mirror of
https://github.com/e107inc/e107.git
synced 2025-01-18 05:09:05 +01:00
20882920a0
* `strftime()` has been replaced with a polyfill based on `DateTime`. * Explicit type casts/assertions added where required by PHP 8.1 * `filter_var(…, FILTER_SANITIZE_STRING)` replaced with `strip_tags()` or HTML entity encoding of quotation marks, depending on a guess of what the intended "sanitization" was * `http_build_query()` usage type mismatches fixed * Removed usages of the `FILE_TEXT` constant * To avoid breaking PHP 5.6 compatibility (function return types), `e_session_db` no longer implements `SessionHandlerInterface`. Instead, the alternative non-OOP invocation of `session_set_save_handler()` is used instead to apply the session handler. * The shim for `strptime()` still calls the native function if available but now suppresses the deprecation warning. * `e_db_pdo` explicitly asks for `PDO::ATTR_STRINGIFY_FETCHES` to maintain consistent behavior with past versions of PHP. * `e_db_mysql` explicitly sets `mysqli_report(MYSQLI_REPORT_OFF)` to maintain consistent behavior with past versions of PHP. * Removed pointless random number generator seed from `banner` plugin * Workaround for `COUNT(*)` SQL query in `validatorClass::dbValidateArray()` without a proper API for avoiding SQL injection
367 lines
9.0 KiB
PHP
367 lines
9.0 KiB
PHP
<?php
|
|
/*
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2013 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
*/
|
|
|
|
if (!defined('e107_INIT')) { exit; }
|
|
|
|
class page_shortcodes extends e_shortcode
|
|
{
|
|
protected $request;
|
|
|
|
function __construct()
|
|
{
|
|
|
|
|
|
$this->request = e107::getRegistry('core/page/request');
|
|
|
|
$action = varset($this->request['action']);
|
|
|
|
if(($action == 'listPages' || $action == 'listChapters') && vartrue($this->request['id']))
|
|
{
|
|
$this->var = e107::getDb()->retrieve('page_chapters','chapter_id, chapter_name, chapter_meta_description, chapter_sef','chapter_id = '.intval($this->request['id']).' LIMIT 1');
|
|
}
|
|
|
|
if($action == 'showPage' && vartrue($this->request['id'])) // get chapter and description from current.
|
|
{
|
|
$query = "SELECT p.page_id,c.chapter_name,c.chapter_meta_description FROM #page AS p LEFT JOIN #page_chapters AS c ON p.page_chapter = c.chapter_id WHERE p.page_id = ".intval($this->request['id'])." LIMIT 1 ";
|
|
$rows = e107::getDb()->retrieve($query,true);
|
|
$this->var = $rows[0];
|
|
}
|
|
|
|
|
|
}
|
|
|
|
/**
|
|
* Page Navigation
|
|
* @example {PAGE_NAVIGATION: template=navdoc&auto=1} in your Theme template.
|
|
* @example {PAGE_NAVIGATION: chapter=4}
|
|
* @example {PAGE_NAVIGATION: book=3&pages=true}
|
|
*/
|
|
function sc_page_navigation($parm=null) // TODO when No $parm provided, auto-detect based on URL which book/chapters to display.
|
|
{
|
|
// $parm = eHelper::scParams($parm);
|
|
|
|
$tmpl = e107::getCoreTemplate('chapter', vartrue($parm['template'],'nav'), true, true); // always merge
|
|
|
|
$template = $tmpl['showPage'];
|
|
|
|
$request = $this->request;
|
|
|
|
if($request && is_array($request))
|
|
{
|
|
switch ($request['action'])
|
|
{
|
|
case 'listBooks':
|
|
$parm['cbook'] = 'all';
|
|
$template = $tmpl['listBooks'];
|
|
if(e107::getPref('listBooks',false) == false) // List Books has been disabled.
|
|
{
|
|
return false;
|
|
}
|
|
break;
|
|
|
|
case 'listChapters':
|
|
$parm['cbook'] = $request['id'];
|
|
$template = $tmpl['listChapters'];
|
|
break;
|
|
|
|
case 'listPages':
|
|
$parm['cchapter'] = $request['id'];
|
|
$template = $tmpl['listPages'];
|
|
|
|
break;
|
|
|
|
case 'showPage':
|
|
$parm['cpage'] = $request['id'];
|
|
break;
|
|
}
|
|
}
|
|
|
|
if($parm)
|
|
{
|
|
$parm = http_build_query($parm);
|
|
}
|
|
else
|
|
{
|
|
$parm = '';
|
|
}
|
|
|
|
/** @var page_sitelink $links */
|
|
$links = e107::getAddon('page', 'e_sitelink');
|
|
|
|
$data = $links->pageNav($parm);
|
|
|
|
if(isset($data['title']) && !vartrue($template['noAutoTitle']))
|
|
{
|
|
// use chapter title
|
|
$template['caption'] = $data['title'];
|
|
$data = $data['body'];
|
|
}
|
|
|
|
if(empty($data)){ return null; }
|
|
|
|
return e107::getNav()->render($data, $template) ;
|
|
|
|
}
|
|
|
|
|
|
function sc_page_chapter_name($parm='')
|
|
{
|
|
return e107::getParser()->toHTML($this->var['chapter_name']);
|
|
}
|
|
|
|
|
|
function sc_page_chapter_description($parm='')
|
|
{
|
|
return e107::getParser()->toHTML($this->var['chapter_meta_description'],true);
|
|
}
|
|
|
|
/**
|
|
* New in v2.x. eg. {CMENU=feature-1} Renders a menu called 'feature-1' as found in the e107_page table See admin Pages/Menus .
|
|
*/
|
|
function sc_cmenu($parm=null)
|
|
{
|
|
if(empty($parm))
|
|
{
|
|
return null;
|
|
}
|
|
|
|
return e107::getMenu()->renderMenu($parm, false, false, true);
|
|
}
|
|
|
|
|
|
/**
|
|
* Render All visible Menus from a specific chapter.
|
|
* @param null $parm
|
|
* @example {CHAPTER_MENUS: name=chapter-sef-url}
|
|
* @example {CHAPTER_MENUS: name=chapter-sef-url&template=xxxxx}
|
|
* @return string
|
|
*/
|
|
function sc_chapter_menus($parm=null)
|
|
{
|
|
if(empty($parm['name']))
|
|
{
|
|
if(ADMIN)
|
|
{
|
|
return "<div class='alert alert-danger'>Missing 'name'. eg: {CHAPTER_MENUS: name=chapter-sef-url}</div>";
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
$tp = e107::getParser();
|
|
|
|
$text = '';
|
|
$start = '';
|
|
$classCount = 0;
|
|
|
|
$sef = $tp->filter($parm['name'],'str');
|
|
|
|
$registry = 'e_shortcode/sc_chapter_menus/'.$sef;
|
|
|
|
if(!$pageArray = e107::getRegistry($registry))
|
|
{
|
|
$query = "SELECT * FROM #page AS p LEFT JOIN #page_chapters as ch ON p.page_chapter=ch.chapter_id WHERE ch.chapter_visibility IN (" . USERCLASS_LIST . ") AND p.menu_class IN (" . USERCLASS_LIST . ") AND ch.chapter_sef = '" . $sef . "' ORDER BY p.page_order ASC ";
|
|
|
|
e107::getDebug()->log("Loading Page Chapters (".$sef.")");
|
|
|
|
if(!$pageArray = e107::getDb()->retrieve($query, true))
|
|
{
|
|
e107::getDebug()->log('{CHAPTER_MENUS: name='.$parm['name'].'} failed.<br />Query: '.$query);
|
|
return null;
|
|
}
|
|
|
|
e107::setRegistry($registry, $pageArray);
|
|
}
|
|
|
|
$template = e107::getCoreTemplate('menu',null,true,true);
|
|
|
|
$sc = e107::getScBatch('page', null, 'cpage');
|
|
$editable = array(
|
|
'table' => 'page',
|
|
'pid' => 'page_id',
|
|
'perms' => '5',
|
|
'shortcodes' => array(
|
|
'cpagetitle' => array('field'=>'page_subtitle','type'=>'text', 'container'=>'span'),
|
|
'cpagebody' => array('field'=>'page_text','type'=>'html', 'container'=>'div'),
|
|
'cmenubody' => array('field'=>'menu_text','type'=>'html', 'container'=>'div'),
|
|
|
|
)
|
|
);
|
|
|
|
$sc->setVars($pageArray[0]);
|
|
$sc->editable($editable);
|
|
|
|
$tpl = varset($pageArray[0]['menu_template'],'default'); // use start template from first row.
|
|
|
|
if(!empty($parm['template']))
|
|
{
|
|
e107::getDebug()->log('{CHAPTER_MENUS CUSTOM TEMPLATE}');
|
|
$tpl = $parm['template'];
|
|
$start .= "<!-- CHAPTER_MENUS Start Template: ". $tpl." -->";
|
|
|
|
if(empty($template[$tpl]))
|
|
{
|
|
e107::getDebug()->log('{CHAPTER_MENUS: '.http_build_query($parm).'} has an empty template.');
|
|
}
|
|
|
|
}
|
|
|
|
if(!empty($parm['class']) && is_array($parm['class']))
|
|
{
|
|
$classArray = $parm['class'];
|
|
$classCount = count($parm['class']);
|
|
}
|
|
|
|
|
|
$active = varset($parm['active'],1);
|
|
|
|
$start .= $tp->parseTemplate($template[$tpl]['start'],true,$sc);
|
|
|
|
$c=1;
|
|
$i = 0;
|
|
foreach($pageArray as $row)
|
|
{
|
|
if(!empty($parm['limit']) && $c > $parm['limit'])
|
|
{
|
|
break;
|
|
}
|
|
|
|
|
|
$row['cmenu_tab_active'] = ($c === (int) $active) ? true : false;
|
|
|
|
if(empty($parm['template']))
|
|
{
|
|
$tpl = varset($row['menu_template'],'default');
|
|
}
|
|
|
|
$itemTemplate = $template[$tpl]['body'];
|
|
|
|
$sc->setVars($row);
|
|
|
|
if(!empty($classArray))
|
|
{
|
|
$itemTemplate = str_replace('{CLASS}',$classArray[$i],$itemTemplate);
|
|
|
|
$i++;
|
|
if($classCount === $i)
|
|
{
|
|
$i = 0;
|
|
}
|
|
}
|
|
|
|
$text .= $tp->parseTemplate($itemTemplate,true,$sc);
|
|
$c++;
|
|
}
|
|
|
|
$end = $tp->parseTemplate($template[$tpl]['end'],true,$sc);
|
|
|
|
$end .= "<!-- ".http_build_query($parm)." -->";
|
|
|
|
if(!empty($parm['template']))
|
|
{
|
|
$end .= "<!-- CHAPTER_MENUS end template: ". $parm['template']." -->";
|
|
}
|
|
|
|
if(!empty($text))
|
|
{
|
|
return $start . $text . $end;
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
* Render All visible Chapters from a specific Book.
|
|
* Uses "listChapter" template key. ie. $CHAPTER_TEMPLATE[---TEMPLATE --]['listChapters']
|
|
* @param null $parm
|
|
* @example {BOOK_CHAPTERS: name=book-sef-url}
|
|
* @example {BOOK_CHAPTERS: name=book-sef-url&template=xxxxx&limit=3}
|
|
* @return string
|
|
*/
|
|
function sc_book_chapters($parm=null)
|
|
{
|
|
if(empty($parm['name']))
|
|
{
|
|
if(ADMIN)
|
|
{
|
|
return "<div class='alert alert-danger'>Missing 'name'. eg: {BOOK_CHAPTER: name=book-sef-url}</div>";
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
$tp = e107::getParser();
|
|
|
|
$sef = $tp->filter($parm['name'],'str');
|
|
|
|
$tmplKey = varset($parm['template'],'panel');
|
|
$limit = (int) varset($parm['limit'], 3);
|
|
|
|
$registry = 'e_shortcode/sc_book_chapters/'.$sef. '/'.$limit;
|
|
|
|
if(!$chapArray = e107::getRegistry($registry))
|
|
{
|
|
$bookID = e107::getDb()->retrieve('page_chapters', 'chapter_id', "chapter_sef = '" . $sef . "' LIMIT 1");
|
|
|
|
if(empty($bookID))
|
|
{
|
|
return null;
|
|
}
|
|
|
|
$query = "SELECT * FROM #page_chapters WHERE chapter_visibility IN (" . USERCLASS_LIST . ") AND chapter_parent = ".$bookID." ORDER BY chapter_order ASC LIMIT ".$limit;
|
|
|
|
e107::getDebug()->log("Loading sc_book_chapters(".$sef.")");
|
|
|
|
if(!$chapArray = e107::getDb()->retrieve($query, true))
|
|
{
|
|
e107::getDebug()->log('{BOOK_CHAPTERS: name='.$parm['name'].'} failed.<br />Query: '.$query);
|
|
return null;
|
|
}
|
|
|
|
e107::setRegistry($registry, $chapArray);
|
|
}
|
|
|
|
|
|
|
|
$temp = e107::getCoreTemplate('chapter',$tmplKey,true,true);
|
|
$template = $temp['listChapters'];
|
|
|
|
$sc = e107::getScBatch('page', null, 'cpage');
|
|
|
|
$start = "<!-- sc_book_chapters Start Template: ". $tmplKey." -->";
|
|
$start .= $tp->parseTemplate($template['start'],true,$sc);
|
|
|
|
$text = '';
|
|
|
|
foreach($chapArray as $row)
|
|
{
|
|
$sc->setVars($row);
|
|
$sc->setChapter($row['chapter_id']);
|
|
$text .= $tp->parseTemplate($template['item'],true,$sc);
|
|
}
|
|
|
|
$end = $tp->parseTemplate($template['end'],true,$sc);
|
|
$end .= "<!-- sc_book_chapters end template: ". $tmplKey." -->";
|
|
|
|
if(!empty($text))
|
|
{
|
|
return $start . $text . $end;
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|