diff options
| author | Achilleas Pipinellis <axilleas@axilleas.me> | 2016-01-19 11:18:17 +0100 | 
|---|---|---|
| committer | Achilleas Pipinellis <axilleas@axilleas.me> | 2016-01-19 11:18:17 +0100 | 
| commit | 1ede975cde6d32a74b2d4d523e5c0e242c89d50d (patch) | |
| tree | de016fde47c2acca9b353c84ba5dfb4e31c7744a | |
| parent | c870bb796bbbc424fdd369c8237b08b706215d03 (diff) | |
| download | gitlab-ce-1ede975cde6d32a74b2d4d523e5c0e242c89d50d.tar.gz | |
Styleguide the commit status API
[ci skip]
| -rw-r--r-- | doc/api/commits.md | 202 | 
1 files changed, 127 insertions, 75 deletions
| diff --git a/doc/api/commits.md b/doc/api/commits.md index a07c9dff54e..4008629e0a2 100644 --- a/doc/api/commits.md +++ b/doc/api/commits.md @@ -158,8 +158,21 @@ Example response:  ## Post comment to commit -Adds a comment to a commit. Optionally you can post comments on a specific line -of a commit. In that case `path`, `line` and `line_type` are required. +Adds a comment to a commit. + +In order to post a comment in a particular line of a particular file, you must +specify the full commit SHA, the `path`, the `line` and `line_type` should be +`new`. + +The comment will be added at the end of the last commit if at least one of the +cases below is valid: + +- the `sha` is instead a branch or a tag and the `line` or `path` are invalid +- the `line` number is invalid (does not exist) +- the `path` is invalid (does not exist) + +In any of the above cases, the response of `line`, `line_type` and `path` is +set to `null`.  ```  POST /projects/:id/repository/commits/:sha/comments @@ -168,35 +181,33 @@ POST /projects/:id/repository/commits/:sha/comments  | Attribute | Type | Required | Description |  | --------- | ---- | -------- | ----------- |  | `id`        | integer | yes | The ID of a project | -| `sha`       | string  | yes | The commit hash or name of a repository branch or tag | -| `note`      | string  | yes | Text of comment | +| `sha`       | string  | yes | The commit SHA or name of a repository branch or tag | +| `note`      | string  | yes | The text of the comment |  | `path`      | string  | no  | The file path relative to the repository | -| `line`      | integer | no  | The line number | +| `line`      | integer | no  | The line number where the comment should be placed |  | `line_type` | string  | no  | The line type. Takes `new` or `old` as arguments | -In order to post a comment in a particular line of a particular file, you must -specify `path`, `line` and `line_type` should be `new`. -  ```bash -curl -X POST -H "PRIVATE-TOKEN: 9koXpg98eAheJpvBs5tK" "https://gitlab.example.com/api/v3/projects/5/repository/commits/master/comments?note=New%20comment&path=CHANGELOG&line=664&line_type=new" +curl -X POST -H "PRIVATE-TOKEN: 9koXpg98eAheJpvBs5tK" -F "note=Nice picture man\!" -F "path=dudeism.md" -F "line=11" -F "line_type=new" https://gitlab.example.com/api/v3/projects/17/repository/commits/18f3e63d05582537db6d183d9d557be09e1f90c8/comments  ```  Example response:  ```json  { -  "author": { -    "id": 1, -    "username": "admin", -    "email": "admin@local.host", -    "name": "Administrator", -    "blocked": false, -    "created_at": "2012-04-29T08:46:00Z" -  }, -  "note": "text1", -  "path": "example.rb", -  "line": 5, -  "line_type": "new" +   "author" : { +      "web_url" : "https://gitlab.example.com/u/thedude", +      "avatar_url" : "https://gitlab.example.com/uploads/user/avatar/28/The-Big-Lebowski-400-400.png", +      "username" : "thedude", +      "state" : "active", +      "name" : "Jeff Lebowski", +      "id" : 28 +   }, +   "created_at" : "2016-01-19T09:44:55.600Z", +   "line_type" : "new", +   "path" : "dudeism.md", +   "line" : 11, +   "note" : "Nice picture man!"  }  ``` @@ -208,75 +219,116 @@ Get the statuses of a commit in a project.  GET /projects/:id/repository/commits/:sha/statuses  ``` -Parameters: +| Attribute | Type | Required | Description | +| --------- | ---- | -------- | ----------- | +| `id`      | integer | yes | The ID of a project +| `sha`     | string  | yes | The commit SHA +| `ref_name`| string  | no  | The name of a repository branch or tag or, if not given, the default branch +| `stage`   | string  | no  | Filter by [build stage](../ci/yaml/README.md#stages), e.g., `test` +| `name`    | string  | no  | Filter by [job name](../ci/yaml/README.md#jobs), e.g., `bundler:audit` +| `all`     | boolean | no  | Return all statuses, not only the latest ones -- `id` (required) - The ID of a project -- `sha` (required) - The commit SHA -- `ref` (optional) - Filter by ref name, it can be branch or tag -- `stage` (optional) - Filter by stage -- `name` (optional) - Filer by status name, eg. jenkins -- `all` (optional) - The flag to return all statuses, not only latest ones +```bash +curl -H "PRIVATE-TOKEN: 9koXpg98eAheJpvBs5tK" "https://gitlab.example.com/api/v3/projects/17/repository/commits/18f3e63d05582537db6d183d9d557be09e1f90c8/statuses +``` + +Example response:  ```json  [ -  { -    "id": 13, -    "sha": "b0b3a907f41409829b307a28b82fdbd552ee5a27", -    "ref": "test", -    "status": "success", -    "name": "ci/jenkins", -    "target_url": "http://jenkins/project/url", -    "description": "Jenkins success", -    "created_at": "2015-10-12T09:47:16.250Z", -    "started_at": "2015-10-12T09:47:16.250Z", -    "finished_at": "2015-10-12T09:47:16.262Z", -    "author": { -      "id": 1, -      "username": "admin", -      "email": "admin@local.host", -      "name": "Administrator", -      "blocked": false, -      "created_at": "2012-04-29T08:46:00Z" -    } -  } +   ... + +   { +      "status" : "pending", +      "created_at" : "2016-01-19T08:40:25.934Z", +      "started_at" : null, +      "name" : "bundler:audit", +      "allow_failure" : true, +      "author" : { +         "username" : "thedude", +         "state" : "active", +         "web_url" : "https://gitlab.example.com/u/thedude", +         "avatar_url" : "https://gitlab.example.com/uploads/user/avatar/28/The-Big-Lebowski-400-400.png", +         "id" : 28, +         "name" : "Jeff Lebowski" +      }, +      "description" : null, +      "sha" : "18f3e63d05582537db6d183d9d557be09e1f90c8", +      "target_url" : "https://gitlab.example.com/thedude/gitlab-ce/builds/91", +      "finished_at" : null, +      "id" : 91, +      "ref" : "master" +   }, +   { +      "started_at" : null, +      "name" : "flay", +      "allow_failure" : false, +      "status" : "pending", +      "created_at" : "2016-01-19T08:40:25.832Z", +      "target_url" : "https://gitlab.example.com/thedude/gitlab-ce/builds/90", +      "id" : 90, +      "finished_at" : null, +      "ref" : "master", +      "sha" : "18f3e63d05582537db6d183d9d557be09e1f90c8", +      "author" : { +         "id" : 28, +         "name" : "Jeff Lebowski", +         "username" : "thedude", +         "web_url" : "https://gitlab.example.com/u/thedude", +         "state" : "active", +         "avatar_url" : "https://gitlab.example.com/uploads/user/avatar/28/The-Big-Lebowski-400-400.png" +      }, +      "description" : null +   }, + +   ...  ]  ``` -## Post the status to commit +## Post the build status to a commit -Adds or updates a status of a commit. +Adds or updates a build status of a commit.  ```  POST /projects/:id/statuses/:sha  ``` -- `id` (required) - The ID of a project -- `sha` (required) - The commit SHA -- `state` (required) - The state of the status. Can be: pending, running, success, failed, canceled -- `ref` (optional) - The ref (branch or tag) to which the status refers -- `name` or `context` (optional) - The label to differentiate this status from the status of other systems. Default: "default" -- `target_url` (optional) - The target URL to associate with this status -- `description` (optional) - The short description of the status +| Attribute | Type | Required | Description | +| --------- | ---- | -------- | ----------- | +| `id`      | integer | yes   | The ID of a project +| `sha`     | string  | yes   | The commit SHA +| `state`   | string  | yes   | The state of the status. Can be one of the following: `pending`, `running`, `success`, `failed`, `canceled` +| `ref`     | string  | no    | The `ref` (branch or tag) to which the status refers +| `name` or `context` | string  | no | The label to differentiate this status from the status of other systems. Default value is `default` +| `target_url` |  string  | no  | The target URL to associate with this status +| `description` | string  | no  | The short description of the status + +```bash +curl -X POST -H "PRIVATE-TOKEN: 9koXpg98eAheJpvBs5tK" "https://gitlab.example.com/api/v3/projects/17/statuses/18f3e63d05582537db6d183d9d557be09e1f90c8?state=success" +``` + +Example response:  ```json  { -  "id": 13, -  "sha": "b0b3a907f41409829b307a28b82fdbd552ee5a27", -  "ref": "test", -  "status": "success", -  "name": "ci/jenkins", -  "target_url": "http://jenkins/project/url", -  "description": "Jenkins success", -  "created_at": "2015-10-12T09:47:16.250Z", -  "started_at": "2015-10-12T09:47:16.250Z", -  "finished_at": "2015-10-12T09:47:16.262Z", -  "author": { -    "id": 1, -    "username": "admin", -    "email": "admin@local.host", -    "name": "Administrator", -    "blocked": false, -    "created_at": "2012-04-29T08:46:00Z" -  } +   "author" : { +      "web_url" : "https://gitlab.example.com/u/thedude", +      "name" : "Jeff Lebowski", +      "avatar_url" : "https://gitlab.example.com/uploads/user/avatar/28/The-Big-Lebowski-400-400.png", +      "username" : "thedude", +      "state" : "active", +      "id" : 28 +   }, +   "name" : "default", +   "sha" : "18f3e63d05582537db6d183d9d557be09e1f90c8", +   "status" : "success", +   "description" : null, +   "id" : 93, +   "target_url" : null, +   "ref" : null, +   "started_at" : null, +   "created_at" : "2016-01-19T09:05:50.355Z", +   "allow_failure" : false, +   "finished_at" : "2016-01-19T09:05:50.365Z"  }  ``` | 
