diff options
-rw-r--r-- | apps/dav/lib/carddav/syncservice.php | 38 | ||||
-rw-r--r-- | apps/federation/appinfo/application.php | 6 | ||||
-rw-r--r-- | apps/federation/dav/fedauth.php | 10 | ||||
-rw-r--r-- | apps/federation/lib/dbhandler.php | 1 | ||||
-rw-r--r-- | apps/federation/tests/dav/fedauthtest.php | 52 | ||||
-rw-r--r-- | apps/federation/tests/lib/dbhandlertest.php | 26 |
6 files changed, 120 insertions, 13 deletions
diff --git a/apps/dav/lib/carddav/syncservice.php b/apps/dav/lib/carddav/syncservice.php index 8442f7cf52b..bfaf09f4c0e 100644 --- a/apps/dav/lib/carddav/syncservice.php +++ b/apps/dav/lib/carddav/syncservice.php @@ -34,6 +34,16 @@ class SyncService { $this->backend = $backend; } + /** + * @param string $url + * @param string $userName + * @param string $sharedSecret + * @param string $syncToken + * @param int $targetBookId + * @param string $targetPrincipal + * @param array $targetProperties + * @return string + */ public function syncRemoteAddressBook($url, $userName, $sharedSecret, $syncToken, $targetBookId, $targetPrincipal, $targetProperties) { // 1. create addressbook $book = $this->ensureSystemAddressBookExists($targetPrincipal, $targetBookId, $targetProperties); @@ -62,6 +72,13 @@ class SyncService { return $response['token']; } + /** + * @param string $principal + * @param string $id + * @param array $properties + * @return array|null + * @throws \Sabre\DAV\Exception\BadRequest + */ protected function ensureSystemAddressBookExists($principal, $id, $properties) { $book = $this->backend->getAddressBooksByUri($id); if (!is_null($book)) { @@ -104,7 +121,13 @@ class SyncService { return $result; } - private function download($url, $sharedSecret, $changeSet) { + /** + * @param string $url + * @param string $sharedSecret + * @param string $resourcePath + * @return array + */ + private function download($url, $sharedSecret, $resourcePath) { $settings = [ 'baseUri' => $url, 'userName' => 'system', @@ -113,11 +136,15 @@ class SyncService { $client = new Client($settings); $client->setThrowExceptions(true); - $response = $client->request('GET', $changeSet); + $response = $client->request('GET', $resourcePath); return $response; } - function buildSyncCollectionRequestBody($synToken) { + /** + * @param string|null $synToken + * @return string + */ + private function buildSyncCollectionRequestBody($synToken) { $dom = new \DOMDocument('1.0', 'UTF-8'); $dom->formatOutput = true; @@ -137,6 +164,11 @@ class SyncService { return $body; } + /** + * @param string $body + * @return array + * @throws \Sabre\Xml\ParseException + */ private function parseMultiStatus($body) { $xml = new Service(); diff --git a/apps/federation/appinfo/application.php b/apps/federation/appinfo/application.php index f0fefb948af..0214d73d900 100644 --- a/apps/federation/appinfo/application.php +++ b/apps/federation/appinfo/application.php @@ -153,8 +153,10 @@ class Application extends \OCP\AppFramework\App { if ($event instanceof SabrePluginEvent) { $authPlugin = $event->getServer()->getPlugin('auth'); if ($authPlugin instanceof Plugin) { - $db = $container->getServer()->getDatabaseConnection(); - $authPlugin->addBackend(new FedAuth($db)); + $h = new DbHandler($container->getServer()->getDatabaseConnection(), + $container->getServer()->getL10N('federation') + ); + $authPlugin->addBackend(new FedAuth($h)); } } }); diff --git a/apps/federation/dav/fedauth.php b/apps/federation/dav/fedauth.php index ade5448d1bc..56173233bf3 100644 --- a/apps/federation/dav/fedauth.php +++ b/apps/federation/dav/fedauth.php @@ -21,7 +21,6 @@ namespace OCA\Federation\DAV; use OCA\Federation\DbHandler; -use OCP\IDBConnection; use Sabre\DAV\Auth\Backend\AbstractBasic; class FedAuth extends AbstractBasic { @@ -29,9 +28,9 @@ class FedAuth extends AbstractBasic { /** * FedAuth constructor. * - * @param IDBConnection $db + * @param DbHandler $db */ - public function __construct(IDBConnection $db) { + public function __construct(DbHandler $db) { $this->db = $db; $this->principalPrefix = 'principals/system/'; } @@ -47,9 +46,6 @@ class FedAuth extends AbstractBasic { * @return bool */ protected function validateUserPass($username, $password) { - $h = new DbHandler($this->db, - \OC::$server->getL10N('federation') - ); - return $h->auth($username, $password); + return $this->db->auth($username, $password); } } diff --git a/apps/federation/lib/dbhandler.php b/apps/federation/lib/dbhandler.php index 0677430f799..f50854fefb3 100644 --- a/apps/federation/lib/dbhandler.php +++ b/apps/federation/lib/dbhandler.php @@ -206,6 +206,7 @@ class DbHandler { * * @param string $url * @param int $status + * @param string|null $token */ public function setServerStatus($url, $status, $token = null) { $hash = $this->hash($url); diff --git a/apps/federation/tests/dav/fedauthtest.php b/apps/federation/tests/dav/fedauthtest.php new file mode 100644 index 00000000000..845cfc622d2 --- /dev/null +++ b/apps/federation/tests/dav/fedauthtest.php @@ -0,0 +1,52 @@ +<?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\Tests\DAV; + +use OCA\Federation\DAV\FedAuth; +use OCA\Federation\DbHandler; +use Test\TestCase; + +class FedAuthTest extends TestCase { + + /** + * @dataProvider providesUser + * + * @param array $expected + * @param string $user + * @param string $password + */ + public function testFedAuth($expected, $user, $password) { + /** @var DbHandler | \PHPUnit_Framework_MockObject_MockObject $db */ + $db = $this->getMockBuilder('OCA\Federation\DbHandler')->disableOriginalConstructor()->getMock(); + $db->method('auth')->willReturn(true); + $auth = new FedAuth($db); + $result = $this->invokePrivate($auth, 'validateUserPass', [$user, $password]); + $this->assertEquals($expected, $result); + } + + public function providesUser() { + return [ + [true, 'system', '123456'] + ]; + } +} diff --git a/apps/federation/tests/lib/dbhandlertest.php b/apps/federation/tests/lib/dbhandlertest.php index 123eaaee450..65126e39f72 100644 --- a/apps/federation/tests/lib/dbhandlertest.php +++ b/apps/federation/tests/lib/dbhandlertest.php @@ -26,6 +26,7 @@ namespace OCA\Federation\Tests\lib; use OCA\Federation\DbHandler; use OCA\Federation\TrustedServers; use OCP\IDBConnection; +use OCP\IL10N; use Test\TestCase; /** @@ -36,7 +37,7 @@ class DbHandlerTest extends TestCase { /** @var DbHandler */ private $dbHandler; - /** @var \PHPUnit_Framework_MockObject_MockObject */ + /** @var IL10N | \PHPUnit_Framework_MockObject_MockObject */ private $il10n; /** @var IDBConnection */ @@ -209,6 +210,11 @@ class DbHandlerTest extends TestCase { $this->assertSame(TrustedServers::STATUS_OK, $this->dbHandler->getServerStatus('https://server1') ); + + // test sync token + $this->dbHandler->setServerStatus('http://server1', TrustedServers::STATUS_OK, 'token1234567890'); + $servers = $this->dbHandler->getAllServer(); + $this->assertSame('token1234567890', $servers[0]['sync_token']); } /** @@ -256,4 +262,22 @@ class DbHandlerTest extends TestCase { ]; } + /** + * @dataProvider providesAuth + */ + public function testAuth($expectedResult, $user, $password) { + if ($expectedResult) { + $this->dbHandler->addServer('url1'); + $this->dbHandler->addSharedSecret('url1', $password); + } + $result = $this->dbHandler->auth($user, $password); + $this->assertEquals($expectedResult, $result); + } + + public function providesAuth() { + return [ + [false, 'foo', ''], + [true, 'system', '123456789'], + ]; + } } |