|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
namespace kalanis\kw_auth\Methods; |
|
4
|
|
|
|
|
5
|
|
|
|
|
6
|
|
|
use ArrayAccess; |
|
7
|
|
|
use kalanis\kw_accounts\Interfaces\IAuth; |
|
8
|
|
|
use SessionHandlerInterface; |
|
9
|
|
|
|
|
10
|
|
|
|
|
11
|
|
|
/** |
|
12
|
|
|
* Class TimedSessions |
|
13
|
|
|
* @package kalanis\kw_auth\AuthMethods |
|
14
|
|
|
* Authenticate via Session - timer for valid authentication |
|
15
|
|
|
* @codeCoverageIgnore external resource, Cannot start session when headers already sent |
|
16
|
|
|
*/ |
|
17
|
|
|
class TimedSessions extends Sessions |
|
18
|
|
|
{ |
|
19
|
|
|
protected const INPUT_TIME = 'acc_time'; |
|
20
|
|
|
|
|
21
|
|
|
protected int $loginTimeout = 0; |
|
22
|
|
|
|
|
23
|
|
|
/** |
|
24
|
|
|
* @param IAuth|null $authenticator |
|
25
|
|
|
* @param AMethods|null $nextOne |
|
26
|
|
|
* @param ArrayAccess<string, string|int> $session |
|
27
|
|
|
* @param ArrayAccess<string, string|int> $server |
|
28
|
|
|
* @param int $loginTimeout |
|
29
|
|
|
* @param SessionHandlerInterface|null $externalHandler |
|
30
|
|
|
*/ |
|
31
|
|
|
public function __construct(?IAuth $authenticator, ?AMethods $nextOne, ArrayAccess $session, ArrayAccess $server, int $loginTimeout = 86400, ?SessionHandlerInterface $externalHandler = null) |
|
32
|
|
|
{ |
|
33
|
|
|
parent::__construct($authenticator, $nextOne, $session, $server, $externalHandler); |
|
34
|
|
|
$this->loginTimeout = $loginTimeout; |
|
35
|
|
|
} |
|
36
|
|
|
|
|
37
|
|
|
protected function tryLogged(): bool |
|
38
|
|
|
{ |
|
39
|
|
|
return ( |
|
40
|
|
|
$this->session->offsetExists(static::SESSION_NAME) |
|
41
|
|
|
&& !empty($this->session->offsetGet(static::SESSION_NAME))// user has name already set |
|
42
|
|
|
&& $this->session->offsetExists(static::SESSION_IP) |
|
43
|
|
|
&& !empty($this->session->offsetGet(static::SESSION_IP)) // user has already set known ip |
|
44
|
|
|
&& $this->session->offsetExists(static::INPUT_TIME) |
|
45
|
|
|
&& !empty($this->session->offsetGet(static::INPUT_TIME)) // user has already set last used time |
|
46
|
|
|
&& ($this->server->offsetGet(static::SERVER_REMOTE) == $this->session->offsetGet(static::SESSION_IP)) // against proxy attack - changed ip through work |
|
47
|
|
|
&& ((intval(strval($this->session->offsetGet(static::INPUT_TIME))) + $this->loginTimeout) > time()) // kick-off on time delay |
|
48
|
|
|
); |
|
49
|
|
|
} |
|
50
|
|
|
|
|
51
|
|
|
protected function fillSession(string $name): void |
|
52
|
|
|
{ |
|
53
|
|
|
parent::fillSession($name); |
|
54
|
|
|
$this->session->offsetSet(static::INPUT_TIME, time()); // set new timestamp |
|
55
|
|
|
} |
|
56
|
|
|
|
|
57
|
|
|
protected function clearSession(): void |
|
58
|
|
|
{ |
|
59
|
|
|
parent::clearSession(); |
|
60
|
|
|
$this->session->offsetSet(static::INPUT_TIME, 0); |
|
61
|
|
|
} |
|
62
|
|
|
} |
|
63
|
|
|
|