Nasze serwery z mocami przeszły prawdziwą metamorfozę!

Nowe możliwości, lepsza rozgrywka i jeszcze więcej frajdy czeka właśnie na Ciebie 😎 Wpadaj, sprawdź zmiany i daj się zaskoczyć!

✨ Get FREE TRIAL SVIP for 3 days

Log in and connect Discord to claim your free premium access

🍪 Cookie consent

We use cookies to enhance your experience, analyze traffic and ensure security. We also use external services (Bunny.net for CDN/protection, YouTube, TikTok, Google APIs). By clicking Accept, you consent to all cookies. Learn more

UtopiaFPS
UtopiaFPS

Navigation

Developer API

Documentation API

RESTful API interface for CS2 server status and penalty data. Complete documentation for developers.

Login required

To generate an API token, you must be logged in.

Login via Steam

Getting started

The UtopiaFPS API provides programmatic access to server status information and penalty records. All responses are in JSON format and include cache headers for optimal performance.

Base URL

https://utopiafps.pl/api/v1

Rate limits

  • Public endpoints 30 requests per minute
  • Protected endpoints 60 requests per minute (API token required)

Authentication

Protected endpoints require an API token. Include your token in the Authorization header:

Authorization: Bearer YOUR_API_TOKEN

Alternatively you can pass the token as a query parameter: ?api_token=YOUR_TOKEN

?api_token=YOUR_API_TOKEN

PUBLIC Server Endpoints

GET /servers

Retrieve a list of all servers with their current status.

Example response

{
  "success": true,
  "data": [
    {
      "id": 1,
      "name": "Server #1",
      "slug": "server-1",
      "hostname": "UtopiaFPS Server #1",
      "ip": "51.75.59.212:27015",
      "map": "de_dust2",
      "mode": "casual",
      "region": "pl",
      "players_count": 12,
      "max_players": 32,
      "is_online": true,
      "ping_ms": 25,
      "updated_at": "2025-01-23T12:34:56+00:00"
    }
  ],
  "meta": {
    "total": 5,
    "online": 3,
    "cached_at": "2025-01-23T12:34:56+00:00"
  }
}
GET /servers/{slug}

Get detailed information about a specific server using its slug.

Example response

{
  "success": true,
  "data": {
    "id": 1,
    "name": "Server #1",
    "slug": "server-1",
    "hostname": "UtopiaFPS Server #1",
    "ip": "51.75.59.212:27015",
    "map": "de_dust2",
    "mode": "casual",
    "region": "pl",
    "players_count": 12,
    "max_players": 32,
    "is_online": true,
    "ping_ms": 25,
    "updated_at": "2025-01-23T12:34:56+00:00",
    "players": [
      {
        "name": "PlayerName1",
        "score": 150
      },
      {
        "name": "PlayerName2",
        "score": 120
      }
    ]
  },
  "meta": {
    "cached_at": "2025-01-23T12:34:56+00:00"
  }
}

PROTECTED Penalty Endpoints

GET /penalties

Retrieve all penalties (bans, mutes, gags, silences, warnings) with optional filters.

Query parameters

  • type - Filter by penalty type (ban, mute, gag, silence, warn or empty for all)
  • status - Filter by status active expired unbanned
  • server_id - Filter by server ID
  • steamid - Filter by player SteamID64
  • admin_steamid - Filter by admin SteamID64
  • per_page - Results per page (default 50, max 100)
  • page - Page number

Example response

{
  "success": true,
  "data": [
    {
      "penalty_type": "ban",
      "id": 123,
      "player_name": "PlayerName",
      "player_steamid": "76561198012345678",
      "admin_name": "AdminName",
      "admin_steamid": "76561198087654321",
      "reason": "Cheating",
      "duration": 0,
      "status": "ACTIVE",
      "server_id": 1,
      "created": "2025-01-23T12:00:00+00:00",
      "ends": null
    },
    {
      "penalty_type": "gag",
      "id": 456,
      "player_name": "AnotherPlayer",
      "player_steamid": "76561198099999999",
      "admin_name": "AdminName",
      "admin_steamid": "76561198087654321",
      "reason": "Spam",
      "duration": 3600,
      "status": "ACTIVE",
      "server_id": 1,
      "created": "2025-01-23T11:00:00+00:00",
      "ends": "2025-01-23T12:00:00+00:00"
    }
  ],
  "meta": {
    "current_page": 1,
    "total": 250,
    "per_page": 50,
    "last_page": 5,
    "counts": {
      "ban": 100,
      "gag": 50,
      "mute": 40,
      "silence": 30,
      "warn": 30
    },
    "cached_at": "2025-01-23T12:34:56+00:00"
  }
}
GET /bans

Retrieve a paginated list of bans with optional filters.

Query parameters

  • status - Filter by status active expired unbanned
  • server_id - Filter by server ID
  • steamid - Filter by player SteamID64
  • per_page - Results per page (default 50, max 100)
  • page - Page number

Example response

{
  "success": true,
  "data": [
    {
      "id": 123,
      "player_name": "PlayerName",
      "player_steamid": "76561198012345678",
      "admin_name": "AdminName",
      "admin_steamid": "76561198087654321",
      "reason": "Cheating",
      "duration": 0,
      "status": "ACTIVE",
      "server_id": 1,
      "created": "2025-01-23T12:00:00+00:00",
      "ends": null
    }
  ],
  "meta": {
    "current_page": 1,
    "total": 150,
    "per_page": 50,
    "last_page": 3,
    "cached_at": "2025-01-23T12:34:56+00:00"
  }
}
GET /mutes

Retrieve a paginated list of bans with optional filters.

Query parameters

  • status - Filter by status
  • server_id - Filter by server ID
  • steamid - Filter by player SteamID64
  • type - Filter by type: gag, mute, silence
  • per_page - Results per page (default 50, max 100)
  • page - Page number

Response structure similar to bans endpoint

GET /warns

Retrieve a paginated list of bans with optional filters.

Query parameters

  • status - Filter by status
  • server_id - Filter by server ID
  • steamid - Filter by player SteamID64
  • per_page - Results per page (default 50, max 100)
  • page - Page number

Error responses

401 Unauthorized

{
  "success": false,
  "message": "API token is required"
}

404 Not Found

{
  "success": false,
  "message": "Server not found"
}

429 Too Many Requests

When the rate limit is exceeded, you will receive a 429 status code with retry information in the headers.