diff options
author | Sebastian <sebasjm@gmail.com> | 2023-03-15 09:54:31 -0300 |
---|---|---|
committer | Sebastian <sebasjm@gmail.com> | 2023-03-15 09:54:31 -0300 |
commit | ae4d4647e988a6eb8e9fd87af3385371ba56ab43 (patch) | |
tree | f9a3dccebc4d809790819f6ab396297113c7d312 /packages/merchant-backoffice-ui/src/hooks | |
parent | 0bf92a44df14f1946df2b1cd58a6b0b92b5befa2 (diff) | |
download | wallet-core-ae4d4647e988a6eb8e9fd87af3385371ba56ab43.tar.xz |
better error handling
Diffstat (limited to 'packages/merchant-backoffice-ui/src/hooks')
-rw-r--r-- | packages/merchant-backoffice-ui/src/hooks/backend.ts | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/packages/merchant-backoffice-ui/src/hooks/backend.ts b/packages/merchant-backoffice-ui/src/hooks/backend.ts index 93e95934e..3ab99b402 100644 --- a/packages/merchant-backoffice-ui/src/hooks/backend.ts +++ b/packages/merchant-backoffice-ui/src/hooks/backend.ts @@ -25,8 +25,10 @@ import { useBackendContext } from "../context/backend.js"; import { useCallback, useEffect, useState } from "preact/hooks"; import { useInstanceContext } from "../context/instance.js"; import { + ErrorType, HttpResponse, HttpResponseOk, + RequestError, RequestOptions, } from "@gnu-taler/web-util/lib/index.browser"; import { useApiContext } from "@gnu-taler/web-util/lib/index.browser"; @@ -146,14 +148,21 @@ export function useCredentialsChecker() { return async function testLogin( instance: string, token: string, - ): Promise<boolean> { + ): Promise<{ + valid: boolean; + cause?: ErrorType; + }> { try { const response = await request(instance, `/private/`, { token, }); - return true; - } catch (e) { - return false; + return { valid: true }; + } catch (error) { + if (error instanceof RequestError) { + return { valid: false, cause: error.cause.type }; + } + + return { valid: false, cause: ErrorType.UNEXPECTED }; } }; } |