generated from pascalmartineau/wp-skeleton
refactor: use onServerResponse for auth instead of server api
This commit is contained in:
@@ -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 };
|
||||
}
|
||||
});
|
||||
@@ -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 };
|
||||
}
|
||||
});
|
||||
|
||||
@@ -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 };
|
||||
}
|
||||
});
|
||||
Reference in New Issue
Block a user