@k3-universe/react-kit 0.0.29 → 0.0.31
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/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1023 -25
- package/dist/kit/builder/auth/components/Can.d.ts +13 -0
- package/dist/kit/builder/auth/components/Can.d.ts.map +1 -0
- package/dist/kit/builder/auth/components/RequireAuth.d.ts +45 -0
- package/dist/kit/builder/auth/components/RequireAuth.d.ts.map +1 -0
- package/dist/kit/builder/auth/components/ShowWhenAuthenticated.d.ts +8 -0
- package/dist/kit/builder/auth/components/ShowWhenAuthenticated.d.ts.map +1 -0
- package/dist/kit/builder/auth/components/ShowWhenError.d.ts +8 -0
- package/dist/kit/builder/auth/components/ShowWhenError.d.ts.map +1 -0
- package/dist/kit/builder/auth/components/ShowWhenLoading.d.ts +8 -0
- package/dist/kit/builder/auth/components/ShowWhenLoading.d.ts.map +1 -0
- package/dist/kit/builder/auth/components/ShowWhenUnauthenticated.d.ts +8 -0
- package/dist/kit/builder/auth/components/ShowWhenUnauthenticated.d.ts.map +1 -0
- package/dist/kit/builder/auth/components/withPermission.d.ts +7 -0
- package/dist/kit/builder/auth/components/withPermission.d.ts.map +1 -0
- package/dist/kit/builder/auth/hooks/action-hooks.d.ts +18 -0
- package/dist/kit/builder/auth/hooks/action-hooks.d.ts.map +1 -0
- package/dist/kit/builder/auth/hooks/core-hooks.d.ts +56 -0
- package/dist/kit/builder/auth/hooks/core-hooks.d.ts.map +1 -0
- package/dist/kit/builder/auth/hooks/index.d.ts +5 -0
- package/dist/kit/builder/auth/hooks/index.d.ts.map +1 -0
- package/dist/kit/builder/auth/hooks/permission-hooks.d.ts +18 -0
- package/dist/kit/builder/auth/hooks/permission-hooks.d.ts.map +1 -0
- package/dist/kit/builder/auth/hooks/token-hooks.d.ts +13 -0
- package/dist/kit/builder/auth/hooks/token-hooks.d.ts.map +1 -0
- package/dist/kit/builder/auth/index.d.ts +14 -8
- package/dist/kit/builder/auth/index.d.ts.map +1 -1
- package/dist/kit/builder/auth/{AuthProvider.d.ts → providers/AuthProvider.d.ts} +1 -1
- package/dist/kit/builder/auth/providers/AuthProvider.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/adapter-config.d.ts +31 -0
- package/dist/kit/builder/auth/types/adapter-config.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/adapter.d.ts +80 -0
- package/dist/kit/builder/auth/types/adapter.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/core.d.ts +16 -0
- package/dist/kit/builder/auth/types/core.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/index.d.ts +10 -0
- package/dist/kit/builder/auth/types/index.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/middleware.d.ts +11 -0
- package/dist/kit/builder/auth/types/middleware.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/permissions.d.ts +17 -0
- package/dist/kit/builder/auth/types/permissions.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/state.d.ts +13 -0
- package/dist/kit/builder/auth/types/state.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/storage.d.ts +20 -0
- package/dist/kit/builder/auth/types/storage.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/token-manager.d.ts +7 -0
- package/dist/kit/builder/auth/types/token-manager.d.ts.map +1 -0
- package/dist/kit/builder/auth/types/utils.d.ts +7 -0
- package/dist/kit/builder/auth/types/utils.d.ts.map +1 -0
- package/dist/kit/builder/auth/{adapter.d.ts → utils/auth-adapter.d.ts} +2 -2
- package/dist/kit/builder/auth/utils/auth-adapter.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/client-adapters/apollo-link.d.ts +4 -0
- package/dist/kit/builder/auth/utils/client-adapters/apollo-link.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/client-adapters/axios.d.ts +6 -0
- package/dist/kit/builder/auth/utils/client-adapters/axios.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/client-adapters/fetch.d.ts +6 -0
- package/dist/kit/builder/auth/utils/client-adapters/fetch.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/client-adapters/graphql.d.ts +9 -0
- package/dist/kit/builder/auth/utils/client-adapters/graphql.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/client-adapters/index.d.ts +7 -0
- package/dist/kit/builder/auth/utils/client-adapters/index.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/client-adapters/rest.d.ts +9 -0
- package/dist/kit/builder/auth/utils/client-adapters/rest.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/client-adapters/urql-exchange.d.ts +14 -0
- package/dist/kit/builder/auth/utils/client-adapters/urql-exchange.d.ts.map +1 -0
- package/dist/kit/builder/auth/{permission-checker.d.ts → utils/permission-checker.d.ts} +1 -1
- package/dist/kit/builder/auth/utils/permission-checker.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/storage/browser.d.ts +11 -0
- package/dist/kit/builder/auth/utils/storage/browser.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/storage/cookie.d.ts +3 -0
- package/dist/kit/builder/auth/utils/storage/cookie.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/storage/encryption.d.ts +7 -0
- package/dist/kit/builder/auth/utils/storage/encryption.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/storage/env.d.ts +2 -0
- package/dist/kit/builder/auth/utils/storage/env.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/storage/factory.d.ts +6 -0
- package/dist/kit/builder/auth/utils/storage/factory.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/storage/index.d.ts +7 -0
- package/dist/kit/builder/auth/utils/storage/index.d.ts.map +1 -0
- package/dist/kit/builder/auth/utils/storage/memory.d.ts +3 -0
- package/dist/kit/builder/auth/utils/storage/memory.d.ts.map +1 -0
- package/dist/kit/builder/auth/{token-manager.d.ts → utils/token-manager.d.ts} +1 -1
- package/dist/kit/builder/auth/utils/token-manager.d.ts.map +1 -0
- package/dist/kit/components/login/Login.d.ts +2 -1
- package/dist/kit/components/login/Login.d.ts.map +1 -1
- package/dist/kit/layouts/admin/components/AdminLayout.d.ts +2 -1
- package/dist/kit/layouts/admin/components/AdminLayout.d.ts.map +1 -1
- package/dist/kit/themes/clean-slate.css +28 -4
- package/dist/kit/themes/default.css +28 -4
- package/dist/kit/themes/minimal-modern.css +28 -4
- package/dist/kit/themes/spotify.css +28 -4
- package/package.json +1 -1
- package/src/index.ts +1 -0
- package/src/kit/builder/auth/components/Can.tsx +27 -0
- package/src/kit/builder/auth/components/RequireAuth.tsx +78 -0
- package/src/kit/builder/auth/components/ShowWhenAuthenticated.tsx +10 -0
- package/src/kit/builder/auth/components/ShowWhenError.tsx +10 -0
- package/src/kit/builder/auth/components/ShowWhenLoading.tsx +10 -0
- package/src/kit/builder/auth/components/ShowWhenUnauthenticated.tsx +10 -0
- package/src/kit/builder/auth/components/withPermission.tsx +23 -0
- package/src/kit/builder/auth/hooks/action-hooks.ts +34 -0
- package/src/kit/builder/auth/hooks/core-hooks.ts +65 -0
- package/src/kit/builder/auth/hooks/index.ts +4 -0
- package/src/kit/builder/auth/hooks/permission-hooks.ts +43 -0
- package/src/kit/builder/auth/hooks/token-hooks.ts +25 -0
- package/src/kit/builder/auth/index.ts +16 -18
- package/src/kit/builder/auth/{AuthProvider.tsx → providers/AuthProvider.tsx} +1 -1
- package/src/kit/builder/auth/types/adapter-config.ts +44 -0
- package/src/kit/builder/auth/types/adapter.ts +132 -0
- package/src/kit/builder/auth/types/core.ts +27 -0
- package/src/kit/builder/auth/types/index.ts +9 -0
- package/src/kit/builder/auth/types/middleware.ts +20 -0
- package/src/kit/builder/auth/types/permissions.ts +23 -0
- package/src/kit/builder/auth/types/state.ts +16 -0
- package/src/kit/builder/auth/types/storage.ts +21 -0
- package/src/kit/builder/auth/types/token-manager.ts +9 -0
- package/src/kit/builder/auth/types/utils.ts +55 -0
- package/src/kit/builder/auth/{adapter.ts → utils/auth-adapter.ts} +3 -2
- package/src/kit/builder/auth/utils/client-adapters/apollo-link.ts +30 -0
- package/src/kit/builder/auth/utils/client-adapters/axios.ts +61 -0
- package/src/kit/builder/auth/utils/client-adapters/fetch.ts +48 -0
- package/src/kit/builder/auth/utils/client-adapters/graphql.ts +60 -0
- package/src/kit/builder/auth/utils/client-adapters/index.ts +6 -0
- package/src/kit/builder/auth/utils/client-adapters/rest.ts +60 -0
- package/src/kit/builder/auth/utils/client-adapters/urql-exchange.ts +76 -0
- package/src/kit/builder/auth/{permission-checker.ts → utils/permission-checker.ts} +1 -1
- package/src/kit/builder/auth/utils/storage/browser.ts +99 -0
- package/src/kit/builder/auth/utils/storage/cookie.ts +116 -0
- package/src/kit/builder/auth/utils/storage/encryption.ts +80 -0
- package/src/kit/builder/auth/utils/storage/env.ts +2 -0
- package/src/kit/builder/auth/utils/storage/factory.ts +37 -0
- package/src/kit/builder/auth/utils/storage/index.ts +6 -0
- package/src/kit/builder/auth/utils/storage/memory.ts +15 -0
- package/src/kit/builder/auth/{token-manager.ts → utils/token-manager.ts} +1 -1
- package/src/kit/components/login/Login.tsx +36 -21
- package/src/kit/layouts/admin/components/AdminLayout.tsx +24 -17
- package/dist/kit/builder/auth/AuthProvider.d.ts.map +0 -1
- package/dist/kit/builder/auth/adapter.d.ts.map +0 -1
- package/dist/kit/builder/auth/client-adapters.d.ts +0 -149
- package/dist/kit/builder/auth/client-adapters.d.ts.map +0 -1
- package/dist/kit/builder/auth/components.d.ts +0 -119
- package/dist/kit/builder/auth/components.d.ts.map +0 -1
- package/dist/kit/builder/auth/hooks.d.ts +0 -158
- package/dist/kit/builder/auth/hooks.d.ts.map +0 -1
- package/dist/kit/builder/auth/permission-checker.d.ts.map +0 -1
- package/dist/kit/builder/auth/storage.d.ts +0 -17
- package/dist/kit/builder/auth/storage.d.ts.map +0 -1
- package/dist/kit/builder/auth/token-manager.d.ts.map +0 -1
- package/dist/kit/builder/auth/types.d.ts +0 -183
- package/dist/kit/builder/auth/types.d.ts.map +0 -1
- package/src/kit/builder/auth/client-adapters.ts +0 -398
- package/src/kit/builder/auth/components.tsx +0 -221
- package/src/kit/builder/auth/hooks.ts +0 -237
- package/src/kit/builder/auth/storage.ts +0 -366
- package/src/kit/builder/auth/types.ts +0 -393
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { CanProps } from '../types';
|
|
2
|
+
/**
|
|
3
|
+
* Component for conditional rendering based on permissions.
|
|
4
|
+
*
|
|
5
|
+
* @example
|
|
6
|
+
* ```tsx
|
|
7
|
+
* <Can permissions="post:edit" fallback={<ReadOnlyView />}>
|
|
8
|
+
* <EditButton />
|
|
9
|
+
* </Can>
|
|
10
|
+
* ```
|
|
11
|
+
*/
|
|
12
|
+
export declare function Can<TRole extends string = string, TPermission extends string = string>({ children, fallback, roles, permissions, requireAll, }: CanProps<TRole, TPermission>): import('react').ReactNode;
|
|
13
|
+
//# sourceMappingURL=Can.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Can.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/components/Can.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAGzC;;;;;;;;;GASG;AACH,wBAAgB,GAAG,CACjB,KAAK,SAAS,MAAM,GAAG,MAAM,EAC7B,WAAW,SAAS,MAAM,GAAG,MAAM,EACnC,EACA,QAAQ,EACR,QAAe,EACf,KAAK,EACL,WAAW,EACX,UAAiB,GAClB,EAAE,QAAQ,CAAC,KAAK,EAAE,WAAW,CAAC,6BAI9B"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { RequireAuthProps } from '../types';
|
|
2
|
+
/**
|
|
3
|
+
* Component that requires authentication
|
|
4
|
+
* Optionally checks for specific roles and permissions
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```tsx
|
|
8
|
+
* // Basic authentication check
|
|
9
|
+
* <RequireAuth fallback={<Login />}>
|
|
10
|
+
* <Dashboard />
|
|
11
|
+
* </RequireAuth>
|
|
12
|
+
*
|
|
13
|
+
* // With role check
|
|
14
|
+
* <RequireAuth
|
|
15
|
+
* roles="admin"
|
|
16
|
+
* fallback={<Forbidden />}
|
|
17
|
+
* loadingFallback={<Spinner />}
|
|
18
|
+
* >
|
|
19
|
+
* <AdminPanel />
|
|
20
|
+
* </RequireAuth>
|
|
21
|
+
*
|
|
22
|
+
* // With permission check
|
|
23
|
+
* <RequireAuth
|
|
24
|
+
* permissions={['post:edit', 'post:delete']}
|
|
25
|
+
* fallback={<Forbidden />}
|
|
26
|
+
* >
|
|
27
|
+
* <PostEditor />
|
|
28
|
+
* </RequireAuth>
|
|
29
|
+
*
|
|
30
|
+
* // Complex rule
|
|
31
|
+
* <RequireAuth
|
|
32
|
+
* roles={['admin', 'moderator']}
|
|
33
|
+
* permissions={{
|
|
34
|
+
* operator: 'OR',
|
|
35
|
+
* permissions: ['post:edit', 'post:delete']
|
|
36
|
+
* }}
|
|
37
|
+
* requireAll={false}
|
|
38
|
+
* fallback={<Forbidden />}
|
|
39
|
+
* >
|
|
40
|
+
* <ContentManager />
|
|
41
|
+
* </RequireAuth>
|
|
42
|
+
* ```
|
|
43
|
+
*/
|
|
44
|
+
export declare function RequireAuth<TRole extends string = string, TPermission extends string = string>({ children, fallback, loadingFallback, roles, permissions, requireAll, }: RequireAuthProps<TRole, TPermission>): import('react').ReactNode;
|
|
45
|
+
//# sourceMappingURL=RequireAuth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RequireAuth.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/components/RequireAuth.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAGjD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AACH,wBAAgB,WAAW,CACzB,KAAK,SAAS,MAAM,GAAG,MAAM,EAC7B,WAAW,SAAS,MAAM,GAAG,MAAM,EACnC,EACA,QAAQ,EACR,QAAe,EACf,eAAsB,EACtB,KAAK,EACL,WAAW,EACX,UAAiB,GAClB,EAAE,gBAAgB,CAAC,KAAK,EAAE,WAAW,CAAC,6BAsBtC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ShowWhenAuthenticated.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/components/ShowWhenAuthenticated.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,aAG1E"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ShowWhenError.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/components/ShowWhenError.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC;;GAEG;AACH,wBAAgB,aAAa,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,aAGlE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ShowWhenLoading.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/components/ShowWhenLoading.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC;;GAEG;AACH,wBAAgB,eAAe,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,aAGpE"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* Component that shows children only when NOT authenticated.
|
|
4
|
+
*/
|
|
5
|
+
export declare function ShowWhenUnauthenticated({ children }: {
|
|
6
|
+
children: ReactNode;
|
|
7
|
+
}): ReactNode;
|
|
8
|
+
//# sourceMappingURL=ShowWhenUnauthenticated.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ShowWhenUnauthenticated.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/components/ShowWhenUnauthenticated.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGvC;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,aAG5E"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ComponentType } from 'react';
|
|
2
|
+
import { WithPermissionOptions } from '../types';
|
|
3
|
+
/**
|
|
4
|
+
* Higher-order component that wraps a component with permission checks.
|
|
5
|
+
*/
|
|
6
|
+
export declare function withPermission<TRole extends string = string, TPermission extends string = string, TProps extends Record<string, unknown> = Record<string, unknown>>(Component: ComponentType<TProps>, options: WithPermissionOptions<TRole, TPermission>): ComponentType<TProps>;
|
|
7
|
+
//# sourceMappingURL=withPermission.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"withPermission.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/components/withPermission.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAC3C,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,UAAU,CAAC;AAGtD;;GAEG;AACH,wBAAgB,cAAc,CAC5B,KAAK,SAAS,MAAM,GAAG,MAAM,EAC7B,WAAW,SAAS,MAAM,GAAG,MAAM,EACnC,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAEhE,SAAS,EAAE,aAAa,CAAC,MAAM,CAAC,EAChC,OAAO,EAAE,qBAAqB,CAAC,KAAK,EAAE,WAAW,CAAC,GACjD,aAAa,CAAC,MAAM,CAAC,CAQvB"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { AuthSession } from '../types';
|
|
2
|
+
/**
|
|
3
|
+
* Hook to get the login function.
|
|
4
|
+
*/
|
|
5
|
+
export declare function useLogin<TCredentials = unknown>(): ((credentials: TCredentials) => Promise<unknown>) | undefined;
|
|
6
|
+
/**
|
|
7
|
+
* Hook to get the logout function.
|
|
8
|
+
*/
|
|
9
|
+
export declare function useLogout(): () => Promise<void>;
|
|
10
|
+
/**
|
|
11
|
+
* Hook to get the refresh function.
|
|
12
|
+
*/
|
|
13
|
+
export declare function useRefresh(): () => Promise<import('..').AuthAdapterState<AuthSession<unknown, string, string>, unknown, string, string>>;
|
|
14
|
+
/**
|
|
15
|
+
* Hook to get the setSession function.
|
|
16
|
+
*/
|
|
17
|
+
export declare function useSetSession<TSession extends AuthSession>(): (session: TSession | null) => Promise<unknown>;
|
|
18
|
+
//# sourceMappingURL=action-hooks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"action-hooks.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/hooks/action-hooks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAG5C;;GAEG;AACH,wBAAgB,QAAQ,CAAC,YAAY,GAAG,OAAO,KAE7B,CAAC,CAAC,WAAW,EAAE,YAAY,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,SAAS,CAC9E;AAED;;GAEG;AACH,wBAAgB,SAAS,wBAGxB;AAED;;GAEG;AACH,wBAAgB,UAAU,gHAGzB;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,QAAQ,SAAS,WAAW,KAEnC,CAAC,OAAO,EAAE,QAAQ,GAAG,IAAI,KAAK,OAAO,CAAC,OAAO,CAAC,CACpE"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { AuthSession } from '../types';
|
|
2
|
+
/**
|
|
3
|
+
* Hook to access the entire auth context
|
|
4
|
+
*/
|
|
5
|
+
export declare function useAuth(): {
|
|
6
|
+
state: import('..').AuthAdapterState<AuthSession<unknown, string, string>, unknown, string, string>;
|
|
7
|
+
status: import('..').AuthAdapterState<TSession, TUser, TRole, TPermission>["status"];
|
|
8
|
+
session: AuthSession<unknown, string, string> | null;
|
|
9
|
+
user: unknown;
|
|
10
|
+
roles: string[];
|
|
11
|
+
permissions: string[];
|
|
12
|
+
error?: unknown;
|
|
13
|
+
login?: ((credentials: unknown) => Promise<import('..').AuthAdapterState<AuthSession<unknown, string, string>, unknown, string, string>>) | undefined;
|
|
14
|
+
logout: () => Promise<void>;
|
|
15
|
+
refresh: () => Promise<import('..').AuthAdapterState<AuthSession<unknown, string, string>, unknown, string, string>>;
|
|
16
|
+
setSession: (session: AuthSession<unknown, string, string> | null) => Promise<import('..').AuthAdapterState<AuthSession<unknown, string, string>, unknown, string, string>>;
|
|
17
|
+
hasRole: (target: string | string[], options?: {
|
|
18
|
+
requireAll?: boolean;
|
|
19
|
+
}) => boolean;
|
|
20
|
+
hasPermission: (target: string | string[] | import('..').PermissionPolicy<string>, options?: {
|
|
21
|
+
requireAll?: boolean;
|
|
22
|
+
}) => boolean;
|
|
23
|
+
can: (rule: import('..').PermissionRule<string, string>) => boolean;
|
|
24
|
+
getToken: () => string | null;
|
|
25
|
+
isTokenExpired: () => boolean;
|
|
26
|
+
getTimeUntilExpiry: () => number;
|
|
27
|
+
};
|
|
28
|
+
/**
|
|
29
|
+
* Hook to get the current auth status
|
|
30
|
+
*/
|
|
31
|
+
export declare function useAuthStatus(): import('..').AuthStatus;
|
|
32
|
+
/**
|
|
33
|
+
* Hook to check if user is authenticated
|
|
34
|
+
*/
|
|
35
|
+
export declare function useIsAuthenticated(): boolean;
|
|
36
|
+
/**
|
|
37
|
+
* Hook to get the current session
|
|
38
|
+
*/
|
|
39
|
+
export declare function useAuthSession<TSession extends AuthSession>(): TSession | null;
|
|
40
|
+
/**
|
|
41
|
+
* Hook to get the current user
|
|
42
|
+
*/
|
|
43
|
+
export declare function useAuthUser<TUser>(): TUser | null;
|
|
44
|
+
/**
|
|
45
|
+
* Hook to get user roles
|
|
46
|
+
*/
|
|
47
|
+
export declare function useAuthRoles<TRole extends string = string>(): TRole[];
|
|
48
|
+
/**
|
|
49
|
+
* Hook to get user permissions
|
|
50
|
+
*/
|
|
51
|
+
export declare function useAuthPermissions<TPermission extends string = string>(): TPermission[];
|
|
52
|
+
/**
|
|
53
|
+
* Hook to get authentication error
|
|
54
|
+
*/
|
|
55
|
+
export declare function useAuthError(): unknown;
|
|
56
|
+
//# sourceMappingURL=core-hooks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core-hooks.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/hooks/core-hooks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAG5C;;GAEG;AACH,wBAAgB,OAAO;;;;;;;;;;;;;kBA2DqiC,CAAC;;;kBAAmJ,CAAC;;;;;;EAzDhtC;AAED;;GAEG;AACH,wBAAgB,aAAa,4BAG5B;AAED;;GAEG;AACH,wBAAgB,kBAAkB,YAGjC;AAED;;GAEG;AACH,wBAAgB,cAAc,CAAC,QAAQ,SAAS,WAAW,KAEvC,QAAQ,GAAG,IAAI,CAClC;AAED;;GAEG;AACH,wBAAgB,WAAW,CAAC,KAAK,KAEhB,KAAK,GAAG,IAAI,CAC5B;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,KAAK,SAAS,MAAM,GAAG,MAAM,KAExC,KAAK,EAAE,CACxB;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,WAAW,SAAS,MAAM,GAAG,MAAM,KAE9C,WAAW,EAAE,CACpC;AAED;;GAEG;AACH,wBAAgB,YAAY,YAG3B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAC7B,cAAc,oBAAoB,CAAC;AACnC,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { PermissionPolicy, PermissionRule, WithPermissionOptions } from '../types';
|
|
2
|
+
/**
|
|
3
|
+
* Hook to check if user has specific permission(s).
|
|
4
|
+
*/
|
|
5
|
+
export declare function usePermission<TPermission extends string = string>(permission: TPermission | TPermission[] | PermissionPolicy<TPermission>, options?: {
|
|
6
|
+
requireAll?: boolean;
|
|
7
|
+
}): boolean;
|
|
8
|
+
/**
|
|
9
|
+
* Hook to check if user has specific role(s).
|
|
10
|
+
*/
|
|
11
|
+
export declare function useRole<TRole extends string = string>(roles: TRole | TRole[], options?: {
|
|
12
|
+
requireAll?: boolean;
|
|
13
|
+
}): boolean;
|
|
14
|
+
/**
|
|
15
|
+
* Hook to check complex permission rules.
|
|
16
|
+
*/
|
|
17
|
+
export declare function useCan<TRole extends string = string, TPermission extends string = string>(rule: WithPermissionOptions<TRole, TPermission> | PermissionRule<TRole, TPermission>): boolean;
|
|
18
|
+
//# sourceMappingURL=permission-hooks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permission-hooks.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/hooks/permission-hooks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,gBAAgB,EAChB,cAAc,EACd,qBAAqB,EACtB,MAAM,UAAU,CAAC;AAGlB;;GAEG;AACH,wBAAgB,aAAa,CAAC,WAAW,SAAS,MAAM,GAAG,MAAM,EAC/D,UAAU,EAAE,WAAW,GAAG,WAAW,EAAE,GAAG,gBAAgB,CAAC,WAAW,CAAC,EACvE,OAAO,CAAC,EAAE;IAAE,UAAU,CAAC,EAAE,OAAO,CAAA;CAAE,WAInC;AAED;;GAEG;AACH,wBAAgB,OAAO,CAAC,KAAK,SAAS,MAAM,GAAG,MAAM,EACnD,KAAK,EAAE,KAAK,GAAG,KAAK,EAAE,EACtB,OAAO,CAAC,EAAE;IAAE,UAAU,CAAC,EAAE,OAAO,CAAA;CAAE,WAInC;AAED;;GAEG;AACH,wBAAgB,MAAM,CACpB,KAAK,SAAS,MAAM,GAAG,MAAM,EAC7B,WAAW,SAAS,MAAM,GAAG,MAAM,EAEnC,IAAI,EACA,qBAAqB,CAAC,KAAK,EAAE,WAAW,CAAC,GACzC,cAAc,CAAC,KAAK,EAAE,WAAW,CAAC,WAIvC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Hook to get the current auth token.
|
|
3
|
+
*/
|
|
4
|
+
export declare function useAuthToken(): string | null;
|
|
5
|
+
/**
|
|
6
|
+
* Hook to check if token is expired.
|
|
7
|
+
*/
|
|
8
|
+
export declare function useIsTokenExpired(): boolean;
|
|
9
|
+
/**
|
|
10
|
+
* Hook to get time until token expiry in milliseconds.
|
|
11
|
+
*/
|
|
12
|
+
export declare function useTimeUntilExpiry(): number;
|
|
13
|
+
//# sourceMappingURL=token-hooks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-hooks.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/hooks/token-hooks.ts"],"names":[],"mappings":"AAEA;;GAEG;AACH,wBAAgB,YAAY,kBAG3B;AAED;;GAEG;AACH,wBAAgB,iBAAiB,YAGhC;AAED;;GAEG;AACH,wBAAgB,kBAAkB,WAGjC"}
|
|
@@ -1,11 +1,17 @@
|
|
|
1
|
-
export { createAuthAdapter } from './adapter';
|
|
2
|
-
export { AuthProvider, useAuthContext } from './AuthProvider';
|
|
3
|
-
export { createStorage, createMemoryStorage, createBrowserStorage, createCookieStorage, } from './storage';
|
|
4
|
-
export { createTokenManager } from './token-manager';
|
|
5
|
-
export { expandPermissions, expandRoles, checkPermissions, checkRoles, evaluatePermissionRule, } from './permission-checker';
|
|
6
|
-
export { createGraphQLAuthAdapter, createRESTAuthAdapter, createAxiosAuthInterceptor, createAuthFetch, createApolloAuthLink, } from './client-adapters';
|
|
7
|
-
export type { GraphQLClientAdapterOptions, RESTClientAdapterOptions, } from './client-adapters';
|
|
1
|
+
export { createAuthAdapter } from './utils/auth-adapter';
|
|
2
|
+
export { AuthProvider, useAuthContext } from './providers/AuthProvider';
|
|
3
|
+
export { createStorage, createMemoryStorage, createBrowserStorage, createCookieStorage, } from './utils/storage';
|
|
4
|
+
export { createTokenManager } from './utils/token-manager';
|
|
5
|
+
export { expandPermissions, expandRoles, checkPermissions, checkRoles, evaluatePermissionRule, } from './utils/permission-checker';
|
|
6
|
+
export { createGraphQLAuthAdapter, createRESTAuthAdapter, createAxiosAuthInterceptor, createAuthFetch, createApolloAuthLink, } from './utils/client-adapters';
|
|
7
|
+
export type { GraphQLClientAdapterOptions, RESTClientAdapterOptions, } from './utils/client-adapters';
|
|
8
8
|
export { useAuth, useAuthStatus, useIsAuthenticated, useAuthSession, useAuthUser, useAuthRoles, useAuthPermissions, useAuthError, usePermission, useRole, useCan, useAuthToken, useIsTokenExpired, useTimeUntilExpiry, useLogin, useLogout, useRefresh, useSetSession, } from './hooks';
|
|
9
|
-
export { RequireAuth
|
|
9
|
+
export { RequireAuth } from './components/RequireAuth';
|
|
10
|
+
export { Can } from './components/Can';
|
|
11
|
+
export { withPermission } from './components/withPermission';
|
|
12
|
+
export { ShowWhenAuthenticated } from './components/ShowWhenAuthenticated';
|
|
13
|
+
export { ShowWhenUnauthenticated } from './components/ShowWhenUnauthenticated';
|
|
14
|
+
export { ShowWhenLoading } from './components/ShowWhenLoading';
|
|
15
|
+
export { ShowWhenError } from './components/ShowWhenError';
|
|
10
16
|
export type { AuthStatus, TokenType, RefreshStrategy, AuthSession, PermissionOperator, PermissionPolicy, PermissionRule, PermissionHierarchy, RoleHierarchy, AuthAdapterState, AuthAdapterSubscriber, AuthStorage, StorageType, StorageOptions, AuthMiddleware, TokenManager, AuthAdapterConfig, AuthAdapter, AuthContextValue, RequireAuthProps, CanProps, WithPermissionOptions, GraphQLAuthClient, RESTAuthClient, ClientAdapter, InferSession, InferUser, InferRole, InferPermission, InferCredentials, } from './types';
|
|
11
17
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/kit/builder/auth/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,iBAAiB,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/kit/builder/auth/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAMxE,OAAO,EACL,aAAa,EACb,mBAAmB,EACnB,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,iBAAiB,CAAC;AAMzB,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EACL,iBAAiB,EACjB,WAAW,EACX,gBAAgB,EAChB,UAAU,EACV,sBAAsB,GACvB,MAAM,4BAA4B,CAAC;AAMpC,OAAO,EACL,wBAAwB,EACxB,qBAAqB,EACrB,0BAA0B,EAC1B,eAAe,EACf,oBAAoB,GACrB,MAAM,yBAAyB,CAAC;AAEjC,YAAY,EACV,2BAA2B,EAC3B,wBAAwB,GACzB,MAAM,yBAAyB,CAAC;AAMjC,OAAO,EACL,OAAO,EACP,aAAa,EACb,kBAAkB,EAClB,cAAc,EACd,WAAW,EACX,YAAY,EACZ,kBAAkB,EAClB,YAAY,EACZ,aAAa,EACb,OAAO,EACP,MAAM,EACN,YAAY,EACZ,iBAAiB,EACjB,kBAAkB,EAClB,QAAQ,EACR,SAAS,EACT,UAAU,EACV,aAAa,GACd,MAAM,SAAS,CAAC;AAMjB,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAC3E,OAAO,EAAE,uBAAuB,EAAE,MAAM,sCAAsC,CAAC;AAC/E,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAM3D,YAAY,EAEV,UAAU,EACV,SAAS,EACT,eAAe,EACf,WAAW,EAEX,kBAAkB,EAClB,gBAAgB,EAChB,cAAc,EACd,mBAAmB,EACnB,aAAa,EAEb,gBAAgB,EAChB,qBAAqB,EAErB,WAAW,EACX,WAAW,EACX,cAAc,EAEd,cAAc,EAEd,YAAY,EAEZ,iBAAiB,EACjB,WAAW,EAEX,gBAAgB,EAEhB,gBAAgB,EAChB,QAAQ,EACR,qBAAqB,EAErB,iBAAiB,EACjB,cAAc,EACd,aAAa,EAEb,YAAY,EACZ,SAAS,EACT,SAAS,EACT,eAAe,EACf,gBAAgB,GACjB,MAAM,SAAS,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ReactNode } from 'react';
|
|
2
|
-
import { AuthAdapter, AuthContextValue, AuthSession } from '
|
|
2
|
+
import { AuthAdapter, AuthContextValue, AuthSession } from '../types';
|
|
3
3
|
type AnyAuthContextValue = AuthContextValue<unknown, string, string, AuthSession<unknown, string, string>, unknown>;
|
|
4
4
|
type AuthProviderProps<TUser = unknown, TRole extends string = string, TPermission extends string = string, TSession extends AuthSession<TUser, TRole, TPermission> = AuthSession<TUser, TRole, TPermission>, TCredentials = unknown> = {
|
|
5
5
|
adapter: AuthAdapter<TUser, TRole, TPermission, TSession, TCredentials>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthProvider.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/providers/AuthProvider.tsx"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAE3E,KAAK,mBAAmB,GAAG,gBAAgB,CACzC,OAAO,EACP,MAAM,EACN,MAAM,EACN,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EACpC,OAAO,CACR,CAAC;AAIF,KAAK,iBAAiB,CACpB,KAAK,GAAG,OAAO,EACf,KAAK,SAAS,MAAM,GAAG,MAAM,EAC7B,WAAW,SAAS,MAAM,GAAG,MAAM,EACnC,QAAQ,SAAS,WAAW,CAAC,KAAK,EAAE,KAAK,EAAE,WAAW,CAAC,GAAG,WAAW,CACnE,KAAK,EACL,KAAK,EACL,WAAW,CACZ,EACD,YAAY,GAAG,OAAO,IACpB;IACF,OAAO,EAAE,WAAW,CAAC,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IACxE,QAAQ,EAAE,SAAS,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF;;;;;;;;;;;;;;;;;;;GAmBG;AACH,wBAAgB,YAAY,CAC1B,KAAK,GAAG,OAAO,EACf,KAAK,SAAS,MAAM,GAAG,MAAM,EAC7B,WAAW,SAAS,MAAM,GAAG,MAAM,EACnC,QAAQ,SAAS,WAAW,CAAC,KAAK,EAAE,KAAK,EAAE,WAAW,CAAC,GAAG,WAAW,CACnE,KAAK,EACL,KAAK,EACL,WAAW,CACZ,EACD,YAAY,GAAG,OAAO,EACtB,EACA,OAAO,EACP,QAAQ,EACR,QAAe,GAChB,EAAE,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,YAAY,CAAC,2CAkDtE;AAED;;;GAGG;AACH,wBAAgB,cAAc,IAAI,mBAAmB,CAIpD"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { AuthSession, RefreshStrategy } from './core';
|
|
2
|
+
import { PermissionHierarchy, RoleHierarchy } from './permissions';
|
|
3
|
+
import { AuthAdapterState } from './state';
|
|
4
|
+
import { AuthMiddleware } from './middleware';
|
|
5
|
+
import { TokenManager } from './token-manager';
|
|
6
|
+
import { AuthStorage } from './storage';
|
|
7
|
+
export type AuthAdapterConfig<TUser = unknown, TRole extends string = string, TPermission extends string = string, TSession extends AuthSession<TUser, TRole, TPermission> = AuthSession<TUser, TRole, TPermission>, TCredentials = unknown> = {
|
|
8
|
+
storage?: AuthStorage<TSession>;
|
|
9
|
+
loadSession?: () => Promise<TSession | null>;
|
|
10
|
+
login?: (credentials: TCredentials) => Promise<TSession>;
|
|
11
|
+
logout?: (session: TSession | null) => Promise<void> | void;
|
|
12
|
+
refresh?: (session: TSession) => Promise<TSession>;
|
|
13
|
+
resolveUser?: (session: TSession | null) => TUser | null;
|
|
14
|
+
resolveRoles?: (session: TSession | null) => TRole[];
|
|
15
|
+
resolvePermissions?: (session: TSession | null) => TPermission[];
|
|
16
|
+
shouldRefresh?: (session: TSession) => boolean;
|
|
17
|
+
onStateChange?: (state: AuthAdapterState<TSession, TUser, TRole, TPermission>) => void;
|
|
18
|
+
refreshStrategy?: RefreshStrategy;
|
|
19
|
+
refreshThreshold?: number;
|
|
20
|
+
autoRefresh?: boolean;
|
|
21
|
+
permissionHierarchy?: PermissionHierarchy<TPermission>;
|
|
22
|
+
roleHierarchy?: RoleHierarchy<TRole>;
|
|
23
|
+
middleware?: AuthMiddleware<TSession, TUser, TRole, TPermission>[];
|
|
24
|
+
tokenManager?: TokenManager;
|
|
25
|
+
retryConfig?: {
|
|
26
|
+
maxRetries?: number;
|
|
27
|
+
retryDelay?: number;
|
|
28
|
+
retryOn?: (error: unknown) => boolean;
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=adapter-config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter-config.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/types/adapter-config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAC3D,OAAO,KAAK,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACxE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAChD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAE7C,MAAM,MAAM,iBAAiB,CAC3B,KAAK,GAAG,OAAO,EACf,KAAK,SAAS,MAAM,GAAG,MAAM,EAC7B,WAAW,SAAS,MAAM,GAAG,MAAM,EACnC,QAAQ,SAAS,WAAW,CAAC,KAAK,EAAE,KAAK,EAAE,WAAW,CAAC,GAAG,WAAW,CACnE,KAAK,EACL,KAAK,EACL,WAAW,CACZ,EACD,YAAY,GAAG,OAAO,IACpB;IACF,OAAO,CAAC,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;IAChC,WAAW,CAAC,EAAE,MAAM,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC;IAC7C,KAAK,CAAC,EAAE,CAAC,WAAW,EAAE,YAAY,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC;IACzD,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,GAAG,IAAI,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC5D,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC;IACnD,WAAW,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,GAAG,IAAI,KAAK,KAAK,GAAG,IAAI,CAAC;IACzD,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,GAAG,IAAI,KAAK,KAAK,EAAE,CAAC;IACrD,kBAAkB,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,GAAG,IAAI,KAAK,WAAW,EAAE,CAAC;IACjE,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE,QAAQ,KAAK,OAAO,CAAC;IAC/C,aAAa,CAAC,EAAE,CACd,KAAK,EAAE,gBAAgB,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,CAAC,KACzD,IAAI,CAAC;IAEV,eAAe,CAAC,EAAE,eAAe,CAAC;IAClC,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,mBAAmB,CAAC,EAAE,mBAAmB,CAAC,WAAW,CAAC,CAAC;IACvD,aAAa,CAAC,EAAE,aAAa,CAAC,KAAK,CAAC,CAAC;IACrC,UAAU,CAAC,EAAE,cAAc,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,CAAC,EAAE,CAAC;IACnE,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,WAAW,CAAC,EAAE;QACZ,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,OAAO,CAAC;KACvC,CAAC;CACH,CAAC"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { AuthSession } from './core';
|
|
2
|
+
import { PermissionPolicy, PermissionRule } from './permissions';
|
|
3
|
+
import { AuthAdapterState, AuthAdapterSubscriber } from './state';
|
|
4
|
+
export type AuthAdapter<TUser = unknown, TRole extends string = string, TPermission extends string = string, TSession extends AuthSession<TUser, TRole, TPermission> = AuthSession<TUser, TRole, TPermission>, TCredentials = unknown> = {
|
|
5
|
+
getState: () => AuthAdapterState<TSession, TUser, TRole, TPermission>;
|
|
6
|
+
subscribe: (listener: AuthAdapterSubscriber<TSession, TUser, TRole, TPermission>) => () => void;
|
|
7
|
+
sync: () => Promise<AuthAdapterState<TSession, TUser, TRole, TPermission>>;
|
|
8
|
+
login?: (credentials: TCredentials) => Promise<AuthAdapterState<TSession, TUser, TRole, TPermission>>;
|
|
9
|
+
logout: () => Promise<void>;
|
|
10
|
+
refresh: () => Promise<AuthAdapterState<TSession, TUser, TRole, TPermission>>;
|
|
11
|
+
setSession: (session: TSession | null) => Promise<AuthAdapterState<TSession, TUser, TRole, TPermission>>;
|
|
12
|
+
hasRole: (target: TRole | TRole[], options?: {
|
|
13
|
+
requireAll?: boolean;
|
|
14
|
+
}) => boolean;
|
|
15
|
+
hasPermission: (target: TPermission | TPermission[] | PermissionPolicy<TPermission>, options?: {
|
|
16
|
+
requireAll?: boolean;
|
|
17
|
+
}) => boolean;
|
|
18
|
+
can: (rule: PermissionRule<TRole, TPermission>) => boolean;
|
|
19
|
+
getToken: () => string | null;
|
|
20
|
+
isTokenExpired: () => boolean;
|
|
21
|
+
getTimeUntilExpiry: () => number;
|
|
22
|
+
scheduleAutoRefresh?: () => () => void;
|
|
23
|
+
};
|
|
24
|
+
export type AuthContextValue<TUser = unknown, TRole extends string = string, TPermission extends string = string, TSession extends AuthSession<TUser, TRole, TPermission> = AuthSession<TUser, TRole, TPermission>, TCredentials = unknown> = {
|
|
25
|
+
state: AuthAdapterState<TSession, TUser, TRole, TPermission>;
|
|
26
|
+
status: AuthAdapterState<TSession, TUser, TRole, TPermission>['status'];
|
|
27
|
+
session: TSession | null;
|
|
28
|
+
user: TUser | null;
|
|
29
|
+
roles: TRole[];
|
|
30
|
+
permissions: TPermission[];
|
|
31
|
+
error?: unknown;
|
|
32
|
+
login?: (credentials: TCredentials) => Promise<AuthAdapterState<TSession, TUser, TRole, TPermission>>;
|
|
33
|
+
logout: () => Promise<void>;
|
|
34
|
+
refresh: () => Promise<AuthAdapterState<TSession, TUser, TRole, TPermission>>;
|
|
35
|
+
setSession: (session: TSession | null) => Promise<AuthAdapterState<TSession, TUser, TRole, TPermission>>;
|
|
36
|
+
hasRole: (target: TRole | TRole[], options?: {
|
|
37
|
+
requireAll?: boolean;
|
|
38
|
+
}) => boolean;
|
|
39
|
+
hasPermission: (target: TPermission | TPermission[] | PermissionPolicy<TPermission>, options?: {
|
|
40
|
+
requireAll?: boolean;
|
|
41
|
+
}) => boolean;
|
|
42
|
+
can: (rule: PermissionRule<TRole, TPermission>) => boolean;
|
|
43
|
+
getToken: () => string | null;
|
|
44
|
+
isTokenExpired: () => boolean;
|
|
45
|
+
getTimeUntilExpiry: () => number;
|
|
46
|
+
};
|
|
47
|
+
export type RequireAuthProps<TRole extends string = string, TPermission extends string = string> = {
|
|
48
|
+
children: React.ReactNode;
|
|
49
|
+
fallback?: React.ReactNode;
|
|
50
|
+
loadingFallback?: React.ReactNode;
|
|
51
|
+
roles?: TRole | TRole[];
|
|
52
|
+
permissions?: TPermission | TPermission[] | PermissionPolicy<TPermission>;
|
|
53
|
+
requireAll?: boolean;
|
|
54
|
+
};
|
|
55
|
+
export type CanProps<TRole extends string = string, TPermission extends string = string> = {
|
|
56
|
+
children: React.ReactNode;
|
|
57
|
+
fallback?: React.ReactNode;
|
|
58
|
+
roles?: TRole | TRole[];
|
|
59
|
+
permissions?: TPermission | TPermission[] | PermissionPolicy<TPermission>;
|
|
60
|
+
requireAll?: boolean;
|
|
61
|
+
};
|
|
62
|
+
export type WithPermissionOptions<TRole extends string = string, TPermission extends string = string> = {
|
|
63
|
+
roles?: TRole | TRole[];
|
|
64
|
+
permissions?: TPermission | TPermission[] | PermissionPolicy<TPermission>;
|
|
65
|
+
requireAll?: boolean;
|
|
66
|
+
};
|
|
67
|
+
export type GraphQLAuthClient<TSession = unknown, TCredentials = unknown> = {
|
|
68
|
+
login: (credentials: TCredentials) => Promise<TSession>;
|
|
69
|
+
logout?: () => Promise<void>;
|
|
70
|
+
refresh?: (refreshToken: string) => Promise<TSession>;
|
|
71
|
+
getCurrentUser?: () => Promise<TSession>;
|
|
72
|
+
};
|
|
73
|
+
export type RESTAuthClient<TSession = unknown, TCredentials = unknown> = {
|
|
74
|
+
login: (credentials: TCredentials) => Promise<TSession>;
|
|
75
|
+
logout?: () => Promise<void>;
|
|
76
|
+
refresh?: (refreshToken: string) => Promise<TSession>;
|
|
77
|
+
getCurrentUser?: () => Promise<TSession>;
|
|
78
|
+
};
|
|
79
|
+
export type ClientAdapter<TSession = unknown, TCredentials = unknown> = GraphQLAuthClient<TSession, TCredentials> | RESTAuthClient<TSession, TCredentials>;
|
|
80
|
+
//# sourceMappingURL=adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/types/adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export type AuthStatus = 'idle' | 'loading' | 'authenticated' | 'unauthenticated' | 'error';
|
|
2
|
+
export type TokenType = 'bearer' | 'jwt' | 'custom';
|
|
3
|
+
export type RefreshStrategy = 'auto' | 'manual' | 'sliding';
|
|
4
|
+
export type AuthSession<TUser = unknown, TRole = string, TPermission = string> = {
|
|
5
|
+
user?: TUser | null;
|
|
6
|
+
accessToken?: string | null;
|
|
7
|
+
refreshToken?: string | null;
|
|
8
|
+
tokenType?: TokenType;
|
|
9
|
+
roles?: TRole[] | null;
|
|
10
|
+
permissions?: TPermission[] | null;
|
|
11
|
+
expiresAt?: number | null;
|
|
12
|
+
refreshExpiresAt?: number | null;
|
|
13
|
+
issuedAt?: number | null;
|
|
14
|
+
meta?: Record<string, unknown> | null;
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=core.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/types/core.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAClB,MAAM,GACN,SAAS,GACT,eAAe,GACf,iBAAiB,GACjB,OAAO,CAAC;AAEZ,MAAM,MAAM,SAAS,GAAG,QAAQ,GAAG,KAAK,GAAG,QAAQ,CAAC;AAEpD,MAAM,MAAM,eAAe,GAAG,MAAM,GAAG,QAAQ,GAAG,SAAS,CAAC;AAE5D,MAAM,MAAM,WAAW,CACrB,KAAK,GAAG,OAAO,EACf,KAAK,GAAG,MAAM,EACd,WAAW,GAAG,MAAM,IAClB;IACF,IAAI,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,KAAK,CAAC,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC;IACvB,WAAW,CAAC,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC;IACnC,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC1B,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;CACvC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from './core';
|
|
2
|
+
export * from './permissions';
|
|
3
|
+
export * from './state';
|
|
4
|
+
export * from './storage';
|
|
5
|
+
export * from './middleware';
|
|
6
|
+
export * from './token-manager';
|
|
7
|
+
export * from './adapter-config';
|
|
8
|
+
export * from './adapter';
|
|
9
|
+
export * from './utils';
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,eAAe,CAAC;AAC9B,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AuthAdapterState } from './state';
|
|
2
|
+
export type AuthMiddleware<TSession = unknown, TUser = unknown, TRole extends string = string, TPermission extends string = string> = {
|
|
3
|
+
onBeforeLogin?: (credentials: unknown) => Promise<void> | void;
|
|
4
|
+
onAfterLogin?: (state: AuthAdapterState<TSession, TUser, TRole, TPermission>) => Promise<void> | void;
|
|
5
|
+
onBeforeLogout?: () => Promise<void> | void;
|
|
6
|
+
onAfterLogout?: () => Promise<void> | void;
|
|
7
|
+
onRefresh?: (state: AuthAdapterState<TSession, TUser, TRole, TPermission>) => Promise<void> | void;
|
|
8
|
+
onError?: (error: unknown) => Promise<void> | void;
|
|
9
|
+
onSessionExpired?: () => Promise<void> | void;
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/types/middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAEhD,MAAM,MAAM,cAAc,CACxB,QAAQ,GAAG,OAAO,EAClB,KAAK,GAAG,OAAO,EACf,KAAK,SAAS,MAAM,GAAG,MAAM,EAC7B,WAAW,SAAS,MAAM,GAAG,MAAM,IACjC;IACF,aAAa,CAAC,EAAE,CAAC,WAAW,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC/D,YAAY,CAAC,EAAE,CACb,KAAK,EAAE,gBAAgB,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,CAAC,KACzD,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC5C,aAAa,CAAC,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC3C,SAAS,CAAC,EAAE,CACV,KAAK,EAAE,gBAAgB,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,CAAC,KACzD,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC1B,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IACnD,gBAAgB,CAAC,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;CAC/C,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export type PermissionOperator = 'AND' | 'OR';
|
|
2
|
+
export type PermissionPolicy<TPermission extends string = string> = {
|
|
3
|
+
operator?: PermissionOperator;
|
|
4
|
+
permissions: TPermission[];
|
|
5
|
+
};
|
|
6
|
+
export type PermissionRule<TRole extends string = string, TPermission extends string = string> = {
|
|
7
|
+
roles?: TRole | TRole[];
|
|
8
|
+
permissions?: TPermission | TPermission[] | PermissionPolicy<TPermission>;
|
|
9
|
+
requireAll?: boolean;
|
|
10
|
+
};
|
|
11
|
+
export type PermissionHierarchy<TPermission extends string = string> = {
|
|
12
|
+
[key in TPermission]?: TPermission[];
|
|
13
|
+
};
|
|
14
|
+
export type RoleHierarchy<TRole extends string = string> = {
|
|
15
|
+
[key in TRole]?: TRole[];
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=permissions.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissions.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/types/permissions.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,kBAAkB,GAAG,KAAK,GAAG,IAAI,CAAC;AAE9C,MAAM,MAAM,gBAAgB,CAAC,WAAW,SAAS,MAAM,GAAG,MAAM,IAAI;IAClE,QAAQ,CAAC,EAAE,kBAAkB,CAAC;IAC9B,WAAW,EAAE,WAAW,EAAE,CAAC;CAC5B,CAAC;AAEF,MAAM,MAAM,cAAc,CACxB,KAAK,SAAS,MAAM,GAAG,MAAM,EAC7B,WAAW,SAAS,MAAM,GAAG,MAAM,IACjC;IACF,KAAK,CAAC,EAAE,KAAK,GAAG,KAAK,EAAE,CAAC;IACxB,WAAW,CAAC,EAAE,WAAW,GAAG,WAAW,EAAE,GAAG,gBAAgB,CAAC,WAAW,CAAC,CAAC;IAC1E,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,mBAAmB,CAAC,WAAW,SAAS,MAAM,GAAG,MAAM,IAAI;KACpE,GAAG,IAAI,WAAW,CAAC,CAAC,EAAE,WAAW,EAAE;CACrC,CAAC;AAEF,MAAM,MAAM,aAAa,CAAC,KAAK,SAAS,MAAM,GAAG,MAAM,IAAI;KACxD,GAAG,IAAI,KAAK,CAAC,CAAC,EAAE,KAAK,EAAE;CACzB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { AuthStatus } from './core';
|
|
2
|
+
export type AuthAdapterState<TSession, TUser, TRole, TPermission> = {
|
|
3
|
+
status: AuthStatus;
|
|
4
|
+
session: TSession | null;
|
|
5
|
+
user: TUser | null;
|
|
6
|
+
roles: TRole[];
|
|
7
|
+
permissions: TPermission[];
|
|
8
|
+
error?: unknown;
|
|
9
|
+
lastRefresh?: number;
|
|
10
|
+
tokenExpiresIn?: number;
|
|
11
|
+
};
|
|
12
|
+
export type AuthAdapterSubscriber<TSession, TUser, TRole, TPermission> = (state: AuthAdapterState<TSession, TUser, TRole, TPermission>) => void;
|
|
13
|
+
//# sourceMappingURL=state.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/types/state.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEzC,MAAM,MAAM,gBAAgB,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,IAAI;IAClE,MAAM,EAAE,UAAU,CAAC;IACnB,OAAO,EAAE,QAAQ,GAAG,IAAI,CAAC;IACzB,IAAI,EAAE,KAAK,GAAG,IAAI,CAAC;IACnB,KAAK,EAAE,KAAK,EAAE,CAAC;IACf,WAAW,EAAE,WAAW,EAAE,CAAC;IAC3B,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB,CAAC;AAEF,MAAM,MAAM,qBAAqB,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,IAAI,CACvE,KAAK,EAAE,gBAAgB,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,CAAC,KACzD,IAAI,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export type AuthStorage<TSession> = {
|
|
2
|
+
get: () => Promise<TSession | null> | TSession | null;
|
|
3
|
+
set: (value: TSession | null) => Promise<void> | void;
|
|
4
|
+
clear: () => Promise<void> | void;
|
|
5
|
+
};
|
|
6
|
+
export type StorageType = 'local' | 'session' | 'cookie' | 'memory';
|
|
7
|
+
export type StorageOptions = {
|
|
8
|
+
key?: string;
|
|
9
|
+
encrypt?: boolean;
|
|
10
|
+
encryptionKey?: string;
|
|
11
|
+
storage?: StorageType;
|
|
12
|
+
cookieOptions?: {
|
|
13
|
+
domain?: string;
|
|
14
|
+
path?: string;
|
|
15
|
+
secure?: boolean;
|
|
16
|
+
sameSite?: 'strict' | 'lax' | 'none';
|
|
17
|
+
maxAge?: number;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=storage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/types/storage.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,CAAC,QAAQ,IAAI;IAClC,GAAG,EAAE,MAAM,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC,GAAG,QAAQ,GAAG,IAAI,CAAC;IACtD,GAAG,EAAE,CAAC,KAAK,EAAE,QAAQ,GAAG,IAAI,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IACtD,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;CACnC,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG,OAAO,GAAG,SAAS,GAAG,QAAQ,GAAG,QAAQ,CAAC;AAEpE,MAAM,MAAM,cAAc,GAAG;IAC3B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,aAAa,CAAC,EAAE;QACd,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,QAAQ,CAAC,EAAE,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAC;QACrC,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,CAAC;CACH,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export type TokenManager = {
|
|
2
|
+
isExpired: (expiresAt?: number | null) => boolean;
|
|
3
|
+
shouldRefresh: (expiresAt?: number | null, threshold?: number) => boolean;
|
|
4
|
+
getTimeUntilExpiry: (expiresAt?: number | null) => number;
|
|
5
|
+
scheduleRefresh?: (callback: () => void, expiresAt?: number | null) => () => void;
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=token-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token-manager.d.ts","sourceRoot":"","sources":["../../../../../src/kit/builder/auth/types/token-manager.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,YAAY,GAAG;IACzB,SAAS,EAAE,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,KAAK,OAAO,CAAC;IAClD,aAAa,EAAE,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,EAAE,SAAS,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC;IAC1E,kBAAkB,EAAE,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,KAAK,MAAM,CAAC;IAC1D,eAAe,CAAC,EAAE,CAChB,QAAQ,EAAE,MAAM,IAAI,EACpB,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,KACtB,MAAM,IAAI,CAAC;CACjB,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { AuthAdapter } from './adapter';
|
|
2
|
+
export type InferSession<T> = T extends AuthAdapter<infer _User, infer _Role extends string, infer _Permission extends string, infer TSession, infer _Credentials> ? TSession : never;
|
|
3
|
+
export type InferUser<T> = T extends AuthAdapter<infer TUser, infer _Role extends string, infer _Permission extends string, infer _Session, infer _Credentials> ? TUser : never;
|
|
4
|
+
export type InferRole<T> = T extends AuthAdapter<infer _User, infer TRole extends string, infer _Permission extends string, infer _Session, infer _Credentials> ? TRole : never;
|
|
5
|
+
export type InferPermission<T> = T extends AuthAdapter<infer _User, infer _Role extends string, infer TPermission extends string, infer _Session, infer _Credentials> ? TPermission : never;
|
|
6
|
+
export type InferCredentials<T> = T extends AuthAdapter<infer _User, infer _Role extends string, infer _Permission extends string, infer _Session, infer TCredentials> ? TCredentials : never;
|
|
7
|
+
//# sourceMappingURL=utils.d.ts.map
|