diff options
author | Roeland Jago Douma <rullzer@users.noreply.github.com> | 2019-11-26 19:49:01 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-11-26 19:49:01 +0100 |
commit | 0e87c6fac98d90bdde2fa905356a22b27df969ce (patch) | |
tree | e0325de4d651630d84ff95205e03829ea6955ce9 | |
parent | d09f8c7423d5f6432776b96b00ff87897c225119 (diff) | |
parent | 77d136cbdffc02fb5c0d36652ca9babfd0283154 (diff) | |
download | nextcloud-server-0e87c6fac98d90bdde2fa905356a22b27df969ce.tar.gz nextcloud-server-0e87c6fac98d90bdde2fa905356a22b27df969ce.zip |
Merge pull request #18058 from nextcloud/enh/shareinfo/permissionmask
Apply share permission mask to all files obtained via shareinfo
-rw-r--r-- | apps/files_sharing/lib/Controller/ShareInfoController.php | 37 | ||||
-rw-r--r-- | apps/files_sharing/tests/Controller/ShareInfoControllerTest.php | 5 |
2 files changed, 13 insertions, 29 deletions
diff --git a/apps/files_sharing/lib/Controller/ShareInfoController.php b/apps/files_sharing/lib/Controller/ShareInfoController.php index 5ecf00321fc..5aea32fe064 100644 --- a/apps/files_sharing/lib/Controller/ShareInfoController.php +++ b/apps/files_sharing/lib/Controller/ShareInfoController.php @@ -81,11 +81,7 @@ class ShareInfoController extends ApiController { return new JSONResponse([], Http::STATUS_FORBIDDEN); } - $isWritable = $share->getPermissions() & (\OCP\Constants::PERMISSION_UPDATE | \OCP\Constants::PERMISSION_CREATE); - if (!$isWritable) { - $this->addROWrapper(); - } - + $permissionMask = $share->getPermissions(); $node = $share->getNode(); if ($dir !== null && $node instanceof Folder) { @@ -96,34 +92,34 @@ class ShareInfoController extends ApiController { } } - return new JSONResponse($this->parseNode($node)); + return new JSONResponse($this->parseNode($node, $permissionMask)); } - private function parseNode(Node $node) { + private function parseNode(Node $node, int $permissionMask) { if ($node instanceof File) { - return $this->parseFile($node); + return $this->parseFile($node, $permissionMask); } - return $this->parseFolder($node); + return $this->parseFolder($node, $permissionMask); } - private function parseFile(File $file) { - return $this->format($file); + private function parseFile(File $file, int $permissionMask) { + return $this->format($file, $permissionMask); } - private function parseFolder(Folder $folder) { - $data = $this->format($folder); + private function parseFolder(Folder $folder, int $permissionMask) { + $data = $this->format($folder, $permissionMask); $data['children'] = []; $nodes = $folder->getDirectoryListing(); foreach ($nodes as $node) { - $data['children'][] = $this->parseNode($node); + $data['children'][] = $this->parseNode($node, $permissionMask); } return $data; } - private function format(Node $node) { + private function format(Node $node, int $permissionMask) { $entry = []; $entry['id'] = $node->getId(); @@ -131,7 +127,7 @@ class ShareInfoController extends ApiController { $entry['mtime'] = $node->getMTime(); $entry['name'] = $node->getName(); - $entry['permissions'] = $node->getPermissions(); + $entry['permissions'] = $node->getPermissions() & $permissionMask; $entry['mimetype'] = $node->getMimetype(); $entry['size'] = $node->getSize(); $entry['type'] = $node->getType(); @@ -139,13 +135,4 @@ class ShareInfoController extends ApiController { return $entry; } - - protected function addROWrapper() { - // FIXME: should not add storage wrappers outside of preSetup, need to find a better way - $previousLog = \OC\Files\Filesystem::logWarningWhenAddingStorageWrapper(false); - \OC\Files\Filesystem::addStorageWrapper('readonly', function ($mountPoint, $storage) { - return new \OC\Files\Storage\Wrapper\PermissionsMask(array('storage' => $storage, 'mask' => \OCP\Constants::PERMISSION_READ + \OCP\Constants::PERMISSION_SHARE)); - }); - \OC\Files\Filesystem::logWarningWhenAddingStorageWrapper($previousLog); - } } diff --git a/apps/files_sharing/tests/Controller/ShareInfoControllerTest.php b/apps/files_sharing/tests/Controller/ShareInfoControllerTest.php index cd548ecfa21..627990a2f90 100644 --- a/apps/files_sharing/tests/Controller/ShareInfoControllerTest.php +++ b/apps/files_sharing/tests/Controller/ShareInfoControllerTest.php @@ -173,9 +173,6 @@ class ShareInfoControllerTest extends TestCase { ->with($share, 'pass') ->willReturn(true); - $this->controller->expects($this->once()) - ->method('addROWrapper'); - $expected = new JSONResponse([ 'id' => 42, 'parentId' => 41, @@ -285,7 +282,7 @@ class ShareInfoControllerTest extends TestCase { 'parentId' => 43, 'mtime' => 1339, 'name' => 'file', - 'permissions' => 9, + 'permissions' => 1, 'mimetype' => 'mime/type', 'size' => 3, 'type' => 'file', |