aboutsummaryrefslogtreecommitdiffstats
path: root/lib/private
diff options
context:
space:
mode:
authorJoas Schilling <coding@schilljs.com>2019-07-23 10:28:47 +0200
committerRoeland Jago Douma <roeland@famdouma.nl>2019-08-15 11:12:45 +0200
commit810ee7d811c4cf0291add770cb89e5b6d11104b9 (patch)
tree329b6656be47cfeca48239722b55df0a8a1e4bc4 /lib/private
parentf6c34240395bd53e160bdc8bac10e504451553b8 (diff)
downloadnextcloud-server-810ee7d811c4cf0291add770cb89e5b6d11104b9.tar.gz
nextcloud-server-810ee7d811c4cf0291add770cb89e5b6d11104b9.zip
Make the auto-disabled list more broad
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/private')
-rw-r--r--lib/private/App/AppManager.php18
-rw-r--r--lib/private/Updater.php12
-rw-r--r--lib/private/legacy/app.php4
3 files changed, 20 insertions, 14 deletions
diff --git a/lib/private/App/AppManager.php b/lib/private/App/AppManager.php
index db286d7ad7d..322731d677c 100644
--- a/lib/private/App/AppManager.php
+++ b/lib/private/App/AppManager.php
@@ -91,6 +91,9 @@ class AppManager implements IAppManager {
/** @var array */
private $appVersions = [];
+ /** @var array */
+ private $autoDisabledApps = [];
+
/**
* @param IUserSession $userSession
* @param AppConfig $appConfig
@@ -168,6 +171,13 @@ class AppManager implements IAppManager {
}
/**
+ * @return array
+ */
+ public function getAutoDisabledApps(): array {
+ return $this->autoDisabledApps;
+ }
+
+ /**
* @param string $appId
* @return array
*/
@@ -351,12 +361,18 @@ class AppManager implements IAppManager {
* Disable an app for every user
*
* @param string $appId
+ * @param bool $automaticDisabled
* @throws \Exception if app can't be disabled
*/
- public function disableApp($appId) {
+ public function disableApp($appId, $automaticDisabled = false) {
if ($this->isAlwaysEnabled($appId)) {
throw new \Exception("$appId can't be disabled.");
}
+
+ if ($automaticDisabled) {
+ $this->autoDisabledApps[] = $appId;
+ }
+
unset($this->installedAppsCache[$appId]);
$this->appConfig->setValue($appId, 'enabled', 'no');
diff --git a/lib/private/Updater.php b/lib/private/Updater.php
index 87e68b84cf4..d5de1bf6b27 100644
--- a/lib/private/Updater.php
+++ b/lib/private/Updater.php
@@ -75,13 +75,6 @@ class Updater extends BasicEmitter {
];
/**
- * List of appIds that have automatically been disabled during upgrade
- *
- * @var String[]
- */
- private $autoDisabledApps = [];
-
- /**
* @param IConfig $config
* @param Checker $checker
* @param ILogger $log
@@ -263,7 +256,7 @@ class Updater extends BasicEmitter {
// upgrade appstore apps
$this->upgradeAppStoreApps(\OC::$server->getAppManager()->getInstalledApps());
- $autoDisabledApps = array_merge(\OC_App::$autoDisabledApps, $this->autoDisabledApps);
+ $autoDisabledApps = \OC::$server->getAppManager()->getAutoDisabledApps();
$this->upgradeAppStoreApps($autoDisabledApps, true);
// install new shipped apps on upgrade
@@ -412,8 +405,7 @@ class Updater extends BasicEmitter {
if ($appManager->isShipped($app)) {
throw new \UnexpectedValueException('The files of the app "' . $app . '" were not correctly replaced before running the update');
}
- \OC::$server->getAppManager()->disableApp($app);
- $this->autoDisabledApps[] = $app;
+ \OC::$server->getAppManager()->disableApp($app, true);
$this->emit('\OC\Updater', 'incompatibleAppDisabled', array($app));
}
// no need to disable any app in case this is a non-core upgrade
diff --git a/lib/private/legacy/app.php b/lib/private/legacy/app.php
index d495bef2ebd..58b617aae45 100644
--- a/lib/private/legacy/app.php
+++ b/lib/private/legacy/app.php
@@ -70,7 +70,6 @@ class OC_App {
static private $loadedApps = [];
static private $altLogin = [];
static private $alreadyRegistered = [];
- static public $autoDisabledApps = [];
const supportedApp = 300;
const officialApp = 200;
@@ -157,8 +156,7 @@ class OC_App {
\OC::$server->getLogger()->logException($ex);
if (!\OC::$server->getAppManager()->isShipped($app)) {
// Only disable apps which are not shipped
- \OC::$server->getAppManager()->disableApp($app);
- self::$autoDisabledApps[] = $app;
+ \OC::$server->getAppManager()->disableApp($app, true);
}
}
\OC::$server->getEventLogger()->end('load_app_' . $app);