RefreshTokenStorage::__construct()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 0

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 0
nc 1
nop 1
dl 0
loc 4
rs 10
c 0
b 0
f 0
1
<?php
2
3
namespace kalanis\OAuth2\Storage\Dibi;
4
5
6
use DateTime;
7
use Dibi\Connection;
8
use kalanis\OAuth2\Storage\RefreshTokens\IRefreshToken;
9
use kalanis\OAuth2\Storage\RefreshTokens\IRefreshTokenStorage;
10
use kalanis\OAuth2\Storage\RefreshTokens\RefreshToken;
11
12
13
/**
14
 * Nette database RefreshToken storage
15
 * @package kalanis\OAuth2\Storage\Dibi
16
 */
17
class RefreshTokenStorage implements IRefreshTokenStorage
18
{
19
20
    public function __construct(
21
        private readonly Connection $context,
22
    )
23
    {
24
    }
25
26
    /**
27
     * Get authorization code table
28
     * @return string
29
     */
30
    protected function getTable(): string
31
    {
32
        return 'oauth_refresh_token';
33
    }
34
35
    /**
36
     * Store refresh token
37
     * @param IRefreshToken $refreshToken
38
     */
39
    public function store(IRefreshToken $refreshToken): void
40
    {
41
        $this->context->insert($this->getTable(), [
42
            'refresh_token' => $refreshToken->getRefreshToken(),
43
            'client_id' => $refreshToken->getClientId(),
44
            'user_id' => $refreshToken->getUserId(),
45
            'expires_at' => $refreshToken->getExpires()
46
        ])->execute();
47
    }
48
49
    /**
50
     * Remove refresh token
51
     * @param string $token
52
     */
53
    public function remove(string $token): void
54
    {
55
        $this->context->delete($this->getTable())->where(['refresh_token' => $token])->execute();
56
    }
57
58
    /**
59
     * Get valid refresh token
60
     * @param string $refreshToken
61
     * @return IRefreshToken|null
62
     */
63
    public function getValidRefreshToken(string $refreshToken): ?IRefreshToken
64
    {
65
        $row = $this->context->select('*')->from($this->getTable())
66
            ->where('refresh_token = %s', $refreshToken)
67
            ->where('TIMEDIFF(expires_at, NOW()) >= 0')
68
            ->fetch();
69
70
        if (!$row) {
71
            return null;
72
        }
73
74
        return new RefreshToken(
75
            strval($row['refresh_token']),
76
            new DateTime(strval($row['expires_at'])),
77
            is_numeric($row['client_id'])? intval($row['client_id']) : strval($row['client_id']),
78
            is_null($row['user_id']) ? null : strval($row['user_id']),
79
        );
80
    }
81
}
82