README.md 56.9 KB
Newer Older
徐晓伟's avatar
徐晓伟 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
<div align="center" style="text-align: center;">
    <h1>gitlab-go</h1>
    <h3>GitLab Go 脚手架</h3>
    <a target="_blank" href="https://github.com/996icu/996.ICU/blob/master/LICENSE">
        <img alt="License-Anti" src="https://img.shields.io/badge/License-Anti 996-blue.svg">
    </a>
    <a target="_blank" href="https://996.icu/#/zh_CN">
        <img alt="Link-996" src="https://img.shields.io/badge/Link-996.icu-red.svg">
    </a>
    <a target="_blank" href="https://qm.qq.com/cgi-bin/qm/qr?k=ZieC6s1WB4njfVbrDHYgoNS8YpT26VtF&jump_from=webapi">
        <img alt="QQ群" src="https://img.shields.io/badge/QQ群-696503132-blue.svg"/>
    </a>
</div>

<p></p>

<div align="center" style="text-align: center;">
    <a target="_blank" href="https://work.weixin.qq.com/gm/75cfc47d6a341047e4b6aca7389bdfa8">
        <img alt="企业微信群" src="static/wechat-work.jpg" height="100"/>
    </a>
</div>

<p></p>

<div align="center" style="text-align: center;">
    基于 go 语言的 gitlab 脚手架
</div>

<p></p>

<div align="center" style="text-align: center;">
  为简化开发工作、提高生产率、解决常见问题而生
</div>

<p></p>

<div align="center" style="text-align: center;">

  <a target="_blank" href="https://space.bilibili.com/198580655">
    <img alt="bilibili 粉丝" src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fapi.spencerwoo.com%2Fsubstats%2F%3Fsource%3Dbilibili%26queryKey%3D198580655&label=bilibili%20fans&query=%24.data.totalSubs&logo=bilibili">
  </a>

  <a target="_blank" href="https://blog.csdn.net/qq_32596527">
    <img alt="CSDN 码龄" src="https://img.shields.io/badge/dynamic/xml?color=orange&label=CSDN&query=%2F%2Fdiv%5B%40class%3D%27person-code-age%27%5D%5B1%5D%2Fspan%5B1%5D%2Ftext%28%29%5B1%5D&url=https%3A%2F%2Fblog.csdn.net%2Fqq_32596527&logo=">
  </a>

  <a target="_blank" href="https://blog.csdn.net/qq_32596527">
    <img alt="CSDN 粉丝" src="https://img.shields.io/badge/dynamic/xml?color=orange&label=CSDN&prefix=%E7%B2%89%E4%B8%9D&query=%2F%2Fli%5B4%5D%2Fa%5B1%5D%2Fdiv%5B%40class%3D%27user-profile-statistics-num%27%5D%5B1%5D%2Ftext%28%29%5B1%5D&url=https%3A%2F%2Fblog.csdn.net%2Fqq_32596527&logo=">
  </a>

  <a target="_blank" href="https://blog.csdn.net/qq_32596527">
    <img alt="CSDN 访问" src="https://img.shields.io/badge/dynamic/xml?color=orange&label=CSDN&prefix=%E8%AE%BF%E9%97%AE&query=//span[1]/div[@class='user-profile-statistics-num'][1]/text()[1]&url=https%3A%2F%2Fblog.csdn.net%2Fqq_32596527&logo=">
  </a>

  <a target="_blank" href="https://blog.csdn.net/qq_32596527">
    <img alt="CSDN 博客" src="https://img.shields.io/badge/dynamic/json?color=orange&label=CSDN&prefix=%E5%8D%9A%E5%AE%A2&query=%24.data.blog&suffix=%E7%AF%87&url=https%3A%2F%2Fblog.csdn.net%2Fcommunity%2Fhome-api%2Fv1%2Fget-tab-total%3Fusername%3Dqq_32596527&logo=">
  </a>

  <a target="_blank" href="https://www.jetbrains.com/idea">
    <img alt="IntelliJ IDEA" src="https://img.shields.io/static/v1?logo=&message=IntelliJ IDEA">
  </a>

  <a target="_blank" href="https://github.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="GitHub stars" src="https://img.shields.io/github/stars/xuxiaowei-com-cn/gitlab-go?logo=github">
  </a>

  <a target="_blank" href="https://github.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="GitHub forks" src="https://img.shields.io/github/forks/xuxiaowei-com-cn/gitlab-go?logo=github">
  </a>

  <a target="_blank" href="https://github.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="GitHub watchers" src="https://img.shields.io/github/watchers/xuxiaowei-com-cn/gitlab-go?logo=github">
  </a>

  <a target="_blank" href="https://github.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="GitHub last commit" src="https://img.shields.io/github/last-commit/xuxiaowei-com-cn/gitlab-go">
  </a>

  <a target="_blank" href="https://gitee.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="码云Gitee stars" src="https://gitee.com/xuxiaowei-com-cn/gitlab-go/badge/star.svg?theme=blue">
  </a>

  <a target="_blank" href="https://gitee.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="码云Gitee forks" src="https://gitee.com/xuxiaowei-com-cn/gitlab-go/badge/fork.svg?theme=blue">
  </a>

  <a target="_blank" href="https://gitlab.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="Gitlab stars" src="https://badgen.net/gitlab/stars/xuxiaowei-com-cn/gitlab-go?icon=gitlab">
  </a>

  <a target="_blank" href="https://gitlab.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="Gitlab forks" src="https://badgen.net/gitlab/forks/xuxiaowei-com-cn/gitlab-go?icon=gitlab">
  </a>

  <a target="_blank" href="https://github.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="OSCS Status" src="https://www.oscs1024.com/platform/badge/xuxiaowei-com-cn/gitlab-go.svg?size=small">
  </a>

  <a target="_blank" href="https://github.com/xuxiaowei-com-cn/gitlab-go">
    <img alt="total lines" src="https://tokei.rs/b1/github/xuxiaowei-com-cn/gitlab-go">
  </a>

  <a target="_blank" href="https://www.apache.org/licenses/LICENSE-2.0">
    <img alt="code style" src="https://img.shields.io/badge/license-Apache 2-blue">
  </a>
</div>
107 108 109 110 111 112

## 开发命令

### get

```shell
113
go env -w GOPROXY=https://goproxy.cn,direct
徐晓伟's avatar
徐晓伟 已提交
114
# go env -w GOPROXY=https://mirrors.aliyun.com/goproxy,direct
115
go get -u github.com/urfave/cli/v2
徐晓伟's avatar
徐晓伟 已提交
116
go get -u github.com/xanzy/go-gitlab
117 118
go get -u github.com/xuxiaowei-com-cn/git-go@main
go get -u gopkg.in/yaml.v3
119 120 121 122 123 124 125 126
```

### mod

```shell
go mod tidy
```

徐晓伟's avatar
徐晓伟 已提交
127 128 129 130
```shell
go mod download
```

131 132 133 134 135 136 137 138
### run

```shell
go run main.go
```

### run help

徐晓伟's avatar
徐晓伟 已提交
139 140 141
- Windows 环境为 %xxx%
- Linux 环境为 $xxx

徐晓伟's avatar
徐晓伟 已提交
142
```shell
143
go run main.go --help
徐晓伟's avatar
徐晓伟 已提交
144 145
```

146
```shell
徐晓伟's avatar
:memo:  
徐晓伟 已提交
147
$ go run main.go --help
148
NAME:
徐晓伟's avatar
:memo:  
徐晓伟 已提交
149
   gitlab-go - 基于 Go 语言开发的 GitLab 命令行工具
150 151

USAGE:
徐晓伟's avatar
:memo:  
徐晓伟 已提交
152
   gitlab-go [global options] command [command options] [arguments...]
153

徐晓伟's avatar
徐晓伟 已提交
154
VERSION:
徐晓伟's avatar
:memo:  
徐晓伟 已提交
155
   dev
徐晓伟's avatar
徐晓伟 已提交
156

徐晓伟's avatar
徐晓伟 已提交
157 158 159
AUTHOR:
   徐晓伟 <xuxiaowei@xuxiaowei.com.cn>

160
COMMANDS:
161
   access-request, access-requests, ar                            群组和项目访问请求 API,中文文档:https://docs.gitlab.cn/jh/api/access_requests.html
徐晓伟's avatar
徐晓伟 已提交
162
   board, boards                                                  项目议题板 API,中文文档:https://docs.gitlab.cn/jh/api/boards.html
163
   container-registry, cr                                         容器仓库 API,中文文档:https://docs.gitlab.cn/jh/api/container_registry.html
164
   instance-level-ci-variable, instance-level-ci-variables, ilcv  实例级 CI/CD 变量 API,中文文档:https://docs.gitlab.cn/jh/api/instance_level_ci_variables.html
徐晓伟's avatar
徐晓伟 已提交
165
   issue, issues                                                  议题 API,中文文档:https://docs.gitlab.cn/jh/api/issues.html
166 167 168 169
   job-artifact, job-artifacts, ja                                作业产物 API,中文文档:https://docs.gitlab.cn/jh/api/job_artifacts.html
   job, jobs, j                                                   作业 API,中文文档:https://docs.gitlab.cn/jh/api/jobs.html
   pipeline, pipelines, pl                                        流水线 API,中文文档:https://docs.gitlab.cn/jh/api/pipelines.html
   project, projects, p                                           项目 API,中文文档:https://docs.gitlab.cn/jh/api/projects.html
徐晓伟's avatar
徐晓伟 已提交
170
   mix-delete, mix-rm                                             删除(混合命令,多接口命令)
171
   help, h                                                        Shows a list of commands or help for one command
172 173

GLOBAL OPTIONS:
徐晓伟's avatar
徐晓伟 已提交
174 175
   --help, -h     show help
   --version, -v  print the version
徐晓伟's avatar
徐晓伟 已提交
176 177 178

COPYRIGHT:
   徐晓伟工作室 <xuxiaowei@xuxiaowei.com.cn>
179 180
```

181
- [access-request - 群组和项目访问请求 API](https://docs.gitlab.cn/jh/api/access_requests.html)
徐晓伟's avatar
:memo:  
徐晓伟 已提交
182

徐晓伟's avatar
徐晓伟 已提交
183
    ```shell
184
    $ go run main.go access-request --help
徐晓伟's avatar
徐晓伟 已提交
185
    NAME:
186
       gitlab-go access-request - 群组和项目访问请求 API,中文文档:https://docs.gitlab.cn/jh/api/access_requests.html
徐晓伟's avatar
徐晓伟 已提交
187 188
    
    USAGE:
189
       gitlab-go access-request command [command options] [arguments...]
徐晓伟's avatar
徐晓伟 已提交
190 191
    
    COMMANDS:
192 193 194
       group, groups      为群组列出访问请求
       project, projects  为项目列出访问请求
       help, h            Shows a list of commands or help for one command
徐晓伟's avatar
徐晓伟 已提交
195 196 197
    
    OPTIONS:
       --base-url value  实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
徐晓伟's avatar
徐晓伟 已提交
198
       --token value     your_access_token
199 200 201 202
       --page value      页码(默认:1),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 1)
       --per-page value  每页列出的项目数(默认:20;最大:100),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 20)
       --print-json      打印 JSON (default: false)
       --print-time      打印时间 (default: false)
徐晓伟's avatar
徐晓伟 已提交
203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222
       --id value        项目 ID 或 URL 编码的路径
       --help, -h        show help
    ```

- [board - 项目议题板 API](https://docs.gitlab.cn/jh/api/boards.html)

    ```shell
    $ go run main.go board --help
    NAME:
       gitlab-go board - 项目议题板 API,中文文档:https://docs.gitlab.cn/jh/api/boards.html
    
    USAGE:
       gitlab-go board command [command options] [arguments...]
    
    COMMANDS:
       list     列出项目议题板
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
       --base-url value  实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
徐晓伟's avatar
徐晓伟 已提交
223
       --token value     your_access_token
224 225 226 227
       --page value      页码(默认:1),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 1)
       --per-page value  每页列出的项目数(默认:20;最大:100),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 20)
       --print-json      打印 JSON (default: false)
       --print-time      打印时间 (default: false)
228
       --id value        项目 ID 或 URL 编码的路径
徐晓伟's avatar
徐晓伟 已提交
229 230
       --help, -h        show help
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
231

232 233 234 235 236 237 238 239 240 241 242
- [container-registry - 容器仓库 API](https://docs.gitlab.cn/jh/api/container_registry.html)

    ```shell
    $ go run main.go container-registry --help
    NAME:
       gitlab-go container-registry - 容器仓库 API,中文文档:https://docs.gitlab.cn/jh/api/container_registry.html
    
    USAGE:
       gitlab-go container-registry command [command options] [arguments...]
    
    COMMANDS:
243 244 245 246 247
       list                列出仓库内存储库
       list-tags           列出仓库里存储库的标签
       get-tag             获取仓库里存储库的某个标签的详情
       delete-tag, rm-tag  删除仓库里存储库的某个标签
       help, h             Shows a list of commands or help for one command
248 249
    
    OPTIONS:
250 251 252 253 254 255 256 257
       --base-url value    实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
       --token value       your_access_token
       --page value        页码(默认:1),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 1)
       --per-page value    每页列出的项目数(默认:20;最大:100),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 20)
       --print-json        打印 JSON (default: false)
       --print-time        打印时间 (default: false)
       --id value          项目 ID 或 URL 编码的路径
       --repository value  仓库里存储库的 ID
258
       --tag-name value    标签的名称
259
       --help, -h          show help
260 261
    ```

262
- [instance-level-ci-variable - 实例级 CI/CD 变量 API](https://docs.gitlab.cn/jh/api/instance_level_ci_variables.html)
徐晓伟's avatar
:memo:  
徐晓伟 已提交
263

徐晓伟's avatar
徐晓伟 已提交
264
    ```shell
265
    $ go run main.go instance-level-ci-variable --help
徐晓伟's avatar
徐晓伟 已提交
266
    NAME:
267
       gitlab-go instance-level-ci-variable - 实例级 CI/CD 变量 API,中文文档:https://docs.gitlab.cn/jh/api/instance_level_ci_variables.html
徐晓伟's avatar
徐晓伟 已提交
268 269
    
    USAGE:
270
       gitlab-go instance-level-ci-variable command [command options] [arguments...]
徐晓伟's avatar
徐晓伟 已提交
271 272
    
    COMMANDS:
徐晓伟's avatar
徐晓伟 已提交
273
       list     列出所有实例变量
徐晓伟's avatar
徐晓伟 已提交
274 275 276 277 278
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
       --base-url value  实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
       --token value     your_access_token
279 280 281 282
       --page value      页码(默认:1),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 1)
       --per-page value  每页列出的项目数(默认:20;最大:100),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 20)
       --print-json      打印 JSON (default: false)
       --print-time      打印时间 (default: false)
283 284 285
       --help, -h        show help
    ```

徐晓伟's avatar
徐晓伟 已提交
286 287 288 289 290 291 292 293 294 295 296
- [issue - 议题 API](https://docs.gitlab.cn/jh/api/issues.html)

    ```shell
    $ go run main.go issue --help
    NAME:
       gitlab-go issue - 议题 API,中文文档:https://docs.gitlab.cn/jh/api/issues.html
    
    USAGE:
       gitlab-go issue command [command options] [arguments...]
    
    COMMANDS:
297 298 299 300
       list                    列出议题
       delete, rm              删除议题
       delete-range, rm-range  删除议题(范围)
       help, h                 Shows a list of commands or help for one command
徐晓伟's avatar
徐晓伟 已提交
301 302
    
    OPTIONS:
303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336
       --base-url value                                   实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
       --token value                                      your_access_token
       --page value                                       页码(默认:1),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 1)
       --per-page value                                   每页列出的项目数(默认:20;最大:100),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 20)
       --print-json                                       打印 JSON (default: false)
       --print-time                                       打印时间 (default: false)
       --recursion                                        递归 (default: false)
       --assignee-username value                          对于给定的用户名 username,返回指派给这个用户的议题。与 assignee_id 相似且与其冲突。在免费版中,assignee_username 数组只能包含单个成员,否则将报参数错误提示。
       --author-id value                                  对于给定的用户 id,返回这个用户创建的议题。与 author_username 冲突。与 scope=all 或 scope=assigned_to_me 配合使用。
       --author-username value                            对于给定的用户名 username,返回这个用户创建的议题。与 author_id 相似且与其冲突。
       --confidential                                     筛选私密议题与公开议题。 (default: false)
       --due-date value                                   返回没有截止日期、已经逾期、本周内逾期、本月内逾期或介于两周前和下个月之间逾期的议题。可接受的值:0(没有截止日期)、any、today、tomorrow、overdue、week、month、next_month_and_previous_two_weeks。
       --iids value                                       返回包含给定 iid 的议题。
       --in value                                         修改 search 属性的范围。可以使用 title、description 或使用半角逗号对他们进行连接。默认值是 title,description。 (default: "title,description")
       --issue-type value                                 筛选议题的类型,可选值为 issue、incident 或 test_case。引入于 13.12 版本。
       --iteration-id value                               对于给定的迭代 ID,返回与这个迭代关联的议题。使用 None 则返回未与迭代关联的议题。使用 Any 则返回存在关联迭代的议题。引入于 13.6 版本。
       --milestone value                                  里程碑名称。使用 None 则列出没有里程碑的议题。使用 Any 则列出存在关联里程碑的议题。None 及 Any 的用法将会在未来被弃用,请使用 milestone_id 替代。milestone 与 milestone_id 冲突。
       --milestone-id value                               对于给定的时间段(None、Any、Upcoming 或 Started),返回与该时间段里程碑相关联的议题。使用 None 则列出没有里程碑的议题。使用 Any 则列出存在关联里程碑的议题。使用 Upcoming 则列出与未开始里程碑相关联的议题。使用 Started 则列出与已开始里程碑相关联的议题。milestone 和 milestone_id 冲突。引入于 14.3 版本。
       --my-reaction-emoji value                          对于给定的 emoji,返回用户使用该表情回应的议题。使用 None 则返回没有使用表情回应的议题。使用 Any 则返回使用至少一个表情回应的议题。
       --order-by value                                   返回根据 created_at、due_date、label_priority、milestone_due、popularity、priority、relative_position、title、updated_at 或 weight 排序的议题。默认值是 created_at。 (default: "created_at")
       --scope value                                      返回满足范围 created_by_me、assigned_to_me 或 all 的议题。默认值是 created_by_me。 (default: "created_by_me")
       --search value                                     根据 title 和 description 搜索议题。
       --sort value                                       按照 asc 或者 desc 排序 (default: "desc")
       --state value                                      返回全部 all 议题或仅返回处于 opened 或 closed 状态的议题。 (default: "all")
       --with-labels-details                              若为 true 则返回更详尽的标签信息::name、:color、:description、:description_html、:text_color。默认值是 false。description_html 属性引入于 12.7 版本。 (default: false)
       --created-after value                              对于给定的时间戳,返回不早于该时间创建的议题。时间戳应符合 ISO 8601 格式(2019-03-15T08:00:00Z)
       --created-before value                             对于给定的时间戳,返回不晚于该时间创建的议题。时间戳应符合 ISO 8601 格式(2019-03-15T08:00:00Z)。
       --issue-id value                                   项目议题的内部 ID
       --issue-id-range value [ --issue-id-range value ]  议题ID的范围,支持范围如下:
                                                          单数:1
                                                          多个数字(使用英文逗号隔开):1,2,3,7,8,15
                                                          支持范围:5-10,
                                                          支持范围方向选择:-10(小于等于10,即:从 0 到 10),214-(大于等于214,即:从 214 到 214 + 10000,数据范围不超过 10000)
       --help, -h                                         show help
徐晓伟's avatar
徐晓伟 已提交
337 338
    ```

339 340 341 342 343 344 345 346 347 348 349
- [job-artifact - 作业产物 API](https://docs.gitlab.cn/jh/api/job_artifacts.html)

    ```shell
    $ go run main.go job-artifact --help
    NAME:
       gitlab-go job-artifact - 作业产物 API,中文文档:https://docs.gitlab.cn/jh/api/job_artifacts.html
    
    USAGE:
       gitlab-go job-artifact command [command options] [arguments...]
    
    COMMANDS:
350
       get                                    获取(下载)作业产物
351 352
       download, dl                           下载产物归档文件(未完成)
       delete, rm                             删除作业产物
353
       delete-project, delete-projects, rm-p  删除项目产物(计划删除,如需立即删除请使用混合命令)
354 355 356
       help, h                                Shows a list of commands or help for one command
    
    OPTIONS:
357 358 359 360 361 362
       --base-url value        实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
       --token value           your_access_token
       --id value              项目 ID 或 URL 编码的路径
       --job-id value          作业 ID
       --artifacts-name value  保存产物名称(保存到系统磁盘的名称) (default: "artifacts.zip")
       --help, -h              show help
徐晓伟's avatar
徐晓伟 已提交
363
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
364

徐晓伟's avatar
徐晓伟 已提交
365
- [job - 作业 API](https://docs.gitlab.cn/jh/api/jobs.html)
徐晓伟's avatar
:memo:  
徐晓伟 已提交
366

徐晓伟's avatar
徐晓伟 已提交
367
    ```shell
徐晓伟's avatar
徐晓伟 已提交
368
    $ go run main.go job --help
徐晓伟's avatar
徐晓伟 已提交
369
    NAME:
徐晓伟's avatar
徐晓伟 已提交
370
       gitlab-go job - 作业 API,中文文档:https://docs.gitlab.cn/jh/api/jobs.html
徐晓伟's avatar
徐晓伟 已提交
371 372
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
373
       gitlab-go job command [command options] [arguments...]
徐晓伟's avatar
徐晓伟 已提交
374 375 376
    
    COMMANDS:
       list     列出项目作业
377
       erase    删除作业(删除作业产物和作业日志)
徐晓伟's avatar
徐晓伟 已提交
378 379 380
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396
       --base-url value                               实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
       --token value                                  your_access_token
       --page value                                   页码(默认:1),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 1)
       --per-page value                               每页列出的项目数(默认:20;最大:100),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 20)
       --print-json                                   打印 JSON (default: false)
       --print-time                                   打印时间 (default: false)
       --recursion                                    递归 (default: false)
       --sort value                                   按照 asc 或者 desc 排序 (default: "desc")
       --id value                                     项目 ID 或 URL 编码的路径
       --job-id-range value [ --job-id-range value ]  Job ID的范围,支持范围如下:
                                                      单数:1
                                                      多个数字(使用英文逗号隔开):1,2,3,7,8,15
                                                      支持范围:5-10,
                                                      支持范围方向选择:-10(小于等于10,即:从 0 到 10),214-(大于等于214,即:从 214 到 214 + 10000,数据范围不超过 10000)
       --scope value                                  要显示的作业范围。以下之一或数组:created、pending、running、failed、success、canceled、skipped、waiting_for_resource 或 manual。范围如果未提供,则返回所有作业。
       --help, -h                                     show help
徐晓伟's avatar
徐晓伟 已提交
397
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
398

399
- [pipeline - 流水线 API](https://docs.gitlab.cn/jh/api/pipelines.html)
徐晓伟's avatar
:memo:  
徐晓伟 已提交
400

徐晓伟's avatar
徐晓伟 已提交
401
    ```shell
402
    $ go run main.go pipeline --help
徐晓伟's avatar
徐晓伟 已提交
403
    NAME:
404
       gitlab-go pipeline - 流水线 API,中文文档:https://docs.gitlab.cn/jh/api/pipelines.html
徐晓伟's avatar
徐晓伟 已提交
405 406
    
    USAGE:
407
       gitlab-go pipeline command [command options] [arguments...]
徐晓伟's avatar
徐晓伟 已提交
408 409
    
    COMMANDS:
410 411
       list     列出项目流水线
       help, h  Shows a list of commands or help for one command
徐晓伟's avatar
徐晓伟 已提交
412 413 414 415
    
    OPTIONS:
       --base-url value  实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
       --token value     your_access_token
416
       --sort value      按照 asc 或者 desc 排序 (default: "desc")
417 418 419 420
       --page value      页码(默认:1),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 1)
       --per-page value  每页列出的项目数(默认:20;最大:100),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 20)
       --print-json      打印 JSON (default: false)
       --print-time      打印时间 (default: false)
421
       --recursion       递归 (default: false)
徐晓伟's avatar
徐晓伟 已提交
422 423 424
       --id value        项目 ID 或 URL 编码的路径
       --help, -h        show help
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
425

426
- [project - 项目 API](https://docs.gitlab.cn/jh/api/projects.html)
427 428

    ```shell
429
    $ go run main.go project --help
430
    NAME:
431
       gitlab-go project - 项目 API,中文文档:https://docs.gitlab.cn/jh/api/projects.html
432 433
    
    USAGE:
434
       gitlab-go project command [command options] [arguments...]
435 436
    
    COMMANDS:
437
       list     列出所有项目
438 439 440
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
441 442 443 444 445
       --base-url value     实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
       --token value        your_access_token
       --sort value         按照 asc 或者 desc 排序 (default: "desc")
       --page value         页码(默认:1),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 1)
       --per-page value     每页列出的项目数(默认:20;最大:100),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 20)
446 447
       --print-json         打印 JSON (default: false)
       --print-time         打印时间 (default: false)
448 449
       --search value       根据 title 和 description 搜索议题。
       --search-namespaces  匹配搜索条件时包括上级命名空间。默认为 false。 (default: false)
450
       --order-by value     返回按 id、name、path、created_at、updated_at、last_activity_at 或 similarity 字段排序的项目。repository_size、storage_size、packages_size 或 wiki_size 字段只允许管理员使用。similarity(引入于 14.1 版本)仅在搜索 时可用,并且仅限于当前用户所属的项目。默认是created_at。 (default: "created_at")
451
       --help, -h           show help
452 453
    ```

徐晓伟's avatar
徐晓伟 已提交
454
- 删除(混合命令,多接口命令)
455

456 457 458
    ```shell
    $ go run main.go mix-delete --help
    NAME:
徐晓伟's avatar
徐晓伟 已提交
459
       gitlab-go mix-delete - 删除(混合命令,多接口命令)
460 461 462 463 464
    
    USAGE:
       gitlab-go mix-delete command [command options] [arguments...]
    
    COMMANDS:
徐晓伟's avatar
徐晓伟 已提交
465 466
       artifact, artifacts          根据项目路径/ID、流水线IID范围删除产物(混合命令,多接口命令,立即删除)
       all-artifact, all-artifacts  根据项目路径/ID删除所有产物(混合命令,多接口命令,立即删除)
467 468
       job, jobs                    根据项目路径/ID、流水线IID范围删除作业产物和作业日志(混合命令,多接口命令,立即删除)
       all-job, all-jobs            根据项目路径/ID删除所有作业产物和作业日志(混合命令,多接口命令,立即删除)
469
       help, h                      Shows a list of commands or help for one command
470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485
    
    OPTIONS:
       --base-url value                         实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
       --token value                            your_access_token
       --sort value                             按照 asc 或者 desc 排序 (default: "desc")
       --page value                             页码(默认:1),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 1)
       --per-page value                         每页列出的项目数(默认:20;最大:100),中文文档 https://docs.gitlab.cn/jh/api/rest/index.html#pagination (default: 20)
       --id value                               项目 ID 或 URL 编码的路径
       --iid-range value [ --iid-range value ]  流水线ID的范围,支持范围如下:
                                                单数:1
                                                多个数字(使用英文逗号隔开):1,2,3,7,8,15
                                                支持范围:5-10,
                                                支持范围方向选择:-10(小于等于10,即:从 0 到 10),214-(大于等于214,即:从 214 到 214 + 10000,数据范围不超过 10000)
       --help, -h                               show help
    ```

486 487 488
### test

```shell
徐晓伟's avatar
:memo:  
徐晓伟 已提交
489
go test ./... -v
490 491 492 493 494
```

### build

```shell
徐晓伟's avatar
徐晓伟 已提交
495 496 497 498 499
go build
# GOOS=:设置构建的目标操作系统(darwin | freebsd | linux | windows)
# GOARCH=:设置构建的目标操作系统(386 | amd64 | arm | arm64)
# -v:打印编译过程中的详细信息
# -ldflags:设置在编译时传递给链接器的参数
徐晓伟's avatar
徐晓伟 已提交
500 501 502 503
# -ldflags "-s -w -buildid="
#                           -s: 删除符号表信息,减小可执行文件的大小。
#                           -w: 删除调试信息,使可执行文件在运行时不会打印调试信息。
#                           -buildid=: 删除构建ID,使可执行文件在运行时不会打印构建ID。
徐晓伟's avatar
徐晓伟 已提交
504 505
# -trimpath:去掉所有包含 go path 的路径
# -o:指定构建后输出的文件名
506
```
徐晓伟's avatar
徐晓伟 已提交
507 508 509 510

- Windows
    - amd64
        ```shell
511
        go build -o buildinfo/buildinfo.exe buildinfo/buildinfo.go
512
        GOOS=windows GOARCH=amd64 go build -v -ldflags "-s -w -buildid= -X main.BuildDate=$(buildinfo/buildinfo.exe now) -X main.Compiler= -X main.GitCommitBranch=$(buildinfo/buildinfo.exe commitBranch) -X main.GitCommitSha=$(buildinfo/buildinfo.exe commitSha) -X main.GitCommitShortSha=$(buildinfo/buildinfo.exe commitShortSha) -X main.GitCommitTag=$(buildinfo/buildinfo.exe commitTag) -X main.GitCommitTimestamp=$(buildinfo/buildinfo.exe commitTimestamp) -X main.GitTreeState=$(buildinfo/buildinfo.exe git-tree-state) -X main.GitVersion=$(buildinfo/buildinfo.exe commitTag) -X main.GoVersion=$(buildinfo/buildinfo.exe goShortVersion) -X main.Major= -X main.Minor= -X main.Revision= -X main.Platform=windows/amd64 -X main.CiPipelineId= -X main.CiJobId=" -trimpath -o gitlab-go-windows-amd64.exe .
徐晓伟's avatar
徐晓伟 已提交
513 514 515
        ```
    - arm64
        ```shell
516
        go build -o buildinfo/buildinfo.exe buildinfo/buildinfo.go
517
        GOOS=windows GOARCH=arm64 go build -v -ldflags "-s -w -buildid= -X main.BuildDate=$(buildinfo/buildinfo.exe now) -X main.Compiler= -X main.GitCommitBranch=$(buildinfo/buildinfo.exe commitBranch) -X main.GitCommitSha=$(buildinfo/buildinfo.exe commitSha) -X main.GitCommitShortSha=$(buildinfo/buildinfo.exe commitShortSha) -X main.GitCommitTag=$(buildinfo/buildinfo.exe commitTag) -X main.GitCommitTimestamp=$(buildinfo/buildinfo.exe commitTimestamp) -X main.GitTreeState=$(buildinfo/buildinfo.exe git-tree-state) -X main.GitVersion=$(buildinfo/buildinfo.exe commitTag) -X main.GoVersion=$(buildinfo/buildinfo.exe goShortVersion) -X main.Major= -X main.Minor= -X main.Revision= -X main.Platform=windows/arm64 -X main.CiPipelineId= -X main.CiJobId=" -trimpath -o gitlab-go-windows-arm64.exe .
徐晓伟's avatar
徐晓伟 已提交
518 519 520 521 522
        ```

- Linux
    - amd64
        ```shell
523
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
524
        GOOS=linux GOARCH=amd64 go build -v -ldflags "-s -w -buildid= -X main.BuildDate=$(buildinfo/buildinfo now) -X main.Compiler= -X main.GitCommitBranch=$(buildinfo/buildinfo commitBranch) -X main.GitCommitSha=$(buildinfo/buildinfo commitSha) -X main.GitCommitShortSha=$(buildinfo/buildinfo commitShortSha) -X main.GitCommitTag=$(buildinfo/buildinfo commitTag) -X main.GitCommitTimestamp=$(buildinfo/buildinfo commitTimestamp) -X main.GitTreeState=$(buildinfo/buildinfo git-tree-state) -X main.GitVersion=$(buildinfo/buildinfo commitTag) -X main.GoVersion=$(buildinfo/buildinfo goShortVersion) -X main.Major= -X main.Minor= -X main.Revision= -X main.Platform=linux/amd64 -X main.CiPipelineId= -X main.CiJobId=" -trimpath -o gitlab-go-linux-amd64 .
徐晓伟's avatar
徐晓伟 已提交
525 526 527
        ```
    - arm64
        ```shell
528
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
529
        GOOS=linux GOARCH=arm64 go build -v -ldflags "-s -w -buildid= -X main.BuildDate=$(buildinfo/buildinfo now) -X main.Compiler= -X main.GitCommitBranch=$(buildinfo/buildinfo commitBranch) -X main.GitCommitSha=$(buildinfo/buildinfo commitSha) -X main.GitCommitShortSha=$(buildinfo/buildinfo commitShortSha) -X main.GitCommitTag=$(buildinfo/buildinfo commitTag) -X main.GitCommitTimestamp=$(buildinfo/buildinfo commitTimestamp) -X main.GitTreeState=$(buildinfo/buildinfo git-tree-state) -X main.GitVersion=$(buildinfo/buildinfo commitTag) -X main.GoVersion=$(buildinfo/buildinfo goShortVersion) -X main.Major= -X main.Minor= -X main.Revision= -X main.Platform=linux/arm64 -X main.CiPipelineId= -X main.CiJobId=" -trimpath -o gitlab-go-linux-arm64 .
徐晓伟's avatar
徐晓伟 已提交
530 531 532 533 534
        ```

- Darwin
    - amd64
        ```shell
535
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
536
        GOOS=darwin GOARCH=amd64 go build -v -ldflags "-s -w -buildid= -X main.BuildDate=$(buildinfo/buildinfo now) -X main.Compiler= -X main.GitCommitBranch=$(buildinfo/buildinfo commitBranch) -X main.GitCommitSha=$(buildinfo/buildinfo commitSha) -X main.GitCommitShortSha=$(buildinfo/buildinfo commitShortSha) -X main.GitCommitTag=$(buildinfo/buildinfo commitTag) -X main.GitCommitTimestamp=$(buildinfo/buildinfo commitTimestamp) -X main.GitTreeState=$(buildinfo/buildinfo git-tree-state) -X main.GitVersion=$(buildinfo/buildinfo commitTag) -X main.GoVersion=$(buildinfo/buildinfo goShortVersion) -X main.Major= -X main.Minor= -X main.Revision= -X main.Platform=darwin/amd64 -X main.CiPipelineId= -X main.CiJobId=" -trimpath -o gitlab-go-darwin-amd64 .
徐晓伟's avatar
徐晓伟 已提交
537 538 539
        ```
    - arm64
        ```shell
540
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
541
        GOOS=darwin GOARCH=arm64 go build -v -ldflags "-s -w -buildid= -X main.BuildDate=$(buildinfo/buildinfo now) -X main.Compiler= -X main.GitCommitBranch=$(buildinfo/buildinfo commitBranch) -X main.GitCommitSha=$(buildinfo/buildinfo commitSha) -X main.GitCommitShortSha=$(buildinfo/buildinfo commitShortSha) -X main.GitCommitTag=$(buildinfo/buildinfo commitTag) -X main.GitCommitTimestamp=$(buildinfo/buildinfo commitTimestamp) -X main.GitTreeState=$(buildinfo/buildinfo git-tree-state) -X main.GitVersion=$(buildinfo/buildinfo commitTag) -X main.GoVersion=$(buildinfo/buildinfo goShortVersion) -X main.Major= -X main.Minor= -X main.Revision= -X main.Platform=darwin/arm64 -X main.CiPipelineId= -X main.CiJobId=" -trimpath -o gitlab-go-darwin-arm64 .
徐晓伟's avatar
徐晓伟 已提交
542
        ```