| | |
| | | <?php |
| | | |
| | | if (!class_exists('rcube_install') || !is_object($RCI)) { |
| | | die("Not allowed! Please open installer/index.php instead."); |
| | | } |
| | | |
| | | ?> |
| | | <form action="index.php?_step=3" method="post"> |
| | | |
| | | <h3>Check config files</h3> |
| | | <?php |
| | | |
| | | $read_main = is_readable(RCMAIL_CONFIG_DIR.'/main.inc.php'); |
| | | $read_db = is_readable(RCMAIL_CONFIG_DIR.'/db.inc.php'); |
| | | $read_main = is_readable(RCUBE_CONFIG_DIR . 'main.inc.php'); |
| | | $read_db = is_readable(RCUBE_CONFIG_DIR . 'db.inc.php'); |
| | | |
| | | if ($read_main && !empty($RCI->config)) { |
| | | $RCI->pass('main.inc.php'); |
| | |
| | | } |
| | | echo '<br />'; |
| | | |
| | | if ($read_db && !empty($RCI->config['db_table_users'])) { |
| | | if ($read_db && !empty($RCI->config['db_dsnw'])) { |
| | | $RCI->pass('db.inc.php'); |
| | | } |
| | | else if ($read_db) { |
| | |
| | | |
| | | if (is_array($messages['missing'])) { |
| | | echo '<h3 class="warning">Missing config options</h3>'; |
| | | echo '<p class="hint">The following config options are not present in the current configuration.<br/>'; |
| | | echo 'Please check the default config files and add the missing properties to your local config files.</p>'; |
| | | |
| | | echo '<ul class="configwarings">'; |
| | | echo '<p class="hint">The following config options are not set (not present or empty) in the current configuration.<br/>'; |
| | | echo 'Please check the default config files and set the missing properties in your local config files.</p>'; |
| | | |
| | | echo '<ul class="configwarnings">'; |
| | | foreach ($messages['missing'] as $msg) { |
| | | echo html::tag('li', null, html::span('propname', $msg['prop']) . ($msg['name'] ? ': ' . $msg['name'] : '')); |
| | | } |
| | | } |
| | | echo '</ul>'; |
| | | } |
| | | |
| | |
| | | $db_working = false; |
| | | if ($RCI->configured) { |
| | | if (!empty($RCI->config['db_dsnw'])) { |
| | | |
| | | $DB = new rcube_mdb2($RCI->config['db_dsnw'], '', false); |
| | | $DB = rcube_db::factory($RCI->config['db_dsnw'], '', false); |
| | | $DB->db_connect('w'); |
| | | |
| | | if (!($db_error_msg = $DB->is_error())) { |
| | | $RCI->pass('DSN (write)'); |
| | | echo '<br />'; |
| | |
| | | } |
| | | |
| | | else if ($db_working && $_POST['updatedb']) { |
| | | if (!($success = $RCI->update_db($DB, $_POST['version']))) { |
| | | $updatefile = INSTALL_PATH . 'SQL/' . (isset($RCI->db_map[$DB->db_provider]) ? $RCI->db_map[$DB->db_provider] : $DB->db_provider) . '.update.sql'; |
| | | echo '<p class="warning">Please manually execute the SQL statements from '.$updatefile.' on your database.<br/>'; |
| | | echo 'See comments in the file and execute queries below the comment with the currently installed version number.</p>'; |
| | | } |
| | | if (!($success = $RCI->update_db($_POST['version']))) { |
| | | echo '<p class="warning">Database schema update failed.</p>'; |
| | | } |
| | | } |
| | | |
| | | // test database |
| | | if ($db_working) { |
| | | $db_read = $DB->query("SELECT count(*) FROM {$RCI->config['db_table_users']}"); |
| | | if ($DB->db_error) { |
| | | $db_read = $DB->query("SELECT count(*) FROM {$RCI->config['db_prefix']}users"); |
| | | if ($DB->is_error()) { |
| | | $RCI->fail('DB Schema', "Database not initialized"); |
| | | echo '<p><input type="submit" name="initdb" value="Initialize database" /></p>'; |
| | | $db_working = false; |
| | |
| | | $RCI->fail('DB Schema', "Database schema differs"); |
| | | echo '<ul style="margin:0"><li>' . join("</li>\n<li>", $err) . "</li></ul>"; |
| | | $select = $RCI->versions_select(array('name' => 'version')); |
| | | echo '<p class="suggestion">You should run the update queries to get the schmea fixed.<br/><br/>Version to update from: ' . $select->show() . ' <input type="submit" name="updatedb" value="Update" /></p>'; |
| | | // echo '<p class="warning">Please manually execute the SQL statements from '.$updatefile.' on your database.<br/>'; |
| | | // echo 'See comments in the file and execute queries that are superscribed with the currently installed version number.</p>'; |
| | | $select->add('0.9 or newer', ''); |
| | | echo '<p class="suggestion">You should run the update queries to get the schema fixed.<br/><br/>Version to update from: ' . $select->show() . ' <input type="submit" name="updatedb" value="Update" /></p>'; |
| | | $db_working = false; |
| | | } |
| | | else { |
| | |
| | | if ($db_working) { |
| | | // write test |
| | | $insert_id = md5(uniqid()); |
| | | $db_write = $DB->query("INSERT INTO {$RCI->config['db_table_session']} (sess_id, created, ip, vars) VALUES (?, ".$DB->now().", '127.0.0.1', 'foo')", $insert_id); |
| | | $db_write = $DB->query("INSERT INTO {$RCI->config['db_prefix']}session (sess_id, created, ip, vars) VALUES (?, ".$DB->now().", '127.0.0.1', 'foo')", $insert_id); |
| | | |
| | | if ($db_write) { |
| | | $RCI->pass('DB Write'); |
| | | $DB->query("DELETE FROM {$RCI->config['db_table_session']} WHERE sess_id=?", $insert_id); |
| | | $DB->query("DELETE FROM {$RCI->config['db_prefix']}session WHERE sess_id=?", $insert_id); |
| | | } |
| | | else { |
| | | $RCI->fail('DB Write', $RCI->get_error()); |
| | |
| | | } |
| | | |
| | | ?> |
| | | |
| | | <h3>Test filetype detection</h3> |
| | | |
| | | <p> |
| | | <?php |
| | | |
| | | if ($errors = $RCI->check_mime_detection()) { |
| | | $RCI->fail('Fileinfo/mime_content_type configuration'); |
| | | if (!empty($RCI->config['mime_magic'])) { |
| | | echo '<p class="hint">Try setting the <tt>mime_magic</tt> config option to <tt>null</tt>.</p>'; |
| | | } |
| | | else { |
| | | echo '<p class="hint">Check the <a href="http://www.php.net/manual/en/function.finfo-open.php">Fileinfo functions</a> of your PHP installation.<br/>'; |
| | | echo 'The path to the magic.mime file can be set using the <tt>mime_magic</tt> config option in Roundcube.</p>'; |
| | | } |
| | | } |
| | | else { |
| | | $RCI->pass('Fileinfo/mime_content_type configuration'); |
| | | } |
| | | |
| | | ?> |
| | | </p> |
| | | <p> |
| | | <?php |
| | | |
| | | if ($errors = $RCI->check_mime_extensions()) { |
| | | $RCI->fail('Mimetype to file extension mapping'); |
| | | echo '<p class="hint">Please set a valid path to your webserver\'s mime.types file to the <tt>mime_types</tt> config option.<br/>'; |
| | | echo 'If you can\'t find such a file, download it from <a href="http://svn.apache.org/repos/asf/httpd/httpd/trunk/docs/conf/mime.types">svn.apache.org</a>.</p>'; |
| | | } |
| | | else { |
| | | $RCI->pass('Mimetype to file extension mapping'); |
| | | } |
| | | |
| | | ?> |
| | | |
| | | |
| | | <h3>Test SMTP config</h3> |
| | | |
| | |
| | | <?php |
| | | |
| | | if (isset($_POST['imaptest']) && !empty($_POST['_host']) && !empty($_POST['_user'])) { |
| | | |
| | | |
| | | echo '<p>Connecting to ' . Q($_POST['_host']) . '...<br />'; |
| | | |
| | | $a_host = parse_url($_POST['_host']); |
| | | |
| | | $imap_host = trim($_POST['_host']); |
| | | $imap_port = $RCI->getprop('default_port'); |
| | | $a_host = parse_url($imap_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_ssl = (isset($a_host['scheme']) && in_array($a_host['scheme'], array('ssl','imaps','tls'))) ? $a_host['scheme'] : null; |
| | | if (isset($a_host['port'])) |
| | | $imap_port = $a_host['port']; |
| | | else if ($imap_ssl && $imap_ssl != 'tls' && (!$imap_port || $imap_port == 143)) |
| | | $imap_port = 993; |
| | | } |
| | | |
| | | $imap_host = idn_to_ascii($imap_host); |