Leveraging Windows Azure and Twilio to support SMS in the Cloud
Introduction
- Leveraging SMS messaging in a cloud context is a powerful capability. There are a wide variety of applications that can be built upon the techniques I illustrate. Imagine that you have a cloud service that responds to SMS messages. Here are some examples:
- Imagine you are presenting at a conference and you want to collect email addresses from the audience. This is the use case I will demonstrate.
- You could SMS the message "TIME, JAPAN" and the cloud would send back the answer
- The list goes on. Use your imagination.
- My solution leverages twilio from .net. I found the twilio guidance on doing this to be challenging. Myself, and my colleague, found it to be fairly challenging to implement. It took many hours of experimentation.
Prerequisites
- Sign up for an Azure account
- You can do that here: https://bit.ly/azuretestdrive
- Sign up for Twilio Account
- Twilio allows you to re-route SMS messages to your Azure hosted Account and then from Azure back to the phone.
- You can sign up here: https://www.twilio.com/
There are some high level steps to follow:
- Sign up for Azure as discussed previously
- Create an Azure Cloud Service at the Azure Portal
- You will end up with a URL that is the endpoint that will receive an SMS message forwarded by Twilio.
- For example, that endpoint might look like this:
- Write our Azure Application that will be deployed to a MS data center.
- Deploy your app to a MS data center
- Sign up for a Twilio account
- You will be given a phone number that will receive the SMS message (ie, +1 707-999-2736).
- You will indicate to Twilio the endpoint where your Azure app is deployed (discussed previously https://receiveandsendsms.cloudapp.net/SMSHandler.ashx)
- You are done.
- You can now write apps that receive SMS messages and return responses from a cloud application.
Signing up for an Azure account
- Signing up for an Azure account means you need to follow this link:
- It is a no obligation. Yes, you have to supply a credit card. Amazon does this too. It helps guard against fraud.
Create an Azure Cloud Service at the Azure Portal
- You can notice that I have clicked on NEW. The service I created can be seen in the list above. Note “ReceiveAndSendSms” is the name that I personally defined for me cloud service. You will necessarily need to have a different name. It becomes the endpoint, https://receiveandsendsms.cloudapp.net
- If you don’t know https://www.windowsazure.com/en-us/manage/services/cloud-services/how-to-create-and-deploy-a-cloud-service/
- Once you create your service, it will have an endpoint where SMS messages will be forwarded by Twilio.
- That endpoint, in my case is, https://receiveandsendsms.cloudapp.net. Yours will differ.
- You will need to use this endpoint at the Twilio portal. Twilio will forward SMS messages to this endpoint. The cloud app that you write will be able to read this endpoint.
Write an Azure Application that will be deployed to a MS data center.
- Here is a little tutorial that is similar to mine.
- https://msdn.microsoft.com/en-us/library/windowsazure/ee405487.aspx
- Start Visual Studio 2010/2012
- Select File/New Project
- Choose the template “Cloud / Windows Azure Cloud Service.”
- You will indicate a “Project Name” and “Location.”
- You will add a Web Role to the project
- Your finished solution will look similar to this:
- We now need to add some code that will execute when the SMS message is received
- Right mouse-click on the “Web Role” and choose “Add / New Item.” You will add a “Generic Handler.”
- You can keep the default name of Handler1.ashx, if you wish.
- There will be a method with the following signature: public void ProcessRequest(HttpContext context) {}
- This is where we will add our code to receive and process the SMS message.
- I will also add a method to perform the insert into the database
- Here is the two finished functions in Handler1.ashx.cs
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 | public void ProcessRequest(HttpContext context){ // Search for the word "Body=" and pluck out the value, which is the sms msg that was sent string srchfor = "Body="; int mylen = srchfor.Length; // Read the sms message sent System.IO.StreamReader reader = new System.IO.StreamReader(HttpContext.Current.Request.InputStream); string requestFromPost = reader.ReadToEnd(); // Find the "Body=" string int offset = requestFromPost.IndexOf(srchfor); int end = requestFromPost.Substring(offset).IndexOf('&') + offset; // Pluck out the value string myval = requestFromPost.Substring(offset + mylen, end - (offset + mylen)); InsertEmail(myval); // Write the upper case version back to the client context.Response.Clear(); context.Response.ContentType = "text/xml"; context.Response.ContentEncoding = System.Text.Encoding.UTF8; string twiMLResponse = null; twiMLResponse = " + myval + ""; context.Response.Write(twiMLResponse); context.Response.End();}public void InsertEmail(string email){ try { string connString = "Server=tcp:fj869qmhla.database.windows.net;" + "Database=SMSEmail; User ID=bruno\@fj869qmhla;" + "Password=xyz;Trusted_Connection=False;Encrypt=False;"; using (SqlConnection connection = new SqlConnection(connString)) { connection.Open(); SqlCommand cmdInsert = new SqlCommand( string.Format("Insert Into [dbo].[Email]" + "(email) Values" + "('{0}')", email), connection); cmdInsert.ExecuteNonQuery(); } } catch (SqlException ex) { Exception error = new Exception("Failure on Insert!", ex); throw error; }} |
Deploy to the cloud
- There are many ways to deploy to the cloud. You can learn more here:
- https://msdn.microsoft.com/en-us/library/ff683672.aspx
- I am using the “Publish” method. You could also create a package, go to the portal, and upload it.
The database
- The database is hosted in the cloud as well. I am using SQL Database. You can see I have created a database called SMSEmail. I have create a table called, “email”
- For more help, see this link, Getting Started with Windows Azure SQL Database (https://www.windowsazure.com/en-us/manage/services/sql-databases/getting-started-w-sql-databases/)
- I created a very simple database with one table as follows:
Twilio Setup
- The next step is to configure twilio to point to our cloud service. You can sign up for a free twilio account at their website. There is some important information here.
- Phone Number – 707-999-2736
- What users will use to send their email
- SMS Request URL
- Points to our deployed cloud service discussed previously.
- Phone Number – 707-999-2736
We are done
- We just need to send a text message to 707-999-2736. Whatever his texted, gets saved into a database in the cloud. Cool stuff.
Comments
Anonymous
April 20, 2015
Thanks for posting this, the code from Twilio is too simple indeed. I was able to use this article in an existing project and it worked. I then tried to create a new cloud service with a single webrole (like the tutorial does) and published it with ease but for some reason Twilio can not post to it. I get a HTTP retrieval failure from the Twilio App Monitor. I am new to .NET MVC (junior). If I add the Handler to the existing code (that I did not write) the App does not start. The other controllers don't work. Can you have multiple endpoints in one cloud service?Anonymous
April 20, 2015
ok. the problem was in the Database