@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.
- package/dist/cjs/app-router/client/TernSecureProvider.js +75 -0
- package/dist/cjs/app-router/client/TernSecureProvider.js.map +1 -0
- package/dist/cjs/app-router/server/TernSecureServerProvider.js +63 -0
- package/dist/cjs/app-router/server/TernSecureServerProvider.js.map +1 -0
- package/dist/cjs/app-router/server/auth.js +37 -0
- package/dist/cjs/app-router/server/auth.js.map +1 -0
- package/dist/cjs/boundary/TernSecureCtx.js +50 -0
- package/dist/cjs/boundary/TernSecureCtx.js.map +1 -0
- package/dist/cjs/boundary/hooks/useAuth.js +45 -0
- package/dist/cjs/boundary/hooks/useAuth.js.map +1 -0
- package/dist/cjs/components/sign-in.js +132 -0
- package/dist/cjs/components/sign-in.js.map +1 -0
- package/dist/cjs/errors.js +41 -0
- package/dist/cjs/errors.js.map +1 -0
- package/dist/cjs/index.js +49 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/types.js +17 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/cjs/utils/client-init.js +46 -0
- package/dist/cjs/utils/client-init.js.map +1 -0
- package/dist/cjs/utils/config.js +73 -0
- package/dist/cjs/utils/config.js.map +1 -0
- package/dist/cjs/utils/{create-styles.cjs → create-styles.js} +38 -14
- package/dist/cjs/utils/create-styles.js.map +1 -0
- package/dist/esm/app-router/client/TernSecureProvider.js +39 -5
- package/dist/esm/app-router/client/TernSecureProvider.js.map +1 -1
- package/dist/esm/app-router/server/TernSecureServerProvider.js +28 -6
- package/dist/esm/app-router/server/TernSecureServerProvider.js.map +1 -1
- package/dist/esm/app-router/server/auth.js +12 -4
- package/dist/esm/app-router/server/auth.js.map +1 -1
- package/dist/esm/boundary/TernSecureCtx.js +24 -2
- package/dist/esm/boundary/TernSecureCtx.js.map +1 -1
- package/dist/esm/boundary/hooks/useAuth.js +20 -3
- package/dist/esm/boundary/hooks/useAuth.js.map +1 -1
- package/dist/esm/components/sign-in.js +107 -6
- package/dist/esm/components/sign-in.js.map +1 -1
- package/dist/esm/errors.js +6 -6
- package/dist/esm/errors.js.map +1 -1
- package/dist/esm/index.js +17 -10
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/types.js +0 -2
- package/dist/esm/types.js.map +1 -1
- package/dist/esm/utils/client-init.js +19 -3
- package/dist/esm/utils/client-init.js.map +1 -1
- package/dist/esm/utils/config.js +46 -2
- package/dist/esm/utils/config.js.map +1 -1
- package/dist/esm/utils/create-styles.js +122 -2
- package/dist/esm/utils/create-styles.js.map +1 -1
- package/package.json +2 -14
- package/dist/cjs/app-router/client/TernSecureProvider.cjs +0 -84
- package/dist/cjs/app-router/client/TernSecureProvider.cjs.map +0 -1
- package/dist/cjs/app-router/server/TernSecureServerProvider.cjs +0 -95
- package/dist/cjs/app-router/server/TernSecureServerProvider.cjs.map +0 -1
- package/dist/cjs/app-router/server/auth.cjs +0 -71
- package/dist/cjs/app-router/server/auth.cjs.map +0 -1
- package/dist/cjs/boundary/TernSecureCtx.cjs +0 -17
- package/dist/cjs/boundary/TernSecureCtx.cjs.map +0 -1
- package/dist/cjs/boundary/hooks/useAuth.cjs +0 -30
- package/dist/cjs/boundary/hooks/useAuth.cjs.map +0 -1
- package/dist/cjs/components/sign-in.cjs +0 -291
- package/dist/cjs/components/sign-in.cjs.map +0 -1
- package/dist/cjs/errors.cjs +0 -19
- package/dist/cjs/errors.cjs.map +0 -1
- package/dist/cjs/index.cjs +0 -349
- package/dist/cjs/index.cjs.map +0 -1
- package/dist/cjs/types.cjs +0 -4
- package/dist/cjs/types.cjs.map +0 -1
- package/dist/cjs/utils/client-init.cjs +0 -68
- package/dist/cjs/utils/client-init.cjs.map +0 -1
- package/dist/cjs/utils/config.cjs +0 -50
- package/dist/cjs/utils/config.cjs.map +0 -1
- package/dist/cjs/utils/create-styles.cjs.map +0 -1
- package/dist/esm/app-router/client/TernSecureProvider.d.ts +0 -16
- package/dist/esm/app-router/server/TernSecureServerProvider.d.ts +0 -9
- package/dist/esm/app-router/server/auth.d.ts +0 -9
- package/dist/esm/boundary/TernSecureCtx.d.ts +0 -10
- package/dist/esm/boundary/hooks/useAuth.d.ts +0 -6
- package/dist/esm/chunk-27O3JVAU.js +0 -16
- package/dist/esm/chunk-27O3JVAU.js.map +0 -1
- package/dist/esm/chunk-4XFIX4FL.js +0 -14
- package/dist/esm/chunk-4XFIX4FL.js.map +0 -1
- package/dist/esm/chunk-7VKPI5HF.js +0 -15
- package/dist/esm/chunk-7VKPI5HF.js.map +0 -1
- package/dist/esm/chunk-EI37GOD7.js +0 -121
- package/dist/esm/chunk-EI37GOD7.js.map +0 -1
- package/dist/esm/chunk-EIOZNLP2.js +0 -109
- package/dist/esm/chunk-EIOZNLP2.js.map +0 -1
- package/dist/esm/chunk-FVV74XVR.js +0 -19
- package/dist/esm/chunk-FVV74XVR.js.map +0 -1
- package/dist/esm/chunk-ODVOZOJG.js +0 -28
- package/dist/esm/chunk-ODVOZOJG.js.map +0 -1
- package/dist/esm/chunk-SHRRIEFY.js +0 -19
- package/dist/esm/chunk-SHRRIEFY.js.map +0 -1
- package/dist/esm/chunk-UHGBSUM6.js +0 -46
- package/dist/esm/chunk-UHGBSUM6.js.map +0 -1
- package/dist/esm/components/sign-in.d.ts +0 -25
- package/dist/esm/errors.d.ts +0 -10
- package/dist/esm/index.d.ts +0 -15
- package/dist/esm/types.d.ts +0 -49
- package/dist/esm/utils/client-init.d.ts +0 -9
- package/dist/esm/utils/config.d.ts +0 -22
- package/dist/esm/utils/create-styles.d.ts +0 -100
package/dist/esm/utils/config.js
CHANGED
|
@@ -1,3 +1,47 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
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":[],"
|
|
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
|
-
|
|
2
|
-
|
|
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":[],"
|
|
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.
|
|
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
|
|
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}"]}
|