src/EventSubscriber/PermissionsSubscriber.php line 31

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use App\Entity\User;
  4. use App\Service\Routes\RoutesPermissions;
  5. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  6. use Symfony\Component\HttpFoundation\RedirectResponse;
  7. use Symfony\Component\HttpKernel\Event\RequestEvent;
  8. use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
  9. use Symfony\Component\Routing\RouterInterface;
  10. use Symfony\Component\Security\Core\Security;
  11. use Symfony\Contracts\Translation\TranslatorInterface;
  12. class PermissionsSubscriber implements EventSubscriberInterface
  13. {
  14.     public function __construct(
  15.         private Security $security,
  16.         private TranslatorInterface $translator,
  17.         private RouterInterface $router,
  18.         private RoutesPermissions $routesPermissions
  19.     ) {}
  20.     public static function getSubscribedEvents(): array
  21.     {
  22.         return [
  23.             RequestEvent::class => 'onKernelRequest'
  24.         ];
  25.     }
  26.     public function onKernelRequest(RequestEvent $event): void
  27.     {
  28.         // don't do anything if it's not the main request
  29.         if (!$event->isMainRequest()) return;
  30.         $uri $event->getRequest()->getRequestUri();
  31.         if (preg_match('/^\/(logout|login|_(wdt|profiler))/'$uri)) return;
  32.         $routeName $event->getRequest()->get('_route');
  33.         /** @var User $user */
  34.         $user $this->security->getUser();
  35.         if (!$user && !str_contains($routeName'admin')) return;
  36.         if (!$user && str_contains($routeName'admin')) {
  37.             $session $event->getRequest()->getSession();
  38.             $session->getFlashBag()->add(
  39.                 'danger'$this->translator->trans('security.forbidden', [], 'security')
  40.             );
  41.             $event->setResponse(new RedirectResponse($this->router->generate('app_login')));
  42.         }
  43.         if ($user && !$this->routesPermissions->checkUserPermissionByRouteName($routeName)) {
  44.             throw new AccessDeniedHttpException('Forbidden');
  45.         }
  46.     }
  47. }