Disclaimer: I don't know what I'm doing, both in Rust and Discord territory. It may blow up in your face, be warned.
A (not so) simple Discord bot providing the following commands:
/bl-link
//bl-unlink
, allowing to link user account to Beat Leader profile. Not required if user has linked Discord account on BeatLeader website./bl-replay
, allowing to post replay according to set criteria along with links to BL replay and ArcViewer/bl-profile
, allowing to post user profile/bl-add-auto-role
//bl-remove-auto-role
, allowing a user (role management permission required) to configure the automatic setting of selected roles to server users based on their BL profile. The roles to be set up are grouped, and each role can be assigned a set of multiple conditions that must be met for it to be given./bl-set-log-channel
, allowing to set the channel on which all role changes will be posted/bl-set-profile-verification
, allowing to set the profile verification requirement when linking a player's profile/bl-set-clan-invitation
, allowing to set up self-sending by the user invitations to the clan without the involvement of the clan owner (NOTE: requires contacting NSGolova on BeatLeader discord to get OAuth application id and secret)/bl-clan-invitation
, allowing a user to send an invitation to join a clan on their own/bl-clan-wars-playlist
, allowing a user to generate personalized playlist of clan wars maps/bl-set-clan-wars-maps-channel
, allowing to set the channel on which top 30 clan wars maps will be postedCapture the map
context menu command, allowing you to check the pp and accuracy needed to capture the map after clicking on any message containing a link to the leaderboard/bl-show-settings
, showing current server settings/bl-export
//bl-import
, allowing to export and import all bot data (bot owner only)
All of the following commands require a Rust environment installed on your computer.
- Copy
config.example.toml
asconfig.toml
and/orconfig.dev.toml
. The first will be used production, the second for development. If both are present dev one takes precedence. - Register bot:
- Go to Discord Developer Portal
- Create New Application
- Copy Discord Token (click
Reset Token
button on Bot tab to obtain it) and setdiscord_token
inconfig.toml
/config.dev.toml
- If you want to use clan commands set
client_id
,client_secret
andredirect_url
in theoauth
section ofconfig.toml
(get them from NSGolova on BeatLeader discord). In addition, you need to run a server that will receive the OAuth Authorization code and generate the corresponding Discord command. You can use this project for this purpose or write your own.
- Invite a bot to your server (replace
<APP_ID>
with your application ID, you can find it on General Information tab in Discord Developer Portal)https://discord.com/oauth2/authorize?client_id=<APP_ID>&scope=bot&permissions=2415937536
(required permissions: Manage roles, Embed links, Send Messages, Use Application Commands) - Either download the latest version for your server architecture from the Releases page and run it, or build from source as described below. Make sure that the directory from which you run the bot includes the
config.toml
file, theassets
andstatic
directories from this repository, and empty.logs
,.storage
and.http-cache
directories. - The bot's built-in web server uses the HTTP protocol (defaults to port 3000, you can change this in
config.toml
), so you probably need a SSL termination reverse proxy, such as nginx. Example nginx configuration (using Let's encrypt SSL certificate):
server {
server_name your-domain.com;
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_http_version 1.1;
proxy_set_header Connection "";
proxy_pass https://localhost:3000/;
}
access_log /var/log/nginx/your-domain.com-access.log;
error_log /var/log/nginx/your-domain.com-error.log;
listen 443 ssl;
ssl_certificate /etc/letsencrypt/live/your-domain.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/your-domain.com/privkey.pem;
include /etc/letsencrypt/options-ssl-nginx.conf;
ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem;
}
server {
if ($host = your-domain.com) {
return 301 https://$host$request_uri;
}
listen 80;
server_name your-domain.com;
return 404;
}
cargo test && cargo run
After you launch and invite the bot to your server, it will be visible in the list of users, but inaccessible. The bot does not automatically register Discord commands globally, you have to do it manually. To do this, after logging into the account that owns the bot, issue the command @BL Bot register
(use the name you gave it). The bot will respond by displaying 4 buttons that allow you to register or delete commands globally or only on this server.
Note: If you register commands globally remember that global commands can take up to 1 hour to update. During development, it is better to register them only on the test server, because they update immediately.
The description applies to Ubuntu Server 22.04 (x86_64), but it will look similar for other Linux distributions.
- Add
deploy
user and createdeployments
directory
sudo useradd -m -s /sbin/bash -d /home/deploy deploy
sudo -u deploy bash -c "mkdir -p /home/deploy/deployments"
- Install
supervisor
sudo apt install supervisor
- Update
/etc/supervisor/supervisord.conf
[unix_http_server]
file=/tmp/supervisor.sock
chown=deploy:deploy
chmod=0700
...
[supervisorctl]
serverurl=unix:https:///tmp/supervisor.sock
- Restart
supervisor
service
systemctl restart supervisor
- Add process configuration
/etc/supervisor/conf.d/your-program-name.conf
[program:your-program-name]
directory=/home/deploy/deployments/your-program-name
command=/home/deploy/deployments/your-program-name/your-program-name
environment=RUST_LOG="your_program_name=debug"
autostart=true
autorestart=true
stopasgroup=true
killasgroup=true
user=deploy
numprocs=1
redirect_stderr=true
stdout_logfile=/home/deploy/deployments/your-program-name/.logs/your-program-name.log
stdout_logfile_maxbytes=20MB
stdout_logfile_backups=30
stopwaitsecs=30
- Update config and start program
supervisorctl update your-program-name
-
Update program name in
.deploy/deploy.sh
and possibly the architecture of your server in.github/workflows/release.yml
-
Create SSH keys
ssh-keygen -t ed25519 -C "[email protected]"
and copy public key contents to /home/deploy/.ssh/authorized_keys
on your server. Make sure that both .ssh
directory and /home/deploy/.ssh/authorized_keys
file are owned by deploy:deploy
and have 0700
and 0600
permissions, respectively.
- Add GitHub actions secrets (Settings/Secrets and variables/Actions)
SSH_PRIVATE_KEY
- copy contents of your private SSH keySSH_HOST
- set it to your server IP addressSSH_USER
- set it todeploy
DEPLOY_PATH
- set it to/home/deploy/deployments
- Create
/home/deployments/YOUR-PROGRAM-NAME/.http-cache
,/home/deployments/YOUR-PROGRAM-NAME/.logs
and/home/deploy/deployments/YOUR-PROGRAM-NAME/.storage
directories. Copyassets
folder as/home/deploy/deployments/YOUR-PROGRAM-NAME/assets
. Copystatic
folder as/home/deploy/deployments/YOUR-PROGRAM-NAME/static
. Copyconfig.example.toml
as/home/deploy/deployments/YOUR-PROGRAM-NAME/config.toml
and set it up.
Every time you want to deploy a new version, just add the vX.Y.Z
(e.g. v0.1.1
) tag to your commit and push the code to the repository.