payload-auth 1.5.0 → 1.6.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 (52) hide show
  1. package/dist/better-auth/plugin/lib/build-collections/index.d.ts.map +1 -1
  2. package/dist/better-auth/plugin/lib/build-collections/index.js +3 -1
  3. package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts +1 -1
  4. package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts.map +1 -1
  5. package/dist/better-auth/plugin/lib/build-collections/passkeys.js +16 -3
  6. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.d.ts +0 -1
  7. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.d.ts.map +1 -1
  8. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.js +1 -2
  9. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts +1 -1
  10. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts.map +1 -1
  11. package/dist/better-auth/plugin/lib/build-collections/users/index.js +32 -10
  12. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts.map +1 -1
  13. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js +11 -3
  14. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.d.ts +10 -0
  15. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.d.ts.map +1 -0
  16. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.js +62 -0
  17. package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts +7 -0
  18. package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts.map +1 -0
  19. package/dist/better-auth/plugin/payload/components/passkeys/add-button.js +120 -0
  20. package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts +4 -0
  21. package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts.map +1 -0
  22. package/dist/better-auth/plugin/payload/components/passkeys/client.js +59 -0
  23. package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts +5 -0
  24. package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts.map +1 -0
  25. package/dist/better-auth/plugin/payload/components/passkeys/index.js +40 -0
  26. package/dist/better-auth/plugin/payload/components/passkeys/index.scss +91 -0
  27. package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts +9 -0
  28. package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts.map +1 -0
  29. package/dist/better-auth/plugin/payload/components/passkeys/list.js +57 -0
  30. package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts +20 -0
  31. package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts.map +1 -0
  32. package/dist/better-auth/plugin/payload/components/passkeys/types.js +3 -0
  33. package/dist/better-auth/plugin/payload/exports/rsc.d.ts +2 -1
  34. package/dist/better-auth/plugin/payload/exports/rsc.d.ts.map +1 -1
  35. package/dist/better-auth/plugin/payload/exports/rsc.js +3 -2
  36. package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts +1 -0
  37. package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts.map +1 -1
  38. package/dist/better-auth/plugin/payload/views/admin-login/client.js +11 -7
  39. package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts.map +1 -1
  40. package/dist/better-auth/plugin/payload/views/admin-login/index.js +3 -1
  41. package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts.map +1 -1
  42. package/dist/better-auth/plugin/payload/views/admin-signup/client.js +29 -28
  43. package/dist/better-auth/plugin/types.d.ts +2 -0
  44. package/dist/better-auth/plugin/types.d.ts.map +1 -1
  45. package/dist/better-auth/plugin/types.js +1 -1
  46. package/dist/shared/form/validation.d.ts +1 -3
  47. package/dist/shared/form/validation.d.ts.map +1 -1
  48. package/dist/shared/form/validation.js +3 -3
  49. package/package.json +1 -1
  50. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/signup.d.ts +0 -4
  51. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/signup.d.ts.map +0 -1
  52. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/signup.js +0 -157
@@ -10,10 +10,10 @@ export const emailField = ({ t, required = true })=>{
10
10
  message: t('authentication:emailNotValid') || 'Email is not valid'
11
11
  });
12
12
  };
13
- export const usernameField = ({ t, required = true, minLength = 5, maxLength = 128 })=>{
13
+ export const usernameField = ({ t, required = true })=>{
14
14
  let schema = z.string();
15
15
  if (required) schema = schema.min(1, t('validation:required'));
16
- return schema.refine((val)=>usernameRegex.test(val) && val.length >= minLength && val.length <= maxLength, {
16
+ return schema.refine((val)=>usernameRegex.test(val), {
17
17
  message: t('authentication:usernameNotValid') || 'Username is not valid'
18
18
  });
19
19
  };
@@ -113,4 +113,4 @@ export const createSignupSchema = ({ t, requireUsername = false, requireConfirmP
113
113
  });
114
114
  };
115
115
 
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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"}
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 = ({ 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) => usernameRegex.test(val), {\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","passwordField","minLength","confirmPasswordField","passwordWithConfirmation","object","password","confirmPassword","data","path","isValidEmail","isValidUsername","maxLength","length","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.5.0",
3
+ "version": "1.6.0",
4
4
  "main": "./dist/index.js",
5
5
  "module": "./dist/index.mjs",
6
6
  "types": "./dist/index.d.ts",
@@ -1,4 +0,0 @@
1
- import { BetterAuthPluginOptions } from '@/better-auth/plugin/types';
2
- import { type Endpoint } from 'payload';
3
- export declare const getSignupEndpoint: (pluginOptions: BetterAuthPluginOptions) => Endpoint;
4
- //# sourceMappingURL=signup.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"signup.d.ts","sourceRoot":"","sources":["../../../../../../../src/better-auth/plugin/lib/build-collections/users/endpoints/signup.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AAEpE,OAAO,EAAgF,KAAK,QAAQ,EAAE,MAAM,SAAS,CAAA;AAuBrH,eAAO,MAAM,iBAAiB,GAAI,eAAe,uBAAuB,KAAG,QAkI1E,CAAA"}
@@ -1,157 +0,0 @@
1
- import { adminEndpoints, baseSlugs, supportedBAPluginIds } from "../../../../constants";
2
- import { status as httpStatus } from "http-status";
3
- import { addDataAndFileToRequest, commitTransaction, initTransaction, killTransaction } from "payload";
4
- import { z } from "zod";
5
- import { getRequestCollection } from "../../../../helpers/get-requst-collection";
6
- import { createSignupSchema } from "../../../../../../shared/form/validation";
7
- import { checkPluginExists } from "../../../../helpers/check-plugin-exists";
8
- const sendJSON = (data, status)=>new Response(JSON.stringify(data), {
9
- headers: {
10
- 'Content-Type': 'application/json'
11
- },
12
- status
13
- });
14
- const forwardCookies = (from, to)=>{
15
- const setCookieHeader = from.headers.get('set-cookie');
16
- if (!setCookieHeader) return;
17
- setCookieHeader.split(',').forEach((c)=>to.headers.append('Set-Cookie', c.trim()));
18
- };
19
- const routeParamsSchema = z.object({
20
- token: z.string(),
21
- redirect: z.string().optional()
22
- });
23
- export const getSignupEndpoint = (pluginOptions)=>{
24
- const { betterAuthOptions = {}, adminInvitations, users } = pluginOptions;
25
- const { baseURL = '', basePath = '/api/auth', emailVerification, emailAndPassword } = betterAuthOptions;
26
- if (!baseURL) {
27
- throw new Error('betterAuthOptions.baseURL is required for server‑side authentication calls');
28
- }
29
- const adminInvitationsSlug = adminInvitations?.slug ?? baseSlugs.adminInvitations;
30
- const usersSlug = users?.slug ?? baseSlugs.users;
31
- const endpoint = {
32
- path: adminEndpoints.signup,
33
- method: 'post',
34
- handler: async (req)=>{
35
- await addDataAndFileToRequest(req);
36
- const collection = getRequestCollection(req);
37
- const { t } = req;
38
- const shouldCommit = await initTransaction(req);
39
- try {
40
- const { success: routeParamsSuccess, data: routeParamsData, error: routeParamsError } = routeParamsSchema.safeParse(req.query);
41
- if (!routeParamsSuccess) {
42
- await killTransaction(req);
43
- return sendJSON({
44
- error: 'INVALID_PARAMS',
45
- message: routeParamsError.message
46
- }, httpStatus.BAD_REQUEST);
47
- }
48
- const inviteResult = await req.payload.find({
49
- collection: adminInvitationsSlug,
50
- where: {
51
- token: {
52
- equals: routeParamsData.token
53
- }
54
- },
55
- limit: 1,
56
- req
57
- });
58
- const inviteDoc = inviteResult.docs.at(0);
59
- if (!inviteDoc) {
60
- await killTransaction(req);
61
- return sendJSON({
62
- error: 'INVALID_TOKEN',
63
- message: 'Invalid token'
64
- }, httpStatus.UNAUTHORIZED);
65
- }
66
- const hasUsernamePlugin = checkPluginExists(betterAuthOptions, supportedBAPluginIds.username);
67
- const supportsLoginWithUsername = hasUsernamePlugin && collection.config?.auth?.loginWithUsername;
68
- const requireUsername = hasUsernamePlugin && typeof collection.config?.auth?.loginWithUsername === 'object' && !!collection.config?.auth?.loginWithUsername?.requireUsername;
69
- const signupSchema = createSignupSchema({
70
- t,
71
- requireUsername,
72
- requireConfirmPassword: false
73
- });
74
- const parsedBody = signupSchema.safeParse(req.data);
75
- if (!parsedBody.success) {
76
- await killTransaction(req);
77
- const messages = parsedBody.error.issues.map((issue)=>issue.message);
78
- return sendJSON({
79
- error: {
80
- message: messages
81
- }
82
- }, httpStatus.BAD_REQUEST);
83
- }
84
- const { name, email, password, username } = parsedBody.data;
85
- const authApiURL = `${baseURL}${basePath}`;
86
- const url = new URL(`${authApiURL}/sign-up/email`);
87
- url.searchParams.set('callbackURL', routeParamsData.redirect ?? `${baseURL}${req.payload.config.routes.admin}`);
88
- if (routeParamsData.token) {
89
- url.searchParams.set('adminInviteToken', routeParamsData.token);
90
- }
91
- const apiResponse = await fetch(url.toString(), {
92
- method: 'POST',
93
- headers: {
94
- 'Content-Type': 'application/json'
95
- },
96
- body: JSON.stringify({
97
- name,
98
- email,
99
- password,
100
- ...supportsLoginWithUsername && username && {
101
- username
102
- }
103
- })
104
- });
105
- if (!apiResponse.ok) {
106
- throw new Error(apiResponse.statusText);
107
- }
108
- const responseData = await apiResponse.json();
109
- await req.payload.update({
110
- collection: usersSlug,
111
- id: responseData.user.id,
112
- data: {
113
- role: inviteDoc.role
114
- },
115
- overrideAccess: true,
116
- req
117
- });
118
- await req.payload.delete({
119
- collection: adminInvitationsSlug,
120
- where: {
121
- token: {
122
- equals: inviteDoc.token
123
- }
124
- },
125
- req
126
- });
127
- const requireEmailVerification = (emailAndPassword?.requireEmailVerification || collection.config.auth.verify) && !responseData.user.emailVerified;
128
- const sentEmailVerification = emailVerification?.sendVerificationEmail !== undefined;
129
- if (requireEmailVerification) {
130
- const res = sendJSON({
131
- message: t('authentication:verifyYourEmail'),
132
- sentEmailVerification,
133
- requireEmailVerification
134
- }, httpStatus.UNAUTHORIZED);
135
- forwardCookies(apiResponse, res);
136
- if (shouldCommit) await commitTransaction(req);
137
- return res;
138
- }
139
- const successRes = sendJSON({
140
- message: t('authentication:passed'),
141
- ...responseData
142
- }, httpStatus.OK);
143
- forwardCookies(apiResponse, successRes);
144
- if (shouldCommit) await commitTransaction(req);
145
- return successRes;
146
- } catch (error) {
147
- await killTransaction(req);
148
- return sendJSON({
149
- message: error.message
150
- }, httpStatus.INTERNAL_SERVER_ERROR);
151
- }
152
- }
153
- };
154
- return endpoint;
155
- };
156
-
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../../src/better-auth/plugin/lib/build-collections/users/endpoints/signup.ts"],"sourcesContent":["import { adminEndpoints, baseSlugs, supportedBAPluginIds } from '@/better-auth/plugin/constants'\nimport { BetterAuthPluginOptions } from '@/better-auth/plugin/types'\nimport { status as httpStatus } from 'http-status'\nimport { addDataAndFileToRequest, commitTransaction, initTransaction, killTransaction, type Endpoint } from 'payload'\nimport { z } from 'zod'\nimport { getRequestCollection } from '../../../../helpers/get-requst-collection'\nimport { createSignupSchema } from '@/shared/form/validation'\nimport { checkPluginExists } from '@/better-auth/plugin/helpers/check-plugin-exists'\n\nconst sendJSON = (data: unknown, status: number): Response =>\n  new Response(JSON.stringify(data), {\n    headers: { 'Content-Type': 'application/json' },\n    status\n  })\n\nconst forwardCookies = (from: Response, to: Response): void => {\n  const setCookieHeader = from.headers.get('set-cookie')\n  if (!setCookieHeader) return\n  setCookieHeader.split(',').forEach((c) => to.headers.append('Set-Cookie', c.trim()))\n}\n\nconst routeParamsSchema = z.object({\n  token: z.string(),\n  redirect: z.string().optional()\n})\n\nexport const getSignupEndpoint = (pluginOptions: BetterAuthPluginOptions): Endpoint => {\n  const { betterAuthOptions = {}, adminInvitations, users } = pluginOptions\n  const { baseURL = '', basePath = '/api/auth', emailVerification, emailAndPassword } = betterAuthOptions\n\n  if (!baseURL) {\n    throw new Error('betterAuthOptions.baseURL is required for server‑side authentication calls')\n  }\n\n  const adminInvitationsSlug = adminInvitations?.slug ?? baseSlugs.adminInvitations\n  const usersSlug = users?.slug ?? baseSlugs.users\n\n  const endpoint: Endpoint = {\n    path: adminEndpoints.signup,\n    method: 'post',\n    handler: async (req) => {\n      await addDataAndFileToRequest(req)\n      const collection = getRequestCollection(req)\n      const { t } = req\n\n      const shouldCommit = await initTransaction(req)\n\n      try {\n        const { success: routeParamsSuccess, data: routeParamsData, error: routeParamsError } = routeParamsSchema.safeParse(req.query)\n\n        if (!routeParamsSuccess) {\n          await killTransaction(req)\n          return sendJSON({ error: 'INVALID_PARAMS', message: routeParamsError.message }, httpStatus.BAD_REQUEST)\n        }\n\n        const inviteResult = await req.payload.find({\n          collection: adminInvitationsSlug,\n          where: { token: { equals: routeParamsData.token } },\n          limit: 1,\n          req\n        })\n\n        const inviteDoc = inviteResult.docs.at(0)\n\n        if (!inviteDoc) {\n          await killTransaction(req)\n          return sendJSON({ error: 'INVALID_TOKEN', message: 'Invalid token' }, httpStatus.UNAUTHORIZED)\n        }\n\n        const hasUsernamePlugin = checkPluginExists(betterAuthOptions, supportedBAPluginIds.username)\n        const supportsLoginWithUsername = hasUsernamePlugin && collection.config?.auth?.loginWithUsername\n        const requireUsername =\n          hasUsernamePlugin &&\n          typeof collection.config?.auth?.loginWithUsername === 'object' &&\n          !!collection.config?.auth?.loginWithUsername?.requireUsername\n\n        const signupSchema = createSignupSchema({ t, requireUsername, requireConfirmPassword: false })\n        const parsedBody = signupSchema.safeParse(req.data)\n\n        if (!parsedBody.success) {\n          await killTransaction(req)\n          const messages = parsedBody.error.issues.map((issue) => issue.message)\n          return sendJSON({ error: { message: messages } }, httpStatus.BAD_REQUEST)\n        }\n\n        const { name, email, password, username } = parsedBody.data\n\n        const authApiURL = `${baseURL}${basePath}`\n        const url = new URL(`${authApiURL}/sign-up/email`)\n        url.searchParams.set('callbackURL', routeParamsData.redirect ?? `${baseURL}${req.payload.config.routes.admin}`)\n        if (routeParamsData.token) {\n          url.searchParams.set('adminInviteToken', routeParamsData.token)\n        }\n\n        const apiResponse = await fetch(url.toString(), {\n          method: 'POST',\n          headers: { 'Content-Type': 'application/json' },\n          body: JSON.stringify({\n            name,\n            email,\n            password,\n            ...(supportsLoginWithUsername && username && { username })\n          })\n        })\n\n        if (!apiResponse.ok) {\n          throw new Error(apiResponse.statusText)\n        }\n\n        const responseData = await apiResponse.json()\n\n        await req.payload.update({\n          collection: usersSlug,\n          id: responseData.user.id,\n          data: { role: inviteDoc.role },\n          overrideAccess: true,\n          req\n        })\n\n        await req.payload.delete({\n          collection: adminInvitationsSlug,\n          where: { token: { equals: inviteDoc.token } },\n          req\n        })\n\n        const requireEmailVerification =\n          (emailAndPassword?.requireEmailVerification || collection.config.auth.verify) && !responseData.user.emailVerified\n\n        const sentEmailVerification = emailVerification?.sendVerificationEmail !== undefined\n\n        if (requireEmailVerification) {\n          const res = sendJSON(\n            {\n              message: t('authentication:verifyYourEmail'),\n              sentEmailVerification,\n              requireEmailVerification\n            },\n            httpStatus.UNAUTHORIZED\n          )\n          forwardCookies(apiResponse, res)\n          if (shouldCommit) await commitTransaction(req)\n          return res\n        }\n\n        const successRes = sendJSON({ message: t('authentication:passed'), ...responseData }, httpStatus.OK)\n        forwardCookies(apiResponse, successRes)\n        if (shouldCommit) await commitTransaction(req)\n        return successRes\n      } catch (error: any) {\n        await killTransaction(req)\n        return sendJSON({ message: error.message }, httpStatus.INTERNAL_SERVER_ERROR)\n      }\n    }\n  }\n\n  return endpoint\n}\n"],"names":["adminEndpoints","baseSlugs","supportedBAPluginIds","status","httpStatus","addDataAndFileToRequest","commitTransaction","initTransaction","killTransaction","z","getRequestCollection","createSignupSchema","checkPluginExists","sendJSON","data","Response","JSON","stringify","headers","forwardCookies","from","to","setCookieHeader","get","split","forEach","c","append","trim","routeParamsSchema","object","token","string","redirect","optional","getSignupEndpoint","pluginOptions","betterAuthOptions","adminInvitations","users","baseURL","basePath","emailVerification","emailAndPassword","Error","adminInvitationsSlug","slug","usersSlug","endpoint","path","signup","method","handler","req","collection","t","shouldCommit","success","routeParamsSuccess","routeParamsData","error","routeParamsError","safeParse","query","message","BAD_REQUEST","inviteResult","payload","find","where","equals","limit","inviteDoc","docs","at","UNAUTHORIZED","hasUsernamePlugin","username","supportsLoginWithUsername","config","auth","loginWithUsername","requireUsername","signupSchema","requireConfirmPassword","parsedBody","messages","issues","map","issue","name","email","password","authApiURL","url","URL","searchParams","set","routes","admin","apiResponse","fetch","toString","body","ok","statusText","responseData","json","update","id","user","role","overrideAccess","delete","requireEmailVerification","verify","emailVerified","sentEmailVerification","sendVerificationEmail","undefined","res","successRes","OK","INTERNAL_SERVER_ERROR"],"mappings":"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"}