diff options
author | Côme Chilliet <come.chilliet@nextcloud.com> | 2024-12-10 15:27:38 +0100 |
---|---|---|
committer | Côme Chilliet <91878298+come-nc@users.noreply.github.com> | 2024-12-12 15:39:48 +0100 |
commit | 17007f6b8dae214355c164b274915413628cb5d0 (patch) | |
tree | 926a57358f88402569afd564fd4845b21eba4d68 /lib/private/Share20/Manager.php | |
parent | 28d7206e5cab68eb4b4a012574ee26275e2c74d8 (diff) | |
download | nextcloud-server-17007f6b8dae214355c164b274915413628cb5d0.tar.gz nextcloud-server-17007f6b8dae214355c164b274915413628cb5d0.zip |
fix(shares): Wrap exceptions from password validation to set code to 400
This fixes a regression that bad password returned 403 instead of 400
because of previous changes.
Signed-off-by: Côme Chilliet <come.chilliet@nextcloud.com>
Diffstat (limited to 'lib/private/Share20/Manager.php')
-rw-r--r-- | lib/private/Share20/Manager.php | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/lib/private/Share20/Manager.php b/lib/private/Share20/Manager.php index ea338937e2a..219f3d86380 100644 --- a/lib/private/Share20/Manager.php +++ b/lib/private/Share20/Manager.php @@ -112,7 +112,12 @@ class Manager implements IManager { } // Let others verify the password - $this->dispatcher->dispatchTyped(new ValidatePasswordPolicyEvent($password)); + try { + $this->dispatcher->dispatchTyped(new ValidatePasswordPolicyEvent($password)); + } catch (HintException $e) { + /* Wrap in a 400 bad request error */ + throw new HintException($e->getMessage(), $e->getHint(), 400, $e); + } } /** @@ -780,7 +785,7 @@ class Manager implements IManager { * @param IShare $share * @return IShare The share object * @throws \InvalidArgumentException - * @throws GenericShareException + * @throws HintException */ public function updateShare(IShare $share, bool $onlyValid = true) { $expirationDateUpdated = false; |