2020-10-28 15:08:49 +00:00
---
stage: none
group: unassigned
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#designated-technical-writers
---
2017-05-18 08:49:03 +00:00
# System hooks API
2014-05-27 12:12:15 +00:00
2016-01-24 19:19:46 +00:00
All methods require administrator authorization.
2014-03-14 18:53:43 +00:00
2016-01-18 08:45:50 +00:00
The URL endpoint of the system hooks can also be configured using the UI in
2020-01-09 00:07:40 +00:00
the **Admin Area > System Hooks** (`/admin/hooks`).
2016-01-24 19:19:46 +00:00
Read more about [system hooks ](../system_hooks/system_hooks.md ).
2014-03-14 18:53:43 +00:00
## List system hooks
2016-01-18 08:45:50 +00:00
Get a list of all system hooks.
2014-03-14 18:53:43 +00:00
2020-02-29 03:07:51 +00:00
```plaintext
2014-03-14 18:53:43 +00:00
GET /hooks
```
2016-01-24 19:19:46 +00:00
Example request:
2020-01-30 15:09:15 +00:00
```shell
2020-05-28 00:08:37 +00:00
curl --header "PRIVATE-TOKEN: < your_access_token > " "https://gitlab.example.com/api/v4/hooks"
2016-01-18 08:45:50 +00:00
```
2014-03-14 18:53:43 +00:00
2016-01-18 08:45:50 +00:00
Example response:
2014-03-14 18:53:43 +00:00
```json
[
2016-10-19 14:08:30 +00:00
{
"id":1,
"url":"https://gitlab.example.com/hook",
"created_at":"2016-10-31T12:32:15.192Z",
"push_events":true,
"tag_push_events":false,
2017-11-23 15:45:00 +00:00
"merge_requests_events": true,
2018-08-14 18:55:55 +00:00
"repository_update_events": true,
2016-10-19 14:08:30 +00:00
"enable_ssl_verification":true
}
2014-03-14 18:53:43 +00:00
]
```
2016-01-18 08:45:50 +00:00
## Add new system hook
2014-03-14 18:53:43 +00:00
2016-01-24 19:19:46 +00:00
Add a new system hook.
2020-02-29 03:07:51 +00:00
```plaintext
2014-03-14 18:53:43 +00:00
POST /hooks
```
2016-01-18 08:45:50 +00:00
| Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- |
| `url` | string | yes | The hook URL |
2016-11-02 12:24:24 +00:00
| `token` | string | no | Secret token to validate received payloads; this will not be returned in the response |
| `push_events` | boolean | no | When true, the hook will fire on push events |
| `tag_push_events` | boolean | no | When true, the hook will fire on new tags being pushed |
2017-11-23 20:36:58 +00:00
| `merge_requests_events` | boolean | no | Trigger hook on merge requests events |
2018-08-14 18:55:55 +00:00
| `repository_update_events` | boolean | no | Trigger hook on repository update events |
2016-11-02 12:24:24 +00:00
| `enable_ssl_verification` | boolean | no | Do SSL verification when triggering the hook |
2016-01-18 08:45:50 +00:00
2016-01-24 19:19:46 +00:00
Example request:
2020-01-30 15:09:15 +00:00
```shell
2018-12-27 09:03:08 +00:00
curl --request POST --header "PRIVATE-TOKEN: < your_access_token > " "https://gitlab.example.com/api/v4/hooks?url=https://gitlab.example.com/hook"
2016-01-18 08:45:50 +00:00
```
2014-03-14 18:53:43 +00:00
2016-01-18 08:45:50 +00:00
Example response:
```json
[
2016-10-19 14:08:30 +00:00
{
"id":1,
"url":"https://gitlab.example.com/hook",
"created_at":"2016-10-31T12:32:15.192Z",
"push_events":true,
"tag_push_events":false,
2017-11-23 20:36:58 +00:00
"merge_requests_events": true,
2018-08-14 18:55:55 +00:00
"repository_update_events": true,
2016-10-19 14:08:30 +00:00
"enable_ssl_verification":true
}
2016-01-18 08:45:50 +00:00
]
```
2014-03-14 18:53:43 +00:00
## Test system hook
2020-02-29 03:07:51 +00:00
```plaintext
2014-03-14 18:53:43 +00:00
GET /hooks/:id
```
2016-01-18 08:45:50 +00:00
| Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- |
| `id` | integer | yes | The ID of the hook |
2014-03-14 18:53:43 +00:00
2016-01-24 19:19:46 +00:00
Example request:
2020-01-30 15:09:15 +00:00
```shell
2020-05-28 00:08:37 +00:00
curl --header "PRIVATE-TOKEN: < your_access_token > " "https://gitlab.example.com/api/v4/hooks/2"
2016-01-18 08:45:50 +00:00
```
Example response:
2014-03-14 18:53:43 +00:00
```json
{
2016-01-18 08:45:50 +00:00
"project_id" : 1,
"owner_email" : "example@gitlabhq.com",
"owner_name" : "Someone",
"name" : "Ruby",
"path" : "ruby",
"event_name" : "project_create"
2014-03-14 18:53:43 +00:00
}
```
## Delete system hook
2016-11-24 17:28:52 +00:00
Deletes a system hook.
2016-01-24 19:19:46 +00:00
2020-02-29 03:07:51 +00:00
```plaintext
2014-03-14 18:53:43 +00:00
DELETE /hooks/:id
```
2016-01-18 08:45:50 +00:00
| Attribute | Type | Required | Description |
| --------- | ---- | -------- | ----------- |
| `id` | integer | yes | The ID of the hook |
2016-01-24 19:19:46 +00:00
Example request:
2020-01-30 15:09:15 +00:00
```shell
2020-05-28 00:08:37 +00:00
curl --request DELETE --header "PRIVATE-TOKEN: < your_access_token > " "https://gitlab.example.com/api/v4/hooks/2"
2019-07-15 01:04:35 +00:00
```