2019-08-01 12:17:12 +03:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace api\models\authentication;
|
|
|
|
|
2024-12-02 15:10:55 +05:00
|
|
|
use DateTimeImmutable;
|
|
|
|
use Lcobucci\JWT\UnencryptedToken;
|
2019-08-01 12:17:12 +03:00
|
|
|
|
2024-12-02 15:10:55 +05:00
|
|
|
final readonly class AuthenticationResult {
|
2019-08-01 12:17:12 +03:00
|
|
|
|
2024-12-02 15:10:55 +05:00
|
|
|
public function __construct(
|
|
|
|
private UnencryptedToken $token,
|
|
|
|
private ?string $refreshToken = null,
|
|
|
|
) {
|
2019-08-01 12:17:12 +03:00
|
|
|
}
|
|
|
|
|
2024-12-02 15:10:55 +05:00
|
|
|
public function getToken(): UnencryptedToken {
|
2019-08-01 12:17:12 +03:00
|
|
|
return $this->token;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getRefreshToken(): ?string {
|
|
|
|
return $this->refreshToken;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function formatAsOAuth2Response(): array {
|
2024-12-02 15:10:55 +05:00
|
|
|
/** @var DateTimeImmutable $expiresAt */
|
|
|
|
$expiresAt = $this->token->claims()->get('exp');
|
2019-08-01 12:17:12 +03:00
|
|
|
$response = [
|
2024-12-02 15:10:55 +05:00
|
|
|
'access_token' => $this->token->toString(),
|
|
|
|
'expires_in' => $expiresAt->getTimestamp() - (new DateTimeImmutable())->getTimestamp(),
|
2019-08-01 12:17:12 +03:00
|
|
|
];
|
|
|
|
|
|
|
|
$refreshToken = $this->refreshToken;
|
|
|
|
if ($refreshToken !== null) {
|
|
|
|
$response['refresh_token'] = $refreshToken;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|