prepare(" SELECT id, content, deleted_at, userId FROM chats WHERE deleted_at = 0 ORDER BY id DESC LIMIT 500 "); $stmt->execute(); $result = $stmt->get_result(); $rows = $result->fetch_all(MYSQLI_ASSOC); $mapped = []; $icons = []; foreach ($rows as $row) { $userId = $row["userId"]; $stmt2 = $conn1->prepare("SELECT legacy_high_score, save_data FROM userdata WHERE id = ? LIMIT 1"); $stmt2->bind_param("i", $userId); $stmt2->execute(); $result2 = $stmt2->get_result(); if ($result2->num_rows != 1) continue; $row2 = $result2->fetch_assoc(); $stmt3 = $conn0->prepare("SELECT username FROM users WHERE id = ? LIMIT 1"); $stmt3->bind_param("i", $userId); $stmt3->execute(); $result3 = $stmt3->get_result(); if ($result3->num_rows != 1) continue; $row3 = $result3->fetch_assoc(); $savedata = json_decode($row2['save_data'], true); $customIcon = $savedata['bird']['customIcon']['selected'] ?? null; if ($customIcon != null && strlen($customIcon) == 36 && $icons[$customIcon] == null) { $stmt = $conn1->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' => $row3['username'], 'userid' => $row['userId'], 'content' => (int)$row['deleted_at'] == 0 ? $row['content'] : null, 'deleted' => (int)$row['deleted_at'] != 0, 'id' => $row['id'], '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, ]; } if (getClientVersion() == "1.6") { echo encrypt(json_encode($mapped)); } else { echo encrypt(json_encode(["messages" => array_reverse($mapped), "customIcons" => $icons == [] ? new stdClass() : $icons])); } $conn0->close(); $conn1->close();