Reminder Bot for Discord, now in Rust
Go to file
2021-09-11 00:14:23 +01:00
migration added an on delete clause 2021-06-23 14:04:46 +01:00
regex_command_attr more commands. fixed an issue with text only commands 2021-09-11 00:14:23 +01:00
src more commands. fixed an issue with text only commands 2021-09-11 00:14:23 +01:00
.gitignore removed IDE files 2021-03-21 14:19:52 +00:00
Cargo.lock linked everything together 2021-09-10 18:09:25 +01:00
Cargo.toml linked everything together 2021-09-10 18:09:25 +01:00
create.sql migrated reminder commands to new database code 2021-06-03 17:43:28 +01:00
dp.py natural command stuff 2020-09-26 22:23:41 +01:00
LICENSE Create LICENSE 2020-09-21 09:16:10 +00:00
README.md updated README.md 2021-02-14 15:40:05 +00:00
rustfmt.toml more commands. fixed an issue with text only commands 2021-09-11 00:14:23 +01:00

reminder-rs

Reminder Bot for Discord, now in Rust. Old Python version: https://github.com/reminder-bot/bot

How do I use it?

We offer a hosted version of the bot. You can invite it with: https://invite.reminder-bot.com. The catch is that repeating reminders are paid on the hosted version of the bot. Keep reading if you want to host it yourself.

You'll need rustc and cargo for compilation. To run, you'll need Python 3 still (due to no suitable replacement for dateparser in Rust)

Compiling

Reminder Bot can be built by running cargo build --release in the top level directory. It is necessary to create a folder called 'assets' containing an image file with its name specified in the environment as WEBHOOK_AVATAR, of dimensions 128x128px to be used as the webhook avatar.

Compilation environment variables

These environment variables must be provided when compiling the bot

  • DATABASE_URL - the URL of your MySQL database (mysql://user[:password]@domain/database)
  • WEBHOOK_AVATAR - accepts the name of an image file located in $CARGO_MANIFEST_DIR/assets/ to be used as the avatar when creating webhooks. IMPORTANT: image file must be 128x128 or smaller in size
  • STRINGS_FILE - accepts the name of a compiled strings file located in $CARGO_MANIFEST_DIR/assets/ to be used for creating messages. Compiled string files can be generated with compile.py at https://github.com/reminder-bot/languages

Setting up Python

Reminder Bot by default looks for a venv within it's working directory to run Python out of. To set up a venv, install python3-venv and run python3 -m venv venv. Then, run source venv/bin/activate to activate the venv, and do pip install dateparser to install the required library

Environment Variables

Reminder Bot reads a number of environment variables. Some are essential, and others have hardcoded fallbacks. Environment variables can be loaded from a .env file in the working directory.

Required Variables

  • DATABASE_URL - the URL of your MySQL database (mysql://user[:password]@domain/database)
  • DISCORD_TOKEN - your application's bot user's authorization token

Other Variables

  • MIN_INTERVAL - default 600, defines the shortest interval the bot should accept
  • MAX_TIME - default 1576800000, defines the maximum time ahead that reminders can be set for
  • LOCAL_TIMEZONE - default UTC, necessary for calculations in the natural language processor
  • DEFAULT_PREFIX - default $, used for the default prefix on new guilds
  • SUBSCRIPTION_ROLES - default None, accepts a list of Discord role IDs that are given to subscribed users
  • CNC_GUILD - default None, accepts a single Discord guild ID for the server that the subscription roles belong to
  • IGNORE_BOTS - default 1, if 1, Reminder Bot will ignore all other bots
  • PYTHON_LOCATION - default venv/bin/python3. Can be changed if your Python executable is located somewhere else
  • LOCAL_LANGUAGE - default EN. Specifies the string set to fall back to if a string cannot be found (and to be used with new users)
  • THEME_COLOR - default 8fb677. Specifies the hex value of the color to use on info message embeds
  • CASE_INSENSITIVE - default 1, if 1, commands will be treated with case insensitivity (so both $help and $HELP will work)
  • SHARD_COUNT - default None, accepts the number of shards that are being ran
  • SHARD_RANGE - default None, if SHARD_COUNT is specified, specifies what range of shards to start on this process
  • DM_ENABLED - default 1, if 1, Reminder Bot will respond to direct messages