* @license http://www.opensource.org/licenses/bsd-license.php The BSD License * @version CVS: $Id$ * @link https://svn.roundcube.net/trunk * @todo Check IMAP settings. * @todo Check SMTP settings. * @todo HTML/CSS to make it pretty. * @todo In devel-next, use bootstrap. */ $include_path = dirname(__FILE__) . '/program/lib/'; $include_path .= PATH_SEPARATOR; $include_path .= dirname(__FILE__) . '/program/'; $include_path .= PATH_SEPARATOR; $include_path .= get_include_path(); set_include_path($include_path); $writable_dirs = array('logs/', 'temp/'); $create_files = array('config/db.inc.php', 'config/main.inc.php'); $path = dirname(__FILE__) . '/'; echo '

Check if directories are writable

'; echo '

RoundCube may need to write/save files into these directories.

'; foreach ($writable_dirs AS $dir) { echo "Directory $dir: "; if (!is_writable($path . $dir)) { echo 'NOT OK'; } else { echo 'OK'; } echo "
"; } echo '

Check if you setup config files

'; echo '

Checks if the files exist and if they are readable.

'; foreach ($create_files AS $file) { echo "File $file: "; if (file_exists($path . $file) && is_readable($path . $file)) { echo 'OK'; } else { echo 'NOT OK'; } echo '
'; } echo '

Check supplied DB settings

'; @include $path . 'config/db.inc.php'; $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 'OK'; $db->disconnect(); $db_working = true; } else { echo 'NOT OK'; } echo '
'; } else { echo 'Could not open db.inc.php config file, or file is empty.
'; } echo '

TimeZone

'; 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 = $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 'NOT OK'; } else { echo 'OK'; } } else { echo 'Could not test (fix DB first).'; } echo '
'; echo '

Checking .ini settings

'; $auto_start = ini_get('session.auto_start'); $file_uploads = ini_get('file_uploads'); echo '

session.auto_start

'; echo 'status: '; if ($auto_start == 1) { echo 'NOT OK'; } else { echo 'OK'; } echo '
'; echo '

file_uploads

'; echo 'status: '; if ($file_uploads == 1) { echo 'OK'; } else { echo 'NOT OK'; } /* * Probably not needed because we have a custom handler echo '

session.save_path

'; echo 'status: '; $save_path = ini_get('session.save_path'); if (empty($save_path)) { echo 'NOT OK'; } else { echo "OK: $save_path"; if (!file_exists($save_path)) { echo ', but it does not exist'; } else { if (!is_readable($save_path) || !is_writable($save_path)) { echo ', but permissions to read and/or write are missing'; } } } echo '
'; */ ?>