How to send RCS messages with Ruby and Twilio
Time to read: 4 minutes
Rich Communication Services (RCS) is reshaping the way businesses and consumers interact, offering a modern messaging experience that combines the reliability of SMS with the interactive features of popular messaging apps. Apple devices also now support RCS, as of the release of iOS 18. Developers around the globe are exploring how to integrate this cutting-edge channel into their applications.
In this tutorial, we’ll show you how to get started with RCS using Twilio and Ruby.
Comparing RCS to SMS and WhatsApp
RCS is revolutionizing the messaging landscape by combining the simplicity of SMS with the advanced features of modern apps like WhatsApp. With multimedia, verified sender profiles, and comprehensive engagement tracking support, RCS offers a rich, interactive experience—all without requiring an additional app download. For a deeper dive into how RCS stacks up against other messaging channels, check out the Guide to Rich Communication Services: What Developers Need to Know.
Implementing RCS with Twilio and Ruby
Getting started with RCS to test message sending is easy with Twilio. We’ll walk you through creating an RCS sender, creating a messaging service, and sending your first RCS message using Ruby.
Prerequisites
To get started, you will need the following:
Step 1: Create an RCS Sender
- Log in to the Twilio Console.
- Navigate to the Explore Products section and click RCS. • If RCS isn’t visible, you may need to request access here.
data:image/s3,"s3://crabby-images/55a79/55a796c8fff5572c02fc663f67542ea442e61d3b" alt="Software interface displaying various product options with a highlighted arrow pointing to RCS selection. Software interface displaying various product options with a highlighted arrow pointing to RCS selection."
data:image/s3,"s3://crabby-images/55a79/55a796c8fff5572c02fc663f67542ea442e61d3b" alt=""
3. In the side panel, navigate to the Senders section.
4. Click Create new sender.
data:image/s3,"s3://crabby-images/10369/1036907ad0b9e2258c7dce7e9e79e752bd73a3c8" alt="Web dashboard on a senders management page with an option to create a new sender. Web dashboard on a senders management page with an option to create a new sender."
data:image/s3,"s3://crabby-images/10369/1036907ad0b9e2258c7dce7e9e79e752bd73a3c8" alt=""
data:image/s3,"s3://crabby-images/c216d/c216deb469ed172a61c48f08a211b7d206ed00d8" alt="A screenshot showing the process of creating a new sender in an email platform. A screenshot showing the process of creating a new sender in an email platform."
data:image/s3,"s3://crabby-images/c216d/c216deb469ed172a61c48f08a211b7d206ed00d8" alt=""
Step 2: Add Profile Information
Next, you’ll add profile information for your RCS sender. Use the following:
- Sender display name: Choose a recognizable name for your sender. Usually, this is your brand name. For our example, we will use “My First RCS Sender”.
- Description: Describe your brand. This description will be displayed just under your display name at the top of your user’s RCS interactions.
- Border color: Keep in mind the minimum contrast ratio. For testing purposes, start with
#000000
to keep it simple. - Logo: Your brand logo should meet the following requirements:
• Dimensions: 224x224 pixels
• File size: Max 50 KB
• Image type: JPEG/JPG/PNG
• For testing, you can use this example image:https://corn-lobster-7338.twil.io/assets/twiliodevs-logo-rcs.png
- Banner: Your brand banner should meet the following requirements:
• Dimensions: 1440x448 pixels
• File size: Max 200KB
• Image type: JPEG/JPG/PNG
• For testing, you can use this example image:https://corn-lobster-7338.twil.io/assets/twiliodevs-banner-rcs.png
- Contact Details - Phone number: A phone number associated with your RCS sender is required. Optionally, you can also add an email address.
- Link to privacy policy and Link to terms of service: For testing purposes, you can enter links to arbitrary information here. When you begin building for production usage, make sure to create an RCS sender with real information about your business.
data:image/s3,"s3://crabby-images/3e32b/3e32b046ceba11fae6ca4eacf0956bdc5ac25c77" alt="Screenshot of Twilio profile creation screen with fields for username and avatar, plus a phone preview. Screenshot of Twilio profile creation screen with fields for username and avatar, plus a phone preview."
data:image/s3,"s3://crabby-images/3e32b/3e32b046ceba11fae6ca4eacf0956bdc5ac25c77" alt=""
Step 3: Test Your RCS Sender
- On the optional Test tab, click Add device to test this sender.
data:image/s3,"s3://crabby-images/e1ce3/e1ce329cda666f4d5012b4aa77cd005dfcf7c8bb" alt="Screen showing Twilio interface for confirming sender with brand information and adding phone as test device. Screen showing Twilio interface for confirming sender with brand information and adding phone as test device."
data:image/s3,"s3://crabby-images/e1ce3/e1ce329cda666f4d5012b4aa77cd005dfcf7c8bb" alt=""
2. Enter the phone number of your RCS-capable device and click Invite.
3. You should receive an opt-in message from Twilio’s RCS agent on your device.
4. Confirm the opt-in on your device by selecting Make me a tester.
5. Check the dialog box in the Twilio Console, and send a test message.
data:image/s3,"s3://crabby-images/47854/47854d547cd921ac4a56a67ca858875b1edc5c8c" alt="Instructions for Setting Up Your RCS Test Device Instructions for Setting Up Your RCS Test Device"
data:image/s3,"s3://crabby-images/47854/47854d547cd921ac4a56a67ca858875b1edc5c8c" alt=""
6. Celebrate—you’ve just sent your first RCS message!
data:image/s3,"s3://crabby-images/6ca82/6ca823a8bb1736ca48db01f0c56623b9e977713e" alt="Smartphone screen showing the first RCS message received from a Twilio sender. Smartphone screen showing the first RCS message received from a Twilio sender."
data:image/s3,"s3://crabby-images/6ca82/6ca823a8bb1736ca48db01f0c56623b9e977713e" alt=""
data:image/s3,"s3://crabby-images/83dd3/83dd3487a3febe302528311890c0cef1d4063239" alt="Twilio interface for creating a sender with a preview of the message on a mobile device. Twilio interface for creating a sender with a preview of the message on a mobile device."
data:image/s3,"s3://crabby-images/83dd3/83dd3487a3febe302528311890c0cef1d4063239" alt=""
Step 4: Create a Messaging Service
- In the Console, navigate to Messaging > Services.
- Click Create Messaging Service.
data:image/s3,"s3://crabby-images/93c67/93c67f821e64f9f9f08331619b173f6bc5e68b5b" alt="Browser window showing a web app interface for creating and managing messaging services. Browser window showing a web app interface for creating and managing messaging services."
data:image/s3,"s3://crabby-images/93c67/93c67f821e64f9f9f08331619b173f6bc5e68b5b" alt=""
data:image/s3,"s3://crabby-images/f0814/f081435e75c72e985ebaed04ef22516f1f1f2dba" alt="Browser window showing the setup process for a messaging service with fields for service name and usage. Browser window showing the setup process for a messaging service with fields for service name and usage."
data:image/s3,"s3://crabby-images/f0814/f081435e75c72e985ebaed04ef22516f1f1f2dba" alt=""
4. Add your RCS sender.
5. Click Add Sender, select RCS Sender.
data:image/s3,"s3://crabby-images/25068/25068d9db51ac2596140a19e688cde579a45d119" alt="User interface showing the process to add an RCS sender, with highlighted steps and guidance text. User interface showing the process to add an RCS sender, with highlighted steps and guidance text."
data:image/s3,"s3://crabby-images/25068/25068d9db51ac2596140a19e688cde579a45d119" alt=""
data:image/s3,"s3://crabby-images/c080c/c080c8ce744a3e5305aa949efe9138c123bc3be2" alt="Web interface screenshot for adding RCS senders with instructions to select the RCS agent highlighted. Web interface screenshot for adding RCS senders with instructions to select the RCS agent highlighted."
data:image/s3,"s3://crabby-images/c080c/c080c8ce744a3e5305aa949efe9138c123bc3be2" alt=""
data:image/s3,"s3://crabby-images/2b717/2b71765502aa7c8443730abf2f1058d602bf8514" alt="Screenshot of Sender Pool settings and integration steps in a web-based messaging service dashboard. Screenshot of Sender Pool settings and integration steps in a web-based messaging service dashboard."
data:image/s3,"s3://crabby-images/2b717/2b71765502aa7c8443730abf2f1058d602bf8514" alt=""
Step 5: (Optional) Set Up Webhook Integration
- Webhooks allow you to handle incoming messages in the same way as SMS or WhatsApp. Learn more in Twilio's docs about Incoming Message Webhooks.
- Use the Set Up Integration option to register a webhook. Feel free to reuse an existing one if available.
data:image/s3,"s3://crabby-images/c272f/c272fd7045dbd88605b739b8bb1542e25002697c" alt="Screenshot of Twilio integration settings page with an option to add a webhook and fallback URL. Screenshot of Twilio integration settings page with an option to add a webhook and fallback URL."
data:image/s3,"s3://crabby-images/c272f/c272fd7045dbd88605b739b8bb1542e25002697c" alt=""
Step 6: Send Your First RCS Message with Ruby
- Finish the wizard flow by clicking the white Skip setup button.
data:image/s3,"s3://crabby-images/b594a/b594adb0daecc7d591386ea88bb66ff7b89d6846" alt="Configuration wizard screen in Microsoft Azure with options for settings and a Skip button highlighted. Configuration wizard screen in Microsoft Azure with options for settings and a Skip button highlighted."
data:image/s3,"s3://crabby-images/b594a/b594adb0daecc7d591386ea88bb66ff7b89d6846" alt=""
2. Copy the Messaging Service SID (like MGe1fdfb207e9aa5b44f398b1094d88a8b
) from the Console.
data:image/s3,"s3://crabby-images/38d25/38d259fb8830c2ed04b8e91a998a18c657db383e" alt="Screenshot of Twilio Console showing steps to copy the messaging service SID from the Properties section. Screenshot of Twilio Console showing steps to copy the messaging service SID from the Properties section."
data:image/s3,"s3://crabby-images/38d25/38d259fb8830c2ed04b8e91a998a18c657db383e" alt=""
4. Create a file in your Ruby project folder called .env
. Add the credentials from the previous steps, so that your file looks like this:
6. Create a new file named sendRCS.rb
with the following code:
ruby sendRCS.rb
and see the result on your phone.data:image/s3,"s3://crabby-images/c3265/c32652490445c6dec760bcb5fee8cd94dfe1fd0e" alt="Smartphone screen showing an RCS message from My First RCS Sender on a dark grid background with a red hashtag. Smartphone screen showing an RCS message from My First RCS Sender on a dark grid background with a red hashtag."
data:image/s3,"s3://crabby-images/c3265/c32652490445c6dec760bcb5fee8cd94dfe1fd0e" alt=""
Explore Advanced RCS Features
Congratulations! You just sent your first RCS message using Ruby!
Business messaging with RCS opens up a whole new world of possibilities. If you’re looking for the next steps, start by exploring some of the other things you can do with your new capabilities:
- Extend your script to use the Content Template Builder for rich message content.
- Explore the Programmable Messaging Logs to see message statuses and troubleshoot any errors.
- Learn how to send OTP codes with RCS. With Twilio Verify, it’s easy to deliver secure and engaging one-time passwords to your users.
Twilio is continuously enhancing its RCS offering with features like failover for undelivered messages and quick reply buttons. Stay tuned for updates, and start building more engaging customer experiences today!
RCS is redefining how businesses connect with customers—combining the reliability of SMS with the interactivity of modern messaging apps. With Twilio, you can harness RCS to elevate your messaging strategy.
We can’t wait to see what you build!
Related Posts
Related Resources
Twilio Docs
From APIs to SDKs to sample apps
API reference documentation, SDKs, helper libraries, quickstarts, and tutorials for your language and platform.
Resource Center
The latest ebooks, industry reports, and webinars
Learn from customer engagement experts to improve your own communication.
Ahoy
Twilio's developer community hub
Best practices, code samples, and inspiration to build communications and digital engagement experiences.