Group relations export API
- Tier: Free, Premium, Ultimate
- Offering: GitLab.com, GitLab Self-Managed, GitLab Dedicated
This API is used by the destination instance during group migration by direct transfer to migrate a group structure. You don’t usually need to use this API yourself.
In this context, a ​ is an exportable item such as an epic. When exported, the relation includes any items related to the relation such as a label.
If you want to use this API, your GitLab instance must meet certain prerequisites.
This API can’t be used with the group import and export API, which is for file-based migration.
Schedule new export
Start a new group relations export:
POST /groups/:id/export_relations| Attribute | Type | Required | Description |
|---|---|---|---|
id |
Integer or string | Yes | ID of the group. |
batched |
Boolean | No | Whether to export in batches. |
curl --request POST \
--header "PRIVATE-TOKEN: <your_access_token>" \
--url "https://gitlab.example.com/api/v4/groups/1/export_relations"{
"message": "202 Accepted"
}Export status
View the status of the relations export:
GET /groups/:id/export_relations/status| Attribute | Type | Required | Description |
|---|---|---|---|
id |
Integer or string | Yes | ID of the group. |
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/groups/1/export_relations/status"The status can be one of the following:
0:started1:finished-1:failed
[
{
"relation": "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 /groups/:id/export_relations/download| Attribute | Type | Required | Description |
|---|---|---|---|
id |
Integer or string | Yes | ID of the group. |
relation |
String | Yes | Name of the group 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 "https://gitlab.example.com/api/v4/groups/1/export_relations/download?relation=labels"ls labels.ndjson.gz
labels.ndjson.gz