diff --git a/apps/files_external/lib/config.php b/apps/files_external/lib/config.php
index 47e68b4b1a01d76e41503f38b77fa8bfa1f5bacf..cc417a837facabe96fd810c26f2db722adc2eb5b 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 0000000000000000000000000000000000000000..c143d96912103ba8caa5d35fd724fffc551c81c8
--- /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));
+	}
+
+}