mirror of
				https://github.com/hay-kot/homebox.git
				synced 2025-10-25 02:30:57 +00:00 
			
		
		
		
	
							parent
							
								
									0ef9d0deb8
								
							
						
					
					
						commit
						6e203e7833
					
				
					 2 changed files with 10 additions and 6 deletions
				
			
		|  | @ -45,7 +45,8 @@ class AuthContext implements IAuthContext { | ||||||
|   private _attachmentToken: CookieRef<string | null>; |   private _attachmentToken: CookieRef<string | null>; | ||||||
| 
 | 
 | ||||||
|   get token() { |   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() { |   get attachmentToken() { | ||||||
|  | @ -66,11 +67,11 @@ class AuthContext implements IAuthContext { | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   isExpired() { |   isExpired() { | ||||||
|     return this.token; |     return !this.token; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   isAuthorized() { |   isAuthorized() { | ||||||
|     return !this.isExpired(); |     return this.token; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   invalidateSession() { |   invalidateSession() { | ||||||
|  | @ -79,7 +80,6 @@ class AuthContext implements IAuthContext { | ||||||
|     // Delete the cookies
 |     // Delete the cookies
 | ||||||
|     this._token.value = null; |     this._token.value = null; | ||||||
|     this._attachmentToken.value = null; |     this._attachmentToken.value = null; | ||||||
| 
 |  | ||||||
|     console.log("Session invalidated"); |     console.log("Session invalidated"); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -3,14 +3,18 @@ export default defineNuxtRouteMiddleware(async () => { | ||||||
|   const api = useUserApi(); |   const api = useUserApi(); | ||||||
| 
 | 
 | ||||||
|   if (!ctx.isAuthorized()) { |   if (!ctx.isAuthorized()) { | ||||||
|     return navigateTo("/"); |     if (window.location.pathname !== "/") { | ||||||
|  |       return navigateTo("/"); | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if (!ctx.user) { |   if (!ctx.user) { | ||||||
|     console.log("Fetching user data"); |     console.log("Fetching user data"); | ||||||
|     const { data, error } = await api.user.self(); |     const { data, error } = await api.user.self(); | ||||||
|     if (error) { |     if (error) { | ||||||
|       return navigateTo("/"); |       if (window.location.pathname !== "/") { | ||||||
|  |         return navigateTo("/"); | ||||||
|  |       } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     ctx.user = data.item; |     ctx.user = data.item; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue