src/Security/ImpersonateUserVoter.php line 12

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Security;
  4. use App\Entity\System\Customer;
  5. use App\Entity\System\Employee;
  6. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  7. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  8. class ImpersonateUserVoter extends Voter
  9. {
  10.     public const CAN_SWITCH_USER 'CAN_SWITCH_USER';
  11.     protected function supports($attribute$subject): bool
  12.     {
  13.         return $attribute === self::CAN_SWITCH_USER && $subject instanceof Customer;
  14.     }
  15.     protected function voteOnAttribute($attribute$subjectTokenInterface $token): bool
  16.     {
  17.         $user $token->getUser();
  18.         if (!$user instanceof Employee || !$subject instanceof Customer) {
  19.             return false;
  20.         }
  21.         if ($this->loggedUserIsAdmin($user)) {
  22.             return true;
  23.         }
  24.         $subjectRolesIndex = \array_flip($subject->getRoles());
  25.         if ($this->requestedUserHasManagementRoles($subjectRolesIndex)) {
  26.             return false;
  27.         }
  28.         $userRolesIndex = \array_flip($user->getRoles());
  29.         return $this->loggedUserHasAnyImpersonatorRole($userRolesIndex);
  30.     }
  31.     /**
  32.      * @param array $subjectRolesIndex
  33.      *
  34.      * @return bool
  35.      */
  36.     protected function requestedUserHasManagementRoles(array $subjectRolesIndex): bool
  37.     {
  38.         return \array_key_exists('ROLE_EMPLOYEE'$subjectRolesIndex);
  39.     }
  40.     protected function loggedUserIsAdmin(Employee $user): bool
  41.     {
  42.         $userRolesIndex = \array_flip($user->getRoles());
  43.         return \array_key_exists('ROLE_SUPER_ADMIN'$userRolesIndex);
  44.     }
  45.     /**
  46.      * @param array<string, array-key> $userRolesIndex
  47.      */
  48.     public function loggedUserHasAnyImpersonatorRole(array $userRolesIndex): bool
  49.     {
  50.         return \array_key_exists('ROLE_SUPER_ADMIN'$userRolesIndex)
  51.             || \array_key_exists('ROLE_TECH_SUPPORT'$userRolesIndex)
  52.             || \array_key_exists('ROLE_SALES_ADMIN'$userRolesIndex)
  53.             || \array_key_exists('ROLE_FINANCE'$userRolesIndex)
  54.             || \array_key_exists('ROLE_SALES'$userRolesIndex);
  55.     }
  56. }