2023-08-12 01:39:17 +03:00
|
|
|
<?php
|
2024-01-13 03:24:42 +03:00
|
|
|
// Things related to authentication
|
|
|
|
|
|
|
|
|
2023-08-12 01:39:17 +03:00
|
|
|
|
2023-10-31 21:57:17 +03:00
|
|
|
// Includes
|
2024-01-20 20:05:45 +03:00
|
|
|
if (isset($IS_FRONTEND) && $IS_FRONTEND)
|
2023-12-20 06:08:13 +03:00
|
|
|
require_once("api/_db.php");
|
|
|
|
else
|
|
|
|
require_once("_db.php");
|
2023-08-12 01:39:17 +03:00
|
|
|
|
2023-08-16 06:34:01 +03:00
|
|
|
|
|
|
|
|
2023-08-30 04:41:13 +03:00
|
|
|
// End currently active session
|
2024-01-13 03:24:42 +03:00
|
|
|
function AUTH_EndSession () {
|
2023-08-30 04:41:13 +03:00
|
|
|
session_unset();
|
|
|
|
session_destroy();
|
|
|
|
if (isset($_COOKIE["PHPSESSID"])) {
|
|
|
|
unset($_COOKIE["PHPSESSID"]);
|
|
|
|
setcookie("PHPSESSID", "", time() - 3600, "/");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2023-08-31 23:26:16 +03:00
|
|
|
// A few tips:
|
|
|
|
// session_start() - start OR RESUME session
|
|
|
|
// If $_SESSION["userid"] is set - it counted as active login session
|
|
|
|
// If its not set - it counted as no login session
|
|
|
|
session_start();
|
2023-08-12 01:39:17 +03:00
|
|
|
|
|
|
|
$LOGGED_IN = false;
|
2023-09-07 23:05:23 +03:00
|
|
|
$THIS_USER = null; // ID of logged in user
|
2023-08-12 01:39:17 +03:00
|
|
|
|
2023-08-31 23:26:16 +03:00
|
|
|
if (session_status() === PHP_SESSION_ACTIVE && isset($_SESSION["userid"])) { // If there are active session
|
2023-08-12 01:39:17 +03:00
|
|
|
// Check if user still exist
|
2024-01-15 04:58:29 +03:00
|
|
|
$s = $db->prepare("SELECT id FROM users WHERE id = ?");
|
2023-08-12 01:39:17 +03:00
|
|
|
$s->bind_param("s", $_SESSION["userid"]);
|
|
|
|
$s->execute();
|
2023-08-16 06:34:01 +03:00
|
|
|
if (!(bool)$s->get_result()->fetch_assoc()) { // If not, then destroy session
|
2024-01-13 03:24:42 +03:00
|
|
|
AUTH_EndSession();
|
2023-08-12 01:39:17 +03:00
|
|
|
die("user id used in session does not exist");
|
|
|
|
}
|
|
|
|
$LOGGED_IN = true;
|
2023-09-07 23:05:23 +03:00
|
|
|
$THIS_USER = $_SESSION["userid"];
|
2023-08-31 23:26:16 +03:00
|
|
|
} elseif (session_status() === PHP_SESSION_DISABLED) { // If sessions are disabled
|
|
|
|
die("ERROR: please enable sessions in php config");
|
|
|
|
}
|
|
|
|
|
2024-01-15 04:58:29 +03:00
|
|
|
// HACK
|
2023-08-31 23:26:16 +03:00
|
|
|
if ($Config["debug"] && isset($_REQUEST["debug"])) { // If there are not any session and debug mode is on
|
|
|
|
// ATTENTION: FOR DEBUG PURPOSES ONLY!
|
|
|
|
if ($_REQUEST["debug"] == "drop") {
|
2024-01-13 03:24:42 +03:00
|
|
|
AUTH_EndSession();
|
2023-08-31 23:26:16 +03:00
|
|
|
die("session discarded");
|
|
|
|
}
|
|
|
|
$_SESSION["userid"] = intval($_REQUEST["debug"]);
|
|
|
|
print_r(["created_session" => $_SESSION]);
|
|
|
|
die();
|
2023-08-12 01:39:17 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
?>
|