aboutsummaryrefslogtreecommitdiffstats
path: root/lib/private/Server.php
diff options
context:
space:
mode:
Diffstat (limited to 'lib/private/Server.php')
-rw-r--r--lib/private/Server.php2023
1 files changed, 1082 insertions, 941 deletions
diff --git a/lib/private/Server.php b/lib/private/Server.php
index 5bc72e3614f..22cd13438b8 100644
--- a/lib/private/Server.php
+++ b/lib/private/Server.php
@@ -1,100 +1,244 @@
<?php
+
/**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- * @copyright Copyright (c) 2016, Lukas Reschke <lukas@statuscode.ch>
- *
- * @author Arthur Schiwon <blizzz@arthur-schiwon.de>
- * @author Bart Visscher <bartv@thisnet.nl>
- * @author Bernhard Posselt <dev@bernhard-posselt.com>
- * @author Bernhard Reiter <ockham@raz.or.at>
- * @author Bjoern Schiessle <bjoern@schiessle.org>
- * @author Björn Schießle <bjoern@schiessle.org>
- * @author Christopher Schäpers <kondou@ts.unde.re>
- * @author Christoph Wurst <christoph@owncloud.com>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Jörn Friedrich Dreyer <jfd@butonic.de>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Morris Jobke <hey@morrisjobke.de>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Robin McCorkell <robin@mccorkell.me.uk>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Sander <brantje@gmail.com>
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- * @author Thomas Tanghus <thomas@tanghus.net>
- * @author Vincent Petry <pvince81@owncloud.com>
- * @author Roger Szabo <roger.szabo@web.de>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
namespace OC;
use bantu\IniGetWrapper\IniGetWrapper;
+use NCU\Security\Signature\ISignatureManager;
+use OC\Accounts\AccountManager;
+use OC\App\AppManager;
+use OC\App\AppStore\Bundles\BundleFetcher;
use OC\App\AppStore\Fetcher\AppFetcher;
-use OC\App\AppStore\Fetcher\CategoryFetcher;
+use OC\AppFramework\Bootstrap\Coordinator;
use OC\AppFramework\Http\Request;
+use OC\AppFramework\Http\RequestId;
use OC\AppFramework\Utility\TimeFactory;
-use OC\Command\AsyncBus;
+use OC\Authentication\Events\LoginFailed;
+use OC\Authentication\Listeners\LoginFailedListener;
+use OC\Authentication\Listeners\UserLoggedInListener;
+use OC\Authentication\LoginCredentials\Store;
+use OC\Authentication\Token\IProvider;
+use OC\Avatar\AvatarManager;
+use OC\Blurhash\Listener\GenerateBlurhashMetadata;
+use OC\Collaboration\Collaborators\GroupPlugin;
+use OC\Collaboration\Collaborators\MailPlugin;
+use OC\Collaboration\Collaborators\RemoteGroupPlugin;
+use OC\Collaboration\Collaborators\RemotePlugin;
+use OC\Collaboration\Collaborators\UserPlugin;
+use OC\Collaboration\Reference\ReferenceManager;
+use OC\Command\CronBus;
+use OC\Comments\ManagerFactory as CommentsManagerFactory;
+use OC\Contacts\ContactsMenu\ActionFactory;
+use OC\Contacts\ContactsMenu\ContactsStore;
+use OC\DB\Connection;
+use OC\DB\ConnectionAdapter;
use OC\Diagnostics\EventLogger;
-use OC\Diagnostics\NullEventLogger;
-use OC\Diagnostics\NullQueryLogger;
use OC\Diagnostics\QueryLogger;
+use OC\Federation\CloudFederationFactory;
+use OC\Federation\CloudFederationProviderManager;
+use OC\Federation\CloudIdManager;
+use OC\Files\Cache\FileAccess;
+use OC\Files\Config\MountProviderCollection;
use OC\Files\Config\UserMountCache;
use OC\Files\Config\UserMountCacheListener;
+use OC\Files\Conversion\ConversionManager;
+use OC\Files\Lock\LockManager;
use OC\Files\Mount\CacheMountProvider;
use OC\Files\Mount\LocalHomeMountProvider;
use OC\Files\Mount\ObjectHomeMountProvider;
+use OC\Files\Mount\ObjectStorePreviewCacheMountProvider;
+use OC\Files\Mount\RootMountProvider;
use OC\Files\Node\HookConnector;
use OC\Files\Node\LazyRoot;
use OC\Files\Node\Root;
+use OC\Files\ObjectStore\PrimaryObjectStoreConfig;
+use OC\Files\SetupManager;
+use OC\Files\Storage\StorageFactory;
+use OC\Files\Template\TemplateManager;
+use OC\Files\Type\Loader;
use OC\Files\View;
+use OC\FilesMetadata\FilesMetadataManager;
+use OC\FullTextSearch\FullTextSearchManager;
use OC\Http\Client\ClientService;
+use OC\Http\Client\NegativeDnsCache;
use OC\IntegrityCheck\Checker;
use OC\IntegrityCheck\Helpers\AppLocator;
use OC\IntegrityCheck\Helpers\EnvironmentHelper;
use OC\IntegrityCheck\Helpers\FileAccessHelper;
+use OC\KnownUser\KnownUserService;
+use OC\LDAP\NullLDAPProviderFactory;
use OC\Lock\DBLockingProvider;
use OC\Lock\MemcacheLockingProvider;
use OC\Lock\NoopLockingProvider;
use OC\Lockdown\LockdownManager;
+use OC\Log\LogFactory;
+use OC\Log\PsrLoggerAdapter;
use OC\Mail\Mailer;
use OC\Memcache\ArrayCache;
+use OC\Memcache\Factory;
use OC\Notification\Manager;
-use OC\Repair\NC11\CleanPreviewsBackgroundJob;
+use OC\OCM\Model\OCMProvider;
+use OC\OCM\OCMDiscoveryService;
+use OC\OCS\DiscoveryService;
+use OC\Preview\GeneratorHelper;
+use OC\Preview\IMagickSupport;
+use OC\Preview\MimeIconProvider;
+use OC\Profile\ProfileManager;
+use OC\Profiler\Profiler;
+use OC\Remote\Api\ApiFactory;
+use OC\Remote\InstanceFactory;
use OC\RichObjectStrings\Validator;
+use OC\Route\CachingRouter;
+use OC\Route\Router;
use OC\Security\Bruteforce\Throttler;
use OC\Security\CertificateManager;
-use OC\Security\CSP\ContentSecurityPolicyManager;
+use OC\Security\CredentialsManager;
use OC\Security\Crypto;
+use OC\Security\CSP\ContentSecurityPolicyManager;
use OC\Security\CSP\ContentSecurityPolicyNonceManager;
-use OC\Security\CSRF\CsrfTokenGenerator;
use OC\Security\CSRF\CsrfTokenManager;
use OC\Security\CSRF\TokenStorage\SessionStorage;
use OC\Security\Hasher;
-use OC\Security\CredentialsManager;
+use OC\Security\Ip\RemoteAddress;
+use OC\Security\RateLimiting\Limiter;
use OC\Security\SecureRandom;
+use OC\Security\Signature\SignatureManager;
use OC\Security\TrustedDomainHelper;
+use OC\Security\VerificationToken\VerificationToken;
use OC\Session\CryptoWrapper;
-use OC\Tagging\TagMapper;
+use OC\Settings\DeclarativeManager;
+use OC\SetupCheck\SetupCheckManager;
+use OC\Share20\ProviderFactory;
+use OC\Share20\ShareHelper;
+use OC\SpeechToText\SpeechToTextManager;
+use OC\SystemTag\ManagerFactory as SystemTagManagerFactory;
+use OC\Talk\Broker;
+use OC\Teams\TeamManager;
+use OC\Template\JSCombiner;
+use OC\Translation\TranslationManager;
+use OC\User\AvailabilityCoordinator;
+use OC\User\DisplayNameCache;
+use OC\User\Listeners\BeforeUserDeletedListener;
+use OC\User\Listeners\UserChangedListener;
+use OC\User\Session;
+use OCA\Theming\ImageManager;
+use OCA\Theming\Service\BackgroundService;
use OCA\Theming\ThemingDefaults;
+use OCA\Theming\Util;
+use OCP\Accounts\IAccountManager;
+use OCP\App\IAppManager;
+use OCP\AppFramework\Utility\ITimeFactory;
+use OCP\Authentication\LoginCredentials\IStore;
+use OCP\Authentication\Token\IProvider as OCPIProvider;
+use OCP\BackgroundJob\IJobList;
+use OCP\Collaboration\Reference\IReferenceManager;
+use OCP\Command\IBus;
+use OCP\Comments\ICommentsManager;
+use OCP\Config\IUserConfig;
+use OCP\Contacts\ContactsMenu\IActionFactory;
+use OCP\Contacts\ContactsMenu\IContactsStore;
+use OCP\Defaults;
+use OCP\Diagnostics\IEventLogger;
+use OCP\Diagnostics\IQueryLogger;
+use OCP\Encryption\IFile;
+use OCP\Encryption\Keys\IStorage;
+use OCP\EventDispatcher\IEventDispatcher;
+use OCP\Federation\ICloudFederationFactory;
+use OCP\Federation\ICloudFederationProviderManager;
+use OCP\Federation\ICloudIdManager;
+use OCP\Files\Cache\IFileAccess;
+use OCP\Files\Config\IMountProviderCollection;
+use OCP\Files\Config\IUserMountCache;
+use OCP\Files\Conversion\IConversionManager;
+use OCP\Files\IMimeTypeDetector;
+use OCP\Files\IMimeTypeLoader;
+use OCP\Files\IRootFolder;
+use OCP\Files\Lock\ILockManager;
+use OCP\Files\Mount\IMountManager;
+use OCP\Files\Storage\IStorageFactory;
+use OCP\Files\Template\ITemplateManager;
+use OCP\FilesMetadata\IFilesMetadataManager;
+use OCP\FullTextSearch\IFullTextSearchManager;
+use OCP\Group\ISubAdmin;
+use OCP\Http\Client\IClientService;
+use OCP\IAppConfig;
+use OCP\IAvatarManager;
+use OCP\IBinaryFinder;
+use OCP\ICache;
+use OCP\ICacheFactory;
+use OCP\ICertificateManager;
+use OCP\IDateTimeFormatter;
+use OCP\IDateTimeZone;
+use OCP\IDBConnection;
+use OCP\IEventSourceFactory;
+use OCP\IGroupManager;
+use OCP\IInitialStateService;
use OCP\IL10N;
+use OCP\INavigationManager;
+use OCP\IPhoneNumberUtil;
+use OCP\IPreview;
+use OCP\IRequest;
+use OCP\IRequestId;
use OCP\IServerContainer;
+use OCP\ISession;
+use OCP\ITempManager;
+use OCP\IURLGenerator;
+use OCP\IUserManager;
+use OCP\IUserSession;
+use OCP\L10N\IFactory;
+use OCP\LDAP\ILDAPProvider;
+use OCP\LDAP\ILDAPProviderFactory;
+use OCP\Lock\ILockingProvider;
+use OCP\Lockdown\ILockdownManager;
+use OCP\Log\ILogFactory;
+use OCP\Mail\IMailer;
+use OCP\OCM\ICapabilityAwareOCMProvider;
+use OCP\OCM\IOCMDiscoveryService;
+use OCP\OCM\IOCMProvider;
+use OCP\Preview\IMimeIconProvider;
+use OCP\Profile\IProfileManager;
+use OCP\Profiler\IProfiler;
+use OCP\Remote\Api\IApiFactory;
+use OCP\Remote\IInstanceFactory;
+use OCP\RichObjectStrings\IRichTextFormatter;
use OCP\RichObjectStrings\IValidator;
-use OCP\Security\IContentSecurityPolicyManager;
-use Symfony\Component\EventDispatcher\EventDispatcher;
-use Symfony\Component\EventDispatcher\EventDispatcherInterface;
+use OCP\Route\IRouter;
+use OCP\Security\Bruteforce\IThrottler;
+use OCP\Security\ICredentialsManager;
+use OCP\Security\ICrypto;
+use OCP\Security\IHasher;
+use OCP\Security\Ip\IRemoteAddress;
+use OCP\Security\ISecureRandom;
+use OCP\Security\ITrustedDomainHelper;
+use OCP\Security\RateLimiting\ILimiter;
+use OCP\Security\VerificationToken\IVerificationToken;
+use OCP\ServerVersion;
+use OCP\Settings\IDeclarativeManager;
+use OCP\SetupCheck\ISetupCheckManager;
+use OCP\Share\IProviderFactory;
+use OCP\Share\IShareHelper;
+use OCP\SpeechToText\ISpeechToTextManager;
+use OCP\SystemTag\ISystemTagManager;
+use OCP\SystemTag\ISystemTagObjectMapper;
+use OCP\Talk\IBroker;
+use OCP\Teams\ITeamManager;
+use OCP\Translation\ITranslationManager;
+use OCP\User\Events\BeforeUserDeletedEvent;
+use OCP\User\Events\BeforeUserLoggedInEvent;
+use OCP\User\Events\BeforeUserLoggedInWithCookieEvent;
+use OCP\User\Events\BeforeUserLoggedOutEvent;
+use OCP\User\Events\PostLoginEvent;
+use OCP\User\Events\UserChangedEvent;
+use OCP\User\Events\UserLoggedInEvent;
+use OCP\User\Events\UserLoggedInWithCookieEvent;
+use OCP\User\Events\UserLoggedOutEvent;
+use OCP\User\IAvailabilityCoordinator;
+use Psr\Container\ContainerInterface;
+use Psr\Log\LoggerInterface;
/**
* Class Server
@@ -115,479 +259,621 @@ class Server extends ServerContainer implements IServerContainer {
parent::__construct();
$this->webRoot = $webRoot;
- $this->registerService('ContactsManager', function ($c) {
- return new ContactsManager();
+ // To find out if we are running from CLI or not
+ $this->registerParameter('isCLI', \OC::$CLI);
+ $this->registerParameter('serverRoot', \OC::$SERVERROOT);
+
+ $this->registerService(ContainerInterface::class, function (ContainerInterface $c) {
+ return $c;
});
+ $this->registerDeprecatedAlias(\OCP\IServerContainer::class, ContainerInterface::class);
+
+ $this->registerAlias(\OCP\Calendar\IManager::class, \OC\Calendar\Manager::class);
+
+ $this->registerAlias(\OCP\Calendar\Resource\IManager::class, \OC\Calendar\Resource\Manager::class);
+
+ $this->registerAlias(\OCP\Calendar\Room\IManager::class, \OC\Calendar\Room\Manager::class);
- $this->registerService('PreviewManager', function (Server $c) {
+ $this->registerAlias(\OCP\Contacts\IManager::class, \OC\ContactsManager::class);
+
+ $this->registerAlias(\OCP\ContextChat\IContentManager::class, \OC\ContextChat\ContentManager::class);
+
+ $this->registerAlias(\OCP\DirectEditing\IManager::class, \OC\DirectEditing\Manager::class);
+ $this->registerAlias(ITemplateManager::class, TemplateManager::class);
+ $this->registerAlias(\OCP\Template\ITemplateManager::class, \OC\Template\TemplateManager::class);
+
+ $this->registerAlias(IActionFactory::class, ActionFactory::class);
+
+ $this->registerService(View::class, function (Server $c) {
+ return new View();
+ }, false);
+
+ $this->registerService(IPreview::class, function (ContainerInterface $c) {
return new PreviewManager(
- $c->getConfig(),
- $c->getRootFolder(),
- $c->getAppDataDir('preview'),
- $c->getEventDispatcher()
+ $c->get(\OCP\IConfig::class),
+ $c->get(IRootFolder::class),
+ new \OC\Preview\Storage\Root(
+ $c->get(IRootFolder::class),
+ $c->get(SystemConfig::class)
+ ),
+ $c->get(IEventDispatcher::class),
+ $c->get(GeneratorHelper::class),
+ $c->get(ISession::class)->get('user_id'),
+ $c->get(Coordinator::class),
+ $c->get(IServerContainer::class),
+ $c->get(IBinaryFinder::class),
+ $c->get(IMagickSupport::class)
);
});
+ $this->registerAlias(IMimeIconProvider::class, MimeIconProvider::class);
- $this->registerService(\OC\Preview\Watcher::class, function (Server $c) {
+ $this->registerService(\OC\Preview\Watcher::class, function (ContainerInterface $c) {
return new \OC\Preview\Watcher(
- $c->getAppDataDir('preview')
+ new \OC\Preview\Storage\Root(
+ $c->get(IRootFolder::class),
+ $c->get(SystemConfig::class)
+ )
);
});
- $this->registerService('EncryptionManager', function (Server $c) {
+ $this->registerService(IProfiler::class, function (Server $c) {
+ return new Profiler($c->get(SystemConfig::class));
+ });
+
+ $this->registerService(Encryption\Manager::class, function (Server $c): Encryption\Manager {
$view = new View();
$util = new Encryption\Util(
$view,
- $c->getUserManager(),
- $c->getGroupManager(),
- $c->getConfig()
+ $c->get(IUserManager::class),
+ $c->get(IGroupManager::class),
+ $c->get(\OCP\IConfig::class)
);
return new Encryption\Manager(
- $c->getConfig(),
- $c->getLogger(),
+ $c->get(\OCP\IConfig::class),
+ $c->get(LoggerInterface::class),
$c->getL10N('core'),
new View(),
$util,
new ArrayCache()
);
});
+ $this->registerAlias(\OCP\Encryption\IManager::class, Encryption\Manager::class);
- $this->registerService('EncryptionFileHelper', function (Server $c) {
+ $this->registerService(IFile::class, function (ContainerInterface $c) {
$util = new Encryption\Util(
new View(),
- $c->getUserManager(),
- $c->getGroupManager(),
- $c->getConfig()
+ $c->get(IUserManager::class),
+ $c->get(IGroupManager::class),
+ $c->get(\OCP\IConfig::class)
+ );
+ return new Encryption\File(
+ $util,
+ $c->get(IRootFolder::class),
+ $c->get(\OCP\Share\IManager::class)
);
- return new Encryption\File($util);
});
- $this->registerService('EncryptionKeyStorage', function (Server $c) {
+ $this->registerService(IStorage::class, function (ContainerInterface $c) {
$view = new View();
$util = new Encryption\Util(
$view,
- $c->getUserManager(),
- $c->getGroupManager(),
- $c->getConfig()
+ $c->get(IUserManager::class),
+ $c->get(IGroupManager::class),
+ $c->get(\OCP\IConfig::class)
);
- return new Encryption\Keys\Storage($view, $util);
- });
- $this->registerService('TagMapper', function (Server $c) {
- return new TagMapper($c->getDatabaseConnection());
- });
- $this->registerService('TagManager', function (Server $c) {
- $tagMapper = $c->query('TagMapper');
- return new TagManager($tagMapper, $c->getUserSession());
+ return new Encryption\Keys\Storage(
+ $view,
+ $util,
+ $c->get(ICrypto::class),
+ $c->get(\OCP\IConfig::class)
+ );
});
- $this->registerService('SystemTagManagerFactory', function (Server $c) {
- $config = $c->getConfig();
- $factoryClass = $config->getSystemValue('systemtags.managerFactory', '\OC\SystemTag\ManagerFactory');
- /** @var \OC\SystemTag\ManagerFactory $factory */
- $factory = new $factoryClass($this);
- return $factory;
+
+ $this->registerAlias(\OCP\ITagManager::class, TagManager::class);
+
+ $this->registerService('SystemTagManagerFactory', function (ContainerInterface $c) {
+ /** @var \OCP\IConfig $config */
+ $config = $c->get(\OCP\IConfig::class);
+ $factoryClass = $config->getSystemValue('systemtags.managerFactory', SystemTagManagerFactory::class);
+ return new $factoryClass($this);
});
- $this->registerService('SystemTagManager', function (Server $c) {
- return $c->query('SystemTagManagerFactory')->getManager();
+ $this->registerService(ISystemTagManager::class, function (ContainerInterface $c) {
+ return $c->get('SystemTagManagerFactory')->getManager();
});
- $this->registerService('SystemTagObjectMapper', function (Server $c) {
- return $c->query('SystemTagManagerFactory')->getObjectMapper();
+ /** @deprecated 19.0.0 */
+ $this->registerDeprecatedAlias('SystemTagManager', ISystemTagManager::class);
+
+ $this->registerService(ISystemTagObjectMapper::class, function (ContainerInterface $c) {
+ return $c->get('SystemTagManagerFactory')->getObjectMapper();
});
- $this->registerService('RootFolder', function (Server $c) {
- $manager = \OC\Files\Filesystem::getMountManager(null);
+ $this->registerAlias(IFileAccess::class, FileAccess::class);
+ $this->registerService('RootFolder', function (ContainerInterface $c) {
+ $manager = \OC\Files\Filesystem::getMountManager();
$view = new View();
+ /** @var IUserSession $userSession */
+ $userSession = $c->get(IUserSession::class);
$root = new Root(
$manager,
$view,
- null,
- $c->getUserMountCache(),
- $this->getLogger(),
- $this->getUserManager()
+ $userSession->getUser(),
+ $c->get(IUserMountCache::class),
+ $this->get(LoggerInterface::class),
+ $this->get(IUserManager::class),
+ $this->get(IEventDispatcher::class),
+ $this->get(ICacheFactory::class),
);
- $connector = new HookConnector($root, $view);
- $connector->viewToNode();
- $previewConnector = new \OC\Preview\WatcherConnector($root, $c->getSystemConfig());
+ $previewConnector = new \OC\Preview\WatcherConnector(
+ $root,
+ $c->get(SystemConfig::class),
+ $this->get(IEventDispatcher::class)
+ );
$previewConnector->connectWatcher();
return $root;
});
- $this->registerService('LazyRootFolder', function(Server $c) {
- return new LazyRoot(function() use ($c) {
- return $c->query('RootFolder');
+ $this->registerService(HookConnector::class, function (ContainerInterface $c) {
+ return new HookConnector(
+ $c->get(IRootFolder::class),
+ new View(),
+ $c->get(IEventDispatcher::class),
+ $c->get(LoggerInterface::class)
+ );
+ });
+
+ $this->registerService(IRootFolder::class, function (ContainerInterface $c) {
+ return new LazyRoot(function () use ($c) {
+ return $c->get('RootFolder');
});
});
- $this->registerService('UserManager', function (Server $c) {
- $config = $c->getConfig();
- return new \OC\User\Manager($config);
+
+ $this->registerAlias(\OCP\IUserManager::class, \OC\User\Manager::class);
+
+ $this->registerService(DisplayNameCache::class, function (ContainerInterface $c) {
+ return $c->get(\OC\User\Manager::class)->getDisplayNameCache();
});
- $this->registerService('GroupManager', function (Server $c) {
- $groupManager = new \OC\Group\Manager($this->getUserManager());
- $groupManager->listen('\OC\Group', 'preCreate', function ($gid) {
- \OC_Hook::emit('OC_Group', 'pre_createGroup', array('run' => true, 'gid' => $gid));
- });
- $groupManager->listen('\OC\Group', 'postCreate', function (\OC\Group\Group $gid) {
- \OC_Hook::emit('OC_User', 'post_createGroup', array('gid' => $gid->getGID()));
- });
- $groupManager->listen('\OC\Group', 'preDelete', function (\OC\Group\Group $group) {
- \OC_Hook::emit('OC_Group', 'pre_deleteGroup', array('run' => true, 'gid' => $group->getGID()));
- });
- $groupManager->listen('\OC\Group', 'postDelete', function (\OC\Group\Group $group) {
- \OC_Hook::emit('OC_User', 'post_deleteGroup', array('gid' => $group->getGID()));
- });
- $groupManager->listen('\OC\Group', 'preAddUser', function (\OC\Group\Group $group, \OC\User\User $user) {
- \OC_Hook::emit('OC_Group', 'pre_addToGroup', array('run' => true, 'uid' => $user->getUID(), 'gid' => $group->getGID()));
- });
- $groupManager->listen('\OC\Group', 'postAddUser', function (\OC\Group\Group $group, \OC\User\User $user) {
- \OC_Hook::emit('OC_Group', 'post_addToGroup', array('uid' => $user->getUID(), 'gid' => $group->getGID()));
- //Minimal fix to keep it backward compatible TODO: clean up all the GroupManager hooks
- \OC_Hook::emit('OC_User', 'post_addToGroup', array('uid' => $user->getUID(), 'gid' => $group->getGID()));
- });
+
+ $this->registerService(\OCP\IGroupManager::class, function (ContainerInterface $c) {
+ $groupManager = new \OC\Group\Manager(
+ $this->get(IUserManager::class),
+ $this->get(IEventDispatcher::class),
+ $this->get(LoggerInterface::class),
+ $this->get(ICacheFactory::class),
+ $this->get(IRemoteAddress::class),
+ );
return $groupManager;
});
- $this->registerService('OC\Authentication\Token\DefaultTokenMapper', function (Server $c) {
- $dbConnection = $c->getDatabaseConnection();
- return new Authentication\Token\DefaultTokenMapper($dbConnection);
- });
- $this->registerService('OC\Authentication\Token\DefaultTokenProvider', function (Server $c) {
- $mapper = $c->query('OC\Authentication\Token\DefaultTokenMapper');
- $crypto = $c->getCrypto();
- $config = $c->getConfig();
- $logger = $c->getLogger();
- $timeFactory = new TimeFactory();
- return new \OC\Authentication\Token\DefaultTokenProvider($mapper, $crypto, $config, $logger, $timeFactory);
+
+ $this->registerService(Store::class, function (ContainerInterface $c) {
+ $session = $c->get(ISession::class);
+ if (\OC::$server->get(SystemConfig::class)->getValue('installed', false)) {
+ $tokenProvider = $c->get(IProvider::class);
+ } else {
+ $tokenProvider = null;
+ }
+ $logger = $c->get(LoggerInterface::class);
+ $crypto = $c->get(ICrypto::class);
+ return new Store($session, $logger, $crypto, $tokenProvider);
});
- $this->registerAlias('OC\Authentication\Token\IProvider', 'OC\Authentication\Token\DefaultTokenProvider');
- $this->registerService('UserSession', function (Server $c) {
- $manager = $c->getUserManager();
- $session = new \OC\Session\Memory('');
+ $this->registerAlias(IStore::class, Store::class);
+ $this->registerAlias(IProvider::class, Authentication\Token\Manager::class);
+ $this->registerAlias(OCPIProvider::class, Authentication\Token\Manager::class);
+
+ $this->registerService(\OC\User\Session::class, function (Server $c) {
+ $manager = $c->get(IUserManager::class);
+ $session = new \OC\Session\Memory();
$timeFactory = new TimeFactory();
// Token providers might require a working database. This code
- // might however be called when ownCloud is not yet setup.
- if (\OC::$server->getSystemConfig()->getValue('installed', false)) {
- $defaultTokenProvider = $c->query('OC\Authentication\Token\IProvider');
+ // might however be called when Nextcloud is not yet setup.
+ if (\OC::$server->get(SystemConfig::class)->getValue('installed', false)) {
+ $provider = $c->get(IProvider::class);
} else {
- $defaultTokenProvider = null;
+ $provider = null;
}
- $userSession = new \OC\User\Session($manager, $session, $timeFactory, $defaultTokenProvider, $c->getConfig(), $c->getSecureRandom());
+ $userSession = new \OC\User\Session(
+ $manager,
+ $session,
+ $timeFactory,
+ $provider,
+ $c->get(\OCP\IConfig::class),
+ $c->get(ISecureRandom::class),
+ $c->get('LockdownManager'),
+ $c->get(LoggerInterface::class),
+ $c->get(IEventDispatcher::class),
+ );
+ /** @deprecated 21.0.0 use BeforeUserCreatedEvent event with the IEventDispatcher instead */
$userSession->listen('\OC\User', 'preCreateUser', function ($uid, $password) {
- \OC_Hook::emit('OC_User', 'pre_createUser', array('run' => true, 'uid' => $uid, 'password' => $password));
+ \OC_Hook::emit('OC_User', 'pre_createUser', ['run' => true, 'uid' => $uid, 'password' => $password]);
});
+ /** @deprecated 21.0.0 use UserCreatedEvent event with the IEventDispatcher instead */
$userSession->listen('\OC\User', 'postCreateUser', function ($user, $password) {
- /** @var $user \OC\User\User */
- \OC_Hook::emit('OC_User', 'post_createUser', array('uid' => $user->getUID(), 'password' => $password));
+ /** @var \OC\User\User $user */
+ \OC_Hook::emit('OC_User', 'post_createUser', ['uid' => $user->getUID(), 'password' => $password]);
});
+ /** @deprecated 21.0.0 use BeforeUserDeletedEvent event with the IEventDispatcher instead */
$userSession->listen('\OC\User', 'preDelete', function ($user) {
- /** @var $user \OC\User\User */
- \OC_Hook::emit('OC_User', 'pre_deleteUser', array('run' => true, 'uid' => $user->getUID()));
+ /** @var \OC\User\User $user */
+ \OC_Hook::emit('OC_User', 'pre_deleteUser', ['run' => true, 'uid' => $user->getUID()]);
});
+ /** @deprecated 21.0.0 use UserDeletedEvent event with the IEventDispatcher instead */
$userSession->listen('\OC\User', 'postDelete', function ($user) {
- /** @var $user \OC\User\User */
- \OC_Hook::emit('OC_User', 'post_deleteUser', array('uid' => $user->getUID()));
+ /** @var \OC\User\User $user */
+ \OC_Hook::emit('OC_User', 'post_deleteUser', ['uid' => $user->getUID()]);
});
$userSession->listen('\OC\User', 'preSetPassword', function ($user, $password, $recoveryPassword) {
- /** @var $user \OC\User\User */
- \OC_Hook::emit('OC_User', 'pre_setPassword', array('run' => true, 'uid' => $user->getUID(), 'password' => $password, 'recoveryPassword' => $recoveryPassword));
+ /** @var \OC\User\User $user */
+ \OC_Hook::emit('OC_User', 'pre_setPassword', ['run' => true, 'uid' => $user->getUID(), 'password' => $password, 'recoveryPassword' => $recoveryPassword]);
});
$userSession->listen('\OC\User', 'postSetPassword', function ($user, $password, $recoveryPassword) {
- /** @var $user \OC\User\User */
- \OC_Hook::emit('OC_User', 'post_setPassword', array('run' => true, 'uid' => $user->getUID(), 'password' => $password, 'recoveryPassword' => $recoveryPassword));
+ /** @var \OC\User\User $user */
+ \OC_Hook::emit('OC_User', 'post_setPassword', ['run' => true, 'uid' => $user->getUID(), 'password' => $password, 'recoveryPassword' => $recoveryPassword]);
});
$userSession->listen('\OC\User', 'preLogin', function ($uid, $password) {
- \OC_Hook::emit('OC_User', 'pre_login', array('run' => true, 'uid' => $uid, 'password' => $password));
+ \OC_Hook::emit('OC_User', 'pre_login', ['run' => true, 'uid' => $uid, 'password' => $password]);
+
+ /** @var IEventDispatcher $dispatcher */
+ $dispatcher = $this->get(IEventDispatcher::class);
+ $dispatcher->dispatchTyped(new BeforeUserLoggedInEvent($uid, $password));
});
- $userSession->listen('\OC\User', 'postLogin', function ($user, $password) {
- /** @var $user \OC\User\User */
- \OC_Hook::emit('OC_User', 'post_login', array('run' => true, 'uid' => $user->getUID(), 'password' => $password));
+ $userSession->listen('\OC\User', 'postLogin', function ($user, $loginName, $password, $isTokenLogin) {
+ /** @var \OC\User\User $user */
+ \OC_Hook::emit('OC_User', 'post_login', ['run' => true, 'uid' => $user->getUID(), 'loginName' => $loginName, 'password' => $password, 'isTokenLogin' => $isTokenLogin]);
+
+ /** @var IEventDispatcher $dispatcher */
+ $dispatcher = $this->get(IEventDispatcher::class);
+ $dispatcher->dispatchTyped(new UserLoggedInEvent($user, $loginName, $password, $isTokenLogin));
+ });
+ $userSession->listen('\OC\User', 'preRememberedLogin', function ($uid) {
+ /** @var IEventDispatcher $dispatcher */
+ $dispatcher = $this->get(IEventDispatcher::class);
+ $dispatcher->dispatchTyped(new BeforeUserLoggedInWithCookieEvent($uid));
+ });
+ $userSession->listen('\OC\User', 'postRememberedLogin', function ($user, $password) {
+ /** @var \OC\User\User $user */
+ \OC_Hook::emit('OC_User', 'post_login', ['run' => true, 'uid' => $user->getUID(), 'password' => $password]);
+
+ /** @var IEventDispatcher $dispatcher */
+ $dispatcher = $this->get(IEventDispatcher::class);
+ $dispatcher->dispatchTyped(new UserLoggedInWithCookieEvent($user, $password));
});
- $userSession->listen('\OC\User', 'logout', function () {
- \OC_Hook::emit('OC_User', 'logout', array());
+ $userSession->listen('\OC\User', 'logout', function ($user) {
+ \OC_Hook::emit('OC_User', 'logout', []);
+
+ /** @var IEventDispatcher $dispatcher */
+ $dispatcher = $this->get(IEventDispatcher::class);
+ $dispatcher->dispatchTyped(new BeforeUserLoggedOutEvent($user));
+ });
+ $userSession->listen('\OC\User', 'postLogout', function ($user) {
+ /** @var IEventDispatcher $dispatcher */
+ $dispatcher = $this->get(IEventDispatcher::class);
+ $dispatcher->dispatchTyped(new UserLoggedOutEvent($user));
});
- $userSession->listen('\OC\User', 'changeUser', function ($user, $feature, $value) {
- /** @var $user \OC\User\User */
- \OC_Hook::emit('OC_User', 'changeUser', array('run' => true, 'user' => $user, 'feature' => $feature, 'value' => $value));
+ $userSession->listen('\OC\User', 'changeUser', function ($user, $feature, $value, $oldValue) {
+ /** @var \OC\User\User $user */
+ \OC_Hook::emit('OC_User', 'changeUser', ['run' => true, 'user' => $user, 'feature' => $feature, 'value' => $value, 'old_value' => $oldValue]);
});
return $userSession;
});
+ $this->registerAlias(\OCP\IUserSession::class, \OC\User\Session::class);
- $this->registerService(\OC\Authentication\TwoFactorAuth\Manager::class, function (Server $c) {
- return new \OC\Authentication\TwoFactorAuth\Manager($c->getAppManager(), $c->getSession(), $c->getConfig(), $c->getActivityManager(), $c->getLogger());
- });
+ $this->registerAlias(\OCP\Authentication\TwoFactorAuth\IRegistry::class, \OC\Authentication\TwoFactorAuth\Registry::class);
- $this->registerService('NavigationManager', function ($c) {
- return new \OC\NavigationManager();
- });
- $this->registerService('AllConfig', function (Server $c) {
- return new \OC\AllConfig(
- $c->getSystemConfig()
- );
- });
- $this->registerService('SystemConfig', function ($c) use ($config) {
+ $this->registerAlias(INavigationManager::class, \OC\NavigationManager::class);
+
+ $this->registerAlias(\OCP\IConfig::class, \OC\AllConfig::class);
+
+ $this->registerService(\OC\SystemConfig::class, function ($c) use ($config) {
return new \OC\SystemConfig($config);
});
- $this->registerService('AppConfig', function (Server $c) {
- return new \OC\AppConfig($c->getDatabaseConnection());
- });
- $this->registerService('L10NFactory', function (Server $c) {
+
+ $this->registerAlias(IAppConfig::class, \OC\AppConfig::class);
+ $this->registerAlias(IUserConfig::class, \OC\Config\UserConfig::class);
+ $this->registerAlias(IAppManager::class, AppManager::class);
+
+ $this->registerService(IFactory::class, function (Server $c) {
return new \OC\L10N\Factory(
- $c->getConfig(),
+ $c->get(\OCP\IConfig::class),
$c->getRequest(),
- $c->getUserSession(),
- \OC::$SERVERROOT
+ $c->get(IUserSession::class),
+ $c->get(ICacheFactory::class),
+ \OC::$SERVERROOT,
+ $c->get(IAppManager::class),
);
});
- $this->registerService('URLGenerator', function (Server $c) {
- $config = $c->getConfig();
- $cacheFactory = $c->getMemCacheFactory();
- return new \OC\URLGenerator(
- $config,
- $cacheFactory
- );
- });
- $this->registerService('AppHelper', function ($c) {
- return new \OC\AppHelper();
- });
- $this->registerService('AppFetcher', function ($c) {
- return new AppFetcher(
- $this->getAppDataDir('appstore'),
- $this->getHTTPClientService(),
- $this->query(TimeFactory::class),
- $this->getConfig()
- );
- });
- $this->registerService('CategoryFetcher', function ($c) {
- return new CategoryFetcher(
- $this->getAppDataDir('appstore'),
- $this->getHTTPClientService(),
- $this->query(TimeFactory::class),
- $this->getConfig()
- );
- });
- $this->registerService('UserCache', function ($c) {
+
+ $this->registerAlias(IURLGenerator::class, URLGenerator::class);
+
+ $this->registerService(ICache::class, function ($c) {
return new Cache\File();
});
- $this->registerService('MemCacheFactory', function (Server $c) {
- $config = $c->getConfig();
-
- if ($config->getSystemValue('installed', false) && !(defined('PHPUNIT_RUN') && PHPUNIT_RUN)) {
- $v = \OC_App::getAppVersions();
- $v['core'] = md5(file_get_contents(\OC::$SERVERROOT . '/version.php'));
- $version = implode(',', $v);
- $instanceId = \OC_Util::getInstanceId();
- $path = \OC::$SERVERROOT;
- $prefix = md5($instanceId . '-' . $version . '-' . $path);
- return new \OC\Memcache\Factory($prefix, $c->getLogger(),
- $config->getSystemValue('memcache.local', null),
- $config->getSystemValue('memcache.distributed', null),
- $config->getSystemValue('memcache.locking', null)
- );
- }
- return new \OC\Memcache\Factory('', $c->getLogger(),
- '\\OC\\Memcache\\ArrayCache',
- '\\OC\\Memcache\\ArrayCache',
- '\\OC\\Memcache\\ArrayCache'
+ $this->registerService(Factory::class, function (Server $c) {
+ $profiler = $c->get(IProfiler::class);
+ $arrayCacheFactory = new \OC\Memcache\Factory(fn () => '', $c->get(LoggerInterface::class),
+ $profiler,
+ ArrayCache::class,
+ ArrayCache::class,
+ ArrayCache::class
);
+ /** @var SystemConfig $config */
+ $config = $c->get(SystemConfig::class);
+ /** @var ServerVersion $serverVersion */
+ $serverVersion = $c->get(ServerVersion::class);
+
+ if ($config->getValue('installed', false) && !(defined('PHPUNIT_RUN') && PHPUNIT_RUN)) {
+ $logQuery = $config->getValue('log_query');
+ $prefixClosure = function () use ($logQuery, $serverVersion): ?string {
+ if (!$logQuery) {
+ try {
+ $v = \OCP\Server::get(IAppConfig::class)->getAppInstalledVersions(true);
+ } catch (\Doctrine\DBAL\Exception $e) {
+ // Database service probably unavailable
+ // Probably related to https://github.com/nextcloud/server/issues/37424
+ return null;
+ }
+ } else {
+ // If the log_query is enabled, we can not get the app versions
+ // as that does a query, which will be logged and the logging
+ // depends on redis and here we are back again in the same function.
+ $v = [
+ 'log_query' => 'enabled',
+ ];
+ }
+ $v['core'] = implode(',', $serverVersion->getVersion());
+ $version = implode(',', array_keys($v)) . implode(',', $v);
+ $instanceId = \OC_Util::getInstanceId();
+ $path = \OC::$SERVERROOT;
+ return md5($instanceId . '-' . $version . '-' . $path);
+ };
+ return new \OC\Memcache\Factory($prefixClosure,
+ $c->get(LoggerInterface::class),
+ $profiler,
+ /** @psalm-taint-escape callable */
+ $config->getValue('memcache.local', null),
+ /** @psalm-taint-escape callable */
+ $config->getValue('memcache.distributed', null),
+ /** @psalm-taint-escape callable */
+ $config->getValue('memcache.locking', null),
+ /** @psalm-taint-escape callable */
+ $config->getValue('redis_log_file')
+ );
+ }
+ return $arrayCacheFactory;
});
+ $this->registerAlias(ICacheFactory::class, Factory::class);
+
$this->registerService('RedisFactory', function (Server $c) {
- $systemConfig = $c->getSystemConfig();
- return new RedisFactory($systemConfig);
+ $systemConfig = $c->get(SystemConfig::class);
+ return new RedisFactory($systemConfig, $c->get(IEventLogger::class));
});
- $this->registerService('ActivityManager', function (Server $c) {
+
+ $this->registerService(\OCP\Activity\IManager::class, function (Server $c) {
+ $l10n = $this->get(IFactory::class)->get('lib');
return new \OC\Activity\Manager(
$c->getRequest(),
- $c->getUserSession(),
- $c->getConfig(),
- $c->query(IValidator::class)
+ $c->get(IUserSession::class),
+ $c->get(\OCP\IConfig::class),
+ $c->get(IValidator::class),
+ $c->get(IRichTextFormatter::class),
+ $l10n,
+ $c->get(ITimeFactory::class),
);
});
+
$this->registerService(\OCP\Activity\IEventMerger::class, function (Server $c) {
return new \OC\Activity\EventMerger(
$c->getL10N('lib')
);
});
$this->registerAlias(IValidator::class, Validator::class);
- $this->registerService('AvatarManager', function (Server $c) {
+
+ $this->registerService(AvatarManager::class, function (Server $c) {
return new AvatarManager(
- $c->getUserManager(),
+ $c->get(IUserSession::class),
+ $c->get(\OC\User\Manager::class),
$c->getAppDataDir('avatar'),
$c->getL10N('lib'),
- $c->getLogger(),
- $c->getConfig()
+ $c->get(LoggerInterface::class),
+ $c->get(\OCP\IConfig::class),
+ $c->get(IAccountManager::class),
+ $c->get(KnownUserService::class)
);
});
- $this->registerService('Logger', function (Server $c) {
- $logClass = $c->query('AllConfig')->getSystemValue('log_type', 'file');
- // TODO: Drop backwards compatibility for config in the future
- $logger = 'OC\\Log\\' . ucfirst($logClass=='owncloud' ? 'file' : $logClass);
- call_user_func(array($logger, 'init'));
- return new Log($logger);
+ $this->registerAlias(IAvatarManager::class, AvatarManager::class);
+
+ $this->registerAlias(\OCP\Support\CrashReport\IRegistry::class, \OC\Support\CrashReport\Registry::class);
+ $this->registerAlias(\OCP\Support\Subscription\IRegistry::class, \OC\Support\Subscription\Registry::class);
+ $this->registerAlias(\OCP\Support\Subscription\IAssertion::class, \OC\Support\Subscription\Assertion::class);
+
+ /** Only used by the PsrLoggerAdapter should not be used by apps */
+ $this->registerService(\OC\Log::class, function (Server $c) {
+ $logType = $c->get(AllConfig::class)->getSystemValue('log_type', 'file');
+ $factory = new LogFactory($c, $this->get(SystemConfig::class));
+ $logger = $factory->get($logType);
+ $registry = $c->get(\OCP\Support\CrashReport\IRegistry::class);
+
+ return new Log($logger, $this->get(SystemConfig::class), crashReporters: $registry);
});
- $this->registerService('JobList', function (Server $c) {
- $config = $c->getConfig();
- return new \OC\BackgroundJob\JobList(
- $c->getDatabaseConnection(),
- $config,
- new TimeFactory()
- );
+ // PSR-3 logger
+ $this->registerAlias(LoggerInterface::class, PsrLoggerAdapter::class);
+
+ $this->registerService(ILogFactory::class, function (Server $c) {
+ return new LogFactory($c, $this->get(SystemConfig::class));
});
- $this->registerService('Router', function (Server $c) {
- $cacheFactory = $c->getMemCacheFactory();
- $logger = $c->getLogger();
- if ($cacheFactory->isAvailable()) {
- $router = new \OC\Route\CachingRouter($cacheFactory->create('route'), $logger);
+
+ $this->registerAlias(IJobList::class, \OC\BackgroundJob\JobList::class);
+
+ $this->registerService(Router::class, function (Server $c) {
+ $cacheFactory = $c->get(ICacheFactory::class);
+ if ($cacheFactory->isLocalCacheAvailable()) {
+ $router = $c->resolve(CachingRouter::class);
} else {
- $router = new \OC\Route\Router($logger);
+ $router = $c->resolve(Router::class);
}
return $router;
});
- $this->registerService('Search', function ($c) {
- return new Search();
- });
- $this->registerService('SecureRandom', function ($c) {
- return new SecureRandom();
- });
- $this->registerService('Crypto', function (Server $c) {
- return new Crypto($c->getConfig(), $c->getSecureRandom());
- });
- $this->registerService('Hasher', function (Server $c) {
- return new Hasher($c->getConfig());
- });
- $this->registerService('CredentialsManager', function (Server $c) {
- return new CredentialsManager($c->getCrypto(), $c->getDatabaseConnection());
+ $this->registerAlias(IRouter::class, Router::class);
+
+ $this->registerService(\OC\Security\RateLimiting\Backend\IBackend::class, function ($c) {
+ $config = $c->get(\OCP\IConfig::class);
+ if (ltrim($config->getSystemValueString('memcache.distributed', ''), '\\') === \OC\Memcache\Redis::class) {
+ $backend = new \OC\Security\RateLimiting\Backend\MemoryCacheBackend(
+ $c->get(AllConfig::class),
+ $this->get(ICacheFactory::class),
+ new \OC\AppFramework\Utility\TimeFactory()
+ );
+ } else {
+ $backend = new \OC\Security\RateLimiting\Backend\DatabaseBackend(
+ $c->get(AllConfig::class),
+ $c->get(IDBConnection::class),
+ new \OC\AppFramework\Utility\TimeFactory()
+ );
+ }
+
+ return $backend;
});
- $this->registerService('DatabaseConnection', function (Server $c) {
- $systemConfig = $c->getSystemConfig();
- $factory = new \OC\DB\ConnectionFactory($c->getConfig());
+
+ $this->registerAlias(\OCP\Security\ISecureRandom::class, SecureRandom::class);
+ $this->registerAlias(\OCP\Security\IRemoteHostValidator::class, \OC\Security\RemoteHostValidator::class);
+ $this->registerAlias(IVerificationToken::class, VerificationToken::class);
+
+ $this->registerAlias(ICrypto::class, Crypto::class);
+
+ $this->registerAlias(IHasher::class, Hasher::class);
+
+ $this->registerAlias(ICredentialsManager::class, CredentialsManager::class);
+
+ $this->registerAlias(IDBConnection::class, ConnectionAdapter::class);
+ $this->registerService(Connection::class, function (Server $c) {
+ $systemConfig = $c->get(SystemConfig::class);
+ $factory = new \OC\DB\ConnectionFactory($systemConfig, $c->get(ICacheFactory::class));
$type = $systemConfig->getValue('dbtype', 'sqlite');
if (!$factory->isValidType($type)) {
throw new \OC\DatabaseException('Invalid database type');
}
- $connectionParams = $factory->createConnectionParams($systemConfig);
- $connection = $factory->getConnection($type, $connectionParams);
- $connection->getConfiguration()->setSQLLogger($c->getQueryLogger());
+ $connection = $factory->getConnection($type, []);
return $connection;
});
- $this->registerService('HTTPHelper', function (Server $c) {
- $config = $c->getConfig();
- return new HTTPHelper(
- $config,
- $c->getHTTPClientService()
- );
- });
- $this->registerService('HttpClientService', function (Server $c) {
- $user = \OC_User::getUser();
- $uid = $user ? $user : null;
- return new ClientService(
- $c->getConfig(),
- new \OC\Security\CertificateManager($uid, new View(), $c->getConfig())
+
+ $this->registerAlias(ICertificateManager::class, CertificateManager::class);
+ $this->registerAlias(IClientService::class, ClientService::class);
+ $this->registerService(NegativeDnsCache::class, function (ContainerInterface $c) {
+ return new NegativeDnsCache(
+ $c->get(ICacheFactory::class),
);
});
- $this->registerService('EventLogger', function (Server $c) {
- if ($c->getSystemConfig()->getValue('debug', false)) {
- return new EventLogger();
- } else {
- return new NullEventLogger();
- }
+ $this->registerDeprecatedAlias('HttpClientService', IClientService::class);
+ $this->registerService(IEventLogger::class, function (ContainerInterface $c) {
+ return new EventLogger($c->get(SystemConfig::class), $c->get(LoggerInterface::class), $c->get(Log::class));
});
- $this->registerService('QueryLogger', function (Server $c) {
- if ($c->getSystemConfig()->getValue('debug', false)) {
- return new QueryLogger();
- } else {
- return new NullQueryLogger();
+
+ $this->registerService(IQueryLogger::class, function (ContainerInterface $c) {
+ $queryLogger = new QueryLogger();
+ if ($c->get(SystemConfig::class)->getValue('debug', false)) {
+ // In debug mode, module is being activated by default
+ $queryLogger->activate();
}
+ return $queryLogger;
});
- $this->registerService('TempManager', function (Server $c) {
- return new TempManager(
- $c->getLogger(),
- $c->getConfig()
- );
- });
- $this->registerService('AppManager', function (Server $c) {
- return new \OC\App\AppManager(
- $c->getUserSession(),
- $c->getAppConfig(),
- $c->getGroupManager(),
- $c->getMemCacheFactory(),
- $c->getEventDispatcher()
- );
- });
- $this->registerService('DateTimeZone', function (Server $c) {
- return new DateTimeZone(
- $c->getConfig(),
- $c->getSession()
- );
- });
- $this->registerService('DateTimeFormatter', function (Server $c) {
- $language = $c->getConfig()->getUserValue($c->getSession()->get('user_id'), 'core', 'lang', null);
+
+ $this->registerAlias(ITempManager::class, TempManager::class);
+ $this->registerAlias(IDateTimeZone::class, DateTimeZone::class);
+
+ $this->registerService(IDateTimeFormatter::class, function (Server $c) {
+ $language = $c->get(\OCP\IConfig::class)->getUserValue($c->get(ISession::class)->get('user_id'), 'core', 'lang', null);
return new DateTimeFormatter(
- $c->getDateTimeZone()->getTimeZone(),
+ $c->get(IDateTimeZone::class)->getTimeZone(),
$c->getL10N('lib', $language)
);
});
- $this->registerService('UserMountCache', function (Server $c) {
- $mountCache = new UserMountCache($c->getDatabaseConnection(), $c->getUserManager(), $c->getLogger());
+
+ $this->registerService(IUserMountCache::class, function (ContainerInterface $c) {
+ $mountCache = $c->get(UserMountCache::class);
$listener = new UserMountCacheListener($mountCache);
- $listener->listen($c->getUserManager());
+ $listener->listen($c->get(IUserManager::class));
return $mountCache;
});
- $this->registerService('MountConfigManager', function (Server $c) {
- $loader = \OC\Files\Filesystem::getLoader();
- $mountCache = $c->query('UserMountCache');
- $manager = new \OC\Files\Config\MountProviderCollection($loader, $mountCache);
+
+ $this->registerService(IMountProviderCollection::class, function (ContainerInterface $c) {
+ $loader = $c->get(IStorageFactory::class);
+ $mountCache = $c->get(IUserMountCache::class);
+ $eventLogger = $c->get(IEventLogger::class);
+ $manager = new MountProviderCollection($loader, $mountCache, $eventLogger);
// builtin providers
- $config = $c->getConfig();
+ $config = $c->get(\OCP\IConfig::class);
+ $logger = $c->get(LoggerInterface::class);
+ $objectStoreConfig = $c->get(PrimaryObjectStoreConfig::class);
$manager->registerProvider(new CacheMountProvider($config));
$manager->registerHomeProvider(new LocalHomeMountProvider());
- $manager->registerHomeProvider(new ObjectHomeMountProvider($config));
+ $manager->registerHomeProvider(new ObjectHomeMountProvider($objectStoreConfig));
+ $manager->registerRootProvider(new RootMountProvider($objectStoreConfig, $config));
+ $manager->registerRootProvider(new ObjectStorePreviewCacheMountProvider($logger, $config));
return $manager;
});
- $this->registerService('IniWrapper', function ($c) {
- return new IniGetWrapper();
- });
- $this->registerService('AsyncCommandBus', function (Server $c) {
- $jobList = $c->getJobList();
- return new AsyncBus($jobList);
- });
- $this->registerService('TrustedDomainHelper', function ($c) {
- return new TrustedDomainHelper($this->getConfig());
+
+ $this->registerService(IBus::class, function (ContainerInterface $c) {
+ $busClass = $c->get(\OCP\IConfig::class)->getSystemValueString('commandbus');
+ if ($busClass) {
+ [$app, $class] = explode('::', $busClass, 2);
+ if ($c->get(IAppManager::class)->isEnabledForUser($app)) {
+ $c->get(IAppManager::class)->loadApp($app);
+ return $c->get($class);
+ } else {
+ throw new ServiceUnavailableException("The app providing the command bus ($app) is not enabled");
+ }
+ } else {
+ $jobList = $c->get(IJobList::class);
+ return new CronBus($jobList);
+ }
});
- $this->registerService('Throttler', function(Server $c) {
- return new Throttler(
- $c->getDatabaseConnection(),
- new TimeFactory(),
- $c->getLogger(),
- $c->getConfig()
- );
+ $this->registerDeprecatedAlias('AsyncCommandBus', IBus::class);
+ $this->registerAlias(ITrustedDomainHelper::class, TrustedDomainHelper::class);
+ $this->registerAlias(IThrottler::class, Throttler::class);
+
+ $this->registerService(\OC\Security\Bruteforce\Backend\IBackend::class, function ($c) {
+ $config = $c->get(\OCP\IConfig::class);
+ if (!$config->getSystemValueBool('auth.bruteforce.protection.force.database', false)
+ && ltrim($config->getSystemValueString('memcache.distributed', ''), '\\') === \OC\Memcache\Redis::class) {
+ $backend = $c->get(\OC\Security\Bruteforce\Backend\MemoryCacheBackend::class);
+ } else {
+ $backend = $c->get(\OC\Security\Bruteforce\Backend\DatabaseBackend::class);
+ }
+
+ return $backend;
});
- $this->registerService('IntegrityCodeChecker', function (Server $c) {
- // IConfig and IAppManager requires a working database. This code
- // might however be called when ownCloud is not yet setup.
- if(\OC::$server->getSystemConfig()->getValue('installed', false)) {
- $config = $c->getConfig();
- $appManager = $c->getAppManager();
+
+ $this->registerDeprecatedAlias('IntegrityCodeChecker', Checker::class);
+ $this->registerService(Checker::class, function (ContainerInterface $c) {
+ // IConfig requires a working database. This code
+ // might however be called when Nextcloud is not yet setup.
+ if (\OC::$server->get(SystemConfig::class)->getValue('installed', false)) {
+ $config = $c->get(\OCP\IConfig::class);
+ $appConfig = $c->get(\OCP\IAppConfig::class);
} else {
$config = null;
- $appManager = null;
+ $appConfig = null;
}
return new Checker(
- new EnvironmentHelper(),
- new FileAccessHelper(),
- new AppLocator(),
- $config,
- $c->getMemCacheFactory(),
- $appManager,
- $c->getTempManager()
+ $c->get(ServerVersion::class),
+ $c->get(EnvironmentHelper::class),
+ new FileAccessHelper(),
+ new AppLocator(),
+ $config,
+ $appConfig,
+ $c->get(ICacheFactory::class),
+ $c->get(IAppManager::class),
+ $c->get(IMimeTypeDetector::class)
);
});
- $this->registerService('Request', function ($c) {
+ $this->registerService(Request::class, function (ContainerInterface $c) {
if (isset($this['urlParams'])) {
$urlParams = $this['urlParams'];
} else {
@@ -612,112 +898,186 @@ class Server extends ServerContainer implements IServerContainer {
'cookies' => $_COOKIE,
'method' => (isset($_SERVER) && isset($_SERVER['REQUEST_METHOD']))
? $_SERVER['REQUEST_METHOD']
- : null,
+ : '',
'urlParams' => $urlParams,
],
- $this->getSecureRandom(),
- $this->getConfig(),
- $this->getCsrfTokenManager(),
+ $this->get(IRequestId::class),
+ $this->get(\OCP\IConfig::class),
+ $this->get(CsrfTokenManager::class),
$stream
);
});
- $this->registerService('Mailer', function (Server $c) {
+ $this->registerAlias(\OCP\IRequest::class, Request::class);
+
+ $this->registerService(IRequestId::class, function (ContainerInterface $c): IRequestId {
+ return new RequestId(
+ $_SERVER['UNIQUE_ID'] ?? '',
+ $this->get(ISecureRandom::class)
+ );
+ });
+
+ $this->registerService(IMailer::class, function (Server $c) {
return new Mailer(
- $c->getConfig(),
- $c->getLogger(),
- $c->getThemingDefaults()
+ $c->get(\OCP\IConfig::class),
+ $c->get(LoggerInterface::class),
+ $c->get(Defaults::class),
+ $c->get(IURLGenerator::class),
+ $c->getL10N('lib'),
+ $c->get(IEventDispatcher::class),
+ $c->get(IFactory::class)
);
});
- $this->registerService('LDAPProvider', function(Server $c) {
- $config = $c->getConfig();
+
+ /** @since 30.0.0 */
+ $this->registerAlias(\OCP\Mail\Provider\IManager::class, \OC\Mail\Provider\Manager::class);
+
+ $this->registerService(ILDAPProviderFactory::class, function (ContainerInterface $c) {
+ $config = $c->get(\OCP\IConfig::class);
$factoryClass = $config->getSystemValue('ldapProviderFactory', null);
- if(is_null($factoryClass)) {
- throw new \Exception('ldapProviderFactory not set');
+ if (is_null($factoryClass) || !class_exists($factoryClass)) {
+ return new NullLDAPProviderFactory($this);
}
/** @var \OCP\LDAP\ILDAPProviderFactory $factory */
- $factory = new $factoryClass($this);
+ return new $factoryClass($this);
+ });
+ $this->registerService(ILDAPProvider::class, function (ContainerInterface $c) {
+ $factory = $c->get(ILDAPProviderFactory::class);
return $factory->getLDAPProvider();
});
- $this->registerService('LockingProvider', function (Server $c) {
- $ini = $c->getIniWrapper();
- $config = $c->getConfig();
- $ttl = $config->getSystemValue('filelocking.ttl', max(3600, $ini->getNumeric('max_execution_time')));
- if ($config->getSystemValue('filelocking.enabled', true) or (defined('PHPUNIT_RUN') && PHPUNIT_RUN)) {
+ $this->registerService(ILockingProvider::class, function (ContainerInterface $c) {
+ $ini = $c->get(IniGetWrapper::class);
+ $config = $c->get(\OCP\IConfig::class);
+ $ttl = $config->getSystemValueInt('filelocking.ttl', max(3600, $ini->getNumeric('max_execution_time')));
+ if ($config->getSystemValueBool('filelocking.enabled', true) or (defined('PHPUNIT_RUN') && PHPUNIT_RUN)) {
/** @var \OC\Memcache\Factory $memcacheFactory */
- $memcacheFactory = $c->getMemCacheFactory();
+ $memcacheFactory = $c->get(ICacheFactory::class);
$memcache = $memcacheFactory->createLocking('lock');
if (!($memcache instanceof \OC\Memcache\NullCache)) {
- return new MemcacheLockingProvider($memcache, $ttl);
+ $timeFactory = $c->get(ITimeFactory::class);
+ return new MemcacheLockingProvider($memcache, $timeFactory, $ttl);
}
- return new DBLockingProvider($c->getDatabaseConnection(), $c->getLogger(), new TimeFactory(), $ttl);
+ return new DBLockingProvider(
+ $c->get(IDBConnection::class),
+ new TimeFactory(),
+ $ttl,
+ !\OC::$CLI
+ );
}
return new NoopLockingProvider();
});
- $this->registerService('MountManager', function () {
- return new \OC\Files\Mount\Manager();
+
+ $this->registerService(ILockManager::class, function (Server $c): LockManager {
+ return new LockManager();
+ });
+
+ $this->registerAlias(ILockdownManager::class, 'LockdownManager');
+ $this->registerService(SetupManager::class, function ($c) {
+ // create the setupmanager through the mount manager to resolve the cyclic dependency
+ return $c->get(\OC\Files\Mount\Manager::class)->getSetupManager();
});
- $this->registerService('MimeTypeDetector', function (Server $c) {
+ $this->registerAlias(IMountManager::class, \OC\Files\Mount\Manager::class);
+
+ $this->registerService(IMimeTypeDetector::class, function (ContainerInterface $c) {
return new \OC\Files\Type\Detection(
- $c->getURLGenerator(),
+ $c->get(IURLGenerator::class),
+ $c->get(LoggerInterface::class),
\OC::$configDir,
\OC::$SERVERROOT . '/resources/config/'
);
});
- $this->registerService('MimeTypeLoader', function (Server $c) {
- return new \OC\Files\Type\Loader(
- $c->getDatabaseConnection()
- );
- });
- $this->registerService('NotificationManager', function (Server $c) {
- return new Manager(
- $c->query(IValidator::class)
- );
+
+ $this->registerAlias(IMimeTypeLoader::class, Loader::class);
+ $this->registerService(BundleFetcher::class, function () {
+ return new BundleFetcher($this->getL10N('lib'));
});
- $this->registerService('CapabilitiesManager', function (Server $c) {
- $manager = new \OC\CapabilitiesManager($c->getLogger());
+ $this->registerAlias(\OCP\Notification\IManager::class, Manager::class);
+
+ $this->registerService(CapabilitiesManager::class, function (ContainerInterface $c) {
+ $manager = new CapabilitiesManager($c->get(LoggerInterface::class));
$manager->registerCapability(function () use ($c) {
- return new \OC\OCS\CoreCapabilities($c->getConfig());
+ return new \OC\OCS\CoreCapabilities($c->get(\OCP\IConfig::class));
+ });
+ $manager->registerCapability(function () use ($c) {
+ return $c->get(\OC\Security\Bruteforce\Capabilities::class);
});
return $manager;
});
- $this->registerService('CommentsManager', function(Server $c) {
- $config = $c->getConfig();
- $factoryClass = $config->getSystemValue('comments.managerFactory', '\OC\Comments\ManagerFactory');
+
+ $this->registerService(ICommentsManager::class, function (Server $c) {
+ $config = $c->get(\OCP\IConfig::class);
+ $factoryClass = $config->getSystemValue('comments.managerFactory', CommentsManagerFactory::class);
/** @var \OCP\Comments\ICommentsManagerFactory $factory */
$factory = new $factoryClass($this);
- return $factory->getManager();
- });
- $this->registerService('ThemingDefaults', function(Server $c) {
- /*
- * Dark magic for autoloader.
- * If we do a class_exists it will try to load the class which will
- * make composer cache the result. Resulting in errors when enabling
- * the theming app.
- */
- $prefixes = \OC::$composerAutoloader->getPrefixesPsr4();
- if (isset($prefixes['OCA\\Theming\\'])) {
- $classExists = true;
- } else {
+ $manager = $factory->getManager();
+
+ $manager->registerDisplayNameResolver('user', function ($id) use ($c) {
+ $manager = $c->get(IUserManager::class);
+ $userDisplayName = $manager->getDisplayName($id);
+ if ($userDisplayName === null) {
+ $l = $c->get(IFactory::class)->get('core');
+ return $l->t('Unknown account');
+ }
+ return $userDisplayName;
+ });
+
+ return $manager;
+ });
+
+ $this->registerAlias(\OC_Defaults::class, 'ThemingDefaults');
+ $this->registerService('ThemingDefaults', function (Server $c) {
+ try {
+ $classExists = class_exists('OCA\Theming\ThemingDefaults');
+ } catch (\OCP\AutoloadNotAllowedException $e) {
+ // App disabled or in maintenance mode
$classExists = false;
}
- if ($classExists && $c->getConfig()->getSystemValue('installed', false) && $c->getAppManager()->isInstalled('theming')) {
+ if ($classExists && $c->get(\OCP\IConfig::class)->getSystemValueBool('installed', false) && $c->get(IAppManager::class)->isEnabledForAnyone('theming') && $c->get(TrustedDomainHelper::class)->isTrustedDomain($c->getRequest()->getInsecureServerHost())) {
+ $backgroundService = new BackgroundService(
+ $c->get(IRootFolder::class),
+ $c->getAppDataDir('theming'),
+ $c->get(IAppConfig::class),
+ $c->get(\OCP\IConfig::class),
+ $c->get(ISession::class)->get('user_id'),
+ );
+ $imageManager = new ImageManager(
+ $c->get(\OCP\IConfig::class),
+ $c->getAppDataDir('theming'),
+ $c->get(IURLGenerator::class),
+ $c->get(ICacheFactory::class),
+ $c->get(LoggerInterface::class),
+ $c->get(ITempManager::class),
+ $backgroundService,
+ );
return new ThemingDefaults(
- $c->getConfig(),
+ $c->get(\OCP\IConfig::class),
+ $c->get(\OCP\IAppConfig::class),
$c->getL10N('theming'),
- $c->getURLGenerator(),
- new \OC_Defaults(),
- $c->getLazyRootFolder(),
- $c->getMemCacheFactory()
+ $c->get(IUserSession::class),
+ $c->get(IURLGenerator::class),
+ $c->get(ICacheFactory::class),
+ new Util($c->get(ServerVersion::class), $c->get(\OCP\IConfig::class), $this->get(IAppManager::class), $c->getAppDataDir('theming'), $imageManager),
+ $imageManager,
+ $c->get(IAppManager::class),
+ $c->get(INavigationManager::class),
+ $backgroundService,
);
}
return new \OC_Defaults();
});
- $this->registerService('EventDispatcher', function () {
- return new EventDispatcher();
+ $this->registerService(JSCombiner::class, function (Server $c) {
+ return new JSCombiner(
+ $c->getAppDataDir('js'),
+ $c->get(IURLGenerator::class),
+ $this->get(ICacheFactory::class),
+ $c->get(SystemConfig::class),
+ $c->get(LoggerInterface::class)
+ );
});
- $this->registerService('CryptoWrapper', function (Server $c) {
- // FIXME: Instantiiated here due to cyclic dependency
+ $this->registerAlias(\OCP\EventDispatcher\IEventDispatcher::class, \OC\EventDispatcher\EventDispatcher::class);
+
+ $this->registerService('CryptoWrapper', function (ContainerInterface $c) {
+ // FIXME: Instantiated here due to cyclic dependency
$request = new Request(
[
'get' => $_GET,
@@ -730,120 +1090,240 @@ class Server extends ServerContainer implements IServerContainer {
? $_SERVER['REQUEST_METHOD']
: null,
],
- $c->getSecureRandom(),
- $c->getConfig()
+ $c->get(IRequestId::class),
+ $c->get(\OCP\IConfig::class)
);
return new CryptoWrapper(
- $c->getConfig(),
- $c->getCrypto(),
- $c->getSecureRandom(),
+ $c->get(ICrypto::class),
+ $c->get(ISecureRandom::class),
$request
);
});
- $this->registerService('CsrfTokenManager', function (Server $c) {
- $tokenGenerator = new CsrfTokenGenerator($c->getSecureRandom());
+ $this->registerService(SessionStorage::class, function (ContainerInterface $c) {
+ return new SessionStorage($c->get(ISession::class));
+ });
+ $this->registerAlias(\OCP\Security\IContentSecurityPolicyManager::class, ContentSecurityPolicyManager::class);
- return new CsrfTokenManager(
- $tokenGenerator,
- $c->query(SessionStorage::class)
- );
+ $this->registerService(IProviderFactory::class, function (ContainerInterface $c) {
+ $config = $c->get(\OCP\IConfig::class);
+ $factoryClass = $config->getSystemValue('sharing.managerFactory', ProviderFactory::class);
+ /** @var \OCP\Share\IProviderFactory $factory */
+ return $c->get($factoryClass);
});
- $this->registerService(SessionStorage::class, function (Server $c) {
- return new SessionStorage($c->getSession());
+
+ $this->registerAlias(\OCP\Share\IManager::class, \OC\Share20\Manager::class);
+
+ $this->registerService(\OCP\Collaboration\Collaborators\ISearch::class, function (Server $c) {
+ $instance = new Collaboration\Collaborators\Search($c);
+
+ // register default plugins
+ $instance->registerPlugin(['shareType' => 'SHARE_TYPE_USER', 'class' => UserPlugin::class]);
+ $instance->registerPlugin(['shareType' => 'SHARE_TYPE_GROUP', 'class' => GroupPlugin::class]);
+ $instance->registerPlugin(['shareType' => 'SHARE_TYPE_EMAIL', 'class' => MailPlugin::class]);
+ $instance->registerPlugin(['shareType' => 'SHARE_TYPE_REMOTE', 'class' => RemotePlugin::class]);
+ $instance->registerPlugin(['shareType' => 'SHARE_TYPE_REMOTE_GROUP', 'class' => RemoteGroupPlugin::class]);
+
+ return $instance;
});
- $this->registerService('ContentSecurityPolicyManager', function (Server $c) {
- return new ContentSecurityPolicyManager();
+ $this->registerAlias(\OCP\Collaboration\Collaborators\ISearchResult::class, \OC\Collaboration\Collaborators\SearchResult::class);
+
+ $this->registerAlias(\OCP\Collaboration\AutoComplete\IManager::class, \OC\Collaboration\AutoComplete\Manager::class);
+
+ $this->registerAlias(\OCP\Collaboration\Resources\IProviderManager::class, \OC\Collaboration\Resources\ProviderManager::class);
+ $this->registerAlias(\OCP\Collaboration\Resources\IManager::class, \OC\Collaboration\Resources\Manager::class);
+
+ $this->registerAlias(IReferenceManager::class, ReferenceManager::class);
+ $this->registerAlias(ITeamManager::class, TeamManager::class);
+
+ $this->registerDeprecatedAlias('SettingsManager', \OC\Settings\Manager::class);
+ $this->registerAlias(\OCP\Settings\IManager::class, \OC\Settings\Manager::class);
+ $this->registerService(\OC\Files\AppData\Factory::class, function (ContainerInterface $c) {
+ return new \OC\Files\AppData\Factory(
+ $c->get(IRootFolder::class),
+ $c->get(SystemConfig::class)
+ );
+ });
+
+ $this->registerService('LockdownManager', function (ContainerInterface $c) {
+ return new LockdownManager(function () use ($c) {
+ return $c->get(ISession::class);
+ });
});
- $this->registerService('ContentSecurityPolicyNonceManager', function(Server $c) {
- return new ContentSecurityPolicyNonceManager(
- $c->getCsrfTokenManager(),
- $c->getRequest()
+
+ $this->registerService(\OCP\OCS\IDiscoveryService::class, function (ContainerInterface $c) {
+ return new DiscoveryService(
+ $c->get(ICacheFactory::class),
+ $c->get(IClientService::class)
);
});
- $this->registerService('ShareManager', function(Server $c) {
- $config = $c->getConfig();
- $factoryClass = $config->getSystemValue('sharing.managerFactory', '\OC\Share20\ProviderFactory');
- /** @var \OCP\Share\IProviderFactory $factory */
- $factory = new $factoryClass($this);
+ $this->registerAlias(IOCMDiscoveryService::class, OCMDiscoveryService::class);
- $manager = new \OC\Share20\Manager(
- $c->getLogger(),
- $c->getConfig(),
- $c->getSecureRandom(),
- $c->getHasher(),
- $c->getMountManager(),
- $c->getGroupManager(),
- $c->getL10N('core'),
- $factory,
- $c->getUserManager(),
- $c->getLazyRootFolder(),
- $c->getEventDispatcher()
+ $this->registerService(ICloudIdManager::class, function (ContainerInterface $c) {
+ return new CloudIdManager(
+ $c->get(ICacheFactory::class),
+ $c->get(IEventDispatcher::class),
+ $c->get(\OCP\Contacts\IManager::class),
+ $c->get(IURLGenerator::class),
+ $c->get(IUserManager::class),
);
+ });
- return $manager;
+ $this->registerAlias(\OCP\GlobalScale\IConfig::class, \OC\GlobalScale\Config::class);
+ $this->registerAlias(ICloudFederationProviderManager::class, CloudFederationProviderManager::class);
+ $this->registerService(ICloudFederationFactory::class, function (Server $c) {
+ return new CloudFederationFactory();
});
- $this->registerService('SettingsManager', function(Server $c) {
- $manager = new \OC\Settings\Manager(
- $c->getLogger(),
- $c->getDatabaseConnection(),
- $c->getL10N('lib'),
- $c->getConfig(),
- $c->getEncryptionManager(),
- $c->getUserManager(),
- $c->getLockingProvider(),
- new \OC\Settings\Mapper($c->getDatabaseConnection())
+
+ $this->registerAlias(\OCP\AppFramework\Utility\IControllerMethodReflector::class, \OC\AppFramework\Utility\ControllerMethodReflector::class);
+
+ $this->registerAlias(\OCP\AppFramework\Utility\ITimeFactory::class, \OC\AppFramework\Utility\TimeFactory::class);
+ $this->registerAlias(\Psr\Clock\ClockInterface::class, \OCP\AppFramework\Utility\ITimeFactory::class);
+
+ $this->registerService(Defaults::class, function (Server $c) {
+ return new Defaults(
+ $c->get('ThemingDefaults')
);
- return $manager;
});
- $this->registerService(\OC\Files\AppData\Factory::class, function (Server $c) {
- return new \OC\Files\AppData\Factory(
- $c->getRootFolder(),
- $c->getSystemConfig()
+
+ $this->registerService(\OCP\ISession::class, function (ContainerInterface $c) {
+ return $c->get(\OCP\IUserSession::class)->getSession();
+ }, false);
+
+ $this->registerService(IShareHelper::class, function (ContainerInterface $c) {
+ return new ShareHelper(
+ $c->get(\OCP\Share\IManager::class)
);
});
- $this->registerService('LockdownManager', function (Server $c) {
- return new LockdownManager();
+ $this->registerService(Installer::class, function (ContainerInterface $c) {
+ return new Installer(
+ $c->get(AppFetcher::class),
+ $c->get(IClientService::class),
+ $c->get(ITempManager::class),
+ $c->get(LoggerInterface::class),
+ $c->get(\OCP\IConfig::class),
+ \OC::$CLI
+ );
});
- /* To trick DI since we don't extend the DIContainer here */
- $this->registerService(CleanPreviewsBackgroundJob::class, function (Server $c) {
- return new CleanPreviewsBackgroundJob(
- $c->getRootFolder(),
- $c->getLogger(),
- $c->getJobList(),
- new TimeFactory()
- );
+ $this->registerService(IApiFactory::class, function (ContainerInterface $c) {
+ return new ApiFactory($c->get(IClientService::class));
});
+
+ $this->registerService(IInstanceFactory::class, function (ContainerInterface $c) {
+ $memcacheFactory = $c->get(ICacheFactory::class);
+ return new InstanceFactory($memcacheFactory->createLocal('remoteinstance.'), $c->get(IClientService::class));
+ });
+
+ $this->registerAlias(IContactsStore::class, ContactsStore::class);
+ $this->registerAlias(IAccountManager::class, AccountManager::class);
+
+ $this->registerAlias(IStorageFactory::class, StorageFactory::class);
+
+ $this->registerAlias(\OCP\Dashboard\IManager::class, \OC\Dashboard\Manager::class);
+
+ $this->registerAlias(IFullTextSearchManager::class, FullTextSearchManager::class);
+ $this->registerAlias(IFilesMetadataManager::class, FilesMetadataManager::class);
+
+ $this->registerAlias(ISubAdmin::class, SubAdmin::class);
+
+ $this->registerAlias(IInitialStateService::class, InitialStateService::class);
+
+ $this->registerAlias(\OCP\IEmojiHelper::class, \OC\EmojiHelper::class);
+
+ $this->registerAlias(\OCP\UserStatus\IManager::class, \OC\UserStatus\Manager::class);
+
+ $this->registerAlias(IBroker::class, Broker::class);
+
+ $this->registerAlias(\OCP\Files\AppData\IAppDataFactory::class, \OC\Files\AppData\Factory::class);
+
+ $this->registerAlias(\OCP\Files\IFilenameValidator::class, \OC\Files\FilenameValidator::class);
+
+ $this->registerAlias(IBinaryFinder::class, BinaryFinder::class);
+
+ $this->registerAlias(\OCP\Share\IPublicShareTemplateFactory::class, \OC\Share20\PublicShareTemplateFactory::class);
+
+ $this->registerAlias(ITranslationManager::class, TranslationManager::class);
+
+ $this->registerAlias(IConversionManager::class, ConversionManager::class);
+
+ $this->registerAlias(ISpeechToTextManager::class, SpeechToTextManager::class);
+
+ $this->registerAlias(IEventSourceFactory::class, EventSourceFactory::class);
+
+ $this->registerAlias(\OCP\TextProcessing\IManager::class, \OC\TextProcessing\Manager::class);
+
+ $this->registerAlias(\OCP\TextToImage\IManager::class, \OC\TextToImage\Manager::class);
+
+ $this->registerAlias(ILimiter::class, Limiter::class);
+
+ $this->registerAlias(IPhoneNumberUtil::class, PhoneNumberUtil::class);
+
+ $this->registerAlias(ICapabilityAwareOCMProvider::class, OCMProvider::class);
+ $this->registerDeprecatedAlias(IOCMProvider::class, OCMProvider::class);
+
+ $this->registerAlias(ISetupCheckManager::class, SetupCheckManager::class);
+
+ $this->registerAlias(IProfileManager::class, ProfileManager::class);
+
+ $this->registerAlias(IAvailabilityCoordinator::class, AvailabilityCoordinator::class);
+
+ $this->registerAlias(IDeclarativeManager::class, DeclarativeManager::class);
+
+ $this->registerAlias(\OCP\TaskProcessing\IManager::class, \OC\TaskProcessing\Manager::class);
+
+ $this->registerAlias(IRemoteAddress::class, RemoteAddress::class);
+
+ $this->registerAlias(\OCP\Security\Ip\IFactory::class, \OC\Security\Ip\Factory::class);
+
+ $this->registerAlias(IRichTextFormatter::class, \OC\RichObjectStrings\RichTextFormatter::class);
+
+ $this->registerAlias(ISignatureManager::class, SignatureManager::class);
+
+ $this->connectDispatcher();
+ }
+
+ public function boot() {
+ /** @var HookConnector $hookConnector */
+ $hookConnector = $this->get(HookConnector::class);
+ $hookConnector->viewToNode();
+ }
+
+ private function connectDispatcher(): void {
+ /** @var IEventDispatcher $eventDispatcher */
+ $eventDispatcher = $this->get(IEventDispatcher::class);
+ $eventDispatcher->addServiceListener(LoginFailed::class, LoginFailedListener::class);
+ $eventDispatcher->addServiceListener(PostLoginEvent::class, UserLoggedInListener::class);
+ $eventDispatcher->addServiceListener(UserChangedEvent::class, UserChangedListener::class);
+ $eventDispatcher->addServiceListener(BeforeUserDeletedEvent::class, BeforeUserDeletedListener::class);
+
+ FilesMetadataManager::loadListeners($eventDispatcher);
+ GenerateBlurhashMetadata::loadListeners($eventDispatcher);
}
/**
* @return \OCP\Contacts\IManager
+ * @deprecated 20.0.0
*/
public function getContactsManager() {
- return $this->query('ContactsManager');
+ return $this->get(\OCP\Contacts\IManager::class);
}
/**
* @return \OC\Encryption\Manager
+ * @deprecated 20.0.0
*/
public function getEncryptionManager() {
- return $this->query('EncryptionManager');
+ return $this->get(\OCP\Encryption\IManager::class);
}
/**
* @return \OC\Encryption\File
+ * @deprecated 20.0.0
*/
public function getEncryptionFilesHelper() {
- return $this->query('EncryptionFileHelper');
- }
-
- /**
- * @return \OCP\Encryption\Keys\IStorage
- */
- public function getEncryptionKeyStorage() {
- return $this->query('EncryptionKeyStorage');
+ return $this->get(IFile::class);
}
/**
@@ -852,69 +1332,20 @@ class Server extends ServerContainer implements IServerContainer {
* In case the current execution was not initiated by a web request null is returned
*
* @return \OCP\IRequest
+ * @deprecated 20.0.0
*/
public function getRequest() {
- return $this->query('Request');
- }
-
- /**
- * Returns the preview manager which can create preview images for a given file
- *
- * @return \OCP\IPreview
- */
- public function getPreviewManager() {
- return $this->query('PreviewManager');
- }
-
- /**
- * Returns the tag manager which can get and set tags for different object types
- *
- * @see \OCP\ITagManager::load()
- * @return \OCP\ITagManager
- */
- public function getTagManager() {
- return $this->query('TagManager');
- }
-
- /**
- * Returns the system-tag manager
- *
- * @return \OCP\SystemTag\ISystemTagManager
- *
- * @since 9.0.0
- */
- public function getSystemTagManager() {
- return $this->query('SystemTagManager');
- }
-
- /**
- * Returns the system-tag object mapper
- *
- * @return \OCP\SystemTag\ISystemTagObjectMapper
- *
- * @since 9.0.0
- */
- public function getSystemTagObjectMapper() {
- return $this->query('SystemTagObjectMapper');
- }
-
-
- /**
- * Returns the avatar manager, used for avatar functionality
- *
- * @return \OCP\IAvatarManager
- */
- public function getAvatarManager() {
- return $this->query('AvatarManager');
+ return $this->get(IRequest::class);
}
/**
* Returns the root folder of ownCloud's data directory
*
- * @return \OCP\Files\IRootFolder
+ * @return IRootFolder
+ * @deprecated 20.0.0
*/
public function getRootFolder() {
- return $this->query('LazyRootFolder');
+ return $this->get(IRootFolder::class);
}
/**
@@ -922,10 +1353,11 @@ class Server extends ServerContainer implements IServerContainer {
* This is the lazy variant so this gets only initialized once it
* is actually used.
*
- * @return \OCP\Files\IRootFolder
+ * @return IRootFolder
+ * @deprecated 20.0.0
*/
public function getLazyRootFolder() {
- return $this->query('LazyRootFolder');
+ return $this->get(IRootFolder::class);
}
/**
@@ -933,115 +1365,84 @@ class Server extends ServerContainer implements IServerContainer {
*
* @param string $userId user ID
* @return \OCP\Files\Folder|null
+ * @deprecated 20.0.0
*/
public function getUserFolder($userId = null) {
if ($userId === null) {
- $user = $this->getUserSession()->getUser();
+ $user = $this->get(IUserSession::class)->getUser();
if (!$user) {
return null;
}
$userId = $user->getUID();
}
- $root = $this->getRootFolder();
+ $root = $this->get(IRootFolder::class);
return $root->getUserFolder($userId);
}
/**
- * Returns an app-specific view in ownClouds data directory
- *
- * @return \OCP\Files\Folder
- * @deprecated since 9.2.0 use IAppData
- */
- public function getAppFolder() {
- $dir = '/' . \OC_App::getCurrentApp();
- $root = $this->getRootFolder();
- if (!$root->nodeExists($dir)) {
- $folder = $root->newFolder($dir);
- } else {
- $folder = $root->get($dir);
- }
- return $folder;
- }
-
- /**
* @return \OC\User\Manager
+ * @deprecated 20.0.0
*/
public function getUserManager() {
- return $this->query('UserManager');
+ return $this->get(IUserManager::class);
}
/**
* @return \OC\Group\Manager
+ * @deprecated 20.0.0
*/
public function getGroupManager() {
- return $this->query('GroupManager');
+ return $this->get(IGroupManager::class);
}
/**
* @return \OC\User\Session
+ * @deprecated 20.0.0
*/
public function getUserSession() {
- return $this->query('UserSession');
+ return $this->get(IUserSession::class);
}
/**
* @return \OCP\ISession
+ * @deprecated 20.0.0
*/
public function getSession() {
- return $this->query('UserSession')->getSession();
+ return $this->get(Session::class)->getSession();
}
/**
* @param \OCP\ISession $session
+ * @return void
*/
public function setSession(\OCP\ISession $session) {
- $this->query(SessionStorage::class)->setSession($session);
- return $this->query('UserSession')->setSession($session);
- }
-
- /**
- * @return \OC\Authentication\TwoFactorAuth\Manager
- */
- public function getTwoFactorAuthManager() {
- return $this->query('\OC\Authentication\TwoFactorAuth\Manager');
- }
-
- /**
- * @return \OC\NavigationManager
- */
- public function getNavigationManager() {
- return $this->query('NavigationManager');
+ $this->get(SessionStorage::class)->setSession($session);
+ $this->get(Session::class)->setSession($session);
+ $this->get(Store::class)->setSession($session);
}
/**
* @return \OCP\IConfig
+ * @deprecated 20.0.0
*/
public function getConfig() {
- return $this->query('AllConfig');
+ return $this->get(AllConfig::class);
}
/**
- * @internal For internal use only
* @return \OC\SystemConfig
+ * @deprecated 20.0.0
*/
public function getSystemConfig() {
- return $this->query('SystemConfig');
- }
-
- /**
- * Returns the app config manager
- *
- * @return \OCP\IAppConfig
- */
- public function getAppConfig() {
- return $this->query('AppConfig');
+ return $this->get(SystemConfig::class);
}
/**
- * @return \OCP\L10N\IFactory
+ * @return IFactory
+ * @deprecated 20.0.0
*/
public function getL10NFactory() {
- return $this->query('L10NFactory');
+ return $this->get(IFactory::class);
}
/**
@@ -1050,366 +1451,179 @@ class Server extends ServerContainer implements IServerContainer {
* @param string $app appid
* @param string $lang
* @return IL10N
+ * @deprecated 20.0.0 use DI of {@see IL10N} or {@see IFactory} instead, or {@see \OCP\Util::getL10N()} as a last resort
*/
public function getL10N($app, $lang = null) {
- return $this->getL10NFactory()->get($app, $lang);
+ return $this->get(IFactory::class)->get($app, $lang);
}
/**
- * @return \OCP\IURLGenerator
+ * @return IURLGenerator
+ * @deprecated 20.0.0
*/
public function getURLGenerator() {
- return $this->query('URLGenerator');
- }
-
- /**
- * @return \OCP\IHelper
- */
- public function getHelper() {
- return $this->query('AppHelper');
- }
-
- /**
- * @return AppFetcher
- */
- public function getAppFetcher() {
- return $this->query('AppFetcher');
+ return $this->get(IURLGenerator::class);
}
/**
* Returns an ICache instance. Since 8.1.0 it returns a fake cache. Use
* getMemCacheFactory() instead.
*
- * @return \OCP\ICache
+ * @return ICache
* @deprecated 8.1.0 use getMemCacheFactory to obtain a proper cache
*/
public function getCache() {
- return $this->query('UserCache');
+ return $this->get(ICache::class);
}
/**
* Returns an \OCP\CacheFactory instance
*
* @return \OCP\ICacheFactory
+ * @deprecated 20.0.0
*/
public function getMemCacheFactory() {
- return $this->query('MemCacheFactory');
+ return $this->get(ICacheFactory::class);
}
/**
- * Returns an \OC\RedisFactory instance
- *
- * @return \OC\RedisFactory
- */
- public function getGetRedisFactory() {
- return $this->query('RedisFactory');
- }
-
-
- /**
* Returns the current session
*
* @return \OCP\IDBConnection
+ * @deprecated 20.0.0
*/
public function getDatabaseConnection() {
- return $this->query('DatabaseConnection');
+ return $this->get(IDBConnection::class);
}
/**
* Returns the activity manager
*
* @return \OCP\Activity\IManager
+ * @deprecated 20.0.0
*/
public function getActivityManager() {
- return $this->query('ActivityManager');
+ return $this->get(\OCP\Activity\IManager::class);
}
/**
* Returns an job list for controlling background jobs
*
- * @return \OCP\BackgroundJob\IJobList
+ * @return IJobList
+ * @deprecated 20.0.0
*/
public function getJobList() {
- return $this->query('JobList');
- }
-
- /**
- * Returns a logger instance
- *
- * @return \OCP\ILogger
- */
- public function getLogger() {
- return $this->query('Logger');
- }
-
- /**
- * Returns a router for generating and matching urls
- *
- * @return \OCP\Route\IRouter
- */
- public function getRouter() {
- return $this->query('Router');
- }
-
- /**
- * Returns a search instance
- *
- * @return \OCP\ISearch
- */
- public function getSearch() {
- return $this->query('Search');
+ return $this->get(IJobList::class);
}
/**
* Returns a SecureRandom instance
*
* @return \OCP\Security\ISecureRandom
+ * @deprecated 20.0.0
*/
public function getSecureRandom() {
- return $this->query('SecureRandom');
+ return $this->get(ISecureRandom::class);
}
/**
* Returns a Crypto instance
*
- * @return \OCP\Security\ICrypto
+ * @return ICrypto
+ * @deprecated 20.0.0
*/
public function getCrypto() {
- return $this->query('Crypto');
+ return $this->get(ICrypto::class);
}
/**
* Returns a Hasher instance
*
- * @return \OCP\Security\IHasher
+ * @return IHasher
+ * @deprecated 20.0.0
*/
public function getHasher() {
- return $this->query('Hasher');
- }
-
- /**
- * Returns a CredentialsManager instance
- *
- * @return \OCP\Security\ICredentialsManager
- */
- public function getCredentialsManager() {
- return $this->query('CredentialsManager');
- }
-
- /**
- * Returns an instance of the HTTP helper class
- *
- * @deprecated Use getHTTPClientService()
- * @return \OC\HTTPHelper
- */
- public function getHTTPHelper() {
- return $this->query('HTTPHelper');
- }
-
- /**
- * Get the certificate manager for the user
- *
- * @param string $userId (optional) if not specified the current loggedin user is used, use null to get the system certificate manager
- * @return \OCP\ICertificateManager | null if $uid is null and no user is logged in
- */
- public function getCertificateManager($userId = '') {
- if ($userId === '') {
- $userSession = $this->getUserSession();
- $user = $userSession->getUser();
- if (is_null($user)) {
- return null;
- }
- $userId = $user->getUID();
- }
- return new CertificateManager($userId, new View(), $this->getConfig());
+ return $this->get(IHasher::class);
}
/**
- * Returns an instance of the HTTP client service
+ * Get the certificate manager
*
- * @return \OCP\Http\Client\IClientService
+ * @return \OCP\ICertificateManager
*/
- public function getHTTPClientService() {
- return $this->query('HttpClientService');
- }
-
- /**
- * Create a new event source
- *
- * @return \OCP\IEventSource
- */
- public function createEventSource() {
- return new \OC_EventSource();
- }
-
- /**
- * Get the active event logger
- *
- * The returned logger only logs data when debug mode is enabled
- *
- * @return \OCP\Diagnostics\IEventLogger
- */
- public function getEventLogger() {
- return $this->query('EventLogger');
- }
-
- /**
- * Get the active query logger
- *
- * The returned logger only logs data when debug mode is enabled
- *
- * @return \OCP\Diagnostics\IQueryLogger
- */
- public function getQueryLogger() {
- return $this->query('QueryLogger');
+ public function getCertificateManager() {
+ return $this->get(ICertificateManager::class);
}
/**
* Get the manager for temporary files and folders
*
* @return \OCP\ITempManager
+ * @deprecated 20.0.0
*/
public function getTempManager() {
- return $this->query('TempManager');
+ return $this->get(ITempManager::class);
}
/**
* Get the app manager
*
* @return \OCP\App\IAppManager
+ * @deprecated 20.0.0
*/
public function getAppManager() {
- return $this->query('AppManager');
+ return $this->get(IAppManager::class);
}
/**
* Creates a new mailer
*
- * @return \OCP\Mail\IMailer
+ * @return IMailer
+ * @deprecated 20.0.0
*/
public function getMailer() {
- return $this->query('Mailer');
+ return $this->get(IMailer::class);
}
/**
* Get the webroot
*
* @return string
+ * @deprecated 20.0.0
*/
public function getWebRoot() {
return $this->webRoot;
}
/**
- * @return \OC\OCSClient
- */
- public function getOcsClient() {
- return $this->query('OcsClient');
- }
-
- /**
- * @return \OCP\IDateTimeZone
- */
- public function getDateTimeZone() {
- return $this->query('DateTimeZone');
- }
-
- /**
- * @return \OCP\IDateTimeFormatter
- */
- public function getDateTimeFormatter() {
- return $this->query('DateTimeFormatter');
- }
-
- /**
- * @return \OCP\Files\Config\IMountProviderCollection
- */
- public function getMountProviderCollection() {
- return $this->query('MountConfigManager');
- }
-
- /**
- * Get the IniWrapper
- *
- * @return IniGetWrapper
- */
- public function getIniWrapper() {
- return $this->query('IniWrapper');
- }
-
- /**
- * @return \OCP\Command\IBus
- */
- public function getCommandBus() {
- return $this->query('AsyncCommandBus');
- }
-
- /**
- * Get the trusted domain helper
- *
- * @return TrustedDomainHelper
- */
- public function getTrustedDomainHelper() {
- return $this->query('TrustedDomainHelper');
- }
-
- /**
* Get the locking provider
*
- * @return \OCP\Lock\ILockingProvider
+ * @return ILockingProvider
* @since 8.1.0
+ * @deprecated 20.0.0
*/
public function getLockingProvider() {
- return $this->query('LockingProvider');
- }
-
- /**
- * @return \OCP\Files\Mount\IMountManager
- **/
- function getMountManager() {
- return $this->query('MountManager');
- }
-
- /** @return \OCP\Files\Config\IUserMountCache */
- function getUserMountCache() {
- return $this->query('UserMountCache');
+ return $this->get(ILockingProvider::class);
}
/**
* Get the MimeTypeDetector
*
- * @return \OCP\Files\IMimeTypeDetector
+ * @return IMimeTypeDetector
+ * @deprecated 20.0.0
*/
public function getMimeTypeDetector() {
- return $this->query('MimeTypeDetector');
+ return $this->get(IMimeTypeDetector::class);
}
/**
* Get the MimeTypeLoader
*
- * @return \OCP\Files\IMimeTypeLoader
+ * @return IMimeTypeLoader
+ * @deprecated 20.0.0
*/
public function getMimeTypeLoader() {
- return $this->query('MimeTypeLoader');
- }
-
- /**
- * Get the manager of all the capabilities
- *
- * @return \OC\CapabilitiesManager
- */
- public function getCapabilitiesManager() {
- return $this->query('CapabilitiesManager');
- }
-
- /**
- * Get the EventDispatcher
- *
- * @return EventDispatcherInterface
- * @since 8.2.0
- */
- public function getEventDispatcher() {
- return $this->query('EventDispatcher');
+ return $this->get(IMimeTypeLoader::class);
}
/**
@@ -1417,139 +1631,66 @@ class Server extends ServerContainer implements IServerContainer {
*
* @return \OCP\Notification\IManager
* @since 8.2.0
+ * @deprecated 20.0.0
*/
public function getNotificationManager() {
- return $this->query('NotificationManager');
+ return $this->get(\OCP\Notification\IManager::class);
}
/**
- * @return \OCP\Comments\ICommentsManager
- */
- public function getCommentsManager() {
- return $this->query('CommentsManager');
- }
-
- /**
- * @return \OC_Defaults
+ * @return \OCA\Theming\ThemingDefaults
+ * @deprecated 20.0.0
*/
public function getThemingDefaults() {
- return $this->query('ThemingDefaults');
+ return $this->get('ThemingDefaults');
}
/**
* @return \OC\IntegrityCheck\Checker
+ * @deprecated 20.0.0
*/
public function getIntegrityCodeChecker() {
- return $this->query('IntegrityCodeChecker');
- }
-
- /**
- * @return \OC\Session\CryptoWrapper
- */
- public function getSessionCryptoWrapper() {
- return $this->query('CryptoWrapper');
+ return $this->get('IntegrityCodeChecker');
}
/**
* @return CsrfTokenManager
+ * @deprecated 20.0.0
*/
public function getCsrfTokenManager() {
- return $this->query('CsrfTokenManager');
- }
-
- /**
- * @return Throttler
- */
- public function getBruteForceThrottler() {
- return $this->query('Throttler');
- }
-
- /**
- * @return IContentSecurityPolicyManager
- */
- public function getContentSecurityPolicyManager() {
- return $this->query('ContentSecurityPolicyManager');
+ return $this->get(CsrfTokenManager::class);
}
/**
* @return ContentSecurityPolicyNonceManager
+ * @deprecated 20.0.0
*/
public function getContentSecurityPolicyNonceManager() {
- return $this->query('ContentSecurityPolicyNonceManager');
- }
-
- /**
- * Not a public API as of 8.2, wait for 9.0
- *
- * @return \OCA\Files_External\Service\BackendService
- */
- public function getStoragesBackendService() {
- return $this->query('OCA\\Files_External\\Service\\BackendService');
- }
-
- /**
- * Not a public API as of 8.2, wait for 9.0
- *
- * @return \OCA\Files_External\Service\GlobalStoragesService
- */
- public function getGlobalStoragesService() {
- return $this->query('OCA\\Files_External\\Service\\GlobalStoragesService');
- }
-
- /**
- * Not a public API as of 8.2, wait for 9.0
- *
- * @return \OCA\Files_External\Service\UserGlobalStoragesService
- */
- public function getUserGlobalStoragesService() {
- return $this->query('OCA\\Files_External\\Service\\UserGlobalStoragesService');
- }
-
- /**
- * Not a public API as of 8.2, wait for 9.0
- *
- * @return \OCA\Files_External\Service\UserStoragesService
- */
- public function getUserStoragesService() {
- return $this->query('OCA\\Files_External\\Service\\UserStoragesService');
- }
-
- /**
- * @return \OCP\Share\IManager
- */
- public function getShareManager() {
- return $this->query('ShareManager');
- }
-
- /**
- * Returns the LDAP Provider
- *
- * @return \OCP\LDAP\ILDAPProvider
- */
- public function getLDAPProvider() {
- return $this->query('LDAPProvider');
+ return $this->get(ContentSecurityPolicyNonceManager::class);
}
/**
* @return \OCP\Settings\IManager
+ * @deprecated 20.0.0
*/
public function getSettingsManager() {
- return $this->query('SettingsManager');
+ return $this->get(\OC\Settings\Manager::class);
}
/**
* @return \OCP\Files\IAppData
+ * @deprecated 20.0.0 Use get(\OCP\Files\AppData\IAppDataFactory::class)->get($app) instead
*/
public function getAppDataDir($app) {
- /** @var \OC\Files\AppData\Factory $factory */
- $factory = $this->query(\OC\Files\AppData\Factory::class);
+ $factory = $this->get(\OC\Files\AppData\Factory::class);
return $factory->get($app);
}
/**
- * @return \OCP\Lockdown\ILockdownManager
+ * @return \OCP\Federation\ICloudIdManager
+ * @deprecated 20.0.0
*/
- public function getLockdownManager() {
- return $this->query('LockdownManager');
+ public function getCloudIdManager() {
+ return $this->get(ICloudIdManager::class);
}
}