refactor: auth stuff

This commit is contained in:
2025-09-18 11:39:29 -04:00
parent c82abe88e4
commit 3cc4b570d5
9 changed files with 93 additions and 44 deletions

View File

@@ -2,8 +2,7 @@ import { defineEventHandler } from "h3";
export default defineEventHandler(async (event) => {
try {
// TODO: Switch back to the previous user.
await clearUserSession(event);
await handleSwitchBack(event);
return { success: true };
}
catch (error) {

View File

@@ -32,44 +32,15 @@ export default defineGraphqlServerOptions({
return { headers: { ...headers, Authorization: `Bearer ${session.secure.authToken}` } };
},
onServerResponse(event, response, _operation, operationName) {
// Handle login mutation
if (operationName === "login") {
const loginData = response._data as LoginRootMutation;
if (loginData?.login) {
const { authToken, refreshToken, user } = loginData.login;
setUserSession(event, {
user: {
id: user?.id,
email: user?.email,
},
secure: {
authToken,
refreshToken,
},
});
}
async onServerResponse(event, response, _operation, operationName) {
switch (operationName) {
case "login":
await handleLogin(event, response._data!.data as LoginRootMutation);
break;
case "userSwitchTo":
await handleSwitchTo(event, response._data!.data as UserSwitchToRootMutation);
break;
}
// Handle user switch mutations
if (operationName === "userSwitchTo") {
const switchData = response._data as UserSwitchToRootMutation;
if (switchData?.userSwitchTo?.authToken) {
const { authToken, refreshToken, user } = switchData.userSwitchTo;
setUserSession(event, {
user: {
id: user?.id,
email: user?.email,
},
secure: {
authToken,
refreshToken,
},
});
}
}
// Return the original response data
return response._data!;
},
});

View File

@@ -0,0 +1,65 @@
import type { LoginRootMutation, UserSwitchToRootMutation } from "#graphql-operations";
import type { H3Event } from "h3";
import { pick } from "es-toolkit/compat";
export async function handleLogin(event: H3Event, loginData?: LoginRootMutation) {
if (!loginData?.login?.user) {
return;
}
const { authToken, refreshToken, user } = loginData.login;
await setUserSession(event, {
user: {
id: user.id,
email: user.email,
},
secure: {
authToken,
refreshToken,
},
loggedInAt: new Date().toISOString(),
isSwitchedTo: false,
});
}
export async function handleLogout(event: H3Event) {
await clearUserSession(event);
}
export async function handleSwitchTo(event: H3Event, data?: UserSwitchToRootMutation) {
if (!data?.userSwitchTo?.user) {
return;
}
const session = await getUserSession(event);
const { authToken, refreshToken, user } = data.userSwitchTo;
await setUserSession(event, {
user: {
id: user.id,
email: user.email,
},
secure: {
authToken,
refreshToken,
previous: {
user: session.user,
loggedInAt: session.loggedInAt,
secure: pick(session.secure, ["authToken", "refreshToken"]),
},
},
loggedInAt: new Date().toISOString(),
isSwitchedTo: true,
});
}
export async function handleSwitchBack(event: H3Event) {
const session = await getUserSession(event);
if (!session.secure?.previous) {
return;
}
const { user, loggedInAt, secure } = session.secure.previous;
await setUserSession(event, {
user,
secure,
loggedInAt,
isSwitchedTo: false,
});
}