@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.
Files changed (353) hide show
  1. package/.turbo/turbo-build.log +266 -0
  2. package/.turbo/turbo-test.log +2 -0
  3. package/LICENSE.md +20 -0
  4. package/dist/api/index.d.mts +181 -0
  5. package/dist/api/index.mjs +34 -0
  6. package/dist/api/index.mjs.map +1 -0
  7. package/dist/async_hooks/index.d.mts +7 -0
  8. package/dist/async_hooks/index.mjs +22 -0
  9. package/dist/async_hooks/index.mjs.map +1 -0
  10. package/dist/async_hooks/pure.index.d.mts +7 -0
  11. package/dist/async_hooks/pure.index.mjs +35 -0
  12. package/dist/async_hooks/pure.index.mjs.map +1 -0
  13. package/dist/context/endpoint-context.d.mts +19 -0
  14. package/dist/context/endpoint-context.mjs +32 -0
  15. package/dist/context/endpoint-context.mjs.map +1 -0
  16. package/dist/context/global.d.mts +7 -0
  17. package/dist/context/global.mjs +38 -0
  18. package/dist/context/global.mjs.map +1 -0
  19. package/dist/context/index.d.mts +5 -0
  20. package/dist/context/index.mjs +6 -0
  21. package/dist/context/request-state.d.mts +26 -0
  22. package/dist/context/request-state.mjs +50 -0
  23. package/dist/context/request-state.mjs.map +1 -0
  24. package/dist/context/transaction.d.mts +25 -0
  25. package/dist/context/transaction.mjs +96 -0
  26. package/dist/context/transaction.mjs.map +1 -0
  27. package/dist/db/adapter/factory.d.mts +28 -0
  28. package/dist/db/adapter/factory.mjs +716 -0
  29. package/dist/db/adapter/factory.mjs.map +1 -0
  30. package/dist/db/adapter/get-default-field-name.d.mts +19 -0
  31. package/dist/db/adapter/get-default-field-name.mjs +39 -0
  32. package/dist/db/adapter/get-default-field-name.mjs.map +1 -0
  33. package/dist/db/adapter/get-default-model-name.d.mts +13 -0
  34. package/dist/db/adapter/get-default-model-name.mjs +33 -0
  35. package/dist/db/adapter/get-default-model-name.mjs.map +1 -0
  36. package/dist/db/adapter/get-field-attributes.d.mts +30 -0
  37. package/dist/db/adapter/get-field-attributes.mjs +40 -0
  38. package/dist/db/adapter/get-field-attributes.mjs.map +1 -0
  39. package/dist/db/adapter/get-field-name.d.mts +19 -0
  40. package/dist/db/adapter/get-field-name.mjs +34 -0
  41. package/dist/db/adapter/get-field-name.mjs.map +1 -0
  42. package/dist/db/adapter/get-id-field.d.mts +40 -0
  43. package/dist/db/adapter/get-id-field.mjs +68 -0
  44. package/dist/db/adapter/get-id-field.mjs.map +1 -0
  45. package/dist/db/adapter/get-model-name.d.mts +13 -0
  46. package/dist/db/adapter/get-model-name.mjs +24 -0
  47. package/dist/db/adapter/get-model-name.mjs.map +1 -0
  48. package/dist/db/adapter/index.d.mts +515 -0
  49. package/dist/db/adapter/index.mjs +10 -0
  50. package/dist/db/adapter/types.d.mts +140 -0
  51. package/dist/db/adapter/utils.d.mts +8 -0
  52. package/dist/db/adapter/utils.mjs +39 -0
  53. package/dist/db/adapter/utils.mjs.map +1 -0
  54. package/dist/db/get-tables.d.mts +9 -0
  55. package/dist/db/get-tables.mjs +267 -0
  56. package/dist/db/get-tables.mjs.map +1 -0
  57. package/dist/db/index.d.mts +10 -0
  58. package/dist/db/index.mjs +9 -0
  59. package/dist/db/plugin.d.mts +13 -0
  60. package/dist/db/schema/account.d.mts +27 -0
  61. package/dist/db/schema/account.mjs +20 -0
  62. package/dist/db/schema/account.mjs.map +1 -0
  63. package/dist/db/schema/rate-limit.d.mts +15 -0
  64. package/dist/db/schema/rate-limit.mjs +12 -0
  65. package/dist/db/schema/rate-limit.mjs.map +1 -0
  66. package/dist/db/schema/session.d.mts +22 -0
  67. package/dist/db/schema/session.mjs +15 -0
  68. package/dist/db/schema/session.mjs.map +1 -0
  69. package/dist/db/schema/shared.d.mts +11 -0
  70. package/dist/db/schema/shared.mjs +12 -0
  71. package/dist/db/schema/shared.mjs.map +1 -0
  72. package/dist/db/schema/user.d.mts +21 -0
  73. package/dist/db/schema/user.mjs +14 -0
  74. package/dist/db/schema/user.mjs.map +1 -0
  75. package/dist/db/schema/verification.d.mts +20 -0
  76. package/dist/db/schema/verification.mjs +13 -0
  77. package/dist/db/schema/verification.mjs.map +1 -0
  78. package/dist/db/type.d.mts +147 -0
  79. package/dist/env/color-depth.d.mts +5 -0
  80. package/dist/env/color-depth.mjs +89 -0
  81. package/dist/env/color-depth.mjs.map +1 -0
  82. package/dist/env/env-impl.d.mts +33 -0
  83. package/dist/env/env-impl.mjs +83 -0
  84. package/dist/env/env-impl.mjs.map +1 -0
  85. package/dist/env/index.d.mts +4 -0
  86. package/dist/env/index.mjs +5 -0
  87. package/dist/env/logger.d.mts +49 -0
  88. package/dist/env/logger.mjs +82 -0
  89. package/dist/env/logger.mjs.map +1 -0
  90. package/dist/error/codes.d.mts +199 -0
  91. package/dist/error/codes.mjs +57 -0
  92. package/dist/error/codes.mjs.map +1 -0
  93. package/dist/error/index.d.mts +20 -0
  94. package/dist/error/index.mjs +30 -0
  95. package/dist/error/index.mjs.map +1 -0
  96. package/dist/index.d.mts +8 -0
  97. package/dist/index.mjs +1 -0
  98. package/dist/oauth2/client-credentials-token.d.mts +37 -0
  99. package/dist/oauth2/client-credentials-token.mjs +55 -0
  100. package/dist/oauth2/client-credentials-token.mjs.map +1 -0
  101. package/dist/oauth2/create-authorization-url.d.mts +46 -0
  102. package/dist/oauth2/create-authorization-url.mjs +43 -0
  103. package/dist/oauth2/create-authorization-url.mjs.map +1 -0
  104. package/dist/oauth2/index.d.mts +8 -0
  105. package/dist/oauth2/index.mjs +8 -0
  106. package/dist/oauth2/oauth-provider.d.mts +195 -0
  107. package/dist/oauth2/refresh-access-token.d.mts +36 -0
  108. package/dist/oauth2/refresh-access-token.mjs +59 -0
  109. package/dist/oauth2/refresh-access-token.mjs.map +1 -0
  110. package/dist/oauth2/utils.d.mts +8 -0
  111. package/dist/oauth2/utils.mjs +28 -0
  112. package/dist/oauth2/utils.mjs.map +1 -0
  113. package/dist/oauth2/validate-authorization-code.d.mts +56 -0
  114. package/dist/oauth2/validate-authorization-code.mjs +72 -0
  115. package/dist/oauth2/validate-authorization-code.mjs.map +1 -0
  116. package/dist/oauth2/verify.d.mts +43 -0
  117. package/dist/oauth2/verify.mjs +96 -0
  118. package/dist/oauth2/verify.mjs.map +1 -0
  119. package/dist/social-providers/apple.d.mts +120 -0
  120. package/dist/social-providers/apple.mjs +105 -0
  121. package/dist/social-providers/apple.mjs.map +1 -0
  122. package/dist/social-providers/atlassian.d.mts +73 -0
  123. package/dist/social-providers/atlassian.mjs +84 -0
  124. package/dist/social-providers/atlassian.mjs.map +1 -0
  125. package/dist/social-providers/cognito.d.mts +88 -0
  126. package/dist/social-providers/cognito.mjs +166 -0
  127. package/dist/social-providers/cognito.mjs.map +1 -0
  128. package/dist/social-providers/discord.d.mts +127 -0
  129. package/dist/social-providers/discord.mjs +65 -0
  130. package/dist/social-providers/discord.mjs.map +1 -0
  131. package/dist/social-providers/dropbox.d.mts +72 -0
  132. package/dist/social-providers/dropbox.mjs +76 -0
  133. package/dist/social-providers/dropbox.mjs.map +1 -0
  134. package/dist/social-providers/facebook.d.mts +82 -0
  135. package/dist/social-providers/facebook.mjs +121 -0
  136. package/dist/social-providers/facebook.mjs.map +1 -0
  137. package/dist/social-providers/figma.d.mts +64 -0
  138. package/dist/social-providers/figma.mjs +87 -0
  139. package/dist/social-providers/figma.mjs.map +1 -0
  140. package/dist/social-providers/github.d.mts +105 -0
  141. package/dist/social-providers/github.mjs +97 -0
  142. package/dist/social-providers/github.mjs.map +1 -0
  143. package/dist/social-providers/gitlab.d.mts +126 -0
  144. package/dist/social-providers/gitlab.mjs +83 -0
  145. package/dist/social-providers/gitlab.mjs.map +1 -0
  146. package/dist/social-providers/google.d.mts +100 -0
  147. package/dist/social-providers/google.mjs +109 -0
  148. package/dist/social-providers/google.mjs.map +1 -0
  149. package/dist/social-providers/huggingface.d.mts +86 -0
  150. package/dist/social-providers/huggingface.mjs +76 -0
  151. package/dist/social-providers/huggingface.mjs.map +1 -0
  152. package/dist/social-providers/index.d.mts +1725 -0
  153. package/dist/social-providers/index.mjs +77 -0
  154. package/dist/social-providers/index.mjs.map +1 -0
  155. package/dist/social-providers/kakao.d.mts +164 -0
  156. package/dist/social-providers/kakao.mjs +73 -0
  157. package/dist/social-providers/kakao.mjs.map +1 -0
  158. package/dist/social-providers/kick.d.mts +76 -0
  159. package/dist/social-providers/kick.mjs +72 -0
  160. package/dist/social-providers/kick.mjs.map +1 -0
  161. package/dist/social-providers/line.d.mts +108 -0
  162. package/dist/social-providers/line.mjs +114 -0
  163. package/dist/social-providers/line.mjs.map +1 -0
  164. package/dist/social-providers/linear.d.mts +71 -0
  165. package/dist/social-providers/linear.mjs +89 -0
  166. package/dist/social-providers/linear.mjs.map +1 -0
  167. package/dist/social-providers/linkedin.d.mts +70 -0
  168. package/dist/social-providers/linkedin.mjs +77 -0
  169. package/dist/social-providers/linkedin.mjs.map +1 -0
  170. package/dist/social-providers/microsoft-entra-id.d.mts +175 -0
  171. package/dist/social-providers/microsoft-entra-id.mjs +107 -0
  172. package/dist/social-providers/microsoft-entra-id.mjs.map +1 -0
  173. package/dist/social-providers/naver.d.mts +95 -0
  174. package/dist/social-providers/naver.mjs +68 -0
  175. package/dist/social-providers/naver.mjs.map +1 -0
  176. package/dist/social-providers/notion.d.mts +67 -0
  177. package/dist/social-providers/notion.mjs +76 -0
  178. package/dist/social-providers/notion.mjs.map +1 -0
  179. package/dist/social-providers/paybin.d.mts +74 -0
  180. package/dist/social-providers/paybin.mjs +86 -0
  181. package/dist/social-providers/paybin.mjs.map +1 -0
  182. package/dist/social-providers/paypal.d.mts +132 -0
  183. package/dist/social-providers/paypal.mjs +145 -0
  184. package/dist/social-providers/paypal.mjs.map +1 -0
  185. package/dist/social-providers/polar.d.mts +77 -0
  186. package/dist/social-providers/polar.mjs +74 -0
  187. package/dist/social-providers/polar.mjs.map +1 -0
  188. package/dist/social-providers/reddit.d.mts +65 -0
  189. package/dist/social-providers/reddit.mjs +84 -0
  190. package/dist/social-providers/reddit.mjs.map +1 -0
  191. package/dist/social-providers/roblox.d.mts +73 -0
  192. package/dist/social-providers/roblox.mjs +60 -0
  193. package/dist/social-providers/roblox.mjs.map +1 -0
  194. package/dist/social-providers/salesforce.d.mts +82 -0
  195. package/dist/social-providers/salesforce.mjs +92 -0
  196. package/dist/social-providers/salesforce.mjs.map +1 -0
  197. package/dist/social-providers/slack.d.mts +86 -0
  198. package/dist/social-providers/slack.mjs +69 -0
  199. package/dist/social-providers/slack.mjs.map +1 -0
  200. package/dist/social-providers/spotify.d.mts +66 -0
  201. package/dist/social-providers/spotify.mjs +72 -0
  202. package/dist/social-providers/spotify.mjs.map +1 -0
  203. package/dist/social-providers/tiktok.d.mts +171 -0
  204. package/dist/social-providers/tiktok.mjs +63 -0
  205. package/dist/social-providers/tiktok.mjs.map +1 -0
  206. package/dist/social-providers/twitch.d.mts +82 -0
  207. package/dist/social-providers/twitch.mjs +79 -0
  208. package/dist/social-providers/twitch.mjs.map +1 -0
  209. package/dist/social-providers/twitter.d.mts +129 -0
  210. package/dist/social-providers/twitter.mjs +88 -0
  211. package/dist/social-providers/twitter.mjs.map +1 -0
  212. package/dist/social-providers/vercel.d.mts +65 -0
  213. package/dist/social-providers/vercel.mjs +62 -0
  214. package/dist/social-providers/vercel.mjs.map +1 -0
  215. package/dist/social-providers/vk.d.mts +73 -0
  216. package/dist/social-providers/vk.mjs +84 -0
  217. package/dist/social-providers/vk.mjs.map +1 -0
  218. package/dist/social-providers/zoom.d.mts +173 -0
  219. package/dist/social-providers/zoom.mjs +73 -0
  220. package/dist/social-providers/zoom.mjs.map +1 -0
  221. package/dist/types/context.d.mts +267 -0
  222. package/dist/types/cookie.d.mts +16 -0
  223. package/dist/types/helper.d.mts +10 -0
  224. package/dist/types/index.d.mts +8 -0
  225. package/dist/types/init-options.d.mts +1314 -0
  226. package/dist/types/plugin-client.d.mts +112 -0
  227. package/dist/types/plugin.d.mts +125 -0
  228. package/dist/utils/db.d.mts +12 -0
  229. package/dist/utils/db.mjs +17 -0
  230. package/dist/utils/db.mjs.map +1 -0
  231. package/dist/utils/deprecate.d.mts +10 -0
  232. package/dist/utils/deprecate.mjs +18 -0
  233. package/dist/utils/deprecate.mjs.map +1 -0
  234. package/dist/utils/error-codes.d.mts +13 -0
  235. package/dist/utils/error-codes.mjs +12 -0
  236. package/dist/utils/error-codes.mjs.map +1 -0
  237. package/dist/utils/id.d.mts +5 -0
  238. package/dist/utils/id.mjs +10 -0
  239. package/dist/utils/id.mjs.map +1 -0
  240. package/dist/utils/ip.d.mts +55 -0
  241. package/dist/utils/ip.mjs +119 -0
  242. package/dist/utils/ip.mjs.map +1 -0
  243. package/dist/utils/json.d.mts +5 -0
  244. package/dist/utils/json.mjs +26 -0
  245. package/dist/utils/json.mjs.map +1 -0
  246. package/dist/utils/string.d.mts +5 -0
  247. package/dist/utils/string.mjs +8 -0
  248. package/dist/utils/string.mjs.map +1 -0
  249. package/dist/utils/url.d.mts +21 -0
  250. package/dist/utils/url.mjs +33 -0
  251. package/dist/utils/url.mjs.map +1 -0
  252. package/package.json +147 -0
  253. package/src/api/index.ts +106 -0
  254. package/src/async_hooks/index.ts +40 -0
  255. package/src/async_hooks/pure.index.ts +46 -0
  256. package/src/context/endpoint-context.ts +50 -0
  257. package/src/context/global.ts +57 -0
  258. package/src/context/index.ts +23 -0
  259. package/src/context/request-state.test.ts +94 -0
  260. package/src/context/request-state.ts +91 -0
  261. package/src/context/transaction.ts +136 -0
  262. package/src/db/adapter/factory.ts +1362 -0
  263. package/src/db/adapter/get-default-field-name.ts +59 -0
  264. package/src/db/adapter/get-default-model-name.ts +51 -0
  265. package/src/db/adapter/get-field-attributes.ts +62 -0
  266. package/src/db/adapter/get-field-name.ts +43 -0
  267. package/src/db/adapter/get-id-field.ts +141 -0
  268. package/src/db/adapter/get-model-name.ts +36 -0
  269. package/src/db/adapter/index.ts +554 -0
  270. package/src/db/adapter/types.ts +171 -0
  271. package/src/db/adapter/utils.ts +61 -0
  272. package/src/db/get-tables.ts +296 -0
  273. package/src/db/index.ts +18 -0
  274. package/src/db/plugin.ts +11 -0
  275. package/src/db/schema/account.ts +34 -0
  276. package/src/db/schema/rate-limit.ts +21 -0
  277. package/src/db/schema/session.ts +17 -0
  278. package/src/db/schema/shared.ts +7 -0
  279. package/src/db/schema/user.ts +16 -0
  280. package/src/db/schema/verification.ts +15 -0
  281. package/src/db/test/get-tables.test.ts +116 -0
  282. package/src/db/type.ts +180 -0
  283. package/src/env/color-depth.ts +172 -0
  284. package/src/env/env-impl.ts +124 -0
  285. package/src/env/index.ts +23 -0
  286. package/src/env/logger.test.ts +34 -0
  287. package/src/env/logger.ts +145 -0
  288. package/src/error/codes.ts +58 -0
  289. package/src/error/index.ts +35 -0
  290. package/src/index.ts +1 -0
  291. package/src/oauth2/client-credentials-token.ts +102 -0
  292. package/src/oauth2/create-authorization-url.ts +87 -0
  293. package/src/oauth2/index.ts +26 -0
  294. package/src/oauth2/oauth-provider.ts +222 -0
  295. package/src/oauth2/refresh-access-token.ts +124 -0
  296. package/src/oauth2/utils.ts +38 -0
  297. package/src/oauth2/validate-authorization-code.ts +149 -0
  298. package/src/oauth2/validate-token.test.ts +174 -0
  299. package/src/oauth2/verify.ts +221 -0
  300. package/src/social-providers/apple.ts +223 -0
  301. package/src/social-providers/atlassian.ts +132 -0
  302. package/src/social-providers/cognito.ts +279 -0
  303. package/src/social-providers/discord.ts +169 -0
  304. package/src/social-providers/dropbox.ts +112 -0
  305. package/src/social-providers/facebook.ts +206 -0
  306. package/src/social-providers/figma.ts +117 -0
  307. package/src/social-providers/github.ts +184 -0
  308. package/src/social-providers/gitlab.ts +155 -0
  309. package/src/social-providers/google.ts +199 -0
  310. package/src/social-providers/huggingface.ts +118 -0
  311. package/src/social-providers/index.ts +127 -0
  312. package/src/social-providers/kakao.ts +178 -0
  313. package/src/social-providers/kick.ts +109 -0
  314. package/src/social-providers/line.ts +169 -0
  315. package/src/social-providers/linear.ts +121 -0
  316. package/src/social-providers/linkedin.ts +110 -0
  317. package/src/social-providers/microsoft-entra-id.ts +259 -0
  318. package/src/social-providers/naver.ts +112 -0
  319. package/src/social-providers/notion.ts +108 -0
  320. package/src/social-providers/paybin.ts +122 -0
  321. package/src/social-providers/paypal.ts +263 -0
  322. package/src/social-providers/polar.ts +110 -0
  323. package/src/social-providers/reddit.ts +122 -0
  324. package/src/social-providers/roblox.ts +111 -0
  325. package/src/social-providers/salesforce.ts +159 -0
  326. package/src/social-providers/slack.ts +111 -0
  327. package/src/social-providers/spotify.ts +93 -0
  328. package/src/social-providers/tiktok.ts +209 -0
  329. package/src/social-providers/twitch.ts +111 -0
  330. package/src/social-providers/twitter.ts +198 -0
  331. package/src/social-providers/vercel.ts +87 -0
  332. package/src/social-providers/vk.ts +124 -0
  333. package/src/social-providers/zoom.ts +238 -0
  334. package/src/types/context.ts +396 -0
  335. package/src/types/cookie.ts +10 -0
  336. package/src/types/helper.ts +26 -0
  337. package/src/types/index.ts +32 -0
  338. package/src/types/init-options.ts +1529 -0
  339. package/src/types/plugin-client.ts +127 -0
  340. package/src/types/plugin.ts +157 -0
  341. package/src/utils/db.ts +20 -0
  342. package/src/utils/deprecate.test.ts +72 -0
  343. package/src/utils/deprecate.ts +21 -0
  344. package/src/utils/error-codes.ts +65 -0
  345. package/src/utils/id.ts +5 -0
  346. package/src/utils/ip.test.ts +255 -0
  347. package/src/utils/ip.ts +211 -0
  348. package/src/utils/json.ts +25 -0
  349. package/src/utils/string.ts +3 -0
  350. package/src/utils/url.ts +43 -0
  351. package/tsconfig.json +7 -0
  352. package/tsdown.config.ts +35 -0
  353. 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
+ };
@@ -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
+ }
@@ -0,0 +1,5 @@
1
+ import { createRandomStringGenerator } from "@better-auth/utils/random";
2
+
3
+ export const generateId = (size?: number) => {
4
+ return createRandomStringGenerator("a-z", "A-Z", "0-9")(size || 32);
5
+ };