48 lines
1.2 KiB
PHP
Executable File
48 lines
1.2 KiB
PHP
Executable File
<?php
|
|
|
|
namespace kernel\modules\secure\middlewares;
|
|
|
|
use JetBrains\PhpStorm\NoReturn;
|
|
use kernel\App;
|
|
use kernel\helpers\Debug;
|
|
use kernel\Middleware;
|
|
use kernel\modules\user\service\UserService;
|
|
use kernel\Request;
|
|
|
|
class BearerAuthMiddleware extends Middleware
|
|
{
|
|
protected UserService $userService;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->userService = new UserService();
|
|
}
|
|
|
|
function handler(): void
|
|
{
|
|
$request = new Request();
|
|
$authorization = $request->getHeader("Authorization");
|
|
if ($authorization){
|
|
$authorization = explode(" ", $authorization);
|
|
$type = $authorization[0];
|
|
$token = $authorization[1];
|
|
if ($type === "Bearer"){
|
|
$user = $this->userService->getByAccessToken($token);
|
|
if ($user){
|
|
if ($user->access_token_expires_at > date("Y-m-d")){
|
|
App::$user = $user;
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$this->returnError(403);
|
|
}
|
|
|
|
#[NoReturn] public function returnError(int $code): void
|
|
{
|
|
http_response_code($code);
|
|
die('Forbidden');
|
|
}
|
|
} |