koblog/bl-kernel/site.class.php

465 lines
9.3 KiB
PHP
Raw Normal View History

2015-05-05 03:00:01 +02:00
<?php defined('BLUDIT') or die('Bludit CMS.');
2023-07-15 15:58:33 +02:00
class Site extends dbJSON
{
public $dbFields = array(
2023-07-15 15:58:33 +02:00
'title' => 'I am Guybrush Threepwood, mighty developer',
'slogan' => '',
'description' => '',
'footer' => 'I wanna be a pirate!',
'itemsPerPage' => 6,
'language' => 'en',
'locale' => 'en, en_US, en_AU, en_CA, en_GB, en_IE, en_NZ',
'timezone' => 'America/Argentina/Buenos_Aires',
'theme' => 'alternative',
'adminTheme' => 'booty',
'homepage' => '',
'pageNotFound' => '',
'uriPage' => '/',
'uriTag' => '/tag/',
'uriCategory' => '/category/',
'uriBlog' => '/blog/',
'url' => '',
'emailFrom' => '',
'dateFormat' => 'F j, Y',
'timeFormat' => 'g:i a',
'currentBuild' => 0,
'twitter' => '',
'facebook' => '',
'codepen' => '',
'instagram' => '',
'github' => '',
'gitlab' => '',
'linkedin' => '',
'xing' => '',
2024-06-30 21:48:29 +02:00
'telegram' => '',
2023-07-15 15:58:33 +02:00
'mastodon' => '',
'dribbble' => '',
'vk' => '',
'orderBy' => 'date', // date or position
'extremeFriendly' => true,
'autosaveInterval' => 2, // minutes
'titleFormatHomepage' => '{{site-slogan}} | {{site-title}}',
'titleFormatPages' => '{{page-title}} | {{site-title}}',
'titleFormatCategory' => '{{category-name}} | {{site-title}}',
'titleFormatTag' => '{{tag-name}} | {{site-title}}',
'imageRestrict' => true,
'imageRelativeToAbsolute' => false,
'thumbnailWidth' => 400, // px
'thumbnailHeight' => 400, // px
'thumbnailQuality' => 100,
'avatarWidth' => 400, // px
'avatarHeight' => 400, // px
'avatarQuality' => 100,
2023-07-15 15:58:33 +02:00
'logo' => '',
'markdownParser' => true,
'customFields' => '{}'
2015-05-05 03:00:01 +02:00
);
function __construct()
{
2017-05-09 00:24:15 +02:00
parent::__construct(DB_SITE);
2015-05-05 03:00:01 +02:00
// Set timezone
2023-07-15 15:58:33 +02:00
$this->setTimezone($this->timezone());
2015-05-05 03:00:01 +02:00
// Set locale
2023-07-15 15:58:33 +02:00
$this->setLocale($this->locale());
2015-05-05 03:00:01 +02:00
}
// Returns an array with site configuration.
function get()
{
return $this->db;
}
public function set($args)
{
2018-07-28 21:00:12 +02:00
// Check values on args or set default values
2023-07-15 15:58:33 +02:00
foreach ($this->dbFields as $field => $value) {
2018-07-28 21:00:12 +02:00
if (isset($args[$field])) {
$finalValue = Sanitize::html($args[$field]);
2023-07-15 15:58:33 +02:00
if ($finalValue === 'false') {
$finalValue = false;
} elseif ($finalValue === 'true') {
$finalValue = true;
}
2018-07-28 21:00:12 +02:00
settype($finalValue, gettype($value));
$this->db[$field] = $finalValue;
2015-05-05 03:00:01 +02:00
}
}
return $this->save();
2015-05-05 03:00:01 +02:00
}
2018-03-06 16:35:28 +01:00
// Returns an array with the URL filters
// Also, you can get the a particular filter
2023-07-15 15:58:33 +02:00
public function uriFilters($filter = '')
2015-05-05 03:00:01 +02:00
{
2023-07-15 15:58:33 +02:00
$filters['admin'] = '/' . ADMIN_URI_FILTER . '/';
2018-03-06 19:42:18 +01:00
$filters['page'] = $this->getField('uriPage');
$filters['tag'] = $this->getField('uriTag');
$filters['category'] = $this->getField('uriCategory');
2015-05-05 03:00:01 +02:00
2018-03-06 16:35:28 +01:00
if ($this->getField('uriBlog')) {
$filters['blog'] = $this->getField('uriBlog');
}
if (empty($filter)) {
2015-05-05 03:00:01 +02:00
return $filters;
2015-09-18 02:37:14 +02:00
}
2015-05-05 03:00:01 +02:00
2018-03-06 19:42:18 +01:00
if (isset($filters[$filter])) {
return $filters[$filter];
}
return false;
2015-05-05 03:00:01 +02:00
}
// DEPRECATED in v3.0, use Theme::rssUrl()
public function rss()
{
2023-07-15 15:58:33 +02:00
return DOMAIN_BASE . 'rss.xml';
}
// DEPRECATED in v3.0, use Theme::sitemapUrl()
public function sitemap()
{
2023-07-15 15:58:33 +02:00
return DOMAIN_BASE . 'sitemap.xml';
2017-05-03 21:10:03 +02:00
}
public function avatarWidth()
{
return $this->getField('avatarWidth');
}
public function avatarHeight()
{
return $this->getField('avatarHeight');
}
public function avatarQuality()
{
return $this->getField('avatarQuality');
}
2018-11-25 17:54:26 +01:00
public function thumbnailWidth()
{
return $this->getField('thumbnailWidth');
}
public function thumbnailHeight()
{
return $this->getField('thumbnailHeight');
}
public function thumbnailQuality()
{
return $this->getField('thumbnailQuality');
}
2018-07-07 12:04:34 +02:00
public function autosaveInterval()
{
return $this->getField('autosaveInterval');
}
public function extremeFriendly()
{
return $this->getField('extremeFriendly');
}
public function markdownParser()
{
return $this->getField('markdownParser');
}
2016-02-14 01:15:19 +01:00
public function twitter()
{
return $this->getField('twitter');
}
public function facebook()
{
return $this->getField('facebook');
}
2017-09-29 23:02:05 +02:00
public function codepen()
{
return $this->getField('codepen');
}
2016-02-14 22:53:37 +01:00
public function instagram()
{
return $this->getField('instagram');
}
2016-02-14 01:15:19 +01:00
public function github()
{
return $this->getField('github');
}
2018-07-07 12:04:34 +02:00
2018-06-24 13:37:45 +02:00
public function gitlab()
{
return $this->getField('gitlab');
}
2016-02-14 01:15:19 +01:00
2018-03-05 10:57:02 +01:00
public function linkedin()
{
return $this->getField('linkedin');
}
public function xing()
{
return $this->getField('xing');
}
2024-06-30 21:48:29 +02:00
public function telegram()
{
return $this->getField('telegram');
}
2018-09-10 22:04:24 +02:00
public function mastodon()
{
return $this->getField('mastodon');
}
2019-09-02 18:24:34 +02:00
public function dribbble()
{
return $this->getField('dribbble');
}
2019-12-07 14:32:39 +01:00
public function vk()
{
return $this->getField('vk');
}
2017-05-17 00:04:53 +02:00
public function orderBy()
{
return $this->getField('orderBy');
}
public function imageRestrict()
{
return $this->getField('imageRestrict');
}
public function imageRelativeToAbsolute()
{
return $this->getField('imageRelativeToAbsolute');
}
2017-05-09 00:24:15 +02:00
// Returns the site title
2015-05-05 03:00:01 +02:00
public function title()
{
return $this->getField('title');
2015-05-05 03:00:01 +02:00
}
2017-05-09 00:24:15 +02:00
// Returns the site slogan
2016-01-29 17:07:29 +01:00
public function slogan()
2015-10-20 05:14:28 +02:00
{
2016-01-29 17:07:29 +01:00
return $this->getField('slogan');
}
2017-05-09 00:24:15 +02:00
// Returns the site description
2016-01-29 17:07:29 +01:00
public function description()
{
2016-01-29 17:07:29 +01:00
return $this->getField('description');
}
2016-01-29 17:07:29 +01:00
public function emailFrom()
{
2016-01-29 17:07:29 +01:00
return $this->getField('emailFrom');
2015-10-20 05:14:28 +02:00
}
2016-01-29 17:07:29 +01:00
public function dateFormat()
2015-05-19 01:22:05 +02:00
{
2016-01-29 17:07:29 +01:00
return $this->getField('dateFormat');
2015-05-19 01:22:05 +02:00
}
2016-01-29 17:07:29 +01:00
public function timeFormat()
2015-05-05 03:00:01 +02:00
{
2016-01-29 17:07:29 +01:00
return $this->getField('timeFormat');
2015-05-05 03:00:01 +02:00
}
2017-05-09 00:24:15 +02:00
// Returns the site theme name
2015-05-05 03:00:01 +02:00
public function theme()
{
return $this->getField('theme');
2015-05-05 03:00:01 +02:00
}
2017-05-09 00:24:15 +02:00
// Returns the admin theme name
2015-05-05 03:00:01 +02:00
public function adminTheme()
{
return $this->getField('adminTheme');
2015-05-05 03:00:01 +02:00
}
2017-05-09 00:24:15 +02:00
// Returns the footer text
2015-05-05 03:00:01 +02:00
public function footer()
{
return $this->getField('footer');
2015-05-05 03:00:01 +02:00
}
public function titleFormatPages()
{
return $this->getField('titleFormatPages');
}
public function titleFormatHomepage()
{
return $this->getField('titleFormatHomepage');
}
public function titleFormatCategory()
{
return $this->getField('titleFormatCategory');
}
public function titleFormatTag()
{
return $this->getField('titleFormatTag');
}
2018-12-21 19:45:53 +01:00
// Returns the absolute URL of the site logo
// If you set $absolute=false returns only the filename
2023-07-15 15:58:33 +02:00
public function logo($absolute = true)
2018-12-21 19:45:53 +01:00
{
$logo = $this->getField('logo');
2018-12-21 20:16:00 +01:00
if ($absolute && $logo) {
2023-07-15 15:58:33 +02:00
return DOMAIN_UPLOADS . $logo;
2018-12-21 19:45:53 +01:00
}
return $logo;
}
2017-05-09 00:24:15 +02:00
// Returns the full domain and base url
// For example, https://www.domain.com/bludit
2015-05-05 03:00:01 +02:00
public function url()
{
return $this->getField('url');
2015-05-05 03:00:01 +02:00
}
2017-05-09 00:24:15 +02:00
// Returns the protocol and the domain, without the base url
2016-01-21 01:29:01 +01:00
// For example, http://www.domain.com
public function domain()
{
2015-11-30 01:45:30 +01:00
// If the URL field is not set, try detect the domain.
2023-07-15 15:58:33 +02:00
if (Text::isEmpty($this->url())) {
if (!empty($_SERVER['HTTPS'])) {
2015-11-30 01:45:30 +01:00
$protocol = 'https://';
2023-07-15 15:58:33 +02:00
} else {
2015-11-30 01:45:30 +01:00
$protocol = 'http://';
}
2016-01-11 23:51:00 +01:00
$domain = trim($_SERVER['HTTP_HOST'], '/');
2023-07-15 15:58:33 +02:00
return $protocol . $domain;
2015-11-30 01:45:30 +01:00
}
// Parse the domain from the field url (Settings->Advanced)
$parse = parse_url($this->url());
$domain = rtrim($parse['host'], '/');
2023-07-15 15:58:33 +02:00
$port = !empty($parse['port']) ? ':' . $parse['port'] : '';
$scheme = !empty($parse['scheme']) ? $parse['scheme'] . '://' : 'http://';
2016-01-11 23:51:00 +01:00
2023-07-15 15:58:33 +02:00
return $scheme . $domain . $port;
}
2015-05-05 03:00:01 +02:00
// Returns the timezone.
public function timezone()
{
return $this->getField('timezone');
2015-05-05 03:00:01 +02:00
}
2023-07-15 15:58:33 +02:00
public function urlPath()
{
$url = $this->getField('url');
return parse_url($url, PHP_URL_PATH);
}
2021-11-28 12:45:31 +01:00
2023-07-15 15:58:33 +02:00
public function isHTTPS()
{
$url = $this->getField('url');
return parse_url($url, PHP_URL_SCHEME) === 'https';
}
2021-11-28 12:45:31 +01:00
// Returns the current build / version of Bludit.
public function currentBuild()
{
return $this->getField('currentBuild');
}
2017-05-09 00:24:15 +02:00
// Returns the amount of pages per page
public function itemsPerPage()
2015-05-05 03:00:01 +02:00
{
2023-07-15 15:58:33 +02:00
$value = $this->getField('itemsPerPage');
if (($value > 0) or ($value == -1)) {
return $value;
}
return 6;
2015-05-05 03:00:01 +02:00
}
// Returns the current language.
public function language()
{
return $this->getField('language');
2015-05-05 03:00:01 +02:00
}
// Returns the sort version of the site's language
public function languageShortVersion()
{
$current = $this->language();
$explode = explode('_', $current);
return $explode[0];
}
2015-05-05 03:00:01 +02:00
// Returns the current locale.
public function locale()
{
return $this->getField('locale');
2015-05-05 03:00:01 +02:00
}
2017-07-11 23:53:53 +02:00
// Returns the current homepage, FALSE if not defined homepage
2015-05-05 03:00:01 +02:00
public function homepage()
{
2017-07-11 23:53:53 +02:00
$homepage = $this->getField('homepage');
2018-12-26 19:17:30 +01:00
if (empty($homepage)) {
2017-07-11 23:53:53 +02:00
return false;
}
return $homepage;
2015-05-05 03:00:01 +02:00
}
// Returns the page key for the page not found
public function pageNotFound()
{
$pageNotFound = $this->getField('pageNotFound');
return $pageNotFound;
}
// Set the locale, returns TRUE is success, FALSE otherwise
2015-05-05 03:00:01 +02:00
public function setLocale($locale)
{
$localeList = explode(',', $locale);
foreach ($localeList as $locale) {
$locale = trim($locale);
2023-07-15 15:58:33 +02:00
if (setlocale(LC_ALL, $locale . '.UTF-8') !== false) {
return true;
2023-07-15 15:58:33 +02:00
} elseif (setlocale(LC_ALL, $locale) !== false) {
return true;
}
2015-10-24 01:23:33 +02:00
}
2015-05-05 03:00:01 +02:00
// Not was possible to set a locale, using default locale
return false;
2015-05-05 03:00:01 +02:00
}
// Set the timezone.
public function setTimezone($timezone)
{
return date_default_timezone_set($timezone);
}
2019-09-03 18:35:30 +02:00
// Returns the custom fields as array
2019-09-02 18:24:34 +02:00
public function customFields()
{
2019-09-03 18:35:30 +02:00
$customFields = Sanitize::htmlDecode($this->getField('customFields'));
return json_decode($customFields, true);
2019-09-02 18:24:34 +02:00
}
2023-07-15 15:58:33 +02:00
}