{{< details >}}

  • Tier: 基础版,专业版,旗舰版
  • Offering: JihuLab.com, 私有化部署

{{< /details >}}

列出项目仓库标签

{{< history >}}

  • version 属性的 order_by 值在极狐GitLab 15.4 引入。
  • created_at 响应属性在极狐GitLab 16.11 引入。

{{< /history >}}

获取项目的仓库标签列表,按更新时间和日期降序排列。

{{< alert type=”note” >}}

如果仓库是公开访问的,则不需要进行认证 (--header "PRIVATE-TOKEN: <your_access_token>")。

{{< /alert >}}

GET /projects/:id/repository/tags

参数:

属性 类型 必需 描述
id integer 或 string 项目的 ID 或 URL 编码路径
order_by string 返回按 nameupdatedversion 排序的标签。默认为 updated
sort string 返回按 ascdesc 排序的标签。默认为 desc
search string 返回符合搜索条件的标签列表。可以使用 ^termterm$ 来查找以 term 开头或结尾的标签。不支持其他正则表达式。
curl --header "PRIVATE-TOKEN: <your_access_token>" \
    --url "https://gitlab.example.com/api/v4/projects/5/repository/tags"

示例响应:

[
  {
    "commit": {
      "id": "2695effb5807a22ff3d138d593fd856244e155e7",
      "short_id": "2695effb",
      "title": "Initial commit",
      "created_at": "2017-07-26T11:08:53.000+02:00",
      "parent_ids": [
        "2a4b78934375d7f53875269ffd4f45fd83a84ebe"
      ],
      "message": "Initial commit",
      "author_name": "John Smith",
      "author_email": "john@example.com",
      "authored_date": "2012-05-28T04:42:42-07:00",
      "committer_name": "Jack Smith",
      "committer_email": "jack@example.com",
      "committed_date": "2012-05-28T04:42:42-07:00"
    },
    "release": {
      "tag_name": "1.0.0",
      "description": "Amazing release. Wow"
    },
    "name": "v1.0.0",
    "target": "2695effb5807a22ff3d138d593fd856244e155e7",
    "message": null,
    "protected": true,
    "created_at": "2017-07-26T11:08:53.000+02:00"
  }
]

获取单个仓库标签

{{< history >}}

  • created_at 响应属性在极狐GitLab 16.11 引入。

{{< /history >}}

根据标签名称获取特定的仓库标签。如果仓库是公开访问的,则可以不进行认证访问此端点。

GET /projects/:id/repository/tags/:tag_name

参数:

属性 类型 必需 描述
id integer 或 string 项目的 ID 或 URL 编码路径
tag_name string 标签的名称。
curl --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/repository/tags/v1.0.0"

示例响应:

{
  "name": "v5.0.0",
  "message": null,
  "target": "60a8ff033665e1207714d6670fcd7b65304ec02f",
  "commit": {
    "id": "60a8ff033665e1207714d6670fcd7b65304ec02f",
    "short_id": "60a8ff03",
    "title": "Initial commit",
    "created_at": "2017-07-26T11:08:53.000+02:00",
    "parent_ids": [
      "f61c062ff8bcbdb00e0a1b3317a91aed6ceee06b"
    ],
    "message": "v5.0.0\n",
    "author_name": "Arthur Verschaeve",
    "author_email": "contact@arthurverschaeve.be",
    "authored_date": "2015-02-01T21:56:31.000+01:00",
    "committer_name": "Arthur Verschaeve",
    "committer_email": "contact@arthurverschaeve.be",
    "committed_date": "2015-02-01T21:56:31.000+01:00"
  },
  "release": null,
  "protected": false,
  "created_at": "2017-07-26T11:08:53.000+02:00"
}

创建新标签

{{< history >}}

  • created_at 响应属性在极狐GitLab 16.11 引入。

{{< /history >}}

在仓库中创建一个指向给定 ref 的新标签。

POST /projects/:id/repository/tags

参数:

属性 类型 必需 描述
id integer 或 string 项目的 ID 或 URL 编码路径
tag_name string 标签的名称。
ref string 从提交 SHA、另一个标签名或分支名创建标签。
message string 创建注释标签。
curl --request POST \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/repository/tags?tag_name=test&ref=main"

示例响应:

{
  "commit": {
    "id": "2695effb5807a22ff3d138d593fd856244e155e7",
    "short_id": "2695effb",
    "title": "Initial commit",
    "created_at": "2017-07-26T11:08:53.000+02:00",
    "parent_ids": [
      "2a4b78934375d7f53875269ffd4f45fd83a84ebe"
    ],
    "message": "Initial commit",
    "author_name": "John Smith",
    "author_email": "john@example.com",
    "authored_date": "2012-05-28T04:42:42-07:00",
    "committer_name": "Jack Smith",
    "committer_email": "jack@example.com",
    "committed_date": "2012-05-28T04:42:42-07:00"
  },
  "release": null,
  "name": "v1.0.0",
  "target": "2695effb5807a22ff3d138d593fd856244e155e7",
  "message": null,
  "protected": false,
  "created_at": null
}

创建的标签类型决定了 created_attargetmessage 的内容:

  • 对于注释标签:
    • created_at 包含标签创建的时间戳。
    • message 包含注释。
    • target 包含标签对象的 ID。
  • 对于轻量标签:
    • created_at 为 null。
    • message 为 null。
    • target 包含提交 ID。

错误返回状态码 405 和解释性错误信息。

删除标签

删除给定名称的仓库标签。

DELETE /projects/:id/repository/tags/:tag_name

参数:

属性 类型 必需 描述
id integer 或 string 项目的 ID 或 URL 编码路径
tag_name string 标签的名称。

获取标签的 X.509 签名

{{< history >}}

  • 在极狐GitLab 15.7 引入。

{{< /history >}}

获取 标签的 X.509 签名,如果它已签名。未签名的标签返回 404 Not Found 响应。

GET /projects/:id/repository/tags/:tag_name/signature

参数:

属性 类型 必需 描述
id integer 或 string 项目的 ID 或 URL 编码路径
tag_name string 标签的名称。
curl --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/1/repository/tags/v1.1.1/signature"

如果标签是 X.509 签名的示例响应:

{
  "signature_type": "X509",
  "verification_status": "unverified",
  "x509_certificate": {
    "id": 1,
    "subject": "CN=gitlab@example.org,OU=Example,O=World",
    "subject_key_identifier": "BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC:BC",
    "email": "gitlab@example.org",
    "serial_number": 278969561018901340486471282831158785578,
    "certificate_status": "good",
    "x509_issuer": {
      "id": 1,
      "subject": "CN=PKI,OU=Example,O=World",
      "subject_key_identifier": "AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB:AB",
      "crl_url": "http://example.com/pki.crl"
    }
  }
}

如果标签是未签名的示例响应:

{
  "message": "404 GPG Signature Not Found"
}