[TASK] Update Fluid dependency to 2.0
[Packages/TYPO3.CMS.git] / typo3 / sysext / fluid / Classes / Core / Cache / FluidTemplateCache.php
1 <?php
2 namespace TYPO3\CMS\Fluid\Core\Cache;
3
4 /*
5 * This file is part of the TYPO3 CMS project.
6 *
7 * It is free software; you can redistribute it and/or modify it under
8 * the terms of the GNU General Public License, either version 2
9 * of the License, or any later version.
10 *
11 * For the full copyright and license information, please read the
12 * LICENSE.txt file that was distributed with this source code.
13 *
14 * The TYPO3 project - inspiring people to share!
15 */
16
17 use TYPO3\CMS\Core\Cache\Exception\InvalidDataException;
18 use TYPO3\CMS\Core\Cache\Frontend\PhpFrontend;
19 use TYPO3Fluid\Fluid\Core\Cache\FluidCacheInterface;
20 use TYPO3Fluid\Fluid\Core\Cache\FluidCacheWarmerInterface;
21 use TYPO3Fluid\Fluid\Core\Cache\StandardCacheWarmer;
22
23 /**
24 * Class FluidTemplateCache
25 *
26 * Connector class that enables the TYPO3 cache called "fluid_template" to be operated with the
27 * interface appropriate for the Fluid engine.
28 */
29 class FluidTemplateCache extends PhpFrontend implements FluidCacheInterface
30 {
31 /**
32 * @param null $name
33 * @return void
34 */
35 public function flush($name = null)
36 {
37 parent::flush();
38 }
39
40 /**
41 * @param string $entryIdentifier
42 * @return mixed
43 */
44 public function get($entryIdentifier)
45 {
46 return $this->requireOnce($entryIdentifier);
47 }
48
49 /**
50 * @param string $entryIdentifier
51 * @param string $sourceCode
52 * @param array $tags
53 * @param int $lifetime
54 * @throws InvalidDataException
55 */
56 public function set($entryIdentifier, $sourceCode, array $tags = [], $lifetime = null)
57 {
58 if (strpos($sourceCode, '<?php') === 0) {
59 // Remove opening PHP tag; it is added by the cache backend to which
60 // we delegate and would be duplicated if not removed.
61 $sourceCode = substr($sourceCode, 6);
62 }
63 parent::set($entryIdentifier, $sourceCode, $tags, time() + 86400);
64 }
65
66 /**
67 * @return FluidCacheWarmerInterface
68 */
69 public function getCacheWarmer()
70 {
71 return new StandardCacheWarmer();
72 }
73 }