diff options
author | Thomas Müller <thomas.mueller@tmit.eu> | 2016-02-25 14:36:00 +0100 |
---|---|---|
committer | Thomas Müller <thomas.mueller@tmit.eu> | 2016-02-25 14:36:00 +0100 |
commit | 914ac09aaec9e4f8c5e0ed10ca881cc85cef4b28 (patch) | |
tree | de16ef66b04b3a6525eb334db311a97ff015f63c | |
parent | 202bf17e4acff00d48ffd94ed95d83e53f3dec90 (diff) | |
parent | db2ddb54413831adef41fe5e233481a2d546731d (diff) | |
download | nextcloud-server-914ac09aaec9e4f8c5e0ed10ca881cc85cef4b28.tar.gz nextcloud-server-914ac09aaec9e4f8c5e0ed10ca881cc85cef4b28.zip |
Merge pull request #22636 from owncloud/fix-ssl-on-external-storages
Fix HTTPS support on external storages
-rw-r--r-- | apps/files_external/js/settings.js | 3 | ||||
-rw-r--r-- | apps/files_external/lib/storageconfig.php | 14 | ||||
-rw-r--r-- | apps/files_external/tests/storageconfigtest.php | 34 | ||||
-rw-r--r-- | lib/private/files/storage/dav.php | 6 |
4 files changed, 45 insertions, 12 deletions
diff --git a/apps/files_external/js/settings.js b/apps/files_external/js/settings.js index 96b56d221c5..ceacbf4afab 100644 --- a/apps/files_external/js/settings.js +++ b/apps/files_external/js/settings.js @@ -859,6 +859,9 @@ MountConfigListView.prototype = _.extend({ var input = $(this); var val = storageConfig.backendOptions[input.data('parameter')]; if (val !== undefined) { + if(input.is('input:checkbox')) { + input.prop('checked', val); + } input.val(storageConfig.backendOptions[input.data('parameter')]); highlightInput(input); } diff --git a/apps/files_external/lib/storageconfig.php b/apps/files_external/lib/storageconfig.php index 42c515f4671..ef859e8ae8a 100644 --- a/apps/files_external/lib/storageconfig.php +++ b/apps/files_external/lib/storageconfig.php @@ -211,6 +211,20 @@ class StorageConfig implements \JsonSerializable { * @param array $backendOptions backend options */ public function setBackendOptions($backendOptions) { + if($this->getBackend() instanceof Backend) { + $parameters = $this->getBackend()->getParameters(); + foreach($backendOptions as $key => $value) { + if(isset($parameters[$key])) { + switch ($parameters[$key]->getType()) { + case \OCA\Files_External\Lib\DefinitionParameter::VALUE_BOOLEAN: + $value = (bool)$value; + break; + } + $backendOptions[$key] = $value; + } + } + } + $this->backendOptions = $backendOptions; } diff --git a/apps/files_external/tests/storageconfigtest.php b/apps/files_external/tests/storageconfigtest.php index d7f8d2b4d7d..60ec14dd080 100644 --- a/apps/files_external/tests/storageconfigtest.php +++ b/apps/files_external/tests/storageconfigtest.php @@ -30,6 +30,17 @@ class StorageConfigTest extends \Test\TestCase { $backend = $this->getMockBuilder('\OCA\Files_External\Lib\Backend\Backend') ->disableOriginalConstructor() ->getMock(); + $parameter = $this->getMockBuilder('\OCA\Files_External\Lib\DefinitionParameter') + ->disableOriginalConstructor() + ->getMock(); + $parameter + ->expects($this->once()) + ->method('getType') + ->willReturn(1); + $backend + ->expects($this->once()) + ->method('getParameters') + ->willReturn(['secure' => $parameter]); $backend->method('getIdentifier') ->willReturn('storage::identifier'); @@ -43,7 +54,7 @@ class StorageConfigTest extends \Test\TestCase { $storageConfig->setMountPoint('test'); $storageConfig->setBackend($backend); $storageConfig->setAuthMechanism($authMech); - $storageConfig->setBackendOptions(['user' => 'test', 'password' => 'password123']); + $storageConfig->setBackendOptions(['user' => 'test', 'password' => 'password123', 'secure' => '1']); $storageConfig->setPriority(128); $storageConfig->setApplicableUsers(['user1', 'user2']); $storageConfig->setApplicableGroups(['group1', 'group2']); @@ -51,16 +62,17 @@ class StorageConfigTest extends \Test\TestCase { $json = $storageConfig->jsonSerialize(); - $this->assertEquals(1, $json['id']); - $this->assertEquals('/test', $json['mountPoint']); - $this->assertEquals('storage::identifier', $json['backend']); - $this->assertEquals('auth::identifier', $json['authMechanism']); - $this->assertEquals('test', $json['backendOptions']['user']); - $this->assertEquals('password123', $json['backendOptions']['password']); - $this->assertEquals(128, $json['priority']); - $this->assertEquals(['user1', 'user2'], $json['applicableUsers']); - $this->assertEquals(['group1', 'group2'], $json['applicableGroups']); - $this->assertEquals(['preview' => false], $json['mountOptions']); + $this->assertSame(1, $json['id']); + $this->assertSame('/test', $json['mountPoint']); + $this->assertSame('storage::identifier', $json['backend']); + $this->assertSame('auth::identifier', $json['authMechanism']); + $this->assertSame('test', $json['backendOptions']['user']); + $this->assertSame('password123', $json['backendOptions']['password']); + $this->assertSame(true, $json['backendOptions']['secure']); + $this->assertSame(128, $json['priority']); + $this->assertSame(['user1', 'user2'], $json['applicableUsers']); + $this->assertSame(['group1', 'group2'], $json['applicableGroups']); + $this->assertSame(['preview' => false], $json['mountOptions']); } } diff --git a/lib/private/files/storage/dav.php b/lib/private/files/storage/dav.php index a6e77e1b232..5e00a03ebb8 100644 --- a/lib/private/files/storage/dav.php +++ b/lib/private/files/storage/dav.php @@ -136,9 +136,13 @@ class DAV extends Common { 'password' => $this->password, ); + $proxy = \OC::$server->getConfig()->getSystemValue('proxy', ''); + if($proxy !== '') { + $settings['proxy'] = $proxy; + } + $this->client = new Client($settings); $this->client->setThrowExceptions(true); - if ($this->secure === true && $this->certPath) { $this->client->addCurlSetting(CURLOPT_CAINFO, $this->certPath); } |