Skip to main content

GitHub 이벤트 유형

GitHub 이벤트 API의 경우 각 이벤트 유형, GitHub에 대한 트리거 작업, 각 이벤트의 고유 속성에 대해 알아봅니다.

이벤트 API는 GitHub에서 활동에 의해 트리거되는 다양한 유형의 이벤트를 반환할 수 있습니다. 각 이벤트 응답에는 공유 속성이 포함되어 있지만 해당 이벤트 유형에 따라 결정되는 고유한 payload 개체가 있습니다. Event 개체 공통 속성은 모든 이벤트에서 공유하는 속성을 설명하고 각 이벤트 유형은 특정 이벤트에 고유한 payload 속성을 설명합니다.

이벤트 개체 공통 속성

이벤트 API 엔드포인트에서 반환된 이벤트 개체의 구조는 동일합니다.

이벤트 API 특성 이름Type설명
idinteger이벤트에 대한 고유 식별자입니다.
typestring이벤트의 유형입니다. 이벤트는 이름에 PascalCase를 사용합니다.
actorobject이벤트를 트리거한 사용자입니다.
actor.idinteger작업자의 고유 식별자입니다.
actor.loginstring작업자의 사용자 이름입니다.
actor.display_loginstring사용자 이름의 특정 표시 형식입니다.
actor.gravatar_idstring작업자에 대한 Gravatar 프로필의 고유 식별자입니다.
actor.urlstring추가 사용자 정보를 포함하는 사용자 개체를 검색하는 데 사용되는 REST API URL입니다.
actor.avatar_urlstring작업자 프로필 이미지의 URL입니다.
repoobject이벤트가 발생한 리포지토리 개체입니다.
repo.idinteger리포지토리의 고유 식별자입니다.
repo.namestring리포지토리의 이름으로, 여기에는 소유자 및 리포지토리 이름이 포함되어 있습니다. 예를 들어 octocat/hello-worldoctocat 개인 계정이 소유한 hello-world 리포지토리의 이름입니다.
repo.urlstring추가 리포지토리 정보가 포함된 리포지토리 개체를 검색하는 데 사용되는 REST API URL입니다.
payloadobject이벤트 페이로드 개체는 이벤트 유형에 고유합니다. 이벤트 API payload 개체는 아래 이벤트 유형을 참조하세요.
publicboolean이벤트가 모든 사용자에게 표시되는지 여부입니다.
created_atstring이벤트가 트리거된 날짜 및 시간입니다. ISO 8601에 따라 형식이 지정됩니다.
orgobject이벤트를 트리거하는 작업을 수행하기 위해 행위자가 선택한 조직입니다.
속성은 해당되는 경우에만 이벤트 개체에 나타납니다.
org.idinteger조직의 고유 식별자입니다.
org.loginstring조직의 이름입니다.
org.gravatar_idstring조직에 대한 Gravatar 프로필의 고유 식별자입니다.
org.urlstring추가 조직 정보가 포함된 조직 개체를 검색하는 데 사용되는 REST API URL입니다.
org.avatar_urlstring조직 프로필 이미지의 URL입니다.

WatchEvent 이벤트 개체 예제

이 예제에서는 이벤트 API를 사용할 때 WatchEvent 응답의 형식을 보여 줍니다.

HTTP/2 200
Link: <https://api.github.com/resource?page=2>; rel="next",
      <https://api.github.com/resource?page=5>; rel="last"
[
  {
    "type": "WatchEvent",
    "public": false,
    "payload": {
    },
    "repo": {
      "id": 3,
      "name": "octocat/Hello-World",
      "url": "https://api.github.com/repos/octocat/Hello-World"
    },
    "actor": {
      "id": 1,
      "login": "octocat",
      "gravatar_id": "",
      "avatar_url": "https://github.com/images/error/octocat_happy.gif",
      "url": "https://api.github.com/users/octocat"
    },
    "org": {
      "id": 1,
      "login": "github",
      "gravatar_id": "",
      "url": "https://api.github.com/orgs/github",
      "avatar_url": "https://github.com/images/error/octocat_happy.gif"
    },
    "created_at": "2011-09-06T17:26:27Z",
    "id": "12345"
  }
]

CommitCommentEvent

커밋 주석이 생성되었습니다. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다. 자세한 내용은 커밋 주석에 대한 REST API 엔드포인트 항목을 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

CommitCommentEvent에 대한 이벤트 payload 개체

형식설명
actionstring수행된 작업입니다. created일 수 있습니다.
commentobject커밋 주석 리소스입니다.

CreateEvent

Git 분기 또는 태그가 생성되었습니다. 자세한 내용은 Git 데이터베이스에 대한 REST API 엔드포인트을(를) 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

CreateEvent에 대한 이벤트 payload 개체

형식설명
refstringgit ref 리소스입니다. ref_typerepository인 경우 null입니다.
ref_typestring리포지토리에서 만든 Git ref 개체의 형식입니다. branch, tag 또는 repository일 수 있습니다.
master_branchstring리포지토리의 기본 분기 이름(일반적으로 main)입니다.
descriptionstring리포지토리의 현재 설명입니다.
pusher_typestringuser 또는 배포 키일 수도 있습니다.

DeleteEvent

Git 분기 또는 태그가 삭제되었습니다. 자세한 내용은 Git 데이터베이스에 대한 REST API 엔드포인트 REST API를 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

DeleteEvent에 대한 이벤트 payload 개체

형식설명
refstringgit ref 리소스입니다.
ref_typestring리포지토리에서 삭제된 Git ref 개체의 형식입니다. branch 또는 tag 중 하나일 수 있습니다.

ForkEvent

사용자가 리포지토리를 포크합니다. 자세한 내용은 리포지토리에 대한 REST API 엔드포인트을(를) 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

ForkEvent에 대한 이벤트 payload 개체

형식설명
forkeeobject만든 repository 리소스입니다.

GollumEvent

Wiki 페이지가 생성되었거나 업데이트되었습니다. 자세한 내용은 위키 정보을(를) 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

GollumEvent에 대한 이벤트 payload 개체

형식설명
pagesarray업데이트된 페이지입니다.
pages[][page_name]string페이지의 이름입니다.
pages[][title]string현재 페이지 제목입니다.
pages[][action]string페이지에서 수행된 작업입니다. created 또는 edited일 수 있습니다.
pages[][sha]string페이지의 최신 커밋 SHA입니다.
pages[][html_url]stringHTML Wiki 페이지를 가리킵니다.

IssueCommentEvent

문제 또는 끌어오기 요청 설명과 관련된 활동입니다. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다. 자세한 내용은 이슈에 대한 REST API 엔드포인트. 항목을 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

IssueCommentEvent에 대한 이벤트 payload 개체

형식설명
actionstring설명에 대해 수행된 작업입니다. created, edited 또는 deleted 중 하나일 수 있습니다.
changesobject작업이 edited인 경우 주석에 대한 변경 내용입니다.
changes[body][from]string작업이 edited인 경우 본문의 이전 버전입니다.
issueobject주석이 속한 문제입니다.
commentobject설명 자체입니다.

IssuesEvent

이슈와 관련된 작업입니다. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다. 자세한 내용은 이슈에 대한 REST API 엔드포인트. 항목을 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

IssuesEvent에 대한 이벤트 payload 개체

형식설명
actionstring수행된 작업입니다. opened, edited, closed, reopened, assigned, unassigned, labeled 또는 unlabeled 중 하나일 수 있습니다.
issueobject이슈 자체입니다.
changesobject작업이 edited인 경우 이슈에 대한 변경 사항입니다.
changes[title][from]string작업이 edited인 경우 제목의 이전 버전입니다.
changes[body][from]string작업이 edited인 경우 본문의 이전 버전입니다.
assigneeobject문제에서 할당되거나 할당되지 않은 선택적 사용자입니다.
labelobject이슈에서 추가 또는 제거된 선택적 레이블입니다.

MemberEvent

리포지토리 협력자 관련 작업입니다. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다. 자세한 내용은 협업자에 대한 REST API 엔드포인트 항목을 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

MemberEvent에 대한 이벤트 payload 개체

형식설명
actionstring수행된 작업입니다. 사용자가 리포지토리 초대를 수락했음을 나타내기 위해 added일 수 있습니다.
memberobject추가된 사용자입니다.
changesobject작업이 edited인 경우 협력자 권한에 대한 변경 사항입니다.
changes[old_permission][from]string작업이 edited인 경우 협력자의 이전 사용 권한입니다.

PublicEvent

프라이빗 리포지토리가 공개되는 경우. 의심의 여지없이 최고의 GitHub Enterprise Server 이벤트입니다.

PublicEvent에 대한 이벤트 payload 개체

이 이벤트는 빈 payload 개체를 반환합니다.

PullRequestEvent

끌어오기 요청과 관련된 작업입니다. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다. 자세한 내용은 끌어오기 요청에 대한 REST API 엔드포인트 항목을 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

PullRequestEvent에 대한 이벤트 payload 개체

형식설명
actionstring수행된 작업입니다. opened, edited, closed, reopened, assigned, unassigned, review_requested, review_request_removed, labeled, unlabeled, synchronize 중 하나일 수 있습니다.
numberinteger끌어오기 요청 번호입니다.
changesobject작업이 edited인 경우 커밋에 대한 변경 내용입니다.
changes[title][from]string작업이 edited인 경우 제목의 이전 버전입니다.
changes[body][from]string작업이 edited인 경우 본문의 이전 버전입니다.
pull_requestobject끌어오기 요청 자체입니다.

PullRequestReviewEvent

끌어오기 요청 검토와 관련된 활동입니다. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다. 자세한 내용은 끌어오기 요청에 대한 REST API 엔드포인트 항목을 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

PullRequestReviewEvent에 대한 이벤트 payload 개체

형식설명
actionstring수행된 작업입니다. created일 수 있습니다.
pull_requestobject검토와 관련된 끌어오기 요청입니다.
reviewobject영향을 받은 검토입니다.

PullRequestReviewCommentEvent

끌어오기 요청의 통합 차이에서 끌어오기 요청 검토 설명과 관련된 활동입니다. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다. 자세한 내용은 끌어오기 요청에 대한 REST API 엔드포인트 항목을 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

PullRequestReviewCommentEvent에 대한 이벤트 payload 개체

형식설명
actionstring설명에 대해 수행된 작업입니다. created일 수 있습니다.
changesobject작업이 edited인 경우 커밋에 대한 변경 내용입니다.
changes[body][from]string작업이 edited인 경우 본문의 이전 버전입니다.
pull_requestobject커밋이 속한 끌어오기 요청입니다.
commentobject설명 자체입니다.

PullRequestReviewThreadEvent

끌어오기 요청이 해결됨 또는 해결되지 않음으로 표시되는 주석 스레드와 관련된 작업입니다. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

PullRequestReviewThreadEvent에 대한 이벤트 payload 개체

형식설명
actionstring수행된 작업입니다. 다음 중 하나일 수 있습니다.
  • resolved - 끌어오기 요청의 주석 스레드가 확인된 것으로 표시되었습니다.
  • unresolved - 끌어오기 요청의 이전에 확인된 주석 스레드가 확인되지 않은 것으로 표시되었습니다.
pull_requestobject스레드와 관련된 끌어오기 요청입니다.
threadobject영향을 받은 스레드입니다.

PushEvent

하나 이상의 커밋이 리포지토리 분기 또는 태그로 푸시됩니다.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

PushEvent에 대한 이벤트 payload 개체

형식설명
push_idinteger푸시의 고유 식별자입니다.
sizeinteger푸시의 커밋 수입니다.
distinct_sizeinteger푸시의 고유 커밋 수입니다.
refstring푸시된 전체 git ref입니다. 예: refs/heads/main
headstring푸시 후 ref에 대한 가장 최근 커밋의 SHA입니다.
beforestring푸시 전 ref에 대한 가장 최근 커밋의 SHA입니다.
commitsarray푸시된 커밋을 설명하는 커밋 개체의 배열. (배열에는 최대 20개의 커밋이 포함됩니다. 필요한 경우 커밋 API를 사용하여 추가 커밋을 가져올 수 있습니다. 이 제한은 타임라인 이벤트에만 적용되며 웹후크 배달에는 적용되지 않습니다.)
commits[][sha]string커밋의 SHA입니다.
commits[][message]string커밋 메시지.
commits[][author]object커밋의 git 작성자.
commits[][author][name]stringgit 작성자의 이름.
commits[][author][email]stringgit 작성자의 메일 주소입니다.
commits[][url]url커밋 API 리소스를 가리키는 URL.
commits[][distinct]boolean이 커밋이 이전에 푸시된 커밋과 구별되는지 여부.

ReleaseEvent

릴리스와 관련된 작업입니다. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다. 자세한 내용은 릴리스 및 릴리스 자산에 대한 REST API 엔드포인트 REST API를 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

ReleaseEvent에 대한 이벤트 payload 개체

형식설명
actionstring수행된 작업입니다. published일 수 있습니다.
changes[body][from]string작업이 edited인 경우 본문의 이전 버전입니다.
changes[name][from]string작업이 edited인 경우 이름의 이전 버전입니다.
releaseobject릴리스 개체입니다.

WatchEvent

누군가가 리포지토리에 별표를 지정할 때. 활동 유형은 페이로드 개체의 action 속성에서 지정됩니다. 자세한 내용은 활동에 대한 REST API 엔드포인트 항목을 참조하세요.

이벤트 개체에는 모든 이벤트에 공통적인 속성이 포함됩니다. 각 이벤트 개체에는 payload 속성이 포함되며 값은 각 이벤트 유형에 고유합니다. 이 이벤트의 payload 개체는 아래에 설명되어 있습니다.

WatchEvent에 대한 이벤트 payload 개체

형식설명
actionstring수행된 작업입니다. 현재는 started만 될 수 있습니다.