gmarche/src/Framework/Auth/LoginModalMiddleware.php

65 lines
2.0 KiB
PHP

<?php
namespace Framework\Auth;
if (!isset($_SESSION)) {
session_start();
}
error_reporting(E_ALL & ~E_NOTICE);
use App\Auth\UserTable;
use Framework\Auth;
use Framework\Response\RedirectResponse;
use Framework\Router;
use Framework\Session\FlashService;
use Framework\Session\SessionInterface;
use Interop\Http\ServerMiddleware\DelegateInterface;
use Interop\Http\ServerMiddleware\MiddlewareInterface;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
class LoginModalMiddleware implements MiddlewareInterface
{
/**
* @var Auth
*/
private $auth;
/**
* @var Router
*/
private $router;
/**
* @var SessionInterface
*/
private $session;
public function __construct(Auth $auth, Router $router, UserTable $userTable, SessionInterface $session)
{
$this->auth = $auth;
$this->router = $router;
$this->userTable = $userTable;
$this->session = $session;
}
public function process(ServerRequestInterface $request, DelegateInterface $delegate): ResponseInterface
{
$url_part = explode('/',$request->getServerParams()['PHP_SELF'] ?? '/');
$username = $url_part[4];
if (is_null($username)) {
$user = $this->auth->getUser() ?: $this->userTable->findBy('username', $request->getAttribute('user'));
} else {
$user = $this->auth->getUser() ?: $this->userTable->findBy('username', $username);
}
if (is_null($user)) {
(new FlashService($this->session))->error('Vous devez vous connecter pour accéder à cette page');
return new RedirectResponse($this->router->generateUri('auth.login'));
} else {
$this->session->set('username',$user->username);
$this->session->set('role',$user->role);
$_SESSION['connecte'] = $user->username;
$_SESSION['role'] = $user->role;
}
return $delegate->process($request->withAttribute('user', $user));
}
}