2020-07-30 08:09:33 -04:00
---
stage: Create
group: Source Code
2020-11-26 01:09:20 -05:00
info: "To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments"
2020-07-30 08:09:33 -04:00
type: reference, api
---
2021-02-09 13:09:59 -05:00
# Project remote mirrors API **(FREE)**
2020-03-06 16:07:59 -05:00
2020-09-07 11:09:04 -04:00
[Push mirrors ](../user/project/repository/repository_mirroring.md#pushing-to-a-remote-repository )
2020-03-06 16:07:59 -05:00
defined on a project's repository settings are called "remote mirrors", and the
state of these mirrors can be queried and modified via the remote mirror API
outlined below.
## List a project's remote mirrors
2020-05-21 02:08:25 -04:00
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/38121) in GitLab 12.9.
2020-03-06 16:07:59 -05:00
Returns an Array of remote mirrors and their statuses:
2020-05-19 23:08:04 -04:00
```plaintext
2020-03-06 16:07:59 -05:00
GET /projects/:id/remote_mirrors
```
Example request:
2020-05-19 14:08:11 -04:00
```shell
2020-05-27 20:08:37 -04:00
curl --header "PRIVATE-TOKEN: < your_access_token > " "https://gitlab.example.com/api/v4/projects/42/remote_mirrors"
2020-03-06 16:07:59 -05:00
```
Example response:
```json
[
{
"enabled": true,
"id": 101486,
"last_error": null,
"last_successful_update_at": "2020-01-06T17:32:02.823Z",
"last_update_at": "2020-01-06T17:32:02.823Z",
"last_update_started_at": "2020-01-06T17:31:55.864Z",
"only_protected_branches": true,
2020-05-18 20:07:58 -04:00
"keep_divergent_refs": true,
2020-03-06 16:07:59 -05:00
"update_status": "finished",
"url": "https://*****:*****@gitlab.com/gitlab-org/security/gitlab.git"
}
]
```
2020-12-04 16:09:29 -05:00
NOTE:
2020-03-06 16:07:59 -05:00
For security reasons, the `url` attribute will always be scrubbed of username
and password information.
## Create a remote mirror
2020-05-21 02:08:25 -04:00
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/24189) in GitLab 12.9.
2020-03-06 16:07:59 -05:00
Create a remote mirror for a project. The mirror will be disabled by default. You can enable it by including the optional parameter `enabled` when creating it:
2020-05-19 23:08:04 -04:00
```plaintext
2020-03-06 16:07:59 -05:00
POST /projects/:id/remote_mirrors
```
| Attribute | Type | Required | Description |
| :---------- | :----- | :--------- | :------------ |
| `url` | String | yes | The URL of the remote repository to be mirrored. |
| `enabled` | Boolean | no | Determines if the mirror is enabled. |
| `only_protected_branches` | Boolean | no | Determines if only protected branches are mirrored. |
2020-05-18 20:07:58 -04:00
| `keep_divergent_refs` | Boolean | no | Determines if divergent refs are skipped. |
2020-03-06 16:07:59 -05:00
Example request:
2020-05-19 14:08:11 -04:00
```shell
2020-05-27 20:08:37 -04:00
curl --request POST --data "url=https://username:token@example.com/gitlab/example.git" --header "PRIVATE-TOKEN: < your_access_token > " "https://gitlab.example.com/api/v4/projects/42/remote_mirrors"
2020-03-06 16:07:59 -05:00
```
Example response:
```json
{
"enabled": false,
"id": 101486,
"last_error": null,
"last_successful_update_at": null,
"last_update_at": null,
"last_update_started_at": null,
"only_protected_branches": false,
2020-05-18 20:07:58 -04:00
"keep_divergent_refs": false,
2020-03-06 16:07:59 -05:00
"update_status": "none",
"url": "https://*****:*****@example.com/gitlab/example.git"
}
```
## Update a remote mirror's attributes
2020-05-21 02:08:25 -04:00
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/38121) in GitLab 12.9.
2020-03-06 16:07:59 -05:00
Toggle a remote mirror on or off, or change which types of branches are
mirrored:
2020-05-19 23:08:04 -04:00
```plaintext
2020-03-06 16:07:59 -05:00
PUT /projects/:id/remote_mirrors/:mirror_id
```
| Attribute | Type | Required | Description |
| :---------- | :----- | :--------- | :------------ |
| `mirror_id` | Integer | yes | The remote mirror ID. |
| `enabled` | Boolean | no | Determines if the mirror is enabled. |
| `only_protected_branches` | Boolean | no | Determines if only protected branches are mirrored. |
2020-05-18 20:07:58 -04:00
| `keep_divergent_refs` | Boolean | no | Determines if divergent refs are skipped. |
2020-03-06 16:07:59 -05:00
Example request:
2020-05-19 14:08:11 -04:00
```shell
2020-05-27 20:08:37 -04:00
curl --request PUT --data "enabled=false" --header "PRIVATE-TOKEN: < your_access_token > " "https://gitlab.example.com/api/v4/projects/42/remote_mirrors/101486"
2020-03-06 16:07:59 -05:00
```
Example response:
```json
{
"enabled": false,
"id": 101486,
"last_error": null,
"last_successful_update_at": "2020-01-06T17:32:02.823Z",
"last_update_at": "2020-01-06T17:32:02.823Z",
"last_update_started_at": "2020-01-06T17:31:55.864Z",
"only_protected_branches": true,
2020-05-18 20:07:58 -04:00
"keep_divergent_refs": true,
2020-03-06 16:07:59 -05:00
"update_status": "finished",
"url": "https://*****:*****@gitlab.com/gitlab-org/security/gitlab.git"
}
```