diff options
author | Joas Schilling <coding@schilljs.com> | 2019-03-05 17:55:35 +0100 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2019-03-05 17:55:35 +0100 |
commit | c5ab74348c01593e3f0c3a05701b224b019ecd87 (patch) | |
tree | 8c960cbbcd6edf4bf675461fdef19438a19cd009 /lib | |
parent | a4b34abe45ec407524f2c12beec9af6eaa103afe (diff) | |
download | nextcloud-server-c5ab74348c01593e3f0c3a05701b224b019ecd87.tar.gz nextcloud-server-c5ab74348c01593e3f0c3a05701b224b019ecd87.zip |
Avoid duplicate App container creation
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/private/ServerContainer.php | 13 | ||||
-rw-r--r-- | lib/public/AppFramework/App.php | 7 |
2 files changed, 19 insertions, 1 deletions
diff --git a/lib/private/ServerContainer.php b/lib/private/ServerContainer.php index e1447d2f06b..4c8107fe1be 100644 --- a/lib/private/ServerContainer.php +++ b/lib/private/ServerContainer.php @@ -72,6 +72,19 @@ class ServerContainer extends SimpleContainer { } /** + * @param string $appName + * @return DIContainer + * @throws QueryException + */ + public function getRegisteredAppContainer(string $appName) { + if (isset($this->appContainers[strtolower(App::buildAppNamespace($appName, ''))])) { + return $this->appContainers[strtolower(App::buildAppNamespace($appName, ''))]; + } + + throw new QueryException(); + } + + /** * @param string $namespace * @param string $sensitiveNamespace * @return DIContainer diff --git a/lib/public/AppFramework/App.php b/lib/public/AppFramework/App.php index b6ed2da5076..06524e4bf02 100644 --- a/lib/public/AppFramework/App.php +++ b/lib/public/AppFramework/App.php @@ -66,11 +66,16 @@ class App { /** + * @param string $appName * @param array $urlParams an array with variables extracted from the routes * @since 6.0.0 */ public function __construct(string $appName, array $urlParams = []) { - $this->container = new \OC\AppFramework\DependencyInjection\DIContainer($appName, $urlParams); + try { + $this->container = \OC::$server->getRegisteredAppContainer($appName); + } catch (QueryException $e) { + $this->container = new \OC\AppFramework\DependencyInjection\DIContainer($appName, $urlParams); + } } /** |