README.md 51.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 114
go env -w GOPROXY=https://goproxy.cn,direct
# go env -w GOPROXY=https://mirrors.aliyun.com/goproxy/
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 143 144 145
```shell
go run main.go help
```

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
170
   help, h                                                        Shows a list of commands or help for one command
171 172

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

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

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

徐晓伟's avatar
徐晓伟 已提交
182
    ```shell
183
    $ go run main.go access-request --help
徐晓伟's avatar
徐晓伟 已提交
184
    NAME:
185
       gitlab-go access-request - 群组和项目访问请求 API,中文文档:https://docs.gitlab.cn/jh/api/access_requests.html
徐晓伟's avatar
徐晓伟 已提交
186 187
    
    USAGE:
188
       gitlab-go access-request command [command options] [arguments...]
徐晓伟's avatar
徐晓伟 已提交
189 190
    
    COMMANDS:
191 192 193
       group, groups      为群组列出访问请求
       project, projects  为项目列出访问请求
       help, h            Shows a list of commands or help for one command
徐晓伟's avatar
徐晓伟 已提交
194 195 196
    
    OPTIONS:
       --base-url value  实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
徐晓伟's avatar
徐晓伟 已提交
197
       --token value     your_access_token
198 199 200 201
       --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
徐晓伟 已提交
202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221
       --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
徐晓伟 已提交
222
       --token value     your_access_token
223 224 225 226
       --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)
227
       --id value        项目 ID 或 URL 编码的路径
徐晓伟's avatar
徐晓伟 已提交
228 229
       --help, -h        show help
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
230

231 232 233 234 235 236 237 238 239 240 241
- [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:
242 243 244 245 246
       list                列出仓库内存储库
       list-tags           列出仓库里存储库的标签
       get-tag             获取仓库里存储库的某个标签的详情
       delete-tag, rm-tag  删除仓库里存储库的某个标签
       help, h             Shows a list of commands or help for one command
247 248
    
    OPTIONS:
249 250 251 252 253 254 255 256
       --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
257
       --tag-name value    标签的名称
258
       --help, -h          show help
259 260
    ```

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

徐晓伟's avatar
徐晓伟 已提交
263
    ```shell
264
    $ go run main.go instance-level-ci-variable --help
徐晓伟's avatar
徐晓伟 已提交
265
    NAME:
266
       gitlab-go instance-level-ci-variable - 实例级 CI/CD 变量 API,中文文档:https://docs.gitlab.cn/jh/api/instance_level_ci_variables.html
徐晓伟's avatar
徐晓伟 已提交
267 268
    
    USAGE:
269
       gitlab-go instance-level-ci-variable command [command options] [arguments...]
徐晓伟's avatar
徐晓伟 已提交
270 271
    
    COMMANDS:
徐晓伟's avatar
徐晓伟 已提交
272
       list     列出所有实例变量
徐晓伟's avatar
徐晓伟 已提交
273 274 275 276 277
       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
278 279 280 281
       --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)
282 283 284
       --help, -h        show help
    ```

徐晓伟's avatar
徐晓伟 已提交
285 286 287 288 289 290 291 292 293 294 295
- [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:
徐晓伟's avatar
徐晓伟 已提交
296 297 298
       list        列出议题
       delete, rm  删除议题
       help, h     Shows a list of commands or help for one command
徐晓伟's avatar
徐晓伟 已提交
299 300
    
    OPTIONS:
301 302 303 304
       --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)
305 306
       --print-json               打印 JSON (default: false)
       --print-time               打印时间 (default: false)
307
       --recursion                递归 (default: false)
308 309 310
       --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 相似且与其冲突。
311
       --confidential             筛选私密议题与公开议题。 (default: false)
312 313
       --due-date value           返回没有截止日期、已经逾期、本周内逾期、本月内逾期或介于两周前和下个月之间逾期的议题。可接受的值:0(没有截止日期)、any、today、tomorrow、overdue、week、month、next_month_and_previous_two_weeks。
       --iids value               返回包含给定 iid 的议题。
314
       --in value                 修改 search 属性的范围。可以使用 title、description 或使用半角逗号对他们进行连接。默认值是 title,description。 (default: "title,description")
315 316 317 318 319
       --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 则返回使用至少一个表情回应的议题。
320 321
       --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")
322 323
       --search value             根据 title 和 description 搜索议题。
       --sort value               按照 asc 或者 desc 排序 (default: "desc")
324 325
       --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)
326 327
       --created-after value      对于给定的时间戳,返回不早于该时间创建的议题。时间戳应符合 ISO 8601 格式(2019-03-15T08:00:00Z)
       --created-before value     对于给定的时间戳,返回不晚于该时间创建的议题。时间戳应符合 ISO 8601 格式(2019-03-15T08:00:00Z)。
徐晓伟's avatar
徐晓伟 已提交
328
       --issue-id value           项目议题的内部 ID
329
       --help, -h                 show help
徐晓伟's avatar
徐晓伟 已提交
330 331
    ```

332 333 334 335 336 337 338 339 340 341 342
- [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:
343
       get                                    获取(下载)作业产物
344 345 346 347 348 349
       download, dl                           下载产物归档文件(未完成)
       delete, rm                             删除作业产物
       delete-project, delete-projects, rm-p  删除项目产物
       help, h                                Shows a list of commands or help for one command
    
    OPTIONS:
350 351 352 353 354 355
       --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
徐晓伟 已提交
356
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
357

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

徐晓伟's avatar
徐晓伟 已提交
360
    ```shell
徐晓伟's avatar
徐晓伟 已提交
361
    $ go run main.go job --help
徐晓伟's avatar
徐晓伟 已提交
362
    NAME:
徐晓伟's avatar
徐晓伟 已提交
363
       gitlab-go job - 作业 API,中文文档:https://docs.gitlab.cn/jh/api/jobs.html
徐晓伟's avatar
徐晓伟 已提交
364 365
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
366
       gitlab-go job command [command options] [arguments...]
徐晓伟's avatar
徐晓伟 已提交
367 368 369 370 371 372 373 374
    
    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%]
       --token value     your_access_token
375 376
       --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)
377 378
       --print-json      打印 JSON (default: false)
       --print-time      打印时间 (default: false)
379
       --recursion       递归 (default: false)
徐晓伟's avatar
徐晓伟 已提交
380
       --sort value      按照 asc 或者 desc 排序 (default: "desc")
381 382
       --id value        项目 ID 或 URL 编码的路径
       --scope value     要显示的作业范围。以下之一或数组:created、pending、running、failed、success、canceled、skipped、waiting_for_resource 或 manual。范围如果未提供,则返回所有作业。
徐晓伟's avatar
徐晓伟 已提交
383 384
       --help, -h        show help
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
385

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

徐晓伟's avatar
徐晓伟 已提交
388
    ```shell
389
    $ go run main.go pipeline --help
徐晓伟's avatar
徐晓伟 已提交
390
    NAME:
391
       gitlab-go pipeline - 流水线 API,中文文档:https://docs.gitlab.cn/jh/api/pipelines.html
徐晓伟's avatar
徐晓伟 已提交
392 393
    
    USAGE:
394
       gitlab-go pipeline command [command options] [arguments...]
徐晓伟's avatar
徐晓伟 已提交
395 396
    
    COMMANDS:
397 398
       list     列出项目流水线
       help, h  Shows a list of commands or help for one command
徐晓伟's avatar
徐晓伟 已提交
399 400 401 402
    
    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
403
       --sort value      按照 asc 或者 desc 排序 (default: "desc")
404 405 406 407
       --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
徐晓伟 已提交
408 409 410
       --id value        项目 ID 或 URL 编码的路径
       --help, -h        show help
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
411

412
- [project - 项目 API](https://docs.gitlab.cn/jh/api/projects.html)
413 414

    ```shell
415
    $ go run main.go project --help
416
    NAME:
417
       gitlab-go project - 项目 API,中文文档:https://docs.gitlab.cn/jh/api/projects.html
418 419
    
    USAGE:
420
       gitlab-go project command [command options] [arguments...]
421 422
    
    COMMANDS:
423
       list     列出所有项目
424 425 426
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
427 428 429 430 431
       --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)
432 433
       --print-json         打印 JSON (default: false)
       --print-time         打印时间 (default: false)
434 435
       --search value       根据 title 和 description 搜索议题。
       --search-namespaces  匹配搜索条件时包括上级命名空间。默认为 false。 (default: false)
436
       --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")
437
       --help, -h           show help
438 439
    ```

440 441 442
### test

```shell
徐晓伟's avatar
:memo:  
徐晓伟 已提交
443
go test ./... -v
444 445 446 447 448
```

### build

```shell
徐晓伟's avatar
徐晓伟 已提交
449 450 451 452 453
go build
# GOOS=:设置构建的目标操作系统(darwin | freebsd | linux | windows)
# GOARCH=:设置构建的目标操作系统(386 | amd64 | arm | arm64)
# -v:打印编译过程中的详细信息
# -ldflags:设置在编译时传递给链接器的参数
徐晓伟's avatar
徐晓伟 已提交
454 455 456 457
# -ldflags "-s -w -buildid="
#                           -s: 删除符号表信息,减小可执行文件的大小。
#                           -w: 删除调试信息,使可执行文件在运行时不会打印调试信息。
#                           -buildid=: 删除构建ID,使可执行文件在运行时不会打印构建ID。
徐晓伟's avatar
徐晓伟 已提交
458 459
# -trimpath:去掉所有包含 go path 的路径
# -o:指定构建后输出的文件名
460
```
徐晓伟's avatar
徐晓伟 已提交
461 462 463 464

- Windows
    - amd64
        ```shell
465
        go build -o buildinfo/buildinfo.exe buildinfo/buildinfo.go
徐晓伟's avatar
徐晓伟 已提交
466
        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= -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
徐晓伟 已提交
467 468 469
        ```
    - arm64
        ```shell
470
        go build -o buildinfo/buildinfo.exe buildinfo/buildinfo.go
徐晓伟's avatar
徐晓伟 已提交
471
        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= -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
徐晓伟 已提交
472 473 474 475 476
        ```

- Linux
    - amd64
        ```shell
477
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
徐晓伟's avatar
徐晓伟 已提交
478
        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= -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
徐晓伟 已提交
479 480 481
        ```
    - arm64
        ```shell
482
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
徐晓伟's avatar
徐晓伟 已提交
483
        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= -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
徐晓伟 已提交
484 485 486 487 488
        ```

- Darwin
    - amd64
        ```shell
489
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
徐晓伟's avatar
徐晓伟 已提交
490
        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= -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
徐晓伟 已提交
491 492 493
        ```
    - arm64
        ```shell
494
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
徐晓伟's avatar
徐晓伟 已提交
495
        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= -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
徐晓伟 已提交
496
        ```