README.md 78.2 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 113 114 115 116 117 118 119 120 121 122
## 支持的系统

1. Linux amd64、arm64
2. Windows amd64、arm64
3. Mac amd64、arm64
4. LoongArch 64-bit

# 构建

本项目发布在 GitHub 进行构建,并使用构建后的程序将自己发布到各大代码托管平台,发布过程参见:
[GitHub Actions](https://github.com/xuxiaowei-com-cn/gitlab-go/actions/workflows/go-push.yml)

## 下载

1. [gitee](https://gitee.com/xuxiaowei-com-cn/gitlab-go/releases)
123 124 125
2. [gitlab](https://gitlab.com/xuxiaowei-com-cn/gitlab-go/-/releases)
3. [github](https://github.com/xuxiaowei-com-cn/gitlab-go/releases)
4. [gitlink](https://gitlink.org.cn/xuxiaowei-com-cn/gitlab-go/releases)
126 127 128 129 130 131

## 支持的功能

1. 一键发布到 github,可包含产物上传
2. 一键发布到 gitlab,可包含产物上传,可自定义域名(支持自建 gitlab),支持将产物文件名、链接导出为 map,可供 gitee 使用
3. 一键发布到 gitee,由于 gitee 暂不支持提供上传产物的 API 接口,
徐晓伟's avatar
徐晓伟 已提交
132 133
   本工具支持提供 json 文件(map 形式,键:代表文件名,值:代表下载链接)作为产物,
   本项目使用 [GitLink](https://www.gitlink.org.cn) 作为 gitee 产物链接
134 135
4. 一键发布到 gitlink,可包含产物上传(需要等到官方开放 token 功能,或者联系官方人员申请 token 才能使用),
   本工具支持提供 json 文件(map 形式,键:代表文件名,值:代表下载链接)作为产物
136

137 138 139 140 141
## 开发命令

### get

```shell
142
go env -w GOPROXY=https://goproxy.cn,direct
徐晓伟's avatar
徐晓伟 已提交
143
# go env -w GOPROXY=https://proxy.golang.org,direct
144
# go env -w GOPROXY=https://goproxy.io,direct
徐晓伟's avatar
徐晓伟 已提交
145
# go env -w GOPROXY=https://mirrors.aliyun.com/goproxy,direct
146
# go env -w GOPROXY=https://mirrors.cloud.tencent.com/go,direct
147
go get -u github.com/urfave/cli/v2
徐晓伟's avatar
徐晓伟 已提交
148
go get -u github.com/xanzy/go-gitlab
149 150
go get -u github.com/xuxiaowei-com-cn/git-go@main
go get -u gopkg.in/yaml.v3
151 152 153 154 155 156 157 158
```

### mod

```shell
go mod tidy
```

徐晓伟's avatar
徐晓伟 已提交
159 160 161 162
```shell
go mod download
```

163 164 165 166 167 168 169 170
### run

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

### run help

徐晓伟's avatar
徐晓伟 已提交
171 172 173
- Windows 环境为 %xxx%
- Linux 环境为 $xxx

徐晓伟's avatar
徐晓伟 已提交
174
```shell
175
go run main.go --help
徐晓伟's avatar
徐晓伟 已提交
176 177
```

178
```shell
徐晓伟's avatar
:memo:  
徐晓伟 已提交
179
$ go run main.go --help
180
NAME:
徐晓伟's avatar
:memo:  
徐晓伟 已提交
181
   gitlab-go - 基于 Go 语言开发的 GitLab 命令行工具
182 183

USAGE:
徐晓伟's avatar
徐晓伟 已提交
184
   gitlab-go [global options] command [command options]
185

徐晓伟's avatar
徐晓伟 已提交
186
VERSION:
徐晓伟's avatar
:memo:  
徐晓伟 已提交
187
   dev
徐晓伟's avatar
徐晓伟 已提交
188

徐晓伟's avatar
徐晓伟 已提交
189 190 191
AUTHOR:
   徐晓伟 <xuxiaowei@xuxiaowei.com.cn>

192
COMMANDS:
193 194 195 196
   access-request, access-requests, ar                              群组和项目访问请求 API,中文文档:https://docs.gitlab.cn/jh/api/access_requests.html
   board, boards                                                    项目议题板 API,中文文档:https://docs.gitlab.cn/jh/api/boards.html
   container-registry, cr                                           容器仓库 API,中文文档:https://docs.gitlab.cn/jh/api/container_registry.html
   environments, environment, env                                   环境 API,中文文档:https://docs.gitlab.cn/jh/api/environments.html
徐晓伟's avatar
徐晓伟 已提交
197
   instance-level-ci-variables, instance-level-ci-variable, ilcv    实例级 CI/CD 变量 API,中文文档:https://docs.gitlab.cn/jh/api/instance_level_ci_variables.html
198 199 200 201
   issue, issues                                                    议题 API,中文文档:https://docs.gitlab.cn/jh/api/issues.html
   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
202
   project-level-variables, project-level-variable, plv             项目级别 CI/CD 变量 API,中文文档:https://docs.gitlab.cn/jh/api/project_level_variables.html
203
   project, projects, p                                             项目 API,中文文档:https://docs.gitlab.cn/jh/api/projects.html
204
   protected-branches, pb                                           受保护的分支 API,中文文档:https://docs.gitlab.cn/jh/api/protected_branches.html
205
   mix-archive                                                      归档(混合命令,多接口命令)
徐晓伟's avatar
徐晓伟 已提交
206
   mix-create-project-level-variables                               创建项目级别 CI/CD 变量(混合命令,多接口命令)
207 208 209
   mix-delete, mix-rm                                               删除(混合命令,多接口命令)
   mix-create-environments, mix-create-environment, mix-create-env  创建新环境(混合命令,多接口命令)
   mix-export                                                       导出(混合命令,多接口命令)
210
   mix-protect-branches                                             保护仓库分支(混合命令,多接口命令)
211 212 213
   mix-transfer                                                     转移(混合命令,多接口命令)
   mix-unarchive                                                    取消归档(混合命令,多接口命令)
   help, h                                                          Shows a list of commands or help for one command
214 215

GLOBAL OPTIONS:
徐晓伟's avatar
徐晓伟 已提交
216 217
   --help, -h     show help
   --version, -v  print the version
徐晓伟's avatar
徐晓伟 已提交
218 219 220

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

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

徐晓伟's avatar
徐晓伟 已提交
225
    ```shell
226
    $ go run main.go access-request --help
徐晓伟's avatar
徐晓伟 已提交
227
    NAME:
228
       gitlab-go access-request - 群组和项目访问请求 API,中文文档:https://docs.gitlab.cn/jh/api/access_requests.html
徐晓伟's avatar
徐晓伟 已提交
229 230
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
231
       gitlab-go access-request command [command options]
徐晓伟's avatar
徐晓伟 已提交
232 233
    
    COMMANDS:
234 235 236
       group, groups      为群组列出访问请求
       project, projects  为项目列出访问请求
       help, h            Shows a list of commands or help for one command
徐晓伟's avatar
徐晓伟 已提交
237 238 239
    
    OPTIONS:
       --base-url value  实例地址,例如:https://gitlab.xuxiaowei.com.cn/api/v4 (default: "https://gitlab.com/api/v4") [%CI_API_V4_URL%]
徐晓伟's avatar
徐晓伟 已提交
240
       --token value     your_access_token
241 242 243 244
       --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
徐晓伟 已提交
245 246 247 248 249 250 251 252 253 254 255 256
       --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:
徐晓伟's avatar
徐晓伟 已提交
257
       gitlab-go board command [command options]
徐晓伟's avatar
徐晓伟 已提交
258 259 260 261 262 263 264
    
    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
徐晓伟 已提交
265
       --token value     your_access_token
266 267 268 269
       --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)
270
       --id value        项目 ID 或 URL 编码的路径
徐晓伟's avatar
徐晓伟 已提交
271 272
       --help, -h        show help
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
273

274 275 276 277 278 279 280 281
- [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:
徐晓伟's avatar
徐晓伟 已提交
282
       gitlab-go container-registry command [command options]
283 284
    
    COMMANDS:
285 286 287 288 289
       list                列出仓库内存储库
       list-tags           列出仓库里存储库的标签
       get-tag             获取仓库里存储库的某个标签的详情
       delete-tag, rm-tag  删除仓库里存储库的某个标签
       help, h             Shows a list of commands or help for one command
290 291
    
    OPTIONS:
292 293 294 295 296 297 298 299
       --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
300
       --tag-name value    标签的名称
301
       --help, -h          show help
302 303
    ```

徐晓伟's avatar
徐晓伟 已提交
304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323
- [environments 环境 API](https://docs.gitlab.cn/jh/api/environments.html)

    ```shell
    $ go run main.go environments --help
    NAME:
       gitlab-go environments - 环境 API,中文文档:https://docs.gitlab.cn/jh/api/environments.html
    
    USAGE:
       gitlab-go environments command [command options]
    
    COMMANDS:
       list     列举环境
       create   创建新环境
       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
       --id value            项目 ID 或 URL 编码的路径
       --name value          环境名称
徐晓伟's avatar
徐晓伟 已提交
324
       --external-url value  该环境的链接位置
徐晓伟's avatar
徐晓伟 已提交
325 326 327 328 329 330 331 332
       --tier value          新环境的层级。允许设置的值为 production, staging, testing, development 和 other
       --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)
       --help, -h            show help
    ```

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

徐晓伟's avatar
徐晓伟 已提交
335
    ```shell
徐晓伟's avatar
徐晓伟 已提交
336
    $ go run main.go instance-level-ci-variables --help
徐晓伟's avatar
徐晓伟 已提交
337
    NAME:
徐晓伟's avatar
徐晓伟 已提交
338
       gitlab-go instance-level-ci-variables - 实例级 CI/CD 变量 API,中文文档:https://docs.gitlab.cn/jh/api/instance_level_ci_variables.html
徐晓伟's avatar
徐晓伟 已提交
339 340
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
341
       gitlab-go instance-level-ci-variables command [command options]
徐晓伟's avatar
徐晓伟 已提交
342 343
    
    COMMANDS:
徐晓伟's avatar
徐晓伟 已提交
344
       list     列出所有实例变量
徐晓伟's avatar
徐晓伟 已提交
345 346 347 348 349
       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
350 351 352 353
       --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)
354 355 356
       --help, -h        show help
    ```

徐晓伟's avatar
徐晓伟 已提交
357 358 359 360 361 362 363 364
- [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:
徐晓伟's avatar
徐晓伟 已提交
365
       gitlab-go issue command [command options]
徐晓伟's avatar
徐晓伟 已提交
366 367
    
    COMMANDS:
368 369 370 371
       list                    列出议题
       delete, rm              删除议题
       delete-range, rm-range  删除议题(范围)
       help, h                 Shows a list of commands or help for one command
徐晓伟's avatar
徐晓伟 已提交
372 373
    
    OPTIONS:
374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407
       --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
徐晓伟 已提交
408 409
    ```

410 411 412 413 414 415 416 417
- [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:
徐晓伟's avatar
徐晓伟 已提交
418
       gitlab-go job-artifact command [command options]
419 420
    
    COMMANDS:
421
       get                                    获取(下载)作业产物
422 423
       download, dl                           下载产物归档文件(未完成)
       delete, rm                             删除作业产物
424
       delete-project, delete-projects, rm-p  删除项目产物(计划删除,如需立即删除请使用混合命令)
425 426 427
       help, h                                Shows a list of commands or help for one command
    
    OPTIONS:
428 429 430 431 432 433
       --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
徐晓伟 已提交
434
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
435

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

徐晓伟's avatar
徐晓伟 已提交
438
    ```shell
徐晓伟's avatar
徐晓伟 已提交
439
    $ go run main.go job --help
徐晓伟's avatar
徐晓伟 已提交
440
    NAME:
徐晓伟's avatar
徐晓伟 已提交
441
       gitlab-go job - 作业 API,中文文档:https://docs.gitlab.cn/jh/api/jobs.html
徐晓伟's avatar
徐晓伟 已提交
442 443
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
444
       gitlab-go job command [command options]
徐晓伟's avatar
徐晓伟 已提交
445 446 447
    
    COMMANDS:
       list     列出项目作业
448
       erase    删除作业(删除作业产物和作业日志)
徐晓伟's avatar
徐晓伟 已提交
449 450 451
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467
       --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
徐晓伟 已提交
468
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
469

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

徐晓伟's avatar
徐晓伟 已提交
472
    ```shell
473
    $ go run main.go pipeline --help
徐晓伟's avatar
徐晓伟 已提交
474
    NAME:
475
       gitlab-go pipeline - 流水线 API,中文文档:https://docs.gitlab.cn/jh/api/pipelines.html
徐晓伟's avatar
徐晓伟 已提交
476 477
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
478
       gitlab-go pipeline command [command options]
徐晓伟's avatar
徐晓伟 已提交
479 480
    
    COMMANDS:
481 482
       list     列出项目流水线
       help, h  Shows a list of commands or help for one command
徐晓伟's avatar
徐晓伟 已提交
483 484 485 486
    
    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
487
       --sort value      按照 asc 或者 desc 排序 (default: "desc")
488 489 490 491
       --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)
492
       --recursion       递归 (default: false)
徐晓伟's avatar
徐晓伟 已提交
493 494 495
       --id value        项目 ID 或 URL 编码的路径
       --help, -h        show help
    ```
徐晓伟's avatar
:memo:  
徐晓伟 已提交
496

497 498 499 500 501 502 503 504 505 506 507 508
- [project-level-variables 项目级别 CI/CD 变量 API](https://docs.gitlab.cn/jh/api/project_level_variables.html)

    ```shell
    $ go run main.go project-level-variables --help
    NAME:
       gitlab-go project-level-variables - 项目级别 CI/CD 变量 API,中文文档:https://docs.gitlab.cn/jh/api/project_level_variables.html
    
    USAGE:
       gitlab-go project-level-variables command [command options]
    
    COMMANDS:
       list     列出项目变量
509
       create   创建变量
510 511 512
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
徐晓伟's avatar
徐晓伟 已提交
513 514 515 516 517 518 519 520 521 522 523 524 525 526 527
       --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 编码的路径
       --key value                变量的 key。不能超过 255 个字符。仅支持 A-Z、a-z、0-9 和 _
       --value value              变量的 value
       --variable-type value      变量类型。可用类型为:env_var 和 file (default: "env_var")
       --protected                变量是否受保护。 (default: false)
       --masked                   变量是否隐藏。 (default: false)
       --raw                      变量是否被视为原始字符串。当为 true 时,值中的变量不会扩展 (default: false)
       --environment-scope value  变量的 environment_scope。 (default: "*")
       --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)
       --help, -h                 show help
528 529
    ```

530
- [project - 项目 API](https://docs.gitlab.cn/jh/api/projects.html)
531 532

    ```shell
533
    $ go run main.go project --help
534
    NAME:
535
       gitlab-go project - 项目 API,中文文档:https://docs.gitlab.cn/jh/api/projects.html
536 537
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
538
       gitlab-go project command [command options]
539 540
    
    COMMANDS:
541
       list     列出所有项目
542 543 544
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
545 546
       --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
547
       --owned              当前用户明确拥有的项目。 (default: false)
548 549 550
       --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)
551 552
       --print-json         打印 JSON (default: false)
       --print-time         打印时间 (default: false)
553 554
       --search value       根据 title 和 description 搜索议题。
       --search-namespaces  匹配搜索条件时包括上级命名空间。默认为 false。 (default: false)
555
       --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")
556
       --help, -h           show help
557 558
    ```

559 560 561 562 563 564 565 566 567 568 569 570
- [protected-branches 受保护的分支 API](https://docs.gitlab.cn/jh/api/protected_branches.html)

    ```shell
    $ go run main.go protected-branches --help
    NAME:
       gitlab-go protected-branches - 受保护的分支 API,中文文档:https://docs.gitlab.cn/jh/api/protected_branches.html
    
    USAGE:
       gitlab-go protected-branches command [command options]
    
    COMMANDS:
       list     列出受保护的分支
571
       protect  保护仓库分支
572 573 574
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616
       --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 编码的路径
       --search value                  要搜索的受保护分支的名称或部分名称
       --name value                    分支或通配符的名称
       --push-access-level value       允许推送的访问级别(默认值:40,维护者角色),合法值:
                                       0:NoPermissions
                                       5:MinimalAccessPermissions
                                       10:GuestPermissions
                                       20:ReporterPermissions
                                       30:DeveloperPermissions
                                       40:MaintainerPermissions
                                       50:OwnerPermissions
                                       60:AdminPermissions
                                        (default: 40)
       --merge-access-level value      允许合并的访问级别(默认值:40,维护者角色),合法值:
                                       0:NoPermissions
                                       5:MinimalAccessPermissions
                                       10:GuestPermissions
                                       20:ReporterPermissions
                                       30:DeveloperPermissions
                                       40:MaintainerPermissions
                                       50:OwnerPermissions
                                       60:AdminPermissions
                                        (default: 40)
       --unprotect-access-level value  允许取消保护的访问级别(默认值:40,维护者角色),合法值:
                                       0:NoPermissions
                                       5:MinimalAccessPermissions
                                       10:GuestPermissions
                                       20:ReporterPermissions
                                       30:DeveloperPermissions
                                       40:MaintainerPermissions
                                       50:OwnerPermissions
                                       60:AdminPermissions
                                        (default: 40)
       --allow-force-push              启用后,可以推送到该分支的成员也可以强制推送 (default: false)
       --code-owner-approval-required  如果分支在 CODEOWNERS https://docs.gitlab.cn/jh/user/project/codeowners/index.html 文件中,则阻止推送到此分支。(默认值:false) (default: false)
       --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)
       --help, -h                      show help
617 618
    ```

徐晓伟's avatar
徐晓伟 已提交
619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639
- mix-archive 归档(混合命令,多接口命令)

    ```shell
    $ go run main.go mix-archive --help
    NAME:
       gitlab-go mix-archive - 归档(混合命令,多接口命令)
    
    USAGE:
       gitlab-go mix-archive command [command options]
    
    COMMANDS:
       all      归档所有项目(混合命令,多接口命令)
       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
       --owned           当前用户明确拥有的项目。 (default: false)
       --help, -h        show help
    ```

徐晓伟's avatar
徐晓伟 已提交
640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668
- mix-create-project-level-variables 创建项目级别 CI/CD 变量(混合命令,多接口命令)

    ```shell
    $ go run main.go mix-create-project-level-variables --help
    NAME:
       gitlab-go mix-create-project-level-variables - 创建项目级别 CI/CD 变量(混合命令,多接口命令)
    
    USAGE:
       gitlab-go mix-create-project-level-variables command [command options]
    
    COMMANDS:
       all, a   所有项目创建新变量
       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
       --key value                变量的 key。不能超过 255 个字符。仅支持 A-Z、a-z、0-9 和 _
       --value value              变量的 value
       --variable-type value      变量类型。可用类型为:env_var 和 file (default: "env_var")
       --protected                变量是否受保护。 (default: false)
       --masked                   变量是否隐藏。 (default: false)
       --raw                      变量是否被视为原始字符串。当为 true 时,值中的变量不会扩展 (default: false)
       --environment-scope value  变量的 environment_scope。 (default: "*")
       --print-json               打印 JSON (default: false)
       --print-time               打印时间 (default: false)
       --help, -h                 show help
    ```

徐晓伟's avatar
徐晓伟 已提交
669
- mix-delete 删除(混合命令,多接口命令)
670

671 672 673
    ```shell
    $ go run main.go mix-delete --help
    NAME:
徐晓伟's avatar
徐晓伟 已提交
674
       gitlab-go mix-delete - 删除(混合命令,多接口命令)
675 676
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
677
       gitlab-go mix-delete command [command options]
678 679
    
    COMMANDS:
徐晓伟's avatar
徐晓伟 已提交
680 681
       artifact, artifacts          根据项目路径/ID、流水线IID范围删除产物(混合命令,多接口命令,立即删除)
       all-artifact, all-artifacts  根据项目路径/ID删除所有产物(混合命令,多接口命令,立即删除)
682 683
       job, jobs                    根据项目路径/ID、流水线IID范围删除作业产物和作业日志(混合命令,多接口命令,立即删除)
       all-job, all-jobs            根据项目路径/ID删除所有作业产物和作业日志(混合命令,多接口命令,立即删除)
684
       help, h                      Shows a list of commands or help for one command
685 686 687 688 689 690 691 692 693 694 695 696 697
    
    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)
698
       --allow-failure                          允许失败 (default: false)
699 700 701
       --help, -h                               show help
    ```

徐晓伟's avatar
徐晓伟 已提交
702
- mix-create-environments 创建新环境(混合命令,多接口命令)
徐晓伟's avatar
徐晓伟 已提交
703 704

    ```shell
徐晓伟's avatar
徐晓伟 已提交
705
    $ go run main.go mix-create-environments --help
徐晓伟's avatar
徐晓伟 已提交
706
    NAME:
徐晓伟's avatar
徐晓伟 已提交
707
       gitlab-go mix-create-environments - 创建新环境(混合命令,多接口命令)
徐晓伟's avatar
徐晓伟 已提交
708 709
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
710
       gitlab-go mix-create-environments command [command options]
徐晓伟's avatar
徐晓伟 已提交
711 712
    
    COMMANDS:
徐晓伟's avatar
徐晓伟 已提交
713
       all, a   所有项目创建新环境
徐晓伟's avatar
徐晓伟 已提交
714 715 716
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
徐晓伟's avatar
徐晓伟 已提交
717 718 719 720 721 722 723 724 725 726
       --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
       --owned               当前用户明确拥有的项目。 (default: false)
       --name value          环境名称
       --external-url value  该环境的链接位置
       --tier value          新环境的层级。允许设置的值为 production, staging, testing, development 和 other
       --allow-failure       允许失败 (default: false)
       --print-json          打印 JSON (default: false)
       --print-time          打印时间 (default: false)
       --help, -h            show help
徐晓伟's avatar
徐晓伟 已提交
727 728
    ```

729 730 731 732 733 734 735 736
- 导出(混合命令,多接口命令)

    ```shell
    $ go run main.go mix-export --help
    NAME:
       gitlab-go mix-export - 导出(混合命令,多接口命令)
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
737
       gitlab-go mix-export command [command options]
738 739 740 741 742 743 744 745 746 747 748 749 750 751 752
    
    COMMANDS:
       all, a   导出所有(混合命令,多接口命令)
                已包含:
                1. git 仓库
                2. wiki 仓库
       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
       --owned                                                            当前用户明确拥有的项目。 (default: false)
       --export-folder value                                              导出文件夹
       --skip-project-path value [ --skip-project-path value ]            跳过项目路径
       --skip-project-wiki-path value [ --skip-project-wiki-path value ]  跳过项目wiki路径
753
       --auto-skip-exist-folder                                           自动跳过已存在的文件夹 (default: false)
徐晓伟's avatar
徐晓伟 已提交
754
       --allow-failure                                                    允许失败 (default: false)
755 756 757
       --help, -h                                                         show help
    ```

758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813
- 保护仓库分支(混合命令,多接口命令)

    ```shell
    $ go run main.go mix-protect-branches --help
    NAME:
       gitlab-go mix-protect-branches - 保护仓库分支(混合命令,多接口命令)
    
    USAGE:
       gitlab-go mix-protect-branches command [command options]
    
    COMMANDS:
       all, a   保护所有仓库分支
       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
       --owned                         当前用户明确拥有的项目。 (default: false)
       --name value                    分支或通配符的名称
       --push-access-level value       允许推送的访问级别(默认值:40,维护者角色),合法值:
                                       0:NoPermissions
                                       5:MinimalAccessPermissions
                                       10:GuestPermissions
                                       20:ReporterPermissions
                                       30:DeveloperPermissions
                                       40:MaintainerPermissions
                                       50:OwnerPermissions
                                       60:AdminPermissions
                                        (default: 40)
       --merge-access-level value      允许合并的访问级别(默认值:40,维护者角色),合法值:
                                       0:NoPermissions
                                       5:MinimalAccessPermissions
                                       10:GuestPermissions
                                       20:ReporterPermissions
                                       30:DeveloperPermissions
                                       40:MaintainerPermissions
                                       50:OwnerPermissions
                                       60:AdminPermissions
                                        (default: 40)
       --unprotect-access-level value  允许取消保护的访问级别(默认值:40,维护者角色),合法值:
                                       0:NoPermissions
                                       5:MinimalAccessPermissions
                                       10:GuestPermissions
                                       20:ReporterPermissions
                                       30:DeveloperPermissions
                                       40:MaintainerPermissions
                                       50:OwnerPermissions
                                       60:AdminPermissions
                                        (default: 40)
       --allow-force-push              启用后,可以推送到该分支的成员也可以强制推送 (default: false)
       --code-owner-approval-required  如果分支在 CODEOWNERS https://docs.gitlab.cn/jh/user/project/codeowners/index.html 文件中,则阻止推送到此分支。(默认值:false) (default: false)
       --print-json                    打印 JSON (default: false)
       --print-time                    打印时间 (default: false)
       --help, -h                      show help
    ```

814 815 816 817 818 819 820 821
- 转移(混合命令,多接口命令)

    ```shell
    $ go run main.go mix-transfer --help
    NAME:
       gitlab-go mix-transfer - 转移(混合命令,多接口命令)
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
822
       gitlab-go mix-transfer command [command options]
823 824 825 826 827 828 829 830 831 832
    
    COMMANDS:
       all, a   将一个命令空间的项目转移到新的命名空间
       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
       --owned                                                  当前用户明确拥有的项目。 (default: false)
       --namespace-source value                                 源命名空间。如:用户名、群组名
徐晓伟's avatar
徐晓伟 已提交
833
       --namespace-target value                                 目标命名空间。如:用户名、群组名
834 835 836 837
       --skip-project-path value [ --skip-project-path value ]  跳过项目路径
       --help, -h                                               show help
    ```

徐晓伟's avatar
徐晓伟 已提交
838
- 取消归档(混合命令,多接口命令)
839 840

    ```shell
徐晓伟's avatar
徐晓伟 已提交
841
    $ go run main.go mix-unarchive --help
842
    NAME:
徐晓伟's avatar
徐晓伟 已提交
843
       gitlab-go mix-unarchive - 取消归档(混合命令,多接口命令)
844 845
    
    USAGE:
徐晓伟's avatar
徐晓伟 已提交
846
       gitlab-go mix-unarchive command [command options]
847 848
    
    COMMANDS:
徐晓伟's avatar
徐晓伟 已提交
849
       all      取消归档所有项目(混合命令,多接口命令)
850 851 852
       help, h  Shows a list of commands or help for one command
    
    OPTIONS:
徐晓伟's avatar
徐晓伟 已提交
853 854 855 856
       --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
       --owned           当前用户明确拥有的项目。 (default: false)
       --help, -h        show help
857 858
    ```

859 860 861
### test

```shell
徐晓伟's avatar
:memo:  
徐晓伟 已提交
862
go test ./... -v
863 864 865 866 867
```

### build

```shell
徐晓伟's avatar
徐晓伟 已提交
868 869 870 871 872
go build
# GOOS=:设置构建的目标操作系统(darwin | freebsd | linux | windows)
# GOARCH=:设置构建的目标操作系统(386 | amd64 | arm | arm64)
# -v:打印编译过程中的详细信息
# -ldflags:设置在编译时传递给链接器的参数
徐晓伟's avatar
徐晓伟 已提交
873 874 875 876
# -ldflags "-s -w -buildid="
#                           -s: 删除符号表信息,减小可执行文件的大小。
#                           -w: 删除调试信息,使可执行文件在运行时不会打印调试信息。
#                           -buildid=: 删除构建ID,使可执行文件在运行时不会打印构建ID。
徐晓伟's avatar
徐晓伟 已提交
877 878
# -trimpath:去掉所有包含 go path 的路径
# -o:指定构建后输出的文件名
879
```
徐晓伟's avatar
徐晓伟 已提交
880 881 882 883

- Windows
    - amd64
        ```shell
884
        go build -o buildinfo/buildinfo.exe buildinfo/buildinfo.go
885
        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
徐晓伟 已提交
886 887 888
        ```
    - arm64
        ```shell
889
        go build -o buildinfo/buildinfo.exe buildinfo/buildinfo.go
890
        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
徐晓伟 已提交
891 892 893 894 895
        ```

- Linux
    - amd64
        ```shell
896
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
897
        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
徐晓伟 已提交
898 899 900
        ```
    - arm64
        ```shell
901
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
902
        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
徐晓伟 已提交
903 904
        ```

905 906 907 908 909 910 911
- LoongArch
    - 64-bit
        ```shell
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
        GOOS=linux GOARCH=loong64 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-loong64 .
        ```

徐晓伟's avatar
徐晓伟 已提交
912 913 914
- Darwin
    - amd64
        ```shell
915
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
916
        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
徐晓伟 已提交
917 918 919
        ```
    - arm64
        ```shell
920
        go build -o buildinfo/buildinfo buildinfo/buildinfo.go
921
        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
徐晓伟 已提交
922
        ```
徐晓伟's avatar
徐晓伟 已提交
923 924 925 926 927 928 929 930 931

## 鸣谢

1. 感谢 [![jetbrains](./static/jb_beam.svg)](https://www.jetbrains.com/)
   提供开发工具 [![IDEA](./static/IntelliJ_IDEA_icon.svg)](https://www.jetbrains.com/idea) 的免费授权

## Stargazers over time

[![Stargazers over time](https://starchart.cc/xuxiaowei-com-cn/gitlab-go.svg)](https://starchart.cc/xuxiaowei-com-cn/gitlab-go)