diff options
| author | Marc Siegfriedt <marc@techaccelerator.com> | 2016-08-29 23:58:32 +0000 | 
|---|---|---|
| committer | Marc Siegfriedt <marc@techaccelerator.com> | 2016-10-05 17:42:52 +0000 | 
| commit | a1ee8cf5ad07256807f15590bdb5f56152d55553 (patch) | |
| tree | 9f90bc8f0d3c5d65e9b8778bc9d80e4ecd8855dd /doc/api/commits.md | |
| parent | 4bc27cd17b304abce01fad1fce56fce32a4ee099 (diff) | |
| download | gitlab-ce-a1ee8cf5ad07256807f15590bdb5f56152d55553.tar.gz | |
multi-file commit
add docs and tests - add additional validation
allow move without content
updated response
Diffstat (limited to 'doc/api/commits.md')
| -rw-r--r-- | doc/api/commits.md | 87 | 
1 files changed, 87 insertions, 0 deletions
| diff --git a/doc/api/commits.md b/doc/api/commits.md index 682151d4b1d..3e20beefb8a 100644 --- a/doc/api/commits.md +++ b/doc/api/commits.md @@ -46,6 +46,91 @@ Example response:  ]  ``` +## Create a commit with multiple files and actions + +> [Introduced][ce-6096] in GitLab 8.13. + +Create a commit by posting a JSON payload + +``` +POST /projects/:id/repository/commits +``` + +| Attribute | Type | Required | Description | +| --------- | ---- | -------- | ----------- | +| `id` | integer/string | yes | The ID of a project or NAMESPACE/PROJECT_NAME | +| `branch_name` | string | yes | The name of a branch | +| `commit_message` | string | yes | Commit message | +| `actions[]` | array | yes | An array of action hashes to commit as a batch. See the next table for what attributes it can take. | +| `author_email` | string | no | Specify the commit author's email address | +| `author_name` | string | no | Specify the commit author's name | + + +| `actions[]` Attribute | Type | Required | Description | +| --------------------- | ---- | -------- | ----------- | +| `action` | string | yes | The action to perform, `create`, `delete`, `move`, `update` | +| `file_path` | string | yes | Full path to the file. Ex. `lib/class.rb` | +| `previous_path` | string | no | Original full path to the file being moved. Ex. `lib/class1.rb` | +| `content` | string | no | File content, required for all except `delete`. Optional for `move` | +| `encoding` | string | no | `text` or `base64`. `text` is default. | + +```bash +PAYLOAD=$(cat << 'JSON' +{ +  "branch_name": "master", +  "commit_message": "some commit message", +  "actions": [ +    { +      "action": "create", +      "file_path": "foo/bar", +      "content": "some content" +    }, +    { +      "action": "delete", +      "file_path": "foo/bar2", +    }, +    { +      "action": "move", +      "file_path": "foo/bar3", +      "previous_path": "foo/bar4", +      "content": "some content" +    }, +    { +      "action": "update", +      "file_path": "foo/bar5", +      "content": "new content" +    } +  ] +} +JSON +) +curl --request POST --header "PRIVATE-TOKEN: 9koXpg98eAheJpvBs5tK" --header "Content-Type: application/json" --data "$PAYLOAD" https://gitlab.example.com/api/v3/projects/1/repository/commits +``` + +Example response: +```json +{ +  "id": "ed899a2f4b50b4370feeea94676502b42383c746", +  "short_id": "ed899a2f4b5", +  "title": "some commit message", +  "author_name": "Dmitriy Zaporozhets", +  "author_email": "dzaporozhets@sphereconsultinginc.com", +  "created_at": "2016-09-20T09:26:24.000-07:00", +  "message": "some commit message", +  "parent_ids": [ +    "ae1d9fb46aa2b07ee9836d49862ec4e2c46fbbba" +  ], +  "committed_date": "2016-09-20T09:26:24.000-07:00", +  "authored_date": "2016-09-20T09:26:24.000-07:00", +  "stats": { +    "additions": 2, +    "deletions": 2, +    "total": 4 +  }, +  "status": null +} +``` +  ## Get a single commit  Get a specific commit identified by the commit hash or name of a branch or tag. @@ -343,3 +428,5 @@ Example response:     "finished_at" : "2016-01-19T09:05:50.365Z"  }  ``` + +[ce-6096]: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/6096 "Multi-file commit" | 
