nidus-sync/ts/store/session.ts
Eli Ribble a0ac5c0674
Add debug logs around authentication
Trying to troubleshoot our redirection logic after signin
2026-04-21 19:40:00 +00:00

100 lines
2.5 KiB
TypeScript

import { defineStore } from "pinia";
import { ref } from "vue";
import { SSEManager, type SSEMessage } from "@/SSEManager";
import {
Organization,
Session,
SessionNotificationCounts,
URLs,
User,
} from "@/type/api";
import { apiClient } from "@/client";
export const useSessionStore = defineStore("session", () => {
// State
const hasSession = ref<boolean>(false);
const isAuthenticated = ref<boolean>(false);
const isLoading = ref(true);
const impersonating = ref<string | null>(null);
const error = ref<string | null>(null);
const current = ref<Session | null>(null);
const notification_counts = ref<SessionNotificationCounts | null>(null);
const ongoingFetch = ref<Promise<Session> | null>(null);
const organization = ref<Organization | null>(null);
const self = ref<User | null>(null);
const urls = ref<URLs | null>(null);
// Subscription
SSEManager.subscribe((msg: SSEMessage) => {
if (msg.type == "sync:session") {
fetchSession();
}
});
// Actions
async function fetchSession(): Promise<Session> {
error.value = null;
try {
const data: Session = await apiClient.JSONGet("/api/session");
isAuthenticated.value = true;
console.log("set authenticated", isAuthenticated.value);
impersonating.value = data.impersonating || null;
notification_counts.value = data.notification_counts;
organization.value = data.organization;
self.value = data.self;
urls.value = data.urls;
return data;
} catch (e) {
error.value = e instanceof Error ? e.message : "an error ocurred";
console.error("Error fetching user:", e);
throw new Error(error.value);
} finally {
hasSession.value = true;
isLoading.value = false;
console.log("no longer loading session");
}
}
async function getAuthenticated(): Promise<boolean> {
await get();
return isAuthenticated.value;
}
async function get(): Promise<Session> {
if (current.value != null) {
return current.value;
}
if (ongoingFetch.value !== null) {
return ongoingFetch.value;
}
const s = await fetchSession();
current.value = s;
ongoingFetch.value = null;
return s;
}
async function signout(): Promise<void> {
isAuthenticated.value = false;
console.log("set authenticated", isAuthenticated.value);
apiClient.JSONPost("/api/signout", {});
}
return {
// State
error,
getAuthenticated,
hasSession,
impersonating,
isAuthenticated,
isLoading,
notification_counts,
organization,
self,
urls,
// Actions
fetchSession,
get,
signout,
};
});