src/Security/Voter/EntityVoter.php line 13

Open in your IDE?
  1. <?php
  2. namespace App\Security\Voter;
  3. use App\Entity\Utilisateur\Droit;
  4. use App\Entity\Utilisateur\Utilisateur;
  5. use Psr\Log\LoggerInterface;
  6. use Symfony\Component\DependencyInjection\ParameterBag\ParameterBagInterface;
  7. use Symfony\Component\HttpFoundation\RequestStack;
  8. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  9. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  10. class EntityVoter extends Voter
  11. {
  12.     public const SESSION_KEY 'droit';
  13.     public const SHOW 'voir';
  14.     public const ADD 'ajouter';
  15.     public const UPDATE 'modifier';
  16.     public const DELETE 'supprimer';
  17.     public const EXPORT 'exporter';
  18.     private RequestStack $requestStack;
  19.     private LoggerInterface $logger;
  20.     private ParameterBagInterface $parameterBag;
  21.     public function __construct(RequestStack $requestStackLoggerInterface $securityLoggerParameterBagInterface $parameterBag)
  22.     {
  23.         $this->requestStack $requestStack;
  24.         $this->logger       $securityLogger;
  25.         $this->parameterBag $parameterBag;
  26.     }
  27.     protected function supports(string $attribute$subject): bool
  28.     {
  29.         //return true;
  30.         return (!empty($subject));
  31.     }
  32.     /*
  33.     public function vote(TokenInterface $token, $subject, array $attributes): int
  34.     {
  35.         dump('test');
  36.         /** @var ?Utilisateur $user *//*
  37.         $user = $token->getUser();
  38.         if ($user === null) {
  39.             return self::ACCESS_ABSTAIN;
  40.         }
  41.         $entityFounded = false;
  42.         /** @var Droit[] $droits *//*
  43.         $droits = $this->requestStack->getSession()->get(self::SESSION_KEY);
  44.         if (is_string($subject) && class_exists($subject)) {
  45.             $objectClassName = $subject;
  46.         } elseif (is_object($subject)) {
  47.             $objectClassName = get_class($subject);
  48.         } else {
  49.             $this->logger->error('This entity doesn\'t exist : '.$subject);
  50.             if($this->parameterBag->get('kernel.debug') === true) {
  51. //                throw new \Exception('This entity doesn\'t exist : '.$subject);
  52.             }
  53.             return self::ACCESS_ABSTAIN;
  54.         }
  55.         foreach ($attributes as $attribute) {
  56.             if ($droits !== null) {
  57.                 foreach ($droits as $line) {
  58.                     if ($line->getEntite() === $objectClassName) {
  59.                         $entityFounded = true;
  60.                         if ($attribute === self::SHOW && $line->getVoir() === true) {
  61.                             return self::ACCESS_GRANTED;
  62.                         } elseif ($attribute === self::ADD && $line->getAjouter() === true) {
  63.                             return self::ACCESS_GRANTED;
  64.                         } elseif ($attribute === self::UPDATE && $line->getModifier() === true) {
  65.                             return self::ACCESS_GRANTED;
  66.                         } elseif ($attribute === self::DELETE && $line->getSupprimer() === true) {
  67.                             return self::ACCESS_GRANTED;
  68.                         } elseif ($attribute === self::EXPORT && $line->getExporter() === true) {
  69.                             return self::ACCESS_GRANTED;
  70.                         }
  71.                     }
  72.                 }
  73.             }
  74.         }
  75.         if ( ! $entityFounded) {
  76.             if($this->parameterBag->get('kernel.debug') === true) {
  77. //                throw new \Exception('This entity not found in rights : '.$objectClassName);
  78.             }
  79.             $this->logger->warning('This entity not found in rights : '.$objectClassName);
  80.         }
  81.         return self::ACCESS_ABSTAIN;
  82.     }
  83. */
  84.     protected function voteOnAttribute(string $attribute$subjectTokenInterface $token): bool
  85.     {
  86.         /** @var ?Utilisateur $user */
  87.         $user $token->getUser();
  88.         if ($user === null) {
  89.             return self::ACCESS_ABSTAIN;
  90.         }
  91.         $entityFounded false;
  92.         /** @var Droit[] $droits */
  93.         $droits $this->requestStack->getSession()->get(self::SESSION_KEY);
  94.         if (is_string($subject) && class_exists($subject)) {
  95.             $objectClassName $subject;
  96.         } elseif (is_object($subject)) {
  97.             $objectClassName get_class($subject);
  98.         } else {
  99.             $this->logger->error('This entity doesn\'t exist : '.$subject);
  100.             if($this->parameterBag->get('kernel.debug') === true) {
  101. //                throw new \Exception('This entity doesn\'t exist : '.$subject);
  102.             }
  103.             return self::ACCESS_ABSTAIN;
  104.         }
  105.         $attributes = [$attribute];
  106.         foreach ($attributes as $attribute) {
  107.             if ($droits !== null) {
  108.                 foreach ($droits as $line) {
  109.                     if ($line->getEntite() === $objectClassName) {
  110.                         $entityFounded true;
  111.                         if ($attribute === self::SHOW && $line->getVoir() === true) {
  112.                             return self::ACCESS_GRANTED;
  113.                         } elseif ($attribute === self::ADD && $line->getAjouter() === true) {
  114.                             return self::ACCESS_GRANTED;
  115.                         } elseif ($attribute === self::UPDATE && $line->getModifier() === true) {
  116.                             return self::ACCESS_GRANTED;
  117.                         } elseif ($attribute === self::DELETE && $line->getSupprimer() === true) {
  118.                             return self::ACCESS_GRANTED;
  119.                         } elseif ($attribute === self::EXPORT && $line->getExporter() === true) {
  120.                             return self::ACCESS_GRANTED;
  121.                         }
  122.                     }
  123.                 }
  124.             }
  125.         }
  126.         if ( ! $entityFounded) {
  127.             if($this->parameterBag->get('kernel.debug') === true) {
  128. //                throw new \Exception('This entity not found in rights : '.$objectClassName);
  129.             }
  130.             $this->logger->warning('This entity not found in rights : '.$objectClassName);
  131.         }
  132.         return self::ACCESS_ABSTAIN;
  133.     }
  134. }