Files
legacy-server/database/getTopPlayers.php

77 lines
2.3 KiB
PHP

<?php
require __DIR__ . '/../incl/util.php';
setPlainHeader();
if ($_SERVER['HTTP_REQUESTER'] == 'BerryDashLauncher') {
$request_type = '0';
} else {
checkClientDatabaseVersion();
$post = getPostData();
$request_type = $post['type'] ?? '';
}
$conn = newConnection();
$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",
5 => "totalCoinBerries",
default => "totalNormalBerries"
};
} else {
exitWithMessage(json_encode([]));
}
$stmt = $conn->prepare("SELECT username, id, save_data
FROM users
WHERE banned = 0 AND leaderboardsBanned = 0");
$stmt->execute();
$result = $stmt->get_result();
$rows = $result->fetch_all(MYSQLI_ASSOC);
$mapped = [];
$icons = [];
foreach ($rows as $row) {
$savedata = json_decode($row['save_data'], true);
if (!$savedata) continue;
$value = $savedata['gameStore'][$request_value] ?? 0;
if ($value <= 0) continue;
$customIcon = $savedata['bird']['customIcon']['selected'] ?? null;
if ($customIcon != null && strlen($customIcon) == 36 && $icons[$customIcon] == null) {
$stmt = $conn->prepare("SELECT data FROM marketplaceicons WHERE uuid = ?");
$stmt->bind_param("s", $customIcon);
$stmt->execute();
$result = $stmt->get_result();
$rowData = $result->fetch_assoc();
if ($rowData) {
$stmt->close();
$icons[$customIcon] = $rowData["data"];
}
}
$mapped[] = [
'username' => $row['username'],
'userid' => $row['id'],
'value' => $value,
'icon' => $savedata['bird']['icon'] ?? 1,
'overlay' => $savedata['bird']['overlay'] ?? 0,
'birdColor' => $savedata['settings']['colors']['icon'] ?? [255,255,255],
'overlayColor' => $savedata['settings']['colors']['overlay'] ?? [255,255,255],
'customIcon' => $customIcon
];
}
usort($mapped, fn($a,$b) => $b['value'] <=> $a['value']);
$limited = array_slice($mapped, 0, 500);
echo encrypt(json_encode(["entries" => $limited, "customIcons" => $icons]));
$conn->close();