Add leaderboards endpoint
This commit is contained in:
32
database/getTopPlayers.php
Normal file
32
database/getTopPlayers.php
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
<?php
|
||||||
|
require __DIR__ . '/../incl/util.php';
|
||||||
|
setPlainHeader();
|
||||||
|
checkClientDatabaseVersion();
|
||||||
|
$conn = newConnection();
|
||||||
|
|
||||||
|
$post = getPostData();
|
||||||
|
$request_type = $post['type'] ?? '';
|
||||||
|
|
||||||
|
$request_value = "";
|
||||||
|
if ($request_type === "0") {
|
||||||
|
$request_value = "highScore";
|
||||||
|
} else if ($request_type === "1") {
|
||||||
|
$request_value = match((int)$post['showType'] ?? 0) {
|
||||||
|
1 => "totalPoisonBerries",
|
||||||
|
2 => "totalSlowBerries",
|
||||||
|
3 => "totalUltraBerries",
|
||||||
|
4 => "totalSpeedyBerries",
|
||||||
|
default => "totalNormalBerries"
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
exitWithMessage(json_encode([]));
|
||||||
|
}
|
||||||
|
|
||||||
|
$stmt = $conn->prepare("SELECT username, `$request_value`, icon, overlay, id, birdR, birdG, birdB, overlayR, overlayG, overlayB FROM users WHERE `$request_value` != 0 AND banned = 0 AND leaderboardsBanned = 0 ORDER BY `$request_value` DESC LIMIT 500");
|
||||||
|
$stmt->execute();
|
||||||
|
|
||||||
|
$result = $stmt->get_result();
|
||||||
|
|
||||||
|
echo encrypt(json_encode(array_map(fn($row) => ['username' => $row['username'], 'userid' => $row['id'], 'value' => $row[$request_value], 'icon' => $row['icon'], 'overlay' => $row['overlay'], 'birdColor' => [$row['birdR'], $row['birdG'], $row['birdB']], 'overlayColor' => [$row['overlayR'], $row['overlayG'], $row['overlayB']]], $result->fetch_all(MYSQLI_ASSOC)), JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES));
|
||||||
|
|
||||||
|
$conn->close();
|
||||||
Reference in New Issue
Block a user