Master Bot
Introduction:
As we proceed with hubots coupled with tools to make our tasks easier in the form of conversations, we realised that there is a need of a framework which should manage other bots. Therefore, conversing with Master Bot
will assist you to manage all your other bots.
Master Bot deployment:
- Install hubot into your server (Refer here)
- Pull your desired scripts-<adapter> folder from our github repository
- Copy the content of scripts-<adapter> into your <newly_installed_hubot_folder>/scripts
- 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)
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 OnBots services running in Kubernetes master server.
OnBots services needs to interact with the Kubernetes Environment for fetching bots related data and performing management activities. Kubernetes will block the OnBots services from accessing it, if it is deployed in different servers even if ports are allowed in firewall.
2) Connect it to adapters like Slack, Hipchat or Mattermost
3) Now you can interact with the bot through commands
Below are the commands supported by Master Bot:
Commands | Description |
---|---|
getDeployedBots | get list of all deployed bots |
getBots | get 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 |
help | list all the commands the master can perform |
→ Actions available by default
→ Actions enriched by OneDevOps | OnBot
Bots which can be deployed using the Master Bot:
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.
Add Comment