2019-02-15 15:39:39 +05:30
# Release links API
2019-12-04 20:38:33 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/issues/41766) in GitLab 11.7.
2019-02-15 15:39:39 +05:30
Using this API you can manipulate GitLab's [Release ](../../user/project/releases/index.md ) links. For manipulating other Release assets, see [Release API ](index.md ).
2019-07-07 11:18:12 +05:30
GitLab supports links links to `http` , `https` , and `ftp` assets.
2019-02-15 15:39:39 +05:30
## Get links
Get assets as links from a Release.
```
GET /projects/:id/releases/:tag_name/assets/links
```
| Attribute | Type | Required | Description |
| ------------- | -------------- | -------- | --------------------------------------- |
2019-07-07 11:18:12 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project ](../README.md#namespaced-path-encoding ). |
2019-02-15 15:39:39 +05:30
| `tag_name` | string | yes | The tag associated with the Release. |
Example request:
2020-03-09 13:42:32 +05:30
```shell
2019-10-12 21:52:04 +05:30
curl --header "PRIVATE-TOKEN: gDybLx3yrUK_HLp3qPjS" "https://gitlab.example.com/api/v4/projects/24/releases/v0.1/assets/links"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
[
{
"id":2,
"name":"awesome-v0.2.msi",
"url":"http://192.168.10.15:3000/msi",
"external":true
},
{
"id":1,
"name":"awesome-v0.2.dmg",
"url":"http://192.168.10.15:3000",
"external":true
}
]
```
## Get a link
Get an asset as a link from a Release.
```
GET /projects/:id/releases/:tag_name/assets/links/:link_id
```
| Attribute | Type | Required | Description |
| ------------- | -------------- | -------- | --------------------------------------- |
2019-07-07 11:18:12 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project ](../README.md#namespaced-path-encoding ). |
2019-02-15 15:39:39 +05:30
| `tag_name` | string | yes | The tag associated with the Release. |
| `link_id` | integer | yes | The id of the link. |
Example request:
2020-03-09 13:42:32 +05:30
```shell
2019-10-12 21:52:04 +05:30
curl --header "PRIVATE-TOKEN: gDybLx3yrUK_HLp3qPjS" "https://gitlab.example.com/api/v4/projects/24/releases/v0.1/assets/links/1"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
{
"id":1,
"name":"awesome-v0.2.dmg",
"url":"http://192.168.10.15:3000",
"external":true
}
```
## Create a link
Create an asset as a link from a Release.
```
POST /projects/:id/releases/:tag_name/assets/links
```
| Attribute | Type | Required | Description |
| ------------- | -------------- | -------- | --------------------------------------- |
2019-07-07 11:18:12 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project ](../README.md#namespaced-path-encoding ). |
2019-02-15 15:39:39 +05:30
| `tag_name` | string | yes | The tag associated with the Release. |
| `name` | string | yes | The name of the link. |
| `url` | string | yes | The URL of the link. |
Example request:
2020-03-09 13:42:32 +05:30
```shell
2019-02-15 15:39:39 +05:30
curl --request POST \
--header "PRIVATE-TOKEN: gDybLx3yrUK_HLp3qPjS" \
--data name="awesome-v0.2.dmg" \
--data url="http://192.168.10.15:3000" \
2019-10-12 21:52:04 +05:30
"https://gitlab.example.com/api/v4/projects/24/releases/v0.1/assets/links"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
{
"id":1,
"name":"awesome-v0.2.dmg",
"url":"http://192.168.10.15:3000",
"external":true
}
```
## Update a link
Update an asset as a link from a Release.
```
PUT /projects/:id/releases/:tag_name/assets/links/:link_id
```
| Attribute | Type | Required | Description |
| ------------- | -------------- | -------- | --------------------------------------- |
2019-07-07 11:18:12 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project ](../README.md#namespaced-path-encoding ). |
2019-02-15 15:39:39 +05:30
| `tag_name` | string | yes | The tag associated with the Release. |
| `link_id` | integer | yes | The id of the link. |
| `name` | string | no | The name of the link. |
| `url` | string | no | The URL of the link. |
NOTE: **NOTE**
You have to specify at least one of `name` or `url`
Example request:
2020-03-09 13:42:32 +05:30
```shell
2019-10-12 21:52:04 +05:30
curl --request PUT --data name="new name" --header "PRIVATE-TOKEN: gDybLx3yrUK_HLp3qPjS" "https://gitlab.example.com/api/v4/projects/24/releases/v0.1/assets/links/1"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
{
"id":1,
"name":"new name",
"url":"http://192.168.10.15:3000",
"external":true
}
```
## Delete a link
Delete an asset as a link from a Release.
```
DELETE /projects/:id/releases/:tag_name/assets/links/:link_id
```
| Attribute | Type | Required | Description |
| ------------- | -------------- | -------- | --------------------------------------- |
2019-07-07 11:18:12 +05:30
| `id` | integer/string | yes | The ID or [URL-encoded path of the project ](../README.md#namespaced-path-encoding ). |
2019-02-15 15:39:39 +05:30
| `tag_name` | string | yes | The tag associated with the Release. |
| `link_id` | integer | yes | The id of the link. |
Example request:
2020-03-09 13:42:32 +05:30
```shell
2019-10-12 21:52:04 +05:30
curl --request DELETE --header "PRIVATE-TOKEN: gDybLx3yrUK_HLp3qPjS" "https://gitlab.example.com/api/v4/projects/24/releases/v0.1/assets/links/1"
2019-02-15 15:39:39 +05:30
```
Example response:
```json
{
"id":1,
"name":"new name",
"url":"http://192.168.10.15:3000",
"external":true
}
```