diff options
Diffstat (limited to 'doc/api/projects.md')
| -rw-r--r-- | doc/api/projects.md | 164 | 
1 files changed, 164 insertions, 0 deletions
| diff --git a/doc/api/projects.md b/doc/api/projects.md index 3703f4b327a..44d40235e9e 100644 --- a/doc/api/projects.md +++ b/doc/api/projects.md @@ -491,6 +491,170 @@ Parameters:  - `id` (required) - The ID of the project to be forked +### Archive a project + +Archives a project if the user has the right access level to this project. This action is +idempotent, thus archiving an already archived project will not change the project. + +Status code 200 with the project as body is given when successful, in case the user doesn't +have the proper access rights, code 404 is returned. + +``` +PUT /projects/:id/archive +``` + +| Attribute | Type | Required | Description | +| --------- | ---- | -------- | ----------- | +| `id`      | integer | yes | The ID of the project | + +```bash +curl -X PUT -H "PRIVATE-TOKEN: 9koXpg98eAheJpvBs5tK" "https://gitlab.example.com/api/v3/projects/archive" +``` + +Example response: + +```json +{ +  "id": 3, +  "description": null, +  "default_branch": "master", +  "public": false, +  "visibility_level": 0, +  "ssh_url_to_repo": "git@example.com:diaspora/diaspora-project-site.git", +  "http_url_to_repo": "http://example.com/diaspora/diaspora-project-site.git", +  "web_url": "http://example.com/diaspora/diaspora-project-site", +  "tag_list": [ +    "example", +    "disapora project" +  ], +  "owner": { +    "id": 3, +    "name": "Diaspora", +    "created_at": "2013-09-30T13: 46: 02Z" +  }, +  "name": "Diaspora Project Site", +  "name_with_namespace": "Diaspora / Diaspora Project Site", +  "path": "diaspora-project-site", +  "path_with_namespace": "diaspora/diaspora-project-site", +  "issues_enabled": true, +  "open_issues_count": 1, +  "merge_requests_enabled": true, +  "builds_enabled": true, +  "wiki_enabled": true, +  "snippets_enabled": false, +  "created_at": "2013-09-30T13: 46: 02Z", +  "last_activity_at": "2013-09-30T13: 46: 02Z", +  "creator_id": 3, +  "namespace": { +    "created_at": "2013-09-30T13: 46: 02Z", +    "description": "", +    "id": 3, +    "name": "Diaspora", +    "owner_id": 1, +    "path": "diaspora", +    "updated_at": "2013-09-30T13: 46: 02Z" +  }, +  "permissions": { +    "project_access": { +      "access_level": 10, +      "notification_level": 3 +    }, +    "group_access": { +      "access_level": 50, +      "notification_level": 3 +    } +  }, +  "archived": true, +  "avatar_url": "http://example.com/uploads/project/avatar/3/uploads/avatar.png", +  "shared_runners_enabled": true, +  "forks_count": 0, +  "star_count": 0, +  "runners_token": "b8bc4a7a29eb76ea83cf79e4908c2b" +} +``` + +### Unarchive a project + +Unarchives a project if the user has the right access level to this project. This action is +idempotent, thus unarchiving an non-archived project will not change the project. + +Status code 200 with the project as body is given when successful, in case the user doesn't +have the proper access rights, code 404 is returned. + +``` +PUT /projects/:id/archive +``` + +| Attribute | Type | Required | Description | +| --------- | ---- | -------- | ----------- | +| `id`      | integer | yes | The ID of the project | + +```bash +curl -X PUT -H "PRIVATE-TOKEN: 9koXpg98eAheJpvBs5tK" "https://gitlab.example.com/api/v3/projects/unarchive" +``` + +Example response: + +```json +{ +  "id": 3, +  "description": null, +  "default_branch": "master", +  "public": false, +  "visibility_level": 0, +  "ssh_url_to_repo": "git@example.com:diaspora/diaspora-project-site.git", +  "http_url_to_repo": "http://example.com/diaspora/diaspora-project-site.git", +  "web_url": "http://example.com/diaspora/diaspora-project-site", +  "tag_list": [ +    "example", +    "disapora project" +  ], +  "owner": { +    "id": 3, +    "name": "Diaspora", +    "created_at": "2013-09-30T13: 46: 02Z" +  }, +  "name": "Diaspora Project Site", +  "name_with_namespace": "Diaspora / Diaspora Project Site", +  "path": "diaspora-project-site", +  "path_with_namespace": "diaspora/diaspora-project-site", +  "issues_enabled": true, +  "open_issues_count": 1, +  "merge_requests_enabled": true, +  "builds_enabled": true, +  "wiki_enabled": true, +  "snippets_enabled": false, +  "created_at": "2013-09-30T13: 46: 02Z", +  "last_activity_at": "2013-09-30T13: 46: 02Z", +  "creator_id": 3, +  "namespace": { +    "created_at": "2013-09-30T13: 46: 02Z", +    "description": "", +    "id": 3, +    "name": "Diaspora", +    "owner_id": 1, +    "path": "diaspora", +    "updated_at": "2013-09-30T13: 46: 02Z" +  }, +  "permissions": { +    "project_access": { +      "access_level": 10, +      "notification_level": 3 +    }, +    "group_access": { +      "access_level": 50, +      "notification_level": 3 +    } +  }, +  "archived": false, +  "avatar_url": "http://example.com/uploads/project/avatar/3/uploads/avatar.png", +  "shared_runners_enabled": true, +  "forks_count": 0, +  "star_count": 0, +  "runners_token": "b8bc4a7a29eb76ea83cf79e4908c2b" +} +``` +  ### Remove project  Removes a project including all associated resources (issues, merge requests etc.) | 
