How to filter landlines before sending SMS with the Lookup API
You successfully created a text message but shortly after received the unfortunate [Twilio Alert] On 1st error each day
email. Maybe it was a 30006 - Landline or unreachable carrier
or other undelivered message error. If you're lucky, your application handles status callbacks for undelivered messages.
What if there was a way to catch undeliverable messages proactively? This blog post will walk you through using the Lookup API to determine line type, so that you can filter landline numbers before sending an SMS to them (and being charged for that SMS).
How to determine if you have undelivered messages
Twilio uses status callbacks to track message delivery status with webhooks. Learn more about tracking the delivery status of messages in this support article.
The two most common types of undelivered message errors this blog post will address include:
- Error 30006: Landline or unreachable carrier
- Error 30003: Unreachable destination handset
Tutorial prerequisites
To follow along with this blog post you'll need:
- A free or paid Twilio Account. Sign up or sign in.
- A Twilio phone number. Buy a new phone number or use an existing one.
- The Twilio Node.js helper library. Follow the instructions to install.
This blog post will use Node.js (download) but you can use the code samples in the documentation to write a similar program in the language of your choice.
Using the Lookup API to detect landline phone numbers
The Lookup API provides various types of phone number information with different data packages. These include information like SIM swap status or call forwarding. This post will use the Line Type Intelligence package which includes carrier and line type information.
First, store your Twilio credentials as environment variables.
From your terminal make the following cURL request to determine the line type of the New York City Hall phone number.
Here's the JSON response:
The phone number line type in the response is "landline". Possible values include mobile
, fixedVoip
, nonFixedVoip
, tollFree
, and others. You can filter out any type of phone number, but this code will focus on filtering landlines.
Write a program to filter landlines before sending SMS
While we're using JavaScript here, you can use the code samples in the documentation to write a similar program in Python, Java, PHP, Ruby, C#, Go, or the language of your choice. Create a new file called "filter-landline.js" and open it in your favorite code editor. Start by instantiating the Twilio client. Add the following code to the top of the file:
Create a variable to store your Twilio phone number. You can either store this in another environment variable or hard code it:
Next, add a function called safeSendSms
. The function will take a phone number parameter, check its line type, throw an error if it's a landline, and proceed with sending the message if not.
Finally, bring it all together by looping through a list of numbers and attempting to send a message to each of them. Add your personal mobile number to the list to see a non-filtered message:
Run the program from your terminal with node filter-landline.js
. You should see the following output:
Cost efficiency of using Lookup before sending an SMS
You only need to make a Lookup request once* compared to unknowingly sending dozens of SMS (marketing message, appointment reminder, support update, etc.) to undeliverable locations. Using Lookup can actually save you money if deployed smartly. Consider this example with 1000 US users: if just 5% of the numbers need to be filtered, you only need to send about 25 messages per user before you'll start saving money with Lookup.
If you have questions about whether the cost makes sense for your usage, we're happy to help evaluate - get in touch.
How to use the Lookup API for more phone number information
You could also detect landlines in order to default to voice calls for something like phone verification or 2FA. The Lookup API will also be handy to block the rare pager number or filter VoIP numbers at sign up.
Lookup is also a great way to clean up your database or validate phone number input with our free formatting API. Learn more in our blog post about best practices for phone number validation.
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.