src/EventListener/AccessDeniedListener.php line 24

Open in your IDE?
  1. <?php
  2. namespace App\EventListener;
  3. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  4. use Symfony\Component\HttpFoundation\Response;
  5. use Symfony\Component\HttpKernel\Event\ExceptionEvent;
  6. use Symfony\Component\HttpKernel\KernelEvents;
  7. use Symfony\Component\Security\Core\Exception\AccessDeniedException;
  8. use Symfony\Component\Security\Core\Exception\CustomUserMessageAccountStatusException;
  9. class AccessDeniedListener implements EventSubscriberInterface
  10. {
  11.     public static function getSubscribedEvents(): array
  12.     {
  13.         return [
  14.             // the priority must be greater than the Security HTTP
  15.             // ExceptionListener, to make sure it's called before
  16.             // the default exception listener
  17.             KernelEvents::EXCEPTION => ['onKernelException'2],
  18.         ];
  19.     }
  20.     public function onKernelException(ExceptionEvent $event): void
  21.     {
  22.         $exception $event->getThrowable();
  23.         if (!$exception instanceof AccessDeniedException) {
  24.             return;
  25.         }
  26.         $routeName $event->getRequest()->get('_route');
  27.         switch ($routeName) {
  28.             case 'app_front_library_page':
  29.                 $accessDeniedMessage "La modification de vos informations est requise lors de votre première connexion";
  30.             break;
  31.             default:
  32.                 $accessDeniedMessage "Cette ressource n'existe pas !";
  33.             break;
  34.         }
  35.         // $request = $event->getRequest();
  36.         // throw new CustomUserMessageAccountStatusException($accessDeniedMessage);
  37.         // $request->getSession()->getFlashBag()->add('unauthorized_notice', 'La modification de vos informations est requise lors de votre première connexion.');
  38.         // ... perform some action (e.g. logging)
  39.         // optionally set the custom response
  40.         // $event->setResponse(new Response(null, 403));
  41.         // or stop propagation (prevents the next exception listeners from being called)
  42.         // $event->stopPropagation();
  43.     }
  44. }