Files
legacy-server/database/voteAccountProfileMessage.php
2025-09-09 22:48:57 -07:00

59 lines
1.6 KiB
PHP

<?php
require __DIR__ . '/../incl/util.php';
setPlainHeader();
checkClientDatabaseVersion();
$conn = newConnection();
$post = getPostData();
$targetId = (int)$post['targetId'] ?? 0;
$liked = (int)$post['liked'] ?? -1;
$token = $post['token'] ?? '';
$username = $post['username'] ?? '';
if ($liked !== 0 && $liked !== 1) {
echo encrypt(json_encode(["success" => false, "message" => 'Invalid type']));
exit;
}
$stmt = $conn->prepare("SELECT * FROM users WHERE token = ? AND username = ?");
$stmt->bind_param("ss", $token, $username);
$stmt->execute();
$result = $stmt->get_result();
$row = $result->fetch_assoc();
if (!$row) {
echo encrypt(json_encode(["success" => false, "message" => 'User info not found']));
exit;
}
$stmt->close();
$user_id = $row["id"];
$stmt = $conn->prepare("SELECT votes, likes FROM userposts WHERE id = ?");
$stmt->bind_param("i", $targetId);
$stmt->execute();
$result = $stmt->get_result();
$row = $result->fetch_assoc();
if (!$row) {
echo encrypt(json_encode(["success" => false, "message" => 'Post info not found']));
exit;
}
$stmt->close();
$votes = json_decode($row["votes"], true) ?? [];
$likes = (int)$row["likes"];
if (isset($votes[$user_id])) {
echo encrypt(json_encode(["success" => false, "message" => 'You have already voted']));
exit;
}
$votes[$user_id] = $liked === 0 ? false : true;
$likes += $liked ? 1 : -1;
$votes = json_encode($votes);
$stmt = $conn->prepare("UPDATE userposts SET likes = ?, votes = ? WHERE id = ?");
$stmt->bind_param("isi", $likes, $votes, $targetId);
$stmt->execute();
$stmt->close();
echo encrypt(json_encode(["success" => true, "likes" => $likes]));
$conn->close();