@tern-secure/nextjs 3.1.75 → 3.1.77

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 (102) hide show
  1. package/dist/cjs/app-router/client/TernSecureProvider.js +75 -0
  2. package/dist/cjs/app-router/client/TernSecureProvider.js.map +1 -0
  3. package/dist/cjs/app-router/server/TernSecureServerProvider.js +63 -0
  4. package/dist/cjs/app-router/server/TernSecureServerProvider.js.map +1 -0
  5. package/dist/cjs/app-router/server/auth.js +37 -0
  6. package/dist/cjs/app-router/server/auth.js.map +1 -0
  7. package/dist/cjs/boundary/TernSecureCtx.js +50 -0
  8. package/dist/cjs/boundary/TernSecureCtx.js.map +1 -0
  9. package/dist/cjs/boundary/hooks/useAuth.js +45 -0
  10. package/dist/cjs/boundary/hooks/useAuth.js.map +1 -0
  11. package/dist/cjs/components/sign-in.js +132 -0
  12. package/dist/cjs/components/sign-in.js.map +1 -0
  13. package/dist/cjs/errors.js +41 -0
  14. package/dist/cjs/errors.js.map +1 -0
  15. package/dist/cjs/index.js +49 -0
  16. package/dist/cjs/index.js.map +1 -0
  17. package/dist/cjs/types.js +17 -0
  18. package/dist/cjs/types.js.map +1 -0
  19. package/dist/cjs/utils/client-init.js +46 -0
  20. package/dist/cjs/utils/client-init.js.map +1 -0
  21. package/dist/cjs/utils/config.js +73 -0
  22. package/dist/cjs/utils/config.js.map +1 -0
  23. package/dist/cjs/utils/{create-styles.cjs → create-styles.js} +38 -14
  24. package/dist/cjs/utils/create-styles.js.map +1 -0
  25. package/dist/esm/app-router/client/TernSecureProvider.js +39 -5
  26. package/dist/esm/app-router/client/TernSecureProvider.js.map +1 -1
  27. package/dist/esm/app-router/server/TernSecureServerProvider.js +28 -6
  28. package/dist/esm/app-router/server/TernSecureServerProvider.js.map +1 -1
  29. package/dist/esm/app-router/server/auth.js +12 -4
  30. package/dist/esm/app-router/server/auth.js.map +1 -1
  31. package/dist/esm/boundary/TernSecureCtx.js +24 -2
  32. package/dist/esm/boundary/TernSecureCtx.js.map +1 -1
  33. package/dist/esm/boundary/hooks/useAuth.js +20 -3
  34. package/dist/esm/boundary/hooks/useAuth.js.map +1 -1
  35. package/dist/esm/components/sign-in.js +107 -6
  36. package/dist/esm/components/sign-in.js.map +1 -1
  37. package/dist/esm/errors.js +6 -6
  38. package/dist/esm/errors.js.map +1 -1
  39. package/dist/esm/index.js +17 -10
  40. package/dist/esm/index.js.map +1 -1
  41. package/dist/esm/types.js +0 -2
  42. package/dist/esm/types.js.map +1 -1
  43. package/dist/esm/utils/client-init.js +19 -3
  44. package/dist/esm/utils/client-init.js.map +1 -1
  45. package/dist/esm/utils/config.js +46 -2
  46. package/dist/esm/utils/config.js.map +1 -1
  47. package/dist/esm/utils/create-styles.js +122 -2
  48. package/dist/esm/utils/create-styles.js.map +1 -1
  49. package/package.json +2 -14
  50. package/dist/cjs/app-router/client/TernSecureProvider.cjs +0 -84
  51. package/dist/cjs/app-router/client/TernSecureProvider.cjs.map +0 -1
  52. package/dist/cjs/app-router/server/TernSecureServerProvider.cjs +0 -95
  53. package/dist/cjs/app-router/server/TernSecureServerProvider.cjs.map +0 -1
  54. package/dist/cjs/app-router/server/auth.cjs +0 -71
  55. package/dist/cjs/app-router/server/auth.cjs.map +0 -1
  56. package/dist/cjs/boundary/TernSecureCtx.cjs +0 -17
  57. package/dist/cjs/boundary/TernSecureCtx.cjs.map +0 -1
  58. package/dist/cjs/boundary/hooks/useAuth.cjs +0 -30
  59. package/dist/cjs/boundary/hooks/useAuth.cjs.map +0 -1
  60. package/dist/cjs/components/sign-in.cjs +0 -291
  61. package/dist/cjs/components/sign-in.cjs.map +0 -1
  62. package/dist/cjs/errors.cjs +0 -19
  63. package/dist/cjs/errors.cjs.map +0 -1
  64. package/dist/cjs/index.cjs +0 -349
  65. package/dist/cjs/index.cjs.map +0 -1
  66. package/dist/cjs/types.cjs +0 -4
  67. package/dist/cjs/types.cjs.map +0 -1
  68. package/dist/cjs/utils/client-init.cjs +0 -68
  69. package/dist/cjs/utils/client-init.cjs.map +0 -1
  70. package/dist/cjs/utils/config.cjs +0 -50
  71. package/dist/cjs/utils/config.cjs.map +0 -1
  72. package/dist/cjs/utils/create-styles.cjs.map +0 -1
  73. package/dist/esm/app-router/client/TernSecureProvider.d.ts +0 -16
  74. package/dist/esm/app-router/server/TernSecureServerProvider.d.ts +0 -9
  75. package/dist/esm/app-router/server/auth.d.ts +0 -9
  76. package/dist/esm/boundary/TernSecureCtx.d.ts +0 -10
  77. package/dist/esm/boundary/hooks/useAuth.d.ts +0 -6
  78. package/dist/esm/chunk-27O3JVAU.js +0 -16
  79. package/dist/esm/chunk-27O3JVAU.js.map +0 -1
  80. package/dist/esm/chunk-4XFIX4FL.js +0 -14
  81. package/dist/esm/chunk-4XFIX4FL.js.map +0 -1
  82. package/dist/esm/chunk-7VKPI5HF.js +0 -15
  83. package/dist/esm/chunk-7VKPI5HF.js.map +0 -1
  84. package/dist/esm/chunk-EI37GOD7.js +0 -121
  85. package/dist/esm/chunk-EI37GOD7.js.map +0 -1
  86. package/dist/esm/chunk-EIOZNLP2.js +0 -109
  87. package/dist/esm/chunk-EIOZNLP2.js.map +0 -1
  88. package/dist/esm/chunk-FVV74XVR.js +0 -19
  89. package/dist/esm/chunk-FVV74XVR.js.map +0 -1
  90. package/dist/esm/chunk-ODVOZOJG.js +0 -28
  91. package/dist/esm/chunk-ODVOZOJG.js.map +0 -1
  92. package/dist/esm/chunk-SHRRIEFY.js +0 -19
  93. package/dist/esm/chunk-SHRRIEFY.js.map +0 -1
  94. package/dist/esm/chunk-UHGBSUM6.js +0 -46
  95. package/dist/esm/chunk-UHGBSUM6.js.map +0 -1
  96. package/dist/esm/components/sign-in.d.ts +0 -25
  97. package/dist/esm/errors.d.ts +0 -10
  98. package/dist/esm/index.d.ts +0 -15
  99. package/dist/esm/types.d.ts +0 -49
  100. package/dist/esm/utils/client-init.d.ts +0 -9
  101. package/dist/esm/utils/config.d.ts +0 -22
  102. package/dist/esm/utils/create-styles.d.ts +0 -100
@@ -1,3 +1,47 @@
1
- export { initializeConfig, loadFireConfig, validateConfig } from '../chunk-UHGBSUM6.js';
2
- //# sourceMappingURL=config.js.map
1
+ const loadFireConfig = () => ({
2
+ apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || "",
3
+ authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || "",
4
+ projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || "",
5
+ storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || "",
6
+ messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || "",
7
+ appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || "",
8
+ measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || void 0
9
+ });
10
+ const validateConfig = (config) => {
11
+ const requiredFields = [
12
+ "apiKey",
13
+ "authDomain",
14
+ "projectId",
15
+ "storageBucket",
16
+ "messagingSenderId",
17
+ "appId"
18
+ ];
19
+ const errors = [];
20
+ requiredFields.forEach((field) => {
21
+ if (!config[field]) {
22
+ errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`);
23
+ }
24
+ });
25
+ return {
26
+ isValid: errors.length === 0,
27
+ errors,
28
+ config
29
+ };
30
+ };
31
+ const initializeConfig = () => {
32
+ const config = loadFireConfig();
33
+ const validationResult = validateConfig(config);
34
+ if (!validationResult.isValid) {
35
+ throw new Error(
36
+ `Firebase configuration validation failed:
37
+ ${validationResult.errors.join("\n")}`
38
+ );
39
+ }
40
+ return config;
41
+ };
42
+ export {
43
+ initializeConfig,
44
+ loadFireConfig,
45
+ validateConfig
46
+ };
3
47
  //# sourceMappingURL=config.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"config.js"}
1
+ {"version":3,"sources":["../../../src/utils/config.ts"],"sourcesContent":["import { TernSecureConfig, ConfigValidationResult } from '../types'\r\n\r\n/**\r\n * Loads Firebase configuration from environment variables\r\n * @returns {TernSecureConfig} Firebase configuration object\r\n */\r\nexport const loadFireConfig = (): TernSecureConfig => ({\r\n apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || '',\r\n authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || '',\r\n projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || '',\r\n storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || '',\r\n messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || '',\r\n appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || '',\r\n measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || undefined,\r\n})\r\n\r\n/**\r\n * Validates Firebase configuration\r\n * @param {TernSecureConfig} config - Firebase configuration object\r\n * @throws {Error} If required configuration values are missing\r\n * @returns {TernSecureConfig} Validated configuration object\r\n */\r\nexport const validateConfig = (config: TernSecureConfig): ConfigValidationResult => {\r\n const requiredFields: (keyof TernSecureConfig)[] = [\r\n 'apiKey',\r\n 'authDomain',\r\n 'projectId',\r\n 'storageBucket',\r\n 'messagingSenderId',\r\n 'appId'\r\n ]\r\n\r\n const errors: string[] = []\r\n \r\n requiredFields.forEach(field => {\r\n if (!config[field]) {\r\n errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`)\r\n }\r\n })\r\n\r\n return {\r\n isValid: errors.length === 0,\r\n errors,\r\n config\r\n }\r\n}\r\n\r\n/**\r\n * Initializes configuration with validation\r\n * @throws {Error} If configuration is invalid\r\n */\r\nexport const initializeConfig = (): TernSecureConfig => {\r\n const config = loadFireConfig()\r\n const validationResult = validateConfig(config)\r\n\r\n if (!validationResult.isValid) {\r\n throw new Error(\r\n `Firebase configuration validation failed:\\n${validationResult.errors.join('\\n')}`\r\n )\r\n }\r\n\r\n return config\r\n}"],"mappings":"AAMO,MAAM,iBAAiB,OAAyB;AAAA,EACrD,QAAQ,QAAQ,IAAI,gCAAgC;AAAA,EACpD,YAAY,QAAQ,IAAI,oCAAoC;AAAA,EAC5D,WAAW,QAAQ,IAAI,mCAAmC;AAAA,EAC1D,eAAe,QAAQ,IAAI,uCAAuC;AAAA,EAClE,mBAAmB,QAAQ,IAAI,4CAA4C;AAAA,EAC3E,OAAO,QAAQ,IAAI,+BAA+B;AAAA,EAClD,eAAe,QAAQ,IAAI,uCAAuC;AACpE;AAQO,MAAM,iBAAiB,CAAC,WAAqD;AAClF,QAAM,iBAA6C;AAAA,IACjD;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAEA,QAAM,SAAmB,CAAC;AAE1B,iBAAe,QAAQ,WAAS;AAC9B,QAAI,CAAC,OAAO,KAAK,GAAG;AAClB,aAAO,KAAK,gDAAgD,OAAO,KAAK,EAAE,YAAY,CAAC,EAAE;AAAA,IAC3F;AAAA,EACF,CAAC;AAED,SAAO;AAAA,IACL,SAAS,OAAO,WAAW;AAAA,IAC3B;AAAA,IACA;AAAA,EACF;AACF;AAMO,MAAM,mBAAmB,MAAwB;AACtD,QAAM,SAAS,eAAe;AAC9B,QAAM,mBAAmB,eAAe,MAAM;AAE9C,MAAI,CAAC,iBAAiB,SAAS;AAC7B,UAAM,IAAI;AAAA,MACR;AAAA,EAA8C,iBAAiB,OAAO,KAAK,IAAI,CAAC;AAAA,IAClF;AAAA,EACF;AAEA,SAAO;AACT;","names":[]}
@@ -1,3 +1,123 @@
1
- export { defaultClassNames, styleConfig, styles } from '../chunk-EI37GOD7.js';
2
- //# sourceMappingURL=create-styles.js.map
1
+ "use client";
2
+ const PREFIX = "tern";
3
+ const styleInjection = {
4
+ isInjected: false,
5
+ styleElement: null
6
+ };
7
+ const defaultClassNames = {
8
+ container: `${PREFIX}-container`,
9
+ header: `${PREFIX}-header`,
10
+ title: `${PREFIX}-title`,
11
+ formWrapper: `${PREFIX}-formWrapper`,
12
+ formContainer: `${PREFIX}-formContainer`,
13
+ form: `${PREFIX}-form`,
14
+ label: `${PREFIX}-label`,
15
+ input: `${PREFIX}-input`,
16
+ button: `${PREFIX}-button`,
17
+ error: `${PREFIX}-error`
18
+ };
19
+ function createStyleSheet(styles2) {
20
+ if (typeof window === "undefined") return defaultClassNames;
21
+ if (styleInjection.isInjected) {
22
+ return defaultClassNames;
23
+ }
24
+ let styleElement = document.querySelector("[data-tern-secure]");
25
+ if (!styleElement) {
26
+ styleElement = document.createElement("style");
27
+ styleElement.setAttribute("data-tern-secure", "");
28
+ document.head.appendChild(styleElement);
29
+ styleInjection.styleElement = styleElement;
30
+ }
31
+ const cssRules = Object.entries(styles2).map(([key, rules]) => {
32
+ const className = defaultClassNames[key];
33
+ const cssProperties = Object.entries(rules).map(([prop, value]) => {
34
+ const cssProperty = prop.replace(/([A-Z])/g, "-$1").toLowerCase();
35
+ return `${cssProperty}: ${value};`;
36
+ }).join(" ");
37
+ return `.${className} { ${cssProperties} }`;
38
+ }).join("\n");
39
+ styleElement.textContent = cssRules;
40
+ styleInjection.isInjected = true;
41
+ return defaultClassNames;
42
+ }
43
+ const styleConfig = {
44
+ container: {
45
+ display: "flex",
46
+ minHeight: "100%",
47
+ flex: "1",
48
+ flexDirection: "column",
49
+ justifyContent: "center",
50
+ padding: "3rem 1.5rem"
51
+ },
52
+ header: {
53
+ margin: "0 auto",
54
+ width: "100%",
55
+ maxWidth: "28rem"
56
+ },
57
+ title: {
58
+ marginTop: "1.5rem",
59
+ textAlign: "center",
60
+ fontSize: "1.875rem",
61
+ fontWeight: "700",
62
+ lineHeight: "2.25rem",
63
+ letterSpacing: "-0.025em",
64
+ color: "var(--tern-text-primary, #111827)"
65
+ },
66
+ formWrapper: {
67
+ marginTop: "2.5rem",
68
+ margin: "0 auto",
69
+ width: "100%",
70
+ maxWidth: "30rem"
71
+ },
72
+ formContainer: {
73
+ padding: "3rem 1.5rem",
74
+ boxShadow: "0 1px 3px 0 rgb(0 0 0 / 0.1)",
75
+ borderRadius: "0.5rem",
76
+ backgroundColor: "var(--tern-background, white)"
77
+ },
78
+ form: {
79
+ display: "flex",
80
+ flexDirection: "column",
81
+ gap: "1rem"
82
+ },
83
+ label: {
84
+ display: "block",
85
+ fontSize: "0.875rem",
86
+ fontWeight: "500",
87
+ color: "var(--tern-text-secondary, #374151)"
88
+ },
89
+ input: {
90
+ marginTop: "0.25rem",
91
+ display: "block",
92
+ width: "100%",
93
+ padding: "0.5rem 0.75rem",
94
+ borderRadius: "0.375rem",
95
+ border: "1px solid var(--tern-border, #D1D5DB)",
96
+ backgroundColor: "var(--tern-input-background, white)",
97
+ color: "var(--tern-text-primary, #111827)"
98
+ },
99
+ button: {
100
+ display: "flex",
101
+ width: "100%",
102
+ justifyContent: "center",
103
+ padding: "0.5rem 1rem",
104
+ fontSize: "0.875rem",
105
+ fontWeight: "500",
106
+ color: "white",
107
+ backgroundColor: "var(--tern-primary, #2563EB)",
108
+ border: "none",
109
+ borderRadius: "0.375rem",
110
+ cursor: "pointer"
111
+ },
112
+ error: {
113
+ color: "var(--tern-error, #DC2626)",
114
+ fontSize: "0.875rem"
115
+ }
116
+ };
117
+ const styles = createStyleSheet(styleConfig);
118
+ export {
119
+ defaultClassNames,
120
+ styleConfig,
121
+ styles
122
+ };
3
123
  //# sourceMappingURL=create-styles.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"create-styles.js"}
1
+ {"version":3,"sources":["../../../src/utils/create-styles.ts"],"sourcesContent":["'use client'\r\n\r\nconst PREFIX = 'tern'\r\n\r\n// Singleton to track style injection\r\nconst styleInjection = {\r\n isInjected: false,\r\n styleElement: null as HTMLStyleElement | null\r\n}\r\n\r\nexport const defaultClassNames = {\r\n container: `${PREFIX}-container`,\r\n header: `${PREFIX}-header`,\r\n title: `${PREFIX}-title`,\r\n formWrapper: `${PREFIX}-formWrapper`,\r\n formContainer: `${PREFIX}-formContainer`,\r\n form: `${PREFIX}-form`,\r\n label: `${PREFIX}-label`,\r\n input: `${PREFIX}-input`,\r\n button: `${PREFIX}-button`,\r\n error: `${PREFIX}-error`\r\n} as const\r\n\r\n// Create styles once and cache them\r\nfunction createStyleSheet(styles: Record<string, React.CSSProperties>) {\r\n if (typeof window === 'undefined') return defaultClassNames\r\n\r\n // Return early if styles are already injected\r\n if (styleInjection.isInjected) {\r\n return defaultClassNames\r\n }\r\n\r\n // Find existing style element or create new one\r\n let styleElement = document.querySelector<HTMLStyleElement>('[data-tern-secure]')\r\n \r\n if (!styleElement) {\r\n styleElement = document.createElement('style')\r\n styleElement.setAttribute('data-tern-secure', '')\r\n document.head.appendChild(styleElement)\r\n styleInjection.styleElement = styleElement\r\n }\r\n\r\n // Create CSS rules\r\n const cssRules = Object.entries(styles).map(([key, rules]) => {\r\n const className = defaultClassNames[key as keyof typeof defaultClassNames]\r\n const cssProperties = Object.entries(rules).map(([prop, value]) => {\r\n const cssProperty = prop.replace(/([A-Z])/g, '-$1').toLowerCase()\r\n return `${cssProperty}: ${value};`\r\n }).join(' ')\r\n\r\n return `.${className} { ${cssProperties} }`\r\n }).join('\\n')\r\n\r\n // Insert styles only once\r\n styleElement.textContent = cssRules\r\n styleInjection.isInjected = true\r\n\r\n return defaultClassNames\r\n}\r\n\r\n// Style configuration\r\nexport const styleConfig = {\r\n container: {\r\n display: 'flex',\r\n minHeight: '100%',\r\n flex: '1',\r\n flexDirection: 'column',\r\n justifyContent: 'center',\r\n padding: '3rem 1.5rem'\r\n },\r\n header: {\r\n margin: '0 auto',\r\n width: '100%',\r\n maxWidth: '28rem'\r\n },\r\n title: {\r\n marginTop: '1.5rem',\r\n textAlign: 'center',\r\n fontSize: '1.875rem',\r\n fontWeight: '700',\r\n lineHeight: '2.25rem',\r\n letterSpacing: '-0.025em',\r\n color: 'var(--tern-text-primary, #111827)'\r\n },\r\n formWrapper: {\r\n marginTop: '2.5rem',\r\n margin: '0 auto',\r\n width: '100%',\r\n maxWidth: '30rem'\r\n },\r\n formContainer: {\r\n padding: '3rem 1.5rem',\r\n boxShadow: '0 1px 3px 0 rgb(0 0 0 / 0.1)',\r\n borderRadius: '0.5rem',\r\n backgroundColor: 'var(--tern-background, white)'\r\n },\r\n form: {\r\n display: 'flex',\r\n flexDirection: 'column',\r\n gap: '1rem'\r\n },\r\n label: {\r\n display: 'block',\r\n fontSize: '0.875rem',\r\n fontWeight: '500',\r\n color: 'var(--tern-text-secondary, #374151)'\r\n },\r\n input: {\r\n marginTop: '0.25rem',\r\n display: 'block',\r\n width: '100%',\r\n padding: '0.5rem 0.75rem',\r\n borderRadius: '0.375rem',\r\n border: '1px solid var(--tern-border, #D1D5DB)',\r\n backgroundColor: 'var(--tern-input-background, white)',\r\n color: 'var(--tern-text-primary, #111827)'\r\n },\r\n button: {\r\n display: 'flex',\r\n width: '100%',\r\n justifyContent: 'center',\r\n padding: '0.5rem 1rem',\r\n fontSize: '0.875rem',\r\n fontWeight: '500',\r\n color: 'white',\r\n backgroundColor: 'var(--tern-primary, #2563EB)',\r\n border: 'none',\r\n borderRadius: '0.375rem',\r\n cursor: 'pointer'\r\n },\r\n error: {\r\n color: 'var(--tern-error, #DC2626)',\r\n fontSize: '0.875rem'\r\n }\r\n} as const\r\n\r\n// Export pre-created styles\r\nexport const styles = createStyleSheet(styleConfig)\r\n\r\n"],"mappings":"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","names":["styles"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tern-secure/nextjs",
3
- "version": "3.1.75",
3
+ "version": "3.1.77",
4
4
  "packageManager": "npm@10.9.0",
5
5
  "type": "module",
6
6
  "publishConfig": {
@@ -19,10 +19,9 @@
19
19
  "module": "./dist/index.js",
20
20
  "scripts": {
21
21
  "build": "npm run clean && tsup",
22
- "build:types": "tsc --emitDeclarationOnly --outDir dist/esm",
23
22
  "build:js": "node build.config.cjs",
24
23
  "clean": "rimraf dist",
25
- "dev": "tsup src/index.ts --format cjs,esm --dts --watch",
24
+ "dev": "tsup --watch",
26
25
  "lint": "eslint \"src/**/*.{ts,tsx}\"",
27
26
  "format": "prettier --write \"src/**/*.{ts,tsx}\""
28
27
  },
@@ -57,17 +56,6 @@
57
56
  "react": "^18 || ^19.0.0-0",
58
57
  "react-dom": "^18 || ^19.0.0-0"
59
58
  },
60
- "peerDependenciesMeta": {
61
- "tailwindcss": {
62
- "optional": true
63
- },
64
- "postcss": {
65
- "optional": true
66
- },
67
- "autoprefixer": {
68
- "optional": true
69
- }
70
- },
71
59
  "exports": {
72
60
  ".": {
73
61
  "types": "./dist/esm/index.d.ts",
@@ -1,84 +0,0 @@
1
- 'use strict';
2
-
3
- var react = require('react');
4
- var app = require('firebase/app');
5
- var auth$1 = require('firebase/auth');
6
- var firestore = require('firebase/firestore');
7
- var storage = require('firebase/storage');
8
- var jsxRuntime = require('react/jsx-runtime');
9
-
10
- // src/utils/config.ts
11
- var loadFireConfig = () => ({
12
- apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || "",
13
- authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || "",
14
- projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || "",
15
- storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || "",
16
- messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || "",
17
- appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || "",
18
- measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || void 0
19
- });
20
- var validateConfig = (config2) => {
21
- const requiredFields = [
22
- "apiKey",
23
- "authDomain",
24
- "projectId",
25
- "storageBucket",
26
- "messagingSenderId",
27
- "appId"
28
- ];
29
- const errors = [];
30
- requiredFields.forEach((field) => {
31
- if (!config2[field]) {
32
- errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`);
33
- }
34
- });
35
- return {
36
- isValid: errors.length === 0,
37
- errors,
38
- config: config2
39
- };
40
- };
41
- var initializeConfig = () => {
42
- const config2 = loadFireConfig();
43
- const validationResult = validateConfig(config2);
44
- if (!validationResult.isValid) {
45
- throw new Error(
46
- `Firebase configuration validation failed:
47
- ${validationResult.errors.join("\n")}`
48
- );
49
- }
50
- return config2;
51
- };
52
-
53
- // src/utils/client-init.ts
54
- var config = initializeConfig();
55
- var clientApp = app.initializeApp(config);
56
- var auth = auth$1.getAuth(clientApp);
57
- auth$1.setPersistence(auth, auth$1.browserSessionPersistence);
58
- firestore.getFirestore(clientApp);
59
- storage.getStorage(clientApp);
60
- var TernSecureAuth = () => auth;
61
- var TernSecureContext = react.createContext(null);
62
- var TernSecureClientProvider = ({
63
- children,
64
- initialState
65
- }) => {
66
- const [authState, setAuthState] = react.useState(initialState);
67
- react.useEffect(() => {
68
- const auth2 = TernSecureAuth();
69
- const unsubscribe = auth2.onAuthStateChanged(
70
- (user) => {
71
- setAuthState({ userId: user?.uid || null, isSignedIn: !!user, loading: false, error: null });
72
- },
73
- (error) => {
74
- setAuthState({ userId: null, isSignedIn: false, loading: false, error: null });
75
- }
76
- );
77
- return () => unsubscribe();
78
- }, []);
79
- return /* @__PURE__ */ jsxRuntime.jsx(TernSecureContext.Provider, { value: { authState }, children });
80
- };
81
-
82
- exports.TernSecureClientProvider = TernSecureClientProvider;
83
- //# sourceMappingURL=TernSecureProvider.cjs.map
84
- //# sourceMappingURL=TernSecureProvider.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/utils/config.ts","../../../../src/utils/client-init.ts","../../../../src/boundary/TernSecureCtx.tsx","../../../../src/app-router/client/TernSecureProvider.tsx"],"names":["config","initializeApp","getAuth","setPersistence","browserSessionPersistence","getFirestore","getStorage","createContext","useState","useEffect","auth","jsx"],"mappings":"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","file":"TernSecureProvider.cjs","sourcesContent":["import { TernSecureConfig, ConfigValidationResult } from '../types'\r\n\r\n/**\r\n * Loads Firebase configuration from environment variables\r\n * @returns {TernSecureConfig} Firebase configuration object\r\n */\r\nexport const loadFireConfig = (): TernSecureConfig => ({\r\n apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || '',\r\n authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || '',\r\n projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || '',\r\n storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || '',\r\n messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || '',\r\n appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || '',\r\n measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || undefined,\r\n})\r\n\r\n/**\r\n * Validates Firebase configuration\r\n * @param {TernSecureConfig} config - Firebase configuration object\r\n * @throws {Error} If required configuration values are missing\r\n * @returns {TernSecureConfig} Validated configuration object\r\n */\r\nexport const validateConfig = (config: TernSecureConfig): ConfigValidationResult => {\r\n const requiredFields: (keyof TernSecureConfig)[] = [\r\n 'apiKey',\r\n 'authDomain',\r\n 'projectId',\r\n 'storageBucket',\r\n 'messagingSenderId',\r\n 'appId'\r\n ]\r\n\r\n const errors: string[] = []\r\n \r\n requiredFields.forEach(field => {\r\n if (!config[field]) {\r\n errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`)\r\n }\r\n })\r\n\r\n return {\r\n isValid: errors.length === 0,\r\n errors,\r\n config\r\n }\r\n}\r\n\r\n/**\r\n * Initializes configuration with validation\r\n * @throws {Error} If configuration is invalid\r\n */\r\nexport const initializeConfig = (): TernSecureConfig => {\r\n const config = loadFireConfig()\r\n const validationResult = validateConfig(config)\r\n\r\n if (!validationResult.isValid) {\r\n throw new Error(\r\n `Firebase configuration validation failed:\\n${validationResult.errors.join('\\n')}`\r\n )\r\n }\r\n\r\n return config\r\n}","import { initializeApp } from 'firebase/app';\r\nimport { getAuth, setPersistence, browserSessionPersistence } from 'firebase/auth';\r\nimport { getFirestore } from 'firebase/firestore';\r\nimport { getStorage } from 'firebase/storage';\r\nimport { initializeConfig} from './config';\r\n\r\n// Initialize immediately\r\nconst config = initializeConfig();\r\nconst clientApp = initializeApp(config)\r\nconst auth = getAuth(clientApp);\r\nsetPersistence(auth, browserSessionPersistence); //to change later user should be able to choose persistance\r\nconst firestore = getFirestore(clientApp);\r\nconst storage = getStorage(clientApp);\r\n\r\nexport const TernSecureAuth = () => auth;\r\nexport const TernSecureFirestore = () => firestore;\r\nexport const TernSecureStorage = () => storage;","'use client'\r\n\r\nimport { createContext, useContext } from 'react';\r\nimport { AuthState } from '../app-router/client/TernSecureProvider';\r\n\r\n\r\nexport interface TernSecureContextType {\r\n authState: AuthState;\r\n}\r\n\r\n\r\n\r\nexport const TernSecureContext = createContext<TernSecureContextType | null>(null);\r\n\r\nexport const useTernSecure = () => {\r\n const context = useContext(TernSecureContext);\r\n if (!context) {\r\n throw new Error('useTernSecure must be used within a TernSecureProvider');\r\n }\r\n return context.authState;\r\n};\r\n\r\n","'use client'\r\n\r\nimport React, { useEffect, useState } from 'react';\r\nimport { TernSecureAuth } from '../../utils/client-init';\r\nimport { TernSecureContext } from '../../boundary/TernSecureCtx';\r\nimport type { ReactNode } from 'react';\r\n\r\n\r\nexport interface AuthState {\r\n userId: string | null;\r\n loading: boolean;\r\n error: string | null;\r\n isSignedIn: boolean;\r\n}\r\n\r\nexport interface TernSecureProviderProps {\r\n children: ReactNode;\r\n}\r\n\r\nexport const TernSecureClientProvider: React.FC<TernSecureProviderProps & { initialState: AuthState }> = ({ \r\n children, \r\n initialState \r\n}) => {\r\n const [authState, setAuthState] = useState<AuthState>(initialState);\r\n\r\n useEffect(() => {\r\n const auth = TernSecureAuth();\r\n const unsubscribe = auth.onAuthStateChanged(\r\n (user) => {\r\n setAuthState({ userId: user?.uid || null, isSignedIn: !!user, loading: false, error: null });\r\n },\r\n (error) => {\r\n setAuthState({ userId: null, isSignedIn: false, loading: false, error: null});\r\n }\r\n );\r\n\r\n return () => unsubscribe();\r\n }, []);\r\n\r\n return (\r\n <TernSecureContext.Provider value={{ authState }}>\r\n {children}\r\n </TernSecureContext.Provider>\r\n );\r\n};\r\n\r\n"]}
@@ -1,95 +0,0 @@
1
- 'use strict';
2
-
3
- var react = require('react');
4
- var app = require('firebase/app');
5
- var auth$1 = require('firebase/auth');
6
- var firestore = require('firebase/firestore');
7
- var storage = require('firebase/storage');
8
- var jsxRuntime = require('react/jsx-runtime');
9
-
10
- // src/app-router/client/TernSecureProvider.tsx
11
-
12
- // src/utils/config.ts
13
- var loadFireConfig = () => ({
14
- apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || "",
15
- authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || "",
16
- projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || "",
17
- storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || "",
18
- messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || "",
19
- appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || "",
20
- measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || void 0
21
- });
22
- var validateConfig = (config2) => {
23
- const requiredFields = [
24
- "apiKey",
25
- "authDomain",
26
- "projectId",
27
- "storageBucket",
28
- "messagingSenderId",
29
- "appId"
30
- ];
31
- const errors = [];
32
- requiredFields.forEach((field) => {
33
- if (!config2[field]) {
34
- errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`);
35
- }
36
- });
37
- return {
38
- isValid: errors.length === 0,
39
- errors,
40
- config: config2
41
- };
42
- };
43
- var initializeConfig = () => {
44
- const config2 = loadFireConfig();
45
- const validationResult = validateConfig(config2);
46
- if (!validationResult.isValid) {
47
- throw new Error(
48
- `Firebase configuration validation failed:
49
- ${validationResult.errors.join("\n")}`
50
- );
51
- }
52
- return config2;
53
- };
54
-
55
- // src/utils/client-init.ts
56
- var config = initializeConfig();
57
- var clientApp = app.initializeApp(config);
58
- var auth = auth$1.getAuth(clientApp);
59
- auth$1.setPersistence(auth, auth$1.browserSessionPersistence);
60
- firestore.getFirestore(clientApp);
61
- storage.getStorage(clientApp);
62
- var TernSecureAuth = () => auth;
63
- var TernSecureContext = react.createContext(null);
64
- var TernSecureClientProvider = ({
65
- children,
66
- initialState
67
- }) => {
68
- const [authState, setAuthState] = react.useState(initialState);
69
- react.useEffect(() => {
70
- const auth2 = TernSecureAuth();
71
- const unsubscribe = auth2.onAuthStateChanged(
72
- (user) => {
73
- setAuthState({ userId: user?.uid || null, isSignedIn: !!user, loading: false, error: null });
74
- },
75
- (error) => {
76
- setAuthState({ userId: null, isSignedIn: false, loading: false, error: null });
77
- }
78
- );
79
- return () => unsubscribe();
80
- }, []);
81
- return /* @__PURE__ */ jsxRuntime.jsx(TernSecureContext.Provider, { value: { authState }, children });
82
- };
83
- function TernSecureProvider({ children }) {
84
- const initialState = {
85
- userId: null,
86
- loading: true,
87
- error: null,
88
- isSignedIn: false
89
- };
90
- return /* @__PURE__ */ jsxRuntime.jsx(TernSecureClientProvider, { initialState, children });
91
- }
92
-
93
- exports.TernSecureProvider = TernSecureProvider;
94
- //# sourceMappingURL=TernSecureServerProvider.cjs.map
95
- //# sourceMappingURL=TernSecureServerProvider.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/utils/config.ts","../../../../src/utils/client-init.ts","../../../../src/boundary/TernSecureCtx.tsx","../../../../src/app-router/client/TernSecureProvider.tsx","../../../../src/app-router/server/TernSecureServerProvider.tsx"],"names":["config","initializeApp","getAuth","setPersistence","browserSessionPersistence","getFirestore","getStorage","createContext","useState","useEffect","auth","jsx"],"mappings":"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","file":"TernSecureServerProvider.cjs","sourcesContent":["import { TernSecureConfig, ConfigValidationResult } from '../types'\r\n\r\n/**\r\n * Loads Firebase configuration from environment variables\r\n * @returns {TernSecureConfig} Firebase configuration object\r\n */\r\nexport const loadFireConfig = (): TernSecureConfig => ({\r\n apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || '',\r\n authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || '',\r\n projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || '',\r\n storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || '',\r\n messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || '',\r\n appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || '',\r\n measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || undefined,\r\n})\r\n\r\n/**\r\n * Validates Firebase configuration\r\n * @param {TernSecureConfig} config - Firebase configuration object\r\n * @throws {Error} If required configuration values are missing\r\n * @returns {TernSecureConfig} Validated configuration object\r\n */\r\nexport const validateConfig = (config: TernSecureConfig): ConfigValidationResult => {\r\n const requiredFields: (keyof TernSecureConfig)[] = [\r\n 'apiKey',\r\n 'authDomain',\r\n 'projectId',\r\n 'storageBucket',\r\n 'messagingSenderId',\r\n 'appId'\r\n ]\r\n\r\n const errors: string[] = []\r\n \r\n requiredFields.forEach(field => {\r\n if (!config[field]) {\r\n errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`)\r\n }\r\n })\r\n\r\n return {\r\n isValid: errors.length === 0,\r\n errors,\r\n config\r\n }\r\n}\r\n\r\n/**\r\n * Initializes configuration with validation\r\n * @throws {Error} If configuration is invalid\r\n */\r\nexport const initializeConfig = (): TernSecureConfig => {\r\n const config = loadFireConfig()\r\n const validationResult = validateConfig(config)\r\n\r\n if (!validationResult.isValid) {\r\n throw new Error(\r\n `Firebase configuration validation failed:\\n${validationResult.errors.join('\\n')}`\r\n )\r\n }\r\n\r\n return config\r\n}","import { initializeApp } from 'firebase/app';\r\nimport { getAuth, setPersistence, browserSessionPersistence } from 'firebase/auth';\r\nimport { getFirestore } from 'firebase/firestore';\r\nimport { getStorage } from 'firebase/storage';\r\nimport { initializeConfig} from './config';\r\n\r\n// Initialize immediately\r\nconst config = initializeConfig();\r\nconst clientApp = initializeApp(config)\r\nconst auth = getAuth(clientApp);\r\nsetPersistence(auth, browserSessionPersistence); //to change later user should be able to choose persistance\r\nconst firestore = getFirestore(clientApp);\r\nconst storage = getStorage(clientApp);\r\n\r\nexport const TernSecureAuth = () => auth;\r\nexport const TernSecureFirestore = () => firestore;\r\nexport const TernSecureStorage = () => storage;","'use client'\r\n\r\nimport { createContext, useContext } from 'react';\r\nimport { AuthState } from '../app-router/client/TernSecureProvider';\r\n\r\n\r\nexport interface TernSecureContextType {\r\n authState: AuthState;\r\n}\r\n\r\n\r\n\r\nexport const TernSecureContext = createContext<TernSecureContextType | null>(null);\r\n\r\nexport const useTernSecure = () => {\r\n const context = useContext(TernSecureContext);\r\n if (!context) {\r\n throw new Error('useTernSecure must be used within a TernSecureProvider');\r\n }\r\n return context.authState;\r\n};\r\n\r\n","'use client'\r\n\r\nimport React, { useEffect, useState } from 'react';\r\nimport { TernSecureAuth } from '../../utils/client-init';\r\nimport { TernSecureContext } from '../../boundary/TernSecureCtx';\r\nimport type { ReactNode } from 'react';\r\n\r\n\r\nexport interface AuthState {\r\n userId: string | null;\r\n loading: boolean;\r\n error: string | null;\r\n isSignedIn: boolean;\r\n}\r\n\r\nexport interface TernSecureProviderProps {\r\n children: ReactNode;\r\n}\r\n\r\nexport const TernSecureClientProvider: React.FC<TernSecureProviderProps & { initialState: AuthState }> = ({ \r\n children, \r\n initialState \r\n}) => {\r\n const [authState, setAuthState] = useState<AuthState>(initialState);\r\n\r\n useEffect(() => {\r\n const auth = TernSecureAuth();\r\n const unsubscribe = auth.onAuthStateChanged(\r\n (user) => {\r\n setAuthState({ userId: user?.uid || null, isSignedIn: !!user, loading: false, error: null });\r\n },\r\n (error) => {\r\n setAuthState({ userId: null, isSignedIn: false, loading: false, error: null});\r\n }\r\n );\r\n\r\n return () => unsubscribe();\r\n }, []);\r\n\r\n return (\r\n <TernSecureContext.Provider value={{ authState }}>\r\n {children}\r\n </TernSecureContext.Provider>\r\n );\r\n};\r\n\r\n","import React, { ReactNode } from \"react\";\r\nimport { TernSecureClientProvider, AuthState } from \"../client/TernSecureProvider\";\r\n\r\nexport interface TernSecureProviderProps {\r\n children: ReactNode;\r\n}\r\n\r\nexport function TernSecureProvider({ children }: TernSecureProviderProps) {\r\n const initialState: AuthState = {\r\n userId: null,\r\n loading: true,\r\n error: null,\r\n isSignedIn: false,\r\n };\r\n\r\n return <TernSecureClientProvider initialState={initialState}>{children}</TernSecureClientProvider>;\r\n}\r\n\r\n"]}
@@ -1,71 +0,0 @@
1
- 'use strict';
2
-
3
- var app = require('firebase/app');
4
- var auth$1 = require('firebase/auth');
5
- var firestore = require('firebase/firestore');
6
- var storage = require('firebase/storage');
7
-
8
- // src/utils/client-init.ts
9
-
10
- // src/utils/config.ts
11
- var loadFireConfig = () => ({
12
- apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || "",
13
- authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || "",
14
- projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || "",
15
- storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || "",
16
- messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || "",
17
- appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || "",
18
- measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || void 0
19
- });
20
- var validateConfig = (config2) => {
21
- const requiredFields = [
22
- "apiKey",
23
- "authDomain",
24
- "projectId",
25
- "storageBucket",
26
- "messagingSenderId",
27
- "appId"
28
- ];
29
- const errors = [];
30
- requiredFields.forEach((field) => {
31
- if (!config2[field]) {
32
- errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`);
33
- }
34
- });
35
- return {
36
- isValid: errors.length === 0,
37
- errors,
38
- config: config2
39
- };
40
- };
41
- var initializeConfig = () => {
42
- const config2 = loadFireConfig();
43
- const validationResult = validateConfig(config2);
44
- if (!validationResult.isValid) {
45
- throw new Error(
46
- `Firebase configuration validation failed:
47
- ${validationResult.errors.join("\n")}`
48
- );
49
- }
50
- return config2;
51
- };
52
-
53
- // src/utils/client-init.ts
54
- var config = initializeConfig();
55
- var clientApp = app.initializeApp(config);
56
- var auth = auth$1.getAuth(clientApp);
57
- auth$1.setPersistence(auth, auth$1.browserSessionPersistence);
58
- firestore.getFirestore(clientApp);
59
- storage.getStorage(clientApp);
60
- var TernSecureAuth = () => auth;
61
- async function signInWithEmail({
62
- email,
63
- password
64
- }) {
65
- const auth2 = TernSecureAuth();
66
- return auth$1.signInWithEmailAndPassword(auth2, email, password);
67
- }
68
-
69
- exports.signInWithEmail = signInWithEmail;
70
- //# sourceMappingURL=auth.cjs.map
71
- //# sourceMappingURL=auth.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/utils/config.ts","../../../../src/utils/client-init.ts","../../../../src/app-router/server/auth.ts"],"names":["config","initializeApp","getAuth","setPersistence","browserSessionPersistence","getFirestore","getStorage","auth","signInWithEmailAndPassword"],"mappings":";;;;;;;;;;AAMO,IAAM,iBAAiB,OAAyB;AAAA,EACrD,MAAA,EAAQ,OAAQ,CAAA,GAAA,CAAI,4BAAgC,IAAA,EAAA;AAAA,EACpD,UAAA,EAAY,OAAQ,CAAA,GAAA,CAAI,gCAAoC,IAAA,EAAA;AAAA,EAC5D,SAAA,EAAW,OAAQ,CAAA,GAAA,CAAI,+BAAmC,IAAA,EAAA;AAAA,EAC1D,aAAA,EAAe,OAAQ,CAAA,GAAA,CAAI,mCAAuC,IAAA,EAAA;AAAA,EAClE,iBAAA,EAAmB,OAAQ,CAAA,GAAA,CAAI,wCAA4C,IAAA,EAAA;AAAA,EAC3E,KAAA,EAAO,OAAQ,CAAA,GAAA,CAAI,2BAA+B,IAAA,EAAA;AAAA,EAClD,aAAA,EAAe,OAAQ,CAAA,GAAA,CAAI,mCAAuC,IAAA,KAAA;AACpE,CAAA,CAAA;AAQO,IAAM,cAAA,GAAiB,CAACA,OAAqD,KAAA;AAClF,EAAA,MAAM,cAA6C,GAAA;AAAA,IACjD,QAAA;AAAA,IACA,YAAA;AAAA,IACA,WAAA;AAAA,IACA,eAAA;AAAA,IACA,mBAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,MAAM,SAAmB,EAAC;AAE1B,EAAA,cAAA,CAAe,QAAQ,CAAS,KAAA,KAAA;AAC9B,IAAI,IAAA,CAACA,OAAO,CAAA,KAAK,CAAG,EAAA;AAClB,MAAA,MAAA,CAAO,KAAK,CAAgD,6CAAA,EAAA,MAAA,CAAO,KAAK,CAAE,CAAA,WAAA,EAAa,CAAE,CAAA,CAAA;AAAA;AAC3F,GACD,CAAA;AAED,EAAO,OAAA;AAAA,IACL,OAAA,EAAS,OAAO,MAAW,KAAA,CAAA;AAAA,IAC3B,MAAA;AAAA,IACA,MAAAA,EAAAA;AAAA,GACF;AACF,CAAA;AAMO,IAAM,mBAAmB,MAAwB;AACtD,EAAA,MAAMA,UAAS,cAAe,EAAA;AAC9B,EAAM,MAAA,gBAAA,GAAmB,eAAeA,OAAM,CAAA;AAE9C,EAAI,IAAA,CAAC,iBAAiB,OAAS,EAAA;AAC7B,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA;AAAA,EAA8C,gBAAiB,CAAA,MAAA,CAAO,IAAK,CAAA,IAAI,CAAC,CAAA;AAAA,KAClF;AAAA;AAGF,EAAOA,OAAAA,OAAAA;AACT,CAAA;;;ACvDA,IAAM,SAAS,gBAAiB,EAAA;AAChC,IAAM,SAAA,GAAYC,kBAAc,MAAM,CAAA;AACtC,IAAM,IAAA,GAAOC,eAAQ,SAAS,CAAA;AAC9BC,qBAAA,CAAe,MAAMC,gCAAyB,CAAA;AAC5BC,uBAAa,SAAS;AACxBC,mBAAW,SAAS;AAE7B,IAAM,iBAAiB,MAAM,IAAA;ACNpC,eAAsB,eAAgB,CAAA;AAAA,EACpC,KAAA;AAAA,EACA;AACF,CAA+C,EAAA;AAC7C,EAAA,MAAMC,QAAO,cAAe,EAAA;AAC5B,EAAO,OAAAC,iCAAA,CAA2BD,KAAM,EAAA,KAAA,EAAO,QAAQ,CAAA;AACzD","file":"auth.cjs","sourcesContent":["import { TernSecureConfig, ConfigValidationResult } from '../types'\r\n\r\n/**\r\n * Loads Firebase configuration from environment variables\r\n * @returns {TernSecureConfig} Firebase configuration object\r\n */\r\nexport const loadFireConfig = (): TernSecureConfig => ({\r\n apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || '',\r\n authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || '',\r\n projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || '',\r\n storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || '',\r\n messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || '',\r\n appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || '',\r\n measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || undefined,\r\n})\r\n\r\n/**\r\n * Validates Firebase configuration\r\n * @param {TernSecureConfig} config - Firebase configuration object\r\n * @throws {Error} If required configuration values are missing\r\n * @returns {TernSecureConfig} Validated configuration object\r\n */\r\nexport const validateConfig = (config: TernSecureConfig): ConfigValidationResult => {\r\n const requiredFields: (keyof TernSecureConfig)[] = [\r\n 'apiKey',\r\n 'authDomain',\r\n 'projectId',\r\n 'storageBucket',\r\n 'messagingSenderId',\r\n 'appId'\r\n ]\r\n\r\n const errors: string[] = []\r\n \r\n requiredFields.forEach(field => {\r\n if (!config[field]) {\r\n errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`)\r\n }\r\n })\r\n\r\n return {\r\n isValid: errors.length === 0,\r\n errors,\r\n config\r\n }\r\n}\r\n\r\n/**\r\n * Initializes configuration with validation\r\n * @throws {Error} If configuration is invalid\r\n */\r\nexport const initializeConfig = (): TernSecureConfig => {\r\n const config = loadFireConfig()\r\n const validationResult = validateConfig(config)\r\n\r\n if (!validationResult.isValid) {\r\n throw new Error(\r\n `Firebase configuration validation failed:\\n${validationResult.errors.join('\\n')}`\r\n )\r\n }\r\n\r\n return config\r\n}","import { initializeApp } from 'firebase/app';\r\nimport { getAuth, setPersistence, browserSessionPersistence } from 'firebase/auth';\r\nimport { getFirestore } from 'firebase/firestore';\r\nimport { getStorage } from 'firebase/storage';\r\nimport { initializeConfig} from './config';\r\n\r\n// Initialize immediately\r\nconst config = initializeConfig();\r\nconst clientApp = initializeApp(config)\r\nconst auth = getAuth(clientApp);\r\nsetPersistence(auth, browserSessionPersistence); //to change later user should be able to choose persistance\r\nconst firestore = getFirestore(clientApp);\r\nconst storage = getStorage(clientApp);\r\n\r\nexport const TernSecureAuth = () => auth;\r\nexport const TernSecureFirestore = () => firestore;\r\nexport const TernSecureStorage = () => storage;","import { TernSecureAuth } from '../../utils/client-init'\r\nimport { signInWithEmailAndPassword, type UserCredential } from 'firebase/auth'\r\n\r\nexport interface SignInCredentials {\r\n email: string\r\n password: string\r\n}\r\n\r\nexport async function signInWithEmail({ \r\n email, \r\n password \r\n}: SignInCredentials): Promise<UserCredential> {\r\n const auth = TernSecureAuth()\r\n return signInWithEmailAndPassword(auth, email, password)\r\n} "]}
@@ -1,17 +0,0 @@
1
- 'use strict';
2
-
3
- var react = require('react');
4
-
5
- var TernSecureContext = react.createContext(null);
6
- var useTernSecure = () => {
7
- const context = react.useContext(TernSecureContext);
8
- if (!context) {
9
- throw new Error("useTernSecure must be used within a TernSecureProvider");
10
- }
11
- return context.authState;
12
- };
13
-
14
- exports.TernSecureContext = TernSecureContext;
15
- exports.useTernSecure = useTernSecure;
16
- //# sourceMappingURL=TernSecureCtx.cjs.map
17
- //# sourceMappingURL=TernSecureCtx.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/boundary/TernSecureCtx.tsx"],"names":["createContext","useContext"],"mappings":";;;;AAYa,IAAA,iBAAA,GAAoBA,oBAA4C,IAAI;AAE1E,IAAM,gBAAgB,MAAM;AACjC,EAAM,MAAA,OAAA,GAAUC,iBAAW,iBAAiB,CAAA;AAC5C,EAAA,IAAI,CAAC,OAAS,EAAA;AACZ,IAAM,MAAA,IAAI,MAAM,wDAAwD,CAAA;AAAA;AAE1E,EAAA,OAAO,OAAQ,CAAA,SAAA;AACjB","file":"TernSecureCtx.cjs","sourcesContent":["'use client'\r\n\r\nimport { createContext, useContext } from 'react';\r\nimport { AuthState } from '../app-router/client/TernSecureProvider';\r\n\r\n\r\nexport interface TernSecureContextType {\r\n authState: AuthState;\r\n}\r\n\r\n\r\n\r\nexport const TernSecureContext = createContext<TernSecureContextType | null>(null);\r\n\r\nexport const useTernSecure = () => {\r\n const context = useContext(TernSecureContext);\r\n if (!context) {\r\n throw new Error('useTernSecure must be used within a TernSecureProvider');\r\n }\r\n return context.authState;\r\n};\r\n\r\n"]}
@@ -1,30 +0,0 @@
1
- 'use strict';
2
-
3
- var react = require('react');
4
-
5
- var TernSecureContext = react.createContext(null);
6
- var useTernSecure = () => {
7
- const context = react.useContext(TernSecureContext);
8
- if (!context) {
9
- throw new Error("useTernSecure must be used within a TernSecureProvider");
10
- }
11
- return context.authState;
12
- };
13
-
14
- // src/boundary/hooks/useAuth.ts
15
- function useAuth() {
16
- const authState = useTernSecure();
17
- if (!authState) {
18
- throw new Error("Auth state not found");
19
- }
20
- return {
21
- userId: authState.userId,
22
- loading: authState.loading,
23
- error: authState.error,
24
- isSignedIn: authState.isSignedIn
25
- };
26
- }
27
-
28
- exports.useAuth = useAuth;
29
- //# sourceMappingURL=useAuth.cjs.map
30
- //# sourceMappingURL=useAuth.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/boundary/TernSecureCtx.tsx","../../../../src/boundary/hooks/useAuth.ts"],"names":["createContext","useContext"],"mappings":";;;;AAYO,IAAM,iBAAA,GAAoBA,oBAA4C,IAAI,CAAA;AAE1E,IAAM,gBAAgB,MAAM;AACjC,EAAM,MAAA,OAAA,GAAUC,iBAAW,iBAAiB,CAAA;AAC5C,EAAA,IAAI,CAAC,OAAS,EAAA;AACZ,IAAM,MAAA,IAAI,MAAM,wDAAwD,CAAA;AAAA;AAE1E,EAAA,OAAO,OAAQ,CAAA,SAAA;AACjB,CAAA;;;ACdO,SAAS,OAAqB,GAAA;AAKnC,EAAA,MAAM,YAAY,aAAc,EAAA;AAEhC,EAAA,IAAI,CAAC,SAAW,EAAA;AACd,IAAM,MAAA,IAAI,MAAM,sBAAsB,CAAA;AAAA;AAGxC,EAAO,OAAA;AAAA,IACL,QAAQ,SAAU,CAAA,MAAA;AAAA,IAClB,SAAS,SAAU,CAAA,OAAA;AAAA,IACnB,OAAO,SAAU,CAAA,KAAA;AAAA,IACjB,YAAY,SAAU,CAAA;AAAA,GACxB;AACF","file":"useAuth.cjs","sourcesContent":["'use client'\r\n\r\nimport { createContext, useContext } from 'react';\r\nimport { AuthState } from '../app-router/client/TernSecureProvider';\r\n\r\n\r\nexport interface TernSecureContextType {\r\n authState: AuthState;\r\n}\r\n\r\n\r\n\r\nexport const TernSecureContext = createContext<TernSecureContextType | null>(null);\r\n\r\nexport const useTernSecure = () => {\r\n const context = useContext(TernSecureContext);\r\n if (!context) {\r\n throw new Error('useTernSecure must be used within a TernSecureProvider');\r\n }\r\n return context.authState;\r\n};\r\n\r\n","'use client'\r\n\r\nimport { useContext } from 'react'\r\nimport { AuthState } from '../../app-router/client/TernSecureProvider'\r\nimport { TernSecureContext, useTernSecure } from '../TernSecureCtx'\r\n\r\nexport function useAuth(): AuthState {\r\n // Verify we're within the provider boundary\r\n // useInternalContext('useAuth')\r\n \r\n // Get the auth state from the AuthStateContext\r\n const authState = useTernSecure()\r\n \r\n if (!authState) {\r\n throw new Error('Auth state not found')\r\n }\r\n\r\n return {\r\n userId: authState.userId,\r\n loading: authState.loading,\r\n error: authState.error,\r\n isSignedIn: authState.isSignedIn\r\n }\r\n}"]}