]> source.dussan.org Git - nextcloud-server.git/commitdiff
Use EventDispatcher to allow additional setup of auth backends - move federation...
authorThomas Müller <thomas.mueller@tmit.eu>
Fri, 4 Dec 2015 11:11:07 +0000 (12:11 +0100)
committerThomas Müller <thomas.mueller@tmit.eu>
Tue, 12 Jan 2016 13:24:01 +0000 (14:24 +0100)
apps/dav/lib/connector/fedauth.php [deleted file]
apps/dav/lib/server.php
apps/federation/appinfo/application.php
apps/federation/dav/fedauth.php [new file with mode: 0644]
lib/public/sabrepluginevent.php

diff --git a/apps/dav/lib/connector/fedauth.php b/apps/dav/lib/connector/fedauth.php
deleted file mode 100644 (file)
index 42a29ce..0000000
+++ /dev/null
@@ -1,55 +0,0 @@
-<?php
-/**
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- *
- * @copyright Copyright (c) 2015, ownCloud, Inc.
- * @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/>
- *
- */
-namespace OCA\DAV\Connector;
-
-use OCA\Federation\DbHandler;
-use OCP\IDBConnection;
-use Sabre\DAV\Auth\Backend\AbstractBasic;
-
-class FedAuth extends AbstractBasic {
-
-       /**
-        * FedAuth constructor.
-        *
-        * @param IDBConnection $db
-        */
-       public function __construct(IDBConnection $db) {
-               $this->db = $db;
-               $this->principalPrefix = 'principals/system/';
-       }
-
-       /**
-        * Validates a username and password
-        *
-        * This method should return true or false depending on if login
-        * succeeded.
-        *
-        * @param string $username
-        * @param string $password
-        * @return bool
-        */
-       protected function validateUserPass($username, $password) {
-               $h = new DbHandler($this->db,
-                               \OC::$server->getL10N('federation')
-               );
-               return $h->auth($username, $password);
-       }
-}
index 8b7171c145c58df40d07898ba064eeccdcbd876e..93e903e6bf1a1946f1f472258d4b50c6a2408854 100644 (file)
@@ -8,6 +8,7 @@ use OCA\DAV\Connector\Sabre\Auth;
 use OCA\DAV\Connector\Sabre\BlockLegacyClientPlugin;
 use OCA\DAV\Files\CustomPropertiesBackend;
 use OCP\IRequest;
+use OCP\SabrePluginEvent;
 use Sabre\DAV\Auth\Plugin;
 
 class Server {
@@ -37,8 +38,12 @@ class Server {
 
                $this->server->addPlugin(new BlockLegacyClientPlugin(\OC::$server->getConfig()));
                $authPlugin = new Plugin($authBackend, 'ownCloud');
-               $authPlugin->addBackend(new FedAuth(\OC::$server->getDatabaseConnection()));
                $this->server->addPlugin($authPlugin);
+
+               // allow setup of additional auth backends
+               $event = new SabrePluginEvent($this->server);
+               $dispatcher->dispatch('OCA\DAV\Connector\Sabre::authInit', $event);
+
                $this->server->addPlugin(new \OCA\DAV\Connector\Sabre\DummyGetResponsePlugin());
                $this->server->addPlugin(new \OCA\DAV\Connector\Sabre\ExceptionLoggerPlugin('webdav', $logger));
                $this->server->addPlugin(new \OCA\DAV\Connector\Sabre\LockPlugin());
index 45d88548b70d2919a702698b6bac3edc694d8ffe..f0fefb948af9ba0e70fed43edabf5ef9881a1926 100644 (file)
@@ -23,6 +23,7 @@ namespace OCA\Federation\AppInfo;
 
 use OCA\Federation\API\OCSAuthAPI;
 use OCA\Federation\Controller\SettingsController;
+use OCA\Federation\DAV\FedAuth;
 use OCA\Federation\DbHandler;
 use OCA\Federation\Hooks;
 use OCA\Federation\Middleware\AddServerMiddleware;
@@ -30,7 +31,9 @@ use OCA\Federation\TrustedServers;
 use OCP\API;
 use OCP\App;
 use OCP\AppFramework\IAppContainer;
+use OCP\SabrePluginEvent;
 use OCP\Util;
+use Sabre\DAV\Auth\Plugin;
 
 class Application extends \OCP\AppFramework\App {
 
@@ -144,6 +147,17 @@ class Application extends \OCP\AppFramework\App {
                                $hooksManager,
                                'addServerHook'
                );
+
+               $dispatcher = $this->getContainer()->getServer()->getEventDispatcher();
+               $dispatcher->addListener('OCA\DAV\Connector\Sabre::authInit', function($event) use($container) {
+                       if ($event instanceof SabrePluginEvent) {
+                               $authPlugin = $event->getServer()->getPlugin('auth');
+                               if ($authPlugin instanceof Plugin) {
+                                       $db = $container->getServer()->getDatabaseConnection();
+                                       $authPlugin->addBackend(new FedAuth($db));
+                               }
+                       }
+               });
        }
 
 }
diff --git a/apps/federation/dav/fedauth.php b/apps/federation/dav/fedauth.php
new file mode 100644 (file)
index 0000000..ade5448
--- /dev/null
@@ -0,0 +1,55 @@
+<?php
+/**
+ * @author Thomas Müller <thomas.mueller@tmit.eu>
+ *
+ * @copyright Copyright (c) 2015, ownCloud, Inc.
+ * @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/>
+ *
+ */
+namespace OCA\Federation\DAV;
+
+use OCA\Federation\DbHandler;
+use OCP\IDBConnection;
+use Sabre\DAV\Auth\Backend\AbstractBasic;
+
+class FedAuth extends AbstractBasic {
+
+       /**
+        * FedAuth constructor.
+        *
+        * @param IDBConnection $db
+        */
+       public function __construct(IDBConnection $db) {
+               $this->db = $db;
+               $this->principalPrefix = 'principals/system/';
+       }
+
+       /**
+        * Validates a username and password
+        *
+        * This method should return true or false depending on if login
+        * succeeded.
+        *
+        * @param string $username
+        * @param string $password
+        * @return bool
+        */
+       protected function validateUserPass($username, $password) {
+               $h = new DbHandler($this->db,
+                               \OC::$server->getL10N('federation')
+               );
+               return $h->auth($username, $password);
+       }
+}
index fed3237166d87c78022780993f685b4ada3a18c3..1a64c8ac3edb109ab17f9f22d150f95f9b85b379 100644 (file)
@@ -23,6 +23,7 @@ namespace OCP;
 
 
 use OCP\AppFramework\Http;
+use Sabre\DAV\Server;
 use Symfony\Component\EventDispatcher\Event;
 
 /**
@@ -36,12 +37,16 @@ class SabrePluginEvent extends Event {
        /** @var string */
        protected $message;
 
+       /** @var Server */
+       protected $server;
+
        /**
         * @since 8.2.0
         */
-       public function __construct() {
+       public function __construct($server = null) {
                $this->message = '';
                $this->statusCode = Http::STATUS_OK;
+               $this->server = $server;
        }
 
        /**
@@ -79,4 +84,12 @@ class SabrePluginEvent extends Event {
        public function getMessage() {
                return $this->message;
        }
+
+       /**
+        * @return null|Server
+        * @since 9.0.0
+        */
+       public function getServer() {
+               return $this->server;
+       }
 }