群组徽章 API
占位符令牌
徽章支持在链接和镜像 URL 中实时替换的占位符。允许的占位符为:
- %{project_path}:替换为项目路径。
- %{project_title}:替换为项目标题。
- %{project_name}: 替换为项目的名称。
- %{project_id}: 替换为项目的 ID。
- %{project_namespace}: 替换为项目命名空间的完整路径。
- %{group_name}: 替换为项目的顶级群组名称。
- %{gitlab_server}: 替换为项目的服务器名称。
- %{gitlab_pages_domain}: 替换为托管极狐GitLab Pages 的域名名称。
- %{default_branch}: 替换为项目的默认分支。
- %{commit_sha}: 替换为项目的最新提交 SHA。
- %{latest_tag}: 替换为项目的最新标签。
因为这些端点不在项目的上下文中,所以用于替换占位符的信息来自第一个创建的群组的项目。如果该群组没有任何项目,则返回带有占位符的原始 URL。
列出群组的所有徽章
列出群组徽章列表。
GET /groups/:id/badges
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
id |
integer/string | yes | 经过身份验证的用户拥有的 ID 或 URL 编码的群组路径 |
name |
string | no | 返回的徽章的名称(区分大小写) |
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/groups/:id/badges?name=Coverage"
响应示例:
[
{
"name": "Coverage",
"id": 1,
"link_url": "http://example.com/ci_status.svg?project=%{project_path}&ref=%{default_branch}",
"image_url": "https://shields.io/my/badge",
"rendered_link_url": "http://example.com/ci_status.svg?project=example-org/example-project&ref=master",
"rendered_image_url": "https://shields.io/my/badge",
"kind": "group"
}
]
获取群组徽章
获取群组的徽章。
GET /groups/:id/badges/:badge_id
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
id |
integer/string | yes | 经过身份验证的用户拥有的 ID 或 URL 编码的群组路径 |
badge_id |
integer | yes | 徽章 ID |
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/groups/:id/badges/:badge_id"
响应示例:
{
"name": "Coverage",
"id": 1,
"link_url": "http://example.com/ci_status.svg?project=%{project_path}&ref=%{default_branch}",
"image_url": "https://shields.io/my/badge",
"rendered_link_url": "http://example.com/ci_status.svg?project=example-org/example-project&ref=master",
"rendered_image_url": "https://shields.io/my/badge",
"kind": "group"
}
向群组添加徽章
向群组添加徽章。
POST /groups/:id/badges
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
id |
integer/string | yes | 经过身份验证的用户拥有的 ID 或 URL 编码的群组路径 |
link_url |
string | yes | 徽章链接的 URL |
image_url |
string | yes | 徽章镜像的 URL |
name |
string | no | 徽章的名称 |
curl --request POST --header "PRIVATE-TOKEN: <your_access_token>" \
--data "link_url=https://gitlab.com/gitlab-org/gitlab-foss/commits/master&image_url=https://shields.io/my/badge1&position=0" \
"https://gitlab.example.com/api/v4/groups/:id/badges"
响应示例:
{
"id": 1,
"name": "mybadge",
"link_url": "https://gitlab.com/gitlab-org/gitlab-foss/commits/master",
"image_url": "https://shields.io/my/badge1",
"rendered_link_url": "https://gitlab.com/gitlab-org/gitlab-foss/commits/master",
"rendered_image_url": "https://shields.io/my/badge1",
"kind": "group"
}
编辑群组徽章
更新群组的徽章。
PUT /groups/:id/badges/:badge_id
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
id |
integer/string | yes | 经过身份验证的用户拥有的 ID 或 URL 编码的群组路径 |
badge_id |
integer | yes | 徽章 ID |
link_url |
string | no | 徽章链接的 URL |
image_url |
string | no | 徽章镜像的 URL |
name |
string | no | 徽章的名称 |
curl --request PUT --header "PRIVATE-TOKEN: <your_access_token>" \
"https://gitlab.example.com/api/v4/groups/:id/badges/:badge_id"
响应示例:
{
"id": 1,
"name": "mybadge",
"link_url": "https://gitlab.com/gitlab-org/gitlab-foss/commits/master",
"image_url": "https://shields.io/my/badge",
"rendered_link_url": "https://gitlab.com/gitlab-org/gitlab-foss/commits/master",
"rendered_image_url": "https://shields.io/my/badge",
"kind": "group"
}
从群组移除徽章
从群组移除徽章。
DELETE /groups/:id/badges/:badge_id
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
id |
integer/string | yes | 经过身份验证的用户拥有的 ID 或 URL 编码的群组路径 |
badge_id |
integer | yes | 徽章 ID |
curl --request DELETE --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/groups/:id/badges/:badge_id"
预览群组徽章
返回解析占位符插值后 link_url
和 image_url
的最终 URL。
GET /groups/:id/badges/render
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
id |
integer/string | yes | 经过身份验证的用户拥有的 ID 或 URL 编码的群组路径 |
link_url |
string | yes | 徽章链接的 URL |
image_url |
string | yes | 徽章镜像的 URL |
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/groups/:id/badges/render?link_url=http%3A%2F%2Fexample.com%2Fci_status.svg%3Fproject%3D%25%7Bproject_path%7D%26ref%3D%25%7Bdefault_branch%7D&image_url=https%3A%2F%2Fshields.io%2Fmy%2Fbadge"
响应示例:
{
"link_url": "http://example.com/ci_status.svg?project=%{project_path}&ref=%{default_branch}",
"image_url": "https://shields.io/my/badge",
"rendered_link_url": "http://example.com/ci_status.svg?project=example-org/example-project&ref=master",
"rendered_image_url": "https://shields.io/my/badge"
}