Skip to contentSkip to navigationSkip to topbar
On this page

Call Notification via Webhook


(warning)

Private Beta

The Call Notification via Webhook feature is currently available as a Private Beta product, and Twilio may change the information in this document at any time. This means that some features aren't yet implemented, and others may change before the product becomes Generally Available. Private Beta products aren't covered by a Service Level Agreement.


How incoming calls work now

how-incoming-calls-work-now page anchor

The Twilio Programmable Voice Android and iOS SDKs use platform push notifications, Firebase Cloud Messaging (FCM) for Android and Apple VoIP Service for iOS, for delivering incoming call notifications. The application developers need to provide their cloud messaging credentials or certificates to Twilio (stored as Push Credentials) to be used for authentication when Twilio sends the push notification delivery requests to FCM or APN. In order to receive incoming call push notifications, an app user needs to first register a push binding, which indicates the mobile client is active ready for incoming calls. Upon receiving the push notification, the application uses the Android Voice.handleMessage() method or the iOS TwilioVoiceSDK.handleNotification() method and passes the push notification payload. A call-invite-received callback event will be raised to the application so the user can choose to accept or reject the call.

There are a few limitations with the current solution:

  • Twilio Voice mobile SDK only supports FCM and Apple VoIP Service. Developers have been asking if they can use different types of push services, for example the regular APN notification for iOS, which does not share the PushKit-CallKit requirement as the Apple VoIP Service notification does, or even manage the delivery themselves.
  • Developers need to provide their cloud messaging service credentials to Twilio, which may raise concerns for the developers.
  • There is no API for client binding management. The only way to delete a binding created by the Voice mobile SDK is using the SDK Voice.unregister() method.
    • Developers sometimes receive Twilio notifications about push notification delivery failure because the information inside the bindings are longer valid, but cannot do much.
    • The application needs to be run on the specific device in order to retrieve the same device token used for creating the binding unless similar binding information (identity, device token, etc) is stored in the application's database.
    • Without a binding management API it's very difficult to perform batch binding CRUD operations.

New call notification via webhook

new-call-notification-via-webhook page anchor

We are introducing the new Call Notification Webhook feature. Once configured, the developer's webhook endpoint will receive incoming call notifications every time calls are made to the clients under their account. Application developers are responsible for delivering the call notifications to their clients, via the channels that are best suited for their application such as push notification or web socket.

Below are a few requirements on the application developers' side in order to adopt the feature:

  • Configure the webhook
  • Client "binding" management
  • Set up a webhook endpoint to handle call delivery requests

Webhook configuration

To create a default configuration with the webhook URL, consult the Voice Client Configuration Resource API reference.

Client binding management

In order to deliver call notifications to app users, the application developers should maintain a list of active clients. Each active client entry should contain:

  • Client identity: if the identity matches the call receiver identity inside the webhook request body, the app developer should send a notification to this client. Note that Twilio currently allows multiple client instances to have the same identity (under the same Twilio account). When a call is made to this client identity, all instances with the same identity should receive the call notification.
  • Twilio Account SID: the call notification sent from Twilio will indicate that the call is made for the clients under a specific Twilio account. Only client instances under this account should receive the call notification.
  • (Optional) Unique device identifier: depending on the delivery mechanism chosen by the application developer, there should be a unique identifier which can be associated with a specific device. For example, a device token for sending push notifications to an Android or iOS app.
  • (Optional) Unique binding identifier: makes it easier in case client binding information needs to be updated or deleted.

Webhook handler

An endpoint to receive HTTP POST requests with information about the call notification. The application endpoint should return a response:

  • 200 OK: client instance with matching identity and Twilio Account SID is found and call notification dispatched to the client.
  • 404 Not Found: no client with the same identity and Twilio Account SID can be found.

The body of the POST request consists of several key parameters of the call in JSON format:

1
{
2
"twi_account_sid": ACxxxx,
3
"twi_bridge_token": "eyJraxxxx",
4
"twi_call_sid": CAxxxx,
5
"twi_from": "client:alice",
6
"twi_message_id": WBxxxx,
7
"twi_message_type": "twilio.voice.call",
8
"twi_to": "client:bob"
9
}

Parameters:

ParameterDefinition
twi_account_sidThe Twilio Account SID used for generating this call.
twi_bridge_tokenAn encrypted token for the mobile client to connect back to the caller.
twi_call_sidThe Twilio Call SID.
twi_fromThe caller ID.
twi_toThe callee ID.
twi_message_idA unique ID associated with this webhook request.
twi_message_typeA string value "twilio.voice.call" indicating this notification is for an incoming call.
twi_params (optional)Custom parameters will be listed here as URL-encoded parameters when provided in the <Client> TwiML or REST Call API. Check out here(link takes you to an external page) for more information about custom parameters.

If bindings matching both the Account SID and the callee identity are found, deliver the JSON body directly, without modification, to the clients through the most suitable communication channel for the application's use case, such as push notifications or web sockets. The mobile application will then pass the payload to the Android Voice.handleMessage() method or the iOS TwilioVoiceSDK.handleNotification() method upon receiving the notification, just like how it works when Twilio sends the incoming call notifications via push notification, and an incoming call invite will be raised to the application for the user to answer.

Here's an example in Python for handling a webhook request and sending the notification payload to the mobile client via push notification:

1
from flask import Flask, request, Response
2
app = Flask(__name__)
3
4
@app.route("/calls/notificationWebhook", methods=["POST"])
5
def call_notification_webhook():
6
try:
7
notification_payload = request.json
8
except:
9
notification_payload = None
10
logging.error("error in parsing request form data as JSON: \n{}".format(sys.exc_info()[0]))
11
return Response(status=400, mimetype="text/plain")
12
13
# Get the callee identity
14
twilio_to = notification_payload["twi_to"]
15
twilio_to_components = twilio_to.split(':')
16
if len(twilio_to_components) == 2:
17
callee_client_identity = twilio_to_components[1]
18
else:
19
logging.error("error parsing the callee identity in twi_to")
20
callee_client_identity = None
21
22
# Get the Twilio Account SID
23
twilio_account_sid = notification_payload["twi_account_sid"]
24
25
if not callee_client_identity:
26
return Response("Invalid callee identity", status=400, mimetype="text/plain")
27
28
global binding_data
29
# Use the identity and account SID for binding lookup
30
bindings = binding_data.get_bindings_by_identity(callee_client_identity, twilio_account_sid)
31
32
if not len(bindings):
33
response = Response('Not found', status=404, mimetype="text/plain")
34
return response
35
36
for binding in bindings:
37
# Send a push notification to this client
38
notification_webhook_processor.notification_dispatch(binding, notification_payload)
39
40
response = Response(status=200, mimetype="text/plain")
41
return response
42

Need some help?

Terms of service

Copyright © 2025 Twilio Inc.