사전 수신 환경에 대한 REST API 엔드포인트
REST API를 사용하면 사전 수신 후크에 대한 환경을 만들고, 나열하고, 업데이트하고, 삭제할 수 있습니다.
사전 수신 환경 정보보
이러한 엔드포인트는 인증된 사이트 관리자만 사용할 수 있습니다. 일반 사용자는 404 응답을 받게 됩니다.
참고 항목
이러한 엔드포인트는 personal access token (classic)을(를) 사용하는 인증만 지원합니다. 자세한 내용은 개인용 액세스 토큰 관리을(를) 참조하세요.
개체 특성
사전 수신 환경
| 속성 | 형식 | 설명 | 
|---|---|---|
name | string | UI에 표시되는 환경 이름입니다. | 
image_url | string | 다운로드하고 추출할 tarball의 URL입니다. | 
default_environment | boolean | GitHub와 함께 제공되는 기본 환경인지 여부입니다. | 
download | object | 이 환경의 다운로드 상태입니다. | 
hooks_count | integer | 이 환경을 사용하는 사전 수신 후크 수입니다. | 
사전 수신 환경 다운로드
| 속성 | 형식 | 설명 | 
|---|---|---|
state | string | 가장 최근 다운로드의 상태입니다. | 
downloaded_at | string | 가장 최근 다운로드가 시작된 시간입니다. | 
message | string | 오류 발생 시 생성된 오류 메시지입니다. | 
state의 가능한 값은 not_started, in_progress, success, failed입니다.
List pre-receive environments
"List pre-receive environments"에 대한 세분화된 액세스 토큰
이 엔드포인트는 GitHub 앱 사용자 액세스 토큰, GitHub 앱 설치 액세스 토큰 또는 세분화된 개인용 액세스 토큰에서 작동하지 않습니다.
"List pre-receive environments"에 대한 매개 변수
| 속성, 형식, 설명 | 
|---|
accept string Setting to   | 
| 속성, 형식, 설명 | 
|---|
per_page integer The number of results per page (max 100). For more information, see "Using pagination in the REST API." 기본값:   | 
page integer The page number of the results to fetch. For more information, see "Using pagination in the REST API." 기본값:   | 
direction string The direction to sort the results by. 기본값:  다음 중 하나일 수 있습니다.:   | 
sort string 기본값:  다음 중 하나일 수 있습니다.:   | 
"List pre-receive environments"에 대한 HTTP 응답 상태 코드
| 상태 코드 | 설명 | 
|---|---|
200 | OK  | 
"List pre-receive environments"에 대한 코드 샘플
요청 예제
curl -L \
  -H "Accept: application/vnd.github+json" \
  -H "Authorization: Bearer <YOUR-TOKEN>" \
  -H "X-GitHub-Api-Version: 2022-11-28" \
  http(s)://HOSTNAME/api/v3/admin/pre-receive-environmentsResponse
Status: 200[
  {
    "id": 1,
    "name": "Default",
    "image_url": "githubenterprise://internal",
    "url": "https://github.example.com/api/v3/admin/pre-receive-environments/1",
    "html_url": "https://github.example.com/admin/pre-receive-environments/1",
    "default_environment": true,
    "created_at": "2016-05-20T11:35:45-05:00",
    "hooks_count": 14,
    "download": {
      "url": "https://github.example.com/api/v3/admin/pre-receive-environments/1/downloads/latest",
      "state": "not_started",
      "downloaded_at": "2016-05-26T07:42:53-05:00",
      "message": null
    }
  },
  {
    "id": 2,
    "name": "DevTools Hook Env",
    "image_url": "https://my_file_server/path/to/devtools_env.tar.gz",
    "url": "https://github.example.com/api/v3/admin/pre-receive-environments/2",
    "html_url": "https://github.example.com/admin/pre-receive-environments/2",
    "default_environment": false,
    "created_at": "2016-05-20T11:35:45-05:00",
    "hooks_count": 1,
    "download": {
      "url": "https://github.example.com/api/v3/admin/pre-receive-environments/2/downloads/latest",
      "state": "success",
      "downloaded_at": "2016-05-26T07:42:53-05:00",
      "message": null
    }
  }
]Create a pre-receive environment
"Create a pre-receive environment"에 대한 세분화된 액세스 토큰
이 엔드포인트는 GitHub 앱 사용자 액세스 토큰, GitHub 앱 설치 액세스 토큰 또는 세분화된 개인용 액세스 토큰에서 작동하지 않습니다.
"Create a pre-receive environment"에 대한 매개 변수
| 속성, 형식, 설명 | 
|---|
accept string Setting to   | 
| 속성, 형식, 설명 | 
|---|
name string RequiredThe new pre-receive environment's name.  | 
image_url string RequiredURL from which to download a tarball of this environment.  | 
"Create a pre-receive environment"에 대한 HTTP 응답 상태 코드
| 상태 코드 | 설명 | 
|---|---|
201 | Created  | 
"Create a pre-receive environment"에 대한 코드 샘플
요청 예제
curl -L \
  -X POST \
  -H "Accept: application/vnd.github+json" \
  -H "Authorization: Bearer <YOUR-TOKEN>" \
  -H "X-GitHub-Api-Version: 2022-11-28" \
  http(s)://HOSTNAME/api/v3/admin/pre-receive-environments \
  -d '{"name":"DevTools Hook Env","image_url":"https://my_file_server/path/to/devtools_env.tar.gz"}'Response
Status: 201{
  "id": 2,
  "name": "DevTools Hook Env",
  "image_url": "https://my_file_server/path/to/devtools_env.tar.gz",
  "url": "https://github.example.com/api/v3/admin/pre-receive-environments/2",
  "html_url": "https://github.example.com/admin/pre-receive-environments/2",
  "default_environment": false,
  "created_at": "2016-05-20T11:35:45-05:00",
  "hooks_count": 1,
  "download": {
    "url": "https://github.example.com/api/v3/admin/pre-receive-environments/2/downloads/latest",
    "state": "not_started",
    "downloaded_at": null,
    "message": null
  }
}Get a pre-receive environment
"Get a pre-receive environment"에 대한 세분화된 액세스 토큰
이 엔드포인트는 GitHub 앱 사용자 액세스 토큰, GitHub 앱 설치 액세스 토큰 또는 세분화된 개인용 액세스 토큰에서 작동하지 않습니다.
"Get a pre-receive environment"에 대한 매개 변수
| 속성, 형식, 설명 | 
|---|
accept string Setting to   | 
| 속성, 형식, 설명 | 
|---|
pre_receive_environment_id integer RequiredThe unique identifier of the pre-receive environment.  | 
"Get a pre-receive environment"에 대한 HTTP 응답 상태 코드
| 상태 코드 | 설명 | 
|---|---|
200 | OK  | 
"Get a pre-receive environment"에 대한 코드 샘플
요청 예제
curl -L \
  -H "Accept: application/vnd.github+json" \
  -H "Authorization: Bearer <YOUR-TOKEN>" \
  -H "X-GitHub-Api-Version: 2022-11-28" \
  http(s)://HOSTNAME/api/v3/admin/pre-receive-environments/PRE_RECEIVE_ENVIRONMENT_IDResponse
Status: 200{
  "id": 2,
  "name": "DevTools Hook Env",
  "image_url": "https://my_file_server/path/to/devtools_env.tar.gz",
  "url": "https://github.example.com/api/v3/admin/pre-receive-environments/2",
  "html_url": "https://github.example.com/admin/pre-receive-environments/2",
  "default_environment": false,
  "created_at": "2016-05-20T11:35:45-05:00",
  "hooks_count": 1,
  "download": {
    "url": "https://github.example.com/api/v3/admin/pre-receive-environments/2/downloads/latest",
    "state": "not_started",
    "downloaded_at": null,
    "message": null
  }
}Update a pre-receive environment
You cannot modify the default environment. If you attempt to modify the default environment, you will receive a 422 Unprocessable Entity response.
"Update a pre-receive environment"에 대한 세분화된 액세스 토큰
이 엔드포인트는 GitHub 앱 사용자 액세스 토큰, GitHub 앱 설치 액세스 토큰 또는 세분화된 개인용 액세스 토큰에서 작동하지 않습니다.
"Update a pre-receive environment"에 대한 매개 변수
| 속성, 형식, 설명 | 
|---|
accept string Setting to   | 
| 속성, 형식, 설명 | 
|---|
pre_receive_environment_id integer RequiredThe unique identifier of the pre-receive environment.  | 
| 속성, 형식, 설명 | 
|---|
name string This pre-receive environment's new name.  | 
image_url string URL from which to download a tarball of this environment.  | 
"Update a pre-receive environment"에 대한 HTTP 응답 상태 코드
| 상태 코드 | 설명 | 
|---|---|
200 | OK  | 
422 | Client Errors  | 
"Update a pre-receive environment"에 대한 코드 샘플
요청 예제
curl -L \
  -X PATCH \
  -H "Accept: application/vnd.github+json" \
  -H "Authorization: Bearer <YOUR-TOKEN>" \
  -H "X-GitHub-Api-Version: 2022-11-28" \
  http(s)://HOSTNAME/api/v3/admin/pre-receive-environments/PRE_RECEIVE_ENVIRONMENT_ID \
  -d '{"name":"DevTools Hook Env","image_url":"https://my_file_server/path/to/devtools_env.tar.gz"}'Response
Status: 200{
  "id": 2,
  "name": "DevTools Hook Env",
  "image_url": "https://my_file_server/path/to/devtools_env.tar.gz",
  "url": "https://github.example.com/api/v3/admin/pre-receive-environments/2",
  "html_url": "https://github.example.com/admin/pre-receive-environments/2",
  "default_environment": false,
  "created_at": "2016-05-20T11:35:45-05:00",
  "hooks_count": 1,
  "download": {
    "url": "https://github.example.com/api/v3/admin/pre-receive-environments/2/downloads/latest",
    "state": "success",
    "downloaded_at": "2016-05-26T07:42:53-05:00",
    "message": null
  }
}Delete a pre-receive environment
If you attempt to delete an environment that cannot be deleted, you will receive a 422 Unprocessable Entity response.
The possible error messages are:
- Cannot modify or delete the default environment
 - Cannot delete environment that has hooks
 - Cannot delete environment when download is in progress
 
"Delete a pre-receive environment"에 대한 세분화된 액세스 토큰
이 엔드포인트는 GitHub 앱 사용자 액세스 토큰, GitHub 앱 설치 액세스 토큰 또는 세분화된 개인용 액세스 토큰에서 작동하지 않습니다.
"Delete a pre-receive environment"에 대한 매개 변수
| 속성, 형식, 설명 | 
|---|
accept string Setting to   | 
| 속성, 형식, 설명 | 
|---|
pre_receive_environment_id integer RequiredThe unique identifier of the pre-receive environment.  | 
"Delete a pre-receive environment"에 대한 HTTP 응답 상태 코드
| 상태 코드 | 설명 | 
|---|---|
204 | No Content  | 
422 | Client Errors  | 
"Delete a pre-receive environment"에 대한 코드 샘플
요청 예제
curl -L \
  -X DELETE \
  -H "Accept: application/vnd.github+json" \
  -H "Authorization: Bearer <YOUR-TOKEN>" \
  -H "X-GitHub-Api-Version: 2022-11-28" \
  http(s)://HOSTNAME/api/v3/admin/pre-receive-environments/PRE_RECEIVE_ENVIRONMENT_IDResponse
Status: 204Start a pre-receive environment download
Triggers a new download of the environment tarball from the environment's image_url. When the download is finished, the newly downloaded tarball will overwrite the existing environment.
If a download cannot be triggered, you will receive a 422 Unprocessable Entity response.
The possible error messages are:
- Cannot modify or delete the default environment
 - Can not start a new download when a download is in progress
 
"Start a pre-receive environment download"에 대한 세분화된 액세스 토큰
이 엔드포인트는 GitHub 앱 사용자 액세스 토큰, GitHub 앱 설치 액세스 토큰 또는 세분화된 개인용 액세스 토큰에서 작동하지 않습니다.
"Start a pre-receive environment download"에 대한 매개 변수
| 속성, 형식, 설명 | 
|---|
accept string Setting to   | 
| 속성, 형식, 설명 | 
|---|
pre_receive_environment_id integer RequiredThe unique identifier of the pre-receive environment.  | 
"Start a pre-receive environment download"에 대한 HTTP 응답 상태 코드
| 상태 코드 | 설명 | 
|---|---|
202 | Accepted  | 
422 | Client Errors  | 
"Start a pre-receive environment download"에 대한 코드 샘플
요청 예제
curl -L \
  -X POST \
  -H "Accept: application/vnd.github+json" \
  -H "Authorization: Bearer <YOUR-TOKEN>" \
  -H "X-GitHub-Api-Version: 2022-11-28" \
  http(s)://HOSTNAME/api/v3/admin/pre-receive-environments/PRE_RECEIVE_ENVIRONMENT_ID/downloadsResponse
Status: 202{
  "url": "https://github.example.com/api/v3/admin/pre-receive-environments/3/downloads/latest",
  "state": "not_started",
  "downloaded_at": null,
  "message": null
}Get the download status for a pre-receive environment
In addition to seeing the download status at the "Get a pre-receive environment" endpoint, there is also this separate endpoint for just the download status.
"Get the download status for a pre-receive environment"에 대한 세분화된 액세스 토큰
이 엔드포인트는 GitHub 앱 사용자 액세스 토큰, GitHub 앱 설치 액세스 토큰 또는 세분화된 개인용 액세스 토큰에서 작동하지 않습니다.
"Get the download status for a pre-receive environment"에 대한 매개 변수
| 속성, 형식, 설명 | 
|---|
accept string Setting to   | 
| 속성, 형식, 설명 | 
|---|
pre_receive_environment_id integer RequiredThe unique identifier of the pre-receive environment.  | 
"Get the download status for a pre-receive environment"에 대한 HTTP 응답 상태 코드
| 상태 코드 | 설명 | 
|---|---|
200 | OK  | 
"Get the download status for a pre-receive environment"에 대한 코드 샘플
요청 예제
curl -L \
  -H "Accept: application/vnd.github+json" \
  -H "Authorization: Bearer <YOUR-TOKEN>" \
  -H "X-GitHub-Api-Version: 2022-11-28" \
  http(s)://HOSTNAME/api/v3/admin/pre-receive-environments/PRE_RECEIVE_ENVIRONMENT_ID/downloads/latestResponse
Status: 200{
  "url": "https://github.example.com/api/v3/admin/pre-receive-environments/3/downloads/latest",
  "state": "success",
  "downloaded_at": "2016-05-26T07:42:53-05:00",
  "message": null
}