Documentation API
RESTful API interface for server status and penalty data
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_API_TOKEN
PUBLIC Server Endpoints
/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"
}
}
/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
/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 IDsteamid- Filter by player SteamID64admin_steamid- Filter by admin SteamID64per_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"
}
}
/bans
Retrieve a paginated list of bans with optional filters.
Query parameters:
status- Filter by status (ACTIVE, EXPIRED, UNBANNED)server_id- Filter by server IDsteamid- Filter by player SteamID64per_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"
}
}
/mutes
Retrieve a paginated list of mutes with optional filters.
Query parameters:
status- Filter by statusserver_id- Filter by server IDsteamid- Filter by player SteamID64type- Filter by type (GAG, MUTE, SILENCE)per_page- Results per page (default: 50, max: 100)page- Page number
Response structure similar to bans endpoint
/warns
Retrieve a paginated list of warnings with optional filters.
Query parameters:
status- Filter by statusserver_id- Filter by server IDsteamid- Filter by player SteamID64per_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.