Prevent loadApps on upgrade
Moved OC::needUpgrade() to OCP\Util::needUpgrade() to make it accessible form the router. Moved maintenance + upgrade check to the router.
This commit is contained in:
parent
baf46c74cd
commit
799205488c
18
lib/base.php
18
lib/base.php
|
@ -262,15 +262,10 @@ class OC {
|
||||||
* check if the instance needs to preform an upgrade
|
* check if the instance needs to preform an upgrade
|
||||||
*
|
*
|
||||||
* @return bool
|
* @return bool
|
||||||
|
* @deprecated use \OCP\Util::needUpgrade instead
|
||||||
*/
|
*/
|
||||||
public static function needUpgrade() {
|
public static function needUpgrade() {
|
||||||
if (OC_Config::getValue('installed', false)) {
|
return \OCP\Util::needUpgrade();
|
||||||
$installedVersion = OC_Config::getValue('version', '0.0.0');
|
|
||||||
$currentVersion = implode('.', OC_Util::getVersion());
|
|
||||||
return version_compare($currentVersion, $installedVersion, '>');
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -279,7 +274,7 @@ class OC {
|
||||||
* @return bool|void
|
* @return bool|void
|
||||||
*/
|
*/
|
||||||
public static function checkUpgrade($showTemplate = true) {
|
public static function checkUpgrade($showTemplate = true) {
|
||||||
if (self::needUpgrade()) {
|
if (\OCP\Util::needUpgrade()) {
|
||||||
if ($showTemplate && !OC_Config::getValue('maintenance', false)) {
|
if ($showTemplate && !OC_Config::getValue('maintenance', false)) {
|
||||||
$version = OC_Util::getVersion();
|
$version = OC_Util::getVersion();
|
||||||
$oldTheme = OC_Config::getValue('theme');
|
$oldTheme = OC_Config::getValue('theme');
|
||||||
|
@ -595,7 +590,7 @@ class OC {
|
||||||
* register hooks for the cache
|
* register hooks for the cache
|
||||||
*/
|
*/
|
||||||
public static function registerCacheHooks() {
|
public static function registerCacheHooks() {
|
||||||
if (OC_Config::getValue('installed', false) && !self::needUpgrade()) { //don't try to do this before we are properly setup
|
if (OC_Config::getValue('installed', false) && !\OCP\Util::needUpgrade()) { //don't try to do this before we are properly setup
|
||||||
\OCP\BackgroundJob::registerJob('OC\Cache\FileGlobalGC');
|
\OCP\BackgroundJob::registerJob('OC\Cache\FileGlobalGC');
|
||||||
|
|
||||||
// NOTE: This will be replaced to use OCP
|
// NOTE: This will be replaced to use OCP
|
||||||
|
@ -608,7 +603,7 @@ class OC {
|
||||||
* register hooks for the cache
|
* register hooks for the cache
|
||||||
*/
|
*/
|
||||||
public static function registerLogRotate() {
|
public static function registerLogRotate() {
|
||||||
if (OC_Config::getValue('installed', false) && OC_Config::getValue('log_rotate_size', false) && !self::needUpgrade()) {
|
if (OC_Config::getValue('installed', false) && OC_Config::getValue('log_rotate_size', false) && !\OCP\Util::needUpgrade()) {
|
||||||
//don't try to do this before we are properly setup
|
//don't try to do this before we are properly setup
|
||||||
//use custom logfile path if defined, otherwise use default of owncloud.log in data directory
|
//use custom logfile path if defined, otherwise use default of owncloud.log in data directory
|
||||||
\OCP\BackgroundJob::registerJob('OC\Log\Rotate', OC_Config::getValue('logfile', OC_Config::getValue("datadirectory", OC::$SERVERROOT . '/data') . '/owncloud.log'));
|
\OCP\BackgroundJob::registerJob('OC\Log\Rotate', OC_Config::getValue('logfile', OC_Config::getValue("datadirectory", OC::$SERVERROOT . '/data') . '/owncloud.log'));
|
||||||
|
@ -695,10 +690,9 @@ class OC {
|
||||||
|
|
||||||
if (!self::$CLI and (!isset($_GET["logout"]) or ($_GET["logout"] !== 'true'))) {
|
if (!self::$CLI and (!isset($_GET["logout"]) or ($_GET["logout"] !== 'true'))) {
|
||||||
try {
|
try {
|
||||||
if (!OC_Config::getValue('maintenance', false) && !self::needUpgrade()) {
|
if (!OC_Config::getValue('maintenance', false) && !\OCP\Util::needUpgrade()) {
|
||||||
OC_App::loadApps(array('authentication'));
|
OC_App::loadApps(array('authentication'));
|
||||||
OC_App::loadApps(array('filesystem', 'logging'));
|
OC_App::loadApps(array('filesystem', 'logging'));
|
||||||
OC_App::loadApps();
|
|
||||||
}
|
}
|
||||||
self::checkSingleUserMode();
|
self::checkSingleUserMode();
|
||||||
OC::$server->getRouter()->match(OC_Request::getRawPathInfo());
|
OC::$server->getRouter()->match(OC_Request::getRawPathInfo());
|
||||||
|
|
|
@ -192,7 +192,9 @@ class Router implements IRouter {
|
||||||
$this->loadRoutes($app);
|
$this->loadRoutes($app);
|
||||||
} else if (substr($url, 0, 6) === '/core/' or substr($url, 0, 10) === '/settings/') {
|
} else if (substr($url, 0, 6) === '/core/' or substr($url, 0, 10) === '/settings/') {
|
||||||
\OC::$REQUESTEDAPP = $url;
|
\OC::$REQUESTEDAPP = $url;
|
||||||
|
if (!\OC_Config::getValue('maintenance', false) && !\OCP\Util::needUpgrade()) {
|
||||||
\OC_App::loadApps();
|
\OC_App::loadApps();
|
||||||
|
}
|
||||||
$this->loadRoutes('core');
|
$this->loadRoutes('core');
|
||||||
} else {
|
} else {
|
||||||
$this->loadRoutes();
|
$this->loadRoutes();
|
||||||
|
|
|
@ -329,7 +329,7 @@ class OC_Util {
|
||||||
$errors = array();
|
$errors = array();
|
||||||
$CONFIG_DATADIRECTORY = OC_Config::getValue('datadirectory', OC::$SERVERROOT . '/data');
|
$CONFIG_DATADIRECTORY = OC_Config::getValue('datadirectory', OC::$SERVERROOT . '/data');
|
||||||
|
|
||||||
if (!\OC::needUpgrade() && OC_Config::getValue('installed', false)) {
|
if (!self::needUpgrade() && OC_Config::getValue('installed', false)) {
|
||||||
// this check needs to be done every time
|
// this check needs to be done every time
|
||||||
$errors = self::checkDataDirectoryValidity($CONFIG_DATADIRECTORY);
|
$errors = self::checkDataDirectoryValidity($CONFIG_DATADIRECTORY);
|
||||||
}
|
}
|
||||||
|
@ -1356,4 +1356,19 @@ class OC_Util {
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check whether the instance needs to preform an upgrade
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public static function needUpgrade() {
|
||||||
|
if (OC_Config::getValue('installed', false)) {
|
||||||
|
$installedVersion = OC_Config::getValue('version', '0.0.0');
|
||||||
|
$currentVersion = implode('.', OC_Util::getVersion());
|
||||||
|
return version_compare($currentVersion, $installedVersion, '>');
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -516,4 +516,13 @@ class Util {
|
||||||
public static function isPublicLinkPasswordRequired() {
|
public static function isPublicLinkPasswordRequired() {
|
||||||
return \OC_Util::isPublicLinkPasswordRequired();
|
return \OC_Util::isPublicLinkPasswordRequired();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks whether the current version needs upgrade.
|
||||||
|
*
|
||||||
|
* @return bool true if upgrade is needed, false otherwise
|
||||||
|
*/
|
||||||
|
public static function needUpgrade() {
|
||||||
|
return \OC_Util::needUpgrade();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue