@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.
- package/LICENSE +201 -0
- package/package.json +3 -1
- package/public/sandbox/chunks/chunk-2AUQRESB.js +1114 -0
- package/public/sandbox/chunks/chunk-2F72LQKW.js +194 -0
- package/public/sandbox/chunks/chunk-2PYDGDD3.js +4071 -0
- package/public/sandbox/chunks/chunk-2UGKSXDZ.js +16 -0
- package/public/sandbox/chunks/chunk-2XVE7F26.js +153 -0
- package/public/sandbox/chunks/chunk-3A7TFNZN.js +219 -0
- package/public/sandbox/chunks/chunk-3BHC6JAV.js +1070 -0
- package/public/sandbox/chunks/chunk-3U4CAKCX.js +61 -0
- package/public/sandbox/chunks/chunk-3VU3JLZO.js +272 -0
- package/public/sandbox/chunks/chunk-4CPONKWY.js +1170 -0
- package/public/sandbox/chunks/chunk-4GMUQTWH.js +850 -0
- package/public/sandbox/chunks/chunk-4KIYG5E4.js +749 -0
- package/public/sandbox/chunks/chunk-4MY35XR3.js +175 -0
- package/public/sandbox/chunks/chunk-5DNHJMHA.js +69 -0
- package/public/sandbox/chunks/chunk-5EC4S7X6.js +42 -0
- package/public/sandbox/chunks/chunk-5FB7QFSH.js +227 -0
- package/public/sandbox/chunks/chunk-5GEYCJW2.js +206 -0
- package/public/sandbox/chunks/chunk-5PT7Q5SS.js +373 -0
- package/public/sandbox/chunks/chunk-5WN5IGKA.js +166 -0
- package/public/sandbox/chunks/chunk-5XOBKSOT.js +213 -0
- package/public/sandbox/chunks/chunk-67RVISUC.js +313 -0
- package/public/sandbox/chunks/chunk-6ELJEKZS.js +12 -0
- package/public/sandbox/chunks/chunk-6FKWRVP4.js +85 -0
- package/public/sandbox/chunks/chunk-6JRP52YT.js +34 -0
- package/public/sandbox/chunks/chunk-6JYAC3G6.js +42 -0
- package/public/sandbox/chunks/chunk-6TUOP63Q.js +86 -0
- package/public/sandbox/chunks/{chunk-A6JFUNQQ.js → chunk-74C5VW7Z.js} +2 -2
- package/public/sandbox/chunks/chunk-75DQFC5M.js +16 -0
- package/public/sandbox/chunks/{chunk-UCFEP3BH.js → chunk-7GPAF2UK.js} +1 -1
- package/public/sandbox/chunks/chunk-7KQFTS2Y.js +135 -0
- package/public/sandbox/chunks/chunk-7POKWYE3.js +112 -0
- package/public/sandbox/chunks/chunk-7VUEF5F3.js +395 -0
- package/public/sandbox/chunks/chunk-7W5APZS2.js +77 -0
- package/public/sandbox/chunks/chunk-A6OFCXDQ.js +397 -0
- package/public/sandbox/chunks/chunk-A7HLOSO6.js +216 -0
- package/public/sandbox/chunks/chunk-AGF4RRCB.js +408 -0
- package/public/sandbox/chunks/chunk-ASJSJAAL.js +122 -0
- package/public/sandbox/chunks/chunk-ASVMK364.js +283 -0
- package/public/sandbox/chunks/chunk-AUDTI2BQ.js +895 -0
- package/public/sandbox/chunks/chunk-B2SZTA3M.js +16 -0
- package/public/sandbox/chunks/chunk-B6YS2UMV.js +372 -0
- package/public/sandbox/chunks/chunk-BCEO3MGD.js +244 -0
- package/public/sandbox/chunks/chunk-BCOO65D4.js +373 -0
- package/public/sandbox/chunks/chunk-BJOWSSEL.js +38 -0
- package/public/sandbox/chunks/chunk-BS2WBFW4.js +373 -0
- package/public/sandbox/chunks/chunk-BUVHG3NJ.js +439 -0
- package/public/sandbox/chunks/chunk-BVE33AN6.js +42 -0
- package/public/sandbox/chunks/chunk-BWTGJZVP.js +19 -0
- package/public/sandbox/chunks/chunk-BXD7GZC3.js +1025 -0
- package/public/sandbox/chunks/chunk-BZH4EUUD.js +164 -0
- package/public/sandbox/chunks/{chunk-HFV5GJPK.js → chunk-C2MYMMO4.js} +3 -3
- package/public/sandbox/chunks/chunk-CRE4NJJ6.js +271 -0
- package/public/sandbox/chunks/chunk-CVZPRIDB.js +706 -0
- package/public/sandbox/chunks/chunk-CWOXD5NG.js +991 -0
- package/public/sandbox/chunks/chunk-D6DOC3BJ.js +373 -0
- package/public/sandbox/chunks/chunk-DEPSGFSY.js +1698 -0
- package/public/sandbox/chunks/chunk-DM7C5NP5.js +819 -0
- package/public/sandbox/chunks/chunk-DN33LMOF.js +1112 -0
- package/public/sandbox/chunks/{chunk-S46P7MC6.js → chunk-DT7YIIWE.js} +2 -2
- package/public/sandbox/chunks/chunk-DVB5WRCI.js +260 -0
- package/public/sandbox/chunks/{chunk-TOHCFMQS.js → chunk-E3EVW7NR.js} +11 -18
- package/public/sandbox/chunks/chunk-E5BV567Q.js +417 -0
- package/public/sandbox/chunks/chunk-E7BIWMQQ.js +203 -0
- package/public/sandbox/chunks/chunk-EAKGPSOQ.js +83 -0
- package/public/sandbox/chunks/chunk-EGUYL2ER.js +75 -0
- package/public/sandbox/chunks/chunk-EP5GQYZ5.js +85 -0
- package/public/sandbox/chunks/chunk-ET6CJEHC.js +221 -0
- package/public/sandbox/chunks/chunk-EU67YZHZ.js +1070 -0
- package/public/sandbox/chunks/{chunk-PTSJJANP.js → chunk-EYNDQLSB.js} +1 -1
- package/public/sandbox/chunks/{chunk-CEGSWZ5S.js → chunk-EZTMVCJF.js} +1 -1
- package/public/sandbox/chunks/chunk-F5CLVIS6.js +907 -0
- package/public/sandbox/chunks/chunk-F743SKYD.js +85 -0
- package/public/sandbox/chunks/chunk-FEGFZ5OX.js +86 -0
- package/public/sandbox/chunks/chunk-FG5B7ZX3.js +373 -0
- package/public/sandbox/chunks/chunk-FKZPYMDG.js +373 -0
- package/public/sandbox/chunks/chunk-FNLXHWIU.js +220 -0
- package/public/sandbox/chunks/chunk-FQRUTYAD.js +1991 -0
- package/public/sandbox/chunks/{chunk-VLYP4WUS.js → chunk-FY5A73NK.js} +5 -5
- package/public/sandbox/chunks/chunk-G7FAOG3O.js +221 -0
- package/public/sandbox/chunks/chunk-GFXHUC7Y.js +73 -0
- package/public/sandbox/chunks/chunk-GIPXUIZQ.js +534 -0
- package/public/sandbox/chunks/chunk-GP37MEGJ.js +52 -0
- package/public/sandbox/chunks/chunk-GXL5QCMF.js +4511 -0
- package/public/sandbox/chunks/chunk-GZ2NSE6A.js +177 -0
- package/public/sandbox/chunks/chunk-GZATW4YD.js +69 -0
- package/public/sandbox/chunks/chunk-H4EBXROQ.js +166 -0
- package/public/sandbox/chunks/chunk-HETCPK6Z.js +153 -0
- package/public/sandbox/chunks/chunk-HGUFQ2QC.js +4431 -0
- package/public/sandbox/chunks/chunk-HGV3VNH3.js +255 -0
- package/public/sandbox/chunks/chunk-HIJ67QWR.js +5397 -0
- package/public/sandbox/chunks/chunk-IDHERBKW.js +1114 -0
- package/public/sandbox/chunks/chunk-IDTK4FIY.js +102 -0
- package/public/sandbox/chunks/chunk-ILFVY7H5.js +164 -0
- package/public/sandbox/chunks/chunk-ISGSRYGO.js +57 -0
- package/public/sandbox/chunks/chunk-J45VPU24.js +408 -0
- package/public/sandbox/chunks/chunk-JAUIM3O5.js +42 -0
- package/public/sandbox/chunks/chunk-JB7OQEM6.js +373 -0
- package/public/sandbox/chunks/chunk-JCKW6NHD.js +15 -0
- package/public/sandbox/chunks/chunk-JMA7GY7Z.js +221 -0
- package/public/sandbox/chunks/chunk-JY46J6IL.js +836 -0
- package/public/sandbox/chunks/{chunk-X72PZOFA.js → chunk-K2MQ66O7.js} +1 -1
- package/public/sandbox/chunks/chunk-KA7PZA6F.js +464 -0
- package/public/sandbox/chunks/chunk-KDEQTUID.js +102 -0
- package/public/sandbox/chunks/chunk-KDJR27JV.js +1696 -0
- package/public/sandbox/chunks/chunk-KFE3JO6N.js +77 -0
- package/public/sandbox/chunks/chunk-KLDSYWT5.js +536 -0
- package/public/sandbox/chunks/chunk-KQWWFYBF.js +203 -0
- package/public/sandbox/chunks/chunk-KTFZSXOW.js +6473 -0
- package/public/sandbox/chunks/chunk-KXVIC55U.js +108 -0
- package/public/sandbox/chunks/{chunk-HNEDTEGQ.js → chunk-L4PNO2H6.js} +1 -1
- package/public/sandbox/chunks/{chunk-WE4STGO2.js → chunk-L4ZNW5DI.js} +2 -2
- package/public/sandbox/chunks/chunk-LBUINGZ4.js +836 -0
- package/public/sandbox/chunks/chunk-LIYPPU6I.js +112 -0
- package/public/sandbox/chunks/chunk-LJHTOJXW.js +221 -0
- package/public/sandbox/chunks/{chunk-BWSNPKO5.js → chunk-LQL23SWJ.js} +2 -2
- package/public/sandbox/chunks/chunk-LTFCYZQ6.js +46 -0
- package/public/sandbox/chunks/chunk-LTWLVCKQ.js +166 -0
- package/public/sandbox/chunks/chunk-LWI7BXFN.js +395 -0
- package/public/sandbox/chunks/chunk-LYBBX6WM.js +225 -0
- package/public/sandbox/chunks/chunk-MXE7HIBM.js +474 -0
- package/public/sandbox/chunks/chunk-MYBDYNK4.js +6004 -0
- package/public/sandbox/chunks/chunk-NC2MIWZX.js +732 -0
- package/public/sandbox/chunks/chunk-NE447XAF.js +597 -0
- package/public/sandbox/chunks/chunk-NEAYV5C2.js +255 -0
- package/public/sandbox/chunks/chunk-NMGFJZ4I.js +26 -0
- package/public/sandbox/chunks/chunk-NWCJJZNQ.js +71 -0
- package/public/sandbox/chunks/chunk-O57OZBDR.js +214 -0
- package/public/sandbox/chunks/chunk-OJJT664Q.js +731 -0
- package/public/sandbox/chunks/chunk-OKTBUTCH.js +1175 -0
- package/public/sandbox/chunks/chunk-OQ4SYV5D.js +534 -0
- package/public/sandbox/chunks/chunk-OTVVIHJD.js +219 -0
- package/public/sandbox/chunks/chunk-OWTMSCF7.js +1052 -0
- package/public/sandbox/chunks/chunk-P5ZQNFC3.js +122 -0
- package/public/sandbox/chunks/chunk-PBPT2U2N.js +1698 -0
- package/public/sandbox/chunks/chunk-PHBJLCP3.js +836 -0
- package/public/sandbox/chunks/chunk-PHV4HYHB.js +397 -0
- package/public/sandbox/chunks/chunk-PIXQ6SOX.js +4071 -0
- package/public/sandbox/chunks/chunk-PKJL6YLK.js +73 -0
- package/public/sandbox/chunks/chunk-PKPOITIU.js +221 -0
- package/public/sandbox/chunks/{chunk-NQW73ACJ.js → chunk-PMXBOYQI.js} +1 -1
- package/public/sandbox/chunks/chunk-PQLZD7NR.js +836 -0
- package/public/sandbox/chunks/chunk-QEESVOZU.js +16 -0
- package/public/sandbox/chunks/chunk-QGIM3FQK.js +159 -0
- package/public/sandbox/chunks/chunk-QL5JNEDO.js +69 -0
- package/public/sandbox/chunks/chunk-QQOZ3RMH.js +867 -0
- package/public/sandbox/chunks/chunk-QUMEVT2F.js +194 -0
- package/public/sandbox/chunks/chunk-QVZBXYVY.js +102 -0
- package/public/sandbox/chunks/chunk-R5HQS6RB.js +135 -0
- package/public/sandbox/chunks/chunk-R75Q2CTT.js +900 -0
- package/public/sandbox/chunks/chunk-RBB6SHW2.js +253 -0
- package/public/sandbox/chunks/chunk-RDHNRWQP.js +383 -0
- package/public/sandbox/chunks/chunk-RIWOEI3T.js +1101 -0
- package/public/sandbox/chunks/chunk-RS5FFPUV.js +103 -0
- package/public/sandbox/chunks/chunk-RYSSJBGX.js +203 -0
- package/public/sandbox/chunks/chunk-S3KBAE5Z.js +1114 -0
- package/public/sandbox/chunks/chunk-S6ZZHV6G.js +244 -0
- package/public/sandbox/chunks/chunk-SFXJ24HY.js +499 -0
- package/public/sandbox/chunks/chunk-SH7TP5CJ.js +1109 -0
- package/public/sandbox/chunks/chunk-SI5OKFFY.js +317 -0
- package/public/sandbox/chunks/chunk-SIXNQNIR.js +86 -0
- package/public/sandbox/chunks/chunk-ST353BOX.js +42 -0
- package/public/sandbox/chunks/chunk-SYEHKMLP.js +1140 -0
- package/public/sandbox/chunks/chunk-SZ4KQUJU.js +69 -0
- package/public/sandbox/chunks/{chunk-5SOP6EKV.js → chunk-SZI65PSP.js} +5 -10
- package/public/sandbox/chunks/chunk-T7RLTSMX.js +78 -0
- package/public/sandbox/chunks/chunk-TJ2RLUTW.js +57 -0
- package/public/sandbox/chunks/chunk-TJB73XPN.js +4071 -0
- package/public/sandbox/chunks/chunk-TXJCYO56.js +4046 -0
- package/public/sandbox/chunks/chunk-U5J3LCYI.js +731 -0
- package/public/sandbox/chunks/chunk-UABFN3NH.js +208 -0
- package/public/sandbox/chunks/chunk-UBMUY7WO.js +13 -0
- package/public/sandbox/chunks/chunk-UC27CE32.js +69 -0
- package/public/sandbox/chunks/chunk-UJGVDFZN.js +147 -0
- package/public/sandbox/chunks/chunk-UNVLTK4N.js +122 -0
- package/public/sandbox/chunks/chunk-UQKQ6V3V.js +208 -0
- package/public/sandbox/chunks/chunk-UZZBHWIO.js +703 -0
- package/public/sandbox/chunks/chunk-VKZIJERL.js +1114 -0
- package/public/sandbox/chunks/chunk-VQQEAGID.js +372 -0
- package/public/sandbox/chunks/{chunk-3LX3KIQQ.js → chunk-W365QUZ5.js} +3 -5
- package/public/sandbox/chunks/chunk-WJY2LSWG.js +1052 -0
- package/public/sandbox/chunks/chunk-WNOBN3DX.js +391 -0
- package/public/sandbox/chunks/chunk-X2Z5VYG3.js +245 -0
- package/public/sandbox/chunks/chunk-X74KU74D.js +959 -0
- package/public/sandbox/chunks/chunk-XE7ULSGQ.js +46 -0
- package/public/sandbox/chunks/chunk-XRXUJZ3X.js +431 -0
- package/public/sandbox/chunks/chunk-XWHIN7CC.js +85 -0
- package/public/sandbox/chunks/chunk-Y2TVGGVL.js +527 -0
- package/public/sandbox/chunks/chunk-YMVMZA3U.js +1395 -0
- package/public/sandbox/chunks/chunk-YOBLFWDV.js +431 -0
- package/public/sandbox/chunks/chunk-YR2RFEZA.js +11 -0
- package/public/sandbox/chunks/chunk-YTD6A35P.js +836 -0
- package/public/sandbox/chunks/chunk-Z5L7EZXS.js +81 -0
- package/public/sandbox/chunks/chunk-Z65I5ET2.js +108 -0
- package/public/sandbox/chunks/chunk-Z6LV34RO.js +390 -0
- package/public/sandbox/chunks/chunk-ZAKUP6QG.js +1634 -0
- package/public/sandbox/chunks/chunk-ZHNYE2YH.js +731 -0
- package/public/sandbox/chunks/chunk-ZHQX3B3Y.js +867 -0
- package/public/sandbox/chunks/chunk-ZIXDFRHJ.js +731 -0
- package/public/sandbox/chunks/chunk-ZPZ2MZ4D.js +528 -0
- package/public/sandbox/chunks/chunk-ZQD6NZXB.js +373 -0
- package/public/sandbox/chunks/chunk-ZVVBP7ON.js +16 -0
- package/public/sandbox/chunks/chunk-ZWE3P6X2.js +11 -0
- package/public/sandbox/logix-core/Bound.js +14 -14
- package/public/sandbox/logix-core/Debug.js +12 -10
- package/public/sandbox/logix-core/EffectOp.js +3 -4
- package/public/sandbox/logix-core/Env.js +5 -2
- package/public/sandbox/logix-core/ExternalStore.js +239 -0
- package/public/sandbox/logix-core/Flow.js +7 -8
- package/public/sandbox/logix-core/Kernel.js +7 -4
- package/public/sandbox/logix-core/Link.js +33 -25
- package/public/sandbox/logix-core/Middleware.js +13 -11
- package/public/sandbox/logix-core/Module.js +93 -30
- package/public/sandbox/logix-core/ModuleTag.js +28 -25
- package/public/sandbox/logix-core/Observability.js +21 -19
- package/public/sandbox/logix-core/Process.js +27 -22
- package/public/sandbox/logix-core/ReadQuery.js +7 -11
- package/public/sandbox/logix-core/Reflection.js +173 -53
- package/public/sandbox/logix-core/Resource.js +6 -3
- package/public/sandbox/logix-core/Root.js +7 -3
- package/public/sandbox/logix-core/Runtime.js +54 -40
- package/public/sandbox/logix-core/ScopeRegistry.js +6 -3
- package/public/sandbox/logix-core/StateTrait.js +17 -14
- package/public/sandbox/logix-core/TraitLifecycle.js +8 -8
- package/public/sandbox/logix-core/Workflow.js +332 -0
- package/public/sandbox/logix-core.js +11133 -6622
- package/public/sandbox/logix-core.manifest.json +4 -2
- package/public/sandbox/worker.js +3 -3
- package/public/sandbox/chunks/chunk-4LRLOTMA.js +0 -1698
- package/public/sandbox/chunks/chunk-CDLXJHXY.js +0 -120
- package/public/sandbox/chunks/chunk-CZRI7MHA.js +0 -46
- package/public/sandbox/chunks/chunk-EJDFUZ4B.js +0 -408
- package/public/sandbox/chunks/chunk-IP63FME6.js +0 -282
- package/public/sandbox/chunks/chunk-JIXTOQXJ.js +0 -1103
- package/public/sandbox/chunks/chunk-MPUSOFJ3.js +0 -1928
- package/public/sandbox/chunks/chunk-ON2LY6HJ.js +0 -135
- package/public/sandbox/chunks/chunk-POIBXAH5.js +0 -995
- package/public/sandbox/chunks/chunk-PQ652ULI.js +0 -6359
- package/public/sandbox/chunks/chunk-RJQ4PG2F.js +0 -77
- package/public/sandbox/chunks/chunk-S4EXG3OS.js +0 -533
- package/public/sandbox/chunks/chunk-SUXDGXVE.js +0 -390
- package/public/sandbox/chunks/chunk-TOQ6SJ6O.js +0 -244
- package/public/sandbox/chunks/chunk-UKYAF3NL.js +0 -1036
- package/public/sandbox/chunks/chunk-UMVN3AWO.js +0 -395
- package/public/sandbox/chunks/chunk-WFV5PPWJ.js +0 -194
- package/public/sandbox/chunks/chunk-YF6IO732.js +0 -206
- 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"]
}

|