src/EventSubscriber/CheckTermsAcceptSubscriber.php line 38

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use App\Entity\Consultant;
  4. use App\Entity\User;
  5. use App\Service\Entity\ConsultantService;
  6. use Symfony\Component\Console\Logger\ConsoleLogger;
  7. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  8. use Symfony\Component\HttpKernel\KernelEvents;
  9. use Symfony\Component\HttpKernel\Event\RequestEvent;
  10. use Symfony\Component\HttpFoundation\RedirectResponse;
  11. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  12. use Symfony\Component\Security\Core\Security;
  13. class CheckTermsAcceptSubscriber implements EventSubscriberInterface
  14. {
  15.     private $security;
  16.     private $urlGenerator;
  17.     private $consultantService;
  18.     public function __construct(Security $securityUrlGeneratorInterface $urlGeneratorConsultantService $consultantService)
  19.     {
  20.         $this->security $security;
  21.         $this->urlGenerator $urlGenerator;
  22.         $this->consultantService $consultantService;
  23.     }
  24.     public static function getSubscribedEvents(): array
  25.     {
  26.         return [
  27.             KernelEvents::REQUEST => [
  28.                 ['checkTermsAccept'0]
  29.             ],
  30.         ];
  31.     }
  32.     public function checkTermsAccept(RequestEvent $event): void
  33.     {
  34.         // only deal with the main request, disregard subrequests
  35.         if (!$event->isMainRequest()) {
  36.             return;
  37.         }
  38.         $request $event->getRequest();
  39.         $route $request->attributes->get('_route');
  40.         // On ignore certaines routes pour ne pas bloquer les actions POST
  41.         $excludedRoutes = ['terms_accept''logout''login''changepassword''localechange'];
  42.         if (in_array($route$excludedRoutestrue)) {
  43.             return;
  44.         }
  45.         $user $this->security->getUser();
  46.         // if you do not have a valid user, it means it's not an authenticated request, so it's not our concern
  47.         if (!$user instanceof User) {
  48.             return;
  49.         }
  50.         if ($user->getHasAcceptTerms()) {
  51.             return;
  52.         }
  53.         // if we get here, it means we need to redirect them to the password change view.
  54.         $redirectTo $this->urlGenerator->generate('terms_index');
  55.         if ($event->getRequest()->getRequestUri() != $redirectTo) {
  56.             $event->setResponse(new RedirectResponse($redirectTo));
  57.         }
  58.     }
  59. }