Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Master Bot

...

Panel
title
borderColor#7BD9F5
borderWidth2
borderStylesolid

Introduction:

As we proceed with hubots coupled with tools to make our tasks easier in the form of conversations, we realised that there needs to be some is a need of a framework which should do the management activity for the manage other bots. Therefore, we came up with the Master Bot, the bot for managing all other bots. This bot is designed to let you manage all your other bots and gather consolidated information about them by just chatting with it. Let us dig deep into how this conversing with Master Bot will assist you to manage all your other bots.

Master Bot deployment:

Panel
  1. Install hubot into your server (Refer here)
  2. Pull your desired scripts-<adapter> folder from our github repository
  3. Copy the content of scripts-<adapter> into your <newly_installed_hubot_folder>/scripts
  4. Set the following environment variables:

             ONBOTS_URL: The url where OnBots services are running

             AUTH_TOKEN: Personal access token of your adapter(must permissions to get uploaded file content from the adapter)

             (for genearating this token in slack Click here, for mattermost Click here, for Hipchat Click here)

             HUBOT_SLACK_TOKEN: To add new app/bot to slack workspace. (for generating this token in slack, Go to https://api.slack.com/apps --> Create New App --> Give app name and Choose Workspace --> "Install your app to your workspace" : use proper permissions(oAuth) and register your apps. you will get token starts with "xoxb-" )

      5.  Install the desired npm-module for your adapter. Master can work with Slack, Hipchat or Mattemost. Execute the following command inside your bot folder:

            npm install hubot-<adapter> (where <adapter> can be slack, hipchat or mattermost. Refer this page to to learn more about how to connect your bot to a chat application.)

          You are all set now. Execute the following to start the bot with your chat adapter:

            ./bin/hubot -a <adapter>

How it works:

1)You will need the masterbot and the OnBots services running in your serversKubernetes master server.

Warning

Your Masterbot and OnBots services should be running on the same server. This is because the Master needs to interact with the Kubernetes Environment for fetching bots related data and doing performing management activities for the bots. If both are not in same machine, even if you have ports opened and allow connection between the servers, kubernetes . Kubernetes will block the master OnBots services from accessing it, if it is deployed in different servers even if ports are allowed in firewall.

2) Connect it to slackadapters like Slack, Hipchat or mattermostMattermost

3) Now you can interact with the bot through commands

Let us have a look at what are all Below are the commands supported by our Master Bot:

CommandsDescription
getDeployedBotsget list of all deployed bots
getBotsget bot types available in onBots
getConfig Template <botname>get Json template for adding a particular type of bot
addBot <json_fileid>adds a bot with the given configuration in Json file
getBotDetails <botname>get configuration and other details for a bot
getLogs <botname>get deployment logs of the given bot
getChatlog <botname>get chat logs of the given bot
stop <botname>stop an active bot if it is running

restart <botname>

restart the bot with the details stored in mongodb
getHitmiss <botname>get hit-miss ratio of conversations of the given bot
getMetrics <botname>get system metrices for the given bot
editbot <botname> <json_fileid>edit the bot configuration details in mongodb from the given json file
tail <number_of_lines> <botname>To get last <number_of_lines> of the logs of <botname>
delete <botname>delete the bot
container status <botname>give the container status in which the bot is deployed
helplist all the commands the master can perform

Now, the question is how do you get master to be deployed in your environment? (wink) Fear not, here's your guide to get the master working in your server:

Panel
  1. Install hubot into your server (Refer here)
  2. Pull your desired scripts-<adapter> folder from our github repository
  3. Copy the content of scripts-<adapter> into your <newly_installed_hubot_folder>/scripts
  4. Install the desired npm-module for your adapter. Master can work with slack, Hipchat or mattemost. Execute the following command inside your bot folder:

            npm install hubot-<adapter> (where <adapter> can be slack, Hipchat or mattermost. Refere this page to to learn more about how to connect your bot to a chat application.)

          You are all set now. Execute the following to start the bot with your chat adapter:

            ./bin/hubot -a <adapter>

...


Image Added → Actions available by default

Image Added → Actions enriched by OneDevOps | OnBot

Bots which can be deployed using the

...

Master Bot:

Panel
borderColor#7BD9F5
borderStyledashed

Below are the Bots Available in OnBots. Below pages will guide you on what a bot can do for you (smile)Click on specific botnames to know more:


Tip

Every Bot has default Help command, which will explain users about what the bot can actually do by giving list of Commands and Actions. In case Bot does not understand user commands then bot can guide users with default replies.

...