summaryrefslogtreecommitdiffstats
path: root/apps/federatedfilesharing/lib
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2020-07-13 16:23:59 +0200
committerMorris Jobke <hey@morrisjobke.de>2020-07-14 16:34:43 +0200
commit7e281a07bb66a082a35cbdd52f7d1e418beb4f53 (patch)
tree9a2ab162c879eec9ede9087d2869a490c3988a49 /apps/federatedfilesharing/lib
parent2c87ce60a04eb98533d430ef7abe386ef0d04c2a (diff)
downloadnextcloud-server-7e281a07bb66a082a35cbdd52f7d1e418beb4f53.tar.gz
nextcloud-server-7e281a07bb66a082a35cbdd52f7d1e418beb4f53.zip
Use IBootstrap for the app federatedfilesharing
Signed-off-by: Morris Jobke <hey@morrisjobke.de>
Diffstat (limited to 'apps/federatedfilesharing/lib')
-rw-r--r--apps/federatedfilesharing/lib/AppInfo/Application.php141
-rw-r--r--apps/federatedfilesharing/lib/Listeners/LoadAdditionalScriptsListener.php50
2 files changed, 65 insertions, 126 deletions
diff --git a/apps/federatedfilesharing/lib/AppInfo/Application.php b/apps/federatedfilesharing/lib/AppInfo/Application.php
index f38f583d85a..09f881d5bb8 100644
--- a/apps/federatedfilesharing/lib/AppInfo/Application.php
+++ b/apps/federatedfilesharing/lib/AppInfo/Application.php
@@ -2,7 +2,6 @@
/**
* @copyright Copyright (c) 2016, ownCloud, Inc.
*
- * @author Bjoern Schiessle <bjoern@schiessle.org>
* @author Björn Schießle <bjoern@schiessle.org>
* @author Christoph Wurst <christoph@winzerhof-wurst.at>
* @author John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>
@@ -29,145 +28,35 @@
namespace OCA\FederatedFileSharing\AppInfo;
-use OC\AppFramework\Utility\SimpleContainer;
-use OCA\FederatedFileSharing\AddressHandler;
-use OCA\FederatedFileSharing\Controller\RequestHandlerController;
-use OCA\FederatedFileSharing\FederatedShareProvider;
-use OCA\FederatedFileSharing\Notifications;
+use OCA\FederatedFileSharing\Listeners\LoadAdditionalScriptsListener;
use OCA\FederatedFileSharing\Notifier;
use OCA\FederatedFileSharing\OCM\CloudFederationProviderFiles;
+use OCA\Files\Event\LoadAdditionalScriptsEvent;
use OCP\AppFramework\App;
-use OCP\GlobalScale\IConfig;
-
-class Application extends App {
-
- /** @var FederatedShareProvider */
- protected $federatedShareProvider;
+use OCP\AppFramework\Bootstrap\IBootContext;
+use OCP\AppFramework\Bootstrap\IBootstrap;
+use OCP\AppFramework\Bootstrap\IRegistrationContext;
+class Application extends App implements IBootstrap {
public function __construct() {
parent::__construct('federatedfilesharing');
+ }
- $container = $this->getContainer();
- $server = $container->getServer();
+ public function register(IRegistrationContext $context): void {
+ $context->registerEventListener(LoadAdditionalScriptsEvent::class, LoadAdditionalScriptsListener::class);
+ }
+
+ public function boot(IBootContext $context): void {
+ $server = $context->getServerContainer();
$cloudFederationManager = $server->getCloudFederationProviderManager();
$cloudFederationManager->addCloudFederationProvider('file',
'Federated Files Sharing',
- function () use ($container) {
- $server = $container->getServer();
- return new CloudFederationProviderFiles(
- $server->getAppManager(),
- $server->query(FederatedShareProvider::class),
- $server->query(AddressHandler::class),
- $server->getLogger(),
- $server->getUserManager(),
- $server->getShareManager(),
- $server->getCloudIdManager(),
- $server->getActivityManager(),
- $server->getNotificationManager(),
- $server->getURLGenerator(),
- $server->getCloudFederationFactory(),
- $server->getCloudFederationProviderManager(),
- $server->getDatabaseConnection(),
- $server->getGroupManager()
- );
+ function () use ($server) {
+ return $server->query(CloudFederationProviderFiles::class);
});
- $container->registerService('RequestHandlerController', function (SimpleContainer $c) use ($server) {
- $addressHandler = new AddressHandler(
- $server->getURLGenerator(),
- $server->getL10N('federatedfilesharing'),
- $server->getCloudIdManager()
- );
- $notification = new Notifications(
- $addressHandler,
- $server->getHTTPClientService(),
- $server->query(\OCP\OCS\IDiscoveryService::class),
- \OC::$server->getJobList(),
- \OC::$server->getCloudFederationProviderManager(),
- \OC::$server->getCloudFederationFactory()
- );
- return new RequestHandlerController(
- $c->query('AppName'),
- $server->getRequest(),
- $this->getFederatedShareProvider(),
- $server->getDatabaseConnection(),
- $server->getShareManager(),
- $notification,
- $addressHandler,
- $server->getUserManager(),
- $server->getCloudIdManager(),
- $server->getLogger(),
- $server->getCloudFederationFactory(),
- $server->getCloudFederationProviderManager()
- );
- });
-
- // register events listeners
- $eventDispatcher = $server->getEventDispatcher();
$manager = $server->getNotificationManager();
- $federatedShareProvider = $this->getFederatedShareProvider();
-
$manager->registerNotifierService(Notifier::class);
-
- $eventDispatcher->addListener(
- 'OCA\Files::loadAdditionalScripts',
- function () use ($federatedShareProvider) {
- if ($federatedShareProvider->isIncomingServer2serverShareEnabled()) {
- \OCP\Util::addScript('federatedfilesharing', 'external');
- }
- }
- );
- }
-
- /**
- * get instance of federated share provider
- *
- * @return FederatedShareProvider
- */
- public function getFederatedShareProvider() {
- if ($this->federatedShareProvider === null) {
- $this->initFederatedShareProvider();
- }
- return $this->federatedShareProvider;
- }
-
- /**
- * initialize federated share provider
- */
- protected function initFederatedShareProvider() {
- $c = $this->getContainer();
- $addressHandler = new \OCA\FederatedFileSharing\AddressHandler(
- \OC::$server->getURLGenerator(),
- \OC::$server->getL10N('federatedfilesharing'),
- \OC::$server->getCloudIdManager()
- );
- $notifications = new \OCA\FederatedFileSharing\Notifications(
- $addressHandler,
- \OC::$server->getHTTPClientService(),
- \OC::$server->query(\OCP\OCS\IDiscoveryService::class),
- \OC::$server->getJobList(),
- \OC::$server->getCloudFederationProviderManager(),
- \OC::$server->getCloudFederationFactory()
- );
- $tokenHandler = new \OCA\FederatedFileSharing\TokenHandler(
- \OC::$server->getSecureRandom()
- );
-
- $this->federatedShareProvider = new \OCA\FederatedFileSharing\FederatedShareProvider(
- \OC::$server->getDatabaseConnection(),
- $addressHandler,
- $notifications,
- $tokenHandler,
- \OC::$server->getL10N('federatedfilesharing'),
- \OC::$server->getLogger(),
- \OC::$server->getLazyRootFolder(),
- \OC::$server->getConfig(),
- \OC::$server->getUserManager(),
- \OC::$server->getCloudIdManager(),
- $c->query(IConfig::class),
- \OC::$server->getCloudFederationProviderManager()
-
- );
}
}
diff --git a/apps/federatedfilesharing/lib/Listeners/LoadAdditionalScriptsListener.php b/apps/federatedfilesharing/lib/Listeners/LoadAdditionalScriptsListener.php
new file mode 100644
index 00000000000..3901a1c93ea
--- /dev/null
+++ b/apps/federatedfilesharing/lib/Listeners/LoadAdditionalScriptsListener.php
@@ -0,0 +1,50 @@
+<?php
+
+declare(strict_types=1);
+/**
+ * @copyright Copyright (c) 2020 Morris Jobke <hey@morrisjobke.de>
+ *
+ * @author Morris Jobke <hey@morrisjobke.de>
+ *
+ * @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/>.
+ *
+ */
+
+namespace OCA\FederatedFileSharing\Listeners;
+
+use OCA\FederatedFileSharing\FederatedShareProvider;
+use OCA\Files\Event\LoadAdditionalScriptsEvent;
+use OCP\EventDispatcher\Event;
+use OCP\EventDispatcher\IEventListener;
+
+class LoadAdditionalScriptsListener implements IEventListener {
+ /** @var FederatedShareProvider */
+ protected $federatedShareProvider;
+
+ public function __construct(FederatedShareProvider $federatedShareProvider) {
+ $this->federatedShareProvider = $federatedShareProvider;
+ }
+
+ public function handle(Event $event): void {
+ if (!$event instanceof LoadAdditionalScriptsEvent) {
+ return;
+ }
+
+ if ($this->federatedShareProvider->isIncomingServer2serverShareEnabled()) {
+ \OCP\Util::addScript('federatedfilesharing', 'external');
+ }
+ }
+}