src/Security/EmailVerifiedChecker.php line 36

Open in your IDE?
  1. <?php
  2. namespace App\Security;
  3. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  4. use Symfony\Component\HttpFoundation\RedirectResponse;
  5. use Symfony\Component\HttpFoundation\RequestStack;
  6. use Symfony\Component\HttpFoundation\Session\Flash\FlashBagInterface;
  7. use Symfony\Component\HttpKernel\Event\ControllerEvent;
  8. use Symfony\Component\HttpKernel\KernelEvents;
  9. use Symfony\Component\Routing\RouterInterface;
  10. use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
  11. class EmailVerifiedChecker implements EventSubscriberInterface
  12. {
  13.     const FREE_ROUTE = ['homepage''public_page''email_unverified','resend_verification','verify_email'];
  14.     private TokenStorageInterface $token;
  15.     private FlashBagInterface $session;
  16.     private RequestStack $requestStack;
  17.     private RouterInterface $router;
  18.     public function __construct(
  19.         TokenStorageInterface $token,
  20.         FlashBagInterface $session,
  21.         RequestStack $requestStack,
  22.         RouterInterface $router
  23.     ) {
  24.         $this->token $token;
  25.         $this->session $session;
  26.         $this->requestStack $requestStack;
  27.         $this->router $router;
  28.     }
  29.     public function onKernelController(ControllerEvent $event)
  30.     {
  31.         $token $this->token->getToken();
  32.         $isValidation $this->session->get('email_validation_send');
  33.         $currentRoute $this->requestStack->getCurrentRequest()->get('_route');
  34.         if (!$token || $token->getUser()->isAdmin() || in_array($currentRouteself::FREE_ROUTE)) {
  35.             return;
  36.         }
  37.         if (!$token->getUser()->isVerified() && empty($isValidation)) {
  38.             $event->setController(function() {
  39.                 return new RedirectResponse($this->router->generate('email_unverified'));
  40.             });
  41.         }
  42.     }
  43.     public static function getSubscribedEvents(): array
  44.     {
  45.         return [
  46.             KernelEvents::CONTROLLER => 'onKernelController',
  47.         ];
  48.     }
  49. }