Вход Регистрация
Файл: symfony-2.7/src/Symfony/Component/Security/Core/Authentication/AuthenticationProviderManager.php
Строк: 206
<?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 SymfonyComponentSecurityCoreAuthentication;

use 
SymfonyComponentSecurityCoreEventAuthenticationFailureEvent;
use 
SymfonyComponentSecurityCoreEventAuthenticationEvent;
use 
SymfonyComponentSecurityCoreAuthenticationEvents;
use 
SymfonyComponentEventDispatcherEventDispatcherInterface;
use 
SymfonyComponentSecurityCoreExceptionAccountStatusException;
use 
SymfonyComponentSecurityCoreExceptionAuthenticationException;
use 
SymfonyComponentSecurityCoreExceptionProviderNotFoundException;
use 
SymfonyComponentSecurityCoreAuthenticationProviderAuthenticationProviderInterface;
use 
SymfonyComponentSecurityCoreAuthenticationTokenTokenInterface;

/**
 * AuthenticationProviderManager uses a list of AuthenticationProviderInterface
 * instances to authenticate a Token.
 *
 * @author Fabien Potencier <fabien@symfony.com>
 * @author Johannes M. Schmitt <schmittjoh@gmail.com>
 */
class AuthenticationProviderManager implements AuthenticationManagerInterface
{
    private 
$providers;
    private 
$eraseCredentials;
    private 
$eventDispatcher;

    
/**
     * Constructor.
     *
     * @param AuthenticationProviderInterface[] $providers        An array of AuthenticationProviderInterface instances
     * @param bool                              $eraseCredentials Whether to erase credentials after authentication or not
     *
     * @throws InvalidArgumentException
     */
    
public function __construct(array $providers$eraseCredentials true)
    {
        if (!
$providers) {
            throw new 
InvalidArgumentException('You must at least add one authentication provider.');
        }

        
$this->providers $providers;
        
$this->eraseCredentials = (bool) $eraseCredentials;
    }

    public function 
setEventDispatcher(EventDispatcherInterface $dispatcher)
    {
        
$this->eventDispatcher $dispatcher;
    }

    
/**
     * {@inheritdoc}
     */
    
public function authenticate(TokenInterface $token)
    {
        
$lastException null;
        
$result null;

        foreach (
$this->providers as $provider) {
            if (!
$provider->supports($token)) {
                continue;
            }

            try {
                
$result $provider->authenticate($token);

                if (
null !== $result) {
                    break;
                }
            } catch (
AccountStatusException $e) {
                
$e->setToken($token);

                throw 
$e;
            } catch (
AuthenticationException $e) {
                
$lastException $e;
            }
        }

        if (
null !== $result) {
            if (
true === $this->eraseCredentials) {
                
$result->eraseCredentials();
            }

            if (
null !== $this->eventDispatcher) {
                
$this->eventDispatcher->dispatch(AuthenticationEvents::AUTHENTICATION_SUCCESS, new AuthenticationEvent($result));
            }

            return 
$result;
        }

        if (
null === $lastException) {
            
$lastException = new ProviderNotFoundException(sprintf('No Authentication Provider found for token of class "%s".'get_class($token)));
        }

        if (
null !== $this->eventDispatcher) {
            
$this->eventDispatcher->dispatch(AuthenticationEvents::AUTHENTICATION_FAILURE, new AuthenticationFailureEvent($token$lastException));
        }

        
$lastException->setToken($token);

        throw 
$lastException;
    }
}
Онлайн: 0
Реклама