src/Bundles/ReportBundle/Security/ReportTemplateViewVoter.php line 19

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Bundles\ReportBundle\Security;
  4. use App\Bundles\LocationBundle\Enum\LocationTypeEnum;
  5. use App\Bundles\OrganizationBundle\Enum\UserOrganizationResponsibleLevelEnum;
  6. use App\Bundles\OrganizationBundle\Exception\UserOrganizationNotFoundException;
  7. use App\Bundles\OrganizationBundle\Service\UserOrganization\UserOrganizationProvider;
  8. use App\Bundles\OrganizationBundle\Service\UserOrganization\UserOrganizationResponsibleLevelResolver;
  9. use App\Bundles\ReportBundle\Entity\ReportTemplate;
  10. use App\Bundles\UserBundle\Entity\User;
  11. use App\Bundles\UserBundle\Enum\SystemPermissionEnum;
  12. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  13. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  14. use Symfony\Component\Security\Core\Security;
  15. class ReportTemplateViewVoter extends Voter
  16. {
  17.     public function __construct(
  18.         private readonly Security $security,
  19.         private readonly UserOrganizationProvider $organizationProvider,
  20.         private readonly UserOrganizationProvider $userOrganizationProvider,
  21.         private readonly UserOrganizationResponsibleLevelResolver $levelResolver,
  22.     ) {
  23.     }
  24.     protected function supports(string $attribute$subject): bool
  25.     {
  26.         return $attribute === SystemPermissionEnum::SINGLE_REPORT_TEMPLATE_VIEW->value;
  27.     }
  28.     /** @param ReportTemplate $subject
  29.      * @throws UserOrganizationNotFoundException
  30.      */
  31.     protected function voteOnAttribute(string $attribute$subjectTokenInterface $token): bool
  32.     {
  33.         $user $this->security->getUser();
  34.         if (!$user instanceof User) {
  35.             return false;
  36.         }
  37.         if ($subject->getUser() === $user) {
  38.             return true;
  39.         }
  40.         $organization $this->userOrganizationProvider->provideFromSession()->getOrganization();
  41.         if ($organization === $subject->getOrganization() and $subject->isShared()) {
  42.             return true;
  43.         }
  44.         if (!$subject->isSent()) {
  45.             return false;
  46.         }
  47.         $userLevel $this->levelResolver->resolve(
  48.             $this->organizationProvider->provideFromSession()
  49.         );
  50.         $location $subject->getLocation();
  51.         if (in_array($location->getType(), LocationTypeEnum::getRegionalTypes())) {
  52.             if ($userLevel === UserOrganizationResponsibleLevelEnum::NATIONAL_LEVEL->value) {
  53.                 return true;
  54.             }
  55.         }
  56.         if (in_array($location->getType(), LocationTypeEnum::getDistrictTypes())) {
  57.             if ($userLevel === UserOrganizationResponsibleLevelEnum::REGIONAL_LEVEL->value) {
  58.                 return true;
  59.             }
  60.         }
  61.         return false;
  62.     }
  63. }