A Discord bot to remotely control and manage multiple Minecraft servers.
βΆοΈ easily start and stop servers via Discord Bot commands- π switch between servers with different configurations on the fly
- π optional automatic server shutdown when server is empty to save resources
- π₯οΈ well-thought-out user interface
- π¨ advanced error handling
- π‘ designed for easy self-hosting
- create an Discord Bot and note down its API key (for example using this guide)
-
get at least one server running Linux
-
make sure that the Special Host System Requirements are installed and enabled
-
if the control programm runs on another server, get the IP-Address of the server
-
if the control programm runs on another server and you want to be able to shutdown the whole host server, get the MAC-Address of the server
-
setup a Minecraft server, with an option to start it via terminal commands
- install Docker
- pull image
ghcr.io/2mal3/somnus:latest
- run the image with the required Environment Variables you got in step 1 and 2
- install Rye
- clone the somnus repository onto your server
- install Python dependencies with
rye sync
- fill the
.env
file with the required Environment Variables you got in step 1 and 2 (you can use the.env.example
file for reference) - start Discord bot with
rye run prod
Command | Description | Requires Super User |
---|---|---|
/start |
Starts the Minecraft server (and if necessary the server via Wake On Lan before) | no |
/stop |
Stops the Minecraft server and then shuts down the server | no |
/change_world |
Creates a drop-down menu in which the world to be switched to can be selected. The next time the server is started (with /start or /restart ), the selected world is started. |
no |
/restart |
Restarts the Minecraft server process, not the hole server. | no |
/show_worlds |
Shows all available worlds. (Super users are shown all worlds, including those not currently visible, and are also shown whether the respective world is visible) | no |
/ping |
Replies with "Pong" | no |
/reset_busy |
If the message that the bot is busy is sent by mistake, this command can reset the incorrect busy state. | no |
/get_players |
Shows all players who are online on the server. | no |
/help |
Displays all relevant commands from this bot with an explanation. | no |
/add_world |
Creates a new reference to an installed Minecraft installation with the new display_name, start_cmd and the Booleans sudo_start_cmd (whether the start command should be executed with sudo rights) and visible (whether the world should be visible and selectable by normal users) | yes |
/edit_world |
Edits and shows a reference to an installed Minecraft installation. The (old) display_name of the world reference has to be specified. Optionally, a new display_name, start_cmd, sudo_start_cmd or visble can be specified. All values updated after the possible change are then returned. This means that even without specifying the optional new parameters, only the currently saved status of the world can be displayed. | yes |
/delete_world |
Deletes a reference to an installed Minecraft installation after renewed approval. | yes |
/stop_without_shutdown |
Stops the Minecraft server, but doesn't shut it off | yes |
Env Var | Type | Required | Default | Description |
---|---|---|---|---|
DISCORD_TOKEN | string | yes | your discord bot token | |
HOST_SERVER_HOST | string | yes | ip adress of your host server on which the Minecraft server process should be started | |
HOST_SERVER_USER | string | yes | username on host server | |
HOST_SERVER_PASSWORD | string | yes | password for the user on host server | |
HOST_SERVER_MAC | string | yes | mac adress of host server (only necessary if Wake On Lan is activated) | |
MC_SERVER_START_CMD | string | yes | start command for minecraft server (use absolute path if possible) | |
MC_SERVER_ADDRESS | string | yes | minecraft server adress WITH PORT | |
DISCORD_SUPER_USER_ID | integer | no | discord user id's separated with β;β from discord users who should have access to superuser commands | |
GET_PLAYERS_COMMAND_ENABLED | boolean | no | true | if the "/get_players" command is enabled (returns all player names of players who are online) |
MC_SERVER_START_CMD_SUDO | boolean | no | false | if the minecraft server should start with sudo rights |
LANGUAGE | string | no | en | display language for the discord bot ("en" -> english, "de" -> deutsch/german are included) |
HOST_SERVER_SSH_PORT | integer | no | 22 | ssh port of the host server |
INACTIVITY_SHUTDOWN_MINUTES | integer | no | none | time after which the server shuts down if nobody is online. Use "" so that the server doesn't shut down automatically |
DISCORD_STATUS_CHANNEL_ID | integer | no | none | discord channel id of the channel in which the automatic inactivity server shutdown message is sent |
DEBUG | boolean | no | false | server does not shut down and faster timeouts if set to βtrueβ |
DEBUG_LOGGING | boolean | no | false | debug messages are displayed |
-
bash
as default shell -
ssh
-
screen
2mal3 π» π π€ π¦ |
E44 π π» π π€ π π |
MCsharerGIT π π€ π π |
License - LGPL-3.0