2 /***************************************************************
5 * (c) 1999-2005 Kasper Skaarhoj (kasperYYYY@typo3.com)
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.
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.
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.
25 * This copyright notice MUST APPEAR in all copies of the script!
26 ***************************************************************/
28 * TYPO3 Backend initialization
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
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.
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
49 * For a detailed description of this script, the scope of constants and variables in it,
50 * please refer to the document "Inside TYPO3"
53 * Revised for TYPO3 3.6 2/2003 by Kasper Skaarhoj
55 * @author Kasper Skaarhoj <kasperYYYY@typo3.com>
61 // *******************************
62 // Set error reporting
63 // *******************************
64 error_reporting (E_ALL ^ E_NOTICE
);
67 // *******************************
69 // *******************************
70 define('TYPO3_OS', stristr(PHP_OS
,'win')&&!stristr(PHP_OS
,'darwin')?
'WIN':'');
71 define('TYPO3_MODE','BE');
72 define('PATH_thisScript',str_replace('//','/', str_replace('\\','/', (php_sapi_name()=='cgi'||
php_sapi_name()=='isapi' ||
php_sapi_name()=='cgi-fcgi')&&($_SERVER['ORIG_PATH_TRANSLATED']?
$_SERVER['ORIG_PATH_TRANSLATED']:$_SERVER['PATH_TRANSLATED'])?
($_SERVER['ORIG_PATH_TRANSLATED']?
$_SERVER['ORIG_PATH_TRANSLATED']:$_SERVER['PATH_TRANSLATED']):($_SERVER['ORIG_SCRIPT_FILENAME']?
$_SERVER['ORIG_SCRIPT_FILENAME']:$_SERVER['SCRIPT_FILENAME']))));
73 define('TYPO3_mainDir', 'typo3/'); // This is the directory of the backend administration for the sites of this TYPO3 installation.
76 // *******************************
78 // *******************************
79 $temp_path = str_replace('\\','/',dirname(PATH_thisScript
).'/');
81 // If TYPO3_MOD_PATH is defined we must calculate the modPath since init.php must be included by a module
82 if (substr($temp_path,-strlen(TYPO3_mainDir
))!=TYPO3_mainDir
) {
83 if (defined('TYPO3_MOD_PATH')) {
84 if (substr($temp_path,-strlen(TYPO3_MOD_PATH
))==TYPO3_MOD_PATH
) {
85 $temp_path=substr($temp_path,0,-strlen(TYPO3_MOD_PATH
));
86 $temp_modPath=TYPO3_MOD_PATH
;
87 } elseif (substr(TYPO3_MOD_PATH
,0,13)=='../typo3conf/' && (substr(TYPO3_MOD_PATH
,3)==substr($temp_path,-strlen(substr(TYPO3_MOD_PATH
,3))))) {
88 $temp_path = substr($temp_path,0,-strlen(substr(TYPO3_MOD_PATH
,3))).TYPO3_mainDir
;
89 $temp_modPath=TYPO3_MOD_PATH
;
91 if (!@is_dir
($temp_path)) {
97 // OUTPUT error message and exit if there are problems with the path. Otherwise define constants and continue.
98 if (!$temp_path ||
substr($temp_path,-strlen(TYPO3_mainDir
))!=TYPO3_mainDir
) { // This must be the case in order to proceed
99 if (TYPO3_OS
=='WIN') {
100 $thisPath_base = basename(substr($temp_path,-strlen(TYPO3_mainDir
)));
101 $mainPath_base = basename(TYPO3_mainDir
);
102 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!!
103 $script_name = (php_sapi_name()=='cgi'||
php_sapi_name()=='cgi-fcgi')&&($_SERVER['ORIG_PATH_INFO']?
$_SERVER['ORIG_PATH_INFO']:$_SERVER['PATH_INFO']) ?
($_SERVER['ORIG_PATH_INFO']?
$_SERVER['ORIG_PATH_INFO']:$_SERVER['PATH_INFO']) : ($_SERVER['ORIG_SCRIPT_NAME']?
$_SERVER['ORIG_SCRIPT_NAME']:$_SERVER['SCRIPT_NAME']); // Copied from t3lib_div::getIndpEnv()
104 header('Location: '.str_replace($thisPath_base, $mainPath_base, $script_name));
109 echo ('Error in init.php: Path to TYPO3 main dir could not be resolved correctly. <br /><br />
110 This happens if the last '.strlen(TYPO3_mainDir
).' characters of this path, '.$temp_path.', (\$temp_path) is NOT "'.TYPO3_mainDir
.'" for some reason. <br />
111 You may have a strange server configuration.
112 Or maybe you didn\'t set constant TYPO3_MOD_PATH in your module?');
113 echo '<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>';
114 if (strstr($temp_path,'typo3_src')) {
115 echo '<br /><font color="red"><strong> It seems you are trying to run the TYPO3 source libraries DIRECTLY! You cannot do that. Please read the installation documents for more information.<br />
116 However here is a little tip for now: Download one of the zip-file "packages", eg the "testsite" or "dummy" package.</strong></font>';
120 'TYPO3_OS'=>TYPO3_OS
,
121 'PATH_thisScript'=>PATH_thisScript
,
122 'php_sapi_name()'=>php_sapi_name(),
123 'TYPO3_MOD_PATH'=>TYPO3_MOD_PATH
,
124 'PATH_TRANSLATED'=>$_SERVER['PATH_TRANSLATED'],
125 'SCRIPT_FILENAME'=>$_SERVER['SCRIPT_FILENAME']
131 define('PATH_typo3', $temp_path); // Abs. path of the TYPO3 admin dir (PATH_site + TYPO3_mainDir).
132 define('PATH_typo3_mod', $temp_modPath); // Relative path (from the PATH_typo3) to a properly configured module
133 define('PATH_site', substr(PATH_typo3
,0,-strlen(TYPO3_mainDir
))); // Abs. path to directory with the frontend (one above the admin-dir)
134 $temp_path_t3lib = @is_dir
(PATH_site
.'t3lib/') ? PATH_site
.'t3lib/' : PATH_typo3
.'t3lib/';
135 define('PATH_t3lib', $temp_path_t3lib); // Abs. path to t3lib/ (general TYPO3 library) within the TYPO3 admin dir
136 define('PATH_typo3conf', PATH_site
.'typo3conf/'); // Abs. TYPO3 configuration path (local, not part of source)
140 // *************************************************
141 // t3lib_div + extention management class included
142 // *************************************************
143 require_once(PATH_t3lib
.'class.t3lib_div.php'); // The standard-library is included
144 require_once(PATH_t3lib
.'class.t3lib_extmgm.php'); // Extension API Management library included
146 // ****************************************************
147 // Include configuration (localconf + ext_localconf)
148 // ****************************************************
149 require(PATH_t3lib
.'config_default.php');
150 if (!defined ('TYPO3_db')) die ('The configuration file was not included.');
152 require_once(PATH_t3lib
.'class.t3lib_db.php'); // The database library
153 $TYPO3_DB = t3lib_div
::makeInstance('t3lib_DB');
154 $TYPO3_DB->debugOutput
= $TYPO3_CONF_VARS['SYS']['sqlDebug'];
156 $CLIENT = t3lib_div
::clientInfo(); // $CLIENT includes information about the browser/user-agent
157 $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
162 // *************************
163 // CLI dispatch processing
164 // *************************
165 if (defined('TYPO3_cliMode') && TYPO3_cliMode´
&& basename(PATH_thisScript
)=='cli_dispatch.phpsh') {
166 // First, take out the first argument (cli-key)
167 $temp_cliScriptPath = array_shift($_SERVER['argv']);
168 $temp_cliKey = array_shift($_SERVER['argv']);
169 array_unshift($_SERVER['argv'],$temp_cliScriptPath);
171 // If cli_key was found in configuration, then set up the cliInclude path and module name:
173 if (is_array($TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys'][$temp_cliKey])) {
174 define('TYPO3_cliInclude', t3lib_div
::getFileAbsFileName($TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys'][$temp_cliKey][0]));
175 $MCONF['name'] = $TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys'][$temp_cliKey][1];
177 echo "The supplied 'cliKey' was not valid. Please use one of the available from this list:\n\n";
178 print_r(array_keys($TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys']));
183 echo "Please supply a 'cliKey' as first argument. The following are available:\n\n";
184 print_r($TYPO3_CONF_VARS['SC_OPTIONS']['GLOBAL']['cliKeys']);
192 // *********************
193 // Libraries included
194 // *********************
195 require_once(PATH_t3lib
.'class.t3lib_userauth.php');
196 require_once(PATH_t3lib
.'class.t3lib_userauthgroup.php');
197 require_once(PATH_t3lib
.'class.t3lib_beuserauth.php');
198 require_once(PATH_t3lib
.'class.t3lib_iconworks.php');
199 require_once(PATH_t3lib
.'class.t3lib_befunc.php');
200 require_once(PATH_t3lib
.'class.t3lib_cs.php');
202 // **********************
203 // Check Hardcoded lock on BE:
204 // **********************
205 if ($TYPO3_CONF_VARS['BE']['adminOnly'] < 0) {
206 header('Status: 404 Not Found'); // Send Not Found header - if the webserver can make use of it...
207 header('Location: http://'); // Just point us away from here...
208 exit; // ... and exit good!
211 // **********************
213 // **********************
214 if (trim($TYPO3_CONF_VARS['BE']['IPmaskList'])) {
215 if (!t3lib_div
::cmpIP(t3lib_div
::getIndpEnv('REMOTE_ADDR'), $TYPO3_CONF_VARS['BE']['IPmaskList'])) {
216 header('Status: 404 Not Found'); // Send Not Found header - if the webserver can make use of it...
217 header('Location: http://'); // Just point us away from here...
218 exit; // ... and exit good!
223 // **********************
225 // **********************
226 if (intval($TYPO3_CONF_VARS['BE']['lockSSL']) && !(defined('TYPO3_cliMode') && TYPO3_cliMode
)) {
227 if ($TYPO3_CONF_VARS['BE']['lockSSL'] == 3) {
228 $requestStr = substr(t3lib_div
::getIndpEnv('TYPO3_REQUEST_SCRIPT'), strlen(t3lib_div
::getIndpEnv('TYPO3_SITE_URL').TYPO3_mainDir
));
229 if($requestStr == 'index.php' && !t3lib_div
::getIndpEnv('TYPO3_SSL')) {
230 list(,$url) = explode('://',t3lib_div
::getIndpEnv('TYPO3_REQUEST_URL'),2);
231 header('Location: https://'.$url);
233 } elseif (!t3lib_div
::getIndpEnv('TYPO3_SSL') ) {
234 if ($TYPO3_CONF_VARS['BE']['lockSSL'] == 2) {
235 list(,$url) = explode('://',t3lib_div
::getIndpEnv('TYPO3_SITE_URL').TYPO3_mainDir
,2);
236 header('Location: https://'.$url); // Just point us away from here...
238 header('Status: 404 Not Found'); // Send Not Found header - if the webserver can make use of it...
239 header('Location: http://'); // Just point us away from here...
241 exit; // ... and exit good!
246 // *******************************
247 // Checking environment
248 // *******************************
249 if (t3lib_div
::int_from_ver(phpversion())<4001000) die ('TYPO3 runs with PHP4.1.0+ only');
250 if (isset($_POST['GLOBALS']) ||
isset($_GET['GLOBALS'])) die('You cannot set the GLOBALS-array from outside the script.');
251 if (!get_magic_quotes_gpc()) {
252 t3lib_div
::addSlashesOnArray($_GET);
253 t3lib_div
::addSlashesOnArray($_POST);
254 $HTTP_GET_VARS = $_GET;
255 $HTTP_POST_VARS = $_POST;
259 // ********************************************
260 // Check if the install script should be run:
261 // ********************************************
262 if (defined('TYPO3_enterInstallScript') && TYPO3_enterInstallScript
) {
263 if (!t3lib_extMgm
::isLoaded('install')) 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"].');
265 require_once(t3lib_extMgm
::extPath('install').'mod/class.tx_install.php');
266 $install_check = t3lib_div
::makeInstance('tx_install');
267 $install_check->allowUpdateLocalConf
= 1;
268 $install_check->init();
273 // *************************
274 // Connect to the database
275 // *************************
276 if ($GLOBALS['TYPO3_DB']->sql_pconnect(TYPO3_db_host
, TYPO3_db_username
, TYPO3_db_password
)) {
278 t3lib_BEfunc
::typo3PrintError ('No database selected','Database Error');
280 } elseif (!$GLOBALS['TYPO3_DB']->sql_select_db(TYPO3_db
)) {
281 t3lib_BEfunc
::typo3PrintError ('Cannot connect to the current database, "'.TYPO3_db
.'"','Database Error');
285 t3lib_BEfunc
::typo3PrintError ('The current username, password or host was not accepted when the connection to the database was attempted to be established!','Database Error');
290 // *******************************
291 // Checks for proper browser
292 // *******************************
293 if (!$CLIENT['BROWSER'] && !(defined('TYPO3_cliMode') && TYPO3_cliMode
)) {
294 t3lib_BEfunc
::typo3PrintError ('Browser error','You must use 4+ browsers with TYPO3!',0);
299 // ****************************************************
300 // Include tables customization (tables + ext_tables)
301 // ****************************************************
302 include (TYPO3_tables_script ? PATH_typo3conf
.TYPO3_tables_script
: PATH_t3lib
.'stddb/tables.php');
303 // Extension additions
304 if ($TYPO3_LOADED_EXT['_CACHEFILE']) {
305 include (PATH_typo3conf
.$TYPO3_LOADED_EXT['_CACHEFILE'].'_ext_tables.php');
307 include (PATH_t3lib
.'stddb/load_ext_tables.php');
310 if (TYPO3_extTableDef_script
) {
311 include (PATH_typo3conf
.TYPO3_extTableDef_script
);
316 // *******************************
317 // BackEnd User authentication
318 // *******************************
321 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!
323 $BE_USER = t3lib_div
::makeInstance('t3lib_beUserAuth'); // New backend user object
324 $BE_USER->warningEmail
= $TYPO3_CONF_VARS['BE']['warning_email_addr'];
325 $BE_USER->lockIP
= $TYPO3_CONF_VARS['BE']['lockIP'];
326 $BE_USER->auth_timeout_field
= intval($TYPO3_CONF_VARS['BE']['sessionTimeout']);
327 $BE_USER->OS
= TYPO3_OS
;
328 $BE_USER->start(); // Object is initialized
329 $BE_USER->checkCLIuser();
330 $BE_USER->backendCheckLogin(); // Checking if there's a user logged in
331 $BE_USER->trackBeUser($TYPO3_CONF_VARS['BE']['trackBeUser']); // Tracking backend user script hits
333 // Setting the web- and filemount global vars:
334 $WEBMOUNTS = $BE_USER->returnWebmounts(); // ! WILL INCLUDE deleted mount pages as well!
335 $FILEMOUNTS = $BE_USER->returnFilemounts();
341 if (defined('TYPO3_cliMode') && TYPO3_cliMode
) {
343 if (!strcmp($_SERVER['argv'][1],'status')) {
344 echo "Status of TYPO3 CLI script:\n\n";
345 echo "Username [uid]: ".$BE_USER->user
['username']." [".$BE_USER->user
['uid']."]\n";
346 echo "Database: ".TYPO3_db
."\n";
347 echo "PATH_site: ".PATH_site
."\n";
356 if ($TYPO3_CONF_VARS['BE']['compressionLevel']) {
358 require_once (PATH_t3lib
.'class.gzip_encode.php');