|
|
|
#!/usr/bin/env php
|
|
|
|
<?php
|
|
|
|
/*
|
|
|
|
+-----------------------------------------------------------------------+
|
|
|
|
| bin/update.sh |
|
|
|
|
| |
|
|
|
|
| This file is part of the Roundcube Webmail client |
|
|
|
|
| Copyright (C) 2010-2011, The Roundcube Dev Team |
|
|
|
|
| |
|
|
|
|
| Licensed under the GNU General Public License version 3 or |
|
|
|
|
| any later version with exceptions for skins & plugins. |
|
|
|
|
| See the README file for a full license statement. |
|
|
|
|
| |
|
|
|
|
| PURPOSE: |
|
|
|
|
| Check local configuration and database schema after upgrading |
|
|
|
|
| to a new version |
|
|
|
|
+-----------------------------------------------------------------------+
|
|
|
|
| Author: Thomas Bruederli <roundcube@gmail.com> |
|
|
|
|
+-----------------------------------------------------------------------+
|
|
|
|
*/
|
|
|
|
|
|
|
|
define('INSTALL_PATH', realpath(dirname(__FILE__) . '/..') . '/' );
|
|
|
|
|
|
|
|
require_once INSTALL_PATH . 'program/include/clisetup.php';
|
|
|
|
require_once INSTALL_PATH . 'installer/rcube_install.php';
|
|
|
|
|
|
|
|
// get arguments
|
|
|
|
$opts = rcube_utils::get_opt(array('v' => 'version'));
|
|
|
|
|
|
|
|
// ask user if no version is specified
|
|
|
|
if (!$opts['version']) {
|
|
|
|
echo "What version are you upgrading from? Type '?' if you don't know.\n";
|
|
|
|
if (($input = trim(fgets(STDIN))) && preg_match('/^[0-9.]+[a-z-]*$/', $input))
|
|
|
|
$opts['version'] = $input;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($opts['version'] && version_compare($opts['version'], RCMAIL_VERSION, '>'))
|
|
|
|
die("Nothing to be done here. Bye!\n");
|
|
|
|
|
|
|
|
|
|
|
|
$RCI = rcube_install::get_instance();
|
|
|
|
$RCI->load_config();
|
|
|
|
|
|
|
|
if ($RCI->configured) {
|
|
|
|
$success = true;
|
|
|
|
|
|
|
|
if ($messages = $RCI->check_config()) {
|
|
|
|
$success = false;
|
|
|
|
$err = 0;
|
|
|
|
|
|
|
|
// list missing config options
|
|
|
|
if (is_array($messages['missing'])) {
|
|
|
|
echo "WARNING: Missing config options:\n";
|
|
|
|
echo "(These config options should be present in the current configuration)\n";
|
|
|
|
|
|
|
|
foreach ($messages['missing'] as $msg) {
|
|
|
|
echo "- '" . $msg['prop'] . ($msg['name'] ? "': " . $msg['name'] : "'") . "\n";
|
|
|
|
$err++;
|
|
|
|
}
|
|
|
|
echo "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
// list old/replaced config options
|
|
|
|
if (is_array($messages['replaced'])) {
|
|
|
|
echo "WARNING: Replaced config options:\n";
|
|
|
|
echo "(These config options have been replaced or renamed)\n";
|
|
|
|
|
|
|
|
foreach ($messages['replaced'] as $msg) {
|
|
|
|
echo "- '" . $msg['prop'] . "' was replaced by '" . $msg['replacement'] . "'\n";
|
|
|
|
$err++;
|
|
|
|
}
|
|
|
|
echo "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
// list obsolete config options (just a notice)
|
|
|
|
if (is_array($messages['obsolete'])) {
|
|
|
|
echo "NOTICE: Obsolete config options:\n";
|
|
|
|
echo "(You still have some obsolete or inexistent properties set. This isn't a problem but should be noticed)\n";
|
|
|
|
|
|
|
|
foreach ($messages['obsolete'] as $msg) {
|
|
|
|
echo "- '" . $msg['prop'] . ($msg['name'] ? "': " . $msg['name'] : "'") . "\n";
|
|
|
|
$err++;
|
|
|
|
}
|
|
|
|
echo "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
// ask user to update config files
|
|
|
|
if ($err) {
|
|
|
|
echo "Do you want me to fix your local configuration? (y/N)\n";
|
|
|
|
$input = trim(fgets(STDIN));
|
|
|
|
|
|
|
|
// positive: let's merge the local config with the defaults
|
|
|
|
if (strtolower($input) == 'y') {
|
|
|
|
$copy1 = $copy2 = $write1 = $write2 = false;
|
|
|
|
|
|
|
|
// backup current config
|
|
|
|
echo ". backing up the current config files...\n";
|
|
|
|
$copy1 = copy(RCMAIL_CONFIG_DIR . '/main.inc.php', RCMAIL_CONFIG_DIR . '/main.old.php');
|
|
|
|
$copy2 = copy(RCMAIL_CONFIG_DIR . '/db.inc.php', RCMAIL_CONFIG_DIR . '/db.old.php');
|
|
|
|
|
|
|
|
if ($copy1 && $copy2) {
|
|
|
|
$RCI->merge_config();
|
|
|
|
|
|
|
|
echo ". writing " . RCMAIL_CONFIG_DIR . "/main.inc.php...\n";
|
|
|
|
$write1 = file_put_contents(RCMAIL_CONFIG_DIR . '/main.inc.php', $RCI->create_config('main', true));
|
|
|
|
echo ". writing " . RCMAIL_CONFIG_DIR . "/main.db.php...\n";
|
|
|
|
$write2 = file_put_contents(RCMAIL_CONFIG_DIR . '/db.inc.php', $RCI->create_config('db', true));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Success!
|
|
|
|
if ($write1 && $write2) {
|
|
|
|
echo "Done.\n";
|
|
|
|
echo "Your configuration files are now up-to-date!\n";
|
|
|
|
|
|
|
|
if ($messages['missing']) {
|
|
|
|
echo "But you still need to add the following missing options:\n";
|
|
|
|
foreach ($messages['missing'] as $msg)
|
|
|
|
echo "- '" . $msg['prop'] . ($msg['name'] ? "': " . $msg['name'] : "'") . "\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
echo "Failed to write config files!\n";
|
|
|
|
echo "Grant write privileges to the current user or update the files manually according to the above messages.\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
echo "Please update your config files manually according to the above messages.\n\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// check dependencies based on the current configuration
|
|
|
|
if (is_array($messages['dependencies'])) {
|
|
|
|
echo "WARNING: Dependency check failed!\n";
|
|
|
|
echo "(Some of your configuration settings require other options to be configured or additional PHP modules to be installed)\n";
|
|
|
|
|
|
|
|
foreach ($messages['dependencies'] as $msg) {
|
|
|
|
echo "- " . $msg['prop'] . ': ' . $msg['explain'] . "\n";
|
|
|
|
}
|
|
|
|
echo "Please fix your config files and run this script again!\n";
|
|
|
|
echo "See ya.\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// check database schema
|
|
|
|
if ($RCI->config['db_dsnw']) {
|
|
|
|
$DB = rcube_db::factory($RCI->config['db_dsnw'], '', false);
|
|
|
|
$DB->db_connect('w');
|
|
|
|
if ($db_error_msg = $DB->is_error()) {
|
|
|
|
echo "Error connecting to database: $db_error_msg\n";
|
|
|
|
$success = false;
|
|
|
|
}
|
|
|
|
else if ($err = $RCI->db_schema_check($DB, false)) {
|
|
|
|
$updatefile = INSTALL_PATH . 'SQL/' . (isset($RCI->db_map[$DB->db_provider]) ? $RCI->db_map[$DB->db_provider] : $DB->db_provider) . '.update.sql';
|
|
|
|
echo "WARNING: Database schema needs to be updated!\n";
|
|
|
|
echo join("\n", $err) . "\n\n";
|
|
|
|
$success = false;
|
|
|
|
|
|
|
|
if ($opts['version']) {
|
|
|
|
echo "Do you want to run the update queries to get the schmea fixed? (y/N)\n";
|
|
|
|
$input = trim(fgets(STDIN));
|
|
|
|
if (strtolower($input) == 'y') {
|
|
|
|
$success = $RCI->update_db($DB, $opts['version']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$success)
|
|
|
|
echo "Open $updatefile and execute all queries below the comment with the currently installed version number.\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// index contacts for fulltext searching
|
|
|
|
if (version_compare($opts['version'], '0.6', '<')) {
|
|
|
|
system(INSTALL_PATH . 'bin/indexcontacts.sh');
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($success) {
|
|
|
|
echo "This instance of Roundcube is up-to-date.\n";
|
|
|
|
echo "Have fun!\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
echo "This instance of Roundcube is not yet configured!\n";
|
|
|
|
echo "Open http://url-to-roundcube/installer/ in your browser and follow the instuctions.\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
echo "\n";
|
|
|
|
|
|
|
|
?>
|