X-Git-Url: http://git.polytechnique.org/?a=blobdiff_plain;f=classes%2Fplpage.php;h=26445c9ac721ac9cb0ffc1c5901b8ead563a4bb8;hb=b631d8034a2ef2f092d6b29dfdb327182ebf1f6e;hp=da24f3d1d88cfac345ed0aadc69cf7c977dfe988;hpb=04334c61ffd1e63616503bf52e90174adaa3cc86;p=platal.git diff --git a/classes/plpage.php b/classes/plpage.php index da24f3d..26445c9 100644 --- a/classes/plpage.php +++ b/classes/plpage.php @@ -1,6 +1,6 @@ caching = false; $this->config_overwrite = false; $this->use_sub_dirs = false; - $this->template_dir = $globals->spoolroot."/templates/"; - $this->compile_dir = $globals->spoolroot."/spool/templates_c/"; - array_unshift($this->plugins_dir, $globals->spoolroot."/plugins/"); - $this->config_dir = $globals->spoolroot."/configs/"; + $this->template_dir = $globals->spoolroot . '/templates/'; + $this->compile_dir = $globals->spoolroot . '/spool/templates_c/'; + array_unshift($this->plugins_dir, + $globals->spoolroot . '/core/plugins/', + $globals->spoolroot . '/plugins/'); + $this->config_dir = $globals->spoolroot . '/configs/'; $this->compile_check = !empty($globals->debug); - $this->changeTpl($tpl, $type); $this->_errors = array('errors' => array()); $this->_jsonVars = array(); $this->_failure = false; if ($globals->mode != 'rw') { - $this->trigError("En raison d'une maintenance, une partie des fonctionnalités du site sont" - . " actuellement désactivée, en particuliers aucune donnée ne sera sauvegardée"); + $this->trigError("En raison d'une maintenance, une partie des fonctionnalités du site est" + . " actuellement désactivée, en particulier aucune donnée ne sera sauvegardée"); } $this->register_prefilter('at_to_globals'); - $this->addJsLink('xorg.js'); $this->addJsLink('jquery.js'); } @@ -66,9 +68,29 @@ abstract class PlPage extends Smarty public function changeTpl($tpl, $type = SKINNED) { - $this->_tpl = $tpl; - $this->_page_type = $type; - $this->assign('xorg_tpl', $tpl); + $this->_tpl = $tpl; + $this->_page_type = $type; + $this->assign('pl_tpl', $tpl); + } + + // }}} + // {{{ function getCoreTpl() + + public static function getCoreTpl($tpl) + { + global $globals; + return $globals->spoolroot . '/core/templates/' . $tpl; + } + + // }}} + // {{{ function coreTpl() + + /** Use a template from the core. + */ + public function coreTpl($tpl, $type = SKINNED) + { + global $globals; + $this->changeTpl(self::getCoreTpl($tpl), $type); } // }}} @@ -86,18 +108,20 @@ abstract class PlPage extends Smarty protected function _run($skin) { - global $globals, $TIME_BEGIN; + global $globals, $platal, $TIME_BEGIN; - session_write_close(); + Platal::session()->close(); $this->register_prefilter('trimwhitespace'); $this->register_prefilter('form_force_encodings'); $this->register_prefilter('wiki_include'); + $this->register_prefilter('core_include'); $this->register_prefilter('if_has_perms'); - $this->assign('xorg_triggers', $this->_errors); - $this->assign('xorg_errors', $this->nb_errs()); - $this->assign('xorg_failure', $this->_failure); - $this->assign('globals', $globals); + $this->assign('pl_triggers', $this->_errors); + $this->assign('pl_errors', $this->nb_errs()); + $this->assign('pl_failure', $this->_failure); + $this->assign_by_ref('platal', $platal); + $this->assign_by_ref('globals', $globals); if (Env::has('json') && count($this->_jsonVars)) { return $this->jsonDisplay(); @@ -153,7 +177,9 @@ abstract class PlPage extends Smarty if ($globals->debug & DEBUG_BT) { PlBacktrace::clean(); $this->assign_by_ref('backtraces', PlBacktrace::$bt); - $result = str_replace('@@BACKTRACE@@', $this->fetch('skin/common.backtrace.tpl'), $result); + $result = str_replace('@@BACKTRACE@@', + $this->fetch(self::getCoreTpl('backtrace.tpl')), + $result); } else { $result = str_replace('@@BACKTRACE@@', '', $result); } @@ -222,20 +248,37 @@ abstract class PlPage extends Smarty public function kill($msg) { + // PHP is used on command line... do not run the whole page stuff. + if (php_sapi_name() == 'cli') { + echo $msg . "\n"; + exit; + } + global $platal; - $this->assign('platal', $platal); $this->trigError($msg); $this->_failure = true; $this->run(); } // }}} + // {{{ function setTitle + + public function setTitle($title) + { + global $globals; + if (isset($globals->core->sitename)) { + $title = $globals->core->sitename . ' :: ' . $title; + } + $this->assign('pl_title', $title); + } + + // }}} // {{{ function addJsLink public function addJsLink($path) { - $this->append('xorg_js', $path); + $this->append('pl_js', $path); } // }}} @@ -243,16 +286,25 @@ abstract class PlPage extends Smarty public function addCssLink($path) { - $this->append('xorg_css', $path); + $this->append('pl_css', $path); + } + + // }}} + // {{{ function addLink + + public function addLink($rel, $path) + { + $this->append('pl_link', array('rel' => $rel, 'href' => $path)); } + // }}} // {{{ function addCssInline public function addCssInline($css) { if (!empty($css)) { - $this->append('xorg_inline_css', $css); + $this->append('pl_inline_css', $css); } } @@ -261,7 +313,7 @@ abstract class PlPage extends Smarty public function setRssLink($title, $path) { - $this->assign('xorg_rss', array('title' => $title, 'href' => $path)); + $this->assign('pl_rss', array('title' => $title, 'href' => $path)); } // }}} @@ -294,7 +346,7 @@ abstract class PlPage extends Smarty function escape_xorgDB(&$item, $key) { - if (is_a($item, 'XOrgDBIterator')) { + if ($item instanceof XOrgDBIterator) { $expanded = array(); while ($a = $item->next()) { $expanded[] = $a; @@ -370,8 +422,17 @@ function trimwhitespace($source, &$smarty) function wiki_include($source, &$smarty) { + global $globals; return preg_replace('/\{include( [^}]*)? wiki=([^} ]+)(.*?)\}/ui', - '{include\1 file="../spool/wiki.d/cache_\2.tpl"\3 included=1}', + '{include\1 file="' . $globals->spoolroot . '/spool/wiki.d/cache_\2.tpl"\3 included=1}', + $source); +} + +function core_include($source, &$smarty) +{ + global $globals; + return preg_replace('/\{include( [^}]*)? core=([^} ]+)(.*?)\}/ui', + '{include\1 file="' . $globals->spoolroot . '/core/templates/\2"\3}', $source); } @@ -405,8 +466,8 @@ function _hide_email($source) { $source = str_replace("\n", '', $source); return ''; + 'Nix.decode("' . addslashes(str_rot13($source)) . '");' . "\n" . + '//]]>'; } function hide_emails($source, &$smarty)