@luochuanyuewu/payload-auth 1.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (424) hide show
  1. package/dist/better-auth/adapter/generate-schema/generate-schema-builder.d.ts +24 -0
  2. package/dist/better-auth/adapter/generate-schema/generate-schema-builder.d.ts.map +1 -0
  3. package/dist/better-auth/adapter/generate-schema/generate-schema-builder.js +317 -0
  4. package/dist/better-auth/adapter/generate-schema/get-payload-schema.d.ts +2 -0
  5. package/dist/better-auth/adapter/generate-schema/get-payload-schema.d.ts.map +1 -0
  6. package/dist/better-auth/adapter/generate-schema/get-payload-schema.js +23 -0
  7. package/dist/better-auth/adapter/generate-schema/index.d.ts +5 -0
  8. package/dist/better-auth/adapter/generate-schema/index.d.ts.map +1 -0
  9. package/dist/better-auth/adapter/generate-schema/index.js +19 -0
  10. package/dist/better-auth/adapter/generate-schema/utils.d.ts +3 -0
  11. package/dist/better-auth/adapter/generate-schema/utils.d.ts.map +1 -0
  12. package/dist/better-auth/adapter/generate-schema/utils.js +20 -0
  13. package/dist/better-auth/adapter/index.d.ts +16 -0
  14. package/dist/better-auth/adapter/index.d.ts.map +1 -0
  15. package/dist/better-auth/adapter/index.js +717 -0
  16. package/dist/better-auth/adapter/transform/index.d.ts +31 -0
  17. package/dist/better-auth/adapter/transform/index.d.ts.map +1 -0
  18. package/dist/better-auth/adapter/transform/index.js +729 -0
  19. package/dist/better-auth/adapter/types.d.ts +11 -0
  20. package/dist/better-auth/adapter/types.d.ts.map +1 -0
  21. package/dist/better-auth/adapter/types.js +3 -0
  22. package/dist/better-auth/generated-types.d.ts +329 -0
  23. package/dist/better-auth/generated-types.d.ts.map +1 -0
  24. package/dist/better-auth/generated-types.js +4 -0
  25. package/dist/better-auth/index.d.ts +4 -0
  26. package/dist/better-auth/index.d.ts.map +1 -0
  27. package/dist/better-auth/index.js +5 -0
  28. package/dist/better-auth/plugin/constants.d.ts +231 -0
  29. package/dist/better-auth/plugin/constants.d.ts.map +1 -0
  30. package/dist/better-auth/plugin/constants.js +259 -0
  31. package/dist/better-auth/plugin/helpers/check-plugin-exists.d.ts +13 -0
  32. package/dist/better-auth/plugin/helpers/check-plugin-exists.d.ts.map +1 -0
  33. package/dist/better-auth/plugin/helpers/check-plugin-exists.js +14 -0
  34. package/dist/better-auth/plugin/helpers/generate-verify-email-url.d.ts +30 -0
  35. package/dist/better-auth/plugin/helpers/generate-verify-email-url.d.ts.map +1 -0
  36. package/dist/better-auth/plugin/helpers/generate-verify-email-url.js +46 -0
  37. package/dist/better-auth/plugin/helpers/get-admin-access.d.ts +8 -0
  38. package/dist/better-auth/plugin/helpers/get-admin-access.d.ts.map +1 -0
  39. package/dist/better-auth/plugin/helpers/get-admin-access.js +22 -0
  40. package/dist/better-auth/plugin/helpers/get-all-roles.d.ts +6 -0
  41. package/dist/better-auth/plugin/helpers/get-all-roles.d.ts.map +1 -0
  42. package/dist/better-auth/plugin/helpers/get-all-roles.js +20 -0
  43. package/dist/better-auth/plugin/helpers/get-better-auth-schema.d.ts +19 -0
  44. package/dist/better-auth/plugin/helpers/get-better-auth-schema.d.ts.map +1 -0
  45. package/dist/better-auth/plugin/helpers/get-better-auth-schema.js +75 -0
  46. package/dist/better-auth/plugin/helpers/get-collection-slug.d.ts +6 -0
  47. package/dist/better-auth/plugin/helpers/get-collection-slug.d.ts.map +1 -0
  48. package/dist/better-auth/plugin/helpers/get-collection-slug.js +20 -0
  49. package/dist/better-auth/plugin/helpers/get-collection.d.ts +28 -0
  50. package/dist/better-auth/plugin/helpers/get-collection.d.ts.map +1 -0
  51. package/dist/better-auth/plugin/helpers/get-collection.js +49 -0
  52. package/dist/better-auth/plugin/helpers/get-ip.d.ts +3 -0
  53. package/dist/better-auth/plugin/helpers/get-ip.d.ts.map +1 -0
  54. package/dist/better-auth/plugin/helpers/get-ip.js +31 -0
  55. package/dist/better-auth/plugin/helpers/get-signed-cookie.d.ts +3 -0
  56. package/dist/better-auth/plugin/helpers/get-signed-cookie.d.ts.map +1 -0
  57. package/dist/better-auth/plugin/helpers/get-signed-cookie.js +63 -0
  58. package/dist/better-auth/plugin/helpers/index.d.ts +2 -0
  59. package/dist/better-auth/plugin/helpers/index.d.ts.map +1 -0
  60. package/dist/better-auth/plugin/helpers/index.js +3 -0
  61. package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts +60 -0
  62. package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts.map +1 -0
  63. package/dist/better-auth/plugin/helpers/prepare-session-data.js +49 -0
  64. package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.d.ts +21 -0
  65. package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.d.ts.map +1 -0
  66. package/dist/better-auth/plugin/helpers/sync-resolved-schema-with-collection-map.js +63 -0
  67. package/dist/better-auth/plugin/index.d.ts +8 -0
  68. package/dist/better-auth/plugin/index.d.ts.map +1 -0
  69. package/dist/better-auth/plugin/index.js +103 -0
  70. package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.d.ts +13 -0
  71. package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.d.ts.map +1 -0
  72. package/dist/better-auth/plugin/lib/apply-disabled-default-auth-config.js +87 -0
  73. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.d.ts +4 -0
  74. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.d.ts.map +1 -0
  75. package/dist/better-auth/plugin/lib/build-collections/accounts/hooks/sync-password-to-user.js +51 -0
  76. package/dist/better-auth/plugin/lib/build-collections/accounts/index.d.ts +4 -0
  77. package/dist/better-auth/plugin/lib/build-collections/accounts/index.d.ts.map +1 -0
  78. package/dist/better-auth/plugin/lib/build-collections/accounts/index.js +150 -0
  79. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-after-read.d.ts +6 -0
  80. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-after-read.d.ts.map +1 -0
  81. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-after-read.js +11 -0
  82. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-before-change.d.ts +3 -0
  83. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-before-change.d.ts.map +1 -0
  84. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/hooks/get-url-before-change.js +8 -0
  85. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.d.ts +7 -0
  86. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.d.ts.map +1 -0
  87. package/dist/better-auth/plugin/lib/build-collections/admin-invitations/index.js +117 -0
  88. package/dist/better-auth/plugin/lib/build-collections/api-keys.d.ts +4 -0
  89. package/dist/better-auth/plugin/lib/build-collections/api-keys.d.ts.map +1 -0
  90. package/dist/better-auth/plugin/lib/build-collections/api-keys.js +174 -0
  91. package/dist/better-auth/plugin/lib/build-collections/device-code.d.ts +4 -0
  92. package/dist/better-auth/plugin/lib/build-collections/device-code.d.ts.map +1 -0
  93. package/dist/better-auth/plugin/lib/build-collections/device-code.js +49 -0
  94. package/dist/better-auth/plugin/lib/build-collections/index.d.ts +11 -0
  95. package/dist/better-auth/plugin/lib/build-collections/index.d.ts.map +1 -0
  96. package/dist/better-auth/plugin/lib/build-collections/index.js +79 -0
  97. package/dist/better-auth/plugin/lib/build-collections/invitations.d.ts +4 -0
  98. package/dist/better-auth/plugin/lib/build-collections/invitations.d.ts.map +1 -0
  99. package/dist/better-auth/plugin/lib/build-collections/invitations.js +93 -0
  100. package/dist/better-auth/plugin/lib/build-collections/jwks.d.ts +4 -0
  101. package/dist/better-auth/plugin/lib/build-collections/jwks.d.ts.map +1 -0
  102. package/dist/better-auth/plugin/lib/build-collections/jwks.js +58 -0
  103. package/dist/better-auth/plugin/lib/build-collections/members.d.ts +4 -0
  104. package/dist/better-auth/plugin/lib/build-collections/members.d.ts.map +1 -0
  105. package/dist/better-auth/plugin/lib/build-collections/members.js +72 -0
  106. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.d.ts +4 -0
  107. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.d.ts.map +1 -0
  108. package/dist/better-auth/plugin/lib/build-collections/oauth-access-tokens.js +105 -0
  109. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.d.ts +4 -0
  110. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.d.ts.map +1 -0
  111. package/dist/better-auth/plugin/lib/build-collections/oauth-applications.js +117 -0
  112. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.d.ts +4 -0
  113. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.d.ts.map +1 -0
  114. package/dist/better-auth/plugin/lib/build-collections/oauth-consents.js +87 -0
  115. package/dist/better-auth/plugin/lib/build-collections/organization-roles.d.ts +4 -0
  116. package/dist/better-auth/plugin/lib/build-collections/organization-roles.d.ts.map +1 -0
  117. package/dist/better-auth/plugin/lib/build-collections/organization-roles.js +65 -0
  118. package/dist/better-auth/plugin/lib/build-collections/organizations.d.ts +4 -0
  119. package/dist/better-auth/plugin/lib/build-collections/organizations.d.ts.map +1 -0
  120. package/dist/better-auth/plugin/lib/build-collections/organizations.js +106 -0
  121. package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts +4 -0
  122. package/dist/better-auth/plugin/lib/build-collections/passkeys.d.ts.map +1 -0
  123. package/dist/better-auth/plugin/lib/build-collections/passkeys.js +115 -0
  124. package/dist/better-auth/plugin/lib/build-collections/rate-limit.d.ts +4 -0
  125. package/dist/better-auth/plugin/lib/build-collections/rate-limit.d.ts.map +1 -0
  126. package/dist/better-auth/plugin/lib/build-collections/rate-limit.js +54 -0
  127. package/dist/better-auth/plugin/lib/build-collections/scim-provider.d.ts +4 -0
  128. package/dist/better-auth/plugin/lib/build-collections/scim-provider.d.ts.map +1 -0
  129. package/dist/better-auth/plugin/lib/build-collections/scim-provider.js +65 -0
  130. package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts +4 -0
  131. package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts.map +1 -0
  132. package/dist/better-auth/plugin/lib/build-collections/sessions.js +140 -0
  133. package/dist/better-auth/plugin/lib/build-collections/sso-providers.d.ts +4 -0
  134. package/dist/better-auth/plugin/lib/build-collections/sso-providers.d.ts.map +1 -0
  135. package/dist/better-auth/plugin/lib/build-collections/sso-providers.js +80 -0
  136. package/dist/better-auth/plugin/lib/build-collections/subscriptions.d.ts +4 -0
  137. package/dist/better-auth/plugin/lib/build-collections/subscriptions.d.ts.map +1 -0
  138. package/dist/better-auth/plugin/lib/build-collections/subscriptions.js +110 -0
  139. package/dist/better-auth/plugin/lib/build-collections/team-members.d.ts +4 -0
  140. package/dist/better-auth/plugin/lib/build-collections/team-members.d.ts.map +1 -0
  141. package/dist/better-auth/plugin/lib/build-collections/team-members.js +63 -0
  142. package/dist/better-auth/plugin/lib/build-collections/teams.d.ts +4 -0
  143. package/dist/better-auth/plugin/lib/build-collections/teams.d.ts.map +1 -0
  144. package/dist/better-auth/plugin/lib/build-collections/teams.js +74 -0
  145. package/dist/better-auth/plugin/lib/build-collections/two-factors.d.ts +4 -0
  146. package/dist/better-auth/plugin/lib/build-collections/two-factors.d.ts.map +1 -0
  147. package/dist/better-auth/plugin/lib/build-collections/two-factors.js +66 -0
  148. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.d.ts +8 -0
  149. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.d.ts.map +1 -0
  150. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.js +52 -0
  151. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.d.ts +12 -0
  152. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.d.ts.map +1 -0
  153. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/generate-invite-url.js +68 -0
  154. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.d.ts +5 -0
  155. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.d.ts.map +1 -0
  156. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/index.js +6 -0
  157. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.d.ts +3 -0
  158. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.d.ts.map +1 -0
  159. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/refresh-token.js +114 -0
  160. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/send-invite-url.d.ts +4 -0
  161. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/send-invite-url.d.ts.map +1 -0
  162. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/send-invite-url.js +64 -0
  163. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.d.ts +4 -0
  164. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.d.ts.map +1 -0
  165. package/dist/better-auth/plugin/lib/build-collections/users/endpoints/set-admin-role.js +90 -0
  166. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts +7 -0
  167. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts.map +1 -0
  168. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js +80 -0
  169. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.d.ts +3 -0
  170. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.d.ts.map +1 -0
  171. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-logout.js +79 -0
  172. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.d.ts +3 -0
  173. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.d.ts.map +1 -0
  174. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-delete.js +54 -0
  175. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.d.ts +7 -0
  176. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.d.ts.map +1 -0
  177. package/dist/better-auth/plugin/lib/build-collections/users/hooks/before-login.js +15 -0
  178. package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.d.ts +7 -0
  179. package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.d.ts.map +1 -0
  180. package/dist/better-auth/plugin/lib/build-collections/users/hooks/index.js +8 -0
  181. package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.d.ts +3 -0
  182. package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.d.ts.map +1 -0
  183. package/dist/better-auth/plugin/lib/build-collections/users/hooks/on-verified-change.js +17 -0
  184. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.d.ts +3 -0
  185. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.d.ts.map +1 -0
  186. package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.js +90 -0
  187. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts +4 -0
  188. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts.map +1 -0
  189. package/dist/better-auth/plugin/lib/build-collections/users/index.js +333 -0
  190. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.d.ts +16 -0
  191. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.d.ts.map +1 -0
  192. package/dist/better-auth/plugin/lib/build-collections/utils/collection-schema.js +24 -0
  193. package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.d.ts +11 -0
  194. package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.d.ts.map +1 -0
  195. package/dist/better-auth/plugin/lib/build-collections/utils/filter-properties.js +112 -0
  196. package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.d.ts +8 -0
  197. package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.d.ts.map +1 -0
  198. package/dist/better-auth/plugin/lib/build-collections/utils/get-timestamp-fields.js +31 -0
  199. package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.d.ts +12 -0
  200. package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.d.ts.map +1 -0
  201. package/dist/better-auth/plugin/lib/build-collections/utils/model-field-transformations.js +26 -0
  202. package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.d.ts +18 -0
  203. package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.d.ts.map +1 -0
  204. package/dist/better-auth/plugin/lib/build-collections/utils/payload-access.js +84 -0
  205. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.d.ts +21 -0
  206. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.d.ts.map +1 -0
  207. package/dist/better-auth/plugin/lib/build-collections/utils/transform-schema-fields-to-payload.js +95 -0
  208. package/dist/better-auth/plugin/lib/build-collections/verifications.d.ts +4 -0
  209. package/dist/better-auth/plugin/lib/build-collections/verifications.d.ts.map +1 -0
  210. package/dist/better-auth/plugin/lib/build-collections/verifications.js +82 -0
  211. package/dist/better-auth/plugin/lib/get-payload-auth.d.ts +6 -0
  212. package/dist/better-auth/plugin/lib/get-payload-auth.d.ts.map +1 -0
  213. package/dist/better-auth/plugin/lib/get-payload-auth.js +9 -0
  214. package/dist/better-auth/plugin/lib/init-better-auth.d.ts +8 -0
  215. package/dist/better-auth/plugin/lib/init-better-auth.d.ts.map +1 -0
  216. package/dist/better-auth/plugin/lib/init-better-auth.js +16 -0
  217. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.d.ts +3 -0
  218. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.d.ts.map +1 -0
  219. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/admin-plugin.js +12 -0
  220. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.d.ts +3 -0
  221. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.d.ts.map +1 -0
  222. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/api-key-plugin.js +10 -0
  223. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/device-authorization-plugin.d.ts +3 -0
  224. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/device-authorization-plugin.d.ts.map +1 -0
  225. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/device-authorization-plugin.js +8 -0
  226. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts +12 -0
  227. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts.map +1 -0
  228. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js +146 -0
  229. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.d.ts +3 -0
  230. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.d.ts.map +1 -0
  231. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/oidc-plugin.js +18 -0
  232. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.d.ts +3 -0
  233. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.d.ts.map +1 -0
  234. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/organizations-plugin.js +34 -0
  235. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.d.ts +3 -0
  236. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.d.ts.map +1 -0
  237. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/passkey-plugin.js +11 -0
  238. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.d.ts +3 -0
  239. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.d.ts.map +1 -0
  240. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/sso-plugin.js +10 -0
  241. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.d.ts +3 -0
  242. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.d.ts.map +1 -0
  243. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/two-factor-plugin.js +11 -0
  244. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-after-role-middleware.d.ts +8 -0
  245. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-after-role-middleware.d.ts.map +1 -0
  246. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-after-role-middleware.js +20 -0
  247. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-before-role-middleware.d.ts +8 -0
  248. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-before-role-middleware.d.ts.map +1 -0
  249. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/admin-before-role-middleware.js +20 -0
  250. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/apply-save-to-jwt-returned.d.ts +14 -0
  251. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/apply-save-to-jwt-returned.d.ts.map +1 -0
  252. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/apply-save-to-jwt-returned.js +38 -0
  253. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/ensure-password-set-before-create.d.ts +8 -0
  254. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/ensure-password-set-before-create.d.ts.map +1 -0
  255. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/ensure-password-set-before-create.js +23 -0
  256. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/password.d.ts +26 -0
  257. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/password.d.ts.map +1 -0
  258. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/password.js +62 -0
  259. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.d.ts +10 -0
  260. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.d.ts.map +1 -0
  261. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.js +42 -0
  262. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.d.ts +10 -0
  263. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.d.ts.map +1 -0
  264. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/use-admin-invite-after-email-sign-up-middleware.js +62 -0
  265. package/dist/better-auth/plugin/lib/set-login-methods.d.ts +5 -0
  266. package/dist/better-auth/plugin/lib/set-login-methods.d.ts.map +1 -0
  267. package/dist/better-auth/plugin/lib/set-login-methods.js +14 -0
  268. package/dist/better-auth/plugin/payload/components/admin-buttons/index.d.ts +10 -0
  269. package/dist/better-auth/plugin/payload/components/admin-buttons/index.d.ts.map +1 -0
  270. package/dist/better-auth/plugin/payload/components/admin-buttons/index.js +116 -0
  271. package/dist/better-auth/plugin/payload/components/admin-buttons/index.scss +36 -0
  272. package/dist/better-auth/plugin/payload/components/admin-invite-button/index.d.ts +11 -0
  273. package/dist/better-auth/plugin/payload/components/admin-invite-button/index.d.ts.map +1 -0
  274. package/dist/better-auth/plugin/payload/components/admin-invite-button/index.js +213 -0
  275. package/dist/better-auth/plugin/payload/components/admin-invite-button/index.scss +136 -0
  276. package/dist/better-auth/plugin/payload/components/login-form/alternative-methods.d.ts +4 -0
  277. package/dist/better-auth/plugin/payload/components/login-form/alternative-methods.d.ts.map +1 -0
  278. package/dist/better-auth/plugin/payload/components/login-form/alternative-methods.js +197 -0
  279. package/dist/better-auth/plugin/payload/components/login-form/context.d.ts +49 -0
  280. package/dist/better-auth/plugin/payload/components/login-form/context.d.ts.map +1 -0
  281. package/dist/better-auth/plugin/payload/components/login-form/context.js +94 -0
  282. package/dist/better-auth/plugin/payload/components/login-form/credentials-form.d.ts +4 -0
  283. package/dist/better-auth/plugin/payload/components/login-form/credentials-form.d.ts.map +1 -0
  284. package/dist/better-auth/plugin/payload/components/login-form/credentials-form.js +167 -0
  285. package/dist/better-auth/plugin/payload/components/login-form/index.d.ts +5 -0
  286. package/dist/better-auth/plugin/payload/components/login-form/index.d.ts.map +1 -0
  287. package/dist/better-auth/plugin/payload/components/login-form/index.js +6 -0
  288. package/dist/better-auth/plugin/payload/components/login-form/index.scss +58 -0
  289. package/dist/better-auth/plugin/payload/components/logout-button.d.ts +5 -0
  290. package/dist/better-auth/plugin/payload/components/logout-button.d.ts.map +1 -0
  291. package/dist/better-auth/plugin/payload/components/logout-button.js +24 -0
  292. package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts +9 -0
  293. package/dist/better-auth/plugin/payload/components/passkeys/add-button.d.ts.map +1 -0
  294. package/dist/better-auth/plugin/payload/components/passkeys/add-button.js +122 -0
  295. package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts +3 -0
  296. package/dist/better-auth/plugin/payload/components/passkeys/client.d.ts.map +1 -0
  297. package/dist/better-auth/plugin/payload/components/passkeys/client.js +61 -0
  298. package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts +5 -0
  299. package/dist/better-auth/plugin/payload/components/passkeys/index.d.ts.map +1 -0
  300. package/dist/better-auth/plugin/payload/components/passkeys/index.js +42 -0
  301. package/dist/better-auth/plugin/payload/components/passkeys/index.scss +98 -0
  302. package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts +9 -0
  303. package/dist/better-auth/plugin/payload/components/passkeys/list.d.ts.map +1 -0
  304. package/dist/better-auth/plugin/payload/components/passkeys/list.js +57 -0
  305. package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts +23 -0
  306. package/dist/better-auth/plugin/payload/components/passkeys/types.d.ts.map +1 -0
  307. package/dist/better-auth/plugin/payload/components/passkeys/types.js +3 -0
  308. package/dist/better-auth/plugin/payload/components/rsc-redirect.d.ts +7 -0
  309. package/dist/better-auth/plugin/payload/components/rsc-redirect.d.ts.map +1 -0
  310. package/dist/better-auth/plugin/payload/components/rsc-redirect.js +13 -0
  311. package/dist/better-auth/plugin/payload/components/token-field.d.ts +4 -0
  312. package/dist/better-auth/plugin/payload/components/token-field.d.ts.map +1 -0
  313. package/dist/better-auth/plugin/payload/components/token-field.js +29 -0
  314. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts +9 -0
  315. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts.map +1 -0
  316. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.js +347 -0
  317. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.scss +116 -0
  318. package/dist/better-auth/plugin/payload/exports/client.d.ts +7 -0
  319. package/dist/better-auth/plugin/payload/exports/client.d.ts.map +1 -0
  320. package/dist/better-auth/plugin/payload/exports/client.js +8 -0
  321. package/dist/better-auth/plugin/payload/exports/rsc.d.ts +9 -0
  322. package/dist/better-auth/plugin/payload/exports/rsc.d.ts.map +1 -0
  323. package/dist/better-auth/plugin/payload/exports/rsc.js +10 -0
  324. package/dist/better-auth/plugin/payload/utils/generate-admin-invite-url.d.ts +3 -0
  325. package/dist/better-auth/plugin/payload/utils/generate-admin-invite-url.d.ts.map +1 -0
  326. package/dist/better-auth/plugin/payload/utils/generate-admin-invite-url.js +9 -0
  327. package/dist/better-auth/plugin/payload/utils/get-safe-redirect.d.ts +2 -0
  328. package/dist/better-auth/plugin/payload/utils/get-safe-redirect.d.ts.map +1 -0
  329. package/dist/better-auth/plugin/payload/utils/get-safe-redirect.js +22 -0
  330. package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts +23 -0
  331. package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts.map +1 -0
  332. package/dist/better-auth/plugin/payload/views/admin-login/client.js +24 -0
  333. package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts +11 -0
  334. package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts.map +1 -0
  335. package/dist/better-auth/plugin/payload/views/admin-login/index.js +143 -0
  336. package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts +23 -0
  337. package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts.map +1 -0
  338. package/dist/better-auth/plugin/payload/views/admin-signup/client.js +185 -0
  339. package/dist/better-auth/plugin/payload/views/admin-signup/index.d.ts +10 -0
  340. package/dist/better-auth/plugin/payload/views/admin-signup/index.d.ts.map +1 -0
  341. package/dist/better-auth/plugin/payload/views/admin-signup/index.js +92 -0
  342. package/dist/better-auth/plugin/payload/views/forgot-password/client.d.ts +7 -0
  343. package/dist/better-auth/plugin/payload/views/forgot-password/client.d.ts.map +1 -0
  344. package/dist/better-auth/plugin/payload/views/forgot-password/client.js +104 -0
  345. package/dist/better-auth/plugin/payload/views/forgot-password/index.d.ts +9 -0
  346. package/dist/better-auth/plugin/payload/views/forgot-password/index.d.ts.map +1 -0
  347. package/dist/better-auth/plugin/payload/views/forgot-password/index.js +61 -0
  348. package/dist/better-auth/plugin/payload/views/reset-password/client.d.ts +11 -0
  349. package/dist/better-auth/plugin/payload/views/reset-password/client.d.ts.map +1 -0
  350. package/dist/better-auth/plugin/payload/views/reset-password/client.js +111 -0
  351. package/dist/better-auth/plugin/payload/views/reset-password/index.d.ts +9 -0
  352. package/dist/better-auth/plugin/payload/views/reset-password/index.d.ts.map +1 -0
  353. package/dist/better-auth/plugin/payload/views/reset-password/index.js +78 -0
  354. package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts +9 -0
  355. package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts.map +1 -0
  356. package/dist/better-auth/plugin/payload/views/two-factor-verify/client.js +79 -0
  357. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts +10 -0
  358. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts.map +1 -0
  359. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.js +49 -0
  360. package/dist/better-auth/plugin/types.d.ts +448 -0
  361. package/dist/better-auth/plugin/types.d.ts.map +1 -0
  362. package/dist/better-auth/plugin/types.js +3 -0
  363. package/dist/better-auth/plugin/utils/set.d.ts +40 -0
  364. package/dist/better-auth/plugin/utils/set.d.ts.map +1 -0
  365. package/dist/better-auth/plugin/utils/set.js +84 -0
  366. package/dist/better-auth/scripts/generate-types.d.ts +2 -0
  367. package/dist/better-auth/scripts/generate-types.d.ts.map +1 -0
  368. package/dist/better-auth/scripts/generate-types.js +225 -0
  369. package/dist/better-auth/types.d.ts +3 -0
  370. package/dist/better-auth/types.d.ts.map +1 -0
  371. package/dist/better-auth/types.js +4 -0
  372. package/dist/index.d.ts +2 -0
  373. package/dist/index.d.ts.map +1 -0
  374. package/dist/index.js +4 -0
  375. package/dist/shared/components/icons.d.ts +8 -0
  376. package/dist/shared/components/icons.d.ts.map +1 -0
  377. package/dist/shared/components/icons.js +436 -0
  378. package/dist/shared/components/logo.d.ts +3 -0
  379. package/dist/shared/components/logo.d.ts.map +1 -0
  380. package/dist/shared/components/logo.js +24 -0
  381. package/dist/shared/form/components/submit.d.ts +8 -0
  382. package/dist/shared/form/components/submit.d.ts.map +1 -0
  383. package/dist/shared/form/components/submit.js +23 -0
  384. package/dist/shared/form/fields/text-field.d.ts +9 -0
  385. package/dist/shared/form/fields/text-field.d.ts.map +1 -0
  386. package/dist/shared/form/fields/text-field.js +44 -0
  387. package/dist/shared/form/index.d.ts +28 -0
  388. package/dist/shared/form/index.d.ts.map +1 -0
  389. package/dist/shared/form/index.js +17 -0
  390. package/dist/shared/form/ui/header/index.d.ts +9 -0
  391. package/dist/shared/form/ui/header/index.d.ts.map +1 -0
  392. package/dist/shared/form/ui/header/index.js +23 -0
  393. package/dist/shared/form/ui/header/index.scss +8 -0
  394. package/dist/shared/form/ui/index.d.ts +34 -0
  395. package/dist/shared/form/ui/index.d.ts.map +1 -0
  396. package/dist/shared/form/ui/index.js +70 -0
  397. package/dist/shared/form/ui/index.scss +27 -0
  398. package/dist/shared/form/validation.d.ts +65 -0
  399. package/dist/shared/form/validation.d.ts.map +1 -0
  400. package/dist/shared/form/validation.js +108 -0
  401. package/dist/shared/index.d.ts +3 -0
  402. package/dist/shared/index.d.ts.map +1 -0
  403. package/dist/shared/index.js +4 -0
  404. package/dist/shared/payload/fields/field-copy-button/index.css +47 -0
  405. package/dist/shared/payload/fields/field-copy-button/index.d.ts +4 -0
  406. package/dist/shared/payload/fields/field-copy-button/index.d.ts.map +1 -0
  407. package/dist/shared/payload/fields/field-copy-button/index.js +38 -0
  408. package/dist/shared/payload/fields/generate-uuid-button/index.css +14 -0
  409. package/dist/shared/payload/fields/generate-uuid-button/index.d.ts +4 -0
  410. package/dist/shared/payload/fields/generate-uuid-button/index.d.ts.map +1 -0
  411. package/dist/shared/payload/fields/generate-uuid-button/index.js +26 -0
  412. package/dist/shared/payload/fields/index.d.ts +3 -0
  413. package/dist/shared/payload/fields/index.d.ts.map +1 -0
  414. package/dist/shared/payload/fields/index.js +4 -0
  415. package/dist/shared/utils/regex.d.ts +3 -0
  416. package/dist/shared/utils/regex.d.ts.map +1 -0
  417. package/dist/shared/utils/regex.js +4 -0
  418. package/dist/shared/utils/try-catch.d.ts +12 -0
  419. package/dist/shared/utils/try-catch.d.ts.map +1 -0
  420. package/dist/shared/utils/try-catch.js +17 -0
  421. package/dist/shared/utils/value-or-default.d.ts +10 -0
  422. package/dist/shared/utils/value-or-default.d.ts.map +1 -0
  423. package/dist/shared/utils/value-or-default.js +12 -0
  424. package/package.json +124 -0
@@ -0,0 +1,717 @@
1
+ import { BetterAuthError } from "better-auth";
2
+ import { generateSchema } from "./generate-schema";
3
+ import { createTransform } from "./transform";
4
+ export const BETTER_AUTH_CONTEXT_KEY = "payload-db-adapter";
5
+ const PAYLOAD_QUERY_DEPTH = 1;
6
+ const CREATE_QUERY_DEPTH = 0;
7
+ /**
8
+ * Payload adapter for Better Auth.
9
+ *
10
+ * This adapter connects Better Auth to Payload CMS, allowing authentication
11
+ * operations to be performed against Payload collections.
12
+ *
13
+ * @param payloadClient - The Payload CMS client instance or a function that returns it
14
+ * @param config - Configuration options for the adapter
15
+ * @returns A function that creates a Better Auth adapter
16
+ */ const payloadAdapter = ({ payloadClient, adapterConfig })=>{
17
+ /**
18
+ * Logs debug messages if debug logging is enabled
19
+ * @param message - The message to log
20
+ */ function debugLog(message) {
21
+ if (adapterConfig.enableDebugLogs) {
22
+ console.log("[payload-db-adapter]", ...message);
23
+ }
24
+ }
25
+ /**
26
+ * Logs error messages
27
+ * @param message - The error message to log
28
+ */ function errorLog(message) {
29
+ console.error(`[payload-db-adapter]`, ...message);
30
+ }
31
+ /**
32
+ * Throws an error when a collection slug doesn't exist
33
+ * @param model - The model name that couldn't be found
34
+ * @throws {BetterAuthError} When the collection doesn't exist
35
+ * @returns Never - Function always throws
36
+ */ function collectionSlugError(model) {
37
+ throw new BetterAuthError(`Collection ${model} does not exist. Please check your payload collection slugs match the better auth schema`);
38
+ }
39
+ /**
40
+ * Validates that a collection exists in Payload
41
+ * @param payload - The Payload client instance
42
+ * @param collectionSlug - The collection slug to validate
43
+ * @param model - The model name for error messages
44
+ * @throws {BetterAuthError} When the collection doesn't exist
45
+ */ async function validateCollection(payload, collectionSlug, model) {
46
+ if (!collectionSlug || !(collectionSlug in payload.collections)) {
47
+ collectionSlugError(model);
48
+ }
49
+ }
50
+ /**
51
+ * Creates a context object for Payload operations
52
+ * @param data - Data to include in the context
53
+ * @returns The context object with Better Auth metadata
54
+ */ const createAdapterContext = (data)=>({
55
+ [BETTER_AUTH_CONTEXT_KEY]: {
56
+ ...data
57
+ }
58
+ });
59
+ /**
60
+ * Resolves the Payload client, handling both function and direct references
61
+ * @returns The resolved Payload client
62
+ * @throws {BetterAuthError} When Better Auth plugin is not configured
63
+ */ async function resolvePayloadClient() {
64
+ const payload = typeof payloadClient === "function" ? await payloadClient() : await payloadClient;
65
+ if (!payload.config?.custom?.hasBetterAuthPlugin) {
66
+ throw new BetterAuthError(`Payload is not configured with the better-auth plugin. Please add the plugin to your payload config.`);
67
+ }
68
+ return payload;
69
+ }
70
+ /**
71
+ * Creates and returns a Better Auth adapter for Payload
72
+ * @param options - Better Auth options
73
+ * @returns A Better Auth adapter implementation
74
+ */ return (options)=>{
75
+ const { transformInput, transformOutput, convertWhereClause, convertSelect, convertSort, getCollectionSlug, singleIdQuery } = createTransform(options, adapterConfig.enableDebugLogs ?? false);
76
+ function getJoinFieldNames(payload, collectionSlug) {
77
+ const collection = payload.collections?.[collectionSlug]?.config;
78
+ if (!collection?.flattenedFields) return new Set();
79
+ return new Set(collection.flattenedFields.filter((f)=>f.type === "join").map((f)=>f.name));
80
+ }
81
+ function buildPayloadJoins(join, payload, collectionSlug) {
82
+ if (!join) return undefined;
83
+ const allowedJoinFields = getJoinFieldNames(payload, collectionSlug);
84
+ const joins = {};
85
+ Object.entries(join).forEach(([modelKey, config])=>{
86
+ if (config === false) return;
87
+ // Translate Better Auth model key (e.g. 'account') to Payload join field name (e.g. 'accounts')
88
+ const joinFieldName = getCollectionSlug(modelKey);
89
+ if (!allowedJoinFields.has(joinFieldName)) {
90
+ debugLog([
91
+ `join skipped: no join field '${joinFieldName}' (from model '${modelKey}') on ${collectionSlug}`
92
+ ]);
93
+ return;
94
+ }
95
+ if (config === true) {
96
+ joins[joinFieldName] = {};
97
+ return;
98
+ }
99
+ if (config && typeof config === "object") {
100
+ joins[joinFieldName] = {
101
+ ...config
102
+ };
103
+ }
104
+ });
105
+ return Object.keys(joins).length ? joins : undefined;
106
+ }
107
+ return {
108
+ id: "payload-adapter",
109
+ async transaction (callback) {
110
+ return await callback(this);
111
+ },
112
+ async create ({ model, data: values, select }) {
113
+ const start = Date.now();
114
+ const payload = await resolvePayloadClient();
115
+ const collectionSlug = getCollectionSlug(model);
116
+ // Validate collection exists before proceeding
117
+ await validateCollection(payload, collectionSlug, model);
118
+ const transformedInput = transformInput({
119
+ data: values,
120
+ model: model,
121
+ idType: adapterConfig.idType,
122
+ payload
123
+ });
124
+ debugLog([
125
+ "create",
126
+ {
127
+ collectionSlug,
128
+ transformedInput,
129
+ select
130
+ }
131
+ ]);
132
+ try {
133
+ // Use depth: 0 for create to avoid populating relationship fields.
134
+ // Populated relationships would bloat the session data stored in cookie cache.
135
+ // This needs more testing and validation.
136
+ const result = await payload.create({
137
+ collection: collectionSlug,
138
+ data: transformedInput,
139
+ select: convertSelect(model, select),
140
+ context: createAdapterContext({
141
+ model,
142
+ operation: "create"
143
+ }),
144
+ depth: CREATE_QUERY_DEPTH
145
+ });
146
+ const transformedResult = transformOutput({
147
+ doc: result,
148
+ model: model,
149
+ payload
150
+ });
151
+ debugLog([
152
+ "create result",
153
+ {
154
+ collectionSlug,
155
+ transformedResult,
156
+ duration: `${Date.now() - start}ms`
157
+ }
158
+ ]);
159
+ return transformedResult;
160
+ } catch (error) {
161
+ errorLog([
162
+ "Error in creating:",
163
+ model,
164
+ error
165
+ ]);
166
+ return null;
167
+ }
168
+ },
169
+ async findOne ({ model, where, select, join }) {
170
+ const start = Date.now();
171
+ const payload = await resolvePayloadClient();
172
+ const collectionSlug = getCollectionSlug(model);
173
+ // Validate collection exists before proceeding
174
+ await validateCollection(payload, collectionSlug, model);
175
+ const payloadWhere = convertWhereClause({
176
+ idType: adapterConfig.idType,
177
+ model: model,
178
+ where,
179
+ payload
180
+ });
181
+ debugLog([
182
+ "findOne",
183
+ {
184
+ collectionSlug,
185
+ join
186
+ }
187
+ ]);
188
+ try {
189
+ const singleId = singleIdQuery(payloadWhere);
190
+ let result = null;
191
+ const payloadJoins = buildPayloadJoins(join, payload, collectionSlug);
192
+ if (singleId) {
193
+ debugLog([
194
+ "findOneByID",
195
+ {
196
+ collectionSlug,
197
+ id: singleId
198
+ }
199
+ ]);
200
+ result = await payload.findByID({
201
+ collection: collectionSlug,
202
+ id: singleId,
203
+ select: convertSelect(model, select),
204
+ ...payloadJoins && Object.keys(payloadJoins).length > 0 && {
205
+ joins: payloadJoins
206
+ },
207
+ context: createAdapterContext({
208
+ model,
209
+ operation: "findOneByID"
210
+ }),
211
+ depth: PAYLOAD_QUERY_DEPTH
212
+ });
213
+ } else {
214
+ debugLog([
215
+ "findOneByWhere",
216
+ {
217
+ collectionSlug,
218
+ payloadWhere
219
+ }
220
+ ]);
221
+ const docs = await payload.find({
222
+ collection: collectionSlug,
223
+ where: payloadWhere,
224
+ select: convertSelect(model, select),
225
+ ...payloadJoins && Object.keys(payloadJoins).length > 0 && {
226
+ joins: payloadJoins
227
+ },
228
+ context: createAdapterContext({
229
+ model,
230
+ operation: "findOneByWhere"
231
+ }),
232
+ depth: PAYLOAD_QUERY_DEPTH,
233
+ limit: 1
234
+ });
235
+ result = docs.docs[0];
236
+ }
237
+ const transformedResult = transformOutput({
238
+ doc: result,
239
+ model: model,
240
+ payload
241
+ });
242
+ debugLog([
243
+ "findOne result",
244
+ {
245
+ collectionSlug,
246
+ transformedResult,
247
+ duration: `${Date.now() - start}ms`
248
+ }
249
+ ]);
250
+ return transformedResult;
251
+ } catch (error) {
252
+ if (error instanceof Error && "status" in error && error.status === 404) {
253
+ return null;
254
+ }
255
+ errorLog([
256
+ "Error in findOne: ",
257
+ error
258
+ ]);
259
+ return null;
260
+ }
261
+ },
262
+ async findMany ({ model, where, limit = 10, sortBy, offset = 0, join }) {
263
+ const start = Date.now();
264
+ const payload = await resolvePayloadClient();
265
+ const collectionSlug = getCollectionSlug(model);
266
+ // Validate collection exists before proceeding
267
+ await validateCollection(payload, collectionSlug, model);
268
+ const payloadWhere = convertWhereClause({
269
+ idType: adapterConfig.idType,
270
+ model: model,
271
+ where,
272
+ payload
273
+ });
274
+ debugLog([
275
+ "findMany",
276
+ {
277
+ collectionSlug,
278
+ sortBy,
279
+ limit,
280
+ offset
281
+ }
282
+ ]);
283
+ try {
284
+ let result = null;
285
+ const singleId = singleIdQuery(payloadWhere);
286
+ const payloadJoins = buildPayloadJoins(join, payload, collectionSlug);
287
+ if (singleId) {
288
+ debugLog([
289
+ "findManyBySingleID",
290
+ {
291
+ collectionSlug,
292
+ id: singleId
293
+ }
294
+ ]);
295
+ const doc = await payload.findByID({
296
+ collection: collectionSlug,
297
+ id: singleId,
298
+ ...payloadJoins && Object.keys(payloadJoins).length > 0 && {
299
+ joins: payloadJoins
300
+ },
301
+ depth: PAYLOAD_QUERY_DEPTH,
302
+ context: createAdapterContext({
303
+ model,
304
+ operation: "findManyBySingleID"
305
+ })
306
+ });
307
+ result = {
308
+ docs: doc ? [
309
+ doc
310
+ ] : [],
311
+ totalDocs: doc ? 1 : 0
312
+ };
313
+ } else {
314
+ debugLog([
315
+ "findManyByWhere",
316
+ {
317
+ collectionSlug,
318
+ payloadWhere
319
+ }
320
+ ]);
321
+ const spill = offset % limit;
322
+ const page = Math.floor(offset / limit) + 1;
323
+ const fetchLimit = spill ? limit + spill : limit;
324
+ const res = await payload.find({
325
+ collection: collectionSlug,
326
+ where: payloadWhere,
327
+ limit: fetchLimit,
328
+ page: page,
329
+ sort: convertSort(model, sortBy),
330
+ ...payloadJoins && Object.keys(payloadJoins).length > 0 && {
331
+ joins: payloadJoins
332
+ },
333
+ depth: PAYLOAD_QUERY_DEPTH,
334
+ context: createAdapterContext({
335
+ model,
336
+ operation: "findManyByWhere"
337
+ })
338
+ });
339
+ result = {
340
+ docs: res.docs.slice(spill, spill + limit),
341
+ totalDocs: res.totalDocs
342
+ };
343
+ }
344
+ const transformedResult = result?.docs.map((doc)=>transformOutput({
345
+ doc,
346
+ model: model,
347
+ payload
348
+ })) ?? [];
349
+ debugLog([
350
+ "findMany result",
351
+ {
352
+ collectionSlug,
353
+ transformedResult,
354
+ duration: `${Date.now() - start}ms`
355
+ }
356
+ ]);
357
+ return transformedResult;
358
+ } catch (error) {
359
+ if (error instanceof Error && "status" in error && error.status === 404) {
360
+ return [];
361
+ }
362
+ errorLog([
363
+ "Error in findMany: ",
364
+ error
365
+ ]);
366
+ return [];
367
+ }
368
+ },
369
+ async update ({ model, where, update }) {
370
+ const start = Date.now();
371
+ const payload = await resolvePayloadClient();
372
+ const collectionSlug = getCollectionSlug(model);
373
+ // Validate collection exists before proceeding
374
+ await validateCollection(payload, collectionSlug, model);
375
+ const payloadWhere = convertWhereClause({
376
+ idType: adapterConfig.idType,
377
+ model: model,
378
+ where,
379
+ payload
380
+ });
381
+ const transformedInput = transformInput({
382
+ data: update,
383
+ model: model,
384
+ idType: adapterConfig.idType,
385
+ payload
386
+ });
387
+ debugLog([
388
+ "update",
389
+ {
390
+ collectionSlug,
391
+ update
392
+ }
393
+ ]);
394
+ try {
395
+ let result = null;
396
+ const id = singleIdQuery(payloadWhere);
397
+ if (id) {
398
+ debugLog([
399
+ "updateByID",
400
+ {
401
+ collectionSlug,
402
+ id
403
+ }
404
+ ]);
405
+ result = await payload.update({
406
+ collection: collectionSlug,
407
+ id,
408
+ data: transformedInput,
409
+ depth: PAYLOAD_QUERY_DEPTH,
410
+ context: createAdapterContext({
411
+ model,
412
+ operation: "updateByID"
413
+ })
414
+ });
415
+ } else {
416
+ debugLog([
417
+ "updateByWhere",
418
+ {
419
+ collectionSlug,
420
+ payloadWhere
421
+ }
422
+ ]);
423
+ const doc = await payload.update({
424
+ collection: collectionSlug,
425
+ where: payloadWhere,
426
+ data: transformedInput,
427
+ depth: PAYLOAD_QUERY_DEPTH,
428
+ context: createAdapterContext({
429
+ model,
430
+ operation: "updateByWhere"
431
+ })
432
+ });
433
+ result = doc.docs[0];
434
+ }
435
+ const transformedResult = transformOutput({
436
+ doc: result,
437
+ model: model,
438
+ payload
439
+ });
440
+ debugLog([
441
+ "update-result",
442
+ {
443
+ collectionSlug,
444
+ transformedResult,
445
+ duration: `${Date.now() - start}ms`
446
+ }
447
+ ]);
448
+ return transformedResult;
449
+ } catch (error) {
450
+ if (error instanceof Error && "status" in error && error.status === 404) {
451
+ return null;
452
+ }
453
+ errorLog([
454
+ "Error in update: ",
455
+ error
456
+ ]);
457
+ return null;
458
+ }
459
+ },
460
+ async updateMany ({ model, where, update }) {
461
+ const start = Date.now();
462
+ const payload = await resolvePayloadClient();
463
+ const collectionSlug = getCollectionSlug(model);
464
+ // Validate collection exists before proceeding
465
+ await validateCollection(payload, collectionSlug, model);
466
+ const payloadWhere = convertWhereClause({
467
+ idType: adapterConfig.idType,
468
+ model: model,
469
+ where,
470
+ payload
471
+ });
472
+ const transformedInput = transformInput({
473
+ data: update,
474
+ model: model,
475
+ idType: adapterConfig.idType,
476
+ payload
477
+ });
478
+ debugLog([
479
+ "updateMany",
480
+ {
481
+ collectionSlug,
482
+ payloadWhere,
483
+ update
484
+ }
485
+ ]);
486
+ try {
487
+ const { docs: updateResult } = await payload.update({
488
+ collection: collectionSlug,
489
+ where: payloadWhere,
490
+ data: transformedInput,
491
+ depth: PAYLOAD_QUERY_DEPTH,
492
+ context: createAdapterContext({
493
+ model,
494
+ operation: "updateMany"
495
+ })
496
+ });
497
+ debugLog([
498
+ "updateMany result",
499
+ {
500
+ collectionSlug,
501
+ result: updateResult,
502
+ duration: `${Date.now() - start}ms`
503
+ }
504
+ ]);
505
+ return updateResult?.length || 0;
506
+ } catch (error) {
507
+ if (error instanceof Error && "status" in error && error.status === 404) {
508
+ return 0;
509
+ }
510
+ errorLog([
511
+ "Error in updateMany: ",
512
+ error
513
+ ]);
514
+ return 0;
515
+ }
516
+ },
517
+ async delete ({ model, where }) {
518
+ const start = Date.now();
519
+ const payload = await resolvePayloadClient();
520
+ const collectionSlug = getCollectionSlug(model);
521
+ // Validate collection exists before proceeding
522
+ await validateCollection(payload, collectionSlug, model);
523
+ const payloadWhere = convertWhereClause({
524
+ idType: adapterConfig.idType,
525
+ model: model,
526
+ where,
527
+ payload
528
+ });
529
+ debugLog([
530
+ "delete",
531
+ {
532
+ collectionSlug
533
+ }
534
+ ]);
535
+ try {
536
+ let deleteResult = null;
537
+ const singleId = singleIdQuery(payloadWhere);
538
+ if (singleId) {
539
+ debugLog([
540
+ "deleteByID",
541
+ {
542
+ collectionSlug,
543
+ id: singleId
544
+ }
545
+ ]);
546
+ const doc = await payload.delete({
547
+ collection: collectionSlug,
548
+ id: singleId,
549
+ depth: PAYLOAD_QUERY_DEPTH,
550
+ context: createAdapterContext({
551
+ model,
552
+ operation: "deleteByID"
553
+ })
554
+ });
555
+ deleteResult = {
556
+ doc,
557
+ errors: []
558
+ };
559
+ } else {
560
+ debugLog([
561
+ "deleteByWhere",
562
+ {
563
+ collectionSlug,
564
+ payloadWhere
565
+ }
566
+ ]);
567
+ const doc = await payload.delete({
568
+ collection: collectionSlug,
569
+ where: payloadWhere,
570
+ depth: PAYLOAD_QUERY_DEPTH,
571
+ context: createAdapterContext({
572
+ model,
573
+ operation: "deleteByWhere"
574
+ })
575
+ });
576
+ deleteResult = {
577
+ doc: doc.docs[0],
578
+ errors: []
579
+ };
580
+ }
581
+ debugLog([
582
+ "delete result",
583
+ {
584
+ collectionSlug,
585
+ result: deleteResult,
586
+ duration: `${Date.now() - start}ms`
587
+ }
588
+ ]);
589
+ } catch (error) {
590
+ if (error instanceof Error && "status" in error && error.status === 404) {
591
+ return;
592
+ }
593
+ errorLog([
594
+ "Error in delete: ",
595
+ error
596
+ ]);
597
+ }
598
+ },
599
+ async deleteMany ({ model, where }) {
600
+ const start = Date.now();
601
+ const payload = await resolvePayloadClient();
602
+ const collectionSlug = getCollectionSlug(model);
603
+ // Validate collection exists before proceeding
604
+ await validateCollection(payload, collectionSlug, model);
605
+ const payloadWhere = convertWhereClause({
606
+ idType: adapterConfig.idType,
607
+ model: model,
608
+ where,
609
+ payload
610
+ });
611
+ debugLog([
612
+ "deleteMany",
613
+ {
614
+ collectionSlug,
615
+ payloadWhere
616
+ }
617
+ ]);
618
+ try {
619
+ const deleteResult = await payload.delete({
620
+ collection: collectionSlug,
621
+ where: payloadWhere,
622
+ depth: PAYLOAD_QUERY_DEPTH,
623
+ context: createAdapterContext({
624
+ model,
625
+ operation: "deleteMany"
626
+ })
627
+ });
628
+ debugLog([
629
+ "deleteMany result",
630
+ {
631
+ collectionSlug,
632
+ result: deleteResult,
633
+ duration: `${Date.now() - start}ms`
634
+ }
635
+ ]);
636
+ return deleteResult.docs.length;
637
+ } catch (error) {
638
+ if (error instanceof Error && "status" in error && error.status === 404) {
639
+ return 0;
640
+ }
641
+ errorLog([
642
+ "Error in deleteMany: ",
643
+ error
644
+ ]);
645
+ return 0;
646
+ }
647
+ },
648
+ async count ({ model, where }) {
649
+ const start = Date.now();
650
+ const payload = await resolvePayloadClient();
651
+ const collectionSlug = getCollectionSlug(model);
652
+ // Validate collection exists before proceeding
653
+ await validateCollection(payload, collectionSlug, model);
654
+ const payloadWhere = convertWhereClause({
655
+ idType: adapterConfig.idType,
656
+ model: model,
657
+ where,
658
+ payload
659
+ });
660
+ debugLog([
661
+ "count",
662
+ {
663
+ collectionSlug,
664
+ payloadWhere
665
+ }
666
+ ]);
667
+ try {
668
+ const result = await payload.count({
669
+ collection: collectionSlug,
670
+ where: payloadWhere,
671
+ depth: PAYLOAD_QUERY_DEPTH,
672
+ context: createAdapterContext({
673
+ model,
674
+ operation: "count"
675
+ })
676
+ });
677
+ debugLog([
678
+ "count result",
679
+ {
680
+ collectionSlug,
681
+ result: {
682
+ totalDocs: result.totalDocs
683
+ },
684
+ duration: `${Date.now() - start}ms`
685
+ }
686
+ ]);
687
+ return result.totalDocs;
688
+ } catch (error) {
689
+ if (error instanceof Error && "status" in error && error.status === 404) {
690
+ return 0;
691
+ }
692
+ errorLog([
693
+ "Error in count: ",
694
+ error
695
+ ]);
696
+ return 0;
697
+ }
698
+ },
699
+ createSchema: async (options, file)=>{
700
+ const schemaCode = await generateSchema(options);
701
+ return {
702
+ code: schemaCode,
703
+ path: file || "schema.ts",
704
+ append: false,
705
+ overwrite: true
706
+ };
707
+ },
708
+ options: {
709
+ adapterConfig: {},
710
+ ...adapterConfig
711
+ }
712
+ };
713
+ };
714
+ };
715
+ export { generateSchema, payloadAdapter };
716
+
717
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9hZGFwdGVyL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERCQWRhcHRlciB9IGZyb20gXCJAYmV0dGVyLWF1dGgvY29yZS9kYi9hZGFwdGVyXCI7XG5pbXBvcnQgdHlwZSB7IEJldHRlckF1dGhPcHRpb25zLCBXaGVyZSB9IGZyb20gXCJiZXR0ZXItYXV0aFwiO1xuaW1wb3J0IHsgQmV0dGVyQXV0aEVycm9yIH0gZnJvbSBcImJldHRlci1hdXRoXCI7XG5pbXBvcnQgeyBNb2RlbEtleSB9IGZyb20gXCIuLi9nZW5lcmF0ZWQtdHlwZXNcIjtcbmltcG9ydCB7IGdlbmVyYXRlU2NoZW1hIH0gZnJvbSBcIi4vZ2VuZXJhdGUtc2NoZW1hXCI7XG5pbXBvcnQgeyBjcmVhdGVUcmFuc2Zvcm0gfSBmcm9tIFwiLi90cmFuc2Zvcm1cIjtcbmltcG9ydCB0eXBlIHsgUGF5bG9hZEFkYXB0ZXIgfSBmcm9tIFwiLi90eXBlc1wiO1xuXG5leHBvcnQgY29uc3QgQkVUVEVSX0FVVEhfQ09OVEVYVF9LRVkgPSBcInBheWxvYWQtZGItYWRhcHRlclwiO1xuY29uc3QgUEFZTE9BRF9RVUVSWV9ERVBUSCA9IDE7XG5jb25zdCBDUkVBVEVfUVVFUllfREVQVEggPSAwO1xuXG4vKiogQmV0dGVyIEF1dGggam9pbiBvcHRpb24gdHlwZSAobm90IGV4cG9ydGVkIGZyb20gYmV0dGVyLWF1dGggeWV0KSAqL1xudHlwZSBKb2luT3B0aW9uID0ge1xuICBbbW9kZWxLZXk6IHN0cmluZ106XG4gICAgfCBib29sZWFuXG4gICAgfCB7XG4gICAgICAgIGxpbWl0PzogbnVtYmVyO1xuICAgICAgfTtcbn07XG5cbi8qKlxuICogUGF5bG9hZCBhZGFwdGVyIGZvciBCZXR0ZXIgQXV0aC5cbiAqXG4gKiBUaGlzIGFkYXB0ZXIgY29ubmVjdHMgQmV0dGVyIEF1dGggdG8gUGF5bG9hZCBDTVMsIGFsbG93aW5nIGF1dGhlbnRpY2F0aW9uXG4gKiBvcGVyYXRpb25zIHRvIGJlIHBlcmZvcm1lZCBhZ2FpbnN0IFBheWxvYWQgY29sbGVjdGlvbnMuXG4gKlxuICogQHBhcmFtIHBheWxvYWRDbGllbnQgLSBUaGUgUGF5bG9hZCBDTVMgY2xpZW50IGluc3RhbmNlIG9yIGEgZnVuY3Rpb24gdGhhdCByZXR1cm5zIGl0XG4gKiBAcGFyYW0gY29uZmlnIC0gQ29uZmlndXJhdGlvbiBvcHRpb25zIGZvciB0aGUgYWRhcHRlclxuICogQHJldHVybnMgQSBmdW5jdGlvbiB0aGF0IGNyZWF0ZXMgYSBCZXR0ZXIgQXV0aCBhZGFwdGVyXG4gKi9cbmNvbnN0IHBheWxvYWRBZGFwdGVyOiBQYXlsb2FkQWRhcHRlciA9ICh7IHBheWxvYWRDbGllbnQsIGFkYXB0ZXJDb25maWcgfSkgPT4ge1xuICAvKipcbiAgICogTG9ncyBkZWJ1ZyBtZXNzYWdlcyBpZiBkZWJ1ZyBsb2dnaW5nIGlzIGVuYWJsZWRcbiAgICogQHBhcmFtIG1lc3NhZ2UgLSBUaGUgbWVzc2FnZSB0byBsb2dcbiAgICovXG4gIGZ1bmN0aW9uIGRlYnVnTG9nKG1lc3NhZ2U6IGFueVtdKSB7XG4gICAgaWYgKGFkYXB0ZXJDb25maWcuZW5hYmxlRGVidWdMb2dzKSB7XG4gICAgICBjb25zb2xlLmxvZyhcIltwYXlsb2FkLWRiLWFkYXB0ZXJdXCIsIC4uLm1lc3NhZ2UpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBMb2dzIGVycm9yIG1lc3NhZ2VzXG4gICAqIEBwYXJhbSBtZXNzYWdlIC0gVGhlIGVycm9yIG1lc3NhZ2UgdG8gbG9nXG4gICAqL1xuICBmdW5jdGlvbiBlcnJvckxvZyhtZXNzYWdlOiBhbnlbXSkge1xuICAgIGNvbnNvbGUuZXJyb3IoYFtwYXlsb2FkLWRiLWFkYXB0ZXJdYCwgLi4ubWVzc2FnZSk7XG4gIH1cblxuICAvKipcbiAgICogVGhyb3dzIGFuIGVycm9yIHdoZW4gYSBjb2xsZWN0aW9uIHNsdWcgZG9lc24ndCBleGlzdFxuICAgKiBAcGFyYW0gbW9kZWwgLSBUaGUgbW9kZWwgbmFtZSB0aGF0IGNvdWxkbid0IGJlIGZvdW5kXG4gICAqIEB0aHJvd3Mge0JldHRlckF1dGhFcnJvcn0gV2hlbiB0aGUgY29sbGVjdGlvbiBkb2Vzbid0IGV4aXN0XG4gICAqIEByZXR1cm5zIE5ldmVyIC0gRnVuY3Rpb24gYWx3YXlzIHRocm93c1xuICAgKi9cbiAgZnVuY3Rpb24gY29sbGVjdGlvblNsdWdFcnJvcihtb2RlbDogc3RyaW5nKTogbmV2ZXIge1xuICAgIHRocm93IG5ldyBCZXR0ZXJBdXRoRXJyb3IoXG4gICAgICBgQ29sbGVjdGlvbiAke21vZGVsfSBkb2VzIG5vdCBleGlzdC4gUGxlYXNlIGNoZWNrIHlvdXIgcGF5bG9hZCBjb2xsZWN0aW9uIHNsdWdzIG1hdGNoIHRoZSBiZXR0ZXIgYXV0aCBzY2hlbWFgXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBWYWxpZGF0ZXMgdGhhdCBhIGNvbGxlY3Rpb24gZXhpc3RzIGluIFBheWxvYWRcbiAgICogQHBhcmFtIHBheWxvYWQgLSBUaGUgUGF5bG9hZCBjbGllbnQgaW5zdGFuY2VcbiAgICogQHBhcmFtIGNvbGxlY3Rpb25TbHVnIC0gVGhlIGNvbGxlY3Rpb24gc2x1ZyB0byB2YWxpZGF0ZVxuICAgKiBAcGFyYW0gbW9kZWwgLSBUaGUgbW9kZWwgbmFtZSBmb3IgZXJyb3IgbWVzc2FnZXNcbiAgICogQHRocm93cyB7QmV0dGVyQXV0aEVycm9yfSBXaGVuIHRoZSBjb2xsZWN0aW9uIGRvZXNuJ3QgZXhpc3RcbiAgICovXG4gIGFzeW5jIGZ1bmN0aW9uIHZhbGlkYXRlQ29sbGVjdGlvbihcbiAgICBwYXlsb2FkOiBhbnksXG4gICAgY29sbGVjdGlvblNsdWc6IHN0cmluZyxcbiAgICBtb2RlbDogc3RyaW5nXG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIGlmICghY29sbGVjdGlvblNsdWcgfHwgIShjb2xsZWN0aW9uU2x1ZyBpbiBwYXlsb2FkLmNvbGxlY3Rpb25zKSkge1xuICAgICAgY29sbGVjdGlvblNsdWdFcnJvcihtb2RlbCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBjb250ZXh0IG9iamVjdCBmb3IgUGF5bG9hZCBvcGVyYXRpb25zXG4gICAqIEBwYXJhbSBkYXRhIC0gRGF0YSB0byBpbmNsdWRlIGluIHRoZSBjb250ZXh0XG4gICAqIEByZXR1cm5zIFRoZSBjb250ZXh0IG9iamVjdCB3aXRoIEJldHRlciBBdXRoIG1ldGFkYXRhXG4gICAqL1xuICBjb25zdCBjcmVhdGVBZGFwdGVyQ29udGV4dCA9IChkYXRhOiBSZWNvcmQ8c3RyaW5nLCBhbnk+KSA9PiAoe1xuICAgIFtCRVRURVJfQVVUSF9DT05URVhUX0tFWV06IHsgLi4uZGF0YSB9XG4gIH0pO1xuXG4gIC8qKlxuICAgKiBSZXNvbHZlcyB0aGUgUGF5bG9hZCBjbGllbnQsIGhhbmRsaW5nIGJvdGggZnVuY3Rpb24gYW5kIGRpcmVjdCByZWZlcmVuY2VzXG4gICAqIEByZXR1cm5zIFRoZSByZXNvbHZlZCBQYXlsb2FkIGNsaWVudFxuICAgKiBAdGhyb3dzIHtCZXR0ZXJBdXRoRXJyb3J9IFdoZW4gQmV0dGVyIEF1dGggcGx1Z2luIGlzIG5vdCBjb25maWd1cmVkXG4gICAqL1xuICBhc3luYyBmdW5jdGlvbiByZXNvbHZlUGF5bG9hZENsaWVudCgpIHtcbiAgICBjb25zdCBwYXlsb2FkID1cbiAgICAgIHR5cGVvZiBwYXlsb2FkQ2xpZW50ID09PSBcImZ1bmN0aW9uXCJcbiAgICAgICAgPyBhd2FpdCBwYXlsb2FkQ2xpZW50KClcbiAgICAgICAgOiBhd2FpdCBwYXlsb2FkQ2xpZW50O1xuICAgIGlmICghcGF5bG9hZC5jb25maWc/LmN1c3RvbT8uaGFzQmV0dGVyQXV0aFBsdWdpbikge1xuICAgICAgdGhyb3cgbmV3IEJldHRlckF1dGhFcnJvcihcbiAgICAgICAgYFBheWxvYWQgaXMgbm90IGNvbmZpZ3VyZWQgd2l0aCB0aGUgYmV0dGVyLWF1dGggcGx1Z2luLiBQbGVhc2UgYWRkIHRoZSBwbHVnaW4gdG8geW91ciBwYXlsb2FkIGNvbmZpZy5gXG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gcGF5bG9hZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGFuZCByZXR1cm5zIGEgQmV0dGVyIEF1dGggYWRhcHRlciBmb3IgUGF5bG9hZFxuICAgKiBAcGFyYW0gb3B0aW9ucyAtIEJldHRlciBBdXRoIG9wdGlvbnNcbiAgICogQHJldHVybnMgQSBCZXR0ZXIgQXV0aCBhZGFwdGVyIGltcGxlbWVudGF0aW9uXG4gICAqL1xuICByZXR1cm4gKG9wdGlvbnM6IEJldHRlckF1dGhPcHRpb25zKTogREJBZGFwdGVyID0+IHtcbiAgICBjb25zdCB7XG4gICAgICB0cmFuc2Zvcm1JbnB1dCxcbiAgICAgIHRyYW5zZm9ybU91dHB1dCxcbiAgICAgIGNvbnZlcnRXaGVyZUNsYXVzZSxcbiAgICAgIGNvbnZlcnRTZWxlY3QsXG4gICAgICBjb252ZXJ0U29ydCxcbiAgICAgIGdldENvbGxlY3Rpb25TbHVnLFxuICAgICAgc2luZ2xlSWRRdWVyeVxuICAgIH0gPSBjcmVhdGVUcmFuc2Zvcm0ob3B0aW9ucywgYWRhcHRlckNvbmZpZy5lbmFibGVEZWJ1Z0xvZ3MgPz8gZmFsc2UpO1xuXG4gICAgZnVuY3Rpb24gZ2V0Sm9pbkZpZWxkTmFtZXMocGF5bG9hZDogYW55LCBjb2xsZWN0aW9uU2x1Zzogc3RyaW5nKSB7XG4gICAgICBjb25zdCBjb2xsZWN0aW9uID0gcGF5bG9hZC5jb2xsZWN0aW9ucz8uW2NvbGxlY3Rpb25TbHVnXT8uY29uZmlnO1xuICAgICAgaWYgKCFjb2xsZWN0aW9uPy5mbGF0dGVuZWRGaWVsZHMpIHJldHVybiBuZXcgU2V0PHN0cmluZz4oKTtcbiAgICAgIHJldHVybiBuZXcgU2V0KFxuICAgICAgICBjb2xsZWN0aW9uLmZsYXR0ZW5lZEZpZWxkc1xuICAgICAgICAgIC5maWx0ZXIoKGY6IGFueSkgPT4gZi50eXBlID09PSBcImpvaW5cIilcbiAgICAgICAgICAubWFwKChmOiBhbnkpID0+IGYubmFtZSlcbiAgICAgICk7XG4gICAgfVxuXG4gICAgZnVuY3Rpb24gYnVpbGRQYXlsb2FkSm9pbnMoXG4gICAgICBqb2luOiBKb2luT3B0aW9uIHwgdW5kZWZpbmVkLFxuICAgICAgcGF5bG9hZDogYW55LFxuICAgICAgY29sbGVjdGlvblNsdWc6IHN0cmluZ1xuICAgICkge1xuICAgICAgaWYgKCFqb2luKSByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgY29uc3QgYWxsb3dlZEpvaW5GaWVsZHMgPSBnZXRKb2luRmllbGROYW1lcyhwYXlsb2FkLCBjb2xsZWN0aW9uU2x1Zyk7XG4gICAgICBjb25zdCBqb2luczogUmVjb3JkPHN0cmluZywgYW55PiA9IHt9O1xuXG4gICAgICBPYmplY3QuZW50cmllcyhqb2luKS5mb3JFYWNoKChbbW9kZWxLZXksIGNvbmZpZ10pID0+IHtcbiAgICAgICAgaWYgKGNvbmZpZyA9PT0gZmFsc2UpIHJldHVybjtcblxuICAgICAgICAvLyBUcmFuc2xhdGUgQmV0dGVyIEF1dGggbW9kZWwga2V5IChlLmcuICdhY2NvdW50JykgdG8gUGF5bG9hZCBqb2luIGZpZWxkIG5hbWUgKGUuZy4gJ2FjY291bnRzJylcbiAgICAgICAgY29uc3Qgam9pbkZpZWxkTmFtZSA9IGdldENvbGxlY3Rpb25TbHVnKG1vZGVsS2V5IGFzIE1vZGVsS2V5KTtcblxuICAgICAgICBpZiAoIWFsbG93ZWRKb2luRmllbGRzLmhhcyhqb2luRmllbGROYW1lKSkge1xuICAgICAgICAgIGRlYnVnTG9nKFtcbiAgICAgICAgICAgIGBqb2luIHNraXBwZWQ6IG5vIGpvaW4gZmllbGQgJyR7am9pbkZpZWxkTmFtZX0nIChmcm9tIG1vZGVsICcke21vZGVsS2V5fScpIG9uICR7Y29sbGVjdGlvblNsdWd9YFxuICAgICAgICAgIF0pO1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChjb25maWcgPT09IHRydWUpIHtcbiAgICAgICAgICBqb2luc1tqb2luRmllbGROYW1lXSA9IHt9O1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBpZiAoY29uZmlnICYmIHR5cGVvZiBjb25maWcgPT09IFwib2JqZWN0XCIpIHtcbiAgICAgICAgICBqb2luc1tqb2luRmllbGROYW1lXSA9IHsgLi4uY29uZmlnIH07XG4gICAgICAgIH1cbiAgICAgIH0pO1xuXG4gICAgICByZXR1cm4gT2JqZWN0LmtleXMoam9pbnMpLmxlbmd0aCA/IGpvaW5zIDogdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICBpZDogXCJwYXlsb2FkLWFkYXB0ZXJcIixcbiAgICAgIGFzeW5jIHRyYW5zYWN0aW9uPFI+KFxuICAgICAgICBjYWxsYmFjazogKHR4OiBPbWl0PERCQWRhcHRlciwgXCJ0cmFuc2FjdGlvblwiPikgPT4gUHJvbWlzZTxSPlxuICAgICAgKTogUHJvbWlzZTxSPiB7XG4gICAgICAgIHJldHVybiBhd2FpdCBjYWxsYmFjayh0aGlzKTtcbiAgICAgIH0sXG4gICAgICBhc3luYyBjcmVhdGU8VCBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4sIFIgPSBUPih7XG4gICAgICAgIG1vZGVsLFxuICAgICAgICBkYXRhOiB2YWx1ZXMsXG4gICAgICAgIHNlbGVjdFxuICAgICAgfToge1xuICAgICAgICBtb2RlbDogc3RyaW5nO1xuICAgICAgICBkYXRhOiBUO1xuICAgICAgICBzZWxlY3Q/OiBzdHJpbmdbXTtcbiAgICAgIH0pOiBQcm9taXNlPFI+IHtcbiAgICAgICAgY29uc3Qgc3RhcnQgPSBEYXRlLm5vdygpO1xuICAgICAgICBjb25zdCBwYXlsb2FkID0gYXdhaXQgcmVzb2x2ZVBheWxvYWRDbGllbnQoKTtcbiAgICAgICAgY29uc3QgY29sbGVjdGlvblNsdWcgPSBnZXRDb2xsZWN0aW9uU2x1Zyhtb2RlbCBhcyBNb2RlbEtleSk7XG5cbiAgICAgICAgLy8gVmFsaWRhdGUgY29sbGVjdGlvbiBleGlzdHMgYmVmb3JlIHByb2NlZWRpbmdcbiAgICAgICAgYXdhaXQgdmFsaWRhdGVDb2xsZWN0aW9uKHBheWxvYWQsIGNvbGxlY3Rpb25TbHVnLCBtb2RlbCk7XG5cbiAgICAgICAgY29uc3QgdHJhbnNmb3JtZWRJbnB1dCA9IHRyYW5zZm9ybUlucHV0KHtcbiAgICAgICAgICBkYXRhOiB2YWx1ZXMsXG4gICAgICAgICAgbW9kZWw6IG1vZGVsIGFzIE1vZGVsS2V5LFxuICAgICAgICAgIGlkVHlwZTogYWRhcHRlckNvbmZpZy5pZFR5cGUsXG4gICAgICAgICAgcGF5bG9hZFxuICAgICAgICB9KTtcblxuICAgICAgICBkZWJ1Z0xvZyhbXCJjcmVhdGVcIiwgeyBjb2xsZWN0aW9uU2x1ZywgdHJhbnNmb3JtZWRJbnB1dCwgc2VsZWN0IH1dKTtcblxuICAgICAgICB0cnkge1xuICAgICAgICAgIC8vIFVzZSBkZXB0aDogMCBmb3IgY3JlYXRlIHRvIGF2b2lkIHBvcHVsYXRpbmcgcmVsYXRpb25zaGlwIGZpZWxkcy5cbiAgICAgICAgICAvLyBQb3B1bGF0ZWQgcmVsYXRpb25zaGlwcyB3b3VsZCBibG9hdCB0aGUgc2Vzc2lvbiBkYXRhIHN0b3JlZCBpbiBjb29raWUgY2FjaGUuXG4gICAgICAgICAgLy8gVGhpcyBuZWVkcyBtb3JlIHRlc3RpbmcgYW5kIHZhbGlkYXRpb24uXG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgcGF5bG9hZC5jcmVhdGUoe1xuICAgICAgICAgICAgY29sbGVjdGlvbjogY29sbGVjdGlvblNsdWcsXG4gICAgICAgICAgICBkYXRhOiB0cmFuc2Zvcm1lZElucHV0LFxuICAgICAgICAgICAgc2VsZWN0OiBjb252ZXJ0U2VsZWN0KG1vZGVsIGFzIE1vZGVsS2V5LCBzZWxlY3QpLFxuICAgICAgICAgICAgY29udGV4dDogY3JlYXRlQWRhcHRlckNvbnRleHQoeyBtb2RlbCwgb3BlcmF0aW9uOiBcImNyZWF0ZVwiIH0pLFxuICAgICAgICAgICAgZGVwdGg6IENSRUFURV9RVUVSWV9ERVBUSFxuICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgY29uc3QgdHJhbnNmb3JtZWRSZXN1bHQgPSB0cmFuc2Zvcm1PdXRwdXQoe1xuICAgICAgICAgICAgZG9jOiByZXN1bHQsXG4gICAgICAgICAgICBtb2RlbDogbW9kZWwgYXMgTW9kZWxLZXksXG4gICAgICAgICAgICBwYXlsb2FkXG4gICAgICAgICAgfSk7XG5cbiAgICAgICAgICBkZWJ1Z0xvZyhbXG4gICAgICAgICAgICBcImNyZWF0ZSByZXN1bHRcIixcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgY29sbGVjdGlvblNsdWcsXG4gICAgICAgICAgICAgIHRyYW5zZm9ybWVkUmVzdWx0LFxuICAgICAgICAgICAgICBkdXJhdGlvbjogYCR7RGF0ZS5ub3coKSAtIHN0YXJ0fW1zYFxuICAgICAgICAgICAgfVxuICAgICAgICAgIF0pO1xuXG4gICAgICAgICAgcmV0dXJuIHRyYW5zZm9ybWVkUmVzdWx0IGFzIFI7XG4gICAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgICAgZXJyb3JMb2coW1wiRXJyb3IgaW4gY3JlYXRpbmc6XCIsIG1vZGVsLCBlcnJvcl0pO1xuICAgICAgICAgIHJldHVybiBudWxsIGFzIFI7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBhc3luYyBmaW5kT25lPFI+KHtcbiAgICAgICAgbW9kZWwsXG4gICAgICAgIHdoZXJlLFxuICAgICAgICBzZWxlY3QsXG4gICAgICAgIGpvaW5cbiAgICAgIH06IHtcbiAgICAgICAgbW9kZWw6IHN0cmluZztcbiAgICAgICAgd2hlcmU6IFdoZXJlW107XG4gICAgICAgIHNlbGVjdD86IHN0cmluZ1tdO1xuICAgICAgICBqb2luPzogSm9pbk9wdGlvbjtcbiAgICAgIH0pOiBQcm9taXNlPFIgfCBudWxsPiB7XG4gICAgICAgIGNvbnN0IHN0YXJ0ID0gRGF0ZS5ub3coKTtcbiAgICAgICAgY29uc3QgcGF5bG9hZCA9IGF3YWl0IHJlc29sdmVQYXlsb2FkQ2xpZW50KCk7XG4gICAgICAgIGNvbnN0IGNvbGxlY3Rpb25TbHVnID0gZ2V0Q29sbGVjdGlvblNsdWcobW9kZWwgYXMgTW9kZWxLZXkpO1xuXG4gICAgICAgIC8vIFZhbGlkYXRlIGNvbGxlY3Rpb24gZXhpc3RzIGJlZm9yZSBwcm9jZWVkaW5nXG4gICAgICAgIGF3YWl0IHZhbGlkYXRlQ29sbGVjdGlvbihwYXlsb2FkLCBjb2xsZWN0aW9uU2x1ZywgbW9kZWwpO1xuXG4gICAgICAgIGNvbnN0IHBheWxvYWRXaGVyZSA9IGNvbnZlcnRXaGVyZUNsYXVzZSh7XG4gICAgICAgICAgaWRUeXBlOiBhZGFwdGVyQ29uZmlnLmlkVHlwZSxcbiAgICAgICAgICBtb2RlbDogbW9kZWwgYXMgTW9kZWxLZXksXG4gICAgICAgICAgd2hlcmUsXG4gICAgICAgICAgcGF5bG9hZFxuICAgICAgICB9KTtcblxuICAgICAgICBkZWJ1Z0xvZyhbXCJmaW5kT25lXCIsIHsgY29sbGVjdGlvblNsdWcsIGpvaW4gfV0pO1xuXG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3Qgc2luZ2xlSWQgPSBzaW5nbGVJZFF1ZXJ5KHBheWxvYWRXaGVyZSk7XG4gICAgICAgICAgbGV0IHJlc3VsdDogUmVjb3JkPHN0cmluZywgYW55PiB8IG51bGwgPSBudWxsO1xuICAgICAgICAgIGNvbnN0IHBheWxvYWRKb2lucyA9IGJ1aWxkUGF5bG9hZEpvaW5zKGpvaW4sIHBheWxvYWQsIGNvbGxlY3Rpb25TbHVnKTtcblxuICAgICAgICAgIGlmIChzaW5nbGVJZCkge1xuICAgICAgICAgICAgZGVidWdMb2coW1wiZmluZE9uZUJ5SURcIiwgeyBjb2xsZWN0aW9uU2x1ZywgaWQ6IHNpbmdsZUlkIH1dKTtcbiAgICAgICAgICAgIHJlc3VsdCA9IGF3YWl0IHBheWxvYWQuZmluZEJ5SUQoe1xuICAgICAgICAgICAgICBjb2xsZWN0aW9uOiBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgICAgaWQ6IHNpbmdsZUlkLFxuICAgICAgICAgICAgICBzZWxlY3Q6IGNvbnZlcnRTZWxlY3QobW9kZWwgYXMgTW9kZWxLZXksIHNlbGVjdCksXG4gICAgICAgICAgICAgIC4uLihwYXlsb2FkSm9pbnMgJiZcbiAgICAgICAgICAgICAgICBPYmplY3Qua2V5cyhwYXlsb2FkSm9pbnMpLmxlbmd0aCA+IDAgJiYge1xuICAgICAgICAgICAgICAgICAgam9pbnM6IHBheWxvYWRKb2luc1xuICAgICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgICBjb250ZXh0OiBjcmVhdGVBZGFwdGVyQ29udGV4dCh7XG4gICAgICAgICAgICAgICAgbW9kZWwsXG4gICAgICAgICAgICAgICAgb3BlcmF0aW9uOiBcImZpbmRPbmVCeUlEXCJcbiAgICAgICAgICAgICAgfSksXG4gICAgICAgICAgICAgIGRlcHRoOiBQQVlMT0FEX1FVRVJZX0RFUFRIXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgZGVidWdMb2coW1wiZmluZE9uZUJ5V2hlcmVcIiwgeyBjb2xsZWN0aW9uU2x1ZywgcGF5bG9hZFdoZXJlIH1dKTtcbiAgICAgICAgICAgIGNvbnN0IGRvY3MgPSBhd2FpdCBwYXlsb2FkLmZpbmQoe1xuICAgICAgICAgICAgICBjb2xsZWN0aW9uOiBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgICAgd2hlcmU6IHBheWxvYWRXaGVyZSxcbiAgICAgICAgICAgICAgc2VsZWN0OiBjb252ZXJ0U2VsZWN0KG1vZGVsIGFzIE1vZGVsS2V5LCBzZWxlY3QpLFxuICAgICAgICAgICAgICAuLi4ocGF5bG9hZEpvaW5zICYmXG4gICAgICAgICAgICAgICAgT2JqZWN0LmtleXMocGF5bG9hZEpvaW5zKS5sZW5ndGggPiAwICYmIHtcbiAgICAgICAgICAgICAgICAgIGpvaW5zOiBwYXlsb2FkSm9pbnNcbiAgICAgICAgICAgICAgICB9KSxcbiAgICAgICAgICAgICAgY29udGV4dDogY3JlYXRlQWRhcHRlckNvbnRleHQoe1xuICAgICAgICAgICAgICAgIG1vZGVsLFxuICAgICAgICAgICAgICAgIG9wZXJhdGlvbjogXCJmaW5kT25lQnlXaGVyZVwiXG4gICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgICBkZXB0aDogUEFZTE9BRF9RVUVSWV9ERVBUSCxcbiAgICAgICAgICAgICAgbGltaXQ6IDFcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgcmVzdWx0ID0gZG9jcy5kb2NzWzBdO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IHRyYW5zZm9ybWVkUmVzdWx0ID0gdHJhbnNmb3JtT3V0cHV0PHR5cGVvZiByZXN1bHQgfCBudWxsPih7XG4gICAgICAgICAgICBkb2M6IHJlc3VsdCxcbiAgICAgICAgICAgIG1vZGVsOiBtb2RlbCBhcyBNb2RlbEtleSxcbiAgICAgICAgICAgIHBheWxvYWRcbiAgICAgICAgICB9KTtcblxuICAgICAgICAgIGRlYnVnTG9nKFtcbiAgICAgICAgICAgIFwiZmluZE9uZSByZXN1bHRcIixcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgY29sbGVjdGlvblNsdWcsXG4gICAgICAgICAgICAgIHRyYW5zZm9ybWVkUmVzdWx0LFxuICAgICAgICAgICAgICBkdXJhdGlvbjogYCR7RGF0ZS5ub3coKSAtIHN0YXJ0fW1zYFxuICAgICAgICAgICAgfVxuICAgICAgICAgIF0pO1xuXG4gICAgICAgICAgcmV0dXJuIHRyYW5zZm9ybWVkUmVzdWx0IGFzIFI7XG4gICAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgICAgaWYgKFxuICAgICAgICAgICAgZXJyb3IgaW5zdGFuY2VvZiBFcnJvciAmJlxuICAgICAgICAgICAgXCJzdGF0dXNcIiBpbiBlcnJvciAmJlxuICAgICAgICAgICAgZXJyb3Iuc3RhdHVzID09PSA0MDRcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgIH1cbiAgICAgICAgICBlcnJvckxvZyhbXCJFcnJvciBpbiBmaW5kT25lOiBcIiwgZXJyb3JdKTtcbiAgICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIGFzeW5jIGZpbmRNYW55PFI+KHtcbiAgICAgICAgbW9kZWwsXG4gICAgICAgIHdoZXJlLFxuICAgICAgICBsaW1pdCA9IDEwLFxuICAgICAgICBzb3J0QnksXG4gICAgICAgIG9mZnNldCA9IDAsXG4gICAgICAgIGpvaW5cbiAgICAgIH06IHtcbiAgICAgICAgbW9kZWw6IHN0cmluZztcbiAgICAgICAgd2hlcmU/OiBXaGVyZVtdO1xuICAgICAgICBsaW1pdD86IG51bWJlcjtcbiAgICAgICAgc29ydEJ5Pzoge1xuICAgICAgICAgIGZpZWxkOiBzdHJpbmc7XG4gICAgICAgICAgZGlyZWN0aW9uOiBcImFzY1wiIHwgXCJkZXNjXCI7XG4gICAgICAgIH07XG4gICAgICAgIG9mZnNldD86IG51bWJlcjtcbiAgICAgICAgam9pbj86IEpvaW5PcHRpb247XG4gICAgICB9KTogUHJvbWlzZTxSW10+IHtcbiAgICAgICAgY29uc3Qgc3RhcnQgPSBEYXRlLm5vdygpO1xuICAgICAgICBjb25zdCBwYXlsb2FkID0gYXdhaXQgcmVzb2x2ZVBheWxvYWRDbGllbnQoKTtcbiAgICAgICAgY29uc3QgY29sbGVjdGlvblNsdWcgPSBnZXRDb2xsZWN0aW9uU2x1Zyhtb2RlbCBhcyBNb2RlbEtleSk7XG5cbiAgICAgICAgLy8gVmFsaWRhdGUgY29sbGVjdGlvbiBleGlzdHMgYmVmb3JlIHByb2NlZWRpbmdcbiAgICAgICAgYXdhaXQgdmFsaWRhdGVDb2xsZWN0aW9uKHBheWxvYWQsIGNvbGxlY3Rpb25TbHVnLCBtb2RlbCk7XG5cbiAgICAgICAgY29uc3QgcGF5bG9hZFdoZXJlID0gY29udmVydFdoZXJlQ2xhdXNlKHtcbiAgICAgICAgICBpZFR5cGU6IGFkYXB0ZXJDb25maWcuaWRUeXBlLFxuICAgICAgICAgIG1vZGVsOiBtb2RlbCBhcyBNb2RlbEtleSxcbiAgICAgICAgICB3aGVyZSxcbiAgICAgICAgICBwYXlsb2FkXG4gICAgICAgIH0pO1xuXG4gICAgICAgIGRlYnVnTG9nKFtcImZpbmRNYW55XCIsIHsgY29sbGVjdGlvblNsdWcsIHNvcnRCeSwgbGltaXQsIG9mZnNldCB9XSk7XG5cbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBsZXQgcmVzdWx0OiB7XG4gICAgICAgICAgICBkb2NzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+W107XG4gICAgICAgICAgICB0b3RhbERvY3M6IG51bWJlcjtcbiAgICAgICAgICB9IHwgbnVsbCA9IG51bGw7XG5cbiAgICAgICAgICBjb25zdCBzaW5nbGVJZCA9IHNpbmdsZUlkUXVlcnkocGF5bG9hZFdoZXJlKTtcbiAgICAgICAgICBjb25zdCBwYXlsb2FkSm9pbnMgPSBidWlsZFBheWxvYWRKb2lucyhqb2luLCBwYXlsb2FkLCBjb2xsZWN0aW9uU2x1Zyk7XG4gICAgICAgICAgaWYgKHNpbmdsZUlkKSB7XG4gICAgICAgICAgICBkZWJ1Z0xvZyhbXCJmaW5kTWFueUJ5U2luZ2xlSURcIiwgeyBjb2xsZWN0aW9uU2x1ZywgaWQ6IHNpbmdsZUlkIH1dKTtcbiAgICAgICAgICAgIGNvbnN0IGRvYyA9IGF3YWl0IHBheWxvYWQuZmluZEJ5SUQoe1xuICAgICAgICAgICAgICBjb2xsZWN0aW9uOiBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgICAgaWQ6IHNpbmdsZUlkLFxuICAgICAgICAgICAgICAuLi4ocGF5bG9hZEpvaW5zICYmXG4gICAgICAgICAgICAgICAgT2JqZWN0LmtleXMocGF5bG9hZEpvaW5zKS5sZW5ndGggPiAwICYmIHtcbiAgICAgICAgICAgICAgICAgIGpvaW5zOiBwYXlsb2FkSm9pbnNcbiAgICAgICAgICAgICAgICB9KSxcbiAgICAgICAgICAgICAgZGVwdGg6IFBBWUxPQURfUVVFUllfREVQVEgsXG4gICAgICAgICAgICAgIGNvbnRleHQ6IGNyZWF0ZUFkYXB0ZXJDb250ZXh0KHtcbiAgICAgICAgICAgICAgICBtb2RlbCxcbiAgICAgICAgICAgICAgICBvcGVyYXRpb246IFwiZmluZE1hbnlCeVNpbmdsZUlEXCJcbiAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgcmVzdWx0ID0geyBkb2NzOiBkb2MgPyBbZG9jXSA6IFtdLCB0b3RhbERvY3M6IGRvYyA/IDEgOiAwIH07XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGRlYnVnTG9nKFtcImZpbmRNYW55QnlXaGVyZVwiLCB7IGNvbGxlY3Rpb25TbHVnLCBwYXlsb2FkV2hlcmUgfV0pO1xuICAgICAgICAgICAgY29uc3Qgc3BpbGwgPSBvZmZzZXQgJSBsaW1pdDtcbiAgICAgICAgICAgIGNvbnN0IHBhZ2UgPSBNYXRoLmZsb29yKG9mZnNldCAvIGxpbWl0KSArIDE7XG4gICAgICAgICAgICBjb25zdCBmZXRjaExpbWl0ID0gc3BpbGwgPyBsaW1pdCArIHNwaWxsIDogbGltaXQ7XG5cbiAgICAgICAgICAgIGNvbnN0IHJlcyA9IGF3YWl0IHBheWxvYWQuZmluZCh7XG4gICAgICAgICAgICAgIGNvbGxlY3Rpb246IGNvbGxlY3Rpb25TbHVnLFxuICAgICAgICAgICAgICB3aGVyZTogcGF5bG9hZFdoZXJlLFxuICAgICAgICAgICAgICBsaW1pdDogZmV0Y2hMaW1pdCxcbiAgICAgICAgICAgICAgcGFnZTogcGFnZSxcbiAgICAgICAgICAgICAgc29ydDogY29udmVydFNvcnQobW9kZWwgYXMgTW9kZWxLZXksIHNvcnRCeSksXG4gICAgICAgICAgICAgIC4uLihwYXlsb2FkSm9pbnMgJiZcbiAgICAgICAgICAgICAgICBPYmplY3Qua2V5cyhwYXlsb2FkSm9pbnMpLmxlbmd0aCA+IDAgJiYge1xuICAgICAgICAgICAgICAgICAgam9pbnM6IHBheWxvYWRKb2luc1xuICAgICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgICBkZXB0aDogUEFZTE9BRF9RVUVSWV9ERVBUSCxcbiAgICAgICAgICAgICAgY29udGV4dDogY3JlYXRlQWRhcHRlckNvbnRleHQoe1xuICAgICAgICAgICAgICAgIG1vZGVsLFxuICAgICAgICAgICAgICAgIG9wZXJhdGlvbjogXCJmaW5kTWFueUJ5V2hlcmVcIlxuICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICByZXN1bHQgPSB7XG4gICAgICAgICAgICAgIGRvY3M6IHJlcy5kb2NzLnNsaWNlKHNwaWxsLCBzcGlsbCArIGxpbWl0KSxcbiAgICAgICAgICAgICAgdG90YWxEb2NzOiByZXMudG90YWxEb2NzXG4gICAgICAgICAgICB9O1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IHRyYW5zZm9ybWVkUmVzdWx0ID1cbiAgICAgICAgICAgIHJlc3VsdD8uZG9jcy5tYXAoKGRvYykgPT5cbiAgICAgICAgICAgICAgdHJhbnNmb3JtT3V0cHV0KHtcbiAgICAgICAgICAgICAgICBkb2MsXG4gICAgICAgICAgICAgICAgbW9kZWw6IG1vZGVsIGFzIE1vZGVsS2V5LFxuICAgICAgICAgICAgICAgIHBheWxvYWRcbiAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICkgPz8gW107XG5cbiAgICAgICAgICBkZWJ1Z0xvZyhbXG4gICAgICAgICAgICBcImZpbmRNYW55IHJlc3VsdFwiLFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgICAgdHJhbnNmb3JtZWRSZXN1bHQsXG4gICAgICAgICAgICAgIGR1cmF0aW9uOiBgJHtEYXRlLm5vdygpIC0gc3RhcnR9bXNgXG4gICAgICAgICAgICB9XG4gICAgICAgICAgXSk7XG5cbiAgICAgICAgICByZXR1cm4gdHJhbnNmb3JtZWRSZXN1bHQgYXMgUltdO1xuICAgICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICAgIGlmIChcbiAgICAgICAgICAgIGVycm9yIGluc3RhbmNlb2YgRXJyb3IgJiZcbiAgICAgICAgICAgIFwic3RhdHVzXCIgaW4gZXJyb3IgJiZcbiAgICAgICAgICAgIGVycm9yLnN0YXR1cyA9PT0gNDA0XG4gICAgICAgICAgKSB7XG4gICAgICAgICAgICByZXR1cm4gW10gYXMgUltdO1xuICAgICAgICAgIH1cbiAgICAgICAgICBlcnJvckxvZyhbXCJFcnJvciBpbiBmaW5kTWFueTogXCIsIGVycm9yXSk7XG4gICAgICAgICAgcmV0dXJuIFtdIGFzIFJbXTtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICAgIGFzeW5jIHVwZGF0ZTxSPih7XG4gICAgICAgIG1vZGVsLFxuICAgICAgICB3aGVyZSxcbiAgICAgICAgdXBkYXRlXG4gICAgICB9OiB7XG4gICAgICAgIG1vZGVsOiBzdHJpbmc7XG4gICAgICAgIHdoZXJlOiBXaGVyZVtdO1xuICAgICAgICB1cGRhdGU6IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuICAgICAgfSk6IFByb21pc2U8UiB8IG51bGw+IHtcbiAgICAgICAgY29uc3Qgc3RhcnQgPSBEYXRlLm5vdygpO1xuICAgICAgICBjb25zdCBwYXlsb2FkID0gYXdhaXQgcmVzb2x2ZVBheWxvYWRDbGllbnQoKTtcbiAgICAgICAgY29uc3QgY29sbGVjdGlvblNsdWcgPSBnZXRDb2xsZWN0aW9uU2x1Zyhtb2RlbCBhcyBNb2RlbEtleSk7XG5cbiAgICAgICAgLy8gVmFsaWRhdGUgY29sbGVjdGlvbiBleGlzdHMgYmVmb3JlIHByb2NlZWRpbmdcbiAgICAgICAgYXdhaXQgdmFsaWRhdGVDb2xsZWN0aW9uKHBheWxvYWQsIGNvbGxlY3Rpb25TbHVnLCBtb2RlbCk7XG5cbiAgICAgICAgY29uc3QgcGF5bG9hZFdoZXJlID0gY29udmVydFdoZXJlQ2xhdXNlKHtcbiAgICAgICAgICBpZFR5cGU6IGFkYXB0ZXJDb25maWcuaWRUeXBlLFxuICAgICAgICAgIG1vZGVsOiBtb2RlbCBhcyBNb2RlbEtleSxcbiAgICAgICAgICB3aGVyZSxcbiAgICAgICAgICBwYXlsb2FkXG4gICAgICAgIH0pO1xuXG4gICAgICAgIGNvbnN0IHRyYW5zZm9ybWVkSW5wdXQgPSB0cmFuc2Zvcm1JbnB1dCh7XG4gICAgICAgICAgZGF0YTogdXBkYXRlLFxuICAgICAgICAgIG1vZGVsOiBtb2RlbCBhcyBNb2RlbEtleSxcbiAgICAgICAgICBpZFR5cGU6IGFkYXB0ZXJDb25maWcuaWRUeXBlLFxuICAgICAgICAgIHBheWxvYWRcbiAgICAgICAgfSk7XG5cbiAgICAgICAgZGVidWdMb2coW1widXBkYXRlXCIsIHsgY29sbGVjdGlvblNsdWcsIHVwZGF0ZSB9XSk7XG5cbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBsZXQgcmVzdWx0OiBSZWNvcmQ8c3RyaW5nLCBhbnk+IHwgbnVsbCA9IG51bGw7XG4gICAgICAgICAgY29uc3QgaWQgPSBzaW5nbGVJZFF1ZXJ5KHBheWxvYWRXaGVyZSk7XG5cbiAgICAgICAgICBpZiAoaWQpIHtcbiAgICAgICAgICAgIGRlYnVnTG9nKFtcInVwZGF0ZUJ5SURcIiwgeyBjb2xsZWN0aW9uU2x1ZywgaWQgfV0pO1xuICAgICAgICAgICAgcmVzdWx0ID0gYXdhaXQgcGF5bG9hZC51cGRhdGUoe1xuICAgICAgICAgICAgICBjb2xsZWN0aW9uOiBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgICAgaWQsXG4gICAgICAgICAgICAgIGRhdGE6IHRyYW5zZm9ybWVkSW5wdXQsXG4gICAgICAgICAgICAgIGRlcHRoOiBQQVlMT0FEX1FVRVJZX0RFUFRILFxuICAgICAgICAgICAgICBjb250ZXh0OiBjcmVhdGVBZGFwdGVyQ29udGV4dCh7IG1vZGVsLCBvcGVyYXRpb246IFwidXBkYXRlQnlJRFwiIH0pXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgZGVidWdMb2coW1widXBkYXRlQnlXaGVyZVwiLCB7IGNvbGxlY3Rpb25TbHVnLCBwYXlsb2FkV2hlcmUgfV0pO1xuICAgICAgICAgICAgY29uc3QgZG9jID0gYXdhaXQgcGF5bG9hZC51cGRhdGUoe1xuICAgICAgICAgICAgICBjb2xsZWN0aW9uOiBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgICAgd2hlcmU6IHBheWxvYWRXaGVyZSxcbiAgICAgICAgICAgICAgZGF0YTogdHJhbnNmb3JtZWRJbnB1dCxcbiAgICAgICAgICAgICAgZGVwdGg6IFBBWUxPQURfUVVFUllfREVQVEgsXG4gICAgICAgICAgICAgIGNvbnRleHQ6IGNyZWF0ZUFkYXB0ZXJDb250ZXh0KHtcbiAgICAgICAgICAgICAgICBtb2RlbCxcbiAgICAgICAgICAgICAgICBvcGVyYXRpb246IFwidXBkYXRlQnlXaGVyZVwiXG4gICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIHJlc3VsdCA9IGRvYy5kb2NzWzBdO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IHRyYW5zZm9ybWVkUmVzdWx0ID0gdHJhbnNmb3JtT3V0cHV0PHR5cGVvZiByZXN1bHQgfCBudWxsPih7XG4gICAgICAgICAgICBkb2M6IHJlc3VsdCxcbiAgICAgICAgICAgIG1vZGVsOiBtb2RlbCBhcyBNb2RlbEtleSxcbiAgICAgICAgICAgIHBheWxvYWRcbiAgICAgICAgICB9KTtcblxuICAgICAgICAgIGRlYnVnTG9nKFtcbiAgICAgICAgICAgIFwidXBkYXRlLXJlc3VsdFwiLFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgICAgdHJhbnNmb3JtZWRSZXN1bHQsXG4gICAgICAgICAgICAgIGR1cmF0aW9uOiBgJHtEYXRlLm5vdygpIC0gc3RhcnR9bXNgXG4gICAgICAgICAgICB9XG4gICAgICAgICAgXSk7XG5cbiAgICAgICAgICByZXR1cm4gdHJhbnNmb3JtZWRSZXN1bHQgYXMgUjtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICBpZiAoXG4gICAgICAgICAgICBlcnJvciBpbnN0YW5jZW9mIEVycm9yICYmXG4gICAgICAgICAgICBcInN0YXR1c1wiIGluIGVycm9yICYmXG4gICAgICAgICAgICBlcnJvci5zdGF0dXMgPT09IDQwNFxuICAgICAgICAgICkge1xuICAgICAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICAgICAgfVxuICAgICAgICAgIGVycm9yTG9nKFtcIkVycm9yIGluIHVwZGF0ZTogXCIsIGVycm9yXSk7XG4gICAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBhc3luYyB1cGRhdGVNYW55KHtcbiAgICAgICAgbW9kZWwsXG4gICAgICAgIHdoZXJlLFxuICAgICAgICB1cGRhdGVcbiAgICAgIH06IHtcbiAgICAgICAgbW9kZWw6IHN0cmluZztcbiAgICAgICAgd2hlcmU6IFdoZXJlW107XG4gICAgICAgIHVwZGF0ZTogUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG4gICAgICB9KTogUHJvbWlzZTxudW1iZXI+IHtcbiAgICAgICAgY29uc3Qgc3RhcnQgPSBEYXRlLm5vdygpO1xuICAgICAgICBjb25zdCBwYXlsb2FkID0gYXdhaXQgcmVzb2x2ZVBheWxvYWRDbGllbnQoKTtcbiAgICAgICAgY29uc3QgY29sbGVjdGlvblNsdWcgPSBnZXRDb2xsZWN0aW9uU2x1Zyhtb2RlbCBhcyBNb2RlbEtleSk7XG5cbiAgICAgICAgLy8gVmFsaWRhdGUgY29sbGVjdGlvbiBleGlzdHMgYmVmb3JlIHByb2NlZWRpbmdcbiAgICAgICAgYXdhaXQgdmFsaWRhdGVDb2xsZWN0aW9uKHBheWxvYWQsIGNvbGxlY3Rpb25TbHVnLCBtb2RlbCk7XG5cbiAgICAgICAgY29uc3QgcGF5bG9hZFdoZXJlID0gY29udmVydFdoZXJlQ2xhdXNlKHtcbiAgICAgICAgICBpZFR5cGU6IGFkYXB0ZXJDb25maWcuaWRUeXBlLFxuICAgICAgICAgIG1vZGVsOiBtb2RlbCBhcyBNb2RlbEtleSxcbiAgICAgICAgICB3aGVyZSxcbiAgICAgICAgICBwYXlsb2FkXG4gICAgICAgIH0pO1xuXG4gICAgICAgIGNvbnN0IHRyYW5zZm9ybWVkSW5wdXQgPSB0cmFuc2Zvcm1JbnB1dCh7XG4gICAgICAgICAgZGF0YTogdXBkYXRlLFxuICAgICAgICAgIG1vZGVsOiBtb2RlbCBhcyBNb2RlbEtleSxcbiAgICAgICAgICBpZFR5cGU6IGFkYXB0ZXJDb25maWcuaWRUeXBlLFxuICAgICAgICAgIHBheWxvYWRcbiAgICAgICAgfSk7XG5cbiAgICAgICAgZGVidWdMb2coW1widXBkYXRlTWFueVwiLCB7IGNvbGxlY3Rpb25TbHVnLCBwYXlsb2FkV2hlcmUsIHVwZGF0ZSB9XSk7XG5cbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCB7IGRvY3M6IHVwZGF0ZVJlc3VsdCB9ID0gYXdhaXQgcGF5bG9hZC51cGRhdGUoe1xuICAgICAgICAgICAgY29sbGVjdGlvbjogY29sbGVjdGlvblNsdWcsXG4gICAgICAgICAgICB3aGVyZTogcGF5bG9hZFdoZXJlLFxuICAgICAgICAgICAgZGF0YTogdHJhbnNmb3JtZWRJbnB1dCxcbiAgICAgICAgICAgIGRlcHRoOiBQQVlMT0FEX1FVRVJZX0RFUFRILFxuICAgICAgICAgICAgY29udGV4dDogY3JlYXRlQWRhcHRlckNvbnRleHQoeyBtb2RlbCwgb3BlcmF0aW9uOiBcInVwZGF0ZU1hbnlcIiB9KVxuICAgICAgICAgIH0pO1xuXG4gICAgICAgICAgZGVidWdMb2coW1xuICAgICAgICAgICAgXCJ1cGRhdGVNYW55IHJlc3VsdFwiLFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgICAgcmVzdWx0OiB1cGRhdGVSZXN1bHQsXG4gICAgICAgICAgICAgIGR1cmF0aW9uOiBgJHtEYXRlLm5vdygpIC0gc3RhcnR9bXNgXG4gICAgICAgICAgICB9XG4gICAgICAgICAgXSk7XG5cbiAgICAgICAgICByZXR1cm4gdXBkYXRlUmVzdWx0Py5sZW5ndGggfHwgMDtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICBpZiAoXG4gICAgICAgICAgICBlcnJvciBpbnN0YW5jZW9mIEVycm9yICYmXG4gICAgICAgICAgICBcInN0YXR1c1wiIGluIGVycm9yICYmXG4gICAgICAgICAgICBlcnJvci5zdGF0dXMgPT09IDQwNFxuICAgICAgICAgICkge1xuICAgICAgICAgICAgcmV0dXJuIDA7XG4gICAgICAgICAgfVxuICAgICAgICAgIGVycm9yTG9nKFtcIkVycm9yIGluIHVwZGF0ZU1hbnk6IFwiLCBlcnJvcl0pO1xuICAgICAgICAgIHJldHVybiAwO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAgYXN5bmMgZGVsZXRlKHtcbiAgICAgICAgbW9kZWwsXG4gICAgICAgIHdoZXJlXG4gICAgICB9OiB7XG4gICAgICAgIG1vZGVsOiBzdHJpbmc7XG4gICAgICAgIHdoZXJlOiBXaGVyZVtdO1xuICAgICAgfSk6IFByb21pc2U8dm9pZD4ge1xuICAgICAgICBjb25zdCBzdGFydCA9IERhdGUubm93KCk7XG4gICAgICAgIGNvbnN0IHBheWxvYWQgPSBhd2FpdCByZXNvbHZlUGF5bG9hZENsaWVudCgpO1xuICAgICAgICBjb25zdCBjb2xsZWN0aW9uU2x1ZyA9IGdldENvbGxlY3Rpb25TbHVnKG1vZGVsIGFzIE1vZGVsS2V5KTtcblxuICAgICAgICAvLyBWYWxpZGF0ZSBjb2xsZWN0aW9uIGV4aXN0cyBiZWZvcmUgcHJvY2VlZGluZ1xuICAgICAgICBhd2FpdCB2YWxpZGF0ZUNvbGxlY3Rpb24ocGF5bG9hZCwgY29sbGVjdGlvblNsdWcsIG1vZGVsKTtcblxuICAgICAgICBjb25zdCBwYXlsb2FkV2hlcmUgPSBjb252ZXJ0V2hlcmVDbGF1c2Uoe1xuICAgICAgICAgIGlkVHlwZTogYWRhcHRlckNvbmZpZy5pZFR5cGUsXG4gICAgICAgICAgbW9kZWw6IG1vZGVsIGFzIE1vZGVsS2V5LFxuICAgICAgICAgIHdoZXJlLFxuICAgICAgICAgIHBheWxvYWRcbiAgICAgICAgfSk7XG5cbiAgICAgICAgZGVidWdMb2coW1wiZGVsZXRlXCIsIHsgY29sbGVjdGlvblNsdWcgfV0pO1xuXG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgbGV0IGRlbGV0ZVJlc3VsdDoge1xuICAgICAgICAgICAgZG9jOiBSZWNvcmQ8c3RyaW5nLCBhbnk+IHwgbnVsbDtcbiAgICAgICAgICAgIGVycm9yczogYW55W107XG4gICAgICAgICAgfSB8IG51bGwgPSBudWxsO1xuXG4gICAgICAgICAgY29uc3Qgc2luZ2xlSWQgPSBzaW5nbGVJZFF1ZXJ5KHBheWxvYWRXaGVyZSk7XG4gICAgICAgICAgaWYgKHNpbmdsZUlkKSB7XG4gICAgICAgICAgICBkZWJ1Z0xvZyhbXCJkZWxldGVCeUlEXCIsIHsgY29sbGVjdGlvblNsdWcsIGlkOiBzaW5nbGVJZCB9XSk7XG4gICAgICAgICAgICBjb25zdCBkb2MgPSBhd2FpdCBwYXlsb2FkLmRlbGV0ZSh7XG4gICAgICAgICAgICAgIGNvbGxlY3Rpb246IGNvbGxlY3Rpb25TbHVnLFxuICAgICAgICAgICAgICBpZDogc2luZ2xlSWQsXG4gICAgICAgICAgICAgIGRlcHRoOiBQQVlMT0FEX1FVRVJZX0RFUFRILFxuICAgICAgICAgICAgICBjb250ZXh0OiBjcmVhdGVBZGFwdGVyQ29udGV4dCh7IG1vZGVsLCBvcGVyYXRpb246IFwiZGVsZXRlQnlJRFwiIH0pXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIGRlbGV0ZVJlc3VsdCA9IHsgZG9jLCBlcnJvcnM6IFtdIH07XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGRlYnVnTG9nKFtcImRlbGV0ZUJ5V2hlcmVcIiwgeyBjb2xsZWN0aW9uU2x1ZywgcGF5bG9hZFdoZXJlIH1dKTtcbiAgICAgICAgICAgIGNvbnN0IGRvYyA9IGF3YWl0IHBheWxvYWQuZGVsZXRlKHtcbiAgICAgICAgICAgICAgY29sbGVjdGlvbjogY29sbGVjdGlvblNsdWcsXG4gICAgICAgICAgICAgIHdoZXJlOiBwYXlsb2FkV2hlcmUsXG4gICAgICAgICAgICAgIGRlcHRoOiBQQVlMT0FEX1FVRVJZX0RFUFRILFxuICAgICAgICAgICAgICBjb250ZXh0OiBjcmVhdGVBZGFwdGVyQ29udGV4dCh7XG4gICAgICAgICAgICAgICAgbW9kZWwsXG4gICAgICAgICAgICAgICAgb3BlcmF0aW9uOiBcImRlbGV0ZUJ5V2hlcmVcIlxuICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICBkZWxldGVSZXN1bHQgPSB7IGRvYzogZG9jLmRvY3NbMF0sIGVycm9yczogW10gfTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBkZWJ1Z0xvZyhbXG4gICAgICAgICAgICBcImRlbGV0ZSByZXN1bHRcIixcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgY29sbGVjdGlvblNsdWcsXG4gICAgICAgICAgICAgIHJlc3VsdDogZGVsZXRlUmVzdWx0LFxuICAgICAgICAgICAgICBkdXJhdGlvbjogYCR7RGF0ZS5ub3coKSAtIHN0YXJ0fW1zYFxuICAgICAgICAgICAgfVxuICAgICAgICAgIF0pO1xuICAgICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICAgIGlmIChcbiAgICAgICAgICAgIGVycm9yIGluc3RhbmNlb2YgRXJyb3IgJiZcbiAgICAgICAgICAgIFwic3RhdHVzXCIgaW4gZXJyb3IgJiZcbiAgICAgICAgICAgIGVycm9yLnN0YXR1cyA9PT0gNDA0XG4gICAgICAgICAgKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgfVxuICAgICAgICAgIGVycm9yTG9nKFtcIkVycm9yIGluIGRlbGV0ZTogXCIsIGVycm9yXSk7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBhc3luYyBkZWxldGVNYW55KHtcbiAgICAgICAgbW9kZWwsXG4gICAgICAgIHdoZXJlXG4gICAgICB9OiB7XG4gICAgICAgIG1vZGVsOiBzdHJpbmc7XG4gICAgICAgIHdoZXJlOiBXaGVyZVtdO1xuICAgICAgfSk6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgICAgIGNvbnN0IHN0YXJ0ID0gRGF0ZS5ub3coKTtcbiAgICAgICAgY29uc3QgcGF5bG9hZCA9IGF3YWl0IHJlc29sdmVQYXlsb2FkQ2xpZW50KCk7XG4gICAgICAgIGNvbnN0IGNvbGxlY3Rpb25TbHVnID0gZ2V0Q29sbGVjdGlvblNsdWcobW9kZWwgYXMgTW9kZWxLZXkpO1xuXG4gICAgICAgIC8vIFZhbGlkYXRlIGNvbGxlY3Rpb24gZXhpc3RzIGJlZm9yZSBwcm9jZWVkaW5nXG4gICAgICAgIGF3YWl0IHZhbGlkYXRlQ29sbGVjdGlvbihwYXlsb2FkLCBjb2xsZWN0aW9uU2x1ZywgbW9kZWwpO1xuXG4gICAgICAgIGNvbnN0IHBheWxvYWRXaGVyZSA9IGNvbnZlcnRXaGVyZUNsYXVzZSh7XG4gICAgICAgICAgaWRUeXBlOiBhZGFwdGVyQ29uZmlnLmlkVHlwZSxcbiAgICAgICAgICBtb2RlbDogbW9kZWwgYXMgTW9kZWxLZXksXG4gICAgICAgICAgd2hlcmUsXG4gICAgICAgICAgcGF5bG9hZFxuICAgICAgICB9KTtcblxuICAgICAgICBkZWJ1Z0xvZyhbXCJkZWxldGVNYW55XCIsIHsgY29sbGVjdGlvblNsdWcsIHBheWxvYWRXaGVyZSB9XSk7XG5cbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCBkZWxldGVSZXN1bHQgPSBhd2FpdCBwYXlsb2FkLmRlbGV0ZSh7XG4gICAgICAgICAgICBjb2xsZWN0aW9uOiBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgIHdoZXJlOiBwYXlsb2FkV2hlcmUsXG4gICAgICAgICAgICBkZXB0aDogUEFZTE9BRF9RVUVSWV9ERVBUSCxcbiAgICAgICAgICAgIGNvbnRleHQ6IGNyZWF0ZUFkYXB0ZXJDb250ZXh0KHsgbW9kZWwsIG9wZXJhdGlvbjogXCJkZWxldGVNYW55XCIgfSlcbiAgICAgICAgICB9KTtcblxuICAgICAgICAgIGRlYnVnTG9nKFtcbiAgICAgICAgICAgIFwiZGVsZXRlTWFueSByZXN1bHRcIixcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgY29sbGVjdGlvblNsdWcsXG4gICAgICAgICAgICAgIHJlc3VsdDogZGVsZXRlUmVzdWx0LFxuICAgICAgICAgICAgICBkdXJhdGlvbjogYCR7RGF0ZS5ub3coKSAtIHN0YXJ0fW1zYFxuICAgICAgICAgICAgfVxuICAgICAgICAgIF0pO1xuXG4gICAgICAgICAgcmV0dXJuIGRlbGV0ZVJlc3VsdC5kb2NzLmxlbmd0aDtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICBpZiAoXG4gICAgICAgICAgICBlcnJvciBpbnN0YW5jZW9mIEVycm9yICYmXG4gICAgICAgICAgICBcInN0YXR1c1wiIGluIGVycm9yICYmXG4gICAgICAgICAgICBlcnJvci5zdGF0dXMgPT09IDQwNFxuICAgICAgICAgICkge1xuICAgICAgICAgICAgcmV0dXJuIDA7XG4gICAgICAgICAgfVxuICAgICAgICAgIGVycm9yTG9nKFtcIkVycm9yIGluIGRlbGV0ZU1hbnk6IFwiLCBlcnJvcl0pO1xuICAgICAgICAgIHJldHVybiAwO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICAgYXN5bmMgY291bnQoe1xuICAgICAgICBtb2RlbCxcbiAgICAgICAgd2hlcmVcbiAgICAgIH06IHtcbiAgICAgICAgbW9kZWw6IHN0cmluZztcbiAgICAgICAgd2hlcmU/OiBXaGVyZVtdO1xuICAgICAgfSk6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgICAgIGNvbnN0IHN0YXJ0ID0gRGF0ZS5ub3coKTtcbiAgICAgICAgY29uc3QgcGF5bG9hZCA9IGF3YWl0IHJlc29sdmVQYXlsb2FkQ2xpZW50KCk7XG4gICAgICAgIGNvbnN0IGNvbGxlY3Rpb25TbHVnID0gZ2V0Q29sbGVjdGlvblNsdWcobW9kZWwgYXMgTW9kZWxLZXkpO1xuXG4gICAgICAgIC8vIFZhbGlkYXRlIGNvbGxlY3Rpb24gZXhpc3RzIGJlZm9yZSBwcm9jZWVkaW5nXG4gICAgICAgIGF3YWl0IHZhbGlkYXRlQ29sbGVjdGlvbihwYXlsb2FkLCBjb2xsZWN0aW9uU2x1ZywgbW9kZWwpO1xuXG4gICAgICAgIGNvbnN0IHBheWxvYWRXaGVyZSA9IGNvbnZlcnRXaGVyZUNsYXVzZSh7XG4gICAgICAgICAgaWRUeXBlOiBhZGFwdGVyQ29uZmlnLmlkVHlwZSxcbiAgICAgICAgICBtb2RlbDogbW9kZWwgYXMgTW9kZWxLZXksXG4gICAgICAgICAgd2hlcmUsXG4gICAgICAgICAgcGF5bG9hZFxuICAgICAgICB9KTtcblxuICAgICAgICBkZWJ1Z0xvZyhbXCJjb3VudFwiLCB7IGNvbGxlY3Rpb25TbHVnLCBwYXlsb2FkV2hlcmUgfV0pO1xuXG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgcGF5bG9hZC5jb3VudCh7XG4gICAgICAgICAgICBjb2xsZWN0aW9uOiBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgIHdoZXJlOiBwYXlsb2FkV2hlcmUsXG4gICAgICAgICAgICBkZXB0aDogUEFZTE9BRF9RVUVSWV9ERVBUSCxcbiAgICAgICAgICAgIGNvbnRleHQ6IGNyZWF0ZUFkYXB0ZXJDb250ZXh0KHsgbW9kZWwsIG9wZXJhdGlvbjogXCJjb3VudFwiIH0pXG4gICAgICAgICAgfSk7XG5cbiAgICAgICAgICBkZWJ1Z0xvZyhbXG4gICAgICAgICAgICBcImNvdW50IHJlc3VsdFwiLFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBjb2xsZWN0aW9uU2x1ZyxcbiAgICAgICAgICAgICAgcmVzdWx0OiB7IHRvdGFsRG9jczogcmVzdWx0LnRvdGFsRG9jcyB9LFxuICAgICAgICAgICAgICBkdXJhdGlvbjogYCR7RGF0ZS5ub3coKSAtIHN0YXJ0fW1zYFxuICAgICAgICAgICAgfVxuICAgICAgICAgIF0pO1xuXG4gICAgICAgICAgcmV0dXJuIHJlc3VsdC50b3RhbERvY3M7XG4gICAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgICAgaWYgKFxuICAgICAgICAgICAgZXJyb3IgaW5zdGFuY2VvZiBFcnJvciAmJlxuICAgICAgICAgICAgXCJzdGF0dXNcIiBpbiBlcnJvciAmJlxuICAgICAgICAgICAgZXJyb3Iuc3RhdHVzID09PSA0MDRcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIHJldHVybiAwO1xuICAgICAgICAgIH1cbiAgICAgICAgICBlcnJvckxvZyhbXCJFcnJvciBpbiBjb3VudDogXCIsIGVycm9yXSk7XG4gICAgICAgICAgcmV0dXJuIDA7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgICBjcmVhdGVTY2hlbWE6IGFzeW5jIChvcHRpb25zLCBmaWxlKSA9PiB7XG4gICAgICAgIGNvbnN0IHNjaGVtYUNvZGUgPSBhd2FpdCBnZW5lcmF0ZVNjaGVtYShvcHRpb25zKTtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBjb2RlOiBzY2hlbWFDb2RlLFxuICAgICAgICAgIHBhdGg6IGZpbGUgfHwgXCJzY2hlbWEudHNcIixcbiAgICAgICAgICBhcHBlbmQ6IGZhbHNlLFxuICAgICAgICAgIG92ZXJ3cml0ZTogdHJ1ZVxuICAgICAgICB9O1xuICAgICAgfSxcbiAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgYWRhcHRlckNvbmZpZzoge30gYXMgYW55LFxuICAgICAgICAuLi5hZGFwdGVyQ29uZmlnXG4gICAgICB9XG4gICAgfTtcbiAgfTtcbn07XG5cbmV4cG9ydCB7IGdlbmVyYXRlU2NoZW1hLCBwYXlsb2FkQWRhcHRlciB9O1xuIl0sIm5hbWVzIjpbIkJldHRlckF1dGhFcnJvciIsImdlbmVyYXRlU2NoZW1hIiwiY3JlYXRlVHJhbnNmb3JtIiwiQkVUVEVSX0FVVEhfQ09OVEVYVF9LRVkiLCJQQVlMT0FEX1FVRVJZX0RFUFRIIiwiQ1JFQVRFX1FVRVJZX0RFUFRIIiwicGF5bG9hZEFkYXB0ZXIiLCJwYXlsb2FkQ2xpZW50IiwiYWRhcHRlckNvbmZpZyIsImRlYnVnTG9nIiwibWVzc2FnZSIsImVuYWJsZURlYnVnTG9ncyIsImNvbnNvbGUiLCJsb2ciLCJlcnJvckxvZyIsImVycm9yIiwiY29sbGVjdGlvblNsdWdFcnJvciIsIm1vZGVsIiwidmFsaWRhdGVDb2xsZWN0aW9uIiwicGF5bG9hZCIsImNvbGxlY3Rpb25TbHVnIiwiY29sbGVjdGlvbnMiLCJjcmVhdGVBZGFwdGVyQ29udGV4dCIsImRhdGEiLCJyZXNvbHZlUGF5bG9hZENsaWVudCIsImNvbmZpZyIsImN1c3RvbSIsImhhc0JldHRlckF1dGhQbHVnaW4iLCJvcHRpb25zIiwidHJhbnNmb3JtSW5wdXQiLCJ0cmFuc2Zvcm1PdXRwdXQiLCJjb252ZXJ0V2hlcmVDbGF1c2UiLCJjb252ZXJ0U2VsZWN0IiwiY29udmVydFNvcnQiLCJnZXRDb2xsZWN0aW9uU2x1ZyIsInNpbmdsZUlkUXVlcnkiLCJnZXRKb2luRmllbGROYW1lcyIsImNvbGxlY3Rpb24iLCJmbGF0dGVuZWRGaWVsZHMiLCJTZXQiLCJmaWx0ZXIiLCJmIiwidHlwZSIsIm1hcCIsIm5hbWUiLCJidWlsZFBheWxvYWRKb2lucyIsImpvaW4iLCJ1bmRlZmluZWQiLCJhbGxvd2VkSm9pbkZpZWxkcyIsImpvaW5zIiwiT2JqZWN0IiwiZW50cmllcyIsImZvckVhY2giLCJtb2RlbEtleSIsImpvaW5GaWVsZE5hbWUiLCJoYXMiLCJrZXlzIiwibGVuZ3RoIiwiaWQiLCJ0cmFuc2FjdGlvbiIsImNhbGxiYWNrIiwiY3JlYXRlIiwidmFsdWVzIiwic2VsZWN0Iiwic3RhcnQiLCJEYXRlIiwibm93IiwidHJhbnNmb3JtZWRJbnB1dCIsImlkVHlwZSIsInJlc3VsdCIsImNvbnRleHQiLCJvcGVyYXRpb24iLCJkZXB0aCIsInRyYW5zZm9ybWVkUmVzdWx0IiwiZG9jIiwiZHVyYXRpb24iLCJmaW5kT25lIiwid2hlcmUiLCJwYXlsb2FkV2hlcmUiLCJzaW5nbGVJZCIsInBheWxvYWRKb2lucyIsImZpbmRCeUlEIiwiZG9jcyIsImZpbmQiLCJsaW1pdCIsIkVycm9yIiwic3RhdHVzIiwiZmluZE1hbnkiLCJzb3J0QnkiLCJvZmZzZXQiLCJ0b3RhbERvY3MiLCJzcGlsbCIsInBhZ2UiLCJNYXRoIiwiZmxvb3IiLCJmZXRjaExpbWl0IiwicmVzIiwic29ydCIsInNsaWNlIiwidXBkYXRlIiwidXBkYXRlTWFueSIsInVwZGF0ZVJlc3VsdCIsImRlbGV0ZSIsImRlbGV0ZVJlc3VsdCIsImVycm9ycyIsImRlbGV0ZU1hbnkiLCJjb3VudCIsImNyZWF0ZVNjaGVtYSIsImZpbGUiLCJzY2hlbWFDb2RlIiwiY29kZSIsInBhdGgiLCJhcHBlbmQiLCJvdmVyd3JpdGUiXSwibWFwcGluZ3MiOiJBQUVBLFNBQVNBLGVBQWUsUUFBUSxjQUFjO0FBRTlDLFNBQVNDLGNBQWMsUUFBUSxvQkFBb0I7QUFDbkQsU0FBU0MsZUFBZSxRQUFRLGNBQWM7QUFHOUMsT0FBTyxNQUFNQywwQkFBMEIscUJBQXFCO0FBQzVELE1BQU1DLHNCQUFzQjtBQUM1QixNQUFNQyxxQkFBcUI7QUFXM0I7Ozs7Ozs7OztDQVNDLEdBQ0QsTUFBTUMsaUJBQWlDLENBQUMsRUFBRUMsYUFBYSxFQUFFQyxhQUFhLEVBQUU7SUFDdEU7OztHQUdDLEdBQ0QsU0FBU0MsU0FBU0MsT0FBYztRQUM5QixJQUFJRixjQUFjRyxlQUFlLEVBQUU7WUFDakNDLFFBQVFDLEdBQUcsQ0FBQywyQkFBMkJIO1FBQ3pDO0lBQ0Y7SUFFQTs7O0dBR0MsR0FDRCxTQUFTSSxTQUFTSixPQUFjO1FBQzlCRSxRQUFRRyxLQUFLLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLTDtJQUMzQztJQUVBOzs7OztHQUtDLEdBQ0QsU0FBU00sb0JBQW9CQyxLQUFhO1FBQ3hDLE1BQU0sSUFBSWpCLGdCQUNSLENBQUMsV0FBVyxFQUFFaUIsTUFBTSx3RkFBd0YsQ0FBQztJQUVqSDtJQUVBOzs7Ozs7R0FNQyxHQUNELGVBQWVDLG1CQUNiQyxPQUFZLEVBQ1pDLGNBQXNCLEVBQ3RCSCxLQUFhO1FBRWIsSUFBSSxDQUFDRyxrQkFBa0IsQ0FBRUEsQ0FBQUEsa0JBQWtCRCxRQUFRRSxXQUFXLEFBQUQsR0FBSTtZQUMvREwsb0JBQW9CQztRQUN0QjtJQUNGO0lBRUE7Ozs7R0FJQyxHQUNELE1BQU1LLHVCQUF1QixDQUFDQyxPQUErQixDQUFBO1lBQzNELENBQUNwQix3QkFBd0IsRUFBRTtnQkFBRSxHQUFHb0IsSUFBSTtZQUFDO1FBQ3ZDLENBQUE7SUFFQTs7OztHQUlDLEdBQ0QsZUFBZUM7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