/smexybot

A bot for Discord, written in Rust using the serenity-rs library.

Primary LanguageRustApache License 2.0Apache-2.0

smexybot

Linux / OS X travis-badge
crates-io license-badge coveralls-badge

Smexybot is a general-purpose Discord bot written in Rust. It is built upon the serenity.rs Discord API.

Table of Contents

Usage

Invitation

The easiest way to use this bot is to invite it to your Discord server. The bot is running 24/7 and gets updated as soon as new features are available.

To invite the bot to your server, click here. You must have the Manage Server permission for that server. Upon clicking the link, you will be asked to choose which permissions to give to smexybot, but be aware that disabling the permissions may lead to unexpected behaviour.

If you have any questions or feedback, feel free to either email me or open an issue in this repo. You can also join my personal Discord server and leave a message, or messaging iwearapot on discord.

Instructions on running a local instance are coming soon.

the global instance (hosted by me) to your server.

Personal Setup

Alternatively, a personal instance of the bot can be configured.

Setup a bot account:

  1. Go to Discord Developers My Applications page
  2. Click "New Application"
  3. Enter a name for your application (this is not your bot username) in the "App Name" field
  4. (Optional) Add a description and/or icon for your bot (the icon will be your bot's profile picture)
  5. Click "Create Application"

Create a bot user:

  1. On the page for your application, click "Create a Bot User"
  2. Click "Yes, do it!" when asked to confirm
  3. Now that your bot is created, press "click to reveal" on the application page to see your bot's token.
  4. Copy this value, and paste it into the file .env.example (included in this repository), in the place of the existing DISCORD_BOT_TOKEN value.
  5. Copy the .env.example file to .env, and modify any other configuration options you wish.

Run an instance of the bot, either by running a pre-built executable (coming soon!), or by compiling the bot yourself (instructions coming soon!).

Configuration

Currently, Smexybot reads its configuration from the environment. It is assumed that you have then loaded the necessary configuration options into the environment prior to running the bot.

A set of example configuration options can be found in the file .env.example, included in this repository.

Detailed information regarding plugin configurations can be found in the plugins' respective README.md files.

Commands

Interacting with Smexybot is done via commands. Commands may be performed by DM, or by @mentioning the bot in a text channel on a server on which the bot is present.

Plugins

Coming soon!

Contributing

Contributions are always welcome! If you have an idea for something to add (code, documentation, tests, examples, etc.) feel free to give it a shot.

Please read CONTRIBUTING.md before you start contributing.

Credits

Smexybot and it's constituent components and plugins are built primarily using the excellent serenity.rs framework by zeyla.

The list of contributors to this project can be found at CONTRIBUTORS.md.

License

smexybot is distributed under the terms of both the MIT license and the Apache License (Version 2.0).

See LICENSE-APACHE, and LICENSE-MIT for details.