Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
c0124e7
📝 Document webhooks
coyotte508 Dec 13, 2022
40ca212
fixup! 📝 Document webhooks
coyotte508 Dec 13, 2022
b9dca40
Update docs/hub/webhooks.md
coyotte508 Dec 13, 2022
0d7a9f2
Update docs/hub/webhooks.md
coyotte508 Dec 13, 2022
868df3e
Update docs/hub/webhooks.md
coyotte508 Dec 13, 2022
ccd7b17
Update docs/hub/webhooks.md
coyotte508 Dec 13, 2022
66930b8
Update docs/hub/webhooks.md
coyotte508 Dec 13, 2022
aedb144
Update docs/hub/webhooks.md
coyotte508 Dec 13, 2022
f0da9c7
Update docs/hub/webhooks.md
coyotte508 Dec 14, 2022
98e68d7
Update docs/hub/webhooks.md
coyotte508 Dec 14, 2022
3913170
Update docs/hub/webhooks.md
coyotte508 Dec 14, 2022
b756d57
Update docs/hub/webhooks.md
coyotte508 Dec 14, 2022
22897e7
Update docs/hub/webhooks.md
coyotte508 Dec 14, 2022
9cbb7eb
📝 Add screenshots + full payload + change domain to scope
coyotte508 Dec 14, 2022
9d3daaa
💬 Sample to "here is an example..."
coyotte508 Dec 14, 2022
01574e5
✏️
coyotte508 Dec 14, 2022
99e742c
✏️ Proof reading
coyotte508 Dec 14, 2022
7f284f8
📝 Improve secrets doc + document daily triggers
coyotte508 Dec 14, 2022
af52533
fixup! 📝 Improve secrets doc + document daily triggers
coyotte508 Dec 14, 2022
efb995d
💬 Update payloads
coyotte508 Dec 14, 2022
75ab75a
Update docs/hub/webhooks.md
coyotte508 Dec 19, 2022
7c400b5
Update docs/hub/webhooks.md
coyotte508 Dec 19, 2022
23f96c4
Apply suggestions from code review
coyotte508 Dec 19, 2022
f2ce396
Apply suggestions from code review
coyotte508 Dec 26, 2022
e824dc7
Add link to webhooks-explorers
coyotte508 Jan 8, 2023
a4107d9
Typo
coyotte508 Jan 8, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions docs/hub/_toctree.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@
title: Pull Requests & Discussions
- local: notifications
title: Notifications
- local: webhooks
title: Webhooks
- local: repositories-next-steps
title: Next Steps
- local: repositories-licenses
Expand Down
195 changes: 195 additions & 0 deletions docs/hub/webhooks.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,195 @@
# Webhooks

**Join the [webhooks-explorers](https://huggingface.co/webhooks-explorers) organization to beta-test webhooks!**

Webhooks are a foundation for MLOps related features. You can use them to auto-convert models, build community bots, or build CI/CD for your models, datasets, and Spaces.

They allow you to listen for new changes on specific repos or repos belonging to particular users/organizations (not just your repos, but any repo!).

You can create new webhooks and edit exiting ones in your webhooks [settings](https://huggingface.co/settings/webhooks):

![Settings of an individual webhook](https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/hub/webhook-settings.png)

Webhooks can watch for repos updates, Pull requests, discussions, and new comments. It's even possible to create a Space to react to your webhooks!

<!-- Todo: add a link to a guide with a real example -->

## Webhook Payloads

After registering a webhook, you will be notified of new events via an `HTTP POST` call on the specified target URL. The payload is encoded in JSON.

You can view the history of payloads sent in the activity tab of the webhook settings page, it's also possible to replay past webhooks for easier debugging:


![image.png](https://s3.amazonaws.com/moonup/production/uploads/1671034300077-61d2f90c3c2083e1c08af22d.png)

As an example, here is the full payload when a Pull request is opened:

```json
{
"event": {
"action": "create",
"scope": "discussion"
},
"repo": {
"type": "model",
"name": "gpt2",
"id": "621ffdc036468d709f17434d",
"private": false,
"url": {
"web": "https://hugginface.co/gpt2",
"api": "https://hugginface.co/api/models/gpt2"
},
"owner": {
"id": "628b753283ef59b5be89e937"
}
},
"discussion": {
"id": "6399f58518721fdd27fc9ca9",
"title": "Update co2 emissions",
"url": {
"web": "https://hugginface.co/gpt2/discussions/19",
"api": "https://hugginface.co/api/models/gpt2/discussions/19"
},
"status": "open",
"author": {
"id": "61d2f90c3c2083e1c08af22d"
},
"num": 19,
"isPullRequest": true,
"changes": {
"base": "refs/heads/main"
}
},
"comment": {
"id": "6399f58518721fdd27fc9caa",
"author": {
"id": "61d2f90c3c2083e1c08af22d"
},
"content": "Add co2 emissions information to the model card",
"hidden": false,
"url": {
"web": "https://hugginface.co/gpt2/discussions/19#6399f58518721fdd27fc9caa"
}
},
"webhook": {
"id": "6390e855e30d9209411de93b",
"version": 3
}
}
```

### Event

The top-level properties `event` is always specified and used to determine the nature of the event.

It has two sub-properties: `event.action` and `event.scope`.

`event.scope` will be one of the following values:

- `"repo"` - Global events on repos. Possible values for the associated `action`: `"create"`, `"delete"`, `"update"`, `"move"`.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I wonder if a better format for this would be a table with three columns: event.scope value, description, associated actions

- `"repo.content"` - Events on the repo's content, such as new commits or tags. It triggers on new Pull requests as well due to the newly created reference/commit. The associated `action` is always `"update"`.
- `"repo.config"` - Events on the config: update Space secrets, update settings, update DOIs, disabled or not, etc. The associated `action` is always `"update"`.
- `"discussion"` - Creating a discussion or Pull request, updating the title or status, and merging. Possible values for the associated `action`: `"create"`, `"delete"`, `"update"`.
- `"discussion.comment"` - Creating, updating, and hiding a comment. Possible values for the associated `action`: `"create"`, `"update"`.

More scopes can be added in the future. To handle unknown events, your webhook handler can consider any action on a narrowed scope to be an `"update"` action on the broader scope.

For example, if the `"repo.config.dois"` scope is added in the future, any event with that scope can be considered by your webhook handler as an `"update"` action on the `"repo.config"` scope.

### Repo

In the current version of webhooks, the top level property `repo` is always specified, as events can always be associated to a repo. For example, consider the following value:

```json
"repo": {
"type": "model",
"name": "some-user/some-repo",
"id": "6366c000a2abcdf2fd69a080",
"private": false,
"url": {
"web": "http://huggingface.co/some-user/some-repo",
"api": "http://huggingface.co/api/models/some-user/some-repo"
},
"headSha": "c379e821c9c95d613899e8c4343e4bfee2b0c600",
"tags": [
"license:other",
"has_space"
],
"owner": {
"id": "61d2000c3c2083e1c08af22d"
}
}
```

`repo.headSha` is the sha of the latest commit on the repo's `main` branch. It is only sent when `event.scope` starts with `"repo"`, not on community events like discussions and comments.

### Discussion and Pull Requests

The top-level property `discussion` is specified on community events (discussions and Pull requests). The `discussion.isPullRequest` property is a boolean indicating if the discussion is also a Pull request (on the Hub, a PR is a special type of discussion). Here is an example value:

```json
"discussion": {
"id": "639885d811ae2bad2b7ba461",
"title": "Hello!",
"url": {
"web": "https://huggingface.co/some-user/some-repo/discussions/3",
"api": "https://huggingface.co/api/models/some-user/some-repo/discussions/3"
},
"status": "open",
"author": {
"id": "61d2000c3c2083e1c08af22d"
},
"isPullRequest": true,
"changes": {
"base": "refs/heads/main"
}
"num": 3
}
```

### Comment

The top level property `comment` is specified when a comment is created (including on discussion creation) or updated. Here is an example value:

```json
"comment": {
"id": "6398872887bfcfb93a306f18",
"author": {
"id": "61d2000c3c2083e1c08af22d"
},
"content": "This adds an env key",
"hidden": false,
"url": {
"web": "http://huggingface.co/some-user/some-repo/discussions/4#6398872887bfcfb93a306f18"
}
}
```

## Webhook secret

Setting a webhook secret is useful to make sure payloads sent to your webhook handler URL are from Hugging Face.

If you set a secret for your webhook, it will be sent along as an `X-Webhook-Secret` HTTP header on every request. Only ASCII characters are supported.

<Tip>
It's also possible to add the secret directly in the handler URL. For example, setting it as a query parameter: https://example.com/webhook?secret=XXX.

This can be helpful if accessing the HTTP headers of the request is complicated for your webhook handler.
</Tip>

## Rate limiting

Each webhook is limited to 1,000 triggers per 24 hours. You can view your usage in the Webhook settings page in the "Activity" tab.

If you need to increase the number of triggers for your webhook, contact us at [email protected].

## Debugging webhooks

Go in the activity tab for your webhook, there you will see the list of recent events.

![image.png](https://s3.amazonaws.com/moonup/production/uploads/1671035382840-61d2f90c3c2083e1c08af22d.png)

You will see the HTTP status code and the payload of past events. You can replay those events by clicking on the `replay` button!

When changing the target URL or secret of a webhook, replaying an event will send the payload to the updated URL.