diff options
author | Robin Appelman <robin@icewind.nl> | 2018-03-07 12:05:57 +0100 |
---|---|---|
committer | Robin Appelman <robin@icewind.nl> | 2018-03-07 12:05:57 +0100 |
commit | 9764e70494a35c5112729847451794bfd40e61df (patch) | |
tree | 78be1517326c7c745dde12da59dc159cb4c2f7b0 /lib/private/Files/ObjectStore/ObjectStoreStorage.php | |
parent | 076b49b9fe54060bf08b6ef55bfea34fc7279fd6 (diff) | |
download | nextcloud-server-9764e70494a35c5112729847451794bfd40e61df.tar.gz nextcloud-server-9764e70494a35c5112729847451794bfd40e61df.zip |
don't read existing file when overwriting using object store
Signed-off-by: Robin Appelman <robin@icewind.nl>
Diffstat (limited to 'lib/private/Files/ObjectStore/ObjectStoreStorage.php')
-rw-r--r-- | lib/private/Files/ObjectStore/ObjectStoreStorage.php | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/lib/private/Files/ObjectStore/ObjectStoreStorage.php b/lib/private/Files/ObjectStore/ObjectStoreStorage.php index 45c22a81a7b..84d714ce7de 100644 --- a/lib/private/Files/ObjectStore/ObjectStoreStorage.php +++ b/lib/private/Files/ObjectStore/ObjectStoreStorage.php @@ -261,6 +261,12 @@ class ObjectStoreStorage extends \OC\Files\Storage\Common { public function fopen($path, $mode) { $path = $this->normalizePath($path); + if (strrpos($path, '.') !== false) { + $ext = substr($path, strrpos($path, '.')); + } else { + $ext = ''; + } + switch ($mode) { case 'r': case 'rb': @@ -280,21 +286,21 @@ class ObjectStoreStorage extends \OC\Files\Storage\Common { } case 'w': case 'wb': + case 'w+': + case 'wb+': + $tmpFile = \OC::$server->getTempManager()->getTemporaryFile($ext); + $handle = fopen($tmpFile, $mode); + return CallbackWrapper::wrap($handle, null, null, function () use ($path, $tmpFile) { + $this->writeBack($tmpFile, $path); + }); case 'a': case 'ab': case 'r+': - case 'w+': - case 'wb+': case 'a+': case 'x': case 'x+': case 'c': case 'c+': - if (strrpos($path, '.') !== false) { - $ext = substr($path, strrpos($path, '.')); - } else { - $ext = ''; - } $tmpFile = \OC::$server->getTempManager()->getTemporaryFile($ext); if ($this->file_exists($path)) { $source = $this->fopen($path, 'r'); |