47 lines
1.2 KiB
PHP
47 lines
1.2 KiB
PHP
<?php
|
|
namespace Framework\Auth;
|
|
|
|
use Framework\Auth;
|
|
use Interop\Http\ServerMiddleware\DelegateInterface;
|
|
use Interop\Http\ServerMiddleware\MiddlewareInterface;
|
|
use Psr\Http\Message\ResponseInterface;
|
|
use Psr\Http\Message\ServerRequestInterface;
|
|
|
|
class RoleMiddleware implements MiddlewareInterface
|
|
{
|
|
|
|
/**
|
|
* @var Auth
|
|
*/
|
|
private $auth;
|
|
/**
|
|
* @var string
|
|
*/
|
|
private $role;
|
|
|
|
public function __construct(Auth $auth, string $role, string $role2)
|
|
{
|
|
$this->auth = $auth;
|
|
$this->role = $role;
|
|
$this->role2 = $role2;
|
|
}
|
|
|
|
public function process(ServerRequestInterface $request, DelegateInterface $delegate): ResponseInterface
|
|
{
|
|
$user = $this->auth->getUser();
|
|
//if (array_key_exists('premier', $search_array))
|
|
$non_admin = true;
|
|
if (!in_array($this->role, [$_SESSION['role']])) {
|
|
$non_admin = false;
|
|
}
|
|
if (!in_array($this->role2, [$_SESSION['role']])) {
|
|
$non_admin = false;
|
|
}
|
|
if ($user === null || $non_admin ) {
|
|
//if ($user === null || !array_key_exists($chaine_user,$this->role)) {
|
|
throw new ForbiddenException();
|
|
}
|
|
return $delegate->process($request);
|
|
}
|
|
}
|