***
title: Webhook
'og:site\_name': Unleash Documentation
'og:title': Webhook
max-toc-depth: 2
slug: integrate/webhook
-----------------------
The Webhook Integration introduces a generic way to post messages from Unleash to third party services. Unleash allows you to define a webhook which listens for changes in Unleash and posts them to third party services.
The webhook will perform a single retry if the HTTP POST call fails (either a 50x or network error). Duplicate events may happen, and you should never assume events always comes in order.
## Configuration
#### Events
You can choose to trigger updates for the following events (we might add more event types in the future):
* feature-created
* feature-metadata-updated
* feature-project-change
* feature-archived
* feature-revived
* feature-strategy-update
* feature-strategy-add
* feature-strategy-remove
* feature-stale-on
* feature-stale-off
* feature-completed
* feature-environment-enabled
* feature-environment-disabled
* feature-variants-updated
* feature-tagged
* feature-untagged
* change-request-created
* change-request-discarded
* change-added
* change-discarded
* change-request-approved
* change-request-approval-added
* change-request-cancelled
* change-request-sent-to-review
* change-request-applied
* change-request-scheduled
* change-request-scheduled-application-success
* change-request-scheduled-application-failure
* change-request-schedule-suspended
* feature-potentially-stale-on
* feature-updated (deprecated in v4.3)
#### Parameters
Unleash Webhook integration takes the following parameters.
**Webhook URL** This is the only required property. If you are using a Slack Application you must also make sure your application is allowed to post the channel you want to post to.
**Content-Type** Used to set the content-type header used when unleash performs an HTTP POST to the defined endpoint.
**Body template** Used to override the body template used by Unleash when performing the HTTP POST. You may format you message using a [Mustache template](https://mustache.github.io). You will have the Unleash event format available in the rendering context:
Example:
```mustache
{
"event": "{{event.type}}",
"createdBy": "{{event.createdBy}}",
"featureToggle": "{{event.data.name}}",
"timestamp": "{{event.data.createdAt}}"
}
```
If you don't specify anything Unleash will use the Unleash event format:
#### Custom SSL certificates
If your webhook endpoint uses a custom SSL certificate,
you will need to start Unleash with the `NODE_EXTRA_CA_CERTS` environment variable set.
It needs to point to your custom certificate file in pem format.
For more information, see the [official Node.js documentation on setting extra certificate files](https://nodejs.org/api/cli.html#node_extra_ca_certsfile).