Grab the Server release from the Releases page. Unzip it to anywhere you want.
The server needs a patched version of Distance's code to run:
- Grab the Patcher. If you're on Windows, this comes with the Windows zip.
- Open up your copy of Distance. If you got Distance through Steam, this will be at
C:\Program Files (x86)\Steam\steamapps\common\Distance
. If otherwise, then you should know its install location. - Navigate to the
Distance\Distance_Data\Managed
directory. - Drag
Assembly-CSharp.dll
toPatcher.exe
. - If you're using the Windows zip,
Distance.dll
is already in the correct place. Otherwise, moveDistance.dll
to the same directory asDistanceServer.exe
.
Server launch arguments:
Argument | Description |
---|---|
-serverdir |
Sets the server config directory. The server config directory houses all setting files for a server. If not set, then the server executable directory is used. |
-nodefaultplugins |
By default, the server will load all plugins in server executable directory/Plugins . This turns that off. |
-noserverplugins |
By default, the server will load all plugins in server config directory/Plugins . This turns that off. |
-plugin <plugin file path> |
Loads a specific plugin. |
-pluginsdir <plugin dir path> |
Loads all plugins in the specified directory. |
-loadfrom |
Uses an alternative method to load plugin dlls. Not recommended. |
-batchmode -nographics |
Unity args on Windows to run the server without graphics. You will have to manually kill the process through the task manager. |
-logFile |
Unity arg to set log file location. It is recommended to set this as the same as your server config directory. |
The server will read base server settings from a file in the server config directory names Server.json
:
Setting | Description |
---|---|
"PluginsDir": ["path/to/directory", "path/to/directory"] |
Include plugins from multiple directories |
"Plugins": ["path/to/plugin", "path/to/plugin"] |
Include plugins from multiple files |
Additional configuration can be done through plugins that read config files or apply hardcoded settings.
The server supports plugins. Plugins are intended to work like scripts that use the server's API to customize server functionality. Most plugins provide limited customization through config files, and extended customization can be done by modifying the plugin code.
Default plugins
Plugin | Description |
---|---|
Vanilla | A plugin to provide vanilla functionality, such as some messages and countdowns. |
BasicAutoServer | A plugin to run a server over a set of maps continuously. By default it loops through all campaign maps, and can be configured to build a list of levels using Steam Workshop searches. |
VoteCommands | A plugin to let players vote to play workshop levels. Votes work in a Mario Kart-like manner: as if a wheel spins and chooses a level, so more votes makes a level more likely, but any voted-for level may be chosen. |
WorkshopSearch | A plugin that allows other plugins -- such as BasicAutoServer and VoteCommands -- to search the Steam Workshop. This plugin does not provide configuration. |
RealmsFilter | A plugin to filter in/out Realms maps. Since these two map types are fundamentally different and since the community is split between both map types, it is good to keep the two separate to keep both groups happy and prevent vote trolling. |
HttpConsole | A plugin to provide information about the server and its players over a small web server. This provides no method for authentication, so configuration allows for limiting displayed info for privacy. |
See PLUGINS.md
for plugin configuration and usage.
See Examples/PluginConfiguration
for example plugin configuration.
See the PLUGINDEV.md
for info on developing your own plugins.
On Windows, the server provides a basic UI unless launched with -batchmode -nographics
. If the executable directory is used as the config directory, then you can double click the exe to launch the server.
On Linux, the server does not provide a UI. You can check the server log by opening the file or using the HttpConsole plugin. The server can be closed with pkill
, other task killing commands, or a task manager equivalent.
An example script to run multiple servers from multiple directories is provided in Examples/MultipleServersSingleExecutable
.
- Add a
Plugins
folder next toAutoServer.exe
- Add the plugins you want to use to the
Plugins
folder - Add the default config files for plugins next to
AutoServer.exe
- Run
AutoServer.exe
. The plugins inPlugins
will be loaded by default and use the settings from your config files.
The server, plugins, patcher, and network debugger can be opened using Visual Studio 2017.
Since this project uses git submodules, you can either do your initial clone of the project using:
git clone --recursive https://github.com/Corecii/Distance-Server
Or you can clone the repository, then init all submodules:
git clone https://github.com/Corecii/Distance-Server
git submodule update --init --recursive
The network debugger is a Spectrum mod that...
- Prints out all global events and their indexes.
- Prints out all instanced events and their indexes.
- Prints out whenever it receives an event of any type, with the associated data for that event call.
- Prints out a list of all official levels, for use in making the default playlist.
The network debugger can be used to update the events lists, investigate unimplemented server functionality, and rebuild the default campaign playlist.
When new functionality is implemented, it should go...
- In the base server, if it involves common network routines or an implementation of default distance data types and networking processes. (e.g. the process of adding a player to the game)
- In the Vanilla plugin, if it involves optional, but default behaviors such as messages, timers, or game modes that Distance uses. (e.g. messages, end-of-level countdown, and the sprint, tag, and stunt gamemodes)
- In other plugins or a new plugin, it it involves optional additional functionality (e.g. auto servers, tournament servers, user interface, map voting)
The server is meant to be used with plugins in all scenarios, so don't shy away from implementing additional functionality in plugins. The base server should be very lightweight and offer little functionality without additional scripting (i.e. plugins).
If you would like to provide the server in an easy-to-use package, then it is reasonable to bundle the base server with plugins and a launcher/UI without modifying the base server directly.
The server is set up to make testing easy. Each plugin copies its files to the default Plugins directory when built. The external server dll copies to the executable directory when built. The server project comes with configuration files that make testing the plugins and the servee as a whole easy.
Build all the plugins and the external server in Visual Studio. Run the server in Unity. The server should load all plugins and their config files into a local server that does not report to the master server. You can test it by joining 127.0.0.1
or your local IP address if connecting from another local computer.
- Windows zips should contain:
- The server in development mode for 64 bit
- The plugins, in a Plugins directory in the server executable directory
- DistanceServerBaseExternal.dll, in the server executable directory
- The Patcher, with Patcher.exe and its dependencies in the server executable directory
- Linux zips should contain:
- The server in headless mode for 64 bit
- The plugins, in a Plugins directory in the server executable directory
- DistanceServerBaseExternal.dll, in the server executable directory
- The Patcher zip should contain the Patcher in its own folder built for Windows
The batch script, release-prepare.bat
, will prepare these files on Windows. Existing files will be deleted before preparing so that if anything fails to prepare, it will be missing instead of outdated.
This project uses semantic versioning: major.minor.patch
- The
major
number indicates likely incompatibilities between releases for plugins using the API. - The
minor
number indicates releases that are backwards-compatible and introduce new features or API. - The
patch
number indicates small changes like bugfixes or mini features that usually do no change the API but do change behavior.
Additionally, this patch has an optional "fork code": fork.major.minor.patch
. If you fork the project and implement breaking changes, you can change the fork code to indicate that your fork's version numbers are not compatible with other forks' version numbers. The fork code for the original branch is an empty string.
During 0.x.x
releases, minor pathes are also treated as breaking changes. API-breaking changes are expected until version 1.x.x!
The starter uses a simple versioning scheme, where each increment of the number indicates an incompatibility with older versions.
The user is warned of any possible version compatibilities when plugins or the starter are loaded.