リポジトリの pre-receive フック用の REST API エンドポイント
REST API を使用して、リポジトリで使用可能な pre-receive フックの適用を表示および変更します。
リポジトリの pre-receive フックについて
メモ
これらのエンドポイントでは、personal access token (classic) を使う認証のみがサポートされます。 詳しくは、「個人用アクセス トークンを管理する」をご覧ください。
| 名前 | Type | 説明 | 
|---|---|---|
| name | string | フックの名前。 | 
| enforcement | string | このリポジトリでのフックの適用状態。 | 
| configuration_url | string | 適用設定されているエンドポイントの URL。 | 
_適用_に使用できる値は enabled、disabledとtestingです。 disabled は、pre-receive フックが実行されないことを示します。 enabled は、それが実行され、ゼロ以外の状態になるプッシュを拒否することを示します。 testing は、スクリプトは実行されるが、プッシュが拒否されないことを示します。
configuration_url は、このリポジトリ、その organization の所有者、またはグローバル設定へのリンクである場合があります。 configuration_url のエンドポイントにアクセスする権限は、所有者またはサイト管理者レベルで決定されます。
List pre-receive hooks for a repository
List all pre-receive hooks that are enabled or testing for this repository as well as any disabled hooks that are allowed to be enabled at the repository level. Pre-receive hooks that are disabled at a higher level and are not configurable will not be listed.
"List pre-receive hooks for a repository" のきめ細かいアクセス トークン
このエンドポイントは、次の粒度の細かいトークンの種類で動作します:
粒度の細かいトークンには次のアクセス許可セットが設定されている必要があります:
- "Repository pre-receive hooks" repository permissions (read)
"List pre-receive hooks for a repository" のパラメーター
| 名前, Type, 説明 | 
|---|
| acceptstringSetting to  | 
| 名前, Type, 説明 | 
|---|
| ownerstring 必須The account owner of the repository. The name is not case sensitive. | 
| repostring 必須The name of the repository without the  | 
| 名前, Type, 説明 | 
|---|
| per_pageintegerThe number of results per page (max 100). For more information, see "Using pagination in the REST API." Default:  | 
| pageintegerThe page number of the results to fetch. For more information, see "Using pagination in the REST API." Default:  | 
| directionstringThe direction to sort the results by. Default:  次のいずれかにできます:  | 
| sortstringDefault:  次のいずれかにできます:  | 
"List pre-receive hooks for a repository" の HTTP 応答状態コード
| 状態コード | 説明 | 
|---|---|
| 200 | OK | 
"List pre-receive hooks for a repository" のコード サンプル
要求の例
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/repos/OWNER/REPO/pre-receive-hooksResponse
Status: 200[
  {
    "id": 42,
    "name": "Check Commits",
    "enforcement": "disabled",
    "configuration_url": "https://github.example.com/api/v3/orgs/octocat/pre-receive-hooks/42"
  }
]Get a pre-receive hook for a repository
"Get a pre-receive hook for a repository" のきめ細かいアクセス トークン
このエンドポイントは、次の粒度の細かいトークンの種類で動作します:
粒度の細かいトークンには次のアクセス許可セットが設定されている必要があります:
- "Repository pre-receive hooks" repository permissions (read)
"Get a pre-receive hook for a repository" のパラメーター
| 名前, Type, 説明 | 
|---|
| acceptstringSetting to  | 
| 名前, Type, 説明 | 
|---|
| ownerstring 必須The account owner of the repository. The name is not case sensitive. | 
| repostring 必須The name of the repository without the  | 
| pre_receive_hook_idinteger 必須The unique identifier of the pre-receive hook. | 
"Get a pre-receive hook for a repository" の HTTP 応答状態コード
| 状態コード | 説明 | 
|---|---|
| 200 | OK | 
"Get a pre-receive hook for a repository" のコード サンプル
要求の例
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/repos/OWNER/REPO/pre-receive-hooks/PRE_RECEIVE_HOOK_IDResponse
Status: 200{
  "id": 42,
  "name": "Check Commits",
  "enforcement": "disabled",
  "configuration_url": "https://github.example.com/api/v3/orgs/octocat/pre-receive-hooks/42"
}Update pre-receive hook enforcement for a repository
For pre-receive hooks which are allowed to be configured at the repo level, you can set enforcement
"Update pre-receive hook enforcement for a repository" のきめ細かいアクセス トークン
このエンドポイントは、次の粒度の細かいトークンの種類で動作します:
粒度の細かいトークンには次のアクセス許可セットが設定されている必要があります:
- "Repository pre-receive hooks" repository permissions (write)
"Update pre-receive hook enforcement for a repository" のパラメーター
| 名前, Type, 説明 | 
|---|
| acceptstringSetting to  | 
| 名前, Type, 説明 | 
|---|
| ownerstring 必須The account owner of the repository. The name is not case sensitive. | 
| repostring 必須The name of the repository without the  | 
| pre_receive_hook_idinteger 必須The unique identifier of the pre-receive hook. | 
| 名前, Type, 説明 | 
|---|
| enforcementstringThe state of enforcement for the hook on this repository. 次のいずれかにできます:  | 
"Update pre-receive hook enforcement for a repository" の HTTP 応答状態コード
| 状態コード | 説明 | 
|---|---|
| 200 | OK | 
"Update pre-receive hook enforcement for a repository" のコード サンプル
要求の例
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/repos/OWNER/REPO/pre-receive-hooks/PRE_RECEIVE_HOOK_ID \
  -d '{"enforcement":"enabled"}'Response
Status: 200{
  "id": 42,
  "name": "Check Commits",
  "enforcement": "enabled",
  "configuration_url": "https://github.example.com/api/v3/repos/octocat/hello-world/pre-receive-hooks/42"
}Remove pre-receive hook enforcement for a repository
Deletes any overridden enforcement on this repository for the specified hook.
Responds with effective values inherited from owner and/or global level.
"Remove pre-receive hook enforcement for a repository" のきめ細かいアクセス トークン
このエンドポイントは、次の粒度の細かいトークンの種類で動作します:
粒度の細かいトークンには次のアクセス許可セットが設定されている必要があります:
- "Repository pre-receive hooks" repository permissions (write)
"Remove pre-receive hook enforcement for a repository" のパラメーター
| 名前, Type, 説明 | 
|---|
| acceptstringSetting to  | 
| 名前, Type, 説明 | 
|---|
| ownerstring 必須The account owner of the repository. The name is not case sensitive. | 
| repostring 必須The name of the repository without the  | 
| pre_receive_hook_idinteger 必須The unique identifier of the pre-receive hook. | 
"Remove pre-receive hook enforcement for a repository" の HTTP 応答状態コード
| 状態コード | 説明 | 
|---|---|
| 200 | Responds with effective values inherited from owner and/or global level. | 
"Remove pre-receive hook enforcement for a repository" のコード サンプル
要求の例
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/repos/OWNER/REPO/pre-receive-hooks/PRE_RECEIVE_HOOK_IDResponds with effective values inherited from owner and/or global level.
Status: 200{
  "id": 42,
  "name": "Check Commits",
  "enforcement": "disabled",
  "configuration_url": "https://github.example.com/api/v3/orgs/octocat/pre-receive-hooks/42"
}