This bot manages the verification process, karma and a bunch of other simple commands on our BUT FIT Discord server. It is written in Python with the help of Disnake and its DB runs on PostgreSQL with ORM.
Since the most of the features are custom-made, we wouldn't recommend using it for different servers.
Before you proceed to the environment setup, you will need to create a Discord application to get the Discord API key. We will not provide you with the exact steps on how to do this as there already exists this awesome guide from the developers of Disnake, Discord API Python library.
- When creating an invite URL in the Inviting Your Bot section,
the
bot
andapplications.commands
scopes are required. We also strongly recommend choosingAdministrator
in the Bot permissions as it is hard to figure out which of these permissions you actually need for the development.
You should set up a separate server just for the development purposes so it shouldn't be that much of a security risk anyway.
- After you create the Discord application, one additional step is required.
You will also need to enable
SERVER MEMBERS INTENT
in Bot tab:
You can do this by going to the Discord Developer Portal and selecting your newly created application. Then click on the Bot tab on the left and scroll down to the Privileged Gateway Intents section.
Start by cloning the repo:
git clone https://github.com/Toaster192/rubbergod.git
cd rubbergod
If you want to contribute to this project, refer to the contribution section first.
cp config/config.template.toml config/config.toml
Now open the config.toml
file in your editor. Insert the Discord API key you obtained earlier in the setup process:
1 [base]
2 command_prefix = ['?', '!']
3 default_prefix = '?'
4 ignored_prefixes = ['!']
5 key = '<Your Discord API key>'
...
Be careful. Bad things will happen if anyone else gets a possession of this key. Do not share it with anyone, ever!
On the next two lines, insert your Discord user and server ID so you get administrator rights over the bot:
6 admin_ids = [<Your Discord user ID>]
7 guild_id = <Your Server ID here>
Then, create the following 5 channels (or use one channel for all of them) on your server and paste their IDs to the config:
58 log_channel = <Channel ID>
59 bot_dev_channel = <Channel ID>
60 vote_room = <Channel ID>
61 bot_room = <Channel ID>
62 mod_room = <Channel ID>
(Optional) For some features you will also need to set other config variables, usually they are divided into categories based on cogs.
Install Docker & Docker Compose V2 by going to their official documentation. Just select your OS and follow the steps.
You can also install Docker as a GUI App — Docker Desktop — which includes everything you need.
- If you haven't already, enable
docker
service on startup:sudo systemctl enable --now docker.service
. Most installers should do that automatically, though. - To use Docker without
sudo
, you also need to be indocker
group (eg.sudo usermod -aG docker $USER && newgrp docker
). - It's recommended to restart your system at this point (to get all the permissions and other stuff right).
If you are using VS Code, you can simply run Rubbergod by using the Dev containers extension.
Either by clicking on a notification or by clicking on arrows in bottom left corner (Open a Remote Window) and choosing Reopen in container
.
This command should do the trick:
docker compose up
Note: We use the newer Compose V2 here. If the above command doesn't work, please install Compose V2: docker-compose-plugin
. As a second option, you can install and use (now deprecated) docker-compose
command instead.
Docker will download all the necessary stuff and run the container. If you did everything correctly, bot will connect to the DB, load all the extensions and print Ready
at the end. It will also send :peepowave:
emoji to the #bot-room
if you configured one. You're now all set!
If you didn't run the container in detached mode, just press Ctrl+C
to stop it.
Try to tweak some command a little bit and run the bot again, this time you can try to open it in detached mode so it won't block your terminal:
docker compose up --detach
Note: You can use shorter -d
instead of --detach
.
If you changed some internal command logic, it should be applied instantly. If, however, your change involves Discord-side API changes — command name change, for example — it can take longer (few minutes to a few hours in extreme cases).
To stop the detached container, use this command:
docker compose down
These things are not necessary for development but can help from time to time.
To enable command synchronization debug logging, change the following setting in rubbergod.py
to True
:
command_sync_flags = commands.CommandSyncFlags()
command_sync_flags.sync_commands_debug = False
Database-related tips can be found in database README.
List with all cogs, their commands and tasks can be found in cog README.
Install the required Python modules (venv
/ --user
flag recommended):
pip3 install -r requirements.txt
Run the bot (might want to use nohup
or something):
python3 rubbergod.py
git
python3.8
python3.8-dev
python3-pip
postgresql
postgresql-contrib
libpq-dev
To participate in the development, you need to create a fork and send us your contributions through "Pull requests". You can read more in About forks and Creating a pull request guides directly from GitHub. It may look scary at the first moment, but don't worry, it's actually pretty simple. If you don't know where to start, we can help you on Discord (mentioned below).
We use pre-commit
for lint check before each commit. Use it by running these commands:
pip install -r requirements-dev.txt
pre-commit install
Pull requests, issues or tips for new features are very much welcome!
You can discuss bot-related stuff in the #bot-development
channel on the BUT FIT Discord server.
GrillBot — our 2nd Discord bot almost entirely developed and maintained by @Misha12 aka Hobit.
Pumpkin.py — Highly modular Discord bot created by folks at BUT FEEC.
This project is licensed under the GNU GPL v.3 License.