e949/api/_auth.php

41 lines
952 B
PHP
Raw Normal View History

2023-08-12 01:39:17 +03:00
<?php
require_once("_db.php"); //("api/_db.php");
2023-08-30 04:41:13 +03:00
// End currently active session
function EndSession () {
session_unset();
session_destroy();
if (isset($_COOKIE["PHPSESSID"])) {
unset($_COOKIE["PHPSESSID"]);
setcookie("PHPSESSID", "", time() - 3600, "/");
}
}
2023-08-19 21:15:47 +03:00
//session_start();
// This ^ should be placed at login stage
2023-08-12 01:39:17 +03:00
$LOGGED_IN = false;
if (session_status() == PHP_SESSION_ACTIVE && isset($_SESSION["userid"])) {
2023-08-12 01:39:17 +03:00
// Check if user still exist
$s = $db->prepare("SELECT * FROM users WHERE id = ?");
$s->bind_param("s", $_SESSION["userid"]);
$s->execute();
if (!(bool)$s->get_result()->fetch_assoc()) { // If not, then destroy session
2023-08-30 04:41:13 +03:00
EndSession();
2023-08-12 01:39:17 +03:00
echo "user id does not exist";
die("user id used in session does not exist");
}
$LOGGED_IN = true;
} elseif (session_status() == PHP_SESSION_ACTIVE && !isset($_SESSION["userid"])) {
echo "no userid, destroying session";
EndSession();
die("no userid in session");
2023-08-12 01:39:17 +03:00
}
?>