src/Bundles/DiseaseCaseBundle/Security/DiseaseCaseVoter.php line 13

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Bundles\DiseaseCaseBundle\Security;
  4. use App\Bundles\DiseaseCaseBundle\Entity\DiseaseCase;
  5. use App\Bundles\OrganizationBundle\Service\Organization\OrganizationService;
  6. use App\Bundles\UserBundle\Enum\SystemPermissionEnum;
  7. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  8. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  9. class DiseaseCaseVoter extends Voter
  10. {
  11.     public function __construct(
  12.         private readonly OrganizationService $organizationService,
  13.     ) {
  14.     }
  15.     protected function supports(string $attribute$subject): bool
  16.     {
  17.         return in_array(
  18.             $attribute,
  19.             [
  20.                 SystemPermissionEnum::SPECIFIC_DISEASE_CASE_VIEW->value,
  21.                 SystemPermissionEnum::SPECIFIC_DISEASE_CASE_EDIT->value,
  22.             ],
  23.         );
  24.     }
  25.     /** @param DiseaseCase $subject */
  26.     protected function voteOnAttribute(string $attribute$subjectTokenInterface $token): bool
  27.     {
  28.         if (
  29.             !($this->organizationService->hasPermissionByOrganization($subject->getCreatingOrganization()) ||
  30.                 $this->organizationService->hasPermissionByOrganization($subject->getInvestigatingInstitution()) ||
  31.                 $this->organizationService->hasPermissionByPatientAddress($subject->getPatientLivingAddress()))
  32.         ) {
  33.             return false;
  34.         }
  35.         return true;
  36.     }
  37. }