Skip to contentSkip to navigationSkip to topbar
On this page

Webhook Configuration Resource


The Webhook Configuration resource allows you to precisely control the effects of account-scoped webhooks. Sending a POST request to the Webhook Configuration endpoint is equivalent to configuring session webhooks in the Twilio Console(link takes you to an external page).

Good applications of the configured webhooks in Conversations include:

  • Implementing an archival system for all Conversations
  • Feeding messages into Elasticsearch
  • Implementing a profanity filter across all Conversations

Note: You can send pre-hooks and post-hooks to different targets.

Our guide to Conversations Webhooks includes the specific pre- and post-event webhooks that fire, as well as the webhook payloads.


Webhook Properties

webhook-properties page anchor
Property nameTypeRequiredDescriptionChild properties
account_sidSID<AC>Optional
Not PII

The unique ID of the Account responsible for this conversation.

Pattern: ^AC[0-9a-fA-F]{32}$Min length: 34Max length: 34

methodenum<string>Optional

The HTTP method to be used when sending a webhook request.

Possible values:
GETPOST

filtersarray[string]Optional

The list of webhook event triggers that are enabled for this Service: onMessageAdded, onMessageUpdated, onMessageRemoved, onConversationUpdated, onConversationRemoved, onParticipantAdded, onParticipantUpdated, onParticipantRemoved


pre_webhook_urlstringOptional

The absolute url the pre-event webhook request should be sent to.


post_webhook_urlstringOptional

The absolute url the post-event webhook request should be sent to.


targetenum<string>Optional

The routing target of the webhook. Can be ordinary or route internally to Flex

Possible values:
webhookflex

urlstring<uri>Optional

An absolute API resource API resource URL for this webhook.


Fetch a ConfigurationWebhook resource

fetch-a-configurationwebhook-resource page anchor
GET https://conversations.twilio.com/v1/Configuration/Webhooks

FETCH: Retrieve a Webhook Configuration ResourceLink to code sample: FETCH: Retrieve a Webhook Configuration Resource
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function fetchConfigurationWebhook() {
11
const webhook = await client.conversations.v1.configuration
12
.webhooks()
13
.fetch();
14
15
console.log(webhook.accountSid);
16
}
17
18
fetchConfigurationWebhook();

Output

1
{
2
"account_sid": "ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
3
"pre_webhook_url": "https://example.com/pre",
4
"post_webhook_url": "https://example.com/post",
5
"method": "GET",
6
"filters": [
7
"onMessageSend",
8
"onConversationUpdated"
9
],
10
"target": "webhook",
11
"url": "https://conversations.twilio.com/v1/Configuration/Webhooks"
12
}

Update a ConfigurationWebhook resource

update-a-configurationwebhook-resource page anchor
POST https://conversations.twilio.com/v1/Configuration/Webhooks

Request body parameters

request-body-parameters page anchor
Encoding type:application/x-www-form-urlencoded
SchemaExample
Property nameTypeRequiredDescriptionChild properties
MethodstringOptional

The HTTP method to be used when sending a webhook request.


Filtersarray[string]Optional

The list of webhook event triggers that are enabled for this Service: onMessageAdded, onMessageUpdated, onMessageRemoved, onConversationUpdated, onConversationRemoved, onParticipantAdded, onParticipantUpdated, onParticipantRemoved


PreWebhookUrlstringOptional

The absolute url the pre-event webhook request should be sent to.


PostWebhookUrlstringOptional

The absolute url the post-event webhook request should be sent to.


Targetenum<string>Optional

The routing target of the webhook.

Possible values:
webhookflex
1
// Download the helper library from https://www.twilio.com/docs/node/install
2
const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";
3
4
// Find your Account SID and Auth Token at twilio.com/console
5
// and set the environment variables. See http://twil.io/secure
6
const accountSid = process.env.TWILIO_ACCOUNT_SID;
7
const authToken = process.env.TWILIO_AUTH_TOKEN;
8
const client = twilio(accountSid, authToken);
9
10
async function updateConfigurationWebhook() {
11
const webhook = await client.conversations.v1.configuration
12
.webhooks()
13
.update({
14
filters: ["onConversationUpdated", "onMessageRemoved"],
15
method: "POST",
16
postWebhookUrl: "https://company.com/archive-every-action",
17
preWebhookUrl: "https://company.com/filtering-and-permissions",
18
});
19
20
console.log(webhook.accountSid);
21
}
22
23
updateConfigurationWebhook();

Output

1
{
2
"account_sid": "ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
3
"pre_webhook_url": "https://company.com/filtering-and-permissions",
4
"post_webhook_url": "https://company.com/archive-every-action",
5
"method": "POST",
6
"filters": [
7
"onConversationUpdated"
8
],
9
"target": "webhook",
10
"url": "https://conversations.twilio.com/v1/Configuration/Webhooks"
11
}