aboutsummaryrefslogtreecommitdiff
path: root/upgrade.php
diff options
context:
space:
mode:
authorBrett Profitt <brett.profitt@gmail.com>2012-12-16 17:32:01 -0500
committerBrett Profitt <brett.profitt@gmail.com>2012-12-16 17:32:01 -0500
commitcc0f1ddad2fac1d1761d59a818f1c41d7db6ed0d (patch)
tree322d7a5e3104a17b64d65a12ce1478a14ced4cb1 /upgrade.php
parentd719d03f1b0e636db021e728cf79a10176d991da (diff)
parent22e8d9be4582b78a500382e14046a653a14e3f43 (diff)
downloadelgg-cc0f1ddad2fac1d1761d59a818f1c41d7db6ed0d.tar.gz
elgg-cc0f1ddad2fac1d1761d59a818f1c41d7db6ed0d.tar.bz2
Merge branch 'pr-309' into 1.8
Diffstat (limited to 'upgrade.php')
-rw-r--r--upgrade.php13
1 files changed, 12 insertions, 1 deletions
diff --git a/upgrade.php b/upgrade.php
index 60764ba93..c5f158c61 100644
--- a/upgrade.php
+++ b/upgrade.php
@@ -9,6 +9,8 @@
* new version of the script. Deleting the script is not a requirement and
* leaving it behind does not affect the security of the site.
*
+ * Upgrades use a table {db_prefix}upgrade_lock as a mutex to prevent concurrent upgrades.
+ *
* @package Elgg.Core
* @subpackage Upgrade
*/
@@ -20,6 +22,12 @@ define('UPGRADING', 'upgrading');
require_once(dirname(__FILE__) . "/engine/start.php");
if (get_input('upgrade') == 'upgrade') {
+ // prevent someone from running the upgrade script in parallel (see #4643)
+ if (!_elgg_upgrade_lock()) {
+ register_error(elgg_echo('upgrade:locked'));
+ forward();
+ }
+
// disable the system log for upgrades to avoid exceptions when the schema changes.
elgg_unregister_event_handler('log', 'systemlog', 'system_log_default_logger');
elgg_unregister_event_handler('all', 'all', 'system_log_listener');
@@ -33,6 +41,9 @@ if (get_input('upgrade') == 'upgrade') {
elgg_trigger_event('upgrade', 'system', null);
elgg_invalidate_simplecache();
elgg_reset_system_cache();
+
+ _elgg_upgrade_unlock();
+
} else {
// if upgrading from < 1.8.0, check for the core view 'welcome' and bail if it's found.
// see http://trac.elgg.org/ticket/3064
@@ -53,4 +64,4 @@ if (get_input('upgrade') == 'upgrade') {
exit;
}
-forward(); \ No newline at end of file
+forward();