diff options
author | Robin Appelman <robin@icewind.nl> | 2021-03-26 15:20:13 +0100 |
---|---|---|
committer | Arthur Schiwon <blizzz@arthur-schiwon.de> | 2021-06-16 13:56:20 +0200 |
commit | 3a645e2d403d2a600b1def52e643a92067f433aa (patch) | |
tree | cda3e22d5a0eb341d2f12f64112ba097b7f2a9f7 /apps | |
parent | 1052feabede4b9054047f60aaa6fe4e04e89c434 (diff) | |
download | nextcloud-server-3a645e2d403d2a600b1def52e643a92067f433aa.tar.gz nextcloud-server-3a645e2d403d2a600b1def52e643a92067f433aa.zip |
move files_external to IBootstrap
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'apps')
-rw-r--r-- | apps/files_external/appinfo/app.php | 51 | ||||
-rw-r--r-- | apps/files_external/lib/AppInfo/Application.php | 35 | ||||
-rw-r--r-- | apps/files_external/lib/Controller/ApiController.php | 2 | ||||
-rw-r--r-- | apps/files_external/lib/MountConfig.php | 3 |
4 files changed, 32 insertions, 59 deletions
diff --git a/apps/files_external/appinfo/app.php b/apps/files_external/appinfo/app.php deleted file mode 100644 index 92236f2de32..00000000000 --- a/apps/files_external/appinfo/app.php +++ /dev/null @@ -1,51 +0,0 @@ -<?php -/** - * @copyright Copyright (c) 2016, ownCloud, Inc. - * - * @author Arthur Schiwon <blizzz@arthur-schiwon.de> - * @author Jan-Christoph Borchardt <hey@jancborchardt.net> - * @author Jörn Friedrich Dreyer <jfd@butonic.de> - * @author Morris Jobke <hey@morrisjobke.de> - * @author Robin Appelman <robin@icewind.nl> - * @author Robin McCorkell <robin@mccorkell.me.uk> - * @author szaimen <szaimen@e.mail.de> - * @author Vincent Petry <vincent@nextcloud.com> - * - * @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/> - * - */ -use OCA\Files_External\Config\ConfigAdapter; - -require_once __DIR__ . '/../3rdparty/autoload.php'; - -// register Application object singleton -$app = \OC::$server->query(\OCA\Files_External\AppInfo\Application::class); -$app->registerListeners(); - -$appContainer = $app->getContainer(); - -\OCA\Files\App::getNavigationManager()->add(function () { - $l = \OC::$server->getL10N('files_external'); - return [ - 'id' => 'extstoragemounts', - 'appname' => 'files_external', - 'script' => 'list.php', - 'order' => 30, - 'name' => $l->t('External storage'), - ]; -}); - -$mountProvider = $appContainer->query(ConfigAdapter::class); -\OC::$server->getMountProviderCollection()->registerProvider($mountProvider); diff --git a/apps/files_external/lib/AppInfo/Application.php b/apps/files_external/lib/AppInfo/Application.php index 151b14fdfa9..7bc4440781b 100644 --- a/apps/files_external/lib/AppInfo/Application.php +++ b/apps/files_external/lib/AppInfo/Application.php @@ -29,6 +29,7 @@ */ namespace OCA\Files_External\AppInfo; +use OCA\Files_External\Config\ConfigAdapter; use OCA\Files_External\Config\UserPlaceholderHandler; use OCA\Files_External\Service\DBConfigService; use OCA\Files_External\Lib\Auth\AmazonS3\AccessKey; @@ -62,14 +63,21 @@ use OCA\Files_External\Lib\Config\IAuthMechanismProvider; use OCA\Files_External\Lib\Config\IBackendProvider; use OCA\Files_External\Service\BackendService; use OCP\AppFramework\App; +use OCP\AppFramework\Bootstrap\IBootContext; +use OCP\AppFramework\Bootstrap\IBootstrap; +use OCP\AppFramework\Bootstrap\IRegistrationContext; +use OCP\Files\Config\IMountProviderCollection; use OCP\IGroup; use OCP\IUser; +use Symfony\Component\EventDispatcher\EventDispatcherInterface; use Symfony\Component\EventDispatcher\GenericEvent; +require_once __DIR__ . '/../../3rdparty/autoload.php'; + /** * @package OCA\Files_External\AppInfo */ -class Application extends App implements IBackendProvider, IAuthMechanismProvider { +class Application extends App implements IBackendProvider, IAuthMechanismProvider, IBootstrap { /** * Application constructor. @@ -94,8 +102,29 @@ class Application extends App implements IBackendProvider, IAuthMechanismProvide $this->getAuthMechanisms(); } - public function registerListeners() { - $dispatcher = $this->getContainer()->getServer()->getEventDispatcher(); + public function register(IRegistrationContext $context): void { + // TODO: Implement register() method. + } + + public function boot(IBootContext $context): void { + $context->injectFn(function (IMountProviderCollection $mountProviderCollection, ConfigAdapter $configAdapter) { + $mountProviderCollection->registerProvider($configAdapter); + }); + \OCA\Files\App::getNavigationManager()->add(function () { + $l = \OC::$server->getL10N('files_external'); + return [ + 'id' => 'extstoragemounts', + 'appname' => 'files_external', + 'script' => 'list.php', + 'order' => 30, + 'name' => $l->t('External storages'), + ]; + }); + $context->injectFn([$this, 'registerListeners']); + } + + + public function registerListeners(EventDispatcherInterface $dispatcher) { $dispatcher->addListener( IUser::class . '::postDelete', function (GenericEvent $event) { diff --git a/apps/files_external/lib/Controller/ApiController.php b/apps/files_external/lib/Controller/ApiController.php index 906bd7d0f4b..40539d0bbca 100644 --- a/apps/files_external/lib/Controller/ApiController.php +++ b/apps/files_external/lib/Controller/ApiController.php @@ -30,13 +30,11 @@ declare(strict_types=1); namespace OCA\Files_External\Controller; use OCA\Files_External\Lib\StorageConfig; -use OCA\Files_External\MountConfig; use OCA\Files_External\Service\UserGlobalStoragesService; use OCA\Files_External\Service\UserStoragesService; use OCP\AppFramework\Http\DataResponse; use OCP\AppFramework\OCSController; use OCP\IRequest; -use OCP\IUserManager; use OCP\IUserSession; class ApiController extends OCSController { diff --git a/apps/files_external/lib/MountConfig.php b/apps/files_external/lib/MountConfig.php index 741368a6996..aa3b662e224 100644 --- a/apps/files_external/lib/MountConfig.php +++ b/apps/files_external/lib/MountConfig.php @@ -39,17 +39,14 @@ */ namespace OCA\Files_External; -use OCA\Files_External\AppInfo\Application; use OCA\Files_External\Config\IConfigHandler; use OCA\Files_External\Config\UserContext; use OCA\Files_External\Lib\Backend\Backend; -use OCA\Files_External\Lib\StorageConfig; use OCA\Files_External\Service\BackendService; use OCA\Files_External\Service\GlobalStoragesService; use OCA\Files_External\Service\UserGlobalStoragesService; use OCA\Files_External\Service\UserStoragesService; use OCP\Files\StorageNotAvailableException; -use OCP\IUserManager; use phpseclib\Crypt\AES; /** |