gitlab-go/README.md

318 lines
38 KiB
Markdown
Raw Normal View History

2023-10-05 04:36:40 +08:00
<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>
## 开发命令
### get
```shell
go env -w GOPROXY=https://goproxy.cn,direct
# go env -w GOPROXY=https://mirrors.aliyun.com/goproxy/
go get -u github.com/urfave/cli/v2
go get -u github.com/xanzy/go-gitlab
go get -u github.com/xuxiaowei-com-cn/git-go@main
go get -u gopkg.in/yaml.v3
```
### mod
```shell
go mod tidy
```
2023-10-02 01:56:29 +08:00
```shell
go mod download
```
### run
```shell
go run main.go
```
### run help
2023-10-01 23:14:26 +08:00
```shell
go run main.go help
```
```shell
2023-10-05 04:23:49 +08:00
$ go run main.go --help
NAME:
2023-10-05 04:23:49 +08:00
gitlab-go - 基于 Go 语言开发的 GitLab 命令行工具
USAGE:
2023-10-05 04:23:49 +08:00
gitlab-go [global options] command [command options] [arguments...]
2023-10-01 23:14:26 +08:00
VERSION:
2023-10-05 04:23:49 +08:00
dev
2023-10-01 23:14:26 +08:00
2023-10-08 09:59:13 +08:00
AUTHOR:
徐晓伟 <xuxiaowei@xuxiaowei.com.cn>
COMMANDS:
2023-10-05 05:52:04 +08:00
project, projects, p 项目 API中文文档https://docs.gitlab.cn/jh/api/projects.html
pipeline, pipelines, pl 流水线 API中文文档https://docs.gitlab.cn/jh/api/pipelines.html
job, jobs, j 作业 API中文文档https://docs.gitlab.cn/jh/api/jobs.html
job-artifact, job-artifacts, ja 作业产物 API中文文档https://docs.gitlab.cn/jh/api/job_artifacts.html
help, h Shows a list of commands or help for one command
GLOBAL OPTIONS:
2023-10-01 23:14:26 +08:00
--help, -h show help
--version, -v print the version
2023-10-08 09:59:13 +08:00
COPYRIGHT:
徐晓伟工作室 <xuxiaowei@xuxiaowei.com.cn>
```
2023-10-05 05:52:04 +08:00
- [project - 项目 API](https://docs.gitlab.cn/jh/api/projects.html)
2023-10-05 04:23:49 +08:00
2023-10-05 05:37:43 +08:00
```shell
2023-10-05 05:52:04 +08:00
$ go run main.go project --help
2023-10-05 05:37:43 +08:00
NAME:
2023-10-05 05:52:04 +08:00
gitlab-go project - 项目 API中文文档https://docs.gitlab.cn/jh/api/projects.html
2023-10-05 05:37:43 +08:00
USAGE:
2023-10-05 05:52:04 +08:00
gitlab-go project command [command options] [arguments...]
2023-10-05 05:37:43 +08:00
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
--sort value 按照 asc 或者 desc 排序 (default: "desc")
--help, -h show help
```
2023-10-05 04:23:49 +08:00
2023-10-05 05:52:04 +08:00
- [pipeline - 流水线 API](https://docs.gitlab.cn/jh/api/pipelines.html)
2023-10-05 04:23:49 +08:00
2023-10-05 05:37:43 +08:00
```shell
2023-10-05 05:52:04 +08:00
$ go run main.go pipeline --help
2023-10-05 05:37:43 +08:00
NAME:
2023-10-05 05:52:04 +08:00
gitlab-go pipeline - 流水线 API中文文档https://docs.gitlab.cn/jh/api/pipelines.html
2023-10-05 05:37:43 +08:00
USAGE:
2023-10-05 05:52:04 +08:00
gitlab-go pipeline command [command options] [arguments...]
2023-10-05 05:37:43 +08:00
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
--sort value 按照 asc 或者 desc 排序 (default: "desc")
--id value 项目 ID 或 URL 编码的路径
--help, -h show help
```
2023-10-05 04:23:49 +08:00
2023-10-05 05:52:04 +08:00
- [job - 作业 API](https://docs.gitlab.cn/jh/api/jobs.html)
2023-10-05 04:23:49 +08:00
2023-10-05 05:37:43 +08:00
```shell
2023-10-05 05:52:04 +08:00
$ go run main.go job --help
2023-10-05 05:37:43 +08:00
NAME:
2023-10-05 05:52:04 +08:00
gitlab-go job - 作业 API中文文档https://docs.gitlab.cn/jh/api/jobs.html
2023-10-05 05:37:43 +08:00
USAGE:
2023-10-05 05:52:04 +08:00
gitlab-go job command [command options] [arguments...]
2023-10-05 05:37:43 +08:00
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
--sort value 按照 asc 或者 desc 排序 (default: "desc")
--help, -h show help
```
2023-10-05 04:23:49 +08:00
2023-10-05 05:52:04 +08:00
- [job-artifact - 作业产物 API](https://docs.gitlab.cn/jh/api/job_artifacts.html)
2023-10-05 04:23:49 +08:00
2023-10-05 05:37:43 +08:00
```shell
2023-10-05 05:52:04 +08:00
$ go run main.go job-artifact --help
2023-10-05 05:37:43 +08:00
NAME:
2023-10-05 05:52:04 +08:00
gitlab-go job-artifact - 作业产物 API中文文档https://docs.gitlab.cn/jh/api/job_artifacts.html
2023-10-05 05:37:43 +08:00
USAGE:
2023-10-05 05:52:04 +08:00
gitlab-go job-artifact command [command options] [arguments...]
2023-10-05 05:37:43 +08:00
COMMANDS:
2023-10-05 05:52:04 +08:00
get 获取作业产物(未完成)
download, dl 下载产物归档文件(未完成)
delete, rm 删除作业产物
delete-project, delete-projects, rm-p 删除项目产物
help, h Shows a list of commands or help for one command
2023-10-05 05:37:43 +08:00
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 编码的路径
--job-id value 作业 ID
--help, -h show help
```
2023-10-05 04:23:49 +08:00
### test
```shell
2023-10-05 04:23:49 +08:00
go test ./... -v
```
### build
```shell
2023-10-01 22:37:43 +08:00
go build
# GOOS=设置构建的目标操作系统darwin | freebsd | linux | windows
# GOARCH=设置构建的目标操作系统386 | amd64 | arm | arm64
# -v打印编译过程中的详细信息
# -ldflags设置在编译时传递给链接器的参数
2023-10-01 23:01:32 +08:00
# -ldflags "-s -w -buildid="
# -s: 删除符号表信息,减小可执行文件的大小。
# -w: 删除调试信息,使可执行文件在运行时不会打印调试信息。
# -buildid=: 删除构建ID使可执行文件在运行时不会打印构建ID。
2023-10-01 22:37:43 +08:00
# -trimpath去掉所有包含 go path 的路径
# -o指定构建后输出的文件名
```
2023-10-01 22:37:43 +08:00
- Windows
- amd64
```shell
go build -o buildinfo/buildinfo.exe buildinfo/buildinfo.go
2023-10-08 10:25:57 +08:00
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 .
2023-10-01 22:37:43 +08:00
```
- arm64
```shell
go build -o buildinfo/buildinfo.exe buildinfo/buildinfo.go
2023-10-08 10:25:57 +08:00
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 .
2023-10-01 22:37:43 +08:00
```
- Linux
- amd64
```shell
go build -o buildinfo/buildinfo buildinfo/buildinfo.go
2023-10-08 10:25:57 +08:00
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 .
2023-10-01 22:37:43 +08:00
```
- arm64
```shell
go build -o buildinfo/buildinfo buildinfo/buildinfo.go
2023-10-08 10:25:57 +08:00
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 .
2023-10-01 22:37:43 +08:00
```
- Darwin
- amd64
```shell
go build -o buildinfo/buildinfo buildinfo/buildinfo.go
2023-10-08 10:25:57 +08:00
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 .
2023-10-01 22:37:43 +08:00
```
- arm64
```shell
go build -o buildinfo/buildinfo buildinfo/buildinfo.go
2023-10-08 10:25:57 +08:00
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 .
2023-10-01 22:37:43 +08:00
```