From 06c01d172009eebe253c59673d25bc6f3595b15a Mon Sep 17 00:00:00 2001 From: thomascube <thomas@roundcube.net> Date: Wed, 22 Jun 2011 01:52:48 -0400 Subject: [PATCH] Trigger keep_alive hook when checking for recent messages, too --- installer/check.php | 178 ++++++++++++++++++++++++++++++++++++++++------------------- 1 files changed, 120 insertions(+), 58 deletions(-) diff --git a/installer/check.php b/installer/check.php index 5776990..944d384 100644 --- a/installer/check.php +++ b/installer/check.php @@ -1,64 +1,96 @@ <form action="index.php" method="get"> <?php -$required_php_exts = array('PCRE' => 'pcre', 'Session' => 'session', 'Sockets' => 'sockets'); - -$optional_php_exts = array('FileInfo' => 'fileinfo', 'Libiconv' => 'iconv', - 'Multibyte' => 'mbstring', 'OpenSSL' => 'openssl', 'Mcrypt' => 'mcrypt', 'GD' => 'gd'); - -$required_libs = array('PEAR' => 'PEAR.php', 'DB' => 'DB.php', 'MDB2' => 'MDB2.php', - 'Net_SMTP' => 'Net/SMTP.php', 'Mail_mime' => 'Mail/mime.php', 'iilConnection' => 'lib/imap.inc'); - -$supported_dbs = array('MySQL' => 'mysql', 'MySQLi' => 'mysqli', - 'PostgreSQL' => 'pgsql', 'SQLite (v2)' => 'sqlite'); - -$ini_checks = array('file_uploads' => 1, 'session.auto_start' => 0, - 'magic_quotes_gpc' => 0, 'magic_quotes_sybase' => 0, - 'zlib.output_compression' => 0); - -$source_urls = array( - 'Sockets' => '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', - 'Mcrypt' => 'http://www.php.net/manual/en/ref.mcrypt.php', - 'OpenSSL' => 'http://www.php.net/manual/en/ref.openssl.php', - 'GD' => 'http://www.php.net/manual/en/ref.image.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' +$required_php_exts = array( + 'PCRE' => 'pcre', + 'DOM' => 'dom', + 'Session' => 'session', + 'XML' => 'xml', + 'JSON' => 'json' ); -echo '<input type="hidden" name="_step" value="' . ($RCI->configured ? 2 : 3) . '" />'; +$optional_php_exts = array( + 'FileInfo' => 'fileinfo', + 'Libiconv' => 'iconv', + 'Multibyte' => 'mbstring', + 'OpenSSL' => 'openssl', + 'Mcrypt' => 'mcrypt', + 'Intl' => 'intl', +); + +$required_libs = array( + 'PEAR' => 'PEAR.php', + 'MDB2' => 'MDB2.php', + 'Net_SMTP' => 'Net/SMTP.php', + 'Net_IDNA2' => 'Net/IDNA2.php', + 'Mail_mime' => 'Mail/mime.php', +); + +$supported_dbs = array( + 'MySQL' => 'mysql', + 'MySQLi' => 'mysqli', + 'PostgreSQL' => 'pgsql', + 'SQLite (v2)' => 'sqlite', +); + +$ini_checks = array( + 'file_uploads' => 1, + 'session.auto_start' => 0, + 'zend.ze1_compatibility_mode' => 0, + 'mbstring.func_overload' => 0, + 'suhosin.session.encrypt' => 0, +); + +$optional_checks = array( + 'date.timezone' => '-NOTEMPTY-', +); + +$source_urls = array( + 'Sockets' => 'http://www.php.net/manual/en/book.sockets.php', + 'Session' => 'http://www.php.net/manual/en/book.session.php', + 'PCRE' => 'http://www.php.net/manual/en/book.pcre.php', + 'FileInfo' => 'http://www.php.net/manual/en/book.fileinfo.php', + 'Libiconv' => 'http://www.php.net/manual/en/book.iconv.php', + 'Multibyte' => 'http://www.php.net/manual/en/book.mbstring.php', + 'Mcrypt' => 'http://www.php.net/manual/en/book.mcrypt.php', + 'OpenSSL' => 'http://www.php.net/manual/en/book.openssl.php', + 'JSON' => 'http://www.php.net/manual/en/book.json.php', + 'DOM' => 'http://www.php.net/manual/en/book.dom.php', + 'Intl' => 'http://www.php.net/manual/en/book.intl.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', +); + +echo '<input type="hidden" name="_step" value="' . ($RCI->configured ? 3 : 2) . '" />'; ?> <h3>Checking PHP version</h3> <?php -if (phpversion() > 4.3) { - $RCI->pass('Version', 'PHP ' . phpversion() . ' detected'); +define('MIN_PHP_VERSION', '5.2.1'); +if (version_compare(PHP_VERSION, MIN_PHP_VERSION, '>=')) { + $RCI->pass('Version', 'PHP ' . PHP_VERSION . ' detected'); +} else { + $RCI->fail('Version', 'PHP Version ' . MIN_PHP_VERSION . ' or greater is required ' . PHP_VERSION . ' detected'); } -else { - $RCI->fail('Version', 'PHP Version 4.3.1 or greater is required'); -} - ?> <h3>Checking PHP extensions</h3> -<p class="hint">The following modules/extensions are <em>required</em> to run RoundCube:</p> +<p class="hint">The following modules/extensions are <em>required</em> to run Roundcube:</p> <?php - + +// get extensions location +$ext_dir = ini_get('extension_dir'); + $prefix = (PHP_SHLIB_SUFFIX === 'dll') ? 'php_' : ''; -foreach ($required_php_exts AS $name => $ext) { +foreach ($required_php_exts as $name => $ext) { if (extension_loaded($ext)) { $RCI->pass($name); - } - else { - $_ext = $prefix . $ext . '.' . PHP_SHLIB_SUFFIX; - $msg = @dl($_ext) ? 'Could be loaded. Please add in php.ini' : ''; + } else { + $_ext = $ext_dir . '/' . $prefix . $ext . '.' . PHP_SHLIB_SUFFIX; + $msg = @is_readable($_ext) ? 'Could be loaded. Please add in php.ini' : ''; $RCI->fail($name, $msg, $source_urls[$name]); } echo '<br />'; @@ -66,16 +98,16 @@ ?> -<p class="hint">These extensions are <em>optional</em> but recommended to get the best performance:</p> +<p class="hint">The next couple of extensions are <em>optional</em> and recommended to get the best performance:</p> <?php -foreach ($optional_php_exts AS $name => $ext) { +foreach ($optional_php_exts as $name => $ext) { if (extension_loaded($ext)) { $RCI->pass($name); } else { - $_ext = $prefix . $ext . '.' . PHP_SHLIB_SUFFIX; - $msg = @dl($_ext) ? 'Could be loaded. Please add in php.ini' : ''; + $_ext = $ext_dir . '/' . $prefix . $ext . '.' . PHP_SHLIB_SUFFIX; + $msg = @is_readable($_ext) ? 'Could be loaded. Please add in php.ini' : ''; $RCI->na($name, $msg, $source_urls[$name]); } echo '<br />'; @@ -90,13 +122,13 @@ <?php $prefix = (PHP_SHLIB_SUFFIX === 'dll') ? 'php_' : ''; -foreach ($supported_dbs AS $database => $ext) { +foreach ($supported_dbs as $database => $ext) { if (extension_loaded($ext)) { $RCI->pass($database); } else { - $_ext = $prefix . $ext . '.' . PHP_SHLIB_SUFFIX; - $msg = @dl($_ext) ? 'Could be loaded. Please add in php.ini' : 'Not installed'; + $_ext = $ext_dir . '/' . $prefix . $ext . '.' . PHP_SHLIB_SUFFIX; + $msg = @is_readable($_ext) ? 'Could be loaded. Please add in php.ini' : 'Not installed'; $RCI->na($database, $msg, $source_urls[$database]); } echo '<br />'; @@ -115,9 +147,6 @@ if (class_exists($classname)) { $RCI->pass($classname); } - else if ($classname == 'DB' || ($classname == 'MDB2' && class_exists('DB'))) { - $RCI->na($classname, 'Use ' . ($classname == 'DB' ? 'MDB2' : 'DB') . ' instead'); - } else { $RCI->fail($classname, "Failed to load $file", $source_urls[$classname]); } @@ -128,16 +157,49 @@ ?> <h3>Checking php.ini/.htaccess settings</h3> +<p class="hint">The following settings are <em>required</em> to run Roundcube:</p> <?php foreach ($ini_checks as $var => $val) { $status = ini_get($var); + if ($val === '-NOTEMPTY-') { + if (empty($status)) { + $RCI->fail($var, "cannot be empty and needs to be set"); + } else { + $RCI->pass($var); + } + echo '<br />'; + continue; + } if ($status == $val) { $RCI->pass($var); - } - else { + } else { $RCI->fail($var, "is '$status', should be '$val'"); + } + echo '<br />'; +} +?> + +<p class="hint">The following settings are <em>optional</em> and recommended:</p> + +<?php + +foreach ($optional_checks as $var => $val) { + $status = ini_get($var); + if ($val === '-NOTEMPTY-') { + if (empty($status)) { + $RCI->optfail($var, "Could be set"); + } else { + $RCI->pass($var); + } + echo '<br />'; + continue; + } + if ($status == $val) { + $RCI->pass($var); + } else { + $RCI->optfail($var, "is '$status', could be '$val'"); } echo '<br />'; } @@ -145,11 +207,11 @@ <?php -if ($RCI->failures) - echo '<p class="warning">Sorry but your webserver does not meet the requirements for RoundCube!<br /> +if ($RCI->failures) { + echo '<p class="warning">Sorry but your webserver does not meet the requirements for Roundcube!<br /> Please install the missing modules or fix the php.ini settings according to the above check results.<br /> Hint: only checks showing <span class="fail">NOT OK</span> need to be fixed.</p>'; - +} echo '<p><br /><input type="submit" value="NEXT" ' . ($RCI->failures ? 'disabled' : '') . ' /></p>'; ?> -- Gitblit v1.9.1