payload-auth 1.5.1 → 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.
- package/dist/better-auth/plugin/lib/build-collections/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/index.js +3 -1
- package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts +1 -1
- package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/passkeys.js +16 -3
- package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts +1 -1
- 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 +30 -7
- package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts +7 -0
- package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/add-button.js +120 -0
- package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/client.js +59 -0
- package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts +5 -0
- package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/index.js +40 -0
- package/dist/better-auth/plugin/payload/components/passkeys/index.scss +91 -0
- package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts +9 -0
- package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/list.js +57 -0
- package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts +20 -0
- package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/passkeys/types.js +3 -0
- 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 +1 -0
- 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 +11 -7
- 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 +3 -1
- package/dist/better-auth/plugin/types.d.ts +2 -0
- package/dist/better-auth/plugin/types.d.ts.map +1 -1
- package/dist/better-auth/plugin/types.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { PasskeysClient } from "./client";
|
|
4
|
+
import "./index.scss";
|
|
5
|
+
export const Passkeys = async (props)=>{
|
|
6
|
+
const { id, passkeySlug, payload, passkeyUserIdFieldName, req, user } = props;
|
|
7
|
+
if (!id || !passkeySlug || !passkeyUserIdFieldName) return null;
|
|
8
|
+
const { docs: userPasskeys } = await payload.find({
|
|
9
|
+
collection: passkeySlug,
|
|
10
|
+
where: {
|
|
11
|
+
[passkeyUserIdFieldName]: {
|
|
12
|
+
equals: id
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
limit: 100,
|
|
16
|
+
req,
|
|
17
|
+
depth: 0
|
|
18
|
+
});
|
|
19
|
+
return /*#__PURE__*/ _jsxs("div", {
|
|
20
|
+
className: "passkeys-field",
|
|
21
|
+
children: [
|
|
22
|
+
/*#__PURE__*/ _jsx("h3", {
|
|
23
|
+
className: "passkeys-field__title",
|
|
24
|
+
style: {
|
|
25
|
+
marginBottom: '0.7rem'
|
|
26
|
+
},
|
|
27
|
+
children: "Passkeys"
|
|
28
|
+
}),
|
|
29
|
+
/*#__PURE__*/ _jsx(PasskeysClient, {
|
|
30
|
+
initialPasskeys: userPasskeys,
|
|
31
|
+
documentId: id,
|
|
32
|
+
currentUserId: user?.id,
|
|
33
|
+
passkeySlug: passkeySlug,
|
|
34
|
+
passkeyUserIdFieldName: passkeyUserIdFieldName
|
|
35
|
+
})
|
|
36
|
+
]
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC9jb21wb25lbnRzL3Bhc3NrZXlzL2luZGV4LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBQYXNza2V5c0NsaWVudCB9IGZyb20gJy4vY2xpZW50J1xuaW1wb3J0ICcuL2luZGV4LnNjc3MnXG5pbXBvcnQgdHlwZSB7IFBhc3NrZXlzU2VydmVyQ29tcG9uZW50UHJvcHMsIFBhc3NrZXlXaXRoSWQgfSBmcm9tICcuL3R5cGVzJ1xuXG5leHBvcnQgY29uc3QgUGFzc2tleXM6IFJlYWN0LkZDPFBhc3NrZXlzU2VydmVyQ29tcG9uZW50UHJvcHM+ID0gYXN5bmMgKHByb3BzKSA9PiB7XG4gIGNvbnN0IHsgaWQsIHBhc3NrZXlTbHVnLCBwYXlsb2FkLCBwYXNza2V5VXNlcklkRmllbGROYW1lLCByZXEsIHVzZXIgfSA9IHByb3BzXG5cbiAgaWYgKCFpZCB8fCAhcGFzc2tleVNsdWcgfHwgIXBhc3NrZXlVc2VySWRGaWVsZE5hbWUpIHJldHVybiBudWxsXG5cbiAgY29uc3QgeyBkb2NzOiB1c2VyUGFzc2tleXMgfSA9IGF3YWl0IHBheWxvYWQuZmluZCh7XG4gICAgY29sbGVjdGlvbjogcGFzc2tleVNsdWcsXG4gICAgd2hlcmU6IHtcbiAgICAgIFtwYXNza2V5VXNlcklkRmllbGROYW1lXTogeyBlcXVhbHM6IGlkIH1cbiAgICB9LFxuICAgIGxpbWl0OiAxMDAsXG4gICAgcmVxLFxuICAgIGRlcHRoOiAwXG4gIH0pIGFzIHVua25vd24gYXMgeyBkb2NzOiBQYXNza2V5V2l0aElkW10gfVxuXG4gIHJldHVybiAoXG4gICAgPGRpdiBjbGFzc05hbWU9XCJwYXNza2V5cy1maWVsZFwiPlxuICAgICAgPGgzIGNsYXNzTmFtZT1cInBhc3NrZXlzLWZpZWxkX190aXRsZVwiIHN0eWxlPXt7IG1hcmdpbkJvdHRvbTogJzAuN3JlbScgfX0+XG4gICAgICAgIFBhc3NrZXlzXG4gICAgICA8L2gzPlxuICAgICAgPFBhc3NrZXlzQ2xpZW50XG4gICAgICAgIGluaXRpYWxQYXNza2V5cz17dXNlclBhc3NrZXlzfVxuICAgICAgICBkb2N1bWVudElkPXtpZH1cbiAgICAgICAgY3VycmVudFVzZXJJZD17dXNlcj8uaWR9XG4gICAgICAgIHBhc3NrZXlTbHVnPXtwYXNza2V5U2x1Z31cbiAgICAgICAgcGFzc2tleVVzZXJJZEZpZWxkTmFtZT17cGFzc2tleVVzZXJJZEZpZWxkTmFtZX1cbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gIClcbn1cbiJdLCJuYW1lcyI6WyJSZWFjdCIsIlBhc3NrZXlzQ2xpZW50IiwiUGFzc2tleXMiLCJwcm9wcyIsImlkIiwicGFzc2tleVNsdWciLCJwYXlsb2FkIiwicGFzc2tleVVzZXJJZEZpZWxkTmFtZSIsInJlcSIsInVzZXIiLCJkb2NzIiwidXNlclBhc3NrZXlzIiwiZmluZCIsImNvbGxlY3Rpb24iLCJ3aGVyZSIsImVxdWFscyIsImxpbWl0IiwiZGVwdGgiLCJkaXYiLCJjbGFzc05hbWUiLCJoMyIsInN0eWxlIiwibWFyZ2luQm90dG9tIiwiaW5pdGlhbFBhc3NrZXlzIiwiZG9jdW1lbnRJZCIsImN1cnJlbnRVc2VySWQiXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPQSxXQUFXLFFBQU87QUFDekIsU0FBU0MsY0FBYyxRQUFRLFdBQVU7QUFDekMsT0FBTyxlQUFjO0FBR3JCLE9BQU8sTUFBTUMsV0FBbUQsT0FBT0M7SUFDckUsTUFBTSxFQUFFQyxFQUFFLEVBQUVDLFdBQVcsRUFBRUMsT0FBTyxFQUFFQyxzQkFBc0IsRUFBRUMsR0FBRyxFQUFFQyxJQUFJLEVBQUUsR0FBR047SUFFeEUsSUFBSSxDQUFDQyxNQUFNLENBQUNDLGVBQWUsQ0FBQ0Usd0JBQXdCLE9BQU87SUFFM0QsTUFBTSxFQUFFRyxNQUFNQyxZQUFZLEVBQUUsR0FBRyxNQUFNTCxRQUFRTSxJQUFJLENBQUM7UUFDaERDLFlBQVlSO1FBQ1pTLE9BQU87WUFDTCxDQUFDUCx1QkFBdUIsRUFBRTtnQkFBRVEsUUFBUVg7WUFBRztRQUN6QztRQUNBWSxPQUFPO1FBQ1BSO1FBQ0FTLE9BQU87SUFDVDtJQUVBLHFCQUNFLE1BQUNDO1FBQUlDLFdBQVU7OzBCQUNiLEtBQUNDO2dCQUFHRCxXQUFVO2dCQUF3QkUsT0FBTztvQkFBRUMsY0FBYztnQkFBUzswQkFBRzs7MEJBR3pFLEtBQUNyQjtnQkFDQ3NCLGlCQUFpQlo7Z0JBQ2pCYSxZQUFZcEI7Z0JBQ1pxQixlQUFlaEIsTUFBTUw7Z0JBQ3JCQyxhQUFhQTtnQkFDYkUsd0JBQXdCQTs7OztBQUloQyxFQUFDIn0=
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
@layer payload-default {
|
|
2
|
+
.passkeys-modal {
|
|
3
|
+
position: fixed;
|
|
4
|
+
inset: 0;
|
|
5
|
+
z-index: 1000;
|
|
6
|
+
display: flex;
|
|
7
|
+
align-items: center;
|
|
8
|
+
justify-content: center;
|
|
9
|
+
height: 100%;
|
|
10
|
+
|
|
11
|
+
&:before {
|
|
12
|
+
content: '';
|
|
13
|
+
position: absolute;
|
|
14
|
+
inset: 0;
|
|
15
|
+
background: rgba(0, 0, 0, 0.8);
|
|
16
|
+
z-index: 0;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
&__wrapper {
|
|
20
|
+
z-index: 1;
|
|
21
|
+
position: relative;
|
|
22
|
+
display: flex;
|
|
23
|
+
flex-direction: column;
|
|
24
|
+
gap: 16px;
|
|
25
|
+
border-radius: 3px;
|
|
26
|
+
border: 1px solid var(--theme-border-color);
|
|
27
|
+
background-color: var(--theme-elevation-50);
|
|
28
|
+
min-width: 340px;
|
|
29
|
+
max-width: 90vw;
|
|
30
|
+
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
&__close-button {
|
|
34
|
+
position: absolute;
|
|
35
|
+
top: 0;
|
|
36
|
+
right: 0;
|
|
37
|
+
margin-block: 0 !important;
|
|
38
|
+
padding: 10px !important;
|
|
39
|
+
svg {
|
|
40
|
+
width: 24px;
|
|
41
|
+
height: 24px;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
&__content {
|
|
46
|
+
display: flex;
|
|
47
|
+
flex-direction: column;
|
|
48
|
+
gap: 1.5rem;
|
|
49
|
+
padding: 1.5rem 1.5rem 1rem 1.5rem;
|
|
50
|
+
h2 {
|
|
51
|
+
font-size: 1.5rem;
|
|
52
|
+
font-weight: 600;
|
|
53
|
+
margin: 0;
|
|
54
|
+
}
|
|
55
|
+
p {
|
|
56
|
+
margin: 0;
|
|
57
|
+
color: var(--theme-elevation-500);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
&__input {
|
|
62
|
+
margin-bottom: 1rem;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
.passkeys-field {
|
|
66
|
+
&__list {
|
|
67
|
+
list-style: disc;
|
|
68
|
+
padding-left: 0;
|
|
69
|
+
row-gap: 1rem;
|
|
70
|
+
display: flex;
|
|
71
|
+
flex-direction: column;
|
|
72
|
+
}
|
|
73
|
+
&__list-item {
|
|
74
|
+
display: flex;
|
|
75
|
+
background-color: var(--theme-input-bg);
|
|
76
|
+
align-items: center;
|
|
77
|
+
padding: 0.8rem 1rem;
|
|
78
|
+
gap: 0.5rem;
|
|
79
|
+
border: 1px solid var(--theme-elevation-150);
|
|
80
|
+
border-radius: var(--style-radius-m);
|
|
81
|
+
color: var(--theme-elevation-800);
|
|
82
|
+
}
|
|
83
|
+
&__list-item-date {
|
|
84
|
+
color: var(--theme-elevation-500);
|
|
85
|
+
}
|
|
86
|
+
&__delete-button {
|
|
87
|
+
margin-block: 0;
|
|
88
|
+
margin-left: auto;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { PasskeyWithId } from './types';
|
|
3
|
+
interface PasskeyListProps {
|
|
4
|
+
passkeys: PasskeyWithId[];
|
|
5
|
+
onDelete?: (id: string) => void;
|
|
6
|
+
}
|
|
7
|
+
export declare const PasskeyList: React.FC<PasskeyListProps>;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=list.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/components/passkeys/list.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAA;AAE5C,UAAU,gBAAgB;IACxB,QAAQ,EAAE,aAAa,EAAE,CAAA;IACzB,QAAQ,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,KAAK,IAAI,CAAA;CAChC;AAED,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAiClD,CAAA"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { Fingerprint, Trash } from "lucide-react";
|
|
5
|
+
import { Button } from "@payloadcms/ui";
|
|
6
|
+
export const PasskeyList = ({ passkeys, onDelete })=>{
|
|
7
|
+
if (passkeys.length === 0) return /*#__PURE__*/ _jsx("p", {
|
|
8
|
+
style: {
|
|
9
|
+
marginBottom: '1rem'
|
|
10
|
+
},
|
|
11
|
+
children: "No passkeys found."
|
|
12
|
+
});
|
|
13
|
+
return /*#__PURE__*/ _jsx("ul", {
|
|
14
|
+
className: "passkeys-field__list",
|
|
15
|
+
children: passkeys.map((pk)=>{
|
|
16
|
+
const { id, createdAt } = pk;
|
|
17
|
+
if (!id || !createdAt) return null;
|
|
18
|
+
return /*#__PURE__*/ _jsxs("li", {
|
|
19
|
+
className: "passkeys-field__list-item",
|
|
20
|
+
children: [
|
|
21
|
+
/*#__PURE__*/ _jsx(Fingerprint, {
|
|
22
|
+
size: 16
|
|
23
|
+
}),
|
|
24
|
+
/*#__PURE__*/ _jsx("span", {
|
|
25
|
+
children: pk.name || 'My Passkey'
|
|
26
|
+
}),
|
|
27
|
+
/*#__PURE__*/ _jsx("span", {
|
|
28
|
+
className: "passkeys-field__list-item-date",
|
|
29
|
+
children: " - "
|
|
30
|
+
}),
|
|
31
|
+
/*#__PURE__*/ _jsx("span", {
|
|
32
|
+
className: "passkeys-field__list-item-date",
|
|
33
|
+
children: new Date(createdAt).toLocaleString('en-US', {
|
|
34
|
+
month: 'long',
|
|
35
|
+
day: 'numeric',
|
|
36
|
+
year: 'numeric',
|
|
37
|
+
hour: 'numeric',
|
|
38
|
+
minute: '2-digit',
|
|
39
|
+
hour12: true
|
|
40
|
+
})
|
|
41
|
+
}),
|
|
42
|
+
onDelete && /*#__PURE__*/ _jsx(Button, {
|
|
43
|
+
buttonStyle: "none",
|
|
44
|
+
size: "small",
|
|
45
|
+
className: "passkeys-field__delete-button",
|
|
46
|
+
onClick: ()=>onDelete(id),
|
|
47
|
+
children: /*#__PURE__*/ _jsx(Trash, {
|
|
48
|
+
size: 16
|
|
49
|
+
})
|
|
50
|
+
})
|
|
51
|
+
]
|
|
52
|
+
}, id);
|
|
53
|
+
})
|
|
54
|
+
});
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC9jb21wb25lbnRzL3Bhc3NrZXlzL2xpc3QudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBGaW5nZXJwcmludCwgVHJhc2ggfSBmcm9tICdsdWNpZGUtcmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICdAcGF5bG9hZGNtcy91aSdcbmltcG9ydCB0eXBlIHsgUGFzc2tleVdpdGhJZCB9IGZyb20gJy4vdHlwZXMnXG5cbmludGVyZmFjZSBQYXNza2V5TGlzdFByb3BzIHtcbiAgcGFzc2tleXM6IFBhc3NrZXlXaXRoSWRbXVxuICBvbkRlbGV0ZT86IChpZDogc3RyaW5nKSA9PiB2b2lkXG59XG5cbmV4cG9ydCBjb25zdCBQYXNza2V5TGlzdDogUmVhY3QuRkM8UGFzc2tleUxpc3RQcm9wcz4gPSAoeyBwYXNza2V5cywgb25EZWxldGUgfSkgPT4ge1xuICBpZiAocGFzc2tleXMubGVuZ3RoID09PSAwKSByZXR1cm4gPHAgc3R5bGU9e3sgbWFyZ2luQm90dG9tOiAnMXJlbScgfX0+Tm8gcGFzc2tleXMgZm91bmQuPC9wPlxuXG4gIHJldHVybiAoXG4gICAgPHVsIGNsYXNzTmFtZT1cInBhc3NrZXlzLWZpZWxkX19saXN0XCI+XG4gICAgICB7cGFzc2tleXMubWFwKChwaykgPT4ge1xuICAgICAgICBjb25zdCB7IGlkLCBjcmVhdGVkQXQgfSA9IHBrXG4gICAgICAgIGlmICghaWQgfHwgIWNyZWF0ZWRBdCkgcmV0dXJuIG51bGxcbiAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICA8bGkga2V5PXtpZH0gY2xhc3NOYW1lPVwicGFzc2tleXMtZmllbGRfX2xpc3QtaXRlbVwiPlxuICAgICAgICAgICAgPEZpbmdlcnByaW50IHNpemU9ezE2fSAvPlxuICAgICAgICAgICAgPHNwYW4+e3BrLm5hbWUgfHwgJ015IFBhc3NrZXknfTwvc3Bhbj5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT1cInBhc3NrZXlzLWZpZWxkX19saXN0LWl0ZW0tZGF0ZVwiPiAtIDwvc3Bhbj5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT1cInBhc3NrZXlzLWZpZWxkX19saXN0LWl0ZW0tZGF0ZVwiPlxuICAgICAgICAgICAgICB7bmV3IERhdGUoY3JlYXRlZEF0KS50b0xvY2FsZVN0cmluZygnZW4tVVMnLCB7XG4gICAgICAgICAgICAgICAgbW9udGg6ICdsb25nJyxcbiAgICAgICAgICAgICAgICBkYXk6ICdudW1lcmljJyxcbiAgICAgICAgICAgICAgICB5ZWFyOiAnbnVtZXJpYycsXG4gICAgICAgICAgICAgICAgaG91cjogJ251bWVyaWMnLFxuICAgICAgICAgICAgICAgIG1pbnV0ZTogJzItZGlnaXQnLFxuICAgICAgICAgICAgICAgIGhvdXIxMjogdHJ1ZVxuICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICAgIHtvbkRlbGV0ZSAmJiAoXG4gICAgICAgICAgICAgIDxCdXR0b24gYnV0dG9uU3R5bGU9XCJub25lXCIgc2l6ZT1cInNtYWxsXCIgY2xhc3NOYW1lPVwicGFzc2tleXMtZmllbGRfX2RlbGV0ZS1idXR0b25cIiBvbkNsaWNrPXsoKSA9PiBvbkRlbGV0ZShpZCl9PlxuICAgICAgICAgICAgICAgIDxUcmFzaCBzaXplPXsxNn0gLz5cbiAgICAgICAgICAgICAgPC9CdXR0b24+XG4gICAgICAgICAgICApfVxuICAgICAgICAgIDwvbGk+XG4gICAgICAgIClcbiAgICAgIH0pfVxuICAgIDwvdWw+XG4gIClcbn1cbiJdLCJuYW1lcyI6WyJSZWFjdCIsIkZpbmdlcnByaW50IiwiVHJhc2giLCJCdXR0b24iLCJQYXNza2V5TGlzdCIsInBhc3NrZXlzIiwib25EZWxldGUiLCJsZW5ndGgiLCJwIiwic3R5bGUiLCJtYXJnaW5Cb3R0b20iLCJ1bCIsImNsYXNzTmFtZSIsIm1hcCIsInBrIiwiaWQiLCJjcmVhdGVkQXQiLCJsaSIsInNpemUiLCJzcGFuIiwibmFtZSIsIkRhdGUiLCJ0b0xvY2FsZVN0cmluZyIsIm1vbnRoIiwiZGF5IiwieWVhciIsImhvdXIiLCJtaW51dGUiLCJob3VyMTIiLCJidXR0b25TdHlsZSIsIm9uQ2xpY2siXSwibWFwcGluZ3MiOiJBQUFBOztBQUVBLE9BQU9BLFdBQVcsUUFBTztBQUN6QixTQUFTQyxXQUFXLEVBQUVDLEtBQUssUUFBUSxlQUFjO0FBQ2pELFNBQVNDLE1BQU0sUUFBUSxpQkFBZ0I7QUFRdkMsT0FBTyxNQUFNQyxjQUEwQyxDQUFDLEVBQUVDLFFBQVEsRUFBRUMsUUFBUSxFQUFFO0lBQzVFLElBQUlELFNBQVNFLE1BQU0sS0FBSyxHQUFHLHFCQUFPLEtBQUNDO1FBQUVDLE9BQU87WUFBRUMsY0FBYztRQUFPO2tCQUFHOztJQUV0RSxxQkFDRSxLQUFDQztRQUFHQyxXQUFVO2tCQUNYUCxTQUFTUSxHQUFHLENBQUMsQ0FBQ0M7WUFDYixNQUFNLEVBQUVDLEVBQUUsRUFBRUMsU0FBUyxFQUFFLEdBQUdGO1lBQzFCLElBQUksQ0FBQ0MsTUFBTSxDQUFDQyxXQUFXLE9BQU87WUFDOUIscUJBQ0UsTUFBQ0M7Z0JBQVlMLFdBQVU7O2tDQUNyQixLQUFDWDt3QkFBWWlCLE1BQU07O2tDQUNuQixLQUFDQztrQ0FBTUwsR0FBR00sSUFBSSxJQUFJOztrQ0FDbEIsS0FBQ0Q7d0JBQUtQLFdBQVU7a0NBQWlDOztrQ0FDakQsS0FBQ087d0JBQUtQLFdBQVU7a0NBQ2IsSUFBSVMsS0FBS0wsV0FBV00sY0FBYyxDQUFDLFNBQVM7NEJBQzNDQyxPQUFPOzRCQUNQQyxLQUFLOzRCQUNMQyxNQUFNOzRCQUNOQyxNQUFNOzRCQUNOQyxRQUFROzRCQUNSQyxRQUFRO3dCQUNWOztvQkFFRHRCLDBCQUNDLEtBQUNIO3dCQUFPMEIsYUFBWTt3QkFBT1gsTUFBSzt3QkFBUU4sV0FBVTt3QkFBZ0NrQixTQUFTLElBQU14QixTQUFTUztrQ0FDeEcsY0FBQSxLQUFDYjs0QkFBTWdCLE1BQU07Ozs7ZUFoQlZIO1FBcUJiOztBQUdOLEVBQUMifQ==
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { UIFieldServerProps } from 'payload';
|
|
2
|
+
import type { BuildSchema } from '@/better-auth/types';
|
|
3
|
+
import type { Passkey } from '@/better-auth/generated-types';
|
|
4
|
+
export type PasskeyWithId = Passkey & {
|
|
5
|
+
id: string;
|
|
6
|
+
createdAt: Date;
|
|
7
|
+
};
|
|
8
|
+
export type PasskeysServerComponentProps = UIFieldServerProps & {
|
|
9
|
+
schema: BuildSchema;
|
|
10
|
+
passkeySlug: string;
|
|
11
|
+
passkeyUserIdFieldName: string;
|
|
12
|
+
};
|
|
13
|
+
export type PasskeysClientComponentProps = {
|
|
14
|
+
initialPasskeys: PasskeyWithId[];
|
|
15
|
+
documentId: string | number;
|
|
16
|
+
currentUserId: string | number;
|
|
17
|
+
passkeySlug: string;
|
|
18
|
+
passkeyUserIdFieldName: string;
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/components/passkeys/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAA;AACjD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AACtD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAA;AAE5D,MAAM,MAAM,aAAa,GAAG,OAAO,GAAG;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,IAAI,CAAA;CAAE,CAAA;AAErE,MAAM,MAAM,4BAA4B,GAAG,kBAAkB,GAAG;IAC9D,MAAM,EAAE,WAAW,CAAA;IACnB,WAAW,EAAE,MAAM,CAAA;IACnB,sBAAsB,EAAE,MAAM,CAAA;CAC/B,CAAA;AAED,MAAM,MAAM,4BAA4B,GAAG;IACzC,eAAe,EAAE,aAAa,EAAE,CAAA;IAChC,UAAU,EAAE,MAAM,GAAG,MAAM,CAAA;IAC3B,aAAa,EAAE,MAAM,GAAG,MAAM,CAAA;IAC9B,WAAW,EAAE,MAAM,CAAA;IACnB,sBAAsB,EAAE,MAAM,CAAA;CAC/B,CAAA"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { };
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC9jb21wb25lbnRzL3Bhc3NrZXlzL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVUlGaWVsZFNlcnZlclByb3BzIH0gZnJvbSAncGF5bG9hZCdcbmltcG9ydCB0eXBlIHsgQnVpbGRTY2hlbWEgfSBmcm9tICdAL2JldHRlci1hdXRoL3R5cGVzJ1xuaW1wb3J0IHR5cGUgeyBQYXNza2V5IH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9nZW5lcmF0ZWQtdHlwZXMnXG5cbmV4cG9ydCB0eXBlIFBhc3NrZXlXaXRoSWQgPSBQYXNza2V5ICYgeyBpZDogc3RyaW5nOyBjcmVhdGVkQXQ6IERhdGUgfVxuXG5leHBvcnQgdHlwZSBQYXNza2V5c1NlcnZlckNvbXBvbmVudFByb3BzID0gVUlGaWVsZFNlcnZlclByb3BzICYge1xuICBzY2hlbWE6IEJ1aWxkU2NoZW1hXG4gIHBhc3NrZXlTbHVnOiBzdHJpbmdcbiAgcGFzc2tleVVzZXJJZEZpZWxkTmFtZTogc3RyaW5nXG59XG5cbmV4cG9ydCB0eXBlIFBhc3NrZXlzQ2xpZW50Q29tcG9uZW50UHJvcHMgPSB7XG4gIGluaXRpYWxQYXNza2V5czogUGFzc2tleVdpdGhJZFtdXG4gIGRvY3VtZW50SWQ6IHN0cmluZyB8IG51bWJlclxuICBjdXJyZW50VXNlcklkOiBzdHJpbmcgfCBudW1iZXJcbiAgcGFzc2tleVNsdWc6IHN0cmluZ1xuICBwYXNza2V5VXNlcklkRmllbGROYW1lOiBzdHJpbmdcbn1cblxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlBLFdBTUMifQ==
|
|
@@ -4,5 +4,6 @@ import ForgotPassword from '../views/forgot-password';
|
|
|
4
4
|
import ResetPassword from '../views/reset-password';
|
|
5
5
|
import RSCRedirect from '../components/rsc-redirect';
|
|
6
6
|
import TwoFactorVerify from '../views/two-factor-verify';
|
|
7
|
-
|
|
7
|
+
import { Passkeys } from '../components/passkeys';
|
|
8
|
+
export { AdminSignup, AdminLogin, ForgotPassword, ResetPassword, RSCRedirect, TwoFactorVerify, Passkeys };
|
|
8
9
|
//# sourceMappingURL=rsc.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rsc.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/payload/exports/rsc.ts"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,uBAAuB,CAAA;AAC/C,OAAO,UAAU,MAAM,sBAAsB,CAAA;AAC7C,OAAO,cAAc,MAAM,0BAA0B,CAAA;AACrD,OAAO,aAAa,MAAM,yBAAyB,CAAA;AACnD,OAAO,WAAW,MAAM,4BAA4B,CAAA;AACpD,OAAO,eAAe,MAAM,4BAA4B,CAAA;
|
|
1
|
+
{"version":3,"file":"rsc.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/payload/exports/rsc.ts"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,uBAAuB,CAAA;AAC/C,OAAO,UAAU,MAAM,sBAAsB,CAAA;AAC7C,OAAO,cAAc,MAAM,0BAA0B,CAAA;AACrD,OAAO,aAAa,MAAM,yBAAyB,CAAA;AACnD,OAAO,WAAW,MAAM,4BAA4B,CAAA;AACpD,OAAO,eAAe,MAAM,4BAA4B,CAAA;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAA;AAEjD,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,aAAa,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,CAAA"}
|
|
@@ -4,6 +4,7 @@ import ForgotPassword from "../views/forgot-password";
|
|
|
4
4
|
import ResetPassword from "../views/reset-password";
|
|
5
5
|
import RSCRedirect from "../components/rsc-redirect";
|
|
6
6
|
import TwoFactorVerify from "../views/two-factor-verify";
|
|
7
|
-
|
|
7
|
+
import { Passkeys } from "../components/passkeys";
|
|
8
|
+
export { AdminSignup, AdminLogin, ForgotPassword, ResetPassword, RSCRedirect, TwoFactorVerify, Passkeys };
|
|
8
9
|
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC9leHBvcnRzL3JzYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQWRtaW5TaWdudXAgZnJvbSAnLi4vdmlld3MvYWRtaW4tc2lnbnVwJ1xuaW1wb3J0IEFkbWluTG9naW4gZnJvbSAnLi4vdmlld3MvYWRtaW4tbG9naW4nXG5pbXBvcnQgRm9yZ290UGFzc3dvcmQgZnJvbSAnLi4vdmlld3MvZm9yZ290LXBhc3N3b3JkJ1xuaW1wb3J0IFJlc2V0UGFzc3dvcmQgZnJvbSAnLi4vdmlld3MvcmVzZXQtcGFzc3dvcmQnXG5pbXBvcnQgUlNDUmVkaXJlY3QgZnJvbSAnLi4vY29tcG9uZW50cy9yc2MtcmVkaXJlY3QnXG5pbXBvcnQgVHdvRmFjdG9yVmVyaWZ5IGZyb20gJy4uL3ZpZXdzL3R3by1mYWN0b3ItdmVyaWZ5J1xuaW1wb3J0IHsgUGFzc2tleXMgfSBmcm9tICcuLi9jb21wb25lbnRzL3Bhc3NrZXlzJ1xuXG5leHBvcnQgeyBBZG1pblNpZ251cCwgQWRtaW5Mb2dpbiwgRm9yZ290UGFzc3dvcmQsIFJlc2V0UGFzc3dvcmQsIFJTQ1JlZGlyZWN0LCBUd29GYWN0b3JWZXJpZnksIFBhc3NrZXlzIH1cbiJdLCJuYW1lcyI6WyJBZG1pblNpZ251cCIsIkFkbWluTG9naW4iLCJGb3Jnb3RQYXNzd29yZCIsIlJlc2V0UGFzc3dvcmQiLCJSU0NSZWRpcmVjdCIsIlR3b0ZhY3RvclZlcmlmeSIsIlBhc3NrZXlzIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxpQkFBaUIsd0JBQXVCO0FBQy9DLE9BQU9DLGdCQUFnQix1QkFBc0I7QUFDN0MsT0FBT0Msb0JBQW9CLDJCQUEwQjtBQUNyRCxPQUFPQyxtQkFBbUIsMEJBQXlCO0FBQ25ELE9BQU9DLGlCQUFpQiw2QkFBNEI7QUFDcEQsT0FBT0MscUJBQXFCLDZCQUE0QjtBQUN4RCxTQUFTQyxRQUFRLFFBQVEseUJBQXdCO0FBRWpELFNBQVNOLFdBQVcsRUFBRUMsVUFBVSxFQUFFQyxjQUFjLEVBQUVDLGFBQWEsRUFBRUMsV0FBVyxFQUFFQyxlQUFlLEVBQUVDLFFBQVEsR0FBRSJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"names":[],"mappings":"AAKA,OAAO,KAA4B,MAAM,OAAO,CAAA;AAChD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAA;AAYvD,KAAK,qBAAqB,GAAG;IAC3B,YAAY,EAAE,WAAW,EAAE,CAAA;IAC3B,iBAAiB,EAAE,OAAO,CAAA;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,YAAY,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;IAC9D,iBAAiB,EAAE,KAAK,GAAG,wBAAwB,CAAA;CACpD,CAAA;
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"names":[],"mappings":"AAKA,OAAO,KAA4B,MAAM,OAAO,CAAA;AAChD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAA;AAYvD,KAAK,qBAAqB,GAAG;IAC3B,YAAY,EAAE,WAAW,EAAE,CAAA;IAC3B,iBAAiB,EAAE,OAAO,CAAA;IAC1B,gBAAgB,EAAE,OAAO,CAAA;IACzB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,YAAY,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;IAC9D,iBAAiB,EAAE,KAAK,GAAG,wBAAwB,CAAA;CACpD,CAAA;AA4HD,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CA+B5D,CAAA"}
|
|
@@ -10,12 +10,12 @@ import { Form, FormError, FormInputWrap } from "../../../../../shared/form/ui";
|
|
|
10
10
|
import { FormHeader } from "../../../../../shared/form/ui/header";
|
|
11
11
|
import { createLoginSchema, isValidEmail } from "../../../../../shared/form/validation";
|
|
12
12
|
import { createAuthClient } from "better-auth/client";
|
|
13
|
-
import { usernameClient, twoFactorClient } from "better-auth/client/plugins";
|
|
13
|
+
import { usernameClient, twoFactorClient, passkeyClient } from "better-auth/client/plugins";
|
|
14
14
|
import { formatAdminURL, getLoginOptions } from "payload/shared";
|
|
15
15
|
import { useRouter } from "next/navigation";
|
|
16
16
|
import { valueOrDefaultString } from "../../../../../shared/utils/value-or-default";
|
|
17
17
|
const baseClass = 'login__form';
|
|
18
|
-
const LoginForm = ({ hasUsernamePlugin, prefillEmail, prefillPassword, prefillUsername, searchParams, loginWithUsername })=>{
|
|
18
|
+
const LoginForm = ({ hasUsernamePlugin, hasPasskeyPlugin, prefillEmail, prefillPassword, prefillUsername, searchParams, loginWithUsername })=>{
|
|
19
19
|
const { config } = useConfig();
|
|
20
20
|
const router = useRouter();
|
|
21
21
|
const adminRoute = valueOrDefaultString(config?.routes?.admin, '/admin');
|
|
@@ -34,7 +34,10 @@ const LoginForm = ({ hasUsernamePlugin, prefillEmail, prefillPassword, prefillUs
|
|
|
34
34
|
onTwoFactorRedirect () {
|
|
35
35
|
router.push(`${adminRoute}${adminRoutes.twoFactorVerify}?redirect=${redirectUrl}`);
|
|
36
36
|
}
|
|
37
|
-
})
|
|
37
|
+
}),
|
|
38
|
+
...hasPasskeyPlugin ? [
|
|
39
|
+
passkeyClient()
|
|
40
|
+
] : []
|
|
38
41
|
]
|
|
39
42
|
}), []);
|
|
40
43
|
const loginType = useMemo(()=>{
|
|
@@ -129,7 +132,7 @@ const LoginForm = ({ hasUsernamePlugin, prefillEmail, prefillPassword, prefillUs
|
|
|
129
132
|
children: (field)=>/*#__PURE__*/ _jsx(field.TextField, {
|
|
130
133
|
type: "text",
|
|
131
134
|
className: "email",
|
|
132
|
-
autoComplete:
|
|
135
|
+
autoComplete: `email${hasPasskeyPlugin ? ' webauthn' : ''}`,
|
|
133
136
|
label: getLoginTypeLabel()
|
|
134
137
|
})
|
|
135
138
|
}),
|
|
@@ -138,7 +141,7 @@ const LoginForm = ({ hasUsernamePlugin, prefillEmail, prefillPassword, prefillUs
|
|
|
138
141
|
children: (field)=>/*#__PURE__*/ _jsx(field.TextField, {
|
|
139
142
|
type: "password",
|
|
140
143
|
className: "password",
|
|
141
|
-
autoComplete:
|
|
144
|
+
autoComplete: `password${hasPasskeyPlugin ? ' webauthn' : ''}`,
|
|
142
145
|
label: t('general:password')
|
|
143
146
|
})
|
|
144
147
|
})
|
|
@@ -160,11 +163,12 @@ const LoginForm = ({ hasUsernamePlugin, prefillEmail, prefillPassword, prefillUs
|
|
|
160
163
|
]
|
|
161
164
|
});
|
|
162
165
|
};
|
|
163
|
-
export const AdminLoginClient = ({ loginMethods, hasUsernamePlugin, prefillEmail, prefillPassword, prefillUsername, searchParams, loginWithUsername })=>{
|
|
166
|
+
export const AdminLoginClient = ({ loginMethods, hasUsernamePlugin, hasPasskeyPlugin, prefillEmail, prefillPassword, prefillUsername, searchParams, loginWithUsername })=>{
|
|
164
167
|
return /*#__PURE__*/ _jsxs(_Fragment, {
|
|
165
168
|
children: [
|
|
166
169
|
loginMethods.includes('emailPassword') && /*#__PURE__*/ _jsx(LoginForm, {
|
|
167
170
|
hasUsernamePlugin: hasUsernamePlugin,
|
|
171
|
+
hasPasskeyPlugin: hasPasskeyPlugin,
|
|
168
172
|
prefillEmail: prefillEmail,
|
|
169
173
|
prefillPassword: prefillPassword,
|
|
170
174
|
prefillUsername: prefillUsername,
|
|
@@ -181,4 +185,4 @@ export const AdminLoginClient = ({ loginMethods, hasUsernamePlugin, prefillEmail
|
|
|
181
185
|
});
|
|
182
186
|
};
|
|
183
187
|
|
|
184
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"sourcesContent":["'use client'\n\nimport { AdminSocialProviderButtons } from '@/better-auth/plugin/payload/components/social-provider-buttons'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { useConfig, Link, toast, useTranslation } from '@payloadcms/ui'\nimport React, { useMemo, useState } from 'react'\nimport type { LoginMethod } from '@/better-auth/plugin/types'\nimport type { LoginWithUsernameOptions } from 'payload'\nimport { adminRoutes } from '@/better-auth/plugin/constants'\nimport { useAppForm } from '@/shared/form'\nimport { Form, FormError, FormInputWrap } from '@/shared/form/ui'\nimport { FormHeader } from '@/shared/form/ui/header'\nimport { createLoginSchema, isValidEmail } from '@/shared/form/validation'\nimport { createAuthClient } from 'better-auth/client'\nimport { usernameClient, twoFactorClient } from 'better-auth/client/plugins'\nimport { formatAdminURL, getLoginOptions } from 'payload/shared'\nimport { useRouter } from 'next/navigation'\nimport { valueOrDefaultString } from '@/shared/utils/value-or-default'\n\ntype AdminLoginClientProps = {\n  loginMethods: LoginMethod[]\n  hasUsernamePlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}\n\nconst baseClass = 'login__form'\n\nconst LoginForm: React.FC<{\n  hasUsernamePlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}> = ({ hasUsernamePlugin, prefillEmail, prefillPassword, prefillUsername, searchParams, loginWithUsername }) => {\n  const { config } = useConfig()\n  const router = useRouter()\n  const adminRoute = valueOrDefaultString(config?.routes?.admin, '/admin')\n  const { t } = useTranslation()\n  const { canLoginWithEmail, canLoginWithUsername } = getLoginOptions(loginWithUsername)\n  const searchParamError = searchParams?.error\n  const redirectUrl = getSafeRedirect(searchParams?.redirect as string, adminRoute)\n  const forgotPasswordUrl = formatAdminURL({\n    adminRoute: adminRoute,\n    path: adminRoutes?.forgotPassword as `/${string}`\n  })\n  const authClient = useMemo(\n    () =>\n      createAuthClient({\n        plugins: [\n          usernameClient(),\n          twoFactorClient({\n            onTwoFactorRedirect() {\n              router.push(`${adminRoute}${adminRoutes.twoFactorVerify}?redirect=${redirectUrl}`)\n            }\n          })\n        ]\n      }),\n    []\n  )\n  const loginType = useMemo(() => {\n    if (canLoginWithEmail && canLoginWithUsername && hasUsernamePlugin) return 'emailOrUsername'\n    if (canLoginWithUsername && hasUsernamePlugin) return 'username'\n    return 'email'\n  }, [canLoginWithEmail, canLoginWithUsername, hasUsernamePlugin])\n  const [requireEmailVerification, setRequireEmailVerification] = useState<boolean>(false)\n\n  if (requireEmailVerification) {\n    return <FormHeader heading=\"Please verify your email\" description={t('authentication:emailSent')} style={{ textAlign: 'center' }} />\n  }\n\n  const loginSchema = createLoginSchema({ t, loginType, canLoginWithUsername })\n\n  const form = useAppForm({\n    defaultValues: {\n      login: prefillEmail ?? prefillUsername ?? '',\n      password: prefillPassword ?? ''\n    },\n    onSubmit: async ({ value }) => {\n      const { login, password } = value\n      const isEmail = isValidEmail(login)\n      try {\n        const { data, error } = await (loginType === 'email' || (loginType === 'emailOrUsername' && isEmail)\n          ? authClient.signIn.email({ email: login, password, callbackURL: redirectUrl })\n          : authClient.signIn.username({ username: login, password }))\n        if (error) {\n          if (error.code === 'EMAIL_NOT_VERIFIED') {\n            setRequireEmailVerification(true)\n          }\n          if (error.message) {\n            toast.error(error.message.charAt(0).toUpperCase() + error.message.slice(1))\n          }\n        }\n        if (data?.token) {\n          toast.success(t('general:success'))\n          window.location.href = redirectUrl\n        }\n      } catch (err) {\n        toast.error(t('error:unknown') || 'An unexpected error occurred')\n      }\n    },\n    validators: {\n      onSubmit: loginSchema\n    }\n  })\n\n  const getLoginTypeLabel = () => {\n    const labels = {\n      email: t('general:email') || 'Email',\n      username: t('authentication:username') || 'Username',\n      emailOrUsername: t('authentication:emailOrUsername') || 'Email or Username'\n    }\n    return labels[loginType]\n  }\n\n  return (\n    <div className={`${baseClass}__wrapper`}>\n      {searchParamError && searchParamError === 'signup_disabled' && <FormError errors={['Sign up is disabled.']} />}\n      <Form\n        className={baseClass}\n        onSubmit={(e) => {\n          e.preventDefault()\n          void form.handleSubmit()\n        }}>\n        <FormInputWrap className={baseClass}>\n          <form.AppField\n            name=\"login\"\n            children={(field) => <field.TextField type=\"text\" className=\"email\" autoComplete=\"email\" label={getLoginTypeLabel()} />}\n          />\n          <form.AppField\n            name=\"password\"\n            children={(field) => (\n              <field.TextField type=\"password\" className=\"password\" autoComplete=\"password\" label={t('general:password')} />\n            )}\n          />\n        </FormInputWrap>\n        <Link href={forgotPasswordUrl} prefetch={false}>\n          {t('authentication:forgotPasswordQuestion')}\n        </Link>\n        <form.AppForm children={<form.Submit label={t('authentication:login')} loadingLabel={t('general:loading')} />} />\n      </Form>\n    </div>\n  )\n}\n\nexport const AdminLoginClient: React.FC<AdminLoginClientProps> = ({\n  loginMethods,\n  hasUsernamePlugin,\n  prefillEmail,\n  prefillPassword,\n  prefillUsername,\n  searchParams,\n  loginWithUsername\n}) => {\n  return (\n    <>\n      {loginMethods.includes('emailPassword') && (\n        <LoginForm\n          hasUsernamePlugin={hasUsernamePlugin}\n          prefillEmail={prefillEmail}\n          prefillPassword={prefillPassword}\n          prefillUsername={prefillUsername}\n          searchParams={searchParams}\n          loginWithUsername={loginWithUsername}\n        />\n      )}\n      <AdminSocialProviderButtons\n        isSignup={false}\n        loginMethods={loginMethods}\n        setLoading={() => {}}\n        redirectUrl={getSafeRedirect(searchParams?.redirect as string, useConfig().config.routes.admin)}\n      />\n    </>\n  )\n}\n"],"names":["AdminSocialProviderButtons","getSafeRedirect","useConfig","Link","toast","useTranslation","React","useMemo","useState","adminRoutes","useAppForm","Form","FormError","FormInputWrap","FormHeader","createLoginSchema","isValidEmail","createAuthClient","usernameClient","twoFactorClient","formatAdminURL","getLoginOptions","useRouter","valueOrDefaultString","baseClass","LoginForm","hasUsernamePlugin","prefillEmail","prefillPassword","prefillUsername","searchParams","loginWithUsername","config","router","adminRoute","routes","admin","t","canLoginWithEmail","canLoginWithUsername","searchParamError","error","redirectUrl","redirect","forgotPasswordUrl","path","forgotPassword","authClient","plugins","onTwoFactorRedirect","push","twoFactorVerify","loginType","requireEmailVerification","setRequireEmailVerification","heading","description","style","textAlign","loginSchema","form","defaultValues","login","password","onSubmit","value","isEmail","data","signIn","email","callbackURL","username","code","message","charAt","toUpperCase","slice","token","success","window","location","href","err","validators","getLoginTypeLabel","labels","emailOrUsername","div","className","errors","e","preventDefault","handleSubmit","AppField","name","children","field","TextField","type","autoComplete","label","prefetch","AppForm","Submit","loadingLabel","AdminLoginClient","loginMethods","includes","isSignup","setLoading"],"mappings":"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"}
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"sourcesContent":["'use client'\n\nimport { AdminSocialProviderButtons } from '@/better-auth/plugin/payload/components/social-provider-buttons'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { useConfig, Link, toast, useTranslation } from '@payloadcms/ui'\nimport React, { useMemo, useState } from 'react'\nimport type { LoginMethod } from '@/better-auth/plugin/types'\nimport type { LoginWithUsernameOptions } from 'payload'\nimport { adminRoutes } from '@/better-auth/plugin/constants'\nimport { useAppForm } from '@/shared/form'\nimport { Form, FormError, FormInputWrap } from '@/shared/form/ui'\nimport { FormHeader } from '@/shared/form/ui/header'\nimport { createLoginSchema, isValidEmail } from '@/shared/form/validation'\nimport { createAuthClient } from 'better-auth/client'\nimport { usernameClient, twoFactorClient, passkeyClient } from 'better-auth/client/plugins'\nimport { formatAdminURL, getLoginOptions } from 'payload/shared'\nimport { useRouter } from 'next/navigation'\nimport { valueOrDefaultString } from '@/shared/utils/value-or-default'\n\ntype AdminLoginClientProps = {\n  loginMethods: LoginMethod[]\n  hasUsernamePlugin: boolean\n  hasPasskeyPlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}\n\nconst baseClass = 'login__form'\n\nconst LoginForm: React.FC<{\n  hasUsernamePlugin: boolean\n  hasPasskeyPlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}> = ({ hasUsernamePlugin, hasPasskeyPlugin, prefillEmail, prefillPassword, prefillUsername, searchParams, loginWithUsername }) => {\n  const { config } = useConfig()\n  const router = useRouter()\n  const adminRoute = valueOrDefaultString(config?.routes?.admin, '/admin')\n  const { t } = useTranslation()\n  const { canLoginWithEmail, canLoginWithUsername } = getLoginOptions(loginWithUsername)\n  const searchParamError = searchParams?.error\n  const redirectUrl = getSafeRedirect(searchParams?.redirect as string, adminRoute)\n  const forgotPasswordUrl = formatAdminURL({\n    adminRoute: adminRoute,\n    path: adminRoutes?.forgotPassword as `/${string}`\n  })\n  const authClient = useMemo(\n    () =>\n      createAuthClient({\n        plugins: [\n          usernameClient(),\n          twoFactorClient({\n            onTwoFactorRedirect() {\n              router.push(`${adminRoute}${adminRoutes.twoFactorVerify}?redirect=${redirectUrl}`)\n            }\n          }),\n          ...(hasPasskeyPlugin ? [passkeyClient()] : [])\n        ]\n      }),\n    []\n  )\n  const loginType = useMemo(() => {\n    if (canLoginWithEmail && canLoginWithUsername && hasUsernamePlugin) return 'emailOrUsername'\n    if (canLoginWithUsername && hasUsernamePlugin) return 'username'\n    return 'email'\n  }, [canLoginWithEmail, canLoginWithUsername, hasUsernamePlugin])\n  const [requireEmailVerification, setRequireEmailVerification] = useState<boolean>(false)\n\n  if (requireEmailVerification) {\n    return <FormHeader heading=\"Please verify your email\" description={t('authentication:emailSent')} style={{ textAlign: 'center' }} />\n  }\n\n  const loginSchema = createLoginSchema({ t, loginType, canLoginWithUsername })\n\n  const form = useAppForm({\n    defaultValues: {\n      login: prefillEmail ?? prefillUsername ?? '',\n      password: prefillPassword ?? ''\n    },\n    onSubmit: async ({ value }) => {\n      const { login, password } = value\n      const isEmail = isValidEmail(login)\n      try {\n        const { data, error } = await (loginType === 'email' || (loginType === 'emailOrUsername' && isEmail)\n          ? authClient.signIn.email({ email: login, password, callbackURL: redirectUrl })\n          : authClient.signIn.username({ username: login, password }))\n        if (error) {\n          if (error.code === 'EMAIL_NOT_VERIFIED') {\n            setRequireEmailVerification(true)\n          }\n          if (error.message) {\n            toast.error(error.message.charAt(0).toUpperCase() + error.message.slice(1))\n          }\n        }\n        if (data?.token) {\n          toast.success(t('general:success'))\n          window.location.href = redirectUrl\n        }\n      } catch (err) {\n        toast.error(t('error:unknown') || 'An unexpected error occurred')\n      }\n    },\n    validators: {\n      onSubmit: loginSchema\n    }\n  })\n\n  const getLoginTypeLabel = () => {\n    const labels = {\n      email: t('general:email') || 'Email',\n      username: t('authentication:username') || 'Username',\n      emailOrUsername: t('authentication:emailOrUsername') || 'Email or Username'\n    }\n    return labels[loginType]\n  }\n\n  return (\n    <div className={`${baseClass}__wrapper`}>\n      {searchParamError && searchParamError === 'signup_disabled' && <FormError errors={['Sign up is disabled.']} />}\n      <Form\n        className={baseClass}\n        onSubmit={(e) => {\n          e.preventDefault()\n          void form.handleSubmit()\n        }}>\n        <FormInputWrap className={baseClass}>\n          <form.AppField\n            name=\"login\"\n            children={(field) => <field.TextField type=\"text\" className=\"email\" autoComplete={`email${hasPasskeyPlugin ? ' webauthn' : ''}`} label={getLoginTypeLabel()} />}\n          />\n          <form.AppField\n            name=\"password\"\n            children={(field) => (\n              <field.TextField type=\"password\" className=\"password\" autoComplete={`password${hasPasskeyPlugin ? ' webauthn' : ''}`} label={t('general:password')} />\n            )}\n          />\n        </FormInputWrap>\n        <Link href={forgotPasswordUrl} prefetch={false}>\n          {t('authentication:forgotPasswordQuestion')}\n        </Link>\n        <form.AppForm children={<form.Submit label={t('authentication:login')} loadingLabel={t('general:loading')} />} />\n      </Form>\n    </div>\n  )\n}\n\nexport const AdminLoginClient: React.FC<AdminLoginClientProps> = ({\n  loginMethods,\n  hasUsernamePlugin,\n  hasPasskeyPlugin,\n  prefillEmail,\n  prefillPassword,\n  prefillUsername,\n  searchParams,\n  loginWithUsername\n}) => {\n  return (\n    <>\n      {loginMethods.includes('emailPassword') && (\n        <LoginForm\n          hasUsernamePlugin={hasUsernamePlugin}\n          hasPasskeyPlugin={hasPasskeyPlugin}\n          prefillEmail={prefillEmail}\n          prefillPassword={prefillPassword}\n          prefillUsername={prefillUsername}\n          searchParams={searchParams}\n          loginWithUsername={loginWithUsername}\n        />\n      )}\n      <AdminSocialProviderButtons\n        isSignup={false}\n        loginMethods={loginMethods}\n        setLoading={() => {}}\n        redirectUrl={getSafeRedirect(searchParams?.redirect as string, useConfig().config.routes.admin)}\n      />\n    </>\n  )\n}\n"],"names":["AdminSocialProviderButtons","getSafeRedirect","useConfig","Link","toast","useTranslation","React","useMemo","useState","adminRoutes","useAppForm","Form","FormError","FormInputWrap","FormHeader","createLoginSchema","isValidEmail","createAuthClient","usernameClient","twoFactorClient","passkeyClient","formatAdminURL","getLoginOptions","useRouter","valueOrDefaultString","baseClass","LoginForm","hasUsernamePlugin","hasPasskeyPlugin","prefillEmail","prefillPassword","prefillUsername","searchParams","loginWithUsername","config","router","adminRoute","routes","admin","t","canLoginWithEmail","canLoginWithUsername","searchParamError","error","redirectUrl","redirect","forgotPasswordUrl","path","forgotPassword","authClient","plugins","onTwoFactorRedirect","push","twoFactorVerify","loginType","requireEmailVerification","setRequireEmailVerification","heading","description","style","textAlign","loginSchema","form","defaultValues","login","password","onSubmit","value","isEmail","data","signIn","email","callbackURL","username","code","message","charAt","toUpperCase","slice","token","success","window","location","href","err","validators","getLoginTypeLabel","labels","emailOrUsername","div","className","errors","e","preventDefault","handleSubmit","AppField","name","children","field","TextField","type","autoComplete","label","prefetch","AppForm","Submit","loadingLabel","AdminLoginClient","loginMethods","includes","isSignup","setLoading"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAUzB,OAAO,EAAE,KAAK,oBAAoB,EAAoB,MAAM,SAAS,CAAA;AACrE,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AAEzE,eAAO,MAAM,cAAc,UAAU,CAAA;AAErC,UAAU,eAAgB,SAAQ,oBAAoB;IACpD,oBAAoB,EAAE,MAAM,CAAA;IAC5B,aAAa,EAAE,uBAAuB,CAAA;CACvC;AAED,QAAA,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAUzB,OAAO,EAAE,KAAK,oBAAoB,EAAoB,MAAM,SAAS,CAAA;AACrE,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AAEzE,eAAO,MAAM,cAAc,UAAU,CAAA;AAErC,UAAU,eAAgB,SAAQ,oBAAoB;IACpD,oBAAoB,EAAE,MAAM,CAAA;IAC5B,aAAa,EAAE,uBAAuB,CAAA;CACvC;AAED,QAAA,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAmIzC,CAAA;AAED,eAAe,UAAU,CAAA"}
|
|
@@ -61,6 +61,7 @@ const AdminLogin = async ({ initPageResult, params, searchParams, pluginOptions,
|
|
|
61
61
|
const prefillEmail = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.email : undefined;
|
|
62
62
|
const prefillPassword = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.password : undefined;
|
|
63
63
|
const hasUsernamePlugin = checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.username);
|
|
64
|
+
const hasPasskeyPlugin = checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.passkey);
|
|
64
65
|
const loginMethods = pluginOptions.admin?.loginMethods ?? [];
|
|
65
66
|
const loginWithUsername = collections?.[userSlug]?.config.auth.loginWithUsername;
|
|
66
67
|
const canLoginWithUsername = (hasUsernamePlugin && loginWithUsername) ?? false;
|
|
@@ -95,6 +96,7 @@ const AdminLogin = async ({ initPageResult, params, searchParams, pluginOptions,
|
|
|
95
96
|
/*#__PURE__*/ _jsx(AdminLoginClient, {
|
|
96
97
|
loginWithUsername: canLoginWithUsername,
|
|
97
98
|
hasUsernamePlugin: hasUsernamePlugin,
|
|
99
|
+
hasPasskeyPlugin: hasPasskeyPlugin,
|
|
98
100
|
loginMethods: loginMethods,
|
|
99
101
|
prefillEmail: prefillEmail,
|
|
100
102
|
prefillPassword: prefillPassword,
|
|
@@ -119,4 +121,4 @@ const AdminLogin = async ({ initPageResult, params, searchParams, pluginOptions,
|
|
|
119
121
|
};
|
|
120
122
|
export default AdminLogin;
|
|
121
123
|
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/index.tsx"],"sourcesContent":["import React from 'react'\nimport { AdminLoginClient } from './client'\nimport { redirect } from 'next/navigation'\nimport { Logo } from '@/shared/components/logo'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { MinimalTemplate } from '@payloadcms/next/templates'\nimport { checkPluginExists } from '@/better-auth/plugin/helpers/check-plugin-exists'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { adminRoutes, defaults, supportedBAPluginIds } from '@/better-auth/plugin/constants'\n\nimport { type AdminViewServerProps, type ServerProps } from 'payload'\nimport type { BetterAuthPluginOptions } from '@/better-auth/plugin/types'\n\nexport const loginBaseClass = 'login'\n\ninterface AdminLoginProps extends AdminViewServerProps {\n  adminInvitationsSlug: string\n  pluginOptions: BetterAuthPluginOptions\n}\n\nconst AdminLogin: React.FC<AdminLoginProps> = async ({\n  initPageResult,\n  params,\n  searchParams,\n  pluginOptions,\n  adminInvitationsSlug\n}: AdminLoginProps) => {\n  const { locale, permissions, req } = initPageResult\n  const {\n    i18n,\n    payload: { config, collections },\n    payload,\n    user\n  } = req\n\n  const {\n    admin: { components: { afterLogin, beforeLogin } = {}, user: userSlug },\n    routes: { admin: adminRoute }\n  } = config\n\n  const adminRole = pluginOptions.users?.defaultAdminRole ?? defaults.adminRole\n  const redirectUrl = getSafeRedirect(searchParams?.redirect ?? '', adminRoute)\n\n  if (user) {\n    redirect(redirectUrl)\n  }\n\n  const adminCount = await req.payload.count({\n    collection: userSlug,\n    where: {\n      role: {\n        equals: adminRole\n      }\n    }\n  })\n\n  if (adminCount.totalDocs === 0) {\n    // Check if we already have an admin invitation\n    const existingInvitations = await req.payload.find({\n      collection: adminInvitationsSlug,\n      where: {\n        role: {\n          equals: adminRole\n        }\n      }\n    })\n\n    let token\n\n    if (existingInvitations.totalDocs > 0) {\n      // Use existing token\n      token = existingInvitations.docs[0].token\n    } else {\n      // Generate a new secure invite token\n      token = crypto.randomUUID()\n      await req.payload.create({\n        collection: adminInvitationsSlug,\n        data: {\n          role: adminRole,\n          token\n        }\n      })\n    }\n\n    redirect(`${adminRoute}${adminRoutes.adminSignup}?token=${token}`)\n  }\n\n  // Filter out the first component from afterLogin array or set to undefined if not more than 1\n  // This is because of the custom login redirect component, we don't want an infinite loop\n  const filteredAfterLogin = Array.isArray(afterLogin) && afterLogin.length > 1 ? afterLogin.slice(1) : undefined\n  const prefillAutoLogin = typeof config.admin?.autoLogin === 'object' && config.admin?.autoLogin.prefillOnly\n  const prefillUsername = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.username : undefined\n  const prefillEmail = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.email : undefined\n  const prefillPassword = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.password : undefined\n  const hasUsernamePlugin = checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.username)\n  const loginMethods = pluginOptions.admin?.loginMethods ?? []\n  const loginWithUsername = collections?.[userSlug]?.config.auth.loginWithUsername\n  const canLoginWithUsername = (hasUsernamePlugin && loginWithUsername) ?? false\n\n  return (\n    <MinimalTemplate className={loginBaseClass}>\n      <div className={`${loginBaseClass}__brand`}>\n        <Logo\n          i18n={i18n}\n          locale={locale}\n          params={params}\n          payload={payload}\n          permissions={permissions}\n          searchParams={searchParams}\n          user={user ?? undefined}\n        />\n      </div>\n      {RenderServerComponent({\n        Component: beforeLogin,\n        importMap: payload.importMap,\n        serverProps: {\n          i18n,\n          locale,\n          params,\n          payload,\n          permissions,\n          searchParams,\n          user: user ?? undefined\n        } satisfies ServerProps\n      })}\n      <AdminLoginClient\n        loginWithUsername={canLoginWithUsername}\n        hasUsernamePlugin={hasUsernamePlugin}\n        loginMethods={loginMethods}\n        prefillEmail={prefillEmail}\n        prefillPassword={prefillPassword}\n        prefillUsername={prefillUsername}\n        searchParams={searchParams ?? {}}\n      />\n      {RenderServerComponent({\n        Component: filteredAfterLogin,\n        importMap: payload.importMap,\n        serverProps: {\n          i18n,\n          locale,\n          params,\n          payload,\n          permissions,\n          searchParams,\n          user: user ?? undefined\n        } satisfies ServerProps\n      })}\n    </MinimalTemplate>\n  )\n}\n\nexport default AdminLogin\n"],"names":["React","AdminLoginClient","redirect","Logo","getSafeRedirect","MinimalTemplate","checkPluginExists","RenderServerComponent","adminRoutes","defaults","supportedBAPluginIds","loginBaseClass","AdminLogin","initPageResult","params","searchParams","pluginOptions","adminInvitationsSlug","locale","permissions","req","i18n","payload","config","collections","user","admin","components","afterLogin","beforeLogin","userSlug","routes","adminRoute","adminRole","users","defaultAdminRole","redirectUrl","adminCount","count","collection","where","role","equals","totalDocs","existingInvitations","find","token","docs","crypto","randomUUID","create","data","adminSignup","filteredAfterLogin","Array","isArray","length","slice","undefined","prefillAutoLogin","autoLogin","prefillOnly","prefillUsername","username","prefillEmail","email","prefillPassword","password","hasUsernamePlugin","betterAuthOptions","loginMethods","loginWithUsername","auth","canLoginWithUsername","className","div","Component","importMap","serverProps"],"mappings":"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"}
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/index.tsx"],"sourcesContent":["import React from 'react'\nimport { AdminLoginClient } from './client'\nimport { redirect } from 'next/navigation'\nimport { Logo } from '@/shared/components/logo'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { MinimalTemplate } from '@payloadcms/next/templates'\nimport { checkPluginExists } from '@/better-auth/plugin/helpers/check-plugin-exists'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { adminRoutes, defaults, supportedBAPluginIds } from '@/better-auth/plugin/constants'\n\nimport { type AdminViewServerProps, type ServerProps } from 'payload'\nimport type { BetterAuthPluginOptions } from '@/better-auth/plugin/types'\n\nexport const loginBaseClass = 'login'\n\ninterface AdminLoginProps extends AdminViewServerProps {\n  adminInvitationsSlug: string\n  pluginOptions: BetterAuthPluginOptions\n}\n\nconst AdminLogin: React.FC<AdminLoginProps> = async ({\n  initPageResult,\n  params,\n  searchParams,\n  pluginOptions,\n  adminInvitationsSlug\n}: AdminLoginProps) => {\n  const { locale, permissions, req } = initPageResult\n  const {\n    i18n,\n    payload: { config, collections },\n    payload,\n    user\n  } = req\n\n  const {\n    admin: { components: { afterLogin, beforeLogin } = {}, user: userSlug },\n    routes: { admin: adminRoute }\n  } = config\n\n  const adminRole = pluginOptions.users?.defaultAdminRole ?? defaults.adminRole\n  const redirectUrl = getSafeRedirect(searchParams?.redirect ?? '', adminRoute)\n\n  if (user) {\n    redirect(redirectUrl)\n  }\n\n  const adminCount = await req.payload.count({\n    collection: userSlug,\n    where: {\n      role: {\n        equals: adminRole\n      }\n    }\n  })\n\n  if (adminCount.totalDocs === 0) {\n    // Check if we already have an admin invitation\n    const existingInvitations = await req.payload.find({\n      collection: adminInvitationsSlug,\n      where: {\n        role: {\n          equals: adminRole\n        }\n      }\n    })\n\n    let token\n\n    if (existingInvitations.totalDocs > 0) {\n      // Use existing token\n      token = existingInvitations.docs[0].token\n    } else {\n      // Generate a new secure invite token\n      token = crypto.randomUUID()\n      await req.payload.create({\n        collection: adminInvitationsSlug,\n        data: {\n          role: adminRole,\n          token\n        }\n      })\n    }\n\n    redirect(`${adminRoute}${adminRoutes.adminSignup}?token=${token}`)\n  }\n\n  // Filter out the first component from afterLogin array or set to undefined if not more than 1\n  // This is because of the custom login redirect component, we don't want an infinite loop\n  const filteredAfterLogin = Array.isArray(afterLogin) && afterLogin.length > 1 ? afterLogin.slice(1) : undefined\n  const prefillAutoLogin = typeof config.admin?.autoLogin === 'object' && config.admin?.autoLogin.prefillOnly\n  const prefillUsername = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.username : undefined\n  const prefillEmail = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.email : undefined\n  const prefillPassword = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.password : undefined\n  const hasUsernamePlugin = checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.username)\n  const hasPasskeyPlugin = checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.passkey)\n  const loginMethods = pluginOptions.admin?.loginMethods ?? []\n  const loginWithUsername = collections?.[userSlug]?.config.auth.loginWithUsername\n  const canLoginWithUsername = (hasUsernamePlugin && loginWithUsername) ?? false\n\n  return (\n    <MinimalTemplate className={loginBaseClass}>\n      <div className={`${loginBaseClass}__brand`}>\n        <Logo\n          i18n={i18n}\n          locale={locale}\n          params={params}\n          payload={payload}\n          permissions={permissions}\n          searchParams={searchParams}\n          user={user ?? undefined}\n        />\n      </div>\n      {RenderServerComponent({\n        Component: beforeLogin,\n        importMap: payload.importMap,\n        serverProps: {\n          i18n,\n          locale,\n          params,\n          payload,\n          permissions,\n          searchParams,\n          user: user ?? undefined\n        } satisfies ServerProps\n      })}\n      <AdminLoginClient\n        loginWithUsername={canLoginWithUsername}\n        hasUsernamePlugin={hasUsernamePlugin}\n        hasPasskeyPlugin={hasPasskeyPlugin}\n        loginMethods={loginMethods}\n        prefillEmail={prefillEmail}\n        prefillPassword={prefillPassword}\n        prefillUsername={prefillUsername}\n        searchParams={searchParams ?? {}}\n      />\n      {RenderServerComponent({\n        Component: filteredAfterLogin,\n        importMap: payload.importMap,\n        serverProps: {\n          i18n,\n          locale,\n          params,\n          payload,\n          permissions,\n          searchParams,\n          user: user ?? undefined\n        } satisfies ServerProps\n      })}\n    </MinimalTemplate>\n  )\n}\n\nexport default AdminLogin\n"],"names":["React","AdminLoginClient","redirect","Logo","getSafeRedirect","MinimalTemplate","checkPluginExists","RenderServerComponent","adminRoutes","defaults","supportedBAPluginIds","loginBaseClass","AdminLogin","initPageResult","params","searchParams","pluginOptions","adminInvitationsSlug","locale","permissions","req","i18n","payload","config","collections","user","admin","components","afterLogin","beforeLogin","userSlug","routes","adminRoute","adminRole","users","defaultAdminRole","redirectUrl","adminCount","count","collection","where","role","equals","totalDocs","existingInvitations","find","token","docs","crypto","randomUUID","create","data","adminSignup","filteredAfterLogin","Array","isArray","length","slice","undefined","prefillAutoLogin","autoLogin","prefillOnly","prefillUsername","username","prefillEmail","email","prefillPassword","password","hasUsernamePlugin","betterAuthOptions","hasPasskeyPlugin","passkey","loginMethods","loginWithUsername","auth","canLoginWithUsername","className","div","Component","importMap","serverProps"],"mappings":"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"}
|
|
@@ -3,6 +3,7 @@ import type { BetterAuthOptions as BetterAuthOptionsType, BetterAuthPlugin as Be
|
|
|
3
3
|
import type { BasePayload, CollectionConfig, Config, Endpoint, Field, Payload, PayloadRequest } from 'payload';
|
|
4
4
|
import { adminRoutes, baPluginSlugs, loginMethods, socialProviders } from './constants';
|
|
5
5
|
import { FieldAttribute } from 'better-auth/db';
|
|
6
|
+
import { CollectionSchemaMap } from './helpers/get-collection-schema-map';
|
|
6
7
|
/**
|
|
7
8
|
* BetterAuth options with the following caveats:
|
|
8
9
|
* - The `database` option is removed as it is configured internally
|
|
@@ -407,6 +408,7 @@ export interface BuildCollectionProps {
|
|
|
407
408
|
schema: BuildSchema;
|
|
408
409
|
pluginOptions: BetterAuthPluginOptions;
|
|
409
410
|
incomingCollections: CollectionConfig[];
|
|
411
|
+
collectionSchemaMap: CollectionSchemaMap;
|
|
410
412
|
}
|
|
411
413
|
export type FieldOverrides<K extends string = string> = {
|
|
412
414
|
[Key in K]?: (field: FieldAttribute) => Partial<Field>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAClE,OAAO,KAAK,EACV,iBAAiB,IAAI,qBAAqB,EAC1C,gBAAgB,IAAI,oBAAoB,EACxC,QAAQ,EACR,gBAAgB,EACjB,MAAM,mBAAmB,CAAA;AAC1B,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AAC9G,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,YAAY,EAAE,eAAe,EAAwB,MAAM,aAAa,CAAA;AAC7G,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAA;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/types.ts"],"names":[],"mappings":"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"}
|