forked from simplesamlphp/simplesamlphp
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSessionHandlerStore.php
More file actions
91 lines (73 loc) · 2.15 KB
/
SessionHandlerStore.php
File metadata and controls
91 lines (73 loc) · 2.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
<?php
/**
* Session storage in the data store.
*
* @package SimpleSAMLphp
*/
declare(strict_types=1);
namespace SimpleSAML;
use SimpleSAML\Assert\Assert;
use SimpleSAML\Store\StoreInterface;
use function time;
class SessionHandlerStore extends SessionHandlerCookie
{
/**
* The data store we save the session to.
*
* @var \SimpleSAML\Store\StoreInterface
*/
private StoreInterface $store;
/**
* Initialize the session.
*
* @param \SimpleSAML\Store\StoreInterface $store The store to use.
* @throws \Exception
*/
protected function __construct(StoreInterface $store)
{
parent::__construct();
$this->store = $store;
}
/**
* Load a session from the data store.
*
* @param string|null $sessionId The ID of the session we should load, or null to use the default.
*
* @return \SimpleSAML\Session|null The session object, or null if it doesn't exist.
*/
public function loadSession(?string $sessionId): ?Session
{
if ($sessionId === null) {
$sessionId = $this->getCookieSessionId();
if ($sessionId === null) {
// no session cookie, nothing to load
return null;
}
}
$session = $this->store->get('session', $sessionId);
if ($session !== null) {
Assert::isInstanceOf($session, Session::class);
return $session;
}
return null;
}
/**
* Save a session to the data store.
*
* @param \SimpleSAML\Session $session The session object we should save.
* @throws \Exception
*/
public function saveSession(Session $session): void
{
if ($session->isTransient()) {
// transient session, nothing to save
return;
}
/** @var string $sessionId */
$sessionId = $session->getSessionId();
$config = Configuration::getInstance();
$sessionDuration = $config->getOptionalInteger('session.duration', 8 * 60 * 60);
$expire = time() + $sessionDuration;
$this->store->set('session', $sessionId, $session, $expire);
}
}