主题 API
使用 REST API 与项目主题进行交互。
获取主题列表
列出所有在极狐GitLab 实例中的项目主题,并按照与主题关联项目的数量进行排序。
GET /topics
支持参数:
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
page |
integer | No | 获取第几页的数据,默认是 1 。 |
per_page |
integer | No | 指定一页返回数据的数量,默认是 20 。 |
search |
string | No | 按照主题的 name 属性进行搜索。 |
without_projects |
boolean | No | 将结果限制为没有分配项目的主题。 |
请求示例:
curl "https://gitlab.example.com/api/v4/topics?search=git"
响应示例:
[
{
"id": 1,
"name": "gitlab",
"title": "GitLab",
"description": "GitLab is an open source end-to-end software development platform with built-in version control, issue tracking, code review, CI/CD, and more.",
"total_projects_count": 1000,
"avatar_url": "http://www.gravatar.com/avatar/a0d477b3ea21970ce6ffcbb817b0b435?s=80&d=identicon"
},
{
"id": 3,
"name": "git",
"title": "Git",
"description": "Git is a free and open source distributed version control system designed to handle everything from small to very large projects with speed and efficiency.",
"total_projects_count": 900,
"avatar_url": "http://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=80&d=identicon"
},
{
"id": 2,
"name": "git-lfs",
"title": "Git LFS",
"description": null,
"total_projects_count": 300,
"avatar_url": null
}
]
获取一个主题
通过 ID 获取某一个主题。
GET /topics/:id
支持参数:
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
id |
integer | Yes | 项目主题的 ID。 |
请求示例:
curl "https://gitlab.example.com/api/v4/topics/1"
响应示例:
{
"id": 1,
"name": "gitlab",
"title": "GitLab",
"description": "GitLab is an open source end-to-end software development platform with built-in version control, issue tracking, code review, CI/CD, and more.",
"total_projects_count": 1000,
"avatar_url": "http://www.gravatar.com/avatar/a0d477b3ea21970ce6ffcbb817b0b435?s=80&d=identicon"
}
获取被指派某主题的项目列表
使用项目 API 来获取指派了某一个主题的所有项目列表。
GET /projects?topic=<topic_name>
创建一个项目主题
创建一个项目主题,只有管理员可以使用该API。
POST /topics
支持参数:
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
name |
string | Yes | Slug(名称) |
title |
string | Yes | 标题 |
avatar |
file | No | 头像 |
description |
string | No | 描述 |
organization_id |
integer | No | 主题的组织 ID。警告:此属性是试验性的,未来可能会发生更改。关于组织的更多信息,查看组织 API |
请求示例:
curl --request POST \
--data "name=topic1&title=Topic 1" \
--header "PRIVATE-TOKEN: <your_access_token>" \
"https://gitlab.example.com/api/v4/topics"
响应示例:
{
"id": 1,
"name": "topic1",
"title": "Topic 1",
"description": null,
"total_projects_count": 0,
"avatar_url": null
}
更新项目主题
更新项目主题,只有管理员可以使用该 API。
PUT /topics/:id
支持参数:
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
id |
integer | Yes | 项目主题的 ID |
avatar |
file | No | 头像 |
description |
string | No | 描述 |
name |
string | No | Slug(名称) |
title |
string | No | 标题 |
请求示例:
curl --request PUT \
--data "name=topic1" \
--header "PRIVATE-TOKEN: <your_access_token>" \
"https://gitlab.example.com/api/v4/topics/1"
响应示例:
{
"id": 1,
"name": "topic1",
"title": "Topic 1",
"description": null,
"total_projects_count": 0,
"avatar_url": null
}
更新项目主题的头像
为了从您的文件系统中上传头像文件,请使用 --form
参数。这个参数会通过 cURL 使用 HTTP 头 Content-Type: multipart/form-data
来上传数据。参数 file=
必须指向一个文件系统中的文件,从在最前面添加字符 @
。比如:
curl --request PUT \
--header "PRIVATE-TOKEN: <your_access_token>" \
"https://gitlab.example.com/api/v4/topics/1" \
--form "avatar=@/tmp/example.png"
删除项目主题的头像
通过对参数 avatar
设置为空值来删除项目主题的头像。
请求示例:
curl --request PUT \
--data "avatar=" \
--header "PRIVATE-TOKEN: <your_access_token>" \
"https://gitlab.example.com/api/v4/topics/1"
删除项目主题
您必须是管理员才能删除项目主题。当您删除项目主题时,同时也从项目中删除了该主题的指派关系。
DELETE /topics/:id
支持的参数:
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
id |
integer | Yes | 项目主题 ID |
请求示例:
curl --request DELETE \
--header "PRIVATE-TOKEN: <your_access_token>" \
"https://gitlab.example.com/api/v4/topics/1"
合并主题
- 引入于极狐GitLab 15.4。
您必须是管理员才能将源主题合并到目标主题中。合并主题时,您删除源主题并将所有分配的项目移动到目标主题。
POST /topics/merge
支持的参数:
参数 | 类型 | 是否必需 | 描述 |
---|---|---|---|
source_topic_id |
integer | Yes | 源项目主题 ID |
target_topic_id |
integer | Yes | 目标项目主题 ID |
请求示例:
curl --request POST \
--data "source_topic_id=2&target_topic_id=1" \
--header "PRIVATE-TOKEN: <your_access_token>" \
"https://gitlab.example.com/api/v4/topics/merge"
响应示例:
{
"id": 1,
"name": "topic1",
"title": "Topic 1",
"description": null,
"total_projects_count": 0,
"avatar_url": null
}