82 lines
2.0 KiB
PHP
Executable File
82 lines
2.0 KiB
PHP
Executable File
<?php
|
|
|
|
class Session {
|
|
use SingletonTrait;
|
|
|
|
private $sessionPrefix = '';
|
|
|
|
private function __construct() {
|
|
$this->initSession();
|
|
}
|
|
|
|
public function initSession() {
|
|
session_cache_limiter(false);
|
|
session_start();
|
|
}
|
|
|
|
public function closeSession() {
|
|
session_destroy();
|
|
}
|
|
|
|
public function createSession($userId, $staff = false) {
|
|
$this->store('userId', $userId);
|
|
$this->store('staff', $staff);
|
|
$this->store('token', Hashing::generateRandomToken());
|
|
}
|
|
|
|
public function createTicketSession($ticketNumber) {
|
|
$this->store('ticketNumber', $ticketNumber);
|
|
$this->store('token', Hashing::generateRandomToken());
|
|
}
|
|
|
|
public function getTicketNumber() {
|
|
return $this->getStoredData('ticketNumber');
|
|
}
|
|
|
|
public function getUserId() {
|
|
return $this->getStoredData('userId');
|
|
}
|
|
|
|
public function getToken() {
|
|
return $this->getStoredData('token');
|
|
}
|
|
|
|
public function sessionExists() {
|
|
return !!$this->getToken();
|
|
}
|
|
|
|
public function isStaffLogged() {
|
|
return $this->getStoredData('staff');
|
|
}
|
|
|
|
public function checkAuthentication($data) {
|
|
$userId = $this->getStoredData('userId');
|
|
$token = $this->getStoredData('token');
|
|
|
|
return $userId && $token &&
|
|
$userId === $data['userId'] &&
|
|
$token === $data['token'];
|
|
}
|
|
|
|
public function store($key, $value) {
|
|
$_SESSION[$this->sessionPrefix . $key] = $value;
|
|
}
|
|
|
|
private function getStoredData($key) {
|
|
$storedValue = null;
|
|
|
|
if (array_key_exists($this->sessionPrefix . $key, $_SESSION)) {
|
|
$storedValue = $_SESSION[$this->sessionPrefix . $key];
|
|
}
|
|
|
|
return $storedValue;
|
|
}
|
|
|
|
public function isLoggedWithId($userId) {
|
|
return ($this->getStoredData('userId') === $userId);
|
|
}
|
|
|
|
public function setSessionPrefix($prefix) {
|
|
$this->sessionPrefix = $prefix;
|
|
}
|
|
} |