src/EventListener/CheckAccountStateListener.php line 35

Open in your IDE?
  1. <?php
  2. namespace App\EventListener;
  3. use App\Entity\SonataUserUser;
  4. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  5. use Symfony\Component\HttpFoundation\RedirectResponse;
  6. use Symfony\Component\HttpKernel\Event\RequestEvent;
  7. use Symfony\Component\Routing\RouterInterface;
  8. use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
  9. use Symfony\Component\Security\Http\Util\TargetPathTrait;
  10. class CheckAccountStateListener implements EventSubscriberInterface
  11. {
  12.     use TargetPathTrait;
  13.     private TokenStorageInterface $tokenStorage;
  14.     private RouterInterface $router;
  15.     public function __construct(
  16.         TokenStorageInterface $tokenStorage,
  17.         RouterInterface $router
  18.     ) {
  19.         $this->tokenStorage $tokenStorage;
  20.         $this->router $router;
  21.     }
  22.     public static function getSubscribedEvents(): array
  23.     {
  24.         return [
  25.             RequestEvent::class => 'onKernelRequest',
  26.         ];
  27.     }
  28.     public function onKernelRequest(RequestEvent $event): void
  29.     {
  30.         $request $event->getRequest();
  31.         // Přeskoč API nebo veřejné routy (můžeš upravit dle projektu)
  32.         $excludedRoutes = ['account_active''account_inactive''app_logout''app_login'];
  33.         $currentRoute $request->attributes->get('_route');
  34.         if (!$currentRoute || in_array($currentRoute$excludedRoutestrue)) {
  35.             return;
  36.         }
  37.         $token $this->tokenStorage->getToken();
  38.         if (!$token || !$token->getUser() instanceof SonataUserUser) {
  39.             return;
  40.         }
  41.         /** @var SonataUserUser $user */
  42.         $user $token->getUser();
  43.         if (!$user->getAccountState() || $user->getAccountState()->getIdentifier() !== 'active') {
  44.             $event->setResponse(new RedirectResponse($this->router->generate('account_inactive')));
  45.         }
  46.     }
  47. }