diff options
| author | Toon Claes <toon@gitlab.com> | 2017-02-01 11:23:57 +0100 | 
|---|---|---|
| committer | Toon Claes <toon@gitlab.com> | 2017-02-14 16:41:57 +0100 | 
| commit | 4e9e29d295fe2f8cd258cde4b65e244eb74a1ae6 (patch) | |
| tree | a1112a9839019fd0c667d19d995474bae1ed8a17 /doc/api | |
| parent | 9a0c1ffabcfc9d29e8cccd8d1e2162d6abbf9277 (diff) | |
| download | gitlab-ce-4e9e29d295fe2f8cd258cde4b65e244eb74a1ae6.tar.gz | |
API: Consolidate /projects endpoint
It consolidates these endpoints:
 - /projects
 - /projects/owned
 - /projects/visible
 - /projects/starred
 - /projects/all
Into the /projects endpoint using query parameters.
Diffstat (limited to 'doc/api')
| -rw-r--r-- | doc/api/groups.md | 2 | ||||
| -rw-r--r-- | doc/api/projects.md | 186 | ||||
| -rw-r--r-- | doc/api/v3_to_v4.md | 2 | 
3 files changed, 5 insertions, 185 deletions
| diff --git a/doc/api/groups.md b/doc/api/groups.md index a3a43ca7f1c..4a39dbc5555 100644 --- a/doc/api/groups.md +++ b/doc/api/groups.md @@ -73,6 +73,8 @@ Parameters:  | `sort` | string | no | Return projects sorted in `asc` or `desc` order. Default is `desc` |  | `search` | string | no | Return list of authorized projects matching the search criteria |  | `simple` | boolean | no | Return only the ID, URL, name, and path of each project | +| `owned` | boolean | no | Limit by projects owned by the current user | +| `starred` | boolean | no | Limit by projects starred by the current user |  Example response: diff --git a/doc/api/projects.md b/doc/api/projects.md index e579b89d836..fa51158956a 100644 --- a/doc/api/projects.md +++ b/doc/api/projects.md @@ -36,6 +36,8 @@ Parameters:  | `sort` | string | no | Return projects sorted in `asc` or `desc` order. Default is `desc` |  | `search` | string | no | Return list of authorized projects matching the search criteria |  | `simple` | boolean | no | Return only the ID, URL, name, and path of each project | +| `owned` | boolean | no | Limit by projects owned by the current user | +| `starred` | boolean | no | Limit by projects starred by the current user |  ```json  [ @@ -152,190 +154,6 @@ Parameters:  ]  ``` -Get a list of projects which the authenticated user can see. - -``` -GET /projects/visible -``` - -Parameters: - -| Attribute | Type | Required | Description | -| --------- | ---- | -------- | ----------- | -| `archived` | boolean | no | Limit by archived status | -| `visibility` | string | no | Limit by visibility `public`, `internal`, or `private` | -| `order_by` | string | no | Return projects ordered by `id`, `name`, `path`, `created_at`, `updated_at`, or `last_activity_at` fields. Default is `created_at` | -| `sort` | string | no | Return projects sorted in `asc` or `desc` order. Default is `desc` | -| `search` | string | no | Return list of authorized projects matching the search criteria | -| `simple` | boolean | no | Return only the ID, URL, name, and path of each project | - -```json -[ -  { -    "id": 4, -    "description": null, -    "default_branch": "master", -    "public": false, -    "visibility_level": 0, -    "ssh_url_to_repo": "git@example.com:diaspora/diaspora-client.git", -    "http_url_to_repo": "http://example.com/diaspora/diaspora-client.git", -    "web_url": "http://example.com/diaspora/diaspora-client", -    "tag_list": [ -      "example", -      "disapora client" -    ], -    "owner": { -      "id": 3, -      "name": "Diaspora", -      "created_at": "2013-09-30T13:46:02Z" -    }, -    "name": "Diaspora Client", -    "name_with_namespace": "Diaspora / Diaspora Client", -    "path": "diaspora-client", -    "path_with_namespace": "diaspora/diaspora-client", -    "issues_enabled": true, -    "open_issues_count": 1, -    "merge_requests_enabled": true, -    "builds_enabled": true, -    "wiki_enabled": true, -    "snippets_enabled": false, -    "container_registry_enabled": false, -    "created_at": "2013-09-30T13:46:02Z", -    "last_activity_at": "2013-09-30T13:46:02Z", -    "creator_id": 3, -    "namespace": { -      "id": 3, -      "name": "Diaspora", -      "path": "diaspora", -      "kind": "group" -    }, -    "archived": false, -    "avatar_url": "http://example.com/uploads/project/avatar/4/uploads/avatar.png", -    "shared_runners_enabled": true, -    "forks_count": 0, -    "star_count": 0, -    "runners_token": "b8547b1dc37721d05889db52fa2f02", -    "public_builds": true, -    "shared_with_groups": [] -  }, -  { -    "id": 6, -    "description": null, -    "default_branch": "master", -    "public": false, -    "visibility_level": 0, -    "ssh_url_to_repo": "git@example.com:brightbox/puppet.git", -    "http_url_to_repo": "http://example.com/brightbox/puppet.git", -    "web_url": "http://example.com/brightbox/puppet", -    "tag_list": [ -      "example", -      "puppet" -    ], -    "owner": { -      "id": 4, -      "name": "Brightbox", -      "created_at": "2013-09-30T13:46:02Z" -    }, -    "name": "Puppet", -    "name_with_namespace": "Brightbox / Puppet", -    "path": "puppet", -    "path_with_namespace": "brightbox/puppet", -    "issues_enabled": true, -    "open_issues_count": 1, -    "merge_requests_enabled": true, -    "builds_enabled": true, -    "wiki_enabled": true, -    "snippets_enabled": false, -    "container_registry_enabled": false, -    "created_at": "2013-09-30T13:46:02Z", -    "last_activity_at": "2013-09-30T13:46:02Z", -    "creator_id": 3, -    "namespace": { -      "id": 4, -      "name": "Brightbox", -      "path": "brightbox", -      "kind": "group" -    }, -    "permissions": { -      "project_access": { -        "access_level": 10, -        "notification_level": 3 -      }, -      "group_access": { -        "access_level": 50, -        "notification_level": 3 -      } -    }, -    "archived": false, -    "avatar_url": null, -    "shared_runners_enabled": true, -    "forks_count": 0, -    "star_count": 0, -    "runners_token": "b8547b1dc37721d05889db52fa2f02", -    "public_builds": true, -    "shared_with_groups": [] -  } -] -``` - -### List owned projects - -Get a list of projects which are owned by the authenticated user. - -``` -GET /projects/owned -``` - -Parameters: - -| Attribute | Type | Required | Description | -| --------- | ---- | -------- | ----------- | -| `archived` | boolean | no | Limit by archived status | -| `visibility` | string | no | Limit by visibility `public`, `internal`, or `private` | -| `order_by` | string | no | Return projects ordered by `id`, `name`, `path`, `created_at`, `updated_at`, or `last_activity_at` fields. Default is `created_at` | -| `sort` | string | no | Return projects sorted in `asc` or `desc` order. Default is `desc` | -| `search` | string | no | Return list of authorized projects matching the search criteria | -| `simple` | boolean | no | Return only the ID, URL, name, and path of each project | -| `statistics` | boolean | no | Include project statistics | - -### List starred projects - -Get a list of projects which are starred by the authenticated user. - -``` -GET /projects/starred -``` - -Parameters: - -| Attribute | Type | Required | Description | -| --------- | ---- | -------- | ----------- | -| `archived` | boolean | no | Limit by archived status | -| `visibility` | string | no | Limit by visibility `public`, `internal`, or `private` | -| `order_by` | string | no | Return projects ordered by `id`, `name`, `path`, `created_at`, `updated_at`, or `last_activity_at` fields. Default is `created_at` | -| `sort` | string | no | Return projects sorted in `asc` or `desc` order. Default is `desc` | -| `search` | string | no | Return list of authorized projects matching the search criteria | -| `simple` | boolean | no | Return only the ID, URL, name, and path of each project | - -### List ALL projects - -Get a list of all GitLab projects (admin only). - -``` -GET /projects/all -``` - -Parameters: - -| Attribute | Type | Required | Description | -| --------- | ---- | -------- | ----------- | -| `archived` | boolean | no | Limit by archived status | -| `visibility` | string | no | Limit by visibility `public`, `internal`, or `private` | -| `order_by` | string | no | Return projects ordered by `id`, `name`, `path`, `created_at`, `updated_at`, or `last_activity_at` fields. Default is `created_at` | -| `sort` | string | no | Return projects sorted in `asc` or `desc` order. Default is `desc` | -| `search` | string | no | Return list of authorized projects matching the search criteria | -| `statistics` | boolean | no | Include project statistics | -  ### Get single project  Get a specific project, identified by project ID or NAMESPACE/PROJECT_NAME, which is owned by the authenticated user. diff --git a/doc/api/v3_to_v4.md b/doc/api/v3_to_v4.md index 7811025f34e..84ff72bc36c 100644 --- a/doc/api/v3_to_v4.md +++ b/doc/api/v3_to_v4.md @@ -23,4 +23,4 @@ changes are in V4:    - `/gitlab_ci_ymls/:key`    - `/dockerfiles/:key`  - Moved `/projects/fork/:id` to `/projects/:id/fork` - +- Endpoints `/projects/owned`, `/projects/visible`, `/projects/starred` & `/projects/all` are consolidated into `/projects` using query parameters | 
