@logixjs/sandbox 0.0.1 → 0.0.2

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 (248) hide show
  1. package/LICENSE +201 -0
  2. package/package.json +3 -1
  3. package/public/sandbox/chunks/chunk-2AUQRESB.js +1114 -0
  4. package/public/sandbox/chunks/chunk-2F72LQKW.js +194 -0
  5. package/public/sandbox/chunks/chunk-2PYDGDD3.js +4071 -0
  6. package/public/sandbox/chunks/chunk-2UGKSXDZ.js +16 -0
  7. package/public/sandbox/chunks/chunk-2XVE7F26.js +153 -0
  8. package/public/sandbox/chunks/chunk-3A7TFNZN.js +219 -0
  9. package/public/sandbox/chunks/chunk-3BHC6JAV.js +1070 -0
  10. package/public/sandbox/chunks/chunk-3U4CAKCX.js +61 -0
  11. package/public/sandbox/chunks/chunk-3VU3JLZO.js +272 -0
  12. package/public/sandbox/chunks/chunk-4CPONKWY.js +1170 -0
  13. package/public/sandbox/chunks/chunk-4GMUQTWH.js +850 -0
  14. package/public/sandbox/chunks/chunk-4KIYG5E4.js +749 -0
  15. package/public/sandbox/chunks/chunk-4MY35XR3.js +175 -0
  16. package/public/sandbox/chunks/chunk-5DNHJMHA.js +69 -0
  17. package/public/sandbox/chunks/chunk-5EC4S7X6.js +42 -0
  18. package/public/sandbox/chunks/chunk-5FB7QFSH.js +227 -0
  19. package/public/sandbox/chunks/chunk-5GEYCJW2.js +206 -0
  20. package/public/sandbox/chunks/chunk-5PT7Q5SS.js +373 -0
  21. package/public/sandbox/chunks/chunk-5WN5IGKA.js +166 -0
  22. package/public/sandbox/chunks/chunk-5XOBKSOT.js +213 -0
  23. package/public/sandbox/chunks/chunk-67RVISUC.js +313 -0
  24. package/public/sandbox/chunks/chunk-6ELJEKZS.js +12 -0
  25. package/public/sandbox/chunks/chunk-6FKWRVP4.js +85 -0
  26. package/public/sandbox/chunks/chunk-6JRP52YT.js +34 -0
  27. package/public/sandbox/chunks/chunk-6JYAC3G6.js +42 -0
  28. package/public/sandbox/chunks/chunk-6TUOP63Q.js +86 -0
  29. package/public/sandbox/chunks/{chunk-A6JFUNQQ.js → chunk-74C5VW7Z.js} +2 -2
  30. package/public/sandbox/chunks/chunk-75DQFC5M.js +16 -0
  31. package/public/sandbox/chunks/{chunk-UCFEP3BH.js → chunk-7GPAF2UK.js} +1 -1
  32. package/public/sandbox/chunks/chunk-7KQFTS2Y.js +135 -0
  33. package/public/sandbox/chunks/chunk-7POKWYE3.js +112 -0
  34. package/public/sandbox/chunks/chunk-7VUEF5F3.js +395 -0
  35. package/public/sandbox/chunks/chunk-7W5APZS2.js +77 -0
  36. package/public/sandbox/chunks/chunk-A6OFCXDQ.js +397 -0
  37. package/public/sandbox/chunks/chunk-A7HLOSO6.js +216 -0
  38. package/public/sandbox/chunks/chunk-AGF4RRCB.js +408 -0
  39. package/public/sandbox/chunks/chunk-ASJSJAAL.js +122 -0
  40. package/public/sandbox/chunks/chunk-ASVMK364.js +283 -0
  41. package/public/sandbox/chunks/chunk-AUDTI2BQ.js +895 -0
  42. package/public/sandbox/chunks/chunk-B2SZTA3M.js +16 -0
  43. package/public/sandbox/chunks/chunk-B6YS2UMV.js +372 -0
  44. package/public/sandbox/chunks/chunk-BCEO3MGD.js +244 -0
  45. package/public/sandbox/chunks/chunk-BCOO65D4.js +373 -0
  46. package/public/sandbox/chunks/chunk-BJOWSSEL.js +38 -0
  47. package/public/sandbox/chunks/chunk-BS2WBFW4.js +373 -0
  48. package/public/sandbox/chunks/chunk-BUVHG3NJ.js +439 -0
  49. package/public/sandbox/chunks/chunk-BVE33AN6.js +42 -0
  50. package/public/sandbox/chunks/chunk-BWTGJZVP.js +19 -0
  51. package/public/sandbox/chunks/chunk-BXD7GZC3.js +1025 -0
  52. package/public/sandbox/chunks/chunk-BZH4EUUD.js +164 -0
  53. package/public/sandbox/chunks/{chunk-HFV5GJPK.js → chunk-C2MYMMO4.js} +3 -3
  54. package/public/sandbox/chunks/chunk-CRE4NJJ6.js +271 -0
  55. package/public/sandbox/chunks/chunk-CVZPRIDB.js +706 -0
  56. package/public/sandbox/chunks/chunk-CWOXD5NG.js +991 -0
  57. package/public/sandbox/chunks/chunk-D6DOC3BJ.js +373 -0
  58. package/public/sandbox/chunks/chunk-DEPSGFSY.js +1698 -0
  59. package/public/sandbox/chunks/chunk-DM7C5NP5.js +819 -0
  60. package/public/sandbox/chunks/chunk-DN33LMOF.js +1112 -0
  61. package/public/sandbox/chunks/{chunk-S46P7MC6.js → chunk-DT7YIIWE.js} +2 -2
  62. package/public/sandbox/chunks/chunk-DVB5WRCI.js +260 -0
  63. package/public/sandbox/chunks/{chunk-TOHCFMQS.js → chunk-E3EVW7NR.js} +11 -18
  64. package/public/sandbox/chunks/chunk-E5BV567Q.js +417 -0
  65. package/public/sandbox/chunks/chunk-E7BIWMQQ.js +203 -0
  66. package/public/sandbox/chunks/chunk-EAKGPSOQ.js +83 -0
  67. package/public/sandbox/chunks/chunk-EGUYL2ER.js +75 -0
  68. package/public/sandbox/chunks/chunk-EP5GQYZ5.js +85 -0
  69. package/public/sandbox/chunks/chunk-ET6CJEHC.js +221 -0
  70. package/public/sandbox/chunks/chunk-EU67YZHZ.js +1070 -0
  71. package/public/sandbox/chunks/{chunk-PTSJJANP.js → chunk-EYNDQLSB.js} +1 -1
  72. package/public/sandbox/chunks/{chunk-CEGSWZ5S.js → chunk-EZTMVCJF.js} +1 -1
  73. package/public/sandbox/chunks/chunk-F5CLVIS6.js +907 -0
  74. package/public/sandbox/chunks/chunk-F743SKYD.js +85 -0
  75. package/public/sandbox/chunks/chunk-FEGFZ5OX.js +86 -0
  76. package/public/sandbox/chunks/chunk-FG5B7ZX3.js +373 -0
  77. package/public/sandbox/chunks/chunk-FKZPYMDG.js +373 -0
  78. package/public/sandbox/chunks/chunk-FNLXHWIU.js +220 -0
  79. package/public/sandbox/chunks/chunk-FQRUTYAD.js +1991 -0
  80. package/public/sandbox/chunks/{chunk-VLYP4WUS.js → chunk-FY5A73NK.js} +5 -5
  81. package/public/sandbox/chunks/chunk-G7FAOG3O.js +221 -0
  82. package/public/sandbox/chunks/chunk-GFXHUC7Y.js +73 -0
  83. package/public/sandbox/chunks/chunk-GIPXUIZQ.js +534 -0
  84. package/public/sandbox/chunks/chunk-GP37MEGJ.js +52 -0
  85. package/public/sandbox/chunks/chunk-GXL5QCMF.js +4511 -0
  86. package/public/sandbox/chunks/chunk-GZ2NSE6A.js +177 -0
  87. package/public/sandbox/chunks/chunk-GZATW4YD.js +69 -0
  88. package/public/sandbox/chunks/chunk-H4EBXROQ.js +166 -0
  89. package/public/sandbox/chunks/chunk-HETCPK6Z.js +153 -0
  90. package/public/sandbox/chunks/chunk-HGUFQ2QC.js +4431 -0
  91. package/public/sandbox/chunks/chunk-HGV3VNH3.js +255 -0
  92. package/public/sandbox/chunks/chunk-HIJ67QWR.js +5397 -0
  93. package/public/sandbox/chunks/chunk-IDHERBKW.js +1114 -0
  94. package/public/sandbox/chunks/chunk-IDTK4FIY.js +102 -0
  95. package/public/sandbox/chunks/chunk-ILFVY7H5.js +164 -0
  96. package/public/sandbox/chunks/chunk-ISGSRYGO.js +57 -0
  97. package/public/sandbox/chunks/chunk-J45VPU24.js +408 -0
  98. package/public/sandbox/chunks/chunk-JAUIM3O5.js +42 -0
  99. package/public/sandbox/chunks/chunk-JB7OQEM6.js +373 -0
  100. package/public/sandbox/chunks/chunk-JCKW6NHD.js +15 -0
  101. package/public/sandbox/chunks/chunk-JMA7GY7Z.js +221 -0
  102. package/public/sandbox/chunks/chunk-JY46J6IL.js +836 -0
  103. package/public/sandbox/chunks/{chunk-X72PZOFA.js → chunk-K2MQ66O7.js} +1 -1
  104. package/public/sandbox/chunks/chunk-KA7PZA6F.js +464 -0
  105. package/public/sandbox/chunks/chunk-KDEQTUID.js +102 -0
  106. package/public/sandbox/chunks/chunk-KDJR27JV.js +1696 -0
  107. package/public/sandbox/chunks/chunk-KFE3JO6N.js +77 -0
  108. package/public/sandbox/chunks/chunk-KLDSYWT5.js +536 -0
  109. package/public/sandbox/chunks/chunk-KQWWFYBF.js +203 -0
  110. package/public/sandbox/chunks/chunk-KTFZSXOW.js +6473 -0
  111. package/public/sandbox/chunks/chunk-KXVIC55U.js +108 -0
  112. package/public/sandbox/chunks/{chunk-HNEDTEGQ.js → chunk-L4PNO2H6.js} +1 -1
  113. package/public/sandbox/chunks/{chunk-WE4STGO2.js → chunk-L4ZNW5DI.js} +2 -2
  114. package/public/sandbox/chunks/chunk-LBUINGZ4.js +836 -0
  115. package/public/sandbox/chunks/chunk-LIYPPU6I.js +112 -0
  116. package/public/sandbox/chunks/chunk-LJHTOJXW.js +221 -0
  117. package/public/sandbox/chunks/{chunk-BWSNPKO5.js → chunk-LQL23SWJ.js} +2 -2
  118. package/public/sandbox/chunks/chunk-LTFCYZQ6.js +46 -0
  119. package/public/sandbox/chunks/chunk-LTWLVCKQ.js +166 -0
  120. package/public/sandbox/chunks/chunk-LWI7BXFN.js +395 -0
  121. package/public/sandbox/chunks/chunk-LYBBX6WM.js +225 -0
  122. package/public/sandbox/chunks/chunk-MXE7HIBM.js +474 -0
  123. package/public/sandbox/chunks/chunk-MYBDYNK4.js +6004 -0
  124. package/public/sandbox/chunks/chunk-NC2MIWZX.js +732 -0
  125. package/public/sandbox/chunks/chunk-NE447XAF.js +597 -0
  126. package/public/sandbox/chunks/chunk-NEAYV5C2.js +255 -0
  127. package/public/sandbox/chunks/chunk-NMGFJZ4I.js +26 -0
  128. package/public/sandbox/chunks/chunk-NWCJJZNQ.js +71 -0
  129. package/public/sandbox/chunks/chunk-O57OZBDR.js +214 -0
  130. package/public/sandbox/chunks/chunk-OJJT664Q.js +731 -0
  131. package/public/sandbox/chunks/chunk-OKTBUTCH.js +1175 -0
  132. package/public/sandbox/chunks/chunk-OQ4SYV5D.js +534 -0
  133. package/public/sandbox/chunks/chunk-OTVVIHJD.js +219 -0
  134. package/public/sandbox/chunks/chunk-OWTMSCF7.js +1052 -0
  135. package/public/sandbox/chunks/chunk-P5ZQNFC3.js +122 -0
  136. package/public/sandbox/chunks/chunk-PBPT2U2N.js +1698 -0
  137. package/public/sandbox/chunks/chunk-PHBJLCP3.js +836 -0
  138. package/public/sandbox/chunks/chunk-PHV4HYHB.js +397 -0
  139. package/public/sandbox/chunks/chunk-PIXQ6SOX.js +4071 -0
  140. package/public/sandbox/chunks/chunk-PKJL6YLK.js +73 -0
  141. package/public/sandbox/chunks/chunk-PKPOITIU.js +221 -0
  142. package/public/sandbox/chunks/{chunk-NQW73ACJ.js → chunk-PMXBOYQI.js} +1 -1
  143. package/public/sandbox/chunks/chunk-PQLZD7NR.js +836 -0
  144. package/public/sandbox/chunks/chunk-QEESVOZU.js +16 -0
  145. package/public/sandbox/chunks/chunk-QGIM3FQK.js +159 -0
  146. package/public/sandbox/chunks/chunk-QL5JNEDO.js +69 -0
  147. package/public/sandbox/chunks/chunk-QQOZ3RMH.js +867 -0
  148. package/public/sandbox/chunks/chunk-QUMEVT2F.js +194 -0
  149. package/public/sandbox/chunks/chunk-QVZBXYVY.js +102 -0
  150. package/public/sandbox/chunks/chunk-R5HQS6RB.js +135 -0
  151. package/public/sandbox/chunks/chunk-R75Q2CTT.js +900 -0
  152. package/public/sandbox/chunks/chunk-RBB6SHW2.js +253 -0
  153. package/public/sandbox/chunks/chunk-RDHNRWQP.js +383 -0
  154. package/public/sandbox/chunks/chunk-RIWOEI3T.js +1101 -0
  155. package/public/sandbox/chunks/chunk-RS5FFPUV.js +103 -0
  156. package/public/sandbox/chunks/chunk-RYSSJBGX.js +203 -0
  157. package/public/sandbox/chunks/chunk-S3KBAE5Z.js +1114 -0
  158. package/public/sandbox/chunks/chunk-S6ZZHV6G.js +244 -0
  159. package/public/sandbox/chunks/chunk-SFXJ24HY.js +499 -0
  160. package/public/sandbox/chunks/chunk-SH7TP5CJ.js +1109 -0
  161. package/public/sandbox/chunks/chunk-SI5OKFFY.js +317 -0
  162. package/public/sandbox/chunks/chunk-SIXNQNIR.js +86 -0
  163. package/public/sandbox/chunks/chunk-ST353BOX.js +42 -0
  164. package/public/sandbox/chunks/chunk-SYEHKMLP.js +1140 -0
  165. package/public/sandbox/chunks/chunk-SZ4KQUJU.js +69 -0
  166. package/public/sandbox/chunks/{chunk-5SOP6EKV.js → chunk-SZI65PSP.js} +5 -10
  167. package/public/sandbox/chunks/chunk-T7RLTSMX.js +78 -0
  168. package/public/sandbox/chunks/chunk-TJ2RLUTW.js +57 -0
  169. package/public/sandbox/chunks/chunk-TJB73XPN.js +4071 -0
  170. package/public/sandbox/chunks/chunk-TXJCYO56.js +4046 -0
  171. package/public/sandbox/chunks/chunk-U5J3LCYI.js +731 -0
  172. package/public/sandbox/chunks/chunk-UABFN3NH.js +208 -0
  173. package/public/sandbox/chunks/chunk-UBMUY7WO.js +13 -0
  174. package/public/sandbox/chunks/chunk-UC27CE32.js +69 -0
  175. package/public/sandbox/chunks/chunk-UJGVDFZN.js +147 -0
  176. package/public/sandbox/chunks/chunk-UNVLTK4N.js +122 -0
  177. package/public/sandbox/chunks/chunk-UQKQ6V3V.js +208 -0
  178. package/public/sandbox/chunks/chunk-UZZBHWIO.js +703 -0
  179. package/public/sandbox/chunks/chunk-VKZIJERL.js +1114 -0
  180. package/public/sandbox/chunks/chunk-VQQEAGID.js +372 -0
  181. package/public/sandbox/chunks/{chunk-3LX3KIQQ.js → chunk-W365QUZ5.js} +3 -5
  182. package/public/sandbox/chunks/chunk-WJY2LSWG.js +1052 -0
  183. package/public/sandbox/chunks/chunk-WNOBN3DX.js +391 -0
  184. package/public/sandbox/chunks/chunk-X2Z5VYG3.js +245 -0
  185. package/public/sandbox/chunks/chunk-X74KU74D.js +959 -0
  186. package/public/sandbox/chunks/chunk-XE7ULSGQ.js +46 -0
  187. package/public/sandbox/chunks/chunk-XRXUJZ3X.js +431 -0
  188. package/public/sandbox/chunks/chunk-XWHIN7CC.js +85 -0
  189. package/public/sandbox/chunks/chunk-Y2TVGGVL.js +527 -0
  190. package/public/sandbox/chunks/chunk-YMVMZA3U.js +1395 -0
  191. package/public/sandbox/chunks/chunk-YOBLFWDV.js +431 -0
  192. package/public/sandbox/chunks/chunk-YR2RFEZA.js +11 -0
  193. package/public/sandbox/chunks/chunk-YTD6A35P.js +836 -0
  194. package/public/sandbox/chunks/chunk-Z5L7EZXS.js +81 -0
  195. package/public/sandbox/chunks/chunk-Z65I5ET2.js +108 -0
  196. package/public/sandbox/chunks/chunk-Z6LV34RO.js +390 -0
  197. package/public/sandbox/chunks/chunk-ZAKUP6QG.js +1634 -0
  198. package/public/sandbox/chunks/chunk-ZHNYE2YH.js +731 -0
  199. package/public/sandbox/chunks/chunk-ZHQX3B3Y.js +867 -0
  200. package/public/sandbox/chunks/chunk-ZIXDFRHJ.js +731 -0
  201. package/public/sandbox/chunks/chunk-ZPZ2MZ4D.js +528 -0
  202. package/public/sandbox/chunks/chunk-ZQD6NZXB.js +373 -0
  203. package/public/sandbox/chunks/chunk-ZVVBP7ON.js +16 -0
  204. package/public/sandbox/chunks/chunk-ZWE3P6X2.js +11 -0
  205. package/public/sandbox/logix-core/Bound.js +14 -14
  206. package/public/sandbox/logix-core/Debug.js +12 -10
  207. package/public/sandbox/logix-core/EffectOp.js +3 -4
  208. package/public/sandbox/logix-core/Env.js +5 -2
  209. package/public/sandbox/logix-core/ExternalStore.js +239 -0
  210. package/public/sandbox/logix-core/Flow.js +7 -8
  211. package/public/sandbox/logix-core/Kernel.js +7 -4
  212. package/public/sandbox/logix-core/Link.js +33 -25
  213. package/public/sandbox/logix-core/Middleware.js +13 -11
  214. package/public/sandbox/logix-core/Module.js +93 -30
  215. package/public/sandbox/logix-core/ModuleTag.js +28 -25
  216. package/public/sandbox/logix-core/Observability.js +21 -19
  217. package/public/sandbox/logix-core/Process.js +27 -22
  218. package/public/sandbox/logix-core/ReadQuery.js +7 -11
  219. package/public/sandbox/logix-core/Reflection.js +173 -53
  220. package/public/sandbox/logix-core/Resource.js +6 -3
  221. package/public/sandbox/logix-core/Root.js +7 -3
  222. package/public/sandbox/logix-core/Runtime.js +54 -40
  223. package/public/sandbox/logix-core/ScopeRegistry.js +6 -3
  224. package/public/sandbox/logix-core/StateTrait.js +17 -14
  225. package/public/sandbox/logix-core/TraitLifecycle.js +8 -8
  226. package/public/sandbox/logix-core/Workflow.js +332 -0
  227. package/public/sandbox/logix-core.js +11133 -6622
  228. package/public/sandbox/logix-core.manifest.json +4 -2
  229. package/public/sandbox/worker.js +3 -3
  230. package/public/sandbox/chunks/chunk-4LRLOTMA.js +0 -1698
  231. package/public/sandbox/chunks/chunk-CDLXJHXY.js +0 -120
  232. package/public/sandbox/chunks/chunk-CZRI7MHA.js +0 -46
  233. package/public/sandbox/chunks/chunk-EJDFUZ4B.js +0 -408
  234. package/public/sandbox/chunks/chunk-IP63FME6.js +0 -282
  235. package/public/sandbox/chunks/chunk-JIXTOQXJ.js +0 -1103
  236. package/public/sandbox/chunks/chunk-MPUSOFJ3.js +0 -1928
  237. package/public/sandbox/chunks/chunk-ON2LY6HJ.js +0 -135
  238. package/public/sandbox/chunks/chunk-POIBXAH5.js +0 -995
  239. package/public/sandbox/chunks/chunk-PQ652ULI.js +0 -6359
  240. package/public/sandbox/chunks/chunk-RJQ4PG2F.js +0 -77
  241. package/public/sandbox/chunks/chunk-S4EXG3OS.js +0 -533
  242. package/public/sandbox/chunks/chunk-SUXDGXVE.js +0 -390
  243. package/public/sandbox/chunks/chunk-TOQ6SJ6O.js +0 -244
  244. package/public/sandbox/chunks/chunk-UKYAF3NL.js +0 -1036
  245. package/public/sandbox/chunks/chunk-UMVN3AWO.js +0 -395
  246. package/public/sandbox/chunks/chunk-WFV5PPWJ.js +0 -194
  247. package/public/sandbox/chunks/chunk-YF6IO732.js +0 -206
  248. package/public/sandbox/chunks/chunk-ZUBABAAO.js +0 -86
@@ -0,0 +1,417 @@
1
+ // @logix/core subpath bundles for @logix/sandbox
2
+
3
+ import {
4
+ ProcessRuntimeTag,
5
+ layer
6
+ } from "./chunk-ZAKUP6QG.js";
7
+ import {
8
+ make
9
+ } from "./chunk-OKTBUTCH.js";
10
+ import {
11
+ RootContextTag
12
+ } from "./chunk-XWHIN7CC.js";
13
+ import {
14
+ ConcurrencyPolicyTag,
15
+ StateTransactionConfigTag
16
+ } from "./chunk-GP37MEGJ.js";
17
+
18
+ // ../logix-core/src/internal/runtime/core/runner/ProgramRunner.errors.ts
19
+ var summarizeCause = (cause) => {
20
+ if (cause instanceof Error) {
21
+ return { name: cause.name, message: cause.message };
22
+ }
23
+ return { message: typeof cause === "string" ? cause : void 0 };
24
+ };
25
+ var ProgramRunnerErrorBase = class extends Error {
26
+ constructor(params) {
27
+ super(params.message);
28
+ this.moduleId = params.identity.moduleId;
29
+ this.instanceId = params.identity.instanceId;
30
+ this.entrypoint = params.entrypoint;
31
+ this.hint = params.hint;
32
+ }
33
+ toJSON() {
34
+ return {
35
+ _tag: this._tag,
36
+ name: this.name,
37
+ message: this.message,
38
+ moduleId: this.moduleId,
39
+ instanceId: this.instanceId,
40
+ entrypoint: this.entrypoint,
41
+ hint: this.hint
42
+ };
43
+ }
44
+ };
45
+ var BootError = class extends ProgramRunnerErrorBase {
46
+ constructor(identity, cause) {
47
+ super({
48
+ message: "[Logix] Program boot failed",
49
+ identity,
50
+ entrypoint: "boot",
51
+ hint: "Check that options.layer / imports / providers are complete, and that no dependencies are missing during assembly."
52
+ });
53
+ this._tag = "BootError";
54
+ this.name = "BootError";
55
+ this.cause = summarizeCause(cause);
56
+ }
57
+ toJSON() {
58
+ return { ...super.toJSON(), cause: this.cause };
59
+ }
60
+ };
61
+ var MainError = class extends ProgramRunnerErrorBase {
62
+ constructor(identity, cause) {
63
+ super({
64
+ message: "[Logix] Program main failed",
65
+ identity,
66
+ entrypoint: "main",
67
+ hint: "Main failed: ensure main handles domain errors explicitly, and check for interruption or missing dependencies."
68
+ });
69
+ this._tag = "MainError";
70
+ this.name = "MainError";
71
+ this.cause = summarizeCause(cause);
72
+ }
73
+ toJSON() {
74
+ return { ...super.toJSON(), cause: this.cause };
75
+ }
76
+ };
77
+ var DisposeError = class extends ProgramRunnerErrorBase {
78
+ constructor(identity, cause) {
79
+ super({
80
+ message: "[Logix] Program dispose failed",
81
+ identity,
82
+ entrypoint: "dispose",
83
+ hint: "Dispose failed: a finalizer may have thrown, or scope/resource handles may be invalid; check onError/logs."
84
+ });
85
+ this._tag = "DisposeError";
86
+ this.name = "DisposeError";
87
+ this.cause = summarizeCause(cause);
88
+ }
89
+ toJSON() {
90
+ return { ...super.toJSON(), cause: this.cause };
91
+ }
92
+ };
93
+ var DisposeTimeoutError = class extends ProgramRunnerErrorBase {
94
+ constructor(identity, params) {
95
+ super({
96
+ message: "[Logix] Program dispose timed out",
97
+ identity,
98
+ entrypoint: "dispose",
99
+ hint: "Dispose timed out: if the program cannot exit naturally, resources may not be released or background fibers are still running."
100
+ });
101
+ this._tag = "DisposeTimeout";
102
+ this.name = "DisposeTimeoutError";
103
+ this.timeoutMs = params.timeoutMs;
104
+ this.elapsedMs = params.elapsedMs;
105
+ this.suggestions = [
106
+ "Check for event listeners that were not unregistered (e.g. process.on / emitter.on).",
107
+ "Check for fibers that were not joined/interrupt (long-lived watchers / Stream.run*).",
108
+ "Check for resource handles that were not closed (timer / socket / file handle)."
109
+ ];
110
+ }
111
+ toJSON() {
112
+ return {
113
+ ...super.toJSON(),
114
+ timeoutMs: this.timeoutMs,
115
+ elapsedMs: this.elapsedMs,
116
+ suggestions: this.suggestions
117
+ };
118
+ }
119
+ };
120
+
121
+ // ../logix-core/src/internal/runtime/AppRuntime.ts
122
+ import { Context, Deferred, Effect, Layer, ManagedRuntime } from "../effect.js";
123
+ var getTagKey = (tag) => {
124
+ const anyTag = tag;
125
+ if (typeof anyTag.key === "string") {
126
+ return anyTag.key;
127
+ }
128
+ if (typeof anyTag._id === "string") {
129
+ return anyTag._id;
130
+ }
131
+ if (typeof anyTag.toString === "function") {
132
+ return anyTag.toString();
133
+ }
134
+ return "[unknown-tag]";
135
+ };
136
+ var buildTagIndex = (entries) => {
137
+ const index = /* @__PURE__ */ new Map();
138
+ for (const entry of entries) {
139
+ const ownerId = String(entry.module.id);
140
+ const moduleTag = entry.module;
141
+ const moduleKey = getTagKey(moduleTag);
142
+ const moduleInfo = {
143
+ key: moduleKey,
144
+ tag: moduleTag,
145
+ ownerModuleId: ownerId,
146
+ source: "module"
147
+ };
148
+ const existingModuleInfos = index.get(moduleKey);
149
+ if (existingModuleInfos) {
150
+ existingModuleInfos.push(moduleInfo);
151
+ } else {
152
+ index.set(moduleKey, [moduleInfo]);
153
+ }
154
+ if (entry.serviceTags && entry.serviceTags.length > 0) {
155
+ for (const tag of entry.serviceTags) {
156
+ const key = getTagKey(tag);
157
+ const info = {
158
+ key,
159
+ tag,
160
+ ownerModuleId: ownerId,
161
+ source: "service"
162
+ };
163
+ const existingInfos = index.get(key);
164
+ if (existingInfos) {
165
+ existingInfos.push(info);
166
+ } else {
167
+ index.set(key, [info]);
168
+ }
169
+ }
170
+ }
171
+ }
172
+ return index;
173
+ };
174
+ var validateTags = (entries) => {
175
+ const index = buildTagIndex(entries);
176
+ const collisions = [];
177
+ for (const [key, infos] of index) {
178
+ if (infos.length <= 1) {
179
+ continue;
180
+ }
181
+ const owners = /* @__PURE__ */ new Set();
182
+ for (const info of infos) {
183
+ owners.add(info.ownerModuleId);
184
+ }
185
+ if (owners.size > 1) {
186
+ collisions.push({ key, conflicts: infos });
187
+ }
188
+ }
189
+ if (collisions.length === 0) {
190
+ return;
191
+ }
192
+ const message = "[Logix] Tag collision detected:\n" + collisions.map((c) => {
193
+ const header = `- key: ${c.key}`;
194
+ const lines = c.conflicts.map((i) => ` - owner: ${i.ownerModuleId}, source: ${i.source}`);
195
+ return [header, ...lines].join("\n");
196
+ }).join("\n");
197
+ const error = Object.assign(new Error(message), {
198
+ _tag: "TagCollisionError",
199
+ collisions
200
+ });
201
+ throw error;
202
+ };
203
+ var makeApp = (config) => {
204
+ const seenIds = /* @__PURE__ */ new Set();
205
+ for (const entry of config.modules) {
206
+ const id = String(entry.module.id);
207
+ if (seenIds.has(id)) {
208
+ throw new Error(
209
+ `[Logix] Duplicate Module ID/Tag detected: "${id}".
210
+ Ensure all modules in the application Runtime have unique IDs.`
211
+ );
212
+ }
213
+ seenIds.add(id);
214
+ }
215
+ validateTags(config.modules);
216
+ const stateTxnLayer = config.stateTransaction ? Layer.succeed(StateTransactionConfigTag, config.stateTransaction) : Layer.empty;
217
+ const concurrencyPolicyLayer = config.concurrencyPolicy ? Layer.succeed(ConcurrencyPolicyTag, config.concurrencyPolicy) : Layer.empty;
218
+ const appModuleIds = config.modules.map((entry) => String(entry.module.id));
219
+ const appId = appModuleIds.length === 1 ? appModuleIds[0] : appModuleIds.slice().sort().join("~");
220
+ const baseLayer = Layer.mergeAll(
221
+ config.layer,
222
+ stateTxnLayer,
223
+ concurrencyPolicyLayer,
224
+ layer(),
225
+ Layer.effect(
226
+ RootContextTag,
227
+ Effect.gen(function* () {
228
+ const ready = yield* Deferred.make();
229
+ return { context: void 0, ready, appId, appModuleIds };
230
+ })
231
+ )
232
+ );
233
+ const moduleLayers = config.modules.map(
234
+ (entry) => (
235
+ // 确保每个模块层都能看到 App 级 Env(baseLayer),避免在初始化阶段找不到 Root Env。
236
+ Layer.provide(entry.layer, baseLayer)
237
+ )
238
+ );
239
+ const envLayer = moduleLayers.length > 0 ? Layer.mergeAll(baseLayer, ...moduleLayers) : baseLayer;
240
+ const finalLayer = Layer.unwrapScoped(
241
+ Effect.gen(function* () {
242
+ const scope = yield* Effect.scope;
243
+ const [patch, env] = yield* Effect.diffFiberRefs(Layer.buildWithScope(envLayer, scope));
244
+ const rootContext = Context.get(
245
+ env,
246
+ RootContextTag
247
+ );
248
+ rootContext.context = env;
249
+ yield* Deferred.succeed(rootContext.ready, env);
250
+ const processRuntime = Context.get(
251
+ env,
252
+ ProcessRuntimeTag
253
+ );
254
+ yield* Effect.forEach(
255
+ config.processes,
256
+ (process) => Effect.gen(function* () {
257
+ const installation = yield* Effect.provide(
258
+ processRuntime.install(process, {
259
+ scope: { type: "app", appId },
260
+ enabled: true,
261
+ installedAt: "appRuntime"
262
+ }),
263
+ env
264
+ );
265
+ if (installation === void 0) {
266
+ yield* Effect.forkScoped(
267
+ Effect.provide(
268
+ config.onError ? Effect.catchAllCause(process, config.onError) : process,
269
+ env
270
+ )
271
+ );
272
+ }
273
+ }),
274
+ { discard: true }
275
+ );
276
+ const fiberRefsLayer = Layer.scopedDiscard(Effect.patchFiberRefs(patch));
277
+ return Layer.mergeAll(
278
+ Layer.succeedContext(env),
279
+ fiberRefsLayer
280
+ );
281
+ })
282
+ );
283
+ return {
284
+ definition: config,
285
+ layer: finalLayer,
286
+ makeRuntime: () => ManagedRuntime.make(finalLayer)
287
+ };
288
+ };
289
+ var provide = (module, resource) => {
290
+ const layer2 = isLayer(resource) ? resource : Layer.succeed(module, resource);
291
+ return { module, layer: layer2 };
292
+ };
293
+ var isLayer = (value) => typeof value === "object" && value !== null && Layer.LayerTypeId in value;
294
+
295
+ // ../logix-core/src/internal/runtime/core/runner/ProgramRunner.closeScope.ts
296
+ import { Cause, Effect as Effect2, Exit, Fiber, Option, Scope } from "../effect.js";
297
+ var closeProgramScope = (params) => {
298
+ return Effect2.gen(function* () {
299
+ const start = Date.now();
300
+ const fiber = yield* Effect2.forkDaemon(Scope.close(params.scope, Exit.void));
301
+ while (true) {
302
+ const exitOpt = yield* Fiber.poll(fiber);
303
+ if (Option.isSome(exitOpt)) {
304
+ const exit = exitOpt.value;
305
+ if (exit._tag === "Success") {
306
+ return;
307
+ }
308
+ return yield* Effect2.die(new DisposeError(params.identity, exit.cause));
309
+ }
310
+ const elapsedMs = Date.now() - start;
311
+ if (elapsedMs >= params.timeoutMs) {
312
+ const error = new DisposeTimeoutError(params.identity, {
313
+ timeoutMs: params.timeoutMs,
314
+ elapsedMs
315
+ });
316
+ if (typeof params.onError === "function") {
317
+ yield* params.onError(Cause.die(error)).pipe(Effect2.catchAllCause(() => Effect2.void));
318
+ }
319
+ yield* Fiber.interruptFork(fiber);
320
+ return yield* Effect2.die(error);
321
+ }
322
+ yield* Effect2.promise(() => new Promise((r) => queueMicrotask(r)));
323
+ }
324
+ });
325
+ };
326
+
327
+ // ../logix-core/src/internal/runtime/core/runner/ProgramRunner.signals.ts
328
+ import { Effect as Effect3, Exit as Exit2, Scope as Scope2 } from "../effect.js";
329
+ var getProcess = () => globalThis.process;
330
+ var isNodeProcess = (value) => typeof value === "object" && value !== null && typeof value.on === "function";
331
+ var removeListener = (proc, event, handler) => {
332
+ if (typeof proc.off === "function") {
333
+ proc.off(event, handler);
334
+ return;
335
+ }
336
+ if (typeof proc.removeListener === "function") {
337
+ proc.removeListener(event, handler);
338
+ }
339
+ };
340
+ var installGracefulShutdownHandlers = (params) => {
341
+ if (!params.enabled) {
342
+ return Effect3.void;
343
+ }
344
+ const proc = getProcess();
345
+ if (!isNodeProcess(proc)) {
346
+ return Effect3.void;
347
+ }
348
+ const handler = () => {
349
+ void Effect3.runPromise(Scope2.close(params.scope, Exit2.void));
350
+ };
351
+ return Effect3.gen(function* () {
352
+ yield* Scope2.addFinalizer(
353
+ params.scope,
354
+ Effect3.sync(() => {
355
+ removeListener(proc, "SIGINT", handler);
356
+ removeListener(proc, "SIGTERM", handler);
357
+ })
358
+ );
359
+ yield* Effect3.sync(() => {
360
+ proc.on("SIGINT", handler);
361
+ proc.on("SIGTERM", handler);
362
+ });
363
+ });
364
+ };
365
+
366
+ // ../logix-core/src/internal/runtime/core/runner/ProgramRunner.kernel.ts
367
+ import { Effect as Effect4, Scope as Scope3 } from "../effect.js";
368
+ var makeProgramRunnerKernel = (makeRuntime, rootImpl, options) => Effect4.gen(function* () {
369
+ const identity = {
370
+ moduleId: String(rootImpl.module.id),
371
+ instanceId: "unknown"
372
+ };
373
+ const scope = yield* Scope3.make();
374
+ const runtime = makeRuntime(rootImpl, options);
375
+ yield* Scope3.addFinalizer(
376
+ scope,
377
+ Effect4.promise(() => runtime.dispose()).pipe(Effect4.asVoid)
378
+ );
379
+ const setInstanceId = (value) => {
380
+ identity.instanceId = typeof value === "string" && value.length > 0 ? value : String(value ?? "unknown");
381
+ };
382
+ const close = (params) => closeProgramScope({
383
+ scope,
384
+ timeoutMs: params.timeoutMs,
385
+ identity,
386
+ onError: params.onError
387
+ });
388
+ const installSignals = (enabled) => installGracefulShutdownHandlers({ scope, enabled });
389
+ const toContext = (moduleRuntime) => ({
390
+ scope,
391
+ runtime,
392
+ module: moduleRuntime,
393
+ $: make(rootImpl.module.shape, moduleRuntime)
394
+ });
395
+ return {
396
+ scope,
397
+ runtime,
398
+ identity,
399
+ installSignals,
400
+ close,
401
+ setInstanceId,
402
+ toContext
403
+ };
404
+ });
405
+
406
+ export {
407
+ BootError,
408
+ MainError,
409
+ DisposeError,
410
+ DisposeTimeoutError,
411
+ closeProgramScope,
412
+ installGracefulShutdownHandlers,
413
+ makeProgramRunnerKernel,
414
+ makeApp,
415
+ provide
416
+ };
417
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vbG9naXgtY29yZS9zcmMvaW50ZXJuYWwvcnVudGltZS9jb3JlL3J1bm5lci9Qcm9ncmFtUnVubmVyLmVycm9ycy50cyIsICIuLi8uLi8uLi8uLi9sb2dpeC1jb3JlL3NyYy9pbnRlcm5hbC9ydW50aW1lL0FwcFJ1bnRpbWUudHMiLCAiLi4vLi4vLi4vLi4vbG9naXgtY29yZS9zcmMvaW50ZXJuYWwvcnVudGltZS9jb3JlL3J1bm5lci9Qcm9ncmFtUnVubmVyLmNsb3NlU2NvcGUudHMiLCAiLi4vLi4vLi4vLi4vbG9naXgtY29yZS9zcmMvaW50ZXJuYWwvcnVudGltZS9jb3JlL3J1bm5lci9Qcm9ncmFtUnVubmVyLnNpZ25hbHMudHMiLCAiLi4vLi4vLi4vLi4vbG9naXgtY29yZS9zcmMvaW50ZXJuYWwvcnVudGltZS9jb3JlL3J1bm5lci9Qcm9ncmFtUnVubmVyLmtlcm5lbC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiZXhwb3J0IHR5cGUgUHJvZ3JhbVJ1bm5lckVycm9yVGFnID1cbiAgfCBcIkJvb3RFcnJvclwiXG4gIHwgXCJNYWluRXJyb3JcIlxuICB8IFwiRGlzcG9zZUVycm9yXCJcbiAgfCBcIkRpc3Bvc2VUaW1lb3V0XCJcblxuZXhwb3J0IGludGVyZmFjZSBQcm9ncmFtSWRlbnRpdHkge1xuICBtb2R1bGVJZDogc3RyaW5nXG4gIGluc3RhbmNlSWQ6IHN0cmluZ1xufVxuXG5jb25zdCBzdW1tYXJpemVDYXVzZSA9IChjYXVzZTogdW5rbm93bik6IHsgbmFtZT86IHN0cmluZzsgbWVzc2FnZT86IHN0cmluZyB9ID0+IHtcbiAgaWYgKGNhdXNlIGluc3RhbmNlb2YgRXJyb3IpIHtcbiAgICByZXR1cm4geyBuYW1lOiBjYXVzZS5uYW1lLCBtZXNzYWdlOiBjYXVzZS5tZXNzYWdlIH1cbiAgfVxuICByZXR1cm4geyBtZXNzYWdlOiB0eXBlb2YgY2F1c2UgPT09IFwic3RyaW5nXCIgPyBjYXVzZSA6IHVuZGVmaW5lZCB9XG59XG5cbmFic3RyYWN0IGNsYXNzIFByb2dyYW1SdW5uZXJFcnJvckJhc2UgZXh0ZW5kcyBFcnJvciB7XG4gIGFic3RyYWN0IHJlYWRvbmx5IF90YWc6IFByb2dyYW1SdW5uZXJFcnJvclRhZ1xuICByZWFkb25seSBtb2R1bGVJZDogc3RyaW5nXG4gIHJlYWRvbmx5IGluc3RhbmNlSWQ6IHN0cmluZ1xuICByZWFkb25seSBlbnRyeXBvaW50OiBcImJvb3RcIiB8IFwibWFpblwiIHwgXCJkaXNwb3NlXCJcbiAgcmVhZG9ubHkgaGludD86IHN0cmluZ1xuXG4gIHByb3RlY3RlZCBjb25zdHJ1Y3RvcihwYXJhbXM6IHtcbiAgICByZWFkb25seSBtZXNzYWdlOiBzdHJpbmdcbiAgICByZWFkb25seSBpZGVudGl0eTogUHJvZ3JhbUlkZW50aXR5XG4gICAgcmVhZG9ubHkgZW50cnlwb2ludDogXCJib290XCIgfCBcIm1haW5cIiB8IFwiZGlzcG9zZVwiXG4gICAgcmVhZG9ubHkgaGludD86IHN0cmluZ1xuICB9KSB7XG4gICAgc3VwZXIocGFyYW1zLm1lc3NhZ2UpXG4gICAgdGhpcy5tb2R1bGVJZCA9IHBhcmFtcy5pZGVudGl0eS5tb2R1bGVJZFxuICAgIHRoaXMuaW5zdGFuY2VJZCA9IHBhcmFtcy5pZGVudGl0eS5pbnN0YW5jZUlkXG4gICAgdGhpcy5lbnRyeXBvaW50ID0gcGFyYW1zLmVudHJ5cG9pbnRcbiAgICB0aGlzLmhpbnQgPSBwYXJhbXMuaGludFxuICB9XG5cbiAgdG9KU09OKCk6IFJlY29yZDxzdHJpbmcsIHVua25vd24+IHtcbiAgICByZXR1cm4ge1xuICAgICAgX3RhZzogdGhpcy5fdGFnLFxuICAgICAgbmFtZTogdGhpcy5uYW1lLFxuICAgICAgbWVzc2FnZTogdGhpcy5tZXNzYWdlLFxuICAgICAgbW9kdWxlSWQ6IHRoaXMubW9kdWxlSWQsXG4gICAgICBpbnN0YW5jZUlkOiB0aGlzLmluc3RhbmNlSWQsXG4gICAgICBlbnRyeXBvaW50OiB0aGlzLmVudHJ5cG9pbnQsXG4gICAgICBoaW50OiB0aGlzLmhpbnQsXG4gICAgfVxuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBCb290RXJyb3IgZXh0ZW5kcyBQcm9ncmFtUnVubmVyRXJyb3JCYXNlIHtcbiAgcmVhZG9ubHkgX3RhZyA9IFwiQm9vdEVycm9yXCIgYXMgY29uc3RcbiAgcmVhZG9ubHkgY2F1c2U/OiB7IG5hbWU/OiBzdHJpbmc7IG1lc3NhZ2U/OiBzdHJpbmcgfVxuXG4gIGNvbnN0cnVjdG9yKGlkZW50aXR5OiBQcm9ncmFtSWRlbnRpdHksIGNhdXNlOiB1bmtub3duKSB7XG4gICAgc3VwZXIoe1xuICAgICAgbWVzc2FnZTogXCJbTG9naXhdIFByb2dyYW0gYm9vdCBmYWlsZWRcIixcbiAgICAgIGlkZW50aXR5LFxuICAgICAgZW50cnlwb2ludDogXCJib290XCIsXG4gICAgICBoaW50OiBcIkNoZWNrIHRoYXQgb3B0aW9ucy5sYXllciAvIGltcG9ydHMgLyBwcm92aWRlcnMgYXJlIGNvbXBsZXRlLCBhbmQgdGhhdCBubyBkZXBlbmRlbmNpZXMgYXJlIG1pc3NpbmcgZHVyaW5nIGFzc2VtYmx5LlwiLFxuICAgIH0pXG4gICAgdGhpcy5uYW1lID0gXCJCb290RXJyb3JcIlxuICAgIHRoaXMuY2F1c2UgPSBzdW1tYXJpemVDYXVzZShjYXVzZSlcbiAgfVxuXG4gIG92ZXJyaWRlIHRvSlNPTigpOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB7XG4gICAgcmV0dXJuIHsgLi4uc3VwZXIudG9KU09OKCksIGNhdXNlOiB0aGlzLmNhdXNlIH1cbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgTWFpbkVycm9yIGV4dGVuZHMgUHJvZ3JhbVJ1bm5lckVycm9yQmFzZSB7XG4gIHJlYWRvbmx5IF90YWcgPSBcIk1haW5FcnJvclwiIGFzIGNvbnN0XG4gIHJlYWRvbmx5IGNhdXNlPzogeyBuYW1lPzogc3RyaW5nOyBtZXNzYWdlPzogc3RyaW5nIH1cblxuICBjb25zdHJ1Y3RvcihpZGVudGl0eTogUHJvZ3JhbUlkZW50aXR5LCBjYXVzZTogdW5rbm93bikge1xuICAgIHN1cGVyKHtcbiAgICAgIG1lc3NhZ2U6IFwiW0xvZ2l4XSBQcm9ncmFtIG1haW4gZmFpbGVkXCIsXG4gICAgICBpZGVudGl0eSxcbiAgICAgIGVudHJ5cG9pbnQ6IFwibWFpblwiLFxuICAgICAgaGludDogXCJNYWluIGZhaWxlZDogZW5zdXJlIG1haW4gaGFuZGxlcyBkb21haW4gZXJyb3JzIGV4cGxpY2l0bHksIGFuZCBjaGVjayBmb3IgaW50ZXJydXB0aW9uIG9yIG1pc3NpbmcgZGVwZW5kZW5jaWVzLlwiLFxuICAgIH0pXG4gICAgdGhpcy5uYW1lID0gXCJNYWluRXJyb3JcIlxuICAgIHRoaXMuY2F1c2UgPSBzdW1tYXJpemVDYXVzZShjYXVzZSlcbiAgfVxuXG4gIG92ZXJyaWRlIHRvSlNPTigpOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB7XG4gICAgcmV0dXJuIHsgLi4uc3VwZXIudG9KU09OKCksIGNhdXNlOiB0aGlzLmNhdXNlIH1cbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgRGlzcG9zZUVycm9yIGV4dGVuZHMgUHJvZ3JhbVJ1bm5lckVycm9yQmFzZSB7XG4gIHJlYWRvbmx5IF90YWcgPSBcIkRpc3Bvc2VFcnJvclwiIGFzIGNvbnN0XG4gIHJlYWRvbmx5IGNhdXNlPzogeyBuYW1lPzogc3RyaW5nOyBtZXNzYWdlPzogc3RyaW5nIH1cblxuICBjb25zdHJ1Y3RvcihpZGVudGl0eTogUHJvZ3JhbUlkZW50aXR5LCBjYXVzZTogdW5rbm93bikge1xuICAgIHN1cGVyKHtcbiAgICAgIG1lc3NhZ2U6IFwiW0xvZ2l4XSBQcm9ncmFtIGRpc3Bvc2UgZmFpbGVkXCIsXG4gICAgICBpZGVudGl0eSxcbiAgICAgIGVudHJ5cG9pbnQ6IFwiZGlzcG9zZVwiLFxuICAgICAgaGludDogXCJEaXNwb3NlIGZhaWxlZDogYSBmaW5hbGl6ZXIgbWF5IGhhdmUgdGhyb3duLCBvciBzY29wZS9yZXNvdXJjZSBoYW5kbGVzIG1heSBiZSBpbnZhbGlkOyBjaGVjayBvbkVycm9yL2xvZ3MuXCIsXG4gICAgfSlcbiAgICB0aGlzLm5hbWUgPSBcIkRpc3Bvc2VFcnJvclwiXG4gICAgdGhpcy5jYXVzZSA9IHN1bW1hcml6ZUNhdXNlKGNhdXNlKVxuICB9XG5cbiAgb3ZlcnJpZGUgdG9KU09OKCk6IFJlY29yZDxzdHJpbmcsIHVua25vd24+IHtcbiAgICByZXR1cm4geyAuLi5zdXBlci50b0pTT04oKSwgY2F1c2U6IHRoaXMuY2F1c2UgfVxuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBEaXNwb3NlVGltZW91dEVycm9yIGV4dGVuZHMgUHJvZ3JhbVJ1bm5lckVycm9yQmFzZSB7XG4gIHJlYWRvbmx5IF90YWcgPSBcIkRpc3Bvc2VUaW1lb3V0XCIgYXMgY29uc3RcbiAgcmVhZG9ubHkgdGltZW91dE1zOiBudW1iZXJcbiAgcmVhZG9ubHkgZWxhcHNlZE1zOiBudW1iZXJcbiAgcmVhZG9ubHkgc3VnZ2VzdGlvbnM6IFJlYWRvbmx5QXJyYXk8c3RyaW5nPlxuXG4gIGNvbnN0cnVjdG9yKFxuICAgIGlkZW50aXR5OiBQcm9ncmFtSWRlbnRpdHksXG4gICAgcGFyYW1zOiB7IHJlYWRvbmx5IHRpbWVvdXRNczogbnVtYmVyOyByZWFkb25seSBlbGFwc2VkTXM6IG51bWJlciB9LFxuICApIHtcbiAgICBzdXBlcih7XG4gICAgICBtZXNzYWdlOiBcIltMb2dpeF0gUHJvZ3JhbSBkaXNwb3NlIHRpbWVkIG91dFwiLFxuICAgICAgaWRlbnRpdHksXG4gICAgICBlbnRyeXBvaW50OiBcImRpc3Bvc2VcIixcbiAgICAgIGhpbnQ6IFwiRGlzcG9zZSB0aW1lZCBvdXQ6IGlmIHRoZSBwcm9ncmFtIGNhbm5vdCBleGl0IG5hdHVyYWxseSwgcmVzb3VyY2VzIG1heSBub3QgYmUgcmVsZWFzZWQgb3IgYmFja2dyb3VuZCBmaWJlcnMgYXJlIHN0aWxsIHJ1bm5pbmcuXCIsXG4gICAgfSlcbiAgICB0aGlzLm5hbWUgPSBcIkRpc3Bvc2VUaW1lb3V0RXJyb3JcIlxuICAgIHRoaXMudGltZW91dE1zID0gcGFyYW1zLnRpbWVvdXRNc1xuICAgIHRoaXMuZWxhcHNlZE1zID0gcGFyYW1zLmVsYXBzZWRNc1xuICAgIHRoaXMuc3VnZ2VzdGlvbnMgPSBbXG4gICAgICBcIkNoZWNrIGZvciBldmVudCBsaXN0ZW5lcnMgdGhhdCB3ZXJlIG5vdCB1bnJlZ2lzdGVyZWQgKGUuZy4gcHJvY2Vzcy5vbiAvIGVtaXR0ZXIub24pLlwiLFxuICAgICAgXCJDaGVjayBmb3IgZmliZXJzIHRoYXQgd2VyZSBub3Qgam9pbmVkL2ludGVycnVwdCAobG9uZy1saXZlZCB3YXRjaGVycyAvIFN0cmVhbS5ydW4qKS5cIixcbiAgICAgIFwiQ2hlY2sgZm9yIHJlc291cmNlIGhhbmRsZXMgdGhhdCB3ZXJlIG5vdCBjbG9zZWQgKHRpbWVyIC8gc29ja2V0IC8gZmlsZSBoYW5kbGUpLlwiLFxuICAgIF1cbiAgfVxuXG4gIG92ZXJyaWRlIHRvSlNPTigpOiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnN1cGVyLnRvSlNPTigpLFxuICAgICAgdGltZW91dE1zOiB0aGlzLnRpbWVvdXRNcyxcbiAgICAgIGVsYXBzZWRNczogdGhpcy5lbGFwc2VkTXMsXG4gICAgICBzdWdnZXN0aW9uczogdGhpcy5zdWdnZXN0aW9ucyxcbiAgICB9XG4gIH1cbn1cbiIsICJpbXBvcnQgeyBDb250ZXh0LCBEZWZlcnJlZCwgRWZmZWN0LCBMYXllciwgTWFuYWdlZFJ1bnRpbWUgfSBmcm9tICdlZmZlY3QnXG5pbXBvcnQge1xuICBDb25jdXJyZW5jeVBvbGljeVRhZyxcbiAgU3RhdGVUcmFuc2FjdGlvbkNvbmZpZ1RhZyxcbiAgdHlwZSBDb25jdXJyZW5jeVBvbGljeSxcbiAgdHlwZSBTdGF0ZVRyYW5zYWN0aW9uUnVudGltZUNvbmZpZyxcbn0gZnJvbSAnLi9jb3JlL2Vudi5qcydcbmltcG9ydCB7IFJvb3RDb250ZXh0VGFnLCB0eXBlIFJvb3RDb250ZXh0IH0gZnJvbSBcIi4vY29yZS9Sb290Q29udGV4dC5qc1wiXG5pbXBvcnQgKiBhcyBQcm9jZXNzUnVudGltZSBmcm9tIFwiLi9jb3JlL3Byb2Nlc3MvUHJvY2Vzc1J1bnRpbWUuanNcIlxuaW1wb3J0IHR5cGUgeyBBbnlNb2R1bGVTaGFwZSwgTW9kdWxlVGFnLCBNb2R1bGVSdW50aW1lLCBTdGF0ZU9mLCBBY3Rpb25PZiB9IGZyb20gJy4vY29yZS9tb2R1bGUuanMnXG5cbi8qKlxuICogQXBwTW9kdWxlRW50cnlcdUZGMUFcdTc1MzEgTG9naXgucHJvdmlkZSBcdTc1MUZcdTYyMTBcdTc2ODRcdTZBMjFcdTU3NTdcdTY3NjFcdTc2RUVcdTMwMDJcbiAqXG4gKiAtIG1vZHVsZVx1RkYxQU1vZHVsZSBcdTVCOUFcdTRFNDlcdTVCRjlcdThDNjFcdUZGMDhcdTY1RTJcdTY2MkYgVGFnXHVGRjBDXHU1M0M4XHU2NDNBXHU1RTI2IFNoYXBlIFx1NEZFMVx1NjA2Rlx1NEUwRVx1NURFNVx1NTM4Mlx1ODBGRFx1NTI5Qlx1RkYwOVx1RkYxQlxuICogLSBsYXllclx1RkYxQVx1OEJFNSBNb2R1bGUgXHU1QkY5XHU1RTk0XHU3Njg0IFJ1bnRpbWUgTGF5ZXJcdTMwMDJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBcHBNb2R1bGVFbnRyeSB7XG4gIHJlYWRvbmx5IG1vZHVsZTogTW9kdWxlVGFnPGFueSwgQW55TW9kdWxlU2hhcGU+XG4gIHJlYWRvbmx5IGxheWVyOiBMYXllci5MYXllcjxhbnksIGFueSwgYW55PlxuICAvKipcbiAgICogXHU1M0VGXHU5MDA5XHVGRjFBXHU3NTMxXHU4QkU1XHU2QTIxXHU1NzU3XHU1QkY5XHU1RTk0IExheWVyIFx1NjNEMFx1NEY5Qlx1NzY4NCBTZXJ2aWNlIFRhZyBcdTUyMTdcdTg4NjhcdTMwMDJcbiAgICpcbiAgICogLSBcdTRFQzVcdTc1MjhcdTRFOEUgQXBwIFx1Njc4NFx1NUVGQVx1OTYzNlx1NkJCNVx1NzY4NCBUYWcgXHU1MUIyXHU3QTgxXHU2OEMwXHU2RDRCXHU0RTBFIEVudiBcdTYyRDNcdTYyNTFcdTUyMDZcdTY3OTBcdUZGMUJcbiAgICogLSBcdTUxODVcdTkwRThcdTU3MjhcdTRGN0ZcdTc1MjggQXBwUnVudGltZSBcdTdFQzRcdTg4QzVcdTVFOTRcdTc1MjhcdTg0RERcdTU2RkVcdTY1RjZcdUZGMENcdTUzRUZcdTkwMUFcdThGQzcgcHJvdmlkZVdpdGhUYWdzIFx1NjYzRVx1NUYwRlx1NThGMFx1NjYwRVx1RkYxQlxuICAgKiAtIFx1NEUwRFx1NUY3MVx1NTRDRFx1OEZEMFx1ODg0Q1x1NjVGNlx1ODg0Q1x1NEUzQVx1RkYwQ1x1NEUwRFx1NThGMFx1NjYwRVx1NTIxOVx1ODlDNlx1NEUzQVx1MjAxQ1x1OEJFNSBNb2R1bGUgTGF5ZXIgXHU2NzJBXHU2NjNFXHU1RjBGXHU2M0QwXHU0RjlCIFNlcnZpY2UgVGFnXHUyMDFEXHUzMDAyXG4gICAqL1xuICByZWFkb25seSBzZXJ2aWNlVGFncz86IFJlYWRvbmx5QXJyYXk8Q29udGV4dC5UYWc8YW55LCBhbnk+PlxufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvZ2l4QXBwQ29uZmlnPFI+IHtcbiAgcmVhZG9ubHkgbGF5ZXI6IExheWVyLkxheWVyPFIsIG5ldmVyLCBuZXZlcj5cbiAgcmVhZG9ubHkgbW9kdWxlczogUmVhZG9ubHlBcnJheTxBcHBNb2R1bGVFbnRyeT5cbiAgcmVhZG9ubHkgcHJvY2Vzc2VzOiBSZWFkb25seUFycmF5PEVmZmVjdC5FZmZlY3Q8dm9pZCwgYW55LCBhbnk+PlxuICByZWFkb25seSBvbkVycm9yPzogKGNhdXNlOiBpbXBvcnQoJ2VmZmVjdCcpLkNhdXNlLkNhdXNlPHVua25vd24+KSA9PiBFZmZlY3QuRWZmZWN0PHZvaWQ+XG4gIC8qKlxuICAgKiBSdW50aW1lIFx1N0VBNyBTdGF0ZVRyYW5zYWN0aW9uIFx1OUVEOFx1OEJBNFx1OTE0RFx1N0Y2RVx1RkYxQVxuICAgKiAtIFx1ODJFNVx1NjcyQVx1NjNEMFx1NEY5Qlx1RkYwQ1x1NTIxOVx1NTQwNCBNb2R1bGVSdW50aW1lIFx1OTAwMFx1NTZERVx1NTIzMFx1NTdGQVx1NEU4RSBOT0RFX0VOViBcdTc2ODRcdTlFRDhcdThCQTRcdTg5QzJcdTZENEJcdTdCNTZcdTc1NjVcdUZGMUJcbiAgICogLSBcdTgyRTVcdTYzRDBcdTRGOUIgaW5zdHJ1bWVudGF0aW9uXHVGRjBDXHU1MjE5XHU0RjVDXHU0RTNBIFJ1bnRpbWUgXHU0RTBCXHU2MjQwXHU2NzA5XHU2QTIxXHU1NzU3XHU3Njg0XHU5RUQ4XHU4QkE0XHU4OUMyXHU2RDRCXHU3RUE3XHU1MjJCXHVGRjBDXG4gICAqICAgXHU1MTc3XHU0RjUzXHU2QTIxXHU1NzU3XHU0RUNEXHU1M0VGXHU5MDFBXHU4RkM3IE1vZHVsZUltcGwuc3RhdGVUcmFuc2FjdGlvbiBcdTg5ODZcdTUxOTlcdTMwMDJcbiAgICovXG4gIHJlYWRvbmx5IHN0YXRlVHJhbnNhY3Rpb24/OiBTdGF0ZVRyYW5zYWN0aW9uUnVudGltZUNvbmZpZ1xuICAvKipcbiAgICogUnVudGltZSBcdTdFQTdcdTVFNzZcdTUzRDFcdTYzQTdcdTUyMzZcdTk3NjJcdUZGMUFcbiAgICogLSBcdTgyRTVcdTY3MkFcdTYzRDBcdTRGOUJcdUZGMENcdTUyMTlcdTU0MDRcdTUxNjVcdTUzRTNcdTkwMDBcdTU2REVcdTUyMzAgYnVpbHRpbiBcdTlFRDhcdThCQTRcdUZGMDhcdTRGOEJcdTU5ODIgY29uY3VycmVuY3lMaW1pdD0xNlx1RkYwOVx1MzAwMlxuICAgKiAtIFx1ODJFNVx1NjNEMFx1NEY5Qlx1RkYwQ1x1NTIxOVx1NEY1Q1x1NEUzQSBSdW50aW1lIFx1NEUwQlx1NjI0MFx1NjcwOVx1NkEyMVx1NTc1N1x1NzY4NFx1OUVEOFx1OEJBNFx1N0I1Nlx1NzU2NVx1RkYxQlxuICAgKiAgIFx1NTE3N1x1NEY1M1x1NkEyMVx1NTc1N1x1NEVDRFx1NTNFRlx1OTAxQVx1OEZDNyBydW50aW1lX21vZHVsZS9wcm92aWRlciBcdTg5ODZcdTUxOTlcdUZGMDhcdTc1MzEgTW9kdWxlUnVudGltZSByZXNvbHZlciBcdTU0MDhcdTVFNzZcdUZGMDlcdTMwMDJcbiAgICovXG4gIHJlYWRvbmx5IGNvbmN1cnJlbmN5UG9saWN5PzogQ29uY3VycmVuY3lQb2xpY3lcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBcHBEZWZpbml0aW9uPFI+IHtcbiAgcmVhZG9ubHkgZGVmaW5pdGlvbjogTG9naXhBcHBDb25maWc8Uj5cbiAgcmVhZG9ubHkgbGF5ZXI6IExheWVyLkxheWVyPFIsIG5ldmVyLCBuZXZlcj5cbiAgcmVhZG9ubHkgbWFrZVJ1bnRpbWU6ICgpID0+IE1hbmFnZWRSdW50aW1lLk1hbmFnZWRSdW50aW1lPFIsIG5ldmVyPlxufVxuXG5pbnRlcmZhY2UgVGFnSW5mbyB7XG4gIHJlYWRvbmx5IGtleTogc3RyaW5nXG4gIHJlYWRvbmx5IHRhZzogQ29udGV4dC5UYWc8YW55LCBhbnk+XG4gIHJlYWRvbmx5IG93bmVyTW9kdWxlSWQ6IHN0cmluZ1xuICByZWFkb25seSBzb3VyY2U6ICdtb2R1bGUnIHwgJ3NlcnZpY2UnXG59XG5cbmludGVyZmFjZSBUYWdDb2xsaXNpb24ge1xuICByZWFkb25seSBrZXk6IHN0cmluZ1xuICByZWFkb25seSBjb25mbGljdHM6IFJlYWRvbmx5QXJyYXk8VGFnSW5mbz5cbn1cblxuaW50ZXJmYWNlIFRhZ0NvbGxpc2lvbkVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICByZWFkb25seSBfdGFnOiAnVGFnQ29sbGlzaW9uRXJyb3InXG4gIHJlYWRvbmx5IGNvbGxpc2lvbnM6IFJlYWRvbmx5QXJyYXk8VGFnQ29sbGlzaW9uPlxufVxuXG5jb25zdCBnZXRUYWdLZXkgPSAodGFnOiBDb250ZXh0LlRhZzxhbnksIGFueT4pOiBzdHJpbmcgPT4ge1xuICBjb25zdCBhbnlUYWcgPSB0YWcgYXMgYW55XG4gIGlmICh0eXBlb2YgYW55VGFnLmtleSA9PT0gJ3N0cmluZycpIHtcbiAgICByZXR1cm4gYW55VGFnLmtleVxuICB9XG4gIGlmICh0eXBlb2YgYW55VGFnLl9pZCA9PT0gJ3N0cmluZycpIHtcbiAgICByZXR1cm4gYW55VGFnLl9pZFxuICB9XG4gIGlmICh0eXBlb2YgYW55VGFnLnRvU3RyaW5nID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcmV0dXJuIGFueVRhZy50b1N0cmluZygpXG4gIH1cbiAgcmV0dXJuICdbdW5rbm93bi10YWddJ1xufVxuXG5jb25zdCBidWlsZFRhZ0luZGV4ID0gKGVudHJpZXM6IFJlYWRvbmx5QXJyYXk8QXBwTW9kdWxlRW50cnk+KTogTWFwPHN0cmluZywgVGFnSW5mb1tdPiA9PiB7XG4gIGNvbnN0IGluZGV4ID0gbmV3IE1hcDxzdHJpbmcsIFRhZ0luZm9bXT4oKVxuXG4gIGZvciAoY29uc3QgZW50cnkgb2YgZW50cmllcykge1xuICAgIGNvbnN0IG93bmVySWQgPSBTdHJpbmcoZW50cnkubW9kdWxlLmlkKVxuXG4gICAgLy8gXHU4QkIwXHU1RjU1IE1vZHVsZSBcdTgxRUFcdThFQUIgVGFnXG4gICAgY29uc3QgbW9kdWxlVGFnID0gZW50cnkubW9kdWxlIGFzIHVua25vd24gYXMgQ29udGV4dC5UYWc8YW55LCBhbnk+XG4gICAgY29uc3QgbW9kdWxlS2V5ID0gZ2V0VGFnS2V5KG1vZHVsZVRhZylcbiAgICBjb25zdCBtb2R1bGVJbmZvOiBUYWdJbmZvID0ge1xuICAgICAga2V5OiBtb2R1bGVLZXksXG4gICAgICB0YWc6IG1vZHVsZVRhZyxcbiAgICAgIG93bmVyTW9kdWxlSWQ6IG93bmVySWQsXG4gICAgICBzb3VyY2U6ICdtb2R1bGUnLFxuICAgIH1cbiAgICBjb25zdCBleGlzdGluZ01vZHVsZUluZm9zID0gaW5kZXguZ2V0KG1vZHVsZUtleSlcbiAgICBpZiAoZXhpc3RpbmdNb2R1bGVJbmZvcykge1xuICAgICAgZXhpc3RpbmdNb2R1bGVJbmZvcy5wdXNoKG1vZHVsZUluZm8pXG4gICAgfSBlbHNlIHtcbiAgICAgIGluZGV4LnNldChtb2R1bGVLZXksIFttb2R1bGVJbmZvXSlcbiAgICB9XG5cbiAgICAvLyBcdThCQjBcdTVGNTVcdTY2M0VcdTVGMEZcdTU4RjBcdTY2MEVcdTc2ODQgU2VydmljZSBUYWdcdUZGMDhcdTU5ODJcdTY3MDlcdUZGMDlcbiAgICBpZiAoZW50cnkuc2VydmljZVRhZ3MgJiYgZW50cnkuc2VydmljZVRhZ3MubGVuZ3RoID4gMCkge1xuICAgICAgZm9yIChjb25zdCB0YWcgb2YgZW50cnkuc2VydmljZVRhZ3MpIHtcbiAgICAgICAgY29uc3Qga2V5ID0gZ2V0VGFnS2V5KHRhZylcbiAgICAgICAgY29uc3QgaW5mbzogVGFnSW5mbyA9IHtcbiAgICAgICAgICBrZXksXG4gICAgICAgICAgdGFnLFxuICAgICAgICAgIG93bmVyTW9kdWxlSWQ6IG93bmVySWQsXG4gICAgICAgICAgc291cmNlOiAnc2VydmljZScsXG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgZXhpc3RpbmdJbmZvcyA9IGluZGV4LmdldChrZXkpXG4gICAgICAgIGlmIChleGlzdGluZ0luZm9zKSB7XG4gICAgICAgICAgZXhpc3RpbmdJbmZvcy5wdXNoKGluZm8pXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgaW5kZXguc2V0KGtleSwgW2luZm9dKVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGluZGV4XG59XG5cbmNvbnN0IHZhbGlkYXRlVGFncyA9IChlbnRyaWVzOiBSZWFkb25seUFycmF5PEFwcE1vZHVsZUVudHJ5Pik6IHZvaWQgPT4ge1xuICBjb25zdCBpbmRleCA9IGJ1aWxkVGFnSW5kZXgoZW50cmllcylcbiAgY29uc3QgY29sbGlzaW9uczogVGFnQ29sbGlzaW9uW10gPSBbXVxuXG4gIGZvciAoY29uc3QgW2tleSwgaW5mb3NdIG9mIGluZGV4KSB7XG4gICAgaWYgKGluZm9zLmxlbmd0aCA8PSAxKSB7XG4gICAgICBjb250aW51ZVxuICAgIH1cbiAgICBjb25zdCBvd25lcnMgPSBuZXcgU2V0PHN0cmluZz4oKVxuICAgIGZvciAoY29uc3QgaW5mbyBvZiBpbmZvcykge1xuICAgICAgb3duZXJzLmFkZChpbmZvLm93bmVyTW9kdWxlSWQpXG4gICAgfVxuICAgIC8vIFx1NEVDNVx1NUY1M1x1NTQwQ1x1NEUwMCBrZXkgXHU1MUZBXHU3M0IwXHU1NzI4XHU1OTFBXHU0RTJBXHU0RTBEXHU1NDBDXHU2QTIxXHU1NzU3XHU0RTBCXHU2NUY2XHU4OUM2XHU0RTNBXHU1MUIyXHU3QTgxXHVGRjFCXG4gICAgLy8gXHU1MzU1XHU2QTIxXHU1NzU3XHU1MTg1XHU5MUNEXHU1OTBEXHU3NjdCXHU4QkIwXHU1NDBDXHU0RTAwIFRhZyBcdTRFMERcdTRGNUNcdTRFM0FcdTk1MTlcdThCRUZcdTU5MDRcdTc0MDZcdUZGMDhcdTUzRUZcdTgwRkRcdTY3NjVcdTgxRUFcdTU5MUFcdTVDNDJcdTdFQzRcdTU0MDhcdUZGMDlcdTMwMDJcbiAgICBpZiAob3duZXJzLnNpemUgPiAxKSB7XG4gICAgICBjb2xsaXNpb25zLnB1c2goeyBrZXksIGNvbmZsaWN0czogaW5mb3MgfSlcbiAgICB9XG4gIH1cblxuICBpZiAoY29sbGlzaW9ucy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm5cbiAgfVxuXG4gIGNvbnN0IG1lc3NhZ2UgPVxuICAgICdbTG9naXhdIFRhZyBjb2xsaXNpb24gZGV0ZWN0ZWQ6XFxuJyArXG4gICAgY29sbGlzaW9uc1xuICAgICAgLm1hcCgoYykgPT4ge1xuICAgICAgICBjb25zdCBoZWFkZXIgPSBgLSBrZXk6ICR7Yy5rZXl9YFxuICAgICAgICBjb25zdCBsaW5lcyA9IGMuY29uZmxpY3RzLm1hcCgoaSkgPT4gYCAgLSBvd25lcjogJHtpLm93bmVyTW9kdWxlSWR9LCBzb3VyY2U6ICR7aS5zb3VyY2V9YClcbiAgICAgICAgcmV0dXJuIFtoZWFkZXIsIC4uLmxpbmVzXS5qb2luKCdcXG4nKVxuICAgICAgfSlcbiAgICAgIC5qb2luKCdcXG4nKVxuXG4gIGNvbnN0IGVycm9yOiBUYWdDb2xsaXNpb25FcnJvciA9IE9iamVjdC5hc3NpZ24obmV3IEVycm9yKG1lc3NhZ2UpLCB7XG4gICAgX3RhZzogJ1RhZ0NvbGxpc2lvbkVycm9yJyBhcyBjb25zdCxcbiAgICBjb2xsaXNpb25zLFxuICB9KVxuXG4gIHRocm93IGVycm9yXG59XG5cbmV4cG9ydCBjb25zdCBtYWtlQXBwID0gPFI+KGNvbmZpZzogTG9naXhBcHBDb25maWc8Uj4pOiBBcHBEZWZpbml0aW9uPFI+ID0+IHtcbiAgY29uc3Qgc2VlbklkcyA9IG5ldyBTZXQ8c3RyaW5nPigpXG4gIGZvciAoY29uc3QgZW50cnkgb2YgY29uZmlnLm1vZHVsZXMpIHtcbiAgICBjb25zdCBpZCA9IFN0cmluZyhlbnRyeS5tb2R1bGUuaWQpXG5cbiAgICBpZiAoc2Vlbklkcy5oYXMoaWQpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgIGBbTG9naXhdIER1cGxpY2F0ZSBNb2R1bGUgSUQvVGFnIGRldGVjdGVkOiBcIiR7aWR9XCIuIFxcbkVuc3VyZSBhbGwgbW9kdWxlcyBpbiB0aGUgYXBwbGljYXRpb24gUnVudGltZSBoYXZlIHVuaXF1ZSBJRHMuYCxcbiAgICAgIClcbiAgICB9XG4gICAgc2Vlbklkcy5hZGQoaWQpXG4gIH1cblxuICAvLyBcdTU3MjhcdTU0MDhcdTVFNzYgTGF5ZXIgXHU0RTRCXHU1MjREXHVGRjBDXHU1QkY5IE1vZHVsZSBUYWcgXHU0RTBFXHU2NjNFXHU1RjBGXHU2M0QwXHU0RjlCXHU3Njg0IFNlcnZpY2UgVGFnIFx1NTA1QVx1NEUwMFx1NkIyMVx1NTFCMlx1N0E4MVx1NjgyMVx1OUE4Q1x1MzAwMlxuICAvLyBcdThGRDlcdTUzRUZcdTRFRTVcdTYzRDBcdTUyNERcdTY2QjRcdTk3MzJcdTIwMUNcdTU0MENcdTRFMDAgU2VydmljZVRhZyBcdTc1MzFcdTU5MUFcdTRFMkFcdTZBMjFcdTU3NTdcdTVCOUVcdTczQjBcdTIwMURcdTc2ODRcdTk1RUVcdTk4OThcdUZGMENcdTkwN0ZcdTUxNEQgRW52IFx1ODhBQlx1OTc1OVx1OUVEOFx1ODk4Nlx1NzZENlx1MzAwMlxuICB2YWxpZGF0ZVRhZ3MoY29uZmlnLm1vZHVsZXMpXG5cbiAgLy8gXHU4MkU1IFJ1bnRpbWUgXHU1QzQyXHU2M0QwXHU0RjlCXHU0RTg2XHU3RURGXHU0RTAwXHU3Njg0IFN0YXRlVHJhbnNhY3Rpb24gXHU5MTREXHU3RjZFXHVGRjBDXHU1MjE5XHU1NzI4IEFwcCBcdTdFQTcgRW52IFx1NEUwQVx1OEZGRFx1NTJBMFx1NUJGOVx1NUU5NCBTZXJ2aWNlXHUzMDAyXG4gIGNvbnN0IHN0YXRlVHhuTGF5ZXI6IExheWVyLkxheWVyPFIsIG5ldmVyLCBuZXZlcj4gPVxuICAgIGNvbmZpZy5zdGF0ZVRyYW5zYWN0aW9uXG4gICAgICA/IChMYXllci5zdWNjZWVkKFN0YXRlVHJhbnNhY3Rpb25Db25maWdUYWcsIGNvbmZpZy5zdGF0ZVRyYW5zYWN0aW9uKSBhcyBMYXllci5MYXllcjxSLCBuZXZlciwgbmV2ZXI+KVxuICAgICAgOiAoTGF5ZXIuZW1wdHkgYXMgTGF5ZXIuTGF5ZXI8UiwgbmV2ZXIsIG5ldmVyPilcblxuICAvLyBcdTgyRTUgUnVudGltZSBcdTVDNDJcdTYzRDBcdTRGOUJcdTRFODZcdTdFREZcdTRFMDBcdTc2ODQgQ29uY3VycmVuY3lQb2xpY3lcdUZGMENcdTUyMTlcdTU3MjggQXBwIFx1N0VBNyBFbnYgXHU0RTBBXHU4RkZEXHU1MkEwXHU1QkY5XHU1RTk0IFNlcnZpY2VcdTMwMDJcbiAgY29uc3QgY29uY3VycmVuY3lQb2xpY3lMYXllcjogTGF5ZXIuTGF5ZXI8UiwgbmV2ZXIsIG5ldmVyPiA9XG4gICAgY29uZmlnLmNvbmN1cnJlbmN5UG9saWN5XG4gICAgICA/IChMYXllci5zdWNjZWVkKENvbmN1cnJlbmN5UG9saWN5VGFnLCBjb25maWcuY29uY3VycmVuY3lQb2xpY3kpIGFzIExheWVyLkxheWVyPFIsIG5ldmVyLCBuZXZlcj4pXG4gICAgICA6IChMYXllci5lbXB0eSBhcyBMYXllci5MYXllcjxSLCBuZXZlciwgbmV2ZXI+KVxuXG4gIGNvbnN0IGFwcE1vZHVsZUlkcyA9IGNvbmZpZy5tb2R1bGVzLm1hcCgoZW50cnkpID0+IFN0cmluZyhlbnRyeS5tb2R1bGUuaWQpKVxuICBjb25zdCBhcHBJZCA9XG4gICAgYXBwTW9kdWxlSWRzLmxlbmd0aCA9PT0gMVxuICAgICAgPyBhcHBNb2R1bGVJZHNbMF0hXG4gICAgICA6IGFwcE1vZHVsZUlkcy5zbGljZSgpLnNvcnQoKS5qb2luKFwiflwiKVxuXG4gIGNvbnN0IGJhc2VMYXllciA9IExheWVyLm1lcmdlQWxsKFxuICAgIGNvbmZpZy5sYXllcixcbiAgICBzdGF0ZVR4bkxheWVyLFxuICAgIGNvbmN1cnJlbmN5UG9saWN5TGF5ZXIsXG4gICAgUHJvY2Vzc1J1bnRpbWUubGF5ZXIoKSxcbiAgICBMYXllci5lZmZlY3QoXG4gICAgICBSb290Q29udGV4dFRhZyxcbiAgICAgIEVmZmVjdC5nZW4oZnVuY3Rpb24qICgpIHtcbiAgICAgICAgY29uc3QgcmVhZHkgPSB5aWVsZCogRGVmZXJyZWQubWFrZTxDb250ZXh0LkNvbnRleHQ8YW55Pj4oKVxuICAgICAgICByZXR1cm4geyBjb250ZXh0OiB1bmRlZmluZWQsIHJlYWR5LCBhcHBJZCwgYXBwTW9kdWxlSWRzIH0gc2F0aXNmaWVzIFJvb3RDb250ZXh0XG4gICAgICB9KSxcbiAgICApLFxuICApIGFzIExheWVyLkxheWVyPFIsIG5ldmVyLCBuZXZlcj5cblxuICBjb25zdCBtb2R1bGVMYXllcnMgPSBjb25maWcubW9kdWxlcy5tYXAoKGVudHJ5KSA9PlxuICAgIC8vIFx1Nzg2RVx1NEZERFx1NkJDRlx1NEUyQVx1NkEyMVx1NTc1N1x1NUM0Mlx1OTBGRFx1ODBGRFx1NzcwQlx1NTIzMCBBcHAgXHU3RUE3IEVudlx1RkYwOGJhc2VMYXllclx1RkYwOVx1RkYwQ1x1OTA3Rlx1NTE0RFx1NTcyOFx1NTIxRFx1NTlDQlx1NTMxNlx1OTYzNlx1NkJCNVx1NjI3RVx1NEUwRFx1NTIzMCBSb290IEVudlx1MzAwMlxuICAgIExheWVyLnByb3ZpZGUoZW50cnkubGF5ZXIsIGJhc2VMYXllciksXG4gIClcbiAgY29uc3QgZW52TGF5ZXIgPSBtb2R1bGVMYXllcnMubGVuZ3RoID4gMCA/IExheWVyLm1lcmdlQWxsKGJhc2VMYXllciwgLi4ubW9kdWxlTGF5ZXJzKSA6IGJhc2VMYXllclxuXG4gIGNvbnN0IGZpbmFsTGF5ZXIgPSBMYXllci51bndyYXBTY29wZWQoXG4gICAgRWZmZWN0LmdlbihmdW5jdGlvbiogKCkge1xuICAgICAgY29uc3Qgc2NvcGUgPSB5aWVsZCogRWZmZWN0LnNjb3BlXG5cbiAgICAgIC8vIGJ1aWxkV2l0aFNjb3BlIFx1NEYxQVx1NTcyOFx1NUY1M1x1NTI0RCBzY29wZSBcdTUxODVcdTY3ODRcdTVFRkEgZW52TGF5ZXJcdUZGMENcdTVFNzZcdTU3MjggRmliZXJSZWZzIFx1NEUwQVx1NjI1M1x1ODg2NVx1NEUwMVx1RkYwOFx1NEY4Qlx1NTk4MiBEZWJ1ZyBzaW5rc1x1RkYwOVx1MzAwMlxuICAgICAgLy8gXHU4RkQ5XHU5MUNDXHU3NTI4IGRpZmZGaWJlclJlZnMgXHU1MzA1XHU4OEY5IGJ1aWxkV2l0aFNjb3BlXHVGRjBDXHU2MzU1XHU4M0I3IEZpYmVyUmVmcyBcdTc2ODRcdTUzRDhcdTY2RjQgcGF0Y2hcdUZGMENcbiAgICAgIC8vIFx1NTE4RFx1NjI4QSBwYXRjaCBcdTRGNUNcdTRFM0FcdTRFMDBcdTVDNDIgTGF5ZXIgXHU1NkRFXHU3MDRDXHU1MjMwXHU2NzAwXHU3RUM4IFJ1bnRpbWVcdUZGMENcdTkwN0ZcdTUxNEQgRmliZXJSZWYgXHU0RkVFXHU2NTM5XHU1NzI4XHU3RUM0XHU4OEM1XHU5NjM2XHU2QkI1XHU4OEFCXHUyMDFDXHU2RDE3XHU2Mzg5XHUyMDFEXHUzMDAyXG4gICAgICBjb25zdCBbcGF0Y2gsIGVudl0gPSB5aWVsZCogRWZmZWN0LmRpZmZGaWJlclJlZnMoTGF5ZXIuYnVpbGRXaXRoU2NvcGUoZW52TGF5ZXIsIHNjb3BlKSlcblxuICAgICAgLy8gRW52TGF5ZXIgYnVpbGQgXHU1QjhDXHU2MjEwXHU1NDBFXHVGRjBDXHU4ODY1XHU5RjUwIFJvb3RDb250ZXh0XHVGRjA4XHU0RjVDXHU0RTNBIHJvb3QgcHJvdmlkZXIgXHU3Njg0XHU1MzU1XHU0RTAwXHU0RThCXHU1QjlFXHU2RTkwXHVGRjA5XHUzMDAyXG4gICAgICAvLyBcdTZDRThcdTYxMEZcdUZGMUFNb2R1bGUgbG9naWNzIFx1NTNFRlx1ODBGRFx1NURGMiBmb3JrIFx1NUU3Nlx1NTcyOCBydW4gXHU5NjM2XHU2QkI1XHU3QjQ5XHU1Rjg1IFJvb3RDb250ZXh0XHVGRjFCXHU4RkQ5XHU5MUNDXHU1QjhDXHU2MjEwXHU1NDBFXHU1MzczXHU1M0VGXHU4OUUzXHU5NTAxXHUzMDAyXG4gICAgICAvLyBSb290Q29udGV4dFRhZyBcdTVDNUVcdTRFOEUgQXBwUnVudGltZSBcdTUxODVcdTkwRThcdTZDRThcdTUxNjVcdTc2ODRcdTY3MERcdTUyQTFcdUZGMDhcdTRFMERcdTVFOTRcdTZDQzRcdTZGMEZcdTUyMzBcdTU5MTZcdTkwRTggUiBcdTdDN0JcdTU3OEJcdUZGMDlcdUZGMENcbiAgICAgIC8vIFx1OEZEOVx1OTFDQ1x1NzUyOFx1NjcwMFx1NUMwRlx1NzY4NFx1N0M3Qlx1NTc4Qlx1NjUzNlx1N0E4NFx1OTA3Rlx1NTE0RCBDb250ZXh0LmdldCBcdTc2ODRcdTZDREJcdTU3OEJcdTdFQTZcdTY3NUZcdThCRUZcdTUyMjRcdTMwMDJcbiAgICAgIGNvbnN0IHJvb3RDb250ZXh0ID0gQ29udGV4dC5nZXQoXG4gICAgICAgIGVudiBhcyBDb250ZXh0LkNvbnRleHQ8YW55PixcbiAgICAgICAgUm9vdENvbnRleHRUYWcgYXMgYW55LFxuICAgICAgKSBhcyBSb290Q29udGV4dFxuXG4gICAgICByb290Q29udGV4dC5jb250ZXh0ID0gZW52IGFzIENvbnRleHQuQ29udGV4dDxhbnk+XG4gICAgICB5aWVsZCogRGVmZXJyZWQuc3VjY2VlZChyb290Q29udGV4dC5yZWFkeSwgZW52IGFzIENvbnRleHQuQ29udGV4dDxhbnk+KVxuXG4gICAgICBjb25zdCBwcm9jZXNzUnVudGltZSA9IENvbnRleHQuZ2V0KFxuICAgICAgICBlbnYgYXMgQ29udGV4dC5Db250ZXh0PGFueT4sXG4gICAgICAgIFByb2Nlc3NSdW50aW1lLlByb2Nlc3NSdW50aW1lVGFnIGFzIGFueSxcbiAgICAgICkgYXMgUHJvY2Vzc1J1bnRpbWUuUHJvY2Vzc1J1bnRpbWVcblxuICAgICAgLy8gXHU1NzI4IEVudiBcdTVCOENcdTUxNjhcdTVDMzFcdTdFRUFcdTU0MEVcdUZGMENcdTUxOERcdTU0MkZcdTUyQTggQXBwIFx1N0VBN1x1OTU3Rlx1NjcxRlx1OEZEQlx1N0EwQlx1RkYwOFByb2Nlc3MgLyBMaW5rIC8gd2F0Y2hlciAvIGhvc3QgYnJpZGdlIFx1N0I0OVx1RkYwOVx1MzAwMlxuICAgICAgeWllbGQqIEVmZmVjdC5mb3JFYWNoKFxuICAgICAgICBjb25maWcucHJvY2Vzc2VzLFxuICAgICAgICAocHJvY2VzcykgPT5cbiAgICAgICAgICBFZmZlY3QuZ2VuKGZ1bmN0aW9uKiAoKSB7XG4gICAgICAgICAgICBjb25zdCBpbnN0YWxsYXRpb24gPSB5aWVsZCogRWZmZWN0LnByb3ZpZGUoXG4gICAgICAgICAgICAgIHByb2Nlc3NSdW50aW1lLmluc3RhbGwocHJvY2VzcyBhcyBhbnksIHtcbiAgICAgICAgICAgICAgICBzY29wZTogeyB0eXBlOiBcImFwcFwiLCBhcHBJZCB9LFxuICAgICAgICAgICAgICAgIGVuYWJsZWQ6IHRydWUsXG4gICAgICAgICAgICAgICAgaW5zdGFsbGVkQXQ6IFwiYXBwUnVudGltZVwiLFxuICAgICAgICAgICAgICB9KSxcbiAgICAgICAgICAgICAgZW52LFxuICAgICAgICAgICAgKVxuXG4gICAgICAgICAgICAvLyBsZWdhY3kgZmFsbGJhY2tcdUZGMUFcdTg4RjggRWZmZWN0IFx1NEVDRFx1NTE0MVx1OEJCOFx1NEY1Q1x1NEUzQSBwcm9jZXNzZXMgXHU4RkQwXHU4ODRDXHU2MjdGXHU4RjdEXHVGRjBDXHU0RjQ2XHU0RTBEXHU1MTc3XHU1OTA3IFByb2Nlc3MgXHU5NzU5XHU2MDAxXHU5NzYyL1x1OEJDQVx1NjVBRFx1ODBGRFx1NTI5Qlx1MzAwMlxuICAgICAgICAgICAgaWYgKGluc3RhbGxhdGlvbiA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAgIHlpZWxkKiBFZmZlY3QuZm9ya1Njb3BlZChcbiAgICAgICAgICAgICAgICBFZmZlY3QucHJvdmlkZShcbiAgICAgICAgICAgICAgICAgIGNvbmZpZy5vbkVycm9yID8gRWZmZWN0LmNhdGNoQWxsQ2F1c2UocHJvY2VzcywgY29uZmlnLm9uRXJyb3IpIDogcHJvY2VzcyxcbiAgICAgICAgICAgICAgICAgIGVudixcbiAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgICApXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSksXG4gICAgICAgIHsgZGlzY2FyZDogdHJ1ZSB9LFxuICAgICAgKVxuXG4gICAgICBjb25zdCBmaWJlclJlZnNMYXllciA9IExheWVyLnNjb3BlZERpc2NhcmQoRWZmZWN0LnBhdGNoRmliZXJSZWZzKHBhdGNoKSlcblxuICAgICAgcmV0dXJuIExheWVyLm1lcmdlQWxsKFxuICAgICAgICBMYXllci5zdWNjZWVkQ29udGV4dChlbnYpLFxuICAgICAgICBmaWJlclJlZnNMYXllcixcbiAgICAgIClcbiAgICB9KSxcbiAgKSBhcyBMYXllci5MYXllcjxSLCBuZXZlciwgbmV2ZXI+XG5cbiAgcmV0dXJuIHtcbiAgICBkZWZpbml0aW9uOiBjb25maWcsXG4gICAgbGF5ZXI6IGZpbmFsTGF5ZXIsXG4gICAgbWFrZVJ1bnRpbWU6ICgpID0+IE1hbmFnZWRSdW50aW1lLm1ha2UoZmluYWxMYXllciksXG4gIH1cbn1cblxuLyoqXG4gKiBcdThCRURcdTZDRDVcdTdDRDZcdUZGMUFcdTVDMDYgTW9kdWxlIFx1NEUwRSBSdW50aW1lIFx1NUI5RVx1NEY4Qlx1NjIxNiBMYXllciBcdTkxNERcdTVCRjlcdUZGMENcdTc1MjhcdTRFOEUgQXBwUnVudGltZSBcdTc2ODQgbW9kdWxlcyBcdTkxNERcdTdGNkVcdTMwMDJcbiAqL1xuZXhwb3J0IGNvbnN0IHByb3ZpZGUgPSA8U2ggZXh0ZW5kcyBBbnlNb2R1bGVTaGFwZSwgUiwgRT4oXG4gIG1vZHVsZTogTW9kdWxlVGFnPGFueSwgU2g+LFxuICByZXNvdXJjZTogTGF5ZXIuTGF5ZXI8TW9kdWxlUnVudGltZTxTdGF0ZU9mPFNoPiwgQWN0aW9uT2Y8U2g+PiwgRSwgUj4gfCBNb2R1bGVSdW50aW1lPFN0YXRlT2Y8U2g+LCBBY3Rpb25PZjxTaD4+LFxuKTogQXBwTW9kdWxlRW50cnkgPT4ge1xuICBjb25zdCBsYXllciA9IGlzTGF5ZXIocmVzb3VyY2UpXG4gICAgPyByZXNvdXJjZVxuICAgIDogTGF5ZXIuc3VjY2VlZChtb2R1bGUsIHJlc291cmNlIGFzIE1vZHVsZVJ1bnRpbWU8U3RhdGVPZjxTaD4sIEFjdGlvbk9mPFNoPj4pXG5cbiAgcmV0dXJuIHsgbW9kdWxlLCBsYXllciB9XG59XG5cbi8qKlxuICogXHU4QkVEXHU2Q0Q1XHU3Q0Q2XHVGRjFBXHU1NzI4IEFwcCBcdTZBMjFcdTU3NTdcdTY3NjFcdTc2RUVcdTRFMEFcdTk2NDRcdTUyQTBcdTY2M0VcdTVGMEYgU2VydmljZSBUYWcgXHU1MTQzXHU0RkUxXHU2MDZGXHVGRjBDXHU3NTI4XHU0RThFIFRhZyBcdTUxQjJcdTdBODFcdTY4QzBcdTZENEJcdTMwMDJcbiAqXG4gKiAtIHNlcnZpY2VUYWdzIFx1NUU5NFx1NEVDNVx1NTMwNVx1NTQyQlx1MjAxQ1x1NzUzMVx1OEJFNVx1NkEyMVx1NTc1N1x1NUJGOVx1NUU5NCBMYXllciBcdTYzRDBcdTRGOUJcdTVCOUVcdTczQjBcdTIwMURcdTc2ODQgU2VydmljZVx1RkYxQlxuICogLSBcdTkwMUFcdThGQzcgTG9naXgucHJvdmlkZVdpdGhUYWdzIFx1NjZCNFx1OTczMlx1N0VEOVx1NEUxQVx1NTJBMVx1NEVFM1x1NzgwMVx1RkYwQ1x1NTcyOCBBcHAgXHU2Nzg0XHU1RUZBXHU5NjM2XHU2QkI1XHU2M0QwXHU1MjREXHU1M0QxXHU3M0IwIFRhZyBLZXkgXHU1MUIyXHU3QTgxXHUzMDAyXG4gKi9cbmV4cG9ydCBjb25zdCBwcm92aWRlV2l0aFRhZ3MgPSA8U2ggZXh0ZW5kcyBBbnlNb2R1bGVTaGFwZSwgUiwgRT4oXG4gIG1vZHVsZTogTW9kdWxlVGFnPGFueSwgU2g+LFxuICByZXNvdXJjZTogTGF5ZXIuTGF5ZXI8TW9kdWxlUnVudGltZTxTdGF0ZU9mPFNoPiwgQWN0aW9uT2Y8U2g+PiwgRSwgUj4gfCBNb2R1bGVSdW50aW1lPFN0YXRlT2Y8U2g+LCBBY3Rpb25PZjxTaD4+LFxuICBzZXJ2aWNlVGFnczogUmVhZG9ubHlBcnJheTxDb250ZXh0LlRhZzxhbnksIGFueT4+LFxuKTogQXBwTW9kdWxlRW50cnkgPT4ge1xuICBjb25zdCBiYXNlID0gcHJvdmlkZShtb2R1bGUsIHJlc291cmNlKVxuICByZXR1cm4ge1xuICAgIC4uLmJhc2UsXG4gICAgc2VydmljZVRhZ3MsXG4gIH1cbn1cblxuY29uc3QgaXNMYXllciA9ICh2YWx1ZTogdW5rbm93bik6IHZhbHVlIGlzIExheWVyLkxheWVyPGFueSwgYW55LCBhbnk+ID0+XG4gIHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcgJiYgdmFsdWUgIT09IG51bGwgJiYgTGF5ZXIuTGF5ZXJUeXBlSWQgaW4gdmFsdWVcbiIsICJpbXBvcnQgeyBDYXVzZSwgRWZmZWN0LCBFeGl0LCBGaWJlciwgT3B0aW9uLCBTY29wZSB9IGZyb20gXCJlZmZlY3RcIlxuaW1wb3J0IHtcbiAgRGlzcG9zZUVycm9yLFxuICBEaXNwb3NlVGltZW91dEVycm9yLFxuICB0eXBlIFByb2dyYW1JZGVudGl0eSxcbn0gZnJvbSBcIi4vUHJvZ3JhbVJ1bm5lci5lcnJvcnMuanNcIlxuXG5leHBvcnQgY29uc3QgY2xvc2VQcm9ncmFtU2NvcGUgPSAocGFyYW1zOiB7XG4gIHJlYWRvbmx5IHNjb3BlOiBTY29wZS5DbG9zZWFibGVTY29wZVxuICByZWFkb25seSB0aW1lb3V0TXM6IG51bWJlclxuICByZWFkb25seSBpZGVudGl0eTogUHJvZ3JhbUlkZW50aXR5XG4gIHJlYWRvbmx5IG9uRXJyb3I/OiAoY2F1c2U6IENhdXNlLkNhdXNlPHVua25vd24+KSA9PiBFZmZlY3QuRWZmZWN0PHZvaWQsIG5ldmVyLCBuZXZlcj5cbn0pOiBFZmZlY3QuRWZmZWN0PHZvaWQsIG5ldmVyLCBuZXZlcj4gPT4ge1xuICByZXR1cm4gRWZmZWN0LmdlbihmdW5jdGlvbiogKCkge1xuICAgIGNvbnN0IHN0YXJ0ID0gRGF0ZS5ub3coKVxuXG4gICAgY29uc3QgZmliZXIgPSB5aWVsZCogRWZmZWN0LmZvcmtEYWVtb24oU2NvcGUuY2xvc2UocGFyYW1zLnNjb3BlLCBFeGl0LnZvaWQpKVxuXG4gICAgd2hpbGUgKHRydWUpIHtcbiAgICAgIGNvbnN0IGV4aXRPcHQgPSB5aWVsZCogRmliZXIucG9sbChmaWJlcilcbiAgICAgIGlmIChPcHRpb24uaXNTb21lKGV4aXRPcHQpKSB7XG4gICAgICAgIGNvbnN0IGV4aXQgPSBleGl0T3B0LnZhbHVlXG4gICAgICAgIGlmIChleGl0Ll90YWcgPT09IFwiU3VjY2Vzc1wiKSB7XG4gICAgICAgICAgcmV0dXJuXG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHlpZWxkKiBFZmZlY3QuZGllKG5ldyBEaXNwb3NlRXJyb3IocGFyYW1zLmlkZW50aXR5LCBleGl0LmNhdXNlKSlcbiAgICAgIH1cblxuICAgICAgY29uc3QgZWxhcHNlZE1zID0gRGF0ZS5ub3coKSAtIHN0YXJ0XG4gICAgICBpZiAoZWxhcHNlZE1zID49IHBhcmFtcy50aW1lb3V0TXMpIHtcbiAgICAgICAgY29uc3QgZXJyb3IgPSBuZXcgRGlzcG9zZVRpbWVvdXRFcnJvcihwYXJhbXMuaWRlbnRpdHksIHtcbiAgICAgICAgICB0aW1lb3V0TXM6IHBhcmFtcy50aW1lb3V0TXMsXG4gICAgICAgICAgZWxhcHNlZE1zLFxuICAgICAgICB9KVxuXG4gICAgICAgIGlmICh0eXBlb2YgcGFyYW1zLm9uRXJyb3IgPT09IFwiZnVuY3Rpb25cIikge1xuICAgICAgICAgIHlpZWxkKiBwYXJhbXNcbiAgICAgICAgICAgIC5vbkVycm9yKENhdXNlLmRpZShlcnJvcikpXG4gICAgICAgICAgICAucGlwZShFZmZlY3QuY2F0Y2hBbGxDYXVzZSgoKSA9PiBFZmZlY3Qudm9pZCkpXG4gICAgICAgIH1cblxuICAgICAgICB5aWVsZCogRmliZXIuaW50ZXJydXB0Rm9yayhmaWJlcilcbiAgICAgICAgcmV0dXJuIHlpZWxkKiBFZmZlY3QuZGllKGVycm9yKVxuICAgICAgfVxuXG4gICAgICAvLyBOT1RFOiBVc2UgYSBtaWNyb3Rhc2sgeWllbGQgKG5vdCBUZXN0Q2xvY2stYmFzZWQpIHRvIGF2b2lkIGJlaW5nIGJsb2NrZWQgYnkgVGVzdENsb2NrLFxuICAgICAgLy8gd2hpbGUga2VlcGluZyB0aGUgXCJzdWNjZXNzZnVsIGNsb3NlXCIgZmFzdCBwYXRoIGNoZWFwIChwZXJmLWNyaXRpY2FsIGZvciB0aWdodCBsb29wcykuXG4gICAgICB5aWVsZCogRWZmZWN0LnByb21pc2UoKCkgPT4gbmV3IFByb21pc2U8dm9pZD4oKHIpID0+IHF1ZXVlTWljcm90YXNrKHIpKSlcbiAgICB9XG4gIH0pXG59XG4iLCAiaW1wb3J0IHsgRWZmZWN0LCBFeGl0LCBTY29wZSB9IGZyb20gXCJlZmZlY3RcIlxuXG5jb25zdCBnZXRQcm9jZXNzID0gKCk6IGFueSA9PiAoZ2xvYmFsVGhpcyBhcyBhbnkpLnByb2Nlc3NcblxuY29uc3QgaXNOb2RlUHJvY2VzcyA9ICh2YWx1ZTogdW5rbm93bik6IHZhbHVlIGlzIHtcbiAgb246IChldmVudDogc3RyaW5nLCBoYW5kbGVyOiAoKSA9PiB2b2lkKSA9PiB2b2lkXG4gIG9mZj86IChldmVudDogc3RyaW5nLCBoYW5kbGVyOiAoKSA9PiB2b2lkKSA9PiB2b2lkXG4gIHJlbW92ZUxpc3RlbmVyPzogKGV2ZW50OiBzdHJpbmcsIGhhbmRsZXI6ICgpID0+IHZvaWQpID0+IHZvaWRcbn0gPT5cbiAgdHlwZW9mIHZhbHVlID09PSBcIm9iamVjdFwiICYmXG4gIHZhbHVlICE9PSBudWxsICYmXG4gIHR5cGVvZiAodmFsdWUgYXMgYW55KS5vbiA9PT0gXCJmdW5jdGlvblwiXG5cbmNvbnN0IHJlbW92ZUxpc3RlbmVyID0gKHByb2M6IGFueSwgZXZlbnQ6IHN0cmluZywgaGFuZGxlcjogKCkgPT4gdm9pZCk6IHZvaWQgPT4ge1xuICBpZiAodHlwZW9mIHByb2Mub2ZmID09PSBcImZ1bmN0aW9uXCIpIHtcbiAgICBwcm9jLm9mZihldmVudCwgaGFuZGxlcilcbiAgICByZXR1cm5cbiAgfVxuICBpZiAodHlwZW9mIHByb2MucmVtb3ZlTGlzdGVuZXIgPT09IFwiZnVuY3Rpb25cIikge1xuICAgIHByb2MucmVtb3ZlTGlzdGVuZXIoZXZlbnQsIGhhbmRsZXIpXG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGluc3RhbGxHcmFjZWZ1bFNodXRkb3duSGFuZGxlcnMgPSAocGFyYW1zOiB7XG4gIHJlYWRvbmx5IHNjb3BlOiBTY29wZS5DbG9zZWFibGVTY29wZVxuICByZWFkb25seSBlbmFibGVkOiBib29sZWFuXG59KTogRWZmZWN0LkVmZmVjdDx2b2lkPiA9PiB7XG4gIGlmICghcGFyYW1zLmVuYWJsZWQpIHtcbiAgICByZXR1cm4gRWZmZWN0LnZvaWRcbiAgfVxuXG4gIGNvbnN0IHByb2MgPSBnZXRQcm9jZXNzKClcbiAgaWYgKCFpc05vZGVQcm9jZXNzKHByb2MpKSB7XG4gICAgcmV0dXJuIEVmZmVjdC52b2lkXG4gIH1cblxuICBjb25zdCBoYW5kbGVyID0gKCk6IHZvaWQgPT4ge1xuICAgIHZvaWQgRWZmZWN0LnJ1blByb21pc2UoU2NvcGUuY2xvc2UocGFyYW1zLnNjb3BlLCBFeGl0LnZvaWQpKVxuICB9XG5cbiAgcmV0dXJuIEVmZmVjdC5nZW4oZnVuY3Rpb24qICgpIHtcbiAgICB5aWVsZCogU2NvcGUuYWRkRmluYWxpemVyKFxuICAgICAgcGFyYW1zLnNjb3BlLFxuICAgICAgRWZmZWN0LnN5bmMoKCkgPT4ge1xuICAgICAgICByZW1vdmVMaXN0ZW5lcihwcm9jLCBcIlNJR0lOVFwiLCBoYW5kbGVyKVxuICAgICAgICByZW1vdmVMaXN0ZW5lcihwcm9jLCBcIlNJR1RFUk1cIiwgaGFuZGxlcilcbiAgICAgIH0pLFxuICAgIClcblxuICAgIHlpZWxkKiBFZmZlY3Quc3luYygoKSA9PiB7XG4gICAgICBwcm9jLm9uKFwiU0lHSU5UXCIsIGhhbmRsZXIpXG4gICAgICBwcm9jLm9uKFwiU0lHVEVSTVwiLCBoYW5kbGVyKVxuICAgIH0pXG4gIH0pXG59XG5cbiIsICJpbXBvcnQgeyBFZmZlY3QsIFNjb3BlIH0gZnJvbSBcImVmZmVjdFwiXG5pbXBvcnQgdHlwZSB7IE1hbmFnZWRSdW50aW1lIH0gZnJvbSBcImVmZmVjdFwiXG5pbXBvcnQgdHlwZSB7IEFueU1vZHVsZVNoYXBlLCBNb2R1bGVJbXBsIH0gZnJvbSBcIi4uL21vZHVsZS5qc1wiXG5pbXBvcnQgeyBtYWtlIGFzIG1ha2VCb3VuZEFwaSB9IGZyb20gXCIuLi9Cb3VuZEFwaVJ1bnRpbWUuanNcIlxuaW1wb3J0IHsgY2xvc2VQcm9ncmFtU2NvcGUgfSBmcm9tIFwiLi9Qcm9ncmFtUnVubmVyLmNsb3NlU2NvcGUuanNcIlxuaW1wb3J0IHR5cGUgeyBQcm9ncmFtSWRlbnRpdHkgfSBmcm9tIFwiLi9Qcm9ncmFtUnVubmVyLmVycm9ycy5qc1wiXG5pbXBvcnQgeyBpbnN0YWxsR3JhY2VmdWxTaHV0ZG93bkhhbmRsZXJzIH0gZnJvbSBcIi4vUHJvZ3JhbVJ1bm5lci5zaWduYWxzLmpzXCJcbmltcG9ydCB0eXBlIHsgUHJvZ3JhbVJ1bkNvbnRleHQgfSBmcm9tIFwiLi9Qcm9ncmFtUnVubmVyLmNvbnRleHQuanNcIlxuXG5leHBvcnQgdHlwZSBSdW50aW1lRmFjdG9yeSA9IChcbiAgcm9vdEltcGw6IE1vZHVsZUltcGw8YW55LCBBbnlNb2R1bGVTaGFwZSwgYW55PixcbiAgb3B0aW9ucz86IHVua25vd24sXG4pID0+IE1hbmFnZWRSdW50aW1lLk1hbmFnZWRSdW50aW1lPGFueSwgbmV2ZXI+XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvZ3JhbVJ1bm5lcktlcm5lbDxTaCBleHRlbmRzIEFueU1vZHVsZVNoYXBlPiB7XG4gIHJlYWRvbmx5IHNjb3BlOiBTY29wZS5DbG9zZWFibGVTY29wZVxuICByZWFkb25seSBydW50aW1lOiBNYW5hZ2VkUnVudGltZS5NYW5hZ2VkUnVudGltZTxhbnksIG5ldmVyPlxuICByZWFkb25seSBpZGVudGl0eTogUHJvZ3JhbUlkZW50aXR5XG4gIHJlYWRvbmx5IGluc3RhbGxTaWduYWxzOiAoZW5hYmxlZDogYm9vbGVhbikgPT4gRWZmZWN0LkVmZmVjdDx2b2lkPlxuICByZWFkb25seSBjbG9zZTogKHBhcmFtczoge1xuICAgIHJlYWRvbmx5IHRpbWVvdXRNczogbnVtYmVyXG4gICAgcmVhZG9ubHkgb25FcnJvcj86IChjYXVzZTogaW1wb3J0KFwiZWZmZWN0XCIpLkNhdXNlLkNhdXNlPHVua25vd24+KSA9PiBFZmZlY3QuRWZmZWN0PHZvaWQsIG5ldmVyLCBuZXZlcj5cbiAgfSkgPT4gRWZmZWN0LkVmZmVjdDx2b2lkLCBuZXZlciwgbmV2ZXI+XG4gIHJlYWRvbmx5IHNldEluc3RhbmNlSWQ6ICh2YWx1ZTogdW5rbm93bikgPT4gdm9pZFxuICByZWFkb25seSB0b0NvbnRleHQ6IChtb2R1bGVSdW50aW1lOiB1bmtub3duKSA9PiBQcm9ncmFtUnVuQ29udGV4dDxTaD5cbn1cblxuZXhwb3J0IGNvbnN0IG1ha2VQcm9ncmFtUnVubmVyS2VybmVsID0gPFNoIGV4dGVuZHMgQW55TW9kdWxlU2hhcGU+KFxuICBtYWtlUnVudGltZTogUnVudGltZUZhY3RvcnksXG4gIHJvb3RJbXBsOiBNb2R1bGVJbXBsPGFueSwgU2gsIGFueT4sXG4gIG9wdGlvbnM/OiB1bmtub3duLFxuKTogRWZmZWN0LkVmZmVjdDxQcm9ncmFtUnVubmVyS2VybmVsPFNoPj4gPT5cbiAgRWZmZWN0LmdlbihmdW5jdGlvbiogKCkge1xuICAgIGNvbnN0IGlkZW50aXR5OiBQcm9ncmFtSWRlbnRpdHkgPSB7XG4gICAgICBtb2R1bGVJZDogU3RyaW5nKHJvb3RJbXBsLm1vZHVsZS5pZCksXG4gICAgICBpbnN0YW5jZUlkOiBcInVua25vd25cIixcbiAgICB9XG5cbiAgICBjb25zdCBzY29wZSA9IHlpZWxkKiBTY29wZS5tYWtlKClcbiAgICBjb25zdCBydW50aW1lID0gbWFrZVJ1bnRpbWUocm9vdEltcGwgYXMgTW9kdWxlSW1wbDxhbnksIEFueU1vZHVsZVNoYXBlLCBhbnk+LCBvcHRpb25zKVxuXG4gICAgeWllbGQqIFNjb3BlLmFkZEZpbmFsaXplcihcbiAgICAgIHNjb3BlLFxuICAgICAgRWZmZWN0LnByb21pc2UoKCkgPT4gcnVudGltZS5kaXNwb3NlKCkpLnBpcGUoRWZmZWN0LmFzVm9pZCksXG4gICAgKVxuXG4gICAgY29uc3Qgc2V0SW5zdGFuY2VJZCA9ICh2YWx1ZTogdW5rbm93bikgPT4ge1xuICAgICAgaWRlbnRpdHkuaW5zdGFuY2VJZCA9XG4gICAgICAgIHR5cGVvZiB2YWx1ZSA9PT0gXCJzdHJpbmdcIiAmJiB2YWx1ZS5sZW5ndGggPiAwXG4gICAgICAgICAgPyB2YWx1ZVxuICAgICAgICAgIDogU3RyaW5nKHZhbHVlID8/IFwidW5rbm93blwiKVxuICAgIH1cblxuICAgIGNvbnN0IGNsb3NlID0gKHBhcmFtczoge1xuICAgICAgcmVhZG9ubHkgdGltZW91dE1zOiBudW1iZXJcbiAgICAgIHJlYWRvbmx5IG9uRXJyb3I/OiAoY2F1c2U6IGltcG9ydChcImVmZmVjdFwiKS5DYXVzZS5DYXVzZTx1bmtub3duPikgPT4gRWZmZWN0LkVmZmVjdDx2b2lkLCBuZXZlciwgbmV2ZXI+XG4gICAgfSkgPT5cbiAgICAgIGNsb3NlUHJvZ3JhbVNjb3BlKHtcbiAgICAgICAgc2NvcGUsXG4gICAgICAgIHRpbWVvdXRNczogcGFyYW1zLnRpbWVvdXRNcyxcbiAgICAgICAgaWRlbnRpdHksXG4gICAgICAgIG9uRXJyb3I6IHBhcmFtcy5vbkVycm9yLFxuICAgICAgfSlcblxuICAgIGNvbnN0IGluc3RhbGxTaWduYWxzID0gKGVuYWJsZWQ6IGJvb2xlYW4pID0+XG4gICAgICBpbnN0YWxsR3JhY2VmdWxTaHV0ZG93bkhhbmRsZXJzKHsgc2NvcGUsIGVuYWJsZWQgfSlcblxuICAgIGNvbnN0IHRvQ29udGV4dCA9IChtb2R1bGVSdW50aW1lOiB1bmtub3duKSA9PiAoe1xuICAgICAgc2NvcGUsXG4gICAgICBydW50aW1lLFxuICAgICAgbW9kdWxlOiBtb2R1bGVSdW50aW1lIGFzIGFueSxcbiAgICAgICQ6IG1ha2VCb3VuZEFwaShyb290SW1wbC5tb2R1bGUuc2hhcGUgYXMgYW55LCBtb2R1bGVSdW50aW1lIGFzIGFueSkgYXMgYW55LFxuICAgIH0pIHNhdGlzZmllcyBQcm9ncmFtUnVuQ29udGV4dDxTaD5cblxuICAgIHJldHVybiB7XG4gICAgICBzY29wZSxcbiAgICAgIHJ1bnRpbWUsXG4gICAgICBpZGVudGl0eSxcbiAgICAgIGluc3RhbGxTaWduYWxzLFxuICAgICAgY2xvc2UsXG4gICAgICBzZXRJbnN0YW5jZUlkLFxuICAgICAgdG9Db250ZXh0LFxuICAgIH1cbiAgfSlcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQVdBLElBQU0saUJBQWlCLENBQUMsVUFBd0Q7QUFDOUUsTUFBSSxpQkFBaUIsT0FBTztBQUMxQixXQUFPLEVBQUUsTUFBTSxNQUFNLE1BQU0sU0FBUyxNQUFNLFFBQVE7QUFBQSxFQUNwRDtBQUNBLFNBQU8sRUFBRSxTQUFTLE9BQU8sVUFBVSxXQUFXLFFBQVEsT0FBVTtBQUNsRTtBQUVBLElBQWUseUJBQWYsY0FBOEMsTUFBTTtBQUFBLEVBT3hDLFlBQVksUUFLbkI7QUFDRCxVQUFNLE9BQU8sT0FBTztBQUNwQixTQUFLLFdBQVcsT0FBTyxTQUFTO0FBQ2hDLFNBQUssYUFBYSxPQUFPLFNBQVM7QUFDbEMsU0FBSyxhQUFhLE9BQU87QUFDekIsU0FBSyxPQUFPLE9BQU87QUFBQSxFQUNyQjtBQUFBLEVBRUEsU0FBa0M7QUFDaEMsV0FBTztBQUFBLE1BQ0wsTUFBTSxLQUFLO0FBQUEsTUFDWCxNQUFNLEtBQUs7QUFBQSxNQUNYLFNBQVMsS0FBSztBQUFBLE1BQ2QsVUFBVSxLQUFLO0FBQUEsTUFDZixZQUFZLEtBQUs7QUFBQSxNQUNqQixZQUFZLEtBQUs7QUFBQSxNQUNqQixNQUFNLEtBQUs7QUFBQSxJQUNiO0FBQUEsRUFDRjtBQUNGO0FBRU8sSUFBTSxZQUFOLGNBQXdCLHVCQUF1QjtBQUFBLEVBSXBELFlBQVksVUFBMkIsT0FBZ0I7QUFDckQsVUFBTTtBQUFBLE1BQ0osU0FBUztBQUFBLE1BQ1Q7QUFBQSxNQUNBLFlBQVk7QUFBQSxNQUNaLE1BQU07QUFBQSxJQUNSLENBQUM7QUFUSCxTQUFTLE9BQU87QUFVZCxTQUFLLE9BQU87QUFDWixTQUFLLFFBQVEsZUFBZSxLQUFLO0FBQUEsRUFDbkM7QUFBQSxFQUVTLFNBQWtDO0FBQ3pDLFdBQU8sRUFBRSxHQUFHLE1BQU0sT0FBTyxHQUFHLE9BQU8sS0FBSyxNQUFNO0FBQUEsRUFDaEQ7QUFDRjtBQUVPLElBQU0sWUFBTixjQUF3Qix1QkFBdUI7QUFBQSxFQUlwRCxZQUFZLFVBQTJCLE9BQWdCO0FBQ3JELFVBQU07QUFBQSxNQUNKLFNBQVM7QUFBQSxNQUNUO0FBQUEsTUFDQSxZQUFZO0FBQUEsTUFDWixNQUFNO0FBQUEsSUFDUixDQUFDO0FBVEgsU0FBUyxPQUFPO0FBVWQsU0FBSyxPQUFPO0FBQ1osU0FBSyxRQUFRLGVBQWUsS0FBSztBQUFBLEVBQ25DO0FBQUEsRUFFUyxTQUFrQztBQUN6QyxXQUFPLEVBQUUsR0FBRyxNQUFNLE9BQU8sR0FBRyxPQUFPLEtBQUssTUFBTTtBQUFBLEVBQ2hEO0FBQ0Y7QUFFTyxJQUFNLGVBQU4sY0FBMkIsdUJBQXVCO0FBQUEsRUFJdkQsWUFBWSxVQUEyQixPQUFnQjtBQUNyRCxVQUFNO0FBQUEsTUFDSixTQUFTO0FBQUEsTUFDVDtBQUFBLE1BQ0EsWUFBWTtBQUFBLE1BQ1osTUFBTTtBQUFBLElBQ1IsQ0FBQztBQVRILFNBQVMsT0FBTztBQVVkLFNBQUssT0FBTztBQUNaLFNBQUssUUFBUSxlQUFlLEtBQUs7QUFBQSxFQUNuQztBQUFBLEVBRVMsU0FBa0M7QUFDekMsV0FBTyxFQUFFLEdBQUcsTUFBTSxPQUFPLEdBQUcsT0FBTyxLQUFLLE1BQU07QUFBQSxFQUNoRDtBQUNGO0FBRU8sSUFBTSxzQkFBTixjQUFrQyx1QkFBdUI7QUFBQSxFQU05RCxZQUNFLFVBQ0EsUUFDQTtBQUNBLFVBQU07QUFBQSxNQUNKLFNBQVM7QUFBQSxNQUNUO0FBQUEsTUFDQSxZQUFZO0FBQUEsTUFDWixNQUFNO0FBQUEsSUFDUixDQUFDO0FBZEgsU0FBUyxPQUFPO0FBZWQsU0FBSyxPQUFPO0FBQ1osU0FBSyxZQUFZLE9BQU87QUFDeEIsU0FBSyxZQUFZLE9BQU87QUFDeEIsU0FBSyxjQUFjO0FBQUEsTUFDakI7QUFBQSxNQUNBO0FBQUEsTUFDQTtBQUFBLElBQ0Y7QUFBQSxFQUNGO0FBQUEsRUFFUyxTQUFrQztBQUN6QyxXQUFPO0FBQUEsTUFDTCxHQUFHLE1BQU0sT0FBTztBQUFBLE1BQ2hCLFdBQVcsS0FBSztBQUFBLE1BQ2hCLFdBQVcsS0FBSztBQUFBLE1BQ2hCLGFBQWEsS0FBSztBQUFBLElBQ3BCO0FBQUEsRUFDRjtBQUNGOzs7QUNqSkEsU0FBUyxTQUFTLFVBQVUsUUFBUSxPQUFPLHNCQUFzQjtBQTBFakUsSUFBTSxZQUFZLENBQUMsUUFBdUM7QUFDeEQsUUFBTSxTQUFTO0FBQ2YsTUFBSSxPQUFPLE9BQU8sUUFBUSxVQUFVO0FBQ2xDLFdBQU8sT0FBTztBQUFBLEVBQ2hCO0FBQ0EsTUFBSSxPQUFPLE9BQU8sUUFBUSxVQUFVO0FBQ2xDLFdBQU8sT0FBTztBQUFBLEVBQ2hCO0FBQ0EsTUFBSSxPQUFPLE9BQU8sYUFBYSxZQUFZO0FBQ3pDLFdBQU8sT0FBTyxTQUFTO0FBQUEsRUFDekI7QUFDQSxTQUFPO0FBQ1Q7QUFFQSxJQUFNLGdCQUFnQixDQUFDLFlBQW1FO0FBQ3hGLFFBQU0sUUFBUSxvQkFBSSxJQUF1QjtBQUV6QyxhQUFXLFNBQVMsU0FBUztBQUMzQixVQUFNLFVBQVUsT0FBTyxNQUFNLE9BQU8sRUFBRTtBQUd0QyxVQUFNLFlBQVksTUFBTTtBQUN4QixVQUFNLFlBQVksVUFBVSxTQUFTO0FBQ3JDLFVBQU0sYUFBc0I7QUFBQSxNQUMxQixLQUFLO0FBQUEsTUFDTCxLQUFLO0FBQUEsTUFDTCxlQUFlO0FBQUEsTUFDZixRQUFRO0FBQUEsSUFDVjtBQUNBLFVBQU0sc0JBQXNCLE1BQU0sSUFBSSxTQUFTO0FBQy9DLFFBQUkscUJBQXFCO0FBQ3ZCLDBCQUFvQixLQUFLLFVBQVU7QUFBQSxJQUNyQyxPQUFPO0FBQ0wsWUFBTSxJQUFJLFdBQVcsQ0FBQyxVQUFVLENBQUM7QUFBQSxJQUNuQztBQUdBLFFBQUksTUFBTSxlQUFlLE1BQU0sWUFBWSxTQUFTLEdBQUc7QUFDckQsaUJBQVcsT0FBTyxNQUFNLGFBQWE7QUFDbkMsY0FBTSxNQUFNLFVBQVUsR0FBRztBQUN6QixjQUFNLE9BQWdCO0FBQUEsVUFDcEI7QUFBQSxVQUNBO0FBQUEsVUFDQSxlQUFlO0FBQUEsVUFDZixRQUFRO0FBQUEsUUFDVjtBQUNBLGNBQU0sZ0JBQWdCLE1BQU0sSUFBSSxHQUFHO0FBQ25DLFlBQUksZUFBZTtBQUNqQix3QkFBYyxLQUFLLElBQUk7QUFBQSxRQUN6QixPQUFPO0FBQ0wsZ0JBQU0sSUFBSSxLQUFLLENBQUMsSUFBSSxDQUFDO0FBQUEsUUFDdkI7QUFBQSxNQUNGO0FBQUEsSUFDRjtBQUFBLEVBQ0Y7QUFFQSxTQUFPO0FBQ1Q7QUFFQSxJQUFNLGVBQWUsQ0FBQyxZQUFpRDtBQUNyRSxRQUFNLFFBQVEsY0FBYyxPQUFPO0FBQ25DLFFBQU0sYUFBNkIsQ0FBQztBQUVwQyxhQUFXLENBQUMsS0FBSyxLQUFLLEtBQUssT0FBTztBQUNoQyxRQUFJLE1BQU0sVUFBVSxHQUFHO0FBQ3JCO0FBQUEsSUFDRjtBQUNBLFVBQU0sU0FBUyxvQkFBSSxJQUFZO0FBQy9CLGVBQVcsUUFBUSxPQUFPO0FBQ3hCLGFBQU8sSUFBSSxLQUFLLGFBQWE7QUFBQSxJQUMvQjtBQUdBLFFBQUksT0FBTyxPQUFPLEdBQUc7QUFDbkIsaUJBQVcsS0FBSyxFQUFFLEtBQUssV0FBVyxNQUFNLENBQUM7QUFBQSxJQUMzQztBQUFBLEVBQ0Y7QUFFQSxNQUFJLFdBQVcsV0FBVyxHQUFHO0FBQzNCO0FBQUEsRUFDRjtBQUVBLFFBQU0sVUFDSixzQ0FDQSxXQUNHLElBQUksQ0FBQyxNQUFNO0FBQ1YsVUFBTSxTQUFTLFVBQVUsRUFBRSxHQUFHO0FBQzlCLFVBQU0sUUFBUSxFQUFFLFVBQVUsSUFBSSxDQUFDLE1BQU0sY0FBYyxFQUFFLGFBQWEsYUFBYSxFQUFFLE1BQU0sRUFBRTtBQUN6RixXQUFPLENBQUMsUUFBUSxHQUFHLEtBQUssRUFBRSxLQUFLLElBQUk7QUFBQSxFQUNyQyxDQUFDLEVBQ0EsS0FBSyxJQUFJO0FBRWQsUUFBTSxRQUEyQixPQUFPLE9BQU8sSUFBSSxNQUFNLE9BQU8sR0FBRztBQUFBLElBQ2pFLE1BQU07QUFBQSxJQUNOO0FBQUEsRUFDRixDQUFDO0FBRUQsUUFBTTtBQUNSO0FBRU8sSUFBTSxVQUFVLENBQUksV0FBZ0Q7QUFDekUsUUFBTSxVQUFVLG9CQUFJLElBQVk7QUFDaEMsYUFBVyxTQUFTLE9BQU8sU0FBUztBQUNsQyxVQUFNLEtBQUssT0FBTyxNQUFNLE9BQU8sRUFBRTtBQUVqQyxRQUFJLFFBQVEsSUFBSSxFQUFFLEdBQUc7QUFDbkIsWUFBTSxJQUFJO0FBQUEsUUFDUiw4Q0FBOEMsRUFBRTtBQUFBO0FBQUEsTUFDbEQ7QUFBQSxJQUNGO0FBQ0EsWUFBUSxJQUFJLEVBQUU7QUFBQSxFQUNoQjtBQUlBLGVBQWEsT0FBTyxPQUFPO0FBRzNCLFFBQU0sZ0JBQ0osT0FBTyxtQkFDRixNQUFNLFFBQVEsMkJBQTJCLE9BQU8sZ0JBQWdCLElBQ2hFLE1BQU07QUFHYixRQUFNLHlCQUNKLE9BQU8sb0JBQ0YsTUFBTSxRQUFRLHNCQUFzQixPQUFPLGlCQUFpQixJQUM1RCxNQUFNO0FBRWIsUUFBTSxlQUFlLE9BQU8sUUFBUSxJQUFJLENBQUMsVUFBVSxPQUFPLE1BQU0sT0FBTyxFQUFFLENBQUM7QUFDMUUsUUFBTSxRQUNKLGFBQWEsV0FBVyxJQUNwQixhQUFhLENBQUMsSUFDZCxhQUFhLE1BQU0sRUFBRSxLQUFLLEVBQUUsS0FBSyxHQUFHO0FBRTFDLFFBQU0sWUFBWSxNQUFNO0FBQUEsSUFDdEIsT0FBTztBQUFBLElBQ1A7QUFBQSxJQUNBO0FBQUEsSUFDZSxNQUFNO0FBQUEsSUFDckIsTUFBTTtBQUFBLE1BQ0o7QUFBQSxNQUNBLE9BQU8sSUFBSSxhQUFhO0FBQ3RCLGNBQU0sUUFBUSxPQUFPLFNBQVMsS0FBMkI7QUFDekQsZUFBTyxFQUFFLFNBQVMsUUFBVyxPQUFPLE9BQU8sYUFBYTtBQUFBLE1BQzFELENBQUM7QUFBQSxJQUNIO0FBQUEsRUFDRjtBQUVBLFFBQU0sZUFBZSxPQUFPLFFBQVE7QUFBQSxJQUFJLENBQUM7QUFBQTtBQUFBLE1BRXZDLE1BQU0sUUFBUSxNQUFNLE9BQU8sU0FBUztBQUFBO0FBQUEsRUFDdEM7QUFDQSxRQUFNLFdBQVcsYUFBYSxTQUFTLElBQUksTUFBTSxTQUFTLFdBQVcsR0FBRyxZQUFZLElBQUk7QUFFeEYsUUFBTSxhQUFhLE1BQU07QUFBQSxJQUN2QixPQUFPLElBQUksYUFBYTtBQUN0QixZQUFNLFFBQVEsT0FBTyxPQUFPO0FBSzVCLFlBQU0sQ0FBQyxPQUFPLEdBQUcsSUFBSSxPQUFPLE9BQU8sY0FBYyxNQUFNLGVBQWUsVUFBVSxLQUFLLENBQUM7QUFNdEYsWUFBTSxjQUFjLFFBQVE7QUFBQSxRQUMxQjtBQUFBLFFBQ0E7QUFBQSxNQUNGO0FBRUEsa0JBQVksVUFBVTtBQUN0QixhQUFPLFNBQVMsUUFBUSxZQUFZLE9BQU8sR0FBMkI7QUFFdEUsWUFBTSxpQkFBaUIsUUFBUTtBQUFBLFFBQzdCO0FBQUEsUUFDZTtBQUFBLE1BQ2pCO0FBR0EsYUFBTyxPQUFPO0FBQUEsUUFDWixPQUFPO0FBQUEsUUFDUCxDQUFDLFlBQ0MsT0FBTyxJQUFJLGFBQWE7QUFDdEIsZ0JBQU0sZUFBZSxPQUFPLE9BQU87QUFBQSxZQUNqQyxlQUFlLFFBQVEsU0FBZ0I7QUFBQSxjQUNyQyxPQUFPLEVBQUUsTUFBTSxPQUFPLE1BQU07QUFBQSxjQUM1QixTQUFTO0FBQUEsY0FDVCxhQUFhO0FBQUEsWUFDZixDQUFDO0FBQUEsWUFDRDtBQUFBLFVBQ0Y7QUFHQSxjQUFJLGlCQUFpQixRQUFXO0FBQzlCLG1CQUFPLE9BQU87QUFBQSxjQUNaLE9BQU87QUFBQSxnQkFDTCxPQUFPLFVBQVUsT0FBTyxjQUFjLFNBQVMsT0FBTyxPQUFPLElBQUk7QUFBQSxnQkFDakU7QUFBQSxjQUNGO0FBQUEsWUFDRjtBQUFBLFVBQ0Y7QUFBQSxRQUNGLENBQUM7QUFBQSxRQUNILEVBQUUsU0FBUyxLQUFLO0FBQUEsTUFDbEI7QUFFQSxZQUFNLGlCQUFpQixNQUFNLGNBQWMsT0FBTyxlQUFlLEtBQUssQ0FBQztBQUV2RSxhQUFPLE1BQU07QUFBQSxRQUNYLE1BQU0sZUFBZSxHQUFHO0FBQUEsUUFDeEI7QUFBQSxNQUNGO0FBQUEsSUFDRixDQUFDO0FBQUEsRUFDSDtBQUVBLFNBQU87QUFBQSxJQUNMLFlBQVk7QUFBQSxJQUNaLE9BQU87QUFBQSxJQUNQLGFBQWEsTUFBTSxlQUFlLEtBQUssVUFBVTtBQUFBLEVBQ25EO0FBQ0Y7QUFLTyxJQUFNLFVBQVUsQ0FDckIsUUFDQSxhQUNtQjtBQUNuQixRQUFNQSxTQUFRLFFBQVEsUUFBUSxJQUMxQixXQUNBLE1BQU0sUUFBUSxRQUFRLFFBQW9EO0FBRTlFLFNBQU8sRUFBRSxRQUFRLE9BQUFBLE9BQU07QUFDekI7QUFvQkEsSUFBTSxVQUFVLENBQUMsVUFDZixPQUFPLFVBQVUsWUFBWSxVQUFVLFFBQVEsTUFBTSxlQUFlOzs7QUMzVXRFLFNBQVMsT0FBTyxVQUFBQyxTQUFRLE1BQU0sT0FBTyxRQUFRLGFBQWE7QUFPbkQsSUFBTSxvQkFBb0IsQ0FBQyxXQUtPO0FBQ3ZDLFNBQU9DLFFBQU8sSUFBSSxhQUFhO0FBQzdCLFVBQU0sUUFBUSxLQUFLLElBQUk7QUFFdkIsVUFBTSxRQUFRLE9BQU9BLFFBQU8sV0FBVyxNQUFNLE1BQU0sT0FBTyxPQUFPLEtBQUssSUFBSSxDQUFDO0FBRTNFLFdBQU8sTUFBTTtBQUNYLFlBQU0sVUFBVSxPQUFPLE1BQU0sS0FBSyxLQUFLO0FBQ3ZDLFVBQUksT0FBTyxPQUFPLE9BQU8sR0FBRztBQUMxQixjQUFNLE9BQU8sUUFBUTtBQUNyQixZQUFJLEtBQUssU0FBUyxXQUFXO0FBQzNCO0FBQUEsUUFDRjtBQUNBLGVBQU8sT0FBT0EsUUFBTyxJQUFJLElBQUksYUFBYSxPQUFPLFVBQVUsS0FBSyxLQUFLLENBQUM7QUFBQSxNQUN4RTtBQUVBLFlBQU0sWUFBWSxLQUFLLElBQUksSUFBSTtBQUMvQixVQUFJLGFBQWEsT0FBTyxXQUFXO0FBQ2pDLGNBQU0sUUFBUSxJQUFJLG9CQUFvQixPQUFPLFVBQVU7QUFBQSxVQUNyRCxXQUFXLE9BQU87QUFBQSxVQUNsQjtBQUFBLFFBQ0YsQ0FBQztBQUVELFlBQUksT0FBTyxPQUFPLFlBQVksWUFBWTtBQUN4QyxpQkFBTyxPQUNKLFFBQVEsTUFBTSxJQUFJLEtBQUssQ0FBQyxFQUN4QixLQUFLQSxRQUFPLGNBQWMsTUFBTUEsUUFBTyxJQUFJLENBQUM7QUFBQSxRQUNqRDtBQUVBLGVBQU8sTUFBTSxjQUFjLEtBQUs7QUFDaEMsZUFBTyxPQUFPQSxRQUFPLElBQUksS0FBSztBQUFBLE1BQ2hDO0FBSUEsYUFBT0EsUUFBTyxRQUFRLE1BQU0sSUFBSSxRQUFjLENBQUMsTUFBTSxlQUFlLENBQUMsQ0FBQyxDQUFDO0FBQUEsSUFDekU7QUFBQSxFQUNGLENBQUM7QUFDSDs7O0FDbERBLFNBQVMsVUFBQUMsU0FBUSxRQUFBQyxPQUFNLFNBQUFDLGNBQWE7QUFFcEMsSUFBTSxhQUFhLE1BQVksV0FBbUI7QUFFbEQsSUFBTSxnQkFBZ0IsQ0FBQyxVQUtyQixPQUFPLFVBQVUsWUFDakIsVUFBVSxRQUNWLE9BQVEsTUFBYyxPQUFPO0FBRS9CLElBQU0saUJBQWlCLENBQUMsTUFBVyxPQUFlLFlBQThCO0FBQzlFLE1BQUksT0FBTyxLQUFLLFFBQVEsWUFBWTtBQUNsQyxTQUFLLElBQUksT0FBTyxPQUFPO0FBQ3ZCO0FBQUEsRUFDRjtBQUNBLE1BQUksT0FBTyxLQUFLLG1CQUFtQixZQUFZO0FBQzdDLFNBQUssZUFBZSxPQUFPLE9BQU87QUFBQSxFQUNwQztBQUNGO0FBRU8sSUFBTSxrQ0FBa0MsQ0FBQyxXQUdyQjtBQUN6QixNQUFJLENBQUMsT0FBTyxTQUFTO0FBQ25CLFdBQU9GLFFBQU87QUFBQSxFQUNoQjtBQUVBLFFBQU0sT0FBTyxXQUFXO0FBQ3hCLE1BQUksQ0FBQyxjQUFjLElBQUksR0FBRztBQUN4QixXQUFPQSxRQUFPO0FBQUEsRUFDaEI7QUFFQSxRQUFNLFVBQVUsTUFBWTtBQUMxQixTQUFLQSxRQUFPLFdBQVdFLE9BQU0sTUFBTSxPQUFPLE9BQU9ELE1BQUssSUFBSSxDQUFDO0FBQUEsRUFDN0Q7QUFFQSxTQUFPRCxRQUFPLElBQUksYUFBYTtBQUM3QixXQUFPRSxPQUFNO0FBQUEsTUFDWCxPQUFPO0FBQUEsTUFDUEYsUUFBTyxLQUFLLE1BQU07QUFDaEIsdUJBQWUsTUFBTSxVQUFVLE9BQU87QUFDdEMsdUJBQWUsTUFBTSxXQUFXLE9BQU87QUFBQSxNQUN6QyxDQUFDO0FBQUEsSUFDSDtBQUVBLFdBQU9BLFFBQU8sS0FBSyxNQUFNO0FBQ3ZCLFdBQUssR0FBRyxVQUFVLE9BQU87QUFDekIsV0FBSyxHQUFHLFdBQVcsT0FBTztBQUFBLElBQzVCLENBQUM7QUFBQSxFQUNILENBQUM7QUFDSDs7O0FDdERBLFNBQVMsVUFBQUcsU0FBUSxTQUFBQyxjQUFhO0FBMkJ2QixJQUFNLDBCQUEwQixDQUNyQyxhQUNBLFVBQ0EsWUFFQUMsUUFBTyxJQUFJLGFBQWE7QUFDdEIsUUFBTSxXQUE0QjtBQUFBLElBQ2hDLFVBQVUsT0FBTyxTQUFTLE9BQU8sRUFBRTtBQUFBLElBQ25DLFlBQVk7QUFBQSxFQUNkO0FBRUEsUUFBTSxRQUFRLE9BQU9DLE9BQU0sS0FBSztBQUNoQyxRQUFNLFVBQVUsWUFBWSxVQUFrRCxPQUFPO0FBRXJGLFNBQU9BLE9BQU07QUFBQSxJQUNYO0FBQUEsSUFDQUQsUUFBTyxRQUFRLE1BQU0sUUFBUSxRQUFRLENBQUMsRUFBRSxLQUFLQSxRQUFPLE1BQU07QUFBQSxFQUM1RDtBQUVBLFFBQU0sZ0JBQWdCLENBQUMsVUFBbUI7QUFDeEMsYUFBUyxhQUNQLE9BQU8sVUFBVSxZQUFZLE1BQU0sU0FBUyxJQUN4QyxRQUNBLE9BQU8sU0FBUyxTQUFTO0FBQUEsRUFDakM7QUFFQSxRQUFNLFFBQVEsQ0FBQyxXQUliLGtCQUFrQjtBQUFBLElBQ2hCO0FBQUEsSUFDQSxXQUFXLE9BQU87QUFBQSxJQUNsQjtBQUFBLElBQ0EsU0FBUyxPQUFPO0FBQUEsRUFDbEIsQ0FBQztBQUVILFFBQU0saUJBQWlCLENBQUMsWUFDdEIsZ0NBQWdDLEVBQUUsT0FBTyxRQUFRLENBQUM7QUFFcEQsUUFBTSxZQUFZLENBQUMsbUJBQTRCO0FBQUEsSUFDN0M7QUFBQSxJQUNBO0FBQUEsSUFDQSxRQUFRO0FBQUEsSUFDUixHQUFHLEtBQWEsU0FBUyxPQUFPLE9BQWMsYUFBb0I7QUFBQSxFQUNwRTtBQUVBLFNBQU87QUFBQSxJQUNMO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsRUFDRjtBQUNGLENBQUM7IiwKICAibmFtZXMiOiBbImxheWVyIiwgIkVmZmVjdCIsICJFZmZlY3QiLCAiRWZmZWN0IiwgIkV4aXQiLCAiU2NvcGUiLCAiRWZmZWN0IiwgIlNjb3BlIiwgIkVmZmVjdCIsICJTY29wZSJdCn0K