From e52e8f4b4b70a812773eeee79ca868b6832b01af Mon Sep 17 00:00:00 2001 From: itsHenry <2671230065@qq.com> Date: Sun, 10 Mar 2024 16:47:17 +0800 Subject: [PATCH] feat: better error handling of webauthn (#159) --- src/pages/login/index.tsx | 28 ++++++++++++++++++---------- src/pages/manage/users/Profile.tsx | 2 +- 2 files changed, 19 insertions(+), 11 deletions(-) diff --git a/src/pages/login/index.tsx b/src/pages/login/index.tsx index bbda98faa7..8d4eb06ba7 100644 --- a/src/pages/login/index.tsx +++ b/src/pages/login/index.tsx @@ -144,17 +144,25 @@ const Login = () => { } const resp = await getauthntemp(username()) handleResp(resp, async (data) => { - const options = parseRequestOptionsFromJSON(data.options) - const credentials = await get(options) - const resp = await postauthnlogin(data.session, credentials, username()) - handleRespWithoutNotify(resp, (data) => { - notify.success(t("login.success")) - changeToken(data.token) - to( - decodeURIComponent(searchParams.redirect || base_path || "/"), - true, + try { + const options = parseRequestOptionsFromJSON(data.options) + const credentials = await get(options) + const resp = await postauthnlogin( + data.session, + credentials, + username(), ) - }) + handleRespWithoutNotify(resp, (data) => { + notify.success(t("login.success")) + changeToken(data.token) + to( + decodeURIComponent(searchParams.redirect || base_path || "/"), + true, + ) + }) + } catch (error: unknown) { + if (error instanceof Error) notify.error(error.message) + } }) } } diff --git a/src/pages/manage/users/Profile.tsx b/src/pages/manage/users/Profile.tsx index 98b8c04be4..c110f136c3 100644 --- a/src/pages/manage/users/Profile.tsx +++ b/src/pages/manage/users/Profile.tsx @@ -282,7 +282,7 @@ const Profile = () => { return } const resp = await getauthntemp() - handleRespWithoutNotify(resp, async (data) => { + handleResp(resp, async (data) => { const options = parseCreationOptionsFromJSON(data.options) const session = data.session try {