2016-01-15 03:45:22 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class Session {
|
2016-04-05 01:00:39 +02:00
|
|
|
static $instance = null;
|
2016-01-15 03:45:22 +01:00
|
|
|
|
2016-04-05 01:00:39 +02:00
|
|
|
private function __construct() {
|
|
|
|
$this->initSession();
|
|
|
|
}
|
2016-01-15 03:45:22 +01:00
|
|
|
|
|
|
|
public function initSession() {
|
|
|
|
session_start();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function closeSession() {
|
|
|
|
session_destroy();
|
|
|
|
}
|
|
|
|
|
2016-04-05 01:00:39 +02:00
|
|
|
public static function getInstance() {
|
|
|
|
if (!self::$instance) {
|
|
|
|
self::$instance = new Session();
|
2016-01-15 03:45:22 +01:00
|
|
|
}
|
|
|
|
|
2016-04-05 01:00:39 +02:00
|
|
|
return self::$instance;
|
2016-01-15 03:45:22 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function createSession($userId) {
|
2016-02-02 22:41:10 +01:00
|
|
|
$this->store('userId', $userId);
|
2016-01-15 03:45:22 +01:00
|
|
|
$this->store('token', $this->generateToken());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getToken() {
|
|
|
|
return $this->getStoredData('token');
|
|
|
|
}
|
|
|
|
|
2016-02-02 22:41:10 +01:00
|
|
|
public function sessionExists() {
|
|
|
|
return !!$this->getToken();
|
|
|
|
}
|
|
|
|
|
2016-01-15 03:45:22 +01:00
|
|
|
public function checkAuthentication($data) {
|
2016-02-02 22:41:10 +01:00
|
|
|
return $this->getStoredData('userId') === $data['userId'] &&
|
2016-01-15 03:45:22 +01:00
|
|
|
$this->getStoredData('token') === $data['token'];
|
|
|
|
}
|
|
|
|
|
2016-02-02 22:41:10 +01:00
|
|
|
public function isLoggedWithId($userId) {
|
|
|
|
return ($this->getStoredData('userId') === $userId);
|
|
|
|
}
|
|
|
|
|
2016-01-15 03:45:22 +01:00
|
|
|
private function store($key, $value) {
|
|
|
|
$_SESSION[$key] = $value;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getStoredData($key) {
|
2016-04-05 01:00:39 +02:00
|
|
|
$storedValue = null;
|
|
|
|
|
|
|
|
if (array_key_exists($key, $_SESSION)) {
|
|
|
|
$storedValue = $_SESSION[$key];
|
|
|
|
}
|
|
|
|
|
|
|
|
return $storedValue;
|
2016-01-15 03:45:22 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private function generateToken() {
|
|
|
|
return md5(uniqid(rand()));
|
|
|
|
}
|
|
|
|
}
|