Check config files

config)) { $RCI->pass('main.inc.php'); } else if ($read_main) { $RCI->fail('main.inc.php', 'Syntax error'); } else if (!$read_main) { $RCI->fail('main.inc.php', 'Unable to read file. Did you create the config files?'); } echo '
'; if ($read_db && !empty($RCI->config['db_table_users'])) { $RCI->pass('db.inc.php'); } else if ($read_db) { $RCI->fail('db.inc.php', 'Syntax error'); } else if (!$read_db) { $RCI->fail('db.inc.php', 'Unable to read file. Did you create the config files?'); } ?>

Check configured database settings

config)) { if (!empty($RCI->config['db_backend']) && !empty($RCI->config['db_dsnw'])) { echo 'Backend: '; echo 'PEAR::' . strtoupper($RCI->config['db_backend']) . '
'; $_class = 'rcube_' . strtolower($RCI->config['db_backend']); require_once 'include/' . $_class . '.inc'; $DB = new $_class($RCI->config['db_dsnw'], '', false); $DB->db_connect('w'); if (!($db_error_msg = $DB->is_error())) { $RCI->pass('DSN (write)'); echo '
'; $db_working = true; } else { $RCI->fail('DSN (write)', $db_error_msg); echo '

Make sure that the configured database extists and that the user as write privileges
'; echo 'DSN: ' . $RCI->config['db_dsnw'] . '

'; } } else { $RCI->fail('DSN (write)', 'not set'); } } else { $RCI->fail('Config', 'Could not read config files'); } // initialize db with schema found in /SQL/* if ($db_working && $_POST['initdb']) { if (!($success = $RCI->init_db($DB))) { $db_working = false; echo '

Please try to inizialize the database manually as described in the INSTALL guide. Make sure that the configured database extists and that the user as write privileges

'; } } // test database if ($db_working) { $db_read = $DB->query("SELECT count(*) FROM {$RCI->config['db_table_users']}"); if (!$db_read) { $RCI->fail('DB Schema', "Database not initialized"); $db_working = false; echo '

'; } else { $RCI->pass('DB Schema'); } echo '
'; } // more database tests if ($db_working) { // write test $db_write = $DB->query("INSERT INTO {$RCI->config['db_table_cache']} (session_id, cache_key, data, user_id) VALUES (?, ?, ?, 0)", '1234567890abcdef', 'test', 'test'); $insert_id = $DB->insert_id($RCI->config['db_sequence_cache']); if ($db_write && $insert_id) { $RCI->pass('DB Write'); $DB->query("DELETE FROM {$RCI->config['db_table_cache']} WHERE cache_id=?", $insert_id); } else { $RCI->fail('DB Write', $RCI->get_error()); } echo '
'; // check timezone settings $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; // sometimes db and web servers are on separate hosts, so allow a 30 minutes delta if (abs($tz_diff) > 1800) { $RCI->fail('DB Time', "Database time differs {$td_ziff}s from PHP time"); } else { $RCI->pass('DB Time'); } } ?>

Test SMTP settings

Server: getprop('smtp_server', 'PHP mail()'); ?>
Port: getprop('smtp_port'); ?>
getprop('smtp_server')) { $user = $RCI->getprop('smtp_user', '(none)'); $pass = $RCI->getprop('smtp_pass', '(none)'); if ($user == '%u') { $user_field = new textfield(array('name' => '_user')); $user = $user_field->show($_POST['_user']); } if ($pass == '%p') { $pass_field = new passwordfield(array('name' => '_pass')); $pass = $pass_field->show(); } echo "User: $user
"; echo "Password: $pass
"; } $from_field = new textfield(array('name' => '_from', 'id' => 'sendmailfrom')); $to_field = new textfield(array('name' => '_to', 'id' => 'sendmailto')); ?>

Trying to send email...
'; if (preg_match('/^' . $RCI->email_pattern . '$/i', trim($_POST['_from'])) && preg_match('/^' . $RCI->email_pattern . '$/i', trim($_POST['_to']))) { $headers = array( 'From' => trim($_POST['_from']), 'To' => trim($_POST['_to']), 'Subject' => 'Test message from RoundCube', ); $body = 'This is a test to confirm that RoundCube can send email.'; $smtp_response = array(); // send mail using configured SMTP server if ($RCI->getprop('smtp_server')) { $CONFIG = $RCI->config; if (!empty($_POST['_user'])) $CONFIG['smtp_user'] = $_POST['_user']; if (!empty($_POST['_pass'])) $CONFIG['smtp_pass'] = $_POST['_pass']; $mail_object = new rc_mail_mime(); $send_headers = $mail_object->headers($headers); $status = smtp_mail($headers['From'], $headers['To'], ($foo = $mail_object->txtHeaders($send_headers)), $body, $smtp_response); } else { // use mail() $header_str = 'From: ' . $headers['From']; if (ini_get('safe_mode')) $status = mail($headers['To'], $headers['Subject'], $body, $header_str); else $status = mail($headers['To'], $headers['Subject'], $body, $header_str, '-f'.$headers['From']); if (!$status) $smtp_response[] = 'Mail delivery with mail() failed. Check your error logs for details'; } if ($status) { $RCI->pass('SMTP send'); } else { $RCI->fail('SMTP send', join('; ', $smtp_response)); } } else { $RCI->fail('SMTP send', 'Invalid sender or recipient'); } } echo '

'; ?>
show($_POST['_from']); ?>
show($_POST['_to']); ?>

Test IMAP configuration

get_hostlist(); if (!empty($default_hosts)) { $host_field = new select(array('name' => '_host', 'id' => 'imaphost')); $host_field->add($default_hosts); } else { $host_field = new textfield(array('name' => '_host', 'id' => 'imaphost')); } $user_field = new textfield(array('name' => '_user', 'id' => 'imapuser')); $pass_field = new passwordfield(array('name' => '_pass', 'id' => 'imappass')); ?>
show($_POST['_host']); ?>
Port getprop('default_port'); ?>
show($_POST['_user']); ?>
show(); ?>
Connecting to ' . Q($_POST['_host']) . '...
'; $a_host = parse_url($_POST['_host']); if ($a_host['host']) { $imap_host = $a_host['host']; $imap_ssl = (isset($a_host['scheme']) && in_array($a_host['scheme'], array('ssl','imaps','tls'))) ? $a_host['scheme'] : null; $imap_port = isset($a_host['port']) ? $a_host['port'] : ($imap_ssl ? 993 : $CONFIG['default_port']); } else { $imap_host = trim($_POST['_host']); $imap_port = $RCI->getprop('default_port'); } $imap = new rcube_imap(null); if ($imap->connect($imap_host, $_POST['_user'], $_POST['_pass'], $imap_port, $imap_ssl)) { $RCI->pass('IMAP connect', 'SORT capability: ' . ($imap->get_capability('SORT') ? 'yes' : 'no')); $imap->close(); } else { $RCI->fail('IMAP connect', $RCI->get_error()); } } ?>


After completing the installation and the final tests please remove the whole installer folder from the document root of the webserver.

These files may expose sensitive configuration data like server passwords and encryption keys to the public. Make sure you cannot access this installer from your browser.