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

Make an outbound phone call via REST API in a non-US Twilio Region


This guide will show you how to make an outbound Call using the Twilio REST API in a Region other than the default, United States (US1) Region.

The examples in this guide will use the Ireland (IE1) Region.

Please ensure that you understand the basic concepts involved in Making Calls and using Twilio Regions before reading this guide.


Step 1: Setup

step-1-setup page anchor

Before proceeding, make sure that you have the following items handy:

See this guide(link takes you to an external page) for help finding and purchasing a Twilio phone number.

Next, you'll need a Twilio API Key that is valid in the target Region.

Twilio API Keys are a Region-specific resource. In order to interact with the API in the IE1 Region, you need to use an API Key which exists in that Region (rather than an API Key you created in the default US1 Region, for example). Refer to the Twilio Regions overview for more information about the Region isolation model.

Follow these steps to create an API Key for the IE1 Region using the Twilio Console:

  1. Log into the Twilio Console(link takes you to an external page) .
  2. Click the Account menu in the upper right corner of the screen.
  3. Click API keys , under the Keys & Credentials heading.
  4. Select the "Ireland (IE1)" option from the Region menu.
  5. Click the blue Create API key button.
  6. Enter a friendly name for the key (example: "Regional Calls Quickstart").
  7. Leave Key type on the default option, "Standard".
  8. Click the blue Create API Key button.

Take note of the API Key's SID and secret for use in the next step.


Step 2: Make a request to the Calls endpoint

step-2-make-a-request-to-the-calls-endpoint page anchor

The Twilio REST API operates on a per-Region basis. When making requests to the API, it's up to you to select which Region will handle the request. Whichever Region you choose will be the Region that processes and stores data related to the request.

If you don't specify a target Region for a request, the request will be handled in the default US1 Region.

To specify a target Region for a request, you will include the name of the target Region in the request's hostname, also known as the fully qualified domain name (FQDN)(link takes you to an external page).

The Twilio API's FQDN format

the-twilio-apis-fqdn-format page anchor

The FQDN format follows a convention that encodes three pieces of information in the hostname:

  1. The Twilio Product
  2. The target Edge Location
  3. The target Region

The format of an FQDN is:

{product}.{edge-location}.{region}.twilio.com

Some example FQDNs targeting API products in different Regions (through various Edge Locations) include:

FQDNTarget Region
studio.sydney.au1.twilio.comAustralia (AU1) Region
events.ashburn.us1.twilio.comUnited States (US1) Region
messaging.dublin.ie1.twilio.comIreland (IE1) Region
(warning)

Warning

Note: Legacy FQDNs which do not include the Edge Location and Region (e.g. video.twilio.com) are implicitly routed to the US1 Region through the ashburn Edge Location.

In this example, you'll be making a POST request to the Call resource endpoint to create a Call. This endpoint is a part of Twilio's core API product. You will select the dublin Edge Location, and the IE1 processing Region.

Thus, the FQDN you need to use is:

api.dublin.ie1.twilio.com

(information)

Info

As we'll discuss in Step 3 of this guide, you can use the Twilio helper libraries for making API requests to a target Region. Helper libraries accept an edge and region parameter, and automatically construct the appropriate FQDN for API requests.

Issue the API request with cURL

issue-the-api-request-with-curl page anchor

If you use a MacOS or Linux operating system, you can follow these instructions to issue the request using the cURL command line utility. Otherwise, please continue to read along, since this section contains important information.

First, set some environment variables containing data that will be referenced by the curl command you run later. This practice prevents us from needing to include sensitive data directly in shell commands, and has the added benefit of making our curl command copy/pasteable without needing to adjust any placeholder values.

Create a new file named .env, and add the following content, using your own Account SID, API Key SID, and API Key secret:


_10
export ACCOUNT_SID=<your_account_sid_here>
_10
export API_KEY_SID=<your_api_key_sid_here>
_10
export API_KEY_SECRET=<your_api_key_secret_here>

Next, add E.164 formatted(link takes you to an external page) phone number values for the To and From number of the phone call that you want to make. Be sure to use a From number that is either a Twilio phone number you own, or a verified phone number associated with your Twilio account.


_10
export TO_NUMBER=<your_to_number_here>
_10
export FROM_NUMBER=<your_from_number_here>

Save the file, and run the source command in a terminal to set the file's values as variables in your shell session:


_10
source .env

Confirm that the variables are set by echoing one of them:


_10
echo $TO_NUMBER

The shell should print the value of the To number that you set in the .env file.

Run the following command to issue the API request.


_10
curl -X POST \
_10
-u $API_KEY_SID:$API_KEY_SECRET \
_10
https://api.dublin.ie1.twilio.com/2010-04-01/Accounts/$ACCOUNT_SID/Calls.json \
_10
--data-urlencode "To=$TO_NUMBER" \
_10
--data-urlencode "From=$FROM_NUMBER" \
_10
--data-urlencode "Twiml=<Response><Say>Ahoy from Ireland</Say></Response>"

The command should print a JSON representation of the new Call, and the destination phone should now be ringing.

Congratulations, you've successfully created a Call using a non-US1 Twilio Region!

Keep in mind that this Call will only exist in the Region where it was created — IE1 in this case. In order to view the Call log in the Twilio Console, for example, you'll need to access the IE1-specific Call Logs(link takes you to an external page) page. Refer to the Twilio Regions introduction for a refresher on Twilio's Region isolation model.


Step 3 (optional): Issue the API request with a server-side helper library

step-3-optional-issue-the-api-request-with-a-server-side-helper-library page anchor

Real applications are unlikely to make API requests using cURL, and will instead be using an HTTP client appropriate for the application's programming language. A common choice is to use one of Twilio's language-specific server-side helper libraries.

These libraries make it easy to issue requests against a target Region, simply by setting a region attribute on a client instance.

For example, using one of the helper libraries, a request equivalent to the one sent using the curl command in the previous step could be sent using the following language-specific code:

Specify a Twilio Region and Edge when making a call

specify-a-twilio-region-and-edge-when-making-a-call page anchor
Node.js
Python
C#
Java
Go
PHP
Ruby

_21
const accountSid = process.env.ACCOUNT_SID;
_21
const apiKeySid = process.env.API_KEY_SID;
_21
const apiKeySecret = process.env.API_KEY_SECRET;
_21
_21
const toNumber = process.env.TO_NUMBER;
_21
const fromNumber = process.env.FROM_NUMBER;
_21
_21
const client = require('twilio')(
_21
apiKeySid,
_21
apiKeySecret, {
_21
accountSid: accountSid,
_21
edge: 'dublin',
_21
region: 'ie1'
_21
});
_21
_21
client.calls
_21
.create({
_21
twiml: '<Response><Say>Ahoy from Ireland</Say></Response>',
_21
to: toNumber,
_21
from: fromNumber
_21
});


Now that you know the basics of making Calls via a specific Twilio Region using the REST API, check out these other resources to learn more about building with Twilio Regions:


Rate this page: