123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\Security\Acl\Voter;
- use Psr\Log\LoggerInterface;
- use Symfony\Component\Security\Acl\Exception\NoAceFoundException;
- use Symfony\Component\Security\Acl\Exception\AclNotFoundException;
- use Symfony\Component\Security\Acl\Model\AclProviderInterface;
- use Symfony\Component\Security\Acl\Model\ObjectIdentityInterface;
- use Symfony\Component\Security\Acl\Permission\PermissionMapInterface;
- use Symfony\Component\Security\Acl\Model\SecurityIdentityRetrievalStrategyInterface;
- use Symfony\Component\Security\Acl\Model\ObjectIdentityRetrievalStrategyInterface;
- use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
- use Symfony\Component\Security\Core\Authorization\Voter\VoterInterface;
- /**
- * This voter can be used as a base class for implementing your own permissions.
- *
- * @author Johannes M. Schmitt <schmittjoh@gmail.com>
- */
- class AclVoter implements VoterInterface
- {
- private $aclProvider;
- private $permissionMap;
- private $objectIdentityRetrievalStrategy;
- private $securityIdentityRetrievalStrategy;
- private $allowIfObjectIdentityUnavailable;
- private $logger;
- public function __construct(AclProviderInterface $aclProvider, ObjectIdentityRetrievalStrategyInterface $oidRetrievalStrategy, SecurityIdentityRetrievalStrategyInterface $sidRetrievalStrategy, PermissionMapInterface $permissionMap, LoggerInterface $logger = null, $allowIfObjectIdentityUnavailable = true)
- {
- $this->aclProvider = $aclProvider;
- $this->permissionMap = $permissionMap;
- $this->objectIdentityRetrievalStrategy = $oidRetrievalStrategy;
- $this->securityIdentityRetrievalStrategy = $sidRetrievalStrategy;
- $this->logger = $logger;
- $this->allowIfObjectIdentityUnavailable = $allowIfObjectIdentityUnavailable;
- }
- public function supportsAttribute($attribute)
- {
- return $this->permissionMap->contains($attribute);
- }
- public function vote(TokenInterface $token, $object, array $attributes)
- {
- foreach ($attributes as $attribute) {
- if (null === $masks = $this->permissionMap->getMasks($attribute, $object)) {
- continue;
- }
- if (null === $object) {
- if (null !== $this->logger) {
- $this->logger->debug(sprintf('Object identity unavailable. Voting to %s', $this->allowIfObjectIdentityUnavailable? 'grant access' : 'abstain'));
- }
- return $this->allowIfObjectIdentityUnavailable ? self::ACCESS_GRANTED : self::ACCESS_ABSTAIN;
- } elseif ($object instanceof FieldVote) {
- $field = $object->getField();
- $object = $object->getDomainObject();
- } else {
- $field = null;
- }
- if ($object instanceof ObjectIdentityInterface) {
- $oid = $object;
- } elseif (null === $oid = $this->objectIdentityRetrievalStrategy->getObjectIdentity($object)) {
- if (null !== $this->logger) {
- $this->logger->debug(sprintf('Object identity unavailable. Voting to %s', $this->allowIfObjectIdentityUnavailable? 'grant access' : 'abstain'));
- }
- return $this->allowIfObjectIdentityUnavailable ? self::ACCESS_GRANTED : self::ACCESS_ABSTAIN;
- }
- if (!$this->supportsClass($oid->getType())) {
- return self::ACCESS_ABSTAIN;
- }
- $sids = $this->securityIdentityRetrievalStrategy->getSecurityIdentities($token);
- try {
- $acl = $this->aclProvider->findAcl($oid, $sids);
- if (null === $field && $acl->isGranted($masks, $sids, false)) {
- if (null !== $this->logger) {
- $this->logger->debug('ACL found, permission granted. Voting to grant access');
- }
- return self::ACCESS_GRANTED;
- } elseif (null !== $field && $acl->isFieldGranted($field, $masks, $sids, false)) {
- if (null !== $this->logger) {
- $this->logger->debug('ACL found, permission granted. Voting to grant access');
- }
- return self::ACCESS_GRANTED;
- }
- if (null !== $this->logger) {
- $this->logger->debug('ACL found, insufficient permissions. Voting to deny access.');
- }
- return self::ACCESS_DENIED;
- } catch (AclNotFoundException $noAcl) {
- if (null !== $this->logger) {
- $this->logger->debug('No ACL found for the object identity. Voting to deny access.');
- }
- return self::ACCESS_DENIED;
- } catch (NoAceFoundException $noAce) {
- if (null !== $this->logger) {
- $this->logger->debug('ACL found, no ACE applicable. Voting to deny access.');
- }
- return self::ACCESS_DENIED;
- }
- }
- // no attribute was supported
- return self::ACCESS_ABSTAIN;
- }
- /**
- * You can override this method when writing a voter for a specific domain
- * class.
- *
- * @param string $class The class name
- *
- * @return Boolean
- */
- public function supportsClass($class)
- {
- return true;
- }
- }
|