@envive-ai/react-hooks 0.2.4 → 0.2.6-alpha

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 (878) hide show
  1. package/dist/AmplitudeOperations-CDe6oRn4.cjs +41 -0
  2. package/dist/AmplitudeOperations-zFjk1Mkm.js +34 -0
  3. package/dist/{NewOrgConfig-xNlcpcF_.js → NewOrgConfig-ChNJ3ZtC.js} +2 -2
  4. package/dist/{NewOrgConfig-B_1A1d9q.cjs → NewOrgConfig-KHz61ikr.cjs} +2 -2
  5. package/dist/TrackComponentVisibleEvent-f8ahqV1g.js +53 -0
  6. package/dist/TrackComponentVisibleEvent-uEzgBXb9.cjs +60 -0
  7. package/dist/amplitudeContext-CRFxGj_x.d.ts +52 -0
  8. package/dist/amplitudeContext-ZkerrMUa.d.cts +52 -0
  9. package/dist/api-1-73JxnF.js +166 -0
  10. package/dist/api-ZNG6wObS.cjs +239 -0
  11. package/dist/application/models/graphql/index.cjs +3 -3
  12. package/dist/application/models/graphql/index.d.cts +2 -2
  13. package/dist/application/models/graphql/index.d.ts +2 -2
  14. package/dist/application/models/graphql/index.js +2 -3
  15. package/dist/application/models/guards/api/index.cjs +3 -3
  16. package/dist/application/models/guards/api/index.d.cts +2 -2
  17. package/dist/application/models/guards/api/index.d.ts +2 -2
  18. package/dist/application/models/guards/api/index.js +3 -3
  19. package/dist/application/models/guards/utils.cjs +1 -1
  20. package/dist/application/models/guards/utils.d.ts +1 -1
  21. package/dist/application/models/guards/utils.js +1 -1
  22. package/dist/application/models/index.cjs +7 -23
  23. package/dist/application/models/index.d.cts +167 -11
  24. package/dist/application/models/index.d.ts +168 -12
  25. package/dist/application/models/index.js +7 -11
  26. package/dist/application/utils/index.cjs +18 -18
  27. package/dist/application/utils/index.d.cts +16 -65
  28. package/dist/application/utils/index.d.ts +14 -63
  29. package/dist/application/utils/index.js +18 -18
  30. package/dist/{atomStore-BLYJ2ZoQ.js → atomStore-DAQvNPkh.js} +1 -1
  31. package/dist/{atomStore-8ppNkJ_n.cjs → atomStore-DD9g7Zw2.cjs} +1 -1
  32. package/dist/atoms/app/index.cjs +18 -18
  33. package/dist/atoms/app/index.d.cts +9 -20
  34. package/dist/atoms/app/index.d.ts +8 -19
  35. package/dist/atoms/app/index.js +18 -18
  36. package/dist/atoms/atomStore/index.cjs +1 -1
  37. package/dist/atoms/atomStore/index.js +1 -1
  38. package/dist/atoms/chat/index.cjs +20 -20
  39. package/dist/atoms/chat/index.d.cts +37 -45
  40. package/dist/atoms/chat/index.d.ts +35 -43
  41. package/dist/atoms/chat/index.js +20 -20
  42. package/dist/atoms/globalSearch/index.cjs +1 -1
  43. package/dist/atoms/globalSearch/index.d.cts +6 -6
  44. package/dist/atoms/globalSearch/index.d.ts +6 -6
  45. package/dist/atoms/globalSearch/index.js +1 -1
  46. package/dist/atoms/org/index.cjs +10 -11
  47. package/dist/atoms/org/index.d.cts +19 -31
  48. package/dist/atoms/org/index.d.ts +19 -31
  49. package/dist/atoms/org/index.js +2 -3
  50. package/dist/atoms/search/index.cjs +6 -46
  51. package/dist/atoms/search/index.d.cts +76 -14
  52. package/dist/atoms/search/index.d.ts +76 -14
  53. package/dist/atoms/search/index.js +6 -28
  54. package/dist/atoms/search/utils.d.cts +1 -1
  55. package/dist/atoms/search/utils.d.ts +1 -1
  56. package/dist/cdnContext-BLNiW2HT.cjs +53 -0
  57. package/dist/cdnContext-DT6J5nCw.js +38 -0
  58. package/dist/chat-C0cgfkL8.js +230 -0
  59. package/dist/{chat-pXCsesuS.js → chat-ClvJ9xEj.js} +1 -1
  60. package/dist/{chat-sCX7aTrz.cjs → chat-DCGriB7h.cjs} +1 -1
  61. package/dist/chat-DULmjtx1.cjs +330 -0
  62. package/dist/chatState-BrSfXIV4.cjs +120 -0
  63. package/dist/chatState-Cn8JGAlH.js +34 -0
  64. package/dist/{common-4xhjcUbt.cjs → common-DQPvV_S_.cjs} +1 -1
  65. package/dist/{common-DhKoZ6jN.js → common-c_4eX0qn.js} +1 -1
  66. package/dist/{components-BUisjl4v.js → components-CDpaMUjK.js} +1 -1
  67. package/dist/{components-DVaYBroL.cjs → components-DKwVHIjq.cjs} +1 -1
  68. package/dist/config/index.cjs +71 -0
  69. package/dist/config/index.d.cts +5 -0
  70. package/dist/config/index.d.ts +5 -0
  71. package/dist/config/index.js +6 -0
  72. package/dist/config/locators/components/chat/index.cjs +1 -1
  73. package/dist/config/locators/components/chat/index.d.cts +1 -1
  74. package/dist/config/locators/components/chat/index.d.ts +1 -1
  75. package/dist/config/locators/components/chat/index.js +1 -1
  76. package/dist/config/locators/components/chat/variants/index.d.cts +1 -1
  77. package/dist/config/locators/components/chat/variants/index.d.ts +1 -1
  78. package/dist/config/locators/components/common/index.cjs +1 -1
  79. package/dist/config/locators/components/common/index.d.cts +1 -1
  80. package/dist/config/locators/components/common/index.d.ts +1 -1
  81. package/dist/config/locators/components/common/index.js +1 -1
  82. package/dist/config/locators/components/index.cjs +1 -1
  83. package/dist/config/locators/components/index.d.cts +1 -1
  84. package/dist/config/locators/components/index.d.ts +1 -1
  85. package/dist/config/locators/components/index.js +1 -1
  86. package/dist/config/locators/components/search/index.d.cts +1 -1
  87. package/dist/config/locators/components/search/index.d.ts +1 -1
  88. package/dist/config/locators/index.cjs +23 -44
  89. package/dist/config/locators/index.d.cts +5 -26
  90. package/dist/config/locators/index.d.ts +5 -26
  91. package/dist/config/locators/index.js +5 -26
  92. package/dist/contexts/amplitudeContext/index.cjs +18 -18
  93. package/dist/contexts/amplitudeContext/index.d.cts +1 -1
  94. package/dist/contexts/amplitudeContext/index.d.ts +1 -1
  95. package/dist/contexts/amplitudeContext/index.js +18 -18
  96. package/dist/contexts/cdnContext/index.cjs +4 -4
  97. package/dist/contexts/cdnContext/index.d.cts +2 -6
  98. package/dist/contexts/cdnContext/index.d.ts +2 -6
  99. package/dist/contexts/cdnContext/index.js +4 -4
  100. package/dist/contexts/enviveConfigContext/index.cjs +4 -4
  101. package/dist/contexts/enviveConfigContext/index.d.cts +3 -24
  102. package/dist/contexts/enviveConfigContext/index.d.ts +3 -24
  103. package/dist/contexts/enviveConfigContext/index.js +4 -4
  104. package/dist/contexts/enviveCssContext/index.cjs +15 -19
  105. package/dist/contexts/enviveCssContext/index.d.cts +3 -5
  106. package/dist/contexts/enviveCssContext/index.d.ts +3 -5
  107. package/dist/contexts/enviveCssContext/index.js +15 -19
  108. package/dist/contexts/featureFlagContext/index.cjs +9 -10
  109. package/dist/contexts/featureFlagContext/index.d.cts +3 -11
  110. package/dist/contexts/featureFlagContext/index.d.ts +3 -11
  111. package/dist/contexts/featureFlagContext/index.js +6 -7
  112. package/dist/contexts/featureFlagServiceContext/index.cjs +4 -3
  113. package/dist/contexts/featureFlagServiceContext/index.d.cts +1 -4
  114. package/dist/contexts/featureFlagServiceContext/index.d.ts +1 -4
  115. package/dist/contexts/featureFlagServiceContext/index.js +4 -3
  116. package/dist/contexts/graphqlContext/index.cjs +8 -13
  117. package/dist/contexts/graphqlContext/index.d.cts +11 -14
  118. package/dist/contexts/graphqlContext/index.d.ts +11 -14
  119. package/dist/contexts/graphqlContext/index.js +8 -13
  120. package/dist/contexts/localStorageContext/index.cjs +3 -3
  121. package/dist/contexts/localStorageContext/index.d.cts +3 -22
  122. package/dist/contexts/localStorageContext/index.d.ts +3 -22
  123. package/dist/contexts/localStorageContext/index.js +4 -3
  124. package/dist/contexts/newOrgConfigContext/index.cjs +13 -17
  125. package/dist/contexts/newOrgConfigContext/index.d.cts +12 -15
  126. package/dist/contexts/newOrgConfigContext/index.d.ts +12 -15
  127. package/dist/contexts/newOrgConfigContext/index.js +13 -17
  128. package/dist/contexts/searchContext/index.cjs +23 -23
  129. package/dist/contexts/searchContext/index.d.cts +2 -7
  130. package/dist/contexts/searchContext/index.d.ts +2 -7
  131. package/dist/contexts/searchContext/index.js +23 -23
  132. package/dist/contexts/sessionStorageContext/index.cjs +2 -2
  133. package/dist/contexts/sessionStorageContext/index.d.cts +2 -6
  134. package/dist/contexts/sessionStorageContext/index.d.ts +2 -6
  135. package/dist/contexts/sessionStorageContext/index.js +2 -2
  136. package/dist/contexts/shopifyUrlContext/index.cjs +2 -2
  137. package/dist/contexts/shopifyUrlContext/index.d.cts +2 -11
  138. package/dist/contexts/shopifyUrlContext/index.d.ts +2 -11
  139. package/dist/contexts/shopifyUrlContext/index.js +2 -2
  140. package/dist/contexts/systemSettingsContext/index.cjs +4 -4
  141. package/dist/contexts/systemSettingsContext/index.d.cts +4 -14
  142. package/dist/contexts/systemSettingsContext/index.d.ts +4 -14
  143. package/dist/contexts/systemSettingsContext/index.js +4 -4
  144. package/dist/contexts/userIdentityContext/index.cjs +18 -18
  145. package/dist/contexts/userIdentityContext/index.d.cts +11 -2
  146. package/dist/contexts/userIdentityContext/index.d.ts +11 -2
  147. package/dist/contexts/userIdentityContext/index.js +18 -18
  148. package/dist/dist-BZX_Mgfn.cjs +6019 -0
  149. package/dist/dist-CIM4YRqp.js +5923 -0
  150. package/dist/domObserver-DKcas6tl.js +1 -1
  151. package/dist/domObserver-Do6RAJdf.cjs +1 -1
  152. package/dist/enviveConfig-DaotBKMS.cjs +130 -0
  153. package/dist/enviveConfig-DrvYlCYG.js +62 -0
  154. package/dist/enviveConfigContext--89ejDs5.cjs +60 -0
  155. package/dist/enviveConfigContext-BCnzgk4M.js +45 -0
  156. package/dist/events/index.cjs +2 -3
  157. package/dist/events/index.d.cts +2 -15
  158. package/dist/events/index.d.ts +2 -15
  159. package/dist/events/index.js +2 -2
  160. package/dist/events-CgFGtanE.cjs +69 -0
  161. package/dist/events-WOOrnUAx.js +63 -0
  162. package/dist/exceptions/index.cjs +4 -0
  163. package/dist/exceptions/index.d.cts +12 -0
  164. package/dist/exceptions/index.d.ts +12 -0
  165. package/dist/exceptions/index.js +3 -0
  166. package/dist/exceptions-BiSWJEl2.cjs +32 -0
  167. package/dist/exceptions-DSv0ZaH0.js +20 -0
  168. package/dist/featureFlagServiceContext-B7je7VZV.d.cts +24 -0
  169. package/dist/featureFlagServiceContext-BztKnBPk.cjs +66 -0
  170. package/dist/featureFlagServiceContext-DpdlcjNb.js +46 -0
  171. package/dist/featureFlagServiceContext-ahy3jou0.d.ts +24 -0
  172. package/dist/{globalSearch-OiF96VLG.cjs → globalSearch-Cpc8egsM.cjs} +1 -1
  173. package/dist/{globalSearch-B_v9qfCT.js → globalSearch-nmrfGLOn.js} +1 -1
  174. package/dist/graphql-CWNkUHFV.js +46 -0
  175. package/dist/graphql-DT-H-lta.cjs +70 -0
  176. package/dist/graphqlContext-B181y-sa.cjs +111 -0
  177. package/dist/graphqlContext-CWulFxxC.js +96 -0
  178. package/dist/hooks/AmplitudeOperations/index.cjs +20 -21
  179. package/dist/hooks/AmplitudeOperations/index.d.cts +2 -2
  180. package/dist/hooks/AmplitudeOperations/index.d.ts +2 -2
  181. package/dist/hooks/AmplitudeOperations/index.js +19 -20
  182. package/dist/hooks/AppDetails/index.cjs +21 -21
  183. package/dist/hooks/AppDetails/index.d.cts +3 -23
  184. package/dist/hooks/AppDetails/index.d.ts +3 -23
  185. package/dist/hooks/AppDetails/index.js +21 -21
  186. package/dist/hooks/CdnOperations/index.cjs +4 -4
  187. package/dist/hooks/CdnOperations/index.js +4 -4
  188. package/dist/hooks/ChatToggle/index.cjs +23 -23
  189. package/dist/hooks/ChatToggle/index.d.cts +2 -2
  190. package/dist/hooks/ChatToggle/index.d.ts +2 -2
  191. package/dist/hooks/ChatToggle/index.js +21 -21
  192. package/dist/hooks/ChatToggleAnalytics/index.cjs +22 -23
  193. package/dist/hooks/ChatToggleAnalytics/index.d.cts +2 -2
  194. package/dist/hooks/ChatToggleAnalytics/index.d.ts +2 -2
  195. package/dist/hooks/ChatToggleAnalytics/index.js +21 -22
  196. package/dist/hooks/CustomerSupportHandoff/index.cjs +2 -2
  197. package/dist/hooks/CustomerSupportHandoff/index.js +2 -2
  198. package/dist/hooks/Debounce/index.cjs +20 -2
  199. package/dist/hooks/Debounce/index.js +18 -2
  200. package/dist/hooks/ElementObserver/index.cjs +3 -5
  201. package/dist/hooks/ElementObserver/index.d.cts +4 -25
  202. package/dist/hooks/ElementObserver/index.d.ts +4 -25
  203. package/dist/hooks/ElementObserver/index.js +3 -5
  204. package/dist/hooks/GrabAndScroll/index.cjs +1 -1
  205. package/dist/hooks/GrabAndScroll/index.js +1 -1
  206. package/dist/hooks/GraphQLConfig/index.cjs +9 -14
  207. package/dist/hooks/GraphQLConfig/index.d.cts +2 -13
  208. package/dist/hooks/GraphQLConfig/index.d.ts +2 -13
  209. package/dist/hooks/GraphQLConfig/index.js +9 -14
  210. package/dist/hooks/IdentifyUser/index.cjs +18 -18
  211. package/dist/hooks/IdentifyUser/index.js +18 -18
  212. package/dist/hooks/ImageResolver/index.cjs +20 -29
  213. package/dist/hooks/ImageResolver/index.js +20 -29
  214. package/dist/hooks/Intersection/index.cjs +1 -1
  215. package/dist/hooks/Intersection/index.js +1 -1
  216. package/dist/hooks/LocalStorageOperations/index.cjs +8 -7
  217. package/dist/hooks/LocalStorageOperations/index.js +4 -3
  218. package/dist/hooks/MessageFilter/index.cjs +3 -12
  219. package/dist/hooks/MessageFilter/index.d.cts +2 -17
  220. package/dist/hooks/MessageFilter/index.d.ts +2 -17
  221. package/dist/hooks/MessageFilter/index.js +2 -11
  222. package/dist/hooks/NewOrgConfig/index.cjs +14 -18
  223. package/dist/hooks/NewOrgConfig/index.d.cts +3 -16
  224. package/dist/hooks/NewOrgConfig/index.d.ts +3 -16
  225. package/dist/hooks/NewOrgConfig/index.js +14 -18
  226. package/dist/hooks/Search/index.cjs +331 -166
  227. package/dist/hooks/Search/index.d.cts +3 -57
  228. package/dist/hooks/Search/index.d.ts +3 -57
  229. package/dist/hooks/Search/index.js +319 -155
  230. package/dist/hooks/SearchOperations/index.cjs +24 -24
  231. package/dist/hooks/SearchOperations/index.d.cts +2 -3
  232. package/dist/hooks/SearchOperations/index.d.ts +2 -3
  233. package/dist/hooks/SearchOperations/index.js +24 -24
  234. package/dist/hooks/SessionStorageOperations/index.cjs +2 -2
  235. package/dist/hooks/SessionStorageOperations/index.js +2 -2
  236. package/dist/hooks/ShopifyUrlOperations/index.cjs +3 -3
  237. package/dist/hooks/ShopifyUrlOperations/index.d.cts +3 -5
  238. package/dist/hooks/ShopifyUrlOperations/index.d.ts +3 -5
  239. package/dist/hooks/ShopifyUrlOperations/index.js +3 -3
  240. package/dist/hooks/SnapCalculator/index.cjs +1 -1
  241. package/dist/hooks/SnapCalculator/index.d.cts +4 -3
  242. package/dist/hooks/SnapCalculator/index.d.ts +4 -3
  243. package/dist/hooks/SnapCalculator/index.js +1 -1
  244. package/dist/hooks/SystemSettingsContext/index.cjs +17 -6
  245. package/dist/hooks/SystemSettingsContext/index.d.cts +5 -15
  246. package/dist/hooks/SystemSettingsContext/index.d.ts +5 -15
  247. package/dist/hooks/SystemSettingsContext/index.js +15 -6
  248. package/dist/hooks/TrackComponentVisibleEvent/index.cjs +20 -20
  249. package/dist/hooks/TrackComponentVisibleEvent/index.d.cts +2 -3
  250. package/dist/hooks/TrackComponentVisibleEvent/index.d.ts +2 -3
  251. package/dist/hooks/TrackComponentVisibleEvent/index.js +20 -20
  252. package/dist/hooks/UpdateAnalyticsProps/index.cjs +20 -20
  253. package/dist/hooks/UpdateAnalyticsProps/index.js +19 -19
  254. package/dist/hooks/utils.cjs +1 -1
  255. package/dist/hooks/utils.d.cts +20 -13
  256. package/dist/hooks/utils.d.ts +20 -13
  257. package/dist/hooks/utils.js +1 -1
  258. package/dist/index-B4cSHxVN.d.ts +22 -0
  259. package/dist/{index-DzbkQtaK.d.cts → index-BQpWG3Jm.d.cts} +1 -1
  260. package/dist/index-BVZbvpx_.d.cts +11 -0
  261. package/dist/index-CEmUfoZa.d.ts +42 -0
  262. package/dist/index-CMZcE7pk.d.cts +224 -0
  263. package/dist/{index-DzzKdrcZ.d.ts → index-CYGpI6hE.d.ts} +1 -1
  264. package/dist/{index-9NE86em3.d.cts → index-ClVBVK15.d.cts} +1 -1
  265. package/dist/{index-Dy22w7kg.d.ts → index-Clf4wYaJ.d.ts} +1 -1
  266. package/dist/index-DeQte6mb.d.ts +11 -0
  267. package/dist/index-Dzv6WwSZ.d.ts +224 -0
  268. package/dist/index-ca7Qn8o0.d.cts +22 -0
  269. package/dist/{index-C1nwLU6Q.d.ts → index-dngXrfnT.d.ts} +1 -1
  270. package/dist/index-qOBU4GEh.d.cts +42 -0
  271. package/dist/{index-Da1s8h5C.d.cts → index-w64il54a.d.cts} +1 -1
  272. package/dist/interceptors/index.cjs +28 -3
  273. package/dist/interceptors/index.d.cts +4 -15
  274. package/dist/interceptors/index.d.ts +4 -15
  275. package/dist/interceptors/index.js +25 -3
  276. package/dist/localStorageContext-DSpmlfyr.js +90 -0
  277. package/dist/localStorageContext-DbWl7Row.cjs +104 -0
  278. package/dist/locators-BMQGmGLq.js +23 -0
  279. package/dist/locators-DxYdak1F.cjs +131 -0
  280. package/dist/{logger-Cp7J4YJT.cjs → logger-BF6iGSVd.cjs} +1 -1
  281. package/dist/{logger-oAgZx2-m.js → logger-DCs3_11o.js} +1 -1
  282. package/dist/models-158fyHt9.cjs +1305 -0
  283. package/dist/models-DEJUuKYQ.js +1118 -0
  284. package/dist/newOrgConfigAtom-BuQE_zPK.js +8 -0
  285. package/dist/{newOrgConfigAtom-B9FW3fDc.cjs → newOrgConfigAtom-rrYHmp1b.cjs} +1 -1
  286. package/dist/newOrgConfigContext-BVrzYatq.cjs +68 -0
  287. package/dist/newOrgConfigContext-C0LzIRJ7.js +53 -0
  288. package/dist/nodeSelector-CbWcUbuc.d.ts +28 -0
  289. package/dist/nodeSelector-Cj-Xl1LP.d.cts +28 -0
  290. package/dist/org-CVjyv-gv.cjs +111 -0
  291. package/dist/org-Ct9Vjv1J.js +32 -0
  292. package/dist/search-C0TAcTeY.cjs +312 -0
  293. package/dist/search-DLHzcbfP.js +233 -0
  294. package/dist/searchContext-Dmtue5QO.js +129 -0
  295. package/dist/searchContext-l_23fiuP.cjs +145 -0
  296. package/dist/searchServiceAdapter-B0h7psvh.js +16 -0
  297. package/dist/searchServiceAdapter-BclWy4fE.cjs +34 -0
  298. package/dist/sessionStorageContext-BOyr7mIM.cjs +66 -0
  299. package/dist/sessionStorageContext-ClXN9eX4.js +52 -0
  300. package/dist/shopifyUrlContext-G9eqIcsL.cjs +75 -0
  301. package/dist/shopifyUrlContext-WAm0pnPh.js +61 -0
  302. package/dist/src/application/commerce-api.js +406 -0
  303. package/dist/src/application/logging/logger.js +16 -0
  304. package/dist/src/application/models/graphql/index.js +3 -0
  305. package/dist/src/application/models/graphql/queries/getMerchantColorsQuery.js +13 -0
  306. package/dist/src/application/models/graphql/queries/getMerchantFrontendConfigQuery.js +13 -0
  307. package/dist/src/application/models/graphql/queries/getMerchantOrgIdQuery.js +10 -0
  308. package/dist/src/application/models/guards/api/index.js +12 -0
  309. package/dist/src/application/models/guards/api/isApiFormResponse.js +59 -0
  310. package/dist/src/application/models/guards/api/isApiFormSubmittedResponseAttributes.js +22 -0
  311. package/dist/src/application/models/guards/api/isApiOrderResponseAttributes.js +91 -0
  312. package/dist/src/application/models/guards/api/isApiOrgConfigResults.js +188 -0
  313. package/dist/src/application/models/guards/api/isApiOrganizationConfig.js +115 -0
  314. package/dist/src/application/models/guards/api/isApiPDPEventAttributes.js +16 -0
  315. package/dist/src/application/models/guards/api/isApiPLPEventAttributes.js +26 -0
  316. package/dist/src/application/models/guards/api/isApiPageResponseAttributes.js +15 -0
  317. package/dist/src/application/models/guards/api/isApiProductResponseAttributes.js +65 -0
  318. package/dist/src/application/models/guards/api/isApiProductSearchAttributes.js +15 -0
  319. package/dist/src/application/models/guards/api/isApiProductSearchFilterAttributes.js +10 -0
  320. package/dist/src/application/models/guards/api/isApiQueryTypedEventAttributes.js +4 -0
  321. package/dist/src/application/models/guards/api/isApiResponse.js +33 -0
  322. package/dist/src/application/models/guards/api/isApiReviewResponseAttributes.js +22 -0
  323. package/dist/src/application/models/guards/api/isApiReviewRichInformation.js +23 -0
  324. package/dist/src/application/models/guards/api/isApiSearchEventAttributes.js +20 -0
  325. package/dist/src/application/models/guards/api/isApiSuggestion.js +24 -0
  326. package/dist/src/application/models/guards/api/isApiSuggestionClickedEventAttributes.js +4 -0
  327. package/dist/src/application/models/guards/api/isApiTextResponseAttributes.js +4 -0
  328. package/dist/src/application/models/guards/api/isApiUserEvent.js +18 -0
  329. package/dist/src/application/models/guards/graphQL/isGraphQLColorsConfig.js +41 -0
  330. package/dist/src/application/models/guards/isBaseEcommerceEvent.js +14 -0
  331. package/dist/src/application/models/guards/isGA4EcommerceEvent.js +14 -0
  332. package/dist/src/application/models/guards/isLegacyUAEcommerceEvent.js +14 -0
  333. package/dist/src/application/models/guards/isMobilePLPChatPlacementParameter.js +4 -0
  334. package/dist/src/application/models/guards/isSpanxTakeAQuizCtaParameter.js +1 -0
  335. package/dist/src/application/models/guards/isVariantInfo.js +28 -0
  336. package/dist/src/application/models/guards/utils.js +34 -0
  337. package/dist/src/application/models/index.js +34 -0
  338. package/dist/src/application/models/utils/snakeToCamelTransformer.js +71 -0
  339. package/dist/src/application/models/utils/stringToFulfillmentDisplayStatusEnumValue.js +65 -0
  340. package/dist/src/application/models/validators/validateGraphQLColorsConfig.js +9 -0
  341. package/dist/src/application/models/validators/validateGraphQLFrontendConfig.js +420 -0
  342. package/dist/src/application/models/validators/validateGraphQLOrgId.js +6 -0
  343. package/dist/src/application/models/validators/validateMobilePLPChatPlacementParameter.js +9 -0
  344. package/dist/src/application/models/validators/validateOrgConfigResults.js +44 -0
  345. package/dist/src/application/models/validators/validateOrganizationConfig.js +34 -0
  346. package/dist/src/application/models/validators/validateResponse.js +173 -0
  347. package/dist/src/application/models/validators/validateSuggestion.js +13 -0
  348. package/dist/src/application/models/validators/validateUserEvent.js +91 -0
  349. package/dist/src/application/utils/analyticsUtils.js +94 -0
  350. package/dist/src/application/utils/coreContextToApiContext.js +8 -0
  351. package/dist/src/application/utils/coreUserEventToApiUserEvent.js +90 -0
  352. package/dist/src/application/utils/divideArray.js +7 -0
  353. package/dist/src/application/utils/domObserver.js +85 -0
  354. package/dist/src/application/utils/elementObserver.js +186 -0
  355. package/dist/src/application/utils/imageFilter.js +11 -0
  356. package/dist/src/application/utils/index.js +21 -0
  357. package/dist/src/application/utils/merchantUtils.js +15 -0
  358. package/dist/src/application/utils/messageFromFormSubmittedEvent.js +19 -0
  359. package/dist/src/application/utils/messageFromQueryEvent.js +35 -0
  360. package/dist/src/application/utils/messageFromResponse.js +123 -0
  361. package/dist/src/application/utils/messageFromSuggestionEvent.js +27 -0
  362. package/dist/src/application/utils/mouseEventTypes.js +1 -0
  363. package/dist/src/application/utils/mutationHelper.js +33 -0
  364. package/dist/src/application/utils/nextMessageRequestToApiRequest.js +29 -0
  365. package/dist/src/application/utils/nodeSelector.js +101 -0
  366. package/dist/src/application/utils/overrides.js +144 -0
  367. package/dist/src/application/utils/stringUtils.js +47 -0
  368. package/dist/src/application/utils/supportedEventRequestToApiRequest.js +7 -0
  369. package/dist/src/application/utils/urlsParser.js +33 -0
  370. package/dist/src/application/utils/validation.js +5 -0
  371. package/dist/src/atoms/amplitude/amplitudeTrackEventAtom.js +4 -0
  372. package/dist/src/atoms/app/index.js +23 -0
  373. package/dist/src/atoms/app/variant.js +102 -0
  374. package/dist/src/atoms/atomStore/atomStore.js +28 -0
  375. package/dist/src/atoms/atomStore/index.js +1 -0
  376. package/dist/src/atoms/chat/chatState.js +33 -0
  377. package/dist/src/atoms/chat/form.js +16 -0
  378. package/dist/src/atoms/chat/index.js +23 -0
  379. package/dist/src/atoms/chat/lastMessage.js +10 -0
  380. package/dist/src/atoms/chat/messageQueue.js +68 -0
  381. package/dist/src/atoms/chat/performanceMetrics.js +70 -0
  382. package/dist/src/atoms/chat/renderedWidgetRefs.js +24 -0
  383. package/dist/src/atoms/chat/replies.js +43 -0
  384. package/dist/src/atoms/chat/suggestions.js +29 -0
  385. package/dist/src/atoms/envive/enviveConfig.js +67 -0
  386. package/dist/src/atoms/globalSearch/globalSearch.js +8 -0
  387. package/dist/src/atoms/globalSearch/index.js +1 -0
  388. package/dist/src/atoms/org/customerService.js +6 -0
  389. package/dist/src/atoms/org/graphqlConfig.js +8 -0
  390. package/dist/src/atoms/org/index.js +4 -0
  391. package/dist/src/atoms/org/newOrgConfigAtom.js +2 -0
  392. package/dist/src/atoms/org/orgAnalyticsConfig.js +8 -0
  393. package/dist/src/atoms/search/index.js +1 -0
  394. package/dist/src/atoms/search/productFilters.js +163 -0
  395. package/dist/src/atoms/search/productRetrievalAPI.js +50 -0
  396. package/dist/src/atoms/search/productRetrievalAdapter.js +14 -0
  397. package/dist/src/atoms/search/productSorter.js +13 -0
  398. package/dist/src/atoms/search/searchAPI.js +140 -0
  399. package/dist/src/atoms/search/searchServiceAdapter.js +14 -0
  400. package/dist/src/atoms/search/utils.js +15 -0
  401. package/dist/src/config/index.js +1 -0
  402. package/dist/src/config/locators/components/chat/entrypoints.js +10 -0
  403. package/dist/src/config/locators/components/chat/index.js +21 -0
  404. package/dist/src/config/locators/components/chat/preview.js +11 -0
  405. package/dist/src/config/locators/components/chat/variants/index.js +12 -0
  406. package/dist/src/config/locators/components/common/buttons.js +6 -0
  407. package/dist/src/config/locators/components/common/cards.js +17 -0
  408. package/dist/src/config/locators/components/common/index.js +4 -0
  409. package/dist/src/config/locators/components/common/links.js +1 -0
  410. package/dist/src/config/locators/components/common/tables.js +1 -0
  411. package/dist/src/config/locators/components/floating-button.js +2 -0
  412. package/dist/src/config/locators/components/index.js +3 -0
  413. package/dist/src/config/locators/components/report-issue.js +13 -0
  414. package/dist/src/config/locators/components/search/index.js +5 -0
  415. package/dist/src/config/locators/components/shadow-dom.js +1 -0
  416. package/dist/src/config/locators/embedded.js +20 -0
  417. package/dist/src/config/locators/index.js +4 -0
  418. package/dist/src/contexts/amplitudeContext/amplitudeContext.js +292 -0
  419. package/dist/src/contexts/amplitudeContext/index.js +1 -0
  420. package/dist/src/contexts/cdnContext/cdnContext.js +28 -0
  421. package/dist/src/contexts/cdnContext/index.js +1 -0
  422. package/dist/src/contexts/enviveConfigContext/enviveConfigContext.js +37 -0
  423. package/dist/src/contexts/enviveConfigContext/index.js +1 -0
  424. package/dist/src/contexts/enviveCssContext/enviveCssContext.js +31 -0
  425. package/dist/src/contexts/enviveCssContext/index.js +1 -0
  426. package/dist/src/contexts/featureFlagContext/featureFlagContext.js +109 -0
  427. package/dist/src/contexts/featureFlagContext/index.js +1 -0
  428. package/dist/src/contexts/featureFlagServiceContext/featureFlagServiceContext.js +47 -0
  429. package/dist/src/contexts/featureFlagServiceContext/index.js +1 -0
  430. package/dist/src/contexts/graphqlContext/graphqlContext.js +87 -0
  431. package/dist/src/contexts/graphqlContext/index.js +1 -0
  432. package/dist/src/contexts/localStorageContext/index.js +1 -0
  433. package/dist/src/contexts/localStorageContext/localStorageContext.js +95 -0
  434. package/dist/src/contexts/newOrgConfigContext/index.js +1 -0
  435. package/dist/src/contexts/newOrgConfigContext/newOrgConfigContext.js +33 -0
  436. package/dist/src/contexts/searchContext/index.js +1 -0
  437. package/dist/src/contexts/searchContext/searchContext.js +131 -0
  438. package/dist/src/contexts/sessionStorageContext/index.js +1 -0
  439. package/dist/src/contexts/sessionStorageContext/sessionStorageContext.js +43 -0
  440. package/dist/src/contexts/shopifyUrlContext/index.js +1 -0
  441. package/dist/src/contexts/shopifyUrlContext/shopifyUrlContext.js +62 -0
  442. package/dist/src/contexts/systemSettingsContext/index.js +1 -0
  443. package/dist/src/contexts/systemSettingsContext/systemSettingsContext.js +29 -0
  444. package/dist/src/contexts/userIdentityContext/index.js +1 -0
  445. package/dist/src/contexts/userIdentityContext/userIdentityContext.js +118 -0
  446. package/dist/src/events/index.js +51 -0
  447. package/dist/src/events/registerAnalyticsListeners.js +32 -0
  448. package/dist/src/exceptions/index.js +2 -0
  449. package/dist/src/exceptions/sessionExceptions.js +6 -0
  450. package/dist/src/exceptions/unsupportedProductExceptions.js +6 -0
  451. package/dist/src/hooks/AmplitudeOperations/index.js +1 -0
  452. package/dist/src/hooks/AmplitudeOperations/useAmplitudeOperations.js +24 -0
  453. package/dist/src/hooks/AppDetails/index.js +1 -0
  454. package/dist/src/hooks/AppDetails/useAppDetails.js +26 -0
  455. package/dist/src/hooks/BlockBackButton/index.js +1 -0
  456. package/dist/src/hooks/BlockBackButton/useBlockBackButton.js +23 -0
  457. package/dist/src/hooks/CdnOperations/index.js +1 -0
  458. package/dist/src/hooks/CdnOperations/useCdnOperations.js +13 -0
  459. package/dist/src/hooks/ChatToggle/index.js +1 -0
  460. package/dist/src/hooks/ChatToggle/useChatToggle.js +50 -0
  461. package/dist/src/hooks/ChatToggleAnalytics/index.js +1 -0
  462. package/dist/src/hooks/ChatToggleAnalytics/useChatToggleAnalytics.js +11 -0
  463. package/dist/src/hooks/CustomerSupportHandoff/index.js +1 -0
  464. package/dist/src/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.js +32 -0
  465. package/dist/src/hooks/Debounce/index.js +1 -0
  466. package/dist/src/hooks/Debounce/useDebounce.js +13 -0
  467. package/dist/src/hooks/ElementObserver/index.js +1 -0
  468. package/dist/src/hooks/ElementObserver/useElementObserver.js +208 -0
  469. package/dist/src/hooks/GrabAndScroll/index.js +1 -0
  470. package/dist/src/hooks/GrabAndScroll/useGrabAndScroll.js +105 -0
  471. package/dist/src/hooks/GraphQLConfig/index.js +1 -0
  472. package/dist/src/hooks/GraphQLConfig/useGraphQLConfig.js +54 -0
  473. package/dist/src/hooks/IdentifyUser/index.js +1 -0
  474. package/dist/src/hooks/IdentifyUser/useIdentifyUser.js +28 -0
  475. package/dist/src/hooks/ImageResolver/index.js +1 -0
  476. package/dist/src/hooks/ImageResolver/useImageResolver.js +45 -0
  477. package/dist/src/hooks/Intersection/index.js +1 -0
  478. package/dist/src/hooks/Intersection/useIntersection.js +20 -0
  479. package/dist/src/hooks/IsSmallScreen/index.js +1 -0
  480. package/dist/src/hooks/IsSmallScreen/useIsSmallScreen.js +16 -0
  481. package/dist/src/hooks/LocalStorageOperations/index.js +1 -0
  482. package/dist/src/hooks/LocalStorageOperations/useLocalStorageOperations.js +64 -0
  483. package/dist/src/hooks/MessageFilter/index.js +1 -0
  484. package/dist/src/hooks/MessageFilter/useMessageFilter.js +37 -0
  485. package/dist/src/hooks/MessageScrollObserver/index.js +1 -0
  486. package/dist/src/hooks/MessageScrollObserver/useMessageScrollObserver.js +35 -0
  487. package/dist/src/hooks/NewOrgConfig/index.js +1 -0
  488. package/dist/src/hooks/NewOrgConfig/useNewOrgConfig.js +5 -0
  489. package/dist/src/hooks/Search/index.js +1 -0
  490. package/dist/src/hooks/Search/useRecommendedProducts.js +35 -0
  491. package/dist/src/hooks/Search/useSearch.js +224 -0
  492. package/dist/src/hooks/Search/useSearchInput.js +183 -0
  493. package/dist/src/hooks/SearchOperations/index.js +1 -0
  494. package/dist/src/hooks/SearchOperations/useSearchOperations.js +78 -0
  495. package/dist/src/hooks/SessionStorageOperations/index.js +1 -0
  496. package/dist/src/hooks/SessionStorageOperations/useSessionStorageOperations.js +20 -0
  497. package/dist/src/hooks/ShopifyUrlOperations/index.js +1 -0
  498. package/dist/src/hooks/ShopifyUrlOperations/useShopifyUrlOperations.js +34 -0
  499. package/dist/src/hooks/SnapCalculator/index.js +1 -0
  500. package/dist/src/hooks/SnapCalculator/useSnapCalculator.js +22 -0
  501. package/dist/src/hooks/SystemSettingsContext/index.js +1 -0
  502. package/dist/src/hooks/SystemSettingsContext/useSystemSettingsContext.js +9 -0
  503. package/dist/src/hooks/TrackComponentVisibleEvent/index.js +1 -0
  504. package/dist/src/hooks/TrackComponentVisibleEvent/useTrackComponentVisibleEvent.js +45 -0
  505. package/dist/src/hooks/UpdateAnalyticsProps/index.js +1 -0
  506. package/dist/src/hooks/UpdateAnalyticsProps/useUpdateAnalyticsProps.js +43 -0
  507. package/dist/src/hooks/utils.js +116 -0
  508. package/dist/src/interceptors/index.js +1 -0
  509. package/dist/src/interceptors/useMessageInterceptor.js +24 -0
  510. package/dist/src/types/ApiResponse.js +1 -0
  511. package/dist/src/types/FilterAttribute.js +3 -0
  512. package/dist/src/types/Message.js +24 -0
  513. package/dist/src/types/Suggestion.js +3 -0
  514. package/dist/src/types/index.js +4 -0
  515. package/dist/src/util/colorVar.js +3 -0
  516. package/dist/src/util/configVersion.js +4 -0
  517. package/dist/src/util/domInsertion.js +16 -0
  518. package/dist/systemSettingsContext-Cb5kczBD.cjs +60 -0
  519. package/dist/systemSettingsContext-CksCdpiU.js +39 -0
  520. package/dist/types/index.cjs +3 -33
  521. package/dist/types/index.d.cts +2 -3
  522. package/dist/types/index.d.ts +2 -3
  523. package/dist/types/index.js +2 -30
  524. package/dist/types-18QXD2rd.cjs +39 -0
  525. package/dist/types-DQC1pHqD.js +27 -0
  526. package/dist/urlsParser-C-Vzs--G.cjs +78 -0
  527. package/dist/urlsParser-G7Ocwg0M.js +42 -0
  528. package/dist/useAppDetails-BJFRSYbI.js +30 -0
  529. package/dist/useAppDetails-Czn-5FzP.cjs +38 -0
  530. package/dist/useGraphQLConfig-BEtX5pDM.cjs +76 -0
  531. package/dist/useGraphQLConfig-Dkcrz1YL.js +63 -0
  532. package/dist/{useIntersection-UEO0Cezc.js → useIntersection-BWiHkpKL.js} +1 -1
  533. package/dist/{useIntersection-rV0Q8mBH.cjs → useIntersection-DZHz44BY.cjs} +1 -1
  534. package/dist/{utils-ARmpTh1O.js → utils-CEKzBcN2.js} +1 -1
  535. package/dist/utils-CPvqOk0g.cjs +1546 -0
  536. package/dist/{utils-Cavu4XiM.cjs → utils-CsMbZmRw.cjs} +1 -1
  537. package/dist/utils-D_kATUj6.js +92 -0
  538. package/dist/utils-N47VsL9W.js +1364 -0
  539. package/dist/utils-hYTjy7hJ.cjs +130 -0
  540. package/dist/{utils-BLe5oreh.d.ts → utils-wWki3L1d.d.ts} +1 -1
  541. package/package.json +15 -25
  542. package/src/application/commerce-api.ts +38 -37
  543. package/src/application/models/graphql/index.ts +1 -0
  544. package/src/application/models/graphql/queries/getMerchantColorsQuery.ts +1 -23
  545. package/src/application/models/graphql/queries/getMerchantFrontendConfigQuery.ts +1 -89
  546. package/src/application/models/guards/api/isApiFormResponse.ts +4 -4
  547. package/src/application/models/guards/api/isApiFormSubmittedResponseAttributes.ts +2 -2
  548. package/src/application/models/guards/api/isApiOrderResponseAttributes.ts +2 -20
  549. package/src/application/models/guards/api/isApiOrgConfigResults.ts +3 -9
  550. package/src/application/models/guards/api/isApiOrganizationConfig.ts +8 -32
  551. package/src/application/models/guards/api/isApiPDPEventAttributes.ts +8 -5
  552. package/src/application/models/guards/api/isApiPLPEventAttributes.ts +14 -10
  553. package/src/application/models/guards/api/isApiPageResponseAttributes.ts +1 -1
  554. package/src/application/models/guards/api/isApiProductResponseAttributes.ts +2 -4
  555. package/src/application/models/guards/api/isApiProductSearchAttributes.ts +9 -6
  556. package/src/application/models/guards/api/isApiProductSearchFilterAttributes.ts +7 -4
  557. package/src/application/models/guards/api/isApiQueryTypedEventAttributes.ts +8 -3
  558. package/src/application/models/guards/api/isApiResponse.ts +22 -15
  559. package/src/application/models/guards/api/isApiReviewResponseAttributes.ts +1 -1
  560. package/src/application/models/guards/api/isApiReviewRichInformation.ts +1 -1
  561. package/src/application/models/guards/api/isApiTextResponseAttributes.ts +1 -1
  562. package/src/application/models/guards/graphQL/isGraphQLColorsConfig.ts +1 -1
  563. package/src/application/models/guards/isBaseEcommerceEvent.ts +1 -2
  564. package/src/application/models/guards/isGA4EcommerceEvent.ts +1 -1
  565. package/src/application/models/guards/isLegacyUAEcommerceEvent.ts +1 -1
  566. package/src/application/models/guards/isMobilePLPChatPlacementParameter.ts +1 -3
  567. package/src/application/models/guards/isSpanxTakeAQuizCtaParameter.ts +5 -3
  568. package/src/application/models/guards/isVariantInfo.ts +6 -1
  569. package/src/application/models/index.ts +30 -95
  570. package/src/application/models/utils/snakeToCamelTransformer.ts +8 -8
  571. package/src/application/models/validators/validateGraphQLColorsConfig.ts +6 -2
  572. package/src/application/models/validators/validateGraphQLFrontendConfig.ts +6 -6
  573. package/src/application/models/validators/validateMobilePLPChatPlacementParameter.ts +5 -3
  574. package/src/application/models/validators/validateOrgConfigResults.ts +6 -5
  575. package/src/application/models/validators/validateOrganizationConfig.ts +11 -8
  576. package/src/application/models/validators/validateResponse.ts +66 -44
  577. package/src/application/models/validators/validateSuggestion.ts +1 -1
  578. package/src/application/models/validators/validateUserEvent.ts +23 -12
  579. package/src/application/utils/analyticsUtils.ts +16 -38
  580. package/src/application/utils/coreContextToApiContext.ts +3 -1
  581. package/src/application/utils/coreUserEventToApiUserEvent.ts +2 -2
  582. package/src/application/utils/elementObserver.ts +1 -1
  583. package/src/application/utils/imageFilter.ts +5 -2
  584. package/src/application/utils/index.ts +20 -21
  585. package/src/application/utils/messageFromFormSubmittedEvent.ts +1 -1
  586. package/src/application/utils/messageFromQueryEvent.ts +1 -1
  587. package/src/application/utils/messageFromResponse.ts +14 -10
  588. package/src/application/utils/messageFromSuggestionEvent.ts +6 -4
  589. package/src/application/utils/mouseEventTypes.ts +1 -1
  590. package/src/application/utils/nextMessageRequestToApiRequest.ts +1 -1
  591. package/src/application/utils/overrides.ts +1 -49
  592. package/src/application/utils/supportedEventRequestToApiRequest.ts +3 -1
  593. package/src/application/utils/urlsParser.ts +1 -7
  594. package/src/atoms/app/index.ts +15 -25
  595. package/src/atoms/app/variant.ts +1 -1
  596. package/src/atoms/chat/chatState.ts +9 -14
  597. package/src/atoms/chat/form.ts +1 -1
  598. package/src/atoms/chat/messageQueue.ts +25 -50
  599. package/src/atoms/chat/replies.ts +40 -43
  600. package/src/atoms/chat/suggestions.ts +34 -29
  601. package/src/atoms/envive/enviveConfig.ts +14 -20
  602. package/src/atoms/org/customerService.ts +4 -8
  603. package/src/atoms/org/graphqlConfig.ts +7 -15
  604. package/src/atoms/org/index.ts +4 -6
  605. package/src/atoms/org/newOrgConfigAtom.ts +2 -2
  606. package/src/atoms/org/orgAnalyticsConfig.ts +1 -1
  607. package/src/atoms/search/index.ts +0 -1
  608. package/src/atoms/search/productFilters.ts +72 -52
  609. package/src/atoms/search/productRetrievalAPI.ts +72 -0
  610. package/src/atoms/search/productRetrievalAdapter.ts +28 -0
  611. package/src/atoms/search/productSorter.ts +2 -2
  612. package/src/atoms/search/searchAPI.ts +42 -60
  613. package/src/atoms/search/searchServiceAdapter.ts +1 -1
  614. package/src/config/index.ts +1 -0
  615. package/src/contexts/amplitudeContext/amplitudeContext.tsx +104 -143
  616. package/src/contexts/cdnContext/cdnContext.tsx +9 -16
  617. package/src/contexts/enviveConfigContext/enviveConfigContext.tsx +6 -27
  618. package/src/contexts/enviveCssContext/enviveCssContext.tsx +5 -12
  619. package/src/contexts/featureFlagContext/featureFlagContext.tsx +27 -48
  620. package/src/contexts/featureFlagServiceContext/featureFlagServiceContext.tsx +11 -3
  621. package/src/contexts/graphqlContext/graphqlContext.tsx +40 -95
  622. package/src/contexts/localStorageContext/localStorageContext.tsx +26 -60
  623. package/src/contexts/newOrgConfigContext/newOrgConfigContext.tsx +10 -22
  624. package/src/contexts/searchContext/searchContext.tsx +29 -49
  625. package/src/contexts/sessionStorageContext/sessionStorageContext.tsx +12 -33
  626. package/src/contexts/shopifyUrlContext/shopifyUrlContext.tsx +20 -37
  627. package/src/contexts/systemSettingsContext/systemSettingsContext.tsx +8 -21
  628. package/src/contexts/userIdentityContext/userIdentityContext.tsx +33 -77
  629. package/src/events/index.ts +8 -5
  630. package/src/events/registerAnalyticsListeners.ts +10 -13
  631. package/src/exceptions/index.ts +2 -0
  632. package/src/{types/exceptions → exceptions}/unsupportedProductExceptions.ts +2 -2
  633. package/src/global.d.ts +8 -0
  634. package/src/hooks/AmplitudeOperations/useAmplitudeOperations.ts +6 -11
  635. package/src/hooks/AppDetails/useAppDetails.ts +10 -24
  636. package/src/hooks/ChatToggle/useChatToggle.ts +7 -19
  637. package/src/hooks/ChatToggleAnalytics/useChatToggleAnalytics.ts +4 -4
  638. package/src/hooks/CustomerSupportHandoff/useCustomerSupportHandoff.ts +1 -1
  639. package/src/hooks/ElementObserver/useElementObserver.ts +14 -32
  640. package/src/hooks/GrabAndScroll/useGrabAndScroll.ts +125 -124
  641. package/src/hooks/GraphQLConfig/useGraphQLConfig.ts +5 -7
  642. package/src/hooks/ImageResolver/useImageResolver.ts +24 -31
  643. package/src/hooks/LocalStorageOperations/useLocalStorageOperations.ts +12 -19
  644. package/src/hooks/MessageFilter/useMessageFilter.ts +1 -7
  645. package/src/hooks/Search/useRecommendedProducts.ts +50 -0
  646. package/src/hooks/Search/useSearch.tsx +80 -210
  647. package/src/hooks/Search/useSearchInput.ts +227 -0
  648. package/src/hooks/SearchOperations/useSearchOperations.ts +8 -12
  649. package/src/hooks/ShopifyUrlOperations/useShopifyUrlOperations.ts +8 -14
  650. package/src/hooks/SnapCalculator/useSnapCalculator.ts +1 -2
  651. package/src/hooks/TrackComponentVisibleEvent/useTrackComponentVisibleEvent.ts +8 -11
  652. package/src/hooks/UpdateAnalyticsProps/useUpdateAnalyticsProps.ts +11 -25
  653. package/src/hooks/utils.ts +19 -29
  654. package/src/interceptors/index.ts +1 -2
  655. package/src/interceptors/useMessageInterceptor.ts +10 -6
  656. package/src/{application/models/api/response.ts → types/ApiResponse.ts} +35 -29
  657. package/src/types/FilterAttribute.ts +35 -0
  658. package/src/{application/models/message.ts → types/Message.ts} +38 -34
  659. package/src/types/Suggestion.ts +6 -0
  660. package/src/types/index.ts +4 -4
  661. package/src/util/colorVar.ts +4 -0
  662. package/src/util/configVersion.ts +4 -0
  663. package/src/util/domInsertion.ts +17 -0
  664. package/dist/SystemSettingsContext-CCuS3kWH.js +0 -13
  665. package/dist/SystemSettingsContext-Dh_35fES.cjs +0 -20
  666. package/dist/TrackComponentVisibleEvent-B828giM-.js +0 -52
  667. package/dist/TrackComponentVisibleEvent-DsTIH7Yt.cjs +0 -59
  668. package/dist/amplitudeContext-B73xamNe.d.cts +0 -52
  669. package/dist/amplitudeContext-BfRDG5CX.d.ts +0 -52
  670. package/dist/api-Bc3_julZ.cjs +0 -239
  671. package/dist/api-D9gmGNAV.js +0 -166
  672. package/dist/application/models/utilityTypes/index.cjs +0 -1
  673. package/dist/application/models/utilityTypes/index.d.cts +0 -2
  674. package/dist/application/models/utilityTypes/index.d.ts +0 -2
  675. package/dist/application/models/utilityTypes/index.js +0 -3
  676. package/dist/application/models/variantInfo/index.cjs +0 -3
  677. package/dist/application/models/variantInfo/index.d.cts +0 -2
  678. package/dist/application/models/variantInfo/index.d.ts +0 -2
  679. package/dist/application/models/variantInfo/index.js +0 -3
  680. package/dist/atoms/search/types.cjs +0 -5
  681. package/dist/atoms/search/types.d.cts +0 -2
  682. package/dist/atoms/search/types.d.ts +0 -2
  683. package/dist/atoms/search/types.js +0 -3
  684. package/dist/cdnContext-BlRI74F-.cjs +0 -53
  685. package/dist/cdnContext-D26C8Y4H.js +0 -38
  686. package/dist/chat-2NGrmU_Z.cjs +0 -393
  687. package/dist/chat-Bg3wEfNd.js +0 -257
  688. package/dist/chatElementDisplayLocation-D6oLuQS4.d.ts +0 -25
  689. package/dist/chatElementDisplayLocation-DWmfNX_u.d.cts +0 -25
  690. package/dist/chatSearch-B4dsxGth.cjs +0 -418
  691. package/dist/chatSearch-Cvc_eBFV.js +0 -295
  692. package/dist/chatState-2bMtvPgG.js +0 -34
  693. package/dist/chatState-fP1r34CN.cjs +0 -120
  694. package/dist/contexts/chatContext/index.cjs +0 -326
  695. package/dist/contexts/chatContext/index.d.cts +0 -15
  696. package/dist/contexts/chatContext/index.d.ts +0 -15
  697. package/dist/contexts/chatContext/index.js +0 -319
  698. package/dist/contexts/types.cjs +0 -7
  699. package/dist/contexts/types.d.cts +0 -4
  700. package/dist/contexts/types.d.ts +0 -4
  701. package/dist/contexts/types.js +0 -3
  702. package/dist/enviveConfig-BSfyz_pm.js +0 -62
  703. package/dist/enviveConfig-D8vcVPWD.cjs +0 -130
  704. package/dist/enviveConfigContext-C8cCcdKU.cjs +0 -60
  705. package/dist/enviveConfigContext-CJqpRSKu.js +0 -45
  706. package/dist/events-BHJJjPDN.js +0 -78
  707. package/dist/events-B_fJZf9E.cjs +0 -90
  708. package/dist/featureFlagServiceContext-C2Yj-Uyh.d.ts +0 -23
  709. package/dist/featureFlagServiceContext-CiKWV306.d.cts +0 -23
  710. package/dist/featureFlagServiceContext-DFb-uLHN.cjs +0 -62
  711. package/dist/featureFlagServiceContext-Dd_Hbq6e.js +0 -42
  712. package/dist/featureGates-BdvOVv8N.cjs +0 -32
  713. package/dist/featureGates-DhoJq4io.js +0 -26
  714. package/dist/frontendConfig-CbyjUXZW.d.ts +0 -856
  715. package/dist/frontendConfig-tVg0hsWZ.d.cts +0 -856
  716. package/dist/graphql-B9HhDXYt.cjs +0 -53
  717. package/dist/graphql-W7GMIHUu.js +0 -36
  718. package/dist/graphqlConfig-DZHeFKDY.cjs +0 -73
  719. package/dist/graphqlConfig-Xk--JbPl.js +0 -24
  720. package/dist/graphqlContext-BotK7KCg.d.ts +0 -28
  721. package/dist/graphqlContext-CMav2igl.d.cts +0 -28
  722. package/dist/graphqlContext-CSVwhCnP.js +0 -96
  723. package/dist/graphqlContext-aaOOb79d.cjs +0 -111
  724. package/dist/index-7VOYQNo5.d.ts +0 -184
  725. package/dist/index-Bmub8e38.d.cts +0 -98
  726. package/dist/index-CESxqFso.d.cts +0 -228
  727. package/dist/index-CG3P8xE1.d.cts +0 -676
  728. package/dist/index-CalyvQj_.d.ts +0 -1
  729. package/dist/index-CiWEYzXl.d.cts +0 -184
  730. package/dist/index-Cyq5HiC0.d.cts +0 -44
  731. package/dist/index-D9SzePCE.d.cts +0 -186
  732. package/dist/index-DDZmV951.d.ts +0 -186
  733. package/dist/index-L7SEpDLz.d.ts +0 -228
  734. package/dist/index-RcVcRKH7.d.cts +0 -1
  735. package/dist/index-YrhxAGtH.d.ts +0 -676
  736. package/dist/index-exSzn3SP.d.ts +0 -44
  737. package/dist/index-hebsV7fc.d.ts +0 -98
  738. package/dist/interceptors/types.cjs +0 -1
  739. package/dist/interceptors/types.d.cts +0 -13
  740. package/dist/interceptors/types.d.ts +0 -13
  741. package/dist/interceptors/types.js +0 -3
  742. package/dist/localStorageContext-Dwgto93_.js +0 -95
  743. package/dist/localStorageContext-cnMYDllE.cjs +0 -115
  744. package/dist/models-B1P-dSCW.cjs +0 -1537
  745. package/dist/models-CgvSM2fW.js +0 -1296
  746. package/dist/newOrgConfigAtom-CMeY5c6t.js +0 -8
  747. package/dist/newOrgConfigContext-1uwWWCPa.js +0 -53
  748. package/dist/newOrgConfigContext-B0v1q3dk.cjs +0 -68
  749. package/dist/newOrgConfigContext-C8wBmK3q.d.cts +0 -16
  750. package/dist/newOrgConfigContext-D180PO0t.d.ts +0 -16
  751. package/dist/nodeSelector-B3bPtEjX.d.cts +0 -31
  752. package/dist/nodeSelector-DQicm08Y.d.ts +0 -31
  753. package/dist/org-DU3Wck0R.cjs +0 -43
  754. package/dist/org-DptftvB6.js +0 -12
  755. package/dist/search-BtYKpiNB.js +0 -126
  756. package/dist/search-DYVQuYti.d.ts +0 -20
  757. package/dist/search-Du6HZpO6.cjs +0 -205
  758. package/dist/search-filter-types-B5xcaEit.d.ts +0 -102
  759. package/dist/search-filter-types-DZPTzUK9.d.cts +0 -102
  760. package/dist/search-y-ioX5Mz.d.cts +0 -20
  761. package/dist/searchContext-BK43ArCs.cjs +0 -145
  762. package/dist/searchContext-JjZZhDCe.js +0 -129
  763. package/dist/searchServiceAdapter-BSPZOg1r.js +0 -16
  764. package/dist/searchServiceAdapter-DrjFCiw8.cjs +0 -34
  765. package/dist/sessionStorageContext-BQY9r8zz.js +0 -52
  766. package/dist/sessionStorageContext-R2yUAkd9.cjs +0 -66
  767. package/dist/shopifyUrlContext-Bon8_SUJ.js +0 -61
  768. package/dist/shopifyUrlContext-DUdw1xUH.cjs +0 -75
  769. package/dist/spiffyWidgets-BuS00VaQ.d.cts +0 -20
  770. package/dist/spiffyWidgets-DZqG5plz.d.ts +0 -20
  771. package/dist/systemSettingsContext-BjbhIz6y.js +0 -39
  772. package/dist/systemSettingsContext-Dv9EmjmZ.cjs +0 -60
  773. package/dist/test-types-Dl5puRHC.d.ts +0 -40
  774. package/dist/test-types-ThQiO_cc.d.cts +0 -40
  775. package/dist/types-BwNrLPSZ.cjs +0 -106
  776. package/dist/types-CKMMb_gX.d.cts +0 -51
  777. package/dist/types-Csgpt7EV.d.ts +0 -51
  778. package/dist/types-D3uOF0Oy.js +0 -76
  779. package/dist/types-DIk0FLwd.js +0 -30
  780. package/dist/types-DNLkuGWZ.cjs +0 -48
  781. package/dist/types-DSW9XODe.d.cts +0 -10
  782. package/dist/types-DtTnp0o0.js +0 -1
  783. package/dist/types-a8gm_IaQ.cjs +0 -0
  784. package/dist/types-oSg-AkO5.d.ts +0 -10
  785. package/dist/types.cjs +0 -0
  786. package/dist/types.d.cts +0 -15
  787. package/dist/types.d.ts +0 -15
  788. package/dist/types.js +0 -1
  789. package/dist/urlsParser-BV5yF8sa.cjs +0 -78
  790. package/dist/urlsParser-DUgV_Qy9.js +0 -42
  791. package/dist/useAmplitudeOperations-C9o_wDU6.cjs +0 -41
  792. package/dist/useAmplitudeOperations-COq3L1no.js +0 -34
  793. package/dist/useAppDetails-C4GTLEIR.cjs +0 -38
  794. package/dist/useAppDetails-CEksA88Q.js +0 -30
  795. package/dist/useDebounce--rPGMuE7.js +0 -19
  796. package/dist/useDebounce-DECHWSTn.cjs +0 -26
  797. package/dist/useGraphQLConfig-DQoMmpNM.js +0 -63
  798. package/dist/useGraphQLConfig-DzH1nVBh.cjs +0 -76
  799. package/dist/useMessageInterceptor-CstX10ih.cjs +0 -33
  800. package/dist/useMessageInterceptor-D5oAekXn.js +0 -25
  801. package/dist/userIdentityContext-8kfKQRFx.d.ts +0 -20
  802. package/dist/userIdentityContext-D2oFVFzo.d.cts +0 -20
  803. package/dist/utilityTypes-DynzxjK3.js +0 -1
  804. package/dist/utilityTypes-xb8SjKSV.cjs +0 -0
  805. package/dist/utils-B8rATLoc.d.ts +0 -22
  806. package/dist/utils-Bcz5kAgP.js +0 -92
  807. package/dist/utils-CMqFfqZx.cjs +0 -130
  808. package/dist/utils-EDgzCG3Q.d.cts +0 -22
  809. package/dist/utils-V1YTUQng.js +0 -1385
  810. package/dist/utils-VI19AC8S.cjs +0 -1591
  811. package/dist/variantInfo-BRmDpamJ.cjs +0 -17
  812. package/dist/variantInfo-BwBBEWSA.js +0 -11
  813. package/src/application/models/api/context.ts +0 -4
  814. package/src/application/models/api/generationParams.ts +0 -4
  815. package/src/application/models/api/nextMessageRequest.ts +0 -11
  816. package/src/application/models/api/orgAnalyticsConfig.ts +0 -19
  817. package/src/application/models/api/orgConfigResults.ts +0 -44
  818. package/src/application/models/api/organizationConfig.ts +0 -12
  819. package/src/application/models/api/responseGenerics.ts +0 -67
  820. package/src/application/models/api/search.ts +0 -26
  821. package/src/application/models/api/suggestion.ts +0 -4
  822. package/src/application/models/api/supportedEventRequest.ts +0 -8
  823. package/src/application/models/api/userEvent.ts +0 -101
  824. package/src/application/models/cachedValue.ts +0 -8
  825. package/src/application/models/chatElementDisplayLocation.ts +0 -22
  826. package/src/application/models/clientDetails.ts +0 -18
  827. package/src/application/models/colorsConfig.ts +0 -28
  828. package/src/application/models/conversationalSearchIds.ts +0 -5
  829. package/src/application/models/dataLayer.ts +0 -45
  830. package/src/application/models/events.ts +0 -5
  831. package/src/application/models/featureGates.ts +0 -21
  832. package/src/application/models/frontendConfig.ts +0 -14
  833. package/src/application/models/googleAnalyticsEvents.ts +0 -8
  834. package/src/application/models/localStorageEventListener.ts +0 -4
  835. package/src/application/models/mobilePLPChatPlacementParameter.ts +0 -3
  836. package/src/application/models/orgsEnum.ts +0 -36
  837. package/src/application/models/productExperiment.ts +0 -5
  838. package/src/application/models/spanxTakeAQuizCtaParameter.ts +0 -4
  839. package/src/application/models/spiffyWidgets.ts +0 -16
  840. package/src/application/models/utilityTypes/camelCase.ts +0 -87
  841. package/src/application/models/utilityTypes/camelCasedPropertiesDeep.ts +0 -80
  842. package/src/application/models/utilityTypes/delimiterCase.ts +0 -121
  843. package/src/application/models/utilityTypes/delimiterCasedPropertiesDeep.ts +0 -98
  844. package/src/application/models/utilityTypes/index.ts +0 -1
  845. package/src/application/models/utilityTypes/internal.ts +0 -93
  846. package/src/application/models/utilityTypes/primitive.ts +0 -8
  847. package/src/application/models/utilityTypes/snakeCasedPropertiesDeep.ts +0 -49
  848. package/src/application/models/utilityTypes/splitWords.ts +0 -76
  849. package/src/application/models/utilityTypes/trim.ts +0 -28
  850. package/src/application/models/utilityTypes/unknownArray.ts +0 -25
  851. package/src/application/models/variantInfo/index.ts +0 -1
  852. package/src/application/models/variantInfo/pageVisitInfo.ts +0 -6
  853. package/src/application/models/variantInfo/plpInfo.ts +0 -3
  854. package/src/application/models/variantInfo/productInfo.ts +0 -5
  855. package/src/application/models/variantInfo/variantInfo.ts +0 -29
  856. package/src/application/utils/__tests__/divideArrays.test.ts +0 -14
  857. package/src/application/utils/cdnUtils.ts +0 -11
  858. package/src/atoms/search/chatSearch.ts +0 -317
  859. package/src/atoms/search/types.ts +0 -55
  860. package/src/config/divIds.ts +0 -27
  861. package/src/config/socialProofClasses.ts +0 -17
  862. package/src/contexts/chatContext/chatContext.tsx +0 -509
  863. package/src/contexts/chatContext/index.ts +0 -1
  864. package/src/contexts/types.ts +0 -1066
  865. package/src/events/event-types.ts +0 -11
  866. package/src/interceptors/types.ts +0 -6
  867. package/src/merchants/domInsertion.ts +0 -30
  868. package/src/merchants/gridInsertion.ts +0 -19
  869. package/src/types/config-versions.ts +0 -6
  870. package/src/types/customerService.ts +0 -31
  871. package/src/types/custservice-types.ts +0 -28
  872. package/src/types/search-filter-types.ts +0 -111
  873. package/src/types/suggestionBarV2-types.ts +0 -4
  874. package/src/types/test-types.ts +0 -3
  875. package/src/types.ts +0 -11
  876. /package/dist/{AmplitudeOperations-CEwp7tPJ.cjs → featureFlagServiceContext-B4ash4vz.cjs} +0 -0
  877. /package/dist/{AmplitudeOperations-uF2zIi_1.js → featureFlagServiceContext-bI7ZLz4r.js} +0 -0
  878. /package/src/{types/exceptions → exceptions}/sessionExceptions.ts +0 -0
@@ -0,0 +1,1364 @@
1
+ import { EventsDispatcher } from "./events-WOOrnUAx.js";
2
+ import { FeatureGates, LocalStorageKeys, MessageRole as MessageRole$1, MessageType as MessageType$1, OrgShortName, ProductExperiment, SpiffyEvent, VariantTypeEnum } from "./dist-CIM4YRqp.js";
3
+ import { SessionRestartRequired, UnsupportedProductException } from "./exceptions-DSv0ZaH0.js";
4
+ import { isBaseEcommerceEvent, isGA4EcommerceEvent, isLegacyUAEcommerceEvent, validateOrgConfigResults, validateResponse, validateSuggestion, validateUserEvent } from "./models-DEJUuKYQ.js";
5
+ import { logger_default } from "./logger-DCs3_11o.js";
6
+ import { amplitudeApiKeyAtom, baseUrlAtom, contextSourceAtom, dataResidencyAtom, envAtom, identifyingPrefixAtom, orgShortNameAtom, reactAppNameAtom } from "./enviveConfig-DrvYlCYG.js";
7
+ import { useLocalStorage } from "./localStorageContext-DSpmlfyr.js";
8
+ import { featureFlagServiceAtom, orgAnalyticsGoogleAnalyticsConfigAtom, orgIdAtom } from "./org-Ct9Vjv1J.js";
9
+ import { getAtomStore, sessionStorageUtil } from "./atomStore-DAQvNPkh.js";
10
+ import { useEnviveConfig } from "./enviveConfigContext-BCnzgk4M.js";
11
+ import { useFeatureFlagService } from "./featureFlagServiceContext-DpdlcjNb.js";
12
+ import { MessageRole, MessageType } from "./types-DQC1pHqD.js";
13
+ import { Configuration, ContextEnvEnum, ContextSourceEnum, CustomerServiceApi, DefaultApi, FormType, InferenceApi, PLPAttributeCategory, ResponseCategory, ResponseError, UserEventCategory, V1OrgConfigGetSourceEnum } from "@spiffy-ai/commerce-api-client";
14
+ import React, { createContext, useCallback, useContext, useEffect, useMemo, useState } from "react";
15
+ import { v4 } from "uuid";
16
+ import { atom, useAtomValue } from "jotai";
17
+ import { createInstance } from "@amplitude/analytics-browser";
18
+ import { jsx } from "react/jsx-runtime";
19
+ import { atomWithStorage } from "jotai/utils";
20
+ import UAParser from "ua-parser-js";
21
+
22
+ //#region src/application/commerce-api.ts
23
+ async function errorResponseBody(error) {
24
+ try {
25
+ return await error.response.json();
26
+ } catch {
27
+ return {};
28
+ }
29
+ }
30
+ async function throwSessionRestartRequiredIf(errorMsg, error) {
31
+ if (!(error instanceof ResponseError)) {
32
+ logger_default.logInfo(errorMsg, error);
33
+ throw error;
34
+ }
35
+ const errorResponse = await errorResponseBody(error);
36
+ if (errorResponse?.message?.toLowerCase() === "unsupported product" || errorResponse?.app_code?.toUpperCase() === "PRODUCT_NOT_FOUND") throw new UnsupportedProductException();
37
+ else if (errorResponse?.app_code?.toUpperCase() === "RESTART_SESSION" || errorResponse?.sub_code?.toUpperCase() === "NOT_FOUND") {
38
+ logger_default.logInfo("Session does not exist. Re-start session", error, error.response, errorResponse);
39
+ throw new SessionRestartRequired();
40
+ }
41
+ logger_default.logInfo(errorMsg, error);
42
+ throw error;
43
+ }
44
+ var CommerceApiClient = class CommerceApiClient {
45
+ static {
46
+ this.getInstance = () => {
47
+ if (!CommerceApiClient.instance) CommerceApiClient.instance = new CommerceApiClient();
48
+ return CommerceApiClient.instance;
49
+ };
50
+ }
51
+ constructor(basePath) {
52
+ this.suggestionsAbortController = new AbortController();
53
+ this.responsesAbortController = new AbortController();
54
+ const baseUrl = getAtomStore().get(baseUrlAtom);
55
+ const config = new Configuration({
56
+ basePath: basePath || baseUrl,
57
+ headers: {
58
+ "Content-Type": "application/json",
59
+ Accept: "application/json"
60
+ }
61
+ });
62
+ this.defaultApi = new DefaultApi(config);
63
+ this.inferenceApi = new InferenceApi(config);
64
+ this.customerServiceApi = new CustomerServiceApi(config);
65
+ }
66
+ static {
67
+ this.resolveUrl = async (url) => {
68
+ const atomStore = getAtomStore();
69
+ const orgShortName = atomStore.get(orgShortNameAtom);
70
+ const orgId = atomStore.get(orgIdAtom);
71
+ const userId = atomStore.get(userIdAtom);
72
+ const chatId = atomStore.get(chatIdAtom);
73
+ const source = atomStore.get(contextSourceAtom);
74
+ const env = atomStore.get(envAtom);
75
+ const featureFlagService = atomStore.get(featureFlagServiceAtom);
76
+ const context = {
77
+ user_id: userId ?? "",
78
+ org_id: orgId ?? "",
79
+ org_short_name: orgShortName ?? "",
80
+ chat_id: chatId ?? "",
81
+ source: source ?? ContextSourceEnum.App,
82
+ env: env ?? ContextEnvEnum.Dev
83
+ };
84
+ const featureGates = featureFlagService?.featureFlagService?.getFeatureFlags() || {};
85
+ const urlResolvingRequest = {
86
+ url,
87
+ context,
88
+ feature_gates: featureGates
89
+ };
90
+ return await (await CommerceApiClient.getInstance().inferenceApi.v1UrlResolvingPostRaw({ UrlResolvingRequest: urlResolvingRequest })).raw.json();
91
+ };
92
+ }
93
+ static {
94
+ this.reportSession = async (reportRequest) => {
95
+ await CommerceApiClient.getInstance().defaultApi.v1ChatsReportSessionIdPost({ ReportSessionRequest: reportRequest });
96
+ };
97
+ }
98
+ static {
99
+ this.getNextResponses = async (payload) => {
100
+ try {
101
+ return (await CommerceApiClient.getInstance().inferenceApi.v1NextResponsesPost({ NextMessageRequest: messageRequestToCommerceMessageRequest(payload) })).map((resp) => validateResponse(resp)).map((resp) => messageFromResponse(resp)).filter((m) => m != null);
102
+ } catch (err) {
103
+ logger_default.logInfo("Failed to get next responses", err, {
104
+ payloadContext: payload?.context,
105
+ userEvents: payload?.userEvents
106
+ });
107
+ await throwSessionRestartRequiredIf("Failed to get next responses", err);
108
+ return [];
109
+ }
110
+ };
111
+ }
112
+ static {
113
+ this.getNextResponseStreaming = (payload) => {
114
+ async function* generate(inferenceApi, abortController) {
115
+ try {
116
+ const response = await inferenceApi.v1NextResponsesPostRaw({ NextMessageRequest: messageRequestToCommerceMessageRequest(payload) }, { signal: abortController.signal });
117
+ if (!response.raw.body) {
118
+ logger_default.logError("[spiffy-ai] No body in the streamed response", void 0, { response: response.raw });
119
+ return;
120
+ }
121
+ const reader = response.raw.body.getReader();
122
+ const decoder = new TextDecoder("utf-8");
123
+ let partial = "";
124
+ const safeParse = (line) => {
125
+ try {
126
+ return JSON.parse(line);
127
+ } catch (err) {
128
+ logger_default.logError("[spiffy-ai] Error parsing streamed line", err, {
129
+ line,
130
+ partial
131
+ });
132
+ partial = line;
133
+ return partial;
134
+ }
135
+ };
136
+ const processChunk = (chunk) => {
137
+ return `${partial}${chunk}`.split("\n").map((line) => line.replace(/^data: /, "").trim()).filter((line) => line !== "" && line !== "[DONE]").map(safeParse).filter((v) => v);
138
+ };
139
+ while (true) {
140
+ const { done, value } = await reader.read();
141
+ if (done) break;
142
+ const chunk = decoder.decode(value);
143
+ const parsedLines = processChunk(chunk);
144
+ for (const parsedLine of parsedLines) {
145
+ const validatedResponse = validateResponse(parsedLine);
146
+ if (validatedResponse) yield validatedResponse;
147
+ }
148
+ }
149
+ } catch (error) {
150
+ logger_default.logError("[spiffy-ai] Failed to get next streaming responses", error, {
151
+ payloadContext: payload?.context,
152
+ userEvents: payload?.userEvents
153
+ });
154
+ await throwSessionRestartRequiredIf("Failed to get next streaming responses", error);
155
+ }
156
+ }
157
+ CommerceApiClient.getInstance().responsesAbortController.abort();
158
+ CommerceApiClient.getInstance().responsesAbortController = new AbortController();
159
+ return generate(CommerceApiClient.getInstance().inferenceApi, CommerceApiClient.getInstance().responsesAbortController);
160
+ };
161
+ }
162
+ static {
163
+ this.getNextSuggestions = async (payload) => {
164
+ try {
165
+ CommerceApiClient.getInstance().suggestionsAbortController.abort();
166
+ CommerceApiClient.getInstance().suggestionsAbortController = new AbortController();
167
+ return (await CommerceApiClient.getInstance().inferenceApi.v1NextSuggestionsPost({ NextMessageRequest: messageRequestToCommerceMessageRequest(payload) }, { signal: CommerceApiClient.getInstance().suggestionsAbortController.signal })).map((resp) => validateSuggestion(resp)).filter((suggestion) => suggestion != null);
168
+ } catch (error) {
169
+ logger_default.logInfo("Failed to get suggestions", error, {
170
+ payloadContext: payload?.context,
171
+ userEvents: payload?.userEvents
172
+ });
173
+ await throwSessionRestartRequiredIf("Failed to get suggestions", error);
174
+ return [];
175
+ }
176
+ };
177
+ }
178
+ static {
179
+ this.getResponses = async (orgId, chatId, userId) => {
180
+ let data = {
181
+ responses: [],
182
+ suggestions: [],
183
+ user_events: []
184
+ };
185
+ const request = {
186
+ org_id: orgId,
187
+ chat_id: chatId,
188
+ user_id: userId
189
+ };
190
+ try {
191
+ data = await CommerceApiClient.getInstance().defaultApi.v1GetSessionMessages(request);
192
+ } catch (error) {
193
+ await throwSessionRestartRequiredIf("Failed to get chat responses", error);
194
+ }
195
+ const responses = data?.responses?.map((turn) => turn.map((response) => validateResponse(response)).filter((response) => response != null));
196
+ const suggestions = data?.suggestions.map((suggestion) => validateSuggestion(suggestion)).filter((suggestion) => suggestion != null);
197
+ const userEvents = data?.user_events.map((event) => validateUserEvent(event)).filter((event) => event != null);
198
+ const formSubmittedUserEventsFormIds = userEvents.filter((event) => event.category === UserEventCategory.FormSubmitted).map((event) => event.attributes.formResponseId);
199
+ const assistantMessages = responses.map((turn) => turn.filter((response) => !(response.category === ResponseCategory.Form && formSubmittedUserEventsFormIds.includes(response.id))).map((response) => messageFromResponse(response)).filter((message) => message != null)).filter((turn) => turn.length > 0);
200
+ const userMessages = userEvents.map((event) => {
201
+ if ([UserEventCategory.QueryTyped, UserEventCategory.Search].includes(event.category)) return [messageFromQueryEvent(event)];
202
+ if (event.category === UserEventCategory.SuggestionClicked) return [messageFromSuggestionEvent(event, suggestions)];
203
+ if (event.category === UserEventCategory.FormSubmitted) {
204
+ const formResponse = responses.flat().find((response) => response.id === event.attributes.formResponseId && event.attributes.formType !== FormType.Escalation);
205
+ if (formResponse && formResponse.category === ResponseCategory.Form) return [messageFromFormSubmittedEvent(event, formResponse.attributes)];
206
+ }
207
+ return [];
208
+ }).filter((message) => message.length > 0);
209
+ const sortedMessages = [...assistantMessages, ...userMessages].sort((a, b) => new Date(a[0].createdAt).getTime() - new Date(b[0].createdAt).getTime());
210
+ return {
211
+ responses,
212
+ userEvents,
213
+ suggestions,
214
+ messages: sortedMessages
215
+ };
216
+ };
217
+ }
218
+ static {
219
+ this.isSupportedEvent = async (payload) => {
220
+ try {
221
+ const httpResponseText = await (await CommerceApiClient.getInstance().inferenceApi.v1SupportedEventPostRaw({ SupportedEventRequest: coreSupportedEventRequestToApiRequest(payload) })).raw.text();
222
+ const httpResponseJson = JSON.parse(httpResponseText);
223
+ return {
224
+ ...httpResponseJson,
225
+ numberOfReviews: httpResponseJson.num_of_reviews,
226
+ merchant_tags: httpResponseJson.merchant_tags || []
227
+ };
228
+ } catch (err) {
229
+ logger_default.logError("Failed to get response for v1SupportedEventPost", { err });
230
+ return {
231
+ supported: false,
232
+ ready: false,
233
+ category: void 0,
234
+ collections: [],
235
+ numberOfReviews: void 0,
236
+ top_category: void 0,
237
+ merchant_tags: []
238
+ };
239
+ }
240
+ };
241
+ }
242
+ static {
243
+ this.identifyUser = async (spiffyUserId, merchantUserId, uaDetails) => {
244
+ try {
245
+ await CommerceApiClient.getInstance().defaultApi.v1AnalyticsIdentifyPost({ AnalyticsIdentifyRequest: {
246
+ user_id: spiffyUserId,
247
+ os_name: uaDetails.os,
248
+ os_version: uaDetails.osVersion,
249
+ platform: uaDetails.os,
250
+ device_id: uaDetails.deviceModel,
251
+ device_brand: uaDetails.deviceBrand,
252
+ device_manufacturer: uaDetails.deviceManufacturer,
253
+ device_model: uaDetails.deviceModel,
254
+ user_properties: {
255
+ cdp_user_id: merchantUserId,
256
+ browser: uaDetails.browser,
257
+ browser_version: uaDetails.browserVersion,
258
+ user_agent: uaDetails.userAgent
259
+ }
260
+ } });
261
+ } catch (err) {
262
+ logger_default.logError("Failed to identify user", err);
263
+ }
264
+ };
265
+ }
266
+ static {
267
+ this.mapContextSourceToV1OrgConfigGetSource = (source) => {
268
+ if (source === void 0) return void 0;
269
+ switch (source) {
270
+ case ContextSourceEnum.Fork: return V1OrgConfigGetSourceEnum.Fork;
271
+ case ContextSourceEnum.Playground: return V1OrgConfigGetSourceEnum.Playground;
272
+ case ContextSourceEnum.App: return V1OrgConfigGetSourceEnum.App;
273
+ case ContextSourceEnum.Test: return V1OrgConfigGetSourceEnum.Test;
274
+ default: return source;
275
+ }
276
+ };
277
+ }
278
+ static {
279
+ this.getOrgConfig = async (user_id) => {
280
+ try {
281
+ const atomStore = getAtomStore();
282
+ const reactAppName = atomStore.get(reactAppNameAtom);
283
+ const contextSource = atomStore.get(contextSourceAtom);
284
+ const featureFlagService = atomStore.get(featureFlagServiceAtom);
285
+ const request = {
286
+ namespace: reactAppName,
287
+ user_id,
288
+ source: this.mapContextSourceToV1OrgConfigGetSource(contextSource),
289
+ include_experiments: Object.values(ProductExperiment),
290
+ include_feature_gates: Object.entries(featureFlagService?.featureFlagService?.getFeatureFlags() || {}).filter(([, isEnabled]) => isEnabled).map(([featureGateName]) => featureGateName)
291
+ };
292
+ const response = await CommerceApiClient.getInstance().defaultApi.v1OrgConfigGet(request);
293
+ return validateOrgConfigResults(response);
294
+ } catch (err) {
295
+ logger_default.logError(`Failed to get org config`, err, { err });
296
+ return;
297
+ }
298
+ };
299
+ }
300
+ static {
301
+ this.addNoteToLatestConversation = async (spiffyUserId, email, customerServiceProvider) => {
302
+ logger_default.logInfo(`addNoteToLatestConversation - user_id=${spiffyUserId} email=${email} customer_service_provider=${customerServiceProvider}`);
303
+ try {
304
+ await CommerceApiClient.getInstance().customerServiceApi.v1CustserviceAddNoteToLatestConversationPost({ AddNoteToLatestConversationRequest: {
305
+ spiffy_user_id: spiffyUserId,
306
+ email,
307
+ customer_service_provider: customerServiceProvider
308
+ } });
309
+ } catch (err) {
310
+ logger_default.logError("Failed to add note to latest conversation", { err });
311
+ }
312
+ };
313
+ }
314
+ static {
315
+ this.getCustomerServiceApi = () => CommerceApiClient.getInstance().customerServiceApi;
316
+ }
317
+ };
318
+ var commerce_api_default = CommerceApiClient;
319
+
320
+ //#endregion
321
+ //#region src/contexts/userIdentityContext/userIdentityContext.tsx
322
+ const getUserAgentDetails = () => {
323
+ const result = new UAParser().getResult();
324
+ return {
325
+ os: result?.os?.name,
326
+ osVersion: result?.os?.version,
327
+ deviceBrand: result?.device?.vendor,
328
+ deviceManufacturer: result?.device?.vendor,
329
+ deviceModel: result?.device?.model,
330
+ browser: result?.browser?.name,
331
+ browserVersion: result?.browser?.version,
332
+ userAgent: result?.ua
333
+ };
334
+ };
335
+ const UserIdentityContext = createContext(void 0);
336
+ const UserIdentityProvider = ({ children }) => {
337
+ const { getItem, setItem, isAvailable: localStorageIsReady } = useLocalStorage();
338
+ const [isReady, setIsReady] = useState(false);
339
+ useEffect(() => {
340
+ setIsReady(localStorageIsReady);
341
+ }, [localStorageIsReady]);
342
+ const USER_ID_OVERRIDE_KEY = "v1-spiffy-user-id-override";
343
+ const USER_ID_DEFAULT_KEY = "v1-spiffy-user-id-default";
344
+ const getUserIdOverrideFromLocalStorage = useCallback(() => getItem(USER_ID_OVERRIDE_KEY) ?? void 0, [getItem]);
345
+ const getUserIdDefaultFromLocalStorage = useCallback(() => getItem(USER_ID_DEFAULT_KEY) ?? void 0, [getItem]);
346
+ const setUserIdDefaultInLocalStorage = useCallback((userId) => {
347
+ logger_default.logInfo(`setUserIdDefaultInLocalStorage - Setting user_id=${userId}`);
348
+ setItem(USER_ID_DEFAULT_KEY, userId);
349
+ return userId;
350
+ }, [setItem, USER_ID_DEFAULT_KEY]);
351
+ const setUserIdOverrideInLocalStorage = useCallback((userId) => {
352
+ logger_default.logInfo(`setUserIdOverrideInLocalStorage - Setting user_id=${userId}`);
353
+ setItem(USER_ID_OVERRIDE_KEY, userId);
354
+ return userId;
355
+ }, [setItem, USER_ID_OVERRIDE_KEY]);
356
+ const clearUserIdOverrideInLocalStorage = useCallback(() => {
357
+ logger_default.logInfo(`clearUserIdOverrideInLocalStorage - Clearing user_id`);
358
+ setItem(USER_ID_OVERRIDE_KEY, "");
359
+ }, [setItem, USER_ID_OVERRIDE_KEY]);
360
+ const getUserIdOrDefault = useCallback(() => {
361
+ const userIdOverride = getUserIdOverrideFromLocalStorage();
362
+ if (userIdOverride) return userIdOverride;
363
+ const defaultUserId = getUserIdDefaultFromLocalStorage();
364
+ if (defaultUserId) return defaultUserId;
365
+ return setUserIdDefaultInLocalStorage(`spiffy-user-id-${v4()}`);
366
+ }, [
367
+ getUserIdOverrideFromLocalStorage,
368
+ getUserIdDefaultFromLocalStorage,
369
+ setUserIdDefaultInLocalStorage
370
+ ]);
371
+ const identifyUser = useCallback(async () => {
372
+ if (!isReady) {
373
+ logger_default.logWarn("[UserIdentityContext] Context not ready, skipping identifyUser", void 0);
374
+ return;
375
+ }
376
+ try {
377
+ const cdpUserId = "UNKNOWN_CDP_USER_ID";
378
+ const userId = getUserIdOrDefault();
379
+ const userAgentDetails = getUserAgentDetails();
380
+ await commerce_api_default.identifyUser(userId, cdpUserId, userAgentDetails);
381
+ } catch (error) {
382
+ logger_default.logError("[spiffy-ai] Error identifying user", error);
383
+ }
384
+ }, [isReady, getUserIdOrDefault]);
385
+ const value = useMemo(() => ({
386
+ identifyUser,
387
+ getUserIdOrDefault,
388
+ getUserIdOverrideFromLocalStorage,
389
+ getUserIdDefaultFromLocalStorage,
390
+ setUserIdDefaultInLocalStorage,
391
+ setUserIdOverrideInLocalStorage,
392
+ clearUserIdOverrideInLocalStorage,
393
+ isReady
394
+ }), [
395
+ identifyUser,
396
+ getUserIdOrDefault,
397
+ getUserIdOverrideFromLocalStorage,
398
+ getUserIdDefaultFromLocalStorage,
399
+ setUserIdDefaultInLocalStorage,
400
+ setUserIdOverrideInLocalStorage,
401
+ clearUserIdOverrideInLocalStorage,
402
+ isReady
403
+ ]);
404
+ return /* @__PURE__ */ jsx(UserIdentityContext.Provider, {
405
+ value,
406
+ children
407
+ });
408
+ };
409
+ const useUserIdentity = () => {
410
+ const context = useContext(UserIdentityContext);
411
+ if (!context) throw new Error("useUserIdentity must be used within a UserIdentityProvider");
412
+ return context;
413
+ };
414
+
415
+ //#endregion
416
+ //#region src/atoms/app/variant.ts
417
+ const internalStorageUrlResolverAtom = atomWithStorage("spiffy-url-resolver", void 0, sessionStorageUtil, { getOnInit: true });
418
+ const urlResolverAtom = atom((get) => {
419
+ const maybeUrlResolver = get(internalStorageUrlResolverAtom);
420
+ if (maybeUrlResolver == null) return {};
421
+ return JSON.parse(maybeUrlResolver);
422
+ }, (get, set, value) => {
423
+ const newCache = {
424
+ ...get(urlResolverAtom),
425
+ [value.url]: value.response
426
+ };
427
+ set(internalStorageUrlResolverAtom, JSON.stringify(newCache));
428
+ });
429
+ const internalStorageSupportedEventAtom = atomWithStorage("spiffy-supported-event", void 0, sessionStorageUtil, { getOnInit: true });
430
+ const internalSupportedEventAtom = atom(void 0);
431
+ const supportedEventAtom = atom((get) => {
432
+ const maybeSupportedEvent = get(internalStorageSupportedEventAtom);
433
+ if (maybeSupportedEvent == null) return;
434
+ return JSON.parse(maybeSupportedEvent);
435
+ }, (_, set, value) => {
436
+ if (value == null) {
437
+ set(internalStorageSupportedEventAtom, void 0);
438
+ set(internalSupportedEventAtom, void 0);
439
+ return;
440
+ }
441
+ set(internalSupportedEventAtom, value);
442
+ set(internalStorageSupportedEventAtom, JSON.stringify(value));
443
+ });
444
+ const internalVariantIdAtom = atom();
445
+ const internalProductIdAtom = atom();
446
+ const internalParentProductIdAtom = atom();
447
+ const internalProductUrlAtom = atom();
448
+ const internalPlpIdAtom = atom();
449
+ const internalUrlAtom = atom();
450
+ const internalPageVisitCategoryAtom = atom();
451
+ const internalVariantAtom = atom("pdp");
452
+ const variantIdAtom = atom((get) => get(internalVariantIdAtom));
453
+ const productIdAtom = atom((get) => get(internalProductIdAtom));
454
+ const parentProductIdAtom = atom((get) => get(internalParentProductIdAtom));
455
+ const productUrlAtom = atom((get) => get(internalProductUrlAtom));
456
+ const plpIdAtom = atom((get) => get(internalPlpIdAtom));
457
+ const urlAtom = atom((get) => get(internalUrlAtom));
458
+ const pageVisitCategoryAtom = atom((get) => get(internalPageVisitCategoryAtom));
459
+ const variantAtom = atom((get) => get(internalVariantAtom));
460
+ const hasParsedVariantInfoAtom = atom(false);
461
+ const variantInfoAtom = atom((get) => {
462
+ const variant = get(variantAtom);
463
+ if (variant === VariantTypeEnum.Pdp) return {
464
+ variantId: get(variantIdAtom),
465
+ variant,
466
+ productId: get(productIdAtom),
467
+ parentProductId: get(parentProductIdAtom),
468
+ url: get(urlAtom)
469
+ };
470
+ if (variant === VariantTypeEnum.Plp) return {
471
+ variantId: get(variantIdAtom),
472
+ variant,
473
+ plpId: get(plpIdAtom),
474
+ url: get(urlAtom)
475
+ };
476
+ if (variant === VariantTypeEnum.PageVisit) return {
477
+ variantId: get(variantIdAtom),
478
+ variant,
479
+ url: get(urlAtom),
480
+ pageVisitCategory: get(pageVisitCategoryAtom)
481
+ };
482
+ throw new Error("Invalid variantInfo details");
483
+ }, (_, set, newVariant) => {
484
+ set(internalVariantAtom, newVariant.variant);
485
+ set(internalVariantIdAtom, newVariant.variantId);
486
+ if (newVariant.variant === VariantTypeEnum.Pdp) {
487
+ set(internalProductIdAtom, newVariant.productId);
488
+ set(internalParentProductIdAtom, newVariant.parentProductId);
489
+ set(internalUrlAtom, newVariant.url);
490
+ }
491
+ if (newVariant.variant === VariantTypeEnum.Plp) {
492
+ set(internalPlpIdAtom, newVariant.plpId);
493
+ set(internalUrlAtom, newVariant.url);
494
+ }
495
+ if (newVariant.variant === VariantTypeEnum.PageVisit) {
496
+ set(internalUrlAtom, newVariant.url);
497
+ set(internalPageVisitCategoryAtom, newVariant.pageVisitCategory);
498
+ }
499
+ });
500
+
501
+ //#endregion
502
+ //#region src/atoms/app/index.ts
503
+ const internalUserIdAtom = atom(void 0);
504
+ const userIdAtom = atom((get) => {
505
+ const maybeUserId = get(internalUserIdAtom);
506
+ if (maybeUserId) return maybeUserId;
507
+ const { getUserIdOrDefault } = useUserIdentity();
508
+ return getUserIdOrDefault();
509
+ }, (_, set, value) => {
510
+ set(internalUserIdAtom, value);
511
+ });
512
+ const userIdentityAtom = atom(void 0);
513
+ const appSourceAtom = atom((get) => get(contextSourceAtom) ?? ContextSourceEnum.App);
514
+ const chatIdAtom = atomWithStorage("v1-spiffy-chat-session-id", v4(), void 0, { getOnInit: true });
515
+
516
+ //#endregion
517
+ //#region src/contexts/amplitudeContext/amplitudeContext.tsx
518
+ let SpiffyMetricsEventName = /* @__PURE__ */ function(SpiffyMetricsEventName$1) {
519
+ SpiffyMetricsEventName$1["BundleLoaded"] = "Bundle Loaded";
520
+ SpiffyMetricsEventName$1["ChatLiveAgentBtnClick"] = "Chat Live Agent Btn Click";
521
+ SpiffyMetricsEventName$1["ChatFloatingButtonVisible"] = "Chat Floating Button Visible";
522
+ SpiffyMetricsEventName$1["ChatComponentVisible"] = "Chat Component Visible";
523
+ SpiffyMetricsEventName$1["ChatComponentExpanded"] = "Chat Component Expanded";
524
+ SpiffyMetricsEventName$1["ChatComponentCollapsed"] = "Chat Component Collapsed";
525
+ SpiffyMetricsEventName$1["ChatUserMessageInput"] = "Chat User Message Input";
526
+ SpiffyMetricsEventName$1["ChatSuggestionClicked"] = "Chat Suggestion Clicked";
527
+ SpiffyMetricsEventName$1["ChatAssistantResponse"] = "Chat Assistant Response";
528
+ SpiffyMetricsEventName$1["ProductCardClicked"] = "Product Card Clicked";
529
+ SpiffyMetricsEventName$1["ProductReviewCardClicked"] = "Product Review Card Clicked";
530
+ SpiffyMetricsEventName$1["AddToCartClicked"] = "Add to Cart Clicked";
531
+ SpiffyMetricsEventName$1["PromptCardClicked"] = "Prompt Card Clicked";
532
+ SpiffyMetricsEventName$1["SupportedEvent"] = "Supported Event";
533
+ SpiffyMetricsEventName$1["SearchBackToResponseClicked"] = "Search Back to Response Clicked";
534
+ SpiffyMetricsEventName$1["PerformanceMetrics"] = "Performance Metrics";
535
+ SpiffyMetricsEventName$1["SearchBarClicked"] = "Search Bar Clicked";
536
+ SpiffyMetricsEventName$1["OrderLookupStarted"] = "Order Lookup Started";
537
+ SpiffyMetricsEventName$1["OrderLookupFormSubmitted"] = "Order Lookup Form Submitted";
538
+ SpiffyMetricsEventName$1["SearchComponentVisible"] = "Search Component Visible";
539
+ SpiffyMetricsEventName$1["SearchZeroStateSuggestionClicked"] = "Search Zero State Suggestion Clicked";
540
+ SpiffyMetricsEventName$1["SearchInputStarted"] = "Search Input Started";
541
+ SpiffyMetricsEventName$1["SearchQuerySubmitted"] = "Search Query Submitted";
542
+ SpiffyMetricsEventName$1["SearchResultsViewed"] = "Search Results Viewed";
543
+ SpiffyMetricsEventName$1["SearchTimeToFirstClick"] = "Search Time to First Click";
544
+ SpiffyMetricsEventName$1["SearchZeroResultsRate"] = "Search Zero Results Rate";
545
+ SpiffyMetricsEventName$1["SearchFilterClicked"] = "Search Filter Clicked";
546
+ SpiffyMetricsEventName$1["SearchSortClicked"] = "Search Sort Clicked";
547
+ return SpiffyMetricsEventName$1;
548
+ }({});
549
+ const AmplitudeContext = createContext(null);
550
+ const AmplitudeProvider = ({ children }) => {
551
+ const userId = useAtomValue(userIdAtom);
552
+ const amplitudeApiKey = useAtomValue(amplitudeApiKeyAtom);
553
+ const dataResidency = useAtomValue(dataResidencyAtom);
554
+ const orgGaConfig = useAtomValue(orgAnalyticsGoogleAnalyticsConfigAtom);
555
+ const env = useAtomValue(envAtom);
556
+ const contextSource = useAtomValue(contextSourceAtom);
557
+ useAtomValue(identifyingPrefixAtom);
558
+ const { getItem } = useLocalStorage();
559
+ const { publicKey, featureOverrides, variantUrlOverride, variantInfoOverride, show, orgShortName, featureGates } = useEnviveConfig();
560
+ const { featureFlagService } = useFeatureFlagService();
561
+ const [amplitudeClient, setAmplitudeClient] = React.useState(void 0);
562
+ const [internalEventTrackingEnrichment, setInternalEventTrackingEnrichment] = React.useState(void 0);
563
+ const [supplementalDefaultProps, setSupplementalDefaultProps] = React.useState({});
564
+ const isReady = Boolean(userId && featureFlagService && amplitudeApiKey && userId);
565
+ const getDefaultTrackingProps = useCallback(() => {
566
+ const gatesProps = featureGates ? featureGates.reduce((acc, curr) => {
567
+ if (curr.name && curr.value != null) return {
568
+ ...acc,
569
+ [`feature_gate.${curr.name}`]: curr.value
570
+ };
571
+ return acc;
572
+ }, {}) : {};
573
+ const experimentProps = {};
574
+ return {
575
+ ...gatesProps,
576
+ ...experimentProps,
577
+ ...supplementalDefaultProps,
578
+ app_id: "commerce-chat-react-component",
579
+ chat_id: getItem(LocalStorageKeys.ChatId),
580
+ env: env || "unknown",
581
+ app_source: contextSource,
582
+ "org.short_name": orgShortName,
583
+ "user.id": userId,
584
+ "cdp.user_id": null,
585
+ "cdp.provider": null,
586
+ "event.source": "web-browser",
587
+ "event.type": "user-activity",
588
+ "event.id": null,
589
+ "event.channel": "web",
590
+ "event.timestamp": null
591
+ };
592
+ }, [
593
+ featureGates,
594
+ supplementalDefaultProps,
595
+ env,
596
+ contextSource,
597
+ orgShortName,
598
+ userId
599
+ ]);
600
+ const eventPropsToPrefixedEventProps = useCallback((eventName, eventProps) => {
601
+ const prefix = eventName.toLowerCase().replace(/\s+/g, "_");
602
+ return Object.entries(eventProps).reduce((acc, [key, value$1]) => {
603
+ acc[`${prefix}.${key}`] = value$1;
604
+ return acc;
605
+ }, {});
606
+ }, []);
607
+ const amplitudeSessionReplayInit = useCallback(() => {
608
+ const isEnabled = Boolean(orgShortName === OrgShortName.UniqueVintage && featureFlagService?.isClientSessionEnabled() && featureFlagService?.isFeatureGateEnabled(FeatureGates.IsNewFeatureEnabled));
609
+ const sampleRate = 1;
610
+ try {
611
+ logger_default.logDebug(`[spiffy-ai] amplitude session-replay initializing isEnabled=${isEnabled} sampleRate=${sampleRate}`);
612
+ if (!isEnabled) return isEnabled;
613
+ return isEnabled;
614
+ } catch (e) {
615
+ logger_default.logError("[spiffy-ai] Error initializing amplitude session-replay", e);
616
+ return false;
617
+ }
618
+ }, [orgShortName, featureFlagService]);
619
+ const getEventTrackingEnrichment = useCallback(() => {
620
+ if (internalEventTrackingEnrichment !== void 0) return internalEventTrackingEnrichment;
621
+ const enrichment = {
622
+ name: "page-view-tracking-enrichment",
623
+ type: "enrichment",
624
+ setup: async () => void 0,
625
+ execute: async (event) => {
626
+ let enrichedEvent;
627
+ if (["[Amplitude] Page Viewed", `[Spiffy] ${SpiffyMetricsEventName.BundleLoaded}`].includes(event.event_type)) {
628
+ const globalProperties = {};
629
+ if (publicKey) globalProperties["globalProperties.publicKey"] = publicKey;
630
+ if (featureOverrides) Object.entries(featureOverrides).forEach(([key, value$1]) => {
631
+ globalProperties[`globalProperties.featureOverrides.${key}`] = String(value$1);
632
+ });
633
+ if (variantUrlOverride) globalProperties["globalProperties.variantUrlOverride"] = variantUrlOverride;
634
+ if (variantInfoOverride) globalProperties["globalProperties.variantInfoOverride"] = JSON.stringify(variantInfoOverride);
635
+ if (show != null) globalProperties["globalProperties.show"] = String(show);
636
+ const enabledFeatures = featureFlagService.getFeatureFlags();
637
+ const enabledFeaturesProperties = Object.entries(enabledFeatures).reduce((acc, [key, value$1]) => ({
638
+ ...acc,
639
+ [`enabledFeatures.${key}`]: `${value$1}`
640
+ }), {});
641
+ const timingProperties = { "timing.enriched_at_ms": window.performance?.now() };
642
+ enrichedEvent = {
643
+ ...event,
644
+ event_properties: {
645
+ ...event.event_properties,
646
+ ...getDefaultTrackingProps(),
647
+ ...globalProperties,
648
+ ...enabledFeaturesProperties,
649
+ ...timingProperties
650
+ }
651
+ };
652
+ } else enrichedEvent = event;
653
+ EventsDispatcher.dispatch(SpiffyEvent.AMPLITUDE_EVENT, enrichedEvent);
654
+ return enrichedEvent;
655
+ }
656
+ };
657
+ setInternalEventTrackingEnrichment(enrichment);
658
+ return enrichment;
659
+ }, [
660
+ internalEventTrackingEnrichment,
661
+ getDefaultTrackingProps,
662
+ featureFlagService,
663
+ publicKey,
664
+ featureOverrides,
665
+ variantUrlOverride,
666
+ variantInfoOverride,
667
+ show
668
+ ]);
669
+ useEffect(() => {
670
+ if (isReady && !amplitudeClient) {
671
+ const currentAmplitudeInstance = createInstance();
672
+ const isSessionsEnabled = amplitudeSessionReplayInit();
673
+ currentAmplitudeInstance.add(getEventTrackingEnrichment());
674
+ currentAmplitudeInstance.init(amplitudeApiKey, userId, {
675
+ serverZone: dataResidency,
676
+ trackingOptions: { ipAddress: true },
677
+ autocapture: {
678
+ attribution: true,
679
+ pageViews: { trackHistoryChanges: "pathOnly" },
680
+ sessions: isSessionsEnabled,
681
+ formInteractions: false,
682
+ fileDownloads: false
683
+ }
684
+ });
685
+ setAmplitudeClient(currentAmplitudeInstance);
686
+ }
687
+ }, [
688
+ isReady,
689
+ amplitudeClient,
690
+ amplitudeApiKey,
691
+ userId,
692
+ dataResidency,
693
+ amplitudeSessionReplayInit,
694
+ getEventTrackingEnrichment
695
+ ]);
696
+ const trackEvent = useCallback(async ({ eventName, eventProps, eventGroups, alsoSendToGoogleAnalytics = false }) => {
697
+ logger_default.logDebug("Submitting event", eventName);
698
+ try {
699
+ const decoratedEventName = `[Spiffy] ${eventName}`;
700
+ if (!amplitudeClient) {
701
+ logger_default.logWarn("amplitude client undefined", void 0, { event_name: decoratedEventName });
702
+ return;
703
+ }
704
+ const eventData = JSON.stringify({
705
+ eventName,
706
+ eventProps,
707
+ created_at: (/* @__PURE__ */ new Date()).toISOString()
708
+ });
709
+ const data = new TextEncoder().encode(eventData);
710
+ const hashBuffer = await crypto.subtle.digest("SHA-256", data);
711
+ const currentInsertId = Array.from(new Uint8Array(hashBuffer)).map((b) => b.toString(16).padStart(2, "0")).join("");
712
+ logger_default.logDebug(`amplitude tracking ${decoratedEventName}`, null, {
713
+ event_name: decoratedEventName,
714
+ props: eventProps
715
+ });
716
+ amplitudeClient.track(decoratedEventName, {
717
+ ...getDefaultTrackingProps(),
718
+ ...eventProps,
719
+ ...eventProps ? eventPropsToPrefixedEventProps(eventName, eventProps) : {}
720
+ }, {
721
+ ...eventGroups,
722
+ insert_id: currentInsertId
723
+ });
724
+ if (alsoSendToGoogleAnalytics && orgGaConfig) {
725
+ logger_default.logDebug("[spiffy-ai] GA tracking", decoratedEventName);
726
+ if (window.dataLayer) window.dataLayer.push({
727
+ event: decoratedEventName,
728
+ eventProps
729
+ });
730
+ }
731
+ } catch (err) {
732
+ logger_default.logError("[spiffy-ai] Error tracking event", err, {
733
+ eventName,
734
+ eventProps
735
+ });
736
+ }
737
+ }, [
738
+ amplitudeClient,
739
+ getDefaultTrackingProps,
740
+ eventPropsToPrefixedEventProps,
741
+ orgGaConfig
742
+ ]);
743
+ const value = useMemo(() => ({
744
+ trackEvent,
745
+ isReady,
746
+ setSupplementalDefaultProps: (props) => setSupplementalDefaultProps(props)
747
+ }), [
748
+ trackEvent,
749
+ isReady,
750
+ setSupplementalDefaultProps
751
+ ]);
752
+ return /* @__PURE__ */ jsx(AmplitudeContext.Provider, {
753
+ value,
754
+ children
755
+ });
756
+ };
757
+ const useAmplitude = () => {
758
+ const context = useContext(AmplitudeContext);
759
+ if (!context) throw new Error("useAmplitude must be used within AmplitudeProvider");
760
+ return context;
761
+ };
762
+
763
+ //#endregion
764
+ //#region src/application/utils/analyticsUtils.ts
765
+ const NORMALIZED_ADD_TO_CART_EVENT_NAMES = ["addtocart", "addedtocart"];
766
+ const CHECK_DATA_LAYER_INTERVAL_MS = 500;
767
+ const CHECK_DATA_LAYER_MAX_ATTEMPTS = 10;
768
+ /**
769
+ * Checks if a Google Analytics event is an add_to_cart event.
770
+ *
771
+ * @param event The event name to check.
772
+ *
773
+ * @returns True if the event is an add_to_cart event, false otherwise.
774
+ */
775
+ const isAddToCartEvent = (event) => {
776
+ const normalizedEvent = event.replace(/[-_]/g, "").toLowerCase();
777
+ return NORMALIZED_ADD_TO_CART_EVENT_NAMES.some((name) => normalizedEvent.includes(name));
778
+ };
779
+ /**
780
+ * Tracks an add_to_cart event in Amplitude.
781
+ *
782
+ * @param event The event to track.
783
+ */
784
+ const handleAddToCartEvent = (event, track) => {
785
+ let eventProps;
786
+ if (isLegacyUAEcommerceEvent(event)) eventProps = {
787
+ items: event.ecommerce.add.products.map((product) => ({
788
+ item_name: product.name,
789
+ item_category: product.category,
790
+ price: product.price,
791
+ quantity: product.quantity
792
+ })),
793
+ currency: event.ecommerce.add.currencyCode,
794
+ event_format_version: "legacy_universal_analytics"
795
+ };
796
+ else if (isGA4EcommerceEvent(event)) eventProps = {
797
+ items: event.ecommerce.items.map((item) => ({
798
+ item_name: item.item_name,
799
+ item_category: item.item_category,
800
+ price: item.price,
801
+ quantity: item.quantity
802
+ })),
803
+ currency: event.ecommerce.currency,
804
+ event_format_version: "google_analytics_4"
805
+ };
806
+ else eventProps = {
807
+ event_properties: { ...event },
808
+ event_format_version: "unknown"
809
+ };
810
+ track(SpiffyMetricsEventName.AddToCartClicked, { eventProps });
811
+ };
812
+ /**
813
+ * Wraps the window.dataLayer.push method to intercept add_to_cart events and send them to Amplitude.
814
+ * This function runs on an interval until the dataLayer is available.
815
+ */
816
+ const initDataLayerWrapper = (track) => {
817
+ let attempts = 0;
818
+ const checkAndInitialize = () => {
819
+ if (!window.dataLayer || !window.dataLayer.push) {
820
+ attempts += 1;
821
+ if (attempts >= CHECK_DATA_LAYER_MAX_ATTEMPTS) {
822
+ logger_default.logDebug(`[spiffy-ai] dataLayer not available after ${CHECK_DATA_LAYER_MAX_ATTEMPTS} attempts`);
823
+ return;
824
+ }
825
+ setTimeout(checkAndInitialize, CHECK_DATA_LAYER_INTERVAL_MS);
826
+ return;
827
+ }
828
+ logger_default.logDebug("[spiffy-ai] dataLayer is available, wrapping push function...");
829
+ const originalPush = window.dataLayer.push;
830
+ window.dataLayer.push = (...args) => {
831
+ if (isBaseEcommerceEvent(args[0]) && isAddToCartEvent(args[0].event)) handleAddToCartEvent(args[0], track);
832
+ return originalPush.apply(window.dataLayer, args);
833
+ };
834
+ };
835
+ checkAndInitialize();
836
+ };
837
+ const initAmplitude = (track) => {
838
+ track(SpiffyMetricsEventName.BundleLoaded);
839
+ };
840
+
841
+ //#endregion
842
+ //#region src/application/utils/coreContextToApiContext.ts
843
+ const coreContextToApiContext = (context) => ({
844
+ chat_id: context.chatId,
845
+ org_id: context.orgId,
846
+ user_id: context.userId,
847
+ org_short_name: context.orgShortName,
848
+ source: context.source,
849
+ env: context.env
850
+ });
851
+
852
+ //#endregion
853
+ //#region src/application/utils/coreUserEventToApiUserEvent.ts
854
+ const coreUserEventToApiUserEvent = (data) => {
855
+ if (data.category === UserEventCategory.PdpVisit || data.category === UserEventCategory.AddToCart) return {
856
+ event_id: data.eventId,
857
+ created_at: data.createdAt,
858
+ category: data.category,
859
+ attributes: {
860
+ product_id: data.attributes.productId,
861
+ parent_product_id: data.attributes.parentProductId,
862
+ url: data.attributes.url
863
+ }
864
+ };
865
+ if (data.category === UserEventCategory.PlpVisit) return {
866
+ event_id: data.eventId,
867
+ created_at: data.createdAt,
868
+ category: data.category,
869
+ attributes: {
870
+ category: PLPAttributeCategory.Id,
871
+ attributes: { id: data.attributes.attributes.id }
872
+ }
873
+ };
874
+ if (data.category === UserEventCategory.QueryTyped) return {
875
+ event_id: data.eventId,
876
+ created_at: data.createdAt,
877
+ category: data.category,
878
+ attributes: { query: data.attributes.query }
879
+ };
880
+ if (data.category === UserEventCategory.Search) return {
881
+ event_id: data.eventId,
882
+ created_at: data.createdAt,
883
+ category: data.category,
884
+ attributes: {
885
+ search_term: data.attributes.searchTerm,
886
+ selected_filters: data.attributes.selectedFilters
887
+ }
888
+ };
889
+ if (data.category === UserEventCategory.SuggestionClicked) return {
890
+ event_id: data.eventId,
891
+ created_at: data.createdAt,
892
+ category: data.category,
893
+ attributes: { suggestion_id: data.attributes.suggestionId }
894
+ };
895
+ if (data.category === UserEventCategory.PageVisit) return {
896
+ event_id: data.eventId,
897
+ created_at: data.createdAt,
898
+ category: data.category,
899
+ attributes: {
900
+ url: data.attributes.url,
901
+ page_visit_category: data.attributes.pageVisitCategory
902
+ }
903
+ };
904
+ if (data.category === UserEventCategory.FormSubmitted) return {
905
+ event_id: data.eventId,
906
+ created_at: data.createdAt,
907
+ category: data.category,
908
+ attributes: {
909
+ filled_schema: { ...data.attributes.filledSchema },
910
+ form_response_id: data.attributes.formResponseId,
911
+ form_type: data.attributes.formType
912
+ }
913
+ };
914
+ return {
915
+ event_id: data.eventId,
916
+ created_at: data.createdAt,
917
+ category: data.category
918
+ };
919
+ };
920
+
921
+ //#endregion
922
+ //#region src/application/utils/divideArray.ts
923
+ const divideArray = (array, size) => {
924
+ const rows = [];
925
+ for (let i = 0; i < size; i += 1) rows.push(array.filter((_, index) => index % size === i));
926
+ return rows;
927
+ };
928
+
929
+ //#endregion
930
+ //#region src/application/utils/imageFilter.ts
931
+ const getRecentProductImageUrls = (lastMessages, currentProductId) => {
932
+ const productMessages = lastMessages.filter((message) => message.type === MessageType$1.Product && message.metadata?.imageUrl).map((m) => m);
933
+ return [...productMessages.filter((m) => m.metadata?.id === currentProductId), ...productMessages.filter((m) => m.metadata?.id !== currentProductId)].map((m) => m.metadata.imageUrl);
934
+ };
935
+
936
+ //#endregion
937
+ //#region src/application/utils/merchantUtils.ts
938
+ const prepareMerchantPage = () => {
939
+ let metaViewport = document.querySelector("meta[name='viewport']");
940
+ if (metaViewport) {
941
+ const content = metaViewport.getAttribute("content");
942
+ if (!content?.includes("maximum-scale=1")) metaViewport.setAttribute("content", `${content}, maximum-scale=1`);
943
+ return;
944
+ }
945
+ metaViewport = document.createElement("meta");
946
+ metaViewport.setAttribute("name", "viewport");
947
+ metaViewport.setAttribute("content", "width=device-width, initial-scale=1, maximum-scale=1");
948
+ document.head.appendChild(metaViewport);
949
+ };
950
+
951
+ //#endregion
952
+ //#region src/application/utils/messageFromFormSubmittedEvent.ts
953
+ const messageFromFormSubmittedEvent = (event, formResponseAttributes) => {
954
+ if (event.category !== UserEventCategory.FormSubmitted) return;
955
+ const formStringContents = Object.entries(formResponseAttributes.schema.properties).map(([key, value]) => `${value.title}: ${event.attributes.filledSchema[key]}`).join("\n");
956
+ return {
957
+ id: event.eventId,
958
+ role: MessageRole$1.User,
959
+ type: MessageType$1.QueryTyped,
960
+ createdAt: event.createdAt,
961
+ metadata: { content: formStringContents }
962
+ };
963
+ };
964
+
965
+ //#endregion
966
+ //#region src/application/utils/messageFromQueryEvent.ts
967
+ /**
968
+ * Transforms a query UserEvent object into a Message object for presentation.
969
+ *
970
+ * @param event The user event object received from the server
971
+ *
972
+ * @returns A Message if the event is a query event, otherwise undefined
973
+ */
974
+ const messageFromQueryEvent = (event) => {
975
+ if (event.category === UserEventCategory.QueryTyped) return {
976
+ id: event.eventId,
977
+ role: MessageRole$1.User,
978
+ type: MessageType$1.QueryTyped,
979
+ createdAt: event.createdAt,
980
+ metadata: { content: event.attributes.query }
981
+ };
982
+ if (event.category === UserEventCategory.Search) return {
983
+ id: event.eventId,
984
+ role: MessageRole$1.User,
985
+ type: MessageType$1.Search,
986
+ createdAt: event.createdAt,
987
+ metadata: {
988
+ searchTerm: event.attributes.searchTerm || "",
989
+ selectedFilters: event.attributes.selectedFilters || []
990
+ }
991
+ };
992
+ };
993
+
994
+ //#endregion
995
+ //#region src/application/utils/messageFromResponse.ts
996
+ /**
997
+ * Transforms a server Response object into a Message object for presentation.
998
+ *
999
+ * @param response The response object received from the server containing model generated content
1000
+ *
1001
+ * @returns A Message if the response contains known attributes, undefined otherwise
1002
+ */
1003
+ const messageFromResponse = (response) => {
1004
+ if (response == null) return;
1005
+ if (response.category === ResponseCategory.Text) return {
1006
+ id: response.id,
1007
+ createdAt: response.createdAt,
1008
+ type: MessageType.Text,
1009
+ role: MessageRole.Assistant,
1010
+ metadata: { content: response.attributes.content }
1011
+ };
1012
+ if (response.category === ResponseCategory.Product) return {
1013
+ id: response.id,
1014
+ createdAt: response.createdAt,
1015
+ role: MessageRole.Assistant,
1016
+ type: MessageType.Product,
1017
+ metadata: { ...response.attributes }
1018
+ };
1019
+ if (response.category === ResponseCategory.Review) return {
1020
+ id: response.id,
1021
+ createdAt: response.createdAt,
1022
+ type: MessageType.Review,
1023
+ role: MessageRole.Assistant,
1024
+ metadata: {
1025
+ review: response.attributes.review,
1026
+ reviewer: response.attributes.reviewer,
1027
+ stars: response.attributes.stars,
1028
+ title: response.attributes.title,
1029
+ richInformation: response.attributes.richInformation
1030
+ }
1031
+ };
1032
+ if (response.category === ResponseCategory.Separator) return {
1033
+ id: response.id,
1034
+ createdAt: response.createdAt,
1035
+ type: MessageType.Separator,
1036
+ role: MessageRole.Assistant
1037
+ };
1038
+ if (response.category === ResponseCategory.Page) return {
1039
+ id: response.id,
1040
+ createdAt: response.createdAt,
1041
+ role: MessageRole.Assistant,
1042
+ type: MessageType.Page,
1043
+ metadata: { ...response.attributes }
1044
+ };
1045
+ if (response.category === ResponseCategory.ProductSearch) return {
1046
+ id: response.id,
1047
+ createdAt: response.createdAt,
1048
+ role: MessageRole.Assistant,
1049
+ type: MessageType.ProductSearch,
1050
+ metadata: { ...response.attributes }
1051
+ };
1052
+ if (response.category === ResponseCategory.ProductSearchFilter) return {
1053
+ id: response.id,
1054
+ createdAt: response.createdAt,
1055
+ role: MessageRole.Assistant,
1056
+ type: MessageType.ProductSearchFilter,
1057
+ metadata: { ...response.attributes }
1058
+ };
1059
+ if (response.category === ResponseCategory.Form) return {
1060
+ id: response.id,
1061
+ createdAt: response.createdAt,
1062
+ role: MessageRole.Assistant,
1063
+ type: MessageType.Form,
1064
+ metadata: {
1065
+ formType: response.attributes.formCategory?.formType,
1066
+ fields: Object.entries(response.attributes.schema.properties).map(([key, value]) => ({
1067
+ key,
1068
+ title: value.title,
1069
+ type: value.type,
1070
+ format: value.format,
1071
+ required: response.attributes.schema.required.includes(key)
1072
+ }))
1073
+ }
1074
+ };
1075
+ if (response.category === ResponseCategory.Order) return {
1076
+ id: response.id,
1077
+ createdAt: response.createdAt,
1078
+ role: MessageRole.Assistant,
1079
+ type: MessageType.Order,
1080
+ metadata: { ...response.attributes }
1081
+ };
1082
+ };
1083
+
1084
+ //#endregion
1085
+ //#region src/application/utils/messageFromSuggestionEvent.ts
1086
+ /**
1087
+ * Transforms a UserEvent object into a Message object for presentation.
1088
+ *
1089
+ * @param event The UserEvent object received from the server
1090
+ * @param suggestions A list of generated suggestions to match the event to
1091
+ *
1092
+ * @returns A Message if the event is a suggestion click event, undefined otherwise
1093
+ */
1094
+ const messageFromSuggestionEvent = (event, suggestions) => {
1095
+ if (event.category === UserEventCategory.SuggestionClicked) {
1096
+ const { suggestionId } = event.attributes;
1097
+ return {
1098
+ id: event.eventId,
1099
+ role: MessageRole.User,
1100
+ type: MessageType.SuggestionClicked,
1101
+ createdAt: event.createdAt,
1102
+ metadata: {
1103
+ suggestionId,
1104
+ suggestionContent: suggestions.find((s) => s.id === suggestionId)?.content ?? ""
1105
+ }
1106
+ };
1107
+ }
1108
+ };
1109
+
1110
+ //#endregion
1111
+ //#region src/application/utils/nextMessageRequestToApiRequest.ts
1112
+ const messageRequestToCommerceMessageRequest = (data) => ({
1113
+ context: {
1114
+ chat_id: data.context.chatId,
1115
+ org_id: data.context.orgId,
1116
+ org_short_name: data.context.orgShortName,
1117
+ user_id: data.context.userId,
1118
+ source: data.context.source,
1119
+ env: data.context.env
1120
+ },
1121
+ id: data.id,
1122
+ feature_flags: data.featureFlags,
1123
+ user_events: data.userEvents?.map((userEvent) => coreUserEventToApiUserEvent(userEvent)),
1124
+ generation_params: {
1125
+ model: data.generationParams?.model,
1126
+ max_tokens: data.generationParams?.maxTokens,
1127
+ stop: data.generationParams?.stop,
1128
+ stream: data.generationParams?.stream,
1129
+ temperature: data.generationParams?.temperature,
1130
+ top_p: data.generationParams?.topP,
1131
+ num_suggestions: data.generationParams?.numSuggestions,
1132
+ response_system_prompt: data.generationParams?.responseSystemPrompt,
1133
+ suggestion_system_prompt: data.generationParams?.suggestionSystemPrompt,
1134
+ response_caching: data.generationParams?.responseCaching
1135
+ }
1136
+ });
1137
+
1138
+ //#endregion
1139
+ //#region src/application/utils/nodeSelector.ts
1140
+ var NodeSelector = class {
1141
+ constructor(pattern) {
1142
+ this.pattern = pattern;
1143
+ this.root = document;
1144
+ }
1145
+ getPattern() {
1146
+ return this.pattern;
1147
+ }
1148
+ setRoot(root) {
1149
+ this.root = root;
1150
+ }
1151
+ getRoot() {
1152
+ return this.root;
1153
+ }
1154
+ };
1155
+ var QuerySelector = class extends NodeSelector {
1156
+ parse() {
1157
+ return this.getRoot().querySelector(this.getPattern());
1158
+ }
1159
+ };
1160
+ var IDSelector = class extends NodeSelector {
1161
+ parse() {
1162
+ return this.getRoot().getElementById(this.getPattern());
1163
+ }
1164
+ };
1165
+ var XpathSelector = class extends NodeSelector {
1166
+ parse() {
1167
+ return this.getRoot()?.evaluate(this.getPattern(), this.getRoot(), null, XPathResult.FIRST_ORDERED_NODE_TYPE, null)?.singleNodeValue;
1168
+ }
1169
+ };
1170
+ var ChainSelector = class extends NodeSelector {
1171
+ parse() {
1172
+ let selectorIndex = 0;
1173
+ const selectors = this.getPattern().split("@");
1174
+ const lastIndex = selectors.length - 1;
1175
+ const parseChain = (pattern, prevNode) => {
1176
+ const selector = SelectorFactory.parse(pattern);
1177
+ if (prevNode) selector.setRoot(prevNode);
1178
+ const currentNode = selector.parse();
1179
+ if (selectorIndex === lastIndex) return currentNode;
1180
+ let node = currentNode || document;
1181
+ if (currentNode?.shadowRoot) node = currentNode.shadowRoot;
1182
+ if (currentNode?.contentWindow) node = currentNode.contentWindow?.document;
1183
+ return parseChain(selectors[++selectorIndex].trim(), node);
1184
+ };
1185
+ return parseChain(selectors[selectorIndex].trim());
1186
+ }
1187
+ };
1188
+ var Empty = class extends NodeSelector {
1189
+ constructor() {
1190
+ super("");
1191
+ }
1192
+ parse() {
1193
+ return null;
1194
+ }
1195
+ };
1196
+ var SelectorFactory = class {
1197
+ static parse(composedSelector) {
1198
+ if (!composedSelector) return new Empty();
1199
+ const split = composedSelector.split("|");
1200
+ const type = split[0];
1201
+ const selector = split[1];
1202
+ switch (type) {
1203
+ case "id": return this.id(selector);
1204
+ case "query": return this.query(selector);
1205
+ case "xpath": return this.xpath(selector);
1206
+ default: return new Empty();
1207
+ }
1208
+ }
1209
+ static check(selector) {
1210
+ return selector ?? new Empty();
1211
+ }
1212
+ static chain(pattern) {
1213
+ return pattern ? new ChainSelector(pattern) : new Empty();
1214
+ }
1215
+ static id(pattern) {
1216
+ return pattern ? new IDSelector(pattern) : new Empty();
1217
+ }
1218
+ static query(pattern) {
1219
+ return pattern ? new QuerySelector(pattern) : new Empty();
1220
+ }
1221
+ static xpath(pattern) {
1222
+ return pattern ? new XpathSelector(pattern) : new Empty();
1223
+ }
1224
+ };
1225
+
1226
+ //#endregion
1227
+ //#region src/application/utils/overrides.ts
1228
+ function isPlainObject(x) {
1229
+ return !!x && typeof x === "object" && !Array.isArray(x) && !(x instanceof Date) && !(x instanceof RegExp);
1230
+ }
1231
+ function isReplace(x) {
1232
+ return !!x && typeof x === "object" && "$replace" in x;
1233
+ }
1234
+ function isDelete(x) {
1235
+ return !!x && typeof x === "object" && x.$delete === true;
1236
+ }
1237
+ function isPrimitiveValue(x) {
1238
+ const t = typeof x;
1239
+ return x === null || t === "string" || t === "number" || t === "boolean" || t === "bigint" || t === "symbol" || t === "undefined";
1240
+ }
1241
+ function isArrayOfPrimitives(arr) {
1242
+ if (arr.length === 0) return false;
1243
+ for (let i = 0; i < arr.length; i += 1) {
1244
+ const v = arr[i];
1245
+ if (v !== void 0 && !isPrimitiveValue(v)) return false;
1246
+ }
1247
+ return true;
1248
+ }
1249
+ function mergeAny(baseAny, patchAny, opts) {
1250
+ if (isReplace(patchAny)) return patchAny.$replace;
1251
+ if (isDelete(patchAny)) return void 0;
1252
+ if (Array.isArray(baseAny)) {
1253
+ if (Array.isArray(patchAny)) {
1254
+ const baseArr = baseAny;
1255
+ const patchArr = patchAny;
1256
+ if (opts.arrayStrategy === "replace" || isArrayOfPrimitives(baseArr) || isArrayOfPrimitives(patchArr)) return patchAny;
1257
+ const out = baseArr.slice();
1258
+ const max = Math.max(out.length, patchArr.length);
1259
+ for (let i = 0; i < max; i += 1) {
1260
+ const pVal = patchArr[i];
1261
+ if (pVal !== void 0) out[i] = mergeAny(out[i], pVal, opts);
1262
+ }
1263
+ return out;
1264
+ }
1265
+ return baseAny;
1266
+ }
1267
+ if (isPlainObject(baseAny) && isPlainObject(patchAny)) {
1268
+ const baseObj = baseAny;
1269
+ const patchObj = patchAny;
1270
+ const out = { ...baseObj };
1271
+ for (const key of Object.keys(patchObj)) {
1272
+ const pVal = patchObj[key];
1273
+ if (pVal === void 0) {} else if (opts.nullDeletes && pVal === null) delete out[key];
1274
+ else if (isReplace(pVal)) out[key] = pVal.$replace;
1275
+ else if (isDelete(pVal)) delete out[key];
1276
+ else out[key] = mergeAny(baseObj?.[key], pVal, opts);
1277
+ }
1278
+ return out;
1279
+ }
1280
+ return patchAny ?? baseAny;
1281
+ }
1282
+ function applyOverrides(base, patch, opts = {}) {
1283
+ const { arrayStrategy = "mergeByIndex", nullDeletes = false } = opts;
1284
+ if (isReplace(patch)) return patch.$replace;
1285
+ if (isDelete(patch)) return void 0;
1286
+ if (Array.isArray(base)) {
1287
+ if (isReplace(patch)) return patch.$replace;
1288
+ if (Array.isArray(patch)) {
1289
+ if (arrayStrategy === "replace") return patch;
1290
+ const out = base.slice();
1291
+ const max = Math.max(out.length, patch.length);
1292
+ for (let i = 0; i < max; i += 1) {
1293
+ const pVal = patch[i];
1294
+ if (pVal !== void 0) out[i] = mergeAny(out[i], pVal, opts);
1295
+ }
1296
+ return out;
1297
+ }
1298
+ return base;
1299
+ }
1300
+ if (isPlainObject(base) && isPlainObject(patch)) {
1301
+ const out = { ...base };
1302
+ const patchObj = patch;
1303
+ for (const key of Object.keys(patchObj)) {
1304
+ const pVal = patchObj[key];
1305
+ if (pVal === void 0) {} else if (nullDeletes && pVal === null) delete out[key];
1306
+ else if (isReplace(pVal)) out[key] = pVal.$replace;
1307
+ else if (isDelete(pVal)) delete out[key];
1308
+ else {
1309
+ const bVal = base[key];
1310
+ out[key] = mergeAny(bVal, pVal, opts);
1311
+ }
1312
+ }
1313
+ return out;
1314
+ }
1315
+ return patch ?? base;
1316
+ }
1317
+
1318
+ //#endregion
1319
+ //#region src/application/utils/stringUtils.ts
1320
+ var StringUtils = class StringUtils {
1321
+ static isNullOrEmpty(value) {
1322
+ const valueTrimmed = value?.trim();
1323
+ return value === void 0 || valueTrimmed === "";
1324
+ }
1325
+ static trimToNull(value) {
1326
+ const valueTrimmed = value?.trim();
1327
+ return StringUtils.isNullOrEmpty(valueTrimmed) ? void 0 : valueTrimmed;
1328
+ }
1329
+ static capitalize(type) {
1330
+ if (type === void 0) return "";
1331
+ return type.charAt(0).toUpperCase() + type.substring(1);
1332
+ }
1333
+ /**
1334
+ * Finds the first pattern in an array that matches a given URL.
1335
+ * Patterns can include a single wildcard '*' which matches any sequence of characters.
1336
+ *
1337
+ * @param patterns
1338
+ * @param urlToTest
1339
+ * @returns
1340
+ */
1341
+ static findMatchingPattern(patterns, urlToTest) {
1342
+ if (!urlToTest) return;
1343
+ for (const pattern of patterns) if (urlToTest.pathname !== "/") {
1344
+ const regexPattern = pattern.replace(/[.+?^${}()|[\]\\]/g, "\\$&").replace(/\*/g, ".*");
1345
+ if ((/* @__PURE__ */ new RegExp(`^${regexPattern}$`)).test(urlToTest.pathname)) return pattern;
1346
+ } else if (pattern.startsWith(urlToTest.hostname)) return pattern;
1347
+ }
1348
+ };
1349
+
1350
+ //#endregion
1351
+ //#region src/application/utils/supportedEventRequestToApiRequest.ts
1352
+ const coreSupportedEventRequestToApiRequest = (coreSupportedEventRequest) => ({
1353
+ id: coreSupportedEventRequest.id,
1354
+ user_event: coreUserEventToApiUserEvent(coreSupportedEventRequest.userEvent),
1355
+ context: coreContextToApiContext(coreSupportedEventRequest.context)
1356
+ });
1357
+
1358
+ //#endregion
1359
+ //#region src/application/utils/validation.ts
1360
+ const validateEmail = (value) => /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(value);
1361
+
1362
+ //#endregion
1363
+ export { AmplitudeProvider, NodeSelector, SelectorFactory, SpiffyMetricsEventName, StringUtils, UserIdentityProvider, appSourceAtom, applyOverrides, chatIdAtom, coreContextToApiContext, coreSupportedEventRequestToApiRequest, coreUserEventToApiUserEvent, divideArray, getRecentProductImageUrls, hasParsedVariantInfoAtom, initAmplitude, initDataLayerWrapper, messageFromFormSubmittedEvent, messageFromQueryEvent, messageFromResponse, messageFromSuggestionEvent, messageRequestToCommerceMessageRequest, prepareMerchantPage, useAmplitude, useUserIdentity, userIdAtom, userIdentityAtom, validateEmail, variantInfoAtom };
1364
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMtTjQ3VnNMOVcuanMiLCJuYW1lcyI6WyJjb25maWc6IENvbmZpZ3VyYXRpb24iLCJjb250ZXh0OiBDb250ZXh0IiwiZXJyOiB1bmtub3duIiwiZXJyb3I6IHVua25vd24iLCJkYXRhOiBWMUdldFNlc3Npb25NZXNzYWdlczIwMFJlc3BvbnNlIiwicmVzcG9uc2VzOiBBcGlSZXNwb25zZVtdW10iLCJzdWdnZXN0aW9uczogU3VnZ2VzdGlvbltdIiwidXNlckV2ZW50czogVXNlckV2ZW50W10iLCJhc3Npc3RhbnRNZXNzYWdlczogTWVzc2FnZVtdW10iLCJ1c2VyTWVzc2FnZXM6IE1lc3NhZ2VbXVtdIiwicmVxdWVzdDogVjFPcmdDb25maWdHZXRSZXF1ZXN0IiwiVXNlcklkZW50aXR5UHJvdmlkZXI6IFJlYWN0LkZDPHsgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZSB9PiIsInV1aWQiLCJDb21tZXJjZUFwaUNsaWVudCIsInV1aWQiLCJBbXBsaXR1ZGVQcm92aWRlcjogUmVhY3QuRkM8eyBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlIH0+IiwidmFsdWUiLCJlbnJpY2htZW50OiBFbnJpY2htZW50UGx1Z2luIiwiZW5yaWNoZWRFdmVudDogRXZlbnQiLCJnbG9iYWxQcm9wZXJ0aWVzOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+IiwiY3VycmVudEFtcGxpdHVkZUluc3RhbmNlOiBCcm93c2VyQ2xpZW50IiwiZXZlbnRQcm9wczogUmVjb3JkPHN0cmluZywgdW5rbm93bj4iLCJNZXNzYWdlVHlwZSIsIk1lc3NhZ2VSb2xlIiwiTWVzc2FnZVR5cGUiLCJNZXNzYWdlUm9sZSIsIk1lc3NhZ2VUeXBlIiwibm9kZTogTm9kZSB8IG51bGwgfCB1bmRlZmluZWQiLCJvdXQ6IFJlY29yZDxzdHJpbmcsIHVua25vd24+Il0sInNvdXJjZXMiOlsiLi4vc3JjL2FwcGxpY2F0aW9uL2NvbW1lcmNlLWFwaS50cyIsIi4uL3NyYy9jb250ZXh0cy91c2VySWRlbnRpdHlDb250ZXh0L3VzZXJJZGVudGl0eUNvbnRleHQudHN4IiwiLi4vc3JjL2F0b21zL2FwcC92YXJpYW50LnRzIiwiLi4vc3JjL2F0b21zL2FwcC9pbmRleC50cyIsIi4uL3NyYy9jb250ZXh0cy9hbXBsaXR1ZGVDb250ZXh0L2FtcGxpdHVkZUNvbnRleHQudHN4IiwiLi4vc3JjL2FwcGxpY2F0aW9uL3V0aWxzL2FuYWx5dGljc1V0aWxzLnRzIiwiLi4vc3JjL2FwcGxpY2F0aW9uL3V0aWxzL2NvcmVDb250ZXh0VG9BcGlDb250ZXh0LnRzIiwiLi4vc3JjL2FwcGxpY2F0aW9uL3V0aWxzL2NvcmVVc2VyRXZlbnRUb0FwaVVzZXJFdmVudC50cyIsIi4uL3NyYy9hcHBsaWNhdGlvbi91dGlscy9kaXZpZGVBcnJheS50cyIsIi4uL3NyYy9hcHBsaWNhdGlvbi91dGlscy9pbWFnZUZpbHRlci50cyIsIi4uL3NyYy9hcHBsaWNhdGlvbi91dGlscy9tZXJjaGFudFV0aWxzLnRzIiwiLi4vc3JjL2FwcGxpY2F0aW9uL3V0aWxzL21lc3NhZ2VGcm9tRm9ybVN1Ym1pdHRlZEV2ZW50LnRzIiwiLi4vc3JjL2FwcGxpY2F0aW9uL3V0aWxzL21lc3NhZ2VGcm9tUXVlcnlFdmVudC50cyIsIi4uL3NyYy9hcHBsaWNhdGlvbi91dGlscy9tZXNzYWdlRnJvbVJlc3BvbnNlLnRzIiwiLi4vc3JjL2FwcGxpY2F0aW9uL3V0aWxzL21lc3NhZ2VGcm9tU3VnZ2VzdGlvbkV2ZW50LnRzIiwiLi4vc3JjL2FwcGxpY2F0aW9uL3V0aWxzL25leHRNZXNzYWdlUmVxdWVzdFRvQXBpUmVxdWVzdC50cyIsIi4uL3NyYy9hcHBsaWNhdGlvbi91dGlscy9ub2RlU2VsZWN0b3IudHMiLCIuLi9zcmMvYXBwbGljYXRpb24vdXRpbHMvb3ZlcnJpZGVzLnRzIiwiLi4vc3JjL2FwcGxpY2F0aW9uL3V0aWxzL3N0cmluZ1V0aWxzLnRzIiwiLi4vc3JjL2FwcGxpY2F0aW9uL3V0aWxzL3N1cHBvcnRlZEV2ZW50UmVxdWVzdFRvQXBpUmVxdWVzdC50cyIsIi4uL3NyYy9hcHBsaWNhdGlvbi91dGlscy92YWxpZGF0aW9uLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbnRleHQsXG4gIENvbnRleHRFbnZFbnVtLFxuICBDb25maWd1cmF0aW9uLFxuICBDdXN0b21lclNlcnZpY2VBcGksXG4gIERlZmF1bHRBcGksXG4gIEluZmVyZW5jZUFwaSxcbiAgUmVwb3J0U2Vzc2lvblJlcXVlc3QsXG4gIFJlc3BvbnNlRXJyb3IsXG4gIFVzZXJFdmVudENhdGVnb3J5LFxuICBWMUdldFNlc3Npb25NZXNzYWdlczIwMFJlc3BvbnNlLFxuICBWMU9yZ0NvbmZpZ0dldFJlcXVlc3QsXG4gIENvbnRleHRTb3VyY2VFbnVtLFxuICBWMU9yZ0NvbmZpZ0dldFNvdXJjZUVudW0sXG4gIEN1c3RvbWVyU2VydmljZVByb3ZpZGVyLFxuICBSZXNwb25zZUNhdGVnb3J5LFxuICBGb3JtVHlwZSxcbn0gZnJvbSBcIkBzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudFwiO1xuaW1wb3J0IHtcbiAgU3VwcG9ydGVkRXZlbnQsXG4gIFByb2R1Y3RFeHBlcmltZW50LFxuICBDbGllbnREZXRhaWxzLFxuICBVc2VyRXZlbnQsXG4gIE5leHRNZXNzYWdlUmVxdWVzdCxcbiAgU3VwcG9ydGVkRXZlbnRSZXF1ZXN0LFxuICBPcmdDb25maWcsXG59IGZyb20gXCJAZW52aXZlLWFpL3R5cGVzXCI7XG5pbXBvcnQgeyBBcGlSZXNwb25zZSwgTWVzc2FnZSwgU3VnZ2VzdGlvbiB9IGZyb20gXCJzcmMvdHlwZXNcIjtcbmltcG9ydCB7IHVzZXJJZEF0b20sIGNoYXRJZEF0b20gfSBmcm9tIFwic3JjL2F0b21zL2FwcFwiO1xuaW1wb3J0IHsgZ2V0QXRvbVN0b3JlIH0gZnJvbSBcInNyYy9hdG9tcy9hdG9tU3RvcmVcIjtcbmltcG9ydCB7XG4gIGJhc2VVcmxBdG9tLFxuICBvcmdTaG9ydE5hbWVBdG9tLFxuICBjb250ZXh0U291cmNlQXRvbSxcbiAgZW52QXRvbSxcbiAgcmVhY3RBcHBOYW1lQXRvbSxcbn0gZnJvbSBcInNyYy9hdG9tcy9lbnZpdmUvZW52aXZlQ29uZmlnXCI7XG5pbXBvcnQgeyBvcmdJZEF0b20sIGZlYXR1cmVGbGFnU2VydmljZUF0b20gfSBmcm9tIFwic3JjL2F0b21zL29yZ1wiO1xuaW1wb3J0IHtcbiAgVW5zdXBwb3J0ZWRQcm9kdWN0RXhjZXB0aW9uLFxuICBTZXNzaW9uUmVzdGFydFJlcXVpcmVkLFxufSBmcm9tIFwic3JjL2V4Y2VwdGlvbnNcIjtcbmltcG9ydCBMb2dnZXIgZnJvbSBcIi4vbG9nZ2luZy9sb2dnZXJcIjtcbmltcG9ydCB7XG4gIHZhbGlkYXRlUmVzcG9uc2UsXG4gIHZhbGlkYXRlU3VnZ2VzdGlvbixcbiAgdmFsaWRhdGVVc2VyRXZlbnQsXG4gIHZhbGlkYXRlT3JnQ29uZmlnUmVzdWx0cyxcbn0gZnJvbSBcIi4vbW9kZWxzXCI7XG5pbXBvcnQge1xuICBtZXNzYWdlUmVxdWVzdFRvQ29tbWVyY2VNZXNzYWdlUmVxdWVzdCxcbiAgbWVzc2FnZUZyb21SZXNwb25zZSxcbiAgbWVzc2FnZUZyb21RdWVyeUV2ZW50LFxuICBtZXNzYWdlRnJvbVN1Z2dlc3Rpb25FdmVudCxcbiAgbWVzc2FnZUZyb21Gb3JtU3VibWl0dGVkRXZlbnQsXG4gIGNvcmVTdXBwb3J0ZWRFdmVudFJlcXVlc3RUb0FwaVJlcXVlc3QsXG59IGZyb20gXCIuL3V0aWxzXCI7XG5cbmFzeW5jIGZ1bmN0aW9uIGVycm9yUmVzcG9uc2VCb2R5KGVycm9yOiBSZXNwb25zZUVycm9yKSB7XG4gIHRyeSB7XG4gICAgcmV0dXJuIGF3YWl0IGVycm9yLnJlc3BvbnNlLmpzb24oKTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIHt9O1xuICB9XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHRocm93U2Vzc2lvblJlc3RhcnRSZXF1aXJlZElmKGVycm9yTXNnOiBzdHJpbmcsIGVycm9yOiB1bmtub3duKSB7XG4gIGlmICghKGVycm9yIGluc3RhbmNlb2YgUmVzcG9uc2VFcnJvcikpIHtcbiAgICBMb2dnZXIubG9nSW5mbyhlcnJvck1zZywgZXJyb3IpO1xuICAgIHRocm93IGVycm9yO1xuICB9XG5cbiAgY29uc3QgZXJyb3JSZXNwb25zZSA9IGF3YWl0IGVycm9yUmVzcG9uc2VCb2R5KGVycm9yKTtcbiAgaWYgKFxuICAgIGVycm9yUmVzcG9uc2U/Lm1lc3NhZ2U/LnRvTG93ZXJDYXNlKCkgPT09IFwidW5zdXBwb3J0ZWQgcHJvZHVjdFwiIHx8IC8vIGZvciBiYWNrd2FyZCBjb21wYXRpYmlsaXR5LiBuZXdlciB2ZXJzaW9ucyBvZiB0aGUgQVBJIHJldHVybiBzdWJfY29kZSBpbnN0ZWFkIG9mIG1lc3NhZ2VcbiAgICBlcnJvclJlc3BvbnNlPy5hcHBfY29kZT8udG9VcHBlckNhc2UoKSA9PT0gXCJQUk9EVUNUX05PVF9GT1VORFwiXG4gICkge1xuICAgIHRocm93IG5ldyBVbnN1cHBvcnRlZFByb2R1Y3RFeGNlcHRpb24oKTtcbiAgfSBlbHNlIGlmIChcbiAgICBlcnJvclJlc3BvbnNlPy5hcHBfY29kZT8udG9VcHBlckNhc2UoKSA9PT0gXCJSRVNUQVJUX1NFU1NJT05cIiB8fFxuICAgIGVycm9yUmVzcG9uc2U/LnN1Yl9jb2RlPy50b1VwcGVyQ2FzZSgpID09PSBcIk5PVF9GT1VORFwiIC8vIGZvciBiYWNrd2FyZCBjb21wYXRpYmlsaXR5LiBuZXcgQVBJIHJlc3BvbnNlcyB3aWxsIGNvbnRhaW4gXCJhcHBfY29kZVwiXG4gICkge1xuICAgIExvZ2dlci5sb2dJbmZvKFxuICAgICAgXCJTZXNzaW9uIGRvZXMgbm90IGV4aXN0LiBSZS1zdGFydCBzZXNzaW9uXCIsXG4gICAgICBlcnJvcixcbiAgICAgIGVycm9yLnJlc3BvbnNlLFxuICAgICAgZXJyb3JSZXNwb25zZVxuICAgICk7XG4gICAgdGhyb3cgbmV3IFNlc3Npb25SZXN0YXJ0UmVxdWlyZWQoKTtcbiAgfVxuXG4gIExvZ2dlci5sb2dJbmZvKGVycm9yTXNnLCBlcnJvcik7XG4gIHRocm93IGVycm9yO1xufVxuXG5jbGFzcyBDb21tZXJjZUFwaUNsaWVudCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgZGVmYXVsdEFwaTogRGVmYXVsdEFwaTtcblxuICBwcml2YXRlIHJlYWRvbmx5IGN1c3RvbWVyU2VydmljZUFwaTogQ3VzdG9tZXJTZXJ2aWNlQXBpO1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgaW5mZXJlbmNlQXBpOiBJbmZlcmVuY2VBcGk7XG5cbiAgcHJpdmF0ZSBzdGF0aWMgaW5zdGFuY2U6IENvbW1lcmNlQXBpQ2xpZW50IHwgdW5kZWZpbmVkO1xuXG4gIHByaXZhdGUgc3VnZ2VzdGlvbnNBYm9ydENvbnRyb2xsZXIgPSBuZXcgQWJvcnRDb250cm9sbGVyKCk7XG5cbiAgcHJpdmF0ZSByZXNwb25zZXNBYm9ydENvbnRyb2xsZXIgPSBuZXcgQWJvcnRDb250cm9sbGVyKCk7XG5cbiAgcHJpdmF0ZSBzdGF0aWMgZ2V0SW5zdGFuY2UgPSAoKTogQ29tbWVyY2VBcGlDbGllbnQgPT4ge1xuICAgIGlmICghQ29tbWVyY2VBcGlDbGllbnQuaW5zdGFuY2UpIHtcbiAgICAgIENvbW1lcmNlQXBpQ2xpZW50Lmluc3RhbmNlID0gbmV3IENvbW1lcmNlQXBpQ2xpZW50KCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIENvbW1lcmNlQXBpQ2xpZW50Lmluc3RhbmNlO1xuICB9O1xuXG4gIHByaXZhdGUgY29uc3RydWN0b3IoYmFzZVBhdGg/OiBzdHJpbmcpIHtcbiAgICBjb25zdCBhdG9tU3RvcmUgPSBnZXRBdG9tU3RvcmUoKTtcbiAgICBjb25zdCBiYXNlVXJsID0gYXRvbVN0b3JlLmdldChiYXNlVXJsQXRvbSk7XG4gICAgY29uc3QgcGF0aCA9IGJhc2VQYXRoIHx8IGJhc2VVcmw7XG4gICAgLy8gQVBJIEtleSBpcyBub3cgaGFuZGxlZCBhdCB0aGUgRW52aXZlQ29uZmlnUHJvdmlkZXIgbGV2ZWxcbiAgICBjb25zdCBjb25maWc6IENvbmZpZ3VyYXRpb24gPSBuZXcgQ29uZmlndXJhdGlvbih7XG4gICAgICBiYXNlUGF0aDogcGF0aCxcbiAgICAgIGhlYWRlcnM6IHtcbiAgICAgICAgXCJDb250ZW50LVR5cGVcIjogXCJhcHBsaWNhdGlvbi9qc29uXCIsXG4gICAgICAgIEFjY2VwdDogXCJhcHBsaWNhdGlvbi9qc29uXCIsXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHRoaXMuZGVmYXVsdEFwaSA9IG5ldyBEZWZhdWx0QXBpKGNvbmZpZyk7XG4gICAgdGhpcy5pbmZlcmVuY2VBcGkgPSBuZXcgSW5mZXJlbmNlQXBpKGNvbmZpZyk7XG4gICAgdGhpcy5jdXN0b21lclNlcnZpY2VBcGkgPSBuZXcgQ3VzdG9tZXJTZXJ2aWNlQXBpKGNvbmZpZyk7XG4gIH1cblxuICBzdGF0aWMgcmVzb2x2ZVVybCA9IGFzeW5jICh1cmw6IHN0cmluZykgPT4ge1xuICAgIGNvbnN0IGF0b21TdG9yZSA9IGdldEF0b21TdG9yZSgpO1xuICAgIGNvbnN0IG9yZ1Nob3J0TmFtZSA9IGF0b21TdG9yZS5nZXQob3JnU2hvcnROYW1lQXRvbSk7XG4gICAgY29uc3Qgb3JnSWQgPSBhdG9tU3RvcmUuZ2V0KG9yZ0lkQXRvbSk7XG4gICAgY29uc3QgdXNlcklkID0gYXRvbVN0b3JlLmdldCh1c2VySWRBdG9tKTtcbiAgICBjb25zdCBjaGF0SWQgPSBhdG9tU3RvcmUuZ2V0KGNoYXRJZEF0b20pO1xuICAgIGNvbnN0IHNvdXJjZSA9IGF0b21TdG9yZS5nZXQoY29udGV4dFNvdXJjZUF0b20pO1xuICAgIGNvbnN0IGVudiA9IGF0b21TdG9yZS5nZXQoZW52QXRvbSk7XG5cbiAgICBjb25zdCBmZWF0dXJlRmxhZ1NlcnZpY2UgPSBhdG9tU3RvcmUuZ2V0KGZlYXR1cmVGbGFnU2VydmljZUF0b20pO1xuXG4gICAgY29uc3QgY29udGV4dDogQ29udGV4dCA9IHtcbiAgICAgIHVzZXJfaWQ6IHVzZXJJZCA/PyBcIlwiLFxuICAgICAgb3JnX2lkOiBvcmdJZCA/PyBcIlwiLFxuICAgICAgb3JnX3Nob3J0X25hbWU6IG9yZ1Nob3J0TmFtZSA/PyBcIlwiLFxuICAgICAgY2hhdF9pZDogY2hhdElkID8/IFwiXCIsXG4gICAgICBzb3VyY2U6IHNvdXJjZSA/PyBDb250ZXh0U291cmNlRW51bS5BcHAsXG4gICAgICBlbnY6IChlbnYgYXMgQ29udGV4dEVudkVudW0pID8/IENvbnRleHRFbnZFbnVtLkRldiwgLy8gQ2FzdCBlbnYgdG8gQ29udGV4dEVudkVudW1cbiAgICB9O1xuXG4gICAgY29uc3QgZmVhdHVyZUdhdGVzID1cbiAgICAgIGZlYXR1cmVGbGFnU2VydmljZT8uZmVhdHVyZUZsYWdTZXJ2aWNlPy5nZXRGZWF0dXJlRmxhZ3MoKSB8fCB7fTtcbiAgICBjb25zdCB1cmxSZXNvbHZpbmdSZXF1ZXN0ID0ge1xuICAgICAgdXJsLFxuICAgICAgY29udGV4dCxcbiAgICAgIGZlYXR1cmVfZ2F0ZXM6IGZlYXR1cmVHYXRlcyxcbiAgICB9O1xuXG4gICAgY29uc3QgcmF3UmVzcG9uc2UgPVxuICAgICAgYXdhaXQgQ29tbWVyY2VBcGlDbGllbnQuZ2V0SW5zdGFuY2UoKS5pbmZlcmVuY2VBcGkudjFVcmxSZXNvbHZpbmdQb3N0UmF3KHtcbiAgICAgICAgVXJsUmVzb2x2aW5nUmVxdWVzdDogdXJsUmVzb2x2aW5nUmVxdWVzdCxcbiAgICAgIH0pO1xuXG4gICAgY29uc3QgcmVzcG9uc2VCb2R5ID0gYXdhaXQgcmF3UmVzcG9uc2UucmF3Lmpzb24oKTtcblxuICAgIHJldHVybiByZXNwb25zZUJvZHk7XG4gIH07XG5cbiAgc3RhdGljIHJlcG9ydFNlc3Npb24gPSBhc3luYyAoXG4gICAgcmVwb3J0UmVxdWVzdDogUmVwb3J0U2Vzc2lvblJlcXVlc3RcbiAgKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgYXdhaXQgQ29tbWVyY2VBcGlDbGllbnQuZ2V0SW5zdGFuY2UoKS5kZWZhdWx0QXBpLnYxQ2hhdHNSZXBvcnRTZXNzaW9uSWRQb3N0KFxuICAgICAge1xuICAgICAgICBSZXBvcnRTZXNzaW9uUmVxdWVzdDogcmVwb3J0UmVxdWVzdCxcbiAgICAgIH1cbiAgICApO1xuICB9O1xuXG4gIHN0YXRpYyBnZXROZXh0UmVzcG9uc2VzID0gYXN5bmMgKFxuICAgIHBheWxvYWQ6IE5leHRNZXNzYWdlUmVxdWVzdFxuICApOiBQcm9taXNlPE1lc3NhZ2VbXT4gPT4ge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCByZXNwb25zZSA9XG4gICAgICAgIGF3YWl0IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuaW5mZXJlbmNlQXBpLnYxTmV4dFJlc3BvbnNlc1Bvc3Qoe1xuICAgICAgICAgIE5leHRNZXNzYWdlUmVxdWVzdDogbWVzc2FnZVJlcXVlc3RUb0NvbW1lcmNlTWVzc2FnZVJlcXVlc3QocGF5bG9hZCksXG4gICAgICAgIH0pO1xuICAgICAgY29uc3QgbWVzc2FnZXMgPSByZXNwb25zZVxuICAgICAgICAubWFwKChyZXNwKSA9PiB2YWxpZGF0ZVJlc3BvbnNlKHJlc3ApKVxuICAgICAgICAubWFwKChyZXNwKSA9PiBtZXNzYWdlRnJvbVJlc3BvbnNlKHJlc3ApKTtcblxuICAgICAgcmV0dXJuIG1lc3NhZ2VzLmZpbHRlcigobSk6IG0gaXMgTWVzc2FnZSA9PiBtICE9IG51bGwpO1xuICAgIH0gY2F0Y2ggKGVycjogdW5rbm93bikge1xuICAgICAgTG9nZ2VyLmxvZ0luZm8oXCJGYWlsZWQgdG8gZ2V0IG5leHQgcmVzcG9uc2VzXCIsIGVyciwge1xuICAgICAgICBwYXlsb2FkQ29udGV4dDogcGF5bG9hZD8uY29udGV4dCxcbiAgICAgICAgdXNlckV2ZW50czogcGF5bG9hZD8udXNlckV2ZW50cyxcbiAgICAgIH0pO1xuICAgICAgYXdhaXQgdGhyb3dTZXNzaW9uUmVzdGFydFJlcXVpcmVkSWYoXCJGYWlsZWQgdG8gZ2V0IG5leHQgcmVzcG9uc2VzXCIsIGVycik7XG4gICAgICByZXR1cm4gW107XG4gICAgfVxuICB9O1xuXG4gIHN0YXRpYyBnZXROZXh0UmVzcG9uc2VTdHJlYW1pbmcgPSAoXG4gICAgcGF5bG9hZDogTmV4dE1lc3NhZ2VSZXF1ZXN0XG4gICk6IEFzeW5jR2VuZXJhdG9yPEFwaVJlc3BvbnNlLCB2b2lkLCB1bmtub3duPiA9PiB7XG4gICAgYXN5bmMgZnVuY3Rpb24qIGdlbmVyYXRlKFxuICAgICAgaW5mZXJlbmNlQXBpOiBJbmZlcmVuY2VBcGksXG4gICAgICBhYm9ydENvbnRyb2xsZXI6IEFib3J0Q29udHJvbGxlclxuICAgICkge1xuICAgICAgLy8gbWFrZSBzdXJlIHN0cmVhbWluZyBpcyBlbmFibGVkXG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGluZmVyZW5jZUFwaS52MU5leHRSZXNwb25zZXNQb3N0UmF3KFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIE5leHRNZXNzYWdlUmVxdWVzdDogbWVzc2FnZVJlcXVlc3RUb0NvbW1lcmNlTWVzc2FnZVJlcXVlc3QocGF5bG9hZCksXG4gICAgICAgICAgfSxcbiAgICAgICAgICB7IHNpZ25hbDogYWJvcnRDb250cm9sbGVyLnNpZ25hbCB9XG4gICAgICAgICk7XG5cbiAgICAgICAgLy8gUmVhZCB0aGUgcmVzcG9uc2UgYXMgYSBzdHJlYW0gb2YgZGF0YVxuICAgICAgICBpZiAoIXJlc3BvbnNlLnJhdy5ib2R5KSB7XG4gICAgICAgICAgTG9nZ2VyLmxvZ0Vycm9yKFxuICAgICAgICAgICAgXCJbc3BpZmZ5LWFpXSBObyBib2R5IGluIHRoZSBzdHJlYW1lZCByZXNwb25zZVwiLFxuICAgICAgICAgICAgdW5kZWZpbmVkLFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICByZXNwb25zZTogcmVzcG9uc2UucmF3LFxuICAgICAgICAgICAgfVxuICAgICAgICAgICk7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcmVhZGVyID0gcmVzcG9uc2UucmF3LmJvZHkuZ2V0UmVhZGVyKCk7XG4gICAgICAgIGNvbnN0IGRlY29kZXIgPSBuZXcgVGV4dERlY29kZXIoXCJ1dGYtOFwiKTtcblxuICAgICAgICBsZXQgcGFydGlhbCA9IFwiXCI7XG4gICAgICAgIC8vIFRPRE8gdGhpcyBmdW5jdGlvbiBpcyByZWNyZWF0ZWQgZXZlcnkgdGltZSBuZXcgZGF0YSBjb21lcyBmcm9tIHRoZSBzdHJlYW0gLSBkZWZpbmUgaXQgb3V0c2lkZSBvZiB0aGUgZ2VuZXJhdG9yXG4gICAgICAgIGNvbnN0IHNhZmVQYXJzZSA9IChsaW5lOiBzdHJpbmcpOiB1bmtub3duID0+IHtcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgcmV0dXJuIEpTT04ucGFyc2UobGluZSk7IC8vIFBhcnNlIHRoZSBKU09OIHN0cmluZ1xuICAgICAgICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICAgICAgTG9nZ2VyLmxvZ0Vycm9yKFwiW3NwaWZmeS1haV0gRXJyb3IgcGFyc2luZyBzdHJlYW1lZCBsaW5lXCIsIGVyciwge1xuICAgICAgICAgICAgICBsaW5lLFxuICAgICAgICAgICAgICBwYXJ0aWFsLFxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAvLyBzd2FsbG93IHRoZSBlcnJvciBhbmQgc2V0IHRoZSBwYXJ0aWFsIHRvIG91ciBjdXJyZW50IGNodW5rXG4gICAgICAgICAgICBwYXJ0aWFsID0gbGluZTtcbiAgICAgICAgICAgIHJldHVybiBwYXJ0aWFsO1xuICAgICAgICAgIH1cbiAgICAgICAgfTtcblxuICAgICAgICAvLyBUT0RPIHRoaXMgZnVuY3Rpb24gaXMgcmVjcmVhdGVkIGV2ZXJ5IHRpbWUgbmV3IGRhdGEgY29tZXMgZnJvbSB0aGUgc3RyZWFtIC0gZGVmaW5lIGl0IG91dHNpZGUgb2YgdGhlIGdlbmVyYXRvclxuICAgICAgICBjb25zdCBwcm9jZXNzQ2h1bmsgPSAoY2h1bms6IHN0cmluZyk6IHVua25vd25bXSA9PiB7XG4gICAgICAgICAgLy8gbWVyZ2UgdGhlIHBhcnRpYWwgd2l0aCB0aGUgaW5jb21pbmcgY2h1bmtcbiAgICAgICAgICBjb25zdCBsaW5lcyA9IGAke3BhcnRpYWx9JHtjaHVua31gLnNwbGl0KFwiXFxuXCIpO1xuXG4gICAgICAgICAgY29uc3QgcGFyc2VkTGluZXMgPSBsaW5lc1xuICAgICAgICAgICAgLm1hcCgobGluZSkgPT4gbGluZS5yZXBsYWNlKC9eZGF0YTogLywgXCJcIikudHJpbSgpKSAvLyBSZW1vdmUgdGhlIFwiZGF0YTogXCIgcHJlZml4XG4gICAgICAgICAgICAuZmlsdGVyKChsaW5lKSA9PiBsaW5lICE9PSBcIlwiICYmIGxpbmUgIT09IFwiW0RPTkVdXCIpIC8vIFJlbW92ZSBlbXB0eSBsaW5lcyBhbmQgXCJbRE9ORV1cIlxuICAgICAgICAgICAgLm1hcChzYWZlUGFyc2UpXG4gICAgICAgICAgICAuZmlsdGVyKCh2KSA9PiB2KTsgLy8gYW5kIGZpbHRlciBvdXQgdGhlIHVuZGVmaW5lZCB2YWx1ZXNcbiAgICAgICAgICByZXR1cm4gcGFyc2VkTGluZXM7XG4gICAgICAgIH07XG5cbiAgICAgICAgd2hpbGUgKHRydWUpIHtcbiAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tYXdhaXQtaW4tbG9vcFxuICAgICAgICAgIGNvbnN0IHsgZG9uZSwgdmFsdWUgfSA9IGF3YWl0IHJlYWRlci5yZWFkKCk7XG5cbiAgICAgICAgICBpZiAoZG9uZSkge1xuICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgLy8gTWFzc2FnZSBhbmQgcGFyc2UgdGhlIGNodW5rIG9mIGRhdGFcbiAgICAgICAgICBjb25zdCBjaHVuayA9IGRlY29kZXIuZGVjb2RlKHZhbHVlKTtcbiAgICAgICAgICBjb25zdCBwYXJzZWRMaW5lcyA9IHByb2Nlc3NDaHVuayhjaHVuayk7XG5cbiAgICAgICAgICBmb3IgKGNvbnN0IHBhcnNlZExpbmUgb2YgcGFyc2VkTGluZXMpIHtcbiAgICAgICAgICAgIGNvbnN0IHZhbGlkYXRlZFJlc3BvbnNlID0gdmFsaWRhdGVSZXNwb25zZShwYXJzZWRMaW5lKTtcblxuICAgICAgICAgICAgaWYgKHZhbGlkYXRlZFJlc3BvbnNlKSB7XG4gICAgICAgICAgICAgIHlpZWxkIHZhbGlkYXRlZFJlc3BvbnNlO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfSBjYXRjaCAoZXJyb3I6IHVua25vd24pIHtcbiAgICAgICAgTG9nZ2VyLmxvZ0Vycm9yKFxuICAgICAgICAgIFwiW3NwaWZmeS1haV0gRmFpbGVkIHRvIGdldCBuZXh0IHN0cmVhbWluZyByZXNwb25zZXNcIixcbiAgICAgICAgICBlcnJvcixcbiAgICAgICAgICB7XG4gICAgICAgICAgICBwYXlsb2FkQ29udGV4dDogcGF5bG9hZD8uY29udGV4dCxcbiAgICAgICAgICAgIHVzZXJFdmVudHM6IHBheWxvYWQ/LnVzZXJFdmVudHMsXG4gICAgICAgICAgfVxuICAgICAgICApO1xuICAgICAgICBhd2FpdCB0aHJvd1Nlc3Npb25SZXN0YXJ0UmVxdWlyZWRJZihcbiAgICAgICAgICBcIkZhaWxlZCB0byBnZXQgbmV4dCBzdHJlYW1pbmcgcmVzcG9uc2VzXCIsXG4gICAgICAgICAgZXJyb3JcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBDb21tZXJjZUFwaUNsaWVudC5nZXRJbnN0YW5jZSgpLnJlc3BvbnNlc0Fib3J0Q29udHJvbGxlci5hYm9ydCgpO1xuICAgIENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkucmVzcG9uc2VzQWJvcnRDb250cm9sbGVyID1cbiAgICAgIG5ldyBBYm9ydENvbnRyb2xsZXIoKTtcblxuICAgIHJldHVybiBnZW5lcmF0ZShcbiAgICAgIENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuaW5mZXJlbmNlQXBpLFxuICAgICAgQ29tbWVyY2VBcGlDbGllbnQuZ2V0SW5zdGFuY2UoKS5yZXNwb25zZXNBYm9ydENvbnRyb2xsZXJcbiAgICApO1xuICB9O1xuXG4gIHN0YXRpYyBnZXROZXh0U3VnZ2VzdGlvbnMgPSBhc3luYyAoXG4gICAgcGF5bG9hZDogTmV4dE1lc3NhZ2VSZXF1ZXN0XG4gICk6IFByb21pc2U8U3VnZ2VzdGlvbltdPiA9PiB7XG4gICAgdHJ5IHtcbiAgICAgIENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuc3VnZ2VzdGlvbnNBYm9ydENvbnRyb2xsZXIuYWJvcnQoKTtcbiAgICAgIENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuc3VnZ2VzdGlvbnNBYm9ydENvbnRyb2xsZXIgPVxuICAgICAgICBuZXcgQWJvcnRDb250cm9sbGVyKCk7XG5cbiAgICAgIGNvbnN0IHJlc3BvbnNlID1cbiAgICAgICAgYXdhaXQgQ29tbWVyY2VBcGlDbGllbnQuZ2V0SW5zdGFuY2UoKS5pbmZlcmVuY2VBcGkudjFOZXh0U3VnZ2VzdGlvbnNQb3N0KFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIE5leHRNZXNzYWdlUmVxdWVzdDogbWVzc2FnZVJlcXVlc3RUb0NvbW1lcmNlTWVzc2FnZVJlcXVlc3QocGF5bG9hZCksXG4gICAgICAgICAgfSxcbiAgICAgICAgICB7XG4gICAgICAgICAgICBzaWduYWw6XG4gICAgICAgICAgICAgIENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuc3VnZ2VzdGlvbnNBYm9ydENvbnRyb2xsZXIuc2lnbmFsLFxuICAgICAgICAgIH1cbiAgICAgICAgKTtcblxuICAgICAgY29uc3Qgc3VnZ2VzdGlvbnMgPSByZXNwb25zZVxuICAgICAgICAubWFwKChyZXNwKSA9PiB2YWxpZGF0ZVN1Z2dlc3Rpb24ocmVzcCkpXG4gICAgICAgIC5maWx0ZXIoKHN1Z2dlc3Rpb24pOiBzdWdnZXN0aW9uIGlzIFN1Z2dlc3Rpb24gPT4gc3VnZ2VzdGlvbiAhPSBudWxsKTtcblxuICAgICAgcmV0dXJuIHN1Z2dlc3Rpb25zO1xuICAgIH0gY2F0Y2ggKGVycm9yOiB1bmtub3duKSB7XG4gICAgICBMb2dnZXIubG9nSW5mbyhcIkZhaWxlZCB0byBnZXQgc3VnZ2VzdGlvbnNcIiwgZXJyb3IsIHtcbiAgICAgICAgcGF5bG9hZENvbnRleHQ6IHBheWxvYWQ/LmNvbnRleHQsXG4gICAgICAgIHVzZXJFdmVudHM6IHBheWxvYWQ/LnVzZXJFdmVudHMsXG4gICAgICB9KTtcblxuICAgICAgYXdhaXQgdGhyb3dTZXNzaW9uUmVzdGFydFJlcXVpcmVkSWYoXCJGYWlsZWQgdG8gZ2V0IHN1Z2dlc3Rpb25zXCIsIGVycm9yKTtcbiAgICAgIHJldHVybiBbXTtcbiAgICB9XG4gIH07XG5cbiAgLyoqXG4gICAqIEZldGNoZXMgdGhlIGV4aXN0aW5nIGNoYXQgZGF0YSBmb3IgYSBnaXZlbiBzZXNzaW9uIGFuZCB0cmFuc2Zvcm1zIHRoZW0gdG8gcmVjb25zdHJ1Y3QgdGhlIGNoYXQgaGlzdG9yeS5cbiAgICpcbiAgICogQHBhcmFtIG9yZ0lkIFRoZSBvcmdhbml6YXRpb24gSWRcbiAgICogQHBhcmFtIGNoYXRJZCBUaGUgZXhpc3RpbmcgY2hhdCBJZFxuICAgKiBAcGFyYW0gdXNlcklkIFRoZSB1c2VyIElkXG4gICAqXG4gICAqIEByZXR1cm5zIEEgbGlzdCBvZiBtZXNzYWdlcyB0aGF0IHdlcmUgZXhjaGFuZ2VkIGluIHRoZSBjaGF0LCB0aHJvd3MgYW4gZXJyb3IgaWYgdGhlIGNoYXQgc2Vzc2lvbiBoYXMgZXhwaXJlZC5cbiAgICovXG4gIHN0YXRpYyBnZXRSZXNwb25zZXMgPSBhc3luYyAoXG4gICAgb3JnSWQ6IHN0cmluZyxcbiAgICBjaGF0SWQ6IHN0cmluZyxcbiAgICB1c2VySWQ6IHN0cmluZ1xuICApOiBQcm9taXNlPHtcbiAgICByZXNwb25zZXM6IEFwaVJlc3BvbnNlW11bXTtcbiAgICB1c2VyRXZlbnRzOiBVc2VyRXZlbnRbXTtcbiAgICBzdWdnZXN0aW9uczogU3VnZ2VzdGlvbltdO1xuICAgIG1lc3NhZ2VzOiBNZXNzYWdlW11bXTtcbiAgfT4gPT4ge1xuICAgIGxldCBkYXRhOiBWMUdldFNlc3Npb25NZXNzYWdlczIwMFJlc3BvbnNlID0ge1xuICAgICAgcmVzcG9uc2VzOiBbXSxcbiAgICAgIHN1Z2dlc3Rpb25zOiBbXSxcbiAgICAgIHVzZXJfZXZlbnRzOiBbXSxcbiAgICB9O1xuICAgIGNvbnN0IHJlcXVlc3QgPSB7XG4gICAgICBvcmdfaWQ6IG9yZ0lkLFxuICAgICAgY2hhdF9pZDogY2hhdElkLFxuICAgICAgdXNlcl9pZDogdXNlcklkLFxuICAgIH07XG4gICAgdHJ5IHtcbiAgICAgIGRhdGEgPVxuICAgICAgICBhd2FpdCBDb21tZXJjZUFwaUNsaWVudC5nZXRJbnN0YW5jZSgpLmRlZmF1bHRBcGkudjFHZXRTZXNzaW9uTWVzc2FnZXMoXG4gICAgICAgICAgcmVxdWVzdFxuICAgICAgICApO1xuICAgIH0gY2F0Y2ggKGVycm9yOiB1bmtub3duKSB7XG4gICAgICBhd2FpdCB0aHJvd1Nlc3Npb25SZXN0YXJ0UmVxdWlyZWRJZihcbiAgICAgICAgXCJGYWlsZWQgdG8gZ2V0IGNoYXQgcmVzcG9uc2VzXCIsXG4gICAgICAgIGVycm9yXG4gICAgICApO1xuICAgIH1cblxuICAgIGNvbnN0IHJlc3BvbnNlczogQXBpUmVzcG9uc2VbXVtdID0gZGF0YT8ucmVzcG9uc2VzPy5tYXAoKHR1cm4pID0+XG4gICAgICB0dXJuXG4gICAgICAgIC5tYXAoKHJlc3BvbnNlKSA9PiB2YWxpZGF0ZVJlc3BvbnNlKHJlc3BvbnNlKSlcbiAgICAgICAgLmZpbHRlcigocmVzcG9uc2UpOiByZXNwb25zZSBpcyBBcGlSZXNwb25zZSA9PiByZXNwb25zZSAhPSBudWxsKVxuICAgICk7XG5cbiAgICBjb25zdCBzdWdnZXN0aW9uczogU3VnZ2VzdGlvbltdID0gZGF0YT8uc3VnZ2VzdGlvbnNcbiAgICAgIC5tYXAoKHN1Z2dlc3Rpb24pID0+IHZhbGlkYXRlU3VnZ2VzdGlvbihzdWdnZXN0aW9uKSlcbiAgICAgIC5maWx0ZXIoKHN1Z2dlc3Rpb24pOiBzdWdnZXN0aW9uIGlzIFN1Z2dlc3Rpb24gPT4gc3VnZ2VzdGlvbiAhPSBudWxsKTtcblxuICAgIGNvbnN0IHVzZXJFdmVudHM6IFVzZXJFdmVudFtdID0gZGF0YT8udXNlcl9ldmVudHNcbiAgICAgIC5tYXAoKGV2ZW50KSA9PiB2YWxpZGF0ZVVzZXJFdmVudChldmVudCkpXG4gICAgICAuZmlsdGVyKChldmVudCk6IGV2ZW50IGlzIFVzZXJFdmVudCA9PiBldmVudCAhPSBudWxsKTtcblxuICAgIC8vIGlmIGEgZm9ybSBoYXMgYWxyZWFkeSBiZWVuIHN1Ym1pdHRlZCwgZG9uJ3Qgc2hvdyBpdCBpbiB0aGUgY2hhdCBoaXN0b3J5XG4gICAgY29uc3QgZm9ybVN1Ym1pdHRlZFVzZXJFdmVudHNGb3JtSWRzID0gdXNlckV2ZW50c1xuICAgICAgLmZpbHRlcigoZXZlbnQpID0+IGV2ZW50LmNhdGVnb3J5ID09PSBVc2VyRXZlbnRDYXRlZ29yeS5Gb3JtU3VibWl0dGVkKVxuICAgICAgLm1hcCgoZXZlbnQpID0+IGV2ZW50LmF0dHJpYnV0ZXMuZm9ybVJlc3BvbnNlSWQpO1xuXG4gICAgY29uc3QgYXNzaXN0YW50TWVzc2FnZXM6IE1lc3NhZ2VbXVtdID0gcmVzcG9uc2VzXG4gICAgICAubWFwKCh0dXJuKSA9PlxuICAgICAgICB0dXJuXG4gICAgICAgICAgLmZpbHRlcihcbiAgICAgICAgICAgIChyZXNwb25zZSkgPT5cbiAgICAgICAgICAgICAgIShcbiAgICAgICAgICAgICAgICByZXNwb25zZS5jYXRlZ29yeSA9PT0gUmVzcG9uc2VDYXRlZ29yeS5Gb3JtICYmXG4gICAgICAgICAgICAgICAgZm9ybVN1Ym1pdHRlZFVzZXJFdmVudHNGb3JtSWRzLmluY2x1ZGVzKHJlc3BvbnNlLmlkKVxuICAgICAgICAgICAgICApXG4gICAgICAgICAgKVxuICAgICAgICAgIC5tYXAoKHJlc3BvbnNlKSA9PiBtZXNzYWdlRnJvbVJlc3BvbnNlKHJlc3BvbnNlKSlcbiAgICAgICAgICAuZmlsdGVyKChtZXNzYWdlKTogbWVzc2FnZSBpcyBNZXNzYWdlID0+IG1lc3NhZ2UgIT0gbnVsbClcbiAgICAgIClcbiAgICAgIC5maWx0ZXIoKHR1cm4pID0+IHR1cm4ubGVuZ3RoID4gMCk7XG5cbiAgICBjb25zdCB1c2VyTWVzc2FnZXM6IE1lc3NhZ2VbXVtdID0gdXNlckV2ZW50c1xuICAgICAgLm1hcCgoZXZlbnQpID0+IHtcbiAgICAgICAgaWYgKFxuICAgICAgICAgIFtVc2VyRXZlbnRDYXRlZ29yeS5RdWVyeVR5cGVkLCBVc2VyRXZlbnRDYXRlZ29yeS5TZWFyY2hdLmluY2x1ZGVzKFxuICAgICAgICAgICAgZXZlbnQuY2F0ZWdvcnlcbiAgICAgICAgICApXG4gICAgICAgICkge1xuICAgICAgICAgIHJldHVybiBbbWVzc2FnZUZyb21RdWVyeUV2ZW50KGV2ZW50KV07XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoZXZlbnQuY2F0ZWdvcnkgPT09IFVzZXJFdmVudENhdGVnb3J5LlN1Z2dlc3Rpb25DbGlja2VkKSB7XG4gICAgICAgICAgcmV0dXJuIFttZXNzYWdlRnJvbVN1Z2dlc3Rpb25FdmVudChldmVudCwgc3VnZ2VzdGlvbnMpXTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChldmVudC5jYXRlZ29yeSA9PT0gVXNlckV2ZW50Q2F0ZWdvcnkuRm9ybVN1Ym1pdHRlZCkge1xuICAgICAgICAgIGNvbnN0IGZvcm1SZXNwb25zZSA9IHJlc3BvbnNlc1xuICAgICAgICAgICAgLmZsYXQoKVxuICAgICAgICAgICAgLmZpbmQoXG4gICAgICAgICAgICAgIChyZXNwb25zZSkgPT5cbiAgICAgICAgICAgICAgICByZXNwb25zZS5pZCA9PT0gZXZlbnQuYXR0cmlidXRlcy5mb3JtUmVzcG9uc2VJZCAmJlxuICAgICAgICAgICAgICAgIGV2ZW50LmF0dHJpYnV0ZXMuZm9ybVR5cGUgIT09IEZvcm1UeXBlLkVzY2FsYXRpb25cbiAgICAgICAgICAgICk7XG5cbiAgICAgICAgICBpZiAoZm9ybVJlc3BvbnNlICYmIGZvcm1SZXNwb25zZS5jYXRlZ29yeSA9PT0gUmVzcG9uc2VDYXRlZ29yeS5Gb3JtKSB7XG4gICAgICAgICAgICByZXR1cm4gW1xuICAgICAgICAgICAgICBtZXNzYWdlRnJvbUZvcm1TdWJtaXR0ZWRFdmVudChldmVudCwgZm9ybVJlc3BvbnNlLmF0dHJpYnV0ZXMpLFxuICAgICAgICAgICAgXTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gW107XG4gICAgICB9KVxuICAgICAgLmZpbHRlcigobWVzc2FnZSk6IG1lc3NhZ2UgaXMgTWVzc2FnZVtdID0+IG1lc3NhZ2UubGVuZ3RoID4gMCk7XG5cbiAgICAvLyBTb3J0IHRoZSBtZXNzYWdlcyBjaHJvbm9sb2dpY2FsbHkgdG8gcmVjb25zdHJ1Y3QgdGhlIGNoYXQgaGlzdG9yeVxuICAgIGNvbnN0IHNvcnRlZE1lc3NhZ2VzID0gWy4uLmFzc2lzdGFudE1lc3NhZ2VzLCAuLi51c2VyTWVzc2FnZXNdLnNvcnQoXG4gICAgICAoYSwgYikgPT5cbiAgICAgICAgbmV3IERhdGUoYVswXS5jcmVhdGVkQXQpLmdldFRpbWUoKSAtIG5ldyBEYXRlKGJbMF0uY3JlYXRlZEF0KS5nZXRUaW1lKClcbiAgICApO1xuXG4gICAgcmV0dXJuIHsgcmVzcG9uc2VzLCB1c2VyRXZlbnRzLCBzdWdnZXN0aW9ucywgbWVzc2FnZXM6IHNvcnRlZE1lc3NhZ2VzIH07XG4gIH07XG5cbiAgLyoqXG4gICAqXG4gICAqIEBwYXJhbSBwYXlsb2FkXG4gICAqIEByZXR1cm5zXG4gICAqL1xuICBzdGF0aWMgaXNTdXBwb3J0ZWRFdmVudCA9IGFzeW5jIChcbiAgICBwYXlsb2FkOiBTdXBwb3J0ZWRFdmVudFJlcXVlc3RcbiAgKTogUHJvbWlzZTxTdXBwb3J0ZWRFdmVudD4gPT4ge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCByYXdSZXNwb25zZSA9XG4gICAgICAgIGF3YWl0IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuaW5mZXJlbmNlQXBpLnYxU3VwcG9ydGVkRXZlbnRQb3N0UmF3KFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIFN1cHBvcnRlZEV2ZW50UmVxdWVzdDpcbiAgICAgICAgICAgICAgY29yZVN1cHBvcnRlZEV2ZW50UmVxdWVzdFRvQXBpUmVxdWVzdChwYXlsb2FkKSxcbiAgICAgICAgICB9XG4gICAgICAgICk7XG5cbiAgICAgIC8vIEdldCB0aGUgYWN0dWFsIEhUVFAgcmVzcG9uc2UgSlNPTlxuICAgICAgY29uc3QgaHR0cFJlc3BvbnNlVGV4dCA9IGF3YWl0IHJhd1Jlc3BvbnNlLnJhdy50ZXh0KCk7XG4gICAgICBjb25zdCBodHRwUmVzcG9uc2VKc29uID0gSlNPTi5wYXJzZShodHRwUmVzcG9uc2VUZXh0KTtcblxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgLi4uaHR0cFJlc3BvbnNlSnNvbixcbiAgICAgICAgbnVtYmVyT2ZSZXZpZXdzOiBodHRwUmVzcG9uc2VKc29uLm51bV9vZl9yZXZpZXdzLFxuICAgICAgICBtZXJjaGFudF90YWdzOiBodHRwUmVzcG9uc2VKc29uLm1lcmNoYW50X3RhZ3MgfHwgW10sXG4gICAgICB9O1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgTG9nZ2VyLmxvZ0Vycm9yKFwiRmFpbGVkIHRvIGdldCByZXNwb25zZSBmb3IgdjFTdXBwb3J0ZWRFdmVudFBvc3RcIiwge1xuICAgICAgICBlcnIsXG4gICAgICB9KTtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHN1cHBvcnRlZDogZmFsc2UsXG4gICAgICAgIHJlYWR5OiBmYWxzZSxcbiAgICAgICAgY2F0ZWdvcnk6IHVuZGVmaW5lZCxcbiAgICAgICAgY29sbGVjdGlvbnM6IFtdLFxuICAgICAgICBudW1iZXJPZlJldmlld3M6IHVuZGVmaW5lZCxcbiAgICAgICAgdG9wX2NhdGVnb3J5OiB1bmRlZmluZWQsXG4gICAgICAgIG1lcmNoYW50X3RhZ3M6IFtdLFxuICAgICAgfTtcbiAgICB9XG4gIH07XG5cbiAgc3RhdGljIGlkZW50aWZ5VXNlciA9IGFzeW5jIChcbiAgICBzcGlmZnlVc2VySWQ6IHN0cmluZyxcbiAgICBtZXJjaGFudFVzZXJJZDogc3RyaW5nLFxuICAgIHVhRGV0YWlsczogQ2xpZW50RGV0YWlsc1xuICApOiBQcm9taXNlPHZvaWQ+ID0+IHtcbiAgICB0cnkge1xuICAgICAgYXdhaXQgQ29tbWVyY2VBcGlDbGllbnQuZ2V0SW5zdGFuY2UoKS5kZWZhdWx0QXBpLnYxQW5hbHl0aWNzSWRlbnRpZnlQb3N0KHtcbiAgICAgICAgQW5hbHl0aWNzSWRlbnRpZnlSZXF1ZXN0OiB7XG4gICAgICAgICAgdXNlcl9pZDogc3BpZmZ5VXNlcklkLFxuICAgICAgICAgIG9zX25hbWU6IHVhRGV0YWlscy5vcyxcbiAgICAgICAgICBvc192ZXJzaW9uOiB1YURldGFpbHMub3NWZXJzaW9uLFxuICAgICAgICAgIHBsYXRmb3JtOiB1YURldGFpbHMub3MsXG4gICAgICAgICAgZGV2aWNlX2lkOiB1YURldGFpbHMuZGV2aWNlTW9kZWwsXG4gICAgICAgICAgZGV2aWNlX2JyYW5kOiB1YURldGFpbHMuZGV2aWNlQnJhbmQsXG4gICAgICAgICAgZGV2aWNlX21hbnVmYWN0dXJlcjogdWFEZXRhaWxzLmRldmljZU1hbnVmYWN0dXJlcixcbiAgICAgICAgICBkZXZpY2VfbW9kZWw6IHVhRGV0YWlscy5kZXZpY2VNb2RlbCxcbiAgICAgICAgICB1c2VyX3Byb3BlcnRpZXM6IHtcbiAgICAgICAgICAgIGNkcF91c2VyX2lkOiBtZXJjaGFudFVzZXJJZCxcbiAgICAgICAgICAgIGJyb3dzZXI6IHVhRGV0YWlscy5icm93c2VyLFxuICAgICAgICAgICAgYnJvd3Nlcl92ZXJzaW9uOiB1YURldGFpbHMuYnJvd3NlclZlcnNpb24sXG4gICAgICAgICAgICB1c2VyX2FnZW50OiB1YURldGFpbHMudXNlckFnZW50LFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICB9KTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIExvZ2dlci5sb2dFcnJvcihcIkZhaWxlZCB0byBpZGVudGlmeSB1c2VyXCIsIGVycik7XG4gICAgfVxuICB9O1xuXG4gIHByaXZhdGUgc3RhdGljIG1hcENvbnRleHRTb3VyY2VUb1YxT3JnQ29uZmlnR2V0U291cmNlID0gKFxuICAgIHNvdXJjZTogQ29udGV4dFNvdXJjZUVudW0gfCB1bmRlZmluZWRcbiAgKTogVjFPcmdDb25maWdHZXRTb3VyY2VFbnVtIHwgdW5kZWZpbmVkID0+IHtcbiAgICBpZiAoc291cmNlID09PSB1bmRlZmluZWQpIHJldHVybiB1bmRlZmluZWQ7XG4gICAgc3dpdGNoIChzb3VyY2UpIHtcbiAgICAgIGNhc2UgQ29udGV4dFNvdXJjZUVudW0uRm9yazpcbiAgICAgICAgcmV0dXJuIFYxT3JnQ29uZmlnR2V0U291cmNlRW51bS5Gb3JrO1xuICAgICAgY2FzZSBDb250ZXh0U291cmNlRW51bS5QbGF5Z3JvdW5kOlxuICAgICAgICByZXR1cm4gVjFPcmdDb25maWdHZXRTb3VyY2VFbnVtLlBsYXlncm91bmQ7XG4gICAgICBjYXNlIENvbnRleHRTb3VyY2VFbnVtLkFwcDpcbiAgICAgICAgcmV0dXJuIFYxT3JnQ29uZmlnR2V0U291cmNlRW51bS5BcHA7XG4gICAgICBjYXNlIENvbnRleHRTb3VyY2VFbnVtLlRlc3Q6XG4gICAgICAgIHJldHVybiBWMU9yZ0NvbmZpZ0dldFNvdXJjZUVudW0uVGVzdDtcbiAgICAgIGRlZmF1bHQ6IHtcbiAgICAgICAgLy8gVGhpcyBlbnN1cmVzIHRoYXQgaWYgbmV3IHZhbHVlcyBhcmUgYWRkZWQgdG8gQ29udGV4dFNvdXJjZUVudW0sIHdlIGNhdGNoIGl0XG4gICAgICAgIGNvbnN0IGV4aGF1c3RpdmVDaGVjazogbmV2ZXIgPSBzb3VyY2U7XG4gICAgICAgIHJldHVybiBleGhhdXN0aXZlQ2hlY2s7XG4gICAgICB9XG4gICAgfVxuICB9O1xuXG4gIHN0YXRpYyBnZXRPcmdDb25maWcgPSBhc3luYyAoXG4gICAgdXNlcl9pZDogc3RyaW5nXG4gICk6IFByb21pc2U8T3JnQ29uZmlnIHwgdW5kZWZpbmVkPiA9PiB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IGF0b21TdG9yZSA9IGdldEF0b21TdG9yZSgpO1xuICAgICAgY29uc3QgcmVhY3RBcHBOYW1lID0gYXRvbVN0b3JlLmdldChyZWFjdEFwcE5hbWVBdG9tKTtcbiAgICAgIGNvbnN0IGNvbnRleHRTb3VyY2UgPSBhdG9tU3RvcmUuZ2V0KGNvbnRleHRTb3VyY2VBdG9tKTtcbiAgICAgIGNvbnN0IGZlYXR1cmVGbGFnU2VydmljZSA9IGF0b21TdG9yZS5nZXQoZmVhdHVyZUZsYWdTZXJ2aWNlQXRvbSk7IC8vIEdldCBmZWF0dXJlRmxhZ1NlcnZpY2VcbiAgICAgIGNvbnN0IHJlcXVlc3Q6IFYxT3JnQ29uZmlnR2V0UmVxdWVzdCA9IHtcbiAgICAgICAgbmFtZXNwYWNlOiByZWFjdEFwcE5hbWUsXG4gICAgICAgIHVzZXJfaWQsXG4gICAgICAgIHNvdXJjZTogdGhpcy5tYXBDb250ZXh0U291cmNlVG9WMU9yZ0NvbmZpZ0dldFNvdXJjZShjb250ZXh0U291cmNlKSxcbiAgICAgICAgaW5jbHVkZV9leHBlcmltZW50czogT2JqZWN0LnZhbHVlcyhQcm9kdWN0RXhwZXJpbWVudCksXG4gICAgICAgIGluY2x1ZGVfZmVhdHVyZV9nYXRlczogT2JqZWN0LmVudHJpZXMoXG4gICAgICAgICAgZmVhdHVyZUZsYWdTZXJ2aWNlPy5mZWF0dXJlRmxhZ1NlcnZpY2U/LmdldEZlYXR1cmVGbGFncygpIHx8IHt9XG4gICAgICAgIClcbiAgICAgICAgICAuZmlsdGVyKChbLCBpc0VuYWJsZWRdKSA9PiBpc0VuYWJsZWQpXG4gICAgICAgICAgLm1hcCgoW2ZlYXR1cmVHYXRlTmFtZV0pID0+IGZlYXR1cmVHYXRlTmFtZSksIC8vIFVzZSBmZWF0dXJlRmxhZ1NlcnZpY2VcbiAgICAgIH07XG4gICAgICBjb25zdCByZXNwb25zZSA9XG4gICAgICAgIGF3YWl0IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuZGVmYXVsdEFwaS52MU9yZ0NvbmZpZ0dldChcbiAgICAgICAgICByZXF1ZXN0XG4gICAgICAgICk7XG5cbiAgICAgIHJldHVybiB2YWxpZGF0ZU9yZ0NvbmZpZ1Jlc3VsdHMocmVzcG9uc2UpO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgTG9nZ2VyLmxvZ0Vycm9yKGBGYWlsZWQgdG8gZ2V0IG9yZyBjb25maWdgLCBlcnIsIHsgZXJyIH0pO1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG4gIH07XG5cbiAgc3RhdGljIGFkZE5vdGVUb0xhdGVzdENvbnZlcnNhdGlvbiA9IGFzeW5jIChcbiAgICBzcGlmZnlVc2VySWQ6IHN0cmluZyxcbiAgICBlbWFpbDogc3RyaW5nLFxuICAgIGN1c3RvbWVyU2VydmljZVByb3ZpZGVyOiBDdXN0b21lclNlcnZpY2VQcm92aWRlclxuICApID0+IHtcbiAgICBMb2dnZXIubG9nSW5mbyhcbiAgICAgIGBhZGROb3RlVG9MYXRlc3RDb252ZXJzYXRpb24gLSB1c2VyX2lkPSR7c3BpZmZ5VXNlcklkfSBlbWFpbD0ke2VtYWlsfSBjdXN0b21lcl9zZXJ2aWNlX3Byb3ZpZGVyPSR7Y3VzdG9tZXJTZXJ2aWNlUHJvdmlkZXJ9YFxuICAgICk7XG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IENvbW1lcmNlQXBpQ2xpZW50LmdldEluc3RhbmNlKCkuY3VzdG9tZXJTZXJ2aWNlQXBpLnYxQ3VzdHNlcnZpY2VBZGROb3RlVG9MYXRlc3RDb252ZXJzYXRpb25Qb3N0KFxuICAgICAgICB7XG4gICAgICAgICAgQWRkTm90ZVRvTGF0ZXN0Q29udmVyc2F0aW9uUmVxdWVzdDoge1xuICAgICAgICAgICAgc3BpZmZ5X3VzZXJfaWQ6IHNwaWZmeVVzZXJJZCxcbiAgICAgICAgICAgIGVtYWlsLFxuICAgICAgICAgICAgY3VzdG9tZXJfc2VydmljZV9wcm92aWRlcjogY3VzdG9tZXJTZXJ2aWNlUHJvdmlkZXIsXG4gICAgICAgICAgfSxcbiAgICAgICAgfVxuICAgICAgKTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIExvZ2dlci5sb2dFcnJvcihcIkZhaWxlZCB0byBhZGQgbm90ZSB0byBsYXRlc3QgY29udmVyc2F0aW9uXCIsIHsgZXJyIH0pO1xuICAgIH1cbiAgfTtcblxuICBzdGF0aWMgZ2V0Q3VzdG9tZXJTZXJ2aWNlQXBpID0gKCkgPT5cbiAgICBDb21tZXJjZUFwaUNsaWVudC5nZXRJbnN0YW5jZSgpLmN1c3RvbWVyU2VydmljZUFwaTtcbn1cblxuZXhwb3J0IGRlZmF1bHQgQ29tbWVyY2VBcGlDbGllbnQ7XG4iLCJpbXBvcnQgUmVhY3QsIHsgY3JlYXRlQ29udGV4dCwgdXNlQ2FsbGJhY2ssIHVzZUNvbnRleHQsIHVzZU1lbW8sIHVzZVN0YXRlLCB1c2VFZmZlY3QgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgVUFQYXJzZXIgZnJvbSAndWEtcGFyc2VyLWpzJztcbmltcG9ydCB7IENsaWVudERldGFpbHMsIFVzZXJJZGVudGl0eUNvbnRleHRUeXBlIH0gZnJvbSAnQGVudml2ZS1haS90eXBlcyc7XG5pbXBvcnQgTG9nZ2VyIGZyb20gJy4uLy4uL2FwcGxpY2F0aW9uL2xvZ2dpbmcvbG9nZ2VyJztcbmltcG9ydCBDb21tZXJjZUFwaUNsaWVudCBmcm9tICcuLi8uLi9hcHBsaWNhdGlvbi9jb21tZXJjZS1hcGknO1xuaW1wb3J0IHsgdXNlTG9jYWxTdG9yYWdlIH0gZnJvbSAnLi4vbG9jYWxTdG9yYWdlQ29udGV4dCc7XG5pbXBvcnQgeyB2NCBhcyB1dWlkIH0gZnJvbSAndXVpZCc7XG5cbi8vIEhlbHBlciBmdW5jdGlvbiBmcm9tIHRoZSBvcmlnaW5hbCBzZXJ2aWNlXG5jb25zdCBnZXRVc2VyQWdlbnREZXRhaWxzID0gKCk6IENsaWVudERldGFpbHMgPT4ge1xuICBjb25zdCB1YVBhcnNlciA9IG5ldyBVQVBhcnNlcigpO1xuICBjb25zdCByZXN1bHQgPSB1YVBhcnNlci5nZXRSZXN1bHQoKTtcblxuICByZXR1cm4ge1xuICAgIG9zOiByZXN1bHQ/Lm9zPy5uYW1lLFxuICAgIG9zVmVyc2lvbjogcmVzdWx0Py5vcz8udmVyc2lvbixcbiAgICBkZXZpY2VCcmFuZDogcmVzdWx0Py5kZXZpY2U/LnZlbmRvcixcbiAgICBkZXZpY2VNYW51ZmFjdHVyZXI6IHJlc3VsdD8uZGV2aWNlPy52ZW5kb3IsXG4gICAgZGV2aWNlTW9kZWw6IHJlc3VsdD8uZGV2aWNlPy5tb2RlbCxcbiAgICBicm93c2VyOiByZXN1bHQ/LmJyb3dzZXI/Lm5hbWUsXG4gICAgYnJvd3NlclZlcnNpb246IHJlc3VsdD8uYnJvd3Nlcj8udmVyc2lvbixcbiAgICB1c2VyQWdlbnQ6IHJlc3VsdD8udWEsXG4gIH07XG59O1xuXG5jb25zdCBVc2VySWRlbnRpdHlDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcblxuZXhwb3J0IGNvbnN0IFVzZXJJZGVudGl0eVByb3ZpZGVyOiBSZWFjdC5GQzx7IGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGUgfT4gPSAoeyBjaGlsZHJlbiB9KSA9PiB7XG4gIGNvbnN0IHsgZ2V0SXRlbSwgc2V0SXRlbSwgaXNBdmFpbGFibGU6IGxvY2FsU3RvcmFnZUlzUmVhZHkgfSA9IHVzZUxvY2FsU3RvcmFnZSgpO1xuXG4gIGNvbnN0IFtpc1JlYWR5LCBzZXRJc1JlYWR5XSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIC8vIEFzc3VtaW5nIENvbW1lcmNlQXBpQ2xpZW50IGFuZCBvdGhlciBkZXBlbmRlbmNpZXMgYXJlIHJlYWR5IGlmIGxvY2FsU3RvcmFnZSBpcy5cbiAgICAvLyBJbiBhIG1vcmUgY29tcGxleCBzY2VuYXJpbywgeW91IG1pZ2h0IGhhdmUgbW9yZSBjaGVja3MgaGVyZS5cbiAgICBzZXRJc1JlYWR5KGxvY2FsU3RvcmFnZUlzUmVhZHkpO1xuICB9LCBbbG9jYWxTdG9yYWdlSXNSZWFkeV0pO1xuXG4gIGNvbnN0IFVTRVJfSURfT1ZFUlJJREVfS0VZID0gJ3YxLXNwaWZmeS11c2VyLWlkLW92ZXJyaWRlJztcbiAgY29uc3QgVVNFUl9JRF9ERUZBVUxUX0tFWSA9ICd2MS1zcGlmZnktdXNlci1pZC1kZWZhdWx0JztcblxuICBjb25zdCBnZXRVc2VySWRPdmVycmlkZUZyb21Mb2NhbFN0b3JhZ2UgPSB1c2VDYWxsYmFjayhcbiAgICAoKTogc3RyaW5nIHwgdW5kZWZpbmVkID0+IGdldEl0ZW0oVVNFUl9JRF9PVkVSUklERV9LRVkpID8/IHVuZGVmaW5lZCxcbiAgICBbZ2V0SXRlbV0sXG4gICk7XG5cbiAgY29uc3QgZ2V0VXNlcklkRGVmYXVsdEZyb21Mb2NhbFN0b3JhZ2UgPSB1c2VDYWxsYmFjayhcbiAgICAoKTogc3RyaW5nIHwgdW5kZWZpbmVkID0+IGdldEl0ZW0oVVNFUl9JRF9ERUZBVUxUX0tFWSkgPz8gdW5kZWZpbmVkLFxuICAgIFtnZXRJdGVtXSxcbiAgKTtcblxuICBjb25zdCBzZXRVc2VySWREZWZhdWx0SW5Mb2NhbFN0b3JhZ2UgPSB1c2VDYWxsYmFjayhcbiAgICAodXNlcklkOiBzdHJpbmcpOiBzdHJpbmcgPT4ge1xuICAgICAgTG9nZ2VyLmxvZ0luZm8oYHNldFVzZXJJZERlZmF1bHRJbkxvY2FsU3RvcmFnZSAtIFNldHRpbmcgdXNlcl9pZD0ke3VzZXJJZH1gKTtcbiAgICAgIHNldEl0ZW0oVVNFUl9JRF9ERUZBVUxUX0tFWSwgdXNlcklkKTtcbiAgICAgIC8vIHdpbmRvdy5kaXNwYXRjaEV2ZW50IGlzIGhhbmRsZWQgYnkgdXNlTG9jYWxTdG9yYWdlIG5vd1xuICAgICAgcmV0dXJuIHVzZXJJZDtcbiAgICB9LFxuICAgIFtzZXRJdGVtLCBVU0VSX0lEX0RFRkFVTFRfS0VZXSxcbiAgKTtcblxuICBjb25zdCBzZXRVc2VySWRPdmVycmlkZUluTG9jYWxTdG9yYWdlID0gdXNlQ2FsbGJhY2soXG4gICAgKHVzZXJJZDogc3RyaW5nKTogc3RyaW5nID0+IHtcbiAgICAgIExvZ2dlci5sb2dJbmZvKGBzZXRVc2VySWRPdmVycmlkZUluTG9jYWxTdG9yYWdlIC0gU2V0dGluZyB1c2VyX2lkPSR7dXNlcklkfWApO1xuICAgICAgc2V0SXRlbShVU0VSX0lEX09WRVJSSURFX0tFWSwgdXNlcklkKTtcbiAgICAgIC8vIHdpbmRvdy5kaXNwYXRjaEV2ZW50IGlzIGhhbmRsZWQgYnkgdXNlTG9jYWxTdG9yYWdlIG5vd1xuICAgICAgcmV0dXJuIHVzZXJJZDtcbiAgICB9LFxuICAgIFtzZXRJdGVtLCBVU0VSX0lEX09WRVJSSURFX0tFWV0sXG4gICk7XG5cbiAgY29uc3QgY2xlYXJVc2VySWRPdmVycmlkZUluTG9jYWxTdG9yYWdlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIExvZ2dlci5sb2dJbmZvKGBjbGVhclVzZXJJZE92ZXJyaWRlSW5Mb2NhbFN0b3JhZ2UgLSBDbGVhcmluZyB1c2VyX2lkYCk7XG4gICAgLy8gTG9jYWxTdG9yYWdlU2VydmljZS5nZXRMb2NhbFN0b3JhZ2UoKT8ucmVtb3ZlSXRlbShVU0VSX0lEX09WRVJSSURFX0tFWSk7XG4gICAgLy8gd2luZG93LmRpc3BhdGNoRXZlbnQgaXMgaGFuZGxlZCBieSB1c2VMb2NhbFN0b3JhZ2Ugbm93XG4gICAgc2V0SXRlbShVU0VSX0lEX09WRVJSSURFX0tFWSwgJycpOyAvLyBTZXQgdG8gZW1wdHkgc3RyaW5nIHRvIGNsZWFyXG4gIH0sIFtzZXRJdGVtLCBVU0VSX0lEX09WRVJSSURFX0tFWV0pO1xuXG4gIGNvbnN0IGdldFVzZXJJZE9yRGVmYXVsdCA9IHVzZUNhbGxiYWNrKCgpOiBzdHJpbmcgPT4ge1xuICAgIGNvbnN0IHVzZXJJZE92ZXJyaWRlID0gZ2V0VXNlcklkT3ZlcnJpZGVGcm9tTG9jYWxTdG9yYWdlKCk7XG4gICAgaWYgKHVzZXJJZE92ZXJyaWRlKSB7XG4gICAgICByZXR1cm4gdXNlcklkT3ZlcnJpZGU7XG4gICAgfVxuXG4gICAgY29uc3QgZGVmYXVsdFVzZXJJZCA9IGdldFVzZXJJZERlZmF1bHRGcm9tTG9jYWxTdG9yYWdlKCk7XG4gICAgaWYgKGRlZmF1bHRVc2VySWQpIHtcbiAgICAgIHJldHVybiBkZWZhdWx0VXNlcklkO1xuICAgIH1cblxuICAgIHJldHVybiBzZXRVc2VySWREZWZhdWx0SW5Mb2NhbFN0b3JhZ2UoYHNwaWZmeS11c2VyLWlkLSR7dXVpZCgpfWApO1xuICB9LCBbXG4gICAgZ2V0VXNlcklkT3ZlcnJpZGVGcm9tTG9jYWxTdG9yYWdlLFxuICAgIGdldFVzZXJJZERlZmF1bHRGcm9tTG9jYWxTdG9yYWdlLFxuICAgIHNldFVzZXJJZERlZmF1bHRJbkxvY2FsU3RvcmFnZSxcbiAgXSk7XG5cbiAgY29uc3QgaWRlbnRpZnlVc2VyID0gdXNlQ2FsbGJhY2soYXN5bmMgKCk6IFByb21pc2U8dm9pZD4gPT4ge1xuICAgIGlmICghaXNSZWFkeSkge1xuICAgICAgTG9nZ2VyLmxvZ1dhcm4oJ1tVc2VySWRlbnRpdHlDb250ZXh0XSBDb250ZXh0IG5vdCByZWFkeSwgc2tpcHBpbmcgaWRlbnRpZnlVc2VyJywgdW5kZWZpbmVkKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0cnkge1xuICAgICAgLy8gVGVtcG9yYXJpbHkgY29tbWVudGVkIG91dCB1bnRpbCBXaW5kb3dEYXRhTGF5ZXJTZXJ2aWNlIGlzIHJlc29sdmVkXG4gICAgICAvLyBjb25zdCBjZHBVc2VySWQgPSBXaW5kb3dEYXRhTGF5ZXJTZXJ2aWNlLmdldEdvb2dsZUFuYWx5dGljc0NsaWVudElkKCk7XG4gICAgICBjb25zdCBjZHBVc2VySWQgPSAnVU5LTk9XTl9DRFBfVVNFUl9JRCc7IC8vIFBsYWNlaG9sZGVyXG4gICAgICBjb25zdCB1c2VySWQgPSBnZXRVc2VySWRPckRlZmF1bHQoKTtcbiAgICAgIGNvbnN0IHVzZXJBZ2VudERldGFpbHMgPSBnZXRVc2VyQWdlbnREZXRhaWxzKCk7XG5cbiAgICAgIGlmICghY2RwVXNlcklkKSB7XG4gICAgICAgIExvZ2dlci5sb2dXYXJuKCdbc3BpZmZ5LWFpXSBObyBHQSBDbGllbnQgSUQgZm91bmQsIHNraXBwaW5nIGlkZW50aWZ5VXNlcicsIHVuZGVmaW5lZCk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgYXdhaXQgQ29tbWVyY2VBcGlDbGllbnQuaWRlbnRpZnlVc2VyKHVzZXJJZCwgY2RwVXNlcklkLCB1c2VyQWdlbnREZXRhaWxzKTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgTG9nZ2VyLmxvZ0Vycm9yKCdbc3BpZmZ5LWFpXSBFcnJvciBpZGVudGlmeWluZyB1c2VyJywgZXJyb3IpO1xuICAgIH1cbiAgfSwgW2lzUmVhZHksIGdldFVzZXJJZE9yRGVmYXVsdF0pO1xuXG4gIGNvbnN0IHZhbHVlID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgaWRlbnRpZnlVc2VyLFxuICAgICAgZ2V0VXNlcklkT3JEZWZhdWx0LFxuICAgICAgZ2V0VXNlcklkT3ZlcnJpZGVGcm9tTG9jYWxTdG9yYWdlLFxuICAgICAgZ2V0VXNlcklkRGVmYXVsdEZyb21Mb2NhbFN0b3JhZ2UsXG4gICAgICBzZXRVc2VySWREZWZhdWx0SW5Mb2NhbFN0b3JhZ2UsXG4gICAgICBzZXRVc2VySWRPdmVycmlkZUluTG9jYWxTdG9yYWdlLFxuICAgICAgY2xlYXJVc2VySWRPdmVycmlkZUluTG9jYWxTdG9yYWdlLFxuICAgICAgaXNSZWFkeSxcbiAgICB9KSxcbiAgICBbXG4gICAgICBpZGVudGlmeVVzZXIsXG4gICAgICBnZXRVc2VySWRPckRlZmF1bHQsXG4gICAgICBnZXRVc2VySWRPdmVycmlkZUZyb21Mb2NhbFN0b3JhZ2UsXG4gICAgICBnZXRVc2VySWREZWZhdWx0RnJvbUxvY2FsU3RvcmFnZSxcbiAgICAgIHNldFVzZXJJZERlZmF1bHRJbkxvY2FsU3RvcmFnZSxcbiAgICAgIHNldFVzZXJJZE92ZXJyaWRlSW5Mb2NhbFN0b3JhZ2UsXG4gICAgICBjbGVhclVzZXJJZE92ZXJyaWRlSW5Mb2NhbFN0b3JhZ2UsXG4gICAgICBpc1JlYWR5LFxuICAgIF0sXG4gICk7XG5cbiAgcmV0dXJuIDxVc2VySWRlbnRpdHlDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXt2YWx1ZX0+e2NoaWxkcmVufTwvVXNlcklkZW50aXR5Q29udGV4dC5Qcm92aWRlcj47XG59O1xuXG5leHBvcnQgY29uc3QgdXNlVXNlcklkZW50aXR5ID0gKCkgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChVc2VySWRlbnRpdHlDb250ZXh0KTtcbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCd1c2VVc2VySWRlbnRpdHkgbXVzdCBiZSB1c2VkIHdpdGhpbiBhIFVzZXJJZGVudGl0eVByb3ZpZGVyJyk7XG4gIH1cbiAgcmV0dXJuIGNvbnRleHQ7XG59O1xuIiwiaW1wb3J0IHsgYXRvbVdpdGhTdG9yYWdlIH0gZnJvbSAnam90YWkvdXRpbHMnO1xuaW1wb3J0IHsgYXRvbSB9IGZyb20gJ2pvdGFpJztcbmltcG9ydCB7IFN1cHBvcnRlZEV2ZW50UmVzcG9uc2UsIFBhZ2VWaXNpdENhdGVnb3J5IH0gZnJvbSAnQHNwaWZmeS1haS9jb21tZXJjZS1hcGktY2xpZW50JztcbmltcG9ydCB7XG4gIFBhZ2VWaXNpdFZhcmlhbnRJbmZvLFxuICBQRFBWYXJpYW50SW5mbyxcbiAgUExQVmFyaWFudEluZm8sXG4gIFZhcmlhbnRJbmZvLFxuICBWYXJpYW50VHlwZUVudW0sXG59IGZyb20gJ0BlbnZpdmUtYWkvdHlwZXMnO1xuaW1wb3J0IHsgc2Vzc2lvblN0b3JhZ2VVdGlsIH0gZnJvbSAnc3JjL2F0b21zL2F0b21TdG9yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3VwcG9ydGVkRXZlbnRcbiAgZXh0ZW5kcyBQaWNrPFxuICAgIFN1cHBvcnRlZEV2ZW50UmVzcG9uc2UsXG4gICAgJ3N1cHBvcnRlZCcgfCAncmVhZHknIHwgJ2NhdGVnb3J5JyB8ICdjb2xsZWN0aW9ucycgfCAndG9wX2NhdGVnb3J5J1xuICA+IHtcbiAgbnVtYmVyT2ZSZXZpZXdzOiBudW1iZXIgfCB1bmRlZmluZWQ7XG4gIG1lcmNoYW50X3RhZ3M/OiBzdHJpbmdbXTtcbn1cblxuaW50ZXJmYWNlIFBEUEF0dHJpYnV0ZXMge1xuICBwcm9kdWN0X2lkPzogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgUExQQXR0cmlidXRlcyB7XG4gIGF0dHJpYnV0ZXM/OiB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXJsUmVzb2x2aW5nUERQQ29uZmlnIHtcbiAgcGRwX2F0dHJpYnV0ZXM6IFBEUEF0dHJpYnV0ZXM7XG4gIG51bWJlcl9vZl9yZXZpZXdzPzogbnVtYmVyO1xuICBjb2xsZWN0aW9ucz86IHN0cmluZ1tdO1xuICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXJsUmVzb2x2aW5nUExQQ29uZmlnIHtcbiAgcGxwX2F0dHJpYnV0ZXM6IFBMUEF0dHJpYnV0ZXM7XG4gIHRvcF9jYXRlZ29yeT86IHN0cmluZztcbn1cblxuaW50ZXJmYWNlIFVybFJlc29sdmluZ0dlbmVyaWNDb25maWcge1xuICBkZXRhaWxzPzogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBQYWdlVmFyaWFudENoZWNrQ29uZmlnID0ge1xuICBjaGVja190eXBlOiBzdHJpbmc7XG4gIGZlYXR1cmVfZ2F0ZT86IHN0cmluZztcbiAgZXh0cmFjdG9yPzoge1xuICAgIHR5cGU6IHN0cmluZztcbiAgICBtYXA/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmdbXT47XG4gICAgdmFsdWU/OiBzdHJpbmc7XG4gIH07XG4gIHByb2R1Y3RfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xuICBwcm9kdWN0X2lkcz86IHN0cmluZ1tdO1xuICBwbHBfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xuICBwbHBfaWRzPzogc3RyaW5nW107XG4gIGNvbGxlY3Rpb25zPzogc3RyaW5nW107XG4gIHF1ZXJ5X3BhcmFtPzogc3RyaW5nO1xuICBjYXRlZ29yeT86IHN0cmluZztcbiAgdG9wX2NhdGVnb3J5Pzogc3RyaW5nW107XG4gIHJldmlld19taW5pbXVtPzogbnVtYmVyO1xuICBtZXJjaGFudF90YWdzPzogc3RyaW5nW107XG59O1xuXG5leHBvcnQgdHlwZSBCYWNrZW5kV2lkZ2V0TW91bnRpbmdDb25maWcgPSB7XG4gIG1vdW50aW5nX2NvbmZpZ19pZDogc3RyaW5nO1xuICB3aWRnZXRfY29uZmlnX2lkPzogc3RyaW5nO1xuICBtb3VudGluZ19wb2ludF93aWRnZXRzPzogQXJyYXk8e1xuICAgIGNoZWNrczogUGFnZVZhcmlhbnRDaGVja0NvbmZpZ1tdO1xuICAgIHdpZGdldF9jb25maWdfaWQ6IHN0cmluZztcbiAgfT47XG59O1xuXG5leHBvcnQgdHlwZSBCYWNrZW5kUGFnZVZhcmlhbnRDb25maWcgPSB7XG4gIHZhcmlhbnRfaWQ6IHN0cmluZztcbiAgdmFyaWFudF90eXBlOiBzdHJpbmc7XG4gIHZhcmlhbnRfY2hlY2tzOiBQYWdlVmFyaWFudENoZWNrQ29uZmlnW107XG4gIHdpZGdldF9tb3VudGluZzogQmFja2VuZFdpZGdldE1vdW50aW5nQ29uZmlnW107XG4gIHBscF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG4gIHByb2R1Y3RfaWRfZXh0cmFjdG9yPzogc3RyaW5nO1xuICBwYXJlbnRfcHJvZHVjdF9pZF9leHRyYWN0b3I/OiBzdHJpbmc7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIFVybFJlc29sdmVyUmVzcG9uc2Uge1xuICB2YXJpYW50X3R5cGU6IHN0cmluZztcbiAgc3BlY2lmaWNfZGV0YWlsczogVXJsUmVzb2x2aW5nUERQQ29uZmlnIHwgVXJsUmVzb2x2aW5nUExQQ29uZmlnIHwgVXJsUmVzb2x2aW5nR2VuZXJpY0NvbmZpZztcbiAgcmVhZHk6IGJvb2xlYW47XG4gIHVzZXJfZXZlbnQ/OiB7XG4gICAgZXZlbnRfaWQ/OiBzdHJpbmc7XG4gICAgYXR0cmlidXRlcz86IFBEUEF0dHJpYnV0ZXMgfCBQTFBBdHRyaWJ1dGVzO1xuICAgIGNhdGVnb3J5Pzogc3RyaW5nO1xuICAgIGNyZWF0ZWRfYXQ/OiBzdHJpbmc7XG4gIH07XG4gIHBhZ2VfdmFyaWFudD86IEJhY2tlbmRQYWdlVmFyaWFudENvbmZpZztcbn1cblxuLy8gVXNlIGEgbWFwIGZvciBwZXItVVJMIGNhY2hlXG5leHBvcnQgdHlwZSBVcmxSZXNvbHZlckNhY2hlID0gUmVjb3JkPHN0cmluZywgVXJsUmVzb2x2ZXJSZXNwb25zZSB8IHVuZGVmaW5lZD47XG5cbmNvbnN0IGludGVybmFsU3RvcmFnZVVybFJlc29sdmVyQXRvbSA9IGF0b21XaXRoU3RvcmFnZTxzdHJpbmcgfCB1bmRlZmluZWQ+KFxuICAnc3BpZmZ5LXVybC1yZXNvbHZlcicsXG4gIHVuZGVmaW5lZCxcbiAgc2Vzc2lvblN0b3JhZ2VVdGlsLFxuICB7XG4gICAgZ2V0T25Jbml0OiB0cnVlLFxuICB9LFxuKTtcblxuZXhwb3J0IGNvbnN0IHVybFJlc29sdmVyQXRvbSA9IGF0b20oXG4gIChnZXQpOiBVcmxSZXNvbHZlckNhY2hlID0+IHtcbiAgICBjb25zdCBtYXliZVVybFJlc29sdmVyID0gZ2V0KGludGVybmFsU3RvcmFnZVVybFJlc29sdmVyQXRvbSk7XG4gICAgaWYgKG1heWJlVXJsUmVzb2x2ZXIgPT0gbnVsbCkge1xuICAgICAgcmV0dXJuIHt9O1xuICAgIH1cbiAgICByZXR1cm4gSlNPTi5wYXJzZShtYXliZVVybFJlc29sdmVyKTtcbiAgfSxcbiAgKGdldCwgc2V0LCB2YWx1ZTogeyB1cmw6IHN0cmluZzsgcmVzcG9uc2U6IFVybFJlc29sdmVyUmVzcG9uc2UgfCB1bmRlZmluZWQgfSkgPT4ge1xuICAgIC8vIEdldCBjdXJyZW50IGNhY2hlIGZyb20gc3RvcmFnZVxuICAgIGNvbnN0IGN1cnJlbnRDYWNoZSA9IGdldCh1cmxSZXNvbHZlckF0b20pO1xuICAgIGNvbnN0IG5ld0NhY2hlID0geyAuLi5jdXJyZW50Q2FjaGUsIFt2YWx1ZS51cmxdOiB2YWx1ZS5yZXNwb25zZSB9O1xuXG4gICAgc2V0KGludGVybmFsU3RvcmFnZVVybFJlc29sdmVyQXRvbSwgSlNPTi5zdHJpbmdpZnkobmV3Q2FjaGUpKTtcbiAgfSxcbik7XG5cbmNvbnN0IGludGVybmFsU3RvcmFnZVN1cHBvcnRlZEV2ZW50QXRvbSA9IGF0b21XaXRoU3RvcmFnZTxzdHJpbmcgfCB1bmRlZmluZWQ+KFxuICAnc3BpZmZ5LXN1cHBvcnRlZC1ldmVudCcsXG4gIHVuZGVmaW5lZCxcbiAgc2Vzc2lvblN0b3JhZ2VVdGlsLFxuICB7XG4gICAgZ2V0T25Jbml0OiB0cnVlLFxuICB9LFxuKTtcbmNvbnN0IGludGVybmFsU3VwcG9ydGVkRXZlbnRBdG9tID0gYXRvbTxTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcblxuZXhwb3J0IGNvbnN0IHN1cHBvcnRlZEV2ZW50QXRvbSA9IGF0b20oXG4gIChnZXQpOiBTdXBwb3J0ZWRFdmVudCB8IHVuZGVmaW5lZCA9PiB7XG4gICAgY29uc3QgbWF5YmVTdXBwb3J0ZWRFdmVudCA9IGdldChpbnRlcm5hbFN0b3JhZ2VTdXBwb3J0ZWRFdmVudEF0b20pO1xuICAgIGlmIChtYXliZVN1cHBvcnRlZEV2ZW50ID09IG51bGwpIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgLy8gVE9ETyB0aGlzIGlzIGFuIHVudmFsaWRhdGVkIHBhcnNlLiBJdCBtYXkgYmUgYmV0dGVyIHRvIGltcGxlbWVudCBhIGN1c3RvbSBzdG9yYWdlIHV0aWxcbiAgICAvLyBhbmQgcGVyZm9ybSB0aGUgb2JqZWN0IHZhbGlkYXRpb24gb24gXCJnZXRcIiB0aGVyZS5cbiAgICByZXR1cm4gSlNPTi5wYXJzZShtYXliZVN1cHBvcnRlZEV2ZW50KTtcbiAgfSxcbiAgKF8sIHNldCwgdmFsdWU6IFN1cHBvcnRlZEV2ZW50IHwgdW5kZWZpbmVkKSA9PiB7XG4gICAgaWYgKHZhbHVlID09IG51bGwpIHtcbiAgICAgIHNldChpbnRlcm5hbFN0b3JhZ2VTdXBwb3J0ZWRFdmVudEF0b20sIHVuZGVmaW5lZCk7XG4gICAgICBzZXQoaW50ZXJuYWxTdXBwb3J0ZWRFdmVudEF0b20sIHVuZGVmaW5lZCk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgc2V0KGludGVybmFsU3VwcG9ydGVkRXZlbnRBdG9tLCB2YWx1ZSk7XG4gICAgc2V0KGludGVybmFsU3RvcmFnZVN1cHBvcnRlZEV2ZW50QXRvbSwgSlNPTi5zdHJpbmdpZnkodmFsdWUpKTtcbiAgfSxcbik7XG5cbmNvbnN0IGludGVybmFsVmFyaWFudElkQXRvbSA9IGF0b208c3RyaW5nPigpO1xuY29uc3QgaW50ZXJuYWxQcm9kdWN0SWRBdG9tID0gYXRvbTxzdHJpbmc+KCk7XG5jb25zdCBpbnRlcm5hbFBhcmVudFByb2R1Y3RJZEF0b20gPSBhdG9tPHN0cmluZz4oKTtcbmNvbnN0IGludGVybmFsUHJvZHVjdFVybEF0b20gPSBhdG9tPHN0cmluZz4oKTtcbmNvbnN0IGludGVybmFsUGxwSWRBdG9tID0gYXRvbTxzdHJpbmc+KCk7XG5jb25zdCBpbnRlcm5hbFVybEF0b20gPSBhdG9tPHN0cmluZz4oKTtcbmNvbnN0IGludGVybmFsUGFnZVZpc2l0Q2F0ZWdvcnlBdG9tID0gYXRvbTxQYWdlVmlzaXRDYXRlZ29yeT4oKTtcbmNvbnN0IGludGVybmFsVmFyaWFudEF0b20gPSBhdG9tPCdwZHAnIHwgJ3BscCcgfCAnc2VhcmNoJyB8ICdwYWdlX3Zpc2l0Jz4oJ3BkcCcpO1xuXG5leHBvcnQgY29uc3QgdmFyaWFudElkQXRvbSA9IGF0b20oKGdldCkgPT4gZ2V0KGludGVybmFsVmFyaWFudElkQXRvbSkpO1xuZXhwb3J0IGNvbnN0IHByb2R1Y3RJZEF0b20gPSBhdG9tKChnZXQpID0+IGdldChpbnRlcm5hbFByb2R1Y3RJZEF0b20pKTtcbmV4cG9ydCBjb25zdCBwYXJlbnRQcm9kdWN0SWRBdG9tID0gYXRvbSgoZ2V0KSA9PiBnZXQoaW50ZXJuYWxQYXJlbnRQcm9kdWN0SWRBdG9tKSk7XG5leHBvcnQgY29uc3QgcHJvZHVjdFVybEF0b20gPSBhdG9tKChnZXQpID0+IGdldChpbnRlcm5hbFByb2R1Y3RVcmxBdG9tKSk7XG5leHBvcnQgY29uc3QgcGxwSWRBdG9tID0gYXRvbSgoZ2V0KSA9PiBnZXQoaW50ZXJuYWxQbHBJZEF0b20pKTtcbmV4cG9ydCBjb25zdCB1cmxBdG9tID0gYXRvbSgoZ2V0KSA9PiBnZXQoaW50ZXJuYWxVcmxBdG9tKSk7XG5leHBvcnQgY29uc3QgcGFnZVZpc2l0Q2F0ZWdvcnlBdG9tID0gYXRvbSgoZ2V0KSA9PiBnZXQoaW50ZXJuYWxQYWdlVmlzaXRDYXRlZ29yeUF0b20pKTtcbmV4cG9ydCBjb25zdCB2YXJpYW50QXRvbSA9IGF0b20oKGdldCkgPT4gZ2V0KGludGVybmFsVmFyaWFudEF0b20pKTtcbmV4cG9ydCBjb25zdCBoYXNQYXJzZWRWYXJpYW50SW5mb0F0b20gPSBhdG9tKGZhbHNlKTtcblxuZXhwb3J0IGNvbnN0IHZhcmlhbnRJbmZvQXRvbSA9IGF0b20oXG4gIChnZXQpOiBWYXJpYW50SW5mbyA9PiB7XG4gICAgY29uc3QgdmFyaWFudCA9IGdldCh2YXJpYW50QXRvbSk7XG4gICAgaWYgKHZhcmlhbnQgPT09IFZhcmlhbnRUeXBlRW51bS5QZHApIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHZhcmlhbnRJZDogZ2V0KHZhcmlhbnRJZEF0b20pLFxuICAgICAgICB2YXJpYW50LFxuICAgICAgICBwcm9kdWN0SWQ6IGdldChwcm9kdWN0SWRBdG9tKSxcbiAgICAgICAgcGFyZW50UHJvZHVjdElkOiBnZXQocGFyZW50UHJvZHVjdElkQXRvbSksXG4gICAgICAgIHVybDogZ2V0KHVybEF0b20pLFxuICAgICAgfSBhcyBQRFBWYXJpYW50SW5mbztcbiAgICB9XG4gICAgaWYgKHZhcmlhbnQgPT09IFZhcmlhbnRUeXBlRW51bS5QbHApIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHZhcmlhbnRJZDogZ2V0KHZhcmlhbnRJZEF0b20pLFxuICAgICAgICB2YXJpYW50LFxuICAgICAgICBwbHBJZDogZ2V0KHBscElkQXRvbSksXG4gICAgICAgIHVybDogZ2V0KHVybEF0b20pLFxuICAgICAgfSBhcyBQTFBWYXJpYW50SW5mbztcbiAgICB9XG4gICAgaWYgKHZhcmlhbnQgPT09IFZhcmlhbnRUeXBlRW51bS5QYWdlVmlzaXQpIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHZhcmlhbnRJZDogZ2V0KHZhcmlhbnRJZEF0b20pLFxuICAgICAgICB2YXJpYW50LFxuICAgICAgICB1cmw6IGdldCh1cmxBdG9tKSxcbiAgICAgICAgcGFnZVZpc2l0Q2F0ZWdvcnk6IGdldChwYWdlVmlzaXRDYXRlZ29yeUF0b20pLFxuICAgICAgfSBhcyBQYWdlVmlzaXRWYXJpYW50SW5mbztcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKCdJbnZhbGlkIHZhcmlhbnRJbmZvIGRldGFpbHMnKTtcbiAgfSxcbiAgKF8sIHNldCwgbmV3VmFyaWFudDogVmFyaWFudEluZm8pID0+IHtcbiAgICBzZXQoaW50ZXJuYWxWYXJpYW50QXRvbSwgbmV3VmFyaWFudC52YXJpYW50KTtcbiAgICBzZXQoaW50ZXJuYWxWYXJpYW50SWRBdG9tLCBuZXdWYXJpYW50LnZhcmlhbnRJZCk7XG4gICAgaWYgKG5ld1ZhcmlhbnQudmFyaWFudCA9PT0gVmFyaWFudFR5cGVFbnVtLlBkcCkge1xuICAgICAgc2V0KGludGVybmFsUHJvZHVjdElkQXRvbSwgbmV3VmFyaWFudC5wcm9kdWN0SWQpO1xuICAgICAgc2V0KGludGVybmFsUGFyZW50UHJvZHVjdElkQXRvbSwgbmV3VmFyaWFudC5wYXJlbnRQcm9kdWN0SWQpO1xuICAgICAgc2V0KGludGVybmFsVXJsQXRvbSwgbmV3VmFyaWFudC51cmwpO1xuICAgIH1cbiAgICBpZiAobmV3VmFyaWFudC52YXJpYW50ID09PSBWYXJpYW50VHlwZUVudW0uUGxwKSB7XG4gICAgICBzZXQoaW50ZXJuYWxQbHBJZEF0b20sIG5ld1ZhcmlhbnQucGxwSWQpO1xuICAgICAgc2V0KGludGVybmFsVXJsQXRvbSwgbmV3VmFyaWFudC51cmwpO1xuICAgIH1cbiAgICBpZiAobmV3VmFyaWFudC52YXJpYW50ID09PSBWYXJpYW50VHlwZUVudW0uUGFnZVZpc2l0KSB7XG4gICAgICBzZXQoaW50ZXJuYWxVcmxBdG9tLCBuZXdWYXJpYW50LnVybCk7XG4gICAgICBzZXQoaW50ZXJuYWxQYWdlVmlzaXRDYXRlZ29yeUF0b20sIG5ld1ZhcmlhbnQucGFnZVZpc2l0Q2F0ZWdvcnkpO1xuICAgIH1cbiAgfSxcbik7XG4iLCJpbXBvcnQgeyBDb250ZXh0RW52RW51bSwgQ29udGV4dFNvdXJjZUVudW0gfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHsgYXRvbSB9IGZyb20gJ2pvdGFpJztcbmltcG9ydCB7IGF0b21XaXRoU3RvcmFnZSB9IGZyb20gJ2pvdGFpL3V0aWxzJztcbmltcG9ydCB7IFZhcmlhbnRJbmZvLCBVc2VySWRlbnRpdHlDb250ZXh0VHlwZSB9IGZyb20gJ0BlbnZpdmUtYWkvdHlwZXMnO1xuaW1wb3J0IHsgdXNlVXNlcklkZW50aXR5IH0gZnJvbSAnc3JjL2NvbnRleHRzL3VzZXJJZGVudGl0eUNvbnRleHQvdXNlcklkZW50aXR5Q29udGV4dCc7XG5pbXBvcnQgeyB2YXJpYW50SW5mb0F0b20gfSBmcm9tICdzcmMvYXRvbXMvYXBwL3ZhcmlhbnQnO1xuaW1wb3J0IHsgdjQgYXMgdXVpZCB9IGZyb20gJ3V1aWQnO1xuaW1wb3J0IHsgY29udGV4dFNvdXJjZUF0b20gfSBmcm9tICcuLi9lbnZpdmUvZW52aXZlQ29uZmlnJztcblxuZXhwb3J0IGludGVyZmFjZSBBcHBEZXRhaWxzIHtcbiAgb3JnSWQ6IHN0cmluZztcbiAgb3JnU2hvcnROYW1lOiBzdHJpbmc7XG4gIGNoYXRJZDogc3RyaW5nO1xuICB1c2VySWQ6IHN0cmluZztcbiAgc291cmNlOiBDb250ZXh0U291cmNlRW51bTtcbiAgZW52OiBDb250ZXh0RW52RW51bTtcbiAgdmFyaWFudEluZm86IFZhcmlhbnRJbmZvO1xufVxuXG5leHBvcnQgeyB2YXJpYW50SW5mb0F0b20gfSBmcm9tICcuL3ZhcmlhbnQnO1xuXG5jb25zdCBpbnRlcm5hbFVzZXJJZEF0b20gPSBhdG9tPHN0cmluZyB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcblxuZXhwb3J0IGNvbnN0IHVzZXJJZEF0b20gPSBhdG9tKFxuICAoZ2V0KSA9PiB7XG4gICAgY29uc3QgbWF5YmVVc2VySWQgPSBnZXQoaW50ZXJuYWxVc2VySWRBdG9tKTtcblxuICAgIGlmIChtYXliZVVzZXJJZCkge1xuICAgICAgcmV0dXJuIG1heWJlVXNlcklkO1xuICAgIH1cblxuICAgIGNvbnN0IHsgZ2V0VXNlcklkT3JEZWZhdWx0IH0gPSB1c2VVc2VySWRlbnRpdHkoKTtcbiAgICByZXR1cm4gZ2V0VXNlcklkT3JEZWZhdWx0KCk7XG4gIH0sXG4gIChfLCBzZXQsIHZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWQpID0+IHtcbiAgICBzZXQoaW50ZXJuYWxVc2VySWRBdG9tLCB2YWx1ZSk7XG4gIH0sXG4pO1xuXG5leHBvcnQgY29uc3QgdXNlcklkZW50aXR5QXRvbSA9IGF0b208VXNlcklkZW50aXR5Q29udGV4dFR5cGUgfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XG5cbmV4cG9ydCBjb25zdCBhcHBTb3VyY2VBdG9tID0gYXRvbTxDb250ZXh0U291cmNlRW51bT4oXG4gIChnZXQpOiBDb250ZXh0U291cmNlRW51bSA9PiBnZXQoY29udGV4dFNvdXJjZUF0b20pID8/IENvbnRleHRTb3VyY2VFbnVtLkFwcCxcbik7XG5leHBvcnQgY29uc3QgY2hhdElkQXRvbSA9IGF0b21XaXRoU3RvcmFnZTxzdHJpbmc+KCd2MS1zcGlmZnktY2hhdC1zZXNzaW9uLWlkJywgdXVpZCgpLCB1bmRlZmluZWQsIHtcbiAgZ2V0T25Jbml0OiB0cnVlLFxufSk7XG4iLCJpbXBvcnQgUmVhY3QsIHsgY3JlYXRlQ29udGV4dCwgdXNlQ29udGV4dCwgdXNlQ2FsbGJhY2ssIHVzZU1lbW8sIHVzZUVmZmVjdCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IHVzZUF0b21WYWx1ZSB9IGZyb20gJ2pvdGFpJztcbmltcG9ydCB7IGNyZWF0ZUluc3RhbmNlIH0gZnJvbSAnQGFtcGxpdHVkZS9hbmFseXRpY3MtYnJvd3Nlcic7XG5pbXBvcnQgeyBGZWF0dXJlR2F0ZXMsIE9yZ1Nob3J0TmFtZSwgTG9jYWxTdG9yYWdlS2V5cywgU3BpZmZ5RXZlbnQgfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcbmltcG9ydCB7XG4gIGFtcGxpdHVkZUFwaUtleUF0b20sXG4gIGNvbnRleHRTb3VyY2VBdG9tLFxuICBkYXRhUmVzaWRlbmN5QXRvbSxcbiAgaWRlbnRpZnlpbmdQcmVmaXhBdG9tLFxufSBmcm9tICdzcmMvYXRvbXMvZW52aXZlL2Vudml2ZUNvbmZpZyc7XG5pbXBvcnQgeyB1c2VMb2NhbFN0b3JhZ2UgfSBmcm9tICdzcmMvY29udGV4dHMvbG9jYWxTdG9yYWdlQ29udGV4dCc7XG5pbXBvcnQgeyBvcmdBbmFseXRpY3NHb29nbGVBbmFseXRpY3NDb25maWdBdG9tIH0gZnJvbSAnc3JjL2F0b21zL29yZy9vcmdBbmFseXRpY3NDb25maWcnO1xuaW1wb3J0IHsgdXNlcklkQXRvbSB9IGZyb20gJ3NyYy9hdG9tcy9hcHAnO1xuaW1wb3J0IHsgZW52QXRvbSB9IGZyb20gJ3NyYy9hdG9tcy9lbnZpdmUvZW52aXZlQ29uZmlnJztcbmltcG9ydCBMb2dnZXIgZnJvbSAnc3JjL2FwcGxpY2F0aW9uL2xvZ2dpbmcvbG9nZ2VyJztcbmltcG9ydCB0eXBlIHtcbiAgQnJvd3NlckNsaWVudCxcbiAgRW5yaWNobWVudFBsdWdpbixcbiAgRXZlbnQsXG4gIFNlcnZlclpvbmVUeXBlLFxufSBmcm9tICdAYW1wbGl0dWRlL2FuYWx5dGljcy10eXBlcyc7XG5pbXBvcnQgeyB1c2VFbnZpdmVDb25maWcgfSBmcm9tICdzcmMvY29udGV4dHMvZW52aXZlQ29uZmlnQ29udGV4dC9lbnZpdmVDb25maWdDb250ZXh0JztcbmltcG9ydCB7IHVzZUZlYXR1cmVGbGFnU2VydmljZSB9IGZyb20gJ3NyYy9jb250ZXh0cy9mZWF0dXJlRmxhZ1NlcnZpY2VDb250ZXh0L2ZlYXR1cmVGbGFnU2VydmljZUNvbnRleHQnO1xuaW1wb3J0IHsgRXZlbnRzRGlzcGF0Y2hlciB9IGZyb20gJ3NyYy9ldmVudHMnO1xuXG5leHBvcnQgZW51bSBTcGlmZnlNZXRyaWNzRXZlbnROYW1lIHtcbiAgQnVuZGxlTG9hZGVkID0gJ0J1bmRsZSBMb2FkZWQnLFxuICBDaGF0TGl2ZUFnZW50QnRuQ2xpY2sgPSAnQ2hhdCBMaXZlIEFnZW50IEJ0biBDbGljaycsXG4gIENoYXRGbG9hdGluZ0J1dHRvblZpc2libGUgPSAnQ2hhdCBGbG9hdGluZyBCdXR0b24gVmlzaWJsZScsXG4gIENoYXRDb21wb25lbnRWaXNpYmxlID0gJ0NoYXQgQ29tcG9uZW50IFZpc2libGUnLFxuICBDaGF0Q29tcG9uZW50RXhwYW5kZWQgPSAnQ2hhdCBDb21wb25lbnQgRXhwYW5kZWQnLFxuICBDaGF0Q29tcG9uZW50Q29sbGFwc2VkID0gJ0NoYXQgQ29tcG9uZW50IENvbGxhcHNlZCcsXG4gIENoYXRVc2VyTWVzc2FnZUlucHV0ID0gJ0NoYXQgVXNlciBNZXNzYWdlIElucHV0JyxcbiAgQ2hhdFN1Z2dlc3Rpb25DbGlja2VkID0gJ0NoYXQgU3VnZ2VzdGlvbiBDbGlja2VkJyxcbiAgQ2hhdEFzc2lzdGFudFJlc3BvbnNlID0gJ0NoYXQgQXNzaXN0YW50IFJlc3BvbnNlJyxcbiAgUHJvZHVjdENhcmRDbGlja2VkID0gJ1Byb2R1Y3QgQ2FyZCBDbGlja2VkJyxcbiAgUHJvZHVjdFJldmlld0NhcmRDbGlja2VkID0gJ1Byb2R1Y3QgUmV2aWV3IENhcmQgQ2xpY2tlZCcsXG4gIEFkZFRvQ2FydENsaWNrZWQgPSAnQWRkIHRvIENhcnQgQ2xpY2tlZCcsXG4gIFByb21wdENhcmRDbGlja2VkID0gJ1Byb21wdCBDYXJkIENsaWNrZWQnLFxuICBTdXBwb3J0ZWRFdmVudCA9ICdTdXBwb3J0ZWQgRXZlbnQnLFxuICBTZWFyY2hCYWNrVG9SZXNwb25zZUNsaWNrZWQgPSAnU2VhcmNoIEJhY2sgdG8gUmVzcG9uc2UgQ2xpY2tlZCcsXG4gIFBlcmZvcm1hbmNlTWV0cmljcyA9ICdQZXJmb3JtYW5jZSBNZXRyaWNzJyxcbiAgU2VhcmNoQmFyQ2xpY2tlZCA9ICdTZWFyY2ggQmFyIENsaWNrZWQnLFxuICBPcmRlckxvb2t1cFN0YXJ0ZWQgPSAnT3JkZXIgTG9va3VwIFN0YXJ0ZWQnLFxuICBPcmRlckxvb2t1cEZvcm1TdWJtaXR0ZWQgPSAnT3JkZXIgTG9va3VwIEZvcm0gU3VibWl0dGVkJyxcbiAgU2VhcmNoQ29tcG9uZW50VmlzaWJsZSA9ICdTZWFyY2ggQ29tcG9uZW50IFZpc2libGUnLFxuICBTZWFyY2haZXJvU3RhdGVTdWdnZXN0aW9uQ2xpY2tlZCA9ICdTZWFyY2ggWmVybyBTdGF0ZSBTdWdnZXN0aW9uIENsaWNrZWQnLCAvLyBUaGlzIGlzIHRoZSBzY3JvbGxpbmcgbGlzdCBvZiBzdWdnZXN0aW9uIGJ1dHRvbnMgaW4gZ2xvYmFsIHNlYXJjaFxuICBTZWFyY2hJbnB1dFN0YXJ0ZWQgPSAnU2VhcmNoIElucHV0IFN0YXJ0ZWQnLFxuICBTZWFyY2hRdWVyeVN1Ym1pdHRlZCA9ICdTZWFyY2ggUXVlcnkgU3VibWl0dGVkJyxcbiAgLy8gU2VhcmNoQXV0b2NvbXBsZXRlVmlld2VkID0gJ1NlYXJjaCBBdXRvY29tcGxldGUgVmlld2VkJywgLy8gVE9ETzogYWRkIHRoaXMgd2hlbiBhdXRvY29tcGxldGUgaXMgYWRkZWRcbiAgLy8gU2VhcmNoQXV0b2NvbXBsZXRlQ2xpY2tlZCA9ICdTZWFyY2ggQXV0b2NvbXBsZXRlIENsaWNrZWQnLCAvLyBUT0RPOiBhZGQgdGhpcyB3aGVuIGF1dG9jb21wbGV0ZSBpcyBhZGRlZFxuICBTZWFyY2hSZXN1bHRzVmlld2VkID0gJ1NlYXJjaCBSZXN1bHRzIFZpZXdlZCcsXG4gIFNlYXJjaFRpbWVUb0ZpcnN0Q2xpY2sgPSAnU2VhcmNoIFRpbWUgdG8gRmlyc3QgQ2xpY2snLFxuICBTZWFyY2haZXJvUmVzdWx0c1JhdGUgPSAnU2VhcmNoIFplcm8gUmVzdWx0cyBSYXRlJyxcbiAgU2VhcmNoRmlsdGVyQ2xpY2tlZCA9ICdTZWFyY2ggRmlsdGVyIENsaWNrZWQnLFxuICBTZWFyY2hTb3J0Q2xpY2tlZCA9ICdTZWFyY2ggU29ydCBDbGlja2VkJyxcbn1cblxuaW50ZXJmYWNlIFRyYWNrRXZlbnRQYXJhbXMge1xuICBldmVudE5hbWU6IFNwaWZmeU1ldHJpY3NFdmVudE5hbWU7XG4gIGV2ZW50UHJvcHM/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgZXZlbnRHcm91cHM/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcbiAgYWxzb1NlbmRUb0dvb2dsZUFuYWx5dGljcz86IGJvb2xlYW47XG59XG5cbmludGVyZmFjZSBBbXBsaXR1ZGVDb250ZXh0VHlwZSB7XG4gIHRyYWNrRXZlbnQ6IChwYXJhbXM6IFRyYWNrRXZlbnRQYXJhbXMpID0+IFByb21pc2U8dm9pZD47XG4gIGlzUmVhZHk6IGJvb2xlYW47XG4gIHNldFN1cHBsZW1lbnRhbERlZmF1bHRQcm9wczogKHByb3BzOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPikgPT4gdm9pZDtcbn1cblxuY29uc3QgQW1wbGl0dWRlQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8QW1wbGl0dWRlQ29udGV4dFR5cGUgfCBudWxsPihudWxsKTtcblxuZXhwb3J0IGNvbnN0IEFtcGxpdHVkZVByb3ZpZGVyOiBSZWFjdC5GQzx7IGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGUgfT4gPSAoeyBjaGlsZHJlbiB9KSA9PiB7XG4gIGNvbnN0IHVzZXJJZCA9IHVzZUF0b21WYWx1ZSh1c2VySWRBdG9tKTtcbiAgY29uc3QgYW1wbGl0dWRlQXBpS2V5ID0gdXNlQXRvbVZhbHVlKGFtcGxpdHVkZUFwaUtleUF0b20pO1xuICBjb25zdCBkYXRhUmVzaWRlbmN5ID0gdXNlQXRvbVZhbHVlKGRhdGFSZXNpZGVuY3lBdG9tKTtcbiAgY29uc3Qgb3JnR2FDb25maWcgPSB1c2VBdG9tVmFsdWUob3JnQW5hbHl0aWNzR29vZ2xlQW5hbHl0aWNzQ29uZmlnQXRvbSk7XG4gIGNvbnN0IGVudiA9IHVzZUF0b21WYWx1ZShlbnZBdG9tKTtcbiAgY29uc3QgY29udGV4dFNvdXJjZSA9IHVzZUF0b21WYWx1ZShjb250ZXh0U291cmNlQXRvbSk7XG4gIGNvbnN0IGlkZW50aWZ5aW5nUHJlZml4ID0gdXNlQXRvbVZhbHVlKGlkZW50aWZ5aW5nUHJlZml4QXRvbSk7XG4gIGNvbnN0IHsgZ2V0SXRlbSB9ID0gdXNlTG9jYWxTdG9yYWdlKCk7XG4gIGNvbnN0IHtcbiAgICBwdWJsaWNLZXksXG4gICAgZmVhdHVyZU92ZXJyaWRlcyxcbiAgICB2YXJpYW50VXJsT3ZlcnJpZGUsXG4gICAgdmFyaWFudEluZm9PdmVycmlkZSxcbiAgICBzaG93LFxuICAgIG9yZ1Nob3J0TmFtZSxcbiAgICBmZWF0dXJlR2F0ZXMsXG4gIH0gPSB1c2VFbnZpdmVDb25maWcoKTtcblxuICBjb25zdCB7IGZlYXR1cmVGbGFnU2VydmljZSB9ID0gdXNlRmVhdHVyZUZsYWdTZXJ2aWNlKCk7XG5cbiAgY29uc3QgW2FtcGxpdHVkZUNsaWVudCwgc2V0QW1wbGl0dWRlQ2xpZW50XSA9IFJlYWN0LnVzZVN0YXRlPEJyb3dzZXJDbGllbnQgfCB1bmRlZmluZWQ+KFxuICAgIHVuZGVmaW5lZCxcbiAgKTtcbiAgY29uc3QgW2ludGVybmFsRXZlbnRUcmFja2luZ0VucmljaG1lbnQsIHNldEludGVybmFsRXZlbnRUcmFja2luZ0VucmljaG1lbnRdID0gUmVhY3QudXNlU3RhdGU8XG4gICAgRW5yaWNobWVudFBsdWdpbiB8IHVuZGVmaW5lZFxuICA+KHVuZGVmaW5lZCk7XG4gIGNvbnN0IFtzdXBwbGVtZW50YWxEZWZhdWx0UHJvcHMsIHNldFN1cHBsZW1lbnRhbERlZmF1bHRQcm9wc10gPSBSZWFjdC51c2VTdGF0ZTxcbiAgICBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPlxuICA+KHt9KTtcblxuICBjb25zdCBpc1JlYWR5ID0gQm9vbGVhbih1c2VySWQgJiYgZmVhdHVyZUZsYWdTZXJ2aWNlICYmIGFtcGxpdHVkZUFwaUtleSAmJiB1c2VySWQpO1xuXG4gIGNvbnN0IGdldERlZmF1bHRUcmFja2luZ1Byb3BzID0gdXNlQ2FsbGJhY2soKCk6IFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0+IHtcbiAgICBjb25zdCBnYXRlc1Byb3BzID0gZmVhdHVyZUdhdGVzXG4gICAgICA/IGZlYXR1cmVHYXRlcy5yZWR1Y2U8UmVjb3JkPHN0cmluZywgYm9vbGVhbj4+KChhY2MsIGN1cnIpID0+IHtcbiAgICAgICAgICBpZiAoY3Vyci5uYW1lICYmIGN1cnIudmFsdWUgIT0gbnVsbCkge1xuICAgICAgICAgICAgcmV0dXJuIHsgLi4uYWNjLCBbYGZlYXR1cmVfZ2F0ZS4ke2N1cnIubmFtZX1gXTogY3Vyci52YWx1ZSB9O1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gYWNjO1xuICAgICAgICB9LCB7fSlcbiAgICAgIDoge307XG4gICAgY29uc3QgZXhwZXJpbWVudFByb3BzID0ge307IC8vIE5vIGRpcmVjdCBlcXVpdmFsZW50IGZvciBleHBlcmltZW50cyBpbiBFbnZpdmVDb25maWcgeWV0XG5cbiAgICBjb25zdCBvcmdMZXZlbEFtcGxpdHVkZVRyYWNraW5nUHJvcHMgPSB7XG4gICAgICAuLi5nYXRlc1Byb3BzLFxuICAgICAgLi4uZXhwZXJpbWVudFByb3BzLFxuICAgIH07XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4ub3JnTGV2ZWxBbXBsaXR1ZGVUcmFja2luZ1Byb3BzLFxuICAgICAgLi4uc3VwcGxlbWVudGFsRGVmYXVsdFByb3BzLFxuICAgICAgLy8gVE9ETzogb3JnX2lkIGlzIG5vdCBkaXJlY3RseSBhdmFpbGFibGUgaW4gRW52aXZlQ29uZmlnLiBOZWVkIHRvIGZpbmQgYSBuZXcgc291cmNlIG9yIGRlcml2ZSBpdC5cbiAgICAgIC8vIG9yZ19pZDogb3JnQ29uZmlnPy5vcmc/Lm9yZz8uaWQsXG4gICAgICBhcHBfaWQ6ICdjb21tZXJjZS1jaGF0LXJlYWN0LWNvbXBvbmVudCcsXG4gICAgICBjaGF0X2lkOiBnZXRJdGVtKExvY2FsU3RvcmFnZUtleXMuQ2hhdElkKSxcbiAgICAgIGVudjogZW52IHx8ICd1bmtub3duJyxcbiAgICAgIGFwcF9zb3VyY2U6IGNvbnRleHRTb3VyY2UsXG4gICAgICAnb3JnLnNob3J0X25hbWUnOiBvcmdTaG9ydE5hbWUsXG4gICAgICAndXNlci5pZCc6IHVzZXJJZCxcbiAgICAgICdjZHAudXNlcl9pZCc6IG51bGwsXG4gICAgICAnY2RwLnByb3ZpZGVyJzogbnVsbCxcbiAgICAgICdldmVudC5zb3VyY2UnOiAnd2ViLWJyb3dzZXInLFxuICAgICAgJ2V2ZW50LnR5cGUnOiAndXNlci1hY3Rpdml0eScsXG4gICAgICAnZXZlbnQuaWQnOiBudWxsLFxuICAgICAgJ2V2ZW50LmNoYW5uZWwnOiAnd2ViJyxcbiAgICAgICdldmVudC50aW1lc3RhbXAnOiBudWxsLFxuICAgIH07XG4gIH0sIFtmZWF0dXJlR2F0ZXMsIHN1cHBsZW1lbnRhbERlZmF1bHRQcm9wcywgZW52LCBjb250ZXh0U291cmNlLCBvcmdTaG9ydE5hbWUsIHVzZXJJZF0pO1xuXG4gIGNvbnN0IGV2ZW50UHJvcHNUb1ByZWZpeGVkRXZlbnRQcm9wcyA9IHVzZUNhbGxiYWNrKFxuICAgIChcbiAgICAgIGV2ZW50TmFtZTogU3BpZmZ5TWV0cmljc0V2ZW50TmFtZSxcbiAgICAgIGV2ZW50UHJvcHM6IFJlY29yZDxzdHJpbmcsIHVua25vd24+LFxuICAgICk6IFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0+IHtcbiAgICAgIGNvbnN0IHByZWZpeCA9IGV2ZW50TmFtZS50b0xvd2VyQ2FzZSgpLnJlcGxhY2UoL1xccysvZywgJ18nKTtcbiAgICAgIHJldHVybiBPYmplY3QuZW50cmllcyhldmVudFByb3BzKS5yZWR1Y2UoXG4gICAgICAgIChhY2MsIFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgICAgIGFjY1tgJHtwcmVmaXh9LiR7a2V5fWBdID0gdmFsdWU7XG4gICAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgICAgfSxcbiAgICAgICAge30gYXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj4sXG4gICAgICApO1xuICAgIH0sXG4gICAgW10sXG4gICk7XG5cbiAgY29uc3QgYW1wbGl0dWRlU2Vzc2lvblJlcGxheUluaXQgPSB1c2VDYWxsYmFjaygoKTogYm9vbGVhbiA9PiB7XG4gICAgY29uc3QgaXNFbmFibGVkID0gQm9vbGVhbihcbiAgICAgIG9yZ1Nob3J0TmFtZSA9PT0gT3JnU2hvcnROYW1lLlVuaXF1ZVZpbnRhZ2UgJiZcbiAgICAgICAgZmVhdHVyZUZsYWdTZXJ2aWNlPy5pc0NsaWVudFNlc3Npb25FbmFibGVkKCkgJiZcbiAgICAgICAgZmVhdHVyZUZsYWdTZXJ2aWNlPy5pc0ZlYXR1cmVHYXRlRW5hYmxlZChGZWF0dXJlR2F0ZXMuSXNOZXdGZWF0dXJlRW5hYmxlZCksXG4gICAgKTtcbiAgICBjb25zdCBzYW1wbGVSYXRlID0gMTtcblxuICAgIHRyeSB7XG4gICAgICBMb2dnZXIubG9nRGVidWcoXG4gICAgICAgIGBbc3BpZmZ5LWFpXSBhbXBsaXR1ZGUgc2Vzc2lvbi1yZXBsYXkgaW5pdGlhbGl6aW5nIGlzRW5hYmxlZD0ke2lzRW5hYmxlZH0gc2FtcGxlUmF0ZT0ke3NhbXBsZVJhdGV9YCxcbiAgICAgICk7XG5cbiAgICAgIGlmICghaXNFbmFibGVkKSB7XG4gICAgICAgIHJldHVybiBpc0VuYWJsZWQ7XG4gICAgICB9XG5cbiAgICAgIC8vIGFtcGxpdHVkZUluc3RhbmNlLmFkZChzZXNzaW9uUmVwbGF5UGx1Z2luKHsgc2FtcGxlUmF0ZSB9KSk7XG5cbiAgICAgIHJldHVybiBpc0VuYWJsZWQ7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgTG9nZ2VyLmxvZ0Vycm9yKCdbc3BpZmZ5LWFpXSBFcnJvciBpbml0aWFsaXppbmcgYW1wbGl0dWRlIHNlc3Npb24tcmVwbGF5JywgZSk7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICB9LCBbb3JnU2hvcnROYW1lLCBmZWF0dXJlRmxhZ1NlcnZpY2VdKTtcblxuICBjb25zdCBnZXRFdmVudFRyYWNraW5nRW5yaWNobWVudCA9IHVzZUNhbGxiYWNrKCgpOiBFbnJpY2htZW50UGx1Z2luID0+IHtcbiAgICBpZiAoaW50ZXJuYWxFdmVudFRyYWNraW5nRW5yaWNobWVudCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICByZXR1cm4gaW50ZXJuYWxFdmVudFRyYWNraW5nRW5yaWNobWVudDtcbiAgICB9XG5cbiAgICBjb25zdCBlbnJpY2htZW50OiBFbnJpY2htZW50UGx1Z2luID0ge1xuICAgICAgbmFtZTogJ3BhZ2Utdmlldy10cmFja2luZy1lbnJpY2htZW50JyxcbiAgICAgIHR5cGU6ICdlbnJpY2htZW50JyxcbiAgICAgIHNldHVwOiBhc3luYyAoKSA9PiB1bmRlZmluZWQsXG4gICAgICBleGVjdXRlOiBhc3luYyAoZXZlbnQ6IEV2ZW50KTogUHJvbWlzZTxFdmVudD4gPT4ge1xuICAgICAgICBsZXQgZW5yaWNoZWRFdmVudDogRXZlbnQ7XG5cbiAgICAgICAgY29uc3QgZXZlbnRzVG9FbnJpY2ggPSBbXG4gICAgICAgICAgJ1tBbXBsaXR1ZGVdIFBhZ2UgVmlld2VkJyxcbiAgICAgICAgICBgW1NwaWZmeV0gJHtTcGlmZnlNZXRyaWNzRXZlbnROYW1lLkJ1bmRsZUxvYWRlZH1gLFxuICAgICAgICBdO1xuXG4gICAgICAgIGlmIChldmVudHNUb0VucmljaC5pbmNsdWRlcyhldmVudC5ldmVudF90eXBlKSkge1xuICAgICAgICAgIGNvbnN0IGdsb2JhbFByb3BlcnRpZXM6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPSB7fTtcblxuICAgICAgICAgIGlmIChwdWJsaWNLZXkpIHtcbiAgICAgICAgICAgIGdsb2JhbFByb3BlcnRpZXNbJ2dsb2JhbFByb3BlcnRpZXMucHVibGljS2V5J10gPSBwdWJsaWNLZXk7XG4gICAgICAgICAgfVxuICAgICAgICAgIGlmIChmZWF0dXJlT3ZlcnJpZGVzKSB7XG4gICAgICAgICAgICBPYmplY3QuZW50cmllcyhmZWF0dXJlT3ZlcnJpZGVzKS5mb3JFYWNoKChba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgICAgICAgICAgZ2xvYmFsUHJvcGVydGllc1tgZ2xvYmFsUHJvcGVydGllcy5mZWF0dXJlT3ZlcnJpZGVzLiR7a2V5fWBdID0gU3RyaW5nKHZhbHVlKTtcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgICBpZiAodmFyaWFudFVybE92ZXJyaWRlKSB7XG4gICAgICAgICAgICBnbG9iYWxQcm9wZXJ0aWVzWydnbG9iYWxQcm9wZXJ0aWVzLnZhcmlhbnRVcmxPdmVycmlkZSddID0gdmFyaWFudFVybE92ZXJyaWRlO1xuICAgICAgICAgIH1cbiAgICAgICAgICBpZiAodmFyaWFudEluZm9PdmVycmlkZSkge1xuICAgICAgICAgICAgZ2xvYmFsUHJvcGVydGllc1snZ2xvYmFsUHJvcGVydGllcy52YXJpYW50SW5mb092ZXJyaWRlJ10gPVxuICAgICAgICAgICAgICBKU09OLnN0cmluZ2lmeSh2YXJpYW50SW5mb092ZXJyaWRlKTtcbiAgICAgICAgICB9XG4gICAgICAgICAgaWYgKHNob3cgIT0gbnVsbCkge1xuICAgICAgICAgICAgZ2xvYmFsUHJvcGVydGllc1snZ2xvYmFsUHJvcGVydGllcy5zaG93J10gPSBTdHJpbmcoc2hvdyk7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29uc3QgZW5hYmxlZEZlYXR1cmVzID0gZmVhdHVyZUZsYWdTZXJ2aWNlIS5nZXRGZWF0dXJlRmxhZ3MoKTtcbiAgICAgICAgICBjb25zdCBlbmFibGVkRmVhdHVyZXNQcm9wZXJ0aWVzID0gT2JqZWN0LmVudHJpZXMoZW5hYmxlZEZlYXR1cmVzKS5yZWR1Y2U8XG4gICAgICAgICAgICBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+XG4gICAgICAgICAgPihcbiAgICAgICAgICAgIChhY2MsIFtrZXksIHZhbHVlXSkgPT4gKHtcbiAgICAgICAgICAgICAgLi4uYWNjLFxuICAgICAgICAgICAgICBbYGVuYWJsZWRGZWF0dXJlcy4ke2tleX1gXTogYCR7dmFsdWV9YCxcbiAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAge30sXG4gICAgICAgICAgKTtcblxuICAgICAgICAgIGNvbnN0IHRpbWluZ1Byb3BlcnRpZXMgPSB7XG4gICAgICAgICAgICAndGltaW5nLmVucmljaGVkX2F0X21zJzogd2luZG93LnBlcmZvcm1hbmNlPy5ub3coKSxcbiAgICAgICAgICB9O1xuXG4gICAgICAgICAgZW5yaWNoZWRFdmVudCA9IHtcbiAgICAgICAgICAgIC4uLmV2ZW50LFxuICAgICAgICAgICAgZXZlbnRfcHJvcGVydGllczoge1xuICAgICAgICAgICAgICAuLi5ldmVudC5ldmVudF9wcm9wZXJ0aWVzLFxuICAgICAgICAgICAgICAuLi5nZXREZWZhdWx0VHJhY2tpbmdQcm9wcygpLFxuICAgICAgICAgICAgICAuLi5nbG9iYWxQcm9wZXJ0aWVzLFxuICAgICAgICAgICAgICAuLi5lbmFibGVkRmVhdHVyZXNQcm9wZXJ0aWVzLFxuICAgICAgICAgICAgICAuLi50aW1pbmdQcm9wZXJ0aWVzLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICB9O1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGVucmljaGVkRXZlbnQgPSBldmVudDtcbiAgICAgICAgfVxuXG4gICAgICAgIEV2ZW50c0Rpc3BhdGNoZXIuZGlzcGF0Y2goU3BpZmZ5RXZlbnQuQU1QTElUVURFX0VWRU5ULCBlbnJpY2hlZEV2ZW50KTtcblxuICAgICAgICByZXR1cm4gZW5yaWNoZWRFdmVudDtcbiAgICAgIH0sXG4gICAgfTtcbiAgICBzZXRJbnRlcm5hbEV2ZW50VHJhY2tpbmdFbnJpY2htZW50KGVucmljaG1lbnQpO1xuICAgIHJldHVybiBlbnJpY2htZW50O1xuICB9LCBbXG4gICAgaW50ZXJuYWxFdmVudFRyYWNraW5nRW5yaWNobWVudCxcbiAgICBnZXREZWZhdWx0VHJhY2tpbmdQcm9wcyxcbiAgICBmZWF0dXJlRmxhZ1NlcnZpY2UsXG4gICAgcHVibGljS2V5LFxuICAgIGZlYXR1cmVPdmVycmlkZXMsXG4gICAgdmFyaWFudFVybE92ZXJyaWRlLFxuICAgIHZhcmlhbnRJbmZvT3ZlcnJpZGUsXG4gICAgc2hvdyxcbiAgXSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaXNSZWFkeSAmJiAhYW1wbGl0dWRlQ2xpZW50KSB7XG4gICAgICBjb25zdCBjdXJyZW50QW1wbGl0dWRlSW5zdGFuY2U6IEJyb3dzZXJDbGllbnQgPSBjcmVhdGVJbnN0YW5jZSgpO1xuICAgICAgY29uc3QgaXNTZXNzaW9uc0VuYWJsZWQgPSBhbXBsaXR1ZGVTZXNzaW9uUmVwbGF5SW5pdCgpO1xuICAgICAgY3VycmVudEFtcGxpdHVkZUluc3RhbmNlLmFkZChnZXRFdmVudFRyYWNraW5nRW5yaWNobWVudCgpKTtcbiAgICAgIGN1cnJlbnRBbXBsaXR1ZGVJbnN0YW5jZS5pbml0KGFtcGxpdHVkZUFwaUtleSEsIHVzZXJJZCEsIHtcbiAgICAgICAgc2VydmVyWm9uZTogZGF0YVJlc2lkZW5jeSBhcyBTZXJ2ZXJab25lVHlwZSxcbiAgICAgICAgdHJhY2tpbmdPcHRpb25zOiB7XG4gICAgICAgICAgaXBBZGRyZXNzOiB0cnVlLFxuICAgICAgICB9LFxuICAgICAgICBhdXRvY2FwdHVyZToge1xuICAgICAgICAgIGF0dHJpYnV0aW9uOiB0cnVlLFxuICAgICAgICAgIHBhZ2VWaWV3czoge1xuICAgICAgICAgICAgdHJhY2tIaXN0b3J5Q2hhbmdlczogJ3BhdGhPbmx5JyxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHNlc3Npb25zOiBpc1Nlc3Npb25zRW5hYmxlZCxcbiAgICAgICAgICBmb3JtSW50ZXJhY3Rpb25zOiBmYWxzZSxcbiAgICAgICAgICBmaWxlRG93bmxvYWRzOiBmYWxzZSxcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICAgICAgc2V0QW1wbGl0dWRlQ2xpZW50KGN1cnJlbnRBbXBsaXR1ZGVJbnN0YW5jZSk7XG4gICAgfVxuICB9LCBbXG4gICAgaXNSZWFkeSxcbiAgICBhbXBsaXR1ZGVDbGllbnQsXG4gICAgYW1wbGl0dWRlQXBpS2V5LFxuICAgIHVzZXJJZCxcbiAgICBkYXRhUmVzaWRlbmN5LFxuICAgIGFtcGxpdHVkZVNlc3Npb25SZXBsYXlJbml0LFxuICAgIGdldEV2ZW50VHJhY2tpbmdFbnJpY2htZW50LFxuICBdKTtcblxuICBjb25zdCB0cmFja0V2ZW50ID0gdXNlQ2FsbGJhY2soXG4gICAgYXN5bmMgKHtcbiAgICAgIGV2ZW50TmFtZSxcbiAgICAgIGV2ZW50UHJvcHMsXG4gICAgICBldmVudEdyb3VwcyxcbiAgICAgIGFsc29TZW5kVG9Hb29nbGVBbmFseXRpY3MgPSBmYWxzZSxcbiAgICB9OiBUcmFja0V2ZW50UGFyYW1zKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgICBMb2dnZXIubG9nRGVidWcoJ1N1Ym1pdHRpbmcgZXZlbnQnLCBldmVudE5hbWUpO1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgZGVjb3JhdGVkRXZlbnROYW1lID0gYFtTcGlmZnldICR7ZXZlbnROYW1lfWA7XG5cbiAgICAgICAgaWYgKCFhbXBsaXR1ZGVDbGllbnQpIHtcbiAgICAgICAgICBMb2dnZXIubG9nV2FybignYW1wbGl0dWRlIGNsaWVudCB1bmRlZmluZWQnLCB1bmRlZmluZWQsIHtcbiAgICAgICAgICAgIGV2ZW50X25hbWU6IGRlY29yYXRlZEV2ZW50TmFtZSxcbiAgICAgICAgICB9KTtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBldmVudERhdGEgPSBKU09OLnN0cmluZ2lmeSh7XG4gICAgICAgICAgZXZlbnROYW1lLFxuICAgICAgICAgIGV2ZW50UHJvcHMsXG4gICAgICAgICAgY3JlYXRlZF9hdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgICAgICB9KTtcbiAgICAgICAgY29uc3QgZW5jb2RlciA9IG5ldyBUZXh0RW5jb2RlcigpO1xuICAgICAgICBjb25zdCBkYXRhID0gZW5jb2Rlci5lbmNvZGUoZXZlbnREYXRhKTtcbiAgICAgICAgLy8gY2FsY3VsYXRlIGEgaGFzaCBvZiB0aGUgZXZlbnQgcHJvcGVydGllcyB0byB1c2UgYXMgdGhlIGluc2VydF9pZCBzbyB0aGF0IGR1cGxpY2F0ZSBldmVudHNcbiAgICAgICAgLy8gYXJlIGF1dG9tYXRpY2FsbHkgZHJvcHBlZCBieSBBbXBsaXR1ZGVcbiAgICAgICAgY29uc3QgaGFzaEJ1ZmZlciA9IGF3YWl0IGNyeXB0by5zdWJ0bGUuZGlnZXN0KCdTSEEtMjU2JywgZGF0YSk7XG4gICAgICAgIGNvbnN0IGhhc2hBcnJheSA9IEFycmF5LmZyb20obmV3IFVpbnQ4QXJyYXkoaGFzaEJ1ZmZlcikpO1xuICAgICAgICBjb25zdCBjdXJyZW50SW5zZXJ0SWQgPSBoYXNoQXJyYXkubWFwKChiKSA9PiBiLnRvU3RyaW5nKDE2KS5wYWRTdGFydCgyLCAnMCcpKS5qb2luKCcnKTtcblxuICAgICAgICBMb2dnZXIubG9nRGVidWcoYGFtcGxpdHVkZSB0cmFja2luZyAke2RlY29yYXRlZEV2ZW50TmFtZX1gLCBudWxsLCB7XG4gICAgICAgICAgZXZlbnRfbmFtZTogZGVjb3JhdGVkRXZlbnROYW1lLFxuICAgICAgICAgIHByb3BzOiBldmVudFByb3BzLFxuICAgICAgICB9KTtcblxuICAgICAgICBhbXBsaXR1ZGVDbGllbnQudHJhY2soXG4gICAgICAgICAgZGVjb3JhdGVkRXZlbnROYW1lLFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIC4uLmdldERlZmF1bHRUcmFja2luZ1Byb3BzKCksXG4gICAgICAgICAgICAuLi5ldmVudFByb3BzLFxuICAgICAgICAgICAgLi4uKGV2ZW50UHJvcHMgPyBldmVudFByb3BzVG9QcmVmaXhlZEV2ZW50UHJvcHMoZXZlbnROYW1lLCBldmVudFByb3BzKSA6IHt9KSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIC4uLmV2ZW50R3JvdXBzLFxuICAgICAgICAgICAgaW5zZXJ0X2lkOiBjdXJyZW50SW5zZXJ0SWQsXG4gICAgICAgICAgfSxcbiAgICAgICAgKTtcblxuICAgICAgICBpZiAoYWxzb1NlbmRUb0dvb2dsZUFuYWx5dGljcyAmJiBvcmdHYUNvbmZpZykge1xuICAgICAgICAgIC8vIFRPRE86IEFkZCBpbiB3aW5kb3dEYXRhTGF5ZXJTZXJ2aWNlIG9yIGNvbnRleHQgYWx0ZXJuYXRpdmUgYW5kIGhvb2sgaXQgdXAgaGVyZVxuICAgICAgICAgIExvZ2dlci5sb2dEZWJ1ZygnW3NwaWZmeS1haV0gR0EgdHJhY2tpbmcnLCBkZWNvcmF0ZWRFdmVudE5hbWUpO1xuICAgICAgICAgIGlmICh3aW5kb3cuZGF0YUxheWVyKSB7XG4gICAgICAgICAgICAod2luZG93LmRhdGFMYXllciBhcyBhbnlbXSkucHVzaCh7XG4gICAgICAgICAgICAgIGV2ZW50OiBkZWNvcmF0ZWRFdmVudE5hbWUsXG4gICAgICAgICAgICAgIGV2ZW50UHJvcHM6IGV2ZW50UHJvcHMsXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgICBMb2dnZXIubG9nRXJyb3IoJ1tzcGlmZnktYWldIEVycm9yIHRyYWNraW5nIGV2ZW50JywgZXJyLCB7XG4gICAgICAgICAgZXZlbnROYW1lLFxuICAgICAgICAgIGV2ZW50UHJvcHMsXG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH0sXG4gICAgW2FtcGxpdHVkZUNsaWVudCwgZ2V0RGVmYXVsdFRyYWNraW5nUHJvcHMsIGV2ZW50UHJvcHNUb1ByZWZpeGVkRXZlbnRQcm9wcywgb3JnR2FDb25maWddLFxuICApO1xuXG4gIGNvbnN0IHZhbHVlID0gdXNlTWVtbyhcbiAgICAoKSA9PiAoe1xuICAgICAgdHJhY2tFdmVudCxcbiAgICAgIGlzUmVhZHksXG4gICAgICBzZXRTdXBwbGVtZW50YWxEZWZhdWx0UHJvcHM6IChwcm9wczogUmVjb3JkPHN0cmluZywgdW5rbm93bj4pID0+XG4gICAgICAgIHNldFN1cHBsZW1lbnRhbERlZmF1bHRQcm9wcyhwcm9wcyksXG4gICAgfSksXG4gICAgW3RyYWNrRXZlbnQsIGlzUmVhZHksIHNldFN1cHBsZW1lbnRhbERlZmF1bHRQcm9wc10sXG4gICk7XG5cbiAgcmV0dXJuIDxBbXBsaXR1ZGVDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXt2YWx1ZX0+e2NoaWxkcmVufTwvQW1wbGl0dWRlQ29udGV4dC5Qcm92aWRlcj47XG59O1xuXG5leHBvcnQgY29uc3QgdXNlQW1wbGl0dWRlID0gKCkgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChBbXBsaXR1ZGVDb250ZXh0KTtcbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCd1c2VBbXBsaXR1ZGUgbXVzdCBiZSB1c2VkIHdpdGhpbiBBbXBsaXR1ZGVQcm92aWRlcicpO1xuICB9XG4gIHJldHVybiBjb250ZXh0O1xufTtcbiIsImltcG9ydCBMb2dnZXIgZnJvbSAnc3JjL2FwcGxpY2F0aW9uL2xvZ2dpbmcvbG9nZ2VyJztcbmltcG9ydCB7XG4gIGlzTGVnYWN5VUFFY29tbWVyY2VFdmVudCxcbiAgaXNHQTRFY29tbWVyY2VFdmVudCxcbiAgaXNCYXNlRWNvbW1lcmNlRXZlbnQsXG59IGZyb20gJ3NyYy9hcHBsaWNhdGlvbi9tb2RlbHMnO1xuaW1wb3J0IHsgQmFzZUVjb21tZXJjZUV2ZW50IH0gZnJvbSAnQGVudml2ZS1haS90eXBlcyc7XG5pbXBvcnQgeyBTcGlmZnlNZXRyaWNzRXZlbnROYW1lIH0gZnJvbSAnc3JjL2NvbnRleHRzL2FtcGxpdHVkZUNvbnRleHQvYW1wbGl0dWRlQ29udGV4dCc7XG5cbmNvbnN0IE5PUk1BTElaRURfQUREX1RPX0NBUlRfRVZFTlRfTkFNRVMgPSBbJ2FkZHRvY2FydCcsICdhZGRlZHRvY2FydCddO1xuY29uc3QgQ0hFQ0tfREFUQV9MQVlFUl9JTlRFUlZBTF9NUyA9IDUwMDtcbmNvbnN0IENIRUNLX0RBVEFfTEFZRVJfTUFYX0FUVEVNUFRTID0gMTA7XG5cbi8qKlxuICogQ2hlY2tzIGlmIGEgR29vZ2xlIEFuYWx5dGljcyBldmVudCBpcyBhbiBhZGRfdG9fY2FydCBldmVudC5cbiAqXG4gKiBAcGFyYW0gZXZlbnQgVGhlIGV2ZW50IG5hbWUgdG8gY2hlY2suXG4gKlxuICogQHJldHVybnMgVHJ1ZSBpZiB0aGUgZXZlbnQgaXMgYW4gYWRkX3RvX2NhcnQgZXZlbnQsIGZhbHNlIG90aGVyd2lzZS5cbiAqL1xuY29uc3QgaXNBZGRUb0NhcnRFdmVudCA9IChldmVudDogc3RyaW5nKTogYm9vbGVhbiA9PiB7XG4gIGNvbnN0IG5vcm1hbGl6ZWRFdmVudCA9IGV2ZW50LnJlcGxhY2UoL1stX10vZywgJycpLnRvTG93ZXJDYXNlKCk7XG4gIHJldHVybiBOT1JNQUxJWkVEX0FERF9UT19DQVJUX0VWRU5UX05BTUVTLnNvbWUoKG5hbWUpID0+IG5vcm1hbGl6ZWRFdmVudC5pbmNsdWRlcyhuYW1lKSk7XG59O1xuXG4vKipcbiAqIFRyYWNrcyBhbiBhZGRfdG9fY2FydCBldmVudCBpbiBBbXBsaXR1ZGUuXG4gKlxuICogQHBhcmFtIGV2ZW50IFRoZSBldmVudCB0byB0cmFjay5cbiAqL1xuY29uc3QgaGFuZGxlQWRkVG9DYXJ0RXZlbnQgPSAoXG4gIGV2ZW50OiBCYXNlRWNvbW1lcmNlRXZlbnQsXG4gIHRyYWNrOiAoZXZlbnROYW1lOiBTcGlmZnlNZXRyaWNzRXZlbnROYW1lLCBldmVudFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj4pID0+IHZvaWQsXG4pID0+IHtcbiAgbGV0IGV2ZW50UHJvcHM6IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuXG4gIGlmIChpc0xlZ2FjeVVBRWNvbW1lcmNlRXZlbnQoZXZlbnQpKSB7XG4gICAgZXZlbnRQcm9wcyA9IHtcbiAgICAgIGl0ZW1zOiBldmVudC5lY29tbWVyY2UuYWRkLnByb2R1Y3RzLm1hcCgocHJvZHVjdCkgPT4gKHtcbiAgICAgICAgaXRlbV9uYW1lOiBwcm9kdWN0Lm5hbWUsXG4gICAgICAgIGl0ZW1fY2F0ZWdvcnk6IHByb2R1Y3QuY2F0ZWdvcnksXG4gICAgICAgIHByaWNlOiBwcm9kdWN0LnByaWNlLFxuICAgICAgICBxdWFudGl0eTogcHJvZHVjdC5xdWFudGl0eSxcbiAgICAgIH0pKSxcbiAgICAgIGN1cnJlbmN5OiBldmVudC5lY29tbWVyY2UuYWRkLmN1cnJlbmN5Q29kZSxcbiAgICAgIGV2ZW50X2Zvcm1hdF92ZXJzaW9uOiAnbGVnYWN5X3VuaXZlcnNhbF9hbmFseXRpY3MnLFxuICAgIH07XG4gIH0gZWxzZSBpZiAoaXNHQTRFY29tbWVyY2VFdmVudChldmVudCkpIHtcbiAgICBldmVudFByb3BzID0ge1xuICAgICAgaXRlbXM6IGV2ZW50LmVjb21tZXJjZS5pdGVtcy5tYXAoKGl0ZW0pID0+ICh7XG4gICAgICAgIGl0ZW1fbmFtZTogaXRlbS5pdGVtX25hbWUsXG4gICAgICAgIGl0ZW1fY2F0ZWdvcnk6IGl0ZW0uaXRlbV9jYXRlZ29yeSxcbiAgICAgICAgcHJpY2U6IGl0ZW0ucHJpY2UsXG4gICAgICAgIHF1YW50aXR5OiBpdGVtLnF1YW50aXR5LFxuICAgICAgfSkpLFxuICAgICAgY3VycmVuY3k6IGV2ZW50LmVjb21tZXJjZS5jdXJyZW5jeSxcbiAgICAgIGV2ZW50X2Zvcm1hdF92ZXJzaW9uOiAnZ29vZ2xlX2FuYWx5dGljc180JyxcbiAgICB9O1xuICB9IGVsc2Uge1xuICAgIGV2ZW50UHJvcHMgPSB7XG4gICAgICBldmVudF9wcm9wZXJ0aWVzOiB7IC4uLmV2ZW50IH0sXG4gICAgICBldmVudF9mb3JtYXRfdmVyc2lvbjogJ3Vua25vd24nLFxuICAgIH07XG4gIH1cblxuICB0cmFjayhTcGlmZnlNZXRyaWNzRXZlbnROYW1lLkFkZFRvQ2FydENsaWNrZWQsIHtcbiAgICBldmVudFByb3BzLFxuICB9KTtcbn07XG5cbi8qKlxuICogV3JhcHMgdGhlIHdpbmRvdy5kYXRhTGF5ZXIucHVzaCBtZXRob2QgdG8gaW50ZXJjZXB0IGFkZF90b19jYXJ0IGV2ZW50cyBhbmQgc2VuZCB0aGVtIHRvIEFtcGxpdHVkZS5cbiAqIFRoaXMgZnVuY3Rpb24gcnVucyBvbiBhbiBpbnRlcnZhbCB1bnRpbCB0aGUgZGF0YUxheWVyIGlzIGF2YWlsYWJsZS5cbiAqL1xuZXhwb3J0IGNvbnN0IGluaXREYXRhTGF5ZXJXcmFwcGVyID0gKFxuICB0cmFjazogKGV2ZW50TmFtZTogU3BpZmZ5TWV0cmljc0V2ZW50TmFtZSwgZXZlbnRQcm9wcz86IFJlY29yZDxzdHJpbmcsIHVua25vd24+KSA9PiB2b2lkLFxuKSA9PiB7XG4gIGxldCBhdHRlbXB0cyA9IDA7XG5cbiAgLy8gY3VycmVudGx5LCBvdXIgYnVuZGxlIGlzIGFsd2F5cyBsb2FkZWQgYWZ0ZXIgR1RNIGhhcyBpbml0aWFsaXplZCBHQS9kYXRhTGF5ZXJcbiAgLy8gd2UnbGwgbmVlZCB0aGlzIGNoZWNrIGhlcmUgaWYvd2hlbiB3ZSBsb2FkIHNwaWZmeSBiZWZvcmUvb3V0c2lkZSBvZiBHVE1cbiAgY29uc3QgY2hlY2tBbmRJbml0aWFsaXplID0gKCkgPT4ge1xuICAgIGlmICghd2luZG93LmRhdGFMYXllciB8fCAhKHdpbmRvdy5kYXRhTGF5ZXIgYXMgYW55KS5wdXNoKSB7XG4gICAgICBhdHRlbXB0cyArPSAxO1xuXG4gICAgICBpZiAoYXR0ZW1wdHMgPj0gQ0hFQ0tfREFUQV9MQVlFUl9NQVhfQVRURU1QVFMpIHtcbiAgICAgICAgTG9nZ2VyLmxvZ0RlYnVnKFxuICAgICAgICAgIGBbc3BpZmZ5LWFpXSBkYXRhTGF5ZXIgbm90IGF2YWlsYWJsZSBhZnRlciAke0NIRUNLX0RBVEFfTEFZRVJfTUFYX0FUVEVNUFRTfSBhdHRlbXB0c2AsXG4gICAgICAgICk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgc2V0VGltZW91dChjaGVja0FuZEluaXRpYWxpemUsIENIRUNLX0RBVEFfTEFZRVJfSU5URVJWQUxfTVMpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIExvZ2dlci5sb2dEZWJ1ZygnW3NwaWZmeS1haV0gZGF0YUxheWVyIGlzIGF2YWlsYWJsZSwgd3JhcHBpbmcgcHVzaCBmdW5jdGlvbi4uLicpO1xuICAgIGNvbnN0IG9yaWdpbmFsUHVzaCA9IHdpbmRvdy5kYXRhTGF5ZXIucHVzaDtcbiAgICB3aW5kb3cuZGF0YUxheWVyLnB1c2ggPSAoLi4uYXJnczogdW5rbm93bltdKSA9PiB7XG4gICAgICBpZiAoaXNCYXNlRWNvbW1lcmNlRXZlbnQoYXJnc1swXSkgJiYgaXNBZGRUb0NhcnRFdmVudCgoYXJnc1swXSBhcyBhbnkpLmV2ZW50KSkge1xuICAgICAgICBoYW5kbGVBZGRUb0NhcnRFdmVudChhcmdzWzBdIGFzIEJhc2VFY29tbWVyY2VFdmVudCwgdHJhY2spO1xuICAgICAgfVxuXG4gICAgICAvLyBJTVBPUlRBTlQ6IGNhbGwgdGhlIG9yaWdpbmFsIHB1c2ggbWV0aG9kIHNvIHRoYXQgdGhlIGV2ZW50IGlzIHN0aWxsIGxvZ2dlZCB0byBHQVxuICAgICAgcmV0dXJuIG9yaWdpbmFsUHVzaC5hcHBseSh3aW5kb3cuZGF0YUxheWVyLCBhcmdzKTtcbiAgICB9O1xuICB9O1xuXG4gIGNoZWNrQW5kSW5pdGlhbGl6ZSgpO1xufTtcblxuZXhwb3J0IGNvbnN0IGluaXRBbXBsaXR1ZGUgPSAoXG4gIHRyYWNrOiAoZXZlbnROYW1lOiBTcGlmZnlNZXRyaWNzRXZlbnROYW1lLCBldmVudFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj4pID0+IHZvaWQsXG4pID0+IHtcbiAgLy8gVGhpcyBmdW5jdGlvbiBtaWdodCBub3QgYmUgbmVlZGVkIGFueW1vcmUgaWYgQW1wbGl0dWRlIGlzIGluaXRpYWxpemVkIHZpYSBjb250ZXh0LlxuICAvLyBGb3Igbm93LCB3ZSdsbCBrZWVwIGl0IGFuZCBwYXNzIHRoZSB0cmFjayBmdW5jdGlvbi5cbiAgLy8gSWYgaXQncyB0cnVseSByZWR1bmRhbnQsIGl0IGNhbiBiZSByZW1vdmVkIGxhdGVyLlxuICB0cmFjayhTcGlmZnlNZXRyaWNzRXZlbnROYW1lLkJ1bmRsZUxvYWRlZCk7IC8vIEV4YW1wbGUgdXNhZ2UsIGFkanVzdCBhcyBuZWVkZWRcbn07XG4iLCJpbXBvcnQgeyBDYW1lbENhc2VkUHJvcGVydGllc0RlZXAgfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcbmltcG9ydCB7IENvbnRleHQgYXMgQXBpQ29udGV4dCB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5cbmludGVyZmFjZSBDb3JlQ29udGV4dCBleHRlbmRzIENhbWVsQ2FzZWRQcm9wZXJ0aWVzRGVlcDxBcGlDb250ZXh0PiB7fVxuXG5leHBvcnQgY29uc3QgY29yZUNvbnRleHRUb0FwaUNvbnRleHQgPSAoY29udGV4dDogQ29yZUNvbnRleHQpOiBBcGlDb250ZXh0ID0+ICh7XG4gIGNoYXRfaWQ6IGNvbnRleHQuY2hhdElkLFxuICBvcmdfaWQ6IGNvbnRleHQub3JnSWQsXG4gIHVzZXJfaWQ6IGNvbnRleHQudXNlcklkLFxuICBvcmdfc2hvcnRfbmFtZTogY29udGV4dC5vcmdTaG9ydE5hbWUsXG4gIHNvdXJjZTogY29udGV4dC5zb3VyY2UsXG4gIGVudjogY29udGV4dC5lbnYsXG59KTtcbiIsImltcG9ydCB7IFVzZXJFdmVudCB9IGZyb20gJ0BlbnZpdmUtYWkvdHlwZXMnO1xuaW1wb3J0IHtcbiAgVXNlckV2ZW50IGFzIEFwaVVzZXJFdmVudCxcbiAgUExQQXR0cmlidXRlQ2F0ZWdvcnksXG4gIFBMUElkQXR0cmlidXRlcyxcbiAgVXNlckV2ZW50Q2F0ZWdvcnksXG59IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5cbmV4cG9ydCBjb25zdCBjb3JlVXNlckV2ZW50VG9BcGlVc2VyRXZlbnQgPSAoZGF0YTogVXNlckV2ZW50KTogQXBpVXNlckV2ZW50ID0+IHtcbiAgaWYgKFxuICAgIGRhdGEuY2F0ZWdvcnkgPT09IFVzZXJFdmVudENhdGVnb3J5LlBkcFZpc2l0IHx8XG4gICAgZGF0YS5jYXRlZ29yeSA9PT0gVXNlckV2ZW50Q2F0ZWdvcnkuQWRkVG9DYXJ0XG4gICkge1xuICAgIHJldHVybiB7XG4gICAgICBldmVudF9pZDogZGF0YS5ldmVudElkLFxuICAgICAgY3JlYXRlZF9hdDogZGF0YS5jcmVhdGVkQXQsXG4gICAgICBjYXRlZ29yeTogZGF0YS5jYXRlZ29yeSxcbiAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgcHJvZHVjdF9pZDogZGF0YS5hdHRyaWJ1dGVzLnByb2R1Y3RJZCxcbiAgICAgICAgcGFyZW50X3Byb2R1Y3RfaWQ6IGRhdGEuYXR0cmlidXRlcy5wYXJlbnRQcm9kdWN0SWQsXG4gICAgICAgIHVybDogZGF0YS5hdHRyaWJ1dGVzLnVybCxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuXG4gIGlmIChkYXRhLmNhdGVnb3J5ID09PSBVc2VyRXZlbnRDYXRlZ29yeS5QbHBWaXNpdCkge1xuICAgIHJldHVybiB7XG4gICAgICBldmVudF9pZDogZGF0YS5ldmVudElkLFxuICAgICAgY3JlYXRlZF9hdDogZGF0YS5jcmVhdGVkQXQsXG4gICAgICBjYXRlZ29yeTogZGF0YS5jYXRlZ29yeSxcbiAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgY2F0ZWdvcnk6IFBMUEF0dHJpYnV0ZUNhdGVnb3J5LklkLFxuICAgICAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICAgICAgLy8gd2UncmUgb25seSBoYW5kbGluZyBpZCBhdHRyaWJ1dGVzIGZvciBub3dcbiAgICAgICAgICBpZDogKGRhdGEuYXR0cmlidXRlcy5hdHRyaWJ1dGVzIGFzIFBMUElkQXR0cmlidXRlcykuaWQsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH07XG4gIH1cblxuICBpZiAoZGF0YS5jYXRlZ29yeSA9PT0gVXNlckV2ZW50Q2F0ZWdvcnkuUXVlcnlUeXBlZCkge1xuICAgIHJldHVybiB7XG4gICAgICBldmVudF9pZDogZGF0YS5ldmVudElkLFxuICAgICAgY3JlYXRlZF9hdDogZGF0YS5jcmVhdGVkQXQsXG4gICAgICBjYXRlZ29yeTogZGF0YS5jYXRlZ29yeSxcbiAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgcXVlcnk6IGRhdGEuYXR0cmlidXRlcy5xdWVyeSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuXG4gIGlmIChkYXRhLmNhdGVnb3J5ID09PSBVc2VyRXZlbnRDYXRlZ29yeS5TZWFyY2gpIHtcbiAgICByZXR1cm4ge1xuICAgICAgZXZlbnRfaWQ6IGRhdGEuZXZlbnRJZCxcbiAgICAgIGNyZWF0ZWRfYXQ6IGRhdGEuY3JlYXRlZEF0LFxuICAgICAgY2F0ZWdvcnk6IGRhdGEuY2F0ZWdvcnksXG4gICAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICAgIHNlYXJjaF90ZXJtOiBkYXRhLmF0dHJpYnV0ZXMuc2VhcmNoVGVybSxcbiAgICAgICAgc2VsZWN0ZWRfZmlsdGVyczogZGF0YS5hdHRyaWJ1dGVzLnNlbGVjdGVkRmlsdGVycyxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuXG4gIGlmIChkYXRhLmNhdGVnb3J5ID09PSBVc2VyRXZlbnRDYXRlZ29yeS5TdWdnZXN0aW9uQ2xpY2tlZCkge1xuICAgIHJldHVybiB7XG4gICAgICBldmVudF9pZDogZGF0YS5ldmVudElkLFxuICAgICAgY3JlYXRlZF9hdDogZGF0YS5jcmVhdGVkQXQsXG4gICAgICBjYXRlZ29yeTogZGF0YS5jYXRlZ29yeSxcbiAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgc3VnZ2VzdGlvbl9pZDogZGF0YS5hdHRyaWJ1dGVzLnN1Z2dlc3Rpb25JZCxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuXG4gIGlmIChkYXRhLmNhdGVnb3J5ID09PSBVc2VyRXZlbnRDYXRlZ29yeS5QYWdlVmlzaXQpIHtcbiAgICByZXR1cm4ge1xuICAgICAgZXZlbnRfaWQ6IGRhdGEuZXZlbnRJZCxcbiAgICAgIGNyZWF0ZWRfYXQ6IGRhdGEuY3JlYXRlZEF0LFxuICAgICAgY2F0ZWdvcnk6IGRhdGEuY2F0ZWdvcnksXG4gICAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICAgIHVybDogZGF0YS5hdHRyaWJ1dGVzLnVybCxcbiAgICAgICAgcGFnZV92aXNpdF9jYXRlZ29yeTogZGF0YS5hdHRyaWJ1dGVzLnBhZ2VWaXNpdENhdGVnb3J5LFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgaWYgKGRhdGEuY2F0ZWdvcnkgPT09IFVzZXJFdmVudENhdGVnb3J5LkZvcm1TdWJtaXR0ZWQpIHtcbiAgICByZXR1cm4ge1xuICAgICAgZXZlbnRfaWQ6IGRhdGEuZXZlbnRJZCxcbiAgICAgIGNyZWF0ZWRfYXQ6IGRhdGEuY3JlYXRlZEF0LFxuICAgICAgY2F0ZWdvcnk6IGRhdGEuY2F0ZWdvcnksXG4gICAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICAgIGZpbGxlZF9zY2hlbWE6IHsgLi4uZGF0YS5hdHRyaWJ1dGVzLmZpbGxlZFNjaGVtYSB9LFxuICAgICAgICBmb3JtX3Jlc3BvbnNlX2lkOiBkYXRhLmF0dHJpYnV0ZXMuZm9ybVJlc3BvbnNlSWQsXG4gICAgICAgIGZvcm1fdHlwZTogZGF0YS5hdHRyaWJ1dGVzLmZvcm1UeXBlLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgLy8gVGhpcyBpcyB0aGUgZGVmYXVsdCBhcHBfbG9hZGVkIGV2ZW50LCB3aGVuIHdlIHN0YXJ0IHRvIHVzZSBhcHBfdW5sb2FkZWQgd2UgbmVlZCB0byBoYW5kbGUgaXQgaGVyZVxuICByZXR1cm4ge1xuICAgIGV2ZW50X2lkOiBkYXRhLmV2ZW50SWQsXG4gICAgY3JlYXRlZF9hdDogZGF0YS5jcmVhdGVkQXQsXG4gICAgY2F0ZWdvcnk6IGRhdGEuY2F0ZWdvcnksXG4gIH07XG59O1xuIiwiZXhwb3J0IGNvbnN0IGRpdmlkZUFycmF5ID0gPFQ+KGFycmF5OiBUW10sIHNpemU6IG51bWJlcikgPT4ge1xuICBjb25zdCByb3dzID0gW107XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgc2l6ZTsgaSArPSAxKSB7XG4gICAgcm93cy5wdXNoKGFycmF5LmZpbHRlcigoXzogVCwgaW5kZXg6IG51bWJlcikgPT4gaW5kZXggJSBzaXplID09PSBpKSk7XG4gIH1cbiAgcmV0dXJuIHJvd3M7XG59O1xuIiwiaW1wb3J0IHsgTWVzc2FnZSwgTWVzc2FnZVR5cGUsIFByb2R1Y3RNZXNzYWdlTWV0YWRhdGEgfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGdldFJlY2VudFByb2R1Y3RJbWFnZVVybHMgPSAoXG4gIGxhc3RNZXNzYWdlczogTWVzc2FnZVtdLFxuICBjdXJyZW50UHJvZHVjdElkOiBzdHJpbmcgfCB1bmRlZmluZWQsXG4pID0+IHtcbiAgY29uc3QgcHJvZHVjdE1lc3NhZ2VzID0gbGFzdE1lc3NhZ2VzXG4gICAgLmZpbHRlcigobWVzc2FnZSkgPT4gbWVzc2FnZS50eXBlID09PSBNZXNzYWdlVHlwZS5Qcm9kdWN0ICYmIG1lc3NhZ2UubWV0YWRhdGE/LmltYWdlVXJsKVxuICAgIC5tYXAoKG0pID0+IG0gYXMgUHJvZHVjdE1lc3NhZ2VNZXRhZGF0YSk7XG4gIC8vIHB1dCBhZGRlZCBwcm9kdWN0IGltYWdlIGF0IHRoZSB0b3Agb2YgdGhlIGxpc3RcbiAgcmV0dXJuIFtcbiAgICAuLi5wcm9kdWN0TWVzc2FnZXMuZmlsdGVyKChtKSA9PiBtLm1ldGFkYXRhPy5pZCA9PT0gY3VycmVudFByb2R1Y3RJZCksXG4gICAgLi4ucHJvZHVjdE1lc3NhZ2VzLmZpbHRlcigobSkgPT4gbS5tZXRhZGF0YT8uaWQgIT09IGN1cnJlbnRQcm9kdWN0SWQpLFxuICBdLm1hcCgobSkgPT4gbS5tZXRhZGF0YSEuaW1hZ2VVcmwhKTtcbn07XG4iLCJleHBvcnQgY29uc3QgcHJlcGFyZU1lcmNoYW50UGFnZSA9ICgpID0+IHtcbiAgbGV0IG1ldGFWaWV3cG9ydCA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoXCJtZXRhW25hbWU9J3ZpZXdwb3J0J11cIik7XG4gIGlmIChtZXRhVmlld3BvcnQpIHtcbiAgICBjb25zdCBjb250ZW50ID0gbWV0YVZpZXdwb3J0LmdldEF0dHJpYnV0ZShcImNvbnRlbnRcIilcbiAgICBjb25zdCBoYXNNYXhpbXVtU2NhbGUgPSBjb250ZW50Py5pbmNsdWRlcyhcIm1heGltdW0tc2NhbGU9MVwiKVxuICAgIGlmICghaGFzTWF4aW11bVNjYWxlKSB7XG4gICAgICBtZXRhVmlld3BvcnQuc2V0QXR0cmlidXRlKFwiY29udGVudFwiLCBgJHtjb250ZW50fSwgbWF4aW11bS1zY2FsZT0xYClcbiAgICB9XG4gICAgcmV0dXJuXG4gIH1cblxuICBtZXRhVmlld3BvcnQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KFwibWV0YVwiKTtcbiAgbWV0YVZpZXdwb3J0LnNldEF0dHJpYnV0ZShcIm5hbWVcIiwgXCJ2aWV3cG9ydFwiKVxuICBtZXRhVmlld3BvcnQuc2V0QXR0cmlidXRlKFwiY29udGVudFwiLCBcIndpZHRoPWRldmljZS13aWR0aCwgaW5pdGlhbC1zY2FsZT0xLCBtYXhpbXVtLXNjYWxlPTFcIilcbiAgZG9jdW1lbnQuaGVhZC5hcHBlbmRDaGlsZChtZXRhVmlld3BvcnQpO1xufVxuIiwiaW1wb3J0IHsgVXNlckV2ZW50Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuaW1wb3J0IHtcbiAgRm9ybVJlc3BvbnNlQXR0cmlidXRlcyxcbiAgTWVzc2FnZSxcbiAgTWVzc2FnZVJvbGUsXG4gIE1lc3NhZ2VUeXBlLFxuICBVc2VyRXZlbnQsXG59IGZyb20gJ0BlbnZpdmUtYWkvdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgbWVzc2FnZUZyb21Gb3JtU3VibWl0dGVkRXZlbnQgPSAoXG4gIGV2ZW50OiBVc2VyRXZlbnQsXG4gIGZvcm1SZXNwb25zZUF0dHJpYnV0ZXM6IEZvcm1SZXNwb25zZUF0dHJpYnV0ZXNbJ2F0dHJpYnV0ZXMnXSxcbik6IE1lc3NhZ2UgfCB1bmRlZmluZWQgPT4ge1xuICBpZiAoZXZlbnQuY2F0ZWdvcnkgIT09IFVzZXJFdmVudENhdGVnb3J5LkZvcm1TdWJtaXR0ZWQpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3QgZm9ybVN0cmluZ0NvbnRlbnRzID0gT2JqZWN0LmVudHJpZXMoZm9ybVJlc3BvbnNlQXR0cmlidXRlcy5zY2hlbWEucHJvcGVydGllcylcbiAgICAubWFwKChba2V5LCB2YWx1ZV0pID0+IGAke3ZhbHVlLnRpdGxlfTogJHtldmVudC5hdHRyaWJ1dGVzLmZpbGxlZFNjaGVtYVtrZXldfWApXG4gICAgLmpvaW4oJ1xcbicpO1xuXG4gIHJldHVybiB7XG4gICAgaWQ6IGV2ZW50LmV2ZW50SWQsXG4gICAgcm9sZTogTWVzc2FnZVJvbGUuVXNlcixcbiAgICB0eXBlOiBNZXNzYWdlVHlwZS5RdWVyeVR5cGVkLFxuICAgIGNyZWF0ZWRBdDogZXZlbnQuY3JlYXRlZEF0LFxuICAgIG1ldGFkYXRhOiB7XG4gICAgICBjb250ZW50OiBmb3JtU3RyaW5nQ29udGVudHMsXG4gICAgfSxcbiAgfTtcbn07XG4iLCJpbXBvcnQgeyBNZXNzYWdlLCBNZXNzYWdlUm9sZSwgTWVzc2FnZVR5cGUsIFVzZXJFdmVudCB9IGZyb20gJ0BlbnZpdmUtYWkvdHlwZXMnO1xuaW1wb3J0IHsgVXNlckV2ZW50Q2F0ZWdvcnkgfSBmcm9tICdAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnQnO1xuXG4vKipcbiAqIFRyYW5zZm9ybXMgYSBxdWVyeSBVc2VyRXZlbnQgb2JqZWN0IGludG8gYSBNZXNzYWdlIG9iamVjdCBmb3IgcHJlc2VudGF0aW9uLlxuICpcbiAqIEBwYXJhbSBldmVudCBUaGUgdXNlciBldmVudCBvYmplY3QgcmVjZWl2ZWQgZnJvbSB0aGUgc2VydmVyXG4gKlxuICogQHJldHVybnMgQSBNZXNzYWdlIGlmIHRoZSBldmVudCBpcyBhIHF1ZXJ5IGV2ZW50LCBvdGhlcndpc2UgdW5kZWZpbmVkXG4gKi9cbmV4cG9ydCBjb25zdCBtZXNzYWdlRnJvbVF1ZXJ5RXZlbnQgPSAoZXZlbnQ6IFVzZXJFdmVudCk6IE1lc3NhZ2UgfCB1bmRlZmluZWQgPT4ge1xuICBpZiAoZXZlbnQuY2F0ZWdvcnkgPT09IFVzZXJFdmVudENhdGVnb3J5LlF1ZXJ5VHlwZWQpIHtcbiAgICByZXR1cm4ge1xuICAgICAgaWQ6IGV2ZW50LmV2ZW50SWQsXG4gICAgICByb2xlOiBNZXNzYWdlUm9sZS5Vc2VyLFxuICAgICAgdHlwZTogTWVzc2FnZVR5cGUuUXVlcnlUeXBlZCxcbiAgICAgIGNyZWF0ZWRBdDogZXZlbnQuY3JlYXRlZEF0LFxuICAgICAgbWV0YWRhdGE6IHtcbiAgICAgICAgY29udGVudDogZXZlbnQuYXR0cmlidXRlcy5xdWVyeSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuXG4gIGlmIChldmVudC5jYXRlZ29yeSA9PT0gVXNlckV2ZW50Q2F0ZWdvcnkuU2VhcmNoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiBldmVudC5ldmVudElkLFxuICAgICAgcm9sZTogTWVzc2FnZVJvbGUuVXNlcixcbiAgICAgIHR5cGU6IE1lc3NhZ2VUeXBlLlNlYXJjaCxcbiAgICAgIGNyZWF0ZWRBdDogZXZlbnQuY3JlYXRlZEF0LFxuICAgICAgbWV0YWRhdGE6IHtcbiAgICAgICAgc2VhcmNoVGVybTogZXZlbnQuYXR0cmlidXRlcy5zZWFyY2hUZXJtIHx8ICcnLFxuICAgICAgICBzZWxlY3RlZEZpbHRlcnM6IGV2ZW50LmF0dHJpYnV0ZXMuc2VsZWN0ZWRGaWx0ZXJzIHx8IFtdLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn07XG4iLCJpbXBvcnQgeyBNZXNzYWdlLCBNZXNzYWdlVHlwZSwgTWVzc2FnZVJvbGUsIEFwaVJlc3BvbnNlIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHsgUmVzcG9uc2VDYXRlZ29yeSB9IGZyb20gXCJAc3BpZmZ5LWFpL2NvbW1lcmNlLWFwaS1jbGllbnRcIjtcblxuLyoqXG4gKiBUcmFuc2Zvcm1zIGEgc2VydmVyIFJlc3BvbnNlIG9iamVjdCBpbnRvIGEgTWVzc2FnZSBvYmplY3QgZm9yIHByZXNlbnRhdGlvbi5cbiAqXG4gKiBAcGFyYW0gcmVzcG9uc2UgVGhlIHJlc3BvbnNlIG9iamVjdCByZWNlaXZlZCBmcm9tIHRoZSBzZXJ2ZXIgY29udGFpbmluZyBtb2RlbCBnZW5lcmF0ZWQgY29udGVudFxuICpcbiAqIEByZXR1cm5zIEEgTWVzc2FnZSBpZiB0aGUgcmVzcG9uc2UgY29udGFpbnMga25vd24gYXR0cmlidXRlcywgdW5kZWZpbmVkIG90aGVyd2lzZVxuICovXG5leHBvcnQgY29uc3QgbWVzc2FnZUZyb21SZXNwb25zZSA9IChcbiAgcmVzcG9uc2U/OiBBcGlSZXNwb25zZVxuKTogTWVzc2FnZSB8IHVuZGVmaW5lZCA9PiB7XG4gIGlmIChyZXNwb25zZSA9PSBudWxsKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGlmIChyZXNwb25zZS5jYXRlZ29yeSA9PT0gUmVzcG9uc2VDYXRlZ29yeS5UZXh0KSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiByZXNwb25zZS5pZCxcbiAgICAgIGNyZWF0ZWRBdDogcmVzcG9uc2UuY3JlYXRlZEF0LFxuICAgICAgdHlwZTogTWVzc2FnZVR5cGUuVGV4dCxcbiAgICAgIHJvbGU6IE1lc3NhZ2VSb2xlLkFzc2lzdGFudCxcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgIGNvbnRlbnQ6IHJlc3BvbnNlLmF0dHJpYnV0ZXMuY29udGVudCxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuXG4gIGlmIChyZXNwb25zZS5jYXRlZ29yeSA9PT0gUmVzcG9uc2VDYXRlZ29yeS5Qcm9kdWN0KSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiByZXNwb25zZS5pZCxcbiAgICAgIGNyZWF0ZWRBdDogcmVzcG9uc2UuY3JlYXRlZEF0LFxuICAgICAgcm9sZTogTWVzc2FnZVJvbGUuQXNzaXN0YW50LFxuICAgICAgdHlwZTogTWVzc2FnZVR5cGUuUHJvZHVjdCxcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgIC4uLnJlc3BvbnNlLmF0dHJpYnV0ZXMsXG4gICAgICB9LFxuICAgIH07XG4gIH1cblxuICBpZiAocmVzcG9uc2UuY2F0ZWdvcnkgPT09IFJlc3BvbnNlQ2F0ZWdvcnkuUmV2aWV3KSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiByZXNwb25zZS5pZCxcbiAgICAgIGNyZWF0ZWRBdDogcmVzcG9uc2UuY3JlYXRlZEF0LFxuICAgICAgdHlwZTogTWVzc2FnZVR5cGUuUmV2aWV3LFxuICAgICAgcm9sZTogTWVzc2FnZVJvbGUuQXNzaXN0YW50LFxuICAgICAgbWV0YWRhdGE6IHtcbiAgICAgICAgcmV2aWV3OiByZXNwb25zZS5hdHRyaWJ1dGVzLnJldmlldyxcbiAgICAgICAgcmV2aWV3ZXI6IHJlc3BvbnNlLmF0dHJpYnV0ZXMucmV2aWV3ZXIsXG4gICAgICAgIHN0YXJzOiByZXNwb25zZS5hdHRyaWJ1dGVzLnN0YXJzLFxuICAgICAgICB0aXRsZTogcmVzcG9uc2UuYXR0cmlidXRlcy50aXRsZSxcbiAgICAgICAgcmljaEluZm9ybWF0aW9uOiByZXNwb25zZS5hdHRyaWJ1dGVzLnJpY2hJbmZvcm1hdGlvbixcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuXG4gIGlmIChyZXNwb25zZS5jYXRlZ29yeSA9PT0gUmVzcG9uc2VDYXRlZ29yeS5TZXBhcmF0b3IpIHtcbiAgICByZXR1cm4ge1xuICAgICAgaWQ6IHJlc3BvbnNlLmlkLFxuICAgICAgY3JlYXRlZEF0OiByZXNwb25zZS5jcmVhdGVkQXQsXG4gICAgICB0eXBlOiBNZXNzYWdlVHlwZS5TZXBhcmF0b3IsXG4gICAgICByb2xlOiBNZXNzYWdlUm9sZS5Bc3Npc3RhbnQsXG4gICAgfTtcbiAgfVxuXG4gIGlmIChyZXNwb25zZS5jYXRlZ29yeSA9PT0gUmVzcG9uc2VDYXRlZ29yeS5QYWdlKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiByZXNwb25zZS5pZCxcbiAgICAgIGNyZWF0ZWRBdDogcmVzcG9uc2UuY3JlYXRlZEF0LFxuICAgICAgcm9sZTogTWVzc2FnZVJvbGUuQXNzaXN0YW50LFxuICAgICAgdHlwZTogTWVzc2FnZVR5cGUuUGFnZSxcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgIC4uLnJlc3BvbnNlLmF0dHJpYnV0ZXMsXG4gICAgICB9LFxuICAgIH07XG4gIH1cblxuICBpZiAocmVzcG9uc2UuY2F0ZWdvcnkgPT09IFJlc3BvbnNlQ2F0ZWdvcnkuUHJvZHVjdFNlYXJjaCkge1xuICAgIHJldHVybiB7XG4gICAgICBpZDogcmVzcG9uc2UuaWQsXG4gICAgICBjcmVhdGVkQXQ6IHJlc3BvbnNlLmNyZWF0ZWRBdCxcbiAgICAgIHJvbGU6IE1lc3NhZ2VSb2xlLkFzc2lzdGFudCxcbiAgICAgIHR5cGU6IE1lc3NhZ2VUeXBlLlByb2R1Y3RTZWFyY2gsXG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICAuLi5yZXNwb25zZS5hdHRyaWJ1dGVzLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgaWYgKHJlc3BvbnNlLmNhdGVnb3J5ID09PSBSZXNwb25zZUNhdGVnb3J5LlByb2R1Y3RTZWFyY2hGaWx0ZXIpIHtcbiAgICByZXR1cm4ge1xuICAgICAgaWQ6IHJlc3BvbnNlLmlkLFxuICAgICAgY3JlYXRlZEF0OiByZXNwb25zZS5jcmVhdGVkQXQsXG4gICAgICByb2xlOiBNZXNzYWdlUm9sZS5Bc3Npc3RhbnQsXG4gICAgICB0eXBlOiBNZXNzYWdlVHlwZS5Qcm9kdWN0U2VhcmNoRmlsdGVyLFxuICAgICAgbWV0YWRhdGE6IHtcbiAgICAgICAgLi4ucmVzcG9uc2UuYXR0cmlidXRlcyxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuXG4gIGlmIChyZXNwb25zZS5jYXRlZ29yeSA9PT0gUmVzcG9uc2VDYXRlZ29yeS5Gb3JtKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiByZXNwb25zZS5pZCxcbiAgICAgIGNyZWF0ZWRBdDogcmVzcG9uc2UuY3JlYXRlZEF0LFxuICAgICAgcm9sZTogTWVzc2FnZVJvbGUuQXNzaXN0YW50LFxuICAgICAgdHlwZTogTWVzc2FnZVR5cGUuRm9ybSxcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgIGZvcm1UeXBlOiByZXNwb25zZS5hdHRyaWJ1dGVzLmZvcm1DYXRlZ29yeT8uZm9ybVR5cGUsXG4gICAgICAgIGZpZWxkczogT2JqZWN0LmVudHJpZXMocmVzcG9uc2UuYXR0cmlidXRlcy5zY2hlbWEucHJvcGVydGllcykubWFwKFxuICAgICAgICAgIChba2V5LCB2YWx1ZV0pID0+ICh7XG4gICAgICAgICAgICBrZXksXG4gICAgICAgICAgICB0aXRsZTogdmFsdWUudGl0bGUsXG4gICAgICAgICAgICB0eXBlOiB2YWx1ZS50eXBlLFxuICAgICAgICAgICAgZm9ybWF0OiB2YWx1ZS5mb3JtYXQsXG4gICAgICAgICAgICByZXF1aXJlZDogcmVzcG9uc2UuYXR0cmlidXRlcy5zY2hlbWEucmVxdWlyZWQuaW5jbHVkZXMoa2V5KSxcbiAgICAgICAgICB9KVxuICAgICAgICApLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgaWYgKHJlc3BvbnNlLmNhdGVnb3J5ID09PSBSZXNwb25zZUNhdGVnb3J5Lk9yZGVyKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiByZXNwb25zZS5pZCxcbiAgICAgIGNyZWF0ZWRBdDogcmVzcG9uc2UuY3JlYXRlZEF0LFxuICAgICAgcm9sZTogTWVzc2FnZVJvbGUuQXNzaXN0YW50LFxuICAgICAgdHlwZTogTWVzc2FnZVR5cGUuT3JkZXIsXG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICAuLi5yZXNwb25zZS5hdHRyaWJ1dGVzLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn07XG4iLCJpbXBvcnQgeyBNZXNzYWdlLCBNZXNzYWdlUm9sZSwgTWVzc2FnZVR5cGUsIFN1Z2dlc3Rpb24gfSBmcm9tIFwic3JjL3R5cGVzXCI7XG5pbXBvcnQgeyBVc2VyRXZlbnQgfSBmcm9tIFwiQGVudml2ZS1haS90eXBlc1wiO1xuaW1wb3J0IHsgVXNlckV2ZW50Q2F0ZWdvcnkgfSBmcm9tIFwiQHNwaWZmeS1haS9jb21tZXJjZS1hcGktY2xpZW50XCI7XG5cbi8qKlxuICogVHJhbnNmb3JtcyBhIFVzZXJFdmVudCBvYmplY3QgaW50byBhIE1lc3NhZ2Ugb2JqZWN0IGZvciBwcmVzZW50YXRpb24uXG4gKlxuICogQHBhcmFtIGV2ZW50IFRoZSBVc2VyRXZlbnQgb2JqZWN0IHJlY2VpdmVkIGZyb20gdGhlIHNlcnZlclxuICogQHBhcmFtIHN1Z2dlc3Rpb25zIEEgbGlzdCBvZiBnZW5lcmF0ZWQgc3VnZ2VzdGlvbnMgdG8gbWF0Y2ggdGhlIGV2ZW50IHRvXG4gKlxuICogQHJldHVybnMgQSBNZXNzYWdlIGlmIHRoZSBldmVudCBpcyBhIHN1Z2dlc3Rpb24gY2xpY2sgZXZlbnQsIHVuZGVmaW5lZCBvdGhlcndpc2VcbiAqL1xuZXhwb3J0IGNvbnN0IG1lc3NhZ2VGcm9tU3VnZ2VzdGlvbkV2ZW50ID0gKFxuICBldmVudDogVXNlckV2ZW50LFxuICBzdWdnZXN0aW9uczogU3VnZ2VzdGlvbltdXG4pOiBNZXNzYWdlIHwgdW5kZWZpbmVkID0+IHtcbiAgaWYgKGV2ZW50LmNhdGVnb3J5ID09PSBVc2VyRXZlbnRDYXRlZ29yeS5TdWdnZXN0aW9uQ2xpY2tlZCkge1xuICAgIGNvbnN0IHsgc3VnZ2VzdGlvbklkIH0gPSBldmVudC5hdHRyaWJ1dGVzO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiBldmVudC5ldmVudElkLFxuICAgICAgcm9sZTogTWVzc2FnZVJvbGUuVXNlcixcbiAgICAgIHR5cGU6IE1lc3NhZ2VUeXBlLlN1Z2dlc3Rpb25DbGlja2VkLFxuICAgICAgY3JlYXRlZEF0OiBldmVudC5jcmVhdGVkQXQsXG4gICAgICBtZXRhZGF0YToge1xuICAgICAgICBzdWdnZXN0aW9uSWQsXG4gICAgICAgIHN1Z2dlc3Rpb25Db250ZW50OlxuICAgICAgICAgIHN1Z2dlc3Rpb25zLmZpbmQoKHMpID0+IHMuaWQgPT09IHN1Z2dlc3Rpb25JZCk/LmNvbnRlbnQgPz8gXCJcIixcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuXG4gIHJldHVybiB1bmRlZmluZWQ7XG59O1xuIiwiaW1wb3J0IHsgTmV4dE1lc3NhZ2VSZXF1ZXN0IGFzIEFwaU5leHRNZXNzYWdlUmVxdWVzdCB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBjb3JlVXNlckV2ZW50VG9BcGlVc2VyRXZlbnQgfSBmcm9tICcuL2NvcmVVc2VyRXZlbnRUb0FwaVVzZXJFdmVudCc7XG5pbXBvcnQgeyBOZXh0TWVzc2FnZVJlcXVlc3QgfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IG1lc3NhZ2VSZXF1ZXN0VG9Db21tZXJjZU1lc3NhZ2VSZXF1ZXN0ID0gKFxuICBkYXRhOiBOZXh0TWVzc2FnZVJlcXVlc3QsXG4pOiBBcGlOZXh0TWVzc2FnZVJlcXVlc3QgPT4gKHtcbiAgY29udGV4dDoge1xuICAgIGNoYXRfaWQ6IGRhdGEuY29udGV4dC5jaGF0SWQsXG4gICAgb3JnX2lkOiBkYXRhLmNvbnRleHQub3JnSWQsXG4gICAgb3JnX3Nob3J0X25hbWU6IGRhdGEuY29udGV4dC5vcmdTaG9ydE5hbWUsXG4gICAgdXNlcl9pZDogZGF0YS5jb250ZXh0LnVzZXJJZCxcbiAgICBzb3VyY2U6IGRhdGEuY29udGV4dC5zb3VyY2UsXG4gICAgZW52OiBkYXRhLmNvbnRleHQuZW52LFxuICB9LFxuICBpZDogZGF0YS5pZCxcbiAgZmVhdHVyZV9mbGFnczogZGF0YS5mZWF0dXJlRmxhZ3MsXG4gIHVzZXJfZXZlbnRzOiBkYXRhLnVzZXJFdmVudHM/Lm1hcCgodXNlckV2ZW50KSA9PiBjb3JlVXNlckV2ZW50VG9BcGlVc2VyRXZlbnQodXNlckV2ZW50KSksXG4gIGdlbmVyYXRpb25fcGFyYW1zOiB7XG4gICAgbW9kZWw6IGRhdGEuZ2VuZXJhdGlvblBhcmFtcz8ubW9kZWwsXG4gICAgbWF4X3Rva2VuczogZGF0YS5nZW5lcmF0aW9uUGFyYW1zPy5tYXhUb2tlbnMsXG4gICAgc3RvcDogZGF0YS5nZW5lcmF0aW9uUGFyYW1zPy5zdG9wLFxuICAgIHN0cmVhbTogZGF0YS5nZW5lcmF0aW9uUGFyYW1zPy5zdHJlYW0sXG4gICAgdGVtcGVyYXR1cmU6IGRhdGEuZ2VuZXJhdGlvblBhcmFtcz8udGVtcGVyYXR1cmUsXG4gICAgdG9wX3A6IGRhdGEuZ2VuZXJhdGlvblBhcmFtcz8udG9wUCxcbiAgICBudW1fc3VnZ2VzdGlvbnM6IGRhdGEuZ2VuZXJhdGlvblBhcmFtcz8ubnVtU3VnZ2VzdGlvbnMsXG4gICAgcmVzcG9uc2Vfc3lzdGVtX3Byb21wdDogZGF0YS5nZW5lcmF0aW9uUGFyYW1zPy5yZXNwb25zZVN5c3RlbVByb21wdCxcbiAgICBzdWdnZXN0aW9uX3N5c3RlbV9wcm9tcHQ6IGRhdGEuZ2VuZXJhdGlvblBhcmFtcz8uc3VnZ2VzdGlvblN5c3RlbVByb21wdCxcbiAgICByZXNwb25zZV9jYWNoaW5nOiBkYXRhLmdlbmVyYXRpb25QYXJhbXM/LnJlc3BvbnNlQ2FjaGluZyxcbiAgfSxcbn0pO1xuIiwiZXhwb3J0IGFic3RyYWN0IGNsYXNzIE5vZGVTZWxlY3RvciB7XG4gIHByaXZhdGUgcGF0dGVybjogc3RyaW5nO1xuICBwcml2YXRlIHJvb3Q6IERvY3VtZW50O1xuXG4gIGNvbnN0cnVjdG9yKHBhdHRlcm46IHN0cmluZykge1xuICAgIHRoaXMucGF0dGVybiA9IHBhdHRlcm47XG4gICAgdGhpcy5yb290ID0gZG9jdW1lbnQ7XG4gIH1cblxuICBnZXRQYXR0ZXJuKCkge1xuICAgIHJldHVybiB0aGlzLnBhdHRlcm47XG4gIH1cblxuICBzZXRSb290KHJvb3Q6IERvY3VtZW50KSB7XG4gICAgdGhpcy5yb290ID0gcm9vdDtcbiAgfVxuXG4gIGdldFJvb3QoKSB7XG4gICAgcmV0dXJuIHRoaXMucm9vdDtcbiAgfVxuXG4gIGFic3RyYWN0IHBhcnNlKCk6IE5vZGUgfCBudWxsO1xufVxuXG5jbGFzcyBRdWVyeVNlbGVjdG9yIGV4dGVuZHMgTm9kZVNlbGVjdG9yIHtcbiAgcGFyc2UoKTogTm9kZSB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLmdldFJvb3QoKS5xdWVyeVNlbGVjdG9yKHRoaXMuZ2V0UGF0dGVybigpKTtcbiAgfVxufVxuXG5jbGFzcyBJRFNlbGVjdG9yIGV4dGVuZHMgTm9kZVNlbGVjdG9yIHtcbiAgcGFyc2UoKTogTm9kZSB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLmdldFJvb3QoKS5nZXRFbGVtZW50QnlJZCh0aGlzLmdldFBhdHRlcm4oKSkgYXMgTm9kZTtcbiAgfVxufVxuXG5jbGFzcyBYcGF0aFNlbGVjdG9yIGV4dGVuZHMgTm9kZVNlbGVjdG9yIHtcbiAgcGFyc2UoKTogTm9kZSB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLmdldFJvb3QoKT8uZXZhbHVhdGUoXG4gICAgICB0aGlzLmdldFBhdHRlcm4oKSxcbiAgICAgIHRoaXMuZ2V0Um9vdCgpLFxuICAgICAgbnVsbCxcbiAgICAgIFhQYXRoUmVzdWx0LkZJUlNUX09SREVSRURfTk9ERV9UWVBFLFxuICAgICAgbnVsbCxcbiAgICApPy5zaW5nbGVOb2RlVmFsdWUgYXMgTm9kZTtcbiAgfVxufVxuXG5jbGFzcyBDaGFpblNlbGVjdG9yIGV4dGVuZHMgTm9kZVNlbGVjdG9yIHtcbiAgcGFyc2UoKTogTm9kZSB8IG51bGwge1xuICAgIGxldCBzZWxlY3RvckluZGV4ID0gMDtcbiAgICBjb25zdCBzZWxlY3RvcnMgPSB0aGlzLmdldFBhdHRlcm4oKS5zcGxpdCgnQCcpO1xuICAgIGNvbnN0IGxhc3RJbmRleCA9IHNlbGVjdG9ycy5sZW5ndGggLSAxO1xuXG4gICAgY29uc3QgcGFyc2VDaGFpbiA9IChwYXR0ZXJuOiBzdHJpbmcsIHByZXZOb2RlPzogTm9kZSB8IG51bGwpOiBOb2RlIHwgbnVsbCA9PiB7XG4gICAgICBjb25zdCBzZWxlY3RvciA9IFNlbGVjdG9yRmFjdG9yeS5wYXJzZShwYXR0ZXJuKTtcblxuICAgICAgaWYgKHByZXZOb2RlKSB7XG4gICAgICAgIHNlbGVjdG9yLnNldFJvb3QocHJldk5vZGUgYXMgRG9jdW1lbnQpO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBjdXJyZW50Tm9kZSA9IHNlbGVjdG9yLnBhcnNlKCk7XG4gICAgICBpZiAoc2VsZWN0b3JJbmRleCA9PT0gbGFzdEluZGV4KSB7XG4gICAgICAgIHJldHVybiBjdXJyZW50Tm9kZTtcbiAgICAgIH1cblxuICAgICAgbGV0IG5vZGU6IE5vZGUgfCBudWxsIHwgdW5kZWZpbmVkID0gY3VycmVudE5vZGUgfHwgZG9jdW1lbnQ7XG4gICAgICBpZiAoKGN1cnJlbnROb2RlIGFzIEhUTUxFbGVtZW50KT8uc2hhZG93Um9vdCkge1xuICAgICAgICBub2RlID0gKGN1cnJlbnROb2RlIGFzIEhUTUxFbGVtZW50KS5zaGFkb3dSb290O1xuICAgICAgfVxuXG4gICAgICBpZiAoKGN1cnJlbnROb2RlIGFzIEhUTUxJRnJhbWVFbGVtZW50KT8uY29udGVudFdpbmRvdykge1xuICAgICAgICBub2RlID0gKGN1cnJlbnROb2RlIGFzIEhUTUxJRnJhbWVFbGVtZW50KS5jb250ZW50V2luZG93Py5kb2N1bWVudDtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHBhcnNlQ2hhaW4oc2VsZWN0b3JzWysrc2VsZWN0b3JJbmRleF0udHJpbSgpLCBub2RlKTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIHBhcnNlQ2hhaW4oc2VsZWN0b3JzW3NlbGVjdG9ySW5kZXhdLnRyaW0oKSk7XG4gIH1cbn1cblxuY2xhc3MgRW1wdHkgZXh0ZW5kcyBOb2RlU2VsZWN0b3Ige1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcignJyk7XG4gIH1cbiAgcGFyc2UoKTogTm9kZSB8IG51bGwge1xuICAgIHJldHVybiBudWxsO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBTZWxlY3RvckZhY3Rvcnkge1xuICBzdGF0aWMgcGFyc2UoY29tcG9zZWRTZWxlY3Rvcj86IHN0cmluZykge1xuICAgIGlmICghY29tcG9zZWRTZWxlY3Rvcikge1xuICAgICAgcmV0dXJuIG5ldyBFbXB0eSgpO1xuICAgIH1cblxuICAgIGNvbnN0IHNwbGl0ID0gY29tcG9zZWRTZWxlY3Rvci5zcGxpdCgnfCcpO1xuICAgIGNvbnN0IHR5cGUgPSBzcGxpdFswXTtcbiAgICBjb25zdCBzZWxlY3RvciA9IHNwbGl0WzFdO1xuXG4gICAgc3dpdGNoICh0eXBlKSB7XG4gICAgICBjYXNlICdpZCc6XG4gICAgICAgIHJldHVybiB0aGlzLmlkKHNlbGVjdG9yKTtcbiAgICAgIGNhc2UgJ3F1ZXJ5JzpcbiAgICAgICAgcmV0dXJuIHRoaXMucXVlcnkoc2VsZWN0b3IpO1xuICAgICAgY2FzZSAneHBhdGgnOlxuICAgICAgICByZXR1cm4gdGhpcy54cGF0aChzZWxlY3Rvcik7XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gbmV3IEVtcHR5KCk7XG4gICAgfVxuICB9XG5cbiAgc3RhdGljIGNoZWNrKHNlbGVjdG9yPzogTm9kZVNlbGVjdG9yKSB7XG4gICAgcmV0dXJuIHNlbGVjdG9yID8/IG5ldyBFbXB0eSgpO1xuICB9XG5cbiAgc3RhdGljIGNoYWluKHBhdHRlcm4/OiBzdHJpbmcpIHtcbiAgICByZXR1cm4gcGF0dGVybiA/IG5ldyBDaGFpblNlbGVjdG9yKHBhdHRlcm4pIDogbmV3IEVtcHR5KCk7XG4gIH1cblxuICBzdGF0aWMgaWQocGF0dGVybj86IHN0cmluZyk6IE5vZGVTZWxlY3RvciB7XG4gICAgcmV0dXJuIHBhdHRlcm4gPyBuZXcgSURTZWxlY3RvcihwYXR0ZXJuKSA6IG5ldyBFbXB0eSgpO1xuICB9XG5cbiAgc3RhdGljIHF1ZXJ5KHBhdHRlcm4/OiBzdHJpbmcpOiBOb2RlU2VsZWN0b3Ige1xuICAgIHJldHVybiBwYXR0ZXJuID8gbmV3IFF1ZXJ5U2VsZWN0b3IocGF0dGVybikgOiBuZXcgRW1wdHkoKTtcbiAgfVxuXG4gIHN0YXRpYyB4cGF0aChwYXR0ZXJuPzogc3RyaW5nKTogTm9kZVNlbGVjdG9yIHtcbiAgICByZXR1cm4gcGF0dGVybiA/IG5ldyBYcGF0aFNlbGVjdG9yKHBhdHRlcm4pIDogbmV3IEVtcHR5KCk7XG4gIH1cbn1cbiIsImltcG9ydCB7IERlbGV0ZU9wLCBNZXJnZU9wdGlvbnMsIE5vSW5mZXIsIE92ZXJyaWRlLCBSZXBsYWNlT3AgfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcblxuZnVuY3Rpb24gaXNQbGFpbk9iamVjdCh4OiB1bmtub3duKTogeCBpcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB7XG4gIHJldHVybiAoXG4gICAgISF4ICYmXG4gICAgdHlwZW9mIHggPT09ICdvYmplY3QnICYmXG4gICAgIUFycmF5LmlzQXJyYXkoeCkgJiZcbiAgICAhKHggaW5zdGFuY2VvZiBEYXRlKSAmJlxuICAgICEoeCBpbnN0YW5jZW9mIFJlZ0V4cClcbiAgKTtcbn1cblxuZnVuY3Rpb24gaXNSZXBsYWNlKHg6IHVua25vd24pOiB4IGlzIFJlcGxhY2VPcDx1bmtub3duPiB7XG4gIHJldHVybiAhIXggJiYgdHlwZW9mIHggPT09ICdvYmplY3QnICYmICckcmVwbGFjZScgaW4gKHggYXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj4pO1xufVxuZnVuY3Rpb24gaXNEZWxldGUoeDogdW5rbm93bik6IHggaXMgRGVsZXRlT3Age1xuICByZXR1cm4gISF4ICYmIHR5cGVvZiB4ID09PSAnb2JqZWN0JyAmJiAoeCBhcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPikuJGRlbGV0ZSA9PT0gdHJ1ZTtcbn1cblxuZnVuY3Rpb24gaXNQcmltaXRpdmVWYWx1ZSh4OiB1bmtub3duKTogYm9vbGVhbiB7XG4gIGNvbnN0IHQgPSB0eXBlb2YgeDtcbiAgcmV0dXJuIChcbiAgICB4ID09PSBudWxsIHx8XG4gICAgdCA9PT0gJ3N0cmluZycgfHxcbiAgICB0ID09PSAnbnVtYmVyJyB8fFxuICAgIHQgPT09ICdib29sZWFuJyB8fFxuICAgIHQgPT09ICdiaWdpbnQnIHx8XG4gICAgdCA9PT0gJ3N5bWJvbCcgfHxcbiAgICB0ID09PSAndW5kZWZpbmVkJ1xuICApO1xufVxuXG5mdW5jdGlvbiBpc0FycmF5T2ZQcmltaXRpdmVzKGFycjogdW5rbm93bltdKTogYm9vbGVhbiB7XG4gIGlmIChhcnIubGVuZ3RoID09PSAwKSByZXR1cm4gZmFsc2U7IC8vIGFtYmlndW91cywgZGVmYXVsdCB0byBtZXJnZS1ieS1pbmRleCBvbiBlbXB0eVxuICAvLyBJZiBldmVyeSBkZWZpbmVkIGVsZW1lbnQgaXMgcHJpbWl0aXZlLCB0cmVhdCBhcyBwcmltaXRpdmVzXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgYXJyLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgY29uc3QgdiA9IGFycltpXTtcbiAgICBpZiAodiAhPT0gdW5kZWZpbmVkICYmICFpc1ByaW1pdGl2ZVZhbHVlKHYpKSByZXR1cm4gZmFsc2U7XG4gIH1cbiAgcmV0dXJuIHRydWU7XG59XG5cbmZ1bmN0aW9uIG1lcmdlQW55KGJhc2VBbnk6IHVua25vd24sIHBhdGNoQW55OiB1bmtub3duLCBvcHRzOiBNZXJnZU9wdGlvbnMpOiB1bmtub3duIHtcbiAgaWYgKGlzUmVwbGFjZShwYXRjaEFueSkpIHJldHVybiBwYXRjaEFueS4kcmVwbGFjZSBhcyB1bmtub3duO1xuICBpZiAoaXNEZWxldGUocGF0Y2hBbnkpKSByZXR1cm4gdW5kZWZpbmVkOyAvLyBjYWxsZXIgZGVsZXRlcyB0aGUga2V5XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkoYmFzZUFueSkpIHtcbiAgICBpZiAoQXJyYXkuaXNBcnJheShwYXRjaEFueSkpIHtcbiAgICAgIGNvbnN0IGJhc2VBcnIgPSBiYXNlQW55IGFzIHVua25vd25bXTtcbiAgICAgIGNvbnN0IHBhdGNoQXJyID0gcGF0Y2hBbnkgYXMgdW5rbm93bltdO1xuICAgICAgY29uc3Qgc2hvdWxkUmVwbGFjZSA9XG4gICAgICAgIG9wdHMuYXJyYXlTdHJhdGVneSA9PT0gJ3JlcGxhY2UnIHx8XG4gICAgICAgIGlzQXJyYXlPZlByaW1pdGl2ZXMoYmFzZUFycikgfHxcbiAgICAgICAgaXNBcnJheU9mUHJpbWl0aXZlcyhwYXRjaEFycik7XG4gICAgICBpZiAoc2hvdWxkUmVwbGFjZSkgcmV0dXJuIHBhdGNoQW55IGFzIHVua25vd247XG4gICAgICBjb25zdCBvdXQgPSBiYXNlQXJyLnNsaWNlKCk7XG4gICAgICBjb25zdCBtYXggPSBNYXRoLm1heChvdXQubGVuZ3RoLCBwYXRjaEFyci5sZW5ndGgpO1xuICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCBtYXg7IGkgKz0gMSkge1xuICAgICAgICBjb25zdCBwVmFsID0gcGF0Y2hBcnJbaV07XG4gICAgICAgIGlmIChwVmFsICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICBvdXRbaV0gPSBtZXJnZUFueShvdXRbaV0sIHBWYWwsIG9wdHMpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICByZXR1cm4gb3V0IGFzIHVua25vd247XG4gICAgfVxuICAgIHJldHVybiBiYXNlQW55IGFzIHVua25vd247XG4gIH1cblxuICBpZiAoaXNQbGFpbk9iamVjdChiYXNlQW55KSAmJiBpc1BsYWluT2JqZWN0KHBhdGNoQW55KSkge1xuICAgIGNvbnN0IGJhc2VPYmogPSBiYXNlQW55IGFzIFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuICAgIGNvbnN0IHBhdGNoT2JqID0gcGF0Y2hBbnkgYXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj47XG4gICAgY29uc3Qgb3V0OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiA9IHsgLi4uYmFzZU9iaiB9O1xuICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKHBhdGNoT2JqKSkge1xuICAgICAgY29uc3QgcFZhbCA9IHBhdGNoT2JqW2tleV07XG4gICAgICBpZiAocFZhbCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIC8vIGxlYXZlIGFzLWlzXG4gICAgICB9IGVsc2UgaWYgKG9wdHMubnVsbERlbGV0ZXMgJiYgcFZhbCA9PT0gbnVsbCkge1xuICAgICAgICBkZWxldGUgb3V0W2tleV07XG4gICAgICB9IGVsc2UgaWYgKGlzUmVwbGFjZShwVmFsKSkge1xuICAgICAgICBvdXRba2V5XSA9IHBWYWwuJHJlcGxhY2U7XG4gICAgICB9IGVsc2UgaWYgKGlzRGVsZXRlKHBWYWwpKSB7XG4gICAgICAgIGRlbGV0ZSBvdXRba2V5XTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIG91dFtrZXldID0gbWVyZ2VBbnkoYmFzZU9iaj8uW2tleV0sIHBWYWwsIG9wdHMpO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gb3V0IGFzIHVua25vd247XG4gIH1cblxuICByZXR1cm4gKHBhdGNoQW55IGFzIHVua25vd24pID8/IGJhc2VBbnk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhcHBseU92ZXJyaWRlczxUPihcbiAgYmFzZTogVCxcbiAgcGF0Y2g6IE92ZXJyaWRlPE5vSW5mZXI8VD4+LFxuICBvcHRzOiBNZXJnZU9wdGlvbnMgPSB7fSxcbik6IFQge1xuICBjb25zdCB7IGFycmF5U3RyYXRlZ3kgPSAnbWVyZ2VCeUluZGV4JywgbnVsbERlbGV0ZXMgPSBmYWxzZSB9ID0gb3B0cztcblxuICAvLyBIYW5kbGUgd2hvbGUtbm9kZSBjb250cm9sIG9wZXJhdG9ycyBvbiBwYXRjaCBpdHNlbGZcbiAgaWYgKGlzUmVwbGFjZShwYXRjaCkpIHJldHVybiBwYXRjaC4kcmVwbGFjZSBhcyBUO1xuICBpZiAoaXNEZWxldGUocGF0Y2gpKSByZXR1cm4gdW5kZWZpbmVkIGFzIHVua25vd24gYXMgVDtcblxuICAvLyBBcnJheXNcbiAgaWYgKEFycmF5LmlzQXJyYXkoYmFzZSkpIHtcbiAgICBpZiAoaXNSZXBsYWNlKHBhdGNoKSkgcmV0dXJuIHBhdGNoLiRyZXBsYWNlIGFzIFQ7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkocGF0Y2gpKSB7XG4gICAgICBpZiAoYXJyYXlTdHJhdGVneSA9PT0gJ3JlcGxhY2UnKSByZXR1cm4gcGF0Y2ggYXMgdW5rbm93biBhcyBUO1xuICAgICAgLy8gbWVyZ2UgYnkgaW5kZXhcbiAgICAgIGNvbnN0IG91dCA9IChiYXNlIGFzIHVua25vd25bXSkuc2xpY2UoKTtcbiAgICAgIGNvbnN0IG1heCA9IE1hdGgubWF4KG91dC5sZW5ndGgsIHBhdGNoLmxlbmd0aCk7XG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IG1heDsgaSArPSAxKSB7XG4gICAgICAgIGNvbnN0IHBWYWwgPSAocGF0Y2ggYXMgdW5rbm93bltdKVtpXTtcbiAgICAgICAgaWYgKHBWYWwgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgIG91dFtpXSA9IG1lcmdlQW55KG91dFtpXSwgcFZhbCwgb3B0cyk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIHJldHVybiBvdXQgYXMgdW5rbm93biBhcyBUO1xuICAgIH1cbiAgICAvLyBpbnZhbGlkIHBhdGNoIHR5cGUgZm9yIGFuIGFycmF5IOKGkiBpZ25vcmUgYW5kIHJldHVybiBiYXNlXG4gICAgcmV0dXJuIGJhc2UgYXMgVDtcbiAgfVxuXG4gIC8vIFBsYWluIG9iamVjdHNcbiAgaWYgKGlzUGxhaW5PYmplY3QoYmFzZSkgJiYgaXNQbGFpbk9iamVjdChwYXRjaCkpIHtcbiAgICBjb25zdCBvdXQ6IFJlY29yZDxzdHJpbmcsIHVua25vd24+ID0geyAuLi4oYmFzZSBhcyBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPikgfTtcbiAgICBjb25zdCBwYXRjaE9iaiA9IHBhdGNoIGFzIFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKHBhdGNoT2JqKSkge1xuICAgICAgY29uc3QgcFZhbCA9IHBhdGNoT2JqW2tleV07XG4gICAgICBpZiAocFZhbCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIC8vIGxlYXZlIGV4aXN0aW5nIHZhbHVlXG4gICAgICB9IGVsc2UgaWYgKG51bGxEZWxldGVzICYmIHBWYWwgPT09IG51bGwpIHtcbiAgICAgICAgZGVsZXRlIG91dFtrZXldO1xuICAgICAgfSBlbHNlIGlmIChpc1JlcGxhY2UocFZhbCkpIHtcbiAgICAgICAgb3V0W2tleV0gPSBwVmFsLiRyZXBsYWNlO1xuICAgICAgfSBlbHNlIGlmIChpc0RlbGV0ZShwVmFsKSkge1xuICAgICAgICBkZWxldGUgb3V0W2tleV07XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zdCBiVmFsID0gKGJhc2UgYXMgUmVjb3JkPHN0cmluZywgdW5rbm93bj4pW2tleV07XG4gICAgICAgIG91dFtrZXldID0gbWVyZ2VBbnkoYlZhbCwgcFZhbCwgb3B0cyk7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBvdXQgYXMgdW5rbm93biBhcyBUO1xuICB9XG5cbiAgLy8gRm9yIHByaW1pdGl2ZXMgb3Igd2hlbiBwYXRjaCBpcyBwcmltaXRpdmUsIHBhdGNoIHdpbnMgaWYgZGVmaW5lZFxuICByZXR1cm4gKChwYXRjaCBhcyB1bmtub3duKSA/PyBiYXNlKSBhcyBUO1xufVxuIiwiXG5jbGFzcyBTdHJpbmdVdGlscyB7XG4gIHN0YXRpYyBpc051bGxPckVtcHR5KHZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWQpOiBib29sZWFuIHtcbiAgICBjb25zdCB2YWx1ZVRyaW1tZWQgPSB2YWx1ZT8udHJpbSgpO1xuICAgIHJldHVybiB2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8IHZhbHVlVHJpbW1lZCA9PT0gJyc7XG4gIH1cblxuICBzdGF0aWMgdHJpbVRvTnVsbCh2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICBjb25zdCB2YWx1ZVRyaW1tZWQgPSB2YWx1ZT8udHJpbSgpO1xuICAgIHJldHVybiBTdHJpbmdVdGlscy5pc051bGxPckVtcHR5KHZhbHVlVHJpbW1lZCkgPyB1bmRlZmluZWQgOiB2YWx1ZVRyaW1tZWQ7XG4gIH1cblxuICBzdGF0aWMgY2FwaXRhbGl6ZSh0eXBlOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcbiAgICBpZiAodHlwZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICByZXR1cm4gJyc7XG4gICAgfVxuICAgIHJldHVybiB0eXBlLmNoYXJBdCgwKS50b1VwcGVyQ2FzZSgpICsgdHlwZS5zdWJzdHJpbmcoMSk7XG4gIH1cblxuICAvKipcbiAgICogRmluZHMgdGhlIGZpcnN0IHBhdHRlcm4gaW4gYW4gYXJyYXkgdGhhdCBtYXRjaGVzIGEgZ2l2ZW4gVVJMLlxuICAgKiBQYXR0ZXJucyBjYW4gaW5jbHVkZSBhIHNpbmdsZSB3aWxkY2FyZCAnKicgd2hpY2ggbWF0Y2hlcyBhbnkgc2VxdWVuY2Ugb2YgY2hhcmFjdGVycy5cbiAgICpcbiAgICogQHBhcmFtIHBhdHRlcm5zXG4gICAqIEBwYXJhbSB1cmxUb1Rlc3RcbiAgICogQHJldHVybnNcbiAgICovXG4gIHN0YXRpYyBmaW5kTWF0Y2hpbmdQYXR0ZXJuKHBhdHRlcm5zOiBzdHJpbmdbXSwgdXJsVG9UZXN0OiBMb2NhdGlvbik6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKCF1cmxUb1Rlc3QpIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgZm9yIChjb25zdCBwYXR0ZXJuIG9mIHBhdHRlcm5zKSB7XG4gICAgICAvLyBUZXN0IG9ubHkgaWYgYSBwYXRobmFtZSBpcyBwcmVzZW50LlxuICAgICAgaWYgKHVybFRvVGVzdC5wYXRobmFtZSAhPT0gJy8nKSB7XG4gICAgICAgIC8vIEVzY2FwZSBzcGVjaWFsIHJlZ2V4IGNoYXJhY3RlcnMgaW4gdGhlIHBhdHRlcm5cbiAgICAgICAgLy8gVGhpcyBlbnN1cmVzIHRoYXQgY2hhcmFjdGVycyBsaWtlICcuJywgJysnLCAnPycsICcoJywgZXRjLiwgaW4gdGhlIHBhdHRlcm4gYXJlIHRyZWF0ZWQgbGl0ZXJhbGx5LlxuICAgICAgICBjb25zdCBlc2NhcGVkUGF0dGVybiA9IHBhdHRlcm4ucmVwbGFjZSgvWy4rP14ke30oKXxbXFxdXFxcXF0vZywgJ1xcXFwkJicpO1xuXG4gICAgICAgIC8vIFJlcGxhY2UgdGhlIHdpbGRjYXJkICcqJyB3aXRoIGl0cyByZWdleCBlcXVpdmFsZW50ICcuKicgKG1hdGNoZXMgYW55IGNoYXJhY3RlciB6ZXJvIG9yIG1vcmUgdGltZXMpXG4gICAgICAgIGNvbnN0IHJlZ2V4UGF0dGVybiA9IGVzY2FwZWRQYXR0ZXJuLnJlcGxhY2UoL1xcKi9nLCAnLionKTtcblxuICAgICAgICBjb25zdCByZWdleCA9IG5ldyBSZWdFeHAoYF4ke3JlZ2V4UGF0dGVybn0kYCk7XG4gICAgICAgIGlmIChyZWdleC50ZXN0KHVybFRvVGVzdC5wYXRobmFtZSkpIHtcbiAgICAgICAgICByZXR1cm4gcGF0dGVybjtcbiAgICAgICAgfVxuXG4gICAgICB9IGVsc2UgaWYgKHBhdHRlcm4uc3RhcnRzV2l0aCh1cmxUb1Rlc3QuaG9zdG5hbWUpKSB7XG4gICAgICAgIHJldHVybiBwYXR0ZXJuO1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuXG5leHBvcnQgeyBTdHJpbmdVdGlscyB9O1xuIiwiaW1wb3J0IHsgU3VwcG9ydGVkRXZlbnRSZXF1ZXN0IGFzIEFwaVN1cHBvcnRlZEV2ZW50UmVxdWVzdCB9IGZyb20gJ0BzcGlmZnktYWkvY29tbWVyY2UtYXBpLWNsaWVudCc7XG5pbXBvcnQgeyBTdXBwb3J0ZWRFdmVudFJlcXVlc3QgfSBmcm9tICdAZW52aXZlLWFpL3R5cGVzJztcbmltcG9ydCB7IGNvcmVVc2VyRXZlbnRUb0FwaVVzZXJFdmVudCB9IGZyb20gJy4vY29yZVVzZXJFdmVudFRvQXBpVXNlckV2ZW50JztcbmltcG9ydCB7IGNvcmVDb250ZXh0VG9BcGlDb250ZXh0IH0gZnJvbSAnLi9jb3JlQ29udGV4dFRvQXBpQ29udGV4dCc7XG5cbnR5cGUgQ29yZVN1cHBvcnRlZEV2ZW50UmVxdWVzdCA9IFN1cHBvcnRlZEV2ZW50UmVxdWVzdDtcblxuZXhwb3J0IGNvbnN0IGNvcmVTdXBwb3J0ZWRFdmVudFJlcXVlc3RUb0FwaVJlcXVlc3QgPSAoXG4gIGNvcmVTdXBwb3J0ZWRFdmVudFJlcXVlc3Q6IENvcmVTdXBwb3J0ZWRFdmVudFJlcXVlc3QsXG4pOiBBcGlTdXBwb3J0ZWRFdmVudFJlcXVlc3QgPT4gKHtcbiAgaWQ6IGNvcmVTdXBwb3J0ZWRFdmVudFJlcXVlc3QuaWQsXG4gIHVzZXJfZXZlbnQ6IGNvcmVVc2VyRXZlbnRUb0FwaVVzZXJFdmVudChjb3JlU3VwcG9ydGVkRXZlbnRSZXF1ZXN0LnVzZXJFdmVudCksXG4gIGNvbnRleHQ6IGNvcmVDb250ZXh0VG9BcGlDb250ZXh0KGNvcmVTdXBwb3J0ZWRFdmVudFJlcXVlc3QuY29udGV4dCksXG59KTtcbiIsIi8vIFRoaXMgZW1haWwgdmFsaWRhdGVzIHRoYXQgdGhlcmUgYXJlIG9uZSBvciBtb3JlIGNoYXJhY3RlcnMgYmVmb3JlIHRoZSBgQGAgc3ltYm9sLFxuLy8gb25lIG9yIG1vcmUgY2hhcmFjdGVycyBiZXR3ZWVuIHRoZSBgQGAgc3ltYm9sIGFuZCB0aGUgYC5gIHN5bWJvbCxcbi8vIGFuZCBvbmUgb3IgbW9yZSBjaGFyYWN0ZXJzIGFmdGVyIHRoZSBgLmAgc3ltYm9sXG4vLyBJdCBkb2VzIE5PVCB2YWxpZGF0ZSBhbGwgcG9zc2libGUgZW1haWwgZm9ybWF0cywgYnV0IGl0IGlzIGEgZGVjZW50IHBsYWNlIHRvIHN0YXJ0LlxuZXhwb3J0IGNvbnN0IHZhbGlkYXRlRW1haWwgPSAodmFsdWU6IHN0cmluZyk6IGJvb2xlYW4gPT4gL15bXlxcc0BdK0BbXlxcc0BdK1xcLlteXFxzQF0rJC8udGVzdCh2YWx1ZSk7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUEwREEsZUFBZSxrQkFBa0IsT0FBc0I7QUFDckQsS0FBSTtBQUNGLFNBQU8sTUFBTSxNQUFNLFNBQVMsTUFBTTtTQUM1QjtBQUNOLFNBQU8sRUFBRTs7O0FBSWIsZUFBZSw4QkFBOEIsVUFBa0IsT0FBZ0I7QUFDN0UsS0FBSSxFQUFFLGlCQUFpQixnQkFBZ0I7QUFDckMsaUJBQU8sUUFBUSxVQUFVLE1BQU07QUFDL0IsUUFBTTs7Q0FHUixNQUFNLGdCQUFnQixNQUFNLGtCQUFrQixNQUFNO0FBQ3BELEtBQ0UsZUFBZSxTQUFTLGFBQWEsS0FBSyx5QkFDMUMsZUFBZSxVQUFVLGFBQWEsS0FBSyxvQkFFM0MsT0FBTSxJQUFJLDZCQUE2QjtVQUV2QyxlQUFlLFVBQVUsYUFBYSxLQUFLLHFCQUMzQyxlQUFlLFVBQVUsYUFBYSxLQUFLLGFBQzNDO0FBQ0EsaUJBQU8sUUFDTCw0Q0FDQSxPQUNBLE1BQU0sVUFDTixjQUNEO0FBQ0QsUUFBTSxJQUFJLHdCQUF3Qjs7QUFHcEMsZ0JBQU8sUUFBUSxVQUFVLE1BQU07QUFDL0IsT0FBTTs7QUFHUixJQUFNLG9CQUFOLE1BQU0sa0JBQWtCOzsyQkFhZ0M7QUFDcEQsT0FBSSxDQUFDLGtCQUFrQixTQUNyQixtQkFBa0IsV0FBVyxJQUFJLG1CQUFtQjtBQUd0RCxVQUFPLGtCQUFrQjs7O0NBRzNCLEFBQVEsWUFBWSxVQUFtQjtvQ0FaRixJQUFJLGlCQUFpQjtrQ0FFdkIsSUFBSSxpQkFBaUI7RUFZdEQsTUFBTSxVQURZLGNBQWMsQ0FDTixJQUFJLFlBQVk7RUFHMUMsTUFBTUEsU0FBd0IsSUFBSSxjQUFjO0dBQzlDLFVBSFcsWUFBWTtHQUl2QixTQUFTO0lBQ1AsZ0JBQWdCO0lBQ2hCLFFBQVE7SUFDVDtHQUNGLENBQUM7QUFDRixPQUFLLGFBQWEsSUFBSSxXQUFXLE9BQU87QUFDeEMsT0FBSyxlQUFlLElBQUksYUFBYSxPQUFPO0FBQzVDLE9BQUsscUJBQXFCLElBQUksbUJBQW1CLE9BQU87OztvQkFHdEMsT0FBTyxRQUFnQjtHQUN6QyxNQUFNLFlBQVksY0FBYztHQUNoQyxNQUFNLGVBQWUsVUFBVSxJQUFJLGlCQUFpQjtHQUNwRCxNQUFNLFFBQVEsVUFBVSxJQUFJLFVBQVU7R0FDdEMsTUFBTSxTQUFTLFVBQVUsSUFBSSxXQUFXO0dBQ3hDLE1BQU0sU0FBUyxVQUFVLElBQUksV0FBVztHQUN4QyxNQUFNLFNBQVMsVUFBVSxJQUFJLGtCQUFrQjtHQUMvQyxNQUFNLE1BQU0sVUFBVSxJQUFJLFFBQVE7R0FFbEMsTUFBTSxxQkFBcUIsVUFBVSxJQUFJLHVCQUF1QjtHQUVoRSxNQUFNQyxVQUFtQjtJQUN2QixTQUFTLFVBQVU7SUFDbkIsUUFBUSxTQUFTO0lBQ2pCLGdCQUFnQixnQkFBZ0I7SUFDaEMsU0FBUyxVQUFVO0lBQ25CLFFBQVEsVUFBVSxrQkFBa0I7SUFDcEMsS0FBTSxPQUEwQixlQUFlO0lBQ2hEO0dBRUQsTUFBTSxlQUNKLG9CQUFvQixvQkFBb0IsaUJBQWlCLElBQUksRUFBRTtHQUNqRSxNQUFNLHNCQUFzQjtJQUMxQjtJQUNBO0lBQ0EsZUFBZTtJQUNoQjtBQVNELFVBRnFCLE9BSm5CLE1BQU0sa0JBQWtCLGFBQWEsQ0FBQyxhQUFhLHNCQUFzQixFQUN2RSxxQkFBcUIscUJBQ3RCLENBQUMsRUFFbUMsSUFBSSxNQUFNOzs7O3VCQUs1QixPQUNyQixrQkFDa0I7QUFDbEIsU0FBTSxrQkFBa0IsYUFBYSxDQUFDLFdBQVcsMkJBQy9DLEVBQ0Usc0JBQXNCLGVBQ3ZCLENBQ0Y7Ozs7MEJBR3VCLE9BQ3hCLFlBQ3VCO0FBQ3ZCLE9BQUk7QUFTRixZQVBFLE1BQU0sa0JBQWtCLGFBQWEsQ0FBQyxhQUFhLG9CQUFvQixFQUNyRSxvQkFBb0IsdUNBQXVDLFFBQVEsRUFDcEUsQ0FBQyxFQUVELEtBQUssU0FBUyxpQkFBaUIsS0FBSyxDQUFDLENBQ3JDLEtBQUssU0FBUyxvQkFBb0IsS0FBSyxDQUFDLENBRTNCLFFBQVEsTUFBb0IsS0FBSyxLQUFLO1lBQy9DQyxLQUFjO0FBQ3JCLG1CQUFPLFFBQVEsZ0NBQWdDLEtBQUs7S0FDbEQsZ0JBQWdCLFNBQVM7S0FDekIsWUFBWSxTQUFTO0tBQ3RCLENBQUM7QUFDRixVQUFNLDhCQUE4QixnQ0FBZ0MsSUFBSTtBQUN4RSxXQUFPLEVBQUU7Ozs7O21DQUtYLFlBQytDO0dBQy9DLGdCQUFnQixTQUNkLGNBQ0EsaUJBQ0E7QUFFQSxRQUFJO0tBQ0YsTUFBTSxXQUFXLE1BQU0sYUFBYSx1QkFDbEMsRUFDRSxvQkFBb0IsdUNBQXVDLFFBQVEsRUFDcEUsRUFDRCxFQUFFLFFBQVEsZ0JBQWdCLFFBQVEsQ0FDbkM7QUFHRCxTQUFJLENBQUMsU0FBUyxJQUFJLE1BQU07QUFDdEIscUJBQU8sU0FDTCxnREFDQSxRQUNBLEVBQ0UsVUFBVSxTQUFTLEtBQ3BCLENBQ0Y7QUFDRDs7S0FHRixNQUFNLFNBQVMsU0FBUyxJQUFJLEtBQUssV0FBVztLQUM1QyxNQUFNLFVBQVUsSUFBSSxZQUFZLFFBQVE7S0FFeEMsSUFBSSxVQUFVO0tBRWQsTUFBTSxhQUFhLFNBQTBCO0FBQzNDLFVBQUk7QUFDRixjQUFPLEtBQUssTUFBTSxLQUFLO2VBQ2hCLEtBQUs7QUFDWixzQkFBTyxTQUFTLDJDQUEyQyxLQUFLO1FBQzlEO1FBQ0E7UUFDRCxDQUFDO0FBRUYsaUJBQVU7QUFDVixjQUFPOzs7S0FLWCxNQUFNLGdCQUFnQixVQUE2QjtBQVNqRCxhQVBjLEdBQUcsVUFBVSxRQUFRLE1BQU0sS0FBSyxDQUczQyxLQUFLLFNBQVMsS0FBSyxRQUFRLFdBQVcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUNqRCxRQUFRLFNBQVMsU0FBUyxNQUFNLFNBQVMsU0FBUyxDQUNsRCxJQUFJLFVBQVUsQ0FDZCxRQUFRLE1BQU0sRUFBRTs7QUFJckIsWUFBTyxNQUFNO01BRVgsTUFBTSxFQUFFLE1BQU0sVUFBVSxNQUFNLE9BQU8sTUFBTTtBQUUzQyxVQUFJLEtBQ0Y7TUFJRixNQUFNLFFBQVEsUUFBUSxPQUFPLE1BQU07TUFDbkMsTUFBTSxjQUFjLGFBQWEsTUFBTTtBQUV2QyxXQUFLLE1BQU0sY0FBYyxhQUFhO09BQ3BDLE1BQU0sb0JBQW9CLGlCQUFpQixXQUFXO0FBRXRELFdBQUksa0JBQ0YsT0FBTTs7O2FBSUxDLE9BQWdCO0FBQ3ZCLG9CQUFPLFNBQ0wsc0RBQ0EsT0FDQTtNQUNFLGdCQUFnQixTQUFTO01BQ3pCLFlBQVksU0FBUztNQUN0QixDQUNGO0FBQ0QsV0FBTSw4QkFDSiwwQ0FDQSxNQUNEOzs7QUFJTCxxQkFBa0IsYUFBYSxDQUFDLHlCQUF5QixPQUFPO0FBQ2hFLHFCQUFrQixhQUFhLENBQUMsMkJBQzlCLElBQUksaUJBQWlCO0FBRXZCLFVBQU8sU0FDTCxrQkFBa0IsYUFBYSxDQUFDLGNBQ2hDLGtCQUFrQixhQUFhLENBQUMseUJBQ2pDOzs7OzRCQUd5QixPQUMxQixZQUMwQjtBQUMxQixPQUFJO0FBQ0Ysc0JBQWtCLGFBQWEsQ0FBQywyQkFBMkIsT0FBTztBQUNsRSxzQkFBa0IsYUFBYSxDQUFDLDZCQUM5QixJQUFJLGlCQUFpQjtBQWlCdkIsWUFkRSxNQUFNLGtCQUFrQixhQUFhLENBQUMsYUFBYSxzQkFDakQsRUFDRSxvQkFBb0IsdUNBQXVDLFFBQVEsRUFDcEUsRUFDRCxFQUNFLFFBQ0Usa0JBQWtCLGFBQWEsQ0FBQywyQkFBMkIsUUFDOUQsQ0FDRixFQUdBLEtBQUssU0FBUyxtQkFBbUIsS0FBSyxDQUFDLENBQ3ZDLFFBQVEsZUFBeUMsY0FBYyxLQUFLO1lBR2hFQSxPQUFnQjtBQUN2QixtQkFBTyxRQUFRLDZCQUE2QixPQUFPO0tBQ2pELGdCQUFnQixTQUFTO0tBQ3pCLFlBQVksU0FBUztLQUN0QixDQUFDO0FBRUYsVUFBTSw4QkFBOEIsNkJBQTZCLE1BQU07QUFDdkUsV0FBTyxFQUFFOzs7OztzQkFhUyxPQUNwQixPQUNBLFFBQ0EsV0FNSTtHQUNKLElBQUlDLE9BQXdDO0lBQzFDLFdBQVcsRUFBRTtJQUNiLGFBQWEsRUFBRTtJQUNmLGFBQWEsRUFBRTtJQUNoQjtHQUNELE1BQU0sVUFBVTtJQUNkLFFBQVE7SUFDUixTQUFTO0lBQ1QsU0FBUztJQUNWO0FBQ0QsT0FBSTtBQUNGLFdBQ0UsTUFBTSxrQkFBa0IsYUFBYSxDQUFDLFdBQVcscUJBQy9DLFFBQ0Q7WUFDSUQsT0FBZ0I7QUFDdkIsVUFBTSw4QkFDSixnQ0FDQSxNQUNEOztHQUdILE1BQU1FLFlBQTZCLE1BQU0sV0FBVyxLQUFLLFNBQ3ZELEtBQ0csS0FBSyxhQUFhLGlCQUFpQixTQUFTLENBQUMsQ0FDN0MsUUFBUSxhQUFzQyxZQUFZLEtBQUssQ0FDbkU7R0FFRCxNQUFNQyxjQUE0QixNQUFNLFlBQ3JDLEtBQUssZUFBZSxtQkFBbUIsV0FBVyxDQUFDLENBQ25ELFFBQVEsZUFBeUMsY0FBYyxLQUFLO0dBRXZFLE1BQU1DLGFBQTBCLE1BQU0sWUFDbkMsS0FBSyxVQUFVLGtCQUFrQixNQUFNLENBQUMsQ0FDeEMsUUFBUSxVQUE4QixTQUFTLEtBQUs7R0FHdkQsTUFBTSxpQ0FBaUMsV0FDcEMsUUFBUSxVQUFVLE1BQU0sYUFBYSxrQkFBa0IsY0FBYyxDQUNyRSxLQUFLLFVBQVUsTUFBTSxXQUFXLGVBQWU7R0FFbEQsTUFBTUMsb0JBQWlDLFVBQ3BDLEtBQUssU0FDSixLQUNHLFFBQ0UsYUFDQyxFQUNFLFNBQVMsYUFBYSxpQkFBaUIsUUFDdkMsK0JBQStCLFNBQVMsU0FBUyxHQUFHLEVBRXpELENBQ0EsS0FBSyxhQUFhLG9CQUFvQixTQUFTLENBQUMsQ0FDaEQsUUFBUSxZQUFnQyxXQUFXLEtBQUssQ0FDNUQsQ0FDQSxRQUFRLFNBQVMsS0FBSyxTQUFTLEVBQUU7R0FFcEMsTUFBTUMsZUFBNEIsV0FDL0IsS0FBSyxVQUFVO0FBQ2QsUUFDRSxDQUFDLGtCQUFrQixZQUFZLGtCQUFrQixPQUFPLENBQUMsU0FDdkQsTUFBTSxTQUNQLENBRUQsUUFBTyxDQUFDLHNCQUFzQixNQUFNLENBQUM7QUFHdkMsUUFBSSxNQUFNLGFBQWEsa0JBQWtCLGtCQUN2QyxRQUFPLENBQUMsMkJBQTJCLE9BQU8sWUFBWSxDQUFDO0FBR3pELFFBQUksTUFBTSxhQUFhLGtCQUFrQixlQUFlO0tBQ3RELE1BQU0sZUFBZSxVQUNsQixNQUFNLENBQ04sTUFDRSxhQUNDLFNBQVMsT0FBTyxNQUFNLFdBQVcsa0JBQ2pDLE1BQU0sV0FBVyxhQUFhLFNBQVMsV0FDMUM7QUFFSCxTQUFJLGdCQUFnQixhQUFhLGFBQWEsaUJBQWlCLEtBQzdELFFBQU8sQ0FDTCw4QkFBOEIsT0FBTyxhQUFhLFdBQVcsQ0FDOUQ7O0FBSUwsV0FBTyxFQUFFO0tBQ1QsQ0FDRCxRQUFRLFlBQWtDLFFBQVEsU0FBUyxFQUFFO0dBR2hFLE1BQU0saUJBQWlCLENBQUMsR0FBRyxtQkFBbUIsR0FBRyxhQUFhLENBQUMsTUFDNUQsR0FBRyxNQUNGLElBQUksS0FBSyxFQUFFLEdBQUcsVUFBVSxDQUFDLFNBQVMsR0FBRyxJQUFJLEtBQUssRUFBRSxHQUFHLFVBQVUsQ0FBQyxTQUFTLENBQzFFO0FBRUQsVUFBTztJQUFFO0lBQVc7SUFBWTtJQUFhLFVBQVU7SUFBZ0I7Ozs7MEJBUS9DLE9BQ3hCLFlBQzRCO0FBQzVCLE9BQUk7SUFVRixNQUFNLG1CQUFtQixPQVJ2QixNQUFNLGtCQUFrQixhQUFhLENBQUMsYUFBYSx3QkFDakQsRUFDRSx1QkFDRSxzQ0FBc0MsUUFBUSxFQUNqRCxDQUNGLEVBR3dDLElBQUksTUFBTTtJQUNyRCxNQUFNLG1CQUFtQixLQUFLLE1BQU0saUJBQWlCO0FBRXJELFdBQU87S0FDTCxHQUFHO0tBQ0gsaUJBQWlCLGlCQUFpQjtLQUNsQyxlQUFlLGlCQUFpQixpQkFBaUIsRUFBRTtLQUNwRDtZQUNNLEtBQUs7QUFDWixtQkFBTyxTQUFTLG1EQUFtRCxFQUNqRSxLQUNELENBQUM7QUFDRixXQUFPO0tBQ0wsV0FBVztLQUNYLE9BQU87S0FDUCxVQUFVO0tBQ1YsYUFBYSxFQUFFO0tBQ2YsaUJBQWlCO0tBQ2pCLGNBQWM7S0FDZCxlQUFlLEVBQUU7S0FDbEI7Ozs7O3NCQUlpQixPQUNwQixjQUNBLGdCQUNBLGNBQ2tCO0FBQ2xCLE9BQUk7QUFDRixVQUFNLGtCQUFrQixhQUFhLENBQUMsV0FBVyx3QkFBd0IsRUFDdkUsMEJBQTBCO0tBQ3hCLFNBQVM7S0FDVCxTQUFTLFVBQVU7S0FDbkIsWUFBWSxVQUFVO0tBQ3RCLFVBQVUsVUFBVTtLQUNwQixXQUFXLFVBQVU7S0FDckIsY0FBYyxVQUFVO0tBQ3hCLHFCQUFxQixVQUFVO0tBQy9CLGNBQWMsVUFBVTtLQUN4QixpQkFBaUI7TUFDZixhQUFhO01BQ2IsU0FBUyxVQUFVO01BQ25CLGlCQUFpQixVQUFVO01BQzNCLFlBQVksVUFBVTtNQUN2QjtLQUNGLEVBQ0YsQ0FBQztZQUNLLEtBQUs7QUFDWixtQkFBTyxTQUFTLDJCQUEyQixJQUFJOzs7OztpREFLakQsV0FDeUM7QUFDekMsT0FBSSxXQUFXLE9BQVcsUUFBTztBQUNqQyxXQUFRLFFBQVI7SUFDRSxLQUFLLGtCQUFrQixLQUNyQixRQUFPLHlCQUF5QjtJQUNsQyxLQUFLLGtCQUFrQixXQUNyQixRQUFPLHlCQUF5QjtJQUNsQyxLQUFLLGtCQUFrQixJQUNyQixRQUFPLHlCQUF5QjtJQUNsQyxLQUFLLGtCQUFrQixLQUNyQixRQUFPLHlCQUF5QjtJQUNsQyxRQUdFLFFBRCtCOzs7OztzQkFNZixPQUNwQixZQUNtQztBQUNuQyxPQUFJO0lBQ0YsTUFBTSxZQUFZLGNBQWM7SUFDaEMsTUFBTSxlQUFlLFVBQVUsSUFBSSxpQkFBaUI7SUFDcEQsTUFBTSxnQkFBZ0IsVUFBVSxJQUFJLGtCQUFrQjtJQUN0RCxNQUFNLHFCQUFxQixVQUFVLElBQUksdUJBQXVCO0lBQ2hFLE1BQU1DLFVBQWlDO0tBQ3JDLFdBQVc7S0FDWDtLQUNBLFFBQVEsS0FBSyx1Q0FBdUMsY0FBYztLQUNsRSxxQkFBcUIsT0FBTyxPQUFPLGtCQUFrQjtLQUNyRCx1QkFBdUIsT0FBTyxRQUM1QixvQkFBb0Isb0JBQW9CLGlCQUFpQixJQUFJLEVBQUUsQ0FDaEUsQ0FDRSxRQUFRLEdBQUcsZUFBZSxVQUFVLENBQ3BDLEtBQUssQ0FBQyxxQkFBcUIsZ0JBQWdCO0tBQy9DO0lBQ0QsTUFBTSxXQUNKLE1BQU0sa0JBQWtCLGFBQWEsQ0FBQyxXQUFXLGVBQy9DLFFBQ0Q7QUFFSCxXQUFPLHlCQUF5QixTQUFTO1lBQ2xDLEtBQUs7QUFDWixtQkFBTyxTQUFTLDRCQUE0QixLQUFLLEVBQUUsS0FBSyxDQUFDO0FBQ3pEOzs7OztxQ0FJaUMsT0FDbkMsY0FDQSxPQUNBLDRCQUNHO0FBQ0gsa0JBQU8sUUFDTCx5Q0FBeUMsYUFBYSxTQUFTLE1BQU0sNkJBQTZCLDBCQUNuRztBQUNELE9BQUk7QUFDRixVQUFNLGtCQUFrQixhQUFhLENBQUMsbUJBQW1CLDZDQUN2RCxFQUNFLG9DQUFvQztLQUNsQyxnQkFBZ0I7S0FDaEI7S0FDQSwyQkFBMkI7S0FDNUIsRUFDRixDQUNGO1lBQ00sS0FBSztBQUNaLG1CQUFPLFNBQVMsNkNBQTZDLEVBQUUsS0FBSyxDQUFDOzs7OztxQ0FLdkUsa0JBQWtCLGFBQWEsQ0FBQzs7O0FBR3BDLDJCQUFlOzs7O0FDNWxCZixNQUFNLDRCQUEyQztDQUUvQyxNQUFNLFNBRFcsSUFBSSxVQUFVLENBQ1AsV0FBVztBQUVuQyxRQUFPO0VBQ0wsSUFBSSxRQUFRLElBQUk7RUFDaEIsV0FBVyxRQUFRLElBQUk7RUFDdkIsYUFBYSxRQUFRLFFBQVE7RUFDN0Isb0JBQW9CLFFBQVEsUUFBUTtFQUNwQyxhQUFhLFFBQVEsUUFBUTtFQUM3QixTQUFTLFFBQVEsU0FBUztFQUMxQixnQkFBZ0IsUUFBUSxTQUFTO0VBQ2pDLFdBQVcsUUFBUTtFQUNwQjs7QUFHSCxNQUFNLHNCQUFzQixjQUFtRCxPQUFVO0FBRXpGLE1BQWFDLHdCQUFpRSxFQUFFLGVBQWU7Q0FDN0YsTUFBTSxFQUFFLFNBQVMsU0FBUyxhQUFhLHdCQUF3QixpQkFBaUI7Q0FFaEYsTUFBTSxDQUFDLFNBQVMsY0FBYyxTQUFTLE1BQU07QUFFN0MsaUJBQWdCO0FBR2QsYUFBVyxvQkFBb0I7SUFDOUIsQ0FBQyxvQkFBb0IsQ0FBQztDQUV6QixNQUFNLHVCQUF1QjtDQUM3QixNQUFNLHNCQUFzQjtDQUU1QixNQUFNLG9DQUFvQyxrQkFDZCxRQUFRLHFCQUFxQixJQUFJLFFBQzNELENBQUMsUUFBUSxDQUNWO0NBRUQsTUFBTSxtQ0FBbUMsa0JBQ2IsUUFBUSxvQkFBb0IsSUFBSSxRQUMxRCxDQUFDLFFBQVEsQ0FDVjtDQUVELE1BQU0saUNBQWlDLGFBQ3BDLFdBQTJCO0FBQzFCLGlCQUFPLFFBQVEsb0RBQW9ELFNBQVM7QUFDNUUsVUFBUSxxQkFBcUIsT0FBTztBQUVwQyxTQUFPO0lBRVQsQ0FBQyxTQUFTLG9CQUFvQixDQUMvQjtDQUVELE1BQU0sa0NBQWtDLGFBQ3JDLFdBQTJCO0FBQzFCLGlCQUFPLFFBQVEscURBQXFELFNBQVM7QUFDN0UsVUFBUSxzQkFBc0IsT0FBTztBQUVyQyxTQUFPO0lBRVQsQ0FBQyxTQUFTLHFCQUFxQixDQUNoQztDQUVELE1BQU0sb0NBQW9DLGtCQUFrQjtBQUMxRCxpQkFBTyxRQUFRLHVEQUF1RDtBQUd0RSxVQUFRLHNCQUFzQixHQUFHO0lBQ2hDLENBQUMsU0FBUyxxQkFBcUIsQ0FBQztDQUVuQyxNQUFNLHFCQUFxQixrQkFBMEI7RUFDbkQsTUFBTSxpQkFBaUIsbUNBQW1DO0FBQzFELE1BQUksZUFDRixRQUFPO0VBR1QsTUFBTSxnQkFBZ0Isa0NBQWtDO0FBQ3hELE1BQUksY0FDRixRQUFPO0FBR1QsU0FBTywrQkFBK0Isa0JBQWtCQyxJQUFNLEdBQUc7SUFDaEU7RUFDRDtFQUNBO0VBQ0E7RUFDRCxDQUFDO0NBRUYsTUFBTSxlQUFlLFlBQVksWUFBMkI7QUFDMUQsTUFBSSxDQUFDLFNBQVM7QUFDWixrQkFBTyxRQUFRLGtFQUFrRSxPQUFVO0FBQzNGOztBQUdGLE1BQUk7R0FHRixNQUFNLFlBQVk7R0FDbEIsTUFBTSxTQUFTLG9CQUFvQjtHQUNuQyxNQUFNLG1CQUFtQixxQkFBcUI7QUFPOUMsU0FBTUMscUJBQWtCLGFBQWEsUUFBUSxXQUFXLGlCQUFpQjtXQUNsRSxPQUFPO0FBQ2Qsa0JBQU8sU0FBUyxzQ0FBc0MsTUFBTTs7SUFFN0QsQ0FBQyxTQUFTLG1CQUFtQixDQUFDO0NBRWpDLE1BQU0sUUFBUSxlQUNMO0VBQ0w7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNELEdBQ0Q7RUFDRTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0QsQ0FDRjtBQUVELFFBQU8sb0JBQUMsb0JBQW9CO0VBQWdCO0VBQVE7R0FBd0M7O0FBRzlGLE1BQWEsd0JBQXdCO0NBQ25DLE1BQU0sVUFBVSxXQUFXLG9CQUFvQjtBQUMvQyxLQUFJLENBQUMsUUFDSCxPQUFNLElBQUksTUFBTSw2REFBNkQ7QUFFL0UsUUFBTzs7Ozs7QUNqRFQsTUFBTSxpQ0FBaUMsZ0JBQ3JDLHVCQUNBLFFBQ0Esb0JBQ0EsRUFDRSxXQUFXLE1BQ1osQ0FDRjtBQUVELE1BQWEsa0JBQWtCLE1BQzVCLFFBQTBCO0NBQ3pCLE1BQU0sbUJBQW1CLElBQUksK0JBQStCO0FBQzVELEtBQUksb0JBQW9CLEtBQ3RCLFFBQU8sRUFBRTtBQUVYLFFBQU8sS0FBSyxNQUFNLGlCQUFpQjtJQUVwQyxLQUFLLEtBQUssVUFBc0U7Q0FHL0UsTUFBTSxXQUFXO0VBQUUsR0FERSxJQUFJLGdCQUFnQjtHQUNKLE1BQU0sTUFBTSxNQUFNO0VBQVU7QUFFakUsS0FBSSxnQ0FBZ0MsS0FBSyxVQUFVLFNBQVMsQ0FBQztFQUVoRTtBQUVELE1BQU0sb0NBQW9DLGdCQUN4QywwQkFDQSxRQUNBLG9CQUNBLEVBQ0UsV0FBVyxNQUNaLENBQ0Y7QUFDRCxNQUFNLDZCQUE2QixLQUFpQyxPQUFVO0FBRTlFLE1BQWEscUJBQXFCLE1BQy9CLFFBQW9DO0NBQ25DLE1BQU0sc0JBQXNCLElBQUksa0NBQWtDO0FBQ2xFLEtBQUksdUJBQXVCLEtBQ3pCO0FBS0YsUUFBTyxLQUFLLE1BQU0sb0JBQW9CO0lBRXZDLEdBQUcsS0FBSyxVQUFzQztBQUM3QyxLQUFJLFNBQVMsTUFBTTtBQUNqQixNQUFJLG1DQUFtQyxPQUFVO0FBQ2pELE1BQUksNEJBQTRCLE9BQVU7QUFDMUM7O0FBR0YsS0FBSSw0QkFBNEIsTUFBTTtBQUN0QyxLQUFJLG1DQUFtQyxLQUFLLFVBQVUsTUFBTSxDQUFDO0VBRWhFO0FBRUQsTUFBTSx3QkFBd0IsTUFBYztBQUM1QyxNQUFNLHdCQUF3QixNQUFjO0FBQzVDLE1BQU0sOEJBQThCLE1BQWM7QUFDbEQsTUFBTSx5QkFBeUIsTUFBYztBQUM3QyxNQUFNLG9CQUFvQixNQUFjO0FBQ3hDLE1BQU0sa0JBQWtCLE1BQWM7QUFDdEMsTUFBTSxnQ0FBZ0MsTUFBeUI7QUFDL0QsTUFBTSxzQkFBc0IsS0FBOEMsTUFBTTtBQUVoRixNQUFhLGdCQUFnQixNQUFNLFFBQVEsSUFBSSxzQkFBc0IsQ0FBQztBQUN0RSxNQUFhLGdCQUFnQixNQUFNLFFBQVEsSUFBSSxzQkFBc0IsQ0FBQztBQUN0RSxNQUFhLHNCQUFzQixNQUFNLFFBQVEsSUFBSSw0QkFBNEIsQ0FBQztBQUNsRixNQUFhLGlCQUFpQixNQUFNLFFBQVEsSUFBSSx1QkFBdUIsQ0FBQztBQUN4RSxNQUFhLFlBQVksTUFBTSxRQUFRLElBQUksa0JBQWtCLENBQUM7QUFDOUQsTUFBYSxVQUFVLE1BQU0sUUFBUSxJQUFJLGdCQUFnQixDQUFDO0FBQzFELE1BQWEsd0JBQXdCLE1BQU0sUUFBUSxJQUFJLDhCQUE4QixDQUFDO0FBQ3RGLE1BQWEsY0FBYyxNQUFNLFFBQVEsSUFBSSxvQkFBb0IsQ0FBQztBQUNsRSxNQUFhLDJCQUEyQixLQUFLLE1BQU07QUFFbkQsTUFBYSxrQkFBa0IsTUFDNUIsUUFBcUI7Q0FDcEIsTUFBTSxVQUFVLElBQUksWUFBWTtBQUNoQyxLQUFJLFlBQVksZ0JBQWdCLElBQzlCLFFBQU87RUFDTCxXQUFXLElBQUksY0FBYztFQUM3QjtFQUNBLFdBQVcsSUFBSSxjQUFjO0VBQzdCLGlCQUFpQixJQUFJLG9CQUFvQjtFQUN6QyxLQUFLLElBQUksUUFBUTtFQUNsQjtBQUVILEtBQUksWUFBWSxnQkFBZ0IsSUFDOUIsUUFBTztFQUNMLFdBQVcsSUFBSSxjQUFjO0VBQzdCO0VBQ0EsT0FBTyxJQUFJLFVBQVU7RUFDckIsS0FBSyxJQUFJLFFBQVE7RUFDbEI7QUFFSCxLQUFJLFlBQVksZ0JBQWdCLFVBQzlCLFFBQU87RUFDTCxXQUFXLElBQUksY0FBYztFQUM3QjtFQUNBLEtBQUssSUFBSSxRQUFRO0VBQ2pCLG1CQUFtQixJQUFJLHNCQUFzQjtFQUM5QztBQUVILE9BQU0sSUFBSSxNQUFNLDhCQUE4QjtJQUUvQyxHQUFHLEtBQUssZUFBNEI7QUFDbkMsS0FBSSxxQkFBcUIsV0FBVyxRQUFRO0FBQzVDLEtBQUksdUJBQXVCLFdBQVcsVUFBVTtBQUNoRCxLQUFJLFdBQVcsWUFBWSxnQkFBZ0IsS0FBSztBQUM5QyxNQUFJLHVCQUF1QixXQUFXLFVBQVU7QUFDaEQsTUFBSSw2QkFBNkIsV0FBVyxnQkFBZ0I7QUFDNUQsTUFBSSxpQkFBaUIsV0FBVyxJQUFJOztBQUV0QyxLQUFJLFdBQVcsWUFBWSxnQkFBZ0IsS0FBSztBQUM5QyxNQUFJLG1CQUFtQixXQUFXLE1BQU07QUFDeEMsTUFBSSxpQkFBaUIsV0FBVyxJQUFJOztBQUV0QyxLQUFJLFdBQVcsWUFBWSxnQkFBZ0IsV0FBVztBQUNwRCxNQUFJLGlCQUFpQixXQUFXLElBQUk7QUFDcEMsTUFBSSwrQkFBK0IsV0FBVyxrQkFBa0I7O0VBR3JFOzs7O0FDOU1ELE1BQU0scUJBQXFCLEtBQXlCLE9BQVU7QUFFOUQsTUFBYSxhQUFhLE1BQ3ZCLFFBQVE7Q0FDUCxNQUFNLGNBQWMsSUFBSSxtQkFBbUI7QUFFM0MsS0FBSSxZQUNGLFFBQU87Q0FHVCxNQUFNLEVBQUUsdUJBQXVCLGlCQUFpQjtBQUNoRCxRQUFPLG9CQUFvQjtJQUU1QixHQUFHLEtBQUssVUFBOEI7QUFDckMsS0FBSSxvQkFBb0IsTUFBTTtFQUVqQztBQUVELE1BQWEsbUJBQW1CLEtBQTBDLE9BQVU7QUFFcEYsTUFBYSxnQkFBZ0IsTUFDMUIsUUFBMkIsSUFBSSxrQkFBa0IsSUFBSSxrQkFBa0IsSUFDekU7QUFDRCxNQUFhLGFBQWEsZ0JBQXdCLDZCQUE2QkMsSUFBTSxFQUFFLFFBQVcsRUFDaEcsV0FBVyxNQUNaLENBQUM7Ozs7QUNyQkYsSUFBWSw0RUFBTDtBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFnQkYsTUFBTSxtQkFBbUIsY0FBMkMsS0FBSztBQUV6RSxNQUFhQyxxQkFBOEQsRUFBRSxlQUFlO0NBQzFGLE1BQU0sU0FBUyxhQUFhLFdBQVc7Q0FDdkMsTUFBTSxrQkFBa0IsYUFBYSxvQkFBb0I7Q0FDekQsTUFBTSxnQkFBZ0IsYUFBYSxrQkFBa0I7Q0FDckQsTUFBTSxjQUFjLGFBQWEsc0NBQXNDO0NBQ3ZFLE1BQU0sTUFBTSxhQUFhLFFBQVE7Q0FDakMsTUFBTSxnQkFBZ0IsYUFBYSxrQkFBa0I7QUFDM0IsY0FBYSxzQkFBc0I7Q0FDN0QsTUFBTSxFQUFFLFlBQVksaUJBQWlCO0NBQ3JDLE1BQU0sRUFDSixXQUNBLGtCQUNBLG9CQUNBLHFCQUNBLE1BQ0EsY0FDQSxpQkFDRSxpQkFBaUI7Q0FFckIsTUFBTSxFQUFFLHVCQUF1Qix1QkFBdUI7Q0FFdEQsTUFBTSxDQUFDLGlCQUFpQixzQkFBc0IsTUFBTSxTQUNsRCxPQUNEO0NBQ0QsTUFBTSxDQUFDLGlDQUFpQyxzQ0FBc0MsTUFBTSxTQUVsRixPQUFVO0NBQ1osTUFBTSxDQUFDLDBCQUEwQiwrQkFBK0IsTUFBTSxTQUVwRSxFQUFFLENBQUM7Q0FFTCxNQUFNLFVBQVUsUUFBUSxVQUFVLHNCQUFzQixtQkFBbUIsT0FBTztDQUVsRixNQUFNLDBCQUEwQixrQkFBMkM7RUFDekUsTUFBTSxhQUFhLGVBQ2YsYUFBYSxRQUFpQyxLQUFLLFNBQVM7QUFDMUQsT0FBSSxLQUFLLFFBQVEsS0FBSyxTQUFTLEtBQzdCLFFBQU87SUFBRSxHQUFHO0tBQU0sZ0JBQWdCLEtBQUssU0FBUyxLQUFLO0lBQU87QUFFOUQsVUFBTztLQUNOLEVBQUUsQ0FBQyxHQUNOLEVBQUU7RUFDTixNQUFNLGtCQUFrQixFQUFFO0FBTzFCLFNBQU87R0FKTCxHQUFHO0dBQ0gsR0FBRztHQUtILEdBQUc7R0FHSCxRQUFRO0dBQ1IsU0FBUyxRQUFRLGlCQUFpQixPQUFPO0dBQ3pDLEtBQUssT0FBTztHQUNaLFlBQVk7R0FDWixrQkFBa0I7R0FDbEIsV0FBVztHQUNYLGVBQWU7R0FDZixnQkFBZ0I7R0FDaEIsZ0JBQWdCO0dBQ2hCLGNBQWM7R0FDZCxZQUFZO0dBQ1osaUJBQWlCO0dBQ2pCLG1CQUFtQjtHQUNwQjtJQUNBO0VBQUM7RUFBYztFQUEwQjtFQUFLO0VBQWU7RUFBYztFQUFPLENBQUM7Q0FFdEYsTUFBTSxpQ0FBaUMsYUFFbkMsV0FDQSxlQUM0QjtFQUM1QixNQUFNLFNBQVMsVUFBVSxhQUFhLENBQUMsUUFBUSxRQUFRLElBQUk7QUFDM0QsU0FBTyxPQUFPLFFBQVEsV0FBVyxDQUFDLFFBQy9CLEtBQUssQ0FBQyxLQUFLQyxhQUFXO0FBQ3JCLE9BQUksR0FBRyxPQUFPLEdBQUcsU0FBU0E7QUFDMUIsVUFBTztLQUVULEVBQUUsQ0FDSDtJQUVILEVBQUUsQ0FDSDtDQUVELE1BQU0sNkJBQTZCLGtCQUEyQjtFQUM1RCxNQUFNLFlBQVksUUFDaEIsaUJBQWlCLGFBQWEsaUJBQzVCLG9CQUFvQix3QkFBd0IsSUFDNUMsb0JBQW9CLHFCQUFxQixhQUFhLG9CQUFvQixDQUM3RTtFQUNELE1BQU0sYUFBYTtBQUVuQixNQUFJO0FBQ0Ysa0JBQU8sU0FDTCwrREFBK0QsVUFBVSxjQUFjLGFBQ3hGO0FBRUQsT0FBSSxDQUFDLFVBQ0gsUUFBTztBQUtULFVBQU87V0FDQSxHQUFHO0FBQ1Ysa0JBQU8sU0FBUywyREFBMkQsRUFBRTtBQUM3RSxVQUFPOztJQUVSLENBQUMsY0FBYyxtQkFBbUIsQ0FBQztDQUV0QyxNQUFNLDZCQUE2QixrQkFBb0M7QUFDckUsTUFBSSxvQ0FBb0MsT0FDdEMsUUFBTztFQUdULE1BQU1DLGFBQStCO0dBQ25DLE1BQU07R0FDTixNQUFNO0dBQ04sT0FBTyxZQUFZO0dBQ25CLFNBQVMsT0FBTyxVQUFpQztJQUMvQyxJQUFJQztBQU9KLFFBTHVCLENBQ3JCLDJCQUNBLFlBQVksdUJBQXVCLGVBQ3BDLENBRWtCLFNBQVMsTUFBTSxXQUFXLEVBQUU7S0FDN0MsTUFBTUMsbUJBQTJDLEVBQUU7QUFFbkQsU0FBSSxVQUNGLGtCQUFpQixnQ0FBZ0M7QUFFbkQsU0FBSSxpQkFDRixRQUFPLFFBQVEsaUJBQWlCLENBQUMsU0FBUyxDQUFDLEtBQUtILGFBQVc7QUFDekQsdUJBQWlCLHFDQUFxQyxTQUFTLE9BQU9BLFFBQU07T0FDNUU7QUFFSixTQUFJLG1CQUNGLGtCQUFpQix5Q0FBeUM7QUFFNUQsU0FBSSxvQkFDRixrQkFBaUIsMENBQ2YsS0FBSyxVQUFVLG9CQUFvQjtBQUV2QyxTQUFJLFFBQVEsS0FDVixrQkFBaUIsMkJBQTJCLE9BQU8sS0FBSztLQUcxRCxNQUFNLGtCQUFrQixtQkFBb0IsaUJBQWlCO0tBQzdELE1BQU0sNEJBQTRCLE9BQU8sUUFBUSxnQkFBZ0IsQ0FBQyxRQUcvRCxLQUFLLENBQUMsS0FBS0EsY0FBWTtNQUN0QixHQUFHO09BQ0YsbUJBQW1CLFFBQVEsR0FBR0E7TUFDaEMsR0FDRCxFQUFFLENBQ0g7S0FFRCxNQUFNLG1CQUFtQixFQUN2Qix5QkFBeUIsT0FBTyxhQUFhLEtBQUssRUFDbkQ7QUFFRCxxQkFBZ0I7TUFDZCxHQUFHO01BQ0gsa0JBQWtCO09BQ2hCLEdBQUcsTUFBTTtPQUNULEdBQUcseUJBQXlCO09BQzVCLEdBQUc7T0FDSCxHQUFHO09BQ0gsR0FBRztPQUNKO01BQ0Y7VUFFRCxpQkFBZ0I7QUFHbEIscUJBQWlCLFNBQVMsWUFBWSxpQkFBaUIsY0FBYztBQUVyRSxXQUFPOztHQUVWO0FBQ0QscUNBQW1DLFdBQVc7QUFDOUMsU0FBTztJQUNOO0VBQ0Q7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNELENBQUM7QUFFRixpQkFBZ0I7QUFDZCxNQUFJLFdBQVcsQ0FBQyxpQkFBaUI7R0FDL0IsTUFBTUksMkJBQTBDLGdCQUFnQjtHQUNoRSxNQUFNLG9CQUFvQiw0QkFBNEI7QUFDdEQsNEJBQXlCLElBQUksNEJBQTRCLENBQUM7QUFDMUQsNEJBQXlCLEtBQUssaUJBQWtCLFFBQVM7SUFDdkQsWUFBWTtJQUNaLGlCQUFpQixFQUNmLFdBQVcsTUFDWjtJQUNELGFBQWE7S0FDWCxhQUFhO0tBQ2IsV0FBVyxFQUNULHFCQUFxQixZQUN0QjtLQUNELFVBQVU7S0FDVixrQkFBa0I7S0FDbEIsZUFBZTtLQUNoQjtJQUNGLENBQUM7QUFDRixzQkFBbUIseUJBQXlCOztJQUU3QztFQUNEO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0QsQ0FBQztDQUVGLE1BQU0sYUFBYSxZQUNqQixPQUFPLEVBQ0wsV0FDQSxZQUNBLGFBQ0EsNEJBQTRCLFlBQ1M7QUFDckMsaUJBQU8sU0FBUyxvQkFBb0IsVUFBVTtBQUM5QyxNQUFJO0dBQ0YsTUFBTSxxQkFBcUIsWUFBWTtBQUV2QyxPQUFJLENBQUMsaUJBQWlCO0FBQ3BCLG1CQUFPLFFBQVEsOEJBQThCLFFBQVcsRUFDdEQsWUFBWSxvQkFDYixDQUFDO0FBQ0Y7O0dBR0YsTUFBTSxZQUFZLEtBQUssVUFBVTtJQUMvQjtJQUNBO0lBQ0EsNkJBQVksSUFBSSxNQUFNLEVBQUMsYUFBYTtJQUNyQyxDQUFDO0dBRUYsTUFBTSxPQURVLElBQUksYUFBYSxDQUNaLE9BQU8sVUFBVTtHQUd0QyxNQUFNLGFBQWEsTUFBTSxPQUFPLE9BQU8sT0FBTyxXQUFXLEtBQUs7R0FFOUQsTUFBTSxrQkFEWSxNQUFNLEtBQUssSUFBSSxXQUFXLFdBQVcsQ0FBQyxDQUN0QixLQUFLLE1BQU0sRUFBRSxTQUFTLEdBQUcsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLENBQUMsS0FBSyxHQUFHO0FBRXRGLGtCQUFPLFNBQVMsc0JBQXNCLHNCQUFzQixNQUFNO0lBQ2hFLFlBQVk7SUFDWixPQUFPO0lBQ1IsQ0FBQztBQUVGLG1CQUFnQixNQUNkLG9CQUNBO0lBQ0UsR0FBRyx5QkFBeUI7SUFDNUIsR0FBRztJQUNILEdBQUksYUFBYSwrQkFBK0IsV0FBVyxXQUFXLEdBQUcsRUFBRTtJQUM1RSxFQUNEO0lBQ0UsR0FBRztJQUNILFdBQVc7SUFDWixDQUNGO0FBRUQsT0FBSSw2QkFBNkIsYUFBYTtBQUU1QyxtQkFBTyxTQUFTLDJCQUEyQixtQkFBbUI7QUFDOUQsUUFBSSxPQUFPLFVBQ1QsQ0FBQyxPQUFPLFVBQW9CLEtBQUs7S0FDL0IsT0FBTztLQUNLO0tBQ2IsQ0FBQzs7V0FHQyxLQUFLO0FBQ1osa0JBQU8sU0FBUyxvQ0FBb0MsS0FBSztJQUN2RDtJQUNBO0lBQ0QsQ0FBQzs7SUFHTjtFQUFDO0VBQWlCO0VBQXlCO0VBQWdDO0VBQVksQ0FDeEY7Q0FFRCxNQUFNLFFBQVEsZUFDTDtFQUNMO0VBQ0E7RUFDQSw4QkFBOEIsVUFDNUIsNEJBQTRCLE1BQU07RUFDckMsR0FDRDtFQUFDO0VBQVk7RUFBUztFQUE0QixDQUNuRDtBQUVELFFBQU8sb0JBQUMsaUJBQWlCO0VBQWdCO0VBQVE7R0FBcUM7O0FBR3hGLE1BQWEscUJBQXFCO0NBQ2hDLE1BQU0sVUFBVSxXQUFXLGlCQUFpQjtBQUM1QyxLQUFJLENBQUMsUUFDSCxPQUFNLElBQUksTUFBTSxxREFBcUQ7QUFFdkUsUUFBTzs7Ozs7QUM5WFQsTUFBTSxxQ0FBcUMsQ0FBQyxhQUFhLGNBQWM7QUFDdkUsTUFBTSwrQkFBK0I7QUFDckMsTUFBTSxnQ0FBZ0M7Ozs7Ozs7O0FBU3RDLE1BQU0sb0JBQW9CLFVBQTJCO0NBQ25ELE1BQU0sa0JBQWtCLE1BQU0sUUFBUSxTQUFTLEdBQUcsQ0FBQyxhQUFhO0FBQ2hFLFFBQU8sbUNBQW1DLE1BQU0sU0FBUyxnQkFBZ0IsU0FBUyxLQUFLLENBQUM7Ozs7Ozs7QUFRMUYsTUFBTSx3QkFDSixPQUNBLFVBQ0c7Q0FDSCxJQUFJQztBQUVKLEtBQUkseUJBQXlCLE1BQU0sQ0FDakMsY0FBYTtFQUNYLE9BQU8sTUFBTSxVQUFVLElBQUksU0FBUyxLQUFLLGFBQWE7R0FDcEQsV0FBVyxRQUFRO0dBQ25CLGVBQWUsUUFBUTtHQUN2QixPQUFPLFFBQVE7R0FDZixVQUFVLFFBQVE7R0FDbkIsRUFBRTtFQUNILFVBQVUsTUFBTSxVQUFVLElBQUk7RUFDOUIsc0JBQXNCO0VBQ3ZCO1VBQ1Esb0JBQW9CLE1BQU0sQ0FDbkMsY0FBYTtFQUNYLE9BQU8sTUFBTSxVQUFVLE1BQU0sS0FBSyxVQUFVO0dBQzFDLFdBQVcsS0FBSztHQUNoQixlQUFlLEtBQUs7R0FDcEIsT0FBTyxLQUFLO0dBQ1osVUFBVSxLQUFLO0dBQ2hCLEVBQUU7RUFDSCxVQUFVLE1BQU0sVUFBVTtFQUMxQixzQkFBc0I7RUFDdkI7S0FFRCxjQUFhO0VBQ1gsa0JBQWtCLEVBQUUsR0FBRyxPQUFPO0VBQzlCLHNCQUFzQjtFQUN2QjtBQUdILE9BQU0sdUJBQXVCLGtCQUFrQixFQUM3QyxZQUNELENBQUM7Ozs7OztBQU9KLE1BQWEsd0JBQ1gsVUFDRztDQUNILElBQUksV0FBVztDQUlmLE1BQU0sMkJBQTJCO0FBQy9CLE1BQUksQ0FBQyxPQUFPLGFBQWEsQ0FBRSxPQUFPLFVBQWtCLE1BQU07QUFDeEQsZUFBWTtBQUVaLE9BQUksWUFBWSwrQkFBK0I7QUFDN0MsbUJBQU8sU0FDTCw2Q0FBNkMsOEJBQThCLFdBQzVFO0FBQ0Q7O0FBR0YsY0FBVyxvQkFBb0IsNkJBQTZCO0FBQzVEOztBQUdGLGlCQUFPLFNBQVMsZ0VBQWdFO0VBQ2hGLE1BQU0sZUFBZSxPQUFPLFVBQVU7QUFDdEMsU0FBTyxVQUFVLFFBQVEsR0FBRyxTQUFvQjtBQUM5QyxPQUFJLHFCQUFxQixLQUFLLEdBQUcsSUFBSSxpQkFBa0IsS0FBSyxHQUFXLE1BQU0sQ0FDM0Usc0JBQXFCLEtBQUssSUFBMEIsTUFBTTtBQUk1RCxVQUFPLGFBQWEsTUFBTSxPQUFPLFdBQVcsS0FBSzs7O0FBSXJELHFCQUFvQjs7QUFHdEIsTUFBYSxpQkFDWCxVQUNHO0FBSUgsT0FBTSx1QkFBdUIsYUFBYTs7Ozs7QUNoSDVDLE1BQWEsMkJBQTJCLGFBQXNDO0NBQzVFLFNBQVMsUUFBUTtDQUNqQixRQUFRLFFBQVE7Q0FDaEIsU0FBUyxRQUFRO0NBQ2pCLGdCQUFnQixRQUFRO0NBQ3hCLFFBQVEsUUFBUTtDQUNoQixLQUFLLFFBQVE7Q0FDZDs7OztBQ0pELE1BQWEsK0JBQStCLFNBQWtDO0FBQzVFLEtBQ0UsS0FBSyxhQUFhLGtCQUFrQixZQUNwQyxLQUFLLGFBQWEsa0JBQWtCLFVBRXBDLFFBQU87RUFDTCxVQUFVLEtBQUs7RUFDZixZQUFZLEtBQUs7RUFDakIsVUFBVSxLQUFLO0VBQ2YsWUFBWTtHQUNWLFlBQVksS0FBSyxXQUFXO0dBQzVCLG1CQUFtQixLQUFLLFdBQVc7R0FDbkMsS0FBSyxLQUFLLFdBQVc7R0FDdEI7RUFDRjtBQUdILEtBQUksS0FBSyxhQUFhLGtCQUFrQixTQUN0QyxRQUFPO0VBQ0wsVUFBVSxLQUFLO0VBQ2YsWUFBWSxLQUFLO0VBQ2pCLFVBQVUsS0FBSztFQUNmLFlBQVk7R0FDVixVQUFVLHFCQUFxQjtHQUMvQixZQUFZLEVBRVYsSUFBSyxLQUFLLFdBQVcsV0FBK0IsSUFDckQ7R0FDRjtFQUNGO0FBR0gsS0FBSSxLQUFLLGFBQWEsa0JBQWtCLFdBQ3RDLFFBQU87RUFDTCxVQUFVLEtBQUs7RUFDZixZQUFZLEtBQUs7RUFDakIsVUFBVSxLQUFLO0VBQ2YsWUFBWSxFQUNWLE9BQU8sS0FBSyxXQUFXLE9BQ3hCO0VBQ0Y7QUFHSCxLQUFJLEtBQUssYUFBYSxrQkFBa0IsT0FDdEMsUUFBTztFQUNMLFVBQVUsS0FBSztFQUNmLFlBQVksS0FBSztFQUNqQixVQUFVLEtBQUs7RUFDZixZQUFZO0dBQ1YsYUFBYSxLQUFLLFdBQVc7R0FDN0Isa0JBQWtCLEtBQUssV0FBVztHQUNuQztFQUNGO0FBR0gsS0FBSSxLQUFLLGFBQWEsa0JBQWtCLGtCQUN0QyxRQUFPO0VBQ0wsVUFBVSxLQUFLO0VBQ2YsWUFBWSxLQUFLO0VBQ2pCLFVBQVUsS0FBSztFQUNmLFlBQVksRUFDVixlQUFlLEtBQUssV0FBVyxjQUNoQztFQUNGO0FBR0gsS0FBSSxLQUFLLGFBQWEsa0JBQWtCLFVBQ3RDLFFBQU87RUFDTCxVQUFVLEtBQUs7RUFDZixZQUFZLEtBQUs7RUFDakIsVUFBVSxLQUFLO0VBQ2YsWUFBWTtHQUNWLEtBQUssS0FBSyxXQUFXO0dBQ3JCLHFCQUFxQixLQUFLLFdBQVc7R0FDdEM7RUFDRjtBQUdILEtBQUksS0FBSyxhQUFhLGtCQUFrQixjQUN0QyxRQUFPO0VBQ0wsVUFBVSxLQUFLO0VBQ2YsWUFBWSxLQUFLO0VBQ2pCLFVBQVUsS0FBSztFQUNmLFlBQVk7R0FDVixlQUFlLEVBQUUsR0FBRyxLQUFLLFdBQVcsY0FBYztHQUNsRCxrQkFBa0IsS0FBSyxXQUFXO0dBQ2xDLFdBQVcsS0FBSyxXQUFXO0dBQzVCO0VBQ0Y7QUFJSCxRQUFPO0VBQ0wsVUFBVSxLQUFLO0VBQ2YsWUFBWSxLQUFLO0VBQ2pCLFVBQVUsS0FBSztFQUNoQjs7Ozs7QUN4R0gsTUFBYSxlQUFrQixPQUFZLFNBQWlCO0NBQzFELE1BQU0sT0FBTyxFQUFFO0FBQ2YsTUFBSyxJQUFJLElBQUksR0FBRyxJQUFJLE1BQU0sS0FBSyxFQUM3QixNQUFLLEtBQUssTUFBTSxRQUFRLEdBQU0sVUFBa0IsUUFBUSxTQUFTLEVBQUUsQ0FBQztBQUV0RSxRQUFPOzs7OztBQ0hULE1BQWEsNkJBQ1gsY0FDQSxxQkFDRztDQUNILE1BQU0sa0JBQWtCLGFBQ3JCLFFBQVEsWUFBWSxRQUFRLFNBQVNDLGNBQVksV0FBVyxRQUFRLFVBQVUsU0FBUyxDQUN2RixLQUFLLE1BQU0sRUFBNEI7QUFFMUMsUUFBTyxDQUNMLEdBQUcsZ0JBQWdCLFFBQVEsTUFBTSxFQUFFLFVBQVUsT0FBTyxpQkFBaUIsRUFDckUsR0FBRyxnQkFBZ0IsUUFBUSxNQUFNLEVBQUUsVUFBVSxPQUFPLGlCQUFpQixDQUN0RSxDQUFDLEtBQUssTUFBTSxFQUFFLFNBQVUsU0FBVTs7Ozs7QUNickMsTUFBYSw0QkFBNEI7Q0FDdkMsSUFBSSxlQUFlLFNBQVMsY0FBYyx3QkFBd0I7QUFDbEUsS0FBSSxjQUFjO0VBQ2hCLE1BQU0sVUFBVSxhQUFhLGFBQWEsVUFBVTtBQUVwRCxNQUFJLENBRG9CLFNBQVMsU0FBUyxrQkFBa0IsQ0FFMUQsY0FBYSxhQUFhLFdBQVcsR0FBRyxRQUFRLG1CQUFtQjtBQUVyRTs7QUFHRixnQkFBZSxTQUFTLGNBQWMsT0FBTztBQUM3QyxjQUFhLGFBQWEsUUFBUSxXQUFXO0FBQzdDLGNBQWEsYUFBYSxXQUFXLHVEQUF1RDtBQUM1RixVQUFTLEtBQUssWUFBWSxhQUFhOzs7OztBQ0x6QyxNQUFhLGlDQUNYLE9BQ0EsMkJBQ3dCO0FBQ3hCLEtBQUksTUFBTSxhQUFhLGtCQUFrQixjQUN2QztDQUdGLE1BQU0scUJBQXFCLE9BQU8sUUFBUSx1QkFBdUIsT0FBTyxXQUFXLENBQ2hGLEtBQUssQ0FBQyxLQUFLLFdBQVcsR0FBRyxNQUFNLE1BQU0sSUFBSSxNQUFNLFdBQVcsYUFBYSxPQUFPLENBQzlFLEtBQUssS0FBSztBQUViLFFBQU87RUFDTCxJQUFJLE1BQU07RUFDVixNQUFNQyxjQUFZO0VBQ2xCLE1BQU1DLGNBQVk7RUFDbEIsV0FBVyxNQUFNO0VBQ2pCLFVBQVUsRUFDUixTQUFTLG9CQUNWO0VBQ0Y7Ozs7Ozs7Ozs7OztBQ25CSCxNQUFhLHlCQUF5QixVQUEwQztBQUM5RSxLQUFJLE1BQU0sYUFBYSxrQkFBa0IsV0FDdkMsUUFBTztFQUNMLElBQUksTUFBTTtFQUNWLE1BQU1DLGNBQVk7RUFDbEIsTUFBTUMsY0FBWTtFQUNsQixXQUFXLE1BQU07RUFDakIsVUFBVSxFQUNSLFNBQVMsTUFBTSxXQUFXLE9BQzNCO0VBQ0Y7QUFHSCxLQUFJLE1BQU0sYUFBYSxrQkFBa0IsT0FDdkMsUUFBTztFQUNMLElBQUksTUFBTTtFQUNWLE1BQU1ELGNBQVk7RUFDbEIsTUFBTUMsY0FBWTtFQUNsQixXQUFXLE1BQU07RUFDakIsVUFBVTtHQUNSLFlBQVksTUFBTSxXQUFXLGNBQWM7R0FDM0MsaUJBQWlCLE1BQU0sV0FBVyxtQkFBbUIsRUFBRTtHQUN4RDtFQUNGOzs7Ozs7Ozs7Ozs7QUN2QkwsTUFBYSx1QkFDWCxhQUN3QjtBQUN4QixLQUFJLFlBQVksS0FDZDtBQUdGLEtBQUksU0FBUyxhQUFhLGlCQUFpQixLQUN6QyxRQUFPO0VBQ0wsSUFBSSxTQUFTO0VBQ2IsV0FBVyxTQUFTO0VBQ3BCLE1BQU0sWUFBWTtFQUNsQixNQUFNLFlBQVk7RUFDbEIsVUFBVSxFQUNSLFNBQVMsU0FBUyxXQUFXLFNBQzlCO0VBQ0Y7QUFHSCxLQUFJLFNBQVMsYUFBYSxpQkFBaUIsUUFDekMsUUFBTztFQUNMLElBQUksU0FBUztFQUNiLFdBQVcsU0FBUztFQUNwQixNQUFNLFlBQVk7RUFDbEIsTUFBTSxZQUFZO0VBQ2xCLFVBQVUsRUFDUixHQUFHLFNBQVMsWUFDYjtFQUNGO0FBR0gsS0FBSSxTQUFTLGFBQWEsaUJBQWlCLE9BQ3pDLFFBQU87RUFDTCxJQUFJLFNBQVM7RUFDYixXQUFXLFNBQVM7RUFDcEIsTUFBTSxZQUFZO0VBQ2xCLE1BQU0sWUFBWTtFQUNsQixVQUFVO0dBQ1IsUUFBUSxTQUFTLFdBQVc7R0FDNUIsVUFBVSxTQUFTLFdBQVc7R0FDOUIsT0FBTyxTQUFTLFdBQVc7R0FDM0IsT0FBTyxTQUFTLFdBQVc7R0FDM0IsaUJBQWlCLFNBQVMsV0FBVztHQUN0QztFQUNGO0FBR0gsS0FBSSxTQUFTLGFBQWEsaUJBQWlCLFVBQ3pDLFFBQU87RUFDTCxJQUFJLFNBQVM7RUFDYixXQUFXLFNBQVM7RUFDcEIsTUFBTSxZQUFZO0VBQ2xCLE1BQU0sWUFBWTtFQUNuQjtBQUdILEtBQUksU0FBUyxhQUFhLGlCQUFpQixLQUN6QyxRQUFPO0VBQ0wsSUFBSSxTQUFTO0VBQ2IsV0FBVyxTQUFTO0VBQ3BCLE1BQU0sWUFBWTtFQUNsQixNQUFNLFlBQVk7RUFDbEIsVUFBVSxFQUNSLEdBQUcsU0FBUyxZQUNiO0VBQ0Y7QUFHSCxLQUFJLFNBQVMsYUFBYSxpQkFBaUIsY0FDekMsUUFBTztFQUNMLElBQUksU0FBUztFQUNiLFdBQVcsU0FBUztFQUNwQixNQUFNLFlBQVk7RUFDbEIsTUFBTSxZQUFZO0VBQ2xCLFVBQVUsRUFDUixHQUFHLFNBQVMsWUFDYjtFQUNGO0FBR0gsS0FBSSxTQUFTLGFBQWEsaUJBQWlCLG9CQUN6QyxRQUFPO0VBQ0wsSUFBSSxTQUFTO0VBQ2IsV0FBVyxTQUFTO0VBQ3BCLE1BQU0sWUFBWTtFQUNsQixNQUFNLFlBQVk7RUFDbEIsVUFBVSxFQUNSLEdBQUcsU0FBUyxZQUNiO0VBQ0Y7QUFHSCxLQUFJLFNBQVMsYUFBYSxpQkFBaUIsS0FDekMsUUFBTztFQUNMLElBQUksU0FBUztFQUNiLFdBQVcsU0FBUztFQUNwQixNQUFNLFlBQVk7RUFDbEIsTUFBTSxZQUFZO0VBQ2xCLFVBQVU7R0FDUixVQUFVLFNBQVMsV0FBVyxjQUFjO0dBQzVDLFFBQVEsT0FBTyxRQUFRLFNBQVMsV0FBVyxPQUFPLFdBQVcsQ0FBQyxLQUMzRCxDQUFDLEtBQUssWUFBWTtJQUNqQjtJQUNBLE9BQU8sTUFBTTtJQUNiLE1BQU0sTUFBTTtJQUNaLFFBQVEsTUFBTTtJQUNkLFVBQVUsU0FBUyxXQUFXLE9BQU8sU0FBUyxTQUFTLElBQUk7SUFDNUQsRUFDRjtHQUNGO0VBQ0Y7QUFHSCxLQUFJLFNBQVMsYUFBYSxpQkFBaUIsTUFDekMsUUFBTztFQUNMLElBQUksU0FBUztFQUNiLFdBQVcsU0FBUztFQUNwQixNQUFNLFlBQVk7RUFDbEIsTUFBTSxZQUFZO0VBQ2xCLFVBQVUsRUFDUixHQUFHLFNBQVMsWUFDYjtFQUNGOzs7Ozs7Ozs7Ozs7O0FDeEhMLE1BQWEsOEJBQ1gsT0FDQSxnQkFDd0I7QUFDeEIsS0FBSSxNQUFNLGFBQWEsa0JBQWtCLG1CQUFtQjtFQUMxRCxNQUFNLEVBQUUsaUJBQWlCLE1BQU07QUFFL0IsU0FBTztHQUNMLElBQUksTUFBTTtHQUNWLE1BQU0sWUFBWTtHQUNsQixNQUFNLFlBQVk7R0FDbEIsV0FBVyxNQUFNO0dBQ2pCLFVBQVU7SUFDUjtJQUNBLG1CQUNFLFlBQVksTUFBTSxNQUFNLEVBQUUsT0FBTyxhQUFhLEVBQUUsV0FBVztJQUM5RDtHQUNGOzs7Ozs7QUN6QkwsTUFBYSwwQ0FDWCxVQUMyQjtDQUMzQixTQUFTO0VBQ1AsU0FBUyxLQUFLLFFBQVE7RUFDdEIsUUFBUSxLQUFLLFFBQVE7RUFDckIsZ0JBQWdCLEtBQUssUUFBUTtFQUM3QixTQUFTLEtBQUssUUFBUTtFQUN0QixRQUFRLEtBQUssUUFBUTtFQUNyQixLQUFLLEtBQUssUUFBUTtFQUNuQjtDQUNELElBQUksS0FBSztDQUNULGVBQWUsS0FBSztDQUNwQixhQUFhLEtBQUssWUFBWSxLQUFLLGNBQWMsNEJBQTRCLFVBQVUsQ0FBQztDQUN4RixtQkFBbUI7RUFDakIsT0FBTyxLQUFLLGtCQUFrQjtFQUM5QixZQUFZLEtBQUssa0JBQWtCO0VBQ25DLE1BQU0sS0FBSyxrQkFBa0I7RUFDN0IsUUFBUSxLQUFLLGtCQUFrQjtFQUMvQixhQUFhLEtBQUssa0JBQWtCO0VBQ3BDLE9BQU8sS0FBSyxrQkFBa0I7RUFDOUIsaUJBQWlCLEtBQUssa0JBQWtCO0VBQ3hDLHdCQUF3QixLQUFLLGtCQUFrQjtFQUMvQywwQkFBMEIsS0FBSyxrQkFBa0I7RUFDakQsa0JBQWtCLEtBQUssa0JBQWtCO0VBQzFDO0NBQ0Y7Ozs7QUM5QkQsSUFBc0IsZUFBdEIsTUFBbUM7Q0FJakMsWUFBWSxTQUFpQjtBQUMzQixPQUFLLFVBQVU7QUFDZixPQUFLLE9BQU87O0NBR2QsYUFBYTtBQUNYLFNBQU8sS0FBSzs7Q0FHZCxRQUFRLE1BQWdCO0FBQ3RCLE9BQUssT0FBTzs7Q0FHZCxVQUFVO0FBQ1IsU0FBTyxLQUFLOzs7QUFNaEIsSUFBTSxnQkFBTixjQUE0QixhQUFhO0NBQ3ZDLFFBQXFCO0FBQ25CLFNBQU8sS0FBSyxTQUFTLENBQUMsY0FBYyxLQUFLLFlBQVksQ0FBQzs7O0FBSTFELElBQU0sYUFBTixjQUF5QixhQUFhO0NBQ3BDLFFBQXFCO0FBQ25CLFNBQU8sS0FBSyxTQUFTLENBQUMsZUFBZSxLQUFLLFlBQVksQ0FBQzs7O0FBSTNELElBQU0sZ0JBQU4sY0FBNEIsYUFBYTtDQUN2QyxRQUFxQjtBQUNuQixTQUFPLEtBQUssU0FBUyxFQUFFLFNBQ3JCLEtBQUssWUFBWSxFQUNqQixLQUFLLFNBQVMsRUFDZCxNQUNBLFlBQVkseUJBQ1osS0FDRCxFQUFFOzs7QUFJUCxJQUFNLGdCQUFOLGNBQTRCLGFBQWE7Q0FDdkMsUUFBcUI7RUFDbkIsSUFBSSxnQkFBZ0I7RUFDcEIsTUFBTSxZQUFZLEtBQUssWUFBWSxDQUFDLE1BQU0sSUFBSTtFQUM5QyxNQUFNLFlBQVksVUFBVSxTQUFTO0VBRXJDLE1BQU0sY0FBYyxTQUFpQixhQUF3QztHQUMzRSxNQUFNLFdBQVcsZ0JBQWdCLE1BQU0sUUFBUTtBQUUvQyxPQUFJLFNBQ0YsVUFBUyxRQUFRLFNBQXFCO0dBR3hDLE1BQU0sY0FBYyxTQUFTLE9BQU87QUFDcEMsT0FBSSxrQkFBa0IsVUFDcEIsUUFBTztHQUdULElBQUlDLE9BQWdDLGVBQWU7QUFDbkQsT0FBSyxhQUE2QixXQUNoQyxRQUFRLFlBQTRCO0FBR3RDLE9BQUssYUFBbUMsY0FDdEMsUUFBUSxZQUFrQyxlQUFlO0FBRzNELFVBQU8sV0FBVyxVQUFVLEVBQUUsZUFBZSxNQUFNLEVBQUUsS0FBSzs7QUFHNUQsU0FBTyxXQUFXLFVBQVUsZUFBZSxNQUFNLENBQUM7OztBQUl0RCxJQUFNLFFBQU4sY0FBb0IsYUFBYTtDQUMvQixjQUFjO0FBQ1osUUFBTSxHQUFHOztDQUVYLFFBQXFCO0FBQ25CLFNBQU87OztBQUlYLElBQWEsa0JBQWIsTUFBNkI7Q0FDM0IsT0FBTyxNQUFNLGtCQUEyQjtBQUN0QyxNQUFJLENBQUMsaUJBQ0gsUUFBTyxJQUFJLE9BQU87RUFHcEIsTUFBTSxRQUFRLGlCQUFpQixNQUFNLElBQUk7RUFDekMsTUFBTSxPQUFPLE1BQU07RUFDbkIsTUFBTSxXQUFXLE1BQU07QUFFdkIsVUFBUSxNQUFSO0dBQ0UsS0FBSyxLQUNILFFBQU8sS0FBSyxHQUFHLFNBQVM7R0FDMUIsS0FBSyxRQUNILFFBQU8sS0FBSyxNQUFNLFNBQVM7R0FDN0IsS0FBSyxRQUNILFFBQU8sS0FBSyxNQUFNLFNBQVM7R0FDN0IsUUFDRSxRQUFPLElBQUksT0FBTzs7O0NBSXhCLE9BQU8sTUFBTSxVQUF5QjtBQUNwQyxTQUFPLFlBQVksSUFBSSxPQUFPOztDQUdoQyxPQUFPLE1BQU0sU0FBa0I7QUFDN0IsU0FBTyxVQUFVLElBQUksY0FBYyxRQUFRLEdBQUcsSUFBSSxPQUFPOztDQUczRCxPQUFPLEdBQUcsU0FBZ0M7QUFDeEMsU0FBTyxVQUFVLElBQUksV0FBVyxRQUFRLEdBQUcsSUFBSSxPQUFPOztDQUd4RCxPQUFPLE1BQU0sU0FBZ0M7QUFDM0MsU0FBTyxVQUFVLElBQUksY0FBYyxRQUFRLEdBQUcsSUFBSSxPQUFPOztDQUczRCxPQUFPLE1BQU0sU0FBZ0M7QUFDM0MsU0FBTyxVQUFVLElBQUksY0FBYyxRQUFRLEdBQUcsSUFBSSxPQUFPOzs7Ozs7QUNoSTdELFNBQVMsY0FBYyxHQUEwQztBQUMvRCxRQUNFLENBQUMsQ0FBQyxLQUNGLE9BQU8sTUFBTSxZQUNiLENBQUMsTUFBTSxRQUFRLEVBQUUsSUFDakIsRUFBRSxhQUFhLFNBQ2YsRUFBRSxhQUFhOztBQUluQixTQUFTLFVBQVUsR0FBcUM7QUFDdEQsUUFBTyxDQUFDLENBQUMsS0FBSyxPQUFPLE1BQU0sWUFBWSxjQUFlOztBQUV4RCxTQUFTLFNBQVMsR0FBMkI7QUFDM0MsUUFBTyxDQUFDLENBQUMsS0FBSyxPQUFPLE1BQU0sWUFBYSxFQUE4QixZQUFZOztBQUdwRixTQUFTLGlCQUFpQixHQUFxQjtDQUM3QyxNQUFNLElBQUksT0FBTztBQUNqQixRQUNFLE1BQU0sUUFDTixNQUFNLFlBQ04sTUFBTSxZQUNOLE1BQU0sYUFDTixNQUFNLFlBQ04sTUFBTSxZQUNOLE1BQU07O0FBSVYsU0FBUyxvQkFBb0IsS0FBeUI7QUFDcEQsS0FBSSxJQUFJLFdBQVcsRUFBRyxRQUFPO0FBRTdCLE1BQUssSUFBSSxJQUFJLEdBQUcsSUFBSSxJQUFJLFFBQVEsS0FBSyxHQUFHO0VBQ3RDLE1BQU0sSUFBSSxJQUFJO0FBQ2QsTUFBSSxNQUFNLFVBQWEsQ0FBQyxpQkFBaUIsRUFBRSxDQUFFLFFBQU87O0FBRXRELFFBQU87O0FBR1QsU0FBUyxTQUFTLFNBQWtCLFVBQW1CLE1BQTZCO0FBQ2xGLEtBQUksVUFBVSxTQUFTLENBQUUsUUFBTyxTQUFTO0FBQ3pDLEtBQUksU0FBUyxTQUFTLENBQUUsUUFBTztBQUUvQixLQUFJLE1BQU0sUUFBUSxRQUFRLEVBQUU7QUFDMUIsTUFBSSxNQUFNLFFBQVEsU0FBUyxFQUFFO0dBQzNCLE1BQU0sVUFBVTtHQUNoQixNQUFNLFdBQVc7QUFLakIsT0FIRSxLQUFLLGtCQUFrQixhQUN2QixvQkFBb0IsUUFBUSxJQUM1QixvQkFBb0IsU0FBUyxDQUNaLFFBQU87R0FDMUIsTUFBTSxNQUFNLFFBQVEsT0FBTztHQUMzQixNQUFNLE1BQU0sS0FBSyxJQUFJLElBQUksUUFBUSxTQUFTLE9BQU87QUFDakQsUUFBSyxJQUFJLElBQUksR0FBRyxJQUFJLEtBQUssS0FBSyxHQUFHO0lBQy9CLE1BQU0sT0FBTyxTQUFTO0FBQ3RCLFFBQUksU0FBUyxPQUNYLEtBQUksS0FBSyxTQUFTLElBQUksSUFBSSxNQUFNLEtBQUs7O0FBR3pDLFVBQU87O0FBRVQsU0FBTzs7QUFHVCxLQUFJLGNBQWMsUUFBUSxJQUFJLGNBQWMsU0FBUyxFQUFFO0VBQ3JELE1BQU0sVUFBVTtFQUNoQixNQUFNLFdBQVc7RUFDakIsTUFBTUMsTUFBK0IsRUFBRSxHQUFHLFNBQVM7QUFDbkQsT0FBSyxNQUFNLE9BQU8sT0FBTyxLQUFLLFNBQVMsRUFBRTtHQUN2QyxNQUFNLE9BQU8sU0FBUztBQUN0QixPQUFJLFNBQVMsUUFBVyxZQUViLEtBQUssZUFBZSxTQUFTLEtBQ3RDLFFBQU8sSUFBSTtZQUNGLFVBQVUsS0FBSyxDQUN4QixLQUFJLE9BQU8sS0FBSztZQUNQLFNBQVMsS0FBSyxDQUN2QixRQUFPLElBQUk7T0FFWCxLQUFJLE9BQU8sU0FBUyxVQUFVLE1BQU0sTUFBTSxLQUFLOztBQUduRCxTQUFPOztBQUdULFFBQVEsWUFBd0I7O0FBR2xDLFNBQWdCLGVBQ2QsTUFDQSxPQUNBLE9BQXFCLEVBQUUsRUFDcEI7Q0FDSCxNQUFNLEVBQUUsZ0JBQWdCLGdCQUFnQixjQUFjLFVBQVU7QUFHaEUsS0FBSSxVQUFVLE1BQU0sQ0FBRSxRQUFPLE1BQU07QUFDbkMsS0FBSSxTQUFTLE1BQU0sQ0FBRSxRQUFPO0FBRzVCLEtBQUksTUFBTSxRQUFRLEtBQUssRUFBRTtBQUN2QixNQUFJLFVBQVUsTUFBTSxDQUFFLFFBQU8sTUFBTTtBQUNuQyxNQUFJLE1BQU0sUUFBUSxNQUFNLEVBQUU7QUFDeEIsT0FBSSxrQkFBa0IsVUFBVyxRQUFPO0dBRXhDLE1BQU0sTUFBTyxLQUFtQixPQUFPO0dBQ3ZDLE1BQU0sTUFBTSxLQUFLLElBQUksSUFBSSxRQUFRLE1BQU0sT0FBTztBQUM5QyxRQUFLLElBQUksSUFBSSxHQUFHLElBQUksS0FBSyxLQUFLLEdBQUc7SUFDL0IsTUFBTSxPQUFRLE1BQW9CO0FBQ2xDLFFBQUksU0FBUyxPQUNYLEtBQUksS0FBSyxTQUFTLElBQUksSUFBSSxNQUFNLEtBQUs7O0FBR3pDLFVBQU87O0FBR1QsU0FBTzs7QUFJVCxLQUFJLGNBQWMsS0FBSyxJQUFJLGNBQWMsTUFBTSxFQUFFO0VBQy9DLE1BQU1BLE1BQStCLEVBQUUsR0FBSSxNQUFrQztFQUM3RSxNQUFNLFdBQVc7QUFDakIsT0FBSyxNQUFNLE9BQU8sT0FBTyxLQUFLLFNBQVMsRUFBRTtHQUN2QyxNQUFNLE9BQU8sU0FBUztBQUN0QixPQUFJLFNBQVMsUUFBVyxZQUViLGVBQWUsU0FBUyxLQUNqQyxRQUFPLElBQUk7WUFDRixVQUFVLEtBQUssQ0FDeEIsS0FBSSxPQUFPLEtBQUs7WUFDUCxTQUFTLEtBQUssQ0FDdkIsUUFBTyxJQUFJO1FBQ047SUFDTCxNQUFNLE9BQVEsS0FBaUM7QUFDL0MsUUFBSSxPQUFPLFNBQVMsTUFBTSxNQUFNLEtBQUs7OztBQUd6QyxTQUFPOztBQUlULFFBQVMsU0FBcUI7Ozs7O0FDakpoQyxJQUFNLGNBQU4sTUFBTSxZQUFZO0NBQ2hCLE9BQU8sY0FBYyxPQUFvQztFQUN2RCxNQUFNLGVBQWUsT0FBTyxNQUFNO0FBQ2xDLFNBQU8sVUFBVSxVQUFhLGlCQUFpQjs7Q0FHakQsT0FBTyxXQUFXLE9BQStDO0VBQy9ELE1BQU0sZUFBZSxPQUFPLE1BQU07QUFDbEMsU0FBTyxZQUFZLGNBQWMsYUFBYSxHQUFHLFNBQVk7O0NBRy9ELE9BQU8sV0FBVyxNQUEwQjtBQUMxQyxNQUFJLFNBQVMsT0FDWCxRQUFPO0FBRVQsU0FBTyxLQUFLLE9BQU8sRUFBRSxDQUFDLGFBQWEsR0FBRyxLQUFLLFVBQVUsRUFBRTs7Ozs7Ozs7OztDQVd6RCxPQUFPLG9CQUFvQixVQUFvQixXQUF5QztBQUN0RixNQUFJLENBQUMsVUFDSDtBQUdGLE9BQUssTUFBTSxXQUFXLFNBRXBCLEtBQUksVUFBVSxhQUFhLEtBQUs7R0FNOUIsTUFBTSxlQUhpQixRQUFRLFFBQVEsc0JBQXNCLE9BQU8sQ0FHaEMsUUFBUSxPQUFPLEtBQUs7QUFHeEQsd0JBRGMsSUFBSSxPQUFPLElBQUksYUFBYSxHQUFHLEVBQ25DLEtBQUssVUFBVSxTQUFTLENBQ2hDLFFBQU87YUFHQSxRQUFRLFdBQVcsVUFBVSxTQUFTLENBQy9DLFFBQU87Ozs7OztBQ3pDZixNQUFhLHlDQUNYLCtCQUM4QjtDQUM5QixJQUFJLDBCQUEwQjtDQUM5QixZQUFZLDRCQUE0QiwwQkFBMEIsVUFBVTtDQUM1RSxTQUFTLHdCQUF3QiwwQkFBMEIsUUFBUTtDQUNwRTs7OztBQ1RELE1BQWEsaUJBQWlCLFVBQTJCLDZCQUE2QixLQUFLLE1BQU0ifQ==