debian-mirror-gitlab/doc/api/releases/index.md

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

856 lines
38 KiB
Markdown
Raw Normal View History

2020-06-23 00:09:42 +05:30
---
2023-05-27 22:25:52 +05:30
stage: Configure
group: Configure
2022-11-25 23:54:43 +05:30
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/product/ux/technical-writing/#assignments
2020-06-23 00:09:42 +05:30
---
2021-11-11 11:23:49 +05:30
# Releases API **(FREE)**
2019-02-15 15:39:39 +05:30
2020-06-23 00:09:42 +05:30
> - Release Evidences were [introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/26019) in GitLab 12.5.
2021-06-08 01:23:25 +05:30
> - `description_html` became an opt-in field [with GitLab 13.12 for performance reasons](https://gitlab.com/gitlab-org/gitlab/-/issues/299447).
Please pass the `include_html_description` query string parameter if you need it.
2021-09-30 23:02:18 +05:30
> - [The permission model for create, update and delete actions was fixed](https://gitlab.com/gitlab-org/gitlab/-/issues/327505) in GitLab 14.1.
See [Release permissions](../../user/project/releases/index.md#release-permissions) for more information.
2019-02-15 15:39:39 +05:30
2022-03-02 08:16:31 +05:30
Use this API to manipulate GitLab [Release](../../user/project/releases/index.md)
entries. For manipulating links as a release asset, see [Release Links API](links.md).
2021-10-27 15:23:28 +05:30
## Authentication
For authentication, the Releases API accepts either:
- A [Personal Access Token](../../user/profile/personal_access_tokens.md) using the
`PRIVATE-TOKEN` header.
2021-11-11 11:23:49 +05:30
- The [GitLab CI/CD job token](../../ci/jobs/ci_job_token.md) `$CI_JOB_TOKEN` using
2021-10-27 15:23:28 +05:30
the `JOB-TOKEN` header.
2019-02-15 15:39:39 +05:30
## List Releases
2021-12-11 22:18:48 +05:30
> [Changed](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/72448) to allow for `JOB-TOKEN` in GitLab 14.5.
2023-01-13 00:05:48 +05:30
Returns a paginated list of releases, sorted by `released_at`.
2019-02-15 15:39:39 +05:30
2020-04-08 14:13:33 +05:30
```plaintext
2019-02-15 15:39:39 +05:30
GET /projects/:id/releases
```
2019-12-04 20:38:33 +05:30
| Attribute | Type | Required | Description |
| ------------- | -------------- | -------- | ----------------------------------------------------------------------------------- |
2023-04-23 21:23:45 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project](../rest/index.md#namespaced-path-encoding). |
2021-01-03 14:25:43 +05:30
| `order_by` | string | no | The field to use as order. Either `released_at` (default) or `created_at`. |
| `sort` | string | no | The direction of the order. Either `desc` (default) for descending order or `asc` for ascending order. |
2021-06-08 01:23:25 +05:30
| `include_html_description` | boolean | no | If `true`, a response includes HTML rendered Markdown of the release description. |
2019-02-15 15:39:39 +05:30
2023-04-23 21:23:45 +05:30
If successful, returns [`200 OK`](../../api/rest/index.md#status-codes) and the following
2023-03-17 16:20:25 +05:30
response attributes:
2023-04-23 21:23:45 +05:30
| Attribute | Type | Description |
|:--------------------------------------|:-------|:-------------------------------------------------|
| `[]._links` | object | Links of the release. |
| `[]._links.closed_issues_url` | string | HTTP URL of the release's closed issues. |
| `[]._links.closed_merge_requests_url` | string | HTTP URL of the release's closed merge requests. |
| `[]._links.edit_url` | string | HTTP URL of the release's edit page. |
| `[]._links.merged_merge_requests_url` | string | HTTP URL of the release's merged merge requests. |
| `[]._links.opened_issues_url` | string | HTTP URL of the release's open issues. |
| `[]._links.opened_merge_requests_url` | string | HTTP URL of the release's open merge requests. |
| `[]._links.self` | string | HTTP URL of the release. |
2023-03-17 16:20:25 +05:30
2019-02-15 15:39:39 +05:30
Example request:
2020-03-13 15:44:24 +05:30
```shell
2021-03-08 18:12:59 +05:30
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/projects/24/releases"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
[
{
"tag_name":"v0.2",
2022-06-21 17:19:12 +05:30
"description":"## CHANGELOG\r\n\r\n- Escape label and milestone titles to prevent XSS in GLFM autocomplete. !2740\r\n- Prevent private snippets from being embeddable.\r\n- Add subresources removal to member destroy service.",
2019-02-15 15:39:39 +05:30
"name":"Awesome app v0.2 beta",
"created_at":"2019-01-03T01:56:19.539Z",
2019-09-30 21:07:59 +05:30
"released_at":"2019-01-03T01:56:19.539Z",
2019-02-15 15:39:39 +05:30
"author":{
"id":1,
"name":"Administrator",
"username":"root",
"state":"active",
"avatar_url":"https://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=80\u0026d=identicon",
2019-12-04 20:38:33 +05:30
"web_url":"https://gitlab.example.com/root"
2019-02-15 15:39:39 +05:30
},
"commit":{
"id":"079e90101242458910cccd35eab0e211dfc359c0",
"short_id":"079e9010",
"title":"Update README.md",
"created_at":"2019-01-03T01:55:38.000Z",
"parent_ids":[
"f8d3d94cbd347e924aa7b715845e439d00e80ca4"
],
"message":"Update README.md",
"author_name":"Administrator",
"author_email":"admin@example.com",
"authored_date":"2019-01-03T01:55:38.000Z",
"committer_name":"Administrator",
"committer_email":"admin@example.com",
"committed_date":"2019-01-03T01:55:38.000Z"
},
2019-12-04 20:38:33 +05:30
"milestones": [
{
"id":51,
"iid":1,
"project_id":24,
"title":"v1.0-rc",
"description":"Voluptate fugiat possimus quis quod aliquam expedita.",
"state":"closed",
"created_at":"2019-07-12T19:45:44.256Z",
"updated_at":"2019-07-12T19:45:44.256Z",
2021-11-11 11:23:49 +05:30
"due_date":"2019-08-16",
"start_date":"2019-07-30",
2020-04-08 14:13:33 +05:30
"web_url":"https://gitlab.example.com/root/awesome-app/-/milestones/1",
"issue_stats": {
"total": 98,
"closed": 76
}
2019-12-04 20:38:33 +05:30
},
{
"id":52,
"iid":2,
"project_id":24,
"title":"v1.0",
"description":"Voluptate fugiat possimus quis quod aliquam expedita.",
"state":"closed",
"created_at":"2019-07-16T14:00:12.256Z",
"updated_at":"2019-07-16T14:00:12.256Z",
2021-11-11 11:23:49 +05:30
"due_date":"2019-08-16",
"start_date":"2019-07-30",
2020-04-08 14:13:33 +05:30
"web_url":"https://gitlab.example.com/root/awesome-app/-/milestones/2",
"issue_stats": {
"total": 24,
"closed": 21
}
2019-12-04 20:38:33 +05:30
}
],
2019-12-21 20:55:43 +05:30
"commit_path":"/root/awesome-app/commit/588440f66559714280628a4f9799f0c4eb880a4a",
"tag_path":"/root/awesome-app/-/tags/v0.11.1",
2019-02-15 15:39:39 +05:30
"assets":{
"count":6,
"sources":[
{
"format":"zip",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.2/awesome-app-v0.2.zip"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.gz",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.2/awesome-app-v0.2.tar.gz"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.bz2",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.2/awesome-app-v0.2.tar.bz2"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.2/awesome-app-v0.2.tar"
2019-02-15 15:39:39 +05:30
}
],
"links":[
{
"id":2,
"name":"awesome-v0.2.msi",
"url":"http://192.168.10.15:3000/msi",
2023-04-23 21:23:45 +05:30
"external":true, // deprecated in GitLab 15.9, will be removed in GitLab 16.0.
2020-06-23 00:09:42 +05:30
"link_type":"other"
2019-02-15 15:39:39 +05:30
},
{
"id":1,
"name":"awesome-v0.2.dmg",
"url":"http://192.168.10.15:3000",
2023-04-23 21:23:45 +05:30
"external":true, // deprecated in GitLab 15.9, will be removed in GitLab 16.0.
2020-06-23 00:09:42 +05:30
"link_type":"other"
2019-02-15 15:39:39 +05:30
}
2020-01-01 13:55:28 +05:30
],
"evidence_file_path":"https://gitlab.example.com/root/awesome-app/-/releases/v0.2/evidence.json"
2019-12-21 20:55:43 +05:30
},
2020-05-24 23:13:21 +05:30
"evidences":[
{
2021-06-08 01:23:25 +05:30
"sha": "760d6cdfb0879c3ffedec13af470e0f71cf52c6cde4d",
"filepath": "https://gitlab.example.com/root/awesome-app/-/releases/v0.2/evidence.json",
"collected_at": "2019-01-03T01:56:19.539Z"
2020-05-24 23:13:21 +05:30
}
]
2019-02-15 15:39:39 +05:30
},
{
"tag_name":"v0.1",
"description":"## CHANGELOG\r\n\r\n-Remove limit of 100 when searching repository code. !8671\r\n- Show error message when attempting to reopen an MR and there is an open MR for the same branch. !16447 (Akos Gyimesi)\r\n- Fix a bug where internal email pattern wasn't respected. !22516",
"name":"Awesome app v0.1 alpha",
"created_at":"2019-01-03T01:55:18.203Z",
2019-09-30 21:07:59 +05:30
"released_at":"2019-01-03T01:55:18.203Z",
2019-02-15 15:39:39 +05:30
"author":{
"id":1,
"name":"Administrator",
"username":"root",
"state":"active",
"avatar_url":"https://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=80\u0026d=identicon",
2019-12-04 20:38:33 +05:30
"web_url":"https://gitlab.example.com/root"
2019-02-15 15:39:39 +05:30
},
"commit":{
"id":"f8d3d94cbd347e924aa7b715845e439d00e80ca4",
"short_id":"f8d3d94c",
"title":"Initial commit",
"created_at":"2019-01-03T01:53:28.000Z",
"parent_ids":[
],
"message":"Initial commit",
"author_name":"Administrator",
"author_email":"admin@example.com",
"authored_date":"2019-01-03T01:53:28.000Z",
"committer_name":"Administrator",
"committer_email":"admin@example.com",
"committed_date":"2019-01-03T01:53:28.000Z"
},
"assets":{
"count":4,
"sources":[
{
"format":"zip",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.zip"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.gz",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar.gz"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.bz2",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar.bz2"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar"
2019-02-15 15:39:39 +05:30
}
],
"links":[
2020-01-01 13:55:28 +05:30
],
"evidence_file_path":"https://gitlab.example.com/root/awesome-app/-/releases/v0.1/evidence.json"
2019-12-21 20:55:43 +05:30
},
2020-05-24 23:13:21 +05:30
"evidences":[
{
2021-06-08 01:23:25 +05:30
"sha": "c3ffedec13af470e760d6cdfb08790f71cf52c6cde4d",
"filepath": "https://gitlab.example.com/root/awesome-app/-/releases/v0.1/evidence.json",
"collected_at": "2019-01-03T01:55:18.203Z"
2020-05-24 23:13:21 +05:30
}
2023-03-17 16:20:25 +05:30
],
"_links": {
2023-04-23 21:23:45 +05:30
"closed_issues_url": "https://gitlab.example.com/root/awesome-app/-/issues?release_tag=v0.1&scope=all&state=closed",
"closed_merge_requests_url": "https://gitlab.example.com/root/awesome-app/-/merge_requests?release_tag=v0.1&scope=all&state=closed",
"edit_url": "https://gitlab.example.com/root/awesome-app/-/releases/v0.1/edit",
"merged_merge_requests_url": "https://gitlab.example.com/root/awesome-app/-/merge_requests?release_tag=v0.1&scope=all&state=merged",
"opened_issues_url": "https://gitlab.example.com/root/awesome-app/-/issues?release_tag=v0.1&scope=all&state=opened",
"opened_merge_requests_url": "https://gitlab.example.com/root/awesome-app/-/merge_requests?release_tag=v0.1&scope=all&state=opened",
"self": "https://gitlab.example.com/root/awesome-app/-/releases/v0.1"
2023-03-17 16:20:25 +05:30
}
2019-02-15 15:39:39 +05:30
}
]
```
## Get a Release by a tag name
2021-12-11 22:18:48 +05:30
> [Changed](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/72448) to allow for `JOB-TOKEN` in GitLab 14.5.
2023-01-13 00:05:48 +05:30
Gets a release for the given tag.
2019-02-15 15:39:39 +05:30
2020-04-08 14:13:33 +05:30
```plaintext
2019-02-15 15:39:39 +05:30
GET /projects/:id/releases/:tag_name
```
2022-06-21 17:19:12 +05:30
| Attribute | Type | Required | Description |
|----------------------------| -------------- | -------- | ----------------------------------------------------------------------------------- |
2023-04-23 21:23:45 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project](../rest/index.md#namespaced-path-encoding). |
2022-06-21 17:19:12 +05:30
| `tag_name` | string | yes | The Git tag the release is associated with. |
2021-06-08 01:23:25 +05:30
| `include_html_description` | boolean | no | If `true`, a response includes HTML rendered Markdown of the release description. |
2019-02-15 15:39:39 +05:30
2023-04-23 21:23:45 +05:30
If successful, returns [`200 OK`](../../api/rest/index.md#status-codes) and the following
2023-03-17 16:20:25 +05:30
response attributes:
2023-04-23 21:23:45 +05:30
| Attribute | Type | Description |
|:--------------------------------------|:-------|:-------------------------------------------------|
| `[]._links` | object | Links of the release. |
| `[]._links.closed_issues_url` | string | HTTP URL of the release's closed issues. |
| `[]._links.closed_merge_requests_url` | string | HTTP URL of the release's closed merge requests. |
| `[]._links.edit_url` | string | HTTP URL of the release's edit page. |
| `[]._links.merged_merge_requests_url` | string | HTTP URL of the release's merged merge requests. |
| `[]._links.opened_issues_url` | string | HTTP URL of the release's open issues. |
| `[]._links.opened_merge_requests_url` | string | HTTP URL of the release's open merge requests. |
| `[]._links.self` | string | HTTP URL of the release. |
2023-03-17 16:20:25 +05:30
2019-02-15 15:39:39 +05:30
Example request:
2020-03-13 15:44:24 +05:30
```shell
2021-03-08 18:12:59 +05:30
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/projects/24/releases/v0.1"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
{
"tag_name":"v0.1",
"description":"## CHANGELOG\r\n\r\n- Remove limit of 100 when searching repository code. !8671\r\n- Show error message when attempting to reopen an MR and there is an open MR for the same branch. !16447 (Akos Gyimesi)\r\n- Fix a bug where internal email pattern wasn't respected. !22516",
"name":"Awesome app v0.1 alpha",
"created_at":"2019-01-03T01:55:18.203Z",
2019-09-30 21:07:59 +05:30
"released_at":"2019-01-03T01:55:18.203Z",
2019-02-15 15:39:39 +05:30
"author":{
"id":1,
"name":"Administrator",
"username":"root",
"state":"active",
"avatar_url":"https://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=80\u0026d=identicon",
2019-12-04 20:38:33 +05:30
"web_url":"https://gitlab.example.com/root"
2019-02-15 15:39:39 +05:30
},
"commit":{
"id":"f8d3d94cbd347e924aa7b715845e439d00e80ca4",
"short_id":"f8d3d94c",
"title":"Initial commit",
"created_at":"2019-01-03T01:53:28.000Z",
"parent_ids":[
],
"message":"Initial commit",
"author_name":"Administrator",
"author_email":"admin@example.com",
"authored_date":"2019-01-03T01:53:28.000Z",
"committer_name":"Administrator",
"committer_email":"admin@example.com",
"committed_date":"2019-01-03T01:53:28.000Z"
},
2019-12-04 20:38:33 +05:30
"milestones": [
{
"id":51,
"iid":1,
"project_id":24,
"title":"v1.0-rc",
"description":"Voluptate fugiat possimus quis quod aliquam expedita.",
"state":"closed",
"created_at":"2019-07-12T19:45:44.256Z",
"updated_at":"2019-07-12T19:45:44.256Z",
2021-11-11 11:23:49 +05:30
"due_date":"2019-08-16",
"start_date":"2019-07-30",
2020-04-08 14:13:33 +05:30
"web_url":"https://gitlab.example.com/root/awesome-app/-/milestones/1",
"issue_stats": {
"total": 98,
"closed": 76
}
2019-12-04 20:38:33 +05:30
},
{
"id":52,
"iid":2,
"project_id":24,
"title":"v1.0",
"description":"Voluptate fugiat possimus quis quod aliquam expedita.",
"state":"closed",
"created_at":"2019-07-16T14:00:12.256Z",
"updated_at":"2019-07-16T14:00:12.256Z",
2021-11-11 11:23:49 +05:30
"due_date":"2019-08-16",
"start_date":"2019-07-30",
2020-04-08 14:13:33 +05:30
"web_url":"https://gitlab.example.com/root/awesome-app/-/milestones/2",
"issue_stats": {
"total": 24,
"closed": 21
}
2019-12-04 20:38:33 +05:30
}
],
2019-12-21 20:55:43 +05:30
"commit_path":"/root/awesome-app/commit/588440f66559714280628a4f9799f0c4eb880a4a",
"tag_path":"/root/awesome-app/-/tags/v0.11.1",
2019-02-15 15:39:39 +05:30
"assets":{
2020-01-01 13:55:28 +05:30
"count":5,
2019-02-15 15:39:39 +05:30
"sources":[
{
"format":"zip",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.zip"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.gz",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar.gz"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.bz2",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar.bz2"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar"
2019-02-15 15:39:39 +05:30
}
],
"links":[
2020-04-08 14:13:33 +05:30
{
"id":3,
"name":"hoge",
"url":"https://gitlab.example.com/root/awesome-app/-/tags/v0.11.1/binaries/linux-amd64",
2023-04-23 21:23:45 +05:30
"external":true, // deprecated in GitLab 15.9, will be removed in GitLab 16.0.
2020-06-23 00:09:42 +05:30
"link_type":"other"
2020-04-08 14:13:33 +05:30
}
2020-05-24 23:13:21 +05:30
]
2019-12-21 20:55:43 +05:30
},
2020-05-24 23:13:21 +05:30
"evidences":[
{
2021-06-08 01:23:25 +05:30
"sha": "760d6cdfb0879c3ffedec13af470e0f71cf52c6cde4d",
"filepath": "https://gitlab.example.com/root/awesome-app/-/releases/v0.1/evidence.json",
"collected_at": "2019-07-16T14:00:12.256Z"
2023-03-17 16:20:25 +05:30
},
"_links": {
2023-04-23 21:23:45 +05:30
"closed_issues_url": "https://gitlab.example.com/root/awesome-app/-/issues?release_tag=v0.1&scope=all&state=closed",
"closed_merge_requests_url": "https://gitlab.example.com/root/awesome-app/-/merge_requests?release_tag=v0.1&scope=all&state=closed",
"edit_url": "https://gitlab.example.com/root/awesome-app/-/releases/v0.1/edit",
"merged_merge_requests_url": "https://gitlab.example.com/root/awesome-app/-/merge_requests?release_tag=v0.1&scope=all&state=merged",
"opened_issues_url": "https://gitlab.example.com/root/awesome-app/-/issues?release_tag=v0.1&scope=all&state=opened",
"opened_merge_requests_url": "https://gitlab.example.com/root/awesome-app/-/merge_requests?release_tag=v0.1&scope=all&state=opened",
"self": "https://gitlab.example.com/root/awesome-app/-/releases/v0.1"
2023-03-17 16:20:25 +05:30
}
2020-05-24 23:13:21 +05:30
]
2019-02-15 15:39:39 +05:30
}
```
2023-01-13 00:05:48 +05:30
## Download a release asset
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/358188) in GitLab 15.4.
Download a release asset file by making a request with the following format:
```plaintext
2023-04-23 21:23:45 +05:30
GET /projects/:id/releases/:tag_name/downloads/:direct_asset_path
2023-01-13 00:05:48 +05:30
```
| Attribute | Type | Required | Description |
|----------------------------| -------------- | -------- | ----------------------------------------------------------------------------------- |
2023-04-23 21:23:45 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project](../rest/index.md#namespaced-path-encoding). |
2023-01-13 00:05:48 +05:30
| `tag_name` | string | yes | The Git tag the release is associated with. |
2023-04-23 21:23:45 +05:30
| `filepath` | string | yes | Deprecated: Use `direct_asset_path` instead. |
| `direct_asset_path` | string | yes | Path to the release asset file as specified when [creating](links.md#create-a-release-link) or [updating](links.md#update-a-release-link) its link. |
2023-01-13 00:05:48 +05:30
Example request:
```shell
curl --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/projects/24/releases/v0.1/downloads/bin/asset.exe"
```
### Get the latest release
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/358188) in GitLab 15.4.
Latest release information is accessible through a permanent API URL.
The format of the URL is:
```plaintext
GET /projects/:id/releases/permalink/latest
```
To call any other GET API that requires a release tag, append a suffix to the `permalink/latest` API path.
For example, to get latest [release evidence](#collect-release-evidence) you can use:
```plaintext
GET /projects/:id/releases/permalink/latest/evidence
```
Another example is [downloading an asset](#download-a-release-asset) of the latest release, for which you can use:
```plaintext
GET /projects/:id/releases/permalink/latest/downloads/bin/asset.exe
```
#### Sorting preferences
By default, GitLab fetches the release using `released_at` time. The use of the query parameter
`?order_by=released_at` is optional, and support for `?order_by=semver` is tracked [in issue 352945](https://gitlab.com/gitlab-org/gitlab/-/issues/352945).
2019-02-15 15:39:39 +05:30
## Create a release
2023-01-13 00:05:48 +05:30
Creates a release. Developer level access to the project is required to create a release.
2019-02-15 15:39:39 +05:30
2020-04-08 14:13:33 +05:30
```plaintext
2019-02-15 15:39:39 +05:30
POST /projects/:id/releases
```
2019-12-21 20:55:43 +05:30
| Attribute | Type | Required | Description |
| -------------------| --------------- | -------- | -------------------------------------------------------------------------------------------------------------------------------- |
2023-04-23 21:23:45 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project](../rest/index.md#namespaced-path-encoding). |
2019-12-26 22:10:19 +05:30
| `name` | string | no | The release name. |
2021-03-08 18:12:59 +05:30
| `tag_name` | string | yes | The tag where the release is created from. |
2022-07-23 23:45:48 +05:30
| `tag_message` | string | no | Message to use if creating a new annotated tag. |
2020-04-08 14:13:33 +05:30
| `description` | string | no | The description of the release. You can use [Markdown](../../user/markdown.md). |
2021-03-08 18:12:59 +05:30
| `ref` | string | yes, if `tag_name` doesn't exist | If a tag specified in `tag_name` doesn't exist, the release is created from `ref` and tagged with `tag_name`. It can be a commit SHA, another tag name, or a branch name. |
2021-01-03 14:25:43 +05:30
| `milestones` | array of string | no | The title of each milestone the release is associated with. [GitLab Premium](https://about.gitlab.com/pricing/) customers can specify group milestones. |
2019-12-21 20:55:43 +05:30
| `assets:links` | array of hash | no | An array of assets links. |
2021-02-22 17:27:13 +05:30
| `assets:links:name`| string | required by: `assets:links` | The name of the link. Link names must be unique within the release. |
| `assets:links:url` | string | required by: `assets:links` | The URL of the link. Link URLs must be unique within the release. |
2023-04-23 21:23:45 +05:30
| `assets:links:filepath` | string | no | Deprecated: Use `direct_asset_path` instead. |
| `assets:links:direct_asset_path` | string | no | Optional path for a [direct asset link](../../user/project/releases/release_fields.md#permanent-links-to-release-assets). |
| `assets:links:link_type` | string | no | The type of the link: `other`, `runbook`, `image`, `package`. Defaults to `other`. |
2022-10-11 01:57:18 +05:30
| `released_at` | datetime | no | Date and time for the release. Defaults to the current time. Expected in ISO 8601 format (`2019-03-15T08:00:00Z`). Only provide this field if creating an [upcoming](../../user/project/releases/index.md#upcoming-releases) or [historical](../../user/project/releases/index.md#historical-releases) release. |
2019-02-15 15:39:39 +05:30
Example request:
2020-03-13 15:44:24 +05:30
```shell
2021-03-08 18:12:59 +05:30
curl --header 'Content-Type: application/json' --header "PRIVATE-TOKEN: <your_access_token>" \
2023-04-23 21:23:45 +05:30
--data '{ "name": "New release", "tag_name": "v0.3", "description": "Super nice release", "milestones": ["v1.0", "v1.0-rc"], "assets": { "links": [{ "name": "hoge", "url": "https://google.com", "direct_asset_path": "/binaries/linux-amd64", "link_type":"other" }] } }' \
2021-02-22 17:27:13 +05:30
--request POST "https://gitlab.example.com/api/v4/projects/24/releases"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
{
"tag_name":"v0.3",
"description":"Super nice release",
"name":"New release",
"created_at":"2019-01-03T02:22:45.118Z",
2019-09-30 21:07:59 +05:30
"released_at":"2019-01-03T02:22:45.118Z",
2019-02-15 15:39:39 +05:30
"author":{
"id":1,
"name":"Administrator",
"username":"root",
"state":"active",
"avatar_url":"https://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=80\u0026d=identicon",
2019-12-04 20:38:33 +05:30
"web_url":"https://gitlab.example.com/root"
2019-02-15 15:39:39 +05:30
},
"commit":{
"id":"079e90101242458910cccd35eab0e211dfc359c0",
"short_id":"079e9010",
"title":"Update README.md",
"created_at":"2019-01-03T01:55:38.000Z",
"parent_ids":[
"f8d3d94cbd347e924aa7b715845e439d00e80ca4"
],
"message":"Update README.md",
"author_name":"Administrator",
"author_email":"admin@example.com",
"authored_date":"2019-01-03T01:55:38.000Z",
"committer_name":"Administrator",
"committer_email":"admin@example.com",
"committed_date":"2019-01-03T01:55:38.000Z"
},
2019-12-04 20:38:33 +05:30
"milestones": [
{
"id":51,
"iid":1,
"project_id":24,
"title":"v1.0-rc",
"description":"Voluptate fugiat possimus quis quod aliquam expedita.",
"state":"closed",
"created_at":"2019-07-12T19:45:44.256Z",
"updated_at":"2019-07-12T19:45:44.256Z",
2021-11-11 11:23:49 +05:30
"due_date":"2019-08-16",
"start_date":"2019-07-30",
2020-04-08 14:13:33 +05:30
"web_url":"https://gitlab.example.com/root/awesome-app/-/milestones/1",
"issue_stats": {
"total": 99,
"closed": 76
}
2019-12-04 20:38:33 +05:30
},
{
"id":52,
"iid":2,
"project_id":24,
"title":"v1.0",
"description":"Voluptate fugiat possimus quis quod aliquam expedita.",
"state":"closed",
"created_at":"2019-07-16T14:00:12.256Z",
"updated_at":"2019-07-16T14:00:12.256Z",
2021-11-11 11:23:49 +05:30
"due_date":"2019-08-16",
"start_date":"2019-07-30",
2020-04-08 14:13:33 +05:30
"web_url":"https://gitlab.example.com/root/awesome-app/-/milestones/2",
"issue_stats": {
"total": 24,
"closed": 21
}
2019-12-04 20:38:33 +05:30
}
],
2019-12-21 20:55:43 +05:30
"commit_path":"/root/awesome-app/commit/588440f66559714280628a4f9799f0c4eb880a4a",
"tag_path":"/root/awesome-app/-/tags/v0.11.1",
2020-01-01 13:55:28 +05:30
"evidence_sha":"760d6cdfb0879c3ffedec13af470e0f71cf52c6cde4d",
2019-02-15 15:39:39 +05:30
"assets":{
"count":5,
"sources":[
{
"format":"zip",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.3/awesome-app-v0.3.zip"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.gz",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.3/awesome-app-v0.3.tar.gz"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.bz2",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.3/awesome-app-v0.3.tar.bz2"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.3/awesome-app-v0.3.tar"
2019-02-15 15:39:39 +05:30
}
],
"links":[
{
"id":3,
"name":"hoge",
2020-04-08 14:13:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/tags/v0.11.1/binaries/linux-amd64",
2023-04-23 21:23:45 +05:30
"external":true, // deprecated in GitLab 15.9, will be removed in GitLab 16.0.
2020-06-23 00:09:42 +05:30
"link_type":"other"
2019-02-15 15:39:39 +05:30
}
2020-01-01 13:55:28 +05:30
],
"evidence_file_path":"https://gitlab.example.com/root/awesome-app/-/releases/v0.3/evidence.json"
2021-06-08 01:23:25 +05:30
}
2019-02-15 15:39:39 +05:30
}
```
2021-03-11 19:13:27 +05:30
### Group milestones **(PREMIUM SELF)**
2021-01-03 14:25:43 +05:30
2021-11-11 11:23:49 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/235391) in GitLab 13.5.
2021-01-03 14:25:43 +05:30
Group milestones associated with the project may be specified in the `milestones`
array for [Create a release](#create-a-release) and [Update a release](#update-a-release)
API calls. Only milestones associated with the project's group may be specified, and
2021-03-08 18:12:59 +05:30
adding milestones for ancestor groups raises an error.
2021-01-03 14:25:43 +05:30
2021-03-11 19:13:27 +05:30
## Collect release evidence **(PREMIUM SELF)**
2020-04-22 19:07:51 +05:30
2021-12-11 22:18:48 +05:30
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/199065) in GitLab 12.10.
> - [Changed](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/72448) to allow for `JOB-TOKEN` in GitLab 14.5.
2020-04-22 19:07:51 +05:30
2023-01-13 00:05:48 +05:30
Creates an evidence for an existing release.
2020-04-22 19:07:51 +05:30
```plaintext
POST /projects/:id/releases/:tag_name/evidence
```
| Attribute | Type | Required | Description |
| ------------- | -------------- | -------- | ----------------------------------------------------------------------------------- |
2023-04-23 21:23:45 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project](../rest/index.md#namespaced-path-encoding). |
2021-01-29 00:20:46 +05:30
| `tag_name` | string | yes | The Git tag the release is associated with. |
2020-04-22 19:07:51 +05:30
Example request:
```shell
2021-03-08 18:12:59 +05:30
curl --request POST --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/projects/24/releases/v0.1/evidence"
2020-04-22 19:07:51 +05:30
```
Example response:
```json
200
```
2019-02-15 15:39:39 +05:30
## Update a release
2021-12-11 22:18:48 +05:30
> [Changed](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/72448) to allow for `JOB-TOKEN` in GitLab 14.5.
2023-01-13 00:05:48 +05:30
Updates a release. Developer level access to the project is required to update a release.
2019-02-15 15:39:39 +05:30
2020-04-08 14:13:33 +05:30
```plaintext
2019-02-15 15:39:39 +05:30
PUT /projects/:id/releases/:tag_name
```
2019-12-04 20:38:33 +05:30
| Attribute | Type | Required | Description |
| ------------- | --------------- | -------- | ----------------------------------------------------------------------------------------------------------- |
2023-04-23 21:23:45 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project](../rest/index.md#namespaced-path-encoding). |
2021-01-29 00:20:46 +05:30
| `tag_name` | string | yes | The Git tag the release is associated with. |
2019-12-04 20:38:33 +05:30
| `name` | string | no | The release name. |
2020-01-01 13:55:28 +05:30
| `description` | string | no | The description of the release. You can use [Markdown](../../user/markdown.md). |
2021-01-03 14:25:43 +05:30
| `milestones` | array of string | no | The title of each milestone to associate with the release. [GitLab Premium](https://about.gitlab.com/pricing/) customers can specify group milestones. To remove all milestones from the release, specify `[]`. |
2021-03-08 18:12:59 +05:30
| `released_at` | datetime | no | The date when the release is/was ready. Expected in ISO 8601 format (`2019-03-15T08:00:00Z`). |
2019-02-15 15:39:39 +05:30
Example request:
2020-03-13 15:44:24 +05:30
```shell
2021-09-04 01:27:46 +05:30
curl --header 'Content-Type: application/json' --request PUT --data '{"name": "new name", "milestones": ["v1.2"]}' \
--header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/projects/24/releases/v0.1"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
{
"tag_name":"v0.1",
"description":"## CHANGELOG\r\n\r\n- Remove limit of 100 when searching repository code. !8671\r\n- Show error message when attempting to reopen an MR and there is an open MR for the same branch. !16447 (Akos Gyimesi)\r\n- Fix a bug where internal email pattern wasn't respected. !22516",
"name":"new name",
"created_at":"2019-01-03T01:55:18.203Z",
2019-09-30 21:07:59 +05:30
"released_at":"2019-01-03T01:55:18.203Z",
2019-02-15 15:39:39 +05:30
"author":{
"id":1,
"name":"Administrator",
"username":"root",
"state":"active",
"avatar_url":"https://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=80\u0026d=identicon",
2019-12-04 20:38:33 +05:30
"web_url":"https://gitlab.example.com/root"
2019-02-15 15:39:39 +05:30
},
"commit":{
"id":"f8d3d94cbd347e924aa7b715845e439d00e80ca4",
"short_id":"f8d3d94c",
"title":"Initial commit",
"created_at":"2019-01-03T01:53:28.000Z",
"parent_ids":[
],
"message":"Initial commit",
"author_name":"Administrator",
"author_email":"admin@example.com",
"authored_date":"2019-01-03T01:53:28.000Z",
"committer_name":"Administrator",
"committer_email":"admin@example.com",
"committed_date":"2019-01-03T01:53:28.000Z"
},
2019-12-04 20:38:33 +05:30
"milestones": [
{
"id":53,
"iid":3,
"project_id":24,
2021-01-29 00:20:46 +05:30
"title":"v1.2",
2019-12-04 20:38:33 +05:30
"description":"Voluptate fugiat possimus quis quod aliquam expedita.",
"state":"active",
"created_at":"2019-09-01T13:00:00.256Z",
"updated_at":"2019-09-01T13:00:00.256Z",
2021-11-11 11:23:49 +05:30
"due_date":"2019-09-20",
"start_date":"2019-09-05",
2020-04-08 14:13:33 +05:30
"web_url":"https://gitlab.example.com/root/awesome-app/-/milestones/3",
"issue_stats": {
"opened": 11,
"closed": 78
}
2019-12-04 20:38:33 +05:30
}
],
2019-12-21 20:55:43 +05:30
"commit_path":"/root/awesome-app/commit/588440f66559714280628a4f9799f0c4eb880a4a",
"tag_path":"/root/awesome-app/-/tags/v0.11.1",
2020-01-01 13:55:28 +05:30
"evidence_sha":"760d6cdfb0879c3ffedec13af470e0f71cf52c6cde4d",
2019-02-15 15:39:39 +05:30
"assets":{
"count":4,
"sources":[
{
"format":"zip",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.zip"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.gz",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar.gz"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.bz2",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar.bz2"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar"
2019-02-15 15:39:39 +05:30
}
],
"links":[
2020-01-01 13:55:28 +05:30
],
"evidence_file_path":"https://gitlab.example.com/root/awesome-app/-/releases/v0.1/evidence.json"
2021-06-08 01:23:25 +05:30
}
2019-02-15 15:39:39 +05:30
}
```
## Delete a Release
2021-12-11 22:18:48 +05:30
> [Changed](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/72448) to allow for `JOB-TOKEN` in GitLab 14.5.
2023-01-13 00:05:48 +05:30
Deletes a release. Deleting a release doesn't delete the associated tag. Maintainer level access to the project is required to delete a release.
2019-02-15 15:39:39 +05:30
2020-04-08 14:13:33 +05:30
```plaintext
2019-02-15 15:39:39 +05:30
DELETE /projects/:id/releases/:tag_name
```
2019-12-04 20:38:33 +05:30
| Attribute | Type | Required | Description |
| ------------- | -------------- | -------- | ----------------------------------------------------------------------------------- |
2023-04-23 21:23:45 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project](../rest/index.md#namespaced-path-encoding). |
2021-01-29 00:20:46 +05:30
| `tag_name` | string | yes | The Git tag the release is associated with. |
2019-02-15 15:39:39 +05:30
Example request:
2020-03-13 15:44:24 +05:30
```shell
2021-03-08 18:12:59 +05:30
curl --request DELETE --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/projects/24/releases/v0.1"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
{
"tag_name":"v0.1",
"description":"## CHANGELOG\r\n\r\n- Remove limit of 100 when searching repository code. !8671\r\n- Show error message when attempting to reopen an MR and there is an open MR for the same branch. !16447 (Akos Gyimesi)\r\n- Fix a bug where internal email pattern wasn't respected. !22516",
"name":"new name",
"created_at":"2019-01-03T01:55:18.203Z",
2019-09-30 21:07:59 +05:30
"released_at":"2019-01-03T01:55:18.203Z",
2019-02-15 15:39:39 +05:30
"author":{
"id":1,
"name":"Administrator",
"username":"root",
"state":"active",
"avatar_url":"https://www.gravatar.com/avatar/e64c7d89f26bd1972efa854d13d7dd61?s=80\u0026d=identicon",
2019-12-04 20:38:33 +05:30
"web_url":"https://gitlab.example.com/root"
2019-02-15 15:39:39 +05:30
},
"commit":{
"id":"f8d3d94cbd347e924aa7b715845e439d00e80ca4",
"short_id":"f8d3d94c",
"title":"Initial commit",
"created_at":"2019-01-03T01:53:28.000Z",
"parent_ids":[
],
"message":"Initial commit",
"author_name":"Administrator",
"author_email":"admin@example.com",
"authored_date":"2019-01-03T01:53:28.000Z",
"committer_name":"Administrator",
"committer_email":"admin@example.com",
"committed_date":"2019-01-03T01:53:28.000Z"
},
2019-12-21 20:55:43 +05:30
"commit_path":"/root/awesome-app/commit/588440f66559714280628a4f9799f0c4eb880a4a",
"tag_path":"/root/awesome-app/-/tags/v0.11.1",
2020-01-01 13:55:28 +05:30
"evidence_sha":"760d6cdfb0879c3ffedec13af470e0f71cf52c6cde4d",
2019-02-15 15:39:39 +05:30
"assets":{
"count":4,
"sources":[
{
"format":"zip",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.zip"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.gz",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar.gz"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar.bz2",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar.bz2"
2019-02-15 15:39:39 +05:30
},
{
"format":"tar",
2019-12-04 20:38:33 +05:30
"url":"https://gitlab.example.com/root/awesome-app/-/archive/v0.1/awesome-app-v0.1.tar"
2019-02-15 15:39:39 +05:30
}
],
"links":[
2020-01-01 13:55:28 +05:30
],
"evidence_file_path":"https://gitlab.example.com/root/awesome-app/-/releases/v0.1/evidence.json"
2021-06-08 01:23:25 +05:30
}
2019-02-15 15:39:39 +05:30
}
```
2019-09-30 21:07:59 +05:30
## Upcoming Releases
2020-06-23 00:09:42 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/38105) in GitLab 12.1.
2019-09-30 21:07:59 +05:30
2021-06-08 01:23:25 +05:30
A release with a `released_at` attribute set to a future date is labeled
as an **Upcoming Release** [in the UI](../../user/project/releases/index.md#upcoming-releases).
2021-11-18 22:05:49 +05:30
2022-08-27 11:52:29 +05:30
Additionally, if a [release is requested from the API](#list-releases), for each release with a `release_at` attribute set to a future date, an additional attribute `upcoming_release` (set to true) is returned as part of the response.
## Historical releases
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/199429) in GitLab 15.2.
A release with a `released_at` attribute set to a past date is labeled
as an **Historical release** [in the UI](../../user/project/releases/index.md#historical-releases).
Additionally, if a [release is requested from the API](#list-releases), for each
release with a `release_at` attribute set to a past date, an additional
attribute `historical_release` (set to true) is returned as part of the response.