Вход Регистрация
Файл: symfony-2.7/src/Symfony/Component/Security/Http/Logout/LogoutUrlGenerator.php
Строк: 251
<?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 SymfonyComponentSecurityHttpLogout;

use 
SymfonyComponentFormExtensionCsrfCsrfProviderCsrfProviderAdapter;
use 
SymfonyComponentFormExtensionCsrfCsrfProviderCsrfProviderInterface;
use 
SymfonyComponentHttpFoundationRequestStack;
use 
SymfonyComponentRoutingGeneratorUrlGeneratorInterface;
use 
SymfonyComponentSecurityCoreAuthenticationTokenStorageTokenStorageInterface;
use 
SymfonyComponentSecurityCsrfCsrfTokenManagerInterface;

/**
 * Provides generator functions for the logout URL.
 *
 * @author Fabien Potencier <fabien@symfony.com>
 * @author Jeremy Mikola <jmikola@gmail.com>
 */
class LogoutUrlGenerator
{
    private 
$requestStack;
    private 
$router;
    private 
$tokenStorage;
    private 
$listeners = array();

    public function 
__construct(RequestStack $requestStack nullUrlGeneratorInterface $router nullTokenStorageInterface $tokenStorage null)
    {
        
$this->requestStack $requestStack;
        
$this->router $router;
        
$this->tokenStorage $tokenStorage;
    }

    
/**
     * Registers a firewall's LogoutListener, allowing its URL to be generated.
     *
     * @param string                    $key              The firewall key
     * @param string                    $logoutPath       The path that starts the logout process
     * @param string                    $csrfTokenId      The ID of the CSRF token
     * @param string                    $csrfParameter    The CSRF token parameter name
     * @param CsrfTokenManagerInterface $csrfTokenManager A CsrfTokenManagerInterface instance
     */
    
public function registerListener($key$logoutPath$csrfTokenId$csrfParameter$csrfTokenManager null)
    {
        if (
$csrfTokenManager instanceof CsrfProviderInterface) {
            
$csrfTokenManager = new CsrfProviderAdapter($csrfTokenManager);
        } elseif (
null !== $csrfTokenManager && !$csrfTokenManager instanceof CsrfTokenManagerInterface) {
            throw new 
InvalidArgumentException('The CSRF token manager should be an instance of CsrfProviderInterface or CsrfTokenManagerInterface.');
        }

        
$this->listeners[$key] = array($logoutPath$csrfTokenId$csrfParameter$csrfTokenManager);
    }

    
/**
     * Generates the absolute logout path for the firewall.
     *
     * @param string|null $key The firewall key or null to use the current firewall key
     *
     * @return string The logout path
     */
    
public function getLogoutPath($key null)
    {
        return 
$this->generateLogoutUrl($keyUrlGeneratorInterface::ABSOLUTE_PATH);
    }

    
/**
     * Generates the absolute logout URL for the firewall.
     *
     * @param string|null $key The firewall key or null to use the current firewall key
     *
     * @return string The logout URL
     */
    
public function getLogoutUrl($key null)
    {
        return 
$this->generateLogoutUrl($keyUrlGeneratorInterface::ABSOLUTE_URL);
    }

    
/**
     * Generates the logout URL for the firewall.
     *
     * @param string|null $key           The firewall key or null to use the current firewall key
     * @param bool|string $referenceType The type of reference (one of the constants in UrlGeneratorInterface)
     *
     * @return string The logout URL
     *
     * @throws InvalidArgumentException if no LogoutListener is registered for the key or the key could not be found automatically.
     */
    
private function generateLogoutUrl($key$referenceType)
    {
        
// Fetch the current provider key from token, if possible
        
if (null === $key && null !== $this->tokenStorage) {
            
$token $this->tokenStorage->getToken();
            if (
null !== $token && method_exists($token'getProviderKey')) {
                
$key $token->getProviderKey();
            }
        }

        if (
null === $key) {
            throw new 
InvalidArgumentException('Unable to find the current firewall LogoutListener, please provide the provider key manually.');
        }

        if (!
array_key_exists($key$this->listeners)) {
            throw new 
InvalidArgumentException(sprintf('No LogoutListener found for firewall key "%s".'$key));
        }

        list(
$logoutPath$csrfTokenId$csrfParameter$csrfTokenManager) = $this->listeners[$key];

        
$parameters null !== $csrfTokenManager ? array($csrfParameter => (string) $csrfTokenManager->getToken($csrfTokenId)) : array();

        if (
'/' === $logoutPath[0]) {
            if (!
$this->requestStack) {
                throw new 
LogicException('Unable to generate the logout URL without a RequestStack.');
            }

            
$request $this->requestStack->getCurrentRequest();

            
$url UrlGeneratorInterface::ABSOLUTE_URL === $referenceType $request->getUriForPath($logoutPath) : $request->getBasePath().$logoutPath;

            if (!empty(
$parameters)) {
                
$url .= '?'.http_build_query($parameters);
            }
        } else {
            if (!
$this->router) {
                throw new 
LogicException('Unable to generate the logout URL without a Router.');
            }

            
$url $this->router->generate($logoutPath$parameters$referenceType);
        }

        return 
$url;
    }
}
Онлайн: 2
Реклама