X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=src%2Fconfigtest.php;h=431904bc072f64324f0f8d2875ec338dcca6ceb4;hp=224db87a40448e1351ec68e0e96b646201c2ab19;hb=dc528046c09b177b3f7bdc55c3540c91383d7730;hpb=daa0c5b8d740d8214008924c89e472897cddce89 diff --git a/src/configtest.php b/src/configtest.php index 224db87a..431904bc 100644 --- a/src/configtest.php +++ b/src/configtest.php @@ -196,9 +196,25 @@ if(!check_php_version(4,1,0)) { echo $IND . 'PHP version ' . PHP_VERSION . ' OK. (You have: ' . phpversion() . ". Minimum: 4.1.0)
\n"; +echo $IND . 'display_errors: ' . ini_get('display_errors') . "
\n"; + +echo $IND . 'error_reporting: ' . ini_get('error_reporting') . "
\n"; + +$safe_mode = ini_get('safe_mode'); +if ($safe_mode) { + echo $IND . 'safe_mode: ' . $safe_mode; + if (empty($prefs_dsn) || empty($addrbook_dsn)) + echo ' (double check data and attachment directory ownership, etc!)'; + if (!empty($addrbook_dsn) || !empty($prefs_dsn) || !empty($addrbook_global_dsn)) + echo ' (does PHP have access to database interface?)'; + echo "
\n"; + $safe_mode_exec_dir = ini_get('safe_mode_exec_dir'); + echo $IND . 'safe_mode_exec_dir: ' . $safe_mode_exec_dir . "
\n"; +} + /* register_globals check: test for boolean false and any string that is not equal to 'off' */ -if ((bool) ini_get('register_globals') && +if ((bool) ini_get('register_globals') && strtolower(ini_get('register_globals'))!='off') { do_err('You have register_globals turned on. This is not an error, but it CAN be a security hazard. Consider turning register_globals off.', false); } @@ -207,7 +223,7 @@ if ((bool) ini_get('register_globals') && /* variables_order check */ // FIXME(?): Hmm, how do we distinguish between when an ini setting is -// not available (ini_set() returns empty string) and when +// not available (ini_set() returns empty string) and when // the administrator set the value to an empty string? The // latter is sure to be highly rare, so for now, just assume // that empty value means the setting isn't even available @@ -231,7 +247,7 @@ else if (strpos($variables_order, 'G') === FALSE if (!check_php_version(5)) { // FIXME(?): Hmm, how do we distinguish between when an ini setting is - // not available (ini_set() returns empty string) and when + // not available (ini_set() returns empty string) and when // the administrator set the value to an empty string? The // latter is sure to be highly rare, so for now, just assume // that empty value means the setting isn't even available @@ -291,6 +307,17 @@ if ( get_magic_quotes_runtime() || get_magic_quotes_gpc() || do_err($magic_quotes_warning,false); } +if (ini_get('short_open_tag') == 0) { + $short_open_tag_warning = 'You have configured PHP not to allow short tags ' + . '(short_open_tag=off). This shouldn\'t be a problem with ' + . 'SquirrelMail or any plugin coded coded according to the ' + . 'SquirrelMail Coding Guidelines, but if you experience problems with ' + . 'PHP code being displayed in some of the pages and changing setting ' + . 'to "on" solves the problem, please file a bug report against the ' + . 'failing plugin. The correct contact information is most likely ' + . 'to be found in the plugin documentation.'; + do_err($short_open_tag_warning, false); +} /* checking paths */ @@ -298,7 +325,7 @@ echo "Checking paths...
\n"; if(!file_exists($data_dir)) { // data_dir is not that important in db_setups. - if (isset($prefs_dsn) && ! empty($prefs_dsn)) { + if (!empty($prefs_dsn)) { $data_dir_error = "Data dir ($data_dir) does not exist!\n"; echo $IND .'ERROR: ' . $data_dir_error; } else { @@ -307,7 +334,7 @@ if(!file_exists($data_dir)) { } // don't check if errors if(!isset($data_dir_error) && !is_dir($data_dir)) { - if (isset($prefs_dsn) && ! empty($prefs_dsn)) { + if (!empty($prefs_dsn)) { $data_dir_error = "Data dir ($data_dir) is not a directory!\n"; echo $IND . 'ERROR: ' . $data_dir_error; } else { @@ -316,7 +343,7 @@ if(!isset($data_dir_error) && !is_dir($data_dir)) { } // datadir should be executable - but no clean way to test on that if(!isset($data_dir_error) && !is_writable($data_dir)) { - if (isset($prefs_dsn) && ! empty($prefs_dsn)) { + if (!empty($prefs_dsn)) { $data_dir_error = "Data dir ($data_dir) is not writable!\n"; echo $IND . 'ERROR: ' . $data_dir_error; } else { @@ -411,7 +438,7 @@ if (isset($plugins[0])) { $plugin_load_error = 'Some output is produced when plugins are loaded. Usually this means there is an error in one of the plugin setup or configuration files. The output was: '.htmlspecialchars($output); do_err($plugin_load_error); } - /** + /** * Print plugin versions */ echo $IND . "Plugin versions...
\n"; @@ -420,7 +447,7 @@ if (isset($plugins[0])) { $english_name = get_plugin_requirement($name, 'english_name'); echo $IND . $IND . (empty($english_name) ? $name . ' ' : $english_name . ' (' . $name . ') ') . (empty($plugin_version) ? '??' : $plugin_version) . "
\n"; - // check if this plugin has any other plugin + // check if this plugin has any other plugin // dependencies and if they are satisfied // $failed_dependencies = check_plugin_dependencies($name); @@ -437,7 +464,7 @@ if (isset($plugins[0])) { } /** - * This hook was added in 1.5.2 and 1.4.10. Each plugins should print an error + * This hook was added in 1.5.2 and 1.4.10. Each plugins should print an error * message and return TRUE if there are any errors in its setup/configuration. */ $plugin_err = boolean_hook_function('configtest', $null, 1); @@ -558,7 +585,7 @@ if($useSendmail) { break; } } else { - // + // $ehlo_error = true; $ehlo[]=$line; break; @@ -859,7 +886,7 @@ if($addrbook_dsn || $prefs_dsn || $addrbook_global_dsn) { } else { $db_error='Required PHP PEAR DB support is not available.' .' Is PEAR installed and is the include path set correctly to find DB.php?' - .' The include path is now:' . ini_get('include_path') . '.'; + .' The include path is now: "' . ini_get('include_path') . '".'; do_err($db_error); } } else {