]> source.dussan.org Git - nextcloud-server.git/commitdiff
Migrate Two-Factor Backup Codes to new bootstrap mechanism 20865/head
authorChristoph Wurst <christoph@winzerhof-wurst.at>
Mon, 8 Jun 2020 17:27:28 +0000 (19:27 +0200)
committerChristoph Wurst <christoph@winzerhof-wurst.at>
Wed, 17 Jun 2020 07:22:22 +0000 (09:22 +0200)
Signed-off-by: Christoph Wurst <christoph@winzerhof-wurst.at>
apps/twofactor_backupcodes/appinfo/app.php [deleted file]
apps/twofactor_backupcodes/lib/AppInfo/Application.php

diff --git a/apps/twofactor_backupcodes/appinfo/app.php b/apps/twofactor_backupcodes/appinfo/app.php
deleted file mode 100644 (file)
index 2ca0108..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-<?php
-/**
- * @copyright Copyright (c) 2017 Joas Schilling <coding@schilljs.com>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Robin Appelman <robin@icewind.nl>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * 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
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- */
-
-use OCA\TwoFactorBackupCodes\AppInfo\Application;
-
-$app = \OC::$server->query(Application::class);
-$app->register();
index 3cf05073ec80e8c957d2bb7de092c607623424ac..1941cb545adb9c31ec53391704f2dbf767472472 100644 (file)
@@ -1,4 +1,7 @@
 <?php
+
+declare(strict_types=1);
+
 /**
  * @copyright Copyright (c) 2017 Joas Schilling <coding@schilljs.com>
  *
@@ -34,44 +37,44 @@ use OCA\TwoFactorBackupCodes\Listener\ProviderEnabled;
 use OCA\TwoFactorBackupCodes\Listener\RegistryUpdater;
 use OCA\TwoFactorBackupCodes\Notifications\Notifier;
 use OCP\AppFramework\App;
+use OCP\AppFramework\Bootstrap\IBootContext;
+use OCP\AppFramework\Bootstrap\IBootstrap;
+use OCP\AppFramework\Bootstrap\IRegistrationContext;
 use OCP\Authentication\TwoFactorAuth\IRegistry;
 use OCP\Notification\IManager;
 use OCP\Util;
 
-class Application extends App {
+class Application extends App implements IBootstrap {
+       public const APP_ID = 'twofactor_backupcodes';
+
        public function __construct() {
-               parent::__construct('twofactor_backupcodes');
+               parent::__construct(self::APP_ID);
        }
 
-       /**
-        * Register the different app parts
-        */
-       public function register() {
-               $this->registerHooksAndEvents();
-               $this->registerNotification();
+       public function register(IRegistrationContext $context): void {
+               $this->registerHooksAndEvents($context);
        }
 
-       /**
-        * Register the hooks and events
-        */
-       public function registerHooksAndEvents() {
+       public function boot(IBootContext $context): void {
                Util::connectHook('OC_User', 'post_deleteUser', $this, 'deleteUser');
 
-               $container = $this->getContainer();
+               $this->registerNotification(
+                       $context->getAppContainer()->query(IManager::class)
+               );
+       }
 
-               /** @var IEventDispatcher $eventDispatcher */
-               $eventDispatcher = $container->query(IEventDispatcher::class);
-               $eventDispatcher->addServiceListener(CodesGenerated::class, ActivityPublisher::class);
-               $eventDispatcher->addServiceListener(CodesGenerated::class, RegistryUpdater::class);
-               $eventDispatcher->addServiceListener(CodesGenerated::class, ClearNotifications::class);
-               $eventDispatcher->addServiceListener(IRegistry::EVENT_PROVIDER_ENABLED, ProviderEnabled::class);
-               $eventDispatcher->addServiceListener(IRegistry::EVENT_PROVIDER_DISABLED, ProviderDisabled::class);
+       /**
+        * Register the hooks and events
+        */
+       public function registerHooksAndEvents(IRegistrationContext $context) {
+               $context->registerEventListener(CodesGenerated::class, ActivityPublisher::class);
+               $context->registerEventListener(CodesGenerated::class, RegistryUpdater::class);
+               $context->registerEventListener(CodesGenerated::class, ClearNotifications::class);
+               $context->registerEventListener(IRegistry::EVENT_PROVIDER_ENABLED, ProviderEnabled::class);
+               $context->registerEventListener(IRegistry::EVENT_PROVIDER_DISABLED, ProviderDisabled::class);
        }
 
-       public function registerNotification() {
-               $container = $this->getContainer();
-               /** @var IManager $manager */
-               $manager = $container->query(IManager::class);
+       private function registerNotification(IManager $manager) {
                $manager->registerNotifierService(Notifier::class);
        }