Build an Auditable SMS Proxy Using Twilio Programmable SMS, Pangea Audit Service, and JavaScript
Third parties knowing what is said in SMS conversations can be scary, but in a world filled with increasingly false and misleading information being presented as news, not knowing what was said can be just as scary. In this tutorial, learn how to add cryptographically verifiable hashes of Twilio powered SMS conversations to an immutable public ledger or blockchain powered by Pangea’s tamperproof audit and logging service.
By publishing conversation hashes to the blockchain you can provide irrefutable evidence of what was said between two parties without actually exposing the contents of the conversation publicly. With Twilio Programmable SMS and Pangea’s Javascript SDK you can deliver the power of the blockchain to your users with a few lines of code. In this tutorial, you’ll set up a free Pangea account and, using Node.js, build an SMS forwarding service that logs messages between two parties using Twilio Functions.
Requirements
- A free or paid Twilio account
- A Twilio phone number
- A free Pangea account
- Node.js (version 14.16.1 or higher)
Set up your Pangea account and Access Token
Once you’ve signed up for Pangea, log in and access the Pangea Console. Set up the Audit service by selecting Secure Audit Log from the left-hand navigation menu.
Review the benefits of the service and select Next to continue.
Create an Access Token
by selecting a token name, expiration date, and token scope or use the default values by selecting Done.
Make a note of the Config ID, service Domain, and access Token. You will use each of these values to interact with the service from your app’s code in the next step.
Get the code
In this section, you will configure your app to communicate with Twilio, and Pangea, with your account credentials. You’ll also configure which phone numbers your proxy will forward each message to and examine the code that does so.
Navigate to your terminal and enter the following command to clone the SMS proxy app:
Now change the working directory to your new Node.js project, audit-twilio-proxy, with the following command:
Open up your project directory in your preferred IDE and take a moment to explore the project files and configure it to your environments.
- package.json - Describes the project and lists dependencies. Both the Twilio and Pangea SDKs for Node.js are listed. The
devDependencies
includestwilio-run
which you’ll use to deploy to code to Twilio Functions. - .env - Contains the environment variables the app will reference.
- functions/sms-audit-proxy.js - The application source file that contains a single function to handle incoming SMS messages.
Configure and deploy the app
The application source reads 7 variables from the .env file.
ACCOUNT_SID
andAUTH_TOKEN
to authenticate your app with the Twilio service.PANGEA_DOMAIN
,PANGEA_CONFIG_ID
, andPANGEA_AUTH_TOKEN
to authenticate with the Pangea service.TARGET_NUMBER
andOWNER_NUMBER
are used to determine where to forward incoming SMS messages.
Modify the .env file by replacing each {REPLACE}
tag with its corresponding value.
For the PANGEA_
specific variables, use the three values you noted in the previous section, or retrieve them from the Pangea Console by navigating to the Secure Audit Log tab.
The Twilio values for ACCOUNT_SID
and AUTH_TOKEN
can be found on the landing page of the Twilio Console.
OWNER_NUMBER
and TARGET_NUMBER
should each be a valid E.164 phone number you’d like to test with. For example, OWNER_NUMBER
can be set to your mobile phone number and TARGET_NUMBER
to a friend's number who you’d like to start and record an auditable message thread with. An example of an E.164 formatted number in the US is +16502223333.
Verify your changes to the .env file with the git diff
sub-command:
The output should look similar to this:
Code walkthrough
Inspect the contents of the /function/sms-audit-proxy.js source file before deploying the app to a Twilio Serverless environment. The file contains a single function. You will configure Twilio to invoke this function when your Twilio owned number receives an SMS. The function’s response and actions taken will be determined by the contents of the object passed in as the event
parameter.
The user defined environment variables set in the .env file will be passed into the function via the context
parameter. The Twilio account variables are read and set to accountSid
and authToken
, respectively, and used to represent an instance of the twilio
class defined in the SDK.
TwilioClient
is then used to create a MessagingResponse
object which may be used to reply to the sender. Note that a reply will only be necessary when reporting an error back to the sender.
The Pangea SDK is imported and the PANGEA_
values are assigned to their respective variables. A PangeaConfig
object is created and used to create an AuditService
instance.
Before invoking the Audit Service, determine if the inbound message should be added to the secure audit log and if so who to relay the message to after it is logged. Only messages between the two numbers configured in the .env file should be logged. Each of the allowed recipient numbers are read into local variables.
Determine the destinationNumber
to relay the message to:
- If the message originated from the owner, send it to the target.
- If the message came from the target, send it to the owner.
- If the message came from any other number, notify the sender that the message will be ignored by populating and returning the
MessageResponse
.
Create a JavaScript object and map the relevant event details to the log entry. Set the actor
field to the Twilio owned number that is logging and forwarding the message. The source
is set to the number that sent the incoming SMS, read from the event.From
field, and target
is set to the intended recipient or destinationNumber
. The message
is set to the body or contents of the SMS, which is also read from the event object.
Call the log
method of the AuditService
with the auditData
. This will invoke the Pangea Service to create the log entry. The hash of the message will also be recorded on a tamper proof blockchain which can then be used to prove the conversation has not been modified. You can explore the log viewer on the Pangea Console to verify the message integrity later.
When the asynchronous log
function completes the callback function is called with a single response
parameter. If the response is marked successful, use the TwilioClient
to relay the contents of the message to the destinationNumber
and return a blank response to complete the function execution.
Deploy to Twilio Functions & Assets
Twilio Functions is a serverless environment that empowers developers to quickly create and host applications. Because the package.json file lists the twilio-run
module as a development dependency, you can quickly deploy your function using the following command:
The module uses the same ACCOUNT_SID
and AUTH_TOKEN
used by the application in the .env file to authenticate with your Twilio account when deploying the project.
A successful deploy will yield output similar to:
Congratulations! You just deployed a Pangea enabled Twilio service. Make a note of the Functions URL as it will be needed to configure your Twilio programmable number.
If you do not already have a Twilio number, follow these instructions:
- Go to your Phone Numbers Dashboard.
- Click Buy a Number.
- Search for a number that suits you.
- Click Buy
- Confirm your purchase, then click Setup Number.
Otherwise, navigate to the Active numbers panel of the Twilio console and select the number you’d like to use with this service.
Under Messaging, look for the line that says “A message comes in.” Change the first box to “Webhook” and add the function URL to the second box, then click Save to save your configuration. The function you deployed will now be invoked every time an SMS is sent to this number.
Test and verify the conversation audit trail
That's it! You now have a secure audit trail between the OWNER_NUMBER
and TARGET_NUMBER
you configured in the .env file. Use a cellphone with either number to send an SMS to the Twilio number you purchased and configured to invoke your function. The SMS message will be logged by the Pangea service and forwarded to the other participant, similarly their replies will be forwarded back to you creating a conversation thread on the SMS apps on both your phones.
To later view the conversation or present the verified proof that messages were not altered or deleted, navigate back to the Pangea Console, select Secure Audit Log from the left-hand navigation menu, and then select View Logs.
You can expand each message to view the sender and recipient details, labeled as source and target, respectively.
The green lock to the left of each message indicates that its hash has been published to the ARWeave blockchain and verified. To view the transaction on ViewBlock.io, click the lock icon and then click the View button next to Published Root.
Conclusion
In this article you learned how to build and deploy an SMS proxy that records conversations and provides users with verifiable proof that the conversation was not altered. Most telecom providers maintain records of the messages sent over their network, but even the largest carriers are susceptible to tampered records on their centralized data sources. It may also be impractical for your users to request conversation logs from carriers as the process may require a legal process or subpoena. Utilizing a Blockchain with your Twilio and Pangea powered proxy you are able to quickly solve both these problems for your user.
Nicolas Vautier is a Developer Advocate at Pangea Cyber and is a privacy and data security enthusiast. If you have questions, comments, or ideas for future posts, Nicolas can be reached at nicolas.vautier@pangea.cloud. Follow him on Twitter @DeveloperEnvY to join his journey as he helps unify security services for app builders @PangeaCyber.
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.