summaryrefslogtreecommitdiffstats
path: root/apps/dav/lib
diff options
context:
space:
mode:
authorRobin Appelman <robin@icewind.nl>2015-10-27 16:58:00 +0100
committerRobin Appelman <robin@icewind.nl>2015-10-27 16:58:00 +0100
commitc30919303990c51b78157d86b95c0f97e004233d (patch)
treeface7331dce78bcb04cd60f978d96d119d9cdfbf /apps/dav/lib
parent4d87276f4be55419189fb23d3c3c13f00c19f006 (diff)
parent021ed8b2bd814b2ca262209738fc039a92391660 (diff)
downloadnextcloud-server-c30919303990c51b78157d86b95c0f97e004233d.tar.gz
nextcloud-server-c30919303990c51b78157d86b95c0f97e004233d.zip
Merge pull request #17104 from owncloud/chunked-upload-locking
locking for chunked dav upload
Diffstat (limited to 'apps/dav/lib')
-rw-r--r--apps/dav/lib/connector/sabre/file.php21
-rw-r--r--apps/dav/lib/connector/sabre/lockplugin.php4
2 files changed, 15 insertions, 10 deletions
diff --git a/apps/dav/lib/connector/sabre/file.php b/apps/dav/lib/connector/sabre/file.php
index 9e515cdc687..961532daf50 100644
--- a/apps/dav/lib/connector/sabre/file.php
+++ b/apps/dav/lib/connector/sabre/file.php
@@ -349,6 +349,7 @@ class File extends Node implements IFile {
if (empty($info)) {
throw new NotImplemented('Invalid chunk name');
}
+
$chunk_handler = new \OC_FileChunking($info);
$bytesWritten = $chunk_handler->store($info['index'], $data);
@@ -376,15 +377,17 @@ class File extends Node implements IFile {
$exists = $this->fileView->file_exists($targetPath);
try {
- $this->emitPreHooks($exists, $targetPath);
+ $this->fileView->lockFile($targetPath, ILockingProvider::LOCK_SHARED);
- $this->changeLock(ILockingProvider::LOCK_EXCLUSIVE);
+ $this->emitPreHooks($exists, $targetPath);
+ $this->fileView->changeLock($targetPath, ILockingProvider::LOCK_EXCLUSIVE);
+ /** @var \OC\Files\Storage\Storage $targetStorage */
+ list($targetStorage, $targetInternalPath) = $this->fileView->resolvePath($targetPath);
if ($needsPartFile) {
// we first assembly the target file as a part file
$partFile = $path . '/' . $info['name'] . '.ocTransferId' . $info['transferid'] . '.part';
-
-
+ /** @var \OC\Files\Storage\Storage $targetStorage */
list($partStorage, $partInternalPath) = $this->fileView->resolvePath($partFile);
@@ -392,8 +395,7 @@ class File extends Node implements IFile {
// here is the final atomic rename
$renameOkay = $targetStorage->moveFromStorage($partStorage, $partInternalPath, $targetInternalPath);
-
- $fileExists = $this->fileView->file_exists($targetPath);
+ $fileExists = $targetStorage->file_exists($targetInternalPath);
if ($renameOkay === false || $fileExists === false) {
\OCP\Util::writeLog('webdav', '\OC\Files\Filesystem::rename() failed', \OCP\Util::ERROR);
// only delete if an error occurred and the target file was already created
@@ -403,7 +405,7 @@ class File extends Node implements IFile {
$partFile = null;
$targetStorage->unlink($targetInternalPath);
}
- $this->changeLock(ILockingProvider::LOCK_SHARED);
+ $this->fileView->changeLock($targetPath, ILockingProvider::LOCK_SHARED);
throw new Exception('Could not rename part file assembled from chunks');
}
} else {
@@ -419,7 +421,7 @@ class File extends Node implements IFile {
}
}
- $this->changeLock(ILockingProvider::LOCK_SHARED);
+ $this->fileView->changeLock($targetPath, ILockingProvider::LOCK_SHARED);
// since we skipped the view we need to scan and emit the hooks ourselves
$this->fileView->getUpdater()->update($targetPath);
@@ -427,6 +429,9 @@ class File extends Node implements IFile {
$this->emitPostHooks($exists, $targetPath);
$info = $this->fileView->getFileInfo($targetPath);
+
+ $this->fileView->unlockFile($targetPath, ILockingProvider::LOCK_SHARED);
+
return $info->getEtag();
} catch (\Exception $e) {
if ($partFile !== null) {
diff --git a/apps/dav/lib/connector/sabre/lockplugin.php b/apps/dav/lib/connector/sabre/lockplugin.php
index c564e066f8e..5840e59854c 100644
--- a/apps/dav/lib/connector/sabre/lockplugin.php
+++ b/apps/dav/lib/connector/sabre/lockplugin.php
@@ -62,7 +62,7 @@ class LockPlugin extends ServerPlugin {
public function getLock(RequestInterface $request) {
// we cant listen on 'beforeMethod:PUT' due to order of operations with setting up the tree
// so instead we limit ourselves to the PUT method manually
- if ($request->getMethod() !== 'PUT') {
+ if ($request->getMethod() !== 'PUT' || isset($_SERVER['HTTP_OC_CHUNKED'])) {
return;
}
try {
@@ -80,7 +80,7 @@ class LockPlugin extends ServerPlugin {
}
public function releaseLock(RequestInterface $request) {
- if ($request->getMethod() !== 'PUT') {
+ if ($request->getMethod() !== 'PUT' || isset($_SERVER['HTTP_OC_CHUNKED'])) {
return;
}
try {