payload-auth 1.4.0 → 1.5.0

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 (213) hide show
  1. package/dist/better-auth/adapter/index.d.ts +10 -0
  2. package/dist/better-auth/adapter/index.d.ts.map +1 -1
  3. package/dist/better-auth/adapter/index.js +151 -125
  4. package/dist/better-auth/adapter/transform/index.d.ts +2 -4
  5. package/dist/better-auth/adapter/transform/index.d.ts.map +1 -1
  6. package/dist/better-auth/adapter/transform/index.js +435 -311
  7. package/dist/better-auth/generated-types.d.ts +216 -0
  8. package/dist/better-auth/generated-types.d.ts.map +1 -0
  9. package/dist/better-auth/generated-types.js +4 -0
  10. package/dist/better-auth/plugin/constants.d.ts +146 -3
  11. package/dist/better-auth/plugin/constants.d.ts.map +1 -1
  12. package/dist/better-auth/plugin/constants.js +149 -6
  13. package/dist/better-auth/plugin/helpers/check-plugin-exists.d.ts +13 -0
  14. package/dist/better-auth/plugin/helpers/check-plugin-exists.d.ts.map +1 -0
  15. package/dist/better-auth/plugin/helpers/check-plugin-exists.js +14 -0
  16. package/dist/better-auth/plugin/helpers/get-better-auth-schema.d.ts +22 -0
  17. package/dist/better-auth/plugin/helpers/get-better-auth-schema.d.ts.map +1 -0
  18. package/dist/better-auth/plugin/helpers/get-better-auth-schema.js +50 -0
  19. package/dist/better-auth/plugin/helpers/get-collection-schema-map.d.ts +16 -0
  20. package/dist/better-auth/plugin/helpers/get-collection-schema-map.d.ts.map +1 -0
  21. package/dist/better-auth/plugin/helpers/get-collection-schema-map.js +108 -0
  22. package/dist/better-auth/plugin/helpers/get-collection-slug.d.ts +6 -0
  23. package/dist/better-auth/plugin/helpers/get-collection-slug.d.ts.map +1 -0
  24. package/dist/better-auth/plugin/helpers/get-collection-slug.js +20 -0
  25. package/dist/better-auth/plugin/helpers/get-collection.d.ts +41 -0
  26. package/dist/better-auth/plugin/helpers/get-collection.d.ts.map +1 -0
  27. package/dist/better-auth/plugin/helpers/get-collection.js +62 -0
  28. package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts +52 -14
  29. package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts.map +1 -1
  30. package/dist/better-auth/plugin/helpers/prepare-session-data.js +41 -35
  31. package/dist/better-auth/plugin/index.d.ts +3 -3
  32. package/dist/better-auth/plugin/index.d.ts.map +1 -1
  33. package/dist/better-auth/plugin/index.js +31 -40
  34. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.d.ts +2 -6
  35. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.d.ts.map +1 -1
  36. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.js +22 -7
  37. package/dist/better-auth/plugin/lib/build-collections/accounts/index.d.ts +3 -6
  38. package/dist/better-auth/plugin/lib/build-collections/accounts/index.d.ts.map +1 -1
  39. package/dist/better-auth/plugin/lib/build-collections/accounts/index.js +96 -102
  40. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.d.ts +2 -2
  41. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.d.ts.map +1 -1
  42. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.js +6 -5
  43. package/dist/better-auth/plugin/lib/build-collections/api-keys.d.ts +3 -5
  44. package/dist/better-auth/plugin/lib/build-collections/api-keys.d.ts.map +1 -1
  45. package/dist/better-auth/plugin/lib/build-collections/api-keys.js +97 -113
  46. package/dist/better-auth/plugin/lib/build-collections/index.d.ts +6 -6
  47. package/dist/better-auth/plugin/lib/build-collections/index.d.ts.map +1 -1
  48. package/dist/better-auth/plugin/lib/build-collections/index.js +68 -84
  49. package/dist/better-auth/plugin/lib/build-collections/invitations.d.ts +2 -4
  50. package/dist/better-auth/plugin/lib/build-collections/invitations.d.ts.map +1 -1
  51. package/dist/better-auth/plugin/lib/build-collections/invitations.js +75 -70
  52. package/dist/better-auth/plugin/lib/build-collections/jwks.d.ts +3 -5
  53. package/dist/better-auth/plugin/lib/build-collections/jwks.d.ts.map +1 -1
  54. package/dist/better-auth/plugin/lib/build-collections/jwks.js +46 -28
  55. package/dist/better-auth/plugin/lib/build-collections/members.d.ts +3 -5
  56. package/dist/better-auth/plugin/lib/build-collections/members.d.ts.map +1 -1
  57. package/dist/better-auth/plugin/lib/build-collections/members.js +52 -48
  58. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.d.ts +3 -5
  59. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.d.ts.map +1 -1
  60. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.js +74 -64
  61. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.d.ts +3 -5
  62. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.d.ts.map +1 -1
  63. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.js +78 -71
  64. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.d.ts +3 -5
  65. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.d.ts.map +1 -1
  66. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.js +68 -45
  67. package/dist/better-auth/plugin/lib/build-collections/organizations.d.ts +3 -5
  68. package/dist/better-auth/plugin/lib/build-collections/organizations.d.ts.map +1 -1
  69. package/dist/better-auth/plugin/lib/build-collections/organizations.js +52 -39
  70. package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts +3 -5
  71. package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts.map +1 -1
  72. package/dist/better-auth/plugin/lib/build-collections/passkeys.js +60 -64
  73. package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts +3 -7
  74. package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts.map +1 -1
  75. package/dist/better-auth/plugin/lib/build-collections/sessions.js +100 -96
  76. package/dist/better-auth/plugin/lib/build-collections/sso-providers.d.ts +3 -5
  77. package/dist/better-auth/plugin/lib/build-collections/sso-providers.d.ts.map +1 -1
  78. package/dist/better-auth/plugin/lib/build-collections/sso-providers.js +56 -56
  79. package/dist/better-auth/plugin/lib/build-collections/subscriptions.d.ts +4 -0
  80. package/dist/better-auth/plugin/lib/build-collections/subscriptions.d.ts.map +1 -0
  81. package/dist/better-auth/plugin/lib/build-collections/subscriptions.js +113 -0
  82. package/dist/better-auth/plugin/lib/build-collections/teams.d.ts +3 -5
  83. package/dist/better-auth/plugin/lib/build-collections/teams.d.ts.map +1 -1
  84. package/dist/better-auth/plugin/lib/build-collections/teams.js +62 -30
  85. package/dist/better-auth/plugin/lib/build-collections/two-factors.d.ts +3 -5
  86. package/dist/better-auth/plugin/lib/build-collections/two-factors.d.ts.map +1 -1
  87. package/dist/better-auth/plugin/lib/build-collections/two-factors.js +50 -37
  88. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.d.ts.map +1 -1
  89. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.js +5 -5
  90. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.js +3 -3
  91. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.d.ts +6 -0
  92. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.d.ts.map +1 -0
  93. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.js +7 -0
  94. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.js +4 -4
  95. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/signup.d.ts +2 -2
  96. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/signup.d.ts.map +1 -1
  97. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/signup.js +93 -96
  98. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts +1 -6
  99. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts.map +1 -1
  100. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js +27 -16
  101. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.d.ts +1 -5
  102. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.d.ts.map +1 -1
  103. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.js +16 -8
  104. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.d.ts +2 -6
  105. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.d.ts.map +1 -1
  106. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.js +25 -6
  107. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.d.ts +2 -1
  108. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.d.ts.map +1 -1
  109. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.js +5 -8
  110. package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.d.ts +7 -0
  111. package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.d.ts.map +1 -0
  112. package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.js +8 -0
  113. package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.d.ts +1 -1
  114. package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.d.ts.map +1 -1
  115. package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.js +15 -12
  116. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.d.ts +1 -6
  117. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.d.ts.map +1 -1
  118. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.js +21 -10
  119. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts +3 -7
  120. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts.map +1 -1
  121. package/dist/better-auth/plugin/lib/build-collections/users/index.js +153 -210
  122. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.d.ts +16 -0
  123. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.d.ts.map +1 -0
  124. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.js +32 -0
  125. package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.d.ts +1 -1
  126. package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.d.ts.map +1 -1
  127. package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.js +1 -1
  128. package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.d.ts +17 -0
  129. package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.d.ts.map +1 -0
  130. package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.js +21 -0
  131. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.d.ts +22 -0
  132. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.d.ts.map +1 -0
  133. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.js +95 -0
  134. package/dist/better-auth/plugin/lib/build-collections/verifications.d.ts +3 -6
  135. package/dist/better-auth/plugin/lib/build-collections/verifications.d.ts.map +1 -1
  136. package/dist/better-auth/plugin/lib/build-collections/verifications.js +62 -40
  137. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.d.ts.map +1 -1
  138. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.js +4 -3
  139. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.d.ts +2 -1
  140. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.d.ts.map +1 -1
  141. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.js +8 -15
  142. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts +5 -3
  143. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts.map +1 -1
  144. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js +56 -69
  145. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.d.ts +2 -1
  146. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.d.ts.map +1 -1
  147. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.js +16 -55
  148. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.d.ts +2 -1
  149. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.d.ts.map +1 -1
  150. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.js +21 -83
  151. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.d.ts +2 -1
  152. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.d.ts.map +1 -1
  153. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.js +8 -15
  154. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.d.ts +2 -1
  155. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.d.ts.map +1 -1
  156. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.js +8 -15
  157. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.d.ts +3 -0
  158. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.d.ts.map +1 -0
  159. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.js +10 -0
  160. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.d.ts +3 -3
  161. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.d.ts.map +1 -1
  162. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.js +3 -3
  163. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts +5 -4
  164. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts.map +1 -1
  165. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js +19 -17
  166. package/dist/better-auth/plugin/lib/set-login-methods.d.ts +1 -1
  167. package/dist/better-auth/plugin/lib/set-login-methods.d.ts.map +1 -1
  168. package/dist/better-auth/plugin/lib/set-login-methods.js +5 -6
  169. package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts.map +1 -1
  170. package/dist/better-auth/plugin/payload/views/admin-login/client.js +2 -2
  171. package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts +4 -4
  172. package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts.map +1 -1
  173. package/dist/better-auth/plugin/payload/views/admin-login/index.js +7 -8
  174. package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts +1 -1
  175. package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts.map +1 -1
  176. package/dist/better-auth/plugin/payload/views/admin-signup/client.js +27 -7
  177. package/dist/better-auth/plugin/payload/views/admin-signup/index.d.ts +4 -5
  178. package/dist/better-auth/plugin/payload/views/admin-signup/index.d.ts.map +1 -1
  179. package/dist/better-auth/plugin/payload/views/admin-signup/index.js +6 -6
  180. package/dist/better-auth/plugin/payload/views/forgot-password/index.d.ts +1 -5
  181. package/dist/better-auth/plugin/payload/views/forgot-password/index.d.ts.map +1 -1
  182. package/dist/better-auth/plugin/payload/views/forgot-password/index.js +1 -1
  183. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts +3 -3
  184. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts.map +1 -1
  185. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.js +10 -7
  186. package/dist/better-auth/plugin/types.d.ts +41 -13
  187. package/dist/better-auth/plugin/types.d.ts.map +1 -1
  188. package/dist/better-auth/plugin/types.js +1 -1
  189. package/dist/better-auth/plugin/utils/set.d.ts +40 -0
  190. package/dist/better-auth/plugin/utils/set.d.ts.map +1 -0
  191. package/dist/better-auth/plugin/utils/set.js +84 -0
  192. package/dist/better-auth/scripts/generate-types.d.ts +2 -0
  193. package/dist/better-auth/scripts/generate-types.d.ts.map +1 -0
  194. package/dist/better-auth/scripts/generate-types.js +219 -0
  195. package/dist/shared/form/validation.d.ts +31 -7
  196. package/dist/shared/form/validation.d.ts.map +1 -1
  197. package/dist/shared/form/validation.js +13 -5
  198. package/package.json +14 -4
  199. package/dist/better-auth/plugin/helpers/check-passkey-plugin.d.ts +0 -3
  200. package/dist/better-auth/plugin/helpers/check-passkey-plugin.d.ts.map +0 -1
  201. package/dist/better-auth/plugin/helpers/check-passkey-plugin.js +0 -6
  202. package/dist/better-auth/plugin/helpers/check-two-factor-plugin.d.ts +0 -3
  203. package/dist/better-auth/plugin/helpers/check-two-factor-plugin.d.ts.map +0 -1
  204. package/dist/better-auth/plugin/helpers/check-two-factor-plugin.js +0 -6
  205. package/dist/better-auth/plugin/helpers/check-username-plugin.d.ts +0 -3
  206. package/dist/better-auth/plugin/helpers/check-username-plugin.d.ts.map +0 -1
  207. package/dist/better-auth/plugin/helpers/check-username-plugin.js +0 -6
  208. package/dist/better-auth/plugin/lib/get-required-collection-slugs.d.ts +0 -10
  209. package/dist/better-auth/plugin/lib/get-required-collection-slugs.d.ts.map +0 -1
  210. package/dist/better-auth/plugin/lib/get-required-collection-slugs.js +0 -35
  211. package/dist/better-auth/plugin/payload/utils/generate-metadata.d.ts +0 -15
  212. package/dist/better-auth/plugin/payload/utils/generate-metadata.d.ts.map +0 -1
  213. package/dist/better-auth/plugin/payload/utils/generate-metadata.js +0 -74
@@ -0,0 +1,40 @@
1
+ /**
2
+ * Deep-sets a value on an object using a dotted-path string.
3
+ *
4
+ * **Path syntax**
5
+ * ──────────────────────────────────────────────────────────
6
+ * token action
7
+ * ------------ ------------------------------------------
8
+ * `foo.bar` create/read plain nested objects
9
+ * `foo.bar[]` *append* `value` to array `foo.bar`
10
+ * `foo.[]bar` *prepend* `value` to array `foo.bar`
11
+ * `foo.bar[2]` replace item `2` of `foo.bar`, creating
12
+ * empty slots if the index is out of bounds
13
+ *
14
+ * Missing objects/arrays are created on the fly.
15
+ * The function mutates `target` in place and returns it so
16
+ * you can chain calls.
17
+ *
18
+ * @typeParam T – target object type
19
+ * @typeParam V – value type
20
+ * @param target Object to mutate
21
+ * @param rawPath Dotted path string (see syntax table)
22
+ * @param value Value to set / append / prepend
23
+ * @returns The original `target` reference
24
+ *
25
+ * @example
26
+ * const o: Record<string, unknown> = {};
27
+ * set(o, 'alpha.beta[2].gamma', 42);
28
+ * // o →
29
+ * // {
30
+ * // alpha: {
31
+ * // beta: [
32
+ * // , // <-- empty slot #0
33
+ * // , // <-- empty slot #1
34
+ * // { gamma: 42 } // <-- slot #2
35
+ * // ]
36
+ * // }
37
+ * // }
38
+ */
39
+ export declare function set<T extends Record<string, unknown>, V = unknown>(target: T, rawPath: string, value: V): T;
40
+ //# sourceMappingURL=set.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"set.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/utils/set.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AACH,wBAAgB,GAAG,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC,GAAG,OAAO,EAAE,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,CAAC,CAqD3G"}
@@ -0,0 +1,84 @@
1
+ /**
2
+ * Deep-sets a value on an object using a dotted-path string.
3
+ *
4
+ * **Path syntax**
5
+ * ──────────────────────────────────────────────────────────
6
+ * token action
7
+ * ------------ ------------------------------------------
8
+ * `foo.bar` create/read plain nested objects
9
+ * `foo.bar[]` *append* `value` to array `foo.bar`
10
+ * `foo.[]bar` *prepend* `value` to array `foo.bar`
11
+ * `foo.bar[2]` replace item `2` of `foo.bar`, creating
12
+ * empty slots if the index is out of bounds
13
+ *
14
+ * Missing objects/arrays are created on the fly.
15
+ * The function mutates `target` in place and returns it so
16
+ * you can chain calls.
17
+ *
18
+ * @typeParam T – target object type
19
+ * @typeParam V – value type
20
+ * @param target Object to mutate
21
+ * @param rawPath Dotted path string (see syntax table)
22
+ * @param value Value to set / append / prepend
23
+ * @returns The original `target` reference
24
+ *
25
+ * @example
26
+ * const o: Record<string, unknown> = {};
27
+ * set(o, 'alpha.beta[2].gamma', 42);
28
+ * // o →
29
+ * // {
30
+ * // alpha: {
31
+ * // beta: [
32
+ * // , // <-- empty slot #0
33
+ * // , // <-- empty slot #1
34
+ * // { gamma: 42 } // <-- slot #2
35
+ * // ]
36
+ * // }
37
+ * // }
38
+ */ export function set(target, rawPath, value) {
39
+ if (!rawPath) return target;
40
+ const tokens = rawPath.split('.');
41
+ let node = target;
42
+ for(let i = 0; i < tokens.length; i += 1){
43
+ const raw = tokens[i];
44
+ const prepend = raw.startsWith('[]');
45
+ const append = raw.endsWith('[]');
46
+ const idxMatch = raw.match(/\[(\d+)]$/);
47
+ const hasIndex = Boolean(idxMatch);
48
+ const index = hasIndex ? Number(idxMatch[1]) : -1;
49
+ const key = prepend ? raw.slice(2) : append ? raw.slice(0, -2) : hasIndex ? raw.slice(0, raw.length - idxMatch[0].length) : raw;
50
+ const last = i === tokens.length - 1;
51
+ /* ----- prepend / append ------------------------------------------------ */ if (prepend || append) {
52
+ if (!Array.isArray(node[key])) node[key] = [];
53
+ if (last) {
54
+ prepend ? node[key].unshift(value) : node[key].push(value);
55
+ return target;
56
+ }
57
+ const next = {};
58
+ prepend ? node[key].unshift(next) : node[key].push(next);
59
+ node = next;
60
+ continue;
61
+ }
62
+ /* ----- explicit numeric index ----------------------------------------- */ if (hasIndex) {
63
+ if (!Array.isArray(node[key])) node[key] = [];
64
+ const arr = node[key];
65
+ while(arr.length <= index)arr.push(undefined);
66
+ if (last) {
67
+ arr[index] = value;
68
+ return target;
69
+ }
70
+ if (arr[index] === undefined) arr[index] = {};
71
+ node = arr[index];
72
+ continue;
73
+ }
74
+ /* ----- plain object step ---------------------------------------------- */ if (last) {
75
+ node[key] = value;
76
+ return target;
77
+ }
78
+ if (node[key] === undefined) node[key] = {};
79
+ node = node[key];
80
+ }
81
+ return target;
82
+ }
83
+
84
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vdXRpbHMvc2V0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRGVlcC1zZXRzIGEgdmFsdWUgb24gYW4gb2JqZWN0IHVzaW5nIGEgZG90dGVkLXBhdGggc3RyaW5nLlxuICpcbiAqICoqUGF0aCBzeW50YXgqKlxuICog4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSAXG4gKiAgIHRva2VuICAgICAgICBhY3Rpb25cbiAqICAgLS0tLS0tLS0tLS0tIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuICogICBgZm9vLmJhcmAgICAgY3JlYXRlL3JlYWQgcGxhaW4gbmVzdGVkIG9iamVjdHNcbiAqICAgYGZvby5iYXJbXWAgICphcHBlbmQqIGB2YWx1ZWAgdG8gYXJyYXkgYGZvby5iYXJgXG4gKiAgIGBmb28uW11iYXJgICAqcHJlcGVuZCogYHZhbHVlYCB0byBhcnJheSBgZm9vLmJhcmBcbiAqICAgYGZvby5iYXJbMl1gIHJlcGxhY2UgaXRlbSBgMmAgb2YgYGZvby5iYXJgLCBjcmVhdGluZ1xuICogICAgICAgICAgICAgICAgZW1wdHkgc2xvdHMgaWYgdGhlIGluZGV4IGlzIG91dCBvZiBib3VuZHNcbiAqXG4gKiBNaXNzaW5nIG9iamVjdHMvYXJyYXlzIGFyZSBjcmVhdGVkIG9uIHRoZSBmbHkuXG4gKiBUaGUgZnVuY3Rpb24gbXV0YXRlcyBgdGFyZ2V0YCBpbiBwbGFjZSBhbmQgcmV0dXJucyBpdCBzb1xuICogeW91IGNhbiBjaGFpbiBjYWxscy5cbiAqXG4gKiBAdHlwZVBhcmFtIFQg4oCTIHRhcmdldCBvYmplY3QgdHlwZVxuICogQHR5cGVQYXJhbSBWIOKAkyB2YWx1ZSB0eXBlXG4gKiBAcGFyYW0gdGFyZ2V0ICAgT2JqZWN0IHRvIG11dGF0ZVxuICogQHBhcmFtIHJhd1BhdGggIERvdHRlZCBwYXRoIHN0cmluZyAoc2VlIHN5bnRheCB0YWJsZSlcbiAqIEBwYXJhbSB2YWx1ZSAgICBWYWx1ZSB0byBzZXQgLyBhcHBlbmQgLyBwcmVwZW5kXG4gKiBAcmV0dXJucyAgICAgICAgVGhlIG9yaWdpbmFsIGB0YXJnZXRgIHJlZmVyZW5jZVxuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCBvOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiA9IHt9O1xuICogc2V0KG8sICdhbHBoYS5iZXRhWzJdLmdhbW1hJywgNDIpO1xuICogLy8gbyDihpJcbiAqIC8vIHtcbiAqIC8vICAgYWxwaGE6IHtcbiAqIC8vICAgICBiZXRhOiBbXG4gKiAvLyAgICAgICAsICAgICAgICAgICAgICAgLy8gPC0tIGVtcHR5IHNsb3QgIzBcbiAqIC8vICAgICAgICwgICAgICAgICAgICAgICAvLyA8LS0gZW1wdHkgc2xvdCAjMVxuICogLy8gICAgICAgeyBnYW1tYTogNDIgfSAgIC8vIDwtLSBzbG90ICMyXG4gKiAvLyAgICAgXVxuICogLy8gICB9XG4gKiAvLyB9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzZXQ8VCBleHRlbmRzIFJlY29yZDxzdHJpbmcsIHVua25vd24+LCBWID0gdW5rbm93bj4odGFyZ2V0OiBULCByYXdQYXRoOiBzdHJpbmcsIHZhbHVlOiBWKTogVCB7XG4gIGlmICghcmF3UGF0aCkgcmV0dXJuIHRhcmdldFxuXG4gIGNvbnN0IHRva2VucyA9IHJhd1BhdGguc3BsaXQoJy4nKVxuICBsZXQgbm9kZTogYW55ID0gdGFyZ2V0XG5cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCB0b2tlbnMubGVuZ3RoOyBpICs9IDEpIHtcbiAgICBjb25zdCByYXcgPSB0b2tlbnNbaV1cbiAgICBjb25zdCBwcmVwZW5kID0gcmF3LnN0YXJ0c1dpdGgoJ1tdJylcbiAgICBjb25zdCBhcHBlbmQgPSByYXcuZW5kc1dpdGgoJ1tdJylcbiAgICBjb25zdCBpZHhNYXRjaCA9IHJhdy5tYXRjaCgvXFxbKFxcZCspXSQvKVxuICAgIGNvbnN0IGhhc0luZGV4ID0gQm9vbGVhbihpZHhNYXRjaClcbiAgICBjb25zdCBpbmRleCA9IGhhc0luZGV4ID8gTnVtYmVyKGlkeE1hdGNoIVsxXSkgOiAtMVxuICAgIGNvbnN0IGtleSA9IHByZXBlbmQgPyByYXcuc2xpY2UoMikgOiBhcHBlbmQgPyByYXcuc2xpY2UoMCwgLTIpIDogaGFzSW5kZXggPyByYXcuc2xpY2UoMCwgcmF3Lmxlbmd0aCAtIGlkeE1hdGNoIVswXS5sZW5ndGgpIDogcmF3XG4gICAgY29uc3QgbGFzdCA9IGkgPT09IHRva2Vucy5sZW5ndGggLSAxXG5cbiAgICAvKiAtLS0tLSBwcmVwZW5kIC8gYXBwZW5kIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSAqL1xuICAgIGlmIChwcmVwZW5kIHx8IGFwcGVuZCkge1xuICAgICAgaWYgKCFBcnJheS5pc0FycmF5KG5vZGVba2V5XSkpIG5vZGVba2V5XSA9IFtdXG4gICAgICBpZiAobGFzdCkge1xuICAgICAgICBwcmVwZW5kID8gKG5vZGVba2V5XSBhcyBhbnlbXSkudW5zaGlmdCh2YWx1ZSkgOiAobm9kZVtrZXldIGFzIGFueVtdKS5wdXNoKHZhbHVlKVxuICAgICAgICByZXR1cm4gdGFyZ2V0XG4gICAgICB9XG4gICAgICBjb25zdCBuZXh0OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiA9IHt9XG4gICAgICBwcmVwZW5kID8gKG5vZGVba2V5XSBhcyBhbnlbXSkudW5zaGlmdChuZXh0KSA6IChub2RlW2tleV0gYXMgYW55W10pLnB1c2gobmV4dClcbiAgICAgIG5vZGUgPSBuZXh0XG4gICAgICBjb250aW51ZVxuICAgIH1cblxuICAgIC8qIC0tLS0tIGV4cGxpY2l0IG51bWVyaWMgaW5kZXggLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0gKi9cbiAgICBpZiAoaGFzSW5kZXgpIHtcbiAgICAgIGlmICghQXJyYXkuaXNBcnJheShub2RlW2tleV0pKSBub2RlW2tleV0gPSBbXVxuICAgICAgY29uc3QgYXJyOiBhbnlbXSA9IG5vZGVba2V5XSBhcyBhbnlbXVxuICAgICAgd2hpbGUgKGFyci5sZW5ndGggPD0gaW5kZXgpIGFyci5wdXNoKHVuZGVmaW5lZClcbiAgICAgIGlmIChsYXN0KSB7XG4gICAgICAgIGFycltpbmRleF0gPSB2YWx1ZVxuICAgICAgICByZXR1cm4gdGFyZ2V0XG4gICAgICB9XG4gICAgICBpZiAoYXJyW2luZGV4XSA9PT0gdW5kZWZpbmVkKSBhcnJbaW5kZXhdID0ge31cbiAgICAgIG5vZGUgPSBhcnJbaW5kZXhdXG4gICAgICBjb250aW51ZVxuICAgIH1cblxuICAgIC8qIC0tLS0tIHBsYWluIG9iamVjdCBzdGVwIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0gKi9cbiAgICBpZiAobGFzdCkge1xuICAgICAgbm9kZVtrZXldID0gdmFsdWVcbiAgICAgIHJldHVybiB0YXJnZXRcbiAgICB9XG4gICAgaWYgKG5vZGVba2V5XSA9PT0gdW5kZWZpbmVkKSBub2RlW2tleV0gPSB7fVxuICAgIG5vZGUgPSBub2RlW2tleV1cbiAgfVxuXG4gIHJldHVybiB0YXJnZXRcbn1cbiJdLCJuYW1lcyI6WyJzZXQiLCJ0YXJnZXQiLCJyYXdQYXRoIiwidmFsdWUiLCJ0b2tlbnMiLCJzcGxpdCIsIm5vZGUiLCJpIiwibGVuZ3RoIiwicmF3IiwicHJlcGVuZCIsInN0YXJ0c1dpdGgiLCJhcHBlbmQiLCJlbmRzV2l0aCIsImlkeE1hdGNoIiwibWF0Y2giLCJoYXNJbmRleCIsIkJvb2xlYW4iLCJpbmRleCIsIk51bWJlciIsImtleSIsInNsaWNlIiwibGFzdCIsIkFycmF5IiwiaXNBcnJheSIsInVuc2hpZnQiLCJwdXNoIiwibmV4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
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=generate-types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-types.d.ts","sourceRoot":"","sources":["../../../src/better-auth/scripts/generate-types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,219 @@
1
+ import { stripe } from "@better-auth/stripe";
2
+ import { emailHarmony, phoneHarmony } from "better-auth-harmony";
3
+ import { getSchema } from "better-auth/db";
4
+ import { admin, anonymous, apiKey, bearer, emailOTP, genericOAuth, jwt, magicLink, multiSession, oneTap, oneTimeToken, openAPI, organization, oidcProvider, phoneNumber, twoFactor, username } from "better-auth/plugins";
5
+ import { passkey } from "better-auth/plugins/passkey";
6
+ import { sso } from "better-auth/plugins/sso";
7
+ import { polar } from "@polar-sh/better-auth";
8
+ import { Polar } from "@polar-sh/sdk";
9
+ import fs from "node:fs/promises";
10
+ import path from "node:path";
11
+ import { fileURLToPath } from "node:url";
12
+ const client = new Polar({
13
+ accessToken: 'pk_test_1234567890',
14
+ server: 'sandbox'
15
+ });
16
+ const plugins = [
17
+ username(),
18
+ admin(),
19
+ apiKey(),
20
+ passkey(),
21
+ emailHarmony(),
22
+ phoneHarmony(),
23
+ bearer(),
24
+ emailOTP({
25
+ sendVerificationOTP: async ()=>{}
26
+ }),
27
+ magicLink({
28
+ sendMagicLink: async ()=>{}
29
+ }),
30
+ phoneNumber({
31
+ sendOTP: async ()=>{}
32
+ }),
33
+ oneTap(),
34
+ anonymous(),
35
+ multiSession(),
36
+ oneTimeToken(),
37
+ oidcProvider({
38
+ loginPage: ''
39
+ }),
40
+ sso(),
41
+ genericOAuth({
42
+ config: [
43
+ {
44
+ providerId: 'typescript',
45
+ clientId: 'typescript',
46
+ clientSecret: 'typescript'
47
+ }
48
+ ]
49
+ }),
50
+ openAPI(),
51
+ organization({
52
+ teams: {
53
+ enabled: true
54
+ }
55
+ }),
56
+ jwt(),
57
+ twoFactor(),
58
+ phoneNumber(),
59
+ stripe({
60
+ stripeClient: {
61
+ apiKey: 'typescript'
62
+ },
63
+ stripeWebhookSecret: 'typescript',
64
+ subscription: {
65
+ enabled: true,
66
+ plans: [
67
+ {
68
+ id: 'basic',
69
+ name: 'Basic',
70
+ price: 1000,
71
+ interval: 'month',
72
+ currency: 'usd'
73
+ },
74
+ {
75
+ id: 'pro',
76
+ name: 'Pro',
77
+ price: 2000,
78
+ interval: 'month',
79
+ currency: 'usd'
80
+ },
81
+ {
82
+ id: 'enterprise',
83
+ name: 'Enterprise',
84
+ price: 3000,
85
+ interval: 'month',
86
+ currency: 'usd'
87
+ }
88
+ ]
89
+ }
90
+ }),
91
+ // As of writing this, Polar don't create schema fields, but just in case in the future we leave this here.
92
+ polar({
93
+ client,
94
+ checkout: {
95
+ enabled: true,
96
+ products: [
97
+ {
98
+ productId: 'basic',
99
+ slug: 'basic'
100
+ },
101
+ {
102
+ productId: 'pro',
103
+ slug: 'pro'
104
+ },
105
+ {
106
+ productId: 'enterprise',
107
+ slug: 'enterprise'
108
+ }
109
+ ]
110
+ }
111
+ })
112
+ ];
113
+ const betterAuthConfig = {
114
+ emailAndPassword: {
115
+ enabled: true
116
+ },
117
+ user: {
118
+ additionalFields: {
119
+ role: {
120
+ type: 'string',
121
+ defaultValue: 'user',
122
+ input: false
123
+ }
124
+ }
125
+ },
126
+ plugins
127
+ };
128
+ const baseSchema = getSchema({
129
+ ...betterAuthConfig,
130
+ plugins: []
131
+ });
132
+ const map = (t)=>{
133
+ if (t === 'boolean') return 'boolean';
134
+ if (t === 'date') return 'Date';
135
+ if (t === 'number') return 'number';
136
+ if (t === 'string') return 'string';
137
+ if (t === 'number[]') return 'number[]';
138
+ if (t === 'string[]') return 'string[]';
139
+ return 'unknown';
140
+ };
141
+ const pascal = (s)=>s.split(/[-_]/g).map((p)=>p.charAt(0).toUpperCase() + p.slice(1)).join('');
142
+ const diff = (base, target)=>{
143
+ const d = {};
144
+ for (const [m, { fields }] of Object.entries(target)){
145
+ const added = Object.entries(fields).filter(([k])=>!(k in (base[m]?.fields ?? {})));
146
+ if (added.length) d[m] = Object.fromEntries(added);
147
+ }
148
+ return d;
149
+ };
150
+ const gen = ()=>{
151
+ let out = '// Auto-generated types. Do not edit.\n\n';
152
+ const pluginAdds = {};
153
+ const seen = new Set();
154
+ for (const pl of plugins){
155
+ const id = pl.id;
156
+ if (!id || seen.has(id)) continue;
157
+ seen.add(id);
158
+ const adds = diff(baseSchema, getSchema({
159
+ ...betterAuthConfig,
160
+ plugins: [
161
+ pl
162
+ ]
163
+ }));
164
+ for (const [m, f] of Object.entries(adds)){
165
+ pluginAdds[m] ??= {};
166
+ pluginAdds[m][id] = f;
167
+ }
168
+ }
169
+ const models = new Set([
170
+ ...Object.keys(baseSchema),
171
+ ...Object.keys(pluginAdds)
172
+ ]);
173
+ for (const model of models){
174
+ const P = pascal(model);
175
+ const base = baseSchema[model]?.fields ?? {};
176
+ const pluginsForModel = pluginAdds[model] ?? {};
177
+ const pluginIds = Object.keys(pluginsForModel);
178
+ if (Object.keys(base).length) {
179
+ out += `export type Base${P}Fields = {\n`;
180
+ for (const [k, f] of Object.entries(base))out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type)}\n`;
181
+ out += '}\n\n';
182
+ }
183
+ const needPluginMap = pluginIds.length > 1 || Object.keys(base).length;
184
+ if (needPluginMap && pluginIds.length) {
185
+ out += `export type ${P}PluginFields = {\n`;
186
+ for (const [pid, flds] of Object.entries(pluginsForModel)){
187
+ out += ` ${JSON.stringify(pid)}: {\n`;
188
+ for (const [k, f] of Object.entries(flds))out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type)}\n`;
189
+ out += ' }\n';
190
+ }
191
+ out += '}\n\n';
192
+ }
193
+ if (!Object.keys(base).length && pluginIds.length === 1) {
194
+ const only = pluginIds[0];
195
+ out += `export type ${P}Fields = {\n`;
196
+ for (const [k, f] of Object.entries(pluginsForModel[only]))out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type)}\n`;
197
+ out += '}\n\n';
198
+ out += `export type ${P} = ${P}Fields\n\n`;
199
+ continue;
200
+ }
201
+ const parts = [];
202
+ if (Object.keys(base).length) parts.push(`Base${P}Fields`);
203
+ if (pluginIds.length) {
204
+ const mapName = needPluginMap ? `${P}PluginFields` : undefined;
205
+ parts.push(...pluginIds.map((id)=>mapName ? `${mapName}[${JSON.stringify(id)}]` : 'never'));
206
+ }
207
+ out += `export type ${P} = ${parts.join(' & ')}\n\n`;
208
+ }
209
+ return out;
210
+ };
211
+ const generated = gen();
212
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
213
+ (async ()=>{
214
+ const file = path.resolve(__dirname, '../generated-types.ts');
215
+ await fs.writeFile(file, generated, 'utf8');
216
+ console.log(`Generated types written to ${file}`);
217
+ })();
218
+
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/better-auth/scripts/generate-types.ts"],"sourcesContent":["import { stripe } from '@better-auth/stripe'\nimport { emailHarmony, phoneHarmony } from 'better-auth-harmony'\nimport { getSchema } from 'better-auth/db'\nimport type { FieldAttribute } from 'better-auth/db'\nimport {\n  admin,\n  anonymous,\n  apiKey,\n  bearer,\n  emailOTP,\n  genericOAuth,\n  jwt,\n  magicLink,\n  multiSession,\n  oneTap,\n  oneTimeToken,\n  openAPI,\n  organization,\n  oidcProvider,\n  phoneNumber,\n  twoFactor,\n  username\n} from 'better-auth/plugins'\nimport { passkey } from 'better-auth/plugins/passkey'\nimport { sso } from 'better-auth/plugins/sso'\nimport { polar } from '@polar-sh/better-auth'\nimport { Polar } from '@polar-sh/sdk'\nimport type { SanitizedBetterAuthOptions } from '../types'\nimport fs from 'node:fs/promises'\nimport path from 'node:path'\nimport { fileURLToPath } from 'node:url'\n\nconst client = new Polar({\n  accessToken: 'pk_test_1234567890',\n  server: 'sandbox'\n});\n\nconst plugins = [\n  username(),\n  admin(),\n  apiKey(),\n  passkey(),\n  emailHarmony(),\n  phoneHarmony(),\n  bearer(),\n  emailOTP({ sendVerificationOTP: async () => {} }),\n  magicLink({ sendMagicLink: async () => {} }),\n  phoneNumber({ sendOTP: async () => {} }),\n  oneTap(),\n  anonymous(),\n  multiSession(),\n  oneTimeToken(),\n  oidcProvider({ loginPage: '' }),\n  sso(),\n  genericOAuth({ config: [{ providerId: 'typescript', clientId: 'typescript', clientSecret: 'typescript' }] }),\n  openAPI(),\n  organization({ teams: { enabled: true } }),\n  jwt(),\n  twoFactor(),\n  phoneNumber(),\n  stripe({\n    stripeClient: { apiKey: 'typescript' },\n    stripeWebhookSecret: 'typescript',\n    subscription: {\n      enabled: true,\n      plans: [\n        { id: 'basic', name: 'Basic', price: 1000, interval: 'month', currency: 'usd' },\n        { id: 'pro', name: 'Pro', price: 2000, interval: 'month', currency: 'usd' },\n        { id: 'enterprise', name: 'Enterprise', price: 3000, interval: 'month', currency: 'usd' }\n      ]\n    }\n  }),\n  // As of writing this, Polar don't create schema fields, but just in case in the future we leave this here.\n  polar({\n    client,\n    checkout: {\n      enabled: true,\n      products: [\n        { productId: 'basic', slug: 'basic' },\n        { productId: 'pro', slug: 'pro' },\n        { productId: 'enterprise', slug: 'enterprise' }\n      ]\n    }\n  })\n]\n\nconst betterAuthConfig: SanitizedBetterAuthOptions = {\n  emailAndPassword: { enabled: true },\n  user: { additionalFields: { role: { type: 'string', defaultValue: 'user', input: false } } },\n  plugins\n}\n\nconst baseSchema = getSchema({ ...betterAuthConfig, plugins: [] })\n\ntype Schema = Record<string, { fields: Record<string, FieldAttribute> }>\n\nconst map = (t: string): string => {\n  if (t === 'boolean') return 'boolean'\n  if (t === 'date') return 'Date'\n  if (t === 'number') return 'number'\n  if (t === 'string') return 'string'\n  if (t === 'number[]') return 'number[]'\n  if (t === 'string[]') return 'string[]'\n  return 'unknown'\n}\n\nconst pascal = (s: string): string =>\n  s\n    .split(/[-_]/g)\n    .map((p) => p.charAt(0).toUpperCase() + p.slice(1))\n    .join('')\n\nconst diff = (base: Schema, target: Schema): Record<string, Record<string, FieldAttribute>> => {\n  const d: Record<string, Record<string, FieldAttribute>> = {}\n  for (const [m, { fields }] of Object.entries(target)) {\n    const added = Object.entries(fields).filter(([k]) => !(k in (base[m]?.fields ?? {})))\n    if (added.length) d[m] = Object.fromEntries(added)\n  }\n  return d\n}\n\nconst gen = (): string => {\n  let out = '// Auto-generated types. Do not edit.\\n\\n'\n\n  const pluginAdds: Record<string, Record<string, Record<string, FieldAttribute>>> = {}\n  const seen = new Set<string>()\n\n  for (const pl of plugins) {\n    const id = (pl as any).id as string | undefined\n    if (!id || seen.has(id)) continue\n    seen.add(id)\n    const adds = diff(baseSchema, getSchema({ ...betterAuthConfig, plugins: [pl] }))\n    for (const [m, f] of Object.entries(adds)) {\n      pluginAdds[m] ??= {}\n      pluginAdds[m][id] = f\n    }\n  }\n\n  const models = new Set<string>([...Object.keys(baseSchema), ...Object.keys(pluginAdds)])\n\n  for (const model of models) {\n    const P = pascal(model)\n    const base = baseSchema[model]?.fields ?? {}\n    const pluginsForModel = pluginAdds[model] ?? {}\n    const pluginIds = Object.keys(pluginsForModel)\n\n    if (Object.keys(base).length) {\n      out += `export type Base${P}Fields = {\\n`\n      for (const [k, f] of Object.entries(base)) out += `  ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type as string)}\\n`\n      out += '}\\n\\n'\n    }\n\n    const needPluginMap = pluginIds.length > 1 || Object.keys(base).length\n    if (needPluginMap && pluginIds.length) {\n      out += `export type ${P}PluginFields = {\\n`\n      for (const [pid, flds] of Object.entries(pluginsForModel)) {\n        out += `  ${JSON.stringify(pid)}: {\\n`\n        for (const [k, f] of Object.entries(flds)) out += `    ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type as string)}\\n`\n        out += '  }\\n'\n      }\n      out += '}\\n\\n'\n    }\n\n    if (!Object.keys(base).length && pluginIds.length === 1) {\n      const only = pluginIds[0]\n      out += `export type ${P}Fields = {\\n`\n      for (const [k, f] of Object.entries(pluginsForModel[only]))\n        out += `  ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type as string)}\\n`\n      out += '}\\n\\n'\n      out += `export type ${P} = ${P}Fields\\n\\n`\n      continue\n    }\n\n    const parts: string[] = []\n    if (Object.keys(base).length) parts.push(`Base${P}Fields`)\n    if (pluginIds.length) {\n      const mapName = needPluginMap ? `${P}PluginFields` : undefined\n      parts.push(...pluginIds.map((id) => (mapName ? `${mapName}[${JSON.stringify(id)}]` : 'never') /* not reachable */))\n    }\n    out += `export type ${P} = ${parts.join(' & ')}\\n\\n`\n  }\n\n  return out\n}\n\nconst generated = gen()\n\nconst __dirname = path.dirname(fileURLToPath(import.meta.url))\n;(async () => {\n  const file = path.resolve(__dirname, '../generated-types.ts')\n  await fs.writeFile(file, generated, 'utf8')\n  console.log(`Generated types written to ${file}`)\n})()\n"],"names":["stripe","emailHarmony","phoneHarmony","getSchema","admin","anonymous","apiKey","bearer","emailOTP","genericOAuth","jwt","magicLink","multiSession","oneTap","oneTimeToken","openAPI","organization","oidcProvider","phoneNumber","twoFactor","username","passkey","sso","polar","Polar","fs","path","fileURLToPath","client","accessToken","server","plugins","sendVerificationOTP","sendMagicLink","sendOTP","loginPage","config","providerId","clientId","clientSecret","teams","enabled","stripeClient","stripeWebhookSecret","subscription","plans","id","name","price","interval","currency","checkout","products","productId","slug","betterAuthConfig","emailAndPassword","user","additionalFields","role","type","defaultValue","input","baseSchema","map","t","pascal","s","split","p","charAt","toUpperCase","slice","join","diff","base","target","d","m","fields","Object","entries","added","filter","k","length","fromEntries","gen","out","pluginAdds","seen","Set","pl","has","add","adds","f","models","keys","model","P","pluginsForModel","pluginIds","fieldName","required","needPluginMap","pid","flds","JSON","stringify","only","parts","push","mapName","undefined","generated","__dirname","dirname","url","file","resolve","writeFile","console","log"],"mappings":"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"}
@@ -70,34 +70,58 @@ export declare const createLoginSchema: ({ t, loginType, canLoginWithUsername, u
70
70
  password: string;
71
71
  login: string;
72
72
  }>;
73
- export declare const createSignupSchema: ({ t, requireUsername }: {
73
+ export declare const createSignupSchema: ({ t, requireUsername, requireConfirmPassword }: {
74
74
  t: Translate;
75
75
  requireUsername?: boolean;
76
- }) => z.ZodEffects<z.ZodObject<{
76
+ requireConfirmPassword?: boolean;
77
+ }) => z.ZodObject<{
78
+ name: z.ZodString;
77
79
  email: z.ZodEffects<z.ZodString, string, string>;
78
80
  username: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
79
81
  password: z.ZodString;
80
- confirmPassword: z.ZodString;
82
+ confirmPassword: z.ZodOptional<z.ZodString>;
81
83
  }, "strip", z.ZodTypeAny, {
84
+ name: string;
82
85
  email: string;
83
86
  password: string;
84
- confirmPassword: string;
85
87
  username?: string | undefined;
88
+ confirmPassword?: string | undefined;
86
89
  }, {
90
+ name: string;
91
+ email: string;
92
+ password: string;
93
+ username?: string | undefined;
94
+ confirmPassword?: string | undefined;
95
+ }> | z.ZodEffects<z.ZodObject<{
96
+ name: z.ZodString;
97
+ email: z.ZodEffects<z.ZodString, string, string>;
98
+ username: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
99
+ password: z.ZodString;
100
+ confirmPassword: z.ZodOptional<z.ZodString>;
101
+ }, "strip", z.ZodTypeAny, {
102
+ name: string;
87
103
  email: string;
88
104
  password: string;
89
- confirmPassword: string;
90
105
  username?: string | undefined;
106
+ confirmPassword?: string | undefined;
107
+ }, {
108
+ name: string;
109
+ email: string;
110
+ password: string;
111
+ username?: string | undefined;
112
+ confirmPassword?: string | undefined;
91
113
  }>, {
114
+ name: string;
92
115
  email: string;
93
116
  password: string;
94
- confirmPassword: string;
95
117
  username?: string | undefined;
118
+ confirmPassword?: string | undefined;
96
119
  }, {
120
+ name: string;
97
121
  email: string;
98
122
  password: string;
99
- confirmPassword: string;
100
123
  username?: string | undefined;
124
+ confirmPassword?: string | undefined;
101
125
  }>;
102
126
  export {};
103
127
  //# sourceMappingURL=validation.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../../src/shared/form/validation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAQvB;;;GAGG;AACH,MAAM,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,MAAM,CAAA;AAMlD,eAAO,MAAM,UAAU,GAAI,iBAAwB;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,8CAMtF,CAAA;AAED,eAAO,MAAM,aAAa,GAAI,uCAK3B;IACD,CAAC,EAAE,SAAS,CAAA;IACZ,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,8CAMA,CAAA;AAED,eAAO,MAAM,aAAa,GAAI,4BAAuC;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,gBAI5H,CAAA;AAED,eAAO,MAAM,oBAAoB,GAAI,iBAAwB;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,gBAIhG,CAAA;AAMD;;;GAGG;AACH,eAAO,MAAM,wBAAwB,GAAI,kBAAsB;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE;;;;;;;;;;;;;;;EAS7F,CAAA;AAMN,eAAO,MAAM,YAAY,GAAI,KAAK,MAAM,YAAyB,CAAA;AACjE,eAAO,MAAM,eAAe,GAAI,KAAK,MAAM,EAAE,2BAAoC;IAAE,SAAS,CAAC,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAO,YACjD,CAAA;AAM/E,KAAK,gBAAgB,GAAG;IAAE,SAAS,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAAA;AAEhE,eAAO,MAAM,iBAAiB,GAAI,0DAK/B;IACD,CAAC,EAAE,SAAS,CAAA;IACZ,SAAS,EAAE,OAAO,GAAG,UAAU,GAAG,iBAAiB,CAAA;IACnD,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,gBAAgB,CAAC,EAAE,gBAAgB,CAAA;CACpC;;;;;;;;;EA8BG,CAAA;AAEJ,eAAO,MAAM,kBAAkB,GAAI,wBAAgC;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,eAAe,CAAC,EAAE,OAAO,CAAA;CAAE;;;;;;;;;;;;;;;;;;;;;;;;;EAWxG,CAAA"}
1
+ {"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../../src/shared/form/validation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAQvB;;;GAGG;AACH,MAAM,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,MAAM,CAAA;AAMlD,eAAO,MAAM,UAAU,GAAI,iBAAwB;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,8CAMtF,CAAA;AAED,eAAO,MAAM,aAAa,GAAI,uCAK3B;IACD,CAAC,EAAE,SAAS,CAAA;IACZ,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,8CAMA,CAAA;AAED,eAAO,MAAM,aAAa,GAAI,4BAAuC;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,gBAI5H,CAAA;AAED,eAAO,MAAM,oBAAoB,GAAI,iBAAwB;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,gBAIhG,CAAA;AAMD;;;GAGG;AACH,eAAO,MAAM,wBAAwB,GAAI,kBAAsB;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE;;;;;;;;;;;;;;;EAS7F,CAAA;AAMN,eAAO,MAAM,YAAY,GAAI,KAAK,MAAM,YAAyB,CAAA;AACjE,eAAO,MAAM,eAAe,GAAI,KAAK,MAAM,EAAE,2BAAoC;IAAE,SAAS,CAAC,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAO,YACjD,CAAA;AAM/E,KAAK,gBAAgB,GAAG;IAAE,SAAS,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAAA;AAEhE,eAAO,MAAM,iBAAiB,GAAI,0DAK/B;IACD,CAAC,EAAE,SAAS,CAAA;IACZ,SAAS,EAAE,OAAO,GAAG,UAAU,GAAG,iBAAiB,CAAA;IACnD,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,gBAAgB,CAAC,EAAE,gBAAgB,CAAA;CACpC;;;;;;;;;EA8BG,CAAA;AAEJ,eAAO,MAAM,kBAAkB,GAAI,gDAAgE;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,eAAe,CAAC,EAAE,OAAO,CAAC;IAAC,sBAAsB,CAAC,EAAE,OAAO,CAAA;CAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAe/K,CAAA"}
@@ -84,7 +84,11 @@ export const createLoginSchema = ({ t, loginType, canLoginWithUsername = false,
84
84
  t
85
85
  })
86
86
  });
87
- export const createSignupSchema = ({ t, requireUsername = false })=>z.object({
87
+ export const createSignupSchema = ({ t, requireUsername = false, requireConfirmPassword = false })=>{
88
+ const schema = z.object({
89
+ name: z.string({
90
+ message: 'Name is required'
91
+ }).min(1),
88
92
  email: emailField({
89
93
  t
90
94
  }),
@@ -96,13 +100,17 @@ export const createSignupSchema = ({ t, requireUsername = false })=>z.object({
96
100
  t
97
101
  }),
98
102
  confirmPassword: confirmPasswordField({
99
- t
100
- })
101
- }).refine((data)=>data.password === data.confirmPassword, {
103
+ t,
104
+ required: requireConfirmPassword
105
+ }).optional()
106
+ });
107
+ if (!requireConfirmPassword) return schema;
108
+ return schema.refine((data)=>data.password === data.confirmPassword, {
102
109
  path: [
103
110
  'confirmPassword'
104
111
  ],
105
112
  message: t('fields:passwordsDoNotMatch') || 'Passwords do not match'
106
113
  });
114
+ };
107
115
 
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/shared/form/validation.ts"],"sourcesContent":["import { z } from 'zod'\n\nimport { emailRegex, usernameRegex } from '@/shared/utils/regex'\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\n/**\n * Minimal translation function type extracted from `i18next`.\n * Accepts a key and returns the translated string.\n */\nexport type Translate = (...args: any[]) => string\n\n// ---------------------------------------------------------------------------\n// Field builders\n// ---------------------------------------------------------------------------\n\nexport const emailField = ({ t, required = true }: { t: Translate; required?: boolean }) => {\n  let schema = z.string()\n  if (required) schema = schema.min(1, t('validation:required'))\n  return schema.refine((val) => emailRegex.test(val), {\n    message: t('authentication:emailNotValid') || 'Email is not valid'\n  })\n}\n\nexport const usernameField = ({\n  t,\n  required = true,\n  minLength = 5,\n  maxLength = 128\n}: {\n  t: Translate\n  required?: boolean\n  minLength?: number\n  maxLength?: number\n}) => {\n  let schema = z.string()\n  if (required) schema = schema.min(1, t('validation:required'))\n  return schema.refine((val) => usernameRegex.test(val) && val.length >= minLength && val.length <= maxLength, {\n    message: t('authentication:usernameNotValid') || 'Username is not valid'\n  })\n}\n\nexport const passwordField = ({ t, required = true, minLength = 1 }: { t: Translate; required?: boolean; minLength?: number }) => {\n  let schema = z.string()\n  if (required) schema = schema.min(minLength, t('validation:required') || 'Password is required')\n  return schema\n}\n\nexport const confirmPasswordField = ({ t, required = true }: { t: Translate; required?: boolean }) => {\n  let schema = z.string()\n  if (required) schema = schema.min(1, t('validation:required') || 'Confirm password is required')\n  return schema\n}\n\n// ---------------------------------------------------------------------------\n// Composables\n// ---------------------------------------------------------------------------\n\n/**\n * Returns a Zod object schema with `password` and `confirmPassword` fields\n * and a refinement that ensures they match.\n */\nexport const passwordWithConfirmation = ({ t, minLength = 1 }: { t: Translate; minLength?: number }) =>\n  z\n    .object({\n      password: passwordField({ t, minLength }),\n      confirmPassword: confirmPasswordField({ t })\n    })\n    .refine((data) => data.password === data.confirmPassword, {\n      path: ['confirmPassword'],\n      message: t('fields:passwordsDoNotMatch') || 'Passwords do not match'\n    })\n\n// ---------------------------------------------------------------------------\n// Utility validators (non‑Zod) — handy for dynamic login field checks\n// ---------------------------------------------------------------------------\n\nexport const isValidEmail = (val: string) => emailRegex.test(val)\nexport const isValidUsername = (val: string, { minLength = 5, maxLength = 128 }: { minLength?: number; maxLength?: number } = {}) =>\n  usernameRegex.test(val) && val.length >= minLength && val.length <= maxLength\n\n// ---------------------------------------------------------------------------\n// Schema builders\n// ---------------------------------------------------------------------------\n\ntype UsernameSettings = { minLength: number; maxLength: number }\n\nexport const createLoginSchema = ({\n  t,\n  loginType,\n  canLoginWithUsername = false,\n  usernameSettings = { minLength: 5, maxLength: 128 }\n}: {\n  t: Translate\n  loginType: 'email' | 'username' | 'emailOrUsername'\n  canLoginWithUsername?: boolean\n  usernameSettings?: UsernameSettings\n}) =>\n  z.object({\n    login: z.string().refine(\n      (val) => {\n        if (!val) return false\n        if (loginType === 'email') return isValidEmail(val)\n        if (loginType === 'username') return isValidUsername(val, usernameSettings)\n        return isValidEmail(val) || isValidUsername(val, usernameSettings)\n      },\n      (val) => {\n        if (!val) return { message: t('validation:required') }\n\n        const isProbablyEmail = val.includes('@') || !canLoginWithUsername\n\n        if (loginType === 'email') {\n          return { message: t('authentication:emailNotValid') || 'Email is not valid' }\n        }\n\n        if (loginType === 'username') {\n          return { message: t('authentication:usernameNotValid') || 'Username is not valid' }\n        }\n\n        return {\n          message: isProbablyEmail\n            ? t('authentication:emailNotValid') || 'Email is not valid'\n            : t('authentication:usernameNotValid') || 'Username is not valid'\n        }\n      }\n    ),\n    password: passwordField({ t })\n  })\n\nexport const createSignupSchema = ({ t, requireUsername = false }: { t: Translate; requireUsername?: boolean }) =>\n  z\n    .object({\n      email: emailField({ t }),\n      username: usernameField({ t, required: requireUsername }).optional(),\n      password: passwordField({ t }),\n      confirmPassword: confirmPasswordField({ t })\n    })\n    .refine((data) => data.password === data.confirmPassword, {\n      path: ['confirmPassword'],\n      message: t('fields:passwordsDoNotMatch') || 'Passwords do not match'\n    })\n"],"names":["z","emailRegex","usernameRegex","emailField","t","required","schema","string","min","refine","val","test","message","usernameField","minLength","maxLength","length","passwordField","confirmPasswordField","passwordWithConfirmation","object","password","confirmPassword","data","path","isValidEmail","isValidUsername","createLoginSchema","loginType","canLoginWithUsername","usernameSettings","login","isProbablyEmail","includes","createSignupSchema","requireUsername","email","username","optional"],"mappings":"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"}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/shared/form/validation.ts"],"sourcesContent":["import { z } from 'zod'\n\nimport { emailRegex, usernameRegex } from '@/shared/utils/regex'\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\n/**\n * Minimal translation function type extracted from `i18next`.\n * Accepts a key and returns the translated string.\n */\nexport type Translate = (...args: any[]) => string\n\n// ---------------------------------------------------------------------------\n// Field builders\n// ---------------------------------------------------------------------------\n\nexport const emailField = ({ t, required = true }: { t: Translate; required?: boolean }) => {\n  let schema = z.string()\n  if (required) schema = schema.min(1, t('validation:required'))\n  return schema.refine((val) => emailRegex.test(val), {\n    message: t('authentication:emailNotValid') || 'Email is not valid'\n  })\n}\n\nexport const usernameField = ({\n  t,\n  required = true,\n  minLength = 5,\n  maxLength = 128\n}: {\n  t: Translate\n  required?: boolean\n  minLength?: number\n  maxLength?: number\n}) => {\n  let schema = z.string()\n  if (required) schema = schema.min(1, t('validation:required'))\n  return schema.refine((val) => usernameRegex.test(val) && val.length >= minLength && val.length <= maxLength, {\n    message: t('authentication:usernameNotValid') || 'Username is not valid'\n  })\n}\n\nexport const passwordField = ({ t, required = true, minLength = 1 }: { t: Translate; required?: boolean; minLength?: number }) => {\n  let schema = z.string()\n  if (required) schema = schema.min(minLength, t('validation:required') || 'Password is required')\n  return schema\n}\n\nexport const confirmPasswordField = ({ t, required = true }: { t: Translate; required?: boolean }) => {\n  let schema = z.string()\n  if (required) schema = schema.min(1, t('validation:required') || 'Confirm password is required')\n  return schema\n}\n\n// ---------------------------------------------------------------------------\n// Composables\n// ---------------------------------------------------------------------------\n\n/**\n * Returns a Zod object schema with `password` and `confirmPassword` fields\n * and a refinement that ensures they match.\n */\nexport const passwordWithConfirmation = ({ t, minLength = 1 }: { t: Translate; minLength?: number }) =>\n  z\n    .object({\n      password: passwordField({ t, minLength }),\n      confirmPassword: confirmPasswordField({ t })\n    })\n    .refine((data) => data.password === data.confirmPassword, {\n      path: ['confirmPassword'],\n      message: t('fields:passwordsDoNotMatch') || 'Passwords do not match'\n    })\n\n// ---------------------------------------------------------------------------\n// Utility validators (non‑Zod) — handy for dynamic login field checks\n// ---------------------------------------------------------------------------\n\nexport const isValidEmail = (val: string) => emailRegex.test(val)\nexport const isValidUsername = (val: string, { minLength = 5, maxLength = 128 }: { minLength?: number; maxLength?: number } = {}) =>\n  usernameRegex.test(val) && val.length >= minLength && val.length <= maxLength\n\n// ---------------------------------------------------------------------------\n// Schema builders\n// ---------------------------------------------------------------------------\n\ntype UsernameSettings = { minLength: number; maxLength: number }\n\nexport const createLoginSchema = ({\n  t,\n  loginType,\n  canLoginWithUsername = false,\n  usernameSettings = { minLength: 5, maxLength: 128 }\n}: {\n  t: Translate\n  loginType: 'email' | 'username' | 'emailOrUsername'\n  canLoginWithUsername?: boolean\n  usernameSettings?: UsernameSettings\n}) =>\n  z.object({\n    login: z.string().refine(\n      (val) => {\n        if (!val) return false\n        if (loginType === 'email') return isValidEmail(val)\n        if (loginType === 'username') return isValidUsername(val, usernameSettings)\n        return isValidEmail(val) || isValidUsername(val, usernameSettings)\n      },\n      (val) => {\n        if (!val) return { message: t('validation:required') }\n\n        const isProbablyEmail = val.includes('@') || !canLoginWithUsername\n\n        if (loginType === 'email') {\n          return { message: t('authentication:emailNotValid') || 'Email is not valid' }\n        }\n\n        if (loginType === 'username') {\n          return { message: t('authentication:usernameNotValid') || 'Username is not valid' }\n        }\n\n        return {\n          message: isProbablyEmail\n            ? t('authentication:emailNotValid') || 'Email is not valid'\n            : t('authentication:usernameNotValid') || 'Username is not valid'\n        }\n      }\n    ),\n    password: passwordField({ t })\n  })\n\nexport const createSignupSchema = ({ t, requireUsername = false, requireConfirmPassword = false }: { t: Translate; requireUsername?: boolean; requireConfirmPassword?: boolean }) => {\n  const schema = z.object({\n    name: z.string({ message: 'Name is required' }).min(1),\n    email: emailField({ t }),\n    username: usernameField({ t, required: requireUsername }).optional(),\n    password: passwordField({ t }),\n    confirmPassword: confirmPasswordField({ t, required: requireConfirmPassword }).optional()\n  })\n\n  if (!requireConfirmPassword) return schema\n\n  return schema.refine((data) => data.password === data.confirmPassword, {\n    path: ['confirmPassword'],\n    message: t('fields:passwordsDoNotMatch') || 'Passwords do not match'\n  })\n}\n"],"names":["z","emailRegex","usernameRegex","emailField","t","required","schema","string","min","refine","val","test","message","usernameField","minLength","maxLength","length","passwordField","confirmPasswordField","passwordWithConfirmation","object","password","confirmPassword","data","path","isValidEmail","isValidUsername","createLoginSchema","loginType","canLoginWithUsername","usernameSettings","login","isProbablyEmail","includes","createSignupSchema","requireUsername","requireConfirmPassword","name","email","username","optional"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "payload-auth",
3
- "version": "1.4.0",
3
+ "version": "1.5.0",
4
4
  "main": "./dist/index.js",
5
5
  "module": "./dist/index.mjs",
6
6
  "types": "./dist/index.d.ts",
@@ -75,9 +75,11 @@
75
75
  "scripts": {
76
76
  "clean": "rm -rf ./dist && rm -rf ./tsconfig.tsbuildinfo",
77
77
  "build": "pnpm clean && pnpm copyfiles && pnpm build:types && pnpm build:swc",
78
- "copyfiles": "copyfiles -u 1 \"src/**/*.{html,css,scss,ttf,woff,woff2,eot,svg,jpg,png,json}\" dist",
78
+ "copyfiles": "copyfiles -u 1 --exclude \"src/better-auth/adapter/tests/**/*\" \"src/**/*.{html,css,scss,ttf,woff,woff2,eot,svg,jpg,png,json}\" dist",
79
79
  "build:swc": "swc ./src -d ./dist --config-file .swcrc --strip-leading-paths",
80
- "build:types": "tsc --project tsconfig.json"
80
+ "build:types": "pnpm generate:better-auth-types && tsc --project tsconfig.json",
81
+ "test": "vitest",
82
+ "generate:better-auth-types": "rm -rf src/better-auth/generated-types.ts && tsx src/better-auth/scripts/generate-types.ts"
81
83
  },
82
84
  "peerDependencies": {
83
85
  "@payloadcms/ui": "3.35.1",
@@ -89,25 +91,33 @@
89
91
  },
90
92
  "devDependencies": {
91
93
  "@clerk/types": "^4.50.1",
94
+ "@payloadcms/db-postgres": "3.35.1",
92
95
  "@swc/cli": "0.6.0",
93
96
  "@swc/core": "1.11.13",
94
97
  "@types/node": "^20.0.0",
95
98
  "@types/react": "^19",
96
99
  "@types/react-dom": "^19",
97
100
  "copyfiles": "^2.4.1",
101
+ "cross-env": "^7.0.3",
102
+ "dotenv": "^16.5.0",
103
+ "payload": "^3.35",
104
+ "tsx": "^4.19.4",
98
105
  "typescript": "5.8.2",
99
106
  "vitest": "^1.0.0"
100
107
  },
101
108
  "dependencies": {
109
+ "@better-auth/stripe": "1.2.7",
102
110
  "@better-auth/utils": "0.2.4",
103
111
  "@clerk/backend": "^1.25.8",
104
112
  "@clerk/clerk-js": "^5.58.1",
105
113
  "@clerk/nextjs": "^6.12.12",
114
+ "@polar-sh/better-auth": "^0.1.1",
115
+ "@polar-sh/sdk": "^0.32.13",
106
116
  "@tanstack/react-form": "1.4.0",
107
117
  "class-variance-authority": "0.7.1",
108
118
  "clsx": "2.1.1",
109
119
  "jose": "^6.0.10",
110
- "lucide-react": "0.482.0",
120
+ "lucide-react": "0.503.0",
111
121
  "qrcode.react": "^4.2.0",
112
122
  "sonner": "2.0.1",
113
123
  "svix": "^1.62.0",
@@ -1,3 +0,0 @@
1
- import type { SanitizedBetterAuthOptions } from '../types';
2
- export declare function checkPasskeyPlugin(options: SanitizedBetterAuthOptions): boolean;
3
- //# sourceMappingURL=check-passkey-plugin.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"check-passkey-plugin.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/check-passkey-plugin.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,UAAU,CAAA;AAE1D,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,0BAA0B,WAErE"}
@@ -1,6 +0,0 @@
1
- import { supportedBetterAuthPluginIds } from "../constants";
2
- export function checkPasskeyPlugin(options) {
3
- return options.plugins?.some((plugin)=>plugin.id === supportedBetterAuthPluginIds.passkey) || false;
4
- }
5
-
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9jaGVjay1wYXNza2V5LXBsdWdpbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzdXBwb3J0ZWRCZXR0ZXJBdXRoUGx1Z2luSWRzIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRCZXR0ZXJBdXRoT3B0aW9ucyB9IGZyb20gJy4uL3R5cGVzJ1xuXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tQYXNza2V5UGx1Z2luKG9wdGlvbnM6IFNhbml0aXplZEJldHRlckF1dGhPcHRpb25zKSB7XG4gIHJldHVybiBvcHRpb25zLnBsdWdpbnM/LnNvbWUoKHBsdWdpbikgPT4gcGx1Z2luLmlkID09PSBzdXBwb3J0ZWRCZXR0ZXJBdXRoUGx1Z2luSWRzLnBhc3NrZXkpIHx8IGZhbHNlXG59XG4iXSwibmFtZXMiOlsic3VwcG9ydGVkQmV0dGVyQXV0aFBsdWdpbklkcyIsImNoZWNrUGFzc2tleVBsdWdpbiIsIm9wdGlvbnMiLCJwbHVnaW5zIiwic29tZSIsInBsdWdpbiIsImlkIiwicGFzc2tleSJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsNEJBQTRCLFFBQVEsZUFBYztBQUczRCxPQUFPLFNBQVNDLG1CQUFtQkMsT0FBbUM7SUFDcEUsT0FBT0EsUUFBUUMsT0FBTyxFQUFFQyxLQUFLLENBQUNDLFNBQVdBLE9BQU9DLEVBQUUsS0FBS04sNkJBQTZCTyxPQUFPLEtBQUs7QUFDbEcifQ==
@@ -1,3 +0,0 @@
1
- import type { SanitizedBetterAuthOptions } from '../types';
2
- export declare function checkTwoFactorPlugin(options: SanitizedBetterAuthOptions): boolean;
3
- //# sourceMappingURL=check-two-factor-plugin.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"check-two-factor-plugin.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/check-two-factor-plugin.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,UAAU,CAAA;AAE1D,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,0BAA0B,WAEvE"}