@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,819 @@
1
+ // @logixjs/core subpath bundles for @logixjs/sandbox
2
+
3
+ import {
4
+ compileWorkflowRuntimeStepsV1,
5
+ evalInputExpr,
6
+ makeWorkflowError
7
+ } from "./chunk-UZZBHWIO.js";
8
+ import {
9
+ attachLogicUnitMeta,
10
+ currentTxnOriginOverride
11
+ } from "./chunk-BJOWSSEL.js";
12
+ import {
13
+ RootContextTag
14
+ } from "./chunk-UBMUY7WO.js";
15
+ import {
16
+ getRuntimeInternals
17
+ } from "./chunk-7GPAF2UK.js";
18
+ import {
19
+ HostSchedulerTag,
20
+ TickSchedulerTag,
21
+ forceSourceRefresh,
22
+ inSyncTransactionFiber
23
+ } from "./chunk-YMVMZA3U.js";
24
+ import {
25
+ makeInRunSession,
26
+ run
27
+ } from "./chunk-W365QUZ5.js";
28
+ import {
29
+ currentDiagnosticsLevel,
30
+ record,
31
+ toSerializableErrorSummary
32
+ } from "./chunk-SH7TP5CJ.js";
33
+ import {
34
+ EffectOpMiddlewareTag
35
+ } from "./chunk-SI5OKFFY.js";
36
+
37
+ // ../logix-core/src/internal/runtime/core/WorkflowRuntime.ts
38
+ import { Cause, Context, Deferred, Effect, Exit, Fiber, FiberRef, Option, Stream } from "../effect.js";
39
+ var WORKFLOW_REGISTRY = /* @__PURE__ */ Symbol.for("@logixjs/core/workflowRegistry");
40
+ var isRecord = (value) => typeof value === "object" && value !== null && !Array.isArray(value);
41
+ var isObjectLike = (value) => typeof value === "object" && value !== null || typeof value === "function";
42
+ var getRegistry = (runtime) => runtime[WORKFLOW_REGISTRY];
43
+ var resolveActionTag = (action) => {
44
+ const tag = isObjectLike(action) ? action._tag : void 0;
45
+ if (typeof tag === "string" && tag.length > 0) return tag;
46
+ const type = isObjectLike(action) ? action.type : void 0;
47
+ if (typeof type === "string" && type.length > 0) return type;
48
+ if (tag != null) return String(tag);
49
+ if (type != null) return String(type);
50
+ return void 0;
51
+ };
52
+ var asNonEmptyString = (value) => typeof value === "string" && value.trim().length > 0 ? value.trim() : void 0;
53
+ var KERNEL_PORT_SOURCE_REFRESH = "logix/kernel/sourceRefresh";
54
+ var resolveServicePort = (runtime, env, serviceId, programId, stepKey) => {
55
+ if (serviceId === KERNEL_PORT_SOURCE_REFRESH) {
56
+ return (input) => Effect.gen(function* () {
57
+ const fieldPath = asNonEmptyString(isRecord(input) ? input.fieldPath : void 0);
58
+ if (!fieldPath) {
59
+ throw makeWorkflowError({
60
+ code: "WORKFLOW_INVALID_STEP",
61
+ message: "KernelPort sourceRefresh requires input.fieldPath (non-empty string).",
62
+ programId,
63
+ source: { stepKey },
64
+ detail: { serviceId, input }
65
+ });
66
+ }
67
+ const internals = getRuntimeInternals(runtime);
68
+ const handler = internals.traits.getSourceRefreshHandler(fieldPath);
69
+ if (!handler) {
70
+ return;
71
+ }
72
+ const force = isRecord(input) && input.force === true;
73
+ const runHandler = (state) => force ? Effect.locally(forceSourceRefresh, true)(handler(state)) : handler(state);
74
+ const inTxn = yield* FiberRef.get(inSyncTransactionFiber);
75
+ if (inTxn) {
76
+ const state = yield* runtime.getState;
77
+ yield* runHandler(state);
78
+ return;
79
+ }
80
+ yield* internals.txn.runWithStateTransaction(
81
+ {
82
+ kind: "source-refresh",
83
+ name: fieldPath
84
+ },
85
+ () => Effect.gen(function* () {
86
+ const state = yield* runtime.getState;
87
+ yield* runHandler(state);
88
+ })
89
+ );
90
+ });
91
+ }
92
+ const tag = Context.GenericTag(serviceId);
93
+ const opt = Context.getOption(env, tag);
94
+ if (Option.isNone(opt)) {
95
+ throw makeWorkflowError({
96
+ code: "WORKFLOW_MISSING_SERVICE",
97
+ message: `Missing service for serviceId="${serviceId}".`,
98
+ programId,
99
+ source: { stepKey },
100
+ detail: { serviceId }
101
+ });
102
+ }
103
+ const value = opt.value;
104
+ if (typeof value === "function") {
105
+ const fn = value;
106
+ return (input) => fn(input);
107
+ }
108
+ const callFn = isObjectLike(value) ? value.call : void 0;
109
+ if (typeof callFn === "function") {
110
+ const call = callFn;
111
+ return (input) => call.call(value, input);
112
+ }
113
+ throw makeWorkflowError({
114
+ code: "WORKFLOW_INVALID_SERVICE_PORT",
115
+ message: `Invalid service port for serviceId="${serviceId}" (expected a function or { call(input): Effect }).`,
116
+ programId,
117
+ source: { stepKey },
118
+ detail: { serviceId, portType: typeof value }
119
+ });
120
+ };
121
+ var compileSteps = (steps, resolvePort) => {
122
+ const visit = (step) => {
123
+ switch (step.kind) {
124
+ case "dispatch":
125
+ return {
126
+ kind: "dispatch",
127
+ key: step.key,
128
+ actionTag: step.actionTag,
129
+ ...step.payload ? { payload: step.payload } : null
130
+ };
131
+ case "delay":
132
+ return { kind: "delay", key: step.key, ms: step.ms };
133
+ case "call":
134
+ return {
135
+ kind: "call",
136
+ key: step.key,
137
+ serviceId: step.serviceId,
138
+ port: resolvePort(step.serviceId, step.key),
139
+ ...step.input ? { input: step.input } : null,
140
+ ...step.timeoutMs !== void 0 ? { timeoutMs: step.timeoutMs } : null,
141
+ ...step.retryTimes !== void 0 ? { retryTimes: step.retryTimes } : null,
142
+ onSuccess: step.onSuccess.map(visit),
143
+ onFailure: step.onFailure.map(visit)
144
+ };
145
+ }
146
+ };
147
+ return steps.map(visit);
148
+ };
149
+ var resolveConcurrency = (def) => def.policy?.concurrency ?? "parallel";
150
+ var resolvePriority = (def) => def.policy?.priority ?? "urgent";
151
+ var makeRunId = (instanceId, programId, runSeq) => `${instanceId}::wf:${programId}::r${runSeq}`;
152
+ var runBoundary = (args) => Effect.gen(function* () {
153
+ const op = yield* makeInRunSession({
154
+ kind: args.kind,
155
+ name: args.name,
156
+ effect: args.effect,
157
+ payload: args.payload,
158
+ meta: args.meta
159
+ });
160
+ const stack = args.middleware?.stack ?? [];
161
+ return yield* run(op, stack);
162
+ });
163
+ var makeTimer = (args) => Effect.async((resume) => {
164
+ let fired = false;
165
+ const cancel = args.host.scheduleTimeout(args.ms, () => {
166
+ fired = true;
167
+ args.host.scheduleMicrotask(() => resume(Effect.void));
168
+ });
169
+ return Effect.sync(() => {
170
+ cancel();
171
+ }).pipe(Effect.zipRight(fired ? Effect.void : args.onCancel));
172
+ });
173
+ var ensureLimiterReady = (registry, runtime) => Effect.gen(function* () {
174
+ if (registry.parallelLimiter !== void 0) return;
175
+ const internals = getRuntimeInternals(runtime);
176
+ const policy = yield* internals.concurrency.resolveConcurrencyPolicy();
177
+ const limit = policy.concurrencyLimit;
178
+ if (limit === "unbounded") {
179
+ registry.parallelLimiter = null;
180
+ return;
181
+ }
182
+ const n = typeof limit === "number" && Number.isFinite(limit) && limit >= 1 ? Math.floor(limit) : 16;
183
+ registry.parallelLimiter = yield* Effect.makeSemaphore(n);
184
+ });
185
+ var withRootEnvIfAvailable = (eff) => Effect.gen(function* () {
186
+ const rootOpt = yield* Effect.serviceOption(RootContextTag);
187
+ if (Option.isNone(rootOpt)) {
188
+ return yield* eff;
189
+ }
190
+ const root = rootOpt.value;
191
+ const rootEnv = root.context ?? (yield* Deferred.await(root.ready));
192
+ const currentEnv = yield* Effect.context();
193
+ const mergedEnv = Context.merge(rootEnv, currentEnv);
194
+ return yield* Effect.provide(eff, mergedEnv);
195
+ });
196
+ var ensurePortsResolved = (registry, runtime) => Effect.gen(function* () {
197
+ const done = yield* Deferred.isDone(registry.portsReady);
198
+ if (done) {
199
+ yield* Deferred.await(registry.portsReady);
200
+ return;
201
+ }
202
+ if (registry.portsResolving) {
203
+ yield* Deferred.await(registry.portsReady);
204
+ return;
205
+ }
206
+ registry.portsResolving = true;
207
+ const env = yield* Effect.context();
208
+ yield* Effect.sync(() => {
209
+ const portCache = /* @__PURE__ */ new Map();
210
+ for (const entry of registry.entries) {
211
+ const program = entry.program;
212
+ if (program.steps) continue;
213
+ const resolvePort = (serviceId, stepKey) => {
214
+ const cached = portCache.get(serviceId);
215
+ if (cached) return cached;
216
+ const resolved = resolveServicePort(runtime, env, serviceId, program.programId, stepKey);
217
+ portCache.set(serviceId, resolved);
218
+ return resolved;
219
+ };
220
+ program.steps = compileSteps(program.compiledSteps, resolvePort);
221
+ }
222
+ }).pipe(
223
+ Effect.tap(() => Deferred.succeed(registry.portsReady, void 0)),
224
+ Effect.catchAllCause((cause) => Deferred.failCause(registry.portsReady, cause).pipe(Effect.zipRight(Effect.failCause(cause)))),
225
+ Effect.ensuring(
226
+ Effect.sync(() => {
227
+ registry.portsResolving = false;
228
+ })
229
+ )
230
+ );
231
+ });
232
+ var shouldObserveForRun = (diagnostics, runSeq) => {
233
+ if (diagnostics === "off") return false;
234
+ if (diagnostics === "sampled") {
235
+ return (runSeq & 15) === 0;
236
+ }
237
+ return true;
238
+ };
239
+ var startProgramRun = (args) => Effect.gen(function* () {
240
+ const { entry, runtime, registry } = args;
241
+ const { program, state } = entry;
242
+ const diagnostics = yield* FiberRef.get(currentDiagnosticsLevel);
243
+ const beginRun = () => {
244
+ if (state.mode === "latest") {
245
+ state.runSeq += 1;
246
+ const runSeq3 = state.runSeq;
247
+ const runId3 = makeRunId(runtime.instanceId, program.programId, runSeq3);
248
+ return {
249
+ runSeq: runSeq3,
250
+ runId: runId3,
251
+ canWriteBack: () => state.runSeq === runSeq3
252
+ };
253
+ }
254
+ state.runSeq += 1;
255
+ const runSeq2 = state.runSeq;
256
+ const runId2 = makeRunId(runtime.instanceId, program.programId, runSeq2);
257
+ return {
258
+ runSeq: runSeq2,
259
+ runId: runId2,
260
+ canWriteBack: () => true
261
+ };
262
+ };
263
+ if (state.mode === "exhaust") {
264
+ if (state.busy) {
265
+ if (diagnostics !== "off") {
266
+ const observe2 = shouldObserveForRun(diagnostics, state.runSeq);
267
+ const tickSeq = observe2 ? (yield* TickSchedulerTag).getTickSeq() : void 0;
268
+ yield* runBoundary({
269
+ kind: "flow",
270
+ name: "workflow.drop",
271
+ payload: { programId: program.programId, trigger: args.trigger },
272
+ meta: {
273
+ moduleId: runtime.moduleId,
274
+ instanceId: runtime.instanceId,
275
+ programId: program.programId,
276
+ ...tickSeq !== void 0 ? { tickSeq } : null,
277
+ policy: { disableObservers: !observe2 },
278
+ reason: "exhaust"
279
+ },
280
+ effect: Effect.void,
281
+ middleware: args.middleware
282
+ });
283
+ }
284
+ return;
285
+ }
286
+ state.busy = true;
287
+ }
288
+ const { runSeq, runId, canWriteBack } = beginRun();
289
+ if (state.mode === "latest") {
290
+ const prev = state.current;
291
+ const prevRunId = state.currentRunId;
292
+ if (prev) {
293
+ yield* Fiber.interruptFork(prev);
294
+ if (diagnostics !== "off") {
295
+ const observe2 = shouldObserveForRun(diagnostics, runSeq);
296
+ const tickSeq = observe2 ? (yield* TickSchedulerTag).getTickSeq() : void 0;
297
+ yield* runBoundary({
298
+ kind: "flow",
299
+ name: "workflow.cancel",
300
+ payload: { programId: program.programId, cancelled: prevRunId, by: runId },
301
+ meta: {
302
+ moduleId: runtime.moduleId,
303
+ instanceId: runtime.instanceId,
304
+ programId: program.programId,
305
+ ...tickSeq !== void 0 ? { tickSeq } : null,
306
+ policy: { disableObservers: !observe2 },
307
+ reason: "latest",
308
+ cancelledByRunId: runId,
309
+ cancelledRunId: prevRunId
310
+ },
311
+ effect: Effect.void,
312
+ middleware: args.middleware
313
+ });
314
+ }
315
+ }
316
+ state.currentRunId = runId;
317
+ }
318
+ const observe = shouldObserveForRun(diagnostics, runSeq);
319
+ const policy = { disableObservers: !observe };
320
+ const programEffect = Effect.gen(function* () {
321
+ const host = yield* HostSchedulerTag;
322
+ const tick = yield* TickSchedulerTag;
323
+ if (!program.steps) {
324
+ const env = yield* Effect.context();
325
+ const portCache = /* @__PURE__ */ new Map();
326
+ const resolvePort = (serviceId, stepKey) => {
327
+ const cached = portCache.get(serviceId);
328
+ if (cached) return cached;
329
+ const resolved = resolveServicePort(runtime, env, serviceId, program.programId, stepKey);
330
+ portCache.set(serviceId, resolved);
331
+ return resolved;
332
+ };
333
+ program.steps = compileSteps(program.compiledSteps, resolvePort);
334
+ }
335
+ const getTickSeq = () => observe ? tick.getTickSeq() : void 0;
336
+ const emitTimerEvents = observe && diagnostics === "full";
337
+ const evalPayload = (expr) => expr ? evalInputExpr(expr, args.payload) : void 0;
338
+ const defaultInputForCall = () => args.trigger.kind === "action" ? args.payload : void 0;
339
+ let timerTriggered = false;
340
+ const runSteps = (steps) => Effect.gen(function* () {
341
+ for (const step of steps) {
342
+ if (!canWriteBack()) return;
343
+ if (step.kind === "dispatch") {
344
+ const payload = evalPayload(step.payload);
345
+ const action = { _tag: step.actionTag, payload };
346
+ const tickSeq = getTickSeq();
347
+ const dispatchEffectBase = program.priority === "nonUrgent" ? runtime.dispatchLowPriority(action) : runtime.dispatch(action);
348
+ const dispatchEffect = timerTriggered ? Effect.locally(
349
+ currentTxnOriginOverride,
350
+ {
351
+ kind: "workflow.timer",
352
+ name: `timer:${program.programId}:${step.key}`
353
+ }
354
+ )(dispatchEffectBase) : dispatchEffectBase;
355
+ yield* runBoundary({
356
+ kind: "flow",
357
+ name: "workflow.dispatch",
358
+ payload: { actionTag: step.actionTag },
359
+ meta: {
360
+ moduleId: runtime.moduleId,
361
+ instanceId: runtime.instanceId,
362
+ programId: program.programId,
363
+ runId,
364
+ stepKey: step.key,
365
+ ...tickSeq !== void 0 ? { tickSeq } : null,
366
+ policy
367
+ },
368
+ effect: dispatchEffect,
369
+ middleware: args.middleware
370
+ }).pipe(Effect.asVoid);
371
+ continue;
372
+ }
373
+ if (step.kind === "delay") {
374
+ const timerId = emitTimerEvents ? `${runId}::timer:${step.key}` : void 0;
375
+ const recordTimerEvent = (name, patchMeta) => Effect.gen(function* () {
376
+ const tickSeq2 = getTickSeq();
377
+ yield* runBoundary({
378
+ kind: "flow",
379
+ name,
380
+ payload: { ms: step.ms },
381
+ meta: {
382
+ moduleId: runtime.moduleId,
383
+ instanceId: runtime.instanceId,
384
+ programId: program.programId,
385
+ runId,
386
+ stepKey: step.key,
387
+ ...timerId ? { timerId } : null,
388
+ ...tickSeq2 !== void 0 ? { tickSeq: tickSeq2 } : null,
389
+ policy,
390
+ ...patchMeta ?? null
391
+ },
392
+ effect: Effect.void,
393
+ middleware: args.middleware
394
+ });
395
+ });
396
+ const schedule = emitTimerEvents ? recordTimerEvent("workflow.timer.schedule") : Effect.void;
397
+ const onCancel = emitTimerEvents ? recordTimerEvent("workflow.timer.cancel", { reason: "interrupt" }) : Effect.void;
398
+ const fired = emitTimerEvents ? recordTimerEvent("workflow.timer.fired") : Effect.void;
399
+ const delayEffect = schedule.pipe(
400
+ Effect.zipRight(makeTimer({ host, ms: step.ms, onCancel })),
401
+ Effect.zipRight(fired)
402
+ );
403
+ const tickSeq = getTickSeq();
404
+ yield* runBoundary({
405
+ kind: "flow",
406
+ name: "workflow.delay",
407
+ payload: { ms: step.ms },
408
+ meta: {
409
+ moduleId: runtime.moduleId,
410
+ instanceId: runtime.instanceId,
411
+ programId: program.programId,
412
+ runId,
413
+ stepKey: step.key,
414
+ ...tickSeq !== void 0 ? { tickSeq } : null,
415
+ ...timerId ? { timerId } : null,
416
+ policy
417
+ },
418
+ effect: delayEffect,
419
+ middleware: args.middleware
420
+ }).pipe(Effect.asVoid);
421
+ timerTriggered = true;
422
+ continue;
423
+ }
424
+ const input = step.input ? evalInputExpr(step.input, args.payload) : defaultInputForCall();
425
+ const maxRetries = step.retryTimes ?? 0;
426
+ let exit;
427
+ for (let attempt = 1; attempt <= maxRetries + 1; attempt += 1) {
428
+ const tickSeq = getTickSeq();
429
+ const base = runBoundary({
430
+ kind: "service",
431
+ name: `workflow.call:${step.serviceId}`,
432
+ payload: { serviceId: step.serviceId },
433
+ meta: {
434
+ moduleId: runtime.moduleId,
435
+ instanceId: runtime.instanceId,
436
+ programId: program.programId,
437
+ runId,
438
+ stepKey: step.key,
439
+ serviceId: step.serviceId,
440
+ attempt,
441
+ ...tickSeq !== void 0 ? { tickSeq } : null,
442
+ policy
443
+ },
444
+ effect: step.port(input),
445
+ middleware: args.middleware
446
+ });
447
+ const withTimeout = step.timeoutMs === void 0 ? base : Effect.gen(function* () {
448
+ const timeoutMs = step.timeoutMs;
449
+ if (timeoutMs === void 0) {
450
+ return yield* base;
451
+ }
452
+ const timerId = emitTimerEvents ? `${runId}::timeout:${step.key}:a${attempt}` : void 0;
453
+ const recordTimeoutEvent = (name, patchMeta) => Effect.gen(function* () {
454
+ const tickSeq2 = getTickSeq();
455
+ yield* runBoundary({
456
+ kind: "flow",
457
+ name,
458
+ payload: { ms: timeoutMs },
459
+ meta: {
460
+ moduleId: runtime.moduleId,
461
+ instanceId: runtime.instanceId,
462
+ programId: program.programId,
463
+ runId,
464
+ stepKey: step.key,
465
+ attempt,
466
+ ...timerId ? { timerId } : null,
467
+ ...tickSeq2 !== void 0 ? { tickSeq: tickSeq2 } : null,
468
+ policy,
469
+ ...patchMeta ?? null
470
+ },
471
+ effect: Effect.void,
472
+ middleware: args.middleware
473
+ });
474
+ });
475
+ const schedule = emitTimerEvents ? recordTimeoutEvent("workflow.timeout.schedule") : Effect.void;
476
+ const onCancel = emitTimerEvents ? recordTimeoutEvent("workflow.timeout.cancel", { reason: "interrupt" }) : Effect.void;
477
+ const fired = emitTimerEvents ? recordTimeoutEvent("workflow.timeout.fired") : Effect.void;
478
+ const timeoutError = makeWorkflowError({
479
+ code: "WORKFLOW_CALL_TIMEOUT",
480
+ message: `Workflow call timed out (serviceId="${step.serviceId}", timeoutMs=${timeoutMs}).`,
481
+ programId: program.programId,
482
+ source: { stepKey: step.key },
483
+ detail: { serviceId: step.serviceId, timeoutMs, attempt }
484
+ });
485
+ const timeoutFail = schedule.pipe(
486
+ Effect.zipRight(makeTimer({ host, ms: timeoutMs, onCancel })),
487
+ Effect.zipRight(fired),
488
+ Effect.zipRight(Effect.fail(timeoutError))
489
+ );
490
+ return yield* Effect.raceFirst(base, timeoutFail);
491
+ });
492
+ const attemptExit = yield* Effect.exit(withTimeout);
493
+ exit = attemptExit;
494
+ if (!canWriteBack() || Exit.isSuccess(attemptExit)) {
495
+ break;
496
+ }
497
+ if (Cause.isInterrupted(attemptExit.cause) || Option.isNone(Cause.failureOption(attemptExit.cause))) {
498
+ break;
499
+ }
500
+ if (attempt < maxRetries + 1) {
501
+ continue;
502
+ }
503
+ break;
504
+ }
505
+ if (!exit) {
506
+ exit = Exit.succeed(void 0);
507
+ }
508
+ if (!canWriteBack()) return;
509
+ if (Exit.isSuccess(exit)) {
510
+ yield* runSteps(step.onSuccess);
511
+ } else {
512
+ const failure = Option.getOrUndefined(Cause.failureOption(exit.cause));
513
+ const isTimeout = isObjectLike(failure) && failure._tag === "WorkflowError" && failure.code === "WORKFLOW_CALL_TIMEOUT";
514
+ if (isTimeout) timerTriggered = true;
515
+ yield* runSteps(step.onFailure);
516
+ }
517
+ }
518
+ });
519
+ const runTickSeq = getTickSeq();
520
+ yield* runBoundary({
521
+ kind: "flow",
522
+ name: "workflow.run",
523
+ payload: { trigger: args.trigger },
524
+ meta: {
525
+ moduleId: runtime.moduleId,
526
+ instanceId: runtime.instanceId,
527
+ programId: program.programId,
528
+ runId,
529
+ ...runTickSeq !== void 0 ? { tickSeq: runTickSeq } : null,
530
+ policy
531
+ },
532
+ effect: runSteps(program.steps),
533
+ middleware: args.middleware
534
+ }).pipe(Effect.asVoid);
535
+ });
536
+ const limited = registry.parallelLimiter ? registry.parallelLimiter.withPermits(1)(programEffect) : programEffect;
537
+ const fiber = yield* Effect.forkScoped(
538
+ limited.pipe(
539
+ Effect.catchAllCause((cause) => {
540
+ const { errorSummary, downgrade } = toSerializableErrorSummary(cause);
541
+ const downgradeHint = downgrade ? ` (downgrade=${downgrade})` : "";
542
+ return record({
543
+ type: "diagnostic",
544
+ moduleId: runtime.moduleId,
545
+ instanceId: runtime.instanceId,
546
+ code: "workflow::run_crashed",
547
+ severity: "error",
548
+ message: `Workflow run crashed for programId="${program.programId}" runId="${runId}".${downgradeHint}`,
549
+ hint: `${errorSummary.name ? `${errorSummary.name}: ` : ""}${errorSummary.message}`,
550
+ actionTag: args.trigger.kind === "action" ? args.trigger.actionTag : void 0,
551
+ kind: "workflow_run_crashed",
552
+ trigger: {
553
+ kind: "workflow",
554
+ name: "run",
555
+ details: {
556
+ programId: program.programId,
557
+ runId,
558
+ trigger: args.trigger
559
+ }
560
+ }
561
+ }).pipe(Effect.catchAllCause(() => Effect.void));
562
+ }),
563
+ Effect.ensuring(
564
+ Effect.sync(() => {
565
+ if (state.mode === "exhaust") {
566
+ state.busy = false;
567
+ }
568
+ })
569
+ )
570
+ )
571
+ );
572
+ if (state.mode === "latest") {
573
+ state.current = fiber;
574
+ }
575
+ });
576
+ var ensureRegistry = (runtime) => Effect.gen(function* () {
577
+ const existing = getRegistry(runtime);
578
+ if (existing) {
579
+ return {
580
+ moduleId: runtime.moduleId,
581
+ instanceId: runtime.instanceId,
582
+ registry: existing
583
+ };
584
+ }
585
+ const portsReady = yield* Deferred.make();
586
+ const next = {
587
+ byActionTag: /* @__PURE__ */ new Map(),
588
+ entries: [],
589
+ watcherStarted: false,
590
+ watcherStartCount: 0,
591
+ portsResolving: false,
592
+ portsReady,
593
+ parallelLimiter: void 0
594
+ };
595
+ Object.defineProperty(runtime, WORKFLOW_REGISTRY, {
596
+ value: next,
597
+ enumerable: false,
598
+ configurable: true,
599
+ writable: false
600
+ });
601
+ return { moduleId: runtime.moduleId, instanceId: runtime.instanceId, registry: next };
602
+ });
603
+ var registerPrograms = (args) => Effect.gen(function* () {
604
+ const runtime = yield* args.moduleTag;
605
+ const { moduleId, instanceId, registry } = yield* ensureRegistry(runtime);
606
+ if (registry.parallelLimiter === void 0) {
607
+ yield* ensureLimiterReady(registry, runtime);
608
+ }
609
+ const validateNoIoStepsForOnInit = (steps, programId) => {
610
+ const visit = (step) => {
611
+ if (step.kind === "call" || step.kind === "delay") {
612
+ throw makeWorkflowError({
613
+ code: "WORKFLOW_INVALID_TRIGGER",
614
+ message: "Lifecycle onInit programs must not include call/delay (initRequired must stay sync-only; use onStart for IO/time).",
615
+ programId,
616
+ source: { stepKey: step.key },
617
+ detail: { kind: step.kind }
618
+ });
619
+ }
620
+ };
621
+ for (const s of steps) visit(s);
622
+ };
623
+ const programHasCall = (steps) => steps.some((s) => s.kind === "call");
624
+ const insertEntry = (actionTag, entry) => {
625
+ const prev = registry.byActionTag.get(actionTag);
626
+ registry.byActionTag.set(actionTag, prev ? [...prev, entry] : [entry]);
627
+ };
628
+ const internals = getRuntimeInternals(runtime);
629
+ for (const program of args.programs) {
630
+ const def = program.def;
631
+ const localId = asNonEmptyString(def.localId);
632
+ if (!localId) {
633
+ throw makeWorkflowError({
634
+ code: "WORKFLOW_INVALID_DEF",
635
+ message: "Workflow.install: def.localId must be a non-empty string.",
636
+ detail: { localId: def.localId }
637
+ });
638
+ }
639
+ const programId = `${moduleId}.${localId}`;
640
+ const compiled = compileWorkflowRuntimeStepsV1({ def });
641
+ if (def.trigger.kind === "lifecycle" && def.trigger.phase === "onInit") {
642
+ validateNoIoStepsForOnInit(compiled, programId);
643
+ }
644
+ const compiledProgram = {
645
+ programId,
646
+ localId,
647
+ trigger: def.trigger,
648
+ concurrency: resolveConcurrency(def),
649
+ priority: resolvePriority(def),
650
+ compiledSteps: compiled
651
+ };
652
+ if (!programHasCall(compiled)) {
653
+ compiledProgram.steps = compileSteps(compiled, () => {
654
+ throw makeWorkflowError({
655
+ code: "WORKFLOW_MISSING_SERVICE",
656
+ message: "Internal error: unexpected call step while resolving call-less program.",
657
+ programId,
658
+ detail: { programId }
659
+ });
660
+ });
661
+ }
662
+ const state = compiledProgram.concurrency === "latest" ? { mode: "latest", runSeq: 0, current: void 0, currentRunId: void 0 } : compiledProgram.concurrency === "exhaust" ? { mode: "exhaust", runSeq: 0, busy: false } : { mode: "parallel", runSeq: 0 };
663
+ const entry = { program: compiledProgram, state };
664
+ registry.entries.push(entry);
665
+ if (def.trigger.kind === "action") {
666
+ insertEntry(def.trigger.actionTag, entry);
667
+ } else {
668
+ if (def.trigger.phase === "onStart") {
669
+ internals.lifecycle.registerStart(
670
+ withRootEnvIfAvailable(
671
+ Effect.gen(function* () {
672
+ const middlewareOpt = yield* Effect.serviceOption(EffectOpMiddlewareTag);
673
+ const middleware = Option.isSome(middlewareOpt) ? middlewareOpt.value : void 0;
674
+ yield* ensurePortsResolved(registry, runtime).pipe(Effect.orDie);
675
+ yield* startProgramRun({
676
+ entry,
677
+ runtime,
678
+ registry,
679
+ trigger: { kind: "lifecycle", phase: "onStart" },
680
+ payload: void 0,
681
+ middleware
682
+ });
683
+ })
684
+ ),
685
+ { name: `workflow:${localId}` }
686
+ );
687
+ } else {
688
+ internals.lifecycle.registerInitRequired(
689
+ Effect.gen(function* () {
690
+ const middlewareOpt = yield* Effect.serviceOption(EffectOpMiddlewareTag);
691
+ const middleware = Option.isSome(middlewareOpt) ? middlewareOpt.value : void 0;
692
+ yield* startProgramRun({
693
+ entry,
694
+ runtime,
695
+ registry,
696
+ trigger: { kind: "lifecycle", phase: "onInit" },
697
+ payload: void 0,
698
+ middleware
699
+ });
700
+ }),
701
+ { name: `workflow:${localId}` }
702
+ );
703
+ }
704
+ }
705
+ }
706
+ void instanceId;
707
+ });
708
+ var startWatcherIfNeeded = (args) => Effect.gen(function* () {
709
+ const runtime = yield* args.moduleTag;
710
+ const init = yield* ensureRegistry(runtime);
711
+ const registry = init.registry;
712
+ if (registry.watcherStarted) {
713
+ return;
714
+ }
715
+ registry.watcherStarted = true;
716
+ registry.watcherStartCount += 1;
717
+ const middlewareOpt = yield* Effect.serviceOption(EffectOpMiddlewareTag);
718
+ const middleware = Option.isSome(middlewareOpt) ? middlewareOpt.value : void 0;
719
+ const actions$ = runtime.actions$;
720
+ const portsExit = yield* Effect.exit(ensurePortsResolved(registry, runtime));
721
+ if (Exit.isFailure(portsExit)) {
722
+ const { errorSummary, downgrade } = toSerializableErrorSummary(portsExit.cause);
723
+ const downgradeHint = downgrade ? ` (downgrade=${downgrade})` : "";
724
+ yield* record({
725
+ type: "diagnostic",
726
+ moduleId: runtime.moduleId,
727
+ instanceId: runtime.instanceId,
728
+ code: "workflow::ports_resolution_failed",
729
+ severity: "error",
730
+ message: `Workflow ports resolution failed before starting watcher.${downgradeHint}`,
731
+ hint: `${errorSummary.name ? `${errorSummary.name}: ` : ""}${errorSummary.message}`,
732
+ kind: "workflow_ports_resolution_failed",
733
+ trigger: {
734
+ kind: "workflow",
735
+ name: "portsResolution",
736
+ details: {
737
+ entryLabel: args.entryLabel
738
+ }
739
+ }
740
+ });
741
+ return;
742
+ }
743
+ yield* Stream.runForEach(
744
+ actions$,
745
+ (action) => Effect.gen(function* () {
746
+ const actionTag = resolveActionTag(action);
747
+ if (!actionTag) return;
748
+ const entries = registry.byActionTag.get(actionTag);
749
+ if (!entries || entries.length === 0) return;
750
+ const payload = isRecord(action) ? action.payload : void 0;
751
+ yield* Effect.forEach(
752
+ entries,
753
+ (entry) => startProgramRun({
754
+ entry,
755
+ runtime,
756
+ registry,
757
+ trigger: { kind: "action", actionTag },
758
+ payload,
759
+ middleware
760
+ }),
761
+ { discard: true }
762
+ );
763
+ })
764
+ ).pipe(
765
+ Effect.catchAllCause((cause) => {
766
+ const { errorSummary, downgrade } = toSerializableErrorSummary(cause);
767
+ const downgradeHint = downgrade ? ` (downgrade=${downgrade})` : "";
768
+ return record({
769
+ type: "diagnostic",
770
+ moduleId: runtime.moduleId,
771
+ instanceId: runtime.instanceId,
772
+ code: "workflow::watcher_crashed",
773
+ severity: "error",
774
+ message: `Workflow watcher crashed.${downgradeHint}`,
775
+ hint: `${errorSummary.name ? `${errorSummary.name}: ` : ""}${errorSummary.message}`,
776
+ kind: "workflow_watcher_crashed",
777
+ trigger: {
778
+ kind: "workflow",
779
+ name: "watcher",
780
+ details: {
781
+ entryLabel: args.entryLabel
782
+ }
783
+ }
784
+ });
785
+ })
786
+ );
787
+ void args.entryLabel;
788
+ });
789
+ var mountAll = (args) => {
790
+ const plan = {
791
+ setup: registerPrograms({ moduleTag: args.moduleTag, programs: args.programs, entryLabel: "mountAll" }),
792
+ run: startWatcherIfNeeded({ moduleTag: args.moduleTag, entryLabel: "mountAll" })
793
+ };
794
+ attachLogicUnitMeta(plan, {
795
+ id: "__logix_internal:workflows",
796
+ kind: "internal",
797
+ name: "workflows"
798
+ });
799
+ return plan;
800
+ };
801
+ var installOne = (args) => {
802
+ const localId = asNonEmptyString(args.program.def.localId) ?? "unknown";
803
+ const plan = {
804
+ setup: registerPrograms({ moduleTag: args.moduleTag, programs: [args.program], entryLabel: `install:${localId}` }),
805
+ run: startWatcherIfNeeded({ moduleTag: args.moduleTag, entryLabel: `install:${localId}` })
806
+ };
807
+ attachLogicUnitMeta(plan, {
808
+ id: `workflow:${localId}`,
809
+ kind: "workflow",
810
+ name: localId
811
+ });
812
+ return plan;
813
+ };
814
+
815
+ export {
816
+ mountAll,
817
+ installOne
818
+ };
819
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../logix-core/src/internal/runtime/core/WorkflowRuntime.ts"],
  "sourcesContent": ["import { Cause, Context, Deferred, Effect, Exit, Fiber, FiberRef, Option, Stream } from 'effect'\nimport * as EffectOpCore from './EffectOpCore.js'\nimport * as Debug from './DebugSink.js'\nimport * as LogicUnitMeta from './LogicUnitMeta.js'\nimport { toSerializableErrorSummary } from './errorSummary.js'\nimport type { AnyModuleShape, LogicPlan, ModuleRuntime as PublicModuleRuntime } from './module.js'\nimport { HostSchedulerTag, TickSchedulerTag } from './env.js'\nimport { currentTxnOriginOverride } from './TxnOriginOverride.js'\nimport { getRuntimeInternals } from './runtimeInternalsAccessor.js'\nimport { RootContextTag, type RootContext } from './RootContext.js'\nimport * as TaskRunner from './TaskRunner.js'\nimport * as EffectOp from '../../effect-op.js'\nimport { makeWorkflowError } from '../../workflow/errors.js'\nimport { compileWorkflowRuntimeStepsV1, type CompiledWorkflowStep } from '../../workflow/compiler.js'\nimport { evalInputExpr, type CompiledInputExpr } from '../../workflow/inputExpr.js'\nimport type { WorkflowDefV1, WorkflowTriggerV1 } from '../../workflow/model.js'\n\ntype ModuleTag = Context.Tag<unknown, PublicModuleRuntime<unknown, unknown>>\n\nexport type WorkflowLike = {\n  readonly _tag?: 'Workflow'\n  readonly def: WorkflowDefV1\n  readonly validate?: () => void\n}\n\ntype ConcurrencyMode = 'latest' | 'exhaust' | 'parallel'\ntype Priority = 'urgent' | 'nonUrgent'\n\ntype ServicePort = (input: unknown) => Effect.Effect<unknown, unknown, unknown>\n\ntype CompiledRuntimeStep =\n  | { readonly kind: 'dispatch'; readonly key: string; readonly actionTag: string; readonly payload?: CompiledInputExpr }\n  | { readonly kind: 'delay'; readonly key: string; readonly ms: number }\n  | {\n      readonly kind: 'call'\n      readonly key: string\n      readonly serviceId: string\n      readonly input?: CompiledInputExpr\n      readonly timeoutMs?: number\n      readonly retryTimes?: number\n      readonly port: ServicePort\n      readonly onSuccess: ReadonlyArray<CompiledRuntimeStep>\n      readonly onFailure: ReadonlyArray<CompiledRuntimeStep>\n    }\n\ntype CompiledProgram = {\n  readonly programId: string\n  readonly localId: string\n  readonly trigger: WorkflowTriggerV1\n  readonly concurrency: ConcurrencyMode\n  readonly priority: Priority\n  readonly compiledSteps: ReadonlyArray<CompiledWorkflowStep>\n  steps?: ReadonlyArray<CompiledRuntimeStep>\n}\n\ntype ProgramState =\n  | { readonly mode: 'latest'; runSeq: number; current?: Fiber.RuntimeFiber<void, never>; currentRunId?: string }\n  | { readonly mode: 'exhaust'; runSeq: number; busy: boolean }\n  | { readonly mode: 'parallel'; runSeq: number }\n\ntype ProgramEntry = {\n  readonly program: CompiledProgram\n  readonly state: ProgramState\n}\n\ntype WorkflowRegistryV1 = {\n  readonly byActionTag: Map<string, ReadonlyArray<ProgramEntry>>\n  readonly entries: Array<ProgramEntry>\n  watcherStarted: boolean\n  watcherStartCount: number\n  portsResolving: boolean\n  portsReady: Deferred.Deferred<void, unknown>\n  parallelLimiter: Effect.Semaphore | null | undefined\n}\n\nconst WORKFLOW_REGISTRY = Symbol.for('@logixjs/core/workflowRegistry')\n\nconst isRecord = (value: unknown): value is Record<string, unknown> =>\n  typeof value === 'object' && value !== null && !Array.isArray(value)\n\nconst isObjectLike = (value: unknown): value is Record<string, unknown> | ((...args: never[]) => unknown) =>\n  (typeof value === 'object' && value !== null) || typeof value === 'function'\n\nconst getRegistry = (runtime: object): WorkflowRegistryV1 | undefined =>\n  (runtime as Record<PropertyKey, unknown>)[WORKFLOW_REGISTRY] as WorkflowRegistryV1 | undefined\n\nconst resolveActionTag = (action: unknown): string | undefined => {\n  const tag = isObjectLike(action) ? (action as Record<string, unknown>)._tag : undefined\n  if (typeof tag === 'string' && tag.length > 0) return tag\n  const type = isObjectLike(action) ? (action as Record<string, unknown>).type : undefined\n  if (typeof type === 'string' && type.length > 0) return type\n  if (tag != null) return String(tag)\n  if (type != null) return String(type)\n  return undefined\n}\n\nconst asNonEmptyString = (value: unknown): string | undefined =>\n  typeof value === 'string' && value.trim().length > 0 ? value.trim() : undefined\n\nconst KERNEL_PORT_SOURCE_REFRESH = 'logix/kernel/sourceRefresh'\n\nconst resolveServicePort = (\n  runtime: PublicModuleRuntime<unknown, unknown>,\n  env: Context.Context<unknown>,\n  serviceId: string,\n  programId: string,\n  stepKey: string,\n): ServicePort => {\n  if (serviceId === KERNEL_PORT_SOURCE_REFRESH) {\n    return (input) =>\n      Effect.gen(function* () {\n        const fieldPath = asNonEmptyString(isRecord(input) ? input.fieldPath : undefined)\n        if (!fieldPath) {\n          throw makeWorkflowError({\n            code: 'WORKFLOW_INVALID_STEP',\n            message: 'KernelPort sourceRefresh requires input.fieldPath (non-empty string).',\n            programId,\n            source: { stepKey },\n            detail: { serviceId, input },\n          })\n        }\n\n        const internals = getRuntimeInternals(runtime)\n        const handler = internals.traits.getSourceRefreshHandler(fieldPath)\n\n        // If no refresh handler is registered, treat it as a no-op (aligns with BoundApiRuntime behavior).\n        if (!handler) {\n          return\n        }\n\n        const force = isRecord(input) && input.force === true\n        const runHandler = (state: unknown) =>\n          force ? Effect.locally(TaskRunner.forceSourceRefresh, true)(handler(state)) : handler(state)\n\n        const inTxn = yield* FiberRef.get(TaskRunner.inSyncTransactionFiber)\n        if (inTxn) {\n          const state = yield* runtime.getState\n          yield* runHandler(state)\n          return\n        }\n\n        yield* internals.txn.runWithStateTransaction(\n          {\n            kind: 'source-refresh',\n            name: fieldPath,\n          },\n          () =>\n            Effect.gen(function* () {\n              const state = yield* runtime.getState\n              yield* runHandler(state)\n            }),\n        )\n      })\n  }\n\n  const tag = Context.GenericTag<unknown>(serviceId)\n  const opt = Context.getOption(env, tag)\n  if (Option.isNone(opt)) {\n    throw makeWorkflowError({\n      code: 'WORKFLOW_MISSING_SERVICE',\n      message: `Missing service for serviceId=\"${serviceId}\".`,\n      programId,\n      source: { stepKey },\n      detail: { serviceId },\n    })\n  }\n\n  const value: unknown = opt.value\n  if (typeof value === 'function') {\n    const fn = value as (input: unknown) => Effect.Effect<unknown, unknown, unknown>\n    return (input) => fn(input)\n  }\n\n  const callFn = isObjectLike(value) ? (value as Record<string, unknown>).call : undefined\n  if (typeof callFn === 'function') {\n    const call = callFn as (this: unknown, input: unknown) => Effect.Effect<unknown, unknown, unknown>\n    return (input) => call.call(value, input)\n  }\n\n  throw makeWorkflowError({\n    code: 'WORKFLOW_INVALID_SERVICE_PORT',\n    message: `Invalid service port for serviceId=\"${serviceId}\" (expected a function or { call(input): Effect }).`,\n    programId,\n    source: { stepKey },\n    detail: { serviceId, portType: typeof value },\n  })\n}\n\nconst compileSteps = (steps: ReadonlyArray<CompiledWorkflowStep>, resolvePort: (serviceId: string, stepKey: string) => ServicePort) => {\n  const visit = (step: CompiledWorkflowStep): CompiledRuntimeStep => {\n    switch (step.kind) {\n      case 'dispatch':\n        return {\n          kind: 'dispatch',\n          key: step.key,\n          actionTag: step.actionTag,\n          ...(step.payload ? { payload: step.payload } : null),\n        }\n      case 'delay':\n        return { kind: 'delay', key: step.key, ms: step.ms }\n      case 'call':\n        return {\n          kind: 'call',\n          key: step.key,\n          serviceId: step.serviceId,\n          port: resolvePort(step.serviceId, step.key),\n          ...(step.input ? { input: step.input } : null),\n          ...(step.timeoutMs !== undefined ? { timeoutMs: step.timeoutMs } : null),\n          ...(step.retryTimes !== undefined ? { retryTimes: step.retryTimes } : null),\n          onSuccess: step.onSuccess.map(visit),\n          onFailure: step.onFailure.map(visit),\n        }\n    }\n  }\n\n  return steps.map(visit)\n}\n\nconst resolveConcurrency = (def: WorkflowDefV1): ConcurrencyMode => (def.policy?.concurrency ?? 'parallel') as ConcurrencyMode\nconst resolvePriority = (def: WorkflowDefV1): Priority => (def.policy?.priority ?? 'urgent') as Priority\n\nconst makeRunId = (instanceId: string, programId: string, runSeq: number): string =>\n  `${instanceId}::wf:${programId}::r${runSeq}`\n\nconst runBoundary = <A, E, R>(args: {\n  readonly kind: EffectOp.EffectOp['kind']\n  readonly name: string\n  readonly effect: Effect.Effect<A, E, R>\n  readonly payload?: unknown\n  readonly meta?: EffectOp.EffectOp['meta']\n  readonly middleware: EffectOpCore.EffectOpMiddlewareEnv | undefined\n}): Effect.Effect<A, E, R> =>\n  Effect.gen(function* () {\n    const op = yield* EffectOp.makeInRunSession({\n      kind: args.kind,\n      name: args.name,\n      effect: args.effect,\n      payload: args.payload,\n      meta: args.meta,\n    })\n    const stack = args.middleware?.stack ?? []\n    return yield* EffectOp.run(op, stack)\n  }) as unknown as Effect.Effect<A, E, R>\n\nconst makeTimer = (args: {\n  readonly host: {\n    readonly scheduleMicrotask: (cb: () => void) => void\n    readonly scheduleTimeout: (ms: number, cb: () => void) => () => void\n  }\n  readonly ms: number\n  readonly onCancel: Effect.Effect<void, never, unknown>\n}): Effect.Effect<void, never, unknown> =>\n  Effect.async<void, never, unknown>((resume) => {\n    let fired = false\n    const cancel = args.host.scheduleTimeout(args.ms, () => {\n      fired = true\n      // Route resumption through a microtask boundary:\n      // - Improves determinism in tests (deterministic HostScheduler).\n      // - Avoids deep JS-microtask chains that are invisible to HostScheduler flushing.\n      args.host.scheduleMicrotask(() => resume(Effect.void))\n    })\n    return Effect.sync(() => {\n      cancel()\n    }).pipe(Effect.zipRight(fired ? Effect.void : args.onCancel))\n  })\n\nconst ensureLimiterReady = (registry: WorkflowRegistryV1, runtime: PublicModuleRuntime<unknown, unknown>) =>\n  Effect.gen(function* () {\n    if (registry.parallelLimiter !== undefined) return\n\n    const internals = getRuntimeInternals(runtime)\n    const policy = yield* internals.concurrency.resolveConcurrencyPolicy()\n    const limit = policy.concurrencyLimit\n    if (limit === 'unbounded') {\n      registry.parallelLimiter = null\n      return\n    }\n\n    const n = typeof limit === 'number' && Number.isFinite(limit) && limit >= 1 ? Math.floor(limit) : 16\n    registry.parallelLimiter = yield* Effect.makeSemaphore(n)\n  })\n\nconst withRootEnvIfAvailable = <A, E, R>(eff: Effect.Effect<A, E, R>): Effect.Effect<A, E, R> =>\n  Effect.gen(function* () {\n    const rootOpt = yield* Effect.serviceOption(RootContextTag)\n    if (Option.isNone(rootOpt)) {\n      return yield* eff\n    }\n    const root: RootContext = rootOpt.value\n    const rootEnv = root.context ?? (yield* Deferred.await(root.ready))\n\n    const currentEnv = yield* Effect.context<unknown>()\n    const mergedEnv = Context.merge(rootEnv as unknown as Context.Context<unknown>, currentEnv)\n    return yield* (Effect.provide(eff as unknown as Effect.Effect<A, E, unknown>, mergedEnv) as unknown as Effect.Effect<A, E, R>)\n  }) as unknown as Effect.Effect<A, E, R>\n\nconst ensurePortsResolved = (\n  registry: WorkflowRegistryV1,\n  runtime: PublicModuleRuntime<unknown, unknown>,\n): Effect.Effect<void, unknown, unknown> =>\n  Effect.gen(function* () {\n    const done = yield* Deferred.isDone(registry.portsReady)\n    if (done) {\n      yield* Deferred.await(registry.portsReady)\n      return\n    }\n\n    if (registry.portsResolving) {\n      yield* Deferred.await(registry.portsReady)\n      return\n    }\n\n    registry.portsResolving = true\n    const env = yield* Effect.context<unknown>()\n\n    yield* Effect.sync(() => {\n      const portCache = new Map<string, ServicePort>()\n      for (const entry of registry.entries) {\n        const program = entry.program\n        if (program.steps) continue\n\n        const resolvePort = (serviceId: string, stepKey: string): ServicePort => {\n          const cached = portCache.get(serviceId)\n          if (cached) return cached\n          const resolved = resolveServicePort(runtime, env, serviceId, program.programId, stepKey)\n          portCache.set(serviceId, resolved)\n          return resolved\n        }\n\n        program.steps = compileSteps(program.compiledSteps, resolvePort)\n      }\n    }).pipe(\n      Effect.tap(() => Deferred.succeed(registry.portsReady, undefined)),\n      Effect.catchAllCause((cause) => Deferred.failCause(registry.portsReady, cause).pipe(Effect.zipRight(Effect.failCause(cause)))),\n      Effect.ensuring(\n        Effect.sync(() => {\n          registry.portsResolving = false\n        }),\n      ),\n    )\n  })\n\nconst shouldObserveForRun = (diagnostics: Debug.DiagnosticsLevel, runSeq: number): boolean => {\n  if (diagnostics === 'off') return false\n  if (diagnostics === 'sampled') {\n    // Deterministic sampling (no Math.random): 1/16 by runSeq.\n    return (runSeq & 0x0f) === 0\n  }\n  return true\n}\n\nconst startProgramRun = (args: {\n  readonly entry: ProgramEntry\n  readonly runtime: PublicModuleRuntime<unknown, unknown>\n  readonly registry: WorkflowRegistryV1\n  readonly trigger: { readonly kind: 'action'; readonly actionTag: string } | { readonly kind: 'lifecycle'; readonly phase: string }\n  readonly payload: unknown\n  readonly middleware: EffectOpCore.EffectOpMiddlewareEnv | undefined\n}): Effect.Effect<void, never, unknown> =>\n  Effect.gen(function* () {\n    const { entry, runtime, registry } = args\n    const { program, state } = entry\n\n    const diagnostics = yield* FiberRef.get(Debug.currentDiagnosticsLevel)\n\n    const beginRun = (): { readonly runSeq: number; readonly runId: string; readonly canWriteBack: () => boolean } => {\n      if (state.mode === 'latest') {\n        state.runSeq += 1\n        const runSeq = state.runSeq\n        const runId = makeRunId(runtime.instanceId, program.programId, runSeq)\n        return {\n          runSeq,\n          runId,\n          canWriteBack: () => state.runSeq === runSeq,\n        }\n      }\n\n      state.runSeq += 1\n      const runSeq = state.runSeq\n      const runId = makeRunId(runtime.instanceId, program.programId, runSeq)\n      return {\n        runSeq,\n        runId,\n        canWriteBack: () => true,\n      }\n    }\n\n    if (state.mode === 'exhaust') {\n      if (state.busy) {\n        if (diagnostics !== 'off') {\n          const observe = shouldObserveForRun(diagnostics, state.runSeq)\n          const tickSeq = observe ? (yield* TickSchedulerTag).getTickSeq() : undefined\n          yield* runBoundary({\n            kind: 'flow',\n            name: 'workflow.drop',\n            payload: { programId: program.programId, trigger: args.trigger },\n            meta: {\n              moduleId: runtime.moduleId,\n              instanceId: runtime.instanceId,\n              programId: program.programId,\n              ...(tickSeq !== undefined ? { tickSeq } : null),\n              policy: { disableObservers: !observe },\n              reason: 'exhaust' as const,\n            },\n            effect: Effect.void,\n            middleware: args.middleware,\n          })\n        }\n        return\n      }\n      state.busy = true\n    }\n\n    const { runSeq, runId, canWriteBack } = beginRun()\n\n    if (state.mode === 'latest') {\n      const prev = state.current\n      const prevRunId = state.currentRunId\n      if (prev) {\n        yield* Fiber.interruptFork(prev)\n        if (diagnostics !== 'off') {\n          const observe = shouldObserveForRun(diagnostics, runSeq)\n          const tickSeq = observe ? (yield* TickSchedulerTag).getTickSeq() : undefined\n          yield* runBoundary({\n            kind: 'flow',\n            name: 'workflow.cancel',\n            payload: { programId: program.programId, cancelled: prevRunId, by: runId },\n            meta: {\n              moduleId: runtime.moduleId,\n              instanceId: runtime.instanceId,\n              programId: program.programId,\n              ...(tickSeq !== undefined ? { tickSeq } : null),\n              policy: { disableObservers: !observe },\n              reason: 'latest' as const,\n              cancelledByRunId: runId,\n              cancelledRunId: prevRunId,\n            },\n            effect: Effect.void,\n            middleware: args.middleware,\n          })\n        }\n      }\n      state.currentRunId = runId\n    }\n\n    const observe = shouldObserveForRun(diagnostics, runSeq)\n    const policy = { disableObservers: !observe } satisfies NonNullable<EffectOp.EffectOp['meta']>['policy']\n\n    const programEffect = Effect.gen(function* () {\n      const host = yield* HostSchedulerTag\n      const tick = yield* TickSchedulerTag\n\n      if (!program.steps) {\n        const env = yield* Effect.context<unknown>()\n        const portCache = new Map<string, ServicePort>()\n        const resolvePort = (serviceId: string, stepKey: string): ServicePort => {\n          const cached = portCache.get(serviceId)\n          if (cached) return cached\n          const resolved = resolveServicePort(runtime, env, serviceId, program.programId, stepKey)\n          portCache.set(serviceId, resolved)\n          return resolved\n        }\n        program.steps = compileSteps(program.compiledSteps, resolvePort)\n      }\n\n      const getTickSeq = (): number | undefined => (observe ? tick.getTickSeq() : undefined)\n      const emitTimerEvents = observe && diagnostics === 'full'\n\n      const evalPayload = (expr: CompiledInputExpr | undefined): unknown => (expr ? evalInputExpr(expr, args.payload) : undefined)\n\n      const defaultInputForCall = (): unknown =>\n        args.trigger.kind === 'action' ? args.payload : undefined\n\n      let timerTriggered = false\n\n      const runSteps = (steps: ReadonlyArray<CompiledRuntimeStep>): Effect.Effect<void, never, unknown> =>\n        Effect.gen(function* () {\n          for (const step of steps) {\n            if (!canWriteBack()) return\n\n            if (step.kind === 'dispatch') {\n              const payload = evalPayload(step.payload)\n              const action = { _tag: step.actionTag, payload }\n              const tickSeq = getTickSeq()\n\n              const dispatchEffectBase =\n                program.priority === 'nonUrgent' ? runtime.dispatchLowPriority(action) : runtime.dispatch(action)\n\n              const dispatchEffect = timerTriggered\n                ? Effect.locally(\n                    currentTxnOriginOverride,\n                    {\n                      kind: 'workflow.timer',\n                      name: `timer:${program.programId}:${step.key}`,\n                    },\n                  )(dispatchEffectBase)\n                : dispatchEffectBase\n\n              yield* runBoundary({\n                kind: 'flow',\n                name: 'workflow.dispatch',\n                payload: { actionTag: step.actionTag },\n                meta: {\n                  moduleId: runtime.moduleId,\n                  instanceId: runtime.instanceId,\n                  programId: program.programId,\n                  runId,\n                  stepKey: step.key,\n                  ...(tickSeq !== undefined ? { tickSeq } : null),\n                  policy,\n                },\n                effect: dispatchEffect,\n                middleware: args.middleware,\n              }).pipe(Effect.asVoid)\n              continue\n            }\n\n            if (step.kind === 'delay') {\n              const timerId = emitTimerEvents ? `${runId}::timer:${step.key}` : undefined\n\n              const recordTimerEvent = (name: string, patchMeta?: Record<string, unknown>) =>\n                Effect.gen(function* () {\n                  const tickSeq = getTickSeq()\n                  yield* runBoundary({\n                    kind: 'flow',\n                    name,\n                    payload: { ms: step.ms },\n                    meta: {\n                      moduleId: runtime.moduleId,\n                      instanceId: runtime.instanceId,\n                      programId: program.programId,\n                      runId,\n                      stepKey: step.key,\n                      ...(timerId ? { timerId } : null),\n                      ...(tickSeq !== undefined ? { tickSeq } : null),\n                      policy,\n                      ...(patchMeta ?? null),\n                    },\n                    effect: Effect.void,\n                    middleware: args.middleware,\n                  })\n                })\n\n              const schedule = emitTimerEvents ? recordTimerEvent('workflow.timer.schedule') : Effect.void\n              const onCancel = emitTimerEvents ? recordTimerEvent('workflow.timer.cancel', { reason: 'interrupt' }) : Effect.void\n              const fired = emitTimerEvents ? recordTimerEvent('workflow.timer.fired') : Effect.void\n\n              const delayEffect = schedule.pipe(\n                Effect.zipRight(makeTimer({ host, ms: step.ms, onCancel })),\n                Effect.zipRight(fired),\n              )\n\n              const tickSeq = getTickSeq()\n\n              yield* runBoundary({\n                kind: 'flow',\n                name: 'workflow.delay',\n                payload: { ms: step.ms },\n                meta: {\n                  moduleId: runtime.moduleId,\n                  instanceId: runtime.instanceId,\n                  programId: program.programId,\n                  runId,\n                  stepKey: step.key,\n                  ...(tickSeq !== undefined ? { tickSeq } : null),\n                  ...(timerId ? { timerId } : null),\n                  policy,\n                },\n                effect: delayEffect,\n                middleware: args.middleware,\n              }).pipe(Effect.asVoid)\n\n              timerTriggered = true\n              continue\n            }\n\n            // call\n            const input = step.input ? evalInputExpr(step.input, args.payload) : defaultInputForCall()\n            const maxRetries = step.retryTimes ?? 0\n            // Attempt id is 1-based and stable within a run.\n            let exit: Exit.Exit<unknown, unknown> | undefined\n            for (let attempt = 1; attempt <= maxRetries + 1; attempt += 1) {\n              const tickSeq = getTickSeq()\n\n              const base = runBoundary({\n                kind: 'service',\n                name: `workflow.call:${step.serviceId}`,\n                payload: { serviceId: step.serviceId },\n                meta: {\n                  moduleId: runtime.moduleId,\n                  instanceId: runtime.instanceId,\n                  programId: program.programId,\n                  runId,\n                  stepKey: step.key,\n                  serviceId: step.serviceId,\n                  attempt,\n                  ...(tickSeq !== undefined ? { tickSeq } : null),\n                  policy,\n                },\n                effect: step.port(input),\n                middleware: args.middleware,\n              })\n\n              const withTimeout =\n                step.timeoutMs === undefined\n                  ? base\n                  : Effect.gen(function* () {\n                      const timeoutMs = step.timeoutMs\n                      if (timeoutMs === undefined) {\n                        // Defensive: TS doesn't keep narrowing across generator boundaries.\n                        return yield* base\n                      }\n\n                      // Unique per attempt (otherwise retries would reuse the same timerId and break explainability).\n                      const timerId = emitTimerEvents ? `${runId}::timeout:${step.key}:a${attempt}` : undefined\n\n                      const recordTimeoutEvent = (name: string, patchMeta?: Record<string, unknown>) =>\n                        Effect.gen(function* () {\n                          const tickSeq = getTickSeq()\n                          yield* runBoundary({\n                            kind: 'flow',\n                            name,\n                            payload: { ms: timeoutMs },\n                            meta: {\n                              moduleId: runtime.moduleId,\n                              instanceId: runtime.instanceId,\n                              programId: program.programId,\n                              runId,\n                              stepKey: step.key,\n                              attempt,\n                              ...(timerId ? { timerId } : null),\n                              ...(tickSeq !== undefined ? { tickSeq } : null),\n                              policy,\n                              ...(patchMeta ?? null),\n                            },\n                            effect: Effect.void,\n                            middleware: args.middleware,\n                          })\n                        })\n\n                      const schedule = emitTimerEvents ? recordTimeoutEvent('workflow.timeout.schedule') : Effect.void\n                      const onCancel = emitTimerEvents\n                        ? recordTimeoutEvent('workflow.timeout.cancel', { reason: 'interrupt' })\n                        : Effect.void\n                      const fired = emitTimerEvents ? recordTimeoutEvent('workflow.timeout.fired') : Effect.void\n\n                      const timeoutError = makeWorkflowError({\n                        code: 'WORKFLOW_CALL_TIMEOUT',\n                        message: `Workflow call timed out (serviceId=\"${step.serviceId}\", timeoutMs=${timeoutMs}).`,\n                        programId: program.programId,\n                        source: { stepKey: step.key },\n                        detail: { serviceId: step.serviceId, timeoutMs, attempt },\n                      })\n\n                      const timeoutFail = schedule.pipe(\n                        Effect.zipRight(makeTimer({ host, ms: timeoutMs, onCancel })),\n                        Effect.zipRight(fired),\n                        Effect.zipRight(Effect.fail(timeoutError)),\n                      )\n\n                      return yield* Effect.raceFirst(base, timeoutFail)\n                    })\n\n              const attemptExit = yield* Effect.exit(withTimeout)\n              exit = attemptExit\n\n              if (!canWriteBack() || Exit.isSuccess(attemptExit)) {\n                break\n              }\n\n              // Do not retry defects/interrupts; only retry failure-channel errors.\n              if (Cause.isInterrupted(attemptExit.cause) || Option.isNone(Cause.failureOption(attemptExit.cause))) {\n                break\n              }\n\n              // Retry if we still have remaining attempts.\n              if (attempt < maxRetries + 1) {\n                continue\n              }\n\n              break\n            }\n\n            // Defensive: attempt loop always runs at least once.\n            if (!exit) {\n              exit = Exit.succeed(undefined) as Exit.Exit<unknown, unknown>\n            }\n\n            if (!canWriteBack()) return\n\n            if (Exit.isSuccess(exit)) {\n              yield* runSteps(step.onSuccess)\n            } else {\n              // Timeout uses a timer; mark the continuation as timer-triggered (for trace:tick.triggerSummary).\n              const failure = Option.getOrUndefined(Cause.failureOption(exit.cause))\n              const isTimeout =\n                isObjectLike(failure) &&\n                (failure as Record<string, unknown>)._tag === 'WorkflowError' &&\n                (failure as Record<string, unknown>).code === 'WORKFLOW_CALL_TIMEOUT'\n              if (isTimeout) timerTriggered = true\n              yield* runSteps(step.onFailure)\n            }\n          }\n        })\n\n      const runTickSeq = getTickSeq()\n      yield* runBoundary({\n        kind: 'flow',\n        name: 'workflow.run',\n        payload: { trigger: args.trigger },\n        meta: {\n          moduleId: runtime.moduleId,\n          instanceId: runtime.instanceId,\n          programId: program.programId,\n          runId,\n          ...(runTickSeq !== undefined ? { tickSeq: runTickSeq } : null),\n          policy,\n        },\n        effect: runSteps(program.steps!),\n        middleware: args.middleware,\n      }).pipe(Effect.asVoid)\n    })\n\n    const limited = registry.parallelLimiter ? registry.parallelLimiter.withPermits(1)(programEffect) : programEffect\n\n    const fiber = yield* Effect.forkScoped(\n      limited.pipe(\n        Effect.catchAllCause((cause) => {\n          const { errorSummary, downgrade } = toSerializableErrorSummary(cause)\n          const downgradeHint = downgrade ? ` (downgrade=${downgrade})` : ''\n          return Debug.record({\n            type: 'diagnostic',\n            moduleId: runtime.moduleId,\n            instanceId: runtime.instanceId,\n            code: 'workflow::run_crashed',\n            severity: 'error',\n            message: `Workflow run crashed for programId=\"${program.programId}\" runId=\"${runId}\".${downgradeHint}`,\n            hint: `${errorSummary.name ? `${errorSummary.name}: ` : ''}${errorSummary.message}`,\n            actionTag: args.trigger.kind === 'action' ? args.trigger.actionTag : undefined,\n            kind: 'workflow_run_crashed',\n            trigger: {\n              kind: 'workflow',\n              name: 'run',\n              details: {\n                programId: program.programId,\n                runId,\n                trigger: args.trigger,\n              },\n            },\n          }).pipe(Effect.catchAllCause(() => Effect.void))\n        }),\n        Effect.ensuring(\n          Effect.sync(() => {\n            if (state.mode === 'exhaust') {\n              state.busy = false\n            }\n          }),\n        ),\n      ),\n    )\n\n    if (state.mode === 'latest') {\n      state.current = fiber as Fiber.RuntimeFiber<void, never>\n    }\n  })\n\ntype RegistryInit = {\n  readonly moduleId: string\n  readonly instanceId: string\n  readonly registry: WorkflowRegistryV1\n}\n\nconst ensureRegistry = (runtime: PublicModuleRuntime<unknown, unknown>) =>\n  Effect.gen(function* () {\n    const existing = getRegistry(runtime)\n    if (existing) {\n      return {\n        moduleId: runtime.moduleId,\n        instanceId: runtime.instanceId,\n        registry: existing,\n      }\n    }\n\n    const portsReady = yield* Deferred.make<void, unknown>()\n\n    const next: WorkflowRegistryV1 = {\n      byActionTag: new Map(),\n      entries: [],\n      watcherStarted: false,\n      watcherStartCount: 0,\n      portsResolving: false,\n      portsReady,\n      parallelLimiter: undefined,\n    }\n\n    Object.defineProperty(runtime, WORKFLOW_REGISTRY, {\n      value: next,\n      enumerable: false,\n      configurable: true,\n      writable: false,\n    })\n\n    return { moduleId: runtime.moduleId, instanceId: runtime.instanceId, registry: next }\n  })\n\nconst registerPrograms = (args: {\n  readonly moduleTag: ModuleTag\n  readonly programs: ReadonlyArray<WorkflowLike>\n  readonly entryLabel: string\n}): Effect.Effect<void, never, unknown> =>\n  Effect.gen(function* () {\n    const runtime = yield* args.moduleTag\n    const { moduleId, instanceId, registry } = yield* ensureRegistry(runtime)\n\n    // Lazily resolve the global parallel limiter once.\n    if (registry.parallelLimiter === undefined) {\n      yield* ensureLimiterReady(registry, runtime)\n    }\n\n    const validateNoIoStepsForOnInit = (steps: ReadonlyArray<CompiledWorkflowStep>, programId: string): void => {\n      const visit = (step: CompiledWorkflowStep): void => {\n        if (step.kind === 'call' || step.kind === 'delay') {\n          throw makeWorkflowError({\n            code: 'WORKFLOW_INVALID_TRIGGER',\n            message: 'Lifecycle onInit programs must not include call/delay (initRequired must stay sync-only; use onStart for IO/time).',\n            programId,\n            source: { stepKey: step.key },\n            detail: { kind: step.kind },\n          })\n        }\n      }\n      for (const s of steps) visit(s)\n    }\n\n    const programHasCall = (steps: ReadonlyArray<CompiledWorkflowStep>): boolean =>\n      steps.some((s) => s.kind === 'call')\n\n    const insertEntry = (actionTag: string, entry: ProgramEntry): void => {\n      const prev = registry.byActionTag.get(actionTag)\n      registry.byActionTag.set(actionTag, prev ? [...prev, entry] : [entry])\n    }\n\n    const internals = getRuntimeInternals(runtime)\n\n    for (const program of args.programs) {\n      const def = program.def\n      const localId = asNonEmptyString(def.localId)\n      if (!localId) {\n        throw makeWorkflowError({\n          code: 'WORKFLOW_INVALID_DEF',\n          message: 'Workflow.install: def.localId must be a non-empty string.',\n          detail: { localId: def.localId },\n        })\n      }\n\n      const programId = `${moduleId}.${localId}`\n      const compiled = compileWorkflowRuntimeStepsV1({ def })\n\n      if (def.trigger.kind === 'lifecycle' && def.trigger.phase === 'onInit') {\n        validateNoIoStepsForOnInit(compiled, programId)\n      }\n\n      const compiledProgram: CompiledProgram = {\n        programId,\n        localId,\n        trigger: def.trigger,\n        concurrency: resolveConcurrency(def),\n        priority: resolvePriority(def),\n        compiledSteps: compiled,\n      }\n\n      if (!programHasCall(compiled)) {\n        compiledProgram.steps = compileSteps(compiled, () => {\n          throw makeWorkflowError({\n            code: 'WORKFLOW_MISSING_SERVICE',\n            message: 'Internal error: unexpected call step while resolving call-less program.',\n            programId,\n            detail: { programId },\n          })\n        })\n      }\n\n      const state: ProgramState =\n        compiledProgram.concurrency === 'latest'\n          ? { mode: 'latest', runSeq: 0, current: undefined, currentRunId: undefined }\n          : compiledProgram.concurrency === 'exhaust'\n            ? { mode: 'exhaust', runSeq: 0, busy: false }\n            : { mode: 'parallel', runSeq: 0 }\n\n      const entry: ProgramEntry = { program: compiledProgram, state }\n      registry.entries.push(entry)\n\n      if (def.trigger.kind === 'action') {\n        insertEntry(def.trigger.actionTag, entry)\n      } else {\n        if (def.trigger.phase === 'onStart') {\n          internals.lifecycle.registerStart(\n            withRootEnvIfAvailable(\n              Effect.gen(function* () {\n                const middlewareOpt = yield* Effect.serviceOption(EffectOpCore.EffectOpMiddlewareTag)\n                const middleware = Option.isSome(middlewareOpt) ? middlewareOpt.value : undefined\n                yield* ensurePortsResolved(registry, runtime).pipe(Effect.orDie)\n                yield* startProgramRun({\n                  entry,\n                  runtime,\n                  registry,\n                  trigger: { kind: 'lifecycle', phase: 'onStart' },\n                  payload: undefined,\n                  middleware,\n                })\n              }),\n            ),\n            { name: `workflow:${localId}` },\n          )\n        } else {\n          internals.lifecycle.registerInitRequired(\n            Effect.gen(function* () {\n              const middlewareOpt = yield* Effect.serviceOption(EffectOpCore.EffectOpMiddlewareTag)\n              const middleware = Option.isSome(middlewareOpt) ? middlewareOpt.value : undefined\n              yield* startProgramRun({\n                entry,\n                runtime,\n                registry,\n                trigger: { kind: 'lifecycle', phase: 'onInit' },\n                payload: undefined,\n                middleware,\n              })\n            }),\n            { name: `workflow:${localId}` },\n          )\n        }\n      }\n    }\n\n    void instanceId\n  })\n\nconst startWatcherIfNeeded = (args: {\n  readonly moduleTag: ModuleTag\n  readonly entryLabel: string\n}): Effect.Effect<void, never, unknown> =>\n  Effect.gen(function* () {\n    const runtime = yield* args.moduleTag\n    const init = yield* ensureRegistry(runtime)\n    const registry = init.registry\n\n    if (registry.watcherStarted) {\n      return\n    }\n\n    registry.watcherStarted = true\n    registry.watcherStartCount += 1\n\n    const middlewareOpt = yield* Effect.serviceOption(EffectOpCore.EffectOpMiddlewareTag)\n    const middleware = Option.isSome(middlewareOpt) ? middlewareOpt.value : undefined\n\n    const actions$ = runtime.actions$ as Stream.Stream<unknown>\n\n    const portsExit = yield* Effect.exit(ensurePortsResolved(registry, runtime))\n    if (Exit.isFailure(portsExit)) {\n      const { errorSummary, downgrade } = toSerializableErrorSummary(portsExit.cause)\n      const downgradeHint = downgrade ? ` (downgrade=${downgrade})` : ''\n      yield* Debug.record({\n        type: 'diagnostic',\n        moduleId: runtime.moduleId,\n        instanceId: runtime.instanceId,\n        code: 'workflow::ports_resolution_failed',\n        severity: 'error',\n        message: `Workflow ports resolution failed before starting watcher.${downgradeHint}`,\n        hint: `${errorSummary.name ? `${errorSummary.name}: ` : ''}${errorSummary.message}`,\n        kind: 'workflow_ports_resolution_failed',\n        trigger: {\n          kind: 'workflow',\n          name: 'portsResolution',\n          details: {\n            entryLabel: args.entryLabel,\n          },\n        },\n      })\n      return\n    }\n\n    yield* Stream.runForEach(actions$, (action) =>\n      Effect.gen(function* () {\n        const actionTag = resolveActionTag(action)\n        if (!actionTag) return\n\n        const entries = registry.byActionTag.get(actionTag)\n        if (!entries || entries.length === 0) return\n\n        const payload = isRecord(action) ? action.payload : undefined\n\n        yield* Effect.forEach(\n          entries,\n          (entry) =>\n            startProgramRun({\n              entry,\n              runtime,\n              registry,\n              trigger: { kind: 'action', actionTag },\n              payload,\n              middleware,\n            }),\n          { discard: true },\n        )\n      }),\n    ).pipe(\n      Effect.catchAllCause((cause) => {\n        const { errorSummary, downgrade } = toSerializableErrorSummary(cause)\n        const downgradeHint = downgrade ? ` (downgrade=${downgrade})` : ''\n        return Debug.record({\n          type: 'diagnostic',\n          moduleId: runtime.moduleId,\n          instanceId: runtime.instanceId,\n          code: 'workflow::watcher_crashed',\n          severity: 'error',\n          message: `Workflow watcher crashed.${downgradeHint}`,\n          hint: `${errorSummary.name ? `${errorSummary.name}: ` : ''}${errorSummary.message}`,\n          kind: 'workflow_watcher_crashed',\n          trigger: {\n            kind: 'workflow',\n            name: 'watcher',\n            details: {\n              entryLabel: args.entryLabel,\n            },\n          },\n        })\n      }),\n    )\n\n    void args.entryLabel\n  })\n\nexport const mountAll = (args: {\n  readonly moduleTag: ModuleTag\n  readonly programs: ReadonlyArray<WorkflowLike>\n}): LogicPlan<AnyModuleShape, unknown, never> => {\n  const plan = {\n    setup: registerPrograms({ moduleTag: args.moduleTag, programs: args.programs, entryLabel: 'mountAll' }),\n    run: startWatcherIfNeeded({ moduleTag: args.moduleTag, entryLabel: 'mountAll' }),\n  } satisfies LogicPlan<AnyModuleShape, unknown, never>\n\n  LogicUnitMeta.attachLogicUnitMeta(plan, {\n    id: '__logix_internal:workflows',\n    kind: 'internal',\n    name: 'workflows',\n  })\n\n  return plan\n}\n\nexport const installOne = (args: {\n  readonly moduleTag: ModuleTag\n  readonly program: WorkflowLike\n}): LogicPlan<AnyModuleShape, unknown, never> => {\n  const localId = asNonEmptyString(args.program.def.localId) ?? 'unknown'\n  const plan = {\n    setup: registerPrograms({ moduleTag: args.moduleTag, programs: [args.program], entryLabel: `install:${localId}` }),\n    run: startWatcherIfNeeded({ moduleTag: args.moduleTag, entryLabel: `install:${localId}` }),\n  } satisfies LogicPlan<AnyModuleShape, unknown, never>\n\n  LogicUnitMeta.attachLogicUnitMeta(plan, {\n    id: `workflow:${localId}`,\n    kind: 'workflow',\n    name: localId,\n  })\n\n  return plan\n}\n\n// test-only probe: whether a watcher has started (for single-subscription gates).\nexport const __unsafeGetWatcherStartCount = (runtime: unknown): number => {\n  if (!runtime || typeof runtime !== 'object') return 0\n  const reg = getRegistry(runtime)\n  return reg ? reg.watcherStartCount : 0\n}\n"],
  "mappings": "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",
  "names": ["runSeq", "runId", "observe", "tickSeq"]
}
