import { safeParse } from "$lib/utils/json.js"; import { PUBLIC_HF_TOKEN } from "$env/static/public"; import typia from "typia"; const key = "hf_token"; class Token { #value = $state(""); writeToLocalStorage = $state(true); constructor() { if (PUBLIC_HF_TOKEN) { this.#value = PUBLIC_HF_TOKEN; return; } const storedHfToken = localStorage.getItem(key); const parsed = safeParse(storedHfToken ?? ""); const storedToken = typia.is(parsed) ? parsed : ""; if (storedToken) { this.#value = storedToken; } else { this.requestTokenFromParent(); } } get value() { return this.#value; } set value(token: string) { if (this.writeToLocalStorage) { localStorage.setItem(key, JSON.stringify(token)); } this.#value = token; } requestTokenFromParent = (): Promise => { if (typeof window === "undefined") return Promise.resolve(); return new Promise(resolve => { const handleMessage = (event: MessageEvent) => { if (event.data.type === "INFERENCE_JWT_RESPONSE") { const token = event.data.token; if (token && typeof token === "string") { this.value = token; window.removeEventListener("message", handleMessage); resolve(); } } }; window.addEventListener("message", handleMessage); window.parent?.postMessage({ type: "INFERENCE_JWT_REQUEST" }, "*"); }); }; reset = () => { this.value = ""; localStorage.removeItem(key); if (!PUBLIC_HF_TOKEN) { this.requestTokenFromParent(); } }; } export const token = new Token();