Make loadAccount.php work with new db method

This commit is contained in:
2025-12-31 19:21:50 -07:00
parent 9b499e35f4
commit f511da6f21
3 changed files with 98 additions and 62 deletions

View File

@@ -1,23 +1,62 @@
<?php <?php
if (getClientVersion() == "1.5.2") {
$post = getPostData();
$token = $post['gameSession'] ?? '';
$username = $post['userName'] ?? '';
} else if (getClientVersion() == "1.5.0" || getClientVersion() == "1.5.1") {
$token = decrypt($_POST['gameSession'] ?? '');
$username = decrypt($_POST['userName'] ?? '');
} else {
$token = $_POST['gameSession'] ?? ''; $token = $_POST['gameSession'] ?? '';
$username = $_POST['userName'] ?? ''; $username = $_POST['userName'] ?? '';
}
$conn = newConnection(); $conn0 = newConnection(0);
$conn1 = newConnection(1);
$stmt = $conn->prepare("SELECT * FROM users WHERE token = ? AND username = ?"); $stmt = $conn0->prepare("SELECT * FROM users WHERE username = ?");
$stmt->bind_param("ss", $token, $username); $stmt->bind_param("s", $username);
$stmt->execute(); $stmt->execute();
$result = $stmt->get_result(); $result = $stmt->get_result();
if ($result->num_rows > 0) { if ($result->num_rows != 1) {
$row = $result->fetch_assoc(); echo (getClientVersion() == "1.5.0" || getClientVersion() == "1.5.1" || getClientVersion() == "1.5.2") ? encrypt("-1") : "-1";
$savedata = json_decode($row['save_data'], true); $conn0->close();
$icon = $savedata['bird']['icon'] ?? 1; $conn1->close();
$overlay = $savedata['bird']['overlay'] ?? 0; exit;
echo "1:" . $row['legacy_high_score'] . ":" . $icon . ":" . $overlay;
} else {
echo "-1";
} }
$stmt->close(); $row = $result->fetch_assoc();
$conn->close(); $id = $row["id"];
$stmt2 = $conn1->prepare("SELECT save_data, legacy_high_score FROM userdata WHERE id = ? AND token = ? LIMIT 1");
$stmt2->bind_param("is", $id, $token);
$stmt2->execute();
$result2 = $stmt2->get_result();
if ($result2->num_rows != 1) {
echo (getClientVersion() == "1.5.0" || getClientVersion() == "1.5.1" || getClientVersion() == "1.5.2") ? encrypt("-1") : "-1";
$conn0->close();
$conn1->close();
exit;
}
$user2 = $result2->fetch_assoc();
$savedata = json_decode($user2['save_data'], true);
$icon = $savedata['bird']['icon'] ?? 1;
$overlay = $savedata['bird']['overlay'] ?? 0;
if (getClientVersion() == "1.5.0" || getClientVersion() == "1.5.1" || getClientVersion() == "1.5.2") {
$birdColor = $savedata['settings']['colors']['icon'] ?? [255,255,255];
$msg = "1:" . $user2['legacy_high_score'] . ":" . $icon . ":" . $overlay . ":0:0:0:0:0:0:" . ":" . $birdColor[0] . ":" . $birdColor[1] . ":" . $birdColor[2];
if (getClientVersion() == "1.5.2") {
$overlayColor = $savedata['settings']['colors']['overlay'] ?? [255,255,255];
$msg .= ":" . $overlayColor[0] . ":" . $overlayColor[1] . ":" . $overlayColor[2];
}
echo encrypt($msg);
} else {
echo "1:" . $user2['legacy_high_score'] . ":" . $icon . ":" . $overlay;
}
$conn0->close();
$conn1->close();

View File

@@ -1,26 +0,0 @@
<?php
$post = getPostData();
$token = $post['gameSession'] ?? '';
$username = $post['userName'] ?? '';
$conn = newConnection();
$stmt = $conn->prepare("SELECT * FROM users WHERE token = ? AND username = ?");
$stmt->bind_param("ss", $token, $username);
$stmt->execute();
$result = $stmt->get_result();
if ($result->num_rows > 0) {
$row = $result->fetch_assoc();
$savedata = json_decode($row['save_data'], true);
$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];
echo encrypt("1" . ":" . $row['legacy_high_score'] . ":" . $icon . ":" . $overlay . ":0:0:0:0:0:0:" . ":" . $birdColor[0] . ":" . $birdColor[1] . ":" . $birdColor[2] . ":" . $overlayColor[0] . ":" . $overlayColor[1] . ":" . $overlayColor[2]);
} else {
echo encrypt("-1");
}
$stmt->close();
$conn->close();

View File

@@ -1,39 +1,62 @@
<?php <?php
require __DIR__ . '/../incl/util.php'; require __DIR__ . '/../incl/util.php';
setPlainHeader(); setPlainHeader();
if (getClientVersion() == "1.4.0-beta1") { if (
getClientVersion() == "1.4.0-beta1" ||
getClientVersion() == "1.4.0" ||
getClientVersion() == "1.4.1" ||
getClientVersion() == "1.5.0" ||
getClientVersion() == "1.5.1" ||
getClientVersion() == "1.5.2"
) {
require __DIR__ . '/backported/1.4.0-beta1/loadAccount.php'; require __DIR__ . '/backported/1.4.0-beta1/loadAccount.php';
exit; exit;
} }
if (getClientVersion() == "1.5.0" || getClientVersion() == "1.5.1" || getClientVersion() == "1.5.2") {
require __DIR__ . '/backported/1.5/loadAccount.php';
exit;
}
$post = getPostData(); $post = getPostData();
$token = $post['token'] ?? ''; $token = $post['token'] ?? '';
$username = $post['username'] ?? ''; $username = $post['username'] ?? '';
$conn = newConnection(); $conn0 = newConnection(0);
$conn1 = newConnection(1);
$stmt = $conn->prepare("SELECT * FROM users WHERE token = ? AND username = ?"); $stmt = $conn0->prepare("SELECT id, username FROM users WHERE username = ?");
$stmt->bind_param("ss", $token, $username); $stmt->bind_param("s", $username);
$stmt->execute(); $stmt->execute();
$result = $stmt->get_result(); $result = $stmt->get_result();
if ($result->num_rows > 0) { if ($result->num_rows != 1) {
echo encrypt(json_encode(["success" => false, "message" => "Invalid session token or username, please refresh login"]));
$conn0->close();
$conn1->close();
exit;
}
$row = $result->fetch_assoc(); $row = $result->fetch_assoc();
$savedata = json_decode($row['save_data'], true); $id = $row["id"];
$savedata['account']['id'] = $row['id'];
$stmt2 = $conn1->prepare("SELECT save_data, token FROM userdata WHERE id = ? AND token = ?");
$stmt2->bind_param("is", $id, $token);
$stmt2->execute();
$result2 = $stmt2->get_result();
if ($result2->num_rows != 1) {
echo encrypt(json_encode(["success" => false, "message" => "Invalid session token or username, please refresh login"]));
$conn0->close();
$conn1->close();
exit;
}
$row2 = $result2->fetch_assoc();
$savedata = json_decode($row2['save_data'], true);
$savedata['account']['id'] = $id;
$savedata['account']['name'] = $row['username']; $savedata['account']['name'] = $row['username'];
$savedata['account']['session'] = $row['token']; $savedata['account']['session'] = $row2['token'];
echo encrypt(json_encode([ echo encrypt(json_encode([
"success" => true, "success" => true,
"data" => $savedata "data" => $savedata
])); ]));
} else {
echo encrypt(json_encode(["success" => false, "message" => "Invalid session token or username, please refresh login"]));
}
$stmt->close(); $conn0->close();
$conn->close(); $conn1->close();