Your IP : 216.73.216.220


Current Path : /var/www/surf/TYPO3/vendor/typo3fluid/fluid/src/ViewHelpers/Cache/
Upload File :
Current File : /var/www/surf/TYPO3/vendor/typo3fluid/fluid/src/ViewHelpers/Cache/WarmupViewHelper.php

<?php

/*
 * This file belongs to the package "TYPO3 Fluid".
 * See LICENSE.txt that was shipped with this package.
 */

namespace TYPO3Fluid\Fluid\ViewHelpers\Cache;

use TYPO3Fluid\Fluid\Core\Compiler\TemplateCompiler;
use TYPO3Fluid\Fluid\Core\Rendering\RenderingContextInterface;
use TYPO3Fluid\Fluid\Core\Variables\ChainedVariableProvider;
use TYPO3Fluid\Fluid\Core\Variables\StandardVariableProvider;
use TYPO3Fluid\Fluid\Core\Variables\VariableProviderInterface;
use TYPO3Fluid\Fluid\Core\ViewHelper\AbstractViewHelper;

/**
 * ViewHelper to insert variables which only apply during
 * cache warmup and only apply if no other variables are
 * specified for the warmup process.
 *
 * If a chunk of template code is impossible to compile
 * without additional variables, for example when rendering
 * sections or partials using dynamic names, you can use this
 * ViewHelper around that chunk and specify a set of variables
 * which will be assigned only while compiling the template
 * and only when this is done as part of cache warmup. The
 * template chunk can then be compiled using those default
 * variables.
 *
 * This does not imply that only those variable values will
 * be used by the compiled template. It only means that
 * DEFAULT values of vital variables will be present during
 * compiling.
 *
 * If you find yourself completely unable to properly warm up
 * a specific template file even with use of this ViewHelper,
 * then you can consider using
 * ``f:cache.disable`` ViewHelper
 * to prevent the template compiler from even attempting to
 * compile it.
 *
 * USE WITH CARE! SOME EDGE CASES OF FOR EXAMPLE VIEWHELPERS
 * WHICH REQUIRE SPECIAL VARIABLE TYPES MAY NOT BE SUPPORTED
 * HERE DUE TO THE RUDIMENTARY NATURE OF VARIABLES YOU DEFINE.
 *
 * Examples
 * ========
 *
 * Usage and effect
 * ----------------
 *
 * ::
 *
 *     <f:cache.warmup variables="{foo: bar}">
 *        Template code depending on {foo} variable which is not
 *        assigned when warming up Fluid's caches. {foo} is only
 *        assigned if the variable does not already exist and the
 *        assignment only happens if Fluid is in warmup mode.
 *     </f:cache.warmup>
 *
 * @api
 */
class WarmupViewHelper extends AbstractViewHelper
{
    /**
     * @var bool
     */
    protected $escapeChildren = false;

    /**
     * @var bool
     */
    protected $escapeOutput = false;

    public function initializeArguments()
    {
        $this->registerArgument(
            'variables',
            'array',
            'Array of variables to assign ONLY when compiling. See main class documentation.',
            false,
            []
        );
    }

    /**
     * Render this ViewHelper
     *
     * Makes a decision based on whether or not warmup mode is
     * currently active - if it is NOT ACTIVE the ViewHelper
     * returns the result of `renderChildren` without any further
     * operations. If ACTIVE the ViewHelper will assign/overlay
     * replacement variables, call `renderChildren`, restore the
     * original variable provider and finally return the content.
     *
     * @return string
     */
    public function render()
    {
        if (!$this->renderingContext->getTemplateCompiler()->isWarmupMode()) {
            return $this->renderChildren();
        }
        $originalVariableProvider = static::overlayVariablesIfNotSet(
            $this->renderingContext,
            $this->arguments['variables']
        );
        $content = $this->renderChildren();
        $this->renderingContext->setVariableProvider($originalVariableProvider);
        return $content;
    }

    /**
     * Custom implementation of convert. Performs variable
     * provider overlaying, calls renderChildren and uses this as output.
     *
     * TemplateCompiler then inserts this string as a static string in
     * the compiled template.
     */
    final public function convert(TemplateCompiler $templateCompiler): array
    {
        $originalVariableProvider = static::overlayVariablesIfNotSet($this->renderingContext, $this->arguments);
        $renderedChildren = $this->renderChildren();
        $this->renderingContext->setVariableProvider($originalVariableProvider);
        return [
            'initialization' => '// Rendering ViewHelper ' . $this->viewHelperNode->getViewHelperClassName() . chr(10),
            'execution' => '\'' . str_replace("'", "\'", $renderedChildren) . '\'',
        ];
    }

    /**
     * Overlay variables by replacing the VariableProvider with a
     * ChainedVariableProvider using dual data sources. Returns the
     * original VariableProvider which must replace the temporary
     * one again once the rendering/compiling is done.
     *
     * @param RenderingContextInterface $renderingContext
     * @param array $variables
     * @return VariableProviderInterface
     */
    protected static function overlayVariablesIfNotSet(RenderingContextInterface $renderingContext, array $variables)
    {
        $currentProvider = $renderingContext->getVariableProvider();
        $chainedVariableProvider = new ChainedVariableProvider([
            $currentProvider,
            new StandardVariableProvider($variables)
        ]);
        $renderingContext->setVariableProvider($chainedVariableProvider);
        return $currentProvider;
    }
}