Resources »

Packages »

Twilio Bot

Introduction

This package creates Twilio Bot for demonstrating integration between Cerb and Twilio’s API.

Configure the Twilio service

If you haven’t already, follow these instructions to configure the Twilio service and add your first connected account.

Import the package

Navigate to Setup » Configure » Import Package.

Paste the following package into the large text box:



{
  "package": {
    "name": "Twilio Bot",
    "revision": 1,
    "requires": {
      "cerb_version": "9.1.0"
    },
    "configure": {
      "prompts": [
        {
          "type": "chooser",
          "label": "Twilio account:",
          "key": "twilio_account_id",
          "params": {
            "context": "cerberusweb.contexts.connected_account",
            "single": true,
            "query": "name:twilio"
          }
        },
        {
          "type": "text",
          "label": "Account SID:",
          "key": "account_sid",
          "params": {
          }
        },
        {
          "type": "text",
          "label": "Default responder phone number:",
          "key": "default_from",
          "params": {
          }
        }
      ],
      "placeholders": [
        {
          "type": "random",
          "key": "webhook_guid",
          "params": {
            "length": 40
          }
        }
      ]
    }
  },
  "bots": [
    {
      "uid": "bot_twilio",
      "name": "Twilio Bot",
      "owner": {
        "context": "cerberusweb.contexts.app",
        "id": 0
      },
      "is_disabled": false,
      "params": {
        "config": {
          "account_sid": "{{{account_sid}}}",
          "default_from": "{{{default_from}}}"
        },
        "events": {
          "mode": "all",
          "items": [

          ]
        },
        "actions": {
          "mode": "all",
          "items": [

          ]
        }
      },
      "image": "",
      "behaviors": [
        {
          "uid": "behavior_42",
          "title": "Look up a number",
          "is_disabled": false,
          "is_private": true,
          "priority": 50,
          "event": {
            "key": "event.macro.bot",
            "label": "Custom behavior on bot"
          },
          "variables": {
            "var_phone_number": {
              "key": "var_phone_number",
              "label": "Phone Number",
              "type": "S",
              "is_private": "0",
              "params": {
                "widget": "single"
              }
            }
          },
          "nodes": [
            {
              "type": "action",
              "title": "Look up number via API",
              "status": "live",
              "params": {
                "actions": [
                  {
                    "action": "core.va.action.http_request",
                    "http_verb": "get",
                    "http_url": "https://lookups.twilio.com/v1/PhoneNumbers/{{var_phone_number|url_encode}}?Type=carrier&Type=caller-name",
                    "http_headers": "",
                    "http_body": "",
                    "auth": "connected_account",
                    "auth_connected_account_id": "{{{twilio_account_id}}}",
                    "options": {
                      "raw_response_body": "1"
                    },
                    "run_in_simulator": "1",
                    "response_placeholder": "_http_response"
                  },
                  {
                    "action": "_set_custom_var",
                    "value": "{{_http_response.body|json_pretty}}",
                    "format": "json",
                    "is_simulator_only": "0",
                    "var": "response"
                  }
                ]
              }
            }
          ]
        },
        {
          "uid": "behavior_43",
          "title": "Respond to Twilio SMS webhook",
          "is_disabled": false,
          "is_private": false,
          "priority": 50,
          "event": {
            "key": "event.webhook.received",
            "label": "Webhook received"
          },
          "nodes": [
            {
              "type": "switch",
              "title": "Command:",
              "status": "live",
              "nodes": [
                {
                  "type": "outcome",
                  "title": "HELP",
                  "status": "live",
                  "params": {
                    "groups": [
                      {
                        "any": 0,
                        "conditions": [
                          {
                            "condition": "http_param",
                            "name": "body",
                            "oper": "is",
                            "value": "help"
                          }
                        ]
                      }
                    ]
                  },
                  "nodes": [
                    {
                      "type": "action",
                      "title": "Respond",
                      "status": "live",
                      "params": {
                        "actions": [
                          {
                            "action": "set_http_body",
                            "value": "{% set msg = \"You can say:\\n* HELP\\n* LOGO\\n* LINK\\n\" %}\r\n<?xml version=\"1.0\" encoding=\"UTF-8\"?>\r\n<Response>\r\n    <Message>{{msg|escape}}</Message>\r\n</Response>"
                          }
                        ]
                      }
                    }
                  ]
                },
                {
                  "type": "outcome",
                  "title": "LOGO",
                  "status": "live",
                  "params": {
                    "groups": [
                      {
                        "any": 0,
                        "conditions": [
                          {
                            "condition": "http_param",
                            "name": "body",
                            "oper": "is",
                            "value": "logo"
                          }
                        ]
                      }
                    ]
                  },
                  "nodes": [
                    {
                      "type": "action",
                      "title": "Respond",
                      "status": "live",
                      "params": {
                        "actions": [
                          {
                            "action": "set_http_body",
                            "value": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\r\n<Response>\r\n    <Message>\r\n    \tHere's the Cerb logo:\r\n    </Message>\r\n    <Message>\r\n    \t<Media>https://cerb.ai/assets/images/home/cerby.png</Media>\r\n    </Message>\r\n</Response>"
                          }
                        ]
                      }
                    }
                  ]
                },
                {
                  "type": "outcome",
                  "title": "LINK",
                  "status": "live",
                  "params": {
                    "groups": [
                      {
                        "any": 0,
                        "conditions": [
                          {
                            "condition": "http_param",
                            "name": "body",
                            "oper": "is",
                            "value": "link"
                          }
                        ]
                      }
                    ]
                  },
                  "nodes": [
                    {
                      "type": "action",
                      "title": "Respond",
                      "status": "live",
                      "params": {
                        "actions": [
                          {
                            "action": "set_http_body",
                            "value": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\r\n<Response>\r\n    <Message>\r\n    \tVisit https://cerb.ai/ for more info.\r\n    </Message>\r\n</Response>"
                          }
                        ]
                      }
                    }
                  ]
                },
                {
                  "type": "outcome",
                  "title": "(default)",
                  "status": "live",
                  "params": {
                    "groups": [
                      {
                        "any": 0,
                        "conditions": [

                        ]
                      }
                    ]
                  },
                  "nodes": [
                    {
                      "type": "action",
                      "title": "Respond",
                      "status": "live",
                      "params": {
                        "actions": [
                          {
                            "action": "set_http_body",
                            "value": "{% set msg = \"Hi \" ~ http_params.from ~ \"! You said: \" ~ http_params.body %}\r\n<?xml version=\"1.0\" encoding=\"UTF-8\"?>\r\n<Response>\r\n    <Message>{{msg|escape}}</Message>\r\n</Response>"
                          }
                        ]
                      }
                    }
                  ]
                }
              ]
            }
          ]
        },
        {
          "uid": "behavior_41",
          "title": "Send SMS message",
          "is_disabled": false,
          "is_private": true,
          "priority": 50,
          "event": {
            "key": "event.macro.bot",
            "label": "Custom behavior on bot"
          },
          "variables": {
            "var_to": {
              "key": "var_to",
              "label": "To",
              "type": "S",
              "is_private": "0",
              "params": {
                "widget": "single"
              }
            },
            "var_body": {
              "key": "var_body",
              "label": "Body",
              "type": "S",
              "is_private": "0",
              "params": {
                "widget": "multiple"
              }
            }
          },
          "nodes": [
            {
              "type": "action",
              "title": "Send message via API",
              "status": "live",
              "params": {
                "actions": [
                  {
                    "action": "core.va.action.http_request",
                    "http_verb": "post",
                    "http_url": "https://api.twilio.com/2010-04-01/Accounts/{{behavior_bot_config.account_sid}}/Messages",
                    "http_headers": "",
                    "http_body": "{% set params = {\r\n\t\"To\": var_to,\r\n\t\"From\": behavior_bot_config.default_from,\r\n\t\"Body\": var_body\r\n} %}\r\n{{params|url_encode}}",
                    "auth": "connected_account",
                    "auth_connected_account_id": "{{{twilio_account_id}}}",
                    "options": {
                      "raw_response_body": "1"
                    },
                    "run_in_simulator": "1",
                    "response_placeholder": "_http_response"
                  }
                ]
              }
            }
          ]
        }
      ]
    }
  ],
  "records": [
    {
      "uid": "webhook_twilio_bot",
      "_context": "webhook_listener",
      "name": "Twilio SMS Received",
      "guid": "{{{webhook_guid|lower}}}",
      "extension_id": "cerb.webhooks.listener.engine.va",
      "extension_params": {
        "behavior_id": "{{{uid.behavior_43}}}"
      }
    }
  ]
}


Click the Import button.

You’ll be prompted for some configuration options:

  • Twilio account: The Twilio connected account you created earlier.
  • Account SID: Your Twilio account SID (from your Twilio dashboard).
  • Default responder phone number: The default phone number to use when sending SMS messages. This should be formatted as an E.164 number, like +15551234567. This number must exist in your Twilio account.

Click the Import button again.

You should see the following:

Test the integration behaviors

Click on Twilio Bot and then click Behaviors on its card.

Looking up a phone number

You can use Twilio’s Lookup API to retrive caller and carrier information about a phone number.

Open the card for the Look up a number behavior:

Click on the Simulator button at the top of the card.

Enter your mobile number in Phone Number: field (in E.164 format) and click the Simulate button.

At the bottom of the simulator output, in the Set custom placeholder section, you’ll find the results of the lookup:

Sending a text message

Open the card for the Send SMS message behavior:

Click on the Simulator button at the top of the card.

Enter your mobile number in To:, a message in Body:, and then click the Simulate button.

You should receive a text message on your mobile phone.

If you don't receive a text message, you can check the logs and debugger in Twilio. The bot simulator also provides debug output.

Receiving text messages

The package above automatically created a webhook for you and linked it to the Respond to Twilio SMS webhook bot behavior. Let’s copy this URL so we can add it to Twilio:

  1. Log in to Cerb.

  2. Navigate to Search » Webhooks:

  3. Copy the URL for the Twilio SMS Received webhook. (You can right-click the URL in your browser and select Copy Link from the menu.)

When you provision a phone number at Twilio, you can configure a webhook URL to handle inbound text messages.

  1. Log in to Twilio’s phone number console.

  2. Provision a new phone number, or select an existing one.

  3. Under the Configure tab, in the Messaging section, make sure Webhook is selected, then paste the Cerb webhook URL from above:

  4. Click the red Save button at the bottom of the page.

You should now be able to send text messages to that number and have a Cerb bot respond.

We’ve set up a few examples. Try sending the following messages:

  • hi
  • help
  • link
  • logo

The bot will respond:

Next steps

At this point you can modify the behaviors to meet your needs. You can use the responses from Twilio’s API in your behaviors.