Server HTTP API

The server has an embedded HTTP API for fetching status and sending commands remotely. This describes that API.

By default, this HTTP API listens on the same port number as the game UDP port, but this can be changed with the relevant status.* CVars.

Warning

This article uses comments in JSON to make stuff easier to describe. This is not standard JSON and just for example here. Don’t put comments in JSON for real data.

Content can add more APIs to this.

Public API (no authorization needed)

GET /status

Gets basic status info about the server as JSON, used to display the status in the SS14 launcher. The engine automatically supplies the following info:

// Note: comments are not valid in JSON normally, but it makes annotating stuff here easy.
{ 
    "name": "MyServer", // Server name
    "players": 5, // Amount of players on the server
    "soft_max_players": 10, // Optional, max player count on the server.
    "tags": ["rp:low"], // Optional, array of tags (see below for standard values)
}

Content can edit this info at will.

GET /info

More detailed JSON server information that is mostly necessary when connecting to the server (to download resources and some other stuff).

{
  	"connect_addrees": "", // udp:// URI that specifies UDP connection address. Automatically guessed to be same port as status API if left out.
    "auth": {
  			"mode": "Required", // Auth mode. Can be one of "Optional", "Required", "Disabled"
        "public_key": "", // Public encryption key of server to use when authenticating. This uses libsodium's "sealed box" API.
    },
    "build": { // Information about build to download. See below.
    },
    "desc": "My amazing server", // Optional, generic description for the server, shown in the fold in the launcher.
    "links": [ // Set of links to show in the launcher for this server.
        {
            "name": "Discord", // Name of the button shown in the launcher.
            "icon": "discord", // Icon to use for this button, can be left out. See below for valid icon names.
            "url": "https://discord.gg/abcdef" // Link this button opens when pressed. Must be http:// or https://
        }
    ],
    // Optional, specifies information about a privacy policy that players must agree with.
    "privacy_policy": {
        // Link that contains the privacy policy, accessible via web browser.
        "link": "https://example.com/privacy",
        // An identifier that will be stored by the launcher when accepted.
        // THIS SHOULD BE UNIQUE FOR EVERY SERVER COMMUNITY. DON'T JUST COPY PASTE THIS FROM SOMEBODY ELSE.
        "identifier": "example",
        // The "version" of the privacy policy. This should be changed if the server's privacy policy has been updated.
        "version": "example"
    }
}

For details about build information, see Advanced Server Build Configuration.

Content can also edit this at will.

Watchdog API

Requires authorization by specifying the WatchdogToken HTTP header to match the watchdog.token CVar (automatically set when using the watchdog).

POST /shutdown

Instructs the server to gracefully shut down immediately.

POST /update

Instructs the server that an update is available and that it should automatically shut down as soon as possible to allow for the update to be applied. For SS14, this means the server will restart when the current round ends.

These are the valid icons for the links in the info API:

  • discord
  • forum
  • github
  • web: Generic website icon
  • wiki

Standard tags

These are standard understood tags for the tags field in status data. The launcher supports filtering and other behaviors based on these tags.

18+

Your server contains 18+ content.

lang:

Specifies Describes the language used on your server with an IETF Language Tag. Examples: lang:en for English, lang:ru for Russian, etc…

You can have multiple of this tag to specify multiple languages, if for some reason you want a multilingual server?

You can specify a more detailed IETF language tag like en-US, but the launcher will currently only look at the primary tag (e.g. en).

rp:none, rp:low, rp:med, rp:high

Specifies level of RP (roleplay) expected on your server. This is very subjective.

region:

Specifies a rough region code to aid players in selecting servers close to them. Following codes are understood:

CodeRegion
region:eu_wWest Europe
region:eu_eEast Europe
region:ataAntarctica (meme option)
region:grlGreenland (meme option)
region:am_n_wNorth America West
region:am_n_cNorth America Central
region:am_n_eNorth America East
region:am_cCentral America
region:am_s_sSouth America South
region:am_s_eSouth America East
region:am_s_wSouth America West
region:af_nNorth Africa
region:af_cCentral Africa
region:af_sSouth Africa
region:meMiddle East
region:as_nNorth Asia
region:as_seSouth East Asia
region:as_eEast Asia
region:indIndia
region:oceOceania
region:lunaThe Moon (meme option)

See this map for rough guidance what goes where:

region_map_ss14.png

If your region doesn’t have a good fit, let us know!

no_tag_infer

Stops automatic tag inference, see below.

Tag inference

Some hub tags are automatically inferred by the launcher based on server name. This is mostly intended to provide some filters before all servers fill them in manually, so if you’re reading this as a server host, just fill in your tags manually and you can ignore this. Rules are as follows:

  • If you specify no_tag_infer, no tag inference is done at all.
  • [18+] or [+18] automatically adds the 18+ tag.
  • [NRP/LRP/MRP/HRP] automatically add the relevant roleplay level as a tag, if you have no explicit role-play tag at all.
  • [EN] and [RU] add English and Russian as a tag respectively, if you have no explicit language tag at all.

We will not be adding extra rules (e.g. detecting more languages) to this. Tag your server manually.

Subpages