src/Security/Voter/ProductsVoter.php line 11

Open in your IDE?
  1. <?php
  2. namespace App\Security\Voter;
  3. use App\Entity\Products;
  4. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  5. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  6. use Symfony\Component\Security\Core\Security;
  7. use Symfony\Component\Security\Core\User\UserInterface;
  8. class ProductsVoter extends Voter
  9. {
  10.     const EDIT 'PRODUCT_EDIT';
  11.     const DELETE 'PRODUCT_DELETE';
  12.     private $security;
  13.     public function __construct(Security $security)
  14.     {
  15.         $this->security $security;
  16.     }
  17.     protected function supports(string $attribute$product): bool
  18.     {
  19.         if(!in_array($attribute, [self::EDITself::DELETE])){
  20.             return false;
  21.         }
  22.         if(!$product instanceof Products){
  23.             return false;
  24.         }
  25.         return true;
  26.         // return in_array($attribute, [self::EDIT, self::DELETE]) && $product instanceof Products;
  27.     }
  28.     protected function voteOnAttribute($attribute$productTokenInterface $token): bool
  29.     {
  30.         // On récupère l'utilisateur à partir du token
  31.         $user $token->getUser();
  32.         if(!$user instanceof UserInterface) return false;
  33.         // On vérifie si l'utilisateur est admin
  34.         if($this->security->isGranted('ROLE_ADMIN')) return true;
  35.         // On vérifie les permissions
  36.         switch($attribute){
  37.             case self::EDIT:
  38.                 // On vérifie si l'utilisateur peut éditer
  39.                 return $this->canEdit();
  40.                 break;
  41.             case self::DELETE:
  42.                 // On vérifie si l'utilisateur peut supprimer
  43.                 return $this->canDelete();
  44.                 break;
  45.         }
  46.     }
  47.     private function canEdit(){
  48.         return $this->security->isGranted('ROLE_PRODUCT_ADMIN');
  49.     }
  50.     private function canDelete(){
  51.         return $this->security->isGranted('ROLE_ADMIN');
  52.     }
  53. }