diff options
author | Robin Appelman <robin@icewind.nl> | 2022-02-25 16:11:38 +0100 |
---|---|---|
committer | Robin Appelman <robin@icewind.nl> | 2022-02-25 16:33:27 +0100 |
commit | ec15020777c9f0de248ced8b83fe48767c2919b6 (patch) | |
tree | a5980b6986c31c99649094cb7f20e74732688f2d | |
parent | d08d0ebdda82bdbc8c5cc5f7432e98a913fa2321 (diff) | |
download | nextcloud-server-ec15020777c9f0de248ced8b83fe48767c2919b6.tar.gz nextcloud-server-ec15020777c9f0de248ced8b83fe48767c2919b6.zip |
also handle expired pre-write shared lock on dav upload when not using part files
Signed-off-by: Robin Appelman <robin@icewind.nl>
-rw-r--r-- | apps/dav/lib/Connector/Sabre/File.php | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/apps/dav/lib/Connector/Sabre/File.php b/apps/dav/lib/Connector/Sabre/File.php index 28817b93b76..fa8a46e0530 100644 --- a/apps/dav/lib/Connector/Sabre/File.php +++ b/apps/dav/lib/Connector/Sabre/File.php @@ -173,7 +173,23 @@ class File extends Node implements IFile { [$storage, $internalPath] = $this->fileView->resolvePath($this->path); try { if (!$needsPartFile) { - $this->changeLock(ILockingProvider::LOCK_EXCLUSIVE); + try { + $this->changeLock(ILockingProvider::LOCK_EXCLUSIVE); + } catch (LockedException $e) { + // during very large uploads, the shared lock we got at the start might have been expired + // meaning that the above lock can fail not just only because somebody else got a shared lock + // or because there is no existing shared lock to make exclusive + // + // Thus we try to get a new exclusive lock, if the original lock failed because of a different shared + // lock this will still fail, if our original shared lock expired the new lock will be successful and + // the entire operation will be safe + + try { + $this->acquireLock(ILockingProvider::LOCK_EXCLUSIVE); + } catch (LockedException $ex) { + throw new FileLocked($e->getMessage(), $e->getCode(), $e); + } + } } if (!is_resource($data)) { |