All API routes on this page should be prefixed with https://paceman.gg/stats/api/
Returns nether enter count & average for a given timeframe
getSessionNethers?name=meebie&hours=24&hoursBetween=2
Returns nether enter count and average for latest session in the last 24 hours, ignoring runs behind a >2 hour break (in case there are multiple sessions in a day)
{
"count": 3,
"avg": "3:36"
}
getSessionStats?name=meebie&hours=730&hoursBetween=730
Returns all stats for 30-ish days (any hour values are valid, e.g 999999 for "lifetime")
{
"count": 20,
"avg": "5:40"
}
{"error": "Unknown user"}
# Status code 404
{
"count": 0,
"avg": "0:00"
}
# Status code 200
Returns counts & average for all splits in a given timeframe
getSessionStats?name=meebie&hours=24&hoursBetween=2
Returns stats for latest session in the last 24 hours, ignoring runs behind a >2 hour break (in case there are multiple sessions in a day)
{
"nether": {
"count": 2,
"avg": "4:36"
},
"bastion": {
"count": 0,
"avg": "0:00"
},
"fortress": {
"count": 0,
"avg": "0:00"
},
"first_structure": {
"count": 0,
"avg": "0:00"
},
"second_structure": {
"count": 0,
"avg": "0:00"
},
"first_portal": {
"count": 0,
"avg": "0:00"
},
"stronghold": {
"count": 0,
"avg": "0:00"
},
"end": {
"count": 0,
"avg": "0:00"
},
"finish": {
"count": 0,
"avg": "0:00"
}
}
getSessionStats?name=meebie&hours=730&hoursBetween=730
Returns all stats for 30-ish days (any hour values are valid, e.g 999999 for "lifetime")
{
"nether": {
"count": 1818,
"avg": "2:25"
},
"bastion": {
"count": 432,
"avg": "2:32"
},
"fortress": {
"count": 167,
"avg": "4:40"
},
"first_structure": {
"count": 464,
"avg": "2:26"
},
"second_structure": {
"count": 137,
"avg": "5:28"
},
"first_portal": {
"count": 108,
"avg": "7:04"
},
"stronghold": {
"count": 54,
"avg": "9:36"
},
"end": {
"count": 33,
"avg": "11:06"
},
"finish": {
"count": 13,
"avg": "10:33"
}
}
{"error": "Unknown user"}
# Status code 404
{
"nether": {
"count": 0,
"avg": "0:00"
},
# etc, other splits with 0's here
}
# Status code 200
first_structure
and second_structure
are recommended instead of bastion and fortresssecond_structure
requires either a rod if fort first, or >50 seconds between structures if bastion firstReturns count & average for a given split in a given timeframe
getSplitStats?name=meebie&split=bastion&maxTime=300000&hours=24&hoursBetween=2
Returns number of sub 5 bastions for latest session in the last 24 hours, ignoring runs behind a >2 hour break (in case there are multiple sessions in a day)
{
"count": 2,
"avg": "4:36"
}
{"error": "Unknown user"}
# Status code 404
{
"count": 0,
"avg": "0:00"
}
# Status code 200
first_structure
and second_structure
are recommended instead of bastion and fortresssecond_structure
requires either a rod if fort first, or >50 seconds between structures if bastion firstReturns data for a given run
getWorld/?worldId=31aad8ee0540af3a0573ac959e85f8b81f3941010d8cd20a33b67d04b29a0237
getWorld/?worldId=251471
{
"data": {
"id": 251471, # run id from stats db
"worldId": "31aad8ee0540af3a0573ac959e85f8b81f3941010d8cd20a33b67d04b29a0237", # world id from paceman api (hash of world file path)
"nickname": "dfanm", # mc username
"uuid": "4990072b-252e-42f2-aef9-45cd765f2425", # mc uuid
"twitch": "dfanm", # twitch account (or null)
"nether": 146952, # IGT in ms
"bastion": 200037, # IGT in ms (or null)
"fortress": null, # IGT in ms (or null)
"first_portal": null, # IGT in ms (or null)
"stronghold": null, # IGT in ms (or null)
"end": null, # IGT in ms (or null)
"finish": null, # IGT in ms (or null)
"netherRta": 152614, # RTA in ms
"bastionRta": 211353, # RTA in ms (or null)
"fortressRta": null, # RTA in ms (or null)
"first_portalRta": null, # RTA in ms (or null)
"strongholdRta": null, # RTA in ms (or null)
"endRta": null, # RTA in ms (or null)
"finishRta": null, # RTA in ms (or null)
"insertTime": 1715824744, # unix timestamp (secs) of nether enter
"updateTime": 1715824800, # unix timestamp (secs) of last split update
"vodId": 2146675569, # twitch VOD id (or null)
"vodOffset": 14503, # seconds from VOD start to run start (or null)
},
"time": 1715929618254, # unix timestamp (ms) when this data was last cached
"isLive": false # whether the run is currently in liveruns
}
null
# Status code 200
Returns recent runs for a user
getRecentRuns?name=meebie&hours=24&limit=1
Returns the most recent run for user "meebie" in the last 24 hours
[
{
"id": 252315, # run id from stats db
"nether": 128750, # IGT in ms
"bastion": 167565, # IGT in ms (or null)
"fortress": null, # IGT in ms (or null)
"first_portal": null, # IGT in ms (or null)
"stronghold": null, # IGT in ms (or null)
"end": null, # IGT in ms (or null)
"finish": null, # IGT in ms (or null)
"lootBastion": null, # IGT in ms (or null)
"obtainObsidian": null, # IGT in ms (or null)
"obtainCryingObsidian": null, # IGT in ms (or null)
"obtainRod": null, # IGT in ms (or null)
"time": 1715912736 # unix timestamp (secs) of nether enter
}
]
{"error": "Unknown user"}
# Status code 404
[]
# Status code 200
getWorld
Returns the leaderboard for a given category and type
1, 7, 30, 9999
nether
)nether, bastion, fortress, first_structure, second_structure, first_portal, second_portal, stronghold, end, finish
count
)count, average, fastest, conversion
getLeaderboard?category=nether&type=count&days=7&limit=1
Returns the player with the most nether entries in the last 7 days
[
{
"uuid": "eb77c626-a8ff-4d25-b095-7918a5d19b59", # mc uuid
"name": "Pjoes", # mc username
"value": 50, # value for given type (nether enter count)
"qty": 50, # qty (always present)
"avg": 112957.62 # avg (always present)
}
]
Returns unix timestamps for splits in recent runs
getRecentTimestamps/?name=jojoe_77777&limit=1
Returns timestamps for most recent run from player
[
{
"id": 123456, # run id
"runName": "3:23 Bastion", # last split of run
"start": 1714048026.945, # timestamp of run start (with decimals)
"nether": 1714048131, # no decimals sorry
"bastion": 1714048207.958, # with decimals (or null)
"fortress": null, # with decimals (or null)
"first_portal": null, # with decimals (or null)
"stronghold": null, # with decimals (or null)
"end": null, # with decimals (or null)
"finish": null, # with decimals (or null)
"realUpdate": null # more accurate but nullable, no decimals
"lastUpdated": 1714048207 # always exists but affected by db patches, no decimals
}
]
{"error": "Unknown user"}
# Status code 404
{"error": "No data found for this user"}
# Status code 404
Secret API to get all runs from all users for a given timeframe, DM jojoe77777 on Discord for access
Warning: This endpoint can be very slow and take a long time to return data