@tern-secure/nextjs 3.1.50 → 3.1.52
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.cjs +103 -0
- package/dist/cjs/app-router/client/TernSecureProvider.cjs.map +1 -0
- package/dist/cjs/app-router/server/TernSecureServerProvider.cjs +109 -0
- package/dist/cjs/app-router/server/TernSecureServerProvider.cjs.map +1 -0
- package/dist/cjs/app-router/server/auth.cjs +71 -0
- package/dist/cjs/app-router/server/auth.cjs.map +1 -0
- package/dist/cjs/boundary/TernSecureCtx.cjs +23 -0
- package/dist/cjs/boundary/TernSecureCtx.cjs.map +1 -0
- package/dist/cjs/boundary/hooks/use-auth.cjs +111 -0
- package/dist/cjs/boundary/hooks/use-auth.cjs.map +1 -0
- package/dist/{esm/index.cjs → cjs/components/sign-in.cjs} +12 -88
- package/dist/cjs/components/sign-in.cjs.map +1 -0
- package/dist/cjs/errors.cjs +19 -0
- package/dist/cjs/errors.cjs.map +1 -0
- package/dist/cjs/index.cjs +41 -22
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/types.cjs +4 -0
- package/dist/cjs/types.cjs.map +1 -0
- package/dist/cjs/utils/client-init.cjs +68 -0
- package/dist/cjs/utils/client-init.cjs.map +1 -0
- package/dist/cjs/utils/config.cjs +50 -0
- package/dist/cjs/utils/config.cjs.map +1 -0
- package/dist/cjs/utils/create-styles.cjs +125 -0
- package/dist/cjs/utils/create-styles.cjs.map +1 -0
- package/dist/esm/app-router/client/TernSecureProvider.d.ts +9 -0
- package/dist/esm/app-router/client/TernSecureProvider.js +6 -0
- package/dist/esm/app-router/client/TernSecureProvider.js.map +1 -0
- package/dist/esm/app-router/server/TernSecureServerProvider.d.ts +9 -0
- package/dist/esm/app-router/server/TernSecureServerProvider.js +7 -0
- package/dist/esm/app-router/server/TernSecureServerProvider.js.map +1 -0
- package/dist/esm/app-router/server/auth.d.ts +9 -0
- package/dist/esm/app-router/server/auth.js +5 -0
- package/dist/esm/app-router/server/auth.js.map +1 -0
- package/dist/esm/boundary/TernSecureCtx.d.ts +16 -0
- package/dist/esm/boundary/TernSecureCtx.js +3 -0
- package/dist/esm/boundary/TernSecureCtx.js.map +1 -0
- package/dist/esm/boundary/hooks/use-auth.d.ts +14 -0
- package/dist/esm/boundary/hooks/use-auth.js +6 -0
- package/dist/esm/boundary/hooks/use-auth.js.map +1 -0
- package/dist/esm/chunk-4XFIX4FL.js +14 -0
- package/dist/esm/chunk-4XFIX4FL.js.map +1 -0
- package/dist/esm/chunk-EI37GOD7.js +121 -0
- package/dist/esm/chunk-EI37GOD7.js.map +1 -0
- package/dist/esm/chunk-EIOZNLP2.js +109 -0
- package/dist/esm/chunk-EIOZNLP2.js.map +1 -0
- package/dist/esm/chunk-FVV74XVR.js +19 -0
- package/dist/esm/chunk-FVV74XVR.js.map +1 -0
- package/dist/esm/chunk-HHEFM7RH.js +40 -0
- package/dist/esm/chunk-HHEFM7RH.js.map +1 -0
- package/dist/esm/chunk-I2PGODCQ.js +17 -0
- package/dist/esm/chunk-I2PGODCQ.js.map +1 -0
- package/dist/esm/chunk-LLW7HUEK.js +45 -0
- package/dist/esm/chunk-LLW7HUEK.js.map +1 -0
- package/dist/esm/chunk-NOBAXS4Z.js +11 -0
- package/dist/esm/chunk-NOBAXS4Z.js.map +1 -0
- package/dist/esm/chunk-UHGBSUM6.js +46 -0
- package/dist/esm/chunk-UHGBSUM6.js.map +1 -0
- package/dist/esm/components/sign-in.d.ts +25 -0
- package/dist/esm/components/sign-in.js +7 -0
- package/dist/esm/components/sign-in.js.map +1 -0
- package/dist/esm/errors.d.ts +10 -0
- package/dist/esm/errors.js +16 -0
- package/dist/esm/errors.js.map +1 -0
- package/dist/esm/index.d.ts +16 -135
- package/dist/esm/index.js +9 -348
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/types.d.ts +49 -0
- package/dist/esm/types.js +3 -0
- package/dist/esm/types.js.map +1 -0
- package/dist/esm/utils/client-init.d.ts +9 -0
- package/dist/esm/utils/client-init.js +4 -0
- package/dist/esm/utils/client-init.js.map +1 -0
- package/dist/esm/utils/config.d.ts +22 -0
- package/dist/esm/utils/config.js +3 -0
- package/dist/esm/utils/config.js.map +1 -0
- package/dist/esm/utils/create-styles.d.ts +100 -0
- package/dist/esm/utils/create-styles.js +3 -0
- package/dist/esm/utils/create-styles.js.map +1 -0
- package/package.json +2 -2
- package/dist/cjs/index.d.cts +0 -135
- package/dist/cjs/index.d.ts +0 -135
- package/dist/cjs/index.js +0 -350
- package/dist/cjs/index.js.map +0 -1
- package/dist/esm/index.cjs.map +0 -1
- package/dist/esm/index.d.cts +0 -135
|
@@ -0,0 +1,103 @@
|
|
|
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
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
11
|
+
|
|
12
|
+
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
13
|
+
|
|
14
|
+
// src/utils/config.ts
|
|
15
|
+
var loadFireConfig = () => ({
|
|
16
|
+
apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || "",
|
|
17
|
+
authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || "",
|
|
18
|
+
projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || "",
|
|
19
|
+
storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || "",
|
|
20
|
+
messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || "",
|
|
21
|
+
appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || "",
|
|
22
|
+
measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || void 0
|
|
23
|
+
});
|
|
24
|
+
var validateConfig = (config2) => {
|
|
25
|
+
const requiredFields = [
|
|
26
|
+
"apiKey",
|
|
27
|
+
"authDomain",
|
|
28
|
+
"projectId",
|
|
29
|
+
"storageBucket",
|
|
30
|
+
"messagingSenderId",
|
|
31
|
+
"appId"
|
|
32
|
+
];
|
|
33
|
+
const errors = [];
|
|
34
|
+
requiredFields.forEach((field) => {
|
|
35
|
+
if (!config2[field]) {
|
|
36
|
+
errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`);
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
return {
|
|
40
|
+
isValid: errors.length === 0,
|
|
41
|
+
errors,
|
|
42
|
+
config: config2
|
|
43
|
+
};
|
|
44
|
+
};
|
|
45
|
+
var initializeConfig = () => {
|
|
46
|
+
const config2 = loadFireConfig();
|
|
47
|
+
const validationResult = validateConfig(config2);
|
|
48
|
+
if (!validationResult.isValid) {
|
|
49
|
+
throw new Error(
|
|
50
|
+
`Firebase configuration validation failed:
|
|
51
|
+
${validationResult.errors.join("\n")}`
|
|
52
|
+
);
|
|
53
|
+
}
|
|
54
|
+
return config2;
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
// src/utils/client-init.ts
|
|
58
|
+
var config = initializeConfig();
|
|
59
|
+
var clientApp = app.initializeApp(config);
|
|
60
|
+
var auth = auth$1.getAuth(clientApp);
|
|
61
|
+
auth$1.setPersistence(auth, auth$1.browserSessionPersistence);
|
|
62
|
+
firestore.getFirestore(clientApp);
|
|
63
|
+
storage.getStorage(clientApp);
|
|
64
|
+
var TernSecureAuth = () => auth;
|
|
65
|
+
var TernSecureContext = React__default.default.createContext(void 0);
|
|
66
|
+
var TernSecureCtxProvider = (props) => {
|
|
67
|
+
const { children, options } = props;
|
|
68
|
+
return /* @__PURE__ */ jsxRuntime.jsx(TernSecureContext.Provider, { value: { value: options }, children });
|
|
69
|
+
};
|
|
70
|
+
var auth2 = TernSecureAuth();
|
|
71
|
+
function TernSecureClientProvider({ children }) {
|
|
72
|
+
const [authState, setAuthState] = React.useState({
|
|
73
|
+
loading: true,
|
|
74
|
+
isSignedIn: false,
|
|
75
|
+
userId: null,
|
|
76
|
+
error: null
|
|
77
|
+
});
|
|
78
|
+
React__default.default.useEffect(() => {
|
|
79
|
+
const unsubscribe = auth$1.onAuthStateChanged(auth2, (user) => {
|
|
80
|
+
if (user) {
|
|
81
|
+
setAuthState({
|
|
82
|
+
loading: false,
|
|
83
|
+
isSignedIn: true,
|
|
84
|
+
userId: user.uid,
|
|
85
|
+
error: null
|
|
86
|
+
});
|
|
87
|
+
} else {
|
|
88
|
+
setAuthState({
|
|
89
|
+
loading: false,
|
|
90
|
+
isSignedIn: false,
|
|
91
|
+
userId: null,
|
|
92
|
+
error: null
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
return () => unsubscribe();
|
|
97
|
+
}, []);
|
|
98
|
+
return /* @__PURE__ */ jsxRuntime.jsx(TernSecureCtxProvider, { options: authState, children });
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
exports.TernSecureClientProvider = TernSecureClientProvider;
|
|
102
|
+
//# sourceMappingURL=TernSecureProvider.cjs.map
|
|
103
|
+
//# sourceMappingURL=TernSecureProvider.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
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","React","jsx","auth","useState","onAuthStateChanged"],"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 React from 'react'\r\n\r\ntype TernSecureState = {\r\n userId: string | null\r\n loading: boolean\r\n error: string | null\r\n isSignedIn: boolean\r\n}\r\n\r\n\r\n// Create context instance only when imported on client\r\nconst TernSecureContext = React.createContext<{value: TernSecureState} | undefined>(undefined);\r\n\r\nconst useInternalContext = (hookname?: string) => {\r\n const context = React.useContext(TernSecureContext)\r\n return context\r\n}\r\n\r\nconst TernSecureCtxProvider = (\r\n props: React.PropsWithChildren<{ options: TernSecureState }>,\r\n): React.JSX.Element => {\r\n const { children, options } = props;\r\n return <TernSecureContext.Provider value={{ value: options }}>{children}</TernSecureContext.Provider>;\r\n};\r\n\r\n\r\nexport {\r\n useInternalContext,\r\n TernSecureCtxProvider\r\n}","'use client'\r\n\r\nimport React, { useState } from 'react'\r\nimport { TernSecureAuth } from '../../utils/client-init'\r\nimport { onAuthStateChanged } from \"firebase/auth\"\r\nimport { useInternalContext, TernSecureCtxProvider } from '../../boundary/TernSecureCtx'\r\n\r\ntype TernSecureState = {\r\n userId: string | null\r\n loading: boolean\r\n error: string | null\r\n isSignedIn: boolean\r\n}\r\n\r\ninterface TernSecureClientProps {\r\n children: React.ReactNode\r\n}\r\n\r\nconst auth = TernSecureAuth()\r\n\r\nexport function TernSecureClientProvider({ children }: TernSecureClientProps) {\r\n const [authState, setAuthState] = useState<TernSecureState>({\r\n loading: true,\r\n isSignedIn: false,\r\n userId: null,\r\n error: null\r\n })\r\n\r\nReact.useEffect(() => {\r\n const unsubscribe = onAuthStateChanged(auth, (user) => {\r\n if (user) {\r\n setAuthState({\r\n loading: false,\r\n isSignedIn: true,\r\n userId: user.uid,\r\n error: null\r\n })\r\n } else {\r\n setAuthState({\r\n loading: false,\r\n isSignedIn: false,\r\n userId: null,\r\n error: null\r\n })\r\n }\r\n })\r\n \r\n return () => unsubscribe()\r\n }, [])\r\n\r\n\r\n return (\r\n <TernSecureCtxProvider options={authState}>\r\n {children}\r\n </TernSecureCtxProvider>\r\n )\r\n}"]}
|
|
@@ -0,0 +1,109 @@
|
|
|
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
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
11
|
+
|
|
12
|
+
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
13
|
+
|
|
14
|
+
// src/app-router/client/TernSecureProvider.tsx
|
|
15
|
+
|
|
16
|
+
// src/utils/config.ts
|
|
17
|
+
var loadFireConfig = () => ({
|
|
18
|
+
apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || "",
|
|
19
|
+
authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || "",
|
|
20
|
+
projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || "",
|
|
21
|
+
storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || "",
|
|
22
|
+
messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || "",
|
|
23
|
+
appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || "",
|
|
24
|
+
measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || void 0
|
|
25
|
+
});
|
|
26
|
+
var validateConfig = (config2) => {
|
|
27
|
+
const requiredFields = [
|
|
28
|
+
"apiKey",
|
|
29
|
+
"authDomain",
|
|
30
|
+
"projectId",
|
|
31
|
+
"storageBucket",
|
|
32
|
+
"messagingSenderId",
|
|
33
|
+
"appId"
|
|
34
|
+
];
|
|
35
|
+
const errors = [];
|
|
36
|
+
requiredFields.forEach((field) => {
|
|
37
|
+
if (!config2[field]) {
|
|
38
|
+
errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`);
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
return {
|
|
42
|
+
isValid: errors.length === 0,
|
|
43
|
+
errors,
|
|
44
|
+
config: config2
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
var initializeConfig = () => {
|
|
48
|
+
const config2 = loadFireConfig();
|
|
49
|
+
const validationResult = validateConfig(config2);
|
|
50
|
+
if (!validationResult.isValid) {
|
|
51
|
+
throw new Error(
|
|
52
|
+
`Firebase configuration validation failed:
|
|
53
|
+
${validationResult.errors.join("\n")}`
|
|
54
|
+
);
|
|
55
|
+
}
|
|
56
|
+
return config2;
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
// src/utils/client-init.ts
|
|
60
|
+
var config = initializeConfig();
|
|
61
|
+
var clientApp = app.initializeApp(config);
|
|
62
|
+
var auth = auth$1.getAuth(clientApp);
|
|
63
|
+
auth$1.setPersistence(auth, auth$1.browserSessionPersistence);
|
|
64
|
+
firestore.getFirestore(clientApp);
|
|
65
|
+
storage.getStorage(clientApp);
|
|
66
|
+
var TernSecureAuth = () => auth;
|
|
67
|
+
var TernSecureContext = React__default.default.createContext(void 0);
|
|
68
|
+
var TernSecureCtxProvider = (props) => {
|
|
69
|
+
const { children, options } = props;
|
|
70
|
+
return /* @__PURE__ */ jsxRuntime.jsx(TernSecureContext.Provider, { value: { value: options }, children });
|
|
71
|
+
};
|
|
72
|
+
var auth2 = TernSecureAuth();
|
|
73
|
+
function TernSecureClientProvider({ children }) {
|
|
74
|
+
const [authState, setAuthState] = React.useState({
|
|
75
|
+
loading: true,
|
|
76
|
+
isSignedIn: false,
|
|
77
|
+
userId: null,
|
|
78
|
+
error: null
|
|
79
|
+
});
|
|
80
|
+
React__default.default.useEffect(() => {
|
|
81
|
+
const unsubscribe = auth$1.onAuthStateChanged(auth2, (user) => {
|
|
82
|
+
if (user) {
|
|
83
|
+
setAuthState({
|
|
84
|
+
loading: false,
|
|
85
|
+
isSignedIn: true,
|
|
86
|
+
userId: user.uid,
|
|
87
|
+
error: null
|
|
88
|
+
});
|
|
89
|
+
} else {
|
|
90
|
+
setAuthState({
|
|
91
|
+
loading: false,
|
|
92
|
+
isSignedIn: false,
|
|
93
|
+
userId: null,
|
|
94
|
+
error: null
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
return () => unsubscribe();
|
|
99
|
+
}, []);
|
|
100
|
+
return /* @__PURE__ */ jsxRuntime.jsx(TernSecureCtxProvider, { options: authState, children });
|
|
101
|
+
}
|
|
102
|
+
async function TernSecureProvider({ children }) {
|
|
103
|
+
const output = /* @__PURE__ */ jsxRuntime.jsx(TernSecureClientProvider, { children });
|
|
104
|
+
return output;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
exports.TernSecureProvider = TernSecureProvider;
|
|
108
|
+
//# sourceMappingURL=TernSecureServerProvider.cjs.map
|
|
109
|
+
//# sourceMappingURL=TernSecureServerProvider.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
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","React","jsx","auth","useState","onAuthStateChanged"],"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 React from 'react'\r\n\r\ntype TernSecureState = {\r\n userId: string | null\r\n loading: boolean\r\n error: string | null\r\n isSignedIn: boolean\r\n}\r\n\r\n\r\n// Create context instance only when imported on client\r\nconst TernSecureContext = React.createContext<{value: TernSecureState} | undefined>(undefined);\r\n\r\nconst useInternalContext = (hookname?: string) => {\r\n const context = React.useContext(TernSecureContext)\r\n return context\r\n}\r\n\r\nconst TernSecureCtxProvider = (\r\n props: React.PropsWithChildren<{ options: TernSecureState }>,\r\n): React.JSX.Element => {\r\n const { children, options } = props;\r\n return <TernSecureContext.Provider value={{ value: options }}>{children}</TernSecureContext.Provider>;\r\n};\r\n\r\n\r\nexport {\r\n useInternalContext,\r\n TernSecureCtxProvider\r\n}","'use client'\r\n\r\nimport React, { useState } from 'react'\r\nimport { TernSecureAuth } from '../../utils/client-init'\r\nimport { onAuthStateChanged } from \"firebase/auth\"\r\nimport { useInternalContext, TernSecureCtxProvider } from '../../boundary/TernSecureCtx'\r\n\r\ntype TernSecureState = {\r\n userId: string | null\r\n loading: boolean\r\n error: string | null\r\n isSignedIn: boolean\r\n}\r\n\r\ninterface TernSecureClientProps {\r\n children: React.ReactNode\r\n}\r\n\r\nconst auth = TernSecureAuth()\r\n\r\nexport function TernSecureClientProvider({ children }: TernSecureClientProps) {\r\n const [authState, setAuthState] = useState<TernSecureState>({\r\n loading: true,\r\n isSignedIn: false,\r\n userId: null,\r\n error: null\r\n })\r\n\r\nReact.useEffect(() => {\r\n const unsubscribe = onAuthStateChanged(auth, (user) => {\r\n if (user) {\r\n setAuthState({\r\n loading: false,\r\n isSignedIn: true,\r\n userId: user.uid,\r\n error: null\r\n })\r\n } else {\r\n setAuthState({\r\n loading: false,\r\n isSignedIn: false,\r\n userId: null,\r\n error: null\r\n })\r\n }\r\n })\r\n \r\n return () => unsubscribe()\r\n }, [])\r\n\r\n\r\n return (\r\n <TernSecureCtxProvider options={authState}>\r\n {children}\r\n </TernSecureCtxProvider>\r\n )\r\n}","import { TernSecureClientProvider } from \"../client/TernSecureProvider\";\r\nimport React, { ReactNode } from \"react\";\r\n\r\ninterface TernSecureProviderProps {\r\n children: ReactNode;\r\n}\r\n\r\n\r\n\r\nexport async function TernSecureProvider({ children }: TernSecureProviderProps) {\r\n // Check if the children contain html/body tags\r\n const output = (\r\n <TernSecureClientProvider>\r\n {children}\r\n </TernSecureClientProvider>\r\n );\r\n\r\n // For non-root layouts, wrap normally\r\n return output;\r\n}"]}
|
|
@@ -0,0 +1,71 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
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} "]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
5
|
+
|
|
6
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
7
|
+
|
|
8
|
+
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
9
|
+
|
|
10
|
+
var TernSecureContext = React__default.default.createContext(void 0);
|
|
11
|
+
var useInternalContext = (hookname) => {
|
|
12
|
+
const context = React__default.default.useContext(TernSecureContext);
|
|
13
|
+
return context;
|
|
14
|
+
};
|
|
15
|
+
var TernSecureCtxProvider = (props) => {
|
|
16
|
+
const { children, options } = props;
|
|
17
|
+
return /* @__PURE__ */ jsxRuntime.jsx(TernSecureContext.Provider, { value: { value: options }, children });
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
exports.TernSecureCtxProvider = TernSecureCtxProvider;
|
|
21
|
+
exports.useInternalContext = useInternalContext;
|
|
22
|
+
//# sourceMappingURL=TernSecureCtx.cjs.map
|
|
23
|
+
//# sourceMappingURL=TernSecureCtx.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/boundary/TernSecureCtx.tsx"],"names":["React","jsx"],"mappings":";;;;;;;;;AAaA,IAAM,iBAAA,GAAoBA,sBAAM,CAAA,aAAA,CAAoD,KAAS,CAAA,CAAA;AAEvF,IAAA,kBAAA,GAAqB,CAAC,QAAsB,KAAA;AAChD,EAAM,MAAA,OAAA,GAAUA,sBAAM,CAAA,UAAA,CAAW,iBAAiB,CAAA;AAClD,EAAO,OAAA,OAAA;AACT;AAEM,IAAA,qBAAA,GAAwB,CAC5B,KACsB,KAAA;AACtB,EAAM,MAAA,EAAE,QAAU,EAAA,OAAA,EAAY,GAAA,KAAA;AAC9B,EAAO,uBAAAC,cAAA,CAAC,kBAAkB,QAAlB,EAAA,EAA2B,OAAO,EAAE,KAAA,EAAO,OAAQ,EAAA,EAAI,QAAS,EAAA,CAAA;AAC1E","file":"TernSecureCtx.cjs","sourcesContent":["'use client'\r\n\r\nimport React from 'react'\r\n\r\ntype TernSecureState = {\r\n userId: string | null\r\n loading: boolean\r\n error: string | null\r\n isSignedIn: boolean\r\n}\r\n\r\n\r\n// Create context instance only when imported on client\r\nconst TernSecureContext = React.createContext<{value: TernSecureState} | undefined>(undefined);\r\n\r\nconst useInternalContext = (hookname?: string) => {\r\n const context = React.useContext(TernSecureContext)\r\n return context\r\n}\r\n\r\nconst TernSecureCtxProvider = (\r\n props: React.PropsWithChildren<{ options: TernSecureState }>,\r\n): React.JSX.Element => {\r\n const { children, options } = props;\r\n return <TernSecureContext.Provider value={{ value: options }}>{children}</TernSecureContext.Provider>;\r\n};\r\n\r\n\r\nexport {\r\n useInternalContext,\r\n TernSecureCtxProvider\r\n}"]}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var auth$1 = require('firebase/auth');
|
|
5
|
+
var app = require('firebase/app');
|
|
6
|
+
var firestore = require('firebase/firestore');
|
|
7
|
+
var storage = require('firebase/storage');
|
|
8
|
+
require('react/jsx-runtime');
|
|
9
|
+
|
|
10
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
11
|
+
|
|
12
|
+
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
13
|
+
|
|
14
|
+
// src/utils/config.ts
|
|
15
|
+
var loadFireConfig = () => ({
|
|
16
|
+
apiKey: process.env.NEXT_PUBLIC_FIREBASE_API_KEY || "",
|
|
17
|
+
authDomain: process.env.NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN || "",
|
|
18
|
+
projectId: process.env.NEXT_PUBLIC_FIREBASE_PROJECT_ID || "",
|
|
19
|
+
storageBucket: process.env.NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET || "",
|
|
20
|
+
messagingSenderId: process.env.NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID || "",
|
|
21
|
+
appId: process.env.NEXT_PUBLIC_FIREBASE_APP_ID || "",
|
|
22
|
+
measurementId: process.env.NEXT_PUBLIC_FIREBASE_MEASUREMENT_ID || void 0
|
|
23
|
+
});
|
|
24
|
+
var validateConfig = (config2) => {
|
|
25
|
+
const requiredFields = [
|
|
26
|
+
"apiKey",
|
|
27
|
+
"authDomain",
|
|
28
|
+
"projectId",
|
|
29
|
+
"storageBucket",
|
|
30
|
+
"messagingSenderId",
|
|
31
|
+
"appId"
|
|
32
|
+
];
|
|
33
|
+
const errors = [];
|
|
34
|
+
requiredFields.forEach((field) => {
|
|
35
|
+
if (!config2[field]) {
|
|
36
|
+
errors.push(`Missing required field: NEXT_PUBLIC_FIREBASE_${String(field).toUpperCase()}`);
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
return {
|
|
40
|
+
isValid: errors.length === 0,
|
|
41
|
+
errors,
|
|
42
|
+
config: config2
|
|
43
|
+
};
|
|
44
|
+
};
|
|
45
|
+
var initializeConfig = () => {
|
|
46
|
+
const config2 = loadFireConfig();
|
|
47
|
+
const validationResult = validateConfig(config2);
|
|
48
|
+
if (!validationResult.isValid) {
|
|
49
|
+
throw new Error(
|
|
50
|
+
`Firebase configuration validation failed:
|
|
51
|
+
${validationResult.errors.join("\n")}`
|
|
52
|
+
);
|
|
53
|
+
}
|
|
54
|
+
return config2;
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
// src/utils/client-init.ts
|
|
58
|
+
var config = initializeConfig();
|
|
59
|
+
var clientApp = app.initializeApp(config);
|
|
60
|
+
var auth = auth$1.getAuth(clientApp);
|
|
61
|
+
auth$1.setPersistence(auth, auth$1.browserSessionPersistence);
|
|
62
|
+
firestore.getFirestore(clientApp);
|
|
63
|
+
storage.getStorage(clientApp);
|
|
64
|
+
var TernSecureAuth = () => auth;
|
|
65
|
+
var TernSecureContext = React__default.default.createContext(void 0);
|
|
66
|
+
var useInternalContext = (hookname) => {
|
|
67
|
+
const context = React__default.default.useContext(TernSecureContext);
|
|
68
|
+
return context;
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
// src/boundary/hooks/use-auth.ts
|
|
72
|
+
function useAuth() {
|
|
73
|
+
const auth2 = React.useMemo(() => TernSecureAuth(), []);
|
|
74
|
+
const [authState, setAuthState] = React.useState({
|
|
75
|
+
loading: true,
|
|
76
|
+
isSignedIn: false,
|
|
77
|
+
userId: null,
|
|
78
|
+
error: null
|
|
79
|
+
});
|
|
80
|
+
React.useEffect(() => {
|
|
81
|
+
const unsubscribe = auth$1.onAuthStateChanged(auth2, (user) => {
|
|
82
|
+
if (user) {
|
|
83
|
+
setAuthState({
|
|
84
|
+
loading: false,
|
|
85
|
+
isSignedIn: true,
|
|
86
|
+
userId: user.uid,
|
|
87
|
+
error: null
|
|
88
|
+
});
|
|
89
|
+
} else {
|
|
90
|
+
setAuthState({
|
|
91
|
+
loading: false,
|
|
92
|
+
isSignedIn: false,
|
|
93
|
+
userId: null,
|
|
94
|
+
error: null
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
return () => unsubscribe();
|
|
99
|
+
}, [auth2]);
|
|
100
|
+
useInternalContext();
|
|
101
|
+
return {
|
|
102
|
+
loading: authState.loading,
|
|
103
|
+
isSignedIn: authState.isSignedIn,
|
|
104
|
+
userId: authState.userId,
|
|
105
|
+
error: authState.error
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
exports.useAuth = useAuth;
|
|
110
|
+
//# sourceMappingURL=use-auth.cjs.map
|
|
111
|
+
//# sourceMappingURL=use-auth.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/utils/config.ts","../../../../src/utils/client-init.ts","../../../../src/boundary/TernSecureCtx.tsx","../../../../src/boundary/hooks/use-auth.ts"],"names":["config","initializeApp","getAuth","setPersistence","browserSessionPersistence","getFirestore","getStorage","React","auth","useMemo","useState","useEffect","onAuthStateChanged"],"mappings":"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","file":"use-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;","'use client'\r\n\r\nimport React from 'react'\r\n\r\ntype TernSecureState = {\r\n userId: string | null\r\n loading: boolean\r\n error: string | null\r\n isSignedIn: boolean\r\n}\r\n\r\n\r\n// Create context instance only when imported on client\r\nconst TernSecureContext = React.createContext<{value: TernSecureState} | undefined>(undefined);\r\n\r\nconst useInternalContext = (hookname?: string) => {\r\n const context = React.useContext(TernSecureContext)\r\n return context\r\n}\r\n\r\nconst TernSecureCtxProvider = (\r\n props: React.PropsWithChildren<{ options: TernSecureState }>,\r\n): React.JSX.Element => {\r\n const { children, options } = props;\r\n return <TernSecureContext.Provider value={{ value: options }}>{children}</TernSecureContext.Provider>;\r\n};\r\n\r\n\r\nexport {\r\n useInternalContext,\r\n TernSecureCtxProvider\r\n}","'use client'\r\n\r\nimport { useEffect, useState, useMemo } from 'react'\r\nimport { onAuthStateChanged } from 'firebase/auth'\r\nimport { TernSecureAuth } from '../../utils/client-init'\r\nimport { useInternalContext } from '../TernSecureCtx'\r\n\r\nexport interface AuthState {\r\n userId: string | null\r\n loading: boolean;\r\n error: Error | null;\r\n isSignedIn: boolean;\r\n}\r\n\r\nexport function useAuth() {\r\n const auth = useMemo(() => TernSecureAuth(), [])\r\n const [authState, setAuthState] = useState<AuthState>({\r\n loading: true,\r\n isSignedIn: false,\r\n userId: null,\r\n error: null\r\n })\r\n\r\n\r\n useEffect(() => {\r\n const unsubscribe = onAuthStateChanged(auth, (user) => {\r\n if (user) {\r\n setAuthState({\r\n loading: false,\r\n isSignedIn: true,\r\n userId: user.uid,\r\n error: null\r\n })\r\n } else {\r\n setAuthState({\r\n loading: false,\r\n isSignedIn: false,\r\n userId: null,\r\n error: null\r\n })\r\n }\r\n })\r\n \r\n return () => unsubscribe()\r\n }, [auth])\r\n\r\n useInternalContext('useAuth')\r\n return {\r\n loading: authState.loading,\r\n isSignedIn: authState.isSignedIn,\r\n userId: authState.userId,\r\n error: authState.error\r\n }\r\n}"]}
|
|
@@ -1,17 +1,13 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
+
var react = require('react');
|
|
3
4
|
var app = require('firebase/app');
|
|
4
5
|
var auth$1 = require('firebase/auth');
|
|
5
|
-
var firestore
|
|
6
|
-
var storage
|
|
7
|
-
var React = require('react');
|
|
6
|
+
var firestore = require('firebase/firestore');
|
|
7
|
+
var storage = require('firebase/storage');
|
|
8
8
|
var jsxRuntime = require('react/jsx-runtime');
|
|
9
9
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
13
|
-
|
|
14
|
-
// src/utils/client-init.ts
|
|
10
|
+
// src/components/sign-in.tsx
|
|
15
11
|
|
|
16
12
|
// src/utils/config.ts
|
|
17
13
|
var loadFireConfig = () => ({
|
|
@@ -61,11 +57,9 @@ var config = initializeConfig();
|
|
|
61
57
|
var clientApp = app.initializeApp(config);
|
|
62
58
|
var auth = auth$1.getAuth(clientApp);
|
|
63
59
|
auth$1.setPersistence(auth, auth$1.browserSessionPersistence);
|
|
64
|
-
|
|
65
|
-
|
|
60
|
+
firestore.getFirestore(clientApp);
|
|
61
|
+
storage.getStorage(clientApp);
|
|
66
62
|
var TernSecureAuth = () => auth;
|
|
67
|
-
var TernSecureFirestore = () => firestore;
|
|
68
|
-
var TernSecureStorage = () => storage;
|
|
69
63
|
async function signInWithEmail({
|
|
70
64
|
email,
|
|
71
65
|
password
|
|
@@ -73,65 +67,6 @@ async function signInWithEmail({
|
|
|
73
67
|
const auth2 = TernSecureAuth();
|
|
74
68
|
return auth$1.signInWithEmailAndPassword(auth2, email, password);
|
|
75
69
|
}
|
|
76
|
-
var INTERNAL_CONTEXT_KEY = Symbol("TERN_SECURE_CONTEXT");
|
|
77
|
-
var TernSecureContext = React.createContext(null);
|
|
78
|
-
var useInternalContext = (hookName) => {
|
|
79
|
-
const context = React.useContext(TernSecureContext);
|
|
80
|
-
if (!context || context._contextKey !== INTERNAL_CONTEXT_KEY) {
|
|
81
|
-
throw new Error(
|
|
82
|
-
`${hookName || "Hook"} must be used within TernSecureProvider. Please wrap your component with TernSecureProvider.`
|
|
83
|
-
);
|
|
84
|
-
}
|
|
85
|
-
return context;
|
|
86
|
-
};
|
|
87
|
-
function TernSecureClientProvider({ children }) {
|
|
88
|
-
const contextValue = React__default.default.useMemo(
|
|
89
|
-
() => ({ _contextKey: INTERNAL_CONTEXT_KEY }),
|
|
90
|
-
[]
|
|
91
|
-
);
|
|
92
|
-
return /* @__PURE__ */ jsxRuntime.jsx(TernSecureContext.Provider, { value: contextValue, children });
|
|
93
|
-
}
|
|
94
|
-
TernSecureClientProvider.displayName = "TernSecureClientProvider";
|
|
95
|
-
async function TernSecureProvider({ children }) {
|
|
96
|
-
const output = /* @__PURE__ */ jsxRuntime.jsx(TernSecureClientProvider, { children });
|
|
97
|
-
return output;
|
|
98
|
-
}
|
|
99
|
-
function useAuth() {
|
|
100
|
-
const auth2 = React.useMemo(() => TernSecureAuth(), []);
|
|
101
|
-
const [authState, setAuthState] = React.useState({
|
|
102
|
-
loading: true,
|
|
103
|
-
isSignedIn: false,
|
|
104
|
-
userId: null,
|
|
105
|
-
error: null
|
|
106
|
-
});
|
|
107
|
-
React.useEffect(() => {
|
|
108
|
-
const unsubscribe = auth$1.onAuthStateChanged(auth2, (user) => {
|
|
109
|
-
if (user) {
|
|
110
|
-
setAuthState({
|
|
111
|
-
loading: false,
|
|
112
|
-
isSignedIn: true,
|
|
113
|
-
userId: user.uid,
|
|
114
|
-
error: null
|
|
115
|
-
});
|
|
116
|
-
} else {
|
|
117
|
-
setAuthState({
|
|
118
|
-
loading: false,
|
|
119
|
-
isSignedIn: false,
|
|
120
|
-
userId: null,
|
|
121
|
-
error: null
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
});
|
|
125
|
-
return () => unsubscribe();
|
|
126
|
-
}, [auth2]);
|
|
127
|
-
useInternalContext("useAuth");
|
|
128
|
-
return {
|
|
129
|
-
loading: authState.loading,
|
|
130
|
-
isSignedIn: authState.isSignedIn,
|
|
131
|
-
userId: authState.userId,
|
|
132
|
-
error: authState.error
|
|
133
|
-
};
|
|
134
|
-
}
|
|
135
70
|
|
|
136
71
|
// src/utils/create-styles.ts
|
|
137
72
|
var PREFIX = "tern";
|
|
@@ -258,10 +193,10 @@ function SignIn({
|
|
|
258
193
|
style,
|
|
259
194
|
customStyles = {}
|
|
260
195
|
}) {
|
|
261
|
-
const [email, setEmail] =
|
|
262
|
-
const [password, setPassword] =
|
|
263
|
-
const [loading, setLoading] =
|
|
264
|
-
const [error, setError] =
|
|
196
|
+
const [email, setEmail] = react.useState("");
|
|
197
|
+
const [password, setPassword] = react.useState("");
|
|
198
|
+
const [loading, setLoading] = react.useState(false);
|
|
199
|
+
const [error, setError] = react.useState("");
|
|
265
200
|
const handleSubmit = async (e) => {
|
|
266
201
|
e.preventDefault();
|
|
267
202
|
setLoading(true);
|
|
@@ -352,16 +287,5 @@ function SignIn({
|
|
|
352
287
|
}
|
|
353
288
|
|
|
354
289
|
exports.SignIn = SignIn;
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
exports.TernSecureContext = TernSecureContext;
|
|
358
|
-
exports.TernSecureFirestore = TernSecureFirestore;
|
|
359
|
-
exports.TernSecureProvider = TernSecureProvider;
|
|
360
|
-
exports.TernSecureStorage = TernSecureStorage;
|
|
361
|
-
exports.loadFireConfig = loadFireConfig;
|
|
362
|
-
exports.signInWithEmail = signInWithEmail;
|
|
363
|
-
exports.useAuth = useAuth;
|
|
364
|
-
exports.useInternalContext = useInternalContext;
|
|
365
|
-
exports.validateConfig = validateConfig;
|
|
366
|
-
//# sourceMappingURL=index.cjs.map
|
|
367
|
-
//# sourceMappingURL=index.cjs.map
|
|
290
|
+
//# sourceMappingURL=sign-in.cjs.map
|
|
291
|
+
//# sourceMappingURL=sign-in.cjs.map
|