[BUGFIX] Regression: filelistFolderTree constructor is recursive
[Packages/TYPO3.CMS.git] / typo3 / init.php
1 <?php
2 /***************************************************************
3 * Copyright notice
4 *
5 * (c) 1999-2011 Kasper Skårhøj (kasperYYYY@typo3.com)
6 * All rights reserved
7 *
8 * This script is part of the TYPO3 project. The TYPO3 project is
9 * free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * The GNU General Public License can be found at
15 * http://www.gnu.org/copyleft/gpl.html.
16 * A copy is found in the textfile GPL.txt and important notices to the license
17 * from the author is found in LICENSE.txt distributed with these scripts.
18 *
19 *
20 * This script is distributed in the hope that it will be useful,
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 * GNU General Public License for more details.
24 *
25 * This copyright notice MUST APPEAR in all copies of the script!
26 ***************************************************************/
27 /**
28 * TYPO3 Backend initialization
29 *
30 * This script is called by every backend script.
31 * The script authenticates the backend user.
32 * In addition this script also initializes the database and other stuff by including the script localconf.php
33 *
34 * IMPORTANT:
35 * This script exits if no user is logged in!
36 * If you want the script to return even if no user is logged in,
37 * you must define the constant TYPO3_PROCEED_IF_NO_USER=1
38 * before you include this script.
39 *
40 *
41 * This script does the following:
42 * - extracts and defines path's
43 * - includes certain libraries
44 * - authenticates the user
45 * - sets the configuration values (localconf.php)
46 * - includes tables.php that sets more values and possibly overrides others
47 * - load the groupdata for the user and set filemounts / webmounts
48 *
49 * For a detailed description of this script, the scope of constants and variables in it,
50 * please refer to the document "Inside TYPO3"
51 *
52 * Revised for TYPO3 3.6 2/2003 by Kasper Skårhøj
53 *
54 * @author Kasper Skårhøj <kasperYYYY@typo3.com>
55 * @package TYPO3
56 * @subpackage core
57 */
58
59 // *******************************
60 // Checking PHP version
61 // *******************************
62 if (version_compare(phpversion(), '5.3', '<')) die ('TYPO3 requires PHP 5.3.0 or higher.');
63
64
65 // *******************************
66 // Set error reporting
67 // *******************************
68 error_reporting(E_ALL ^ E_NOTICE ^ E_DEPRECATED);
69
70 // *******************************
71 // Prevent any unwanted output that may corrupt AJAX/compression. Note: this does
72 // not interfeer with "die()" or "echo"+"exit()" messages!
73 // *******************************
74 ob_start();
75
76 // *******************************
77 // Define constants
78 // *******************************
79 define('TYPO3_OS', stristr(PHP_OS,'win')&&!stristr(PHP_OS,'darwin')?'WIN':'');
80 define('TYPO3_MODE','BE');
81 define('PATH_thisScript', str_replace('//', '/', str_replace('\\', '/',
82 (PHP_SAPI == 'fpm-fcgi' || PHP_SAPI == 'cgi' || PHP_SAPI == 'isapi' || PHP_SAPI == 'cgi-fcgi') &&
83 ($_SERVER['ORIG_PATH_TRANSLATED'] ? $_SERVER['ORIG_PATH_TRANSLATED'] : $_SERVER['PATH_TRANSLATED']) ?
84 ($_SERVER['ORIG_PATH_TRANSLATED'] ? $_SERVER['ORIG_PATH_TRANSLATED'] : $_SERVER['PATH_TRANSLATED']) :
85 ($_SERVER['ORIG_SCRIPT_FILENAME'] ? $_SERVER['ORIG_SCRIPT_FILENAME'] : $_SERVER['SCRIPT_FILENAME']))));
86
87 define('TYPO3_mainDir', 'typo3/'); // This is the directory of the backend administration for the sites of this TYPO3 installation.
88
89
90 // *******************************
91 // Fix BACK_PATH, if the TYPO3_mainDir is set to something else than
92 // typo3/, this is a workaround because the conf.php of the old modules
93 // still have "typo3/" hardcoded. Can be removed once we don't have to worry about
94 // legacy modules (with conf.php and $BACK_PATH) anymore. See RFC / Bug #13262 for more details.
95 // *******************************
96 if (isset($BACK_PATH) && strlen($BACK_PATH) > 0 && TYPO3_mainDir != 'typo3/' && substr($BACK_PATH, -7) == '/typo3/') {
97 $BACK_PATH = substr($BACK_PATH, 0, -6) . TYPO3_mainDir;
98 }
99
100 // *******************************
101 // Checking path
102 // *******************************
103 $temp_path = str_replace('\\','/',dirname(PATH_thisScript).'/');
104 $temp_modPath='';
105 // If TYPO3_MOD_PATH is defined we must calculate the modPath since init.php must be included by a module
106 if (substr($temp_path,-strlen(TYPO3_mainDir))!=TYPO3_mainDir) {
107 if (defined('TYPO3_MOD_PATH')) {
108 if (substr($temp_path,-strlen(TYPO3_MOD_PATH))==TYPO3_MOD_PATH) {
109 $temp_path=substr($temp_path,0,-strlen(TYPO3_MOD_PATH));
110 $temp_modPath=TYPO3_MOD_PATH;
111 } elseif (substr(TYPO3_MOD_PATH,0,13)=='../typo3conf/' && (substr(TYPO3_MOD_PATH,3)==substr($temp_path,-strlen(substr(TYPO3_MOD_PATH,3))))) {
112 $temp_path = substr($temp_path,0,-strlen(substr(TYPO3_MOD_PATH,3))).TYPO3_mainDir;
113 $temp_modPath=TYPO3_MOD_PATH;
114 }
115 if (!@is_dir($temp_path)) {
116 $temp_path='';
117 }
118 }
119 }
120
121 // OUTPUT error message and exit if there are problems with the path. Otherwise define constants and continue.
122 if (!$temp_path || substr($temp_path,-strlen(TYPO3_mainDir))!=TYPO3_mainDir) { // This must be the case in order to proceed
123 if (TYPO3_OS=='WIN') {
124 $thisPath_base = basename(substr($temp_path,-strlen(TYPO3_mainDir)));
125 $mainPath_base = basename(TYPO3_mainDir);
126 if (!strcasecmp($thisPath, $mainPath)) { // Seems like the requested URL is not case-specific. This may happen on Windows only. -case. Otherwise, redirect to the correct URL. TYPO3_mainDir must be lower-case!!
127 $script_name = (PHP_SAPI=='fpm-fcgi' || PHP_SAPI=='cgi' || PHP_SAPI=='cgi-fcgi') &&
128 ($_SERVER['ORIG_PATH_INFO'] ? $_SERVER['ORIG_PATH_INFO'] : $_SERVER['PATH_INFO']) ?
129 ($_SERVER['ORIG_PATH_INFO'] ? $_SERVER['ORIG_PATH_INFO'] : $_SERVER['PATH_INFO']) :
130 ($_SERVER['ORIG_SCRIPT_NAME']?$_SERVER['ORIG_SCRIPT_NAME']:$_SERVER['SCRIPT_NAME']); // Copied from t3lib_div::getIndpEnv()
131
132 header('Location: '.str_replace($thisPath_base, $mainPath_base, $script_name));
133 exit;
134 }
135 }
136
137 echo 'Error in init.php: Path to TYPO3 main dir could not be resolved correctly. <br /><br />';
138
139 echo '<font color="red"><strong>';
140 if (strstr($temp_path,'typo3_src')) {
141 echo 'It seems you are trying to run the TYPO3 source libraries DIRECTLY! You cannot do that.<br />
142 Please read the installation documents for more information.';
143 } else {
144 $temp_path_parts = explode('/', $temp_path);
145 $temp_path_parts = array_slice($temp_path_parts, count($temp_path_parts) - 3);
146 $temp_path = '..../' . implode('/', $temp_path_parts);
147 echo 'This happens if the last ' . strlen(TYPO3_mainDir) . ' characters of this path, ' . $temp_path . ' (end of $temp_path), is NOT "' . TYPO3_mainDir . '" for some reason.<br />
148 You may have a strange server configuration.
149 Or maybe you didn\'t set constant TYPO3_MOD_PATH in your module?';
150 }
151 echo '</strong></font>';
152
153 echo '<br /><br />If you want to debug this issue, please edit typo3/init.php of your TYPO3 source and search for the die() call right after this line (search for this text to find)...';
154
155 // Remove this line if you want to debug this problem a little more...
156 die();
157 echo '<br /><br /><strong>If you expect any help from anybody on this issue, you should save this page as an html document and send it along with your request for help!</strong>';
158 echo '<hr /><pre>';
159 print_r(array(
160 'TYPO3_OS'=>TYPO3_OS,
161 'PATH_thisScript'=>PATH_thisScript,
162 'php_sapi_name()'=>PHP_SAPI,
163 'TYPO3_MOD_PATH'=>TYPO3_MOD_PATH,
164 'PATH_TRANSLATED'=>$_SERVER['PATH_TRANSLATED'],
165 'SCRIPT_FILENAME'=>$_SERVER['SCRIPT_FILENAME']
166 ));
167 echo '</pre><hr />';
168 phpinfo();
169 exit;
170 } else {
171 define('PATH_typo3', $temp_path); // Abs. path of the TYPO3 admin dir (PATH_site + TYPO3_mainDir).
172 define('PATH_typo3_mod', $temp_modPath); // Relative path (from the PATH_typo3) to a properly configured module
173 define('PATH_site', substr(PATH_typo3,0,-strlen(TYPO3_mainDir))); // Abs. path to directory with the frontend (one above the admin-dir)
174 $temp_path_t3lib = @is_dir(PATH_site.'t3lib/') ? PATH_site.'t3lib/' : PATH_typo3.'t3lib/';
175 define('PATH_t3lib', $temp_path_t3lib); // Abs. path to t3lib/ (general TYPO3 library) within the TYPO3 admin dir
176 define('PATH_typo3conf', PATH_site.'typo3conf/'); // Abs. TYPO3 configuration path (local, not part of source)
177
178 if (!defined('PATH_tslib')) {
179 if (@is_dir(PATH_site . TYPO3_mainDir . 'sysext/cms/tslib/')) {
180 define('PATH_tslib', PATH_site . TYPO3_mainDir . 'sysext/cms/tslib/');
181 } elseif (@is_dir(PATH_site . 'tslib/')) {
182 define('PATH_tslib', PATH_site . 'tslib/');
183 }
184 }
185 }
186
187 // *********************
188 // Unset variable(s) in global scope (fixes #13959)
189 // *********************
190 unset($error);
191
192 // *************************************************
193 // t3lib_div + extention management class included
194 // *************************************************
195 require_once(PATH_t3lib.'class.t3lib_div.php'); // The standard-library is included
196 require_once(PATH_t3lib.'class.t3lib_extmgm.php'); // Extension API Management library included
197
198 // ****************************************************
199 // Include configuration (localconf + ext_localconf)
200 // ****************************************************
201 require(PATH_t3lib.'config_default.php');
202 if (!defined ('TYPO3_db')) die ('The configuration file was not included.');
203
204
205
206
207 // *********************
208 // Error & Exception handling
209 // *********************
210 if ($TYPO3_CONF_VARS['SC_OPTIONS']['errors']['exceptionHandler'] !== '') {
211 if ($TYPO3_CONF_VARS['SYS']['errorHandler'] !== '') {
212 // register an error handler for the given errorHandlerErrors
213 $errorHandler = t3lib_div::makeInstance($TYPO3_CONF_VARS['SYS']['errorHandler'], $TYPO3_CONF_VARS['SYS']['errorHandlerErrors']);
214 // set errors which will be converted in an exception
215 $errorHandler->setExceptionalErrors($TYPO3_CONF_VARS['SC_OPTIONS']['errors']['exceptionalErrors']);
216 }
217 $exceptionHandler = t3lib_div::makeInstance($TYPO3_CONF_VARS['SC_OPTIONS']['errors']['exceptionHandler']);
218 }
219
220 /** @var TYPO3_DB t3lib_db */
221 $TYPO3_DB = t3lib_div::makeInstance('t3lib_DB');
222 $TYPO3_DB->debugOutput = $TYPO3_CONF_VARS['SYS']['sqlDebug'];
223
224 $CLIENT = t3lib_div::clientInfo(); // $CLIENT includes information about the browser/user-agent
225 $PARSETIME_START = t3lib_div::milliseconds(); // Is set to the system time in milliseconds. This could be used to output script parsetime in the end of the script
226
227
228 // *************************
229 // CLI dispatch processing
230 // *************************
231 if ((TYPO3_REQUESTTYPE & TYPO3_REQUESTTYPE_CLI) && basename(PATH_thisScript) == 'cli_dispatch.phpsh') {
232 // First, take out the first argument (cli-key)
233 $temp_cliScriptPath = array_shift($_SERVER['argv']);
234 $temp_cliKey = array_shift($_SERVER['argv']);
235 array_unshift($_SERVER['argv'],$temp_cliScriptPath);
236
237 // If cli_key was found in configuration, then set up the cliInclude path and module name:
238 if ($temp_cliKey) {
239 if (is_array($TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys'][$temp_cliKey])) {
240 define('TYPO3_cliInclude', t3lib_div::getFileAbsFileName($TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys'][$temp_cliKey][0]));
241 $MCONF['name'] = $TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys'][$temp_cliKey][1];
242 } else {
243 echo "The supplied 'cliKey' was not valid. Please use one of the available from this list:\n\n";
244 print_r(array_keys($TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys']));
245 echo LF;
246 exit;
247 }
248 } else {
249 echo "Please supply a 'cliKey' as first argument. The following are available:\n\n";
250 print_r($TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys']);
251 echo LF;
252 exit;
253 }
254 }
255
256
257 // **********************
258 // Check Hardcoded lock on BE:
259 // **********************
260 if ($TYPO3_CONF_VARS['BE']['adminOnly'] < 0) {
261 throw new RuntimeException('TYPO3 Backend locked: Backend and Install Tool are locked for maintenance. [BE][adminOnly] is set to "' . intval($TYPO3_CONF_VARS['BE']['adminOnly']) . '".', 1294586847);
262 }
263 if (!(TYPO3_REQUESTTYPE & TYPO3_REQUESTTYPE_CLI) && @is_file(PATH_typo3conf . 'LOCK_BACKEND')) {
264 if (TYPO3_PROCEED_IF_NO_USER == 2) {
265 // ajax poll for login, let him pass
266 } else {
267 $fContent = t3lib_div::getUrl(PATH_typo3conf.'LOCK_BACKEND');
268 if ($fContent) {
269 header('Location: '.$fContent); // Redirect
270 } else {
271 throw new RuntimeException('TYPO3 Backend locked: Browser backend is locked for maintenance. Remove lock by removing the file "typo3conf/LOCK_BACKEND" or use CLI-scripts.', 1294586848);
272 }
273 exit;
274 }
275
276 }
277
278 // **********************
279 // Check IP
280 // **********************
281 if (trim($TYPO3_CONF_VARS['BE']['IPmaskList']) && !(TYPO3_REQUESTTYPE & TYPO3_REQUESTTYPE_CLI)) {
282 if (!t3lib_div::cmpIP(t3lib_div::getIndpEnv('REMOTE_ADDR'), $TYPO3_CONF_VARS['BE']['IPmaskList'])) {
283 header('Status: 404 Not Found'); // Send Not Found header - if the webserver can make use of it...
284 header('Location: http://'); // Just point us away from here...
285 exit; // ... and exit good!
286 }
287 }
288
289
290 // **********************
291 // Check SSL (https)
292 // **********************
293 if (intval($TYPO3_CONF_VARS['BE']['lockSSL']) && !(TYPO3_REQUESTTYPE & TYPO3_REQUESTTYPE_CLI)) {
294 if(intval($TYPO3_CONF_VARS['BE']['lockSSLPort'])) {
295 $sslPortSuffix = ':'.intval($TYPO3_CONF_VARS['BE']['lockSSLPort']);
296 } else {
297 $sslPortSuffix = '';
298 }
299 if ($TYPO3_CONF_VARS['BE']['lockSSL'] == 3) {
300 $requestStr = substr(t3lib_div::getIndpEnv('TYPO3_REQUEST_SCRIPT'), strlen(t3lib_div::getIndpEnv('TYPO3_SITE_URL').TYPO3_mainDir));
301 if($requestStr == 'index.php' && !t3lib_div::getIndpEnv('TYPO3_SSL')) {
302 list(,$url) = explode('://',t3lib_div::getIndpEnv('TYPO3_REQUEST_URL'),2);
303 list($server,$address) = explode('/',$url,2);
304 header('Location: https://'.$server.$sslPortSuffix.'/'.$address);
305 exit;
306 }
307 } elseif (!t3lib_div::getIndpEnv('TYPO3_SSL') ) {
308 if ($TYPO3_CONF_VARS['BE']['lockSSL'] == 2) {
309 list(,$url) = explode('://',t3lib_div::getIndpEnv('TYPO3_SITE_URL').TYPO3_mainDir,2);
310 list($server,$address) = explode('/',$url,2);
311 header('Location: https://'.$server.$sslPortSuffix.'/'.$address);
312 } else {
313 header('Status: 404 Not Found'); // Send Not Found header - if the webserver can make use of it...
314 header('Location: http://'); // Just point us away from here...
315 }
316 exit; // ... and exit good!
317 }
318 }
319
320
321 // *******************************
322 // Checking environment
323 // *******************************
324 if (isset($_POST['GLOBALS']) || isset($_GET['GLOBALS'])) die('You cannot set the GLOBALS-array from outside the script.');
325 if (!get_magic_quotes_gpc()) {
326 t3lib_div::addSlashesOnArray($_GET);
327 t3lib_div::addSlashesOnArray($_POST);
328 $HTTP_GET_VARS = $_GET;
329 $HTTP_POST_VARS = $_POST;
330 }
331
332
333 // ********************************************
334 // Check if the install script should be run:
335 // ********************************************
336 if (TYPO3_REQUESTTYPE & TYPO3_REQUESTTYPE_INSTALL) {
337 if(!t3lib_extMgm::isLoaded('install')) {
338 die('Install Tool is not loaded as an extension.<br />You must add the key "install" to the list of installed extensions in typo3conf/localconf.php, $TYPO3_CONF_VARS[\'EXT\'][\'extList\'].');
339 }
340
341 require_once(t3lib_extMgm::extPath('install').'mod/class.tx_install.php');
342 $install_check = t3lib_div::makeInstance('tx_install');
343 $install_check->allowUpdateLocalConf = 1;
344 $install_check->init();
345 exit;
346 }
347
348
349 // *************************
350 // Connect to the database
351 // *************************
352 // Redirect to install tool if database host and database are not defined
353 if (!TYPO3_db_host && !TYPO3_db) {
354 t3lib_utility_Http::redirect('install/index.php?mode=123&step=1&password=joh316');
355 } else {
356 $TYPO3_DB->connectDB();
357 }
358
359
360 // *******************************
361 // Checks for proper browser
362 // *******************************
363 if (!$CLIENT['BROWSER'] && !(TYPO3_REQUESTTYPE & TYPO3_REQUESTTYPE_CLI)) {
364 throw new RuntimeException('Browser Error: Your browser version looks incompatible with this TYPO3 version!', 1294587023);
365 }
366
367
368 // ****************************************************
369 // Include tables customization (tables + ext_tables)
370 // ****************************************************
371 include (TYPO3_tables_script ? PATH_typo3conf.TYPO3_tables_script : PATH_t3lib.'stddb/tables.php');
372 // Extension additions
373 if ($TYPO3_LOADED_EXT['_CACHEFILE']) {
374 include (PATH_typo3conf.$TYPO3_LOADED_EXT['_CACHEFILE'].'_ext_tables.php');
375 } else {
376 include (PATH_t3lib.'stddb/load_ext_tables.php');
377 }
378 // extScript
379 if (TYPO3_extTableDef_script) {
380 include (PATH_typo3conf.TYPO3_extTableDef_script);
381 }
382
383 // load TYPO3 SpriteGenerating API
384 $spriteManager = t3lib_div::makeInstance('t3lib_SpriteManager', TRUE);
385 $spriteManager->loadCacheFile();
386
387
388 // *******************************
389 // BackEnd User authentication
390 // *******************************
391 /*
392 NOTICE:
393 if constant TYPO3_PROCEED_IF_NO_USER is defined TRUE (in the mainscript), this script will return even though a user did not log in!
394 */
395 $BE_USER = t3lib_div::makeInstance('t3lib_beUserAuth'); // New backend user object
396 $BE_USER->warningEmail = $TYPO3_CONF_VARS['BE']['warning_email_addr'];
397 $BE_USER->lockIP = $TYPO3_CONF_VARS['BE']['lockIP'];
398 $BE_USER->auth_timeout_field = intval($TYPO3_CONF_VARS['BE']['sessionTimeout']);
399 $BE_USER->OS = TYPO3_OS;
400 if (TYPO3_REQUESTTYPE & TYPO3_REQUESTTYPE_CLI) {
401 $BE_USER->dontSetCookie = TRUE;
402 }
403 $BE_USER->start(); // Object is initialized
404 $BE_USER->checkCLIuser();
405 $BE_USER->backendCheckLogin(); // Checking if there's a user logged in
406
407 // Setting the web- and filemount global vars:
408 $WEBMOUNTS = $BE_USER->returnWebmounts(); // ! WILL INCLUDE deleted mount pages as well!
409 $FILEMOUNTS = $BE_USER->returnFilemounts();
410
411 // *******************************
412 // $GLOBALS['LANG'] initialisation
413 // *******************************
414 // $GLOBALS needed here ?? we still are in the global scope.
415
416 $GLOBALS['LANG'] = t3lib_div::makeInstance('language');
417 $GLOBALS['LANG']->init($BE_USER->uc['lang']);
418
419
420 // ****************
421 // CLI processing
422 // ****************
423 if (TYPO3_REQUESTTYPE & TYPO3_REQUESTTYPE_CLI) {
424 // Status output:
425 if (!strcmp($_SERVER['argv'][1],'status')) {
426 echo "Status of TYPO3 CLI script:\n\n";
427 echo "Username [uid]: ".$BE_USER->user['username']." [".$BE_USER->user['uid']."]\n";
428 echo "Database: ".TYPO3_db.LF;
429 echo "PATH_site: ".PATH_site.LF;
430 echo LF;
431 exit;
432 }
433 }
434
435 // ****************
436 // compression
437 // ****************
438 ob_clean();
439 if (extension_loaded('zlib') && $TYPO3_CONF_VARS['BE']['compressionLevel']) {
440 if (t3lib_utility_Math::canBeInterpretedAsInteger($TYPO3_CONF_VARS['BE']['compressionLevel'])) {
441 @ini_set('zlib.output_compression_level', $TYPO3_CONF_VARS['BE']['compressionLevel']);
442 }
443 ob_start('ob_gzhandler');
444 }
445
446 ?>