Automated Webex Bot Deployment to Heroku

A Python application to automatically deploy a Webex Bot to Heroku using the Heroku Platform APIs.

Webex Bots Introduction

Overview

Webex Bots: Webex is Cisco's cloud collaboration platform and the Cisco Webex for Developers program opens up the platform to extend and customize the Webex experience. Bots are one example that can help users automate tasks, add external content, and gain efficiencies. There are different types of bots:

  • Notifier Bots: Notifier bots typically respond to events in external services and post a summary in Webex. A bot that sends a notification about an alarm in Meraki is an example.
  • Controller Bots: Controller bots act as a text-based remote control for external services. Users can call the bot and ask it to take certain actions, such as updating configurations in Cisco DNA Center.

Heroku: Heroku is a platform as a service (Paas), which is popular by developers to deploy and manage applications in the cloud. It officially supports languages such as Python, Node.js, or Java, and it provides an API to automate services, which makes it easy to use and quick to setup.

Webex Bot on Heroku: Webex bots are triggered using webhooks. Webhooks need to be configured to listen to a public URL, which is provided when hosting the application on a cloud service like Heroku. Heroku hosts the application and makes it publicly accessible at the URL it is hosted at, so that when a service is configured to send a message to the webhook, the application listens and responds. The application processes the request following the script that defines the actions of the bot and sends a notification in the name of the bot.

External Services and Webhooks: Examples of external services that can be configured to send messages or alerts to a webhook include Cisco solutions, such as Meraki or DNA, but also other services like Grafana. To deploy a controller bot in Webex, a webhook must be configured to respond to events within Webex, such as someone sending a message to the bot or adding the bot to a team space.

Contacts

Solution Components

  • Webex Bot
  • Heroku
  • Python

Prerequisites

  • Webex Account: If you do not have a Webex account yet, you can create one here for free.

  • Bot:

    • Creation:
      1. Go to the Webex Developer website to create a bot.
      2. Log in with your Webex credentials by clicking Log in on the top right corner.
      3. Click Create a Bot.
      4. Fill in the information for your new bot, and click Add Bot at the bottom of the page.
      5. On the next page, you will see your Bot Access Token. Copy the token and save it as it will not be shown again.
    • Additional Information: Depending on whether you are deploying a notifier or controller bot, follow the these steps:
      • Notifier Bot:
        • Dedicated Team Space and Room ID:
          1. Create a Webex Teams Space by following these instructions.
          2. Name the space.
          3. Add the bot to the space. Also add other users that should receive the bot notifications.
          4. Click Create.
          5. Go to the Webex API documentation for Webex Teams Rooms to retrieve the ID.
          6. Use the interactive API endpoint on the right of the page. Use your personal access token (enabled by default) and if you just created the space, you can use the query parameter sortBy with the value created to list that space as the first entry in the response. Click Run and note the id value for the space you just created from the returned response.
      • Controller Bot:
  • Heroku:

    • Account: If you do not have a Heroku account yet, click here to sign up for free.
    • Stack and Buildpack: This app is based on the Heroku-20 stack and since the application is written in Python, it uses the officially supported Python buildpack. To customize this, you can edit the app.json file following the official schema.

Deployment

  1. Clone this repository with git clone <this repo>.

  2. Navigate to the bot directory and open the bot.py file. Take the following actions:

    • Depending on whether you are implementing a notifier or controller bot, uncomment the lines of codes as described in the file itself.
    • Customize the behaviour of the bot. The default behaviour of the bot in this repo is to send a hard-coded message to Webex. Depending on the use case of your bot, this should be changed.
  3. Create your own repository on GitHub and push all files in the bot directory (app.json, bot.py, Procfile, requirements.txt) to the repository following these steps.

  4. Navigate to the setup directory and open the credentials.yaml file. Fill in the information and save the file:

     heroku_username: ''     # your Heroku account username
     heroku_password: ''     # your Heroku account paswoord
     heroku_region: ''       # either 'eu' or 'us'
     webex_bot_token: ''     # the access token noted during bot creation
     webex_bot_email: ''     # for controller bots (see Prerequisites section), leave empty for notifier bots
     webex_room_id: ''       # for notifier bots (see Prerequisites section), leave empty for controller bots
     github_url: ''          # the URL of the GitHub repository created in step 3 of the installation*
     github_version: ''      # the version of the GitHub repository to be deployed, can be a branch name (e.g. master) or commit hash 
    

    NB: The GitHub URL is used to create the source_blob that is required to setup an app using the Heroku Platform APIs. For that matter, the repository must be public. If the repository is private, you will need to include a username and token according to the information provided here.

  5. (Optional) Create a Python virtual environment and activate it (find instructions here).

  6. In a terminal, navigate to the setup directory, and install the dependencies with pip install -r requirements_setup.txt.

  7. Run the setup script with python setup.py.

  8. From the logging output written to the console while the script is running, note the URL the app is deployed. It has the following format: https://app-name.herokuapp.com.

Webhook Setup

  • For notifier bots:
    • The webhook URL must be configured in the external services. A few examples to for example send alerts on different platforms:
    • Once configured and a notification/alert is sent from the service to the URL, the bot takes action following the logic of the bot.py script.
  • For controller bots, a webhook must be configured for the bot to respond to events within Webex. Follow these steps to set it up:
    1. Go to the Webex API documentation for Webhooks to create a webhook for the bot.
    2. Use the interactive API endpoint on the right of the page.
      1. Use the bot access token in the Authorization field of the headers.
      2. Provide a name for the webhook in the name field of the body.
      3. Provide the webhook URL in the targetURL field of the body.
      4. Provide a resource in the resource field and an event in the event field of the body. For example, if you want the bot to respond to messages that are sent in a Webex space, enter messages as resource and created as event.
      5. Click Run. Ensure you receive a 200/OK status message in the response.
    3. You can now chat with the bot on Webex and it will take actions following the logic of the bot.py script.
      • Take into account that a bot can only access messages sent to it directly. In group spaces, bots must be @mentioned to access the message. In 1-to-1 spaces, a bot has access to all messages from the user.

License

Provided under Cisco Sample Code License, for details see LICENSE.

Code of Conduct

Our code of conduct is available here.

Contributing

See our contributing guidelines here.

View code on GitHub

Code Exchange Community

Get help, share code, and collaborate with other developers in the Code Exchange community.View Community
Disclaimer:
Cisco provides Code Exchange for convenience and informational purposes only, with no support of any kind. This page contains information and links from third-party websites that are governed by their own separate terms. Reference to a project or contributor on this page does not imply any affiliation with or endorsement by Cisco.