summaryrefslogtreecommitdiffhomepage
path: root/packages/console/app/src
diff options
context:
space:
mode:
authorFrank <[email protected]>2025-12-26 17:32:37 -0500
committerFrank <[email protected]>2025-12-26 17:32:39 -0500
commit52b99622ad0c01d11a5f8a5826ed955f6aa13dca (patch)
tree8fd3e0fb81b115276dac2fb6a84a9e4c825b12b2 /packages/console/app/src
parenta15397cd89881c36c19b3f909ebceddb47aeca90 (diff)
downloadopencode-52b99622ad0c01d11a5f8a5826ed955f6aa13dca.tar.gz
opencode-52b99622ad0c01d11a5f8a5826ed955f6aa13dca.zip
zen: add context for login errors
Diffstat (limited to 'packages/console/app/src')
-rw-r--r--packages/console/app/src/routes/auth/callback.ts54
1 files changed, 31 insertions, 23 deletions
diff --git a/packages/console/app/src/routes/auth/callback.ts b/packages/console/app/src/routes/auth/callback.ts
index a793b8596..2f8781e98 100644
--- a/packages/console/app/src/routes/auth/callback.ts
+++ b/packages/console/app/src/routes/auth/callback.ts
@@ -5,28 +5,36 @@ import { useAuthSession } from "~/context/auth.session"
export async function GET(input: APIEvent) {
const url = new URL(input.request.url)
- const code = url.searchParams.get("code")
- if (!code) throw new Error("No code found")
- const result = await AuthClient.exchange(code, `${url.origin}${url.pathname}`)
- if (result.err) {
- throw new Error(result.err.message)
- }
- const decoded = AuthClient.decode(result.tokens.access, {} as any)
- if (decoded.err) throw new Error(decoded.err.message)
- const session = await useAuthSession()
- const id = decoded.subject.properties.accountID
- await session.update((value) => {
- return {
- ...value,
- account: {
- ...value.account,
- [id]: {
- id,
- email: decoded.subject.properties.email,
+ try {
+ const code = url.searchParams.get("code")
+ if (!code) throw new Error("No code found")
+ const result = await AuthClient.exchange(code, `${url.origin}${url.pathname}`)
+ if (result.err) throw new Error(result.err.message)
+ const decoded = AuthClient.decode(result.tokens.access, {} as any)
+ if (decoded.err) throw new Error(decoded.err.message)
+ const session = await useAuthSession()
+ const id = decoded.subject.properties.accountID
+ await session.update((value) => {
+ return {
+ ...value,
+ account: {
+ ...value.account,
+ [id]: {
+ id,
+ email: decoded.subject.properties.email,
+ },
},
- },
- current: id,
- }
- })
- return redirect("/auth")
+ current: id,
+ }
+ })
+ return redirect("/auth")
+ } catch (e: any) {
+ return new Response(
+ JSON.stringify({
+ error: e.message,
+ cause: Object.fromEntries(url.searchParams.entries()),
+ }),
+ { status: 500 },
+ )
+ }
}