Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/grantbirki/errbot-launchpad
Quickly deploy a chatbot with Errbot, Dockerized! ๐ณ
https://github.com/grantbirki/errbot-launchpad
chatbot discord docker framework python slack
Last synced: 25 days ago
JSON representation
Quickly deploy a chatbot with Errbot, Dockerized! ๐ณ
- Host: GitHub
- URL: https://github.com/grantbirki/errbot-launchpad
- Owner: GrantBirki
- License: gpl-3.0
- Created: 2021-08-08T23:20:10.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-07-15T16:46:07.000Z (6 months ago)
- Last Synced: 2024-12-09T14:18:52.247Z (29 days ago)
- Topics: chatbot, discord, docker, framework, python, slack
- Language: Python
- Homepage:
- Size: 205 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
errbot
A chatbot that is easy to deploy and build upon
## About ๐ก
This project uses [Errbot](https://github.com/errbotio/errbot) and [Docker](https://www.docker.com/) to quickly launch your own chatbot in a container.
The goal of this project is to make it as easy as possible to launch a minimal, working chatbot.
## Quickstart โญ
Want to get going quick? Run the following commands to bring up a CLI to interact with `errbot` locally:
1. `git clone [email protected]:GrantBirki/errbot-launchpad.git`
1. `cd errbot-launchpad`
1. `make local`
1. Interact with the bot!```console
[@local_admin โก @errbot] >>> .hello
Hello world! I am errbot!
```1. ๐
> Didn't work quite right? See the setup section below..
---
## Setup ๐ ๏ธ
### Prerequisites โ๏ธ
If you got all the items below downloaded and are familiar with setting up a bot account for chat service, you can skip right to the setup section.
- [Docker](https://www.docker.com/)
- [Docker-compose](https://docs.docker.com/compose/)
- [Make](https://www.gnu.org/software/make/)
- [WSL](https://docs.microsoft.com/en-us/windows/wsl/install-win10) if you are using WindowsDepending on which "backend" or "chat-service" you plan on using, you will need an authentication token to start your bot.
- [Slack](https://my.slack.com/services/new/bot) - Extra errbot [documentation](https://errbot.readthedocs.io/en/latest/user_guide/configuration/slack.html?highlight=slack)
- [Discord](https://discord.com/developers/docs/intro) - Extra errbot [documentation](https://github.com/gbin/err-backend-discord)Lastly, you will need to be familiar with how to add your bot to your chat service.
Adding your bot to a chat service examples:
#### Slack
In the case of Slack, this can be done by mentioning your bot in any channel and you will be prompted to invite the bot right there.
> Note, this particular repo does not use Slack. It is a Discord app!
#### Discord
> This bot has already been provisioned to Discord. It is included as a reference should the bot ever need to be rebuilt
With Discord, things are a little different. You will need to first enable `SERVER MEMBERS INTENT` for your bot application. After that, you need to go into the Oauth2 page for your bot and select the `bot` scope. This will expand more options. You may go as crazy or as restrictive as you want with the chat permissions. That part is totally up to you.
Once your permissiosn are scoped out, you will need to copy the oauth2 link that is generated.
It could look something like this: `https://discord.com/api/oauth2/authorize?client_id=&permissions=&scope=bot`
> Note: You can find an example invite link farther below
Enter that link into your web browser and it should give you a list of servers to invtire your bot to. Add it to your favorite server!
#### Other backends
The errbot framework supports lots of different backends. For view their setup information, check out the [docs](https://errbot.readthedocs.io/en/latest/features.html)
### Configuring your bot
To configure your bot, you will need to modify your `config.env` and `creds.env` files. To make things easier, there is a and `creds.example.env` file in the root of this repo to configure your sensitive credentials.
1. Rename `creds.example.env` to `creds.env` *required
1. Set `BACKEND=` *required
1. Set `CHAT_SERVICE_TOKEN=''` *required
1. Change `BOT_PREFIX=.` if you want *optional---
### Testing and Building Locally ๐งช
**Important**: Make sure you followed the setup instructions above first
For plugin testing, you may run the following command to launch a local instance of your bot and interact with it over the command line:
```console
$ make local
[#] Starting local bot test environment
[#] Killing old docker processes
docker-compose rm -fs
Stopping chatbot ... done
Going to remove chatbot
Removing chatbot ... done
[#] Building docker containers
docker-compose build
Building chatbot
[+] Building 1.3s (22/22) FINISHED
...
..
.
[#] TEST Container is now running!
[#] Interact with me over the CLI prompt below
...
..
.
[@local_admin โก @errbot] >>>
```> Read more about the errbot local dev environment [here](https://errbot.readthedocs.io/en/latest/user_guide/plugin_development/development_environment.html#local-test-mode)
#### Windows Tips for Local Testing
If for some reason you are using Windows and not WSL like a pleb, you can build a local image using the following commands:
```console
docker-compose build
docker run -it --rm --env-file config.env --env-file creds.env -e LOCAL_TESTING=True errbot_chatbot:latest
```This will result in a CLI prompt to `errbot` locally so you can test. Simply press `CTRL+C` to exit when you are done
### Testing and Building Connected to Discord โจ๏ธ
Completed the simple setup? Awesome! Let's start the bot:
```text
make run
```Output:
```console
$ make run
[#] Killing old docker processes
docker-compose rm -fs
No stopped containers
[#] Building docker containers
docker-compose up --build -d
Building chatbot
[+] Building 1.3s (23/23) FINISHED
...
..
.
Creating chatbot ... done
[#] Container is now running!
```If you followed the steps above and everything succeeded, you should get a DM from the bot stating that it is "Now Online". You should note that you will only get this message if `BOT_ADMINS='@username'` is set to your username in the `config.env` file.
---
## Making your own plugin / function ๐
Check out the [CONTRIBUTING.md](CONTRIBUTING.md) file in this repo for all the info you will need to develop, test, and deploy!
---
## Project Folder/File Information ๐
What is in each folder?
- `.github/` - Mainly GitHub workflows for actions
- `script/` - Maintenance and automation scripts for working with this project
- `template/` - Template / boilerplate code for new chatops commands
- `app/` - All the files, data, and configuration for `errbot`- `app/backend/` - Folder containing extra backend modules (Discord)
- `app/plugins/` - Folder containing all the extra / custom plugins for our chatop commandsWhat are these files?
- `.gitignore` - Used for ignoring files from Git
- `config.env` - Used for adding non-sensitive environment variables to your local instance of `errbot`
- `creds.env` - Used for adding sensitive environment variables to your local instance of `errbot`
- `docker-compose.yml` - Used for starting `errbot` locally with Docker-Compose
- `Makefile` - Used to easily invoke scripts in this repo
- `*.md` - Documentation!---
## About the Infrastructure ๐งฑ
Here is a high level overview of this project and the software/infrastruce that run this bot:
- This project uses [errbot](https://github.com/errbotio/errbot) which is a Python based chatop/chatbot framework
- `errbot` and all of its components are built using Docker to create a deployable image
- The bot then listens for commands and responds to them