feat: better user switching code
All checks were successful
Deploy WordPress and Nuxt / deploy (push) Successful in 1m0s

This commit is contained in:
2025-09-15 12:47:28 -04:00
parent 98876f23b8
commit 0fc62d25c3
6 changed files with 53 additions and 53 deletions

View File

@@ -1,38 +1,48 @@
export const useUserSwitching = () => {
const session = useUserSession();
export function useUserSwitching() {
const toast = useToast();
const { fetch: refreshUserSession } = useUserSession();
const { session } = useUserSession();
const isSwitched = computed(() => Boolean(session.data.value?.switchedBy));
const isUserSwitched = computed(() => Boolean(session.value?.switchedBy));
const switchTo = async (userId: string | number) => {
const response = await $fetch("/api/switch-to", {
async function userSwitchTo(userId: string | number) {
try {
const result = await $fetch<{ success: boolean; message?: string }>("/api/switch-to", {
method: "POST",
body: { userId },
});
if (response.success) {
await session.fetch();
return response;
if (!result.success) {
throw new Error(result.message || "Switch failed");
}
throw new Error(response.message || "Switch failed");
};
await refreshUserSession();
return result;
}
catch (error) {
const message = error instanceof Error ? error.message : "Switch failed";
toast.add({ title: "Échec du changement d'utilisateur", description: message, color: "error" });
throw error;
}
}
const switchBack = async () => {
const response = await $fetch("/api/switch-back", {
async function userSwitchBack() {
try {
const result = await $fetch<{ success: boolean; message?: string }>("/api/switch-back", {
method: "POST",
});
if (response.success) {
await session.fetch();
return response;
if (!result.success) {
throw new Error(result.message || "Échec du retour à l'utilisateur précédent");
}
await refreshUserSession();
return result;
}
catch (error) {
const message = error instanceof Error ? error.message : "Échec du retour à l'utilisateur précédent";
toast.add({ title: "Échec du changement d'utilisateur", description: message, color: "error" });
throw error;
}
}
throw new Error(response.message || "Switch back failed");
};
return {
isSwitched,
switchTo,
switchBack,
};
};
return { isUserSwitched, userSwitchTo, userSwitchBack };
}

View File

@@ -3,17 +3,14 @@ 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 || "Switch back failed");
throw new Error(response.errors[0]?.message);
}
await clearUserSession(event);
return { success: true };
}
catch (error) {
const message = error instanceof Error ? error.message : "Switch back failed";
const message = error instanceof Error ? error.message : "Échec du retour à l'utilisateur précédent";
return { success: false, message };
}
});

View File

@@ -2,32 +2,29 @@ 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 required");
throw new Error("Authentication requise");
}
const response = await useGraphqlMutation("userSwitchTo", { userId });
if (response.errors?.length) {
throw new Error(response.errors[0]?.message || "Switch failed");
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 : "Switch failed";
const message = error instanceof Error ? error.message : "Le changement d'utilisateur a échoué";
return { success: false, message };
}
});

View File

@@ -3,6 +3,7 @@ mutation login($email: String!, $password: String!) {
authToken
refreshToken
user {
id
email
}
}

View File

@@ -4,14 +4,7 @@ mutation userSwitchTo($userId: ID!) {
refreshToken
user {
id
databaseId
username
email
firstName
lastName
avatar {
url
}
}
}
}

View File

@@ -1,11 +1,13 @@
// auth.d.ts
declare module "#auth-utils" {
interface User {
id: number;
email: string;
}
interface UserSession {
loggedInAt: string;
switchedBy?: number;
}
interface SecureSessionData {