Skip to content

🍣 A Discord chat bot with a ranking system, moderation tools, and more.

License

Notifications You must be signed in to change notification settings

sushiibot/sushii-bot

Repository files navigation

Build Status Build Status

⚠ sushii bot is no longer active or maintained, see sushii 2 for the rewrite.

sushii bot

sushii

A Discord bot written in Rust with serenity-rs. Uses a PostgreSQL database along with diesel-rs and r2d2-diesel.

Work in progress. Features may be either missing, incomplete, or broken. sushii is not designed to be self hosted and likely won't ever be, no support will be offered unless you are making a pull request.

Disclaimer: sushii was started as a project to learn Rust so there is definitely a lot of questionable things in the code. A major refactor to clean up and organize the code is planned but probably won't happen anytime soon. Read at your own risk.

Features

  • Ranking system based on message counts in daily, weekly, monthly, and all time categories
  • User 24 hour activity tracker
  • Profile image generation for displaying rank and activity graph (with sushii-image-server)
  • sushiiboard (starboard)
  • Configurable self assigning role system with multiple categories and limits
  • Configurable prefix per guild
  • Moderation action logs and editable action reasons
  • Mute evasion prevention
  • Mass mention auto-mutes
  • User created tags (custom commands-ish)
  • Channel galleries (sends links & images from a channel to a webhook)
  • Reminders
  • Keyword notifications
  • User join and leave messages
  • Rust playground code execution
  • Discord events counter
  • ...and more to be added

Installation

  1. Download the latest version from the releases page or the download an artifact on Azure Pipelines, currently only supporting Linux. Sushii should work on Windows and other platforms but it is untested and unsupported.

  2. Allow the file to be executed.

    chmod +x x86_64-unknown-linux-gnu
  3. Create an .env file in the same directory and update according to .env.example. All variables must exist except for BLOCKED_USERS or the bot will panic.

  4. Run with ./x86_64-unknown-linux-gnu or with a process manager like Supervisor.

Building from Source

  1. Install dependencies.
  2. Clone this repository and enter the directory.
    git clone /~https://github.com/drklee3/sushii-bot.git
    cd sushii-bot
  3. Edit .env.example and rename to .env. Removing any key or leaving them blank will result in panics.
  4. Build and run the bot.
    cargo run --release

About

🍣 A Discord chat bot with a ranking system, moderation tools, and more.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published