generated from pascalmartineau/wp-skeleton
feat: better user switching code
All checks were successful
Deploy WordPress and Nuxt / deploy (push) Successful in 1m0s
All checks were successful
Deploy WordPress and Nuxt / deploy (push) Successful in 1m0s
This commit is contained in:
@@ -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", {
|
||||
method: "POST",
|
||||
body: { userId },
|
||||
});
|
||||
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");
|
||||
}
|
||||
|
||||
await refreshUserSession();
|
||||
return result;
|
||||
}
|
||||
|
||||
throw new Error(response.message || "Switch failed");
|
||||
};
|
||||
|
||||
const switchBack = async () => {
|
||||
const response = await $fetch("/api/switch-back", {
|
||||
method: "POST",
|
||||
});
|
||||
|
||||
if (response.success) {
|
||||
await session.fetch();
|
||||
return response;
|
||||
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;
|
||||
}
|
||||
}
|
||||
|
||||
throw new Error(response.message || "Switch back failed");
|
||||
};
|
||||
async function userSwitchBack() {
|
||||
try {
|
||||
const result = await $fetch<{ success: boolean; message?: string }>("/api/switch-back", {
|
||||
method: "POST",
|
||||
});
|
||||
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;
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
isSwitched,
|
||||
switchTo,
|
||||
switchBack,
|
||||
};
|
||||
};
|
||||
return { isUserSwitched, userSwitchTo, userSwitchBack };
|
||||
}
|
||||
|
||||
@@ -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 };
|
||||
}
|
||||
});
|
||||
|
||||
@@ -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 };
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
@@ -3,6 +3,7 @@ mutation login($email: String!, $password: String!) {
|
||||
authToken
|
||||
refreshToken
|
||||
user {
|
||||
id
|
||||
email
|
||||
}
|
||||
}
|
||||
@@ -4,14 +4,7 @@ mutation userSwitchTo($userId: ID!) {
|
||||
refreshToken
|
||||
user {
|
||||
id
|
||||
databaseId
|
||||
username
|
||||
email
|
||||
firstName
|
||||
lastName
|
||||
avatar {
|
||||
url
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
2
wp-content/themes/ccat/shared/auth.d.ts
vendored
2
wp-content/themes/ccat/shared/auth.d.ts
vendored
@@ -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 {
|
||||
|
||||
Reference in New Issue
Block a user