이슈 링크 API
Tier: Free, Premium, Ultimate
Offering: GitLab.com, Self-managed, GitLab Dedicated
- 간단한 “관련” 관계가 이동되었습니다 13.4 버전의 GitLab Free로.
이슈 관계 목록
주어진 이슈의 링크된 이슈 목록을 가져오고,
관계 생성 날짜 시간(오름차순)으로 정렬합니다.
이슈는 사용자 권한에 따라 필터링됩니다.
GET /projects/:id/issues/:issue_iid/links
매개변수:
속성 | 유형 | 필수 | 설명 |
---|---|---|---|
id |
정수/문자열 | 예 | 프로젝트의 ID 또는 URL 인코딩된 경로 |
issue_iid |
정수 | 예 | 프로젝트 이슈의 내부 ID |
[
{
"id" : 84,
"iid" : 14,
"issue_link_id": 1,
"project_id" : 4,
"created_at" : "2016-01-07T12:44:33.959Z",
"title" : "인증 문제",
"state" : "열림",
"assignees" : [],
"assignee" : null,
"labels" : [
"버그"
],
"author" : {
"name" : "알렉산드라 바시리안",
"avatar_url" : null,
"state" : "활성",
"web_url" : "https://gitlab.example.com/eileen.lowe",
"id" : 18,
"username" : "eileen.lowe"
},
"description" : null,
"updated_at" : "2016-01-07T12:44:33.959Z",
"milestone" : null,
"user_notes_count": 0,
"due_date": null,
"web_url": "http://example.com/example/example/issues/14",
"confidential": false,
"weight": null,
"link_type": "relates_to",
"link_created_at": "2016-01-07T12:44:33.959Z",
"link_updated_at": "2016-01-07T12:44:33.959Z"
}
]
이슈 링크 가져오기
- 도입됨 GitLab 15.1에서.
이슈 링크의 세부 정보를 가져옵니다.
GET /projects/:id/issues/:issue_iid/links/:issue_link_id
지원되는 속성:
속성 | 유형 | 필수 | 설명 |
---|---|---|---|
id |
정수/문자열 | 예 | 프로젝트의 ID 또는 URL 인코딩된 경로. |
issue_iid |
정수 | 예 | 프로젝트 이슈의 내부 ID. |
issue_link_id |
정수/문자열 | 예 | 이슈 관계의 ID. |
응답 본문 속성:
속성 | 유형 | 설명 |
---|---|---|
source_issue |
객체 | 관계의 출처 이슈에 대한 세부 정보. |
target_issue |
객체 | 관계의 대상 이슈에 대한 세부 정보. |
link_type |
문자열 | 관계의 유형. 가능한 값은 relates_to , blocks 및 is_blocked_by 입니다. |
예시 요청:
curl --request GET --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/projects/84/issues/14/links/1"
예시 응답:
{
"source_issue" : {
"id" : 83,
"iid" : 11,
"project_id" : 4,
"created_at" : "2016-01-07T12:44:33.959Z",
"title" : "인증 문제",
"state" : "열림",
"assignees" : [],
"assignee" : null,
"labels" : [
"버그"
],
"author" : {
"name" : "알렉산드라 바시리안",
"avatar_url" : null,
"state" : "활성",
"web_url" : "https://gitlab.example.com/eileen.lowe",
"id" : 18,
"username" : "eileen.lowe"
},
"description" : null,
"updated_at" : "2016-01-07T12:44:33.959Z",
"milestone" : null,
"subscribed" : true,
"user_notes_count": 0,
"due_date": null,
"web_url": "http://example.com/example/example/issues/11",
"confidential": false,
"weight": null
},
"target_issue" : {
"id" : 84,
"iid" : 14,
"project_id" : 4,
"created_at" : "2016-01-07T12:44:33.959Z",
"title" : "인증 문제",
"state" : "열림",
"assignees" : [],
"assignee" : null,
"labels" : [
"버그"
],
"author" : {
"name" : "알렉산드라 바시리안",
"avatar_url" : null,
"state" : "활성",
"web_url" : "https://gitlab.example.com/eileen.lowe",
"id" : 18,
"username" : "eileen.lowe"
},
"description" : null,
"updated_at" : "2016-01-07T12:44:33.959Z",
"milestone" : null,
"subscribed" : true,
"user_notes_count": 0,
"due_date": null,
"web_url": "http://example.com/example/example/issues/14",
"confidential": false,
"weight": null
},
"link_type": "relates_to"
}
이슈 링크 생성
이슈 간의 양방향 관계를 생성합니다. 사용자는 성공하려면 두 이슈 모두를 업데이트할 수 있어야 합니다.
POST /projects/:id/issues/:issue_iid/links
속성 | 유형 | 필수 | 설명 |
---|---|---|---|
id |
integer/string | 예 | 프로젝트의 ID 또는 URL 인코딩 경로 |
issue_iid |
integer | 예 | 프로젝트 이슈의 내부 ID |
target_project_id |
integer/string | 예 | 목표 프로젝트의 ID 또는 URL 인코딩 경로 |
target_issue_iid |
integer/string | 예 | 목표 프로젝트 이슈의 내부 ID |
link_type |
string | 아니오 | 관계의 유형 (relates_to , blocks , is_blocked_by ), 기본값은 relates_to 입니다. |
curl --request POST --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/projects/4/issues/1/links?target_project_id=5&target_issue_iid=1"
예시 응답:
{
"source_issue" : {
"id" : 83,
"iid" : 11,
"project_id" : 4,
"created_at" : "2016-01-07T12:44:33.959Z",
"title" : "인증 관련 이슈",
"state" : "opened",
"assignees" : [],
"assignee" : null,
"labels" : [
"버그"
],
"author" : {
"name" : "Alexandra Bashirian",
"avatar_url" : null,
"state" : "active",
"web_url" : "https://gitlab.example.com/eileen.lowe",
"id" : 18,
"username" : "eileen.lowe"
},
"description" : null,
"updated_at" : "2016-01-07T12:44:33.959Z",
"milestone" : null,
"subscribed" : true,
"user_notes_count": 0,
"due_date": null,
"web_url": "http://example.com/example/example/issues/11",
"confidential": false,
"weight": null
},
"target_issue" : {
"id" : 84,
"iid" : 14,
"project_id" : 4,
"created_at" : "2016-01-07T12:44:33.959Z",
"title" : "인증 관련 이슈",
"state" : "opened",
"assignees" : [],
"assignee" : null,
"labels" : [
"버그"
],
"author" : {
"name" : "Alexandra Bashirian",
"avatar_url" : null,
"state" : "active",
"web_url" : "https://gitlab.example.com/eileen.lowe",
"id" : 18,
"username" : "eileen.lowe"
},
"description" : null,
"updated_at" : "2016-01-07T12:44:33.959Z",
"milestone" : null,
"subscribed" : true,
"user_notes_count": 0,
"due_date": null,
"web_url": "http://example.com/example/example/issues/14",
"confidential": false,
"weight": null
},
"link_type": "relates_to"
}
이슈 링크 삭제
이슈 링크를 삭제하면 양방향 관계가 제거됩니다.
DELETE /projects/:id/issues/:issue_iid/links/:issue_link_id
속성 | 유형 | 필수 | 설명 |
---|---|---|---|
id |
정수/문자열 | 예 | 프로젝트의 ID 또는 URL 인코딩된 경로 |
issue_iid |
정수 | 예 | 프로젝트 이슈의 내부 ID |
issue_link_id |
정수/문자열 | 예 | 이슈 관계의 ID |
link_type |
문자열 | 아니오 | 관계의 유형(relates_to , blocks , is_blocked_by ), 기본값은 relates_to
|
{
"source_issue" : {
"id" : 83,
"iid" : 11,
"project_id" : 4,
"created_at" : "2016-01-07T12:44:33.959Z",
"title" : "인증 관련 이슈",
"state" : "opened",
"assignees" : [],
"assignee" : null,
"labels" : [
"버그"
],
"author" : {
"name" : "알렉산드라 바시리안",
"avatar_url" : null,
"state" : "active",
"web_url" : "https://gitlab.example.com/eileen.lowe",
"id" : 18,
"username" : "eileen.lowe"
},
"description" : null,
"updated_at" : "2016-01-07T12:44:33.959Z",
"milestone" : null,
"subscribed" : true,
"user_notes_count": 0,
"due_date": null,
"web_url": "http://example.com/example/example/issues/11",
"confidential": false,
"weight": null
},
"target_issue" : {
"id" : 84,
"iid" : 14,
"project_id" : 4,
"created_at" : "2016-01-07T12:44:33.959Z",
"title" : "인증 관련 이슈",
"state" : "opened",
"assignees" : [],
"assignee" : null,
"labels" : [
"버그"
],
"author" : {
"name" : "알렉산드라 바시리안",
"avatar_url" : null,
"state" : "active",
"web_url" : "https://gitlab.example.com/eileen.lowe",
"id" : 18,
"username" : "eileen.lowe"
},
"description" : null,
"updated_at" : "2016-01-07T12:44:33.959Z",
"milestone" : null,
"subscribed" : true,
"user_notes_count": 0,
"due_date": null,
"web_url": "http://example.com/example/example/issues/14",
"confidential": false,
"weight": null
},
"link_type": "relates_to"
}