summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2020-07-22 20:38:50 +0200
committerGitHub <noreply@github.com>2020-07-22 20:38:50 +0200
commit346f647962e00b1f5e5f19a8526c88a09ebca59e (patch)
tree64f324cb5ff04f29247bf00f32e84bc7c8f4ed36
parentc842678f0a1fb65981a03302895192ddc58479c9 (diff)
parent7870ca06637453f4e72dbd67edbfb3603d813196 (diff)
downloadnextcloud-server-346f647962e00b1f5e5f19a8526c88a09ebca59e.tar.gz
nextcloud-server-346f647962e00b1f5e5f19a8526c88a09ebca59e.zip
Merge pull request #21870 from nextcloud/fix/bootstrap-context-container-interfaces
Make the bootstrap context return ContainerInterface instances
-rw-r--r--apps/admin_audit/lib/AppInfo/Application.php35
-rw-r--r--apps/comments/lib/AppInfo/Application.php11
-rw-r--r--apps/comments/lib/JSSettingsHelper.php8
-rw-r--r--apps/comments/tests/Unit/JSSettingsHelperTest.php16
-rw-r--r--apps/federatedfilesharing/lib/AppInfo/Application.php20
-rw-r--r--apps/files/lib/AppInfo/Application.php34
-rw-r--r--apps/lookup_server_connector/lib/AppInfo/Application.php19
-rw-r--r--apps/settings/lib/AppInfo/Application.php77
-rw-r--r--apps/systemtags/lib/AppInfo/Application.php56
-rw-r--r--apps/twofactor_backupcodes/lib/AppInfo/Application.php5
-rw-r--r--apps/updatenotification/lib/AppInfo/Application.php62
-rw-r--r--apps/user_ldap/lib/AppInfo/Application.php84
-rw-r--r--apps/workflowengine/lib/AppInfo/Application.php7
-rw-r--r--lib/private/AppFramework/Bootstrap/BootContext.php2
-rw-r--r--lib/private/AppFramework/Bootstrap/FunctionInjector.php10
-rw-r--r--lib/public/AppFramework/Bootstrap/IBootContext.php3
-rw-r--r--tests/lib/AppFramework/Bootstrap/BootContextTest.php3
17 files changed, 236 insertions, 216 deletions
diff --git a/apps/admin_audit/lib/AppInfo/Application.php b/apps/admin_audit/lib/AppInfo/Application.php
index 6c79aef84c8..b63c361b51f 100644
--- a/apps/admin_audit/lib/AppInfo/Application.php
+++ b/apps/admin_audit/lib/AppInfo/Application.php
@@ -37,7 +37,6 @@ use Closure;
use OC\Files\Filesystem;
use OC\Files\Node\File;
use OC\Group\Manager;
-use OC\User\Session;
use OCA\AdminAudit\Actions\AppManagement;
use OCA\AdminAudit\Actions\Auth;
use OCA\AdminAudit\Actions\Console;
@@ -64,6 +63,7 @@ use OCP\IUserSession;
use OCP\Log\ILogFactory;
use OCP\Share;
use OCP\Util;
+use Symfony\Component\EventDispatcher\EventDispatcherInterface;
use Symfony\Component\EventDispatcher\GenericEvent;
class Application extends App implements IBootstrap {
@@ -108,43 +108,42 @@ class Application extends App implements IBootstrap {
*/
private function registerHooks(ILogger $logger,
IServerContainer $serverContainer) {
- $this->userManagementHooks($logger, $serverContainer);
- $this->groupHooks($logger, $serverContainer);
+ $this->userManagementHooks($logger, $serverContainer->get(IUserSession::class));
+ $this->groupHooks($logger, $serverContainer->get(IGroupManager::class));
$this->authHooks($logger);
- $this->consoleHooks($logger, $serverContainer);
- $this->appHooks($logger, $serverContainer);
+ /** @var EventDispatcherInterface $eventDispatcher */
+ $eventDispatcher = $serverContainer->get(EventDispatcherInterface::class);
+ $this->consoleHooks($logger, $eventDispatcher);
+ $this->appHooks($logger, $eventDispatcher);
$this->sharingHooks($logger);
- $this->fileHooks($logger, $serverContainer);
+ $this->fileHooks($logger, $eventDispatcher);
$this->trashbinHooks($logger);
$this->versionsHooks($logger);
- $this->securityHooks($logger, $serverContainer);
+ $this->securityHooks($logger, $eventDispatcher);
}
private function userManagementHooks(ILogger $logger,
- IServerContainer $serverContainer) {
+ IUserSession $userSession) {
$userActions = new UserManagement($logger);
Util::connectHook('OC_User', 'post_createUser', $userActions, 'create');
Util::connectHook('OC_User', 'post_deleteUser', $userActions, 'delete');
Util::connectHook('OC_User', 'changeUser', $userActions, 'change');
- /** @var IUserSession|Session $userSession */
- $userSession = $serverContainer->getUserSession();
$userSession->listen('\OC\User', 'postSetPassword', [$userActions, 'setPassword']);
$userSession->listen('\OC\User', 'assignedUserId', [$userActions, 'assign']);
$userSession->listen('\OC\User', 'postUnassignedUserId', [$userActions, 'unassign']);
}
private function groupHooks(ILogger $logger,
- IServerContainer $serverContainer) {
+ IGroupManager $groupManager) {
$groupActions = new GroupManagement($logger);
/** @var IGroupManager|Manager $groupManager */
- $groupManager = $serverContainer->getGroupManager();
$groupManager->listen('\OC\Group', 'postRemoveUser', [$groupActions, 'removeUser']);
$groupManager->listen('\OC\Group', 'postAddUser', [$groupActions, 'addUser']);
$groupManager->listen('\OC\Group', 'postDelete', [$groupActions, 'deleteGroup']);
@@ -172,8 +171,7 @@ class Application extends App implements IBootstrap {
}
private function appHooks(ILogger $logger,
- IServerContainer $serverContainer) {
- $eventDispatcher = $serverContainer->getEventDispatcher();
+ EventDispatcherInterface $eventDispatcher) {
$eventDispatcher->addListener(ManagerEvent::EVENT_APP_ENABLE, function (ManagerEvent $event) use ($logger) {
$appActions = new AppManagement($logger);
$appActions->enableApp($event->getAppID());
@@ -189,8 +187,7 @@ class Application extends App implements IBootstrap {
}
private function consoleHooks(ILogger $logger,
- IServerContainer $serverContainer) {
- $eventDispatcher = $serverContainer->getEventDispatcher();
+ EventDispatcherInterface $eventDispatcher) {
$eventDispatcher->addListener(ConsoleEvent::EVENT_RUN, function (ConsoleEvent $event) use ($logger) {
$appActions = new Console($logger);
$appActions->runCommand($event->getArguments());
@@ -198,9 +195,8 @@ class Application extends App implements IBootstrap {
}
private function fileHooks(ILogger $logger,
- IServerContainer $serverContainer) {
+ EventDispatcherInterface $eventDispatcher) {
$fileActions = new Files($logger);
- $eventDispatcher = $serverContainer->getEventDispatcher();
$eventDispatcher->addListener(
IPreview::EVENT,
function (GenericEvent $event) use ($fileActions) {
@@ -273,8 +269,7 @@ class Application extends App implements IBootstrap {
}
private function securityHooks(ILogger $logger,
- IServerContainer $serverContainer) {
- $eventDispatcher = $serverContainer->getEventDispatcher();
+ EventDispatcherInterface $eventDispatcher) {
$eventDispatcher->addListener(IProvider::EVENT_SUCCESS, function (GenericEvent $event) use ($logger) {
$security = new Security($logger);
$security->twofactorSuccess($event->getSubject(), $event->getArguments());
diff --git a/apps/comments/lib/AppInfo/Application.php b/apps/comments/lib/AppInfo/Application.php
index fafac0c6040..247ba034107 100644
--- a/apps/comments/lib/AppInfo/Application.php
+++ b/apps/comments/lib/AppInfo/Application.php
@@ -27,6 +27,7 @@
namespace OCA\Comments\AppInfo;
+use Closure;
use OCA\Comments\Capabilities;
use OCA\Comments\Controller\Notifications;
use OCA\Comments\EventHandler;
@@ -44,6 +45,8 @@ use OCP\AppFramework\Bootstrap\IBootContext;
use OCP\AppFramework\Bootstrap\IBootstrap;
use OCP\AppFramework\Bootstrap\IRegistrationContext;
use OCP\Comments\CommentsEntityEvent;
+use OCP\IConfig;
+use OCP\ISearch;
use OCP\IServerContainer;
use OCP\Util;
@@ -75,13 +78,13 @@ class Application extends App implements IBootstrap {
}
public function boot(IBootContext $context): void {
- $this->registerNotifier($context->getServerContainer());
- $this->registerCommentsEventHandler($context->getServerContainer());
+ $context->injectFn(Closure::fromCallable([$this, 'registerNotifier']));
+ $context->injectFn(Closure::fromCallable([$this, 'registerCommentsEventHandler']));
- $jsSettingsHelper = new JSSettingsHelper($context->getServerContainer());
+ $jsSettingsHelper = new JSSettingsHelper($context->getAppContainer()->get(IConfig::class));
Util::connectHook('\OCP\Config', 'js', $jsSettingsHelper, 'extend');
- $context->getServerContainer()->getSearch()->registerProvider(LegacyProvider::class, ['apps' => ['files']]);
+ $context->getServerContainer()->get(ISearch::class)->registerProvider(LegacyProvider::class, ['apps' => ['files']]);
}
protected function registerNotifier(IServerContainer $container) {
diff --git a/apps/comments/lib/JSSettingsHelper.php b/apps/comments/lib/JSSettingsHelper.php
index 4c54bb07c1c..93578e06295 100644
--- a/apps/comments/lib/JSSettingsHelper.php
+++ b/apps/comments/lib/JSSettingsHelper.php
@@ -23,20 +23,20 @@
namespace OCA\Comments;
-use OCP\IServerContainer;
+use OCP\IConfig;
class JSSettingsHelper {
- /** @var IServerContainer */
+ /** @var IConfig */
private $c;
- public function __construct(IServerContainer $c) {
+ public function __construct(IConfig $c) {
$this->c = $c;
}
public function extend(array $settings) {
$appConfig = json_decode($settings['array']['oc_appconfig'], true);
- $value = (int)$this->c->getConfig()->getAppValue('comments', 'maxAutoCompleteResults', 10);
+ $value = (int)$this->c->getAppValue('comments', 'maxAutoCompleteResults', 10);
$appConfig['comments']['maxAutoCompleteResults'] = $value;
$settings['array']['oc_appconfig'] = json_encode($appConfig);
diff --git a/apps/comments/tests/Unit/JSSettingsHelperTest.php b/apps/comments/tests/Unit/JSSettingsHelperTest.php
index 26cdee1f26b..94d13a77d94 100644
--- a/apps/comments/tests/Unit/JSSettingsHelperTest.php
+++ b/apps/comments/tests/Unit/JSSettingsHelperTest.php
@@ -1,4 +1,7 @@
<?php
+
+declare(strict_types=1);
+
/**
* @copyright Copyright (c) 2017 Arthur Schiwon <blizzz@arthur-schiwon.de>
*
@@ -26,11 +29,11 @@ namespace OCA\Comments\Tests\Unit;
use OCA\Comments\JSSettingsHelper;
use OCP\IConfig;
-use OCP\IServerContainer;
+use PHPUnit\Framework\MockObject\MockObject;
use Test\TestCase;
class JSSettingsHelperTest extends TestCase {
- /** @var IServerContainer|\PHPUnit_Framework_MockObject_MockObject */
+ /** @var IConfig|MockObject */
protected $c;
/** @var JSSettingsHelper */
protected $helper;
@@ -38,22 +41,17 @@ class JSSettingsHelperTest extends TestCase {
protected function setUp(): void {
parent::setUp();
- $this->c = $this->createMock(IServerContainer::class);
+ $this->c = $this->createMock(IConfig::class);
$this->helper = new JSSettingsHelper($this->c);
}
public function testExtend() {
- $config = $this->createMock(IConfig::class);
- $config->expects($this->once())
+ $this->c->expects($this->once())
->method('getAppValue')
->with('comments', 'maxAutoCompleteResults')
->willReturn(13);
- $this->c->expects($this->once())
- ->method('getConfig')
- ->willReturn($config);
-
$config = [
'oc_appconfig' => json_encode([
'anotherapp' => [
diff --git a/apps/federatedfilesharing/lib/AppInfo/Application.php b/apps/federatedfilesharing/lib/AppInfo/Application.php
index 09f881d5bb8..48907a88447 100644
--- a/apps/federatedfilesharing/lib/AppInfo/Application.php
+++ b/apps/federatedfilesharing/lib/AppInfo/Application.php
@@ -28,6 +28,7 @@
namespace OCA\FederatedFileSharing\AppInfo;
+use Closure;
use OCA\FederatedFileSharing\Listeners\LoadAdditionalScriptsListener;
use OCA\FederatedFileSharing\Notifier;
use OCA\FederatedFileSharing\OCM\CloudFederationProviderFiles;
@@ -36,6 +37,9 @@ use OCP\AppFramework\App;
use OCP\AppFramework\Bootstrap\IBootContext;
use OCP\AppFramework\Bootstrap\IBootstrap;
use OCP\AppFramework\Bootstrap\IRegistrationContext;
+use OCP\AppFramework\IAppContainer;
+use OCP\Federation\ICloudFederationProviderManager;
+use OCP\Notification\IManager as INotifiactionManager;
class Application extends App implements IBootstrap {
public function __construct() {
@@ -47,16 +51,20 @@ class Application extends App implements IBootstrap {
}
public function boot(IBootContext $context): void {
- $server = $context->getServerContainer();
+ $context->injectFn(Closure::fromCallable([$this, 'registerCloudFederationProvider']));
+ $context->injectFn(Closure::fromCallable([$this, 'registerNotificationManager']));
+ }
- $cloudFederationManager = $server->getCloudFederationProviderManager();
- $cloudFederationManager->addCloudFederationProvider('file',
+ private function registerCloudFederationProvider(ICloudFederationProviderManager $manager,
+ IAppContainer $appContainer): void {
+ $manager->addCloudFederationProvider('file',
'Federated Files Sharing',
- function () use ($server) {
- return $server->query(CloudFederationProviderFiles::class);
+ function () use ($appContainer) {
+ return $appContainer->get(CloudFederationProviderFiles::class);
});
+ }
- $manager = $server->getNotificationManager();
+ private function registerNotificationManager(INotifiactionManager $manager): void {
$manager->registerNotifierService(Notifier::class);
}
}
diff --git a/apps/files/lib/AppInfo/Application.php b/apps/files/lib/AppInfo/Application.php
index 9500f91fdf9..08ec9fbbcc4 100644
--- a/apps/files/lib/AppInfo/Application.php
+++ b/apps/files/lib/AppInfo/Application.php
@@ -34,6 +34,7 @@ declare(strict_types=1);
namespace OCA\Files\AppInfo;
+use Closure;
use OC\Search\Provider\File;
use OCA\Files\Capabilities;
use OCA\Files\Collaboration\Resources\Listener;
@@ -53,6 +54,7 @@ use OCP\AppFramework\Bootstrap\IRegistrationContext;
use OCP\Collaboration\Resources\IProviderManager;
use OCP\IContainer;
use OCP\IL10N;
+use OCP\ISearch;
use OCP\IServerContainer;
use OCP\Notification\IManager;
use OCP\Util;
@@ -112,35 +114,25 @@ class Application extends App implements IBootstrap {
}
public function boot(IBootContext $context): void {
- $this->registerCollaboration($context);
- Listener::register($context->getServerContainer()->getEventDispatcher());
- $this->registerNotification($context);
- $this->registerSearchProvider($context);
+ $context->injectFn(Closure::fromCallable([$this, 'registerCollaboration']));
+ $context->injectFn([Listener::class, 'register']);
+ $context->injectFn(Closure::fromCallable([$this, 'registerNotification']));
+ $context->injectFn(Closure::fromCallable([$this, 'registerSearchProvider']));
$this->registerTemplates();
- $this->registerNavigation($context);
+ $context->injectFn(Closure::fromCallable([$this, 'registerNavigation']));
$this->registerHooks();
}
- /**
- * Register Collaboration ResourceProvider
- */
- private function registerCollaboration(IBootContext $context): void {
- /** @var IProviderManager $providerManager */
- $providerManager = $context->getAppContainer()->query(IProviderManager::class);
+ private function registerCollaboration(IProviderManager $providerManager): void {
$providerManager->registerResourceProvider(ResourceProvider::class);
}
- private function registerNotification(IBootContext $context): void {
- /** @var IManager $notifications */
- $notifications = $context->getAppContainer()->query(IManager::class);
+ private function registerNotification(IManager $notifications): void {
$notifications->registerNotifierService(Notifier::class);
}
- /**
- * @param IBootContext $context
- */
- private function registerSearchProvider(IBootContext $context): void {
- $context->getServerContainer()->getSearch()->registerProvider(File::class, ['apps' => ['files']]);
+ private function registerSearchProvider(ISearch $search): void {
+ $search->registerProvider(File::class, ['apps' => ['files']]);
}
private function registerTemplates(): void {
@@ -150,9 +142,7 @@ class Application extends App implements IBootstrap {
$templateManager->registerTemplate('application/vnd.oasis.opendocument.spreadsheet', 'core/templates/filetemplates/template.ods');
}
- private function registerNavigation(IBootContext $context): void {
- /** @var IL10N $l10n */
- $l10n = $context->getAppContainer()->query(IL10N::class);
+ private function registerNavigation(IL10N $l10n): void {
\OCA\Files\App::getNavigationManager()->add(function () use ($l10n) {
return [
'id' => 'files',
diff --git a/apps/lookup_server_connector/lib/AppInfo/Application.php b/apps/lookup_server_connector/lib/AppInfo/Application.php
index c2bb61000c1..cc51dff5cf0 100644
--- a/apps/lookup_server_connector/lib/AppInfo/Application.php
+++ b/apps/lookup_server_connector/lib/AppInfo/Application.php
@@ -28,11 +28,14 @@ declare(strict_types=1);
namespace OCA\LookupServerConnector\AppInfo;
+use Closure;
use OCA\LookupServerConnector\UpdateLookupServer;
use OCP\AppFramework\App;
use OCP\AppFramework\Bootstrap\IBootContext;
use OCP\AppFramework\Bootstrap\IBootstrap;
use OCP\AppFramework\Bootstrap\IRegistrationContext;
+use OCP\EventDispatcher\IEventDispatcher;
+use OCP\AppFramework\IAppContainer;
use OCP\IUser;
use Symfony\Component\EventDispatcher\GenericEvent;
@@ -47,16 +50,20 @@ class Application extends App implements IBootstrap {
}
public function boot(IBootContext $context): void {
- /*
- * @todo move the OCP events and then move the registration to `register`
- */
- $dispatcher = $context->getServerContainer()->getEventDispatcher();
- $dispatcher->addListener('OC\AccountManager::userUpdated', function (GenericEvent $event) use ($context) {
+ $context->injectFn(Closure::fromCallable([$this, 'registerEventListeners']));
+ }
+
+ /**
+ * @todo move the OCP events and then move the registration to `register`
+ */
+ private function registerEventListeners(IEventDispatcher $dispatcher,
+ IAppContainer $appContainer): void {
+ $dispatcher->addListener('OC\AccountManager::userUpdated', function (GenericEvent $event) use ($appContainer) {
/** @var IUser $user */
$user = $event->getSubject();
/** @var UpdateLookupServer $updateLookupServer */
- $updateLookupServer = $context->getServerContainer()->query(UpdateLookupServer::class);
+ $updateLookupServer = $appContainer->get(UpdateLookupServer::class);
$updateLookupServer->userUpdated($user);
});
}
diff --git a/apps/settings/lib/AppInfo/Application.php b/apps/settings/lib/AppInfo/Application.php
index 73db869bc6a..6e6eb26d011 100644
--- a/apps/settings/lib/AppInfo/Application.php
+++ b/apps/settings/lib/AppInfo/Application.php
@@ -40,6 +40,7 @@ use BadMethodCallException;
use OC\AppFramework\Utility\TimeFactory;
use OC\Authentication\Token\IProvider;
use OC\Authentication\Token\IToken;
+use OC\Group\Manager;
use OC\Server;
use OCA\Settings\Activity\Provider;
use OCA\Settings\Hooks;
@@ -50,14 +51,15 @@ use OCP\AppFramework\App;
use OCP\AppFramework\Bootstrap\IBootContext;
use OCP\AppFramework\Bootstrap\IBootstrap;
use OCP\AppFramework\Bootstrap\IRegistrationContext;
+use OCP\AppFramework\IAppContainer;
use OCP\Defaults;
use OCP\IGroup;
+use OCP\IGroupManager;
use OCP\ILogger;
use OCP\IServerContainer;
use OCP\IUser;
use OCP\Settings\IManager;
use OCP\Util;
-use Psr\Container\ContainerInterface;
use Symfony\Component\EventDispatcher\EventDispatcherInterface;
use Symfony\Component\EventDispatcher\GenericEvent;
@@ -92,30 +94,30 @@ class Application extends App implements IBootstrap {
}
return $isSubAdmin;
});
- $context->registerService('userCertificateManager', function (ContainerInterface $c) {
+ $context->registerService('userCertificateManager', function (IAppContainer $appContainer) {
/** @var IServerContainer $serverContainer */
- $serverContainer = $c->get(IServerContainer::class);
+ $serverContainer = $appContainer->get(IServerContainer::class);
return $serverContainer->getCertificateManager();
}, false);
- $context->registerService('systemCertificateManager', function (ContainerInterface $c) {
+ $context->registerService('systemCertificateManager', function (IAppContainer $appContainer) {
/** @var IServerContainer $serverContainer */
- $serverContainer = $c->query('ServerContainer');
+ $serverContainer = $appContainer->query('ServerContainer');
return $serverContainer->getCertificateManager(null);
}, false);
- $context->registerService(IProvider::class, function (ContainerInterface $c) {
+ $context->registerService(IProvider::class, function (IAppContainer $appContainer) {
/** @var IServerContainer $serverContainer */
- $serverContainer = $c->query(IServerContainer::class);
+ $serverContainer = $appContainer->query(IServerContainer::class);
return $serverContainer->query(IProvider::class);
});
- $context->registerService(IManager::class, function (ContainerInterface $c) {
+ $context->registerService(IManager::class, function (IAppContainer $appContainer) {
/** @var IServerContainer $serverContainer */
- $serverContainer = $c->query(IServerContainer::class);
+ $serverContainer = $appContainer->query(IServerContainer::class);
return $serverContainer->getSettingsManager();
});
- $context->registerService(NewUserMailHelper::class, function (ContainerInterface $c) {
+ $context->registerService(NewUserMailHelper::class, function (IAppContainer $appContainer) {
/** @var Server $server */
- $server = $c->query(IServerContainer::class);
+ $server = $appContainer->query(IServerContainer::class);
/** @var Defaults $defaults */
$defaults = $server->query(Defaults::class);
@@ -134,38 +136,39 @@ class Application extends App implements IBootstrap {
}
public function boot(IBootContext $context): void {
- /** @var EventDispatcherInterface $eventDispatcher */
- $eventDispatcher = $context->getServerContainer()->getEventDispatcher();
- $container = $context->getAppContainer();
- $eventDispatcher->addListener('app_password_created', function (GenericEvent $event) use ($container) {
- if (($token = $event->getSubject()) instanceof IToken) {
- /** @var IActivityManager $activityManager */
- $activityManager = $container->query(IActivityManager::class);
- /** @var ILogger $logger */
- $logger = $container->query(ILogger::class);
-
- $activity = $activityManager->generateEvent();
- $activity->setApp('settings')
- ->setType('security')
- ->setAffectedUser($token->getUID())
- ->setAuthor($token->getUID())
- ->setSubject(Provider::APP_TOKEN_CREATED, ['name' => $token->getName()])
- ->setObject('app_token', $token->getId());
-
- try {
- $activityManager->publish($activity);
- } catch (BadMethodCallException $e) {
- $logger->logException($e, ['message' => 'could not publish activity', 'level' => ILogger::WARN]);
+ $context->injectFn(function (EventDispatcherInterface $dispatcher, IAppContainer $appContainer) {
+ $dispatcher->addListener('app_password_created', function (GenericEvent $event) use ($appContainer) {
+ if (($token = $event->getSubject()) instanceof IToken) {
+ /** @var IActivityManager $activityManager */
+ $activityManager = $appContainer->get(IActivityManager::class);
+ /** @var ILogger $logger */
+ $logger = $appContainer->get(ILogger::class);
+
+ $activity = $activityManager->generateEvent();
+ $activity->setApp('settings')
+ ->setType('security')
+ ->setAffectedUser($token->getUID())
+ ->setAuthor($token->getUID())
+ ->setSubject(Provider::APP_TOKEN_CREATED, ['name' => $token->getName()])
+ ->setObject('app_token', $token->getId());
+
+ try {
+ $activityManager->publish($activity);
+ } catch (BadMethodCallException $e) {
+ $logger->logException($e, ['message' => 'could not publish activity', 'level' => ILogger::WARN]);
+ }
}
- }
+ });
});
Util::connectHook('OC_User', 'post_setPassword', $this, 'onChangePassword');
Util::connectHook('OC_User', 'changeUser', $this, 'onChangeInfo');
- $groupManager = $context->getServerContainer()->getGroupManager();
- $groupManager->listen('\OC\Group', 'postRemoveUser', [$this, 'removeUserFromGroup']);
- $groupManager->listen('\OC\Group', 'postAddUser', [$this, 'addUserToGroup']);
+ $context->injectFn(function (IGroupManager $groupManager) {
+ /** @var IGroupManager|Manager $groupManager */
+ $groupManager->listen('\OC\Group', 'postRemoveUser', [$this, 'removeUserFromGroup']);
+ $groupManager->listen('\OC\Group', 'postAddUser', [$this, 'addUserToGroup']);
+ });
Util::connectHook('\OCP\Config', 'js', $this, 'extendJsConfig');
}
diff --git a/apps/systemtags/lib/AppInfo/Application.php b/apps/systemtags/lib/AppInfo/Application.php
index 45ac2dc1e84..ca18165680b 100644
--- a/apps/systemtags/lib/AppInfo/Application.php
+++ b/apps/systemtags/lib/AppInfo/Application.php
@@ -32,6 +32,7 @@ use OCP\AppFramework\Bootstrap\IBootstrap;
use OCP\AppFramework\Bootstrap\IRegistrationContext;
use OCP\SystemTag\ManagerEvent;
use OCP\SystemTag\MapperEvent;
+use Symfony\Component\EventDispatcher\EventDispatcher;
class Application extends App implements IBootstrap {
public const APP_ID = 'systemtags';
@@ -44,35 +45,36 @@ class Application extends App implements IBootstrap {
}
public function boot(IBootContext $context): void {
- /*
- * @todo move the OCP events and then move the registration to `register`
- */
- $eventDispatcher = $context->getServerContainer()->getEventDispatcher();
- $eventDispatcher->addListener(
- 'OCA\Files::loadAdditionalScripts',
- function () {
- // FIXME: no public API for these ?
- \OCP\Util::addScript('dist/systemtags');
- \OCP\Util::addScript(self::APP_ID, 'systemtags');
- }
- );
+ $context->injectFn(function (EventDispatcher $dispatcher) use ($context) {
+ /*
+ * @todo move the OCP events and then move the registration to `register`
+ */
+ $dispatcher->addListener(
+ 'OCA\Files::loadAdditionalScripts',
+ function () {
+ // FIXME: no public API for these ?
+ \OCP\Util::addScript('dist/systemtags');
+ \OCP\Util::addScript(self::APP_ID, 'systemtags');
+ }
+ );
- $managerListener = function (ManagerEvent $event) use ($context) {
- /** @var \OCA\SystemTags\Activity\Listener $listener */
- $listener = $context->getServerContainer()->query(Listener::class);
- $listener->event($event);
- };
- $eventDispatcher->addListener(ManagerEvent::EVENT_CREATE, $managerListener);
- $eventDispatcher->addListener(ManagerEvent::EVENT_DELETE, $managerListener);
- $eventDispatcher->addListener(ManagerEvent::EVENT_UPDATE, $managerListener);
+ $managerListener = function (ManagerEvent $event) use ($context) {
+ /** @var \OCA\SystemTags\Activity\Listener $listener */
+ $listener = $context->getServerContainer()->query(Listener::class);
+ $listener->event($event);
+ };
+ $dispatcher->addListener(ManagerEvent::EVENT_CREATE, $managerListener);
+ $dispatcher->addListener(ManagerEvent::EVENT_DELETE, $managerListener);
+ $dispatcher->addListener(ManagerEvent::EVENT_UPDATE, $managerListener);
- $mapperListener = function (MapperEvent $event) use ($context) {
- /** @var \OCA\SystemTags\Activity\Listener $listener */
- $listener = $context->getServerContainer()->query(Listener::class);
- $listener->mapperEvent($event);
- };
- $eventDispatcher->addListener(MapperEvent::EVENT_ASSIGN, $mapperListener);
- $eventDispatcher->addListener(MapperEvent::EVENT_UNASSIGN, $mapperListener);
+ $mapperListener = function (MapperEvent $event) use ($context) {
+ /** @var \OCA\SystemTags\Activity\Listener $listener */
+ $listener = $context->getServerContainer()->query(Listener::class);
+ $listener->mapperEvent($event);
+ };
+ $dispatcher->addListener(MapperEvent::EVENT_ASSIGN, $mapperListener);
+ $dispatcher->addListener(MapperEvent::EVENT_UNASSIGN, $mapperListener);
+ });
\OCA\Files\App::getNavigationManager()->add(function () {
$l = \OC::$server->getL10N(self::APP_ID);
diff --git a/apps/twofactor_backupcodes/lib/AppInfo/Application.php b/apps/twofactor_backupcodes/lib/AppInfo/Application.php
index 1941cb545ad..4ac5016f925 100644
--- a/apps/twofactor_backupcodes/lib/AppInfo/Application.php
+++ b/apps/twofactor_backupcodes/lib/AppInfo/Application.php
@@ -28,6 +28,7 @@ declare(strict_types=1);
namespace OCA\TwoFactorBackupCodes\AppInfo;
+use Closure;
use OCA\TwoFactorBackupCodes\Db\BackupCodeMapper;
use OCA\TwoFactorBackupCodes\Event\CodesGenerated;
use OCA\TwoFactorBackupCodes\Listener\ActivityPublisher;
@@ -58,9 +59,7 @@ class Application extends App implements IBootstrap {
public function boot(IBootContext $context): void {
Util::connectHook('OC_User', 'post_deleteUser', $this, 'deleteUser');
- $this->registerNotification(
- $context->getAppContainer()->query(IManager::class)
- );
+ $context->injectFn(Closure::fromCallable([$this, 'registerNotification']));
}
/**
diff --git a/apps/updatenotification/lib/AppInfo/Application.php b/apps/updatenotification/lib/AppInfo/Application.php
index 12d5cd9e626..48f89de3c37 100644
--- a/apps/updatenotification/lib/AppInfo/Application.php
+++ b/apps/updatenotification/lib/AppInfo/Application.php
@@ -30,12 +30,19 @@ namespace OCA\UpdateNotification\AppInfo;
use OCA\UpdateNotification\Notification\Notifier;
use OCA\UpdateNotification\UpdateChecker;
+use OCP\App\IAppManager;
use OCP\AppFramework\App;
use OCP\AppFramework\Bootstrap\IBootContext;
use OCP\AppFramework\Bootstrap\IBootstrap;
use OCP\AppFramework\Bootstrap\IRegistrationContext;
+use OCP\AppFramework\IAppContainer;
use OCP\AppFramework\QueryException;
+use OCP\IConfig;
+use OCP\IGroupManager;
+use OCP\ILogger;
use OCP\IUser;
+use OCP\IUserSession;
+use OCP\Notification\IManager as INotificationManager;
use OCP\Util;
class Application extends App implements IBootstrap {
@@ -47,36 +54,41 @@ class Application extends App implements IBootstrap {
}
public function boot(IBootContext $context): void {
- $server = $context->getServerContainer();
-
- if ($server->getConfig()->getSystemValue('updatechecker', true) !== true) {
- // Updater check is disabled
- return;
- }
-
- // Always register the notifier, so background jobs (without a user) can send push notifications
- $notificationsManager = $server->getNotificationManager();
- $notificationsManager->registerNotifierService(Notifier::class);
+ $context->injectFn(function (IConfig $config,
+ INotificationManager $notificationsManager,
+ IUserSession $userSession,
+ IAppManager $appManager,
+ IGroupManager $groupManager,
+ IAppContainer $appContainer,
+ ILogger $logger) {
+ if ($config->getSystemValue('updatechecker', true) !== true) {
+ // Updater check is disabled
+ return;
+ }
- $user = $server->getUserSession()->getUser();
- if (!$user instanceof IUser) {
- // Nothing to do for guests
- return;
- }
+ // Always register the notifier, so background jobs (without a user) can send push notifications
+ $notificationsManager->registerNotifierService(Notifier::class);
- if (!$server->getAppManager()->isEnabledForUser('notifications') &&
- $server->getGroupManager()->isAdmin($user->getUID())) {
- try {
- $updateChecker = $server->query(UpdateChecker::class);
- } catch (QueryException $e) {
- $server->getLogger()->logException($e);
+ $user = $userSession->getUser();
+ if (!$user instanceof IUser) {
+ // Nothing to do for guests
return;
}
- if ($updateChecker->getUpdateState() !== []) {
- Util::addScript('updatenotification', 'legacy-notification');
- \OC_Hook::connect('\OCP\Config', 'js', $updateChecker, 'populateJavaScriptVariables');
+ if (!$appManager->isEnabledForUser('notifications') &&
+ $groupManager->isAdmin($user->getUID())) {
+ try {
+ $updateChecker = $appContainer->get(UpdateChecker::class);
+ } catch (QueryException $e) {
+ $logger->logException($e);
+ return;
+ }
+
+ if ($updateChecker->getUpdateState() !== []) {
+ Util::addScript('updatenotification', 'legacy-notification');
+ \OC_Hook::connect('\OCP\Config', 'js', $updateChecker, 'populateJavaScriptVariables');
+ }
}
- }
+ });
}
}
diff --git a/apps/user_ldap/lib/AppInfo/Application.php b/apps/user_ldap/lib/AppInfo/Application.php
index a97b9c3fef9..7086bb08ee5 100644
--- a/apps/user_ldap/lib/AppInfo/Application.php
+++ b/apps/user_ldap/lib/AppInfo/Application.php
@@ -26,6 +26,7 @@
namespace OCA\User_LDAP\AppInfo;
+use Closure;
use OCA\Files_External\Service\BackendService;
use OCA\User_LDAP\Controller\RenewPasswordController;
use OCA\User_LDAP\Group_Proxy;
@@ -41,9 +42,14 @@ use OCP\AppFramework\App;
use OCP\AppFramework\Bootstrap\IBootContext;
use OCP\AppFramework\Bootstrap\IBootstrap;
use OCP\AppFramework\Bootstrap\IRegistrationContext;
+use OCP\AppFramework\IAppContainer;
+use OCP\IConfig;
+use OCP\IGroupManager;
use OCP\IL10N;
use OCP\IServerContainer;
-use Psr\Container\ContainerInterface;
+use OCP\IUserSession;
+use OCP\Notification\IManager as INotificationManager;
+use Symfony\Component\EventDispatcher\EventDispatcherInterface;
class Application extends App implements IBootstrap {
public function __construct() {
@@ -53,17 +59,17 @@ class Application extends App implements IBootstrap {
/**
* Controller
*/
- $container->registerService('RenewPasswordController', function (ContainerInterface $c) {
+ $container->registerService('RenewPasswordController', function (IAppContainer $appContainer) {
/** @var IServerContainer $server */
- $server = $c->get(IServerContainer::class);
+ $server = $appContainer->get(IServerContainer::class);
return new RenewPasswordController(
- $c->get('AppName'),
+ $appContainer->get('AppName'),
$server->getRequest(),
- $c->get('UserManager'),
+ $appContainer->get('UserManager'),
$server->getConfig(),
- $c->get(IL10N::class),
- $c->get('Session'),
+ $appContainer->get(IL10N::class),
+ $appContainer->get('Session'),
$server->getURLGenerator()
);
});
@@ -77,35 +83,37 @@ class Application extends App implements IBootstrap {
}
public function boot(IBootContext $context): void {
- $server = $context->getServerContainer();
- $config = $server->getConfig();
-
- $helper = new Helper($config);
- $configPrefixes = $helper->getServerConfigurationPrefixes(true);
- if (count($configPrefixes) > 0) {
- $ldapWrapper = new LDAP();
-
- $notificationManager = $server->getNotificationManager();
- $notificationManager->registerNotifierService(Notifier::class);
- $userSession = $server->getUserSession();
-
- $userPluginManager = $server->query(UserPluginManager::class);
- $groupPluginManager = $server->query(GroupPluginManager::class);
-
- $userBackend = new User_Proxy(
- $configPrefixes, $ldapWrapper, $config, $notificationManager, $userSession, $userPluginManager
- );
- $groupBackend = new Group_Proxy($configPrefixes, $ldapWrapper, $groupPluginManager);
- // register user backend
- \OC_User::useBackend($userBackend);
-
- // Hook to allow plugins to work on registered backends
- $server->getEventDispatcher()->dispatch('OCA\\User_LDAP\\User\\User::postLDAPBackendAdded');
-
- $server->getGroupManager()->addBackend($groupBackend);
+ $context->injectFn(function (IConfig $config,
+ INotificationManager $notificationManager,
+ IUserSession $userSession,
+ IAppContainer $appContainer,
+ EventDispatcherInterface $dispatcher,
+ IGroupManager $groupManager) {
+ $helper = new Helper($config);
+ $configPrefixes = $helper->getServerConfigurationPrefixes(true);
+ if (count($configPrefixes) > 0) {
+ $ldapWrapper = new LDAP();
+
+ $notificationManager->registerNotifierService(Notifier::class);
+
+ $userPluginManager = $appContainer->get(UserPluginManager::class);
+ $groupPluginManager = $appContainer->get(GroupPluginManager::class);
+
+ $userBackend = new User_Proxy(
+ $configPrefixes, $ldapWrapper, $config, $notificationManager, $userSession, $userPluginManager
+ );
+ $groupBackend = new Group_Proxy($configPrefixes, $ldapWrapper, $groupPluginManager);
+ // register user backend
+ \OC_User::useBackend($userBackend);
+
+ // Hook to allow plugins to work on registered backends
+ $dispatcher->dispatch('OCA\\User_LDAP\\User\\User::postLDAPBackendAdded');
+
+ $groupManager->addBackend($groupBackend);
+ }
+ });
- $this->registerBackendDependents($context->getAppContainer());
- }
+ $context->injectFn(Closure::fromCallable([$this, 'registerBackendDependents']));
\OCP\Util::connectHook(
'\OCA\Files_Sharing\API\Server2Server',
@@ -115,10 +123,8 @@ class Application extends App implements IBootstrap {
);
}
- public function registerBackendDependents(ContainerInterface $appContainer) {
- /** @var IServerContainer $serverContainer */
- $serverContainer = $appContainer->get(IServerContainer::class);
- $serverContainer->getEventDispatcher()->addListener(
+ private function registerBackendDependents(IAppContainer $appContainer, EventDispatcherInterface $dispatcher) {
+ $dispatcher->addListener(
'OCA\\Files_External::loadAdditionalBackends',
function () use ($appContainer) {
$storagesBackendService = $appContainer->get(BackendService::class);
diff --git a/apps/workflowengine/lib/AppInfo/Application.php b/apps/workflowengine/lib/AppInfo/Application.php
index 2fd38c5f1ba..ddac4a74e28 100644
--- a/apps/workflowengine/lib/AppInfo/Application.php
+++ b/apps/workflowengine/lib/AppInfo/Application.php
@@ -21,6 +21,7 @@
namespace OCA\WorkflowEngine\AppInfo;
+use Closure;
use OCA\WorkflowEngine\Controller\RequestTime;
use OCA\WorkflowEngine\Helper\LogContext;
use OCA\WorkflowEngine\Listener\LoadAdditionalSettingsScriptsListener;
@@ -57,11 +58,7 @@ class Application extends App implements IBootstrap {
}
public function boot(IBootContext $context): void {
- $this->registerRuleListeners(
- $context->getAppContainer()->query(IEventDispatcher::class),
- $context->getServerContainer(),
- $context->getAppContainer()->query(ILogger::class)
- );
+ $context->injectFn(Closure::fromCallable([$this, 'registerRuleListeners']));
}
private function registerRuleListeners(IEventDispatcher $dispatcher,
diff --git a/lib/private/AppFramework/Bootstrap/BootContext.php b/lib/private/AppFramework/Bootstrap/BootContext.php
index d206884c0b7..45aaf167e75 100644
--- a/lib/private/AppFramework/Bootstrap/BootContext.php
+++ b/lib/private/AppFramework/Bootstrap/BootContext.php
@@ -43,7 +43,7 @@ class BootContext implements IBootContext {
}
public function getServerContainer(): IServerContainer {
- return $this->appContainer->getServer();
+ return $this->appContainer->get(IServerContainer::class);
}
public function injectFn(callable $fn) {
diff --git a/lib/private/AppFramework/Bootstrap/FunctionInjector.php b/lib/private/AppFramework/Bootstrap/FunctionInjector.php
index cb1dc7d3f37..25c1fbc0be6 100644
--- a/lib/private/AppFramework/Bootstrap/FunctionInjector.php
+++ b/lib/private/AppFramework/Bootstrap/FunctionInjector.php
@@ -27,17 +27,17 @@ namespace OC\AppFramework\Bootstrap;
use Closure;
use OCP\AppFramework\QueryException;
-use OCP\IContainer;
+use Psr\Container\ContainerInterface;
use ReflectionFunction;
use ReflectionParameter;
use function array_map;
class FunctionInjector {
- /** @var IContainer */
+ /** @var ContainerInterface */
private $container;
- public function __construct(IContainer $container) {
+ public function __construct(ContainerInterface $container) {
$this->container = $container;
}
@@ -47,14 +47,14 @@ class FunctionInjector {
// First we try by type (more likely these days)
if (($type = $param->getType()) !== null) {
try {
- return $this->container->query($type->getName());
+ return $this->container->get($type->getName());
} catch (QueryException $ex) {
// Ignore and try name as well
}
}
// Second we try by name (mostly for primitives)
try {
- return $this->container->query($param->getName());
+ return $this->container->get($param->getName());
} catch (QueryException $ex) {
// As a last resort we pass `null` if allowed
if ($type !== null && $type->allowsNull()) {
diff --git a/lib/public/AppFramework/Bootstrap/IBootContext.php b/lib/public/AppFramework/Bootstrap/IBootContext.php
index ee0bef6a5fa..80a4edf1cd6 100644
--- a/lib/public/AppFramework/Bootstrap/IBootContext.php
+++ b/lib/public/AppFramework/Bootstrap/IBootContext.php
@@ -28,7 +28,6 @@ namespace OCP\AppFramework\Bootstrap;
use OCP\AppFramework\IAppContainer;
use OCP\IServerContainer;
use Psr\Container\ContainerExceptionInterface;
-use Psr\Container\ContainerInterface;
use Throwable;
/**
@@ -41,7 +40,7 @@ interface IBootContext {
*
* Useful to register and query app-specific services
*
- * @return IAppContainer|ContainerInterface
+ * @return IAppContainer
* @since 20.0.0
*/
public function getAppContainer(): IAppContainer;
diff --git a/tests/lib/AppFramework/Bootstrap/BootContextTest.php b/tests/lib/AppFramework/Bootstrap/BootContextTest.php
index 219c6d7e782..b566347e3ff 100644
--- a/tests/lib/AppFramework/Bootstrap/BootContextTest.php
+++ b/tests/lib/AppFramework/Bootstrap/BootContextTest.php
@@ -57,7 +57,8 @@ class BootContextTest extends TestCase {
public function testGetServerContainer(): void {
$serverContainer = $this->createMock(IServerContainer::class);
- $this->appContainer->method('getServer')
+ $this->appContainer->method('get')
+ ->with(IServerContainer::class)
->willReturn($serverContainer);
$container = $this->context->getServerContainer();