src/Security/Voter/ClientVoter.php line 10

Open in your IDE?
  1. <?php
  2. namespace App\Security\Voter;
  3. use App\Entity\Company\Client;
  4. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  5. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  6. use Symfony\Component\Security\Core\User\UserInterface;
  7. class ClientVoter extends Voter
  8. {
  9.     public const EDIT 'CLIENT_EDIT';
  10.     public const VIEW 'CLIENT_VIEW';
  11.     public const DELETE 'CLIENT_DELETE';
  12.     protected function supports(string $attributemixed $subject): bool
  13.     {
  14.         return in_array($attribute, [self::EDITself::VIEWself::DELETE])
  15.             && $subject instanceof Client;
  16.     }
  17.     protected function voteOnAttribute(string $attributemixed $subjectTokenInterface $token): bool
  18.     {
  19.         $user $token->getUser();
  20.         
  21.         if (!$user instanceof UserInterface) {
  22.             return false;
  23.         }
  24.         return $subject->getCompany()->getId() == $user->getCompany()->getId();
  25.     }
  26. }