src/Security/Voter/UserVoter.php line 12

Open in your IDE?
  1. <?php
  2. namespace Seidemann\Hanagud\Security\Voter;
  3. namespace Seidemann\Hanagud\Security\Voter;
  4. use Seidemann\Hanagud\Entity\HanagudUser;
  5. use Seidemann\Hanagud\Services\PermissionService;
  6. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  7. use Symfony\Component\Security\Core\Authorization\Voter\Voter;
  8. use Symfony\Component\Security\Core\User\UserInterface;
  9. class UserVoter extends Voter
  10. {
  11.     public function __construct(private PermissionService $permissionService) {}
  12.     protected function supports(string $attributemixed $subject): bool
  13.     {
  14.         // Hier definierst du, welche Berechtigungen dieser Voter behandelt
  15.         return in_array($attribute, ['Edit User''Create User''Delete User']);
  16.     }
  17.     protected function voteOnAttribute(string $attributemixed $subjectTokenInterface $token): bool
  18.     {
  19.         $user $token->getUser();
  20.         // Sicherstellen, dass ein eingeloggter Benutzer vorhanden ist
  21.         if (!$user instanceof HanagudUser) {
  22.             return false;
  23.         }
  24.         // Berechtigungen abrufen
  25.         $permissions $this->permissionService->getPermissionsForUser($user);
  26.         // Prüfen, ob die gewünschte Berechtigung vorhanden ist
  27.         return in_array($attribute$permissions);
  28.     }
  29. }