payload-auth 1.6.1-canary.3 → 1.6.1-canary.5

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.
@@ -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,CAAC;AAGtE;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,0BAA0B,CAAC,aAAa,EAAE,uBAAuB,GAAG,iBAAiB,CAoDpG"}
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;AAGrE;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,0BAA0B,CAAC,aAAa,EAAE,uBAAuB,GAAG,iBAAiB,CAoDpG"}
@@ -1,6 +1,6 @@
1
1
  import { getAuthTables } from "better-auth/db";
2
2
  import { baModelFieldKeysToFieldNames } from "../constants";
3
- import { getDeafultCollectionSlug } from "./get-collection-slug";
3
+ import { getDefaultCollectionSlug } from "./get-collection-slug";
4
4
  /**
5
5
  * A consistent BetterAuth schema generator.
6
6
  *
@@ -23,7 +23,7 @@ import { getDeafultCollectionSlug } from "./get-collection-slug";
23
23
  for (const modelKey of Object.keys(tables)){
24
24
  const table = tables[modelKey];
25
25
  // Resolve the canonical collection slug / model name for this key
26
- const resolvedModelName = getDeafultCollectionSlug({
26
+ const resolvedModelName = getDefaultCollectionSlug({
27
27
  modelKey,
28
28
  pluginOptions
29
29
  });
@@ -38,7 +38,7 @@ import { getDeafultCollectionSlug } from "./get-collection-slug";
38
38
  // Rewrite references to use the resolved modelName for the target table
39
39
  if (fieldValue.references) {
40
40
  const refModelKey = fieldValue.references.model;
41
- const resolvedRefModelName = getDeafultCollectionSlug({
41
+ const resolvedRefModelName = getDefaultCollectionSlug({
42
42
  modelKey: refModelKey,
43
43
  pluginOptions
44
44
  });
@@ -65,4 +65,4 @@ import { getDeafultCollectionSlug } from "./get-collection-slug";
65
65
  return schema;
66
66
  }
67
67
 
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9nZXQtYmV0dGVyLWF1dGgtc2NoZW1hLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZGVsS2V5IH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9nZW5lcmF0ZWQtdHlwZXMnO1xuaW1wb3J0IHsgZ2V0QXV0aFRhYmxlcywgdHlwZSBGaWVsZEF0dHJpYnV0ZSB9IGZyb20gJ2JldHRlci1hdXRoL2RiJztcbmltcG9ydCB7IGJhTW9kZWxGaWVsZEtleXNUb0ZpZWxkTmFtZXMgfSBmcm9tICcuLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgQmV0dGVyQXV0aFBsdWdpbk9wdGlvbnMsIEJldHRlckF1dGhTY2hlbWFzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgZ2V0RGVhZnVsdENvbGxlY3Rpb25TbHVnIH0gZnJvbSAnLi9nZXQtY29sbGVjdGlvbi1zbHVnJztcblxuLyoqXG4gKiBBIGNvbnNpc3RlbnQgQmV0dGVyQXV0aCBzY2hlbWEgZ2VuZXJhdG9yLlxuICpcbiAqIERpZmZlcmVuY2VzIGZyb20gdGhlIG9yaWdpbmFsIGBnZXRTY2hlbWFgIGltcGxlbWVudGF0aW9uIGluIEJldHRlckF1dGg6XG4gKiAxLiBLZXlzIGluIHRoZSByZXR1cm5lZCBvYmplY3QgYXJlIGFsd2F5cyB0aGUgKipzdGF0aWMgdGFibGUgaWRlbnRpZmllcnMqKiBjb21pbmcgZnJvbVxuICogICAgYGdldEF1dGhUYWJsZXNgLCBuZXZlciB0aGUgcG9zc2libHktb3ZlcnJpZGRlbiBgbW9kZWxOYW1lYC4gIFRoaXMgZ3VhcmFudGVlcyB0aGF0XG4gKiAgICBzdWJzZXF1ZW50IGxvb2stdXBzIHJlbWFpbiBzdGFibGUgZXZlbiBpZiB0aGUgdXNlciByZW5hbWVzIGNvbGxlY3Rpb25zLlxuICogMi4gRWFjaCBzY2hlbWEgZW50cnkgbm93IGNvbnRhaW5zIGFuIGV4cGxpY2l0IGBtb2RlbE5hbWVgIHByb3BlcnR5IGV4cG9zaW5nIHRoZSBjdXJyZW50XG4gKiAgICAocG90ZW50aWFsbHkgdXNlci1vdmVycmlkZGVuKSBtb2RlbCBuYW1lLCB3aGlsZSBgZmllbGRzYCBjb250aW51ZSB0byBiZSByZWZlcmVuY2VkIGJ5XG4gKiAgICB0aGVpciBzdGF0aWMgQmV0dGVyQXV0aCBmaWVsZCBrZXlzLlxuICogMy4gV2hlbiBjb252ZXJ0aW5nIGZpZWxkcywgd2Ugc3RvcmUgdGhlbSB1bmRlciB0aGVpciBvcmlnaW5hbCBrZXkgKGBhY3R1YWxGaWVsZHNba2V5XSA9IGZpZWxkYClcbiAqICAgIGluc3RlYWQgb2YgYGZpZWxkLmZpZWxkTmFtZSB8fCBrZXlgIHRvIGF2b2lkIGFjY2lkZW50YWwgcmVuYW1lcy5cbiAqXG4gKiBAcGFyYW0gY29uZmlnIC0gVGhlIEJldHRlckF1dGggb3B0aW9ucyBmZWQgaW50byBgZ2V0QXV0aFRhYmxlc2AuXG4gKiBAcmV0dXJucyBBIG1hcCBrZXllZCBieSBzdGF0aWMgdGFibGUga2V5cywgZWFjaCB2YWx1ZSBjb250YWluaW5nIGB7IG1vZGVsTmFtZSwgZmllbGRzLCBvcmRlciB9YC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldERlZmF1bHRCZXR0ZXJBdXRoU2NoZW1hKHBsdWdpbk9wdGlvbnM6IEJldHRlckF1dGhQbHVnaW5PcHRpb25zKTogQmV0dGVyQXV0aFNjaGVtYXMge1xuICBjb25zdCBiZXR0ZXJBdXRoT3B0aW9ucyA9IHBsdWdpbk9wdGlvbnMuYmV0dGVyQXV0aE9wdGlvbnMgPz8ge31cbiAgY29uc3QgdGFibGVzID0gZ2V0QXV0aFRhYmxlcyhiZXR0ZXJBdXRoT3B0aW9ucylcblxuICBjb25zdCBzY2hlbWE6IFBhcnRpYWw8QmV0dGVyQXV0aFNjaGVtYXM+ID0ge31cblxuICBmb3IgKGNvbnN0IG1vZGVsS2V5IG9mIE9iamVjdC5rZXlzKHRhYmxlcykgYXMgTW9kZWxLZXlbXSkge1xuICAgIGNvbnN0IHRhYmxlID0gdGFibGVzW21vZGVsS2V5XVxuXG4gICAgLy8gUmVzb2x2ZSB0aGUgY2Fub25pY2FsIGNvbGxlY3Rpb24gc2x1ZyAvIG1vZGVsIG5hbWUgZm9yIHRoaXMga2V5XG4gICAgY29uc3QgcmVzb2x2ZWRNb2RlbE5hbWUgPSBnZXREZWFmdWx0Q29sbGVjdGlvblNsdWcoeyBtb2RlbEtleSwgcGx1Z2luT3B0aW9ucyB9KVxuXG4gICAgY29uc3QgZGVmYXVsdEZpZWxkTWFwID0gKGJhTW9kZWxGaWVsZEtleXNUb0ZpZWxkTmFtZXMgYXMgUmVjb3JkPHN0cmluZywgUmVjb3JkPHN0cmluZywgc3RyaW5nPj4pW21vZGVsS2V5XSA/PyB7fVxuXG4gICAgY29uc3QgYWN0dWFsRmllbGRzOiBSZWNvcmQ8c3RyaW5nLCBGaWVsZEF0dHJpYnV0ZT4gPSB7fVxuXG4gICAgT2JqZWN0LmVudHJpZXModGFibGUuZmllbGRzKS5mb3JFYWNoKChbZmllbGRLZXksIGZpZWxkVmFsdWVdKSA9PiB7XG4gICAgICAvLyBCdWlsZCB0aGUgZmllbGQgZW5zdXJpbmcgYSBmaWVsZE5hbWUgZXhpc3RzXG4gICAgICBjb25zdCBuZXdGaWVsZDogRmllbGRBdHRyaWJ1dGUgPSB7XG4gICAgICAgIC4uLmZpZWxkVmFsdWUsXG4gICAgICAgIGZpZWxkTmFtZTogZGVmYXVsdEZpZWxkTWFwW2ZpZWxkS2V5XSA/PyBmaWVsZEtleVxuICAgICAgfVxuXG4gICAgICAvLyBSZXdyaXRlIHJlZmVyZW5jZXMgdG8gdXNlIHRoZSByZXNvbHZlZCBtb2RlbE5hbWUgZm9yIHRoZSB0YXJnZXQgdGFibGVcbiAgICAgIGlmIChmaWVsZFZhbHVlLnJlZmVyZW5jZXMpIHtcbiAgICAgICAgY29uc3QgcmVmTW9kZWxLZXkgPSBmaWVsZFZhbHVlLnJlZmVyZW5jZXMubW9kZWwgYXMgc3RyaW5nXG4gICAgICAgIGNvbnN0IHJlc29sdmVkUmVmTW9kZWxOYW1lID0gZ2V0RGVhZnVsdENvbGxlY3Rpb25TbHVnKHsgbW9kZWxLZXk6IHJlZk1vZGVsS2V5LCBwbHVnaW5PcHRpb25zIH0pXG4gICAgICAgIG5ld0ZpZWxkLnJlZmVyZW5jZXMgPSB7XG4gICAgICAgICAgbW9kZWw6IHJlc29sdmVkUmVmTW9kZWxOYW1lLFxuICAgICAgICAgIGZpZWxkOiBmaWVsZFZhbHVlLnJlZmVyZW5jZXMuZmllbGRcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBhY3R1YWxGaWVsZHNbZmllbGRLZXldID0gbmV3RmllbGRcbiAgICB9KVxuXG4gICAgaWYgKHNjaGVtYVttb2RlbEtleV0pIHtcbiAgICAgIHNjaGVtYVttb2RlbEtleV0uZmllbGRzID0ge1xuICAgICAgICAuLi5zY2hlbWFbbW9kZWxLZXldLmZpZWxkcyxcbiAgICAgICAgLi4uYWN0dWFsRmllbGRzXG4gICAgICB9XG4gICAgICBjb250aW51ZVxuICAgIH1cblxuICAgIHNjaGVtYVttb2RlbEtleV0gPSB7XG4gICAgICBtb2RlbE5hbWU6IHJlc29sdmVkTW9kZWxOYW1lLFxuICAgICAgZmllbGRzOiBhY3R1YWxGaWVsZHMsXG4gICAgICBvcmRlcjogdGFibGUub3JkZXIgfHwgSW5maW5pdHlcbiAgICB9XG4gIH1cblxuICByZXR1cm4gc2NoZW1hIGFzIEJldHRlckF1dGhTY2hlbWFzXG59XG4iXSwibmFtZXMiOlsiZ2V0QXV0aFRhYmxlcyIsImJhTW9kZWxGaWVsZEtleXNUb0ZpZWxkTmFtZXMiLCJnZXREZWFmdWx0Q29sbGVjdGlvblNsdWciLCJnZXREZWZhdWx0QmV0dGVyQXV0aFNjaGVtYSIsInBsdWdpbk9wdGlvbnMiLCJiZXR0ZXJBdXRoT3B0aW9ucyIsInRhYmxlcyIsInNjaGVtYSIsIm1vZGVsS2V5IiwiT2JqZWN0Iiwia2V5cyIsInRhYmxlIiwicmVzb2x2ZWRNb2RlbE5hbWUiLCJkZWZhdWx0RmllbGRNYXAiLCJhY3R1YWxGaWVsZHMiLCJlbnRyaWVzIiwiZmllbGRzIiwiZm9yRWFjaCIsImZpZWxkS2V5IiwiZmllbGRWYWx1ZSIsIm5ld0ZpZWxkIiwiZmllbGROYW1lIiwicmVmZXJlbmNlcyIsInJlZk1vZGVsS2V5IiwibW9kZWwiLCJyZXNvbHZlZFJlZk1vZGVsTmFtZSIsImZpZWxkIiwibW9kZWxOYW1lIiwib3JkZXIiLCJJbmZpbml0eSJdLCJtYXBwaW5ncyI6IkFBQ0EsU0FBU0EsYUFBYSxRQUE2QixpQkFBaUI7QUFDcEUsU0FBU0MsNEJBQTRCLFFBQVEsZUFBZTtBQUU1RCxTQUFTQyx3QkFBd0IsUUFBUSx3QkFBd0I7QUFFakU7Ozs7Ozs7Ozs7Ozs7OztDQWVDLEdBQ0QsT0FBTyxTQUFTQywyQkFBMkJDLGFBQXNDO0lBQy9FLE1BQU1DLG9CQUFvQkQsY0FBY0MsaUJBQWlCLElBQUksQ0FBQztJQUM5RCxNQUFNQyxTQUFTTixjQUFjSztJQUU3QixNQUFNRSxTQUFxQyxDQUFDO0lBRTVDLEtBQUssTUFBTUMsWUFBWUMsT0FBT0MsSUFBSSxDQUFDSixRQUF1QjtRQUN4RCxNQUFNSyxRQUFRTCxNQUFNLENBQUNFLFNBQVM7UUFFOUIsa0VBQWtFO1FBQ2xFLE1BQU1JLG9CQUFvQlYseUJBQXlCO1lBQUVNO1lBQVVKO1FBQWM7UUFFN0UsTUFBTVMsa0JBQWtCLEFBQUNaLDRCQUF1RSxDQUFDTyxTQUFTLElBQUksQ0FBQztRQUUvRyxNQUFNTSxlQUErQyxDQUFDO1FBRXRETCxPQUFPTSxPQUFPLENBQUNKLE1BQU1LLE1BQU0sRUFBRUMsT0FBTyxDQUFDLENBQUMsQ0FBQ0MsVUFBVUMsV0FBVztZQUMxRCw4Q0FBOEM7WUFDOUMsTUFBTUMsV0FBMkI7Z0JBQy9CLEdBQUdELFVBQVU7Z0JBQ2JFLFdBQVdSLGVBQWUsQ0FBQ0ssU0FBUyxJQUFJQTtZQUMxQztZQUVBLHdFQUF3RTtZQUN4RSxJQUFJQyxXQUFXRyxVQUFVLEVBQUU7Z0JBQ3pCLE1BQU1DLGNBQWNKLFdBQVdHLFVBQVUsQ0FBQ0UsS0FBSztnQkFDL0MsTUFBTUMsdUJBQXVCdkIseUJBQXlCO29CQUFFTSxVQUFVZTtvQkFBYW5CO2dCQUFjO2dCQUM3RmdCLFNBQVNFLFVBQVUsR0FBRztvQkFDcEJFLE9BQU9DO29CQUNQQyxPQUFPUCxXQUFXRyxVQUFVLENBQUNJLEtBQUs7Z0JBQ3BDO1lBQ0Y7WUFFQVosWUFBWSxDQUFDSSxTQUFTLEdBQUdFO1FBQzNCO1FBRUEsSUFBSWIsTUFBTSxDQUFDQyxTQUFTLEVBQUU7WUFDcEJELE1BQU0sQ0FBQ0MsU0FBUyxDQUFDUSxNQUFNLEdBQUc7Z0JBQ3hCLEdBQUdULE1BQU0sQ0FBQ0MsU0FBUyxDQUFDUSxNQUFNO2dCQUMxQixHQUFHRixZQUFZO1lBQ2pCO1lBQ0E7UUFDRjtRQUVBUCxNQUFNLENBQUNDLFNBQVMsR0FBRztZQUNqQm1CLFdBQVdmO1lBQ1hJLFFBQVFGO1lBQ1JjLE9BQU9qQixNQUFNaUIsS0FBSyxJQUFJQztRQUN4QjtJQUNGO0lBRUEsT0FBT3RCO0FBQ1QifQ==
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9nZXQtYmV0dGVyLWF1dGgtc2NoZW1hLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1vZGVsS2V5IH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9nZW5lcmF0ZWQtdHlwZXMnXG5pbXBvcnQgeyBnZXRBdXRoVGFibGVzLCB0eXBlIEZpZWxkQXR0cmlidXRlIH0gZnJvbSAnYmV0dGVyLWF1dGgvZGInXG5pbXBvcnQgeyBiYU1vZGVsRmllbGRLZXlzVG9GaWVsZE5hbWVzIH0gZnJvbSAnLi4vY29uc3RhbnRzJ1xuaW1wb3J0IHsgQmV0dGVyQXV0aFBsdWdpbk9wdGlvbnMsIEJldHRlckF1dGhTY2hlbWFzIH0gZnJvbSAnLi4vdHlwZXMnXG5pbXBvcnQgeyBnZXREZWZhdWx0Q29sbGVjdGlvblNsdWcgfSBmcm9tICcuL2dldC1jb2xsZWN0aW9uLXNsdWcnXG5cbi8qKlxuICogQSBjb25zaXN0ZW50IEJldHRlckF1dGggc2NoZW1hIGdlbmVyYXRvci5cbiAqXG4gKiBEaWZmZXJlbmNlcyBmcm9tIHRoZSBvcmlnaW5hbCBgZ2V0U2NoZW1hYCBpbXBsZW1lbnRhdGlvbiBpbiBCZXR0ZXJBdXRoOlxuICogMS4gS2V5cyBpbiB0aGUgcmV0dXJuZWQgb2JqZWN0IGFyZSBhbHdheXMgdGhlICoqc3RhdGljIHRhYmxlIGlkZW50aWZpZXJzKiogY29taW5nIGZyb21cbiAqICAgIGBnZXRBdXRoVGFibGVzYCwgbmV2ZXIgdGhlIHBvc3NpYmx5LW92ZXJyaWRkZW4gYG1vZGVsTmFtZWAuICBUaGlzIGd1YXJhbnRlZXMgdGhhdFxuICogICAgc3Vic2VxdWVudCBsb29rLXVwcyByZW1haW4gc3RhYmxlIGV2ZW4gaWYgdGhlIHVzZXIgcmVuYW1lcyBjb2xsZWN0aW9ucy5cbiAqIDIuIEVhY2ggc2NoZW1hIGVudHJ5IG5vdyBjb250YWlucyBhbiBleHBsaWNpdCBgbW9kZWxOYW1lYCBwcm9wZXJ0eSBleHBvc2luZyB0aGUgY3VycmVudFxuICogICAgKHBvdGVudGlhbGx5IHVzZXItb3ZlcnJpZGRlbikgbW9kZWwgbmFtZSwgd2hpbGUgYGZpZWxkc2AgY29udGludWUgdG8gYmUgcmVmZXJlbmNlZCBieVxuICogICAgdGhlaXIgc3RhdGljIEJldHRlckF1dGggZmllbGQga2V5cy5cbiAqIDMuIFdoZW4gY29udmVydGluZyBmaWVsZHMsIHdlIHN0b3JlIHRoZW0gdW5kZXIgdGhlaXIgb3JpZ2luYWwga2V5IChgYWN0dWFsRmllbGRzW2tleV0gPSBmaWVsZGApXG4gKiAgICBpbnN0ZWFkIG9mIGBmaWVsZC5maWVsZE5hbWUgfHwga2V5YCB0byBhdm9pZCBhY2NpZGVudGFsIHJlbmFtZXMuXG4gKlxuICogQHBhcmFtIGNvbmZpZyAtIFRoZSBCZXR0ZXJBdXRoIG9wdGlvbnMgZmVkIGludG8gYGdldEF1dGhUYWJsZXNgLlxuICogQHJldHVybnMgQSBtYXAga2V5ZWQgYnkgc3RhdGljIHRhYmxlIGtleXMsIGVhY2ggdmFsdWUgY29udGFpbmluZyBgeyBtb2RlbE5hbWUsIGZpZWxkcywgb3JkZXIgfWAuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXREZWZhdWx0QmV0dGVyQXV0aFNjaGVtYShwbHVnaW5PcHRpb25zOiBCZXR0ZXJBdXRoUGx1Z2luT3B0aW9ucyk6IEJldHRlckF1dGhTY2hlbWFzIHtcbiAgY29uc3QgYmV0dGVyQXV0aE9wdGlvbnMgPSBwbHVnaW5PcHRpb25zLmJldHRlckF1dGhPcHRpb25zID8/IHt9XG4gIGNvbnN0IHRhYmxlcyA9IGdldEF1dGhUYWJsZXMoYmV0dGVyQXV0aE9wdGlvbnMpXG5cbiAgY29uc3Qgc2NoZW1hOiBQYXJ0aWFsPEJldHRlckF1dGhTY2hlbWFzPiA9IHt9XG5cbiAgZm9yIChjb25zdCBtb2RlbEtleSBvZiBPYmplY3Qua2V5cyh0YWJsZXMpIGFzIE1vZGVsS2V5W10pIHtcbiAgICBjb25zdCB0YWJsZSA9IHRhYmxlc1ttb2RlbEtleV1cblxuICAgIC8vIFJlc29sdmUgdGhlIGNhbm9uaWNhbCBjb2xsZWN0aW9uIHNsdWcgLyBtb2RlbCBuYW1lIGZvciB0aGlzIGtleVxuICAgIGNvbnN0IHJlc29sdmVkTW9kZWxOYW1lID0gZ2V0RGVmYXVsdENvbGxlY3Rpb25TbHVnKHsgbW9kZWxLZXksIHBsdWdpbk9wdGlvbnMgfSlcblxuICAgIGNvbnN0IGRlZmF1bHRGaWVsZE1hcCA9IChiYU1vZGVsRmllbGRLZXlzVG9GaWVsZE5hbWVzIGFzIFJlY29yZDxzdHJpbmcsIFJlY29yZDxzdHJpbmcsIHN0cmluZz4+KVttb2RlbEtleV0gPz8ge31cblxuICAgIGNvbnN0IGFjdHVhbEZpZWxkczogUmVjb3JkPHN0cmluZywgRmllbGRBdHRyaWJ1dGU+ID0ge31cblxuICAgIE9iamVjdC5lbnRyaWVzKHRhYmxlLmZpZWxkcykuZm9yRWFjaCgoW2ZpZWxkS2V5LCBmaWVsZFZhbHVlXSkgPT4ge1xuICAgICAgLy8gQnVpbGQgdGhlIGZpZWxkIGVuc3VyaW5nIGEgZmllbGROYW1lIGV4aXN0c1xuICAgICAgY29uc3QgbmV3RmllbGQ6IEZpZWxkQXR0cmlidXRlID0ge1xuICAgICAgICAuLi5maWVsZFZhbHVlLFxuICAgICAgICBmaWVsZE5hbWU6IGRlZmF1bHRGaWVsZE1hcFtmaWVsZEtleV0gPz8gZmllbGRLZXlcbiAgICAgIH1cblxuICAgICAgLy8gUmV3cml0ZSByZWZlcmVuY2VzIHRvIHVzZSB0aGUgcmVzb2x2ZWQgbW9kZWxOYW1lIGZvciB0aGUgdGFyZ2V0IHRhYmxlXG4gICAgICBpZiAoZmllbGRWYWx1ZS5yZWZlcmVuY2VzKSB7XG4gICAgICAgIGNvbnN0IHJlZk1vZGVsS2V5ID0gZmllbGRWYWx1ZS5yZWZlcmVuY2VzLm1vZGVsIGFzIHN0cmluZ1xuICAgICAgICBjb25zdCByZXNvbHZlZFJlZk1vZGVsTmFtZSA9IGdldERlZmF1bHRDb2xsZWN0aW9uU2x1Zyh7IG1vZGVsS2V5OiByZWZNb2RlbEtleSwgcGx1Z2luT3B0aW9ucyB9KVxuICAgICAgICBuZXdGaWVsZC5yZWZlcmVuY2VzID0ge1xuICAgICAgICAgIG1vZGVsOiByZXNvbHZlZFJlZk1vZGVsTmFtZSxcbiAgICAgICAgICBmaWVsZDogZmllbGRWYWx1ZS5yZWZlcmVuY2VzLmZpZWxkXG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgYWN0dWFsRmllbGRzW2ZpZWxkS2V5XSA9IG5ld0ZpZWxkXG4gICAgfSlcblxuICAgIGlmIChzY2hlbWFbbW9kZWxLZXldKSB7XG4gICAgICBzY2hlbWFbbW9kZWxLZXldLmZpZWxkcyA9IHtcbiAgICAgICAgLi4uc2NoZW1hW21vZGVsS2V5XS5maWVsZHMsXG4gICAgICAgIC4uLmFjdHVhbEZpZWxkc1xuICAgICAgfVxuICAgICAgY29udGludWVcbiAgICB9XG5cbiAgICBzY2hlbWFbbW9kZWxLZXldID0ge1xuICAgICAgbW9kZWxOYW1lOiByZXNvbHZlZE1vZGVsTmFtZSxcbiAgICAgIGZpZWxkczogYWN0dWFsRmllbGRzLFxuICAgICAgb3JkZXI6IHRhYmxlLm9yZGVyIHx8IEluZmluaXR5XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHNjaGVtYSBhcyBCZXR0ZXJBdXRoU2NoZW1hc1xufVxuIl0sIm5hbWVzIjpbImdldEF1dGhUYWJsZXMiLCJiYU1vZGVsRmllbGRLZXlzVG9GaWVsZE5hbWVzIiwiZ2V0RGVmYXVsdENvbGxlY3Rpb25TbHVnIiwiZ2V0RGVmYXVsdEJldHRlckF1dGhTY2hlbWEiLCJwbHVnaW5PcHRpb25zIiwiYmV0dGVyQXV0aE9wdGlvbnMiLCJ0YWJsZXMiLCJzY2hlbWEiLCJtb2RlbEtleSIsIk9iamVjdCIsImtleXMiLCJ0YWJsZSIsInJlc29sdmVkTW9kZWxOYW1lIiwiZGVmYXVsdEZpZWxkTWFwIiwiYWN0dWFsRmllbGRzIiwiZW50cmllcyIsImZpZWxkcyIsImZvckVhY2giLCJmaWVsZEtleSIsImZpZWxkVmFsdWUiLCJuZXdGaWVsZCIsImZpZWxkTmFtZSIsInJlZmVyZW5jZXMiLCJyZWZNb2RlbEtleSIsIm1vZGVsIiwicmVzb2x2ZWRSZWZNb2RlbE5hbWUiLCJmaWVsZCIsIm1vZGVsTmFtZSIsIm9yZGVyIiwiSW5maW5pdHkiXSwibWFwcGluZ3MiOiJBQUNBLFNBQVNBLGFBQWEsUUFBNkIsaUJBQWdCO0FBQ25FLFNBQVNDLDRCQUE0QixRQUFRLGVBQWM7QUFFM0QsU0FBU0Msd0JBQXdCLFFBQVEsd0JBQXVCO0FBRWhFOzs7Ozs7Ozs7Ozs7Ozs7Q0FlQyxHQUNELE9BQU8sU0FBU0MsMkJBQTJCQyxhQUFzQztJQUMvRSxNQUFNQyxvQkFBb0JELGNBQWNDLGlCQUFpQixJQUFJLENBQUM7SUFDOUQsTUFBTUMsU0FBU04sY0FBY0s7SUFFN0IsTUFBTUUsU0FBcUMsQ0FBQztJQUU1QyxLQUFLLE1BQU1DLFlBQVlDLE9BQU9DLElBQUksQ0FBQ0osUUFBdUI7UUFDeEQsTUFBTUssUUFBUUwsTUFBTSxDQUFDRSxTQUFTO1FBRTlCLGtFQUFrRTtRQUNsRSxNQUFNSSxvQkFBb0JWLHlCQUF5QjtZQUFFTTtZQUFVSjtRQUFjO1FBRTdFLE1BQU1TLGtCQUFrQixBQUFDWiw0QkFBdUUsQ0FBQ08sU0FBUyxJQUFJLENBQUM7UUFFL0csTUFBTU0sZUFBK0MsQ0FBQztRQUV0REwsT0FBT00sT0FBTyxDQUFDSixNQUFNSyxNQUFNLEVBQUVDLE9BQU8sQ0FBQyxDQUFDLENBQUNDLFVBQVVDLFdBQVc7WUFDMUQsOENBQThDO1lBQzlDLE1BQU1DLFdBQTJCO2dCQUMvQixHQUFHRCxVQUFVO2dCQUNiRSxXQUFXUixlQUFlLENBQUNLLFNBQVMsSUFBSUE7WUFDMUM7WUFFQSx3RUFBd0U7WUFDeEUsSUFBSUMsV0FBV0csVUFBVSxFQUFFO2dCQUN6QixNQUFNQyxjQUFjSixXQUFXRyxVQUFVLENBQUNFLEtBQUs7Z0JBQy9DLE1BQU1DLHVCQUF1QnZCLHlCQUF5QjtvQkFBRU0sVUFBVWU7b0JBQWFuQjtnQkFBYztnQkFDN0ZnQixTQUFTRSxVQUFVLEdBQUc7b0JBQ3BCRSxPQUFPQztvQkFDUEMsT0FBT1AsV0FBV0csVUFBVSxDQUFDSSxLQUFLO2dCQUNwQztZQUNGO1lBRUFaLFlBQVksQ0FBQ0ksU0FBUyxHQUFHRTtRQUMzQjtRQUVBLElBQUliLE1BQU0sQ0FBQ0MsU0FBUyxFQUFFO1lBQ3BCRCxNQUFNLENBQUNDLFNBQVMsQ0FBQ1EsTUFBTSxHQUFHO2dCQUN4QixHQUFHVCxNQUFNLENBQUNDLFNBQVMsQ0FBQ1EsTUFBTTtnQkFDMUIsR0FBR0YsWUFBWTtZQUNqQjtZQUNBO1FBQ0Y7UUFFQVAsTUFBTSxDQUFDQyxTQUFTLEdBQUc7WUFDakJtQixXQUFXZjtZQUNYSSxRQUFRRjtZQUNSYyxPQUFPakIsTUFBTWlCLEtBQUssSUFBSUM7UUFDeEI7SUFDRjtJQUVBLE9BQU90QjtBQUNUIn0=
@@ -1,5 +1,5 @@
1
1
  import type { BetterAuthPluginOptions } from '../types';
2
- export declare function getDeafultCollectionSlug({ pluginOptions, modelKey }: {
2
+ export declare function getDefaultCollectionSlug({ pluginOptions, modelKey }: {
3
3
  pluginOptions: BetterAuthPluginOptions;
4
4
  modelKey: string;
5
5
  }): string;
@@ -1,5 +1,5 @@
1
1
  import { baseSlugs, baModelKeyToSlug } from "../constants";
2
- export function getDeafultCollectionSlug({ pluginOptions, modelKey }) {
2
+ export function getDefaultCollectionSlug({ pluginOptions, modelKey }) {
3
3
  const baseSlug = baModelKeyToSlug[modelKey] ?? modelKey;
4
4
  switch(modelKey){
5
5
  case 'user':
@@ -17,4 +17,4 @@ export function getDeafultCollectionSlug({ pluginOptions, modelKey }) {
17
17
  }
18
18
  }
19
19
 
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9nZXQtY29sbGVjdGlvbi1zbHVnLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQmV0dGVyQXV0aFBsdWdpbk9wdGlvbnMgfSBmcm9tICcuLi90eXBlcydcbmltcG9ydCB7IGJhc2VTbHVncywgYmFNb2RlbEtleVRvU2x1ZyB9IGZyb20gJy4uL2NvbnN0YW50cydcblxuZXhwb3J0IGZ1bmN0aW9uIGdldERlYWZ1bHRDb2xsZWN0aW9uU2x1Zyh7XG4gIHBsdWdpbk9wdGlvbnMsXG4gIG1vZGVsS2V5XG59OiB7XG4gIHBsdWdpbk9wdGlvbnM6IEJldHRlckF1dGhQbHVnaW5PcHRpb25zXG4gIG1vZGVsS2V5OiBzdHJpbmdcbn0pOiBzdHJpbmcge1xuICBjb25zdCBiYXNlU2x1ZyA9IGJhTW9kZWxLZXlUb1NsdWdbbW9kZWxLZXkgYXMga2V5b2YgdHlwZW9mIGJhTW9kZWxLZXlUb1NsdWddID8/IG1vZGVsS2V5XG4gIFxuICBzd2l0Y2ggKG1vZGVsS2V5KSB7XG4gICAgY2FzZSAndXNlcic6XG4gICAgICByZXR1cm4gcGx1Z2luT3B0aW9ucy51c2Vycz8uc2x1ZyA/PyBiYXNlU2x1Z3MudXNlcnNcbiAgICBjYXNlICdhY2NvdW50JzpcbiAgICAgIHJldHVybiBwbHVnaW5PcHRpb25zLmFjY291bnRzPy5zbHVnID8/IGJhc2VTbHVncy5hY2NvdW50c1xuICAgIGNhc2UgJ3Nlc3Npb24nOlxuICAgICAgcmV0dXJuIHBsdWdpbk9wdGlvbnMuc2Vzc2lvbnM/LnNsdWcgPz8gYmFzZVNsdWdzLnNlc3Npb25zXG4gICAgY2FzZSAndmVyaWZpY2F0aW9uJzpcbiAgICAgIHJldHVybiBwbHVnaW5PcHRpb25zLnZlcmlmaWNhdGlvbnM/LnNsdWcgPz8gYmFzZVNsdWdzLnZlcmlmaWNhdGlvbnNcbiAgICBjYXNlICdhZG1pbkludml0YXRpb24nOlxuICAgICAgcmV0dXJuIHBsdWdpbk9wdGlvbnMuYWRtaW5JbnZpdGF0aW9ucz8uc2x1ZyA/PyBiYXNlU2x1Z3MuYWRtaW5JbnZpdGF0aW9uc1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gYmFzZVNsdWdcbiAgfVxufSAiXSwibmFtZXMiOlsiYmFzZVNsdWdzIiwiYmFNb2RlbEtleVRvU2x1ZyIsImdldERlYWZ1bHRDb2xsZWN0aW9uU2x1ZyIsInBsdWdpbk9wdGlvbnMiLCJtb2RlbEtleSIsImJhc2VTbHVnIiwidXNlcnMiLCJzbHVnIiwiYWNjb3VudHMiLCJzZXNzaW9ucyIsInZlcmlmaWNhdGlvbnMiLCJhZG1pbkludml0YXRpb25zIl0sIm1hcHBpbmdzIjoiQUFDQSxTQUFTQSxTQUFTLEVBQUVDLGdCQUFnQixRQUFRLGVBQWM7QUFFMUQsT0FBTyxTQUFTQyx5QkFBeUIsRUFDdkNDLGFBQWEsRUFDYkMsUUFBUSxFQUlUO0lBQ0MsTUFBTUMsV0FBV0osZ0JBQWdCLENBQUNHLFNBQTBDLElBQUlBO0lBRWhGLE9BQVFBO1FBQ04sS0FBSztZQUNILE9BQU9ELGNBQWNHLEtBQUssRUFBRUMsUUFBUVAsVUFBVU0sS0FBSztRQUNyRCxLQUFLO1lBQ0gsT0FBT0gsY0FBY0ssUUFBUSxFQUFFRCxRQUFRUCxVQUFVUSxRQUFRO1FBQzNELEtBQUs7WUFDSCxPQUFPTCxjQUFjTSxRQUFRLEVBQUVGLFFBQVFQLFVBQVVTLFFBQVE7UUFDM0QsS0FBSztZQUNILE9BQU9OLGNBQWNPLGFBQWEsRUFBRUgsUUFBUVAsVUFBVVUsYUFBYTtRQUNyRSxLQUFLO1lBQ0gsT0FBT1AsY0FBY1EsZ0JBQWdCLEVBQUVKLFFBQVFQLFVBQVVXLGdCQUFnQjtRQUMzRTtZQUNFLE9BQU9OO0lBQ1g7QUFDRiJ9
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9nZXQtY29sbGVjdGlvbi1zbHVnLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQmV0dGVyQXV0aFBsdWdpbk9wdGlvbnMgfSBmcm9tICcuLi90eXBlcydcbmltcG9ydCB7IGJhc2VTbHVncywgYmFNb2RlbEtleVRvU2x1ZyB9IGZyb20gJy4uL2NvbnN0YW50cydcblxuZXhwb3J0IGZ1bmN0aW9uIGdldERlZmF1bHRDb2xsZWN0aW9uU2x1Zyh7XG4gIHBsdWdpbk9wdGlvbnMsXG4gIG1vZGVsS2V5XG59OiB7XG4gIHBsdWdpbk9wdGlvbnM6IEJldHRlckF1dGhQbHVnaW5PcHRpb25zXG4gIG1vZGVsS2V5OiBzdHJpbmdcbn0pOiBzdHJpbmcge1xuICBjb25zdCBiYXNlU2x1ZyA9IGJhTW9kZWxLZXlUb1NsdWdbbW9kZWxLZXkgYXMga2V5b2YgdHlwZW9mIGJhTW9kZWxLZXlUb1NsdWddID8/IG1vZGVsS2V5XG5cbiAgc3dpdGNoIChtb2RlbEtleSkge1xuICAgIGNhc2UgJ3VzZXInOlxuICAgICAgcmV0dXJuIHBsdWdpbk9wdGlvbnMudXNlcnM/LnNsdWcgPz8gYmFzZVNsdWdzLnVzZXJzXG4gICAgY2FzZSAnYWNjb3VudCc6XG4gICAgICByZXR1cm4gcGx1Z2luT3B0aW9ucy5hY2NvdW50cz8uc2x1ZyA/PyBiYXNlU2x1Z3MuYWNjb3VudHNcbiAgICBjYXNlICdzZXNzaW9uJzpcbiAgICAgIHJldHVybiBwbHVnaW5PcHRpb25zLnNlc3Npb25zPy5zbHVnID8/IGJhc2VTbHVncy5zZXNzaW9uc1xuICAgIGNhc2UgJ3ZlcmlmaWNhdGlvbic6XG4gICAgICByZXR1cm4gcGx1Z2luT3B0aW9ucy52ZXJpZmljYXRpb25zPy5zbHVnID8/IGJhc2VTbHVncy52ZXJpZmljYXRpb25zXG4gICAgY2FzZSAnYWRtaW5JbnZpdGF0aW9uJzpcbiAgICAgIHJldHVybiBwbHVnaW5PcHRpb25zLmFkbWluSW52aXRhdGlvbnM/LnNsdWcgPz8gYmFzZVNsdWdzLmFkbWluSW52aXRhdGlvbnNcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIGJhc2VTbHVnXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJiYXNlU2x1Z3MiLCJiYU1vZGVsS2V5VG9TbHVnIiwiZ2V0RGVmYXVsdENvbGxlY3Rpb25TbHVnIiwicGx1Z2luT3B0aW9ucyIsIm1vZGVsS2V5IiwiYmFzZVNsdWciLCJ1c2VycyIsInNsdWciLCJhY2NvdW50cyIsInNlc3Npb25zIiwidmVyaWZpY2F0aW9ucyIsImFkbWluSW52aXRhdGlvbnMiXSwibWFwcGluZ3MiOiJBQUNBLFNBQVNBLFNBQVMsRUFBRUMsZ0JBQWdCLFFBQVEsZUFBYztBQUUxRCxPQUFPLFNBQVNDLHlCQUF5QixFQUN2Q0MsYUFBYSxFQUNiQyxRQUFRLEVBSVQ7SUFDQyxNQUFNQyxXQUFXSixnQkFBZ0IsQ0FBQ0csU0FBMEMsSUFBSUE7SUFFaEYsT0FBUUE7UUFDTixLQUFLO1lBQ0gsT0FBT0QsY0FBY0csS0FBSyxFQUFFQyxRQUFRUCxVQUFVTSxLQUFLO1FBQ3JELEtBQUs7WUFDSCxPQUFPSCxjQUFjSyxRQUFRLEVBQUVELFFBQVFQLFVBQVVRLFFBQVE7UUFDM0QsS0FBSztZQUNILE9BQU9MLGNBQWNNLFFBQVEsRUFBRUYsUUFBUVAsVUFBVVMsUUFBUTtRQUMzRCxLQUFLO1lBQ0gsT0FBT04sY0FBY08sYUFBYSxFQUFFSCxRQUFRUCxVQUFVVSxhQUFhO1FBQ3JFLEtBQUs7WUFDSCxPQUFPUCxjQUFjUSxnQkFBZ0IsRUFBRUosUUFBUVAsVUFBVVcsZ0JBQWdCO1FBQzNFO1lBQ0UsT0FBT047SUFDWDtBQUNGIn0=
@@ -171,4 +171,4 @@ export function buildApiKeysCollection({ incomingCollections, pluginOptions, res
171
171
  return apiKeyCollection;
172
172
  }
173
173
 
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/api-keys.ts"],"sourcesContent":["import { baModelKey } from '../../constants'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\nimport { getDeafultCollectionSlug } from '../../helpers/get-collection-slug'\nimport { getCollectionFields } from './utils/transform-schema-fields-to-payload'\nimport { assertAllSchemaFields, getSchemaCollectionSlug } from './utils/collection-schema'\n\nimport { type CollectionConfig } from 'payload'\nimport type { Apikey } from '@/better-auth/generated-types'\nimport type { FieldRule } from './utils/model-field-transformations'\nimport type { BuildCollectionProps, FieldOverrides } from '@/better-auth/plugin/types'\n\nexport function buildApiKeysCollection({ incomingCollections, pluginOptions, resolvedSchemas }: BuildCollectionProps): CollectionConfig {\n  const apiKeySlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.apikey)\n  const apiKeySchema = resolvedSchemas[baModelKey.apikey]\n\n  const existingApiKeyCollection = incomingCollections.find((collection) => collection.slug === apiKeySlug) as CollectionConfig | undefined\n\n  const fieldOverrides: FieldOverrides<keyof Apikey> = {\n    name: () => ({\n      admin: { readOnly: true, description: 'The name of the API key.' }\n    }),\n    start: () => ({\n      admin: { readOnly: true, description: 'The starting characters of the API key.' }\n    }),\n    prefix: () => ({\n      admin: { readOnly: true, description: 'The API Key prefix. Stored as plain text.' }\n    }),\n    key: () => ({\n      admin: { readOnly: true, description: 'The hashed API key itself.' }\n    }),\n    userId: () => ({\n      admin: { readOnly: true, description: 'The user associated with the API key.' }\n    }),\n    refillInterval: () => ({\n      admin: { readOnly: true, description: 'The interval to refill the key in milliseconds.' }\n    }),\n    refillAmount: () => ({\n      admin: { readOnly: true, description: 'The amount to refill the remaining count of the key.' }\n    }),\n    lastRefillAt: () => ({\n      admin: { readOnly: true, description: 'The date and time when the key was last refilled.' }\n    }),\n    enabled: () => ({\n      defaultValue: true,\n      admin: { readOnly: true, description: 'Whether the API key is enabled.' }\n    }),\n    rateLimitEnabled: () => ({\n      defaultValue: true,\n      admin: { readOnly: true, description: 'Whether the API key has rate limiting enabled.' }\n    }),\n    rateLimitTimeWindow: () => ({\n      admin: { readOnly: true, description: 'The time window in milliseconds for the rate limit.' }\n    }),\n    rateLimitMax: () => ({\n      admin: { readOnly: true, description: 'The maximum number of requests allowed within the rate limit time window.' }\n    }),\n    requestCount: () => ({\n      admin: { readOnly: true, description: 'The number of requests made within the rate limit time window.' }\n    }),\n    remaining: () => ({\n      admin: { readOnly: true, description: 'The number of requests remaining.' }\n    }),\n    lastRequest: () => ({\n      admin: { readOnly: true, description: 'The date and time of the last request made to the key.' }\n    }),\n    expiresAt: () => ({\n      admin: { readOnly: true, description: 'The date and time of when the API key will expire.' }\n    }),\n    permissions: () => ({\n      admin: { readOnly: true, description: 'The permissions for the API key.' }\n    }),\n    metadata: () => ({\n      type: 'json',\n      admin: { readOnly: true, description: 'Any additional metadata you want to store with the key.' }\n    })\n  }\n\n  const apiKeyFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.type === 'date',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => t('general:updatedAt')\n      })\n    }\n  ]\n\n  const collectionFields = getCollectionFields({\n    schema: apiKeySchema,\n    fieldRules: apiKeyFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let apiKeyCollection: CollectionConfig = {\n    ...existingApiKeyCollection,\n    slug: apiKeySlug,\n    admin: {\n      hidden: pluginOptions.hidePluginCollections ?? false,\n      useAsTitle: apiKeySchema?.fields?.name?.fieldName,\n      description: 'API keys are used to authenticate requests to the API.',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingApiKeyCollection?.admin\n    },\n    access: {\n      ...getAdminAccess(pluginOptions),\n      ...(existingApiKeyCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingApiKeyCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.apikey\n    },\n    fields: [...(existingApiKeyCollection?.fields ?? []), ...(collectionFields ?? [])]\n  }\n\n  if (typeof pluginOptions.pluginCollectionOverrides?.apiKeys === 'function') {\n    apiKeyCollection = pluginOptions.pluginCollectionOverrides.apiKeys({\n      collection: apiKeyCollection\n    })\n  }\n\n  assertAllSchemaFields(apiKeyCollection, apiKeySchema)\n\n  return apiKeyCollection\n}\n"],"names":["baModelKey","getAdminAccess","getCollectionFields","assertAllSchemaFields","getSchemaCollectionSlug","buildApiKeysCollection","incomingCollections","pluginOptions","resolvedSchemas","apiKeySlug","apikey","apiKeySchema","existingApiKeyCollection","find","collection","slug","fieldOverrides","name","admin","readOnly","description","start","prefix","key","userId","refillInterval","refillAmount","lastRefillAt","enabled","defaultValue","rateLimitEnabled","rateLimitTimeWindow","rateLimitMax","requestCount","remaining","lastRequest","expiresAt","permissions","metadata","type","apiKeyFieldRules","condition","field","transform","saveToJWT","disableBulkEdit","hidden","index","label","t","collectionFields","schema","fieldRules","additionalProperties","apiKeyCollection","hidePluginCollections","useAsTitle","fields","fieldName","group","collectionAdminGroup","access","custom","betterAuthModelKey","pluginCollectionOverrides","apiKeys"],"mappings":"AAAA,SAASA,UAAU,QAAQ,kBAAiB;AAC5C,SAASC,cAAc,QAAQ,iCAAgC;AAE/D,SAASC,mBAAmB,QAAQ,6CAA4C;AAChF,SAASC,qBAAqB,EAAEC,uBAAuB,QAAQ,4BAA2B;AAO1F,OAAO,SAASC,uBAAuB,EAAEC,mBAAmB,EAAEC,aAAa,EAAEC,eAAe,EAAwB;IAClH,MAAMC,aAAaL,wBAAwBI,iBAAiBR,WAAWU,MAAM;IAC7E,MAAMC,eAAeH,eAAe,CAACR,WAAWU,MAAM,CAAC;IAEvD,MAAME,2BAA2BN,oBAAoBO,IAAI,CAAC,CAACC,aAAeA,WAAWC,IAAI,KAAKN;IAE9F,MAAMO,iBAA+C;QACnDC,MAAM,IAAO,CAAA;gBACXC,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA2B;YACnE,CAAA;QACAC,OAAO,IAAO,CAAA;gBACZH,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA0C;YAClF,CAAA;QACAE,QAAQ,IAAO,CAAA;gBACbJ,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA4C;YACpF,CAAA;QACAG,KAAK,IAAO,CAAA;gBACVL,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA6B;YACrE,CAAA;QACAI,QAAQ,IAAO,CAAA;gBACbN,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAwC;YAChF,CAAA;QACAK,gBAAgB,IAAO,CAAA;gBACrBP,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAkD;YAC1F,CAAA;QACAM,cAAc,IAAO,CAAA;gBACnBR,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAuD;YAC/F,CAAA;QACAO,cAAc,IAAO,CAAA;gBACnBT,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAoD;YAC5F,CAAA;QACAQ,SAAS,IAAO,CAAA;gBACdC,cAAc;gBACdX,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAkC;YAC1E,CAAA;QACAU,kBAAkB,IAAO,CAAA;gBACvBD,cAAc;gBACdX,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAiD;YACzF,CAAA;QACAW,qBAAqB,IAAO,CAAA;gBAC1Bb,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAsD;YAC9F,CAAA;QACAY,cAAc,IAAO,CAAA;gBACnBd,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA4E;YACpH,CAAA;QACAa,cAAc,IAAO,CAAA;gBACnBf,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAiE;YACzG,CAAA;QACAc,WAAW,IAAO,CAAA;gBAChBhB,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAoC;YAC5E,CAAA;QACAe,aAAa,IAAO,CAAA;gBAClBjB,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAyD;YACjG,CAAA;QACAgB,WAAW,IAAO,CAAA;gBAChBlB,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAqD;YAC7F,CAAA;QACAiB,aAAa,IAAO,CAAA;gBAClBnB,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAmC;YAC3E,CAAA;QACAkB,UAAU,IAAO,CAAA;gBACfC,MAAM;gBACNrB,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA0D;YAClG,CAAA;IACF;IAEA,MAAMoB,mBAAgC;QACpC;YACEC,WAAW,CAACC,QAAUA,MAAMH,IAAI,KAAK;YACrCI,WAAW,CAACD,QAAW,CAAA;oBACrB,GAAGA,KAAK;oBACRE,WAAW;oBACX1B,OAAO;wBACL2B,iBAAiB;wBACjBC,QAAQ;oBACV;oBACAC,OAAO;oBACPC,OAAO,CAAC,EAAEC,CAAC,EAAO,GAAKA,EAAE;gBAC3B,CAAA;QACF;KACD;IAED,MAAMC,mBAAmBhD,oBAAoB;QAC3CiD,QAAQxC;QACRyC,YAAYZ;QACZa,sBAAsBrC;IACxB;IAEA,IAAIsC,mBAAqC;QACvC,GAAG1C,wBAAwB;QAC3BG,MAAMN;QACNS,OAAO;YACL4B,QAAQvC,cAAcgD,qBAAqB,IAAI;YAC/CC,YAAY7C,cAAc8C,QAAQxC,MAAMyC;YACxCtC,aAAa;YACbuC,OAAOpD,eAAeqD,wBAAwB;YAC9C,GAAGhD,0BAA0BM,KAAK;QACpC;QACA2C,QAAQ;YACN,GAAG5D,eAAeM,cAAc;YAChC,GAAIK,0BAA0BiD,UAAU,CAAC,CAAC;QAC5C;QACAC,QAAQ;YACN,GAAIlD,0BAA0BkD,UAAU,CAAC,CAAC;YAC1CC,oBAAoB/D,WAAWU,MAAM;QACvC;QACA+C,QAAQ;eAAK7C,0BAA0B6C,UAAU,EAAE;eAAOP,oBAAoB,EAAE;SAAE;IACpF;IAEA,IAAI,OAAO3C,cAAcyD,yBAAyB,EAAEC,YAAY,YAAY;QAC1EX,mBAAmB/C,cAAcyD,yBAAyB,CAACC,OAAO,CAAC;YACjEnD,YAAYwC;QACd;IACF;IAEAnD,sBAAsBmD,kBAAkB3C;IAExC,OAAO2C;AACT"}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/api-keys.ts"],"sourcesContent":["import { baModelKey } from '../../constants'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\nimport { getDefaultCollectionSlug } from '../../helpers/get-collection-slug'\nimport { getCollectionFields } from './utils/transform-schema-fields-to-payload'\nimport { assertAllSchemaFields, getSchemaCollectionSlug } from './utils/collection-schema'\n\nimport { type CollectionConfig } from 'payload'\nimport type { Apikey } from '@/better-auth/generated-types'\nimport type { FieldRule } from './utils/model-field-transformations'\nimport type { BuildCollectionProps, FieldOverrides } from '@/better-auth/plugin/types'\n\nexport function buildApiKeysCollection({ incomingCollections, pluginOptions, resolvedSchemas }: BuildCollectionProps): CollectionConfig {\n  const apiKeySlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.apikey)\n  const apiKeySchema = resolvedSchemas[baModelKey.apikey]\n\n  const existingApiKeyCollection = incomingCollections.find((collection) => collection.slug === apiKeySlug) as CollectionConfig | undefined\n\n  const fieldOverrides: FieldOverrides<keyof Apikey> = {\n    name: () => ({\n      admin: { readOnly: true, description: 'The name of the API key.' }\n    }),\n    start: () => ({\n      admin: { readOnly: true, description: 'The starting characters of the API key.' }\n    }),\n    prefix: () => ({\n      admin: { readOnly: true, description: 'The API Key prefix. Stored as plain text.' }\n    }),\n    key: () => ({\n      admin: { readOnly: true, description: 'The hashed API key itself.' }\n    }),\n    userId: () => ({\n      admin: { readOnly: true, description: 'The user associated with the API key.' }\n    }),\n    refillInterval: () => ({\n      admin: { readOnly: true, description: 'The interval to refill the key in milliseconds.' }\n    }),\n    refillAmount: () => ({\n      admin: { readOnly: true, description: 'The amount to refill the remaining count of the key.' }\n    }),\n    lastRefillAt: () => ({\n      admin: { readOnly: true, description: 'The date and time when the key was last refilled.' }\n    }),\n    enabled: () => ({\n      defaultValue: true,\n      admin: { readOnly: true, description: 'Whether the API key is enabled.' }\n    }),\n    rateLimitEnabled: () => ({\n      defaultValue: true,\n      admin: { readOnly: true, description: 'Whether the API key has rate limiting enabled.' }\n    }),\n    rateLimitTimeWindow: () => ({\n      admin: { readOnly: true, description: 'The time window in milliseconds for the rate limit.' }\n    }),\n    rateLimitMax: () => ({\n      admin: { readOnly: true, description: 'The maximum number of requests allowed within the rate limit time window.' }\n    }),\n    requestCount: () => ({\n      admin: { readOnly: true, description: 'The number of requests made within the rate limit time window.' }\n    }),\n    remaining: () => ({\n      admin: { readOnly: true, description: 'The number of requests remaining.' }\n    }),\n    lastRequest: () => ({\n      admin: { readOnly: true, description: 'The date and time of the last request made to the key.' }\n    }),\n    expiresAt: () => ({\n      admin: { readOnly: true, description: 'The date and time of when the API key will expire.' }\n    }),\n    permissions: () => ({\n      admin: { readOnly: true, description: 'The permissions for the API key.' }\n    }),\n    metadata: () => ({\n      type: 'json',\n      admin: { readOnly: true, description: 'Any additional metadata you want to store with the key.' }\n    })\n  }\n\n  const apiKeyFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.type === 'date',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => t('general:updatedAt')\n      })\n    }\n  ]\n\n  const collectionFields = getCollectionFields({\n    schema: apiKeySchema,\n    fieldRules: apiKeyFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let apiKeyCollection: CollectionConfig = {\n    ...existingApiKeyCollection,\n    slug: apiKeySlug,\n    admin: {\n      hidden: pluginOptions.hidePluginCollections ?? false,\n      useAsTitle: apiKeySchema?.fields?.name?.fieldName,\n      description: 'API keys are used to authenticate requests to the API.',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingApiKeyCollection?.admin\n    },\n    access: {\n      ...getAdminAccess(pluginOptions),\n      ...(existingApiKeyCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingApiKeyCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.apikey\n    },\n    fields: [...(existingApiKeyCollection?.fields ?? []), ...(collectionFields ?? [])]\n  }\n\n  if (typeof pluginOptions.pluginCollectionOverrides?.apiKeys === 'function') {\n    apiKeyCollection = pluginOptions.pluginCollectionOverrides.apiKeys({\n      collection: apiKeyCollection\n    })\n  }\n\n  assertAllSchemaFields(apiKeyCollection, apiKeySchema)\n\n  return apiKeyCollection\n}\n"],"names":["baModelKey","getAdminAccess","getCollectionFields","assertAllSchemaFields","getSchemaCollectionSlug","buildApiKeysCollection","incomingCollections","pluginOptions","resolvedSchemas","apiKeySlug","apikey","apiKeySchema","existingApiKeyCollection","find","collection","slug","fieldOverrides","name","admin","readOnly","description","start","prefix","key","userId","refillInterval","refillAmount","lastRefillAt","enabled","defaultValue","rateLimitEnabled","rateLimitTimeWindow","rateLimitMax","requestCount","remaining","lastRequest","expiresAt","permissions","metadata","type","apiKeyFieldRules","condition","field","transform","saveToJWT","disableBulkEdit","hidden","index","label","t","collectionFields","schema","fieldRules","additionalProperties","apiKeyCollection","hidePluginCollections","useAsTitle","fields","fieldName","group","collectionAdminGroup","access","custom","betterAuthModelKey","pluginCollectionOverrides","apiKeys"],"mappings":"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"}
@@ -55,4 +55,4 @@ export function buildJwksCollection({ incomingCollections, pluginOptions, resolv
55
55
  return jwksCollection;
56
56
  }
57
57
 
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL2p3a3MudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYmFNb2RlbEtleSB9IGZyb20gJy4uLy4uL2NvbnN0YW50cydcbmltcG9ydCB7IGdldEFkbWluQWNjZXNzIH0gZnJvbSAnLi4vLi4vaGVscGVycy9nZXQtYWRtaW4tYWNjZXNzJ1xuaW1wb3J0IHsgZ2V0Q29sbGVjdGlvbkZpZWxkcyB9IGZyb20gJy4vdXRpbHMvdHJhbnNmb3JtLXNjaGVtYS1maWVsZHMtdG8tcGF5bG9hZCdcbmltcG9ydCB7IGdldERlYWZ1bHRDb2xsZWN0aW9uU2x1ZyB9IGZyb20gJy4uLy4uL2hlbHBlcnMvZ2V0LWNvbGxlY3Rpb24tc2x1ZydcbmltcG9ydCB7IGFzc2VydEFsbFNjaGVtYUZpZWxkcywgZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWcsIGdldFNjaGVtYUZpZWxkTmFtZSB9IGZyb20gJy4vdXRpbHMvY29sbGVjdGlvbi1zY2hlbWEnXG5cbmltcG9ydCB0eXBlIHsgQ29sbGVjdGlvbkNvbmZpZyB9IGZyb20gJ3BheWxvYWQnXG5pbXBvcnQgdHlwZSB7IEp3a3MgfSBmcm9tICdAL2JldHRlci1hdXRoL2dlbmVyYXRlZC10eXBlcydcbmltcG9ydCB0eXBlIHsgQnVpbGRDb2xsZWN0aW9uUHJvcHMsIEZpZWxkT3ZlcnJpZGVzIH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9wbHVnaW4vdHlwZXMnXG5cbmV4cG9ydCBmdW5jdGlvbiBidWlsZEp3a3NDb2xsZWN0aW9uKHsgaW5jb21pbmdDb2xsZWN0aW9ucywgcGx1Z2luT3B0aW9ucywgcmVzb2x2ZWRTY2hlbWFzIH06IEJ1aWxkQ29sbGVjdGlvblByb3BzKTogQ29sbGVjdGlvbkNvbmZpZyB7XG4gIGNvbnN0IGp3a3NTbHVnID0gZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWcocmVzb2x2ZWRTY2hlbWFzLCBiYU1vZGVsS2V5Lmp3a3MpXG4gIGNvbnN0IGp3a3NTY2hlbWEgPSByZXNvbHZlZFNjaGVtYXNbYmFNb2RlbEtleS5qd2tzXVxuXG4gIGNvbnN0IGV4aXN0aW5nSndrc0NvbGxlY3Rpb24gPSBpbmNvbWluZ0NvbGxlY3Rpb25zLmZpbmQoKGNvbGxlY3Rpb24pID0+IGNvbGxlY3Rpb24uc2x1ZyA9PT0gandrc1NsdWcpIGFzIENvbGxlY3Rpb25Db25maWcgfCB1bmRlZmluZWRcblxuICBjb25zdCBmaWVsZE92ZXJyaWRlczogRmllbGRPdmVycmlkZXM8a2V5b2YgSndrcz4gPSB7XG4gICAgcHVibGljS2V5OiAoKSA9PiAoe1xuICAgICAgaW5kZXg6IHRydWUsXG4gICAgICBhZG1pbjogeyBkZXNjcmlwdGlvbjogJ1RoZSBwdWJsaWMgcGFydCBvZiB0aGUgd2ViIGtleScgfVxuICAgIH0pLFxuICAgIHByaXZhdGVLZXk6ICgpID0+ICh7XG4gICAgICBhZG1pbjogeyBkZXNjcmlwdGlvbjogJ1RoZSBwcml2YXRlIHBhcnQgb2YgdGhlIHdlYiBrZXknIH1cbiAgICB9KVxuICB9XG5cbiAgY29uc3QgY29sbGVjdGlvbkZpZWxkcyA9IGdldENvbGxlY3Rpb25GaWVsZHMoe1xuICAgIHNjaGVtYTogandrc1NjaGVtYSxcbiAgICBhZGRpdGlvbmFsUHJvcGVydGllczogZmllbGRPdmVycmlkZXNcbiAgfSlcblxuICBsZXQgandrc0NvbGxlY3Rpb246IENvbGxlY3Rpb25Db25maWcgPSB7XG4gICAgLi4uZXhpc3RpbmdKd2tzQ29sbGVjdGlvbixcbiAgICBzbHVnOiBqd2tzU2x1ZyxcbiAgICBhZG1pbjoge1xuICAgICAgaGlkZGVuOiBwbHVnaW5PcHRpb25zLmhpZGVQbHVnaW5Db2xsZWN0aW9ucyA/PyBmYWxzZSxcbiAgICAgIHVzZUFzVGl0bGU6IGdldFNjaGVtYUZpZWxkTmFtZShyZXNvbHZlZFNjaGVtYXMsIGJhTW9kZWxLZXkuandrcywgJ3B1YmxpY0tleScpLFxuICAgICAgZGVzY3JpcHRpb246ICdKV0tTIGFyZSB1c2VkIHRvIHZlcmlmeSB0aGUgc2lnbmF0dXJlIG9mIHRoZSBKV1QgdG9rZW4nLFxuICAgICAgZ3JvdXA6IHBsdWdpbk9wdGlvbnM/LmNvbGxlY3Rpb25BZG1pbkdyb3VwID8/ICdBdXRoJyxcbiAgICAgIC4uLmV4aXN0aW5nSndrc0NvbGxlY3Rpb24/LmFkbWluXG4gICAgfSxcbiAgICBhY2Nlc3M6IHtcbiAgICAgIC4uLmdldEFkbWluQWNjZXNzKHBsdWdpbk9wdGlvbnMpLFxuICAgICAgLi4uKGV4aXN0aW5nSndrc0NvbGxlY3Rpb24/LmFjY2VzcyA/PyB7fSlcbiAgICB9LFxuICAgIGN1c3RvbToge1xuICAgICAgLi4uKGV4aXN0aW5nSndrc0NvbGxlY3Rpb24/LmN1c3RvbSA/PyB7fSksXG4gICAgICBiZXR0ZXJBdXRoTW9kZWxLZXk6IGJhTW9kZWxLZXkuandrc1xuICAgIH0sXG4gICAgZmllbGRzOiBbLi4uKGV4aXN0aW5nSndrc0NvbGxlY3Rpb24/LmZpZWxkcyA/PyBbXSksIC4uLihjb2xsZWN0aW9uRmllbGRzID8/IFtdKV1cbiAgfVxuXG4gIGlmICh0eXBlb2YgcGx1Z2luT3B0aW9ucy5wbHVnaW5Db2xsZWN0aW9uT3ZlcnJpZGVzPy5qd2tzID09PSAnZnVuY3Rpb24nKSB7XG4gICAgandrc0NvbGxlY3Rpb24gPSBwbHVnaW5PcHRpb25zLnBsdWdpbkNvbGxlY3Rpb25PdmVycmlkZXMuandrcyh7XG4gICAgICBjb2xsZWN0aW9uOiBqd2tzQ29sbGVjdGlvblxuICAgIH0pXG4gIH1cblxuICBhc3NlcnRBbGxTY2hlbWFGaWVsZHMoandrc0NvbGxlY3Rpb24sIGp3a3NTY2hlbWEpXG5cbiAgcmV0dXJuIGp3a3NDb2xsZWN0aW9uXG59XG4iXSwibmFtZXMiOlsiYmFNb2RlbEtleSIsImdldEFkbWluQWNjZXNzIiwiZ2V0Q29sbGVjdGlvbkZpZWxkcyIsImFzc2VydEFsbFNjaGVtYUZpZWxkcyIsImdldFNjaGVtYUNvbGxlY3Rpb25TbHVnIiwiZ2V0U2NoZW1hRmllbGROYW1lIiwiYnVpbGRKd2tzQ29sbGVjdGlvbiIsImluY29taW5nQ29sbGVjdGlvbnMiLCJwbHVnaW5PcHRpb25zIiwicmVzb2x2ZWRTY2hlbWFzIiwiandrc1NsdWciLCJqd2tzIiwiandrc1NjaGVtYSIsImV4aXN0aW5nSndrc0NvbGxlY3Rpb24iLCJmaW5kIiwiY29sbGVjdGlvbiIsInNsdWciLCJmaWVsZE92ZXJyaWRlcyIsInB1YmxpY0tleSIsImluZGV4IiwiYWRtaW4iLCJkZXNjcmlwdGlvbiIsInByaXZhdGVLZXkiLCJjb2xsZWN0aW9uRmllbGRzIiwic2NoZW1hIiwiYWRkaXRpb25hbFByb3BlcnRpZXMiLCJqd2tzQ29sbGVjdGlvbiIsImhpZGRlbiIsImhpZGVQbHVnaW5Db2xsZWN0aW9ucyIsInVzZUFzVGl0bGUiLCJncm91cCIsImNvbGxlY3Rpb25BZG1pbkdyb3VwIiwiYWNjZXNzIiwiY3VzdG9tIiwiYmV0dGVyQXV0aE1vZGVsS2V5IiwiZmllbGRzIiwicGx1Z2luQ29sbGVjdGlvbk92ZXJyaWRlcyJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsVUFBVSxRQUFRLGtCQUFpQjtBQUM1QyxTQUFTQyxjQUFjLFFBQVEsaUNBQWdDO0FBQy9ELFNBQVNDLG1CQUFtQixRQUFRLDZDQUE0QztBQUVoRixTQUFTQyxxQkFBcUIsRUFBRUMsdUJBQXVCLEVBQUVDLGtCQUFrQixRQUFRLDRCQUEyQjtBQU05RyxPQUFPLFNBQVNDLG9CQUFvQixFQUFFQyxtQkFBbUIsRUFBRUMsYUFBYSxFQUFFQyxlQUFlLEVBQXdCO0lBQy9HLE1BQU1DLFdBQVdOLHdCQUF3QkssaUJBQWlCVCxXQUFXVyxJQUFJO0lBQ3pFLE1BQU1DLGFBQWFILGVBQWUsQ0FBQ1QsV0FBV1csSUFBSSxDQUFDO0lBRW5ELE1BQU1FLHlCQUF5Qk4sb0JBQW9CTyxJQUFJLENBQUMsQ0FBQ0MsYUFBZUEsV0FBV0MsSUFBSSxLQUFLTjtJQUU1RixNQUFNTyxpQkFBNkM7UUFDakRDLFdBQVcsSUFBTyxDQUFBO2dCQUNoQkMsT0FBTztnQkFDUEMsT0FBTztvQkFBRUMsYUFBYTtnQkFBaUM7WUFDekQsQ0FBQTtRQUNBQyxZQUFZLElBQU8sQ0FBQTtnQkFDakJGLE9BQU87b0JBQUVDLGFBQWE7Z0JBQWtDO1lBQzFELENBQUE7SUFDRjtJQUVBLE1BQU1FLG1CQUFtQnJCLG9CQUFvQjtRQUMzQ3NCLFFBQVFaO1FBQ1JhLHNCQUFzQlI7SUFDeEI7SUFFQSxJQUFJUyxpQkFBbUM7UUFDckMsR0FBR2Isc0JBQXNCO1FBQ3pCRyxNQUFNTjtRQUNOVSxPQUFPO1lBQ0xPLFFBQVFuQixjQUFjb0IscUJBQXFCLElBQUk7WUFDL0NDLFlBQVl4QixtQkFBbUJJLGlCQUFpQlQsV0FBV1csSUFBSSxFQUFFO1lBQ2pFVSxhQUFhO1lBQ2JTLE9BQU90QixlQUFldUIsd0JBQXdCO1lBQzlDLEdBQUdsQix3QkFBd0JPLEtBQUs7UUFDbEM7UUFDQVksUUFBUTtZQUNOLEdBQUcvQixlQUFlTyxjQUFjO1lBQ2hDLEdBQUlLLHdCQUF3Qm1CLFVBQVUsQ0FBQyxDQUFDO1FBQzFDO1FBQ0FDLFFBQVE7WUFDTixHQUFJcEIsd0JBQXdCb0IsVUFBVSxDQUFDLENBQUM7WUFDeENDLG9CQUFvQmxDLFdBQVdXLElBQUk7UUFDckM7UUFDQXdCLFFBQVE7ZUFBS3RCLHdCQUF3QnNCLFVBQVUsRUFBRTtlQUFPWixvQkFBb0IsRUFBRTtTQUFFO0lBQ2xGO0lBRUEsSUFBSSxPQUFPZixjQUFjNEIseUJBQXlCLEVBQUV6QixTQUFTLFlBQVk7UUFDdkVlLGlCQUFpQmxCLGNBQWM0Qix5QkFBeUIsQ0FBQ3pCLElBQUksQ0FBQztZQUM1REksWUFBWVc7UUFDZDtJQUNGO0lBRUF2QixzQkFBc0J1QixnQkFBZ0JkO0lBRXRDLE9BQU9jO0FBQ1QifQ==
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL2p3a3MudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYmFNb2RlbEtleSB9IGZyb20gJy4uLy4uL2NvbnN0YW50cydcbmltcG9ydCB7IGdldEFkbWluQWNjZXNzIH0gZnJvbSAnLi4vLi4vaGVscGVycy9nZXQtYWRtaW4tYWNjZXNzJ1xuaW1wb3J0IHsgZ2V0Q29sbGVjdGlvbkZpZWxkcyB9IGZyb20gJy4vdXRpbHMvdHJhbnNmb3JtLXNjaGVtYS1maWVsZHMtdG8tcGF5bG9hZCdcbmltcG9ydCB7IGdldERlZmF1bHRDb2xsZWN0aW9uU2x1ZyB9IGZyb20gJy4uLy4uL2hlbHBlcnMvZ2V0LWNvbGxlY3Rpb24tc2x1ZydcbmltcG9ydCB7IGFzc2VydEFsbFNjaGVtYUZpZWxkcywgZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWcsIGdldFNjaGVtYUZpZWxkTmFtZSB9IGZyb20gJy4vdXRpbHMvY29sbGVjdGlvbi1zY2hlbWEnXG5cbmltcG9ydCB0eXBlIHsgQ29sbGVjdGlvbkNvbmZpZyB9IGZyb20gJ3BheWxvYWQnXG5pbXBvcnQgdHlwZSB7IEp3a3MgfSBmcm9tICdAL2JldHRlci1hdXRoL2dlbmVyYXRlZC10eXBlcydcbmltcG9ydCB0eXBlIHsgQnVpbGRDb2xsZWN0aW9uUHJvcHMsIEZpZWxkT3ZlcnJpZGVzIH0gZnJvbSAnQC9iZXR0ZXItYXV0aC9wbHVnaW4vdHlwZXMnXG5cbmV4cG9ydCBmdW5jdGlvbiBidWlsZEp3a3NDb2xsZWN0aW9uKHsgaW5jb21pbmdDb2xsZWN0aW9ucywgcGx1Z2luT3B0aW9ucywgcmVzb2x2ZWRTY2hlbWFzIH06IEJ1aWxkQ29sbGVjdGlvblByb3BzKTogQ29sbGVjdGlvbkNvbmZpZyB7XG4gIGNvbnN0IGp3a3NTbHVnID0gZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWcocmVzb2x2ZWRTY2hlbWFzLCBiYU1vZGVsS2V5Lmp3a3MpXG4gIGNvbnN0IGp3a3NTY2hlbWEgPSByZXNvbHZlZFNjaGVtYXNbYmFNb2RlbEtleS5qd2tzXVxuXG4gIGNvbnN0IGV4aXN0aW5nSndrc0NvbGxlY3Rpb24gPSBpbmNvbWluZ0NvbGxlY3Rpb25zLmZpbmQoKGNvbGxlY3Rpb24pID0+IGNvbGxlY3Rpb24uc2x1ZyA9PT0gandrc1NsdWcpIGFzIENvbGxlY3Rpb25Db25maWcgfCB1bmRlZmluZWRcblxuICBjb25zdCBmaWVsZE92ZXJyaWRlczogRmllbGRPdmVycmlkZXM8a2V5b2YgSndrcz4gPSB7XG4gICAgcHVibGljS2V5OiAoKSA9PiAoe1xuICAgICAgaW5kZXg6IHRydWUsXG4gICAgICBhZG1pbjogeyBkZXNjcmlwdGlvbjogJ1RoZSBwdWJsaWMgcGFydCBvZiB0aGUgd2ViIGtleScgfVxuICAgIH0pLFxuICAgIHByaXZhdGVLZXk6ICgpID0+ICh7XG4gICAgICBhZG1pbjogeyBkZXNjcmlwdGlvbjogJ1RoZSBwcml2YXRlIHBhcnQgb2YgdGhlIHdlYiBrZXknIH1cbiAgICB9KVxuICB9XG5cbiAgY29uc3QgY29sbGVjdGlvbkZpZWxkcyA9IGdldENvbGxlY3Rpb25GaWVsZHMoe1xuICAgIHNjaGVtYTogandrc1NjaGVtYSxcbiAgICBhZGRpdGlvbmFsUHJvcGVydGllczogZmllbGRPdmVycmlkZXNcbiAgfSlcblxuICBsZXQgandrc0NvbGxlY3Rpb246IENvbGxlY3Rpb25Db25maWcgPSB7XG4gICAgLi4uZXhpc3RpbmdKd2tzQ29sbGVjdGlvbixcbiAgICBzbHVnOiBqd2tzU2x1ZyxcbiAgICBhZG1pbjoge1xuICAgICAgaGlkZGVuOiBwbHVnaW5PcHRpb25zLmhpZGVQbHVnaW5Db2xsZWN0aW9ucyA/PyBmYWxzZSxcbiAgICAgIHVzZUFzVGl0bGU6IGdldFNjaGVtYUZpZWxkTmFtZShyZXNvbHZlZFNjaGVtYXMsIGJhTW9kZWxLZXkuandrcywgJ3B1YmxpY0tleScpLFxuICAgICAgZGVzY3JpcHRpb246ICdKV0tTIGFyZSB1c2VkIHRvIHZlcmlmeSB0aGUgc2lnbmF0dXJlIG9mIHRoZSBKV1QgdG9rZW4nLFxuICAgICAgZ3JvdXA6IHBsdWdpbk9wdGlvbnM/LmNvbGxlY3Rpb25BZG1pbkdyb3VwID8/ICdBdXRoJyxcbiAgICAgIC4uLmV4aXN0aW5nSndrc0NvbGxlY3Rpb24/LmFkbWluXG4gICAgfSxcbiAgICBhY2Nlc3M6IHtcbiAgICAgIC4uLmdldEFkbWluQWNjZXNzKHBsdWdpbk9wdGlvbnMpLFxuICAgICAgLi4uKGV4aXN0aW5nSndrc0NvbGxlY3Rpb24/LmFjY2VzcyA/PyB7fSlcbiAgICB9LFxuICAgIGN1c3RvbToge1xuICAgICAgLi4uKGV4aXN0aW5nSndrc0NvbGxlY3Rpb24/LmN1c3RvbSA/PyB7fSksXG4gICAgICBiZXR0ZXJBdXRoTW9kZWxLZXk6IGJhTW9kZWxLZXkuandrc1xuICAgIH0sXG4gICAgZmllbGRzOiBbLi4uKGV4aXN0aW5nSndrc0NvbGxlY3Rpb24/LmZpZWxkcyA/PyBbXSksIC4uLihjb2xsZWN0aW9uRmllbGRzID8/IFtdKV1cbiAgfVxuXG4gIGlmICh0eXBlb2YgcGx1Z2luT3B0aW9ucy5wbHVnaW5Db2xsZWN0aW9uT3ZlcnJpZGVzPy5qd2tzID09PSAnZnVuY3Rpb24nKSB7XG4gICAgandrc0NvbGxlY3Rpb24gPSBwbHVnaW5PcHRpb25zLnBsdWdpbkNvbGxlY3Rpb25PdmVycmlkZXMuandrcyh7XG4gICAgICBjb2xsZWN0aW9uOiBqd2tzQ29sbGVjdGlvblxuICAgIH0pXG4gIH1cblxuICBhc3NlcnRBbGxTY2hlbWFGaWVsZHMoandrc0NvbGxlY3Rpb24sIGp3a3NTY2hlbWEpXG5cbiAgcmV0dXJuIGp3a3NDb2xsZWN0aW9uXG59XG4iXSwibmFtZXMiOlsiYmFNb2RlbEtleSIsImdldEFkbWluQWNjZXNzIiwiZ2V0Q29sbGVjdGlvbkZpZWxkcyIsImFzc2VydEFsbFNjaGVtYUZpZWxkcyIsImdldFNjaGVtYUNvbGxlY3Rpb25TbHVnIiwiZ2V0U2NoZW1hRmllbGROYW1lIiwiYnVpbGRKd2tzQ29sbGVjdGlvbiIsImluY29taW5nQ29sbGVjdGlvbnMiLCJwbHVnaW5PcHRpb25zIiwicmVzb2x2ZWRTY2hlbWFzIiwiandrc1NsdWciLCJqd2tzIiwiandrc1NjaGVtYSIsImV4aXN0aW5nSndrc0NvbGxlY3Rpb24iLCJmaW5kIiwiY29sbGVjdGlvbiIsInNsdWciLCJmaWVsZE92ZXJyaWRlcyIsInB1YmxpY0tleSIsImluZGV4IiwiYWRtaW4iLCJkZXNjcmlwdGlvbiIsInByaXZhdGVLZXkiLCJjb2xsZWN0aW9uRmllbGRzIiwic2NoZW1hIiwiYWRkaXRpb25hbFByb3BlcnRpZXMiLCJqd2tzQ29sbGVjdGlvbiIsImhpZGRlbiIsImhpZGVQbHVnaW5Db2xsZWN0aW9ucyIsInVzZUFzVGl0bGUiLCJncm91cCIsImNvbGxlY3Rpb25BZG1pbkdyb3VwIiwiYWNjZXNzIiwiY3VzdG9tIiwiYmV0dGVyQXV0aE1vZGVsS2V5IiwiZmllbGRzIiwicGx1Z2luQ29sbGVjdGlvbk92ZXJyaWRlcyJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsVUFBVSxRQUFRLGtCQUFpQjtBQUM1QyxTQUFTQyxjQUFjLFFBQVEsaUNBQWdDO0FBQy9ELFNBQVNDLG1CQUFtQixRQUFRLDZDQUE0QztBQUVoRixTQUFTQyxxQkFBcUIsRUFBRUMsdUJBQXVCLEVBQUVDLGtCQUFrQixRQUFRLDRCQUEyQjtBQU05RyxPQUFPLFNBQVNDLG9CQUFvQixFQUFFQyxtQkFBbUIsRUFBRUMsYUFBYSxFQUFFQyxlQUFlLEVBQXdCO0lBQy9HLE1BQU1DLFdBQVdOLHdCQUF3QkssaUJBQWlCVCxXQUFXVyxJQUFJO0lBQ3pFLE1BQU1DLGFBQWFILGVBQWUsQ0FBQ1QsV0FBV1csSUFBSSxDQUFDO0lBRW5ELE1BQU1FLHlCQUF5Qk4sb0JBQW9CTyxJQUFJLENBQUMsQ0FBQ0MsYUFBZUEsV0FBV0MsSUFBSSxLQUFLTjtJQUU1RixNQUFNTyxpQkFBNkM7UUFDakRDLFdBQVcsSUFBTyxDQUFBO2dCQUNoQkMsT0FBTztnQkFDUEMsT0FBTztvQkFBRUMsYUFBYTtnQkFBaUM7WUFDekQsQ0FBQTtRQUNBQyxZQUFZLElBQU8sQ0FBQTtnQkFDakJGLE9BQU87b0JBQUVDLGFBQWE7Z0JBQWtDO1lBQzFELENBQUE7SUFDRjtJQUVBLE1BQU1FLG1CQUFtQnJCLG9CQUFvQjtRQUMzQ3NCLFFBQVFaO1FBQ1JhLHNCQUFzQlI7SUFDeEI7SUFFQSxJQUFJUyxpQkFBbUM7UUFDckMsR0FBR2Isc0JBQXNCO1FBQ3pCRyxNQUFNTjtRQUNOVSxPQUFPO1lBQ0xPLFFBQVFuQixjQUFjb0IscUJBQXFCLElBQUk7WUFDL0NDLFlBQVl4QixtQkFBbUJJLGlCQUFpQlQsV0FBV1csSUFBSSxFQUFFO1lBQ2pFVSxhQUFhO1lBQ2JTLE9BQU90QixlQUFldUIsd0JBQXdCO1lBQzlDLEdBQUdsQix3QkFBd0JPLEtBQUs7UUFDbEM7UUFDQVksUUFBUTtZQUNOLEdBQUcvQixlQUFlTyxjQUFjO1lBQ2hDLEdBQUlLLHdCQUF3Qm1CLFVBQVUsQ0FBQyxDQUFDO1FBQzFDO1FBQ0FDLFFBQVE7WUFDTixHQUFJcEIsd0JBQXdCb0IsVUFBVSxDQUFDLENBQUM7WUFDeENDLG9CQUFvQmxDLFdBQVdXLElBQUk7UUFDckM7UUFDQXdCLFFBQVE7ZUFBS3RCLHdCQUF3QnNCLFVBQVUsRUFBRTtlQUFPWixvQkFBb0IsRUFBRTtTQUFFO0lBQ2xGO0lBRUEsSUFBSSxPQUFPZixjQUFjNEIseUJBQXlCLEVBQUV6QixTQUFTLFlBQVk7UUFDdkVlLGlCQUFpQmxCLGNBQWM0Qix5QkFBeUIsQ0FBQ3pCLElBQUksQ0FBQztZQUM1REksWUFBWVc7UUFDZDtJQUNGO0lBRUF2QixzQkFBc0J1QixnQkFBZ0JkO0lBRXRDLE9BQU9jO0FBQ1QifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"oauth-access-tokens.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-access-tokens.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAG/C,OAAO,KAAK,EAAE,oBAAoB,EAAkB,MAAM,4BAA4B,CAAA;AAEtF,wBAAgB,gCAAgC,CAAC,EAAE,mBAAmB,EAAE,aAAa,EAAE,eAAe,EAAE,EAAE,oBAAoB,GAAG,gBAAgB,CAqFhJ"}
1
+ {"version":3,"file":"oauth-access-tokens.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-access-tokens.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAG/C,OAAO,KAAK,EAAE,oBAAoB,EAAkB,MAAM,4BAA4B,CAAA;AAEtF,wBAAgB,gCAAgC,CAAC,EAC/C,mBAAmB,EACnB,aAAa,EACb,eAAe,EAChB,EAAE,oBAAoB,GAAG,gBAAgB,CAqFzC"}
@@ -102,4 +102,4 @@ export function buildOauthAccessTokensCollection({ incomingCollections, pluginOp
102
102
  return oauthAccessTokenCollection;
103
103
  }
104
104
 
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-access-tokens.ts"],"sourcesContent":["import { baModelKey } from '../../constants'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\nimport { getCollectionFields } from './utils/transform-schema-fields-to-payload'\nimport { getDeafultCollectionSlug } from '../../helpers/get-collection-slug'\nimport { assertAllSchemaFields, getSchemaCollectionSlug, getSchemaFieldName } from './utils/collection-schema'\n\nimport type { CollectionConfig } from 'payload'\nimport type { FieldRule } from './utils/model-field-transformations'\nimport type { OauthAccessToken } from '@/better-auth/generated-types'\nimport type { BuildCollectionProps, FieldOverrides } from '@/better-auth/plugin/types'\n\nexport function buildOauthAccessTokensCollection({ incomingCollections, pluginOptions, resolvedSchemas }: BuildCollectionProps): CollectionConfig {\n  const oauthAccessTokenSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.oauthAccessToken)\n  const oauthAccessTokenSchema = resolvedSchemas[baModelKey.oauthAccessToken]\n\n  const existingOauthAccessTokenCollection = incomingCollections.find((collection) => collection.slug === oauthAccessTokenSlug) as\n    | CollectionConfig\n    | undefined\n\n  const fieldOverrides: FieldOverrides<keyof OauthAccessToken> = {\n    accessToken: () => ({\n      index: true,\n      admin: { readOnly: true, description: 'Access token issued to the client' }\n    }),\n    refreshToken: () => ({\n      admin: { readOnly: true, description: 'Refresh token issued to the client' }\n    }),\n    accessTokenExpiresAt: () => ({\n      admin: { readOnly: true, description: 'Expiration date of the access token' }\n    }),\n    refreshTokenExpiresAt: () => ({\n      admin: { readOnly: true, description: 'Expiration date of the refresh token' }\n    }),\n    clientId: () => ({\n      admin: { readOnly: true, description: 'OAuth application associated with the access token' }\n    }),\n    userId: () => ({\n      admin: { readOnly: true, description: 'User associated with the access token' }\n    }),\n    scopes: () => ({\n      admin: { description: 'Comma-separated list of scopes granted' }\n    })\n  }\n\n  const oauthAccessTokenFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.type === 'date',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => t('general:updatedAt')\n      })\n    }\n  ]\n\n  const collectionFields = getCollectionFields({\n    schema: oauthAccessTokenSchema,\n    fieldRules: oauthAccessTokenFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let oauthAccessTokenCollection: CollectionConfig = {\n    ...existingOauthAccessTokenCollection,\n    slug: oauthAccessTokenSlug,\n    admin: {\n      hidden: pluginOptions.hidePluginCollections ?? false,\n      useAsTitle: getSchemaFieldName(resolvedSchemas, baModelKey.oauthAccessToken, 'accessToken'),\n      description: 'OAuth access tokens for custom OAuth clients',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingOauthAccessTokenCollection?.admin\n    },\n    access: {\n      ...getAdminAccess(pluginOptions),\n      ...(existingOauthAccessTokenCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingOauthAccessTokenCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.oauthAccessToken\n    },\n    fields: [...(existingOauthAccessTokenCollection?.fields ?? []), ...(collectionFields ?? [])]\n  }\n\n  if (typeof pluginOptions.pluginCollectionOverrides?.oauthAccessTokens === 'function') {\n    oauthAccessTokenCollection = pluginOptions.pluginCollectionOverrides.oauthAccessTokens({\n      collection: oauthAccessTokenCollection\n    })\n  }\n\n  assertAllSchemaFields(oauthAccessTokenCollection, oauthAccessTokenSchema)\n\n  return oauthAccessTokenCollection\n}\n"],"names":["baModelKey","getAdminAccess","getCollectionFields","assertAllSchemaFields","getSchemaCollectionSlug","getSchemaFieldName","buildOauthAccessTokensCollection","incomingCollections","pluginOptions","resolvedSchemas","oauthAccessTokenSlug","oauthAccessToken","oauthAccessTokenSchema","existingOauthAccessTokenCollection","find","collection","slug","fieldOverrides","accessToken","index","admin","readOnly","description","refreshToken","accessTokenExpiresAt","refreshTokenExpiresAt","clientId","userId","scopes","oauthAccessTokenFieldRules","condition","field","type","transform","saveToJWT","disableBulkEdit","hidden","label","t","collectionFields","schema","fieldRules","additionalProperties","oauthAccessTokenCollection","hidePluginCollections","useAsTitle","group","collectionAdminGroup","access","custom","betterAuthModelKey","fields","pluginCollectionOverrides","oauthAccessTokens"],"mappings":"AAAA,SAASA,UAAU,QAAQ,kBAAiB;AAC5C,SAASC,cAAc,QAAQ,iCAAgC;AAC/D,SAASC,mBAAmB,QAAQ,6CAA4C;AAEhF,SAASC,qBAAqB,EAAEC,uBAAuB,EAAEC,kBAAkB,QAAQ,4BAA2B;AAO9G,OAAO,SAASC,iCAAiC,EAAEC,mBAAmB,EAAEC,aAAa,EAAEC,eAAe,EAAwB;IAC5H,MAAMC,uBAAuBN,wBAAwBK,iBAAiBT,WAAWW,gBAAgB;IACjG,MAAMC,yBAAyBH,eAAe,CAACT,WAAWW,gBAAgB,CAAC;IAE3E,MAAME,qCAAqCN,oBAAoBO,IAAI,CAAC,CAACC,aAAeA,WAAWC,IAAI,KAAKN;IAIxG,MAAMO,iBAAyD;QAC7DC,aAAa,IAAO,CAAA;gBAClBC,OAAO;gBACPC,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAoC;YAC5E,CAAA;QACAC,cAAc,IAAO,CAAA;gBACnBH,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAqC;YAC7E,CAAA;QACAE,sBAAsB,IAAO,CAAA;gBAC3BJ,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAsC;YAC9E,CAAA;QACAG,uBAAuB,IAAO,CAAA;gBAC5BL,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAuC;YAC/E,CAAA;QACAI,UAAU,IAAO,CAAA;gBACfN,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAqD;YAC7F,CAAA;QACAK,QAAQ,IAAO,CAAA;gBACbP,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAwC;YAChF,CAAA;QACAM,QAAQ,IAAO,CAAA;gBACbR,OAAO;oBAAEE,aAAa;gBAAyC;YACjE,CAAA;IACF;IAEA,MAAMO,6BAA0C;QAC9C;YACEC,WAAW,CAACC,QAAUA,MAAMC,IAAI,KAAK;YACrCC,WAAW,CAACF,QAAW,CAAA;oBACrB,GAAGA,KAAK;oBACRG,WAAW;oBACXd,OAAO;wBACLe,iBAAiB;wBACjBC,QAAQ;oBACV;oBACAjB,OAAO;oBACPkB,OAAO,CAAC,EAAEC,CAAC,EAAO,GAAKA,EAAE;gBAC3B,CAAA;QACF;KACD;IAED,MAAMC,mBAAmBrC,oBAAoB;QAC3CsC,QAAQ5B;QACR6B,YAAYZ;QACZa,sBAAsBzB;IACxB;IAEA,IAAI0B,6BAA+C;QACjD,GAAG9B,kCAAkC;QACrCG,MAAMN;QACNU,OAAO;YACLgB,QAAQ5B,cAAcoC,qBAAqB,IAAI;YAC/CC,YAAYxC,mBAAmBI,iBAAiBT,WAAWW,gBAAgB,EAAE;YAC7EW,aAAa;YACbwB,OAAOtC,eAAeuC,wBAAwB;YAC9C,GAAGlC,oCAAoCO,KAAK;QAC9C;QACA4B,QAAQ;YACN,GAAG/C,eAAeO,cAAc;YAChC,GAAIK,oCAAoCmC,UAAU,CAAC,CAAC;QACtD;QACAC,QAAQ;YACN,GAAIpC,oCAAoCoC,UAAU,CAAC,CAAC;YACpDC,oBAAoBlD,WAAWW,gBAAgB;QACjD;QACAwC,QAAQ;eAAKtC,oCAAoCsC,UAAU,EAAE;eAAOZ,oBAAoB,EAAE;SAAE;IAC9F;IAEA,IAAI,OAAO/B,cAAc4C,yBAAyB,EAAEC,sBAAsB,YAAY;QACpFV,6BAA6BnC,cAAc4C,yBAAyB,CAACC,iBAAiB,CAAC;YACrFtC,YAAY4B;QACd;IACF;IAEAxC,sBAAsBwC,4BAA4B/B;IAElD,OAAO+B;AACT"}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-access-tokens.ts"],"sourcesContent":["import { baModelKey } from '../../constants'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\nimport { getCollectionFields } from './utils/transform-schema-fields-to-payload'\nimport { getDefaultCollectionSlug } from '../../helpers/get-collection-slug'\nimport { assertAllSchemaFields, getSchemaCollectionSlug, getSchemaFieldName } from './utils/collection-schema'\n\nimport type { CollectionConfig } from 'payload'\nimport type { FieldRule } from './utils/model-field-transformations'\nimport type { OauthAccessToken } from '@/better-auth/generated-types'\nimport type { BuildCollectionProps, FieldOverrides } from '@/better-auth/plugin/types'\n\nexport function buildOauthAccessTokensCollection({\n  incomingCollections,\n  pluginOptions,\n  resolvedSchemas\n}: BuildCollectionProps): CollectionConfig {\n  const oauthAccessTokenSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.oauthAccessToken)\n  const oauthAccessTokenSchema = resolvedSchemas[baModelKey.oauthAccessToken]\n\n  const existingOauthAccessTokenCollection = incomingCollections.find((collection) => collection.slug === oauthAccessTokenSlug) as\n    | CollectionConfig\n    | undefined\n\n  const fieldOverrides: FieldOverrides<keyof OauthAccessToken> = {\n    accessToken: () => ({\n      index: true,\n      admin: { readOnly: true, description: 'Access token issued to the client' }\n    }),\n    refreshToken: () => ({\n      admin: { readOnly: true, description: 'Refresh token issued to the client' }\n    }),\n    accessTokenExpiresAt: () => ({\n      admin: { readOnly: true, description: 'Expiration date of the access token' }\n    }),\n    refreshTokenExpiresAt: () => ({\n      admin: { readOnly: true, description: 'Expiration date of the refresh token' }\n    }),\n    clientId: () => ({\n      admin: { readOnly: true, description: 'OAuth application associated with the access token' }\n    }),\n    userId: () => ({\n      admin: { readOnly: true, description: 'User associated with the access token' }\n    }),\n    scopes: () => ({\n      admin: { description: 'Comma-separated list of scopes granted' }\n    })\n  }\n\n  const oauthAccessTokenFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.type === 'date',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => t('general:updatedAt')\n      })\n    }\n  ]\n\n  const collectionFields = getCollectionFields({\n    schema: oauthAccessTokenSchema,\n    fieldRules: oauthAccessTokenFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let oauthAccessTokenCollection: CollectionConfig = {\n    ...existingOauthAccessTokenCollection,\n    slug: oauthAccessTokenSlug,\n    admin: {\n      hidden: pluginOptions.hidePluginCollections ?? false,\n      useAsTitle: getSchemaFieldName(resolvedSchemas, baModelKey.oauthAccessToken, 'accessToken'),\n      description: 'OAuth access tokens for custom OAuth clients',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingOauthAccessTokenCollection?.admin\n    },\n    access: {\n      ...getAdminAccess(pluginOptions),\n      ...(existingOauthAccessTokenCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingOauthAccessTokenCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.oauthAccessToken\n    },\n    fields: [...(existingOauthAccessTokenCollection?.fields ?? []), ...(collectionFields ?? [])]\n  }\n\n  if (typeof pluginOptions.pluginCollectionOverrides?.oauthAccessTokens === 'function') {\n    oauthAccessTokenCollection = pluginOptions.pluginCollectionOverrides.oauthAccessTokens({\n      collection: oauthAccessTokenCollection\n    })\n  }\n\n  assertAllSchemaFields(oauthAccessTokenCollection, oauthAccessTokenSchema)\n\n  return oauthAccessTokenCollection\n}\n"],"names":["baModelKey","getAdminAccess","getCollectionFields","assertAllSchemaFields","getSchemaCollectionSlug","getSchemaFieldName","buildOauthAccessTokensCollection","incomingCollections","pluginOptions","resolvedSchemas","oauthAccessTokenSlug","oauthAccessToken","oauthAccessTokenSchema","existingOauthAccessTokenCollection","find","collection","slug","fieldOverrides","accessToken","index","admin","readOnly","description","refreshToken","accessTokenExpiresAt","refreshTokenExpiresAt","clientId","userId","scopes","oauthAccessTokenFieldRules","condition","field","type","transform","saveToJWT","disableBulkEdit","hidden","label","t","collectionFields","schema","fieldRules","additionalProperties","oauthAccessTokenCollection","hidePluginCollections","useAsTitle","group","collectionAdminGroup","access","custom","betterAuthModelKey","fields","pluginCollectionOverrides","oauthAccessTokens"],"mappings":"AAAA,SAASA,UAAU,QAAQ,kBAAiB;AAC5C,SAASC,cAAc,QAAQ,iCAAgC;AAC/D,SAASC,mBAAmB,QAAQ,6CAA4C;AAEhF,SAASC,qBAAqB,EAAEC,uBAAuB,EAAEC,kBAAkB,QAAQ,4BAA2B;AAO9G,OAAO,SAASC,iCAAiC,EAC/CC,mBAAmB,EACnBC,aAAa,EACbC,eAAe,EACM;IACrB,MAAMC,uBAAuBN,wBAAwBK,iBAAiBT,WAAWW,gBAAgB;IACjG,MAAMC,yBAAyBH,eAAe,CAACT,WAAWW,gBAAgB,CAAC;IAE3E,MAAME,qCAAqCN,oBAAoBO,IAAI,CAAC,CAACC,aAAeA,WAAWC,IAAI,KAAKN;IAIxG,MAAMO,iBAAyD;QAC7DC,aAAa,IAAO,CAAA;gBAClBC,OAAO;gBACPC,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAoC;YAC5E,CAAA;QACAC,cAAc,IAAO,CAAA;gBACnBH,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAqC;YAC7E,CAAA;QACAE,sBAAsB,IAAO,CAAA;gBAC3BJ,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAsC;YAC9E,CAAA;QACAG,uBAAuB,IAAO,CAAA;gBAC5BL,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAuC;YAC/E,CAAA;QACAI,UAAU,IAAO,CAAA;gBACfN,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAqD;YAC7F,CAAA;QACAK,QAAQ,IAAO,CAAA;gBACbP,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAwC;YAChF,CAAA;QACAM,QAAQ,IAAO,CAAA;gBACbR,OAAO;oBAAEE,aAAa;gBAAyC;YACjE,CAAA;IACF;IAEA,MAAMO,6BAA0C;QAC9C;YACEC,WAAW,CAACC,QAAUA,MAAMC,IAAI,KAAK;YACrCC,WAAW,CAACF,QAAW,CAAA;oBACrB,GAAGA,KAAK;oBACRG,WAAW;oBACXd,OAAO;wBACLe,iBAAiB;wBACjBC,QAAQ;oBACV;oBACAjB,OAAO;oBACPkB,OAAO,CAAC,EAAEC,CAAC,EAAO,GAAKA,EAAE;gBAC3B,CAAA;QACF;KACD;IAED,MAAMC,mBAAmBrC,oBAAoB;QAC3CsC,QAAQ5B;QACR6B,YAAYZ;QACZa,sBAAsBzB;IACxB;IAEA,IAAI0B,6BAA+C;QACjD,GAAG9B,kCAAkC;QACrCG,MAAMN;QACNU,OAAO;YACLgB,QAAQ5B,cAAcoC,qBAAqB,IAAI;YAC/CC,YAAYxC,mBAAmBI,iBAAiBT,WAAWW,gBAAgB,EAAE;YAC7EW,aAAa;YACbwB,OAAOtC,eAAeuC,wBAAwB;YAC9C,GAAGlC,oCAAoCO,KAAK;QAC9C;QACA4B,QAAQ;YACN,GAAG/C,eAAeO,cAAc;YAChC,GAAIK,oCAAoCmC,UAAU,CAAC,CAAC;QACtD;QACAC,QAAQ;YACN,GAAIpC,oCAAoCoC,UAAU,CAAC,CAAC;YACpDC,oBAAoBlD,WAAWW,gBAAgB;QACjD;QACAwC,QAAQ;eAAKtC,oCAAoCsC,UAAU,EAAE;eAAOZ,oBAAoB,EAAE;SAAE;IAC9F;IAEA,IAAI,OAAO/B,cAAc4C,yBAAyB,EAAEC,sBAAsB,YAAY;QACpFV,6BAA6BnC,cAAc4C,yBAAyB,CAACC,iBAAiB,CAAC;YACrFtC,YAAY4B;QACd;IACF;IAEAxC,sBAAsBwC,4BAA4B/B;IAElD,OAAO+B;AACT"}
@@ -1 +1 @@
1
- {"version":3,"file":"oauth-applications.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-applications.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAG/C,OAAO,KAAK,EAAE,oBAAoB,EAAkB,MAAM,4BAA4B,CAAA;AAEtF,wBAAgB,gCAAgC,CAAC,EAAE,mBAAmB,EAAE,aAAa,EAAE,eAAe,EAAE,EAAE,oBAAoB,GAAG,gBAAgB,CA+FhJ"}
1
+ {"version":3,"file":"oauth-applications.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-applications.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAG/C,OAAO,KAAK,EAAE,oBAAoB,EAAkB,MAAM,4BAA4B,CAAA;AAEtF,wBAAgB,gCAAgC,CAAC,EAC/C,mBAAmB,EACnB,aAAa,EACb,eAAe,EAChB,EAAE,oBAAoB,GAAG,gBAAgB,CA+FzC"}
@@ -114,4 +114,4 @@ export function buildOauthApplicationsCollection({ incomingCollections, pluginOp
114
114
  return oauthApplicationCollection;
115
115
  }
116
116
 
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-applications.ts"],"sourcesContent":["import { baModelKey } from '../../constants'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\nimport { getDeafultCollectionSlug } from '../../helpers/get-collection-slug'\nimport { getCollectionFields } from './utils/transform-schema-fields-to-payload'\nimport { assertAllSchemaFields, getSchemaCollectionSlug } from './utils/collection-schema'\n\nimport type { CollectionConfig } from 'payload'\nimport type { OauthApplication } from '@/better-auth/generated-types'\nimport type { FieldRule } from './utils/model-field-transformations'\nimport type { BuildCollectionProps, FieldOverrides } from '@/better-auth/plugin/types'\n\nexport function buildOauthApplicationsCollection({ incomingCollections, pluginOptions, resolvedSchemas }: BuildCollectionProps): CollectionConfig {\n  const oauthApplicationSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.oauthApplication)\n\n  const oauthApplicationSchema = resolvedSchemas[baModelKey.oauthApplication]\n\n  const existingOauthApplicationCollection = incomingCollections.find((collection) => collection.slug === oauthApplicationSlug) as\n    | CollectionConfig\n    | undefined\n\n  const fieldOverrides: FieldOverrides<keyof OauthApplication> = {\n    clientId: () => ({\n      unique: true,\n      index: true,\n      admin: { readOnly: true, description: 'Unique identifier for each OAuth client' }\n    }),\n    clientSecret: () => ({\n      admin: { readOnly: true, description: 'Secret key for the OAuth client' }\n    }),\n    name: () => ({\n      index: true,\n      admin: { description: 'Name of the OAuth application' }\n    }),\n    redirectURLs: () => ({\n      admin: { description: 'Comma-separated list of redirect URLs' }\n    }),\n    metadata: () => ({\n      admin: { readOnly: true, description: 'Additional metadata for the OAuth application' }\n    }),\n    type: () => ({\n      admin: { readOnly: true, description: 'Type of OAuth client (e.g., web, mobile)' }\n    }),\n    disabled: () => ({\n      defaultValue: false,\n      admin: { description: 'Indicates if the client is disabled' }\n    }),\n    icon: () => ({\n      admin: { description: 'Icon of the OAuth application' }\n    }),\n    userId: () => ({\n      admin: { readOnly: true, description: 'ID of the user who owns the client. (optional)' }\n    })\n  }\n\n  const oauthApplicationFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.type === 'date',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => t('general:updatedAt')\n      })\n    }\n  ]\n\n  const collectionFields = getCollectionFields({\n    schema: oauthApplicationSchema,\n    fieldRules: oauthApplicationFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let oauthApplicationCollection: CollectionConfig = {\n    ...existingOauthApplicationCollection,\n    slug: oauthApplicationSlug,\n    admin: {\n      hidden: pluginOptions.hidePluginCollections ?? false,\n      useAsTitle: oauthApplicationSchema?.fields?.name?.fieldName,\n      description: 'OAuth applications are custom OAuth clients',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingOauthApplicationCollection?.admin\n    },\n    access: {\n      ...getAdminAccess(pluginOptions),\n      ...(existingOauthApplicationCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingOauthApplicationCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.oauthApplication\n    },\n    fields: [...(existingOauthApplicationCollection?.fields ?? []), ...(collectionFields ?? [])]\n  }\n\n  if (typeof pluginOptions.pluginCollectionOverrides?.oauthApplications === 'function') {\n    oauthApplicationCollection = pluginOptions.pluginCollectionOverrides.oauthApplications({\n      collection: oauthApplicationCollection\n    })\n  }\n\n  assertAllSchemaFields(oauthApplicationCollection, oauthApplicationSchema)\n\n  return oauthApplicationCollection\n}\n"],"names":["baModelKey","getAdminAccess","getCollectionFields","assertAllSchemaFields","getSchemaCollectionSlug","buildOauthApplicationsCollection","incomingCollections","pluginOptions","resolvedSchemas","oauthApplicationSlug","oauthApplication","oauthApplicationSchema","existingOauthApplicationCollection","find","collection","slug","fieldOverrides","clientId","unique","index","admin","readOnly","description","clientSecret","name","redirectURLs","metadata","type","disabled","defaultValue","icon","userId","oauthApplicationFieldRules","condition","field","transform","saveToJWT","disableBulkEdit","hidden","label","t","collectionFields","schema","fieldRules","additionalProperties","oauthApplicationCollection","hidePluginCollections","useAsTitle","fields","fieldName","group","collectionAdminGroup","access","custom","betterAuthModelKey","pluginCollectionOverrides","oauthApplications"],"mappings":"AAAA,SAASA,UAAU,QAAQ,kBAAiB;AAC5C,SAASC,cAAc,QAAQ,iCAAgC;AAE/D,SAASC,mBAAmB,QAAQ,6CAA4C;AAChF,SAASC,qBAAqB,EAAEC,uBAAuB,QAAQ,4BAA2B;AAO1F,OAAO,SAASC,iCAAiC,EAAEC,mBAAmB,EAAEC,aAAa,EAAEC,eAAe,EAAwB;IAC5H,MAAMC,uBAAuBL,wBAAwBI,iBAAiBR,WAAWU,gBAAgB;IAEjG,MAAMC,yBAAyBH,eAAe,CAACR,WAAWU,gBAAgB,CAAC;IAE3E,MAAME,qCAAqCN,oBAAoBO,IAAI,CAAC,CAACC,aAAeA,WAAWC,IAAI,KAAKN;IAIxG,MAAMO,iBAAyD;QAC7DC,UAAU,IAAO,CAAA;gBACfC,QAAQ;gBACRC,OAAO;gBACPC,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA0C;YAClF,CAAA;QACAC,cAAc,IAAO,CAAA;gBACnBH,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAkC;YAC1E,CAAA;QACAE,MAAM,IAAO,CAAA;gBACXL,OAAO;gBACPC,OAAO;oBAAEE,aAAa;gBAAgC;YACxD,CAAA;QACAG,cAAc,IAAO,CAAA;gBACnBL,OAAO;oBAAEE,aAAa;gBAAwC;YAChE,CAAA;QACAI,UAAU,IAAO,CAAA;gBACfN,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAgD;YACxF,CAAA;QACAK,MAAM,IAAO,CAAA;gBACXP,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA2C;YACnF,CAAA;QACAM,UAAU,IAAO,CAAA;gBACfC,cAAc;gBACdT,OAAO;oBAAEE,aAAa;gBAAsC;YAC9D,CAAA;QACAQ,MAAM,IAAO,CAAA;gBACXV,OAAO;oBAAEE,aAAa;gBAAgC;YACxD,CAAA;QACAS,QAAQ,IAAO,CAAA;gBACbX,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAiD;YACzF,CAAA;IACF;IAEA,MAAMU,6BAA0C;QAC9C;YACEC,WAAW,CAACC,QAAUA,MAAMP,IAAI,KAAK;YACrCQ,WAAW,CAACD,QAAW,CAAA;oBACrB,GAAGA,KAAK;oBACRE,WAAW;oBACXhB,OAAO;wBACLiB,iBAAiB;wBACjBC,QAAQ;oBACV;oBACAnB,OAAO;oBACPoB,OAAO,CAAC,EAAEC,CAAC,EAAO,GAAKA,EAAE;gBAC3B,CAAA;QACF;KACD;IAED,MAAMC,mBAAmBvC,oBAAoB;QAC3CwC,QAAQ/B;QACRgC,YAAYX;QACZY,sBAAsB5B;IACxB;IAEA,IAAI6B,6BAA+C;QACjD,GAAGjC,kCAAkC;QACrCG,MAAMN;QACNW,OAAO;YACLkB,QAAQ/B,cAAcuC,qBAAqB,IAAI;YAC/CC,YAAYpC,wBAAwBqC,QAAQxB,MAAMyB;YAClD3B,aAAa;YACb4B,OAAO3C,eAAe4C,wBAAwB;YAC9C,GAAGvC,oCAAoCQ,KAAK;QAC9C;QACAgC,QAAQ;YACN,GAAGnD,eAAeM,cAAc;YAChC,GAAIK,oCAAoCwC,UAAU,CAAC,CAAC;QACtD;QACAC,QAAQ;YACN,GAAIzC,oCAAoCyC,UAAU,CAAC,CAAC;YACpDC,oBAAoBtD,WAAWU,gBAAgB;QACjD;QACAsC,QAAQ;eAAKpC,oCAAoCoC,UAAU,EAAE;eAAOP,oBAAoB,EAAE;SAAE;IAC9F;IAEA,IAAI,OAAOlC,cAAcgD,yBAAyB,EAAEC,sBAAsB,YAAY;QACpFX,6BAA6BtC,cAAcgD,yBAAyB,CAACC,iBAAiB,CAAC;YACrF1C,YAAY+B;QACd;IACF;IAEA1C,sBAAsB0C,4BAA4BlC;IAElD,OAAOkC;AACT"}
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-applications.ts"],"sourcesContent":["import { baModelKey } from '../../constants'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\nimport { getDefaultCollectionSlug } from '../../helpers/get-collection-slug'\nimport { getCollectionFields } from './utils/transform-schema-fields-to-payload'\nimport { assertAllSchemaFields, getSchemaCollectionSlug } from './utils/collection-schema'\n\nimport type { CollectionConfig } from 'payload'\nimport type { OauthApplication } from '@/better-auth/generated-types'\nimport type { FieldRule } from './utils/model-field-transformations'\nimport type { BuildCollectionProps, FieldOverrides } from '@/better-auth/plugin/types'\n\nexport function buildOauthApplicationsCollection({\n  incomingCollections,\n  pluginOptions,\n  resolvedSchemas\n}: BuildCollectionProps): CollectionConfig {\n  const oauthApplicationSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.oauthApplication)\n\n  const oauthApplicationSchema = resolvedSchemas[baModelKey.oauthApplication]\n\n  const existingOauthApplicationCollection = incomingCollections.find((collection) => collection.slug === oauthApplicationSlug) as\n    | CollectionConfig\n    | undefined\n\n  const fieldOverrides: FieldOverrides<keyof OauthApplication> = {\n    clientId: () => ({\n      unique: true,\n      index: true,\n      admin: { readOnly: true, description: 'Unique identifier for each OAuth client' }\n    }),\n    clientSecret: () => ({\n      admin: { readOnly: true, description: 'Secret key for the OAuth client' }\n    }),\n    name: () => ({\n      index: true,\n      admin: { description: 'Name of the OAuth application' }\n    }),\n    redirectURLs: () => ({\n      admin: { description: 'Comma-separated list of redirect URLs' }\n    }),\n    metadata: () => ({\n      admin: { readOnly: true, description: 'Additional metadata for the OAuth application' }\n    }),\n    type: () => ({\n      admin: { readOnly: true, description: 'Type of OAuth client (e.g., web, mobile)' }\n    }),\n    disabled: () => ({\n      defaultValue: false,\n      admin: { description: 'Indicates if the client is disabled' }\n    }),\n    icon: () => ({\n      admin: { description: 'Icon of the OAuth application' }\n    }),\n    userId: () => ({\n      admin: { readOnly: true, description: 'ID of the user who owns the client. (optional)' }\n    })\n  }\n\n  const oauthApplicationFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.type === 'date',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => t('general:updatedAt')\n      })\n    }\n  ]\n\n  const collectionFields = getCollectionFields({\n    schema: oauthApplicationSchema,\n    fieldRules: oauthApplicationFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let oauthApplicationCollection: CollectionConfig = {\n    ...existingOauthApplicationCollection,\n    slug: oauthApplicationSlug,\n    admin: {\n      hidden: pluginOptions.hidePluginCollections ?? false,\n      useAsTitle: oauthApplicationSchema?.fields?.name?.fieldName,\n      description: 'OAuth applications are custom OAuth clients',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingOauthApplicationCollection?.admin\n    },\n    access: {\n      ...getAdminAccess(pluginOptions),\n      ...(existingOauthApplicationCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingOauthApplicationCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.oauthApplication\n    },\n    fields: [...(existingOauthApplicationCollection?.fields ?? []), ...(collectionFields ?? [])]\n  }\n\n  if (typeof pluginOptions.pluginCollectionOverrides?.oauthApplications === 'function') {\n    oauthApplicationCollection = pluginOptions.pluginCollectionOverrides.oauthApplications({\n      collection: oauthApplicationCollection\n    })\n  }\n\n  assertAllSchemaFields(oauthApplicationCollection, oauthApplicationSchema)\n\n  return oauthApplicationCollection\n}\n"],"names":["baModelKey","getAdminAccess","getCollectionFields","assertAllSchemaFields","getSchemaCollectionSlug","buildOauthApplicationsCollection","incomingCollections","pluginOptions","resolvedSchemas","oauthApplicationSlug","oauthApplication","oauthApplicationSchema","existingOauthApplicationCollection","find","collection","slug","fieldOverrides","clientId","unique","index","admin","readOnly","description","clientSecret","name","redirectURLs","metadata","type","disabled","defaultValue","icon","userId","oauthApplicationFieldRules","condition","field","transform","saveToJWT","disableBulkEdit","hidden","label","t","collectionFields","schema","fieldRules","additionalProperties","oauthApplicationCollection","hidePluginCollections","useAsTitle","fields","fieldName","group","collectionAdminGroup","access","custom","betterAuthModelKey","pluginCollectionOverrides","oauthApplications"],"mappings":"AAAA,SAASA,UAAU,QAAQ,kBAAiB;AAC5C,SAASC,cAAc,QAAQ,iCAAgC;AAE/D,SAASC,mBAAmB,QAAQ,6CAA4C;AAChF,SAASC,qBAAqB,EAAEC,uBAAuB,QAAQ,4BAA2B;AAO1F,OAAO,SAASC,iCAAiC,EAC/CC,mBAAmB,EACnBC,aAAa,EACbC,eAAe,EACM;IACrB,MAAMC,uBAAuBL,wBAAwBI,iBAAiBR,WAAWU,gBAAgB;IAEjG,MAAMC,yBAAyBH,eAAe,CAACR,WAAWU,gBAAgB,CAAC;IAE3E,MAAME,qCAAqCN,oBAAoBO,IAAI,CAAC,CAACC,aAAeA,WAAWC,IAAI,KAAKN;IAIxG,MAAMO,iBAAyD;QAC7DC,UAAU,IAAO,CAAA;gBACfC,QAAQ;gBACRC,OAAO;gBACPC,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA0C;YAClF,CAAA;QACAC,cAAc,IAAO,CAAA;gBACnBH,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAkC;YAC1E,CAAA;QACAE,MAAM,IAAO,CAAA;gBACXL,OAAO;gBACPC,OAAO;oBAAEE,aAAa;gBAAgC;YACxD,CAAA;QACAG,cAAc,IAAO,CAAA;gBACnBL,OAAO;oBAAEE,aAAa;gBAAwC;YAChE,CAAA;QACAI,UAAU,IAAO,CAAA;gBACfN,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAgD;YACxF,CAAA;QACAK,MAAM,IAAO,CAAA;gBACXP,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAA2C;YACnF,CAAA;QACAM,UAAU,IAAO,CAAA;gBACfC,cAAc;gBACdT,OAAO;oBAAEE,aAAa;gBAAsC;YAC9D,CAAA;QACAQ,MAAM,IAAO,CAAA;gBACXV,OAAO;oBAAEE,aAAa;gBAAgC;YACxD,CAAA;QACAS,QAAQ,IAAO,CAAA;gBACbX,OAAO;oBAAEC,UAAU;oBAAMC,aAAa;gBAAiD;YACzF,CAAA;IACF;IAEA,MAAMU,6BAA0C;QAC9C;YACEC,WAAW,CAACC,QAAUA,MAAMP,IAAI,KAAK;YACrCQ,WAAW,CAACD,QAAW,CAAA;oBACrB,GAAGA,KAAK;oBACRE,WAAW;oBACXhB,OAAO;wBACLiB,iBAAiB;wBACjBC,QAAQ;oBACV;oBACAnB,OAAO;oBACPoB,OAAO,CAAC,EAAEC,CAAC,EAAO,GAAKA,EAAE;gBAC3B,CAAA;QACF;KACD;IAED,MAAMC,mBAAmBvC,oBAAoB;QAC3CwC,QAAQ/B;QACRgC,YAAYX;QACZY,sBAAsB5B;IACxB;IAEA,IAAI6B,6BAA+C;QACjD,GAAGjC,kCAAkC;QACrCG,MAAMN;QACNW,OAAO;YACLkB,QAAQ/B,cAAcuC,qBAAqB,IAAI;YAC/CC,YAAYpC,wBAAwBqC,QAAQxB,MAAMyB;YAClD3B,aAAa;YACb4B,OAAO3C,eAAe4C,wBAAwB;YAC9C,GAAGvC,oCAAoCQ,KAAK;QAC9C;QACAgC,QAAQ;YACN,GAAGnD,eAAeM,cAAc;YAChC,GAAIK,oCAAoCwC,UAAU,CAAC,CAAC;QACtD;QACAC,QAAQ;YACN,GAAIzC,oCAAoCyC,UAAU,CAAC,CAAC;YACpDC,oBAAoBtD,WAAWU,gBAAgB;QACjD;QACAsC,QAAQ;eAAKpC,oCAAoCoC,UAAU,EAAE;eAAOP,oBAAoB,EAAE;SAAE;IAC9F;IAEA,IAAI,OAAOlC,cAAcgD,yBAAyB,EAAEC,sBAAsB,YAAY;QACpFX,6BAA6BtC,cAAcgD,yBAAyB,CAACC,iBAAiB,CAAC;YACrF1C,YAAY+B;QACd;IACF;IAEA1C,sBAAsB0C,4BAA4BlC;IAElD,OAAOkC;AACT"}
@@ -1 +1 @@
1
- {"version":3,"file":"oauth-consents.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-consents.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAG/C,OAAO,KAAK,EAAE,oBAAoB,EAAkB,MAAM,4BAA4B,CAAA;AAGtF,wBAAgB,4BAA4B,CAAC,EAAE,mBAAmB,EAAE,aAAa,EAAE,eAAe,EAAE,EAAE,oBAAoB,GAAG,gBAAgB,CA2E5I"}
1
+ {"version":3,"file":"oauth-consents.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/lib/build-collections/oauth-consents.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAG/C,OAAO,KAAK,EAAE,oBAAoB,EAAkB,MAAM,4BAA4B,CAAA;AAGtF,wBAAgB,4BAA4B,CAAC,EAC3C,mBAAmB,EACnB,aAAa,EACb,eAAe,EAChB,EAAE,oBAAoB,GAAG,gBAAgB,CA2EzC"}
@@ -85,4 +85,4 @@ export function buildOauthConsentsCollection({ incomingCollections, pluginOption
85
85
  return oauthConsentCollection;
86
86
  }
87
87
 
88
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL29hdXRoLWNvbnNlbnRzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJhTW9kZWxLZXkgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnXG5pbXBvcnQgeyBnZXRBZG1pbkFjY2VzcyB9IGZyb20gJy4uLy4uL2hlbHBlcnMvZ2V0LWFkbWluLWFjY2VzcydcbmltcG9ydCB7IGdldERlYWZ1bHRDb2xsZWN0aW9uU2x1ZyB9IGZyb20gJy4uLy4uL2hlbHBlcnMvZ2V0LWNvbGxlY3Rpb24tc2x1ZydcbmltcG9ydCB7IGdldENvbGxlY3Rpb25GaWVsZHMgfSBmcm9tICcuL3V0aWxzL3RyYW5zZm9ybS1zY2hlbWEtZmllbGRzLXRvLXBheWxvYWQnXG5pbXBvcnQgeyBhc3NlcnRBbGxTY2hlbWFGaWVsZHMgfSBmcm9tICcuL3V0aWxzL2NvbGxlY3Rpb24tc2NoZW1hJ1xuXG5pbXBvcnQgdHlwZSB7IENvbGxlY3Rpb25Db25maWcgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBPYXV0aENvbnNlbnQgfSBmcm9tICdAL2JldHRlci1hdXRoL2dlbmVyYXRlZC10eXBlcydcbmltcG9ydCB0eXBlIHsgRmllbGRSdWxlIH0gZnJvbSAnLi91dGlscy9tb2RlbC1maWVsZC10cmFuc2Zvcm1hdGlvbnMnXG5pbXBvcnQgdHlwZSB7IEJ1aWxkQ29sbGVjdGlvblByb3BzLCBGaWVsZE92ZXJyaWRlcyB9IGZyb20gJ0AvYmV0dGVyLWF1dGgvcGx1Z2luL3R5cGVzJ1xuaW1wb3J0IHsgZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWcgfSBmcm9tICcuL3V0aWxzL2NvbGxlY3Rpb24tc2NoZW1hJ1xuXG5leHBvcnQgZnVuY3Rpb24gYnVpbGRPYXV0aENvbnNlbnRzQ29sbGVjdGlvbih7IGluY29taW5nQ29sbGVjdGlvbnMsIHBsdWdpbk9wdGlvbnMsIHJlc29sdmVkU2NoZW1hcyB9OiBCdWlsZENvbGxlY3Rpb25Qcm9wcyk6IENvbGxlY3Rpb25Db25maWcge1xuICBjb25zdCBvYXV0aENvbnNlbnRTbHVnID0gZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWcocmVzb2x2ZWRTY2hlbWFzLCBiYU1vZGVsS2V5Lm9hdXRoQ29uc2VudClcbiAgY29uc3Qgb2F1dGhDb25zZW50U2NoZW1hID0gcmVzb2x2ZWRTY2hlbWFzW2JhTW9kZWxLZXkub2F1dGhDb25zZW50XVxuXG4gIGNvbnN0IGV4aXN0aW5nT2F1dGhDb25zZW50Q29sbGVjdGlvbiA9IGluY29taW5nQ29sbGVjdGlvbnMuZmluZCgoY29sbGVjdGlvbikgPT4gY29sbGVjdGlvbi5zbHVnID09PSBvYXV0aENvbnNlbnRTbHVnKSBhc1xuICAgIHwgQ29sbGVjdGlvbkNvbmZpZ1xuICAgIHwgdW5kZWZpbmVkXG5cbiAgY29uc3QgZmllbGRPdmVycmlkZXM6IEZpZWxkT3ZlcnJpZGVzPGtleW9mIE9hdXRoQ29uc2VudD4gPSB7XG4gICAgY2xpZW50SWQ6ICgpID0+ICh7XG4gICAgICBhZG1pbjogeyByZWFkT25seTogdHJ1ZSwgZGVzY3JpcHRpb246ICdPQXV0aCBjbGllbnQgYXNzb2NpYXRlZCB3aXRoIHRoZSBjb25zZW50JyB9XG4gICAgfSksXG4gICAgdXNlcklkOiAoKSA9PiAoe1xuICAgICAgYWRtaW46IHsgcmVhZE9ubHk6IHRydWUsIGRlc2NyaXB0aW9uOiAnVXNlciBhc3NvY2lhdGVkIHdpdGggdGhlIGNvbnNlbnQnIH1cbiAgICB9KSxcbiAgICBzY29wZXM6ICgpID0+ICh7XG4gICAgICBhZG1pbjogeyByZWFkT25seTogdHJ1ZSwgZGVzY3JpcHRpb246ICdDb21tYS1zZXBhcmF0ZWQgbGlzdCBvZiBzY29wZXMgY29uc2VudGVkIHRvJyB9XG4gICAgfSksXG4gICAgY29uc2VudEdpdmVuOiAoKSA9PiAoe1xuICAgICAgZGVmYXVsdFZhbHVlOiBmYWxzZSxcbiAgICAgIGFkbWluOiB7IHJlYWRPbmx5OiB0cnVlLCBkZXNjcmlwdGlvbjogJ0luZGljYXRlcyBpZiBjb25zZW50IHdhcyBnaXZlbicgfVxuICAgIH0pXG4gIH1cblxuICBjb25zdCBvYXV0aENvbnNlbnRGaWVsZFJ1bGVzOiBGaWVsZFJ1bGVbXSA9IFtcbiAgICB7XG4gICAgICBjb25kaXRpb246IChmaWVsZCkgPT4gZmllbGQudHlwZSA9PT0gJ2RhdGUnLFxuICAgICAgdHJhbnNmb3JtOiAoZmllbGQpID0+ICh7XG4gICAgICAgIC4uLmZpZWxkLFxuICAgICAgICBzYXZlVG9KV1Q6IGZhbHNlLFxuICAgICAgICBhZG1pbjoge1xuICAgICAgICAgIGRpc2FibGVCdWxrRWRpdDogdHJ1ZSxcbiAgICAgICAgICBoaWRkZW46IHRydWVcbiAgICAgICAgfSxcbiAgICAgICAgaW5kZXg6IHRydWUsXG4gICAgICAgIGxhYmVsOiAoeyB0IH06IGFueSkgPT4gdCgnZ2VuZXJhbDp1cGRhdGVkQXQnKVxuICAgICAgfSlcbiAgICB9XG4gIF1cblxuICBjb25zdCBjb2xsZWN0aW9uRmllbGRzID0gZ2V0Q29sbGVjdGlvbkZpZWxkcyh7XG4gICAgc2NoZW1hOiBvYXV0aENvbnNlbnRTY2hlbWEsXG4gICAgZmllbGRSdWxlczogb2F1dGhDb25zZW50RmllbGRSdWxlcyxcbiAgICBhZGRpdGlvbmFsUHJvcGVydGllczogZmllbGRPdmVycmlkZXNcbiAgfSlcblxuICBsZXQgb2F1dGhDb25zZW50Q29sbGVjdGlvbjogQ29sbGVjdGlvbkNvbmZpZyA9IHtcbiAgICAuLi5leGlzdGluZ09hdXRoQ29uc2VudENvbGxlY3Rpb24sXG4gICAgc2x1Zzogb2F1dGhDb25zZW50U2x1ZyxcbiAgICBhZG1pbjoge1xuICAgICAgaGlkZGVuOiBwbHVnaW5PcHRpb25zLmhpZGVQbHVnaW5Db2xsZWN0aW9ucyA/PyBmYWxzZSxcbiAgICAgIGRlc2NyaXB0aW9uOiAnT0F1dGggY29uc2VudHMgYXJlIHVzZWQgdG8gc3RvcmUgdXNlciBjb25zZW50cyBmb3IgT0F1dGggY2xpZW50cycsXG4gICAgICBncm91cDogcGx1Z2luT3B0aW9ucz8uY29sbGVjdGlvbkFkbWluR3JvdXAgPz8gJ0F1dGgnLFxuICAgICAgLi4uZXhpc3RpbmdPYXV0aENvbnNlbnRDb2xsZWN0aW9uPy5hZG1pblxuICAgIH0sXG4gICAgYWNjZXNzOiB7XG4gICAgICAuLi5nZXRBZG1pbkFjY2VzcyhwbHVnaW5PcHRpb25zKSxcbiAgICAgIC4uLihleGlzdGluZ09hdXRoQ29uc2VudENvbGxlY3Rpb24/LmFjY2VzcyA/PyB7fSlcbiAgICB9LFxuICAgIGN1c3RvbToge1xuICAgICAgLi4uKGV4aXN0aW5nT2F1dGhDb25zZW50Q29sbGVjdGlvbj8uY3VzdG9tID8/IHt9KSxcbiAgICAgIGJldHRlckF1dGhNb2RlbEtleTogYmFNb2RlbEtleS5vYXV0aENvbnNlbnRcbiAgICB9LFxuICAgIGZpZWxkczogWy4uLihleGlzdGluZ09hdXRoQ29uc2VudENvbGxlY3Rpb24/LmZpZWxkcyA/PyBbXSksIC4uLihjb2xsZWN0aW9uRmllbGRzID8/IFtdKV1cbiAgfVxuXG4gIGlmICh0eXBlb2YgcGx1Z2luT3B0aW9ucy5wbHVnaW5Db2xsZWN0aW9uT3ZlcnJpZGVzPy5vYXV0aENvbnNlbnRzID09PSAnZnVuY3Rpb24nKSB7XG4gICAgb2F1dGhDb25zZW50Q29sbGVjdGlvbiA9IHBsdWdpbk9wdGlvbnMucGx1Z2luQ29sbGVjdGlvbk92ZXJyaWRlcy5vYXV0aENvbnNlbnRzKHtcbiAgICAgIGNvbGxlY3Rpb246IG9hdXRoQ29uc2VudENvbGxlY3Rpb25cbiAgICB9KVxuICB9XG5cbiAgYXNzZXJ0QWxsU2NoZW1hRmllbGRzKG9hdXRoQ29uc2VudENvbGxlY3Rpb24sIG9hdXRoQ29uc2VudFNjaGVtYSlcblxuICByZXR1cm4gb2F1dGhDb25zZW50Q29sbGVjdGlvblxufVxuIl0sIm5hbWVzIjpbImJhTW9kZWxLZXkiLCJnZXRBZG1pbkFjY2VzcyIsImdldENvbGxlY3Rpb25GaWVsZHMiLCJhc3NlcnRBbGxTY2hlbWFGaWVsZHMiLCJnZXRTY2hlbWFDb2xsZWN0aW9uU2x1ZyIsImJ1aWxkT2F1dGhDb25zZW50c0NvbGxlY3Rpb24iLCJpbmNvbWluZ0NvbGxlY3Rpb25zIiwicGx1Z2luT3B0aW9ucyIsInJlc29sdmVkU2NoZW1hcyIsIm9hdXRoQ29uc2VudFNsdWciLCJvYXV0aENvbnNlbnQiLCJvYXV0aENvbnNlbnRTY2hlbWEiLCJleGlzdGluZ09hdXRoQ29uc2VudENvbGxlY3Rpb24iLCJmaW5kIiwiY29sbGVjdGlvbiIsInNsdWciLCJmaWVsZE92ZXJyaWRlcyIsImNsaWVudElkIiwiYWRtaW4iLCJyZWFkT25seSIsImRlc2NyaXB0aW9uIiwidXNlcklkIiwic2NvcGVzIiwiY29uc2VudEdpdmVuIiwiZGVmYXVsdFZhbHVlIiwib2F1dGhDb25zZW50RmllbGRSdWxlcyIsImNvbmRpdGlvbiIsImZpZWxkIiwidHlwZSIsInRyYW5zZm9ybSIsInNhdmVUb0pXVCIsImRpc2FibGVCdWxrRWRpdCIsImhpZGRlbiIsImluZGV4IiwibGFiZWwiLCJ0IiwiY29sbGVjdGlvbkZpZWxkcyIsInNjaGVtYSIsImZpZWxkUnVsZXMiLCJhZGRpdGlvbmFsUHJvcGVydGllcyIsIm9hdXRoQ29uc2VudENvbGxlY3Rpb24iLCJoaWRlUGx1Z2luQ29sbGVjdGlvbnMiLCJncm91cCIsImNvbGxlY3Rpb25BZG1pbkdyb3VwIiwiYWNjZXNzIiwiY3VzdG9tIiwiYmV0dGVyQXV0aE1vZGVsS2V5IiwiZmllbGRzIiwicGx1Z2luQ29sbGVjdGlvbk92ZXJyaWRlcyIsIm9hdXRoQ29uc2VudHMiXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFVBQVUsUUFBUSxrQkFBaUI7QUFDNUMsU0FBU0MsY0FBYyxRQUFRLGlDQUFnQztBQUUvRCxTQUFTQyxtQkFBbUIsUUFBUSw2Q0FBNEM7QUFDaEYsU0FBU0MscUJBQXFCLFFBQVEsNEJBQTJCO0FBTWpFLFNBQVNDLHVCQUF1QixRQUFRLDRCQUEyQjtBQUVuRSxPQUFPLFNBQVNDLDZCQUE2QixFQUFFQyxtQkFBbUIsRUFBRUMsYUFBYSxFQUFFQyxlQUFlLEVBQXdCO0lBQ3hILE1BQU1DLG1CQUFtQkwsd0JBQXdCSSxpQkFBaUJSLFdBQVdVLFlBQVk7SUFDekYsTUFBTUMscUJBQXFCSCxlQUFlLENBQUNSLFdBQVdVLFlBQVksQ0FBQztJQUVuRSxNQUFNRSxpQ0FBaUNOLG9CQUFvQk8sSUFBSSxDQUFDLENBQUNDLGFBQWVBLFdBQVdDLElBQUksS0FBS047SUFJcEcsTUFBTU8saUJBQXFEO1FBQ3pEQyxVQUFVLElBQU8sQ0FBQTtnQkFDZkMsT0FBTztvQkFBRUMsVUFBVTtvQkFBTUMsYUFBYTtnQkFBMkM7WUFDbkYsQ0FBQTtRQUNBQyxRQUFRLElBQU8sQ0FBQTtnQkFDYkgsT0FBTztvQkFBRUMsVUFBVTtvQkFBTUMsYUFBYTtnQkFBbUM7WUFDM0UsQ0FBQTtRQUNBRSxRQUFRLElBQU8sQ0FBQTtnQkFDYkosT0FBTztvQkFBRUMsVUFBVTtvQkFBTUMsYUFBYTtnQkFBOEM7WUFDdEYsQ0FBQTtRQUNBRyxjQUFjLElBQU8sQ0FBQTtnQkFDbkJDLGNBQWM7Z0JBQ2ROLE9BQU87b0JBQUVDLFVBQVU7b0JBQU1DLGFBQWE7Z0JBQWlDO1lBQ3pFLENBQUE7SUFDRjtJQUVBLE1BQU1LLHlCQUFzQztRQUMxQztZQUNFQyxXQUFXLENBQUNDLFFBQVVBLE1BQU1DLElBQUksS0FBSztZQUNyQ0MsV0FBVyxDQUFDRixRQUFXLENBQUE7b0JBQ3JCLEdBQUdBLEtBQUs7b0JBQ1JHLFdBQVc7b0JBQ1haLE9BQU87d0JBQ0xhLGlCQUFpQjt3QkFDakJDLFFBQVE7b0JBQ1Y7b0JBQ0FDLE9BQU87b0JBQ1BDLE9BQU8sQ0FBQyxFQUFFQyxDQUFDLEVBQU8sR0FBS0EsRUFBRTtnQkFDM0IsQ0FBQTtRQUNGO0tBQ0Q7SUFFRCxNQUFNQyxtQkFBbUJsQyxvQkFBb0I7UUFDM0NtQyxRQUFRMUI7UUFDUjJCLFlBQVliO1FBQ1pjLHNCQUFzQnZCO0lBQ3hCO0lBRUEsSUFBSXdCLHlCQUEyQztRQUM3QyxHQUFHNUIsOEJBQThCO1FBQ2pDRyxNQUFNTjtRQUNOUyxPQUFPO1lBQ0xjLFFBQVF6QixjQUFja0MscUJBQXFCLElBQUk7WUFDL0NyQixhQUFhO1lBQ2JzQixPQUFPbkMsZUFBZW9DLHdCQUF3QjtZQUM5QyxHQUFHL0IsZ0NBQWdDTSxLQUFLO1FBQzFDO1FBQ0EwQixRQUFRO1lBQ04sR0FBRzNDLGVBQWVNLGNBQWM7WUFDaEMsR0FBSUssZ0NBQWdDZ0MsVUFBVSxDQUFDLENBQUM7UUFDbEQ7UUFDQUMsUUFBUTtZQUNOLEdBQUlqQyxnQ0FBZ0NpQyxVQUFVLENBQUMsQ0FBQztZQUNoREMsb0JBQW9COUMsV0FBV1UsWUFBWTtRQUM3QztRQUNBcUMsUUFBUTtlQUFLbkMsZ0NBQWdDbUMsVUFBVSxFQUFFO2VBQU9YLG9CQUFvQixFQUFFO1NBQUU7SUFDMUY7SUFFQSxJQUFJLE9BQU83QixjQUFjeUMseUJBQXlCLEVBQUVDLGtCQUFrQixZQUFZO1FBQ2hGVCx5QkFBeUJqQyxjQUFjeUMseUJBQXlCLENBQUNDLGFBQWEsQ0FBQztZQUM3RW5DLFlBQVkwQjtRQUNkO0lBQ0Y7SUFFQXJDLHNCQUFzQnFDLHdCQUF3QjdCO0lBRTlDLE9BQU82QjtBQUNUIn0=
88
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2J1aWxkLWNvbGxlY3Rpb25zL29hdXRoLWNvbnNlbnRzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJhTW9kZWxLZXkgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnXG5pbXBvcnQgeyBnZXRBZG1pbkFjY2VzcyB9IGZyb20gJy4uLy4uL2hlbHBlcnMvZ2V0LWFkbWluLWFjY2VzcydcbmltcG9ydCB7IGdldERlZmF1bHRDb2xsZWN0aW9uU2x1ZyB9IGZyb20gJy4uLy4uL2hlbHBlcnMvZ2V0LWNvbGxlY3Rpb24tc2x1ZydcbmltcG9ydCB7IGdldENvbGxlY3Rpb25GaWVsZHMgfSBmcm9tICcuL3V0aWxzL3RyYW5zZm9ybS1zY2hlbWEtZmllbGRzLXRvLXBheWxvYWQnXG5pbXBvcnQgeyBhc3NlcnRBbGxTY2hlbWFGaWVsZHMgfSBmcm9tICcuL3V0aWxzL2NvbGxlY3Rpb24tc2NoZW1hJ1xuXG5pbXBvcnQgdHlwZSB7IENvbGxlY3Rpb25Db25maWcgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHR5cGUgeyBPYXV0aENvbnNlbnQgfSBmcm9tICdAL2JldHRlci1hdXRoL2dlbmVyYXRlZC10eXBlcydcbmltcG9ydCB0eXBlIHsgRmllbGRSdWxlIH0gZnJvbSAnLi91dGlscy9tb2RlbC1maWVsZC10cmFuc2Zvcm1hdGlvbnMnXG5pbXBvcnQgdHlwZSB7IEJ1aWxkQ29sbGVjdGlvblByb3BzLCBGaWVsZE92ZXJyaWRlcyB9IGZyb20gJ0AvYmV0dGVyLWF1dGgvcGx1Z2luL3R5cGVzJ1xuaW1wb3J0IHsgZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWcgfSBmcm9tICcuL3V0aWxzL2NvbGxlY3Rpb24tc2NoZW1hJ1xuXG5leHBvcnQgZnVuY3Rpb24gYnVpbGRPYXV0aENvbnNlbnRzQ29sbGVjdGlvbih7XG4gIGluY29taW5nQ29sbGVjdGlvbnMsXG4gIHBsdWdpbk9wdGlvbnMsXG4gIHJlc29sdmVkU2NoZW1hc1xufTogQnVpbGRDb2xsZWN0aW9uUHJvcHMpOiBDb2xsZWN0aW9uQ29uZmlnIHtcbiAgY29uc3Qgb2F1dGhDb25zZW50U2x1ZyA9IGdldFNjaGVtYUNvbGxlY3Rpb25TbHVnKHJlc29sdmVkU2NoZW1hcywgYmFNb2RlbEtleS5vYXV0aENvbnNlbnQpXG4gIGNvbnN0IG9hdXRoQ29uc2VudFNjaGVtYSA9IHJlc29sdmVkU2NoZW1hc1tiYU1vZGVsS2V5Lm9hdXRoQ29uc2VudF1cblxuICBjb25zdCBleGlzdGluZ09hdXRoQ29uc2VudENvbGxlY3Rpb24gPSBpbmNvbWluZ0NvbGxlY3Rpb25zLmZpbmQoKGNvbGxlY3Rpb24pID0+IGNvbGxlY3Rpb24uc2x1ZyA9PT0gb2F1dGhDb25zZW50U2x1ZykgYXNcbiAgICB8IENvbGxlY3Rpb25Db25maWdcbiAgICB8IHVuZGVmaW5lZFxuXG4gIGNvbnN0IGZpZWxkT3ZlcnJpZGVzOiBGaWVsZE92ZXJyaWRlczxrZXlvZiBPYXV0aENvbnNlbnQ+ID0ge1xuICAgIGNsaWVudElkOiAoKSA9PiAoe1xuICAgICAgYWRtaW46IHsgcmVhZE9ubHk6IHRydWUsIGRlc2NyaXB0aW9uOiAnT0F1dGggY2xpZW50IGFzc29jaWF0ZWQgd2l0aCB0aGUgY29uc2VudCcgfVxuICAgIH0pLFxuICAgIHVzZXJJZDogKCkgPT4gKHtcbiAgICAgIGFkbWluOiB7IHJlYWRPbmx5OiB0cnVlLCBkZXNjcmlwdGlvbjogJ1VzZXIgYXNzb2NpYXRlZCB3aXRoIHRoZSBjb25zZW50JyB9XG4gICAgfSksXG4gICAgc2NvcGVzOiAoKSA9PiAoe1xuICAgICAgYWRtaW46IHsgcmVhZE9ubHk6IHRydWUsIGRlc2NyaXB0aW9uOiAnQ29tbWEtc2VwYXJhdGVkIGxpc3Qgb2Ygc2NvcGVzIGNvbnNlbnRlZCB0bycgfVxuICAgIH0pLFxuICAgIGNvbnNlbnRHaXZlbjogKCkgPT4gKHtcbiAgICAgIGRlZmF1bHRWYWx1ZTogZmFsc2UsXG4gICAgICBhZG1pbjogeyByZWFkT25seTogdHJ1ZSwgZGVzY3JpcHRpb246ICdJbmRpY2F0ZXMgaWYgY29uc2VudCB3YXMgZ2l2ZW4nIH1cbiAgICB9KVxuICB9XG5cbiAgY29uc3Qgb2F1dGhDb25zZW50RmllbGRSdWxlczogRmllbGRSdWxlW10gPSBbXG4gICAge1xuICAgICAgY29uZGl0aW9uOiAoZmllbGQpID0+IGZpZWxkLnR5cGUgPT09ICdkYXRlJyxcbiAgICAgIHRyYW5zZm9ybTogKGZpZWxkKSA9PiAoe1xuICAgICAgICAuLi5maWVsZCxcbiAgICAgICAgc2F2ZVRvSldUOiBmYWxzZSxcbiAgICAgICAgYWRtaW46IHtcbiAgICAgICAgICBkaXNhYmxlQnVsa0VkaXQ6IHRydWUsXG4gICAgICAgICAgaGlkZGVuOiB0cnVlXG4gICAgICAgIH0sXG4gICAgICAgIGluZGV4OiB0cnVlLFxuICAgICAgICBsYWJlbDogKHsgdCB9OiBhbnkpID0+IHQoJ2dlbmVyYWw6dXBkYXRlZEF0JylcbiAgICAgIH0pXG4gICAgfVxuICBdXG5cbiAgY29uc3QgY29sbGVjdGlvbkZpZWxkcyA9IGdldENvbGxlY3Rpb25GaWVsZHMoe1xuICAgIHNjaGVtYTogb2F1dGhDb25zZW50U2NoZW1hLFxuICAgIGZpZWxkUnVsZXM6IG9hdXRoQ29uc2VudEZpZWxkUnVsZXMsXG4gICAgYWRkaXRpb25hbFByb3BlcnRpZXM6IGZpZWxkT3ZlcnJpZGVzXG4gIH0pXG5cbiAgbGV0IG9hdXRoQ29uc2VudENvbGxlY3Rpb246IENvbGxlY3Rpb25Db25maWcgPSB7XG4gICAgLi4uZXhpc3RpbmdPYXV0aENvbnNlbnRDb2xsZWN0aW9uLFxuICAgIHNsdWc6IG9hdXRoQ29uc2VudFNsdWcsXG4gICAgYWRtaW46IHtcbiAgICAgIGhpZGRlbjogcGx1Z2luT3B0aW9ucy5oaWRlUGx1Z2luQ29sbGVjdGlvbnMgPz8gZmFsc2UsXG4gICAgICBkZXNjcmlwdGlvbjogJ09BdXRoIGNvbnNlbnRzIGFyZSB1c2VkIHRvIHN0b3JlIHVzZXIgY29uc2VudHMgZm9yIE9BdXRoIGNsaWVudHMnLFxuICAgICAgZ3JvdXA6IHBsdWdpbk9wdGlvbnM/LmNvbGxlY3Rpb25BZG1pbkdyb3VwID8/ICdBdXRoJyxcbiAgICAgIC4uLmV4aXN0aW5nT2F1dGhDb25zZW50Q29sbGVjdGlvbj8uYWRtaW5cbiAgICB9LFxuICAgIGFjY2Vzczoge1xuICAgICAgLi4uZ2V0QWRtaW5BY2Nlc3MocGx1Z2luT3B0aW9ucyksXG4gICAgICAuLi4oZXhpc3RpbmdPYXV0aENvbnNlbnRDb2xsZWN0aW9uPy5hY2Nlc3MgPz8ge30pXG4gICAgfSxcbiAgICBjdXN0b206IHtcbiAgICAgIC4uLihleGlzdGluZ09hdXRoQ29uc2VudENvbGxlY3Rpb24/LmN1c3RvbSA/PyB7fSksXG4gICAgICBiZXR0ZXJBdXRoTW9kZWxLZXk6IGJhTW9kZWxLZXkub2F1dGhDb25zZW50XG4gICAgfSxcbiAgICBmaWVsZHM6IFsuLi4oZXhpc3RpbmdPYXV0aENvbnNlbnRDb2xsZWN0aW9uPy5maWVsZHMgPz8gW10pLCAuLi4oY29sbGVjdGlvbkZpZWxkcyA/PyBbXSldXG4gIH1cblxuICBpZiAodHlwZW9mIHBsdWdpbk9wdGlvbnMucGx1Z2luQ29sbGVjdGlvbk92ZXJyaWRlcz8ub2F1dGhDb25zZW50cyA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIG9hdXRoQ29uc2VudENvbGxlY3Rpb24gPSBwbHVnaW5PcHRpb25zLnBsdWdpbkNvbGxlY3Rpb25PdmVycmlkZXMub2F1dGhDb25zZW50cyh7XG4gICAgICBjb2xsZWN0aW9uOiBvYXV0aENvbnNlbnRDb2xsZWN0aW9uXG4gICAgfSlcbiAgfVxuXG4gIGFzc2VydEFsbFNjaGVtYUZpZWxkcyhvYXV0aENvbnNlbnRDb2xsZWN0aW9uLCBvYXV0aENvbnNlbnRTY2hlbWEpXG5cbiAgcmV0dXJuIG9hdXRoQ29uc2VudENvbGxlY3Rpb25cbn1cbiJdLCJuYW1lcyI6WyJiYU1vZGVsS2V5IiwiZ2V0QWRtaW5BY2Nlc3MiLCJnZXRDb2xsZWN0aW9uRmllbGRzIiwiYXNzZXJ0QWxsU2NoZW1hRmllbGRzIiwiZ2V0U2NoZW1hQ29sbGVjdGlvblNsdWciLCJidWlsZE9hdXRoQ29uc2VudHNDb2xsZWN0aW9uIiwiaW5jb21pbmdDb2xsZWN0aW9ucyIsInBsdWdpbk9wdGlvbnMiLCJyZXNvbHZlZFNjaGVtYXMiLCJvYXV0aENvbnNlbnRTbHVnIiwib2F1dGhDb25zZW50Iiwib2F1dGhDb25zZW50U2NoZW1hIiwiZXhpc3RpbmdPYXV0aENvbnNlbnRDb2xsZWN0aW9uIiwiZmluZCIsImNvbGxlY3Rpb24iLCJzbHVnIiwiZmllbGRPdmVycmlkZXMiLCJjbGllbnRJZCIsImFkbWluIiwicmVhZE9ubHkiLCJkZXNjcmlwdGlvbiIsInVzZXJJZCIsInNjb3BlcyIsImNvbnNlbnRHaXZlbiIsImRlZmF1bHRWYWx1ZSIsIm9hdXRoQ29uc2VudEZpZWxkUnVsZXMiLCJjb25kaXRpb24iLCJmaWVsZCIsInR5cGUiLCJ0cmFuc2Zvcm0iLCJzYXZlVG9KV1QiLCJkaXNhYmxlQnVsa0VkaXQiLCJoaWRkZW4iLCJpbmRleCIsImxhYmVsIiwidCIsImNvbGxlY3Rpb25GaWVsZHMiLCJzY2hlbWEiLCJmaWVsZFJ1bGVzIiwiYWRkaXRpb25hbFByb3BlcnRpZXMiLCJvYXV0aENvbnNlbnRDb2xsZWN0aW9uIiwiaGlkZVBsdWdpbkNvbGxlY3Rpb25zIiwiZ3JvdXAiLCJjb2xsZWN0aW9uQWRtaW5Hcm91cCIsImFjY2VzcyIsImN1c3RvbSIsImJldHRlckF1dGhNb2RlbEtleSIsImZpZWxkcyIsInBsdWdpbkNvbGxlY3Rpb25PdmVycmlkZXMiLCJvYXV0aENvbnNlbnRzIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxVQUFVLFFBQVEsa0JBQWlCO0FBQzVDLFNBQVNDLGNBQWMsUUFBUSxpQ0FBZ0M7QUFFL0QsU0FBU0MsbUJBQW1CLFFBQVEsNkNBQTRDO0FBQ2hGLFNBQVNDLHFCQUFxQixRQUFRLDRCQUEyQjtBQU1qRSxTQUFTQyx1QkFBdUIsUUFBUSw0QkFBMkI7QUFFbkUsT0FBTyxTQUFTQyw2QkFBNkIsRUFDM0NDLG1CQUFtQixFQUNuQkMsYUFBYSxFQUNiQyxlQUFlLEVBQ007SUFDckIsTUFBTUMsbUJBQW1CTCx3QkFBd0JJLGlCQUFpQlIsV0FBV1UsWUFBWTtJQUN6RixNQUFNQyxxQkFBcUJILGVBQWUsQ0FBQ1IsV0FBV1UsWUFBWSxDQUFDO0lBRW5FLE1BQU1FLGlDQUFpQ04sb0JBQW9CTyxJQUFJLENBQUMsQ0FBQ0MsYUFBZUEsV0FBV0MsSUFBSSxLQUFLTjtJQUlwRyxNQUFNTyxpQkFBcUQ7UUFDekRDLFVBQVUsSUFBTyxDQUFBO2dCQUNmQyxPQUFPO29CQUFFQyxVQUFVO29CQUFNQyxhQUFhO2dCQUEyQztZQUNuRixDQUFBO1FBQ0FDLFFBQVEsSUFBTyxDQUFBO2dCQUNiSCxPQUFPO29CQUFFQyxVQUFVO29CQUFNQyxhQUFhO2dCQUFtQztZQUMzRSxDQUFBO1FBQ0FFLFFBQVEsSUFBTyxDQUFBO2dCQUNiSixPQUFPO29CQUFFQyxVQUFVO29CQUFNQyxhQUFhO2dCQUE4QztZQUN0RixDQUFBO1FBQ0FHLGNBQWMsSUFBTyxDQUFBO2dCQUNuQkMsY0FBYztnQkFDZE4sT0FBTztvQkFBRUMsVUFBVTtvQkFBTUMsYUFBYTtnQkFBaUM7WUFDekUsQ0FBQTtJQUNGO0lBRUEsTUFBTUsseUJBQXNDO1FBQzFDO1lBQ0VDLFdBQVcsQ0FBQ0MsUUFBVUEsTUFBTUMsSUFBSSxLQUFLO1lBQ3JDQyxXQUFXLENBQUNGLFFBQVcsQ0FBQTtvQkFDckIsR0FBR0EsS0FBSztvQkFDUkcsV0FBVztvQkFDWFosT0FBTzt3QkFDTGEsaUJBQWlCO3dCQUNqQkMsUUFBUTtvQkFDVjtvQkFDQUMsT0FBTztvQkFDUEMsT0FBTyxDQUFDLEVBQUVDLENBQUMsRUFBTyxHQUFLQSxFQUFFO2dCQUMzQixDQUFBO1FBQ0Y7S0FDRDtJQUVELE1BQU1DLG1CQUFtQmxDLG9CQUFvQjtRQUMzQ21DLFFBQVExQjtRQUNSMkIsWUFBWWI7UUFDWmMsc0JBQXNCdkI7SUFDeEI7SUFFQSxJQUFJd0IseUJBQTJDO1FBQzdDLEdBQUc1Qiw4QkFBOEI7UUFDakNHLE1BQU1OO1FBQ05TLE9BQU87WUFDTGMsUUFBUXpCLGNBQWNrQyxxQkFBcUIsSUFBSTtZQUMvQ3JCLGFBQWE7WUFDYnNCLE9BQU9uQyxlQUFlb0Msd0JBQXdCO1lBQzlDLEdBQUcvQixnQ0FBZ0NNLEtBQUs7UUFDMUM7UUFDQTBCLFFBQVE7WUFDTixHQUFHM0MsZUFBZU0sY0FBYztZQUNoQyxHQUFJSyxnQ0FBZ0NnQyxVQUFVLENBQUMsQ0FBQztRQUNsRDtRQUNBQyxRQUFRO1lBQ04sR0FBSWpDLGdDQUFnQ2lDLFVBQVUsQ0FBQyxDQUFDO1lBQ2hEQyxvQkFBb0I5QyxXQUFXVSxZQUFZO1FBQzdDO1FBQ0FxQyxRQUFRO2VBQUtuQyxnQ0FBZ0NtQyxVQUFVLEVBQUU7ZUFBT1gsb0JBQW9CLEVBQUU7U0FBRTtJQUMxRjtJQUVBLElBQUksT0FBTzdCLGNBQWN5Qyx5QkFBeUIsRUFBRUMsa0JBQWtCLFlBQVk7UUFDaEZULHlCQUF5QmpDLGNBQWN5Qyx5QkFBeUIsQ0FBQ0MsYUFBYSxDQUFDO1lBQzdFbkMsWUFBWTBCO1FBQ2Q7SUFDRjtJQUVBckMsc0JBQXNCcUMsd0JBQXdCN0I7SUFFOUMsT0FBTzZCO0FBQ1QifQ==
@@ -1,7 +1,7 @@
1
1
  import { baModelKey, baseSlugs } from "../../constants";
2
2
  import { getAdminAccess } from "../../helpers/get-admin-access";
3
3
  import { getCollectionFields } from "./utils/transform-schema-fields-to-payload";
4
- import { getDeafultCollectionSlug } from "../../helpers/get-collection-slug";
4
+ import { getDefaultCollectionSlug } from "../../helpers/get-collection-slug";
5
5
  import { assertAllSchemaFields } from "./utils/collection-schema";
6
6
  import { getSchemaCollectionSlug } from "./utils/collection-schema";
7
7
  export function buildSessionsCollection({ incomingCollections, pluginOptions, resolvedSchemas }) {
@@ -15,7 +15,7 @@ export function buildSessionsCollection({ incomingCollections, pluginOptions, re
15
15
  readOnly: true,
16
16
  description: 'The user that the session belongs to'
17
17
  },
18
- relationTo: getDeafultCollectionSlug({
18
+ relationTo: getDefaultCollectionSlug({
19
19
  modelKey: baModelKey.user,
20
20
  pluginOptions
21
21
  })
@@ -62,7 +62,7 @@ export function buildSessionsCollection({ incomingCollections, pluginOptions, re
62
62
  activeOrganizationId: ()=>({
63
63
  type: 'relationship',
64
64
  saveToJWT: true,
65
- relationTo: getDeafultCollectionSlug({
65
+ relationTo: getDefaultCollectionSlug({
66
66
  modelKey: baModelKey.organization,
67
67
  pluginOptions
68
68
  }),
@@ -123,4 +123,4 @@ export function buildSessionsCollection({ incomingCollections, pluginOptions, re
123
123
  return sessionCollection;
124
124
  }
125
125
 
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/sessions.ts"],"sourcesContent":["import { baModelKey, baModelKeyToSlug, baseSlugs } from '../../constants'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\nimport { getCollectionFields } from './utils/transform-schema-fields-to-payload'\nimport { getDeafultCollectionSlug } from '../../helpers/get-collection-slug'\nimport { assertAllSchemaFields } from './utils/collection-schema'\n\nimport type { CollectionConfig } from 'payload'\nimport type { Session } from '@/better-auth/generated-types'\nimport type { FieldRule } from './utils/model-field-transformations'\nimport type { BuildCollectionProps, FieldOverrides } from '@/better-auth/plugin/types'\nimport { getSchemaCollectionSlug } from './utils/collection-schema'\n\nexport function buildSessionsCollection({ incomingCollections, pluginOptions, resolvedSchemas }: BuildCollectionProps): CollectionConfig {\n  const sessionSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.session)\n  const sessionSchema = resolvedSchemas[baModelKey.session]\n\n  const existingSessionCollection = incomingCollections.find((collection) => collection.slug === sessionSlug) as\n    | CollectionConfig\n    | undefined\n\n  const fieldOverrides: FieldOverrides<keyof Session> = {\n    userId: () => ({\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The user that the session belongs to' },\n      relationTo: getDeafultCollectionSlug({ modelKey: baModelKey.user, pluginOptions })\n    }),\n    token: () => ({\n      index: true,\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The unique session token' }\n    }),\n    expiresAt: () => ({\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The date and time when the session will expire' }\n    }),\n    ipAddress: () => ({\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The IP address of the device' }\n    }),\n    userAgent: () => ({\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The user agent information of the device' }\n    }),\n    impersonatedBy: () => ({\n      type: 'relationship',\n      relationTo: pluginOptions.users?.slug ?? baseSlugs.users,\n      required: false,\n      saveToJWT: true,\n      admin: {\n        readOnly: true,\n        description: 'The admin who is impersonating this session'\n      }\n    }),\n    activeOrganizationId: () => ({\n      type: 'relationship',\n      saveToJWT: true,\n      relationTo: getDeafultCollectionSlug({ modelKey: baModelKey.organization, pluginOptions }),\n      admin: {\n        readOnly: true,\n        description: 'The currently active organization for the session'\n      }\n    })\n  }\n\n  const sessionFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.fieldName === 'updatedAt' || field.fieldName === 'createdAt',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => t('general:updatedAt')\n      })\n    }\n  ]\n\n  const collectionFields = getCollectionFields({\n    schema: sessionSchema,\n    fieldRules: sessionFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let sessionCollection: CollectionConfig = {\n    ...existingSessionCollection,\n    slug: sessionSlug,\n    admin: {\n      hidden: pluginOptions.sessions?.hidden,\n      description: 'Sessions are active sessions for users. They are used to authenticate users with a session token',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingSessionCollection?.admin\n    },\n    access: {\n      ...getAdminAccess(pluginOptions),\n      ...(existingSessionCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingSessionCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.session\n    },\n    fields: [...(existingSessionCollection?.fields ?? []), ...(collectionFields ?? [])]\n  }\n\n  if (typeof pluginOptions.sessions?.collectionOverrides === 'function') {\n    sessionCollection = pluginOptions.sessions.collectionOverrides({\n      collection: sessionCollection\n    })\n  }\n\n  assertAllSchemaFields(sessionCollection, sessionSchema)\n\n  return sessionCollection\n}\n"],"names":["baModelKey","baseSlugs","getAdminAccess","getCollectionFields","getDeafultCollectionSlug","assertAllSchemaFields","getSchemaCollectionSlug","buildSessionsCollection","incomingCollections","pluginOptions","resolvedSchemas","sessionSlug","session","sessionSchema","existingSessionCollection","find","collection","slug","fieldOverrides","userId","saveToJWT","admin","readOnly","description","relationTo","modelKey","user","token","index","expiresAt","ipAddress","userAgent","impersonatedBy","type","users","required","activeOrganizationId","organization","sessionFieldRules","condition","field","fieldName","transform","disableBulkEdit","hidden","label","t","collectionFields","schema","fieldRules","additionalProperties","sessionCollection","sessions","group","collectionAdminGroup","access","custom","betterAuthModelKey","fields","collectionOverrides"],"mappings":"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"}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/better-auth/plugin/lib/build-collections/sessions.ts"],"sourcesContent":["import { baModelKey, baModelKeyToSlug, baseSlugs } from '../../constants'\nimport { getAdminAccess } from '../../helpers/get-admin-access'\nimport { getCollectionFields } from './utils/transform-schema-fields-to-payload'\nimport { getDefaultCollectionSlug } from '../../helpers/get-collection-slug'\nimport { assertAllSchemaFields } from './utils/collection-schema'\n\nimport type { CollectionConfig } from 'payload'\nimport type { Session } from '@/better-auth/generated-types'\nimport type { FieldRule } from './utils/model-field-transformations'\nimport type { BuildCollectionProps, FieldOverrides } from '@/better-auth/plugin/types'\nimport { getSchemaCollectionSlug } from './utils/collection-schema'\n\nexport function buildSessionsCollection({ incomingCollections, pluginOptions, resolvedSchemas }: BuildCollectionProps): CollectionConfig {\n  const sessionSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.session)\n  const sessionSchema = resolvedSchemas[baModelKey.session]\n\n  const existingSessionCollection = incomingCollections.find((collection) => collection.slug === sessionSlug) as\n    | CollectionConfig\n    | undefined\n\n  const fieldOverrides: FieldOverrides<keyof Session> = {\n    userId: () => ({\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The user that the session belongs to' },\n      relationTo: getDefaultCollectionSlug({ modelKey: baModelKey.user, pluginOptions })\n    }),\n    token: () => ({\n      index: true,\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The unique session token' }\n    }),\n    expiresAt: () => ({\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The date and time when the session will expire' }\n    }),\n    ipAddress: () => ({\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The IP address of the device' }\n    }),\n    userAgent: () => ({\n      saveToJWT: true,\n      admin: { readOnly: true, description: 'The user agent information of the device' }\n    }),\n    impersonatedBy: () => ({\n      type: 'relationship',\n      relationTo: pluginOptions.users?.slug ?? baseSlugs.users,\n      required: false,\n      saveToJWT: true,\n      admin: {\n        readOnly: true,\n        description: 'The admin who is impersonating this session'\n      }\n    }),\n    activeOrganizationId: () => ({\n      type: 'relationship',\n      saveToJWT: true,\n      relationTo: getDefaultCollectionSlug({ modelKey: baModelKey.organization, pluginOptions }),\n      admin: {\n        readOnly: true,\n        description: 'The currently active organization for the session'\n      }\n    })\n  }\n\n  const sessionFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.fieldName === 'updatedAt' || field.fieldName === 'createdAt',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => t('general:updatedAt')\n      })\n    }\n  ]\n\n  const collectionFields = getCollectionFields({\n    schema: sessionSchema,\n    fieldRules: sessionFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let sessionCollection: CollectionConfig = {\n    ...existingSessionCollection,\n    slug: sessionSlug,\n    admin: {\n      hidden: pluginOptions.sessions?.hidden,\n      description: 'Sessions are active sessions for users. They are used to authenticate users with a session token',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingSessionCollection?.admin\n    },\n    access: {\n      ...getAdminAccess(pluginOptions),\n      ...(existingSessionCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingSessionCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.session\n    },\n    fields: [...(existingSessionCollection?.fields ?? []), ...(collectionFields ?? [])]\n  }\n\n  if (typeof pluginOptions.sessions?.collectionOverrides === 'function') {\n    sessionCollection = pluginOptions.sessions.collectionOverrides({\n      collection: sessionCollection\n    })\n  }\n\n  assertAllSchemaFields(sessionCollection, sessionSchema)\n\n  return sessionCollection\n}\n"],"names":["baModelKey","baseSlugs","getAdminAccess","getCollectionFields","getDefaultCollectionSlug","assertAllSchemaFields","getSchemaCollectionSlug","buildSessionsCollection","incomingCollections","pluginOptions","resolvedSchemas","sessionSlug","session","sessionSchema","existingSessionCollection","find","collection","slug","fieldOverrides","userId","saveToJWT","admin","readOnly","description","relationTo","modelKey","user","token","index","expiresAt","ipAddress","userAgent","impersonatedBy","type","users","required","activeOrganizationId","organization","sessionFieldRules","condition","field","fieldName","transform","disableBulkEdit","hidden","label","t","collectionFields","schema","fieldRules","additionalProperties","sessionCollection","sessions","group","collectionAdminGroup","access","custom","betterAuthModelKey","fields","collectionOverrides"],"mappings":"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"}
@@ -296,4 +296,4 @@ export function buildUsersCollection({ incomingCollections, pluginOptions, resol
296
296
  return usersCollection;
297
297
  }
298
298
 
299
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/lib/build-collections/users/index.ts"],"sourcesContent":["import { checkPluginExists } from '@/better-auth/plugin/helpers/check-plugin-exists'\nimport { getDeafultCollectionSlug } from '@/better-auth/plugin/helpers/get-collection-slug'\nimport { baModelFieldKeys, baModelKey, defaults, supportedBAPluginIds } from '../../../constants'\nimport { getAllRoleOptions } from '../../../helpers/get-all-roles'\nimport { assertAllSchemaFields, getSchemaCollectionSlug, getSchemaFieldName } from '../utils/collection-schema'\nimport { isAdminOrCurrentUserUpdateWithAllowedFields, isAdminOrCurrentUserWithRoles, isAdminWithRoles } from '../utils/payload-access'\nimport { getCollectionFields } from '../utils/transform-schema-fields-to-payload'\nimport { betterAuthStrategy } from './better-auth-strategy'\nimport { getGenerateInviteUrlEndpoint, getRefreshTokenEndpoint, getSendInviteUrlEndpoint, getSetAdminRoleEndpoint } from './endpoints'\nimport {\n  getSyncAccountHook,\n  getAfterLoginHook,\n  getAfterLogoutHook,\n  getBeforeDeleteHook,\n  getBeforeLoginHook,\n  getOnVerifiedChangeHook\n} from './hooks'\n\nimport type { CollectionConfig, UIField } from 'payload'\nimport type { FieldRule } from '../utils/model-field-transformations'\nimport type { BuildCollectionProps, FieldOverrides } from '../../../types'\nimport type { User } from '@/better-auth/generated-types'\n\nexport function buildUsersCollection({ incomingCollections, pluginOptions, resolvedSchemas }: BuildCollectionProps): CollectionConfig {\n  const userSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.user)\n  const passkeySlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.passkey)\n  const passkeyUserIdFieldName = getSchemaFieldName(resolvedSchemas, baModelKey.passkey, baModelFieldKeys.passkey.userId)\n  const userSchema = resolvedSchemas[baModelKey.user]\n  const adminRoles = pluginOptions.users?.adminRoles ?? [defaults.adminRole]\n  const allRoleOptions = getAllRoleOptions(pluginOptions)\n  const hasUsernamePlugin = checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.username)\n  const existingUserCollection = incomingCollections.find((collection) => collection.slug === userSlug) as CollectionConfig | undefined\n\n  // TODO: REVIEW THIS\n  const allowedFields = pluginOptions.users?.allowedFields ?? ['name']\n\n  const userFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.fieldName === 'createdAt' || field.fieldName === 'updatedAt',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => field.fieldName === 'createdAt' ? t('general:createdAt') : t('general:updatedAt')\n      })\n    }\n  ]\n\n  const fieldOverrides: FieldOverrides<keyof User> = {\n    role: (field) => ({\n      type: 'select',\n      options: allRoleOptions,\n      defaultValue: field.defaultValue ?? defaults.userRole,\n      saveToJWT: true,\n      admin: { description: 'The role of the user' }\n    }),\n    email: () => ({\n      index: true,\n      admin: { description: 'The email of the user' }\n    }),\n    emailVerified: (field) => ({\n      defaultValue: field.defaultValue ?? false,\n      saveToJWT: true,\n      admin: { description: 'Whether the email of the user has been verified' }\n    }),\n    name: () => ({\n      saveToJWT: true,\n      admin: { description: 'Users chosen display name' }\n    }),\n    image: () => ({\n      saveToJWT: false,\n      admin: { description: 'The image of the user' }\n    }),\n    twoFactorEnabled: () => ({\n      defaultValue: false,\n      admin: {\n        description: 'Whether the user has two factor authentication enabled',\n        components: {\n          Field: {\n            path: 'payload-auth/better-auth/plugin/client#TwoFactorAuth'\n          }\n        }\n      }\n    }),\n    username: () => ({\n      admin: { description: 'The username of the user' }\n    }),\n    displayUsername: () => ({\n      admin: { description: 'The display username of the user' }\n    }),\n    isAnonymous: () => ({\n      defaultValue: false,\n      admin: { description: 'Whether the user is anonymous.' }\n    }),\n    phoneNumber: () => ({\n      admin: { description: 'The phone number of the user' }\n    }),\n    phoneNumberVerified: () => ({\n      defaultValue: false,\n      admin: { description: 'Whether the phone number of the user has been verified' }\n    }),\n    banned: () => ({\n      defaultValue: false,\n      admin: { description: 'Whether the user is banned from the platform' }\n    }),\n    banReason: () => ({\n      admin: { description: 'The reason for the ban' }\n    }),\n    banExpires: () => ({\n      admin: { description: 'The date and time when the ban will expire' }\n    }),\n    normalizedEmail: () => ({\n      admin: {\n        readOnly: true,\n        description: 'The normalized email of the user'\n      }\n    }),\n    stripeCustomerId: () => ({\n      admin: {\n        readOnly: true,\n        description: 'The Stripe customer ID of the user'\n      }\n    })\n  }\n\n  const collectionFields = getCollectionFields({\n    schema: userSchema,\n    fieldRules: userFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let usersCollection: CollectionConfig = {\n    ...existingUserCollection,\n    slug: userSlug,\n    admin: {\n      defaultColumns: ['email'],\n      useAsTitle: 'email',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingUserCollection?.admin,\n      hidden: pluginOptions.users?.hidden ?? false,\n      components: {\n        Description: {\n          path: 'payload-auth/better-auth/plugin/client#AdminInviteButton',\n          clientProps: {\n            roles: allRoleOptions\n          }\n        },\n        views: {\n          edit: {\n            adminButtons: {\n              tab: {\n                Component: {\n                  path: 'payload-auth/better-auth/plugin/client#AdminButtons',\n                  clientProps: {\n                    userSlug\n                  }\n                },\n                condition: () => {\n                  // Only show the impersonate button if the admin plugin is enabled\n                  return checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.admin)\n                }\n              }\n            }\n          }\n        }\n      }\n    },\n    access: {\n      admin: ({ req }) => adminRoles.includes((req.user?.role as string) ?? 'user'),\n      read: isAdminOrCurrentUserWithRoles({ adminRoles, idField: 'id' }),\n      create: isAdminWithRoles({ adminRoles }),\n      delete: isAdminOrCurrentUserWithRoles({ adminRoles, idField: 'id' }),\n      update: isAdminOrCurrentUserUpdateWithAllowedFields({\n        allowedFields,\n        adminRoles,\n        userSlug\n      }),\n      ...(existingUserCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingUserCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.user\n    },\n    endpoints: [\n      ...(existingUserCollection?.endpoints ? existingUserCollection.endpoints : []),\n      getRefreshTokenEndpoint(userSlug),\n      getSetAdminRoleEndpoint(pluginOptions, userSlug),\n      getGenerateInviteUrlEndpoint({\n        roles: allRoleOptions,\n        pluginOptions\n      }),\n      getSendInviteUrlEndpoint(pluginOptions)\n    ],\n    hooks: {\n      beforeChange: [\n        ...(existingUserCollection?.hooks?.beforeChange ?? []),\n        ...(pluginOptions.disableDefaultPayloadAuth ? [] : [getOnVerifiedChangeHook()])\n      ],\n      afterChange: [\n        ...(existingUserCollection?.hooks?.afterChange ?? []),\n        ...(pluginOptions.disableDefaultPayloadAuth ? [] : [getSyncAccountHook()])\n      ],\n      beforeLogin: [\n        ...(existingUserCollection?.hooks?.beforeLogin ?? []),\n        ...(pluginOptions.disableDefaultPayloadAuth ? [] : [getBeforeLoginHook(pluginOptions.betterAuthOptions ?? {})])\n      ],\n      afterLogin: [\n        ...(existingUserCollection?.hooks?.afterLogin ?? []),\n        ...(pluginOptions.disableDefaultPayloadAuth ? [] : [getAfterLoginHook()])\n      ],\n      afterLogout: [...(existingUserCollection?.hooks?.afterLogout ?? []), getAfterLogoutHook()],\n      beforeDelete: [...(existingUserCollection?.hooks?.beforeDelete ?? []), getBeforeDeleteHook()]\n    },\n    auth: {\n      ...(existingUserCollection && typeof existingUserCollection.auth === 'object' ? existingUserCollection.auth : {}),\n      disableLocalStrategy: pluginOptions.disableDefaultPayloadAuth ? true : undefined,\n      ...(hasUsernamePlugin && {\n        loginWithUsername: {\n          allowEmailLogin: true,\n          requireEmail: true,\n          requireUsername: false\n        }\n      }),\n      strategies: [betterAuthStrategy(userSlug)]\n    },\n    fields: [\n      ...(existingUserCollection?.fields ?? []),\n      ...(collectionFields ?? []),\n      ...(checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.passkey)\n        ? [\n            {\n              name: 'managePasskeys',\n              type: 'ui' as const,\n              admin: {\n                disableBulkEdit: true,\n                components: {\n                  Field: {\n                    path: 'payload-auth/better-auth/plugin/rsc#Passkeys',\n                    serverProps: {\n                      passkeyUserIdFieldName,\n                      passkeySlug\n                    }\n                  }\n                }\n              }\n            } as UIField\n          ]\n        : [])\n    ]\n  }\n\n  if (pluginOptions.users?.collectionOverrides) {\n    usersCollection = pluginOptions.users.collectionOverrides({\n      collection: usersCollection\n    })\n  }\n\n  assertAllSchemaFields(usersCollection, userSchema)\n\n  return usersCollection\n}\n"],"names":["checkPluginExists","baModelFieldKeys","baModelKey","defaults","supportedBAPluginIds","getAllRoleOptions","assertAllSchemaFields","getSchemaCollectionSlug","getSchemaFieldName","isAdminOrCurrentUserUpdateWithAllowedFields","isAdminOrCurrentUserWithRoles","isAdminWithRoles","getCollectionFields","betterAuthStrategy","getGenerateInviteUrlEndpoint","getRefreshTokenEndpoint","getSendInviteUrlEndpoint","getSetAdminRoleEndpoint","getSyncAccountHook","getAfterLoginHook","getAfterLogoutHook","getBeforeDeleteHook","getBeforeLoginHook","getOnVerifiedChangeHook","buildUsersCollection","incomingCollections","pluginOptions","resolvedSchemas","userSlug","user","passkeySlug","passkey","passkeyUserIdFieldName","userId","userSchema","adminRoles","users","adminRole","allRoleOptions","hasUsernamePlugin","betterAuthOptions","username","existingUserCollection","find","collection","slug","allowedFields","userFieldRules","condition","field","fieldName","transform","saveToJWT","admin","disableBulkEdit","hidden","index","label","t","fieldOverrides","role","type","options","defaultValue","userRole","description","email","emailVerified","name","image","twoFactorEnabled","components","Field","path","displayUsername","isAnonymous","phoneNumber","phoneNumberVerified","banned","banReason","banExpires","normalizedEmail","readOnly","stripeCustomerId","collectionFields","schema","fieldRules","additionalProperties","usersCollection","defaultColumns","useAsTitle","group","collectionAdminGroup","Description","clientProps","roles","views","edit","adminButtons","tab","Component","access","req","includes","read","idField","create","delete","update","custom","betterAuthModelKey","endpoints","hooks","beforeChange","disableDefaultPayloadAuth","afterChange","beforeLogin","afterLogin","afterLogout","beforeDelete","auth","disableLocalStrategy","undefined","loginWithUsername","allowEmailLogin","requireEmail","requireUsername","strategies","fields","serverProps","collectionOverrides"],"mappings":"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"}
299
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/lib/build-collections/users/index.ts"],"sourcesContent":["import { checkPluginExists } from '@/better-auth/plugin/helpers/check-plugin-exists'\nimport { getDefaultCollectionSlug } from '@/better-auth/plugin/helpers/get-collection-slug'\nimport { baModelFieldKeys, baModelKey, defaults, supportedBAPluginIds } from '../../../constants'\nimport { getAllRoleOptions } from '../../../helpers/get-all-roles'\nimport { assertAllSchemaFields, getSchemaCollectionSlug, getSchemaFieldName } from '../utils/collection-schema'\nimport { isAdminOrCurrentUserUpdateWithAllowedFields, isAdminOrCurrentUserWithRoles, isAdminWithRoles } from '../utils/payload-access'\nimport { getCollectionFields } from '../utils/transform-schema-fields-to-payload'\nimport { betterAuthStrategy } from './better-auth-strategy'\nimport { getGenerateInviteUrlEndpoint, getRefreshTokenEndpoint, getSendInviteUrlEndpoint, getSetAdminRoleEndpoint } from './endpoints'\nimport {\n  getSyncAccountHook,\n  getAfterLoginHook,\n  getAfterLogoutHook,\n  getBeforeDeleteHook,\n  getBeforeLoginHook,\n  getOnVerifiedChangeHook\n} from './hooks'\n\nimport type { CollectionConfig, UIField } from 'payload'\nimport type { FieldRule } from '../utils/model-field-transformations'\nimport type { BuildCollectionProps, FieldOverrides } from '../../../types'\nimport type { User } from '@/better-auth/generated-types'\n\nexport function buildUsersCollection({ incomingCollections, pluginOptions, resolvedSchemas }: BuildCollectionProps): CollectionConfig {\n  const userSlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.user)\n  const passkeySlug = getSchemaCollectionSlug(resolvedSchemas, baModelKey.passkey)\n  const passkeyUserIdFieldName = getSchemaFieldName(resolvedSchemas, baModelKey.passkey, baModelFieldKeys.passkey.userId)\n  const userSchema = resolvedSchemas[baModelKey.user]\n  const adminRoles = pluginOptions.users?.adminRoles ?? [defaults.adminRole]\n  const allRoleOptions = getAllRoleOptions(pluginOptions)\n  const hasUsernamePlugin = checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.username)\n  const existingUserCollection = incomingCollections.find((collection) => collection.slug === userSlug) as CollectionConfig | undefined\n\n  // TODO: REVIEW THIS\n  const allowedFields = pluginOptions.users?.allowedFields ?? ['name']\n\n  const userFieldRules: FieldRule[] = [\n    {\n      condition: (field) => field.fieldName === 'createdAt' || field.fieldName === 'updatedAt',\n      transform: (field) => ({\n        ...field,\n        saveToJWT: false,\n        admin: {\n          disableBulkEdit: true,\n          hidden: true\n        },\n        index: true,\n        label: ({ t }: any) => (field.fieldName === 'createdAt' ? t('general:createdAt') : t('general:updatedAt'))\n      })\n    }\n  ]\n\n  const fieldOverrides: FieldOverrides<keyof User> = {\n    role: (field) => ({\n      type: 'select',\n      options: allRoleOptions,\n      defaultValue: field.defaultValue ?? defaults.userRole,\n      saveToJWT: true,\n      admin: { description: 'The role of the user' }\n    }),\n    email: () => ({\n      index: true,\n      admin: { description: 'The email of the user' }\n    }),\n    emailVerified: (field) => ({\n      defaultValue: field.defaultValue ?? false,\n      saveToJWT: true,\n      admin: { description: 'Whether the email of the user has been verified' }\n    }),\n    name: () => ({\n      saveToJWT: true,\n      admin: { description: 'Users chosen display name' }\n    }),\n    image: () => ({\n      saveToJWT: false,\n      admin: { description: 'The image of the user' }\n    }),\n    twoFactorEnabled: () => ({\n      defaultValue: false,\n      admin: {\n        description: 'Whether the user has two factor authentication enabled',\n        components: {\n          Field: {\n            path: 'payload-auth/better-auth/plugin/client#TwoFactorAuth'\n          }\n        }\n      }\n    }),\n    username: () => ({\n      admin: { description: 'The username of the user' }\n    }),\n    displayUsername: () => ({\n      admin: { description: 'The display username of the user' }\n    }),\n    isAnonymous: () => ({\n      defaultValue: false,\n      admin: { description: 'Whether the user is anonymous.' }\n    }),\n    phoneNumber: () => ({\n      admin: { description: 'The phone number of the user' }\n    }),\n    phoneNumberVerified: () => ({\n      defaultValue: false,\n      admin: { description: 'Whether the phone number of the user has been verified' }\n    }),\n    banned: () => ({\n      defaultValue: false,\n      admin: { description: 'Whether the user is banned from the platform' }\n    }),\n    banReason: () => ({\n      admin: { description: 'The reason for the ban' }\n    }),\n    banExpires: () => ({\n      admin: { description: 'The date and time when the ban will expire' }\n    }),\n    normalizedEmail: () => ({\n      admin: {\n        readOnly: true,\n        description: 'The normalized email of the user'\n      }\n    }),\n    stripeCustomerId: () => ({\n      admin: {\n        readOnly: true,\n        description: 'The Stripe customer ID of the user'\n      }\n    })\n  }\n\n  const collectionFields = getCollectionFields({\n    schema: userSchema,\n    fieldRules: userFieldRules,\n    additionalProperties: fieldOverrides\n  })\n\n  let usersCollection: CollectionConfig = {\n    ...existingUserCollection,\n    slug: userSlug,\n    admin: {\n      defaultColumns: ['email'],\n      useAsTitle: 'email',\n      group: pluginOptions?.collectionAdminGroup ?? 'Auth',\n      ...existingUserCollection?.admin,\n      hidden: pluginOptions.users?.hidden ?? false,\n      components: {\n        Description: {\n          path: 'payload-auth/better-auth/plugin/client#AdminInviteButton',\n          clientProps: {\n            roles: allRoleOptions\n          }\n        },\n        views: {\n          edit: {\n            adminButtons: {\n              tab: {\n                Component: {\n                  path: 'payload-auth/better-auth/plugin/client#AdminButtons',\n                  clientProps: {\n                    userSlug\n                  }\n                },\n                condition: () => {\n                  // Only show the impersonate button if the admin plugin is enabled\n                  return checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.admin)\n                }\n              }\n            }\n          }\n        }\n      }\n    },\n    access: {\n      admin: ({ req }) => adminRoles.includes((req.user?.role as string) ?? 'user'),\n      read: isAdminOrCurrentUserWithRoles({ adminRoles, idField: 'id' }),\n      create: isAdminWithRoles({ adminRoles }),\n      delete: isAdminOrCurrentUserWithRoles({ adminRoles, idField: 'id' }),\n      update: isAdminOrCurrentUserUpdateWithAllowedFields({\n        allowedFields,\n        adminRoles,\n        userSlug\n      }),\n      ...(existingUserCollection?.access ?? {})\n    },\n    custom: {\n      ...(existingUserCollection?.custom ?? {}),\n      betterAuthModelKey: baModelKey.user\n    },\n    endpoints: [\n      ...(existingUserCollection?.endpoints ? existingUserCollection.endpoints : []),\n      getRefreshTokenEndpoint(userSlug),\n      getSetAdminRoleEndpoint(pluginOptions, userSlug),\n      getGenerateInviteUrlEndpoint({\n        roles: allRoleOptions,\n        pluginOptions\n      }),\n      getSendInviteUrlEndpoint(pluginOptions)\n    ],\n    hooks: {\n      beforeChange: [\n        ...(existingUserCollection?.hooks?.beforeChange ?? []),\n        ...(pluginOptions.disableDefaultPayloadAuth ? [] : [getOnVerifiedChangeHook()])\n      ],\n      afterChange: [\n        ...(existingUserCollection?.hooks?.afterChange ?? []),\n        ...(pluginOptions.disableDefaultPayloadAuth ? [] : [getSyncAccountHook()])\n      ],\n      beforeLogin: [\n        ...(existingUserCollection?.hooks?.beforeLogin ?? []),\n        ...(pluginOptions.disableDefaultPayloadAuth ? [] : [getBeforeLoginHook(pluginOptions.betterAuthOptions ?? {})])\n      ],\n      afterLogin: [\n        ...(existingUserCollection?.hooks?.afterLogin ?? []),\n        ...(pluginOptions.disableDefaultPayloadAuth ? [] : [getAfterLoginHook()])\n      ],\n      afterLogout: [...(existingUserCollection?.hooks?.afterLogout ?? []), getAfterLogoutHook()],\n      beforeDelete: [...(existingUserCollection?.hooks?.beforeDelete ?? []), getBeforeDeleteHook()]\n    },\n    auth: {\n      ...(existingUserCollection && typeof existingUserCollection.auth === 'object' ? existingUserCollection.auth : {}),\n      disableLocalStrategy: pluginOptions.disableDefaultPayloadAuth ? true : undefined,\n      ...(hasUsernamePlugin && {\n        loginWithUsername: {\n          allowEmailLogin: true,\n          requireEmail: true,\n          requireUsername: false\n        }\n      }),\n      strategies: [betterAuthStrategy(userSlug)]\n    },\n    fields: [\n      ...(existingUserCollection?.fields ?? []),\n      ...(collectionFields ?? []),\n      ...(checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.passkey)\n        ? [\n            {\n              name: 'managePasskeys',\n              type: 'ui' as const,\n              admin: {\n                disableBulkEdit: true,\n                components: {\n                  Field: {\n                    path: 'payload-auth/better-auth/plugin/rsc#Passkeys',\n                    serverProps: {\n                      passkeyUserIdFieldName,\n                      passkeySlug\n                    }\n                  }\n                }\n              }\n            } as UIField\n          ]\n        : [])\n    ]\n  }\n\n  if (pluginOptions.users?.collectionOverrides) {\n    usersCollection = pluginOptions.users.collectionOverrides({\n      collection: usersCollection\n    })\n  }\n\n  assertAllSchemaFields(usersCollection, userSchema)\n\n  return usersCollection\n}\n"],"names":["checkPluginExists","baModelFieldKeys","baModelKey","defaults","supportedBAPluginIds","getAllRoleOptions","assertAllSchemaFields","getSchemaCollectionSlug","getSchemaFieldName","isAdminOrCurrentUserUpdateWithAllowedFields","isAdminOrCurrentUserWithRoles","isAdminWithRoles","getCollectionFields","betterAuthStrategy","getGenerateInviteUrlEndpoint","getRefreshTokenEndpoint","getSendInviteUrlEndpoint","getSetAdminRoleEndpoint","getSyncAccountHook","getAfterLoginHook","getAfterLogoutHook","getBeforeDeleteHook","getBeforeLoginHook","getOnVerifiedChangeHook","buildUsersCollection","incomingCollections","pluginOptions","resolvedSchemas","userSlug","user","passkeySlug","passkey","passkeyUserIdFieldName","userId","userSchema","adminRoles","users","adminRole","allRoleOptions","hasUsernamePlugin","betterAuthOptions","username","existingUserCollection","find","collection","slug","allowedFields","userFieldRules","condition","field","fieldName","transform","saveToJWT","admin","disableBulkEdit","hidden","index","label","t","fieldOverrides","role","type","options","defaultValue","userRole","description","email","emailVerified","name","image","twoFactorEnabled","components","Field","path","displayUsername","isAnonymous","phoneNumber","phoneNumberVerified","banned","banReason","banExpires","normalizedEmail","readOnly","stripeCustomerId","collectionFields","schema","fieldRules","additionalProperties","usersCollection","defaultColumns","useAsTitle","group","collectionAdminGroup","Description","clientProps","roles","views","edit","adminButtons","tab","Component","access","req","includes","read","idField","create","delete","update","custom","betterAuthModelKey","endpoints","hooks","beforeChange","disableDefaultPayloadAuth","afterChange","beforeLogin","afterLogin","afterLogout","beforeDelete","auth","disableLocalStrategy","undefined","loginWithUsername","allowEmailLogin","requireEmail","requireUsername","strategies","fields","serverProps","collectionOverrides"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"names":[],"mappings":"AAKA,OAAO,KAA4B,MAAM,OAAO,CAAA;AAChD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAA;AAYvD,KAAK,qBAAqB,GAAG;IAC3B,YAAY,EAAE,WAAW,EAAE,CAAA;IAC3B,iBAAiB,EAAE,OAAO,CAAA;IAC1B,gBAAgB,EAAE,OAAO,CAAA;IACzB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,YAAY,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;IAC9D,iBAAiB,EAAE,KAAK,GAAG,wBAAwB,CAAA;CACpD,CAAA;AA4HD,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CA+B5D,CAAA"}
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"names":[],"mappings":"AAKA,OAAO,KAA4B,MAAM,OAAO,CAAA;AAChD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAA;AAYvD,KAAK,qBAAqB,GAAG;IAC3B,YAAY,EAAE,WAAW,EAAE,CAAA;IAC3B,iBAAiB,EAAE,OAAO,CAAA;IAC1B,gBAAgB,EAAE,OAAO,CAAA;IACzB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,YAAY,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;IAC9D,iBAAiB,EAAE,KAAK,GAAG,wBAAwB,CAAA;CACpD,CAAA;AA6HD,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CA+B5D,CAAA"}
@@ -152,6 +152,13 @@ const LoginForm = ({ hasUsernamePlugin, hasPasskeyPlugin, prefillEmail, prefillP
152
152
  prefetch: false,
153
153
  children: t('authentication:forgotPasswordQuestion')
154
154
  }),
155
+ /*#__PURE__*/ _jsx("button", {
156
+ type: "submit",
157
+ style: {
158
+ display: 'none'
159
+ },
160
+ tabIndex: -1
161
+ }),
155
162
  /*#__PURE__*/ _jsx(form.AppForm, {
156
163
  children: /*#__PURE__*/ _jsx(form.Submit, {
157
164
  label: t('authentication:login'),
@@ -185,4 +192,4 @@ export const AdminLoginClient = ({ loginMethods, hasUsernamePlugin, hasPasskeyPl
185
192
  });
186
193
  };
187
194
 
188
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"sourcesContent":["'use client'\n\nimport { AdminSocialProviderButtons } from '@/better-auth/plugin/payload/components/social-provider-buttons'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { useConfig, Link, toast, useTranslation } from '@payloadcms/ui'\nimport React, { useMemo, useState } from 'react'\nimport type { LoginMethod } from '@/better-auth/plugin/types'\nimport type { LoginWithUsernameOptions } from 'payload'\nimport { adminRoutes } from '@/better-auth/plugin/constants'\nimport { useAppForm } from '@/shared/form'\nimport { Form, FormError, FormInputWrap } from '@/shared/form/ui'\nimport { FormHeader } from '@/shared/form/ui/header'\nimport { createLoginSchema, isValidEmail } from '@/shared/form/validation'\nimport { createAuthClient } from 'better-auth/client'\nimport { usernameClient, twoFactorClient, passkeyClient } from 'better-auth/client/plugins'\nimport { formatAdminURL, getLoginOptions } from 'payload/shared'\nimport { useRouter } from 'next/navigation'\nimport { valueOrDefaultString } from '@/shared/utils/value-or-default'\n\ntype AdminLoginClientProps = {\n  loginMethods: LoginMethod[]\n  hasUsernamePlugin: boolean\n  hasPasskeyPlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}\n\nconst baseClass = 'login__form'\n\nconst LoginForm: React.FC<{\n  hasUsernamePlugin: boolean\n  hasPasskeyPlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}> = ({ hasUsernamePlugin, hasPasskeyPlugin, prefillEmail, prefillPassword, prefillUsername, searchParams, loginWithUsername }) => {\n  const { config } = useConfig()\n  const router = useRouter()\n  const adminRoute = valueOrDefaultString(config?.routes?.admin, '/admin')\n  const { t } = useTranslation()\n  const { canLoginWithEmail, canLoginWithUsername } = getLoginOptions(loginWithUsername)\n  const searchParamError = searchParams?.error\n  const redirectUrl = getSafeRedirect(searchParams?.redirect as string, adminRoute)\n  const forgotPasswordUrl = formatAdminURL({\n    adminRoute: adminRoute,\n    path: adminRoutes?.forgotPassword as `/${string}`\n  })\n  const authClient = useMemo(\n    () =>\n      createAuthClient({\n        plugins: [\n          usernameClient(),\n          twoFactorClient({\n            onTwoFactorRedirect() {\n              router.push(`${adminRoute}${adminRoutes.twoFactorVerify}?redirect=${redirectUrl}`)\n            }\n          }),\n          ...(hasPasskeyPlugin ? [passkeyClient()] : [])\n        ]\n      }),\n    []\n  )\n  const loginType = useMemo(() => {\n    if (canLoginWithEmail && canLoginWithUsername && hasUsernamePlugin) return 'emailOrUsername'\n    if (canLoginWithUsername && hasUsernamePlugin) return 'username'\n    return 'email'\n  }, [canLoginWithEmail, canLoginWithUsername, hasUsernamePlugin])\n  const [requireEmailVerification, setRequireEmailVerification] = useState<boolean>(false)\n\n  if (requireEmailVerification) {\n    return <FormHeader heading=\"Please verify your email\" description={t('authentication:emailSent')} style={{ textAlign: 'center' }} />\n  }\n\n  const loginSchema = createLoginSchema({ t, loginType, canLoginWithUsername })\n\n  const form = useAppForm({\n    defaultValues: {\n      login: prefillEmail ?? prefillUsername ?? '',\n      password: prefillPassword ?? ''\n    },\n    onSubmit: async ({ value }) => {\n      const { login, password } = value\n      const isEmail = isValidEmail(login)\n      try {\n        const { data, error } = await (loginType === 'email' || (loginType === 'emailOrUsername' && isEmail)\n          ? authClient.signIn.email({ email: login, password, callbackURL: redirectUrl })\n          : authClient.signIn.username({ username: login, password }))\n        if (error) {\n          if (error.code === 'EMAIL_NOT_VERIFIED') {\n            setRequireEmailVerification(true)\n          }\n          if (error.message) {\n            toast.error(error.message.charAt(0).toUpperCase() + error.message.slice(1))\n          }\n        }\n        if (data?.token) {\n          toast.success(t('general:success'))\n          window.location.href = redirectUrl\n        }\n      } catch (err) {\n        toast.error(t('error:unknown') || 'An unexpected error occurred')\n      }\n    },\n    validators: {\n      onSubmit: loginSchema\n    }\n  })\n\n  const getLoginTypeLabel = () => {\n    const labels = {\n      email: t('general:email') || 'Email',\n      username: t('authentication:username') || 'Username',\n      emailOrUsername: t('authentication:emailOrUsername') || 'Email or Username'\n    }\n    return labels[loginType]\n  }\n\n  return (\n    <div className={`${baseClass}__wrapper`}>\n      {searchParamError && searchParamError === 'signup_disabled' && <FormError errors={['Sign up is disabled.']} />}\n      <Form\n        className={baseClass}\n        onSubmit={(e) => {\n          e.preventDefault()\n          void form.handleSubmit()\n        }}>\n        <FormInputWrap className={baseClass}>\n          <form.AppField\n            name=\"login\"\n            children={(field) => <field.TextField type=\"text\" className=\"email\" autoComplete={`email${hasPasskeyPlugin ? ' webauthn' : ''}`} label={getLoginTypeLabel()} />}\n          />\n          <form.AppField\n            name=\"password\"\n            children={(field) => (\n              <field.TextField type=\"password\" className=\"password\" autoComplete={`password${hasPasskeyPlugin ? ' webauthn' : ''}`} label={t('general:password')} />\n            )}\n          />\n        </FormInputWrap>\n        <Link href={forgotPasswordUrl} prefetch={false}>\n          {t('authentication:forgotPasswordQuestion')}\n        </Link>\n        <form.AppForm children={<form.Submit label={t('authentication:login')} loadingLabel={t('general:loading')} />} />\n      </Form>\n    </div>\n  )\n}\n\nexport const AdminLoginClient: React.FC<AdminLoginClientProps> = ({\n  loginMethods,\n  hasUsernamePlugin,\n  hasPasskeyPlugin,\n  prefillEmail,\n  prefillPassword,\n  prefillUsername,\n  searchParams,\n  loginWithUsername\n}) => {\n  return (\n    <>\n      {loginMethods.includes('emailPassword') && (\n        <LoginForm\n          hasUsernamePlugin={hasUsernamePlugin}\n          hasPasskeyPlugin={hasPasskeyPlugin}\n          prefillEmail={prefillEmail}\n          prefillPassword={prefillPassword}\n          prefillUsername={prefillUsername}\n          searchParams={searchParams}\n          loginWithUsername={loginWithUsername}\n        />\n      )}\n      <AdminSocialProviderButtons\n        isSignup={false}\n        loginMethods={loginMethods}\n        setLoading={() => {}}\n        redirectUrl={getSafeRedirect(searchParams?.redirect as string, useConfig().config.routes.admin)}\n      />\n    </>\n  )\n}\n"],"names":["AdminSocialProviderButtons","getSafeRedirect","useConfig","Link","toast","useTranslation","React","useMemo","useState","adminRoutes","useAppForm","Form","FormError","FormInputWrap","FormHeader","createLoginSchema","isValidEmail","createAuthClient","usernameClient","twoFactorClient","passkeyClient","formatAdminURL","getLoginOptions","useRouter","valueOrDefaultString","baseClass","LoginForm","hasUsernamePlugin","hasPasskeyPlugin","prefillEmail","prefillPassword","prefillUsername","searchParams","loginWithUsername","config","router","adminRoute","routes","admin","t","canLoginWithEmail","canLoginWithUsername","searchParamError","error","redirectUrl","redirect","forgotPasswordUrl","path","forgotPassword","authClient","plugins","onTwoFactorRedirect","push","twoFactorVerify","loginType","requireEmailVerification","setRequireEmailVerification","heading","description","style","textAlign","loginSchema","form","defaultValues","login","password","onSubmit","value","isEmail","data","signIn","email","callbackURL","username","code","message","charAt","toUpperCase","slice","token","success","window","location","href","err","validators","getLoginTypeLabel","labels","emailOrUsername","div","className","errors","e","preventDefault","handleSubmit","AppField","name","children","field","TextField","type","autoComplete","label","prefetch","AppForm","Submit","loadingLabel","AdminLoginClient","loginMethods","includes","isSignup","setLoading"],"mappings":"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"}
195
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"sourcesContent":["'use client'\n\nimport { AdminSocialProviderButtons } from '@/better-auth/plugin/payload/components/social-provider-buttons'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { useConfig, Link, toast, useTranslation } from '@payloadcms/ui'\nimport React, { useMemo, useState } from 'react'\nimport type { LoginMethod } from '@/better-auth/plugin/types'\nimport type { LoginWithUsernameOptions } from 'payload'\nimport { adminRoutes } from '@/better-auth/plugin/constants'\nimport { useAppForm } from '@/shared/form'\nimport { Form, FormError, FormInputWrap } from '@/shared/form/ui'\nimport { FormHeader } from '@/shared/form/ui/header'\nimport { createLoginSchema, isValidEmail } from '@/shared/form/validation'\nimport { createAuthClient } from 'better-auth/client'\nimport { usernameClient, twoFactorClient, passkeyClient } from 'better-auth/client/plugins'\nimport { formatAdminURL, getLoginOptions } from 'payload/shared'\nimport { useRouter } from 'next/navigation'\nimport { valueOrDefaultString } from '@/shared/utils/value-or-default'\n\ntype AdminLoginClientProps = {\n  loginMethods: LoginMethod[]\n  hasUsernamePlugin: boolean\n  hasPasskeyPlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}\n\nconst baseClass = 'login__form'\n\nconst LoginForm: React.FC<{\n  hasUsernamePlugin: boolean\n  hasPasskeyPlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}> = ({ hasUsernamePlugin, hasPasskeyPlugin, prefillEmail, prefillPassword, prefillUsername, searchParams, loginWithUsername }) => {\n  const { config } = useConfig()\n  const router = useRouter()\n  const adminRoute = valueOrDefaultString(config?.routes?.admin, '/admin')\n  const { t } = useTranslation()\n  const { canLoginWithEmail, canLoginWithUsername } = getLoginOptions(loginWithUsername)\n  const searchParamError = searchParams?.error\n  const redirectUrl = getSafeRedirect(searchParams?.redirect as string, adminRoute)\n  const forgotPasswordUrl = formatAdminURL({\n    adminRoute: adminRoute,\n    path: adminRoutes?.forgotPassword as `/${string}`\n  })\n  const authClient = useMemo(\n    () =>\n      createAuthClient({\n        plugins: [\n          usernameClient(),\n          twoFactorClient({\n            onTwoFactorRedirect() {\n              router.push(`${adminRoute}${adminRoutes.twoFactorVerify}?redirect=${redirectUrl}`)\n            }\n          }),\n          ...(hasPasskeyPlugin ? [passkeyClient()] : [])\n        ]\n      }),\n    []\n  )\n  const loginType = useMemo(() => {\n    if (canLoginWithEmail && canLoginWithUsername && hasUsernamePlugin) return 'emailOrUsername'\n    if (canLoginWithUsername && hasUsernamePlugin) return 'username'\n    return 'email'\n  }, [canLoginWithEmail, canLoginWithUsername, hasUsernamePlugin])\n  const [requireEmailVerification, setRequireEmailVerification] = useState<boolean>(false)\n\n  if (requireEmailVerification) {\n    return <FormHeader heading=\"Please verify your email\" description={t('authentication:emailSent')} style={{ textAlign: 'center' }} />\n  }\n\n  const loginSchema = createLoginSchema({ t, loginType, canLoginWithUsername })\n\n  const form = useAppForm({\n    defaultValues: {\n      login: prefillEmail ?? prefillUsername ?? '',\n      password: prefillPassword ?? ''\n    },\n    onSubmit: async ({ value }) => {\n      const { login, password } = value\n      const isEmail = isValidEmail(login)\n      try {\n        const { data, error } = await (loginType === 'email' || (loginType === 'emailOrUsername' && isEmail)\n          ? authClient.signIn.email({ email: login, password, callbackURL: redirectUrl })\n          : authClient.signIn.username({ username: login, password }))\n        if (error) {\n          if (error.code === 'EMAIL_NOT_VERIFIED') {\n            setRequireEmailVerification(true)\n          }\n          if (error.message) {\n            toast.error(error.message.charAt(0).toUpperCase() + error.message.slice(1))\n          }\n        }\n        if (data?.token) {\n          toast.success(t('general:success'))\n          window.location.href = redirectUrl\n        }\n      } catch (err) {\n        toast.error(t('error:unknown') || 'An unexpected error occurred')\n      }\n    },\n    validators: {\n      onSubmit: loginSchema\n    }\n  })\n\n  const getLoginTypeLabel = () => {\n    const labels = {\n      email: t('general:email') || 'Email',\n      username: t('authentication:username') || 'Username',\n      emailOrUsername: t('authentication:emailOrUsername') || 'Email or Username'\n    }\n    return labels[loginType]\n  }\n\n  return (\n    <div className={`${baseClass}__wrapper`}>\n      {searchParamError && searchParamError === 'signup_disabled' && <FormError errors={['Sign up is disabled.']} />}\n      <Form\n        className={baseClass}\n        onSubmit={(e) => {\n          e.preventDefault()\n          void form.handleSubmit()\n        }}>\n        <FormInputWrap className={baseClass}>\n          <form.AppField\n            name=\"login\"\n            children={(field) => <field.TextField type=\"text\" className=\"email\" autoComplete={`email${hasPasskeyPlugin ? ' webauthn' : ''}`} label={getLoginTypeLabel()} />}\n          />\n          <form.AppField\n            name=\"password\"\n            children={(field) => (\n              <field.TextField type=\"password\" className=\"password\" autoComplete={`password${hasPasskeyPlugin ? ' webauthn' : ''}`} label={t('general:password')} />\n            )}\n          />\n        </FormInputWrap>\n        <Link href={forgotPasswordUrl} prefetch={false}>\n          {t('authentication:forgotPasswordQuestion')}\n        </Link>\n        <button type=\"submit\" style={{ display: 'none' }} tabIndex={-1} />\n        <form.AppForm children={<form.Submit label={t('authentication:login')} loadingLabel={t('general:loading')} />} />\n      </Form>\n    </div>\n  )\n}\n\nexport const AdminLoginClient: React.FC<AdminLoginClientProps> = ({\n  loginMethods,\n  hasUsernamePlugin,\n  hasPasskeyPlugin,\n  prefillEmail,\n  prefillPassword,\n  prefillUsername,\n  searchParams,\n  loginWithUsername\n}) => {\n  return (\n    <>\n      {loginMethods.includes('emailPassword') && (\n        <LoginForm\n          hasUsernamePlugin={hasUsernamePlugin}\n          hasPasskeyPlugin={hasPasskeyPlugin}\n          prefillEmail={prefillEmail}\n          prefillPassword={prefillPassword}\n          prefillUsername={prefillUsername}\n          searchParams={searchParams}\n          loginWithUsername={loginWithUsername}\n        />\n      )}\n      <AdminSocialProviderButtons\n        isSignup={false}\n        loginMethods={loginMethods}\n        setLoading={() => {}}\n        redirectUrl={getSafeRedirect(searchParams?.redirect as string, useConfig().config.routes.admin)}\n      />\n    </>\n  )\n}\n"],"names":["AdminSocialProviderButtons","getSafeRedirect","useConfig","Link","toast","useTranslation","React","useMemo","useState","adminRoutes","useAppForm","Form","FormError","FormInputWrap","FormHeader","createLoginSchema","isValidEmail","createAuthClient","usernameClient","twoFactorClient","passkeyClient","formatAdminURL","getLoginOptions","useRouter","valueOrDefaultString","baseClass","LoginForm","hasUsernamePlugin","hasPasskeyPlugin","prefillEmail","prefillPassword","prefillUsername","searchParams","loginWithUsername","config","router","adminRoute","routes","admin","t","canLoginWithEmail","canLoginWithUsername","searchParamError","error","redirectUrl","redirect","forgotPasswordUrl","path","forgotPassword","authClient","plugins","onTwoFactorRedirect","push","twoFactorVerify","loginType","requireEmailVerification","setRequireEmailVerification","heading","description","style","textAlign","loginSchema","form","defaultValues","login","password","onSubmit","value","isEmail","data","signIn","email","callbackURL","username","code","message","charAt","toUpperCase","slice","token","success","window","location","href","err","validators","getLoginTypeLabel","labels","emailOrUsername","div","className","errors","e","preventDefault","handleSubmit","AppField","name","children","field","TextField","type","autoComplete","label","prefetch","button","display","tabIndex","AppForm","Submit","loadingLabel","AdminLoginClient","loginMethods","includes","isSignup","setLoading"],"mappings":"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"}
@@ -73,6 +73,7 @@ export const PasswordResetForm = ({ token })=>{
73
73
  },
74
74
  children: [
75
75
  /*#__PURE__*/ _jsxs(FormInputWrap, {
76
+ className: "login__form",
76
77
  children: [
77
78
  /*#__PURE__*/ _jsx(form.AppField, {
78
79
  name: "password",
@@ -104,4 +105,4 @@ export const PasswordResetForm = ({ token })=>{
104
105
  });
105
106
  };
106
107
 
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/reset-password/client.tsx"],"sourcesContent":["'use client'\n\nimport React, { useMemo } from 'react'\nimport { z } from 'zod'\nimport { Form, FormInputWrap } from '@/shared/form/ui'\nimport { FormHeader } from '@/shared/form/ui/header'\nimport { useRouter } from 'next/navigation.js'\nimport { formatAdminURL } from 'payload/shared'\nimport { createAuthClient } from 'better-auth/react'\nimport { useAuth, useConfig, useTranslation, toast } from '@payloadcms/ui'\nimport { useAppForm } from '@/shared/form'\n\ntype PasswordResetFormArgs = {\n  readonly token: string\n  readonly minPasswordLength?: number\n  readonly maxPasswordLength?: number\n}\n\nexport const PasswordResetForm: React.FC<PasswordResetFormArgs> = ({ token }) => {\n  const { t } = useTranslation()\n  const history = useRouter()\n  const { fetchFullUser } = useAuth()\n  const authClient = useMemo(() => createAuthClient(), [])\n  const {\n    config: {\n      admin: {\n        routes: { login: loginRoute }\n      },\n      routes: { admin: adminRoute }\n    }\n  } = useConfig()\n\n  const resetPasswordSchema = z\n    .object({\n      password: z.string().min(1, t('validation:required') || 'Password is required'),\n      confirmPassword: z.string().min(1, t('validation:required') || 'Confirm password is required')\n    })\n    .refine(\n      (data) => {\n        // Only validate matching passwords if both fields have values\n        if (data.password && data.confirmPassword) {\n          return data.password === data.confirmPassword\n        }\n        // If one or both fields are empty, validation will be handled by the min(1) validators\n        return true\n      },\n      {\n        message: t('fields:passwordsDoNotMatch') || 'Passwords do not match',\n        path: ['confirmPassword']\n      }\n    )\n\n  const form = useAppForm({\n    defaultValues: {\n      password: '',\n      confirmPassword: ''\n    },\n    onSubmit: async ({ value }) => {\n      const { password } = value\n      try {\n        const { data, error } = await authClient.resetPassword({\n          newPassword: password,\n          token\n        })\n        if (error) {\n          toast.error(error.message || 'Error resetting password')\n          return\n        }\n        if (data?.status) {\n          const user = await fetchFullUser()\n          if (user) {\n            history.push(adminRoute)\n          } else {\n            history.push(\n              formatAdminURL({\n                adminRoute,\n                path: loginRoute\n              })\n            )\n          }\n          toast.success(t('authentication:passwordResetSuccessfully'))\n        }\n      } catch (e) {\n        toast.error('An unexpected error occurred')\n      }\n    },\n    validators: {\n      onSubmit: resetPasswordSchema\n    }\n  })\n\n  return (\n    <Form\n      onSubmit={(e) => {\n        e.preventDefault()\n        void form.handleSubmit()\n      }}>\n      <FormInputWrap>\n        <form.AppField\n          name=\"password\"\n          children={(field) => <field.TextField type=\"password\" className=\"password\" label={t('authentication:newPassword')} required />}\n        />\n        <form.AppField\n          name=\"confirmPassword\"\n          children={(field) => (\n            <field.TextField type=\"password\" className=\"password\" label={t('authentication:confirmPassword')} required />\n          )}\n        />\n      </FormInputWrap>\n      <form.AppForm children={<form.Submit label={t('authentication:resetPassword')} loadingLabel={t('general:loading')} />} />\n    </Form>\n  )\n}\n"],"names":["React","useMemo","z","Form","FormInputWrap","useRouter","formatAdminURL","createAuthClient","useAuth","useConfig","useTranslation","toast","useAppForm","PasswordResetForm","token","t","history","fetchFullUser","authClient","config","admin","routes","login","loginRoute","adminRoute","resetPasswordSchema","object","password","string","min","confirmPassword","refine","data","message","path","form","defaultValues","onSubmit","value","error","resetPassword","newPassword","status","user","push","success","e","validators","preventDefault","handleSubmit","AppField","name","children","field","TextField","type","className","label","required","AppForm","Submit","loadingLabel"],"mappings":"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"}
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/reset-password/client.tsx"],"sourcesContent":["'use client'\n\nimport React, { useMemo } from 'react'\nimport { z } from 'zod'\nimport { Form, FormInputWrap } from '@/shared/form/ui'\nimport { FormHeader } from '@/shared/form/ui/header'\nimport { useRouter } from 'next/navigation.js'\nimport { formatAdminURL } from 'payload/shared'\nimport { createAuthClient } from 'better-auth/react'\nimport { useAuth, useConfig, useTranslation, toast } from '@payloadcms/ui'\nimport { useAppForm } from '@/shared/form'\n\ntype PasswordResetFormArgs = {\n  readonly token: string\n  readonly minPasswordLength?: number\n  readonly maxPasswordLength?: number\n}\n\nexport const PasswordResetForm: React.FC<PasswordResetFormArgs> = ({ token }) => {\n  const { t } = useTranslation()\n  const history = useRouter()\n  const { fetchFullUser } = useAuth()\n  const authClient = useMemo(() => createAuthClient(), [])\n  const {\n    config: {\n      admin: {\n        routes: { login: loginRoute }\n      },\n      routes: { admin: adminRoute }\n    }\n  } = useConfig()\n\n  const resetPasswordSchema = z\n    .object({\n      password: z.string().min(1, t('validation:required') || 'Password is required'),\n      confirmPassword: z.string().min(1, t('validation:required') || 'Confirm password is required')\n    })\n    .refine(\n      (data) => {\n        // Only validate matching passwords if both fields have values\n        if (data.password && data.confirmPassword) {\n          return data.password === data.confirmPassword\n        }\n        // If one or both fields are empty, validation will be handled by the min(1) validators\n        return true\n      },\n      {\n        message: t('fields:passwordsDoNotMatch') || 'Passwords do not match',\n        path: ['confirmPassword']\n      }\n    )\n\n  const form = useAppForm({\n    defaultValues: {\n      password: '',\n      confirmPassword: ''\n    },\n    onSubmit: async ({ value }) => {\n      const { password } = value\n      try {\n        const { data, error } = await authClient.resetPassword({\n          newPassword: password,\n          token\n        })\n        if (error) {\n          toast.error(error.message || 'Error resetting password')\n          return\n        }\n        if (data?.status) {\n          const user = await fetchFullUser()\n          if (user) {\n            history.push(adminRoute)\n          } else {\n            history.push(\n              formatAdminURL({\n                adminRoute,\n                path: loginRoute\n              })\n            )\n          }\n          toast.success(t('authentication:passwordResetSuccessfully'))\n        }\n      } catch (e) {\n        toast.error('An unexpected error occurred')\n      }\n    },\n    validators: {\n      onSubmit: resetPasswordSchema\n    }\n  })\n\n  return (\n    <Form\n      onSubmit={(e) => {\n        e.preventDefault()\n        void form.handleSubmit()\n      }}>\n      <FormInputWrap className=\"login__form\">\n        <form.AppField\n          name=\"password\"\n          children={(field) => <field.TextField type=\"password\" className=\"password\" label={t('authentication:newPassword')} required />}\n        />\n        <form.AppField\n          name=\"confirmPassword\"\n          children={(field) => (\n            <field.TextField type=\"password\" className=\"password\" label={t('authentication:confirmPassword')} required />\n          )}\n        />\n      </FormInputWrap>\n      <form.AppForm children={<form.Submit label={t('authentication:resetPassword')} loadingLabel={t('general:loading')} />} />\n    </Form>\n  )\n}\n"],"names":["React","useMemo","z","Form","FormInputWrap","useRouter","formatAdminURL","createAuthClient","useAuth","useConfig","useTranslation","toast","useAppForm","PasswordResetForm","token","t","history","fetchFullUser","authClient","config","admin","routes","login","loginRoute","adminRoute","resetPasswordSchema","object","password","string","min","confirmPassword","refine","data","message","path","form","defaultValues","onSubmit","value","error","resetPassword","newPassword","status","user","push","success","e","validators","preventDefault","handleSubmit","className","AppField","name","children","field","TextField","type","label","required","AppForm","Submit","loadingLabel"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "payload-auth",
3
- "version": "1.6.1-canary.3",
3
+ "version": "1.6.1-canary.5",
4
4
  "main": "./dist/index.js",
5
5
  "module": "./dist/index.mjs",
6
6
  "types": "./dist/index.d.ts",