src/Security/Voter/AdminVoter.php line 13

Open in your IDE?
  1. <?php
  2. namespace App\Security\Voter;
  3. use App\Entity\Admin;
  4. use App\Service\PermissionService;
  5. use Doctrine\ORM\EntityManagerInterface;
  6. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  7. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  8. use Symfony\Component\Security\Core\Security;
  9. class AdminVoter extends Voter
  10. {
  11.     const VIEW 'view';
  12.     const ADD 'add';
  13.     const EDIT 'edit';
  14.     const DELETE 'delete';
  15.     const PERMISSION 'permission';
  16.     private $security;
  17.     private $entityManager;
  18.     public function __construct(Security $securityEntityManagerInterface $entityManager)
  19.     {
  20.         $this->security $security;
  21.         $this->entityManager $entityManager;
  22.     }
  23.     public function supports($attribute$subject): bool
  24.     {
  25.         if(!in_array($attribute, [self::DELETEself::ADDself::VIEWself::EDITself::PERMISSION])){
  26.             return false;
  27.         }
  28.         if($attribute !== self::VIEW && !$subject instanceof Admin){
  29.             return false;
  30.         }
  31.         return true;
  32.     }
  33.     public function voteOnAttribute($attribute$subjectTokenInterface $token)
  34.     {
  35.         $user $token->getUser();
  36.         if(!$user instanceof Admin){
  37.             return false;
  38.         }
  39.         if($this->security->isGranted('ROLE_SUPERADMIN')) {
  40.             return true;
  41.         }
  42.         $service = new PermissionService($this->entityManager);
  43.         $permissions $service->getUserPermissions($user);
  44.         switch($attribute){
  45.             case self::VIEW:
  46.                 if(in_array("admin"$permissions)){
  47.                     return true;
  48.                 }
  49.                 return false;
  50.                 break;
  51.             case self::DELETE:
  52.                 if(in_array("admin_delete"$permissions)){
  53.                     return true;
  54.                 }
  55.                 return false;
  56.                 break;
  57.             case self::ADD:
  58.                 if(in_array("admin_add"$permissions)){
  59.                     return true;
  60.                 }
  61.                 return false;
  62.                 break;
  63.             case self::EDIT:
  64.                 if(in_array("admin_edit"$permissions)){
  65.                     return true;
  66.                 }
  67.                 if($subject->getId() == $user->getId()){
  68.                     return true;
  69.                 }
  70.                 return false;
  71.                 break;
  72.             case self::PERMISSION:
  73.                 if(in_array("admin_permissions"$permissions)){
  74.                     return true;
  75.                 }
  76.                 return false;
  77.                 break;
  78.         }
  79.         return false;
  80.     }
  81. }