Replace Twilio API Explorer with Bruno, an Open Source API Client
data:image/s3,"s3://crabby-images/8076a/8076a1390ffd77d87473a09476d527127199d29e" alt="Users upgrading to Bruno API client on their laptops"
Time to read: 4 minutes
Twilio provides straightforward communication REST APIs with great documentation. In addition, developers have long used Twilio’s API explorer to get started building applications. However, on December 15th, 2023 we will End Of Life the tool.
In this post, we will learn to use Bruno, an Open Source API client as an API Explorer replacement.
Why an API client?
With an API client, developers can make requests to our REST API, explore responses from Twilio’s servers, and copy code snippets for use in their applications. A developer can test operations such as buying a phone number, sending a text message, or making a phone call programmatically before writing a lot of code.
This process ensures that building powerful telephony applications is a seamless process, and gives developers confidence to integrate the right Twilio APIs into whatever application they are building.
In this blog post, I will show you how to send an SMS without coding using Bruno as the API client.
Prerequisites
- Twilio Account: Set up a Twilio Account (if you don’t have one yet,sign up for a free Twilio Trial)
- Phone Number: Note that most countries have differing registration requirements depending on number type. For some API operations, you’ll need to complete those requirements before exploring API calls.
- Twilio OpenAPI Specification: Download Twilio’s OpenAPI Specifications and unarchive them into a working directory on your local computer. We will need to import this into Bruno.
- Bruno - Download: Install the latest version of Bruno for your Operating System
- Mobile Phone: A SMS-capable device to receive your test message
Set up Bruno
Import Twilio OpenAPI Specifications into a Bruno Collection
Open the Bruno Application. Navigate to Import Collection.
Test |
|
|
---|---|---|
hi |
More |
hi |
hi |
|
hi |
hi |
hi |
hi hi |
data:image/s3,"s3://crabby-images/37956/37956722484c536f852447133c3777d0daf264f2" alt="Import a Collection inside Bruno"
Now, click Import Collection.
data:image/s3,"s3://crabby-images/5623d/5623d537b217e78aed1c696513ba1b3e007f3df5" alt="Import an OpenAPI spec from Twilio inside Bruno"
Select OpenAPI V3 Spec in the opened dialog box.
Browse to your location where you extracted the Twilio OpenAPI Specifications. The Twilio OpenAPI Specification file twilio_api_v2010.json is located in the folder twilio-oai-<version> -> spec -> json -> twilio_api_v2010.json
data:image/s3,"s3://crabby-images/da82d/da82d63b2a9b05bd79d85138b34f53c6a3c44dff" alt="Load an OpenAPI spec of Twilio's API in Bruno"
You will be prompted to add a location where you want the specs to be imported. Click Browse, and select a location on your computer.
data:image/s3,"s3://crabby-images/0bd72/0bd7246fcc185f22c913087f5f4e43d66ccde8bf" alt="Browse in Bruno to where to save an API spec"
Configure Bruno to use Twilio APIs
Open up your Twilio Console
We will need the following information from the Home Screen
- Account SID
- Auth Token
- My Twilio phone number
Remember, this number should be registered for A2P10DLC or Toll Free Verified, or otherwise fulfill the requirements of the number type in that number’s country.
data:image/s3,"s3://crabby-images/b4d1a/b4d1ab3d829475428d4fd199073ae8e17f4f0831" alt="Fifth anniversary edition of the Customer Data Platform report Fifth anniversary edition of the Customer Data Platform report"
data:image/s3,"s3://crabby-images/b4d1a/b4d1ab3d829475428d4fd199073ae8e17f4f0831" alt=""
data:image/s3,"s3://crabby-images/d3461/d34614808605ef4b560f45a17275b4f8291e06d3" alt="Twilio credentials from the Twilio Console"
Set up the Twilio Environment for Bruno
Now when you open Bruno, you will see Twilio APIs on the left hand side menu:
data:image/s3,"s3://crabby-images/f4511/f451108724ac32d9d1a7ba4638ae639a4c6e9556" alt="Selecting the Twilio API in Bruno"
In the upper right corner of Bruno, drop down to Configure:
data:image/s3,"s3://crabby-images/99707/99707a4b9638e7b9c7e132a097f984b59beab80f" alt="Configure a Collection in Bruno"
Create the new environment.
data:image/s3,"s3://crabby-images/1f099/1f099dc818be61b155676bbfd53bbe958119db3d" alt="Create a new Environment in Bruno"
Give the environment a name so you know what Twilio account it is associated with:
data:image/s3,"s3://crabby-images/0e1ce/0e1ce77e6e76c52a977276f39e4f57b683d99129" alt="Name a Bruno environment"
Now, we will add 3 variables from the information we collected from our Twilio Console.
Add the following names with the respective values we collected by hitting the + Add Variable button
- TWILIO_ACCOUNT_SID
- TWILIO_FROM_NUMBER
- TWILIO_AUTH_TOKEN
Be sure to click “Secret” for the TWILIO_AUTH_TOKEN
data:image/s3,"s3://crabby-images/969cf/969cfa56e4102c8102733ad6eede591e317e5e4e" alt="Adding Twilio account credentials inside Bruno"
Save our Environment!
Expand to Twilio API -> Api20100401Message -> POST CreateMessage in the opened Bruno Collection:
data:image/s3,"s3://crabby-images/f24b6/f24b6c247a4177f98f2c8f6bbe949cc16e06b45a" alt="Expand CreateMessage inside Bruno"
Select the environment we just created to use with this Bruno collection
data:image/s3,"s3://crabby-images/7b25c/7b25c5f8d3f02923766aedc104ac7077c726c428" alt="Pick the Twilio Environment we created earlier"
Send our first SMS
Navigate to the following in your Twilio API collection:
Twilio API -> Api20100401Message -> POST CreateMessage
At a minimum, to send an SMS with Twilio API, the API requires:
- Account SID - Already configured under auth
- Auth Token - Already configured under auth
- A From number - A Twilio Phone number you are sending the message from
- A To number - where you want the message sent
- A Body - What the messages is
We need to set up our Basic Authentication to use the Twilio credentials we set up in our Environment. Under the Auth Tab for CreateMessage, change the Username to {{TWILIO_ACCOUNT_SID}}
and Password to reference the {{TWILIO_AUTH_TOKEN}}
environmental variable.
data:image/s3,"s3://crabby-images/ceecf/ceecf6e1a1f4a9b5b3eb8bb5c2b0c94807d50f3c" alt="Entering Twilio Account Credentials to CreateMessage in Twilio"
Now, under the Body tab, you will see all the parameters available for the CreateMessage
endpoint. We will keep only the required parameters to send the SMS. Those are:
- To
- From
- Body
Using E.164 format, enter the number you wish to send an SMS to. For example, +14155551212
.
data:image/s3,"s3://crabby-images/24ab0/24ab0d76bd762104276fd68ceecb21b50ab37beb" alt="Enter a 'to' number in Bruno"
We will use the {{TWILIO_FROM_NUMBER}}
to send From, this will use the environment variable in {{}} to reference it as a variable.
Finally, input the message we want to send in “Body”: Hi, My First Twilio SMS
data:image/s3,"s3://crabby-images/7ccff/7ccffabfe36ea7ab82793358a427485e070ad888" alt="Add a message body in Bruno"
Finally, update the POST url to include your account’s Account SID. We are changing {AccountSid}
to {{TWILIO_ACCOUNT_SID}}
in the POST URL.
Change the URL from:
data:image/s3,"s3://crabby-images/45204/4520411d048eb800fbd7993a7b5f9c9cabff165d" alt="Change the path based on an environment variable in Bruno"
To:
data:image/s3,"s3://crabby-images/0594d/0594d0c4311892e63de0e3856b236b86045a0e8c" alt="Bruno using a path with an environment variable"
Click the arrow (->) button to send the API request.
data:image/s3,"s3://crabby-images/b15c5/b15c56249fb625226f0d34168f86b8a47baa2a3b" alt="Send an API reqest using the arrow button in Bruno"
You should now receive the message and see the Twilio Response.
data:image/s3,"s3://crabby-images/80a41/80a41e053af48388ec5cb0d81ba8f6483172c9db" alt="Bruno displaying an API response from Twilio"
Congratulations on sending your first message using Bruno as an API client!
What next?
Check Logs
If your message was not successful, check the Twilio Logs in your Twilio Console. Did Twilio receive the message?
Check the Monitor, Logs -> Messaging section.
data:image/s3,"s3://crabby-images/42931/42931e8b9aa6d2dc6665ee732a8b936245e35192" alt="View the messaging logs in the Twilio Console"
Learn more about Messaging API
We only covered the basics with the CreateMessage
endpoint. I’ll give you a few suggestions around where you might explore next:
Maybe you’d like to explore sending messages:
https://www.twilio.com/docs/messaging/api/message-resource#create-a-message-resource
Remember all the boxes we un-checked? This document explains what else you can do with the message endpoint.
https://www.twilio.com/docs/messaging/api/message-resource#create-a-message-resource
For example, let’s enable MediaUrl and send a picture. Check the checkbox and provide a MediaUrl, such as:
https://upload.wikimedia.org/wikipedia/commons/9/93/1%25_20-%25_20EEE2HHO.gif
data:image/s3,"s3://crabby-images/97dbb/97dbbda2c4d027551197755bfee9e075e2bc4b64" alt="Add a MediaUrl in Bruno to send an SMS with image link or MMS via Twilio"
Conclusion
We’ve only scratched the surface in this post. I hope by having another tool to understand Twilio’s API, we’ve inspired you to explore building with Twilio.
As always, we can’t wait to see what you build.
Alex Chun is a Principal Solutions Engineer at Twilio.org. Alex Chun partners with social impact organizations to create tech solutions for communication workflows. His areas of interest are hotlines, technologies for helping climate changes, and animal rescues. He is currently working on solutions using Twilio technologies like Flex, Frontline, and WhatsApp. You can reach him at achun [at] twilio.com.
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.