diff options
Diffstat (limited to 'apps/files_external/lib')
-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 |
3 files changed, 32 insertions, 8 deletions
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; /** |