src/EventSubscriber/UserActivitySubscriber.php line 36

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  4. use Symfony\Component\HttpFoundation\Request;
  5. use Symfony\Component\HttpFoundation\Session\Flash\FlashBagInterface;
  6. use Symfony\Component\HttpKernel\Event\RequestEvent;
  7. use Symfony\Component\HttpKernel\KernelEvents;
  8. use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
  9. use Symfony\Component\Security\Core\Security;
  10. use Symfony\Component\HttpFoundation\RedirectResponse;
  11. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  12. class UserActivitySubscriber implements EventSubscriberInterface
  13. {
  14.     private $security;
  15.     private $urlGenerator;
  16.     private $flashBag;
  17.     private $tokenStorage;
  18.     public function __construct(Security $securityUrlGeneratorInterface $urlGeneratorFlashBagInterface $flashBagTokenStorageInterface $tokenStorage)
  19.     {
  20.         $this->security $security;
  21.         $this->urlGenerator $urlGenerator;
  22.         $this->flashBag $flashBag;
  23.         $this->tokenStorage $tokenStorage;
  24.     }
  25.     public static function getSubscribedEvents()
  26.     {
  27.         return [
  28.             KernelEvents::REQUEST => 'onKernelRequest',
  29.         ];
  30.     }
  31.     public function onKernelRequest(RequestEvent $event)
  32.     {
  33.         $user $this->security->getUser();
  34.         $request $event->getRequest();
  35.         $currentRoute $request->get('_route');
  36.         if ($user && !$user->getIsActive() && !$request->getSession()->get('password_change_in_progress')) {
  37.             if ($currentRoute !== 'app_change_password') {
  38.                 $request->getSession()->set('force_password_change'true);
  39.                 $event->setResponse(new RedirectResponse($this->urlGenerator->generate('profile.change_password')));
  40.             }
  41.         } else if ($user && $user->getIsActive()) {
  42.             // Si el usuario está activo, asegurarse de que no esté forzado a cambiar la contraseña
  43.             $request->getSession()->remove('force_password_change');
  44.             $request->getSession()->remove('password_change_in_progress');
  45.         }
  46.         // Si se debe cambiar la contraseña y no está en la ruta correcta, redirigir
  47.         if ($request->getSession()->get('force_password_change') && $currentRoute !== 'app_change_password') {
  48.             $event->setResponse(new RedirectResponse($this->urlGenerator->generate('profile.change_password')));
  49.         }
  50.     }
  51. }