gitlab-org--gitlab-foss/doc/api/merge_requests.md

254 lines
4.8 KiB
Markdown
Raw Normal View History

2012-10-22 19:53:06 +00:00
## List merge requests
Get all merge requests for this project. This function takes pagination parameters
`page` and `per_page` to restrict the list of merge requests.
2012-10-22 19:53:06 +00:00
```
2012-10-25 10:13:01 +00:00
GET /projects/:id/merge_requests
2012-10-22 19:53:06 +00:00
```
Parameters:
+ `id` (required) - The ID of a project
2012-10-22 19:53:06 +00:00
```json
[
2014-04-05 06:36:47 +00:00
{
"id": 1,
"iid": 1,
"target_branch": "master",
"source_branch": "test1",
"project_id": 3,
"title": "test1",
"state": "opened",
"upvotes": 0,
"downvotes": 0,
"author": {
"id": 1,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2012-04-29T08:46:00Z"
},
"assignee": {
"id": 1,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2012-04-29T08:46:00Z"
2012-10-22 19:53:06 +00:00
}
2014-04-05 06:36:47 +00:00
}
2012-10-22 19:53:06 +00:00
]
```
## Get single MR
Shows information about a single merge request.
2012-10-22 19:53:06 +00:00
```
2012-10-25 10:13:01 +00:00
GET /projects/:id/merge_request/:merge_request_id
2012-10-22 19:53:06 +00:00
```
Parameters:
+ `id` (required) - The ID of a project
2012-10-22 19:53:06 +00:00
+ `merge_request_id` (required) - The ID of MR
```json
{
2014-04-05 06:36:47 +00:00
"id": 1,
"iid": 1,
"target_branch": "master",
"source_branch": "test1",
"project_id": 3,
"title": "test1",
"state": "merged",
"upvotes": 0,
"downvotes": 0,
"author": {
"id": 1,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2012-04-29T08:46:00Z"
},
"assignee": {
"id": 1,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2012-04-29T08:46:00Z"
}
2012-10-22 19:53:06 +00:00
}
```
## Create MR
Creates a new merge request.
2012-10-22 19:53:06 +00:00
```
2012-10-25 10:13:01 +00:00
POST /projects/:id/merge_requests
2012-10-22 19:53:06 +00:00
```
Parameters:
+ `id` (required) - The ID of a project
2012-10-22 19:53:06 +00:00
+ `source_branch` (required) - The source branch
+ `target_branch` (required) - The target branch
+ `assignee_id` (optional) - Assignee user ID
2012-10-22 19:53:06 +00:00
+ `title` (required) - Title of MR
```json
{
2014-04-05 06:36:47 +00:00
"id": 1,
"target_branch": "master",
"source_branch": "test1",
"project_id": 3,
"title": "test1",
"state": "opened",
"upvotes": 0,
"downvotes": 0,
"author": {
"id": 1,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2012-04-29T08:46:00Z"
},
"assignee": {
"id": 1,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2012-04-29T08:46:00Z"
}
2012-10-22 19:53:06 +00:00
}
```
2012-10-22 19:53:06 +00:00
## Update MR
Updates an existing merge request. You can change branches, title, or even close the MR.
2012-10-22 19:53:06 +00:00
```
2012-10-25 10:13:01 +00:00
PUT /projects/:id/merge_request/:merge_request_id
2012-10-22 19:53:06 +00:00
```
Parameters:
+ `id` (required) - The ID of a project
2012-10-22 19:53:06 +00:00
+ `merge_request_id` (required) - ID of MR
+ `source_branch` - The source branch
+ `target_branch` - The target branch
+ `assignee_id` - Assignee user ID
+ `title` - Title of MR
+ `state_event` - New state (close|reopen|merge)
2012-10-22 19:53:06 +00:00
```json
{
2014-04-05 06:36:47 +00:00
"id": 1,
"target_branch": "master",
"source_branch": "test1",
"project_id": 3,
"title": "test1",
"state": "opened",
"upvotes": 0,
"downvotes": 0,
"author": {
"id": 1,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2012-04-29T08:46:00Z"
},
"assignee": {
"id": 1,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2012-04-29T08:46:00Z"
}
2012-10-22 19:53:06 +00:00
}
```
2012-10-22 19:53:06 +00:00
## Post comment to MR
Adds a comment to a merge request.
2012-10-22 19:53:06 +00:00
```
2012-10-25 10:13:01 +00:00
POST /projects/:id/merge_request/:merge_request_id/comments
2012-10-22 19:53:06 +00:00
```
Parameters:
+ `id` (required) - The ID of a project
+ `merge_request_id` (required) - ID of merge request
2012-10-22 19:53:06 +00:00
+ `note` (required) - Text of comment
```json
{
2014-04-05 06:36:47 +00:00
"author": {
"id": 1,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"blocked": false,
"created_at": "2012-04-29T08:46:00Z"
},
"note": "text1"
2012-10-22 19:53:06 +00:00
}
```
## Get the comments on a MR
Gets all the comments associated with a merge request.
```
GET /projects/:id/merge_request/:merge_request_id/comments
```
Parameters:
+ `id` (required) - The ID of a project
+ `merge_request_id` (required) - ID of merge request
```json
[
2014-04-05 06:36:47 +00:00
{
"note": "this is the 1st comment on the 2merge merge request",
"author": {
"id": 11,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2014-03-06T08:17:35.000Z"
}
},
{
"note": "_Status changed to closed_",
"author": {
"id": 11,
"username": "admin",
"email": "admin@local.host",
"name": "Administrator",
"state": "active",
"created_at": "2014-03-06T08:17:35.000Z"
}
2014-04-05 06:36:47 +00:00
}
]
```