src/Security/Voter/AttendanceTypesVoter.php line 14

Open in your IDE?
  1. <?php
  2. namespace App\Security\Voter;
  3. use App\Entity\Admin;
  4. use App\Entity\AttendanceTypes;
  5. use App\Service\PermissionService;
  6. use Doctrine\ORM\EntityManagerInterface;
  7. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  8. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  9. use Symfony\Component\Security\Core\Security;
  10. class AttendanceTypesVoter extends Voter
  11. {
  12.     const VIEW 'view';
  13.     private $security;
  14.     private $entityManager;
  15.     public function __construct(Security $securityEntityManagerInterface $entityManager)
  16.     {
  17.         $this->security $security;
  18.         $this->entityManager $entityManager;
  19.     }
  20.     public function supports($attribute$subject)
  21.     {
  22.         if(!in_array($attribute, [self::VIEW])){
  23.             return false;
  24.         }
  25.         if(!$subject instanceof AttendanceTypes){
  26.             return false;
  27.         }
  28.         return true;
  29.     }
  30.     public function voteOnAttribute($attribute$subjectTokenInterface $token)
  31.     {
  32.         $user $token->getUser();
  33.         if(!$user instanceof Admin){
  34.             return false;
  35.         }
  36.         if($this->security->isGranted('ROLE_SUPERADMIN')) {
  37.             return true;
  38.         }
  39.         $service = new PermissionService($this->entityManager);
  40.         $permissions $service->getUserPermissions($user);
  41.         switch($attribute){
  42.             case self::VIEW:
  43.                 if(in_array("types_of_calendar_entries"$permissions)){
  44.                     return true;
  45.                 }
  46.                 return false;
  47.                 break;
  48.         }
  49.         return false;
  50.     }
  51. }