generated from pascalmartineau/wp-skeleton
refactor: use onServerResponse for auth instead of server api
This commit is contained in:
@@ -1,5 +1,6 @@
|
||||
import { defineGraphqlServerOptions } from "nuxt-graphql-middleware/server-options";
|
||||
import { jwtDecode } from "jwt-decode";
|
||||
import type { LoginRootMutation, UserSwitchToRootMutation } from "#graphql-operations";
|
||||
|
||||
interface DecodedToken {
|
||||
exp: number;
|
||||
@@ -24,9 +25,51 @@ export default defineGraphqlServerOptions({
|
||||
const newToken = await refreshAuthToken(session.secure.refreshToken);
|
||||
if (newToken) {
|
||||
session.secure.authToken = newToken;
|
||||
await setUserSession(event, session);
|
||||
}
|
||||
}
|
||||
|
||||
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,
|
||||
},
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
// 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!;
|
||||
},
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user