src/Security/Voter/IsOwnerOrGranted.php line 14

Open in your IDE?
  1. <?php
  2. namespace App\Security\Voter;
  3. use App\Entity\Establishment;
  4. use App\Entity\Faq;
  5. use App\Entity\Message;
  6. use App\Entity\Program;
  7. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  8. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  9. use Symfony\Component\Security\Core\Security;
  10. use Symfony\Component\Security\Core\User\UserInterface;
  11. class IsOwnerOrGranted extends Voter
  12. {
  13.     public function __construct(private readonly Security $security)
  14.     {
  15.     }
  16.     protected function supports(string $attribute$subject): bool
  17.     {
  18.         return $attribute == 'IS_OWNER_OR_GRANTED';
  19.     }
  20.     protected function voteOnAttribute(string $attribute$subjectTokenInterface $token): bool
  21.     {
  22.         $user $token->getUser();
  23.         // if the user is anonymous, do not grant access
  24.         if (!$user instanceof UserInterface) {
  25.             return false;
  26.         }
  27.         // Autorise l’équipe soignante d’un établissement à modifier les messages envoyés par l’un des membres de l’équipe
  28.         if ($subject instanceof Message && $user->getEstablishment() instanceof Establishment && $this->security->isGranted('ROLE_DOCTOR')) {
  29.             if ($subject->getSender()->getEstablishment() === $user->getEstablishment()) {
  30.                 return true;
  31.             }
  32.         }
  33.         // Autorise un utilisateur à modifier un message qu’il a envoyé
  34.         if ($subject instanceof Message) {
  35.             return $subject->getSender() === $user;
  36.         }
  37.         // Autorise un utilisateur à consulter un ETP de son établissement
  38.         if ($subject instanceof Faq && $subject->getEstablishment() === $user->getEstablishment()) {
  39.             return true;
  40.         }
  41.         // Autorise un utilisateur à supprimer un program type qu'il a créé
  42.         if ($subject instanceof Program && $user->getEstablishment() instanceof Establishment && $this->security->isGranted('ROLE_DOCTOR')) {
  43.             return $subject->getEstablishment() === $user->getEstablishment();
  44.         }
  45.         return false;
  46.     }
  47. }