move request handler for federated shares to the federated sharing app
This commit is contained in:
parent
59a85a4c76
commit
5a1641bed2
|
@ -23,14 +23,21 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace OCA\Files_Sharing\API;
|
namespace OCA\FederatedFileSharing;
|
||||||
|
|
||||||
use OCA\FederatedFileSharing\DiscoveryManager;
|
use OCA\FederatedFileSharing\DiscoveryManager;
|
||||||
use OCA\FederatedFileSharing\FederatedShareProvider;
|
use OCA\FederatedFileSharing\FederatedShareProvider;
|
||||||
use OCA\Files_Sharing\Activity;
|
use OCA\Files_Sharing\Activity;
|
||||||
use OCP\Files\NotFoundException;
|
use OCP\Files\NotFoundException;
|
||||||
|
|
||||||
class Server2Server {
|
/**
|
||||||
|
* Class RequestHandler
|
||||||
|
*
|
||||||
|
* handles OCS Request to the federated share API
|
||||||
|
*
|
||||||
|
* @package OCA\FederatedFileSharing\API
|
||||||
|
*/
|
||||||
|
class RequestHandler {
|
||||||
|
|
||||||
/** @var FederatedShareProvider */
|
/** @var FederatedShareProvider */
|
||||||
private $federatedShareProvider;
|
private $federatedShareProvider;
|
|
@ -23,14 +23,19 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
use OCA\Files_Sharing\Tests\TestCase;
|
namespace OCA\FederatedFileSharing\Tests;
|
||||||
|
|
||||||
|
use OC\Files\Filesystem;
|
||||||
|
use OCA\FederatedFileSharing\DiscoveryManager;
|
||||||
|
use OCA\FederatedFileSharing\RequestHandler;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class Test_Files_Sharing_Api
|
* Class RequestHandlerTest
|
||||||
*
|
*
|
||||||
|
* @package OCA\FederatedFileSharing\Tests
|
||||||
* @group DB
|
* @group DB
|
||||||
*/
|
*/
|
||||||
class Test_Files_Sharing_S2S_OCS_API extends TestCase {
|
class RequestHandlerTest extends TestCase {
|
||||||
|
|
||||||
const TEST_FOLDER_NAME = '/folder_share_api_test';
|
const TEST_FOLDER_NAME = '/folder_share_api_test';
|
||||||
|
|
||||||
|
@ -69,7 +74,7 @@ class Test_Files_Sharing_S2S_OCS_API extends TestCase {
|
||||||
|
|
||||||
$this->registerHttpHelper($httpHelperMock);
|
$this->registerHttpHelper($httpHelperMock);
|
||||||
|
|
||||||
$this->s2s = new \OCA\Files_Sharing\API\Server2Server($this->federatedShareProvider);
|
$this->s2s = new RequestHandler($this->federatedShareProvider);
|
||||||
|
|
||||||
$this->connection = \OC::$server->getDatabaseConnection();
|
$this->connection = \OC::$server->getDatabaseConnection();
|
||||||
}
|
}
|
||||||
|
@ -194,14 +199,14 @@ class Test_Files_Sharing_S2S_OCS_API extends TestCase {
|
||||||
function testDeleteUser($toDelete, $expected, $remainingUsers) {
|
function testDeleteUser($toDelete, $expected, $remainingUsers) {
|
||||||
$this->createDummyS2SShares();
|
$this->createDummyS2SShares();
|
||||||
|
|
||||||
$discoveryManager = new \OCA\FederatedFileSharing\DiscoveryManager(
|
$discoveryManager = new DiscoveryManager(
|
||||||
\OC::$server->getMemCacheFactory(),
|
\OC::$server->getMemCacheFactory(),
|
||||||
\OC::$server->getHTTPClientService()
|
\OC::$server->getHTTPClientService()
|
||||||
);
|
);
|
||||||
$manager = new OCA\Files_Sharing\External\Manager(
|
$manager = new \OCA\Files_Sharing\External\Manager(
|
||||||
\OC::$server->getDatabaseConnection(),
|
\OC::$server->getDatabaseConnection(),
|
||||||
\OC\Files\Filesystem::getMountManager(),
|
Filesystem::getMountManager(),
|
||||||
\OC\Files\Filesystem::getLoader(),
|
Filesystem::getLoader(),
|
||||||
\OC::$server->getHTTPHelper(),
|
\OC::$server->getHTTPHelper(),
|
||||||
\OC::$server->getNotificationManager(),
|
\OC::$server->getNotificationManager(),
|
||||||
$discoveryManager,
|
$discoveryManager,
|
|
@ -0,0 +1,133 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @author Björn Schießle <schiessle@owncloud.com>
|
||||||
|
* @author Joas Schilling <nickvergessen@owncloud.com>
|
||||||
|
* @author Jörn Friedrich Dreyer <jfd@butonic.de>
|
||||||
|
* @author Lukas Reschke <lukas@owncloud.com>
|
||||||
|
* @author Morris Jobke <hey@morrisjobke.de>
|
||||||
|
* @author Robin Appelman <icewind@owncloud.com>
|
||||||
|
* @author Robin McCorkell <robin@mccorkell.me.uk>
|
||||||
|
* @author Roeland Jago Douma <rullzer@owncloud.com>
|
||||||
|
* @author Thomas Müller <thomas.mueller@tmit.eu>
|
||||||
|
* @author Vincent Petry <pvince81@owncloud.com>
|
||||||
|
*
|
||||||
|
* @copyright Copyright (c) 2016, 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\FederatedFileSharing\Tests;
|
||||||
|
|
||||||
|
use OC\Files\Filesystem;
|
||||||
|
use OCA\Files\Share;
|
||||||
|
use OCA\Files_Sharing\Appinfo\Application;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class Test_Files_Sharing_Base
|
||||||
|
*
|
||||||
|
* @group DB
|
||||||
|
*
|
||||||
|
* Base class for sharing tests.
|
||||||
|
*/
|
||||||
|
abstract class TestCase extends \Test\TestCase {
|
||||||
|
|
||||||
|
const TEST_FILES_SHARING_API_USER1 = "test-share-user1";
|
||||||
|
const TEST_FILES_SHARING_API_USER2 = "test-share-user2";
|
||||||
|
|
||||||
|
public static function setUpBeforeClass() {
|
||||||
|
parent::setUpBeforeClass();
|
||||||
|
|
||||||
|
// reset backend
|
||||||
|
\OC_User::clearBackends();
|
||||||
|
\OC_Group::clearBackends();
|
||||||
|
|
||||||
|
// create users
|
||||||
|
$backend = new \Test\Util\User\Dummy();
|
||||||
|
\OC_User::useBackend($backend);
|
||||||
|
$backend->createUser(self::TEST_FILES_SHARING_API_USER1, self::TEST_FILES_SHARING_API_USER1);
|
||||||
|
$backend->createUser(self::TEST_FILES_SHARING_API_USER2, self::TEST_FILES_SHARING_API_USER2);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function setUp() {
|
||||||
|
parent::setUp();
|
||||||
|
|
||||||
|
//login as user1
|
||||||
|
self::loginHelper(self::TEST_FILES_SHARING_API_USER1);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function tearDownAfterClass() {
|
||||||
|
// cleanup users
|
||||||
|
$user = \OC::$server->getUserManager()->get(self::TEST_FILES_SHARING_API_USER1);
|
||||||
|
if ($user !== null) {
|
||||||
|
$user->delete();
|
||||||
|
}
|
||||||
|
$user = \OC::$server->getUserManager()->get(self::TEST_FILES_SHARING_API_USER2);
|
||||||
|
if ($user !== null) {
|
||||||
|
$user->delete();
|
||||||
|
}
|
||||||
|
|
||||||
|
\OC_Util::tearDownFS();
|
||||||
|
\OC_User::setUserId('');
|
||||||
|
Filesystem::tearDown();
|
||||||
|
|
||||||
|
// reset backend
|
||||||
|
\OC_User::clearBackends();
|
||||||
|
\OC_User::useBackend('database');
|
||||||
|
\OC_Group::clearBackends();
|
||||||
|
\OC_Group::useBackend(new \OC_Group_Database());
|
||||||
|
|
||||||
|
parent::tearDownAfterClass();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $user
|
||||||
|
* @param bool $create
|
||||||
|
* @param bool $password
|
||||||
|
*/
|
||||||
|
protected static function loginHelper($user, $create = false, $password = false) {
|
||||||
|
|
||||||
|
if ($password === false) {
|
||||||
|
$password = $user;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($create) {
|
||||||
|
\OC::$server->getUserManager()->createUser($user, $password);
|
||||||
|
\OC_Group::createGroup('group');
|
||||||
|
\OC_Group::addToGroup($user, 'group');
|
||||||
|
}
|
||||||
|
|
||||||
|
self::resetStorage();
|
||||||
|
|
||||||
|
\OC_Util::tearDownFS();
|
||||||
|
\OC::$server->getUserSession()->setUser(null);
|
||||||
|
\OC\Files\Filesystem::tearDown();
|
||||||
|
\OC::$server->getUserSession()->login($user, $password);
|
||||||
|
\OC::$server->getUserFolder($user);
|
||||||
|
|
||||||
|
\OC_Util::setupFS($user);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* reset init status for the share storage
|
||||||
|
*/
|
||||||
|
protected static function resetStorage() {
|
||||||
|
$storage = new \ReflectionClass('\OC\Files\Storage\Shared');
|
||||||
|
$isInitialized = $storage->getProperty('initialized');
|
||||||
|
$isInitialized->setAccessible(true);
|
||||||
|
$isInitialized->setValue($storage, false);
|
||||||
|
$isInitialized->setAccessible(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -100,7 +100,7 @@ API::register(
|
||||||
// Server-to-Server Sharing
|
// Server-to-Server Sharing
|
||||||
if (\OC::$server->getAppManager()->isEnabledForUser('files_sharing')) {
|
if (\OC::$server->getAppManager()->isEnabledForUser('files_sharing')) {
|
||||||
$federatedSharingApp = new \OCA\FederatedFileSharing\AppInfo\Application('federatedfilesharing');
|
$federatedSharingApp = new \OCA\FederatedFileSharing\AppInfo\Application('federatedfilesharing');
|
||||||
$s2s = new \OCA\Files_Sharing\API\Server2Server($federatedSharingApp->getFederatedShareProvider());
|
$s2s = new OCA\FederatedFileSharing\RequestHandler($federatedSharingApp->getFederatedShareProvider());
|
||||||
API::register('post',
|
API::register('post',
|
||||||
'/cloud/shares',
|
'/cloud/shares',
|
||||||
array($s2s, 'createShare'),
|
array($s2s, 'createShare'),
|
||||||
|
|
Loading…
Reference in New Issue