UserAclVoter.php 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <?php
  2. namespace Sonata\UserBundle\Security\Authorization\Voter;
  3. use FOS\UserBundle\Model\UserInterface;
  4. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  5. use Symfony\Component\Security\Acl\Voter\AclVoter;
  6. class UserAclVoter extends AclVoter
  7. {
  8. /**
  9. * {@InheritDoc}
  10. */
  11. public function supportsClass($class)
  12. {
  13. // support the Object-Scope ACL
  14. return is_subclass_of($class, 'FOS\UserBundle\Model\UserInterface');
  15. }
  16. public function supportsAttribute($attribute)
  17. {
  18. return $attribute === 'EDIT' || $attribute === 'DELETE';
  19. }
  20. public function vote(TokenInterface $token, $object, array $attributes)
  21. {
  22. if (!$this->supportsClass(get_class($object))) {
  23. return self::ACCESS_ABSTAIN;
  24. }
  25. foreach ($attributes as $attribute) {
  26. if ($this->supportsAttribute($attribute) && $object instanceof UserInterface) {
  27. if ($object->isSuperAdmin() && !$token->getUser()->isSuperAdmin()) {
  28. // deny a non super admin user to edit or delete a super admin user
  29. return self::ACCESS_DENIED;
  30. }
  31. }
  32. }
  33. // leave the permission voting to the AclVoter that is using the default permission map
  34. return self::ACCESS_ABSTAIN;
  35. }
  36. }