src/EventSubscriber/SecuritySubscriber.php line 24

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use App\Entity\BackUser;
  4. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  5. use Symfony\Component\HttpFoundation\RedirectResponse;
  6. use Symfony\Component\HttpKernel\Event\RequestEvent;
  7. use Symfony\Component\HttpKernel\KernelEvents;
  8. use Symfony\Component\Routing\RouterInterface;
  9. use Symfony\Component\Security\Core\Authentication\Token\Storage\UsageTrackingTokenStorage;
  10. class SecuritySubscriber implements EventSubscriberInterface
  11. {
  12.     /**
  13.      * UpdatePageSubscriber constructor.
  14.      */
  15.     public function __construct(
  16.         private UsageTrackingTokenStorage $tokenStorage,
  17.         private RouterInterface $router
  18.     ) {
  19.     }
  20.     public function onKernelRequest(RequestEvent $event): void
  21.     {
  22.         $request $event->getRequest();
  23.         if ($this->tokenStorage->getToken() && $this->tokenStorage->getToken()->getUser() && 'anon.' != $this->tokenStorage->getToken()->getUser()) {
  24.             $user $this->tokenStorage->getToken()->getUser();
  25.             if (!$user->getEnabled() && !in_array($request->attributes->get('_route'), ['back_security_logout''front_security_logout'])) {
  26.                 $event->setResponse(new RedirectResponse($this->router->generate($user instanceof BackUser 'back_security_logout' 'front_security_logout')));
  27.             }
  28.         }
  29.     }
  30.     public static function getSubscribedEvents(): array
  31.     {
  32.         return [
  33.             KernelEvents::REQUEST => [['onKernelRequest'1]],
  34.         ];
  35.     }
  36. }