src/Security/Voter/CreditVoter.php line 11

Open in your IDE?
  1. <?php
  2. namespace App\Security\Voter;
  3. use App\Entity\Company\User;
  4. use App\Entity\Credit\Credit;
  5. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  6. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  7. use Symfony\Component\Security\Core\User\UserInterface;
  8. class CreditVoter extends Voter
  9. {
  10.     public const EDIT 'EDIT';
  11.     public const VIEW 'VIEW';
  12.     public const DELETE 'DELETE';
  13.     public const CONTINUE = 'CONTINUE';
  14.     public const SEND_MAIL 'SEND_MAIL';
  15.     protected function supports(string $attributemixed $subject): bool
  16.     {
  17.         return $subject instanceof Credit;
  18.     }
  19.     protected function voteOnAttribute(string $attributemixed $subjectTokenInterface $token): bool
  20.     {
  21.         $user $token->getUser();
  22.         if (!$user instanceof UserInterface) {
  23.             return false;
  24.         }
  25.         return match ($attribute) {
  26.             self::EDIT => $this->canPerformSimpleAction($subject$user),
  27.             self::VIEW => $this->canPerformSimpleAction($subject$user),
  28.             self::DELETE => $this->canPerformSimpleAction($subject$user),
  29.             self::CONTINUE => $this->canContinue($subject$user),
  30.             self::SEND_MAIL => $this->canSendMail($subject$user)
  31.         };
  32.     }
  33.     /**
  34.      *
  35.      * @param Credit $credit
  36.      * @param User $user
  37.      * @return boolean
  38.      */
  39.     private function canPerformSimpleAction(Credit $creditUser $user): bool
  40.     {
  41.         return $credit->getCompany()->getId() == $user->getCompany()->getId();
  42.     }
  43.     /**
  44.      *
  45.      * @param Credit $credit
  46.      * @param User $user
  47.      * @return boolean
  48.      */
  49.     private function canContinue(Credit $creditUser $user): bool
  50.     {
  51.         return $this->canPerformSimpleAction($credit$user) && $credit->getStatus() == 0;
  52.     }
  53.     /**
  54.      *
  55.      * @param Credit $invoice
  56.      * @param User $user
  57.      * @return boolean
  58.      */
  59.     private function canSendMail(Credit $creditUser $user): bool
  60.     {
  61.         return $this->canPerformSimpleAction($credit$user) && $credit->getStatus() == 1;
  62.     }
  63. }