2015-05-05 03:00:01 +02:00
|
|
|
<?php defined('BLUDIT') or die('Bludit CMS.');
|
2015-03-08 18:02:59 +01:00
|
|
|
|
2017-05-09 22:57:56 +02:00
|
|
|
class Page {
|
|
|
|
|
|
|
|
private $vars;
|
2016-01-12 03:18:20 +01:00
|
|
|
|
2015-05-05 03:00:01 +02:00
|
|
|
function __construct($key)
|
2015-08-24 00:07:14 +02:00
|
|
|
{
|
2017-05-09 22:57:56 +02:00
|
|
|
$this->vars = false;
|
|
|
|
|
|
|
|
if( $this->build($key) ) {
|
|
|
|
$this->vars['key'] = $key;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Parse the content from the file index.txt
|
|
|
|
private function build($key)
|
|
|
|
{
|
|
|
|
$filePath = PATH_PAGES.$key.DS.FILENAME;
|
|
|
|
|
2017-06-25 22:54:59 +02:00
|
|
|
// Check if the file exists
|
2017-05-09 22:57:56 +02:00
|
|
|
if( !Sanitize::pathFile($filePath) ) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$tmp = 0;
|
|
|
|
$lines = file($filePath);
|
|
|
|
foreach($lines as $lineNumber=>$line) {
|
2017-06-25 22:54:59 +02:00
|
|
|
// Split the line in 2 parts, limiter by :
|
|
|
|
$parts = explode(':', $line, 2);
|
2017-05-09 22:57:56 +02:00
|
|
|
|
2017-06-25 22:54:59 +02:00
|
|
|
// Remove all characters except letters and dash -
|
|
|
|
$parts[0] = preg_replace('/[^A-Za-z\-]/', '', $parts[0]);
|
|
|
|
|
|
|
|
// Lowercase
|
2017-05-09 22:57:56 +02:00
|
|
|
$parts[0] = Text::lowercase($parts[0]);
|
|
|
|
|
2017-06-25 22:54:59 +02:00
|
|
|
// Check if the current line start the content of the page
|
|
|
|
// We have two breakers, the word content or 3 dash ---
|
|
|
|
if( ($parts[0]==='content') || ($parts[0]==='---') ) {
|
2017-05-09 22:57:56 +02:00
|
|
|
$tmp = $lineNumber;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( !empty($parts[0]) && !empty($parts[1]) ) {
|
2017-06-25 22:54:59 +02:00
|
|
|
$parts[1] = trim($parts[1]);
|
|
|
|
// Sanitize all fields, except the content
|
2017-05-09 22:57:56 +02:00
|
|
|
$this->vars[$parts[0]] = Sanitize::html($parts[1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process the content
|
|
|
|
if($tmp!==0) {
|
2017-06-25 22:54:59 +02:00
|
|
|
// Next line after "Content:" or "---"
|
2017-05-09 22:57:56 +02:00
|
|
|
$tmp++;
|
|
|
|
|
|
|
|
// Remove lines after Content
|
|
|
|
$output = array_slice($lines, $tmp);
|
|
|
|
|
2017-06-25 22:54:59 +02:00
|
|
|
if( !empty($parts[1]) ) {
|
2017-05-09 22:57:56 +02:00
|
|
|
array_unshift($output, "\n");
|
|
|
|
array_unshift($output, $parts[1]);
|
|
|
|
}
|
|
|
|
|
|
|
|
$implode = implode($output);
|
2017-05-10 20:40:28 +02:00
|
|
|
$this->vars['contentRaw'] = $implode;
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
2017-05-16 00:46:20 +02:00
|
|
|
|
|
|
|
return true;
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Returns TRUE if the content is loaded correctly, FALSE otherwise
|
|
|
|
public function isValid()
|
|
|
|
{
|
|
|
|
return($this->vars!==false);
|
|
|
|
}
|
|
|
|
|
2017-07-06 23:27:22 +02:00
|
|
|
// DEPRACTED
|
2017-05-09 22:57:56 +02:00
|
|
|
// Returns the value from the $field, FALSE if the field doesn't exist
|
|
|
|
public function getField($field)
|
|
|
|
{
|
|
|
|
if(isset($this->vars[$field])) {
|
|
|
|
return $this->vars[$field];
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2017-06-04 21:08:31 +02:00
|
|
|
public function getValue($field)
|
|
|
|
{
|
|
|
|
if(isset($this->vars[$field])) {
|
|
|
|
return $this->vars[$field];
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2017-07-06 23:27:22 +02:00
|
|
|
public function getDB()
|
|
|
|
{
|
|
|
|
return $this->vars;
|
|
|
|
}
|
|
|
|
|
2017-05-09 22:57:56 +02:00
|
|
|
// Set a field with a value
|
|
|
|
public function setField($field, $value, $overwrite=true)
|
|
|
|
{
|
|
|
|
if($overwrite || empty($this->vars[$field])) {
|
|
|
|
$this->vars[$field] = $value;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the content
|
|
|
|
// This content is markdown parser
|
|
|
|
// (boolean) $fullContent, TRUE returns all content, if FALSE returns the first part of the content
|
|
|
|
// (boolean) $noSanitize, TRUE returns the content without sanitized
|
|
|
|
public function content($fullContent=true, $noSanitize=true)
|
|
|
|
{
|
|
|
|
// This content is not sanitized.
|
2017-06-04 21:08:31 +02:00
|
|
|
$content = $this->getValue('content');
|
2017-05-09 22:57:56 +02:00
|
|
|
|
|
|
|
if(!$fullContent) {
|
2017-05-10 20:40:28 +02:00
|
|
|
return $this->contentBreak();
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if($noSanitize) {
|
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Sanitize::html($content);
|
|
|
|
}
|
|
|
|
|
2017-05-10 20:40:28 +02:00
|
|
|
public function contentBreak()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('contentBreak');
|
2017-05-10 20:40:28 +02:00
|
|
|
}
|
|
|
|
|
2017-05-09 22:57:56 +02:00
|
|
|
// Returns the raw content
|
|
|
|
// This content is not markdown parser
|
|
|
|
// (boolean) $noSanitize, TRUE returns the content without sanitized
|
|
|
|
public function contentRaw($noSanitize=true)
|
|
|
|
{
|
|
|
|
// This content is not sanitized.
|
2017-06-04 21:08:31 +02:00
|
|
|
$content = $this->getValue('contentRaw');
|
2017-05-09 22:57:56 +02:00
|
|
|
|
|
|
|
if($noSanitize) {
|
|
|
|
return $content;
|
|
|
|
}
|
|
|
|
|
|
|
|
return Sanitize::html($content);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the date according to locale settings and format settings
|
|
|
|
public function date()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('date');
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the date according to locale settings and format as database stored
|
|
|
|
// (string) $format, you can specify the date format
|
|
|
|
public function dateRaw($format=false)
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
$date = $this->getValue('dateRaw');
|
2017-05-09 22:57:56 +02:00
|
|
|
|
|
|
|
if($format) {
|
|
|
|
return Date::format($date, DB_DATE_FORMAT, $format);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $date;
|
|
|
|
}
|
|
|
|
|
2017-05-16 00:46:20 +02:00
|
|
|
// Returns the permalink
|
|
|
|
// (boolean) $absolute, TRUE returns the page link with the DOMAIN, FALSE without the DOMAIN
|
2017-05-30 20:28:55 +02:00
|
|
|
public function permalink($absolute=true)
|
2017-05-16 00:46:20 +02:00
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
// Get the key of the page
|
|
|
|
$key = $this->getValue('key');
|
2017-05-16 00:46:20 +02:00
|
|
|
|
|
|
|
if($absolute) {
|
2017-06-09 20:30:13 +02:00
|
|
|
return DOMAIN_PAGES.$key;
|
2017-05-16 00:46:20 +02:00
|
|
|
}
|
|
|
|
|
2017-06-04 21:08:31 +02:00
|
|
|
return HTML_PATH_ROOT.PAGE_URI_FILTER.$key;
|
2017-05-16 00:46:20 +02:00
|
|
|
}
|
|
|
|
|
2017-05-17 00:04:53 +02:00
|
|
|
// Returns the category key
|
|
|
|
public function categoryKey()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('category');
|
2017-05-17 00:04:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the field from the array
|
|
|
|
// categoryMap = array( 'name'=>'', 'list'=>array() )
|
|
|
|
public function categoryMap($field)
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
$map = $this->getValue('categoryMap');
|
2017-05-17 00:04:53 +02:00
|
|
|
|
|
|
|
if($field=='key') {
|
|
|
|
return $this->categoryKey();
|
|
|
|
}
|
|
|
|
elseif($field=='name') {
|
|
|
|
return $map['name'];
|
|
|
|
}
|
|
|
|
elseif($field=='list') {
|
|
|
|
return $map['list'];
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2017-05-09 22:57:56 +02:00
|
|
|
|
|
|
|
// Returns the user object
|
|
|
|
// (boolean) $field, TRUE returns the value of the field, FALSE returns the object
|
|
|
|
public function user($field=false)
|
|
|
|
{
|
|
|
|
// Get the user object.
|
2017-06-04 21:08:31 +02:00
|
|
|
$User = $this->getValue('user');
|
2017-05-09 22:57:56 +02:00
|
|
|
|
|
|
|
if($field) {
|
|
|
|
return $User->getField($field);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $User;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the username who created the post/page
|
|
|
|
public function username()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('username');
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the description field
|
|
|
|
public function description()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('description');
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
2015-03-08 18:02:59 +01:00
|
|
|
|
2015-06-28 01:28:22 +02:00
|
|
|
|
2017-05-09 22:57:56 +02:00
|
|
|
|
|
|
|
// Returns relative time (e.g. "1 minute ago")
|
|
|
|
// Based on http://stackoverflow.com/a/18602474
|
|
|
|
// Modified for Bludit
|
|
|
|
// $complete = false : short version
|
|
|
|
// $complete = true : full version
|
|
|
|
public function relativeTime($complete = false) {
|
|
|
|
$current = new DateTime;
|
2017-06-04 21:08:31 +02:00
|
|
|
$past = new DateTime($this->getValue('date'));
|
2017-05-09 22:57:56 +02:00
|
|
|
$elapsed = $current->diff($past);
|
|
|
|
|
|
|
|
$elapsed->w = floor($elapsed->d / 7);
|
|
|
|
$elapsed->d -= $elapsed->w * 7;
|
|
|
|
|
|
|
|
$string = array(
|
|
|
|
'y' => 'year',
|
|
|
|
'm' => 'month',
|
|
|
|
'w' => 'week',
|
|
|
|
'd' => 'day',
|
|
|
|
'h' => 'hour',
|
|
|
|
'i' => 'minute',
|
|
|
|
's' => 'second',
|
|
|
|
);
|
|
|
|
|
|
|
|
foreach($string as $key => &$value) {
|
|
|
|
if($elapsed->$key) {
|
|
|
|
$value = $elapsed->$key . ' ' . $value . ($elapsed->$key > 1 ? 's' : ' ');
|
|
|
|
} else {
|
|
|
|
unset($string[$key]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!$complete) {
|
|
|
|
$string = array_slice($string, 0 , 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $string ? implode(', ', $string) . ' ago' : 'Just now';
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the tags
|
|
|
|
// (boolean) $returnsArray, TRUE to get the tags as an array, FALSE to get the tags separeted by comma
|
|
|
|
public function tags($returnsArray=false)
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
$tags = $this->getValue('tags');
|
2017-05-09 22:57:56 +02:00
|
|
|
|
|
|
|
if($returnsArray) {
|
|
|
|
if($tags==false) {
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
return $tags;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if($tags==false) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// Return string with tags separeted by comma.
|
|
|
|
return implode(', ', $tags);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function json($returnsArray=false)
|
|
|
|
{
|
|
|
|
$tmp['key'] = $this->key();
|
|
|
|
$tmp['title'] = $this->title();
|
|
|
|
$tmp['content'] = $this->content(); // Markdown parsed
|
|
|
|
$tmp['contentRaw'] = $this->contentRaw(); // No Markdown parsed
|
|
|
|
$tmp['description'] = $this->description();
|
|
|
|
$tmp['date'] = $this->dateRaw();
|
|
|
|
$tmp['permalink'] = $this->permalink(true);
|
|
|
|
|
|
|
|
if($returnsArray) {
|
|
|
|
return $tmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
return json_encode($tmp);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the file name of the cover image, FALSE there isn't a cover image setted
|
|
|
|
// (boolean) $absolute, TRUE returns the absolute path and file name, FALSE just the file name
|
|
|
|
public function coverImage($absolute=true)
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
$fileName = $this->getValue('coverImage');
|
2017-05-09 22:57:56 +02:00
|
|
|
if(empty($fileName)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if($absolute) {
|
2017-05-30 21:54:09 +02:00
|
|
|
return DOMAIN_UPLOADS.$fileName;
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $fileName;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Returns TRUE if the content has the text splited
|
|
|
|
public function readMore()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('readMore');
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function uuid()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('uuid');
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Returns the field key
|
|
|
|
public function key()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('key');
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
2017-06-22 23:50:12 +02:00
|
|
|
// (boolean) Returns TRUE if the page is published, FALSE otherwise
|
2017-05-09 22:57:56 +02:00
|
|
|
public function published()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return ($this->getValue('status')==='published');
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
2017-06-22 23:50:12 +02:00
|
|
|
// (boolean) Returns TRUE if the page is scheduled, FALSE otherwise
|
2017-05-09 22:57:56 +02:00
|
|
|
public function scheduled()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return ($this->getValue('status')==='scheduled');
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
2017-06-22 23:50:12 +02:00
|
|
|
// (boolean) Returns TRUE if the page is draft, FALSE otherwise
|
2017-05-09 22:57:56 +02:00
|
|
|
public function draft()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return ($this->getValue('status')=='draft');
|
2017-05-09 22:57:56 +02:00
|
|
|
}
|
|
|
|
|
2017-06-22 23:50:12 +02:00
|
|
|
// (boolean) Returns TRUE if the page is sticky, FALSE otherwise
|
2017-06-22 00:21:08 +02:00
|
|
|
public function sticky()
|
|
|
|
{
|
|
|
|
return ($this->getValue('status')=='sticky');
|
|
|
|
}
|
|
|
|
|
2017-06-22 23:50:12 +02:00
|
|
|
// (boolean) Returns TRUE if the page is fixed, FALSE otherwise
|
2017-06-22 00:21:08 +02:00
|
|
|
public function fixed()
|
|
|
|
{
|
|
|
|
return ($this->getValue('status')=='fixed');
|
|
|
|
}
|
|
|
|
|
|
|
|
// (string) Returns status of the page
|
|
|
|
public function status()
|
|
|
|
{
|
|
|
|
return $this->getValue('status');
|
|
|
|
}
|
|
|
|
|
2017-05-09 22:57:56 +02:00
|
|
|
// Returns the title field
|
|
|
|
public function title()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('title');
|
2015-05-19 01:22:05 +02:00
|
|
|
}
|
|
|
|
|
2017-05-30 20:28:55 +02:00
|
|
|
// Returns TRUE if the page has enabled the comments, FALSE otherwise
|
|
|
|
public function allowComments()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('allowComments');
|
2017-05-30 20:28:55 +02:00
|
|
|
}
|
|
|
|
|
2016-05-30 02:50:48 +02:00
|
|
|
// Returns the page position
|
2015-05-05 03:00:01 +02:00
|
|
|
public function position()
|
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
return $this->getValue('position');
|
2015-03-08 18:02:59 +01:00
|
|
|
}
|
|
|
|
|
2016-05-30 02:50:48 +02:00
|
|
|
// Returns the page slug
|
2015-05-05 03:00:01 +02:00
|
|
|
public function slug()
|
2015-03-08 18:02:59 +01:00
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
$explode = explode('/', $this->getValue('key'));
|
2015-05-05 03:00:01 +02:00
|
|
|
|
2016-01-12 03:18:20 +01:00
|
|
|
// Check if the page have a parent.
|
|
|
|
if(!empty($explode[1])) {
|
|
|
|
return $explode[1];
|
2015-06-22 02:47:07 +02:00
|
|
|
}
|
|
|
|
|
2016-01-12 03:18:20 +01:00
|
|
|
return $explode[0];
|
2015-03-08 18:02:59 +01:00
|
|
|
}
|
|
|
|
|
2016-05-30 02:50:48 +02:00
|
|
|
// Returns the parent key, if the page doesn't have a parent returns FALSE
|
2015-05-05 03:00:01 +02:00
|
|
|
public function parentKey()
|
2015-03-08 18:02:59 +01:00
|
|
|
{
|
2017-06-04 21:08:31 +02:00
|
|
|
$explode = explode('/', $this->getValue('key'));
|
2015-05-05 03:00:01 +02:00
|
|
|
if(isset($explode[1])) {
|
|
|
|
return $explode[0];
|
|
|
|
}
|
2015-03-08 18:02:59 +01:00
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-05-30 02:50:48 +02:00
|
|
|
// Returns the parent method output, if the page doesn't have a parent returns FALSE
|
2015-11-25 02:48:19 +01:00
|
|
|
public function parentMethod($method)
|
|
|
|
{
|
|
|
|
global $pages;
|
|
|
|
|
|
|
|
if( isset($pages[$this->parentKey()]) ) {
|
|
|
|
return $pages[$this->parentKey()]->{$method}();
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-05-30 05:36:13 +02:00
|
|
|
// Returns an array with all children's key
|
2015-05-05 03:00:01 +02:00
|
|
|
public function children()
|
2015-03-08 18:02:59 +01:00
|
|
|
{
|
2015-05-05 03:00:01 +02:00
|
|
|
$tmp = array();
|
2017-06-04 21:08:31 +02:00
|
|
|
$paths = Filesystem::listDirectories(PATH_PAGES.$this->getValue('key').DS);
|
2015-05-05 03:00:01 +02:00
|
|
|
foreach($paths as $path) {
|
|
|
|
array_push($tmp, basename($path));
|
|
|
|
}
|
|
|
|
|
|
|
|
return $tmp;
|
2015-03-08 18:02:59 +01:00
|
|
|
}
|
|
|
|
|
2016-01-12 03:18:20 +01:00
|
|
|
}
|