API Documentation

Documentation on how to use our API in your service

Overview

The goal of this API documentation is to accurately and precisely describe the functionality of this service in simple English. This page will go over everything you need to know before implementing our API into your service. If you believe there is anything missing, any typos, or incorrect information on this page, please reach out to us via email at [email protected].

Standards

The entirety of this API uses the standardized REST API, which in simple terms means you will be making HTTP requests to our service. We currently only support endpoints using the GET method. You will never have to use POST or any other method with requires you to send body data or headers with your request. All status endpoints return a response body in JSON format. No other data formatting standard is available at this time, and there is currently no future plan to support anything other than JSON. All JSON returned from this service will have whitespace and any unnecessary characters removed to reduce network bandwidth and wasted information. You may learn more about the properties you receive from these routes by reading the documented response body from the route on this page.

Cache

To reduce the amount of spam and deliberate denial-of-service attacks of our service, we implement a caching system for all of the data we fetch, including but not limited to status responses and server icons. Each route has its own cache duration specified in the documentation of said route. All routes with data retrieved from the cache will contain a header in the response with the key X-Cache-Time-Remaining with contains an integer as the amount of seconds remaining until the cache value expires. Any request made after this cache expiration time will result in fresh data being retrieved on our end. If you wish for an exception to this cache, you may reach out to our team by shooting an email to [email protected] with detailed information about your use case.

Supported Versions

All Minecraft servers, including pre-netty rewrite Java Edition and Bedrock Edition servers, are supported.Make sure you are using the correct endpoint when retrieving a server status, as attempting to use the Java Edition status route with a Bedrock Edition host (or vise-versa) will result in a response saying the server is offline unless the server explicitly has cross-play supported. If the server you specify does not use the standard port value (25565 for Java Edition, 19132 for Bedrock Edition), then you will need to specify the port by using the following format: host:port.

Routes

Java Status

GEThttps://api.mcstatus.io/v2/status/java/<address>

{
    // Determines whether the server is online or offline.
    // @type {boolean}
    "online": true,
    // The hostname of the server that was resolved from the address string.
    // @type {string}
    "host": "play.hypixel.net",
    // The port of the server that was resolved from the address string.
    // @type {number}
    "port": 25565,
    // Whether or not this server address has been blocked by Mojang.
    // If this is true, Notchian clients will not be able to connect to the
    // server via the Minecraft client because it previously violated the EULA.
    // @type {boolean}
    "eula_blocked": false,
    // The version data of the server. This will be null if the server 
    // version is pre-1.3.2. This property will be missing if the server
    // is offline.
    // @type {object?}
    "version": {
        // The version name of the server, typically modified by the server
        // itself to show version range. This value may contain special formatting
        // characters.
        // @type {string}
        "name_raw": "Requires MC 1.8 / 1.19",
        // The version name of the server, typically modified by the server
        // itself to show version range. This value will have all formatting
        // characters removed.
        // @type {string}
        "name_clean": "Requires MC 1.8 / 1.19",
        // The version name of the server, typically modified by the server
        // itself to show version range, as an HTML string with proper
        // formatting applied.
        // @type {string}
        "name_html": "<span><span style=\"color: #ffffff;\">Requires MC 1.8 / 1.19</span></span>",
        // The protocol version of the server which is used to identify
        // what client versions are supported.
        // @type {number}
        "protocol": 47
    },
    // Information about the amount of players online and *some* sample
    // players if provided. This property will be missing if the server
    // is offline.
    // @type {object?}
    "players": {
        // The amount of online players in the server.
        // @type {number}
        "online": 66870,
        // The maximum number of allowed players in the server.
        // @type {number}
        "max": 200000,
        // Some sample players online in the server. Most (if not all) major
        // servers disable this or modify the data for custom formatting. If you
        // do not have any items in this array, it is because the server has
        // disabled sample players for a reason.
        // @type {Array.<object>}
        "list": [
            {
                // The UUID of the player logged into the server.
                // @type {string}
                "uuid": "78d78fb0-eb86-3dde-a9fc-203ecf33072b",
                // The username of the player logged into the server. The server
                // may have plugins that modify this data to show special
                // formatting. This value may have formatting characters.
                // @type {string}
                "name_raw": "§5§m               §d§m          §7§m        §d§m          §5§m               ",
                // The username of the player logged into the server. The server
                // may have plugins that modify this data to show special
                // formatting. This value will not have any formatting characters.
                // @type {string}
                "name_clean": "                                                          ",
                // The username of the player logged into the server, as an HTML
                // string with proper formatting applied.
                // @type {string}
                "name_html": "<span><span style=\"color: #aa00aa; text-decoration: line-through;\">               </span><span style=\"text-decoration: line-through; color: #ff55ff;\">          </span><span style=\"color: #aaaaaa; text-decoration: line-through;\">        </span><span style=\"color: #ff55ff; text-decoration: line-through;\">          </span><span style=\"color: #aa00aa; text-decoration: line-through;\">               </span></span>"
            }
        ]
    },
    // The message of the day (or MOTD/description) of the server. This is the
    // message shown below the server name in the client multiplayer menu. This
    // property will be missing if the server is offline.
    // @type {object?}
    "motd": {
        // The raw MOTD with formatting codes. Refer to
        // https://minecraft.fandom.com/wiki/Formatting_codes for information
        // on how to use formatting codes.
        // @type {string}
        "raw": "                §aHypixel Network §c[1.8-1.19]\n       §b§lNEW: DROPPER §7§l| §6§lSUMMER EVENT§7§l+§e§lSALE",
        // A clean text-only version of the MOTD with all formatting codes removed.
        // @type {string}
        "clean": "                Hypixel Network [1.8-1.19]\n       NEW: DROPPER | SUMMER EVENT+SALE",
        // An HTML representation of the MOTD with proper formatting. All formatting
        // codes are supported and are equal to their value in the Minecraft fandom wiki.
        // Magic/obfuscated formatting codes are a <span> with the class `.minecraft-format-obfuscated`.
        // Line breaks are encoded as the "\n" escape code and may be replaced with <br> by the user.
        // @type {string}
        "html": "<span><span style=\"color: #ffffff;\">                </span><span style=\"color: #55ff55;\">Hypixel Network </span><span style=\"color: #ff5555;\">[1.8-1.19]</span><span style=\"color: #ffffff;\">\n       </span><span style=\"color: #55ffff; font-weight: bold;\">NEW: DROPPER </span><span style=\"color: #aaaaaa; font-weight: bold;\">| </span><span style=\"color: #ffaa00; font-weight: bold;\">SUMMER EVENT</span><span style=\"color: #aaaaaa; font-weight: bold;\">+</span><span style=\"font-weight: bold; color: #ffff55;\">SALE</span></span>"
    },
    // The base64-encoded PNG data of the 64x64 server icon. You may require
    // additional libraries or utilities for using this property. There are
    // several examples out there. This property may be null if the server does
    // not set an icon image. This property will also be missing if the server
    // is offline.
    // @type {string? | null}
    "icon": "",
    // Any Forge mods loaded if provided by the server. Most servers do not
    // have Forge installed so this property will be empty a majority of the time.
    // @type {Array.<object>?}
    "mods": [
        {
            // The name of the mod that is loaded on the server.
            // @type {string}
            "name": "Forge",
            // The version of the mod that is loaded on the server.
            // @type {string}
            "version": "v1.0.0"
        }
    ]
}

Bedrock Status

GEThttps://api.mcstatus.io/v2/status/bedrock/<address>

{
    // Determines whether the server is online or offline.
    // @type {boolean}
    "online": true,
    // The hostname of the server that was resolved from the address string.
    // @type {string}
    "host": "bedrock.vortexnetwork.net",
    // The port of the server that was resolved from the address string.
    // @type {number}
    "port": 19132,
    // Whether or not this server address has been blocked by Mojang.
    // If this is true, Notchian clients will not be able to connect to the
    // server via the Minecraft client because it previously violated the EULA.
    // @type {boolean}
    "eula_blocked": false,
    // The version data of the server. This property will be missing if
    // the server is offline.
    // @type {object?}
    "version": {
        // The version name of the server.
        // @type {string}
        "name": "1.19.10",
        // The protocol version of the server which is used to identify
        // what client versions are supported.
        // @type {number}
        "protocol": 534
    },
    // Information about the amount of online and max players. This property
    // will be missing if the server is offline.
    // @type {object?}
    "players": {
        // The amount of online players in the server.
        // @type {number}
        "online": 1633,
        // The maximum number of allowed players in the server.
        // @type {number}
        "max": 3000
    },
    // The message of the day (or MOTD/description) of the server. This is the
    // message shown below the server name in the client multiplayer menu. This
    // property will be missing if the server is offline.
    // @type {object?}
    "motd": {
        // The raw MOTD with formatting codes. Refer to
        // https://minecraft.fandom.com/wiki/Formatting_codes for information
        // on how to use formatting codes.
        // @type {string}
        "raw": "§d\\-§9/  §d§lVORTEX  §9\\-§d/\n§d§lSKYBLOCK PANDORA RELEASED §9- §d§l85% OFF SALE!",
        // A clean text-only version of the MOTD with all formatting codes removed.
        // @type {string}
        "clean": "\\-/  VORTEX  \\-/\nSKYBLOCK PANDORA RELEASED - 85% OFF SALE!",
        // An HTML representation of the MOTD with proper formatting. All formatting
        // codes are supported and are equal to their value in the Minecraft fandom wiki.
        // Magic/obfuscated formatting codes are a <span> with the class `.minecraft-format-obfuscated`.
        // Line breaks are encoded as the "\n" escape code and may be replaced with <br> by the user.
        // @type {string}
        "html": "<span><span style=\"color: #ff55ff;\">\\</span><span style=\"color: #ffffff;\">-</span><span style=\"color: #5555ff;\">/  </span><span style=\"color: #ff55ff; font-weight: bold;\">VORTEX  </span><span style=\"color: #5555ff;\">\\</span><span style=\"color: #ffffff;\">-</span><span style=\"color: #ff55ff;\">/</span><span style=\"color: #ffffff;\">\n</span><span style=\"color: #ff55ff; font-weight: bold;\">SKYBLOCK PANDORA RELEASED </span><span style=\"color: #5555ff;\">- </span><span style=\"color: #ff55ff; font-weight: bold;\">85% OFF SALE!</span></span>"
    },
    // The default gamemode that players will spawn into when joining
    // the server.
    // @type {string}
    "gamemode": "Survival",
    // The ID of the server itself. There is little to no documentation
    // online about the use of this value.
    // @type {string}
    "server_id": "904448693530150393",
    // The type of server that was retrieved. Possible values are "MCPE" for
    // Bedrock and Pocket Edition, or "MCEE" for Education Edition.
    // @type {"MCPE" | "MCEE"}
    "edition": "MCPE"
}

Icon

GEThttps://api.mcstatus.io/v2/icon/<address>

Sample server icon

Support

If you require any additional assistance or found a bug you would like to report, please send an email to [email protected].