@revealui/auth 0.0.1-pre.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 (413) hide show
  1. package/LICENSE +202 -0
  2. package/dist/better-auth/adapter/__tests__/transform.test.js +213 -0
  3. package/dist/better-auth/adapter/__tests__/transform.test.js.map +1 -0
  4. package/dist/better-auth/adapter/generate-schema/biome.d.js +2 -0
  5. package/dist/better-auth/adapter/generate-schema/biome.d.js.map +1 -0
  6. package/dist/better-auth/adapter/generate-schema/generate-schema-builder.d.ts +5 -0
  7. package/dist/better-auth/adapter/generate-schema/generate-schema-builder.js +482 -0
  8. package/dist/better-auth/adapter/generate-schema/generate-schema-builder.js.map +1 -0
  9. package/dist/better-auth/adapter/generate-schema/get-payload-schema.d.ts +1 -0
  10. package/dist/better-auth/adapter/generate-schema/get-payload-schema.js +42 -0
  11. package/dist/better-auth/adapter/generate-schema/get-payload-schema.js.map +1 -0
  12. package/dist/better-auth/adapter/generate-schema/index.d.ts +4 -0
  13. package/dist/better-auth/adapter/generate-schema/index.js +19 -0
  14. package/dist/better-auth/adapter/generate-schema/index.js.map +1 -0
  15. package/dist/better-auth/adapter/generate-schema/utils.d.ts +2 -0
  16. package/dist/better-auth/adapter/generate-schema/utils.js +20 -0
  17. package/dist/better-auth/adapter/generate-schema/utils.js.map +1 -0
  18. package/dist/better-auth/adapter/index.d.ts +15 -0
  19. package/dist/better-auth/adapter/index.js +731 -0
  20. package/dist/better-auth/adapter/index.js.map +1 -0
  21. package/dist/better-auth/adapter/tests/adapter.test.js +174 -0
  22. package/dist/better-auth/adapter/tests/adapter.test.js.map +1 -0
  23. package/dist/better-auth/adapter/tests/base-collections-tests.js +575 -0
  24. package/dist/better-auth/adapter/tests/base-collections-tests.js.map +1 -0
  25. package/dist/better-auth/adapter/tests/dev/index.js +117 -0
  26. package/dist/better-auth/adapter/tests/dev/index.js.map +1 -0
  27. package/dist/better-auth/adapter/tests/dev/migrate.js +26 -0
  28. package/dist/better-auth/adapter/tests/dev/migrate.js.map +1 -0
  29. package/dist/better-auth/adapter/tests/dev/migrations/20250423_232936_init.js +218 -0
  30. package/dist/better-auth/adapter/tests/dev/migrations/20250423_232936_init.js.map +1 -0
  31. package/dist/better-auth/adapter/tests/dev/schema.js +160 -0
  32. package/dist/better-auth/adapter/tests/dev/schema.js.map +1 -0
  33. package/dist/better-auth/adapter/tests/plugins-tests.js +2 -0
  34. package/dist/better-auth/adapter/tests/plugins-tests.js.map +1 -0
  35. package/dist/better-auth/adapter/transform/index.d.ts +27 -0
  36. package/dist/better-auth/adapter/transform/index.js +664 -0
  37. package/dist/better-auth/adapter/transform/index.js.map +1 -0
  38. package/dist/better-auth/adapter/types.d.ts +10 -0
  39. package/dist/better-auth/adapter/types.js +3 -0
  40. package/dist/better-auth/adapter/types.js.map +1 -0
  41. package/dist/better-auth/generated-types.d.ts +285 -0
  42. package/dist/better-auth/index.d.ts +3 -0
  43. package/dist/better-auth/index.js +5 -0
  44. package/dist/better-auth/index.js.map +1 -0
  45. package/dist/better-auth/plugin/__tests__/plugin.test.js +162 -0
  46. package/dist/better-auth/plugin/__tests__/plugin.test.js.map +1 -0
  47. package/dist/better-auth/plugin/constants.d.ts +220 -0
  48. package/dist/better-auth/plugin/constants.js +249 -0
  49. package/dist/better-auth/plugin/constants.js.map +1 -0
  50. package/dist/better-auth/plugin/helpers/check-plugin-exists.d.ts +12 -0
  51. package/dist/better-auth/plugin/helpers/check-plugin-exists.js +14 -0
  52. package/dist/better-auth/plugin/helpers/check-plugin-exists.js.map +1 -0
  53. package/dist/better-auth/plugin/helpers/generate-verify-email-url.d.ts +29 -0
  54. package/dist/better-auth/plugin/helpers/generate-verify-email-url.js +46 -0
  55. package/dist/better-auth/plugin/helpers/generate-verify-email-url.js.map +1 -0
  56. package/dist/better-auth/plugin/helpers/get-admin-access.d.ts +7 -0
  57. package/dist/better-auth/plugin/helpers/get-admin-access.js +22 -0
  58. package/dist/better-auth/plugin/helpers/get-admin-access.js.map +1 -0
  59. package/dist/better-auth/plugin/helpers/get-all-roles.d.ts +5 -0
  60. package/dist/better-auth/plugin/helpers/get-all-roles.js +20 -0
  61. package/dist/better-auth/plugin/helpers/get-all-roles.js.map +1 -0
  62. package/dist/better-auth/plugin/helpers/get-better-auth-schema.d.ts +18 -0
  63. package/dist/better-auth/plugin/helpers/get-better-auth-schema.js +70 -0
  64. package/dist/better-auth/plugin/helpers/get-better-auth-schema.js.map +1 -0
  65. package/dist/better-auth/plugin/helpers/get-collection-slug.d.ts +5 -0
  66. package/dist/better-auth/plugin/helpers/get-collection-slug.js +20 -0
  67. package/dist/better-auth/plugin/helpers/get-collection-slug.js.map +1 -0
  68. package/dist/better-auth/plugin/helpers/get-collection.d.ts +15 -0
  69. package/dist/better-auth/plugin/helpers/get-collection.js +29 -0
  70. package/dist/better-auth/plugin/helpers/get-collection.js.map +1 -0
  71. package/dist/better-auth/plugin/helpers/get-ip.d.ts +2 -0
  72. package/dist/better-auth/plugin/helpers/get-ip.js +31 -0
  73. package/dist/better-auth/plugin/helpers/get-ip.js.map +1 -0
  74. package/dist/better-auth/plugin/helpers/get-signed-cookie.d.ts +2 -0
  75. package/dist/better-auth/plugin/helpers/get-signed-cookie.js +65 -0
  76. package/dist/better-auth/plugin/helpers/get-signed-cookie.js.map +1 -0
  77. package/dist/better-auth/plugin/helpers/index.d.ts +1 -0
  78. package/dist/better-auth/plugin/helpers/index.js +3 -0
  79. package/dist/better-auth/plugin/helpers/index.js.map +1 -0
  80. package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts +59 -0
  81. package/dist/better-auth/plugin/helpers/prepare-session-data.js +49 -0
  82. package/dist/better-auth/plugin/helpers/prepare-session-data.js.map +1 -0
  83. package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.d.ts +20 -0
  84. package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.js +67 -0
  85. package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.js.map +1 -0
  86. package/dist/better-auth/plugin/index.d.ts +11 -0
  87. package/dist/better-auth/plugin/index.js +125 -0
  88. package/dist/better-auth/plugin/index.js.map +1 -0
  89. package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.d.ts +12 -0
  90. package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.js +87 -0
  91. package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.js.map +1 -0
  92. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.d.ts +3 -0
  93. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.js +60 -0
  94. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.js.map +1 -0
  95. package/dist/better-auth/plugin/lib/build-collections/accounts/index.d.ts +3 -0
  96. package/dist/better-auth/plugin/lib/build-collections/accounts/index.js +154 -0
  97. package/dist/better-auth/plugin/lib/build-collections/accounts/index.js.map +1 -0
  98. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-after-read.d.ts +5 -0
  99. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-after-read.js +11 -0
  100. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-after-read.js.map +1 -0
  101. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-before-change.d.ts +2 -0
  102. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-before-change.js +8 -0
  103. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-before-change.js.map +1 -0
  104. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.d.ts +6 -0
  105. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.js +119 -0
  106. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.js.map +1 -0
  107. package/dist/better-auth/plugin/lib/build-collections/api-keys.d.ts +3 -0
  108. package/dist/better-auth/plugin/lib/build-collections/api-keys.js +177 -0
  109. package/dist/better-auth/plugin/lib/build-collections/api-keys.js.map +1 -0
  110. package/dist/better-auth/plugin/lib/build-collections/device-code.d.ts +3 -0
  111. package/dist/better-auth/plugin/lib/build-collections/device-code.js +50 -0
  112. package/dist/better-auth/plugin/lib/build-collections/device-code.js.map +1 -0
  113. package/dist/better-auth/plugin/lib/build-collections/index.d.ts +10 -0
  114. package/dist/better-auth/plugin/lib/build-collections/index.js +73 -0
  115. package/dist/better-auth/plugin/lib/build-collections/index.js.map +1 -0
  116. package/dist/better-auth/plugin/lib/build-collections/invitations.d.ts +3 -0
  117. package/dist/better-auth/plugin/lib/build-collections/invitations.js +94 -0
  118. package/dist/better-auth/plugin/lib/build-collections/invitations.js.map +1 -0
  119. package/dist/better-auth/plugin/lib/build-collections/jwks.d.ts +3 -0
  120. package/dist/better-auth/plugin/lib/build-collections/jwks.js +59 -0
  121. package/dist/better-auth/plugin/lib/build-collections/jwks.js.map +1 -0
  122. package/dist/better-auth/plugin/lib/build-collections/members.d.ts +3 -0
  123. package/dist/better-auth/plugin/lib/build-collections/members.js +73 -0
  124. package/dist/better-auth/plugin/lib/build-collections/members.js.map +1 -0
  125. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.d.ts +3 -0
  126. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.js +107 -0
  127. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.js.map +1 -0
  128. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.d.ts +3 -0
  129. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.js +118 -0
  130. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.js.map +1 -0
  131. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.d.ts +3 -0
  132. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.js +89 -0
  133. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.js.map +1 -0
  134. package/dist/better-auth/plugin/lib/build-collections/organizations.d.ts +3 -0
  135. package/dist/better-auth/plugin/lib/build-collections/organizations.js +70 -0
  136. package/dist/better-auth/plugin/lib/build-collections/organizations.js.map +1 -0
  137. package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts +3 -0
  138. package/dist/better-auth/plugin/lib/build-collections/passkeys.js +115 -0
  139. package/dist/better-auth/plugin/lib/build-collections/passkeys.js.map +1 -0
  140. package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts +3 -0
  141. package/dist/better-auth/plugin/lib/build-collections/sessions.js +170 -0
  142. package/dist/better-auth/plugin/lib/build-collections/sessions.js.map +1 -0
  143. package/dist/better-auth/plugin/lib/build-collections/sso-providers.d.ts +3 -0
  144. package/dist/better-auth/plugin/lib/build-collections/sso-providers.js +81 -0
  145. package/dist/better-auth/plugin/lib/build-collections/sso-providers.js.map +1 -0
  146. package/dist/better-auth/plugin/lib/build-collections/subscriptions.d.ts +3 -0
  147. package/dist/better-auth/plugin/lib/build-collections/subscriptions.js +111 -0
  148. package/dist/better-auth/plugin/lib/build-collections/subscriptions.js.map +1 -0
  149. package/dist/better-auth/plugin/lib/build-collections/team-members.d.ts +3 -0
  150. package/dist/better-auth/plugin/lib/build-collections/team-members.js +57 -0
  151. package/dist/better-auth/plugin/lib/build-collections/team-members.js.map +1 -0
  152. package/dist/better-auth/plugin/lib/build-collections/teams.d.ts +3 -0
  153. package/dist/better-auth/plugin/lib/build-collections/teams.js +76 -0
  154. package/dist/better-auth/plugin/lib/build-collections/teams.js.map +1 -0
  155. package/dist/better-auth/plugin/lib/build-collections/two-factors.d.ts +3 -0
  156. package/dist/better-auth/plugin/lib/build-collections/two-factors.js +67 -0
  157. package/dist/better-auth/plugin/lib/build-collections/two-factors.js.map +1 -0
  158. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.d.ts +7 -0
  159. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.js +53 -0
  160. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.js.map +1 -0
  161. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.d.ts +11 -0
  162. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.js +75 -0
  163. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.js.map +1 -0
  164. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.d.ts +4 -0
  165. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.js +6 -0
  166. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.js.map +1 -0
  167. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.d.ts +2 -0
  168. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.js +115 -0
  169. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.js.map +1 -0
  170. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/send-invite-url.d.ts +3 -0
  171. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/send-invite-url.js +64 -0
  172. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/send-invite-url.js.map +1 -0
  173. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.d.ts +3 -0
  174. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.js +80 -0
  175. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.js.map +1 -0
  176. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts +6 -0
  177. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js +79 -0
  178. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js.map +1 -0
  179. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.d.ts +2 -0
  180. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.js +82 -0
  181. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.js.map +1 -0
  182. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.d.ts +2 -0
  183. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.js +54 -0
  184. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.js.map +1 -0
  185. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.d.ts +6 -0
  186. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.js +15 -0
  187. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.js.map +1 -0
  188. package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.d.ts +6 -0
  189. package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.js +8 -0
  190. package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.js.map +1 -0
  191. package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.d.ts +2 -0
  192. package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.js +17 -0
  193. package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.js.map +1 -0
  194. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.d.ts +2 -0
  195. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.js +91 -0
  196. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.js.map +1 -0
  197. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts +3 -0
  198. package/dist/better-auth/plugin/lib/build-collections/users/index.js +341 -0
  199. package/dist/better-auth/plugin/lib/build-collections/users/index.js.map +1 -0
  200. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.d.ts +15 -0
  201. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.js +24 -0
  202. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.js.map +1 -0
  203. package/dist/better-auth/plugin/lib/build-collections/utils/filter-duplicate-fields.d.ts +10 -0
  204. package/dist/better-auth/plugin/lib/build-collections/utils/filter-duplicate-fields.js +67 -0
  205. package/dist/better-auth/plugin/lib/build-collections/utils/filter-duplicate-fields.js.map +1 -0
  206. package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.d.ts +9 -0
  207. package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.js +94 -0
  208. package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.js.map +1 -0
  209. package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.d.ts +7 -0
  210. package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.js +35 -0
  211. package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.js.map +1 -0
  212. package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.d.ts +12 -0
  213. package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.js +25 -0
  214. package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.js.map +1 -0
  215. package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.d.ts +14 -0
  216. package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.js +67 -0
  217. package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.js.map +1 -0
  218. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.d.ts +20 -0
  219. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.js +98 -0
  220. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.js.map +1 -0
  221. package/dist/better-auth/plugin/lib/build-collections/verifications.d.ts +3 -0
  222. package/dist/better-auth/plugin/lib/build-collections/verifications.js +87 -0
  223. package/dist/better-auth/plugin/lib/build-collections/verifications.js.map +1 -0
  224. package/dist/better-auth/plugin/lib/get-payload-auth.d.ts +5 -0
  225. package/dist/better-auth/plugin/lib/get-payload-auth.js +9 -0
  226. package/dist/better-auth/plugin/lib/get-payload-auth.js.map +1 -0
  227. package/dist/better-auth/plugin/lib/init-better-auth.d.ts +7 -0
  228. package/dist/better-auth/plugin/lib/init-better-auth.js +46 -0
  229. package/dist/better-auth/plugin/lib/init-better-auth.js.map +1 -0
  230. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.d.ts +2 -0
  231. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.js +9 -0
  232. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.js.map +1 -0
  233. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.d.ts +2 -0
  234. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.js +10 -0
  235. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.js.map +1 -0
  236. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/device-authorization-plugin.d.ts +2 -0
  237. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/device-authorization-plugin.js +8 -0
  238. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/device-authorization-plugin.js.map +1 -0
  239. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts +10 -0
  240. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js +156 -0
  241. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js.map +1 -0
  242. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.d.ts +2 -0
  243. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.js +18 -0
  244. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.js.map +1 -0
  245. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.d.ts +2 -0
  246. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.js +34 -0
  247. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.js.map +1 -0
  248. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.d.ts +2 -0
  249. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.js +11 -0
  250. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.js.map +1 -0
  251. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.d.ts +2 -0
  252. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.js +10 -0
  253. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.js.map +1 -0
  254. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.d.ts +2 -0
  255. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.js +11 -0
  256. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.js.map +1 -0
  257. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/ensure-password-set-before-create.d.ts +7 -0
  258. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/ensure-password-set-before-create.js +23 -0
  259. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/ensure-password-set-before-create.js.map +1 -0
  260. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/password.d.ts +25 -0
  261. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/password.js +62 -0
  262. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/password.js.map +1 -0
  263. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.d.ts +9 -0
  264. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.js +47 -0
  265. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.js.map +1 -0
  266. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts +15 -0
  267. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js +42 -0
  268. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js.map +1 -0
  269. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.d.ts +9 -0
  270. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.js +63 -0
  271. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.js.map +1 -0
  272. package/dist/better-auth/plugin/lib/set-login-methods.d.ts +4 -0
  273. package/dist/better-auth/plugin/lib/set-login-methods.js +14 -0
  274. package/dist/better-auth/plugin/lib/set-login-methods.js.map +1 -0
  275. package/dist/better-auth/plugin/payload/components/admin-buttons/index.d.ts +9 -0
  276. package/dist/better-auth/plugin/payload/components/admin-buttons/index.js +143 -0
  277. package/dist/better-auth/plugin/payload/components/admin-buttons/index.js.map +1 -0
  278. package/dist/better-auth/plugin/payload/components/admin-invite-button/index.d.ts +10 -0
  279. package/dist/better-auth/plugin/payload/components/admin-invite-button/index.js +219 -0
  280. package/dist/better-auth/plugin/payload/components/admin-invite-button/index.js.map +1 -0
  281. package/dist/better-auth/plugin/payload/components/logout-button.d.ts +4 -0
  282. package/dist/better-auth/plugin/payload/components/logout-button.js +24 -0
  283. package/dist/better-auth/plugin/payload/components/logout-button.js.map +1 -0
  284. package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts +8 -0
  285. package/dist/better-auth/plugin/payload/components/passkeys/add-button.js +117 -0
  286. package/dist/better-auth/plugin/payload/components/passkeys/add-button.js.map +1 -0
  287. package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts +3 -0
  288. package/dist/better-auth/plugin/payload/components/passkeys/client.js +66 -0
  289. package/dist/better-auth/plugin/payload/components/passkeys/client.js.map +1 -0
  290. package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts +4 -0
  291. package/dist/better-auth/plugin/payload/components/passkeys/index.js +52 -0
  292. package/dist/better-auth/plugin/payload/components/passkeys/index.js.map +1 -0
  293. package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts +8 -0
  294. package/dist/better-auth/plugin/payload/components/passkeys/list.js +57 -0
  295. package/dist/better-auth/plugin/payload/components/passkeys/list.js.map +1 -0
  296. package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts +22 -0
  297. package/dist/better-auth/plugin/payload/components/passkeys/types.js +3 -0
  298. package/dist/better-auth/plugin/payload/components/passkeys/types.js.map +1 -0
  299. package/dist/better-auth/plugin/payload/components/rsc-redirect.d.ts +6 -0
  300. package/dist/better-auth/plugin/payload/components/rsc-redirect.js +7 -0
  301. package/dist/better-auth/plugin/payload/components/rsc-redirect.js.map +1 -0
  302. package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.d.ts +15 -0
  303. package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.js +157 -0
  304. package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.js.map +1 -0
  305. package/dist/better-auth/plugin/payload/components/token-field.d.ts +4 -0
  306. package/dist/better-auth/plugin/payload/components/token-field.js +31 -0
  307. package/dist/better-auth/plugin/payload/components/token-field.js.map +1 -0
  308. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts +8 -0
  309. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.js +300 -0
  310. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.js.map +1 -0
  311. package/dist/better-auth/plugin/payload/exports/client.d.ts +6 -0
  312. package/dist/better-auth/plugin/payload/exports/client.js +8 -0
  313. package/dist/better-auth/plugin/payload/exports/client.js.map +1 -0
  314. package/dist/better-auth/plugin/payload/exports/rsc.d.ts +8 -0
  315. package/dist/better-auth/plugin/payload/exports/rsc.js +10 -0
  316. package/dist/better-auth/plugin/payload/exports/rsc.js.map +1 -0
  317. package/dist/better-auth/plugin/payload/utils/generate-admin-invite-url.d.ts +2 -0
  318. package/dist/better-auth/plugin/payload/utils/generate-admin-invite-url.js +9 -0
  319. package/dist/better-auth/plugin/payload/utils/generate-admin-invite-url.js.map +1 -0
  320. package/dist/better-auth/plugin/payload/utils/get-safe-redirect.d.ts +1 -0
  321. package/dist/better-auth/plugin/payload/utils/get-safe-redirect.js +22 -0
  322. package/dist/better-auth/plugin/payload/utils/get-safe-redirect.js.map +1 -0
  323. package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts +19 -0
  324. package/dist/better-auth/plugin/payload/views/admin-login/client.js +226 -0
  325. package/dist/better-auth/plugin/payload/views/admin-login/client.js.map +1 -0
  326. package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts +10 -0
  327. package/dist/better-auth/plugin/payload/views/admin-login/index.js +150 -0
  328. package/dist/better-auth/plugin/payload/views/admin-login/index.js.map +1 -0
  329. package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts +16 -0
  330. package/dist/better-auth/plugin/payload/views/admin-signup/client.js +299 -0
  331. package/dist/better-auth/plugin/payload/views/admin-signup/client.js.map +1 -0
  332. package/dist/better-auth/plugin/payload/views/admin-signup/index.d.ts +9 -0
  333. package/dist/better-auth/plugin/payload/views/admin-signup/index.js +104 -0
  334. package/dist/better-auth/plugin/payload/views/admin-signup/index.js.map +1 -0
  335. package/dist/better-auth/plugin/payload/views/forgot-password/client.d.ts +7 -0
  336. package/dist/better-auth/plugin/payload/views/forgot-password/client.js +119 -0
  337. package/dist/better-auth/plugin/payload/views/forgot-password/client.js.map +1 -0
  338. package/dist/better-auth/plugin/payload/views/forgot-password/index.d.ts +8 -0
  339. package/dist/better-auth/plugin/payload/views/forgot-password/index.js +78 -0
  340. package/dist/better-auth/plugin/payload/views/forgot-password/index.js.map +1 -0
  341. package/dist/better-auth/plugin/payload/views/reset-password/client.d.ts +10 -0
  342. package/dist/better-auth/plugin/payload/views/reset-password/client.js +144 -0
  343. package/dist/better-auth/plugin/payload/views/reset-password/client.js.map +1 -0
  344. package/dist/better-auth/plugin/payload/views/reset-password/index.d.ts +8 -0
  345. package/dist/better-auth/plugin/payload/views/reset-password/index.js +96 -0
  346. package/dist/better-auth/plugin/payload/views/reset-password/index.js.map +1 -0
  347. package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts +6 -0
  348. package/dist/better-auth/plugin/payload/views/two-factor-verify/client.js +96 -0
  349. package/dist/better-auth/plugin/payload/views/two-factor-verify/client.js.map +1 -0
  350. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts +9 -0
  351. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.js +56 -0
  352. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.js.map +1 -0
  353. package/dist/better-auth/plugin/types.d.ts +429 -0
  354. package/dist/better-auth/plugin/types.js +3 -0
  355. package/dist/better-auth/plugin/types.js.map +1 -0
  356. package/dist/better-auth/plugin/utils/set.d.ts +39 -0
  357. package/dist/better-auth/plugin/utils/set.js +103 -0
  358. package/dist/better-auth/plugin/utils/set.js.map +1 -0
  359. package/dist/better-auth/scripts/generate-types.d.ts +1 -0
  360. package/dist/better-auth/scripts/generate-types.js +234 -0
  361. package/dist/better-auth/scripts/generate-types.js.map +1 -0
  362. package/dist/better-auth/types.d.ts +2 -0
  363. package/dist/better-auth/types.js +4 -0
  364. package/dist/better-auth/types.js.map +1 -0
  365. package/dist/index.d.ts +1 -0
  366. package/dist/index.js +4 -0
  367. package/dist/index.js.map +1 -0
  368. package/dist/shared/components/icons.d.ts +7 -0
  369. package/dist/shared/components/icons.js +442 -0
  370. package/dist/shared/components/icons.js.map +1 -0
  371. package/dist/shared/components/logo.d.ts +3 -0
  372. package/dist/shared/components/logo.js +24 -0
  373. package/dist/shared/components/logo.js.map +1 -0
  374. package/dist/shared/form/components/submit.d.ts +7 -0
  375. package/dist/shared/form/components/submit.js +16 -0
  376. package/dist/shared/form/components/submit.js.map +1 -0
  377. package/dist/shared/form/fields/text-field.d.ts +8 -0
  378. package/dist/shared/form/fields/text-field.js +37 -0
  379. package/dist/shared/form/fields/text-field.js.map +1 -0
  380. package/dist/shared/form/index.d.ts +4 -0
  381. package/dist/shared/form/index.js +8 -0
  382. package/dist/shared/form/index.js.map +1 -0
  383. package/dist/shared/form/ui/header/index.d.ts +8 -0
  384. package/dist/shared/form/ui/header/index.js +24 -0
  385. package/dist/shared/form/ui/header/index.js.map +1 -0
  386. package/dist/shared/form/ui/index.d.ts +31 -0
  387. package/dist/shared/form/ui/index.js +57 -0
  388. package/dist/shared/form/ui/index.js.map +1 -0
  389. package/dist/shared/form/validation.d.ts +51 -0
  390. package/dist/shared/form/validation.js +127 -0
  391. package/dist/shared/form/validation.js.map +1 -0
  392. package/dist/shared/index.d.ts +2 -0
  393. package/dist/shared/index.js +4 -0
  394. package/dist/shared/index.js.map +1 -0
  395. package/dist/shared/payload/fields/field-copy-button/index.d.ts +3 -0
  396. package/dist/shared/payload/fields/field-copy-button/index.js +38 -0
  397. package/dist/shared/payload/fields/field-copy-button/index.js.map +1 -0
  398. package/dist/shared/payload/fields/generate-uuid-button/index.d.ts +3 -0
  399. package/dist/shared/payload/fields/generate-uuid-button/index.js +26 -0
  400. package/dist/shared/payload/fields/generate-uuid-button/index.js.map +1 -0
  401. package/dist/shared/payload/fields/index.d.ts +2 -0
  402. package/dist/shared/payload/fields/index.js +4 -0
  403. package/dist/shared/payload/fields/index.js.map +1 -0
  404. package/dist/shared/utils/regex.d.ts +2 -0
  405. package/dist/shared/utils/regex.js +4 -0
  406. package/dist/shared/utils/regex.js.map +1 -0
  407. package/dist/shared/utils/try-catch.d.ts +11 -0
  408. package/dist/shared/utils/try-catch.js +17 -0
  409. package/dist/shared/utils/try-catch.js.map +1 -0
  410. package/dist/shared/utils/value-or-default.d.ts +9 -0
  411. package/dist/shared/utils/value-or-default.js +12 -0
  412. package/dist/shared/utils/value-or-default.js.map +1 -0
  413. package/package.json +122 -0
@@ -0,0 +1,234 @@
1
+ import fs from "node:fs/promises";
2
+ import path from "node:path";
3
+ import { fileURLToPath } from "node:url";
4
+ // import { emailHarmony, phoneHarmony } from 'better-auth-harmony'
5
+ import { sso } from "@better-auth/sso";
6
+ import { stripe } from "@better-auth/stripe";
7
+ import { checkout, polar } from "@polar-sh/better-auth";
8
+ import { Polar } from "@polar-sh/sdk";
9
+ import { getSchema } from "better-auth/db";
10
+ import { nextCookies } from "better-auth/next-js";
11
+ import { admin, anonymous, apiKey, bearer, customSession, deviceAuthorization, emailOTP, genericOAuth, jwt, lastLoginMethod, magicLink, mcp, multiSession, oidcProvider, oneTap, oneTimeToken, openAPI, organization, phoneNumber, twoFactor, username } from "better-auth/plugins";
12
+ import Stripe from "stripe";
13
+ // Note: passkey may not be available in all better-auth versions
14
+ // Create a no-op function as fallback
15
+ const passkey = ()=>({
16
+ id: 'passkey'
17
+ });
18
+ const client = new Polar({
19
+ accessToken: 'pk_test_1234567890',
20
+ server: 'sandbox'
21
+ });
22
+ const plugins = [
23
+ username(),
24
+ admin(),
25
+ apiKey(),
26
+ passkey(),
27
+ // emailHarmony(),
28
+ // phoneHarmony(),
29
+ bearer(),
30
+ emailOTP({
31
+ sendVerificationOTP: async ()=>{}
32
+ }),
33
+ magicLink({
34
+ sendMagicLink: async ()=>{}
35
+ }),
36
+ phoneNumber({
37
+ sendOTP: async ()=>{}
38
+ }),
39
+ oneTap(),
40
+ anonymous(),
41
+ multiSession(),
42
+ oneTimeToken(),
43
+ oidcProvider({
44
+ loginPage: ''
45
+ }),
46
+ sso(),
47
+ genericOAuth({
48
+ config: [
49
+ {
50
+ providerId: 'typescript',
51
+ clientId: 'typescript',
52
+ clientSecret: 'typescript'
53
+ }
54
+ ]
55
+ }),
56
+ openAPI(),
57
+ organization({
58
+ teams: {
59
+ enabled: true
60
+ }
61
+ }),
62
+ jwt(),
63
+ twoFactor(),
64
+ phoneNumber(),
65
+ nextCookies(),
66
+ customSession(async ()=>({})),
67
+ mcp({
68
+ loginPage: ''
69
+ }),
70
+ deviceAuthorization(),
71
+ lastLoginMethod({
72
+ storeInDatabase: true
73
+ }),
74
+ stripe({
75
+ stripeClient: new Stripe('typescript'),
76
+ stripeWebhookSecret: 'typescript',
77
+ subscription: {
78
+ enabled: true,
79
+ plans: [
80
+ {
81
+ name: 'Basic',
82
+ priceId: 'basic'
83
+ },
84
+ {
85
+ name: 'Pro',
86
+ priceId: 'pro'
87
+ },
88
+ {
89
+ name: 'Enterprise',
90
+ priceId: 'enterprise'
91
+ }
92
+ ]
93
+ }
94
+ }),
95
+ // As of writing this, Polar don't create schema fields, but just in case in the future we leave this here.
96
+ polar({
97
+ client,
98
+ use: [
99
+ checkout({
100
+ products: [
101
+ {
102
+ productId: '123-456-789',
103
+ slug: 'pro'
104
+ }
105
+ ],
106
+ successUrl: '/success?checkout_id={CHECKOUT_ID}',
107
+ authenticatedUsersOnly: true
108
+ })
109
+ ]
110
+ })
111
+ ];
112
+ // Using Record<string, unknown> because BetterAuth config structure varies by plugin configuration and cannot be strictly typed
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
+ if (!only) continue;
196
+ out += `export type ${P}Fields = {\n`;
197
+ for (const [k, f] of Object.entries(pluginsForModel[only] ?? {}))out += ` ${f.fieldName ?? k}${f.required ? '' : '?'}: ${map(f.type)}\n`;
198
+ out += '}\n\n';
199
+ out += `export type ${P} = ${P}Fields\n\n`;
200
+ continue;
201
+ }
202
+ const parts = [];
203
+ if (Object.keys(base).length) parts.push(`Base${P}Fields`);
204
+ if (pluginIds.length) {
205
+ const mapName = needPluginMap ? `${P}PluginFields` : undefined;
206
+ parts.push(...pluginIds.map((id)=>mapName ? `${mapName}[${JSON.stringify(id)}]` : 'never'));
207
+ }
208
+ out += `export type ${P} = ${parts.join(' & ')}\n\n`;
209
+ }
210
+ // Generate union type of plugin identifiers
211
+ const pluginIdUnion = [
212
+ ...seen
213
+ ].map((id)=>JSON.stringify(id)).join(' | ');
214
+ out += `export type PluginId = ${pluginIdUnion}\n\n`;
215
+ // Generate full schema mapping
216
+ out += 'export type BetterAuthFullSchema = {\n';
217
+ for (const model of models){
218
+ const P = pascal(model);
219
+ out += ` ${JSON.stringify(model)}: ${P}\n`;
220
+ }
221
+ out += '}\n\n';
222
+ // Generate union type of all model names
223
+ out += 'export type ModelKey = keyof BetterAuthFullSchema';
224
+ return out;
225
+ };
226
+ const generated = gen();
227
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
228
+ (async ()=>{
229
+ const file = path.resolve(__dirname, '../generated-types.ts');
230
+ await fs.writeFile(file, generated, 'utf8');
231
+ console.log(`Generated types written to ${file}`);
232
+ })();
233
+
234
+ //# sourceMappingURL=generate-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/better-auth/scripts/generate-types.ts"],"sourcesContent":["import fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { fileURLToPath } from 'node:url';\n// import { emailHarmony, phoneHarmony } from 'better-auth-harmony'\nimport { sso } from '@better-auth/sso';\nimport { stripe } from '@better-auth/stripe';\nimport { checkout, polar } from '@polar-sh/better-auth';\nimport { Polar } from '@polar-sh/sdk';\nimport type { DBFieldAttribute } from 'better-auth/db';\nimport { getSchema } from 'better-auth/db';\nimport { nextCookies } from 'better-auth/next-js';\nimport {\n admin,\n anonymous,\n apiKey,\n bearer,\n customSession,\n deviceAuthorization,\n emailOTP,\n genericOAuth,\n jwt,\n lastLoginMethod,\n magicLink,\n mcp,\n multiSession,\n oidcProvider,\n oneTap,\n oneTimeToken,\n openAPI,\n organization,\n phoneNumber,\n twoFactor,\n username,\n} from 'better-auth/plugins';\nimport Stripe from 'stripe';\n\n// Note: passkey may not be available in all better-auth versions\n// Create a no-op function as fallback\nconst passkey = () => ({ id: 'passkey' });\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({\n config: [{ providerId: 'typescript', clientId: 'typescript', clientSecret: 'typescript' }],\n }),\n openAPI(),\n organization({ teams: { enabled: true } }),\n jwt(),\n twoFactor(),\n phoneNumber(),\n nextCookies(),\n customSession(async () => ({})),\n mcp({ loginPage: '' }),\n deviceAuthorization(),\n lastLoginMethod({ storeInDatabase: true }),\n stripe({\n stripeClient: new Stripe('typescript'),\n stripeWebhookSecret: 'typescript',\n subscription: {\n enabled: true,\n plans: [\n {\n name: 'Basic',\n priceId: 'basic',\n },\n {\n name: 'Pro',\n priceId: 'pro',\n },\n {\n name: 'Enterprise',\n priceId: 'enterprise',\n },\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 use: [\n checkout({\n products: [\n {\n productId: '123-456-789', // ID of Product from Polar Dashboard\n slug: 'pro', // Custom slug for easy reference in Checkout URL, e.g. /checkout/pro\n },\n ],\n successUrl: '/success?checkout_id={CHECKOUT_ID}',\n authenticatedUsersOnly: true,\n }),\n ],\n }),\n];\n\n// Using Record<string, unknown> because BetterAuth config structure varies by plugin configuration and cannot be strictly typed\nconst betterAuthConfig: /* Using Record<string, unknown> because BetterAuth config structure varies by plugin configuration and cannot be strictly typed */ Record<\n string,\n unknown\n> = {\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, DBFieldAttribute> }>;\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, DBFieldAttribute>> => {\n const d: Record<string, Record<string, DBFieldAttribute>> = {};\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, DBFieldAttribute>>> = {};\n const seen = new Set<string>();\n\n for (const pl of plugins) {\n const id = (pl as { id?: string }).id;\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))\n 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))\n 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 if (!only) continue;\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(\n ...pluginIds.map(\n id => (mapName ? `${mapName}[${JSON.stringify(id)}]` : 'never') /* not reachable */\n )\n );\n }\n out += `export type ${P} = ${parts.join(' & ')}\\n\\n`;\n }\n\n // Generate union type of plugin identifiers\n const pluginIdUnion = [...seen].map(id => JSON.stringify(id)).join(' | ');\n out += `export type PluginId = ${pluginIdUnion}\\n\\n`;\n\n // Generate full schema mapping\n out += 'export type BetterAuthFullSchema = {\\n';\n for (const model of models) {\n const P = pascal(model);\n out += ` ${JSON.stringify(model)}: ${P}\\n`;\n }\n out += '}\\n\\n';\n\n // Generate union type of all model names\n out += 'export type ModelKey = keyof BetterAuthFullSchema';\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\n console.log(`Generated types written to ${file}`);\n})();\n"],"names":["fs","path","fileURLToPath","sso","stripe","checkout","polar","Polar","getSchema","nextCookies","admin","anonymous","apiKey","bearer","customSession","deviceAuthorization","emailOTP","genericOAuth","jwt","lastLoginMethod","magicLink","mcp","multiSession","oidcProvider","oneTap","oneTimeToken","openAPI","organization","phoneNumber","twoFactor","username","Stripe","passkey","id","client","accessToken","server","plugins","sendVerificationOTP","sendMagicLink","sendOTP","loginPage","config","providerId","clientId","clientSecret","teams","enabled","storeInDatabase","stripeClient","stripeWebhookSecret","subscription","plans","name","priceId","use","products","productId","slug","successUrl","authenticatedUsersOnly","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","pluginIdUnion","generated","__dirname","dirname","url","file","resolve","writeFile","console","log"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './adapter/types';
2
+ export * from './plugin/types';
@@ -0,0 +1,4 @@
1
+ export * from "./adapter/types";
2
+ export * from "./plugin/types";
3
+
4
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/better-auth/types.ts"],"sourcesContent":["export * from './adapter/types';\nexport * from './plugin/types';\n"],"names":[],"mappings":"AAAA,cAAc,kBAAkB;AAChC,cAAc,iBAAiB"}
@@ -0,0 +1 @@
1
+ export * from './better-auth';
package/dist/index.js ADDED
@@ -0,0 +1,4 @@
1
+ // These re-exports will be used by consumers of the library
2
+ export * from "./better-auth";
3
+
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts"],"sourcesContent":["// These re-exports will be used by consumers of the library\nexport * from './better-auth';\n"],"names":[],"mappings":"AAAA,4DAA4D;AAC5D,cAAc,gBAAgB"}
@@ -0,0 +1,7 @@
1
+ import { type ComponentType, type SVGProps } from 'react';
2
+ export interface ProviderIconProps extends SVGProps<SVGSVGElement> {
3
+ className?: string;
4
+ variant?: 'default' | 'color';
5
+ }
6
+ export type ProviderIcon = ComponentType<ProviderIconProps>;
7
+ export declare const Icons: Record<string, ProviderIcon>;