@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,203 @@
1
+ // @logix/core subpath bundles for @logix/sandbox
2
+
3
+ import {
4
+ isDevEnv
5
+ } from "./chunk-GP37MEGJ.js";
6
+ import {
7
+ record
8
+ } from "./chunk-CVZPRIDB.js";
9
+
10
+ // ../logix-core/src/internal/runtime/core/TaskRunner.ts
11
+ import { Cause, Effect, Fiber, FiberRef, Ref, Stream } from "../effect.js";
12
+ var inSyncTransactionFiber = FiberRef.unsafeMake(false);
13
+ var resolve = (eff, payload) => typeof eff === "function" ? eff(payload) : eff;
14
+ var defaultOrigins = (triggerName) => ({
15
+ pending: {
16
+ kind: "task:pending",
17
+ name: triggerName
18
+ },
19
+ success: {
20
+ kind: "service-callback",
21
+ name: "task:success"
22
+ },
23
+ failure: {
24
+ kind: "service-callback",
25
+ name: "task:failure"
26
+ }
27
+ });
28
+ var emitInvalidUsageDiagnostic = (moduleId, instanceId) => record({
29
+ type: "diagnostic",
30
+ moduleId,
31
+ instanceId,
32
+ code: "logic::invalid_usage",
33
+ severity: "error",
34
+ message: "run*Task is not allowed inside a synchronous StateTransaction body (it may deadlock the txnQueue).",
35
+ hint: "\u8BF7\u5C06 run*Task \u653E\u5230 $.onAction/$.onState/$.on \u7B49 watcher \u7684 run \u6BB5\uFF1B\u4E0D\u8981\u5728 reducer / trait.run / \u5355\u7B14\u4E8B\u52A1\u7684\u540C\u6B65 body \u5185\u76F4\u63A5\u8C03\u7528\u3002\u82E5\u9700\u8981\u957F\u94FE\u8DEF\uFF0C\u8BF7\u7528\u591A\u5165\u53E3\uFF08pending\u2192IO\u2192writeback\uFF09\u6A21\u5F0F\u3002",
36
+ kind: "run_task_in_transaction"
37
+ });
38
+ var shouldNoopDueToSyncTxn = (runtime) => Effect.gen(function* () {
39
+ const inTxn = yield* FiberRef.get(inSyncTransactionFiber);
40
+ if (!inTxn) {
41
+ return false;
42
+ }
43
+ if (isDevEnv()) {
44
+ yield* emitInvalidUsageDiagnostic(runtime.moduleId, runtime.instanceId);
45
+ }
46
+ return true;
47
+ });
48
+ var resolveConcurrencyLimit = (runtime) => runtime.resolveConcurrencyPolicy ? runtime.resolveConcurrencyPolicy().pipe(
49
+ Effect.map((p) => p.concurrencyLimit)
50
+ ) : Effect.succeed(16);
51
+ var runTaskLifecycle = (payload, runtime, config, getCanWriteBack) => Effect.gen(function* () {
52
+ const noop = yield* shouldNoopDueToSyncTxn(runtime);
53
+ if (noop) {
54
+ return;
55
+ }
56
+ const defaults = defaultOrigins(config.triggerName);
57
+ const origins = {
58
+ pending: config.origin?.pending ?? defaults.pending,
59
+ success: config.origin?.success ?? defaults.success,
60
+ failure: config.origin?.failure ?? defaults.failure
61
+ };
62
+ const pending = config.pending;
63
+ if (pending) {
64
+ yield* Effect.uninterruptible(
65
+ runtime.runWithStateTransaction(
66
+ origins.pending,
67
+ () => Effect.asVoid(resolve(pending, payload))
68
+ )
69
+ );
70
+ }
71
+ const io = resolve(config.effect, payload);
72
+ const exit = yield* Effect.exit(io);
73
+ if (getCanWriteBack) {
74
+ const ok = yield* getCanWriteBack;
75
+ if (!ok) {
76
+ return;
77
+ }
78
+ }
79
+ if (exit._tag === "Success") {
80
+ const success = config.success;
81
+ if (success) {
82
+ yield* runtime.runWithStateTransaction(
83
+ origins.success,
84
+ () => Effect.asVoid(success(exit.value, payload))
85
+ );
86
+ }
87
+ return;
88
+ }
89
+ const cause = exit.cause;
90
+ if (Cause.isInterrupted(cause)) {
91
+ return;
92
+ }
93
+ const failure = config.failure;
94
+ if (failure) {
95
+ yield* runtime.runWithStateTransaction(
96
+ origins.failure,
97
+ () => Effect.asVoid(failure(cause, payload))
98
+ );
99
+ }
100
+ }).pipe(
101
+ // watcher 不应因单次 task 出错而整体崩溃:吞掉错误,但必须可定位(诊断事件)。
102
+ Effect.catchAllCause(
103
+ (cause) => record({
104
+ type: "diagnostic",
105
+ moduleId: runtime.moduleId,
106
+ instanceId: runtime.instanceId,
107
+ code: "task_runner::unhandled_failure",
108
+ severity: "error",
109
+ message: "TaskRunner encountered an unhandled failure (pending/IO/writeback).",
110
+ hint: "\u4E3A\u8BE5 task \u8865\u5145 failure \u5199\u56DE\u6216\u5728\u4E0A\u5C42\u663E\u5F0F\u5904\u7406\u9519\u8BEF\uFF1B\u907F\u514D fire-and-forget \u5BFC\u81F4\u9519\u8BEF\u88AB\u541E\u6389\u3002",
111
+ actionTag: config.triggerName,
112
+ kind: "task_runner_unhandled_failure",
113
+ trigger: {
114
+ kind: "task",
115
+ name: config.triggerName
116
+ }
117
+ }).pipe(Effect.zipRight(Effect.logError("TaskRunner error", cause)))
118
+ )
119
+ );
120
+ var makeTaskRunner = (stream, mode, runtime, config) => {
121
+ if (mode === "latest") {
122
+ return Effect.gen(function* () {
123
+ const taskIdRef = yield* Ref.make(0);
124
+ const currentFiberRef = yield* Ref.make(
125
+ void 0
126
+ );
127
+ const start = (payload) => Effect.gen(function* () {
128
+ const taskId = yield* Ref.updateAndGet(taskIdRef, (n) => n + 1);
129
+ const prev = yield* Ref.get(currentFiberRef);
130
+ if (prev) {
131
+ yield* Fiber.interruptFork(prev);
132
+ }
133
+ const canWriteBack = Ref.get(taskIdRef).pipe(
134
+ Effect.map((current) => current === taskId)
135
+ );
136
+ const fiber = yield* Effect.fork(
137
+ runTaskLifecycle(
138
+ payload,
139
+ runtime,
140
+ config,
141
+ canWriteBack
142
+ )
143
+ );
144
+ yield* Ref.set(currentFiberRef, fiber);
145
+ });
146
+ return yield* Stream.runForEach(stream, start);
147
+ });
148
+ }
149
+ if (mode === "exhaust") {
150
+ return Effect.gen(function* () {
151
+ const concurrency = yield* resolveConcurrencyLimit(runtime);
152
+ const busyRef = yield* Ref.make(false);
153
+ const mapper = (payload) => Effect.gen(function* () {
154
+ const acquired = yield* Ref.modify(
155
+ busyRef,
156
+ (busy) => busy ? [false, busy] : [true, true]
157
+ );
158
+ if (!acquired) {
159
+ return;
160
+ }
161
+ try {
162
+ yield* runTaskLifecycle(
163
+ payload,
164
+ runtime,
165
+ config
166
+ );
167
+ } finally {
168
+ yield* Ref.set(busyRef, false);
169
+ }
170
+ });
171
+ return yield* Stream.runDrain(
172
+ stream.pipe(Stream.mapEffect(mapper, { concurrency }))
173
+ );
174
+ });
175
+ }
176
+ if (mode === "parallel") {
177
+ return Effect.gen(function* () {
178
+ const concurrency = yield* resolveConcurrencyLimit(runtime);
179
+ return yield* Stream.runDrain(
180
+ stream.pipe(
181
+ Stream.mapEffect(
182
+ (payload) => runTaskLifecycle(
183
+ payload,
184
+ runtime,
185
+ config
186
+ ),
187
+ { concurrency }
188
+ )
189
+ )
190
+ );
191
+ });
192
+ }
193
+ return Stream.runForEach(
194
+ stream,
195
+ (payload) => runTaskLifecycle(payload, runtime, config)
196
+ );
197
+ };
198
+
199
+ export {
200
+ inSyncTransactionFiber,
201
+ makeTaskRunner
202
+ };
203
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../logix-core/src/internal/runtime/core/TaskRunner.ts"],
  "sourcesContent": ["import { Cause, Effect, Fiber, FiberRef, Ref, Stream } from \"effect\"\nimport * as Debug from \"./DebugSink.js\"\nimport { isDevEnv } from \"./env.js\"\nimport type * as Logic from \"./LogicMiddleware.js\"\nimport type { AnyModuleShape } from \"./module.js\"\nimport type { RuntimeInternalsResolvedConcurrencyPolicy } from \"./RuntimeInternals.js\"\nimport type { StateTxnOrigin } from \"./StateTransaction.js\"\n\n/**\n * \u7528\u4E8E\u9632\u6B62\u5728\u300C\u540C\u6B65\u4E8B\u52A1\u6267\u884C fiber\u300D\u5185\u8C03\u7528 run*Task\uFF08\u4F1A\u5BFC\u81F4\u4E8B\u52A1\u961F\u5217\u7B49\u5F85\u81EA\u8EAB\u800C\u6B7B\u9501\uFF09\u3002\n *\n * - ModuleRuntime \u5728\u6267\u884C\u6BCF\u4E2A\u4E8B\u52A1\uFF08dispatch/source-refresh/devtools/...\uFF09\u65F6\uFF0C\u4F1A locally \u6807\u8BB0\u4E3A true\u3002\n * - run*Task \u5728\u542F\u52A8\u65F6\u68C0\u67E5\u8BE5\u6807\u8BB0\uFF1A\u82E5\u4E3A true\uFF0C\u5219\u4EC5\u5728 dev/test \u4E0B\u53D1\u51FA diagnostic \u5E76\u76F4\u63A5 no-op\u3002\n */\nexport const inSyncTransactionFiber = FiberRef.unsafeMake(false)\n\nexport type TaskRunnerMode =\n  | \"task\" // sequential\n  | \"parallel\"\n  | \"latest\"\n  | \"exhaust\"\n\nexport type TaskStatus =\n  | \"idle\"\n  | \"pending\"\n  | \"running\"\n  | \"success\"\n  | \"failure\"\n  | \"interrupted\"\n\nexport interface TaskExecution {\n  readonly taskId: number\n  readonly status: TaskStatus\n  readonly acceptedAt: number\n  readonly startedAt?: number\n  readonly endedAt?: number\n}\n\nexport interface TaskRunnerOrigins {\n  readonly pending?: StateTxnOrigin\n  readonly success?: StateTxnOrigin\n  readonly failure?: StateTxnOrigin\n}\n\ntype TaskHandler<Payload, Sh extends AnyModuleShape, R> =\n  | Logic.Of<Sh, R, void, never>\n  | ((payload: Payload) => Logic.Of<Sh, R, void, never>)\n\ntype TaskEffect<Payload, Sh extends AnyModuleShape, R, A, E> =\n  | Logic.Of<Sh, R, A, E>\n  | ((payload: Payload) => Logic.Of<Sh, R, A, E>)\n\nexport interface TaskRunnerConfig<\n  Payload,\n  Sh extends AnyModuleShape,\n  R,\n  A = void,\n  E = never,\n> {\n  /**\n   * \u53EF\u9009\uFF1A\u89E6\u53D1\u6E90\u540D\u79F0\uFF08\u4F8B\u5982 actionTag / fieldPath\uFF09\uFF0C\u7528\u4E8E\u9ED8\u8BA4 pending origin.name\u3002\n   * - BoundApiRuntime \u5728 onAction(\"xxx\") / traits.source.refresh(\"field\") \u7B49\u573A\u666F\u53EF\u586B\u5145\uFF1B\n   * - \u5176\u4ED6\u573A\u666F\u4E0D\u5F3A\u6C42\u3002\n   */\n  readonly triggerName?: string\n\n  /**\n   * pending\uFF1A\u540C\u6B65\u72B6\u6001\u5199\u5165\uFF08loading=true / \u6E05\u7406\u9519\u8BEF\u7B49\uFF09\uFF0C\u59CB\u7EC8\u4F5C\u4E3A\u72EC\u7ACB\u4E8B\u52A1\u5165\u53E3\u3002\n   * - \u4EC5\u5BF9\u201C\u88AB\u63A5\u53D7\u5E76\u5B9E\u9645\u542F\u52A8\u7684 task\u201D\u6267\u884C\uFF08runExhaustTask \u5FFD\u7565\u7684\u89E6\u53D1\u4E0D\u6267\u884C\uFF09\u3002\n   */\n  readonly pending?: TaskHandler<Payload, Sh, R>\n\n  /**\n   * effect\uFF1A\u771F\u5B9E IO / \u5F02\u6B65\u4EFB\u52A1\uFF08\u5FC5\u987B\u8FD0\u884C\u5728\u4E8B\u52A1\u7A97\u53E3\u4E4B\u5916\uFF09\u3002\n   */\n  readonly effect: TaskEffect<Payload, Sh, R, A, E>\n\n  /**\n   * success\uFF1A\u6210\u529F\u5199\u56DE\uFF08\u72EC\u7ACB\u4E8B\u52A1\u5165\u53E3\uFF09\u3002\n   */\n  readonly success?: (result: A, payload: Payload) => Logic.Of<Sh, R, void, never>\n\n  /**\n   * failure\uFF1A\u5931\u8D25\u5199\u56DE\uFF08\u72EC\u7ACB\u4E8B\u52A1\u5165\u53E3\uFF09\u3002\n   *\n   * \u8BF4\u660E\uFF1A\u4F20\u5165 Cause \u4EE5\u4FDD\u7559 defect/interrupt \u7B49\u8BED\u4E49\uFF1B\u4E2D\u65AD\uFF08interrupt\uFF09\u9ED8\u8BA4\u4E0D\u89E6\u53D1 failure \u5199\u56DE\u3002\n   */\n  readonly failure?: (cause: Cause.Cause<E>, payload: Payload) => Logic.Of<Sh, R, void, never>\n\n  /**\n   * origin\uFF1A\u53EF\u9009\u8986\u5199\u4E09\u7B14\u4E8B\u52A1\u7684 origin\u3002\n   * - \u9ED8\u8BA4\uFF1Apending.kind=\"task:pending\"\uFF1Bsuccess/failure.kind=\"service-callback\"\u3002\n   */\n  readonly origin?: TaskRunnerOrigins\n\n  /**\n   * priority\uFF1A\u9884\u7559\u5B57\u6BB5\uFF0C\u4EC5\u7528\u4E8E\u672A\u6765\u8C03\u8BD5/\u6392\u5E8F\uFF0C\u4E0D\u6539\u53D8\u4E8B\u52A1\u8FB9\u754C\u4E0E\u5E76\u53D1\u8BED\u4E49\u3002\n   */\n  readonly priority?: number\n}\n\nexport interface TaskRunnerRuntime {\n  readonly moduleId?: string\n  readonly instanceId?: string\n  readonly runWithStateTransaction: (\n    origin: StateTxnOrigin,\n    body: () => Effect.Effect<void, never, any>,\n  ) => Effect.Effect<void, never, any>\n  readonly resolveConcurrencyPolicy?: () => Effect.Effect<\n    RuntimeInternalsResolvedConcurrencyPolicy,\n    never,\n    any\n  >\n}\n\nconst resolve = <Payload, Sh extends AnyModuleShape, R, A, E>(\n  eff: TaskEffect<Payload, Sh, R, A, E> | TaskHandler<Payload, Sh, R>,\n  payload: Payload,\n): any => (typeof eff === \"function\" ? (eff as any)(payload) : eff)\n\nconst defaultOrigins = (\n  triggerName: string | undefined,\n): Required<TaskRunnerOrigins> => ({\n  pending: {\n    kind: \"task:pending\",\n    name: triggerName,\n  },\n  success: {\n    kind: \"service-callback\",\n    name: \"task:success\",\n  },\n  failure: {\n    kind: \"service-callback\",\n    name: \"task:failure\",\n  },\n})\n\nconst emitInvalidUsageDiagnostic = (\n  moduleId: string | undefined,\n  instanceId?: string,\n): Effect.Effect<void> =>\n  Debug.record({\n    type: \"diagnostic\",\n    moduleId,\n    instanceId,\n    code: \"logic::invalid_usage\",\n    severity: \"error\",\n    message:\n      \"run*Task is not allowed inside a synchronous StateTransaction body (it may deadlock the txnQueue).\",\n    hint:\n      \"\u8BF7\u5C06 run*Task \u653E\u5230 $.onAction/$.onState/$.on \u7B49 watcher \u7684 run \u6BB5\uFF1B\" +\n      \"\u4E0D\u8981\u5728 reducer / trait.run / \u5355\u7B14\u4E8B\u52A1\u7684\u540C\u6B65 body \u5185\u76F4\u63A5\u8C03\u7528\u3002\u82E5\u9700\u8981\u957F\u94FE\u8DEF\uFF0C\u8BF7\u7528\u591A\u5165\u53E3\uFF08pending\u2192IO\u2192writeback\uFF09\u6A21\u5F0F\u3002\",\n    kind: \"run_task_in_transaction\",\n  })\n\nconst shouldNoopDueToSyncTxn = (\n  runtime: TaskRunnerRuntime,\n): Effect.Effect<boolean> =>\n  Effect.gen(function* () {\n    const inTxn = yield* FiberRef.get(inSyncTransactionFiber)\n    if (!inTxn) {\n      return false\n    }\n    // \u65E0\u8BBA\u73AF\u5883\u5982\u4F55\uFF0C\u90FD\u5FC5\u987B no-op\uFF08\u5426\u5219\u53EF\u80FD\u6B7B\u9501\uFF09\uFF1Bdiagnostic \u4EC5\u5728 dev/test \u4E0B\u53D1\u51FA\u3002\n    if (isDevEnv()) {\n      yield* emitInvalidUsageDiagnostic(runtime.moduleId, runtime.instanceId)\n    }\n    return true\n  })\n\nconst resolveConcurrencyLimit = (\n  runtime: TaskRunnerRuntime,\n): Effect.Effect<number | \"unbounded\", never, any> =>\n  runtime.resolveConcurrencyPolicy\n    ? runtime.resolveConcurrencyPolicy().pipe(\n        Effect.map((p) => p.concurrencyLimit),\n      )\n    : Effect.succeed(16)\n\nconst runTaskLifecycle = <Payload, Sh extends AnyModuleShape, R, A, E>(\n  payload: Payload,\n  runtime: TaskRunnerRuntime,\n  config: TaskRunnerConfig<Payload, Sh, R, A, E>,\n  getCanWriteBack?: Effect.Effect<boolean>,\n): Effect.Effect<void, never, Logic.Env<Sh, R>> =>\n  Effect.gen(function* () {\n    const noop = yield* shouldNoopDueToSyncTxn(runtime)\n    if (noop) {\n      return\n    }\n\n    const defaults = defaultOrigins(config.triggerName)\n    const origins: Required<TaskRunnerOrigins> = {\n      pending: config.origin?.pending ?? defaults.pending,\n      success: config.origin?.success ?? defaults.success,\n      failure: config.origin?.failure ?? defaults.failure,\n    }\n\n    // 1) pending\uFF1A\u4F5C\u4E3A\u72EC\u7ACB\u4E8B\u52A1\u5165\u53E3\uFF0C\u4E14\u4E00\u65E6\u5F00\u59CB\u5C31\u4E0D\u5E94\u88AB runLatest \u7684 interrupt \u6253\u65AD\n    const pending = config.pending\n    if (pending) {\n      yield* Effect.uninterruptible(\n        runtime.runWithStateTransaction(origins.pending, () =>\n          Effect.asVoid(resolve(pending, payload)),\n        ),\n      )\n    }\n\n    // 2) IO\uFF1A\u5728\u4E8B\u52A1\u7A97\u53E3\u4E4B\u5916\u8FD0\u884C\n    const io = resolve(config.effect, payload) as Effect.Effect<A, E, Logic.Env<Sh, R>>\n    const exit = yield* Effect.exit(io)\n\n    // 3) \u5199\u56DE\uFF1A\u9700\u8981\u901A\u8FC7 guard \u786E\u8BA4\u4ECD\u4E3A\u5F53\u524D task\uFF08runLatestTask\uFF09\n    if (getCanWriteBack) {\n      const ok = yield* getCanWriteBack\n      if (!ok) {\n        return\n      }\n    }\n\n    if (exit._tag === \"Success\") {\n      const success = config.success\n      if (success) {\n        yield* runtime.runWithStateTransaction(origins.success, () =>\n          Effect.asVoid(success(exit.value, payload)),\n        )\n      }\n      return\n    }\n\n    // Failure\uFF1A\u4E2D\u65AD\u4E0D\u89E6\u53D1 failure \u5199\u56DE\uFF08\u4F8B\u5982 runLatestTask \u7684\u53D6\u6D88\u3001Scope \u7ED3\u675F\uFF09\u3002\n    const cause = exit.cause as Cause.Cause<E>\n    if (Cause.isInterrupted(cause)) {\n      return\n    }\n\n    const failure = config.failure\n    if (failure) {\n      yield* runtime.runWithStateTransaction(origins.failure, () =>\n        Effect.asVoid(failure(cause, payload)),\n      )\n    }\n  }).pipe(\n    // watcher \u4E0D\u5E94\u56E0\u5355\u6B21 task \u51FA\u9519\u800C\u6574\u4F53\u5D29\u6E83\uFF1A\u541E\u6389\u9519\u8BEF\uFF0C\u4F46\u5FC5\u987B\u53EF\u5B9A\u4F4D\uFF08\u8BCA\u65AD\u4E8B\u4EF6\uFF09\u3002\n    Effect.catchAllCause((cause) =>\n      Debug.record({\n        type: \"diagnostic\",\n        moduleId: runtime.moduleId,\n        instanceId: runtime.instanceId,\n        code: \"task_runner::unhandled_failure\",\n        severity: \"error\",\n        message: \"TaskRunner encountered an unhandled failure (pending/IO/writeback).\",\n        hint:\n          \"\u4E3A\u8BE5 task \u8865\u5145 failure \u5199\u56DE\u6216\u5728\u4E0A\u5C42\u663E\u5F0F\u5904\u7406\u9519\u8BEF\uFF1B\u907F\u514D fire-and-forget \u5BFC\u81F4\u9519\u8BEF\u88AB\u541E\u6389\u3002\",\n        actionTag: config.triggerName,\n        kind: \"task_runner_unhandled_failure\",\n        trigger: {\n          kind: \"task\",\n          name: config.triggerName,\n        },\n      }).pipe(Effect.zipRight(Effect.logError(\"TaskRunner error\", cause))),\n    ),\n  ) as Effect.Effect<void, never, Logic.Env<Sh, R>>\n\n/**\n * makeTaskRunner\uFF1A\n * - \u590D\u7528 FlowRuntime \u7684\u5E76\u53D1\u8BED\u4E49\uFF08sequential/parallel/latest/exhaust\uFF09\uFF1B\n * - \u5C06\u5355\u6B21\u89E6\u53D1\u62C6\u5206\u4E3A\uFF1Apending(\u72EC\u7ACB\u4E8B\u52A1) \u2192 IO \u2192 success/failure(\u72EC\u7ACB\u4E8B\u52A1)\u3002\n */\nexport const makeTaskRunner = <\n  Payload,\n  Sh extends AnyModuleShape,\n  R,\n  A = void,\n  E = never,\n>(\n  stream: Stream.Stream<Payload>,\n  mode: TaskRunnerMode,\n  runtime: TaskRunnerRuntime,\n  config: TaskRunnerConfig<Payload, Sh, R, A, E>,\n): Effect.Effect<void, never, Logic.Env<Sh, R>> => {\n  if (mode === \"latest\") {\n    return Effect.gen(function* () {\n      const taskIdRef = yield* Ref.make(0)\n      const currentFiberRef = yield* Ref.make<Fiber.RuntimeFiber<void, never> | undefined>(\n        undefined,\n      )\n\n      const start = (payload: Payload) =>\n        Effect.gen(function* () {\n          const taskId = yield* Ref.updateAndGet(taskIdRef, (n) => n + 1)\n\n          const prev = yield* Ref.get(currentFiberRef)\n          if (prev) {\n            // \u4E0D\u7B49\u5F85\u65E7 fiber \u771F\u6B63\u7ED3\u675F\uFF0C\u907F\u514D\u963B\u585E\u65B0\u89E6\u53D1\uFF1B\u5199\u56DE\u9636\u6BB5\u9760 taskId guard \u515C\u5E95\u3002\n            yield* Fiber.interruptFork(prev)\n          }\n\n          const canWriteBack = Ref.get(taskIdRef).pipe(\n            Effect.map((current) => current === taskId),\n          )\n\n          const fiber = yield* Effect.fork(\n            runTaskLifecycle<Payload, Sh, R, A, E>(\n              payload,\n              runtime,\n              config,\n              canWriteBack,\n            ),\n          )\n\n          yield* Ref.set(currentFiberRef, fiber)\n        })\n\n      return yield* Stream.runForEach(stream, start)\n    })\n  }\n\n  if (mode === \"exhaust\") {\n    return Effect.gen(function* () {\n      const concurrency = yield* resolveConcurrencyLimit(runtime)\n      const busyRef = yield* Ref.make(false)\n\n      const mapper = (payload: Payload) =>\n        Effect.gen(function* () {\n          const acquired = yield* Ref.modify(busyRef, (busy) =>\n            busy ? ([false, busy] as const) : ([true, true] as const),\n          )\n          if (!acquired) {\n            // \u5FFD\u7565\u89E6\u53D1\uFF1A\u4E0D\u4EA7\u751F pending \u4E8B\u52A1\n            return\n          }\n          try {\n            yield* runTaskLifecycle<Payload, Sh, R, A, E>(\n              payload,\n              runtime,\n              config,\n            )\n          } finally {\n            yield* Ref.set(busyRef, false)\n          }\n        })\n\n      return yield* Stream.runDrain(\n        stream.pipe(Stream.mapEffect(mapper, { concurrency })),\n      )\n    }) as Effect.Effect<void, never, Logic.Env<Sh, R>>\n  }\n\n  if (mode === \"parallel\") {\n    return Effect.gen(function* () {\n      const concurrency = yield* resolveConcurrencyLimit(runtime)\n\n      return yield* Stream.runDrain(\n        stream.pipe(\n          Stream.mapEffect(\n            (payload) =>\n              runTaskLifecycle<Payload, Sh, R, A, E>(\n                payload,\n                runtime,\n                config,\n              ),\n            { concurrency },\n          ),\n        ),\n      )\n    }) as Effect.Effect<void, never, Logic.Env<Sh, R>>\n  }\n\n  // mode === \"task\"\uFF08sequential\uFF09\n  return Stream.runForEach(stream, (payload) =>\n    runTaskLifecycle<Payload, Sh, R, A, E>(payload, runtime, config),\n  ) as Effect.Effect<void, never, Logic.Env<Sh, R>>\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -0,0 +1,83 @@
1
+ // @logix/core subpath bundles for @logix/sandbox
2
+
3
+ import {
4
+ Link
5
+ } from "./chunk-FNLXHWIU.js";
6
+ import {
7
+ attachMeta,
8
+ getDefinition,
9
+ getMeta
10
+ } from "./chunk-ZAKUP6QG.js";
11
+
12
+ // ../logix-core/src/Process.ts
13
+ var DEFAULT_TRIGGERS = [
14
+ { kind: "platformEvent", platformEvent: "runtime:boot" }
15
+ ];
16
+ var normalizeDefinition = (input) => {
17
+ const base = typeof input === "string" ? { processId: input } : input;
18
+ const processId = base.processId;
19
+ if (typeof processId !== "string" || processId.length === 0) {
20
+ throw new Error("[Process.make] processId must be a non-empty string");
21
+ }
22
+ const triggers = Array.isArray(base.triggers) && base.triggers.length > 0 ? base.triggers : DEFAULT_TRIGGERS;
23
+ const concurrency = base.concurrency ?? { mode: "latest" };
24
+ const errorPolicy = base.errorPolicy ?? { mode: "failStop" };
25
+ const diagnosticsLevel = base.diagnosticsLevel ?? "off";
26
+ return {
27
+ processId,
28
+ name: base.name,
29
+ description: base.description,
30
+ requires: base.requires,
31
+ triggers,
32
+ concurrency,
33
+ errorPolicy,
34
+ diagnosticsLevel
35
+ };
36
+ };
37
+ var make = (definition, effect) => attachMeta(effect, {
38
+ definition: normalizeDefinition(definition),
39
+ kind: "process"
40
+ });
41
+ var getDefinition2 = (effect) => getDefinition(effect);
42
+ var getMeta2 = (effect) => getMeta(effect);
43
+ var attachMeta2 = (effect, meta) => attachMeta(effect, meta);
44
+ var isModuleLike = (value) => Boolean(value) && typeof value === "object" && ((value._kind === "ModuleDef" || value._kind === "Module") && "tag" in value);
45
+ var unwrapModuleTag = (module) => isModuleLike(module) ? module.tag : module;
46
+ function link(config, logic) {
47
+ const linkId = config.id ?? [...config.modules].map((m) => m.id).sort().join("~");
48
+ const modulesRecord = /* @__PURE__ */ Object.create(null);
49
+ const requires = /* @__PURE__ */ new Set();
50
+ for (const module of config.modules) {
51
+ const tag = unwrapModuleTag(module);
52
+ requires.add(String(tag.id));
53
+ modulesRecord[tag.id] = tag;
54
+ }
55
+ const effect = Link(
56
+ modulesRecord,
57
+ logic
58
+ );
59
+ const definition = {
60
+ processId: linkId,
61
+ requires: Array.from(requires),
62
+ triggers: [
63
+ ...DEFAULT_TRIGGERS,
64
+ { kind: "platformEvent", platformEvent: `link:${linkId}` }
65
+ ],
66
+ concurrency: { mode: "latest" },
67
+ errorPolicy: { mode: "failStop" },
68
+ diagnosticsLevel: "off"
69
+ };
70
+ return attachMeta(effect, {
71
+ definition,
72
+ kind: "link"
73
+ });
74
+ }
75
+
76
+ export {
77
+ make,
78
+ getDefinition2 as getDefinition,
79
+ getMeta2 as getMeta,
80
+ attachMeta2 as attachMeta,
81
+ link
82
+ };
83
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../logix-core/src/Process.ts"],
  "sourcesContent": ["import { Effect } from \"effect\"\nimport * as ModuleFactory from \"./internal/runtime/ModuleFactory.js\"\nimport type * as Protocol from \"./internal/runtime/core/process/protocol.js\"\nimport * as Meta from \"./internal/runtime/core/process/meta.js\"\nimport type {\n  AnyModuleShape,\n  ModuleHandle,\n  ModuleLike,\n  ModuleTag,\n} from \"./internal/module.js\"\n\nexport type DiagnosticsLevel = Protocol.DiagnosticsLevel\nexport type ProcessScope = Protocol.ProcessScope\nexport type ProcessIdentity = Protocol.ProcessIdentity\nexport type ProcessInstanceIdentity = Protocol.ProcessInstanceIdentity\nexport type ProcessTriggerSpec = Protocol.ProcessTriggerSpec\nexport type ProcessTrigger = Protocol.ProcessTrigger\nexport type ProcessConcurrencyPolicy = Protocol.ProcessConcurrencyPolicy\nexport type ProcessErrorPolicy = Protocol.ProcessErrorPolicy\nexport type ProcessDefinition = Protocol.ProcessDefinition\nexport type ProcessInstallation = Protocol.ProcessInstallation\nexport type SerializableErrorSummary = Protocol.SerializableErrorSummary\nexport type ProcessInstanceStatus = Protocol.ProcessInstanceStatus\nexport type ProcessEvent = Protocol.ProcessEvent\nexport type ProcessControlRequest = Protocol.ProcessControlRequest\nexport type ProcessPlatformEvent = Protocol.ProcessPlatformEvent\n\nexport type ProcessEffect<E = never, R = never> = Meta.ProcessEffect<E, R>\n\nexport type ProcessMakeDefinition =\n  | string\n  | {\n      readonly processId: string\n      readonly name?: string\n      readonly description?: string\n      readonly requires?: ReadonlyArray<string>\n      readonly triggers?: ReadonlyArray<ProcessTriggerSpec>\n      readonly concurrency?: ProcessConcurrencyPolicy\n      readonly errorPolicy?: ProcessErrorPolicy\n      readonly diagnosticsLevel?: DiagnosticsLevel\n    }\n\nconst DEFAULT_TRIGGERS: ReadonlyArray<ProcessTriggerSpec> = [\n  { kind: \"platformEvent\", platformEvent: \"runtime:boot\" },\n]\n\nconst normalizeDefinition = (input: ProcessMakeDefinition): ProcessDefinition => {\n  const base =\n    typeof input === \"string\"\n      ? ({ processId: input } satisfies { readonly processId: string })\n      : input\n\n  const processId = base.processId\n  if (typeof processId !== \"string\" || processId.length === 0) {\n    throw new Error(\"[Process.make] processId must be a non-empty string\")\n  }\n\n  const triggers =\n    Array.isArray(base.triggers) && base.triggers.length > 0\n      ? base.triggers\n      : DEFAULT_TRIGGERS\n\n  const concurrency = base.concurrency ?? ({ mode: \"latest\" } satisfies ProcessConcurrencyPolicy)\n  const errorPolicy = base.errorPolicy ?? ({ mode: \"failStop\" } satisfies ProcessErrorPolicy)\n  const diagnosticsLevel = base.diagnosticsLevel ?? \"off\"\n\n  return {\n    processId,\n    name: base.name,\n    description: base.description,\n    requires: base.requires,\n    triggers,\n    concurrency,\n    errorPolicy,\n    diagnosticsLevel,\n  }\n}\n\nexport const make = <E, R>(\n  definition: ProcessMakeDefinition,\n  effect: Effect.Effect<void, E, R>,\n): ProcessEffect<E, R> =>\n  Meta.attachMeta(effect, {\n    definition: normalizeDefinition(definition),\n    kind: \"process\",\n  })\n\nexport const getDefinition = (\n  effect: Effect.Effect<void, any, any>,\n): ProcessDefinition | undefined => Meta.getDefinition(effect)\n\nexport const getMeta = (effect: Effect.Effect<void, any, any>): Meta.ProcessMeta | undefined =>\n  Meta.getMeta(effect)\n\nexport const attachMeta = <E, R>(\n  effect: Effect.Effect<void, E, R>,\n  meta: Meta.ProcessMeta,\n): ProcessEffect<E, R> => Meta.attachMeta(effect, meta)\n\ntype LinkModuleToken<Id extends string, Sh extends AnyModuleShape> =\n  | ModuleTag<Id, Sh>\n  | ModuleLike<Id, Sh, object>\n\ntype LinkModuleIdOf<M> = M extends { readonly id: infer Id } ? Id : never\ntype LinkModuleShapeOf<M> = M extends ModuleLike<string, infer Sh, object>\n  ? Sh\n  : M extends ModuleTag<string, infer Sh>\n    ? Sh\n    : never\ntype LinkModuleTagOf<M> = M extends ModuleLike<string, infer Sh, object>\n  ? ModuleTag<string, Sh>\n  : M extends ModuleTag<string, AnyModuleShape>\n    ? M\n    : never\n\nconst isModuleLike = (\n  value: unknown,\n): value is ModuleLike<string, AnyModuleShape, object> =>\n  Boolean(value) &&\n  typeof value === \"object\" &&\n  (((value as { readonly _kind?: unknown })._kind === \"ModuleDef\" ||\n    (value as { readonly _kind?: unknown })._kind === \"Module\") &&\n    \"tag\" in (value as object))\n\nconst unwrapModuleTag = <Id extends string, Sh extends AnyModuleShape>(\n  module: LinkModuleToken<Id, Sh>,\n): ModuleTag<Id, Sh> =>\n  isModuleLike(module) ? module.tag : module\n\nexport interface LinkConfig<Ms extends readonly LinkModuleToken<string, AnyModuleShape>[]> {\n  readonly id?: string\n  readonly modules: Ms\n}\n\nexport type LinkHandles<Ms extends readonly LinkModuleToken<string, AnyModuleShape>[]> = {\n  [M in Ms[number] as LinkModuleIdOf<M>]: ModuleHandle<LinkModuleShapeOf<M>>\n}\n\ntype ModulesRecord<Ms extends readonly LinkModuleToken<string, AnyModuleShape>[]> = {\n  [M in Ms[number] as LinkModuleIdOf<M>]: LinkModuleTagOf<M>\n}\n\nexport function link<\n  Ms extends readonly LinkModuleToken<string, AnyModuleShape>[],\n  E = never,\n  R = never\n>(\n  config: LinkConfig<Ms>,\n  logic: ($: LinkHandles<Ms>) => Effect.Effect<void, E, R>,\n): ProcessEffect<E, R> {\n  const linkId =\n    config.id ??\n    [...config.modules]\n      .map((m) => m.id)\n      .sort()\n      .join(\"~\")\n\n  const modulesRecord = Object.create(null) as ModulesRecord<Ms>\n  const requires = new Set<string>()\n\n  for (const module of config.modules) {\n    const tag = unwrapModuleTag(module)\n    requires.add(String(tag.id))\n    ;(modulesRecord as Record<string, ModuleTag<string, AnyModuleShape>>)[tag.id] =\n      tag as unknown as ModuleTag<string, AnyModuleShape>\n  }\n\n  const effect = ModuleFactory.Link(\n    modulesRecord as unknown as Record<string, ModuleTag<string, AnyModuleShape>>,\n    logic as unknown as (\n      $: Record<string, ModuleHandle<AnyModuleShape>>,\n    ) => Effect.Effect<void, E, R>,\n  )\n\n  const definition: ProcessDefinition = {\n    processId: linkId,\n    requires: Array.from(requires),\n    triggers: [\n      ...DEFAULT_TRIGGERS,\n      { kind: \"platformEvent\", platformEvent: `link:${linkId}` },\n    ],\n    concurrency: { mode: \"latest\" },\n    errorPolicy: { mode: \"failStop\" },\n    diagnosticsLevel: \"off\",\n  }\n\n  return Meta.attachMeta(effect, {\n    definition,\n    kind: \"link\",\n  }) as ProcessEffect<E, R>\n}\n"],
  "mappings": ";;;;;;;;;;;;AA0CA,IAAM,mBAAsD;AAAA,EAC1D,EAAE,MAAM,iBAAiB,eAAe,eAAe;AACzD;AAEA,IAAM,sBAAsB,CAAC,UAAoD;AAC/E,QAAM,OACJ,OAAO,UAAU,WACZ,EAAE,WAAW,MAAM,IACpB;AAEN,QAAM,YAAY,KAAK;AACvB,MAAI,OAAO,cAAc,YAAY,UAAU,WAAW,GAAG;AAC3D,UAAM,IAAI,MAAM,qDAAqD;AAAA,EACvE;AAEA,QAAM,WACJ,MAAM,QAAQ,KAAK,QAAQ,KAAK,KAAK,SAAS,SAAS,IACnD,KAAK,WACL;AAEN,QAAM,cAAc,KAAK,eAAgB,EAAE,MAAM,SAAS;AAC1D,QAAM,cAAc,KAAK,eAAgB,EAAE,MAAM,WAAW;AAC5D,QAAM,mBAAmB,KAAK,oBAAoB;AAElD,SAAO;AAAA,IACL;AAAA,IACA,MAAM,KAAK;AAAA,IACX,aAAa,KAAK;AAAA,IAClB,UAAU,KAAK;AAAA,IACf;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;AAEO,IAAM,OAAO,CAClB,YACA,WAEK,WAAW,QAAQ;AAAA,EACtB,YAAY,oBAAoB,UAAU;AAAA,EAC1C,MAAM;AACR,CAAC;AAEI,IAAMA,iBAAgB,CAC3B,WACuC,cAAc,MAAM;AAEtD,IAAMC,WAAU,CAAC,WACjB,QAAQ,MAAM;AAEd,IAAMC,cAAa,CACxB,QACA,SAC6B,WAAW,QAAQ,IAAI;AAkBtD,IAAM,eAAe,CACnB,UAEA,QAAQ,KAAK,KACb,OAAO,UAAU,cACd,MAAuC,UAAU,eACjD,MAAuC,UAAU,aAClD,SAAU;AAEd,IAAM,kBAAkB,CACtB,WAEA,aAAa,MAAM,IAAI,OAAO,MAAM;AAe/B,SAAS,KAKd,QACA,OACqB;AACrB,QAAM,SACJ,OAAO,MACP,CAAC,GAAG,OAAO,OAAO,EACf,IAAI,CAAC,MAAM,EAAE,EAAE,EACf,KAAK,EACL,KAAK,GAAG;AAEb,QAAM,gBAAgB,uBAAO,OAAO,IAAI;AACxC,QAAM,WAAW,oBAAI,IAAY;AAEjC,aAAW,UAAU,OAAO,SAAS;AACnC,UAAM,MAAM,gBAAgB,MAAM;AAClC,aAAS,IAAI,OAAO,IAAI,EAAE,CAAC;AAC1B,IAAC,cAAoE,IAAI,EAAE,IAC1E;AAAA,EACJ;AAEA,QAAM,SAAuB;AAAA,IAC3B;AAAA,IACA;AAAA,EAGF;AAEA,QAAM,aAAgC;AAAA,IACpC,WAAW;AAAA,IACX,UAAU,MAAM,KAAK,QAAQ;AAAA,IAC7B,UAAU;AAAA,MACR,GAAG;AAAA,MACH,EAAE,MAAM,iBAAiB,eAAe,QAAQ,MAAM,GAAG;AAAA,IAC3D;AAAA,IACA,aAAa,EAAE,MAAM,SAAS;AAAA,IAC9B,aAAa,EAAE,MAAM,WAAW;AAAA,IAChC,kBAAkB;AAAA,EACpB;AAEA,SAAY,WAAW,QAAQ;AAAA,IAC7B;AAAA,IACA,MAAM;AAAA,EACR,CAAC;AACH;",
  "names": ["getDefinition", "getMeta", "attachMeta"]
}

@@ -0,0 +1,75 @@
1
+ // @logix/core subpath bundles for @logix/sandbox
2
+
3
+ import {
4
+ isDevEnv
5
+ } from "./chunk-GP37MEGJ.js";
6
+
7
+ // ../logix-core/src/Root.ts
8
+ import { Context as Context2, Effect } from "../effect.js";
9
+
10
+ // ../logix-core/src/internal/runtime/core/RootContext.ts
11
+ import { Context } from "../effect.js";
12
+ var RootContextTagImpl = class extends Context.Tag(
13
+ "@logix/core/RootContext"
14
+ )() {
15
+ };
16
+ var RootContextTag = RootContextTagImpl;
17
+
18
+ // ../logix-core/src/Root.ts
19
+ var tagIdOf = (tag) => typeof tag?.id === "string" ? String(tag.id) : typeof tag?.key === "string" ? String(tag.key) : "<unknown tag>";
20
+ var makeMissingRootProviderError = (tag, entrypoint, extra) => {
21
+ const dev = isDevEnv();
22
+ const tokenId = tagIdOf(tag);
23
+ const fix = dev ? [
24
+ "- Provide it when creating the runtime tree (Logix.Runtime.make(...,{ layer }) / ManagedRuntime.make(Layer.mergeAll(...))).",
25
+ "- If you're in React and want the current runtime environment singleton, use useModule(ModuleTag).",
26
+ "- Do not rely on nested RuntimeProvider.layer to mock Root.resolve."
27
+ ] : [];
28
+ const message = dev ? [
29
+ "[MissingRootProviderError] Cannot resolve Tag from root provider.",
30
+ extra ? `
31
+ ${extra}` : "",
32
+ `tokenId: ${tokenId}`,
33
+ `entrypoint: ${entrypoint}`,
34
+ "mode: global",
35
+ "startScope: root",
36
+ "",
37
+ "fix:",
38
+ ...fix
39
+ ].filter((s) => s.length > 0).join("\n") : "[MissingRootProviderError] tag not found in root provider";
40
+ const err = new Error(message);
41
+ err.name = "MissingRootProviderError";
42
+ err.tokenId = tokenId;
43
+ err.entrypoint = entrypoint;
44
+ err.mode = "global";
45
+ err.startScope = { kind: "root" };
46
+ err.fix = fix;
47
+ return err;
48
+ };
49
+ var resolve = (tag, options) => Effect.gen(function* () {
50
+ const entrypoint = options?.entrypoint ?? "logic.root.resolve";
51
+ const root = yield* RootContextTag;
52
+ const rootContext = root.context ?? (options?.waitForReady ? yield* root.ready : void 0);
53
+ if (!rootContext) {
54
+ return yield* Effect.die(
55
+ makeMissingRootProviderError(
56
+ tag,
57
+ entrypoint,
58
+ "reason: rootContextNotReady"
59
+ )
60
+ );
61
+ }
62
+ try {
63
+ return Context2.get(rootContext, tag);
64
+ } catch {
65
+ return yield* Effect.die(
66
+ makeMissingRootProviderError(tag, entrypoint)
67
+ );
68
+ }
69
+ });
70
+
71
+ export {
72
+ RootContextTag,
73
+ resolve
74
+ };
75
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vbG9naXgtY29yZS9zcmMvUm9vdC50cyIsICIuLi8uLi8uLi8uLi9sb2dpeC1jb3JlL3NyYy9pbnRlcm5hbC9ydW50aW1lL2NvcmUvUm9vdENvbnRleHQudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImltcG9ydCB7IENvbnRleHQsIEVmZmVjdCB9IGZyb20gXCJlZmZlY3RcIlxuaW1wb3J0IHsgaXNEZXZFbnYgfSBmcm9tIFwiLi9pbnRlcm5hbC9ydW50aW1lL2NvcmUvZW52LmpzXCJcbmltcG9ydCB7IFJvb3RDb250ZXh0VGFnIH0gZnJvbSBcIi4vaW50ZXJuYWwvcnVudGltZS9jb3JlL1Jvb3RDb250ZXh0LmpzXCJcblxuZXhwb3J0IHR5cGUgUm9vdFJlc29sdmVFbnRyeXBvaW50ID0gXCJsb2dpYy5yb290LnJlc29sdmVcIiB8IFwibG9naWMuJC5yb290LnJlc29sdmVcIlxuXG5leHBvcnQgaW50ZXJmYWNlIFJvb3RSZXNvbHZlT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGVudHJ5cG9pbnQ/OiBSb290UmVzb2x2ZUVudHJ5cG9pbnRcbiAgLyoqXG4gICAqIFx1NjYyRlx1NTQyNlx1NTE0MVx1OEJCOFx1NTcyOCBSb290Q29udGV4dCBcdTVDMUFcdTY3MkFcdTVDMzFcdTdFRUFcdTY1RjZcdTdCNDlcdTVGODVcdUZGMUFcbiAgICogLSBcdTlFRDhcdThCQTQgZmFsc2VcdUZGMUFcdTkwN0ZcdTUxNERcdTU3MjggbGF5ZXIvc2V0dXAgXHU5NjM2XHU2QkI1XHU4QkVGXHU3NTI4XHU1QkZDXHU4MUY0XHU2QjdCXHU5NTAxXHVGRjFCXG4gICAqIC0gYCQucm9vdC5yZXNvbHZlYCBcdTRGMUFcdTU3MjggcnVuIFx1OTYzNlx1NkJCNVx1NEYyMCB0cnVlXHVGRjA4cnVuLW9ubHlcdUZGMDlcdUZGMENcdTUxNDFcdThCQjhcdTdCNDlcdTVGODUgRW52IFx1N0VDNFx1ODhDNVx1NUI4Q1x1NjIxMFx1MzAwMlxuICAgKi9cbiAgcmVhZG9ubHkgd2FpdEZvclJlYWR5PzogYm9vbGVhblxufVxuXG5jb25zdCB0YWdJZE9mID0gKHRhZzogQ29udGV4dC5UYWc8YW55LCBhbnk+KTogc3RyaW5nID0+XG4gIHR5cGVvZiAodGFnIGFzIGFueSk/LmlkID09PSBcInN0cmluZ1wiXG4gICAgPyBTdHJpbmcoKHRhZyBhcyBhbnkpLmlkKVxuICAgIDogdHlwZW9mICh0YWcgYXMgYW55KT8ua2V5ID09PSBcInN0cmluZ1wiXG4gICAgICA/IFN0cmluZygodGFnIGFzIGFueSkua2V5KVxuICAgICAgOiBcIjx1bmtub3duIHRhZz5cIlxuXG5jb25zdCBtYWtlTWlzc2luZ1Jvb3RQcm92aWRlckVycm9yID0gKFxuICB0YWc6IENvbnRleHQuVGFnPGFueSwgYW55PixcbiAgZW50cnlwb2ludDogUm9vdFJlc29sdmVFbnRyeXBvaW50LFxuICBleHRyYT86IHN0cmluZyxcbik6IEVycm9yID0+IHtcbiAgY29uc3QgZGV2ID0gaXNEZXZFbnYoKVxuICBjb25zdCB0b2tlbklkID0gdGFnSWRPZih0YWcpXG4gIGNvbnN0IGZpeDogc3RyaW5nW10gPSBkZXZcbiAgICA/IFtcbiAgICAgICAgXCItIFByb3ZpZGUgaXQgd2hlbiBjcmVhdGluZyB0aGUgcnVudGltZSB0cmVlIChMb2dpeC5SdW50aW1lLm1ha2UoLi4uLHsgbGF5ZXIgfSkgLyBNYW5hZ2VkUnVudGltZS5tYWtlKExheWVyLm1lcmdlQWxsKC4uLikpKS5cIixcbiAgICAgICAgXCItIElmIHlvdSdyZSBpbiBSZWFjdCBhbmQgd2FudCB0aGUgY3VycmVudCBydW50aW1lIGVudmlyb25tZW50IHNpbmdsZXRvbiwgdXNlIHVzZU1vZHVsZShNb2R1bGVUYWcpLlwiLFxuICAgICAgICBcIi0gRG8gbm90IHJlbHkgb24gbmVzdGVkIFJ1bnRpbWVQcm92aWRlci5sYXllciB0byBtb2NrIFJvb3QucmVzb2x2ZS5cIixcbiAgICAgIF1cbiAgICA6IFtdXG5cbiAgY29uc3QgbWVzc2FnZSA9IGRldlxuICAgID8gW1xuICAgICAgICBcIltNaXNzaW5nUm9vdFByb3ZpZGVyRXJyb3JdIENhbm5vdCByZXNvbHZlIFRhZyBmcm9tIHJvb3QgcHJvdmlkZXIuXCIsXG4gICAgICAgIGV4dHJhID8gYFxcbiR7ZXh0cmF9YCA6IFwiXCIsXG4gICAgICAgIGB0b2tlbklkOiAke3Rva2VuSWR9YCxcbiAgICAgICAgYGVudHJ5cG9pbnQ6ICR7ZW50cnlwb2ludH1gLFxuICAgICAgICBcIm1vZGU6IGdsb2JhbFwiLFxuICAgICAgICBcInN0YXJ0U2NvcGU6IHJvb3RcIixcbiAgICAgICAgXCJcIixcbiAgICAgICAgXCJmaXg6XCIsXG4gICAgICAgIC4uLmZpeCxcbiAgICAgIF1cbiAgICAgICAgLmZpbHRlcigocykgPT4gcy5sZW5ndGggPiAwKVxuICAgICAgICAuam9pbihcIlxcblwiKVxuICAgIDogXCJbTWlzc2luZ1Jvb3RQcm92aWRlckVycm9yXSB0YWcgbm90IGZvdW5kIGluIHJvb3QgcHJvdmlkZXJcIlxuXG4gIGNvbnN0IGVyciA9IG5ldyBFcnJvcihtZXNzYWdlKVxuICBlcnIubmFtZSA9IFwiTWlzc2luZ1Jvb3RQcm92aWRlckVycm9yXCJcbiAgOyhlcnIgYXMgYW55KS50b2tlbklkID0gdG9rZW5JZFxuICA7KGVyciBhcyBhbnkpLmVudHJ5cG9pbnQgPSBlbnRyeXBvaW50XG4gIDsoZXJyIGFzIGFueSkubW9kZSA9IFwiZ2xvYmFsXCJcbiAgOyhlcnIgYXMgYW55KS5zdGFydFNjb3BlID0geyBraW5kOiBcInJvb3RcIiB9XG4gIDsoZXJyIGFzIGFueSkuZml4ID0gZml4XG4gIHJldHVybiBlcnJcbn1cblxuLyoqXG4gKiBSb290LnJlc29sdmVcbiAqXG4gKiBcdTY2M0VcdTVGMEZcdTRFQ0VcdTIwMUNcdTVGNTNcdTUyNEQgUnVudGltZSBUcmVlIFx1NzY4NFx1NjgzOVx1RkYwOHJvb3QgcHJvdmlkZXJcdUZGMDlcdTIwMURcdTg5RTNcdTY3OTBcdTY3RDBcdTRFMkEgVGFnXHVGRjA4U2VydmljZVRhZyAvIE1vZHVsZVRhZ1x1RkYwOVx1MzAwMlxuICpcbiAqIFx1OEJFRFx1NEU0OVx1RkYxQVxuICogLSBcdTU2RkFcdTVCOUFcdThCRkJcdTUzRDYgcm9vdENvbnRleHRcdUZGMENcdTRFMERcdTUzRDdcdTY2RjRcdThGRDEgc2NvcGUgXHU3Njg0IExheWVyL0NvbnRleHQgXHU4OTg2XHU3NkQ2XHU1RjcxXHU1NENEXHVGRjFCXG4gKiAtIFx1NUJGOSBNb2R1bGVUYWdcdUZGMUFcdTUzRUFcdTg4NjhcdThGQkUgcm9vdCBcdTUzNTVcdTRGOEJcdThCRURcdTRFNDlcdUZGMDhcdTRFMERcdTc1MjhcdTRFOEVcdTU5MUFcdTVCOUVcdTRGOEJcdTkwMDlcdTYyRTlcdUZGMDlcdTMwMDJcbiAqL1xuZXhwb3J0IGNvbnN0IHJlc29sdmUgPSA8SWQsIFN2Yz4oXG4gIHRhZzogQ29udGV4dC5UYWc8SWQsIFN2Yz4sXG4gIG9wdGlvbnM/OiBSb290UmVzb2x2ZU9wdGlvbnMsXG4pOiBFZmZlY3QuRWZmZWN0PFN2YywgbmV2ZXIsIGFueT4gPT5cbiAgRWZmZWN0LmdlbihmdW5jdGlvbiogKCkge1xuICAgIGNvbnN0IGVudHJ5cG9pbnQ6IFJvb3RSZXNvbHZlRW50cnlwb2ludCA9XG4gICAgICBvcHRpb25zPy5lbnRyeXBvaW50ID8/IFwibG9naWMucm9vdC5yZXNvbHZlXCJcblxuICAgIGNvbnN0IHJvb3QgPSB5aWVsZCogUm9vdENvbnRleHRUYWdcblxuICAgIGNvbnN0IHJvb3RDb250ZXh0ID1cbiAgICAgIHJvb3QuY29udGV4dCA/PyAob3B0aW9ucz8ud2FpdEZvclJlYWR5ID8geWllbGQqIHJvb3QucmVhZHkgOiB1bmRlZmluZWQpXG5cbiAgICBpZiAoIXJvb3RDb250ZXh0KSB7XG4gICAgICByZXR1cm4geWllbGQqIEVmZmVjdC5kaWUoXG4gICAgICAgIG1ha2VNaXNzaW5nUm9vdFByb3ZpZGVyRXJyb3IoXG4gICAgICAgICAgdGFnIGFzIENvbnRleHQuVGFnPGFueSwgYW55PixcbiAgICAgICAgICBlbnRyeXBvaW50LFxuICAgICAgICAgIFwicmVhc29uOiByb290Q29udGV4dE5vdFJlYWR5XCIsXG4gICAgICAgICksXG4gICAgICApXG4gICAgfVxuXG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBDb250ZXh0LmdldChyb290Q29udGV4dCwgdGFnIGFzIENvbnRleHQuVGFnPGFueSwgYW55PikgYXMgU3ZjXG4gICAgfSBjYXRjaCB7XG4gICAgICByZXR1cm4geWllbGQqIEVmZmVjdC5kaWUoXG4gICAgICAgIG1ha2VNaXNzaW5nUm9vdFByb3ZpZGVyRXJyb3IodGFnIGFzIENvbnRleHQuVGFnPGFueSwgYW55PiwgZW50cnlwb2ludCksXG4gICAgICApXG4gICAgfVxuICB9KVxuIiwgImltcG9ydCB7IENvbnRleHQsIERlZmVycmVkIH0gZnJvbSBcImVmZmVjdFwiXG5cbmV4cG9ydCBpbnRlcmZhY2UgUm9vdENvbnRleHQge1xuICBjb250ZXh0OiBDb250ZXh0LkNvbnRleHQ8YW55PiB8IHVuZGVmaW5lZFxuICByZWFkb25seSByZWFkeTogRGVmZXJyZWQuRGVmZXJyZWQ8Q29udGV4dC5Db250ZXh0PGFueT4sIG5ldmVyPlxufVxuXG5jbGFzcyBSb290Q29udGV4dFRhZ0ltcGwgZXh0ZW5kcyBDb250ZXh0LlRhZyhcbiAgXCJAbG9naXgvY29yZS9Sb290Q29udGV4dFwiLFxuKTxSb290Q29udGV4dFRhZ0ltcGwsIFJvb3RDb250ZXh0PigpIHt9XG5cbmV4cG9ydCBjb25zdCBSb290Q29udGV4dFRhZyA9IFJvb3RDb250ZXh0VGFnSW1wbFxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7OztBQUFBLFNBQVMsV0FBQUEsVUFBUyxjQUFjOzs7QUNBaEMsU0FBUyxlQUF5QjtBQU9sQyxJQUFNLHFCQUFOLGNBQWlDLFFBQVE7QUFBQSxFQUN2QztBQUNGLEVBQW1DLEVBQUU7QUFBQztBQUUvQixJQUFNLGlCQUFpQjs7O0FESzlCLElBQU0sVUFBVSxDQUFDLFFBQ2YsT0FBUSxLQUFhLE9BQU8sV0FDeEIsT0FBUSxJQUFZLEVBQUUsSUFDdEIsT0FBUSxLQUFhLFFBQVEsV0FDM0IsT0FBUSxJQUFZLEdBQUcsSUFDdkI7QUFFUixJQUFNLCtCQUErQixDQUNuQyxLQUNBLFlBQ0EsVUFDVTtBQUNWLFFBQU0sTUFBTSxTQUFTO0FBQ3JCLFFBQU0sVUFBVSxRQUFRLEdBQUc7QUFDM0IsUUFBTSxNQUFnQixNQUNsQjtBQUFBLElBQ0U7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLEVBQ0YsSUFDQSxDQUFDO0FBRUwsUUFBTSxVQUFVLE1BQ1o7QUFBQSxJQUNFO0FBQUEsSUFDQSxRQUFRO0FBQUEsRUFBSyxLQUFLLEtBQUs7QUFBQSxJQUN2QixZQUFZLE9BQU87QUFBQSxJQUNuQixlQUFlLFVBQVU7QUFBQSxJQUN6QjtBQUFBLElBQ0E7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLElBQ0EsR0FBRztBQUFBLEVBQ0wsRUFDRyxPQUFPLENBQUMsTUFBTSxFQUFFLFNBQVMsQ0FBQyxFQUMxQixLQUFLLElBQUksSUFDWjtBQUVKLFFBQU0sTUFBTSxJQUFJLE1BQU0sT0FBTztBQUM3QixNQUFJLE9BQU87QUFDVixFQUFDLElBQVksVUFBVTtBQUN2QixFQUFDLElBQVksYUFBYTtBQUMxQixFQUFDLElBQVksT0FBTztBQUNwQixFQUFDLElBQVksYUFBYSxFQUFFLE1BQU0sT0FBTztBQUN6QyxFQUFDLElBQVksTUFBTTtBQUNwQixTQUFPO0FBQ1Q7QUFXTyxJQUFNLFVBQVUsQ0FDckIsS0FDQSxZQUVBLE9BQU8sSUFBSSxhQUFhO0FBQ3RCLFFBQU0sYUFDSixTQUFTLGNBQWM7QUFFekIsUUFBTSxPQUFPLE9BQU87QUFFcEIsUUFBTSxjQUNKLEtBQUssWUFBWSxTQUFTLGVBQWUsT0FBTyxLQUFLLFFBQVE7QUFFL0QsTUFBSSxDQUFDLGFBQWE7QUFDaEIsV0FBTyxPQUFPLE9BQU87QUFBQSxNQUNuQjtBQUFBLFFBQ0U7QUFBQSxRQUNBO0FBQUEsUUFDQTtBQUFBLE1BQ0Y7QUFBQSxJQUNGO0FBQUEsRUFDRjtBQUVBLE1BQUk7QUFDRixXQUFPQyxTQUFRLElBQUksYUFBYSxHQUE0QjtBQUFBLEVBQzlELFFBQVE7QUFDTixXQUFPLE9BQU8sT0FBTztBQUFBLE1BQ25CLDZCQUE2QixLQUE4QixVQUFVO0FBQUEsSUFDdkU7QUFBQSxFQUNGO0FBQ0YsQ0FBQzsiLAogICJuYW1lcyI6IFsiQ29udGV4dCIsICJDb250ZXh0Il0KfQo=
@@ -0,0 +1,85 @@
1
+ // @logix/core subpath bundles for @logix/sandbox
2
+
3
+ import {
4
+ isDevEnv
5
+ } from "./chunk-XE7ULSGQ.js";
6
+
7
+ // ../logix-core/src/internal/runtime/core/runtimeInternalsAccessor.ts
8
+ var RUNTIME_INTERNALS = /* @__PURE__ */ Symbol.for("@logix/core/runtimeInternals");
9
+ var BOUND_INTERNALS = /* @__PURE__ */ Symbol.for("@logix/core/boundInternals");
10
+ var MODULE_TRAITS_PROGRAM = /* @__PURE__ */ Symbol.for("@logix/core/moduleTraitsProgram");
11
+ var defineHidden = (target, key, value) => {
12
+ Object.defineProperty(target, key, {
13
+ value,
14
+ enumerable: false,
15
+ configurable: true,
16
+ writable: false
17
+ });
18
+ };
19
+ var setRuntimeInternals = (runtime, internals) => {
20
+ defineHidden(runtime, RUNTIME_INTERNALS, internals);
21
+ };
22
+ var setBoundInternals = (bound, internals) => {
23
+ defineHidden(bound, BOUND_INTERNALS, internals);
24
+ };
25
+ var setModuleTraitsProgram = (module, program) => {
26
+ defineHidden(module, MODULE_TRAITS_PROGRAM, program);
27
+ };
28
+ var getModuleTraitsProgram = (module) => {
29
+ if (!module) return void 0;
30
+ if (typeof module !== "object" && typeof module !== "function") return void 0;
31
+ return module[MODULE_TRAITS_PROGRAM];
32
+ };
33
+ var formatScope = (moduleId, instanceId) => {
34
+ const m = typeof moduleId === "string" && moduleId.length > 0 ? moduleId : "unknown";
35
+ const i = typeof instanceId === "string" && instanceId.length > 0 ? instanceId : "unknown";
36
+ return `moduleId=${m}, instanceId=${i}`;
37
+ };
38
+ var getRuntimeInternals = (runtime) => {
39
+ const scope = runtime;
40
+ const internals = runtime[RUNTIME_INTERNALS];
41
+ if (!internals) {
42
+ const msg = isDevEnv() ? [
43
+ "[MissingRuntimeInternals] Runtime internals not installed on ModuleRuntime instance.",
44
+ `scope: ${formatScope(scope.moduleId, scope.instanceId)}`,
45
+ "fix:",
46
+ "- Ensure ModuleRuntime.make calls internalHooks.installInternalHooks (020 foundation).",
47
+ "- If you created a mock runtime for tests, attach internals or avoid calling internal-only APIs."
48
+ ].join("\n") : "Runtime internals not installed";
49
+ throw new Error(msg);
50
+ }
51
+ const runtimeInstanceId = scope.instanceId;
52
+ if (typeof runtimeInstanceId === "string" && runtimeInstanceId.length > 0 && runtimeInstanceId !== internals.instanceId) {
53
+ throw new Error(
54
+ isDevEnv() ? [
55
+ "[InconsistentRuntimeInternals] Runtime internals instanceId mismatch.",
56
+ `runtime: ${formatScope(scope.moduleId, runtimeInstanceId)}`,
57
+ `internals: ${formatScope(internals.moduleId, internals.instanceId)}`
58
+ ].join("\n") : "Runtime internals mismatch"
59
+ );
60
+ }
61
+ return internals;
62
+ };
63
+ var getBoundInternals = (bound) => {
64
+ const internals = bound[BOUND_INTERNALS];
65
+ if (!internals) {
66
+ const msg = isDevEnv() ? [
67
+ "[MissingBoundInternals] Bound internals not installed on Bound API instance.",
68
+ "fix:",
69
+ "- Ensure BoundApiRuntime attaches internals (020 foundation).",
70
+ "- If you created a mock bound for tests, attach internals or avoid calling internal-only APIs."
71
+ ].join("\n") : "Bound internals not installed";
72
+ throw new Error(msg);
73
+ }
74
+ return internals;
75
+ };
76
+
77
+ export {
78
+ setRuntimeInternals,
79
+ setBoundInternals,
80
+ setModuleTraitsProgram,
81
+ getModuleTraitsProgram,
82
+ getRuntimeInternals,
83
+ getBoundInternals
84
+ };
85
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vLi4vbG9naXgtY29yZS9zcmMvaW50ZXJuYWwvcnVudGltZS9jb3JlL3J1bnRpbWVJbnRlcm5hbHNBY2Nlc3Nvci50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHsgaXNEZXZFbnYgfSBmcm9tICcuL2Vudi5qcydcbmltcG9ydCB0eXBlIHsgUnVudGltZUludGVybmFscyB9IGZyb20gJy4vUnVudGltZUludGVybmFscy5qcydcblxuY29uc3QgUlVOVElNRV9JTlRFUk5BTFMgPSBTeW1ib2wuZm9yKCdAbG9naXgvY29yZS9ydW50aW1lSW50ZXJuYWxzJylcbmNvbnN0IEJPVU5EX0lOVEVSTkFMUyA9IFN5bWJvbC5mb3IoJ0Bsb2dpeC9jb3JlL2JvdW5kSW50ZXJuYWxzJylcbmNvbnN0IE1PRFVMRV9UUkFJVFNfUFJPR1JBTSA9IFN5bWJvbC5mb3IoJ0Bsb2dpeC9jb3JlL21vZHVsZVRyYWl0c1Byb2dyYW0nKVxuXG5jb25zdCBkZWZpbmVIaWRkZW4gPSAodGFyZ2V0OiBvYmplY3QsIGtleTogc3ltYm9sLCB2YWx1ZTogdW5rbm93bik6IHZvaWQgPT4ge1xuICBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIHtcbiAgICB2YWx1ZSxcbiAgICBlbnVtZXJhYmxlOiBmYWxzZSxcbiAgICBjb25maWd1cmFibGU6IHRydWUsXG4gICAgd3JpdGFibGU6IGZhbHNlLFxuICB9KVxufVxuXG5leHBvcnQgY29uc3Qgc2V0UnVudGltZUludGVybmFscyA9IChydW50aW1lOiBvYmplY3QsIGludGVybmFsczogUnVudGltZUludGVybmFscyk6IHZvaWQgPT4ge1xuICBkZWZpbmVIaWRkZW4ocnVudGltZSwgUlVOVElNRV9JTlRFUk5BTFMsIGludGVybmFscylcbn1cblxuZXhwb3J0IGNvbnN0IHNldEJvdW5kSW50ZXJuYWxzID0gKGJvdW5kOiBvYmplY3QsIGludGVybmFsczogUnVudGltZUludGVybmFscyk6IHZvaWQgPT4ge1xuICBkZWZpbmVIaWRkZW4oYm91bmQsIEJPVU5EX0lOVEVSTkFMUywgaW50ZXJuYWxzKVxufVxuXG4vKipcbiAqIE1vZHVsZVRyYWl0c1Byb2dyYW1cdUZGMDhTdGF0ZVRyYWl0UHJvZ3JhbVx1RkYwOVx1RkYxQVxuICogLSBcdTc1MjhcdTRFOEVcdTU3MjggTW9kdWxlIFx1NUI5QVx1NEU0OVx1NUJGOVx1OEM2MVx1NEUwQVx1NjMwMlx1OEY3RCB0cmFpdHMgUHJvZ3JhbVx1RkYwOFx1NEY5QiBUcmFpdExpZmVjeWNsZS9EZWJ1ZyBcdTRGN0ZcdTc1MjhcdUZGMDlcdUZGMUJcbiAqIC0gXHU0RjdGXHU3NTI4IFN5bWJvbCArIG5vbi1lbnVtZXJhYmxlIHByb3BlcnR5XHVGRjBDXHU5MDdGXHU1MTREIGAuX18qYCBtYWdpYyBmaWVsZCBcdTYyNjlcdTY1NjNcdTMwMDJcbiAqXG4gKiBcdTZDRThcdTYxMEZcdUZGMUFcdThGRDlcdTY2MkZcdTIwMUNcdTZBMjFcdTU3NTdcdTVCOUFcdTRFNDlcdTRGQTdcdTIwMURcdTc2ODRcdTUxODVcdTkwRThcdTY5RkRcdTRGNERcdUZGMENcdTRFMERcdTVDNUVcdTRFOEUgUnVudGltZUludGVybmFsc1x1RkYwOFx1NUI5RVx1NEY4Qlx1N0VBN1x1RkYwOVx1RkYxQlx1NEUyNFx1ODAwNVx1OEJFRFx1NEU0OVx1NEUwRFx1NTQwQ1x1MzAwMlxuICovXG5leHBvcnQgY29uc3Qgc2V0TW9kdWxlVHJhaXRzUHJvZ3JhbSA9IChtb2R1bGU6IG9iamVjdCwgcHJvZ3JhbTogdW5rbm93bik6IHZvaWQgPT4ge1xuICBkZWZpbmVIaWRkZW4obW9kdWxlLCBNT0RVTEVfVFJBSVRTX1BST0dSQU0sIHByb2dyYW0pXG59XG5cbmV4cG9ydCBjb25zdCBnZXRNb2R1bGVUcmFpdHNQcm9ncmFtID0gKG1vZHVsZTogdW5rbm93bik6IHVua25vd24gfCB1bmRlZmluZWQgPT4ge1xuICBpZiAoIW1vZHVsZSkgcmV0dXJuIHVuZGVmaW5lZFxuICBpZiAodHlwZW9mIG1vZHVsZSAhPT0gJ29iamVjdCcgJiYgdHlwZW9mIG1vZHVsZSAhPT0gJ2Z1bmN0aW9uJykgcmV0dXJuIHVuZGVmaW5lZFxuICByZXR1cm4gKG1vZHVsZSBhcyBhbnkpW01PRFVMRV9UUkFJVFNfUFJPR1JBTV0gYXMgdW5rbm93biB8IHVuZGVmaW5lZFxufVxuXG5jb25zdCBmb3JtYXRTY29wZSA9IChtb2R1bGVJZDogdW5rbm93biwgaW5zdGFuY2VJZDogdW5rbm93bik6IHN0cmluZyA9PiB7XG4gIGNvbnN0IG0gPSB0eXBlb2YgbW9kdWxlSWQgPT09ICdzdHJpbmcnICYmIG1vZHVsZUlkLmxlbmd0aCA+IDAgPyBtb2R1bGVJZCA6ICd1bmtub3duJ1xuICBjb25zdCBpID0gdHlwZW9mIGluc3RhbmNlSWQgPT09ICdzdHJpbmcnICYmIGluc3RhbmNlSWQubGVuZ3RoID4gMCA/IGluc3RhbmNlSWQgOiAndW5rbm93bidcbiAgcmV0dXJuIGBtb2R1bGVJZD0ke219LCBpbnN0YW5jZUlkPSR7aX1gXG59XG5cbmV4cG9ydCBjb25zdCBnZXRSdW50aW1lSW50ZXJuYWxzID0gKHJ1bnRpbWU6IG9iamVjdCk6IFJ1bnRpbWVJbnRlcm5hbHMgPT4ge1xuICBjb25zdCBzY29wZSA9IHJ1bnRpbWUgYXMgeyByZWFkb25seSBtb2R1bGVJZD86IHVua25vd247IHJlYWRvbmx5IGluc3RhbmNlSWQ/OiB1bmtub3duIH1cbiAgY29uc3QgaW50ZXJuYWxzID0gKHJ1bnRpbWUgYXMgYW55KVtSVU5USU1FX0lOVEVSTkFMU10gYXMgUnVudGltZUludGVybmFscyB8IHVuZGVmaW5lZFxuICBpZiAoIWludGVybmFscykge1xuICAgIGNvbnN0IG1zZyA9IGlzRGV2RW52KClcbiAgICAgID8gW1xuICAgICAgICAgICdbTWlzc2luZ1J1bnRpbWVJbnRlcm5hbHNdIFJ1bnRpbWUgaW50ZXJuYWxzIG5vdCBpbnN0YWxsZWQgb24gTW9kdWxlUnVudGltZSBpbnN0YW5jZS4nLFxuICAgICAgICAgIGBzY29wZTogJHtmb3JtYXRTY29wZShzY29wZS5tb2R1bGVJZCwgc2NvcGUuaW5zdGFuY2VJZCl9YCxcbiAgICAgICAgICAnZml4OicsXG4gICAgICAgICAgJy0gRW5zdXJlIE1vZHVsZVJ1bnRpbWUubWFrZSBjYWxscyBpbnRlcm5hbEhvb2tzLmluc3RhbGxJbnRlcm5hbEhvb2tzICgwMjAgZm91bmRhdGlvbikuJyxcbiAgICAgICAgICAnLSBJZiB5b3UgY3JlYXRlZCBhIG1vY2sgcnVudGltZSBmb3IgdGVzdHMsIGF0dGFjaCBpbnRlcm5hbHMgb3IgYXZvaWQgY2FsbGluZyBpbnRlcm5hbC1vbmx5IEFQSXMuJyxcbiAgICAgICAgXS5qb2luKCdcXG4nKVxuICAgICAgOiAnUnVudGltZSBpbnRlcm5hbHMgbm90IGluc3RhbGxlZCdcbiAgICB0aHJvdyBuZXcgRXJyb3IobXNnKVxuICB9XG5cbiAgY29uc3QgcnVudGltZUluc3RhbmNlSWQgPSBzY29wZS5pbnN0YW5jZUlkXG4gIGlmIChcbiAgICB0eXBlb2YgcnVudGltZUluc3RhbmNlSWQgPT09ICdzdHJpbmcnICYmXG4gICAgcnVudGltZUluc3RhbmNlSWQubGVuZ3RoID4gMCAmJlxuICAgIHJ1bnRpbWVJbnN0YW5jZUlkICE9PSBpbnRlcm5hbHMuaW5zdGFuY2VJZFxuICApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBpc0RldkVudigpXG4gICAgICAgID8gW1xuICAgICAgICAgICAgJ1tJbmNvbnNpc3RlbnRSdW50aW1lSW50ZXJuYWxzXSBSdW50aW1lIGludGVybmFscyBpbnN0YW5jZUlkIG1pc21hdGNoLicsXG4gICAgICAgICAgICBgcnVudGltZTogJHtmb3JtYXRTY29wZShzY29wZS5tb2R1bGVJZCwgcnVudGltZUluc3RhbmNlSWQpfWAsXG4gICAgICAgICAgICBgaW50ZXJuYWxzOiAke2Zvcm1hdFNjb3BlKGludGVybmFscy5tb2R1bGVJZCwgaW50ZXJuYWxzLmluc3RhbmNlSWQpfWAsXG4gICAgICAgICAgXS5qb2luKCdcXG4nKVxuICAgICAgICA6ICdSdW50aW1lIGludGVybmFscyBtaXNtYXRjaCcsXG4gICAgKVxuICB9XG5cbiAgcmV0dXJuIGludGVybmFsc1xufVxuXG5leHBvcnQgY29uc3QgZ2V0Qm91bmRJbnRlcm5hbHMgPSAoYm91bmQ6IG9iamVjdCk6IFJ1bnRpbWVJbnRlcm5hbHMgPT4ge1xuICBjb25zdCBpbnRlcm5hbHMgPSAoYm91bmQgYXMgYW55KVtCT1VORF9JTlRFUk5BTFNdIGFzIFJ1bnRpbWVJbnRlcm5hbHMgfCB1bmRlZmluZWRcbiAgaWYgKCFpbnRlcm5hbHMpIHtcbiAgICBjb25zdCBtc2cgPSBpc0RldkVudigpXG4gICAgICA/IFtcbiAgICAgICAgICAnW01pc3NpbmdCb3VuZEludGVybmFsc10gQm91bmQgaW50ZXJuYWxzIG5vdCBpbnN0YWxsZWQgb24gQm91bmQgQVBJIGluc3RhbmNlLicsXG4gICAgICAgICAgJ2ZpeDonLFxuICAgICAgICAgICctIEVuc3VyZSBCb3VuZEFwaVJ1bnRpbWUgYXR0YWNoZXMgaW50ZXJuYWxzICgwMjAgZm91bmRhdGlvbikuJyxcbiAgICAgICAgICAnLSBJZiB5b3UgY3JlYXRlZCBhIG1vY2sgYm91bmQgZm9yIHRlc3RzLCBhdHRhY2ggaW50ZXJuYWxzIG9yIGF2b2lkIGNhbGxpbmcgaW50ZXJuYWwtb25seSBBUElzLicsXG4gICAgICAgIF0uam9pbignXFxuJylcbiAgICAgIDogJ0JvdW5kIGludGVybmFscyBub3QgaW5zdGFsbGVkJ1xuICAgIHRocm93IG5ldyBFcnJvcihtc2cpXG4gIH1cblxuICByZXR1cm4gaW50ZXJuYWxzXG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7O0FBR0EsSUFBTSxvQkFBb0IsdUJBQU8sSUFBSSw4QkFBOEI7QUFDbkUsSUFBTSxrQkFBa0IsdUJBQU8sSUFBSSw0QkFBNEI7QUFDL0QsSUFBTSx3QkFBd0IsdUJBQU8sSUFBSSxpQ0FBaUM7QUFFMUUsSUFBTSxlQUFlLENBQUMsUUFBZ0IsS0FBYSxVQUF5QjtBQUMxRSxTQUFPLGVBQWUsUUFBUSxLQUFLO0FBQUEsSUFDakM7QUFBQSxJQUNBLFlBQVk7QUFBQSxJQUNaLGNBQWM7QUFBQSxJQUNkLFVBQVU7QUFBQSxFQUNaLENBQUM7QUFDSDtBQUVPLElBQU0sc0JBQXNCLENBQUMsU0FBaUIsY0FBc0M7QUFDekYsZUFBYSxTQUFTLG1CQUFtQixTQUFTO0FBQ3BEO0FBRU8sSUFBTSxvQkFBb0IsQ0FBQyxPQUFlLGNBQXNDO0FBQ3JGLGVBQWEsT0FBTyxpQkFBaUIsU0FBUztBQUNoRDtBQVNPLElBQU0seUJBQXlCLENBQUMsUUFBZ0IsWUFBMkI7QUFDaEYsZUFBYSxRQUFRLHVCQUF1QixPQUFPO0FBQ3JEO0FBRU8sSUFBTSx5QkFBeUIsQ0FBQyxXQUF5QztBQUM5RSxNQUFJLENBQUMsT0FBUSxRQUFPO0FBQ3BCLE1BQUksT0FBTyxXQUFXLFlBQVksT0FBTyxXQUFXLFdBQVksUUFBTztBQUN2RSxTQUFRLE9BQWUscUJBQXFCO0FBQzlDO0FBRUEsSUFBTSxjQUFjLENBQUMsVUFBbUIsZUFBZ0M7QUFDdEUsUUFBTSxJQUFJLE9BQU8sYUFBYSxZQUFZLFNBQVMsU0FBUyxJQUFJLFdBQVc7QUFDM0UsUUFBTSxJQUFJLE9BQU8sZUFBZSxZQUFZLFdBQVcsU0FBUyxJQUFJLGFBQWE7QUFDakYsU0FBTyxZQUFZLENBQUMsZ0JBQWdCLENBQUM7QUFDdkM7QUFFTyxJQUFNLHNCQUFzQixDQUFDLFlBQXNDO0FBQ3hFLFFBQU0sUUFBUTtBQUNkLFFBQU0sWUFBYSxRQUFnQixpQkFBaUI7QUFDcEQsTUFBSSxDQUFDLFdBQVc7QUFDZCxVQUFNLE1BQU0sU0FBUyxJQUNqQjtBQUFBLE1BQ0U7QUFBQSxNQUNBLFVBQVUsWUFBWSxNQUFNLFVBQVUsTUFBTSxVQUFVLENBQUM7QUFBQSxNQUN2RDtBQUFBLE1BQ0E7QUFBQSxNQUNBO0FBQUEsSUFDRixFQUFFLEtBQUssSUFBSSxJQUNYO0FBQ0osVUFBTSxJQUFJLE1BQU0sR0FBRztBQUFBLEVBQ3JCO0FBRUEsUUFBTSxvQkFBb0IsTUFBTTtBQUNoQyxNQUNFLE9BQU8sc0JBQXNCLFlBQzdCLGtCQUFrQixTQUFTLEtBQzNCLHNCQUFzQixVQUFVLFlBQ2hDO0FBQ0EsVUFBTSxJQUFJO0FBQUEsTUFDUixTQUFTLElBQ0w7QUFBQSxRQUNFO0FBQUEsUUFDQSxZQUFZLFlBQVksTUFBTSxVQUFVLGlCQUFpQixDQUFDO0FBQUEsUUFDMUQsY0FBYyxZQUFZLFVBQVUsVUFBVSxVQUFVLFVBQVUsQ0FBQztBQUFBLE1BQ3JFLEVBQUUsS0FBSyxJQUFJLElBQ1g7QUFBQSxJQUNOO0FBQUEsRUFDRjtBQUVBLFNBQU87QUFDVDtBQUVPLElBQU0sb0JBQW9CLENBQUMsVUFBb0M7QUFDcEUsUUFBTSxZQUFhLE1BQWMsZUFBZTtBQUNoRCxNQUFJLENBQUMsV0FBVztBQUNkLFVBQU0sTUFBTSxTQUFTLElBQ2pCO0FBQUEsTUFDRTtBQUFBLE1BQ0E7QUFBQSxNQUNBO0FBQUEsTUFDQTtBQUFBLElBQ0YsRUFBRSxLQUFLLElBQUksSUFDWDtBQUNKLFVBQU0sSUFBSSxNQUFNLEdBQUc7QUFBQSxFQUNyQjtBQUVBLFNBQU87QUFDVDsiLAogICJuYW1lcyI6IFtdCn0K