// This script could really use some restructuring as it has grown quite rapidly
// but is not very 'clean'. Feel free to get some structure into this thing.
-
-function do_err($str, $exit = TRUE) {
- global $IND;
- echo '<p>'.$IND.'<font color="red"><b>ERROR:</b></font> ' .$str. "</p>\n";
- if($exit) {
- echo '</body></html>';
- exit;
+$warnings = 0;
+
+function do_err($str, $fatal = TRUE) {
+ global $IND, $warnings;
+ $level = $fatal ? 'FATAL ERROR:' : 'WARNING:';
+ echo '<p>'.$IND.'<font color="red"><b>' . $level . '</b></font> ' .$str. "</p>\n";
+ if($fatal) {
+ echo '</body></html>';
+ exit;
+ } else {
+ $warnings++;
}
}
* later.
*/
if (file_exists(SM_PATH . 'config/config.php')) {
- include(SM_PATH . 'config/config.php');
- include(SM_PATH . 'functions/strings.php');
+ require(SM_PATH . 'config/config.php');
}
-?><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
+require(SM_PATH . 'functions/global.php');
+require(SM_PATH . 'functions/strings.php');
+
+/**
+ * get_location starts session and must be run before output is started.
+ */
+$test_location = get_location();
+
+?><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
+ "http://www.w3.org/TR/1999/REC-html401-19991224/loose.dtd">
<html>
<head>
- <meta name="robots" content="noindex,nofollow">
- <title>SquirrelMail configtest</title>
+ <meta name="robots" content="noindex,nofollow">
+ <title>SquirrelMail configtest</title>
</head>
<body>
<h1>SquirrelMail configtest</h1>
if(!in_array('config.php', $included)) {
if(!file_exists(SM_PATH . 'config/config.php')) {
do_err('Config file '.SM_PATH . 'config/config.php does not exist!<br />'.
- 'You need to run <tt>conf.pl</tt> first.');
+ 'You need to run <tt>conf.pl</tt> first.');
}
do_err('Could not read '.SM_PATH.'config/config.php! Check file permissions.');
}
if(!in_array('strings.php', $included)) {
do_err('Could not include '.SM_PATH.'functions/strings.php!<br />'.
- 'Check permissions on that file.');
+ 'Check permissions on that file.');
}
/* Block remote use of script */
sqGetGlobalVar('SERVER_ADDR',$server_ip,SQ_SERVER);
if ((! isset($client_ip) || $client_ip!='127.0.0.1') &&
- (! isset($client_ip) || ! isset($server_ip) || $client_ip!=$server_ip)) {
+ (! isset($client_ip) || ! isset($server_ip) || $client_ip!=$server_ip)) {
do_err('Enable "Allow remote configtest" option in squirrelmail configuration in order to use this script.');
}
}
/* checking PHP specs */
echo "<p><table>\n<tr><td>SquirrelMail version:</td><td><b>" . $version . "</b></td></tr>\n" .
- '<tr><td>Config file version:</td><td><b>' . $config_version . "</b></td></tr>\n" .
- '<tr><td>Config file last modified:</td><td><b>' .
- date ('d F Y H:i:s', filemtime(SM_PATH . 'config/config.php')) .
- "</b></td></tr>\n</table>\n</p>\n\n";
+ '<tr><td>Config file version:</td><td><b>' . $config_version . "</b></td></tr>\n" .
+ '<tr><td>Config file last modified:</td><td><b>' .
+ date ('d F Y H:i:s', filemtime(SM_PATH . 'config/config.php')) .
+ "</b></td></tr>\n</table>\n</p>\n\n";
-/* TODO: check $config_version here */
+/* check $config_version */
+if ($config_version!='1.4.0') {
+ do_err('Configuration file version does not match required version. Please update your configuration file.');
+}
echo "Checking PHP configuration...<br />\n";
do_err('Insufficient PHP version: '. PHP_VERSION . '! Minimum required: 4.1.0');
}
-echo $IND . 'PHP version ' . PHP_VERSION . " OK.<br />\n";
-
+echo $IND . 'PHP version ' . PHP_VERSION . ' OK. (You have: ' . phpversion() . ". Minimum: 4.1.0)<br />\n";
+/* test for boolean false and any string that is not equal to 'off' */
+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);
+}
$php_exts = array('session','pcre');
$diff = array_diff($php_exts, get_loaded_extensions());
if(count($diff)) {
/* check plugins and themes */
+$bad_plugins = array(
+ 'attachment_common', // Integrated into SquirrelMail 1.2 core
+ 'auto_prune_sent', // Obsolete: See Proon Automatic Folder Pruning plugin
+ 'compose_new_window', // Integrated into SquirrelMail 1.4 core
+ 'delete_move_next', // Integrated into SquirrelMail 1.5 core
+ 'disk_quota', // Obsolete: See Check Quota plugin
+ 'email_priority', // Integrated into SquirrelMail 1.2 core
+ 'emoticons', // Obsolete: See HTML Mail plugin
+ 'focus_change', // Integrated into SquirrelMail 1.2 core
+ 'folder_settings', // Integrated into SquirrelMail 1.5.1 core
+ 'global_sql_addressbook', // Integrated into SquirrelMail 1.4 core
+ 'hancock', // Not Working: See Random Signature Taglines plugin
+ 'msg_flags', // Integrated into SquirrelMail 1.5.1 core
+ 'message_source', // Added to SquirrelMail 1.4 Core Plugins (message_details)
+ 'motd', // Integrated into SquirrelMail 1.2 core
+ 'paginator', // Integrated into SquirrelMail 1.2 core
+ 'printer_friendly', // Integrated into SquirrelMail 1.2 core
+ 'procfilter', // Obsolete: See Server Side Filter plugin
+ 'redhat_php_cgi_fix', // Integrated into SquirrelMail 1.1.1 core
+ 'send_to_semicolon', // Integrated into SquirrelMail 1.4.1 core
+ 'spamassassin', // Not working beyond SquirrelMail 1.2.7: See Spamassassin SpamFilter (Frontend) v2 plugin
+ 'sqcalendar', // Added to SquirrelMail 1.2 Core Plugins (calendar)
+ 'sqclock', // Integrated into SquirrelMail 1.2 core
+ 'sql_squirrel_logger', // Obsolete: See Squirrel Logger plugin
+ 'tmda', // Obsolete: See TMDA Tools plugin
+ 'vacation', // Obsolete: See Vacation Local plugin
+ 'view_as_html', // Integrated into SquirrelMail 1.5.1 core
+ 'xmailer' // Integrated into SquirrelMail 1.2 core
+ );
+
if (isset($plugins[0])) {
foreach($plugins as $plugin) {
if(!file_exists(SM_PATH .'plugins/'.$plugin)) {
- do_err('You have enabled the <i>'.$plugin.'</i> plugin but I cannot find it.', FALSE);
+ do_err('You have enabled the <i>'.$plugin.'</i> plugin, but I cannot find it.', FALSE);
} elseif (!is_readable(SM_PATH .'plugins/'.$plugin.'/setup.php')) {
- do_err('You have enabled the <i>'.$plugin.'</i> plugin but I cannot read its setup.php file.', FALSE);
+ do_err('You have enabled the <i>'.$plugin.'</i> plugin, but I cannot read its setup.php file.', FALSE);
+ } elseif (in_array($plugin, $bad_plugins)) {
+ do_err('You have enabled the <i>'.$plugin.'</i> plugin, which causes problems with this version of SquirrelMail. Please check the ReleaseNotes or other documentation for more information.', false);
}
}
- echo $IND . "Plugins OK.<br />\n";
+ // load plugin functions
+ include_once(SM_PATH . 'functions/plugin.php');
+ // turn on output buffering in order to prevent output of new lines
+ ob_start();
+ foreach ($plugins as $name) {
+ use_plugin($name);
+ }
+ // get output and remove whitespace
+ $output = trim(ob_get_contents());
+ ob_end_clean();
+ // if plugins output more than newlines and spacing, stop script execution.
+ if (!empty($output)) {
+ $plugin_load_error = 'Some output is produced when plugins are loaded.'
+ .' Usually it means error. Output said: '.htmlspecialchars($output);
+ do_err($plugin_load_error);
+ }
+ /**
+ * Hook is added in 1.5.2. Plugins should print error message and return true
+ * if there is an error in plugin.
+ */
+ $plugin_err = boolean_hook_function('configtest');
+ if($plugin_err) {
+ do_err('Some plugin tests failed.');
+ } else {
+ echo $IND . "Plugins OK.<br />\n";
+ }
} else {
echo $IND . "Plugins are not enabled in config.<br />\n";
}
$loc_path = SM_PATH .'locale/'.$squirrelmail_default_language.'/LC_MESSAGES/squirrelmail.mo';
if( ! file_exists( $loc_path ) ) {
do_err('You have set <i>' . $squirrelmail_default_language .
- '</i> as your default language, but I cannot find this translation (should be '.
- 'in <tt>' . $loc_path . '</tt>). Please note that you have to download translations '.
- 'separately from the main SquirrelMail package.', FALSE);
+ '</i> as your default language, but I cannot find this translation (should be '.
+ 'in <tt>' . $loc_path . '</tt>). Please note that you have to download translations '.
+ 'separately from the main SquirrelMail package.', FALSE);
} elseif ( ! is_readable( $loc_path ) ) {
do_err('You have set <i>' . $squirrelmail_default_language .
- '</i> as your default language, but I cannot read this translation (file '.
- 'in <tt>' . $loc_path . '</tt> unreadable).', FALSE);
+ '</i> as your default language, but I cannot read this translation (file '.
+ 'in <tt>' . $loc_path . '</tt> unreadable).', FALSE);
} else {
echo $IND . "Default language OK.<br />\n";
}
echo $IND . "Default language OK.<br />\n";
}
-echo $IND . "Base URL detected as: <tt>" . htmlspecialchars(get_location()) . "</tt><br />\n";
+echo $IND . "Base URL detected as: <tt>" . htmlspecialchars($test_location) . "</tt><br />\n";
/* check minimal requirements for other security options */
}
}
/* starttls extensions */
-if($use_smtp_tls == 2 || $use_imap_tls == 2) {
+if($use_smtp_tls === 2 || $use_imap_tls === 2) {
if (! function_exists('stream_socket_enable_crypto')) {
do_err('If you want to use STARTTLS extension, you need stream_socket_enable_crypto() function from PHP 5.1.0 and newer.');
}
echo $IND . "sendmail OK<br />\n";
} else {
$stream = fsockopen( ($use_smtp_tls==1?'tls://':'').$smtpServerAddress, $smtpPort,
- $errorNumber, $errorString);
+ $errorNumber, $errorString);
if(!$stream) {
do_err("Error connecting to SMTP server \"$smtpServerAddress:$smtpPort\".".
- "Server error: ($errorNumber) ".htmlspecialchars($errorString));
+ "Server error: ($errorNumber) ".htmlspecialchars($errorString));
}
// check for SMTP code; should be 2xx to allow us access
$smtpline = fgets($stream, 1024);
if(((int) $smtpline{0}) > 3) {
do_err("Error connecting to SMTP server. Server error: ".
- htmlspecialchars($smtpline));
+ htmlspecialchars($smtpline));
}
/* smtp starttls checks */
- if ($use_smtp_tls==2) {
+ if ($use_smtp_tls===2) {
// if something breaks, script should close smtp connection on exit.
// say helo
$ehlo_error = false;
while ($line=fgets($stream, 1024)){
if (preg_match("/^250(-|\s)(\S*)\s+(\S.*)/",$line,$match)||
- preg_match("/^250(-|\s)(\S*)\s+/",$line,$match)) {
+ preg_match("/^250(-|\s)(\S*)\s+/",$line,$match)) {
if (!isset($match[3])) {
// simple one word extension
$ehlo[strtoupper($match[2])]='';
fputs($stream, 'QUIT');
fclose($stream);
echo $IND . 'SMTP server OK (<tt><small>'.
- trim(htmlspecialchars($smtpline))."</small></tt>)<br />\n";
+ trim(htmlspecialchars($smtpline))."</small></tt>)<br />\n";
/* POP before SMTP */
if($pop_before_smtp) {
$stream = fsockopen($smtpServerAddress, 110, $err_no, $err_str);
if (!$stream) {
do_err("Error connecting to POP Server ($smtpServerAddress:110) "
- . $err_no . ' : ' . htmlspecialchars($err_str));
+ . $err_no . ' : ' . htmlspecialchars($err_str));
}
$tmp = fgets($stream, 1024);
if (substr($tmp, 0, 3) != '+OK') {
do_err("Error connecting to POP Server ($smtpServerAddress:110)"
- . ' '.htmlspecialchars($tmp));
+ . ' '.htmlspecialchars($tmp));
}
fputs($stream, 'QUIT');
fclose($stream);
/** Can we open a connection? */
$stream = fsockopen( ($use_imap_tls==1?'tls://':'').$imapServerAddress, $imapPort,
- $errorNumber, $errorString);
+ $errorNumber, $errorString);
if(!$stream) {
do_err("Error connecting to IMAP server \"$imapServerAddress:$imapPort\".".
- "Server error: ($errorNumber) ".
- htmlspecialchars($errorString));
+ "Server error: ($errorNumber) ".
+ htmlspecialchars($errorString));
}
/** Is the first response 'OK'? */
$imapline = fgets($stream, 1024);
if(substr($imapline, 0,4) != '* OK') {
- do_err('Error connecting to IMAP server. Server error: '.
- htmlspecialchars($imapline));
+ do_err('Error connecting to IMAP server. Server error: '.
+ htmlspecialchars($imapline));
}
echo $IND . 'IMAP server ready (<tt><small>'.
fputs($stream, "A001 CAPABILITY\r\n");
$capline = '';
while ($line=fgets($stream, 1024)){
- if (preg_match("/A001.*/",$line)) {
- break;
- } else {
- $capline.=$line;
- }
+ if (preg_match("/A001.*/",$line)) {
+ break;
+ } else {
+ $capline.=$line;
+ }
}
/* don't display capabilities before STARTTLS */
-if ($use_imap_tls==2 && stristr($capline, 'STARTTLS') === false) {
+if ($use_imap_tls===2 && stristr($capline, 'STARTTLS') === false) {
do_err('Your server doesn\'t support STARTTLS.');
-} elseif($use_imap_tls==2) {
+} elseif($use_imap_tls===2) {
/* try starting starttls */
fwrite($stream,"A002 STARTTLS\r\n");
$starttls_line=fgets($stream, 1024);
if (! preg_match("/^A002 OK.*/i",$starttls_line)) {
$imap_starttls_err = 'IMAP STARTTLS failed. Server replied: '
- .htmlspecialchars($starttls_line);
+ .htmlspecialchars($starttls_line);
do_err($imap_starttls_err);
} elseif (! stream_socket_enable_crypto($stream,true,STREAM_CRYPTO_METHOD_TLS_CLIENT)) {
do_err('Failed to enable encryption on IMAP connection.');
if($imap_auth_mech == 'login' && stristr($capline, 'LOGINDISABLED') !== FALSE) {
do_err('Your server doesn\'t allow plaintext logins. '.
- 'Try enabling another authentication mechanism like CRAM-MD5, DIGEST-MD5 or TLS-encryption '.
- 'in the SquirrelMail configuration.', FALSE);
+ 'Try enabling another authentication mechanism like CRAM-MD5, DIGEST-MD5 or TLS-encryption '.
+ 'in the SquirrelMail configuration.', FALSE);
}
/** OK, close connection */
echo 'Gettext functions are available.'
.' On some systems you must have appropriate system locales compiled.'
."<br />\n";
+
+ /* optional setlocale() tests. Should work only on glibc systems. */
+ if (sqgetGlobalVar('testlocales',$testlocales,SQ_GET)) {
+ include_once(SM_PATH . 'include/languages.php');
+ echo $IND . $IND . 'Testing translations:<br>';
+ foreach ($languages as $lang_code => $lang_data) {
+ /* don't test aliases */
+ if (isset($lang_data['NAME'])) {
+ /* locale can be $lang_code or $lang_data['LOCALE'] */
+ if (isset($lang_data['LOCALE'])) {
+ $setlocale = $lang_data['LOCALE'];
+ } else {
+ $setlocale = $lang_code;
+ }
+ /* prepare information about tested locales */
+ if (is_array($setlocale)) {
+ $display_locale = implode(', ',$setlocale);
+ $locale_count = count($setlocale);
+ } else {
+ $display_locale = $setlocale;
+ $locale_count = 1;
+ }
+ $tested_locales_msg = 'Tested '.htmlspecialchars($display_locale).' '
+ .($locale_count>1 ? 'locales':'locale'). '.';
+
+ echo $IND . $IND .$IND . $lang_data['NAME'].' (' .$lang_code. ') - ';
+ $retlocale = sq_setlocale(LC_ALL,$setlocale);
+ if (is_bool($retlocale)) {
+ echo '<font color="red">unsupported</font>. ';
+ echo $tested_locales_msg;
+ } else {
+ echo 'supported. '
+ .$tested_locales_msg
+ .' setlocale() returned "'.htmlspecialchars($retlocale).'"';
+ }
+ echo "<br />\n";
+ }
+ }
+ echo $IND . $IND . '<a href="configtest.php">Don\'t test translations</a>';
+ } else {
+ echo $IND . $IND . '<a href="configtest.php?testlocales=1">Test translations</a>. '
+ .'This test is not accurate and might work only on some systems.'
+ ."\n";
+ }
+ echo "<br />\n";
+ /* end of translation tests */
} else {
echo 'Gettext functions are unavailable.'
.' SquirrelMail will use slower internal gettext functions.'
} else {
echo "Iconv functions are unavailable.<br />\n";
}
-// same test as in include/validate.php
+// same test as in include/init.php + date_default_timezone_set check
echo "$IND timezone - ";
-if ( (!ini_get('safe_mode')) ||
- !strcmp(ini_get('safe_mode_allowed_env_vars'),'') ||
- preg_match('/^([\w_]+,)*TZ/', ini_get('safe_mode_allowed_env_vars')) ) {
- echo "Webmail users can change their time zone settings.<br />\n";
+if ( (!ini_get('safe_mode')) || function_exists('date_default_timezone_set') ||
+ !strcmp(ini_get('safe_mode_allowed_env_vars'),'') ||
+ preg_match('/^([\w_]+,)*TZ/', ini_get('safe_mode_allowed_env_vars')) ) {
+ echo "Webmail users can change their time zone settings. \n";
} else {
- echo "Webmail users can't change their time zone settings.<br />\n";
+ echo "Webmail users can't change their time zone settings. \n";
}
-
+if (isset($_ENV['TZ'])) {
+ echo 'Default time zone is '.htmlspecialchars($_ENV['TZ']);
+} else {
+ echo 'Current time zone is '.date('T');
+}
+echo ".<br />\n";
// Pear DB tests
echo "Checking database functions...<br />\n";
if (class_exists('DB')) {
echo "$IND PHP Pear DB support is present.<br />\n";
$db_functions=array(
- 'dbase' => 'dbase_open',
- 'fbsql' => 'fbsql_connect',
- 'interbase' => 'ibase_connect',
- 'informix' => 'ifx_connect',
- 'msql' => 'msql_connect',
- 'mssql' => 'mssql_connect',
- 'mysql' => 'mysql_connect',
- 'mysqli' => 'mysqli_connect',
- 'oci8' => 'ocilogon',
- 'odbc' => 'odbc_connect',
- 'pgsql' => 'pg_connect',
- 'sqlite' => 'sqlite_open',
- 'sybase' => 'sybase_connect'
- );
+ 'dbase' => 'dbase_open',
+ 'fbsql' => 'fbsql_connect',
+ 'interbase' => 'ibase_connect',
+ 'informix' => 'ifx_connect',
+ 'msql' => 'msql_connect',
+ 'mssql' => 'mssql_connect',
+ 'mysql' => 'mysql_connect',
+ 'mysqli' => 'mysqli_connect',
+ 'oci8' => 'ocilogon',
+ 'odbc' => 'odbc_connect',
+ 'pgsql' => 'pg_connect',
+ 'sqlite' => 'sqlite_open',
+ 'sybase' => 'sybase_connect'
+ );
$dsns = array();
if($prefs_dsn) {
$dbh = DB::connect($dsn, true);
if (DB::isError($dbh)) {
do_err('Database error: '. htmlspecialchars(DB::errorMessage($dbh)) .
- ' in ' .$type .' DSN.');
+ ' in ' .$type .' DSN.');
}
$dbh->disconnect();
echo "$IND$type database connect successful.<br />\n";
$linkid = @ldap_connect($param['host'], (empty($param['port']) ? 389 : $param['port']) );
if ( $linkid ) {
- echo "$IND LDAP connect to ".$param['host']." successful: ".$linkid."<br />\n";
+ echo "$IND LDAP connect to ".$param['host']." successful: ".$linkid."<br />\n";
if ( !empty($param['protocol']) &&
- !ldap_set_option($linkid, LDAP_OPT_PROTOCOL_VERSION, $param['protocol']) ) {
+ !ldap_set_option($linkid, LDAP_OPT_PROTOCOL_VERSION, $param['protocol']) ) {
do_err('Unable to set LDAP protocol');
}
}
}
-?>
-
+echo '<hr width="75%" align="center">';
+echo '<h2 align="center">Summary</h2>';
+$footer = '<hr width="75%" align="center">';
+if ($warnings) {
+ echo '<p>No fatal errors were found, but there was at least 1 warning. Please check the flagged issue(s) carefully, as correcting them may prevent erratic, undefined, or incorrect behavior (or flat out breakage).</p>';
+ echo $footer;
+} else {
+ print <<< EOF
<p>Congratulations, your SquirrelMail setup looks fine to me!</p>
<p><a href="login.php">Login now</a></p>
</body>
-</html>
\ No newline at end of file
+</html>
+EOF;
+ echo $footer;
+}
+?>