payload-auth 1.5.1 → 1.6.1-canary.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (164) hide show
  1. package/dist/better-auth/adapter/index.d.ts.map +1 -1
  2. package/dist/better-auth/adapter/index.js +30 -30
  3. package/dist/better-auth/adapter/transform/index.d.ts +8 -7
  4. package/dist/better-auth/adapter/transform/index.d.ts.map +1 -1
  5. package/dist/better-auth/adapter/transform/index.js +2 -2
  6. package/dist/better-auth/adapter/types.d.ts +5 -4
  7. package/dist/better-auth/adapter/types.d.ts.map +1 -1
  8. package/dist/better-auth/adapter/types.js +1 -1
  9. package/dist/better-auth/generated-types.d.ts +21 -0
  10. package/dist/better-auth/generated-types.d.ts.map +1 -1
  11. package/dist/better-auth/generated-types.js +1 -1
  12. package/dist/better-auth/plugin/helpers/get-better-auth-schema.d.ts +14 -17
  13. package/dist/better-auth/plugin/helpers/get-better-auth-schema.d.ts.map +1 -1
  14. package/dist/better-auth/plugin/helpers/get-better-auth-schema.js +51 -33
  15. package/dist/better-auth/plugin/helpers/get-collection.d.ts +11 -36
  16. package/dist/better-auth/plugin/helpers/get-collection.d.ts.map +1 -1
  17. package/dist/better-auth/plugin/helpers/get-collection.js +20 -53
  18. package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts.map +1 -1
  19. package/dist/better-auth/plugin/helpers/prepare-session-data.js +1 -1
  20. package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.d.ts +21 -0
  21. package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.d.ts.map +1 -0
  22. package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.js +62 -0
  23. package/dist/better-auth/plugin/index.d.ts +8 -1
  24. package/dist/better-auth/plugin/index.d.ts.map +1 -1
  25. package/dist/better-auth/plugin/index.js +67 -91
  26. package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.d.ts +13 -0
  27. package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.d.ts.map +1 -0
  28. package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.js +80 -0
  29. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.d.ts +2 -2
  30. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.d.ts.map +1 -1
  31. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.js +6 -16
  32. package/dist/better-auth/plugin/lib/build-collections/accounts/index.d.ts +2 -2
  33. package/dist/better-auth/plugin/lib/build-collections/accounts/index.d.ts.map +1 -1
  34. package/dist/better-auth/plugin/lib/build-collections/accounts/index.js +10 -12
  35. package/dist/better-auth/plugin/lib/build-collections/api-keys.d.ts +1 -1
  36. package/dist/better-auth/plugin/lib/build-collections/api-keys.d.ts.map +1 -1
  37. package/dist/better-auth/plugin/lib/build-collections/api-keys.js +8 -11
  38. package/dist/better-auth/plugin/lib/build-collections/index.d.ts +3 -4
  39. package/dist/better-auth/plugin/lib/build-collections/index.d.ts.map +1 -1
  40. package/dist/better-auth/plugin/lib/build-collections/index.js +15 -26
  41. package/dist/better-auth/plugin/lib/build-collections/invitations.d.ts +1 -1
  42. package/dist/better-auth/plugin/lib/build-collections/invitations.d.ts.map +1 -1
  43. package/dist/better-auth/plugin/lib/build-collections/invitations.js +8 -11
  44. package/dist/better-auth/plugin/lib/build-collections/jwks.d.ts +1 -1
  45. package/dist/better-auth/plugin/lib/build-collections/jwks.d.ts.map +1 -1
  46. package/dist/better-auth/plugin/lib/build-collections/jwks.js +8 -11
  47. package/dist/better-auth/plugin/lib/build-collections/members.d.ts +1 -1
  48. package/dist/better-auth/plugin/lib/build-collections/members.d.ts.map +1 -1
  49. package/dist/better-auth/plugin/lib/build-collections/members.js +8 -10
  50. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.d.ts +1 -1
  51. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.d.ts.map +1 -1
  52. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.js +8 -11
  53. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.d.ts +1 -1
  54. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.d.ts.map +1 -1
  55. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.js +8 -11
  56. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.d.ts +1 -1
  57. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.d.ts.map +1 -1
  58. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.js +7 -9
  59. package/dist/better-auth/plugin/lib/build-collections/organizations.d.ts +1 -1
  60. package/dist/better-auth/plugin/lib/build-collections/organizations.d.ts.map +1 -1
  61. package/dist/better-auth/plugin/lib/build-collections/organizations.js +8 -10
  62. package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts +2 -2
  63. package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts.map +1 -1
  64. package/dist/better-auth/plugin/lib/build-collections/passkeys.js +23 -12
  65. package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts +1 -1
  66. package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts.map +1 -1
  67. package/dist/better-auth/plugin/lib/build-collections/sessions.js +7 -8
  68. package/dist/better-auth/plugin/lib/build-collections/sso-providers.d.ts +1 -1
  69. package/dist/better-auth/plugin/lib/build-collections/sso-providers.d.ts.map +1 -1
  70. package/dist/better-auth/plugin/lib/build-collections/sso-providers.js +8 -10
  71. package/dist/better-auth/plugin/lib/build-collections/subscriptions.d.ts +1 -1
  72. package/dist/better-auth/plugin/lib/build-collections/subscriptions.d.ts.map +1 -1
  73. package/dist/better-auth/plugin/lib/build-collections/subscriptions.js +8 -10
  74. package/dist/better-auth/plugin/lib/build-collections/teams.d.ts +1 -1
  75. package/dist/better-auth/plugin/lib/build-collections/teams.d.ts.map +1 -1
  76. package/dist/better-auth/plugin/lib/build-collections/teams.js +8 -11
  77. package/dist/better-auth/plugin/lib/build-collections/two-factors.d.ts +1 -1
  78. package/dist/better-auth/plugin/lib/build-collections/two-factors.d.ts.map +1 -1
  79. package/dist/better-auth/plugin/lib/build-collections/two-factors.js +8 -11
  80. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts.map +1 -1
  81. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js +4 -11
  82. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.d.ts.map +1 -1
  83. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.js +3 -8
  84. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.d.ts.map +1 -1
  85. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.js +5 -15
  86. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.d.ts.map +1 -1
  87. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.js +19 -22
  88. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts +1 -1
  89. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts.map +1 -1
  90. package/dist/better-auth/plugin/lib/build-collections/users/index.js +31 -14
  91. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.d.ts +6 -6
  92. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.d.ts.map +1 -1
  93. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.js +9 -17
  94. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.d.ts +2 -2
  95. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.d.ts.map +1 -1
  96. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.js +1 -1
  97. package/dist/better-auth/plugin/lib/build-collections/verifications.d.ts +1 -1
  98. package/dist/better-auth/plugin/lib/build-collections/verifications.d.ts.map +1 -1
  99. package/dist/better-auth/plugin/lib/build-collections/verifications.js +8 -11
  100. package/dist/better-auth/plugin/lib/init-better-auth.d.ts +1 -1
  101. package/dist/better-auth/plugin/lib/init-better-auth.d.ts.map +1 -1
  102. package/dist/better-auth/plugin/lib/init-better-auth.js +3 -2
  103. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.d.ts +2 -2
  104. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.d.ts.map +1 -1
  105. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.js +4 -4
  106. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts +3 -4
  107. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts.map +1 -1
  108. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js +15 -15
  109. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.d.ts +2 -2
  110. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.d.ts.map +1 -1
  111. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.js +8 -8
  112. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.d.ts +2 -2
  113. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.d.ts.map +1 -1
  114. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.js +12 -12
  115. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.d.ts +2 -2
  116. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.d.ts.map +1 -1
  117. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.js +4 -4
  118. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.d.ts +2 -2
  119. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.d.ts.map +1 -1
  120. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.js +6 -6
  121. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.d.ts +2 -2
  122. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.d.ts.map +1 -1
  123. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.js +4 -4
  124. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts +3 -4
  125. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts.map +1 -1
  126. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js +4 -4
  127. package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts +7 -0
  128. package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts.map +1 -0
  129. package/dist/better-auth/plugin/payload/components/passkeys/add-button.js +120 -0
  130. package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts +4 -0
  131. package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts.map +1 -0
  132. package/dist/better-auth/plugin/payload/components/passkeys/client.js +59 -0
  133. package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts +5 -0
  134. package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts.map +1 -0
  135. package/dist/better-auth/plugin/payload/components/passkeys/index.js +40 -0
  136. package/dist/better-auth/plugin/payload/components/passkeys/index.scss +91 -0
  137. package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts +9 -0
  138. package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts.map +1 -0
  139. package/dist/better-auth/plugin/payload/components/passkeys/list.js +57 -0
  140. package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts +20 -0
  141. package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts.map +1 -0
  142. package/dist/better-auth/plugin/payload/components/passkeys/types.js +3 -0
  143. package/dist/better-auth/plugin/payload/exports/rsc.d.ts +2 -1
  144. package/dist/better-auth/plugin/payload/exports/rsc.d.ts.map +1 -1
  145. package/dist/better-auth/plugin/payload/exports/rsc.js +3 -2
  146. package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts +1 -0
  147. package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts.map +1 -1
  148. package/dist/better-auth/plugin/payload/views/admin-login/client.js +11 -7
  149. package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts.map +1 -1
  150. package/dist/better-auth/plugin/payload/views/admin-login/index.js +3 -1
  151. package/dist/better-auth/plugin/types.d.ts +6 -3
  152. package/dist/better-auth/plugin/types.d.ts.map +1 -1
  153. package/dist/better-auth/plugin/types.js +1 -1
  154. package/dist/better-auth/scripts/generate-types.js +15 -1
  155. package/package.json +1 -1
  156. package/dist/better-auth/plugin/helpers/get-collection-schema-map.d.ts +0 -16
  157. package/dist/better-auth/plugin/helpers/get-collection-schema-map.d.ts.map +0 -1
  158. package/dist/better-auth/plugin/helpers/get-collection-schema-map.js +0 -108
  159. package/dist/better-auth/plugin/helpers/get-requst-collection.d.ts +0 -3
  160. package/dist/better-auth/plugin/helpers/get-requst-collection.d.ts.map +0 -1
  161. package/dist/better-auth/plugin/helpers/get-requst-collection.js +0 -14
  162. package/dist/better-auth/plugin/helpers/serialize-cookie.d.ts +0 -105
  163. package/dist/better-auth/plugin/helpers/serialize-cookie.d.ts.map +0 -1
  164. package/dist/better-auth/plugin/helpers/serialize-cookie.js +0 -186
@@ -1 +1 @@
1
- {"version":3,"file":"get-collection.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/get-collection.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAE,KAAK,EAAE,MAAM,SAAS,CAAA;AAElE;;;;;;;;;;;GAWG;AACH,wBAAgB,mBAAmB,CAAC,EAClC,aAAa,EACb,kBAAkB,EACnB,EAAE;IACD,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAA;IAC/C,kBAAkB,EAAE,MAAM,CAAA;CAC3B,GAAG,gBAAgB,CAcnB;AAED,UAAU,WAAY,SAAQ,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC;IAC/C,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,KAAK,GAAG,aAAa,CAAC,CAAA;CAC7D;AAED;;;;;;;;;;;;GAYG;AACH,wBAAgB,cAAc,CAAC,EAC7B,UAAU,EACV,kBAAkB,EACnB,EAAE;IACD,UAAU,EAAE,gBAAgB,CAAA;IAC5B,kBAAkB,EAAE,MAAM,CAAA;CAC3B,GAAG,WAAW,CAmBd;AAED,wBAAgB,uCAAuC,CAAC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAIjI"}
1
+ {"version":3,"file":"get-collection.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/get-collection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,QAAQ,EAAE,MAAM,+BAA+B,CAAA;AAC9E,OAAO,EAAoB,KAAK,UAAU,EAAE,KAAK,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAElF,wBAAgB,uBAAuB,CAAC,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,EAAE,QAAQ,EAAE,QAAQ,GAAG,gBAAgB,CAUrH;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,gCAAgC,CAAC,CAAC,SAAS,QAAQ,EACjE,UAAU,EAAE,gBAAgB,EAC5B,KAAK,EAAE,CAAC,EACR,QAAQ,EAAE,OAAO,CAAC,MAAM,oBAAoB,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,GACvD,MAAM,CAIR"}
@@ -1,62 +1,29 @@
1
- /**
2
- * Retrieves a collection from the collection map based on its Better Auth model key
3
- *
4
- * This function searches through the provided collection map to find a collection
5
- * that has been marked with a specific Better Auth model key in its custom properties.
6
- * It's used to map between Better Auth's internal model keys and Payload CMS collections.
7
- *
8
- * @param collectionMap - Map of all available collections
9
- * @param betterAuthModelKey - The Better Auth model key to search for
10
- * @returns The matched collection configuration
11
- * @throws {Error} If no collection with the specified Better Auth model key is found
12
- */ export function getMappedCollection({ collectionMap, betterAuthModelKey }) {
13
- // Find the collection that has the matching betterAuthModelKey in its custom properties
14
- const collection = Object.values(collectionMap).find((c)=>{
15
- return c.custom?.betterAuthModelKey === betterAuthModelKey;
1
+ import { flattenAllFields } from "payload";
2
+ export function getCollectionByModelKey(collections, modelKey) {
3
+ const collection = Object.values(collections).find((c)=>{
4
+ return c.config?.custom?.betterAuthModelKey === modelKey;
16
5
  });
17
- // Throw an error if no matching collection is found
18
6
  if (!collection) {
19
- const error = new Error(`Collection with key ${betterAuthModelKey} not found`);
20
- Error.captureStackTrace(error, getMappedCollection);
21
- throw error;
7
+ throw new Error(`Collection with key ${modelKey} not found`);
22
8
  }
23
- return collection;
9
+ return collection.config;
24
10
  }
25
11
  /**
26
- * Retrieves a field from a collection based on its Better Auth field key
12
+ * Retrieves the field name from a collection based on the field key
27
13
  *
28
- * This function searches through the fields of a provided collection to find a field
29
- * that has been marked with a specific Better Auth field key in its custom properties.
30
- * It's used to map between Better Auth's internal field keys and Payload CMS field configurations.
14
+ * This function searches through the fields of a collection to find a field
15
+ * that has a matching custom property betterAuthFieldKey.
31
16
  *
32
- * @param collection - The collection configuration to search within
33
- * @param betterAuthFieldKey - The Better Auth field key to search for
34
- * @returns The matched field configuration with a guaranteed name and non-UI type
35
- * @throws {Error} If no field with the specified Better Auth field key is found
36
- * @throws {Error} If the found field is a UI-only field type (tabs, row, collapsible)
37
- */ export function getMappedField({ collection, betterAuthFieldKey }) {
38
- // Find the field that has the matching betterAuthFieldKey in its custom properties
39
- const field = collection.fields.find((f)=>f.custom?.betterAuthFieldKey === betterAuthFieldKey);
40
- // Throw an error if no matching field is found
41
- if (!field) {
42
- throw new Error(`Field with key ${betterAuthFieldKey} not found`);
43
- }
44
- // Filter out UI-based fields that don't have a name or aren't data fields
45
- // These field types are used for layout purposes only and cannot store data
46
- switch(field.type){
47
- case 'tabs':
48
- case 'row':
49
- case 'collapsible':
50
- throw new Error(`Field with key ${betterAuthFieldKey} is a UI-only field and cannot be used for data`);
51
- default:
52
- return field;
53
- }
54
- }
55
- export function transformCollectionsToCollectionConfigs(collections) {
56
- return Object.fromEntries(Object.entries(collections).map(([slug, collection])=>[
57
- slug,
58
- collection.config
59
- ]));
17
+ * @param collection - The collection configuration to search through
18
+ * @param model - The model key of the collection (This is really just for type hinting)
19
+ * @param fieldKey - The key of the field to search for
20
+ * @returns The name of the field if found, otherwise the field key itself
21
+ */ export function getCollectionFieldNameByFieldKey(collection, model, fieldKey) {
22
+ const fields = flattenAllFields({
23
+ fields: collection.fields
24
+ });
25
+ console.log('fields', fields);
26
+ return fields.find((f)=>f.custom?.betterAuthFieldKey === fieldKey)?.name ?? fieldKey;
60
27
  }
61
28
 
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9nZXQtY29sbGVjdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENvbGxlY3Rpb24sIENvbGxlY3Rpb25Db25maWcsIEZpZWxkIH0gZnJvbSAncGF5bG9hZCdcblxuLyoqXG4gKiBSZXRyaWV2ZXMgYSBjb2xsZWN0aW9uIGZyb20gdGhlIGNvbGxlY3Rpb24gbWFwIGJhc2VkIG9uIGl0cyBCZXR0ZXIgQXV0aCBtb2RlbCBrZXlcbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHNlYXJjaGVzIHRocm91Z2ggdGhlIHByb3ZpZGVkIGNvbGxlY3Rpb24gbWFwIHRvIGZpbmQgYSBjb2xsZWN0aW9uXG4gKiB0aGF0IGhhcyBiZWVuIG1hcmtlZCB3aXRoIGEgc3BlY2lmaWMgQmV0dGVyIEF1dGggbW9kZWwga2V5IGluIGl0cyBjdXN0b20gcHJvcGVydGllcy5cbiAqIEl0J3MgdXNlZCB0byBtYXAgYmV0d2VlbiBCZXR0ZXIgQXV0aCdzIGludGVybmFsIG1vZGVsIGtleXMgYW5kIFBheWxvYWQgQ01TIGNvbGxlY3Rpb25zLlxuICpcbiAqIEBwYXJhbSBjb2xsZWN0aW9uTWFwIC0gTWFwIG9mIGFsbCBhdmFpbGFibGUgY29sbGVjdGlvbnNcbiAqIEBwYXJhbSBiZXR0ZXJBdXRoTW9kZWxLZXkgLSBUaGUgQmV0dGVyIEF1dGggbW9kZWwga2V5IHRvIHNlYXJjaCBmb3JcbiAqIEByZXR1cm5zIFRoZSBtYXRjaGVkIGNvbGxlY3Rpb24gY29uZmlndXJhdGlvblxuICogQHRocm93cyB7RXJyb3J9IElmIG5vIGNvbGxlY3Rpb24gd2l0aCB0aGUgc3BlY2lmaWVkIEJldHRlciBBdXRoIG1vZGVsIGtleSBpcyBmb3VuZFxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0TWFwcGVkQ29sbGVjdGlvbih7XG4gIGNvbGxlY3Rpb25NYXAsXG4gIGJldHRlckF1dGhNb2RlbEtleVxufToge1xuICBjb2xsZWN0aW9uTWFwOiBSZWNvcmQ8c3RyaW5nLCBDb2xsZWN0aW9uQ29uZmlnPlxuICBiZXR0ZXJBdXRoTW9kZWxLZXk6IHN0cmluZ1xufSk6IENvbGxlY3Rpb25Db25maWcge1xuICAvLyBGaW5kIHRoZSBjb2xsZWN0aW9uIHRoYXQgaGFzIHRoZSBtYXRjaGluZyBiZXR0ZXJBdXRoTW9kZWxLZXkgaW4gaXRzIGN1c3RvbSBwcm9wZXJ0aWVzXG4gIGNvbnN0IGNvbGxlY3Rpb24gPSBPYmplY3QudmFsdWVzKGNvbGxlY3Rpb25NYXApLmZpbmQoKGMpID0+IHtcbiAgICByZXR1cm4gYy5jdXN0b20/LmJldHRlckF1dGhNb2RlbEtleSA9PT0gYmV0dGVyQXV0aE1vZGVsS2V5XG4gIH0pXG5cbiAgLy8gVGhyb3cgYW4gZXJyb3IgaWYgbm8gbWF0Y2hpbmcgY29sbGVjdGlvbiBpcyBmb3VuZFxuICBpZiAoIWNvbGxlY3Rpb24pIHtcbiAgICBjb25zdCBlcnJvciA9IG5ldyBFcnJvcihgQ29sbGVjdGlvbiB3aXRoIGtleSAke2JldHRlckF1dGhNb2RlbEtleX0gbm90IGZvdW5kYClcbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZShlcnJvciwgZ2V0TWFwcGVkQ29sbGVjdGlvbilcbiAgICB0aHJvdyBlcnJvclxuICB9XG5cbiAgcmV0dXJuIGNvbGxlY3Rpb25cbn1cblxuaW50ZXJmYWNlIE1hcHBlZEZpZWxkIGV4dGVuZHMgT21pdDxGaWVsZCwgJ3R5cGUnPiB7XG4gIG5hbWU6IHN0cmluZ1xuICB0eXBlOiBFeGNsdWRlPEZpZWxkWyd0eXBlJ10sICd0YWJzJyB8ICdyb3cnIHwgJ2NvbGxhcHNpYmxlJz5cbn1cblxuLyoqXG4gKiBSZXRyaWV2ZXMgYSBmaWVsZCBmcm9tIGEgY29sbGVjdGlvbiBiYXNlZCBvbiBpdHMgQmV0dGVyIEF1dGggZmllbGQga2V5XG4gKlxuICogVGhpcyBmdW5jdGlvbiBzZWFyY2hlcyB0aHJvdWdoIHRoZSBmaWVsZHMgb2YgYSBwcm92aWRlZCBjb2xsZWN0aW9uIHRvIGZpbmQgYSBmaWVsZFxuICogdGhhdCBoYXMgYmVlbiBtYXJrZWQgd2l0aCBhIHNwZWNpZmljIEJldHRlciBBdXRoIGZpZWxkIGtleSBpbiBpdHMgY3VzdG9tIHByb3BlcnRpZXMuXG4gKiBJdCdzIHVzZWQgdG8gbWFwIGJldHdlZW4gQmV0dGVyIEF1dGgncyBpbnRlcm5hbCBmaWVsZCBrZXlzIGFuZCBQYXlsb2FkIENNUyBmaWVsZCBjb25maWd1cmF0aW9ucy5cbiAqXG4gKiBAcGFyYW0gY29sbGVjdGlvbiAtIFRoZSBjb2xsZWN0aW9uIGNvbmZpZ3VyYXRpb24gdG8gc2VhcmNoIHdpdGhpblxuICogQHBhcmFtIGJldHRlckF1dGhGaWVsZEtleSAtIFRoZSBCZXR0ZXIgQXV0aCBmaWVsZCBrZXkgdG8gc2VhcmNoIGZvclxuICogQHJldHVybnMgVGhlIG1hdGNoZWQgZmllbGQgY29uZmlndXJhdGlvbiB3aXRoIGEgZ3VhcmFudGVlZCBuYW1lIGFuZCBub24tVUkgdHlwZVxuICogQHRocm93cyB7RXJyb3J9IElmIG5vIGZpZWxkIHdpdGggdGhlIHNwZWNpZmllZCBCZXR0ZXIgQXV0aCBmaWVsZCBrZXkgaXMgZm91bmRcbiAqIEB0aHJvd3Mge0Vycm9yfSBJZiB0aGUgZm91bmQgZmllbGQgaXMgYSBVSS1vbmx5IGZpZWxkIHR5cGUgKHRhYnMsIHJvdywgY29sbGFwc2libGUpXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRNYXBwZWRGaWVsZCh7XG4gIGNvbGxlY3Rpb24sXG4gIGJldHRlckF1dGhGaWVsZEtleVxufToge1xuICBjb2xsZWN0aW9uOiBDb2xsZWN0aW9uQ29uZmlnXG4gIGJldHRlckF1dGhGaWVsZEtleTogc3RyaW5nXG59KTogTWFwcGVkRmllbGQge1xuICAvLyBGaW5kIHRoZSBmaWVsZCB0aGF0IGhhcyB0aGUgbWF0Y2hpbmcgYmV0dGVyQXV0aEZpZWxkS2V5IGluIGl0cyBjdXN0b20gcHJvcGVydGllc1xuICBjb25zdCBmaWVsZCA9IGNvbGxlY3Rpb24uZmllbGRzLmZpbmQoKGYpID0+IGYuY3VzdG9tPy5iZXR0ZXJBdXRoRmllbGRLZXkgPT09IGJldHRlckF1dGhGaWVsZEtleSlcblxuICAvLyBUaHJvdyBhbiBlcnJvciBpZiBubyBtYXRjaGluZyBmaWVsZCBpcyBmb3VuZFxuICBpZiAoIWZpZWxkKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBGaWVsZCB3aXRoIGtleSAke2JldHRlckF1dGhGaWVsZEtleX0gbm90IGZvdW5kYClcbiAgfVxuXG4gIC8vIEZpbHRlciBvdXQgVUktYmFzZWQgZmllbGRzIHRoYXQgZG9uJ3QgaGF2ZSBhIG5hbWUgb3IgYXJlbid0IGRhdGEgZmllbGRzXG4gIC8vIFRoZXNlIGZpZWxkIHR5cGVzIGFyZSB1c2VkIGZvciBsYXlvdXQgcHVycG9zZXMgb25seSBhbmQgY2Fubm90IHN0b3JlIGRhdGFcbiAgc3dpdGNoIChmaWVsZC50eXBlKSB7XG4gICAgY2FzZSAndGFicyc6XG4gICAgY2FzZSAncm93JzpcbiAgICBjYXNlICdjb2xsYXBzaWJsZSc6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYEZpZWxkIHdpdGgga2V5ICR7YmV0dGVyQXV0aEZpZWxkS2V5fSBpcyBhIFVJLW9ubHkgZmllbGQgYW5kIGNhbm5vdCBiZSB1c2VkIGZvciBkYXRhYClcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIGZpZWxkIGFzIE1hcHBlZEZpZWxkXG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRyYW5zZm9ybUNvbGxlY3Rpb25zVG9Db2xsZWN0aW9uQ29uZmlncyhjb2xsZWN0aW9uczogUmVjb3JkPHN0cmluZywgQ29sbGVjdGlvbj4pOiBSZWNvcmQ8c3RyaW5nLCBDb2xsZWN0aW9uQ29uZmlnPiB7XG4gIHJldHVybiBPYmplY3QuZnJvbUVudHJpZXMoXG4gICAgT2JqZWN0LmVudHJpZXMoY29sbGVjdGlvbnMpLm1hcCgoW3NsdWcsIGNvbGxlY3Rpb25dKSA9PiBbc2x1ZywgY29sbGVjdGlvbi5jb25maWddKVxuICApXG59XG4iXSwibmFtZXMiOlsiZ2V0TWFwcGVkQ29sbGVjdGlvbiIsImNvbGxlY3Rpb25NYXAiLCJiZXR0ZXJBdXRoTW9kZWxLZXkiLCJjb2xsZWN0aW9uIiwiT2JqZWN0IiwidmFsdWVzIiwiZmluZCIsImMiLCJjdXN0b20iLCJlcnJvciIsIkVycm9yIiwiY2FwdHVyZVN0YWNrVHJhY2UiLCJnZXRNYXBwZWRGaWVsZCIsImJldHRlckF1dGhGaWVsZEtleSIsImZpZWxkIiwiZmllbGRzIiwiZiIsInR5cGUiLCJ0cmFuc2Zvcm1Db2xsZWN0aW9uc1RvQ29sbGVjdGlvbkNvbmZpZ3MiLCJjb2xsZWN0aW9ucyIsImZyb21FbnRyaWVzIiwiZW50cmllcyIsIm1hcCIsInNsdWciLCJjb25maWciXSwibWFwcGluZ3MiOiJBQUVBOzs7Ozs7Ozs7OztDQVdDLEdBQ0QsT0FBTyxTQUFTQSxvQkFBb0IsRUFDbENDLGFBQWEsRUFDYkMsa0JBQWtCLEVBSW5CO0lBQ0Msd0ZBQXdGO0lBQ3hGLE1BQU1DLGFBQWFDLE9BQU9DLE1BQU0sQ0FBQ0osZUFBZUssSUFBSSxDQUFDLENBQUNDO1FBQ3BELE9BQU9BLEVBQUVDLE1BQU0sRUFBRU4sdUJBQXVCQTtJQUMxQztJQUVBLG9EQUFvRDtJQUNwRCxJQUFJLENBQUNDLFlBQVk7UUFDZixNQUFNTSxRQUFRLElBQUlDLE1BQU0sQ0FBQyxvQkFBb0IsRUFBRVIsbUJBQW1CLFVBQVUsQ0FBQztRQUM3RVEsTUFBTUMsaUJBQWlCLENBQUNGLE9BQU9UO1FBQy9CLE1BQU1TO0lBQ1I7SUFFQSxPQUFPTjtBQUNUO0FBT0E7Ozs7Ozs7Ozs7OztDQVlDLEdBQ0QsT0FBTyxTQUFTUyxlQUFlLEVBQzdCVCxVQUFVLEVBQ1ZVLGtCQUFrQixFQUluQjtJQUNDLG1GQUFtRjtJQUNuRixNQUFNQyxRQUFRWCxXQUFXWSxNQUFNLENBQUNULElBQUksQ0FBQyxDQUFDVSxJQUFNQSxFQUFFUixNQUFNLEVBQUVLLHVCQUF1QkE7SUFFN0UsK0NBQStDO0lBQy9DLElBQUksQ0FBQ0MsT0FBTztRQUNWLE1BQU0sSUFBSUosTUFBTSxDQUFDLGVBQWUsRUFBRUcsbUJBQW1CLFVBQVUsQ0FBQztJQUNsRTtJQUVBLDBFQUEwRTtJQUMxRSw0RUFBNEU7SUFDNUUsT0FBUUMsTUFBTUcsSUFBSTtRQUNoQixLQUFLO1FBQ0wsS0FBSztRQUNMLEtBQUs7WUFDSCxNQUFNLElBQUlQLE1BQU0sQ0FBQyxlQUFlLEVBQUVHLG1CQUFtQiwrQ0FBK0MsQ0FBQztRQUN2RztZQUNFLE9BQU9DO0lBQ1g7QUFDRjtBQUVBLE9BQU8sU0FBU0ksd0NBQXdDQyxXQUF1QztJQUM3RixPQUFPZixPQUFPZ0IsV0FBVyxDQUN2QmhCLE9BQU9pQixPQUFPLENBQUNGLGFBQWFHLEdBQUcsQ0FBQyxDQUFDLENBQUNDLE1BQU1wQixXQUFXLEdBQUs7WUFBQ29CO1lBQU1wQixXQUFXcUIsTUFBTTtTQUFDO0FBRXJGIn0=
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9nZXQtY29sbGVjdGlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCZXR0ZXJBdXRoRnVsbFNjaGVtYSwgTW9kZWxLZXkgfSBmcm9tICdAL2JldHRlci1hdXRoL2dlbmVyYXRlZC10eXBlcydcbmltcG9ydCB7IGZsYXR0ZW5BbGxGaWVsZHMsIHR5cGUgQ29sbGVjdGlvbiwgdHlwZSBDb2xsZWN0aW9uQ29uZmlnIH0gZnJvbSAncGF5bG9hZCdcblxuZXhwb3J0IGZ1bmN0aW9uIGdldENvbGxlY3Rpb25CeU1vZGVsS2V5KGNvbGxlY3Rpb25zOiBSZWNvcmQ8c3RyaW5nLCBDb2xsZWN0aW9uPiwgbW9kZWxLZXk6IE1vZGVsS2V5KTogQ29sbGVjdGlvbkNvbmZpZyB7XG4gIGNvbnN0IGNvbGxlY3Rpb24gPSBPYmplY3QudmFsdWVzKGNvbGxlY3Rpb25zKS5maW5kKChjKSA9PiB7XG4gICAgcmV0dXJuIGMuY29uZmlnPy5jdXN0b20/LmJldHRlckF1dGhNb2RlbEtleSA9PT0gbW9kZWxLZXlcbiAgfSlcblxuICBpZiAoIWNvbGxlY3Rpb24pIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYENvbGxlY3Rpb24gd2l0aCBrZXkgJHttb2RlbEtleX0gbm90IGZvdW5kYClcbiAgfVxuXG4gIHJldHVybiBjb2xsZWN0aW9uLmNvbmZpZ1xufVxuXG4vKipcbiAqIFJldHJpZXZlcyB0aGUgZmllbGQgbmFtZSBmcm9tIGEgY29sbGVjdGlvbiBiYXNlZCBvbiB0aGUgZmllbGQga2V5XG4gKlxuICogVGhpcyBmdW5jdGlvbiBzZWFyY2hlcyB0aHJvdWdoIHRoZSBmaWVsZHMgb2YgYSBjb2xsZWN0aW9uIHRvIGZpbmQgYSBmaWVsZFxuICogdGhhdCBoYXMgYSBtYXRjaGluZyBjdXN0b20gcHJvcGVydHkgYmV0dGVyQXV0aEZpZWxkS2V5LlxuICpcbiAqIEBwYXJhbSBjb2xsZWN0aW9uIC0gVGhlIGNvbGxlY3Rpb24gY29uZmlndXJhdGlvbiB0byBzZWFyY2ggdGhyb3VnaFxuICogQHBhcmFtIG1vZGVsIC0gVGhlIG1vZGVsIGtleSBvZiB0aGUgY29sbGVjdGlvbiAoVGhpcyBpcyByZWFsbHkganVzdCBmb3IgdHlwZSBoaW50aW5nKVxuICogQHBhcmFtIGZpZWxkS2V5IC0gVGhlIGtleSBvZiB0aGUgZmllbGQgdG8gc2VhcmNoIGZvclxuICogQHJldHVybnMgVGhlIG5hbWUgb2YgdGhlIGZpZWxkIGlmIGZvdW5kLCBvdGhlcndpc2UgdGhlIGZpZWxkIGtleSBpdHNlbGZcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldENvbGxlY3Rpb25GaWVsZE5hbWVCeUZpZWxkS2V5PE0gZXh0ZW5kcyBNb2RlbEtleT4oXG4gIGNvbGxlY3Rpb246IENvbGxlY3Rpb25Db25maWcsXG4gIG1vZGVsOiBNLFxuICBmaWVsZEtleTogRXh0cmFjdDxrZXlvZiBCZXR0ZXJBdXRoRnVsbFNjaGVtYVtNXSwgc3RyaW5nPlxuKTogc3RyaW5nIHtcbiAgY29uc3QgZmllbGRzID0gZmxhdHRlbkFsbEZpZWxkcyh7IGZpZWxkczogY29sbGVjdGlvbi5maWVsZHMgfSlcbiAgY29uc29sZS5sb2coJ2ZpZWxkcycsIGZpZWxkcylcbiAgcmV0dXJuIGZpZWxkcy5maW5kKChmKSA9PiBmLmN1c3RvbT8uYmV0dGVyQXV0aEZpZWxkS2V5ID09PSBmaWVsZEtleSk/Lm5hbWUgPz8gZmllbGRLZXlcbn1cbiJdLCJuYW1lcyI6WyJmbGF0dGVuQWxsRmllbGRzIiwiZ2V0Q29sbGVjdGlvbkJ5TW9kZWxLZXkiLCJjb2xsZWN0aW9ucyIsIm1vZGVsS2V5IiwiY29sbGVjdGlvbiIsIk9iamVjdCIsInZhbHVlcyIsImZpbmQiLCJjIiwiY29uZmlnIiwiY3VzdG9tIiwiYmV0dGVyQXV0aE1vZGVsS2V5IiwiRXJyb3IiLCJnZXRDb2xsZWN0aW9uRmllbGROYW1lQnlGaWVsZEtleSIsIm1vZGVsIiwiZmllbGRLZXkiLCJmaWVsZHMiLCJjb25zb2xlIiwibG9nIiwiZiIsImJldHRlckF1dGhGaWVsZEtleSIsIm5hbWUiXSwibWFwcGluZ3MiOiJBQUNBLFNBQVNBLGdCQUFnQixRQUFnRCxVQUFTO0FBRWxGLE9BQU8sU0FBU0Msd0JBQXdCQyxXQUF1QyxFQUFFQyxRQUFrQjtJQUNqRyxNQUFNQyxhQUFhQyxPQUFPQyxNQUFNLENBQUNKLGFBQWFLLElBQUksQ0FBQyxDQUFDQztRQUNsRCxPQUFPQSxFQUFFQyxNQUFNLEVBQUVDLFFBQVFDLHVCQUF1QlI7SUFDbEQ7SUFFQSxJQUFJLENBQUNDLFlBQVk7UUFDZixNQUFNLElBQUlRLE1BQU0sQ0FBQyxvQkFBb0IsRUFBRVQsU0FBUyxVQUFVLENBQUM7SUFDN0Q7SUFFQSxPQUFPQyxXQUFXSyxNQUFNO0FBQzFCO0FBRUE7Ozs7Ozs7Ozs7Q0FVQyxHQUNELE9BQU8sU0FBU0ksaUNBQ2RULFVBQTRCLEVBQzVCVSxLQUFRLEVBQ1JDLFFBQXdEO0lBRXhELE1BQU1DLFNBQVNoQixpQkFBaUI7UUFBRWdCLFFBQVFaLFdBQVdZLE1BQU07SUFBQztJQUM1REMsUUFBUUMsR0FBRyxDQUFDLFVBQVVGO0lBQ3RCLE9BQU9BLE9BQU9ULElBQUksQ0FBQyxDQUFDWSxJQUFNQSxFQUFFVCxNQUFNLEVBQUVVLHVCQUF1QkwsV0FBV00sUUFBUU47QUFDaEYifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"prepare-session-data.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/prepare-session-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAC3C,OAAO,KAAK,EAAc,gBAAgB,EAAmB,MAAM,SAAS,CAAA;AAK5E,wBAAsB,WAAW,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,EAAE;IAAE,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAAC,cAAc,EAAE,gBAAgB,CAAA;CAAE;;;;;;;;yBAWjI;AAED,wBAAsB,cAAc,CAAC,EACnC,OAAO,EACP,iBAAiB,EAClB,EAAE;IACD,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IACtC,iBAAiB,EAAE,gBAAgB,CAAA;CACpC;;;;;;;;;yBAiBA;AAED;;;GAGG;AACH,wBAAsB,kBAAkB,CAAC,EACvC,WAAW,EACX,eAAe,EACf,kBAAkB,EACnB,EAAE;IACD,WAAW,EAAE;QACX,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;QACtC,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;KACjC,CAAA;IACD,eAAe,EAAE,gBAAgB,CAAA;IACjC,kBAAkB,EAAE,gBAAgB,CAAA;CACrC;;;;;;;;;;;;;;;;;;;;UAYA"}
1
+ {"version":3,"file":"prepare-session-data.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/prepare-session-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAC3C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAG/C,wBAAsB,WAAW,CAAC,EAAE,IAAI,EAAE,cAAc,EAAE,EAAE;IAAE,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAAC,cAAc,EAAE,gBAAgB,CAAA;CAAE;;;;;;;;yBAWjI;AAED,wBAAsB,cAAc,CAAC,EACnC,OAAO,EACP,iBAAiB,EAClB,EAAE;IACD,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;IACtC,iBAAiB,EAAE,gBAAgB,CAAA;CACpC;;;;;;;;;yBAiBA;AAED;;;GAGG;AACH,wBAAsB,kBAAkB,CAAC,EACvC,WAAW,EACX,eAAe,EACf,kBAAkB,EACnB,EAAE;IACD,WAAW,EAAE;QACX,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;QACtC,IAAI,EAAE,IAAI,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;KACjC,CAAA;IACD,eAAe,EAAE,gBAAgB,CAAA;IACjC,kBAAkB,EAAE,gBAAgB,CAAA;CACrC;;;;;;;;;;;;;;;;;;;;UAYA"}
@@ -46,4 +46,4 @@ export async function prepareSession({ session, sessionCollection }) {
46
46
  return newSessionData;
47
47
  }
48
48
 
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9wcmVwYXJlLXNlc3Npb24tZGF0YS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZXNzaW9uLCBVc2VyIH0gZnJvbSAnYmV0dGVyLWF1dGgnXG5pbXBvcnQgdHlwZSB7IENvbGxlY3Rpb24sIENvbGxlY3Rpb25Db25maWcsIENvbmZpZywgUGF5bG9hZCB9IGZyb20gJ3BheWxvYWQnXG5pbXBvcnQgeyBnZXRGaWVsZHNUb1NpZ24gfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHsgYmFNb2RlbEtleSB9IGZyb20gJy4uL2NvbnN0YW50cydcbmltcG9ydCB7IENvbGxlY3Rpb25TY2hlbWFNYXAgfSBmcm9tICcuL2dldC1jb2xsZWN0aW9uLXNjaGVtYS1tYXAnXG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBwcmVwYXJlVXNlcih7IHVzZXIsIHVzZXJDb2xsZWN0aW9uIH06IHsgdXNlcjogVXNlciAmIFJlY29yZDxzdHJpbmcsIGFueT47IHVzZXJDb2xsZWN0aW9uOiBDb2xsZWN0aW9uQ29uZmlnIH0pIHtcbiAgY29uc3QgbmV3VXNlciA9IGdldEZpZWxkc1RvU2lnbih7XG4gICAgY29sbGVjdGlvbkNvbmZpZzogdXNlckNvbGxlY3Rpb24sXG4gICAgZW1haWw6IHVzZXIuZW1haWwsXG4gICAgdXNlcjoge1xuICAgICAgLi4udXNlcixcbiAgICAgIGNvbGxlY3Rpb246IHVzZXJDb2xsZWN0aW9uLnNsdWdcbiAgICB9XG4gIH0pXG5cbiAgcmV0dXJuIG5ld1VzZXIgYXMgVXNlciAmIFJlY29yZDxzdHJpbmcsIGFueT5cbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHByZXBhcmVTZXNzaW9uKHtcbiAgc2Vzc2lvbixcbiAgc2Vzc2lvbkNvbGxlY3Rpb25cbn06IHtcbiAgc2Vzc2lvbjogU2Vzc2lvbiAmIFJlY29yZDxzdHJpbmcsIGFueT5cbiAgc2Vzc2lvbkNvbGxlY3Rpb246IENvbGxlY3Rpb25Db25maWdcbn0pIHtcbiAgY29uc3QgZmlsdGVyZWRTZXNzaW9uID0gZ2V0RmllbGRzVG9TaWduKHtcbiAgICBjb2xsZWN0aW9uQ29uZmlnOiBzZXNzaW9uQ29sbGVjdGlvbixcbiAgICBlbWFpbDogJycsXG4gICAgdXNlcjoge1xuICAgICAgLi4uc2Vzc2lvbixcbiAgICAgIGNvbGxlY3Rpb246IHNlc3Npb25Db2xsZWN0aW9uLnNsdWdcbiAgICB9XG4gIH0pXG5cbiAgZGVsZXRlIGZpbHRlcmVkU2Vzc2lvbi5lbWFpbFxuICBkZWxldGUgZmlsdGVyZWRTZXNzaW9uLmNvbGxlY3Rpb25cbiAgT2JqZWN0LmFzc2lnbihmaWx0ZXJlZFNlc3Npb24sIHtcbiAgICB1c2VySWQ6IHNlc3Npb24udXNlcklkXG4gIH0pXG5cbiAgcmV0dXJuIGZpbHRlcmVkU2Vzc2lvbiBhcyBTZXNzaW9uICYgUmVjb3JkPHN0cmluZywgYW55PlxufVxuXG4vKipcbiAqIFByZXBhcmVzIHNlc3Npb24gZGF0YSBmb3IgY29va2llIGNhY2hlIGJ5IGZpbHRlcmluZyB1c2VyIGFuZCBzZXNzaW9uIG9iamVjdHNcbiAqIGJhc2VkIG9uIHRoZSBwYXlsb2FkIGNvbmZpZ3VyYXRpb24ncyAnc2F2ZVRvSnd0JyBwcm9wZXJ0eVxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcHJlcGFyZVNlc3Npb25EYXRhKHtcbiAgc2Vzc2lvbkRhdGEsXG4gIHVzZXJzQ29sbGVjdGlvbixcbiAgc2Vzc2lvbnNDb2xsZWN0aW9uXG59OiB7XG4gIHNlc3Npb25EYXRhOiB7XG4gICAgc2Vzc2lvbjogU2Vzc2lvbiAmIFJlY29yZDxzdHJpbmcsIGFueT5cbiAgICB1c2VyOiBVc2VyICYgUmVjb3JkPHN0cmluZywgYW55PlxuICB9XG4gIHVzZXJzQ29sbGVjdGlvbjogQ29sbGVjdGlvbkNvbmZpZ1xuICBzZXNzaW9uc0NvbGxlY3Rpb246IENvbGxlY3Rpb25Db25maWdcbn0pIHtcbiAgaWYgKCFzZXNzaW9uRGF0YSB8fCAhc2Vzc2lvbkRhdGEudXNlcikgcmV0dXJuIG51bGxcblxuICBjb25zdCBuZXdVc2VyID0gYXdhaXQgcHJlcGFyZVVzZXIoeyB1c2VyOiBzZXNzaW9uRGF0YS51c2VyLCB1c2VyQ29sbGVjdGlvbjogdXNlcnNDb2xsZWN0aW9uIH0pXG4gIGNvbnN0IG5ld1Nlc3Npb24gPSBhd2FpdCBwcmVwYXJlU2Vzc2lvbih7IHNlc3Npb246IHNlc3Npb25EYXRhLnNlc3Npb24sIHNlc3Npb25Db2xsZWN0aW9uOiBzZXNzaW9uc0NvbGxlY3Rpb24gfSlcblxuICBjb25zdCBuZXdTZXNzaW9uRGF0YSA9IHtcbiAgICBzZXNzaW9uOiBuZXdTZXNzaW9uLFxuICAgIHVzZXI6IG5ld1VzZXJcbiAgfVxuXG4gIHJldHVybiBuZXdTZXNzaW9uRGF0YVxufVxuIl0sIm5hbWVzIjpbImdldEZpZWxkc1RvU2lnbiIsInByZXBhcmVVc2VyIiwidXNlciIsInVzZXJDb2xsZWN0aW9uIiwibmV3VXNlciIsImNvbGxlY3Rpb25Db25maWciLCJlbWFpbCIsImNvbGxlY3Rpb24iLCJzbHVnIiwicHJlcGFyZVNlc3Npb24iLCJzZXNzaW9uIiwic2Vzc2lvbkNvbGxlY3Rpb24iLCJmaWx0ZXJlZFNlc3Npb24iLCJPYmplY3QiLCJhc3NpZ24iLCJ1c2VySWQiLCJwcmVwYXJlU2Vzc2lvbkRhdGEiLCJzZXNzaW9uRGF0YSIsInVzZXJzQ29sbGVjdGlvbiIsInNlc3Npb25zQ29sbGVjdGlvbiIsIm5ld1Nlc3Npb24iLCJuZXdTZXNzaW9uRGF0YSJdLCJtYXBwaW5ncyI6IkFBRUEsU0FBU0EsZUFBZSxRQUFRLFVBQVM7QUFJekMsT0FBTyxlQUFlQyxZQUFZLEVBQUVDLElBQUksRUFBRUMsY0FBYyxFQUEwRTtJQUNoSSxNQUFNQyxVQUFVSixnQkFBZ0I7UUFDOUJLLGtCQUFrQkY7UUFDbEJHLE9BQU9KLEtBQUtJLEtBQUs7UUFDakJKLE1BQU07WUFDSixHQUFHQSxJQUFJO1lBQ1BLLFlBQVlKLGVBQWVLLElBQUk7UUFDakM7SUFDRjtJQUVBLE9BQU9KO0FBQ1Q7QUFFQSxPQUFPLGVBQWVLLGVBQWUsRUFDbkNDLE9BQU8sRUFDUEMsaUJBQWlCLEVBSWxCO0lBQ0MsTUFBTUMsa0JBQWtCWixnQkFBZ0I7UUFDdENLLGtCQUFrQk07UUFDbEJMLE9BQU87UUFDUEosTUFBTTtZQUNKLEdBQUdRLE9BQU87WUFDVkgsWUFBWUksa0JBQWtCSCxJQUFJO1FBQ3BDO0lBQ0Y7SUFFQSxPQUFPSSxnQkFBZ0JOLEtBQUs7SUFDNUIsT0FBT00sZ0JBQWdCTCxVQUFVO0lBQ2pDTSxPQUFPQyxNQUFNLENBQUNGLGlCQUFpQjtRQUM3QkcsUUFBUUwsUUFBUUssTUFBTTtJQUN4QjtJQUVBLE9BQU9IO0FBQ1Q7QUFFQTs7O0NBR0MsR0FDRCxPQUFPLGVBQWVJLG1CQUFtQixFQUN2Q0MsV0FBVyxFQUNYQyxlQUFlLEVBQ2ZDLGtCQUFrQixFQVFuQjtJQUNDLElBQUksQ0FBQ0YsZUFBZSxDQUFDQSxZQUFZZixJQUFJLEVBQUUsT0FBTztJQUU5QyxNQUFNRSxVQUFVLE1BQU1ILFlBQVk7UUFBRUMsTUFBTWUsWUFBWWYsSUFBSTtRQUFFQyxnQkFBZ0JlO0lBQWdCO0lBQzVGLE1BQU1FLGFBQWEsTUFBTVgsZUFBZTtRQUFFQyxTQUFTTyxZQUFZUCxPQUFPO1FBQUVDLG1CQUFtQlE7SUFBbUI7SUFFOUcsTUFBTUUsaUJBQWlCO1FBQ3JCWCxTQUFTVTtRQUNUbEIsTUFBTUU7SUFDUjtJQUVBLE9BQU9pQjtBQUNUIn0=
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9wcmVwYXJlLXNlc3Npb24tZGF0YS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTZXNzaW9uLCBVc2VyIH0gZnJvbSAnYmV0dGVyLWF1dGgnXG5pbXBvcnQgdHlwZSB7IENvbGxlY3Rpb25Db25maWcgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IHsgZ2V0RmllbGRzVG9TaWduIH0gZnJvbSAncGF5bG9hZCdcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHByZXBhcmVVc2VyKHsgdXNlciwgdXNlckNvbGxlY3Rpb24gfTogeyB1c2VyOiBVc2VyICYgUmVjb3JkPHN0cmluZywgYW55PjsgdXNlckNvbGxlY3Rpb246IENvbGxlY3Rpb25Db25maWcgfSkge1xuICBjb25zdCBuZXdVc2VyID0gZ2V0RmllbGRzVG9TaWduKHtcbiAgICBjb2xsZWN0aW9uQ29uZmlnOiB1c2VyQ29sbGVjdGlvbixcbiAgICBlbWFpbDogdXNlci5lbWFpbCxcbiAgICB1c2VyOiB7XG4gICAgICAuLi51c2VyLFxuICAgICAgY29sbGVjdGlvbjogdXNlckNvbGxlY3Rpb24uc2x1Z1xuICAgIH1cbiAgfSlcblxuICByZXR1cm4gbmV3VXNlciBhcyBVc2VyICYgUmVjb3JkPHN0cmluZywgYW55PlxufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gcHJlcGFyZVNlc3Npb24oe1xuICBzZXNzaW9uLFxuICBzZXNzaW9uQ29sbGVjdGlvblxufToge1xuICBzZXNzaW9uOiBTZXNzaW9uICYgUmVjb3JkPHN0cmluZywgYW55PlxuICBzZXNzaW9uQ29sbGVjdGlvbjogQ29sbGVjdGlvbkNvbmZpZ1xufSkge1xuICBjb25zdCBmaWx0ZXJlZFNlc3Npb24gPSBnZXRGaWVsZHNUb1NpZ24oe1xuICAgIGNvbGxlY3Rpb25Db25maWc6IHNlc3Npb25Db2xsZWN0aW9uLFxuICAgIGVtYWlsOiAnJyxcbiAgICB1c2VyOiB7XG4gICAgICAuLi5zZXNzaW9uLFxuICAgICAgY29sbGVjdGlvbjogc2Vzc2lvbkNvbGxlY3Rpb24uc2x1Z1xuICAgIH1cbiAgfSlcblxuICBkZWxldGUgZmlsdGVyZWRTZXNzaW9uLmVtYWlsXG4gIGRlbGV0ZSBmaWx0ZXJlZFNlc3Npb24uY29sbGVjdGlvblxuICBPYmplY3QuYXNzaWduKGZpbHRlcmVkU2Vzc2lvbiwge1xuICAgIHVzZXJJZDogc2Vzc2lvbi51c2VySWRcbiAgfSlcblxuICByZXR1cm4gZmlsdGVyZWRTZXNzaW9uIGFzIFNlc3Npb24gJiBSZWNvcmQ8c3RyaW5nLCBhbnk+XG59XG5cbi8qKlxuICogUHJlcGFyZXMgc2Vzc2lvbiBkYXRhIGZvciBjb29raWUgY2FjaGUgYnkgZmlsdGVyaW5nIHVzZXIgYW5kIHNlc3Npb24gb2JqZWN0c1xuICogYmFzZWQgb24gdGhlIHBheWxvYWQgY29uZmlndXJhdGlvbidzICdzYXZlVG9Kd3QnIHByb3BlcnR5XG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBwcmVwYXJlU2Vzc2lvbkRhdGEoe1xuICBzZXNzaW9uRGF0YSxcbiAgdXNlcnNDb2xsZWN0aW9uLFxuICBzZXNzaW9uc0NvbGxlY3Rpb25cbn06IHtcbiAgc2Vzc2lvbkRhdGE6IHtcbiAgICBzZXNzaW9uOiBTZXNzaW9uICYgUmVjb3JkPHN0cmluZywgYW55PlxuICAgIHVzZXI6IFVzZXIgJiBSZWNvcmQ8c3RyaW5nLCBhbnk+XG4gIH1cbiAgdXNlcnNDb2xsZWN0aW9uOiBDb2xsZWN0aW9uQ29uZmlnXG4gIHNlc3Npb25zQ29sbGVjdGlvbjogQ29sbGVjdGlvbkNvbmZpZ1xufSkge1xuICBpZiAoIXNlc3Npb25EYXRhIHx8ICFzZXNzaW9uRGF0YS51c2VyKSByZXR1cm4gbnVsbFxuXG4gIGNvbnN0IG5ld1VzZXIgPSBhd2FpdCBwcmVwYXJlVXNlcih7IHVzZXI6IHNlc3Npb25EYXRhLnVzZXIsIHVzZXJDb2xsZWN0aW9uOiB1c2Vyc0NvbGxlY3Rpb24gfSlcbiAgY29uc3QgbmV3U2Vzc2lvbiA9IGF3YWl0IHByZXBhcmVTZXNzaW9uKHsgc2Vzc2lvbjogc2Vzc2lvbkRhdGEuc2Vzc2lvbiwgc2Vzc2lvbkNvbGxlY3Rpb246IHNlc3Npb25zQ29sbGVjdGlvbiB9KVxuXG4gIGNvbnN0IG5ld1Nlc3Npb25EYXRhID0ge1xuICAgIHNlc3Npb246IG5ld1Nlc3Npb24sXG4gICAgdXNlcjogbmV3VXNlclxuICB9XG5cbiAgcmV0dXJuIG5ld1Nlc3Npb25EYXRhXG59XG4iXSwibmFtZXMiOlsiZ2V0RmllbGRzVG9TaWduIiwicHJlcGFyZVVzZXIiLCJ1c2VyIiwidXNlckNvbGxlY3Rpb24iLCJuZXdVc2VyIiwiY29sbGVjdGlvbkNvbmZpZyIsImVtYWlsIiwiY29sbGVjdGlvbiIsInNsdWciLCJwcmVwYXJlU2Vzc2lvbiIsInNlc3Npb24iLCJzZXNzaW9uQ29sbGVjdGlvbiIsImZpbHRlcmVkU2Vzc2lvbiIsIk9iamVjdCIsImFzc2lnbiIsInVzZXJJZCIsInByZXBhcmVTZXNzaW9uRGF0YSIsInNlc3Npb25EYXRhIiwidXNlcnNDb2xsZWN0aW9uIiwic2Vzc2lvbnNDb2xsZWN0aW9uIiwibmV3U2Vzc2lvbiIsIm5ld1Nlc3Npb25EYXRhIl0sIm1hcHBpbmdzIjoiQUFFQSxTQUFTQSxlQUFlLFFBQVEsVUFBUztBQUV6QyxPQUFPLGVBQWVDLFlBQVksRUFBRUMsSUFBSSxFQUFFQyxjQUFjLEVBQTBFO0lBQ2hJLE1BQU1DLFVBQVVKLGdCQUFnQjtRQUM5Qkssa0JBQWtCRjtRQUNsQkcsT0FBT0osS0FBS0ksS0FBSztRQUNqQkosTUFBTTtZQUNKLEdBQUdBLElBQUk7WUFDUEssWUFBWUosZUFBZUssSUFBSTtRQUNqQztJQUNGO0lBRUEsT0FBT0o7QUFDVDtBQUVBLE9BQU8sZUFBZUssZUFBZSxFQUNuQ0MsT0FBTyxFQUNQQyxpQkFBaUIsRUFJbEI7SUFDQyxNQUFNQyxrQkFBa0JaLGdCQUFnQjtRQUN0Q0ssa0JBQWtCTTtRQUNsQkwsT0FBTztRQUNQSixNQUFNO1lBQ0osR0FBR1EsT0FBTztZQUNWSCxZQUFZSSxrQkFBa0JILElBQUk7UUFDcEM7SUFDRjtJQUVBLE9BQU9JLGdCQUFnQk4sS0FBSztJQUM1QixPQUFPTSxnQkFBZ0JMLFVBQVU7SUFDakNNLE9BQU9DLE1BQU0sQ0FBQ0YsaUJBQWlCO1FBQzdCRyxRQUFRTCxRQUFRSyxNQUFNO0lBQ3hCO0lBRUEsT0FBT0g7QUFDVDtBQUVBOzs7Q0FHQyxHQUNELE9BQU8sZUFBZUksbUJBQW1CLEVBQ3ZDQyxXQUFXLEVBQ1hDLGVBQWUsRUFDZkMsa0JBQWtCLEVBUW5CO0lBQ0MsSUFBSSxDQUFDRixlQUFlLENBQUNBLFlBQVlmLElBQUksRUFBRSxPQUFPO0lBRTlDLE1BQU1FLFVBQVUsTUFBTUgsWUFBWTtRQUFFQyxNQUFNZSxZQUFZZixJQUFJO1FBQUVDLGdCQUFnQmU7SUFBZ0I7SUFDNUYsTUFBTUUsYUFBYSxNQUFNWCxlQUFlO1FBQUVDLFNBQVNPLFlBQVlQLE9BQU87UUFBRUMsbUJBQW1CUTtJQUFtQjtJQUU5RyxNQUFNRSxpQkFBaUI7UUFDckJYLFNBQVNVO1FBQ1RsQixNQUFNRTtJQUNSO0lBRUEsT0FBT2lCO0FBQ1QifQ==
@@ -0,0 +1,21 @@
1
+ import type { CollectionConfig } from 'payload';
2
+ import type { BetterAuthSchemas } from '../types';
3
+ /**
4
+ * Syncs a BetterAuth `ResolvedSchema` object with the *actual* collection
5
+ * definitions created by this plugin.
6
+ *
7
+ * This must run **after** the first call to `buildCollections`, because only
8
+ * then do we know the user-overridden slugs / field names. The algorithm is
9
+ * kept deliberately simple:
10
+ *
11
+ * 1. Build a `modelKey → newSlug` map from each collection's
12
+ * `custom.betterAuthModelKey` property.
13
+ * 2. Update `schema.modelName` for all affected tables.
14
+ * 3. Rewrite `references.model` in *every* table field according to the new
15
+ * slugs. We do this in a dedicated pass so referencing tables no longer
16
+ * depend on the original slugs.
17
+ * 4. Finally, iterate collections once more to apply any *field* renames via
18
+ * the `custom.betterAuthFieldKey` property.
19
+ */
20
+ export declare function syncResolvedSchemaWithCollectionMap(resolvedSchemas: BetterAuthSchemas, collectionMap: Record<string, CollectionConfig>): BetterAuthSchemas;
21
+ //# sourceMappingURL=sync-resolved-schema-with-collection-map.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync-resolved-schema-with-collection-map.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAG/C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAA;AAEjD;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,mCAAmC,CACjD,eAAe,EAAE,iBAAiB,EAClC,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,GAC9C,iBAAiB,CAwDnB"}
@@ -0,0 +1,62 @@
1
+ /**
2
+ * Syncs a BetterAuth `ResolvedSchema` object with the *actual* collection
3
+ * definitions created by this plugin.
4
+ *
5
+ * This must run **after** the first call to `buildCollections`, because only
6
+ * then do we know the user-overridden slugs / field names. The algorithm is
7
+ * kept deliberately simple:
8
+ *
9
+ * 1. Build a `modelKey → newSlug` map from each collection's
10
+ * `custom.betterAuthModelKey` property.
11
+ * 2. Update `schema.modelName` for all affected tables.
12
+ * 3. Rewrite `references.model` in *every* table field according to the new
13
+ * slugs. We do this in a dedicated pass so referencing tables no longer
14
+ * depend on the original slugs.
15
+ * 4. Finally, iterate collections once more to apply any *field* renames via
16
+ * the `custom.betterAuthFieldKey` property.
17
+ */ export function syncResolvedSchemaWithCollectionMap(resolvedSchemas, collectionMap) {
18
+ const collections = Object.values(collectionMap);
19
+ // Helper to update references across the whole schema
20
+ const updateReferences = (oldSlug, newSlug)=>{
21
+ for (const schema of Object.values(resolvedSchemas)){
22
+ for (const fieldAttr of Object.values(schema.fields)){
23
+ const ref = fieldAttr.references;
24
+ if (ref?.model === oldSlug) {
25
+ ref.model = newSlug;
26
+ }
27
+ }
28
+ }
29
+ };
30
+ for (const [modelKey, schema] of Object.entries(resolvedSchemas)){
31
+ // Find the collection corresponding to this BetterAuth model
32
+ const collection = collections.find((c)=>c.custom?.betterAuthModelKey === modelKey);
33
+ if (!collection) {
34
+ console.error(`Collection not found for model key: ${modelKey}`);
35
+ continue;
36
+ }
37
+ // ───── Sync slug ─────────────────────────────────────────────────────────
38
+ const oldSlug = schema.modelName;
39
+ const newSlug = collection.slug;
40
+ if (oldSlug !== newSlug) {
41
+ // First, rewrite *all* references that still point to the old slug
42
+ updateReferences(oldSlug, newSlug);
43
+ // Now store the new slug on the schema itself
44
+ schema.modelName = newSlug;
45
+ }
46
+ const collectionFields = Array.isArray(collection.fields) ? collection.fields : [];
47
+ for (const [fieldKey, schemaField] of Object.entries(schema.fields)){
48
+ const matchingField = collectionFields.find((f)=>f.custom?.betterAuthFieldKey === fieldKey);
49
+ if (!matchingField) {
50
+ console.error(`Field not found for key "${fieldKey}" in collection "${collection.slug}"`);
51
+ continue;
52
+ }
53
+ const newName = matchingField.name;
54
+ if (newName && schemaField.fieldName !== newName) {
55
+ schemaField.fieldName = newName;
56
+ }
57
+ }
58
+ }
59
+ return resolvedSchemas;
60
+ }
61
+
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vaGVscGVycy9zeW5jLXJlc29sdmVkLXNjaGVtYS13aXRoLWNvbGxlY3Rpb24tbWFwLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ29sbGVjdGlvbkNvbmZpZyB9IGZyb20gJ3BheWxvYWQnXG5cbmltcG9ydCB0eXBlIHsgTW9kZWxLZXkgfSBmcm9tICcuLi8uLi9nZW5lcmF0ZWQtdHlwZXMnXG5pbXBvcnQgdHlwZSB7IEJldHRlckF1dGhTY2hlbWFzIH0gZnJvbSAnLi4vdHlwZXMnXG5cbi8qKlxuICogU3luY3MgYSBCZXR0ZXJBdXRoIGBSZXNvbHZlZFNjaGVtYWAgb2JqZWN0IHdpdGggdGhlICphY3R1YWwqIGNvbGxlY3Rpb25cbiAqIGRlZmluaXRpb25zIGNyZWF0ZWQgYnkgdGhpcyBwbHVnaW4uXG4gKlxuICogVGhpcyBtdXN0IHJ1biAqKmFmdGVyKiogdGhlIGZpcnN0IGNhbGwgdG8gYGJ1aWxkQ29sbGVjdGlvbnNgLCBiZWNhdXNlIG9ubHlcbiAqIHRoZW4gZG8gd2Uga25vdyB0aGUgdXNlci1vdmVycmlkZGVuIHNsdWdzIC8gZmllbGQgbmFtZXMuICBUaGUgYWxnb3JpdGhtIGlzXG4gKiBrZXB0IGRlbGliZXJhdGVseSBzaW1wbGU6XG4gKlxuICogIDEuIEJ1aWxkIGEgYG1vZGVsS2V5IOKGkiBuZXdTbHVnYCBtYXAgZnJvbSBlYWNoIGNvbGxlY3Rpb24nc1xuICogICAgIGBjdXN0b20uYmV0dGVyQXV0aE1vZGVsS2V5YCBwcm9wZXJ0eS5cbiAqICAyLiBVcGRhdGUgYHNjaGVtYS5tb2RlbE5hbWVgIGZvciBhbGwgYWZmZWN0ZWQgdGFibGVzLlxuICogIDMuIFJld3JpdGUgYHJlZmVyZW5jZXMubW9kZWxgIGluICpldmVyeSogdGFibGUgZmllbGQgYWNjb3JkaW5nIHRvIHRoZSBuZXdcbiAqICAgICBzbHVncy4gIFdlIGRvIHRoaXMgaW4gYSBkZWRpY2F0ZWQgcGFzcyBzbyByZWZlcmVuY2luZyB0YWJsZXMgbm8gbG9uZ2VyXG4gKiAgICAgZGVwZW5kIG9uIHRoZSBvcmlnaW5hbCBzbHVncy5cbiAqICA0LiBGaW5hbGx5LCBpdGVyYXRlIGNvbGxlY3Rpb25zIG9uY2UgbW9yZSB0byBhcHBseSBhbnkgKmZpZWxkKiByZW5hbWVzIHZpYVxuICogICAgIHRoZSBgY3VzdG9tLmJldHRlckF1dGhGaWVsZEtleWAgcHJvcGVydHkuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzeW5jUmVzb2x2ZWRTY2hlbWFXaXRoQ29sbGVjdGlvbk1hcChcbiAgcmVzb2x2ZWRTY2hlbWFzOiBCZXR0ZXJBdXRoU2NoZW1hcyxcbiAgY29sbGVjdGlvbk1hcDogUmVjb3JkPHN0cmluZywgQ29sbGVjdGlvbkNvbmZpZz5cbik6IEJldHRlckF1dGhTY2hlbWFzIHtcbiAgY29uc3QgY29sbGVjdGlvbnMgPSBPYmplY3QudmFsdWVzKGNvbGxlY3Rpb25NYXApXG5cbiAgLy8gSGVscGVyIHRvIHVwZGF0ZSByZWZlcmVuY2VzIGFjcm9zcyB0aGUgd2hvbGUgc2NoZW1hXG4gIGNvbnN0IHVwZGF0ZVJlZmVyZW5jZXMgPSAob2xkU2x1Zzogc3RyaW5nLCBuZXdTbHVnOiBzdHJpbmcpOiB2b2lkID0+IHtcbiAgICBmb3IgKGNvbnN0IHNjaGVtYSBvZiBPYmplY3QudmFsdWVzKHJlc29sdmVkU2NoZW1hcykpIHtcbiAgICAgIGZvciAoY29uc3QgZmllbGRBdHRyIG9mIE9iamVjdC52YWx1ZXMoc2NoZW1hLmZpZWxkcykpIHtcbiAgICAgICAgY29uc3QgcmVmID0gKGZpZWxkQXR0ciBhcyBhbnkpLnJlZmVyZW5jZXNcbiAgICAgICAgaWYgKHJlZj8ubW9kZWwgPT09IG9sZFNsdWcpIHtcbiAgICAgICAgICByZWYubW9kZWwgPSBuZXdTbHVnXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBmb3IgKGNvbnN0IFttb2RlbEtleSwgc2NoZW1hXSBvZiBPYmplY3QuZW50cmllcyhyZXNvbHZlZFNjaGVtYXMpIGFzIFtNb2RlbEtleSwgKHR5cGVvZiByZXNvbHZlZFNjaGVtYXMpW01vZGVsS2V5XV1bXSkge1xuICAgIC8vIEZpbmQgdGhlIGNvbGxlY3Rpb24gY29ycmVzcG9uZGluZyB0byB0aGlzIEJldHRlckF1dGggbW9kZWxcbiAgICBjb25zdCBjb2xsZWN0aW9uID0gY29sbGVjdGlvbnMuZmluZCgoYykgPT4gKGMuY3VzdG9tIGFzIGFueSk/LmJldHRlckF1dGhNb2RlbEtleSA9PT0gbW9kZWxLZXkpXG4gICAgaWYgKCFjb2xsZWN0aW9uKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGBDb2xsZWN0aW9uIG5vdCBmb3VuZCBmb3IgbW9kZWwga2V5OiAke21vZGVsS2V5fWApXG4gICAgICBjb250aW51ZVxuICAgIH1cblxuICAgIC8vIOKUgOKUgOKUgOKUgOKUgCBTeW5jIHNsdWcg4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSA4pSAXG4gICAgY29uc3Qgb2xkU2x1ZyA9IHNjaGVtYS5tb2RlbE5hbWVcbiAgICBjb25zdCBuZXdTbHVnID0gY29sbGVjdGlvbi5zbHVnXG5cbiAgICBpZiAob2xkU2x1ZyAhPT0gbmV3U2x1Zykge1xuICAgICAgLy8gRmlyc3QsIHJld3JpdGUgKmFsbCogcmVmZXJlbmNlcyB0aGF0IHN0aWxsIHBvaW50IHRvIHRoZSBvbGQgc2x1Z1xuICAgICAgdXBkYXRlUmVmZXJlbmNlcyhvbGRTbHVnLCBuZXdTbHVnKVxuXG4gICAgICAvLyBOb3cgc3RvcmUgdGhlIG5ldyBzbHVnIG9uIHRoZSBzY2hlbWEgaXRzZWxmXG4gICAgICBzY2hlbWEubW9kZWxOYW1lID0gbmV3U2x1Z1xuICAgIH1cblxuICAgIC8vIOKUgOKUgOKUgOKUgOKUgCBTeW5jIGZpZWxkIG5hbWVzIOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgOKUgFxuICAgIHR5cGUgRmllbGRXaXRoSWRzID0geyBuYW1lPzogc3RyaW5nOyBjdXN0b20/OiB7IGJldHRlckF1dGhGaWVsZEtleT86IHN0cmluZyB9IH1cblxuICAgIGNvbnN0IGNvbGxlY3Rpb25GaWVsZHM6IEZpZWxkV2l0aElkc1tdID0gQXJyYXkuaXNBcnJheShjb2xsZWN0aW9uLmZpZWxkcykgPyAoY29sbGVjdGlvbi5maWVsZHMgYXMgRmllbGRXaXRoSWRzW10pIDogW11cblxuICAgIGZvciAoY29uc3QgW2ZpZWxkS2V5LCBzY2hlbWFGaWVsZF0gb2YgT2JqZWN0LmVudHJpZXMoc2NoZW1hLmZpZWxkcykpIHtcbiAgICAgIGNvbnN0IG1hdGNoaW5nRmllbGQgPSBjb2xsZWN0aW9uRmllbGRzLmZpbmQoKGYpID0+IGYuY3VzdG9tPy5iZXR0ZXJBdXRoRmllbGRLZXkgPT09IGZpZWxkS2V5KVxuXG4gICAgICBpZiAoIW1hdGNoaW5nRmllbGQpIHtcbiAgICAgICAgY29uc29sZS5lcnJvcihgRmllbGQgbm90IGZvdW5kIGZvciBrZXkgXCIke2ZpZWxkS2V5fVwiIGluIGNvbGxlY3Rpb24gXCIke2NvbGxlY3Rpb24uc2x1Z31cImApXG4gICAgICAgIGNvbnRpbnVlXG4gICAgICB9XG5cbiAgICAgIGNvbnN0IG5ld05hbWUgPSBtYXRjaGluZ0ZpZWxkLm5hbWVcbiAgICAgIGlmIChuZXdOYW1lICYmIHNjaGVtYUZpZWxkLmZpZWxkTmFtZSAhPT0gbmV3TmFtZSkge1xuICAgICAgICBzY2hlbWFGaWVsZC5maWVsZE5hbWUgPSBuZXdOYW1lXG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHJlc29sdmVkU2NoZW1hc1xufVxuIl0sIm5hbWVzIjpbInN5bmNSZXNvbHZlZFNjaGVtYVdpdGhDb2xsZWN0aW9uTWFwIiwicmVzb2x2ZWRTY2hlbWFzIiwiY29sbGVjdGlvbk1hcCIsImNvbGxlY3Rpb25zIiwiT2JqZWN0IiwidmFsdWVzIiwidXBkYXRlUmVmZXJlbmNlcyIsIm9sZFNsdWciLCJuZXdTbHVnIiwic2NoZW1hIiwiZmllbGRBdHRyIiwiZmllbGRzIiwicmVmIiwicmVmZXJlbmNlcyIsIm1vZGVsIiwibW9kZWxLZXkiLCJlbnRyaWVzIiwiY29sbGVjdGlvbiIsImZpbmQiLCJjIiwiY3VzdG9tIiwiYmV0dGVyQXV0aE1vZGVsS2V5IiwiY29uc29sZSIsImVycm9yIiwibW9kZWxOYW1lIiwic2x1ZyIsImNvbGxlY3Rpb25GaWVsZHMiLCJBcnJheSIsImlzQXJyYXkiLCJmaWVsZEtleSIsInNjaGVtYUZpZWxkIiwibWF0Y2hpbmdGaWVsZCIsImYiLCJiZXR0ZXJBdXRoRmllbGRLZXkiLCJuZXdOYW1lIiwibmFtZSIsImZpZWxkTmFtZSJdLCJtYXBwaW5ncyI6IkFBS0E7Ozs7Ozs7Ozs7Ozs7Ozs7Q0FnQkMsR0FDRCxPQUFPLFNBQVNBLG9DQUNkQyxlQUFrQyxFQUNsQ0MsYUFBK0M7SUFFL0MsTUFBTUMsY0FBY0MsT0FBT0MsTUFBTSxDQUFDSDtJQUVsQyxzREFBc0Q7SUFDdEQsTUFBTUksbUJBQW1CLENBQUNDLFNBQWlCQztRQUN6QyxLQUFLLE1BQU1DLFVBQVVMLE9BQU9DLE1BQU0sQ0FBQ0osaUJBQWtCO1lBQ25ELEtBQUssTUFBTVMsYUFBYU4sT0FBT0MsTUFBTSxDQUFDSSxPQUFPRSxNQUFNLEVBQUc7Z0JBQ3BELE1BQU1DLE1BQU0sQUFBQ0YsVUFBa0JHLFVBQVU7Z0JBQ3pDLElBQUlELEtBQUtFLFVBQVVQLFNBQVM7b0JBQzFCSyxJQUFJRSxLQUFLLEdBQUdOO2dCQUNkO1lBQ0Y7UUFDRjtJQUNGO0lBRUEsS0FBSyxNQUFNLENBQUNPLFVBQVVOLE9BQU8sSUFBSUwsT0FBT1ksT0FBTyxDQUFDZixpQkFBc0U7UUFDcEgsNkRBQTZEO1FBQzdELE1BQU1nQixhQUFhZCxZQUFZZSxJQUFJLENBQUMsQ0FBQ0MsSUFBTSxBQUFDQSxFQUFFQyxNQUFNLEVBQVVDLHVCQUF1Qk47UUFDckYsSUFBSSxDQUFDRSxZQUFZO1lBQ2ZLLFFBQVFDLEtBQUssQ0FBQyxDQUFDLG9DQUFvQyxFQUFFUixVQUFVO1lBQy9EO1FBQ0Y7UUFFQSw0RUFBNEU7UUFDNUUsTUFBTVIsVUFBVUUsT0FBT2UsU0FBUztRQUNoQyxNQUFNaEIsVUFBVVMsV0FBV1EsSUFBSTtRQUUvQixJQUFJbEIsWUFBWUMsU0FBUztZQUN2QixtRUFBbUU7WUFDbkVGLGlCQUFpQkMsU0FBU0M7WUFFMUIsOENBQThDO1lBQzlDQyxPQUFPZSxTQUFTLEdBQUdoQjtRQUNyQjtRQUtBLE1BQU1rQixtQkFBbUNDLE1BQU1DLE9BQU8sQ0FBQ1gsV0FBV04sTUFBTSxJQUFLTSxXQUFXTixNQUFNLEdBQXNCLEVBQUU7UUFFdEgsS0FBSyxNQUFNLENBQUNrQixVQUFVQyxZQUFZLElBQUkxQixPQUFPWSxPQUFPLENBQUNQLE9BQU9FLE1BQU0sRUFBRztZQUNuRSxNQUFNb0IsZ0JBQWdCTCxpQkFBaUJSLElBQUksQ0FBQyxDQUFDYyxJQUFNQSxFQUFFWixNQUFNLEVBQUVhLHVCQUF1Qko7WUFFcEYsSUFBSSxDQUFDRSxlQUFlO2dCQUNsQlQsUUFBUUMsS0FBSyxDQUFDLENBQUMseUJBQXlCLEVBQUVNLFNBQVMsaUJBQWlCLEVBQUVaLFdBQVdRLElBQUksQ0FBQyxDQUFDLENBQUM7Z0JBQ3hGO1lBQ0Y7WUFFQSxNQUFNUyxVQUFVSCxjQUFjSSxJQUFJO1lBQ2xDLElBQUlELFdBQVdKLFlBQVlNLFNBQVMsS0FBS0YsU0FBUztnQkFDaERKLFlBQVlNLFNBQVMsR0FBR0Y7WUFDMUI7UUFDRjtJQUNGO0lBRUEsT0FBT2pDO0FBQ1QifQ==
@@ -1,8 +1,15 @@
1
- import { type Config } from 'payload';
1
+ import type { BetterAuthOptions } from 'better-auth/types';
2
+ import { SanitizedConfig, type Config } from 'payload';
3
+ import { PayloadAdapterParams } from '../types';
2
4
  import type { BetterAuthPluginOptions } from './types';
3
5
  export * from './helpers/index';
4
6
  export { getPayloadAuth } from './lib/get-payload-auth';
5
7
  export { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index';
6
8
  export * from './types';
7
9
  export declare function betterAuthPlugin(pluginOptions: BetterAuthPluginOptions): (config: Config) => Config;
10
+ export declare function withPayloadAuth({ payloadConfig, betterAuthConfig: pluginOptions, adapterOptions }: {
11
+ payloadConfig: SanitizedConfig;
12
+ betterAuthConfig: BetterAuthPluginOptions;
13
+ adapterOptions: Pick<PayloadAdapterParams, 'idType'> & Partial<Pick<PayloadAdapterParams, 'payloadClient'>>;
14
+ }): BetterAuthOptions;
8
15
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2D,KAAK,MAAM,EAAc,MAAM,SAAS,CAAA;AAQ1G,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAA;AAItD,cAAc,iBAAiB,CAAA;AAC/B,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACvD,OAAO,EAAE,yBAAyB,EAAE,MAAM,0CAA0C,CAAA;AACpF,cAAc,SAAS,CAAA;AAEvB,wBAAgB,gBAAgB,CAAC,aAAa,EAAE,uBAAuB,IAC7D,QAAQ,MAAM,KAAG,MAAM,CA2IhC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAA;AAC1D,OAAO,EAAc,eAAe,EAAE,KAAK,MAAM,EAAE,MAAM,SAAS,CAAA;AAElE,OAAO,EAAE,oBAAoB,EAAE,MAAM,UAAU,CAAA;AAQ/C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAA;AAEtD,cAAc,iBAAiB,CAAA;AAC/B,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAA;AACvD,OAAO,EAAE,yBAAyB,EAAE,MAAM,0CAA0C,CAAA;AACpF,cAAc,SAAS,CAAA;AA8CvB,wBAAgB,gBAAgB,CAAC,aAAa,EAAE,uBAAuB,IAC7D,QAAQ,MAAM,KAAG,MAAM,CA6DhC;AAED,wBAAgB,eAAe,CAAC,EAC9B,aAAa,EACb,gBAAgB,EAAE,aAAa,EAC/B,cAAc,EACf,EAAE;IACD,aAAa,EAAE,eAAe,CAAA;IAC9B,gBAAgB,EAAE,uBAAuB,CAAA;IACzC,cAAc,EAAE,IAAI,CAAC,oBAAoB,EAAE,QAAQ,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,oBAAoB,EAAE,eAAe,CAAC,CAAC,CAAA;CAC5G,GAAG,iBAAiB,CAoBpB"}
@@ -1,14 +1,48 @@
1
- import { adminRoutes, baModelKey, baseSlugs, supportedBAPluginIds } from "./constants";
2
- import { checkPluginExists } from "./helpers/check-plugin-exists";
3
- import { buildCollectionMap } from "./lib/build-collections/index";
1
+ import { getPayload } from "payload";
2
+ import { payloadAdapter } from "payload-auth/better-auth/adapter";
3
+ import { getDefaultBetterAuthSchema } from "./helpers/get-better-auth-schema";
4
+ import { syncResolvedSchemaWithCollectionMap } from "./helpers/sync-resolved-schema-with-collection-map";
5
+ import { applyDisabledDefaultAuthConfig } from "./lib/apply-disabled-default-auth-config";
6
+ import { buildCollections } from "./lib/build-collections/index";
4
7
  import { initBetterAuth } from "./lib/init-better-auth";
5
8
  import { sanitizeBetterAuthOptions } from "./lib/sanitize-better-auth-options/index";
6
9
  import { setLoginMethods } from "./lib/set-login-methods";
7
- import { buildCollectionSchemaMap } from "./helpers/get-collection-schema-map";
8
10
  export * from "./helpers/index";
9
11
  export { getPayloadAuth } from "./lib/get-payload-auth";
10
12
  export { sanitizeBetterAuthOptions } from "./lib/sanitize-better-auth-options/index";
11
13
  export * from "./types";
14
+ function buildBetterAuthData({ payloadConfig, pluginOptions }) {
15
+ pluginOptions = setLoginMethods({
16
+ pluginOptions
17
+ });
18
+ const defaultBetterAuthSchemas = getDefaultBetterAuthSchema(pluginOptions);
19
+ let collectionMap = buildCollections({
20
+ resolvedSchemas: defaultBetterAuthSchemas,
21
+ incomingCollections: payloadConfig.collections ?? [],
22
+ pluginOptions
23
+ });
24
+ const resolvedBetterAuthSchemas = syncResolvedSchemaWithCollectionMap(defaultBetterAuthSchemas, collectionMap);
25
+ // We need to build the collections a second time with the resolved schemas
26
+ // due to hooks, endpoints, useAsTitle, etc should relay on resolvedBetterAuthSchemas to get slugs
27
+ // if they are referencing to other collections then it self.
28
+ collectionMap = buildCollections({
29
+ resolvedSchemas: resolvedBetterAuthSchemas,
30
+ incomingCollections: payloadConfig.collections ?? [],
31
+ pluginOptions
32
+ });
33
+ const sanitizedBetterAuthOptions = sanitizeBetterAuthOptions({
34
+ config: payloadConfig,
35
+ pluginOptions,
36
+ resolvedSchemas: resolvedBetterAuthSchemas
37
+ });
38
+ pluginOptions.betterAuthOptions = sanitizedBetterAuthOptions;
39
+ return {
40
+ pluginOptions,
41
+ collectionMap,
42
+ resolvedBetterAuthSchemas,
43
+ sanitizedBetterAuthOptions
44
+ };
45
+ }
12
46
  export function betterAuthPlugin(pluginOptions) {
13
47
  return (config)=>{
14
48
  if (pluginOptions.disabled) {
@@ -18,95 +52,18 @@ export function betterAuthPlugin(pluginOptions) {
18
52
  ...config.custom,
19
53
  hasBetterAuthPlugin: true
20
54
  };
21
- pluginOptions = setLoginMethods({
22
- pluginOptions
23
- });
24
- const collectionSchemaMap = buildCollectionSchemaMap(pluginOptions);
25
- const sanitizedBetterAuthOptions = sanitizeBetterAuthOptions({
26
- config,
27
- pluginOptions,
28
- collectionSchemaMap
29
- });
30
- pluginOptions.betterAuthOptions = sanitizedBetterAuthOptions;
31
- // Build the collection map
32
- const collectionMap = buildCollectionMap({
33
- collectionSchemaMap,
34
- incomingCollections: config.collections ?? [],
55
+ const { collectionMap, resolvedBetterAuthSchemas, sanitizedBetterAuthOptions } = buildBetterAuthData({
56
+ payloadConfig: config,
35
57
  pluginOptions
36
58
  });
37
- // Set custom admin components if disableDefaultPayloadAuth is true
59
+ // ---------------------- Finalize config -----------------
38
60
  if (pluginOptions.disableDefaultPayloadAuth) {
39
- config.admin = {
40
- ...config.admin,
41
- components: {
42
- ...config.admin?.components,
43
- afterLogin: [
44
- {
45
- path: 'payload-auth/better-auth/plugin/rsc#RSCRedirect',
46
- serverProps: {
47
- redirectTo: `${config.routes?.admin === undefined ? '/admin' : config.routes.admin}${adminRoutes.adminLogin}`
48
- }
49
- },
50
- ...config.admin?.components?.afterLogin || []
51
- ],
52
- logout: {
53
- Button: {
54
- path: 'payload-auth/better-auth/plugin/client#LogoutButton'
55
- }
56
- },
57
- views: {
58
- ...config.admin?.components?.views,
59
- adminLogin: {
60
- path: adminRoutes.adminLogin,
61
- Component: {
62
- path: 'payload-auth/better-auth/plugin/rsc#AdminLogin',
63
- serverProps: {
64
- pluginOptions: pluginOptions,
65
- adminInvitationsSlug: collectionMap[baseSlugs.adminInvitations].slug
66
- }
67
- }
68
- },
69
- adminSignup: {
70
- path: adminRoutes.adminSignup,
71
- Component: {
72
- path: 'payload-auth/better-auth/plugin/rsc#AdminSignup',
73
- serverProps: {
74
- pluginOptions: pluginOptions,
75
- adminInvitationsSlug: collectionMap[baseSlugs.adminInvitations].slug
76
- }
77
- }
78
- },
79
- forgotPassword: {
80
- path: adminRoutes.forgotPassword,
81
- Component: {
82
- path: 'payload-auth/better-auth/plugin/rsc#ForgotPassword'
83
- }
84
- },
85
- resetPassword: {
86
- path: adminRoutes.resetPassword,
87
- Component: {
88
- path: 'payload-auth/better-auth/plugin/rsc#ResetPassword'
89
- }
90
- },
91
- ...checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.twoFactor) && {
92
- twoFactorVerify: {
93
- path: adminRoutes.twoFactorVerify,
94
- Component: {
95
- path: 'payload-auth/better-auth/plugin/rsc#TwoFactorVerify',
96
- serverProps: {
97
- pluginOptions: pluginOptions,
98
- verificationsSlug: collectionSchemaMap[baModelKey.verification].collectionSlug
99
- }
100
- }
101
- }
102
- }
103
- }
104
- },
105
- routes: {
106
- ...config.admin?.routes,
107
- login: adminRoutes.loginRedirect
108
- }
109
- };
61
+ applyDisabledDefaultAuthConfig({
62
+ config,
63
+ pluginOptions,
64
+ collectionMap,
65
+ resolvedBetterAuthSchemas
66
+ });
110
67
  }
111
68
  config.collections = config.collections ?? [];
112
69
  config.collections = Object.values(collectionMap);
@@ -143,5 +100,24 @@ export function betterAuthPlugin(pluginOptions) {
143
100
  return config;
144
101
  };
145
102
  }
103
+ export function withPayloadAuth({ payloadConfig, betterAuthConfig: pluginOptions, adapterOptions }) {
104
+ if (pluginOptions.disabled) {
105
+ return pluginOptions.betterAuthOptions;
106
+ }
107
+ const { sanitizedBetterAuthOptions } = buildBetterAuthData({
108
+ payloadConfig,
109
+ pluginOptions: structuredClone(pluginOptions)
110
+ });
111
+ const optionsWithAdapter = {
112
+ ...sanitizedBetterAuthOptions,
113
+ database: payloadAdapter({
114
+ payloadClient: adapterOptions?.payloadClient ?? (async ()=>await getPayload({
115
+ config: payloadConfig
116
+ })),
117
+ idType: adapterOptions.idType
118
+ })
119
+ };
120
+ return optionsWithAdapter;
121
+ }
146
122
 
147
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/better-auth/plugin/index.ts"],"sourcesContent":["import { flattenAllFields, FlattenedField, type CollectionConfig, type Config, type Field } from 'payload'\nimport { adminRoutes, baModelFieldKeys, baModelKey, baModelKeyToSlug, baseSlugs, supportedBAPluginIds } from './constants'\nimport { checkPluginExists } from './helpers/check-plugin-exists'\nimport { getMappedCollection } from './helpers/get-collection'\nimport { buildCollectionMap } from './lib/build-collections/index'\nimport { initBetterAuth } from './lib/init-better-auth'\nimport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nimport { setLoginMethods } from './lib/set-login-methods'\nimport type { BetterAuthPluginOptions } from './types'\nimport { getDeafultCollectionSlug } from './helpers/get-collection-slug'\nimport { buildCollectionSchemaMap, getDefaultCollectionSchemaMap } from './helpers/get-collection-schema-map'\n\nexport * from './helpers/index'\nexport { getPayloadAuth } from './lib/get-payload-auth'\nexport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nexport * from './types'\n\nexport function betterAuthPlugin(pluginOptions: BetterAuthPluginOptions) {\n  return (config: Config): Config => {\n    if (pluginOptions.disabled) {\n      return config\n    }\n\n    config.custom = {\n      ...config.custom,\n      hasBetterAuthPlugin: true\n    }\n\n    pluginOptions = setLoginMethods({ pluginOptions })\n\n    const collectionSchemaMap = buildCollectionSchemaMap(pluginOptions)\n    const sanitizedBetterAuthOptions = sanitizeBetterAuthOptions({\n      config,\n      pluginOptions,\n      collectionSchemaMap\n    })\n\n    pluginOptions.betterAuthOptions = sanitizedBetterAuthOptions\n\n    // Build the collection map\n    const collectionMap = buildCollectionMap({\n      collectionSchemaMap,\n      incomingCollections: config.collections ?? [],\n      pluginOptions\n    })\n\n    // Set custom admin components if disableDefaultPayloadAuth is true\n    if (pluginOptions.disableDefaultPayloadAuth) {\n      config.admin = {\n        ...config.admin,\n        components: {\n          ...config.admin?.components,\n          afterLogin: [\n            {\n              path: 'payload-auth/better-auth/plugin/rsc#RSCRedirect',\n              serverProps: {\n                redirectTo: `${config.routes?.admin === undefined ? '/admin' : config.routes.admin}${adminRoutes.adminLogin}`\n              }\n            },\n            ...(config.admin?.components?.afterLogin || [])\n          ],\n          logout: {\n            Button: {\n              path: 'payload-auth/better-auth/plugin/client#LogoutButton'\n            }\n          },\n          views: {\n            ...config.admin?.components?.views,\n            adminLogin: {\n              path: adminRoutes.adminLogin,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#AdminLogin',\n                serverProps: {\n                  pluginOptions: pluginOptions,\n                  adminInvitationsSlug: collectionMap[baseSlugs.adminInvitations].slug\n                }\n              }\n            },\n            adminSignup: {\n              path: adminRoutes.adminSignup,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#AdminSignup',\n                serverProps: {\n                  pluginOptions: pluginOptions,\n                  adminInvitationsSlug: collectionMap[baseSlugs.adminInvitations].slug\n                }\n              }\n            },\n            forgotPassword: {\n              path: adminRoutes.forgotPassword,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#ForgotPassword'\n              }\n            },\n            resetPassword: {\n              path: adminRoutes.resetPassword,\n              Component: {\n                path: 'payload-auth/better-auth/plugin/rsc#ResetPassword'\n              }\n            },\n            ...(checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.twoFactor) && {\n              twoFactorVerify: {\n                path: adminRoutes.twoFactorVerify,\n                Component: {\n                  path: 'payload-auth/better-auth/plugin/rsc#TwoFactorVerify',\n                  serverProps: {\n                    pluginOptions: pluginOptions,\n                    verificationsSlug: collectionSchemaMap[baModelKey.verification].collectionSlug\n                  }\n                }\n              }\n            })\n          }\n        },\n        routes: {\n          ...config.admin?.routes,\n          login: adminRoutes.loginRedirect\n        }\n      }\n    }\n\n    config.collections = config.collections ?? []\n    config.collections = Object.values(collectionMap)\n\n    const incomingOnInit = config.onInit\n\n    config.onInit = async (payload) => {\n      try {\n        // Execute any existing onInit functions first\n        if (incomingOnInit) {\n          await incomingOnInit(payload)\n        }\n\n        // Initialize and set the betterAuth instance\n        const auth = initBetterAuth<NonNullable<typeof sanitizedBetterAuthOptions.plugins>>({\n          payload,\n          idType: payload.db.defaultIDType,\n          options: {\n            ...sanitizedBetterAuthOptions,\n            enableDebugLogs: pluginOptions.debug?.enableDebugLogs ?? false,\n            plugins: [...(sanitizedBetterAuthOptions.plugins ?? [])]\n          }\n        })\n\n        // Type-safe extension of payload with betterAuth\n        Object.defineProperty(payload, 'betterAuth', {\n          value: auth,\n          writable: false,\n          configurable: false\n        })\n      } catch (error) {\n        console.error('Failed to initialize BetterAuth:', error)\n        throw error\n      }\n    }\n    return config\n  }\n}\n"],"names":["adminRoutes","baModelKey","baseSlugs","supportedBAPluginIds","checkPluginExists","buildCollectionMap","initBetterAuth","sanitizeBetterAuthOptions","setLoginMethods","buildCollectionSchemaMap","getPayloadAuth","betterAuthPlugin","pluginOptions","config","disabled","custom","hasBetterAuthPlugin","collectionSchemaMap","sanitizedBetterAuthOptions","betterAuthOptions","collectionMap","incomingCollections","collections","disableDefaultPayloadAuth","admin","components","afterLogin","path","serverProps","redirectTo","routes","undefined","adminLogin","logout","Button","views","Component","adminInvitationsSlug","adminInvitations","slug","adminSignup","forgotPassword","resetPassword","twoFactor","twoFactorVerify","verificationsSlug","verification","collectionSlug","login","loginRedirect","Object","values","incomingOnInit","onInit","payload","auth","idType","db","defaultIDType","options","enableDebugLogs","debug","plugins","defineProperty","value","writable","configurable","error","console"],"mappings":"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"}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/better-auth/plugin/index.ts"],"sourcesContent":["import type { BetterAuthOptions } from 'better-auth/types'\nimport { getPayload, SanitizedConfig, type Config } from 'payload'\nimport { payloadAdapter } from 'payload-auth/better-auth/adapter'\nimport { PayloadAdapterParams } from '../types'\nimport { getDefaultBetterAuthSchema } from './helpers/get-better-auth-schema'\nimport { syncResolvedSchemaWithCollectionMap } from './helpers/sync-resolved-schema-with-collection-map'\nimport { applyDisabledDefaultAuthConfig } from './lib/apply-disabled-default-auth-config'\nimport { buildCollections } from './lib/build-collections/index'\nimport { initBetterAuth } from './lib/init-better-auth'\nimport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nimport { setLoginMethods } from './lib/set-login-methods'\nimport type { BetterAuthPluginOptions } from './types'\n\nexport * from './helpers/index'\nexport { getPayloadAuth } from './lib/get-payload-auth'\nexport { sanitizeBetterAuthOptions } from './lib/sanitize-better-auth-options/index'\nexport * from './types'\n\nfunction buildBetterAuthData({\n  payloadConfig,\n  pluginOptions\n}: {\n  payloadConfig: SanitizedConfig\n  pluginOptions: BetterAuthPluginOptions\n}) {\n  pluginOptions = setLoginMethods({ pluginOptions })\n\n  const defaultBetterAuthSchemas = getDefaultBetterAuthSchema(pluginOptions)\n\n  let collectionMap = buildCollections({\n    resolvedSchemas: defaultBetterAuthSchemas,\n    incomingCollections: payloadConfig.collections ?? [],\n    pluginOptions\n  })\n\n  const resolvedBetterAuthSchemas = syncResolvedSchemaWithCollectionMap(defaultBetterAuthSchemas, collectionMap)\n\n  // We need to build the collections a second time with the resolved schemas\n  // due to hooks, endpoints, useAsTitle, etc should relay on resolvedBetterAuthSchemas to get slugs\n  // if they are referencing to other collections then it self.\n  collectionMap = buildCollections({\n    resolvedSchemas: resolvedBetterAuthSchemas,\n    incomingCollections: payloadConfig.collections ?? [],\n    pluginOptions\n  })\n\n  const sanitizedBetterAuthOptions = sanitizeBetterAuthOptions({\n    config: payloadConfig,\n    pluginOptions,\n    resolvedSchemas: resolvedBetterAuthSchemas\n  })\n\n  pluginOptions.betterAuthOptions = sanitizedBetterAuthOptions\n\n  return {\n    pluginOptions,\n    collectionMap,\n    resolvedBetterAuthSchemas,\n    sanitizedBetterAuthOptions\n  }\n}\n\nexport function betterAuthPlugin(pluginOptions: BetterAuthPluginOptions) {\n  return (config: Config): Config => {\n    if (pluginOptions.disabled) {\n      return config\n    }\n\n    config.custom = {\n      ...config.custom,\n      hasBetterAuthPlugin: true\n    }\n\n    const { collectionMap, resolvedBetterAuthSchemas, sanitizedBetterAuthOptions } = buildBetterAuthData({\n      payloadConfig: config as SanitizedConfig,\n      pluginOptions\n    })\n\n    // ---------------------- Finalize config -----------------\n    if (pluginOptions.disableDefaultPayloadAuth) {\n      applyDisabledDefaultAuthConfig({\n        config,\n        pluginOptions,\n        collectionMap,\n        resolvedBetterAuthSchemas\n      })\n    }\n\n    config.collections = config.collections ?? []\n    config.collections = Object.values(collectionMap)\n\n    const incomingOnInit = config.onInit\n\n    config.onInit = async (payload) => {\n      try {\n        // Execute any existing onInit functions first\n        if (incomingOnInit) {\n          await incomingOnInit(payload)\n        }\n\n        // Initialize and set the betterAuth instance\n        const auth = initBetterAuth<NonNullable<typeof sanitizedBetterAuthOptions.plugins>>({\n          payload,\n          idType: payload.db.defaultIDType,\n          options: {\n            ...sanitizedBetterAuthOptions,\n            enableDebugLogs: pluginOptions.debug?.enableDebugLogs ?? false,\n            plugins: [...(sanitizedBetterAuthOptions.plugins ?? [])]\n          }\n        })\n\n        // Type-safe extension of payload with betterAuth\n        Object.defineProperty(payload, 'betterAuth', {\n          value: auth,\n          writable: false,\n          configurable: false\n        })\n      } catch (error) {\n        console.error('Failed to initialize BetterAuth:', error)\n        throw error\n      }\n    }\n    return config\n  }\n}\n\nexport function withPayloadAuth({\n  payloadConfig,\n  betterAuthConfig: pluginOptions,\n  adapterOptions\n}: {\n  payloadConfig: SanitizedConfig\n  betterAuthConfig: BetterAuthPluginOptions\n  adapterOptions: Pick<PayloadAdapterParams, 'idType'> & Partial<Pick<PayloadAdapterParams, 'payloadClient'>>\n}): BetterAuthOptions {\n\n  if (pluginOptions.disabled) {\n    return pluginOptions.betterAuthOptions as BetterAuthOptions\n  }\n\n  const { sanitizedBetterAuthOptions } = buildBetterAuthData({\n    payloadConfig,\n    pluginOptions: structuredClone(pluginOptions)\n  })\n\n  const optionsWithAdapter: BetterAuthOptions = {\n    ...sanitizedBetterAuthOptions,\n    database: payloadAdapter({\n      payloadClient: adapterOptions?.payloadClient ?? (async () => await getPayload({ config: payloadConfig })),\n      idType: adapterOptions.idType\n    })\n  }\n\n  return optionsWithAdapter\n}\n"],"names":["getPayload","payloadAdapter","getDefaultBetterAuthSchema","syncResolvedSchemaWithCollectionMap","applyDisabledDefaultAuthConfig","buildCollections","initBetterAuth","sanitizeBetterAuthOptions","setLoginMethods","getPayloadAuth","buildBetterAuthData","payloadConfig","pluginOptions","defaultBetterAuthSchemas","collectionMap","resolvedSchemas","incomingCollections","collections","resolvedBetterAuthSchemas","sanitizedBetterAuthOptions","config","betterAuthOptions","betterAuthPlugin","disabled","custom","hasBetterAuthPlugin","disableDefaultPayloadAuth","Object","values","incomingOnInit","onInit","payload","auth","idType","db","defaultIDType","options","enableDebugLogs","debug","plugins","defineProperty","value","writable","configurable","error","console","withPayloadAuth","betterAuthConfig","adapterOptions","structuredClone","optionsWithAdapter","database","payloadClient"],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type { BetterAuthPluginOptions, BetterAuthSchemas } from '../types';
2
+ import type { Config, CollectionConfig } from 'payload';
3
+ /**
4
+ * Applies all admin-related overrides when `disableDefaultPayloadAuth` is `true`.
5
+ * Mutates the provided Payload config in-place.
6
+ */
7
+ export declare function applyDisabledDefaultAuthConfig({ config, pluginOptions, collectionMap, resolvedBetterAuthSchemas }: {
8
+ config: Config;
9
+ pluginOptions: BetterAuthPluginOptions;
10
+ collectionMap: Record<string, CollectionConfig>;
11
+ resolvedBetterAuthSchemas: BetterAuthSchemas;
12
+ }): void;
13
+ //# sourceMappingURL=apply-disabled-default-auth-config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apply-disabled-default-auth-config.d.ts","sourceRoot":"","sources":["../../../../src/better-auth/plugin/lib/apply-disabled-default-auth-config.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAA;AAC1E,OAAO,KAAK,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAEvD;;;GAGG;AACH,wBAAgB,8BAA8B,CAAC,EAC7C,MAAM,EACN,aAAa,EACb,aAAa,EACb,yBAAyB,EAC1B,EAAE;IACD,MAAM,EAAE,MAAM,CAAA;IACd,aAAa,EAAE,uBAAuB,CAAA;IACtC,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAA;IAC/C,yBAAyB,EAAE,iBAAiB,CAAA;CAC7C,GAAG,IAAI,CAwEP"}
@@ -0,0 +1,80 @@
1
+ import { adminRoutes, baModelKey, baseSlugs, supportedBAPluginIds } from "../constants";
2
+ import { checkPluginExists } from "../helpers/check-plugin-exists";
3
+ /**
4
+ * Applies all admin-related overrides when `disableDefaultPayloadAuth` is `true`.
5
+ * Mutates the provided Payload config in-place.
6
+ */ export function applyDisabledDefaultAuthConfig({ config, pluginOptions, collectionMap, resolvedBetterAuthSchemas }) {
7
+ config.admin = {
8
+ ...config.admin,
9
+ components: {
10
+ ...config.admin?.components,
11
+ afterLogin: [
12
+ {
13
+ path: 'payload-auth/better-auth/plugin/rsc#RSCRedirect',
14
+ serverProps: {
15
+ redirectTo: `${config.routes?.admin === undefined ? '/admin' : config.routes.admin}${adminRoutes.adminLogin}`
16
+ }
17
+ },
18
+ ...config.admin?.components?.afterLogin || []
19
+ ],
20
+ logout: {
21
+ Button: {
22
+ path: 'payload-auth/better-auth/plugin/client#LogoutButton'
23
+ }
24
+ },
25
+ views: {
26
+ ...config.admin?.components?.views,
27
+ adminLogin: {
28
+ path: adminRoutes.adminLogin,
29
+ Component: {
30
+ path: 'payload-auth/better-auth/plugin/rsc#AdminLogin',
31
+ serverProps: {
32
+ pluginOptions: pluginOptions,
33
+ adminInvitationsSlug: collectionMap[baseSlugs.adminInvitations].slug
34
+ }
35
+ }
36
+ },
37
+ adminSignup: {
38
+ path: adminRoutes.adminSignup,
39
+ Component: {
40
+ path: 'payload-auth/better-auth/plugin/rsc#AdminSignup',
41
+ serverProps: {
42
+ pluginOptions: pluginOptions,
43
+ adminInvitationsSlug: collectionMap[baseSlugs.adminInvitations].slug
44
+ }
45
+ }
46
+ },
47
+ forgotPassword: {
48
+ path: adminRoutes.forgotPassword,
49
+ Component: {
50
+ path: 'payload-auth/better-auth/plugin/rsc#ForgotPassword'
51
+ }
52
+ },
53
+ resetPassword: {
54
+ path: adminRoutes.resetPassword,
55
+ Component: {
56
+ path: 'payload-auth/better-auth/plugin/rsc#ResetPassword'
57
+ }
58
+ },
59
+ ...checkPluginExists(pluginOptions.betterAuthOptions ?? {}, supportedBAPluginIds.twoFactor) && {
60
+ twoFactorVerify: {
61
+ path: adminRoutes.twoFactorVerify,
62
+ Component: {
63
+ path: 'payload-auth/better-auth/plugin/rsc#TwoFactorVerify',
64
+ serverProps: {
65
+ pluginOptions: pluginOptions,
66
+ verificationsSlug: resolvedBetterAuthSchemas[baModelKey.verification].modelName
67
+ }
68
+ }
69
+ }
70
+ }
71
+ }
72
+ },
73
+ routes: {
74
+ ...config.admin?.routes,
75
+ login: adminRoutes.loginRedirect
76
+ }
77
+ };
78
+ }
79
+
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vbGliL2FwcGx5LWRpc2FibGVkLWRlZmF1bHQtYXV0aC1jb25maWcudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYWRtaW5Sb3V0ZXMsIGJhTW9kZWxLZXksIGJhc2VTbHVncywgc3VwcG9ydGVkQkFQbHVnaW5JZHMgfSBmcm9tICcuLi9jb25zdGFudHMnXG5pbXBvcnQgeyBjaGVja1BsdWdpbkV4aXN0cyB9IGZyb20gJy4uL2hlbHBlcnMvY2hlY2stcGx1Z2luLWV4aXN0cydcbmltcG9ydCB0eXBlIHsgQmV0dGVyQXV0aFBsdWdpbk9wdGlvbnMsIEJldHRlckF1dGhTY2hlbWFzIH0gZnJvbSAnLi4vdHlwZXMnXG5pbXBvcnQgdHlwZSB7IENvbmZpZywgQ29sbGVjdGlvbkNvbmZpZyB9IGZyb20gJ3BheWxvYWQnXG5cbi8qKlxuICogQXBwbGllcyBhbGwgYWRtaW4tcmVsYXRlZCBvdmVycmlkZXMgd2hlbiBgZGlzYWJsZURlZmF1bHRQYXlsb2FkQXV0aGAgaXMgYHRydWVgLlxuICogTXV0YXRlcyB0aGUgcHJvdmlkZWQgUGF5bG9hZCBjb25maWcgaW4tcGxhY2UuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBhcHBseURpc2FibGVkRGVmYXVsdEF1dGhDb25maWcoe1xuICBjb25maWcsXG4gIHBsdWdpbk9wdGlvbnMsXG4gIGNvbGxlY3Rpb25NYXAsXG4gIHJlc29sdmVkQmV0dGVyQXV0aFNjaGVtYXNcbn06IHtcbiAgY29uZmlnOiBDb25maWdcbiAgcGx1Z2luT3B0aW9uczogQmV0dGVyQXV0aFBsdWdpbk9wdGlvbnNcbiAgY29sbGVjdGlvbk1hcDogUmVjb3JkPHN0cmluZywgQ29sbGVjdGlvbkNvbmZpZz5cbiAgcmVzb2x2ZWRCZXR0ZXJBdXRoU2NoZW1hczogQmV0dGVyQXV0aFNjaGVtYXNcbn0pOiB2b2lkIHtcbiAgY29uZmlnLmFkbWluID0ge1xuICAgIC4uLmNvbmZpZy5hZG1pbixcbiAgICBjb21wb25lbnRzOiB7XG4gICAgICAuLi5jb25maWcuYWRtaW4/LmNvbXBvbmVudHMsXG4gICAgICBhZnRlckxvZ2luOiBbXG4gICAgICAgIHtcbiAgICAgICAgICBwYXRoOiAncGF5bG9hZC1hdXRoL2JldHRlci1hdXRoL3BsdWdpbi9yc2MjUlNDUmVkaXJlY3QnLFxuICAgICAgICAgIHNlcnZlclByb3BzOiB7XG4gICAgICAgICAgICByZWRpcmVjdFRvOiBgJHtjb25maWcucm91dGVzPy5hZG1pbiA9PT0gdW5kZWZpbmVkID8gJy9hZG1pbicgOiBjb25maWcucm91dGVzLmFkbWlufSR7YWRtaW5Sb3V0ZXMuYWRtaW5Mb2dpbn1gXG4gICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICAuLi4oY29uZmlnLmFkbWluPy5jb21wb25lbnRzPy5hZnRlckxvZ2luIHx8IFtdKVxuICAgICAgXSxcbiAgICAgIGxvZ291dDoge1xuICAgICAgICBCdXR0b246IHtcbiAgICAgICAgICBwYXRoOiAncGF5bG9hZC1hdXRoL2JldHRlci1hdXRoL3BsdWdpbi9jbGllbnQjTG9nb3V0QnV0dG9uJ1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAgdmlld3M6IHtcbiAgICAgICAgLi4uY29uZmlnLmFkbWluPy5jb21wb25lbnRzPy52aWV3cyxcbiAgICAgICAgYWRtaW5Mb2dpbjoge1xuICAgICAgICAgIHBhdGg6IGFkbWluUm91dGVzLmFkbWluTG9naW4sXG4gICAgICAgICAgQ29tcG9uZW50OiB7XG4gICAgICAgICAgICBwYXRoOiAncGF5bG9hZC1hdXRoL2JldHRlci1hdXRoL3BsdWdpbi9yc2MjQWRtaW5Mb2dpbicsXG4gICAgICAgICAgICBzZXJ2ZXJQcm9wczoge1xuICAgICAgICAgICAgICBwbHVnaW5PcHRpb25zOiBwbHVnaW5PcHRpb25zLFxuICAgICAgICAgICAgICBhZG1pbkludml0YXRpb25zU2x1ZzogY29sbGVjdGlvbk1hcFtiYXNlU2x1Z3MuYWRtaW5JbnZpdGF0aW9uc10uc2x1Z1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgYWRtaW5TaWdudXA6IHtcbiAgICAgICAgICBwYXRoOiBhZG1pblJvdXRlcy5hZG1pblNpZ251cCxcbiAgICAgICAgICBDb21wb25lbnQ6IHtcbiAgICAgICAgICAgIHBhdGg6ICdwYXlsb2FkLWF1dGgvYmV0dGVyLWF1dGgvcGx1Z2luL3JzYyNBZG1pblNpZ251cCcsXG4gICAgICAgICAgICBzZXJ2ZXJQcm9wczoge1xuICAgICAgICAgICAgICBwbHVnaW5PcHRpb25zOiBwbHVnaW5PcHRpb25zLFxuICAgICAgICAgICAgICBhZG1pbkludml0YXRpb25zU2x1ZzogY29sbGVjdGlvbk1hcFtiYXNlU2x1Z3MuYWRtaW5JbnZpdGF0aW9uc10uc2x1Z1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgZm9yZ290UGFzc3dvcmQ6IHtcbiAgICAgICAgICBwYXRoOiBhZG1pblJvdXRlcy5mb3Jnb3RQYXNzd29yZCxcbiAgICAgICAgICBDb21wb25lbnQ6IHtcbiAgICAgICAgICAgIHBhdGg6ICdwYXlsb2FkLWF1dGgvYmV0dGVyLWF1dGgvcGx1Z2luL3JzYyNGb3Jnb3RQYXNzd29yZCdcbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIHJlc2V0UGFzc3dvcmQ6IHtcbiAgICAgICAgICBwYXRoOiBhZG1pblJvdXRlcy5yZXNldFBhc3N3b3JkLFxuICAgICAgICAgIENvbXBvbmVudDoge1xuICAgICAgICAgICAgcGF0aDogJ3BheWxvYWQtYXV0aC9iZXR0ZXItYXV0aC9wbHVnaW4vcnNjI1Jlc2V0UGFzc3dvcmQnXG4gICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICAuLi4oY2hlY2tQbHVnaW5FeGlzdHMocGx1Z2luT3B0aW9ucy5iZXR0ZXJBdXRoT3B0aW9ucyA/PyB7fSwgc3VwcG9ydGVkQkFQbHVnaW5JZHMudHdvRmFjdG9yKSAmJiB7XG4gICAgICAgICAgdHdvRmFjdG9yVmVyaWZ5OiB7XG4gICAgICAgICAgICBwYXRoOiBhZG1pblJvdXRlcy50d29GYWN0b3JWZXJpZnksXG4gICAgICAgICAgICBDb21wb25lbnQ6IHtcbiAgICAgICAgICAgICAgcGF0aDogJ3BheWxvYWQtYXV0aC9iZXR0ZXItYXV0aC9wbHVnaW4vcnNjI1R3b0ZhY3RvclZlcmlmeScsXG4gICAgICAgICAgICAgIHNlcnZlclByb3BzOiB7XG4gICAgICAgICAgICAgICAgcGx1Z2luT3B0aW9uczogcGx1Z2luT3B0aW9ucyxcbiAgICAgICAgICAgICAgICB2ZXJpZmljYXRpb25zU2x1ZzogcmVzb2x2ZWRCZXR0ZXJBdXRoU2NoZW1hc1tiYU1vZGVsS2V5LnZlcmlmaWNhdGlvbl0ubW9kZWxOYW1lXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgICB9XG4gICAgfSxcbiAgICByb3V0ZXM6IHtcbiAgICAgIC4uLmNvbmZpZy5hZG1pbj8ucm91dGVzLFxuICAgICAgbG9naW46IGFkbWluUm91dGVzLmxvZ2luUmVkaXJlY3RcbiAgICB9XG4gIH1cbn0gIl0sIm5hbWVzIjpbImFkbWluUm91dGVzIiwiYmFNb2RlbEtleSIsImJhc2VTbHVncyIsInN1cHBvcnRlZEJBUGx1Z2luSWRzIiwiY2hlY2tQbHVnaW5FeGlzdHMiLCJhcHBseURpc2FibGVkRGVmYXVsdEF1dGhDb25maWciLCJjb25maWciLCJwbHVnaW5PcHRpb25zIiwiY29sbGVjdGlvbk1hcCIsInJlc29sdmVkQmV0dGVyQXV0aFNjaGVtYXMiLCJhZG1pbiIsImNvbXBvbmVudHMiLCJhZnRlckxvZ2luIiwicGF0aCIsInNlcnZlclByb3BzIiwicmVkaXJlY3RUbyIsInJvdXRlcyIsInVuZGVmaW5lZCIsImFkbWluTG9naW4iLCJsb2dvdXQiLCJCdXR0b24iLCJ2aWV3cyIsIkNvbXBvbmVudCIsImFkbWluSW52aXRhdGlvbnNTbHVnIiwiYWRtaW5JbnZpdGF0aW9ucyIsInNsdWciLCJhZG1pblNpZ251cCIsImZvcmdvdFBhc3N3b3JkIiwicmVzZXRQYXNzd29yZCIsImJldHRlckF1dGhPcHRpb25zIiwidHdvRmFjdG9yIiwidHdvRmFjdG9yVmVyaWZ5IiwidmVyaWZpY2F0aW9uc1NsdWciLCJ2ZXJpZmljYXRpb24iLCJtb2RlbE5hbWUiLCJsb2dpbiIsImxvZ2luUmVkaXJlY3QiXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFdBQVcsRUFBRUMsVUFBVSxFQUFFQyxTQUFTLEVBQUVDLG9CQUFvQixRQUFRLGVBQWM7QUFDdkYsU0FBU0MsaUJBQWlCLFFBQVEsaUNBQWdDO0FBSWxFOzs7Q0FHQyxHQUNELE9BQU8sU0FBU0MsK0JBQStCLEVBQzdDQyxNQUFNLEVBQ05DLGFBQWEsRUFDYkMsYUFBYSxFQUNiQyx5QkFBeUIsRUFNMUI7SUFDQ0gsT0FBT0ksS0FBSyxHQUFHO1FBQ2IsR0FBR0osT0FBT0ksS0FBSztRQUNmQyxZQUFZO1lBQ1YsR0FBR0wsT0FBT0ksS0FBSyxFQUFFQyxVQUFVO1lBQzNCQyxZQUFZO2dCQUNWO29CQUNFQyxNQUFNO29CQUNOQyxhQUFhO3dCQUNYQyxZQUFZLEdBQUdULE9BQU9VLE1BQU0sRUFBRU4sVUFBVU8sWUFBWSxXQUFXWCxPQUFPVSxNQUFNLENBQUNOLEtBQUssR0FBR1YsWUFBWWtCLFVBQVUsRUFBRTtvQkFDL0c7Z0JBQ0Y7bUJBQ0laLE9BQU9JLEtBQUssRUFBRUMsWUFBWUMsY0FBYyxFQUFFO2FBQy9DO1lBQ0RPLFFBQVE7Z0JBQ05DLFFBQVE7b0JBQ05QLE1BQU07Z0JBQ1I7WUFDRjtZQUNBUSxPQUFPO2dCQUNMLEdBQUdmLE9BQU9JLEtBQUssRUFBRUMsWUFBWVUsS0FBSztnQkFDbENILFlBQVk7b0JBQ1ZMLE1BQU1iLFlBQVlrQixVQUFVO29CQUM1QkksV0FBVzt3QkFDVFQsTUFBTTt3QkFDTkMsYUFBYTs0QkFDWFAsZUFBZUE7NEJBQ2ZnQixzQkFBc0JmLGFBQWEsQ0FBQ04sVUFBVXNCLGdCQUFnQixDQUFDLENBQUNDLElBQUk7d0JBQ3RFO29CQUNGO2dCQUNGO2dCQUNBQyxhQUFhO29CQUNYYixNQUFNYixZQUFZMEIsV0FBVztvQkFDN0JKLFdBQVc7d0JBQ1RULE1BQU07d0JBQ05DLGFBQWE7NEJBQ1hQLGVBQWVBOzRCQUNmZ0Isc0JBQXNCZixhQUFhLENBQUNOLFVBQVVzQixnQkFBZ0IsQ0FBQyxDQUFDQyxJQUFJO3dCQUN0RTtvQkFDRjtnQkFDRjtnQkFDQUUsZ0JBQWdCO29CQUNkZCxNQUFNYixZQUFZMkIsY0FBYztvQkFDaENMLFdBQVc7d0JBQ1RULE1BQU07b0JBQ1I7Z0JBQ0Y7Z0JBQ0FlLGVBQWU7b0JBQ2JmLE1BQU1iLFlBQVk0QixhQUFhO29CQUMvQk4sV0FBVzt3QkFDVFQsTUFBTTtvQkFDUjtnQkFDRjtnQkFDQSxHQUFJVCxrQkFBa0JHLGNBQWNzQixpQkFBaUIsSUFBSSxDQUFDLEdBQUcxQixxQkFBcUIyQixTQUFTLEtBQUs7b0JBQzlGQyxpQkFBaUI7d0JBQ2ZsQixNQUFNYixZQUFZK0IsZUFBZTt3QkFDakNULFdBQVc7NEJBQ1RULE1BQU07NEJBQ05DLGFBQWE7Z0NBQ1hQLGVBQWVBO2dDQUNmeUIsbUJBQW1CdkIseUJBQXlCLENBQUNSLFdBQVdnQyxZQUFZLENBQUMsQ0FBQ0MsU0FBUzs0QkFDakY7d0JBQ0Y7b0JBQ0Y7Z0JBQ0YsQ0FBQztZQUNIO1FBQ0Y7UUFDQWxCLFFBQVE7WUFDTixHQUFHVixPQUFPSSxLQUFLLEVBQUVNLE1BQU07WUFDdkJtQixPQUFPbkMsWUFBWW9DLGFBQWE7UUFDbEM7SUFDRjtBQUNGIn0=