diff options
author | Robin Appelman <robin@icewind.nl> | 2024-12-04 20:11:41 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-12-04 20:11:41 +0100 |
commit | c2f474ff4975bfac6671e2f9c912be97b1e1d633 (patch) | |
tree | cd9a561b59a3eb454612bd1a23d84aa372228cc3 /apps | |
parent | b4c43bb811407aeaf70f6df6cd1674eb27eaa734 (diff) | |
parent | e59ebafc877ef5e02f88915eeb0b30c91156e242 (diff) | |
download | nextcloud-server-c2f474ff4975bfac6671e2f9c912be97b1e1d633.tar.gz nextcloud-server-c2f474ff4975bfac6671e2f9c912be97b1e1d633.zip |
Merge pull request #48769 from nextcloud/copy-share-unmasked
Fix incorrect permissions when copying shared files
Diffstat (limited to 'apps')
-rw-r--r-- | apps/files_sharing/tests/SharedStorageTest.php | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/apps/files_sharing/tests/SharedStorageTest.php b/apps/files_sharing/tests/SharedStorageTest.php index a91931501b4..39ffec0908b 100644 --- a/apps/files_sharing/tests/SharedStorageTest.php +++ b/apps/files_sharing/tests/SharedStorageTest.php @@ -579,4 +579,30 @@ class SharedStorageTest extends TestCase { $this->assertInstanceOf(FailedStorage::class, $storage->getSourceStorage()); $this->assertInstanceOf(FailedCache::class, $storage->getCache()); } + + public function testCopyPermissions(): void { + self::loginHelper(self::TEST_FILES_SHARING_API_USER1); + + $share = $this->share( + IShare::TYPE_USER, + $this->filename, + self::TEST_FILES_SHARING_API_USER1, + self::TEST_FILES_SHARING_API_USER2, + Constants::PERMISSION_ALL - Constants::PERMISSION_CREATE - Constants::PERMISSION_DELETE + ); + + self::loginHelper(self::TEST_FILES_SHARING_API_USER2); + $view = new View('/' . self::TEST_FILES_SHARING_API_USER2 . '/files'); + $this->assertTrue($view->file_exists($this->filename)); + + $this->assertTrue($view->copy($this->filename, '/target.txt')); + + $this->assertTrue($view->file_exists('/target.txt')); + + $info = $view->getFileInfo('/target.txt'); + $this->assertEquals(Constants::PERMISSION_ALL - Constants::PERMISSION_CREATE, $info->getPermissions()); + + $this->view->unlink($this->filename); + $this->shareManager->deleteShare($share); + } } |