summaryrefslogtreecommitdiffstats
path: root/apps/files_external
diff options
context:
space:
mode:
authorblizzz <blizzz@arthur-schiwon.de>2019-07-24 12:43:29 +0200
committerGitHub <noreply@github.com>2019-07-24 12:43:29 +0200
commit7e8dfd404e5f2b121f145c31dc277d204ddcb2ea (patch)
tree6113fa3cd604aecd469ee46bcd4f635b8252a632 /apps/files_external
parentbabe1333ad42cd95b973c2e72184658307f77e29 (diff)
parentb1bd3f1fe51a98d695a39c3b735e758ba2a323ee (diff)
downloadnextcloud-server-7e8dfd404e5f2b121f145c31dc277d204ddcb2ea.tar.gz
nextcloud-server-7e8dfd404e5f2b121f145c31dc277d204ddcb2ea.zip
Merge pull request #15637 from nextcloud/bugfix/15567/ignore-hidden-share
Allow hidden smb shares
Diffstat (limited to 'apps/files_external')
-rw-r--r--apps/files_external/lib/config.php6
-rw-r--r--apps/files_external/tests/Config/PlaceholderSubstituteTest.php49
2 files changed, 51 insertions, 4 deletions
diff --git a/apps/files_external/lib/config.php b/apps/files_external/lib/config.php
index 47e68b4b1a0..cc417a837fa 100644
--- a/apps/files_external/lib/config.php
+++ b/apps/files_external/lib/config.php
@@ -287,12 +287,10 @@ class OC_Mount_Config {
$result = true;
if(is_array($option)) {
foreach ($option as $optionItem) {
- if(is_array($optionItem)) {
- $result = $result && self::arePlaceholdersSubstituted($option);
- }
+ $result = $result && self::arePlaceholdersSubstituted($optionItem);
}
} else if (is_string($option)) {
- if (strpos($option, '$') !== false) {
+ if (strpos(rtrim($option, '$'), '$') !== false) {
$result = false;
}
}
diff --git a/apps/files_external/tests/Config/PlaceholderSubstituteTest.php b/apps/files_external/tests/Config/PlaceholderSubstituteTest.php
new file mode 100644
index 00000000000..c143d969121
--- /dev/null
+++ b/apps/files_external/tests/Config/PlaceholderSubstituteTest.php
@@ -0,0 +1,49 @@
+<?php
+/**
+ * @copyright Copyright (c) 2019 Daniel Kesselberg <mail@danielkesselberg.de>
+ *
+ * @author Daniel Kesselberg <mail@danielkesselberg.de>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * 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
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+namespace OCA\files_external\tests\Config;
+
+use OC_Mount_Config;
+use Test\TestCase;
+
+class PlaceholderSubstituteTest extends TestCase {
+
+ public function dataArePlaceholdersSubstituted(): array {
+ return [
+ ['smb_$user', false],
+ ['hidden_share$', true],
+ [['smb_$user', 'hidden_share$'], false],
+ [['smb_hello', 'hidden_share$'], true]
+ ];
+ }
+
+ /**
+ * @dataProvider dataArePlaceholdersSubstituted
+ * @param string|array $option
+ * @param bool $expected
+ */
+ public function testArePlaceholdersSubstituted($option, $expected): void {
+ $this->assertSame($expected, OC_Mount_Config::arePlaceholdersSubstituted($option));
+ }
+
+}