Skip to main content

RCS Message

Send RCS messages with Messente's Omnichannel API.

RCS account setup required

Sending RCS messages requires us to prepare your account with a dedicated RCS setup. For more details, contact us at support@messente.com.

tip

The easiest way to use Omnichannel API is with our official libraries. Libraries will take care of authentication, request validation and response handling.


Send an RCS Message

Use the following example to send a simple RCS text message using Omnichannel API.

from pprint import pprint
from messente_api import (
OmnimessageApi,
Omnimessage,
Configuration,
ApiClient,
Rcs,
OmnimessageMessagesInner,
)
from messente_api.rest import ApiException


configuration = Configuration(
username="YOUR_MESSENTE_API_USERNAME",
password="YOUR_MESSENTE_API_PASSWORD",
)

api_instance = OmnimessageApi(ApiClient(configuration))

# Build the RCS message payload
rcs = Rcs(
sender='<sender name (optional)>',
text="hello, world!"
)
omnimessage = Omnimessage(
to='<recipient_phone_number>',
messages=[OmnimessageMessagesInner(rcs)],
)

try:
# Send the omnimessage
response = api_instance.send_omnimessage(omnimessage)
print(
"Successfully sent Omnimessage with id: %s that consists of the following messages:"
% response.omnimessage_id
)
for message in response.messages:
pprint(message)
except ApiException as exception:
print("Exception while sending the Omnimessage: %s\n" % exception)

Response

The API will return a response with an omnimessage_id, as well as a message_id for each "sub-message" (fallback channel). You can use these IDs to track the delivery status of the message.

{
"messages": [
{
"channel": "rcs",
"message_id": "fr593ce7-68de-5e44-bc50-044a3ad0a7fa",
"sender": "SENDER_ID"
}
],
"omnimessage_id": "632c6f3d-49d0-4a8f-5k2n-74023d31e51d",
"to": "RECIPIENT_PHONE_NUMBER"
}

Error example

{
"errors": [
{
"code": "105",
"detail": "Invalid or disallowed sender",
"source": "payload[rcs][sender]",
"title": "Invalid data"
}
]
}
titleError message
detailLonger description of the error message
sourceLocation in the request body for this error message
codeMachine-readable error code: 101 - Not found 102 - Forbidden 103 - Unauthorized 104 - Internal Server Error 105 - Invalid data 106 - Missing data 107 - Method not allowed