diff options
author | Morris Jobke <hey@morrisjobke.de> | 2021-03-19 15:31:04 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-19 15:31:04 +0100 |
commit | fb09f3d31d468411960c10213f460aaf83b523c4 (patch) | |
tree | b93c865d4d0985f0f29b646d366c0dae43944203 | |
parent | e6fd9b2f55b1920c5e3bb2c2448ec3488acc56c9 (diff) | |
parent | 5ffaa94fbc9a879af28e51ccbe13469cbb79cfdb (diff) | |
download | nextcloud-server-fb09f3d31d468411960c10213f460aaf83b523c4.tar.gz nextcloud-server-fb09f3d31d468411960c10213f460aaf83b523c4.zip |
Merge pull request #26145 from nextcloud/smb-force-write-option
add (hidden) option to always show smb root as writable
-rw-r--r-- | apps/files_external/lib/Lib/Storage/SMB.php | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/apps/files_external/lib/Lib/Storage/SMB.php b/apps/files_external/lib/Lib/Storage/SMB.php index bc065b24552..45a01db76b3 100644 --- a/apps/files_external/lib/Lib/Storage/SMB.php +++ b/apps/files_external/lib/Lib/Storage/SMB.php @@ -97,6 +97,9 @@ class SMB extends Common implements INotifyStorage { /** @var bool */ protected $checkAcl; + /** @var bool */ + protected $rootWritable; + public function __construct($params) { if (!isset($params['host'])) { throw new \Exception('Invalid configuration, no host provided'); @@ -134,6 +137,7 @@ class SMB extends Common implements INotifyStorage { $this->showHidden = isset($params['show_hidden']) && $params['show_hidden']; $this->checkAcl = isset($params['check_acl']) && $params['check_acl']; + $this->rootWritable = isset($params['root_force_writable']) && $params['root_force_writable']; $this->statCache = new CappedMemoryCache(); parent::__construct($params); @@ -573,7 +577,11 @@ class SMB extends Common implements INotifyStorage { private function getMetaDataFromFileInfo(IFileInfo $fileInfo) { $permissions = Constants::PERMISSION_READ + Constants::PERMISSION_SHARE; - if (!$fileInfo->isReadOnly()) { + if ( + !$fileInfo->isReadOnly() || ( + $this->rootWritable && $fileInfo->getPath() == $this->buildPath('') + ) + ) { $permissions += Constants::PERMISSION_DELETE; $permissions += Constants::PERMISSION_UPDATE; if ($fileInfo->isDirectory()) { |