src/Bundles/DiseaseCaseBundle/Security/EditDiseaseCaseVoter.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 EditDiseaseCaseVoter 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_EDIT->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($subject, [SharePermissionEnum::EDIT]))
  30.         ) {
  31.             return false;
  32.         }
  33.         return true;
  34.     }
  35. }