summaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorkesselb <mail@danielkesselberg.de>2021-03-10 14:34:02 +0100
committerGitHub <noreply@github.com>2021-03-10 14:34:02 +0100
commit62929cc646134fbd409cfb4eacb7039d15763b96 (patch)
tree835dec609f51de4023c64ec1ba609fb368a1fc09 /apps
parentd090f970dddb7e0be2aaa0ce981a903b08c8838b (diff)
parenta1e5090b3f8592a1d5facd953cc98a886dc02d7e (diff)
downloadnextcloud-server-62929cc646134fbd409cfb4eacb7039d15763b96.tar.gz
nextcloud-server-62929cc646134fbd409cfb4eacb7039d15763b96.zip
Merge pull request #26029 from nextcloud/enh/boostrap/provisioning_api
Provisioning API to IBootstrap
Diffstat (limited to 'apps')
-rw-r--r--apps/provisioning_api/lib/AppInfo/Application.php52
1 files changed, 32 insertions, 20 deletions
diff --git a/apps/provisioning_api/lib/AppInfo/Application.php b/apps/provisioning_api/lib/AppInfo/Application.php
index 9e386e99064..863f8861d8b 100644
--- a/apps/provisioning_api/lib/AppInfo/Application.php
+++ b/apps/provisioning_api/lib/AppInfo/Application.php
@@ -28,56 +28,68 @@
namespace OCA\Provisioning_API\AppInfo;
-use OC\AppFramework\Utility\SimpleContainer;
-use OC\AppFramework\Utility\TimeFactory;
use OC\Group\Manager as GroupManager;
use OCA\Provisioning_API\Middleware\ProvisioningApiMiddleware;
use OCA\Settings\Mailer\NewUserMailHelper;
use OCP\AppFramework\App;
+use OCP\AppFramework\Bootstrap\IBootContext;
+use OCP\AppFramework\Bootstrap\IBootstrap;
+use OCP\AppFramework\Bootstrap\IRegistrationContext;
use OCP\AppFramework\Utility\IControllerMethodReflector;
+use OCP\AppFramework\Utility\ITimeFactory;
use OCP\Defaults;
+use OCP\IConfig;
use OCP\IGroupManager;
+use OCP\IURLGenerator;
use OCP\IUser;
+use OCP\IUserManager;
+use OCP\L10N\IFactory;
+use OCP\Mail\IMailer;
+use OCP\Security\ICrypto;
+use OCP\Security\ISecureRandom;
use OCP\Util;
+use Psr\Container\ContainerInterface;
-class Application extends App {
+class Application extends App implements IBootstrap {
public function __construct(array $urlParams = []) {
parent::__construct('provisioning_api', $urlParams);
+ }
- $container = $this->getContainer();
- $server = $container->getServer();
-
- $container->registerService(NewUserMailHelper::class, function (SimpleContainer $c) use ($server) {
+ public function register(IRegistrationContext $context): void {
+ $context->registerService(NewUserMailHelper::class, function (ContainerInterface $c) {
return new NewUserMailHelper(
- $server->query(Defaults::class),
- $server->getURLGenerator(),
- $server->getL10NFactory(),
- $server->getMailer(),
- $server->getSecureRandom(),
- new TimeFactory(),
- $server->getConfig(),
- $server->getCrypto(),
+ $c->get(Defaults::class),
+ $c->get(IURLGenerator::class),
+ $c->get(IFactory::class),
+ $c->get(IMailer::class),
+ $c->get(ISecureRandom::class),
+ $c->get(ITimeFactory::class),
+ $c->get(IConfig::class),
+ $c->get(ICrypto::class),
Util::getDefaultEmailAddress('no-reply')
);
});
- $container->registerService('ProvisioningApiMiddleware', function (SimpleContainer $c) use ($server) {
- $user = $server->getUserManager()->get($c['UserId']);
+ $context->registerService(ProvisioningApiMiddleware::class, function (ContainerInterface $c) {
+ $user = $c->get(IUserManager::class)->get($c->get('UserId'));
$isAdmin = false;
$isSubAdmin = false;
if ($user instanceof IUser) {
- $groupManager = $server->get(IGroupManager::class);
+ $groupManager = $c->get(IGroupManager::class);
assert($groupManager instanceof GroupManager);
$isAdmin = $groupManager->isAdmin($user->getUID());
$isSubAdmin = $groupManager->getSubAdmin()->isSubAdmin($user);
}
return new ProvisioningApiMiddleware(
- $c->query(IControllerMethodReflector::class),
+ $c->get(IControllerMethodReflector::class),
$isAdmin,
$isSubAdmin
);
});
- $container->registerMiddleWare('ProvisioningApiMiddleware');
+ $context->registerMiddleware(ProvisioningApiMiddleware::class);
+ }
+
+ public function boot(IBootContext $context): void {
}
}