# Webhooks

Webhooks allow you to subscribe to events happening on the Didomi platform to implement custom workflows when your users change their consent preferences. When users make choices on your websites, mobile apps, or preferences center, you will receive a notification allowing you to react to user choices.

When an event is triggered, we'll send a HTTP POST payload to the configured webhook endpoint. Webhooks are configured at the organization level and automatically apply to all consent events triggered within your organization, on all websites, mobile apps, or preferences center.

{% hint style="warning" %}
The Webhooks are not yet compatible with a multi-regulation approach. At this moment in time, user consent will be associated with GDPR in the events that you receive.
{% endhint %}

## Configuration

Webhooks can be configured from the Didomi Marketplace. Once enabled, go to the *Manage* sub-section under the Marketplace to configure your webhook.

<figure><img src="https://1703900661-files.gitbook.io/~/files/v0/b/gitbook-x-prod.appspot.com/o/spaces%2F-LDh8ZWDZrXs8sc4QKEQ%2Fuploads%2Fgit-blob-0ae0e3e2627c8728a8cae941d44e97fa4a195760%2FCapture%20d%E2%80%99e%CC%81cran%202024-09-13%20a%CC%80%2015.40.53.jpg?alt=media" alt=""><figcaption><p>Didomi Marketplace</p></figcaption></figure>

Alternatively, you can reach out to our support team if you need further assistance. Provide the endpoint to send events to and, optionally, the OAuth credentials (client ID and client secret) to use.

To ensure that the consent events are received, when your endpoint is down, we retry at least five times during five minutes before moving on.

After the maximum amount of retries is reached, the event is placed in a permanent storage for later processing.

### Authentication

#### OAuth Access Token

Requests sent to your API endpoint can be authenticated via [OAuth Client Credentials grant](https://oauth.net/2/grant-types/client-credentials/).

The Didomi servers will authenticate against your OAuth authorization server with a Client ID and a Client Secret that you provide to obtain an Access Token.

Didomi will then call your API endpoint for sending events with the Access Token provided in the `Authorization` header as a Bearer token.

#### IP address

API calls from Didomi will originate from the IP `35.159.1.63` . You must whitelist that IP to allow traffic from it for events to be sent.

## Payload

Events sent to your HTTP endpoints are sent as JSON-encoded objects with the following information:

| Field      | Description                     | type     |
| ---------- | ------------------------------- | -------- |
| Event type | The type of event.              | `string` |
| Parameters | Entities affected by the event. | `object` |

## Events

| `Type`          | Description                                | `Parameters`                                                                                                                                                                                                                                                                                                                                                                                                        |
| --------------- | ------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| `event.created` | A new consent event has been created       | <ul><li><code>entity</code>: Created <a href="../../../api-and-platform/consents/events#event-schema">Event</a></li></ul>                                                                                                                                                                                                                                                                                           |
| `event.updated` | An existing consent event has been updated | <ul><li><code>source</code></li><li><code>old\_entity</code>: <a href="../../../api-and-platform/consents/events#event-schema">Event</a> before it gets updated</li><li><code>new\_entity</code>: <a href="../../../api-and-platform/consents/events#event-schema">Event</a> after the update</li></ul>                                                                                                             |
| `event.deleted` | An existing consent event has been deleted | <ul><li><code>entity</code>: Deleted <a href="../../../api-and-platform/consents/events#event-schema">Event</a></li></ul>                                                                                                                                                                                                                                                                                           |
| `user.created`  | A new user has been created                | <ul><li><code>entity</code>: Created <a href="../../../api-and-platform/consents/users#user-schema">User</a></li></ul>                                                                                                                                                                                                                                                                                              |
| `user.updated`  | An existing user has been updated          | <ul><li><code>source</code>: Event that triggered the <a href="../../../api-and-platform/consents/users#user-schema">User</a> update (if any)</li><li><code>old\_entity</code>: <a href="../../../api-and-platform/consents/users#user-schema">User</a> before it gets updated</li><li><code>new\_entity</code>: <a href="../../../api-and-platform/consents/users#user-schema">User</a> after the update</li></ul> |
| `user.deleted`  | An existing user has been deleted          | `entity`: Deleted [User](https://developers.didomi.io/api-and-platform/consents/users#user-schema)                                                                                                                                                                                                                                                                                                                  |

The payload is a JSON string in the body of the HTTP request. Examples:

```javascript
{
  "type": "user.updated",
  "parameters": {
    "source": {
      "id": "unique_event_id",
      "created_at": "2019-08-07T10:45:11Z",
      ...
    },
    "old_entity": {
      "id": "didomi_user_id",
      "organization_user_id": "organization_user_id",
      ...
    },
    "new_entity": {
      "id": "didomi_user_id",
      "organization_user_id": "organization_user_id",
      ...  
    }
  }
}
```

```javascript
{
  "type": "event.deleted",
  "parameters": {
    "entity": {
      "id": "deleted_event_id",
      "created_at": "2019-08-07T10:45:11Z",
      ...
    },
  }
}
```

### Filters

You can customize which events your webhook will receive by selecting the desired event types in the Didomi Marketplace. If no event types are selected, the webhook will receive **all** available events by default.

### Flatten request body

By enabling this option in the interface, your webhook payload will be transformed into a flat JSON object, simplifying property mapping depending on your webhook use case. Flattening converts a JSON object into a flat key-value format, where each key represents a property in the original JSON using a double underscore (`__`) as a separator. Currently, only the `entity` and `new_entity` properties are flattened, merging into a single `entity` property for simplicity.

**Example**

```json
// event.created (original)
{
  "type": "event.created",
  "parameters": {
    "entity": {
      "organization_id": "didomi",
      "user": {
        "id": "some_unique_id",
        "organization_user_id": "example@didomi.io"
      },
      "consents": {
        "purposes": [
          {
            "id": "geo_location",
            "enabled": true
          },
          {
            "id": "market_research",
            "enabled": true
          }
        ]
      }
    }
  }
}
```

```json
// event.created (Flattened)
{
  "type": "event.created",
  "parameters__entity__organization_id": "didomi",
  "parameters__entity__user__id": "some_unique_id",
  "parameters__entity__user__organization_user_id": "example@didomi.io",
  "parameters__entity__consents__purposes__geolocation_data__enabled": true,
  "parameters__entity__consents__purposes__market_research__enabled": true
}
```

### Pending events

Pending events (with status `pending_approval` or similar) are always sent as `event.created` webhooks.

However, new pending events only generate `user.created` events if a new user is created as a result of a pending event. If a pending event applies to an existing user, a `user.updated` event is **not generated** as the user is not effectively modified until the event becomes confirmed.

When a pending event becomes confirmed and, assuming it contains changes that effectively modify the status of the user, then and only then a `user.updated` event is sent.
