@tern-secure/nextjs 1.9.1 → 1.9.2
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/app-router/client/providers/ternSecureClientProvider.js +10 -5
- package/dist/app-router/client/providers/ternSecureClientProvider.js.map +1 -1
- package/dist/app-router/server/providers/TernSecureServerProvider.d.ts +1 -1
- package/dist/app-router/server/providers/TernSecureServerProvider.js +23 -1
- package/dist/app-router/server/providers/TernSecureServerProvider.js.map +1 -1
- package/dist/hooks/useAuth.d.ts +7 -2
- package/dist/hooks/useAuth.js +4 -23
- package/dist/hooks/useAuth.js.map +1 -1
- package/dist/types/ternsecure.d.ts +1 -0
- package/package.json +1 -1
|
@@ -7,7 +7,8 @@ const createTernSecureContext = () => {
|
|
|
7
7
|
user: null,
|
|
8
8
|
loading: true,
|
|
9
9
|
error: null,
|
|
10
|
-
initialized: false
|
|
10
|
+
initialized: false,
|
|
11
|
+
isSignedIn: false
|
|
11
12
|
};
|
|
12
13
|
return createContext(initialAuthState);
|
|
13
14
|
};
|
|
@@ -28,7 +29,8 @@ export function TernSecureClientProvider({ children }) {
|
|
|
28
29
|
user: null,
|
|
29
30
|
loading: true,
|
|
30
31
|
error: null,
|
|
31
|
-
initialized: false
|
|
32
|
+
initialized: false,
|
|
33
|
+
isSignedIn: false
|
|
32
34
|
});
|
|
33
35
|
useEffect(() => {
|
|
34
36
|
try {
|
|
@@ -38,14 +40,16 @@ export function TernSecureClientProvider({ children }) {
|
|
|
38
40
|
user,
|
|
39
41
|
loading: false,
|
|
40
42
|
error: null,
|
|
41
|
-
initialized: true
|
|
43
|
+
initialized: true,
|
|
44
|
+
isSignedIn: !!user
|
|
42
45
|
});
|
|
43
46
|
}, (error) => {
|
|
44
47
|
setAuthState({
|
|
45
48
|
user: null,
|
|
46
49
|
loading: false,
|
|
47
50
|
error,
|
|
48
|
-
initialized: true
|
|
51
|
+
initialized: true,
|
|
52
|
+
isSignedIn: false
|
|
49
53
|
});
|
|
50
54
|
});
|
|
51
55
|
return () => unsubscribe();
|
|
@@ -55,7 +59,8 @@ export function TernSecureClientProvider({ children }) {
|
|
|
55
59
|
user: null,
|
|
56
60
|
loading: false,
|
|
57
61
|
error: error,
|
|
58
|
-
initialized: true
|
|
62
|
+
initialized: true,
|
|
63
|
+
isSignedIn: false
|
|
59
64
|
});
|
|
60
65
|
}
|
|
61
66
|
}, []);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ternSecureClientProvider.js","sourceRoot":"","sources":["../../../../src/app-router/client/providers/ternSecureClientProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AAGlD,oDAAoD;AACpD,MAAM,uBAAuB,GAAG,GAAG,EAAE;IACnC,MAAM,gBAAgB,GAAc;QAClC,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,KAAK;
|
|
1
|
+
{"version":3,"file":"ternSecureClientProvider.js","sourceRoot":"","sources":["../../../../src/app-router/client/providers/ternSecureClientProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AAGlD,oDAAoD;AACpD,MAAM,uBAAuB,GAAG,GAAG,EAAE;IACnC,MAAM,gBAAgB,GAAc;QAClC,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,KAAK;QAClB,UAAU,EAAE,KAAK;KAClB,CAAA;IAED,OAAO,aAAa,CAAY,gBAAgB,CAAC,CAAA;AACnD,CAAC,CAAA;AAED,4CAA4C;AAC5C,MAAM,iBAAiB,GAAG,uBAAuB,EAAE,CAAA;AAEnD,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,EAAE;IAChC,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAA;IACxE,CAAC;IAED,MAAM,OAAO,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAA;IAC7C,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAA;IAC/E,CAAC;IACD,OAAO,OAAO,CAAA;AAChB,CAAC,CAAA;AAMD,MAAM,UAAU,wBAAwB,CAAC,EAAE,QAAQ,EAAyB;IAC1E,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAY;QACpD,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,KAAK;QAClB,UAAU,EAAE,KAAK;KAClB,CAAC,CAAA;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,iBAAiB,EAAE,CAAA;YAChC,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CACzC,CAAC,IAAI,EAAE,EAAE;gBACP,YAAY,CAAC;oBACX,IAAI;oBACJ,OAAO,EAAE,KAAK;oBACd,KAAK,EAAE,IAAI;oBACX,WAAW,EAAE,IAAI;oBACjB,UAAU,EAAE,CAAC,CAAC,IAAI;iBACnB,CAAC,CAAA;YACJ,CAAC,EACD,CAAC,KAAK,EAAE,EAAE;gBACR,YAAY,CAAC;oBACX,IAAI,EAAE,IAAI;oBACV,OAAO,EAAE,KAAK;oBACd,KAAK;oBACL,WAAW,EAAE,IAAI;oBACjB,UAAU,EAAE,KAAK;iBAClB,CAAC,CAAA;YACJ,CAAC,CACF,CAAA;YAED,OAAO,GAAG,EAAE,CAAC,WAAW,EAAE,CAAA;QAC5B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,YAAY,CAAC;gBACX,IAAI,EAAE,IAAI;gBACV,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,KAAc;gBACrB,WAAW,EAAE,IAAI;gBACjB,UAAU,EAAE,KAAK;aAClB,CAAC,CAAA;QACJ,CAAC;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,CACL,oBAAC,iBAAiB,CAAC,QAAQ,IAAC,KAAK,EAAE,SAAS,IACzC,QAAQ,CACkB,CAC9B,CAAA;AACH,CAAC"}
|
|
@@ -2,5 +2,5 @@ import React, { ReactNode } from 'react';
|
|
|
2
2
|
interface TernSecureProviderProps {
|
|
3
3
|
children: ReactNode;
|
|
4
4
|
}
|
|
5
|
-
export declare function TernSecureProvider({ children }: TernSecureProviderProps): React.JSX.Element;
|
|
5
|
+
export declare function TernSecureProvider({ children }: TernSecureProviderProps): React.JSX.Element | (string | number | React.ReactElement<any, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode>)[] | null | undefined;
|
|
6
6
|
export {};
|
|
@@ -1,8 +1,30 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import dynamic from 'next/dynamic';
|
|
3
3
|
// Dynamically import the client provider with no SSR
|
|
4
|
-
const TernSecureClientProvider = dynamic(() => import('../../client/providers/ternSecureClientProvider').then(mod => mod.TernSecureClientProvider), {
|
|
4
|
+
const TernSecureClientProvider = dynamic(() => import('../../client/providers/ternSecureClientProvider').then(mod => mod.TernSecureClientProvider), {
|
|
5
|
+
ssr: false,
|
|
6
|
+
loading: () => null // Return null or a loading indicator
|
|
7
|
+
});
|
|
5
8
|
export function TernSecureProvider({ children }) {
|
|
9
|
+
// Check if the children contain html/body tags
|
|
10
|
+
const isRootLayout = React.Children.toArray(children).some(child => React.isValidElement(child) && child.type === 'html');
|
|
11
|
+
if (isRootLayout) {
|
|
12
|
+
// If this is the root layout, inject our provider after the body tag
|
|
13
|
+
return React.Children.map(children, child => {
|
|
14
|
+
if (React.isValidElement(child) && child.type === 'html') {
|
|
15
|
+
return React.cloneElement(child, {}, React.Children.map(child.props.children, bodyChild => {
|
|
16
|
+
if (React.isValidElement(bodyChild) && bodyChild.type === 'body') {
|
|
17
|
+
// Type assertion to access props safely
|
|
18
|
+
const bodyProps = bodyChild.props;
|
|
19
|
+
return React.cloneElement(bodyChild, {}, React.createElement(TernSecureClientProvider, null, bodyProps.children));
|
|
20
|
+
}
|
|
21
|
+
return bodyChild;
|
|
22
|
+
}));
|
|
23
|
+
}
|
|
24
|
+
return child;
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
// For non-root layouts, wrap normally
|
|
6
28
|
return React.createElement(TernSecureClientProvider, null, children);
|
|
7
29
|
}
|
|
8
30
|
//# sourceMappingURL=TernSecureServerProvider.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TernSecureServerProvider.js","sourceRoot":"","sources":["../../../../src/app-router/server/providers/TernSecureServerProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AACzC,OAAO,OAAO,MAAM,cAAc,CAAA;AAMlC,qDAAqD;AACrD,MAAM,wBAAwB,GAAG,OAAO,CACtC,GAAG,EAAE,CAAC,MAAM,CAAC,iDAAiD,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,wBAAwB,CAAC,EACzG,
|
|
1
|
+
{"version":3,"file":"TernSecureServerProvider.js","sourceRoot":"","sources":["../../../../src/app-router/server/providers/TernSecureServerProvider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AACzC,OAAO,OAAO,MAAM,cAAc,CAAA;AAMlC,qDAAqD;AACrD,MAAM,wBAAwB,GAAG,OAAO,CACtC,GAAG,EAAE,CAAC,MAAM,CAAC,iDAAiD,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,wBAAwB,CAAC,EACzG;IACE,GAAG,EAAE,KAAK;IACV,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,qCAAqC;CAC1D,CACF,CAAA;AAED,MAAM,UAAU,kBAAkB,CAAC,EAAE,QAAQ,EAA2B;IACtE,+CAA+C;IAC/C,MAAM,YAAY,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CACxD,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM,CAC9D,CAAC;IAEF,IAAI,YAAY,EAAE,CAAC;QACjB,qEAAqE;QACrE,OAAO,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE;YAC1C,IAAI,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;gBACzD,OAAO,KAAK,CAAC,YAAY,CAAC,KAAK,EAAE,EAAE,EACjC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,SAAS,CAAC,EAAE;oBACnD,IAAI,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;wBACjE,wCAAwC;wBACxC,MAAM,SAAS,GAAG,SAAS,CAAC,KAAgC,CAAC;wBAC7D,OAAO,KAAK,CAAC,YAAY,CAAC,SAAS,EAAE,EAAE,EACrC,oBAAC,wBAAwB,QACtB,SAAS,CAAC,QAAQ,CACM,CAC5B,CAAC;oBACJ,CAAC;oBACD,OAAO,SAAS,CAAC;gBACnB,CAAC,CAAC,CACH,CAAC;YACJ,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CAAC;IACL,CAAC;IAED,sCAAsC;IACtC,OAAO,oBAAC,wBAAwB,QAAE,QAAQ,CAA4B,CAAC;AACzE,CAAC"}
|
package/dist/hooks/useAuth.d.ts
CHANGED
|
@@ -1,2 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
export declare function useAuth(): {
|
|
2
|
+
user: import("@firebase/auth").User | null;
|
|
3
|
+
loading: boolean;
|
|
4
|
+
error: Error | null;
|
|
5
|
+
initialized: boolean;
|
|
6
|
+
isSignedIn: boolean;
|
|
7
|
+
};
|
package/dist/hooks/useAuth.js
CHANGED
|
@@ -1,38 +1,19 @@
|
|
|
1
1
|
'use client';
|
|
2
2
|
import { useState } from 'react';
|
|
3
|
-
import { getTernSecureAuth } from '../app-router/client/client-init';
|
|
4
|
-
import { signInWithEmailAndPassword } from 'firebase/auth';
|
|
5
3
|
export function useAuth() {
|
|
6
4
|
const [authState, setAuthState] = useState({
|
|
7
5
|
user: null,
|
|
8
6
|
loading: true,
|
|
9
7
|
error: null,
|
|
10
|
-
initialized: false
|
|
8
|
+
initialized: false,
|
|
9
|
+
isSignedIn: false,
|
|
11
10
|
});
|
|
12
|
-
const auth = getTernSecureAuth();
|
|
13
|
-
const signIn = async (email, password) => {
|
|
14
|
-
try {
|
|
15
|
-
const userCredential = await signInWithEmailAndPassword(auth, email, password);
|
|
16
|
-
return userCredential.user;
|
|
17
|
-
}
|
|
18
|
-
catch (error) {
|
|
19
|
-
throw new Error('Failed to sign in: ' + error.message);
|
|
20
|
-
}
|
|
21
|
-
};
|
|
22
|
-
const signOut = async () => {
|
|
23
|
-
try {
|
|
24
|
-
await auth.signOut();
|
|
25
|
-
}
|
|
26
|
-
catch (error) {
|
|
27
|
-
throw new Error('Failed to sign out: ' + error.message);
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
11
|
return {
|
|
31
12
|
user: authState.user,
|
|
32
13
|
loading: authState.loading,
|
|
33
14
|
error: authState.error,
|
|
34
|
-
|
|
35
|
-
|
|
15
|
+
initialized: authState.initialized,
|
|
16
|
+
isSignedIn: authState.isSignedIn,
|
|
36
17
|
};
|
|
37
18
|
}
|
|
38
19
|
//# sourceMappingURL=useAuth.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useAuth.js","sourceRoot":"","sources":["../../src/hooks/useAuth.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,EAAE,QAAQ,
|
|
1
|
+
{"version":3,"file":"useAuth.js","sourceRoot":"","sources":["../../src/hooks/useAuth.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAIjC,MAAM,UAAU,OAAO;IACrB,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAY;QACpD,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,KAAK;QAClB,UAAU,EAAE,KAAK;KAClB,CAAC,CAAC;IAGH,OAAO;QACL,IAAI,EAAE,SAAS,CAAC,IAAI;QACpB,OAAO,EAAE,SAAS,CAAC,OAAO;QAC1B,KAAK,EAAE,SAAS,CAAC,KAAK;QACtB,WAAW,EAAE,SAAS,CAAC,WAAW;QAClC,UAAU,EAAE,SAAS,CAAC,UAAU;KACjC,CAAC;AACJ,CAAC"}
|