]> source.dussan.org Git - nextcloud-server.git/commitdiff
In LockPlugin, only release a lock if it was acquired 21074/head
authorJaakko Salo <jaakkos@gmail.com>
Sun, 24 May 2020 17:03:48 +0000 (20:03 +0300)
committerJaakko Salo <jaakko@meetiqm.com>
Sun, 24 May 2020 17:26:38 +0000 (20:26 +0300)
When uploading new files, getNodeForPath() will not succeed
yet so the lock cannot be acquired.

In that case, don't try to unlock it either.

Signed-off-by: Jaakko Salo <jaakkos@gmail.com>
apps/dav/lib/Connector/Sabre/LockPlugin.php

index 7c07f45fc7947c4dd32bd38f429d90f6bf35a590..bdb681be8da747eb1ddbc9f90621b8bfc59db9e6 100644 (file)
@@ -41,6 +41,13 @@ class LockPlugin extends ServerPlugin {
         */
        private $server;
 
+       /**
+        * State of the lock
+        *
+        * @var bool
+        */
+       private $isLocked;
+
        /**
         * {@inheritdoc}
         */
@@ -48,6 +55,7 @@ class LockPlugin extends ServerPlugin {
                $this->server = $server;
                $this->server->on('beforeMethod:*', [$this, 'getLock'], 50);
                $this->server->on('afterMethod:*', [$this, 'releaseLock'], 50);
+               $this->isLocked = false;
        }
 
        public function getLock(RequestInterface $request) {
@@ -67,10 +75,15 @@ class LockPlugin extends ServerPlugin {
                        } catch (LockedException $e) {
                                throw new FileLocked($e->getMessage(), $e->getCode(), $e);
                        }
+                       $this->isLocked = true;
                }
        }
 
        public function releaseLock(RequestInterface $request) {
+               // don't try to release the lock if we never locked one
+               if ($this->isLocked === false) {
+                       return;
+               }
                if ($request->getMethod() !== 'PUT' || isset($_SERVER['HTTP_OC_CHUNKED'])) {
                        return;
                }
@@ -81,6 +94,7 @@ class LockPlugin extends ServerPlugin {
                }
                if ($node instanceof Node) {
                        $node->releaseLock(ILockingProvider::LOCK_SHARED);
+                       $this->isLocked = false;
                }
        }
 }