Allow hidden smb shares

A hidden smb share ends with $. This patch changes the placeholder
detection to allow shares with $ at the end.

Signed-off-by: Daniel Kesselberg <mail@danielkesselberg.de>
This commit is contained in:
Daniel Kesselberg 2019-05-20 17:54:45 +02:00
parent 685f00c018
commit 1ae68047ea
No known key found for this signature in database
GPG Key ID: 36E3664E099D0614
2 changed files with 48 additions and 1 deletions

View File

@ -292,7 +292,7 @@ class OC_Mount_Config {
}
}
} else if (is_string($option)) {
if (strpos($option, '$') !== false) {
if (strpos(rtrim($option, '$'), '$') !== false) {
$result = false;
}
}

View File

@ -0,0 +1,47 @@
<?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],
];
}
/**
* @dataProvider dataArePlaceholdersSubstituted
* @param string|array $option
* @param bool $expected
*/
public function testArePlaceholdersSubstituted($option, $expected): void {
$this->assertSame($expected, OC_Mount_Config::arePlaceholdersSubstituted($option));
}
}