payload-auth 1.3.4 → 1.4.1
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.
- package/dist/better-auth/adapter/index.d.ts +10 -0
- package/dist/better-auth/adapter/index.d.ts.map +1 -1
- package/dist/better-auth/adapter/index.js +151 -125
- package/dist/better-auth/adapter/transform/index.d.ts +2 -4
- package/dist/better-auth/adapter/transform/index.d.ts.map +1 -1
- package/dist/better-auth/adapter/transform/index.js +433 -309
- package/dist/better-auth/plugin/constants.d.ts +2 -0
- package/dist/better-auth/plugin/constants.d.ts.map +1 -1
- package/dist/better-auth/plugin/constants.js +4 -2
- package/dist/better-auth/plugin/helpers/check-passkey-plugin.d.ts.map +1 -1
- package/dist/better-auth/plugin/helpers/check-passkey-plugin.js +3 -2
- package/dist/better-auth/plugin/helpers/check-two-factor-plugin.d.ts +3 -0
- package/dist/better-auth/plugin/helpers/check-two-factor-plugin.d.ts.map +1 -0
- package/dist/better-auth/plugin/helpers/check-two-factor-plugin.js +6 -0
- package/dist/better-auth/plugin/helpers/check-username-plugin.d.ts.map +1 -1
- package/dist/better-auth/plugin/helpers/check-username-plugin.js +3 -2
- package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts +52 -6
- package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts.map +1 -1
- package/dist/better-auth/plugin/helpers/prepare-session-data.js +52 -35
- package/dist/better-auth/plugin/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/index.js +16 -2
- package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/sessions.js +3 -1
- package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.js +2 -2
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js +6 -4
- package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/users/index.js +7 -2
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js +16 -14
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.js +344 -0
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.scss +113 -0
- package/dist/better-auth/plugin/payload/exports/client.d.ts +2 -1
- package/dist/better-auth/plugin/payload/exports/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/exports/client.js +3 -2
- package/dist/better-auth/plugin/payload/exports/rsc.d.ts +2 -1
- package/dist/better-auth/plugin/payload/exports/rsc.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/exports/rsc.js +3 -2
- package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-login/client.js +14 -5
- package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-login/index.js +1 -3
- package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts +5 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/client.js +77 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts +10 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/index.js +44 -0
- package/dist/shared/form/components/submit.js +3 -1
- package/dist/shared/utils/value-or-default.d.ts +10 -0
- package/dist/shared/utils/value-or-default.d.ts.map +1 -0
- package/dist/shared/utils/value-or-default.js +12 -0
- package/package.json +13 -7
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
export declare const socialProviders: readonly ["apple", "discord", "facebook", "github", "google", "linkedin", "microsoft", "spotify", "tiktok", "twitter", "twitch", "zoom", "gitlab", "roblox", "vk", "kick", "reddit"];
|
|
2
2
|
export declare const loginMethods: readonly ["emailPassword", "magicLink", "emailOTP", "phonePassword", "phoneOTP", "phoneMagicLink", "passkey", "apple", "discord", "facebook", "github", "google", "linkedin", "microsoft", "spotify", "tiktok", "twitter", "twitch", "zoom", "gitlab", "roblox", "vk", "kick", "reddit"];
|
|
3
3
|
export declare const supportedBetterAuthPluginIds: {
|
|
4
|
+
readonly customSession: "custom-session";
|
|
4
5
|
readonly harmonyEmail: "harmony-email";
|
|
5
6
|
readonly harmonyPhoneNumber: "harmony-phone-number";
|
|
6
7
|
readonly twoFactor: "two-factor";
|
|
@@ -49,6 +50,7 @@ export declare const adminRoutes: {
|
|
|
49
50
|
readonly adminSignup: "/signup";
|
|
50
51
|
readonly adminLogin: "/login";
|
|
51
52
|
readonly loginRedirect: "/login-redirect";
|
|
53
|
+
readonly twoFactorVerify: "/two-factor-verify";
|
|
52
54
|
};
|
|
53
55
|
export declare const adminEndpoints: {
|
|
54
56
|
readonly setAdminRole: "/set-admin-role";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,eAAe,sLAkBlB,CAAA;AAEV,eAAO,MAAM,YAAY,0RASf,CAAA;AAEV,eAAO,MAAM,4BAA4B
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,eAAe,sLAkBlB,CAAA;AAEV,eAAO,MAAM,YAAY,0RASf,CAAA;AAEV,eAAO,MAAM,4BAA4B;;;;;;;;;;;;;;;;;;;;;;CAsB/B,CAAA;AAEV,eAAO,MAAM,mBAAmB;;;;;;CAMtB,CAAA;AAEV,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;CAaxB,CAAA;AAEV,eAAO,MAAM,WAAW;;;;;;;CAOd,CAAA;AAEV,eAAO,MAAM,cAAc;;;;;;CAMjB,CAAA;AAEV,eAAO,MAAM,QAAQ;;CAEX,CAAA"}
|
|
@@ -28,6 +28,7 @@ export const loginMethods = [
|
|
|
28
28
|
...socialProviders
|
|
29
29
|
];
|
|
30
30
|
export const supportedBetterAuthPluginIds = {
|
|
31
|
+
customSession: 'custom-session',
|
|
31
32
|
harmonyEmail: 'harmony-email',
|
|
32
33
|
harmonyPhoneNumber: 'harmony-phone-number',
|
|
33
34
|
twoFactor: 'two-factor',
|
|
@@ -75,7 +76,8 @@ export const adminRoutes = {
|
|
|
75
76
|
resetPassword: '/reset-password',
|
|
76
77
|
adminSignup: '/signup',
|
|
77
78
|
adminLogin: '/login',
|
|
78
|
-
loginRedirect: '/login-redirect'
|
|
79
|
+
loginRedirect: '/login-redirect',
|
|
80
|
+
twoFactorVerify: '/two-factor-verify'
|
|
79
81
|
};
|
|
80
82
|
export const adminEndpoints = {
|
|
81
83
|
setAdminRole: '/set-admin-role',
|
|
@@ -88,4 +90,4 @@ export const defaults = {
|
|
|
88
90
|
adminRole: 'admin'
|
|
89
91
|
};
|
|
90
92
|
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vY29uc3RhbnRzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBzb2NpYWxQcm92aWRlcnMgPSBbXG4gICdhcHBsZScsXG4gICdkaXNjb3JkJyxcbiAgJ2ZhY2Vib29rJyxcbiAgJ2dpdGh1YicsXG4gICdnb29nbGUnLFxuICAnbGlua2VkaW4nLFxuICAnbWljcm9zb2Z0JyxcbiAgJ3Nwb3RpZnknLFxuICAndGlrdG9rJyxcbiAgJ3R3aXR0ZXInLFxuICAndHdpdGNoJyxcbiAgJ3pvb20nLFxuICAnZ2l0bGFiJyxcbiAgJ3JvYmxveCcsXG4gICd2aycsXG4gICdraWNrJyxcbiAgJ3JlZGRpdCdcbl0gYXMgY29uc3RcblxuZXhwb3J0IGNvbnN0IGxvZ2luTWV0aG9kcyA9IFtcbiAgJ2VtYWlsUGFzc3dvcmQnLFxuICAnbWFnaWNMaW5rJyxcbiAgJ2VtYWlsT1RQJyxcbiAgJ3Bob25lUGFzc3dvcmQnLFxuICAncGhvbmVPVFAnLFxuICAncGhvbmVNYWdpY0xpbmsnLFxuICAncGFzc2tleScsXG4gIC4uLnNvY2lhbFByb3ZpZGVyc1xuXSBhcyBjb25zdFxuXG5leHBvcnQgY29uc3Qgc3VwcG9ydGVkQmV0dGVyQXV0aFBsdWdpbklkcyA9IHtcbiAgY3VzdG9tU2Vzc2lvbjogJ2N1c3RvbS1zZXNzaW9uJyxcbiAgaGFybW9ueUVtYWlsOiAnaGFybW9ueS1lbWFpbCcsXG4gIGhhcm1vbnlQaG9uZU51bWJlcjogJ2hhcm1vbnktcGhvbmUtbnVtYmVyJyxcbiAgdHdvRmFjdG9yOiAndHdvLWZhY3RvcicsXG4gIHVzZXJuYW1lOiAndXNlcm5hbWUnLFxuICBhbm9ueW1vdXM6ICdhbm9ueW1vdXMnLFxuICBwaG9uZU51bWJlcjogJ3Bob25lLW51bWJlcicsXG4gIG1hZ2ljTGluazogJ21hZ2ljLWxpbmsnLFxuICBlbWFpbE90cDogJ2VtYWlsLW90cCcsXG4gIHBhc3NrZXk6ICdwYXNza2V5JyxcbiAgb25lVGFwOiAnb25lLXRhcCcsXG4gIGFkbWluOiAnYWRtaW4nLFxuICBhcGlLZXk6ICdhcGkta2V5JyxcbiAgb3JnYW5pemF0aW9uOiAnb3JnYW5pemF0aW9uJyxcbiAgbXVsdGlTZXNzaW9uOiAnbXVsdGktc2Vzc2lvbicsXG4gIG9wZW5BcGk6ICdvcGVuLWFwaScsXG4gIGp3dDogJ2p3dCcsXG4gIG5leHRDb29raWVzOiAnbmV4dC1jb29raWVzJyxcbiAgc3NvOiAnc3NvJyxcbiAgb2lkYzogJ29pZGMnLFxuICBleHBvOiAnZXhwbydcbn0gYXMgY29uc3RcblxuZXhwb3J0IGNvbnN0IGJhc2VDb2xsZWN0aW9uU2x1Z3MgPSB7XG4gIHVzZXJzOiAndXNlcnMnLFxuICBzZXNzaW9uczogJ3Nlc3Npb25zJyxcbiAgYWNjb3VudHM6ICdhY2NvdW50cycsXG4gIHZlcmlmaWNhdGlvbnM6ICd2ZXJpZmljYXRpb25zJyxcbiAgYWRtaW5JbnZpdGF0aW9uczogJ2FkbWluLWludml0YXRpb25zJ1xufSBhcyBjb25zdFxuXG5leHBvcnQgY29uc3QgYmV0dGVyQXV0aFBsdWdpblNsdWdzID0ge1xuICBhcGlLZXlzOiAnYXBpS2V5cycsXG4gIGp3a3M6ICdqd2tzJyxcbiAgdHdvRmFjdG9yczogJ3R3b0ZhY3RvcnMnLFxuICBwYXNza2V5czogJ3Bhc3NrZXlzJyxcbiAgb2F1dGhBcHBsaWNhdGlvbnM6ICdvYXV0aEFwcGxpY2F0aW9ucycsXG4gIG9hdXRoQWNjZXNzVG9rZW5zOiAnb2F1dGhBY2Nlc3NUb2tlbnMnLFxuICBvYXV0aENvbnNlbnRzOiAnb2F1dGhDb25zZW50cycsXG4gIHNzb1Byb3ZpZGVyczogJ3Nzb1Byb3ZpZGVycycsXG4gIG9yZ2FuaXphdGlvbnM6ICdvcmdhbml6YXRpb25zJyxcbiAgaW52aXRhdGlvbnM6ICdpbnZpdGF0aW9ucycsXG4gIG1lbWJlcnM6ICdtZW1iZXJzJyxcbiAgdGVhbXM6ICd0ZWFtcydcbn0gYXMgY29uc3RcblxuZXhwb3J0IGNvbnN0IGFkbWluUm91dGVzID0ge1xuICBmb3Jnb3RQYXNzd29yZDogJy9mb3Jnb3QtcGFzc3dvcmQnLFxuICByZXNldFBhc3N3b3JkOiAnL3Jlc2V0LXBhc3N3b3JkJyxcbiAgYWRtaW5TaWdudXA6ICcvc2lnbnVwJyxcbiAgYWRtaW5Mb2dpbjogJy9sb2dpbicsXG4gIGxvZ2luUmVkaXJlY3Q6ICcvbG9naW4tcmVkaXJlY3QnLFxuICB0d29GYWN0b3JWZXJpZnk6ICcvdHdvLWZhY3Rvci12ZXJpZnknXG59IGFzIGNvbnN0XG5cbmV4cG9ydCBjb25zdCBhZG1pbkVuZHBvaW50cyA9IHtcbiAgc2V0QWRtaW5Sb2xlOiAnL3NldC1hZG1pbi1yb2xlJyxcbiAgcmVmcmVzaFRva2VuOiAnL3JlZnJlc2gtdG9rZW4nLFxuICBzZW5kSW52aXRlOiAnL3NlbmQtaW52aXRlJyxcbiAgZ2VuZXJhdGVJbnZpdGVVcmw6ICcvZ2VuZXJhdGUtaW52aXRlLXVybCcsXG4gIHNpZ251cDogJy9zaWdudXAnXG59IGFzIGNvbnN0XG5cbmV4cG9ydCBjb25zdCBkZWZhdWx0cyA9IHtcbiAgYWRtaW5Sb2xlOiAnYWRtaW4nXG59IGFzIGNvbnN0XG4iXSwibmFtZXMiOlsic29jaWFsUHJvdmlkZXJzIiwibG9naW5NZXRob2RzIiwic3VwcG9ydGVkQmV0dGVyQXV0aFBsdWdpbklkcyIsImN1c3RvbVNlc3Npb24iLCJoYXJtb255RW1haWwiLCJoYXJtb255UGhvbmVOdW1iZXIiLCJ0d29GYWN0b3IiLCJ1c2VybmFtZSIsImFub255bW91cyIsInBob25lTnVtYmVyIiwibWFnaWNMaW5rIiwiZW1haWxPdHAiLCJwYXNza2V5Iiwib25lVGFwIiwiYWRtaW4iLCJhcGlLZXkiLCJvcmdhbml6YXRpb24iLCJtdWx0aVNlc3Npb24iLCJvcGVuQXBpIiwiand0IiwibmV4dENvb2tpZXMiLCJzc28iLCJvaWRjIiwiZXhwbyIsImJhc2VDb2xsZWN0aW9uU2x1Z3MiLCJ1c2VycyIsInNlc3Npb25zIiwiYWNjb3VudHMiLCJ2ZXJpZmljYXRpb25zIiwiYWRtaW5JbnZpdGF0aW9ucyIsImJldHRlckF1dGhQbHVnaW5TbHVncyIsImFwaUtleXMiLCJqd2tzIiwidHdvRmFjdG9ycyIsInBhc3NrZXlzIiwib2F1dGhBcHBsaWNhdGlvbnMiLCJvYXV0aEFjY2Vzc1Rva2VucyIsIm9hdXRoQ29uc2VudHMiLCJzc29Qcm92aWRlcnMiLCJvcmdhbml6YXRpb25zIiwiaW52aXRhdGlvbnMiLCJtZW1iZXJzIiwidGVhbXMiLCJhZG1pblJvdXRlcyIsImZvcmdvdFBhc3N3b3JkIiwicmVzZXRQYXNzd29yZCIsImFkbWluU2lnbnVwIiwiYWRtaW5Mb2dpbiIsImxvZ2luUmVkaXJlY3QiLCJ0d29GYWN0b3JWZXJpZnkiLCJhZG1pbkVuZHBvaW50cyIsInNldEFkbWluUm9sZSIsInJlZnJlc2hUb2tlbiIsInNlbmRJbnZpdGUiLCJnZW5lcmF0ZUludml0ZVVybCIsInNpZ251cCIsImRlZmF1bHRzIiwiYWRtaW5Sb2xlIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU1BLGtCQUFrQjtJQUM3QjtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtJQUNBO0NBQ0QsQ0FBUztBQUVWLE9BQU8sTUFBTUMsZUFBZTtJQUMxQjtJQUNBO0lBQ0E7SUFDQTtJQUNBO0lBQ0E7SUFDQTtPQUNHRDtDQUNKLENBQVM7QUFFVixPQUFPLE1BQU1FLCtCQUErQjtJQUMxQ0MsZUFBZTtJQUNmQyxjQUFjO0lBQ2RDLG9CQUFvQjtJQUNwQkMsV0FBVztJQUNYQyxVQUFVO0lBQ1ZDLFdBQVc7SUFDWEMsYUFBYTtJQUNiQyxXQUFXO0lBQ1hDLFVBQVU7SUFDVkMsU0FBUztJQUNUQyxRQUFRO0lBQ1JDLE9BQU87SUFDUEMsUUFBUTtJQUNSQyxjQUFjO0lBQ2RDLGNBQWM7SUFDZEMsU0FBUztJQUNUQyxLQUFLO0lBQ0xDLGFBQWE7SUFDYkMsS0FBSztJQUNMQyxNQUFNO0lBQ05DLE1BQU07QUFDUixFQUFVO0FBRVYsT0FBTyxNQUFNQyxzQkFBc0I7SUFDakNDLE9BQU87SUFDUEMsVUFBVTtJQUNWQyxVQUFVO0lBQ1ZDLGVBQWU7SUFDZkMsa0JBQWtCO0FBQ3BCLEVBQVU7QUFFVixPQUFPLE1BQU1DLHdCQUF3QjtJQUNuQ0MsU0FBUztJQUNUQyxNQUFNO0lBQ05DLFlBQVk7SUFDWkMsVUFBVTtJQUNWQyxtQkFBbUI7SUFDbkJDLG1CQUFtQjtJQUNuQkMsZUFBZTtJQUNmQyxjQUFjO0lBQ2RDLGVBQWU7SUFDZkMsYUFBYTtJQUNiQyxTQUFTO0lBQ1RDLE9BQU87QUFDVCxFQUFVO0FBRVYsT0FBTyxNQUFNQyxjQUFjO0lBQ3pCQyxnQkFBZ0I7SUFDaEJDLGVBQWU7SUFDZkMsYUFBYTtJQUNiQyxZQUFZO0lBQ1pDLGVBQWU7SUFDZkMsaUJBQWlCO0FBQ25CLEVBQVU7QUFFVixPQUFPLE1BQU1DLGlCQUFpQjtJQUM1QkMsY0FBYztJQUNkQyxjQUFjO0lBQ2RDLFlBQVk7SUFDWkMsbUJBQW1CO0lBQ25CQyxRQUFRO0FBQ1YsRUFBVTtBQUVWLE9BQU8sTUFBTUMsV0FBVztJQUN0QkMsV0FBVztBQUNiLEVBQVUifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-passkey-plugin.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/check-passkey-plugin.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"check-passkey-plugin.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/check-passkey-plugin.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,UAAU,CAAA;AAE1D,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,0BAA0B,WAErE"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { supportedBetterAuthPluginIds } from "../constants";
|
|
1
2
|
export function checkPasskeyPlugin(options) {
|
|
2
|
-
return options.plugins?.some((plugin)=>plugin.id ===
|
|
3
|
+
return options.plugins?.some((plugin)=>plugin.id === supportedBetterAuthPluginIds.passkey) || false;
|
|
3
4
|
}
|
|
4
5
|
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9jaGVjay1wYXNza2V5LXBsdWdpbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzdXBwb3J0ZWRCZXR0ZXJBdXRoUGx1Z2luSWRzIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRCZXR0ZXJBdXRoT3B0aW9ucyB9IGZyb20gJy4uL3R5cGVzJ1xuXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tQYXNza2V5UGx1Z2luKG9wdGlvbnM6IFNhbml0aXplZEJldHRlckF1dGhPcHRpb25zKSB7XG4gIHJldHVybiBvcHRpb25zLnBsdWdpbnM/LnNvbWUoKHBsdWdpbikgPT4gcGx1Z2luLmlkID09PSBzdXBwb3J0ZWRCZXR0ZXJBdXRoUGx1Z2luSWRzLnBhc3NrZXkpIHx8IGZhbHNlXG59XG4iXSwibmFtZXMiOlsic3VwcG9ydGVkQmV0dGVyQXV0aFBsdWdpbklkcyIsImNoZWNrUGFzc2tleVBsdWdpbiIsIm9wdGlvbnMiLCJwbHVnaW5zIiwic29tZSIsInBsdWdpbiIsImlkIiwicGFzc2tleSJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsNEJBQTRCLFFBQVEsZUFBYztBQUczRCxPQUFPLFNBQVNDLG1CQUFtQkMsT0FBbUM7SUFDcEUsT0FBT0EsUUFBUUMsT0FBTyxFQUFFQyxLQUFLLENBQUNDLFNBQVdBLE9BQU9DLEVBQUUsS0FBS04sNkJBQTZCTyxPQUFPLEtBQUs7QUFDbEcifQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"check-two-factor-plugin.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/check-two-factor-plugin.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,UAAU,CAAA;AAE1D,wBAAgB,oBAAoB,CAAC,OAAO,EAAE,0BAA0B,WAEvE"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { supportedBetterAuthPluginIds } from "../constants";
|
|
2
|
+
export function checkTwoFactorPlugin(options) {
|
|
3
|
+
return options.plugins?.some((plugin)=>plugin.id === supportedBetterAuthPluginIds.twoFactor) || false;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9jaGVjay10d28tZmFjdG9yLXBsdWdpbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBzdXBwb3J0ZWRCZXR0ZXJBdXRoUGx1Z2luSWRzIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRCZXR0ZXJBdXRoT3B0aW9ucyB9IGZyb20gJy4uL3R5cGVzJ1xuXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tUd29GYWN0b3JQbHVnaW4ob3B0aW9uczogU2FuaXRpemVkQmV0dGVyQXV0aE9wdGlvbnMpIHtcbiAgcmV0dXJuIG9wdGlvbnMucGx1Z2lucz8uc29tZSgocGx1Z2luKSA9PiBwbHVnaW4uaWQgPT09IHN1cHBvcnRlZEJldHRlckF1dGhQbHVnaW5JZHMudHdvRmFjdG9yKSB8fCBmYWxzZVxufVxuIl0sIm5hbWVzIjpbInN1cHBvcnRlZEJldHRlckF1dGhQbHVnaW5JZHMiLCJjaGVja1R3b0ZhY3RvclBsdWdpbiIsIm9wdGlvbnMiLCJwbHVnaW5zIiwic29tZSIsInBsdWdpbiIsImlkIiwidHdvRmFjdG9yIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSw0QkFBNEIsUUFBUSxlQUFjO0FBRzNELE9BQU8sU0FBU0MscUJBQXFCQyxPQUFtQztJQUN0RSxPQUFPQSxRQUFRQyxPQUFPLEVBQUVDLEtBQUssQ0FBQ0MsU0FBV0EsT0FBT0MsRUFBRSxLQUFLTiw2QkFBNkJPLFNBQVMsS0FBSztBQUNwRyJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-username-plugin.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/check-username-plugin.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"check-username-plugin.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/check-username-plugin.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,UAAU,CAAA;AAE1D,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,0BAA0B,WAEtE"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { supportedBetterAuthPluginIds } from "../constants";
|
|
1
2
|
export function checkUsernamePlugin(options) {
|
|
2
|
-
return options.plugins?.some((plugin)=>plugin.id ===
|
|
3
|
+
return options.plugins?.some((plugin)=>plugin.id === supportedBetterAuthPluginIds.username) || false;
|
|
3
4
|
}
|
|
4
5
|
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9jaGVjay11c2VybmFtZS1wbHVnaW4udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYmV0dGVyQXV0aFBsdWdpblNsdWdzLCBzdXBwb3J0ZWRCZXR0ZXJBdXRoUGx1Z2luSWRzIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHR5cGUgeyBTYW5pdGl6ZWRCZXR0ZXJBdXRoT3B0aW9ucyB9IGZyb20gJy4uL3R5cGVzJ1xuXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tVc2VybmFtZVBsdWdpbihvcHRpb25zOiBTYW5pdGl6ZWRCZXR0ZXJBdXRoT3B0aW9ucykge1xuICByZXR1cm4gb3B0aW9ucy5wbHVnaW5zPy5zb21lKChwbHVnaW4pID0+IHBsdWdpbi5pZCA9PT0gc3VwcG9ydGVkQmV0dGVyQXV0aFBsdWdpbklkcy51c2VybmFtZSkgfHwgZmFsc2Vcbn1cbiJdLCJuYW1lcyI6WyJzdXBwb3J0ZWRCZXR0ZXJBdXRoUGx1Z2luSWRzIiwiY2hlY2tVc2VybmFtZVBsdWdpbiIsIm9wdGlvbnMiLCJwbHVnaW5zIiwic29tZSIsInBsdWdpbiIsImlkIiwidXNlcm5hbWUiXSwibWFwcGluZ3MiOiJBQUFBLFNBQWdDQSw0QkFBNEIsUUFBUSxlQUFjO0FBR2xGLE9BQU8sU0FBU0Msb0JBQW9CQyxPQUFtQztJQUNyRSxPQUFPQSxRQUFRQyxPQUFPLEVBQUVDLEtBQUssQ0FBQ0MsU0FBV0EsT0FBT0MsRUFBRSxLQUFLTiw2QkFBNkJPLFFBQVEsS0FBSztBQUNuRyJ9
|
|
@@ -1,22 +1,68 @@
|
|
|
1
|
+
import { Session, User } from 'better-auth';
|
|
1
2
|
import type { Config, Payload } from 'payload';
|
|
2
3
|
type CollectionSlugs = {
|
|
3
4
|
userCollectionSlug: string;
|
|
4
5
|
sessionCollectionSlug: string;
|
|
5
6
|
};
|
|
7
|
+
export declare function prepareUser({ user, payloadConfig, collectionSlugs }: {
|
|
8
|
+
user: User & Record<string, any>;
|
|
9
|
+
payloadConfig: Payload['config'] | Config | Promise<Payload['config'] | Config>;
|
|
10
|
+
collectionSlugs: CollectionSlugs;
|
|
11
|
+
}): Promise<{
|
|
12
|
+
id: string;
|
|
13
|
+
name: string;
|
|
14
|
+
email: string;
|
|
15
|
+
emailVerified: boolean;
|
|
16
|
+
createdAt: Date;
|
|
17
|
+
updatedAt: Date;
|
|
18
|
+
image?: string | null | undefined;
|
|
19
|
+
} & Record<string, any>>;
|
|
20
|
+
export declare function prepareSession({ user, session, payloadConfig, collectionSlugs }: {
|
|
21
|
+
user: User & Record<string, any>;
|
|
22
|
+
session: Session & Record<string, any>;
|
|
23
|
+
payloadConfig: Payload['config'] | Config | Promise<Payload['config'] | Config>;
|
|
24
|
+
collectionSlugs: CollectionSlugs;
|
|
25
|
+
}): Promise<{
|
|
26
|
+
id: string;
|
|
27
|
+
createdAt: Date;
|
|
28
|
+
updatedAt: Date;
|
|
29
|
+
userId: string;
|
|
30
|
+
expiresAt: Date;
|
|
31
|
+
token: string;
|
|
32
|
+
ipAddress?: string | null | undefined;
|
|
33
|
+
userAgent?: string | null | undefined;
|
|
34
|
+
} & Record<string, any>>;
|
|
6
35
|
/**
|
|
7
36
|
* Prepares session data for cookie cache by filtering user and session objects
|
|
8
37
|
* based on the payload configuration's 'saveToJwt' property
|
|
9
38
|
*/
|
|
10
|
-
export declare function prepareSessionData({
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
39
|
+
export declare function prepareSessionData({ sessionData, payloadConfig, collectionSlugs }: {
|
|
40
|
+
sessionData: {
|
|
41
|
+
session: Session & Record<string, any>;
|
|
42
|
+
user: User & Record<string, any>;
|
|
14
43
|
};
|
|
15
44
|
payloadConfig: Payload['config'] | Config | Promise<Payload['config'] | Config>;
|
|
16
45
|
collectionSlugs: CollectionSlugs;
|
|
17
46
|
}): Promise<{
|
|
18
|
-
|
|
19
|
-
|
|
47
|
+
session: {
|
|
48
|
+
id: string;
|
|
49
|
+
createdAt: Date;
|
|
50
|
+
updatedAt: Date;
|
|
51
|
+
userId: string;
|
|
52
|
+
expiresAt: Date;
|
|
53
|
+
token: string;
|
|
54
|
+
ipAddress?: string | null | undefined;
|
|
55
|
+
userAgent?: string | null | undefined;
|
|
56
|
+
} & Record<string, any>;
|
|
57
|
+
user: {
|
|
58
|
+
id: string;
|
|
59
|
+
name: string;
|
|
60
|
+
email: string;
|
|
61
|
+
emailVerified: boolean;
|
|
62
|
+
createdAt: Date;
|
|
63
|
+
updatedAt: Date;
|
|
64
|
+
image?: string | null | undefined;
|
|
65
|
+
} & Record<string, any>;
|
|
20
66
|
} | null>;
|
|
21
67
|
export {};
|
|
22
68
|
//# sourceMappingURL=prepare-session-data.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepare-session-data.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/prepare-session-data.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"prepare-session-data.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/prepare-session-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAE3C,OAAO,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAE9C,KAAK,eAAe,GAAG;IACrB,kBAAkB,EAAE,MAAM,CAAA;IAC1B,qBAAqB,EAAE,MAAM,CAAA;CAC9B,CAAA;AAED,wBAAsB,WAAW,CAAC,EAChC,IAAI,EACJ,aAAa,EACb,eAAe,EAChB,EAAE;IACD,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAChC,aAAa,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAC,CAAA;IAC/E,eAAe,EAAE,eAAe,CAAA;CACjC;;;;;;;;yBAiBA;AAED,wBAAsB,cAAc,CAAC,EACnC,IAAI,EACJ,OAAO,EACP,aAAa,EACb,eAAe,EAChB,EAAE;IACD,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IAChC,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IACtC,aAAa,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAC,CAAA;IAC/E,eAAe,EAAE,eAAe,CAAA;CACjC;;;;;;;;;yBAuBA;AAED;;;GAGG;AACH,wBAAsB,kBAAkB,CAAC,EACvC,WAAW,EACX,aAAa,EACb,eAAe,EAChB,EAAE;IACD,WAAW,EAAE;QACX,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;QACtC,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;KACjC,CAAA;IACD,aAAa,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAC,CAAA;IAC/E,eAAe,EAAE,eAAe,CAAA;CACjC;;;;;;;;;;;;;;;;;;;;UAYA"}
|
|
@@ -1,43 +1,60 @@
|
|
|
1
1
|
import { getFieldsToSign } from "payload";
|
|
2
|
-
|
|
3
|
-
* Prepares session data for cookie cache by filtering user and session objects
|
|
4
|
-
* based on the payload configuration's 'saveToJwt' property
|
|
5
|
-
*/ export async function prepareSessionData({ newSession, payloadConfig, collectionSlugs }) {
|
|
6
|
-
if (!newSession || !newSession.user) {
|
|
7
|
-
return null;
|
|
8
|
-
}
|
|
2
|
+
export async function prepareUser({ user, payloadConfig, collectionSlugs }) {
|
|
9
3
|
const awaitedPayloadConfig = await payloadConfig;
|
|
10
|
-
const { userCollectionSlug
|
|
4
|
+
const { userCollectionSlug } = collectionSlugs;
|
|
11
5
|
const userCollection = awaitedPayloadConfig?.collections?.find((c)=>c.slug === userCollectionSlug);
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
throw new Error(`User collection with slug '${userCollectionSlug}' not found`);
|
|
15
|
-
}
|
|
16
|
-
const filteredUser = getFieldsToSign({
|
|
6
|
+
if (!userCollection) throw new Error(`User collection with slug '${userCollectionSlug}' not found`);
|
|
7
|
+
const newUser = getFieldsToSign({
|
|
17
8
|
collectionConfig: userCollection,
|
|
18
|
-
email:
|
|
19
|
-
user:
|
|
9
|
+
email: user.email,
|
|
10
|
+
user: {
|
|
11
|
+
...user,
|
|
12
|
+
collection: userCollectionSlug
|
|
13
|
+
}
|
|
14
|
+
});
|
|
15
|
+
return newUser;
|
|
16
|
+
}
|
|
17
|
+
export async function prepareSession({ user, session, payloadConfig, collectionSlugs }) {
|
|
18
|
+
const awaitedPayloadConfig = await payloadConfig;
|
|
19
|
+
const { sessionCollectionSlug, userCollectionSlug } = collectionSlugs;
|
|
20
|
+
const sessionCollection = awaitedPayloadConfig?.collections?.find((c)=>c.slug === sessionCollectionSlug);
|
|
21
|
+
if (!sessionCollection) return session;
|
|
22
|
+
const filteredSession = getFieldsToSign({
|
|
23
|
+
collectionConfig: sessionCollection,
|
|
24
|
+
email: user.email,
|
|
25
|
+
user: {
|
|
26
|
+
...session,
|
|
27
|
+
collection: sessionCollectionSlug
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
delete filteredSession.email;
|
|
31
|
+
delete filteredSession.collection;
|
|
32
|
+
Object.assign(filteredSession, {
|
|
33
|
+
userId: session.userId
|
|
34
|
+
});
|
|
35
|
+
return filteredSession;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Prepares session data for cookie cache by filtering user and session objects
|
|
39
|
+
* based on the payload configuration's 'saveToJwt' property
|
|
40
|
+
*/ export async function prepareSessionData({ sessionData, payloadConfig, collectionSlugs }) {
|
|
41
|
+
if (!sessionData || !sessionData.user) return null;
|
|
42
|
+
const newUser = await prepareUser({
|
|
43
|
+
user: sessionData.user,
|
|
44
|
+
payloadConfig,
|
|
45
|
+
collectionSlugs
|
|
46
|
+
});
|
|
47
|
+
const newSession = await prepareSession({
|
|
48
|
+
user: sessionData.user,
|
|
49
|
+
session: sessionData.session,
|
|
50
|
+
payloadConfig,
|
|
51
|
+
collectionSlugs
|
|
20
52
|
});
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
filteredSession = getFieldsToSign({
|
|
25
|
-
collectionConfig: sessionCollection,
|
|
26
|
-
email: newSession.user.email,
|
|
27
|
-
user: newSession.session
|
|
28
|
-
});
|
|
29
|
-
// getFieldsToSign is meant for auth collections so we remove the email and collection fields
|
|
30
|
-
delete filteredSession.email;
|
|
31
|
-
delete filteredSession.collection;
|
|
32
|
-
}
|
|
33
|
-
if (isImpersonated) {
|
|
34
|
-
filteredSession.impersonatedBy = newSession.session.impersonatedBy;
|
|
35
|
-
}
|
|
36
|
-
return {
|
|
37
|
-
...newSession,
|
|
38
|
-
user: filteredUser,
|
|
39
|
-
session: filteredSession
|
|
53
|
+
const newSessionData = {
|
|
54
|
+
session: newSession,
|
|
55
|
+
user: newUser
|
|
40
56
|
};
|
|
57
|
+
return newSessionData;
|
|
41
58
|
}
|
|
42
59
|
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9wcmVwYXJlLXNlc3Npb24tZGF0YS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZXNzaW9uLCBVc2VyIH0gZnJvbSAnYmV0dGVyLWF1dGgnXG5pbXBvcnQgeyBnZXRGaWVsZHNUb1NpZ24gfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBDb25maWcsIFBheWxvYWQgfSBmcm9tICdwYXlsb2FkJ1xuXG50eXBlIENvbGxlY3Rpb25TbHVncyA9IHtcbiAgdXNlckNvbGxlY3Rpb25TbHVnOiBzdHJpbmdcbiAgc2Vzc2lvbkNvbGxlY3Rpb25TbHVnOiBzdHJpbmdcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHByZXBhcmVVc2VyKHtcbiAgdXNlcixcbiAgcGF5bG9hZENvbmZpZyxcbiAgY29sbGVjdGlvblNsdWdzXG59OiB7XG4gIHVzZXI6IFVzZXIgJiBSZWNvcmQ8c3RyaW5nLCBhbnk+XG4gIHBheWxvYWRDb25maWc6IFBheWxvYWRbJ2NvbmZpZyddIHwgQ29uZmlnIHwgUHJvbWlzZTxQYXlsb2FkWydjb25maWcnXSB8IENvbmZpZz5cbiAgY29sbGVjdGlvblNsdWdzOiBDb2xsZWN0aW9uU2x1Z3Ncbn0pIHtcbiAgY29uc3QgYXdhaXRlZFBheWxvYWRDb25maWcgPSBhd2FpdCBwYXlsb2FkQ29uZmlnXG4gIGNvbnN0IHsgdXNlckNvbGxlY3Rpb25TbHVnIH0gPSBjb2xsZWN0aW9uU2x1Z3NcbiAgY29uc3QgdXNlckNvbGxlY3Rpb24gPSBhd2FpdGVkUGF5bG9hZENvbmZpZz8uY29sbGVjdGlvbnM/LmZpbmQoKGMpID0+IGMuc2x1ZyA9PT0gdXNlckNvbGxlY3Rpb25TbHVnKVxuXG4gIGlmICghdXNlckNvbGxlY3Rpb24pIHRocm93IG5ldyBFcnJvcihgVXNlciBjb2xsZWN0aW9uIHdpdGggc2x1ZyAnJHt1c2VyQ29sbGVjdGlvblNsdWd9JyBub3QgZm91bmRgKVxuXG4gIGNvbnN0IG5ld1VzZXIgPSBnZXRGaWVsZHNUb1NpZ24oe1xuICAgIGNvbGxlY3Rpb25Db25maWc6IHVzZXJDb2xsZWN0aW9uLFxuICAgIGVtYWlsOiB1c2VyLmVtYWlsLFxuICAgIHVzZXI6IHtcbiAgICAgIC4uLnVzZXIsXG4gICAgICBjb2xsZWN0aW9uOiB1c2VyQ29sbGVjdGlvblNsdWdcbiAgICB9XG4gIH0pXG5cbiAgcmV0dXJuIG5ld1VzZXIgYXMgVXNlciAmIFJlY29yZDxzdHJpbmcsIGFueT5cbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHByZXBhcmVTZXNzaW9uKHtcbiAgdXNlcixcbiAgc2Vzc2lvbixcbiAgcGF5bG9hZENvbmZpZyxcbiAgY29sbGVjdGlvblNsdWdzXG59OiB7XG4gIHVzZXI6IFVzZXIgJiBSZWNvcmQ8c3RyaW5nLCBhbnk+XG4gIHNlc3Npb246IFNlc3Npb24gJiBSZWNvcmQ8c3RyaW5nLCBhbnk+XG4gIHBheWxvYWRDb25maWc6IFBheWxvYWRbJ2NvbmZpZyddIHwgQ29uZmlnIHwgUHJvbWlzZTxQYXlsb2FkWydjb25maWcnXSB8IENvbmZpZz5cbiAgY29sbGVjdGlvblNsdWdzOiBDb2xsZWN0aW9uU2x1Z3Ncbn0pIHtcbiAgY29uc3QgYXdhaXRlZFBheWxvYWRDb25maWcgPSBhd2FpdCBwYXlsb2FkQ29uZmlnXG4gIGNvbnN0IHsgc2Vzc2lvbkNvbGxlY3Rpb25TbHVnLCB1c2VyQ29sbGVjdGlvblNsdWcgfSA9IGNvbGxlY3Rpb25TbHVnc1xuICBjb25zdCBzZXNzaW9uQ29sbGVjdGlvbiA9IGF3YWl0ZWRQYXlsb2FkQ29uZmlnPy5jb2xsZWN0aW9ucz8uZmluZCgoYykgPT4gYy5zbHVnID09PSBzZXNzaW9uQ29sbGVjdGlvblNsdWcpXG5cbiAgaWYgKCFzZXNzaW9uQ29sbGVjdGlvbikgcmV0dXJuIHNlc3Npb25cblxuICBjb25zdCBmaWx0ZXJlZFNlc3Npb24gPSBnZXRGaWVsZHNUb1NpZ24oe1xuICAgIGNvbGxlY3Rpb25Db25maWc6IHNlc3Npb25Db2xsZWN0aW9uLFxuICAgIGVtYWlsOiB1c2VyLmVtYWlsLFxuICAgIHVzZXI6IHtcbiAgICAgIC4uLnNlc3Npb24sXG4gICAgICBjb2xsZWN0aW9uOiBzZXNzaW9uQ29sbGVjdGlvblNsdWdcbiAgICB9XG4gIH0pXG5cbiAgZGVsZXRlIGZpbHRlcmVkU2Vzc2lvbi5lbWFpbFxuICBkZWxldGUgZmlsdGVyZWRTZXNzaW9uLmNvbGxlY3Rpb25cbiAgT2JqZWN0LmFzc2lnbihmaWx0ZXJlZFNlc3Npb24sIHtcbiAgICB1c2VySWQ6IHNlc3Npb24udXNlcklkXG4gIH0pXG5cbiAgcmV0dXJuIGZpbHRlcmVkU2Vzc2lvbiBhcyBTZXNzaW9uICYgUmVjb3JkPHN0cmluZywgYW55PlxufVxuXG4vKipcbiAqIFByZXBhcmVzIHNlc3Npb24gZGF0YSBmb3IgY29va2llIGNhY2hlIGJ5IGZpbHRlcmluZyB1c2VyIGFuZCBzZXNzaW9uIG9iamVjdHNcbiAqIGJhc2VkIG9uIHRoZSBwYXlsb2FkIGNvbmZpZ3VyYXRpb24ncyAnc2F2ZVRvSnd0JyBwcm9wZXJ0eVxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcHJlcGFyZVNlc3Npb25EYXRhKHtcbiAgc2Vzc2lvbkRhdGEsXG4gIHBheWxvYWRDb25maWcsXG4gIGNvbGxlY3Rpb25TbHVnc1xufToge1xuICBzZXNzaW9uRGF0YToge1xuICAgIHNlc3Npb246IFNlc3Npb24gJiBSZWNvcmQ8c3RyaW5nLCBhbnk+XG4gICAgdXNlcjogVXNlciAmIFJlY29yZDxzdHJpbmcsIGFueT5cbiAgfVxuICBwYXlsb2FkQ29uZmlnOiBQYXlsb2FkWydjb25maWcnXSB8IENvbmZpZyB8IFByb21pc2U8UGF5bG9hZFsnY29uZmlnJ10gfCBDb25maWc+XG4gIGNvbGxlY3Rpb25TbHVnczogQ29sbGVjdGlvblNsdWdzXG59KSB7XG4gIGlmICghc2Vzc2lvbkRhdGEgfHwgIXNlc3Npb25EYXRhLnVzZXIpIHJldHVybiBudWxsXG5cbiAgY29uc3QgbmV3VXNlciA9IGF3YWl0IHByZXBhcmVVc2VyKHsgdXNlcjogc2Vzc2lvbkRhdGEudXNlciwgcGF5bG9hZENvbmZpZywgY29sbGVjdGlvblNsdWdzIH0pXG4gIGNvbnN0IG5ld1Nlc3Npb24gPSBhd2FpdCBwcmVwYXJlU2Vzc2lvbih7IHVzZXI6IHNlc3Npb25EYXRhLnVzZXIsIHNlc3Npb246IHNlc3Npb25EYXRhLnNlc3Npb24sIHBheWxvYWRDb25maWcsIGNvbGxlY3Rpb25TbHVncyB9KVxuXG4gIGNvbnN0IG5ld1Nlc3Npb25EYXRhID0ge1xuICAgIHNlc3Npb246IG5ld1Nlc3Npb24sXG4gICAgdXNlcjogbmV3VXNlclxuICB9XG5cbiAgcmV0dXJuIG5ld1Nlc3Npb25EYXRhXG59XG4iXSwibmFtZXMiOlsiZ2V0RmllbGRzVG9TaWduIiwicHJlcGFyZVVzZXIiLCJ1c2VyIiwicGF5bG9hZENvbmZpZyIsImNvbGxlY3Rpb25TbHVncyIsImF3YWl0ZWRQYXlsb2FkQ29uZmlnIiwidXNlckNvbGxlY3Rpb25TbHVnIiwidXNlckNvbGxlY3Rpb24iLCJjb2xsZWN0aW9ucyIsImZpbmQiLCJjIiwic2x1ZyIsIkVycm9yIiwibmV3VXNlciIsImNvbGxlY3Rpb25Db25maWciLCJlbWFpbCIsImNvbGxlY3Rpb24iLCJwcmVwYXJlU2Vzc2lvbiIsInNlc3Npb24iLCJzZXNzaW9uQ29sbGVjdGlvblNsdWciLCJzZXNzaW9uQ29sbGVjdGlvbiIsImZpbHRlcmVkU2Vzc2lvbiIsIk9iamVjdCIsImFzc2lnbiIsInVzZXJJZCIsInByZXBhcmVTZXNzaW9uRGF0YSIsInNlc3Npb25EYXRhIiwibmV3U2Vzc2lvbiIsIm5ld1Nlc3Npb25EYXRhIl0sIm1hcHBpbmdzIjoiQUFDQSxTQUFTQSxlQUFlLFFBQVEsVUFBUztBQVF6QyxPQUFPLGVBQWVDLFlBQVksRUFDaENDLElBQUksRUFDSkMsYUFBYSxFQUNiQyxlQUFlLEVBS2hCO0lBQ0MsTUFBTUMsdUJBQXVCLE1BQU1GO0lBQ25DLE1BQU0sRUFBRUcsa0JBQWtCLEVBQUUsR0FBR0Y7SUFDL0IsTUFBTUcsaUJBQWlCRixzQkFBc0JHLGFBQWFDLEtBQUssQ0FBQ0MsSUFBTUEsRUFBRUMsSUFBSSxLQUFLTDtJQUVqRixJQUFJLENBQUNDLGdCQUFnQixNQUFNLElBQUlLLE1BQU0sQ0FBQywyQkFBMkIsRUFBRU4sbUJBQW1CLFdBQVcsQ0FBQztJQUVsRyxNQUFNTyxVQUFVYixnQkFBZ0I7UUFDOUJjLGtCQUFrQlA7UUFDbEJRLE9BQU9iLEtBQUthLEtBQUs7UUFDakJiLE1BQU07WUFDSixHQUFHQSxJQUFJO1lBQ1BjLFlBQVlWO1FBQ2Q7SUFDRjtJQUVBLE9BQU9PO0FBQ1Q7QUFFQSxPQUFPLGVBQWVJLGVBQWUsRUFDbkNmLElBQUksRUFDSmdCLE9BQU8sRUFDUGYsYUFBYSxFQUNiQyxlQUFlLEVBTWhCO0lBQ0MsTUFBTUMsdUJBQXVCLE1BQU1GO0lBQ25DLE1BQU0sRUFBRWdCLHFCQUFxQixFQUFFYixrQkFBa0IsRUFBRSxHQUFHRjtJQUN0RCxNQUFNZ0Isb0JBQW9CZixzQkFBc0JHLGFBQWFDLEtBQUssQ0FBQ0MsSUFBTUEsRUFBRUMsSUFBSSxLQUFLUTtJQUVwRixJQUFJLENBQUNDLG1CQUFtQixPQUFPRjtJQUUvQixNQUFNRyxrQkFBa0JyQixnQkFBZ0I7UUFDdENjLGtCQUFrQk07UUFDbEJMLE9BQU9iLEtBQUthLEtBQUs7UUFDakJiLE1BQU07WUFDSixHQUFHZ0IsT0FBTztZQUNWRixZQUFZRztRQUNkO0lBQ0Y7SUFFQSxPQUFPRSxnQkFBZ0JOLEtBQUs7SUFDNUIsT0FBT00sZ0JBQWdCTCxVQUFVO0lBQ2pDTSxPQUFPQyxNQUFNLENBQUNGLGlCQUFpQjtRQUM3QkcsUUFBUU4sUUFBUU0sTUFBTTtJQUN4QjtJQUVBLE9BQU9IO0FBQ1Q7QUFFQTs7O0NBR0MsR0FDRCxPQUFPLGVBQWVJLG1CQUFtQixFQUN2Q0MsV0FBVyxFQUNYdkIsYUFBYSxFQUNiQyxlQUFlLEVBUWhCO0lBQ0MsSUFBSSxDQUFDc0IsZUFBZSxDQUFDQSxZQUFZeEIsSUFBSSxFQUFFLE9BQU87SUFFOUMsTUFBTVcsVUFBVSxNQUFNWixZQUFZO1FBQUVDLE1BQU13QixZQUFZeEIsSUFBSTtRQUFFQztRQUFlQztJQUFnQjtJQUMzRixNQUFNdUIsYUFBYSxNQUFNVixlQUFlO1FBQUVmLE1BQU13QixZQUFZeEIsSUFBSTtRQUFFZ0IsU0FBU1EsWUFBWVIsT0FBTztRQUFFZjtRQUFlQztJQUFnQjtJQUUvSCxNQUFNd0IsaUJBQWlCO1FBQ3JCVixTQUFTUztRQUNUekIsTUFBTVc7SUFDUjtJQUVBLE9BQU9lO0FBQ1QifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AACrC,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AACrC,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAA;AAStD,OAAO,EAAE,yBAAyB,EAAE,MAAM,0CAA0C,CAAA;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACvD,cAAc,SAAS,CAAA;AACvB,cAAc,iBAAiB,CAAA;AAE/B,wBAAgB,gBAAgB,CAAC,aAAa,EAAE,uBAAuB,IAC7D,QAAQ,MAAM,KAAG,MAAM,CAqJhC"}
|
|
@@ -2,8 +2,9 @@ import { sanitizeBetterAuthOptions } from "./lib/sanitize-better-auth-options/in
|
|
|
2
2
|
import { getRequiredCollectionSlugs } from "./lib/get-required-collection-slugs";
|
|
3
3
|
import { buildCollections } from "./lib/build-collections/index";
|
|
4
4
|
import { initBetterAuth } from "./lib/init-better-auth";
|
|
5
|
-
import { adminRoutes } from "./constants";
|
|
5
|
+
import { adminRoutes, baseCollectionSlugs, supportedBetterAuthPluginIds } from "./constants";
|
|
6
6
|
import { setLoginMethods } from "./lib/set-login-methods";
|
|
7
|
+
import { checkTwoFactorPlugin } from "./helpers/check-two-factor-plugin";
|
|
7
8
|
export { sanitizeBetterAuthOptions } from "./lib/sanitize-better-auth-options/index";
|
|
8
9
|
export { getPayloadAuth } from "./lib/get-payload-auth";
|
|
9
10
|
export * from "./types";
|
|
@@ -80,6 +81,19 @@ export function betterAuthPlugin(pluginOptions) {
|
|
|
80
81
|
Component: {
|
|
81
82
|
path: 'payload-auth/better-auth/plugin/rsc#ResetPassword'
|
|
82
83
|
}
|
|
84
|
+
},
|
|
85
|
+
...checkTwoFactorPlugin(betterAuthOptions) && {
|
|
86
|
+
twoFactorVerify: {
|
|
87
|
+
path: adminRoutes.twoFactorVerify,
|
|
88
|
+
Component: {
|
|
89
|
+
path: 'payload-auth/better-auth/plugin/rsc#TwoFactorVerify',
|
|
90
|
+
serverProps: {
|
|
91
|
+
payloadConfig: config,
|
|
92
|
+
twoFactorOptions: betterAuthOptions.plugins?.find((plugin)=>plugin.id === supportedBetterAuthPluginIds.twoFactor)?.options ?? {},
|
|
93
|
+
verificationSlug: pluginOptions.verifications?.slug ?? baseCollectionSlugs.verifications
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
83
97
|
}
|
|
84
98
|
}
|
|
85
99
|
},
|
|
@@ -139,4 +153,4 @@ export function betterAuthPlugin(pluginOptions) {
|
|
|
139
153
|
};
|
|
140
154
|
}
|
|
141
155
|
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/better-auth/plugin/index.ts"],"sourcesContent":["import type { Config } from 'payload'\nimport type { BetterAuthPluginOptions } from './types'\nimport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nimport { getRequiredCollectionSlugs } from './lib/get-required-collection-slugs'\nimport { buildCollections } from './lib/build-collections/index'\nimport { initBetterAuth } from './lib/init-better-auth'\nimport { adminRoutes } from './constants'\nimport { setLoginMethods } from './lib/set-login-methods'\n\nexport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nexport { getPayloadAuth } from './lib/get-payload-auth'\nexport * from './types'\nexport * from './helpers/index'\n\nexport function betterAuthPlugin(pluginOptions: BetterAuthPluginOptions) {\n  return (config: Config): Config => {\n    if (pluginOptions.disabled) {\n      return config\n    }\n\n    const betterAuthOptions = sanitizeBetterAuthOptions({\n      config,\n      options: pluginOptions\n    })\n\n    config.custom = {\n      ...config.custom,\n      hasBetterAuthPlugin: true\n    }\n\n    pluginOptions = setLoginMethods({ pluginOptions })\n\n    // Set custom admin components if disableDefaultPayloadAuth is true\n    if (pluginOptions.disableDefaultPayloadAuth) {\n      config.admin = {\n        ...config.admin,\n        components: {\n          ...config.admin?.components,\n          afterLogin: [\n            {\n              path: 'payload-auth/better-auth/plugin/rsc#RSCRedirect',\n              serverProps: {\n                redirectTo: `${config.routes?.admin === undefined ? '/admin' : config.routes.admin}${adminRoutes.adminLogin}`\n              }\n            },\n            ...(config.admin?.components?.afterLogin || [])\n          ],\n          logout: {\n            Button: {\n              path: 'payload-auth/better-auth/plugin/client#LogoutButton'\n            }\n          },\n          views: {\n            ...config.admin?.components?.views,\n            adminLogin: {\n              path: adminRoutes.adminLogin,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#AdminLogin',\n                serverProps: {\n                  pluginOptions: pluginOptions,\n                  betterAuthOptions: betterAuthOptions\n                }\n              }\n            },\n            adminSignup: {\n              path: adminRoutes.adminSignup,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#AdminSignup',\n                serverProps: {\n                  pluginOptions: pluginOptions,\n                  betterAuthOptions: betterAuthOptions\n                }\n              }\n            },\n            forgotPassword: {\n              path: adminRoutes.forgotPassword,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#ForgotPassword',\n                serverProps: {\n                  betterAuthOptions: betterAuthOptions\n                }\n              }\n            },\n            resetPassword: {\n              path: adminRoutes.resetPassword,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#ResetPassword'\n              }\n            }\n          }\n        },\n        routes: {\n          ...config.admin?.routes,\n          login: adminRoutes.loginRedirect\n        }\n      }\n    }\n\n    // Determine which collections to add based on the options and plugins\n    const requiredCollectionSlugs = getRequiredCollectionSlugs({\n      logTables: pluginOptions.debug?.logTables ?? false,\n      pluginOptions,\n      betterAuthOptions\n    })\n\n    if (!config.collections) {\n      config.collections = []\n    }\n\n    // Update with the required collections + existing collections\n    config.collections = buildCollections({\n      incomingCollections: config.collections ?? [],\n      requiredCollectionSlugs,\n      pluginOptions,\n      betterAuthOptions\n    })\n\n    const incomingOnInit = config.onInit\n\n    config.onInit = async (payload) => {\n      try {\n        // Execute any existing onInit functions first\n        if (incomingOnInit) {\n          await incomingOnInit(payload)\n        }\n\n        // Initialize and set the betterAuth instance\n        const auth = initBetterAuth<NonNullable<typeof betterAuthOptions.plugins>>({\n          payload,\n          idType: payload.db.defaultIDType,\n          options: {\n            ...betterAuthOptions,\n            enableDebugLogs: pluginOptions.debug?.enableDebugLogs ?? false,\n            plugins: [...(betterAuthOptions.plugins ?? [])]\n          }\n        })\n\n        // Type-safe extension of payload with betterAuth\n        Object.defineProperty(payload, 'betterAuth', {\n          value: auth,\n          writable: false,\n          configurable: false\n        })\n      } catch (error) {\n        console.error('Failed to initialize BetterAuth:', error)\n        throw error\n      }\n    }\n    return config\n  }\n}\n"],"names":["sanitizeBetterAuthOptions","getRequiredCollectionSlugs","buildCollections","initBetterAuth","adminRoutes","setLoginMethods","getPayloadAuth","betterAuthPlugin","pluginOptions","config","disabled","betterAuthOptions","options","custom","hasBetterAuthPlugin","disableDefaultPayloadAuth","admin","components","afterLogin","path","serverProps","redirectTo","routes","undefined","adminLogin","logout","Button","views","Component","adminSignup","forgotPassword","resetPassword","login","loginRedirect","requiredCollectionSlugs","logTables","debug","collections","incomingCollections","incomingOnInit","onInit","payload","auth","idType","db","defaultIDType","enableDebugLogs","plugins","Object","defineProperty","value","writable","configurable","error","console"],"mappings":"AAEA,SAASA,yBAAyB,QAAQ,2CAA0C;AACpF,SAASC,0BAA0B,QAAQ,sCAAqC;AAChF,SAASC,gBAAgB,QAAQ,gCAA+B;AAChE,SAASC,cAAc,QAAQ,yBAAwB;AACvD,SAASC,WAAW,QAAQ,cAAa;AACzC,SAASC,eAAe,QAAQ,0BAAyB;AAEzD,SAASL,yBAAyB,QAAQ,2CAA0C;AACpF,SAASM,cAAc,QAAQ,yBAAwB;AACvD,cAAc,UAAS;AACvB,cAAc,kBAAiB;AAE/B,OAAO,SAASC,iBAAiBC,aAAsC;IACrE,OAAO,CAACC;QACN,IAAID,cAAcE,QAAQ,EAAE;YAC1B,OAAOD;QACT;QAEA,MAAME,oBAAoBX,0BAA0B;YAClDS;YACAG,SAASJ;QACX;QAEAC,OAAOI,MAAM,GAAG;YACd,GAAGJ,OAAOI,MAAM;YAChBC,qBAAqB;QACvB;QAEAN,gBAAgBH,gBAAgB;YAAEG;QAAc;QAEhD,mEAAmE;QACnE,IAAIA,cAAcO,yBAAyB,EAAE;YAC3CN,OAAOO,KAAK,GAAG;gBACb,GAAGP,OAAOO,KAAK;gBACfC,YAAY;oBACV,GAAGR,OAAOO,KAAK,EAAEC,UAAU;oBAC3BC,YAAY;wBACV;4BACEC,MAAM;4BACNC,aAAa;gCACXC,YAAY,GAAGZ,OAAOa,MAAM,EAAEN,UAAUO,YAAY,WAAWd,OAAOa,MAAM,CAACN,KAAK,GAAGZ,YAAYoB,UAAU,EAAE;4BAC/G;wBACF;2BACIf,OAAOO,KAAK,EAAEC,YAAYC,cAAc,EAAE;qBAC/C;oBACDO,QAAQ;wBACNC,QAAQ;4BACNP,MAAM;wBACR;oBACF;oBACAQ,OAAO;wBACL,GAAGlB,OAAOO,KAAK,EAAEC,YAAYU,KAAK;wBAClCH,YAAY;4BACVL,MAAMf,YAAYoB,UAAU;4BAC5BI,WAAW;gCACTT,MAAM;gCACNC,aAAa;oCACXZ,eAAeA;oCACfG,mBAAmBA;gCACrB;4BACF;wBACF;wBACAkB,aAAa;4BACXV,MAAMf,YAAYyB,WAAW;4BAC7BD,WAAW;gCACTT,MAAM;gCACNC,aAAa;oCACXZ,eAAeA;oCACfG,mBAAmBA;gCACrB;4BACF;wBACF;wBACAmB,gBAAgB;4BACdX,MAAMf,YAAY0B,cAAc;4BAChCF,WAAW;gCACTT,MAAM;gCACNC,aAAa;oCACXT,mBAAmBA;gCACrB;4BACF;wBACF;wBACAoB,eAAe;4BACbZ,MAAMf,YAAY2B,aAAa;4BAC/BH,WAAW;gCACTT,MAAM;4BACR;wBACF;oBACF;gBACF;gBACAG,QAAQ;oBACN,GAAGb,OAAOO,KAAK,EAAEM,MAAM;oBACvBU,OAAO5B,YAAY6B,aAAa;gBAClC;YACF;QACF;QAEA,sEAAsE;QACtE,MAAMC,0BAA0BjC,2BAA2B;YACzDkC,WAAW3B,cAAc4B,KAAK,EAAED,aAAa;YAC7C3B;YACAG;QACF;QAEA,IAAI,CAACF,OAAO4B,WAAW,EAAE;YACvB5B,OAAO4B,WAAW,GAAG,EAAE;QACzB;QAEA,8DAA8D;QAC9D5B,OAAO4B,WAAW,GAAGnC,iBAAiB;YACpCoC,qBAAqB7B,OAAO4B,WAAW,IAAI,EAAE;YAC7CH;YACA1B;YACAG;QACF;QAEA,MAAM4B,iBAAiB9B,OAAO+B,MAAM;QAEpC/B,OAAO+B,MAAM,GAAG,OAAOC;YACrB,IAAI;gBACF,8CAA8C;gBAC9C,IAAIF,gBAAgB;oBAClB,MAAMA,eAAeE;gBACvB;gBAEA,6CAA6C;gBAC7C,MAAMC,OAAOvC,eAA8D;oBACzEsC;oBACAE,QAAQF,QAAQG,EAAE,CAACC,aAAa;oBAChCjC,SAAS;wBACP,GAAGD,iBAAiB;wBACpBmC,iBAAiBtC,cAAc4B,KAAK,EAAEU,mBAAmB;wBACzDC,SAAS;+BAAKpC,kBAAkBoC,OAAO,IAAI,EAAE;yBAAE;oBACjD;gBACF;gBAEA,iDAAiD;gBACjDC,OAAOC,cAAc,CAACR,SAAS,cAAc;oBAC3CS,OAAOR;oBACPS,UAAU;oBACVC,cAAc;gBAChB;YACF,EAAE,OAAOC,OAAO;gBACdC,QAAQD,KAAK,CAAC,oCAAoCA;gBAClD,MAAMA;YACR;QACF;QACA,OAAO5C;IACT;AACF"}
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/better-auth/plugin/index.ts"],"sourcesContent":["import type { Config } from 'payload'\nimport type { BetterAuthPluginOptions } from './types'\nimport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nimport { getRequiredCollectionSlugs } from './lib/get-required-collection-slugs'\nimport { buildCollections } from './lib/build-collections/index'\nimport { initBetterAuth } from './lib/init-better-auth'\nimport { adminRoutes, baseCollectionSlugs, betterAuthPluginSlugs, supportedBetterAuthPluginIds } from './constants'\nimport { setLoginMethods } from './lib/set-login-methods'\nimport { checkTwoFactorPlugin } from './helpers/check-two-factor-plugin'\n\nexport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nexport { getPayloadAuth } from './lib/get-payload-auth'\nexport * from './types'\nexport * from './helpers/index'\n\nexport function betterAuthPlugin(pluginOptions: BetterAuthPluginOptions) {\n  return (config: Config): Config => {\n    if (pluginOptions.disabled) {\n      return config\n    }\n\n    const betterAuthOptions = sanitizeBetterAuthOptions({\n      config,\n      options: pluginOptions\n    })\n\n    config.custom = {\n      ...config.custom,\n      hasBetterAuthPlugin: true\n    }\n\n    pluginOptions = setLoginMethods({ pluginOptions })\n\n    // Set custom admin components if disableDefaultPayloadAuth is true\n    if (pluginOptions.disableDefaultPayloadAuth) {\n      config.admin = {\n        ...config.admin,\n        components: {\n          ...config.admin?.components,\n          afterLogin: [\n            {\n              path: 'payload-auth/better-auth/plugin/rsc#RSCRedirect',\n              serverProps: {\n                redirectTo: `${config.routes?.admin === undefined ? '/admin' : config.routes.admin}${adminRoutes.adminLogin}`\n              }\n            },\n            ...(config.admin?.components?.afterLogin || [])\n          ],\n          logout: {\n            Button: {\n              path: 'payload-auth/better-auth/plugin/client#LogoutButton'\n            }\n          },\n          views: {\n            ...config.admin?.components?.views,\n            adminLogin: {\n              path: adminRoutes.adminLogin,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#AdminLogin',\n                serverProps: {\n                  pluginOptions: pluginOptions,\n                  betterAuthOptions: betterAuthOptions\n                }\n              }\n            },\n            adminSignup: {\n              path: adminRoutes.adminSignup,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#AdminSignup',\n                serverProps: {\n                  pluginOptions: pluginOptions,\n                  betterAuthOptions: betterAuthOptions\n                }\n              }\n            },\n            forgotPassword: {\n              path: adminRoutes.forgotPassword,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#ForgotPassword',\n                serverProps: {\n                  betterAuthOptions: betterAuthOptions\n                }\n              }\n            },\n            resetPassword: {\n              path: adminRoutes.resetPassword,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#ResetPassword'\n              }\n            },\n            ...(checkTwoFactorPlugin(betterAuthOptions) && {\n              twoFactorVerify: {\n                path: adminRoutes.twoFactorVerify,\n                Component: {\n                  path: 'payload-auth/better-auth/plugin/rsc#TwoFactorVerify',\n                  serverProps: {\n                    payloadConfig: config,\n                    twoFactorOptions:\n                      betterAuthOptions.plugins?.find((plugin) => plugin.id === supportedBetterAuthPluginIds.twoFactor)?.options ?? {},\n                    verificationSlug: pluginOptions.verifications?.slug ?? baseCollectionSlugs.verifications\n                  }\n                }\n              }\n            })\n          }\n        },\n        routes: {\n          ...config.admin?.routes,\n          login: adminRoutes.loginRedirect\n        }\n      }\n    }\n\n    // Determine which collections to add based on the options and plugins\n    const requiredCollectionSlugs = getRequiredCollectionSlugs({\n      logTables: pluginOptions.debug?.logTables ?? false,\n      pluginOptions,\n      betterAuthOptions\n    })\n\n    if (!config.collections) {\n      config.collections = []\n    }\n\n    // Update with the required collections + existing collections\n    config.collections = buildCollections({\n      incomingCollections: config.collections ?? [],\n      requiredCollectionSlugs,\n      pluginOptions,\n      betterAuthOptions\n    })\n\n    const incomingOnInit = config.onInit\n\n    config.onInit = async (payload) => {\n      try {\n        // Execute any existing onInit functions first\n        if (incomingOnInit) {\n          await incomingOnInit(payload)\n        }\n\n        // Initialize and set the betterAuth instance\n        const auth = initBetterAuth<NonNullable<typeof betterAuthOptions.plugins>>({\n          payload,\n          idType: payload.db.defaultIDType,\n          options: {\n            ...betterAuthOptions,\n            enableDebugLogs: pluginOptions.debug?.enableDebugLogs ?? false,\n            plugins: [...(betterAuthOptions.plugins ?? [])]\n          }\n        })\n\n        // Type-safe extension of payload with betterAuth\n        Object.defineProperty(payload, 'betterAuth', {\n          value: auth,\n          writable: false,\n          configurable: false\n        })\n      } catch (error) {\n        console.error('Failed to initialize BetterAuth:', error)\n        throw error\n      }\n    }\n    return config\n  }\n}\n"],"names":["sanitizeBetterAuthOptions","getRequiredCollectionSlugs","buildCollections","initBetterAuth","adminRoutes","baseCollectionSlugs","supportedBetterAuthPluginIds","setLoginMethods","checkTwoFactorPlugin","getPayloadAuth","betterAuthPlugin","pluginOptions","config","disabled","betterAuthOptions","options","custom","hasBetterAuthPlugin","disableDefaultPayloadAuth","admin","components","afterLogin","path","serverProps","redirectTo","routes","undefined","adminLogin","logout","Button","views","Component","adminSignup","forgotPassword","resetPassword","twoFactorVerify","payloadConfig","twoFactorOptions","plugins","find","plugin","id","twoFactor","verificationSlug","verifications","slug","login","loginRedirect","requiredCollectionSlugs","logTables","debug","collections","incomingCollections","incomingOnInit","onInit","payload","auth","idType","db","defaultIDType","enableDebugLogs","Object","defineProperty","value","writable","configurable","error","console"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAC1C,OAAO,EAAE,uBAAuB,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAA;AAKjF,wBAAgB,uBAAuB,CAAC,EACtC,mBAAmB,EACnB,aAAa,EACb,iBAAiB,EAClB,EAAE;IACD,mBAAmB,EAAE,gBAAgB,EAAE,CAAA;IACvC,aAAa,EAAE,uBAAuB,CAAA;IACtC,iBAAiB,EAAE,0BAA0B,CAAA;CAC9C,
|
|
1
|
+
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAC1C,OAAO,EAAE,uBAAuB,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAA;AAKjF,wBAAgB,uBAAuB,CAAC,EACtC,mBAAmB,EACnB,aAAa,EACb,iBAAiB,EAClB,EAAE;IACD,mBAAmB,EAAE,gBAAgB,EAAE,CAAA;IACvC,aAAa,EAAE,uBAAuB,CAAA;IACtC,iBAAiB,EAAE,0BAA0B,CAAA;CAC9C,oBA4HA"}
|
|
@@ -88,6 +88,7 @@ export function buildSessionsCollection({ incomingCollections, pluginOptions, be
|
|
|
88
88
|
type: 'relationship',
|
|
89
89
|
relationTo: userSlug,
|
|
90
90
|
required: false,
|
|
91
|
+
saveToJWT: true,
|
|
91
92
|
label: 'Impersonated By',
|
|
92
93
|
admin: {
|
|
93
94
|
readOnly: true,
|
|
@@ -99,6 +100,7 @@ export function buildSessionsCollection({ incomingCollections, pluginOptions, be
|
|
|
99
100
|
sessionCollection.fields.push({
|
|
100
101
|
name: 'activeOrganization',
|
|
101
102
|
type: 'relationship',
|
|
103
|
+
saveToJWT: true,
|
|
102
104
|
relationTo: betterAuthPluginSlugs.organizations,
|
|
103
105
|
label: 'Active Organization',
|
|
104
106
|
admin: {
|
|
@@ -120,4 +122,4 @@ export function buildSessionsCollection({ incomingCollections, pluginOptions, be
|
|
|
120
122
|
return sessionCollection;
|
|
121
123
|
}
|
|
122
124
|
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL3Nlc3Npb25zLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbGxlY3Rpb25Db25maWcgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHsgQmV0dGVyQXV0aFBsdWdpbk9wdGlvbnMsIFNhbml0aXplZEJldHRlckF1dGhPcHRpb25zIH0gZnJvbSAnLi4vLi4vdHlwZXMnXG5pbXBvcnQgeyBiYXNlQ29sbGVjdGlvblNsdWdzLCBiZXR0ZXJBdXRoUGx1Z2luU2x1Z3MgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnXG5pbXBvcnQgeyBnZXRUaW1lc3RhbXBGaWVsZHMgfSBmcm9tICcuL3V0aWxzL2dldC10aW1lc3RhbXAtZmllbGRzJ1xuaW1wb3J0IHsgZ2V0QWRtaW5BY2Nlc3MgfSBmcm9tICcuLi8uLi9oZWxwZXJzL2dldC1hZG1pbi1hY2Nlc3MnXG5cbmV4cG9ydCBmdW5jdGlvbiBidWlsZFNlc3Npb25zQ29sbGVjdGlvbih7XG4gIGluY29taW5nQ29sbGVjdGlvbnMsXG4gIHBsdWdpbk9wdGlvbnMsXG4gIGJldHRlckF1dGhPcHRpb25zXG59OiB7XG4gIGluY29taW5nQ29sbGVjdGlvbnM6IENvbGxlY3Rpb25Db25maWdbXVxuICBwbHVnaW5PcHRpb25zOiBCZXR0ZXJBdXRoUGx1Z2luT3B0aW9uc1xuICBiZXR0ZXJBdXRoT3B0aW9uczogU2FuaXRpemVkQmV0dGVyQXV0aE9wdGlvbnNcbn0pIHtcbiAgY29uc3Qgc2Vzc2lvblNsdWcgPSBwbHVnaW5PcHRpb25zLnNlc3Npb25zPy5zbHVnID8/IGJhc2VDb2xsZWN0aW9uU2x1Z3Muc2Vzc2lvbnNcbiAgY29uc3QgdXNlclNsdWcgPSBwbHVnaW5PcHRpb25zLnVzZXJzPy5zbHVnID8/IGJhc2VDb2xsZWN0aW9uU2x1Z3MudXNlcnNcbiAgY29uc3QgYmFQbHVnaW5zID0gYmV0dGVyQXV0aE9wdGlvbnMucGx1Z2lucyA/PyBudWxsXG5cbiAgY29uc3QgZXhpc3RpbmdTZXNzaW9uQ29sbGVjdGlvbiA9IGluY29taW5nQ29sbGVjdGlvbnMuZmluZCgoY29sbGVjdGlvbikgPT4gY29sbGVjdGlvbi5zbHVnID09PSBzZXNzaW9uU2x1ZykgYXNcbiAgICB8IENvbGxlY3Rpb25Db25maWdcbiAgICB8IHVuZGVmaW5lZFxuICBsZXQgc2Vzc2lvbkNvbGxlY3Rpb246IENvbGxlY3Rpb25Db25maWcgPSB7XG4gICAgc2x1Zzogc2Vzc2lvblNsdWcsXG4gICAgYWRtaW46IHtcbiAgICAgIC4uLmV4aXN0aW5nU2Vzc2lvbkNvbGxlY3Rpb24/
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/sessions.ts"],"sourcesContent":["import { CollectionConfig } from 'payload'\nimport { BetterAuthPluginOptions, SanitizedBetterAuthOptions } from '../../types'\nimport { baseCollectionSlugs, betterAuthPluginSlugs } from '../../constants'\nimport { getTimestampFields } from './utils/get-timestamp-fields'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\n\nexport function buildSessionsCollection({\n  incomingCollections,\n  pluginOptions,\n  betterAuthOptions\n}: {\n  incomingCollections: CollectionConfig[]\n  pluginOptions: BetterAuthPluginOptions\n  betterAuthOptions: SanitizedBetterAuthOptions\n}) {\n  const sessionSlug = pluginOptions.sessions?.slug ?? baseCollectionSlugs.sessions\n  const userSlug = pluginOptions.users?.slug ?? baseCollectionSlugs.users\n  const baPlugins = betterAuthOptions.plugins ?? null\n\n  const existingSessionCollection = incomingCollections.find((collection) => collection.slug === sessionSlug) as\n    | CollectionConfig\n    | undefined\n  let sessionCollection: CollectionConfig = {\n    slug: sessionSlug,\n    admin: {\n      ...existingSessionCollection?.admin,\n      hidden: pluginOptions.sessions?.hidden,\n      description: 'Sessions are active sessions for users. They are used to authenticate users with a session token',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth'\n    },\n    access: {\n      ...getAdminAccess(pluginOptions)\n    },\n    fields: [\n      ...(existingSessionCollection?.fields ?? []),\n      {\n        name: 'user',\n        type: 'relationship',\n        relationTo: userSlug,\n        required: true,\n        saveToJWT: true,\n        index: true,\n        admin: {\n          readOnly: true,\n          description: 'The user that the session belongs to'\n        }\n      },\n      {\n        name: 'token',\n        type: 'text',\n        required: true,\n        unique: true,\n        index: true,\n        saveToJWT: true,\n        label: 'Token',\n        admin: {\n          description: 'The unique session token',\n          readOnly: true\n        }\n      },\n      {\n        name: 'expiresAt',\n        type: 'date',\n        required: true,\n        label: 'Expires At',\n        saveToJWT: true,\n        admin: {\n          description: 'The date and time when the session will expire',\n          readOnly: true\n        }\n      },\n      {\n        name: 'ipAddress',\n        type: 'text',\n        label: 'IP Address',\n        saveToJWT: true,\n        admin: {\n          description: 'The IP address of the device',\n          readOnly: true\n        }\n      },\n      {\n        name: 'userAgent',\n        type: 'text',\n        label: 'User Agent',\n        saveToJWT: true,\n        admin: {\n          description: 'The user agent information of the device',\n          readOnly: true\n        }\n      },\n      ...getTimestampFields()\n    ],\n    ...existingSessionCollection\n  }\n  if (baPlugins) {\n    baPlugins.forEach((plugin) => {\n      switch (plugin.id) {\n        case 'admin':\n          sessionCollection.fields.push({\n            name: 'impersonatedBy',\n            type: 'relationship',\n            relationTo: userSlug,\n            required: false,\n            saveToJWT: true,\n            label: 'Impersonated By',\n            admin: {\n              readOnly: true,\n              description: 'The admin who is impersonating this session'\n            }\n          })\n          break\n        case 'organization':\n          sessionCollection.fields.push({\n            name: 'activeOrganization',\n            type: 'relationship',\n            saveToJWT: true,\n            relationTo: betterAuthPluginSlugs.organizations,\n            label: 'Active Organization',\n            admin: {\n              readOnly: true,\n              description: 'The currently active organization for the session'\n            }\n          })\n          break\n        default:\n          break\n      }\n    })\n  }\n\n  if (pluginOptions.sessions?.collectionOverrides) {\n    sessionCollection = pluginOptions.sessions.collectionOverrides({\n      collection: sessionCollection\n    })\n  }\n\n  return sessionCollection\n}\n"],"names":["baseCollectionSlugs","betterAuthPluginSlugs","getTimestampFields","getAdminAccess","buildSessionsCollection","incomingCollections","pluginOptions","betterAuthOptions","sessionSlug","sessions","slug","userSlug","users","baPlugins","plugins","existingSessionCollection","find","collection","sessionCollection","admin","hidden","description","group","collectionAdminGroup","access","fields","name","type","relationTo","required","saveToJWT","index","readOnly","unique","label","forEach","plugin","id","push","organizations","collectionOverrides"],"mappings":"AAEA,SAASA,mBAAmB,EAAEC,qBAAqB,QAAQ,kBAAiB;AAC5E,SAASC,kBAAkB,QAAQ,+BAA8B;AACjE,SAASC,cAAc,QAAQ,iCAAgC;AAE/D,OAAO,SAASC,wBAAwB,EACtCC,mBAAmB,EACnBC,aAAa,EACbC,iBAAiB,EAKlB;IACC,MAAMC,cAAcF,cAAcG,QAAQ,EAAEC,QAAQV,oBAAoBS,QAAQ;IAChF,MAAME,WAAWL,cAAcM,KAAK,EAAEF,QAAQV,oBAAoBY,KAAK;IACvE,MAAMC,YAAYN,kBAAkBO,OAAO,IAAI;IAE/C,MAAMC,4BAA4BV,oBAAoBW,IAAI,CAAC,CAACC,aAAeA,WAAWP,IAAI,KAAKF;IAG/F,IAAIU,oBAAsC;QACxCR,MAAMF;QACNW,OAAO;YACL,GAAGJ,2BAA2BI,KAAK;YACnCC,QAAQd,cAAcG,QAAQ,EAAEW;YAChCC,aAAa;YACbC,OAAOhB,eAAeiB,wBAAwB;QAChD;QACAC,QAAQ;YACN,GAAGrB,eAAeG,cAAc;QAClC;QACAmB,QAAQ;eACFV,2BAA2BU,UAAU,EAAE;YAC3C;gBACEC,MAAM;gBACNC,MAAM;gBACNC,YAAYjB;gBACZkB,UAAU;gBACVC,WAAW;gBACXC,OAAO;gBACPZ,OAAO;oBACLa,UAAU;oBACVX,aAAa;gBACf;YACF;YACA;gBACEK,MAAM;gBACNC,MAAM;gBACNE,UAAU;gBACVI,QAAQ;gBACRF,OAAO;gBACPD,WAAW;gBACXI,OAAO;gBACPf,OAAO;oBACLE,aAAa;oBACbW,UAAU;gBACZ;YACF;YACA;gBACEN,MAAM;gBACNC,MAAM;gBACNE,UAAU;gBACVK,OAAO;gBACPJ,WAAW;gBACXX,OAAO;oBACLE,aAAa;oBACbW,UAAU;gBACZ;YACF;YACA;gBACEN,MAAM;gBACNC,MAAM;gBACNO,OAAO;gBACPJ,WAAW;gBACXX,OAAO;oBACLE,aAAa;oBACbW,UAAU;gBACZ;YACF;YACA;gBACEN,MAAM;gBACNC,MAAM;gBACNO,OAAO;gBACPJ,WAAW;gBACXX,OAAO;oBACLE,aAAa;oBACbW,UAAU;gBACZ;YACF;eACG9B;SACJ;QACD,GAAGa,yBAAyB;IAC9B;IACA,IAAIF,WAAW;QACbA,UAAUsB,OAAO,CAAC,CAACC;YACjB,OAAQA,OAAOC,EAAE;gBACf,KAAK;oBACHnB,kBAAkBO,MAAM,CAACa,IAAI,CAAC;wBAC5BZ,MAAM;wBACNC,MAAM;wBACNC,YAAYjB;wBACZkB,UAAU;wBACVC,WAAW;wBACXI,OAAO;wBACPf,OAAO;4BACLa,UAAU;4BACVX,aAAa;wBACf;oBACF;oBACA;gBACF,KAAK;oBACHH,kBAAkBO,MAAM,CAACa,IAAI,CAAC;wBAC5BZ,MAAM;wBACNC,MAAM;wBACNG,WAAW;wBACXF,YAAY3B,sBAAsBsC,aAAa;wBAC/CL,OAAO;wBACPf,OAAO;4BACLa,UAAU;4BACVX,aAAa;wBACf;oBACF;oBACA;gBACF;oBACE;YACJ;QACF;IACF;IAEA,IAAIf,cAAcG,QAAQ,EAAE+B,qBAAqB;QAC/CtB,oBAAoBZ,cAAcG,QAAQ,CAAC+B,mBAAmB,CAAC;YAC7DvB,YAAYC;QACd;IACF;IAEA,OAAOA;AACT"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"better-auth-strategy.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/lib/build-collections/users/better-auth-strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAI3C;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,YAAY,
|
|
1
|
+
{"version":3,"file":"better-auth-strategy.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/lib/build-collections/users/better-auth-strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAI3C;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,YAAY,CAqClE"}
|
|
@@ -18,7 +18,7 @@ import { baseCollectionSlugs } from "../../../constants";
|
|
|
18
18
|
user: null
|
|
19
19
|
};
|
|
20
20
|
}
|
|
21
|
-
const userId = res.
|
|
21
|
+
const userId = res.session.userId ?? res.user.id;
|
|
22
22
|
if (!userId) {
|
|
23
23
|
return {
|
|
24
24
|
user: null
|
|
@@ -49,4 +49,4 @@ import { baseCollectionSlugs } from "../../../constants";
|
|
|
49
49
|
};
|
|
50
50
|
}
|
|
51
51
|
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL3VzZXJzL2JldHRlci1hdXRoLXN0cmF0ZWd5LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQXV0aFN0cmF0ZWd5IH0gZnJvbSAncGF5bG9hZCdcbmltcG9ydCB7IGdldFBheWxvYWRBdXRoIH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2dldC1wYXlsb2FkLWF1dGgnXG5pbXBvcnQgeyBiYXNlQ29sbGVjdGlvblNsdWdzIH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9wbHVnaW4vY29uc3RhbnRzJ1xuXG4vKipcbiAqIEF1dGggc3RyYXRlZ3kgZm9yIEJldHRlckF1dGhcbiAqIEBwYXJhbSB1c2VyU2x1ZyAtIFVzZXIgY29sbGVjdGlvbiBzbHVnXG4gKiBAcmV0dXJucyBBdXRoIHN0cmF0ZWd5XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBiZXR0ZXJBdXRoU3RyYXRlZ3kodXNlclNsdWc/OiBzdHJpbmcpOiBBdXRoU3RyYXRlZ3kge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdiZXR0ZXItYXV0aCcsXG4gICAgYXV0aGVudGljYXRlOiBhc3luYyAoeyBwYXlsb2FkLCBoZWFkZXJzIH0pID0+
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL3VzZXJzL2JldHRlci1hdXRoLXN0cmF0ZWd5LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQXV0aFN0cmF0ZWd5IH0gZnJvbSAncGF5bG9hZCdcbmltcG9ydCB7IGdldFBheWxvYWRBdXRoIH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2dldC1wYXlsb2FkLWF1dGgnXG5pbXBvcnQgeyBiYXNlQ29sbGVjdGlvblNsdWdzIH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9wbHVnaW4vY29uc3RhbnRzJ1xuXG4vKipcbiAqIEF1dGggc3RyYXRlZ3kgZm9yIEJldHRlckF1dGhcbiAqIEBwYXJhbSB1c2VyU2x1ZyAtIFVzZXIgY29sbGVjdGlvbiBzbHVnXG4gKiBAcmV0dXJucyBBdXRoIHN0cmF0ZWd5XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBiZXR0ZXJBdXRoU3RyYXRlZ3kodXNlclNsdWc/OiBzdHJpbmcpOiBBdXRoU3RyYXRlZ3kge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdiZXR0ZXItYXV0aCcsXG4gICAgYXV0aGVudGljYXRlOiBhc3luYyAoeyBwYXlsb2FkLCBoZWFkZXJzIH0pID0+IHtcbiAgICAgIHRyeSB7XG4gICAgICAgIGNvbnN0IHBheWxvYWRBdXRoID0gYXdhaXQgZ2V0UGF5bG9hZEF1dGgocGF5bG9hZC5jb25maWcpXG5cbiAgICAgICAgY29uc3QgcmVzID0gYXdhaXQgcGF5bG9hZEF1dGguYmV0dGVyQXV0aC5hcGkuZ2V0U2Vzc2lvbih7XG4gICAgICAgICAgaGVhZGVyc1xuICAgICAgICB9KVxuXG4gICAgICAgIGlmICghcmVzKSB7XG4gICAgICAgICAgcmV0dXJuIHsgdXNlcjogbnVsbCB9XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgdXNlcklkID0gcmVzLnNlc3Npb24udXNlcklkID8/IHJlcy51c2VyLmlkXG4gICAgICAgIGlmICghdXNlcklkKSB7XG4gICAgICAgICAgcmV0dXJuIHsgdXNlcjogbnVsbCB9XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgdXNlciA9IGF3YWl0IHBheWxvYWRBdXRoLmZpbmRCeUlEKHtcbiAgICAgICAgICBjb2xsZWN0aW9uOiB1c2VyU2x1ZyA/PyBiYXNlQ29sbGVjdGlvblNsdWdzLnVzZXJzLFxuICAgICAgICAgIGlkOiB1c2VySWRcbiAgICAgICAgfSlcbiAgICAgICAgaWYgKCF1c2VyKSB7XG4gICAgICAgICAgcmV0dXJuIHsgdXNlcjogbnVsbCB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICB1c2VyOiB7XG4gICAgICAgICAgICAuLi51c2VyLFxuICAgICAgICAgICAgY29sbGVjdGlvbjogdXNlclNsdWcgPz8gYmFzZUNvbGxlY3Rpb25TbHVncy51c2VycyxcbiAgICAgICAgICAgIF9zdHJhdGVneTogJ2JldHRlci1hdXRoJ1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgcmV0dXJuIHsgdXNlcjogbnVsbCB9XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOlsiZ2V0UGF5bG9hZEF1dGgiLCJiYXNlQ29sbGVjdGlvblNsdWdzIiwiYmV0dGVyQXV0aFN0cmF0ZWd5IiwidXNlclNsdWciLCJuYW1lIiwiYXV0aGVudGljYXRlIiwicGF5bG9hZCIsImhlYWRlcnMiLCJwYXlsb2FkQXV0aCIsImNvbmZpZyIsInJlcyIsImJldHRlckF1dGgiLCJhcGkiLCJnZXRTZXNzaW9uIiwidXNlciIsInVzZXJJZCIsInNlc3Npb24iLCJpZCIsImZpbmRCeUlEIiwiY29sbGVjdGlvbiIsInVzZXJzIiwiX3N0cmF0ZWd5IiwiZXJyb3IiXSwibWFwcGluZ3MiOiJBQUNBLFNBQVNBLGNBQWMsUUFBUSx5QkFBMkM7QUFDMUUsU0FBU0MsbUJBQW1CLFFBQVEscUJBQWdDO0FBRXBFOzs7O0NBSUMsR0FDRCxPQUFPLFNBQVNDLG1CQUFtQkMsUUFBaUI7SUFDbEQsT0FBTztRQUNMQyxNQUFNO1FBQ05DLGNBQWMsT0FBTyxFQUFFQyxPQUFPLEVBQUVDLE9BQU8sRUFBRTtZQUN2QyxJQUFJO2dCQUNGLE1BQU1DLGNBQWMsTUFBTVIsZUFBZU0sUUFBUUcsTUFBTTtnQkFFdkQsTUFBTUMsTUFBTSxNQUFNRixZQUFZRyxVQUFVLENBQUNDLEdBQUcsQ0FBQ0MsVUFBVSxDQUFDO29CQUN0RE47Z0JBQ0Y7Z0JBRUEsSUFBSSxDQUFDRyxLQUFLO29CQUNSLE9BQU87d0JBQUVJLE1BQU07b0JBQUs7Z0JBQ3RCO2dCQUNBLE1BQU1DLFNBQVNMLElBQUlNLE9BQU8sQ0FBQ0QsTUFBTSxJQUFJTCxJQUFJSSxJQUFJLENBQUNHLEVBQUU7Z0JBQ2hELElBQUksQ0FBQ0YsUUFBUTtvQkFDWCxPQUFPO3dCQUFFRCxNQUFNO29CQUFLO2dCQUN0QjtnQkFDQSxNQUFNQSxPQUFPLE1BQU1OLFlBQVlVLFFBQVEsQ0FBQztvQkFDdENDLFlBQVloQixZQUFZRixvQkFBb0JtQixLQUFLO29CQUNqREgsSUFBSUY7Z0JBQ047Z0JBQ0EsSUFBSSxDQUFDRCxNQUFNO29CQUNULE9BQU87d0JBQUVBLE1BQU07b0JBQUs7Z0JBQ3RCO2dCQUNBLE9BQU87b0JBQ0xBLE1BQU07d0JBQ0osR0FBR0EsSUFBSTt3QkFDUEssWUFBWWhCLFlBQVlGLG9CQUFvQm1CLEtBQUs7d0JBQ2pEQyxXQUFXO29CQUNiO2dCQUNGO1lBQ0YsRUFBRSxPQUFPQyxPQUFPO2dCQUNkLE9BQU87b0JBQUVSLE1BQU07Z0JBQUs7WUFDdEI7UUFDRjtJQUNGO0FBQ0YifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"after-login.d.ts","sourceRoot":"","sources":["../../../../../../../src/better-auth/plugin/lib/build-collections/users/hooks/after-login.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAA;AAKlD,KAAK,iBAAiB,GAAG;IACvB,mBAAmB,EAAE,MAAM,CAAA;IAC3B,sBAAsB,EAAE,MAAM,CAAA;CAC/B,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,iBAAiB,GAAI,SAAS,iBAAiB,KAAG,
|
|
1
|
+
{"version":3,"file":"after-login.d.ts","sourceRoot":"","sources":["../../../../../../../src/better-auth/plugin/lib/build-collections/users/hooks/after-login.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAA;AAKlD,KAAK,iBAAiB,GAAG;IACvB,mBAAmB,EAAE,MAAM,CAAA;IAC3B,sBAAsB,EAAE,MAAM,CAAA;CAC/B,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,iBAAiB,GAAI,SAAS,iBAAiB,KAAG,wBAuE9D,CAAA"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { generateId } from "better-auth";
|
|
2
2
|
import { createAuthMiddleware } from "better-auth/api";
|
|
3
|
-
import {
|
|
3
|
+
import { setSessionCookie } from "better-auth/cookies";
|
|
4
4
|
import { parseSetCookie } from "next/dist/compiled/@edge-runtime/cookies";
|
|
5
5
|
import { cookies } from "next/headers";
|
|
6
6
|
import { getPayloadAuth } from "../../../get-payload-auth";
|
|
@@ -36,7 +36,7 @@ import { prepareSessionData } from "../../../../helpers/prepare-session-data";
|
|
|
36
36
|
};
|
|
37
37
|
await ctx.setSignedCookie(ctx.context.authCookies.sessionToken.name, session.token, ctx.context.secret, ctx.context.authCookies.sessionToken.options);
|
|
38
38
|
const filteredSessionData = await prepareSessionData({
|
|
39
|
-
|
|
39
|
+
sessionData: {
|
|
40
40
|
session,
|
|
41
41
|
user
|
|
42
42
|
},
|
|
@@ -46,7 +46,9 @@ import { prepareSessionData } from "../../../../helpers/prepare-session-data";
|
|
|
46
46
|
sessionCollectionSlug: options.sessionsCollectionSlug
|
|
47
47
|
}
|
|
48
48
|
});
|
|
49
|
-
|
|
49
|
+
if (filteredSessionData) {
|
|
50
|
+
await setSessionCookie(ctx, filteredSessionData);
|
|
51
|
+
}
|
|
50
52
|
if ('responseHeaders' in ctx) {
|
|
51
53
|
return ctx.responseHeaders;
|
|
52
54
|
}
|
|
@@ -73,4 +75,4 @@ import { prepareSessionData } from "../../../../helpers/prepare-session-data";
|
|
|
73
75
|
return hook;
|
|
74
76
|
};
|
|
75
77
|
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../../src/better-auth/plugin/lib/build-collections/users/hooks/after-login.ts"],"sourcesContent":["import { generateId, Session } from 'better-auth'\nimport { createAuthMiddleware } from 'better-auth/api'\nimport { setCookieCache, setSessionCookie } from 'better-auth/cookies'\nimport { parseSetCookie, type ResponseCookie } from 'next/dist/compiled/@edge-runtime/cookies'\nimport { cookies } from 'next/headers'\nimport { CollectionAfterLoginHook } from 'payload'\nimport { getPayloadAuth } from '@/better-auth/plugin/lib/get-payload-auth'\nimport { getIp } from '@/better-auth/plugin/helpers/get-ip'\nimport { prepareSessionData } from '@/better-auth/plugin/helpers/prepare-session-data'\n\ntype AfterLoginOptions = {\n  usersCollectionSlug: string\n  sessionsCollectionSlug: string\n}\n\n/**\n * This hook is used to sync the admin login token with better-auth session token\n * It also creates a new session in better-auth\n */\nexport const getAfterLoginHook = (options: AfterLoginOptions): CollectionAfterLoginHook => {\n  const hook: CollectionAfterLoginHook = async ({ collection, context, req, token, user }) => {\n    const config = req.payload.config\n    const payload = await getPayloadAuth(config)\n    const cookieStore = await cookies()\n    const authContext = await payload.betterAuth.$context\n\n    const sessionExpiration = payload.betterAuth.options.session?.expiresIn || 60 * 60 * 24 * 7 // 7 days\n    // we can't use internal adapter as we can cause a race condition unless we pass req to the payload.create\n    const session = (await payload.create({\n      collection: options.sessionsCollectionSlug,\n      data: {\n        ipAddress: getIp(req.headers, payload.betterAuth.options) || '',\n        userAgent: req.headers?.get('user-agent') || '',\n        user: user.id,\n        token: generateId(32),\n        expiresAt: new Date(Date.now() + sessionExpiration * 1000)\n      },\n      req\n    })) as Session\n\n    const betterAuthHandleRequest = createAuthMiddleware(async (ctx): Promise<Headers | null> => {\n      ctx.context = { ...authContext, user: user }\n      await ctx.setSignedCookie(\n        ctx.context.authCookies.sessionToken.name,\n        session.token,\n        ctx.context.secret,\n        ctx.context.authCookies.sessionToken.options\n      )\n      const filteredSessionData = await prepareSessionData({\n        sessionData: { session, user },\n        payloadConfig: config,\n        collectionSlugs: {\n          userCollectionSlug: options.usersCollectionSlug,\n          sessionCollectionSlug: options.sessionsCollectionSlug\n        }\n      })\n      if (filteredSessionData) {\n        await setSessionCookie(ctx, filteredSessionData)\n      }\n      if ('responseHeaders' in ctx) {\n        return ctx.responseHeaders as Headers\n      }\n      return null\n    })\n\n    // Create a modified request object that matches the expected MiddlewareInputContext type\n    const modifiedReq = {\n      ...req,\n      body: undefined // Explicitly set body to undefined to satisfy type constraint\n    }\n\n    const responseHeaders = await betterAuthHandleRequest(modifiedReq)\n    const responseCookies = responseHeaders\n      ?.getSetCookie()\n      .map((cookie) => parseSetCookie(cookie))\n      .filter(Boolean) as ResponseCookie[]\n\n    if (responseCookies) {\n      for (const cookieData of responseCookies) {\n        const { name, value, ...options } = cookieData\n        cookieStore.set({\n          ...options,\n          name,\n          value: decodeURIComponent(value)\n        })\n      }\n    }\n  }\n\n  return hook as CollectionAfterLoginHook\n}\n"],"names":["generateId","createAuthMiddleware","setSessionCookie","parseSetCookie","cookies","getPayloadAuth","getIp","prepareSessionData","getAfterLoginHook","options","hook","collection","context","req","token","user","config","payload","cookieStore","authContext","betterAuth","$context","sessionExpiration","session","expiresIn","create","sessionsCollectionSlug","data","ipAddress","headers","userAgent","get","id","expiresAt","Date","now","betterAuthHandleRequest","ctx","setSignedCookie","authCookies","sessionToken","name","secret","filteredSessionData","sessionData","payloadConfig","collectionSlugs","userCollectionSlug","usersCollectionSlug","sessionCollectionSlug","responseHeaders","modifiedReq","body","undefined","responseCookies","getSetCookie","map","cookie","filter","Boolean","cookieData","value","set","decodeURIComponent"],"mappings":"AAAA,SAASA,UAAU,QAAiB,cAAa;AACjD,SAASC,oBAAoB,QAAQ,kBAAiB;AACtD,SAAyBC,gBAAgB,QAAQ,sBAAqB;AACtE,SAASC,cAAc,QAA6B,2CAA0C;AAC9F,SAASC,OAAO,QAAQ,eAAc;AAEtC,SAASC,cAAc,QAAQ,4BAA2C;AAC1E,SAASC,KAAK,QAAQ,6BAAqC;AAC3D,SAASC,kBAAkB,QAAQ,2CAAmD;AAOtF;;;CAGC,GACD,OAAO,MAAMC,oBAAoB,CAACC;IAChC,MAAMC,OAAiC,OAAO,EAAEC,UAAU,EAAEC,OAAO,EAAEC,GAAG,EAAEC,KAAK,EAAEC,IAAI,EAAE;QACrF,MAAMC,SAASH,IAAII,OAAO,CAACD,MAAM;QACjC,MAAMC,UAAU,MAAMZ,eAAeW;QACrC,MAAME,cAAc,MAAMd;QAC1B,MAAMe,cAAc,MAAMF,QAAQG,UAAU,CAACC,QAAQ;QAErD,MAAMC,oBAAoBL,QAAQG,UAAU,CAACX,OAAO,CAACc,OAAO,EAAEC,aAAa,KAAK,KAAK,KAAK,EAAE,SAAS;;QACrG,0GAA0G;QAC1G,MAAMD,UAAW,MAAMN,QAAQQ,MAAM,CAAC;YACpCd,YAAYF,QAAQiB,sBAAsB;YAC1CC,MAAM;gBACJC,WAAWtB,MAAMO,IAAIgB,OAAO,EAAEZ,QAAQG,UAAU,CAACX,OAAO,KAAK;gBAC7DqB,WAAWjB,IAAIgB,OAAO,EAAEE,IAAI,iBAAiB;gBAC7ChB,MAAMA,KAAKiB,EAAE;gBACblB,OAAOd,WAAW;gBAClBiC,WAAW,IAAIC,KAAKA,KAAKC,GAAG,KAAKb,oBAAoB;YACvD;YACAT;QACF;QAEA,MAAMuB,0BAA0BnC,qBAAqB,OAAOoC;YAC1DA,IAAIzB,OAAO,GAAG;gBAAE,GAAGO,WAAW;gBAAEJ,MAAMA;YAAK;YAC3C,MAAMsB,IAAIC,eAAe,CACvBD,IAAIzB,OAAO,CAAC2B,WAAW,CAACC,YAAY,CAACC,IAAI,EACzClB,QAAQT,KAAK,EACbuB,IAAIzB,OAAO,CAAC8B,MAAM,EAClBL,IAAIzB,OAAO,CAAC2B,WAAW,CAACC,YAAY,CAAC/B,OAAO;YAE9C,MAAMkC,sBAAsB,MAAMpC,mBAAmB;gBACnDqC,aAAa;oBAAErB;oBAASR;gBAAK;gBAC7B8B,eAAe7B;gBACf8B,iBAAiB;oBACfC,oBAAoBtC,QAAQuC,mBAAmB;oBAC/CC,uBAAuBxC,QAAQiB,sBAAsB;gBACvD;YACF;YACA,IAAIiB,qBAAqB;gBACvB,MAAMzC,iBAAiBmC,KAAKM;YAC9B;YACA,IAAI,qBAAqBN,KAAK;gBAC5B,OAAOA,IAAIa,eAAe;YAC5B;YACA,OAAO;QACT;QAEA,yFAAyF;QACzF,MAAMC,cAAc;YAClB,GAAGtC,GAAG;YACNuC,MAAMC,UAAU,8DAA8D;QAChF;QAEA,MAAMH,kBAAkB,MAAMd,wBAAwBe;QACtD,MAAMG,kBAAkBJ,iBACpBK,eACDC,IAAI,CAACC,SAAWtD,eAAesD,SAC/BC,OAAOC;QAEV,IAAIL,iBAAiB;YACnB,KAAK,MAAMM,cAAcN,gBAAiB;gBACxC,MAAM,EAAEb,IAAI,EAAEoB,KAAK,EAAE,GAAGpD,SAAS,GAAGmD;gBACpC1C,YAAY4C,GAAG,CAAC;oBACd,GAAGrD,OAAO;oBACVgC;oBACAoB,OAAOE,mBAAmBF;gBAC5B;YACF;QACF;IACF;IAEA,OAAOnD;AACT,EAAC"}
|