Creating a phone number lookup bot using Microsoft Bot Framework and C#

May 04, 2016
Written by

bots-bots-everywhere

Bots are all the rage and at //BUILD 2016 Microsoft announced their Bot Framework. Let’s see how easy it is to build a bot using the SMS channel powered by Twilio.

Our Tools

Our bot should take a telephone number and reply with information about it using Twilio’s Lookup API. We’ll need:

  • Visual Studio 2015 including the latest updates. We’ll be building this on Windows this time, but you shouldn’t struggle replicating this on a Mac or Linux machine.
  • A Twilio Account and a Twilio Phone Number – Sign up for free!
  • An Azure account which you can get for free here.

Once you have the three things above download and install the the Bot Connector Template for Visual Studio. It will make our lives much easier when creating new bots.

Extract the file to %USERPROFILE%\Documents\Visual Studio 2015\Templates\ProjectTemplates\Visual C# and you should end up with something like this.


Let’s also install the Bot Emulator as it will be really useful for when we’re testing our bot.

If you don’t feel go through the whole post and just want to deploy your bot, feel free to download it from my GitHub repo.

Creating our first bot

Open up Visual Studio 2015 and choose File > New > Project. Choose the Visual C# tab under Templates and there should be a Bot Application template for you to choose. Name it TwilioLookupBot.


Once your project has loaded, open Package Manager Console and install the Twilio.Lookups library by running:
PM> Install-Package Twilio.Lookups
PM> Update-Package

Running your bot for the first time

Using the template gives us a working bot in the form of a messaging API which we will modify later. If you want to check what it looks like right now, run the project and you will see a screen like this:


Open up Microsoft Bot Framework Emulator and check that you bot details are as follows:

Make sure the URL and port matches with what you’re seeing on your browser and that the App Id and App Secret match what’s in the Web.config. The values we’re using are the default and we will change these later on.

ahoy.gif

Send your bot a message and check that you get a response.

Modifying our bot

Now that we know our bot works let’s use Solution Explorer to create a folder called Services in the root of the project.. We will create a new class called TwilioLookupService.cs that will have logic on how to connect with the Twilio Lookup API.

In that class add the Twilio.Lookups namespace and a new method called GetNumberInfo which takes a string as argument.

using System;
using Twilio.Lookups;

namespace TwilioLookupBot.Services
{
    public class TwilioLookupService
    {
        public static Number GetNumberInfo(string number)
        {
            var lookupClient = new LookupsClient(Environment.GetEnvironmentVariable("TWILIO_ACCOUNT_SID"), Environment.GetEnvironmentVariable("TWILIO_AUTH_TOKEN"));

            var response = lookupClient.GetPhoneNumber(number, true);

            return response;
        }
    }
}

Make sure you replace the account sid and auth token with the ones you can get from the Twilio Account Console. The rest of the code authenticates with and makes the request to the Twilio Lookups API, returning the phone number information.

Back in the MessagesController.cs file you will see that the only logic on the Post method is the one that counts the number of characters in the message received and makes the Bot reply with that.

Delete the code inside the if condition and replace it with the following:

if (message.Type == "Message")
{
    // Get number information
    var numberLookup = TwilioLookupService.GetNumberInfo(message.Text);

    // Check if the number entered is valid
    if (numberLookup.RestException != null)
    {
        return message.CreateReplyMessage("You entered an invalid phone number");
    }

    // Build a response using Markdown
    var response =
        $"The number **{numberLookup.NationalFormat}** has the following details:"  
        $"{Environment.NewLine}{Environment.NewLine}"  
        $"**Carrier:** {numberLookup.Carrier.Name}"  
        $"{Environment.NewLine}{Environment.NewLine}"  
        $"**Country Code:** {numberLookup.CountryCode}"  
        $"{Environment.NewLine}{Environment.NewLine}"  
        $"**Type:** {numberLookup.Carrier.Type}";
                
    return message.CreateReplyMessage(response);
}

While we still have the same condition to check if the message received if of the type Message, we’re now making a lookup request to the Twilio API to get information about this number.

We format this message using Markdown. If you want to find out more check out the documentation on Markdown formatting for the text property.

Give it another go and run the project again, but this time try to enter a telephone number and you should get information about it.

lookup.gif

Deploying our Bot to Azure

Our bot is only running on localhost at the moment, to interact with it via the channels offered by the Bot Framework we need to host it somewhere.

In Visual Studio right click on the project name and choose Publish. We will be using Microsoft Azure App Service as a target. Click New and create and choose a server that is in a geographical location close to you and click Create.

When that completes choose that profile and click Next. On the subsequent screen you can choose which URL you want your bot to run from. Make a note of that URL as we will use it later when we register our bot.

Click Publish, and the deploy will start. Once that is completed your browser should open automatically on the homepage for your bot.

Pat yourself on the back, you have just deployed your first bot!

giphy.gif

Registering our bot

Now that our bot has a permanent address on the internet it is time for us to register it so we can start using the various communication channels available.

Head to Register a bot. You can use the same Microsoft credentials here as you used earlier when you signed up for Azure.

On the registration page fill in your bot’s details for all the mandatory fields. Pay attention to the Endpoint, that’s the URL you chose earlier when deploying to Azure plus the path. In my case it ended up being like this:

Also notice how I’ve used HTTPS on the URL. A bot will not work if you try to assign channels to it and the URL is not secure.

In the Behaviour section make sure you choose Listen to all messages. You can leave the other checkboxes unchecked for now and change it later if you need.

Lastly enter an App ID. You can use anything you want here so I will leave that to your imagination, but just remember that if you decide to publish this bot later people will be able to see that. Click Register when you’re done.

Changing our bot’s App ID

Now that our bot has an App ID and an app secret head back to Visual Studio and enter those in Web.config.

<appSettings>
        <!— update these with your appid and one of your appsecret keys—>
        <add key="AppId" value="YourAppId" />
        <add key="AppSecret" value="YourAppSecret" />
</appSettings>

Right click on your project name again and hit Publish. You won’t need a new profile this time so just click the Publish button.

Once that is complete, check that your bot still works by heading back to the Bot Framework Emulator and entering the live credentials for your bot, including the new App ID and App Secret.

Configuring the SMS Channel

Now that you know your bot works and you’ve successfully made a few number lookups on it, it’s time to enable its SMS Channel. You can do that by going back to the settings for your bot and clicking Add on SMS.

This page will take you through all you need to do but the steps are:

You can watch this video here if you’re having difficulty doing that.

Lastly you will need to get your account sid and auth token from the Twilio account dashboard and enter it along with your Twilio telephone number in order to give the framework access to your account.

When you’ve got that, click Submit Twilio Credentials and when that’s verified click I’m done configuring SMS.

Grab your phone and send a text message to your Twilio number with a telephone number you want to check.

bot on phone2.gif

Bots, bots, bots….

Now that you’ve successfully created and deployed your very own Bot how about adding some extra functionality to it? You could parse all the text sent to it and do something different if you do not get a telephone number.

How about getting the bot to start a new conversation with you everyday to ask you how you’re feeling?

Did you know we have an entire track called “/bots” at SIGNAL this year? Dan Driscoll, an engineer on the Microsoft Bot Platform, will be giving a talk called “10 Tips for Building Awesome Bots“. We’ll also have developers from Slack, Facebook and Twilio talking about best practices for bot building on their respective platforms.

SIGNAL is May 24th and 25th in San Francisco. Use the promo code MPLACONA20 for 20% off. I’d love to have you there.

I can’t wait to see what you will build and which functionalities you will add to your bot. Hit me up on Twitter @marcos_placona or by email on marcos@twilio.com to tell me more about it.