1
0
mirror of https://github.com/Daichimarukana/uwuzu.git synced 2026-06-04 19:14:41 +00:00

uwuzu v1.6.12 Hapuego

This commit is contained in:
だいちまる
2026-04-22 01:24:23 +09:00
parent f439bd171f
commit b39307b651
36 changed files with 2851 additions and 2584 deletions
+101 -98
View File
@@ -14,118 +14,121 @@ if (safetext(isset($_POST['page'])) && safetext(isset($_POST['userid'])) && safe
if ($is_login === false) {
echo json_encode(['success' => false, 'error' => 'bad_request']);
exit;
}
// データベースに接続
try {
$option = array(
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::MYSQL_ATTR_MULTI_STATEMENTS => false
);
$pdo = new PDO('mysql:charset=utf8mb4;dbname=' . DB_NAME . ';host=' . DB_HOST, DB_USER, DB_PASS, $option);
} catch (PDOException $e) {
// 接続エラーのときエラー内容を取得する
$error_message[] = $e->getMessage();
}
if (!empty($pdo)) {
$myUserData = getUserData($pdo, $userId);
$myblocklist = safetext($myUserData["blocklist"]);
$mybookmark = safetext($myUserData["bookmark"]);
$itemsPerPage = 15; // 1ページあたりのユーズ数
$pageNumber = $page;
if($pageNumber <= 0 || (!(is_numeric($pageNumber)))){
$pageNumber = 1;
}
$offset = ($pageNumber - 1) * $itemsPerPage;
$blocked_accounts = sqlBlockAccountList('account', $myblocklist);
$messages = array();
$sql = "SELECT ueuse.*
FROM ueuse
LEFT JOIN account ON ueuse.account = account.userid
WHERE ueuse.rpuniqid = '' AND account.role != 'ice' {$blocked_accounts['sql']}
ORDER BY ueuse.datetime DESC
LIMIT :offset, :itemsPerPage";
$stmt = $pdo->prepare($sql);
foreach ($blocked_accounts['params'] as $ph => $val) {
$stmt->bindValue($ph, $val, PDO::PARAM_STR);
}elseif(is_sameUserid($userId, $is_login["userid"]) === true){
// データベースに接続
try {
$option = array(
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::MYSQL_ATTR_MULTI_STATEMENTS => false
);
$pdo = new PDO('mysql:charset=utf8mb4;dbname=' . DB_NAME . ';host=' . DB_HOST, DB_USER, DB_PASS, $option);
} catch (PDOException $e) {
// 接続エラーのときエラー内容を取得する
$error_message[] = $e->getMessage();
}
$stmt->bindValue(':offset', $offset, PDO::PARAM_INT);
$stmt->bindValue(':itemsPerPage', $itemsPerPage, PDO::PARAM_INT);
$stmt->execute();
$message_array = $stmt;
if (!empty($pdo)) {
$myUserData = getUserData($pdo, $userId);
$myblocklist = safetext($myUserData["blocklist"]);
$mybookmark = safetext($myUserData["bookmark"]);
while ($row = $message_array->fetch(PDO::FETCH_ASSOC)) {
$messages[] = $row;
}
$itemsPerPage = 15; // 1ページあたりのユーズ数
$pageNumber = $page;
if($pageNumber <= 0 || (!(is_numeric($pageNumber)))){
$pageNumber = 1;
}
$offset = ($pageNumber - 1) * $itemsPerPage;
// ユーザー情報を取得して、$messages内のusernameをuserDataのusernameに置き換える
$blocked_accounts = sqlBlockAccountList('account', $myblocklist);
$messages = getDatasUeuse($pdo, $messages);
$messages = array();
$sql = "SELECT ueuse.*
FROM ueuse
LEFT JOIN account ON ueuse.account = account.userid
WHERE ueuse.rpuniqid = '' AND account.role != 'ice' {$blocked_accounts['sql']}
ORDER BY ueuse.datetime DESC
LIMIT :offset, :itemsPerPage";
//adsystem------------------
$stmt = $pdo->prepare($sql);
foreach ($blocked_accounts['params'] as $ph => $val) {
$stmt->bindValue($ph, $val, PDO::PARAM_STR);
}
$message['ads'] = "false";
$stmt->bindValue(':offset', $offset, PDO::PARAM_INT);
$stmt->bindValue(':itemsPerPage', $itemsPerPage, PDO::PARAM_INT);
$stmt->execute();
$message_array = $stmt;
$today = date("Y-m-d H:i:s");
while ($row = $message_array->fetch(PDO::FETCH_ASSOC)) {
$messages[] = $row;
}
$adsQuery = $pdo->prepare("SELECT * FROM ads WHERE start_date < :today AND limit_date > :today ORDER BY rand()");
$adsQuery->bindValue(':today', $today);
$adsQuery->execute();
$adsresult = $adsQuery->fetch();
if(!(empty($adsresult))){
$message['ads'] = "true";
$message['ads_url'] = $adsresult["url"];
$message['ads_img_url'] = $adsresult["image_url"];
$message['ads_memo'] = $adsresult["memo"];
}
//--------------------------
// ユーザー情報を取得して、$messages内のusernameをuserDataのusernameに置き換える
$ueuseItems = array();
if(!empty($messages)){
foreach ($messages as $value) {
$formatted = FormatUeuseItem($value, $myblocklist, $mybookmark, $pdo, $userId);
if ($formatted !== null) {
$ueuseItems[] = $formatted;
$messages = getDatasUeuse($pdo, $messages);
//adsystem------------------
$message['ads'] = "false";
$today = date("Y-m-d H:i:s");
$adsQuery = $pdo->prepare("SELECT * FROM ads WHERE start_date < :today AND limit_date > :today ORDER BY rand()");
$adsQuery->bindValue(':today', $today);
$adsQuery->execute();
$adsresult = $adsQuery->fetch();
if(!(empty($adsresult))){
$message['ads'] = "true";
$message['ads_url'] = $adsresult["url"];
$message['ads_img_url'] = $adsresult["image_url"];
$message['ads_memo'] = $adsresult["memo"];
}
//--------------------------
$ueuseItems = array();
if(!empty($messages)){
foreach ($messages as $value) {
$formatted = FormatUeuseItem($value, $myblocklist, $mybookmark, $pdo, $userId);
if ($formatted !== null) {
$ueuseItems[] = $formatted;
}
}
}
if($message['ads'] === "true"){
$adsystem = array(
"type" => "Ads",
"url" => $message['ads_url'],
"imgurl" => $message['ads_img_url'],
"memo" => $message['ads_memo'],
if($message['ads'] === "true"){
$adsystem = array(
"type" => "Ads",
"url" => $message['ads_url'],
"imgurl" => $message['ads_img_url'],
"memo" => $message['ads_memo'],
);
}else{
$adsystem = null;
}
$item = array(
"success" => true,
"ueuses" => $ueuseItems,
"ads" => $adsystem,
);
}else{
$adsystem = null;
}
$item = array(
"success" => true,
"ueuses" => $ueuseItems,
"ads" => $adsystem,
);
echo json_encode($item, JSON_UNESCAPED_UNICODE);
}else{
$item = array(
"success" => false,
"ueuses" => null,
"ads" => null,
"error" => "no_ueuse",
);
echo json_encode($item, JSON_UNESCAPED_UNICODE);
}
$pdo = null;
echo json_encode($item, JSON_UNESCAPED_UNICODE);
}else{
$item = array(
"success" => false,
"ueuses" => null,
"ads" => null,
"error" => "no_ueuse",
);
echo json_encode($item, JSON_UNESCAPED_UNICODE);
}
$pdo = null;
}
}else{
echo json_encode(['success' => false, 'error' => '認証に失敗しました。(AUTH_INVALID)']);
exit;
}
}else{
$item = array(