Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kangalio/rustbot
[MOVED TO https://github.com/rust-community-discord/ferrisbot-for-discord] Rust programming language bot for Discord
https://github.com/kangalio/rustbot
Last synced: 12 days ago
JSON representation
[MOVED TO https://github.com/rust-community-discord/ferrisbot-for-discord] Rust programming language bot for Discord
- Host: GitHub
- URL: https://github.com/kangalio/rustbot
- Owner: kangalio
- License: mit
- Created: 2021-02-14T17:06:44.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2024-07-03T01:29:23.000Z (6 months ago)
- Last Synced: 2024-12-16T08:15:35.701Z (27 days ago)
- Language: Rust
- Homepage: https://github.com/rust-community-discord/ferrisbot-for-discord
- Size: 683 KB
- Stars: 93
- Watchers: 3
- Forks: 32
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE.TXT
Awesome Lists containing this project
README
# MOVED TO https://github.com/rust-community-discord/ferrisbot-for-discord
# Rustbot
## Inviting the bot
Some permissions are required:
- Send Messages: base command functionality
- Manage Roles: for `?rustify` command
- Manage Messages: for `?cleanup` command
- Add Reactions: for `?rustify` command feedback
Furthermore, the `applications.commands` OAuth2 scope is required for slash commands.Here's an invite link to an instance hosted by me on my Raspberry Pi, with the permissions and scopes incorporated:
https://discord.com/oauth2/authorize?client_id=804340127433752646&permissions=268445760&scope=bot%20applications.commandsAdjust the client_id in the URL for your own hosted instances of the bot.
## Hosting the bot
The bot requires `Server Members Intent` enabled in the `Applications > $YOUR_BOTS_NAME > Bot`
settings of Discord's [developer portal](https://discord.com/developers/applications).Run the bot using `cargo run --release`.
You will need to provide several environment variables. A convenient way to do this is to copy the
`.env.example` file to `.env` and fill out the values. Then run the bot with the `.env` file applied.Also set `SQLX_OFFLINE` to `true` if you're running the bot for the first time. Otherwise, SQLx
will try to call into the database to check query correctness, which fails if the database hasn't
been set up yet.Example command-line for Linux:
`set -a && source .env && set +a && SQLX_OFFLINE=true cargo run --release`### Docker
This project has a Containerfile, so you can use Docker or Podman to run this bot if you wish.
For that, rename the `.env.example` file into `.env`, fill out the values, and run the command:```sh
docker-compose -f container-compose.yaml up -d --build
```Currently we're using Docker to run it, but eventually we'll make it work with just podman.
## Credits
This codebase has its roots in [rust-lang/discord-mods-bot](https://github.com/rust-lang/discord-mods-bot/), the Discord bot running on the official Rust server.