@tern-secure/react 1.2.0-canary.v20251127221555 → 1.2.0-canary.v20251202162458

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,2 @@
1
- "use strict";"use client";var l=Object.defineProperty;var S=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var T=Object.prototype.hasOwnProperty;var h=(i,r)=>{for(var o in r)l(i,o,{get:r[o],enumerable:!0})},L=(i,r,o,s)=>{if(r&&typeof r=="object"||typeof r=="function")for(let e of g(r))!T.call(i,e)&&e!==o&&l(i,e,{get:()=>r[e],enumerable:!(s=S(r,e))||s.enumerable});return i};var w=i=>L(l({},"__esModule",{value:!0}),i);var E={};h(E,{useSession:()=>D});module.exports=w(E);var f=require("@tern-secure/shared/react"),n=require("react"),p=require("./useAssertWrappedTernSecureProvider"),m=require("./useAuth");function D(){const i=(0,f.useTernSecureAuthCtx)();(0,p.useAssertWrappedByTernSecureAuthProvider)("useSession");const{user:r}=(0,m.useAuth)(),s=i.currentSession,[e,c]=(0,n.useState)({expirationTime:s?.expirationTime||null,error:null,isLoading:!0}),d=(0,n.useMemo)(()=>e.isLoading?"refreshing":e.error||e.expirationTime?"expired":"active",[e]),a=(0,n.useCallback)(async()=>{try{if(c(x=>({...x,isLoading:!0})),!await r?.getIdToken())throw new Error("Failed to get ID token");const u=Date.now()+60*60*1e3;c({expirationTime:u.toString(),error:null,isLoading:!1})}catch(t){console.error("Failed to refresh session:",t),c(u=>({...u,error:t instanceof Error?t:new Error("An unknown error occurred"),isLoading:!1}))}},[r]);return(0,n.useEffect)(()=>{a();const t=setInterval(()=>{e.expirationTime&&Date.now()<5*60*1e3&&a()},60*1e3);return()=>clearInterval(t)},[a]),{expirationTime:e.expirationTime,error:e.error,isLoading:e.isLoading,status:d,user:r,refresh:a}}0&&(module.exports={useSession});
1
+ "use strict";"use client";var l=Object.defineProperty;var S=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var T=Object.prototype.hasOwnProperty;var h=(i,r)=>{for(var o in r)l(i,o,{get:r[o],enumerable:!0})},L=(i,r,o,s)=>{if(r&&typeof r=="object"||typeof r=="function")for(let e of g(r))!T.call(i,e)&&e!==o&&l(i,e,{get:()=>r[e],enumerable:!(s=S(r,e))||s.enumerable});return i};var w=i=>L(l({},"__esModule",{value:!0}),i);var E={};h(E,{useSession:()=>D});module.exports=w(E);var f=require("@tern-secure/shared/react"),n=require("react"),p=require("./useAssertWrappedTernSecureProvider"),m=require("./useAuth");function D(){const i=(0,f.useTernSecureAuthCtx)();(0,p.useAssertWrappedByTernSecureAuthProvider)("useSession");const{user:r}=(0,m.useAuth)(),s=i.currentSession,[e,c]=(0,n.useState)({expirationTime:s?.expirationTime||null,error:null,isLoading:!0}),d=(0,n.useMemo)(()=>e.isLoading?"refreshing":e.error||e.expirationTime?"expired":"active",[e]),a=(0,n.useCallback)(async()=>{try{if(c(x=>({...x,isLoading:!0})),!await r?.getIdToken())throw new Error("Failed to get ID token");const u=Date.now()+3600*1e3;c({expirationTime:u.toString(),error:null,isLoading:!1})}catch(t){console.error("Failed to refresh session:",t),c(u=>({...u,error:t instanceof Error?t:new Error("An unknown error occurred"),isLoading:!1}))}},[r]);return(0,n.useEffect)(()=>{a();const t=setInterval(()=>{e.expirationTime&&Date.now()<300*1e3&&a()},60*1e3);return()=>clearInterval(t)},[a]),{expirationTime:e.expirationTime,error:e.error,isLoading:e.isLoading,status:d,user:r,refresh:a}}0&&(module.exports={useSession});
2
2
  //# sourceMappingURL=useSession.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useSession.ts"],"sourcesContent":["'use client'\n\nimport { \n useTernSecureAuthCtx\n} from '@tern-secure/shared/react'\nimport { \n useCallback,\n useEffect,\n useMemo, \n useState} from 'react'\n\nimport { useAssertWrappedByTernSecureAuthProvider } from './useAssertWrappedTernSecureProvider'\nimport { useAuth } from './useAuth'\n\ninterface SessionData {\n //accessToken: string | null\n expirationTime: string | null\n error: Error | null\n isLoading: boolean\n}\n\ntype SessionStatus = 'active' | 'expired' | 'refreshing' | 'inactive'\n\nexport function useSession() {\n const instanceCtx = useTernSecureAuthCtx()\n\n useAssertWrappedByTernSecureAuthProvider('useSession')\n \n const { user } = useAuth()\n const instance = instanceCtx\n const session = instance.currentSession\n\n const [sessionData, setSessionData] = useState<SessionData>({\n //accessToken: token || null,\n expirationTime: session?.expirationTime|| null, \n error: null,\n isLoading: true\n })\n\n const status = useMemo((): SessionStatus => {\n if (sessionData.isLoading) return 'refreshing'\n //if (!sessionData.accessToken) return 'inactive'\n if (sessionData.error) return 'expired'\n if (sessionData.expirationTime) return 'expired'\n return 'active'\n }, [sessionData])\n\n const refreshSession = useCallback(async () => {\n try {\n setSessionData(prev => ({ ...prev, isLoading: true }))\n //if (!isAuthenticated) throw new Error('No authenticated user')\n\n const token = await user?.getIdToken()\n if (!token) throw new Error('Failed to get ID token')\n\n // Set expiration to 1 hour from now (Firebase default)\n const expirationTime = Date.now() + (60 * 60 * 1000)\n\n setSessionData({\n //accessToken: token,\n expirationTime: expirationTime.toString(), // Store as string for consistency\n error: null,\n isLoading: false\n \n })\n } catch (error) {\n console.error('Failed to refresh session:', error)\n setSessionData(prev => ({\n ...prev,\n error: error instanceof Error ? error : new Error('An unknown error occurred'),\n isLoading: false\n }))\n }\n }, [ user])\n\n useEffect(() => {\n refreshSession()\n\n // Set up a timer to refresh the token before it expires\n const timer = setInterval(() => {\n if (sessionData.expirationTime) {\n const timeUntilExpiry = Date.now()\n if (timeUntilExpiry < 5 * 60 * 1000) { // Refresh 5 minutes before expiry\n refreshSession()\n }\n }\n }, 60 * 1000) // Check every minute\n\n return () => clearInterval(timer)\n }, [refreshSession])\n\n return {\n //accessToken: sessionData.accessToken,\n expirationTime: sessionData.expirationTime,\n error: sessionData.error,\n isLoading: sessionData.isLoading,\n status,\n user,\n refresh: refreshSession\n }\n}"],"mappings":"sbAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,gBAAAE,IAAA,eAAAC,EAAAH,GAEA,IAAAI,EAEO,qCACPA,EAIiB,iBAEjBC,EAAyD,gDACzDC,EAAwB,qBAWjB,SAASJ,GAAa,CAC3B,MAAMK,KAAc,wBAAqB,KAEzC,4CAAyC,YAAY,EAErD,KAAM,CAAE,KAAAC,CAAK,KAAI,WAAQ,EAEnBC,EADWF,EACQ,eAEnB,CAACG,EAAaC,CAAc,KAAI,YAAsB,CAE1D,eAAgBF,GAAS,gBAAiB,KAC1C,MAAO,KACP,UAAW,EACb,CAAC,EAEKG,KAAS,WAAQ,IACjBF,EAAY,UAAkB,aAE9BA,EAAY,OACZA,EAAY,eAAuB,UAChC,SACN,CAACA,CAAW,CAAC,EAEVG,KAAiB,eAAY,SAAY,CAC7C,GAAI,CAKF,GAJAF,EAAeG,IAAS,CAAE,GAAGA,EAAM,UAAW,EAAK,EAAE,EAIjD,CADU,MAAMN,GAAM,WAAW,EACzB,MAAM,IAAI,MAAM,wBAAwB,EAGpD,MAAMO,EAAiB,KAAK,IAAI,EAAK,GAAK,GAAK,IAE/CJ,EAAe,CAEb,eAAgBI,EAAe,SAAS,EACxC,MAAO,KACP,UAAW,EAEb,CAAC,CACH,OAASC,EAAO,CACd,QAAQ,MAAM,6BAA8BA,CAAK,EACjDL,EAAeG,IAAS,CACtB,GAAGA,EACH,MAAOE,aAAiB,MAAQA,EAAQ,IAAI,MAAM,2BAA2B,EAC7E,UAAW,EACb,EAAE,CACJ,CACF,EAAG,CAAER,CAAI,CAAC,EAEV,sBAAU,IAAM,CACdK,EAAe,EAGf,MAAMI,EAAQ,YAAY,IAAM,CAC1BP,EAAY,gBACW,KAAK,IAAI,EACZ,EAAI,GAAK,KAC7BG,EAAe,CAGrB,EAAG,GAAK,GAAI,EAEZ,MAAO,IAAM,cAAcI,CAAK,CAClC,EAAG,CAACJ,CAAc,CAAC,EAEZ,CAEL,eAAgBH,EAAY,eAC5B,MAAOA,EAAY,MACnB,UAAWA,EAAY,UACvB,OAAAE,EACA,KAAAJ,EACA,QAASK,CACX,CACF","names":["useSession_exports","__export","useSession","__toCommonJS","import_react","import_useAssertWrappedTernSecureProvider","import_useAuth","instanceCtx","user","session","sessionData","setSessionData","status","refreshSession","prev","expirationTime","error","timer"]}
1
+ {"version":3,"sources":["../../src/hooks/useSession.ts"],"sourcesContent":["'use client'\n\nimport { \n useTernSecureAuthCtx\n} from '@tern-secure/shared/react'\nimport { \n useCallback,\n useEffect,\n useMemo, \n useState} from 'react'\n\nimport { useAssertWrappedByTernSecureAuthProvider } from './useAssertWrappedTernSecureProvider'\nimport { useAuth } from './useAuth'\n\ninterface SessionData {\n //accessToken: string | null\n expirationTime: string | null\n error: Error | null\n isLoading: boolean\n}\n\ntype SessionStatus = 'active' | 'expired' | 'refreshing' | 'inactive'\n\nexport function useSession() {\n const instanceCtx = useTernSecureAuthCtx()\n\n useAssertWrappedByTernSecureAuthProvider('useSession')\n \n const { user } = useAuth()\n const instance = instanceCtx\n const session = instance.currentSession\n\n const [sessionData, setSessionData] = useState<SessionData>({\n //accessToken: token || null,\n expirationTime: session?.expirationTime|| null, \n error: null,\n isLoading: true\n })\n\n const status = useMemo((): SessionStatus => {\n if (sessionData.isLoading) return 'refreshing'\n //if (!sessionData.accessToken) return 'inactive'\n if (sessionData.error) return 'expired'\n if (sessionData.expirationTime) return 'expired'\n return 'active'\n }, [sessionData])\n\n const refreshSession = useCallback(async () => {\n try {\n setSessionData(prev => ({ ...prev, isLoading: true }))\n //if (!isAuthenticated) throw new Error('No authenticated user')\n\n const token = await user?.getIdToken()\n if (!token) throw new Error('Failed to get ID token')\n\n // Set expiration to 1 hour from now (Firebase default)\n const expirationTime = Date.now() + (60 * 60 * 1000)\n\n setSessionData({\n //accessToken: token,\n expirationTime: expirationTime.toString(), // Store as string for consistency\n error: null,\n isLoading: false\n \n })\n } catch (error) {\n console.error('Failed to refresh session:', error)\n setSessionData(prev => ({\n ...prev,\n error: error instanceof Error ? error : new Error('An unknown error occurred'),\n isLoading: false\n }))\n }\n }, [ user])\n\n useEffect(() => {\n refreshSession()\n\n // Set up a timer to refresh the token before it expires\n const timer = setInterval(() => {\n if (sessionData.expirationTime) {\n const timeUntilExpiry = Date.now()\n if (timeUntilExpiry < 5 * 60 * 1000) { // Refresh 5 minutes before expiry\n refreshSession()\n }\n }\n }, 60 * 1000) // Check every minute\n\n return () => clearInterval(timer)\n }, [refreshSession])\n\n return {\n //accessToken: sessionData.accessToken,\n expirationTime: sessionData.expirationTime,\n error: sessionData.error,\n isLoading: sessionData.isLoading,\n status,\n user,\n refresh: refreshSession\n }\n}"],"mappings":"sbAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,gBAAAE,IAAA,eAAAC,EAAAH,GAEA,IAAAI,EAEO,qCACPA,EAIiB,iBAEjBC,EAAyD,gDACzDC,EAAwB,qBAWjB,SAASJ,GAAa,CAC3B,MAAMK,KAAc,wBAAqB,KAEzC,4CAAyC,YAAY,EAErD,KAAM,CAAE,KAAAC,CAAK,KAAI,WAAQ,EAEnBC,EADWF,EACQ,eAEnB,CAACG,EAAaC,CAAc,KAAI,YAAsB,CAE1D,eAAgBF,GAAS,gBAAiB,KAC1C,MAAO,KACP,UAAW,EACb,CAAC,EAEKG,KAAS,WAAQ,IACjBF,EAAY,UAAkB,aAE9BA,EAAY,OACZA,EAAY,eAAuB,UAChC,SACN,CAACA,CAAW,CAAC,EAEVG,KAAiB,eAAY,SAAY,CAC7C,GAAI,CAKF,GAJAF,EAAeG,IAAS,CAAE,GAAGA,EAAM,UAAW,EAAK,EAAE,EAIjD,CADU,MAAMN,GAAM,WAAW,EACzB,MAAM,IAAI,MAAM,wBAAwB,EAGpD,MAAMO,EAAiB,KAAK,IAAI,EAAK,KAAU,IAE/CJ,EAAe,CAEb,eAAgBI,EAAe,SAAS,EACxC,MAAO,KACP,UAAW,EAEb,CAAC,CACH,OAASC,EAAO,CACd,QAAQ,MAAM,6BAA8BA,CAAK,EACjDL,EAAeG,IAAS,CACtB,GAAGA,EACH,MAAOE,aAAiB,MAAQA,EAAQ,IAAI,MAAM,2BAA2B,EAC7E,UAAW,EACb,EAAE,CACJ,CACF,EAAG,CAAER,CAAI,CAAC,EAEV,sBAAU,IAAM,CACdK,EAAe,EAGf,MAAMI,EAAQ,YAAY,IAAM,CAC1BP,EAAY,gBACW,KAAK,IAAI,EACZ,IAAS,KAC7BG,EAAe,CAGrB,EAAG,GAAK,GAAI,EAEZ,MAAO,IAAM,cAAcI,CAAK,CAClC,EAAG,CAACJ,CAAc,CAAC,EAEZ,CAEL,eAAgBH,EAAY,eAC5B,MAAOA,EAAY,MACnB,UAAWA,EAAY,UACvB,OAAAE,EACA,KAAAJ,EACA,QAASK,CACX,CACF","names":["useSession_exports","__export","useSession","__toCommonJS","import_react","import_useAssertWrappedTernSecureProvider","import_useAuth","instanceCtx","user","session","sessionData","setSessionData","status","refreshSession","prev","expirationTime","error","timer"]}
@@ -1,2 +1,2 @@
1
- "use client";import{useTernSecureAuthCtx as l}from"@tern-secure/shared/react";import{useCallback as f,useEffect as p,useMemo as m,useState as d}from"react";import{useAssertWrappedByTernSecureAuthProvider as x}from"./useAssertWrappedTernSecureProvider";import{useAuth as S}from"./useAuth";function D(){const s=l();x("useSession");const{user:t}=S(),a=s.currentSession,[e,o]=d({expirationTime:a?.expirationTime||null,error:null,isLoading:!0}),u=m(()=>e.isLoading?"refreshing":e.error||e.expirationTime?"expired":"active",[e]),i=f(async()=>{try{if(o(c=>({...c,isLoading:!0})),!await t?.getIdToken())throw new Error("Failed to get ID token");const n=Date.now()+60*60*1e3;o({expirationTime:n.toString(),error:null,isLoading:!1})}catch(r){console.error("Failed to refresh session:",r),o(n=>({...n,error:r instanceof Error?r:new Error("An unknown error occurred"),isLoading:!1}))}},[t]);return p(()=>{i();const r=setInterval(()=>{e.expirationTime&&Date.now()<5*60*1e3&&i()},60*1e3);return()=>clearInterval(r)},[i]),{expirationTime:e.expirationTime,error:e.error,isLoading:e.isLoading,status:u,user:t,refresh:i}}export{D as useSession};
1
+ "use client";import{useTernSecureAuthCtx as l}from"@tern-secure/shared/react";import{useCallback as f,useEffect as p,useMemo as m,useState as d}from"react";import{useAssertWrappedByTernSecureAuthProvider as x}from"./useAssertWrappedTernSecureProvider";import{useAuth as S}from"./useAuth";function D(){const s=l();x("useSession");const{user:t}=S(),a=s.currentSession,[e,o]=d({expirationTime:a?.expirationTime||null,error:null,isLoading:!0}),u=m(()=>e.isLoading?"refreshing":e.error||e.expirationTime?"expired":"active",[e]),i=f(async()=>{try{if(o(c=>({...c,isLoading:!0})),!await t?.getIdToken())throw new Error("Failed to get ID token");const n=Date.now()+3600*1e3;o({expirationTime:n.toString(),error:null,isLoading:!1})}catch(r){console.error("Failed to refresh session:",r),o(n=>({...n,error:r instanceof Error?r:new Error("An unknown error occurred"),isLoading:!1}))}},[t]);return p(()=>{i();const r=setInterval(()=>{e.expirationTime&&Date.now()<300*1e3&&i()},60*1e3);return()=>clearInterval(r)},[i]),{expirationTime:e.expirationTime,error:e.error,isLoading:e.isLoading,status:u,user:t,refresh:i}}export{D as useSession};
2
2
  //# sourceMappingURL=useSession.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/hooks/useSession.ts"],"sourcesContent":["'use client'\n\nimport { \n useTernSecureAuthCtx\n} from '@tern-secure/shared/react'\nimport { \n useCallback,\n useEffect,\n useMemo, \n useState} from 'react'\n\nimport { useAssertWrappedByTernSecureAuthProvider } from './useAssertWrappedTernSecureProvider'\nimport { useAuth } from './useAuth'\n\ninterface SessionData {\n //accessToken: string | null\n expirationTime: string | null\n error: Error | null\n isLoading: boolean\n}\n\ntype SessionStatus = 'active' | 'expired' | 'refreshing' | 'inactive'\n\nexport function useSession() {\n const instanceCtx = useTernSecureAuthCtx()\n\n useAssertWrappedByTernSecureAuthProvider('useSession')\n \n const { user } = useAuth()\n const instance = instanceCtx\n const session = instance.currentSession\n\n const [sessionData, setSessionData] = useState<SessionData>({\n //accessToken: token || null,\n expirationTime: session?.expirationTime|| null, \n error: null,\n isLoading: true\n })\n\n const status = useMemo((): SessionStatus => {\n if (sessionData.isLoading) return 'refreshing'\n //if (!sessionData.accessToken) return 'inactive'\n if (sessionData.error) return 'expired'\n if (sessionData.expirationTime) return 'expired'\n return 'active'\n }, [sessionData])\n\n const refreshSession = useCallback(async () => {\n try {\n setSessionData(prev => ({ ...prev, isLoading: true }))\n //if (!isAuthenticated) throw new Error('No authenticated user')\n\n const token = await user?.getIdToken()\n if (!token) throw new Error('Failed to get ID token')\n\n // Set expiration to 1 hour from now (Firebase default)\n const expirationTime = Date.now() + (60 * 60 * 1000)\n\n setSessionData({\n //accessToken: token,\n expirationTime: expirationTime.toString(), // Store as string for consistency\n error: null,\n isLoading: false\n \n })\n } catch (error) {\n console.error('Failed to refresh session:', error)\n setSessionData(prev => ({\n ...prev,\n error: error instanceof Error ? error : new Error('An unknown error occurred'),\n isLoading: false\n }))\n }\n }, [ user])\n\n useEffect(() => {\n refreshSession()\n\n // Set up a timer to refresh the token before it expires\n const timer = setInterval(() => {\n if (sessionData.expirationTime) {\n const timeUntilExpiry = Date.now()\n if (timeUntilExpiry < 5 * 60 * 1000) { // Refresh 5 minutes before expiry\n refreshSession()\n }\n }\n }, 60 * 1000) // Check every minute\n\n return () => clearInterval(timer)\n }, [refreshSession])\n\n return {\n //accessToken: sessionData.accessToken,\n expirationTime: sessionData.expirationTime,\n error: sessionData.error,\n isLoading: sessionData.isLoading,\n status,\n user,\n refresh: refreshSession\n }\n}"],"mappings":"aAEA,OACE,wBAAAA,MACK,4BACP,OACE,eAAAC,EACA,aAAAC,EACA,WAAAC,EACA,YAAAC,MAAe,QAEjB,OAAS,4CAAAC,MAAgD,uCACzD,OAAS,WAAAC,MAAe,YAWjB,SAASC,GAAa,CAC3B,MAAMC,EAAcR,EAAqB,EAEzCK,EAAyC,YAAY,EAErD,KAAM,CAAE,KAAAI,CAAK,EAAIH,EAAQ,EAEnBI,EADWF,EACQ,eAEnB,CAACG,EAAaC,CAAc,EAAIR,EAAsB,CAE1D,eAAgBM,GAAS,gBAAiB,KAC1C,MAAO,KACP,UAAW,EACb,CAAC,EAEKG,EAASV,EAAQ,IACjBQ,EAAY,UAAkB,aAE9BA,EAAY,OACZA,EAAY,eAAuB,UAChC,SACN,CAACA,CAAW,CAAC,EAEVG,EAAiBb,EAAY,SAAY,CAC7C,GAAI,CAKF,GAJAW,EAAeG,IAAS,CAAE,GAAGA,EAAM,UAAW,EAAK,EAAE,EAIjD,CADU,MAAMN,GAAM,WAAW,EACzB,MAAM,IAAI,MAAM,wBAAwB,EAGpD,MAAMO,EAAiB,KAAK,IAAI,EAAK,GAAK,GAAK,IAE/CJ,EAAe,CAEb,eAAgBI,EAAe,SAAS,EACxC,MAAO,KACP,UAAW,EAEb,CAAC,CACH,OAASC,EAAO,CACd,QAAQ,MAAM,6BAA8BA,CAAK,EACjDL,EAAeG,IAAS,CACtB,GAAGA,EACH,MAAOE,aAAiB,MAAQA,EAAQ,IAAI,MAAM,2BAA2B,EAC7E,UAAW,EACb,EAAE,CACJ,CACF,EAAG,CAAER,CAAI,CAAC,EAEV,OAAAP,EAAU,IAAM,CACdY,EAAe,EAGf,MAAMI,EAAQ,YAAY,IAAM,CAC1BP,EAAY,gBACW,KAAK,IAAI,EACZ,EAAI,GAAK,KAC7BG,EAAe,CAGrB,EAAG,GAAK,GAAI,EAEZ,MAAO,IAAM,cAAcI,CAAK,CAClC,EAAG,CAACJ,CAAc,CAAC,EAEZ,CAEL,eAAgBH,EAAY,eAC5B,MAAOA,EAAY,MACnB,UAAWA,EAAY,UACvB,OAAAE,EACA,KAAAJ,EACA,QAASK,CACX,CACF","names":["useTernSecureAuthCtx","useCallback","useEffect","useMemo","useState","useAssertWrappedByTernSecureAuthProvider","useAuth","useSession","instanceCtx","user","session","sessionData","setSessionData","status","refreshSession","prev","expirationTime","error","timer"]}
1
+ {"version":3,"sources":["../../src/hooks/useSession.ts"],"sourcesContent":["'use client'\n\nimport { \n useTernSecureAuthCtx\n} from '@tern-secure/shared/react'\nimport { \n useCallback,\n useEffect,\n useMemo, \n useState} from 'react'\n\nimport { useAssertWrappedByTernSecureAuthProvider } from './useAssertWrappedTernSecureProvider'\nimport { useAuth } from './useAuth'\n\ninterface SessionData {\n //accessToken: string | null\n expirationTime: string | null\n error: Error | null\n isLoading: boolean\n}\n\ntype SessionStatus = 'active' | 'expired' | 'refreshing' | 'inactive'\n\nexport function useSession() {\n const instanceCtx = useTernSecureAuthCtx()\n\n useAssertWrappedByTernSecureAuthProvider('useSession')\n \n const { user } = useAuth()\n const instance = instanceCtx\n const session = instance.currentSession\n\n const [sessionData, setSessionData] = useState<SessionData>({\n //accessToken: token || null,\n expirationTime: session?.expirationTime|| null, \n error: null,\n isLoading: true\n })\n\n const status = useMemo((): SessionStatus => {\n if (sessionData.isLoading) return 'refreshing'\n //if (!sessionData.accessToken) return 'inactive'\n if (sessionData.error) return 'expired'\n if (sessionData.expirationTime) return 'expired'\n return 'active'\n }, [sessionData])\n\n const refreshSession = useCallback(async () => {\n try {\n setSessionData(prev => ({ ...prev, isLoading: true }))\n //if (!isAuthenticated) throw new Error('No authenticated user')\n\n const token = await user?.getIdToken()\n if (!token) throw new Error('Failed to get ID token')\n\n // Set expiration to 1 hour from now (Firebase default)\n const expirationTime = Date.now() + (60 * 60 * 1000)\n\n setSessionData({\n //accessToken: token,\n expirationTime: expirationTime.toString(), // Store as string for consistency\n error: null,\n isLoading: false\n \n })\n } catch (error) {\n console.error('Failed to refresh session:', error)\n setSessionData(prev => ({\n ...prev,\n error: error instanceof Error ? error : new Error('An unknown error occurred'),\n isLoading: false\n }))\n }\n }, [ user])\n\n useEffect(() => {\n refreshSession()\n\n // Set up a timer to refresh the token before it expires\n const timer = setInterval(() => {\n if (sessionData.expirationTime) {\n const timeUntilExpiry = Date.now()\n if (timeUntilExpiry < 5 * 60 * 1000) { // Refresh 5 minutes before expiry\n refreshSession()\n }\n }\n }, 60 * 1000) // Check every minute\n\n return () => clearInterval(timer)\n }, [refreshSession])\n\n return {\n //accessToken: sessionData.accessToken,\n expirationTime: sessionData.expirationTime,\n error: sessionData.error,\n isLoading: sessionData.isLoading,\n status,\n user,\n refresh: refreshSession\n }\n}"],"mappings":"aAEA,OACE,wBAAAA,MACK,4BACP,OACE,eAAAC,EACA,aAAAC,EACA,WAAAC,EACA,YAAAC,MAAe,QAEjB,OAAS,4CAAAC,MAAgD,uCACzD,OAAS,WAAAC,MAAe,YAWjB,SAASC,GAAa,CAC3B,MAAMC,EAAcR,EAAqB,EAEzCK,EAAyC,YAAY,EAErD,KAAM,CAAE,KAAAI,CAAK,EAAIH,EAAQ,EAEnBI,EADWF,EACQ,eAEnB,CAACG,EAAaC,CAAc,EAAIR,EAAsB,CAE1D,eAAgBM,GAAS,gBAAiB,KAC1C,MAAO,KACP,UAAW,EACb,CAAC,EAEKG,EAASV,EAAQ,IACjBQ,EAAY,UAAkB,aAE9BA,EAAY,OACZA,EAAY,eAAuB,UAChC,SACN,CAACA,CAAW,CAAC,EAEVG,EAAiBb,EAAY,SAAY,CAC7C,GAAI,CAKF,GAJAW,EAAeG,IAAS,CAAE,GAAGA,EAAM,UAAW,EAAK,EAAE,EAIjD,CADU,MAAMN,GAAM,WAAW,EACzB,MAAM,IAAI,MAAM,wBAAwB,EAGpD,MAAMO,EAAiB,KAAK,IAAI,EAAK,KAAU,IAE/CJ,EAAe,CAEb,eAAgBI,EAAe,SAAS,EACxC,MAAO,KACP,UAAW,EAEb,CAAC,CACH,OAASC,EAAO,CACd,QAAQ,MAAM,6BAA8BA,CAAK,EACjDL,EAAeG,IAAS,CACtB,GAAGA,EACH,MAAOE,aAAiB,MAAQA,EAAQ,IAAI,MAAM,2BAA2B,EAC7E,UAAW,EACb,EAAE,CACJ,CACF,EAAG,CAAER,CAAI,CAAC,EAEV,OAAAP,EAAU,IAAM,CACdY,EAAe,EAGf,MAAMI,EAAQ,YAAY,IAAM,CAC1BP,EAAY,gBACW,KAAK,IAAI,EACZ,IAAS,KAC7BG,EAAe,CAGrB,EAAG,GAAK,GAAI,EAEZ,MAAO,IAAM,cAAcI,CAAK,CAClC,EAAG,CAACJ,CAAc,CAAC,EAEZ,CAEL,eAAgBH,EAAY,eAC5B,MAAOA,EAAY,MACnB,UAAWA,EAAY,UACvB,OAAAE,EACA,KAAAJ,EACA,QAASK,CACX,CACF","names":["useTernSecureAuthCtx","useCallback","useEffect","useMemo","useState","useAssertWrappedByTernSecureAuthProvider","useAuth","useSession","instanceCtx","user","session","sessionData","setSessionData","status","refreshSession","prev","expirationTime","error","timer"]}
@@ -1,2 +1,2 @@
1
- "use strict";var o=Object.defineProperty;var l=Object.getOwnPropertyDescriptor;var p=Object.getOwnPropertyNames;var S=Object.prototype.hasOwnProperty;var f=(i,e)=>{for(var t in e)o(i,t,{get:e[t],enumerable:!0})},g=(i,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of p(e))!S.call(i,n)&&n!==t&&o(i,n,{get:()=>e[n],enumerable:!(r=l(e,n))||r.enumerable});return i};var T=i=>g(o({},"__esModule",{value:!0}),i);var m={};f(m,{IsoTernSecureAuth:()=>h,inBrowser:()=>a});module.exports=T(m);var d=require("@tern-secure/shared/loadTernUIScript"),s=require("@tern-secure/shared/ternStatusEvent"),u=require("@tern-secure/shared/utils"),c=require("../utils/isConstructor");const w={name:"@tern-secure/react",version:"1.2.0-canary.v20251127221555",environment:process.env.NODE_ENV};function a(){return typeof window<"u"}class h{_mode;options;TernSecureAuth;TernSecure;ternauth=null;ternui=null;preAddListener=new Map;premountState={signInNodes:new Map,signUpNodes:new Map,userButttonNodes:new Map,verifyNodes:new Set,methodCalls:new Map,errorListeners:new Set};#s="loading";#r;#i;#n;#t=(0,s.createTernAuthEventBus)();static#e;get status(){return this.ternui?this.ternui.status||(this.ternui.isReady?"ready":"loading"):this.#s}get isReady(){return this.ternui?.isReady||!1}get isLoading(){return this.ternui?.isLoading||!1}get requiresVerification(){return this.options.requiresVerification??!0}get signIn(){if(this.ternui)return this.ternui.signIn||void 0}get signUp(){if(this.ternui)return this.ternui.signUp||void 0}get user(){return this.ternui?this.ternui.user:null}static getOrCreateInstance(e){return(!a()||!this.#e||e.TernSecureAuth&&this.#e.TernSecureAuth!==e.TernSecureAuth)&&(this.#e=new h(e)),this.#e}static clearInstances(){this.#e&&(this.#e.ternui=null,this.#e=null)}static clearInstance(){this.#e=null}get authDomain(){if(typeof window<"u"&&window.location)return(0,u.handleValueOrFn)(this.#i,new URL(window.location.href),"");if(typeof this.#i=="function")throw new Error("Unsupported customDomain type: function");return this.#i||""}get proxyUrl(){if(typeof window<"u"&&window.location)return(0,u.handleValueOrFn)(this.#n,new URL(window.location.href),"");if(typeof this.#n=="function")throw new Error("Unsupported customProxyUrl type: function");return this.#n||""}get mode(){return this._mode}_internal_getOption(e){return this.ternui?._internal_getOption?this.ternui?._internal_getOption(e):this.options[e]}_internal_getAllOptions(){return Object.freeze({...this.options})}constructor(e){const{TernSecureAuth:t=null,TernSecure:r=null}=e||{};this.#i=e.ternSecureConfig?.authDomain,this.options={...e},this._mode=a()?"browser":"server",this.#r=this.options.apiUrl,this.#n=this.options.proxyUrl,this.TernSecureAuth=t,this.TernSecure=r,this.options.sdkMetadata||(this.options.sdkMetadata=w),this.#r&&this.loadTernUI()}get sdkMetadata(){return this.ternui?.sdkMetadata||this.options.sdkMetadata}get version(){return this.ternui?.version}get instanceType(){return this.ternui?.instanceType}get apiUrl(){return this.#r||""}#o(){return new Promise(e=>{e(this.ternui)})}async loadTernUI(){if(!(this._mode!=="browser"||this.isReady)){typeof window<"u"&&(window._TernSecure_authDomain=this.authDomain,window._TernSecure_proxyUrl=this.proxyUrl,window._TernSecure_apiUrl=this.apiUrl);try{if(this.TernSecure){let e;(0,c.isConstructor)(this.TernSecure)?(e=new this.TernSecure(this.#r,{proxyUrl:this.proxyUrl,authDomain:this.authDomain}),this.beforeLoad(e),await e.load(this.options)):(e=this.TernSecure,e.isReady||(this.beforeLoad(e),await e.load(this.options))),global.TernSecure=e}else{if(global.TernSecure||await(0,d.loadTernUIScript)({...this.options,authDomain:this.authDomain,nonce:this.options.nonce}),!global.TernSecure)throw new Error("TernSecure instance is not available globally");this.beforeLoad(global.TernSecure),await global.TernSecure.load(this.options)}return global.TernSecure?.isReady?this.injectTernUI(global.TernSecure):void 0}catch(e){const t=e;console.error(t.stack||t.message||t);return}}}beforeLoad=e=>{if(!e)throw new Error("Failed to inject TernUI")};injectTernUI=e=>{if(!e)throw new Error("TernUI instance is not initialized");return this.ternui=e,this.premountState.methodCalls.forEach(t=>t()),this.preAddListener.forEach((t,r)=>{t.unsubscribe=e.addListener(r)}),this.#t.getListeners("status").forEach(t=>{this.on("status",t,{notify:!0})}),this.premountState.signInNodes.forEach((t,r)=>{e.showSignIn(r,t)}),this.premountState.signUpNodes.forEach((t,r)=>{e.showSignUp(r,t)}),typeof this.ternui.status>"u"&&(console.log("[IsomorphicTernSecure] TernUI has no status, setting internal status to ready"),this.#s="ready",this.#t.emit("status","ready"),console.log("[IsomorphicTernSecure] Set internal status to ready (ternui has no status)")),this.ternui};initTernSecureAuth(){if(this._mode!=="browser"||this.isReady)return;const e=TernSecureAuthImpl.initialize(this.options);this.loadTernSecureAuth(e)}loadTernSecureAuth=e=>{if(!e)throw new Error("TernAuth instance is not initialized");return this.ternauth=e,this.preAddListener.forEach((t,r)=>{t.unsubscribe=e.addListener(r)}),this.#t.getListeners("status").forEach(t=>{this.on("status",t,{notify:!0})}),typeof this.ternauth.status>"u"&&(console.log("[IsoTernSecureAuth] TernSecureAuth has no status, setting internal status to ready"),this.#s="ready",this.#t.emit(s.ternEvents.Status,"ready")),this.ternauth};on=(...e)=>this.ternui?.on?this.ternui.on(...e):this.#t.on(...e);off=(...e)=>this.ternui?.off?this.ternui.off(...e):this.#t.off(...e);addListener=e=>{if(this.ternui)return this.ternui.addListener(e);{const t=()=>{const r=this.preAddListener.get(e);r&&(r.unsubscribe(),this.preAddListener.delete(e))};return this.preAddListener.set(e,{unsubscribe:t}),t}};createActiveSession=e=>this.ternui?this.ternui.createActiveSession(e):Promise.reject(new Error("TernSecureAuth not initialized"));signOut=async e=>{if(!this.ternui)throw new Error("TernSecureAuth not initialized");await this.ternui.signOut()};get currentSession(){return this.ternui?this.ternui.currentSession:null}onAuthStateChanged(e){return this.ternui?this.ternui.onAuthStateChanged(e):(console.warn("[IsoTernSecureAuth] TernAuth not initialized, cannot set up auth state listener"),()=>{})}getRedirectResult=async()=>{if(!this.ternui?.getRedirectResult)throw new Error("TernSecure instance not initialized");return this.ternui.getRedirectResult()};constructUrlWithAuthRedirect=e=>this.ternui&&this.isReady?this.ternui.constructUrlWithAuthRedirect(e):"";constructAfterSignOutUrl=()=>{if(this.ternui&&this.isReady)return this.ternui.constructAfterSignOutUrl()||"";{const e=()=>this.ternui?.constructAfterSignOutUrl()||"";return this.premountState.methodCalls.set("constructAfterSignOutUrl",e),""}};navigate=e=>{this.ternui&&this.isReady&&this.ternui.navigate(e)};initialize=async()=>{try{await this.#o()}catch(e){throw console.error("[IsomorphicTernSecure] Failed to initialize TernUI:",e),e}};showSignIn=(e,t)=>{this.ternui&&this.isReady?this.ternui.showSignIn(e,t):this.premountState.signInNodes.set(e,t)};hideSignIn=e=>{this.ternui&&this.isReady?this.ternui.hideSignIn(e):this.premountState.signInNodes.delete(e)};showSignUp=(e,t)=>{this.ternui&&this.isReady?this.ternui.showSignUp(e,t):this.premountState.signUpNodes.set(e,t)};hideSignUp=e=>{this.ternui&&this.isReady?this.ternui.hideSignUp(e):this.premountState.signUpNodes.delete(e)};showUserButton=e=>{this.ternui&&this.isReady?this.ternui.showUserButton(e):this.premountState.userButttonNodes.set(e,void 0)};hideUserButton=e=>{this.ternui&&this.isReady?this.ternui.hideUserButton(e):this.premountState.userButttonNodes.delete(e)};redirectToSignIn=async e=>{this.ternui?.redirectToSignIn&&this.ternui.redirectToSignIn(e)};redirectToSignUp=async e=>{this.ternui?.redirectToSignUp&&this.ternui.redirectToSignUp()};redirectAfterSignIn=e=>{this.ternui?.redirectAfterSignIn&&this.ternui.redirectAfterSignIn()};redirectAfterSignUp=e=>{this.ternui?.redirectAfterSignUp&&this.ternui.redirectAfterSignUp()};#u(){return new Promise(e=>{e(this.ternauth)})}initializeAuth=async()=>{this.initTernSecureAuth();try{await this.#u()}catch(e){throw console.error("[IsomorphicTernSecure] Failed to initialize TernSecureAuth:",e),e}}}0&&(module.exports={IsoTernSecureAuth,inBrowser});
1
+ "use strict";var o=Object.defineProperty;var l=Object.getOwnPropertyDescriptor;var p=Object.getOwnPropertyNames;var S=Object.prototype.hasOwnProperty;var f=(i,e)=>{for(var t in e)o(i,t,{get:e[t],enumerable:!0})},g=(i,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of p(e))!S.call(i,n)&&n!==t&&o(i,n,{get:()=>e[n],enumerable:!(r=l(e,n))||r.enumerable});return i};var T=i=>g(o({},"__esModule",{value:!0}),i);var m={};f(m,{IsoTernSecureAuth:()=>h,inBrowser:()=>a});module.exports=T(m);var d=require("@tern-secure/shared/loadTernUIScript"),s=require("@tern-secure/shared/ternStatusEvent"),u=require("@tern-secure/shared/utils"),c=require("../utils/isConstructor");const w={name:"@tern-secure/react",version:"1.2.0-canary.v20251202162458",environment:process.env.NODE_ENV};function a(){return typeof window<"u"}class h{_mode;options;TernSecureAuth;TernSecure;ternauth=null;ternui=null;preAddListener=new Map;premountState={signInNodes:new Map,signUpNodes:new Map,userButttonNodes:new Map,verifyNodes:new Set,methodCalls:new Map,errorListeners:new Set};#s="loading";#r;#i;#n;#t=(0,s.createTernAuthEventBus)();static#e;get status(){return this.ternui?this.ternui.status||(this.ternui.isReady?"ready":"loading"):this.#s}get isReady(){return this.ternui?.isReady||!1}get isLoading(){return this.ternui?.isLoading||!1}get requiresVerification(){return this.options.requiresVerification??!0}get signIn(){if(this.ternui)return this.ternui.signIn||void 0}get signUp(){if(this.ternui)return this.ternui.signUp||void 0}get user(){return this.ternui?this.ternui.user:null}static getOrCreateInstance(e){return(!a()||!this.#e||e.TernSecureAuth&&this.#e.TernSecureAuth!==e.TernSecureAuth)&&(this.#e=new h(e)),this.#e}static clearInstances(){this.#e&&(this.#e.ternui=null,this.#e=null)}static clearInstance(){this.#e=null}get authDomain(){if(typeof window<"u"&&window.location)return(0,u.handleValueOrFn)(this.#i,new URL(window.location.href),"");if(typeof this.#i=="function")throw new Error("Unsupported customDomain type: function");return this.#i||""}get proxyUrl(){if(typeof window<"u"&&window.location)return(0,u.handleValueOrFn)(this.#n,new URL(window.location.href),"");if(typeof this.#n=="function")throw new Error("Unsupported customProxyUrl type: function");return this.#n||""}get mode(){return this._mode}_internal_getOption(e){return this.ternui?._internal_getOption?this.ternui?._internal_getOption(e):this.options[e]}_internal_getAllOptions(){return Object.freeze({...this.options})}constructor(e){const{TernSecureAuth:t=null,TernSecure:r=null}=e||{};this.#i=e.ternSecureConfig?.authDomain,this.options={...e},this._mode=a()?"browser":"server",this.#r=this.options.apiUrl,this.#n=this.options.proxyUrl,this.TernSecureAuth=t,this.TernSecure=r,this.options.sdkMetadata||(this.options.sdkMetadata=w),this.#r&&this.loadTernUI()}get sdkMetadata(){return this.ternui?.sdkMetadata||this.options.sdkMetadata}get version(){return this.ternui?.version}get instanceType(){return this.ternui?.instanceType}get apiUrl(){return this.#r||""}#o(){return new Promise(e=>{e(this.ternui)})}async loadTernUI(){if(!(this._mode!=="browser"||this.isReady)){typeof window<"u"&&(window._TernSecure_authDomain=this.authDomain,window._TernSecure_proxyUrl=this.proxyUrl,window._TernSecure_apiUrl=this.apiUrl);try{if(this.TernSecure){let e;(0,c.isConstructor)(this.TernSecure)?(e=new this.TernSecure(this.#r,{proxyUrl:this.proxyUrl,authDomain:this.authDomain}),this.beforeLoad(e),await e.load(this.options)):(e=this.TernSecure,e.isReady||(this.beforeLoad(e),await e.load(this.options))),global.TernSecure=e}else{if(global.TernSecure||await(0,d.loadTernUIScript)({...this.options,authDomain:this.authDomain,nonce:this.options.nonce}),!global.TernSecure)throw new Error("TernSecure instance is not available globally");this.beforeLoad(global.TernSecure),await global.TernSecure.load(this.options)}return global.TernSecure?.isReady?this.injectTernUI(global.TernSecure):void 0}catch(e){const t=e;console.error(t.stack||t.message||t);return}}}beforeLoad=e=>{if(!e)throw new Error("Failed to inject TernUI")};injectTernUI=e=>{if(!e)throw new Error("TernUI instance is not initialized");return this.ternui=e,this.premountState.methodCalls.forEach(t=>t()),this.preAddListener.forEach((t,r)=>{t.unsubscribe=e.addListener(r)}),this.#t.getListeners("status").forEach(t=>{this.on("status",t,{notify:!0})}),this.premountState.signInNodes.forEach((t,r)=>{e.showSignIn(r,t)}),this.premountState.signUpNodes.forEach((t,r)=>{e.showSignUp(r,t)}),typeof this.ternui.status>"u"&&(console.log("[IsomorphicTernSecure] TernUI has no status, setting internal status to ready"),this.#s="ready",this.#t.emit("status","ready"),console.log("[IsomorphicTernSecure] Set internal status to ready (ternui has no status)")),this.ternui};initTernSecureAuth(){if(this._mode!=="browser"||this.isReady)return;const e=TernSecureAuthImpl.initialize(this.options);this.loadTernSecureAuth(e)}loadTernSecureAuth=e=>{if(!e)throw new Error("TernAuth instance is not initialized");return this.ternauth=e,this.preAddListener.forEach((t,r)=>{t.unsubscribe=e.addListener(r)}),this.#t.getListeners("status").forEach(t=>{this.on("status",t,{notify:!0})}),typeof this.ternauth.status>"u"&&(console.log("[IsoTernSecureAuth] TernSecureAuth has no status, setting internal status to ready"),this.#s="ready",this.#t.emit(s.ternEvents.Status,"ready")),this.ternauth};on=(...e)=>this.ternui?.on?this.ternui.on(...e):this.#t.on(...e);off=(...e)=>this.ternui?.off?this.ternui.off(...e):this.#t.off(...e);addListener=e=>{if(this.ternui)return this.ternui.addListener(e);{const t=()=>{const r=this.preAddListener.get(e);r&&(r.unsubscribe(),this.preAddListener.delete(e))};return this.preAddListener.set(e,{unsubscribe:t}),t}};createActiveSession=e=>this.ternui?this.ternui.createActiveSession(e):Promise.reject(new Error("TernSecureAuth not initialized"));signOut=async e=>{if(!this.ternui)throw new Error("TernSecureAuth not initialized");await this.ternui.signOut()};get currentSession(){return this.ternui?this.ternui.currentSession:null}onAuthStateChanged(e){return this.ternui?this.ternui.onAuthStateChanged(e):(console.warn("[IsoTernSecureAuth] TernAuth not initialized, cannot set up auth state listener"),()=>{})}getRedirectResult=async()=>{if(!this.ternui?.getRedirectResult)throw new Error("TernSecure instance not initialized");return this.ternui.getRedirectResult()};constructUrlWithAuthRedirect=e=>this.ternui&&this.isReady?this.ternui.constructUrlWithAuthRedirect(e):"";constructAfterSignOutUrl=()=>{if(this.ternui&&this.isReady)return this.ternui.constructAfterSignOutUrl()||"";{const e=()=>this.ternui?.constructAfterSignOutUrl()||"";return this.premountState.methodCalls.set("constructAfterSignOutUrl",e),""}};navigate=e=>{this.ternui&&this.isReady&&this.ternui.navigate(e)};initialize=async()=>{try{await this.#o()}catch(e){throw console.error("[IsomorphicTernSecure] Failed to initialize TernUI:",e),e}};showSignIn=(e,t)=>{this.ternui&&this.isReady?this.ternui.showSignIn(e,t):this.premountState.signInNodes.set(e,t)};hideSignIn=e=>{this.ternui&&this.isReady?this.ternui.hideSignIn(e):this.premountState.signInNodes.delete(e)};showSignUp=(e,t)=>{this.ternui&&this.isReady?this.ternui.showSignUp(e,t):this.premountState.signUpNodes.set(e,t)};hideSignUp=e=>{this.ternui&&this.isReady?this.ternui.hideSignUp(e):this.premountState.signUpNodes.delete(e)};showUserButton=e=>{this.ternui&&this.isReady?this.ternui.showUserButton(e):this.premountState.userButttonNodes.set(e,void 0)};hideUserButton=e=>{this.ternui&&this.isReady?this.ternui.hideUserButton(e):this.premountState.userButttonNodes.delete(e)};redirectToSignIn=async e=>{this.ternui?.redirectToSignIn&&this.ternui.redirectToSignIn(e)};redirectToSignUp=async e=>{this.ternui?.redirectToSignUp&&this.ternui.redirectToSignUp()};redirectAfterSignIn=e=>{this.ternui?.redirectAfterSignIn&&this.ternui.redirectAfterSignIn()};redirectAfterSignUp=e=>{this.ternui?.redirectAfterSignUp&&this.ternui.redirectAfterSignUp()};#u(){return new Promise(e=>{e(this.ternauth)})}initializeAuth=async()=>{this.initTernSecureAuth();try{await this.#u()}catch(e){throw console.error("[IsomorphicTernSecure] Failed to initialize TernSecureAuth:",e),e}}}0&&(module.exports={IsoTernSecureAuth,inBrowser});
2
2
  //# sourceMappingURL=isoTernSecureAuth.js.map
@@ -1,2 +1,2 @@
1
- import{loadTernUIScript as o}from"@tern-secure/shared/loadTernUIScript";import{createTernAuthEventBus as u,ternEvents as a}from"@tern-secure/shared/ternStatusEvent";import{handleValueOrFn as i}from"@tern-secure/shared/utils";import{isConstructor as h}from"../utils/isConstructor";const d={name:"@tern-secure/react",version:"1.2.0-canary.v20251127221555",environment:process.env.NODE_ENV};function n(){return typeof window<"u"}class s{_mode;options;TernSecureAuth;TernSecure;ternauth=null;ternui=null;preAddListener=new Map;premountState={signInNodes:new Map,signUpNodes:new Map,userButttonNodes:new Map,verifyNodes:new Set,methodCalls:new Map,errorListeners:new Set};#s="loading";#r;#i;#n;#t=u();static#e;get status(){return this.ternui?this.ternui.status||(this.ternui.isReady?"ready":"loading"):this.#s}get isReady(){return this.ternui?.isReady||!1}get isLoading(){return this.ternui?.isLoading||!1}get requiresVerification(){return this.options.requiresVerification??!0}get signIn(){if(this.ternui)return this.ternui.signIn||void 0}get signUp(){if(this.ternui)return this.ternui.signUp||void 0}get user(){return this.ternui?this.ternui.user:null}static getOrCreateInstance(e){return(!n()||!this.#e||e.TernSecureAuth&&this.#e.TernSecureAuth!==e.TernSecureAuth)&&(this.#e=new s(e)),this.#e}static clearInstances(){this.#e&&(this.#e.ternui=null,this.#e=null)}static clearInstance(){this.#e=null}get authDomain(){if(typeof window<"u"&&window.location)return i(this.#i,new URL(window.location.href),"");if(typeof this.#i=="function")throw new Error("Unsupported customDomain type: function");return this.#i||""}get proxyUrl(){if(typeof window<"u"&&window.location)return i(this.#n,new URL(window.location.href),"");if(typeof this.#n=="function")throw new Error("Unsupported customProxyUrl type: function");return this.#n||""}get mode(){return this._mode}_internal_getOption(e){return this.ternui?._internal_getOption?this.ternui?._internal_getOption(e):this.options[e]}_internal_getAllOptions(){return Object.freeze({...this.options})}constructor(e){const{TernSecureAuth:t=null,TernSecure:r=null}=e||{};this.#i=e.ternSecureConfig?.authDomain,this.options={...e},this._mode=n()?"browser":"server",this.#r=this.options.apiUrl,this.#n=this.options.proxyUrl,this.TernSecureAuth=t,this.TernSecure=r,this.options.sdkMetadata||(this.options.sdkMetadata=d),this.#r&&this.loadTernUI()}get sdkMetadata(){return this.ternui?.sdkMetadata||this.options.sdkMetadata}get version(){return this.ternui?.version}get instanceType(){return this.ternui?.instanceType}get apiUrl(){return this.#r||""}#o(){return new Promise(e=>{e(this.ternui)})}async loadTernUI(){if(!(this._mode!=="browser"||this.isReady)){typeof window<"u"&&(window._TernSecure_authDomain=this.authDomain,window._TernSecure_proxyUrl=this.proxyUrl,window._TernSecure_apiUrl=this.apiUrl);try{if(this.TernSecure){let e;h(this.TernSecure)?(e=new this.TernSecure(this.#r,{proxyUrl:this.proxyUrl,authDomain:this.authDomain}),this.beforeLoad(e),await e.load(this.options)):(e=this.TernSecure,e.isReady||(this.beforeLoad(e),await e.load(this.options))),global.TernSecure=e}else{if(global.TernSecure||await o({...this.options,authDomain:this.authDomain,nonce:this.options.nonce}),!global.TernSecure)throw new Error("TernSecure instance is not available globally");this.beforeLoad(global.TernSecure),await global.TernSecure.load(this.options)}return global.TernSecure?.isReady?this.injectTernUI(global.TernSecure):void 0}catch(e){const t=e;console.error(t.stack||t.message||t);return}}}beforeLoad=e=>{if(!e)throw new Error("Failed to inject TernUI")};injectTernUI=e=>{if(!e)throw new Error("TernUI instance is not initialized");return this.ternui=e,this.premountState.methodCalls.forEach(t=>t()),this.preAddListener.forEach((t,r)=>{t.unsubscribe=e.addListener(r)}),this.#t.getListeners("status").forEach(t=>{this.on("status",t,{notify:!0})}),this.premountState.signInNodes.forEach((t,r)=>{e.showSignIn(r,t)}),this.premountState.signUpNodes.forEach((t,r)=>{e.showSignUp(r,t)}),typeof this.ternui.status>"u"&&(console.log("[IsomorphicTernSecure] TernUI has no status, setting internal status to ready"),this.#s="ready",this.#t.emit("status","ready"),console.log("[IsomorphicTernSecure] Set internal status to ready (ternui has no status)")),this.ternui};initTernSecureAuth(){if(this._mode!=="browser"||this.isReady)return;const e=TernSecureAuthImpl.initialize(this.options);this.loadTernSecureAuth(e)}loadTernSecureAuth=e=>{if(!e)throw new Error("TernAuth instance is not initialized");return this.ternauth=e,this.preAddListener.forEach((t,r)=>{t.unsubscribe=e.addListener(r)}),this.#t.getListeners("status").forEach(t=>{this.on("status",t,{notify:!0})}),typeof this.ternauth.status>"u"&&(console.log("[IsoTernSecureAuth] TernSecureAuth has no status, setting internal status to ready"),this.#s="ready",this.#t.emit(a.Status,"ready")),this.ternauth};on=(...e)=>this.ternui?.on?this.ternui.on(...e):this.#t.on(...e);off=(...e)=>this.ternui?.off?this.ternui.off(...e):this.#t.off(...e);addListener=e=>{if(this.ternui)return this.ternui.addListener(e);{const t=()=>{const r=this.preAddListener.get(e);r&&(r.unsubscribe(),this.preAddListener.delete(e))};return this.preAddListener.set(e,{unsubscribe:t}),t}};createActiveSession=e=>this.ternui?this.ternui.createActiveSession(e):Promise.reject(new Error("TernSecureAuth not initialized"));signOut=async e=>{if(!this.ternui)throw new Error("TernSecureAuth not initialized");await this.ternui.signOut()};get currentSession(){return this.ternui?this.ternui.currentSession:null}onAuthStateChanged(e){return this.ternui?this.ternui.onAuthStateChanged(e):(console.warn("[IsoTernSecureAuth] TernAuth not initialized, cannot set up auth state listener"),()=>{})}getRedirectResult=async()=>{if(!this.ternui?.getRedirectResult)throw new Error("TernSecure instance not initialized");return this.ternui.getRedirectResult()};constructUrlWithAuthRedirect=e=>this.ternui&&this.isReady?this.ternui.constructUrlWithAuthRedirect(e):"";constructAfterSignOutUrl=()=>{if(this.ternui&&this.isReady)return this.ternui.constructAfterSignOutUrl()||"";{const e=()=>this.ternui?.constructAfterSignOutUrl()||"";return this.premountState.methodCalls.set("constructAfterSignOutUrl",e),""}};navigate=e=>{this.ternui&&this.isReady&&this.ternui.navigate(e)};initialize=async()=>{try{await this.#o()}catch(e){throw console.error("[IsomorphicTernSecure] Failed to initialize TernUI:",e),e}};showSignIn=(e,t)=>{this.ternui&&this.isReady?this.ternui.showSignIn(e,t):this.premountState.signInNodes.set(e,t)};hideSignIn=e=>{this.ternui&&this.isReady?this.ternui.hideSignIn(e):this.premountState.signInNodes.delete(e)};showSignUp=(e,t)=>{this.ternui&&this.isReady?this.ternui.showSignUp(e,t):this.premountState.signUpNodes.set(e,t)};hideSignUp=e=>{this.ternui&&this.isReady?this.ternui.hideSignUp(e):this.premountState.signUpNodes.delete(e)};showUserButton=e=>{this.ternui&&this.isReady?this.ternui.showUserButton(e):this.premountState.userButttonNodes.set(e,void 0)};hideUserButton=e=>{this.ternui&&this.isReady?this.ternui.hideUserButton(e):this.premountState.userButttonNodes.delete(e)};redirectToSignIn=async e=>{this.ternui?.redirectToSignIn&&this.ternui.redirectToSignIn(e)};redirectToSignUp=async e=>{this.ternui?.redirectToSignUp&&this.ternui.redirectToSignUp()};redirectAfterSignIn=e=>{this.ternui?.redirectAfterSignIn&&this.ternui.redirectAfterSignIn()};redirectAfterSignUp=e=>{this.ternui?.redirectAfterSignUp&&this.ternui.redirectAfterSignUp()};#u(){return new Promise(e=>{e(this.ternauth)})}initializeAuth=async()=>{this.initTernSecureAuth();try{await this.#u()}catch(e){throw console.error("[IsomorphicTernSecure] Failed to initialize TernSecureAuth:",e),e}}}export{s as IsoTernSecureAuth,n as inBrowser};
1
+ import{loadTernUIScript as o}from"@tern-secure/shared/loadTernUIScript";import{createTernAuthEventBus as u,ternEvents as a}from"@tern-secure/shared/ternStatusEvent";import{handleValueOrFn as i}from"@tern-secure/shared/utils";import{isConstructor as h}from"../utils/isConstructor";const d={name:"@tern-secure/react",version:"1.2.0-canary.v20251202162458",environment:process.env.NODE_ENV};function n(){return typeof window<"u"}class s{_mode;options;TernSecureAuth;TernSecure;ternauth=null;ternui=null;preAddListener=new Map;premountState={signInNodes:new Map,signUpNodes:new Map,userButttonNodes:new Map,verifyNodes:new Set,methodCalls:new Map,errorListeners:new Set};#s="loading";#r;#i;#n;#t=u();static#e;get status(){return this.ternui?this.ternui.status||(this.ternui.isReady?"ready":"loading"):this.#s}get isReady(){return this.ternui?.isReady||!1}get isLoading(){return this.ternui?.isLoading||!1}get requiresVerification(){return this.options.requiresVerification??!0}get signIn(){if(this.ternui)return this.ternui.signIn||void 0}get signUp(){if(this.ternui)return this.ternui.signUp||void 0}get user(){return this.ternui?this.ternui.user:null}static getOrCreateInstance(e){return(!n()||!this.#e||e.TernSecureAuth&&this.#e.TernSecureAuth!==e.TernSecureAuth)&&(this.#e=new s(e)),this.#e}static clearInstances(){this.#e&&(this.#e.ternui=null,this.#e=null)}static clearInstance(){this.#e=null}get authDomain(){if(typeof window<"u"&&window.location)return i(this.#i,new URL(window.location.href),"");if(typeof this.#i=="function")throw new Error("Unsupported customDomain type: function");return this.#i||""}get proxyUrl(){if(typeof window<"u"&&window.location)return i(this.#n,new URL(window.location.href),"");if(typeof this.#n=="function")throw new Error("Unsupported customProxyUrl type: function");return this.#n||""}get mode(){return this._mode}_internal_getOption(e){return this.ternui?._internal_getOption?this.ternui?._internal_getOption(e):this.options[e]}_internal_getAllOptions(){return Object.freeze({...this.options})}constructor(e){const{TernSecureAuth:t=null,TernSecure:r=null}=e||{};this.#i=e.ternSecureConfig?.authDomain,this.options={...e},this._mode=n()?"browser":"server",this.#r=this.options.apiUrl,this.#n=this.options.proxyUrl,this.TernSecureAuth=t,this.TernSecure=r,this.options.sdkMetadata||(this.options.sdkMetadata=d),this.#r&&this.loadTernUI()}get sdkMetadata(){return this.ternui?.sdkMetadata||this.options.sdkMetadata}get version(){return this.ternui?.version}get instanceType(){return this.ternui?.instanceType}get apiUrl(){return this.#r||""}#o(){return new Promise(e=>{e(this.ternui)})}async loadTernUI(){if(!(this._mode!=="browser"||this.isReady)){typeof window<"u"&&(window._TernSecure_authDomain=this.authDomain,window._TernSecure_proxyUrl=this.proxyUrl,window._TernSecure_apiUrl=this.apiUrl);try{if(this.TernSecure){let e;h(this.TernSecure)?(e=new this.TernSecure(this.#r,{proxyUrl:this.proxyUrl,authDomain:this.authDomain}),this.beforeLoad(e),await e.load(this.options)):(e=this.TernSecure,e.isReady||(this.beforeLoad(e),await e.load(this.options))),global.TernSecure=e}else{if(global.TernSecure||await o({...this.options,authDomain:this.authDomain,nonce:this.options.nonce}),!global.TernSecure)throw new Error("TernSecure instance is not available globally");this.beforeLoad(global.TernSecure),await global.TernSecure.load(this.options)}return global.TernSecure?.isReady?this.injectTernUI(global.TernSecure):void 0}catch(e){const t=e;console.error(t.stack||t.message||t);return}}}beforeLoad=e=>{if(!e)throw new Error("Failed to inject TernUI")};injectTernUI=e=>{if(!e)throw new Error("TernUI instance is not initialized");return this.ternui=e,this.premountState.methodCalls.forEach(t=>t()),this.preAddListener.forEach((t,r)=>{t.unsubscribe=e.addListener(r)}),this.#t.getListeners("status").forEach(t=>{this.on("status",t,{notify:!0})}),this.premountState.signInNodes.forEach((t,r)=>{e.showSignIn(r,t)}),this.premountState.signUpNodes.forEach((t,r)=>{e.showSignUp(r,t)}),typeof this.ternui.status>"u"&&(console.log("[IsomorphicTernSecure] TernUI has no status, setting internal status to ready"),this.#s="ready",this.#t.emit("status","ready"),console.log("[IsomorphicTernSecure] Set internal status to ready (ternui has no status)")),this.ternui};initTernSecureAuth(){if(this._mode!=="browser"||this.isReady)return;const e=TernSecureAuthImpl.initialize(this.options);this.loadTernSecureAuth(e)}loadTernSecureAuth=e=>{if(!e)throw new Error("TernAuth instance is not initialized");return this.ternauth=e,this.preAddListener.forEach((t,r)=>{t.unsubscribe=e.addListener(r)}),this.#t.getListeners("status").forEach(t=>{this.on("status",t,{notify:!0})}),typeof this.ternauth.status>"u"&&(console.log("[IsoTernSecureAuth] TernSecureAuth has no status, setting internal status to ready"),this.#s="ready",this.#t.emit(a.Status,"ready")),this.ternauth};on=(...e)=>this.ternui?.on?this.ternui.on(...e):this.#t.on(...e);off=(...e)=>this.ternui?.off?this.ternui.off(...e):this.#t.off(...e);addListener=e=>{if(this.ternui)return this.ternui.addListener(e);{const t=()=>{const r=this.preAddListener.get(e);r&&(r.unsubscribe(),this.preAddListener.delete(e))};return this.preAddListener.set(e,{unsubscribe:t}),t}};createActiveSession=e=>this.ternui?this.ternui.createActiveSession(e):Promise.reject(new Error("TernSecureAuth not initialized"));signOut=async e=>{if(!this.ternui)throw new Error("TernSecureAuth not initialized");await this.ternui.signOut()};get currentSession(){return this.ternui?this.ternui.currentSession:null}onAuthStateChanged(e){return this.ternui?this.ternui.onAuthStateChanged(e):(console.warn("[IsoTernSecureAuth] TernAuth not initialized, cannot set up auth state listener"),()=>{})}getRedirectResult=async()=>{if(!this.ternui?.getRedirectResult)throw new Error("TernSecure instance not initialized");return this.ternui.getRedirectResult()};constructUrlWithAuthRedirect=e=>this.ternui&&this.isReady?this.ternui.constructUrlWithAuthRedirect(e):"";constructAfterSignOutUrl=()=>{if(this.ternui&&this.isReady)return this.ternui.constructAfterSignOutUrl()||"";{const e=()=>this.ternui?.constructAfterSignOutUrl()||"";return this.premountState.methodCalls.set("constructAfterSignOutUrl",e),""}};navigate=e=>{this.ternui&&this.isReady&&this.ternui.navigate(e)};initialize=async()=>{try{await this.#o()}catch(e){throw console.error("[IsomorphicTernSecure] Failed to initialize TernUI:",e),e}};showSignIn=(e,t)=>{this.ternui&&this.isReady?this.ternui.showSignIn(e,t):this.premountState.signInNodes.set(e,t)};hideSignIn=e=>{this.ternui&&this.isReady?this.ternui.hideSignIn(e):this.premountState.signInNodes.delete(e)};showSignUp=(e,t)=>{this.ternui&&this.isReady?this.ternui.showSignUp(e,t):this.premountState.signUpNodes.set(e,t)};hideSignUp=e=>{this.ternui&&this.isReady?this.ternui.hideSignUp(e):this.premountState.signUpNodes.delete(e)};showUserButton=e=>{this.ternui&&this.isReady?this.ternui.showUserButton(e):this.premountState.userButttonNodes.set(e,void 0)};hideUserButton=e=>{this.ternui&&this.isReady?this.ternui.hideUserButton(e):this.premountState.userButttonNodes.delete(e)};redirectToSignIn=async e=>{this.ternui?.redirectToSignIn&&this.ternui.redirectToSignIn(e)};redirectToSignUp=async e=>{this.ternui?.redirectToSignUp&&this.ternui.redirectToSignUp()};redirectAfterSignIn=e=>{this.ternui?.redirectAfterSignIn&&this.ternui.redirectAfterSignIn()};redirectAfterSignUp=e=>{this.ternui?.redirectAfterSignUp&&this.ternui.redirectAfterSignUp()};#u(){return new Promise(e=>{e(this.ternauth)})}initializeAuth=async()=>{this.initTernSecureAuth();try{await this.#u()}catch(e){throw console.error("[IsomorphicTernSecure] Failed to initialize TernSecureAuth:",e),e}}}export{s as IsoTernSecureAuth,n as inBrowser};
2
2
  //# sourceMappingURL=isoTernSecureAuth.mjs.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tern-secure/react",
3
- "version": "1.2.0-canary.v20251127221555",
3
+ "version": "1.2.0-canary.v20251202162458",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "git+https://github.com/TernSecure/auth.git",
@@ -36,8 +36,8 @@
36
36
  "tailwind-merge": "^2.5.5",
37
37
  "tailwindcss-animate": "^1.0.7",
38
38
  "tslib": "2.8.1",
39
- "@tern-secure/shared": "1.3.0-canary.v20251127221555",
40
- "@tern-secure/types": "1.1.0-canary.v20251127221555"
39
+ "@tern-secure/shared": "1.3.0-canary.v20251202162458",
40
+ "@tern-secure/types": "1.1.0-canary.v20251202162458"
41
41
  },
42
42
  "devDependencies": {
43
43
  "@tailwindcss/cli": "^4.1.6",