src/EventSubscriber/Firewall.php line 34

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use App\Entity\Account;
  4. use App\Entity\AccountPro;
  5. use App\Entity\Organization;
  6. use App\Service\Security;
  7. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  8. use Symfony\Component\HttpFoundation\RedirectResponse;
  9. use Symfony\Component\HttpKernel\Event\ControllerEvent;
  10. use Symfony\Component\HttpKernel\KernelEvents;
  11. use Symfony\Component\Routing\RouterInterface;
  12. use function in_array;
  13. class Firewall implements EventSubscriberInterface
  14. {
  15.     protected Security        $security;
  16.     protected RouterInterface $router;
  17.     public function __construct(Security $securityRouterInterface $router)
  18.     {
  19.         $this->security $security;
  20.         $this->router   $router;
  21.     }
  22.     public static function getSubscribedEvents(): array
  23.     {
  24.         return [
  25.             KernelEvents::CONTROLLER => 'onKernelController',
  26.         ];
  27.     }
  28.     public function onKernelController(ControllerEvent $event)
  29.     {
  30.         $controller \is_array($event->getController()) ? $event->getController()[0] : $event->getController();
  31.         // Récupère l'utilisateur en session
  32.         $user $this->security->getUser();
  33.         $organization $this->security->getOrganization();
  34.         // Firewall pour la partie App
  35.         if (str_starts_with(\get_class($controller), 'App\Controller\App\\')) {
  36.             // On redirige si aucune session n'est montée
  37.             if (!$user instanceof Account) {
  38.                 $event->setController(function () {
  39.                     return new RedirectResponse($this->router->generate('home'));
  40.                 });
  41.                 return;
  42.             }
  43.         }
  44.         // Firewall pour la partie Daily
  45.         if (str_starts_with(\get_class($controller), 'App\Controller\Daily\\')) {
  46.             // On redirige si aucune session n'est montée
  47.             if (!$user instanceof Account) {
  48.                 $event->setController(function () {
  49.                     return new RedirectResponse($this->router->generate('home'));
  50.                 });
  51.                 return;
  52.             }
  53.         }
  54.         // Firewall pour la partie Pro
  55.         if (str_starts_with(\get_class($controller), 'App\Controller\Pro\\')) {
  56.             // On redirige si aucune session n'est montée
  57.             if (!$user instanceof AccountPro) {
  58.                 $event->setController(function () {
  59.                     return new RedirectResponse($this->router->generate('home'));
  60.                 });
  61.                 return;
  62.             }
  63.         }
  64.         // Firewall pour la partie Admin
  65.         if (str_starts_with(\get_class($controller), 'App\Controller\Admin\\')) {
  66.             // On redirige si aucune session n'est montée
  67.             if (!$user instanceof Account) {
  68.                 $event->setController(function () {
  69.                     return new RedirectResponse($this->router->generate('home'));
  70.                 });
  71.                 return;
  72.             }
  73.             // On redirige si on n'a pas le rôle admin
  74.             if (!in_array('ROLE_ADMIN'$user->getRoles(), true)) {
  75.                 return new RedirectResponse($this->router->generate('home'));
  76.             }
  77.         }
  78.         // Firewall pour la partie Manager
  79.         if (str_starts_with(\get_class($controller), 'App\Controller\Manager\\')) {
  80.             // On redirige si aucune session n'est montée
  81.             if (!$organization instanceof Organization) {
  82.                 $event->setController(function () {
  83.                     return new RedirectResponse($this->router->generate('home'));
  84.                 });
  85.                 return;
  86.             }
  87.         }
  88.     }
  89. }