From ae4b95301f28e361ce989019656f8c78a4469cf9 Mon Sep 17 00:00:00 2001 From: Hayden <64056131+hay-kot@users.noreply.github.com> Date: Tue, 10 Oct 2023 08:43:44 -0500 Subject: [PATCH] fix: infinite redirect issue (#583) --- frontend/composables/use-auth-context.ts | 8 ++++---- frontend/middleware/auth.ts | 8 ++++++-- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/frontend/composables/use-auth-context.ts b/frontend/composables/use-auth-context.ts index 56fc6393..740a303d 100644 --- a/frontend/composables/use-auth-context.ts +++ b/frontend/composables/use-auth-context.ts @@ -45,7 +45,8 @@ class AuthContext implements IAuthContext { private _attachmentToken: CookieRef; get token() { - return this._token.value === "true"; + // @ts-ignore sometimes it's a boolean I guess? + return this._token.value === "true" || this._token.value === true; } get attachmentToken() { @@ -66,11 +67,11 @@ class AuthContext implements IAuthContext { } isExpired() { - return this.token; + return !this.token; } isAuthorized() { - return !this.isExpired(); + return this.token; } invalidateSession() { @@ -79,7 +80,6 @@ class AuthContext implements IAuthContext { // Delete the cookies this._token.value = null; this._attachmentToken.value = null; - console.log("Session invalidated"); } diff --git a/frontend/middleware/auth.ts b/frontend/middleware/auth.ts index 25aebebb..2eca73f2 100644 --- a/frontend/middleware/auth.ts +++ b/frontend/middleware/auth.ts @@ -3,14 +3,18 @@ export default defineNuxtRouteMiddleware(async () => { const api = useUserApi(); if (!ctx.isAuthorized()) { - return navigateTo("/"); + if (window.location.pathname !== "/") { + return navigateTo("/"); + } } if (!ctx.user) { console.log("Fetching user data"); const { data, error } = await api.user.self(); if (error) { - return navigateTo("/"); + if (window.location.pathname !== "/") { + return navigateTo("/"); + } } ctx.user = data.item;