payload-auth 1.6.6 → 1.7.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.map +1 -1
- package/dist/better-auth/adapter/index.js +29 -15
- package/dist/better-auth/adapter/transform/index.d.ts +7 -4
- package/dist/better-auth/adapter/transform/index.d.ts.map +1 -1
- package/dist/better-auth/adapter/transform/index.js +25 -8
- package/dist/better-auth/plugin/helpers/get-better-auth-schema.d.ts.map +1 -1
- package/dist/better-auth/plugin/helpers/get-better-auth-schema.js +9 -2
- package/dist/better-auth/plugin/helpers/get-collection.d.ts +13 -1
- package/dist/better-auth/plugin/helpers/get-collection.d.ts.map +1 -1
- package/dist/better-auth/plugin/helpers/get-collection.js +23 -2
- package/dist/better-auth/plugin/index.js +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 +2 -1
- 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/team-members.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/team-members.js +3 -1
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.js +1 -1
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.js +33 -23
- 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 +5 -4
- package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.d.ts +4 -3
- package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.js +22 -3
- package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.d.ts +1 -2
- package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.js +7 -4
- package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.d.ts +4 -0
- package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.js +22 -2
- package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.js +2 -5
- package/dist/better-auth/plugin/lib/get-payload-auth.d.ts +3 -3
- package/dist/better-auth/plugin/lib/get-payload-auth.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/get-payload-auth.js +1 -1
- package/dist/better-auth/plugin/lib/init-better-auth.d.ts +4 -4
- package/dist/better-auth/plugin/lib/init-better-auth.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/init-better-auth.js +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.d.ts +2 -2
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.js +6 -3
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js +14 -8
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-after-role-middleware.d.ts +8 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-after-role-middleware.d.ts.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-after-role-middleware.js +20 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-before-role-middleware.d.ts +8 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-before-role-middleware.d.ts.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-before-role-middleware.js +20 -0
- package/dist/better-auth/plugin/types.d.ts +38 -40
- package/dist/better-auth/plugin/types.d.ts.map +1 -1
- package/dist/better-auth/plugin/types.js +1 -1
- package/package.json +5 -5
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { filterProps } from "./filter-properties";
|
|
1
|
+
import { filterProps, getValidFieldPropertyKeysForType } from "./filter-properties";
|
|
2
2
|
function getRuleBasedFieldProperties({ field }, fieldRules = []) {
|
|
3
3
|
return fieldRules.reduce((acc, rule)=>{
|
|
4
4
|
const conditionMatch = !rule.condition || rule.condition(field);
|
|
@@ -8,7 +8,7 @@ function getRuleBasedFieldProperties({ field }, fieldRules = []) {
|
|
|
8
8
|
return acc;
|
|
9
9
|
}, {});
|
|
10
10
|
}
|
|
11
|
-
export const getAdditionalFieldProperties = ({ field, fieldKey, fieldRules = [], additionalProperties = {}
|
|
11
|
+
export const getAdditionalFieldProperties = ({ field, fieldKey, fieldRules = [], additionalProperties = {} })=>{
|
|
12
12
|
const ruleProps = getRuleBasedFieldProperties({
|
|
13
13
|
field
|
|
14
14
|
}, fieldRules);
|
|
@@ -17,7 +17,10 @@ export const getAdditionalFieldProperties = ({ field, fieldKey, fieldRules = [],
|
|
|
17
17
|
...ruleProps,
|
|
18
18
|
...specificProps
|
|
19
19
|
};
|
|
20
|
-
|
|
20
|
+
const type = mergedProps.type;
|
|
21
|
+
// get valid field property keys for the type of the field after merging the rules and the additional properties
|
|
22
|
+
const validFieldPropertyKeysForType = getValidFieldPropertyKeysForType(type);
|
|
23
|
+
return filterProps(mergedProps, validFieldPropertyKeysForType);
|
|
21
24
|
};
|
|
22
25
|
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL3V0aWxzL21vZGVsLWZpZWxkLXRyYW5zZm9ybWF0aW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWVsZFJ1bGUgfSBmcm9tICdAL2JldHRlci1hdXRoL3BsdWdpbi90eXBlcydcbmltcG9ydCB0eXBlIHsgREJGaWVsZEF0dHJpYnV0ZSB9IGZyb20gJ2JldHRlci1hdXRoL2RiJ1xuaW1wb3J0IHR5cGUgeyBGaWVsZCB9IGZyb20gJ3BheWxvYWQnXG5pbXBvcnQgeyBmaWx0ZXJQcm9wcywgZ2V0VmFsaWRGaWVsZFByb3BlcnR5S2V5c0ZvclR5cGUgfSBmcm9tICcuL2ZpbHRlci1wcm9wZXJ0aWVzJ1xuXG5mdW5jdGlvbiBnZXRSdWxlQmFzZWRGaWVsZFByb3BlcnRpZXMoeyBmaWVsZCB9OiB7IGZpZWxkOiBEQkZpZWxkQXR0cmlidXRlIH0sIGZpZWxkUnVsZXM6IEZpZWxkUnVsZVtdID0gW10pOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB7XG4gIHJldHVybiBmaWVsZFJ1bGVzLnJlZHVjZTxSZWNvcmQ8c3RyaW5nLCB1bmtub3duPj4oKGFjYywgcnVsZSkgPT4ge1xuICAgIGNvbnN0IGNvbmRpdGlvbk1hdGNoID0gIXJ1bGUuY29uZGl0aW9uIHx8IHJ1bGUuY29uZGl0aW9uKGZpZWxkKVxuXG4gICAgaWYgKGNvbmRpdGlvbk1hdGNoKSB7XG4gICAgICBPYmplY3QuYXNzaWduKGFjYywgcnVsZS50cmFuc2Zvcm0oZmllbGQpKVxuICAgIH1cblxuICAgIHJldHVybiBhY2NcbiAgfSwge30pXG59XG5cbmV4cG9ydCBjb25zdCBnZXRBZGRpdGlvbmFsRmllbGRQcm9wZXJ0aWVzID0gKHtcbiAgZmllbGQsXG4gIGZpZWxkS2V5LFxuICBmaWVsZFJ1bGVzID0gW10sXG4gIGFkZGl0aW9uYWxQcm9wZXJ0aWVzID0ge31cbn06IHtcbiAgZmllbGQ6IERCRmllbGRBdHRyaWJ1dGVcbiAgZmllbGRLZXk6IHN0cmluZ1xuICBmaWVsZFJ1bGVzPzogRmllbGRSdWxlW11cbiAgYWRkaXRpb25hbFByb3BlcnRpZXM/OiB7IFtrZXk6IHN0cmluZ106IChmaWVsZDogREJGaWVsZEF0dHJpYnV0ZSkgPT4gUGFydGlhbDxGaWVsZD4gfVxufSk6IFBhcnRpYWw8RmllbGQ+ID0+IHtcbiAgY29uc3QgcnVsZVByb3BzID0gZ2V0UnVsZUJhc2VkRmllbGRQcm9wZXJ0aWVzKHsgZmllbGQgfSwgZmllbGRSdWxlcylcbiAgY29uc3Qgc3BlY2lmaWNQcm9wcyA9IGFkZGl0aW9uYWxQcm9wZXJ0aWVzW2ZpZWxkS2V5XT8uKGZpZWxkKSA/PyB7fVxuICBjb25zdCBtZXJnZWRQcm9wcyA9IHsgLi4ucnVsZVByb3BzLCAuLi5zcGVjaWZpY1Byb3BzIH1cbiAgY29uc3QgdHlwZSA9IG1lcmdlZFByb3BzLnR5cGUgYXMgRmllbGRbJ3R5cGUnXVxuICAvLyBnZXQgdmFsaWQgZmllbGQgcHJvcGVydHkga2V5cyBmb3IgdGhlIHR5cGUgb2YgdGhlIGZpZWxkIGFmdGVyIG1lcmdpbmcgdGhlIHJ1bGVzIGFuZCB0aGUgYWRkaXRpb25hbCBwcm9wZXJ0aWVzXG4gIGNvbnN0IHZhbGlkRmllbGRQcm9wZXJ0eUtleXNGb3JUeXBlID0gZ2V0VmFsaWRGaWVsZFByb3BlcnR5S2V5c0ZvclR5cGUodHlwZSlcbiAgcmV0dXJuIGZpbHRlclByb3BzKG1lcmdlZFByb3BzIGFzIGFueSwgdmFsaWRGaWVsZFByb3BlcnR5S2V5c0ZvclR5cGUgYXMgYW55KVxufVxuIl0sIm5hbWVzIjpbImZpbHRlclByb3BzIiwiZ2V0VmFsaWRGaWVsZFByb3BlcnR5S2V5c0ZvclR5cGUiLCJnZXRSdWxlQmFzZWRGaWVsZFByb3BlcnRpZXMiLCJmaWVsZCIsImZpZWxkUnVsZXMiLCJyZWR1Y2UiLCJhY2MiLCJydWxlIiwiY29uZGl0aW9uTWF0Y2giLCJjb25kaXRpb24iLCJPYmplY3QiLCJhc3NpZ24iLCJ0cmFuc2Zvcm0iLCJnZXRBZGRpdGlvbmFsRmllbGRQcm9wZXJ0aWVzIiwiZmllbGRLZXkiLCJhZGRpdGlvbmFsUHJvcGVydGllcyIsInJ1bGVQcm9wcyIsInNwZWNpZmljUHJvcHMiLCJtZXJnZWRQcm9wcyIsInR5cGUiLCJ2YWxpZEZpZWxkUHJvcGVydHlLZXlzRm9yVHlwZSJdLCJtYXBwaW5ncyI6IkFBR0EsU0FBU0EsV0FBVyxFQUFFQyxnQ0FBZ0MsUUFBUSxzQkFBcUI7QUFFbkYsU0FBU0MsNEJBQTRCLEVBQUVDLEtBQUssRUFBK0IsRUFBRUMsYUFBMEIsRUFBRTtJQUN2RyxPQUFPQSxXQUFXQyxNQUFNLENBQTBCLENBQUNDLEtBQUtDO1FBQ3RELE1BQU1DLGlCQUFpQixDQUFDRCxLQUFLRSxTQUFTLElBQUlGLEtBQUtFLFNBQVMsQ0FBQ047UUFFekQsSUFBSUssZ0JBQWdCO1lBQ2xCRSxPQUFPQyxNQUFNLENBQUNMLEtBQUtDLEtBQUtLLFNBQVMsQ0FBQ1Q7UUFDcEM7UUFFQSxPQUFPRztJQUNULEdBQUcsQ0FBQztBQUNOO0FBRUEsT0FBTyxNQUFNTywrQkFBK0IsQ0FBQyxFQUMzQ1YsS0FBSyxFQUNMVyxRQUFRLEVBQ1JWLGFBQWEsRUFBRSxFQUNmVyx1QkFBdUIsQ0FBQyxDQUFDLEVBTTFCO0lBQ0MsTUFBTUMsWUFBWWQsNEJBQTRCO1FBQUVDO0lBQU0sR0FBR0M7SUFDekQsTUFBTWEsZ0JBQWdCRixvQkFBb0IsQ0FBQ0QsU0FBUyxHQUFHWCxVQUFVLENBQUM7SUFDbEUsTUFBTWUsY0FBYztRQUFFLEdBQUdGLFNBQVM7UUFBRSxHQUFHQyxhQUFhO0lBQUM7SUFDckQsTUFBTUUsT0FBT0QsWUFBWUMsSUFBSTtJQUM3QixnSEFBZ0g7SUFDaEgsTUFBTUMsZ0NBQWdDbkIsaUNBQWlDa0I7SUFDdkUsT0FBT25CLFlBQVlrQixhQUFvQkU7QUFDekMsRUFBQyJ9
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { Access, FieldAccess } from 'payload';
|
|
2
|
+
import type { PayloadRequest } from 'payload';
|
|
2
3
|
export type AdminRolesConfig = {
|
|
3
4
|
adminRoles?: string[];
|
|
4
5
|
};
|
|
@@ -11,5 +12,8 @@ export type AdminOrCurrentUserUpdateConfig = AdminOrCurrentUserConfig & {
|
|
|
11
12
|
};
|
|
12
13
|
export declare const isAdminWithRoles: (config?: AdminRolesConfig) => FieldAccess;
|
|
13
14
|
export declare const isAdminOrCurrentUserWithRoles: (config?: AdminOrCurrentUserConfig) => Access;
|
|
15
|
+
export declare const hasAdminRoles: (adminRoles: string[]) => ({ req }: {
|
|
16
|
+
req: PayloadRequest;
|
|
17
|
+
}) => boolean;
|
|
14
18
|
export declare const isAdminOrCurrentUserUpdateWithAllowedFields: (config: AdminOrCurrentUserUpdateConfig) => Access;
|
|
15
19
|
//# sourceMappingURL=payload-access.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"payload-access.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/lib/build-collections/utils/payload-access.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"payload-access.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/lib/build-collections/utils/payload-access.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAClD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AAE7C,MAAM,MAAM,gBAAgB,GAAG;IAC7B,UAAU,CAAC,EAAE,MAAM,EAAE,CAAA;CACtB,CAAA;AAED,MAAM,MAAM,wBAAwB,GAAG,gBAAgB,GAAG;IACxD,OAAO,CAAC,EAAE,MAAM,CAAA;CACjB,CAAA;AAED,MAAM,MAAM,8BAA8B,GAAG,wBAAwB,GAAG;IACtE,aAAa,CAAC,EAAE,MAAM,EAAE,CAAA;IACxB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,gBAAgB,GAC1B,SAAQ,gBAAqB,KAAG,WAKhC,CAAA;AAEH,eAAO,MAAM,6BAA6B,GACvC,SAAQ,wBAA6B,KAAG,MAUxC,CAAA;AAEH,eAAO,MAAM,aAAa,GAAI,YAAY,MAAM,EAAE,MACxC,SAAS;IAAE,GAAG,EAAE,cAAc,CAAA;CAAE,KAAG,OAiB5C,CAAA;AAED,eAAO,MAAM,2CAA2C,GAAI,QAAQ,8BAA8B,KAAG,MA2CpG,CAAA"}
|
|
@@ -2,7 +2,9 @@ export const isAdminWithRoles = (config = {})=>({ req })=>{
|
|
|
2
2
|
const { adminRoles = [
|
|
3
3
|
'admin'
|
|
4
4
|
] } = config;
|
|
5
|
-
if (!req?.user || !req.user.role || !adminRoles
|
|
5
|
+
if (!req?.user || !req.user.role || !hasAdminRoles(adminRoles)({
|
|
6
|
+
req
|
|
7
|
+
})) return false;
|
|
6
8
|
return true;
|
|
7
9
|
};
|
|
8
10
|
export const isAdminOrCurrentUserWithRoles = (config = {})=>({ req })=>{
|
|
@@ -21,6 +23,24 @@ export const isAdminOrCurrentUserWithRoles = (config = {})=>({ req })=>{
|
|
|
21
23
|
}
|
|
22
24
|
};
|
|
23
25
|
};
|
|
26
|
+
export const hasAdminRoles = (adminRoles)=>{
|
|
27
|
+
return ({ req })=>{
|
|
28
|
+
let userRoles = [];
|
|
29
|
+
if (Array.isArray(req.user?.role)) {
|
|
30
|
+
userRoles = req.user.role;
|
|
31
|
+
} else if (typeof req.user?.role === 'string') {
|
|
32
|
+
if (req.user.role.includes(',')) {
|
|
33
|
+
userRoles = req.user.role.split(',').map((r)=>r.trim()).filter(Boolean);
|
|
34
|
+
} else if (req.user.role) {
|
|
35
|
+
userRoles = [
|
|
36
|
+
req.user.role
|
|
37
|
+
];
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
if (!userRoles) return false;
|
|
41
|
+
return userRoles.some((role)=>adminRoles.includes(role));
|
|
42
|
+
};
|
|
43
|
+
};
|
|
24
44
|
export const isAdminOrCurrentUserUpdateWithAllowedFields = (config)=>{
|
|
25
45
|
return async ({ req, id, data })=>{
|
|
26
46
|
const { adminRoles = [
|
|
@@ -61,4 +81,4 @@ export const isAdminOrCurrentUserUpdateWithAllowedFields = (config)=>{
|
|
|
61
81
|
};
|
|
62
82
|
};
|
|
63
83
|
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL3V0aWxzL3BheWxvYWQtYWNjZXNzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQWNjZXNzLCBGaWVsZEFjY2VzcyB9IGZyb20gJ3BheWxvYWQnXG5pbXBvcnQgdHlwZSB7IFBheWxvYWRSZXF1ZXN0IH0gZnJvbSAncGF5bG9hZCdcblxuZXhwb3J0IHR5cGUgQWRtaW5Sb2xlc0NvbmZpZyA9IHtcbiAgYWRtaW5Sb2xlcz86IHN0cmluZ1tdXG59XG5cbmV4cG9ydCB0eXBlIEFkbWluT3JDdXJyZW50VXNlckNvbmZpZyA9IEFkbWluUm9sZXNDb25maWcgJiB7XG4gIGlkRmllbGQ/OiBzdHJpbmdcbn1cblxuZXhwb3J0IHR5cGUgQWRtaW5PckN1cnJlbnRVc2VyVXBkYXRlQ29uZmlnID0gQWRtaW5PckN1cnJlbnRVc2VyQ29uZmlnICYge1xuICBhbGxvd2VkRmllbGRzPzogc3RyaW5nW11cbiAgdXNlclNsdWc6IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgaXNBZG1pbldpdGhSb2xlcyA9XG4gIChjb25maWc6IEFkbWluUm9sZXNDb25maWcgPSB7fSk6IEZpZWxkQWNjZXNzID0+XG4gICh7IHJlcSB9KSA9PiB7XG4gICAgY29uc3QgeyBhZG1pblJvbGVzID0gWydhZG1pbiddIH0gPSBjb25maWdcbiAgICBpZiAoIXJlcT8udXNlciB8fCAhcmVxLnVzZXIucm9sZSB8fCAhaGFzQWRtaW5Sb2xlcyhhZG1pblJvbGVzKSh7IHJlcSB9KSkgcmV0dXJuIGZhbHNlXG4gICAgcmV0dXJuIHRydWVcbiAgfVxuXG5leHBvcnQgY29uc3QgaXNBZG1pbk9yQ3VycmVudFVzZXJXaXRoUm9sZXMgPVxuICAoY29uZmlnOiBBZG1pbk9yQ3VycmVudFVzZXJDb25maWcgPSB7fSk6IEFjY2VzcyA9PlxuICAoeyByZXEgfSkgPT4ge1xuICAgIGNvbnN0IHsgYWRtaW5Sb2xlcyA9IFsnYWRtaW4nXSwgaWRGaWVsZCA9ICdpZCcgfSA9IGNvbmZpZ1xuICAgIGlmIChpc0FkbWluV2l0aFJvbGVzKHsgYWRtaW5Sb2xlcyB9KSh7IHJlcSB9KSkgcmV0dXJuIHRydWVcbiAgICBpZiAoIXJlcT8udXNlcikgcmV0dXJuIGZhbHNlXG4gICAgcmV0dXJuIHtcbiAgICAgIFtpZEZpZWxkXToge1xuICAgICAgICBlcXVhbHM6IHJlcT8udXNlcj8uaWRcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuZXhwb3J0IGNvbnN0IGhhc0FkbWluUm9sZXMgPSAoYWRtaW5Sb2xlczogc3RyaW5nW10pID0+IHtcbiAgcmV0dXJuICh7IHJlcSB9OiB7IHJlcTogUGF5bG9hZFJlcXVlc3QgfSk6IGJvb2xlYW4gPT4ge1xuICAgIGxldCB1c2VyUm9sZXM6IHN0cmluZ1tdID0gW11cbiAgICBpZiAoQXJyYXkuaXNBcnJheShyZXEudXNlcj8ucm9sZSkpIHtcbiAgICAgIHVzZXJSb2xlcyA9IHJlcS51c2VyLnJvbGVcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiByZXEudXNlcj8ucm9sZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGlmIChyZXEudXNlci5yb2xlLmluY2x1ZGVzKCcsJykpIHtcbiAgICAgICAgdXNlclJvbGVzID0gcmVxLnVzZXIucm9sZVxuICAgICAgICAgIC5zcGxpdCgnLCcpXG4gICAgICAgICAgLm1hcCgocjogc3RyaW5nKSA9PiByLnRyaW0oKSlcbiAgICAgICAgICAuZmlsdGVyKEJvb2xlYW4pXG4gICAgICB9IGVsc2UgaWYgKHJlcS51c2VyLnJvbGUpIHtcbiAgICAgICAgdXNlclJvbGVzID0gW3JlcS51c2VyLnJvbGVdXG4gICAgICB9XG4gICAgfVxuICAgIGlmICghdXNlclJvbGVzKSByZXR1cm4gZmFsc2VcbiAgICByZXR1cm4gdXNlclJvbGVzLnNvbWUoKHJvbGUpID0+IGFkbWluUm9sZXMuaW5jbHVkZXMocm9sZSkpXG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGlzQWRtaW5PckN1cnJlbnRVc2VyVXBkYXRlV2l0aEFsbG93ZWRGaWVsZHMgPSAoY29uZmlnOiBBZG1pbk9yQ3VycmVudFVzZXJVcGRhdGVDb25maWcpOiBBY2Nlc3MgPT4ge1xuICByZXR1cm4gYXN5bmMgKHsgcmVxLCBpZCwgZGF0YSB9KSA9PiB7XG4gICAgY29uc3QgeyBhZG1pblJvbGVzID0gWydhZG1pbiddLCBhbGxvd2VkRmllbGRzID0gW10sIHVzZXJTbHVnLCBpZEZpZWxkID0gJ2lkJyB9ID0gY29uZmlnXG4gICAgY29uc3QgdXNlciA9IHJlcS51c2VyXG5cbiAgICBpZiAoaXNBZG1pbldpdGhSb2xlcyh7IGFkbWluUm9sZXMgfSkoeyByZXEgfSkpIHJldHVybiB0cnVlXG5cbiAgICBpZiAoIXVzZXIpIHJldHVybiBmYWxzZVxuXG4gICAgaWYgKHVzZXJbaWRGaWVsZF0gPT09IGlkICYmIGRhdGEpIHtcbiAgICAgIGNvbnN0IGRhdGFLZXlzID0gT2JqZWN0LmtleXMoZGF0YSlcblxuICAgICAgY29uc3QgaGFzQ3VycmVudFBhc3N3b3JkID0gZGF0YUtleXMuaW5jbHVkZXMoJ2N1cnJlbnRQYXNzd29yZCcpXG4gICAgICBjb25zdCBoYXNQYXNzd29yZCA9IGRhdGFLZXlzLmluY2x1ZGVzKCdwYXNzd29yZCcpXG5cbiAgICAgIGlmIChoYXNQYXNzd29yZCB8fCBoYXNDdXJyZW50UGFzc3dvcmQpIHtcbiAgICAgICAgaWYgKCEoaGFzQ3VycmVudFBhc3N3b3JkICYmIGhhc1Bhc3N3b3JkKSkgcmV0dXJuIGZhbHNlXG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgaWYgKCF1c2VyLmVtYWlsKSByZXR1cm4gZmFsc2VcblxuICAgICAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHJlcS5wYXlsb2FkLmxvZ2luKHtcbiAgICAgICAgICAgIGNvbGxlY3Rpb246IHVzZXJTbHVnLFxuICAgICAgICAgICAgZGF0YToge1xuICAgICAgICAgICAgICBlbWFpbDogdXNlci5lbWFpbCxcbiAgICAgICAgICAgICAgcGFzc3dvcmQ6IGRhdGEuY3VycmVudFBhc3N3b3JkXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSlcblxuICAgICAgICAgIGlmICghcmVzdWx0KSByZXR1cm4gZmFsc2VcblxuICAgICAgICAgIGFsbG93ZWRGaWVsZHMucHVzaCgncGFzc3dvcmQnLCAnY3VycmVudFBhc3N3b3JkJylcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICByZXR1cm4gZmFsc2VcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBjb25zdCBoYXNEaXNhbGxvd2VkRmllbGQgPSBkYXRhS2V5cy5zb21lKChrZXkpID0+ICFhbGxvd2VkRmllbGRzLmluY2x1ZGVzKGtleSkpXG5cbiAgICAgIHJldHVybiAhaGFzRGlzYWxsb3dlZEZpZWxkXG4gICAgfVxuXG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJpc0FkbWluV2l0aFJvbGVzIiwiY29uZmlnIiwicmVxIiwiYWRtaW5Sb2xlcyIsInVzZXIiLCJyb2xlIiwiaGFzQWRtaW5Sb2xlcyIsImlzQWRtaW5PckN1cnJlbnRVc2VyV2l0aFJvbGVzIiwiaWRGaWVsZCIsImVxdWFscyIsImlkIiwidXNlclJvbGVzIiwiQXJyYXkiLCJpc0FycmF5IiwiaW5jbHVkZXMiLCJzcGxpdCIsIm1hcCIsInIiLCJ0cmltIiwiZmlsdGVyIiwiQm9vbGVhbiIsInNvbWUiLCJpc0FkbWluT3JDdXJyZW50VXNlclVwZGF0ZVdpdGhBbGxvd2VkRmllbGRzIiwiZGF0YSIsImFsbG93ZWRGaWVsZHMiLCJ1c2VyU2x1ZyIsImRhdGFLZXlzIiwiT2JqZWN0Iiwia2V5cyIsImhhc0N1cnJlbnRQYXNzd29yZCIsImhhc1Bhc3N3b3JkIiwiZW1haWwiLCJyZXN1bHQiLCJwYXlsb2FkIiwibG9naW4iLCJjb2xsZWN0aW9uIiwicGFzc3dvcmQiLCJjdXJyZW50UGFzc3dvcmQiLCJwdXNoIiwiZXJyb3IiLCJoYXNEaXNhbGxvd2VkRmllbGQiLCJrZXkiXSwibWFw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
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transform-schema-fields-to-payload.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AACtD,OAAO,KAAK,EAAE,KAAK,EAAqB,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"transform-schema-fields-to-payload.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAA;AAClF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AACtD,OAAO,KAAK,EAAE,KAAK,EAAqB,MAAM,SAAS,CAAA;AAGvD,wBAAgB,mBAAmB,CAAC,EAClC,MAAM,EACN,UAAe,EACf,oBAAyB,EAC1B,EAAE;IACD,MAAM,EAAE,qBAAqB,CAAA;IAC7B,UAAU,CAAC,EAAE,SAAS,EAAE,CAAA;IACxB,oBAAoB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,gBAAgB,KAAK,OAAO,CAAC,KAAK,CAAC,CAAC,CAAA;CACnF,GAAG,KAAK,EAAE,GAAG,IAAI,CAMjB;AAED,wBAAgB,2BAA2B,CAAC,EAC1C,KAAK,EACL,QAAQ,EACR,UAAe,EACf,oBAAyB,EAC1B,EAAE;IACD,KAAK,EAAE,gBAAgB,CAAA;IACvB,QAAQ,EAAE,MAAM,CAAA;IAChB,UAAU,CAAC,EAAE,SAAS,EAAE,CAAA;IACxB,oBAAoB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,gBAAgB,KAAK,OAAO,CAAC,KAAK,CAAC,CAAC,CAAA;CACnF,GAAG,KAAK,CA8BR;AAED,wBAAgB,yBAAyB,CAAC,EAAE,KAAK,EAAE,EAAE;IAAE,KAAK,EAAE,gBAAgB,CAAA;CAAE,GAAG;IACjF,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,CAAA;IACnB,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB,CA2BA"}
|
package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.js
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { getAdditionalFieldProperties } from "./model-field-transformations";
|
|
2
|
-
import { getValidFieldPropertyKeysForType } from "./filter-properties";
|
|
3
2
|
export function getCollectionFields({ schema, fieldRules = [], additionalProperties = {} }) {
|
|
4
3
|
const payloadFields = Object.entries(schema.fields).map(([fieldKey, field])=>{
|
|
5
4
|
return convertSchemaFieldToPayload({
|
|
@@ -15,13 +14,11 @@ export function convertSchemaFieldToPayload({ field, fieldKey, fieldRules = [],
|
|
|
15
14
|
const { type, hasMany } = getPayloadFieldProperties({
|
|
16
15
|
field
|
|
17
16
|
});
|
|
18
|
-
const validFieldPropertyKeys = getValidFieldPropertyKeysForType(type);
|
|
19
17
|
const additionalFieldProperties = getAdditionalFieldProperties({
|
|
20
18
|
field,
|
|
21
19
|
fieldKey,
|
|
22
20
|
fieldRules,
|
|
23
|
-
additionalProperties
|
|
24
|
-
validFieldPropertyKeys
|
|
21
|
+
additionalProperties
|
|
25
22
|
});
|
|
26
23
|
const baseField = {
|
|
27
24
|
name: field.fieldName ?? fieldKey,
|
|
@@ -95,4 +92,4 @@ export function getPayloadFieldProperties({ field }) {
|
|
|
95
92
|
}
|
|
96
93
|
}
|
|
97
94
|
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL3V0aWxzL3RyYW5zZm9ybS1zY2hlbWEtZmllbGRzLXRvLXBheWxvYWQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBCdWlsdEJldHRlckF1dGhTY2hlbWEsIEZpZWxkUnVsZSB9IGZyb20gJ0AvYmV0dGVyLWF1dGgvcGx1Z2luL3R5cGVzJ1xuaW1wb3J0IHR5cGUgeyBEQkZpZWxkQXR0cmlidXRlIH0gZnJvbSAnYmV0dGVyLWF1dGgvZGInXG5pbXBvcnQgdHlwZSB7IEZpZWxkLCBSZWxhdGlvbnNoaXBGaWVsZCB9IGZyb20gJ3BheWxvYWQnXG5pbXBvcnQgeyBnZXRBZGRpdGlvbmFsRmllbGRQcm9wZXJ0aWVzIH0gZnJvbSAnLi9tb2RlbC1maWVsZC10cmFuc2Zvcm1hdGlvbnMnXG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRDb2xsZWN0aW9uRmllbGRzKHtcbiAgc2NoZW1hLFxuICBmaWVsZFJ1bGVzID0gW10sXG4gIGFkZGl0aW9uYWxQcm9wZXJ0aWVzID0ge31cbn06IHtcbiAgc2NoZW1hOiBCdWlsdEJldHRlckF1dGhTY2hlbWFcbiAgZmllbGRSdWxlcz86IEZpZWxkUnVsZVtdXG4gIGFkZGl0aW9uYWxQcm9wZXJ0aWVzPzogUmVjb3JkPHN0cmluZywgKGZpZWxkOiBEQkZpZWxkQXR0cmlidXRlKSA9PiBQYXJ0aWFsPEZpZWxkPj5cbn0pOiBGaWVsZFtdIHwgbnVsbCB7XG4gIGNvbnN0IHBheWxvYWRGaWVsZHMgPSBPYmplY3QuZW50cmllcyhzY2hlbWEuZmllbGRzKS5tYXAoKFtmaWVsZEtleSwgZmllbGRdKSA9PiB7XG4gICAgcmV0dXJuIGNvbnZlcnRTY2hlbWFGaWVsZFRvUGF5bG9hZCh7IGZpZWxkLCBmaWVsZEtleSwgZmllbGRSdWxlcywgYWRkaXRpb25hbFByb3BlcnRpZXMgfSlcbiAgfSlcblxuICByZXR1cm4gcGF5bG9hZEZpZWxkc1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY29udmVydFNjaGVtYUZpZWxkVG9QYXlsb2FkKHtcbiAgZmllbGQsXG4gIGZpZWxkS2V5LFxuICBmaWVsZFJ1bGVzID0gW10sXG4gIGFkZGl0aW9uYWxQcm9wZXJ0aWVzID0ge31cbn06IHtcbiAgZmllbGQ6IERCRmllbGRBdHRyaWJ1dGVcbiAgZmllbGRLZXk6IHN0cmluZ1xuICBmaWVsZFJ1bGVzPzogRmllbGRSdWxlW11cbiAgYWRkaXRpb25hbFByb3BlcnRpZXM/OiBSZWNvcmQ8c3RyaW5nLCAoZmllbGQ6IERCRmllbGRBdHRyaWJ1dGUpID0+IFBhcnRpYWw8RmllbGQ+PlxufSk6IEZpZWxkIHtcbiAgY29uc3QgeyB0eXBlLCBoYXNNYW55IH0gPSBnZXRQYXlsb2FkRmllbGRQcm9wZXJ0aWVzKHsgZmllbGQgfSlcbiAgY29uc3QgYWRkaXRpb25hbEZpZWxkUHJvcGVydGllcyA9IGdldEFkZGl0aW9uYWxGaWVsZFByb3BlcnRpZXMoe1xuICAgIGZpZWxkLFxuICAgIGZpZWxkS2V5LFxuICAgIGZpZWxkUnVsZXMsXG4gICAgYWRkaXRpb25hbFByb3BlcnRpZXMsXG4gIH0pXG4gIGNvbnN0IGJhc2VGaWVsZCA9IHtcbiAgICBuYW1lOiBmaWVsZC5maWVsZE5hbWUgPz8gZmllbGRLZXksXG4gICAgdHlwZSxcbiAgICAuLi4oaGFzTWFueSAmJiB7IGhhc01hbnkgfSksXG4gICAgLi4uKGZpZWxkLnJlcXVpcmVkICYmIHsgcmVxdWlyZWQ6IHRydWUgfSksXG4gICAgLi4uKGZpZWxkLnVuaXF1ZSAmJiB7IHVuaXF1ZTogdHJ1ZSB9KSxcbiAgICAuLi5hZGRpdGlvbmFsRmllbGRQcm9wZXJ0aWVzLFxuICAgIGN1c3RvbToge1xuICAgICAgYmV0dGVyQXV0aEZpZWxkS2V5OiBmaWVsZEtleVxuICAgIH1cbiAgfSBhcyBGaWVsZFxuXG4gIGlmIChmaWVsZC5yZWZlcmVuY2VzKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmJhc2VGaWVsZCxcbiAgICAgIC4uLigncmVsYXRpb25UbycgaW4gYWRkaXRpb25hbEZpZWxkUHJvcGVydGllc1xuICAgICAgICA/IHsgcmVsYXRpb25UbzogYWRkaXRpb25hbEZpZWxkUHJvcGVydGllcy5yZWxhdGlvblRvIH1cbiAgICAgICAgOiB7IHJlbGF0aW9uVG86IGZpZWxkLnJlZmVyZW5jZXMubW9kZWwgfSlcbiAgICB9IGFzIFJlbGF0aW9uc2hpcEZpZWxkXG4gIH1cblxuICByZXR1cm4gYmFzZUZpZWxkXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRQYXlsb2FkRmllbGRQcm9wZXJ0aWVzKHsgZmllbGQgfTogeyBmaWVsZDogREJGaWVsZEF0dHJpYnV0ZSB9KToge1xuICB0eXBlOiBGaWVsZFsndHlwZSddXG4gIGhhc01hbnk/OiBib29sZWFuXG59IHtcbiAgY29uc3QgdHlwZSA9IGZpZWxkLnR5cGVcblxuICBpZiAoJ3JlZmVyZW5jZXMnIGluIGZpZWxkKSB7XG4gICAgcmV0dXJuIHsgdHlwZTogJ3JlbGF0aW9uc2hpcCcgfVxuICB9XG5cbiAgaWYgKHR5cGUgPT09ICdudW1iZXJbXScpIHtcbiAgICByZXR1cm4geyB0eXBlOiAnbnVtYmVyJywgaGFzTWFueTogdHJ1ZSB9XG4gIH1cblxuICBpZiAodHlwZSA9PT0gJ3N0cmluZ1tdJykge1xuICAgIHJldHVybiB7IHR5cGU6ICd0ZXh0JywgaGFzTWFueTogdHJ1ZSB9XG4gIH1cblxuICBzd2l0Y2ggKHR5cGUpIHtcbiAgICBjYXNlICdib29sZWFuJzpcbiAgICAgIHJldHVybiB7IHR5cGU6ICdjaGVja2JveCcgfVxuICAgIGNhc2UgJ2RhdGUnOlxuICAgICAgcmV0dXJuIHsgdHlwZTogJ2RhdGUnIH1cbiAgICBjYXNlICdzdHJpbmcnOlxuICAgICAgcmV0dXJuIHsgdHlwZTogJ3RleHQnIH1cbiAgICBjYXNlICdudW1iZXInOlxuICAgICAgcmV0dXJuIHsgdHlwZTogJ251bWJlcicgfVxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4geyB0eXBlOiAndGV4dCcgfVxuICB9XG59XG4iXSwibmFtZXMiOlsiZ2V0QWRkaXRpb25hbEZpZWxkUHJvcGVydGllcyIsImdldENvbGxlY3Rpb25GaWVsZHMiLCJzY2hlbWEiLCJmaWVsZFJ1bGVzIiwiYWRkaXRpb25hbFByb3BlcnRpZXMiLCJwYXlsb2FkRmllbGRzIiwiT2JqZWN0IiwiZW50cmllcyIsImZpZWxkcyIsIm1hcCIsImZpZWxkS2V5IiwiZmllbGQiLCJjb252ZXJ0U2NoZW1hRmllbGRUb1BheWxvYWQiLCJ0eXBlIiwiaGFzTWFueSIsImdldFBheWxvYWRGaWVsZFByb3BlcnRpZXMiLCJhZGRpdGlvbmFsRmllbGRQcm9wZXJ0aWVzIiwiYmFzZUZpZWxkIiwibmFtZSIsImZpZWxkTmFtZSIsInJlcXVpcmVkIiwidW5pcXVlIiwiY3VzdG9tIiwiYmV0dGVyQXV0aEZpZWxkS2V5IiwicmVmZXJlbmNlcyIsInJlbGF0aW9uVG8iLCJtb2RlbCJdLCJtYXBwaW5ncyI6IkFBR0EsU0FBU0EsNEJBQTRCLFFBQVEsZ0NBQStCO0FBRTVFLE9BQU8sU0FBU0Msb0JBQW9CLEVBQ2xDQyxNQUFNLEVBQ05DLGFBQWEsRUFBRSxFQUNmQyx1QkFBdUIsQ0FBQyxDQUFDLEVBSzFCO0lBQ0MsTUFBTUMsZ0JBQWdCQyxPQUFPQyxPQUFPLENBQUNMLE9BQU9NLE1BQU0sRUFBRUMsR0FBRyxDQUFDLENBQUMsQ0FBQ0MsVUFBVUMsTUFBTTtRQUN4RSxPQUFPQyw0QkFBNEI7WUFBRUQ7WUFBT0Q7WUFBVVA7WUFBWUM7UUFBcUI7SUFDekY7SUFFQSxPQUFPQztBQUNUO0FBRUEsT0FBTyxTQUFTTyw0QkFBNEIsRUFDMUNELEtBQUssRUFDTEQsUUFBUSxFQUNSUCxhQUFhLEVBQUUsRUFDZkMsdUJBQXVCLENBQUMsQ0FBQyxFQU0xQjtJQUNDLE1BQU0sRUFBRVMsSUFBSSxFQUFFQyxPQUFPLEVBQUUsR0FBR0MsMEJBQTBCO1FBQUVKO0lBQU07SUFDNUQsTUFBTUssNEJBQTRCaEIsNkJBQTZCO1FBQzdEVztRQUNBRDtRQUNBUDtRQUNBQztJQUNGO0lBQ0EsTUFBTWEsWUFBWTtRQUNoQkMsTUFBTVAsTUFBTVEsU0FBUyxJQUFJVDtRQUN6Qkc7UUFDQSxHQUFJQyxXQUFXO1lBQUVBO1FBQVEsQ0FBQztRQUMxQixHQUFJSCxNQUFNUyxRQUFRLElBQUk7WUFBRUEsVUFBVTtRQUFLLENBQUM7UUFDeEMsR0FBSVQsTUFBTVUsTUFBTSxJQUFJO1lBQUVBLFFBQVE7UUFBSyxDQUFDO1FBQ3BDLEdBQUdMLHlCQUF5QjtRQUM1Qk0sUUFBUTtZQUNOQyxvQkFBb0JiO1FBQ3RCO0lBQ0Y7SUFFQSxJQUFJQyxNQUFNYSxVQUFVLEVBQUU7UUFDcEIsT0FBTztZQUNMLEdBQUdQLFNBQVM7WUFDWixHQUFJLGdCQUFnQkQsNEJBQ2hCO2dCQUFFUyxZQUFZVCwwQkFBMEJTLFVBQVU7WUFBQyxJQUNuRDtnQkFBRUEsWUFBWWQsTUFBTWEsVUFBVSxDQUFDRSxLQUFLO1lBQUMsQ0FBQztRQUM1QztJQUNGO0lBRUEsT0FBT1Q7QUFDVDtBQUVBLE9BQU8sU0FBU0YsMEJBQTBCLEVBQUVKLEtBQUssRUFBK0I7SUFJOUUsTUFBTUUsT0FBT0YsTUFBTUUsSUFBSTtJQUV2QixJQUFJLGdCQUFnQkYsT0FBTztRQUN6QixPQUFPO1lBQUVFLE1BQU07UUFBZTtJQUNoQztJQUVBLElBQUlBLFNBQVMsWUFBWTtRQUN2QixPQUFPO1lBQUVBLE1BQU07WUFBVUMsU0FBUztRQUFLO0lBQ3pDO0lBRUEsSUFBSUQsU0FBUyxZQUFZO1FBQ3ZCLE9BQU87WUFBRUEsTUFBTTtZQUFRQyxTQUFTO1FBQUs7SUFDdkM7SUFFQSxPQUFRRDtRQUNOLEtBQUs7WUFDSCxPQUFPO2dCQUFFQSxNQUFNO1lBQVc7UUFDNUIsS0FBSztZQUNILE9BQU87Z0JBQUVBLE1BQU07WUFBTztRQUN4QixLQUFLO1lBQ0gsT0FBTztnQkFBRUEsTUFBTTtZQUFPO1FBQ3hCLEtBQUs7WUFDSCxPQUFPO2dCQUFFQSxNQUFNO1lBQVM7UUFDMUI7WUFDRSxPQUFPO2dCQUFFQSxNQUFNO1lBQU87SUFDMUI7QUFDRiJ9
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { BasePayload, SanitizedConfig } from 'payload';
|
|
2
|
-
import type {
|
|
3
|
-
export declare function getPayloadAuth<
|
|
4
|
-
betterAuth: BetterAuthReturn<
|
|
2
|
+
import type { BetterAuthPluginOptions, BetterAuthReturn } from '../types';
|
|
3
|
+
export declare function getPayloadAuth<O extends BetterAuthPluginOptions>(config: Promise<SanitizedConfig> | SanitizedConfig): Promise<BasePayload & {
|
|
4
|
+
betterAuth: BetterAuthReturn<O>;
|
|
5
5
|
}>;
|
|
6
6
|
//# sourceMappingURL=get-payload-auth.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-payload-auth.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/lib/get-payload-auth.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAC3D,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"get-payload-auth.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/lib/get-payload-auth.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAC3D,OAAO,KAAK,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAEzE,wBAAsB,cAAc,CAAC,CAAC,SAAS,uBAAuB,EACpE,MAAM,EAAE,OAAO,CAAC,eAAe,CAAC,GAAG,eAAe,GACjD,OAAO,CAAC,WAAW,GAAG;IAAE,UAAU,EAAE,gBAAgB,CAAC,CAAC,CAAC,CAAA;CAAE,CAAC,CAK5D"}
|
|
@@ -6,4 +6,4 @@ export async function getPayloadAuth(config) {
|
|
|
6
6
|
return payload;
|
|
7
7
|
}
|
|
8
8
|
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2dldC1wYXlsb2FkLWF1dGgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0UGF5bG9hZCB9IGZyb20gJ3BheWxvYWQnXG5pbXBvcnQgdHlwZSB7IEJhc2VQYXlsb2FkLCBTYW5pdGl6ZWRDb25maWcgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBCZXR0ZXJBdXRoUGx1Z2luT3B0aW9ucywgQmV0dGVyQXV0aFJldHVybiB9IGZyb20gJy4uL3R5cGVzJ1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZ2V0UGF5bG9hZEF1dGg8TyBleHRlbmRzIEJldHRlckF1dGhQbHVnaW5PcHRpb25zPihcbiAgY29uZmlnOiBQcm9taXNlPFNhbml0aXplZENvbmZpZz4gfCBTYW5pdGl6ZWRDb25maWdcbik6IFByb21pc2U8QmFzZVBheWxvYWQgJiB7IGJldHRlckF1dGg6IEJldHRlckF1dGhSZXR1cm48Tz4gfT4ge1xuICBjb25zdCBwYXlsb2FkID0gKGF3YWl0IGdldFBheWxvYWQoeyBjb25maWcgfSkpIGFzIEJhc2VQYXlsb2FkICYge1xuICAgIGJldHRlckF1dGg6IEJldHRlckF1dGhSZXR1cm48Tz5cbiAgfVxuICByZXR1cm4gcGF5bG9hZFxufVxuIl0sIm5hbWVzIjpbImdldFBheWxvYWQiLCJnZXRQYXlsb2FkQXV0aCIsImNvbmZpZyIsInBheWxvYWQiXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFVBQVUsUUFBUSxVQUFTO0FBSXBDLE9BQU8sZUFBZUMsZUFDcEJDLE1BQWtEO0lBRWxELE1BQU1DLFVBQVcsTUFBTUgsV0FBVztRQUFFRTtJQUFPO0lBRzNDLE9BQU9DO0FBQ1QifQ==
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import type { BasePayload } from 'payload';
|
|
2
|
-
import type { BetterAuthFunctionOptions,
|
|
3
|
-
export declare function initBetterAuth<
|
|
2
|
+
import type { BetterAuthFunctionOptions, BetterAuthPluginOptions, BetterAuthReturn } from '../types';
|
|
3
|
+
export declare function initBetterAuth<O extends BetterAuthPluginOptions>({ payload, idType, options: { enableDebugLogs, ...restOptions } }: {
|
|
4
4
|
payload: BasePayload;
|
|
5
5
|
idType: 'number' | 'text';
|
|
6
|
-
options: BetterAuthFunctionOptions<
|
|
7
|
-
}): BetterAuthReturn<
|
|
6
|
+
options: BetterAuthFunctionOptions<O>;
|
|
7
|
+
}): BetterAuthReturn<O>;
|
|
8
8
|
//# sourceMappingURL=init-better-auth.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init-better-auth.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/lib/init-better-auth.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAE1C,OAAO,KAAK,EAAE,yBAAyB,EAAE,
|
|
1
|
+
{"version":3,"file":"init-better-auth.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/lib/init-better-auth.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAE1C,OAAO,KAAK,EAAE,yBAAyB,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAEpG,wBAAgB,cAAc,CAAC,CAAC,SAAS,uBAAuB,EAAE,EAChE,OAAO,EACP,MAAM,EACN,OAAO,EAAE,EAAE,eAAuB,EAAE,GAAG,WAAW,EAAE,EACrD,EAAE;IACD,OAAO,EAAE,WAAW,CAAA;IACpB,MAAM,EAAE,QAAQ,GAAG,MAAM,CAAA;IACzB,OAAO,EAAE,yBAAyB,CAAC,CAAC,CAAC,CAAA;CACtC,GAAG,gBAAgB,CAAC,CAAC,CAAC,CAWtB"}
|
|
@@ -13,4 +13,4 @@ export function initBetterAuth({ payload, idType, options: { enableDebugLogs = f
|
|
|
13
13
|
});
|
|
14
14
|
}
|
|
15
15
|
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2luaXQtYmV0dGVyLWF1dGgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYmV0dGVyQXV0aCB9IGZyb20gJ2JldHRlci1hdXRoJ1xuaW1wb3J0IHR5cGUgeyBCYXNlUGF5bG9hZCB9IGZyb20gJ3BheWxvYWQnXG5pbXBvcnQgeyBwYXlsb2FkQWRhcHRlciB9IGZyb20gJ3BheWxvYWQtYXV0aC9iZXR0ZXItYXV0aC9hZGFwdGVyJ1xuaW1wb3J0IHR5cGUgeyBCZXR0ZXJBdXRoRnVuY3Rpb25PcHRpb25zLCBCZXR0ZXJBdXRoUGx1Z2luT3B0aW9ucywgQmV0dGVyQXV0aFJldHVybiB9IGZyb20gJy4uL3R5cGVzJ1xuXG5leHBvcnQgZnVuY3Rpb24gaW5pdEJldHRlckF1dGg8TyBleHRlbmRzIEJldHRlckF1dGhQbHVnaW5PcHRpb25zPih7XG4gIHBheWxvYWQsXG4gIGlkVHlwZSxcbiAgb3B0aW9uczogeyBlbmFibGVEZWJ1Z0xvZ3MgPSBmYWxzZSwgLi4ucmVzdE9wdGlvbnMgfVxufToge1xuICBwYXlsb2FkOiBCYXNlUGF5bG9hZFxuICBpZFR5cGU6ICdudW1iZXInIHwgJ3RleHQnXG4gIG9wdGlvbnM6IEJldHRlckF1dGhGdW5jdGlvbk9wdGlvbnM8Tz5cbn0pOiBCZXR0ZXJBdXRoUmV0dXJuPE8+IHtcbiAgcmV0dXJuIGJldHRlckF1dGgoe1xuICAgIC4uLnJlc3RPcHRpb25zLFxuICAgIGRhdGFiYXNlOiBwYXlsb2FkQWRhcHRlcih7XG4gICAgICBwYXlsb2FkQ2xpZW50OiBwYXlsb2FkLFxuICAgICAgYWRhcHRlckNvbmZpZzoge1xuICAgICAgICBlbmFibGVEZWJ1Z0xvZ3MsXG4gICAgICAgIGlkVHlwZVxuICAgICAgfVxuICAgIH0pXG4gIH0pIGFzIHVua25vd24gYXMgQmV0dGVyQXV0aFJldHVybjxPPlxufVxuIl0sIm5hbWVzIjpbImJldHRlckF1dGgiLCJwYXlsb2FkQWRhcHRlciIsImluaXRCZXR0ZXJBdXRoIiwicGF5bG9hZCIsImlkVHlwZSIsIm9wdGlvbnMiLCJlbmFibGVEZWJ1Z0xvZ3MiLCJyZXN0T3B0aW9ucyIsImRhdGFiYXNlIiwicGF5bG9hZENsaWVudCIsImFkYXB0ZXJDb25maWciXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFVBQVUsUUFBUSxjQUFhO0FBRXhDLFNBQVNDLGNBQWMsUUFBUSxtQ0FBa0M7QUFHakUsT0FBTyxTQUFTQyxlQUFrRCxFQUNoRUMsT0FBTyxFQUNQQyxNQUFNLEVBQ05DLFNBQVMsRUFBRUMsa0JBQWtCLEtBQUssRUFBRSxHQUFHQyxhQUFhLEVBS3JEO0lBQ0MsT0FBT1AsV0FBVztRQUNoQixHQUFHTyxXQUFXO1FBQ2RDLFVBQVVQLGVBQWU7WUFDdkJRLGVBQWVOO1lBQ2ZPLGVBQWU7Z0JBQ2JKO2dCQUNBRjtZQUNGO1FBQ0Y7SUFDRjtBQUNGIn0=
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import type { BetterAuthPluginOptions } from '
|
|
2
|
-
export declare function configureAdminPlugin(plugin: any, options: BetterAuthPluginOptions): void;
|
|
1
|
+
import type { BetterAuthPluginOptions, BetterAuthSchemas } from '@/better-auth/types';
|
|
2
|
+
export declare function configureAdminPlugin(plugin: any, options: BetterAuthPluginOptions, resolvedSchemas: BetterAuthSchemas): void;
|
|
3
3
|
//# sourceMappingURL=admin-plugin.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-plugin.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"admin-plugin.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAA;AAIrF,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,uBAAuB,EAAE,eAAe,EAAE,iBAAiB,GAAG,IAAI,CAS5H"}
|
|
@@ -1,9 +1,12 @@
|
|
|
1
|
-
import { defaults } from "../../constants";
|
|
2
|
-
|
|
1
|
+
import { baModelKey, defaults } from "../../constants";
|
|
2
|
+
import { set } from "../../utils/set";
|
|
3
|
+
import { getSchemaCollectionSlug } from "../build-collections/utils/collection-schema";
|
|
4
|
+
export function configureAdminPlugin(plugin, options, resolvedSchemas) {
|
|
3
5
|
plugin.defaultRole = options.users?.defaultRole ?? defaults.userRole;
|
|
4
6
|
plugin.adminRoles = options.users?.adminRoles ?? [
|
|
5
7
|
defaults.adminRole
|
|
6
8
|
];
|
|
9
|
+
set(plugin, `schema.${baModelKey.session}.fields.impersonatedBy.references.model`, getSchemaCollectionSlug(resolvedSchemas, baModelKey.user));
|
|
7
10
|
}
|
|
8
11
|
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL3Nhbml0aXplLWJldHRlci1hdXRoLW9wdGlvbnMvYWRtaW4tcGx1Z2luLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJhTW9kZWxLZXksIGRlZmF1bHRzIH0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHR5cGUgeyBCZXR0ZXJBdXRoUGx1Z2luT3B0aW9ucywgQmV0dGVyQXV0aFNjaGVtYXMgfSBmcm9tICdAL2JldHRlci1hdXRoL3R5cGVzJ1xuaW1wb3J0IHsgc2V0IH0gZnJvbSAnLi4vLi4vdXRpbHMvc2V0J1xuaW1wb3J0IHsgZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWcgfSBmcm9tICcuLi9idWlsZC1jb2xsZWN0aW9ucy91dGlscy9jb2xsZWN0aW9uLXNjaGVtYSdcblxuZXhwb3J0IGZ1bmN0aW9uIGNvbmZpZ3VyZUFkbWluUGx1Z2luKHBsdWdpbjogYW55LCBvcHRpb25zOiBCZXR0ZXJBdXRoUGx1Z2luT3B0aW9ucywgcmVzb2x2ZWRTY2hlbWFzOiBCZXR0ZXJBdXRoU2NoZW1hcyk6IHZvaWQge1xuICBwbHVnaW4uZGVmYXVsdFJvbGUgPSBvcHRpb25zLnVzZXJzPy5kZWZhdWx0Um9sZSA/PyBkZWZhdWx0cy51c2VyUm9sZVxuICBwbHVnaW4uYWRtaW5Sb2xlcyA9IG9wdGlvbnMudXNlcnM/LmFkbWluUm9sZXMgPz8gW2RlZmF1bHRzLmFkbWluUm9sZV1cblxuICBzZXQoXG4gICAgcGx1Z2luLFxuICAgIGBzY2hlbWEuJHtiYU1vZGVsS2V5LnNlc3Npb259LmZpZWxkcy5pbXBlcnNvbmF0ZWRCeS5yZWZlcmVuY2VzLm1vZGVsYCxcbiAgICBnZXRTY2hlbWFDb2xsZWN0aW9uU2x1ZyhyZXNvbHZlZFNjaGVtYXMsIGJhTW9kZWxLZXkudXNlcilcbiAgKVxufVxuIl0sIm5hbWVzIjpbImJhTW9kZWxLZXkiLCJkZWZhdWx0cyIsInNldCIsImdldFNjaGVtYUNvbGxlY3Rpb25TbHVnIiwiY29uZmlndXJlQWRtaW5QbHVnaW4iLCJwbHVnaW4iLCJvcHRpb25zIiwicmVzb2x2ZWRTY2hlbWFzIiwiZGVmYXVsdFJvbGUiLCJ1c2VycyIsInVzZXJSb2xlIiwiYWRtaW5Sb2xlcyIsImFkbWluUm9sZSIsInNlc3Npb24iLCJ1c2VyIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxVQUFVLEVBQUVDLFFBQVEsUUFBUSxrQkFBaUI7QUFFdEQsU0FBU0MsR0FBRyxRQUFRLGtCQUFpQjtBQUNyQyxTQUFTQyx1QkFBdUIsUUFBUSwrQ0FBOEM7QUFFdEYsT0FBTyxTQUFTQyxxQkFBcUJDLE1BQVcsRUFBRUMsT0FBZ0MsRUFBRUMsZUFBa0M7SUFDcEhGLE9BQU9HLFdBQVcsR0FBR0YsUUFBUUcsS0FBSyxFQUFFRCxlQUFlUCxTQUFTUyxRQUFRO0lBQ3BFTCxPQUFPTSxVQUFVLEdBQUdMLFFBQVFHLEtBQUssRUFBRUUsY0FBYztRQUFDVixTQUFTVyxTQUFTO0tBQUM7SUFFckVWLElBQ0VHLFFBQ0EsQ0FBQyxPQUFPLEVBQUVMLFdBQVdhLE9BQU8sQ0FBQyx1Q0FBdUMsQ0FBQyxFQUNyRVYsd0JBQXdCSSxpQkFBaUJQLFdBQVdjLElBQUk7QUFFNUQifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/sanitize-better-auth-options/index.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,0BAA0B,EAAE,MAAM,4BAA4B,CAAA;AACxH,OAAO,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/sanitize-better-auth-options/index.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,0BAA0B,EAAE,MAAM,4BAA4B,CAAA;AACxH,OAAO,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAS9C;;GAEG;AACH,wBAAgB,yBAAyB,CAAC,EACxC,MAAM,EACN,aAAa,EACb,eAAe,EAChB,EAAE;IACD,MAAM,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAC,CAAA;IACxE,aAAa,EAAE,uBAAuB,CAAA;IACtC,eAAe,EAAE,iBAAiB,CAAA;CACnC,GAAG,0BAA0B,CAmI7B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { baModelFieldKeys, baModelKey, baseSlugs,
|
|
1
|
+
import { baModelFieldKeys, baModelKey, baseSlugs, supportedBAPluginIds } from "../../constants";
|
|
2
2
|
import { set } from "../../utils/set";
|
|
3
3
|
import { getSchemaCollectionSlug, getSchemaFieldName } from "../build-collections/utils/collection-schema";
|
|
4
4
|
import { configureAdminPlugin } from "./admin-plugin";
|
|
@@ -14,6 +14,9 @@ import { configureTwoFactorPlugin } from "./two-factor-plugin";
|
|
|
14
14
|
import { requireAdminInviteForSignUpMiddleware } from "./utils/require-admin-invite-for-sign-up-middleware";
|
|
15
15
|
import { useAdminInviteAfterEmailSignUpMiddleware } from "./utils/use-admin-invite-after-email-sign-up-middleware";
|
|
16
16
|
import { configureDeviceAuthorizationPlugin } from "./device-authorization-plugin";
|
|
17
|
+
import { adminBeforeRoleMiddleware } from "./utils/admin-before-role-middleware";
|
|
18
|
+
import { adminAfterRoleMiddleware } from "./utils/admin-after-role-middleware";
|
|
19
|
+
import { checkPluginExists } from "../../helpers/check-plugin-exists";
|
|
17
20
|
/**
|
|
18
21
|
* Sanitizes the BetterAuth options
|
|
19
22
|
*/ export function sanitizeBetterAuthOptions({ config, pluginOptions, resolvedSchemas }) {
|
|
@@ -23,11 +26,6 @@ import { configureDeviceAuthorizationPlugin } from "./device-authorization-plugi
|
|
|
23
26
|
const userCollectionSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.user);
|
|
24
27
|
const adminInvitationCollectionSlug = pluginOptions.adminInvitations?.slug ?? baseSlugs.adminInvitations;
|
|
25
28
|
set(betterAuthOptions, `${baModelKey.user}.modelName`, userCollectionSlug);
|
|
26
|
-
set(betterAuthOptions, `${baModelKey.user}.additionalFields.role`, {
|
|
27
|
-
type: 'string',
|
|
28
|
-
defaultValue: pluginOptions.users?.defaultRole || defaults.userRole,
|
|
29
|
-
input: false
|
|
30
|
-
});
|
|
31
29
|
const baseModels = [
|
|
32
30
|
baModelKey.account,
|
|
33
31
|
baModelKey.session,
|
|
@@ -102,7 +100,7 @@ import { configureDeviceAuthorizationPlugin } from "./device-authorization-plugi
|
|
|
102
100
|
}
|
|
103
101
|
// Configure plugins by type
|
|
104
102
|
const pluginConfigurators = {
|
|
105
|
-
[supportedBAPluginIds.admin]: (p)=>configureAdminPlugin(p, pluginOptions),
|
|
103
|
+
[supportedBAPluginIds.admin]: (p)=>configureAdminPlugin(p, pluginOptions, resolvedSchemas),
|
|
106
104
|
[supportedBAPluginIds.apiKey]: (p)=>configureApiKeyPlugin(p, resolvedSchemas),
|
|
107
105
|
[supportedBAPluginIds.passkey]: (p)=>configurePasskeyPlugin(p, resolvedSchemas),
|
|
108
106
|
[supportedBAPluginIds.organization]: (p)=>configureOrganizationPlugin(p, resolvedSchemas),
|
|
@@ -125,7 +123,15 @@ import { configureDeviceAuthorizationPlugin } from "./device-authorization-plugi
|
|
|
125
123
|
config,
|
|
126
124
|
resolvedSchemas
|
|
127
125
|
});
|
|
126
|
+
if (checkPluginExists(betterAuthOptions, supportedBAPluginIds.admin)) {
|
|
127
|
+
adminBeforeRoleMiddleware({
|
|
128
|
+
sanitizedOptions: betterAuthOptions
|
|
129
|
+
});
|
|
130
|
+
adminAfterRoleMiddleware({
|
|
131
|
+
sanitizedOptions: betterAuthOptions
|
|
132
|
+
});
|
|
133
|
+
}
|
|
128
134
|
return betterAuthOptions;
|
|
129
135
|
}
|
|
130
136
|
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/sanitize-better-auth-options/index.ts"],"sourcesContent":["import { baModelFieldKeys, baModelKey, baseSlugs, defaults, supportedBAPluginIds } from '@/better-auth/plugin/constants'\nimport { set } from '../../utils/set'\nimport { getSchemaCollectionSlug, getSchemaFieldName } from '../build-collections/utils/collection-schema'\nimport { configureAdminPlugin } from './admin-plugin'\nimport { configureApiKeyPlugin } from './api-key-plugin'\nimport { configureOidcPlugin } from './oidc-plugin'\nimport { configureOrganizationPlugin } from './organizations-plugin'\nimport { configurePasskeyPlugin } from './passkey-plugin'\nimport { configureSsoPlugin } from './sso-plugin'\nimport { ensurePasswordSetBeforeUserCreate } from './utils/ensure-password-set-before-create'\nimport { hashPassword, verifyPassword } from './utils/password'\nimport { saveToJwtMiddleware } from './utils/save-to-jwt-middleware'\n\nimport type { BetterAuthPluginOptions, BetterAuthSchemas, SanitizedBetterAuthOptions } from '@/better-auth/plugin/types'\nimport type { Config, Payload } from 'payload'\nimport { configureTwoFactorPlugin } from './two-factor-plugin'\nimport { requireAdminInviteForSignUpMiddleware } from './utils/require-admin-invite-for-sign-up-middleware'\nimport { useAdminInviteAfterEmailSignUpMiddleware } from './utils/use-admin-invite-after-email-sign-up-middleware'\nimport { configureDeviceAuthorizationPlugin } from './device-authorization-plugin'\n\n/**\n * Sanitizes the BetterAuth options\n */\nexport function sanitizeBetterAuthOptions({\n  config,\n  pluginOptions,\n  resolvedSchemas\n}: {\n  config: Payload['config'] | Config | Promise<Payload['config'] | Config>\n  pluginOptions: BetterAuthPluginOptions\n  resolvedSchemas: BetterAuthSchemas\n}): SanitizedBetterAuthOptions {\n  const betterAuthOptions: SanitizedBetterAuthOptions = { ...(pluginOptions.betterAuthOptions ?? {}) }\n\n  const userCollectionSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.user)\n  const adminInvitationCollectionSlug = pluginOptions.adminInvitations?.slug ?? baseSlugs.adminInvitations\n\n  set(betterAuthOptions, `${baModelKey.user}.modelName`, userCollectionSlug)\n  set(betterAuthOptions, `${baModelKey.user}.additionalFields.role`, {\n    type: 'string',\n    defaultValue: pluginOptions.users?.defaultRole || defaults.userRole,\n    input: false\n  })\n\n  const baseModels = [baModelKey.account, baModelKey.session, baModelKey.verification] as const\n  baseModels.forEach((model) => set(betterAuthOptions, `${model}.modelName`, getSchemaCollectionSlug(resolvedSchemas, model)))\n\n  set(\n    betterAuthOptions,\n    `${baModelKey.account}.fields.userId`,\n    getSchemaFieldName(resolvedSchemas, baModelKey.account, baModelFieldKeys.account.userId)\n  )\n  set(\n    betterAuthOptions,\n    `${baModelKey.session}.fields.userId`,\n    getSchemaFieldName(resolvedSchemas, baModelKey.session, baModelFieldKeys.session.userId)\n  )\n\n  set(betterAuthOptions, `emailAndPassword.enabled`, betterAuthOptions.emailAndPassword?.enabled ?? true)\n\n  // Configure password handling\n  if (betterAuthOptions.emailAndPassword?.enabled && !pluginOptions.disableDefaultPayloadAuth) {\n    betterAuthOptions.emailAndPassword.password = {\n      ...(betterAuthOptions.emailAndPassword.password || {}),\n      verify: ({ hash, password }) => verifyPassword({ hash, password }),\n      hash: (password) => hashPassword(password)\n    }\n  }\n\n  // Handle admin invite for sign up\n  if (pluginOptions.requireAdminInviteForSignUp) {\n    betterAuthOptions.socialProviders = betterAuthOptions.socialProviders || {}\n    betterAuthOptions.socialProviders = Object.fromEntries(\n      Object.entries(betterAuthOptions.socialProviders).map(([provider, config]) => [provider, { ...config, disableImplicitSignUp: true }])\n    )\n    requireAdminInviteForSignUpMiddleware({\n      options: betterAuthOptions,\n      pluginOptions\n    })\n  }\n  useAdminInviteAfterEmailSignUpMiddleware({\n    options: betterAuthOptions,\n    adminInvitationCollectionSlug,\n    userCollectionSlug\n  })\n\n  // Handle verification email blocking\n  if (pluginOptions.users?.blockFirstBetterAuthVerificationEmail && !pluginOptions.disableDefaultPayloadAuth) {\n    const originalSendEmail = betterAuthOptions?.emailVerification?.sendVerificationEmail\n    if (typeof originalSendEmail === 'function') {\n      betterAuthOptions.emailVerification = betterAuthOptions.emailVerification || {}\n      betterAuthOptions.emailVerification.sendVerificationEmail = async (data, request) => {\n        try {\n          const timeSinceCreation = new Date().getTime() - new Date(data.user.createdAt).getTime()\n          // Skip if user was created less than a minute ago (rely on Payload's email)\n          if (timeSinceCreation >= 60000) {\n            await originalSendEmail(data, request)\n          }\n        } catch (error) {\n          console.error('Error sending verification email:', error)\n        }\n      }\n    }\n  }\n\n  // Ensure password is set before user creation\n  if (!pluginOptions.disableDefaultPayloadAuth) {\n    ensurePasswordSetBeforeUserCreate(betterAuthOptions)\n  }\n\n  // Process plugins\n  if (betterAuthOptions.plugins?.length) {\n    try {\n      // Filter to only supported plugins\n      const supportedPlugins = betterAuthOptions.plugins.filter((plugin) => Object.values(supportedBAPluginIds).includes(plugin.id as any))\n\n      // Log warning for unsupported plugins\n      if (supportedPlugins.length !== betterAuthOptions.plugins.length) {\n        const unsupportedIds = betterAuthOptions.plugins\n          .filter((p) => !Object.values(supportedBAPluginIds).includes(p.id as any))\n          .map((p) => p.id)\n          .join(', ')\n\n        console.warn(`Unsupported BetterAuth plugins: ${unsupportedIds}. Supported: ${Object.values(supportedBAPluginIds).join(', ')}`)\n      }\n\n      // Configure plugins by type\n      const pluginConfigurators = {\n        [supportedBAPluginIds.admin]: (p: any) => configureAdminPlugin(p, pluginOptions),\n        [supportedBAPluginIds.apiKey]: (p: any) => configureApiKeyPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.passkey]: (p: any) => configurePasskeyPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.organization]: (p: any) => configureOrganizationPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.sso]: (p: any) => configureSsoPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.oidc]: (p: any) => configureOidcPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.twoFactor]: (p: any) => configureTwoFactorPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.deviceAuthorization]: (p: any) => configureDeviceAuthorizationPlugin(p, resolvedSchemas)\n      }\n\n      supportedPlugins.forEach((plugin) => {\n        const configurator = pluginConfigurators[plugin.id as keyof typeof pluginConfigurators]\n        if (configurator) configurator(plugin as any)\n      })\n\n      betterAuthOptions.plugins = supportedPlugins\n    } catch (error) {\n      throw new Error(`Error sanitizing BetterAuth plugins: ${error}`)\n    }\n  }\n\n  saveToJwtMiddleware({\n    sanitizedOptions: betterAuthOptions,\n    config,\n    resolvedSchemas\n  })\n\n  return betterAuthOptions\n}\n"],"names":["baModelFieldKeys","baModelKey","baseSlugs","defaults","supportedBAPluginIds","set","getSchemaCollectionSlug","getSchemaFieldName","configureAdminPlugin","configureApiKeyPlugin","configureOidcPlugin","configureOrganizationPlugin","configurePasskeyPlugin","configureSsoPlugin","ensurePasswordSetBeforeUserCreate","hashPassword","verifyPassword","saveToJwtMiddleware","configureTwoFactorPlugin","requireAdminInviteForSignUpMiddleware","useAdminInviteAfterEmailSignUpMiddleware","configureDeviceAuthorizationPlugin","sanitizeBetterAuthOptions","config","pluginOptions","resolvedSchemas","betterAuthOptions","userCollectionSlug","user","adminInvitationCollectionSlug","adminInvitations","slug","type","defaultValue","users","defaultRole","userRole","input","baseModels","account","session","verification","forEach","model","userId","emailAndPassword","enabled","disableDefaultPayloadAuth","password","verify","hash","requireAdminInviteForSignUp","socialProviders","Object","fromEntries","entries","map","provider","disableImplicitSignUp","options","blockFirstBetterAuthVerificationEmail","originalSendEmail","emailVerification","sendVerificationEmail","data","request","timeSinceCreation","Date","getTime","createdAt","error","console","plugins","length","supportedPlugins","filter","plugin","values","includes","id","unsupportedIds","p","join","warn","pluginConfigurators","admin","apiKey","passkey","organization","sso","oidc","twoFactor","deviceAuthorization","configurator","Error","sanitizedOptions"],"mappings":"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"}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/sanitize-better-auth-options/index.ts"],"sourcesContent":["import { baModelFieldKeys, baModelKey, baseSlugs, defaults, supportedBAPluginIds } from '@/better-auth/plugin/constants'\nimport { set } from '../../utils/set'\nimport { getSchemaCollectionSlug, getSchemaFieldName } from '../build-collections/utils/collection-schema'\nimport { configureAdminPlugin } from './admin-plugin'\nimport { configureApiKeyPlugin } from './api-key-plugin'\nimport { configureOidcPlugin } from './oidc-plugin'\nimport { configureOrganizationPlugin } from './organizations-plugin'\nimport { configurePasskeyPlugin } from './passkey-plugin'\nimport { configureSsoPlugin } from './sso-plugin'\nimport { ensurePasswordSetBeforeUserCreate } from './utils/ensure-password-set-before-create'\nimport { hashPassword, verifyPassword } from './utils/password'\nimport { saveToJwtMiddleware } from './utils/save-to-jwt-middleware'\n\nimport type { BetterAuthPluginOptions, BetterAuthSchemas, SanitizedBetterAuthOptions } from '@/better-auth/plugin/types'\nimport type { Config, Payload } from 'payload'\nimport { configureTwoFactorPlugin } from './two-factor-plugin'\nimport { requireAdminInviteForSignUpMiddleware } from './utils/require-admin-invite-for-sign-up-middleware'\nimport { useAdminInviteAfterEmailSignUpMiddleware } from './utils/use-admin-invite-after-email-sign-up-middleware'\nimport { configureDeviceAuthorizationPlugin } from './device-authorization-plugin'\nimport { adminBeforeRoleMiddleware } from './utils/admin-before-role-middleware'\nimport { adminAfterRoleMiddleware } from './utils/admin-after-role-middleware'\nimport { checkPluginExists } from '../../helpers/check-plugin-exists'\n\n/**\n * Sanitizes the BetterAuth options\n */\nexport function sanitizeBetterAuthOptions({\n  config,\n  pluginOptions,\n  resolvedSchemas\n}: {\n  config: Payload['config'] | Config | Promise<Payload['config'] | Config>\n  pluginOptions: BetterAuthPluginOptions\n  resolvedSchemas: BetterAuthSchemas\n}): SanitizedBetterAuthOptions {\n  const betterAuthOptions: SanitizedBetterAuthOptions = { ...(pluginOptions.betterAuthOptions ?? {}) }\n\n  const userCollectionSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.user)\n  const adminInvitationCollectionSlug = pluginOptions.adminInvitations?.slug ?? baseSlugs.adminInvitations\n\n  set(betterAuthOptions, `${baModelKey.user}.modelName`, userCollectionSlug)\n\n  const baseModels = [baModelKey.account, baModelKey.session, baModelKey.verification] as const\n  baseModels.forEach((model) => set(betterAuthOptions, `${model}.modelName`, getSchemaCollectionSlug(resolvedSchemas, model)))\n\n  set(\n    betterAuthOptions,\n    `${baModelKey.account}.fields.userId`,\n    getSchemaFieldName(resolvedSchemas, baModelKey.account, baModelFieldKeys.account.userId)\n  )\n  set(\n    betterAuthOptions,\n    `${baModelKey.session}.fields.userId`,\n    getSchemaFieldName(resolvedSchemas, baModelKey.session, baModelFieldKeys.session.userId)\n  )\n\n  set(betterAuthOptions, `emailAndPassword.enabled`, betterAuthOptions.emailAndPassword?.enabled ?? true)\n\n  // Configure password handling\n  if (betterAuthOptions.emailAndPassword?.enabled && !pluginOptions.disableDefaultPayloadAuth) {\n    betterAuthOptions.emailAndPassword.password = {\n      ...(betterAuthOptions.emailAndPassword.password || {}),\n      verify: ({ hash, password }) => verifyPassword({ hash, password }),\n      hash: (password) => hashPassword(password)\n    }\n  }\n\n  // Handle admin invite for sign up\n  if (pluginOptions.requireAdminInviteForSignUp) {\n    betterAuthOptions.socialProviders = betterAuthOptions.socialProviders || {}\n    betterAuthOptions.socialProviders = Object.fromEntries(\n      Object.entries(betterAuthOptions.socialProviders).map(([provider, config]) => [provider, { ...config, disableImplicitSignUp: true }])\n    )\n    requireAdminInviteForSignUpMiddleware({\n      options: betterAuthOptions,\n      pluginOptions\n    })\n  }\n\n  useAdminInviteAfterEmailSignUpMiddleware({\n    options: betterAuthOptions,\n    adminInvitationCollectionSlug,\n    userCollectionSlug\n  })\n\n  // Handle verification email blocking\n  if (pluginOptions.users?.blockFirstBetterAuthVerificationEmail && !pluginOptions.disableDefaultPayloadAuth) {\n    const originalSendEmail = betterAuthOptions?.emailVerification?.sendVerificationEmail\n    if (typeof originalSendEmail === 'function') {\n      betterAuthOptions.emailVerification = betterAuthOptions.emailVerification || {}\n      betterAuthOptions.emailVerification.sendVerificationEmail = async (data, request) => {\n        try {\n          const timeSinceCreation = new Date().getTime() - new Date(data.user.createdAt).getTime()\n          // Skip if user was created less than a minute ago (rely on Payload's email)\n          if (timeSinceCreation >= 60000) {\n            await originalSendEmail(data, request)\n          }\n        } catch (error) {\n          console.error('Error sending verification email:', error)\n        }\n      }\n    }\n  }\n\n  // Ensure password is set before user creation\n  if (!pluginOptions.disableDefaultPayloadAuth) {\n    ensurePasswordSetBeforeUserCreate(betterAuthOptions)\n  }\n\n  // Process plugins\n  if (betterAuthOptions.plugins?.length) {\n    try {\n      // Filter to only supported plugins\n      const supportedPlugins = betterAuthOptions.plugins.filter((plugin) => Object.values(supportedBAPluginIds).includes(plugin.id as any))\n\n      // Log warning for unsupported plugins\n      if (supportedPlugins.length !== betterAuthOptions.plugins.length) {\n        const unsupportedIds = betterAuthOptions.plugins\n          .filter((p) => !Object.values(supportedBAPluginIds).includes(p.id as any))\n          .map((p) => p.id)\n          .join(', ')\n\n        console.warn(`Unsupported BetterAuth plugins: ${unsupportedIds}. Supported: ${Object.values(supportedBAPluginIds).join(', ')}`)\n      }\n\n      // Configure plugins by type\n      const pluginConfigurators = {\n        [supportedBAPluginIds.admin]: (p: any) => configureAdminPlugin(p, pluginOptions, resolvedSchemas),\n        [supportedBAPluginIds.apiKey]: (p: any) => configureApiKeyPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.passkey]: (p: any) => configurePasskeyPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.organization]: (p: any) => configureOrganizationPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.sso]: (p: any) => configureSsoPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.oidc]: (p: any) => configureOidcPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.twoFactor]: (p: any) => configureTwoFactorPlugin(p, resolvedSchemas),\n        [supportedBAPluginIds.deviceAuthorization]: (p: any) => configureDeviceAuthorizationPlugin(p, resolvedSchemas)\n      }\n\n      supportedPlugins.forEach((plugin) => {\n        const configurator = pluginConfigurators[plugin.id as keyof typeof pluginConfigurators]\n        if (configurator) configurator(plugin as any)\n      })\n\n      betterAuthOptions.plugins = supportedPlugins\n    } catch (error) {\n      throw new Error(`Error sanitizing BetterAuth plugins: ${error}`)\n    }\n  }\n\n  saveToJwtMiddleware({\n    sanitizedOptions: betterAuthOptions,\n    config,\n    resolvedSchemas\n  })\n\n  if (checkPluginExists(betterAuthOptions, supportedBAPluginIds.admin)) {\n    adminBeforeRoleMiddleware({\n      sanitizedOptions: betterAuthOptions\n    })\n\n    adminAfterRoleMiddleware({\n      sanitizedOptions: betterAuthOptions\n    })\n  }\n\n  return betterAuthOptions\n}\n"],"names":["baModelFieldKeys","baModelKey","baseSlugs","supportedBAPluginIds","set","getSchemaCollectionSlug","getSchemaFieldName","configureAdminPlugin","configureApiKeyPlugin","configureOidcPlugin","configureOrganizationPlugin","configurePasskeyPlugin","configureSsoPlugin","ensurePasswordSetBeforeUserCreate","hashPassword","verifyPassword","saveToJwtMiddleware","configureTwoFactorPlugin","requireAdminInviteForSignUpMiddleware","useAdminInviteAfterEmailSignUpMiddleware","configureDeviceAuthorizationPlugin","adminBeforeRoleMiddleware","adminAfterRoleMiddleware","checkPluginExists","sanitizeBetterAuthOptions","config","pluginOptions","resolvedSchemas","betterAuthOptions","userCollectionSlug","user","adminInvitationCollectionSlug","adminInvitations","slug","baseModels","account","session","verification","forEach","model","userId","emailAndPassword","enabled","disableDefaultPayloadAuth","password","verify","hash","requireAdminInviteForSignUp","socialProviders","Object","fromEntries","entries","map","provider","disableImplicitSignUp","options","users","blockFirstBetterAuthVerificationEmail","originalSendEmail","emailVerification","sendVerificationEmail","data","request","timeSinceCreation","Date","getTime","createdAt","error","console","plugins","length","supportedPlugins","filter","plugin","values","includes","id","unsupportedIds","p","join","warn","pluginConfigurators","admin","apiKey","passkey","organization","sso","oidc","twoFactor","deviceAuthorization","configurator","Error","sanitizedOptions"],"mappings":"AAAA,SAASA,gBAAgB,EAAEC,UAAU,EAAEC,SAAS,EAAYC,oBAAoB,QAAQ,kBAAgC;AACxH,SAASC,GAAG,QAAQ,kBAAiB;AACrC,SAASC,uBAAuB,EAAEC,kBAAkB,QAAQ,+CAA8C;AAC1G,SAASC,oBAAoB,QAAQ,iBAAgB;AACrD,SAASC,qBAAqB,QAAQ,mBAAkB;AACxD,SAASC,mBAAmB,QAAQ,gBAAe;AACnD,SAASC,2BAA2B,QAAQ,yBAAwB;AACpE,SAASC,sBAAsB,QAAQ,mBAAkB;AACzD,SAASC,kBAAkB,QAAQ,eAAc;AACjD,SAASC,iCAAiC,QAAQ,4CAA2C;AAC7F,SAASC,YAAY,EAAEC,cAAc,QAAQ,mBAAkB;AAC/D,SAASC,mBAAmB,QAAQ,iCAAgC;AAIpE,SAASC,wBAAwB,QAAQ,sBAAqB;AAC9D,SAASC,qCAAqC,QAAQ,sDAAqD;AAC3G,SAASC,wCAAwC,QAAQ,0DAAyD;AAClH,SAASC,kCAAkC,QAAQ,gCAA+B;AAClF,SAASC,yBAAyB,QAAQ,uCAAsC;AAChF,SAASC,wBAAwB,QAAQ,sCAAqC;AAC9E,SAASC,iBAAiB,QAAQ,oCAAmC;AAErE;;CAEC,GACD,OAAO,SAASC,0BAA0B,EACxCC,MAAM,EACNC,aAAa,EACbC,eAAe,EAKhB;IACC,MAAMC,oBAAgD;QAAE,GAAIF,cAAcE,iBAAiB,IAAI,CAAC,CAAC;IAAE;IAEnG,MAAMC,qBAAqBxB,wBAAwBsB,iBAAiB1B,WAAW6B,IAAI;IACnF,MAAMC,gCAAgCL,cAAcM,gBAAgB,EAAEC,QAAQ/B,UAAU8B,gBAAgB;IAExG5B,IAAIwB,mBAAmB,GAAG3B,WAAW6B,IAAI,CAAC,UAAU,CAAC,EAAED;IAEvD,MAAMK,aAAa;QAACjC,WAAWkC,OAAO;QAAElC,WAAWmC,OAAO;QAAEnC,WAAWoC,YAAY;KAAC;IACpFH,WAAWI,OAAO,CAAC,CAACC,QAAUnC,IAAIwB,mBAAmB,GAAGW,MAAM,UAAU,CAAC,EAAElC,wBAAwBsB,iBAAiBY;IAEpHnC,IACEwB,mBACA,GAAG3B,WAAWkC,OAAO,CAAC,cAAc,CAAC,EACrC7B,mBAAmBqB,iBAAiB1B,WAAWkC,OAAO,EAAEnC,iBAAiBmC,OAAO,CAACK,MAAM;IAEzFpC,IACEwB,mBACA,GAAG3B,WAAWmC,OAAO,CAAC,cAAc,CAAC,EACrC9B,mBAAmBqB,iBAAiB1B,WAAWmC,OAAO,EAAEpC,iBAAiBoC,OAAO,CAACI,MAAM;IAGzFpC,IAAIwB,mBAAmB,CAAC,wBAAwB,CAAC,EAAEA,kBAAkBa,gBAAgB,EAAEC,WAAW;IAElG,8BAA8B;IAC9B,IAAId,kBAAkBa,gBAAgB,EAAEC,WAAW,CAAChB,cAAciB,yBAAyB,EAAE;QAC3Ff,kBAAkBa,gBAAgB,CAACG,QAAQ,GAAG;YAC5C,GAAIhB,kBAAkBa,gBAAgB,CAACG,QAAQ,IAAI,CAAC,CAAC;YACrDC,QAAQ,CAAC,EAAEC,IAAI,EAAEF,QAAQ,EAAE,GAAK7B,eAAe;oBAAE+B;oBAAMF;gBAAS;YAChEE,MAAM,CAACF,WAAa9B,aAAa8B;QACnC;IACF;IAEA,kCAAkC;IAClC,IAAIlB,cAAcqB,2BAA2B,EAAE;QAC7CnB,kBAAkBoB,eAAe,GAAGpB,kBAAkBoB,eAAe,IAAI,CAAC;QAC1EpB,kBAAkBoB,eAAe,GAAGC,OAAOC,WAAW,CACpDD,OAAOE,OAAO,CAACvB,kBAAkBoB,eAAe,EAAEI,GAAG,CAAC,CAAC,CAACC,UAAU5B,OAAO,GAAK;gBAAC4B;gBAAU;oBAAE,GAAG5B,MAAM;oBAAE6B,uBAAuB;gBAAK;aAAE;QAEtIpC,sCAAsC;YACpCqC,SAAS3B;YACTF;QACF;IACF;IAEAP,yCAAyC;QACvCoC,SAAS3B;QACTG;QACAF;IACF;IAEA,qCAAqC;IACrC,IAAIH,cAAc8B,KAAK,EAAEC,yCAAyC,CAAC/B,cAAciB,yBAAyB,EAAE;QAC1G,MAAMe,oBAAoB9B,mBAAmB+B,mBAAmBC;QAChE,IAAI,OAAOF,sBAAsB,YAAY;YAC3C9B,kBAAkB+B,iBAAiB,GAAG/B,kBAAkB+B,iBAAiB,IAAI,CAAC;YAC9E/B,kBAAkB+B,iBAAiB,CAACC,qBAAqB,GAAG,OAAOC,MAAMC;gBACvE,IAAI;oBACF,MAAMC,oBAAoB,IAAIC,OAAOC,OAAO,KAAK,IAAID,KAAKH,KAAK/B,IAAI,CAACoC,SAAS,EAAED,OAAO;oBACtF,4EAA4E;oBAC5E,IAAIF,qBAAqB,OAAO;wBAC9B,MAAML,kBAAkBG,MAAMC;oBAChC;gBACF,EAAE,OAAOK,OAAO;oBACdC,QAAQD,KAAK,CAAC,qCAAqCA;gBACrD;YACF;QACF;IACF;IAEA,8CAA8C;IAC9C,IAAI,CAACzC,cAAciB,yBAAyB,EAAE;QAC5C9B,kCAAkCe;IACpC;IAEA,kBAAkB;IAClB,IAAIA,kBAAkByC,OAAO,EAAEC,QAAQ;QACrC,IAAI;YACF,mCAAmC;YACnC,MAAMC,mBAAmB3C,kBAAkByC,OAAO,CAACG,MAAM,CAAC,CAACC,SAAWxB,OAAOyB,MAAM,CAACvE,sBAAsBwE,QAAQ,CAACF,OAAOG,EAAE;YAE5H,sCAAsC;YACtC,IAAIL,iBAAiBD,MAAM,KAAK1C,kBAAkByC,OAAO,CAACC,MAAM,EAAE;gBAChE,MAAMO,iBAAiBjD,kBAAkByC,OAAO,CAC7CG,MAAM,CAAC,CAACM,IAAM,CAAC7B,OAAOyB,MAAM,CAACvE,sBAAsBwE,QAAQ,CAACG,EAAEF,EAAE,GAChExB,GAAG,CAAC,CAAC0B,IAAMA,EAAEF,EAAE,EACfG,IAAI,CAAC;gBAERX,QAAQY,IAAI,CAAC,CAAC,gCAAgC,EAAEH,eAAe,aAAa,EAAE5B,OAAOyB,MAAM,CAACvE,sBAAsB4E,IAAI,CAAC,OAAO;YAChI;YAEA,4BAA4B;YAC5B,MAAME,sBAAsB;gBAC1B,CAAC9E,qBAAqB+E,KAAK,CAAC,EAAE,CAACJ,IAAWvE,qBAAqBuE,GAAGpD,eAAeC;gBACjF,CAACxB,qBAAqBgF,MAAM,CAAC,EAAE,CAACL,IAAWtE,sBAAsBsE,GAAGnD;gBACpE,CAACxB,qBAAqBiF,OAAO,CAAC,EAAE,CAACN,IAAWnE,uBAAuBmE,GAAGnD;gBACtE,CAACxB,qBAAqBkF,YAAY,CAAC,EAAE,CAACP,IAAWpE,4BAA4BoE,GAAGnD;gBAChF,CAACxB,qBAAqBmF,GAAG,CAAC,EAAE,CAACR,IAAWlE,mBAAmBkE,GAAGnD;gBAC9D,CAACxB,qBAAqBoF,IAAI,CAAC,EAAE,CAACT,IAAWrE,oBAAoBqE,GAAGnD;gBAChE,CAACxB,qBAAqBqF,SAAS,CAAC,EAAE,CAACV,IAAW7D,yBAAyB6D,GAAGnD;gBAC1E,CAACxB,qBAAqBsF,mBAAmB,CAAC,EAAE,CAACX,IAAW1D,mCAAmC0D,GAAGnD;YAChG;YAEA4C,iBAAiBjC,OAAO,CAAC,CAACmC;gBACxB,MAAMiB,eAAeT,mBAAmB,CAACR,OAAOG,EAAE,CAAqC;gBACvF,IAAIc,cAAcA,aAAajB;YACjC;YAEA7C,kBAAkByC,OAAO,GAAGE;QAC9B,EAAE,OAAOJ,OAAO;YACd,MAAM,IAAIwB,MAAM,CAAC,qCAAqC,EAAExB,OAAO;QACjE;IACF;IAEAnD,oBAAoB;QAClB4E,kBAAkBhE;QAClBH;QACAE;IACF;IAEA,IAAIJ,kBAAkBK,mBAAmBzB,qBAAqB+E,KAAK,GAAG;QACpE7D,0BAA0B;YACxBuE,kBAAkBhE;QACpB;QAEAN,yBAAyB;YACvBsE,kBAAkBhE;QACpB;IACF;IAEA,OAAOA;AACT"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { SanitizedBetterAuthOptions } from '@/better-auth/plugin/types';
|
|
2
|
+
/**
|
|
3
|
+
* Sets up a middleware that converts session.user.role from an a single string seperated by commas back to an array only for /admin routes
|
|
4
|
+
*/
|
|
5
|
+
export declare function adminAfterRoleMiddleware({ sanitizedOptions }: {
|
|
6
|
+
sanitizedOptions: SanitizedBetterAuthOptions;
|
|
7
|
+
}): void;
|
|
8
|
+
//# sourceMappingURL=admin-after-role-middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-after-role-middleware.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-after-role-middleware.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,4BAA4B,CAAA;AAE5E;;GAEG;AACH,wBAAgB,wBAAwB,CAAC,EAAE,gBAAgB,EAAE,EAAE;IAAE,gBAAgB,EAAE,0BAA0B,CAAA;CAAE,QAiB9G"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { createAuthMiddleware, getSessionFromCtx } from "better-auth/api";
|
|
2
|
+
/**
|
|
3
|
+
* Sets up a middleware that converts session.user.role from an a single string seperated by commas back to an array only for /admin routes
|
|
4
|
+
*/ export function adminAfterRoleMiddleware({ sanitizedOptions }) {
|
|
5
|
+
if (typeof sanitizedOptions.hooks !== 'object') sanitizedOptions.hooks = {};
|
|
6
|
+
const originalAfter = sanitizedOptions.hooks.after;
|
|
7
|
+
sanitizedOptions.hooks.after = createAuthMiddleware(async (ctx)=>{
|
|
8
|
+
if (ctx.path.startsWith('/admin')) {
|
|
9
|
+
await getSessionFromCtx(ctx);
|
|
10
|
+
if (ctx.context.session && ctx.context.session.user && typeof ctx.context.session.user.role === 'string') {
|
|
11
|
+
ctx.context.session.user.role = ctx.context.session.user.role.split(',').map((r)=>r.trim()).filter(Boolean);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
if (typeof originalAfter === 'function') {
|
|
15
|
+
originalAfter(ctx);
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL3Nhbml0aXplLWJldHRlci1hdXRoLW9wdGlvbnMvdXRpbHMvYWRtaW4tYWZ0ZXItcm9sZS1taWRkbGV3YXJlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUF1dGhNaWRkbGV3YXJlLCBnZXRTZXNzaW9uRnJvbUN0eCB9IGZyb20gJ2JldHRlci1hdXRoL2FwaSdcbmltcG9ydCB0eXBlIHsgU2FuaXRpemVkQmV0dGVyQXV0aE9wdGlvbnMgfSBmcm9tICdAL2JldHRlci1hdXRoL3BsdWdpbi90eXBlcydcblxuLyoqXG4gKiBTZXRzIHVwIGEgbWlkZGxld2FyZSB0aGF0IGNvbnZlcnRzIHNlc3Npb24udXNlci5yb2xlIGZyb20gYW4gYSBzaW5nbGUgc3RyaW5nIHNlcGVyYXRlZCBieSBjb21tYXMgYmFjayB0byBhbiBhcnJheSBvbmx5IGZvciAvYWRtaW4gcm91dGVzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBhZG1pbkFmdGVyUm9sZU1pZGRsZXdhcmUoeyBzYW5pdGl6ZWRPcHRpb25zIH06IHsgc2FuaXRpemVkT3B0aW9uczogU2FuaXRpemVkQmV0dGVyQXV0aE9wdGlvbnMgfSkge1xuICBpZiAodHlwZW9mIHNhbml0aXplZE9wdGlvbnMuaG9va3MgIT09ICdvYmplY3QnKSBzYW5pdGl6ZWRPcHRpb25zLmhvb2tzID0ge31cbiAgY29uc3Qgb3JpZ2luYWxBZnRlciA9IHNhbml0aXplZE9wdGlvbnMuaG9va3MuYWZ0ZXJcbiAgc2FuaXRpemVkT3B0aW9ucy5ob29rcy5hZnRlciA9IGNyZWF0ZUF1dGhNaWRkbGV3YXJlKGFzeW5jIChjdHgpID0+IHtcbiAgICBpZiAoY3R4LnBhdGguc3RhcnRzV2l0aCgnL2FkbWluJykpIHtcbiAgICAgIGF3YWl0IGdldFNlc3Npb25Gcm9tQ3R4KGN0eClcbiAgICAgIGlmIChjdHguY29udGV4dC5zZXNzaW9uICYmIGN0eC5jb250ZXh0LnNlc3Npb24udXNlciAmJiB0eXBlb2YgY3R4LmNvbnRleHQuc2Vzc2lvbi51c2VyLnJvbGUgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGN0eC5jb250ZXh0LnNlc3Npb24hLnVzZXIucm9sZSA9IGN0eC5jb250ZXh0LnNlc3Npb24udXNlci5yb2xlXG4gICAgICAgICAgLnNwbGl0KCcsJylcbiAgICAgICAgICAubWFwKChyOiBzdHJpbmcpID0+IHIudHJpbSgpKVxuICAgICAgICAgIC5maWx0ZXIoQm9vbGVhbilcbiAgICAgIH1cbiAgICB9XG4gICAgaWYgKHR5cGVvZiBvcmlnaW5hbEFmdGVyID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICBvcmlnaW5hbEFmdGVyKGN0eClcbiAgICB9XG4gIH0pXG59XG4iXSwibmFtZXMiOlsiY3JlYXRlQXV0aE1pZGRsZXdhcmUiLCJnZXRTZXNzaW9uRnJvbUN0eCIsImFkbWluQWZ0ZXJSb2xlTWlkZGxld2FyZSIsInNhbml0aXplZE9wdGlvbnMiLCJob29rcyIsIm9yaWdpbmFsQWZ0ZXIiLCJhZnRlciIsImN0eCIsInBhdGgiLCJzdGFydHNXaXRoIiwiY29udGV4dCIsInNlc3Npb24iLCJ1c2VyIiwicm9sZSIsInNwbGl0IiwibWFwIiwiciIsInRyaW0iLCJmaWx0ZXIiLCJCb29sZWFuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxvQkFBb0IsRUFBRUMsaUJBQWlCLFFBQVEsa0JBQWlCO0FBR3pFOztDQUVDLEdBQ0QsT0FBTyxTQUFTQyx5QkFBeUIsRUFBRUMsZ0JBQWdCLEVBQW9EO0lBQzdHLElBQUksT0FBT0EsaUJBQWlCQyxLQUFLLEtBQUssVUFBVUQsaUJBQWlCQyxLQUFLLEdBQUcsQ0FBQztJQUMxRSxNQUFNQyxnQkFBZ0JGLGlCQUFpQkMsS0FBSyxDQUFDRSxLQUFLO0lBQ2xESCxpQkFBaUJDLEtBQUssQ0FBQ0UsS0FBSyxHQUFHTixxQkFBcUIsT0FBT087UUFDekQsSUFBSUEsSUFBSUMsSUFBSSxDQUFDQyxVQUFVLENBQUMsV0FBVztZQUNqQyxNQUFNUixrQkFBa0JNO1lBQ3hCLElBQUlBLElBQUlHLE9BQU8sQ0FBQ0MsT0FBTyxJQUFJSixJQUFJRyxPQUFPLENBQUNDLE9BQU8sQ0FBQ0MsSUFBSSxJQUFJLE9BQU9MLElBQUlHLE9BQU8sQ0FBQ0MsT0FBTyxDQUFDQyxJQUFJLENBQUNDLElBQUksS0FBSyxVQUFVO2dCQUN4R04sSUFBSUcsT0FBTyxDQUFDQyxPQUFPLENBQUVDLElBQUksQ0FBQ0MsSUFBSSxHQUFHTixJQUFJRyxPQUFPLENBQUNDLE9BQU8sQ0FBQ0MsSUFBSSxDQUFDQyxJQUFJLENBQzNEQyxLQUFLLENBQUMsS0FDTkMsR0FBRyxDQUFDLENBQUNDLElBQWNBLEVBQUVDLElBQUksSUFDekJDLE1BQU0sQ0FBQ0M7WUFDWjtRQUNGO1FBQ0EsSUFBSSxPQUFPZCxrQkFBa0IsWUFBWTtZQUN2Q0EsY0FBY0U7UUFDaEI7SUFDRjtBQUNGIn0=
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { SanitizedBetterAuthOptions } from '@/better-auth/plugin/types';
|
|
2
|
+
/**
|
|
3
|
+
* Sets up a middleware that converts session.user.role from an array to a single string seperated by commas. only for /admin routes
|
|
4
|
+
*/
|
|
5
|
+
export declare function adminBeforeRoleMiddleware({ sanitizedOptions }: {
|
|
6
|
+
sanitizedOptions: SanitizedBetterAuthOptions;
|
|
7
|
+
}): void;
|
|
8
|
+
//# sourceMappingURL=admin-before-role-middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-before-role-middleware.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-before-role-middleware.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,4BAA4B,CAAA;AAE5E;;GAEG;AACH,wBAAgB,yBAAyB,CAAC,EAAE,gBAAgB,EAAE,EAAE;IAAE,gBAAgB,EAAE,0BAA0B,CAAA;CAAE,QAc/G"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { createAuthMiddleware, getSessionFromCtx } from "better-auth/api";
|
|
2
|
+
/**
|
|
3
|
+
* Sets up a middleware that converts session.user.role from an array to a single string seperated by commas. only for /admin routes
|
|
4
|
+
*/ export function adminBeforeRoleMiddleware({ sanitizedOptions }) {
|
|
5
|
+
if (typeof sanitizedOptions.hooks !== 'object') sanitizedOptions.hooks = {};
|
|
6
|
+
const originalBefore = sanitizedOptions.hooks.before;
|
|
7
|
+
sanitizedOptions.hooks.before = createAuthMiddleware(async (ctx)=>{
|
|
8
|
+
if (ctx.path.startsWith('/admin')) {
|
|
9
|
+
await getSessionFromCtx(ctx);
|
|
10
|
+
if (ctx.context.session && ctx.context.session.user && Array.isArray(ctx.context.session.user.role)) {
|
|
11
|
+
ctx.context.session.user.role = ctx.context.session.user.role.join(',');
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
if (typeof originalBefore === 'function') {
|
|
15
|
+
originalBefore(ctx);
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL3Nhbml0aXplLWJldHRlci1hdXRoLW9wdGlvbnMvdXRpbHMvYWRtaW4tYmVmb3JlLXJvbGUtbWlkZGxld2FyZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVBdXRoTWlkZGxld2FyZSwgZ2V0U2Vzc2lvbkZyb21DdHggfSBmcm9tICdiZXR0ZXItYXV0aC9hcGknXG5pbXBvcnQgdHlwZSB7IFNhbml0aXplZEJldHRlckF1dGhPcHRpb25zIH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9wbHVnaW4vdHlwZXMnXG5cbi8qKlxuICogU2V0cyB1cCBhIG1pZGRsZXdhcmUgdGhhdCBjb252ZXJ0cyBzZXNzaW9uLnVzZXIucm9sZSBmcm9tIGFuIGFycmF5IHRvIGEgc2luZ2xlIHN0cmluZyBzZXBlcmF0ZWQgYnkgY29tbWFzLiBvbmx5IGZvciAvYWRtaW4gcm91dGVzXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBhZG1pbkJlZm9yZVJvbGVNaWRkbGV3YXJlKHsgc2FuaXRpemVkT3B0aW9ucyB9OiB7IHNhbml0aXplZE9wdGlvbnM6IFNhbml0aXplZEJldHRlckF1dGhPcHRpb25zIH0pIHtcbiAgaWYgKHR5cGVvZiBzYW5pdGl6ZWRPcHRpb25zLmhvb2tzICE9PSAnb2JqZWN0Jykgc2FuaXRpemVkT3B0aW9ucy5ob29rcyA9IHt9XG4gIGNvbnN0IG9yaWdpbmFsQmVmb3JlID0gc2FuaXRpemVkT3B0aW9ucy5ob29rcy5iZWZvcmVcbiAgc2FuaXRpemVkT3B0aW9ucy5ob29rcy5iZWZvcmUgPSBjcmVhdGVBdXRoTWlkZGxld2FyZShhc3luYyAoY3R4KSA9PiB7XG4gICAgaWYgKGN0eC5wYXRoLnN0YXJ0c1dpdGgoJy9hZG1pbicpKSB7XG4gICAgICBhd2FpdCBnZXRTZXNzaW9uRnJvbUN0eChjdHgpXG4gICAgICBpZiAoY3R4LmNvbnRleHQuc2Vzc2lvbiAmJiBjdHguY29udGV4dC5zZXNzaW9uLnVzZXIgJiYgQXJyYXkuaXNBcnJheShjdHguY29udGV4dC5zZXNzaW9uLnVzZXIucm9sZSkpIHtcbiAgICAgICAgY3R4LmNvbnRleHQuc2Vzc2lvbiEudXNlci5yb2xlID0gY3R4LmNvbnRleHQuc2Vzc2lvbi51c2VyLnJvbGUuam9pbignLCcpXG4gICAgICB9XG4gICAgfVxuICAgIGlmICh0eXBlb2Ygb3JpZ2luYWxCZWZvcmUgPT09ICdmdW5jdGlvbicpIHtcbiAgICAgIG9yaWdpbmFsQmVmb3JlKGN0eClcbiAgICB9XG4gIH0pXG59XG4iXSwibmFtZXMiOlsiY3JlYXRlQXV0aE1pZGRsZXdhcmUiLCJnZXRTZXNzaW9uRnJvbUN0eCIsImFkbWluQmVmb3JlUm9sZU1pZGRsZXdhcmUiLCJzYW5pdGl6ZWRPcHRpb25zIiwiaG9va3MiLCJvcmlnaW5hbEJlZm9yZSIsImJlZm9yZSIsImN0eCIsInBhdGgiLCJzdGFydHNXaXRoIiwiY29udGV4dCIsInNlc3Npb24iLCJ1c2VyIiwiQXJyYXkiLCJpc0FycmF5Iiwicm9sZSIsImpvaW4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLG9CQUFvQixFQUFFQyxpQkFBaUIsUUFBUSxrQkFBaUI7QUFHekU7O0NBRUMsR0FDRCxPQUFPLFNBQVNDLDBCQUEwQixFQUFFQyxnQkFBZ0IsRUFBb0Q7SUFDOUcsSUFBSSxPQUFPQSxpQkFBaUJDLEtBQUssS0FBSyxVQUFVRCxpQkFBaUJDLEtBQUssR0FBRyxDQUFDO0lBQzFFLE1BQU1DLGlCQUFpQkYsaUJBQWlCQyxLQUFLLENBQUNFLE1BQU07SUFDcERILGlCQUFpQkMsS0FBSyxDQUFDRSxNQUFNLEdBQUdOLHFCQUFxQixPQUFPTztRQUMxRCxJQUFJQSxJQUFJQyxJQUFJLENBQUNDLFVBQVUsQ0FBQyxXQUFXO1lBQ2pDLE1BQU1SLGtCQUFrQk07WUFDeEIsSUFBSUEsSUFBSUcsT0FBTyxDQUFDQyxPQUFPLElBQUlKLElBQUlHLE9BQU8sQ0FBQ0MsT0FBTyxDQUFDQyxJQUFJLElBQUlDLE1BQU1DLE9BQU8sQ0FBQ1AsSUFBSUcsT0FBTyxDQUFDQyxPQUFPLENBQUNDLElBQUksQ0FBQ0csSUFBSSxHQUFHO2dCQUNuR1IsSUFBSUcsT0FBTyxDQUFDQyxPQUFPLENBQUVDLElBQUksQ0FBQ0csSUFBSSxHQUFHUixJQUFJRyxPQUFPLENBQUNDLE9BQU8sQ0FBQ0MsSUFBSSxDQUFDRyxJQUFJLENBQUNDLElBQUksQ0FBQztZQUN0RTtRQUNGO1FBQ0EsSUFBSSxPQUFPWCxtQkFBbUIsWUFBWTtZQUN4Q0EsZUFBZUU7UUFDakI7SUFDRjtBQUNGIn0=
|