Avancement sur droits d'accès à l'url dashboard/user

This commit is contained in:
nox 2019-12-10 14:29:27 +01:00
parent 502586ae49
commit 37468993f6
2 changed files with 17 additions and 3 deletions

View File

@ -2,8 +2,10 @@
namespace App\Admin;
use App\Account\Action\AccountAction;
use App\Account\Action\ActiveAction;
use App\Auth\Action\PasswordForgetAction;
use Framework\Auth\LoggedInMiddleware;
use Framework\Module;
use Framework\Renderer\RendererInterface;
use Framework\Renderer\TwigRenderer;
@ -21,7 +23,7 @@ class AdminModule extends Module
)
{
$router->get('/dashboard', DashboardAction::class, 'dashboard');
$router->get('/dashboard/{user:[a-zA-Z\-0-9]+}', DashboardUserAction::class, 'dashboard.user');
$router->get('/dashboard/{user:[a-zA-Z\-0-9]+}', [LoggedInMiddleware::class, DashboardUserAction::class], 'dashboard.user');
$router->get('/activation', ActiveAction::class, 'account.active');
$router->post('/activation', ActiveAction::class);
$router->any('/password_reinit', PasswordForgetAction::class, 'auth.password');

View File

@ -2,6 +2,11 @@
namespace Framework\Auth;
use Framework\Auth;
use Framework\Actions\RouterAwareAction;
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;
@ -15,16 +20,23 @@ class LoggedInMiddleware implements MiddlewareInterface
*/
private $auth;
public function __construct(Auth $auth)
public function __construct(Auth $auth, Router $router)
{
$this->auth = $auth;
$this->router = $router;
}
public function process(ServerRequestInterface $request, DelegateInterface $delegate): ResponseInterface
{
$user = $this->auth->getUser();
if (is_null($user)) {
throw new ForbiddenException();
//echo "is null";
//die();
//throw new ForbiddenException();
//return $this->redirect('auth.login');
//$this->session->set('auth.login', $request->getUri()->getPath());
//(new FlashService($this->session))->error('Vous devez posséder un compte pour accéder à cette page');
return new RedirectResponse($this->router->generateUri('auth.login'));
}
return $delegate->process($request->withAttribute('user', $user));
}