Вход Регистрация
Файл: vendor/symfony/http-kernel/Fragment/AbstractSurrogateFragmentRenderer.php
Строк: 224
<?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 SymfonyComponentHttpKernelFragment;

use 
SymfonyComponentHttpFoundationRequest;
use 
SymfonyComponentHttpFoundationResponse;
use 
SymfonyComponentHttpFoundationUriSigner;
use 
SymfonyComponentHttpKernelControllerControllerReference;
use 
SymfonyComponentHttpKernelHttpCacheSurrogateInterface;

/**
 * Implements Surrogate rendering strategy.
 *
 * @author Fabien Potencier <fabien@symfony.com>
 */
abstract class AbstractSurrogateFragmentRenderer extends RoutableFragmentRenderer
{
    private ?
SurrogateInterface $surrogate;
    private 
FragmentRendererInterface $inlineStrategy;
    private ?
UriSigner $signer;

    
/**
     * The "fallback" strategy when surrogate is not available should always be an
     * instance of InlineFragmentRenderer.
     *
     * @param FragmentRendererInterface $inlineStrategy The inline strategy to use when the surrogate is not supported
     */
    
public function __construct(?SurrogateInterface $surrogateFragmentRendererInterface $inlineStrategy, ?UriSigner $signer null)
    {
        
$this->surrogate $surrogate;
        
$this->inlineStrategy $inlineStrategy;
        
$this->signer $signer;
    }

    
/**
     * Note that if the current Request has no surrogate capability, this method
     * falls back to use the inline rendering strategy.
     *
     * Additional available options:
     *
     *  * alt: an alternative URI to render in case of an error
     *  * comment: a comment to add when returning the surrogate tag
     *  * absolute_uri: whether to generate an absolute URI or not. Default is false
     *
     * Note, that not all surrogate strategies support all options. For now
     * 'alt' and 'comment' are only supported by ESI.
     *
     * @see SymfonyComponentHttpKernelHttpCacheSurrogateInterface
     */
    
public function render(string|ControllerReference $uriRequest $request, array $options = []): Response
    
{
        if (!
$this->surrogate || !$this->surrogate->hasSurrogateCapability($request)) {
            
$request->attributes->set('_check_controller_is_allowed', -1); // @deprecated, switch to true in Symfony 7

            
if ($uri instanceof ControllerReference && $this->containsNonScalars($uri->attributes)) {
                throw new 
InvalidArgumentException('Passing non-scalar values as part of URI attributes to the ESI and SSI rendering strategies is not supported. Use a different rendering strategy or pass scalar values.');
            }

            return 
$this->inlineStrategy->render($uri$request$options);
        }

        
$absolute $options['absolute_uri'] ?? false;

        if (
$uri instanceof ControllerReference) {
            
$uri $this->generateSignedFragmentUri($uri$request$absolute);
        }

        
$alt $options['alt'] ?? null;
        if (
$alt instanceof ControllerReference) {
            
$alt $this->generateSignedFragmentUri($alt$request$absolute);
        }

        
$tag $this->surrogate->renderIncludeTag($uri$alt$options['ignore_errors'] ?? false$options['comment'] ?? '');

        return new 
Response($tag);
    }

    private function 
generateSignedFragmentUri(ControllerReference $uriRequest $requestbool $absolute): string
    
{
        return (new 
FragmentUriGenerator($this->fragmentPath$this->signer))->generate($uri$request$absolute);
    }

    private function 
containsNonScalars(array $values): bool
    
{
        foreach (
$values as $value) {
            if (
is_scalar($value) || null === $value) {
                continue;
            }

            if (!
is_array($value) || $this->containsNonScalars($value)) {
                return 
true;
            }
        }

        return 
false;
    }
}
Онлайн: 1
Реклама