Skip to contentSkip to navigationSkip to topbar
Rate this page:
On this page

Track the Message Status of Outbound Messages


This guide shows you how to use Twilio's status callbacks to track changes of the message status of outbound messages you send with Programmable Messaging.

Message status changes occur throughout the lifecycle of a message from creation, through sending, to delivery, and even read receipt for supporting messaging channels.

(information)

Info

The guide focuses on outbound messages created using the Message Resource of the Programmable Messaging REST API and covers the necessary considerations when using a Messaging Service.


Before you begin

before-you-begin page anchor

Before you dive into this guide, make sure you're familiar with the following:

Note: The code samples in this guide require some local setup steps. Select your language of choice below to learn how to set up your development environment.

Let's get started!


How to track outbound message status

how-to-track-outbound-message-status page anchor

Tracking the message status of an outbound message is a two-step process

  1. Set up a status callback endpoint

  2. Send a message with status callback URL


Step 1. Set up a status callback endpoint

step-1-set-up-a-status-callback-endpoint page anchor

In order to track the message status of an outbound message, you must first create an API endpoint that:

  • Is served under a publicly accessible URL, the status callback URL, and
  • Implements a status callback handler for Twilio's message status callback HTTP requests.
(warning)

Warning

A status callback URL must contain a valid hostname. Underscores are not allowed.

How you implement your status callback endpoint depends on your use case and technology preferences. This may mean you

  • Create and host a small web application to handle the requests in the programming language and framework of your choice
  • Add an additional new endpoint to your existing web application
  • Use a serverless framework like Twilio Serverless Functions .

How are status callback requests sent?

how-are-status-callback-requests-sent page anchor

Twilio sends status callback requests as HTTP POST requests with a Content-Type of application/x-www-form-urlencoded.

(warning)

Warning

The properties included in Twilio's request to the StatusCallback URL vary by messaging channel and event type and are subject to change.

Twilio occasionally adds new properties without advance notice.

When integrating with status callback requests, it is important that your implementation is able to accept and correctly run signature validation on an evolving set of parameters.

Twilio strongly recommends using the signature validation methods provided in the Helper Libraries and not implementing your own signature validation.

In a status callback request, Twilio provides a subset of the standard request properties, and additionally MessageStatus and ErrorCode. These properties are described in the table below.

PropertyDescription
MessageStatusThe status of the Message resource at the time the status callback request was sent.
ErrorCodeIf an error occurred (i.e. the MessageStatus is failed or undelivered), this property provides additional information about the failure.

For example, a status callback request sent when the Message resource for an outbound SMS changes status to sent, may contain the following content:


_10
"AccountSid": "ACxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
_10
"From": "+15017250604"
_10
"MessageSid": "SM1342fe1b2c904d1ab04f0fc7a58abca9"
_10
"MessageStatus": "sent"
_10
"SmsSid": "SM1342fe1b2c904d1ab04f0fc7a58abca9"
_10
"SmsStatus": "sent"

SMS/MMS

smsmms page anchor

For most SMS/MMS Messages that have a Status of delivered or undelivered, Twilio's request to the StatusCallback URL contains an additional property:

PropertyDescription
RawDlrDoneDateThis property is a passthrough of the Done Date included in the DLR (Delivery Receipt) that Twilio received from the carrier.

The value is in YYMMDDhhmm format.
  • YY is last two digits of the year (00-99)
  • MM is the two-digit month (01-12)
  • DD is the two-digit day (01-31)
  • hh is the two-digit hour (00-23)
  • mm is the two-digit minute (00-59).
Learn more on the "Addition of RawDlrDoneDate to Delivered and Undelivered Status Webhooks" Changelog page(link takes you to an external page).

WhatsApp and other messaging channels

whatsapp-and-other-messaging-channels page anchor

If the Message resource uses WhatsApp or another messaging channel, Twilio's request to the StatusCallback URL contains additional properties. These properties are listed in the table below.

PropertyDescription
ChannelInstallSidThe Installed Channel SID that was used to send this message
ChannelStatusMessageThe error message returned by the underlying messaging channel if Message delivery failed. This property is present only if the Message delivery failed.
ChannelPrefixThe channel-specific prefix identifying the messaging channel associated with this Message
EventTypeThis property contains information about post-delivery events. If the channel supports read receipts (currently WhatsApp only), this property's value is READ after the recipient has read the message.

Implement a status callback handler (simplified example)

implement-a-status-callback-handler-simplified-example page anchor
(information)

Info

You may want to explore how status callback requests behave before working through your actual implementation. A light-weight way to accomplish this goal is to use Twilio Serverless Functions and inspect the status callbacks in the Console using the Function Editor's debugging feature.

  1. Log into your Twilio Account
  2. If you do not already have a suitable Functions and Assets Service(link takes you to an external page) in your Console, you can create a new service for your status callback handler endpoint. Let's assume you created a new service under the name status-callback-prototyping .
  3. From your service go to the Functions Editor to Add a new Function e.g. under the path /message-status with the following handler code:

_10
// Log Status Callback requests
_10
_10
exports.handler = function(context, event, callback) {
_10
console.log("Invoked with: ", event);
_10
return callback(null, "OK");
_10
};

By default your new serverless function is created as a protected endpoint, which means Twilio Serverless performs signature validation to ensure only valid Twilio requests invoke your handler.

  1. Save the new function.
  2. Deploy your new serverless function by pressing Deploy All .
  3. Change the toggle control above the bottom-right corner logging window to Live logs on .
  4. Click on the Copy URL link above the bottom-right logging window to copy the URL for your prototype status callback endpoint into your clipboard. The copied URL would look something like this: https://status-callback-prototyping-1234.twil.io/message-status .

You can now use your copied status callback URL in the next step of this guide: Step 2. Send a message with status callback URL.

  1. Once you sent a message, you can inspect the logged status callback request in the bottom-right logging window of the Functions Editor in Console.
Serverless Functions Status Callback - Functions Editor.Rate this page:

Need some help?

Terms of service

Copyright © 2024 Twilio Inc.