@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.
Files changed (157) hide show
  1. package/dist/index.d.ts +1 -0
  2. package/dist/index.d.ts.map +1 -1
  3. package/dist/index.js +1023 -25
  4. package/dist/kit/builder/auth/components/Can.d.ts +13 -0
  5. package/dist/kit/builder/auth/components/Can.d.ts.map +1 -0
  6. package/dist/kit/builder/auth/components/RequireAuth.d.ts +45 -0
  7. package/dist/kit/builder/auth/components/RequireAuth.d.ts.map +1 -0
  8. package/dist/kit/builder/auth/components/ShowWhenAuthenticated.d.ts +8 -0
  9. package/dist/kit/builder/auth/components/ShowWhenAuthenticated.d.ts.map +1 -0
  10. package/dist/kit/builder/auth/components/ShowWhenError.d.ts +8 -0
  11. package/dist/kit/builder/auth/components/ShowWhenError.d.ts.map +1 -0
  12. package/dist/kit/builder/auth/components/ShowWhenLoading.d.ts +8 -0
  13. package/dist/kit/builder/auth/components/ShowWhenLoading.d.ts.map +1 -0
  14. package/dist/kit/builder/auth/components/ShowWhenUnauthenticated.d.ts +8 -0
  15. package/dist/kit/builder/auth/components/ShowWhenUnauthenticated.d.ts.map +1 -0
  16. package/dist/kit/builder/auth/components/withPermission.d.ts +7 -0
  17. package/dist/kit/builder/auth/components/withPermission.d.ts.map +1 -0
  18. package/dist/kit/builder/auth/hooks/action-hooks.d.ts +18 -0
  19. package/dist/kit/builder/auth/hooks/action-hooks.d.ts.map +1 -0
  20. package/dist/kit/builder/auth/hooks/core-hooks.d.ts +56 -0
  21. package/dist/kit/builder/auth/hooks/core-hooks.d.ts.map +1 -0
  22. package/dist/kit/builder/auth/hooks/index.d.ts +5 -0
  23. package/dist/kit/builder/auth/hooks/index.d.ts.map +1 -0
  24. package/dist/kit/builder/auth/hooks/permission-hooks.d.ts +18 -0
  25. package/dist/kit/builder/auth/hooks/permission-hooks.d.ts.map +1 -0
  26. package/dist/kit/builder/auth/hooks/token-hooks.d.ts +13 -0
  27. package/dist/kit/builder/auth/hooks/token-hooks.d.ts.map +1 -0
  28. package/dist/kit/builder/auth/index.d.ts +14 -8
  29. package/dist/kit/builder/auth/index.d.ts.map +1 -1
  30. package/dist/kit/builder/auth/{AuthProvider.d.ts → providers/AuthProvider.d.ts} +1 -1
  31. package/dist/kit/builder/auth/providers/AuthProvider.d.ts.map +1 -0
  32. package/dist/kit/builder/auth/types/adapter-config.d.ts +31 -0
  33. package/dist/kit/builder/auth/types/adapter-config.d.ts.map +1 -0
  34. package/dist/kit/builder/auth/types/adapter.d.ts +80 -0
  35. package/dist/kit/builder/auth/types/adapter.d.ts.map +1 -0
  36. package/dist/kit/builder/auth/types/core.d.ts +16 -0
  37. package/dist/kit/builder/auth/types/core.d.ts.map +1 -0
  38. package/dist/kit/builder/auth/types/index.d.ts +10 -0
  39. package/dist/kit/builder/auth/types/index.d.ts.map +1 -0
  40. package/dist/kit/builder/auth/types/middleware.d.ts +11 -0
  41. package/dist/kit/builder/auth/types/middleware.d.ts.map +1 -0
  42. package/dist/kit/builder/auth/types/permissions.d.ts +17 -0
  43. package/dist/kit/builder/auth/types/permissions.d.ts.map +1 -0
  44. package/dist/kit/builder/auth/types/state.d.ts +13 -0
  45. package/dist/kit/builder/auth/types/state.d.ts.map +1 -0
  46. package/dist/kit/builder/auth/types/storage.d.ts +20 -0
  47. package/dist/kit/builder/auth/types/storage.d.ts.map +1 -0
  48. package/dist/kit/builder/auth/types/token-manager.d.ts +7 -0
  49. package/dist/kit/builder/auth/types/token-manager.d.ts.map +1 -0
  50. package/dist/kit/builder/auth/types/utils.d.ts +7 -0
  51. package/dist/kit/builder/auth/types/utils.d.ts.map +1 -0
  52. package/dist/kit/builder/auth/{adapter.d.ts → utils/auth-adapter.d.ts} +2 -2
  53. package/dist/kit/builder/auth/utils/auth-adapter.d.ts.map +1 -0
  54. package/dist/kit/builder/auth/utils/client-adapters/apollo-link.d.ts +4 -0
  55. package/dist/kit/builder/auth/utils/client-adapters/apollo-link.d.ts.map +1 -0
  56. package/dist/kit/builder/auth/utils/client-adapters/axios.d.ts +6 -0
  57. package/dist/kit/builder/auth/utils/client-adapters/axios.d.ts.map +1 -0
  58. package/dist/kit/builder/auth/utils/client-adapters/fetch.d.ts +6 -0
  59. package/dist/kit/builder/auth/utils/client-adapters/fetch.d.ts.map +1 -0
  60. package/dist/kit/builder/auth/utils/client-adapters/graphql.d.ts +9 -0
  61. package/dist/kit/builder/auth/utils/client-adapters/graphql.d.ts.map +1 -0
  62. package/dist/kit/builder/auth/utils/client-adapters/index.d.ts +7 -0
  63. package/dist/kit/builder/auth/utils/client-adapters/index.d.ts.map +1 -0
  64. package/dist/kit/builder/auth/utils/client-adapters/rest.d.ts +9 -0
  65. package/dist/kit/builder/auth/utils/client-adapters/rest.d.ts.map +1 -0
  66. package/dist/kit/builder/auth/utils/client-adapters/urql-exchange.d.ts +14 -0
  67. package/dist/kit/builder/auth/utils/client-adapters/urql-exchange.d.ts.map +1 -0
  68. package/dist/kit/builder/auth/{permission-checker.d.ts → utils/permission-checker.d.ts} +1 -1
  69. package/dist/kit/builder/auth/utils/permission-checker.d.ts.map +1 -0
  70. package/dist/kit/builder/auth/utils/storage/browser.d.ts +11 -0
  71. package/dist/kit/builder/auth/utils/storage/browser.d.ts.map +1 -0
  72. package/dist/kit/builder/auth/utils/storage/cookie.d.ts +3 -0
  73. package/dist/kit/builder/auth/utils/storage/cookie.d.ts.map +1 -0
  74. package/dist/kit/builder/auth/utils/storage/encryption.d.ts +7 -0
  75. package/dist/kit/builder/auth/utils/storage/encryption.d.ts.map +1 -0
  76. package/dist/kit/builder/auth/utils/storage/env.d.ts +2 -0
  77. package/dist/kit/builder/auth/utils/storage/env.d.ts.map +1 -0
  78. package/dist/kit/builder/auth/utils/storage/factory.d.ts +6 -0
  79. package/dist/kit/builder/auth/utils/storage/factory.d.ts.map +1 -0
  80. package/dist/kit/builder/auth/utils/storage/index.d.ts +7 -0
  81. package/dist/kit/builder/auth/utils/storage/index.d.ts.map +1 -0
  82. package/dist/kit/builder/auth/utils/storage/memory.d.ts +3 -0
  83. package/dist/kit/builder/auth/utils/storage/memory.d.ts.map +1 -0
  84. package/dist/kit/builder/auth/{token-manager.d.ts → utils/token-manager.d.ts} +1 -1
  85. package/dist/kit/builder/auth/utils/token-manager.d.ts.map +1 -0
  86. package/dist/kit/components/login/Login.d.ts +2 -1
  87. package/dist/kit/components/login/Login.d.ts.map +1 -1
  88. package/dist/kit/layouts/admin/components/AdminLayout.d.ts +2 -1
  89. package/dist/kit/layouts/admin/components/AdminLayout.d.ts.map +1 -1
  90. package/dist/kit/themes/clean-slate.css +28 -4
  91. package/dist/kit/themes/default.css +28 -4
  92. package/dist/kit/themes/minimal-modern.css +28 -4
  93. package/dist/kit/themes/spotify.css +28 -4
  94. package/package.json +1 -1
  95. package/src/index.ts +1 -0
  96. package/src/kit/builder/auth/components/Can.tsx +27 -0
  97. package/src/kit/builder/auth/components/RequireAuth.tsx +78 -0
  98. package/src/kit/builder/auth/components/ShowWhenAuthenticated.tsx +10 -0
  99. package/src/kit/builder/auth/components/ShowWhenError.tsx +10 -0
  100. package/src/kit/builder/auth/components/ShowWhenLoading.tsx +10 -0
  101. package/src/kit/builder/auth/components/ShowWhenUnauthenticated.tsx +10 -0
  102. package/src/kit/builder/auth/components/withPermission.tsx +23 -0
  103. package/src/kit/builder/auth/hooks/action-hooks.ts +34 -0
  104. package/src/kit/builder/auth/hooks/core-hooks.ts +65 -0
  105. package/src/kit/builder/auth/hooks/index.ts +4 -0
  106. package/src/kit/builder/auth/hooks/permission-hooks.ts +43 -0
  107. package/src/kit/builder/auth/hooks/token-hooks.ts +25 -0
  108. package/src/kit/builder/auth/index.ts +16 -18
  109. package/src/kit/builder/auth/{AuthProvider.tsx → providers/AuthProvider.tsx} +1 -1
  110. package/src/kit/builder/auth/types/adapter-config.ts +44 -0
  111. package/src/kit/builder/auth/types/adapter.ts +132 -0
  112. package/src/kit/builder/auth/types/core.ts +27 -0
  113. package/src/kit/builder/auth/types/index.ts +9 -0
  114. package/src/kit/builder/auth/types/middleware.ts +20 -0
  115. package/src/kit/builder/auth/types/permissions.ts +23 -0
  116. package/src/kit/builder/auth/types/state.ts +16 -0
  117. package/src/kit/builder/auth/types/storage.ts +21 -0
  118. package/src/kit/builder/auth/types/token-manager.ts +9 -0
  119. package/src/kit/builder/auth/types/utils.ts +55 -0
  120. package/src/kit/builder/auth/{adapter.ts → utils/auth-adapter.ts} +3 -2
  121. package/src/kit/builder/auth/utils/client-adapters/apollo-link.ts +30 -0
  122. package/src/kit/builder/auth/utils/client-adapters/axios.ts +61 -0
  123. package/src/kit/builder/auth/utils/client-adapters/fetch.ts +48 -0
  124. package/src/kit/builder/auth/utils/client-adapters/graphql.ts +60 -0
  125. package/src/kit/builder/auth/utils/client-adapters/index.ts +6 -0
  126. package/src/kit/builder/auth/utils/client-adapters/rest.ts +60 -0
  127. package/src/kit/builder/auth/utils/client-adapters/urql-exchange.ts +76 -0
  128. package/src/kit/builder/auth/{permission-checker.ts → utils/permission-checker.ts} +1 -1
  129. package/src/kit/builder/auth/utils/storage/browser.ts +99 -0
  130. package/src/kit/builder/auth/utils/storage/cookie.ts +116 -0
  131. package/src/kit/builder/auth/utils/storage/encryption.ts +80 -0
  132. package/src/kit/builder/auth/utils/storage/env.ts +2 -0
  133. package/src/kit/builder/auth/utils/storage/factory.ts +37 -0
  134. package/src/kit/builder/auth/utils/storage/index.ts +6 -0
  135. package/src/kit/builder/auth/utils/storage/memory.ts +15 -0
  136. package/src/kit/builder/auth/{token-manager.ts → utils/token-manager.ts} +1 -1
  137. package/src/kit/components/login/Login.tsx +36 -21
  138. package/src/kit/layouts/admin/components/AdminLayout.tsx +24 -17
  139. package/dist/kit/builder/auth/AuthProvider.d.ts.map +0 -1
  140. package/dist/kit/builder/auth/adapter.d.ts.map +0 -1
  141. package/dist/kit/builder/auth/client-adapters.d.ts +0 -149
  142. package/dist/kit/builder/auth/client-adapters.d.ts.map +0 -1
  143. package/dist/kit/builder/auth/components.d.ts +0 -119
  144. package/dist/kit/builder/auth/components.d.ts.map +0 -1
  145. package/dist/kit/builder/auth/hooks.d.ts +0 -158
  146. package/dist/kit/builder/auth/hooks.d.ts.map +0 -1
  147. package/dist/kit/builder/auth/permission-checker.d.ts.map +0 -1
  148. package/dist/kit/builder/auth/storage.d.ts +0 -17
  149. package/dist/kit/builder/auth/storage.d.ts.map +0 -1
  150. package/dist/kit/builder/auth/token-manager.d.ts.map +0 -1
  151. package/dist/kit/builder/auth/types.d.ts +0 -183
  152. package/dist/kit/builder/auth/types.d.ts.map +0 -1
  153. package/src/kit/builder/auth/client-adapters.ts +0 -398
  154. package/src/kit/builder/auth/components.tsx +0 -221
  155. package/src/kit/builder/auth/hooks.ts +0 -237
  156. package/src/kit/builder/auth/storage.ts +0 -366
  157. 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,8 @@
1
+ import { ReactNode } from 'react';
2
+ /**
3
+ * Component that shows children only when authenticated.
4
+ */
5
+ export declare function ShowWhenAuthenticated({ children }: {
6
+ children: ReactNode;
7
+ }): ReactNode;
8
+ //# sourceMappingURL=ShowWhenAuthenticated.d.ts.map
@@ -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,8 @@
1
+ import { ReactNode } from 'react';
2
+ /**
3
+ * Component that shows children only when there's an error.
4
+ */
5
+ export declare function ShowWhenError({ children }: {
6
+ children: ReactNode;
7
+ }): ReactNode;
8
+ //# sourceMappingURL=ShowWhenError.d.ts.map
@@ -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,8 @@
1
+ import { ReactNode } from 'react';
2
+ /**
3
+ * Component that shows children only while loading.
4
+ */
5
+ export declare function ShowWhenLoading({ children }: {
6
+ children: ReactNode;
7
+ }): ReactNode;
8
+ //# sourceMappingURL=ShowWhenLoading.d.ts.map
@@ -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,5 @@
1
+ export * from './core-hooks';
2
+ export * from './permission-hooks';
3
+ export * from './token-hooks';
4
+ export * from './action-hooks';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -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, Can, withPermission, ShowWhenAuthenticated, ShowWhenUnauthenticated, ShowWhenLoading, ShowWhenError, } from './components';
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,WAAW,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAM9D,OAAO,EACL,aAAa,EACb,mBAAmB,EACnB,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,WAAW,CAAC;AAMnB,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EACL,iBAAiB,EACjB,WAAW,EACX,gBAAgB,EAChB,UAAU,EACV,sBAAsB,GACvB,MAAM,sBAAsB,CAAC;AAM9B,OAAO,EACL,wBAAwB,EACxB,qBAAqB,EACrB,0BAA0B,EAC1B,eAAe,EACf,oBAAoB,GACrB,MAAM,mBAAmB,CAAC;AAE3B,YAAY,EACV,2BAA2B,EAC3B,wBAAwB,GACzB,MAAM,mBAAmB,CAAC;AAM3B,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,EACL,WAAW,EACX,GAAG,EACH,cAAc,EACd,qBAAqB,EACrB,uBAAuB,EACvB,eAAe,EACf,aAAa,GACd,MAAM,cAAc,CAAC;AAMtB,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
+ {"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 './types';
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