194 lines
4.4 KiB
PHP
194 lines
4.4 KiB
PHP
<?php defined('BLUDIT') or die('Bludit CMS.');
|
|
|
|
// ============================================================================
|
|
// Variables
|
|
// ============================================================================
|
|
|
|
// Array with all pages.
|
|
$pages = array();
|
|
|
|
// Array with all pages, order by parent.
|
|
$pagesParents = array(NO_PARENT_CHAR=>array());
|
|
|
|
// ============================================================================
|
|
// Functions
|
|
// ============================================================================
|
|
|
|
function sortPages($a, $b)
|
|
{
|
|
if ($a->position() == $b->position()) {
|
|
return 0;
|
|
}
|
|
|
|
return ($a->position() < $b->position()) ? -1 : 1;
|
|
}
|
|
|
|
function build_page($key)
|
|
{
|
|
global $dbPages;
|
|
global $dbUsers;
|
|
global $Parsedown;
|
|
global $Site;
|
|
|
|
// Page object, content from FILE.
|
|
$Page = new Page($key);
|
|
if( !$Page->isValid() ) {
|
|
Log::set(__METHOD__.LOG_SEP.'Error occurred when trying build the page from file with key: '.$key);
|
|
return false;
|
|
}
|
|
|
|
// Page database, content from DATABASE JSON.
|
|
$db = $dbPages->getDb($key);
|
|
if( !$db ) {
|
|
Log::set(__METHOD__.LOG_SEP.'Error occurred when trying build the page from database with key: '.$key);
|
|
return false;
|
|
}
|
|
|
|
// Foreach field from DATABASE.
|
|
foreach($db as $field=>$value) {
|
|
$Page->setField($field, $value);
|
|
}
|
|
|
|
// Content in raw format
|
|
$contentRaw = $Page->content();
|
|
$Page->setField('contentRaw', $Page->content(), true);
|
|
|
|
// Parse markdown content.
|
|
$content = Text::pre2htmlentities($contentRaw); // Parse pre code with htmlentities
|
|
$content = $Parsedown->text($content); // Parse Markdown.
|
|
$content = Text::imgRel2Abs($content, HTML_PATH_UPLOADS); // Parse img src relative to absolute.
|
|
$Page->setField('content', $content, true);
|
|
|
|
// Date format
|
|
$pageDate = $Page->date();
|
|
$Page->setField('dateRaw', $pageDate, true);
|
|
|
|
$pageDateFormated = $Page->dateRaw( $Site->dateFormat() );
|
|
$Page->setField('date', $pageDateFormated, true);
|
|
|
|
// Parse username for the page.
|
|
if( $dbUsers->userExists( $Page->username() ) )
|
|
{
|
|
$User = new User();
|
|
$userDatabase = $dbUsers->getDb( $Page->username() );
|
|
|
|
foreach($userDatabase as $key=>$value) {
|
|
$User->setField($key, $value);
|
|
}
|
|
|
|
// Save the User object inside the Page object
|
|
$Page->setField('user', $User);
|
|
}
|
|
|
|
return $Page;
|
|
}
|
|
|
|
function build_all_pages()
|
|
{
|
|
global $pages;
|
|
global $pagesParents;
|
|
global $dbPages;
|
|
|
|
$list = $dbPages->getAll();
|
|
|
|
unset($list['error']);
|
|
|
|
foreach($list as $key=>$db)
|
|
{
|
|
$Page = build_page($key);
|
|
|
|
if($Page!==false)
|
|
{
|
|
// --- Order pages by parents ---
|
|
|
|
// Generate all posible parents.
|
|
if( $Page->parentKey()===false )
|
|
{
|
|
// Add the parent key in the dbPages
|
|
$dbPages->addParentKey($Page->key());
|
|
|
|
$pagesParents[NO_PARENT_CHAR][$Page->key()] = $Page;
|
|
}
|
|
else
|
|
{
|
|
$pagesParents[$Page->parentKey()][$Page->key()] = $Page;
|
|
}
|
|
|
|
// --- All pages in 1 array ---
|
|
$pages[$Page->key()] = $Page;
|
|
}
|
|
}
|
|
|
|
// --- SORT PAGES ---
|
|
|
|
// Sort parents.
|
|
$parents = $pagesParents[NO_PARENT_CHAR];
|
|
uasort($parents, 'sortPages');
|
|
|
|
// Sort children.
|
|
unset($pagesParents[NO_PARENT_CHAR]);
|
|
$children = $pagesParents;
|
|
$tmpPageWithParent = array();
|
|
foreach($children as $parentKey=>$childrenPages)
|
|
{
|
|
// If the child doesn't have a valid parent, then doesn't included them.
|
|
if(isset($pages[$parentKey]))
|
|
{
|
|
$tmpPageWithParent[$parentKey] = $childrenPages;
|
|
uasort($tmpPageWithParent[$parentKey], 'sortPages');
|
|
}
|
|
}
|
|
|
|
$pagesParents = array(NO_PARENT_CHAR=>$parents) + $tmpPageWithParent;
|
|
}
|
|
|
|
// ============================================================================
|
|
// Main
|
|
// ============================================================================
|
|
|
|
// Search for changes on pages by the user.
|
|
if( $Site->cliMode() ) {
|
|
$dbPages->regenerateCli();
|
|
}
|
|
|
|
// Filter by page, then build it
|
|
if( ($Url->whereAmI()==='page') && ($Url->notFound()===false) )
|
|
{
|
|
$Page = build_page( $Url->slug() );
|
|
|
|
if($Page===false)
|
|
{
|
|
$Url->setNotFound(true);
|
|
unset($Page);
|
|
}
|
|
elseif( !$Page->published() )
|
|
{
|
|
$Url->setNotFound(true);
|
|
unset($Page);
|
|
}
|
|
}
|
|
|
|
// Default homepage
|
|
if($Url->notFound()===false)
|
|
{
|
|
if( Text::isNotEmpty($Site->homepage()) && ($Url->whereAmI()==='home') )
|
|
{
|
|
$Url->setWhereAmI('page');
|
|
|
|
$Page = build_page( $Site->homepage() );
|
|
|
|
if($Page===false) {
|
|
$Url->setWhereAmI('home');
|
|
}
|
|
}
|
|
}
|
|
|
|
if($Url->notFound())
|
|
{
|
|
$Url->setWhereAmI('page');
|
|
$Page = new Page('error');
|
|
}
|
|
|
|
// Build all pages
|
|
build_all_pages();
|