src/Bundles/DiseaseCaseBundle/Security/ViewDiseaseCaseVoter.php line 15

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\DiseaseCaseBundle\Enum\SharePermissionEnum;
  6. use App\Bundles\DiseaseCaseBundle\Service\DiseaseCaseService;
  7. use App\Bundles\OrganizationBundle\Service\Organization\OrganizationService;
  8. use App\Bundles\UserBundle\Enum\SystemPermissionEnum;
  9. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  10. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  11. class ViewDiseaseCaseVoter extends Voter
  12. {
  13.     public function __construct(
  14.         private readonly OrganizationService $organizationService,
  15.         private readonly DiseaseCaseService $diseaseCaseService,
  16.     ) {
  17.     }
  18.     protected function supports(string $attribute$subject): bool
  19.     {
  20.         return in_array($attribute, [SystemPermissionEnum::SPECIFIC_DISEASE_CASE_VIEW->value]);
  21.     }
  22.     /** @param DiseaseCase $subject */
  23.     protected function voteOnAttribute(string $attribute$subjectTokenInterface $token): bool
  24.     {
  25.         if (
  26.             !($this->organizationService->hasPermissionByOrganization($subject->getCurrentOrganization()) ||
  27.                 $this->organizationService->hasPermissionByOrganization($subject->getInvestigatingInstitution()) ||
  28.                 $this->organizationService->hasPermissionByPatientAddress($subject->getPatientLivingAddress()) ||
  29.                 $this->diseaseCaseService->hasSharedPermissions(
  30.                     $subject,
  31.                     [SharePermissionEnum::SHOWSharePermissionEnum::EDIT]
  32.                 )
  33.             )
  34.         ) {
  35.             return false;
  36.         }
  37.         return true;
  38.     }
  39. }