Skip to content

Remote Console plugin for Minecraft Spigot written in mostly Java and Rust

License

Notifications You must be signed in to change notification settings

TobiasDeBruijn/rConsole

Repository files navigation

rConsole

Remote Console plugin for Minecraft Spigot

This plugin is under heavy development, and is still in beta

Features

  • Read console
  • Send commands
  • Simple API over TCP Sockets docs
  • Feature-rich api via HTTP docs
    • Get Console logs
    • Execute commands
    • Server metrics like CPU usage and memory usage
  • Fast and intuitive web frontend

Platform support

Because I use Rust code, this plugin will not work on all operating systems and architectures.
At the moment the following is supported:

  • x86_64 Linux
  • x86_64 Windows
  • x86_64 MacOS

I am working on support for aarch64 (ARM 64-bit, Raspberry Pi 4 and up) and armhf (ARM 32, Raspberry Pi 3 and lower) support, though this takes some work. Apple's M1 chips aren't supported and probably won't be for a long while.

On the agenda

  • File browser
  • Different permission levels for the webinterface

Config

The default configuration is as follows:

# rConsole general configuration
# Should debug logs be printed to the console
debugMode: true

# The port on which the TCP server will listen
listenPort: 8080

# Should we also load the web server
# Most users should keep this set to true
useWebServer: true

# Authentication tokens for the TCP server
tokens:
- name: TEST
  token: ABC
  scopes:
  - READ_CONSOLE
  - SEND_COMMAND

# This bit of configuration is specific to librconsole
# On which port should the webserver listen. This is also the port you'll use in the browser to access the web-interface
librconsolePort: 8090

# The password pepper to be used. This MUST not be longer than 16 characters. You should not leave this at the default
# This is used to encrypt passwords
pepper: mrsXlQy9friisbeW

# If you are not accessing the frontend through localhost, but through a domain e.g, enter it here
# e.g: https://rconsole.example.com
# You MUST not include a trailing slash, so https://rconsole.example.com/ is WRONG
# Keep in mind that rConsole does NOT do SSL termination, so if you want HTTPS, you must use a reverse proxy like NGINX
baseUrl: http://localhost:8090

Building

To build this plugin you need a couple of dependencies. These are the dependencies for Linux, since that's what I use.

  • gcc-mingw-w64
  • gcc
  • cargo
  • rustup
  • make
  • openjdk-11-jdk-headless
  • npm

Rustup toolchains:

  • stable-x86_64-pc-windows-gnu
  • stable-x86_64-unknown-linux-gnu
    Rustup targets:
  • x86_64-unknown-linux-gnu
  • x86_64-pc-windows-gnu

MacOS
Because we also want MacOS support, we need to do some extra work.

  1. rustup target add x86_64-apple-darwin
  2. Append to ~/.cargo/config:
[target.x86_64-apple-darwin]
linker = "x86_64-apple-darwin14-clang"
ar = "x86_64-apple-darwin14-ar"
  1. git clone /~https://github.com/tpoechtrager/osxcross
  2. cd osxcross
  3. wget https://s3.dockerproject.org/darwin/v2/MacOSX10.11.sdk.tar.xz
  4. mv MacOSX10.11.sdk.tar.xz tarballs/
  5. sed -i -e 's|-march=native||g' build_clang.sh build.sh
  6. UNATTENDED=yes OSX_VERSION_MIN=10.7 ./build.sh
  7. sudo mkdir -p /usr/local/osx-ndk-x86
  8. sudo cp -r target/* /usr/local/osx-ndk-x86
  9. Lastly, add /usr/local/osx-ndk-x86 to your PATH: export PATH=${PATH}:/usr/local/osx-ndk-x86/bin/

The Makefile will take care of the rest, assuming you've followed the instructions above.

To then build the project all you'd need to do is run make. This will build a releasejar, to create a testjar run make testjar.
a releasejar will be outputted to $projectRoot/releases, a testjar will be outputted to $projectRoot/server/plugins

To get the headers for the native function, for if you want the signature again, or something :)
javac -h . ./src/main/java/nl/thedutchmc/rconsole/webserver/Native.java

To get the signature from other methods, if you want to access them from native code:
javap -s ./build/classes/java/main/nl/thedutchmc/rconsole/<Path to the class>