diff options
author | Morris Jobke <hey@morrisjobke.de> | 2020-07-22 20:38:50 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-07-22 20:38:50 +0200 |
commit | 346f647962e00b1f5e5f19a8526c88a09ebca59e (patch) | |
tree | 64f324cb5ff04f29247bf00f32e84bc7c8f4ed36 | |
parent | c842678f0a1fb65981a03302895192ddc58479c9 (diff) | |
parent | 7870ca06637453f4e72dbd67edbfb3603d813196 (diff) | |
download | nextcloud-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
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(); |