Your IP : 216.73.217.13


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

<?php

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

namespace TYPO3Fluid\Fluid\Core\Cache;

/**
 * Class SimpleFileCache
 *
 * The most basic form of cache for Fluid
 * templates: storing the compiled PHP code
 * as a file that can be included via the
 * get() method.
 */
class SimpleFileCache implements FluidCacheInterface
{
    /**
     * Default cache directory is in "cache/"
     * relative to the point of script execution.
     */
    public const DIRECTORY_DEFAULT = 'cache';

    /**
     * @var string
     */
    protected $directory = self::DIRECTORY_DEFAULT;

    /**
     * @param string $directory
     */
    public function __construct($directory = self::DIRECTORY_DEFAULT)
    {
        $this->directory = rtrim($directory, '/') . '/';
    }

    /**
     * Get an instance of FluidCacheWarmerInterface which
     * can warm up template files that would normally be
     * cached on-the-fly to this FluidCacheInterface
     * implementaion.
     *
     * @return FluidCacheWarmerInterface
     */
    public function getCacheWarmer()
    {
        return new StandardCacheWarmer();
    }

    /**
     * Gets an entry from the cache or NULL if the
     * entry does not exist. Returns TRUE if the cached
     * class file was included, FALSE if it does not
     * exist in the cache directory.
     *
     * @param string $name
     * @return bool
     */
    public function get($name)
    {
        if (class_exists($name)) {
            return true;
        }
        $file = $this->getCachedFilePathAndFilename($name);
        if (file_exists($file)) {
            include_once $file;
            return true;
        }
        return false;
    }

    /**
     * Set or updates an entry identified by $name
     * into the cache.
     *
     * @param string $name
     * @param mixed $value
     * @throws \RuntimeException
     */
    public function set($name, $value)
    {
        if (!file_exists(rtrim($this->directory, '/'))) {
            throw new \RuntimeException(sprintf('Invalid Fluid cache directory - %s does not exist!', $this->directory));
        }
        file_put_contents($this->getCachedFilePathAndFilename($name), $value);
    }

    /**
     * Flushes the cache either by entry or flushes
     * the entire cache if no entry is provided.
     *
     * @param string|null $name
     */
    public function flush($name = null)
    {
        if ($name !== null) {
            $this->flushByName($name);
        } else {
            $files = $this->getCachedFilenames();
            if (is_array($files)) {
                array_walk($files, [$this, 'flushByFilename']);
            }
        }
    }

    /**
     * @return array
     */
    protected function getCachedFilenames()
    {
        return glob($this->directory . '*.php');
    }

    /**
     * @param string $name
     */
    protected function flushByName($name)
    {
        $this->flushByFilename($this->getCachedFilePathAndFilename($name));
    }

    /**
     * @param string $filename
     */
    protected function flushByFilename($filename)
    {
        unlink($filename);
    }

    /**
     * @param string $identifier
     * @return string
     */
    protected function getCachedFilePathAndFilename($identifier)
    {
        return $this->directory . $identifier . '.php';
    }
}