yaml-flow 8.7.1 → 8.8.5
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/browser/adapters/firebase-storage.js +2 -2
- package/browser/adapters/firestore-storage.js +2 -2
- package/browser/adapters/localstorage-storage.js +3 -3
- package/browser/asset-integrity.json +9 -13
- package/browser/live-cards.js +6 -6
- package/browser/server-runtime-controlface.js +5 -5
- package/examples/ARCHITECTURE.md +0 -27
- package/examples/board/server/board-server.js +150 -100
- package/examples/board/server/board-worker/source_def_flows.json +0 -8
- package/examples/board/server/board-worker/task-executor.js +1 -3
- package/examples/board/server/chat-flow/flow-steps.json +5 -5
- package/examples/board/test/server-http-test.js +726 -87
- package/examples/board-firestore/server/worker.js +8 -0
- package/examples/portfolio-tracker/portfolio-tracker.js +11 -1
- package/examples/portfolio-tracker/test/portfolio-t4.js +12 -2
- package/lib/{artifacts-store-lib-D9nMkVcE.d.cts → artifacts-store-lib-C6qBpMfU.d.cts} +1 -1
- package/lib/{artifacts-store-lib-DSSMqVL2.d.ts → artifacts-store-lib-D4qf7Q-7.d.ts} +1 -1
- package/lib/artifacts-store-public.d.cts +3 -3
- package/lib/artifacts-store-public.d.ts +3 -3
- package/lib/board-live-cards-mcp.cjs +1 -1
- package/lib/board-live-cards-mcp.d.cts +6 -7
- package/lib/board-live-cards-mcp.d.ts +6 -7
- package/lib/board-live-cards-mcp.js +1 -1
- package/lib/board-live-cards-node.cjs +8 -8
- package/lib/board-live-cards-node.d.cts +70 -15
- package/lib/board-live-cards-node.d.ts +70 -15
- package/lib/board-live-cards-node.js +8 -8
- package/lib/{board-live-cards-public-LlVUQPL2.d.cts → board-live-cards-public-BT5HrgqZ.d.cts} +82 -59
- package/lib/{board-live-cards-public-JNRKfBZy.d.ts → board-live-cards-public-DSRamFm8.d.ts} +82 -59
- package/lib/{board-live-cards-public-async-Di9QB141.d.cts → board-live-cards-public-async-CYjr4mgX.d.cts} +18 -8
- package/lib/{board-live-cards-public-async-fwd1QI82.d.ts → board-live-cards-public-async-DlyC3PgC.d.ts} +18 -8
- package/lib/board-live-cards-public.cjs +1 -1
- package/lib/board-live-cards-public.d.cts +2 -2
- package/lib/board-live-cards-public.d.ts +2 -2
- package/lib/board-live-cards-public.js +1 -1
- package/lib/board-live-cards-server-runtime.cjs +1 -1
- package/lib/board-live-cards-server-runtime.d.cts +6 -8
- package/lib/board-live-cards-server-runtime.d.ts +6 -8
- package/lib/board-live-cards-server-runtime.js +1 -1
- package/lib/board-livegraph-runtime/index.cjs +1 -1
- package/lib/board-livegraph-runtime/index.d.cts +1 -0
- package/lib/board-livegraph-runtime/index.d.ts +1 -0
- package/lib/board-livegraph-runtime/index.js +1 -1
- package/lib/{board-platform-adapter-async-BfHmHdx2.d.cts → board-platform-adapter-async-BZIftm36.d.cts} +18 -14
- package/lib/{board-platform-adapter-async-DYahVzIK.d.ts → board-platform-adapter-async-JP9V-U5E.d.ts} +18 -14
- package/lib/board-worker-adapter.cjs +1 -24
- package/lib/board-worker-adapter.d.cts +68 -3
- package/lib/board-worker-adapter.d.ts +68 -3
- package/lib/board-worker-adapter.js +1 -24
- package/lib/card-store-public.d.cts +2 -2
- package/lib/card-store-public.d.ts +2 -2
- package/lib/chat-store-public.cjs +1 -1
- package/lib/chat-store-public.d.cts +20 -20
- package/lib/chat-store-public.d.ts +20 -20
- package/lib/chat-store-public.js +1 -1
- package/lib/chunk-35N7ONTH.js +2 -0
- package/lib/chunk-36QUKFL7.cjs +3 -0
- package/lib/chunk-37HDEW26.cjs +2 -0
- package/lib/{chunk-PMUSJQSR.cjs → chunk-3CZCGNY4.cjs} +2 -2
- package/lib/{chunk-BQS3EIEK.js → chunk-44L64VQ2.js} +3 -3
- package/lib/{chunk-YGKDQLYP.js → chunk-4HIEOBJC.js} +2 -2
- package/lib/chunk-6OPXQPSC.js +2 -0
- package/lib/chunk-7BTZCOT5.js +2 -0
- package/lib/{chunk-U2N6MCD5.cjs → chunk-7JVHYHT2.cjs} +2 -2
- package/lib/chunk-7QQFDYBM.js +3 -0
- package/lib/chunk-7QZ267XP.cjs +2 -0
- package/lib/chunk-ABAVFLDP.js +7 -0
- package/lib/{chunk-XQRNDX4Q.js → chunk-ANKA7HEJ.js} +2 -2
- package/lib/{chunk-KAWQPLIE.cjs → chunk-BQUQTOPB.cjs} +2 -2
- package/lib/chunk-ETW3BXHD.cjs +2 -0
- package/lib/{chunk-SGV7PU4H.js → chunk-FOFGEABN.js} +2 -2
- package/lib/chunk-GPCMBPLK.cjs +2 -0
- package/lib/chunk-H22NK6KH.cjs +7 -0
- package/lib/chunk-H4TYOSMD.cjs +45 -0
- package/lib/chunk-HFW7E2Z7.cjs +4 -0
- package/lib/chunk-J4MHQ7JF.js +45 -0
- package/lib/chunk-MCPADH33.cjs +2 -0
- package/lib/chunk-NBJTYAYN.cjs +2 -0
- package/lib/chunk-NNSBBO5R.js +2 -0
- package/lib/chunk-NU5NO5NM.js +2 -0
- package/lib/chunk-O5UYCGIN.js +2 -0
- package/lib/chunk-O6II7S4M.js +3 -0
- package/lib/chunk-PN5D32NP.cjs +3 -0
- package/lib/chunk-Q3OTUDIE.js +2 -0
- package/lib/chunk-R44X3RQB.cjs +2 -0
- package/lib/chunk-RKKSVOP2.js +2 -0
- package/lib/chunk-UB54HZA4.cjs +2 -0
- package/lib/{chunk-CIAJNUR4.js → chunk-VGDLSS2H.js} +2 -2
- package/lib/{chunk-SFVO2LB2.cjs → chunk-VQCIOKJV.cjs} +3 -3
- package/lib/chunk-VS3BXEYK.js +4 -0
- package/lib/{chunk-S6DRP2HX.cjs → chunk-XQAHHUZO.cjs} +2 -2
- package/lib/chunk-Y4WK7HE4.js +2 -0
- package/lib/chunk-ZENTBLLA.cjs +3 -0
- package/lib/chunk-ZK3E7L4Y.cjs +2 -0
- package/lib/chunk-ZWVT24YW.js +3 -0
- package/lib/cloud-storage.cjs +1 -1
- package/lib/cloud-storage.d.cts +6 -6
- package/lib/cloud-storage.d.ts +6 -6
- package/lib/cloud-storage.js +1 -1
- package/lib/execution-refs.cjs +1 -1
- package/lib/execution-refs.js +1 -1
- package/lib/firebase-storage/index.cjs +2 -2
- package/lib/firebase-storage/index.d.cts +2 -2
- package/lib/firebase-storage/index.d.ts +2 -2
- package/lib/firebase-storage/index.js +2 -2
- package/lib/firestore-storage/index.cjs +2 -2
- package/lib/firestore-storage/index.d.cts +12 -21
- package/lib/firestore-storage/index.d.ts +12 -21
- package/lib/firestore-storage/index.js +2 -2
- package/lib/index.cjs +2 -2
- package/lib/index.d.cts +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.js +1 -1
- package/lib/localstorage-storage/index.cjs +1 -1
- package/lib/localstorage-storage/index.d.cts +10 -6
- package/lib/localstorage-storage/index.d.ts +10 -6
- package/lib/localstorage-storage/index.js +1 -1
- package/lib/{mcp-tool-registries-W3TRj6O5.d.cts → mcp-tool-registries-CRtea2x4.d.cts} +3 -0
- package/lib/{mcp-tool-registries-BBObLYga.d.ts → mcp-tool-registries-D3rWSppt.d.ts} +3 -0
- package/lib/server-jobs-queue-runner/index.cjs +1 -1
- package/lib/server-jobs-queue-runner/index.d.cts +12 -9
- package/lib/server-jobs-queue-runner/index.d.ts +12 -9
- package/lib/server-jobs-queue-runner/index.js +1 -1
- package/lib/server-runtime/index.cjs +1 -1
- package/lib/server-runtime/index.d.cts +7 -9
- package/lib/server-runtime/index.d.ts +7 -9
- package/lib/server-runtime/index.js +1 -1
- package/lib/server-runtime-agentface/index.d.cts +7 -9
- package/lib/server-runtime-agentface/index.d.ts +7 -9
- package/lib/server-runtime-controlface/index.cjs +1 -1
- package/lib/server-runtime-controlface/index.d.cts +8 -9
- package/lib/server-runtime-controlface/index.d.ts +8 -9
- package/lib/server-runtime-controlface/index.js +1 -1
- package/lib/server-runtime-core/index.cjs +1 -1
- package/lib/server-runtime-core/index.d.cts +59 -21
- package/lib/server-runtime-core/index.d.ts +59 -21
- package/lib/server-runtime-core/index.js +1 -1
- package/lib/server-runtime-watchers/index.cjs +1 -1
- package/lib/server-runtime-watchers/index.d.cts +9 -65
- package/lib/server-runtime-watchers/index.d.ts +9 -65
- package/lib/server-runtime-watchers/index.js +1 -1
- package/lib/server-runtime-webhooks/index.d.cts +7 -9
- package/lib/server-runtime-webhooks/index.d.ts +7 -9
- package/lib/sse-hub-BDjWI7JR.d.cts +63 -0
- package/lib/sse-hub-DM8bw-dO.d.ts +63 -0
- package/lib/step-machine-public/index.cjs +1 -1
- package/lib/step-machine-public/index.d.cts +1 -1
- package/lib/step-machine-public/index.d.ts +1 -1
- package/lib/step-machine-public/index.js +1 -1
- package/lib/{storage-async-interface-BRR4eBjx.d.cts → storage-async-interface-CG0bMqvE.d.ts} +20 -1
- package/lib/{storage-async-interface-DhlOVPSp.d.ts → storage-async-interface-CyO-zwVQ.d.cts} +20 -1
- package/lib/{storage-interface-BFiD3kyB.d.ts → storage-interface-D-iEiTJA.d.cts} +45 -1
- package/lib/{storage-interface-BFiD3kyB.d.cts → storage-interface-D-iEiTJA.d.ts} +45 -1
- package/lib/stores/index.d.cts +1 -1
- package/lib/stores/index.d.ts +1 -1
- package/lib/stores/kv.d.cts +1 -1
- package/lib/stores/kv.d.ts +1 -1
- package/lib/{types-SO5OZm4s.d.ts → types-BsfXZyI3.d.ts} +64 -29
- package/lib/{types-Ba8H5_Wo.d.cts → types-CPnYv7RC.d.cts} +64 -29
- package/package.json +4 -5
- package/browser/board-livecards-client.js +0 -2
- package/examples/board/demo-shell-with-server.html +0 -272
- package/examples/board/doc.html +0 -465
- package/examples/board/server-config.json +0 -24
- package/examples/board/test/sse-worker.js +0 -49
- package/lib/chat-storage-lib-B9Q34Dyv.d.cts +0 -54
- package/lib/chat-storage-lib-DB9iSai2.d.ts +0 -54
- package/lib/chunk-5XHOHTLZ.cjs +0 -2
- package/lib/chunk-6APH25VI.js +0 -2
- package/lib/chunk-76C7N4YT.js +0 -3
- package/lib/chunk-76ON3V7R.js +0 -2
- package/lib/chunk-7ICPAABP.cjs +0 -7
- package/lib/chunk-ASR44K7H.cjs +0 -3
- package/lib/chunk-CPAXTVBQ.cjs +0 -2
- package/lib/chunk-EGRHWZRV.js +0 -2
- package/lib/chunk-EZENHAVZ.cjs +0 -2
- package/lib/chunk-GL2OHR2E.cjs +0 -2
- package/lib/chunk-GYQXDNNI.cjs +0 -2
- package/lib/chunk-HEEDJEKM.js +0 -2
- package/lib/chunk-IPLSRN6P.cjs +0 -4
- package/lib/chunk-J6EGN6S4.cjs +0 -3
- package/lib/chunk-JH37NJGP.js +0 -3
- package/lib/chunk-JJL5VOQZ.cjs +0 -3
- package/lib/chunk-NJJ7WEDT.cjs +0 -2
- package/lib/chunk-NKIQRCOM.cjs +0 -2
- package/lib/chunk-PBCDDO4V.cjs +0 -2
- package/lib/chunk-PBOQ4HYB.cjs +0 -2
- package/lib/chunk-PRKRXAVN.js +0 -3
- package/lib/chunk-QJVR3FWQ.js +0 -2
- package/lib/chunk-S44QZUDX.js +0 -2
- package/lib/chunk-TSN3RTXT.js +0 -4
- package/lib/chunk-VXJHBWK3.js +0 -2
- package/lib/chunk-WHDEBJLT.js +0 -7
- package/lib/chunk-YGALANRO.js +0 -2
- package/lib/chunk-ZCNN6XPV.js +0 -2
|
@@ -1,25 +1,23 @@
|
|
|
1
|
-
import { a as ArtifactsStore } from './artifacts-store-lib-
|
|
2
|
-
export { c as createArtifactsStore, b as createCardFileMetadataStore, d as createFileArtifactsStore } from './artifacts-store-lib-
|
|
3
|
-
import { I as InvocationAdapter } from './types-Ba8H5_Wo.cjs';
|
|
4
|
-
export { D as DescribeEnvelope } from './types-Ba8H5_Wo.cjs';
|
|
5
|
-
import { a as KindValueRef, B as BlobStorage, g as QueueStorage } from './storage-interface-BFiD3kyB.cjs';
|
|
6
|
-
export { p as parseRef, s as serializeRef } from './storage-interface-BFiD3kyB.cjs';
|
|
7
|
-
import { m as BoardWorkerStore, f as BoardWorkerRequest, i as BoardCallbackTransport, d as BoardNonCorePlatformAdapter, e as BoardPlatformAdapter } from './board-live-cards-public-LlVUQPL2.cjs';
|
|
8
|
-
export { n as BOARD_GRAPH_KEY, g as BoardLiveCardsNonCorePublic, c as BoardLiveCardsPublic, o as BoardWorkerDeadLetterRequest, p as BoardWorkerLeasedRequest, q as BoardWorkerQueuedRequest, C as CommandInput, a as CommandResult, E as EMPTY_CONFIG, L as LiveCard, r as SNAPSHOT_SCHEMA_VERSION_V1, s as createBoardLiveCardsNonCorePublic, t as createBoardLiveCardsPublic, u as createBoardWorkerStore, v as createCardStore, w as createHttpBoardCallbackTransport, x as createInProcessBoardCallbackTransport, y as createLocalNodeBoardCallbackTransport } from './board-live-cards-public-LlVUQPL2.cjs';
|
|
9
|
-
import { C as ChatStorage } from './chat-storage-lib-B9Q34Dyv.cjs';
|
|
10
|
-
export { c as ChatConfig, a as ChatRecord, d as createChatStorage, e as createInMemoryChatStorage } from './chat-storage-lib-B9Q34Dyv.cjs';
|
|
11
|
-
export { BoardLiveCardsMcp, BoardLiveCardsMcpBoardStatusResult, BoardLiveCardsMcpDeps, BoardLiveCardsMcpDiscoverSourceKindsResult, BoardLiveCardsMcpFileDownloadDescriptor, BoardLiveCardsMcpInspectCardDefinitionAndRuntimeResult, BoardLiveCardsMcpInspectChatMessagesResult, BoardLiveCardsMcpManageUpsertCardResult, createBoardLiveCardsMcp } from './board-live-cards-mcp.cjs';
|
|
1
|
+
import { a as ArtifactsStore } from './artifacts-store-lib-C6qBpMfU.cjs';
|
|
2
|
+
export { c as createArtifactsStore, b as createCardFileMetadataStore, d as createFileArtifactsStore } from './artifacts-store-lib-C6qBpMfU.cjs';
|
|
12
3
|
import { ExecutionRef, ArgsMassaging } from './execution-refs.cjs';
|
|
13
4
|
export { executionRefFromScriptPath, parseExecutionRef, serializeExecutionRef } from './execution-refs.cjs';
|
|
5
|
+
import { c as BoardRuntimeNonCorePublic, i as BoardWorkerStore, f as BoardWorkerRequest, I as InvocationAdapter } from './types-CPnYv7RC.cjs';
|
|
6
|
+
export { j as BoardWorkerDeadLetterRequest, k as BoardWorkerLeasedRequest, l as BoardWorkerQueuedRequest, D as DescribeEnvelope, m as createBoardWorkerStore } from './types-CPnYv7RC.cjs';
|
|
7
|
+
import { a as KindValueRef, B as BlobStorage, f as QueueStorage } from './storage-interface-D-iEiTJA.cjs';
|
|
8
|
+
export { p as parseRef, s as serializeRef } from './storage-interface-D-iEiTJA.cjs';
|
|
9
|
+
import { f as ChatStorage, k as BoardCallbackTransport, d as BoardNonCorePlatformAdapter, e as BoardPlatformAdapter } from './board-live-cards-public-BT5HrgqZ.cjs';
|
|
10
|
+
export { p as BOARD_GRAPH_KEY, l as BoardLiveCardsNonCorePublic, c as BoardLiveCardsPublic, i as ChatConfig, g as ChatRecord, C as CommandInput, a as CommandResult, E as EMPTY_CONFIG, L as LiveCard, q as SNAPSHOT_SCHEMA_VERSION_V1, r as createBoardLiveCardsNonCorePublic, s as createBoardLiveCardsPublic, t as createCardStore, u as createChatStorage, v as createHttpBoardCallbackTransport, w as createInMemoryChatStorage, x as createInProcessBoardCallbackTransport, y as createLocalNodeBoardCallbackTransport } from './board-live-cards-public-BT5HrgqZ.cjs';
|
|
11
|
+
export { BoardLiveCardsMcp, BoardLiveCardsMcpBoardStatusResult, BoardLiveCardsMcpDeps, BoardLiveCardsMcpDiscoverSourceKindsResult, BoardLiveCardsMcpFileDownloadDescriptor, BoardLiveCardsMcpInspectCardDefinitionAndRuntimeResult, BoardLiveCardsMcpInspectChatMessagesResult, BoardLiveCardsMcpManageUpsertCardResult, createBoardLiveCardsMcp } from './board-live-cards-mcp.cjs';
|
|
14
12
|
export { createCardStorePublic } from './card-store-public.cjs';
|
|
15
13
|
export { createArtifactsStorePublic } from './artifacts-store-public.cjs';
|
|
14
|
+
import { A as AsyncBoardPlatformAdapter } from './board-platform-adapter-async-BZIftm36.cjs';
|
|
16
15
|
import { Q as QueueLaneLease, a as QueueLaneDescriptor, b as QueueLaneRegistry } from './queue-lane-registry-PaZuFpwp.cjs';
|
|
17
16
|
export { c as createQueueLaneRegistry } from './queue-lane-registry-PaZuFpwp.cjs';
|
|
18
|
-
import './board-
|
|
19
|
-
import './storage-async-interface-BRR4eBjx.cjs';
|
|
20
|
-
import './board-live-cards-public-async-Di9QB141.cjs';
|
|
17
|
+
import './board-live-cards-public-async-CYjr4mgX.cjs';
|
|
21
18
|
import './types-BBhqYGhE.cjs';
|
|
22
19
|
import './chat-store-public.cjs';
|
|
20
|
+
import './storage-async-interface-CyO-zwVQ.cjs';
|
|
23
21
|
|
|
24
22
|
/**
|
|
25
23
|
* cli/common/args-massaging — JSONata-based mapping from logical args to
|
|
@@ -170,6 +168,58 @@ declare function createExecutionRefInvoker(options?: CreateExecutionRefInvokerOp
|
|
|
170
168
|
*/
|
|
171
169
|
declare function invokeRefSync(ref: ExecutionRef, args: Record<string, unknown>, options?: InvokeRefSyncOptions): InvokeRefResult;
|
|
172
170
|
|
|
171
|
+
interface HostedAsyncBoardNonCoreOptions {
|
|
172
|
+
taskExecutorRef?: ExecutionRef;
|
|
173
|
+
invokeExecutor?: (ref: ExecutionRef, subcommand: string, opts?: {
|
|
174
|
+
timeout?: number;
|
|
175
|
+
input?: string;
|
|
176
|
+
}) => Promise<string>;
|
|
177
|
+
unsupportedLabel?: string;
|
|
178
|
+
}
|
|
179
|
+
declare function createHostedAsyncBoardNonCorePublic(adapter: AsyncBoardPlatformAdapter, options?: HostedAsyncBoardNonCoreOptions): BoardRuntimeNonCorePublic;
|
|
180
|
+
|
|
181
|
+
/**
|
|
182
|
+
* non-core-executor-dispatcher.ts
|
|
183
|
+
*
|
|
184
|
+
* Storage-agnostic Node implementation of `BoardNonCorePlatformAdapter.invokeExecutor`.
|
|
185
|
+
*
|
|
186
|
+
* Lives outside fs-board-adapter and firestore-storage so any host (fs, firestore,
|
|
187
|
+
* cosmos, …) can compose the same dispatcher onto its storage adapter to produce a
|
|
188
|
+
* full `BoardNonCorePlatformAdapter`.
|
|
189
|
+
*
|
|
190
|
+
* Dispatch is a pure switch on `ref.howToRun`:
|
|
191
|
+
* - http:post / in-process-loop → invokeBoardWorker(ref, { subcommand, input? })
|
|
192
|
+
* - http:get → invokeExecutionRef(ref, { subcommand, input?, extra? })
|
|
193
|
+
* - local-node / local-python /
|
|
194
|
+
* local-process / built-in → spawn(command, [...baseArgs, subcommand, --extra?])
|
|
195
|
+
* - queue-storage → throws (use opts.resolveRef to rewrite first)
|
|
196
|
+
*
|
|
197
|
+
* `resolveRef` lets callers rewrite a ref before dispatch (e.g. an offline localfs
|
|
198
|
+
* host can rewrite a `queue-storage` hosted ref into a `local-node` script ref).
|
|
199
|
+
*/
|
|
200
|
+
|
|
201
|
+
interface NonCoreExecutorDispatcherOpts {
|
|
202
|
+
/** Rewrite the ref before dispatch (e.g. hosted → local-node). Identity if omitted. */
|
|
203
|
+
resolveRef?: (ref: ExecutionRef) => ExecutionRef;
|
|
204
|
+
/** Lazily resolves the CLI directory used by `local-*` spawn refs. */
|
|
205
|
+
resolveCliDir?: () => string;
|
|
206
|
+
/** Default timeouts surfaced as `BoardNonCorePlatformAdapter.executorTimeouts`. */
|
|
207
|
+
executorTimeouts?: {
|
|
208
|
+
validationMs?: number;
|
|
209
|
+
preflightMs?: number;
|
|
210
|
+
probeMs?: number;
|
|
211
|
+
describeMs?: number;
|
|
212
|
+
};
|
|
213
|
+
}
|
|
214
|
+
interface NonCoreExecutorDispatcher {
|
|
215
|
+
invokeExecutor(ref: ExecutionRef, subcommand: string, opts?: {
|
|
216
|
+
timeout?: number;
|
|
217
|
+
input?: string;
|
|
218
|
+
}): Promise<string>;
|
|
219
|
+
executorTimeouts?: NonCoreExecutorDispatcherOpts['executorTimeouts'];
|
|
220
|
+
}
|
|
221
|
+
declare function createNonCoreExecutorDispatcher(opts?: NonCoreExecutorDispatcherOpts): NonCoreExecutorDispatcher;
|
|
222
|
+
|
|
173
223
|
declare function createFsBlobStorage(rootDir: string): BlobStorage;
|
|
174
224
|
declare function createFsQueueStorage(rootDir: string): QueueStorage;
|
|
175
225
|
|
|
@@ -217,10 +267,14 @@ type FsBoardAdapterOpts = {
|
|
|
217
267
|
suppressSpawn?: boolean;
|
|
218
268
|
notifyChannel?: string;
|
|
219
269
|
callbackTransport?: BoardCallbackTransport;
|
|
270
|
+
boardRuntimeStoreRef?: string;
|
|
271
|
+
queueStoreRef?: string;
|
|
220
272
|
};
|
|
221
273
|
type FsBoardNonCoreAdapterOpts = {
|
|
222
274
|
onWarn?: (msg: string) => void;
|
|
223
275
|
callbackTransport?: BoardCallbackTransport;
|
|
276
|
+
/** Rewrite executor refs before dispatch (e.g. hosted queue-storage → local-node). */
|
|
277
|
+
resolveRef?: (ref: ExecutionRef) => ExecutionRef;
|
|
224
278
|
};
|
|
225
279
|
declare function createFsBoardPlatformAdapter(baseRef: KindValueRef, cliDirOrOpts?: string | FsBoardAdapterOpts, maybeOpts?: FsBoardAdapterOpts): BoardPlatformAdapter;
|
|
226
280
|
declare function createFsBoardNonCorePlatformAdapter(baseRef: KindValueRef, cliDirOrOpts?: string | FsBoardNonCoreAdapterOpts, maybeOpts?: FsBoardNonCoreAdapterOpts): BoardNonCorePlatformAdapter;
|
|
@@ -231,6 +285,7 @@ interface FsBoardChatStorageOptions {
|
|
|
231
285
|
kvSubdir?: string;
|
|
232
286
|
}
|
|
233
287
|
declare function createFsBoardChatStorage(boardDir: string, opts?: FsBoardChatStorageOptions): ChatStorage;
|
|
288
|
+
declare function createFsChatStorageForRefRoot(chatStoreDir: string): ChatStorage;
|
|
234
289
|
interface FsBoardFileArtifactsStoreOptions {
|
|
235
290
|
/** Subdirectory under baseDir for file uploads. Default: 'files'. Pass '' to root at baseDir. */
|
|
236
291
|
filesSubdir?: string;
|
|
@@ -242,4 +297,4 @@ declare function createFsBoardFileArtifactsStore(baseDir: string, opts?: FsBoard
|
|
|
242
297
|
*/
|
|
243
298
|
declare function decodeBoardRefFromToken(token: string): string | null;
|
|
244
299
|
|
|
245
|
-
export { BoardNonCorePlatformAdapter, BoardPlatformAdapter, BoardWorkerRequest, BoardWorkerStore, ChatStorage, type CreateExecutionRefInvokerOptions, ExecutionRef, type ExecutionRefInvoker, type FsBoardChatStorageOptions, type FsBoardFileArtifactsStoreOptions, type InProcessExecutionHandler, InvocationAdapter, type InvokeExecutionRefOptions, type InvokeRefResult, KindValueRef, QueueLaneDescriptor, QueueLaneLease, QueueLaneRegistry, type SyncTransportInvoker, type TransportInvoker, buildLocalBaseSpec, createBoardWorkerQueueLane, createExecutionRefInvoker, createFsBlobStorage, createFsBoardChatStorage, createFsBoardFileArtifactsStore, createFsBoardNonCorePlatformAdapter, createFsBoardPlatformAdapter, createFsQueueStorage, createNodeSpawnInvocationAdapter, createQueueStorageLane, decodeBoardRefFromToken, drainQueueLaneToIdle, evaluateArgsMassaging, invokeExecutionRef, invokeExecutionRefSync, invokeRefSync, registerInProcessExecutionHandler, resolveWhatToRunValue, resolveYamlFlowCliPath, startQueueLaneRunner, startQueueLaneRunners, unregisterInProcessExecutionHandler };
|
|
300
|
+
export { BoardNonCorePlatformAdapter, BoardPlatformAdapter, BoardWorkerRequest, BoardWorkerStore, ChatStorage, type CreateExecutionRefInvokerOptions, ExecutionRef, type ExecutionRefInvoker, type FsBoardChatStorageOptions, type FsBoardFileArtifactsStoreOptions, type InProcessExecutionHandler, InvocationAdapter, type InvokeExecutionRefOptions, type InvokeRefResult, KindValueRef, QueueLaneDescriptor, QueueLaneLease, QueueLaneRegistry, type SyncTransportInvoker, type TransportInvoker, buildLocalBaseSpec, createBoardWorkerQueueLane, createExecutionRefInvoker, createFsBlobStorage, createFsBoardChatStorage, createFsBoardFileArtifactsStore, createFsBoardNonCorePlatformAdapter, createFsBoardPlatformAdapter, createFsChatStorageForRefRoot, createFsQueueStorage, createHostedAsyncBoardNonCorePublic, createNodeSpawnInvocationAdapter, createNonCoreExecutorDispatcher, createQueueStorageLane, decodeBoardRefFromToken, drainQueueLaneToIdle, evaluateArgsMassaging, invokeExecutionRef, invokeExecutionRefSync, invokeRefSync, registerInProcessExecutionHandler, resolveWhatToRunValue, resolveYamlFlowCliPath, startQueueLaneRunner, startQueueLaneRunners, unregisterInProcessExecutionHandler };
|
|
@@ -1,25 +1,23 @@
|
|
|
1
|
-
import { a as ArtifactsStore } from './artifacts-store-lib-
|
|
2
|
-
export { c as createArtifactsStore, b as createCardFileMetadataStore, d as createFileArtifactsStore } from './artifacts-store-lib-
|
|
3
|
-
import { I as InvocationAdapter } from './types-SO5OZm4s.js';
|
|
4
|
-
export { D as DescribeEnvelope } from './types-SO5OZm4s.js';
|
|
5
|
-
import { a as KindValueRef, B as BlobStorage, g as QueueStorage } from './storage-interface-BFiD3kyB.js';
|
|
6
|
-
export { p as parseRef, s as serializeRef } from './storage-interface-BFiD3kyB.js';
|
|
7
|
-
import { m as BoardWorkerStore, f as BoardWorkerRequest, i as BoardCallbackTransport, d as BoardNonCorePlatformAdapter, e as BoardPlatformAdapter } from './board-live-cards-public-JNRKfBZy.js';
|
|
8
|
-
export { n as BOARD_GRAPH_KEY, g as BoardLiveCardsNonCorePublic, c as BoardLiveCardsPublic, o as BoardWorkerDeadLetterRequest, p as BoardWorkerLeasedRequest, q as BoardWorkerQueuedRequest, C as CommandInput, a as CommandResult, E as EMPTY_CONFIG, L as LiveCard, r as SNAPSHOT_SCHEMA_VERSION_V1, s as createBoardLiveCardsNonCorePublic, t as createBoardLiveCardsPublic, u as createBoardWorkerStore, v as createCardStore, w as createHttpBoardCallbackTransport, x as createInProcessBoardCallbackTransport, y as createLocalNodeBoardCallbackTransport } from './board-live-cards-public-JNRKfBZy.js';
|
|
9
|
-
import { C as ChatStorage } from './chat-storage-lib-DB9iSai2.js';
|
|
10
|
-
export { c as ChatConfig, a as ChatRecord, d as createChatStorage, e as createInMemoryChatStorage } from './chat-storage-lib-DB9iSai2.js';
|
|
11
|
-
export { BoardLiveCardsMcp, BoardLiveCardsMcpBoardStatusResult, BoardLiveCardsMcpDeps, BoardLiveCardsMcpDiscoverSourceKindsResult, BoardLiveCardsMcpFileDownloadDescriptor, BoardLiveCardsMcpInspectCardDefinitionAndRuntimeResult, BoardLiveCardsMcpInspectChatMessagesResult, BoardLiveCardsMcpManageUpsertCardResult, createBoardLiveCardsMcp } from './board-live-cards-mcp.js';
|
|
1
|
+
import { a as ArtifactsStore } from './artifacts-store-lib-D4qf7Q-7.js';
|
|
2
|
+
export { c as createArtifactsStore, b as createCardFileMetadataStore, d as createFileArtifactsStore } from './artifacts-store-lib-D4qf7Q-7.js';
|
|
12
3
|
import { ExecutionRef, ArgsMassaging } from './execution-refs.js';
|
|
13
4
|
export { executionRefFromScriptPath, parseExecutionRef, serializeExecutionRef } from './execution-refs.js';
|
|
5
|
+
import { c as BoardRuntimeNonCorePublic, i as BoardWorkerStore, f as BoardWorkerRequest, I as InvocationAdapter } from './types-BsfXZyI3.js';
|
|
6
|
+
export { j as BoardWorkerDeadLetterRequest, k as BoardWorkerLeasedRequest, l as BoardWorkerQueuedRequest, D as DescribeEnvelope, m as createBoardWorkerStore } from './types-BsfXZyI3.js';
|
|
7
|
+
import { a as KindValueRef, B as BlobStorage, f as QueueStorage } from './storage-interface-D-iEiTJA.js';
|
|
8
|
+
export { p as parseRef, s as serializeRef } from './storage-interface-D-iEiTJA.js';
|
|
9
|
+
import { f as ChatStorage, k as BoardCallbackTransport, d as BoardNonCorePlatformAdapter, e as BoardPlatformAdapter } from './board-live-cards-public-DSRamFm8.js';
|
|
10
|
+
export { p as BOARD_GRAPH_KEY, l as BoardLiveCardsNonCorePublic, c as BoardLiveCardsPublic, i as ChatConfig, g as ChatRecord, C as CommandInput, a as CommandResult, E as EMPTY_CONFIG, L as LiveCard, q as SNAPSHOT_SCHEMA_VERSION_V1, r as createBoardLiveCardsNonCorePublic, s as createBoardLiveCardsPublic, t as createCardStore, u as createChatStorage, v as createHttpBoardCallbackTransport, w as createInMemoryChatStorage, x as createInProcessBoardCallbackTransport, y as createLocalNodeBoardCallbackTransport } from './board-live-cards-public-DSRamFm8.js';
|
|
11
|
+
export { BoardLiveCardsMcp, BoardLiveCardsMcpBoardStatusResult, BoardLiveCardsMcpDeps, BoardLiveCardsMcpDiscoverSourceKindsResult, BoardLiveCardsMcpFileDownloadDescriptor, BoardLiveCardsMcpInspectCardDefinitionAndRuntimeResult, BoardLiveCardsMcpInspectChatMessagesResult, BoardLiveCardsMcpManageUpsertCardResult, createBoardLiveCardsMcp } from './board-live-cards-mcp.js';
|
|
14
12
|
export { createCardStorePublic } from './card-store-public.js';
|
|
15
13
|
export { createArtifactsStorePublic } from './artifacts-store-public.js';
|
|
14
|
+
import { A as AsyncBoardPlatformAdapter } from './board-platform-adapter-async-JP9V-U5E.js';
|
|
16
15
|
import { Q as QueueLaneLease, a as QueueLaneDescriptor, b as QueueLaneRegistry } from './queue-lane-registry-PaZuFpwp.js';
|
|
17
16
|
export { c as createQueueLaneRegistry } from './queue-lane-registry-PaZuFpwp.js';
|
|
18
|
-
import './board-
|
|
19
|
-
import './storage-async-interface-DhlOVPSp.js';
|
|
20
|
-
import './board-live-cards-public-async-fwd1QI82.js';
|
|
17
|
+
import './board-live-cards-public-async-DlyC3PgC.js';
|
|
21
18
|
import './types-BBhqYGhE.js';
|
|
22
19
|
import './chat-store-public.js';
|
|
20
|
+
import './storage-async-interface-CG0bMqvE.js';
|
|
23
21
|
|
|
24
22
|
/**
|
|
25
23
|
* cli/common/args-massaging — JSONata-based mapping from logical args to
|
|
@@ -170,6 +168,58 @@ declare function createExecutionRefInvoker(options?: CreateExecutionRefInvokerOp
|
|
|
170
168
|
*/
|
|
171
169
|
declare function invokeRefSync(ref: ExecutionRef, args: Record<string, unknown>, options?: InvokeRefSyncOptions): InvokeRefResult;
|
|
172
170
|
|
|
171
|
+
interface HostedAsyncBoardNonCoreOptions {
|
|
172
|
+
taskExecutorRef?: ExecutionRef;
|
|
173
|
+
invokeExecutor?: (ref: ExecutionRef, subcommand: string, opts?: {
|
|
174
|
+
timeout?: number;
|
|
175
|
+
input?: string;
|
|
176
|
+
}) => Promise<string>;
|
|
177
|
+
unsupportedLabel?: string;
|
|
178
|
+
}
|
|
179
|
+
declare function createHostedAsyncBoardNonCorePublic(adapter: AsyncBoardPlatformAdapter, options?: HostedAsyncBoardNonCoreOptions): BoardRuntimeNonCorePublic;
|
|
180
|
+
|
|
181
|
+
/**
|
|
182
|
+
* non-core-executor-dispatcher.ts
|
|
183
|
+
*
|
|
184
|
+
* Storage-agnostic Node implementation of `BoardNonCorePlatformAdapter.invokeExecutor`.
|
|
185
|
+
*
|
|
186
|
+
* Lives outside fs-board-adapter and firestore-storage so any host (fs, firestore,
|
|
187
|
+
* cosmos, …) can compose the same dispatcher onto its storage adapter to produce a
|
|
188
|
+
* full `BoardNonCorePlatformAdapter`.
|
|
189
|
+
*
|
|
190
|
+
* Dispatch is a pure switch on `ref.howToRun`:
|
|
191
|
+
* - http:post / in-process-loop → invokeBoardWorker(ref, { subcommand, input? })
|
|
192
|
+
* - http:get → invokeExecutionRef(ref, { subcommand, input?, extra? })
|
|
193
|
+
* - local-node / local-python /
|
|
194
|
+
* local-process / built-in → spawn(command, [...baseArgs, subcommand, --extra?])
|
|
195
|
+
* - queue-storage → throws (use opts.resolveRef to rewrite first)
|
|
196
|
+
*
|
|
197
|
+
* `resolveRef` lets callers rewrite a ref before dispatch (e.g. an offline localfs
|
|
198
|
+
* host can rewrite a `queue-storage` hosted ref into a `local-node` script ref).
|
|
199
|
+
*/
|
|
200
|
+
|
|
201
|
+
interface NonCoreExecutorDispatcherOpts {
|
|
202
|
+
/** Rewrite the ref before dispatch (e.g. hosted → local-node). Identity if omitted. */
|
|
203
|
+
resolveRef?: (ref: ExecutionRef) => ExecutionRef;
|
|
204
|
+
/** Lazily resolves the CLI directory used by `local-*` spawn refs. */
|
|
205
|
+
resolveCliDir?: () => string;
|
|
206
|
+
/** Default timeouts surfaced as `BoardNonCorePlatformAdapter.executorTimeouts`. */
|
|
207
|
+
executorTimeouts?: {
|
|
208
|
+
validationMs?: number;
|
|
209
|
+
preflightMs?: number;
|
|
210
|
+
probeMs?: number;
|
|
211
|
+
describeMs?: number;
|
|
212
|
+
};
|
|
213
|
+
}
|
|
214
|
+
interface NonCoreExecutorDispatcher {
|
|
215
|
+
invokeExecutor(ref: ExecutionRef, subcommand: string, opts?: {
|
|
216
|
+
timeout?: number;
|
|
217
|
+
input?: string;
|
|
218
|
+
}): Promise<string>;
|
|
219
|
+
executorTimeouts?: NonCoreExecutorDispatcherOpts['executorTimeouts'];
|
|
220
|
+
}
|
|
221
|
+
declare function createNonCoreExecutorDispatcher(opts?: NonCoreExecutorDispatcherOpts): NonCoreExecutorDispatcher;
|
|
222
|
+
|
|
173
223
|
declare function createFsBlobStorage(rootDir: string): BlobStorage;
|
|
174
224
|
declare function createFsQueueStorage(rootDir: string): QueueStorage;
|
|
175
225
|
|
|
@@ -217,10 +267,14 @@ type FsBoardAdapterOpts = {
|
|
|
217
267
|
suppressSpawn?: boolean;
|
|
218
268
|
notifyChannel?: string;
|
|
219
269
|
callbackTransport?: BoardCallbackTransport;
|
|
270
|
+
boardRuntimeStoreRef?: string;
|
|
271
|
+
queueStoreRef?: string;
|
|
220
272
|
};
|
|
221
273
|
type FsBoardNonCoreAdapterOpts = {
|
|
222
274
|
onWarn?: (msg: string) => void;
|
|
223
275
|
callbackTransport?: BoardCallbackTransport;
|
|
276
|
+
/** Rewrite executor refs before dispatch (e.g. hosted queue-storage → local-node). */
|
|
277
|
+
resolveRef?: (ref: ExecutionRef) => ExecutionRef;
|
|
224
278
|
};
|
|
225
279
|
declare function createFsBoardPlatformAdapter(baseRef: KindValueRef, cliDirOrOpts?: string | FsBoardAdapterOpts, maybeOpts?: FsBoardAdapterOpts): BoardPlatformAdapter;
|
|
226
280
|
declare function createFsBoardNonCorePlatformAdapter(baseRef: KindValueRef, cliDirOrOpts?: string | FsBoardNonCoreAdapterOpts, maybeOpts?: FsBoardNonCoreAdapterOpts): BoardNonCorePlatformAdapter;
|
|
@@ -231,6 +285,7 @@ interface FsBoardChatStorageOptions {
|
|
|
231
285
|
kvSubdir?: string;
|
|
232
286
|
}
|
|
233
287
|
declare function createFsBoardChatStorage(boardDir: string, opts?: FsBoardChatStorageOptions): ChatStorage;
|
|
288
|
+
declare function createFsChatStorageForRefRoot(chatStoreDir: string): ChatStorage;
|
|
234
289
|
interface FsBoardFileArtifactsStoreOptions {
|
|
235
290
|
/** Subdirectory under baseDir for file uploads. Default: 'files'. Pass '' to root at baseDir. */
|
|
236
291
|
filesSubdir?: string;
|
|
@@ -242,4 +297,4 @@ declare function createFsBoardFileArtifactsStore(baseDir: string, opts?: FsBoard
|
|
|
242
297
|
*/
|
|
243
298
|
declare function decodeBoardRefFromToken(token: string): string | null;
|
|
244
299
|
|
|
245
|
-
export { BoardNonCorePlatformAdapter, BoardPlatformAdapter, BoardWorkerRequest, BoardWorkerStore, ChatStorage, type CreateExecutionRefInvokerOptions, ExecutionRef, type ExecutionRefInvoker, type FsBoardChatStorageOptions, type FsBoardFileArtifactsStoreOptions, type InProcessExecutionHandler, InvocationAdapter, type InvokeExecutionRefOptions, type InvokeRefResult, KindValueRef, QueueLaneDescriptor, QueueLaneLease, QueueLaneRegistry, type SyncTransportInvoker, type TransportInvoker, buildLocalBaseSpec, createBoardWorkerQueueLane, createExecutionRefInvoker, createFsBlobStorage, createFsBoardChatStorage, createFsBoardFileArtifactsStore, createFsBoardNonCorePlatformAdapter, createFsBoardPlatformAdapter, createFsQueueStorage, createNodeSpawnInvocationAdapter, createQueueStorageLane, decodeBoardRefFromToken, drainQueueLaneToIdle, evaluateArgsMassaging, invokeExecutionRef, invokeExecutionRefSync, invokeRefSync, registerInProcessExecutionHandler, resolveWhatToRunValue, resolveYamlFlowCliPath, startQueueLaneRunner, startQueueLaneRunners, unregisterInProcessExecutionHandler };
|
|
300
|
+
export { BoardNonCorePlatformAdapter, BoardPlatformAdapter, BoardWorkerRequest, BoardWorkerStore, ChatStorage, type CreateExecutionRefInvokerOptions, ExecutionRef, type ExecutionRefInvoker, type FsBoardChatStorageOptions, type FsBoardFileArtifactsStoreOptions, type InProcessExecutionHandler, InvocationAdapter, type InvokeExecutionRefOptions, type InvokeRefResult, KindValueRef, QueueLaneDescriptor, QueueLaneLease, QueueLaneRegistry, type SyncTransportInvoker, type TransportInvoker, buildLocalBaseSpec, createBoardWorkerQueueLane, createExecutionRefInvoker, createFsBlobStorage, createFsBoardChatStorage, createFsBoardFileArtifactsStore, createFsBoardNonCorePlatformAdapter, createFsBoardPlatformAdapter, createFsChatStorageForRefRoot, createFsQueueStorage, createHostedAsyncBoardNonCorePublic, createNodeSpawnInvocationAdapter, createNonCoreExecutorDispatcher, createQueueStorageLane, decodeBoardRefFromToken, drainQueueLaneToIdle, evaluateArgsMassaging, invokeExecutionRef, invokeExecutionRefSync, invokeRefSync, registerInProcessExecutionHandler, resolveWhatToRunValue, resolveYamlFlowCliPath, startQueueLaneRunner, startQueueLaneRunners, unregisterInProcessExecutionHandler };
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import'./chunk-
|
|
1
|
+
import {a as a$2}from'./chunk-Y4WK7HE4.js';export{a as createChatStorage,c as createInMemoryChatStorage}from'./chunk-Y4WK7HE4.js';import {a as a$5}from'./chunk-YBYXCFAI.js';import {a as a$3}from'./chunk-O5UYCGIN.js';export{a as createArtifactsStore,c as createCardFileMetadataStore,b as createFileArtifactsStore}from'./chunk-O5UYCGIN.js';import {a as a$4}from'./chunk-RKKSVOP2.js';export{a as createBoardWorkerStore,b as createQueueLaneRegistry}from'./chunk-RKKSVOP2.js';import {a}from'./chunk-VGDLSS2H.js';import'./chunk-7BTZCOT5.js';import'./chunk-7QQFDYBM.js';import {b as b$1}from'./chunk-NNSBBO5R.js';import {g,y}from'./chunk-ZWVT24YW.js';export{n as BOARD_GRAPH_KEY,u as EMPTY_CONFIG,m as SNAPSHOT_SCHEMA_VERSION_V1,z as createBoardLiveCardsNonCorePublic,y as createBoardLiveCardsPublic,l as createCardStore,e as createHttpBoardCallbackTransport,f as createInProcessBoardCallbackTransport,g as createLocalNodeBoardCallbackTransport}from'./chunk-ZWVT24YW.js';export{a as executionRefFromScriptPath,c as parseExecutionRef,b as serializeExecutionRef}from'./chunk-ANKA7HEJ.js';import {a as a$1,b}from'./chunk-44L64VQ2.js';export{b as parseRef,a as serializeRef}from'./chunk-44L64VQ2.js';import'./chunk-VGT3TRQG.js';import'./chunk-WDPOGXTY.js';export{a as createBoardLiveCardsMcp}from'./chunk-35N7ONTH.js';import {a as a$6}from'./chunk-JMDHDY6M.js';import {d}from'./chunk-3KC6LBOG.js';import'./chunk-MNEOJWPS.js';export{a as createCardStorePublic}from'./chunk-KBELAKIY.js';export{a as createArtifactsStorePublic}from'./chunk-X3LC4LII.js';import {h}from'./chunk-J4MHQ7JF.js';import'./chunk-FW4363Y4.js';import {spawn,spawnSync,execFile,execFileSync}from'child_process';import*as i from'fs';import*as Oe from'os';import*as x from'path';import*as qe from'net';import {fileURLToPath}from'url';import {randomUUID,createHash}from'crypto';import {createRequire}from'module';import {lockSync}from'proper-lockfile';function C(...e){return x.join(...e)}function Ne(e){return x.isAbsolute(e)}function ue(){return randomUUID()}function Qe(e){return createHash("sha256").update(e).digest("hex")}function Je(e){return x.dirname(fileURLToPath(e))}function Pt(e){if(typeof e=="object"&&e!==null){let{command:r,args:o=[],...n}=e,s=Le(r,o);return {...n,command:s.command,args:s.args}}let t=De(e);if(t.length===0)throw new Error(`Empty command spec: ${JSON.stringify(e)}`);return Le(t[0],t.slice(1))}function Le(e,t){return /^(node|node\.exe)$/i.test(e)?{command:process.execPath,args:t}:/\.m?js$/i.test(e)?{command:process.execPath,args:[e,...t]}:{command:e,args:t}}function De(e){let t=[],r="",o=null;for(let n of e.trim()){if(o){n===o?o=null:r+=n;continue}if(n==='"'||n==="'"){o=n;continue}if(/\s/.test(n)){r&&(t.push(r),r="");continue}r+=n;}if(o)throw new Error(`Unterminated quote in command: ${e}`);return r&&t.push(r),t}function We(e){return process.platform==="win32"&&/\.(cmd|bat)$/i.test(e)}function He(e,t){let{command:r,args:o=[],cwd:n,env:s,timeoutMs:a}=e;return execFileSync(r,o,{shell:We(r),timeout:a,encoding:t?.encoding??"utf-8",cwd:n,windowsHide:true,env:s?{...process.env,...s}:void 0,input:t?.input})}function Ft(e,t){let{command:r,args:o=[],cwd:n,env:s,timeoutMs:a=3e4}=e;execFile(r,o,{shell:We(r),encoding:"utf8",windowsHide:true,timeout:a,maxBuffer:10*1024*1024,cwd:n,env:s?{...process.env,...s}:void 0},(g,S,c)=>t(g??null,S,c));}function Ke(e,t,r){let o=x.join(e,"board-live-cards-cli.js");if(i.existsSync(o))return {cmd:process.execPath,args:[o,t,...r]};let n=x.join(e,"board-live-cards-cli.ts"),a=[x.join(e,"..","..","..","node_modules","tsx","dist","cli.mjs"),x.join(e,"..","..","node_modules","tsx","dist","cli.mjs"),x.join(e,"..","..","..","node_modules",".bin","tsx"),x.join(e,"..","..","node_modules",".bin","tsx")].find(S=>i.existsSync(S));return i.existsSync(n)&&a?{cmd:process.execPath,args:[a,n,t,...r]}:{cmd:process.platform==="win32"?"npx.cmd":"npx",args:["tsx",n,t,...r]}}function Ve(e){let t=x.join(e,"board-live-cards-cli.mjs");if(i.existsSync(t))return t;let r=x.join(e,"..","..","..","dev","board-live-cards-cli.js");if(i.existsSync(r))return r;let o=x.join(e,"..","..","dev","board-live-cards-cli.js");if(i.existsSync(o))return o;let n=x.join(e,"board-live-cards-cli.js");if(i.existsSync(n))return n;throw new Error(`resolveBoardCliCallbackTarget: cannot find callback target in ${e} (expected dev/board-live-cards-cli.js wrapper, ${n}, or ${t})`)}function $t(e){return process.platform==="win32"?`\\\\.\\pipe\\${e}`:x.join(Oe.tmpdir(),`${e}.sock`)}var ce=new Map;function Ue(e,t,r){if(t.length===0)return;let o=t.map(g=>JSON.stringify(g)).join(`
|
|
2
2
|
`)+`
|
|
3
|
-
`,o=Z.get(e);if(o&&!o.socket.destroyed){o.ready?o.socket.write(n):o.queue.push(n);return}let s=vt(e),u=Te.createConnection(s);o={socket:u,ready:false,queue:[n]},Z.set(e,o),u.on("connect",()=>{o.ready=true;for(let l of o.queue)u.write(l);o.queue.length=0;}),u.on("error",l=>{r?.(`[named-pipe publish] ${s}: ${l instanceof Error?l.message:String(l)}`),Z.delete(e);}),u.on("close",()=>{Z.delete(e);});}function Le(){return {executeSync(e,t,r){return je({command:e,args:t,cwd:r?.cwd,timeoutMs:r?.timeout,env:r?.env},{encoding:r?.encoding,input:r?.input})},executeAsync(e,t,r){wt({command:e,args:t},r);},resolveInvocation(e,t){let r=kt({command:e,args:t});return {cmd:r.command,args:r.args??[]}},splitCommand:Me}}function fe(e){return {id:e.id??"board-worker",pollIntervalMs:e.pollIntervalMs,visibilityMs:e.visibilityMs,concurrency:e.concurrency,maxAttempts:e.maxAttempts,async lease(t){return e.workerStore.leaseRequests(t).map(r=>({id:r.messageId,attempt:r.attempt,message:r.request,ack:()=>e.workerStore.ackRequest(r.messageId,r.leaseToken),nack:n=>e.workerStore.nackRequest(r.messageId,r.leaseToken,n)}))},async handle(t){await e.handleRequest(t.args,t);},onError:e.onError}}function pe(e){return {id:e.id,pollIntervalMs:e.pollIntervalMs,visibilityMs:e.visibilityMs,concurrency:e.concurrency,maxAttempts:e.maxAttempts,async lease(t){return e.queueStorage.lease(t).map(r=>({id:r.id,attempt:r.attempt,message:r.body,ack:()=>e.queueStorage.ack(r.id,r.leaseToken),nack:n=>e.queueStorage.nack(r.id,r.leaseToken,n)}))},handle:e.handleMessage,onError:e.onError}}async function Qe(e,t){try{await e.handle(t.message,t),await t.ack();}catch(r){let n=t.attempt>=Math.max(1,Math.floor(e.maxAttempts??5));await t.nack({dead:n,reason:r instanceof Error?r.message:String(r)}),e.onError?.(r,t);}}function Oe(e){let t=Math.max(1,Math.floor(e.pollIntervalMs??250)),r=Math.max(1,Math.floor(e.visibilityMs??6e4)),n=Math.max(1,Math.floor(e.concurrency??1)),o=false,s=false;async function u(){if(!(o||s)){s=true;try{let g=await e.lease({max:n,visibilityMs:r});for(let i of g)await Qe(e,i);}finally{s=false;}}}let l=setInterval(()=>{u();},t);return typeof l.unref=="function"&&l.unref(),u(),()=>{o=true,clearInterval(l);}}async function bt(e){let t=Math.max(1,Math.floor(e.visibilityMs??6e4)),r=Math.max(1,Math.floor(e.concurrency??1)),n=await e.lease({max:r,visibilityMs:t});for(let o of n)await Qe(e,o);return n.length}async function ee(e,t){let r=Math.max(1,Math.floor(t?.maxPasses??256)),n=0;for(let o=0;o<r;o+=1){let s=await bt(e);if(n+=s,s<=0)return n}throw new Error(`drainQueueLaneToIdle exceeded ${r} passes for lane "${e.id}"`)}function At(e){let r=(Array.isArray(e)?e:e.lanes).map(n=>Oe(n));return ()=>{for(let n of r)n();}}var Tt=createRequire(import.meta.url);function Bt(e){return typeof e=="object"?e:b$1(e)}function _e(e){let t=y.basename(String(e||"").trim());if(!t)throw new Error(`resolveYamlFlowCliPath: expected non-empty cli file name, got ${JSON.stringify(e)}`);let r=y.dirname(Tt.resolve("yaml-flow/package.json")),n=t.replace(/\.[^.]+$/,""),o=y.join(r,"cli","bundled",`${n}.mjs`);if(a.existsSync(o))return o;let s=y.join(r,"cli","node",t);if(a.existsSync(s))return s;throw new Error(`resolveYamlFlowCliPath: could not find ${t} under cli/bundled or cli/node in ${r}`)}function $(e){let t=Bt(e);return t.kind==="yaml-flow-cli"?_e(t.value):t.value}function It(e,t){let r=$(e);switch(r){case "source-cli-task-executor":{let n=y.join(t,"source-cli-task-executor.js");if(a.existsSync(n))return {command:process.execPath,args:[n]};let o=y.join(t,"source-cli-task-executor.ts"),s=y.join(t,"..","..","node_modules","tsx","dist","cli.mjs"),u=y.join(t,"..","..","node_modules",".bin","tsx"),l=a.existsSync(s)?s:u;return a.existsSync(o)&&a.existsSync(l)?{command:process.execPath,args:[l,o]}:{command:process.execPath,args:[n]}}case "board-live-cards":{let{cmd:n,args:o}=$e(t,"_",[]);return {command:n,args:o}}default:throw new Error(`resolveBuiltIn: unknown built-in name "${r}". Supported: source-cli-task-executor, board-live-cards`)}}function Ct(e,t){if(e.howToRun==="built-in"){let{command:n,args:o}=It(e.whatToRun,t);return {command:n,baseArgs:o}}let r=(typeof e.whatToRun=="object",$(e.whatToRun));switch(e.howToRun){case "local-node":return {command:process.execPath,baseArgs:[r]};case "local-python":return {command:process.platform==="win32"?"python":"python3",baseArgs:[r]};case "local-process":return {command:r,baseArgs:[]};default:throw new Error(`resolveBaseInvocation: howToRun "${e.howToRun}" is not a local transport`)}}function te(e,t){return Ct(e,t)}var ge=new Map;function Mt(e,t){let r=String(e||"").trim();if(!r)throw new Error("registerInProcessExecutionHandler: key is required");ge.set(r,t);}function Ft(e){let t=String(e||"").trim();t&&ge.delete(t);}function Ne(e){let t=e.trim();if(!t)throw new Error("empty stdout");try{return JSON.parse(t)}catch{let r=t.split(/\r?\n/).filter(Boolean),n=r[r.length-1];return JSON.parse(n)}}function Je(e,t){return {...t,whatToRun:$(e.whatToRun),...e.extra?{extra:e.extra}:{}}}function me(e,t,r="invokeExecutionRef"){return a$1(e,t,r)}function De(e,t){if(e&&typeof e=="object"&&!Array.isArray(e)&&typeof e.result=="string"&&e.data&&typeof e.data=="object"&&!Array.isArray(e.data))return {...e,...t||{}};if(e&&typeof e=="object"&&!Array.isArray(e)&&typeof e.status=="string"){let n=e,o=n.status==="success"?"success":n.status==="fail"?"failure":n.status,s=n.data&&typeof n.data=="object"&&!Array.isArray(n.data)?n.data:n.data===void 0?{}:{stdout:n.data};return {result:o,data:s,...typeof n.error=="string"?{error:n.error}:{},...t||{}}}return {result:"success",data:e&&typeof e=="object"&&!Array.isArray(e)?e:{stdout:e},...t||{}}}function j(e){return {result:"failure",data:{error:e}}}function L(e,t,r){let n=r?.label??"invokeExecutionRefSync",o=r?.cliDir??r?.cwd??process.cwd(),s;try{s=me(e.argsMassaging,Je(e,t),n);}catch(d){let f=d instanceof Error?d.message:String(d);return j(f)}let u;try{u=te(e,o);}catch(d){let f=d instanceof Error?d.message:String(d);return j(`[${n}] ref resolution failed: ${f}`)}let l=[...u.baseArgs,...s.cmdArgs??[]],g=JSON.stringify(s.stdin??t),i=Le(),c;try{c=i.executeSync(u.command,l,{timeout:r?.timeoutMs??3e4,encoding:"utf-8",cwd:r?.cwd,input:g});}catch(d){let f=d,m=(f.stderr?String(f.stderr):"").trim(),S=typeof f.status=="number"?f.status:"unknown",h=m||f.message;return j(`[${n}] ref exited with status ${S}${h?`: ${h}`:""}`)}try{return De(Ne(c))}catch{return {result:"success",data:{stdout:c.trim()}}}}async function We(e,t,r){let n=r?.label??"invokeExecutionRef",o;try{o=me(e.argsMassaging,Je(e,t),n);}catch(d){let f=d instanceof Error?d.message:String(d);return j(f)}let s=$(e.whatToRun),u=o.headers?{"Content-Type":"application/json",...o.headers}:{"Content-Type":"application/json"},l=o.url??s,g;if(e.howToRun==="http:get"){let d=o.body&&typeof o.body=="object"&&!Array.isArray(o.body)?o.body:t,f=new URLSearchParams(Object.entries(d).filter(([,m])=>m!=null).map(([m,S])=>[m,String(S)]));f.size>0&&(l=`${l}${l.includes("?")?"&":"?"}${f.toString()}`);}else g=JSON.stringify(o.body??t);let i={method:e.howToRun==="http:get"?"GET":"POST",headers:u,body:g},c=0;for(;;)try{let d=await fetch(l,i);if(!d.ok){let h=await d.text().catch(()=>"");return j(`[${n}] HTTP ${d.status}${h?`: ${h}`:""}`)}let f={};d.headers.forEach((h,w)=>{f[w]=h;});let m=new Uint8Array(await d.arrayBuffer());if(m.byteLength===0)return {result:"success",data:{},headers:f};let S=new TextDecoder().decode(m);try{return De(Ne(S),{headers:f})}catch{return {result:"success",data:{stdout:S},headers:f}}}catch(d){let f=d?.cause,m=f&&typeof f=="object"&&"code"in f?String(f.code||""):"";if((m==="ECONNRESET"||m==="UND_ERR_SOCKET")&&c===0){c+=1;continue}let h=d instanceof Error?d.message:String(d),w=f instanceof Error?`${f.name}: ${f.message}${m?` [${m}]`:""}`:f?String(f):"",p=o.url??s??"",x=`${h}${w?` (cause: ${w})`:""}${p?` url=${p}`:""}`;return j(`[${n}] ${x}`)}}async function jt(e,t,r){let n=r?.label??"invokeExecutionRef",o=$(e.whatToRun).trim();if(!o)return j(`[${n}] in-process-loop requires a non-empty handler key`);let s=ge.get(o);if(!s)return j(`[${n}] no in-process handler registered for: ${o}`);try{return await s(e,t,r)}catch(u){let l=u instanceof Error?u.message:String(u);return j(`[${n}] ${l}`)}}var $t={"local-node":async(e,t,r)=>L(e,t,r),"local-python":async(e,t,r)=>L(e,t,r),"local-process":async(e,t,r)=>L(e,t,r),"built-in":async(e,t,r)=>L(e,t,r),"http:post":We,"http:get":We,"in-process-loop":jt},Pt={"local-node":L,"local-python":L,"local-process":L,"built-in":L};async function H(e,t,r){let n=r?.transports?.[e.howToRun]??$t[e.howToRun];return n?n(e,t,r):j(`[${r?.label??"invokeExecutionRef"}] unsupported howToRun: ${e.howToRun}`)}function ye(e,t,r){let n=r?.syncTransports?.[e.howToRun]??Pt[e.howToRun];return n?n(e,t,r):j(`[${r?.label??"invokeExecutionRefSync"}] unsupported sync howToRun: ${e.howToRun}`)}function qt(e){return {invoke(t,r){return H(t,r,e)},invokeSync(t,r){return ye(t,r,e)}}}function Lt(e,t,r){return ye(e,t,r)}function he(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function Qt(e){return {...he(e),leaseToken:e.leaseToken,leaseExpiresAt:e.leaseExpiresAt}}function Ot(e){return {...he(e),reason:e.reason}}function K(e){return {enqueueRequest(t){return e.enqueue(t).id},enqueueRequestIfAbsent:e.enqueueIfAbsent?(t,r)=>{let n=e.enqueueIfAbsent(t,r);return n?n.id:null}:void 0,leaseRequests(t){return e.lease(t).map(Qt)},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,n){return e.nack(t,r,n)},peekActive(){return e.peekActive().map(he)},peekDeadLetter(){return e.peekDeadLetter().map(Ot)}}}function C(e,t){if(process.platform!=="win32"){a.renameSync(e,t);return}let r=[10,20,40,80,160];for(let n=0;n<=r.length;n++)try{a.renameSync(e,t);return}catch(o){let s=o.code;if((s==="EPERM"||s==="EBUSY")&&n<r.length){Atomics.wait(new Int32Array(new SharedArrayBuffer(4)),0,0,r[n]);continue}throw o}}function N(e){function t(o){return y.join(e,...o.split("/"))}function r(o){return y.relative(e,o).replace(/\\/g,"/")}function n(o,s){if(a.existsSync(o))for(let u of a.readdirSync(o,{withFileTypes:true})){let l=y.join(o,u.name);if(u.isDirectory()){n(l,s);continue}u.isFile()&&s.push(r(l));}}return {read(o){let s=t(o);if(!a.existsSync(s))return null;try{return a.readFileSync(s,"utf-8")}catch{return null}},write(o,s){let u=t(o),l=`${u}.${process.pid}.${randomUUID()}.tmp`;a.mkdirSync(y.dirname(u),{recursive:true}),a.writeFileSync(l,s,"utf-8"),C(l,u);},exists(o){return a.existsSync(t(o))},remove(o){let s=t(o);try{a.existsSync(s)&&a.unlinkSync(s);}catch{}},readBytes(o){let s=t(o);if(!a.existsSync(s))return null;try{return new Uint8Array(a.readFileSync(s))}catch{return null}},writeBytes(o,s){let u=t(o),l=`${u}.${process.pid}.${randomUUID()}.tmp`;a.mkdirSync(y.dirname(u),{recursive:true}),a.writeFileSync(l,Buffer.from(s)),C(l,u);},listKeys(o){let s=[];n(e,s);let u=s.sort();return o?u.filter(l=>l.startsWith(o)):u},stat(o){let s=t(o);if(!a.existsSync(s))return null;try{let u=a.statSync(s);return {key:o,size:Number(u.size||0),updatedAt:new Date(u.mtimeMs).toISOString()}}catch{return null}},keyRef(o){return {kind:"fs-path",value:t(o)}}}}function ke(){return {read(e){if(!a.existsSync(e))return null;try{return a.readFileSync(e,"utf-8")}catch{return null}},write(e,t){let r=`${e}.${process.pid}.${randomUUID()}.tmp`;a.mkdirSync(y.dirname(e),{recursive:true}),a.writeFileSync(r,t,"utf-8"),C(r,e);},exists(e){return a.existsSync(e)},remove(e){try{a.existsSync(e)&&a.unlinkSync(e);}catch{}},readBytes(e){if(!a.existsSync(e))return null;try{return new Uint8Array(a.readFileSync(e))}catch{return null}},writeBytes(e,t){let r=`${e}.${process.pid}.${randomUUID()}.tmp`;a.mkdirSync(y.dirname(e),{recursive:true}),a.writeFileSync(r,Buffer.from(t)),C(r,e);},stat(e){if(!a.existsSync(e))return null;try{let t=a.statSync(e);return {key:e,size:Number(t.size||0),updatedAt:new Date(t.mtimeMs).toISOString()}}catch{return null}},listKeys(e){return []}}}function U(e,t){let r=`${e}.${process.pid}.${randomUUID()}.tmp`;a.mkdirSync(y.dirname(e),{recursive:true}),a.writeFileSync(r,JSON.stringify(t,null,2),"utf-8"),C(r,e);}function _(e){if(!a.existsSync(e))return null;try{return JSON.parse(a.readFileSync(e,"utf-8"))}catch{return null}}function V(e){return a.existsSync(e)?a.readdirSync(e).filter(t=>t.endsWith(".json")).sort().map(t=>y.join(e,t)):[]}function z(e){return {id:e.id,body:e.body,enqueuedAt:e.enqueuedAt,attempt:e.attempt}}function Nt(e){return {...z(e),leaseToken:String(e.leaseToken||""),leaseExpiresAt:String(e.leaseExpiresAt||"")}}function Jt(e){return {...z(e),reason:e.reason}}function J(e){let t=y.join(e,"active"),r=y.join(e,"leased"),n=y.join(e,"done"),o=y.join(e,"dead");for(let c of [t,r,n,o])a.mkdirSync(c,{recursive:true});function s(c){let d=String(c.enqueuedAt||new Date().toISOString()).replace(/[:.]/g,"-");return y.join(t,`${d}-${c.id}.json`)}function u(c){return y.join(r,`${c}.json`)}function l(c){return y.join(n,`${c}.json`)}function g(c){return y.join(o,`${c}.json`)}function i(){let c=Date.now();for(let d of V(r)){let f=_(d);if(!f?.leaseExpiresAt)continue;let m=Date.parse(f.leaseExpiresAt);if(Number.isNaN(m)||m>c)continue;let S={id:f.id,body:f.body,enqueuedAt:f.enqueuedAt,attempt:f.attempt};U(s(S),S);try{a.unlinkSync(d);}catch{}}}return {enqueue(c){let d={id:randomUUID(),body:c,enqueuedAt:new Date().toISOString(),attempt:0};return U(s(d),d),z(d)},enqueueIfAbsent(c,d){i();for(let m of [t,r])for(let S of V(m))if(_(S)?.dedupKey===d)return null;let f={id:randomUUID(),body:c,enqueuedAt:new Date().toISOString(),attempt:0,dedupKey:d};return U(s(f),f),z(f)},lease(c){i();let d=Math.max(1,Math.floor(c?.max??1)),f=Math.max(1,Math.floor(c?.visibilityMs??6e4)),m=[];for(let S of V(t)){if(m.length>=d)break;let h=_(S);if(!h)continue;let w=u(h.id);try{C(S,w);}catch{continue}let p={...h,attempt:(Number(h.attempt)||0)+1,leaseToken:randomUUID(),leaseExpiresAt:new Date(Date.now()+f).toISOString()};U(w,p),m.push(Nt(p));}return m},ack(c,d){let f=u(c),m=_(f);if(!m||m.leaseToken!==d)return false;try{C(f,l(c));}catch{return false}return true},nack(c,d,f){let m=u(c),S=_(m);if(!S||S.leaseToken!==d)return false;let h={id:S.id,body:S.body,enqueuedAt:S.enqueuedAt,attempt:S.attempt};f?.dead?(h.reason=f.reason,U(g(c),h)):U(s(h),h);try{a.unlinkSync(m);}catch{}return true},peekActive(c){return i(),V(t).map(d=>_(d)).filter(d=>!!d).map(z)},peekDeadLetter(c){return V(o).map(d=>_(d)).filter(d=>!!d).map(Jt)}}}var Se="__scratch-marker",Re="__scratch-config.json",Dt=1440*60*1e3,Ht=720*60*1e3,Kt=500;function He(e,t){if(!e)return t;let r=e.replace(/[^A-Za-z0-9._-]/g,"_");return r.length>0?r:t}function G(e){a.mkdirSync(e,{recursive:true});let t=y.join(e,Se),r=y.join(e,Re),n=!a.existsSync(t);if(n)try{a.writeFileSync(t,`scratch-store
|
|
3
|
+
`,n=ce.get(e);if(n&&!n.socket.destroyed){n.ready?n.socket.write(o):n.queue.push(o);return}let s=$t(e),a=qe.createConnection(s);n={socket:a,ready:false,queue:[o]},ce.set(e,n),a.on("connect",()=>{n.ready=true;for(let g of n.queue)a.write(g);n.queue.length=0;}),a.on("error",g=>{r?.(`[named-pipe publish] ${s}: ${g instanceof Error?g.message:String(g)}`),ce.delete(e);}),a.on("close",()=>{ce.delete(e);});}function ze(){return {executeSync(e,t,r){return He({command:e,args:t,cwd:r?.cwd,timeoutMs:r?.timeout,env:r?.env},{encoding:r?.encoding,input:r?.input})},executeAsync(e,t,r){Ft({command:e,args:t},r);},resolveInvocation(e,t){let r=Pt({command:e,args:t});return {cmd:r.command,args:r.args??[]}},splitCommand:De}}function xe(e){return {id:e.id??"board-worker",pollIntervalMs:e.pollIntervalMs,visibilityMs:e.visibilityMs,concurrency:e.concurrency,maxAttempts:e.maxAttempts,async lease(t){return e.workerStore.leaseRequests(t).map(r=>({id:r.messageId,attempt:r.attempt,message:r.request,ack:()=>e.workerStore.ackRequest(r.messageId,r.leaseToken),nack:o=>e.workerStore.nackRequest(r.messageId,r.leaseToken,o)}))},async handle(t){await e.handleRequest(t.args,t);},onError:e.onError}}function we(e){return {id:e.id,pollIntervalMs:e.pollIntervalMs,visibilityMs:e.visibilityMs,concurrency:e.concurrency,maxAttempts:e.maxAttempts,async lease(t){return e.queueStorage.lease(t).map(r=>({id:r.id,attempt:r.attempt,message:r.body,ack:()=>e.queueStorage.ack(r.id,r.leaseToken),nack:o=>e.queueStorage.nack(r.id,r.leaseToken,o)}))},handle:e.handleMessage,onError:e.onError}}async function Ge(e,t){try{await e.handle(t.message,t),await t.ack();}catch(r){let o=t.attempt>=Math.max(1,Math.floor(e.maxAttempts??5));await t.nack({dead:o,reason:r instanceof Error?r.message:String(r)}),e.onError?.(r,t);}}function Ye(e){let t=Math.max(1,Math.floor(e.pollIntervalMs??250)),r=Math.max(1,Math.floor(e.visibilityMs??6e4)),o=Math.max(1,Math.floor(e.concurrency??1)),n=false,s=false;async function a(){if(!(n||s)){s=true;try{let S=await e.lease({max:o,visibilityMs:r});for(let c of S)await Ge(e,c);}finally{s=false;}}}let g=setInterval(()=>{a();},t);return typeof g.unref=="function"&&g.unref(),a(),()=>{n=true,clearInterval(g);}}async function Mt(e){let t=Math.max(1,Math.floor(e.visibilityMs??6e4)),r=Math.max(1,Math.floor(e.concurrency??1)),o=await e.lease({max:r,visibilityMs:t});for(let n of o)await Ge(e,n);return o.length}async function de(e,t){let r=Math.max(1,Math.floor(t?.maxPasses??256)),o=0;for(let n=0;n<r;n+=1){let s=await Mt(e);if(o+=s,s<=0)return o}throw new Error(`drainQueueLaneToIdle exceeded ${r} passes for lane "${e.id}"`)}function _t(e){let r=(Array.isArray(e)?e:e.lanes).map(o=>Ye(o));return ()=>{for(let o of r)o();}}var Ot=createRequire(import.meta.url);function qt(e){return typeof e=="object"?e:b(e)}function Xe(e){let t=x.basename(String(e||"").trim());if(!t)throw new Error(`resolveYamlFlowCliPath: expected non-empty cli file name, got ${JSON.stringify(e)}`);let r=x.dirname(Ot.resolve("yaml-flow/package.json")),o=t.replace(/\.[^.]+$/,""),n=x.join(r,"cli","bundled",`${o}.mjs`);if(i.existsSync(n))return n;let s=x.join(r,"cli","node",t);if(i.existsSync(s))return s;throw new Error(`resolveYamlFlowCliPath: could not find ${t} under cli/bundled or cli/node in ${r}`)}function q(e){let t=qt(e);return t.kind==="yaml-flow-cli"?Xe(t.value):t.value}function Nt(e,t){let r=q(e);switch(r){case "source-cli-task-executor":{let o=x.join(t,"source-cli-task-executor.js");if(i.existsSync(o))return {command:process.execPath,args:[o]};let n=x.join(t,"source-cli-task-executor.ts"),s=x.join(t,"..","..","node_modules","tsx","dist","cli.mjs"),a=x.join(t,"..","..","node_modules",".bin","tsx"),g=i.existsSync(s)?s:a;return i.existsSync(n)&&i.existsSync(g)?{command:process.execPath,args:[g,n]}:{command:process.execPath,args:[o]}}case "board-live-cards":{let{cmd:o,args:n}=Ke(t,"_",[]);return {command:o,args:n}}default:throw new Error(`resolveBuiltIn: unknown built-in name "${r}". Supported: source-cli-task-executor, board-live-cards`)}}function Qt(e,t){if(e.howToRun==="built-in"){let{command:o,args:n}=Nt(e.whatToRun,t);return {command:o,baseArgs:n}}let r=(typeof e.whatToRun=="object",q(e.whatToRun));switch(e.howToRun){case "local-node":return {command:process.execPath,baseArgs:[r]};case "local-python":return {command:process.platform==="win32"?"python":"python3",baseArgs:[r]};case "local-process":return {command:r,baseArgs:[]};default:throw new Error(`resolveBaseInvocation: howToRun "${e.howToRun}" is not a local transport`)}}function le(e,t){return Qt(e,t)}var ke=new Map;function Jt(e,t){let r=String(e||"").trim();if(!r)throw new Error("registerInProcessExecutionHandler: key is required");ke.set(r,t);}function Dt(e){let t=String(e||"").trim();t&&ke.delete(t);}function et(e){let t=e.trim();if(!t)throw new Error("empty stdout");try{return JSON.parse(t)}catch{let r=t.split(/\r?\n/).filter(Boolean),o=r[r.length-1];return JSON.parse(o)}}function tt(e,t){return {...t,whatToRun:q(e.whatToRun),...e.extra?{extra:e.extra}:{}}}function be(e,t,r="invokeExecutionRef"){return a(e,t,r)}function rt(e,t){if(e&&typeof e=="object"&&!Array.isArray(e)&&typeof e.result=="string"&&e.data&&typeof e.data=="object"&&!Array.isArray(e.data))return {...e,...t||{}};if(e&&typeof e=="object"&&!Array.isArray(e)&&typeof e.status=="string"){let o=e,n=o.status==="success"?"success":o.status==="fail"?"failure":o.status,s=o.data&&typeof o.data=="object"&&!Array.isArray(o.data)?o.data:o.data===void 0?{}:{stdout:o.data};return {result:n,data:s,...typeof o.error=="string"?{error:o.error}:{},...t||{}}}return {result:"success",data:e&&typeof e=="object"&&!Array.isArray(e)?e:{stdout:e},...t||{}}}function O(e){return {result:"failure",data:{error:e}}}function V(e,t,r){let o=r?.label??"invokeExecutionRefSync",n=r?.cliDir??r?.cwd??process.cwd(),s;try{s=be(e.argsMassaging,tt(e,t),o);}catch(h){let l=h instanceof Error?h.message:String(h);return O(l)}let a;try{a=le(e,n);}catch(h){let l=h instanceof Error?h.message:String(h);return O(`[${o}] ref resolution failed: ${l}`)}let g=[...a.baseArgs,...s.cmdArgs??[]],S=JSON.stringify(s.stdin??t),c=ze(),d;try{d=c.executeSync(a.command,g,{timeout:r?.timeoutMs??3e4,encoding:"utf-8",cwd:r?.cwd,input:S});}catch(h){let l=h,u=(l.stderr?String(l.stderr):"").trim(),p=typeof l.status=="number"?l.status:"unknown",m=u||l.message;return O(`[${o}] ref exited with status ${p}${m?`: ${m}`:""}`)}try{return rt(et(d))}catch{return {result:"success",data:{stdout:d.trim()}}}}async function Ze(e,t,r){let o=r?.label??"invokeExecutionRef",n;try{n=be(e.argsMassaging,tt(e,t),o);}catch(h){let l=h instanceof Error?h.message:String(h);return O(l)}let s=q(e.whatToRun),a=n.headers?{"Content-Type":"application/json",...n.headers}:{"Content-Type":"application/json"},g=n.url??s,S;if(e.howToRun==="http:get"){let h=n.body&&typeof n.body=="object"&&!Array.isArray(n.body)?n.body:t,l=new URLSearchParams(Object.entries(h).filter(([,u])=>u!=null).map(([u,p])=>[u,String(p)]));l.size>0&&(g=`${g}${g.includes("?")?"&":"?"}${l.toString()}`);}else S=JSON.stringify(n.body??t);let c={method:e.howToRun==="http:get"?"GET":"POST",headers:a,body:S},d=0;for(;;)try{let h=await fetch(g,c);if(!h.ok){let m=await h.text().catch(()=>"");return O(`[${o}] HTTP ${h.status}${m?`: ${m}`:""}`)}let l={};h.headers.forEach((m,R)=>{l[R]=m;});let u=new Uint8Array(await h.arrayBuffer());if(u.byteLength===0)return {result:"success",data:{},headers:l};let p=new TextDecoder().decode(u);try{return rt(et(p),{headers:l})}catch{return {result:"success",data:{stdout:p},headers:l}}}catch(h){let l=h?.cause,u=l&&typeof l=="object"&&"code"in l?String(l.code||""):"";if((u==="ECONNRESET"||u==="UND_ERR_SOCKET")&&d===0){d+=1;continue}let m=h instanceof Error?h.message:String(h),R=l instanceof Error?`${l.name}: ${l.message}${u?` [${u}]`:""}`:l?String(l):"",w=n.url??s??"",f=`${m}${R?` (cause: ${R})`:""}${w?` url=${w}`:""}`;return O(`[${o}] ${f}`)}}async function Wt(e,t,r){let o=r?.label??"invokeExecutionRef",n=q(e.whatToRun).trim();if(!n)return O(`[${o}] in-process-loop requires a non-empty handler key`);let s=ke.get(n);if(!s)return O(`[${o}] no in-process handler registered for: ${n}`);try{return await s(e,t,r)}catch(a){let g=a instanceof Error?a.message:String(a);return O(`[${o}] ${g}`)}}var Ht={"local-node":async(e,t,r)=>V(e,t,r),"local-python":async(e,t,r)=>V(e,t,r),"local-process":async(e,t,r)=>V(e,t,r),"built-in":async(e,t,r)=>V(e,t,r),"http:post":Ze,"http:get":Ze,"in-process-loop":Wt},Kt={"local-node":V,"local-python":V,"local-process":V,"built-in":V};async function Z(e,t,r){let o=r?.transports?.[e.howToRun]??Ht[e.howToRun];return o?o(e,t,r):O(`[${r?.label??"invokeExecutionRef"}] unsupported howToRun: ${e.howToRun}`)}function ve(e,t,r){let o=r?.syncTransports?.[e.howToRun]??Kt[e.howToRun];return o?o(e,t,r):O(`[${r?.label??"invokeExecutionRefSync"}] unsupported sync howToRun: ${e.howToRun}`)}function Vt(e){return {invoke(t,r){return Z(t,r,e)},invokeSync(t,r){return ve(t,r,e)}}}function Ut(e,t,r){return ve(e,t,r)}function Ae(e={}){let t=e.resolveRef??(r=>r);return {...e.executorTimeouts?{executorTimeouts:e.executorTimeouts}:{},async invokeExecutor(r,o,n){let s=t(r);if(s.howToRun==="queue-storage")throw new Error("queue-storage does not support inline executor request/response");if(s.howToRun==="http:post"||s.howToRun==="in-process-loop"){let d=await h(s,{subcommand:o,...n?.input!==void 0?{input:n.input}:{}});return typeof d=="string"?d:d&&typeof d=="object"&&!Array.isArray(d)&&typeof d.stdout=="string"?String(d.stdout):JSON.stringify(d??{})}if(s.howToRun==="http:get"){let d=await Z(s,{subcommand:o,...n?.input!==void 0?{input:n.input}:{},...s.extra?{extra:s.extra}:{}},{cwd:process.cwd(),timeoutMs:n?.timeout??3e4,label:`invokeExecutor:${o}`});if(d.result!=="success"){let h=typeof d.data?.error=="string"?d.data.error:d.error;throw new Error(h||`executor request failed: ${d.result}`)}return typeof d.data?.stdout=="string"?d.data.stdout:JSON.stringify(d.data??{})}if(!e.resolveCliDir)throw new Error(`createNonCoreExecutorDispatcher: ref.howToRun="${s.howToRun}" requires opts.resolveCliDir`);let{command:a,baseArgs:g}=le(s,e.resolveCliDir()),S=s.extra?["--extra",Buffer.from(JSON.stringify(s.extra)).toString("base64")]:[],c=[...g,o,...S];return await new Promise((d,h)=>{let l=spawn(a,c,{cwd:process.cwd(),stdio:"pipe",windowsHide:true,shell:process.platform==="win32"&&/\.(cmd|bat)$/i.test(a)}),u=[],p=[],m=false,R=null,w=y=>{m||(m=true,R&&clearTimeout(R),h(y));},f=y=>{m||(m=true,R&&clearTimeout(R),d(y));};l.stdout.on("data",y=>{u.push(Buffer.from(y));}),l.stderr.on("data",y=>{p.push(Buffer.from(y));}),l.on("error",y=>{let v=y;v.stdout=Buffer.concat(u).toString("utf-8"),v.stderr=Buffer.concat(p).toString("utf-8"),w(v);}),l.on("close",y=>{let v=Buffer.concat(u).toString("utf-8"),k=Buffer.concat(p).toString("utf-8");if(y===0){f(v);return}let b=new Error(k.trim()||`executor exited with status ${y}`);b.stdout=v,b.stderr=k,w(b);}),n?.timeout&&n.timeout>0&&(R=setTimeout(()=>{l.kill();let y=new Error(`executor timed out after ${n.timeout}ms`);y.stdout=Buffer.concat(u).toString("utf-8"),y.stderr=Buffer.concat(p).toString("utf-8"),w(y);},n.timeout)),n?.input!==void 0?l.stdin.end(n.input):l.stdin.end();})}}}function B(e,t){if(process.platform!=="win32"){i.renameSync(e,t);return}let r=[10,20,40,80,160];for(let o=0;o<=r.length;o++)try{i.renameSync(e,t);return}catch(n){let s=n.code;if((s==="EPERM"||s==="EBUSY")&&o<r.length){Atomics.wait(new Int32Array(new SharedArrayBuffer(4)),0,0,r[o]);continue}throw n}}function U(e){function t(n){return x.join(e,...n.split("/"))}function r(n){return x.relative(e,n).replace(/\\/g,"/")}function o(n,s){if(i.existsSync(n))for(let a of i.readdirSync(n,{withFileTypes:true})){let g=x.join(n,a.name);if(a.isDirectory()){o(g,s);continue}a.isFile()&&s.push(r(g));}}return {read(n){let s=t(n);if(!i.existsSync(s))return null;try{return i.readFileSync(s,"utf-8")}catch{return null}},write(n,s){let a=t(n),g=`${a}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(x.dirname(a),{recursive:true}),i.writeFileSync(g,s,"utf-8"),B(g,a);},exists(n){return i.existsSync(t(n))},remove(n){let s=t(n);try{i.existsSync(s)&&i.unlinkSync(s);}catch{}},readBytes(n){let s=t(n);if(!i.existsSync(s))return null;try{return new Uint8Array(i.readFileSync(s))}catch{return null}},writeBytes(n,s){let a=t(n),g=`${a}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(x.dirname(a),{recursive:true}),i.writeFileSync(g,Buffer.from(s)),B(g,a);},listKeys(n){let s=[];o(e,s);let a=s.sort();return n?a.filter(g=>g.startsWith(n)):a},stat(n){let s=t(n);if(!i.existsSync(s))return null;try{let a=i.statSync(s);return {key:n,size:Number(a.size||0),updatedAt:new Date(a.mtimeMs).toISOString()}}catch{return null}},keyRef(n){return {kind:"fs-path",value:t(n)}},renameKey(n,s){let a=t(n);if(!i.existsSync(a))return false;let g=t(s);return i.mkdirSync(x.dirname(g),{recursive:true}),B(a,g),true}}}function Ie(){return {read(e){if(!i.existsSync(e))return null;try{return i.readFileSync(e,"utf-8")}catch{return null}},write(e,t){let r=`${e}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(x.dirname(e),{recursive:true}),i.writeFileSync(r,t,"utf-8"),B(r,e);},exists(e){return i.existsSync(e)},remove(e){try{i.existsSync(e)&&i.unlinkSync(e);}catch{}},readBytes(e){if(!i.existsSync(e))return null;try{return new Uint8Array(i.readFileSync(e))}catch{return null}},writeBytes(e,t){let r=`${e}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(x.dirname(e),{recursive:true}),i.writeFileSync(r,Buffer.from(t)),B(r,e);},stat(e){if(!i.existsSync(e))return null;try{let t=i.statSync(e);return {key:e,size:Number(t.size||0),updatedAt:new Date(t.mtimeMs).toISOString()}}catch{return null}},listKeys(e){return []},renameKey(e,t){return i.existsSync(e)?(i.mkdirSync(x.dirname(t),{recursive:true}),B(e,t),true):false}}}function D(e,t){let r=`${e}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(x.dirname(e),{recursive:true}),i.writeFileSync(r,JSON.stringify(t,null,2),"utf-8"),B(r,e);}function N(e){if(!i.existsSync(e))return null;try{return JSON.parse(i.readFileSync(e,"utf-8"))}catch{return null}}function X(e){return i.existsSync(e)?i.readdirSync(e).filter(t=>t.endsWith(".json")).sort().map(t=>x.join(e,t)):[]}function ee(e){return {id:e.id,body:e.body,enqueuedAt:e.enqueuedAt,attempt:e.attempt}}function Zt(e){return {...ee(e),leaseToken:String(e.leaseToken||""),leaseExpiresAt:String(e.leaseExpiresAt||"")}}function Xt(e){return {...ee(e),reason:e.reason}}function je(e){let t=x.join(e,"active"),r=x.join(e,"leased"),o=x.join(e,"done"),n=x.join(e,"dead"),s=x.join(e,"staged");for(let l of [t,r,o,n,s])i.mkdirSync(l,{recursive:true});function a(l){let u=String(l.enqueuedAt||new Date().toISOString()).replace(/[:.]/g,"-");return x.join(t,`${u}-${l.id}.json`)}function g(l){return x.join(r,`${l}.json`)}function S(l){return x.join(o,`${l}.json`)}function c(l){return x.join(n,`${l}.json`)}function d(l){return x.join(s,`${l}.json`)}function h(){let l=Date.now();for(let u of X(r)){let p=N(u);if(!p?.leaseExpiresAt)continue;let m=Date.parse(p.leaseExpiresAt);if(Number.isNaN(m)||m>l)continue;let R={id:p.id,body:p.body,enqueuedAt:p.enqueuedAt,attempt:p.attempt};D(a(R),R);try{i.unlinkSync(u);}catch{}}}return {enqueue(l){let u={id:randomUUID(),body:l,enqueuedAt:new Date().toISOString(),attempt:0};return D(a(u),u),ee(u)},enqueueMany(l){return l.map(u=>this.enqueue(u))},enqueueIfAbsent(l,u){h();for(let m of [t,r,s])for(let R of X(m))if(N(R)?.dedupKey===u)return null;let p={id:randomUUID(),body:l,enqueuedAt:new Date().toISOString(),attempt:0,dedupKey:u};return D(a(p),p),ee(p)},lease(l){h();let u=Math.max(1,Math.floor(l?.max??1)),p=Math.max(1,Math.floor(l?.visibilityMs??6e4)),m=[];for(let R of X(t)){if(m.length>=u)break;let w=N(R);if(!w)continue;let f=g(w.id);try{B(R,f);}catch{continue}let y={...w,attempt:(Number(w.attempt)||0)+1,leaseToken:randomUUID(),leaseExpiresAt:new Date(Date.now()+p).toISOString()};D(f,y),m.push(Zt(y));}return m},ack(l,u){let p=g(l),m=N(p);if(!m||m.leaseToken!==u)return false;try{B(p,S(l));}catch{return false}return true},nack(l,u,p){let m=g(l),R=N(m);if(!R||R.leaseToken!==u)return false;let w={id:R.id,body:R.body,enqueuedAt:R.enqueuedAt,attempt:R.attempt};p?.dead?(w.reason=p.reason,D(c(l),w)):D(a(w),w);try{i.unlinkSync(m);}catch{}return true},peekActive(l){return h(),X(t).map(u=>N(u)).filter(u=>!!u).map(ee)},peekDeadLetter(l){return X(n).map(u=>N(u)).filter(u=>!!u).map(Xt)},stage(l,u){let p=u?.dedupKey;if(p){h();for(let R of [t,r,s])for(let w of X(R))if(N(w)?.dedupKey===p)return null}let m={id:randomUUID(),body:l,enqueuedAt:new Date().toISOString(),attempt:0,...p?{dedupKey:p}:{}};return D(d(m.id),m),ee(m)},commitStaged(l){let u=d(l),p=N(u);if(!p)return false;let m={...p,attempt:0,enqueuedAt:new Date().toISOString()};D(a(m),m);try{i.unlinkSync(u);}catch{}return true},discardStaged(l,u){let p=d(l),m=N(p);if(!m)return false;let R={id:m.id,body:m.body,enqueuedAt:m.enqueuedAt,attempt:m.attempt,reason:u};D(c(l),R);try{i.unlinkSync(p);}catch{}return true},peekStaged(l){return X(s).map(u=>N(u)).filter(u=>!!u).map(ee)}}}var Ee="__scratch-marker",Te="__scratch-config.json",er=1440*60*1e3,tr=720*60*1e3,rr=500;function nt(e,t){if(!e)return t;let r=e.replace(/[^A-Za-z0-9._-]/g,"_");return r.length>0?r:t}function oe(e){i.mkdirSync(e,{recursive:true});let t=x.join(e,Ee),r=x.join(e,Te),o=!i.existsSync(t);if(o)try{i.writeFileSync(t,`scratch-store
|
|
4
4
|
${new Date().toISOString()}
|
|
5
|
-
`,"utf-8");}catch{}function
|
|
5
|
+
`,"utf-8");}catch{}function n(){if(!i.existsSync(r))return {};try{let c=i.readFileSync(r,"utf-8"),d=JSON.parse(c);return d&&typeof d=="object"&&!Array.isArray(d)?d:{}}catch{return {}}}function s(c){let d=`${r}.${process.pid}.${randomUUID()}.tmp`;try{i.writeFileSync(d,JSON.stringify(c,null,2),"utf-8"),B(d,r);}catch{}}if(o){let c=n();typeof c["retention.lastSweepAt"]!="number"&&(c["retention.lastSweepAt"]=Date.now(),s(c));}function a(){if(!i.existsSync(t))return;let c=n(),d=typeof c["retention.maxAgeMs"]=="number"?c["retention.maxAgeMs"]:er,h=typeof c["retention.sweepIntervalMs"]=="number"?c["retention.sweepIntervalMs"]:tr;if(d<=0||h<=0)return;let l=typeof c["retention.lastSweepAt"]=="number"?c["retention.lastSweepAt"]:0,u=Date.now();if(u-l<h)return;c["retention.lastSweepAt"]=u,s(c);let p=u;try{let m=i.readdirSync(e,{withFileTypes:!0});for(let R of m){if(Date.now()-p>rr)break;if(!R.isFile()||R.name===Ee||R.name===Te)continue;let w=x.join(e,R.name);try{let f=i.statSync(w);if(u-f.mtimeMs>d)try{i.unlinkSync(w);}catch{}}catch{}}}catch{}}function g(c,d){let h=nt(c,"scratch"),l=nt(d,".json"),u=l.startsWith(".")?l:`.${l}`,p=`${h}-${Date.now()}-${randomUUID().slice(0,8)}${u}`;return x.join(e,p)}function S(c,d){let h=`${c}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(x.dirname(c),{recursive:true}),i.writeFileSync(h,d,"utf-8"),B(h,c);}return {read(c){if(!i.existsSync(c))return null;try{return i.readFileSync(c,"utf-8")}catch{return null}},write(c,d){S(c,d);try{a();}catch{}},exists(c){return i.existsSync(c)},remove(c){try{i.existsSync(c)&&i.unlinkSync(c);}catch{}},readBytes(c){if(!i.existsSync(c))return null;try{return new Uint8Array(i.readFileSync(c))}catch{return null}},writeBytes(c,d){let h=`${c}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(x.dirname(c),{recursive:true}),i.writeFileSync(h,Buffer.from(d)),B(h,c);try{a();}catch{}},stat(c){if(!i.existsSync(c))return null;try{let d=i.statSync(c);return {key:c,size:Number(d.size||0),updatedAt:new Date(d.mtimeMs).toISOString()}}catch{return null}},listKeys(c){try{let d=i.readdirSync(e,{withFileTypes:!0}),h=[];for(let l of d){if(!l.isFile()||l.name===Ee||l.name===Te)continue;let u=x.join(e,l.name);(!c||u.startsWith(c))&&h.push(u);}return h.sort()}catch{return []}},getUniqueKey(c,d){return g(c,d)},create(c,d,h){let l=g(d,h);S(l,c);try{a();}catch{}return l},keyRef(c){return {kind:"fs-path",value:c}},renameKey(c,d){return i.existsSync(c)?(i.mkdirSync(x.dirname(d),{recursive:true}),B(c,d),true):false},config:{get(c){return n()[c]??null},set(c,d){let h=n();d==null?delete h[c]:h[c]=d,s(h);}}}}var nr="__archive-marker",or="__archive-config.json",fe="streams",pe="blobs",sr=500;function ot(e){let t=e.replace(/[^A-Za-z0-9._-]/g,"_");if(!t)throw new Error("Archive segment name cannot be empty after sanitization");return t}function ge(e){i.mkdirSync(e,{recursive:true}),i.mkdirSync(x.join(e,fe),{recursive:true}),i.mkdirSync(x.join(e,pe),{recursive:true});let t=x.join(e,nr),r=x.join(e,or);if(!i.existsSync(t))try{i.writeFileSync(t,`archive-store
|
|
6
6
|
${new Date().toISOString()}
|
|
7
|
-
`,"utf-8");}catch{}function
|
|
8
|
-
`).filter(Boolean).map(
|
|
9
|
-
`,"utf-8"),
|
|
10
|
-
`).filter(Boolean).map(
|
|
11
|
-
`,"utf-8");},generateId(){return randomUUID()}}}function ze(e){return {tryAcquire(){try{if(!a.existsSync(e)){a.mkdirSync(y.dirname(e),{recursive:!0});try{a.writeFileSync(e,"{}",{flag:"wx"});}catch{}}return lockSync(e,{retries:0})}catch{return null}}}}function Lr(){return {async invoke(e,t){if(e.howToRun!=="local-node")return {dispatched:false,error:`createNodeSpawnInvocationAdapter: unsupported howToRun "${e.howToRun}"`};let r="";try{let s=e.whatToRun;r=$(s);}catch{r="";}if(!r)return {dispatched:false,error:"createNodeSpawnInvocationAdapter: could not resolve executable path from whatToRun"};let n={...t},o=Buffer.from(JSON.stringify(n)).toString("base64");try{return spawn(process.execPath,[r,"--boardId",String(t.boardId??""),"--cardId",String(t.cardId??""),"--extraEncJson",o],{stdio:"ignore",windowsHide:!0}).unref(),{dispatched:!0}}catch(s){return {dispatched:false,error:s instanceof Error?s.message:String(s)}}},async describe(e){if(e.howToRun!=="local-node")return null;let t="";try{let r=e.whatToRun;t=$(r);}catch{t="";}if(!t)return null;try{let r=spawnSync(process.execPath,[t,"describe"],{timeout:5e3,encoding:"utf-8",windowsHide:!0});return r.status!==0?null:JSON.parse(String(r.stdout).trim())}catch{return null}}}}var Yt=".board.lock";function Ye(e,t){if(!e||!t)return false;let r=String(e).replace(/[\\/]+$/,"").split(/[\\/]+/).filter(Boolean);return r.length>0&&r[r.length-1]===t}function Zt(e,t){return typeof e=="string"?{cliDir:e,opts:t}:{cliDir:void 0,opts:e}}function Xt(e,t){return typeof e=="string"?{cliDir:e,opts:t}:{cliDir:void 0,opts:e}}function Ze(e){if(e)return e;let t=Ce(import.meta.url),r=[t,b(t,"..","cli","node"),b(t,"..","..","cli","node")];for(let n of r)try{return Pe(n),n}catch{}throw new Error(`createFsBoardPlatformAdapter: could not resolve a public CLI directory from module dir ${t}`)}function er(e,t,r){let{cliDir:n,opts:o}=Zt(t,r),s=e.value,u,l=null,g$1,i,c,d=null,f;function m(){return f||(f=Ze(n)),f}let S=o?.callbackTransport??g(o?.notifyChannel),h;function w(){if(o?.suppressSpawn||l)return;let p=fe({id:"task-executor",workerStore:h.boardWorkerStore(),handleRequest:async(x,B)=>{let v=await H(B.ref,B.args,{cliDir:m(),cwd:process.cwd(),label:"fsBoardAdapter.boardWorker"});if(v.result!=="success"){let R=typeof v.data?.error=="string"?v.data.error:v.error;throw new Error(R||v.result)}}});l=ee(p).catch(x=>{o?.onWarn?.(`[board-worker] in-process queue drain failed: ${x instanceof Error?x.message:String(x)}`);}).finally(()=>{l=null,h.boardWorkerStore().peekActive().length>0&&w();});}return h={kvStorage:p=>se(b(s,`.${p}`)),blobStorage:p=>p?N(b(s,p)):N(s),scratchStorage:()=>G(b(s,".tmp")),scratchStorageForRef:p=>G(b$1(p).value),archiveFactory:()=>oe(b(s,"archive")),archiveFactoryForRef:p=>oe(b$1(p).value),journalAdapter:()=>Ve(s),boardWorkerStore:()=>(u||(u=K(J(b(s,".board-worker-queue")))),u),chatAgentStore:()=>(g$1||(g$1=K(J(b(s,".chat-agent-queue")))),g$1),processAccumulatedStore:()=>(i||(i=J(b(s,".process-accumulated-queue"))),i),lock:ze(b(s,Yt)),callbackTransport:S,async dispatchExecution(p,x){let B=!!x.output?.ref;if(p.howToRun==="queue-storage")try{let R=u??K(J(b(s,".board-worker-queue")));u||(u=R);let E=typeof p.extra?.boardId=="string"?p.extra.boardId:void 0;if(B)return R.enqueueRequest({boardId:E,ref:p,args:x}),{dispatched:!0};let M=x.source_def?.bindTo??X().slice(0,8),k=G(b(s,".tmp")),I=k.create(JSON.stringify(x,null,2),`exec-in-${M}`,".json"),D=k.getUniqueKey(`exec-out-${M}`,".json"),Q=k.getUniqueKey(`exec-err-${M}`,".txt"),ae=a$2(k.keyRef(I)),Y=a$2(k.keyRef(D)),ie=a$2(k.keyRef(Q));return R.enqueueRequest({boardId:E,ref:p,args:{subcommand:"run-source-fetch",inRef:ae,outRef:Y,errRef:ie}}),{dispatched:!0}}catch(R){return {dispatched:false,error:R instanceof Error?R.message:String(R)}}if(B&&(p.howToRun==="http:post"||p.howToRun==="in-process-loop"))try{if(p.howToRun==="http:post"){let M=$(p.whatToRun),k=await fetch(M,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...x,...p.extra?{extra:p.extra}:{}})});if(!k.ok){let I=await k.text().catch(()=>"");return {dispatched:!1,error:`HTTP ${k.status}: ${I}`}}return {dispatched:!0}}let R=await H(p,x,{cwd:process.cwd(),label:"dispatchExecution.directHostedWorker"});return R.result==="success"?{dispatched:!0}:{dispatched:!1,error:(typeof R.data?.error=="string"?R.data.error:R.error)||R.result}}catch(R){return {dispatched:false,error:R instanceof Error?R.message:String(R)}}let v=p.howToRun==="local-node"||p.howToRun==="local-process"||p.howToRun==="local-python"||p.howToRun==="built-in";if(o?.suppressSpawn&&v)return {dispatched:false};try{let R=x.source_def?.bindTo??X().slice(0,8),E=G(b(s,".tmp")),M=E.create(JSON.stringify(x,null,2),`exec-in-${R}`,".json"),k=E.getUniqueKey(`exec-out-${R}`,".json"),I=E.getUniqueKey(`exec-err-${R}`,".txt"),D=a$2(E.keyRef(M)),Q=a$2(E.keyRef(k)),ae=a$2(E.keyRef(I)),Y=u??K(J(b(s,".board-worker-queue")));u||(u=Y);let ie=typeof p.extra?.boardId=="string"?p.extra.boardId:void 0;return Y.enqueueRequest({boardId:ie,ref:p,args:{subcommand:"run-source-fetch",inRef:D,outRef:Q,errRef:ae}}),w(),{dispatched:!0}}catch(R){let E=R instanceof Error?R.message:String(R);try{let M=oe(b(s,"archive")),k=new Date().toISOString().replace(/[:.]/g,"-"),I=x.source_def?.bindTo??"unknown";M.blob("exec-failures").write(`${k}-${I}.json`,JSON.stringify({error:E,args:x,ref:p,at:new Date().toISOString()},null,2));}catch{}return {dispatched:false,error:E}}},supportsDirectSourceOutput(p){return p.howToRun==="queue-storage"||p.howToRun==="http:post"||p.howToRun==="in-process-loop"},resolveBlob(p){let x=Be(p.value)?ke().read(p.value):N(s).read(p.value);if(x===null)throw new Error(`resolveBlob: blob not found: ::${p.kind}::${p.value}`);return x},hashFn:Ue,genId:()=>Ie(`${Date.now()}-${Math.random()}`).slice(0,32),kvStorageForRef:p=>se(b$1(p).value),requestProcessAccumulated(){if(o?.suppressSpawn||d)return;let p=this,x=c??=y$1(e,p),B=pe({id:"process-accumulated",queueStorage:p.processAccumulatedStore(),handleMessage:async()=>{let v=await x.processAccumulatedEvents({});if(v.status!=="success")throw new Error(v.error||`processAccumulatedEvents returned ${v.status}`)}});d=ee(B).catch(v=>{o?.onWarn?.(`[process-accumulated] in-process queue drain failed: ${v instanceof Error?v.message:String(v)}`);}).finally(()=>{d=null,p.processAccumulatedStore().peekActive().length>0&&p.requestProcessAccumulated?.();});},publishBoardChangeNotifications(p){if(!o?.notifyChannel||p.length===0)return;let x=p.map(B=>({id:X(),ts:new Date().toISOString(),boardRef:a$2(e),notification:B}));qe(o.notifyChannel,x,o.onWarn);},onWarn:o?.onWarn},h}function Qr(e,t,r){let{cliDir:n,opts:o}=Xt(t,r),s,u=()=>(s||(s=Ze(n)),s);return {...er(e,n,o),async invokeExecutor(g,i,c){if(g.howToRun==="queue-storage")throw new Error("queue-storage does not support inline executor request/response");if(g.howToRun==="http:post"||g.howToRun==="http:get"||g.howToRun==="in-process-loop"){let h=await H(g,{subcommand:i,...c?.input!==void 0?{input:c.input}:{},...g.extra?{extra:g.extra}:{}},{cwd:process.cwd(),timeoutMs:c?.timeout??3e4,label:`invokeExecutor:${i}`});if(h.result!=="success"){let w=typeof h.data?.error=="string"?h.data.error:h.error;throw new Error(w||`executor request failed: ${h.result}`)}return typeof h.data?.stdout=="string"?h.data.stdout:JSON.stringify(h.data??{})}let{command:d,baseArgs:f}=te(g,u()),m=g.extra?["--extra",Buffer.from(JSON.stringify(g.extra)).toString("base64")]:[],S=[...f,i,...m];return await new Promise((h,w)=>{let p=spawn(d,S,{cwd:process.cwd(),stdio:"pipe",windowsHide:true,shell:process.platform==="win32"&&/\.(cmd|bat)$/i.test(d)}),x=[],B=[],v=false,R=null,E=k=>{v||(v=true,R&&clearTimeout(R),w(k));},M=k=>{v||(v=true,R&&clearTimeout(R),h(k));};p.stdout.on("data",k=>{x.push(Buffer.from(k));}),p.stderr.on("data",k=>{B.push(Buffer.from(k));}),p.on("error",k=>{let I=k;I.stdout=Buffer.concat(x).toString("utf-8"),I.stderr=Buffer.concat(B).toString("utf-8"),E(I);}),p.on("close",k=>{let I=Buffer.concat(x).toString("utf-8"),D=Buffer.concat(B).toString("utf-8");if(k===0){M(I);return}let Q=new Error(D.trim()||`executor exited with status ${k}`);Q.stdout=I,Q.stderr=D,E(Q);}),c?.timeout&&c.timeout>0&&(R=setTimeout(()=>{p.kill();let k=new Error(`executor timed out after ${c.timeout}ms`);k.stdout=Buffer.concat(x).toString("utf-8"),k.stderr=Buffer.concat(B).toString("utf-8"),E(k);},c.timeout)),c?.input!==void 0?p.stdin.end(c.input):p.stdin.end();})},validateSchema(g){let i=d(g);return {ok:i.errors.length===0,errors:i.errors}},absoluteBlob:ke()}}function Or(e,t={}){let r=t.chatsSubdir??"chats",n=t.kvSubdir??".kv",o=n?[n,"chat"]:["chat"],s=r&&!Ye(e,r)?b(e,r):e,u=se(b(e,...o));return a$3(l=>{let i=`${String(l).replace(/[^a-zA-Z0-9_-]/g,"_")}.jsonl`,c=b(s,i);return we(c)},u)}function Wr(e,t={}){let r=t.filesSubdir??"files",n=r&&!Ye(e,r)?b(e,r):e;return c(N(n))}function _r(e){try{let t=JSON.parse(Buffer.from(e,"base64url").toString());return typeof t.br=="string"?t.br:null}catch{return null}}export{te as buildLocalBaseSpec,fe as createBoardWorkerQueueLane,K as createBoardWorkerStore,qt as createExecutionRefInvoker,N as createFsBlobStorage,Or as createFsBoardChatStorage,Wr as createFsBoardFileArtifactsStore,Qr as createFsBoardNonCorePlatformAdapter,er as createFsBoardPlatformAdapter,J as createFsQueueStorage,Lr as createNodeSpawnInvocationAdapter,pe as createQueueStorageLane,_r as decodeBoardRefFromToken,ee as drainQueueLaneToIdle,me as evaluateArgsMassaging,H as invokeExecutionRef,ye as invokeExecutionRefSync,Lt as invokeRefSync,Mt as registerInProcessExecutionHandler,$ as resolveWhatToRunValue,_e as resolveYamlFlowCliPath,Oe as startQueueLaneRunner,At as startQueueLaneRunners,Ft as unregisterInProcessExecutionHandler};//# sourceMappingURL=board-live-cards-node.js.map
|
|
7
|
+
`,"utf-8");}catch{}function o(){if(!i.existsSync(r))return {};try{let a=i.readFileSync(r,"utf-8"),g=JSON.parse(a);return g&&typeof g=="object"&&!Array.isArray(g)?g:{}}catch{return {}}}function n(a){let g=`${r}.${process.pid}.${randomUUID()}.tmp`;try{i.writeFileSync(g,JSON.stringify(a,null,2),"utf-8"),B(g,r);}catch{}}function s(){if(!i.existsSync(t))return;let a=o(),g=typeof a["retention.maxAgeMs"]=="number"?a["retention.maxAgeMs"]:0,S=typeof a["retention.sweepIntervalMs"]=="number"?a["retention.sweepIntervalMs"]:0;if(g<=0||S<=0)return;let c=typeof a["retention.lastSweepAt"]=="number"?a["retention.lastSweepAt"]:0,d=Date.now();if(d-c<S)return;a["retention.lastSweepAt"]=d,n(a);let h=d,l=u=>{let p;try{p=i.readdirSync(u,{withFileTypes:!0});}catch{return}for(let m of p){if(Date.now()-h>sr)return;let R=x.join(u,m.name);if(m.isDirectory()){l(R);continue}if(m.isFile())try{let w=i.statSync(R);if(d-w.mtimeMs>g)try{i.unlinkSync(R);}catch{}}catch{}}};l(x.join(e,fe)),l(x.join(e,pe));}return {stream(a){let g=ot(a),S=x.join(e,fe,`${g}.jsonl`),c=me(S);return {append(d){let h=c.append(d);try{s();}catch{}return h},readAll:()=>c.readAll(),readAfter:d=>c.readAfter(d),clear:()=>{c.clear&&c.clear();}}},blob(a){let g=ot(a),S=x.join(e,pe,g);i.mkdirSync(S,{recursive:true});let c=U(S);return {read:d=>c.read(d),write:(d,h)=>{c.write(d,h);try{s();}catch{}},exists:d=>c.exists(d),remove:d=>c.remove(d),readBytes:c.readBytes?d=>c.readBytes(d):void 0,writeBytes:c.writeBytes?(d,h)=>{c.writeBytes(d,h);try{s();}catch{}}:void 0,listKeys:d=>c.listKeys(d),stat:c.stat?d=>c.stat(d):void 0,renameKey:(d,h)=>c.renameKey(d,h)}},listStreams(a){let g=x.join(e,fe);try{return i.readdirSync(g,{withFileTypes:!0}).filter(S=>S.isFile()&&S.name.endsWith(".jsonl")).map(S=>S.name.slice(0,-6)).filter(S=>!a||S.startsWith(a)).sort()}catch{return []}},listBlobs(a){let g=x.join(e,pe);try{return i.readdirSync(g,{withFileTypes:!0}).filter(S=>S.isDirectory()).map(S=>S.name).filter(S=>!a||S.startsWith(a)).sort()}catch{return []}},config:{get(a){return o()[a]??null},set(a,g){let S=o();g==null?delete S[a]:S[a]=g,n(S);}}}}function se(e){function t(o){return x.join(e,...o.split("/"))+".json"}function r(o,n,s,a){if(i.existsSync(o))for(let g of i.readdirSync(o,{withFileTypes:true})){let S=n?`${n}/${g.name}`:g.name;if(g.isDirectory()){r(x.join(o,g.name),S,s,a);continue}if(!g.isFile()||!g.name.endsWith(".json"))continue;let c=S.replace(/\.json$/,"");(!s||c.startsWith(s))&&a.push(c);}}return {read(o){let n=t(o);if(!i.existsSync(n))return null;try{return JSON.parse(i.readFileSync(n,"utf-8"))}catch{return null}},write(o,n){let s=t(o),a=`${s}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(x.dirname(s),{recursive:true}),i.writeFileSync(a,JSON.stringify(n,null,2),"utf-8"),B(a,s);},delete(o){let n=t(o);try{i.existsSync(n)&&i.unlinkSync(n);}catch{}},listKeys(o){let n=[];return r(e,"",o,n),n.sort()}}}function me(e){function t(){if(!i.existsSync(e))return [];let r=i.readFileSync(e,"utf-8").trim();return r?r.split(`
|
|
8
|
+
`).filter(Boolean).map(o=>JSON.parse(o)):[]}return {append(r){let o={id:randomUUID(),payload:r};return i.mkdirSync(x.dirname(e),{recursive:true}),i.appendFileSync(e,JSON.stringify(o)+`
|
|
9
|
+
`,"utf-8"),o},readAll(){return t()},readAfter(r){let o=t();if(!r)return {entries:o,newCursor:o.length>0?o[o.length-1].id:null};let n=o.findIndex(a=>a.id===r),s=n===-1?o:o.slice(n+1);return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},clear(){i.existsSync(e)&&i.truncateSync(e,0);}}}function Ce(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return `[${e.map(Ce).join(",")}]`;let t=e;return `{${Object.keys(t).sort().map(o=>`${JSON.stringify(o)}:${Ce(t[o])}`).join(",")}}`}function st(e){return createHash("sha256").update(Ce(e)).digest("hex")}function Be(e){let t=x.join(e,"board-journal.jsonl");return {readAllEntries(){if(!i.existsSync(t))return [];let r=i.readFileSync(t,"utf-8").trim();return r?r.split(`
|
|
10
|
+
`).filter(Boolean).map(o=>JSON.parse(o)):[]},appendEntry(r){i.appendFileSync(t,JSON.stringify(r)+`
|
|
11
|
+
`,"utf-8");},generateId(){return randomUUID()}}}function it(e){return {tryAcquire(){try{if(!i.existsSync(e)){i.mkdirSync(x.dirname(e),{recursive:!0});try{i.writeFileSync(e,"{}",{flag:"wx"});}catch{}}return lockSync(e,{retries:0})}catch{return null}}}}function z(e){return {status:"success",data:e}}function Q(e){return {status:"fail",error:e}}function re(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function ne(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}function ir(e,t={}){let r=()=>b$1(e.kvStorage("config")),o=t.unsupportedLabel??"hosted async runtime";async function n(){return t.taskExecutorRef?t.taskExecutorRef:await r().readTaskExecutorRef().catch(()=>{})}async function s(u,p,m){let R=await n();if(!R||!t.invokeExecutor)throw new Error(`${u} is not supported on the ${o} yet`);let f=(await t.invokeExecutor(R,u,{...p!==void 0?{input:typeof p=="string"?p:JSON.stringify(p)}:{},...m!==void 0?{timeout:m}:{}})).trim();return f?ne(JSON.parse(f)):{}}async function a(u){try{if(!u.body||typeof u.body!="object"||Array.isArray(u.body))return Q("validateCardPreflight requires card JSON object in body");let p=u.body,m=p["card-content"]??p,R=typeof m.id=="string"?m.id:"(unknown)",w=a$5(m),f=Array.isArray(m.source_defs)&&m.source_defs.length>0,y=[...w.issues];if(f)if(t.invokeExecutor&&await n())for(let v of m.source_defs){let k=typeof v.bindTo=="string"?v.bindTo:"(unknown)";try{let b=await s("validate-source-def",v,1e4);if(b.ok!==!0&&Array.isArray(b.errors))for(let A of b.errors)typeof A=="string"&&A&&y.push(`source "${k}": ${A}`);}catch(b){y.push(`source "${k}": executor validate-source-def failed \u2014 ${b instanceof Error?b.message:String(b)}`);}}else await n()&&y.push(`executor-backed source_def preflight is not supported on the ${o} yet`);return z({cardId:R,isValid:y.length===0,issues:y})}catch(p){return re(p)}}function g(u){try{if(!u.body||typeof u.body!="object"||Array.isArray(u.body))return Q("evalCardCompute requires a JSON object in body");let p=u.body,m=p["card-content"]??p,R=typeof m.id=="string"?m.id:"(unknown)",w=p["mock-fetched-sources"]??{},f=p["mock-requires"]??{},y=m.compute;if(!y||!Array.isArray(y)||y.length===0)return z({cardId:R,ok:!0,computed_values:{},errors:[]});let v={id:R,card_data:m.card_data??{},requires:f,source_defs:m.source_defs,compute:y},k=a$6.runSync(v,{sourcesData:w});return z({cardId:R,ok:(k.errors??[]).length===0,computed_values:k.node.computed_values??{},errors:k.errors??[]})}catch(p){return re(p)}}async function S(u){return Q(`${u} is not supported on the ${o} yet`)}async function c(){try{return t.invokeExecutor&&await n()?z(await s("describe-capabilities",void 0,1e4)):await S("describeTaskExecutorCapabilities")}catch(u){return re(u)}}async function d(u){try{if(!t.invokeExecutor||!await n())return await S("probeSourcePreflight");if(!u.body||typeof u.body!="object"||Array.isArray(u.body))return Q("probeSourcePreflight requires card JSON object in body");let p=u.body,m=p["card-content"]??p,R=ne(p["mock-projections"]??{}),w=u.params?.sourceIdx,f=Array.isArray(m.source_defs)?m.source_defs:[];if(w===void 0)return Q("probeSourcePreflight requires params.sourceIdx");if(w<0||w>=f.length)return Q(`sourceIdx ${w} out of range (card has ${f.length} source(s))`);let y=f[w],v=typeof y.bindTo=="string"?y.bindTo:"source",k=await s("probe-source-preflight",{...y,_projections:R},y.timeout??6e4);return k.ok!==!0?Q(typeof k.error=="string"?k.error:"Preflight probe failed"):z({bindTo:v,reachable:k.reachable,latencyMs:k.latencyMs,...typeof k.note=="string"?{note:k.note}:{}})}catch(p){return re(p)}}async function h(u){try{if(!t.invokeExecutor||!await n())return await S("runSourcePreflight");if(!u.body||typeof u.body!="object"||Array.isArray(u.body))return Q("runSourcePreflight requires card JSON object in body");let p=u.body,m=p["card-content"]??p,R=ne(p["mock-projections"]??{}),w=u.params?.sourceIdx,f=Array.isArray(m.source_defs)?m.source_defs:[];if(w===void 0)return Q("runSourcePreflight requires params.sourceIdx");if(w<0||w>=f.length)return Q(`sourceIdx ${w} out of range (card has ${f.length} source(s))`);let y=f[w],v=typeof y.bindTo=="string"?y.bindTo:"source",k=await s("run-source-preflight",{...y,_projections:R},y.timeout??6e4);return k.ok!==!0?z({bindTo:v,ok:!1,result:null,issues:[typeof k.error=="string"?k.error:"Preflight run failed"]}):z({bindTo:v,ok:!0,result:Object.prototype.hasOwnProperty.call(k,"resultValue")?k.resultValue:null,issues:[]})}catch(p){return re(p)}}async function l(u){try{if(!u.body||typeof u.body!="object"||Array.isArray(u.body))return Q("simulateCardCycle requires a JSON object in body");let p=u.body,m=p["card-content"]??p,R=typeof m.id=="string"?m.id:"(unknown)",w=ne(p["mock-fetched-sources"]??{}),f=ne(p["mock-requires"]??{}),y=await a({body:{"card-content":m}}),v=y.status==="success"?{isValid:y.data.isValid,issues:y.data.issues}:{isValid:!1,issues:[y.status==="fail"?y.error:"internal error"]},k=Array.isArray(m.source_defs)?m.source_defs:[],b=ne(m.card_data??{}),A=[],F=[];if(k.length>0){A=a$6.enrichSourcesSync(k,{card_data:b,requires:f});for(let I of A){let P=I.projections,H=I._projections;if(P&&H){for(let $ of Object.keys(P))if(H[$]===void 0){let ut=typeof I.bindTo=="string"?I.bindTo:"(unknown)";F.push({bindTo:ut,key:$,error:`Projection "${$}" resolved to undefined`});}}}}let E=[],M={...w};for(let I=0;I<A.length;I+=1){let P=A[I],H=typeof P.bindTo=="string"?P.bindTo:`source_${I}`;if(!t.invokeExecutor||!await n()){E.push({bindTo:H,skipped:!0,error:"No task executor configured"});continue}try{let $=await s("run-source-preflight",P,P.timeout??6e4);$.ok===!0&&!Object.prototype.hasOwnProperty.call(w,H)&&Object.prototype.hasOwnProperty.call($,"resultValue")&&(M[H]=$.resultValue),E.push({bindTo:H,reachable:$.reachable,latencyMs:$.latencyMs,...$.ok===!0?{}:{error:typeof $.error=="string"?$.error:"Preflight run failed"}});}catch{E.push({bindTo:H,skipped:!0,error:"Executor does not support run-source-preflight"});}}let W=m.compute,te={},G=[];if(W&&Array.isArray(W)&&W.length>0){let I={id:R,card_data:b,requires:f,source_defs:m.source_defs,compute:W},P=a$6.runSync(I,{sourcesData:M});te=P.node.computed_values??{},G=P.errors??[];}return z({cardId:R,ok:v.isValid&&F.length===0&&G.length===0&&E.every(I=>!I.error),validation:v,source_probes:E,projection_errors:F,fetched_sources:M,computed_values:te,compute_errors:G})}catch(p){return re(p)}}return {describeTaskExecutorCapabilities:c,validateCardPreflight:a,evalCardCompute:g,probeSourcePreflight:d,runSourcePreflight:h,simulateCardCycle:l}}function on(){return {async invoke(e,t){if(e.howToRun!=="local-node")return {dispatched:false,error:`createNodeSpawnInvocationAdapter: unsupported howToRun "${e.howToRun}"`};let r="";try{let s=e.whatToRun;r=q(s);}catch{r="";}if(!r)return {dispatched:false,error:"createNodeSpawnInvocationAdapter: could not resolve executable path from whatToRun"};let o={...t},n=Buffer.from(JSON.stringify(o)).toString("base64");try{return spawn(process.execPath,[r,"--boardId",String(t.boardId??""),"--cardId",String(t.cardId??""),"--extraEncJson",n],{stdio:"ignore",windowsHide:!0}).unref(),{dispatched:!0}}catch(s){return {dispatched:false,error:s instanceof Error?s.message:String(s)}}},async describe(e){if(e.howToRun!=="local-node")return null;let t="";try{let r=e.whatToRun;t=q(r);}catch{t="";}if(!t)return null;try{let r=spawnSync(process.execPath,[t,"describe"],{timeout:5e3,encoding:"utf-8",windowsHide:!0});return r.status!==0?null:JSON.parse(String(r.stdout).trim())}catch{return null}}}}var ur=".board.lock";function at(e,t){if(!e||!t)return false;let r=String(e).replace(/[\\/]+$/,"").split(/[\\/]+/).filter(Boolean);return r.length>0&&r[r.length-1]===t}function dr(e,t){return typeof e=="string"?{cliDir:e,opts:t}:{cliDir:void 0,opts:e}}function lr(e,t){return typeof e=="string"?{cliDir:e,opts:t}:{cliDir:void 0,opts:e}}function ct(e){if(e)return e;let t=Je(import.meta.url),r=[t,C(t,"..","cli","node"),C(t,"..","..","cli","node")];for(let o of r)try{return Ve(o),o}catch{}throw new Error(`createFsBoardPlatformAdapter: could not resolve a public CLI directory from module dir ${t}`)}function fr(e,t,r){let{cliDir:o,opts:n}=dr(t,r),s=e.value,a=null,g$1,S=null,c;function d(){return c||(c=ct(o)),c}function h(f){let y=n?.queueStoreRef;if(!y)throw new Error(`createFsBoardPlatformAdapter: ${f} requires opts.queueStoreRef`);return y}function l(f){let y=n?.boardRuntimeStoreRef;if(!y)throw new Error(`createFsBoardPlatformAdapter: ${f} requires opts.boardRuntimeStoreRef`);return y}let u=n?.callbackTransport??g({notifyChannel:n?.notifyChannel,boardRuntimeStoreRef:n?.boardRuntimeStoreRef,queueStoreRef:n?.queueStoreRef}),p;function m(f){return p.queueStorageForRef(h(`internal lane "${f}"`),f)}function R(f){return a$4(m(f))}function w(){if(n?.suppressSpawn||a)return;let f=xe({id:"task-executor",workerStore:R("task-executor"),handleRequest:async(y,v)=>{let k=await Z(v.ref,v.args,{cliDir:d(),cwd:process.cwd(),label:"fsBoardAdapter.boardWorker"});if(k.result!=="success"){let b=typeof k.data?.error=="string"?k.data.error:k.error;throw new Error(b||k.result)}}});a=de(f).catch(y=>{n?.onWarn?.(`[board-worker] in-process queue drain failed: ${y instanceof Error?y.message:String(y)}`);}).finally(()=>{a=null,m("task-executor").peekActive().length>0&&w();});}return p={kvStorage:f=>se(C(s,`.${f}`)),blobStorage:f=>f?U(C(s,f)):U(s),blobStorageForRef:f=>U(b(f).value),chatStorageForRef:f=>pr(b(f).value),queueStorageForRef:(f,y)=>je(C(b(f).value,y)),scratchStorage:()=>oe(C(s,".tmp")),scratchStorageForRef:f=>oe(b(f).value),archiveFactory:()=>ge(C(s,"archive")),archiveFactoryForRef:f=>ge(b(f).value),journalAdapter:()=>Be(s),journalAdapterForRef:f=>Be(b(f).value),lock:it(C(s,ur)),callbackTransport:u,async dispatchExecution(f,y){let v=!!y.output?.ref;if(f.howToRun==="queue-storage")try{let b=R("task-executor"),A=typeof f.extra?.boardId=="string"?f.extra.boardId:void 0;if(v)return b.enqueueRequest({boardId:A,ref:f,args:y}),{dispatched:!0};let F=y.source_def?.bindTo??ue().slice(0,8),E=oe(C(s,".tmp")),M=E.create(JSON.stringify(y,null,2),`exec-in-${F}`,".json"),W=E.getUniqueKey(`exec-out-${F}`,".json"),te=E.getUniqueKey(`exec-err-${F}`,".txt"),G=a$1(E.keyRef(M)),I=a$1(E.keyRef(W)),P=a$1(E.keyRef(te));return b.enqueueRequest({boardId:A,ref:f,args:{subcommand:"run-source-fetch",inRef:G,outRef:I,errRef:P}}),{dispatched:!0}}catch(b){return {dispatched:false,error:b instanceof Error?b.message:String(b)}}if(v&&(f.howToRun==="http:post"||f.howToRun==="in-process-loop"))try{if(f.howToRun==="http:post"){let F=q(f.whatToRun),E=await fetch(F,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...y,...f.extra?{extra:f.extra}:{}})});if(!E.ok){let M=await E.text().catch(()=>"");return {dispatched:!1,error:`HTTP ${E.status}: ${M}`}}return {dispatched:!0}}let b=await Z(f,y,{cwd:process.cwd(),label:"dispatchExecution.directHostedWorker"});return b.result==="success"?{dispatched:!0}:{dispatched:!1,error:(typeof b.data?.error=="string"?b.data.error:b.error)||b.result}}catch(b){return {dispatched:false,error:b instanceof Error?b.message:String(b)}}let k=f.howToRun==="local-node"||f.howToRun==="local-process"||f.howToRun==="local-python"||f.howToRun==="built-in";if(n?.suppressSpawn&&k)return {dispatched:false};try{let b=y.source_def?.bindTo??ue().slice(0,8),A=oe(C(s,".tmp")),F=A.create(JSON.stringify(y,null,2),`exec-in-${b}`,".json"),E=A.getUniqueKey(`exec-out-${b}`,".json"),M=A.getUniqueKey(`exec-err-${b}`,".txt"),W=a$1(A.keyRef(F)),te=a$1(A.keyRef(E)),G=a$1(A.keyRef(M)),I=R("task-executor"),P=typeof f.extra?.boardId=="string"?f.extra.boardId:void 0;return I.enqueueRequest({boardId:P,ref:f,args:{subcommand:"run-source-fetch",inRef:W,outRef:te,errRef:G}}),w(),{dispatched:!0}}catch(b){let A=b instanceof Error?b.message:String(b);try{let F=ge(C(s,"archive")),E=new Date().toISOString().replace(/[:.]/g,"-"),M=y.source_def?.bindTo??"unknown";F.blob("exec-failures").write(`${E}-${M}.json`,JSON.stringify({error:A,args:y,ref:f,at:new Date().toISOString()},null,2));}catch{}return {dispatched:false,error:A}}},supportsDirectSourceOutput(f){return f.howToRun==="queue-storage"||f.howToRun==="http:post"||f.howToRun==="in-process-loop"},resolveBlob(f){let y=Ne(f.value)?Ie().read(f.value):U(s).read(f.value);if(y===null)throw new Error(`resolveBlob: blob not found: ::${f.kind}::${f.value}`);return y},hashFn:st,genId:()=>Qe(`${Date.now()}-${Math.random()}`).slice(0,32),kvStorageForRef:f=>se(b(f).value),requestProcessAccumulated(){if(n?.suppressSpawn||S)return;let f=this,y$1=g$1??=y(e,f,{boardRuntimeStoreRef:l("requestProcessAccumulated")}),v=we({id:"process-accumulated",queueStorage:m("process-accumulated"),handleMessage:async()=>{let k=await y$1.processAccumulatedEvents({});if(k.status!=="success")throw new Error(k.error||`processAccumulatedEvents returned ${k.status}`)}});S=de(v).catch(k=>{n?.onWarn?.(`[process-accumulated] in-process queue drain failed: ${k instanceof Error?k.message:String(k)}`);}).finally(()=>{S=null,m("process-accumulated").peekActive().length>0&&f.requestProcessAccumulated?.();});},publishBoardChangeNotifications(f){if(!n?.notifyChannel||f.length===0)return;let y=f.map(v=>({id:ue(),ts:new Date().toISOString(),boardRef:a$1(e),notification:v}));Ue(n.notifyChannel,y,n.onWarn);},onWarn:n?.onWarn},p}function sn(e,t,r){let{cliDir:o,opts:n}=lr(t,r),s,a=()=>(s||(s=ct(o)),s),g=fr(e,o,n),S=Ae({resolveCliDir:a,...n?.resolveRef?{resolveRef:n.resolveRef}:{}});return {...g,invokeExecutor:S.invokeExecutor,validateSchema(c){let d$1=d(c);return {ok:d$1.errors.length===0,errors:d$1.errors}},absoluteBlob:Ie()}}function an(e,t={}){let r=t.chatsSubdir??"chats",o=t.kvSubdir??".kv",n=o?[o,"chat"]:["chat"],s=r&&!at(e,r)?C(e,r):e,a=se(C(e,...n));return a$2(g=>{let c=`${String(g).replace(/[^a-zA-Z0-9_-]/g,"_")}.jsonl`,d=C(s,c);return me(d)},a)}function pr(e){return a$2(t=>{let o=`${String(t).replace(/[^a-zA-Z0-9_-]/g,"_")}.jsonl`;return me(C(e,"journal",o))},se(C(e,"kv")))}function cn(e,t={}){let r=t.filesSubdir??"files",o=r&&!at(e,r)?C(e,r):e;return a$3(U(o))}function un(e){try{let t=JSON.parse(Buffer.from(e,"base64url").toString());return typeof t.br=="string"?t.br:null}catch{return null}}export{le as buildLocalBaseSpec,xe as createBoardWorkerQueueLane,Vt as createExecutionRefInvoker,U as createFsBlobStorage,an as createFsBoardChatStorage,cn as createFsBoardFileArtifactsStore,sn as createFsBoardNonCorePlatformAdapter,fr as createFsBoardPlatformAdapter,pr as createFsChatStorageForRefRoot,je as createFsQueueStorage,ir as createHostedAsyncBoardNonCorePublic,on as createNodeSpawnInvocationAdapter,Ae as createNonCoreExecutorDispatcher,we as createQueueStorageLane,un as decodeBoardRefFromToken,de as drainQueueLaneToIdle,be as evaluateArgsMassaging,Z as invokeExecutionRef,ve as invokeExecutionRefSync,Ut as invokeRefSync,Jt as registerInProcessExecutionHandler,q as resolveWhatToRunValue,Xe as resolveYamlFlowCliPath,Ye as startQueueLaneRunner,_t as startQueueLaneRunners,Dt as unregisterInProcessExecutionHandler};//# sourceMappingURL=board-live-cards-node.js.map
|
|
12
12
|
//# sourceMappingURL=board-live-cards-node.js.map
|