<?php use Battles\Database\DBPDO; use Battles\GameLogs; use Battles\Template; require_once "config.php"; const ERROR_NO_SUCH_USER = 'Такого пользователя не существует!'; const ERROR_USER_IS_BLOCKED = 'Пользователь заблокирован!'; const ERROR_WRONG_PASSWORD = 'Неверный пароль!'; const ERROR_EMPTY_CREDENTIALS = 'Вы не ввели логин или пароль!'; foreach ($_POST as $key => $val) { //Проверка всех значений массива POST одним махом. $_POST[$key] = iconv(mb_detect_encoding($val, 'auto'), 'utf-8', $val); } $username = filter_input(INPUT_POST, 'username', FILTER_SANITIZE_SPECIAL_CHARS); $password = $_POST['password'] ?? ''; $battle = $_COOKIE['battle'] ?? ''; $error = ""; if ($username && $password) { $user_query = DBPDO::$db->ofetch('SELECT id, login, pass, room, block FROM users WHERE login = ?', $username); if (!$user_query->id) { $error = ERROR_NO_SUCH_USER; } elseif ($user_query->block) { $error = ERROR_USER_IS_BLOCKED; } elseif (password_verify($password, $user_query->pass)) { if (!$error) { # Проверка на мультоводство по используемому кукису. if ($battle != null && $user_query->id != $battle) { GameLogs::addUserLog($user_query->id,'Разные ID на входе. Возможно используются несколько аккаунтов.', 'multiaccounts'); } setcookie("battle", $user_query->id); $_SESSION['uid'] = $user_query->id; setcookie("uid", $user_query->id, time() + 43200, "/", GAMEDOMAIN); setcookie("hashcode", md5($user_query->id . $user_query->pass . $username), time() + 43200, "/", GAMEDOMAIN); $_SESSION['sid'] = session_id(); $onl = DBPDO::$db->ofetch('SELECT user_id FROM online WHERE user_id = ?', $user_query->id); if (isset($onl->user_id)) { DBPDO::$db->execute('UPDATE online SET date = ? WHERE user_id = ?', [time(), $user_query->id]); } else { DBPDO::$db->execute('INSERT INTO online (user_id, date, room, real_time) VALUES (?,?,?,?)', [$user_query->id, time(), $user_query->room, time()]); } DBPDO::$db->execute('UPDATE users SET session_id = ?, enter_game = 1 WHERE id = ?', [session_id(), $user_query->id]); header("Location: fight.php"); } } else { $error = ERROR_WRONG_PASSWORD; } } else { $error = ERROR_EMPTY_CREDENTIALS; } Template::header('Входим...'); if ($error) { echo sprintf('<a href="/"> ← на главную</a><h1>%s</h1>', $error); }