Вход Регистрация
Файл: symfony-2.7/src/Symfony/Component/Security/Acl/Voter/AclVoter.php
Строк: 217
<?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 SymfonyComponentSecurityAclVoter;

use 
PsrLogLoggerInterface;
use 
SymfonyComponentSecurityAclExceptionNoAceFoundException;
use 
SymfonyComponentSecurityAclExceptionAclNotFoundException;
use 
SymfonyComponentSecurityAclModelAclProviderInterface;
use 
SymfonyComponentSecurityAclModelObjectIdentityInterface;
use 
SymfonyComponentSecurityAclPermissionPermissionMapInterface;
use 
SymfonyComponentSecurityAclModelSecurityIdentityRetrievalStrategyInterface;
use 
SymfonyComponentSecurityAclModelObjectIdentityRetrievalStrategyInterface;
use 
SymfonyComponentSecurityCoreAuthenticationTokenTokenInterface;
use 
SymfonyComponentSecurityCoreAuthorizationVoterVoterInterface;

/**
 * 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 $aclProviderObjectIdentityRetrievalStrategyInterface $oidRetrievalStrategySecurityIdentityRetrievalStrategyInterface $sidRetrievalStrategyPermissionMapInterface $permissionMapLoggerInterface $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 
is_string($attribute) && $this->permissionMap->contains($attribute);
    }

    public function 
vote(TokenInterface $token$object, array $attributes)
    {
        foreach (
$attributes as $attribute) {
            if (!
$this->supportsAttribute($attribute)) {
                continue;
            }

            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$sidsfalse)) {
                    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$sidsfalse)) {
                    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 bool
     */
    
public function supportsClass($class)
    {
        return 
true;
    }
}
Онлайн: 0
Реклама