ConnectorsSetup GuidesMessaging

Twilio Connector

Using Descope's connectors allows you to use Twilio to send SMS and make voice calls with your own Twilio account and trigger these actions within the authentication flow. This article will guide you through setting up and using the Twilio connector.

Configure Twilio connector

Descope uses your Twilio Account SID, Authentication token, API key, secret and sender details for integration.

To configure a Twilio connector, go to the Connectors page within the Descope Console, search for Twilio, and select the connector tile.

Settings

Below is a list of applicable settings for the Twilio connector.

  • Connector name: Custom name for your connector. This will come in handy when creating multiple connectors from the same connector template.
  • Connector Description: Briefly describe the purpose of this connector.
  • Account SID: A unique key provisioned for Twilio customers that acts as a username.
  • Authentication: There are two ways of authenticating with Twilio service:
    • Auth token: The authentication token associated with the Account SID.
    • API key and secret: The preferred way to authenticate to Twilio's services; consist of a SID and a secret.
  • From: There are two ways to define the sender of the message:
    • Phone Number: A Twilio number you own. Must start with a country code.
    • Messaging Service SID: If a messaging service is configured, one of the numbers in that service pool will be used. And if you'd like, the optional field:
  • From Phone number (for voice calls): A Twilio number you own. Defines the sender of the voice call. Must start with a + and country code.

You can test if your connector's configuration is working properly simply by hitting the Test button and viewing the Test Results panel.

Twilio connector initialization

Save your configuration by hitting Create.

Add your Twilio connector to a flow

Configure Twilio as the Default OTP Connector

To configure Twilio as your default connector for the various OTP auth methods for SMS and Voice, navigate to OTP within Authentication Methods, and select the configured Twilio connector. You can further configure the default OTP template for your Twilio messages; for more details, see our guide for Using Email and SMS Templates.

Once you have configured Twilio as the default connector within the OTP Auth method, Descope flows and any OTP calls via the API/SDK will utilize Twilio for OTP verification.

Configuring Twilio as the default OTP connector within Descope Authentication Methods

Using Twilio Explicitly in Flows

To override the default OTP connector within your flow to utilize Twilio, navigate to Flows and choose your flow. Once you are in the flow that you'd like to use Twilio, select and edit the action that starts the OTP process, such as Sign In, Sign Up, or Sign Up or In with OTP via SMS, Email, or Voice. If you have not yet added the OTP action, you can do so by clicking the blue + icon at the top left, searching and selecting the OTP action, and then selecting and editing the initiating action.

In this example, we will update the Sign Up or In / OTP / SMS action to utilize the Twilio connector and override the configured default for the OTP auth method.

Once in edit mode for the initiating OTP action, select the dropdown for the connector and choose your Twilio connector. After selecting the Twilio connector, click done, and save your flow. You can also select a customized template; for more details, see our guide for Using Email and SMS Templates. This action within your flow will utilize the Twilio connector and override the configured default OTP connector.

Configuring Twilio as the OTP connector to be used within Descope flow actions

Sending Custom Messages via Twilio in Flows

There may be a use case where you want to send a text message or voice message as part of your Descope flow that is not directly related to the OTP Auth flow; this section will describe how to use Twilio to send custom messages.

Navigate to: Flows, choose your flow. Then, tap the create button (designated via the + icon), select Connector, and choose Twilio.

Click to set down the connector in your flow editor and double click the action to add required fields:

  • To: Who the message or call should be sent to. Setting this dynamically based on previous attributes is recommended (eg. {{user.phone}}). As you type in the input field, options appear.
  • Message/Call content: Enter the content of the SMS or call.

Twilio connector widget input

Now, link your connector at a logical point in your authentication flow, likely at the end of the flow after the phone number has been submitted by the user.

Twilio connector placement

That's it! Whenever a user goes through your authentication flow, the Twilio connector will be automatically triggered.

Handling Twilio Blocked Calls/SMS

Twilio may block voice calls to certain numbers; this results in Twilio error code 21216. Essentially, the number is blocked by Twilio due to:

  • The destination has a high-risk of fraud
  • Due to regulatory reasons, the destination cannot be reached
  • You are placing a call to a +1 destination and your account is missing a Primary Customer Profile

Descope allows you to capture this returned error from Twilio and handle it how you would like. See the example image below; however, for further details on handling errors within flows, see this guide.

Handling Twilio blocking calls within flow errors

A similar error handling in Descope is also available for sms. In scenarios where a number has been blocked by twilio due to the reasons mentioned above, the error can be captured as a part of "SMS blocked by provider" and handled as required.

Handling Twilio blocking sms within flow errors

Was this helpful?

On this page