getContainer(); /** * Controller */ $container->registerService('RenewPasswordController', function (IAppContainer $appContainer) { /** @var IServerContainer $server */ $server = $appContainer->get(IServerContainer::class); return new RenewPasswordController( $appContainer->get('AppName'), $server->getRequest(), $appContainer->get('UserManager'), $server->getConfig(), $appContainer->get(IL10N::class), $appContainer->get('Session'), $server->getURLGenerator() ); }); $container->registerService(ILDAPWrapper::class, function (IAppContainer $appContainer) { /** @var IServerContainer $server */ $server = $appContainer->get(IServerContainer::class); return new LDAP( $server->getConfig()->getSystemValueString('ldap_log_file') ); }); } public function register(IRegistrationContext $context): void { $context->registerNotifierService(Notifier::class); $context->registerService( Manager::class, function (ContainerInterface $c) { return new Manager( $c->get(IConfig::class), $c->get(FilesystemHelper::class), $c->get(LoggerInterface::class), $c->get(IAvatarManager::class), $c->get(Image::class), $c->get(IUserManager::class), $c->get(INotificationManager::class), $c->get(IShareManager::class), ); }, // the instance is specific to a lazy bound Access instance, thus cannot be shared. false ); $context->registerEventListener(PostLoginEvent::class, LoginListener::class); $context->registerSetupCheck(LdapInvalidUuids::class); $context->registerSetupCheck(LdapConnection::class); } public function boot(IBootContext $context): void { $context->injectFn(function ( INotificationManager $notificationManager, IAppContainer $appContainer, IEventDispatcher $dispatcher, IGroupManager $groupManager, User_Proxy $userBackend, Group_Proxy $groupBackend, Helper $helper, ): void { $configPrefixes = $helper->getServerConfigurationPrefixes(true); if (count($configPrefixes) > 0) { $userPluginManager = $appContainer->get(UserPluginManager::class); $groupPluginManager = $appContainer->get(GroupPluginManager::class); \OC_User::useBackend($userBackend); $groupManager->addBackend($groupBackend); $userBackendRegisteredEvent = new UserBackendRegistered($userBackend, $userPluginManager); $dispatcher->dispatch('OCA\\User_LDAP\\User\\User::postLDAPBackendAdded', $userBackendRegisteredEvent); $dispatcher->dispatchTyped($userBackendRegisteredEvent); $groupBackendRegisteredEvent = new GroupBackendRegistered($groupBackend, $groupPluginManager); $dispatcher->dispatchTyped($groupBackendRegisteredEvent); } }); $context->injectFn(Closure::fromCallable([$this, 'registerBackendDependents'])); \OCP\Util::connectHook( '\OCA\Files_Sharing\API\Server2Server', 'preLoginNameUsedAsUserName', '\OCA\User_LDAP\Helper', 'loginName2UserName' ); } private function registerBackendDependents(IAppContainer $appContainer, IEventDispatcher $dispatcher): void { $dispatcher->addListener( 'OCA\\Files_External::loadAdditionalBackends', function () use ($appContainer): void { $storagesBackendService = $appContainer->get(BackendService::class); $storagesBackendService->registerConfigHandler('home', function () use ($appContainer) { return $appContainer->get(ExtStorageConfigHandler::class); }); } ); } }