refactor: use onServerResponse for auth instead of server api

This commit is contained in:
2025-09-18 10:23:09 -04:00
parent a661350e1c
commit c82abe88e4
11 changed files with 57 additions and 139 deletions

View File

@@ -1,29 +0,0 @@
import { defineEventHandler, readBody } from "h3";
export default defineEventHandler(async (event) => {
const { email, password } = await readBody(event);
try {
const response = await useGraphqlMutation("login", { email, password });
if (response.errors.length) {
throw new Error(response.errors[0]?.message);
}
if (!response.data.login) {
throw new Error("Login failed: Invalid credentials");
}
const { authToken, refreshToken, user } = response.data.login;
await setUserSession(event, {
user,
secure: { authToken, refreshToken },
loggedInAt: new Date().toISOString(),
});
return { success: true };
}
catch (error) {
const messages: Record<string, string> = {
invalid_email: "Courriel et/ou mot de passe invalide(s).",
incorrect_password: "Courriel et/ou mot de passe invalide(s).",
};
const message = error instanceof Error && messages[error.message] ? messages[error.message] : "Une erreur est survenue.";
return { success: false, message };
}
});

View File

@@ -2,15 +2,12 @@ import { defineEventHandler } from "h3";
export default defineEventHandler(async (event) => {
try {
const response = await useGraphqlMutation("userSwitchBack");
if (response.errors?.length) {
throw new Error(response.errors[0]?.message);
}
// TODO: Switch back to the previous user.
await clearUserSession(event);
return { success: true };
}
catch (error) {
const message = error instanceof Error ? error.message : "Échec du retour à l'utilisateur précédent";
const message = error instanceof Error ? error.message : "Une erreur est survenue.";
return { success: false, message };
}
});

View File

@@ -1,30 +0,0 @@
import { defineEventHandler, readBody } from "h3";
export default defineEventHandler(async (event) => {
const { userId } = await readBody(event);
try {
const currentSession = await getUserSession(event);
if (!currentSession?.user) {
throw new Error("Authentication requise");
}
const response = await useGraphqlMutation("userSwitchTo", { userId });
if (response.errors?.length) {
throw new Error(response.errors[0]?.message);
}
if (!response.data.userSwitchTo) {
throw new Error("Le changement d'utilisateur a échoué");
}
const { authToken, refreshToken, user } = response.data.userSwitchTo;
await setUserSession(event, {
user,
secure: { authToken, refreshToken },
loggedInAt: new Date().toISOString(),
switchedBy: currentSession.user.id,
});
return { success: true };
}
catch (error) {
const message = error instanceof Error ? error.message : "Le changement d'utilisateur a échoué";
return { success: false, message };
}
});