关于存储库 Webhook
利用存储库 Webhook 可在存储库内发生特定事件时接收 HTTP POST
有效负载。 可以使用 REST API 来管理存储库、组织和应用 Webhook。 可以列出 Webhook 的 Webhook 交付,获取并重新交付 Webhook 的个别交付,该交付可以集成到外部应用或服务中。 还可使用 REST API 更改 Webhook 的配置。 例如,您可以修改有效负载 URL、内容类型、SSL 验证和机密。 有关详细信息,请参阅:
如果要设置一个 Webhook 来接收来自组织所有存储库的事件,请参阅关于组织 Webhook 的 REST API 文档。
除了 REST API 之外,GitHub 还可以用作存储库的 PubSubHubbub 中心。
接收 web 挂钩
为了让 GitHub Enterprise Server 发送 web 挂钩有效负载,您的服务器需要能够从 Internet 访问。 我们还强烈建议使用 SSL,以便我们可以通过 HTTPS 发送加密的有效负载。
Web 挂钩标头
GitHub Enterprise Server 发送时将附带几个 HTTP 标头,以区分事件类型和有效负载标识符。 有关详细信息,请参阅 Webhook 标头。
PubSubHubbub
GitHub 还可以用作所有存储库的 PubSubHubbub 中心。 PSHB 是一个简单的发布/订阅协议,允许服务器注册在主题更新时接收更新。 这些更新随 HTTP POST 请求一起发送到回调 URL。 GitHub 仓库推送的主题 URL 采用以下格式:
https://github.com/{owner}/{repo}/events/{event}
事件可以是任何可用的 web 挂钩事件。 有关详细信息,请参阅“Webhook 事件和有效负载”。
响应格式
默认格式是现有接收后挂钩应具有的格式:作为 POST 中的 payload
参数发送的 JSON 正文。 还可以指定接收带有 Accept
标头或 .json
扩展名的原始 JSON 正文。
Accept: application/json
https://github.com/{owner}/{repo}/events/push.json
回调 URL
回叫 URL 可以使用 HTTP 协议。
# Send updates to a PostBin bin
https://www.toptal.com/developers/postbin/123
订阅
GitHub PubSubHubbub 终结点为 http(s)://HOSTNAME/api/v3/hub
,它采用以下参数。
名称 | 类型 | 必须 | 说明 |
---|---|---|---|
hub.mode | string | subscribe 或 unsubscribe 。 | |
hub.topic | string | 要订阅的 GitHub 仓库的 URI。 路径的格式必须为 /{owner}/{repo}/events/{event} 。 | |
hub.callback | string | 要接收主题更新的 URI。 | |
hub.secret | string | 用于生成传出正文内容的哈希签名的共享密钥。 可通过比较原始请求正文与 X-Hub-Signature 或 X-Hub-Signature-256 标头。 有关更多详细信息,请参阅 PubSubHubbub 文档。 |
使用 cURL 的示例请求如下所示:
curl -u "user" -i \
http(s)://HOSTNAME/api/v3/hub \
-F "hub.mode=subscribe" \
-F "hub.topic=https://github.com/{owner}/{repo}/events/push" \
-F "hub.callback=https://www.toptal.com/developers/postbin/123"
PubSubHubbub 请求可以多次发送。 如果挂钩已经存在,它将根据请求进行修改。