Project relations export API
- Tier: Free, Premium, Ultimate
- Offering: GitLab.com, GitLab Self-Managed, GitLab Dedicated
Use this API to migrate a project structure. Each top-level relation (for example, milestones, boards, and labels) is stored as a separate file.
This API is primarily used during group migration by direct transfer. You cannot use this API with the project import and export API.
Schedule new export
Start a new project relations export:
POST /projects/:id/export_relations| Attribute | Type | Required | Description |
|---|---|---|---|
id | integer or string | Yes | ID of the project. |
batched | boolean | No | Whether to export in batches. |
curl --request POST \
--header "PRIVATE-TOKEN: <your_access_token>" \
--url "https://gitlab.example.com/api/v4/projects/1/export_relations"{
"message": "202 Accepted"
}Export status
View the status of the relations export:
GET /projects/:id/export_relations/status| Attribute | Type | Required | Description |
|---|---|---|---|
id | integer or string | Yes | ID of the project. |
relation | string | No | Name of the project top-level relation to view. |
curl --request GET \
--header "PRIVATE-TOKEN: <your_access_token>" \
--url "https://gitlab.example.com/api/v4/projects/1/export_relations/status"The status can be one of the following:
0:started1:finished-1:failed
[
{
"relation": "project_badges",
"status": 1,
"error": null,
"updated_at": "2021-05-04T11:25:20.423Z",
"batched": true,
"batches_count": 1,
"batches": [
{
"status": 1,
"batch_number": 1,
"objects_count": 1,
"error": null,
"updated_at": "2021-05-04T11:25:20.423Z"
}
]
},
{
"relation": "boards",
"status": 1,
"error": null,
"updated_at": "2021-05-04T11:25:20.085Z",
"batched": false,
"batches_count": 0
}
]Export download
Download the finished relations export:
GET /projects/:id/export_relations/download| Attribute | Type | Required | Description |
|---|---|---|---|
id | integer or string | Yes | ID of the project. |
relation | string | Yes | Name of the project top-level relation to download. |
batched | boolean | No | Whether the export is batched. |
batch_number | integer | No | Number of export batch to download. |
curl --request GET \
--header "PRIVATE-TOKEN: <your_access_token>" \
--remote-header-name \
--remote-name \
--url "https://gitlab.example.com/api/v4/projects/1/export_relations/download?relation=labels"ls labels.ndjson.gz
labels.ndjson.gz