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,5 @@
|
|
|
1
1
|
import { getAuthTables } from "better-auth/db";
|
|
2
|
+
import { getCollectionByModelKey, getCollectionFieldNameByFieldKeyUntyped, getFieldKeyByCollectionFieldName } from "../../plugin/helpers/get-collection";
|
|
2
3
|
export const createTransform = (options, enableDebugLogs)=>{
|
|
3
4
|
const schema = getAuthTables(options);
|
|
4
5
|
function debugLog(message) {
|
|
@@ -255,6 +256,10 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
255
256
|
});
|
|
256
257
|
}
|
|
257
258
|
}
|
|
259
|
+
// Handle role fields (Coming from better auth, will be a single string seperated by commas if theres multiple roles)
|
|
260
|
+
if (key === 'role' || key === 'roles') {
|
|
261
|
+
return value.split(',').map((role)=>role.trim().toLowerCase());
|
|
262
|
+
}
|
|
258
263
|
// Return original value if no conversion was needed or applicable
|
|
259
264
|
return value;
|
|
260
265
|
}
|
|
@@ -270,7 +275,7 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
270
275
|
* @param model - The model name in the schema
|
|
271
276
|
* @param idType - The expected ID type ('number' or 'text')
|
|
272
277
|
* @returns Transformed data compatible with Payload CMS
|
|
273
|
-
*/ function transformInput({ data, model, idType }) {
|
|
278
|
+
*/ function transformInput({ data, model, idType, payload }) {
|
|
274
279
|
const transformedData = {};
|
|
275
280
|
const schemaFields = schema?.[model]?.fields ?? {};
|
|
276
281
|
// Process each field in the input data
|
|
@@ -292,7 +297,8 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
292
297
|
});
|
|
293
298
|
// Use the schema-defined field name if available, otherwise use original key
|
|
294
299
|
const targetFieldName = schemaFieldName || key;
|
|
295
|
-
|
|
300
|
+
const targetFieldKey = getCollectionFieldNameByFieldKeyUntyped(getCollectionByModelKey(payload.collections, model), targetFieldName);
|
|
301
|
+
transformedData[targetFieldKey] = normalizedData;
|
|
296
302
|
});
|
|
297
303
|
return transformedData;
|
|
298
304
|
}
|
|
@@ -315,7 +321,7 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
315
321
|
* @param doc - The document returned from Payload CMS
|
|
316
322
|
* @param model - The model name in the BetterAuth schema
|
|
317
323
|
* @returns The transformed document compatible with BetterAuth
|
|
318
|
-
*/ function transformOutput({ doc, model }) {
|
|
324
|
+
*/ function transformOutput({ doc, model, payload }) {
|
|
319
325
|
if (!doc || typeof doc !== 'object') return doc;
|
|
320
326
|
const result = {
|
|
321
327
|
...doc
|
|
@@ -324,6 +330,14 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
324
330
|
// Identify relationship fields with custom field name mappings
|
|
325
331
|
const relationshipFields = Object.fromEntries(Object.entries(schemaFields).filter(([key])=>isRelationshipField(key, schemaFields)));
|
|
326
332
|
const dateFields = Object.fromEntries(Object.entries(schemaFields).filter(([_, value])=>value.type === 'date'));
|
|
333
|
+
// First make sure all the fields keys are correct
|
|
334
|
+
Object.keys(result).forEach((key)=>{
|
|
335
|
+
const targetFieldKey = getFieldKeyByCollectionFieldName(getCollectionByModelKey(payload.collections, model), key);
|
|
336
|
+
if (targetFieldKey !== key) {
|
|
337
|
+
result[targetFieldKey] = result[key];
|
|
338
|
+
delete result[key];
|
|
339
|
+
}
|
|
340
|
+
});
|
|
327
341
|
Object.entries(doc).forEach(([key, value])=>{
|
|
328
342
|
if (value === null || value === undefined) return;
|
|
329
343
|
// Convert ID fields to strings for BetterAuth compatibility
|
|
@@ -522,9 +536,12 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
522
536
|
* @param model - The model/collection name to query
|
|
523
537
|
* @param where - Array of Better Auth where conditions
|
|
524
538
|
* @returns A Payload-compatible where clause object
|
|
525
|
-
*/ function convertWhereClause({ idType, model, where }) {
|
|
539
|
+
*/ function convertWhereClause({ idType, model, where, payload }) {
|
|
526
540
|
// Handle empty where clause
|
|
527
541
|
if (!where) return {};
|
|
542
|
+
function getPayloadFieldName(fieldKey) {
|
|
543
|
+
return getCollectionFieldNameByFieldKeyUntyped(getCollectionByModelKey(payload.collections, model), fieldKey);
|
|
544
|
+
}
|
|
528
545
|
// Handle single condition case for optimization
|
|
529
546
|
if (where.length === 1) {
|
|
530
547
|
const w = where[0];
|
|
@@ -540,7 +557,7 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
540
557
|
});
|
|
541
558
|
// Create the Payload where condition with proper operator
|
|
542
559
|
const res = {
|
|
543
|
-
[fieldName]: operatorToPayload(w.operator ?? '', value)
|
|
560
|
+
[getPayloadFieldName(fieldName)]: operatorToPayload(w.operator ?? '', value)
|
|
544
561
|
};
|
|
545
562
|
return res;
|
|
546
563
|
}
|
|
@@ -557,7 +574,7 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
557
574
|
idType
|
|
558
575
|
});
|
|
559
576
|
return {
|
|
560
|
-
[fieldName]: operatorToPayload(w.operator ?? '', value)
|
|
577
|
+
[getPayloadFieldName(fieldName)]: operatorToPayload(w.operator ?? '', value)
|
|
561
578
|
};
|
|
562
579
|
});
|
|
563
580
|
// Process OR conditions
|
|
@@ -569,7 +586,7 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
569
586
|
idType
|
|
570
587
|
});
|
|
571
588
|
return {
|
|
572
|
-
[fieldName]: operatorToPayload(w.operator ?? '', value)
|
|
589
|
+
[getPayloadFieldName(fieldName)]: operatorToPayload(w.operator ?? '', value)
|
|
573
590
|
};
|
|
574
591
|
});
|
|
575
592
|
// Combine AND and OR clauses into final Payload where object
|
|
@@ -644,4 +661,4 @@ export const createTransform = (options, enableDebugLogs)=>{
|
|
|
644
661
|
};
|
|
645
662
|
};
|
|
646
663
|
|
|
647
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../src/better-auth/adapter/transform/index.ts"],"sourcesContent":["import { getAuthTables } from 'better-auth/db'\nimport type { ModelKey } from '@/better-auth/generated-types'\nimport type { BetterAuthOptions, Where } from 'better-auth'\nimport type { DBFieldAttribute } from 'better-auth/db'\nimport type { CollectionSlug, Where as PayloadWhere } from 'payload'\n\nexport const createTransform = (options: BetterAuthOptions, enableDebugLogs: boolean) => {\n  const schema = getAuthTables(options)\n\n  function debugLog(message: any[]) {\n    if (enableDebugLogs) {\n      console.log(`[payload-db-adapter]`, ...message)\n    }\n  }\n\n  /**\n   * Maps a BetterAuth schema model name to its corresponding Payload CMS collection slug.\n   *\n   * This function resolves the appropriate collection slug by:\n   * 1. Looking up the model in the BetterAuth schema to find its configured modelName\n   * 2. Falling back to the original model name if no mapping exists\n   *\n   * Collection slug resolution follows these rules:\n   * - For base collections: The sanitizeBetterAuthOptions function ensures the collection slug\n   *   from plugin options is set as the model name in the schema\n   * - For plugins: The betterAuthPluginSlugs constant is used as the modelName\n   *\n   * @param model - The BetterAuth model name to resolve\n   * @returns The corresponding Payload CMS collection slug\n   *\n   * @example\n   * // If schema['user'].modelName is 'users'\n   * getCollectionSlug('user') // Returns 'users'\n   *\n   * @example\n   * // If model doesn't exist in schema\n   * getCollectionSlug('custom') // Returns 'custom'\n   *\n   * @warning If a collection is overridden using the collectionOverride option\n   * without updating the schema mapping, this function may return incorrect slugs\n   */\n  function getCollectionSlug(model: ModelKey): CollectionSlug {\n    // First try to get the modelName from schema, otherwise fall back to the original model name\n    const collection = schema?.[model]?.modelName || model\n    debugLog(['getCollectionSlug:', { model, resolvedSlug: collection }])\n    return collection as CollectionSlug\n  }\n\n  /**\n   * Maps a BetterAuth schema field to its corresponding Payload CMS field name.\n   *\n   * This function resolves the appropriate field name by:\n   * 1. Preserving 'id' or '_id' fields as-is (special case handling)\n   * 2. Looking up the field in the BetterAuth schema to find its configured fieldName\n   * 3. Falling back to the original field name if no mapping exists\n   *\n   * @param model - The BetterAuth model name containing the field\n   * @param field - The original field name to resolve\n   * @returns The corresponding Payload CMS field name\n   *\n   * @example\n   * // If schema['user'].fields['email'].fieldName is 'emailAddress'\n   * getFieldName('user', 'email') // Returns 'emailAddress'\n   *\n   * @example\n   * // Special case for ID fields\n   * getFieldName('user', 'id') // Always returns 'id'\n   *\n   * @example\n   * // If field doesn't exist in schema or has no fieldName mapping\n   * getFieldName('user', 'custom') // Returns 'custom'\n   *\n   * @warning If a fieldName is overridden in the payload collection config using the collectionOverride option\n   * without updating the schema mapping, this function may return incorrect field names\n   */\n  function getFieldName(model: ModelKey, field: string): string {\n    // Special case: 'id' or '_id' is always preserved as-is\n    if (['id', '_id'].includes(field)) {\n      return field\n    }\n\n    // Look up the field in the schema\n    const fieldDefinition = schema[model]?.fields[field]\n\n    // Use the configured fieldName if available, otherwise fall back to original\n    const fieldName = fieldDefinition?.fieldName || field\n\n    // Log the field resolution for debugging\n    debugLog(['getField: ', { model, originalField: field, fieldName }])\n\n    return fieldName\n  }\n\n  /**\n   * Determines if a field is a relationship field by checking for a references property.\n   *\n   * Relationship fields in the schema have a 'references' property that points to another model.\n   * This function checks if this property exists to identify relationship fields.\n   *\n   * @param fieldKey - The key of the field to check in the schema\n   * @param schemaFields - Object containing all fields from the schema for a specific model\n   * @returns True if the field is a relationship field (has references), false otherwise\n   *\n   * @example\n   * // If schema.user.fields.posts has { references: {} }\n   * isRelationshipField('posts', schema.user.fields) // Returns true\n   *\n   * @example\n   * // If schema.user.fields.email has no references property\n   * isRelationshipField('email', schema.user.fields) // Returns false\n   */\n  function isRelationshipField(fieldKey: string, schemaFields: Record<string, DBFieldAttribute>): boolean {\n    // A field is a relationship field if it has a 'references' property defined\n    return schemaFields[fieldKey]?.references !== undefined\n  }\n  /**\n   * Extracts a single ID value from a Payload where clause if it represents a simple ID query.\n   *\n   * This function analyzes a Payload where clause to determine if it's a simple query for a\n   * single document by ID. It supports both 'id' and '_id' fields with 'equals' or 'contains'\n   * operators. This is useful for optimizing queries when we only need to fetch a single document.\n   *\n   * @param where - The Payload where clause to analyze\n   * @returns The ID value (string or number) if the where clause is a simple ID query, null otherwise\n   *\n   * @example\n   * // Returns '123' for a simple equals query\n   * singleIdQuery({ id: { equals: '123' } }) // '123'\n   *\n   * @example\n   * // Returns 456 for a simple equals query with number ID\n   * singleIdQuery({ _id: { equals: 456 } }) // 456\n   *\n   * @example\n   * // Returns '789' for a contains query with a single value\n   * singleIdQuery({ id: { contains: ['789'] } }) // '789'\n   *\n   * @example\n   * // Returns null for complex queries\n   * singleIdQuery({ and: [{ id: { equals: '123' } }] }) // null\n   */\n  function singleIdQuery(where: PayloadWhere) {\n    // Return null for empty where clauses or complex queries with 'and'/'or' operators\n    if (!where || 'and' in where || 'or' in where) return null\n\n    // Check if the where clause contains either 'id' or '_id' field\n    if (['id', '_id'].some((field) => field in where)) {\n      // Determine which ID field is being used (support both 'id' and '_id')\n      const idField = 'id' in where ? 'id' : '_id'\n      const condition = where[idField]\n\n      // Process the equals operator case\n      if (condition && typeof condition === 'object' && !Array.isArray(condition) && 'equals' in condition) {\n        const value = condition.equals\n        // Only return string or number ID values\n        if (typeof value === 'string' || typeof value === 'number') {\n          return value\n        }\n      }\n\n      // Process the contains operator case with a single value\n      if (\n        condition &&\n        typeof condition === 'object' &&\n        !Array.isArray(condition) &&\n        'contains' in condition &&\n        Array.isArray(condition.contains) &&\n        condition.contains.length === 1\n      ) {\n        const value = condition.contains[0]\n        // Only return string or number ID values\n        if (typeof value === 'string' || typeof value === 'number') {\n          return value\n        }\n      }\n    }\n\n    // Return null if no valid ID query was found\n    return null\n  }\n\n  /**\n   * Normalizes data values based on field type and required ID type\n   *\n   * This function handles type conversion for relationship fields to ensure\n   * IDs are in the correct format (string or number) based on the configuration.\n   *\n   * @param key - The field key/name\n   * @param value - The value to normalize\n   * @param isRelatedField - Whether this field is a relationship field\n   * @param idType - The expected ID type ('number' or 'text')\n   * @returns The normalized value\n   */\n  function normalizeData({\n    key,\n    value,\n    isRelatedField,\n    idType\n  }: {\n    key: string\n    value: any\n    isRelatedField: boolean\n    idType: 'number' | 'text'\n  }) {\n    // Skip processing for null/undefined values\n    if (value === null || value === undefined) {\n      return value\n    }\n\n    if (['id', '_id'].includes(key)) {\n      if (typeof value === 'string' && idType === 'number') {\n        const parsed = parseInt(value, 10)\n        if (!isNaN(parsed)) {\n          debugLog([`ID conversion: ${key} converting string ID to number`, { original: value, converted: parsed }])\n          return parsed\n        }\n      }\n      if (typeof value === 'number' && idType === 'text') {\n        const stringId = String(value)\n        debugLog([`ID conversion: ${key} converting number ID to string`, { original: value, converted: stringId }])\n        return stringId\n      }\n    }\n\n    // Only process relationship fields that need type conversion\n    if (isRelatedField) {\n      // Handle single ID value conversion\n      if (typeof value === 'string' && idType === 'number') {\n        const parsed = parseInt(value, 10)\n        if (!isNaN(parsed)) {\n          debugLog([`ID conversion: ${key} converting string ID to number`, { original: value, converted: parsed }])\n          return parsed\n        }\n      } else if (typeof value === 'number' && idType === 'text') {\n        const stringId = String(value)\n        debugLog([`ID conversion: ${key} converting number ID to string`, { original: value, converted: stringId }])\n        return stringId\n      }\n\n      // Handle array of IDs - map each value to the correct type\n      if (Array.isArray(value)) {\n        return value.map((id) => {\n          // Skip null/undefined values in arrays\n          if (id === null || id === undefined) return id\n\n          if (idType === 'number' && typeof id === 'string') {\n            const parsed = parseInt(id, 10)\n            return !isNaN(parsed) ? parsed : id\n          } else if (idType === 'text' && typeof id === 'number') {\n            return String(id)\n          }\n          return id\n        })\n      }\n    }\n\n    // Return original value if no conversion was needed or applicable\n    return value\n  }\n\n  /**\n   * Transforms input data from better-auth to Payload CMS format\n   *\n   * This function handles:\n   * 1. Field name mapping according to schema definitions\n   * 2. ID type conversion for relationship fields\n   * 3. Proper data normalization based on field types\n   *\n   * @param data - The input data from better-auth\n   * @param model - The model name in the schema\n   * @param idType - The expected ID type ('number' or 'text')\n   * @returns Transformed data compatible with Payload CMS\n   */\n  function transformInput({\n    data,\n    model,\n    idType\n  }: {\n    data: Record<string, any>\n    model: ModelKey\n    idType: 'number' | 'text'\n  }): Record<string, any> {\n    const transformedData: Record<string, any> = {}\n    const schemaFields = schema?.[model]?.fields ?? {}\n\n    // Process each field in the input data\n    Object.entries(data).forEach(([key, value]) => {\n      // Skip null/undefined values\n      if (value === null || value === undefined) {\n        return\n      }\n\n      // Determine if this is a relationship field\n      const isRelatedField = isRelationshipField(key, schemaFields)\n\n      // Get the mapped field name from schema (if any)\n      const schemaFieldName = schemaFields[key]?.fieldName\n\n      // Normalize the data value based on field type and ID type\n      const normalizedData = normalizeData({\n        idType,\n        key,\n        value,\n        isRelatedField\n      })\n\n      // Use the schema-defined field name if available, otherwise use original key\n      const targetFieldName = schemaFieldName || key\n      transformedData[targetFieldName] = normalizedData\n    })\n\n    return transformedData\n  }\n\n  /**\n   * Transforms Payload CMS document output to match BetterAuth schema expectations.\n   *\n   * This function handles several critical transformations:\n   *\n   * 1. ID Conversion: Ensures all ID fields are strings as required by BetterAuth\n   *    (see: https://github.com/better-auth/better-auth/blob/main/packages/better-auth/src/db/schema.ts#L125)\n   *\n   * 2. Relationship Field Mapping: Aligns relationship fields with BetterAuth schema naming conventions\n   *    and ensures proper ID type handling\n   *\n   * 3. Date Conversion: Transforms date strings from Payload into Date objects for BetterAuth\n   *\n   * Note: While setting depth: 1 in Payload operations simplifies this process by avoiding\n   * deeply nested objects, we maintain comprehensive checks for robustness.\n   *\n   * @param doc - The document returned from Payload CMS\n   * @param model - The model name in the BetterAuth schema\n   * @returns The transformed document compatible with BetterAuth\n   */\n  function transformOutput<T extends Record<string, any> | null>({ doc, model }: { doc: T; model: ModelKey }): T {\n    if (!doc || typeof doc !== 'object') return doc\n\n    const result = { ...doc }\n    const schemaFields = schema?.[model]?.fields ?? {}\n\n    // Identify relationship fields with custom field name mappings\n    const relationshipFields = Object.fromEntries(Object.entries(schemaFields).filter(([key]) => isRelationshipField(key, schemaFields)))\n    const dateFields = Object.fromEntries(Object.entries(schemaFields).filter(([_, value]) => value.type === 'date'))\n\n    Object.entries(doc).forEach(([key, value]) => {\n      if (value === null || value === undefined) return\n\n      // Convert ID fields to strings for BetterAuth compatibility\n      if (['id', '_id'].includes(key)) {\n        result[key] = String(value)\n        return\n      }\n\n      // Handle relationship fields with renamed fieldNames\n      const originalRelatedFieldKey = Object.keys(relationshipFields).find((k) => relationshipFields[k].fieldName === key)\n      if (originalRelatedFieldKey) {\n        normalizeDocumentIds(result, originalRelatedFieldKey, key, value)\n        return\n      }\n\n      const originalDateFieldKey = Object.keys(dateFields).find((k) => dateFields[k].fieldName === key)\n      if (originalDateFieldKey) {\n        // Convert ISO date strings to Date objects for BetterAuth\n        result[key] = new Date(value)\n        return\n      }\n    })\n\n    return result as T\n  }\n\n  /**\n   * Normalizes ID fields for both primary and relationship documents.\n   *\n   * This function ensures consistent ID handling between BetterAuth and Payload CMS by:\n   * 1. Converting all IDs to strings for BetterAuth (stored in originalKey)\n   * 2. Preserving original ID types for Payload CMS (stored in fieldName)\n   *\n   * The function handles various ID formats:\n   * - Primitive values (string/number IDs)\n   * - Object references with ID properties\n   * - Arrays of either primitive IDs or object references\n   *\n   * @param result - The result object being transformed\n   * @param originalKey - The original field key from BetterAuth schema\n   * @param fieldName - The renamed field as used in Payload CMS\n   * @param value - The ID value to normalize (primitive, object, or array)\n   */\n  function normalizeDocumentIds(result: Record<string, any>, originalKey: string, fieldName: string, value: any): void {\n    // Case 1: Primitive ID value (string or number)\n    if (typeof value === 'string' || typeof value === 'number') {\n      // For BetterAuth: Always use string IDs\n      result[originalKey] = String(value)\n      // For Payload: Keep original type\n      result[fieldName] = value\n      return\n    }\n\n    // Case 2: Object with ID property\n    if (typeof value === 'object' && value !== null && 'id' in value) {\n      // For BetterAuth: Extract and stringify the ID\n      result[originalKey] = String(value.id)\n      // For Payload: Extract ID but preserve type\n      result[fieldName] = value.id\n      return\n    }\n\n    // Case 3: Array of IDs or references\n    if (Array.isArray(value) && value.length > 0) {\n      // Check if array contains objects with ID properties\n      if (value.every((item) => typeof item === 'object' && item !== null && 'id' in item)) {\n        // Array of objects with IDs\n        result[originalKey] = value.map((item) => String(item.id))\n        result[fieldName] = value.map((item) => item.id)\n      } else {\n        // Array of primitive IDs\n        result[originalKey] = value.map((item) => String(item))\n        result[fieldName] = value.map((item) => item)\n      }\n      return\n    }\n\n    // Note: If value doesn't match any expected format, no changes are made\n  }\n\n  /**\n   * Converts a BetterAuth operator to the equivalent Payload CMS query operator\n   *\n   * This function maps standard query operators from BetterAuth's format to\n   * the specific format expected by Payload CMS's query engine.\n   *\n   * @param operator - The BetterAuth operator string (e.g., 'eq', 'gt', 'contains')\n   * @param value - The value to be used with the operator\n   * @returns An object with the Payload-compatible operator and value\n   *\n   * @example\n   * // Returns { equals: 'test@example.com' }\n   * operatorToPayload('eq', 'test@example.com')\n   *\n   * @example\n   * // Returns { greater_than: 100 }\n   * operatorToPayload('gt', 100)\n   */\n  function operatorToPayload(operator: string, value: any): Record<string, any> {\n    switch (operator) {\n      case 'eq':\n        return { equals: value }\n      case 'ne':\n        return { not_equals: value }\n      case 'gt':\n        return { greater_than: value }\n      case 'gte':\n        return { greater_than_equal: value }\n      case 'lt':\n        return { less_than: value }\n      case 'lte':\n        return { less_than_equal: value }\n      case 'contains':\n        return { contains: value }\n      case 'in':\n        return { in: value }\n      case 'starts_with':\n        return { like: `${value}%` }\n      case 'ends_with':\n        return { like: `%${value}` }\n      default:\n        // Fall back to equals for unrecognized operators\n        return { equals: value }\n    }\n  }\n\n  /**\n   * Converts a where clause value to the appropriate type based on field name and ID type configuration\n   *\n   * This function handles two main scenarios:\n   * 1. ID field conversion - ensures IDs match the database's expected type (number or string)\n   * 2. Object with embedded ID - extracts and converts the ID property from objects\n   *\n   * @param value - The value to convert (can be primitive, object with ID, or array)\n   * @param fieldName - The name of the field being queried\n   * @param idType - The expected ID type in the database\n   * @returns The converted value appropriate for the database query\n   */\n  function convertWhereValue({ value, fieldName, idType }: { value: any; fieldName: string; idType: 'number' | 'text' }) {\n    // Check if field is an ID field (supporting both MongoDB-style _id and standard id)\n    if (['id', '_id'].includes(fieldName)) {\n      // Case 1: Value is an object containing an ID property\n      if (typeof value === 'object' && value !== null && 'id' in value) {\n        // Extract ID from object\n        const id = value.id\n\n        // Use type conversion based on database configuration\n        if (idType === 'number' && typeof id === 'string') {\n          const numId = Number(id)\n          return !isNaN(numId) ? numId : id\n        }\n\n        if (idType === 'text' && typeof id === 'number') {\n          return String(id)\n        }\n\n        return id\n      }\n      // Case 2: Value is a standalone ID that needs type conversion\n      // Convert string ID to number if database expects numeric IDs\n      if (idType === 'number' && typeof value === 'string' && !isNaN(Number(value))) {\n        return Number(value)\n      }\n      // Convert numeric ID to string if database expects text IDs\n      else if (idType === 'text' && typeof value === 'number') {\n        return String(value)\n      }\n      return value\n    }\n\n    // For non-ID fields, return the value unchanged\n    return value\n  }\n\n  /**\n   * Converts Better Auth where clauses to Payload CMS compatible where conditions\n   *\n   * This function transforms the Better Auth query format into Payload's query format,\n   * handling field name mapping, value type conversion, and logical operators (AND/OR).\n   *\n   * The function handles three main cases:\n   * 1. Empty or undefined where clause - returns empty object\n   * 2. Single condition - converts to a simple field-value pair\n   * 3. Multiple conditions - groups by AND/OR connectors and builds a complex query\n   *\n   * @param idType - The database ID type ('number' or 'text')\n   * @param model - The model/collection name to query\n   * @param where - Array of Better Auth where conditions\n   * @returns A Payload-compatible where clause object\n   */\n  function convertWhereClause({ idType, model, where }: { idType: 'number' | 'text'; model: ModelKey; where?: Where[] }): PayloadWhere {\n    // Handle empty where clause\n    if (!where) return {}\n\n    // Handle single condition case for optimization\n    if (where.length === 1) {\n      const w = where[0]\n      if (!w) {\n        return {}\n      }\n\n      // Map field name according to schema and convert value to appropriate type\n      const fieldName = getFieldName(model, w.field)\n      const value = convertWhereValue({\n        value: w.value,\n        fieldName,\n        idType\n      })\n\n      // Create the Payload where condition with proper operator\n      const res = {\n        [fieldName]: operatorToPayload(w.operator ?? '', value)\n      }\n\n      return res\n    }\n\n    // Handle multiple conditions by separating AND/OR clauses\n    // Default to AND if no connector is specified\n    const and = where.filter((w) => w.connector === 'AND' || !w.connector)\n    const or = where.filter((w) => w.connector === 'OR')\n\n    // Process AND conditions\n    const andClause = and.map((w) => {\n      const fieldName = getFieldName(model, w.field)\n      const value = convertWhereValue({\n        value: w.value,\n        fieldName,\n        idType\n      })\n      return {\n        [fieldName]: operatorToPayload(w.operator ?? '', value)\n      }\n    })\n\n    // Process OR conditions\n    const orClause = or.map((w) => {\n      const fieldName = getFieldName(model, w.field)\n      const value = convertWhereValue({\n        value: w.value,\n        fieldName,\n        idType\n      })\n      return {\n        [fieldName]: operatorToPayload(w.operator ?? '', value)\n      }\n    })\n\n    // Combine AND and OR clauses into final Payload where object\n    // Only include non-empty clause arrays\n    return {\n      ...(andClause.length ? { AND: andClause } : {}),\n      ...(orClause.length ? { OR: orClause } : {})\n    }\n  }\n\n  /**\n   * Converts a better-auth select array to a Payload select object\n   *\n   * This function transforms the better-auth select array (which contains field names)\n   * into the format expected by Payload CMS's query API (an object with field names as keys\n   * and boolean true as values).\n   *\n   * It also handles field name mapping between better-auth schema and Payload collections\n   * by using the getFieldName helper to resolve the correct field names.\n   *\n   * @param model - The model/collection name to get field mappings from\n   * @param select - Optional array of field names to select\n   * @returns A Payload-compatible select object or undefined if no fields to select\n   * @example\n   * // Input: ['email', 'name']\n   * // Output: { email: true, name: true }\n   */\n  function convertSelect(model: ModelKey, select?: string[]) {\n    // Return undefined if select is empty or not provided\n    if (!select || select.length === 0) return undefined\n\n    // Transform the array of field names into a Payload select object\n    // while also mapping any field names that might be different in Payload\n    return select.reduce((acc, field) => ({ ...acc, [getFieldName(model, field)]: true }), {})\n  }\n\n  /**\n   * Converts a better-auth sort object to a Payload sort string\n   *\n   * This function transforms the better-auth sort object (which contains field name and direction)\n   * into the format expected by Payload CMS's query API (a string with optional '-' prefix for descending order).\n   *\n   * It also handles field name mapping between better-auth schema and Payload collections\n   * by using the getFieldName helper to resolve the correct field names.\n   *\n   * @param model - The model/collection name to get field mappings from\n   * @param sortBy - Optional object containing field name and sort direction\n   * @returns A Payload-compatible sort string or undefined if no sort specified\n   * @example\n   * // Input: { field: 'email', direction: 'desc' }\n   * // Output: '-email'\n   * // Input: { field: 'createdAt', direction: 'asc' }\n   * // Output: 'createdAt'\n   */\n  function convertSort(model: ModelKey, sortBy?: { field: string; direction: 'asc' | 'desc' }): string | undefined {\n    if (!sortBy) return undefined\n    const fieldName = getFieldName(model, sortBy.field)\n    const prefix = sortBy.direction === 'desc' ? '-' : ''\n    return `${prefix}${fieldName}`\n  }\n\n  return {\n    getFieldName,\n    getCollectionSlug,\n    singleIdQuery,\n    transformInput,\n    transformOutput,\n    convertWhereClause,\n    convertSelect,\n    convertSort\n  }\n}\n"],"names":["getAuthTables","createTransform","options","enableDebugLogs","schema","debugLog","message","console","log","getCollectionSlug","model","collection","modelName","resolvedSlug","getFieldName","field","includes","fieldDefinition","fields","fieldName","originalField","isRelationshipField","fieldKey","schemaFields","references","undefined","singleIdQuery","where","some","idField","condition","Array","isArray","value","equals","contains","length","normalizeData","key","isRelatedField","idType","parsed","parseInt","isNaN","original","converted","stringId","String","map","id","transformInput","data","transformedData","Object","entries","forEach","schemaFieldName","normalizedData","targetFieldName","transformOutput","doc","result","relationshipFields","fromEntries","filter","dateFields","_","type","originalRelatedFieldKey","keys","find","k","normalizeDocumentIds","originalDateFieldKey","Date","originalKey","every","item","operatorToPayload","operator","not_equals","greater_than","greater_than_equal","less_than","less_than_equal","in","like","convertWhereValue","numId","Number","convertWhereClause","w","res","and","connector","or","andClause","orClause","AND","OR","convertSelect","select","reduce","acc","convertSort","sortBy","prefix","direction"],"mappings":"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"}
|
|
664
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../src/better-auth/adapter/transform/index.ts"],"sourcesContent":["import { getAuthTables } from 'better-auth/db'\nimport type { ModelKey } from '@/better-auth/generated-types'\nimport type { BetterAuthOptions, Where } from 'better-auth'\nimport type { DBFieldAttribute } from 'better-auth/db'\nimport type { BasePayload, CollectionSlug, Where as PayloadWhere } from 'payload'\nimport {\n  getCollectionByModelKey,\n  getCollectionFieldNameByFieldKeyUntyped,\n  getFieldKeyByCollectionFieldName\n} from '@/better-auth/plugin/helpers/get-collection'\n\nexport const createTransform = (options: BetterAuthOptions, enableDebugLogs: boolean) => {\n  const schema = getAuthTables(options)\n\n  function debugLog(message: any[]) {\n    if (enableDebugLogs) {\n      console.log(`[payload-db-adapter]`, ...message)\n    }\n  }\n\n  /**\n   * Maps a BetterAuth schema model name to its corresponding Payload CMS collection slug.\n   *\n   * This function resolves the appropriate collection slug by:\n   * 1. Looking up the model in the BetterAuth schema to find its configured modelName\n   * 2. Falling back to the original model name if no mapping exists\n   *\n   * Collection slug resolution follows these rules:\n   * - For base collections: The sanitizeBetterAuthOptions function ensures the collection slug\n   *   from plugin options is set as the model name in the schema\n   * - For plugins: The betterAuthPluginSlugs constant is used as the modelName\n   *\n   * @param model - The BetterAuth model name to resolve\n   * @returns The corresponding Payload CMS collection slug\n   *\n   * @example\n   * // If schema['user'].modelName is 'users'\n   * getCollectionSlug('user') // Returns 'users'\n   *\n   * @example\n   * // If model doesn't exist in schema\n   * getCollectionSlug('custom') // Returns 'custom'\n   *\n   * @warning If a collection is overridden using the collectionOverride option\n   * without updating the schema mapping, this function may return incorrect slugs\n   */\n  function getCollectionSlug(model: ModelKey): CollectionSlug {\n    // First try to get the modelName from schema, otherwise fall back to the original model name\n    const collection = schema?.[model]?.modelName || model\n    debugLog(['getCollectionSlug:', { model, resolvedSlug: collection }])\n    return collection as CollectionSlug\n  }\n\n  /**\n   * Maps a BetterAuth schema field to its corresponding Payload CMS field name.\n   *\n   * This function resolves the appropriate field name by:\n   * 1. Preserving 'id' or '_id' fields as-is (special case handling)\n   * 2. Looking up the field in the BetterAuth schema to find its configured fieldName\n   * 3. Falling back to the original field name if no mapping exists\n   *\n   * @param model - The BetterAuth model name containing the field\n   * @param field - The original field name to resolve\n   * @returns The corresponding Payload CMS field name\n   *\n   * @example\n   * // If schema['user'].fields['email'].fieldName is 'emailAddress'\n   * getFieldName('user', 'email') // Returns 'emailAddress'\n   *\n   * @example\n   * // Special case for ID fields\n   * getFieldName('user', 'id') // Always returns 'id'\n   *\n   * @example\n   * // If field doesn't exist in schema or has no fieldName mapping\n   * getFieldName('user', 'custom') // Returns 'custom'\n   *\n   * @warning If a fieldName is overridden in the payload collection config using the collectionOverride option\n   * without updating the schema mapping, this function may return incorrect field names\n   */\n  function getFieldName(model: ModelKey, field: string): string {\n    // Special case: 'id' or '_id' is always preserved as-is\n    if (['id', '_id'].includes(field)) {\n      return field\n    }\n\n    // Look up the field in the schema\n    const fieldDefinition = schema[model]?.fields[field]\n\n    // Use the configured fieldName if available, otherwise fall back to original\n    const fieldName = fieldDefinition?.fieldName || field\n\n    // Log the field resolution for debugging\n    debugLog(['getField: ', { model, originalField: field, fieldName }])\n\n    return fieldName\n  }\n\n  /**\n   * Determines if a field is a relationship field by checking for a references property.\n   *\n   * Relationship fields in the schema have a 'references' property that points to another model.\n   * This function checks if this property exists to identify relationship fields.\n   *\n   * @param fieldKey - The key of the field to check in the schema\n   * @param schemaFields - Object containing all fields from the schema for a specific model\n   * @returns True if the field is a relationship field (has references), false otherwise\n   *\n   * @example\n   * // If schema.user.fields.posts has { references: {} }\n   * isRelationshipField('posts', schema.user.fields) // Returns true\n   *\n   * @example\n   * // If schema.user.fields.email has no references property\n   * isRelationshipField('email', schema.user.fields) // Returns false\n   */\n  function isRelationshipField(fieldKey: string, schemaFields: Record<string, DBFieldAttribute>): boolean {\n    // A field is a relationship field if it has a 'references' property defined\n    return schemaFields[fieldKey]?.references !== undefined\n  }\n  /**\n   * Extracts a single ID value from a Payload where clause if it represents a simple ID query.\n   *\n   * This function analyzes a Payload where clause to determine if it's a simple query for a\n   * single document by ID. It supports both 'id' and '_id' fields with 'equals' or 'contains'\n   * operators. This is useful for optimizing queries when we only need to fetch a single document.\n   *\n   * @param where - The Payload where clause to analyze\n   * @returns The ID value (string or number) if the where clause is a simple ID query, null otherwise\n   *\n   * @example\n   * // Returns '123' for a simple equals query\n   * singleIdQuery({ id: { equals: '123' } }) // '123'\n   *\n   * @example\n   * // Returns 456 for a simple equals query with number ID\n   * singleIdQuery({ _id: { equals: 456 } }) // 456\n   *\n   * @example\n   * // Returns '789' for a contains query with a single value\n   * singleIdQuery({ id: { contains: ['789'] } }) // '789'\n   *\n   * @example\n   * // Returns null for complex queries\n   * singleIdQuery({ and: [{ id: { equals: '123' } }] }) // null\n   */\n  function singleIdQuery(where: PayloadWhere) {\n    // Return null for empty where clauses or complex queries with 'and'/'or' operators\n    if (!where || 'and' in where || 'or' in where) return null\n\n    // Check if the where clause contains either 'id' or '_id' field\n    if (['id', '_id'].some((field) => field in where)) {\n      // Determine which ID field is being used (support both 'id' and '_id')\n      const idField = 'id' in where ? 'id' : '_id'\n      const condition = where[idField]\n\n      // Process the equals operator case\n      if (condition && typeof condition === 'object' && !Array.isArray(condition) && 'equals' in condition) {\n        const value = condition.equals\n        // Only return string or number ID values\n        if (typeof value === 'string' || typeof value === 'number') {\n          return value\n        }\n      }\n\n      // Process the contains operator case with a single value\n      if (\n        condition &&\n        typeof condition === 'object' &&\n        !Array.isArray(condition) &&\n        'contains' in condition &&\n        Array.isArray(condition.contains) &&\n        condition.contains.length === 1\n      ) {\n        const value = condition.contains[0]\n        // Only return string or number ID values\n        if (typeof value === 'string' || typeof value === 'number') {\n          return value\n        }\n      }\n    }\n\n    // Return null if no valid ID query was found\n    return null\n  }\n\n  /**\n   * Normalizes data values based on field type and required ID type\n   *\n   * This function handles type conversion for relationship fields to ensure\n   * IDs are in the correct format (string or number) based on the configuration.\n   *\n   * @param key - The field key/name\n   * @param value - The value to normalize\n   * @param isRelatedField - Whether this field is a relationship field\n   * @param idType - The expected ID type ('number' or 'text')\n   * @returns The normalized value\n   */\n  function normalizeData({\n    key,\n    value,\n    isRelatedField,\n    idType\n  }: {\n    key: string\n    value: any\n    isRelatedField: boolean\n    idType: 'number' | 'text'\n  }) {\n    // Skip processing for null/undefined values\n    if (value === null || value === undefined) {\n      return value\n    }\n\n    if (['id', '_id'].includes(key)) {\n      if (typeof value === 'string' && idType === 'number') {\n        const parsed = parseInt(value, 10)\n        if (!isNaN(parsed)) {\n          debugLog([`ID conversion: ${key} converting string ID to number`, { original: value, converted: parsed }])\n          return parsed\n        }\n      }\n      if (typeof value === 'number' && idType === 'text') {\n        const stringId = String(value)\n        debugLog([`ID conversion: ${key} converting number ID to string`, { original: value, converted: stringId }])\n        return stringId\n      }\n    }\n\n    // Only process relationship fields that need type conversion\n    if (isRelatedField) {\n      // Handle single ID value conversion\n      if (typeof value === 'string' && idType === 'number') {\n        const parsed = parseInt(value, 10)\n        if (!isNaN(parsed)) {\n          debugLog([`ID conversion: ${key} converting string ID to number`, { original: value, converted: parsed }])\n          return parsed\n        }\n      } else if (typeof value === 'number' && idType === 'text') {\n        const stringId = String(value)\n        debugLog([`ID conversion: ${key} converting number ID to string`, { original: value, converted: stringId }])\n        return stringId\n      }\n\n      // Handle array of IDs - map each value to the correct type\n      if (Array.isArray(value)) {\n        return value.map((id) => {\n          // Skip null/undefined values in arrays\n          if (id === null || id === undefined) return id\n\n          if (idType === 'number' && typeof id === 'string') {\n            const parsed = parseInt(id, 10)\n            return !isNaN(parsed) ? parsed : id\n          } else if (idType === 'text' && typeof id === 'number') {\n            return String(id)\n          }\n          return id\n        })\n      }\n    }\n\n    // Handle role fields (Coming from better auth, will be a single string seperated by commas if theres multiple roles)\n    if (key === 'role' || key === 'roles') {\n      return value.split(',').map((role: string) => role.trim().toLowerCase())\n    }\n\n    // Return original value if no conversion was needed or applicable\n    return value\n  }\n\n  /**\n   * Transforms input data from better-auth to Payload CMS format\n   *\n   * This function handles:\n   * 1. Field name mapping according to schema definitions\n   * 2. ID type conversion for relationship fields\n   * 3. Proper data normalization based on field types\n   *\n   * @param data - The input data from better-auth\n   * @param model - The model name in the schema\n   * @param idType - The expected ID type ('number' or 'text')\n   * @returns Transformed data compatible with Payload CMS\n   */\n  function transformInput({\n    data,\n    model,\n    idType,\n    payload\n  }: {\n    data: Record<string, any>\n    model: ModelKey\n    idType: 'number' | 'text'\n    payload: BasePayload\n  }): Record<string, any> {\n    const transformedData: Record<string, any> = {}\n    const schemaFields = schema?.[model]?.fields ?? {}\n\n    // Process each field in the input data\n    Object.entries(data).forEach(([key, value]) => {\n      // Skip null/undefined values\n      if (value === null || value === undefined) {\n        return\n      }\n\n      // Determine if this is a relationship field\n      const isRelatedField = isRelationshipField(key, schemaFields)\n\n      // Get the mapped field name from schema (if any)\n      const schemaFieldName = schemaFields[key]?.fieldName\n\n      // Normalize the data value based on field type and ID type\n      const normalizedData = normalizeData({\n        idType,\n        key,\n        value,\n        isRelatedField\n      })\n\n      // Use the schema-defined field name if available, otherwise use original key\n      const targetFieldName = schemaFieldName || key\n      const targetFieldKey = getCollectionFieldNameByFieldKeyUntyped(getCollectionByModelKey(payload.collections, model), targetFieldName)\n      transformedData[targetFieldKey] = normalizedData\n    })\n\n    return transformedData\n  }\n\n  /**\n   * Transforms Payload CMS document output to match BetterAuth schema expectations.\n   *\n   * This function handles several critical transformations:\n   *\n   * 1. ID Conversion: Ensures all ID fields are strings as required by BetterAuth\n   *    (see: https://github.com/better-auth/better-auth/blob/main/packages/better-auth/src/db/schema.ts#L125)\n   *\n   * 2. Relationship Field Mapping: Aligns relationship fields with BetterAuth schema naming conventions\n   *    and ensures proper ID type handling\n   *\n   * 3. Date Conversion: Transforms date strings from Payload into Date objects for BetterAuth\n   *\n   * Note: While setting depth: 1 in Payload operations simplifies this process by avoiding\n   * deeply nested objects, we maintain comprehensive checks for robustness.\n   *\n   * @param doc - The document returned from Payload CMS\n   * @param model - The model name in the BetterAuth schema\n   * @returns The transformed document compatible with BetterAuth\n   */\n  function transformOutput<T extends Record<string, any> | null>({\n    doc,\n    model,\n    payload\n  }: {\n    doc: T\n    model: ModelKey\n    payload: BasePayload\n  }): T {\n    if (!doc || typeof doc !== 'object') return doc\n\n    const result = { ...doc }\n    const schemaFields = schema?.[model]?.fields ?? {}\n\n    // Identify relationship fields with custom field name mappings\n    const relationshipFields = Object.fromEntries(Object.entries(schemaFields).filter(([key]) => isRelationshipField(key, schemaFields)))\n    const dateFields = Object.fromEntries(Object.entries(schemaFields).filter(([_, value]) => value.type === 'date'))\n\n    // First make sure all the fields keys are correct\n    Object.keys(result).forEach((key) => {\n      const targetFieldKey = getFieldKeyByCollectionFieldName(getCollectionByModelKey(payload.collections, model), key)\n      if (targetFieldKey !== key) {\n        result[targetFieldKey] = result[key]\n        delete result[key]\n      }\n    })\n\n    Object.entries(doc).forEach(([key, value]) => {\n      if (value === null || value === undefined) return\n\n      // Convert ID fields to strings for BetterAuth compatibility\n      if (['id', '_id'].includes(key)) {\n        result[key] = String(value)\n        return\n      }\n\n      // Handle relationship fields with renamed fieldNames\n      const originalRelatedFieldKey = Object.keys(relationshipFields).find((k) => relationshipFields[k].fieldName === key)\n      if (originalRelatedFieldKey) {\n        normalizeDocumentIds(result, originalRelatedFieldKey, key, value)\n        return\n      }\n\n      const originalDateFieldKey = Object.keys(dateFields).find((k) => dateFields[k].fieldName === key)\n      if (originalDateFieldKey) {\n        // Convert ISO date strings to Date objects for BetterAuth\n        result[key] = new Date(value)\n        return\n      }\n    })\n\n    return result as T\n  }\n\n  /**\n   * Normalizes ID fields for both primary and relationship documents.\n   *\n   * This function ensures consistent ID handling between BetterAuth and Payload CMS by:\n   * 1. Converting all IDs to strings for BetterAuth (stored in originalKey)\n   * 2. Preserving original ID types for Payload CMS (stored in fieldName)\n   *\n   * The function handles various ID formats:\n   * - Primitive values (string/number IDs)\n   * - Object references with ID properties\n   * - Arrays of either primitive IDs or object references\n   *\n   * @param result - The result object being transformed\n   * @param originalKey - The original field key from BetterAuth schema\n   * @param fieldName - The renamed field as used in Payload CMS\n   * @param value - The ID value to normalize (primitive, object, or array)\n   */\n  function normalizeDocumentIds(result: Record<string, any>, originalKey: string, fieldName: string, value: any): void {\n    // Case 1: Primitive ID value (string or number)\n    if (typeof value === 'string' || typeof value === 'number') {\n      // For BetterAuth: Always use string IDs\n      result[originalKey] = String(value)\n      // For Payload: Keep original type\n      result[fieldName] = value\n      return\n    }\n\n    // Case 2: Object with ID property\n    if (typeof value === 'object' && value !== null && 'id' in value) {\n      // For BetterAuth: Extract and stringify the ID\n      result[originalKey] = String(value.id)\n      // For Payload: Extract ID but preserve type\n      result[fieldName] = value.id\n      return\n    }\n\n    // Case 3: Array of IDs or references\n    if (Array.isArray(value) && value.length > 0) {\n      // Check if array contains objects with ID properties\n      if (value.every((item) => typeof item === 'object' && item !== null && 'id' in item)) {\n        // Array of objects with IDs\n        result[originalKey] = value.map((item) => String(item.id))\n        result[fieldName] = value.map((item) => item.id)\n      } else {\n        // Array of primitive IDs\n        result[originalKey] = value.map((item) => String(item))\n        result[fieldName] = value.map((item) => item)\n      }\n      return\n    }\n\n    // Note: If value doesn't match any expected format, no changes are made\n  }\n\n  /**\n   * Converts a BetterAuth operator to the equivalent Payload CMS query operator\n   *\n   * This function maps standard query operators from BetterAuth's format to\n   * the specific format expected by Payload CMS's query engine.\n   *\n   * @param operator - The BetterAuth operator string (e.g., 'eq', 'gt', 'contains')\n   * @param value - The value to be used with the operator\n   * @returns An object with the Payload-compatible operator and value\n   *\n   * @example\n   * // Returns { equals: 'test@example.com' }\n   * operatorToPayload('eq', 'test@example.com')\n   *\n   * @example\n   * // Returns { greater_than: 100 }\n   * operatorToPayload('gt', 100)\n   */\n  function operatorToPayload(operator: string, value: any): Record<string, any> {\n    switch (operator) {\n      case 'eq':\n        return { equals: value }\n      case 'ne':\n        return { not_equals: value }\n      case 'gt':\n        return { greater_than: value }\n      case 'gte':\n        return { greater_than_equal: value }\n      case 'lt':\n        return { less_than: value }\n      case 'lte':\n        return { less_than_equal: value }\n      case 'contains':\n        return { contains: value }\n      case 'in':\n        return { in: value }\n      case 'starts_with':\n        return { like: `${value}%` }\n      case 'ends_with':\n        return { like: `%${value}` }\n      default:\n        // Fall back to equals for unrecognized operators\n        return { equals: value }\n    }\n  }\n\n  /**\n   * Converts a where clause value to the appropriate type based on field name and ID type configuration\n   *\n   * This function handles two main scenarios:\n   * 1. ID field conversion - ensures IDs match the database's expected type (number or string)\n   * 2. Object with embedded ID - extracts and converts the ID property from objects\n   *\n   * @param value - The value to convert (can be primitive, object with ID, or array)\n   * @param fieldName - The name of the field being queried\n   * @param idType - The expected ID type in the database\n   * @returns The converted value appropriate for the database query\n   */\n  function convertWhereValue({ value, fieldName, idType }: { value: any; fieldName: string; idType: 'number' | 'text' }) {\n    // Check if field is an ID field (supporting both MongoDB-style _id and standard id)\n    if (['id', '_id'].includes(fieldName)) {\n      // Case 1: Value is an object containing an ID property\n      if (typeof value === 'object' && value !== null && 'id' in value) {\n        // Extract ID from object\n        const id = value.id\n\n        // Use type conversion based on database configuration\n        if (idType === 'number' && typeof id === 'string') {\n          const numId = Number(id)\n          return !isNaN(numId) ? numId : id\n        }\n\n        if (idType === 'text' && typeof id === 'number') {\n          return String(id)\n        }\n\n        return id\n      }\n      // Case 2: Value is a standalone ID that needs type conversion\n      // Convert string ID to number if database expects numeric IDs\n      if (idType === 'number' && typeof value === 'string' && !isNaN(Number(value))) {\n        return Number(value)\n      }\n      // Convert numeric ID to string if database expects text IDs\n      else if (idType === 'text' && typeof value === 'number') {\n        return String(value)\n      }\n      return value\n    }\n\n    // For non-ID fields, return the value unchanged\n    return value\n  }\n\n  /**\n   * Converts Better Auth where clauses to Payload CMS compatible where conditions\n   *\n   * This function transforms the Better Auth query format into Payload's query format,\n   * handling field name mapping, value type conversion, and logical operators (AND/OR).\n   *\n   * The function handles three main cases:\n   * 1. Empty or undefined where clause - returns empty object\n   * 2. Single condition - converts to a simple field-value pair\n   * 3. Multiple conditions - groups by AND/OR connectors and builds a complex query\n   *\n   * @param idType - The database ID type ('number' or 'text')\n   * @param model - The model/collection name to query\n   * @param where - Array of Better Auth where conditions\n   * @returns A Payload-compatible where clause object\n   */\n  function convertWhereClause({\n    idType,\n    model,\n    where,\n    payload\n  }: {\n    idType: 'number' | 'text'\n    model: ModelKey\n    where?: Where[]\n    payload: BasePayload\n  }): PayloadWhere {\n    // Handle empty where clause\n    if (!where) return {}\n\n    function getPayloadFieldName(fieldKey: string): string {\n      return getCollectionFieldNameByFieldKeyUntyped(getCollectionByModelKey(payload.collections, model), fieldKey)\n    }\n\n    // Handle single condition case for optimization\n    if (where.length === 1) {\n      const w = where[0]\n      if (!w) {\n        return {}\n      }\n\n      // Map field name according to schema and convert value to appropriate type\n      const fieldName = getFieldName(model, w.field)\n      const value = convertWhereValue({\n        value: w.value,\n        fieldName,\n        idType\n      })\n\n      // Create the Payload where condition with proper operator\n      const res = {\n        [getPayloadFieldName(fieldName)]: operatorToPayload(w.operator ?? '', value)\n      }\n\n      return res\n    }\n\n    // Handle multiple conditions by separating AND/OR clauses\n    // Default to AND if no connector is specified\n    const and = where.filter((w) => w.connector === 'AND' || !w.connector)\n    const or = where.filter((w) => w.connector === 'OR')\n\n    // Process AND conditions\n    const andClause = and.map((w) => {\n      const fieldName = getFieldName(model, w.field)\n      const value = convertWhereValue({\n        value: w.value,\n        fieldName,\n        idType\n      })\n      return {\n        [getPayloadFieldName(fieldName)]: operatorToPayload(w.operator ?? '', value)\n      }\n    })\n\n    // Process OR conditions\n    const orClause = or.map((w) => {\n      const fieldName = getFieldName(model, w.field)\n      const value = convertWhereValue({\n        value: w.value,\n        fieldName,\n        idType\n      })\n      return {\n        [getPayloadFieldName(fieldName)]: operatorToPayload(w.operator ?? '', value)\n      }\n    })\n\n    // Combine AND and OR clauses into final Payload where object\n    // Only include non-empty clause arrays\n    return {\n      ...(andClause.length ? { AND: andClause } : {}),\n      ...(orClause.length ? { OR: orClause } : {})\n    }\n  }\n\n  /**\n   * Converts a better-auth select array to a Payload select object\n   *\n   * This function transforms the better-auth select array (which contains field names)\n   * into the format expected by Payload CMS's query API (an object with field names as keys\n   * and boolean true as values).\n   *\n   * It also handles field name mapping between better-auth schema and Payload collections\n   * by using the getFieldName helper to resolve the correct field names.\n   *\n   * @param model - The model/collection name to get field mappings from\n   * @param select - Optional array of field names to select\n   * @returns A Payload-compatible select object or undefined if no fields to select\n   * @example\n   * // Input: ['email', 'name']\n   * // Output: { email: true, name: true }\n   */\n  function convertSelect(model: ModelKey, select?: string[]) {\n    // Return undefined if select is empty or not provided\n    if (!select || select.length === 0) return undefined\n\n    // Transform the array of field names into a Payload select object\n    // while also mapping any field names that might be different in Payload\n    return select.reduce((acc, field) => ({ ...acc, [getFieldName(model, field)]: true }), {})\n  }\n\n  /**\n   * Converts a better-auth sort object to a Payload sort string\n   *\n   * This function transforms the better-auth sort object (which contains field name and direction)\n   * into the format expected by Payload CMS's query API (a string with optional '-' prefix for descending order).\n   *\n   * It also handles field name mapping between better-auth schema and Payload collections\n   * by using the getFieldName helper to resolve the correct field names.\n   *\n   * @param model - The model/collection name to get field mappings from\n   * @param sortBy - Optional object containing field name and sort direction\n   * @returns A Payload-compatible sort string or undefined if no sort specified\n   * @example\n   * // Input: { field: 'email', direction: 'desc' }\n   * // Output: '-email'\n   * // Input: { field: 'createdAt', direction: 'asc' }\n   * // Output: 'createdAt'\n   */\n  function convertSort(model: ModelKey, sortBy?: { field: string; direction: 'asc' | 'desc' }): string | undefined {\n    if (!sortBy) return undefined\n    const fieldName = getFieldName(model, sortBy.field)\n    const prefix = sortBy.direction === 'desc' ? '-' : ''\n    return `${prefix}${fieldName}`\n  }\n\n  return {\n    getFieldName,\n    getCollectionSlug,\n    singleIdQuery,\n    transformInput,\n    transformOutput,\n    convertWhereClause,\n    convertSelect,\n    convertSort\n  }\n}\n"],"names":["getAuthTables","getCollectionByModelKey","getCollectionFieldNameByFieldKeyUntyped","getFieldKeyByCollectionFieldName","createTransform","options","enableDebugLogs","schema","debugLog","message","console","log","getCollectionSlug","model","collection","modelName","resolvedSlug","getFieldName","field","includes","fieldDefinition","fields","fieldName","originalField","isRelationshipField","fieldKey","schemaFields","references","undefined","singleIdQuery","where","some","idField","condition","Array","isArray","value","equals","contains","length","normalizeData","key","isRelatedField","idType","parsed","parseInt","isNaN","original","converted","stringId","String","map","id","split","role","trim","toLowerCase","transformInput","data","payload","transformedData","Object","entries","forEach","schemaFieldName","normalizedData","targetFieldName","targetFieldKey","collections","transformOutput","doc","result","relationshipFields","fromEntries","filter","dateFields","_","type","keys","originalRelatedFieldKey","find","k","normalizeDocumentIds","originalDateFieldKey","Date","originalKey","every","item","operatorToPayload","operator","not_equals","greater_than","greater_than_equal","less_than","less_than_equal","in","like","convertWhereValue","numId","Number","convertWhereClause","getPayloadFieldName","w","res","and","connector","or","andClause","orClause","AND","OR","convertSelect","select","reduce","acc","convertSort","sortBy","prefix","direction"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-better-auth-schema.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/get-better-auth-schema.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAA;
|
|
1
|
+
{"version":3,"file":"get-better-auth-schema.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/get-better-auth-schema.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAA;AAIrE;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,0BAA0B,CAAC,aAAa,EAAE,uBAAuB,GAAG,iBAAiB,CA4DpG"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { getAuthTables } from "better-auth/db";
|
|
2
|
-
import { baModelFieldKeysToFieldNames } from "../constants";
|
|
2
|
+
import { baModelFieldKeysToFieldNames, baModelKey, defaults } from "../constants";
|
|
3
3
|
import { getDefaultCollectionSlug } from "./get-collection-slug";
|
|
4
|
+
import { set } from "../utils/set";
|
|
4
5
|
/**
|
|
5
6
|
* A consistent BetterAuth schema generator.
|
|
6
7
|
*
|
|
@@ -18,6 +19,12 @@ import { getDefaultCollectionSlug } from "./get-collection-slug";
|
|
|
18
19
|
* @returns A map keyed by static table keys, each value containing `{ modelName, fields, order }`.
|
|
19
20
|
*/ export function getDefaultBetterAuthSchema(pluginOptions) {
|
|
20
21
|
const betterAuthOptions = pluginOptions.betterAuthOptions ?? {};
|
|
22
|
+
// We need to add the additional role field to the user schema here or else the built collections will not pick it up.
|
|
23
|
+
set(betterAuthOptions, `${baModelKey.user}.additionalFields.role`, {
|
|
24
|
+
type: 'string',
|
|
25
|
+
defaultValue: pluginOptions.users?.defaultRole || defaults.userRole,
|
|
26
|
+
input: false
|
|
27
|
+
});
|
|
21
28
|
const tables = getAuthTables(betterAuthOptions);
|
|
22
29
|
const schema = {};
|
|
23
30
|
for (const modelKey of Object.keys(tables)){
|
|
@@ -65,4 +72,4 @@ import { getDefaultCollectionSlug } from "./get-collection-slug";
|
|
|
65
72
|
return schema;
|
|
66
73
|
}
|
|
67
74
|
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9nZXQtYmV0dGVyLWF1dGgtc2NoZW1hLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZGVsS2V5IH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9nZW5lcmF0ZWQtdHlwZXMnXG5pbXBvcnQgeyB0eXBlIERCRmllbGRBdHRyaWJ1dGUsIGdldEF1dGhUYWJsZXMgfSBmcm9tICdiZXR0ZXItYXV0aC9kYidcbmltcG9ydCB7IGJhTW9kZWxGaWVsZEtleXNUb0ZpZWxkTmFtZXMsIGJhTW9kZWxLZXksIGRlZmF1bHRzIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHsgQmV0dGVyQXV0aFBsdWdpbk9wdGlvbnMsIEJldHRlckF1dGhTY2hlbWFzIH0gZnJvbSAnLi4vdHlwZXMnXG5pbXBvcnQgeyBnZXREZWZhdWx0Q29sbGVjdGlvblNsdWcgfSBmcm9tICcuL2dldC1jb2xsZWN0aW9uLXNsdWcnXG5pbXBvcnQgeyBzZXQgfSBmcm9tICcuLi91dGlscy9zZXQnXG5cbi8qKlxuICogQSBjb25zaXN0ZW50IEJldHRlckF1dGggc2NoZW1hIGdlbmVyYXRvci5cbiAqXG4gKiBEaWZmZXJlbmNlcyBmcm9tIHRoZSBvcmlnaW5hbCBgZ2V0U2NoZW1hYCBpbXBsZW1lbnRhdGlvbiBpbiBCZXR0ZXJBdXRoOlxuICogMS4gS2V5cyBpbiB0aGUgcmV0dXJuZWQgb2JqZWN0IGFyZSBhbHdheXMgdGhlICoqc3RhdGljIHRhYmxlIGlkZW50aWZpZXJzKiogY29taW5nIGZyb21cbiAqICAgIGBnZXRBdXRoVGFibGVzYCwgbmV2ZXIgdGhlIHBvc3NpYmx5LW92ZXJyaWRkZW4gYG1vZGVsTmFtZWAuICBUaGlzIGd1YXJhbnRlZXMgdGhhdFxuICogICAgc3Vic2VxdWVudCBsb29rLXVwcyByZW1haW4gc3RhYmxlIGV2ZW4gaWYgdGhlIHVzZXIgcmVuYW1lcyBjb2xsZWN0aW9ucy5cbiAqIDIuIEVhY2ggc2NoZW1hIGVudHJ5IG5vdyBjb250YWlucyBhbiBleHBsaWNpdCBgbW9kZWxOYW1lYCBwcm9wZXJ0eSBleHBvc2luZyB0aGUgY3VycmVudFxuICogICAgKHBvdGVudGlhbGx5IHVzZXItb3ZlcnJpZGRlbikgbW9kZWwgbmFtZSwgd2hpbGUgYGZpZWxkc2AgY29udGludWUgdG8gYmUgcmVmZXJlbmNlZCBieVxuICogICAgdGhlaXIgc3RhdGljIEJldHRlckF1dGggZmllbGQga2V5cy5cbiAqIDMuIFdoZW4gY29udmVydGluZyBmaWVsZHMsIHdlIHN0b3JlIHRoZW0gdW5kZXIgdGhlaXIgb3JpZ2luYWwga2V5IChgYWN0dWFsRmllbGRzW2tleV0gPSBmaWVsZGApXG4gKiAgICBpbnN0ZWFkIG9mIGBmaWVsZC5maWVsZE5hbWUgfHwga2V5YCB0byBhdm9pZCBhY2NpZGVudGFsIHJlbmFtZXMuXG4gKlxuICogQHBhcmFtIGNvbmZpZyAtIFRoZSBCZXR0ZXJBdXRoIG9wdGlvbnMgZmVkIGludG8gYGdldEF1dGhUYWJsZXNgLlxuICogQHJldHVybnMgQSBtYXAga2V5ZWQgYnkgc3RhdGljIHRhYmxlIGtleXMsIGVhY2ggdmFsdWUgY29udGFpbmluZyBgeyBtb2RlbE5hbWUsIGZpZWxkcywgb3JkZXIgfWAuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXREZWZhdWx0QmV0dGVyQXV0aFNjaGVtYShwbHVnaW5PcHRpb25zOiBCZXR0ZXJBdXRoUGx1Z2luT3B0aW9ucyk6IEJldHRlckF1dGhTY2hlbWFzIHtcbiAgY29uc3QgYmV0dGVyQXV0aE9wdGlvbnMgPSBwbHVnaW5PcHRpb25zLmJldHRlckF1dGhPcHRpb25zID8/IHt9XG5cbiAgLy8gV2UgbmVlZCB0byBhZGQgdGhlIGFkZGl0aW9uYWwgcm9sZSBmaWVsZCB0byB0aGUgdXNlciBzY2hlbWEgaGVyZSBvciBlbHNlIHRoZSBidWlsdCBjb2xsZWN0aW9ucyB3aWxsIG5vdCBwaWNrIGl0IHVwLlxuICBzZXQoYmV0dGVyQXV0aE9wdGlvbnMgYXMgYW55LCBgJHtiYU1vZGVsS2V5LnVzZXJ9LmFkZGl0aW9uYWxGaWVsZHMucm9sZWAsIHtcbiAgICB0eXBlOiAnc3RyaW5nJyxcbiAgICBkZWZhdWx0VmFsdWU6IHBsdWdpbk9wdGlvbnMudXNlcnM/LmRlZmF1bHRSb2xlIHx8IGRlZmF1bHRzLnVzZXJSb2xlLFxuICAgIGlucHV0OiBmYWxzZSxcbiAgfSlcblxuICBjb25zdCB0YWJsZXMgPSBnZXRBdXRoVGFibGVzKGJldHRlckF1dGhPcHRpb25zKVxuXG4gIGNvbnN0IHNjaGVtYTogUGFydGlhbDxCZXR0ZXJBdXRoU2NoZW1hcz4gPSB7fVxuXG4gIGZvciAoY29uc3QgbW9kZWxLZXkgb2YgT2JqZWN0LmtleXModGFibGVzKSBhcyBNb2RlbEtleVtdKSB7XG4gICAgY29uc3QgdGFibGUgPSB0YWJsZXNbbW9kZWxLZXldXG5cbiAgICAvLyBSZXNvbHZlIHRoZSBjYW5vbmljYWwgY29sbGVjdGlvbiBzbHVnIC8gbW9kZWwgbmFtZSBmb3IgdGhpcyBrZXlcbiAgICBjb25zdCByZXNvbHZlZE1vZGVsTmFtZSA9IGdldERlZmF1bHRDb2xsZWN0aW9uU2x1Zyh7IG1vZGVsS2V5LCBwbHVnaW5PcHRpb25zIH0pXG5cbiAgICBjb25zdCBkZWZhdWx0RmllbGRNYXAgPSAoYmFNb2RlbEZpZWxkS2V5c1RvRmllbGROYW1lcyBhcyBSZWNvcmQ8c3RyaW5nLCBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+PilbbW9kZWxLZXldID8/IHt9XG5cbiAgICBjb25zdCBhY3R1YWxGaWVsZHM6IFJlY29yZDxzdHJpbmcsIERCRmllbGRBdHRyaWJ1dGU+ID0ge31cblxuICAgIE9iamVjdC5lbnRyaWVzKHRhYmxlLmZpZWxkcykuZm9yRWFjaCgoW2ZpZWxkS2V5LCBmaWVsZFZhbHVlXSkgPT4ge1xuICAgICAgLy8gQnVpbGQgdGhlIGZpZWxkIGVuc3VyaW5nIGEgZmllbGROYW1lIGV4aXN0c1xuICAgICAgY29uc3QgbmV3RmllbGQ6IERCRmllbGRBdHRyaWJ1dGUgPSB7XG4gICAgICAgIC4uLmZpZWxkVmFsdWUsXG4gICAgICAgIGZpZWxkTmFtZTogZGVmYXVsdEZpZWxkTWFwW2ZpZWxkS2V5XSA/PyBmaWVsZEtleVxuICAgICAgfVxuXG4gICAgICAvLyBSZXdyaXRlIHJlZmVyZW5jZXMgdG8gdXNlIHRoZSByZXNvbHZlZCBtb2RlbE5hbWUgZm9yIHRoZSB0YXJnZXQgdGFibGVcbiAgICAgIGlmIChmaWVsZFZhbHVlLnJlZmVyZW5jZXMpIHtcbiAgICAgICAgY29uc3QgcmVmTW9kZWxLZXkgPSBmaWVsZFZhbHVlLnJlZmVyZW5jZXMubW9kZWwgYXMgc3RyaW5nXG4gICAgICAgIGNvbnN0IHJlc29sdmVkUmVmTW9kZWxOYW1lID0gZ2V0RGVmYXVsdENvbGxlY3Rpb25TbHVnKHsgbW9kZWxLZXk6IHJlZk1vZGVsS2V5LCBwbHVnaW5PcHRpb25zIH0pXG4gICAgICAgIG5ld0ZpZWxkLnJlZmVyZW5jZXMgPSB7XG4gICAgICAgICAgbW9kZWw6IHJlc29sdmVkUmVmTW9kZWxOYW1lLFxuICAgICAgICAgIGZpZWxkOiBmaWVsZFZhbHVlLnJlZmVyZW5jZXMuZmllbGRcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBhY3R1YWxGaWVsZHNbZmllbGRLZXldID0gbmV3RmllbGRcbiAgICB9KVxuXG4gICAgaWYgKHNjaGVtYVttb2RlbEtleV0pIHtcbiAgICAgIHNjaGVtYVttb2RlbEtleV0uZmllbGRzID0ge1xuICAgICAgICAuLi5zY2hlbWFbbW9kZWxLZXldLmZpZWxkcyxcbiAgICAgICAgLi4uYWN0dWFsRmllbGRzXG4gICAgICB9XG4gICAgICBjb250aW51ZVxuICAgIH1cblxuICAgIHNjaGVtYVttb2RlbEtleV0gPSB7XG4gICAgICBtb2RlbE5hbWU6IHJlc29sdmVkTW9kZWxOYW1lLFxuICAgICAgZmllbGRzOiBhY3R1YWxGaWVsZHMsXG4gICAgICBvcmRlcjogdGFibGUub3JkZXIgfHwgSW5maW5pdHlcbiAgICB9XG4gIH1cblxuICByZXR1cm4gc2NoZW1hIGFzIEJldHRlckF1dGhTY2hlbWFzXG59XG4iXSwibmFtZXMiOlsiZ2V0QXV0aFRhYmxlcyIsImJhTW9kZWxGaWVsZEtleXNUb0ZpZWxkTmFtZXMiLCJiYU1vZGVsS2V5IiwiZGVmYXVsdHMiLCJnZXREZWZhdWx0Q29sbGVjdGlvblNsdWciLCJzZXQiLCJnZXREZWZhdWx0QmV0dGVyQXV0aFNjaGVtYSIsInBsdWdpbk9wdGlvbnMiLCJiZXR0ZXJBdXRoT3B0aW9ucyIsInVzZXIiLCJ0eXBlIiwiZGVmYXVsdFZhbHVlIiwidXNlcnMiLCJkZWZhdWx0Um9sZSIsInVzZXJSb2xlIiwiaW5wdXQiLCJ0YWJsZXMiLCJzY2hlbWEiLCJtb2RlbEtleSIsIk9iamVjdCIsImtleXMiLCJ0YWJsZSIsInJlc29sdmVkTW9kZWxOYW1lIiwiZGVmYXVsdEZpZWxkTWFwIiwiYWN0dWFsRmllbGRzIiwiZW50cmllcyIsImZpZWxkcyIsImZvckVhY2giLCJmaWVsZEtleSIsImZpZWxkVmFsdWUiLCJuZXdGaWVsZCIsImZpZWxkTmFtZSIsInJlZmVyZW5jZXMiLCJyZWZNb2RlbEtleSIsIm1vZGVsIiwicmVzb2x2ZWRSZWZNb2RlbE5hbWUiLCJmaWVsZCIsIm1vZGVsTmFtZSIsIm9yZGVyIiwiSW5maW5pdHkiXSwibWFwcGluZ3MiOiJBQUNBLFNBQWdDQSxhQUFhLFFBQVEsaUJBQWdCO0FBQ3JFLFNBQVNDLDRCQUE0QixFQUFFQyxVQUFVLEVBQUVDLFFBQVEsUUFBUSxlQUFjO0FBRWpGLFNBQVNDLHdCQUF3QixRQUFRLHdCQUF1QjtBQUNoRSxTQUFTQyxHQUFHLFFBQVEsZUFBYztBQUVsQzs7Ozs7Ozs7Ozs7Ozs7O0NBZUMsR0FDRCxPQUFPLFNBQVNDLDJCQUEyQkMsYUFBc0M7SUFDL0UsTUFBTUMsb0JBQW9CRCxjQUFjQyxpQkFBaUIsSUFBSSxDQUFDO0lBRTlELHNIQUFzSDtJQUN0SEgsSUFBSUcsbUJBQTBCLEdBQUdOLFdBQVdPLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxFQUFFO1FBQ3hFQyxNQUFNO1FBQ05DLGNBQWNKLGNBQWNLLEtBQUssRUFBRUMsZUFBZVYsU0FBU1csUUFBUTtRQUNuRUMsT0FBTztJQUNUO0lBRUEsTUFBTUMsU0FBU2hCLGNBQWNRO0lBRTdCLE1BQU1TLFNBQXFDLENBQUM7SUFFNUMsS0FBSyxNQUFNQyxZQUFZQyxPQUFPQyxJQUFJLENBQUNKLFFBQXVCO1FBQ3hELE1BQU1LLFFBQVFMLE1BQU0sQ0FBQ0UsU0FBUztRQUU5QixrRUFBa0U7UUFDbEUsTUFBTUksb0JBQW9CbEIseUJBQXlCO1lBQUVjO1lBQVVYO1FBQWM7UUFFN0UsTUFBTWdCLGtCQUFrQixBQUFDdEIsNEJBQXVFLENBQUNpQixTQUFTLElBQUksQ0FBQztRQUUvRyxNQUFNTSxlQUFpRCxDQUFDO1FBRXhETCxPQUFPTSxPQUFPLENBQUNKLE1BQU1LLE1BQU0sRUFBRUMsT0FBTyxDQUFDLENBQUMsQ0FBQ0MsVUFBVUMsV0FBVztZQUMxRCw4Q0FBOEM7WUFDOUMsTUFBTUMsV0FBNkI7Z0JBQ2pDLEdBQUdELFVBQVU7Z0JBQ2JFLFdBQVdSLGVBQWUsQ0FBQ0ssU0FBUyxJQUFJQTtZQUMxQztZQUVBLHdFQUF3RTtZQUN4RSxJQUFJQyxXQUFXRyxVQUFVLEVBQUU7Z0JBQ3pCLE1BQU1DLGNBQWNKLFdBQVdHLFVBQVUsQ0FBQ0UsS0FBSztnQkFDL0MsTUFBTUMsdUJBQXVCL0IseUJBQXlCO29CQUFFYyxVQUFVZTtvQkFBYTFCO2dCQUFjO2dCQUM3RnVCLFNBQVNFLFVBQVUsR0FBRztvQkFDcEJFLE9BQU9DO29CQUNQQyxPQUFPUCxXQUFXRyxVQUFVLENBQUNJLEtBQUs7Z0JBQ3BDO1lBQ0Y7WUFFQVosWUFBWSxDQUFDSSxTQUFTLEdBQUdFO1FBQzNCO1FBRUEsSUFBSWIsTUFBTSxDQUFDQyxTQUFTLEVBQUU7WUFDcEJELE1BQU0sQ0FBQ0MsU0FBUyxDQUFDUSxNQUFNLEdBQUc7Z0JBQ3hCLEdBQUdULE1BQU0sQ0FBQ0MsU0FBUyxDQUFDUSxNQUFNO2dCQUMxQixHQUFHRixZQUFZO1lBQ2pCO1lBQ0E7UUFDRjtRQUVBUCxNQUFNLENBQUNDLFNBQVMsR0FBRztZQUNqQm1CLFdBQVdmO1lBQ1hJLFFBQVFGO1lBQ1JjLE9BQU9qQixNQUFNaUIsS0FBSyxJQUFJQztRQUN4QjtJQUNGO0lBRUEsT0FBT3RCO0FBQ1QifQ==
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { BetterAuthFullSchema, ModelKey } from '@/better-auth/generated-types';
|
|
2
2
|
import { type Collection, type CollectionConfig } from 'payload';
|
|
3
|
-
export declare function getCollectionByModelKey(collections: Record<string, Collection>, modelKey: ModelKey): CollectionConfig;
|
|
3
|
+
export declare function getCollectionByModelKey(collections: Record<string, Collection>, modelKey: ModelKey | string): CollectionConfig;
|
|
4
4
|
/**
|
|
5
5
|
* Retrieves the field name from a collection based on the field key
|
|
6
6
|
*
|
|
@@ -13,4 +13,16 @@ export declare function getCollectionByModelKey(collections: Record<string, Coll
|
|
|
13
13
|
* @returns The name of the field if found, otherwise the field key itself
|
|
14
14
|
*/
|
|
15
15
|
export declare function getCollectionFieldNameByFieldKey<M extends ModelKey>(collection: CollectionConfig, model: M, fieldKey: Extract<keyof BetterAuthFullSchema[M], string>): string;
|
|
16
|
+
export declare function getCollectionFieldNameByFieldKeyUntyped(collection: CollectionConfig, fieldKey: string): string;
|
|
17
|
+
/**
|
|
18
|
+
* Retrieves the field key from a collection based on the collection field name
|
|
19
|
+
*
|
|
20
|
+
* This function searches through the fields of a collection to find a field
|
|
21
|
+
* that has a matching name.
|
|
22
|
+
*
|
|
23
|
+
* @param collection - The collection configuration to search through
|
|
24
|
+
* @param fieldName - The name of the field to search for
|
|
25
|
+
* @returns The key of the field if found, otherwise the field name itself
|
|
26
|
+
*/
|
|
27
|
+
export declare function getFieldKeyByCollectionFieldName(collection: CollectionConfig, fieldName: string): string;
|
|
16
28
|
//# sourceMappingURL=get-collection.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-collection.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/get-collection.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,QAAQ,EAAE,MAAM,+BAA+B,CAAA;AACnF,OAAO,EAAoB,KAAK,UAAU,EAAE,KAAK,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAElF,wBAAgB,uBAAuB,CAAC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,QAAQ,EAAE,QAAQ,GAAG,gBAAgB,
|
|
1
|
+
{"version":3,"file":"get-collection.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/get-collection.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,QAAQ,EAAE,MAAM,+BAA+B,CAAA;AACnF,OAAO,EAAoB,KAAK,UAAU,EAAE,KAAK,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAElF,wBAAgB,uBAAuB,CAAC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,QAAQ,EAAE,QAAQ,GAAG,MAAM,GAAG,gBAAgB,CAU9H;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,gCAAgC,CAAC,CAAC,SAAS,QAAQ,EACjE,UAAU,EAAE,gBAAgB,EAC5B,KAAK,EAAE,CAAC,EACR,QAAQ,EAAE,OAAO,CAAC,MAAM,oBAAoB,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,GACvD,MAAM,CAGR;AAED,wBAAgB,uCAAuC,CAAC,UAAU,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,CAG9G;AAED;;;;;;;;;GASG;AACH,wBAAgB,gCAAgC,CAAC,UAAU,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM,CAGxG"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { flattenAllFields } from "payload";
|
|
2
2
|
export function getCollectionByModelKey(collections, modelKey) {
|
|
3
3
|
const collection = Object.values(collections).find((c)=>{
|
|
4
|
-
return c.config?.custom?.betterAuthModelKey === modelKey;
|
|
4
|
+
return c.config?.custom?.betterAuthModelKey === modelKey || c.config?.slug === modelKey;
|
|
5
5
|
});
|
|
6
6
|
if (!collection) {
|
|
7
7
|
throw new Error(`Collection with key ${modelKey} not found`);
|
|
@@ -24,5 +24,26 @@ export function getCollectionByModelKey(collections, modelKey) {
|
|
|
24
24
|
});
|
|
25
25
|
return fields.find((f)=>f.custom?.betterAuthFieldKey === fieldKey)?.name ?? fieldKey;
|
|
26
26
|
}
|
|
27
|
+
export function getCollectionFieldNameByFieldKeyUntyped(collection, fieldKey) {
|
|
28
|
+
const fields = flattenAllFields({
|
|
29
|
+
fields: collection.fields
|
|
30
|
+
});
|
|
31
|
+
return fields.find((f)=>f.custom?.betterAuthFieldKey === fieldKey || f.name === fieldKey)?.name ?? fieldKey;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Retrieves the field key from a collection based on the collection field name
|
|
35
|
+
*
|
|
36
|
+
* This function searches through the fields of a collection to find a field
|
|
37
|
+
* that has a matching name.
|
|
38
|
+
*
|
|
39
|
+
* @param collection - The collection configuration to search through
|
|
40
|
+
* @param fieldName - The name of the field to search for
|
|
41
|
+
* @returns The key of the field if found, otherwise the field name itself
|
|
42
|
+
*/ export function getFieldKeyByCollectionFieldName(collection, fieldName) {
|
|
43
|
+
const fields = flattenAllFields({
|
|
44
|
+
fields: collection.fields
|
|
45
|
+
});
|
|
46
|
+
return fields.find((f)=>f.name === fieldName)?.custom?.betterAuthFieldKey ?? fieldName;
|
|
47
|
+
}
|
|
27
48
|
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9nZXQtY29sbGVjdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEJldHRlckF1dGhGdWxsU2NoZW1hLCBNb2RlbEtleSB9IGZyb20gJ0AvYmV0dGVyLWF1dGgvZ2VuZXJhdGVkLXR5cGVzJ1xuaW1wb3J0IHsgZmxhdHRlbkFsbEZpZWxkcywgdHlwZSBDb2xsZWN0aW9uLCB0eXBlIENvbGxlY3Rpb25Db25maWcgfSBmcm9tICdwYXlsb2FkJ1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Q29sbGVjdGlvbkJ5TW9kZWxLZXkoY29sbGVjdGlvbnM6IFJlY29yZDxzdHJpbmcsIENvbGxlY3Rpb24+
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9nZXQtY29sbGVjdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEJldHRlckF1dGhGdWxsU2NoZW1hLCBNb2RlbEtleSB9IGZyb20gJ0AvYmV0dGVyLWF1dGgvZ2VuZXJhdGVkLXR5cGVzJ1xuaW1wb3J0IHsgZmxhdHRlbkFsbEZpZWxkcywgdHlwZSBDb2xsZWN0aW9uLCB0eXBlIENvbGxlY3Rpb25Db25maWcgfSBmcm9tICdwYXlsb2FkJ1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Q29sbGVjdGlvbkJ5TW9kZWxLZXkoY29sbGVjdGlvbnM6IFJlY29yZDxzdHJpbmcsIENvbGxlY3Rpb24+LCBtb2RlbEtleTogTW9kZWxLZXkgfCBzdHJpbmcpOiBDb2xsZWN0aW9uQ29uZmlnIHtcbiAgY29uc3QgY29sbGVjdGlvbiA9IE9iamVjdC52YWx1ZXMoY29sbGVjdGlvbnMpLmZpbmQoKGMpID0+IHtcbiAgICByZXR1cm4gYy5jb25maWc/LmN1c3RvbT8uYmV0dGVyQXV0aE1vZGVsS2V5ID09PSBtb2RlbEtleSB8fCBjLmNvbmZpZz8uc2x1ZyA9PT0gbW9kZWxLZXlcbiAgfSlcblxuICBpZiAoIWNvbGxlY3Rpb24pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYENvbGxlY3Rpb24gd2l0aCBrZXkgJHttb2RlbEtleX0gbm90IGZvdW5kYClcbiAgfVxuXG4gIHJldHVybiBjb2xsZWN0aW9uLmNvbmZpZ1xufVxuXG4vKipcbiAqIFJldHJpZXZlcyB0aGUgZmllbGQgbmFtZSBmcm9tIGEgY29sbGVjdGlvbiBiYXNlZCBvbiB0aGUgZmllbGQga2V5XG4gKlxuICogVGhpcyBmdW5jdGlvbiBzZWFyY2hlcyB0aHJvdWdoIHRoZSBmaWVsZHMgb2YgYSBjb2xsZWN0aW9uIHRvIGZpbmQgYSBmaWVsZFxuICogdGhhdCBoYXMgYSBtYXRjaGluZyBjdXN0b20gcHJvcGVydHkgYmV0dGVyQXV0aEZpZWxkS2V5LlxuICpcbiAqIEBwYXJhbSBjb2xsZWN0aW9uIC0gVGhlIGNvbGxlY3Rpb24gY29uZmlndXJhdGlvbiB0byBzZWFyY2ggdGhyb3VnaFxuICogQHBhcmFtIG1vZGVsIC0gVGhlIG1vZGVsIGtleSBvZiB0aGUgY29sbGVjdGlvbiAoVGhpcyBpcyByZWFsbHkganVzdCBmb3IgdHlwZSBoaW50aW5nKVxuICogQHBhcmFtIGZpZWxkS2V5IC0gVGhlIGtleSBvZiB0aGUgZmllbGQgdG8gc2VhcmNoIGZvclxuICogQHJldHVybnMgVGhlIG5hbWUgb2YgdGhlIGZpZWxkIGlmIGZvdW5kLCBvdGhlcndpc2UgdGhlIGZpZWxkIGtleSBpdHNlbGZcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldENvbGxlY3Rpb25GaWVsZE5hbWVCeUZpZWxkS2V5PE0gZXh0ZW5kcyBNb2RlbEtleT4oXG4gIGNvbGxlY3Rpb246IENvbGxlY3Rpb25Db25maWcsXG4gIG1vZGVsOiBNLFxuICBmaWVsZEtleTogRXh0cmFjdDxrZXlvZiBCZXR0ZXJBdXRoRnVsbFNjaGVtYVtNXSwgc3RyaW5nPlxuKTogc3RyaW5nIHtcbiAgY29uc3QgZmllbGRzID0gZmxhdHRlbkFsbEZpZWxkcyh7IGZpZWxkczogY29sbGVjdGlvbi5maWVsZHMgfSlcbiAgcmV0dXJuIGZpZWxkcy5maW5kKChmKSA9PiBmLmN1c3RvbT8uYmV0dGVyQXV0aEZpZWxkS2V5ID09PSBmaWVsZEtleSk/Lm5hbWUgPz8gZmllbGRLZXlcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldENvbGxlY3Rpb25GaWVsZE5hbWVCeUZpZWxkS2V5VW50eXBlZChjb2xsZWN0aW9uOiBDb2xsZWN0aW9uQ29uZmlnLCBmaWVsZEtleTogc3RyaW5nKTogc3RyaW5nIHtcbiAgY29uc3QgZmllbGRzID0gZmxhdHRlbkFsbEZpZWxkcyh7IGZpZWxkczogY29sbGVjdGlvbi5maWVsZHMgfSlcbiAgcmV0dXJuIGZpZWxkcy5maW5kKChmKSA9PiBmLmN1c3RvbT8uYmV0dGVyQXV0aEZpZWxkS2V5ID09PSBmaWVsZEtleSB8fCBmLm5hbWUgPT09IGZpZWxkS2V5KT8ubmFtZSA/PyBmaWVsZEtleVxufVxuXG4vKipcbiAqIFJldHJpZXZlcyB0aGUgZmllbGQga2V5IGZyb20gYSBjb2xsZWN0aW9uIGJhc2VkIG9uIHRoZSBjb2xsZWN0aW9uIGZpZWxkIG5hbWVcbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHNlYXJjaGVzIHRocm91Z2ggdGhlIGZpZWxkcyBvZiBhIGNvbGxlY3Rpb24gdG8gZmluZCBhIGZpZWxkXG4gKiB0aGF0IGhhcyBhIG1hdGNoaW5nIG5hbWUuXG4gKlxuICogQHBhcmFtIGNvbGxlY3Rpb24gLSBUaGUgY29sbGVjdGlvbiBjb25maWd1cmF0aW9uIHRvIHNlYXJjaCB0aHJvdWdoXG4gKiBAcGFyYW0gZmllbGROYW1lIC0gVGhlIG5hbWUgb2YgdGhlIGZpZWxkIHRvIHNlYXJjaCBmb3JcbiAqIEByZXR1cm5zIFRoZSBrZXkgb2YgdGhlIGZpZWxkIGlmIGZvdW5kLCBvdGhlcndpc2UgdGhlIGZpZWxkIG5hbWUgaXRzZWxmXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRGaWVsZEtleUJ5Q29sbGVjdGlvbkZpZWxkTmFtZShjb2xsZWN0aW9uOiBDb2xsZWN0aW9uQ29uZmlnLCBmaWVsZE5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIGNvbnN0IGZpZWxkcyA9IGZsYXR0ZW5BbGxGaWVsZHMoeyBmaWVsZHM6IGNvbGxlY3Rpb24uZmllbGRzIH0pXG4gIHJldHVybiBmaWVsZHMuZmluZCgoZikgPT4gZi5uYW1lID09PSBmaWVsZE5hbWUpPy5jdXN0b20/LmJldHRlckF1dGhGaWVsZEtleSA/PyBmaWVsZE5hbWVcbn1cbiJdLCJuYW1lcyI6WyJmbGF0dGVuQWxsRmllbGRzIiwiZ2V0Q29sbGVjdGlvbkJ5TW9kZWxLZXkiLCJjb2xsZWN0aW9ucyIsIm1vZGVsS2V5IiwiY29sbGVjdGlvbiIsIk9iamVjdCIsInZhbHVlcyIsImZpbmQiLCJjIiwiY29uZmlnIiwiY3VzdG9tIiwiYmV0dGVyQXV0aE1vZGVsS2V5Iiwic2x1ZyIsIkVycm9yIiwiZ2V0Q29sbGVjdGlvbkZpZWxkTmFtZUJ5RmllbGRLZXkiLCJtb2RlbCIsImZpZWxkS2V5IiwiZmllbGRzIiwiZiIsImJldHRlckF1dGhGaWVsZEtleSIsIm5hbWUiLCJnZXRDb2xsZWN0aW9uRmllbGROYW1lQnlGaWVsZEtleVVudHlwZWQiLCJnZXRGaWVsZEtleUJ5Q29sbGVjdGlvbkZpZWxkTmFtZSIsImZpZWxkTmFtZSJdLCJtYXBwaW5ncyI6IkFBQ0EsU0FBU0EsZ0JBQWdCLFFBQWdELFVBQVM7QUFFbEYsT0FBTyxTQUFTQyx3QkFBd0JDLFdBQXVDLEVBQUVDLFFBQTJCO0lBQzFHLE1BQU1DLGFBQWFDLE9BQU9DLE1BQU0sQ0FBQ0osYUFBYUssSUFBSSxDQUFDLENBQUNDO1FBQ2xELE9BQU9BLEVBQUVDLE1BQU0sRUFBRUMsUUFBUUMsdUJBQXVCUixZQUFZSyxFQUFFQyxNQUFNLEVBQUVHLFNBQVNUO0lBQ2pGO0lBRUEsSUFBSSxDQUFDQyxZQUFZO1FBQ2YsTUFBTSxJQUFJUyxNQUFNLENBQUMsb0JBQW9CLEVBQUVWLFNBQVMsVUFBVSxDQUFDO0lBQzdEO0lBRUEsT0FBT0MsV0FBV0ssTUFBTTtBQUMxQjtBQUVBOzs7Ozs7Ozs7O0NBVUMsR0FDRCxPQUFPLFNBQVNLLGlDQUNkVixVQUE0QixFQUM1QlcsS0FBUSxFQUNSQyxRQUF3RDtJQUV4RCxNQUFNQyxTQUFTakIsaUJBQWlCO1FBQUVpQixRQUFRYixXQUFXYSxNQUFNO0lBQUM7SUFDNUQsT0FBT0EsT0FBT1YsSUFBSSxDQUFDLENBQUNXLElBQU1BLEVBQUVSLE1BQU0sRUFBRVMsdUJBQXVCSCxXQUFXSSxRQUFRSjtBQUNoRjtBQUVBLE9BQU8sU0FBU0ssd0NBQXdDakIsVUFBNEIsRUFBRVksUUFBZ0I7SUFDcEcsTUFBTUMsU0FBU2pCLGlCQUFpQjtRQUFFaUIsUUFBUWIsV0FBV2EsTUFBTTtJQUFDO0lBQzVELE9BQU9BLE9BQU9WLElBQUksQ0FBQyxDQUFDVyxJQUFNQSxFQUFFUixNQUFNLEVBQUVTLHVCQUF1QkgsWUFBWUUsRUFBRUUsSUFBSSxLQUFLSixXQUFXSSxRQUFRSjtBQUN2RztBQUVBOzs7Ozs7Ozs7Q0FTQyxHQUNELE9BQU8sU0FBU00saUNBQWlDbEIsVUFBNEIsRUFBRW1CLFNBQWlCO0lBQzlGLE1BQU1OLFNBQVNqQixpQkFBaUI7UUFBRWlCLFFBQVFiLFdBQVdhLE1BQU07SUFBQztJQUM1RCxPQUFPQSxPQUFPVixJQUFJLENBQUMsQ0FBQ1csSUFBTUEsRUFBRUUsSUFBSSxLQUFLRyxZQUFZYixRQUFRUyxzQkFBc0JJO0FBQ2pGIn0=
|
|
@@ -122,4 +122,4 @@ export function withPayloadAuth({ payloadConfig }) {
|
|
|
122
122
|
return optionsWithAdapter;
|
|
123
123
|
}
|
|
124
124
|
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/better-auth/plugin/index.ts"],"sourcesContent":["import type { BetterAuthOptions } from 'better-auth/types'\nimport { getPayload, SanitizedConfig, type Config } from 'payload'\nimport { payloadAdapter } from 'payload-auth/better-auth/adapter'\nimport { getDefaultBetterAuthSchema } from './helpers/get-better-auth-schema'\nimport { syncResolvedSchemaWithCollectionMap } from './helpers/sync-resolved-schema-with-collection-map'\nimport { applyDisabledDefaultAuthConfig } from './lib/apply-disabled-default-auth-config'\nimport { buildCollections } from './lib/build-collections/index'\nimport { initBetterAuth } from './lib/init-better-auth'\nimport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nimport { setLoginMethods } from './lib/set-login-methods'\nimport type { BetterAuthPluginOptions } from './types'\nimport { set } from './utils/set'\n\nexport * from './helpers/index'\nexport { getPayloadAuth } from './lib/get-payload-auth'\nexport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nexport * from './types'\n\nfunction buildBetterAuthData({ payloadConfig, pluginOptions }: { payloadConfig: SanitizedConfig; pluginOptions: BetterAuthPluginOptions }) {\n  pluginOptions = setLoginMethods({ pluginOptions })\n\n  const defaultBetterAuthSchemas = getDefaultBetterAuthSchema(pluginOptions)\n\n  let collectionMap = buildCollections({\n    resolvedSchemas: defaultBetterAuthSchemas,\n    incomingCollections: payloadConfig.collections ?? [],\n    pluginOptions\n  })\n\n  const resolvedBetterAuthSchemas = syncResolvedSchemaWithCollectionMap(defaultBetterAuthSchemas, collectionMap)\n\n  // We need to build the collections a second time with the resolved schemas\n  // due to hooks, endpoints, useAsTitle, etc should rely on resolvedBetterAuthSchemas to get slugs\n  // if they are referencing to other collections then it self.\n  collectionMap = buildCollections({\n    resolvedSchemas: resolvedBetterAuthSchemas,\n    incomingCollections: payloadConfig.collections ?? [],\n    pluginOptions\n  })\n\n  const sanitizedBetterAuthOptions = sanitizeBetterAuthOptions({\n    config: payloadConfig,\n    pluginOptions,\n    resolvedSchemas: resolvedBetterAuthSchemas\n  })\n\n  pluginOptions.betterAuthOptions = sanitizedBetterAuthOptions\n\n  return {\n    pluginOptions,\n    collectionMap,\n    resolvedBetterAuthSchemas,\n    sanitizedBetterAuthOptions\n  }\n}\n\nexport function betterAuthPlugin(pluginOptions: BetterAuthPluginOptions) {\n  return (config: Config): Config => {\n    if (pluginOptions.disabled) {\n      return config\n    }\n\n    config.custom = {\n      ...config.custom,\n      hasBetterAuthPlugin: true\n    }\n\n    const { collectionMap, resolvedBetterAuthSchemas, sanitizedBetterAuthOptions } = buildBetterAuthData({\n      payloadConfig: config as SanitizedConfig,\n      pluginOptions\n    })\n\n    set(config, 'custom.betterAuth.config', sanitizedBetterAuthOptions)\n\n    // ---------------------- Finalize config -----------------\n    if (pluginOptions.disableDefaultPayloadAuth) {\n      applyDisabledDefaultAuthConfig({\n        config,\n        pluginOptions,\n        collectionMap,\n        resolvedBetterAuthSchemas\n      })\n    }\n\n    config.collections = config.collections ?? []\n    config.collections = Object.values(collectionMap)\n\n    const incomingOnInit = config.onInit\n\n    config.onInit = async (payload) => {\n      try {\n        // Execute any existing onInit functions first\n        if (incomingOnInit) {\n          await incomingOnInit(payload)\n        }\n\n        // Initialize and set the betterAuth instance\n        const auth = initBetterAuth<NonNullable<typeof sanitizedBetterAuthOptions.plugins>>({\n          payload,\n          idType: payload.db.defaultIDType,\n          options: {\n            ...sanitizedBetterAuthOptions,\n            enableDebugLogs: pluginOptions.debug?.enableDebugLogs ?? false,\n            plugins: [...(sanitizedBetterAuthOptions.plugins ?? [])]\n          }\n        })\n\n        // Type-safe extension of payload with betterAuth\n        Object.defineProperty(payload, 'betterAuth', {\n          value: auth,\n          writable: false,\n          configurable: false\n        })\n      } catch (error) {\n        console.error('Failed to initialize BetterAuth:', error)\n        throw error\n      }\n    }\n    return config\n  }\n}\n\nexport function withPayloadAuth({ payloadConfig }: { payloadConfig: SanitizedConfig }): BetterAuthOptions {\n  const betterAuthConfig = payloadConfig.custom.betterAuth.config as BetterAuthOptions\n\n  if (!betterAuthConfig) {\n    throw new Error('BetterAuth config not found. Not set payloadConfig.custom.betterAuth.config')\n  }\n\n  const optionsWithAdapter: BetterAuthOptions = {\n    ...betterAuthConfig,\n    database: payloadAdapter({\n      payloadClient: async () => await getPayload({ config: payloadConfig }),\n      adapterConfig: {\n        enableDebugLogs: false,\n        idType: payloadConfig.db.defaultIDType\n      }\n    })\n  }\n\n  return optionsWithAdapter\n}\n"],"names":["getPayload","payloadAdapter","getDefaultBetterAuthSchema","syncResolvedSchemaWithCollectionMap","applyDisabledDefaultAuthConfig","buildCollections","initBetterAuth","sanitizeBetterAuthOptions","setLoginMethods","set","getPayloadAuth","buildBetterAuthData","payloadConfig","pluginOptions","defaultBetterAuthSchemas","collectionMap","resolvedSchemas","incomingCollections","collections","resolvedBetterAuthSchemas","sanitizedBetterAuthOptions","config","betterAuthOptions","betterAuthPlugin","disabled","custom","hasBetterAuthPlugin","disableDefaultPayloadAuth","Object","values","incomingOnInit","onInit","payload","auth","idType","db","defaultIDType","options","enableDebugLogs","debug","plugins","defineProperty","value","writable","configurable","error","console","withPayloadAuth","betterAuthConfig","betterAuth","Error","optionsWithAdapter","database","payloadClient","adapterConfig"],"mappings":"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"}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/better-auth/plugin/index.ts"],"sourcesContent":["import type { BetterAuthOptions } from 'better-auth/types'\nimport { getPayload, SanitizedConfig, type Config } from 'payload'\nimport { payloadAdapter } from 'payload-auth/better-auth/adapter'\nimport { getDefaultBetterAuthSchema } from './helpers/get-better-auth-schema'\nimport { syncResolvedSchemaWithCollectionMap } from './helpers/sync-resolved-schema-with-collection-map'\nimport { applyDisabledDefaultAuthConfig } from './lib/apply-disabled-default-auth-config'\nimport { buildCollections } from './lib/build-collections/index'\nimport { initBetterAuth } from './lib/init-better-auth'\nimport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nimport { setLoginMethods } from './lib/set-login-methods'\nimport type { BetterAuthPluginOptions } from './types'\nimport { set } from './utils/set'\n\nexport * from './helpers/index'\nexport { getPayloadAuth } from './lib/get-payload-auth'\nexport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nexport * from './types'\n\nfunction buildBetterAuthData({ payloadConfig, pluginOptions }: { payloadConfig: SanitizedConfig; pluginOptions: BetterAuthPluginOptions }) {\n  pluginOptions = setLoginMethods({ pluginOptions })\n\n  const defaultBetterAuthSchemas = getDefaultBetterAuthSchema(pluginOptions)\n\n  let collectionMap = buildCollections({\n    resolvedSchemas: defaultBetterAuthSchemas,\n    incomingCollections: payloadConfig.collections ?? [],\n    pluginOptions\n  })\n\n  const resolvedBetterAuthSchemas = syncResolvedSchemaWithCollectionMap(defaultBetterAuthSchemas, collectionMap)\n\n  // We need to build the collections a second time with the resolved schemas\n  // due to hooks, endpoints, useAsTitle, etc should rely on resolvedBetterAuthSchemas to get slugs\n  // if they are referencing to other collections then it self.\n  collectionMap = buildCollections({\n    resolvedSchemas: resolvedBetterAuthSchemas,\n    incomingCollections: payloadConfig.collections ?? [],\n    pluginOptions\n  })\n\n  const sanitizedBetterAuthOptions = sanitizeBetterAuthOptions({\n    config: payloadConfig,\n    pluginOptions,\n    resolvedSchemas: resolvedBetterAuthSchemas\n  })\n\n  pluginOptions.betterAuthOptions = sanitizedBetterAuthOptions\n\n  return {\n    pluginOptions,\n    collectionMap,\n    resolvedBetterAuthSchemas,\n    sanitizedBetterAuthOptions\n  }\n}\n\nexport function betterAuthPlugin(pluginOptions: BetterAuthPluginOptions) {\n  return (config: Config): Config => {\n    if (pluginOptions.disabled) {\n      return config\n    }\n\n    config.custom = {\n      ...config.custom,\n      hasBetterAuthPlugin: true\n    }\n\n    const { collectionMap, resolvedBetterAuthSchemas, sanitizedBetterAuthOptions } = buildBetterAuthData({\n      payloadConfig: config as SanitizedConfig,\n      pluginOptions\n    })\n\n    set(config, 'custom.betterAuth.config', sanitizedBetterAuthOptions)\n\n    // ---------------------- Finalize config -----------------\n    if (pluginOptions.disableDefaultPayloadAuth) {\n      applyDisabledDefaultAuthConfig({\n        config,\n        pluginOptions,\n        collectionMap,\n        resolvedBetterAuthSchemas\n      })\n    }\n\n    config.collections = config.collections ?? []\n    config.collections = Object.values(collectionMap)\n\n    const incomingOnInit = config.onInit\n\n    config.onInit = async (payload) => {\n      try {\n        // Execute any existing onInit functions first\n        if (incomingOnInit) {\n          await incomingOnInit(payload)\n        }\n\n        // Initialize and set the betterAuth instance\n        const auth = initBetterAuth<typeof pluginOptions>({\n          payload,\n          idType: payload.db.defaultIDType,\n          options: {\n            ...sanitizedBetterAuthOptions,\n            enableDebugLogs: pluginOptions.debug?.enableDebugLogs ?? false,\n            plugins: [...(sanitizedBetterAuthOptions.plugins ?? [])]\n          }\n        })\n\n        // Type-safe extension of payload with betterAuth\n        Object.defineProperty(payload, 'betterAuth', {\n          value: auth,\n          writable: false,\n          configurable: false\n        })\n      } catch (error) {\n        console.error('Failed to initialize BetterAuth:', error)\n        throw error\n      }\n    }\n    return config\n  }\n}\n\nexport function withPayloadAuth({ payloadConfig }: { payloadConfig: SanitizedConfig }): BetterAuthOptions {\n  const betterAuthConfig = payloadConfig.custom.betterAuth.config as BetterAuthOptions\n\n  if (!betterAuthConfig) {\n    throw new Error('BetterAuth config not found. Not set payloadConfig.custom.betterAuth.config')\n  }\n\n  const optionsWithAdapter: BetterAuthOptions = {\n    ...betterAuthConfig,\n    database: payloadAdapter({\n      payloadClient: async () => await getPayload({ config: payloadConfig }),\n      adapterConfig: {\n        enableDebugLogs: false,\n        idType: payloadConfig.db.defaultIDType\n      }\n    })\n  }\n\n  return optionsWithAdapter\n}\n"],"names":["getPayload","payloadAdapter","getDefaultBetterAuthSchema","syncResolvedSchemaWithCollectionMap","applyDisabledDefaultAuthConfig","buildCollections","initBetterAuth","sanitizeBetterAuthOptions","setLoginMethods","set","getPayloadAuth","buildBetterAuthData","payloadConfig","pluginOptions","defaultBetterAuthSchemas","collectionMap","resolvedSchemas","incomingCollections","collections","resolvedBetterAuthSchemas","sanitizedBetterAuthOptions","config","betterAuthOptions","betterAuthPlugin","disabled","custom","hasBetterAuthPlugin","disableDefaultPayloadAuth","Object","values","incomingOnInit","onInit","payload","auth","idType","db","defaultIDType","options","enableDebugLogs","debug","plugins","defineProperty","value","writable","configurable","error","console","withPayloadAuth","betterAuthConfig","betterAuth","Error","optionsWithAdapter","database","payloadClient","adapterConfig"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"passkeys.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/passkeys.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,oBAAoB,EAAkB,MAAM,4BAA4B,CAAA;AACtF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAE/C,wBAAgB,uBAAuB,CAAC,EAAE,mBAAmB,EAAE,aAAa,EAAE,eAAe,EAAE,EAAE,oBAAoB,GAAG,gBAAgB,
|
|
1
|
+
{"version":3,"file":"passkeys.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/passkeys.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,oBAAoB,EAAkB,MAAM,4BAA4B,CAAA;AACtF,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAE/C,wBAAgB,uBAAuB,CAAC,EAAE,mBAAmB,EAAE,aAAa,EAAE,eAAe,EAAE,EAAE,oBAAoB,GAAG,gBAAgB,CAuFvI"}
|
|
@@ -34,6 +34,7 @@ export function buildPasskeysCollection({ incomingCollections, pluginOptions, re
|
|
|
34
34
|
}
|
|
35
35
|
}),
|
|
36
36
|
credentialID: ()=>({
|
|
37
|
+
name: 'credentialId',
|
|
37
38
|
admin: {
|
|
38
39
|
readOnly: true,
|
|
39
40
|
description: 'The unique identifier of the registered credential'
|
|
@@ -112,4 +113,4 @@ export function buildPasskeysCollection({ incomingCollections, pluginOptions, re
|
|
|
112
113
|
return passkeyCollection;
|
|
113
114
|
}
|
|
114
115
|
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL3Bhc3NrZXlzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJhTW9kZWxGaWVsZEtleXNUb0ZpZWxkTmFtZXMsIGJhTW9kZWxLZXksIGRlZmF1bHRzIH0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHsgZ2V0QWRtaW5BY2Nlc3MgfSBmcm9tICcuLi8uLi9oZWxwZXJzL2dldC1hZG1pbi1hY2Nlc3MnXG5pbXBvcnQgeyBnZXRTY2hlbWFDb2xsZWN0aW9uU2x1ZywgZ2V0U2NoZW1hRmllbGROYW1lIH0gZnJvbSAnLi91dGlscy9jb2xsZWN0aW9uLXNjaGVtYSdcbmltcG9ydCB7IGFzc2VydEFsbFNjaGVtYUZpZWxkcyB9IGZyb20gJy4vdXRpbHMvY29sbGVjdGlvbi1zY2hlbWEnXG5pbXBvcnQgeyBpc0FkbWluT3JDdXJyZW50VXNlcldpdGhSb2xlcyB9IGZyb20gJy4vdXRpbHMvcGF5bG9hZC1hY2Nlc3MnXG5pbXBvcnQgeyBnZXRDb2xsZWN0aW9uRmllbGRzIH0gZnJvbSAnLi91dGlscy90cmFuc2Zvcm0tc2NoZW1hLWZpZWxkcy10by1wYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBQYXNza2V5IH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9nZW5lcmF0ZWQtdHlwZXMnXG5pbXBvcnQgdHlwZSB7IEJ1aWxkQ29sbGVjdGlvblByb3BzLCBGaWVsZE92ZXJyaWRlcyB9IGZyb20gJ0AvYmV0dGVyLWF1dGgvcGx1Z2luL3R5cGVzJ1xuaW1wb3J0IHR5cGUgeyBDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZCdcblxuZXhwb3J0IGZ1bmN0aW9uIGJ1aWxkUGFzc2tleXNDb2xsZWN0aW9uKHsgaW5jb21pbmdDb2xsZWN0aW9ucywgcGx1Z2luT3B0aW9ucywgcmVzb2x2ZWRTY2hlbWFzIH06IEJ1aWxkQ29sbGVjdGlvblByb3BzKTogQ29sbGVjdGlvbkNvbmZpZyB7XG4gIGNvbnN0IHBhc3NrZXlTbHVnID0gZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWcocmVzb2x2ZWRTY2hlbWFzLCBiYU1vZGVsS2V5LnBhc3NrZXkpXG4gIGNvbnN0IHBhc3NrZXlTY2hlbWEgPSByZXNvbHZlZFNjaGVtYXNbYmFNb2RlbEtleS5wYXNza2V5XVxuICBjb25zdCB1c2VySWRGaWVsZE5hbWUgPSBwYXNza2V5U2NoZW1hPy5maWVsZHM/LnVzZXJJZD8uZmllbGROYW1lID8/IGJhTW9kZWxGaWVsZEtleXNUb0ZpZWxkTmFtZXMucGFzc2tleS51c2VySWRcbiAgY29uc3QgYWRtaW5Sb2xlcyA9IHBsdWdpbk9wdGlvbnMudXNlcnM/LmFkbWluUm9sZXMgPz8gW2RlZmF1bHRzLmFkbWluUm9sZV1cblxuICBjb25zdCBleGlzdGluZ1Bhc3NrZXlDb2xsZWN0aW9uID0gaW5jb21pbmdDb2xsZWN0aW9ucy5maW5kKChjb2xsZWN0aW9uKSA9PiBjb2xsZWN0aW9uLnNsdWcgPT09IHBhc3NrZXlTbHVnKSBhc1xuICAgIHwgQ29sbGVjdGlvbkNvbmZpZ1xuICAgIHwgdW5kZWZpbmVkXG5cbiAgY29uc3QgZmllbGRPdmVycmlkZXM6IEZpZWxkT3ZlcnJpZGVzPGtleW9mIFBhc3NrZXk+ID0ge1xuICAgIG5hbWU6ICgpID0+ICh7XG4gICAgICBhZG1pbjogeyByZWFkT25seTogdHJ1ZSwgZGVzY3JpcHRpb246ICdUaGUgbmFtZSBvZiB0aGUgcGFzc2tleScgfVxuICAgIH0pLFxuICAgIHB1YmxpY0tleTogKCkgPT4gKHtcbiAgICAgIGluZGV4OiB0cnVlLFxuICAgICAgYWRtaW46IHsgcmVhZE9ubHk6IHRydWUsIGRlc2NyaXB0aW9uOiAnVGhlIHB1YmxpYyBrZXkgb2YgdGhlIHBhc3NrZXknIH1cbiAgICB9KSxcbiAgICB1c2VySWQ6ICgpID0+
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/passkeys.ts"],"sourcesContent":["import { baModelFieldKeysToFieldNames, baModelKey, defaults } from '../../constants'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\nimport { getSchemaCollectionSlug, getSchemaFieldName } from './utils/collection-schema'\nimport { assertAllSchemaFields } from './utils/collection-schema'\nimport { isAdminOrCurrentUserWithRoles } from './utils/payload-access'\nimport { getCollectionFields } from './utils/transform-schema-fields-to-payload'\nimport type { Passkey } from '@/better-auth/generated-types'\nimport type { BuildCollectionProps, FieldOverrides } from '@/better-auth/plugin/types'\nimport type { CollectionConfig } from 'payload'\n\nexport function buildPasskeysCollection({ incomingCollections, pluginOptions, resolvedSchemas }: BuildCollectionProps): CollectionConfig {\n  const passkeySlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.passkey)\n  const passkeySchema = resolvedSchemas[baModelKey.passkey]\n  const userIdFieldName = passkeySchema?.fields?.userId?.fieldName ?? baModelFieldKeysToFieldNames.passkey.userId\n  const adminRoles = pluginOptions.users?.adminRoles ?? [defaults.adminRole]\n\n  const existingPasskeyCollection = incomingCollections.find((collection) => collection.slug === passkeySlug) as\n    | CollectionConfig\n    | undefined\n\n  const fieldOverrides: FieldOverrides<keyof Passkey> = {\n    name: () => ({\n      admin: { readOnly: true, description: 'The name of the passkey' }\n    }),\n    publicKey: () => ({\n      index: true,\n      admin: { readOnly: true, description: 'The public key of the passkey' }\n    }),\n    userId: () => ({\n      index: true,\n      admin: { readOnly: true, description: 'The user that the passkey belongs to' }\n    }),\n    credentialID: () => ({\n      name: 'credentialId',\n      admin: { readOnly: true, description: 'The unique identifier of the registered credential' }\n    }),\n    counter: () => ({\n      required: true,\n      admin: { readOnly: true, description: 'The counter of the passkey' }\n    }),\n    deviceType: () => ({\n      required: true,\n      admin: { readOnly: true, description: 'The type of device used to register the passkey' }\n    }),\n    backedUp: () => ({\n      required: true,\n      admin: { readOnly: true, description: 'Whether the passkey is backed up' }\n    }),\n    transports: () => ({\n      required: true,\n      admin: { readOnly: true, description: 'The transports used to register the passkey' }\n    })\n  }\n\n  const collectionFields = getCollectionFields({\n    schema: passkeySchema,\n    additionalProperties: fieldOverrides\n  })\n\n  let passkeyCollection: CollectionConfig = {\n    ...existingPasskeyCollection,\n    slug: passkeySlug,\n    admin: {\n      hidden: pluginOptions.hidePluginCollections ?? false,\n      useAsTitle: getSchemaFieldName(resolvedSchemas, baModelKey.passkey, 'name'),\n      description: 'Passkeys are used to authenticate users',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingPasskeyCollection?.admin\n    },\n    access: {\n      ...getAdminAccess(pluginOptions),\n      read: isAdminOrCurrentUserWithRoles({\n        idField: userIdFieldName,\n        adminRoles\n      }),\n      delete: isAdminOrCurrentUserWithRoles({\n        idField: userIdFieldName,\n        adminRoles\n      }),\n      ...(existingPasskeyCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingPasskeyCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.passkey\n    },\n    fields: [...(existingPasskeyCollection?.fields ?? []), ...(collectionFields ?? [])]\n  }\n\n  if (typeof pluginOptions.pluginCollectionOverrides?.passkeys === 'function') {\n    passkeyCollection = pluginOptions.pluginCollectionOverrides.passkeys({\n      collection: passkeyCollection\n    })\n  }\n\n  assertAllSchemaFields(passkeyCollection, passkeySchema)\n\n  return passkeyCollection\n}\n"],"names":["baModelFieldKeysToFieldNames","baModelKey","defaults","getAdminAccess","getSchemaCollectionSlug","getSchemaFieldName","assertAllSchemaFields","isAdminOrCurrentUserWithRoles","getCollectionFields","buildPasskeysCollection","incomingCollections","pluginOptions","resolvedSchemas","passkeySlug","passkey","passkeySchema","userIdFieldName","fields","userId","fieldName","adminRoles","users","adminRole","existingPasskeyCollection","find","collection","slug","fieldOverrides","name","admin","readOnly","description","publicKey","index","credentialID","counter","required","deviceType","backedUp","transports","collectionFields","schema","additionalProperties","passkeyCollection","hidden","hidePluginCollections","useAsTitle","group","collectionAdminGroup","access","read","idField","delete","custom","betterAuthModelKey","pluginCollectionOverrides","passkeys"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/sessions.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAE/C,OAAO,KAAK,EAAE,oBAAoB,EAA6B,MAAM,4BAA4B,CAAA;AAEjG,wBAAgB,uBAAuB,CAAC,EAAE,mBAAmB,EAAE,aAAa,EAAE,eAAe,EAAE,EAAE,oBAAoB,GAAG,gBAAgB,
|
|
1
|
+
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/sessions.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAE/C,OAAO,KAAK,EAAE,oBAAoB,EAA6B,MAAM,4BAA4B,CAAA;AAEjG,wBAAgB,uBAAuB,CAAC,EAAE,mBAAmB,EAAE,aAAa,EAAE,eAAe,EAAE,EAAE,oBAAoB,GAAG,gBAAgB,CAmHvI"}
|