bludit/bl-kernel/boot/init.php

288 lines
9.0 KiB
PHP
Raw Normal View History

2015-05-05 03:00:01 +02:00
<?php defined('BLUDIT') or die('Bludit CMS.');
2015-08-17 02:24:22 +02:00
// Bludit version
2017-05-16 00:46:20 +02:00
define('BLUDIT_VERSION', '2.0');
define('BLUDIT_CODENAME', 'Next');
define('BLUDIT_RELEASE_DATE', '2017-10-10');
define('BLUDIT_BUILD', '20171010');
2015-08-17 02:24:22 +02:00
2015-07-26 19:41:40 +02:00
// Debug mode
2017-05-16 00:46:20 +02:00
// Change to FALSE, for prevent warning or errors on browser
2015-07-26 19:35:29 +02:00
define('DEBUG_MODE', TRUE);
2015-08-17 02:24:22 +02:00
error_reporting(0); // Turn off all error reporting
2016-12-01 02:39:16 +01:00
if(DEBUG_MODE) {
2015-08-17 02:24:22 +02:00
// Turn on all error reporting
2015-07-26 19:35:29 +02:00
ini_set("display_errors", 1);
ini_set('display_startup_errors',1);
ini_set("track_errors", 1);
ini_set("html_errors", 1);
error_reporting(E_ALL | E_STRICT | E_NOTICE);
}
2015-08-17 02:24:22 +02:00
// PHP paths
2015-06-22 00:01:07 +02:00
// PATH_ROOT and PATH_BOOT are defined in index.php
2016-01-21 01:29:01 +01:00
define('PATH_LANGUAGES', PATH_ROOT.'bl-languages'.DS);
define('PATH_THEMES', PATH_ROOT.'bl-themes'.DS);
define('PATH_PLUGINS', PATH_ROOT.'bl-plugins'.DS);
define('PATH_KERNEL', PATH_ROOT.'bl-kernel'.DS);
define('PATH_CONTENT', PATH_ROOT.'bl-content'.DS);
2015-08-03 02:49:12 +02:00
define('PATH_ABSTRACT', PATH_KERNEL.'abstract'.DS);
define('PATH_RULES', PATH_KERNEL.'boot'.DS.'rules'.DS);
define('PATH_HELPERS', PATH_KERNEL.'helpers'.DS);
define('PATH_AJAX', PATH_KERNEL.'ajax'.DS);
define('PATH_JS', PATH_KERNEL.'js'.DS);
2016-01-21 01:29:01 +01:00
2015-08-03 02:49:12 +02:00
define('PATH_PAGES', PATH_CONTENT.'pages'.DS);
define('PATH_DATABASES', PATH_CONTENT.'databases'.DS);
2015-06-22 00:01:07 +02:00
define('PATH_PLUGINS_DATABASES', PATH_CONTENT.'databases'.DS.'plugins'.DS);
define('PATH_TMP', PATH_CONTENT.'tmp'.DS);
2015-08-03 02:49:12 +02:00
define('PATH_UPLOADS', PATH_CONTENT.'uploads'.DS);
2016-01-21 01:29:01 +01:00
2015-11-15 22:37:34 +01:00
define('PATH_UPLOADS_PROFILES', PATH_UPLOADS.'profiles'.DS);
define('PATH_UPLOADS_THUMBNAILS', PATH_UPLOADS.'thumbnails'.DS);
2016-01-21 01:29:01 +01:00
2015-11-15 22:37:34 +01:00
define('PATH_ADMIN', PATH_KERNEL.'admin'.DS);
2015-08-03 02:49:12 +02:00
define('PATH_ADMIN_THEMES', PATH_ADMIN.'themes'.DS);
2015-06-22 00:01:07 +02:00
define('PATH_ADMIN_CONTROLLERS', PATH_ADMIN.'controllers'.DS);
2015-08-03 02:49:12 +02:00
define('PATH_ADMIN_VIEWS', PATH_ADMIN.'views'.DS);
2015-06-22 00:01:07 +02:00
2017-05-03 21:10:03 +02:00
define('DEBUG_FILE', PATH_CONTENT.'debug.txt');
2017-05-08 21:26:06 +02:00
// PAGES DATABASE
define('DB_PAGES', PATH_DATABASES.'pages.php');
2017-05-09 00:24:15 +02:00
define('DB_SITE', PATH_DATABASES.'site.php');
2017-05-12 20:18:44 +02:00
define('DB_CATEGORIES', PATH_DATABASES.'categories.php');
2017-05-16 00:46:20 +02:00
define('DB_TAGS', PATH_DATABASES.'tags.php');
2017-05-19 00:45:14 +02:00
define('DB_SYSLOG', PATH_DATABASES.'syslog.php');
2017-05-09 00:24:15 +02:00
// ADMIN URI FILTER
define('ADMIN_URI_FILTER', '/admin/');
2017-05-08 21:26:06 +02:00
2015-08-17 02:24:22 +02:00
// Log separator
define('LOG_SEP', ' | ');
2015-05-15 00:07:45 +02:00
// JSON pretty print
if(!defined('JSON_PRETTY_PRINT')) {
define('JSON_PRETTY_PRINT', 128);
}
2017-05-16 00:46:20 +02:00
// Protecting against Symlink attacks
2016-02-14 22:53:37 +01:00
define('CHECK_SYMBOLIC_LINKS', TRUE);
2017-01-10 17:43:38 +01:00
// Auto scroll
define('AUTO_SCROLL', TRUE);
2015-11-07 01:23:50 +01:00
// Alert status ok
define('ALERT_STATUS_OK', 0);
// Alert status fail
define('ALERT_STATUS_FAIL', 1);
2016-06-03 02:57:13 +02:00
// Amount of thumbnails shown on Bludit Quick images
define('THUMBNAILS_AMOUNT', 6);
// Thubmnails size
define('THUMBNAILS_WIDTH', 400);
define('THUMBNAILS_HEIGHT', 400);
2016-06-03 02:57:13 +02:00
define('THUMBNAILS_QUALITY', 100); // 100%
2016-06-03 02:57:13 +02:00
// Profile image size
define('PROFILE_IMG_WIDTH', 400);
define('PROFILE_IMG_HEIGHT', 400);
define('PROFILE_IMG_QUALITY', 100); // 100%
// Password salt length
2015-05-15 00:07:45 +02:00
define('SALT_LENGTH', 8);
2015-07-14 04:16:28 +02:00
// Page brake string
2015-07-26 02:25:13 +02:00
define('PAGE_BREAK', '<!-- pagebreak -->');
2015-07-14 04:16:28 +02:00
2015-10-31 23:54:42 +01:00
// No parent character, md5('No parent')
define('NO_PARENT_CHAR', '3849abb4cb7abd24c2d8dac17b216f17');
2015-05-05 03:00:01 +02:00
2017-05-10 20:40:28 +02:00
// Items per page for admin area
define('ITEMS_PER_PAGE_ADMIN', 10);
2015-07-24 05:28:25 +02:00
2017-05-16 00:46:20 +02:00
// Cli mode, enable or disable
2016-07-26 01:40:51 +02:00
define('CLI_MODE', FALSE);
2016-05-07 05:10:10 +02:00
2017-05-16 00:46:20 +02:00
// Cli mode, status for new pages
2015-08-26 05:42:32 +02:00
define('CLI_STATUS', 'published');
2017-05-16 00:46:20 +02:00
// Cli mode, username for new pages
2016-02-07 00:44:43 +01:00
define('CLI_USERNAME', 'admin');
2017-05-16 00:46:20 +02:00
// Filename
2016-07-30 21:11:40 +02:00
define('FILENAME', 'index.txt');
2016-01-08 00:43:09 +01:00
// Database date format
define('DB_DATE_FORMAT', 'Y-m-d H:i:s');
2015-05-05 03:00:01 +02:00
2016-01-08 00:43:09 +01:00
// Sitemap date format
define('SITEMAP_DATE_FORMAT', 'Y-m-d');
// Date format for Dashboard schedule posts
2015-10-22 05:14:22 +02:00
define('SCHEDULED_DATE_FORMAT', 'd M - h:i a');
2015-10-20 05:14:28 +02:00
// Token time to live for login via email. The offset is defined by http://php.net/manual/en/datetime.modify.php
2015-10-24 01:23:33 +02:00
define('TOKEN_EMAIL_TTL', '+15 minutes');
2015-10-20 05:14:28 +02:00
2015-08-17 02:24:22 +02:00
// Charset, default UTF-8.
2015-06-26 06:31:53 +02:00
define('CHARSET', 'UTF-8');
2016-12-01 02:39:16 +01:00
// EXTREME FRIENDLY URL, TRUE for dissmiss internet standard. Experimental!
define('EXTREME_FRIENDLY_URL', FALSE);
2016-06-03 02:57:13 +02:00
2017-05-16 00:46:20 +02:00
// Permissions for new directories
define('DIR_PERMISSIONS', 0755);
2017-05-16 00:46:20 +02:00
// Set internal character encoding
2016-07-26 01:40:51 +02:00
mb_internal_encoding(CHARSET);
2015-08-17 02:24:22 +02:00
2017-05-16 00:46:20 +02:00
// Set HTTP output character encoding
2016-07-26 01:40:51 +02:00
mb_http_output(CHARSET);
2015-05-05 03:00:01 +02:00
2015-08-17 02:24:22 +02:00
// Inclde Abstract Classes
2015-05-05 03:00:01 +02:00
include(PATH_ABSTRACT.'dbjson.class.php');
2017-05-16 00:46:20 +02:00
include(PATH_ABSTRACT.'dblist.class.php');
2015-05-05 03:00:01 +02:00
include(PATH_ABSTRACT.'plugin.class.php');
2015-08-17 02:24:22 +02:00
// Inclde Classes
2015-05-05 03:00:01 +02:00
include(PATH_KERNEL.'dbpages.class.php');
include(PATH_KERNEL.'dbusers.class.php');
2015-08-29 07:02:09 +02:00
include(PATH_KERNEL.'dbtags.class.php');
2015-05-05 03:00:01 +02:00
include(PATH_KERNEL.'dblanguage.class.php');
include(PATH_KERNEL.'dbsite.class.php');
2017-03-26 20:51:32 +02:00
include(PATH_KERNEL.'dbcategories.class.php');
2017-05-19 00:45:14 +02:00
include(PATH_KERNEL.'dbsyslog.class.php');
2015-05-05 03:00:01 +02:00
include(PATH_KERNEL.'page.class.php');
2015-12-31 19:47:34 +01:00
include(PATH_KERNEL.'user.class.php');
2015-05-05 03:00:01 +02:00
include(PATH_KERNEL.'url.class.php');
include(PATH_KERNEL.'login.class.php');
include(PATH_KERNEL.'parsedown.class.php');
2015-11-16 09:47:43 +01:00
include(PATH_KERNEL.'parsedownextra.class.php');
2015-08-18 04:02:19 +02:00
include(PATH_KERNEL.'security.class.php');
2015-05-05 03:00:01 +02:00
2016-05-29 19:21:11 +02:00
// Include functions
include(PATH_KERNEL.'functions.php');
2015-08-17 02:24:22 +02:00
// Include Helpers Classes
2015-05-05 03:00:01 +02:00
include(PATH_HELPERS.'text.class.php');
include(PATH_HELPERS.'log.class.php');
include(PATH_HELPERS.'date.class.php');
include(PATH_HELPERS.'theme.class.php');
include(PATH_HELPERS.'session.class.php');
include(PATH_HELPERS.'redirect.class.php');
include(PATH_HELPERS.'sanitize.class.php');
2015-08-04 05:10:12 +02:00
include(PATH_HELPERS.'valid.class.php');
2015-10-20 05:14:28 +02:00
include(PATH_HELPERS.'email.class.php');
2015-05-05 03:00:01 +02:00
include(PATH_HELPERS.'filesystem.class.php');
include(PATH_HELPERS.'alert.class.php');
2015-07-20 05:14:12 +02:00
include(PATH_HELPERS.'paginator.class.php');
include(PATH_HELPERS.'image.class.php');
2015-05-05 03:00:01 +02:00
// Session
Session::start();
if(Session::started()===false) {
2017-05-16 00:46:20 +02:00
exit('Bludit CMS. Session initialization failure.');
2015-05-05 03:00:01 +02:00
}
// Objects
$dbPages = new dbPages();
$dbUsers = new dbUsers();
2015-08-29 07:02:09 +02:00
$dbTags = new dbTags();
2017-03-26 20:51:32 +02:00
$dbCategories = new dbCategories();
2015-05-05 03:00:01 +02:00
$Site = new dbSite();
$Url = new Url();
2015-11-16 09:47:43 +01:00
$Parsedown = new ParsedownExtra();
2015-08-18 04:02:19 +02:00
$Security = new Security();
2017-05-19 00:45:14 +02:00
$Syslog = new dbSyslog();
2015-05-05 03:00:01 +02:00
2016-01-21 01:29:01 +01:00
// --- Relative paths ---
// This paths are relative for the user / web browsing.
// Base URL
2015-12-09 01:56:31 +01:00
// The user can define the base URL.
// Left empty if you want to Bludit try to detect the base URL.
$base = '';
if( !empty($_SERVER['DOCUMENT_ROOT']) && !empty($_SERVER['SCRIPT_NAME']) && empty($base) ) {
$base = str_replace($_SERVER['DOCUMENT_ROOT'], '', $_SERVER['SCRIPT_NAME']);
$base = dirname($base);
}
elseif( empty($base) ) {
$base = empty( $_SERVER['SCRIPT_NAME'] ) ? $_SERVER['PHP_SELF'] : $_SERVER['SCRIPT_NAME'];
$base = dirname($base);
}
2015-09-18 02:37:14 +02:00
if($base!=DS) {
2015-12-09 01:56:31 +01:00
$base = trim($base, '/');
$base = '/'.$base.'/';
2015-09-18 02:37:14 +02:00
}
else {
// Workaround for Windows Web Servers
$base = '/';
}
2015-09-18 02:37:14 +02:00
2016-01-21 01:29:01 +01:00
define('HTML_PATH_ROOT', $base);
define('HTML_PATH_THEMES', HTML_PATH_ROOT.'bl-themes/');
define('HTML_PATH_THEME', HTML_PATH_THEMES.$Site->theme().'/');
2015-08-03 02:49:12 +02:00
define('HTML_PATH_THEME_CSS', HTML_PATH_THEME.'css/');
define('HTML_PATH_THEME_JS', HTML_PATH_THEME.'js/');
2015-09-13 03:06:20 +02:00
define('HTML_PATH_THEME_IMG', HTML_PATH_THEME.'img/');
2015-08-03 02:49:12 +02:00
define('HTML_PATH_ADMIN_ROOT', HTML_PATH_ROOT.'admin/');
2016-01-21 01:29:01 +01:00
define('HTML_PATH_ADMIN_THEME', HTML_PATH_ROOT.'bl-kernel/admin/themes/'.$Site->adminTheme().'/');
2015-11-15 22:37:34 +01:00
define('HTML_PATH_ADMIN_THEME_JS', HTML_PATH_ADMIN_THEME.'js/');
define('HTML_PATH_ADMIN_THEME_CSS', HTML_PATH_ADMIN_THEME.'css/');
2015-11-17 04:21:39 +01:00
define('HTML_PATH_ADMIN_THEME_IMG', HTML_PATH_ADMIN_THEME.'img/');
2015-11-15 22:37:34 +01:00
2016-01-21 01:29:01 +01:00
define('HTML_PATH_UPLOADS', HTML_PATH_ROOT.'bl-content/uploads/');
2015-11-15 22:37:34 +01:00
define('HTML_PATH_UPLOADS_PROFILES', HTML_PATH_UPLOADS.'profiles/');
define('HTML_PATH_UPLOADS_THUMBNAILS', HTML_PATH_UPLOADS.'thumbnails/');
2016-01-21 01:29:01 +01:00
define('HTML_PATH_PLUGINS', HTML_PATH_ROOT.'bl-plugins/');
2015-05-05 03:00:01 +02:00
2017-05-16 00:46:20 +02:00
define('JQUERY', HTML_PATH_ROOT.'bl-kernel/js/jquery.min.js');
2015-09-22 01:37:04 +02:00
2016-01-21 01:29:01 +01:00
// --- PHP paths with dependency ---
2017-05-16 00:46:20 +02:00
// This paths are absolutes for the OS
// Depreacted, use THEME_DIR and THEME_DIR_XXX
define('THEME_DIR', PATH_ROOT.'bl-themes'.DS.$Site->theme().DS);
2017-05-16 00:46:20 +02:00
define('THEME_DIR_PHP', THEME_DIR.'php'.DS);
define('THEME_DIR_CSS', THEME_DIR.'css'.DS);
define('THEME_DIR_JS', THEME_DIR.'js'.DS);
define('THEME_DIR_IMG', THEME_DIR.'img'.DS);
define('THEME_DIR_LANG', THEME_DIR.'languages'.DS);
2016-01-11 23:51:00 +01:00
// --- Absolute paths with domain ---
2016-01-21 01:29:01 +01:00
// This paths are absolutes for the user / web browsing.
2016-01-11 23:51:00 +01:00
define('DOMAIN', $Site->domain());
define('DOMAIN_BASE', DOMAIN.HTML_PATH_ROOT);
define('DOMAIN_THEME_CSS', DOMAIN.HTML_PATH_THEME_CSS);
define('DOMAIN_THEME_JS', DOMAIN.HTML_PATH_THEME_JS);
define('DOMAIN_THEME_IMG', DOMAIN.HTML_PATH_THEME_IMG);
define('DOMAIN_UPLOADS', DOMAIN.HTML_PATH_UPLOADS);
define('DOMAIN_UPLOADS_PROFILES', DOMAIN.HTML_PATH_UPLOADS_PROFILES);
define('DOMAIN_UPLOADS_THUMBNAILS', DOMAIN.HTML_PATH_UPLOADS_THUMBNAILS);
2015-11-30 01:45:30 +01:00
// --- Objects with dependency ---
2015-05-05 03:00:01 +02:00
$Language = new dbLanguage( $Site->locale() );
$Login = new Login( $dbUsers );
$Url->checkFilters( $Site->uriFilters() );
2015-11-30 01:45:30 +01:00
// --- Objects shortcuts ---
2015-05-15 00:07:45 +02:00
$L = $Language;
2017-05-16 00:46:20 +02:00
2017-05-17 00:04:53 +02:00
// --- CONSTANTS with dependency ---
define('ORDER_BY', $Site->orderBy());
2017-05-19 00:45:14 +02:00
$ADMIN_CONTROLLER = '';
2017-05-17 18:48:51 +02:00
$ADMIN_VIEW = '';
2017-05-19 00:45:14 +02:00
$ID_EXECUTION = uniqid(); // string 13 characters long
$WHERE_AM_I = $Url->whereAmI();
2017-05-17 18:48:51 +02:00
2017-05-16 00:46:20 +02:00
// DEBUG: Print constants
// $arr = array_filter(get_defined_constants(), 'is_string');
// echo json_encode($arr);
// exit;