winter/modules/cms/twig/Loader.php

63 lines
1.3 KiB
PHP
Raw Normal View History

2014-05-14 23:24:20 +10:00
<?php namespace Cms\Twig;
use Event;
2014-05-14 23:24:20 +10:00
use Twig_LoaderInterface;
use Cms\Contracts\CmsObject;
2014-05-14 23:24:20 +10:00
/**
* This class implements a Twig template loader for the CMS.
*
* @package october\cms
* @author Alexey Bobkov, Samuel Georges
*/
class Loader implements Twig_LoaderInterface
{
/**
* @var \Cms\Classes\CmsCompoundObject A CMS object to load the template from.
*/
protected $obj;
/**
* Sets a CMS object to load the template from.
* @param \Cms\Contracts\CmsObject $obj Specifies the CMS object.
2014-05-14 23:24:20 +10:00
*/
public function setObject(CmsObject $obj)
{
$this->obj = $obj;
}
/**
* Returns the Twig content string.
* This step is cached internally by Twig.
*/
2014-05-14 23:24:20 +10:00
public function getSource($name)
{
$content = $this->obj->getTwigContent();
/*
* Extensibility
*/
$dataHolder = (object) ['content' => $content];
Event::fire('cms.template.processTwigContent', [$this->obj, $dataHolder]);
return $dataHolder->content;
2014-05-14 23:24:20 +10:00
}
/**
* Returns the Twig cache key.
*/
2014-05-14 23:24:20 +10:00
public function getCacheKey($name)
{
return $this->obj->getTwigCacheKey();
2014-05-14 23:24:20 +10:00
}
/**
* Determines if the content is fresh.
*/
2014-05-14 23:24:20 +10:00
public function isFresh($name, $time)
{
2016-01-02 13:41:57 +11:00
return $this->obj->mtime <= $time;
2014-05-14 23:24:20 +10:00
}
2014-10-11 01:42:04 +02:00
}