yaml-flow 8.6.4 → 8.7.1
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 +3 -0
- package/browser/adapters/firestore-storage.js +3 -0
- package/browser/adapters/localstorage-storage.js +4 -0
- package/browser/asset-integrity.json +22 -6
- package/browser/live-cards.schema.json +10 -1
- package/browser/server-runtime-controlface.js +8 -0
- package/examples/ARCHITECTURE.md +5 -32
- package/examples/board/demo-shell-with-server.html +2 -2
- package/examples/board/doc.html +2 -2
- package/examples/board/server/board-server.js +4 -2
- package/examples/board/test/server-http-test.js +73 -79
- package/examples/board-firestore/README.md +81 -0
- package/examples/board-firestore/browser/board-runtime.js +263 -0
- package/examples/board-firestore/firestore.indexes.json +29 -0
- package/examples/board-firestore/package.json +14 -0
- package/examples/board-firestore/server/adapters/firestore-archive-factory.js +59 -0
- package/examples/board-firestore/server/adapters/firestore-blob-storage.js +82 -0
- package/examples/board-firestore/server/adapters/firestore-board-adapter.js +127 -0
- package/examples/board-firestore/server/adapters/firestore-journal-storage.js +54 -0
- package/examples/board-firestore/server/adapters/firestore-kv-storage.js +47 -0
- package/examples/board-firestore/server/adapters/firestore-lock.js +62 -0
- package/examples/board-firestore/server/adapters/firestore-queue-storage.js +186 -0
- package/examples/board-firestore/server/adapters/firestore-scratch-storage.js +50 -0
- package/examples/board-firestore/server/worker.js +146 -0
- package/lib/{artifacts-store-lib-BR-Samty.d.cts → artifacts-store-lib-D9nMkVcE.d.cts} +1 -1
- package/lib/{artifacts-store-lib-DT7XlWUL.d.ts → artifacts-store-lib-DSSMqVL2.d.ts} +1 -1
- package/lib/artifacts-store-public.d.cts +2 -2
- package/lib/artifacts-store-public.d.ts +2 -2
- package/lib/board-live-cards-mcp.cjs +1 -1
- package/lib/board-live-cards-mcp.d.cts +51 -3
- package/lib/board-live-cards-mcp.d.ts +51 -3
- package/lib/board-live-cards-mcp.js +1 -1
- package/lib/board-live-cards-node.cjs +5 -5
- package/lib/board-live-cards-node.d.cts +16 -11
- package/lib/board-live-cards-node.d.ts +16 -11
- package/lib/board-live-cards-node.js +5 -5
- package/lib/{board-live-cards-public-BMUIPOrc.d.ts → board-live-cards-public-JNRKfBZy.d.ts} +1 -1
- package/lib/{board-live-cards-public-wkNmBIRC.d.cts → board-live-cards-public-LlVUQPL2.d.cts} +1 -1
- package/lib/board-live-cards-public-async-Di9QB141.d.cts +55 -0
- package/lib/board-live-cards-public-async-fwd1QI82.d.ts +55 -0
- package/lib/board-live-cards-public.cjs +1 -1
- package/lib/board-live-cards-public.d.cts +1 -1
- package/lib/board-live-cards-public.d.ts +1 -1
- 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 +10 -6
- package/lib/board-live-cards-server-runtime.d.ts +10 -6
- 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.js +1 -1
- package/lib/board-platform-adapter-async-BfHmHdx2.d.cts +129 -0
- package/lib/board-platform-adapter-async-DYahVzIK.d.ts +129 -0
- package/lib/board-worker-adapter.cjs +3 -3
- package/lib/board-worker-adapter.js +3 -3
- package/lib/card-compute/index.cjs +1 -1
- package/lib/card-compute/index.js +1 -1
- package/lib/card-store-public.d.cts +1 -1
- package/lib/card-store-public.d.ts +1 -1
- package/lib/card-validation.cjs +1 -1
- package/lib/card-validation.js +1 -1
- package/lib/{chat-storage-lib-BIUbE-fM.d.cts → chat-storage-lib-B9Q34Dyv.d.cts} +1 -1
- package/lib/{chat-storage-lib-BlG-sobS.d.ts → chat-storage-lib-DB9iSai2.d.ts} +1 -1
- package/lib/chat-store-public.d.cts +2 -2
- package/lib/chat-store-public.d.ts +2 -2
- package/lib/chunk-272IYUKT.cjs +2 -0
- package/lib/chunk-3KC6LBOG.js +3 -0
- package/lib/chunk-5XHOHTLZ.cjs +2 -0
- package/lib/chunk-6APH25VI.js +2 -0
- package/lib/chunk-76C7N4YT.js +3 -0
- package/lib/chunk-7FGPOGRV.cjs +2 -0
- package/lib/chunk-7ICPAABP.cjs +7 -0
- package/lib/chunk-ASR44K7H.cjs +3 -0
- package/lib/chunk-CPAXTVBQ.cjs +2 -0
- package/lib/chunk-EGRHWZRV.js +2 -0
- package/lib/chunk-EZENHAVZ.cjs +2 -0
- package/lib/chunk-FO4KNVU7.cjs +2 -0
- package/lib/chunk-GL2OHR2E.cjs +2 -0
- package/lib/chunk-HWYMZK3N.cjs +3 -0
- package/lib/chunk-IPLSRN6P.cjs +4 -0
- package/lib/{chunk-H5HBXPOI.cjs → chunk-J6EGN6S4.cjs} +3 -3
- package/lib/chunk-JH37NJGP.js +3 -0
- package/lib/chunk-JJL5VOQZ.cjs +3 -0
- package/lib/chunk-KAWQPLIE.cjs +2 -0
- package/lib/chunk-LPXVVMQT.cjs +2 -0
- package/lib/chunk-NJJ7WEDT.cjs +2 -0
- package/lib/chunk-NKIQRCOM.cjs +2 -0
- package/lib/chunk-NM6O35RY.cjs +2 -0
- package/lib/chunk-NTICU4OK.js +2 -0
- package/lib/chunk-O7NOHKVR.js +2 -0
- package/lib/chunk-PBOQ4HYB.cjs +2 -0
- package/lib/{chunk-VMW4Z6EF.js → chunk-PRKRXAVN.js} +3 -3
- package/lib/chunk-QJVR3FWQ.js +2 -0
- package/lib/chunk-S44QZUDX.js +2 -0
- package/lib/chunk-SGV7PU4H.js +2 -0
- package/lib/chunk-TSN3RTXT.js +4 -0
- package/lib/chunk-VXJHBWK3.js +2 -0
- package/lib/chunk-WHDEBJLT.js +7 -0
- package/lib/chunk-XYN5D3GL.js +2 -0
- package/lib/chunk-YBYXCFAI.js +2 -0
- package/lib/chunk-YGALANRO.js +2 -0
- package/lib/chunk-ZCNN6XPV.js +2 -0
- package/lib/chunk-ZJ5M5COT.js +2 -0
- package/lib/cloud-storage.cjs +1 -1
- package/lib/cloud-storage.d.cts +5 -3
- package/lib/cloud-storage.d.ts +5 -3
- package/lib/cloud-storage.js +1 -1
- package/lib/continuous-event-graph/index.cjs +1 -1
- package/lib/continuous-event-graph/index.js +1 -1
- package/lib/firebase-storage/index.cjs +3 -0
- package/lib/firebase-storage/index.d.cts +57 -0
- package/lib/firebase-storage/index.d.ts +57 -0
- package/lib/firebase-storage/index.js +3 -0
- package/lib/firestore-storage/index.cjs +3 -0
- package/lib/firestore-storage/index.d.cts +111 -0
- package/lib/firestore-storage/index.d.ts +111 -0
- package/lib/firestore-storage/index.js +3 -0
- package/lib/index.cjs +2 -2
- package/lib/index.js +1 -1
- package/lib/localstorage-storage/index.cjs +2 -0
- package/lib/localstorage-storage/index.d.cts +39 -0
- package/lib/localstorage-storage/index.d.ts +39 -0
- package/lib/localstorage-storage/index.js +2 -0
- package/lib/mcp-tool-registries-BBObLYga.d.ts +41 -0
- package/lib/mcp-tool-registries-W3TRj6O5.d.cts +41 -0
- package/lib/queue-lane-registry-PaZuFpwp.d.cts +30 -0
- package/lib/queue-lane-registry-PaZuFpwp.d.ts +30 -0
- package/lib/server-jobs-queue-runner/index.cjs +2 -0
- package/lib/server-jobs-queue-runner/index.d.cts +22 -0
- package/lib/server-jobs-queue-runner/index.d.ts +22 -0
- package/lib/server-jobs-queue-runner/index.js +2 -0
- package/lib/server-runtime/index.cjs +1 -1
- package/lib/server-runtime/index.d.cts +11 -17
- package/lib/server-runtime/index.d.ts +11 -17
- package/lib/server-runtime/index.js +1 -1
- package/lib/server-runtime-agentface/index.cjs +2 -0
- package/lib/server-runtime-agentface/index.d.cts +53 -0
- package/lib/server-runtime-agentface/index.d.ts +53 -0
- package/lib/server-runtime-agentface/index.js +2 -0
- package/lib/server-runtime-controlface/index.cjs +2 -0
- package/lib/server-runtime-controlface/index.d.cts +29 -0
- package/lib/server-runtime-controlface/index.d.ts +29 -0
- package/lib/server-runtime-controlface/index.js +2 -0
- package/lib/server-runtime-core/index.cjs +2 -0
- package/lib/server-runtime-core/index.d.cts +378 -0
- package/lib/server-runtime-core/index.d.ts +378 -0
- package/lib/server-runtime-core/index.js +2 -0
- package/lib/server-runtime-watchers/index.cjs +2 -0
- package/lib/server-runtime-watchers/index.d.cts +127 -0
- package/lib/server-runtime-watchers/index.d.ts +127 -0
- package/lib/server-runtime-watchers/index.js +2 -0
- package/lib/server-runtime-webhooks/index.cjs +2 -0
- package/lib/server-runtime-webhooks/index.d.cts +34 -0
- package/lib/server-runtime-webhooks/index.d.ts +34 -0
- package/lib/server-runtime-webhooks/index.js +2 -0
- package/lib/storage-async-interface-BRR4eBjx.d.cts +81 -0
- package/lib/storage-async-interface-DhlOVPSp.d.ts +81 -0
- package/lib/{queue-lane-registry-BPKWWgd4.d.cts → types-Ba8H5_Wo.d.cts} +10 -34
- package/lib/{queue-lane-registry-Be6c0ftj.d.ts → types-SO5OZm4s.d.ts} +10 -34
- package/package.json +46 -2
- package/schema/live-cards.schema.json +10 -1
- package/examples/board-local/demo-shell-localstorage.html +0 -843
- package/lib/board-live-cards-public-async-DKZqbJVU.d.ts +0 -256
- package/lib/board-live-cards-public-async-dMWNbWq6.d.cts +0 -256
- package/lib/chunk-KXWT3CY6.cjs +0 -8
- package/lib/chunk-MLVTJASJ.js +0 -2
- package/lib/chunk-N6P2JW4W.js +0 -3
- package/lib/chunk-NMZ6XNLB.cjs +0 -3
- package/lib/chunk-OEFTOO47.cjs +0 -3
- package/lib/chunk-OJLA6NLU.js +0 -8
- package/lib/chunk-R5L5WUKN.js +0 -2
- package/lib/chunk-VLBB3D6B.js +0 -3
- package/lib/chunk-WOALA3V5.cjs +0 -2
- package/lib/chunk-YEB5QHGE.cjs +0 -2
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { i as BoardCallbackTransport, B as BoardChangeNotification } from './board-live-cards-public-JNRKfBZy.js';
|
|
2
|
+
import { ExecutionRef } from './execution-refs.js';
|
|
3
|
+
import { a as KindValueRef } from './storage-interface-BFiD3kyB.js';
|
|
4
|
+
import { c as AsyncKVStorage, a as AsyncBlobStorage, f as AsyncScratchStorage, A as AsyncArchiveFactory, b as AsyncJournalStorage, e as AsyncQueueStorage, d as AsyncAtomicRelayLock } from './storage-async-interface-DhlOVPSp.js';
|
|
5
|
+
|
|
6
|
+
interface AsyncBoardWorkerRequest {
|
|
7
|
+
boardId?: string;
|
|
8
|
+
ref: ExecutionRef;
|
|
9
|
+
args: Record<string, unknown>;
|
|
10
|
+
}
|
|
11
|
+
interface AsyncBoardWorkerQueuedRequest {
|
|
12
|
+
messageId: string;
|
|
13
|
+
enqueuedAt: string;
|
|
14
|
+
attempt: number;
|
|
15
|
+
request: AsyncBoardWorkerRequest;
|
|
16
|
+
}
|
|
17
|
+
interface AsyncBoardWorkerLeasedRequest extends AsyncBoardWorkerQueuedRequest {
|
|
18
|
+
leaseToken: string;
|
|
19
|
+
leaseExpiresAt: string;
|
|
20
|
+
}
|
|
21
|
+
interface AsyncBoardWorkerDeadLetterRequest extends AsyncBoardWorkerQueuedRequest {
|
|
22
|
+
reason?: string;
|
|
23
|
+
}
|
|
24
|
+
interface AsyncBoardWorkerStore {
|
|
25
|
+
enqueueRequest(request: AsyncBoardWorkerRequest): Promise<string>;
|
|
26
|
+
leaseRequests(opts?: {
|
|
27
|
+
max?: number;
|
|
28
|
+
visibilityMs?: number;
|
|
29
|
+
}): Promise<AsyncBoardWorkerLeasedRequest[]>;
|
|
30
|
+
ackRequest(messageId: string, leaseToken: string): Promise<boolean>;
|
|
31
|
+
nackRequest(messageId: string, leaseToken: string, opts?: {
|
|
32
|
+
dead?: boolean;
|
|
33
|
+
reason?: string;
|
|
34
|
+
}): Promise<boolean>;
|
|
35
|
+
peekActive(): Promise<AsyncBoardWorkerQueuedRequest[]>;
|
|
36
|
+
peekDeadLetter(): Promise<AsyncBoardWorkerDeadLetterRequest[]>;
|
|
37
|
+
}
|
|
38
|
+
interface AsyncBoardConfigStore {
|
|
39
|
+
readTaskExecutorRef(): Promise<ExecutionRef | undefined>;
|
|
40
|
+
writeTaskExecutorRef(ref: ExecutionRef): Promise<void>;
|
|
41
|
+
readChatHandlerFlow(): Promise<unknown>;
|
|
42
|
+
writeChatHandlerFlow(flow: unknown): Promise<void>;
|
|
43
|
+
readCardStoreRef(): Promise<string | null>;
|
|
44
|
+
writeCardStoreRef(ref: string): Promise<void>;
|
|
45
|
+
readOutputsStoreRef(): Promise<string | null>;
|
|
46
|
+
writeOutputsStoreRef(ref: string): Promise<void>;
|
|
47
|
+
readScratchStoreRef(): Promise<string | null>;
|
|
48
|
+
writeScratchStoreRef(ref: string): Promise<void>;
|
|
49
|
+
readArchiveStoreRef(): Promise<string | null>;
|
|
50
|
+
writeArchiveStoreRef(ref: string): Promise<void>;
|
|
51
|
+
readChatStoreRef(): Promise<string | null>;
|
|
52
|
+
writeChatStoreRef(ref: string): Promise<void>;
|
|
53
|
+
readArtifactsStoreRef(): Promise<string | null>;
|
|
54
|
+
writeArtifactsStoreRef(ref: string): Promise<void>;
|
|
55
|
+
}
|
|
56
|
+
interface AsyncBoardPlatformAdapter {
|
|
57
|
+
kvStorage(namespace: string): AsyncKVStorage;
|
|
58
|
+
kvStorageForRef(ref: string): AsyncKVStorage;
|
|
59
|
+
blobStorage(namespace: string): AsyncBlobStorage;
|
|
60
|
+
scratchStorage(): AsyncScratchStorage;
|
|
61
|
+
scratchStorageForRef(ref: string): AsyncScratchStorage;
|
|
62
|
+
archiveFactory(): AsyncArchiveFactory;
|
|
63
|
+
archiveFactoryForRef(ref: string): AsyncArchiveFactory;
|
|
64
|
+
journalStorage(): AsyncJournalStorage;
|
|
65
|
+
boardWorkerStore(): AsyncBoardWorkerStore;
|
|
66
|
+
chatAgentStore(): AsyncBoardWorkerStore;
|
|
67
|
+
processAccumulatedStore(): AsyncQueueStorage;
|
|
68
|
+
lock: AsyncAtomicRelayLock;
|
|
69
|
+
callbackTransport?: BoardCallbackTransport;
|
|
70
|
+
dispatchExecution(ref: ExecutionRef, args: Record<string, unknown>): Promise<{
|
|
71
|
+
dispatched: boolean;
|
|
72
|
+
error?: string;
|
|
73
|
+
}>;
|
|
74
|
+
supportsDirectSourceOutput?(ref: ExecutionRef): boolean;
|
|
75
|
+
resolveBlob(ref: KindValueRef): Promise<string>;
|
|
76
|
+
hashFn(value: unknown): string;
|
|
77
|
+
genId(): string;
|
|
78
|
+
requestProcessAccumulated?(): void | Promise<void>;
|
|
79
|
+
publishBoardChangeNotifications?(notifications: BoardChangeNotification[]): void | Promise<void>;
|
|
80
|
+
warn?: (msg: string) => void;
|
|
81
|
+
}
|
|
82
|
+
interface HostedFetchResponseLike {
|
|
83
|
+
ok: boolean;
|
|
84
|
+
status: number;
|
|
85
|
+
text(): Promise<string>;
|
|
86
|
+
}
|
|
87
|
+
interface HostedFetchLike {
|
|
88
|
+
(input: string, init: {
|
|
89
|
+
method: string;
|
|
90
|
+
headers: Record<string, string>;
|
|
91
|
+
body: string;
|
|
92
|
+
}): Promise<HostedFetchResponseLike>;
|
|
93
|
+
}
|
|
94
|
+
interface HostedAsyncBoardPlatformAdapterOptions {
|
|
95
|
+
boardId?: string;
|
|
96
|
+
kvStorage(namespace: string): AsyncKVStorage;
|
|
97
|
+
kvStorageForRef(ref: string): AsyncKVStorage;
|
|
98
|
+
blobStorage(namespace: string): AsyncBlobStorage;
|
|
99
|
+
scratchStorage(): AsyncScratchStorage;
|
|
100
|
+
scratchStorageForRef(ref: string): AsyncScratchStorage;
|
|
101
|
+
archiveFactory(): AsyncArchiveFactory;
|
|
102
|
+
archiveFactoryForRef(ref: string): AsyncArchiveFactory;
|
|
103
|
+
journalStorage(): AsyncJournalStorage;
|
|
104
|
+
queueStorage?: AsyncQueueStorage;
|
|
105
|
+
boardWorkerStore?: AsyncBoardWorkerStore;
|
|
106
|
+
chatAgentQueueStorage?: AsyncQueueStorage;
|
|
107
|
+
chatAgentStore?: AsyncBoardWorkerStore;
|
|
108
|
+
processAccumulatedQueueStorage?: AsyncQueueStorage;
|
|
109
|
+
processAccumulatedStore?: AsyncQueueStorage;
|
|
110
|
+
lock: AsyncAtomicRelayLock;
|
|
111
|
+
callbackTransport?: BoardCallbackTransport;
|
|
112
|
+
fetch?: HostedFetchLike;
|
|
113
|
+
dispatchExecution?: (ref: ExecutionRef, args: Record<string, unknown>) => Promise<{
|
|
114
|
+
dispatched: boolean;
|
|
115
|
+
error?: string;
|
|
116
|
+
}>;
|
|
117
|
+
supportsDirectSourceOutput?: (ref: ExecutionRef) => boolean;
|
|
118
|
+
resolveBlob?: (ref: KindValueRef) => Promise<string>;
|
|
119
|
+
hashFn: (value: unknown) => string;
|
|
120
|
+
genId: () => string;
|
|
121
|
+
requestProcessAccumulated?: () => void | Promise<void>;
|
|
122
|
+
publishBoardChangeNotifications?: (notifications: BoardChangeNotification[]) => void | Promise<void>;
|
|
123
|
+
onWarn?: (msg: string) => void;
|
|
124
|
+
}
|
|
125
|
+
declare function createAsyncBoardWorkerStore(queue: AsyncQueueStorage): AsyncBoardWorkerStore;
|
|
126
|
+
declare function createAsyncBoardConfigStore(kv: AsyncKVStorage): AsyncBoardConfigStore;
|
|
127
|
+
declare function createHostedAsyncBoardPlatformAdapter(options: HostedAsyncBoardPlatformAdapterOptions): AsyncBoardPlatformAdapter;
|
|
128
|
+
|
|
129
|
+
export { type AsyncBoardPlatformAdapter as A, type HostedAsyncBoardPlatformAdapterOptions as H, type AsyncBoardConfigStore as a, type AsyncBoardWorkerDeadLetterRequest as b, type AsyncBoardWorkerLeasedRequest as c, type AsyncBoardWorkerQueuedRequest as d, type AsyncBoardWorkerRequest as e, type AsyncBoardWorkerStore as f, type HostedFetchLike as g, type HostedFetchResponseLike as h, createAsyncBoardConfigStore as i, createAsyncBoardWorkerStore as j, createHostedAsyncBoardPlatformAdapter as k };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
'use strict';require('./chunk-GNFE24S7.cjs');var l=require('fs'),a=require('path'),child_process=require('child_process'),module$1=require('module');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var l__namespace=/*#__PURE__*/_interopNamespace(l);var a__namespace=/*#__PURE__*/_interopNamespace(a);var p=new Map;function
|
|
1
|
+
'use strict';require('./chunk-GNFE24S7.cjs');var l=require('fs'),a=require('path'),child_process=require('child_process'),module$1=require('module');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var l__namespace=/*#__PURE__*/_interopNamespace(l);var a__namespace=/*#__PURE__*/_interopNamespace(a);var p=new Map;function v(r,e){let t=String(r||"").trim();if(!t)throw new Error("registerInProcessBoardWorkerCallback: key is required");p.set(t,e);}function B(r){let e=String(r||"").trim();e&&p.delete(e);}async function f(r,e){let t=String(e||"").trim();if(!t)throw new Error("in-process-loop callback requires a non-empty handler key");let o=p.get(t);if(!o)throw new Error(`in-process-loop callback handler not registered: ${t}`);let n=await o(r);if(n&&n.status&&n.status!=="success")throw new Error(n.error||`in-process-loop callback failed with status: ${n.status}`)}function g(r,e,t){w(m(r),JSON.stringify({tool:"webhook.source-fetch-done",args:{token:e,ref:t}}));}function h(r,e,t){w(m(r),JSON.stringify({tool:"webhook.source-fetch-failed",args:{token:e,reason:t}}));}function m(r){return String(r||"").replace(/\/+$/,"")}function w(r,e){let t=`
|
|
2
2
|
const rawUrl = ${JSON.stringify(r)};
|
|
3
3
|
const rawBody = ${JSON.stringify(e)};
|
|
4
4
|
const u = new URL(rawUrl);
|
|
@@ -20,6 +20,6 @@
|
|
|
20
20
|
req.on('error', e => { process.stderr.write(e.message); process.exit(1); });
|
|
21
21
|
req.write(rawBody);
|
|
22
22
|
req.end();
|
|
23
|
-
`,o=child_process.spawnSync(process.execPath,["-e",t],{encoding:"utf-8",windowsHide:true});if(o.status!==0)throw new Error(`http-post failed: ${o.stderr?.trim()}`)}var
|
|
24
|
-
exports.blobStorageForRef=_;exports.parseRef=d;exports.registerInProcessBoardWorkerCallback=
|
|
23
|
+
`,o=child_process.spawnSync(process.execPath,["-e",t],{encoding:"utf-8",windowsHide:true});if(o.status!==0)throw new Error(`http-post failed: ${o.stderr?.trim()}`)}var S=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('board-worker-adapter.cjs', document.baseURI).href)));function b(r,e,t){x(r,["source-data-fetched","--ref",t,"--token",e],"reportComplete");}function y(r,e,t){x(r,["source-data-fetch-failure","--token",e,"--reason",t],"reportFailed");}function x(r,e,t){let o=I(r.whatToRun),{cmd:n,args:s}=T(o),i=P(r),u=child_process.spawnSync(n,[...s,...e,...i?["--notify-channel",i]:[]],{encoding:"utf-8",windowsHide:true});if(u.status!==0)throw new Error(`${t}: board CLI exited ${u.status}: ${u.stderr?.trim()}`)}function I(r){let e=E(r);if(e.kind==="yaml-flow-cli"){let t=a__namespace.basename(e.value.trim());if(!t)throw new Error(`Invalid yaml-flow-cli ref: expected non-empty cli file name, got ${JSON.stringify(e.value)}`);let o=a__namespace.dirname(S.resolve("yaml-flow/package.json")),n=t.replace(/\.[^.]+$/,""),s=a__namespace.join(o,"cli","bundled",`${n}.mjs`);if(l__namespace.existsSync(s))return s;let i=a__namespace.join(o,"cli","node",t);if(l__namespace.existsSync(i))return i;throw new Error(`Invalid yaml-flow-cli ref: could not find ${t} under cli/bundled or cli/node in ${o}`)}return e.value}function P(r){let e=r.extra?.notifyChannel;return typeof e=="string"&&e.length>0?e:void 0}function T(r){if(!r.endsWith(".ts"))return {cmd:process.execPath,args:[r]};let e=a__namespace.dirname(r),t=[];for(let n=1;n<=5;n++){let s=a__namespace.join(e,...Array(n).fill(".."),"node_modules");t.push(a__namespace.join(s,"tsx","dist","cli.mjs")),t.push(a__namespace.join(s,".bin","tsx"));}let o=t.find(n=>l__namespace.existsSync(n));return o?{cmd:process.execPath,args:[o,r]}:{cmd:"npx",args:["tsx",r]}}function E(r){if(!r.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${r}`);let e=r.slice(4),t=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),o;try{o=JSON.parse(Buffer.from(t,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${r}`)}if(!o||typeof o!="object")throw new Error(`Invalid ref format (expected object payload): ${r}`);let n=o;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${r}`);return {kind:n.kind,value:n.value}}function d(r){if(!r.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${r}`);let e=r.slice(4),t=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),o;try{o=JSON.parse(Buffer.from(t,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${r}`)}if(!o||typeof o!="object")throw new Error(`Invalid ref format (expected object payload): ${r}`);let n=o;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${r}`);return {kind:n.kind,value:n.value}}function k(r){return `b64:${Buffer.from(JSON.stringify(r),"utf8").toString("base64").replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}`}function N(){return {read(r){if(!l__namespace.default.existsSync(r))return null;try{return l__namespace.default.readFileSync(r,"utf-8")}catch{return null}},write(r,e){l__namespace.default.mkdirSync(a__namespace.default.dirname(r),{recursive:true}),l__namespace.default.writeFileSync(r,e,"utf-8");}}}function _(r){if(r.kind==="fs-path")return N();throw new Error(`Unsupported storage kind: "${r.kind}". Supported kinds: fs-path`)}function M(r,e){let{token:t,via:o}=r;if(o.howToRun==="local-node"||o.howToRun==="local-process"){b(o,t,k(e));return}if(o.howToRun==="http:post"){g(d(o.whatToRun).value,t,k(e));return}if(o.howToRun==="in-process-loop"){f({token:t,outcome:"success",ref:k(e)},d(o.whatToRun).value);return}throw new Error(`reportComplete: unsupported via.howToRun "${o.howToRun}"`)}function A(r,e){let{token:t,via:o}=r;if(o.howToRun==="local-node"||o.howToRun==="local-process"){y(o,t,e);return}if(o.howToRun==="http:post"){h(d(o.whatToRun).value,t,e);return}if(o.howToRun==="in-process-loop"){f({token:t,outcome:"failure",reason:e},d(o.whatToRun).value);return}throw new Error(`reportFailed: unsupported via.howToRun "${o.howToRun}"`)}
|
|
24
|
+
exports.blobStorageForRef=_;exports.parseRef=d;exports.registerInProcessBoardWorkerCallback=v;exports.reportComplete=M;exports.reportFailed=A;exports.serializeRef=k;exports.unregisterInProcessBoardWorkerCallback=B;//# sourceMappingURL=board-worker-adapter.cjs.map
|
|
25
25
|
//# sourceMappingURL=board-worker-adapter.cjs.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import'./chunk-FW4363Y4.js';import*as l from'fs';import l__default from'fs';import*as a from'path';import a__default from'path';import {spawnSync}from'child_process';import {createRequire}from'module';var p=new Map;function
|
|
1
|
+
import'./chunk-FW4363Y4.js';import*as l from'fs';import l__default from'fs';import*as a from'path';import a__default from'path';import {spawnSync}from'child_process';import {createRequire}from'module';var p=new Map;function v(r,e){let t=String(r||"").trim();if(!t)throw new Error("registerInProcessBoardWorkerCallback: key is required");p.set(t,e);}function B(r){let e=String(r||"").trim();e&&p.delete(e);}async function f(r,e){let t=String(e||"").trim();if(!t)throw new Error("in-process-loop callback requires a non-empty handler key");let o=p.get(t);if(!o)throw new Error(`in-process-loop callback handler not registered: ${t}`);let n=await o(r);if(n&&n.status&&n.status!=="success")throw new Error(n.error||`in-process-loop callback failed with status: ${n.status}`)}function g(r,e,t){w(m(r),JSON.stringify({tool:"webhook.source-fetch-done",args:{token:e,ref:t}}));}function h(r,e,t){w(m(r),JSON.stringify({tool:"webhook.source-fetch-failed",args:{token:e,reason:t}}));}function m(r){return String(r||"").replace(/\/+$/,"")}function w(r,e){let t=`
|
|
2
2
|
const rawUrl = ${JSON.stringify(r)};
|
|
3
3
|
const rawBody = ${JSON.stringify(e)};
|
|
4
4
|
const u = new URL(rawUrl);
|
|
@@ -20,6 +20,6 @@ import'./chunk-FW4363Y4.js';import*as l from'fs';import l__default from'fs';impo
|
|
|
20
20
|
req.on('error', e => { process.stderr.write(e.message); process.exit(1); });
|
|
21
21
|
req.write(rawBody);
|
|
22
22
|
req.end();
|
|
23
|
-
`,o=spawnSync(process.execPath,["-e",t],{encoding:"utf-8",windowsHide:true});if(o.status!==0)throw new Error(`http-post failed: ${o.stderr?.trim()}`)}var
|
|
24
|
-
export{_ as blobStorageForRef,d as parseRef,
|
|
23
|
+
`,o=spawnSync(process.execPath,["-e",t],{encoding:"utf-8",windowsHide:true});if(o.status!==0)throw new Error(`http-post failed: ${o.stderr?.trim()}`)}var S=createRequire(import.meta.url);function b(r,e,t){x(r,["source-data-fetched","--ref",t,"--token",e],"reportComplete");}function y(r,e,t){x(r,["source-data-fetch-failure","--token",e,"--reason",t],"reportFailed");}function x(r,e,t){let o=I(r.whatToRun),{cmd:n,args:s}=T(o),i=P(r),u=spawnSync(n,[...s,...e,...i?["--notify-channel",i]:[]],{encoding:"utf-8",windowsHide:true});if(u.status!==0)throw new Error(`${t}: board CLI exited ${u.status}: ${u.stderr?.trim()}`)}function I(r){let e=E(r);if(e.kind==="yaml-flow-cli"){let t=a.basename(e.value.trim());if(!t)throw new Error(`Invalid yaml-flow-cli ref: expected non-empty cli file name, got ${JSON.stringify(e.value)}`);let o=a.dirname(S.resolve("yaml-flow/package.json")),n=t.replace(/\.[^.]+$/,""),s=a.join(o,"cli","bundled",`${n}.mjs`);if(l.existsSync(s))return s;let i=a.join(o,"cli","node",t);if(l.existsSync(i))return i;throw new Error(`Invalid yaml-flow-cli ref: could not find ${t} under cli/bundled or cli/node in ${o}`)}return e.value}function P(r){let e=r.extra?.notifyChannel;return typeof e=="string"&&e.length>0?e:void 0}function T(r){if(!r.endsWith(".ts"))return {cmd:process.execPath,args:[r]};let e=a.dirname(r),t=[];for(let n=1;n<=5;n++){let s=a.join(e,...Array(n).fill(".."),"node_modules");t.push(a.join(s,"tsx","dist","cli.mjs")),t.push(a.join(s,".bin","tsx"));}let o=t.find(n=>l.existsSync(n));return o?{cmd:process.execPath,args:[o,r]}:{cmd:"npx",args:["tsx",r]}}function E(r){if(!r.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${r}`);let e=r.slice(4),t=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),o;try{o=JSON.parse(Buffer.from(t,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${r}`)}if(!o||typeof o!="object")throw new Error(`Invalid ref format (expected object payload): ${r}`);let n=o;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${r}`);return {kind:n.kind,value:n.value}}function d(r){if(!r.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${r}`);let e=r.slice(4),t=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),o;try{o=JSON.parse(Buffer.from(t,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${r}`)}if(!o||typeof o!="object")throw new Error(`Invalid ref format (expected object payload): ${r}`);let n=o;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${r}`);return {kind:n.kind,value:n.value}}function k(r){return `b64:${Buffer.from(JSON.stringify(r),"utf8").toString("base64").replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}`}function N(){return {read(r){if(!l__default.existsSync(r))return null;try{return l__default.readFileSync(r,"utf-8")}catch{return null}},write(r,e){l__default.mkdirSync(a__default.dirname(r),{recursive:true}),l__default.writeFileSync(r,e,"utf-8");}}}function _(r){if(r.kind==="fs-path")return N();throw new Error(`Unsupported storage kind: "${r.kind}". Supported kinds: fs-path`)}function M(r,e){let{token:t,via:o}=r;if(o.howToRun==="local-node"||o.howToRun==="local-process"){b(o,t,k(e));return}if(o.howToRun==="http:post"){g(d(o.whatToRun).value,t,k(e));return}if(o.howToRun==="in-process-loop"){f({token:t,outcome:"success",ref:k(e)},d(o.whatToRun).value);return}throw new Error(`reportComplete: unsupported via.howToRun "${o.howToRun}"`)}function A(r,e){let{token:t,via:o}=r;if(o.howToRun==="local-node"||o.howToRun==="local-process"){y(o,t,e);return}if(o.howToRun==="http:post"){h(d(o.whatToRun).value,t,e);return}if(o.howToRun==="in-process-loop"){f({token:t,outcome:"failure",reason:e},d(o.whatToRun).value);return}throw new Error(`reportFailed: unsupported via.howToRun "${o.howToRun}"`)}
|
|
24
|
+
export{_ as blobStorageForRef,d as parseRef,v as registerInProcessBoardWorkerCallback,M as reportComplete,A as reportFailed,k as serializeRef,B as unregisterInProcessBoardWorkerCallback};//# sourceMappingURL=board-worker-adapter.js.map
|
|
25
25
|
//# sourceMappingURL=board-worker-adapter.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';Object.defineProperty(exports,'__esModule',{value:true});var chunkIXZG74EW_cjs=require('../chunk-IXZG74EW.cjs'),
|
|
1
|
+
'use strict';Object.defineProperty(exports,'__esModule',{value:true});var chunkIXZG74EW_cjs=require('../chunk-IXZG74EW.cjs'),chunkHWYMZK3N_cjs=require('../chunk-HWYMZK3N.cjs');require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-GNFE24S7.cjs');Object.defineProperty(exports,"CardCompute",{enumerable:true,get:function(){return chunkIXZG74EW_cjs.a}});Object.defineProperty(exports,"default",{enumerable:true,get:function(){return chunkIXZG74EW_cjs.b}});Object.defineProperty(exports,"validateLiveCard",{enumerable:true,get:function(){return chunkHWYMZK3N_cjs.c}});Object.defineProperty(exports,"validateLiveCardDefinition",{enumerable:true,get:function(){return chunkHWYMZK3N_cjs.d}});Object.defineProperty(exports,"validateLiveCardRuntimeExpressions",{enumerable:true,get:function(){return chunkHWYMZK3N_cjs.b}});Object.defineProperty(exports,"validateLiveCardSchema",{enumerable:true,get:function(){return chunkHWYMZK3N_cjs.a}});//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{a as CardCompute,b as default}from'../chunk-JMDHDY6M.js';export{c as validateLiveCard,d as validateLiveCardDefinition,b as validateLiveCardRuntimeExpressions,a as validateLiveCardSchema}from'../chunk-
|
|
1
|
+
export{a as CardCompute,b as default}from'../chunk-JMDHDY6M.js';export{c as validateLiveCard,d as validateLiveCardDefinition,b as validateLiveCardRuntimeExpressions,a as validateLiveCardSchema}from'../chunk-3KC6LBOG.js';import'../chunk-MNEOJWPS.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { C as CommandInput, a as CommandResult, L as LiveCard, b as CardAdminStore } from './board-live-cards-public-LlVUQPL2.cjs';
|
|
2
2
|
import './storage-interface-BFiD3kyB.cjs';
|
|
3
3
|
import './execution-refs.cjs';
|
|
4
4
|
import './types-BBhqYGhE.cjs';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { C as CommandInput, a as CommandResult, L as LiveCard, b as CardAdminStore } from './board-live-cards-public-JNRKfBZy.js';
|
|
2
2
|
import './storage-interface-BFiD3kyB.js';
|
|
3
3
|
import './execution-refs.js';
|
|
4
4
|
import './types-BBhqYGhE.js';
|
package/lib/card-validation.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkFO4KNVU7_cjs=require('./chunk-FO4KNVU7.cjs');require('./chunk-HWYMZK3N.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"validateCardPreflight",{enumerable:true,get:function(){return chunkFO4KNVU7_cjs.a}});//# sourceMappingURL=card-validation.cjs.map
|
|
2
2
|
//# sourceMappingURL=card-validation.cjs.map
|
package/lib/card-validation.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
export{a as validateCardPreflight}from'./chunk-YBYXCFAI.js';import'./chunk-3KC6LBOG.js';import'./chunk-MNEOJWPS.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=card-validation.js.map
|
|
2
2
|
//# sourceMappingURL=card-validation.js.map
|
|
@@ -51,4 +51,4 @@ interface ChatStorage {
|
|
|
51
51
|
declare function createChatStorage(journalFactory: (cardId: string) => JournalStorage, kv: KVStorage): ChatStorage;
|
|
52
52
|
declare function createInMemoryChatStorage(): ChatStorage;
|
|
53
53
|
|
|
54
|
-
export { type
|
|
54
|
+
export { type ChatStorage as C, type ChatRecord as a, type ChatReadAfterResult as b, type ChatConfig as c, createChatStorage as d, createInMemoryChatStorage as e };
|
|
@@ -51,4 +51,4 @@ interface ChatStorage {
|
|
|
51
51
|
declare function createChatStorage(journalFactory: (cardId: string) => JournalStorage, kv: KVStorage): ChatStorage;
|
|
52
52
|
declare function createInMemoryChatStorage(): ChatStorage;
|
|
53
53
|
|
|
54
|
-
export { type
|
|
54
|
+
export { type ChatStorage as C, type ChatRecord as a, type ChatReadAfterResult as b, type ChatConfig as c, createChatStorage as d, createInMemoryChatStorage as e };
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { C as CommandInput, a as CommandResult } from './board-live-cards-public-LlVUQPL2.cjs';
|
|
2
|
+
import { a as ChatRecord, b as ChatReadAfterResult, c as ChatConfig, C as ChatStorage } from './chat-storage-lib-B9Q34Dyv.cjs';
|
|
3
3
|
import './storage-interface-BFiD3kyB.cjs';
|
|
4
4
|
import './execution-refs.cjs';
|
|
5
5
|
import './types-BBhqYGhE.cjs';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { C as CommandInput, a as CommandResult } from './board-live-cards-public-JNRKfBZy.js';
|
|
2
|
+
import { a as ChatRecord, b as ChatReadAfterResult, c as ChatConfig, C as ChatStorage } from './chat-storage-lib-DB9iSai2.js';
|
|
3
3
|
import './storage-interface-BFiD3kyB.js';
|
|
4
4
|
import './execution-refs.js';
|
|
5
5
|
import './types-BBhqYGhE.js';
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';async function u(t,i,o){let s=o[t];if(!s)throw Object.assign(new Error(`Unknown MCP tool: ${t}`),{statusCode:400});let r=await s(i);if(r&&typeof r=="object"&&!Array.isArray(r)){let n=r,e=n.status;if(e==="success")return Object.prototype.hasOwnProperty.call(n,"data")?r:{status:"success",data:{}};if(e==="fail"||e==="error")return r}return {status:"success",data:r}}function f(t,i){if(!t||typeof t!="object"||Array.isArray(t))return i;let o=t;if(typeof o.error=="string"&&o.error.trim())return o.error;if(o.step==="validate"){let s=o.validation;if(s&&typeof s=="object"&&!Array.isArray(s)){let n=s.data;if(n&&typeof n=="object"&&!Array.isArray(n)){let e=n.issues;if(Array.isArray(e)){let c=e.find(d=>typeof d=="string"&&d.trim());if(typeof c=="string")return `Validation failed: ${c}`}let a=n.errors;if(Array.isArray(a)&&a.length>0)return "Validation failed"}}return "Validation failed"}return i}exports.a=u;exports.b=f;//# sourceMappingURL=chunk-272IYUKT.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-272IYUKT.cjs.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {q as q$1}from'./chunk-MNEOJWPS.js';import {b as b$1}from'./chunk-FW4363Y4.js';import A from'ajv-formats';import {createRequire}from'module';var h={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://nsreehari.github.io/boards/live-cards.schema.json",definitions:{bind_ref:{description:"A card data path reference, e.g. 'card_data.raw_quotes' or 'requires.upstream'",type:"string",pattern:"^(card_data|requires|fetched_sources|computed_values)(\\.|$)"},bind_or_literal:{description:"A literal value or a bind reference object",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref"}},required:["bind"]}]},compute_expr:{description:"A declarative JSON compute expression",type:"object",required:["fn"],properties:{fn:{type:"string",description:"Function name from the built-in vocabulary",enum:["sum","avg","min","max","count","first","last","add","sub","mul","div","round","abs","mod","gt","gte","lt","lte","eq","neq","if","and","or","not","concat","upper","lower","template","filter","pluck","map","sort","slice","flat","unique","group","get","default","now","diff_days","format_date"]},input:{description:"card_data.path, literal, array of inputs, or nested compute_expr",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{$ref:"#/definitions/compute_expr"}]},field:{type:"string",description:"For pluck/sum/group \u2014 the object key to extract"},where:{$ref:"#/definitions/compute_expr",description:"For filter \u2014 predicate expression ($ = current item)"},cond:{$ref:"#/definitions/compute_expr",description:"For if \u2014 condition expression"},then:{description:"For if \u2014 value when cond is truthy"},else:{description:"For if \u2014 value when cond is falsy"},format:{type:"string",description:"For format_date \u2014 date format string"}}},meta:{type:"object",properties:{title:{type:"string"},tags:{type:"array",items:{type:"string"}}},additionalProperties:true},__private:{description:"Control-plane-owned private state. Stripped entirely from all regular /mcp read responses. Writable only via 'setstate.card-private' and 'manage.admin-upsert-card'. Agents must never author this field. Keys inside use plain names (no leading underscores).",type:"object",additionalProperties:true},requires:{type:"array",items:{type:"string"},description:"IDs of upstream nodes this node depends on"},provides:{type:"array",items:{type:"object",required:["bindTo","ref"],properties:{bindTo:{type:"string",description:"Token name published downstream"},ref:{type:"string",description:"Path to read value from (card_data.*, requires.*, fetched_sources.*, computed_values.*)"}}},description:"Explicit bindings exposing computed or card_data values downstream as named tokens"},compute_step:{description:"A single ordered compute step: reads card_data.*/requires.*/computed_values.*, writes to computed_values[bindTo]",type:"object",required:["bindTo","expr"],properties:{bindTo:{type:"string",description:"Key in computed_values to write result"},expr:{type:"string",description:"JSONata expression evaluated against { card_data, requires, fetched_sources, computed_values }"}}},source_def:{description:"One source entry. The engine requires 'bindTo' (compute namespace key) and 'outputFile' (delivery signal path). bindTo and outputFile must be unique across all source_defs in a card. Every other property is yours \u2014 add whatever your task-executor needs: kind, url, headers, mailbox, channel, model, query, etc. The full object is passed verbatim as the --in JSON to the executor.",type:"object",required:["bindTo","outputFile"],additionalProperties:true,properties:{bindTo:{type:"string",description:"Key under fetched_sources.* available in compute expressions"},outputFile:{type:"string",description:"Board-relative path the executor writes its JSON result to. Presence of this file signals delivery."},projections:{type:"object",description:"Named data projections from card_data or requires, evaluated before the executor is called. Each key is a ref name; each value is a JSONata expression rooted at card_data or requires. The resolved values are passed to the executor as _projections. fetched_sources, computed_values, and source_defs are not accessible here \u2014 sources run before those exist.",additionalProperties:{type:"string"}},optionalForCompletionGating:{type:"boolean",default:false,description:"When true this source does not gate card completion. Default false when absent, so source_defs are completion-gating by default."},timeout:{type:"integer",minimum:0,default:12e4,description:"Executor/script timeout in ms. Default: 120 000 (2 min)."},script:{type:"string",description:"Legacy direct-run: shell command executed when no .task-executor is registered. stdout is captured as the result."}}},render_element:{type:"object",required:["kind"],properties:{id:{type:"string",description:"Optional element ID for targeted updates"},kind:{enum:["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]},label:{type:"string",description:"Heading above this element"},className:{type:"string",description:"Bootstrap grid class, e.g. 'col-12 col-md-6'"},visible:{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 element shown only if truthy"},data:{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref",description:"card_data/requires/fetched_sources/computed_values path to read data from"},writeTo:{$ref:"#/definitions/bind_ref",description:"card_data path for user input (form, filter, todo, notes)"},columns:{type:"array",items:{type:"string"},description:"table: visible columns"},maxRows:{type:"integer",description:"table/list: max rows to display"},sortable:{type:"boolean",default:true,description:"table: enable click-to-sort"},placeholder:{type:"string",description:"Empty-state message"},chartType:{enum:["bar","line","pie","doughnut"]},chartOptions:{type:"object",description:"Chart.js options passthrough"},fields:{type:"object",description:"JSON Schema for form/filter fields"},thresholds:{type:"object",properties:{green:{type:"string"},amber:{type:"string"}}},colorMap:{type:"object",description:"badge: value \u2192 Bootstrap color"},style:{enum:["heading","muted","default"],description:"text: display style"},upload:{type:"boolean",default:true,description:"file-upload: show drop zone (false = read-only file list)"},accept:{type:"array",items:{type:"string"},description:"file-upload: allowed extensions"},multiple:{type:"boolean",default:true,description:"file-upload: allow multiple files"},fileAttach:{type:"boolean",default:false,description:"chat: enable inline file attachments"},fileAccept:{type:"array",items:{type:"string"},description:"chat: allowed attachment extensions"},buttons:{type:"array",description:"actions: button definitions",items:{type:"object",required:["id","label"],properties:{id:{type:"string"},label:{type:"string"},style:{type:"string",description:"Bootstrap button variant, e.g. 'success', 'outline-danger'"},size:{type:"string",default:"sm"},disabled:{oneOf:[{type:"boolean"},{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 truthy = disabled"}]}}}}}}}},view:{type:"object",required:["elements"],properties:{elements:{type:"array",minItems:1,items:{$ref:"#/definitions/render_element"}},layout:{type:"object",properties:{board:{type:"object",properties:{col:{type:"integer",minimum:1,maximum:12},order:{type:"integer"}}},canvas:{type:"object",properties:{x:{type:"number"},y:{type:"number"},w:{type:"number"},h:{type:"number"}}}}},features:{type:"object",properties:{chat:{type:"boolean",default:false},notes:{type:"boolean",default:false},refresh:{type:"boolean",default:true}}}}}},title:"LiveCard",description:"A unified card node. Behavior depends on which sections are present (source_defs, compute, view, etc.)",type:"object",required:["id"],additionalProperties:false,properties:{id:{type:"string"},requires:{$ref:"#/definitions/requires"},provides:{$ref:"#/definitions/provides"},meta:{$ref:"#/definitions/meta"},__private:{$ref:"#/definitions/__private"},view:{$ref:"#/definitions/view"},card_data:{type:"object",description:"Authored card data and runtime metadata. Includes uploaded-file metadata maintained by host handlers and inference evaluation results.",properties:{files:{type:"array",description:"Optional uploaded-file metadata maintained by host handlers. Stored name is normalized and serial-prefixed (for example 001-my_file.pdf).",items:{type:"object",required:["name","stored_name"],properties:{name:{type:"string",minLength:1},stored_name:{type:"string",minLength:5,maxLength:32,pattern:"^[0-9]{3,}-[a-z0-9._-]+$"},size:{oneOf:[{type:"integer",minimum:0},{type:"null"}]},mime_type:{type:"string"},path:{type:"string",pattern:"^[^\\s]+/files/[0-9]{3,}-[a-z0-9._-]+$"},uploaded_at:{type:"string",format:"date-time"},chat:{type:"boolean",description:"Whether this file entry is associated with a chat interaction"}},additionalProperties:false}}},additionalProperties:true},source_defs:{type:"array",description:"Source entries. Each entry is passed verbatim to the board's .task-executor (registered via init --task-executor) as the --in JSON file. The executor fetches/generates the data and writes JSON to --out. If no executor is registered, the built-in executor runs the entry's 'cli' command directly. Sources gate completion by default. Set optionalForCompletionGating: true for enrichment-only source_defs that should not block task-completed.",items:{$ref:"#/definitions/source_def"}},compute:{type:"array",description:"Ordered array of compute steps. Each reads card_data.*/requires.*/fetched_sources.*/computed_values.* and writes to ephemeral computed_values[bindTo].",items:{$ref:"#/definitions/compute_step"}}}};var _=b$1(q$1(),1);var k=createRequire(import.meta.url),q=k("./jsonata-sync.cjs"),f=null;var b=/\b(card_data|requires|fetched_sources|computed_values|source_defs)\b/g,N=/^\s*(card_data|requires|fetched_sources|computed_values|source_defs)(\.|$)/;function S(e){let t=new Set,o;for(b.lastIndex=0;(o=b.exec(e))!==null;)t.add(o[1]);return t}function v(e){let t=N.exec(e);return t?t[1]:null}function g(e,t,o,n){try{q(e);}catch(s){let d=s instanceof Error?s.message:String(s);n.push(`${t}: invalid JSONata expression (${d})`);return}let i=S(e);for(let s of i)o.has(s)||n.push(`${t}: disallowed namespace "${s}" in expression`);}function y(e,t,o){if(Array.isArray(e)){e.forEach((i,s)=>{y(i,`${t}/${s}`,o);});return}if(typeof e=="string"){let i=v(e);if(!i)return;new Set(["card_data","requires","computed_values"]).has(i)||o.push(`${t}: disallowed namespace "${i}" in view reference`);return}if(!e||typeof e!="object")return;let n=e;for(let[i,s]of Object.entries(n))y(s,`${t}/${i}`,o);}function E(){if(f)return f;let e=new _.default({allErrors:true});return A(e),f=e.compile(h),f}function R(e){let t=E(),o=t(e),n=(t.errors??[]).map(i=>`${i.instancePath||"/"}: ${i.message??"unknown error"}`);if(e&&typeof e=="object"&&!Array.isArray(e)){let i=e.source_defs;if(Array.isArray(i)){let s=new Set,d=new Set;i.forEach((p,u)=>{if(!p||typeof p!="object"||Array.isArray(p))return;let r=p;typeof r.bindTo=="string"&&r.bindTo&&(s.has(r.bindTo)&&n.push(`/source_defs/${u}/bindTo: bindTo "${r.bindTo}" must be unique across all source_defs`),s.add(r.bindTo)),typeof r.outputFile=="string"&&r.outputFile&&(d.has(r.outputFile)&&n.push(`/source_defs/${u}/outputFile: outputFile "${r.outputFile}" must be unique across all source_defs`),d.add(r.outputFile));});}}return !o||n.length>0?{ok:false,errors:n}:{ok:true,errors:[]}}function T(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:true,errors:[]};let o=e,n=o.compute;Array.isArray(n)&&n.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.expr;typeof a!="string"||a.trim().length===0||g(a,`/compute/${c}/expr`,new Set(["card_data","requires","fetched_sources","computed_values"]),t);});let i=new Set(["card_data","requires","fetched_sources","computed_values"]),s=o.provides;Array.isArray(s)&&s.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.ref;if(typeof a!="string"||a.trim().length===0)return;let l=v(a);l===null?t.push(`/provides/${c}/ref: path "${a}" must start with a valid namespace (${[...i].join(", ")})`):i.has(l)||t.push(`/provides/${c}/ref: disallowed namespace "${l}" in path "${a}" (valid: ${[...i].join(", ")})`);});let d=o.view;d&&typeof d=="object"&&!Array.isArray(d)&&y(d,"/view",t);let p=new Set(["card_data","requires"]),u=o.source_defs;return Array.isArray(u)&&u.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.projections;if(!(!a||typeof a!="object"||Array.isArray(a)))for(let[l,m]of Object.entries(a))typeof m!="string"||m.trim().length===0||g(m,`/source_defs/${c}/projections/${l}`,p,t);}),{ok:t.length===0,errors:t}}function V(e){return O(e)}function O(e){let t=R(e);if(!t.ok)return t;let o=T(e);return o.ok?{ok:true,errors:[]}:{ok:false,errors:o.errors}}
|
|
2
|
+
export{R as a,T as b,V as c,O as d};//# sourceMappingURL=chunk-3KC6LBOG.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-3KC6LBOG.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';function T(e){if(!e||typeof e!="object")return;let t=e;if(typeof t.statusCode=="number")return t.statusCode;if(typeof t.code=="number")return t.code}function c(e,t){return T(e)===t}function l(e,t,r){return t?typeof t=="function"?t(e):t:r}function b(e){return (e?.()??new Date).toISOString()}function L(e,t){if(t)return t();let r=String((e?.()??new Date).getTime()).padStart(13,"0"),n=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${r}-${n}`}function p(e){return {id:e.id,payload:e.payload}}function B(e,t={}){return {async read(r){let n=l(r,t.partitionKey,"kv");try{return (await e.item(r,n).read()).resource?.value??null}catch(o){if(c(o,404))return null;throw o}},async write(r,n){let o=l(r,t.partitionKey,"kv");await e.items.upsert({id:r,pk:o,kind:"kv",value:n});},async delete(r){let n=l(r,t.partitionKey,"kv");try{await e.item(r,n).delete();}catch(o){if(!c(o,404))throw o}},async listKeys(r=""){let{resources:n}=await e.items.query({query:"SELECT c.id FROM c WHERE c.kind = @kind AND STARTSWITH(c.id, @prefix)",parameters:[{name:"@kind",value:"kv"},{name:"@prefix",value:r}]}).fetchAll();return n.map(o=>o.id).sort()}}}function x(e,t,r={}){let n=l(t,r.partitionKey,`journal:${t}`);return {async append(o){let s={id:L(r.now,r.idFactory),pk:n,kind:"journal",streamKey:t,createdAt:b(r.now),payload:o};return await e.items.create(s),p(s)},async readAll(){let{resources:o}=await e.items.query({query:"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:n},{name:"@streamKey",value:t}]}).fetchAll();return o.sort((s,a)=>s.id.localeCompare(a.id)).map(p)},async readAfter(o){let{resources:s}=await e.items.query({query:o?"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey AND c.id > @cursor ORDER BY c.id":"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:n},{name:"@streamKey",value:t},...o?[{name:"@cursor",value:o}]:[]]}).fetchAll(),a=s.sort((m,g)=>m.id.localeCompare(g.id));return {entries:a.map(p),newCursor:a.length>0?a[a.length-1].id:o}},async clear(){let o=await this.readAll();await Promise.all(o.map(s=>e.item(s.id,n).delete()));}}}function D(e,t,r={}){let n=r.partitionKey??"lock",o=r.holderId??`holder-${Math.random().toString(36).slice(2,10)}`,s=r.now,a=r.ttlMs??3e4;function m(){let i=s?.()??new Date;return {id:t,pk:n,kind:"lock",held:true,holderId:o,expiresAt:new Date(i.getTime()+a).toISOString(),updatedAt:i.toISOString()}}function g(i){return {...i??{id:t,pk:n,kind:"lock"},kind:"lock",held:false,holderId:o,expiresAt:null,updatedAt:b(s)}}async function k(){try{return (await e.item(t,n).read()).resource??null}catch(i){if(c(i,404))return null;throw i}}function S(i){return i?.held?i.expiresAt?Date.parse(i.expiresAt)>(s?.()??new Date).getTime():true:false}return {async tryAcquire(){let i=await k(),A=m();if(i){if(S(i))return null;try{await e.item(t,n).replace(A,i._etag?{accessCondition:{type:"IfMatch",condition:i._etag}}:void 0);}catch(u){if(c(u,412)||c(u,409))return null;throw u}}else try{await e.items.create(A);}catch(u){if(c(u,409))return null;throw u}return async()=>{let u=await k();if(!u)return;let w=g(u);try{await e.item(t,n).replace(w,u._etag?{accessCondition:{type:"IfMatch",condition:u._etag}}:void 0);}catch{}}}}}function M(e){return new TextDecoder().decode(e)}function P(e,t={}){return {async read(r){if(!await e.getBlobClient(r).exists())return null;let n=await e.getBlobClient(r).downloadToBuffer();return M(n)},async write(r,n){await e.getBlockBlobClient(r).upload(n,new TextEncoder().encode(n).byteLength,{blobHTTPHeaders:{blobContentType:t.defaultContentType??"application/json; charset=utf-8"}});},exists(r){return e.getBlobClient(r).exists()},async remove(r){await e.getBlobClient(r).deleteIfExists();},async readBytes(r){return await e.getBlobClient(r).exists()?await e.getBlobClient(r).downloadToBuffer():null},async writeBytes(r,n){await e.getBlockBlobClient(r).upload(n,n.byteLength,{blobHTTPHeaders:{blobContentType:t.defaultContentType??"application/octet-stream"}});},async listKeys(r=""){let n=[];for await(let o of e.listBlobsFlat({prefix:r}))n.push(o.name);return n.sort()},async stat(r){if(!await e.getBlobClient(r).exists())return null;let n=await e.getBlobClient(r).getProperties();return {key:r,size:Number(n.contentLength??0),updatedAt:n.lastModified?.toISOString(),contentType:n.contentType}},keyRef(r){return t.keyRef?.(r)??{kind:"azure-blob-key",value:r}}}}function C(e){if(!e||typeof e!="object")return;let t=e;if(typeof t.statusCode=="number")return t.statusCode;if(typeof t.code=="number")return t.code}function y(e){let t=JSON.stringify(e),r=globalThis.Buffer;if(r)return r.from(t,"utf-8").toString("base64");if(typeof btoa=="function")return btoa(t);throw new Error("No base64 encoder available in this runtime")}function f(e){let t=e??"",r=globalThis.Buffer;if(r)return JSON.parse(r.from(t,"base64").toString("utf-8"));if(typeof atob=="function")return JSON.parse(atob(t));throw new Error("No base64 decoder available in this runtime")}function d(e,t){return (e??t()).toISOString()}function v(e,t){return {id:String(e.messageId??""),body:f(e.messageText),enqueuedAt:d(e.insertedOn??e.insertionTime,t),attempt:Number(e.dequeueCount??0)}}function h(e,t){return {id:String(e.messageId??""),body:f(e.messageText),enqueuedAt:d(e.insertedOn??e.insertionTime,t),attempt:Number(e.dequeueCount??0),leaseToken:String(e.popReceipt??""),leaseExpiresAt:d(e.nextVisibleOn,t)}}function R(e,t={}){let r=t.now??(()=>new Date);return {async enqueue(n){let o=await e.sendMessage(y(n));return {id:String(o.messageId??""),body:n,enqueuedAt:d(o.insertionTime,r),attempt:0}},async lease(n){return (await e.receiveMessages({numberOfMessages:n?.max,visibilityTimeout:n?.visibilityMs?Math.max(1,Math.ceil(n.visibilityMs/1e3)):void 0})).receivedMessageItems.map(s=>h(s,r))},async ack(n,o){try{return await e.deleteMessage(n,o),!0}catch(s){if(C(s)===404)return false;throw s}},async nack(n,o,s){try{if(s?.dead){if(!t.deadLetterQueueClient)return !1;let a={messageId:n,reason:s.reason??null};return await t.deadLetterQueueClient.sendMessage(y(a)),await e.deleteMessage(n,o),!0}return await e.updateMessage(n,o,y({requeued:!0}),0),!0}catch(a){if(C(a)===404)return false;throw a}},async peekActive(n=""){return (await e.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>v(s,r)).filter(s=>!n||s.id.startsWith(n))},async peekDeadLetter(n=""){return t.deadLetterQueueClient?(await t.deadLetterQueueClient.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>{let a=f(s.messageText);return {id:String(s.messageId??""),body:a,enqueuedAt:d(s.insertedOn??s.insertionTime,r),attempt:Number(s.dequeueCount??0),reason:typeof a.reason=="string"?a.reason:void 0}}).filter(s=>!n||s.id.startsWith(n)):[]}}}exports.a=B;exports.b=x;exports.c=D;exports.d=P;exports.e=R;//# sourceMappingURL=chunk-5XHOHTLZ.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-5XHOHTLZ.cjs.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
function p(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function m(e){let n=e.payload??{};return {id:e.id,role:typeof n.role=="string"?n.role:"system",text:typeof n.text=="string"?n.text:"",files:Array.isArray(n.files)?n.files:[],turn:typeof n.turn=="string"?n.turn:"",updated_at:typeof n.updated_at=="string"?n.updated_at:""}}function R(e,n){let a=t=>`chats/${p(t)}/processing`,r=t=>`chats/${p(t)}/config`;return {append(t,i,o,u=[],s=""){return e(t).append({role:i,text:o,files:u,turn:s,updated_at:new Date().toISOString()}).id},readAll(t){return e(t).readAll().map(m)},readAfter(t,i){let o=e(t).readAfter(i);return {records:o.entries.map(m),cursor:o.newCursor}},clear(t){e(t).clear?.();},setProcessing(t,i){i?n.write(a(t),true):n.delete(a(t));},isProcessing(t){return n.read(a(t))===true},getConfig(t){return n.read(r(t))??{}},setConfig(t,i){let o=n.read(r(t))??{};n.write(r(t),{...o,...i});}}}function S(){let e=globalThis.crypto;return typeof e?.randomUUID=="function"?String(e.randomUUID()):`id-${Date.now()}-${Math.random().toString(36).slice(2)}`}function $(){let e=new Map,n=new Map;function a(r){return e.has(r)||e.set(r,[]),e.get(r)}return {append(r,t,i,o=[],u=""){let s={id:S(),role:t,text:i,files:o,turn:u,updated_at:new Date().toISOString()};return a(r).push(s),s.id},readAll(r){return a(r).slice()},readAfter(r,t){let i=a(r);if(!t)return {records:i.slice(),cursor:i.length>0?i[i.length-1].id:null};let o=i.findIndex(s=>s.id===t),u=o===-1?i.slice():i.slice(o+1);return {records:u,cursor:u.length>0?u[u.length-1].id:t}},clear(r){e.set(r,[]);},setProcessing(r,t){t?n.set(`p:${r}`,true):n.delete(`p:${r}`);},isProcessing(r){return n.get(`p:${r}`)===true},getConfig(r){return n.get(`c:${r}`)??{}},setConfig(r,t){let i=n.get(`c:${r}`)??{};n.set(`c:${r}`,{...i,...t});}}}function y(){return new Date().toISOString()}function x(e){return new TextEncoder().encode(e).byteLength}function A(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function w(e){let n=String(e||"").match(/^(\d+)[-_]/);return n?parseInt(n[1],10):0}function I(e){let n=String(e||"").trim();if(!n)return "upload.bin";let a=Math.max(n.lastIndexOf("/"),n.lastIndexOf("\\"));return (a>=0?n.slice(a+1):n)||"upload.bin"}function k(e){return String(e||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function z(e){if(!e||e===".")return "";let n=String(e).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return n?`.${n}`:""}function F(e){let n=I(e),a=n.lastIndexOf(".");return a<=0||a===n.length-1?{stem:n,ext:""}:{stem:n.slice(0,a),ext:n.slice(a)}}function M(e){let n=e.lastIndexOf("/");return n>=0?e.slice(n+1):e}function L(e){function n(a){let r=e.stat?A(e.stat(a)):null;if(r)return r;if(!e.exists(a))return null;let t=e.read(a);return t===null?{key:a}:{key:a,size:x(t)}}return {exists(a){return e.exists(a)},putText(a,r,t="text/plain; charset=utf-8"){e.write(a,r);let i=n(a)??{key:a};return i.contentType=t,i.updatedAt=i.updatedAt??y(),i.size=i.size??x(r),i},putBytes(a,r,t="application/octet-stream"){if(e.writeBytes)e.writeBytes(a,r);else {let o=JSON.stringify({__kind:"bytes-array",data:[...r]});e.write(a,o);}let i=n(a)??{key:a};return i.contentType=t,i.updatedAt=i.updatedAt??y(),i.size=i.size??r.byteLength,i},getText(a){let r=e.read(a);if(r===null){if(!e.readBytes)return null;let t=e.readBytes(a);return t===null?null:Buffer.from(t).toString("utf-8")}try{let t=JSON.parse(r);if(t&&t.__kind==="bytes-array"&&Array.isArray(t.data))return new TextDecoder("utf-8").decode(new Uint8Array(t.data))}catch{}return r},getBytes(a){if(e.readBytes){let t=e.readBytes(a);if(t!==null)return t}let r=e.read(a);if(r===null)return null;try{let t=JSON.parse(r);if(t&&t.__kind==="bytes-array"&&Array.isArray(t.data))return new Uint8Array(t.data)}catch{}return new TextEncoder().encode(r)},head:n,list(a=""){return e.listKeys(a).map(r=>n(r)??{key:r}).sort((r,t)=>r.key.localeCompare(t.key))},remove(a){e.remove(a);}}}function b(e){function n(t,i){let o=0,u=[];Array.isArray(i)&&u.push(...i);for(let s of e.list(`${t}/`))u.push(M(s.key));for(let s of u){let l=w(s);Number.isFinite(l)&&l>o&&(o=l);}return o+1}function a(t,i,o){let u=Number(o?.maxLen||32),{stem:s,ext:l}=F(t),h=z(l),C=k(s),d=`${String(i).padStart(3,"0")}-`,g=h,f=u-d.length-g.length;f<1&&(g="",f=u-d.length);let _=C.slice(0,Math.max(1,f)),c=`${d}${_}${g}`;return c.length>u&&(c=c.slice(0,u).replace(/\.$/,"")),c}function r(t,i,o){let u=n(t,o?.seedNames),s=a(i,u,{maxLen:o?.maxLen});for(;e.exists(`${t}/${s}`);)u+=1,s=a(i,u,{maxLen:o?.maxLen});return s}return {nextSerial:n,buildStoredName:a,allocateStoredName:r}}function N(){function e(t,i){if(!Array.isArray(t))return [];let o=[];for(let u of t){if(!u||typeof u!="object")continue;let s=u;typeof s.stored_name=="string"&&o.push({name:typeof s.name=="string"?s.name:s.stored_name,stored_name:s.stored_name,size:typeof s.size=="number"&&Number.isFinite(s.size)?s.size:null,mime_type:typeof s.mime_type=="string"?s.mime_type:null,uploaded_at:typeof s.uploaded_at=="string"?s.uploaded_at:i||null,chat:s.chat===true});}return o}function n(t){return !t||typeof t!="object"?[]:e(t.files,void 0)}function a(t,i){let o=n(t);if(i.length===0)return t.files=o,o;let u=new Set(o.map(s=>s.stored_name));for(let s of i)u.has(s.stored_name)||(o.push(s),u.add(s.stored_name));return t.files=o,o}function r(t,i,o){let u=n(t);if(!Number.isInteger(i)||i<0||i>=u.length)return {ok:false,reason:"index_out_of_range"};let s=u[i];return !s||!s.stored_name?{ok:false,reason:"missing_stored_name"}:o&&o!==s.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:s}}return {read:n,normalizeIncoming:e,merge:a,resolve:r}}export{R as a,$ as b,L as c,b as d,N as e};//# sourceMappingURL=chunk-6APH25VI.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-6APH25VI.js.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {n,h,i,j,a as a$6,b as b$3,k,l as l$1,c as c$3,m}from'./chunk-QJVR3FWQ.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$1,b as b$1}from'./chunk-WHDEBJLT.js';import {a as a$4,d as d$1,b as b$4,c as c$2}from'./chunk-SGV7PU4H.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$7,b as b$5}from'./chunk-ZJ5M5COT.js';import {b,c as c$1,e}from'./chunk-6APH25VI.js';import {j as j$1,d,c,b as b$2}from'./chunk-PRKRXAVN.js';import {y,z,l}from'./chunk-JH37NJGP.js';import {a as a$5}from'./chunk-KBELAKIY.js';import {a}from'./chunk-76ON3V7R.js';function Zt(R){let{apiBasePath:k,json:v,readJsonBody:K,initBoardAndSetup:H,bootstrapBoard:I,buildPublishedRuntimePayload:W,createMcpControlplaneToolRegistry:U,retriggerCard:L,applyCardAction:G,resolveChatHandlerTarget:V,sendCardFileDownloadResponse:_}=R;async function X(Q,x,rt){let c=Q.method||"GET",p=rt,h=p.pathname;try{if(c==="GET"&&h===`${k}/init-board`)return await H(),v(x,200,await W()),!0;if(c==="POST"&&h===`${k}/mcp-controlplane`){await I();let w=await K(Q),b=typeof w.tool=="string"?w.tool.trim():"",S=w.args&&typeof w.args=="object"&&!Array.isArray(w.args)?w.args:{};if(!b)return v(x,400,{error:"tool is required"}),!0;try{let g=await a$7(b,S,U());if(g&&typeof g=="object"&&!Array.isArray(g)){let $=g;if($.status==="fail")return v(x,400,{error:b$5(g,"Request failed")}),!0;if($.status==="error")return v(x,500,{error:b$5(g,"Internal error")}),!0}v(x,200,g);}catch(g){let $=typeof g?.statusCode=="number"?Number(g.statusCode):500,N=g instanceof Error?g.message:String(g);v(x,$,{error:N});}return !0}let d=h.match(new RegExp(`^${c$2(k)}/cards/([^/]+)/retrigger$`));if(c==="POST"&&d){await I();let w=decodeURIComponent(d[1]);return await L(w),v(x,200,{ok:!0}),!0}let O=h.match(new RegExp(`^${c$2(k)}/cards/([^/]+)/actions$`));if(c==="POST"&&O){await I();let w=decodeURIComponent(O[1]),b=Date.now(),S=new Date(b).toISOString(),g=await K(Q),$=g?.actionType;if($==="chat-send"&&!await V(w)){let C=Date.now();return v(x,409,{error:`chat handler is not configured for card: ${w}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(C).toISOString(),responseSentAtMs:C,responseStatus:409}),!0}if($==="chat-send"){let C=g?.payload??{},J=typeof C["turn-id"]=="string"?C["turn-id"]:typeof C.turnId=="string"?C.turnId:typeof C.turn=="string"?C.turn:"";if(!J||!String(J).trim()){let q=Date.now();return v(x,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${w}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(q).toISOString(),responseSentAtMs:q,responseStatus:400}),!0}}await G(w,$,g?.payload);let N=Date.now();return v(x,200,{ok:!0,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(N).toISOString(),responseSentAtMs:N,responseStatus:200}),!0}let E=h.match(new RegExp(`^${c$2(k)}/cards/([^/]+)/files/(\\d+)$`));if(c==="GET"&&E){let w=decodeURIComponent(E[1]),b=parseInt(E[2],10),S=p.searchParams.get("sn");return await _(x,w,b,S),!0}return !1}catch(d){let O=d?.statusCode||500;return v(x,O,{error:String(d?.message||d)}),true}}return {handleRuntimeApi:X}}var Yt={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},Xt="chat-handler-flow-queue";function nr(R){let k$1=String(R.apiBasePath||"/api/board").replace(/\/$/,""),v={...Yt,...R.corsHeaders||{}},K=R.queueLaneTuning??{},H=R.boardId||"",I=R.logger||{info:console.log,warn:console.warn,error:console.error},W=R.invocationAdapter,U=R.chatFlowRunner||null,L=R.chatStorage??b(),G=a(L),V=R.notificationTransport||null,_=R.serverUrl||null,X=R.executionExtra||{},Q=R.onSseClientConnected,x=R.onSseClientDisconnected,rt=R.onChannelSubscribed,c$2=R.onChannelUnsubscribed,p=a$1({chatStorage:L,readChatRecords:t=>yt(t),onSseClientDisconnected:x});function h$1(t){function e(a){if(Array.isArray(a))return a;if(a&&typeof a=="object"){let s=a;return Array.isArray(s.files)?s.files:[a]}return null}function r(a){return {async get(s){return a.get(s)},async set(s){return a.set(s)},async del(s){return a.del(s)},async patch(s){return a.patch(s)},async appendFiles(s){return a.appendFiles(s)}}}function o(a){function s(m){return {status:"success",data:m}}function l(m){return {status:"fail",error:m}}function u(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}return {async get(m){try{let f=m.params?.id;if(f){let T=await a.readCard(f);return T?s({cards:[T]}):l(`card "${f}" not found`)}return s({cards:await a.readAllCards()})}catch(f){return u(f)}},async set(m){try{let f=m.body;if(f==null)return l("set requires a body (card object or array of cards)");let T=Array.isArray(f)?f:[f];for(let j of T){if(typeof j.id!="string")return l("each card must have a string `id` field");await a.writeCard(j.id,j);}return s({count:T.length})}catch(f){return u(f)}},async del(m){try{let f=m.body?.ids??[],T=m.params?.id,j=T?[...f,T]:f;if(j.length===0)return l("del requires body.ids (string[]) or params.id");for(let tt of j)await a.removeCard(tt);return s({count:j.length})}catch(f){return u(f)}},async patch(m){try{let f=m.params?.id,T=m.params?.path;if(!f)return l("patch requires params.id");if(!T)return l("patch requires params.path");let j=m.body,tt=j&&Object.prototype.hasOwnProperty.call(j,"value")?j.value:m.body;return await a.patchCard(f,T,tt),s({count:1})}catch(f){return u(f)}},async appendFiles(m){try{let f=m.params?.id;if(!f)return l("appendFiles requires params.id");let T=await a.readCard(f);if(!T)return l(`card "${f}" not found`);let j=e(m.body);if(!j||j.length===0)return l("appendFiles requires a file metadata object, array, or body.files array");let tt=T.card_data&&typeof T.card_data=="object"&&!Array.isArray(T.card_data)?T.card_data:{},At=Array.isArray(tt.files)?tt.files:[],ve=[...At,...j];return await a.patchCard(f,"card_data.files",ve),s({files_added:j.map((Oe,Pe)=>({idx:At.length+Pe,entry:Oe}))})}catch(f){return u(f)}}}}let n=a$4(t.boardAdapter)?j$1(t.baseRef,t.boardAdapter):y(t.baseRef,t.boardAdapter),i=t.nonCoreAdapter??(!a$4(t.boardAdapter)&&w(t.boardAdapter)?t.boardAdapter:null),y$1=t.nonCore??(i?z(t.baseRef,i):null),P,A=a$4(t.boardAdapter)?(()=>{let a=d(c(b$2(t.boardAdapter.kvStorageForRef(t.cardStoreRef)),t.boardAdapter.hashFn),I.warn),s=o(a);return P={get(l){return s.get(l)},set(l){return s.set(l)}},s})():(()=>{let a=t.boardAdapter.kvStorageForRef(t.cardStoreRef),l$1=a$5(l({readIndex:()=>a.read("_index"),writeIndex:u=>a.write("_index",u),readCard:u=>a.read(u),writeCard:(u,m)=>(a.write(u,m),u),removeCard:u=>{a.delete(u);},cardExists:u=>a.read(u)!==null,defaultCardKey:u=>u},I.warn));return P=l$1,r(l$1)})(),F=t.artifactsAdapter||t.boardAdapter,B=t.filesArtifactsStore??null,M=B?{putBytes(a,s,l){B.putBytes(a,s,l);},getBytes(a){return B.getBytes(a)},listKeys(a){return B.list(a).map(s=>s.key)}}:null;if(!M&&!a$4(F)){let a=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files"),s=c$1(a);M={putBytes(l,u,m){s.putBytes(l,u,m);},getBytes(l){return s.getBytes(l)},listKeys(l){return s.list(l).map(u=>u.key)}};}else if(!M&&a$4(F)){let a=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files");M={async putBytes(s,l){if(a.writeBytes){await a.writeBytes(s,l);return}let u=JSON.stringify({__kind:"bytes-array",data:[...l]});await a.write(s,u);},async getBytes(s){if(a.readBytes){let u=await a.readBytes(s);if(u!==null)return u}let l=await a.read(s);if(l===null)return null;try{let u=JSON.parse(l);if(u&&u.__kind==="bytes-array"&&Array.isArray(u.data))return new Uint8Array(u.data)}catch{}return new TextEncoder().encode(l)},async listKeys(s){return await a.listKeys(s)}};}let D={async init(a){return n.init(a)},async status(a){return n.status(a)},async getConfig(a){return n.getConfig(a)},async getAllOutputsDataObjects(a){return n.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return n.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return n.getOutputsFetchedSources(a)},async upsertCard(a){return n.upsertCard(a)},async removeCard(a){return n.removeCard(a)},async cardRefreshedNotify(a){return n.cardRefreshedNotify(a)},async sourceDataFetched(a){return n.sourceDataFetched(a)},async sourceDataFetchFailure(a){return n.sourceDataFetchFailure(a)}};return {label:t.label,board:n,nonCore:y$1,publicCardStore:P,boardOps:D,cardStoreOps:A,get filesArtifacts(){return M},boardAdapter:t.boardAdapter,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,archiveStoreRef:t.archiveStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:a$6(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let d$2=R.boards.map(h$1),O=new Map;function E(t){return O.get(t)??0}function w(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function b$5(t){let e=d$2[E(t)];return {files:e?e.filesArtifacts:null}}function S(){return e()}function g(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function $(t){if(!t||t.notificationTeardown||!V||!t.notifyRef)return;let e=await V.subscribe(t.notifyRef,r=>{c$3(t.notification,r);let o=r.kind==="notification-batch"?r.notifications:[r];p.broadcastNotificationBatch(o);});t.notificationTeardown=e;}async function N(t){if(!t||t.initialized)return;let e={cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef};t.artifactsStoreRef&&(e.artifactsStoreRef=t.artifactsStoreRef),t.chatStoreRef&&(e.chatStoreRef=t.chatStoreRef),t.scratchStoreRef&&(e.scratchStoreRef=t.scratchStoreRef),t.archiveStoreRef&&(e.archiveStoreRef=t.archiveStoreRef);let r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow),t.inferenceAdapterRef&&(r["inference-adapter-ref"]=t.inferenceAdapterRef);let o=await t.boardOps.init({params:e,body:r});if(o.status!=="success")throw Object.assign(new Error(o.error||`init failed for ${t.label}`),{statusCode:500});if(await $(t),!t.chatHandlerFlow&&t.chatHandlerRef&&W.describe)try{let n=await W.describe(t.chatHandlerRef);n&&n.kind!=="chat-handler"?I.warn(`[init] chat-handler describe returned kind="${n.kind}", expected "chat-handler" for ${t.label}`):n&&I.info(`[init] chat-handler validated: ${n.name} (protocol ${n.protocolVersion}) for ${t.label}`);}catch(n){I.warn(`[init] chat-handler describe failed for ${t.label}: ${n?.message||String(n)}`);}t.initialized=true;}async function C(t){if(!t.boardAdapter.publishBoardChangeNotifications)return;let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&b$3(r.data)&&e.push({kind:"status",status:r.data});let o=await t.boardOps.getAllOutputsDataObjects({});if(o.status==="success"&&o.data!=null)for(let[i,y]of Object.entries(o.data))i&&e.push({kind:"data_object",key:i,payload:y});let n=await t.boardOps.getAllOutputsComputedValues({});if(n.status==="success"&&n.data!=null)for(let[i,y]of Object.entries(n.data))i&&e.push({kind:"computed_values",cardId:i,values:y});e.length>0&&t.boardAdapter.publishBoardChangeNotifications(e);}async function J(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),o=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let n of o)typeof n.id=="string"&&(O.set(n.id,e),await t.boardOps.upsertCard({params:{cardId:n.id}}));t.cardsBootstrapped=true;}async function q(){for(let t of d$2)await N(t);}async function it(){await q();for(let t=0;t<d$2.length;t++)await C(d$2[t]),await J(d$2[t],t),await C(d$2[t]);}async function ct(t=false){t||await q();for(let e of d$2){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}async function te(){return await q(),ct(true)}function Y(t){return d$2[E(t)]??null}async function nt(t){let e=Y(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let o=Array.isArray(r.data?.cards)?r.data.cards:[];return o.length>0?o[0]:null}async function ft(){let t=async r=>{if(!r)return [];let o=await r.cardStoreOps.get({});return o.status!=="success"||!Array.isArray(o.data?.cards)?[]:o.data.cards},e=[];for(let r of d$2)e.push(...await t(r));return e}function ee(){return d$2[0]??null}let pt=n({boardContexts:d$2,cardOwnerIndex:O,cardContextForCard:t=>Y(t),readStatusSnapshot:()=>ie(),readDataObjectsByToken:()=>de(),readCardRuntimeArtifacts:()=>ce(),readCardFromStore:t=>nt(t),readCardDefinitions:()=>ft(),processAccumulatedLaneInternal:t=>ct(t),reportSourceFetched:(t,e)=>bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Ct(t,{reason:e}),uploadCardFile:(t,e,r,o,n)=>Rt(t,e,r,o,n),chatStorePublic:G,serverUrl:_,apiBasePath:k$1}),re=pt.mcpCardStoreFacade,z$1=pt.createMcpFacade,ne=h({boardId:H,getMcpFacade:()=>z$1(),getMcpCardStoreFacade:()=>re()});function ae(t){return k(t)}function oe(){return l$1(z$1())}function se(){return m({boardId:H,uploadCardFile:Rt,getMcpFacade:()=>z$1(),controlplane:ne})}let at=i({boardId:H,boardContexts:d$2,readCardDefinitions:()=>ft(),readChatRecords:t=>yt(t),getChatProcessing:t=>z$1().getChatProcessing({cardId:t}).active}),ie=at.readStatusSnapshot,ce=at.readCardRuntimeArtifacts,de=at.readDataObjectsByToken,dt=at.buildPublishedRuntimePayload;async function mt(t,e,r){let o=r?.syncBoard!==false,n=r?.restartOnlyIfChanged===true,i=Y(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let y=await nt(t);if(!y)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let P=n?JSON.stringify(y):null,A=e(y)||y;if(n&&JSON.stringify(A)===P)return;let F=await i.cardStoreOps.set({body:A});if(F.status!=="success")throw Object.assign(new Error(F.error||`Failed to persist card: ${t}`),{statusCode:500});if(o){let B=await i.boardOps.upsertCard({params:{cardId:t,restart:true}});if(B.status!=="success")throw Object.assign(new Error(B.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function ue(t,e){await mt(t,e,{syncBoard:true});}async function gt(t,e){await mt(t,e,{syncBoard:false});}async function le(t){let e=Y(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await nt(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let o=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(o.status!=="success")throw Object.assign(new Error(o.error||`Failed to retrigger card: ${t}`),{statusCode:500})}function fe(t){L.clear(t);try{z$1().setChatProcessing({cardId:t,active:!1});}catch{}}function pe(t,e,r,o,n=""){let i=typeof r=="string"?r.trim():"";return L.append(t,e||"system",i,o,n)}function yt(t){return L.readAll(t)}let Rt=j({safeCardId:t=>g(t),artifactsStores:t=>b$5(t),cardFileMetadataStore:()=>S(),readCardFromStore:t=>nt(t),updateCardLocalOnly:(t,e)=>gt(t,e),writeChatRecord:(t,e,r,o,n)=>pe(t,e,r,o,n)}).uploadCardFile;async function ht(t){let e=Y(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=r.status==="success"?r.data?.value:null,n=e.chatHandlerRef;return o==null&&(!n||typeof n!="object")?null:{ctx:e,handlerFlow:o,handlerRef:n}}async function me(t,e,r=false,o=""){let n=await ht(t);if(!n)return;let{ctx:i,handlerFlow:y,handlerRef:P}=n;if(!r)try{z$1().setChatProcessing({cardId:t,active:!0});}catch{}let A={boardId:H,cardId:String(t),lastChatEntryId:e,...o?{turnId:o}:{},...X,..._?{serverUrl:_}:{}},F=y!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:Xt}}:P;try{a$4(i.boardAdapter)?await i.boardAdapter.chatAgentStore().enqueueRequest({boardId:H,ref:F,args:y!=null?{...A,__chatHandlerFlow:y}:A}):i.boardAdapter.chatAgentStore().enqueueRequest({boardId:H,ref:F,args:y!=null?{...A,__chatHandlerFlow:y}:A}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(B){try{z$1().setChatProcessing({cardId:t,active:!1});}catch{}I.warn(`[chat-handler] queue failed for card "${t}": ${B instanceof Error?B.message:String(B)}`);}}async function ge(t,e,r){if(e.howToRun==="built-in"&&b$4(e)===Xt){let o=U,n=r.__chatHandlerFlow,i={...r};return delete i.__chatHandlerFlow,o?o.run(n,i,{boardId:H,cardId:String(i.cardId||""),label:t.label,logger:I,serverUrl:_,executionExtra:X}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return W.invoke(e,r)}async function ye(t,e=false){e||await q();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",o=r?Y(r):ee();if(!o)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let n=await ge(o,t.ref,t.args);if(!n.dispatched){if(r)try{L.setProcessing(r,!1);}catch{}throw new Error(n.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Re(t,e,r){let o=e==="chat-send"?gt:ue,n;await o(t,i=>{let y=new Date().toISOString(),P=i.card_data&&typeof i.card_data=="object"?i.card_data:{};if(i.card_data=P,e==="chat-send"){let A=r&&typeof r.text=="string"?r.text.trim():"",F=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"",B=[];if(Array.isArray(r?.files)){for(let M of r.files)if(M){if(typeof M=="string"){B.push({name:M});continue}if(typeof M=="object"){let D=M;typeof D.name=="string"&&B.push({name:D.name,size:D.size,mime_type:D.mime_type,uploaded_at:D.uploaded_at,stored_name:D.stored_name,chat:D.chat===true});}}}if(A||B.length>0){let M=G.runBatch({cardId:t,commands:[{command:"append",role:"user",text:A,files:B,turn:F},{command:"set-processing",active:true}]});if(M.status!=="success")throw new Error(M.error);let D=M.data.results[0]?.data?.id;if(typeof D!="string"||!D)throw new Error(`chat-send did not return an append id for card ${t}`);n={cardId:t,lastEntryId:D,processingAlreadySet:true,turnId:F};try{p.broadcastCardChats(t);}catch{}}return i}if(e==="file-upload"){let A=S().normalizeIncoming(r?.files,y);return A.length>0&&S().merge(P,A),i}if(e==="action"){let A=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!A)return i;P.lastAction={buttonId:A,at:y},P.lastActionText=`${A} @ ${y}`;}return i}),n&&me(n.cardId,n.lastEntryId,n.processingAlreadySet,n.turnId??"");}function ot(t,e,r){let o=JSON.stringify(r),n=typeof Buffer<"u"?Buffer.byteLength(o):new TextEncoder().encode(o).length;t.writeHead(e,{...v,"Content-Type":"application/json; charset=utf-8","Content-Length":n}),t.end(o);}async function wt(t,e,r){let o=await nt(t);if(!o)throw Object.assign(new Error("Card not found"),{statusCode:404});let n=S().resolve(o.card_data,e,r);if(!n.ok&&n.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!n.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let i=n.file,y=g(t),P=b$5(t),A=String(i.stored_name||""),F=`${y}/${A}`,B=P.files?await P.files.getBytes(F):null;if(!B)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:i,bytes:B}}async function he(t,e,r,o){let{fileRecord:n,bytes:i}=await wt(e,r,o),y=String(n.name||n.stored_name||"download.bin"),P=String(n.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":P,"Content-Disposition":`attachment; filename="${y}"`,"Content-Length":i.length}),t.end(i);}function we(t){let e=String(t||"").toLowerCase();return e.startsWith("text/")||e.includes("json")||e.includes("xml")||e.includes("javascript")||e.includes("typescript")||e.includes("yaml")||e.includes("csv")}function be(t,e,r){let o=t.split(/\r?\n/);return (e==="head"?o.slice(0,r):o.slice(-r)).join(`
|
|
2
|
+
`)}async function st(t){let e=[];for await(let o of t)e.push(o);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(d$1(e)).trim();return r?JSON.parse(r):{}}async function bt(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let o=d$2[0];return o?o.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Ct(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",o=d$2[0];return o?o.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let Ce=b$1({sseHub:p,corsHeaders:v,json:ot,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:Q,onChannelSubscribed:rt,onChannelUnsubscribed:c$2,apiBasePath:k$1,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),bootstrapBoard:()=>it(),boardContexts:d$2,publishPersistedStateSnapshot:t=>C(t),upsertCardsFromSource:(t,e)=>J(t,e)}).handleWatchersRoutes,Ae=a$2({apiBasePath:k$1,json:ot,readJsonBody:t=>st(t),bootstrapBoard:()=>it(),createMcpFacade:()=>z$1(),createMcpToolRegistry:t=>ae(t),resolveCardFileDownloadPayload:(t,e,r)=>wt(t,e,r),isLikelyTextMimeType:t=>we(t),sliceTextByLines:(t,e,r)=>be(t,e,r)}).handleAgentfaceApi,Se=a$3({apiBasePath:k$1,json:ot,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),createMcpWebhookToolRegistry:()=>oe()}).handleWebhooksApi,Be=Zt({apiBasePath:k$1,json:ot,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),bootstrapBoard:()=>it(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>se(),retriggerCard:t=>le(t),applyCardAction:(t,e,r)=>Re(t,e,r),resolveChatHandlerTarget:t=>ht(t),sendCardFileDownloadResponse:(t,e,r,o)=>he(t,e,r,o)}).handleRuntimeApi;async function ke(t,e,r){return !!(await Ae(t,e,r)||await Se(t,e,r)||await Ce(t,e,r)||await Be(t,e,r))}return {get apiBasePath(){return k$1},get corsHeaders(){return v},get queueLaneTuning(){return K},handleRuntimeApi:ke,buildPublishedRuntimePayload:dt,processAccumulatedEvents:te,processAccumulatedLane:ct,handleChatAgentRequest:ye,clearChatRecords:fe,reportSourceFetched(t,e){return bt(t,{ref:e})},reportSourceFetchFailure(t,e){return Ct(t,{reason:e})},get cardStore(){return d$2[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function ar(R){let k=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),v={...Yt,...R.corsHeaders||{}},K=R.serverMetaStore,H=R.boardRuntimeFactory,I=new Map,W="boards-config.json";function U(){let c=K.getText(W);if(!c)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(c)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function L(c){K.putText(W,JSON.stringify(c,null,2));}function G(c){let p=String(c||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return p.length>0&&p.length<=64?p:null}function V(c){if(I.has(c))return I.get(c);let h=U().boards.find(O=>O.id===c)||{},d=H(c,h);return I.set(c,d),d}function _(c,p,h){let d=JSON.stringify(h),O=typeof Buffer<"u"?Buffer.byteLength(d):new TextEncoder().encode(d).length;c.writeHead(p,{...v,"Content-Type":"application/json; charset=utf-8","Content-Length":O}),c.end(d);}async function X(c,p,h){let d=c.method||"GET",O=h.pathname;if(d==="GET"&&O===k)return _(p,200,{ok:true,boards:U().boards}),true;if(d==="POST"&&O===k){let E=[];for await(let C of c)E.push(C);let w=typeof Buffer<"u"?Buffer.concat(E).toString("utf-8").trim():new TextDecoder().decode(d$1(E)).trim(),b={};try{b=w?JSON.parse(w):{};}catch{b={};}let S=G(b.id);if(!S)return _(p,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let g=U();if(g.boards.some(C=>C.id===S))return _(p,409,{error:`Board "${S}" is already registered`}),true;let $=typeof b.label=="string"&&b.label.trim()?b.label.trim():S,N={id:S,label:$};for(let[C,J]of Object.entries(b))C==="id"||C==="label"||J!=null&&(N[C]=J);return g.boards.push(N),L(g),_(p,200,{ok:true,board:N}),true}return false}async function Q(c,p,h){let O=h.pathname.match(new RegExp(`^${c$2(k)}/([^/]+)(/|$)`));if(!O)return false;let E=G(decodeURIComponent(O[1]));return E?U().boards.some(S=>S.id===E)?!!await V(E).handleRuntimeApi(c,p,h):(_(p,404,{error:`Board "${E}" not registered. POST ${k} with {id} to register it first.`}),true):(_(p,400,{error:"Invalid board id"}),true)}async function x(c,p,h){return !!(await X(c,p,h)||await Q(c,p,h))}function rt(c){if(!U().boards.some(h=>h.id===c))throw Object.assign(new Error(`Board "${c}" not registered`),{statusCode:404});return {service:V(c)}}return {get apiBasePath(){return k},get corsHeaders(){return v},handleApi:x,requireBoardService:rt}}export{nr as a,ar as b};//# sourceMappingURL=chunk-76C7N4YT.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-76C7N4YT.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs');function G(q){let{apiBasePath:x,json:r,readJsonBody:k,bootstrapBoard:T,createMcpFacade:B,createMcpToolRegistry:I,resolveCardFileDownloadPayload:j,isLikelyTextMimeType:v,sliceTextByLines:C}=q;async function D(b,e,N){let A=b.method||"GET",M=N,L=M.pathname;try{if(A==="POST"&&L===`${x}/mcp`){await T();let t=await k(b),i=typeof t.tool=="string"?t.tool.trim():"",a=t.args&&typeof t.args=="object"&&!Array.isArray(t.args)?t.args:{};if(!i)return r(e,400,{error:"tool is required"}),!0;if(i==="inspect.file-contents")return r(e,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let n=await chunk272IYUKT_cjs.a(i,a,I(B()));if(n&&typeof n=="object"&&!Array.isArray(n)){let s=n;if(s.status==="fail")return r(e,400,{error:chunk272IYUKT_cjs.b(n,"Request failed")}),!0;if(s.status==="error")return r(e,500,{error:chunk272IYUKT_cjs.b(n,"Internal error")}),!0}r(e,200,n);}catch(n){let s=typeof n?.statusCode=="number"?Number(n.statusCode):500,d=n instanceof Error?n.message:String(n);r(e,s,{error:d});}return !0}if(A==="POST"&&L===`${x}/mcp-raw`){await T();let t=await k(b),i=typeof t.tool=="string"?t.tool.trim():"",a=t.args&&typeof t.args=="object"&&!Array.isArray(t.args)?t.args:{};if(!i)return r(e,400,{error:"tool is required"}),!0;if(i!=="inspect.file-contents")return r(e,400,{error:`Tool does not support raw response: ${i}`}),!0;let n=chunkLPXVVMQT_cjs.a(a,"card_id","cardId"),s=chunkLPXVVMQT_cjs.b(a,"file_idx","fileIdx"),d=chunkLPXVVMQT_cjs.b(a,"head-lines","headLines"),m=chunkLPXVVMQT_cjs.b(a,"tail-lines","tailLines"),f=chunkLPXVVMQT_cjs.b(a,"head-bytes","headBytes"),y=chunkLPXVVMQT_cjs.b(a,"tail-bytes","tailBytes");if(!n)return r(e,400,{error:"inspect.file-contents requires card_id"}),!0;if(s===void 0||!Number.isInteger(s)||s<0)return r(e,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([d,m,f,y].filter(o=>o!==void 0).length>1)return r(e,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[o,u]of [["head-lines",d],["tail-lines",m],["head-bytes",f],["tail-bytes",y]])if(u!==void 0&&(!Number.isInteger(u)||u<0))return r(e,400,{error:`inspect.file-contents requires ${o} to be a non-negative integer`}),!0;let F=await B().inspectFileContents({cardId:n,fileIdx:s}),$=typeof F?.stored_name=="string"?F.stored_name:null,{fileRecord:R,bytes:p}=await j(n,s,$),P=String(R.name||R.stored_name||"download.bin"),w=String(R.mime_type||"application/octet-stream"),g=(M.searchParams.get("resp")||"").trim().toLowerCase();if(g&&g!=="json-b64")return r(e,400,{error:`unsupported resp mode: ${g}`}),!0;let U=g==="json-b64",c;if(d!==void 0||m!==void 0){if(!v(w))return r(e,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let o=new TextDecoder().decode(p),u=d!==void 0?C(o,"head",d):C(o,"tail",m);c=typeof Buffer<"u"?Buffer.from(u,"utf8"):new TextEncoder().encode(u);}else if(f!==void 0||y!==void 0){let o=f??y;c=f!==void 0?p.slice(0,o):p.slice(Math.max(0,p.length-o));}else c=p;if(U){let o=typeof Buffer<"u"?Buffer.from(c).toString("base64"):btoa(String.fromCharCode(...c));return r(e,200,{bodyBase64:o,mimeType:w,filename:P,byteLength:c.length}),!0}return e.writeHead(200,{"Content-Type":w,"Content-Disposition":`attachment; filename="${P}"`,"Content-Length":c.length}),e.end(c),!0}return !1}catch(t){let i=t?.statusCode||500;return r(e,i,{error:String(t?.message||t)}),true}}return {handleAgentfaceApi:D}}exports.a=G;//# sourceMappingURL=chunk-7FGPOGRV.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-7FGPOGRV.cjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
'use strict';var chunkKAWQPLIE_cjs=require('./chunk-KAWQPLIE.cjs');function A(h){let r=new Map,a=new Map,d=new Map,I=0,b=null;function g(e){let t=JSON.stringify(e);return I++,`id: ${I}
|
|
2
|
+
data: ${t}
|
|
3
|
+
|
|
4
|
+
`}function C(e){let t=e;try{t.flushHeaders?.();}catch{}try{t.flush?.();}catch{}try{t.socket?.setNoDelay?.(!0);}catch{}try{t.socket?.uncork?.();}catch{}}function y(e,t){let s=r.get(e);if(s&&!(t&&s.res!==t)){r.delete(e),w();try{h.onSseClientDisconnected?.(e);}catch{}try{s.res.end();}catch{}}}function v(e,t,s){let n=r.get(e);n&&y(e,n.res),r.set(e,{res:t,subscribedChatCardIds:s??new Set});}function f(e,t){let s=r.get(e);if(!s)return;let n=g(t);try{s.res.write(n),C(s.res);}catch{y(e,s.res);}}function c(){let e=new Set;for(let t of r.values())for(let s of t.subscribedChatCardIds)e.add(s);return Array.from(e)}function l(e){let t=a.has(e)?a.get(e):null,{cursor:s}=h.chatStorage.readAfter(e,t),n=h.chatStorage.isProcessing(e),o=n!==(d.get(e)??false),S=s!==t;return S&&a.set(e,s),d.set(e,n),S||o}function u(e,t){let s=h.readChatRecords(e),n=Date.now();return {kind:"card_chats",cardId:e,sentAt:new Date(n).toISOString(),sentAtMs:n,messages:s.map(o=>({role:String(o.role||"system"),text:String(o.text||""),files:Array.isArray(o.files)?o.files:[]})),receiving:t,processing:h.chatStorage.isProcessing(e)}}function i(e,t=true){let s={kind:"notification-batch",notifications:[u(e,t)]};for(let[n,o]of r.entries())o.subscribedChatCardIds.has(e)&&f(n,s);}function w(){c().length>0||(b&&(clearInterval(b),b=null),a.clear(),d.clear());}function p(){if(b)return;let e=()=>{let t=c();if(t.length===0){w();return}let s=new Set(t);for(let n of Array.from(a.keys()))s.has(n)||a.delete(n);for(let n of Array.from(d.keys()))s.has(n)||d.delete(n);for(let n of t)l(n)&&i(n,true);};e(),b=setInterval(e,1e3);}function k(e,t){let s=r.get(e);if(!s)return false;s.subscribedChatCardIds.add(t);let{cursor:n}=h.chatStorage.readAfter(t,null);return a.set(t,n),d.set(t,h.chatStorage.isProcessing(t)),p(),f(e,{kind:"notification-batch",notifications:[u(t,true)]}),true}function m(e,t){let s=r.get(e);return s?(s.subscribedChatCardIds.delete(t),c().includes(t)||(a.delete(t),d.delete(t)),w(),true):false}function R(e){if(!e||typeof e!="object")return false;let t=e.kind;return t==="card_chats"||t==="chat_messages"}function P(e){if(!e||e.length===0)return;let t=[],s=new Set;for(let n of e)R(n)&&typeof n.cardId=="string"?s.add(String(n.cardId)):t.push(n);if(t.length>0){let n={kind:"notification-batch",notifications:t};for(let o of r.keys())f(o,n);}for(let n of s)i(n,true);}return {size:()=>r.size,has:e=>r.has(e),get:e=>r.get(e),buildFrame:g,flushTransport:C,register:v,disconnect:y,writeFrame:f,subscribeChat:k,unsubscribeChat:m,broadcastNotificationBatch:P,broadcastCardChats:i}}function D(h){let{sseHub:r,corsHeaders:a,json:d,buildPublishedRuntimePayload:I,onSseClientConnected:b,onChannelSubscribed:g,onChannelUnsubscribed:C}=h;function y(f,c,l,u,i){if(!r.has(c)){d(f,404,{error:`SSE client not connected: ${c}`});return}i?g?.(c,l,u):C?.(c,l,u),d(f,200,{ok:true,clientId:c,channelName:l,...u.cardId?{cardId:u.cardId}:{},subscribed:i});}async function v(f,c,l){let u=r.get(l),i=u?new Set(u.subscribedChatCardIds):new Set;c.writeHead(200,{...a,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),r.flushTransport(c),r.register(l,c,i);let w=await I(),p=r.buildFrame(w);c.write(p);try{b?.(l,m=>{r.writeFrame(l,m);});}catch{}let k=setInterval(()=>{try{c.write(`: keepalive
|
|
5
|
+
|
|
6
|
+
`);}catch{}},15e3);f.on("close",()=>{clearInterval(k),r.disconnect(l,c);});}return {handleChannelSubscription:y,handleSse:v}}function T(h){let{apiBasePath:r,json:a,readJsonBody:d,initBoardAndSetup:I,bootstrapBoard:b,boardContexts:g,publishPersistedStateSnapshot:C,upsertCardsFromSource:y,sseHub:v}=h,{handleSse:f,handleChannelSubscription:c}=D(h);async function l(u,i,w){let p=u.method||"GET",k=w,m=k.pathname;try{if(p==="GET"&&m===`${r}/sse`){await I();let s=String(k.searchParams.get("clientId")||"").trim();if(!s)return a(i,400,{error:"clientId query param is required for SSE"}),!0;await f(u,i,s);for(let n=0;n<g.length;n++)await C(g[n]),await y(g[n],n),await C(g[n]);return !0}let R=m.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(r)}/cards/([^/]+)/chats/subscribe-sse$`));if(p==="POST"&&R){await b();let s=decodeURIComponent(R[1]),n=await d(u),o=typeof n?.clientId=="string"?n.clientId.trim():"";return o?v.subscribeChat(o,s)?(a(i,200,{ok:!0,clientId:o,cardId:s,subscribed:!0}),!0):(a(i,404,{error:`SSE client not connected: ${o}`}),!0):(a(i,400,{error:"clientId is required"}),!0)}let P=m.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(r)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(p==="POST"&&P){await b();let s=decodeURIComponent(P[1]),n=await d(u),o=typeof n?.clientId=="string"?n.clientId.trim():"";return o?v.unsubscribeChat(o,s)?(a(i,200,{ok:!0,clientId:o,cardId:s,subscribed:!1}),!0):(a(i,404,{error:`SSE client not connected: ${o}`}),!0):(a(i,400,{error:"clientId is required"}),!0)}let e=m.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(r)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&e){await b();let s=decodeURIComponent(e[1]),n=e[2]==="subscribe",o=await d(u),S=typeof o?.clientId=="string"?o.clientId.trim():"";return S?(c(i,S,s,{},n),!0):(a(i,400,{error:"clientId is required"}),!0)}let t=m.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(r)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&t){await b();let s=decodeURIComponent(t[1]),n=decodeURIComponent(t[2]),o=t[3]==="subscribe",S=await d(u),H=typeof S?.clientId=="string"?S.clientId.trim():"";return H?(c(i,H,n,{cardId:s},o),!0):(a(i,400,{error:"clientId is required"}),!0)}return !1}catch(R){let P=R?.statusCode||500;return a(i,P,{error:String(R?.message||R)}),true}}return {handleWatchersRoutes:l,handleSse:f,handleChannelSubscription:c}}exports.a=A;exports.b=T;//# sourceMappingURL=chunk-7ICPAABP.cjs.map
|
|
7
|
+
//# sourceMappingURL=chunk-7ICPAABP.cjs.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
'use strict';var chunkEZENHAVZ_cjs=require('./chunk-EZENHAVZ.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunk7ICPAABP_cjs=require('./chunk-7ICPAABP.cjs'),chunkKAWQPLIE_cjs=require('./chunk-KAWQPLIE.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkNJJ7WEDT_cjs=require('./chunk-NJJ7WEDT.cjs'),chunkJ6EGN6S4_cjs=require('./chunk-J6EGN6S4.cjs'),chunkJJL5VOQZ_cjs=require('./chunk-JJL5VOQZ.cjs'),chunkYMEIPKLW_cjs=require('./chunk-YMEIPKLW.cjs'),chunkGYQXDNNI_cjs=require('./chunk-GYQXDNNI.cjs');function Zt(R){let{apiBasePath:k,json:v,readJsonBody:K,initBoardAndSetup:H,bootstrapBoard:I,buildPublishedRuntimePayload:W,createMcpControlplaneToolRegistry:U,retriggerCard:L,applyCardAction:G,resolveChatHandlerTarget:V,sendCardFileDownloadResponse:_}=R;async function X(Q,x,rt){let c=Q.method||"GET",p=rt,h=p.pathname;try{if(c==="GET"&&h===`${k}/init-board`)return await H(),v(x,200,await W()),!0;if(c==="POST"&&h===`${k}/mcp-controlplane`){await I();let w=await K(Q),b=typeof w.tool=="string"?w.tool.trim():"",S=w.args&&typeof w.args=="object"&&!Array.isArray(w.args)?w.args:{};if(!b)return v(x,400,{error:"tool is required"}),!0;try{let g=await chunk272IYUKT_cjs.a(b,S,U());if(g&&typeof g=="object"&&!Array.isArray(g)){let $=g;if($.status==="fail")return v(x,400,{error:chunk272IYUKT_cjs.b(g,"Request failed")}),!0;if($.status==="error")return v(x,500,{error:chunk272IYUKT_cjs.b(g,"Internal error")}),!0}v(x,200,g);}catch(g){let $=typeof g?.statusCode=="number"?Number(g.statusCode):500,N=g instanceof Error?g.message:String(g);v(x,$,{error:N});}return !0}let d=h.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(k)}/cards/([^/]+)/retrigger$`));if(c==="POST"&&d){await I();let w=decodeURIComponent(d[1]);return await L(w),v(x,200,{ok:!0}),!0}let O=h.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(k)}/cards/([^/]+)/actions$`));if(c==="POST"&&O){await I();let w=decodeURIComponent(O[1]),b=Date.now(),S=new Date(b).toISOString(),g=await K(Q),$=g?.actionType;if($==="chat-send"&&!await V(w)){let C=Date.now();return v(x,409,{error:`chat handler is not configured for card: ${w}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(C).toISOString(),responseSentAtMs:C,responseStatus:409}),!0}if($==="chat-send"){let C=g?.payload??{},J=typeof C["turn-id"]=="string"?C["turn-id"]:typeof C.turnId=="string"?C.turnId:typeof C.turn=="string"?C.turn:"";if(!J||!String(J).trim()){let q=Date.now();return v(x,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${w}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(q).toISOString(),responseSentAtMs:q,responseStatus:400}),!0}}await G(w,$,g?.payload);let N=Date.now();return v(x,200,{ok:!0,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(N).toISOString(),responseSentAtMs:N,responseStatus:200}),!0}let E=h.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(k)}/cards/([^/]+)/files/(\\d+)$`));if(c==="GET"&&E){let w=decodeURIComponent(E[1]),b=parseInt(E[2],10),S=p.searchParams.get("sn");return await _(x,w,b,S),!0}return !1}catch(d){let O=d?.statusCode||500;return v(x,O,{error:String(d?.message||d)}),true}}return {handleRuntimeApi:X}}var Yt={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},Xt="chat-handler-flow-queue";function nr(R){let k=String(R.apiBasePath||"/api/board").replace(/\/$/,""),v={...Yt,...R.corsHeaders||{}},K=R.queueLaneTuning??{},H=R.boardId||"",I=R.logger||{info:console.log,warn:console.warn,error:console.error},W=R.invocationAdapter,U=R.chatFlowRunner||null,L=R.chatStorage??chunkNJJ7WEDT_cjs.b(),G=chunkGYQXDNNI_cjs.a(L),V=R.notificationTransport||null,_=R.serverUrl||null,X=R.executionExtra||{},Q=R.onSseClientConnected,x=R.onSseClientDisconnected,rt=R.onChannelSubscribed,c=R.onChannelUnsubscribed,p=chunk7ICPAABP_cjs.a({chatStorage:L,readChatRecords:t=>yt(t),onSseClientDisconnected:x});function h(t){function e(a){if(Array.isArray(a))return a;if(a&&typeof a=="object"){let s=a;return Array.isArray(s.files)?s.files:[a]}return null}function r(a){return {async get(s){return a.get(s)},async set(s){return a.set(s)},async del(s){return a.del(s)},async patch(s){return a.patch(s)},async appendFiles(s){return a.appendFiles(s)}}}function o(a){function s(m){return {status:"success",data:m}}function l(m){return {status:"fail",error:m}}function u(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}return {async get(m){try{let f=m.params?.id;if(f){let T=await a.readCard(f);return T?s({cards:[T]}):l(`card "${f}" not found`)}return s({cards:await a.readAllCards()})}catch(f){return u(f)}},async set(m){try{let f=m.body;if(f==null)return l("set requires a body (card object or array of cards)");let T=Array.isArray(f)?f:[f];for(let j of T){if(typeof j.id!="string")return l("each card must have a string `id` field");await a.writeCard(j.id,j);}return s({count:T.length})}catch(f){return u(f)}},async del(m){try{let f=m.body?.ids??[],T=m.params?.id,j=T?[...f,T]:f;if(j.length===0)return l("del requires body.ids (string[]) or params.id");for(let tt of j)await a.removeCard(tt);return s({count:j.length})}catch(f){return u(f)}},async patch(m){try{let f=m.params?.id,T=m.params?.path;if(!f)return l("patch requires params.id");if(!T)return l("patch requires params.path");let j=m.body,tt=j&&Object.prototype.hasOwnProperty.call(j,"value")?j.value:m.body;return await a.patchCard(f,T,tt),s({count:1})}catch(f){return u(f)}},async appendFiles(m){try{let f=m.params?.id;if(!f)return l("appendFiles requires params.id");let T=await a.readCard(f);if(!T)return l(`card "${f}" not found`);let j=e(m.body);if(!j||j.length===0)return l("appendFiles requires a file metadata object, array, or body.files array");let tt=T.card_data&&typeof T.card_data=="object"&&!Array.isArray(T.card_data)?T.card_data:{},At=Array.isArray(tt.files)?tt.files:[],ve=[...At,...j];return await a.patchCard(f,"card_data.files",ve),s({files_added:j.map((Oe,Pe)=>({idx:At.length+Pe,entry:Oe}))})}catch(f){return u(f)}}}}let n=chunkKAWQPLIE_cjs.a(t.boardAdapter)?chunkJ6EGN6S4_cjs.j(t.baseRef,t.boardAdapter):chunkJJL5VOQZ_cjs.y(t.baseRef,t.boardAdapter),i=t.nonCoreAdapter??(!chunkKAWQPLIE_cjs.a(t.boardAdapter)&&w(t.boardAdapter)?t.boardAdapter:null),y=t.nonCore??(i?chunkJJL5VOQZ_cjs.z(t.baseRef,i):null),P,A=chunkKAWQPLIE_cjs.a(t.boardAdapter)?(()=>{let a=chunkJ6EGN6S4_cjs.d(chunkJ6EGN6S4_cjs.c(chunkJ6EGN6S4_cjs.b(t.boardAdapter.kvStorageForRef(t.cardStoreRef)),t.boardAdapter.hashFn),I.warn),s=o(a);return P={get(l){return s.get(l)},set(l){return s.set(l)}},s})():(()=>{let a=t.boardAdapter.kvStorageForRef(t.cardStoreRef),l=chunkYMEIPKLW_cjs.a(chunkJJL5VOQZ_cjs.l({readIndex:()=>a.read("_index"),writeIndex:u=>a.write("_index",u),readCard:u=>a.read(u),writeCard:(u,m)=>(a.write(u,m),u),removeCard:u=>{a.delete(u);},cardExists:u=>a.read(u)!==null,defaultCardKey:u=>u},I.warn));return P=l,r(l)})(),F=t.artifactsAdapter||t.boardAdapter,B=t.filesArtifactsStore??null,M=B?{putBytes(a,s,l){B.putBytes(a,s,l);},getBytes(a){return B.getBytes(a)},listKeys(a){return B.list(a).map(s=>s.key)}}:null;if(!M&&!chunkKAWQPLIE_cjs.a(F)){let a=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files"),s=chunkNJJ7WEDT_cjs.c(a);M={putBytes(l,u,m){s.putBytes(l,u,m);},getBytes(l){return s.getBytes(l)},listKeys(l){return s.list(l).map(u=>u.key)}};}else if(!M&&chunkKAWQPLIE_cjs.a(F)){let a=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files");M={async putBytes(s,l){if(a.writeBytes){await a.writeBytes(s,l);return}let u=JSON.stringify({__kind:"bytes-array",data:[...l]});await a.write(s,u);},async getBytes(s){if(a.readBytes){let u=await a.readBytes(s);if(u!==null)return u}let l=await a.read(s);if(l===null)return null;try{let u=JSON.parse(l);if(u&&u.__kind==="bytes-array"&&Array.isArray(u.data))return new Uint8Array(u.data)}catch{}return new TextEncoder().encode(l)},async listKeys(s){return await a.listKeys(s)}};}let D={async init(a){return n.init(a)},async status(a){return n.status(a)},async getConfig(a){return n.getConfig(a)},async getAllOutputsDataObjects(a){return n.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return n.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return n.getOutputsFetchedSources(a)},async upsertCard(a){return n.upsertCard(a)},async removeCard(a){return n.removeCard(a)},async cardRefreshedNotify(a){return n.cardRefreshedNotify(a)},async sourceDataFetched(a){return n.sourceDataFetched(a)},async sourceDataFetchFailure(a){return n.sourceDataFetchFailure(a)}};return {label:t.label,board:n,nonCore:y,publicCardStore:P,boardOps:D,cardStoreOps:A,get filesArtifacts(){return M},boardAdapter:t.boardAdapter,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,archiveStoreRef:t.archiveStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:chunkEZENHAVZ_cjs.a(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let d=R.boards.map(h),O=new Map;function E(t){return O.get(t)??0}function w(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function b(t){let e=d[E(t)];return {files:e?e.filesArtifacts:null}}function S(){return chunkNJJ7WEDT_cjs.e()}function g(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function $(t){if(!t||t.notificationTeardown||!V||!t.notifyRef)return;let e=await V.subscribe(t.notifyRef,r=>{chunkEZENHAVZ_cjs.c(t.notification,r);let o=r.kind==="notification-batch"?r.notifications:[r];p.broadcastNotificationBatch(o);});t.notificationTeardown=e;}async function N(t){if(!t||t.initialized)return;let e={cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef};t.artifactsStoreRef&&(e.artifactsStoreRef=t.artifactsStoreRef),t.chatStoreRef&&(e.chatStoreRef=t.chatStoreRef),t.scratchStoreRef&&(e.scratchStoreRef=t.scratchStoreRef),t.archiveStoreRef&&(e.archiveStoreRef=t.archiveStoreRef);let r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow),t.inferenceAdapterRef&&(r["inference-adapter-ref"]=t.inferenceAdapterRef);let o=await t.boardOps.init({params:e,body:r});if(o.status!=="success")throw Object.assign(new Error(o.error||`init failed for ${t.label}`),{statusCode:500});if(await $(t),!t.chatHandlerFlow&&t.chatHandlerRef&&W.describe)try{let n=await W.describe(t.chatHandlerRef);n&&n.kind!=="chat-handler"?I.warn(`[init] chat-handler describe returned kind="${n.kind}", expected "chat-handler" for ${t.label}`):n&&I.info(`[init] chat-handler validated: ${n.name} (protocol ${n.protocolVersion}) for ${t.label}`);}catch(n){I.warn(`[init] chat-handler describe failed for ${t.label}: ${n?.message||String(n)}`);}t.initialized=true;}async function C(t){if(!t.boardAdapter.publishBoardChangeNotifications)return;let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&chunkEZENHAVZ_cjs.b(r.data)&&e.push({kind:"status",status:r.data});let o=await t.boardOps.getAllOutputsDataObjects({});if(o.status==="success"&&o.data!=null)for(let[i,y]of Object.entries(o.data))i&&e.push({kind:"data_object",key:i,payload:y});let n=await t.boardOps.getAllOutputsComputedValues({});if(n.status==="success"&&n.data!=null)for(let[i,y]of Object.entries(n.data))i&&e.push({kind:"computed_values",cardId:i,values:y});e.length>0&&t.boardAdapter.publishBoardChangeNotifications(e);}async function J(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),o=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let n of o)typeof n.id=="string"&&(O.set(n.id,e),await t.boardOps.upsertCard({params:{cardId:n.id}}));t.cardsBootstrapped=true;}async function q(){for(let t of d)await N(t);}async function it(){await q();for(let t=0;t<d.length;t++)await C(d[t]),await J(d[t],t),await C(d[t]);}async function ct(t=false){t||await q();for(let e of d){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}async function te(){return await q(),ct(true)}function Y(t){return d[E(t)]??null}async function nt(t){let e=Y(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let o=Array.isArray(r.data?.cards)?r.data.cards:[];return o.length>0?o[0]:null}async function ft(){let t=async r=>{if(!r)return [];let o=await r.cardStoreOps.get({});return o.status!=="success"||!Array.isArray(o.data?.cards)?[]:o.data.cards},e=[];for(let r of d)e.push(...await t(r));return e}function ee(){return d[0]??null}let pt=chunkEZENHAVZ_cjs.n({boardContexts:d,cardOwnerIndex:O,cardContextForCard:t=>Y(t),readStatusSnapshot:()=>ie(),readDataObjectsByToken:()=>de(),readCardRuntimeArtifacts:()=>ce(),readCardFromStore:t=>nt(t),readCardDefinitions:()=>ft(),processAccumulatedLaneInternal:t=>ct(t),reportSourceFetched:(t,e)=>bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Ct(t,{reason:e}),uploadCardFile:(t,e,r,o,n)=>Rt(t,e,r,o,n),chatStorePublic:G,serverUrl:_,apiBasePath:k}),re=pt.mcpCardStoreFacade,z=pt.createMcpFacade,ne=chunkEZENHAVZ_cjs.h({boardId:H,getMcpFacade:()=>z(),getMcpCardStoreFacade:()=>re()});function ae(t){return chunkEZENHAVZ_cjs.k(t)}function oe(){return chunkEZENHAVZ_cjs.l(z())}function se(){return chunkEZENHAVZ_cjs.m({boardId:H,uploadCardFile:Rt,getMcpFacade:()=>z(),controlplane:ne})}let at=chunkEZENHAVZ_cjs.i({boardId:H,boardContexts:d,readCardDefinitions:()=>ft(),readChatRecords:t=>yt(t),getChatProcessing:t=>z().getChatProcessing({cardId:t}).active}),ie=at.readStatusSnapshot,ce=at.readCardRuntimeArtifacts,de=at.readDataObjectsByToken,dt=at.buildPublishedRuntimePayload;async function mt(t,e,r){let o=r?.syncBoard!==false,n=r?.restartOnlyIfChanged===true,i=Y(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let y=await nt(t);if(!y)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let P=n?JSON.stringify(y):null,A=e(y)||y;if(n&&JSON.stringify(A)===P)return;let F=await i.cardStoreOps.set({body:A});if(F.status!=="success")throw Object.assign(new Error(F.error||`Failed to persist card: ${t}`),{statusCode:500});if(o){let B=await i.boardOps.upsertCard({params:{cardId:t,restart:true}});if(B.status!=="success")throw Object.assign(new Error(B.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function ue(t,e){await mt(t,e,{syncBoard:true});}async function gt(t,e){await mt(t,e,{syncBoard:false});}async function le(t){let e=Y(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await nt(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let o=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(o.status!=="success")throw Object.assign(new Error(o.error||`Failed to retrigger card: ${t}`),{statusCode:500})}function fe(t){L.clear(t);try{z().setChatProcessing({cardId:t,active:!1});}catch{}}function pe(t,e,r,o,n=""){let i=typeof r=="string"?r.trim():"";return L.append(t,e||"system",i,o,n)}function yt(t){return L.readAll(t)}let Rt=chunkEZENHAVZ_cjs.j({safeCardId:t=>g(t),artifactsStores:t=>b(t),cardFileMetadataStore:()=>S(),readCardFromStore:t=>nt(t),updateCardLocalOnly:(t,e)=>gt(t,e),writeChatRecord:(t,e,r,o,n)=>pe(t,e,r,o,n)}).uploadCardFile;async function ht(t){let e=Y(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=r.status==="success"?r.data?.value:null,n=e.chatHandlerRef;return o==null&&(!n||typeof n!="object")?null:{ctx:e,handlerFlow:o,handlerRef:n}}async function me(t,e,r=false,o=""){let n=await ht(t);if(!n)return;let{ctx:i,handlerFlow:y,handlerRef:P}=n;if(!r)try{z().setChatProcessing({cardId:t,active:!0});}catch{}let A={boardId:H,cardId:String(t),lastChatEntryId:e,...o?{turnId:o}:{},...X,..._?{serverUrl:_}:{}},F=y!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:Xt}}:P;try{chunkKAWQPLIE_cjs.a(i.boardAdapter)?await i.boardAdapter.chatAgentStore().enqueueRequest({boardId:H,ref:F,args:y!=null?{...A,__chatHandlerFlow:y}:A}):i.boardAdapter.chatAgentStore().enqueueRequest({boardId:H,ref:F,args:y!=null?{...A,__chatHandlerFlow:y}:A}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(B){try{z().setChatProcessing({cardId:t,active:!1});}catch{}I.warn(`[chat-handler] queue failed for card "${t}": ${B instanceof Error?B.message:String(B)}`);}}async function ge(t,e,r){if(e.howToRun==="built-in"&&chunkKAWQPLIE_cjs.b(e)===Xt){let o=U,n=r.__chatHandlerFlow,i={...r};return delete i.__chatHandlerFlow,o?o.run(n,i,{boardId:H,cardId:String(i.cardId||""),label:t.label,logger:I,serverUrl:_,executionExtra:X}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return W.invoke(e,r)}async function ye(t,e=false){e||await q();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",o=r?Y(r):ee();if(!o)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let n=await ge(o,t.ref,t.args);if(!n.dispatched){if(r)try{L.setProcessing(r,!1);}catch{}throw new Error(n.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Re(t,e,r){let o=e==="chat-send"?gt:ue,n;await o(t,i=>{let y=new Date().toISOString(),P=i.card_data&&typeof i.card_data=="object"?i.card_data:{};if(i.card_data=P,e==="chat-send"){let A=r&&typeof r.text=="string"?r.text.trim():"",F=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"",B=[];if(Array.isArray(r?.files)){for(let M of r.files)if(M){if(typeof M=="string"){B.push({name:M});continue}if(typeof M=="object"){let D=M;typeof D.name=="string"&&B.push({name:D.name,size:D.size,mime_type:D.mime_type,uploaded_at:D.uploaded_at,stored_name:D.stored_name,chat:D.chat===true});}}}if(A||B.length>0){let M=G.runBatch({cardId:t,commands:[{command:"append",role:"user",text:A,files:B,turn:F},{command:"set-processing",active:true}]});if(M.status!=="success")throw new Error(M.error);let D=M.data.results[0]?.data?.id;if(typeof D!="string"||!D)throw new Error(`chat-send did not return an append id for card ${t}`);n={cardId:t,lastEntryId:D,processingAlreadySet:true,turnId:F};try{p.broadcastCardChats(t);}catch{}}return i}if(e==="file-upload"){let A=S().normalizeIncoming(r?.files,y);return A.length>0&&S().merge(P,A),i}if(e==="action"){let A=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!A)return i;P.lastAction={buttonId:A,at:y},P.lastActionText=`${A} @ ${y}`;}return i}),n&&me(n.cardId,n.lastEntryId,n.processingAlreadySet,n.turnId??"");}function ot(t,e,r){let o=JSON.stringify(r),n=typeof Buffer<"u"?Buffer.byteLength(o):new TextEncoder().encode(o).length;t.writeHead(e,{...v,"Content-Type":"application/json; charset=utf-8","Content-Length":n}),t.end(o);}async function wt(t,e,r){let o=await nt(t);if(!o)throw Object.assign(new Error("Card not found"),{statusCode:404});let n=S().resolve(o.card_data,e,r);if(!n.ok&&n.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!n.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let i=n.file,y=g(t),P=b(t),A=String(i.stored_name||""),F=`${y}/${A}`,B=P.files?await P.files.getBytes(F):null;if(!B)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:i,bytes:B}}async function he(t,e,r,o){let{fileRecord:n,bytes:i}=await wt(e,r,o),y=String(n.name||n.stored_name||"download.bin"),P=String(n.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":P,"Content-Disposition":`attachment; filename="${y}"`,"Content-Length":i.length}),t.end(i);}function we(t){let e=String(t||"").toLowerCase();return e.startsWith("text/")||e.includes("json")||e.includes("xml")||e.includes("javascript")||e.includes("typescript")||e.includes("yaml")||e.includes("csv")}function be(t,e,r){let o=t.split(/\r?\n/);return (e==="head"?o.slice(0,r):o.slice(-r)).join(`
|
|
2
|
+
`)}async function st(t){let e=[];for await(let o of t)e.push(o);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(chunkKAWQPLIE_cjs.d(e)).trim();return r?JSON.parse(r):{}}async function bt(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let o=d[0];return o?o.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Ct(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",o=d[0];return o?o.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let Ce=chunk7ICPAABP_cjs.b({sseHub:p,corsHeaders:v,json:ot,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:Q,onChannelSubscribed:rt,onChannelUnsubscribed:c,apiBasePath:k,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),bootstrapBoard:()=>it(),boardContexts:d,publishPersistedStateSnapshot:t=>C(t),upsertCardsFromSource:(t,e)=>J(t,e)}).handleWatchersRoutes,Ae=chunk7FGPOGRV_cjs.a({apiBasePath:k,json:ot,readJsonBody:t=>st(t),bootstrapBoard:()=>it(),createMcpFacade:()=>z(),createMcpToolRegistry:t=>ae(t),resolveCardFileDownloadPayload:(t,e,r)=>wt(t,e,r),isLikelyTextMimeType:t=>we(t),sliceTextByLines:(t,e,r)=>be(t,e,r)}).handleAgentfaceApi,Se=chunkNM6O35RY_cjs.a({apiBasePath:k,json:ot,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),createMcpWebhookToolRegistry:()=>oe()}).handleWebhooksApi,Be=Zt({apiBasePath:k,json:ot,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),bootstrapBoard:()=>it(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>se(),retriggerCard:t=>le(t),applyCardAction:(t,e,r)=>Re(t,e,r),resolveChatHandlerTarget:t=>ht(t),sendCardFileDownloadResponse:(t,e,r,o)=>he(t,e,r,o)}).handleRuntimeApi;async function ke(t,e,r){return !!(await Ae(t,e,r)||await Se(t,e,r)||await Ce(t,e,r)||await Be(t,e,r))}return {get apiBasePath(){return k},get corsHeaders(){return v},get queueLaneTuning(){return K},handleRuntimeApi:ke,buildPublishedRuntimePayload:dt,processAccumulatedEvents:te,processAccumulatedLane:ct,handleChatAgentRequest:ye,clearChatRecords:fe,reportSourceFetched(t,e){return bt(t,{ref:e})},reportSourceFetchFailure(t,e){return Ct(t,{reason:e})},get cardStore(){return d[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function ar(R){let k=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),v={...Yt,...R.corsHeaders||{}},K=R.serverMetaStore,H=R.boardRuntimeFactory,I=new Map,W="boards-config.json";function U(){let c=K.getText(W);if(!c)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(c)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function L(c){K.putText(W,JSON.stringify(c,null,2));}function G(c){let p=String(c||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return p.length>0&&p.length<=64?p:null}function V(c){if(I.has(c))return I.get(c);let h=U().boards.find(O=>O.id===c)||{},d=H(c,h);return I.set(c,d),d}function _(c,p,h){let d=JSON.stringify(h),O=typeof Buffer<"u"?Buffer.byteLength(d):new TextEncoder().encode(d).length;c.writeHead(p,{...v,"Content-Type":"application/json; charset=utf-8","Content-Length":O}),c.end(d);}async function X(c,p,h){let d=c.method||"GET",O=h.pathname;if(d==="GET"&&O===k)return _(p,200,{ok:true,boards:U().boards}),true;if(d==="POST"&&O===k){let E=[];for await(let C of c)E.push(C);let w=typeof Buffer<"u"?Buffer.concat(E).toString("utf-8").trim():new TextDecoder().decode(chunkKAWQPLIE_cjs.d(E)).trim(),b={};try{b=w?JSON.parse(w):{};}catch{b={};}let S=G(b.id);if(!S)return _(p,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let g=U();if(g.boards.some(C=>C.id===S))return _(p,409,{error:`Board "${S}" is already registered`}),true;let $=typeof b.label=="string"&&b.label.trim()?b.label.trim():S,N={id:S,label:$};for(let[C,J]of Object.entries(b))C==="id"||C==="label"||J!=null&&(N[C]=J);return g.boards.push(N),L(g),_(p,200,{ok:true,board:N}),true}return false}async function Q(c,p,h){let O=h.pathname.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(k)}/([^/]+)(/|$)`));if(!O)return false;let E=G(decodeURIComponent(O[1]));return E?U().boards.some(S=>S.id===E)?!!await V(E).handleRuntimeApi(c,p,h):(_(p,404,{error:`Board "${E}" not registered. POST ${k} with {id} to register it first.`}),true):(_(p,400,{error:"Invalid board id"}),true)}async function x(c,p,h){return !!(await X(c,p,h)||await Q(c,p,h))}function rt(c){if(!U().boards.some(h=>h.id===c))throw Object.assign(new Error(`Board "${c}" not registered`),{statusCode:404});return {service:V(c)}}return {get apiBasePath(){return k},get corsHeaders(){return v},handleApi:x,requireBoardService:rt}}exports.a=nr;exports.b=ar;//# sourceMappingURL=chunk-ASR44K7H.cjs.map
|
|
3
|
+
//# sourceMappingURL=chunk-ASR44K7H.cjs.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var chunkGL2OHR2E_cjs=require('./chunk-GL2OHR2E.cjs');function d(a,e){return e?{...a,...e.pollIntervalMs!=null?{pollIntervalMs:e.pollIntervalMs}:{},...e.visibilityMs!=null?{visibilityMs:e.visibilityMs}:{},...e.concurrency!=null?{concurrency:e.concurrency}:{},...e.maxAttempts!=null?{maxAttempts:e.maxAttempts}:{}}:a}function p(a,e,c,s){return {id:a,async lease(o){return (await Promise.resolve(e.leaseRequests(o))).map(r=>({id:r.messageId,attempt:r.attempt,message:r.request,ack:()=>Promise.resolve(e.ackRequest(r.messageId,r.leaseToken)),nack:t=>Promise.resolve(e.nackRequest(r.messageId,r.leaseToken,t))}))},async handle(o){await c(o.args,o);},onError:s?(o,u)=>s(o,u.attempt,u.message):void 0}}function l(a,e,c,s){return {id:a,async lease(o){return (await Promise.resolve(e.lease(o))).map(r=>({id:r.id,attempt:r.attempt,message:r.body,ack:()=>Promise.resolve(e.ack(r.id,r.leaseToken)),nack:t=>Promise.resolve(e.nack(r.id,r.leaseToken,t))}))},async handle(){await c();},onError:s?(o,u)=>s(o,u.attempt):void 0}}function y(a){let e=a.logger??{info(){},warn(){},error(){}},c=a.boardAdapter,s=a.runtime.queueLaneTuning??{},o=c.processAccumulatedStore(),u=c.chatAgentStore(),r=[];if(r.push(d(l("process-accumulated",o,async()=>{let t=await a.runtime.processAccumulatedLane();if(t.status!=="success")throw new Error(t.error||`processAccumulatedLane returned ${t.status}`)},(t,n)=>{e.error(`[board-server] queued process-accumulated failed for ${a.boardId} (attempt ${n}): ${String(t&&t.message||t)}`);}),s.processAccumulated)),r.push(d(p("chat-agent",u,async(t,n)=>{await a.runtime.handleChatAgentRequest(n);},(t,n,i)=>{let m=typeof i.args?.cardId=="string"?i.args.cardId:"";e.error(`[board-server] queued chat-agent failed for ${a.boardId}${m?`/${m}`:""} (attempt ${n}): ${String(t&&t.message||t)}`);}),s.chatAgent)),a.executeTaskExecutorRequest){let t=c.boardWorkerStore();r.push(d(p("task-executor",t,a.executeTaskExecutorRequest,(n,i)=>{e.error(`[board-server] queued board-worker failed for ${a.boardId} (attempt ${i}): ${String(n&&n.message||n)}`);}),s.taskExecutor));}return chunkGL2OHR2E_cjs.a(r)}exports.a=y;//# sourceMappingURL=chunk-CPAXTVBQ.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-CPAXTVBQ.cjs.map
|