src/EventSubscriber/SessionTwoFactorMethodSubscriber.php line 32

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\EventSubscriber;
  4. use App\Entity\User;
  5. use Psr\Log\LoggerInterface;
  6. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  7. use Symfony\Component\HttpFoundation\RequestStack;
  8. use Symfony\Component\HttpKernel\Event\RequestEvent;
  9. use Symfony\Component\HttpKernel\KernelEvents;
  10. use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
  11. class SessionTwoFactorMethodSubscriber implements EventSubscriberInterface
  12. {
  13.     public const SESSION_KEY '_2fa_method';
  14.     public function __construct(
  15.         private readonly TokenStorageInterface $tokenStorage,
  16.         private readonly RequestStack $requestStack,
  17.         private readonly LoggerInterface $logger,
  18.     ) {}
  19.     public static function getSubscribedEvents(): array
  20.     {
  21.         return [
  22.             KernelEvents::REQUEST => ['onKernelRequest'1024], // Very high priority — before Scheb listeners
  23.         ];
  24.     }
  25.     public function onKernelRequest(RequestEvent $event): void
  26.     {
  27.         if (!$event->isMainRequest()) {
  28.             return;
  29.         }
  30.         $token $this->tokenStorage->getToken();
  31.         if (!$token) {
  32.             return;
  33.         }
  34.         $user $token->getUser();
  35.         if (!$user instanceof User) {
  36.             return;
  37.         }
  38.         $request $this->requestStack->getCurrentRequest();
  39.         if (!$request || !$request->hasSession()) {
  40.             return;
  41.         }
  42.         $sessionMethod $request->getSession()->get(self::SESSION_KEY);
  43.         if ($sessionMethod !== null) {
  44.             $user->setSessionTwoFactorMethod($sessionMethod);
  45.             $this->logger->debug('[2FA Session] Hydrated session 2FA method onto User entity', [
  46.                 'user_id' => $user->getId(),
  47.                 'session_method' => $sessionMethod,
  48.             ]);
  49.         }
  50.     }
  51. }