From 479037cd623447f3baceb6db47e562a9675fe340 Mon Sep 17 00:00:00 2001 From: Maxence Lange Date: Thu, 28 Sep 2023 21:26:08 -0100 Subject: [PATCH] accept current user filelock --- lib/Controller/WopiController.php | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/lib/Controller/WopiController.php b/lib/Controller/WopiController.php index 177f62b903..051172872d 100644 --- a/lib/Controller/WopiController.php +++ b/lib/Controller/WopiController.php @@ -197,6 +197,11 @@ public function checkFileInfo($fileId, $access_token) { $user = $this->userManager->get($wopi->getEditorUid()); $userDisplayName = $user !== null && !$isPublic ? $user->getDisplayName() : $wopi->getGuestDisplayname(); $isVersion = $version !== '0'; + + // If the file is locked manually by a user we want to open it read only for all others + $locks = $this->lockManager->getLocks($wopi->getFileid()); + $canWriteThroughLock = count($locks) > 0 && $locks[0]->getType() === ILock::TYPE_USER && $locks[0]->getOwner() !== $wopi->getEditorUid() ? false : true; + $response = [ 'BaseFileName' => $file->getName(), 'Size' => $file->getSize(), @@ -206,7 +211,7 @@ public function checkFileInfo($fileId, $access_token) { 'UserFriendlyName' => $userDisplayName, 'UserExtraInfo' => [], 'UserPrivateInfo' => [], - 'UserCanWrite' => (bool)$wopi->getCanwrite(), + 'UserCanWrite' => $canWriteThroughLock && (bool)$wopi->getCanwrite(), 'UserCanNotWriteRelative' => $isPublic || $this->encryptionManager->isEnabled() || $wopi->getHideDownload(), 'PostMessageOrigin' => $wopi->getServerHost(), 'LastModifiedTime' => Helper::toISO8601($file->getMTime()), @@ -710,6 +715,11 @@ private function lock(Wopi $wopi, string $lock): JSONResponse { } catch (NoLockProviderException|PreConditionNotMetException $e) { return new JSONResponse([], Http::STATUS_BAD_REQUEST); } catch (OwnerLockedException $e) { + // If a file is manually locked by a user we want to all this user to still perform a WOPI lock and write + if ($e->getLock()->getType() === ILock::TYPE_USER && $e->getLock()->getOwner() === $wopi->getEditorUid()) { + return new JSONResponse(); + } + return new JSONResponse([], Http::STATUS_LOCKED); } catch (\Exception $e) { return new JSONResponse([], Http::STATUS_INTERNAL_SERVER_ERROR); @@ -724,6 +734,11 @@ private function unlock(Wopi $wopi, string $lock): JSONResponse { )); return new JSONResponse(); } catch (NoLockProviderException|PreConditionNotMetException $e) { + $locks = $this->lockManager->getLocks($wopi->getFileid()); + $canWriteThroughLock = count($locks) > 0 && $locks[0]->getType() === ILock::TYPE_USER && $locks[0]->getOwner() !== $wopi->getEditorUid() ? false : true; + if ($canWriteThroughLock) { + return new JSONResponse(); + } return new JSONResponse([], Http::STATUS_BAD_REQUEST); } catch (\Exception $e) { return new JSONResponse([], Http::STATUS_INTERNAL_SERVER_ERROR);