src/Security/SurveyFillEntryVoter.php line 10

Open in your IDE?
  1. <?php
  2. namespace App\Security;
  3. use App\Entity\SurveyFillEntry;
  4. use App\Entity\User;
  5. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  6. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  7. class SurveyFillEntryVoter extends Voter
  8. {
  9.     const CREATE 'create';
  10.     const UPDATE 'update';
  11.     protected function supports(string $attribute$subject)
  12.     {
  13.         if (!in_array($attribute, [self::CREATEself::UPDATE])) {
  14.             return false;
  15.         }
  16.         if (!$subject instanceof SurveyFillEntry) {
  17.             return false;
  18.         }
  19.         return true;
  20.     }
  21.     protected function voteOnAttribute(string $attribute$subjectTokenInterface $token)
  22.     {
  23.         $user $token->getUser();
  24.         if (!$user instanceof User) {
  25.             // the user must be logged in; if not, deny access
  26.             return false;
  27.         }
  28.         /** @var SurveyFillEntry $surveyFillEntry */
  29.         $surveyFillEntry $subject;
  30.         switch ($attribute) {
  31.             case self::CREATE:
  32.             case self::UPDATE:
  33.                 return $this->canCreate($surveyFillEntry$user);
  34.         }
  35.     }
  36.     private function canCreate(SurveyFillEntry $surveyFillEntryUser $user)
  37.     {
  38.         return $surveyFillEntry->canUserCreate($user);
  39.     }
  40. }