<?php /** * Рутовый класс для любого действия. * Описывает основной функционал для работы с классами действий. * * @copyright * @link * @package Majestic * @subpackage Action * @since * @version SVN: $Id$ * @filesource $URL$ */ abstract class Action { public $template; //шаблон действия public $template_dir = '.'; //путь к шаблону действия public $class; //имя дочернего класса protected $templater; //шаблонизатор public function __construct() { $this->class = get_class($this); $this->template = substr($this->class, 0, -strlen(ACTION_POSTFIX)); if (CACHE_ENABLE && ($cache_name = $this->getCacheKey()) !== false) { $cache = new Cache($this->class.'_'.$cache_name, $this->getCacheTime()); if ($cache->isCached()) { $this->restore($cache->load()); } else { $this->init(); $cache->save($this->store()); } } else { $this->init(); } } /** * Выдает результат действия. * * @return string */ public function display() { $this->templater = Load::templater(); $this->prepare(); $this->templater->setPath(ACTION_TPL_PATH.'/'.$this->template_dir); return $this->templater->fetch($this->template.'.tpl'); } /** * Инициализация данных действия. * Тут должна быть ВСЯ работа с установкой данных, * дабы потом они нормально закешировались. * Этот метод НЕ исполняется при срабатывании кеша. * */ abstract protected function init(); /** * Подготовка данных для шаблона. * Этот метод выполняется ВСЕГДА */ protected function prepare() {} /** * Возвращает имя файла для кеширования * Переопределяется в доченрих классах. * * @return false/string - имя файла кеша либо false если кеш запрещен */ protected function getCacheKey() { return false; } /** * Возвращает время жизни кеша в секундах * При отрицательном значении кеш вечен. * Переопределяется в доченрих классах. * * @return false/integer - время жизни кеша либо false если кеш запрещен */ protected function getCacheTime() { return 0; } /** * Выдает строку для кеширования. */ protected function store() { return serialize(get_object_vars($this)); } /** * Разбирает строку кеша, созданную методом store */ protected function restore($data) { foreach(unserialize($data) as $key => $val) { $this->$key = $val; } } } ?>