diff options
author | Bjoern Schiessle <bjoern@schiessle.org> | 2017-11-17 11:59:25 +0100 |
---|---|---|
committer | Bjoern Schiessle <bjoern@schiessle.org> | 2017-11-17 12:45:46 +0100 |
commit | 1ade6b081781c961049eebd161f845d5be5a4000 (patch) | |
tree | c52b62365da6483fd03e806536a25c6d8e0e8cc0 /lib | |
parent | eeb0cfdaf52bc9929bb27040f74a66bfc18ca67c (diff) | |
download | nextcloud-server-1ade6b081781c961049eebd161f845d5be5a4000.tar.gz nextcloud-server-1ade6b081781c961049eebd161f845d5be5a4000.zip |
only create the file cache entry after the empty file was created successfully, otherwise file_exists() call on the initial file_put_content() will indicate that the file already exists
Signed-off-by: Bjoern Schiessle <bjoern@schiessle.org>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/private/Files/ObjectStore/ObjectStoreStorage.php | 27 |
1 files changed, 13 insertions, 14 deletions
diff --git a/lib/private/Files/ObjectStore/ObjectStoreStorage.php b/lib/private/Files/ObjectStore/ObjectStoreStorage.php index 79ce7ee3247..acb8d670780 100644 --- a/lib/private/Files/ObjectStore/ObjectStoreStorage.php +++ b/lib/private/Files/ObjectStore/ObjectStoreStorage.php @@ -351,25 +351,24 @@ class ObjectStoreStorage extends \OC\Files\Storage\Common { $stat['mtime'] = $mtime; $this->getCache()->update($stat['fileid'], $stat); } else { - $mimeType = \OC::$server->getMimeTypeDetector()->detectPath($path); - // create new file - $stat = array( - 'etag' => $this->getETag($path), - 'mimetype' => $mimeType, - 'size' => 0, - 'mtime' => $mtime, - 'storage_mtime' => $mtime, - 'permissions' => \OCP\Constants::PERMISSION_ALL - \OCP\Constants::PERMISSION_CREATE, - ); - $fileId = $this->getCache()->put($path, $stat); try { - //read an empty file from memory + //create a empty file, need to have at least on char to make it + // work with all object storage implementations $this->file_put_contents($path, ' '); + $mimeType = \OC::$server->getMimeTypeDetector()->detectPath($path); + $stat = array( + 'etag' => $this->getETag($path), + 'mimetype' => $mimeType, + 'size' => 0, + 'mtime' => $mtime, + 'storage_mtime' => $mtime, + 'permissions' => \OCP\Constants::PERMISSION_ALL - \OCP\Constants::PERMISSION_CREATE, + ); + $this->getCache()->put($path, $stat); } catch (\Exception $ex) { - $this->getCache()->remove($path); $this->logger->logException($ex, [ 'app' => 'objectstore', - 'message' => 'Could not create object ' . $this->getURN($fileId) . ' for ' . $path, + 'message' => 'Could not create object for ' . $path, ]); return false; } |