till
2008-02-25 e240d5b35b0c06310bb296e2850572bc13018ec0
check.php-dist
@@ -1,18 +1,18 @@
<?php
/**
 * Copyright (c) 2008, Till Klampaeckel
 *
 *
 * All rights reserved.
 *
 *
 * Redistribution and use in source and binary forms, with or without modification,
 * are permitted provided that the following conditions are met:
 *
 *
 *  * Redistributions of source code must retain the above copyright notice, this
 *    list of conditions and the following disclaimer.
 *  * Redistributions in binary form must reproduce the above copyright notice, this
 *    list of conditions and the following disclaimer in the documentation and/or
 *    other materials provided with the distribution.
 *
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
@@ -56,60 +56,193 @@
 ********************************************
 */
error_reporting(E_ALL ^E_NOTICE);
define('CHECK_OK', '<span class="success">OK</span>');
define('CHECK_NOK', '<span class="fail">NOT OK</span>');
define('CHECK_NA', '<span class="na">NOT AVAILABLE</span>');
$include_path  = dirname(__FILE__) . '/program/lib/';
error_reporting(E_ALL);
$include_path  = dirname(__FILE__) . '/program/lib';
$include_path .= PATH_SEPARATOR;
$include_path .= dirname(__FILE__) . '/program/';
$include_path .= dirname(__FILE__) . '/program';
$include_path .= PATH_SEPARATOR;
$include_path .= get_include_path();
ini_set('display_errors', 1);
set_include_path($include_path);
$writable_dirs = array('logs/', 'temp/');
$create_files  = array('config/db.inc.php', 'config/main.inc.php');
$create_files = array('config/db.inc.php', 'config/main.inc.php');
$required_libs = array('PEAR' => 'PEAR.php', 'DB' => 'DB.php',
    'Net_SMTP' => 'Net/SMTP.php', 'Mail_mime' => 'Mail/mime.php',
    'MDB2' => 'MDB2.php', 'iilConnection' => 'lib/imap.inc');
$supported_drivers = array('MDB2#mysql' => 'MDB2/Driver/mysql.php',
    'MDB2#pgsql' => 'MDB2/Driver/pgsql.php',
    'MDB2#sqlite' => 'MDB2/Driver/sqlite.php');
$supported_dbs = array('MySQL' => 'mysql', 'MySQLi' => 'mysqli',
    'PostgreSQL' => 'pgsql', 'SQLite (v2)' => 'sqlite');
$required_php_exts = array('Session' => 'session',
    'PCRE' => 'pcre', 'Sockets' => 'sockets');
$optional_php_exts = array('FileInfo' => 'fileinfo', 'Libiconv' => 'iconv',
    'Multibyte' => 'mbstring', 'OpenSSL' => 'openssl', 'GD' => 'gd');
$source_urls = array(
    'Socket' => 'http://www.php.net/manual/en/ref.sockets.php',
    'Session' => 'http://www.php.net/manual/en/ref.session.php',
    'PCRE' => 'http://www.php.net/manual/en/ref.pcre.php',
    'FileInfo' => 'http://www.php.net/manual/en/ref.fileinfo.php',
    'Libiconv' => 'http://www.php.net/manual/en/ref.iconv.php',
    'Multibyte' => 'http://www.php.net/manual/en/ref.mbstring.php',
    'OpenSSL' => 'http://www.php.net/manual/en/ref.openssl.php',
    'PEAR' => 'http://pear.php.net',
    'MDB2' => 'http://pear.php.net/package/MDB2',
    'Net_SMTP' => 'http://pear.php.net/package/Net_SMTP',
    'Mail_mime' => 'http://pear.php.net/package/Mail_mime'
);
$path  = dirname(__FILE__) . '/';
$check = basename(__FILE__);
require_once 'include/bugs.inc';
function show_hint($key) {
    global $source_urls;
    if ($source_urls[$key]) {
        echo '<span class="indent">(See <a href="' . $source_urls[$key] . '">';
        echo  $source_urls[$key] . '</a>)</span>';
    }
}
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/2002/REC-xhtml1-20020801/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
    <link rel="shortcut icon" href="skins/default/images/favicon.ico"/>
    <link rel="stylesheet" type="text/css" href="skins/default/common.css" />
    <style type="text/css">
    /* <![CDATA[ */
    label { display:block; }
    .success { color:#006400;font-weight:bold !important; }
    .fail { color:#ff0000 !important;font-weight:bold !important; }
    /* ]]> */
    </style>
    <title>RoundCube :: check</title>
<link rel="shortcut icon" href="skins/default/images/favicon.ico" />
<link rel="stylesheet" type="text/css" href="skins/default/common.css" />
<style type="text/css">
/* <![CDATA[ */
label {
   display: block;
}
th {
   text-align: left;
}
h4 {
   margin-bottom: 0.2em;
}
.success {
   color: #006400;
   font-weight: bold !important;
}
.fail {
   color: #ff0000 !important;
   font-weight: bold !important;
}
.na {
   color: #f60;
   font-weight: bold;
}
.indent {
   padding-left: 0.8em;
}
/* ]]> */
</style>
<title>RoundCube :: check</title>
</head>
<body>
<img src="skins/default/images/roundcube_logo.png" width="165" height="55" border="0" alt="RoundCube Webmail" hspace="12" vspace="2"/>
<img src="skins/default/images/roundcube_logo.png" width="165"
   height="55" border="0" alt="RoundCube Webmail" hspace="12" vspace="2" />
<h3>Check <?php echo basename(__FILE__); ?> Configuration</h3>
From correctly set:
<?php
if ($rctest_config['from'] == '_yourfrom_') {
    echo '<span class="fail">NOT OK</span>';
    echo CHECK_NOK;
} else {
    echo $rctest_config['from'] . '<br /><br />';
    echo '<i>We do not check if this is a <b>valid</b> email address. Since this serves as from &amp; to, make sure it is correct!</i>';
    echo '<i><b>Note:</b> We do not check if this is a <b>valid</b> email address.';
    echo ' Because this settings serves as from &amp; to, make sure it is correctly set!</i>';
}
?>
<br />
<?php
echo '<h3>Check if directories are writable</h3>';
echo '<p>RoundCube may need to write/save files into these directories.</p>';
foreach ($writable_dirs AS $dir) {
    echo "Directory $dir: ";
    if (!is_writable($path . $dir)) {
        echo '<span class="fail">NOT OK</span>';
echo '<h3>Checking available databases</h3>';
echo '<p>Checks if the extension is loaded. At least one of them is required.</p>';
$prefix = (PHP_SHLIB_SUFFIX === 'dll') ? 'php_' : '';
foreach ($supported_dbs AS $database => $ext) {
    echo "$database: ";
    if (extension_loaded($ext)) {
        echo CHECK_OK;
    } else {
        echo '<span class="success">OK</span>';
        $_ext = $prefix . $ext . '.' . PHP_SHLIB_SUFFIX;
        echo CHECK_NA;
        if (@dl($_ext)) {
            echo ' (<i>Could</i> be loaded. Please add in php.ini, if you plan on using it.)';
        } else {
            echo ' (<b>Not</b> installed.)';
        }
    }
    echo '<br />';
}
echo '<h3>Checking PHP extensions</h3>';
echo '<p>The following modules/extensions are <em>required</em> to run RoundCube</p>';
$prefix = (PHP_SHLIB_SUFFIX === 'dll') ? 'php_' : '';
foreach ($required_php_exts AS $name => $ext) {
    echo "$name: ";
    if (extension_loaded($ext)) {
        echo CHECK_OK;
    } else {
        $_ext = $prefix . $ext . '.' . PHP_SHLIB_SUFFIX;
        echo CHECK_NA;
        if (@dl($_ext)) {
            echo ' (<i>Could</i> be loaded. Please add in php.ini.)';
        } else {
            show_hint($name);
        }
    }
    echo '<br />';
}
echo '<p>These extensions are <em>optional</em> but recommended to get the best performance.</p>';
foreach ($optional_php_exts AS $name => $ext) {
    echo "$name: ";
    if (extension_loaded($ext)) {
        echo CHECK_OK;
    } else {
        $_ext = $prefix . $ext . '.' . PHP_SHLIB_SUFFIX;
        echo CHECK_NA;
        if (@dl($_ext)) {
            echo ' (<i>Could</i> be loaded. Please add in php.ini, if you plan on using it.)';
        } else {
            show_hint($name);
        }
    }
    echo '<br />';
}
echo '<h3>Check for required 3rd party libs</h3>';
echo '<p>This also checks if the include path is set correctly.</p>';
foreach ($required_libs as $classname => $file) {
    require_once $file;
    echo "$classname: ";
    if (class_exists($classname)) {
        echo CHECK_OK;
    } else {
        echo CHECK_NOK . " (Failed to load $file.)";
        show_hint($classname);
    }
    echo "<br />";
}
@@ -120,29 +253,74 @@
foreach ($create_files AS $file) {
    echo "File $file: ";
    if (file_exists($path . $file) && is_readable($path . $file)) {
        echo '<span class="success">OK</span>';
        echo CHECK_OK;
    } else {
        echo '<span class="fail">NOT OK</span>';
        echo CHECK_NOK;
    }
    echo '<br />';
}
echo '<h3>Check if directories are writable</h3>';
echo '<p>RoundCube may need to write/save files into these directories.</p>';
require_once $path . 'config/main.inc.php';
$rctest_config = array_merge($rctest_config, $rcmail_config);
if (isset($rctest_config)) {
    foreach (array($rctest_config['temp_dir'], $rctest_config['log_dir']) AS $dir) {
        $dir = $dir{0} == '/' ? $dir : $path . $dir;
        echo "Directory $dir: ";
        if (!is_writable($dir)) {
            echo CHECK_NOK;
        } else {
            echo CHECK_OK;
        }
        echo "<br />";
    }
} else {
    echo 'Could not open db.inc.php config file, or file is empty.<br />';
}
echo '<h3>Check supplied DB settings</h3>';
@include $path . 'config/db.inc.php';
require_once $path . 'config/db.inc.php';
$rctest_config = array_merge($rctest_config, $rcmail_config);
$db_working = false;
if (isset($rcmail_config)) {
    echo 'DB settings: ';
    include_once 'MDB2.php';
    $db = MDB2::connect($rcmail_config['db_dsnw']);
    if (!MDB2::IsError($db)) {
        echo '<span class="success">OK</span>';
        $db->disconnect();
        $db_working = true;
if (isset($rctest_config) && is_array($rctest_config)) {
    echo 'Selected backend: ';
    if ($rctest_config['db_backend'] != '') {
        echo 'PEAR::' . strtoupper($rctest_config['db_backend']) . '<br />';
        $_class = 'rcube_' . strtolower($rctest_config['db_backend']);
        require_once 'include/' . $_class . '.inc';
        echo 'DSN (standard): ';
        $DB = new $_class($rctest_config['db_dsnw'], '', false);
        $DB->db_connect('w');
        if (!($db_error_msg = $DB->is_error())) {
            echo CHECK_OK;
            $db_working = true;
        } else {
            echo CHECK_NOK . " (Error: $db_error_msg)";
        }
        echo '<br />';
        echo 'DSN (read-only, optional): ';
        if ($rctest_config['db_dsnr'] != '') {
            $DB_READ = new $_class($rctest_config['db_dsnr'], '', false);
            $DB_READ->db_connect('w');
            if (!($db_error_msg = $DB_READ->is_error())) {
                echo CHECK_OK;
            } else {
                echo CHECK_NOK . " (Error: $db_error_msg)";
            }
        } else {
            echo CHECK_NA.($db_working ? ' - <span class="success">will use DSN (standard)</span>' : '');
        }
        echo '<br />';
    } else {
        echo '<span class="fail">NOT OK</span>';
        echo CHECK_NOK . ' (not set)';
    }
    echo '<br />';
} else {
    echo 'Could not open db.inc.php config file, or file is empty.<br />';
}
@@ -151,21 +329,18 @@
echo 'Checks if web- and databaseserver are in the same timezone.<br /><br />';
echo 'Status: ';
if ($db_working === true) {
    require_once 'include/rcube_mdb2.inc';
    $DB = new rcube_mdb2($rcmail_config['db_dsnw'], '', false);
    $DB->db_connect('w');
    $tz_db    = "SELECT " . $DB->unixtimestamp($DB->now()) . " AS tz_db";
    $tz_db    = 'SELECT ' . $DB->unixtimestamp($DB->now()) . ' AS tz_db';
    $tz_db    = $DB->query($tz_db);
    $tz_db    = $DB->fetch_assoc($tz_db);
    $tz_db    = (int) $tz_db['tz_db'];
    $tz_local = (int) time();
    $tz_diff  = $tz_local - $tz_db;
    if ($tz_db != $tz_local) {
        echo '<span class="fail">NOT OK</span>';
    // sometimes we have 1 second gap, treat that as ok
    if ($tz_diff > 1) {
        echo CHECK_NOK;
    } else {
        echo '<span class="success">OK</span>';
        echo CHECK_OK;
    }
} else {
    echo 'Could not test (fix DB first).';
@@ -174,145 +349,152 @@
echo '<h3>Checking .ini settings</h3>';
$auto_start   = ini_get('session.auto_start');
$file_uploads = ini_get('file_uploads');
$ini_array = array('session.auto_start' => 0, 'file_uploads' => 1,
    'magic_quotes_sybase' => 0, 'magic_quotes_gpc' => 0,
    'zlib.output_compression' => 0);
echo '<h4>session.auto_start = 0</h4>';
echo 'status: ';
if ($auto_start == 1) {
    echo '<span class="fail">NOT OK</span>';
} else {
    echo '<span class="success">OK</span>';
}
echo '<br />';
foreach ($ini_array AS $var => $val) {
    $status = ini_get($var);
echo '<h4>file_uploads = On</h4>';
echo 'status: ';
if ($file_uploads == 1) {
    echo '<span class="success">OK</span>';
} else {
    echo '<span class="fail">NOT OK</span>';
}
/*
 * Probably not needed because we have a custom handler
echo '<h4>session.save_path <i>is set</i></h4>';
echo 'status: ';
$save_path = ini_get('session.save_path');
if (empty($save_path)) {
    echo '<span class="fail">NOT OK</span>';
} else {
    echo "<span class="success">OK</span>: $save_path";
    if (!file_exists($save_path)) {
        echo ', but it does not exist';
    echo "<h4>$var = $val</h4>";
    echo 'status: ';
    if ($status != $val) {
        echo CHECK_NOK;
    } else {
        if (!is_readable($save_path) || !is_writable($save_path)) {
            echo ', but permissions to read and/or write are missing';
        }
        echo CHECK_OK;
    }
    echo '<br />';
}
echo '<br />';
 */
@include_once $path . '/config/main.inc.php';
?>
<h3>Check email settings</h3>
<?php
echo 'Fetching config-settings from config/main.inc.php.<br /><br />';
if (is_array($rcmail_config) && count($rcmail_config)) {
?>
if (is_array($rctest_config) && count($rctest_config)) {
    ?>
<table border="0">
<tr>
    <th><h4>SMTP Settings</h4></th>
    <th><h4>IMAP Settings</h4></th>
<th><h4>SMTP Settings</h4></th>
<th><h4>IMAP Settings</h4></th>
</tr>
<tr><td valign="top">
<tr>
<td valign="top"><?php
echo 'SMTP: ' . CHECK_OK . '<br />';
echo 'server: '.(isset($rctest_config['smtp_server']) && !empty($rctest_config['smtp_server']) ? $rctest_config['smtp_server'] : '<i>not set</i>').'<br />';
echo 'port: '.(isset($rctest_config['smtp_port']) && !empty($rctest_config['smtp_port']) ? $rctest_config['smtp_port'] : '<i>not set</i>').'<br />';
if (isset($rctest_config['smtp_user']) && !empty($rctest_config['smtp_user'])) {
    echo 'user: '.$rctest_config['smtp_user'].'<br/>';
} elseif ($rctest_config['smtp_user'] == '%u') {
    echo 'user: <i>use current session</i><br/>';
} else {
    echo 'user: <i>not set</i><br/>';
}
if (isset($rctest_config['smtp_pass']) && !empty($rctest_config['smtp_pass'])) {
    echo 'pass: '.$rctest_config['smtp_pass'].'<br/>';
} elseif (isset($rctest_config['smtp_pass']) && $rctest_config['smtp_pass'] == '%p') {
    echo 'pass: <i>use current session</i><br/>';
} else {
    echo 'pass: <i>not set</i><br/>';
}
?></td>
<td valign="top">
<?php
    echo 'SMTP: <span class="success">OK</span><br />';
    echo 'server: ' . $rcmail_config['smtp_server'] . '<br />';
    echo 'port: ' . $rcmail_config['smtp_port'] . '<br />';
    echo 'user: ' . (($rcmail_config['smtp_user'] == '%u')?'<i>use current session</i>':$rcmail_config['smtp_user']) . '<br />';
    echo 'pass: ' . (($rcmail_config['smtp_pass'] == '%p')?'<i>use current session</i>':$rcmail_config['smtp_pass']) . '<br />';
    //var_dump($rcmail_config);
?>
</td><td valign="top">
<?php
    echo 'IMAP: <span class="success">OK</span><br />';
    echo 'server: ' . $rcmail_config['default_host'] . '<br />';
    echo 'port: ' . $rcmail_config['default_port'] . '<br />';
?>
</td></tr>
echo 'IMAP: ' . CHECK_OK . '<br />';
if (isset($rctest_config['default_host']) && is_array($rctest_config['default_host'])) {
    echo 'server: '.var_export($rctest_config['default_host'], true).'<br/>';
} elseif (isset($rctest_config['default_host']) && !empty($rctest_config['default_host'])) {
    echo 'server: '.$rctest_config['default_host'].'<br/>';
} else {
    echo 'server: <i>not set</i><br/>';
}
echo 'port: '.(isset($rctest_config['default_port']) && !empty($rctest_config['default_port']) ? $rctest_config['default_port'] : '<i>not set</i>').'<br />';
?></td>
</tr>
</table>
<h3>Test SMTP settings - send an email</h3>
<p>Don't abuse this!</p>
<form action="<?php echo $check; ?>" method="post">
<?php
if ($rcmail_config['smtp_server'] != ''):
    if ($rcmail_config['smtp_user'] == '%u'):
?>
<label>Username:</label><input type="text" name="smtp_test[user]" />
<form action="<?php echo $check; ?>" method="post"><?php
if ($rctest_config['smtp_server'] != ''):
if ($rctest_config['smtp_user'] == '%u'):
?> <label>Username:</label><input type="text" name="smtp_test[user]" />
<label>Password:</label><input type="password" name="smtp_test[pass]" /><br />
<?php
    endif;
endif;
?>
Recipient:<br />
<?php echo $rctest_config['from']; ?><br /><br />
endif;
?> Recipient:<br />
<?php echo $rctest_config['from']; ?><br />
<br />
<?php if (!empty($rctest_config['smtp_server'])): ?>
<input type="hidden" name="action" value="smtp" />
<input type="submit" value="send an email" />
<?php else: ?>
<i>Because you did not configure SMTP, you cannot test it!</i>
<?php endif; ?>
</form>
<?php
    if ($_SERVER['REQUEST_METHOD'] == 'POST' && $_POST['action'] == 'smtp') {
if ($_SERVER['REQUEST_METHOD'] == 'POST' && $_POST['action'] == 'smtp') {
        echo 'Trying to send email: ';
        if ($rctest_config['from'] == '_yourfrom_') {
            echo '<span class="fail">NOT OK</span><br />';
            echo '<i>Please edit $rctest_config in ' . basename(__FILE__) . '</i><br />';
    echo 'Trying to send email: ';
    if ($rctest_config['from'] == '_yourfrom_') {
        echo CHECK_NOK . '<br />';
        echo '<i>Please edit $rctest_config in ' . basename(__FILE__) . '</i><br />';
    } else {
        $data   = null;
        $CONFIG = $rctest_config;
        if (isset($_POST['smtp_test'])) {
            $data = $_POST['smtp_test'];
            // inject into config array
            $CONFIG['smtp_user'] = $data['user'];
            $CONFIG['smtp_pass'] = $data['pass'];
        }
        require_once 'lib/rc_mail_mime.inc';
        require_once 'include/rcube_smtp.inc';
        $recipients = $rctest_config['from'];
        $headers['From']    = $rctest_config['from'];
        $headers['To']      = $recipients;
        $headers['Subject'] = 'Test message from RoundCube';
        $body = 'This is a test to confirm that RoundCube can send email.';
        $mail_object  = new rc_mail_mime();
        $send_headers = $mail_object->headers($headers);
        $smtp_response = array();
        $status = smtp_mail($rctest_config['from'], $recipients,
            ($foo = $mail_object->txtHeaders($send_headers)),
            $body, $smtp_response);
        if ($status) {
            echo CHECK_OK . '<br />';
        } else {
            $data   = $_POST['smtp_test'];
            $CONFIG = $rcmail_config;
            require_once 'lib/rc_mail_mime.inc';
            require_once 'include/rcube_smtp.inc';
            $recipients = $rctest_config['from'];
            $headers['From']    = $rctest_config['from'];
            $headers['To']      = $recipients;
            $headers['Subject'] = 'Test message from RoundCube';
            $body = 'This is a test to confirm that RoundCube can send email.';
            $mail_object = new rc_mail_mime();
            $mail_object->headers($headers);
            $smtp_response = array();
            if (smtp_mail($rctest_config['from'], $recipients, ($foo = $mail_object->txtHeaders($send_headers)), $body, $smtp_response)) {
                echo '<span class="success">OK</span><br />';
            } else {
                echo '<span class="fail">NOT OK</span>';
                echo '<br />' . join('<br />', $smtp_response);
            }
            echo CHECK_NOK;
            echo '<br />' . join('<br />', $smtp_response);
        }
    }
}
} else {
    echo '<span class="fail">NOT OK</span>';
    echo CHECK_NOK;
}
?>
<h3>Test IMAP settings</h3>
<?php
if ($rcmail_config['default_host'] == '') {
if ($rctest_config['default_host'] == '') {
    echo '<span class="fail">We cannot test, default_host is not set in config/main.inc.php.</span>';
} else {
?>
    ?>
<form action="<?php echo $check; ?>" method="post">
<label>Username:</label><input type="text" name="imap_test[user]" />
<label>Password:</label><input type="password" name="imap_test[pass]" /><br /><br />
<label>Password:</label><input type="password" name="imap_test[pass]" /><br />
<br />
<input type="hidden" name="action" value="imap" />
<input type="submit" value="check email" />
</form><br /><br />
<?php
</form>
<br /><br />
    <?php
    if ($_SERVER['REQUEST_METHOD'] == 'POST' && $_POST['action'] == 'imap') {
        echo 'Testing IMAP connect: ';
@@ -322,19 +504,19 @@
        require_once 'imap.inc';
        global $iil_error, $ICL_PORT;
        $ICL_PORT = $rcmail_config['default_port'];
        $result   = iil_Connect($rcmail_config['default_host'],
            $data['user'], $data['pass']);
        $ICL_PORT = $rctest_config['default_port'];
        $result   = iil_Connect($rctest_config['default_host'],
        $data['user'], $data['pass']);
        if ($result != true) {
            echo '<span class="fail">NOT OK</span>';
            echo CHECK_NOK;
            echo '<br />Error return: ' . $iil_error;
        } else {
            echo '<span class="success">OK</span>';
            echo CHECK_OK;
        }
        echo '<br />';
    }
}
?>
</body>
</html>
</html>