@tern-secure/nextjs 3.1.66 → 3.1.68

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.
Files changed (52) hide show
  1. package/dist/cjs/app-router/client/TernSecureProvider.cjs +14 -91
  2. package/dist/cjs/app-router/client/TernSecureProvider.cjs.map +1 -1
  3. package/dist/cjs/app-router/server/TernSecureServerProvider.cjs +3 -101
  4. package/dist/cjs/app-router/server/TernSecureServerProvider.cjs.map +1 -1
  5. package/dist/cjs/app-router/server/auth.cjs +13 -54
  6. package/dist/cjs/app-router/server/auth.cjs.map +1 -1
  7. package/dist/cjs/boundary/hooks/useAuth.cjs +53 -70
  8. package/dist/cjs/boundary/hooks/useAuth.cjs.map +1 -1
  9. package/dist/cjs/components/sign-in.cjs +13 -54
  10. package/dist/cjs/components/sign-in.cjs.map +1 -1
  11. package/dist/cjs/index.cjs +74 -105
  12. package/dist/cjs/index.cjs.map +1 -1
  13. package/dist/cjs/utils/client-init.cjs +16 -59
  14. package/dist/cjs/utils/client-init.cjs.map +1 -1
  15. package/dist/esm/app-router/client/TernSecureProvider.d.ts +7 -13
  16. package/dist/esm/app-router/client/TernSecureProvider.js +1 -4
  17. package/dist/esm/app-router/server/TernSecureServerProvider.js +2 -5
  18. package/dist/esm/app-router/server/auth.js +2 -3
  19. package/dist/esm/boundary/TernSecureCtx.js +22 -1
  20. package/dist/esm/boundary/TernSecureCtx.js.map +1 -1
  21. package/dist/esm/boundary/hooks/useAuth.d.ts +10 -5
  22. package/dist/esm/boundary/hooks/useAuth.js +3 -5
  23. package/dist/esm/chunk-4UKPQO2Q.js +40 -0
  24. package/dist/esm/chunk-4UKPQO2Q.js.map +1 -0
  25. package/dist/esm/chunk-6M2XYDPF.js +13 -0
  26. package/dist/esm/chunk-6M2XYDPF.js.map +1 -0
  27. package/dist/esm/chunk-CGDSGC2H.js +22 -0
  28. package/dist/esm/chunk-CGDSGC2H.js.map +1 -0
  29. package/dist/esm/chunk-KVOT4326.js +29 -0
  30. package/dist/esm/chunk-KVOT4326.js.map +1 -0
  31. package/dist/esm/{chunk-EIOZNLP2.js → chunk-VZHZK7NN.js} +3 -3
  32. package/dist/esm/{chunk-EIOZNLP2.js.map → chunk-VZHZK7NN.js.map} +1 -1
  33. package/dist/esm/{chunk-NZSUADHV.js → chunk-ZSK4FOWY.js} +4 -10
  34. package/dist/esm/chunk-ZSK4FOWY.js.map +1 -0
  35. package/dist/esm/components/sign-in.js +3 -4
  36. package/dist/esm/index.d.ts +1 -3
  37. package/dist/esm/index.js +6 -7
  38. package/dist/esm/index.js.map +1 -1
  39. package/dist/esm/utils/client-init.d.ts +3 -5
  40. package/dist/esm/utils/client-init.js +1 -2
  41. package/package.json +1 -1
  42. package/dist/esm/chunk-4XFIX4FL.js +0 -14
  43. package/dist/esm/chunk-4XFIX4FL.js.map +0 -1
  44. package/dist/esm/chunk-7N2WA6V3.js +0 -21
  45. package/dist/esm/chunk-7N2WA6V3.js.map +0 -1
  46. package/dist/esm/chunk-FVV74XVR.js +0 -19
  47. package/dist/esm/chunk-FVV74XVR.js.map +0 -1
  48. package/dist/esm/chunk-NZSUADHV.js.map +0 -1
  49. package/dist/esm/chunk-WCTFYLDR.js +0 -45
  50. package/dist/esm/chunk-WCTFYLDR.js.map +0 -1
  51. package/dist/esm/chunk-YOHK2WGW.js +0 -25
  52. package/dist/esm/chunk-YOHK2WGW.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/app-router/server/TernSecureServerProvider.tsx"],"names":[],"mappings":";;;;AAMA,SAAS,yBAA4B,GAAA;AACnC,EACE,uBAAA,GAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,YAAW,EAAA,wBAAA;AAAA,MACX,IAAK,EAAA,QAAA;AAAA,MACL,SAAU,EAAA,qBAAA;AAAA,MAEV,QAAC,kBAAA,GAAA,CAAA,MAAA,EAAA,EAAK,SAAU,EAAA,SAAA,EAAU,QAAyB,EAAA,2BAAA,EAAA;AAAA;AAAA,GACrD;AAEJ;AA2BO,SAAS,wBAAyB,CAAA;AAAA,EACvC;AACF,CAAkC,EAAA;AAChC,EAAA,MAAM,YAAgC,GAAA;AAAA,IACpC,OAAS,EAAA,IAAA;AAAA,IACT,UAAY,EAAA,KAAA;AAAA,IACZ,MAAQ,EAAA,IAAA;AAAA,IACR,KAAO,EAAA;AAAA,GACT;AAEA,EAAA,uBACG,GAAA,CAAA,KAAA,CAAM,QAAN,EAAA,EAAe,QAAU,kBAAA,GAAA,CAAC,yBAA0B,EAAA,EAAA,CAAA,EAEnD,QAAC,kBAAA,GAAA,CAAA,wBAAA,EAAA,EAAyB,YACvB,EAAA,QAAA,EACH,CACF,EAAA,CAAA;AAEJ","file":"chunk-NZSUADHV.js","sourcesContent":["import React from \"react\"\r\nimport { TernSecureClientProvider, TernSecureState } from \"../client/TernSecureProvider\"\r\n\r\n\r\n\r\n// Loading fallback component\r\nfunction TernSecureLoadingFallback() {\r\n return (\r\n <div \r\n aria-label=\"Loading authentication\" \r\n role=\"status\"\r\n className=\"tern-secure-loading\"\r\n >\r\n <span className=\"sr-only\">Loading authentication...</span>\r\n </div>\r\n )\r\n}\r\n\r\ninterface TernSecureServerProviderProps {\r\n children: React.ReactNode\r\n}\r\n\r\n/**\r\n * Root Provider for TernSecure\r\n * Use this in your Next.js App Router root layout\r\n * Automatically handles client/server boundary and authentication state\r\n * \r\n * @example\r\n * // app/layout.tsx\r\n * import { TernSecureProvider } from '@tern/secure'\r\n * \r\n * export default function RootLayout({ children }) {\r\n * return (\r\n * <html>\r\n * <body>\r\n * <TernSecureProvider>\r\n * {children}\r\n * </TernSecureProvider>\r\n * </body>\r\n * </html>\r\n * )\r\n * }\r\n */\r\nexport function TernSecureServerProvider({ \r\n children \r\n}: TernSecureServerProviderProps) {\r\n const initialState: TernSecureState = {\r\n loading: true,\r\n isSignedIn: false,\r\n userId: null,\r\n error: null\r\n }\r\n\r\n return (\r\n <React.Suspense fallback={<TernSecureLoadingFallback />}>\r\n {/* Add use client directive */}\r\n <TernSecureClientProvider initialState={initialState}>\r\n {children}\r\n </TernSecureClientProvider>\r\n </React.Suspense>\r\n )\r\n}\r\n\r\n// Export types for internal use\r\nexport type { TernSecureServerProviderProps }"]}
@@ -1,45 +0,0 @@
1
- import { TernSecureCtxProvider } from './chunk-YOHK2WGW.js';
2
- import { TernSecureAuth } from './chunk-FVV74XVR.js';
3
- import { createContext, useState, useEffect } from 'react';
4
- import { onAuthStateChanged } from 'firebase/auth';
5
- import { jsxs } from 'react/jsx-runtime';
6
-
7
- var AuthStateContext = createContext(null);
8
- var auth = TernSecureAuth();
9
- function TernSecureClientProvider({
10
- children,
11
- initialState
12
- }) {
13
- const [authState, setAuthState] = useState(initialState);
14
- useEffect(() => {
15
- const unsubscribe = onAuthStateChanged(auth, (user) => {
16
- if (user) {
17
- setAuthState({
18
- loading: false,
19
- isSignedIn: !!user,
20
- userId: user.uid,
21
- error: null
22
- });
23
- } else {
24
- setAuthState({
25
- loading: false,
26
- isSignedIn: false,
27
- userId: null,
28
- error: null
29
- });
30
- }
31
- });
32
- return () => unsubscribe();
33
- }, []);
34
- return /* @__PURE__ */ jsxs(TernSecureCtxProvider, { children: [
35
- " ",
36
- /* @__PURE__ */ jsxs(AuthStateContext.Provider, { value: authState, children: [
37
- " ",
38
- children
39
- ] })
40
- ] });
41
- }
42
-
43
- export { AuthStateContext, TernSecureClientProvider };
44
- //# sourceMappingURL=chunk-WCTFYLDR.js.map
45
- //# sourceMappingURL=chunk-WCTFYLDR.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/app-router/client/TernSecureProvider.tsx"],"names":[],"mappings":";;;;;;AAca,IAAA,gBAAA,GAAmB,cAAsC,IAAI;AAO1E,IAAM,OAAO,cAAe,EAAA;AAErB,SAAS,wBAAyB,CAAA;AAAA,EACvC,QAAA;AAAA,EACA;AACD,CAA0B,EAAA;AACzB,EAAA,MAAM,CAAC,SAAA,EAAW,YAAY,CAAA,GAAI,SAAS,YAAY,CAAA;AAEzD,EAAA,SAAA,CAAU,MAAM;AACZ,IAAA,MAAM,WAAc,GAAA,kBAAA,CAAmB,IAAM,EAAA,CAAC,IAAS,KAAA;AACrD,MAAA,IAAI,IAAM,EAAA;AACR,QAAa,YAAA,CAAA;AAAA,UACX,OAAS,EAAA,KAAA;AAAA,UACT,UAAA,EAAY,CAAC,CAAC,IAAA;AAAA,UACd,QAAQ,IAAK,CAAA,GAAA;AAAA,UACb,KAAO,EAAA;AAAA,SACR,CAAA;AAAA,OACI,MAAA;AACL,QAAa,YAAA,CAAA;AAAA,UACX,OAAS,EAAA,KAAA;AAAA,UACT,UAAY,EAAA,KAAA;AAAA,UACZ,MAAQ,EAAA,IAAA;AAAA,UACR,KAAO,EAAA;AAAA,SACR,CAAA;AAAA;AACH,KACD,CAAA;AAED,IAAA,OAAO,MAAM,WAAY,EAAA;AAAA,GAC3B,EAAG,EAAE,CAAA;AAGL,EAAA,4BACG,qBAAsB,EAAA,EAAA,QAAA,EAAA;AAAA,IAAA,GAAA;AAAA,oBACpB,IAAA,CAAA,gBAAA,CAAiB,QAAjB,EAAA,EAA0B,OAAO,SAAW,EAAA,QAAA,EAAA;AAAA,MAAA,GAAA;AAAA,MAC5C;AAAA,KACD,EAAA;AAAA,GACF,EAAA,CAAA;AAEJ","file":"chunk-WCTFYLDR.js","sourcesContent":["'use client'\r\n\r\nimport { createContext, useState, useEffect} from 'react'\r\nimport { TernSecureAuth } from '../../utils/client-init'\r\nimport { onAuthStateChanged } from \"firebase/auth\"\r\nimport { TernSecureCtxProvider } from '../../boundary/TernSecureCtx'\r\n\r\nexport type TernSecureState = {\r\n userId: string | null\r\n loading: boolean\r\n error: string | null\r\n isSignedIn: boolean\r\n}\r\n\r\nexport const AuthStateContext = createContext<TernSecureState | null>(null)\r\n\r\ninterface TernSecureClientProps {\r\n children: React.ReactNode\r\n initialState: TernSecureState\r\n}\r\n\r\nconst auth = TernSecureAuth();\r\n\r\nexport function TernSecureClientProvider({ \r\n children,\r\n initialState\r\n }: TernSecureClientProps) {\r\n const [authState, setAuthState] = useState(initialState)\r\n\r\nuseEffect(() => {\r\n const unsubscribe = onAuthStateChanged(auth, (user) => {\r\n if (user) {\r\n setAuthState({\r\n loading: false,\r\n isSignedIn: !!user,\r\n userId: user.uid,\r\n error: null\r\n })\r\n } else {\r\n setAuthState({\r\n loading: false,\r\n isSignedIn: false,\r\n userId: null,\r\n error: null\r\n })\r\n }\r\n })\r\n \r\n return () => unsubscribe()\r\n }, [])\r\n\r\n\r\n return (\r\n <TernSecureCtxProvider> {/* Handles global Tern configuration */}\r\n <AuthStateContext.Provider value={authState}> {/* Handles auth state */}\r\n {children}\r\n </AuthStateContext.Provider>\r\n </TernSecureCtxProvider>\r\n )\r\n}"]}
@@ -1,25 +0,0 @@
1
- import { createContext, useContext } from 'react';
2
- import { jsx } from 'react/jsx-runtime';
3
-
4
- // src/boundary/TernSecureCtx.tsx
5
- var INTERNAL_CONTEXT_KEY = Symbol("TERN_SECURE_CONTEXT");
6
- var TernSecureContext = createContext(null);
7
- TernSecureContext.displayName = "TernSecureContext";
8
- var useInternalContext = (hookname) => {
9
- const context = useContext(TernSecureContext);
10
- if (!context) {
11
- throw new Error(
12
- `${hookname} must be used within TernSecureProvider`
13
- );
14
- }
15
- return context;
16
- };
17
- function TernSecureCtxProvider({ children }) {
18
- return /* @__PURE__ */ jsx(TernSecureContext.Provider, { value: {
19
- _contextKey: INTERNAL_CONTEXT_KEY
20
- }, children });
21
- }
22
-
23
- export { TernSecureCtxProvider, useInternalContext };
24
- //# sourceMappingURL=chunk-YOHK2WGW.js.map
25
- //# sourceMappingURL=chunk-YOHK2WGW.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/boundary/TernSecureCtx.tsx"],"names":[],"mappings":";;;;AAUA,IAAM,oBAAA,GAAuB,OAAO,qBAAqB,CAAA;AACzD,IAAM,iBAAA,GAAoB,cAAyC,IAAI,CAAA;AAGvE,iBAAA,CAAkB,WAAc,GAAA,mBAAA;AAEnB,IAAA,kBAAA,GAAqB,CAAC,QAAqB,KAAA;AAEtD,EAAM,MAAA,OAAA,GAAU,WAAW,iBAAiB,CAAA;AAE5C,EAAA,IAAI,CAAC,OAAS,EAAA;AACZ,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,GAAG,QAAQ,CAAA,uCAAA;AAAA,KACb;AAAA;AAGF,EAAO,OAAA,OAAA;AACT;AAMO,SAAS,qBAAA,CAAsB,EAAE,QAAA,EAA2C,EAAA;AACjF,EAAA,uBACG,GAAA,CAAA,iBAAA,CAAkB,QAAlB,EAAA,EAA2B,KAAO,EAAA;AAAA,IACjC,WAAa,EAAA;AAAA,KAEZ,QACH,EAAA,CAAA;AAEJ","file":"chunk-YOHK2WGW.js","sourcesContent":["'use client'\r\n\r\nimport { createContext, useContext} from 'react'\r\n\r\n// Core types\r\nexport type TernSecureCtxValue = {\r\n _contextKey: Symbol\r\n}\r\n\r\n// Context with proper null handling\r\nconst INTERNAL_CONTEXT_KEY = Symbol('TERN_SECURE_CONTEXT')\r\nconst TernSecureContext = createContext<TernSecureCtxValue | null>(null)\r\n\r\n// Set display name for better debugging\r\nTernSecureContext.displayName = 'TernSecureContext'\r\n\r\nexport const useInternalContext = (hookname: string) => {\r\n\r\n const context = useContext(TernSecureContext)\r\n \r\n if (!context) {\r\n throw new Error(\r\n `${hookname} must be used within TernSecureProvider`\r\n )\r\n }\r\n\r\n return context\r\n}\r\n\r\n/**\r\n * Provider component for TernSecure\r\n * Must be used in client components only\r\n */\r\nexport function TernSecureCtxProvider({ children }: { children: React.ReactNode }) {\r\n return (\r\n <TernSecureContext.Provider value={{\r\n _contextKey: INTERNAL_CONTEXT_KEY \r\n }}>\r\n {children}\r\n </TernSecureContext.Provider>\r\n )\r\n}"]}