| 1 | 1349 | Luisehahne | <?php
 | 
      
        | 2 |  |  | /**
 | 
      
        | 3 | 1864 | darkviper |  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
 | 
      
        | 4 | 1349 | Luisehahne |  *
 | 
      
        | 5 | 1864 | darkviper |  * This program is free software: you can redistribute it and/or modify
 | 
      
        | 6 |  |  |  * it under the terms of the GNU General Public License as published by
 | 
      
        | 7 |  |  |  * the Free Software Foundation, either version 3 of the License, or
 | 
      
        | 8 |  |  |  * (at your option) any later version.
 | 
      
        | 9 | 1349 | Luisehahne |  *
 | 
      
        | 10 | 1864 | darkviper |  * This program is distributed in the hope that it will be useful,
 | 
      
        | 11 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
      
        | 12 |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
      
        | 13 |  |  |  * GNU General Public License for more details.
 | 
      
        | 14 |  |  |  *
 | 
      
        | 15 |  |  |  * You should have received a copy of the GNU General Public License
 | 
      
        | 16 |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
      
        | 17 | 1349 | Luisehahne |  */
 | 
      
        | 18 |  |  | 
 | 
      
        | 19 | 1617 | darkviper | /**
 | 
      
        | 20 | 1864 | darkviper |  * initialize.php
 | 
      
        | 21 |  |  |  *
 | 
      
        | 22 |  |  |  * @category     Core
 | 
      
        | 23 |  |  |  * @package      Core_Environment
 | 
      
        | 24 |  |  |  * @author       Werner v.d.Decken <wkl@isteam.de>
 | 
      
        | 25 |  |  |  * @copyright    Werner v.d.Decken <wkl@isteam.de>
 | 
      
        | 26 |  |  |  * @license      http://www.gnu.org/licenses/gpl.html   GPL License
 | 
      
        | 27 |  |  |  * @version      0.0.1
 | 
      
        | 28 |  |  |  * @revision     $Revision$
 | 
      
        | 29 |  |  |  * @link         $HeadURL$
 | 
      
        | 30 |  |  |  * @lastmodified $Date$
 | 
      
        | 31 |  |  |  * @since        File replaced since 05.02.2013
 | 
      
        | 32 |  |  |  * @description  set the basic environment to run WebsiteBaker
 | 
      
        | 33 |  |  |  */
 | 
      
        | 34 |  |  | 
 | 
      
        | 35 |  |  | /* *** define some helper functions *** */
 | 
      
        | 36 |  |  | /**
 | 
      
        | 37 | 1617 | darkviper |  * sanitize $_SERVER['HTTP_REFERER']
 | 
      
        | 38 |  |  |  * @param string $sWbUrl qualified startup URL of current application
 | 
      
        | 39 |  |  |  */
 | 
      
        | 40 |  |  | 	function SanitizeHttpReferer($sWbUrl = WB_URL) {
 | 
      
        | 41 |  |  | 		$sTmpReferer = '';
 | 
      
        | 42 |  |  | 		if (isset($_SERVER['HTTP_REFERER']) && $_SERVER['HTTP_REFERER'] != '') {
 | 
      
        | 43 |  |  | 			$aRefUrl = parse_url($_SERVER['HTTP_REFERER']);
 | 
      
        | 44 |  |  | 			if ($aRefUrl !== false) {
 | 
      
        | 45 |  |  | 				$aRefUrl['host'] = isset($aRefUrl['host']) ? $aRefUrl['host'] : '';
 | 
      
        | 46 |  |  | 				$aRefUrl['path'] = isset($aRefUrl['path']) ? $aRefUrl['path'] : '';
 | 
      
        | 47 |  |  | 				$aRefUrl['fragment'] = isset($aRefUrl['fragment']) ? '#'.$aRefUrl['fragment'] : '';
 | 
      
        | 48 |  |  | 				$aWbUrl = parse_url(WB_URL);
 | 
      
        | 49 |  |  | 				if ($aWbUrl !== false) {
 | 
      
        | 50 |  |  | 					$aWbUrl['host'] = isset($aWbUrl['host']) ? $aWbUrl['host'] : '';
 | 
      
        | 51 |  |  | 					$aWbUrl['path'] = isset($aWbUrl['path']) ? $aWbUrl['path'] : '';
 | 
      
        | 52 |  |  | 					if (strpos($aRefUrl['host'].$aRefUrl['path'],
 | 
      
        | 53 |  |  | 							   $aWbUrl['host'].$aWbUrl['path']) !== false) {
 | 
      
        | 54 |  |  | 						$aRefUrl['path'] = preg_replace('#^'.$aWbUrl['path'].'#i', '', $aRefUrl['path']);
 | 
      
        | 55 |  |  | 						$sTmpReferer = WB_URL.$aRefUrl['path'].$aRefUrl['fragment'];
 | 
      
        | 56 |  |  | 					}
 | 
      
        | 57 |  |  | 					unset($aWbUrl);
 | 
      
        | 58 |  |  | 				}
 | 
      
        | 59 |  |  | 				unset($aRefUrl);
 | 
      
        | 60 |  |  | 			}
 | 
      
        | 61 |  |  | 		}
 | 
      
        | 62 |  |  | 		$_SERVER['HTTP_REFERER'] = $sTmpReferer;
 | 
      
        | 63 |  |  | 	}
 | 
      
        | 64 | 1864 | darkviper | /**
 | 
      
        | 65 |  |  |  * Set constants for system/install values
 | 
      
        | 66 |  |  |  * @throws RuntimeException
 | 
      
        | 67 |  |  |  */
 | 
      
        | 68 | 1680 | darkviper | 	function SetInstallPathConstants() {
 | 
      
        | 69 | 1864 | darkviper | 		if(!defined('DEBUG')){ define('DEBUG', false); } // normaly set in config file
 | 
      
        | 70 | 1680 | darkviper | 		if(!defined('ADMIN_DIRECTORY')){ define('ADMIN_DIRECTORY', 'admin'); }
 | 
      
        | 71 |  |  | 		if(!preg_match('/xx[a-z0-9_][a-z0-9_\-\.]+/i', 'xx'.ADMIN_DIRECTORY)) {
 | 
      
        | 72 |  |  | 			throw new RuntimeException('Invalid admin-directory: ' . ADMIN_DIRECTORY);
 | 
      
        | 73 |  |  | 		}
 | 
      
        | 74 |  |  | 		if(!defined('WB_PATH')){ define('WB_PATH', dirname(dirname(__FILE__))); }
 | 
      
        | 75 |  |  | 		if(!defined('ADMIN_URL')){ define('ADMIN_URL', WB_URL.'/'.ADMIN_DIRECTORY); }
 | 
      
        | 76 |  |  | 		if(!defined('ADMIN_PATH')){ define('ADMIN_PATH', WB_PATH.'/'.ADMIN_DIRECTORY); }
 | 
      
        | 77 |  |  | 		if(!defined('WB_REL')){
 | 
      
        | 78 |  |  | 			$x1 = parse_url(WB_URL);
 | 
      
        | 79 |  |  | 			define('WB_REL', (isset($x1['path']) ? $x1['path'] : ''));
 | 
      
        | 80 |  |  | 		}
 | 
      
        | 81 | 1887 | Luisehahne | 		if(!defined('ADMIN_REL')){ define('ADMIN_REL', WB_REL.'/'.ADMIN_DIRECTORY); }
 | 
      
        | 82 | 1680 | darkviper | 		if(!defined('DOCUMENT_ROOT')) {
 | 
      
        | 83 | 1864 | darkviper | 
 | 
      
        | 84 | 1680 | darkviper | 			define('DOCUMENT_ROOT', preg_replace('/'.preg_quote(WB_REL, '/').'$/', '', WB_PATH));
 | 
      
        | 85 |  |  | 		}
 | 
      
        | 86 | 1887 | Luisehahne | 		if(!defined('TMP_PATH')){ define('TMP_PATH', WB_PATH.'/temp'); }
 | 
      
        | 87 | 1680 | darkviper | 	}
 | 
      
        | 88 | 1864 | darkviper | /**
 | 
      
        | 89 |  |  |  * Read DB settings from configuration file
 | 
      
        | 90 |  |  |  * @return string
 | 
      
        | 91 |  |  |  * @throws RuntimeException
 | 
      
        | 92 |  |  |  *
 | 
      
        | 93 |  |  |  */
 | 
      
        | 94 |  |  | 	function readConfiguration($sRetvalType = 'url') {
 | 
      
        | 95 | 1874 | darkviper | 		// check for valid file request. Becomes more stronger in next version
 | 
      
        | 96 | 1864 | darkviper | 		$x = debug_backtrace();
 | 
      
        | 97 | 1874 | darkviper | 		$bValidRequest = false;
 | 
      
        | 98 |  |  | 		if(sizeof($x) != 0) {
 | 
      
        | 99 |  |  | 			foreach($x as $aStep) {
 | 
      
        | 100 |  |  | 				// define the scripts which can read the configuration
 | 
      
        | 101 | 1884 | Luisehahne | 				if(preg_match('/(save.php|index.php|config.php|upgrade-script.php)$/si', $aStep['file'])) {
 | 
      
        | 102 | 1874 | darkviper | 					$bValidRequest = true;
 | 
      
        | 103 |  |  | 					break;
 | 
      
        | 104 |  |  | 				}
 | 
      
        | 105 |  |  | 			}
 | 
      
        | 106 | 1884 | Luisehahne | 		} else {
 | 
      
        | 107 | 1874 | darkviper | 			$bValidRequest = true;
 | 
      
        | 108 |  |  | 		}
 | 
      
        | 109 |  |  | 		if(!$bValidRequest) {
 | 
      
        | 110 |  |  | 			throw new RuntimeException('illegal function request!');
 | 
      
        | 111 |  |  | 		}
 | 
      
        | 112 | 1864 | darkviper | 		$aRetval = array();
 | 
      
        | 113 |  |  | 		$sSetupFile = dirname(dirname(__FILE__)).'/setup.ini.php';
 | 
      
        | 114 |  |  | 		if(is_readable($sSetupFile)) {
 | 
      
        | 115 |  |  | 			$aCfg = parse_ini_file($sSetupFile, true);
 | 
      
        | 116 |  |  | 			foreach($aCfg['Constants'] as $key=>$value) {
 | 
      
        | 117 | 1885 | Luisehahne | 				switch($key):
 | 
      
        | 118 |  |  | 					case 'DEBUG':
 | 
      
        | 119 |  |  | 						$value = filter_var($value, FILTER_VALIDATE_BOOLEAN);
 | 
      
        | 120 | 1887 | Luisehahne | 						if(!defined('DEBUG')) { define('DEBUG', $value); }
 | 
      
        | 121 | 1885 | Luisehahne | 						break;
 | 
      
        | 122 |  |  | 					case 'WB_URL':
 | 
      
        | 123 |  |  | 					case 'AppUrl':
 | 
      
        | 124 |  |  | 						$value = trim(str_replace('\\', '/', $value), '/');
 | 
      
        | 125 |  |  | 						if(!defined('WB_URL')) { define('WB_URL', $value); }
 | 
      
        | 126 |  |  | 						break;
 | 
      
        | 127 |  |  | 					case 'ADMIN_DIRECTORY':
 | 
      
        | 128 |  |  | 					case 'AcpDir':
 | 
      
        | 129 |  |  | 						$value = trim(str_replace('\\', '/', $value), '/');
 | 
      
        | 130 |  |  | 						if(!defined('ADMIN_DIRECTORY')) { define('ADMIN_DIRECTORY', $value); }
 | 
      
        | 131 |  |  | 						break;
 | 
      
        | 132 |  |  | 					default:
 | 
      
        | 133 |  |  | 						if(!defined($key)) { define($key, $value); }
 | 
      
        | 134 |  |  | 						break;
 | 
      
        | 135 |  |  | 				endswitch;
 | 
      
        | 136 | 1864 | darkviper | 			}
 | 
      
        | 137 |  |  | 			$db = $aCfg['DataBase'];
 | 
      
        | 138 |  |  | 			$db['type'] = isset($db['type']) ? $db['type'] : 'mysql';
 | 
      
        | 139 |  |  | 			$db['user'] = isset($db['user']) ? $db['user'] : 'foo';
 | 
      
        | 140 |  |  | 			$db['pass'] = isset($db['pass']) ? $db['pass'] : 'bar';
 | 
      
        | 141 |  |  | 			$db['host'] = isset($db['host']) ? $db['host'] : 'localhost';
 | 
      
        | 142 |  |  | 			$db['port'] = isset($db['port']) ? $db['port'] : '3306';
 | 
      
        | 143 |  |  | 			$db['port'] = ($db['port'] != '3306') ? $db['port'] : '';
 | 
      
        | 144 |  |  | 			$db['name'] = isset($db['name']) ? $db['name'] : 'dummy';
 | 
      
        | 145 | 1889 | Luisehahne | 			$db['charset'] = isset($db['charset']) ? trim($db['charset']) : '';
 | 
      
        | 146 | 1864 | darkviper | 			$db['table_prefix'] = (isset($db['table_prefix']) ? $db['table_prefix'] : '');
 | 
      
        | 147 | 1887 | Luisehahne | 			if(!defined('TABLE_PREFIX')) { define('TABLE_PREFIX', $db['table_prefix']); }
 | 
      
        | 148 | 1864 | darkviper | 			if($sRetvalType == 'dsn') {
 | 
      
        | 149 |  |  | 				$aRetval[0] = $db['type'].':dbname='.$db['name'].';host='.$db['host'].';'
 | 
      
        | 150 |  |  | 				            . ($db['port'] != '' ? 'port='.(int)$db['port'].';' : '');
 | 
      
        | 151 |  |  | 				$aRetval[1] = array('CHARSET' => $db['charset'], 'TABLE_PREFIX' => $db['table_prefix']);
 | 
      
        | 152 |  |  | 				$aRetval[2] = array( 'user' => $db['user'], 'pass' => $db['pass']);
 | 
      
        | 153 |  |  | 			}else { // $sRetvalType == 'url'
 | 
      
        | 154 |  |  | 				$aRetval[0] = $db['type'].'://'.$db['user'].':'.$db['pass'].'@'
 | 
      
        | 155 | 1885 | Luisehahne | 				            . $db['host'].($db['port'] != '' ? ':'.$db['port'] : '').'/'.$db['name']
 | 
      
        | 156 |  |  | 				            . '?Charset='.$db['charset'].'&TablePrefix='.$db['table_prefix'];
 | 
      
        | 157 | 1864 | darkviper | 			}
 | 
      
        | 158 |  |  | 			unset($db, $aCfg);
 | 
      
        | 159 | 1874 | darkviper | 			return $aRetval;
 | 
      
        | 160 | 1864 | darkviper | 		}
 | 
      
        | 161 |  |  | 		throw new RuntimeException('unable to read setup.ini.php');
 | 
      
        | 162 |  |  | 	}
 | 
      
        | 163 |  |  | /* ***************************************************************************************
 | 
      
        | 164 |  |  |  * Start initialization                                                                  *
 | 
      
        | 165 |  |  |  ****************************************************************************************/
 | 
      
        | 166 |  |  | // initialize debug evaluation values ---
 | 
      
        | 167 |  |  | 	$sDbConnectType = 'url'; // depending from class WbDatabase it can be 'url' or 'dsn'
 | 
      
        | 168 | 1680 | darkviper | 	$starttime = array_sum(explode(" ",microtime()));
 | 
      
        | 169 | 1864 | darkviper | 	$iPhpDeclaredClasses = sizeof(get_declared_classes());
 | 
      
        | 170 |  |  | // disable all kind of magic_quotes in PHP versions before 5.4 ---
 | 
      
        | 171 |  |  | 	if(version_compare(PHP_VERSION, '5.4.0', '<')) {
 | 
      
        | 172 |  |  | 		if(get_magic_quotes_gpc() || get_magic_quotes_runtime()) {
 | 
      
        | 173 |  |  | 			@ini_set('magic_quotes_sybase', 0);
 | 
      
        | 174 |  |  | 			@ini_set('magic_quotes_gpc', 0);
 | 
      
        | 175 |  |  | 			@ini_set('magic_quotes_runtime', 0);
 | 
      
        | 176 |  |  | 		}
 | 
      
        | 177 |  |  | 	}
 | 
      
        | 178 | 1865 | darkviper | // load db configuration ---
 | 
      
        | 179 |  |  | 	if(defined('DB_TYPE')) {
 | 
      
        | 180 | 1885 | Luisehahne | 		$sTmp = ($sTmp=((defined('DB_PORT') && DB_PORT !='') ? DB_PORT : '')) ? ':'.$sTmp : '';
 | 
      
        | 181 |  |  | 		$sTmp = DB_TYPE.'://'.DB_USERNAME.':'.DB_PASSWORD.'@'.DB_HOST.$sTmp.'/'.DB_NAME.'?Charset=';
 | 
      
        | 182 |  |  | 		$sTmp .= (defined('DB_CHARSET') ? DB_CHARSET : '').'&TablePrefix='.TABLE_PREFIX;
 | 
      
        | 183 |  |  | 		$aSqlData = array( 0 => $sTmp);
 | 
      
        | 184 | 1865 | darkviper | 	}else {
 | 
      
        | 185 |  |  | 		$aSqlData = readConfiguration($sDbConnectType);
 | 
      
        | 186 |  |  | 	}
 | 
      
        | 187 |  |  | // sanitize $_SERVER['HTTP_REFERER'] ---
 | 
      
        | 188 |  |  | 	SanitizeHttpReferer(WB_URL);
 | 
      
        | 189 |  |  | 	SetInstallPathConstants();
 | 
      
        | 190 | 1864 | darkviper | // register WB basic autoloader ---
 | 
      
        | 191 |  |  | 	$sTmp = dirname(__FILE__).'/WbAutoloader.php';
 | 
      
        | 192 | 1873 | darkviper | 	if(!class_exists('WbAutoloader')){
 | 
      
        | 193 |  |  | 		include($sTmp);
 | 
      
        | 194 |  |  | 	}
 | 
      
        | 195 | 1687 | darkviper | 	WbAutoloader::doRegister(array(ADMIN_DIRECTORY=>'a', 'modules'=>'m'));
 | 
      
        | 196 | 1864 | darkviper | // register TWIG autoloader ---
 | 
      
        | 197 | 1865 | darkviper | 	$sTmp = dirname(dirname(__FILE__)).'/include/Sensio/Twig/lib/Twig/Autoloader.php';
 | 
      
        | 198 | 1873 | darkviper | 	if(!class_exists('Twig_Autoloader')) {
 | 
      
        | 199 |  |  | 		include($sTmp);
 | 
      
        | 200 |  |  | 	}
 | 
      
        | 201 | 1687 | darkviper | 	Twig_Autoloader::register();
 | 
      
        | 202 | 1864 | darkviper | // aktivate exceptionhandler ---
 | 
      
        | 203 |  |  | 	if(!function_exists('globalExceptionHandler')) {
 | 
      
        | 204 |  |  | 		include(dirname(__FILE__).'/globalExceptionHandler.php');
 | 
      
        | 205 |  |  | 	}
 | 
      
        | 206 |  |  | // ---------------------------
 | 
      
        | 207 |  |  | // Create global database instance ---
 | 
      
        | 208 | 1686 | darkviper | 	$database = WbDatabase::getInstance();
 | 
      
        | 209 | 1864 | darkviper | 	if($sDbConnectType == 'dsn') {
 | 
      
        | 210 | 1874 | darkviper | 		$bTmp = $database->doConnect($aSqlData[0], $aSqlData[1]['user'], $aSqlData[1]['pass'], $aSqlData[2]);
 | 
      
        | 211 | 1864 | darkviper | 	}else {
 | 
      
        | 212 | 1885 | Luisehahne | 		$bTmp = $database->doConnect($aSqlData[0]);
 | 
      
        | 213 | 1680 | darkviper | 	}
 | 
      
        | 214 | 1864 | darkviper | 	unset($aSqlData);
 | 
      
        | 215 |  |  | // load global settings from database and define global consts from ---
 | 
      
        | 216 |  |  | 	$sql = 'SELECT `name`, `value` FROM `'.TABLE_PREFIX.'settings`';
 | 
      
        | 217 |  |  | 	if(($oSettings = $database->query($sql))) {
 | 
      
        | 218 |  |  | 		if(!$oSettings->numRows()) { throw new AppException('no settings found'); }
 | 
      
        | 219 |  |  | 		while($aSetting = $oSettings->fetchRow(MYSQL_ASSOC)) {
 | 
      
        | 220 |  |  | 			//sanitize true/false values
 | 
      
        | 221 |  |  | 			$aSetting['value'] = ($aSetting['value'] == 'true'
 | 
      
        | 222 |  |  | 								  ? true
 | 
      
        | 223 |  |  | 								  : ($aSetting['value'] == 'false'
 | 
      
        | 224 |  |  | 									 ? false
 | 
      
        | 225 |  |  | 									 : $aSetting['value'])
 | 
      
        | 226 |  |  | 								 );
 | 
      
        | 227 | 1873 | darkviper | 			$sSettingName = strtoupper($aSetting['name']);
 | 
      
        | 228 |  |  | 			switch($sSettingName):
 | 
      
        | 229 |  |  | 				case 'STRING_FILE_MODE':
 | 
      
        | 230 |  |  | 					$iTmp = ((intval(octdec($aSetting['value'])) & ~0111)|0600);
 | 
      
        | 231 | 1887 | Luisehahne | 					if(!defined('OCTAL_FILE_MODE')) { define('OCTAL_FILE_MODE', $iTmp); }
 | 
      
        | 232 |  |  | 					if(!defined('STRING_FILE_MODE')) { define('STRING_FILE_MODE', sprintf('0%03o', $iTmp)); }
 | 
      
        | 233 | 1873 | darkviper | 					break;
 | 
      
        | 234 |  |  | 				case 'STRING_DIR_MODE':
 | 
      
        | 235 |  |  | 					$iTmp = (intval(octdec($aSetting['value'])) |0711);
 | 
      
        | 236 | 1887 | Luisehahne | 					if(!defined('OCTAL_DIR_MODE')) { define('OCTAL_DIR_MODE', $iTmp); }
 | 
      
        | 237 |  |  | 					if(!defined('STRING_DIR_MODE')) { define('STRING_DIR_MODE', sprintf('0%03o', $iTmp)); }
 | 
      
        | 238 | 1874 | darkviper | 					break;
 | 
      
        | 239 | 1873 | darkviper | 				case 'PAGES_DIRECTORY':
 | 
      
        | 240 |  |  | 					// sanitize pages_directory
 | 
      
        | 241 |  |  | 					$sTmp = trim($aSetting['value'], '/');
 | 
      
        | 242 |  |  | 					$sTmp = ($sTmp == '' ? '' : '/'.$sTmp);
 | 
      
        | 243 | 1887 | Luisehahne | 					if(!defined('PAGES_DIRECTORY')) { define('PAGES_DIRECTORY', $sTmp); }
 | 
      
        | 244 | 1873 | darkviper | 					break;
 | 
      
        | 245 |  |  | 				default: // make global const from setting
 | 
      
        | 246 | 1887 | Luisehahne | 					if(!defined($sSettingName)) { define($sSettingName, $aSetting['value']); }
 | 
      
        | 247 | 1873 | darkviper | 					break;
 | 
      
        | 248 |  |  | 			endswitch;
 | 
      
        | 249 | 1864 | darkviper | 		}
 | 
      
        | 250 |  |  | 	}else { throw new AppException($database->get_error()); }
 | 
      
        | 251 | 1872 | Luisehahne | // set error-reporting from loaded settings ---
 | 
      
        | 252 |  |  | 	if(intval(ER_LEVEL) > 0 ) {
 | 
      
        | 253 |  |  | 		error_reporting(ER_LEVEL);
 | 
      
        | 254 |  |  | 		if( intval(ini_get ( 'display_errors' )) == 0 ) {
 | 
      
        | 255 |  |  | 			ini_set('display_errors', 1);
 | 
      
        | 256 |  |  | 		}
 | 
      
        | 257 |  |  | 	}
 | 
      
        | 258 |  |  | // Start a session ---
 | 
      
        | 259 |  |  | 	if(!defined('SESSION_STARTED')) {
 | 
      
        | 260 |  |  | 		session_name(APP_NAME.'_session_id');
 | 
      
        | 261 |  |  | 		@session_start();
 | 
      
        | 262 |  |  | 		define('SESSION_STARTED', true);
 | 
      
        | 263 |  |  | 	}
 | 
      
        | 264 | 1963 | darkviper | // get/set server timezone ---
 | 
      
        | 265 |  |  | 	if(!defined('SERVER_TIMEZONE')) { define('SERVER_TIMEZONE', "UTC"); }
 | 
      
        | 266 |  |  | 	date_default_timezone_set( SERVER_TIMEZONE );
 | 
      
        | 267 |  |  | 	if(!defined('MAX_TIME')) { define('MAX_TIME', (pow(2, 31)-1)); } // 32-Bit Timestamp of 19 Jan 2038 03:14:07 GMT
 | 
      
        | 268 |  |  | 	$sTmp = (isset($_SERVER['HTTP_DNT']) && $_SERVER['HTTP_DNT'] != '') ? $_SERVER['HTTP_DNT'] : '0';
 | 
      
        | 269 |  |  | 	if(!defined('DO_NOT_TRACK')) { define('DO_NOT_TRACK', ($sTmp[0] == '1')); }
 | 
      
        | 270 | 1864 | darkviper | // get/set users timezone ---
 | 
      
        | 271 | 1887 | Luisehahne | 	if(!defined('TIMEZONE')) { define('TIMEZONE', (isset($_SESSION['TIMEZONE']) ? $_SESSION['TIMEZONE'] : DEFAULT_TIMEZONE)); }
 | 
      
        | 272 |  |  | 	if(!defined('DATE_FORMAT')) { define('DATE_FORMAT', (isset($_SESSION['DATE_FORMAT']) ? $_SESSION['DATE_FORMAT'] : DEFAULT_DATE_FORMAT)); }
 | 
      
        | 273 |  |  | 	if(!defined('TIME_FORMAT')) { define('TIME_FORMAT', (isset($_SESSION['TIME_FORMAT']) ? $_SESSION['TIME_FORMAT'] : DEFAULT_TIME_FORMAT)); }
 | 
      
        | 274 | 1864 | darkviper | // set Theme directory ---
 | 
      
        | 275 | 1887 | Luisehahne | 	if(!defined('THEMA_URL')) { define('THEME_URL',  WB_URL.'/templates/'.DEFAULT_THEME); }
 | 
      
        | 276 |  |  | 	if(!defined('THEME_PATH')) { define('THEME_PATH', WB_PATH.'/templates/'.DEFAULT_THEME); }
 | 
      
        | 277 |  |  | 	if(!defined('THEME_REL')) { define('THEME_REL',  WB_REL.'/templates/'.DEFAULT_THEME); }
 | 
      
        | 278 | 1864 | darkviper | // extended wb editor settings
 | 
      
        | 279 | 1887 | Luisehahne | 	if(!defined('EDIT_ONE_SECTION')) { define('EDIT_ONE_SECTION', false); }
 | 
      
        | 280 |  |  | 	if(!defined('EDITOR_WIDTH')) { define('EDITOR_WIDTH', 0); }
 | 
      
        | 281 | 1864 | darkviper | // define form security class and preload it ---
 | 
      
        | 282 | 1465 | Luisehahne | 	$sSecMod = (defined('SECURE_FORM_MODULE') && SECURE_FORM_MODULE != '') ? '.'.SECURE_FORM_MODULE : '';
 | 
      
        | 283 | 1462 | DarkViper | 	$sSecMod = WB_PATH.'/framework/SecureForm'.$sSecMod.'.php';
 | 
      
        | 284 |  |  | 	require_once($sSecMod);
 | 
      
        | 285 | 1864 | darkviper | // *** begin deprecated part *************************************************************
 | 
      
        | 286 |  |  | // load settings for use in Captch and ASP module
 | 
      
        | 287 | 1887 | Luisehahne | 	if (!defined('WB_INSTALL_PROCESS') && !defined('ENABLED_CAPTCHA')) {
 | 
      
        | 288 | 1864 | darkviper | 		$sql = 'SELECT * FROM `'.TABLE_PREFIX.'mod_captcha_control`';
 | 
      
        | 289 |  |  | 		// request settings from database
 | 
      
        | 290 |  |  | 		if(($oSettings = $database->query($sql))) {
 | 
      
        | 291 |  |  | 			if(($aSetting = $oSettings->fetchRow(MYSQL_ASSOC))) {
 | 
      
        | 292 |  |  | 				define('ENABLED_CAPTCHA', ($aSetting['enabled_captcha'] == '1'));
 | 
      
        | 293 |  |  | 				define('ENABLED_ASP', ($aSetting['enabled_asp'] == '1'));
 | 
      
        | 294 |  |  | 				define('CAPTCHA_TYPE', $aSetting['captcha_type']);
 | 
      
        | 295 |  |  | 				define('ASP_SESSION_MIN_AGE', (int)$aSetting['asp_session_min_age']);
 | 
      
        | 296 |  |  | 				define('ASP_VIEW_MIN_AGE', (int)$aSetting['asp_view_min_age']);
 | 
      
        | 297 |  |  | 				define('ASP_INPUT_MIN_AGE', (int)$aSetting['asp_input_min_age']);
 | 
      
        | 298 |  |  | 			}
 | 
      
        | 299 |  |  | 		}
 | 
      
        | 300 |  |  | 	}
 | 
      
        | 301 |  |  | 	if(defined('ENABLED_ASP') && ENABLED_ASP && !isset($_SESSION['session_started'])) {
 | 
      
        | 302 | 1349 | Luisehahne | 		$_SESSION['session_started'] = time();
 | 
      
        | 303 | 1864 | darkviper | 	}
 | 
      
        | 304 |  |  | // *** end of deprecated part ************************************************************
 | 
      
        | 305 |  |  | // get user language ---
 | 
      
        | 306 |  |  | 	$sRequestMethod = '_'.strtoupper($_SERVER['REQUEST_METHOD']);
 | 
      
        | 307 |  |  | 	// check if get/post value is available
 | 
      
        | 308 |  |  | 	$sTempLanguage = (isset(${$sRequestMethod}['lang']) ? ${$sRequestMethod}['lang'] : '');
 | 
      
        | 309 |  |  | 	// validate language code
 | 
      
        | 310 |  |  | 	if(preg_match('/^[a-z]{2}$/si', $sTempLanguage)) {
 | 
      
        | 311 |  |  | 	// if there's valid get/post
 | 
      
        | 312 |  |  | 		define('LANGUAGE', strtoupper($sTempLanguage));
 | 
      
        | 313 | 1349 | Luisehahne | 		$_SESSION['LANGUAGE']=LANGUAGE;
 | 
      
        | 314 | 1864 | darkviper | 	}else {
 | 
      
        | 315 |  |  | 		if(isset($_SESSION['LANGUAGE']) && $_SESSION['LANGUAGE']) {
 | 
      
        | 316 |  |  | 		// if there's valid session value
 | 
      
        | 317 | 1349 | Luisehahne | 			define('LANGUAGE', $_SESSION['LANGUAGE']);
 | 
      
        | 318 | 1864 | darkviper | 		}else {
 | 
      
        | 319 |  |  | 		// otherwise set to default
 | 
      
        | 320 | 1349 | Luisehahne | 			define('LANGUAGE', DEFAULT_LANGUAGE);
 | 
      
        | 321 |  |  | 		}
 | 
      
        | 322 |  |  | 	}
 | 
      
        | 323 | 1864 | darkviper | // activate translations / load language definitions
 | 
      
        | 324 |  |  | /** begin of deprecated part || will be replaced by class Translate **/
 | 
      
        | 325 |  |  | // Load Language file
 | 
      
        | 326 |  |  | 	if(!file_exists(WB_PATH.'/languages/'.LANGUAGE.'.php')) {
 | 
      
        | 327 |  |  | 		$sMsg = 'Error loading language file '.LANGUAGE.', please check configuration';
 | 
      
        | 328 |  |  | 		throw new AppException($sMsg);
 | 
      
        | 329 | 1349 | Luisehahne | 	} else {
 | 
      
        | 330 | 1864 | darkviper | 	// include language file
 | 
      
        | 331 |  |  | 		require_once(WB_PATH.'/languages/'.LANGUAGE.'.php');
 | 
      
        | 332 | 1349 | Luisehahne | 	}
 | 
      
        | 333 | 1864 | darkviper | /** end of deprecated part **/
 | 
      
        | 334 |  |  | // instantiate and initialize adaptor for temporary registry replacement ---
 | 
      
        | 335 |  |  | 	if(class_exists('WbAdaptor')) {
 | 
      
        | 336 |  |  | 		WbAdaptor::getInstance()->getWbConstants();
 | 
      
        | 337 | 1349 | Luisehahne | 	}
 | 
      
        | 338 | 1864 | darkviper | // load and activate new global translation table
 | 
      
        | 339 |  |  | 	Translate::getInstance()->initialize('en',
 | 
      
        | 340 | 1873 | darkviper | 										 (defined('DEFAULT_LANGUAGE') ? DEFAULT_LANGUAGE : ''),
 | 
      
        | 341 | 1885 | Luisehahne | 										 (defined('LANGUAGE') ? LANGUAGE : ''),
 | 
      
        | 342 |  |  | 										 'WbOldStyle',
 | 
      
        | 343 |  |  | 										 (DEBUG ? Translate::CACHE_DISABLED|Translate::KEEP_MISSING : 0)
 | 
      
        | 344 | 1873 | darkviper | 										);
 | 
      
        | 345 | 1963 | darkviper | 	if(!class_exists('PasswordHash', false)) { include(WB_PATH.'/include/phpass/PasswordHash.php'); }
 | 
      
        | 346 | 1932 | darkviper | 	$oPass = Password::getInstance(new PasswordHash(Password::CRYPT_LOOPS_DEFAULT, Password::HASH_TYPE_AUTO));
 | 
      
        | 347 | 1930 | darkviper | 	if(defined('PASSWORD_CRYPT_LOOPS')) { $oPass->setIteration(PASSWORD_CRYPT_LOOPS); }
 | 
      
        | 348 | 1932 | darkviper | 	if(defined('PASSWORD_HASH_TYPES'))  { $oPass->setHashType(PASSWORD_HASH_TYPES); }
 | 
      
        | 349 | 1864 | darkviper | // *** END OF FILE ***********************************************************************
 |