]> source.dussan.org Git - nextcloud-server.git/commitdiff
get the correct owner path for part files
authorBjoern Schiessle <schiessle@owncloud.com>
Wed, 30 Apr 2014 10:49:16 +0000 (12:49 +0200)
committerBjoern Schiessle <schiessle@owncloud.com>
Wed, 30 Apr 2014 10:49:16 +0000 (12:49 +0200)
apps/files_sharing/lib/sharedstorage.php
apps/files_sharing/tests/sharedstorage.php [new file with mode: 0644]

index 2252ec6a1a6af9ff9a82fce6b530e8d7bbc27876..4733dff3d14b997eb20ca30481f04b05d664e7e6 100644 (file)
@@ -379,7 +379,15 @@ class Shared extends \OC\Files\Storage\Common {
                                // otherwise DELETE and CREATE permissions required
                                ($this->isDeletable($path1) && $this->isCreatable(dirname($path2)))) {
 
-                       list($user1, $path1) = \OCA\Files_Sharing\Helper::getUidAndFilename($relPath1);
+                       $pathinfo = pathinfo($relPath1);
+                       // for part files we need to ask for the owner and path from the parent directory because
+                       // the file cache doesn't return any results for part files
+                       if ($pathinfo['extension'] === 'part') {
+                               list($user1, $path1) = \OCA\Files_Sharing\Helper::getUidAndFilename($pathinfo['dirname']);
+                               $path1 = $path1 . '/' . $pathinfo['basename'];
+                       } else {
+                               list($user1, $path1) = \OCA\Files_Sharing\Helper::getUidAndFilename($relPath1);
+                       }
                        $targetFilename = basename($relPath2);
                        list($user2, $path2) = \OCA\Files_Sharing\Helper::getUidAndFilename(dirname($relPath2));
                        $rootView = new \OC\Files\View('');
diff --git a/apps/files_sharing/tests/sharedstorage.php b/apps/files_sharing/tests/sharedstorage.php
new file mode 100644 (file)
index 0000000..66518a2
--- /dev/null
@@ -0,0 +1,83 @@
+<?php
+/**
+ * ownCloud
+ *
+ * @author Bjoern Schiessle
+ * @copyright 2014 Bjoern Schiessle <schiessle@owncloud.com>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or any later version.
+ *
+ * This library 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 library.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+require_once __DIR__ . '/base.php';
+
+use OCA\Files\Share;
+
+/**
+ * Class Test_Files_Sharing_Api
+ */
+class Test_Files_Sharing_Storage extends Test_Files_Sharing_Base {
+
+       function setUp() {
+               parent::setUp();
+
+               $this->folder = '/folder_share_storage_test';
+
+               $this->filename = '/share-api-storage.txt';
+
+               // save file with content
+               $this->view->mkdir($this->folder);
+       }
+
+       function tearDown() {
+               $this->view->deleteAll($this->folder);
+
+               parent::tearDown();
+       }
+
+       /**
+        * @medium
+        */
+       function testRenamePartFile() {
+
+               // share to user
+               $fileinfo = $this->view->getFileInfo($this->folder);
+               $result = \OCP\Share::shareItem('folder', $fileinfo['fileid'], \OCP\Share::SHARE_TYPE_USER,
+                       self::TEST_FILES_SHARING_API_USER2, 31);
+
+               $this->assertTrue($result);
+
+               self::loginHelper(self::TEST_FILES_SHARING_API_USER2);
+               $user2View = new \OC\Files\View('/' . self::TEST_FILES_SHARING_API_USER2 . '/files');
+
+               $this->assertTrue($user2View->file_exists($this->folder));
+
+               // create part file
+               $result = $user2View->file_put_contents($this->folder. '/foo.txt.part', 'some test data');
+
+               $this->assertTrue(is_int($result));
+               // rename part file to real file
+               $result = $user2View->rename($this->folder. '/foo.txt.part', $this->folder. '/foo.txt');
+
+               $this->assertTrue($result);
+
+               // check if the new file really exists
+               $this->assertTrue($user2View->file_exists( $this->folder. '/foo.txt'));
+
+               // check if the rename also affected the owner
+               self::loginHelper(self::TEST_FILES_SHARING_API_USER1);
+
+               $this->assertTrue($this->view->file_exists( $this->folder. '/foo.txt'));
+       }
+}