src/Security/Voter/DeclarativeVoter.php line 11

Open in your IDE?
  1. <?php
  2. namespace App\Security\Voter;
  3. use App\Entity\Declarative;
  4. use App\Service\HierarchyService;
  5. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  6. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  7. use Symfony\Component\Security\Core\User\UserInterface;
  8. class DeclarativeVoter extends Voter
  9. {
  10.     public const EDIT 'PATCH_DECLARATIVE';
  11.     public const DELETE 'DELETE_DECLARATIVE';
  12.     private $hierarchyService;
  13.     public function __construct(
  14.         HierarchyService $hierarchyService
  15.     )
  16.     {
  17.         $this->hierarchyService $hierarchyService;
  18.     }
  19.     protected function supports(string $attribute$subject): bool
  20.     {
  21.         // remplacez par votre logique
  22.         // https://symfony.com/doc/current/security/voters.html
  23.         return in_array($attribute, [self::EDIT,self::DELETE])
  24.             && $subject instanceof \App\Entity\Declarative;
  25.     }
  26.     protected function voteOnAttribute(string $attribute$declarativeTokenInterface $token): bool
  27.     {
  28.         $userConnected $token->getUser();
  29.         // si l'utilisateur est anonyme, ne pas accorder l'accès
  30.         if (!$userConnected instanceof UserInterface) {
  31.             return false;
  32.         }
  33.         /** @var Declarative $declarative */
  34.         $seller $declarative->getSeller();
  35.         if($seller == null){
  36.             return false;
  37.         }
  38.         // ... (vérifier les conditions et renvoyer true pour accorder l'autorisation) ...
  39.         switch ($attribute) {
  40.             case self::EDIT:
  41.                 // logique pour déterminer si l'utilisateur peut modifier le declaratif
  42.                 // return true or false
  43.                 if($seller == $userConnected || $this->hierarchyService->isChild($userConnected$seller)){
  44.                     return true;
  45.                 }
  46.                 break;
  47.             case self::DELETE:
  48.                 // logique pour déterminer si l'utilisateur peut modifier le declaratif
  49.                 // return true or false
  50.                 if($seller == $userConnected || $this->hierarchyService->isChild($userConnected$seller)){
  51.                     return true;
  52.                 }
  53.                 break;
  54.         }
  55.         return false;
  56.     }
  57. }