The core of the Chaotic server network, maintained by Xpdustry.
You will need:
- Java 17
- Docker
For simply compiling the project, run ./gradlew shadowJar
.
If you also want to run the tests, first, make sure docker is running, then run ./gradlew build
.
If you only want to compile one of the subprojects,
just prefix the task name with the subproject name such as ./gradlew :imperium-discord:shadowJar
.
Imperium needs a mariadb database and a rabbitmq server to run in production.
But for local testing, it will default to h2 and a noop message broker.
If you wish to test with the production setup, use the provided docker-compose file.
You will simply have to run docker-compose up -d
once, then update the configuration file accordingly.
RabbitMQ has a web front-end at http://localhost:15672, you can log in with guest:guest.
First, create the base configuration file named config.yaml
in the directory imperium-mindustry/build/tmp/runMindustryServer/config/mods/imperium
,
with the following content:
# Enable this so the server create presets for easier testing, look out for warnings in the console
# DO NOT USE IT IN PRODUCTION
testing: true
mindustry:
gamemode: SURVIVAL
Then for starting a local mindustry server, run ./gradlew imperium-mindustry:runMindustryServer
.
- This will start a server that you can interact with in the console.
To play on this server, you can start a mindustry client by running ./gradlew imperium-mindustry:runMindustryClient
.
- This client is isolated from your local mindustry installation so no need to worry about your data.
First, create discord bot and a test server for it (there are plenty of online tutorials for that).
Then create the base configuration file named config.yaml
in the directory imperium-discord/build/tmp/runShadow
,
with the following content:
discord:
token: "your discord bot token"
categories:
live-chat: "some channel id"
channels:
notifications: "some channel id"
maps: "some channel id"
reports: "some channel id"
# Optional
# permissions2roles:
# MANAGE_MAPS: "some role id"
# achievements2roles:
# ACTIVE: "some role id"
ranks2roles:
OWNER: "some role id"
# Optional roles to add for further testing
# ADMIN: "some role id"
# MODERATOR: "some role id"
# VERIFIED: "some role id"
webserver:
port: 8080
Then you can start the discord bot by running ./gradlew imperium-discord:runShadow
.
If it's the first time you run it, it will automatically download mindustry assets from GitHub, this might take less than a minute. (Or more if you have potato internet
;-;
)
This plugin is open source for transparency and also easing contributions from CN players. You are free to ask any question about the internals of this project in the issues tab or on discord.
BUT, do not expect any support if you are trying to use this project as it is in your own infrastructure. This project is written with the xpdustry infrastructure and features in mind after all.