src/Bundles/OrganizationBundle/EventListener/CheckUserOrganizationInSessionListener.php line 33

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Bundles\OrganizationBundle\EventListener;
  4. use App\Bundles\OrganizationBundle\Service\UserOrganization\UserOrganizationBinder;
  5. use App\Bundles\OrganizationBundle\Service\UserOrganization\UserOrganizationProvider;
  6. use App\Bundles\UserBundle\Service\User\UserLogoutService;
  7. use App\Platform\Service\SessionProvider;
  8. use Symfony\Component\EventDispatcher\Attribute\AsEventListener;
  9. use Symfony\Component\HttpFoundation\RedirectResponse;
  10. use Symfony\Component\HttpFoundation\Session\SessionInterface;
  11. use Symfony\Component\HttpKernel\Event\RequestEvent;
  12. use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
  13. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  14. #[AsEventListener(eventRequestEvent::class, method'onKernelRequest'priority: -254)]
  15. class CheckUserOrganizationInSessionListener
  16. {
  17.     public function __construct(
  18.         private readonly SessionProvider $sessionProvider,
  19.         private readonly UserOrganizationProvider $provider,
  20.         private readonly TokenStorageInterface $tokenStorage,
  21.         private readonly UserLogoutService $userLogoutService,
  22.     ) {
  23.     }
  24.     public function onKernelRequest(RequestEvent $event): void
  25.     {
  26.         $session $this->sessionProvider->provide();
  27.         if (!$session->has(UserOrganizationBinder::SESSION_USER_ORGANIZATION_KEY)) {
  28.             return;
  29.         }
  30.         if (!$token $this->tokenStorage->getToken()) {
  31.             return;
  32.         }
  33.         if (!$this->provider->provideUserOrganizationBySession($session)) {
  34.             $this->logoutAndRedirectUser($event$token$session);
  35.         }
  36.     }
  37.     private function logoutAndRedirectUser(RequestEvent $eventTokenInterface $tokenSessionInterface $session): void
  38.     {
  39.         $this->userLogoutService->logout($event->getRequest(), $token$session);
  40.         $event->setResponse(new RedirectResponse('/login'));
  41.     }
  42. }