better-auth 1.2.0-beta.6 → 1.2.0-beta.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (119) hide show
  1. package/dist/adapters/drizzle.d.cts +1 -1
  2. package/dist/adapters/drizzle.d.ts +1 -1
  3. package/dist/adapters/kysely.d.cts +1 -1
  4. package/dist/adapters/kysely.d.ts +1 -1
  5. package/dist/adapters/memory.d.cts +1 -1
  6. package/dist/adapters/memory.d.ts +1 -1
  7. package/dist/adapters/mongodb.cjs +16 -3
  8. package/dist/adapters/mongodb.d.cts +1 -1
  9. package/dist/adapters/mongodb.d.ts +1 -1
  10. package/dist/adapters/mongodb.js +16 -3
  11. package/dist/adapters/prisma.d.cts +1 -1
  12. package/dist/adapters/prisma.d.ts +1 -1
  13. package/dist/adapters/test.d.cts +1 -1
  14. package/dist/adapters/test.d.ts +1 -1
  15. package/dist/api.d.cts +2 -2
  16. package/dist/api.d.ts +2 -2
  17. package/dist/{auth-CC4kpwks.d.cts → auth-BLwS7t0V.d.cts} +7266 -3010
  18. package/dist/{auth-BfbTouIV.d.ts → auth-C42JqOR9.d.ts} +7266 -3010
  19. package/dist/{chunk-XKCN2VRG.cjs → chunk-45RBYQKI.cjs} +58 -2
  20. package/dist/{chunk-KAEQXMEV.cjs → chunk-GSEEAIRZ.cjs} +1 -1
  21. package/dist/{chunk-RMPI2YZ3.js → chunk-IQUHEVLH.js} +1 -1
  22. package/dist/{chunk-5AOJMBJI.js → chunk-J6VNT2T4.js} +8 -0
  23. package/dist/{chunk-75SPUXMY.cjs → chunk-QNLSMTXF.cjs} +9 -4
  24. package/dist/{chunk-GWJDRQJ3.js → chunk-QQGRNAM2.js} +9 -4
  25. package/dist/{chunk-OALLKKNX.cjs → chunk-SMZIOWVN.cjs} +8 -0
  26. package/dist/{chunk-FX2ZHENM.js → chunk-TZ34QTAV.js} +58 -2
  27. package/dist/{chunk-LIGJVOZ4.cjs → chunk-WLOSPOQJ.cjs} +45 -24
  28. package/dist/{chunk-V56HFQQX.js → chunk-YHW4KODD.js} +45 -24
  29. package/dist/client/plugins.cjs +45 -12
  30. package/dist/client/plugins.d.cts +44 -6
  31. package/dist/client/plugins.d.ts +44 -6
  32. package/dist/client/plugins.js +45 -12
  33. package/dist/client.d.cts +1 -1
  34. package/dist/client.d.ts +1 -1
  35. package/dist/cookies.d.cts +1 -1
  36. package/dist/cookies.d.ts +1 -1
  37. package/dist/db.d.cts +2 -2
  38. package/dist/db.d.ts +2 -2
  39. package/dist/index-Bszx4yMW.d.cts +7755 -0
  40. package/dist/index-DbIhOM3X.d.ts +7755 -0
  41. package/dist/index.cjs +1 -1
  42. package/dist/index.d.cts +2 -2
  43. package/dist/index.d.ts +2 -2
  44. package/dist/index.js +1 -1
  45. package/dist/next-js.cjs +5 -5
  46. package/dist/next-js.d.cts +1 -1
  47. package/dist/next-js.d.ts +1 -1
  48. package/dist/next-js.js +5 -5
  49. package/dist/node.d.cts +1 -1
  50. package/dist/node.d.ts +1 -1
  51. package/dist/oauth2.d.cts +2 -2
  52. package/dist/oauth2.d.ts +2 -2
  53. package/dist/plugins/admin.cjs +2 -2
  54. package/dist/plugins/admin.d.cts +79 -25
  55. package/dist/plugins/admin.d.ts +79 -25
  56. package/dist/plugins/admin.js +1 -1
  57. package/dist/plugins/anonymous.d.cts +7 -3
  58. package/dist/plugins/anonymous.d.ts +7 -3
  59. package/dist/plugins/bearer.d.cts +1 -1
  60. package/dist/plugins/bearer.d.ts +1 -1
  61. package/dist/plugins/custom-session.d.cts +7 -3
  62. package/dist/plugins/custom-session.d.ts +7 -3
  63. package/dist/plugins/email-otp.d.cts +43 -15
  64. package/dist/plugins/email-otp.d.ts +43 -15
  65. package/dist/plugins/generic-oauth.d.cts +19 -7
  66. package/dist/plugins/generic-oauth.d.ts +19 -7
  67. package/dist/plugins/jwt.d.cts +13 -5
  68. package/dist/plugins/jwt.d.ts +13 -5
  69. package/dist/plugins/magic-link.d.cts +12 -4
  70. package/dist/plugins/magic-link.d.ts +12 -4
  71. package/dist/plugins/multi-session.d.cts +19 -7
  72. package/dist/plugins/multi-session.d.ts +19 -7
  73. package/dist/plugins/oidc-provider.cjs +2 -2
  74. package/dist/plugins/oidc-provider.d.cts +43 -15
  75. package/dist/plugins/oidc-provider.d.ts +43 -15
  76. package/dist/plugins/oidc-provider.js +1 -1
  77. package/dist/plugins/one-tap.cjs +2 -2
  78. package/dist/plugins/one-tap.d.cts +13 -2
  79. package/dist/plugins/one-tap.d.ts +13 -2
  80. package/dist/plugins/one-tap.js +1 -1
  81. package/dist/plugins/open-api.cjs +2 -2
  82. package/dist/plugins/open-api.d.cts +13 -5
  83. package/dist/plugins/open-api.d.ts +13 -5
  84. package/dist/plugins/open-api.js +1 -1
  85. package/dist/plugins/organization.d.cts +2 -2
  86. package/dist/plugins/organization.d.ts +2 -2
  87. package/dist/plugins/passkey.d.cts +43 -15
  88. package/dist/plugins/passkey.d.ts +43 -15
  89. package/dist/plugins/phone-number.d.cts +31 -11
  90. package/dist/plugins/phone-number.d.ts +31 -11
  91. package/dist/plugins/sso.d.cts +19 -7
  92. package/dist/plugins/sso.d.ts +19 -7
  93. package/dist/plugins/two-factor.d.cts +61 -21
  94. package/dist/plugins/two-factor.d.ts +61 -21
  95. package/dist/plugins/username.cjs +2 -2
  96. package/dist/plugins/username.d.cts +28 -4
  97. package/dist/plugins/username.d.ts +28 -4
  98. package/dist/plugins/username.js +1 -1
  99. package/dist/plugins.cjs +10 -10
  100. package/dist/plugins.d.cts +9 -5
  101. package/dist/plugins.d.ts +9 -5
  102. package/dist/plugins.js +5 -5
  103. package/dist/react.d.cts +1 -1
  104. package/dist/react.d.ts +1 -1
  105. package/dist/solid.d.cts +1 -1
  106. package/dist/solid.d.ts +1 -1
  107. package/dist/{state-BlyN0kTT.d.ts → state-BlQHfd32.d.ts} +1 -1
  108. package/dist/{state-ClV1x8my.d.cts → state-lA7cG1Em.d.cts} +1 -1
  109. package/dist/svelte-kit.d.cts +1 -1
  110. package/dist/svelte-kit.d.ts +1 -1
  111. package/dist/svelte.d.cts +1 -1
  112. package/dist/svelte.d.ts +1 -1
  113. package/dist/types.d.cts +2 -2
  114. package/dist/types.d.ts +2 -2
  115. package/dist/vue.d.cts +1 -1
  116. package/dist/vue.d.ts +1 -1
  117. package/package.json +3 -3
  118. package/dist/index-CtbEb8Ls.d.ts +0 -4211
  119. package/dist/index-F5NLq5XF.d.cts +0 -4211
@@ -1,4 +1,4 @@
1
- import { B as BetterAuthOptions, W as Where } from '../auth-CC4kpwks.cjs';
1
+ import { B as BetterAuthOptions, W as Where } from '../auth-BLwS7t0V.cjs';
2
2
  import 'zod';
3
3
  import 'kysely';
4
4
  import 'better-call';
@@ -1,4 +1,4 @@
1
- import { B as BetterAuthOptions, W as Where } from '../auth-BfbTouIV.js';
1
+ import { B as BetterAuthOptions, W as Where } from '../auth-C42JqOR9.js';
2
2
  import 'zod';
3
3
  import 'kysely';
4
4
  import 'better-call';
@@ -1,5 +1,5 @@
1
1
  import { Kysely } from 'kysely';
2
- import { B as BetterAuthOptions, K as KyselyDatabaseType, W as Where } from '../auth-CC4kpwks.cjs';
2
+ import { B as BetterAuthOptions, K as KyselyDatabaseType, W as Where } from '../auth-BLwS7t0V.cjs';
3
3
  import 'zod';
4
4
  import 'better-call';
5
5
  import '../helper-Bi8FQwDD.cjs';
@@ -1,5 +1,5 @@
1
1
  import { Kysely } from 'kysely';
2
- import { B as BetterAuthOptions, K as KyselyDatabaseType, W as Where } from '../auth-BfbTouIV.js';
2
+ import { B as BetterAuthOptions, K as KyselyDatabaseType, W as Where } from '../auth-C42JqOR9.js';
3
3
  import 'zod';
4
4
  import 'better-call';
5
5
  import '../helper-Bi8FQwDD.js';
@@ -1,4 +1,4 @@
1
- import { B as BetterAuthOptions, W as Where } from '../auth-CC4kpwks.cjs';
1
+ import { B as BetterAuthOptions, W as Where } from '../auth-BLwS7t0V.cjs';
2
2
  import 'zod';
3
3
  import 'kysely';
4
4
  import 'better-call';
@@ -1,4 +1,4 @@
1
- import { B as BetterAuthOptions, W as Where } from '../auth-BfbTouIV.js';
1
+ import { B as BetterAuthOptions, W as Where } from '../auth-C42JqOR9.js';
2
2
  import 'zod';
3
3
  import 'kysely';
4
4
  import 'better-call';
@@ -15,7 +15,11 @@ var mongodb = require('mongodb');
15
15
 
16
16
  var createTransform = (options) => {
17
17
  const schema = chunkKAR56MJZ_cjs.getAuthTables(options);
18
+ const customIdGen = options.advanced?.generateId;
18
19
  function serializeID(field, value, model) {
20
+ if (customIdGen) {
21
+ return value;
22
+ }
19
23
  if (field === "id" || field === "_id" || schema[model].fields[field].references?.field === "id") {
20
24
  if (typeof value !== "string") {
21
25
  if (value instanceof mongodb.ObjectId) {
@@ -47,6 +51,9 @@ var createTransform = (options) => {
47
51
  return value;
48
52
  }
49
53
  function deserializeID(field, value, model) {
54
+ if (customIdGen) {
55
+ return value;
56
+ }
50
57
  if (field === "id" || schema[model].fields[field].references?.field === "id") {
51
58
  if (value instanceof mongodb.ObjectId) {
52
59
  return value.toHexString();
@@ -65,6 +72,9 @@ var createTransform = (options) => {
65
72
  }
66
73
  function getField(field, model) {
67
74
  if (field === "id") {
75
+ if (customIdGen) {
76
+ return "id";
77
+ }
68
78
  return "_id";
69
79
  }
70
80
  const f = schema[model].fields[field];
@@ -72,7 +82,9 @@ var createTransform = (options) => {
72
82
  }
73
83
  return {
74
84
  transformInput(data, model, action) {
75
- const transformedData = action === "update" ? {} : {
85
+ const transformedData = action === "update" ? {} : customIdGen ? {
86
+ id: customIdGen({ model })
87
+ } : {
76
88
  _id: new mongodb.ObjectId()
77
89
  };
78
90
  const fields = schema[model].fields;
@@ -179,17 +191,18 @@ var createTransform = (options) => {
179
191
  };
180
192
  var mongodbAdapter = (db) => (options) => {
181
193
  const transform = createTransform(options);
194
+ const hasCustomId = options.advanced?.generateId;
182
195
  return {
183
196
  id: "mongodb-adapter",
184
197
  async create(data) {
185
198
  const { model, data: values, select } = data;
186
199
  const transformedData = transform.transformInput(values, model, "create");
187
- if (transformedData.id) {
200
+ if (transformedData.id && !hasCustomId) {
188
201
  delete transformedData.id;
189
202
  }
190
203
  const res = await db.collection(transform.getModelName(model)).insertOne(transformedData);
191
204
  const id = res.insertedId;
192
- const insertedData = { ...transformedData, id: id.toString() };
205
+ const insertedData = { id: id.toString(), ...transformedData };
193
206
  const t = transform.transformOutput(insertedData, model, select);
194
207
  return t;
195
208
  },
@@ -1,5 +1,5 @@
1
1
  import { Db } from 'mongodb';
2
- import { B as BetterAuthOptions, W as Where } from '../auth-CC4kpwks.cjs';
2
+ import { B as BetterAuthOptions, W as Where } from '../auth-BLwS7t0V.cjs';
3
3
  import 'zod';
4
4
  import 'kysely';
5
5
  import 'better-call';
@@ -1,5 +1,5 @@
1
1
  import { Db } from 'mongodb';
2
- import { B as BetterAuthOptions, W as Where } from '../auth-BfbTouIV.js';
2
+ import { B as BetterAuthOptions, W as Where } from '../auth-C42JqOR9.js';
3
3
  import 'zod';
4
4
  import 'kysely';
5
5
  import 'better-call';
@@ -13,7 +13,11 @@ import { ObjectId } from 'mongodb';
13
13
 
14
14
  var createTransform = (options) => {
15
15
  const schema = getAuthTables(options);
16
+ const customIdGen = options.advanced?.generateId;
16
17
  function serializeID(field, value, model) {
18
+ if (customIdGen) {
19
+ return value;
20
+ }
17
21
  if (field === "id" || field === "_id" || schema[model].fields[field].references?.field === "id") {
18
22
  if (typeof value !== "string") {
19
23
  if (value instanceof ObjectId) {
@@ -45,6 +49,9 @@ var createTransform = (options) => {
45
49
  return value;
46
50
  }
47
51
  function deserializeID(field, value, model) {
52
+ if (customIdGen) {
53
+ return value;
54
+ }
48
55
  if (field === "id" || schema[model].fields[field].references?.field === "id") {
49
56
  if (value instanceof ObjectId) {
50
57
  return value.toHexString();
@@ -63,6 +70,9 @@ var createTransform = (options) => {
63
70
  }
64
71
  function getField(field, model) {
65
72
  if (field === "id") {
73
+ if (customIdGen) {
74
+ return "id";
75
+ }
66
76
  return "_id";
67
77
  }
68
78
  const f = schema[model].fields[field];
@@ -70,7 +80,9 @@ var createTransform = (options) => {
70
80
  }
71
81
  return {
72
82
  transformInput(data, model, action) {
73
- const transformedData = action === "update" ? {} : {
83
+ const transformedData = action === "update" ? {} : customIdGen ? {
84
+ id: customIdGen({ model })
85
+ } : {
74
86
  _id: new ObjectId()
75
87
  };
76
88
  const fields = schema[model].fields;
@@ -177,17 +189,18 @@ var createTransform = (options) => {
177
189
  };
178
190
  var mongodbAdapter = (db) => (options) => {
179
191
  const transform = createTransform(options);
192
+ const hasCustomId = options.advanced?.generateId;
180
193
  return {
181
194
  id: "mongodb-adapter",
182
195
  async create(data) {
183
196
  const { model, data: values, select } = data;
184
197
  const transformedData = transform.transformInput(values, model, "create");
185
- if (transformedData.id) {
198
+ if (transformedData.id && !hasCustomId) {
186
199
  delete transformedData.id;
187
200
  }
188
201
  const res = await db.collection(transform.getModelName(model)).insertOne(transformedData);
189
202
  const id = res.insertedId;
190
- const insertedData = { ...transformedData, id: id.toString() };
203
+ const insertedData = { id: id.toString(), ...transformedData };
191
204
  const t = transform.transformOutput(insertedData, model, select);
192
205
  return t;
193
206
  },
@@ -1,4 +1,4 @@
1
- import { B as BetterAuthOptions, W as Where } from '../auth-CC4kpwks.cjs';
1
+ import { B as BetterAuthOptions, W as Where } from '../auth-BLwS7t0V.cjs';
2
2
  import 'zod';
3
3
  import 'kysely';
4
4
  import 'better-call';
@@ -1,4 +1,4 @@
1
- import { B as BetterAuthOptions, W as Where } from '../auth-BfbTouIV.js';
1
+ import { B as BetterAuthOptions, W as Where } from '../auth-C42JqOR9.js';
2
2
  import 'zod';
3
3
  import 'kysely';
4
4
  import 'better-call';
@@ -1,4 +1,4 @@
1
- import { B as BetterAuthOptions, A as Adapter } from '../auth-CC4kpwks.cjs';
1
+ import { B as BetterAuthOptions, A as Adapter } from '../auth-BLwS7t0V.cjs';
2
2
  import 'zod';
3
3
  import 'kysely';
4
4
  import 'better-call';
@@ -1,4 +1,4 @@
1
- import { B as BetterAuthOptions, A as Adapter } from '../auth-BfbTouIV.js';
1
+ import { B as BetterAuthOptions, A as Adapter } from '../auth-C42JqOR9.js';
2
2
  import 'zod';
3
3
  import 'kysely';
4
4
  import 'better-call';
package/dist/api.d.cts CHANGED
@@ -1,6 +1,6 @@
1
- export { h as AuthEndpoint, i as AuthMiddleware, aD as callbackOAuth, a_ as changeEmail, aW as changePassword, g as createAuthEndpoint, f as createAuthMiddleware, aR as createEmailVerificationToken, aY as deleteUser, aZ as deleteUserCallback, a$ as error, aO as forgetPassword, aP as forgetPasswordCallback, aI as freshSessionMiddleware, az as getEndpoints, aE as getSession, aF as getSessionFromCtx, b3 as linkSocialAccount, aJ as listSessions, b2 as listUserAccounts, b0 as ok, o as optionsMiddleware, b6 as originCheck, b5 as originCheckMiddleware, aH as requestOnlySessionMiddleware, aQ as resetPassword, aM as revokeOtherSessions, aK as revokeSession, aL as revokeSessions, aA as router, aT as sendVerificationEmail, aS as sendVerificationEmailFn, aG as sessionMiddleware, aX as setPassword, aC as signInEmail, aB as signInSocial, aN as signOut, b1 as signUpEmail, b4 as unlinkAccount, aV as updateUser, aU as verifyEmail } from './auth-CC4kpwks.cjs';
2
- import './helper-Bi8FQwDD.cjs';
3
1
  export { APIError } from 'better-call';
2
+ export { h as AuthEndpoint, i as AuthMiddleware, aD as callbackOAuth, a_ as changeEmail, aW as changePassword, g as createAuthEndpoint, f as createAuthMiddleware, aR as createEmailVerificationToken, aY as deleteUser, aZ as deleteUserCallback, a$ as error, aO as forgetPassword, aP as forgetPasswordCallback, aI as freshSessionMiddleware, az as getEndpoints, aE as getSession, aF as getSessionFromCtx, b3 as linkSocialAccount, aJ as listSessions, b2 as listUserAccounts, b0 as ok, o as optionsMiddleware, b6 as originCheck, b5 as originCheckMiddleware, aH as requestOnlySessionMiddleware, aQ as resetPassword, aM as revokeOtherSessions, aK as revokeSession, aL as revokeSessions, aA as router, aT as sendVerificationEmail, aS as sendVerificationEmailFn, aG as sessionMiddleware, aX as setPassword, aC as signInEmail, aB as signInSocial, aN as signOut, b1 as signUpEmail, b4 as unlinkAccount, aV as updateUser, aU as verifyEmail } from './auth-BLwS7t0V.cjs';
3
+ import './helper-Bi8FQwDD.cjs';
4
4
  import 'zod';
5
5
  import 'kysely';
6
6
  import './index-BuRgaJZR.cjs';
package/dist/api.d.ts CHANGED
@@ -1,6 +1,6 @@
1
- export { h as AuthEndpoint, i as AuthMiddleware, aD as callbackOAuth, a_ as changeEmail, aW as changePassword, g as createAuthEndpoint, f as createAuthMiddleware, aR as createEmailVerificationToken, aY as deleteUser, aZ as deleteUserCallback, a$ as error, aO as forgetPassword, aP as forgetPasswordCallback, aI as freshSessionMiddleware, az as getEndpoints, aE as getSession, aF as getSessionFromCtx, b3 as linkSocialAccount, aJ as listSessions, b2 as listUserAccounts, b0 as ok, o as optionsMiddleware, b6 as originCheck, b5 as originCheckMiddleware, aH as requestOnlySessionMiddleware, aQ as resetPassword, aM as revokeOtherSessions, aK as revokeSession, aL as revokeSessions, aA as router, aT as sendVerificationEmail, aS as sendVerificationEmailFn, aG as sessionMiddleware, aX as setPassword, aC as signInEmail, aB as signInSocial, aN as signOut, b1 as signUpEmail, b4 as unlinkAccount, aV as updateUser, aU as verifyEmail } from './auth-BfbTouIV.js';
2
- import './helper-Bi8FQwDD.js';
3
1
  export { APIError } from 'better-call';
2
+ export { h as AuthEndpoint, i as AuthMiddleware, aD as callbackOAuth, a_ as changeEmail, aW as changePassword, g as createAuthEndpoint, f as createAuthMiddleware, aR as createEmailVerificationToken, aY as deleteUser, aZ as deleteUserCallback, a$ as error, aO as forgetPassword, aP as forgetPasswordCallback, aI as freshSessionMiddleware, az as getEndpoints, aE as getSession, aF as getSessionFromCtx, b3 as linkSocialAccount, aJ as listSessions, b2 as listUserAccounts, b0 as ok, o as optionsMiddleware, b6 as originCheck, b5 as originCheckMiddleware, aH as requestOnlySessionMiddleware, aQ as resetPassword, aM as revokeOtherSessions, aK as revokeSession, aL as revokeSessions, aA as router, aT as sendVerificationEmail, aS as sendVerificationEmailFn, aG as sessionMiddleware, aX as setPassword, aC as signInEmail, aB as signInSocial, aN as signOut, b1 as signUpEmail, b4 as unlinkAccount, aV as updateUser, aU as verifyEmail } from './auth-C42JqOR9.js';
3
+ import './helper-Bi8FQwDD.js';
4
4
  import 'zod';
5
5
  import 'kysely';
6
6
  import './index-moQjyfmm.js';