1 | <?php |
||
2 | |||
3 | /** |
||
4 | * @author Alex Bilbie <[email protected]> |
||
5 | * @copyright Copyright (c) Alex Bilbie |
||
6 | * @license http://mit-license.org/ |
||
7 | * |
||
8 | * @link https://github.com/thephpleague/oauth2-server |
||
9 | */ |
||
10 | |||
11 | declare(strict_types=1); |
||
12 | |||
13 | namespace League\OAuth2\Server\Entities\Traits; |
||
14 | |||
15 | use DateTimeImmutable; |
||
16 | use Lcobucci\JWT\Configuration; |
||
17 | use Lcobucci\JWT\Signer\Key\InMemory; |
||
18 | use Lcobucci\JWT\Signer\Rsa\Sha256; |
||
19 | use Lcobucci\JWT\Token; |
||
20 | use League\OAuth2\Server\CryptKeyInterface; |
||
21 | use League\OAuth2\Server\Entities\ClientEntityInterface; |
||
22 | use League\OAuth2\Server\Entities\ScopeEntityInterface; |
||
23 | use RuntimeException; |
||
24 | use SensitiveParameter; |
||
0 ignored issues
–
show
|
|||
25 | |||
26 | trait AccessTokenTrait |
||
27 | { |
||
28 | private CryptKeyInterface $privateKey; |
||
29 | |||
30 | private Configuration $jwtConfiguration; |
||
31 | |||
32 | /** |
||
33 | * Set the private key used to encrypt this access token. |
||
34 | */ |
||
35 | 35 | public function setPrivateKey( |
|
36 | #[SensitiveParameter] |
||
37 | CryptKeyInterface $privateKey |
||
38 | ): void { |
||
39 | 35 | $this->privateKey = $privateKey; |
|
40 | } |
||
41 | |||
42 | /** |
||
43 | * Initialise the JWT Configuration. |
||
44 | */ |
||
45 | 10 | public function initJwtConfiguration(): void |
|
46 | { |
||
47 | 10 | $privateKeyContents = $this->privateKey->getKeyContents(); |
|
48 | |||
49 | 10 | if ($privateKeyContents === '') { |
|
50 | throw new RuntimeException('Private key is empty'); |
||
51 | } |
||
52 | |||
53 | 10 | $this->jwtConfiguration = Configuration::forAsymmetricSigner( |
|
54 | 10 | new Sha256(), |
|
55 | 10 | InMemory::plainText($privateKeyContents, $this->privateKey->getPassPhrase() ?? ''), |
|
56 | 10 | InMemory::plainText('empty', 'empty') |
|
57 | 10 | ); |
|
58 | } |
||
59 | |||
60 | /** |
||
61 | * Generate a JWT from the access token |
||
62 | */ |
||
63 | 10 | private function convertToJWT(): Token |
|
64 | { |
||
65 | 10 | $this->initJwtConfiguration(); |
|
66 | |||
67 | 10 | return $this->jwtConfiguration->builder() |
|
68 | 10 | ->permittedFor($this->getClient()->getIdentifier()) |
|
69 | 10 | ->identifiedBy($this->getIdentifier()) |
|
70 | 10 | ->issuedAt(new DateTimeImmutable()) |
|
71 | 10 | ->canOnlyBeUsedAfter(new DateTimeImmutable()) |
|
72 | 10 | ->expiresAt($this->getExpiryDateTime()) |
|
73 | 10 | ->relatedTo($this->getSubjectIdentifier()) |
|
74 | 10 | ->withClaim('scopes', $this->getScopes()) |
|
75 | 10 | ->getToken($this->jwtConfiguration->signer(), $this->jwtConfiguration->signingKey()); |
|
76 | } |
||
77 | |||
78 | /** |
||
79 | * Generate a string representation from the access token |
||
80 | */ |
||
81 | 10 | public function toString(): string |
|
82 | { |
||
83 | 10 | return $this->convertToJWT()->toString(); |
|
84 | } |
||
85 | |||
86 | abstract public function getClient(): ClientEntityInterface; |
||
87 | |||
88 | abstract public function getExpiryDateTime(): DateTimeImmutable; |
||
89 | |||
90 | /** |
||
91 | * @return non-empty-string|null |
||
0 ignored issues
–
show
|
|||
92 | */ |
||
93 | abstract public function getUserIdentifier(): string|null; |
||
94 | |||
95 | /** |
||
96 | * @return ScopeEntityInterface[] |
||
97 | */ |
||
98 | abstract public function getScopes(): array; |
||
99 | |||
100 | /** |
||
101 | * @return non-empty-string |
||
0 ignored issues
–
show
|
|||
102 | */ |
||
103 | abstract public function getIdentifier(): string; |
||
104 | |||
105 | /** |
||
106 | * @return non-empty-string |
||
0 ignored issues
–
show
|
|||
107 | */ |
||
108 | 10 | private function getSubjectIdentifier(): string |
|
109 | { |
||
110 | 10 | return $this->getUserIdentifier() ?? $this->getClient()->getIdentifier(); |
|
111 | } |
||
112 | } |
||
113 |
The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g.
excluded_paths: ["lib/*"]
, you can move it to the dependency path list as follows:For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths