]>
git.agnieray.net Git - galette.git/blob - galette/includes/galette.inc.php
3 /* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
6 * Main Galette initialisation
10 * Copyright © 2009-2024 The Galette Team
12 * This file is part of Galette (http://galette.tuxfamily.org).
14 * Galette is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU General Public License as published by
16 * the Free Software Foundation, either version 3 of the License, or
17 * (at your option) any later version.
19 * Galette is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
24 * You should have received a copy of the GNU General Public License
25 * along with Galette. If not, see <http://www.gnu.org/licenses/>.
30 * @author Johan Cwiklinski <johan@x-tnd.be>
31 * @copyright 2007-2024 The Galette Team
32 * @license http://www.gnu.org/licenses/gpl-3.0.html GPL License 3.0 or (at your option) any later version
33 * @link http://galette.tuxfamily.org
34 * @since Available since 0.7-dev - 2007-10-07
37 //define galette's root directory
38 if (!defined('GALETTE_ROOT')) {
39 define('GALETTE_ROOT', __DIR__
. '/../');
42 require_once GALETTE_ROOT
. 'config/versions.inc.php';
43 require_once GALETTE_ROOT
. 'config/paths.inc.php';
45 // check required PHP version...
46 if (version_compare(PHP_VERSION
, GALETTE_PHP_MIN
, '<')) {
47 echo 'Galette is NOT compliant with your current PHP version. ' .
48 'Galette requires PHP ' . GALETTE_PHP_MIN
.
49 ' minimum and current version is ' . phpversion();
53 $time_start = microtime(true);
54 $cron = (PHP_SAPI
=== 'cli');
56 // define relative base path templating can use
57 if (!defined('GALETTE_BASE_PATH')) {
58 define('GALETTE_BASE_PATH', './');
61 //we'll only include relevant parts if we work from installer
62 if (!isset($installer)) {
65 // test if galette is already installed or if we're form installer
66 // and redirect to install page if not
67 $installed = file_exists(GALETTE_CONFIG_PATH
. 'config.inc.php');
68 if (!$installed && !$installer) {
69 header('location: ./installer.php');
74 file_exists(GALETTE_CONFIG_PATH
. 'behavior.inc.php')
75 && !defined('GALETTE_TESTS')
77 include_once GALETTE_CONFIG_PATH
. 'behavior.inc.php';
80 if (isset($installer) && $installer !== true) {
81 //If we're not working from installer
82 include_once GALETTE_CONFIG_PATH
. 'config.inc.php';
87 use Analog\Handler\LevelName
;
90 require GALETTE_ROOT
. '/vendor/autoload.php';
94 defined('GALETTE_XHPROF_PATH')
95 && function_exists('xhprof_enable')
97 include_once __DIR__
. '/../lib/Galette/Common/XHProf.php';
98 $profiler = new Galette\Common\
XHProf();
103 if (!defined('GALETTE_HIDE_VERSION')) {
104 define('GALETTE_DISPLAY_VERSION', \Galette\Core\Galette
::gitVersion(false));
107 if (!defined('GALETTE_MODE')) {
108 define('GALETTE_MODE', \Galette\Core\Galette
::MODE_PROD
);
111 if (!isset($_COOKIE['show_galette_dashboard'])) {
113 'show_galette_dashboard',
116 'expires' => time() +
31536000, //valid for a year
122 ini_set('display_errors', (defined('GALETTE_TESTS') ?
'1' : '0'));
124 /*------------------------------------------------------------------------------
126 ------------------------------------------------------------------------------*/
128 error_reporting(E_ALL
);
129 set_error_handler(function ($severity, $message, $file, $line) {
130 if (error_reporting() & $severity) {
131 throw new \
ErrorException($message, 0, $severity, $file, $line);
135 //change default format so the 3rd param is a string for level name
136 Analog
::$format = "%s - %s - %s - %s\n";
137 $galette_run_log = null;
139 if (!defined('GALETTE_LOG_LVL')) {
140 if (\Galette\Core\Galette
::isDebugEnabled()) {
141 define('GALETTE_LOG_LVL', Analog
::DEBUG
);
142 } elseif (defined('GALETTE_TESTS')) {
143 define('GALETTE_LOG_LVL', Analog
::NOTICE
);
145 define('GALETTE_LOG_LVL', Analog
::WARNING
);
149 if (defined('GALETTE_TESTS')) {
150 $log_path = GALETTE_LOGS_PATH
. 'tests.log';
151 $galette_run_log = LevelName
::init(Handler\File
::init($log_path));
153 $galette_log_var = null;
155 if (!$installer ||
($installer && defined('GALETTE_LOGGER_CHECKED'))) {
156 //logs everything in galette log file
157 if (!isset($logfile)) {
158 //if no filename has been setted (ie. from install), set default one
159 $logfile = 'galette';
161 $log_path = GALETTE_LOGS_PATH
. $logfile . '.log';
162 $galette_run_log = LevelName
::init(Handler\File
::init($log_path));
164 $galette_run_log = LevelName
::init(Handler\Variable
::init($galette_log_var));
167 Core\Logs
::cleanup();
171 Analog
::handler($galette_run_log);
173 require_once GALETTE_ROOT
. 'includes/functions.inc.php';
175 if (!$installer and !defined('GALETTE_TESTS')) {
176 //If we're not working from installer nor from tests
177 include_once GALETTE_CONFIG_PATH
. 'config.inc.php';
180 * Database instantiation
182 $zdb = new Core\
Db();
184 if ($zdb->checkDbVersion()) {
189 $preferences = new Core\
Preferences($zdb);
192 * Set the path to the current theme templates
195 '_CURRENT_THEME_PATH',
196 GALETTE_THEMES_PATH
. $preferences->pref_theme
. '/'
199 if (!defined('GALETTE_THEME')) {
202 'themes/' . $preferences->pref_theme
. '/'
206 $needs_update = true;
210 $plugins = new Galette\Core\
Plugins();
211 //make sure plugins autoload is called before session start
212 $plugins->autoload(GALETTE_PLUGINS_PATH
);