@hammadj/better-auth-core 1.5.0-beta.9
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/.turbo/turbo-build.log +266 -0
- package/.turbo/turbo-test.log +2 -0
- package/LICENSE.md +20 -0
- package/dist/api/index.d.mts +181 -0
- package/dist/api/index.mjs +34 -0
- package/dist/api/index.mjs.map +1 -0
- package/dist/async_hooks/index.d.mts +7 -0
- package/dist/async_hooks/index.mjs +22 -0
- package/dist/async_hooks/index.mjs.map +1 -0
- package/dist/async_hooks/pure.index.d.mts +7 -0
- package/dist/async_hooks/pure.index.mjs +35 -0
- package/dist/async_hooks/pure.index.mjs.map +1 -0
- package/dist/context/endpoint-context.d.mts +19 -0
- package/dist/context/endpoint-context.mjs +32 -0
- package/dist/context/endpoint-context.mjs.map +1 -0
- package/dist/context/global.d.mts +7 -0
- package/dist/context/global.mjs +38 -0
- package/dist/context/global.mjs.map +1 -0
- package/dist/context/index.d.mts +5 -0
- package/dist/context/index.mjs +6 -0
- package/dist/context/request-state.d.mts +26 -0
- package/dist/context/request-state.mjs +50 -0
- package/dist/context/request-state.mjs.map +1 -0
- package/dist/context/transaction.d.mts +25 -0
- package/dist/context/transaction.mjs +96 -0
- package/dist/context/transaction.mjs.map +1 -0
- package/dist/db/adapter/factory.d.mts +28 -0
- package/dist/db/adapter/factory.mjs +716 -0
- package/dist/db/adapter/factory.mjs.map +1 -0
- package/dist/db/adapter/get-default-field-name.d.mts +19 -0
- package/dist/db/adapter/get-default-field-name.mjs +39 -0
- package/dist/db/adapter/get-default-field-name.mjs.map +1 -0
- package/dist/db/adapter/get-default-model-name.d.mts +13 -0
- package/dist/db/adapter/get-default-model-name.mjs +33 -0
- package/dist/db/adapter/get-default-model-name.mjs.map +1 -0
- package/dist/db/adapter/get-field-attributes.d.mts +30 -0
- package/dist/db/adapter/get-field-attributes.mjs +40 -0
- package/dist/db/adapter/get-field-attributes.mjs.map +1 -0
- package/dist/db/adapter/get-field-name.d.mts +19 -0
- package/dist/db/adapter/get-field-name.mjs +34 -0
- package/dist/db/adapter/get-field-name.mjs.map +1 -0
- package/dist/db/adapter/get-id-field.d.mts +40 -0
- package/dist/db/adapter/get-id-field.mjs +68 -0
- package/dist/db/adapter/get-id-field.mjs.map +1 -0
- package/dist/db/adapter/get-model-name.d.mts +13 -0
- package/dist/db/adapter/get-model-name.mjs +24 -0
- package/dist/db/adapter/get-model-name.mjs.map +1 -0
- package/dist/db/adapter/index.d.mts +515 -0
- package/dist/db/adapter/index.mjs +10 -0
- package/dist/db/adapter/types.d.mts +140 -0
- package/dist/db/adapter/utils.d.mts +8 -0
- package/dist/db/adapter/utils.mjs +39 -0
- package/dist/db/adapter/utils.mjs.map +1 -0
- package/dist/db/get-tables.d.mts +9 -0
- package/dist/db/get-tables.mjs +267 -0
- package/dist/db/get-tables.mjs.map +1 -0
- package/dist/db/index.d.mts +10 -0
- package/dist/db/index.mjs +9 -0
- package/dist/db/plugin.d.mts +13 -0
- package/dist/db/schema/account.d.mts +27 -0
- package/dist/db/schema/account.mjs +20 -0
- package/dist/db/schema/account.mjs.map +1 -0
- package/dist/db/schema/rate-limit.d.mts +15 -0
- package/dist/db/schema/rate-limit.mjs +12 -0
- package/dist/db/schema/rate-limit.mjs.map +1 -0
- package/dist/db/schema/session.d.mts +22 -0
- package/dist/db/schema/session.mjs +15 -0
- package/dist/db/schema/session.mjs.map +1 -0
- package/dist/db/schema/shared.d.mts +11 -0
- package/dist/db/schema/shared.mjs +12 -0
- package/dist/db/schema/shared.mjs.map +1 -0
- package/dist/db/schema/user.d.mts +21 -0
- package/dist/db/schema/user.mjs +14 -0
- package/dist/db/schema/user.mjs.map +1 -0
- package/dist/db/schema/verification.d.mts +20 -0
- package/dist/db/schema/verification.mjs +13 -0
- package/dist/db/schema/verification.mjs.map +1 -0
- package/dist/db/type.d.mts +147 -0
- package/dist/env/color-depth.d.mts +5 -0
- package/dist/env/color-depth.mjs +89 -0
- package/dist/env/color-depth.mjs.map +1 -0
- package/dist/env/env-impl.d.mts +33 -0
- package/dist/env/env-impl.mjs +83 -0
- package/dist/env/env-impl.mjs.map +1 -0
- package/dist/env/index.d.mts +4 -0
- package/dist/env/index.mjs +5 -0
- package/dist/env/logger.d.mts +49 -0
- package/dist/env/logger.mjs +82 -0
- package/dist/env/logger.mjs.map +1 -0
- package/dist/error/codes.d.mts +199 -0
- package/dist/error/codes.mjs +57 -0
- package/dist/error/codes.mjs.map +1 -0
- package/dist/error/index.d.mts +20 -0
- package/dist/error/index.mjs +30 -0
- package/dist/error/index.mjs.map +1 -0
- package/dist/index.d.mts +8 -0
- package/dist/index.mjs +1 -0
- package/dist/oauth2/client-credentials-token.d.mts +37 -0
- package/dist/oauth2/client-credentials-token.mjs +55 -0
- package/dist/oauth2/client-credentials-token.mjs.map +1 -0
- package/dist/oauth2/create-authorization-url.d.mts +46 -0
- package/dist/oauth2/create-authorization-url.mjs +43 -0
- package/dist/oauth2/create-authorization-url.mjs.map +1 -0
- package/dist/oauth2/index.d.mts +8 -0
- package/dist/oauth2/index.mjs +8 -0
- package/dist/oauth2/oauth-provider.d.mts +195 -0
- package/dist/oauth2/refresh-access-token.d.mts +36 -0
- package/dist/oauth2/refresh-access-token.mjs +59 -0
- package/dist/oauth2/refresh-access-token.mjs.map +1 -0
- package/dist/oauth2/utils.d.mts +8 -0
- package/dist/oauth2/utils.mjs +28 -0
- package/dist/oauth2/utils.mjs.map +1 -0
- package/dist/oauth2/validate-authorization-code.d.mts +56 -0
- package/dist/oauth2/validate-authorization-code.mjs +72 -0
- package/dist/oauth2/validate-authorization-code.mjs.map +1 -0
- package/dist/oauth2/verify.d.mts +43 -0
- package/dist/oauth2/verify.mjs +96 -0
- package/dist/oauth2/verify.mjs.map +1 -0
- package/dist/social-providers/apple.d.mts +120 -0
- package/dist/social-providers/apple.mjs +105 -0
- package/dist/social-providers/apple.mjs.map +1 -0
- package/dist/social-providers/atlassian.d.mts +73 -0
- package/dist/social-providers/atlassian.mjs +84 -0
- package/dist/social-providers/atlassian.mjs.map +1 -0
- package/dist/social-providers/cognito.d.mts +88 -0
- package/dist/social-providers/cognito.mjs +166 -0
- package/dist/social-providers/cognito.mjs.map +1 -0
- package/dist/social-providers/discord.d.mts +127 -0
- package/dist/social-providers/discord.mjs +65 -0
- package/dist/social-providers/discord.mjs.map +1 -0
- package/dist/social-providers/dropbox.d.mts +72 -0
- package/dist/social-providers/dropbox.mjs +76 -0
- package/dist/social-providers/dropbox.mjs.map +1 -0
- package/dist/social-providers/facebook.d.mts +82 -0
- package/dist/social-providers/facebook.mjs +121 -0
- package/dist/social-providers/facebook.mjs.map +1 -0
- package/dist/social-providers/figma.d.mts +64 -0
- package/dist/social-providers/figma.mjs +87 -0
- package/dist/social-providers/figma.mjs.map +1 -0
- package/dist/social-providers/github.d.mts +105 -0
- package/dist/social-providers/github.mjs +97 -0
- package/dist/social-providers/github.mjs.map +1 -0
- package/dist/social-providers/gitlab.d.mts +126 -0
- package/dist/social-providers/gitlab.mjs +83 -0
- package/dist/social-providers/gitlab.mjs.map +1 -0
- package/dist/social-providers/google.d.mts +100 -0
- package/dist/social-providers/google.mjs +109 -0
- package/dist/social-providers/google.mjs.map +1 -0
- package/dist/social-providers/huggingface.d.mts +86 -0
- package/dist/social-providers/huggingface.mjs +76 -0
- package/dist/social-providers/huggingface.mjs.map +1 -0
- package/dist/social-providers/index.d.mts +1725 -0
- package/dist/social-providers/index.mjs +77 -0
- package/dist/social-providers/index.mjs.map +1 -0
- package/dist/social-providers/kakao.d.mts +164 -0
- package/dist/social-providers/kakao.mjs +73 -0
- package/dist/social-providers/kakao.mjs.map +1 -0
- package/dist/social-providers/kick.d.mts +76 -0
- package/dist/social-providers/kick.mjs +72 -0
- package/dist/social-providers/kick.mjs.map +1 -0
- package/dist/social-providers/line.d.mts +108 -0
- package/dist/social-providers/line.mjs +114 -0
- package/dist/social-providers/line.mjs.map +1 -0
- package/dist/social-providers/linear.d.mts +71 -0
- package/dist/social-providers/linear.mjs +89 -0
- package/dist/social-providers/linear.mjs.map +1 -0
- package/dist/social-providers/linkedin.d.mts +70 -0
- package/dist/social-providers/linkedin.mjs +77 -0
- package/dist/social-providers/linkedin.mjs.map +1 -0
- package/dist/social-providers/microsoft-entra-id.d.mts +175 -0
- package/dist/social-providers/microsoft-entra-id.mjs +107 -0
- package/dist/social-providers/microsoft-entra-id.mjs.map +1 -0
- package/dist/social-providers/naver.d.mts +95 -0
- package/dist/social-providers/naver.mjs +68 -0
- package/dist/social-providers/naver.mjs.map +1 -0
- package/dist/social-providers/notion.d.mts +67 -0
- package/dist/social-providers/notion.mjs +76 -0
- package/dist/social-providers/notion.mjs.map +1 -0
- package/dist/social-providers/paybin.d.mts +74 -0
- package/dist/social-providers/paybin.mjs +86 -0
- package/dist/social-providers/paybin.mjs.map +1 -0
- package/dist/social-providers/paypal.d.mts +132 -0
- package/dist/social-providers/paypal.mjs +145 -0
- package/dist/social-providers/paypal.mjs.map +1 -0
- package/dist/social-providers/polar.d.mts +77 -0
- package/dist/social-providers/polar.mjs +74 -0
- package/dist/social-providers/polar.mjs.map +1 -0
- package/dist/social-providers/reddit.d.mts +65 -0
- package/dist/social-providers/reddit.mjs +84 -0
- package/dist/social-providers/reddit.mjs.map +1 -0
- package/dist/social-providers/roblox.d.mts +73 -0
- package/dist/social-providers/roblox.mjs +60 -0
- package/dist/social-providers/roblox.mjs.map +1 -0
- package/dist/social-providers/salesforce.d.mts +82 -0
- package/dist/social-providers/salesforce.mjs +92 -0
- package/dist/social-providers/salesforce.mjs.map +1 -0
- package/dist/social-providers/slack.d.mts +86 -0
- package/dist/social-providers/slack.mjs +69 -0
- package/dist/social-providers/slack.mjs.map +1 -0
- package/dist/social-providers/spotify.d.mts +66 -0
- package/dist/social-providers/spotify.mjs +72 -0
- package/dist/social-providers/spotify.mjs.map +1 -0
- package/dist/social-providers/tiktok.d.mts +171 -0
- package/dist/social-providers/tiktok.mjs +63 -0
- package/dist/social-providers/tiktok.mjs.map +1 -0
- package/dist/social-providers/twitch.d.mts +82 -0
- package/dist/social-providers/twitch.mjs +79 -0
- package/dist/social-providers/twitch.mjs.map +1 -0
- package/dist/social-providers/twitter.d.mts +129 -0
- package/dist/social-providers/twitter.mjs +88 -0
- package/dist/social-providers/twitter.mjs.map +1 -0
- package/dist/social-providers/vercel.d.mts +65 -0
- package/dist/social-providers/vercel.mjs +62 -0
- package/dist/social-providers/vercel.mjs.map +1 -0
- package/dist/social-providers/vk.d.mts +73 -0
- package/dist/social-providers/vk.mjs +84 -0
- package/dist/social-providers/vk.mjs.map +1 -0
- package/dist/social-providers/zoom.d.mts +173 -0
- package/dist/social-providers/zoom.mjs +73 -0
- package/dist/social-providers/zoom.mjs.map +1 -0
- package/dist/types/context.d.mts +267 -0
- package/dist/types/cookie.d.mts +16 -0
- package/dist/types/helper.d.mts +10 -0
- package/dist/types/index.d.mts +8 -0
- package/dist/types/init-options.d.mts +1314 -0
- package/dist/types/plugin-client.d.mts +112 -0
- package/dist/types/plugin.d.mts +125 -0
- package/dist/utils/db.d.mts +12 -0
- package/dist/utils/db.mjs +17 -0
- package/dist/utils/db.mjs.map +1 -0
- package/dist/utils/deprecate.d.mts +10 -0
- package/dist/utils/deprecate.mjs +18 -0
- package/dist/utils/deprecate.mjs.map +1 -0
- package/dist/utils/error-codes.d.mts +13 -0
- package/dist/utils/error-codes.mjs +12 -0
- package/dist/utils/error-codes.mjs.map +1 -0
- package/dist/utils/id.d.mts +5 -0
- package/dist/utils/id.mjs +10 -0
- package/dist/utils/id.mjs.map +1 -0
- package/dist/utils/ip.d.mts +55 -0
- package/dist/utils/ip.mjs +119 -0
- package/dist/utils/ip.mjs.map +1 -0
- package/dist/utils/json.d.mts +5 -0
- package/dist/utils/json.mjs +26 -0
- package/dist/utils/json.mjs.map +1 -0
- package/dist/utils/string.d.mts +5 -0
- package/dist/utils/string.mjs +8 -0
- package/dist/utils/string.mjs.map +1 -0
- package/dist/utils/url.d.mts +21 -0
- package/dist/utils/url.mjs +33 -0
- package/dist/utils/url.mjs.map +1 -0
- package/package.json +147 -0
- package/src/api/index.ts +106 -0
- package/src/async_hooks/index.ts +40 -0
- package/src/async_hooks/pure.index.ts +46 -0
- package/src/context/endpoint-context.ts +50 -0
- package/src/context/global.ts +57 -0
- package/src/context/index.ts +23 -0
- package/src/context/request-state.test.ts +94 -0
- package/src/context/request-state.ts +91 -0
- package/src/context/transaction.ts +136 -0
- package/src/db/adapter/factory.ts +1362 -0
- package/src/db/adapter/get-default-field-name.ts +59 -0
- package/src/db/adapter/get-default-model-name.ts +51 -0
- package/src/db/adapter/get-field-attributes.ts +62 -0
- package/src/db/adapter/get-field-name.ts +43 -0
- package/src/db/adapter/get-id-field.ts +141 -0
- package/src/db/adapter/get-model-name.ts +36 -0
- package/src/db/adapter/index.ts +554 -0
- package/src/db/adapter/types.ts +171 -0
- package/src/db/adapter/utils.ts +61 -0
- package/src/db/get-tables.ts +296 -0
- package/src/db/index.ts +18 -0
- package/src/db/plugin.ts +11 -0
- package/src/db/schema/account.ts +34 -0
- package/src/db/schema/rate-limit.ts +21 -0
- package/src/db/schema/session.ts +17 -0
- package/src/db/schema/shared.ts +7 -0
- package/src/db/schema/user.ts +16 -0
- package/src/db/schema/verification.ts +15 -0
- package/src/db/test/get-tables.test.ts +116 -0
- package/src/db/type.ts +180 -0
- package/src/env/color-depth.ts +172 -0
- package/src/env/env-impl.ts +124 -0
- package/src/env/index.ts +23 -0
- package/src/env/logger.test.ts +34 -0
- package/src/env/logger.ts +145 -0
- package/src/error/codes.ts +58 -0
- package/src/error/index.ts +35 -0
- package/src/index.ts +1 -0
- package/src/oauth2/client-credentials-token.ts +102 -0
- package/src/oauth2/create-authorization-url.ts +87 -0
- package/src/oauth2/index.ts +26 -0
- package/src/oauth2/oauth-provider.ts +222 -0
- package/src/oauth2/refresh-access-token.ts +124 -0
- package/src/oauth2/utils.ts +38 -0
- package/src/oauth2/validate-authorization-code.ts +149 -0
- package/src/oauth2/validate-token.test.ts +174 -0
- package/src/oauth2/verify.ts +221 -0
- package/src/social-providers/apple.ts +223 -0
- package/src/social-providers/atlassian.ts +132 -0
- package/src/social-providers/cognito.ts +279 -0
- package/src/social-providers/discord.ts +169 -0
- package/src/social-providers/dropbox.ts +112 -0
- package/src/social-providers/facebook.ts +206 -0
- package/src/social-providers/figma.ts +117 -0
- package/src/social-providers/github.ts +184 -0
- package/src/social-providers/gitlab.ts +155 -0
- package/src/social-providers/google.ts +199 -0
- package/src/social-providers/huggingface.ts +118 -0
- package/src/social-providers/index.ts +127 -0
- package/src/social-providers/kakao.ts +178 -0
- package/src/social-providers/kick.ts +109 -0
- package/src/social-providers/line.ts +169 -0
- package/src/social-providers/linear.ts +121 -0
- package/src/social-providers/linkedin.ts +110 -0
- package/src/social-providers/microsoft-entra-id.ts +259 -0
- package/src/social-providers/naver.ts +112 -0
- package/src/social-providers/notion.ts +108 -0
- package/src/social-providers/paybin.ts +122 -0
- package/src/social-providers/paypal.ts +263 -0
- package/src/social-providers/polar.ts +110 -0
- package/src/social-providers/reddit.ts +122 -0
- package/src/social-providers/roblox.ts +111 -0
- package/src/social-providers/salesforce.ts +159 -0
- package/src/social-providers/slack.ts +111 -0
- package/src/social-providers/spotify.ts +93 -0
- package/src/social-providers/tiktok.ts +209 -0
- package/src/social-providers/twitch.ts +111 -0
- package/src/social-providers/twitter.ts +198 -0
- package/src/social-providers/vercel.ts +87 -0
- package/src/social-providers/vk.ts +124 -0
- package/src/social-providers/zoom.ts +238 -0
- package/src/types/context.ts +396 -0
- package/src/types/cookie.ts +10 -0
- package/src/types/helper.ts +26 -0
- package/src/types/index.ts +32 -0
- package/src/types/init-options.ts +1529 -0
- package/src/types/plugin-client.ts +127 -0
- package/src/types/plugin.ts +157 -0
- package/src/utils/db.ts +20 -0
- package/src/utils/deprecate.test.ts +72 -0
- package/src/utils/deprecate.ts +21 -0
- package/src/utils/error-codes.ts +65 -0
- package/src/utils/id.ts +5 -0
- package/src/utils/ip.test.ts +255 -0
- package/src/utils/ip.ts +211 -0
- package/src/utils/json.ts +25 -0
- package/src/utils/string.ts +3 -0
- package/src/utils/url.ts +43 -0
- package/tsconfig.json +7 -0
- package/tsdown.config.ts +35 -0
- package/vitest.config.ts +3 -0
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import type {
|
|
2
|
+
BetterFetch,
|
|
3
|
+
BetterFetchOption,
|
|
4
|
+
BetterFetchPlugin,
|
|
5
|
+
} from "@better-fetch/fetch";
|
|
6
|
+
import type { Atom, WritableAtom } from "nanostores";
|
|
7
|
+
import type { LiteralString } from "./helper";
|
|
8
|
+
import type { BetterAuthOptions } from "./init-options";
|
|
9
|
+
import type { BetterAuthPlugin } from "./plugin";
|
|
10
|
+
|
|
11
|
+
export interface ClientStore {
|
|
12
|
+
notify: (signal: string) => void;
|
|
13
|
+
listen: (signal: string, listener: () => void) => void;
|
|
14
|
+
atoms: Record<string, WritableAtom<any>>;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export type ClientAtomListener = {
|
|
18
|
+
matcher: (path: string) => boolean;
|
|
19
|
+
signal: "$sessionSignal" | Omit<string, "$sessionSignal">;
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Better-Fetch options but with additional options for the auth-client.
|
|
24
|
+
*/
|
|
25
|
+
export type ClientFetchOption<
|
|
26
|
+
Body = any,
|
|
27
|
+
Query extends Record<string, any> = any,
|
|
28
|
+
Params extends Record<string, any> | Array<string> | undefined = any,
|
|
29
|
+
Res = any,
|
|
30
|
+
> = BetterFetchOption<Body, Query, Params, Res> & {
|
|
31
|
+
/**
|
|
32
|
+
* Certain endpoints, upon successful response, will trigger atom signals and thus rerendering all hooks related to that atom.
|
|
33
|
+
*
|
|
34
|
+
* This option is useful when you want to skip hook rerenders.
|
|
35
|
+
*/
|
|
36
|
+
disableSignal?: boolean | undefined;
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
export interface RevalidateOptions {
|
|
40
|
+
/**
|
|
41
|
+
* A time interval (in seconds) after which the session will be re-fetched.
|
|
42
|
+
* If set to `0` (default), the session is not polled.
|
|
43
|
+
*
|
|
44
|
+
* This helps prevent session expiry during idle periods by periodically
|
|
45
|
+
* refreshing the session.
|
|
46
|
+
*
|
|
47
|
+
* @default 0
|
|
48
|
+
*/
|
|
49
|
+
refetchInterval?: number | undefined;
|
|
50
|
+
/**
|
|
51
|
+
* Automatically refetch the session when the user switches back to the window/tab.
|
|
52
|
+
* This option activates this behavior if set to `true` (default).
|
|
53
|
+
*
|
|
54
|
+
* Prevents expired sessions when users switch tabs and come back later.
|
|
55
|
+
*
|
|
56
|
+
* @default true
|
|
57
|
+
*/
|
|
58
|
+
refetchOnWindowFocus?: boolean | undefined;
|
|
59
|
+
/**
|
|
60
|
+
* Set to `false` to stop polling when the device has no internet access
|
|
61
|
+
* (determined by `navigator.onLine`).
|
|
62
|
+
*
|
|
63
|
+
* @default false
|
|
64
|
+
* @see https://developer.mozilla.org/en-US/docs/Web/API/NavigatorOnLine/onLine
|
|
65
|
+
*/
|
|
66
|
+
refetchWhenOffline?: boolean | undefined;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
export interface BetterAuthClientOptions {
|
|
70
|
+
fetchOptions?: ClientFetchOption | undefined;
|
|
71
|
+
plugins?: BetterAuthClientPlugin[] | undefined;
|
|
72
|
+
baseURL?: string | undefined;
|
|
73
|
+
basePath?: string | undefined;
|
|
74
|
+
disableDefaultFetchPlugins?: boolean | undefined;
|
|
75
|
+
$InferAuth?: BetterAuthOptions | undefined;
|
|
76
|
+
sessionOptions?: RevalidateOptions | undefined;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
export interface BetterAuthClientPlugin {
|
|
80
|
+
id: LiteralString;
|
|
81
|
+
/**
|
|
82
|
+
* only used for type inference. don't pass the
|
|
83
|
+
* actual plugin
|
|
84
|
+
*/
|
|
85
|
+
$InferServerPlugin?: BetterAuthPlugin | undefined;
|
|
86
|
+
/**
|
|
87
|
+
* Custom actions
|
|
88
|
+
*/
|
|
89
|
+
getActions?: (
|
|
90
|
+
$fetch: BetterFetch,
|
|
91
|
+
$store: ClientStore,
|
|
92
|
+
/**
|
|
93
|
+
* better-auth client options
|
|
94
|
+
*/
|
|
95
|
+
options: BetterAuthClientOptions | undefined,
|
|
96
|
+
) => Record<string, any>;
|
|
97
|
+
/**
|
|
98
|
+
* State atoms that'll be resolved by each framework
|
|
99
|
+
* auth store.
|
|
100
|
+
*/
|
|
101
|
+
getAtoms?: (($fetch: BetterFetch) => Record<string, Atom<any>>) | undefined;
|
|
102
|
+
/**
|
|
103
|
+
* specify path methods for server plugin inferred
|
|
104
|
+
* endpoints to force a specific method.
|
|
105
|
+
*/
|
|
106
|
+
pathMethods?: Record<string, "POST" | "GET"> | undefined;
|
|
107
|
+
/**
|
|
108
|
+
* Better fetch plugins
|
|
109
|
+
*/
|
|
110
|
+
fetchPlugins?: BetterFetchPlugin[] | undefined;
|
|
111
|
+
/**
|
|
112
|
+
* a list of recaller based on a matcher function.
|
|
113
|
+
* The signal name needs to match a signal in this
|
|
114
|
+
* plugin or any plugin the user might have added.
|
|
115
|
+
*/
|
|
116
|
+
atomListeners?: ClientAtomListener[] | undefined;
|
|
117
|
+
/**
|
|
118
|
+
* The error codes returned by the plugin
|
|
119
|
+
*/
|
|
120
|
+
$ERROR_CODES?: Record<
|
|
121
|
+
string,
|
|
122
|
+
{
|
|
123
|
+
code: string;
|
|
124
|
+
message: string;
|
|
125
|
+
}
|
|
126
|
+
>;
|
|
127
|
+
}
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
import type {
|
|
2
|
+
Endpoint,
|
|
3
|
+
EndpointContext,
|
|
4
|
+
InputContext,
|
|
5
|
+
Middleware,
|
|
6
|
+
} from "better-call";
|
|
7
|
+
import type { Migration } from "kysely";
|
|
8
|
+
import type { AuthMiddleware } from "../api";
|
|
9
|
+
import type { BetterAuthPluginDBSchema } from "../db";
|
|
10
|
+
import type { AuthContext } from "./context";
|
|
11
|
+
import type { Awaitable, LiteralString } from "./helper";
|
|
12
|
+
import type { BetterAuthOptions } from "./init-options";
|
|
13
|
+
|
|
14
|
+
type DeepPartial<T> = T extends Function
|
|
15
|
+
? T
|
|
16
|
+
: T extends object
|
|
17
|
+
? { [K in keyof T]?: DeepPartial<T[K]> }
|
|
18
|
+
: T;
|
|
19
|
+
|
|
20
|
+
export type HookEndpointContext = Partial<
|
|
21
|
+
EndpointContext<string, any> & Omit<InputContext<string, any>, "method">
|
|
22
|
+
> & {
|
|
23
|
+
path?: string;
|
|
24
|
+
context: AuthContext & {
|
|
25
|
+
returned?: unknown | undefined;
|
|
26
|
+
responseHeaders?: Headers | undefined;
|
|
27
|
+
};
|
|
28
|
+
headers?: Headers | undefined;
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
export type BetterAuthPlugin = {
|
|
32
|
+
id: LiteralString;
|
|
33
|
+
/**
|
|
34
|
+
* The init function is called when the plugin is initialized.
|
|
35
|
+
* You can return a new context or modify the existing context.
|
|
36
|
+
*/
|
|
37
|
+
init?:
|
|
38
|
+
| ((ctx: AuthContext) =>
|
|
39
|
+
| Awaitable<{
|
|
40
|
+
context?: DeepPartial<Omit<AuthContext, "options">>;
|
|
41
|
+
options?: Partial<BetterAuthOptions>;
|
|
42
|
+
}>
|
|
43
|
+
| void
|
|
44
|
+
| Promise<void>)
|
|
45
|
+
| undefined;
|
|
46
|
+
endpoints?:
|
|
47
|
+
| {
|
|
48
|
+
[key: string]: Endpoint;
|
|
49
|
+
}
|
|
50
|
+
| undefined;
|
|
51
|
+
middlewares?:
|
|
52
|
+
| {
|
|
53
|
+
path: string;
|
|
54
|
+
middleware: Middleware;
|
|
55
|
+
}[]
|
|
56
|
+
| undefined;
|
|
57
|
+
onRequest?:
|
|
58
|
+
| ((
|
|
59
|
+
request: Request,
|
|
60
|
+
ctx: AuthContext,
|
|
61
|
+
) => Promise<
|
|
62
|
+
| {
|
|
63
|
+
response: Response;
|
|
64
|
+
}
|
|
65
|
+
| {
|
|
66
|
+
request: Request;
|
|
67
|
+
}
|
|
68
|
+
| void
|
|
69
|
+
>)
|
|
70
|
+
| undefined;
|
|
71
|
+
onResponse?:
|
|
72
|
+
| ((
|
|
73
|
+
response: Response,
|
|
74
|
+
ctx: AuthContext,
|
|
75
|
+
) => Promise<{
|
|
76
|
+
response: Response;
|
|
77
|
+
} | void>)
|
|
78
|
+
| undefined;
|
|
79
|
+
hooks?:
|
|
80
|
+
| {
|
|
81
|
+
before?: {
|
|
82
|
+
matcher: (context: HookEndpointContext) => boolean;
|
|
83
|
+
handler: AuthMiddleware;
|
|
84
|
+
}[];
|
|
85
|
+
after?: {
|
|
86
|
+
matcher: (context: HookEndpointContext) => boolean;
|
|
87
|
+
handler: AuthMiddleware;
|
|
88
|
+
}[];
|
|
89
|
+
}
|
|
90
|
+
| undefined;
|
|
91
|
+
/**
|
|
92
|
+
* Schema the plugin needs
|
|
93
|
+
*
|
|
94
|
+
* This will also be used to migrate the database. If the fields are dynamic from the plugins
|
|
95
|
+
* configuration each time the configuration is changed a new migration will be created.
|
|
96
|
+
*
|
|
97
|
+
* NOTE: If you want to create migrations manually using
|
|
98
|
+
* migrations option or any other way you
|
|
99
|
+
* can disable migration per table basis.
|
|
100
|
+
*
|
|
101
|
+
* @example
|
|
102
|
+
* ```ts
|
|
103
|
+
* schema: {
|
|
104
|
+
* user: {
|
|
105
|
+
* fields: {
|
|
106
|
+
* email: {
|
|
107
|
+
* type: "string",
|
|
108
|
+
* },
|
|
109
|
+
* emailVerified: {
|
|
110
|
+
* type: "boolean",
|
|
111
|
+
* defaultValue: false,
|
|
112
|
+
* },
|
|
113
|
+
* },
|
|
114
|
+
* }
|
|
115
|
+
* } as AuthPluginSchema
|
|
116
|
+
* ```
|
|
117
|
+
*/
|
|
118
|
+
schema?: BetterAuthPluginDBSchema | undefined;
|
|
119
|
+
/**
|
|
120
|
+
* The migrations of the plugin. If you define schema that will automatically create
|
|
121
|
+
* migrations for you.
|
|
122
|
+
*
|
|
123
|
+
* ⚠️ Only uses this if you dont't want to use the schema option and you disabled migrations for
|
|
124
|
+
* the tables.
|
|
125
|
+
*/
|
|
126
|
+
migrations?: Record<string, Migration> | undefined;
|
|
127
|
+
/**
|
|
128
|
+
* The options of the plugin
|
|
129
|
+
*/
|
|
130
|
+
options?: Record<string, any> | undefined;
|
|
131
|
+
/**
|
|
132
|
+
* types to be inferred
|
|
133
|
+
*/
|
|
134
|
+
$Infer?: Record<string, any> | undefined;
|
|
135
|
+
/**
|
|
136
|
+
* The rate limit rules to apply to specific paths.
|
|
137
|
+
*/
|
|
138
|
+
rateLimit?:
|
|
139
|
+
| {
|
|
140
|
+
window: number;
|
|
141
|
+
max: number;
|
|
142
|
+
pathMatcher: (path: string) => boolean;
|
|
143
|
+
}[]
|
|
144
|
+
| undefined;
|
|
145
|
+
/**
|
|
146
|
+
* The error codes returned by the plugin
|
|
147
|
+
*/
|
|
148
|
+
$ERROR_CODES?: Record<string, { code: string; message: string }> | undefined;
|
|
149
|
+
/**
|
|
150
|
+
* All database operations that are performed by the plugin
|
|
151
|
+
*
|
|
152
|
+
* This will override the default database operations
|
|
153
|
+
*/
|
|
154
|
+
adapter?: {
|
|
155
|
+
[key: string]: (...args: any[]) => Awaitable<any>;
|
|
156
|
+
};
|
|
157
|
+
};
|
package/src/utils/db.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { DBFieldAttribute } from "../db";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Filters output data by removing fields with the `returned: false` attribute.
|
|
5
|
+
* This ensures sensitive fields are not exposed in API responses.
|
|
6
|
+
*/
|
|
7
|
+
export function filterOutputFields<T extends Record<string, unknown> | null>(
|
|
8
|
+
data: T,
|
|
9
|
+
additionalFields: Record<string, DBFieldAttribute> | undefined,
|
|
10
|
+
): T {
|
|
11
|
+
if (!data || !additionalFields) {
|
|
12
|
+
return data;
|
|
13
|
+
}
|
|
14
|
+
const returnFiltered = Object.entries(additionalFields)
|
|
15
|
+
.filter(([, { returned }]) => returned === false)
|
|
16
|
+
.map(([key]) => key);
|
|
17
|
+
return Object.entries(structuredClone(data))
|
|
18
|
+
.filter(([key]) => !returnFiltered.includes(key))
|
|
19
|
+
.reduce((acc, [key, value]) => ({ ...acc, [key]: value }), {} as T);
|
|
20
|
+
}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { describe, expect, it, vi } from "vitest";
|
|
2
|
+
import { deprecate } from "./deprecate";
|
|
3
|
+
|
|
4
|
+
describe("deprecate", () => {
|
|
5
|
+
it("should warn once when called multiple times", () => {
|
|
6
|
+
const warn = vi.fn();
|
|
7
|
+
const logger = { warn } as any;
|
|
8
|
+
const fn = vi.fn();
|
|
9
|
+
const deprecatedFn = deprecate(fn, "test message", logger);
|
|
10
|
+
|
|
11
|
+
deprecatedFn();
|
|
12
|
+
deprecatedFn();
|
|
13
|
+
deprecatedFn();
|
|
14
|
+
|
|
15
|
+
expect(warn).toHaveBeenCalledTimes(1);
|
|
16
|
+
expect(warn).toHaveBeenCalledWith("[Deprecation] test message");
|
|
17
|
+
expect(fn).toHaveBeenCalledTimes(3);
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
it("should use provided logger if available", () => {
|
|
21
|
+
const warn = vi.fn();
|
|
22
|
+
const logger = { warn } as any;
|
|
23
|
+
const fn = vi.fn();
|
|
24
|
+
const deprecatedFn = deprecate(fn, "test message", logger);
|
|
25
|
+
|
|
26
|
+
deprecatedFn();
|
|
27
|
+
|
|
28
|
+
expect(warn).toHaveBeenCalledWith("[Deprecation] test message");
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
it("should fall back to console.warn if no logger provided", () => {
|
|
32
|
+
const consoleWarn = vi.spyOn(console, "warn").mockImplementation(() => {});
|
|
33
|
+
const fn = vi.fn();
|
|
34
|
+
const deprecatedFn = deprecate(fn, "test message");
|
|
35
|
+
|
|
36
|
+
deprecatedFn();
|
|
37
|
+
|
|
38
|
+
expect(consoleWarn).toHaveBeenCalledWith("[Deprecation] test message");
|
|
39
|
+
consoleWarn.mockRestore();
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
it("should pass arguments and return value correctly", () => {
|
|
43
|
+
const fn = vi.fn((a: number, b: number) => a + b);
|
|
44
|
+
const deprecatedFn = deprecate(fn, "test message", {
|
|
45
|
+
warn: vi.fn(),
|
|
46
|
+
} as any);
|
|
47
|
+
|
|
48
|
+
const result = deprecatedFn(1, 2);
|
|
49
|
+
|
|
50
|
+
expect(result).toBe(3);
|
|
51
|
+
expect(fn).toHaveBeenCalledWith(1, 2);
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
it("should preserve this context", () => {
|
|
55
|
+
class TestClass {
|
|
56
|
+
value = 10;
|
|
57
|
+
method(a: number) {
|
|
58
|
+
return this.value + a;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
const instance = new TestClass();
|
|
63
|
+
const originalMethod = instance.method;
|
|
64
|
+
instance.method = deprecate(originalMethod, "test message", {
|
|
65
|
+
warn: vi.fn(),
|
|
66
|
+
} as any);
|
|
67
|
+
|
|
68
|
+
const result = instance.method(5);
|
|
69
|
+
|
|
70
|
+
expect(result).toBe(15);
|
|
71
|
+
});
|
|
72
|
+
});
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { InternalLogger } from "../env";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Wraps a function to log a deprecation warning at once.
|
|
5
|
+
*/
|
|
6
|
+
export function deprecate<T extends (...args: any[]) => any>(
|
|
7
|
+
fn: T,
|
|
8
|
+
message: string,
|
|
9
|
+
logger?: InternalLogger,
|
|
10
|
+
): T {
|
|
11
|
+
let warned = false;
|
|
12
|
+
|
|
13
|
+
return function (this: any, ...args: Parameters<T>): ReturnType<T> {
|
|
14
|
+
if (!warned) {
|
|
15
|
+
const warn = logger?.warn ?? console.warn;
|
|
16
|
+
warn(`[Deprecation] ${message}`);
|
|
17
|
+
warned = true;
|
|
18
|
+
}
|
|
19
|
+
return fn.apply(this, args);
|
|
20
|
+
} as T;
|
|
21
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
type UpperLetter =
|
|
2
|
+
| "A"
|
|
3
|
+
| "B"
|
|
4
|
+
| "C"
|
|
5
|
+
| "D"
|
|
6
|
+
| "E"
|
|
7
|
+
| "F"
|
|
8
|
+
| "G"
|
|
9
|
+
| "H"
|
|
10
|
+
| "I"
|
|
11
|
+
| "J"
|
|
12
|
+
| "K"
|
|
13
|
+
| "L"
|
|
14
|
+
| "M"
|
|
15
|
+
| "N"
|
|
16
|
+
| "O"
|
|
17
|
+
| "P"
|
|
18
|
+
| "Q"
|
|
19
|
+
| "R"
|
|
20
|
+
| "S"
|
|
21
|
+
| "T"
|
|
22
|
+
| "U"
|
|
23
|
+
| "V"
|
|
24
|
+
| "W"
|
|
25
|
+
| "X"
|
|
26
|
+
| "Y"
|
|
27
|
+
| "Z";
|
|
28
|
+
type SpecialCharacter = "_";
|
|
29
|
+
|
|
30
|
+
type IsValidUpperSnakeCase<S extends string> = S extends `${infer F}${infer R}`
|
|
31
|
+
? F extends UpperLetter | SpecialCharacter
|
|
32
|
+
? IsValidUpperSnakeCase<R>
|
|
33
|
+
: false
|
|
34
|
+
: true;
|
|
35
|
+
|
|
36
|
+
type InvalidKeyError<K extends string> =
|
|
37
|
+
`Invalid error code key: "${K}" - must only contain uppercase letters (A-Z) and underscores (_)`;
|
|
38
|
+
|
|
39
|
+
type ValidateErrorCodes<T> = {
|
|
40
|
+
[K in keyof T]: K extends string
|
|
41
|
+
? IsValidUpperSnakeCase<K> extends false
|
|
42
|
+
? InvalidKeyError<K>
|
|
43
|
+
: T[K]
|
|
44
|
+
: T[K];
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export function defineErrorCodes<const T extends Record<string, string>>(
|
|
48
|
+
codes: ValidateErrorCodes<T>,
|
|
49
|
+
): {
|
|
50
|
+
[K in keyof T]: {
|
|
51
|
+
code: K;
|
|
52
|
+
message: T[K];
|
|
53
|
+
};
|
|
54
|
+
} {
|
|
55
|
+
return Object.fromEntries(
|
|
56
|
+
Object.entries(codes).map(([key, value]) => [
|
|
57
|
+
key,
|
|
58
|
+
{
|
|
59
|
+
code: key,
|
|
60
|
+
message: value,
|
|
61
|
+
toString: () => value,
|
|
62
|
+
},
|
|
63
|
+
]),
|
|
64
|
+
) as any;
|
|
65
|
+
}
|