Skip to contentSkip to navigationSkip to topbar
On this page

Programmable Messaging RCS Onboarding Guide


(information)

Public Beta

Programmable Messaging RCS is currently available as a Public Beta product and the information contained in this document is subject to change.

Some features are not yet implemented, and others may be changed before the product is declared Generally Available (GA). Public Beta products are not covered by an SLA.

Rich Communication Services (RCS) is a modern messaging protocol that enhances traditional SMS and MMS by enabling branded, interactive messages. It streamlines communication by supporting features like a branded profile, read receipts, and rich content, all within a device's default messaging app. RCS is compatible with Android and iOS 18 devices.

This guide explains how to send RCS messages with Twilio Programmable Messaging. If you're already using Programmable Messaging with Messaging Services, no code changes are required to start sending RCS messages. Twilio automatically uses SMS or MMS as a fallback if RCS messages can't be delivered.

Support for using RCS without Messaging Services is coming soon.

Android device showing an RCS message with a branded sender and dynamic content.

Regional availability

regional-availability page anchor

See Regional Availability for a list of regions where RCS messages can be sent using Twilio Programmable Messaging, and any special requirements for each region.


Allow 2–4 weeks (or longer if launching in multiple regions) to complete the onboarding process after receiving RCS access. The following steps outline the process to set up and configure RCS messaging with Twilio.

Prerequisites

prerequisites page anchor

Complete these steps before starting the RCS onboarding process.

Required

required page anchor

Step 1: Request RCS access

step-1-request-rcs-access page anchor

First, request access to use RCS in Programmable Messaging. Complete the RCS request form(link takes you to an external page) with the required business and use case information. Twilio manually reviews the submission. The approval process duration can vary based on submission volume and the complexity of your request, but it typically takes a few days.

After your RCS access is granted, you will receive an email at the address provided in the request form with a link to begin RCS onboarding in the Twilio Console.

Step 2: Create an RCS Sender in the Twilio Console

step-2-create-an-rcs-sender-in-the-twilio-console page anchor

Next, create an RCS Sender in the Twilio Console. The RCS Sender represents both your messaging use case and the brand that is displayed to the recipient when you send an RCS message. RCS messages arrive from this named and verified sender instead of a phone number or alphanumeric sender. You can create multiple RCS Senders; however, they cannot be shared between Twilio Accounts.

After you create your RCS Sender in the Console, it is sent to both Twilio and Google RCS Business Messaging(link takes you to an external page) for approval. Twilio is a Google RCS Business Messaging partner, and you will not need to interact directly with Google during this process except to confirm your brand use via email in Step 3.

Navigate to the RCS Senders page(link takes you to an external page) in the Console to create your RCS Sender. During the creation process, you complete three sections: Profile Information, Test, and Compliance.

In this section, you construct your RCS Sender's branded profile. This profile is visible to recipients when you send RCS messages and includes elements like your brand name, logo, and a brief description. You can preview how your profile will appear to recipients as you input this information.

Dynamic preview generated during RCS Sender branded profile creation.

You can send a test message directly from the Console to an RCS-compatible device by providing its phone number. This allows you to preview your RCS Sender's look and feel before it is officially launched.

You can continue to add test devices and send test messages after the RCS Sender has been submitted for approval.

Here you provide information about your business and messaging use case to ensure compliance with carrier and RCS requirements. It consists of four steps: Select countries, Sender review, User interaction, and Authorized representative.

Sender review
sender-review page anchor

Provide either access instructions on how to test your RCS Sender or screenshots or video demonstrating your RCS Sender's core messaging functionality and opt-out flow. You can capture this flow by using the test device that was set up during Sender creation.

The Sender review is required to meet RCS and carrier compliance requirements, and providing detailed instructions and media can help expedite the approval process.

Submit your RCS Sender for approval

submit-your-rcs-sender-for-approval page anchor
(warning)

Warning

Before you complete the creation process, thoroughly review and test your RCS Sender. You cannot change your RCS Sender's profile via the Console once you submit your Sender.

Use the Save as Draft and Close button in the top-right corner of the Console to save your progress and return to it later.

Once you finalize your branded profile and compliance information, select Create in the Compliance section to submit your RCS Sender for approval. You cannot edit the information after submission and before approval, so ensure all details are accurate before selecting Create.

If you need to change your RCS Sender's profile after it's submitted, you must reach out to Twilio for assistance.

Step 3: Confirm RCS brand use with Google via email

step-3-confirm-rcs-brand-use-with-google-via-email page anchor

After you create your RCS Sender in the Twilio Console, you will receive an email in one to two days from the Google RCS Business Messaging Team with instructions on how to confirm your RCS brand use with Twilio. Follow the instructions in the email to confirm with Google so that Twilio can send RCS messages using your brand.

Step 4: Provide additional carrier compliance information to Twilio via email (if applicable)

step-4-provide-additional-carrier-compliance-information-to-twilio-via-email-if-applicable page anchor

Depending on what countries you selected during the RCS Sender creation process, you may need to provide additional compliance information to satisfy specific country carrier requirements. If applicable, you can expect an email from Twilio within 5–10 days of creating your RCS Sender requesting additional compliance information. Follow the instructions in the email to provide the required information.

Step 5: Configure the RCS Sender and Messaging Service

step-5-configure-the-rcs-sender-and-messaging-service page anchor

After the information submitted in Step 3 and Step 4 is reviewed, you will receive an email from Twilio confirming that your RCS Sender is approved and ready for configuration. You can also verify that the statuses of your RCS Sender's specific regions have moved from Under review to Active on the RCS Senders page(link takes you to an external page) in the Console.

Next, configure your RCS Sender in the Twilio Console by navigating to the RCS Senders page(link takes you to an external page) and selecting the RCS Sender. This opens the Sender Settings screen. Select Configuration and fill in the required details about the RCS Sender's Messaging Service and optional endpoint configuration.

You must configure your RCS Sender to use a new or existing Messaging Service. You can view your existing Services on the Messaging Services page(link takes you to an external page) in the Console.

Only one RCS Sender can be associated with a Messaging Service. The Service attempts to use the RCS Sender first for all messages it sends. If the recipient's device cannot receive RCS messages from this Sender, then Twilio will use a fallback SMS Sender.

For SMS fallback, Twilio will first select the short code, followed by the alphanumeric sender, followed by the long code. Alphanumeric senders aren't supported by MMS and won't be selected for MMS fallback. Learn more.

Select Save configuration to save your changes.

Step 6: Configure and enable Advanced Opt-Out

step-6-configure-and-enable-advanced-opt-out page anchor

Now that you have a Messaging Service identified for your RCS Sender, you should configure and enable Advanced Opt-Out for that Service in order to meet compliance standards. Advanced Opt-Out allows you to customize the keywords and responses for opt-out, opt-in, and help messages for your RCS Sender.

You must provide a valid opt-out keyword in the local language of the regions where you are sending RCS messages, and send an opt-out confirmation message to the recipient.

To set up Advanced Opt-Out for a Messaging Service, navigate to the Messaging Services page(link takes you to an external page) in the Console. Select the Messaging Service associated with your RCS Sender and then select Opt-Out Management from the left-hand sidebar. Complete the configuration on this page, and select Enable Advanced Opt-Out. Once you enable these settings, Twilio applies these changes to all Senders in your Messaging Service's Sender Pool.

See Customizing Users' Opt-in and Opt-out Experience with Advanced Opt-Out for more information on the Advanced Opt-Out feature.

(information)

Info

If Advanced Opt-Out isn't configured for your Messaging Service, Twilio's default opt-out solution will take effect, responding with a generic opt-out message when users reply to standard English keywords such as STOP, STOPALL, UNSUBSCRIBE, CANCEL, END, or QUIT.


After completing the setup and configuration steps above, you can send RCS messages using the Programmable Messaging Create a Message resource. Programmable Messaging proactively checks if the recipient's device can support RCS and sends the message using SMS as a fallback if needed.

To send an RCS message, include your Messaging Service's SID in the API request using either the MessagingServiceSid or From parameter. See below for examples using each option.

Use the MessageServiceSid parameter

use-the-messageservicesid-parameter page anchor

You can set the MessagingServiceSid parameter in the API request to the Messaging Service SID assigned to your RCS Sender, shown as MGXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX in the code sample below. To find your Messaging Service's SID, check the Sid column on the Messaging Services page(link takes you to an external page) in the Console.

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 createMessage() {
11
const message = await client.messages.create({
12
body: "My first RCS message. Hello, world!",
13
messagingServiceSid: "MGXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
14
to: "+155XXXXXXXX",
15
});
16
17
console.log(message.body);
18
}
19
20
createMessage();

Output

1
{
2
"account_sid": "ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
3
"api_version": "2010-04-01",
4
"body": "My first RCS message. Hello, world!",
5
"date_created": "Thu, 24 Aug 2023 05:01:45 +0000",
6
"date_sent": "Thu, 24 Aug 2023 05:01:45 +0000",
7
"date_updated": "Thu, 24 Aug 2023 05:01:45 +0000",
8
"direction": "outbound-api",
9
"error_code": null,
10
"error_message": null,
11
"from": "+14155552345",
12
"num_media": "0",
13
"num_segments": "1",
14
"price": null,
15
"price_unit": null,
16
"messaging_service_sid": "MGXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
17
"sid": "SMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
18
"status": "queued",
19
"subresource_uris": {
20
"media": "/2010-04-01/Accounts/ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Messages/SMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Media.json"
21
},
22
"tags": {
23
"campaign_name": "Spring Sale 2022",
24
"message_type": "cart_abandoned"
25
},
26
"to": "+155XXXXXXXX",
27
"uri": "/2010-04-01/Accounts/ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Messages/SMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.json"
28
}

You can set the From parameter in the API request to the Messaging Service SID assigned to your RCS Sender, shown as MGXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX in the code sample below. To find your Messaging Service's SID, check the Sid column on the Messaging Services page(link takes you to an external page) in the Console.

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 createMessage() {
11
const message = await client.messages.create({
12
body: "My first RCS message. Hello, world!",
13
from: "MGXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
14
to: "+155XXXXXXXX",
15
});
16
17
console.log(message.body);
18
}
19
20
createMessage();

Output

1
{
2
"account_sid": "ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
3
"api_version": "2010-04-01",
4
"body": "My first RCS message. Hello, world!",
5
"date_created": "Thu, 24 Aug 2023 05:01:45 +0000",
6
"date_sent": "Thu, 24 Aug 2023 05:01:45 +0000",
7
"date_updated": "Thu, 24 Aug 2023 05:01:45 +0000",
8
"direction": "outbound-api",
9
"error_code": null,
10
"error_message": null,
11
"from": "MGXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
12
"num_media": "0",
13
"num_segments": "1",
14
"price": null,
15
"price_unit": null,
16
"messaging_service_sid": "MGaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
17
"sid": "SMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
18
"status": "queued",
19
"subresource_uris": {
20
"media": "/2010-04-01/Accounts/ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Messages/SMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Media.json"
21
},
22
"tags": {
23
"campaign_name": "Spring Sale 2022",
24
"message_type": "cart_abandoned"
25
},
26
"to": "+155XXXXXXXX",
27
"uri": "/2010-04-01/Accounts/ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Messages/SMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.json"
28
}

Send an RCS message containing media

send-an-rcs-message-containing-media page anchor

You can send messages containing RCS-supported media formats using the MediaUrl field, and Twilio will automatically attempt delivery over RCS. Unsupported media formats may fallback to MMS. Devices that aren't RCS-capable will receive the message via MMS in supported regions(link takes you to an external page), and Picture SMS(link takes you to an external page) elsewhere. The combination of text and media over RCS is supported for image and video files only.

RCS supports a maximum message size of 16 MB. However, when sending an RCS message that requires fallback to MMS, message sizes exceeding the MMS limit of 5 MB will be rejected.

To send an RCS message with media, you must include the MediaUrl parameter as well as your MessageServiceSid in the API request. RCS supports a single MediaUrl field per API request.

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 createMessage() {
11
const message = await client.messages.create({
12
from: "MGXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
13
mediaUrl: [
14
"https://c1.staticflickr.com/3/2899/14341091933_1e92e62d12_b.jpg",
15
],
16
to: "+155XXXXXXXX",
17
});
18
19
console.log(message.body);
20
}
21
22
createMessage();

Output

1
{
2
"account_sid": "ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
3
"api_version": "2010-04-01",
4
"body": "Hello! 👍",
5
"date_created": "Thu, 24 Aug 2023 05:01:45 +0000",
6
"date_sent": "Thu, 24 Aug 2023 05:01:45 +0000",
7
"date_updated": "Thu, 24 Aug 2023 05:01:45 +0000",
8
"direction": "outbound-api",
9
"error_code": null,
10
"error_message": null,
11
"from": "MGXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX",
12
"num_media": "0",
13
"num_segments": "1",
14
"price": null,
15
"price_unit": null,
16
"messaging_service_sid": "MGaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
17
"sid": "SMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
18
"status": "queued",
19
"subresource_uris": {
20
"media": "/2010-04-01/Accounts/ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Messages/SMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Media.json"
21
},
22
"tags": {
23
"campaign_name": "Spring Sale 2022",
24
"message_type": "cart_abandoned"
25
},
26
"to": "+155XXXXXXXX",
27
"uri": "/2010-04-01/Accounts/ACaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/Messages/SMaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.json"
28
}

When users send messages to your RCS Sender, you can see those messages in your Programmable Messaging Logs page(link takes you to an external page). You can also configure your Messaging Service to send a webhook when it receives an incoming message.

To stop using RCS, you can either send messages through a different Messaging Service or remove the RCS Sender from the Messaging Service.

To remove the RCS Sender from the Messaging Service, navigate to the Messaging Services page(link takes you to an external page) in the Console. Select the Messaging Service associated with your RCS Sender and then select Sender Pool from the left-hand sidebar. Use the Remove button to remove the RCS Sender from the Messaging Service.

Monitor and analyze RCS traffic

monitor-and-analyze-rcs-traffic page anchor

After sending RCS messages, you can monitor and analyze your RCS traffic using different tools such as Programmable Messaging Logs(link takes you to an external page) and Messaging Insights.

You can also perform A/B testing between RCS and other channels to compare their effectiveness.

The primary indicator that a message was sent with RCS is the From field containing rcs:<SenderId>. This field is visible in Programmable Messaging Logs(link takes you to an external page), outbound message status callbacks, and Fetch a Message resource request results.

Check the Programmable Messaging Logs page(link takes you to an external page) in the Console for a detailed record of each RCS message request. To filter and view logs for RCS messages only, set the From field to rcs:.

RCS messages can have the following statuses:

  • Accepted
  • Queued
  • Sent
  • Delivered
  • Undelivered
  • Read

If you don't see a log for your message, the message likely encountered an error in your application or potentially with Twilio's API. You can view errors on the Error Logs page(link takes you to an external page) in the Console.

Messaging Insights and dashboards

messaging-insights-and-dashboards page anchor

RCS messages are automatically included in Messaging Insights analytics. Messaging Insights allow you to quickly assess your application's messaging activities, identify and debug issues, optimize delivery, monitor fraud protection, and find areas to boost engagement.

Messaging Insights real-time dashboards display delivery metrics, engagement metrics, and more for your messages. You can find the dashboards in the Twilio Console under Monitor > Insights > Messaging(link takes you to an external page). To view RCS metrics only, filter the dashboards so that the Channel field equals RCS.

Messaging Insights dashboard showing delivery status graph with 7 failed and 3 read RCS messages.

A/B testing RCS and SMS/MMS

ab-testing-rcs-and-smsmms page anchor

In many regions, RCS tracks "delivered" and "read" statuses more reliably than SMS does. For this reason, we recommend using other metrics such as clicks or conversions when A/B testing the two channels.

Need some help?

Terms of service

Copyright © 2025 Twilio Inc.