Skip to content
forked from xpdustry/imperium

ImperiumV2 and Nucleus had a baby.

License

Notifications You must be signed in to change notification settings

weblate/imperium

 
 

Repository files navigation

imperium

The core of the Chaotic server network, maintained by Xpdustry.

Building

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.

Testing

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.

Mindustry

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.

Discord

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 ;-;)

Support

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.

About

ImperiumV2 and Nucleus had a baby.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Kotlin 100.0%