reminder-bot / reminder-rs

**MOVED** Please go to https://gitea.jellypro.xyz/jude/reminder-bot
https://gitea.jellypro.xyz/jude/reminder-bot
GNU Affero General Public License v3.0
48 stars 10 forks source link

reminder-rs

Reminder Bot for Discord.

How do I use it?

I 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

Install build requirements: sudo apt install gcc gcc-multilib cmake libssl-dev build-essential python3-dateparser

Install Rust from https://rustup.rs

Reminder Bot can then 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

Setting up database

Use MySQL 8. MariaDB is confirmed not working at the moment.

Load the SQL files in order from "migrations" to generate the database schema.

Setting up Python

Reminder Bot uses python3-dateparser to handle dates. This depends on Python 3.

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

Other Variables