Merge pull request #21773 from owncloud/files_external-list-authtype
Show the proper auth identifier when listing mounts as json
This commit is contained in:
commit
1199b539f2
3 changed files with 72 additions and 3 deletions
|
@ -194,8 +194,8 @@ class Import extends Base {
|
||||||
$mount = new StorageConfig($data['mount_id']);
|
$mount = new StorageConfig($data['mount_id']);
|
||||||
$mount->setMountPoint($data['mount_point']);
|
$mount->setMountPoint($data['mount_point']);
|
||||||
$mount->setBackend($this->getBackendByClass($data['storage']));
|
$mount->setBackend($this->getBackendByClass($data['storage']));
|
||||||
$authBackends = $this->backendService->getAuthMechanismsByScheme([$data['authentication_type']]);
|
$authBackend = $this->backendService->getAuthMechanism($data['authentication_type']);
|
||||||
$mount->setAuthMechanism(current($authBackends));
|
$mount->setAuthMechanism($authBackend);
|
||||||
$mount->setBackendOptions($data['configuration']);
|
$mount->setBackendOptions($data['configuration']);
|
||||||
$mount->setMountOptions($data['options']);
|
$mount->setMountOptions($data['options']);
|
||||||
$mount->setApplicableUsers(isset($data['applicable_users']) ? $data['applicable_users'] : []);
|
$mount->setApplicableUsers(isset($data['applicable_users']) ? $data['applicable_users'] : []);
|
||||||
|
|
|
@ -146,7 +146,7 @@ class ListCommand extends Base {
|
||||||
$config->getId(),
|
$config->getId(),
|
||||||
$config->getMountPoint(),
|
$config->getMountPoint(),
|
||||||
$config->getBackend()->getStorageClass(),
|
$config->getBackend()->getStorageClass(),
|
||||||
$config->getAuthMechanism()->getScheme(),
|
$config->getAuthMechanism()->getIdentifier(),
|
||||||
$config->getBackendOptions(),
|
$config->getBackendOptions(),
|
||||||
$config->getMountOptions()
|
$config->getMountOptions()
|
||||||
];
|
];
|
||||||
|
|
69
apps/files_external/tests/command/listcommandtest.php
Normal file
69
apps/files_external/tests/command/listcommandtest.php
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @author Robin Appelman <icewind@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\Files_External\Tests\Command;
|
||||||
|
|
||||||
|
use OCA\Files_External\Command\ListCommand;
|
||||||
|
use OCA\Files_External\Lib\Auth\NullMechanism;
|
||||||
|
use OCA\Files_External\Lib\Auth\Password\Password;
|
||||||
|
use OCA\Files_External\Lib\Auth\Password\UserProvided;
|
||||||
|
use OCA\Files_External\Lib\Backend\Local;
|
||||||
|
use OCA\Files_external\Lib\StorageConfig;
|
||||||
|
use Symfony\Component\Console\Output\BufferedOutput;
|
||||||
|
|
||||||
|
class ListCommandTest extends CommandTest {
|
||||||
|
/**
|
||||||
|
* @return \OCA\Files_External\Command\ListCommand|\PHPUnit_Framework_MockObject_MockObject
|
||||||
|
*/
|
||||||
|
private function getInstance() {
|
||||||
|
/** @var \OCA\Files_external\Service\GlobalStoragesService|\PHPUnit_Framework_MockObject_MockObject $globalService */
|
||||||
|
$globalService = $this->getMock('\OCA\Files_external\Service\GlobalStoragesService', null, [], '', false);
|
||||||
|
/** @var \OCA\Files_external\Service\UserStoragesService|\PHPUnit_Framework_MockObject_MockObject $userService */
|
||||||
|
$userService = $this->getMock('\OCA\Files_external\Service\UserStoragesService', null, [], '', false);
|
||||||
|
/** @var \OCP\IUserManager|\PHPUnit_Framework_MockObject_MockObject $userManager */
|
||||||
|
$userManager = $this->getMock('\OCP\IUserManager');
|
||||||
|
/** @var \OCP\IUserSession|\PHPUnit_Framework_MockObject_MockObject $userSession */
|
||||||
|
$userSession = $this->getMock('\OCP\IUserSession');
|
||||||
|
|
||||||
|
return new ListCommand($globalService, $userService, $userSession, $userManager);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testListAuthIdentifier() {
|
||||||
|
$l10n = $this->getMock('\OC_L10N', null, [], '', false);
|
||||||
|
$credentialsManager = $this->getMock('\OCP\Security\ICredentialsManager');
|
||||||
|
$instance = $this->getInstance();
|
||||||
|
$mount1 = new StorageConfig();
|
||||||
|
$mount1->setAuthMechanism(new Password($l10n));
|
||||||
|
$mount1->setBackend(new Local($l10n, new NullMechanism($l10n)));
|
||||||
|
$mount2 = new StorageConfig();
|
||||||
|
$mount2->setAuthMechanism(new UserProvided($l10n, $credentialsManager));
|
||||||
|
$mount2->setBackend(new Local($l10n, new NullMechanism($l10n)));
|
||||||
|
$input = $this->getInput($instance, [], [
|
||||||
|
'output' => 'json'
|
||||||
|
]);
|
||||||
|
$output = new BufferedOutput();
|
||||||
|
|
||||||
|
$instance->listMounts('', [$mount1, $mount2], $input, $output);
|
||||||
|
$output = json_decode($output->fetch(), true);
|
||||||
|
|
||||||
|
$this->assertNotEquals($output[0]['authentication_type'], $output[1]['authentication_type']);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue