组织 Webhook 的 REST API 端点
使用 REST API 与组织中的 Webhook 交互。
关于组织 Webhook
组织 Webhook 允许您的服务器在组织中发生特定事件时接收 HTTP POST
有效负载。更多信息,请参阅“Webhook 文档”。
列出组织 Webhook
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“列出组织 Webhook”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(读取)
“列出组织 Webhook”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
名称、类型、描述 |
---|
per_page 整数每页结果数(最大 100)。更多信息,请参阅“在 REST API 中使用分页”。 默认值: |
page 整数要获取的结果的页码。更多信息,请参阅“在 REST API 中使用分页”。 默认值: |
“列出组织 Webhook”的 HTTP 响应状态码
状态码 | 描述 |
---|---|
200 | OK |
404 | 资源未找到 |
“列出组织 Webhook”的代码示例
请求示例
curl -L \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks
响应
状态:200
[ { "id": 1, "url": "https://api.github.com/orgs/octocat/hooks/1", "ping_url": "https://api.github.com/orgs/octocat/hooks/1/pings", "deliveries_url": "https://api.github.com/orgs/octocat/hooks/1/deliveries", "name": "web", "events": [ "push", "pull_request" ], "active": true, "config": { "url": "http://example.com", "content_type": "json" }, "updated_at": "2011-09-06T20:39:23Z", "created_at": "2011-09-06T17:26:27Z", "type": "Organization" } ]
创建组织 Webhook
创建一个以 JSON 格式发布有效负载的钩子。
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“创建组织 Webhook”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(写入)
“创建组织 Webhook”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
名称、类型、描述 | |||||||
---|---|---|---|---|---|---|---|
name 字符串 必需必须作为“web”传递。 | |||||||
config 对象 必需键值对,用于为此 Webhook 提供设置。 | |||||||
|
名称、类型、描述 |
---|
url 字符串 必需将向其传递有效负载的 URL。 |
content_type 字符串用于序列化有效负载的媒体类型。支持的值包括 |
secret 字符串如果提供,则 |
insecure_ssl 字符串或数字确定在传递有效负载时是否将验证 |
username 字符串 |
password 字符串 |
events
字符串数组确定webhook触发的事件。设置为["*"]
以接收所有可能的事件。
默认: ["push"]
active
布尔值确定触发webhook时是否发送通知。设置为true
以发送通知。
默认: true
“创建组织webhook”的HTTP响应状态码
状态码 | 描述 |
---|---|
201 | 已创建 |
404 | 资源未找到 |
422 | 验证失败,或端点已被标记为垃圾邮件。 |
“创建组织webhook”的代码示例
请求示例
curl -L \ -X POST \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks \ -d '{"name":"web","active":true,"events":["push","pull_request"],"config":{"url":"http://example.com/webhook","content_type":"json"}}'
响应
状态:201
{ "id": 1, "url": "https://api.github.com/orgs/octocat/hooks/1", "ping_url": "https://api.github.com/orgs/octocat/hooks/1/pings", "deliveries_url": "https://api.github.com/orgs/octocat/hooks/1/deliveries", "name": "web", "events": [ "push", "pull_request" ], "active": true, "config": { "url": "http://example.com", "content_type": "json" }, "updated_at": "2011-09-06T20:39:23Z", "created_at": "2011-09-06T17:26:27Z", "type": "Organization" }
获取组织webhook
返回在组织中配置的webhook。要仅获取webhook 的config
属性,请参阅“获取组织的webhook配置”。
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“获取组织webhook”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(读取)
“获取组织webhook”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
hook_id 整数 必需hook的唯一标识符。您可以在webhook传递的 |
“获取组织webhook”的HTTP响应状态码
状态码 | 描述 |
---|---|
200 | OK |
404 | 资源未找到 |
“获取组织webhook”的代码示例
请求示例
curl -L \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks/HOOK_ID
响应
状态:200
{ "id": 1, "url": "https://api.github.com/orgs/octocat/hooks/1", "ping_url": "https://api.github.com/orgs/octocat/hooks/1/pings", "deliveries_url": "https://api.github.com/orgs/octocat/hooks/1/deliveries", "name": "web", "events": [ "push", "pull_request" ], "active": true, "config": { "url": "http://example.com", "content_type": "json" }, "updated_at": "2011-09-06T20:39:23Z", "created_at": "2011-09-06T17:26:27Z", "type": "Organization" }
更新组织webhook
更新在组织中配置的webhook。更新webhook时,secret
将被覆盖。如果您之前已设置secret
,则必须提供相同的secret
或设置新的secret
,否则secret将被移除。如果您只想更新单个webhook config
属性,请使用“更新组织的webhook配置”。
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“更新组织webhook”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(写入)
“更新组织webhook”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
hook_id 整数 必需hook的唯一标识符。您可以在webhook传递的 |
名称、类型、描述 | |||||
---|---|---|---|---|---|
config 对象键值对,用于为此 Webhook 提供设置。 | |||||
|
名称、类型、描述 |
---|
url 字符串 必需将向其传递有效负载的 URL。 |
content_type 字符串用于序列化有效负载的媒体类型。支持的值包括 |
secret 字符串如果提供,则 |
insecure_ssl 字符串或数字确定在传递有效负载时是否将验证 |
events
字符串数组确定webhook触发的事件。
默认: ["push"]
active
布尔值确定触发webhook时是否发送通知。设置为true
以发送通知。
默认: true
name
字符串“更新组织webhook”的HTTP响应状态码
状态码 | 描述 |
---|---|
200 | OK |
404 | 资源未找到 |
422 | 验证失败,或端点已被标记为垃圾邮件。 |
“更新组织webhook”的代码示例
请求示例
curl -L \ -X PATCH \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks/HOOK_ID \ -d '{"active":true,"events":["pull_request"]}'
响应
状态:200
{ "id": 1, "url": "https://api.github.com/orgs/octocat/hooks/1", "ping_url": "https://api.github.com/orgs/octocat/hooks/1/pings", "deliveries_url": "https://api.github.com/repos/octocat/Hello-World/hooks/12345678/deliveries", "name": "web", "events": [ "pull_request" ], "active": true, "config": { "url": "http://example.com", "content_type": "json" }, "updated_at": "2011-09-06T20:39:23Z", "created_at": "2011-09-06T17:26:27Z", "type": "Organization" }
删除组织webhook
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“删除组织webhook”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(写入)
“删除组织webhook”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
hook_id 整数 必需hook的唯一标识符。您可以在webhook传递的 |
“删除组织webhook”的HTTP响应状态码
状态码 | 描述 |
---|---|
204 | 无内容 |
404 | 资源未找到 |
“删除组织webhook”的代码示例
请求示例
curl -L \ -X DELETE \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks/HOOK_ID
响应
状态:204
获取组织的webhook配置
返回组织的webhook配置。要获取有关webhook的更多信息,包括active
状态和events
,请使用“获取组织webhook”。
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“获取组织的webhook配置”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(读取)
“获取组织的webhook配置”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
hook_id 整数 必需hook的唯一标识符。您可以在webhook传递的 |
“获取组织的webhook配置”的HTTP响应状态码
状态码 | 描述 |
---|---|
200 | OK |
“获取组织的webhook配置”的代码示例
请求示例
curl -L \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks/HOOK_ID/config
响应
更新组织的webhook配置
更新组织的webhook配置。要更新有关webhook的更多信息,包括active
状态和events
,请使用“更新组织webhook”。
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“更新组织的webhook配置”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(写入)
“更新组织的webhook配置”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
hook_id 整数 必需hook的唯一标识符。您可以在webhook传递的 |
名称、类型、描述 |
---|
url 字符串将向其传递有效负载的 URL。 |
content_type 字符串用于序列化有效负载的媒体类型。支持的值包括 |
secret 字符串如果提供,则 |
insecure_ssl 字符串或数字确定在传递有效负载时是否将验证 |
“更新组织的webhook配置”的HTTP响应状态码
状态码 | 描述 |
---|---|
200 | OK |
“更新组织的webhook配置”的代码示例
请求示例
curl -L \ -X PATCH \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks/HOOK_ID/config \ -d '{"url":"http://example.com/webhook","content_type":"json","insecure_ssl":"0","secret":"********"}'
响应
列出组织webhook的传递
返回在组织中配置的webhook的webhook传递列表。
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“列出组织webhook的传递”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(读取)
“列出组织webhook的传递”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
hook_id 整数 必需hook的唯一标识符。您可以在webhook传递的 |
名称、类型、描述 |
---|
per_page 整数每页结果数(最大 100)。更多信息,请参阅“在 REST API 中使用分页”。 默认值: |
cursor 字符串用于分页:从中提取传递页面的起始传递。有关下一页和上一页游标,请参阅 |
“列出组织webhook的传递”的HTTP响应状态码
状态码 | 描述 |
---|---|
200 | OK |
400 | 错误请求 |
422 | 验证失败,或端点已被标记为垃圾邮件。 |
“列出组织webhook的传递”的代码示例
请求示例
curl -L \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks/HOOK_ID/deliveries
响应
状态:200
[ { "id": 12345678, "guid": "0b989ba4-242f-11e5-81e1-c7b6966d2516", "delivered_at": "2019-06-03T00:57:16Z", "redelivery": false, "duration": 0.27, "status": "OK", "status_code": 200, "event": "issues", "action": "opened", "installation_id": 123, "repository_id": 456, "throttled_at": "2019-06-03T00:57:16Z" }, { "id": 123456789, "guid": "0b989ba4-242f-11e5-81e1-c7b6966d2516", "delivered_at": "2019-06-04T00:57:16Z", "redelivery": true, "duration": 0.28, "status": "OK", "status_code": 200, "event": "issues", "action": "opened", "installation_id": 123, "repository_id": 456, "throttled_at": null } ]
获取组织webhook的webhook传递
返回在组织中配置的webhook的传递。
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“获取组织webhook的webhook传递”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(读取)
“获取组织webhook的webhook传递”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
hook_id 整数 必需hook的唯一标识符。您可以在webhook传递的 |
delivery_id 整数 必需 |
“获取组织webhook的webhook传递”的HTTP响应状态码
状态码 | 描述 |
---|---|
200 | OK |
400 | 错误请求 |
422 | 验证失败,或端点已被标记为垃圾邮件。 |
“获取组织webhook的webhook传递”的代码示例
请求示例
curl -L \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks/HOOK_ID/deliveries/DELIVERY_ID
响应
状态:200
{ "id": 12345678, "guid": "0b989ba4-242f-11e5-81e1-c7b6966d2516", "delivered_at": "2019-06-03T00:57:16Z", "redelivery": false, "duration": 0.27, "status": "OK", "status_code": 200, "event": "issues", "action": "opened", "installation_id": 123, "repository_id": 456, "url": "https://www.example.com", "throttled_at": "2019-06-03T00:57:16Z", "request": { "headers": { "X-GitHub-Delivery": "0b989ba4-242f-11e5-81e1-c7b6966d2516", "X-Hub-Signature-256": "sha256=6dcb09b5b57875f334f61aebed695e2e4193db5e", "Accept": "*/*", "X-GitHub-Hook-ID": "42", "User-Agent": "GitHub-Hookshot/b8c71d8", "X-GitHub-Event": "issues", "X-GitHub-Hook-Installation-Target-ID": "123", "X-GitHub-Hook-Installation-Target-Type": "repository", "content-type": "application/json", "X-Hub-Signature": "sha1=a84d88e7554fc1fa21bcbc4efae3c782a70d2b9d" }, "payload": { "action": "opened", "issue": { "body": "foo" }, "repository": { "id": 123 } } }, "response": { "headers": { "Content-Type": "text/html;charset=utf-8" }, "payload": "ok" } }
重新传递组织webhook的传递
重新传递在组织中配置的webhook的传递。
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“重新传递组织webhook的传递”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(写入)
“重新传递组织webhook的传递”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
hook_id 整数 必需hook的唯一标识符。您可以在webhook传递的 |
delivery_id 整数 必需 |
“重新传递组织webhook的传递”的HTTP响应状态码
状态码 | 描述 |
---|---|
202 | 已接受 |
400 | 错误请求 |
422 | 验证失败,或端点已被标记为垃圾邮件。 |
“重新传递组织webhook的传递”的代码示例
请求示例
curl -L \ -X POST \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks/HOOK_ID/deliveries/DELIVERY_ID/attempts
已接受
Ping 组织webhook
这将触发发送到hook的ping事件。
您必须是组织所有者才能使用此端点。
OAuth 应用令牌和个人访问令牌(经典版)需要 admin:org_hook
范围。OAuth 应用无法列出、查看或编辑其未创建的 Webhook,用户也无法列出、查看或编辑由 OAuth 应用创建的 Webhook。
“Ping 组织webhook”的细粒度访问令牌
此端点适用于以下细粒度令牌类型:
细粒度令牌必须具有以下权限集
- “Webhook”组织权限(写入)
“Ping 组织webhook”的参数
名称、类型、描述 |
---|
accept 字符串建议设置为 |
名称、类型、描述 |
---|
org 字符串 必需组织名称。名称不区分大小写。 |
hook_id 整数 必需hook的唯一标识符。您可以在webhook传递的 |
“Ping 组织webhook”的HTTP响应状态码
状态码 | 描述 |
---|---|
204 | 无内容 |
404 | 资源未找到 |
“Ping 组织webhook”的代码示例
请求示例
curl -L \ -X POST \ -H "Accept: application/vnd.github+json" \ -H "Authorization: Bearer <YOUR-TOKEN>" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/orgs/ORG/hooks/HOOK_ID/pings
响应
状态:204