@kaspernj/api-maker 1.0.445 → 1.0.447

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 (361) hide show
  1. package/{.eslintrc.cjs → .eslintrc.js} +4 -0
  2. package/README.md +35 -0
  3. package/android/build.gradle +43 -0
  4. package/android/src/main/AndroidManifest.xml +2 -0
  5. package/android/src/main/java/expo/modules/api_maker/ApiMakerModule.kt +50 -0
  6. package/android/src/main/java/expo/modules/api_maker/ApiMakerView.kt +30 -0
  7. package/build/api.js +120 -0
  8. package/build/attribute-not-loaded-error.js +2 -0
  9. package/build/base-component.js +5 -0
  10. package/build/base-error.js +33 -0
  11. package/build/base-model/attribute.js +25 -0
  12. package/build/base-model/column.js +11 -0
  13. package/build/base-model/reflection.js +14 -0
  14. package/build/base-model/scope.js +11 -0
  15. package/build/base-model.js +828 -0
  16. package/build/bootstrap/attribute-row/index.js +105 -0
  17. package/build/bootstrap/attribute-rows.js +31 -0
  18. package/build/bootstrap/card.js +138 -0
  19. package/build/bootstrap/checkbox.js +97 -0
  20. package/build/bootstrap/checkboxes.js +183 -0
  21. package/build/bootstrap/index.js +2 -0
  22. package/build/bootstrap/input.js +128 -0
  23. package/build/bootstrap/invalid-feedback.js +27 -0
  24. package/build/bootstrap/paginate.js +150 -0
  25. package/build/bootstrap/radio-buttons.js +72 -0
  26. package/build/bootstrap/select.js +88 -0
  27. package/build/bootstrap/sort-link.js +130 -0
  28. package/build/cable-connection-pool.js +128 -0
  29. package/build/cable-subscription-pool.js +207 -0
  30. package/build/cable-subscription.js +21 -0
  31. package/build/cache-key-generator.js +81 -0
  32. package/build/can-can.js +134 -0
  33. package/build/channels-consumer.js +3 -0
  34. package/build/collection-loader.js +48 -0
  35. package/build/collection.js +279 -0
  36. package/build/command-submit-data.js +81 -0
  37. package/build/commands-pool.js +195 -0
  38. package/build/compose.js +9 -0
  39. package/build/config.js +53 -0
  40. package/build/custom-error.js +5 -0
  41. package/build/data-set-to-attributes.js +10 -0
  42. package/build/deserializer.js +56 -0
  43. package/build/destroy-error.js +5 -0
  44. package/build/devise.js +109 -0
  45. package/build/draggable-sort/controller.js +136 -0
  46. package/build/draggable-sort/index.js +114 -0
  47. package/build/draggable-sort/item.js +188 -0
  48. package/build/error-logger.js +101 -0
  49. package/build/error-messages.js +13 -0
  50. package/build/event-connection.js +32 -0
  51. package/build/event-model-class.js +24 -0
  52. package/build/events.js +5 -0
  53. package/build/form.js +83 -0
  54. package/build/index.js +3 -0
  55. package/build/inputs/attachment.js +121 -0
  56. package/build/inputs/auto-submit.js +36 -0
  57. package/build/inputs/checkbox.js +145 -0
  58. package/build/inputs/checkboxes.js +111 -0
  59. package/build/inputs/id-for-component.js +15 -0
  60. package/build/inputs/input-wrapper.js +18 -0
  61. package/build/inputs/input.js +230 -0
  62. package/build/inputs/money.js +179 -0
  63. package/build/inputs/name-for-component.js +13 -0
  64. package/build/inputs/select.js +92 -0
  65. package/build/instance-of-class-name.js +23 -0
  66. package/build/key-value-store.js +53 -0
  67. package/build/link.js +68 -0
  68. package/build/logger.js +30 -0
  69. package/build/modal.js +37 -0
  70. package/build/model-class-require.js +13 -0
  71. package/build/model-events.js +30 -0
  72. package/build/model-name.js +28 -0
  73. package/build/model-prop-type.js +101 -0
  74. package/build/model-recipes-loader.js +32 -0
  75. package/build/model-recipes-model-loader.js +357 -0
  76. package/build/models-response-reader.js +40 -0
  77. package/build/models.js +8 -0
  78. package/build/money-formatter.js +77 -0
  79. package/build/not-loaded-error.js +2 -0
  80. package/build/params.js +60 -0
  81. package/build/preloaded.js +38 -0
  82. package/build/resize-observer.js +11 -0
  83. package/build/result.js +13 -0
  84. package/build/router/route.js +262 -0
  85. package/build/router/switch.js +72 -0
  86. package/build/router.js +57 -0
  87. package/build/routes-native.js +202 -0
  88. package/build/routes.js +50 -0
  89. package/build/run-last.js +35 -0
  90. package/build/serializer.js +63 -0
  91. package/build/services.js +20 -0
  92. package/build/session-status-updater.js +126 -0
  93. package/build/source-maps-loader.js +171 -0
  94. package/build/super-admin/config-reader.js +84 -0
  95. package/build/super-admin/edit-page/edit-attribute-checkbox.js +85 -0
  96. package/build/super-admin/edit-page/edit-attribute-content.js +54 -0
  97. package/build/super-admin/edit-page/edit-attribute-input.js +79 -0
  98. package/build/super-admin/edit-page/edit-attribute.js +76 -0
  99. package/build/super-admin/edit-page.js +120 -0
  100. package/build/super-admin/has-edit-config.js +12 -0
  101. package/build/super-admin/index-page.js +24 -0
  102. package/build/super-admin/index.js +180 -0
  103. package/build/super-admin/layout/header/index.js +151 -0
  104. package/build/super-admin/layout/index.js +109 -0
  105. package/build/super-admin/layout/menu/index.js +93 -0
  106. package/build/super-admin/layout/menu/menu-content.js +40 -0
  107. package/build/super-admin/layout/menu/menu-item.js +83 -0
  108. package/build/super-admin/layout/no-access.js +25 -0
  109. package/build/super-admin/model-class-table.js +61 -0
  110. package/build/super-admin/models.js +8 -0
  111. package/build/super-admin/show-nav.js +49 -0
  112. package/build/super-admin/show-page/belongs-to-attribute-row.js +28 -0
  113. package/build/super-admin/show-page/index.js +141 -0
  114. package/build/super-admin/show-reflection-actions.js +47 -0
  115. package/build/super-admin/show-reflection-link.js +46 -0
  116. package/build/super-admin/show-reflection-page.js +47 -0
  117. package/build/table/column-content.js +112 -0
  118. package/build/table/column-identifier.js +18 -0
  119. package/build/table/column-visible.js +7 -0
  120. package/build/table/components/column.js +20 -0
  121. package/build/table/components/flat-list.js +20 -0
  122. package/build/table/components/header.js +25 -0
  123. package/build/table/components/row.js +25 -0
  124. package/build/table/filters/attribute-element.js +43 -0
  125. package/build/table/filters/filter-form.js +392 -0
  126. package/build/table/filters/filter.js +89 -0
  127. package/build/table/filters/index.js +182 -0
  128. package/build/table/filters/load-search-modal.js +174 -0
  129. package/build/table/filters/reflection-element.js +36 -0
  130. package/build/table/filters/save-search-modal.js +86 -0
  131. package/build/table/filters/scope-element.js +41 -0
  132. package/build/table/header-column-content.js +67 -0
  133. package/build/table/header-column.js +144 -0
  134. package/build/table/header-select.js +104 -0
  135. package/build/table/model-callback-args.js +10 -0
  136. package/build/table/model-column.js +87 -0
  137. package/build/table/model-row.js +179 -0
  138. package/build/table/select-calculator.js +63 -0
  139. package/build/table/settings/column-row.js +97 -0
  140. package/build/table/settings/download-action.js +78 -0
  141. package/build/table/settings/index.js +92 -0
  142. package/build/table/table-settings.js +219 -0
  143. package/build/table/table.js +972 -0
  144. package/build/table/use-sorting.js +34 -0
  145. package/build/table/widths.js +75 -0
  146. package/build/table/worker-plugins-check-all-checkbox.js +125 -0
  147. package/build/table/worker-plugins-checkbox.js +115 -0
  148. package/build/translated-attributes.js +10 -0
  149. package/build/translated-collections.js +11 -0
  150. package/build/updated-attribute.js +76 -0
  151. package/build/url-encode.js +15 -0
  152. package/build/use-breakpoint.js +44 -0
  153. package/build/use-can-can.js +55 -0
  154. package/build/use-collection.js +225 -0
  155. package/build/use-created-event.js +52 -0
  156. package/build/use-current-user.js +73 -0
  157. package/build/use-destroyed-event.js +60 -0
  158. package/build/use-event-emitter.js +13 -0
  159. package/build/use-event-listener.js +16 -0
  160. package/build/use-input.js +140 -0
  161. package/build/use-model-event.js +60 -0
  162. package/build/use-model.js +169 -0
  163. package/build/use-resize-observer.js +23 -0
  164. package/build/use-router.js +102 -0
  165. package/build/use-screen-layout.js +39 -0
  166. package/build/use-updated-event.js +60 -0
  167. package/build/use-validation-errors.js +30 -0
  168. package/build/utils/card.js +51 -0
  169. package/build/utils/checkbox.js +48 -0
  170. package/build/utils/default-style.js +18 -0
  171. package/build/utils/modal.js +61 -0
  172. package/build/utils/text.js +18 -0
  173. package/build/validation-error.js +28 -0
  174. package/build/validation-errors.js +98 -0
  175. package/build/with-collection.js +13 -0
  176. package/build/with-current-user.js +9 -0
  177. package/build/with-model.js +14 -0
  178. package/build/with-router.js +21 -0
  179. package/expo-module.config.json +17 -0
  180. package/ios/ApiMaker.podspec +29 -0
  181. package/ios/ApiMakerModule.swift +48 -0
  182. package/ios/ApiMakerView.swift +38 -0
  183. package/package.json +35 -14
  184. package/src/{api.mjs → api.js} +5 -5
  185. package/src/{base-error.mjs → base-error.js} +1 -1
  186. package/src/base-model/{attribute.mjs → attribute.js} +1 -1
  187. package/src/base-model/{reflection.mjs → reflection.js} +1 -1
  188. package/src/{base-model.mjs → base-model.js} +14 -14
  189. package/src/bootstrap/attribute-row/index.jsx +2 -2
  190. package/src/bootstrap/attribute-rows.jsx +1 -1
  191. package/src/bootstrap/card.jsx +1 -1
  192. package/src/bootstrap/checkbox.jsx +1 -1
  193. package/src/bootstrap/checkboxes.jsx +1 -1
  194. package/src/bootstrap/input.jsx +1 -1
  195. package/src/bootstrap/paginate.jsx +2 -2
  196. package/src/bootstrap/sort-link.jsx +3 -3
  197. package/src/{cable-connection-pool.mjs → cable-connection-pool.js} +3 -3
  198. package/src/{cable-subscription-pool.mjs → cable-subscription-pool.js} +4 -4
  199. package/src/{cable-subscription.mjs → cable-subscription.js} +1 -1
  200. package/src/{can-can.mjs → can-can.js} +1 -1
  201. package/src/collection-loader.jsx +2 -2
  202. package/src/{collection.mjs → collection.js} +3 -3
  203. package/src/{commands-pool.mjs → commands-pool.js} +11 -11
  204. package/src/{custom-error.mjs → custom-error.js} +1 -1
  205. package/src/{deserializer.mjs → deserializer.js} +2 -2
  206. package/src/{destroy-error.mjs → destroy-error.js} +1 -1
  207. package/src/{devise.mjs → devise.js} +5 -9
  208. package/src/draggable-sort/controller.js +137 -0
  209. package/src/draggable-sort/index.jsx +108 -0
  210. package/src/draggable-sort/item.jsx +174 -0
  211. package/src/{error-logger.mjs → error-logger.js} +1 -1
  212. package/src/event-connection.jsx +1 -1
  213. package/src/event-model-class.jsx +1 -1
  214. package/src/form.jsx +1 -1
  215. package/src/index.js +3 -0
  216. package/src/inputs/attachment.jsx +2 -2
  217. package/src/inputs/checkbox.jsx +7 -6
  218. package/src/inputs/checkboxes.jsx +1 -1
  219. package/src/inputs/input-wrapper.jsx +1 -1
  220. package/src/inputs/input.jsx +8 -7
  221. package/src/inputs/money.jsx +3 -3
  222. package/src/inputs/select.jsx +1 -1
  223. package/src/{key-value-store.mjs → key-value-store.js} +1 -1
  224. package/src/link.jsx +2 -2
  225. package/src/modal.jsx +1 -1
  226. package/src/{model-class-require.mjs → model-class-require.js} +4 -2
  227. package/src/{model-events.mjs → model-events.js} +1 -1
  228. package/src/{model-name.mjs → model-name.js} +1 -1
  229. package/src/{model-recipes-loader.mjs → model-recipes-loader.js} +1 -1
  230. package/src/{model-recipes-model-loader.mjs → model-recipes-model-loader.js} +2 -2
  231. package/src/{models-response-reader.mjs → models-response-reader.js} +2 -2
  232. package/src/models.js +7 -0
  233. package/src/{models.mjs.erb → models.js.erb} +1 -1
  234. package/src/{params.mjs → params.js} +2 -2
  235. package/src/{preloaded.mjs → preloaded.js} +1 -1
  236. package/src/resize-observer.jsx +1 -1
  237. package/src/router/route.jsx +1 -1
  238. package/src/router/switch.jsx +1 -1
  239. package/src/router.jsx +1 -1
  240. package/src/{routes-native.mjs → routes-native.js} +1 -1
  241. package/src/{services.mjs → services.js} +1 -1
  242. package/src/{session-status-updater.mjs → session-status-updater.js} +3 -3
  243. package/src/{source-maps-loader.mjs → source-maps-loader.js} +1 -1
  244. package/src/super-admin/edit-page/edit-attribute-checkbox.jsx +1 -1
  245. package/src/super-admin/edit-page/edit-attribute-content.jsx +1 -1
  246. package/src/super-admin/edit-page/edit-attribute-input.jsx +1 -1
  247. package/src/super-admin/edit-page/edit-attribute.jsx +1 -1
  248. package/src/super-admin/edit-page.jsx +2 -2
  249. package/src/super-admin/has-edit-config.js +1 -1
  250. package/src/super-admin/index-page.jsx +1 -1
  251. package/src/super-admin/index.jsx +7 -7
  252. package/src/super-admin/layout/header/index.jsx +2 -2
  253. package/src/super-admin/layout/index.jsx +3 -3
  254. package/src/super-admin/layout/menu/index.jsx +3 -3
  255. package/src/super-admin/layout/menu/menu-content.jsx +2 -2
  256. package/src/super-admin/layout/menu/{menu-item/index.jsx → menu-item.jsx} +5 -6
  257. package/src/super-admin/layout/no-access.jsx +2 -2
  258. package/src/super-admin/model-class-table.jsx +3 -3
  259. package/src/super-admin/models.js +1 -1
  260. package/src/super-admin/show-nav.jsx +2 -2
  261. package/src/super-admin/show-page/belongs-to-attribute-row.jsx +1 -1
  262. package/src/super-admin/show-page/index.jsx +2 -2
  263. package/src/super-admin/show-reflection-actions.jsx +1 -1
  264. package/src/super-admin/show-reflection-link.jsx +1 -1
  265. package/src/super-admin/show-reflection-page.jsx +1 -1
  266. package/src/table/column-content.jsx +1 -1
  267. package/src/table/components/column.jsx +8 -2
  268. package/src/table/components/header.jsx +2 -2
  269. package/src/table/filters/filter-form.jsx +1 -1
  270. package/src/table/filters/index.jsx +5 -3
  271. package/src/table/filters/load-search-modal.jsx +6 -4
  272. package/src/table/filters/save-search-modal.jsx +4 -4
  273. package/src/table/header-column.jsx +59 -79
  274. package/src/table/header-select.jsx +1 -1
  275. package/src/table/model-column.jsx +12 -6
  276. package/src/table/model-row.jsx +11 -7
  277. package/src/table/{select-calculator.mjs → select-calculator.js} +1 -1
  278. package/src/table/settings/column-row.jsx +4 -3
  279. package/src/table/settings/download-action.jsx +3 -3
  280. package/src/table/settings/index.jsx +3 -3
  281. package/src/table/table-settings.js +5 -4
  282. package/src/table/table.jsx +149 -71
  283. package/src/table/{use-sorting.mjs → use-sorting.js} +1 -1
  284. package/src/table/{widths.mjs → widths.jsx} +11 -2
  285. package/src/table/worker-plugins-check-all-checkbox.jsx +2 -2
  286. package/src/table/worker-plugins-checkbox.jsx +2 -2
  287. package/src/{translated-collections.mjs → translated-collections.js} +1 -1
  288. package/src/updated-attribute.jsx +1 -1
  289. package/src/{use-breakpoint.mjs → use-breakpoint.js} +2 -2
  290. package/src/use-can-can.js +55 -0
  291. package/src/{use-collection.mjs → use-collection.js} +4 -4
  292. package/src/{use-created-event.mjs → use-created-event.js} +2 -2
  293. package/src/{use-current-user.mjs → use-current-user.js} +6 -5
  294. package/src/{use-destroyed-event.mjs → use-destroyed-event.js} +2 -2
  295. package/src/{use-input.mjs → use-input.js} +5 -5
  296. package/src/use-model-event.js +2 -2
  297. package/src/{use-model.mjs → use-model.js} +4 -4
  298. package/src/{use-resize-observer.mjs → use-resize-observer.js} +1 -1
  299. package/src/use-router.jsx +2 -2
  300. package/src/{use-updated-event.mjs → use-updated-event.js} +2 -2
  301. package/src/{use-validation-errors.mjs → use-validation-errors.js} +3 -3
  302. package/src/utils/checkbox.jsx +2 -2
  303. package/src/{validation-error.mjs → validation-error.js} +1 -1
  304. package/src/{validation-errors.mjs → validation-errors.js} +1 -1
  305. package/src/with-current-user.jsx +1 -1
  306. package/src/with-model.jsx +1 -1
  307. package/__tests__/base-model.test.mjs +0 -71
  308. package/__tests__/cable-connection-pool.test.mjs +0 -227
  309. package/__tests__/cable-subscription-pool.test.mjs +0 -27
  310. package/__tests__/can-can.test.mjs +0 -34
  311. package/__tests__/collection.test.mjs +0 -51
  312. package/__tests__/custom-error.test.mjs +0 -13
  313. package/__tests__/model-name.test.mjs +0 -34
  314. package/__tests__/model-prop-type.test.mjs +0 -113
  315. package/__tests__/params.test.mjs +0 -40
  316. package/__tests__/routes-native.test.mjs +0 -104
  317. package/__tests__/routes.test.mjs +0 -47
  318. package/__tests__/serializer.test.mjs +0 -30
  319. package/__tests__/support/task.mjs +0 -27
  320. package/__tests__/support/user.mjs +0 -32
  321. package/index.js +0 -1
  322. package/jest.config.js +0 -9
  323. package/src/event-created.jsx +0 -12
  324. package/src/event-destroyed.jsx +0 -25
  325. package/src/event-emitter-listener.jsx +0 -10
  326. package/src/event-listener.jsx +0 -25
  327. package/src/event-updated.jsx +0 -27
  328. package/src/super-admin/layout/menu/menu-item/style.scss +0 -10
  329. package/src/use-can-can.mjs +0 -48
  330. package/src/with-can-can.jsx +0 -12
  331. package/webpack.config.js +0 -15
  332. /package/src/{attribute-not-loaded-error.mjs → attribute-not-loaded-error.js} +0 -0
  333. /package/src/base-model/{column.mjs → column.js} +0 -0
  334. /package/src/base-model/{scope.mjs → scope.js} +0 -0
  335. /package/src/{cache-key-generator.mjs → cache-key-generator.js} +0 -0
  336. /package/src/{channels-consumer.mjs → channels-consumer.js} +0 -0
  337. /package/src/{command-submit-data.mjs → command-submit-data.js} +0 -0
  338. /package/src/{config.mjs → config.js} +0 -0
  339. /package/src/{data-set-to-attributes.mjs → data-set-to-attributes.js} +0 -0
  340. /package/src/{error-messages.mjs → error-messages.js} +0 -0
  341. /package/src/{events.mjs → events.js} +0 -0
  342. /package/src/inputs/{auto-submit.mjs → auto-submit.js} +0 -0
  343. /package/src/inputs/{id-for-component.mjs → id-for-component.js} +0 -0
  344. /package/src/inputs/{name-for-component.mjs → name-for-component.js} +0 -0
  345. /package/src/{instance-of-class-name.mjs → instance-of-class-name.js} +0 -0
  346. /package/src/{logger.mjs → logger.js} +0 -0
  347. /package/src/{model-prop-type.mjs → model-prop-type.js} +0 -0
  348. /package/src/{money-formatter.mjs → money-formatter.js} +0 -0
  349. /package/src/{not-loaded-error.mjs → not-loaded-error.js} +0 -0
  350. /package/src/{result.mjs → result.js} +0 -0
  351. /package/src/{routes.mjs → routes.js} +0 -0
  352. /package/src/{run-last.mjs → run-last.js} +0 -0
  353. /package/src/{serializer.mjs → serializer.js} +0 -0
  354. /package/src/table/{column-identifier.mjs → column-identifier.js} +0 -0
  355. /package/src/table/{column-visible.mjs → column-visible.js} +0 -0
  356. /package/src/table/{model-callback-args.mjs → model-callback-args.js} +0 -0
  357. /package/src/{translated-collections-data.mjs.erb → translated-collections-data.js.erb} +0 -0
  358. /package/src/{url-encode.mjs → url-encode.js} +0 -0
  359. /package/src/{use-event-emitter.mjs → use-event-emitter.js} +0 -0
  360. /package/src/{use-event-listener.mjs → use-event-listener.js} +0 -0
  361. /package/src/{use-screen-layout.mjs → use-screen-layout.js} +0 -0
@@ -0,0 +1,828 @@
1
+ import Attribute from "./base-model/attribute";
2
+ import AttributeNotLoadedError from "./attribute-not-loaded-error";
3
+ import CacheKeyGenerator from "./cache-key-generator";
4
+ import Collection from "./collection";
5
+ import CommandsPool from "./commands-pool";
6
+ import Config from "./config";
7
+ import CustomError from "./custom-error";
8
+ import { digg } from "diggerize";
9
+ import FormDataObjectizer from "form-data-objectizer";
10
+ import * as inflection from "inflection";
11
+ import ModelName from "./model-name";
12
+ import NotLoadedError from "./not-loaded-error";
13
+ import objectToFormData from "object-to-formdata";
14
+ import Reflection from "./base-model/reflection";
15
+ import Scope from "./base-model/scope";
16
+ import Services from "./services";
17
+ import ValidationError from "./validation-error";
18
+ import { ValidationErrors } from "./validation-errors";
19
+ const objectToUnderscore = object => {
20
+ const newObject = {};
21
+ for (const key in object) {
22
+ const underscoreKey = inflection.underscore(key);
23
+ newObject[underscoreKey] = object[key];
24
+ }
25
+ return newObject;
26
+ };
27
+ export default class BaseModel {
28
+ static apiMakerType = "BaseModel";
29
+ static attributes() {
30
+ const attributes = digg(this.modelClassData(), "attributes");
31
+ const result = [];
32
+ for (const attributeKey in attributes) {
33
+ const attributeData = attributes[attributeKey];
34
+ const attribute = new Attribute(attributeData);
35
+ result.push(attribute);
36
+ }
37
+ return result;
38
+ }
39
+ static hasAttribute(attributeName) {
40
+ const attributes = digg(this.modelClassData(), "attributes");
41
+ const lowerCaseAttributeName = inflection.underscore(attributeName);
42
+ if (lowerCaseAttributeName in attributes) return true;
43
+ return false;
44
+ }
45
+ static modelClassData() {
46
+ throw new Error("modelClassData should be overriden by child");
47
+ }
48
+ static newCustomEvent = validationErrors => {
49
+ return new CustomEvent("validation-errors", {
50
+ detail: validationErrors
51
+ });
52
+ };
53
+ static sendValidationErrorsEvent = (validationErrors, options) => {
54
+ if (options && options.form) {
55
+ const event = BaseModel.newCustomEvent(validationErrors);
56
+ options.form.dispatchEvent(event);
57
+ }
58
+ };
59
+ static async find(id) {
60
+ const query = {};
61
+ query[`${this.primaryKey()}_eq`] = id;
62
+ const model = await this.ransack(query).first();
63
+ if (model) {
64
+ return model;
65
+ } else {
66
+ throw new CustomError("Record not found");
67
+ }
68
+ }
69
+ static async findOrCreateBy(findOrCreateByArgs, args = {}) {
70
+ const result = await Services.current().sendRequest("Models::FindOrCreateBy", {
71
+ additional_data: args.additionalData,
72
+ find_or_create_by_args: findOrCreateByArgs,
73
+ resource_name: digg(this.modelClassData(), "name")
74
+ });
75
+ const model = digg(result, "model");
76
+ return model;
77
+ }
78
+ static modelName() {
79
+ return new ModelName({
80
+ modelClassData: this.modelClassData()
81
+ });
82
+ }
83
+ static primaryKey() {
84
+ return digg(this.modelClassData(), "primaryKey");
85
+ }
86
+ static ransack(query = {}) {
87
+ return new Collection({
88
+ modelClass: this
89
+ }, {
90
+ ransack: query
91
+ });
92
+ }
93
+ static select(select) {
94
+ return this.ransack().select(select);
95
+ }
96
+ static ransackableAssociations() {
97
+ const relationships = digg(this.modelClassData(), "ransackable_associations");
98
+ const reflections = [];
99
+ for (const relationshipData of relationships) {
100
+ reflections.push(new Reflection(relationshipData));
101
+ }
102
+ return reflections;
103
+ }
104
+ static ransackableAttributes() {
105
+ const attributes = digg(this.modelClassData(), "ransackable_attributes");
106
+ const result = [];
107
+ for (const attributeData of attributes) {
108
+ result.push(new Attribute(attributeData));
109
+ }
110
+ return result;
111
+ }
112
+ static ransackableScopes() {
113
+ const ransackableScopes = digg(this.modelClassData(), "ransackable_scopes");
114
+ const result = [];
115
+ for (const scopeData of ransackableScopes) {
116
+ const scope = new Scope(scopeData);
117
+ result.push(scope);
118
+ }
119
+ return result;
120
+ }
121
+ static reflections() {
122
+ const relationships = digg(this.modelClassData(), "relationships");
123
+ const reflections = [];
124
+ for (const relationshipData of relationships) {
125
+ const reflection = new Reflection(relationshipData);
126
+ reflections.push(reflection);
127
+ }
128
+ return reflections;
129
+ }
130
+ static reflection(name) {
131
+ const foundReflection = this.reflections().find(reflection => reflection.name() == name);
132
+ if (!foundReflection) {
133
+ throw new Error(`No such reflection: ${name} in ${this.reflections().map(reflection => reflection.name()).join(", ")}`);
134
+ }
135
+ return foundReflection;
136
+ }
137
+ static _token() {
138
+ const csrfTokenElement = document.querySelector("meta[name='csrf-token']");
139
+ if (csrfTokenElement) {
140
+ return csrfTokenElement.getAttribute("content");
141
+ }
142
+ }
143
+ constructor(args = {}) {
144
+ this.changes = {};
145
+ this.newRecord = args.isNewRecord;
146
+ this.relationshipsCache = {};
147
+ this.relationships = {};
148
+ if (args && args.data && args.data.a) {
149
+ this._readModelDataFromArgs(args);
150
+ } else if (args.a) {
151
+ this.abilities = args.b || {};
152
+ this.modelData = objectToUnderscore(args.a);
153
+ } else if (args) {
154
+ this.abilities = {};
155
+ this.modelData = objectToUnderscore(args);
156
+ } else {
157
+ this.abilities = {};
158
+ this.modelData = {};
159
+ }
160
+ }
161
+ assignAttributes(newAttributes) {
162
+ for (const key in newAttributes) {
163
+ const newValue = newAttributes[key];
164
+ const attributeUnderscore = inflection.underscore(key);
165
+ let applyChange = true;
166
+ let deleteChange = false;
167
+ if (this.isAttributeLoaded(key)) {
168
+ const oldValue = this.readAttribute(key);
169
+ const originalValue = this.modelData[attributeUnderscore];
170
+ if (newValue == oldValue) {
171
+ applyChange = false;
172
+ } else if (newValue == originalValue) {
173
+ applyChange = false;
174
+ deleteChange = true;
175
+ }
176
+ }
177
+ if (applyChange) {
178
+ this.changes[attributeUnderscore] = newValue;
179
+ } else if (deleteChange) {
180
+ delete this.changes[attributeUnderscore];
181
+ }
182
+ }
183
+ }
184
+ attributes() {
185
+ const result = {};
186
+ for (const key in this.modelData) {
187
+ result[key] = this.modelData[key];
188
+ }
189
+ for (const key in this.changes) {
190
+ result[key] = this.changes[key];
191
+ }
192
+ return result;
193
+ }
194
+ can(givenAbilityName) {
195
+ const abilityName = inflection.underscore(givenAbilityName);
196
+ if (!(abilityName in this.abilities)) {
197
+ throw new Error(`Ability ${abilityName} hasn't been loaded for ${digg(this.modelClassData(), "name")}`);
198
+ }
199
+ return this.abilities[abilityName];
200
+ }
201
+ clone() {
202
+ const clone = new this.constructor();
203
+ clone.abilities = {
204
+ ...this.abilities
205
+ };
206
+ clone.modelData = {
207
+ ...this.modelData
208
+ };
209
+ clone.relationships = {
210
+ ...this.relationships
211
+ };
212
+ clone.relationshipsCache = {
213
+ ...this.relationshipsCache
214
+ };
215
+ return clone;
216
+ }
217
+ cacheKey() {
218
+ if (this.isPersisted()) {
219
+ const keyParts = [this.modelClassData().paramKey, this.primaryKey()];
220
+ if ("updated_at" in this.modelData) {
221
+ const updatedAt = this.updatedAt();
222
+ if (typeof updatedAt != "object") {
223
+ throw new Error(`updatedAt wasn't an object: ${typeof updatedAt}`);
224
+ } else if (!("getTime" in updatedAt)) {
225
+ throw new Error(`updatedAt didn't support getTime with class: ${updatedAt.constructor && updatedAt.constructor.name}`);
226
+ }
227
+ keyParts.push(`updatedAt-${this.updatedAt().getTime()}`);
228
+ }
229
+ return keyParts.join("-");
230
+ } else {
231
+ return this.uniqueKey();
232
+ }
233
+ }
234
+ localCacheKey() {
235
+ const cacheKeyGenerator = new CacheKeyGenerator(this);
236
+ return cacheKeyGenerator.local();
237
+ }
238
+ fullCacheKey() {
239
+ const cacheKeyGenerator = new CacheKeyGenerator(this);
240
+ return cacheKeyGenerator.cacheKey();
241
+ }
242
+ static all() {
243
+ return this.ransack();
244
+ }
245
+ async create(attributes, options) {
246
+ if (attributes) this.assignAttributes(attributes);
247
+ const paramKey = this.modelClassData().paramKey;
248
+ const modelData = this.getAttributes();
249
+ const dataToUse = {};
250
+ dataToUse[paramKey] = modelData;
251
+ let response;
252
+ try {
253
+ response = await CommandsPool.addCommand({
254
+ args: {
255
+ save: dataToUse
256
+ },
257
+ command: `${this.modelClassData().collectionName}-create`,
258
+ collectionName: this.modelClassData().collectionName,
259
+ primaryKey: this.primaryKey(),
260
+ type: "create"
261
+ }, {});
262
+ } catch (error) {
263
+ BaseModel.parseValidationErrors({
264
+ error,
265
+ model: this,
266
+ options
267
+ });
268
+ throw error;
269
+ }
270
+ if (response.model) {
271
+ this._refreshModelFromResponse(response);
272
+ this.changes = {};
273
+ }
274
+ return {
275
+ model: this,
276
+ response
277
+ };
278
+ }
279
+ async createRaw(rawData, options = {}) {
280
+ const objectData = BaseModel._objectDataFromGivenRawData(rawData, options);
281
+ let response;
282
+ try {
283
+ response = await CommandsPool.addCommand({
284
+ args: {
285
+ save: objectData
286
+ },
287
+ command: `${this.modelClassData().collectionName}-create`,
288
+ collectionName: this.modelClassData().collectionName,
289
+ primaryKey: this.primaryKey(),
290
+ type: "create"
291
+ }, {});
292
+ } catch (error) {
293
+ BaseModel.parseValidationErrors({
294
+ error,
295
+ model: this,
296
+ options
297
+ });
298
+ throw error;
299
+ }
300
+ if (response.model) {
301
+ this._refreshModelDataFromResponse(response);
302
+ this.changes = {};
303
+ }
304
+ return {
305
+ model: this,
306
+ response
307
+ };
308
+ }
309
+ async destroy() {
310
+ const response = await CommandsPool.addCommand({
311
+ args: {
312
+ query_params: this.collection && this.collection.params()
313
+ },
314
+ command: `${this.modelClassData().collectionName}-destroy`,
315
+ collectionName: this.modelClassData().collectionName,
316
+ primaryKey: this.primaryKey(),
317
+ type: "destroy"
318
+ }, {});
319
+ if (response.success) {
320
+ if (response.model) {
321
+ this._refreshModelDataFromResponse(response);
322
+ this.changes = {};
323
+ }
324
+ return {
325
+ model: this,
326
+ response
327
+ };
328
+ } else {
329
+ this.handleResponseError(response);
330
+ }
331
+ }
332
+ async ensureAbilities(listOfAbilities) {
333
+ // Populate an array with a list of abilities currently not loaded
334
+ const abilitiesToLoad = [];
335
+ for (const abilityInList of listOfAbilities) {
336
+ if (!(abilityInList in this.abilities)) {
337
+ abilitiesToLoad.push(abilityInList);
338
+ }
339
+ }
340
+
341
+ // Load the missing abilities if any
342
+ if (abilitiesToLoad.length > 0) {
343
+ const primaryKeyName = this.constructor.primaryKey();
344
+ const ransackParams = {};
345
+ ransackParams[`${primaryKeyName}_eq`] = this.primaryKey();
346
+ const abilitiesParams = {};
347
+ abilitiesParams[digg(this.modelClassData(), "name")] = abilitiesToLoad;
348
+ const anotherModel = await this.constructor.ransack(ransackParams).abilities(abilitiesParams).first();
349
+ if (!anotherModel) {
350
+ throw new Error(`Could not look up the same model ${this.primaryKey()} with abilities: ${abilitiesToLoad.join(", ")}`);
351
+ }
352
+ const newAbilities = anotherModel.abilities;
353
+ for (const newAbility in newAbilities) {
354
+ this.abilities[newAbility] = newAbilities[newAbility];
355
+ }
356
+ }
357
+ }
358
+ getAttributes = () => Object.assign(this.modelData, this.changes);
359
+ handleResponseError(response) {
360
+ BaseModel.parseValidationErrors({
361
+ model: this,
362
+ response
363
+ });
364
+ throw new new CustomError("Response wasn't successful", {
365
+ model: this,
366
+ response
367
+ })();
368
+ }
369
+ identifierKey() {
370
+ if (!this._identifierKey) this._identifierKey = this.isPersisted() ? this.primaryKey() : this.uniqueKey();
371
+ return this._identifierKey;
372
+ }
373
+ isAssociationLoaded = associationName => this.isAssociationLoadedUnderscore(inflection.underscore(associationName));
374
+ isAssociationLoadedUnderscore(associationNameUnderscore) {
375
+ if (associationNameUnderscore in this.relationshipsCache) return true;
376
+ return false;
377
+ }
378
+ isAssociationPresent(associationName) {
379
+ if (this.isAssociationLoaded(associationName)) return true;
380
+ if (associationName in this.relationships) return true;
381
+ return false;
382
+ }
383
+ static parseValidationErrors({
384
+ error,
385
+ model,
386
+ options
387
+ }) {
388
+ if (!(error instanceof ValidationError)) return;
389
+ if (!error.args.response.validation_errors) return;
390
+ const validationErrors = new ValidationErrors({
391
+ model,
392
+ validationErrors: digg(error, "args", "response", "validation_errors")
393
+ });
394
+ BaseModel.sendValidationErrorsEvent(validationErrors, options);
395
+ if (!options || options.throwValidationError != false) {
396
+ throw error;
397
+ }
398
+ }
399
+ static humanAttributeName(attributeName) {
400
+ const keyName = digg(this.modelClassData(), "i18nKey");
401
+ const i18n = Config.getI18n();
402
+ if (i18n) return i18n.t(`activerecord.attributes.${keyName}.${BaseModel.snakeCase(attributeName)}`, {
403
+ defaultValue: attributeName
404
+ });
405
+ return inflection.humanize(attributeName);
406
+ }
407
+ isAttributeChanged(attributeName) {
408
+ const attributeNameUnderscore = inflection.underscore(attributeName);
409
+ const attributeData = this.modelClassData().attributes.find(attribute => digg(attribute, "name") == attributeNameUnderscore);
410
+ if (!attributeData) {
411
+ const attributeNames = this.modelClassData().attributes.map(attribute => digg(attribute, "name"));
412
+ throw new Error(`Couldn't find an attribute by that name: "${attributeName}" in: ${attributeNames.join(", ")}`);
413
+ }
414
+ if (!(attributeNameUnderscore in this.changes)) return false;
415
+ const oldValue = this.modelData[attributeNameUnderscore];
416
+ const newValue = this.changes[attributeNameUnderscore];
417
+ const changedMethod = this[`_is${inflection.camelize(attributeData.type, true)}Changed`];
418
+ if (!changedMethod) throw new Error(`Don't know how to handle type: ${attributeData.type}`);
419
+ return changedMethod(oldValue, newValue);
420
+ }
421
+ isChanged() {
422
+ const keys = Object.keys(this.changes);
423
+ if (keys.length > 0) {
424
+ return true;
425
+ } else {
426
+ return false;
427
+ }
428
+ }
429
+ isNewRecord() {
430
+ if (this.newRecord !== undefined) {
431
+ return this.newRecord;
432
+ } else if ("id" in this.modelData && this.modelData.id) {
433
+ return false;
434
+ } else {
435
+ return true;
436
+ }
437
+ }
438
+ isPersisted = () => !this.isNewRecord();
439
+ static snakeCase = string => inflection.underscore(string);
440
+ savedChangeToAttribute(attributeName) {
441
+ if (!this.previousModelData) return false;
442
+ const attributeNameUnderscore = inflection.underscore(attributeName);
443
+ const attributeData = this.modelClassData().attributes.find(attribute => attribute.name == attributeNameUnderscore);
444
+ if (!attributeData) {
445
+ const attributeNames = this.modelClassData().attributes.map(attribute => attribute.name);
446
+ throw new Error(`Couldn't find an attribute by that name: "${attributeName}" in: ${attributeNames.join(", ")}`);
447
+ }
448
+ if (!(attributeNameUnderscore in this.previousModelData)) return true;
449
+ const oldValue = this.previousModelData[attributeNameUnderscore];
450
+ const newValue = this.modelData[attributeNameUnderscore];
451
+ const changedMethodName = `_is${inflection.camelize(attributeData.type)}Changed`;
452
+ const changedMethod = this[changedMethodName];
453
+ if (!changedMethod) throw new Error(`Don't know how to handle type: ${attributeData.type}`);
454
+ return changedMethod(oldValue, newValue);
455
+ }
456
+ setNewModel(model) {
457
+ this.setNewModelData(model);
458
+ for (const relationshipName in model.relationships) {
459
+ this.relationships[relationshipName] = model.relationships[relationshipName];
460
+ }
461
+ for (const relationshipCacheName in model.relationshipsCache) {
462
+ this.relationshipsCache[relationshipCacheName] = model.relationshipsCache[name];
463
+ }
464
+ }
465
+ setNewModelData(model) {
466
+ if (!("modelData" in model)) throw new Error(`No modelData in model: ${JSON.stringify(model)}`);
467
+ this.previousModelData = Object.assign({}, digg(this, "modelData"));
468
+ for (const attributeName in model.modelData) {
469
+ this.modelData[attributeName] = model.modelData[attributeName];
470
+ }
471
+ }
472
+ _isDateChanged(oldValue, newValue) {
473
+ if (Date.parse(oldValue) != Date.parse(newValue)) return true;
474
+ }
475
+ _isIntegerChanged(oldValue, newValue) {
476
+ if (parseInt(oldValue, 10) != parseInt(newValue, 10)) return true;
477
+ }
478
+ _isStringChanged(oldValue, newValue) {
479
+ const oldConvertedValue = `${oldValue}`;
480
+ const newConvertedValue = `${newValue}`;
481
+ if (oldConvertedValue != newConvertedValue) return true;
482
+ }
483
+ modelClassData = () => this.constructor.modelClassData();
484
+ async reload() {
485
+ const params = this.collection && this.collection.params();
486
+ const ransackParams = {};
487
+ ransackParams[`${this.constructor.primaryKey()}_eq`] = this.primaryKey();
488
+ let query = this.constructor.ransack(ransackParams);
489
+ if (params) {
490
+ if (params.preload) {
491
+ query.queryArgs.preload = params.preload;
492
+ }
493
+ if (params.select) {
494
+ query.queryArgs.select = params.select;
495
+ }
496
+ if (params.select_columns) {
497
+ query.queryArgs.selectColumns = params.select_columns;
498
+ }
499
+ }
500
+ const model = await query.first();
501
+ this.setNewModel(model);
502
+ this.changes = {};
503
+ }
504
+ save() {
505
+ if (this.isNewRecord()) {
506
+ return this.create();
507
+ } else {
508
+ return this.update();
509
+ }
510
+ }
511
+ saveRaw(rawData, options = {}) {
512
+ if (this.isNewRecord()) {
513
+ return this.createRaw(rawData, options);
514
+ } else {
515
+ return this.updateRaw(rawData, options);
516
+ }
517
+ }
518
+ async update(newAttributes, options) {
519
+ if (newAttributes) {
520
+ this.assignAttributes(newAttributes);
521
+ }
522
+ if (Object.keys(this.changes).length == 0) {
523
+ return {
524
+ model: this
525
+ };
526
+ }
527
+ const paramKey = this.modelClassData().paramKey;
528
+ const modelData = this.changes;
529
+ const dataToUse = {};
530
+ dataToUse[paramKey] = modelData;
531
+ let response;
532
+ try {
533
+ response = await CommandsPool.addCommand({
534
+ args: {
535
+ query_params: this.collection && this.collection.params(),
536
+ save: dataToUse
537
+ },
538
+ command: `${this.modelClassData().collectionName}-update`,
539
+ collectionName: this.modelClassData().collectionName,
540
+ primaryKey: this.primaryKey(),
541
+ type: "update"
542
+ }, {});
543
+ } catch (error) {
544
+ BaseModel.parseValidationErrors({
545
+ error,
546
+ model: this,
547
+ options
548
+ });
549
+ throw error;
550
+ }
551
+ if (response.success) {
552
+ if (response.model) {
553
+ this._refreshModelFromResponse(response);
554
+ this.changes = {};
555
+ }
556
+ return {
557
+ response,
558
+ model: this
559
+ };
560
+ } else {
561
+ this.handleResponseError(response);
562
+ }
563
+ }
564
+ _refreshModelFromResponse(response) {
565
+ let newModel = digg(response, "model");
566
+ if (Array.isArray(newModel)) newModel = newModel[0];
567
+ this.setNewModel(newModel);
568
+ }
569
+ _refreshModelDataFromResponse(response) {
570
+ let newModel = digg(response, "model");
571
+ if (Array.isArray(newModel)) newModel = newModel[0];
572
+ this.setNewModelData(newModel);
573
+ }
574
+ static _objectDataFromGivenRawData(rawData, options) {
575
+ if (rawData instanceof FormData || rawData.nodeName == "FORM") {
576
+ const formData = FormDataObjectizer.formDataFromObject(rawData, options);
577
+ return FormDataObjectizer.toObject(formData);
578
+ }
579
+ return rawData;
580
+ }
581
+ async updateRaw(rawData, options = {}) {
582
+ const objectData = BaseModel._objectDataFromGivenRawData(rawData, options);
583
+ let response;
584
+ try {
585
+ response = await CommandsPool.addCommand({
586
+ args: {
587
+ query_params: this.collection && this.collection.params(),
588
+ save: objectData,
589
+ simple_model_errors: options?.simpleModelErrors
590
+ },
591
+ command: `${this.modelClassData().collectionName}-update`,
592
+ collectionName: this.modelClassData().collectionName,
593
+ primaryKey: this.primaryKey(),
594
+ type: "update"
595
+ }, {});
596
+ } catch (error) {
597
+ BaseModel.parseValidationErrors({
598
+ error,
599
+ model: this,
600
+ options
601
+ });
602
+ throw error;
603
+ }
604
+ if (response.model) {
605
+ this._refreshModelFromResponse(response);
606
+ this.changes = {};
607
+ }
608
+ return {
609
+ response,
610
+ model: this
611
+ };
612
+ }
613
+ isValid() {
614
+ throw new Error("Not implemented yet");
615
+ }
616
+ async isValidOnServer() {
617
+ const modelData = this.getAttributes();
618
+ const paramKey = this.modelClassData().paramKey;
619
+ const dataToUse = {};
620
+ dataToUse[paramKey] = modelData;
621
+ const response = await CommandsPool.addCommand({
622
+ args: {
623
+ save: dataToUse
624
+ },
625
+ command: `${this.modelClassData().collectionName}-valid`,
626
+ collectionName: this.modelClassData().collectionName,
627
+ primaryKey: this.primaryKey(),
628
+ type: "valid"
629
+ }, {});
630
+ return {
631
+ valid: response.valid,
632
+ errors: response.errors
633
+ };
634
+ }
635
+ modelClass = () => this.constructor;
636
+ preloadRelationship(relationshipName, model) {
637
+ this.relationshipsCache[BaseModel.snakeCase(relationshipName)] = model;
638
+ this.relationships[BaseModel.snakeCase(relationshipName)] = model;
639
+ }
640
+ markForDestruction() {
641
+ this._markedForDestruction = true;
642
+ }
643
+ markedForDestruction = () => this._markedForDestruction;
644
+ uniqueKey() {
645
+ if (!this.uniqueKeyValue) {
646
+ const min = 5000000000000000;
647
+ const max = 9007199254740991;
648
+ const randomBetween = Math.floor(Math.random() * (max - min + 1) + min);
649
+ this.uniqueKeyValue = randomBetween;
650
+ }
651
+ return this.uniqueKeyValue;
652
+ }
653
+ static async _callCollectionCommand(args, commandArgs) {
654
+ const formOrDataObject = args.args;
655
+ try {
656
+ return await CommandsPool.addCommand(args, commandArgs);
657
+ } catch (error) {
658
+ let form;
659
+ if (commandArgs.form) {
660
+ form = commandArgs.form;
661
+ } else if (formOrDataObject?.nodeName == "FORM") {
662
+ form = formOrDataObject;
663
+ }
664
+ if (form) BaseModel.parseValidationErrors({
665
+ error,
666
+ options: {
667
+ form
668
+ }
669
+ });
670
+ throw error;
671
+ }
672
+ }
673
+ _callMemberCommand = (args, commandArgs) => CommandsPool.addCommand(args, commandArgs);
674
+ static _postDataFromArgs(args) {
675
+ let postData;
676
+ if (args) {
677
+ if (args instanceof FormData) {
678
+ postData = args;
679
+ } else {
680
+ postData = objectToFormData.serialize(args, {}, null, "args");
681
+ }
682
+ } else {
683
+ postData = new FormData();
684
+ }
685
+ return postData;
686
+ }
687
+ readAttribute(attributeName) {
688
+ const attributeNameUnderscore = inflection.underscore(attributeName);
689
+ return this.readAttributeUnderscore(attributeNameUnderscore);
690
+ }
691
+ readAttributeUnderscore(attributeName) {
692
+ if (attributeName in this.changes) {
693
+ return this.changes[attributeName];
694
+ } else if (attributeName in this.modelData) {
695
+ return this.modelData[attributeName];
696
+ } else if (this.isNewRecord()) {
697
+ // Return null if this is a new record and the attribute name is a recognized attribute
698
+ const attributes = digg(this.modelClassData(), "attributes");
699
+ if (attributeName in attributes) return null;
700
+ }
701
+ if (this.isPersisted()) {
702
+ throw new AttributeNotLoadedError(`No such attribute: ${digg(this.modelClassData(), "name")}#${attributeName}: ${JSON.stringify(this.modelData)}`);
703
+ }
704
+ }
705
+ isAttributeLoaded(attributeName) {
706
+ const attributeNameUnderscore = inflection.underscore(attributeName);
707
+ if (attributeNameUnderscore in this.changes) return true;
708
+ if (attributeNameUnderscore in this.modelData) return true;
709
+ return false;
710
+ }
711
+ _isPresent(value) {
712
+ if (!value) {
713
+ return false;
714
+ } else if (typeof value == "string" && value.match(/^\s*$/)) {
715
+ return false;
716
+ }
717
+ return true;
718
+ }
719
+ async _loadBelongsToReflection(args, queryArgs = {}) {
720
+ if (args.reflectionName in this.relationships) {
721
+ return this.relationships[args.reflectionName];
722
+ } else if (args.reflectionName in this.relationshipsCache) {
723
+ return this.relationshipsCache[args.reflectionName];
724
+ } else {
725
+ const collection = new Collection(args, queryArgs);
726
+ const model = await collection.first();
727
+ this.relationshipsCache[args.reflectionName] = model;
728
+ return model;
729
+ }
730
+ }
731
+ _readBelongsToReflection({
732
+ reflectionName
733
+ }) {
734
+ if (reflectionName in this.relationships) {
735
+ return this.relationships[reflectionName];
736
+ } else if (reflectionName in this.relationshipsCache) {
737
+ return this.relationshipsCache[reflectionName];
738
+ }
739
+ if (this.isNewRecord()) return null;
740
+ const loadedRelationships = Object.keys(this.relationshipsCache);
741
+ const modelClassName = digg(this.modelClassData(), "name");
742
+ throw new NotLoadedError(`${modelClassName}#${reflectionName} hasn't been loaded yet. Only these were loaded: ${loadedRelationships.join(", ")}`);
743
+ }
744
+ async _loadHasManyReflection(args, queryArgs = {}) {
745
+ if (args.reflectionName in this.relationships) {
746
+ return this.relationships[args.reflectionName];
747
+ } else if (args.reflectionName in this.relationshipsCache) {
748
+ return this.relationshipsCache[args.reflectionName];
749
+ }
750
+ const collection = new Collection(args, queryArgs);
751
+ const models = await collection.toArray();
752
+ this.relationshipsCache[args.reflectionName] = models;
753
+ return models;
754
+ }
755
+ async _loadHasOneReflection(args, queryArgs = {}) {
756
+ if (args.reflectionName in this.relationships) {
757
+ return this.relationships[args.reflectionName];
758
+ } else if (args.reflectionName in this.relationshipsCache) {
759
+ return this.relationshipsCache[args.reflectionName];
760
+ } else {
761
+ const collection = new Collection(args, queryArgs);
762
+ const model = await collection.first();
763
+ this.relationshipsCache[args.reflectionName] = model;
764
+ return model;
765
+ }
766
+ }
767
+ _readHasOneReflection({
768
+ reflectionName
769
+ }) {
770
+ if (reflectionName in this.relationships) {
771
+ return this.relationships[reflectionName];
772
+ } else if (reflectionName in this.relationshipsCache) {
773
+ return this.relationshipsCache[reflectionName];
774
+ }
775
+ if (this.isNewRecord()) {
776
+ return null;
777
+ }
778
+ const loadedRelationships = Object.keys(this.relationshipsCache);
779
+ const modelClassName = digg(this.modelClassData(), "name");
780
+ throw new NotLoadedError(`${modelClassName}#${reflectionName} hasn't been loaded yet. Only these were loaded: ${loadedRelationships.join(", ")}`);
781
+ }
782
+ _readModelDataFromArgs(args) {
783
+ this.abilities = args.data.b || {};
784
+ this.collection = args.collection;
785
+ this.modelData = objectToUnderscore(args.data.a);
786
+ this.preloadedRelationships = args.data.r;
787
+ }
788
+ _readPreloadedRelationships(preloaded) {
789
+ if (!this.preloadedRelationships) {
790
+ return;
791
+ }
792
+ const relationships = digg(this.modelClassData(), "relationships");
793
+ for (const relationshipName in this.preloadedRelationships) {
794
+ const relationshipData = this.preloadedRelationships[relationshipName];
795
+ const relationshipClassData = relationships.find(relationship => digg(relationship, "name") == relationshipName);
796
+ if (!relationshipClassData) {
797
+ const modelName = digg(this.modelClassData(), "name");
798
+ const relationshipsList = relationships.map(relationship => relationship.name).join(", ");
799
+ throw new Error(`Could not find the relation ${relationshipName} on the ${modelName} model: ${relationshipsList}`);
800
+ }
801
+ const relationshipType = digg(relationshipClassData, "collectionName");
802
+ if (relationshipName in this.relationshipsCache) {
803
+ throw new Error(`${relationshipName} has already been loaded`);
804
+ }
805
+ if (!relationshipClassData) {
806
+ throw new Error(`No relationship on ${digg(this.modelClassData(), "name")} by that name: ${relationshipName}`);
807
+ }
808
+ if (!relationshipData) {
809
+ this.relationshipsCache[relationshipName] = null;
810
+ this.relationships[relationshipName] = null;
811
+ } else if (Array.isArray(relationshipData)) {
812
+ this.relationshipsCache[relationshipName] = [];
813
+ this.relationships[relationshipName] = [];
814
+ for (const relationshipId of relationshipData) {
815
+ const model = preloaded.getModel(relationshipType, relationshipId);
816
+ this.relationshipsCache[relationshipName].push(model);
817
+ this.relationships[relationshipName].push(model);
818
+ }
819
+ } else {
820
+ const model = preloaded.getModel(relationshipType, relationshipData);
821
+ this.relationshipsCache[relationshipName] = model;
822
+ this.relationships[relationshipName] = model;
823
+ }
824
+ }
825
+ }
826
+ primaryKey = () => this.readAttributeUnderscore(this.constructor.primaryKey());
827
+ }
828
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJBdHRyaWJ1dGUiLCJBdHRyaWJ1dGVOb3RMb2FkZWRFcnJvciIsIkNhY2hlS2V5R2VuZXJhdG9yIiwiQ29sbGVjdGlvbiIsIkNvbW1hbmRzUG9vbCIsIkNvbmZpZyIsIkN1c3RvbUVycm9yIiwiZGlnZyIsIkZvcm1EYXRhT2JqZWN0aXplciIsImluZmxlY3Rpb24iLCJNb2RlbE5hbWUiLCJOb3RMb2FkZWRFcnJvciIsIm9iamVjdFRvRm9ybURhdGEiLCJSZWZsZWN0aW9uIiwiU2NvcGUiLCJTZXJ2aWNlcyIsIlZhbGlkYXRpb25FcnJvciIsIlZhbGlkYXRpb25FcnJvcnMiLCJvYmplY3RUb1VuZGVyc2NvcmUiLCJvYmplY3QiLCJuZXdPYmplY3QiLCJrZXkiLCJ1bmRlcnNjb3JlS2V5IiwidW5kZXJzY29yZSIsIkJhc2VNb2RlbCIsImFwaU1ha2VyVHlwZSIsImF0dHJpYnV0ZXMiLCJtb2RlbENsYXNzRGF0YSIsInJlc3VsdCIsImF0dHJpYnV0ZUtleSIsImF0dHJpYnV0ZURhdGEiLCJhdHRyaWJ1dGUiLCJwdXNoIiwiaGFzQXR0cmlidXRlIiwiYXR0cmlidXRlTmFtZSIsImxvd2VyQ2FzZUF0dHJpYnV0ZU5hbWUiLCJFcnJvciIsIm5ld0N1c3RvbUV2ZW50IiwidmFsaWRhdGlvbkVycm9ycyIsIkN1c3RvbUV2ZW50IiwiZGV0YWlsIiwic2VuZFZhbGlkYXRpb25FcnJvcnNFdmVudCIsIm9wdGlvbnMiLCJmb3JtIiwiZXZlbnQiLCJkaXNwYXRjaEV2ZW50IiwiZmluZCIsImlkIiwicXVlcnkiLCJwcmltYXJ5S2V5IiwibW9kZWwiLCJyYW5zYWNrIiwiZmlyc3QiLCJmaW5kT3JDcmVhdGVCeSIsImZpbmRPckNyZWF0ZUJ5QXJncyIsImFyZ3MiLCJjdXJyZW50Iiwic2VuZFJlcXVlc3QiLCJhZGRpdGlvbmFsX2RhdGEiLCJhZGRpdGlvbmFsRGF0YSIsImZpbmRfb3JfY3JlYXRlX2J5X2FyZ3MiLCJyZXNvdXJjZV9uYW1lIiwibW9kZWxOYW1lIiwibW9kZWxDbGFzcyIsInNlbGVjdCIsInJhbnNhY2thYmxlQXNzb2NpYXRpb25zIiwicmVsYXRpb25zaGlwcyIsInJlZmxlY3Rpb25zIiwicmVsYXRpb25zaGlwRGF0YSIsInJhbnNhY2thYmxlQXR0cmlidXRlcyIsInJhbnNhY2thYmxlU2NvcGVzIiwic2NvcGVEYXRhIiwic2NvcGUiLCJyZWZsZWN0aW9uIiwibmFtZSIsImZvdW5kUmVmbGVjdGlvbiIsIm1hcCIsImpvaW4iLCJfdG9rZW4iLCJjc3JmVG9rZW5FbGVtZW50IiwiZG9jdW1lbnQiLCJxdWVyeVNlbGVjdG9yIiwiZ2V0QXR0cmlidXRlIiwiY29uc3RydWN0b3IiLCJjaGFuZ2VzIiwibmV3UmVjb3JkIiwiaXNOZXdSZWNvcmQiLCJyZWxhdGlvbnNoaXBzQ2FjaGUiLCJkYXRhIiwiYSIsIl9yZWFkTW9kZWxEYXRhRnJvbUFyZ3MiLCJhYmlsaXRpZXMiLCJiIiwibW9kZWxEYXRhIiwiYXNzaWduQXR0cmlidXRlcyIsIm5ld0F0dHJpYnV0ZXMiLCJuZXdWYWx1ZSIsImF0dHJpYnV0ZVVuZGVyc2NvcmUiLCJhcHBseUNoYW5nZSIsImRlbGV0ZUNoYW5nZSIsImlzQXR0cmlidXRlTG9hZGVkIiwib2xkVmFsdWUiLCJyZWFkQXR0cmlidXRlIiwib3JpZ2luYWxWYWx1ZSIsImNhbiIsImdpdmVuQWJpbGl0eU5hbWUiLCJhYmlsaXR5TmFtZSIsImNsb25lIiwiY2FjaGVLZXkiLCJpc1BlcnNpc3RlZCIsImtleVBhcnRzIiwicGFyYW1LZXkiLCJ1cGRhdGVkQXQiLCJnZXRUaW1lIiwidW5pcXVlS2V5IiwibG9jYWxDYWNoZUtleSIsImNhY2hlS2V5R2VuZXJhdG9yIiwibG9jYWwiLCJmdWxsQ2FjaGVLZXkiLCJhbGwiLCJjcmVhdGUiLCJnZXRBdHRyaWJ1dGVzIiwiZGF0YVRvVXNlIiwicmVzcG9uc2UiLCJhZGRDb21tYW5kIiwic2F2ZSIsImNvbW1hbmQiLCJjb2xsZWN0aW9uTmFtZSIsInR5cGUiLCJlcnJvciIsInBhcnNlVmFsaWRhdGlvbkVycm9ycyIsIl9yZWZyZXNoTW9kZWxGcm9tUmVzcG9uc2UiLCJjcmVhdGVSYXciLCJyYXdEYXRhIiwib2JqZWN0RGF0YSIsIl9vYmplY3REYXRhRnJvbUdpdmVuUmF3RGF0YSIsIl9yZWZyZXNoTW9kZWxEYXRhRnJvbVJlc3BvbnNlIiwiZGVzdHJveSIsInF1ZXJ5X3BhcmFtcyIsImNvbGxlY3Rpb24iLCJwYXJhbXMiLCJzdWNjZXNzIiwiaGFuZGxlUmVzcG9uc2VFcnJvciIsImVuc3VyZUFiaWxpdGllcyIsImxpc3RPZkFiaWxpdGllcyIsImFiaWxpdGllc1RvTG9hZCIsImFiaWxpdHlJbkxpc3QiLCJsZW5ndGgiLCJwcmltYXJ5S2V5TmFtZSIsInJhbnNhY2tQYXJhbXMiLCJhYmlsaXRpZXNQYXJhbXMiLCJhbm90aGVyTW9kZWwiLCJuZXdBYmlsaXRpZXMiLCJuZXdBYmlsaXR5IiwiT2JqZWN0IiwiYXNzaWduIiwiaWRlbnRpZmllcktleSIsIl9pZGVudGlmaWVyS2V5IiwiaXNBc3NvY2lhdGlvbkxvYWRlZCIsImFzc29jaWF0aW9uTmFtZSIsImlzQXNzb2NpYXRpb25Mb2FkZWRVbmRlcnNjb3JlIiwiYXNzb2NpYXRpb25OYW1lVW5kZXJzY29yZSIsImlzQXNzb2NpYXRpb25QcmVzZW50IiwidmFsaWRhdGlvbl9lcnJvcnMiLCJ0aHJvd1ZhbGlkYXRpb25FcnJvciIsImh1bWFuQXR0cmlidXRlTmFtZSIsImtleU5hbWUiLCJpMThuIiwiZ2V0STE4biIsInQiLCJzbmFrZUNhc2UiLCJkZWZhdWx0VmFsdWUiLCJodW1hbml6ZSIsImlzQXR0cmlidXRlQ2hhbmdlZCIsImF0dHJpYnV0ZU5hbWVVbmRlcnNjb3JlIiwiYXR0cmlidXRlTmFtZXMiLCJjaGFuZ2VkTWV0aG9kIiwiY2FtZWxpemUiLCJpc0NoYW5nZWQiLCJrZXlzIiwidW5kZWZpbmVkIiwic3RyaW5nIiwic2F2ZWRDaGFuZ2VUb0F0dHJpYnV0ZSIsInByZXZpb3VzTW9kZWxEYXRhIiwiY2hhbmdlZE1ldGhvZE5hbWUiLCJzZXROZXdNb2RlbCIsInNldE5ld01vZGVsRGF0YSIsInJlbGF0aW9uc2hpcE5hbWUiLCJyZWxhdGlvbnNoaXBDYWNoZU5hbWUiLCJKU09OIiwic3RyaW5naWZ5IiwiX2lzRGF0ZUNoYW5nZWQiLCJEYXRlIiwicGFyc2UiLCJfaXNJbnRlZ2VyQ2hhbmdlZCIsInBhcnNlSW50IiwiX2lzU3RyaW5nQ2hhbmdlZCIsIm9sZENvbnZlcnRlZFZhbHVlIiwibmV3Q29udmVydGVkVmFsdWUiLCJyZWxvYWQiLCJwcmVsb2FkIiwicXVlcnlBcmdzIiwic2VsZWN0X2NvbHVtbnMiLCJzZWxlY3RDb2x1bW5zIiwidXBkYXRlIiwic2F2ZVJhdyIsInVwZGF0ZVJhdyIsIm5ld01vZGVsIiwiQXJyYXkiLCJpc0FycmF5IiwiRm9ybURhdGEiLCJub2RlTmFtZSIsImZvcm1EYXRhIiwiZm9ybURhdGFGcm9tT2JqZWN0IiwidG9PYmplY3QiLCJzaW1wbGVfbW9kZWxfZXJyb3JzIiwic2ltcGxlTW9kZWxFcnJvcnMiLCJpc1ZhbGlkIiwiaXNWYWxpZE9uU2VydmVyIiwidmFsaWQiLCJlcnJvcnMiLCJwcmVsb2FkUmVsYXRpb25zaGlwIiwibWFya0ZvckRlc3RydWN0aW9uIiwiX21hcmtlZEZvckRlc3RydWN0aW9uIiwibWFya2VkRm9yRGVzdHJ1Y3Rpb24iLCJ1bmlxdWVLZXlWYWx1ZSIsIm1pbiIsIm1heCIsInJhbmRvbUJldHdlZW4iLCJNYXRoIiwiZmxvb3IiLCJyYW5kb20iLCJfY2FsbENvbGxlY3Rpb25Db21tYW5kIiwiY29tbWFuZEFyZ3MiLCJmb3JtT3JEYXRhT2JqZWN0IiwiX2NhbGxNZW1iZXJDb21tYW5kIiwiX3Bvc3REYXRhRnJvbUFyZ3MiLCJwb3N0RGF0YSIsInNlcmlhbGl6ZSIsInJlYWRBdHRyaWJ1dGVVbmRlcnNjb3JlIiwiX2lzUHJlc2VudCIsInZhbHVlIiwibWF0Y2giLCJfbG9hZEJlbG9uZ3NUb1JlZmxlY3Rpb24iLCJyZWZsZWN0aW9uTmFtZSIsIl9yZWFkQmVsb25nc1RvUmVmbGVjdGlvbiIsImxvYWRlZFJlbGF0aW9uc2hpcHMiLCJtb2RlbENsYXNzTmFtZSIsIl9sb2FkSGFzTWFueVJlZmxlY3Rpb24iLCJtb2RlbHMiLCJ0b0FycmF5IiwiX2xvYWRIYXNPbmVSZWZsZWN0aW9uIiwiX3JlYWRIYXNPbmVSZWZsZWN0aW9uIiwicHJlbG9hZGVkUmVsYXRpb25zaGlwcyIsInIiLCJfcmVhZFByZWxvYWRlZFJlbGF0aW9uc2hpcHMiLCJwcmVsb2FkZWQiLCJyZWxhdGlvbnNoaXBDbGFzc0RhdGEiLCJyZWxhdGlvbnNoaXAiLCJyZWxhdGlvbnNoaXBzTGlzdCIsInJlbGF0aW9uc2hpcFR5cGUiLCJyZWxhdGlvbnNoaXBJZCIsImdldE1vZGVsIl0sInNvdXJjZXMiOlsiLi4vc3JjL2Jhc2UtbW9kZWwuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEF0dHJpYnV0ZSBmcm9tIFwiLi9iYXNlLW1vZGVsL2F0dHJpYnV0ZVwiXG5pbXBvcnQgQXR0cmlidXRlTm90TG9hZGVkRXJyb3IgZnJvbSBcIi4vYXR0cmlidXRlLW5vdC1sb2FkZWQtZXJyb3JcIlxuaW1wb3J0IENhY2hlS2V5R2VuZXJhdG9yIGZyb20gXCIuL2NhY2hlLWtleS1nZW5lcmF0b3JcIlxuaW1wb3J0IENvbGxlY3Rpb24gZnJvbSBcIi4vY29sbGVjdGlvblwiXG5pbXBvcnQgQ29tbWFuZHNQb29sIGZyb20gXCIuL2NvbW1hbmRzLXBvb2xcIlxuaW1wb3J0IENvbmZpZyBmcm9tIFwiLi9jb25maWdcIlxuaW1wb3J0IEN1c3RvbUVycm9yIGZyb20gXCIuL2N1c3RvbS1lcnJvclwiXG5pbXBvcnQge2RpZ2d9IGZyb20gXCJkaWdnZXJpemVcIlxuaW1wb3J0IEZvcm1EYXRhT2JqZWN0aXplciBmcm9tIFwiZm9ybS1kYXRhLW9iamVjdGl6ZXJcIlxuaW1wb3J0ICogYXMgaW5mbGVjdGlvbiBmcm9tIFwiaW5mbGVjdGlvblwiXG5pbXBvcnQgTW9kZWxOYW1lIGZyb20gXCIuL21vZGVsLW5hbWVcIlxuaW1wb3J0IE5vdExvYWRlZEVycm9yIGZyb20gXCIuL25vdC1sb2FkZWQtZXJyb3JcIlxuaW1wb3J0IG9iamVjdFRvRm9ybURhdGEgZnJvbSBcIm9iamVjdC10by1mb3JtZGF0YVwiXG5pbXBvcnQgUmVmbGVjdGlvbiBmcm9tIFwiLi9iYXNlLW1vZGVsL3JlZmxlY3Rpb25cIlxuaW1wb3J0IFNjb3BlIGZyb20gXCIuL2Jhc2UtbW9kZWwvc2NvcGVcIlxuaW1wb3J0IFNlcnZpY2VzIGZyb20gXCIuL3NlcnZpY2VzXCJcbmltcG9ydCBWYWxpZGF0aW9uRXJyb3IgZnJvbSBcIi4vdmFsaWRhdGlvbi1lcnJvclwiXG5pbXBvcnQge1ZhbGlkYXRpb25FcnJvcnN9IGZyb20gXCIuL3ZhbGlkYXRpb24tZXJyb3JzXCJcblxuY29uc3Qgb2JqZWN0VG9VbmRlcnNjb3JlID0gKG9iamVjdCkgPT4ge1xuICBjb25zdCBuZXdPYmplY3QgPSB7fVxuXG4gIGZvciAoY29uc3Qga2V5IGluIG9iamVjdCkge1xuICAgIGNvbnN0IHVuZGVyc2NvcmVLZXkgPSBpbmZsZWN0aW9uLnVuZGVyc2NvcmUoa2V5KVxuXG4gICAgbmV3T2JqZWN0W3VuZGVyc2NvcmVLZXldID0gb2JqZWN0W2tleV1cbiAgfVxuXG4gIHJldHVybiBuZXdPYmplY3Rcbn1cblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQmFzZU1vZGVsIHtcbiAgc3RhdGljIGFwaU1ha2VyVHlwZSA9IFwiQmFzZU1vZGVsXCJcblxuICBzdGF0aWMgYXR0cmlidXRlcygpIHtcbiAgICBjb25zdCBhdHRyaWJ1dGVzID0gZGlnZyh0aGlzLm1vZGVsQ2xhc3NEYXRhKCksIFwiYXR0cmlidXRlc1wiKVxuICAgIGNvbnN0IHJlc3VsdCA9IFtdXG5cbiAgICBmb3IgKGNvbnN0IGF0dHJpYnV0ZUtleSBpbiBhdHRyaWJ1dGVzKSB7XG4gICAgICBjb25zdCBhdHRyaWJ1dGVEYXRhID0gYXR0cmlidXRlc1thdHRyaWJ1dGVLZXldXG4gICAgICBjb25zdCBhdHRyaWJ1dGUgPSBuZXcgQXR0cmlidXRlKGF0dHJpYnV0ZURhdGEpXG5cbiAgICAgIHJlc3VsdC5wdXNoKGF0dHJpYnV0ZSlcbiAgICB9XG5cbiAgICByZXR1cm4gcmVzdWx0XG4gIH1cblxuICBzdGF0aWMgaGFzQXR0cmlidXRlKGF0dHJpYnV0ZU5hbWUpIHtcbiAgICBjb25zdCBhdHRyaWJ1dGVzID0gZGlnZyh0aGlzLm1vZGVsQ2xhc3NEYXRhKCksIFwiYXR0cmlidXRlc1wiKVxuICAgIGNvbnN0IGxvd2VyQ2FzZUF0dHJpYnV0ZU5hbWUgPSBpbmZsZWN0aW9uLnVuZGVyc2NvcmUoYXR0cmlidXRlTmFtZSlcblxuICAgIGlmIChsb3dlckNhc2VBdHRyaWJ1dGVOYW1lIGluIGF0dHJpYnV0ZXMpIHJldHVybiB0cnVlXG5cbiAgICByZXR1cm4gZmFsc2VcbiAgfVxuXG4gIHN0YXRpYyBtb2RlbENsYXNzRGF0YSgpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXCJtb2RlbENsYXNzRGF0YSBzaG91bGQgYmUgb3ZlcnJpZGVuIGJ5IGNoaWxkXCIpXG4gIH1cblxuICBzdGF0aWMgbmV3Q3VzdG9tRXZlbnQgPSAodmFsaWRhdGlvbkVycm9ycykgPT4ge1xuICAgIHJldHVybiBuZXcgQ3VzdG9tRXZlbnQoXCJ2YWxpZGF0aW9uLWVycm9yc1wiLCB7ZGV0YWlsOiB2YWxpZGF0aW9uRXJyb3JzfSlcbiAgfVxuXG4gIHN0YXRpYyBzZW5kVmFsaWRhdGlvbkVycm9yc0V2ZW50ID0gKHZhbGlkYXRpb25FcnJvcnMsIG9wdGlvbnMpID0+IHtcbiAgICBpZiAob3B0aW9ucyAmJiBvcHRpb25zLmZvcm0pIHtcbiAgICAgIGNvbnN0IGV2ZW50ID0gQmFzZU1vZGVsLm5ld0N1c3RvbUV2ZW50KHZhbGlkYXRpb25FcnJvcnMpXG4gICAgICBvcHRpb25zLmZvcm0uZGlzcGF0Y2hFdmVudChldmVudClcbiAgICB9XG4gIH1cblxuICBzdGF0aWMgYXN5bmMgZmluZChpZCkge1xuICAgIGNvbnN0IHF1ZXJ5ID0ge31cblxuICAgIHF1ZXJ5W2Ake3RoaXMucHJpbWFyeUtleSgpfV9lcWBdID0gaWRcblxuICAgIGNvbnN0IG1vZGVsID0gYXdhaXQgdGhpcy5yYW5zYWNrKHF1ZXJ5KS5maXJzdCgpXG5cbiAgICBpZiAobW9kZWwpIHtcbiAgICAgIHJldHVybiBtb2RlbFxuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgQ3VzdG9tRXJyb3IoXCJSZWNvcmQgbm90IGZvdW5kXCIpXG4gICAgfVxuICB9XG5cbiAgc3RhdGljIGFzeW5jIGZpbmRPckNyZWF0ZUJ5KGZpbmRPckNyZWF0ZUJ5QXJncywgYXJncyA9IHt9KSB7XG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgU2VydmljZXMuY3VycmVudCgpLnNlbmRSZXF1ZXN0KFwiTW9kZWxzOjpGaW5kT3JDcmVhdGVCeVwiLCB7XG4gICAgICBhZGRpdGlvbmFsX2RhdGE6IGFyZ3MuYWRkaXRpb25hbERhdGEsXG4gICAgICBmaW5kX29yX2NyZWF0ZV9ieV9hcmdzOiBmaW5kT3JDcmVhdGVCeUFyZ3MsXG4gICAgICByZXNvdXJjZV9uYW1lOiBkaWdnKHRoaXMubW9kZWxDbGFzc0RhdGEoKSwgXCJuYW1lXCIpXG4gICAgfSlcbiAgICBjb25zdCBtb2RlbCA9IGRpZ2cocmVzdWx0LCBcIm1vZGVsXCIpXG5cbiAgICByZXR1cm4gbW9kZWxcbiAgfVxuXG4gIHN0YXRpYyBtb2RlbE5hbWUoKSB7XG4gICAgcmV0dXJuIG5ldyBNb2RlbE5hbWUoe21vZGVsQ2xhc3NEYXRhOiB0aGlzLm1vZGVsQ2xhc3NEYXRhKCl9KVxuICB9XG5cbiAgc3RhdGljIHByaW1hcnlLZXkoKSB7XG4gICAgcmV0dXJuIGRpZ2codGhpcy5tb2RlbENsYXNzRGF0YSgpLCBcInByaW1hcnlLZXlcIilcbiAgfVxuXG4gIHN0YXRpYyByYW5zYWNrKHF1ZXJ5ID0ge30pIHtcbiAgICByZXR1cm4gbmV3IENvbGxlY3Rpb24oe21vZGVsQ2xhc3M6IHRoaXN9LCB7cmFuc2FjazogcXVlcnl9KVxuICB9XG5cbiAgc3RhdGljIHNlbGVjdChzZWxlY3QpIHtcbiAgICByZXR1cm4gdGhpcy5yYW5zYWNrKCkuc2VsZWN0KHNlbGVjdClcbiAgfVxuXG4gIHN0YXRpYyByYW5zYWNrYWJsZUFzc29jaWF0aW9ucygpIHtcbiAgICBjb25zdCByZWxhdGlvbnNoaXBzID0gZGlnZyh0aGlzLm1vZGVsQ2xhc3NEYXRhKCksIFwicmFuc2Fja2FibGVfYXNzb2NpYXRpb25zXCIpXG4gICAgY29uc3QgcmVmbGVjdGlvbnMgPSBbXVxuXG4gICAgZm9yIChjb25zdCByZWxhdGlvbnNoaXBEYXRhIG9mIHJlbGF0aW9uc2hpcHMpIHtcbiAgICAgIHJlZmxlY3Rpb25zLnB1c2gobmV3IFJlZmxlY3Rpb24ocmVsYXRpb25zaGlwRGF0YSkpXG4gICAgfVxuXG4gICAgcmV0dXJuIHJlZmxlY3Rpb25zXG4gIH1cblxuICBzdGF0aWMgcmFuc2Fja2FibGVBdHRyaWJ1dGVzKCkge1xuICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSBkaWdnKHRoaXMubW9kZWxDbGFzc0RhdGEoKSwgXCJyYW5zYWNrYWJsZV9hdHRyaWJ1dGVzXCIpXG4gICAgY29uc3QgcmVzdWx0ID0gW11cblxuICAgIGZvciAoY29uc3QgYXR0cmlidXRlRGF0YSBvZiBhdHRyaWJ1dGVzKSB7XG4gICAgICByZXN1bHQucHVzaChuZXcgQXR0cmlidXRlKGF0dHJpYnV0ZURhdGEpKVxuICAgIH1cblxuICAgIHJldHVybiByZXN1bHRcbiAgfVxuXG4gIHN0YXRpYyByYW5zYWNrYWJsZVNjb3BlcygpIHtcbiAgICBjb25zdCByYW5zYWNrYWJsZVNjb3BlcyA9IGRpZ2codGhpcy5tb2RlbENsYXNzRGF0YSgpLCBcInJhbnNhY2thYmxlX3Njb3Blc1wiKVxuICAgIGNvbnN0IHJlc3VsdCA9IFtdXG5cbiAgICBmb3IgKGNvbnN0IHNjb3BlRGF0YSBvZiByYW5zYWNrYWJsZVNjb3Blcykge1xuICAgICAgY29uc3Qgc2NvcGUgPSBuZXcgU2NvcGUoc2NvcGVEYXRhKVxuXG4gICAgICByZXN1bHQucHVzaChzY29wZSlcbiAgICB9XG5cbiAgICByZXR1cm4gcmVzdWx0XG4gIH1cblxuICBzdGF0aWMgcmVmbGVjdGlvbnMoKSB7XG4gICAgY29uc3QgcmVsYXRpb25zaGlwcyA9IGRpZ2codGhpcy5tb2RlbENsYXNzRGF0YSgpLCBcInJlbGF0aW9uc2hpcHNcIilcbiAgICBjb25zdCByZWZsZWN0aW9ucyA9IFtdXG5cbiAgICBmb3IgKGNvbnN0IHJlbGF0aW9uc2hpcERhdGEgb2YgcmVsYXRpb25zaGlwcykge1xuICAgICAgY29uc3QgcmVmbGVjdGlvbiA9IG5ldyBSZWZsZWN0aW9uKHJlbGF0aW9uc2hpcERhdGEpXG5cbiAgICAgIHJlZmxlY3Rpb25zLnB1c2gocmVmbGVjdGlvbilcbiAgICB9XG5cbiAgICByZXR1cm4gcmVmbGVjdGlvbnNcbiAgfVxuXG4gIHN0YXRpYyByZWZsZWN0aW9uKG5hbWUpIHtcbiAgICBjb25zdCBmb3VuZFJlZmxlY3Rpb24gPSB0aGlzLnJlZmxlY3Rpb25zKCkuZmluZCgocmVmbGVjdGlvbikgPT4gcmVmbGVjdGlvbi5uYW1lKCkgPT0gbmFtZSlcblxuICAgIGlmICghZm91bmRSZWZsZWN0aW9uKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYE5vIHN1Y2ggcmVmbGVjdGlvbjogJHtuYW1lfSBpbiAke3RoaXMucmVmbGVjdGlvbnMoKS5tYXAoKHJlZmxlY3Rpb24pID0+IHJlZmxlY3Rpb24ubmFtZSgpKS5qb2luKFwiLCBcIil9YClcbiAgICB9XG5cbiAgICByZXR1cm4gZm91bmRSZWZsZWN0aW9uXG4gIH1cblxuICBzdGF0aWMgX3Rva2VuKCkge1xuICAgIGNvbnN0IGNzcmZUb2tlbkVsZW1lbnQgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKFwibWV0YVtuYW1lPSdjc3JmLXRva2VuJ11cIilcblxuICAgIGlmIChjc3JmVG9rZW5FbGVtZW50KSB7XG4gICAgICByZXR1cm4gY3NyZlRva2VuRWxlbWVudC5nZXRBdHRyaWJ1dGUoXCJjb250ZW50XCIpXG4gICAgfVxuICB9XG5cbiAgY29uc3RydWN0b3IoYXJncyA9IHt9KSB7XG4gICAgdGhpcy5jaGFuZ2VzID0ge31cbiAgICB0aGlzLm5ld1JlY29yZCA9IGFyZ3MuaXNOZXdSZWNvcmRcbiAgICB0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZSA9IHt9XG4gICAgdGhpcy5yZWxhdGlvbnNoaXBzID0ge31cblxuICAgIGlmIChhcmdzICYmIGFyZ3MuZGF0YSAmJiBhcmdzLmRhdGEuYSkge1xuICAgICAgdGhpcy5fcmVhZE1vZGVsRGF0YUZyb21BcmdzKGFyZ3MpXG4gICAgfSBlbHNlIGlmIChhcmdzLmEpIHtcbiAgICAgIHRoaXMuYWJpbGl0aWVzID0gYXJncy5iIHx8IHt9XG4gICAgICB0aGlzLm1vZGVsRGF0YSA9IG9iamVjdFRvVW5kZXJzY29yZShhcmdzLmEpXG4gICAgfSBlbHNlIGlmIChhcmdzKSB7XG4gICAgICB0aGlzLmFiaWxpdGllcyA9IHt9XG4gICAgICB0aGlzLm1vZGVsRGF0YSA9IG9iamVjdFRvVW5kZXJzY29yZShhcmdzKVxuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmFiaWxpdGllcyA9IHt9XG4gICAgICB0aGlzLm1vZGVsRGF0YSA9IHt9XG4gICAgfVxuICB9XG5cbiAgYXNzaWduQXR0cmlidXRlcyhuZXdBdHRyaWJ1dGVzKSB7XG4gICAgZm9yIChjb25zdCBrZXkgaW4gbmV3QXR0cmlidXRlcykge1xuICAgICAgY29uc3QgbmV3VmFsdWUgPSBuZXdBdHRyaWJ1dGVzW2tleV1cbiAgICAgIGNvbnN0IGF0dHJpYnV0ZVVuZGVyc2NvcmUgPSBpbmZsZWN0aW9uLnVuZGVyc2NvcmUoa2V5KVxuXG4gICAgICBsZXQgYXBwbHlDaGFuZ2UgPSB0cnVlXG4gICAgICBsZXQgZGVsZXRlQ2hhbmdlID0gZmFsc2VcblxuICAgICAgaWYgKHRoaXMuaXNBdHRyaWJ1dGVMb2FkZWQoa2V5KSkge1xuICAgICAgICBjb25zdCBvbGRWYWx1ZSA9IHRoaXMucmVhZEF0dHJpYnV0ZShrZXkpXG4gICAgICAgIGNvbnN0IG9yaWdpbmFsVmFsdWUgPSB0aGlzLm1vZGVsRGF0YVthdHRyaWJ1dGVVbmRlcnNjb3JlXVxuXG4gICAgICAgIGlmIChuZXdWYWx1ZSA9PSBvbGRWYWx1ZSkge1xuICAgICAgICAgIGFwcGx5Q2hhbmdlID0gZmFsc2VcbiAgICAgICAgfSBlbHNlIGlmIChuZXdWYWx1ZSA9PSBvcmlnaW5hbFZhbHVlKSB7XG4gICAgICAgICAgYXBwbHlDaGFuZ2UgPSBmYWxzZVxuICAgICAgICAgIGRlbGV0ZUNoYW5nZSA9IHRydWVcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoYXBwbHlDaGFuZ2UpIHtcbiAgICAgICAgdGhpcy5jaGFuZ2VzW2F0dHJpYnV0ZVVuZGVyc2NvcmVdID0gbmV3VmFsdWVcbiAgICAgIH0gZWxzZSBpZiAoZGVsZXRlQ2hhbmdlKSB7XG4gICAgICAgIGRlbGV0ZSB0aGlzLmNoYW5nZXNbYXR0cmlidXRlVW5kZXJzY29yZV1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBhdHRyaWJ1dGVzKCkge1xuICAgIGNvbnN0IHJlc3VsdCA9IHt9XG5cbiAgICBmb3IgKGNvbnN0IGtleSBpbiB0aGlzLm1vZGVsRGF0YSkge1xuICAgICAgcmVzdWx0W2tleV0gPSB0aGlzLm1vZGVsRGF0YVtrZXldXG4gICAgfVxuXG4gICAgZm9yIChjb25zdCBrZXkgaW4gdGhpcy5jaGFuZ2VzKSB7XG4gICAgICByZXN1bHRba2V5XSA9IHRoaXMuY2hhbmdlc1trZXldXG4gICAgfVxuXG4gICAgcmV0dXJuIHJlc3VsdFxuICB9XG5cbiAgY2FuKGdpdmVuQWJpbGl0eU5hbWUpIHtcbiAgICBjb25zdCBhYmlsaXR5TmFtZSA9IGluZmxlY3Rpb24udW5kZXJzY29yZShnaXZlbkFiaWxpdHlOYW1lKVxuXG4gICAgaWYgKCEoYWJpbGl0eU5hbWUgaW4gdGhpcy5hYmlsaXRpZXMpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYEFiaWxpdHkgJHthYmlsaXR5TmFtZX0gaGFzbid0IGJlZW4gbG9hZGVkIGZvciAke2RpZ2codGhpcy5tb2RlbENsYXNzRGF0YSgpLCBcIm5hbWVcIil9YClcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy5hYmlsaXRpZXNbYWJpbGl0eU5hbWVdXG4gIH1cblxuICBjbG9uZSgpIHtcbiAgICBjb25zdCBjbG9uZSA9IG5ldyB0aGlzLmNvbnN0cnVjdG9yKClcblxuICAgIGNsb25lLmFiaWxpdGllcyA9IHsuLi50aGlzLmFiaWxpdGllc31cbiAgICBjbG9uZS5tb2RlbERhdGEgPSB7Li4udGhpcy5tb2RlbERhdGF9XG4gICAgY2xvbmUucmVsYXRpb25zaGlwcyA9IHsuLi50aGlzLnJlbGF0aW9uc2hpcHN9XG4gICAgY2xvbmUucmVsYXRpb25zaGlwc0NhY2hlID0gey4uLnRoaXMucmVsYXRpb25zaGlwc0NhY2hlfVxuXG4gICAgcmV0dXJuIGNsb25lXG4gIH1cblxuICBjYWNoZUtleSgpIHtcbiAgICBpZiAodGhpcy5pc1BlcnNpc3RlZCgpKSB7XG4gICAgICBjb25zdCBrZXlQYXJ0cyA9IFtcbiAgICAgICAgdGhpcy5tb2RlbENsYXNzRGF0YSgpLnBhcmFtS2V5LFxuICAgICAgICB0aGlzLnByaW1hcnlLZXkoKVxuICAgICAgXVxuXG4gICAgICBpZiAoXCJ1cGRhdGVkX2F0XCIgaW4gdGhpcy5tb2RlbERhdGEpIHtcbiAgICAgICAgY29uc3QgdXBkYXRlZEF0ID0gdGhpcy51cGRhdGVkQXQoKVxuXG4gICAgICAgIGlmICh0eXBlb2YgdXBkYXRlZEF0ICE9IFwib2JqZWN0XCIpIHtcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYHVwZGF0ZWRBdCB3YXNuJ3QgYW4gb2JqZWN0OiAke3R5cGVvZiB1cGRhdGVkQXR9YClcbiAgICAgICAgfSBlbHNlIGlmICghKFwiZ2V0VGltZVwiIGluIHVwZGF0ZWRBdCkpIHtcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYHVwZGF0ZWRBdCBkaWRuJ3Qgc3VwcG9ydCBnZXRUaW1lIHdpdGggY2xhc3M6ICR7dXBkYXRlZEF0LmNvbnN0cnVjdG9yICYmIHVwZGF0ZWRBdC5jb25zdHJ1Y3Rvci5uYW1lfWApXG4gICAgICAgIH1cblxuICAgICAgICBrZXlQYXJ0cy5wdXNoKGB1cGRhdGVkQXQtJHt0aGlzLnVwZGF0ZWRBdCgpLmdldFRpbWUoKX1gKVxuICAgICAgfVxuXG4gICAgICByZXR1cm4ga2V5UGFydHMuam9pbihcIi1cIilcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIHRoaXMudW5pcXVlS2V5KClcbiAgICB9XG4gIH1cblxuICBsb2NhbENhY2hlS2V5KCkge1xuICAgIGNvbnN0IGNhY2hlS2V5R2VuZXJhdG9yID0gbmV3IENhY2hlS2V5R2VuZXJhdG9yKHRoaXMpXG5cbiAgICByZXR1cm4gY2FjaGVLZXlHZW5lcmF0b3IubG9jYWwoKVxuICB9XG5cbiAgZnVsbENhY2hlS2V5KCkge1xuICAgIGNvbnN0IGNhY2hlS2V5R2VuZXJhdG9yID0gbmV3IENhY2hlS2V5R2VuZXJhdG9yKHRoaXMpXG5cbiAgICByZXR1cm4gY2FjaGVLZXlHZW5lcmF0b3IuY2FjaGVLZXkoKVxuICB9XG5cbiAgc3RhdGljIGFsbCgpIHtcbiAgICByZXR1cm4gdGhpcy5yYW5zYWNrKClcbiAgfVxuXG4gIGFzeW5jIGNyZWF0ZShhdHRyaWJ1dGVzLCBvcHRpb25zKSB7XG4gICAgaWYgKGF0dHJpYnV0ZXMpIHRoaXMuYXNzaWduQXR0cmlidXRlcyhhdHRyaWJ1dGVzKVxuICAgIGNvbnN0IHBhcmFtS2V5ID0gdGhpcy5tb2RlbENsYXNzRGF0YSgpLnBhcmFtS2V5XG4gICAgY29uc3QgbW9kZWxEYXRhID0gdGhpcy5nZXRBdHRyaWJ1dGVzKClcbiAgICBjb25zdCBkYXRhVG9Vc2UgPSB7fVxuICAgIGRhdGFUb1VzZVtwYXJhbUtleV0gPSBtb2RlbERhdGFcbiAgICBsZXQgcmVzcG9uc2VcblxuICAgIHRyeSB7XG4gICAgICByZXNwb25zZSA9IGF3YWl0IENvbW1hbmRzUG9vbC5hZGRDb21tYW5kKFxuICAgICAgICB7XG4gICAgICAgICAgYXJnczoge1xuICAgICAgICAgICAgc2F2ZTogZGF0YVRvVXNlXG4gICAgICAgICAgfSxcbiAgICAgICAgICBjb21tYW5kOiBgJHt0aGlzLm1vZGVsQ2xhc3NEYXRhKCkuY29sbGVjdGlvbk5hbWV9LWNyZWF0ZWAsXG4gICAgICAgICAgY29sbGVjdGlvbk5hbWU6IHRoaXMubW9kZWxDbGFzc0RhdGEoKS5jb2xsZWN0aW9uTmFtZSxcbiAgICAgICAgICBwcmltYXJ5S2V5OiB0aGlzLnByaW1hcnlLZXkoKSxcbiAgICAgICAgICB0eXBlOiBcImNyZWF0ZVwiXG4gICAgICAgIH0sXG4gICAgICAgIHt9XG4gICAgICApXG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIEJhc2VNb2RlbC5wYXJzZVZhbGlkYXRpb25FcnJvcnMoe2Vycm9yLCBtb2RlbDogdGhpcywgb3B0aW9uc30pXG4gICAgICB0aHJvdyBlcnJvclxuICAgIH1cblxuICAgIGlmIChyZXNwb25zZS5tb2RlbCkge1xuICAgICAgdGhpcy5fcmVmcmVzaE1vZGVsRnJvbVJlc3BvbnNlKHJlc3BvbnNlKVxuICAgICAgdGhpcy5jaGFuZ2VzID0ge31cbiAgICB9XG5cbiAgICByZXR1cm4ge21vZGVsOiB0aGlzLCByZXNwb25zZX1cbiAgfVxuXG4gIGFzeW5jIGNyZWF0ZVJhdyhyYXdEYXRhLCBvcHRpb25zID0ge30pIHtcbiAgICBjb25zdCBvYmplY3REYXRhID0gQmFzZU1vZGVsLl9vYmplY3REYXRhRnJvbUdpdmVuUmF3RGF0YShyYXdEYXRhLCBvcHRpb25zKVxuXG4gICAgbGV0IHJlc3BvbnNlXG5cbiAgICB0cnkge1xuICAgICAgcmVzcG9uc2UgPSBhd2FpdCBDb21tYW5kc1Bvb2wuYWRkQ29tbWFuZChcbiAgICAgICAge1xuICAgICAgICAgIGFyZ3M6IHtcbiAgICAgICAgICAgIHNhdmU6IG9iamVjdERhdGFcbiAgICAgICAgICB9LFxuICAgICAgICAgIGNvbW1hbmQ6IGAke3RoaXMubW9kZWxDbGFzc0RhdGEoKS5jb2xsZWN0aW9uTmFtZX0tY3JlYXRlYCxcbiAgICAgICAgICBjb2xsZWN0aW9uTmFtZTogdGhpcy5tb2RlbENsYXNzRGF0YSgpLmNvbGxlY3Rpb25OYW1lLFxuICAgICAgICAgIHByaW1hcnlLZXk6IHRoaXMucHJpbWFyeUtleSgpLFxuICAgICAgICAgIHR5cGU6IFwiY3JlYXRlXCJcbiAgICAgICAgfSxcbiAgICAgICAge31cbiAgICAgIClcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgQmFzZU1vZGVsLnBhcnNlVmFsaWRhdGlvbkVycm9ycyh7ZXJyb3IsIG1vZGVsOiB0aGlzLCBvcHRpb25zfSlcbiAgICAgIHRocm93IGVycm9yXG4gICAgfVxuXG4gICAgaWYgKHJlc3BvbnNlLm1vZGVsKSB7XG4gICAgICB0aGlzLl9yZWZyZXNoTW9kZWxEYXRhRnJvbVJlc3BvbnNlKHJlc3BvbnNlKVxuICAgICAgdGhpcy5jaGFuZ2VzID0ge31cbiAgICB9XG5cbiAgICByZXR1cm4ge21vZGVsOiB0aGlzLCByZXNwb25zZX1cbiAgfVxuXG4gIGFzeW5jIGRlc3Ryb3koKSB7XG4gICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBDb21tYW5kc1Bvb2wuYWRkQ29tbWFuZChcbiAgICAgIHtcbiAgICAgICAgYXJnczoge3F1ZXJ5X3BhcmFtczogdGhpcy5jb2xsZWN0aW9uICYmIHRoaXMuY29sbGVjdGlvbi5wYXJhbXMoKX0sXG4gICAgICAgIGNvbW1hbmQ6IGAke3RoaXMubW9kZWxDbGFzc0RhdGEoKS5jb2xsZWN0aW9uTmFtZX0tZGVzdHJveWAsXG4gICAgICAgIGNvbGxlY3Rpb25OYW1lOiB0aGlzLm1vZGVsQ2xhc3NEYXRhKCkuY29sbGVjdGlvbk5hbWUsXG4gICAgICAgIHByaW1hcnlLZXk6IHRoaXMucHJpbWFyeUtleSgpLFxuICAgICAgICB0eXBlOiBcImRlc3Ryb3lcIlxuICAgICAgfSxcbiAgICAgIHt9XG4gICAgKVxuXG4gICAgaWYgKHJlc3BvbnNlLnN1Y2Nlc3MpIHtcbiAgICAgIGlmIChyZXNwb25zZS5tb2RlbCkge1xuICAgICAgICB0aGlzLl9yZWZyZXNoTW9kZWxEYXRhRnJvbVJlc3BvbnNlKHJlc3BvbnNlKVxuICAgICAgICB0aGlzLmNoYW5nZXMgPSB7fVxuICAgICAgfVxuXG4gICAgICByZXR1cm4ge21vZGVsOiB0aGlzLCByZXNwb25zZX1cbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5oYW5kbGVSZXNwb25zZUVycm9yKHJlc3BvbnNlKVxuICAgIH1cbiAgfVxuXG4gIGFzeW5jIGVuc3VyZUFiaWxpdGllcyhsaXN0T2ZBYmlsaXRpZXMpIHtcbiAgICAvLyBQb3B1bGF0ZSBhbiBhcnJheSB3aXRoIGEgbGlzdCBvZiBhYmlsaXRpZXMgY3VycmVudGx5IG5vdCBsb2FkZWRcbiAgICBjb25zdCBhYmlsaXRpZXNUb0xvYWQgPSBbXVxuXG4gICAgZm9yIChjb25zdCBhYmlsaXR5SW5MaXN0IG9mIGxpc3RPZkFiaWxpdGllcykge1xuICAgICAgaWYgKCEoYWJpbGl0eUluTGlzdCBpbiB0aGlzLmFiaWxpdGllcykpIHtcbiAgICAgICAgYWJpbGl0aWVzVG9Mb2FkLnB1c2goYWJpbGl0eUluTGlzdClcbiAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBMb2FkIHRoZSBtaXNzaW5nIGFiaWxpdGllcyBpZiBhbnlcbiAgICBpZiAoYWJpbGl0aWVzVG9Mb2FkLmxlbmd0aCA+IDApIHtcbiAgICAgIGNvbnN0IHByaW1hcnlLZXlOYW1lID0gdGhpcy5jb25zdHJ1Y3Rvci5wcmltYXJ5S2V5KClcbiAgICAgIGNvbnN0IHJhbnNhY2tQYXJhbXMgPSB7fVxuICAgICAgcmFuc2Fja1BhcmFtc1tgJHtwcmltYXJ5S2V5TmFtZX1fZXFgXSA9IHRoaXMucHJpbWFyeUtleSgpXG5cbiAgICAgIGNvbnN0IGFiaWxpdGllc1BhcmFtcyA9IHt9XG4gICAgICBhYmlsaXRpZXNQYXJhbXNbZGlnZyh0aGlzLm1vZGVsQ2xhc3NEYXRhKCksIFwibmFtZVwiKV0gPSBhYmlsaXRpZXNUb0xvYWRcblxuICAgICAgY29uc3QgYW5vdGhlck1vZGVsID0gYXdhaXQgdGhpcy5jb25zdHJ1Y3RvclxuICAgICAgICAucmFuc2FjayhyYW5zYWNrUGFyYW1zKVxuICAgICAgICAuYWJpbGl0aWVzKGFiaWxpdGllc1BhcmFtcylcbiAgICAgICAgLmZpcnN0KClcblxuICAgICAgaWYgKCFhbm90aGVyTW9kZWwpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBDb3VsZCBub3QgbG9vayB1cCB0aGUgc2FtZSBtb2RlbCAke3RoaXMucHJpbWFyeUtleSgpfSB3aXRoIGFiaWxpdGllczogJHthYmlsaXRpZXNUb0xvYWQuam9pbihcIiwgXCIpfWApXG4gICAgICB9XG5cbiAgICAgIGNvbnN0IG5ld0FiaWxpdGllcyA9IGFub3RoZXJNb2RlbC5hYmlsaXRpZXNcbiAgICAgIGZvciAoY29uc3QgbmV3QWJpbGl0eSBpbiBuZXdBYmlsaXRpZXMpIHtcbiAgICAgICAgdGhpcy5hYmlsaXRpZXNbbmV3QWJpbGl0eV0gPSBuZXdBYmlsaXRpZXNbbmV3QWJpbGl0eV1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBnZXRBdHRyaWJ1dGVzID0gKCkgPT4gT2JqZWN0LmFzc2lnbih0aGlzLm1vZGVsRGF0YSwgdGhpcy5jaGFuZ2VzKVxuXG4gIGhhbmRsZVJlc3BvbnNlRXJyb3IocmVzcG9uc2UpIHtcbiAgICBCYXNlTW9kZWwucGFyc2VWYWxpZGF0aW9uRXJyb3JzKHttb2RlbDogdGhpcywgcmVzcG9uc2V9KVxuICAgIHRocm93IG5ldyBuZXcgQ3VzdG9tRXJyb3IoXCJSZXNwb25zZSB3YXNuJ3Qgc3VjY2Vzc2Z1bFwiLCB7bW9kZWw6IHRoaXMsIHJlc3BvbnNlfSlcbiAgfVxuXG4gIGlkZW50aWZpZXJLZXkoKSB7XG4gICAgaWYgKCF0aGlzLl9pZGVudGlmaWVyS2V5KSB0aGlzLl9pZGVudGlmaWVyS2V5ID0gdGhpcy5pc1BlcnNpc3RlZCgpID8gdGhpcy5wcmltYXJ5S2V5KCkgOiB0aGlzLnVuaXF1ZUtleSgpXG5cbiAgICByZXR1cm4gdGhpcy5faWRlbnRpZmllcktleVxuICB9XG5cbiAgaXNBc3NvY2lhdGlvbkxvYWRlZCA9IChhc3NvY2lhdGlvbk5hbWUpID0+IHRoaXMuaXNBc3NvY2lhdGlvbkxvYWRlZFVuZGVyc2NvcmUoaW5mbGVjdGlvbi51bmRlcnNjb3JlKGFzc29jaWF0aW9uTmFtZSkpXG4gIGlzQXNzb2NpYXRpb25Mb2FkZWRVbmRlcnNjb3JlIChhc3NvY2lhdGlvbk5hbWVVbmRlcnNjb3JlKSB7XG4gICAgaWYgKGFzc29jaWF0aW9uTmFtZVVuZGVyc2NvcmUgaW4gdGhpcy5yZWxhdGlvbnNoaXBzQ2FjaGUpIHJldHVybiB0cnVlXG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cblxuICBpc0Fzc29jaWF0aW9uUHJlc2VudChhc3NvY2lhdGlvbk5hbWUpIHtcbiAgICBpZiAodGhpcy5pc0Fzc29jaWF0aW9uTG9hZGVkKGFzc29jaWF0aW9uTmFtZSkpIHJldHVybiB0cnVlXG4gICAgaWYgKGFzc29jaWF0aW9uTmFtZSBpbiB0aGlzLnJlbGF0aW9uc2hpcHMpIHJldHVybiB0cnVlXG4gICAgcmV0dXJuIGZhbHNlXG4gIH1cblxuICBzdGF0aWMgcGFyc2VWYWxpZGF0aW9uRXJyb3JzKHtlcnJvciwgbW9kZWwsIG9wdGlvbnN9KSB7XG4gICAgaWYgKCEoZXJyb3IgaW5zdGFuY2VvZiBWYWxpZGF0aW9uRXJyb3IpKSByZXR1cm5cbiAgICBpZiAoIWVycm9yLmFyZ3MucmVzcG9uc2UudmFsaWRhdGlvbl9lcnJvcnMpIHJldHVyblxuXG4gICAgY29uc3QgdmFsaWRhdGlvbkVycm9ycyA9IG5ldyBWYWxpZGF0aW9uRXJyb3JzKHtcbiAgICAgIG1vZGVsLFxuICAgICAgdmFsaWRhdGlvbkVycm9yczogZGlnZyhlcnJvciwgXCJhcmdzXCIsIFwicmVzcG9uc2VcIiwgXCJ2YWxpZGF0aW9uX2Vycm9yc1wiKVxuICAgIH0pXG5cbiAgICBCYXNlTW9kZWwuc2VuZFZhbGlkYXRpb25FcnJvcnNFdmVudCh2YWxpZGF0aW9uRXJyb3JzLCBvcHRpb25zKVxuXG4gICAgaWYgKCFvcHRpb25zIHx8IG9wdGlvbnMudGhyb3dWYWxpZGF0aW9uRXJyb3IgIT0gZmFsc2UpIHtcbiAgICAgIHRocm93IGVycm9yXG4gICAgfVxuICB9XG5cbiAgc3RhdGljIGh1bWFuQXR0cmlidXRlTmFtZShhdHRyaWJ1dGVOYW1lKSB7XG4gICAgY29uc3Qga2V5TmFtZSA9IGRpZ2codGhpcy5tb2RlbENsYXNzRGF0YSgpLCBcImkxOG5LZXlcIilcbiAgICBjb25zdCBpMThuID0gQ29uZmlnLmdldEkxOG4oKVxuXG4gICAgaWYgKGkxOG4pIHJldHVybiBpMThuLnQoYGFjdGl2ZXJlY29yZC5hdHRyaWJ1dGVzLiR7a2V5TmFtZX0uJHtCYXNlTW9kZWwuc25ha2VDYXNlKGF0dHJpYnV0ZU5hbWUpfWAsIHtkZWZhdWx0VmFsdWU6IGF0dHJpYnV0ZU5hbWV9KVxuXG4gICAgcmV0dXJuIGluZmxlY3Rpb24uaHVtYW5pemUoYXR0cmlidXRlTmFtZSlcbiAgfVxuXG4gIGlzQXR0cmlidXRlQ2hhbmdlZChhdHRyaWJ1dGVOYW1lKSB7XG4gICAgY29uc3QgYXR0cmlidXRlTmFtZVVuZGVyc2NvcmUgPSBpbmZsZWN0aW9uLnVuZGVyc2NvcmUoYXR0cmlidXRlTmFtZSlcbiAgICBjb25zdCBhdHRyaWJ1dGVEYXRhID0gdGhpcy5tb2RlbENsYXNzRGF0YSgpLmF0dHJpYnV0ZXMuZmluZCgoYXR0cmlidXRlKSA9PiBkaWdnKGF0dHJpYnV0ZSwgXCJuYW1lXCIpID09IGF0dHJpYnV0ZU5hbWVVbmRlcnNjb3JlKVxuXG4gICAgaWYgKCFhdHRyaWJ1dGVEYXRhKSB7XG4gICAgICBjb25zdCBhdHRyaWJ1dGVOYW1lcyA9IHRoaXMubW9kZWxDbGFzc0RhdGEoKS5hdHRyaWJ1dGVzLm1hcCgoYXR0cmlidXRlKSA9PiBkaWdnKGF0dHJpYnV0ZSwgXCJuYW1lXCIpKVxuXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYENvdWxkbid0IGZpbmQgYW4gYXR0cmlidXRlIGJ5IHRoYXQgbmFtZTogXCIke2F0dHJpYnV0ZU5hbWV9XCIgaW46ICR7YXR0cmlidXRlTmFtZXMuam9pbihcIiwgXCIpfWApXG4gICAgfVxuXG4gICAgaWYgKCEoYXR0cmlidXRlTmFtZVVuZGVyc2NvcmUgaW4gdGhpcy5jaGFuZ2VzKSlcbiAgICAgIHJldHVybiBmYWxzZVxuXG4gICAgY29uc3Qgb2xkVmFsdWUgPSB0aGlzLm1vZGVsRGF0YVthdHRyaWJ1dGVOYW1lVW5kZXJzY29yZV1cbiAgICBjb25zdCBuZXdWYWx1ZSA9IHRoaXMuY2hhbmdlc1thdHRyaWJ1dGVOYW1lVW5kZXJzY29yZV1cbiAgICBjb25zdCBjaGFuZ2VkTWV0aG9kID0gdGhpc1tgX2lzJHtpbmZsZWN0aW9uLmNhbWVsaXplKGF0dHJpYnV0ZURhdGEudHlwZSwgdHJ1ZSl9Q2hhbmdlZGBdXG5cbiAgICBpZiAoIWNoYW5nZWRNZXRob2QpXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYERvbid0IGtub3cgaG93IHRvIGhhbmRsZSB0eXBlOiAke2F0dHJpYnV0ZURhdGEudHlwZX1gKVxuXG4gICAgcmV0dXJuIGNoYW5nZWRNZXRob2Qob2xkVmFsdWUsIG5ld1ZhbHVlKVxuICB9XG5cbiAgaXNDaGFuZ2VkKCkge1xuICAgIGNvbnN0IGtleXMgPSBPYmplY3Qua2V5cyh0aGlzLmNoYW5nZXMpXG5cbiAgICBpZiAoa2V5cy5sZW5ndGggPiAwKSB7XG4gICAgICByZXR1cm4gdHJ1ZVxuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gZmFsc2VcbiAgICB9XG4gIH1cblxuICBpc05ld1JlY29yZCgpIHtcbiAgICBpZiAodGhpcy5uZXdSZWNvcmQgIT09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIHRoaXMubmV3UmVjb3JkXG4gICAgfSBlbHNlIGlmIChcImlkXCIgaW4gdGhpcy5tb2RlbERhdGEgJiYgdGhpcy5tb2RlbERhdGEuaWQpIHtcbiAgICAgIHJldHVybiBmYWxzZVxuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gdHJ1ZVxuICAgIH1cbiAgfVxuXG4gIGlzUGVyc2lzdGVkID0gKCkgPT4gIXRoaXMuaXNOZXdSZWNvcmQoKVxuXG4gIHN0YXRpYyBzbmFrZUNhc2UgPSAoc3RyaW5nKSA9PiBpbmZsZWN0aW9uLnVuZGVyc2NvcmUoc3RyaW5nKVxuXG4gIHNhdmVkQ2hhbmdlVG9BdHRyaWJ1dGUoYXR0cmlidXRlTmFtZSkge1xuICAgIGlmICghdGhpcy5wcmV2aW91c01vZGVsRGF0YSlcbiAgICAgIHJldHVybiBmYWxzZVxuXG4gICAgY29uc3QgYXR0cmlidXRlTmFtZVVuZGVyc2NvcmUgPSBpbmZsZWN0aW9uLnVuZGVyc2NvcmUoYXR0cmlidXRlTmFtZSlcbiAgICBjb25zdCBhdHRyaWJ1dGVEYXRhID0gdGhpcy5tb2RlbENsYXNzRGF0YSgpLmF0dHJpYnV0ZXMuZmluZCgoYXR0cmlidXRlKSA9PiBhdHRyaWJ1dGUubmFtZSA9PSBhdHRyaWJ1dGVOYW1lVW5kZXJzY29yZSlcblxuICAgIGlmICghYXR0cmlidXRlRGF0YSkge1xuICAgICAgY29uc3QgYXR0cmlidXRlTmFtZXMgPSB0aGlzLm1vZGVsQ2xhc3NEYXRhKCkuYXR0cmlidXRlcy5tYXAoKGF0dHJpYnV0ZSkgPT4gYXR0cmlidXRlLm5hbWUpXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYENvdWxkbid0IGZpbmQgYW4gYXR0cmlidXRlIGJ5IHRoYXQgbmFtZTogXCIke2F0dHJpYnV0ZU5hbWV9XCIgaW46ICR7YXR0cmlidXRlTmFtZXMuam9pbihcIiwgXCIpfWApXG4gICAgfVxuXG4gICAgaWYgKCEoYXR0cmlidXRlTmFtZVVuZGVyc2NvcmUgaW4gdGhpcy5wcmV2aW91c01vZGVsRGF0YSkpXG4gICAgICByZXR1cm4gdHJ1ZVxuXG4gICAgY29uc3Qgb2xkVmFsdWUgPSB0aGlzLnByZXZpb3VzTW9kZWxEYXRhW2F0dHJpYnV0ZU5hbWVVbmRlcnNjb3JlXVxuICAgIGNvbnN0IG5ld1ZhbHVlID0gdGhpcy5tb2RlbERhdGFbYXR0cmlidXRlTmFtZVVuZGVyc2NvcmVdXG4gICAgY29uc3QgY2hhbmdlZE1ldGhvZE5hbWUgPSBgX2lzJHtpbmZsZWN0aW9uLmNhbWVsaXplKGF0dHJpYnV0ZURhdGEudHlwZSl9Q2hhbmdlZGBcbiAgICBjb25zdCBjaGFuZ2VkTWV0aG9kID0gdGhpc1tjaGFuZ2VkTWV0aG9kTmFtZV1cblxuICAgIGlmICghY2hhbmdlZE1ldGhvZClcbiAgICAgIHRocm93IG5ldyBFcnJvcihgRG9uJ3Qga25vdyBob3cgdG8gaGFuZGxlIHR5cGU6ICR7YXR0cmlidXRlRGF0YS50eXBlfWApXG5cbiAgICByZXR1cm4gY2hhbmdlZE1ldGhvZChvbGRWYWx1ZSwgbmV3VmFsdWUpXG4gIH1cblxuICBzZXROZXdNb2RlbChtb2RlbCkge1xuICAgIHRoaXMuc2V0TmV3TW9kZWxEYXRhKG1vZGVsKVxuXG4gICAgZm9yKGNvbnN0IHJlbGF0aW9uc2hpcE5hbWUgaW4gbW9kZWwucmVsYXRpb25zaGlwcykge1xuICAgICAgdGhpcy5yZWxhdGlvbnNoaXBzW3JlbGF0aW9uc2hpcE5hbWVdID0gbW9kZWwucmVsYXRpb25zaGlwc1tyZWxhdGlvbnNoaXBOYW1lXVxuICAgIH1cblxuICAgIGZvcihjb25zdCByZWxhdGlvbnNoaXBDYWNoZU5hbWUgaW4gbW9kZWwucmVsYXRpb25zaGlwc0NhY2hlKSB7XG4gICAgICB0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZVtyZWxhdGlvbnNoaXBDYWNoZU5hbWVdID0gbW9kZWwucmVsYXRpb25zaGlwc0NhY2hlW25hbWVdXG4gICAgfVxuICB9XG5cbiAgc2V0TmV3TW9kZWxEYXRhKG1vZGVsKSB7XG4gICAgaWYgKCEoXCJtb2RlbERhdGFcIiBpbiBtb2RlbCkpIHRocm93IG5ldyBFcnJvcihgTm8gbW9kZWxEYXRhIGluIG1vZGVsOiAke0pTT04uc3RyaW5naWZ5KG1vZGVsKX1gKVxuXG4gICAgdGhpcy5wcmV2aW91c01vZGVsRGF0YSA9IE9iamVjdC5hc3NpZ24oe30sIGRpZ2codGhpcywgXCJtb2RlbERhdGFcIikpXG5cbiAgICBmb3IoY29uc3QgYXR0cmlidXRlTmFtZSBpbiBtb2RlbC5tb2RlbERhdGEpIHtcbiAgICAgIHRoaXMubW9kZWxEYXRhW2F0dHJpYnV0ZU5hbWVdID0gbW9kZWwubW9kZWxEYXRhW2F0dHJpYnV0ZU5hbWVdXG4gICAgfVxuICB9XG5cbiAgX2lzRGF0ZUNoYW5nZWQob2xkVmFsdWUsIG5ld1ZhbHVlKSB7XG4gICAgaWYgKERhdGUucGFyc2Uob2xkVmFsdWUpICE9IERhdGUucGFyc2UobmV3VmFsdWUpKVxuICAgICAgcmV0dXJuIHRydWVcbiAgfVxuXG4gIF9pc0ludGVnZXJDaGFuZ2VkKG9sZFZhbHVlLCBuZXdWYWx1ZSkge1xuICAgIGlmIChwYXJzZUludChvbGRWYWx1ZSwgMTApICE9IHBhcnNlSW50KG5ld1ZhbHVlLCAxMCkpXG4gICAgICByZXR1cm4gdHJ1ZVxuICB9XG5cbiAgX2lzU3RyaW5nQ2hhbmdlZCAob2xkVmFsdWUsIG5ld1ZhbHVlKSB7XG4gICAgY29uc3Qgb2xkQ29udmVydGVkVmFsdWUgPSBgJHtvbGRWYWx1ZX1gXG4gICAgY29uc3QgbmV3Q29udmVydGVkVmFsdWUgPSBgJHtuZXdWYWx1ZX1gXG5cbiAgICBpZiAob2xkQ29udmVydGVkVmFsdWUgIT0gbmV3Q29udmVydGVkVmFsdWUpXG4gICAgICByZXR1cm4gdHJ1ZVxuICB9XG5cbiAgbW9kZWxDbGFzc0RhdGEgPSAoKSA9PiB0aGlzLmNvbnN0cnVjdG9yLm1vZGVsQ2xhc3NEYXRhKClcblxuICBhc3luYyByZWxvYWQoKSB7XG4gICAgY29uc3QgcGFyYW1zID0gdGhpcy5jb2xsZWN0aW9uICYmIHRoaXMuY29sbGVjdGlvbi5wYXJhbXMoKVxuICAgIGNvbnN0IHJhbnNhY2tQYXJhbXMgPSB7fVxuICAgIHJhbnNhY2tQYXJhbXNbYCR7dGhpcy5jb25zdHJ1Y3Rvci5wcmltYXJ5S2V5KCl9X2VxYF0gPSB0aGlzLnByaW1hcnlLZXkoKVxuXG4gICAgbGV0IHF1ZXJ5ID0gdGhpcy5jb25zdHJ1Y3Rvci5yYW5zYWNrKHJhbnNhY2tQYXJhbXMpXG5cbiAgICBpZiAocGFyYW1zKSB7XG4gICAgICBpZiAocGFyYW1zLnByZWxvYWQpIHtcbiAgICAgICAgcXVlcnkucXVlcnlBcmdzLnByZWxvYWQgPSBwYXJhbXMucHJlbG9hZFxuICAgICAgfVxuXG4gICAgICBpZiAocGFyYW1zLnNlbGVjdCkge1xuICAgICAgICBxdWVyeS5xdWVyeUFyZ3Muc2VsZWN0ID0gcGFyYW1zLnNlbGVjdFxuICAgICAgfVxuXG4gICAgICBpZiAocGFyYW1zLnNlbGVjdF9jb2x1bW5zKSB7XG4gICAgICAgIHF1ZXJ5LnF1ZXJ5QXJncy5zZWxlY3RDb2x1bW5zID0gcGFyYW1zLnNlbGVjdF9jb2x1bW5zXG4gICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgbW9kZWwgPSBhd2FpdCBxdWVyeS5maXJzdCgpXG4gICAgdGhpcy5zZXROZXdNb2RlbChtb2RlbClcbiAgICB0aGlzLmNoYW5nZXMgPSB7fVxuICB9XG5cbiAgc2F2ZSgpIHtcbiAgICBpZiAodGhpcy5pc05ld1JlY29yZCgpKSB7XG4gICAgICByZXR1cm4gdGhpcy5jcmVhdGUoKVxuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gdGhpcy51cGRhdGUoKVxuICAgIH1cbiAgfVxuXG4gIHNhdmVSYXcocmF3RGF0YSwgb3B0aW9ucyA9IHt9KSB7XG4gICAgaWYgKHRoaXMuaXNOZXdSZWNvcmQoKSkge1xuICAgICAgcmV0dXJuIHRoaXMuY3JlYXRlUmF3KHJhd0RhdGEsIG9wdGlvbnMpXG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiB0aGlzLnVwZGF0ZVJhdyhyYXdEYXRhLCBvcHRpb25zKVxuICAgIH1cbiAgfVxuXG4gIGFzeW5jIHVwZGF0ZShuZXdBdHRyaWJ1dGVzLCBvcHRpb25zKSB7XG4gICAgaWYgKG5ld0F0dHJpYnV0ZXMpIHtcbiAgICAgIHRoaXMuYXNzaWduQXR0cmlidXRlcyhuZXdBdHRyaWJ1dGVzKVxuICAgIH1cblxuICAgIGlmIChPYmplY3Qua2V5cyh0aGlzLmNoYW5nZXMpLmxlbmd0aCA9PSAwKSB7XG4gICAgICByZXR1cm4ge21vZGVsOiB0aGlzfVxuICAgIH1cblxuICAgIGNvbnN0IHBhcmFtS2V5ID0gdGhpcy5tb2RlbENsYXNzRGF0YSgpLnBhcmFtS2V5XG4gICAgY29uc3QgbW9kZWxEYXRhID0gdGhpcy5jaGFuZ2VzXG4gICAgY29uc3QgZGF0YVRvVXNlID0ge31cbiAgICBkYXRhVG9Vc2VbcGFyYW1LZXldID0gbW9kZWxEYXRhXG4gICAgbGV0IHJlc3BvbnNlXG5cbiAgICB0cnkge1xuICAgICAgcmVzcG9uc2UgPSBhd2FpdCBDb21tYW5kc1Bvb2wuYWRkQ29tbWFuZChcbiAgICAgICAge1xuICAgICAgICAgIGFyZ3M6IHtcbiAgICAgICAgICAgIHF1ZXJ5X3BhcmFtczogdGhpcy5jb2xsZWN0aW9uICYmIHRoaXMuY29sbGVjdGlvbi5wYXJhbXMoKSxcbiAgICAgICAgICAgIHNhdmU6IGRhdGFUb1VzZVxuICAgICAgICAgIH0sXG4gICAgICAgICAgY29tbWFuZDogYCR7dGhpcy5tb2RlbENsYXNzRGF0YSgpLmNvbGxlY3Rpb25OYW1lfS11cGRhdGVgLFxuICAgICAgICAgIGNvbGxlY3Rpb25OYW1lOiB0aGlzLm1vZGVsQ2xhc3NEYXRhKCkuY29sbGVjdGlvbk5hbWUsXG4gICAgICAgICAgcHJpbWFyeUtleTogdGhpcy5wcmltYXJ5S2V5KCksXG4gICAgICAgICAgdHlwZTogXCJ1cGRhdGVcIlxuICAgICAgICB9LFxuICAgICAgICB7fVxuICAgICAgKVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBCYXNlTW9kZWwucGFyc2VWYWxpZGF0aW9uRXJyb3JzKHtlcnJvciwgbW9kZWw6IHRoaXMsIG9wdGlvbnN9KVxuICAgICAgdGhyb3cgZXJyb3JcbiAgICB9XG5cbiAgICBpZiAocmVzcG9uc2Uuc3VjY2Vzcykge1xuICAgICAgaWYgKHJlc3BvbnNlLm1vZGVsKSB7XG4gICAgICAgIHRoaXMuX3JlZnJlc2hNb2RlbEZyb21SZXNwb25zZShyZXNwb25zZSlcbiAgICAgICAgdGhpcy5jaGFuZ2VzID0ge31cbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHtyZXNwb25zZSwgbW9kZWw6IHRoaXN9XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuaGFuZGxlUmVzcG9uc2VFcnJvcihyZXNwb25zZSlcbiAgICB9XG4gIH1cblxuICBfcmVmcmVzaE1vZGVsRnJvbVJlc3BvbnNlKHJlc3BvbnNlKSB7XG4gICAgbGV0IG5ld01vZGVsID0gZGlnZyhyZXNwb25zZSwgXCJtb2RlbFwiKVxuXG4gICAgaWYgKEFycmF5LmlzQXJyYXkobmV3TW9kZWwpKSBuZXdNb2RlbCA9IG5ld01vZGVsWzBdXG5cbiAgICB0aGlzLnNldE5ld01vZGVsKG5ld01vZGVsKVxuICB9XG5cbiAgX3JlZnJlc2hNb2RlbERhdGFGcm9tUmVzcG9uc2UocmVzcG9uc2UpIHtcbiAgICBsZXQgbmV3TW9kZWwgPSBkaWdnKHJlc3BvbnNlLCBcIm1vZGVsXCIpXG5cbiAgICBpZiAoQXJyYXkuaXNBcnJheShuZXdNb2RlbCkpIG5ld01vZGVsID0gbmV3TW9kZWxbMF1cblxuICAgIHRoaXMuc2V0TmV3TW9kZWxEYXRhKG5ld01vZGVsKVxuICB9XG5cbiAgc3RhdGljIF9vYmplY3REYXRhRnJvbUdpdmVuUmF3RGF0YShyYXdEYXRhLCBvcHRpb25zKSB7XG4gICAgaWYgKHJhd0RhdGEgaW5zdGFuY2VvZiBGb3JtRGF0YSB8fCByYXdEYXRhLm5vZGVOYW1lID09IFwiRk9STVwiKSB7XG4gICAgICBjb25zdCBmb3JtRGF0YSA9IEZvcm1EYXRhT2JqZWN0aXplci5mb3JtRGF0YUZyb21PYmplY3QocmF3RGF0YSwgb3B0aW9ucylcblxuICAgICAgcmV0dXJuIEZvcm1EYXRhT2JqZWN0aXplci50b09iamVjdChmb3JtRGF0YSlcbiAgICB9XG5cbiAgICByZXR1cm4gcmF3RGF0YVxuICB9XG5cbiAgYXN5bmMgdXBkYXRlUmF3KHJhd0RhdGEsIG9wdGlvbnMgPSB7fSkge1xuICAgIGNvbnN0IG9iamVjdERhdGEgPSBCYXNlTW9kZWwuX29iamVjdERhdGFGcm9tR2l2ZW5SYXdEYXRhKHJhd0RhdGEsIG9wdGlvbnMpXG4gICAgbGV0IHJlc3BvbnNlXG5cbiAgICB0cnkge1xuICAgICAgcmVzcG9uc2UgPSBhd2FpdCBDb21tYW5kc1Bvb2wuYWRkQ29tbWFuZChcbiAgICAgICAge1xuICAgICAgICAgIGFyZ3M6IHtcbiAgICAgICAgICAgIHF1ZXJ5X3BhcmFtczogdGhpcy5jb2xsZWN0aW9uICYmIHRoaXMuY29sbGVjdGlvbi5wYXJhbXMoKSxcbiAgICAgICAgICAgIHNhdmU6IG9iamVjdERhdGEsXG4gICAgICAgICAgICBzaW1wbGVfbW9kZWxfZXJyb3JzOiBvcHRpb25zPy5zaW1wbGVNb2RlbEVycm9yc1xuICAgICAgICAgIH0sXG4gICAgICAgICAgY29tbWFuZDogYCR7dGhpcy5tb2RlbENsYXNzRGF0YSgpLmNvbGxlY3Rpb25OYW1lfS11cGRhdGVgLFxuICAgICAgICAgIGNvbGxlY3Rpb25OYW1lOiB0aGlzLm1vZGVsQ2xhc3NEYXRhKCkuY29sbGVjdGlvbk5hbWUsXG4gICAgICAgICAgcHJpbWFyeUtleTogdGhpcy5wcmltYXJ5S2V5KCksXG4gICAgICAgICAgdHlwZTogXCJ1cGRhdGVcIlxuICAgICAgICB9LFxuICAgICAgICB7fVxuICAgICAgKVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBCYXNlTW9kZWwucGFyc2VWYWxpZGF0aW9uRXJyb3JzKHtlcnJvciwgbW9kZWw6IHRoaXMsIG9wdGlvbnN9KVxuICAgICAgdGhyb3cgZXJyb3JcbiAgICB9XG5cbiAgICBpZiAocmVzcG9uc2UubW9kZWwpIHtcbiAgICAgIHRoaXMuX3JlZnJlc2hNb2RlbEZyb21SZXNwb25zZShyZXNwb25zZSlcbiAgICAgIHRoaXMuY2hhbmdlcyA9IHt9XG4gICAgfVxuXG4gICAgcmV0dXJuIHtyZXNwb25zZSwgbW9kZWw6IHRoaXN9XG4gIH1cblxuICBpc1ZhbGlkKCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIk5vdCBpbXBsZW1lbnRlZCB5ZXRcIilcbiAgfVxuXG4gIGFzeW5jIGlzVmFsaWRPblNlcnZlcigpIHtcbiAgICBjb25zdCBtb2RlbERhdGEgPSB0aGlzLmdldEF0dHJpYnV0ZXMoKVxuICAgIGNvbnN0IHBhcmFtS2V5ID0gdGhpcy5tb2RlbENsYXNzRGF0YSgpLnBhcmFtS2V5XG4gICAgY29uc3QgZGF0YVRvVXNlID0ge31cbiAgICBkYXRhVG9Vc2VbcGFyYW1LZXldID0gbW9kZWxEYXRhXG5cbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IENvbW1hbmRzUG9vbC5hZGRDb21tYW5kKFxuICAgICAge1xuICAgICAgICBhcmdzOiB7XG4gICAgICAgICAgc2F2ZTogZGF0YVRvVXNlXG4gICAgICAgIH0sXG4gICAgICAgIGNvbW1hbmQ6IGAke3RoaXMubW9kZWxDbGFzc0RhdGEoKS5jb2xsZWN0aW9uTmFtZX0tdmFsaWRgLFxuICAgICAgICBjb2xsZWN0aW9uTmFtZTogdGhpcy5tb2RlbENsYXNzRGF0YSgpLmNvbGxlY3Rpb25OYW1lLFxuICAgICAgICBwcmltYXJ5S2V5OiB0aGlzLnByaW1hcnlLZXkoKSxcbiAgICAgICAgdHlwZTogXCJ2YWxpZFwiXG4gICAgICB9LFxuICAgICAge31cbiAgICApXG5cbiAgICByZXR1cm4ge3ZhbGlkOiByZXNwb25zZS52YWxpZCwgZXJyb3JzOiByZXNwb25zZS5lcnJvcnN9XG4gIH1cblxuICBtb2RlbENsYXNzID0gKCkgPT4gdGhpcy5jb25zdHJ1Y3RvclxuXG4gIHByZWxvYWRSZWxhdGlvbnNoaXAocmVsYXRpb25zaGlwTmFtZSwgbW9kZWwpIHtcbiAgICB0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZVtCYXNlTW9kZWwuc25ha2VDYXNlKHJlbGF0aW9uc2hpcE5hbWUpXSA9IG1vZGVsXG4gICAgdGhpcy5yZWxhdGlvbnNoaXBzW0Jhc2VNb2RlbC5zbmFrZUNhc2UocmVsYXRpb25zaGlwTmFtZSldID0gbW9kZWxcbiAgfVxuXG4gIG1hcmtGb3JEZXN0cnVjdGlvbigpIHtcbiAgICB0aGlzLl9tYXJrZWRGb3JEZXN0cnVjdGlvbiA9IHRydWVcbiAgfVxuXG4gIG1hcmtlZEZvckRlc3RydWN0aW9uID0gKCkgPT4gdGhpcy5fbWFya2VkRm9yRGVzdHJ1Y3Rpb25cblxuICB1bmlxdWVLZXkoKSB7XG4gICAgaWYgKCF0aGlzLnVuaXF1ZUtleVZhbHVlKSB7XG4gICAgICBjb25zdCBtaW4gPSA1MDAwMDAwMDAwMDAwMDAwXG4gICAgICBjb25zdCBtYXggPSA5MDA3MTk5MjU0NzQwOTkxXG4gICAgICBjb25zdCByYW5kb21CZXR3ZWVuID0gTWF0aC5mbG9vcihNYXRoLnJhbmRvbSgpICogKG1heCAtIG1pbiArIDEpICsgbWluKVxuICAgICAgdGhpcy51bmlxdWVLZXlWYWx1ZSA9IHJhbmRvbUJldHdlZW5cbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy51bmlxdWVLZXlWYWx1ZVxuICB9XG5cbiAgc3RhdGljIGFzeW5jIF9jYWxsQ29sbGVjdGlvbkNvbW1hbmQoYXJncywgY29tbWFuZEFyZ3MpIHtcbiAgICBjb25zdCBmb3JtT3JEYXRhT2JqZWN0ID0gYXJncy5hcmdzXG5cbiAgICB0cnkge1xuICAgICAgcmV0dXJuIGF3YWl0IENvbW1hbmRzUG9vbC5hZGRDb21tYW5kKGFyZ3MsIGNvbW1hbmRBcmdzKVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBsZXQgZm9ybVxuXG4gICAgICBpZiAoY29tbWFuZEFyZ3MuZm9ybSkge1xuICAgICAgICBmb3JtID0gY29tbWFuZEFyZ3MuZm9ybVxuICAgICAgfSBlbHNlIGlmIChmb3JtT3JEYXRhT2JqZWN0Py5ub2RlTmFtZSA9PSBcIkZPUk1cIikge1xuICAgICAgICBmb3JtID0gZm9ybU9yRGF0YU9iamVjdFxuICAgICAgfVxuXG4gICAgICBpZiAoZm9ybSkgQmFzZU1vZGVsLnBhcnNlVmFsaWRhdGlvbkVycm9ycyh7ZXJyb3IsIG9wdGlvbnM6IHtmb3JtfX0pXG5cbiAgICAgIHRocm93IGVycm9yXG4gICAgfVxuICB9XG5cbiAgX2NhbGxNZW1iZXJDb21tYW5kID0gKGFyZ3MsIGNvbW1hbmRBcmdzKSA9PiBDb21tYW5kc1Bvb2wuYWRkQ29tbWFuZChhcmdzLCBjb21tYW5kQXJncylcblxuICBzdGF0aWMgX3Bvc3REYXRhRnJvbUFyZ3MoYXJncykge1xuICAgIGxldCBwb3N0RGF0YVxuXG4gICAgaWYgKGFyZ3MpIHtcbiAgICAgIGlmIChhcmdzIGluc3RhbmNlb2YgRm9ybURhdGEpIHtcbiAgICAgICAgcG9zdERhdGEgPSBhcmdzXG4gICAgICB9IGVsc2Uge1xuICAgICAgICBwb3N0RGF0YSA9IG9iamVjdFRvRm9ybURhdGEuc2VyaWFsaXplKGFyZ3MsIHt9LCBudWxsLCBcImFyZ3NcIilcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgcG9zdERhdGEgPSBuZXcgRm9ybURhdGEoKVxuICAgIH1cblxuICAgIHJldHVybiBwb3N0RGF0YVxuICB9XG5cbiAgcmVhZEF0dHJpYnV0ZShhdHRyaWJ1dGVOYW1lKSB7XG4gICAgY29uc3QgYXR0cmlidXRlTmFtZVVuZGVyc2NvcmUgPSBpbmZsZWN0aW9uLnVuZGVyc2NvcmUoYXR0cmlidXRlTmFtZSlcblxuICAgIHJldHVybiB0aGlzLnJlYWRBdHRyaWJ1dGVVbmRlcnNjb3JlKGF0dHJpYnV0ZU5hbWVVbmRlcnNjb3JlKVxuICB9XG5cbiAgcmVhZEF0dHJpYnV0ZVVuZGVyc2NvcmUoYXR0cmlidXRlTmFtZSkge1xuICAgIGlmIChhdHRyaWJ1dGVOYW1lIGluIHRoaXMuY2hhbmdlcykge1xuICAgICAgcmV0dXJuIHRoaXMuY2hhbmdlc1thdHRyaWJ1dGVOYW1lXVxuICAgIH0gZWxzZSBpZiAoYXR0cmlidXRlTmFtZSBpbiB0aGlzLm1vZGVsRGF0YSkge1xuICAgICAgcmV0dXJuIHRoaXMubW9kZWxEYXRhW2F0dHJpYnV0ZU5hbWVdXG4gICAgfSBlbHNlIGlmICh0aGlzLmlzTmV3UmVjb3JkKCkpIHtcbiAgICAgIC8vIFJldHVybiBudWxsIGlmIHRoaXMgaXMgYSBuZXcgcmVjb3JkIGFuZCB0aGUgYXR0cmlidXRlIG5hbWUgaXMgYSByZWNvZ25pemVkIGF0dHJpYnV0ZVxuICAgICAgY29uc3QgYXR0cmlidXRlcyA9IGRpZ2codGhpcy5tb2RlbENsYXNzRGF0YSgpLCBcImF0dHJpYnV0ZXNcIilcblxuICAgICAgaWYgKGF0dHJpYnV0ZU5hbWUgaW4gYXR0cmlidXRlcykgcmV0dXJuIG51bGxcbiAgICB9XG5cbiAgICBpZiAodGhpcy5pc1BlcnNpc3RlZCgpKSB7XG4gICAgICB0aHJvdyBuZXcgQXR0cmlidXRlTm90TG9hZGVkRXJyb3IoYE5vIHN1Y2ggYXR0cmlidXRlOiAke2RpZ2codGhpcy5tb2RlbENsYXNzRGF0YSgpLCBcIm5hbWVcIil9IyR7YXR0cmlidXRlTmFtZX06ICR7SlNPTi5zdHJpbmdpZnkodGhpcy5tb2RlbERhdGEpfWApXG4gICAgfVxuICB9XG5cbiAgaXNBdHRyaWJ1dGVMb2FkZWQoYXR0cmlidXRlTmFtZSkge1xuICAgIGNvbnN0IGF0dHJpYnV0ZU5hbWVVbmRlcnNjb3JlID0gaW5mbGVjdGlvbi51bmRlcnNjb3JlKGF0dHJpYnV0ZU5hbWUpXG5cbiAgICBpZiAoYXR0cmlidXRlTmFtZVVuZGVyc2NvcmUgaW4gdGhpcy5jaGFuZ2VzKSByZXR1cm4gdHJ1ZVxuICAgIGlmIChhdHRyaWJ1dGVOYW1lVW5kZXJzY29yZSBpbiB0aGlzLm1vZGVsRGF0YSkgcmV0dXJuIHRydWVcbiAgICByZXR1cm4gZmFsc2VcbiAgfVxuXG4gIF9pc1ByZXNlbnQodmFsdWUpIHtcbiAgICBpZiAoIXZhbHVlKSB7XG4gICAgICByZXR1cm4gZmFsc2VcbiAgICB9IGVsc2UgaWYgKHR5cGVvZiB2YWx1ZSA9PSBcInN0cmluZ1wiICYmIHZhbHVlLm1hdGNoKC9eXFxzKiQvKSkge1xuICAgICAgcmV0dXJuIGZhbHNlXG4gICAgfVxuXG4gICAgcmV0dXJuIHRydWVcbiAgfVxuXG4gIGFzeW5jIF9sb2FkQmVsb25nc1RvUmVmbGVjdGlvbihhcmdzLCBxdWVyeUFyZ3MgPSB7fSkge1xuICAgIGlmIChhcmdzLnJlZmxlY3Rpb25OYW1lIGluIHRoaXMucmVsYXRpb25zaGlwcykge1xuICAgICAgcmV0dXJuIHRoaXMucmVsYXRpb25zaGlwc1thcmdzLnJlZmxlY3Rpb25OYW1lXVxuICAgIH0gZWxzZSBpZiAoYXJncy5yZWZsZWN0aW9uTmFtZSBpbiB0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZSkge1xuICAgICAgcmV0dXJuIHRoaXMucmVsYXRpb25zaGlwc0NhY2hlW2FyZ3MucmVmbGVjdGlvbk5hbWVdXG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbnN0IGNvbGxlY3Rpb24gPSBuZXcgQ29sbGVjdGlvbihhcmdzLCBxdWVyeUFyZ3MpXG4gICAgICBjb25zdCBtb2RlbCA9IGF3YWl0IGNvbGxlY3Rpb24uZmlyc3QoKVxuICAgICAgdGhpcy5yZWxhdGlvbnNoaXBzQ2FjaGVbYXJncy5yZWZsZWN0aW9uTmFtZV0gPSBtb2RlbFxuICAgICAgcmV0dXJuIG1vZGVsXG4gICAgfVxuICB9XG5cbiAgX3JlYWRCZWxvbmdzVG9SZWZsZWN0aW9uKHtyZWZsZWN0aW9uTmFtZX0pIHtcbiAgICBpZiAocmVmbGVjdGlvbk5hbWUgaW4gdGhpcy5yZWxhdGlvbnNoaXBzKSB7XG4gICAgICByZXR1cm4gdGhpcy5yZWxhdGlvbnNoaXBzW3JlZmxlY3Rpb25OYW1lXVxuICAgIH0gZWxzZSBpZiAocmVmbGVjdGlvbk5hbWUgaW4gdGhpcy5yZWxhdGlvbnNoaXBzQ2FjaGUpIHtcbiAgICAgIHJldHVybiB0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZVtyZWZsZWN0aW9uTmFtZV1cbiAgICB9XG5cbiAgICBpZiAodGhpcy5pc05ld1JlY29yZCgpKSByZXR1cm4gbnVsbFxuXG4gICAgY29uc3QgbG9hZGVkUmVsYXRpb25zaGlwcyA9IE9iamVjdC5rZXlzKHRoaXMucmVsYXRpb25zaGlwc0NhY2hlKVxuICAgIGNvbnN0IG1vZGVsQ2xhc3NOYW1lID0gZGlnZyh0aGlzLm1vZGVsQ2xhc3NEYXRhKCksIFwibmFtZVwiKVxuXG4gICAgdGhyb3cgbmV3IE5vdExvYWRlZEVycm9yKGAke21vZGVsQ2xhc3NOYW1lfSMke3JlZmxlY3Rpb25OYW1lfSBoYXNuJ3QgYmVlbiBsb2FkZWQgeWV0LiBPbmx5IHRoZXNlIHdlcmUgbG9hZGVkOiAke2xvYWRlZFJlbGF0aW9uc2hpcHMuam9pbihcIiwgXCIpfWApXG4gIH1cblxuICBhc3luYyBfbG9hZEhhc01hbnlSZWZsZWN0aW9uKGFyZ3MsIHF1ZXJ5QXJncyA9IHt9KSB7XG4gICAgaWYgKGFyZ3MucmVmbGVjdGlvbk5hbWUgaW4gdGhpcy5yZWxhdGlvbnNoaXBzKSB7XG4gICAgICByZXR1cm4gdGhpcy5yZWxhdGlvbnNoaXBzW2FyZ3MucmVmbGVjdGlvbk5hbWVdXG4gICAgfSBlbHNlIGlmIChhcmdzLnJlZmxlY3Rpb25OYW1lIGluIHRoaXMucmVsYXRpb25zaGlwc0NhY2hlKSB7XG4gICAgICByZXR1cm4gdGhpcy5yZWxhdGlvbnNoaXBzQ2FjaGVbYXJncy5yZWZsZWN0aW9uTmFtZV1cbiAgICB9XG5cbiAgICBjb25zdCBjb2xsZWN0aW9uID0gbmV3IENvbGxlY3Rpb24oYXJncywgcXVlcnlBcmdzKVxuICAgIGNvbnN0IG1vZGVscyA9IGF3YWl0IGNvbGxlY3Rpb24udG9BcnJheSgpXG5cbiAgICB0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZVthcmdzLnJlZmxlY3Rpb25OYW1lXSA9IG1vZGVsc1xuXG4gICAgcmV0dXJuIG1vZGVsc1xuICB9XG5cbiAgYXN5bmMgX2xvYWRIYXNPbmVSZWZsZWN0aW9uKGFyZ3MsIHF1ZXJ5QXJncyA9IHt9KSB7XG4gICAgaWYgKGFyZ3MucmVmbGVjdGlvbk5hbWUgaW4gdGhpcy5yZWxhdGlvbnNoaXBzKSB7XG4gICAgICByZXR1cm4gdGhpcy5yZWxhdGlvbnNoaXBzW2FyZ3MucmVmbGVjdGlvbk5hbWVdXG4gICAgfSBlbHNlIGlmIChhcmdzLnJlZmxlY3Rpb25OYW1lIGluIHRoaXMucmVsYXRpb25zaGlwc0NhY2hlKSB7XG4gICAgICByZXR1cm4gdGhpcy5yZWxhdGlvbnNoaXBzQ2FjaGVbYXJncy5yZWZsZWN0aW9uTmFtZV1cbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgY29sbGVjdGlvbiA9IG5ldyBDb2xsZWN0aW9uKGFyZ3MsIHF1ZXJ5QXJncylcbiAgICAgIGNvbnN0IG1vZGVsID0gYXdhaXQgY29sbGVjdGlvbi5maXJzdCgpXG5cbiAgICAgIHRoaXMucmVsYXRpb25zaGlwc0NhY2hlW2FyZ3MucmVmbGVjdGlvbk5hbWVdID0gbW9kZWxcblxuICAgICAgcmV0dXJuIG1vZGVsXG4gICAgfVxuICB9XG5cbiAgX3JlYWRIYXNPbmVSZWZsZWN0aW9uKHtyZWZsZWN0aW9uTmFtZX0pIHtcbiAgICBpZiAocmVmbGVjdGlvbk5hbWUgaW4gdGhpcy5yZWxhdGlvbnNoaXBzKSB7XG4gICAgICByZXR1cm4gdGhpcy5yZWxhdGlvbnNoaXBzW3JlZmxlY3Rpb25OYW1lXVxuICAgIH0gZWxzZSBpZiAocmVmbGVjdGlvbk5hbWUgaW4gdGhpcy5yZWxhdGlvbnNoaXBzQ2FjaGUpIHtcbiAgICAgIHJldHVybiB0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZVtyZWZsZWN0aW9uTmFtZV1cbiAgICB9XG5cbiAgICBpZiAodGhpcy5pc05ld1JlY29yZCgpKSB7XG4gICAgICByZXR1cm4gbnVsbFxuICAgIH1cblxuICAgIGNvbnN0IGxvYWRlZFJlbGF0aW9uc2hpcHMgPSBPYmplY3Qua2V5cyh0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZSlcbiAgICBjb25zdCBtb2RlbENsYXNzTmFtZSA9IGRpZ2codGhpcy5tb2RlbENsYXNzRGF0YSgpLCBcIm5hbWVcIilcblxuICAgIHRocm93IG5ldyBOb3RMb2FkZWRFcnJvcihgJHttb2RlbENsYXNzTmFtZX0jJHtyZWZsZWN0aW9uTmFtZX0gaGFzbid0IGJlZW4gbG9hZGVkIHlldC4gT25seSB0aGVzZSB3ZXJlIGxvYWRlZDogJHtsb2FkZWRSZWxhdGlvbnNoaXBzLmpvaW4oXCIsIFwiKX1gKVxuICB9XG5cbiAgX3JlYWRNb2RlbERhdGFGcm9tQXJncyhhcmdzKSB7XG4gICAgdGhpcy5hYmlsaXRpZXMgPSBhcmdzLmRhdGEuYiB8fCB7fVxuICAgIHRoaXMuY29sbGVjdGlvbiA9IGFyZ3MuY29sbGVjdGlvblxuICAgIHRoaXMubW9kZWxEYXRhID0gb2JqZWN0VG9VbmRlcnNjb3JlKGFyZ3MuZGF0YS5hKVxuICAgIHRoaXMucHJlbG9hZGVkUmVsYXRpb25zaGlwcyA9IGFyZ3MuZGF0YS5yXG4gIH1cblxuICBfcmVhZFByZWxvYWRlZFJlbGF0aW9uc2hpcHMocHJlbG9hZGVkKSB7XG4gICAgaWYgKCF0aGlzLnByZWxvYWRlZFJlbGF0aW9uc2hpcHMpIHtcbiAgICAgIHJldHVyblxuICAgIH1cblxuICAgIGNvbnN0IHJlbGF0aW9uc2hpcHMgPSBkaWdnKHRoaXMubW9kZWxDbGFzc0RhdGEoKSwgXCJyZWxhdGlvbnNoaXBzXCIpXG5cbiAgICBmb3IgKGNvbnN0IHJlbGF0aW9uc2hpcE5hbWUgaW4gdGhpcy5wcmVsb2FkZWRSZWxhdGlvbnNoaXBzKSB7XG4gICAgICBjb25zdCByZWxhdGlvbnNoaXBEYXRhID0gdGhpcy5wcmVsb2FkZWRSZWxhdGlvbnNoaXBzW3JlbGF0aW9uc2hpcE5hbWVdXG4gICAgICBjb25zdCByZWxhdGlvbnNoaXBDbGFzc0RhdGEgPSByZWxhdGlvbnNoaXBzLmZpbmQoKHJlbGF0aW9uc2hpcCkgPT4gZGlnZyhyZWxhdGlvbnNoaXAsIFwibmFtZVwiKSA9PSByZWxhdGlvbnNoaXBOYW1lKVxuXG4gICAgICBpZiAoIXJlbGF0aW9uc2hpcENsYXNzRGF0YSkge1xuICAgICAgICBjb25zdCBtb2RlbE5hbWUgPSBkaWdnKHRoaXMubW9kZWxDbGFzc0RhdGEoKSwgXCJuYW1lXCIpXG4gICAgICAgIGNvbnN0IHJlbGF0aW9uc2hpcHNMaXN0ID0gcmVsYXRpb25zaGlwcy5tYXAoKHJlbGF0aW9uc2hpcCkgPT4gcmVsYXRpb25zaGlwLm5hbWUpLmpvaW4oXCIsIFwiKVxuXG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgQ291bGQgbm90IGZpbmQgdGhlIHJlbGF0aW9uICR7cmVsYXRpb25zaGlwTmFtZX0gb24gdGhlICR7bW9kZWxOYW1lfSBtb2RlbDogJHtyZWxhdGlvbnNoaXBzTGlzdH1gKVxuICAgICAgfVxuXG4gICAgICBjb25zdCByZWxhdGlvbnNoaXBUeXBlID0gZGlnZyhyZWxhdGlvbnNoaXBDbGFzc0RhdGEsIFwiY29sbGVjdGlvbk5hbWVcIilcblxuICAgICAgaWYgKHJlbGF0aW9uc2hpcE5hbWUgaW4gdGhpcy5yZWxhdGlvbnNoaXBzQ2FjaGUpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGAke3JlbGF0aW9uc2hpcE5hbWV9IGhhcyBhbHJlYWR5IGJlZW4gbG9hZGVkYClcbiAgICAgIH1cblxuICAgICAgaWYgKCFyZWxhdGlvbnNoaXBDbGFzc0RhdGEpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBObyByZWxhdGlvbnNoaXAgb24gJHtkaWdnKHRoaXMubW9kZWxDbGFzc0RhdGEoKSwgXCJuYW1lXCIpfSBieSB0aGF0IG5hbWU6ICR7cmVsYXRpb25zaGlwTmFtZX1gKVxuICAgICAgfVxuXG4gICAgICBpZiAoIXJlbGF0aW9uc2hpcERhdGEpIHtcbiAgICAgICAgdGhpcy5yZWxhdGlvbnNoaXBzQ2FjaGVbcmVsYXRpb25zaGlwTmFtZV0gPSBudWxsXG4gICAgICAgIHRoaXMucmVsYXRpb25zaGlwc1tyZWxhdGlvbnNoaXBOYW1lXSA9IG51bGxcbiAgICAgIH0gZWxzZSBpZiAoQXJyYXkuaXNBcnJheShyZWxhdGlvbnNoaXBEYXRhKSkge1xuICAgICAgICB0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZVtyZWxhdGlvbnNoaXBOYW1lXSA9IFtdXG4gICAgICAgIHRoaXMucmVsYXRpb25zaGlwc1tyZWxhdGlvbnNoaXBOYW1lXSA9IFtdXG5cbiAgICAgICAgZm9yIChjb25zdCByZWxhdGlvbnNoaXBJZCBvZiByZWxhdGlvbnNoaXBEYXRhKSB7XG4gICAgICAgICAgY29uc3QgbW9kZWwgPSBwcmVsb2FkZWQuZ2V0TW9kZWwocmVsYXRpb25zaGlwVHlwZSwgcmVsYXRpb25zaGlwSWQpXG5cbiAgICAgICAgICB0aGlzLnJlbGF0aW9uc2hpcHNDYWNoZVtyZWxhdGlvbnNoaXBOYW1lXS5wdXNoKG1vZGVsKVxuICAgICAgICAgIHRoaXMucmVsYXRpb25zaGlwc1tyZWxhdGlvbnNoaXBOYW1lXS5wdXNoKG1vZGVsKVxuICAgICAgICB9XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zdCBtb2RlbCA9IHByZWxvYWRlZC5nZXRNb2RlbChyZWxhdGlvbnNoaXBUeXBlLCByZWxhdGlvbnNoaXBEYXRhKVxuXG4gICAgICAgIHRoaXMucmVsYXRpb25zaGlwc0NhY2hlW3JlbGF0aW9uc2hpcE5hbWVdID0gbW9kZWxcbiAgICAgICAgdGhpcy5yZWxhdGlvbnNoaXBzW3JlbGF0aW9uc2hpcE5hbWVdID0gbW9kZWxcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBwcmltYXJ5S2V5ID0gKCkgPT4gdGhpcy5yZWFkQXR0cmlidXRlVW5kZXJzY29yZSh0aGlzLmNvbnN0cnVjdG9yLnByaW1hcnlLZXkoKSlcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsU0FBUyxNQUFNLHdCQUF3QjtBQUM5QyxPQUFPQyx1QkFBdUIsTUFBTSw4QkFBOEI7QUFDbEUsT0FBT0MsaUJBQWlCLE1BQU0sdUJBQXVCO0FBQ3JELE9BQU9DLFVBQVUsTUFBTSxjQUFjO0FBQ3JDLE9BQU9DLFlBQVksTUFBTSxpQkFBaUI7QUFDMUMsT0FBT0MsTUFBTSxNQUFNLFVBQVU7QUFDN0IsT0FBT0MsV0FBVyxNQUFNLGdCQUFnQjtBQUN4QyxTQUFRQyxJQUFJLFFBQU8sV0FBVztBQUM5QixPQUFPQyxrQkFBa0IsTUFBTSxzQkFBc0I7QUFDckQsT0FBTyxLQUFLQyxVQUFVLE1BQU0sWUFBWTtBQUN4QyxPQUFPQyxTQUFTLE1BQU0sY0FBYztBQUNwQyxPQUFPQyxjQUFjLE1BQU0sb0JBQW9CO0FBQy9DLE9BQU9DLGdCQUFnQixNQUFNLG9CQUFvQjtBQUNqRCxPQUFPQyxVQUFVLE1BQU0seUJBQXlCO0FBQ2hELE9BQU9DLEtBQUssTUFBTSxvQkFBb0I7QUFDdEMsT0FBT0MsUUFBUSxNQUFNLFlBQVk7QUFDakMsT0FBT0MsZUFBZSxNQUFNLG9CQUFvQjtBQUNoRCxTQUFRQyxnQkFBZ0IsUUFBTyxxQkFBcUI7QUFFcEQsTUFBTUMsa0JBQWtCLEdBQUlDLE1BQU0sSUFBSztFQUNyQyxNQUFNQyxTQUFTLEdBQUcsQ0FBQyxDQUFDO0VBRXBCLEtBQUssTUFBTUMsR0FB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