yaml-flow 8.7.1 → 8.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/browser/adapters/firebase-storage.js +2 -2
- package/browser/adapters/firestore-storage.js +2 -2
- package/browser/adapters/localstorage-storage.js +3 -3
- package/browser/asset-integrity.json +9 -13
- package/browser/server-runtime-controlface.js +5 -5
- package/examples/ARCHITECTURE.md +0 -27
- package/examples/board/server/board-server.js +150 -100
- package/examples/board/server/board-worker/source_def_flows.json +0 -8
- package/examples/board/server/board-worker/task-executor.js +1 -3
- package/examples/board/test/server-http-test.js +108 -73
- package/examples/board-firestore/server/worker.js +8 -0
- package/examples/portfolio-tracker/portfolio-tracker.js +11 -1
- package/examples/portfolio-tracker/test/portfolio-t4.js +12 -2
- package/lib/{artifacts-store-lib-D9nMkVcE.d.cts → artifacts-store-lib-C6qBpMfU.d.cts} +1 -1
- package/lib/{artifacts-store-lib-DSSMqVL2.d.ts → artifacts-store-lib-D4qf7Q-7.d.ts} +1 -1
- package/lib/artifacts-store-public.d.cts +3 -3
- package/lib/artifacts-store-public.d.ts +3 -3
- package/lib/board-live-cards-mcp.cjs +1 -1
- package/lib/board-live-cards-mcp.d.cts +6 -7
- package/lib/board-live-cards-mcp.d.ts +6 -7
- package/lib/board-live-cards-mcp.js +1 -1
- package/lib/board-live-cards-node.cjs +8 -8
- package/lib/board-live-cards-node.d.cts +15 -14
- package/lib/board-live-cards-node.d.ts +15 -14
- package/lib/board-live-cards-node.js +8 -8
- package/lib/{board-live-cards-public-LlVUQPL2.d.cts → board-live-cards-public-BT5HrgqZ.d.cts} +82 -59
- package/lib/{board-live-cards-public-JNRKfBZy.d.ts → board-live-cards-public-DSRamFm8.d.ts} +82 -59
- package/lib/{board-live-cards-public-async-Di9QB141.d.cts → board-live-cards-public-async-CYjr4mgX.d.cts} +18 -8
- package/lib/{board-live-cards-public-async-fwd1QI82.d.ts → board-live-cards-public-async-DlyC3PgC.d.ts} +18 -8
- package/lib/board-live-cards-public.cjs +1 -1
- package/lib/board-live-cards-public.d.cts +2 -2
- package/lib/board-live-cards-public.d.ts +2 -2
- package/lib/board-live-cards-public.js +1 -1
- package/lib/board-live-cards-server-runtime.cjs +1 -1
- package/lib/board-live-cards-server-runtime.d.cts +6 -8
- package/lib/board-live-cards-server-runtime.d.ts +6 -8
- package/lib/board-live-cards-server-runtime.js +1 -1
- package/lib/{board-platform-adapter-async-BfHmHdx2.d.cts → board-platform-adapter-async-BZIftm36.d.cts} +18 -14
- package/lib/{board-platform-adapter-async-DYahVzIK.d.ts → board-platform-adapter-async-JP9V-U5E.d.ts} +18 -14
- package/lib/board-worker-adapter.cjs +1 -24
- package/lib/board-worker-adapter.d.cts +68 -3
- package/lib/board-worker-adapter.d.ts +68 -3
- package/lib/board-worker-adapter.js +1 -24
- package/lib/card-store-public.d.cts +2 -2
- package/lib/card-store-public.d.ts +2 -2
- package/lib/chat-store-public.cjs +1 -1
- package/lib/chat-store-public.d.cts +20 -20
- package/lib/chat-store-public.d.ts +20 -20
- package/lib/chat-store-public.js +1 -1
- package/lib/chunk-2GSI6C45.js +7 -0
- package/lib/chunk-35N7ONTH.js +2 -0
- package/lib/chunk-37HDEW26.cjs +2 -0
- package/lib/{chunk-PMUSJQSR.cjs → chunk-3CZCGNY4.cjs} +2 -2
- package/lib/{chunk-BQS3EIEK.js → chunk-44L64VQ2.js} +3 -3
- package/lib/chunk-6OPXQPSC.js +2 -0
- package/lib/chunk-7BTZCOT5.js +2 -0
- package/lib/{chunk-U2N6MCD5.cjs → chunk-7JVHYHT2.cjs} +2 -2
- package/lib/chunk-7QZ267XP.cjs +2 -0
- package/lib/{chunk-XQRNDX4Q.js → chunk-ANKA7HEJ.js} +2 -2
- package/lib/{chunk-KAWQPLIE.cjs → chunk-BQUQTOPB.cjs} +2 -2
- package/lib/chunk-CMFD27ZC.cjs +3 -0
- package/lib/chunk-DOFNXJ4C.js +3 -0
- package/lib/chunk-ETW3BXHD.cjs +2 -0
- package/lib/{chunk-SGV7PU4H.js → chunk-FOFGEABN.js} +2 -2
- package/lib/chunk-GPCMBPLK.cjs +2 -0
- package/lib/chunk-GU3T75C4.js +3 -0
- package/lib/chunk-H3EHFCDZ.js +3 -0
- package/lib/chunk-H4TYOSMD.cjs +45 -0
- package/lib/chunk-HFW7E2Z7.cjs +4 -0
- package/lib/chunk-IQIZA7TN.cjs +7 -0
- package/lib/chunk-J4MHQ7JF.js +45 -0
- package/lib/chunk-MCPADH33.cjs +2 -0
- package/lib/chunk-NBJTYAYN.cjs +2 -0
- package/lib/chunk-NDAKMJQK.cjs +3 -0
- package/lib/chunk-NNSBBO5R.js +2 -0
- package/lib/chunk-NU5NO5NM.js +2 -0
- package/lib/chunk-O4RKTQBP.cjs +3 -0
- package/lib/chunk-O5UYCGIN.js +2 -0
- package/lib/chunk-Q3OTUDIE.js +2 -0
- package/lib/chunk-R44X3RQB.cjs +2 -0
- package/lib/chunk-RKKSVOP2.js +2 -0
- package/lib/chunk-UB54HZA4.cjs +2 -0
- package/lib/{chunk-CIAJNUR4.js → chunk-VGDLSS2H.js} +2 -2
- package/lib/{chunk-SFVO2LB2.cjs → chunk-VQCIOKJV.cjs} +3 -3
- package/lib/chunk-VS3BXEYK.js +4 -0
- package/lib/chunk-Y4WK7HE4.js +2 -0
- package/lib/chunk-ZK3E7L4Y.cjs +2 -0
- package/lib/cloud-storage.cjs +1 -1
- package/lib/cloud-storage.d.cts +6 -6
- package/lib/cloud-storage.d.ts +6 -6
- package/lib/cloud-storage.js +1 -1
- package/lib/execution-refs.cjs +1 -1
- package/lib/execution-refs.js +1 -1
- package/lib/firebase-storage/index.cjs +2 -2
- package/lib/firebase-storage/index.d.cts +2 -2
- package/lib/firebase-storage/index.d.ts +2 -2
- package/lib/firebase-storage/index.js +2 -2
- package/lib/firestore-storage/index.cjs +2 -2
- package/lib/firestore-storage/index.d.cts +12 -10
- package/lib/firestore-storage/index.d.ts +12 -10
- package/lib/firestore-storage/index.js +2 -2
- package/lib/index.d.cts +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/localstorage-storage/index.cjs +1 -1
- package/lib/localstorage-storage/index.d.cts +10 -6
- package/lib/localstorage-storage/index.d.ts +10 -6
- package/lib/localstorage-storage/index.js +1 -1
- package/lib/{mcp-tool-registries-W3TRj6O5.d.cts → mcp-tool-registries-CRtea2x4.d.cts} +3 -0
- package/lib/{mcp-tool-registries-BBObLYga.d.ts → mcp-tool-registries-D3rWSppt.d.ts} +3 -0
- package/lib/server-jobs-queue-runner/index.cjs +1 -1
- package/lib/server-jobs-queue-runner/index.d.cts +12 -9
- package/lib/server-jobs-queue-runner/index.d.ts +12 -9
- package/lib/server-jobs-queue-runner/index.js +1 -1
- package/lib/server-runtime/index.cjs +1 -1
- package/lib/server-runtime/index.d.cts +7 -9
- package/lib/server-runtime/index.d.ts +7 -9
- package/lib/server-runtime/index.js +1 -1
- package/lib/server-runtime-agentface/index.d.cts +7 -9
- package/lib/server-runtime-agentface/index.d.ts +7 -9
- package/lib/server-runtime-controlface/index.cjs +1 -1
- package/lib/server-runtime-controlface/index.d.cts +8 -9
- package/lib/server-runtime-controlface/index.d.ts +8 -9
- package/lib/server-runtime-controlface/index.js +1 -1
- package/lib/server-runtime-core/index.cjs +1 -1
- package/lib/server-runtime-core/index.d.cts +59 -21
- package/lib/server-runtime-core/index.d.ts +59 -21
- package/lib/server-runtime-core/index.js +1 -1
- package/lib/server-runtime-watchers/index.cjs +1 -1
- package/lib/server-runtime-watchers/index.d.cts +9 -65
- package/lib/server-runtime-watchers/index.d.ts +9 -65
- package/lib/server-runtime-watchers/index.js +1 -1
- package/lib/server-runtime-webhooks/index.d.cts +7 -9
- package/lib/server-runtime-webhooks/index.d.ts +7 -9
- package/lib/sse-hub-CYXisfXJ.d.cts +63 -0
- package/lib/sse-hub-Dodwtc3_.d.ts +63 -0
- package/lib/step-machine-public/index.cjs +1 -1
- package/lib/step-machine-public/index.d.cts +1 -1
- package/lib/step-machine-public/index.d.ts +1 -1
- package/lib/step-machine-public/index.js +1 -1
- package/lib/{storage-async-interface-BRR4eBjx.d.cts → storage-async-interface-CG0bMqvE.d.ts} +20 -1
- package/lib/{storage-async-interface-DhlOVPSp.d.ts → storage-async-interface-CyO-zwVQ.d.cts} +20 -1
- package/lib/{storage-interface-BFiD3kyB.d.ts → storage-interface-D-iEiTJA.d.cts} +45 -1
- package/lib/{storage-interface-BFiD3kyB.d.cts → storage-interface-D-iEiTJA.d.ts} +45 -1
- package/lib/stores/index.d.cts +1 -1
- package/lib/stores/index.d.ts +1 -1
- package/lib/stores/kv.d.cts +1 -1
- package/lib/stores/kv.d.ts +1 -1
- package/lib/{types-SO5OZm4s.d.ts → types-BtH3scgE.d.ts} +64 -29
- package/lib/{types-Ba8H5_Wo.d.cts → types-Ch0u3FKP.d.cts} +64 -29
- package/package.json +4 -5
- package/browser/board-livecards-client.js +0 -2
- package/examples/board/demo-shell-with-server.html +0 -272
- package/examples/board/doc.html +0 -465
- package/examples/board/server-config.json +0 -24
- package/lib/chat-storage-lib-B9Q34Dyv.d.cts +0 -54
- package/lib/chat-storage-lib-DB9iSai2.d.ts +0 -54
- package/lib/chunk-5XHOHTLZ.cjs +0 -2
- package/lib/chunk-6APH25VI.js +0 -2
- package/lib/chunk-76C7N4YT.js +0 -3
- package/lib/chunk-76ON3V7R.js +0 -2
- package/lib/chunk-7ICPAABP.cjs +0 -7
- package/lib/chunk-ASR44K7H.cjs +0 -3
- package/lib/chunk-CPAXTVBQ.cjs +0 -2
- package/lib/chunk-EGRHWZRV.js +0 -2
- package/lib/chunk-EZENHAVZ.cjs +0 -2
- package/lib/chunk-GL2OHR2E.cjs +0 -2
- package/lib/chunk-GYQXDNNI.cjs +0 -2
- package/lib/chunk-IPLSRN6P.cjs +0 -4
- package/lib/chunk-J6EGN6S4.cjs +0 -3
- package/lib/chunk-JH37NJGP.js +0 -3
- package/lib/chunk-JJL5VOQZ.cjs +0 -3
- package/lib/chunk-NJJ7WEDT.cjs +0 -2
- package/lib/chunk-NKIQRCOM.cjs +0 -2
- package/lib/chunk-PBOQ4HYB.cjs +0 -2
- package/lib/chunk-PRKRXAVN.js +0 -3
- package/lib/chunk-QJVR3FWQ.js +0 -2
- package/lib/chunk-S44QZUDX.js +0 -2
- package/lib/chunk-TSN3RTXT.js +0 -4
- package/lib/chunk-VXJHBWK3.js +0 -2
- package/lib/chunk-WHDEBJLT.js +0 -7
- package/lib/chunk-YGALANRO.js +0 -2
- package/lib/chunk-ZCNN6XPV.js +0 -2
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),module$1=require('module'),url=require('url'),path=require('path'),fs=require('fs');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var f=path.dirname(url.fileURLToPath((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-3CZCGNY4.cjs', document.baseURI).href)))),E=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-3CZCGNY4.cjs', document.baseURI).href)));function w(){let e=path.resolve(f,"./jsonata-sync.cjs");return fs.existsSync(e)?e:path.resolve(f,"../../card-compute/jsonata-sync.cjs")}var p=E(w());function u(e){e.registerFunction("fsPathRef",s=>chunkVQCIOKJV_cjs.a({kind:"fs-path",value:String(s)}),"<s:s>");}function R(e,s,c){if(!e||typeof e!="object")return {};let i={};if(Array.isArray(e.cmdTemplate)){let r=[];for(let n of e.cmdTemplate)try{let a=p(n);u(a),r.push(String(a.evaluate(s)));}catch(a){let t=a instanceof Error?a.message:String(a);throw new Error(`[${c}] argsMassaging.cmdTemplate failed on "${n}": ${t}`)}i.cmdArgs=r;}if(typeof e.stdinTemplate=="string")try{let r=p(e.stdinTemplate);u(r),i.stdin=r.evaluate(s);}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.stdinTemplate failed: ${n}`)}if(typeof e.urlTemplate=="string")try{let r=p(e.urlTemplate);u(r),i.url=String(r.evaluate(s));}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.urlTemplate failed: ${n}`)}if(typeof e.headerTemplate=="string")try{let r=p(e.headerTemplate);u(r);let n=r.evaluate(s);if(typeof n!="object"||n===null)throw new Error(`headerTemplate must produce an object, got: ${JSON.stringify(n)}`);i.headers=n;}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.headerTemplate failed: ${n}`)}if(typeof e.bodyTemplate=="string")try{let r=p(e.bodyTemplate);u(r),i.body=r.evaluate(s);}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.bodyTemplate failed: ${n}`)}return i}function _(e,s,c){if(!e||typeof e!="object")return s;let i={output:s},r=s.result,n=s.data,a=s.error;if(typeof e.resultExpr=="string")try{let t=p(e.resultExpr);u(t);let o=t.evaluate(i);if(typeof o!="string"||!o.trim())throw new Error(`resultExpr did not produce a non-empty string (got ${JSON.stringify(o)})`);r=o;}catch(t){let o=t instanceof Error?t.message:String(t);throw new Error(`[${c}] outputTransforms.resultExpr failed: ${o}`)}if(typeof e.dataTemplate=="string")try{let t=p(e.dataTemplate);u(t);let o=t.evaluate(i);if(!o||typeof o!="object"||Array.isArray(o))throw new Error(`dataTemplate did not produce an object (got ${JSON.stringify(o)})`);n=o;}catch(t){let o=t instanceof Error?t.message:String(t);throw new Error(`[${c}] outputTransforms.dataTemplate failed: ${o}`)}if(typeof e.errorExpr=="string")try{let t=p(e.errorExpr);u(t);let o=t.evaluate(i);a=o!=null?String(o):void 0;}catch(t){let o=t instanceof Error?t.message:String(t);throw new Error(`[${c}] outputTransforms.errorExpr failed: ${o}`)}return a!==void 0?{result:r,data:n,error:a}:{result:r,data:n}}exports.a=R;exports.b=_;//# sourceMappingURL=chunk-3CZCGNY4.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-3CZCGNY4.cjs.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
var s="b64:";function a(e){let n=new TextEncoder().encode(e),r=globalThis.Buffer,t;if(r)t=r.from(n).toString("base64");else if(typeof btoa=="function"){let o="";for(let i of n)o+=String.fromCharCode(i);t=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return t.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function g(e){let n=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),r=globalThis.Buffer;if(r)return r.from(n,"base64").toString("utf8");if(typeof atob=="function"){let t=atob(n),o=new Uint8Array(t.length);for(let i=0;i<t.length;i+=1)o[i]=t.charCodeAt(i);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function
|
|
2
|
-
export{
|
|
3
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
var s="b64:";function a(e){let n=new TextEncoder().encode(e),r=globalThis.Buffer,t;if(r)t=r.from(n).toString("base64");else if(typeof btoa=="function"){let o="";for(let i of n)o+=String.fromCharCode(i);t=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return t.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function g(e){let n=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),r=globalThis.Buffer;if(r)return r.from(n,"base64").toString("utf8");if(typeof atob=="function"){let t=atob(n),o=new Uint8Array(t.length);for(let i=0;i<t.length;i+=1)o[i]=t.charCodeAt(i);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function u(e){return `${s}${a(JSON.stringify(e))}`}function l(e){if(!e.startsWith(s))throw new Error(`Invalid ref format (expected ${s}<base64url(json)>): ${e}`);let n;try{n=JSON.parse(g(e.slice(s.length)));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!n||typeof n!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let r=n;if(typeof r.kind!="string"||typeof r.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:r.kind,value:r.value}}async function d(e,n,r){let t=e.tryAcquire();if(!t)return false;try{await n();}finally{t();}return r?.(),true}
|
|
2
|
+
export{u as a,l as b,d as c};//# sourceMappingURL=chunk-44L64VQ2.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-44L64VQ2.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {a}from'./chunk-FOFGEABN.js';import {a as a$2,b}from'./chunk-RKKSVOP2.js';import {a as a$1}from'./chunk-NNSBBO5R.js';function l(e,r){return r?{...e,...r.pollIntervalMs!=null?{pollIntervalMs:r.pollIntervalMs}:{},...r.visibilityMs!=null?{visibilityMs:r.visibilityMs}:{},...r.concurrency!=null?{concurrency:r.concurrency}:{},...r.maxAttempts!=null?{maxAttempts:r.maxAttempts}:{}}:e}function f(e,r,u,s){return {id:e,async lease(o){return (await Promise.resolve(r.leaseRequests(o))).map(t=>({id:t.messageId,attempt:t.attempt,message:t.request,ack:()=>Promise.resolve(r.ackRequest(t.messageId,t.leaseToken)),nack:a=>Promise.resolve(r.nackRequest(t.messageId,t.leaseToken,a))}))},async handle(o){await u(o.args,o);},onError:s?(o,i)=>s(o,i.attempt,i.message):void 0}}function R(e,r,u,s){return {id:e,async lease(o){return (await Promise.resolve(r.lease(o))).map(t=>({id:t.id,attempt:t.attempt,message:t.body,ack:()=>Promise.resolve(r.ack(t.id,t.leaseToken)),nack:a=>Promise.resolve(r.nack(t.id,t.leaseToken,a))}))},async handle(){await u();},onError:s?(o,i)=>s(o,i.attempt):void 0}}function Q(e){let r=e.logger??{info(){},warn(){},error(){}},u=e.boardAdapter,s=e.runtime.queueLaneTuning??{},o=u.queueStorageForRef(e.queueStoreRef,"process-accumulated"),i=a(u)?a$1(u.queueStorageForRef(e.queueStoreRef,"chat-agent")):a$2(u.queueStorageForRef(e.queueStoreRef,"chat-agent")),t=[];if(t.push(l(R("process-accumulated",o,async()=>{let a=await e.runtime.__drainProcessAccumulatedLane();if(a.status!=="success")throw new Error(a.error||`__drainProcessAccumulatedLane returned ${a.status}`)},(a,n)=>{r.error(`[board-server] queued process-accumulated failed for ${e.boardId} (attempt ${n}): ${String(a&&a.message||a)}`);}),s.processAccumulated)),t.push(l(f("chat-agent",i,async(a,n)=>{await e.runtime.handleChatAgentRequest(n);},(a,n,c)=>{let p=typeof c.args?.cardId=="string"?c.args.cardId:"";r.error(`[board-server] queued chat-agent failed for ${e.boardId}${p?`/${p}`:""} (attempt ${n}): ${String(a&&a.message||a)}`);}),s.chatAgent)),e.executeTaskExecutorRequest){let a$3=a(u)?a$1(u.queueStorageForRef(e.queueStoreRef,"task-executor")):a$2(u.queueStorageForRef(e.queueStoreRef,"task-executor"));t.push(l(f("task-executor",a$3,e.executeTaskExecutorRequest,(n,c)=>{r.error(`[board-server] queued board-worker failed for ${e.boardId} (attempt ${c}): ${String(n&&n.message||n)}`);}),s.taskExecutor));}return b(t)}export{Q as a};//# sourceMappingURL=chunk-6OPXQPSC.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-6OPXQPSC.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
function w(e){if(!e||typeof e!="object")return;let n=e;if(typeof n.statusCode=="number")return n.statusCode;if(typeof n.code=="number")return n.code}function l(e,n){return w(e)===n}function p(e,n,r){return n?typeof n=="function"?n(e):n:r}function A(e){return (e?.()??new Date).toISOString()}function L(e,n){if(n)return n();let r=String((e?.()??new Date).getTime()).padStart(13,"0"),o=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${r}-${o}`}function f(e){return {id:e.id,payload:e.payload}}function B(e,n={}){return {async read(r){let o=p(r,n.partitionKey,"kv");try{return (await e.item(r,o).read()).resource?.value??null}catch(t){if(l(t,404))return null;throw t}},async write(r,o){let t=p(r,n.partitionKey,"kv");await e.items.upsert({id:r,pk:t,kind:"kv",value:o});},async delete(r){let o=p(r,n.partitionKey,"kv");try{await e.item(r,o).delete();}catch(t){if(!l(t,404))throw t}},async listKeys(r=""){let{resources:o}=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 o.map(t=>t.id).sort()}}}function M(e,n,r={}){let o=p(n,r.partitionKey,`journal:${n}`);return {async append(t){let a={id:L(r.now,r.idFactory),pk:o,kind:"journal",streamKey:n,createdAt:A(r.now),payload:t};return await e.items.create(a),f(a)},async readAll(){let{resources:t}=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:o},{name:"@streamKey",value:n}]}).fetchAll();return t.sort((a,s)=>a.id.localeCompare(s.id)).map(f)},async readAfter(t){let{resources:a}=await e.items.query({query:t?"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:o},{name:"@streamKey",value:n},...t?[{name:"@cursor",value:t}]:[]]}).fetchAll(),s=a.sort((u,d)=>u.id.localeCompare(d.id));return {entries:s.map(f),newCursor:s.length>0?s[s.length-1].id:t}},async clear(){let t=await this.readAll();await Promise.all(t.map(a=>e.item(a.id,o).delete()));}}}function P(e,n,r={}){let o=r.partitionKey??"lock",t=r.holderId??`holder-${Math.random().toString(36).slice(2,10)}`,a=r.now,s=r.ttlMs??3e4;function u(){let i=a?.()??new Date;return {id:n,pk:o,kind:"lock",held:true,holderId:t,expiresAt:new Date(i.getTime()+s).toISOString(),updatedAt:i.toISOString()}}function d(i){return {...i??{id:n,pk:o,kind:"lock"},kind:"lock",held:false,holderId:t,expiresAt:null,updatedAt:A(a)}}async function g(){try{return (await e.item(n,o).read()).resource??null}catch(i){if(l(i,404))return null;throw i}}function S(i){return i?.held?i.expiresAt?Date.parse(i.expiresAt)>(a?.()??new Date).getTime():true:false}return {async tryAcquire(){let i=await g(),b=u();if(i){if(S(i))return null;try{await e.item(n,o).replace(b,i._etag?{accessCondition:{type:"IfMatch",condition:i._etag}}:void 0);}catch(c){if(l(c,412)||l(c,409))return null;throw c}}else try{await e.items.create(b);}catch(c){if(l(c,409))return null;throw c}return async()=>{let c=await g();if(!c)return;let T=d(c);try{await e.item(n,o).replace(T,c._etag?{accessCondition:{type:"IfMatch",condition:c._etag}}:void 0);}catch{}}}}}function x(e){return new TextDecoder().decode(e)}function h(e,n={}){return {async read(r){if(!await e.getBlobClient(r).exists())return null;let o=await e.getBlobClient(r).downloadToBuffer();return x(o)},async write(r,o){await e.getBlockBlobClient(r).upload(o,new TextEncoder().encode(o).byteLength,{blobHTTPHeaders:{blobContentType:n.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,o){await e.getBlockBlobClient(r).upload(o,o.byteLength,{blobHTTPHeaders:{blobContentType:n.defaultContentType??"application/octet-stream"}});},async listKeys(r=""){let o=[];for await(let t of e.listBlobsFlat({prefix:r}))o.push(t.name);return o.sort()},async stat(r){if(!await e.getBlobClient(r).exists())return null;let o=await e.getBlobClient(r).getProperties();return {key:r,size:Number(o.contentLength??0),updatedAt:o.lastModified?.toISOString(),contentType:o.contentType}},keyRef(r){return n.keyRef?.(r)??{kind:"azure-blob-key",value:r}},async renameKey(r,o){let t=e.getBlobClient(r);if(!await t.exists())return false;let[a,s]=await Promise.all([t.downloadToBuffer(),t.getProperties()]);return await e.getBlockBlobClient(o).upload(a,a.byteLength,{blobHTTPHeaders:{blobContentType:s.contentType??n.defaultContentType??"application/octet-stream"}}),await t.deleteIfExists(),true}}}function C(e){if(!e||typeof e!="object")return;let n=e;if(typeof n.statusCode=="number")return n.statusCode;if(typeof n.code=="number")return n.code}function y(e){let n=JSON.stringify(e),r=globalThis.Buffer;if(r)return r.from(n,"utf-8").toString("base64");if(typeof btoa=="function")return btoa(n);throw new Error("No base64 encoder available in this runtime")}function k(e){let n=e??"",r=globalThis.Buffer;if(r)return JSON.parse(r.from(n,"base64").toString("utf-8"));if(typeof atob=="function")return JSON.parse(atob(n));throw new Error("No base64 decoder available in this runtime")}function m(e,n){return (e??n()).toISOString()}function D(e,n){return {id:String(e.messageId??""),body:k(e.messageText),enqueuedAt:m(e.insertedOn??e.insertionTime,n),attempt:Number(e.dequeueCount??0)}}function v(e,n){return {id:String(e.messageId??""),body:k(e.messageText),enqueuedAt:m(e.insertedOn??e.insertionTime,n),attempt:Number(e.dequeueCount??0),leaseToken:String(e.popReceipt??""),leaseExpiresAt:m(e.nextVisibleOn,n)}}function R(e,n={}){let r=n.now??(()=>new Date),o=new Map;return {async enqueue(t){let a=await e.sendMessage(y(t));return {id:String(a.messageId??""),body:t,enqueuedAt:m(a.insertionTime,r),attempt:0}},async enqueueMany(t){let a=[];for(let s of t)a.push(await this.enqueue(s));return a},async stage(t,a){let s=a?.dedupKey;if(s){for(let g of o.values())if(g.dedupKey===s)return null}let u=`staged:${crypto.randomUUID?.()??Math.random().toString(36).slice(2,10)}`,d={body:t,enqueuedAt:r().toISOString(),attempt:0,...s?{dedupKey:s}:{}};return o.set(u,d),{id:u,body:t,enqueuedAt:d.enqueuedAt,attempt:0}},async commitStaged(t){let a=o.get(t);return a?(o.delete(t),await e.sendMessage(y(a.body)),true):false},async discardStaged(t){return o.has(t)?(o.delete(t),true):false},async peekStaged(t=""){return Array.from(o.entries()).filter(([a])=>!t||a.startsWith(t)).map(([a,s])=>({id:a,body:s.body,enqueuedAt:s.enqueuedAt,attempt:s.attempt}))},async lease(t){return (await e.receiveMessages({numberOfMessages:t?.max,visibilityTimeout:t?.visibilityMs?Math.max(1,Math.ceil(t.visibilityMs/1e3)):void 0})).receivedMessageItems.map(s=>v(s,r))},async ack(t,a){try{return await e.deleteMessage(t,a),!0}catch(s){if(C(s)===404)return false;throw s}},async nack(t,a,s){try{if(s?.dead){if(!n.deadLetterQueueClient)return !1;let u={messageId:t,reason:s.reason??null};return await n.deadLetterQueueClient.sendMessage(y(u)),await e.deleteMessage(t,a),!0}return await e.updateMessage(t,a,y({requeued:!0}),0),!0}catch(u){if(C(u)===404)return false;throw u}},async peekActive(t=""){return (await e.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>D(s,r)).filter(s=>!t||s.id.startsWith(t))},async peekDeadLetter(t=""){return n.deadLetterQueueClient?(await n.deadLetterQueueClient.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>{let u=k(s.messageText);return {id:String(s.messageId??""),body:u,enqueuedAt:m(s.insertedOn??s.insertionTime,r),attempt:Number(s.dequeueCount??0),reason:typeof u.reason=="string"?u.reason:void 0}}).filter(s=>!t||s.id.startsWith(t)):[]}}}export{B as a,M as b,P as c,h as d,R as e};//# sourceMappingURL=chunk-7BTZCOT5.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-7BTZCOT5.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs');function i(e,t){let n;return /\.m?js$/i.test(e)?n="local-node":/\.py$/i.test(e)?n="local-python":n="local-process",{meta:"task-executor",howToRun:n,whatToRun:chunkVQCIOKJV_cjs.a({kind:"fs-path",value:e}),...t?{extra:t}:{}}}function s(e){return JSON.stringify(e)}function a(e){let t;try{t=JSON.parse(e);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${e}`)}if(typeof t!="object"||t===null||typeof t.howToRun!="string"||typeof t.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${e}`);return t}exports.a=i;exports.b=s;exports.c=a;//# sourceMappingURL=chunk-7JVHYHT2.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-7JVHYHT2.cjs.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var chunkIXZG74EW_cjs=require('./chunk-IXZG74EW.cjs');function v(s,i){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function H(s,i){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${i} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function a(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function b(s){return Array.isArray(s)?s:[]}function z(s,i){if(typeof i!="string"||i.length===0)return;let c=s,u=i;u.startsWith("fetched_sources.")&&(c=a(s).fetched_sources,u=u.slice(16));for(let f of u.split(".")){if(c==null||typeof c!="object")return;c=c[f];}return c}function V(s,i){let c=a(s.view),u=b(c.elements);return {layout:c.layout,features:c.features,elements:u.map((f,_)=>{let I=a(f),k=a(I.data),R=typeof I.visible=="string"?!!z(i,I.visible):true,M=typeof k.bind=="string"?k.bind:void 0,P=typeof k.maxRows=="number"?k.maxRows:void 0,B=M?z(i,M):void 0,F={id:typeof I.id=="string"&&I.id?I.id:`element-${_}`,kind:I.kind,label:I.label,visible:R};return B!==void 0&&(F.resolved=Array.isArray(B)&&typeof P=="number"?B.slice(0,P):B),F})}}function G(s,i){let c=typeof s.id=="string"&&s.id?s.id:"card",u=b(s.provides),f=u.length>0?u:[{bindTo:c,ref:"card_data"}],_={};for(let I of f){let k=a(I),R=typeof k.bindTo=="string"?k.bindTo:"",M=typeof k.ref=="string"?k.ref:"";if(!R||!M)continue;let P=z(i,M);P!==void 0&&(_[R]=P);}return _}function he(s){if(typeof s!="string"||!s.trim())return null;let i=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!i)return null;let c=Number.parseInt(i[2],10);return !Number.isInteger(c)||c<0?null:c}function ke(s){return {"card-content":s}}function E(s){let i={...s};return delete i.__private,i}function D(s,i){return Object.prototype.hasOwnProperty.call(s,i)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,i){let c=Re(s);if(!i||Object.keys(i).length===0)return c;function u(f,_,I){let k=String(_||"").split(".").filter(Boolean);if(!k.length)return;let R=f;for(let M=0;M<k.length-1;M+=1){let P=k[M];(!R[P]||typeof R[P]!="object")&&(R[P]={}),R=R[P];}R[k[k.length-1]]=I;}if(i.fieldValues!==void 0&&i.fieldValues!==null){let f=null,_=a(c.view),I=b(_.elements);for(let k of I){let R=a(a(k).data);if(typeof R.writeTo=="string"&&R.writeTo){f=R.writeTo;break}}return f?u(c,f,i.fieldValues):typeof i.fieldValues=="object"&&!Array.isArray(i.fieldValues)&&(c.card_data={...a(c.card_data),...i.fieldValues}),c}if(Array.isArray(i._stagedFiles)&&i._stagedFiles.length>0)return c;for(let[f,_]of Object.entries(i))f!=="_stagedFiles"&&(_!==null&&typeof _=="object"&&!Array.isArray(_)&&c[f]!==null&&typeof c[f]=="object"&&!Array.isArray(c[f])?c[f]={...c[f],..._}:c[f]=_);return c}function Q(s){return a(s.__private).visible_controlplane_only===true}async function T(s,i){let c=await U(s.get({params:{id:i}}),"cardStore.get"),u=Array.isArray(c?.cards)?c.cards:[];if(u.length===0)throw new Error(`Card "${i}" not found`);return u[0]}function Ae(s){let{board:i,nonCore:c,cardStore:u,chatStore:f,processAccumulated:_,sourceFetchDone:I,sourceFetchFailed:k,uploadCardFile:R,buildFileDownloadUrl:M,readFetchedSourceJsonByRef:P}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function F(){let e=await U(u.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>a(r)):[]}function X(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),n=atob(t);return Uint8Array.from(n,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=a(await U(c.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:a(e.commonSourceDefFields),sourceKinds:a(e.sourceKinds)}}async function Z(){let e=a(await U(i.status({}),"status")),r=a(e.summary),t=b(e.cards);return {meta:a(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:t.map(n=>{let o=a(n);return {"card-id":typeof o.name=="string"?o.name:null,status:o.status??null,error:o.error??null,requires:b(o.requires),requires_satisfied:b(o.requires_satisfied),requires_missing:b(o.requires_missing),provides_declared:b(o.provides_declared),provides_runtime:b(o.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=a(await U(i.status({}),"status")),o=b(t.cards).map(a).find(p=>p.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let d=a(await T(u,r));if(Q(d))throw Object.assign(new Error(`card "${r}" not found`),{statusCode:404});let m=E(d),g=b(o.requires_satisfied).filter(p=>typeof p=="string"&&!!p),w=b(o.provides_runtime).filter(p=>typeof p=="string"&&!!p),h=Object.fromEntries(await Promise.all(g.map(async p=>[p,await U(i.getOutputsDataObject({params:{key:p}}),`getOutputsDataObject(${p})`)]))),A=Object.fromEntries(await Promise.all(w.map(async p=>[p,await U(i.getOutputsDataObject({params:{key:p}}),`getOutputsDataObject(${p})`)]))),C=a(await U(i.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),l=await U(i.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),S=b(d.source_defs).map(a),y={};for(let p of S)typeof p.bindTo=="string"&&typeof p.outputFile=="string"&&(y[p.outputFile]=p.bindTo);let x={};for(let[p,O]of Object.entries(l)){let q=y[p]??p;if(!P||typeof O!="string"){x[q]=null;continue}try{x[q]=P({cardId:r,ref:O});}catch{x[q]=null;}}let L={card_data:a(d.card_data),requires:h,fetched_sources:x,computed_values:C};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:m,refs_for_fetched_source_files:l,runtime_data:{requires:h,provides:A,computed_values:C,rendered_view:V(d,L)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",n=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",d=n?void 0:e.lastUserTurns??(t?void 0:1),m=e.tail,g={...d===void 0?{}:{tailTurns:d},...t?{turnId:t}:{},...n?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},w=Object.keys(g).length>0?{params:{cardId:r},body:g}:{params:{cardId:r}},h=v(await f.readAll(w),"chatStore.readAll"),A=a(await T(u,r)),C=b(a(A.card_data).files).map((y,x)=>({idx:x,stored_name:a(y).stored_name})).filter(y=>typeof y.stored_name=="string"&&y.stored_name.length>0),S=(Array.isArray(h.records)?h.records:[]).map(y=>{let L=a(y.payload),p={...y},O=typeof y?.role=="string"?y.role:typeof L.role=="string"?String(L.role):"",q=typeof y?.text=="string"?y.text:typeof L.text=="string"?String(L.text):"";if(O==="system"){let N=he(q);if(N!==null&&C.some(j=>j.idx===N)){let j=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${N}`;p.retrieval_hint=j,Object.keys(L).length>0&&typeof y.role!="string"&&(p.payload={...L,retrieval_hint:j});}}return p});return {cardId:r,messages:typeof m=="number"&&m>=0?S.slice(-m):S}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let n=a(await T(u,r)),o=b(a(n.card_data).files).map(a);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let d=o[t],m=typeof d.stored_name=="string"?d.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:M({cardId:r,fileIdx:t,storedName:m}),...typeof d.name=="string"?{name:d.name}:{},...typeof d.stored_name=="string"?{stored_name:d.stored_name}:{},...typeof d.mime_type=="string"?{mime_type:d.mime_type}:{},...typeof d.size=="number"?{size:d.size}:{},...typeof d.uploaded_at=="string"?{uploaded_at:d.uploaded_at}:{}}}async function $(e){return await c.validateCardPreflight({body:ke(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=c.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=a(H(r,"evalCardCompute")),n=a(e.candidateCardContent),o={card_data:a(n.card_data),requires:a(e.mockRequires),fetched_sources:a(e.mockFetchedSources),computed_values:a(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof n.id=="string"?n.id:"(unknown)",ok:t.ok===true,computed_values:a(t.computed_values),errors:b(t.errors).map(d=>{let m=a(d);return {bindTo:typeof m.bindTo=="string"?m.bindTo:"",error:typeof m.error=="string"?m.error:""}}),provides_outputs:G(n,o),rendered_view:V(n,o)}}}async function ae(e){return await c.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=a(await T(u,r)),n=b(t.source_defs).filter(d=>!!d&&typeof d=="object"&&!Array.isArray(d)),o={};if(e.sourceIdx>=0&&e.sourceIdx<n.length){let d=n[e.sourceIdx],m=chunkIXZG74EW_cjs.a.enrichSourcesSync([d],{card_data:a(t.card_data),requires:e.mockRequires});Array.isArray(m)&&m.length>0&&(o=a(m[0]._projections));}return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=a(await U(c.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=a(e.candidateCardContent),n=a(r.validation),o=b(r.source_probes),d=b(r.projection_errors),m=a(r.fetched_sources),g=b(r.compute_errors),w=a(r.computed_values),h={card_data:a(t.card_data),requires:e.mockRequires,fetched_sources:m,computed_values:w},A=[];for(let C of b(n.issues))typeof C=="string"&&C&&A.push(C);for(let C of o){let l=a(C),S=typeof l.bindTo=="string"?l.bindTo:"source",y=typeof l.error=="string"?l.error:"";y&&A.push(`${S}: ${y}`);}for(let C of d){let l=a(C),S=typeof l.bindTo=="string"?l.bindTo:"source",y=typeof l.key=="string"?l.key:"projection",x=typeof l.error=="string"?l.error:"projection failed";A.push(`${S}.${y}: ${x}`);}for(let C of g){let l=a(C),S=typeof l.bindTo=="string"?l.bindTo:"compute",y=typeof l.error=="string"?l.error:"compute failed";A.push(`${S}: ${y}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:A,provides_outputs:G(t,h),rendered_view:V(t,h)}}}async function K(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await U(u.get({params:{id:r}}),"cardStore.get"),n=Array.isArray(t.cards)?t.cards.map(a):[];if(n.some(Q))throw Object.assign(new Error(`Card "${r}" not found`),{statusCode:404});return n.map(o=>E(o))}async function W(e){let r=await Promise.all(b(e.files).map(async t=>{let n=a(t),o=String(n.file_name??n.fileName??n.name??"").trim(),d=String(n.content_type??n.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await R({cardId:e.cardId,fileName:o,contentType:d,bytes:X(n),suppressChatRecordWrite:true})}));for(let[t,n]of r.entries()){let o=a(n.file),d=typeof n.file_idx=="number"&&Number.isInteger(n.file_idx)&&n.file_idx>=0?n.file_idx:t,m=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`;v(await f.append({params:{cardId:e.cardId},body:{role:"system",text:m,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}return r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",n=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await W({cardId:r,role:t,turn:n,files:e.files});return {status:"success",data:{cardId:r,turn:n,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),n=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let g=v(await f.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),w=Array.isArray(g.records)?g.records.find(h=>h.role==="assistant"&&String(h.turn||"")===o):void 0;if(w)return {status:"success",data:{cardId:r,id:String(w.id),role:t,turn:o,files:Array.isArray(w.files)?w.files:[]}}}let d=await W({cardId:r,role:t,turn:o,files:e.files}),m=v(await f.append({params:{cardId:r},body:{role:t,text:n,files:d,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(m.id),role:t,turn:o,files:d}}}async function ue(e){let r=String(e.cardId||"").trim(),t=a(e.patch);if(!r)throw new Error("managePatchCard requires cardId");let n=await K({cardId:r}),o=a(n[0]),m={...ve(o,t),...D(o,"meta")?{meta:o.meta}:{},...D(o,"__private")?{__private:o.__private}:{}},g=await u.set({body:m});v(g,"cardStore.set");let w;try{w=await i.upsertCard({params:{cardId:r,restart:!0}}),v(w,"upsertCard");}catch(A){try{await u.set({body:o});}catch{}throw A}let h=null;try{h=await i.cardRefreshedNotify({params:{cardId:r}}),v(h,"cardRefreshedNotify");}catch{h=null;}return {status:"success",data:{validation:null,card_saved:null,board_result:w,refresh_notify:h}}}async function le(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("manageUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:n}),d=a(o),m=a(d.data);if(d.status!=="success"||m.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let w=g?a(g):null,h={...n,...w&&D(w,"meta")?{meta:w.meta}:{},...w&&D(w,"__private")?{__private:w.__private}:{}},A=await u.set({body:h});v(A,"cardStore.set");let C;try{C=await i.upsertCard({params:{cardId:r,restart:!0}}),v(C,"upsertCard");}catch(S){try{g&&await u.set({body:g});}catch{}throw S}let l=null;try{l=await i.cardRefreshedNotify({params:{cardId:r}}),v(l,"cardRefreshedNotify");}catch{l=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:C,refresh_notify:l}}}async function me(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageRemoveCard requires cardId");let t=await i.removeCard({params:{id:r}});v(t,"removeCard");let n=await u.del({params:{id:r}});return v(n,"cardStore.del"),{status:"success",data:{board_result:t,store_result:n}}}async function pe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await U(u.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(n=>a(n)):[]}async function fe(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:n}),d=a(o),m=a(d.data);if(d.status!=="success"||m.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let w=g?a(a(g).__private):{},h={...n,__private:{...w,visible_controlplane_only:true}},A=await u.set({body:h});v(A,"cardStore.set");let C;try{C=await i.upsertCard({params:{cardId:r,restart:!0}}),v(C,"upsertCard");}catch(S){try{g&&await u.set({body:g});}catch{}throw S}let l=null;try{l=await i.cardRefreshedNotify({params:{cardId:r}}),v(l,"cardRefreshedNotify");}catch{l=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:C,refresh_notify:l}}}async function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=H(await f.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}async function we(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return v(await f.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function Ce(){let e=await B(_,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let n=await B(I,"webhook.source-fetch-done")({token:r,ref:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}async function be(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let n=await B(k,"webhook.source-fetch-failed")({token:r,reason:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}return {listRuntimeCards:F,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:$,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:K,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:le,manageRemoveCard:me,adminReadCard:pe,adminUpsertCard:fe,getChatProcessing:ge,setChatProcessing:we,webhookProcessAccumulated:Ce,webhookSourceFetchDone:ye,webhookSourceFetchFailed:be}}async function U(s,i){return v(await s,i)}exports.a=Ae;//# sourceMappingURL=chunk-7QZ267XP.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-7QZ267XP.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {a as a$1}from'./chunk-
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {a as a$1}from'./chunk-44L64VQ2.js';function i(e,t){let n;return /\.m?js$/i.test(e)?n="local-node":/\.py$/i.test(e)?n="local-python":n="local-process",{meta:"task-executor",howToRun:n,whatToRun:a$1({kind:"fs-path",value:e}),...t?{extra:t}:{}}}function s(e){return JSON.stringify(e)}function a(e){let t;try{t=JSON.parse(e);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${e}`)}if(typeof t!="object"||t===null||typeof t.howToRun!="string"||typeof t.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${e}`);return t}export{i as a,s as b,a as c};//# sourceMappingURL=chunk-ANKA7HEJ.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-ANKA7HEJ.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs');function p(t){return typeof t.journalStorage=="function"}function s(t){return typeof t.whatToRun=="string"?t.whatToRun.startsWith("b64:")?chunkVQCIOKJV_cjs.b(t.whatToRun).value:t.whatToRun:t.whatToRun.value}function c(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function f(t){let a=t.reduce((r,u)=>r+u.length,0),o=new Uint8Array(a),n=0;for(let r of t)o.set(r,n),n+=r.length;return o}exports.a=p;exports.b=s;exports.c=c;exports.d=f;//# sourceMappingURL=chunk-BQUQTOPB.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-BQUQTOPB.cjs.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
'use strict';var chunk37HDEW26_cjs=require('./chunk-37HDEW26.cjs'),chunkPBCDDO4V_cjs=require('./chunk-PBCDDO4V.cjs'),chunkNDAKMJQK_cjs=require('./chunk-NDAKMJQK.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkIXZG74EW_cjs=require('./chunk-IXZG74EW.cjs');async function Ye(r,a,u){let i=await r.tryAcquire();if(!i)return false;try{await a();}finally{await i();}return await u?.(),true}function Xe(r){return chunkPBCDDO4V_cjs.b(r)}function Ze(r,a){return {async readIndex(){return await r.read("_index")},writeIndex(u){return r.write("_index",u)},async readCard(u){return await r.read(u)},async writeCard(u,i){return await r.write(u,i),a(i)},removeCard(u){return r.delete(u)},async cardExists(u){return await r.read(u)!==null},defaultCardKey(u){return u}}}function et(r,a){async function u(){return await r.readIndex()??{}}return {async readCard(i){let p=(await u())[i];return !p||!await r.cardExists(p.key)?null:await r.readCard(p.key)},async readCardKey(i){return (await u())[i]?.key??null},async readAllCards(){let i=[];for(let[p,S]of Object.entries(await u())){if(!await r.cardExists(S.key))continue;let c=await r.readCard(S.key);c?i.push(c):a?.(`[card-store] could not read card "${p}" at key "${S.key}"`);}return i},async readChecksumIndex(){let i={};for(let[p,S]of Object.entries(await u()))i[p]=S.checksum;return i},async changedSince(i){let p=await u(),S=[];for(let[c,C]of Object.entries(p))i[c]!==C.checksum&&S.push(c);for(let c of Object.keys(i))p[c]||S.push(c);return S},async validateUpsert(i,p){let S=await u(),c=S[i],C=Object.entries(S).find(([,P])=>P.key===p);return c&&c.key!==p?{ok:false,error:`Card id "${i}" is already mapped to key "${c.key}", cannot remap to "${p}"`}:C&&C[0]!==i?{ok:false,error:`Key "${p}" is already mapped to card id "${C[0]}", cannot remap to "${i}"`}:{ok:true}},async writeCard(i,p,S){let c=await u(),C=S??c[i]?.key??r.defaultCardKey(i),P=await r.writeCard(C,p);c[i]={key:C,checksum:P,updatedAt:new Date().toISOString()},await r.writeIndex(c);},async patchCard(i,p,S){let c=await u(),C=c[i];if(!C||!await r.cardExists(C.key))throw new Error(`card "${i}" not found`);let P=await r.readCard(C.key);if(!P||typeof P!="object"||Array.isArray(P))throw new Error(`card "${i}" is not patchable`);let B=String(p||"").split(".").filter(Boolean),te=chunkPBCDDO4V_cjs.a(P,B,S),E=await r.writeCard(C.key,te);c[i]={key:C.key,checksum:E,updatedAt:new Date().toISOString()},await r.writeIndex(c);},async removeCard(i){let p=await u(),S=p[i];S&&(await r.removeCard(S.key),delete p[i],await r.writeIndex(p));},readIndex(){return u()}}}function Rt(r,a){return chunkNDAKMJQK_cjs.a(r,a)}function kt(r,a,u){return {blob:r,kv:a,journal:u}}function h(r){return r!==void 0?{status:"success",data:r}:{status:"success"}}function f(r){return {status:"fail",error:r}}function v(r){return {status:"error",error:r instanceof Error?r.message:String(r)}}function x(){return new Date().toISOString()}function ut(r){let a=new TextEncoder().encode(r),u=Array.from(a,i=>String.fromCharCode(i)).join("");return btoa(u).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function nt(r){let a=r.replace(/-/g,"+").replace(/_/g,"/"),u=a+"=".repeat((4-a.length%4)%4),i=atob(u),p=Uint8Array.from(i,S=>S.charCodeAt(0));return new TextDecoder().decode(p)}function ge(r){try{let a=JSON.parse(nt(r));return typeof a?.t=="string"?{taskName:a.t}:null}catch{return null}}function tt(r){return ut(JSON.stringify(r))}function rt(r){try{let a=JSON.parse(nt(r));return typeof a?.cbk=="string"&&typeof a?.cid=="string"&&typeof a?.b=="string"&&typeof a?.d=="string"?a:null}catch{return null}}function dt(r){return chunkNDAKMJQK_cjs.j(r,chunkNDAKMJQK_cjs.o,()=>({_sources:{}}))}function ct(r,a){return chunkNDAKMJQK_cjs.h(r,a)}function mt(r){return chunkNDAKMJQK_cjs.k(r)}function lt(r,a){return chunkNDAKMJQK_cjs.i(r,a)}function ft(r,a,u,i,p,S){return async c=>{let C=[],P=await u.cardStore.readCard(c.nodeId);if(!P)return "task-initiate-failure";let B=P.id,te=P.card_data??{},E=P.source_defs??[],re=E.filter(m=>m.optionalForCompletionGating!==true),b=await u.cardRuntimeStore.readRuntime(B),D=false,V=async()=>{D&&(await u.cardRuntimeStore.writeRuntime(B,b),D=false);},T=m=>chunkNDAKMJQK_cjs.p(b._sources[m]),K=(m,l)=>{b._sources[m]=chunkNDAKMJQK_cjs.p(l),D=true;},oe=c.taskState?.executionCount??0;if(b._lastExecutionCount!==oe&&(b._sources={},b._lastExecutionCount=oe,D=true),c.update){let m=c.update.outputFile;if(m){let l=T(m);if(c.update.failure){let R=c.update.rqt??l.lastRequestedToken??l.queueRequestedToken;R&&K(m,chunkNDAKMJQK_cjs.s(l,R));}else {let R=c.update.rqt;if(!l.lastCompletedToken||R>l.lastCompletedToken){let t=typeof c.update.deliveryToken=="string"?c.update.deliveryToken:void 0,e=t?await u.fetchedSourcesStore.commitSourceData(B,m,t):false;K(m,e?chunkNDAKMJQK_cjs.r(l,R):chunkNDAKMJQK_cjs.s(l,R));}}await V();}}let L={};for(let m of E){if(!m.outputFile)continue;let l=await u.fetchedSourcesStore.readSourceData(B,m.outputFile);l!==null&&(L[m.bindTo]=l);}let U={};for(let[m,l]of Object.entries(c.state??{}))if(l!==null&&typeof l=="object"&&!Array.isArray(l)){let R=l[m];U[m]=R!==void 0?R:l;}else U[m]=l;let J={id:B,card_data:{...te},requires:U,source_defs:E,compute:P.compute};J._sourcesData=L,P.compute&&chunkIXZG74EW_cjs.a.runSync(J,{sourcesData:L}),(p??(()=>{}))(B,J.computed_values??{});let ne=chunkIXZG74EW_cjs.a.enrichSourcesSync(Array.isArray(P.source_defs)?P.source_defs:void 0,{card_data:P.card_data,requires:U}),F={...P,source_defs:Array.isArray(ne)?ne.map(m=>({...m,boardDir:typeof m.boardDir=="string"&&m.boardDir?m.boardDir:r.value})):ne},M=x(),G=c.update?void 0:M,W=re.filter(m=>{let l=m.outputFile;if(typeof l!="string"||!l)return true;let R=T(l);G&&(R={...R,queueRequestedToken:G},K(l,R));let t=R.queueRequestedToken??R.lastRequestedToken??M;return chunkNDAKMJQK_cjs.q(R,t)==="dispatch"});if(await V(),W.length>0){let m=false,l=M;for(let R of W){let t=R.outputFile;if(typeof t!="string"||!t)continue;let e=T(t),s=e.queueRequestedToken??M;K(t,{...e,lastRequestedToken:s}),l=s,m=true;}return m&&await V(),m&&(C.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(r),enrichedCard:F,callbackToken:c.callbackToken,rqt:l}}),await u.executionRequestStore.appendEntries(a,C)),"task-initiated"}if(re.some(m=>{let l=m.outputFile;if(typeof l!="string"||!l)return false;let R=T(l),t=R.queueRequestedToken??R.lastRequestedToken??M;return chunkNDAKMJQK_cjs.q(R,t)==="in-flight"}))return "task-initiated";let ye=P.provides??[],ae={};for(let{bindTo:m,ref:l}of ye)ae[m]=chunkIXZG74EW_cjs.a.resolve(J,l);return (S??(()=>{}))(ae),E.filter(m=>{if(m.optionalForCompletionGating!==true)return false;let l=T(m.outputFile);return !l.lastRequestedToken||!l.lastCompletedToken?true:l.lastCompletedToken<=l.lastRequestedToken}).length>0&&C.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(r),enrichedCard:F,callbackToken:c.callbackToken,rqt:M}}),i(c.nodeId,ae),C.length>0&&await u.executionRequestStore.appendEntries(a,C),"task-initiated"}}function Et(r,a,u={}){chunkNDAKMJQK_cjs.d(a.callbackTransport,"createAsyncBoardLiveCardsPublic");let i=a.callbackTransport,p=a.warn??(()=>{}),S=chunkVQCIOKJV_cjs.a(r),c=null,C=u.boardRuntimeStoreRef,P=u.scratchStoreRef,B=u.taskExecutorRef,te=u.chatHandlerFlow;function E(){if(!C)throw new Error(`Board at ${r.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return C}function re(t){if(t.length!==0)try{return Promise.resolve(a.publishBoardChangeNotifications?.(t)).catch(e=>{p(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${e instanceof Error?e.message:String(e)}`);})}catch(e){p(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${e instanceof Error?e.message:String(e)}`);return}}let b=()=>chunk37HDEW26_cjs.b(a.kvStorageForRef(E())),D=r.value,V=()=>chunkNDAKMJQK_cjs.b(chunkNDAKMJQK_cjs.a(()=>a.kvStorageForRef(E()),a.hashFn),"v1"),T=async()=>{let t=await b().readOutputsStoreRef();if(!t)throw new Error(`Board at ${r.value} has no outputs store configured.`);return mt(a.kvStorageForRef(t))},K=async()=>{let t=await b().readCardStoreRef();if(!t)throw new Error(`Board at ${r.value} has no card store configured.`);let e=a.kvStorageForRef(t);return et(Ze(Xe(e),a.hashFn),p)};async function oe(){return !!(await V().readSnapshot(D)).values[chunkNDAKMJQK_cjs.n]}async function L(){let t=await V().readSnapshot(D);if(!t.values[chunkNDAKMJQK_cjs.n])throw new Error(`Board not initialized at ${r.value}`);return chunkNDAKMJQK_cjs.w(t.values)}async function U(t,e){let s=await V().commitSnapshot(D,{schemaVersion:"v1",expectedVersion:e,deleteKeys:[],shallowMerge:chunkNDAKMJQK_cjs.v(t)});if(!s.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${e??"null"} current=${s.currentVersion??"null"}`)}let J=()=>chunkNDAKMJQK_cjs.c(a.journalStorageForRef(E()));async function ne(){return B??await b().readTaskExecutorRef()}async function F(t){await J().appendEvent(t);}async function M(){let t=await b().readFetchedSourcesStoreRef();if(!t)throw new Error(`Board at ${r.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return t}async function G(){return a.blobStorageForRef(await M())}async function W(){return ct(await G(),t=>a.resolveBlob(t))}async function pe(t){let e=(await G()).keyRef?.(t);if(!e)throw new Error("configured fetched-sources store does not support keyRef");let s=await Promise.resolve(e);return chunkVQCIOKJV_cjs.a(s)}async function ye(){let t=lt(a.kvStorageForRef(E()),async(o,d)=>{let k=o.payload,I=(k.enrichedCard??{}).id??k.cardId??"unknown";await F({type:"task-failed",taskName:I,error:d,timestamp:x()});}),e=dt(a.kvStorageForRef(E())),s=await G(),n=await W(),y=await K(),w=await T(),A=new Map,g=new Map,z=[],Q=[],$=[],H=new Map,Y=new Set,Re={async readRuntime(o){return A.get(o)??await e.readRuntime(o)},async writeRuntime(o,d){A.set(o,d),Se[o]=d;}},at={async readSourceData(o,d){let k=`${o}/${d}`;return g.has(k)?g.get(k):await n.readSourceData(o,d)},ingestSourceDataStaged(o,d,k,O){return n.ingestSourceDataStaged(o,d,k,O)},async commitSourceData(o,d,k){let O=`${o}/.staged/${k}/${d}`,I=await s.read(O);if(I==null){let j=await Promise.resolve(s.keyRef?.(O));j&&(I=await a.resolveBlob(j));}if(I==null)return false;let _=`${o}/${d}`,Z=I.trim();try{g.set(_,JSON.parse(Z));}catch{g.set(_,Z);}return z.push({cardId:o,outputFile:d,deliveryToken:k}),true},async hasSource(o,d){let k=`${o}/${d}`;return g.has(k)||await n.hasSource(o,d)},async listSources(o){let d=await n.listSources(o),k=[...g.keys()].filter(O=>O.startsWith(`${o}/`)).map(O=>O.slice(`${o}/`.length));return [...new Set([...d,...k])]}},ke=await L(),ot=chunkG4XXRHL2_cjs.q(ke.graph),Se={...ke.runtimeByCardId},{events:st,newCursor:Ce}=await J().readEntriesAfterCursor(ke.lastDrainedJournalId),se=st,ie=chunkG4XXRHL2_cjs.u(ot,{handlers:{"card-handler":ft(r,Ce,{cardStore:y,cardRuntimeStore:Re,fetchedSourcesStore:at,executionRequestStore:t},(o,d)=>{se.push({type:"task-completed",taskName:o,data:d,timestamp:x()});},(o,d)=>{Q.push({cardId:o,values:d});},o=>{$.push(o);})},onNodeRemoved:o=>{H.delete(o),A.delete(o),delete Se[o],Y.add(o);}});for(;se.length>0;){let o=se;se=[];for(let d of o)if(d.type==="task-restart"){let k=await y.readCard(d.taskName);k&&H.set(d.taskName,k);}ie.pushAll(o),await ie.waitForHandlers();}let Ie=ie.getState();await ie.dispose({wait:true}),await U({lastDrainedJournalId:Ce,graph:chunkG4XXRHL2_cjs.p(Ie),runtimeByCardId:Se},(await V().readSnapshot(D)).version);for(let{cardId:o,values:d}of Q)await w.writeComputedValues(o,d);for(let o of $)await w.writeDataObjects(o);for(let[o,d]of A)await e.writeRuntime(o,d);for(let o of z)await n.commitSourceData(o.cardId,o.outputFile,o.deliveryToken);let xe=chunkNDAKMJQK_cjs.t(S,Ie);await w.writeStatusSnapshot(xe);let ee=[];for(let{cardId:o,values:d}of Q)ee.push({kind:"computed_values",cardId:o,values:d});for(let o of $)for(let[d,k]of Object.entries(o))ee.push({kind:"data_object",key:d,payload:k});for(let[o,d]of H)ee.push({kind:"card_refreshed",cardId:o,card:d});for(let o of Y)ee.push({kind:"card_removed",cardId:o});ee.push({kind:"status",status:xe}),await re(ee);let X=await ne();if(!X)return;let Fe=a.supportsDirectSourceOutput?.(X)===true;await t.dispatchEntriesForJournalId(Ce,async o=>{if(o.taskKind!=="source-fetch"){p(`[async-process-accumulated-events] unknown taskKind "${o.taskKind}" \u2014 skipping`);return}let d=o.payload,k=d.enrichedCard?.id??"unknown",O=d.enrichedCard?.source_defs??[];if(X.howToRun==="queue-storage"&&Fe){try{let I=await b().readQueueStoreRef();if(!I)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let _=a.queueStorageForRef(I,"task-executor"),Z=typeof X.extra?.boardId=="string"?X.extra.boardId:void 0,j=[];for(let N of O){if(!N.outputFile)continue;let ue=a.genId(),de=`${k}/.staged/${ue}/${N.outputFile}`,qe=await Promise.resolve(s.keyRef?.(de));if(!qe)continue;let Te={ref:chunkVQCIOKJV_cjs.a(qe),deliveryToken:ue,outputFile:N.outputFile,cardId:k},it=tt({cbk:d.callbackToken,rg:r.value,br:chunkVQCIOKJV_cjs.a(r),cid:k,b:N.bindTo,d:N.outputFile,cs:void 0,rqt:d.rqt,dt:Te.deliveryToken});j.push({...Z?{boardId:Z}:{},ref:X,args:{source_def:N,base_ref:chunkVQCIOKJV_cjs.a(r),callback:i.createCallback(it),output:Te}});}j.length>0&&await _.enqueueMany(j);}catch(I){await F({type:"task-failed",taskName:k,error:I instanceof Error?I.message:String(I),timestamp:x()});}return}for(let I of O){if(!I.outputFile)continue;let _;if(Fe){let N=a.genId(),ue=`${k}/.staged/${N}/${I.outputFile}`,de=await Promise.resolve(s.keyRef?.(ue));de&&(_={ref:chunkVQCIOKJV_cjs.a(de),deliveryToken:N,outputFile:I.outputFile,cardId:k});}let Z=tt({cbk:d.callbackToken,rg:r.value,br:chunkVQCIOKJV_cjs.a(r),cid:k,b:I.bindTo,d:I.outputFile,cs:void 0,rqt:d.rqt,..._?{dt:_.deliveryToken}:{}}),j=await a.dispatchExecution(X,{source_def:I,base_ref:chunkVQCIOKJV_cjs.a(r),callback:i.createCallback(Z),..._?{output:_}:{}});j.dispatched||await F({type:"task-failed",taskName:k,error:j.error??"dispatch failed",timestamp:x()});}});}async function ae(){try{let t=async()=>{let s=await L(),{events:n}=await J().readEntriesAfterCursor(s.lastDrainedJournalId);n.length>0&&await m();},e=await Ye(a.lock,ye,t);return h({ran:e!==!1})}catch(t){return v(t)}}async function be(){return c||(c=ae().finally(()=>{c=null;}),c)}async function m(){let t=await b().readQueueStoreRef();if(!t)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=a.queueStorageForRef(t,"process-accumulated");e.enqueueIfAbsent?await e.enqueueIfAbsent({boardRef:chunkVQCIOKJV_cjs.a(r)},`process-accumulated:${chunkVQCIOKJV_cjs.a(r)}`):await e.enqueue({boardRef:chunkVQCIOKJV_cjs.a(r)}),await a.requestProcessAccumulated?.();}async function l(){let t=await b().readQueueStoreRef();if(!t)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=a.queueStorageForRef(t,"process-accumulated");for(;;){let s=await e.lease({max:64,visibilityMs:1e3});if(s.length<=0)return;for(let n of s)await e.ack(n.id,n.leaseToken);if(s.length<64)return}}function R(){m();}return {async init(t){try{let e=t.params?.cardStoreRef;if(!e)return f("init requires params.cardStoreRef");if(C=t.params?.boardRuntimeStoreRef,!C)return f("init requires params.boardRuntimeStoreRef");let s=t.params?.outputsStoreRef;if(!s)return f("init requires params.outputsStoreRef");let n=t.params?.queueStoreRef;if(!n)return f("init requires params.queueStoreRef");let y=t.params?.fetchedSourcesStoreRef;if(!y)return f("init requires params.fetchedSourcesStoreRef");if(P=t.params?.scratchStoreRef,!P)return f("init requires params.scratchStoreRef");let w=t.params?.chatStoreRef;if(!w)return f("init requires params.chatStoreRef");let A=t.params?.artifactsStoreRef;if(!A)return f("init requires params.artifactsStoreRef");await oe()||await U({lastDrainedJournalId:"",graph:chunkG4XXRHL2_cjs.p(chunkG4XXRHL2_cjs.a(chunkNDAKMJQK_cjs.u)),runtimeByCardId:{}},null);let g=b();return await g.writeBoardRuntimeStoreRef(C),await g.writeCardStoreRef(e),await g.writeOutputsStoreRef(s),await g.writeQueueStoreRef(n),await g.writeFetchedSourcesStoreRef(y),await g.writeChatStoreRef(w),await g.writeArtifactsStoreRef(A),await(await T()).writeStatusSnapshot(chunkNDAKMJQK_cjs.t(S,chunkG4XXRHL2_cjs.q((await L()).graph))),h()}catch(e){return v(e)}},async status(t){try{let e=await T(),s=await e.readStatusSnapshot();return s||(s=chunkNDAKMJQK_cjs.t(S,chunkG4XXRHL2_cjs.q((await L()).graph)),await e.writeStatusSnapshot(s)),h(s)}catch(e){return v(e)}},async getCardStoreRef(t){try{let e=await b().readCardStoreRef();return e?h({storeRef:e}):f(`Board at ${r.value} has no card store configured`)}catch(e){return v(e)}},async getBoardRuntimeStoreRef(t){try{return h({storeRef:C??null})}catch(e){return v(e)}},async getOutputsStoreRef(t){try{let e=await b().readOutputsStoreRef();return e?h({storeRef:e}):f(`Board at ${r.value} has no outputs store configured`)}catch(e){return v(e)}},async getScratchStoreRef(t){try{return h({storeRef:P??null})}catch(e){return v(e)}},async getChatStoreRef(t){try{return h({storeRef:await b().readChatStoreRef()})}catch(e){return v(e)}},async getArtifactsStoreRef(t){try{return h({storeRef:await b().readArtifactsStoreRef()})}catch(e){return v(e)}},async getFetchedSourcesStoreRef(t){try{return h({storeRef:await b().readFetchedSourcesStoreRef()})}catch(e){return v(e)}},async getConfig(t){try{let e=t.params?.key;if(!e)return f("getConfig requires params.key");let s=b(),n;switch(e){case "task-executor":n=B??null;break;case "chat-handler-flow":n=te??null;break;case "board-runtime-store-ref":n=await s.readBoardRuntimeStoreRef();break;case "card-store-ref":n=await s.readCardStoreRef();break;case "outputs-store-ref":n=await s.readOutputsStoreRef();break;case "scratch-store-ref":n=P??null;break;case "chat-store-ref":n=await s.readChatStoreRef();break;case "artifacts-store-ref":n=await s.readArtifactsStoreRef();break;case "fetched-sources-store-ref":n=await s.readFetchedSourcesStoreRef();break;default:return f(`getConfig: unknown key "${e}"`)}return h({value:n})}catch(e){return v(e)}},async getOutputsDataObject(t){try{let e=t.params?.key;return e?h(await(await T()).readDataObject(e)):f("getOutputsDataObject requires params.key")}catch(e){return v(e)}},async getAllOutputsDataObjects(t){try{return h(await(await T()).readAllDataObjects())}catch(e){return v(e)}},async getOutputsComputedValues(t){try{let e=t.params?.key;return e?h(await(await T()).readComputedValues(e)):f("getOutputsComputedValues requires params.key")}catch(e){return v(e)}},async getAllOutputsComputedValues(t){try{return h(await(await T()).readAllComputedValues())}catch(e){return v(e)}},async getOutputsFetchedSources(t){try{let e=t.params?.key;if(!e)return f("getOutputsFetchedSources requires params.key");let s=await(await W()).listSources(e),n={};for(let y of s)n[y]=await pe(`${e}/${y}`);return h(n)}catch(e){return v(e)}},async getAllOutputsFetchedSources(t){try{let e=await W(),s=await(await G()).listKeys(),n=new Set;for(let w of s){let A=w.indexOf("/");A>0&&!w.includes("/.staged/")&&n.add(w.slice(0,A));}let y={};for(let w of n){let A=await e.listSources(w);if(A.length!==0){y[w]={};for(let g of A)y[w][g]=await pe(`${w}/${g}`);}}return h(y)}catch(e){return v(e)}},async addCardFiles(t){try{let e=t.params?.cardId;if(!e)return f("addCardFiles requires params.cardId");let s=await K(),n=await s.readCard(e);if(!n)return f(`card "${e}" not found`);let y=t.body,w=Array.isArray(y)?y:y&&typeof y=="object"&&Array.isArray(y.files)?y.files:y!=null?[y]:null;if(!w||w.length===0)return f("addCardFiles requires a file metadata object, array, or body.files array");let A=n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?n.card_data:{},g=Array.isArray(A.files)?A.files:[],z=[...g,...w],Q=w.map((H,Y)=>({idx:g.length+Y,entry:H}));await s.writeCard(e,{...n,card_data:{...A,files:z}});let $=await this.cardRefreshedNotify({params:{cardId:e}});return $.status!=="success"?$:h({cardId:e,files_added:Q,notified:!0})}catch(e){return v(e)}},async cardRefreshedNotify(t){try{let e=t.params?.cardId;if(!e)return f("cardRefreshedNotify requires params.cardId");let s=await(await K()).readCard(e);return s?(await re([{kind:"card_refreshed",cardId:e,card:s}]),h({cardId:e,notified:!0})):f(`Card "${e}" not found in board at ${r.value}`)}catch(e){return v(e)}},async removeCard(t){try{let e=t.params?.id;if(!e)return f("removeCard requires params.id");try{await a.kvStorage("card-upsert").delete(e);}catch{}return await F({type:"task-removal",taskName:e,timestamp:x()}),R(),h()}catch(e){return v(e)}},async retrigger(t){try{let e=t.params?.id;return e?(await F({type:"task-restart",taskName:e,timestamp:x()}),R(),h()):f("retrigger requires params.id")}catch(e){return v(e)}},async processAccumulatedEvents(t){return await l(),be()},async upsertCard(t){try{let e=t.params?.cardId,s=t.params?.all,n=!!t.params?.restart;if(!e&&!s)return f("upsertCard requires --card-id <id> or --all");let y=await K(),w=s?(await y.readAllCards()).map(g=>g.id):[e];for(let g of w)if(!await y.readCard(g))return f(`Card "${g}" not found in board at ${r.value}`);let A=a.kvStorage("card-upsert");for(let g of w){let z=await y.readCard(g);if(!z)continue;let Q=chunkNDAKMJQK_cjs.x(z),$=a.hashFn(Q),H=await A.read(g),Y=H?.taskConfigHash!==$;if(!(!Y&&!n)){if(Y){let Re=H?.blobRef??await y.readCardKey(g)??g;await F({type:"task-upsert",taskName:g,taskConfig:Q,timestamp:x()}),await A.write(g,{blobRef:Re,taskConfigHash:$,updatedAt:x()});}n&&await F({type:"task-restart",taskName:g,timestamp:x()});}}return R(),h()}catch(e){return v(e)}},async taskFailed(t){try{let e=t.params?.token;if(!e)return f("taskFailed requires params.token");let s=t.params?.error??"unknown error",n=ge(e);return n?(await F({type:"task-failed",taskName:n.taskName,error:s,timestamp:x()}),R(),h()):f("Invalid callback token")}catch(e){return v(e)}},async taskProgress(t){try{let e=t.params?.token;if(!e)return f("taskProgress requires params.token");let s=(t.body??{}).update??{},n=ge(e);return n?(await F({type:"task-progress",taskName:n.taskName,update:s,timestamp:x()}),R(),h()):f("Invalid callback token")}catch(e){return v(e)}},async sourceDataFetched(t){try{let e=t.params?.token,s=t.params?.ref;if(!e)return f("sourceDataFetched requires params.token");if(!s)return f("sourceDataFetched requires params.ref");let n=rt(e);if(!n)return f("Invalid source token");let y=await W(),w=n.dt||a.genId();n.dt||await y.ingestSourceDataStaged(n.cid,n.d,chunkVQCIOKJV_cjs.b(s),w);let A=ge(n.cbk);return A?(await F({type:"task-progress",taskName:A.taskName,update:{bindTo:n.b,outputFile:n.d,fetchedAt:x(),deliveryToken:w,sourceChecksum:n.cs,rqt:n.rqt},timestamp:x()}),R(),h()):f("Invalid callback token embedded in source token")}catch(e){return v(e)}},async sourceDataFetchFailure(t){try{let e=t.params?.token,s=t.params?.reason??"unknown";if(!e)return f("sourceDataFetchFailure requires params.token");let n=rt(e);if(!n)return f("Invalid source token");let y=ge(n.cbk);return y?(await F({type:"task-progress",taskName:y.taskName,update:{bindTo:n.b,outputFile:n.d,failure:!0,reason:s,sourceChecksum:n.cs,rqt:n.rqt},timestamp:x()}),R(),h()):f("Invalid callback token embedded in source token")}catch(e){return v(e)}}}}
|
|
2
|
+
exports.a=Ye;exports.b=Xe;exports.c=Ze;exports.d=et;exports.e=Rt;exports.f=kt;exports.g=Et;//# sourceMappingURL=chunk-CMFD27ZC.cjs.map
|
|
3
|
+
//# sourceMappingURL=chunk-CMFD27ZC.cjs.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {b as b$1,c as c$1}from'./chunk-ANKA7HEJ.js';import {a,b,c}from'./chunk-44L64VQ2.js';import {r,a as a$1,p,q,u}from'./chunk-VGT3TRQG.js';import {a as a$3}from'./chunk-JMDHDY6M.js';import {a as a$2}from'./chunk-KBELAKIY.js';function it(e){return typeof e=="string"&&e.trim().length>0}function ut(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.selfRef is required`);if(!it(e.howToRun))throw new Error(`${t}: adapter.selfRef.howToRun is required`);if(!it(e.whatToRun))throw new Error(`${t}: adapter.selfRef.whatToRun is required`)}function dt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.callbackTransport is required`);if(typeof e.createCallback!="function")throw new Error(`${t}: adapter.callbackTransport.createCallback is required`)}function Qt(e,t="callbackTransport"){return {createCallback(n){let a=e();return ut(a,t),{token:n,via:a}}}}function Ne(e){return Qt(()=>e,"createStaticExecutionRefCallbackTransport")}function cr(e){return Ne({meta:"board-live-cards",howToRun:"http:post",whatToRun:a({kind:"http-url",value:String(e||"").trim()})})}function lr(e){return Ne({meta:"board-live-cards",howToRun:"in-process-loop",whatToRun:a({kind:"in-process-loop",value:String(e||"").trim()})})}function fr(e){let t=typeof e=="string"?{notifyChannel:e}:e??{},n={};return t.notifyChannel&&(n.notifyChannel=t.notifyChannel),t.boardRuntimeStoreRef&&(n.boardRuntimeStoreRef=t.boardRuntimeStoreRef),t.queueStoreRef&&(n.queueStoreRef=t.queueStoreRef),Ne({meta:"board-live-cards",howToRun:"local-node",whatToRun:a({kind:"yaml-flow-cli",value:"board-live-cards-cli.js"}),...Object.keys(n).length>0?{extra:n}:{}})}function Ae(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Je(e,t){return Ae(e)?e.then(t):t(e)}function lt(e,t){let n={...e};for(let a of t.deleteKeys)delete n[a];return {...n,...t.shallowMerge}}function pr(e,t){return {readValues(a){let o=e(a);return Je(o.listKeys(),d=>{let u=[...d].sort();if(u.length===0)return {version:null,values:{}};let c={},C=null;for(let w of u){let q=o.read(w);Ae(q)?C=(C??Promise.resolve()).then(async()=>{c[w]=await q;}):c[w]=q;}return C?C.then(()=>({version:t(c),values:c})):{version:t(c),values:c}})},writeValues(a,o,d){let u=e(a),c=null;for(let C of d){let w=u.delete(C);Ae(w)&&(c=(c??Promise.resolve()).then(()=>w).then(()=>{}));}for(let[C,w]of Object.entries(o)){let q=u.write(C,w);Ae(q)&&(c=(c??Promise.resolve()).then(()=>q).then(()=>{}));}return c?c.then(()=>t(o)):t(o)}}}function ft(e,t){return {readSnapshot(n){return e.readValues(n)},commitSnapshot(n,a){if(a.schemaVersion!==t)throw new Error(`Unsupported snapshot schema version: ${a.schemaVersion}`);return Je(e.readValues(n),o=>{if(o.version!==a.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:o.version};let d=lt(o.values,a);return Je(e.writeValues(n,d,a.deleteKeys),u=>({ok:true,newVersion:u}))})}}}function ct(e,t){if(!t)return e;let n=e.findIndex(a=>a.id===t);return n===-1?e:e.slice(n+1)}function mt(e){return {readEntriesAfterCursor(t){let n=ct(e.readAllEntries(),t);return n.length===0?{events:[],newCursor:t}:{events:n.map(a=>a.event),newCursor:n[n.length-1].id}},pendingCount(t){return ct(e.readAllEntries(),t).length},appendEvent(t){e.appendEntry({id:e.generateId(),event:t});}}}function gr(e){return {appendEvent(t){return e.append(t).then(()=>{})},async readEntriesAfterCursor(t){let n=await e.readAfter(t||null);return {events:n.entries.map(a=>a.payload),newCursor:n.newCursor??t}}}}function Fe(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function ae(e,t){return Fe(e)?e.then(t):t(e)}function Me(e,t){let n=null;for(let a of e){if(n){n=n.then(()=>t(a)).then(()=>{});continue}let o=t(a);Fe(o)&&(n=Promise.resolve(o).then(()=>{}));}return n??void 0}function zt(e){if(e==null)return null;let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{return t}}function Yt(e,t){let n=e.match(t);return n?n[1]:null}function pt(e,t,n){let a={},o=Me(e,d=>{let u=n(d);if(u)return ae(t(d),c=>{a[u]=c;})});return Fe(o)?o.then(()=>a):a}function gt(e,t){return {readSourceData(n,a){return ae(e.read(`${n}/${a}`),zt)},ingestSourceDataStaged(n,a,o,d){return ae(t(o),u=>e.write(`${n}/.staged/${d}/${a}`,u))},commitSourceData(n,a,o){let d=`${n}/.staged/${o}/${a}`,u=`${n}/${a}`;return e.renameKey(d,u)},hasSource(n,a){return e.exists(`${n}/${a}`)},listSources(n){return ae(e.listKeys(`${n}/`),a=>a.filter(o=>!o.includes("/.staged/")).map(o=>o.slice(`${n}/`.length)))}}}function Xt(e,t){let n=(a,o)=>{try{let d=o(a);return Fe(d)?d.catch(u=>t(a,u instanceof Error?u.message:String(u))):void 0}catch(d){try{return t(a,d instanceof Error?d.message:String(d))}catch{return}}};return {appendEntries(a,o){if(!(!a||o.length===0))return ae(e.read(a),d=>e.write(a,[...d??[],...o]))},dispatchEntriesForJournalId(a,o){if(a)return ae(e.read(a),d=>{let u=d;if(!(!u||u.length===0))return ae(Me(u,c=>n(c,o)),()=>e.delete(a))})}}}function Wt(e,t,n){return {readRuntime(a){return ae(e.read(t(a)),o=>o??n())},writeRuntime(a,o){return e.write(t(a),o)}}}function St(e){return {writeComputedValues(t,n){return e.write(`cards/${t}/computed_values`,n)},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){return ae(e.listKeys("cards/"),t=>pt(t,n=>e.read(n),n=>Yt(n,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(t){return Me(Object.entries(t),([n,a])=>{if(n)return a===void 0?e.delete(`data-objects/${n}`):e.write(`data-objects/${n}`,a)})},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){return ae(e.listKeys("data-objects/"),t=>pt(t,n=>e.read(n),n=>n.slice(13)))},writeStatusSnapshot(t){return e.write("status",t)},readStatusSnapshot(){return e.read("status")}}}function He(e,t){function n(){return e.readIndex()??{}}function a(o,d,u){let c=String(d||"").split(".").filter(Boolean);if(c.length===0)return u&&typeof u=="object"&&!Array.isArray(u)?u:{value:u};let C={...o},w=C;for(let q=0;q<c.length-1;q++){let X=c[q],Y=w[X],ee=Y&&typeof Y=="object"&&!Array.isArray(Y)?{...Y}:{};w[X]=ee,w=ee;}return w[c[c.length-1]]=u,C}return {readCard(o){let d=n()[o];return !d||!e.cardExists(d.key)?null:e.readCard(d.key)},readCardKey(o){return n()[o]?.key??null},readAllCards(){let o=[];for(let[d,u]of Object.entries(n())){if(!e.cardExists(u.key))continue;let c=e.readCard(u.key);c?o.push(c):t?.(`[card-store] could not read card "${d}" at key "${u.key}"`);}return o},readChecksumIndex(){let o={};for(let[d,u]of Object.entries(n()))o[d]=u.checksum;return o},changedSince(o){let d=n(),u=[];for(let[c,C]of Object.entries(d))o[c]!==C.checksum&&u.push(c);for(let c of Object.keys(o))d[c]||u.push(c);return u},validateUpsert(o,d){let u=n(),c=u[o],C=Object.entries(u).find(([,w])=>w.key===d);return c&&c.key!==d?{ok:false,error:`Card id "${o}" is already mapped to key "${c.key}", cannot remap to "${d}"`}:C&&C[0]!==o?{ok:false,error:`Key "${d}" is already mapped to card id "${C[0]}", cannot remap to "${o}"`}:{ok:true}},writeCard(o,d,u){let c=n(),C=u??c[o]?.key??e.defaultCardKey(o),w=e.writeCard(C,d);c[o]={key:C,checksum:w,updatedAt:new Date().toISOString()},e.writeIndex(c);},patchCard(o,d,u){let c=n(),C=c[o];if(!C||!e.cardExists(C.key))throw new Error(`card "${o}" not found`);let w=e.readCard(C.key);if(!w||typeof w!="object"||Array.isArray(w))throw new Error(`card "${o}" is not patchable`);let q=a(w,d,u),X=e.writeCard(C.key,q);c[o]={key:C.key,checksum:X,updatedAt:new Date().toISOString()},e.writeIndex(c);},removeCard(o){let d=n(),u=d[o];u&&(e.removeCard(u.key),delete d[o],e.writeIndex(d));},readIndex(){return n()}}}function _e(e,t){return gt(e,t)}function yt(e){return mt(e)}var Oe="v1",Re="board/graph",Ct="board/lastJournalProcessedId";function vr(e){return `cards/${e}/runtime`}function bt(e){return ft(e,Oe)}function qe(e){function t(n){let a=e.read(n);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}return {readTaskExecutorRef(){let n=t("task-executor");if(n?.trim())return c$1(n.trim())},writeTaskExecutorRef(n){e.write("task-executor",b$1(n));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(n){e.write("chat-handler-flow",n);},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(n){e.write("board-runtime-store-ref",n);},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(n){e.write("card-store-ref",n);},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(n){e.write("outputs-store-ref",n);},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(n){e.write("queue-store-ref",n);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(n){e.write("scratch-store-ref",n);},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(n){e.write("chat-store-ref",n);},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(n){e.write("artifacts-store-ref",n);},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(n){e.write("fetched-sources-store-ref",n);}}}function wt(e){return St(e)}function kt(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function Zt(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function Rt(e,t){return e?.lastRequestedToken?Zt(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function er(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function ht(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function Pe(e,t){let n=t.state.tasks,a=t.config.tasks,o=Object.keys(n),d=r(t),u={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},c=new Map;for(let k of d.pending)c.set(k.taskName,k.waitingOn);for(let k of d.unresolved)c.set(k.taskName,k.missingTokens);for(let k of d.blocked)c.set(k.taskName,k.failedTokens);let C=new Map;for(let[k,x]of Object.entries(a))for(let G of x.requires??[]){let K=C.get(G)??[];K.push(k),C.set(G,K);}let w=o.sort().map(k=>{let x=n[k],G=a[k]??{requires:[],provides:[]};x.status==="completed"?u.completed+=1:x.status==="failed"?u.failed+=1:x.status==="in-progress"&&(u.in_progress+=1);let K=G.requires??[],p=G.provides??[],i=Object.keys(x.data??{}).sort(),m=K.filter(P=>t.state.availableOutputs.includes(P)),b=K.filter(P=>!t.state.availableOutputs.includes(P)),I=c.get(k)??b,R=new Set;for(let P of p)for(let $ of C.get(P)??[])$!==k&&R.add($);let O=x.failedAt,j=x.error?{message:x.error,code:"TASK_FAILED",at:O,source:"task-runtime"}:void 0;return {name:k,status:x.status,error:j,requires:K,requires_satisfied:m,requires_missing:b,provides_declared:p,provides_runtime:i,blocked_by:I,unblocks:Array.from(R).sort(),runtime:{attempt_count:x.executionCount??0,restart_count:x.retryCount??0,in_progress_since:x.status==="in-progress"?x.startedAt??null:null,last_transition_at:x.lastUpdated??null,last_completed_at:x.completedAt??null,last_restarted_at:x.startedAt??null,status_age_ms:x.lastUpdated?0:null}}});u.pending=d.pending.length,u.blocked=d.blocked.length,u.unresolved=d.unresolved.length;let q=w.map(k=>({name:k.name,fanOut:k.unblocks.length})).sort((k,x)=>x.fanOut-k.fanOut||k.name.localeCompare(x.name)),X=q.length>0?q[0]:{name:null,fanOut:0},Y=new Set;for(let k of Object.values(a))for(let x of k.requires??[])Y.add(x);let ee=0;for(let[k,x]of Object.entries(a)){let G=(x.requires??[]).length===0,p=(x.provides??[]).some(i=>(C.get(i)??[]).some(m=>m!==k));G&&!p&&(ee+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:o.length,completed:u.completed,eligible:d.eligible.length,pending:u.pending,blocked:u.blocked,unresolved:u.unresolved,failed:u.failed,in_progress:u.in_progress,orphan_cards:ee,topology:{edge_count:Array.from(Y).length,max_fan_out_card:X.name,max_fan_out:X.fanOut}},cards:w}}function tr(){return new Date().toISOString()}function vt(e,t,n,a$1,o,d,u){return async c=>{let C=[],w=n.cardStore.readCard(c.nodeId);if(!w)return "task-initiate-failure";let q=w.id,X=w.card_data??{},Y=w.source_defs??[],ee=Y.filter(h=>h.optionalForCompletionGating!==true),k=n.cardRuntimeStore.readRuntime(q),x=false,G=()=>{x&&(n.cardRuntimeStore.writeRuntime(q,k),x=false);},K=h=>kt(k._sources[h]),p=(h,v)=>{k._sources[h]=kt(v),x=true;},i=c.taskState?.executionCount??0;if(k._lastExecutionCount!==i&&(k._sources={},k._lastExecutionCount=i,x=true),c.update){let h=c.update,v=h.outputFile;if(v){let B=K(v);if(h.failure){let M=h.rqt??B.lastRequestedToken??B.queueRequestedToken;M&&p(v,ht(B,M));}else {let M=h.rqt;if(!B.lastCompletedToken||M>B.lastCompletedToken){let V=typeof h.deliveryToken=="string"?h.deliveryToken:void 0,H=false;V&&(H=n.fetchedSourcesStore.commitSourceData(q,v,V)),H?p(v,er(B,M)):p(v,ht(B,M));}}G();}}let b={};for(let h of Y)if(h.outputFile){let v=n.fetchedSourcesStore.readSourceData(q,h.outputFile);v!==null&&(b[h.bindTo]=v);}let I={};for(let[h,v]of Object.entries(c.state??{}))if(v!==null&&typeof v=="object"&&!Array.isArray(v)){let B=v[h];I[h]=B!==void 0?B:v;}else I[h]=v;let R={id:q,card_data:{...X},requires:I,source_defs:Y,compute:w.compute};R._sourcesData=b,w.compute&&a$3.runSync(R,{sourcesData:b}),(d??n.outputStore.writeComputedValues.bind(n.outputStore))(q,R.computed_values??{});let O={...w},j=a$3.enrichSourcesSync(Array.isArray(w.source_defs)?w.source_defs:void 0,{card_data:w.card_data,requires:I}),P=e.value;O.source_defs=Array.isArray(j)?j.map(h=>({...h,boardDir:typeof h.boardDir=="string"&&h.boardDir?h.boardDir:P})):j;let $=tr(),J=c.update?void 0:$,U=ee.filter(h=>{let v=h.outputFile;if(typeof v!="string"||!v)return true;let B=K(v);J&&(B={...B,queueRequestedToken:J},p(v,B));let M=B.queueRequestedToken??B.lastRequestedToken??$,V=Rt(B,M);return V==="in-flight"?false:V==="dispatch"});if(G(),U.length>0){let h=false,v=$;for(let B of U){let M=B.outputFile;if(typeof M!="string"||!M)continue;let V=K(M),H=V.queueRequestedToken??$;p(M,{...V,lastRequestedToken:H}),v=H,h=true;}return h&&G(),h&&(C.push({taskKind:"source-fetch",payload:{boardRef:a(e),enrichedCard:O,callbackToken:c.callbackToken,rqt:v}}),n.executionRequestStore.appendEntries(t,C)),"task-initiated"}if(ee.some(h=>{let v=h.outputFile;if(typeof v!="string"||!v)return false;let B=K(v),M=B.queueRequestedToken??B.lastRequestedToken??$;return Rt(B,M)==="in-flight"}))return "task-initiated";let me=w.provides??[],ie={};for(let{bindTo:h,ref:v}of me)ie[h]=a$3.resolve(R,v);return (u??n.outputStore.writeDataObjects.bind(n.outputStore))(ie),Y.filter(h=>{if(h.optionalForCompletionGating!==true)return false;let v=K(h.outputFile);return !v.lastRequestedToken||!v.lastCompletedToken?true:v.lastCompletedToken<=v.lastRequestedToken}).length>0&&C.push({taskKind:"source-fetch",payload:{boardRef:a(e),enrichedCard:O,callbackToken:c.callbackToken,rqt:$}}),a$1(c.nodeId,ie),C.length>0&&n.executionRequestStore.appendEntries(t,C),"task-initiated"}}var Ge={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function xt(e){return {[Re]:e.graph,[Ct]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function Et(e){let t=e[Re],n=e[Ct],o=e.board?.runtimeByCardId;if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${Re}`);return {graph:t,lastDrainedJournalId:typeof n=="string"?n:"",runtimeByCardId:o&&typeof o=="object"?o:{}}}function Tt(e){let t=e.requires;return {provides:e.provides?.map(a=>a.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...t&&t.length>0?{requires:t}:{}}}function E(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function S(e){return {status:"fail",error:e}}function T(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function rr(e){let t=new TextEncoder().encode(e),n=Array.from(t,a=>String.fromCharCode(a)).join("");return btoa(n).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Ft(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),n=t+"=".repeat((4-t.length%4)%4),a=atob(n),o=Uint8Array.from(a,d=>d.charCodeAt(0));return new TextDecoder().decode(o)}function Be(e){try{let t=JSON.parse(Ft(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function It(e){return rr(JSON.stringify(e))}function At(e){try{let t=JSON.parse(Ft(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function Z(){return new Date().toISOString()}function nr(e){let t=new Map;return {appendEntries(n,a){if(!n||a.length===0)return;let o=t.get(n)??[];t.set(n,[...o,...a]);},dispatchEntriesForJournalId(n,a){if(!n)return;let o=t.get(n);if(!(!o||o.length===0)){for(let d of o)try{a(d);}catch(u){try{e(d,u instanceof Error?u.message:String(u));}catch{}}t.delete(n);}}}}function qr(e,t,n={}){dt(t.callbackTransport,"createBoardLiveCardsPublic");let a$3=t.callbackTransport,o=t.onWarn??(()=>{}),d=a(e),u$1=n.boardRuntimeStoreRef,c$1=n.scratchStoreRef,C=n.taskExecutorRef,w=n.chatHandlerFlow;function q$1(){if(!u$1)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return u$1}function X(s){if(s.length!==0)try{let r=t.publishBoardChangeNotifications?.(s);r&&typeof r.catch=="function"&&r.catch(l=>o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${l instanceof Error?l.message:String(l)}`));}catch(r){o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${r instanceof Error?r.message:String(r)}`);}}function Y(){let s=k().readCardStoreRef();if(!s)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let r=t.kvStorageForRef(s);return {readIndex(){return r.read("_index")},writeIndex(l){r.write("_index",l);},readCard(l){return r.read(l)},writeCard(l,g){return r.write(l,g),t.hashFn(g)},removeCard(l){r.delete(l);},cardExists(l){return r.read(l)!==null},defaultCardKey(l){return l}}}let ee={readValues(s){let r=t.kvStorageForRef(q$1()),l=r.listKeys().sort();if(l.length===0)return {version:null,values:{}};let g={};for(let A of l)g[A]=r.read(A);return {version:t.hashFn(g),values:g}},writeValues(s,r,l){let g=t.kvStorageForRef(q$1());for(let A of l)g.delete(A);for(let[A,F]of Object.entries(r))g.write(A,F);return t.hashFn(r)}},k=()=>qe(t.kvStorageForRef(q$1())),x=()=>bt(ee),G=()=>yt(t.journalAdapterForRef(q$1())),K=()=>He(Y(),o),p$1=()=>{let s=k().readOutputsStoreRef();if(!s)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return wt(t.kvStorageForRef(s))};function i(){return C??k().readTaskExecutorRef()}function m(){return !!x().readSnapshot(e.value).values[Re]}function b$1(){let s=x().readSnapshot(e.value);if(!s.values[Re])throw new Error(`Board not initialized at ${e.value}`);return Et(s.values)}function I(s,r){let l=x().commitSnapshot(e.value,{schemaVersion:Oe,expectedVersion:r,commitId:t.genId(),committedAt:Z(),deleteKeys:[],shallowMerge:xt(s)});if(!l.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${r??"null"} current=${l.currentVersion??"null"}`)}function R(s){G().appendEvent(s);}async function O(){let r=nr((f,y)=>{let _=f.payload,L=(_?.enrichedCard??{}).id??_?.cardId??"unknown";R({type:"task-failed",taskName:L,error:y,timestamp:Z()});}),l=b$1(),g=q(l.graph),{events:A,newCursor:F}=G().readEntriesAfterCursor(l.lastDrainedJournalId),Q=V(),D=_e(Q,f=>t.resolveBlob(f)),W={...l.runtimeByCardId},te=new Map,ge={readRuntime(f){return te.get(f)??W[f]??{_sources:{}}},writeRuntime(f,y){te.set(f,y),W[f]=y;}},Se=[],re=new Map,we={readSourceData(f,y){let _=`${f}/${y}`;return re.has(_)?re.get(_):D.readSourceData(f,y)},ingestSourceDataStaged(f,y,_,se){D.ingestSourceDataStaged(f,y,_,se);},commitSourceData(f,y,_){let se=`${f}/.staged/${_}/${y}`,L=Q.read(se);if(L==null){let z=Q.keyRef?.(se);z&&(L=t.resolveBlob(z));}if(L==null)return false;let ne=`${f}/${y}`,le=L.trim();try{re.set(ne,JSON.parse(le));}catch{re.set(ne,le);}return Se.push({cardId:f,outputFile:y,deliveryToken:_}),true},hasSource(f,y){let _=`${f}/${y}`;return re.has(_)?true:D.hasSource(f,y)},listSources(f){let y=D.listSources(f),_=new Set;for(let L of re.keys())L.startsWith(`${f}/`)&&_.add(L.slice(`${f}/`.length));let se=new Set([...y,..._]);return Array.from(se)}},ce={cardStore:K(),cardRuntimeStore:ge,fetchedSourcesStore:we,outputStore:p$1(),executionRequestStore:r},ke=[],Ve=[],je=[],Ke=new Map,ze=new Set,Ht=(f,y)=>{ke.push({type:"task-completed",taskName:f,data:y,timestamp:Z()});},Le=(f,y)=>{R({type:"task-failed",taskName:f,error:y,timestamp:Z()});},ve=u(g,{handlers:{"card-handler":vt(e,F,ce,Ht,Le,(f,y)=>{Ve.push({cardId:f,values:y});},f=>{je.push(f);})},onNodeRemoved:f=>{Ke.delete(f),te.delete(f),delete W[f],ze.add(f);}});for(ke=A;ke.length>0;){let f=ke;ke=[];for(let y of f)if(y.type==="task-restart"){let _=ce.cardStore.readCard(y.taskName);_&&Ke.set(y.taskName,_);}ve.pushAll(f),await ve.waitForHandlers();}let Ye=ve.getState();await ve.dispose({wait:true});let Gt=x().readSnapshot(e.value).version;I({lastDrainedJournalId:F,graph:p(Ye),runtimeByCardId:W},Gt);for(let{cardId:f,values:y}of Ve)ce.outputStore.writeComputedValues(f,y);for(let f of je)ce.outputStore.writeDataObjects(f);for(let{cardId:f,outputFile:y,deliveryToken:_}of Se)D.commitSourceData(f,y,_);let xe;try{xe=Pe(d,Ye),ce.outputStore.writeStatusSnapshot(xe);}catch(f){o(`[board-live-cards-public] status publish failed: ${f instanceof Error?f.message:String(f)}`);}let he=[];for(let{cardId:f,values:y}of Ve)he.push({kind:"computed_values",cardId:f,values:y});for(let f of je)for(let[y,_]of Object.entries(f))y&&he.push({kind:"data_object",key:y,payload:_});for(let[f,y]of Ke)he.push({kind:"card_refreshed",cardId:f,card:y});for(let f of ze)he.push({kind:"card_removed",cardId:f});xe!==void 0&&he.push({kind:"status",status:xe}),X(he);let ye=i()??{howToRun:"built-in",whatToRun:a({kind:"built-in",value:"source-cli-task-executor"})},Xe=t.supportsDirectSourceOutput?.(ye)===true;r.dispatchEntriesForJournalId(F,f=>{if(f.taskKind!=="source-fetch"){o(`[process-accumulated-events] unknown taskKind "${f.taskKind}" \u2014 skipping`);return}let y=f.payload,_=y.enrichedCard?.id??"unknown",se=y.enrichedCard?.source_defs??[];if(ye.howToRun==="queue-storage"&&Xe){try{let L=t.queueStorageForRef(j(),"task-executor"),ne=typeof ye.extra?.boardId=="string"?ye.extra.boardId:void 0,le=[];for(let z of se){if(!z.outputFile){o(`[dispatch] source "${z.bindTo}" has no outputFile \u2014 skipping`);continue}let Ee=t.genId(),Te=`${_}/.staged/${Ee}/${z.outputFile}`,We=Q.keyRef?.(Te);if(!We)continue;let Ze={ref:a(We),deliveryToken:Ee,outputFile:z.outputFile,cardId:_},Ut=It({cbk:y.callbackToken,rg:e.value,br:a(e),cid:_,b:z.bindTo,d:z.outputFile,cs:void 0,rqt:y.rqt,dt:Ze.deliveryToken});le.push({...ne?{boardId:ne}:{},ref:ye,args:{source_def:z,base_ref:a(e),callback:a$3.createCallback(Ut),output:Ze}});}le.length>0&&L.enqueueMany(le);}catch(L){Le(_,L instanceof Error?L.message:String(L));}return}for(let L of se){if(!L.outputFile){o(`[dispatch] source "${L.bindTo}" has no outputFile \u2014 skipping`);continue}let ne;if(Xe){let z=t.genId(),Ee=`${_}/.staged/${z}/${L.outputFile}`,Te=Q.keyRef?.(Ee);Te&&(ne={ref:a(Te),deliveryToken:z,outputFile:L.outputFile,cardId:_});}let le=It({cbk:y.callbackToken,rg:e.value,br:a(e),cid:_,b:L.bindTo,d:L.outputFile,cs:void 0,rqt:y.rqt,...ne?{dt:ne.deliveryToken}:{}});t.dispatchExecution(ye,{source_def:L,base_ref:a(e),callback:a$3.createCallback(le),...ne?{output:ne}:{}}).catch(z=>Le(_,z instanceof Error?z.message:String(z)));}});}function j(){let s=k().readQueueStoreRef();if(!s)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);return s}function P(){let s=t.queueStorageForRef(j(),"process-accumulated");s.enqueueIfAbsent?s.enqueueIfAbsent({boardRef:a(e)},`process-accumulated:${a(e)}`):s.enqueue({boardRef:a(e)}),t.requestProcessAccumulated?.();}function $(){let s=t.queueStorageForRef(j(),"process-accumulated");for(;;){let r=s.lease({max:64,visibilityMs:1e3});if(r.length<=0)return;for(let l of r)s.ack(l.id,l.leaseToken);if(r.length<64)return}}async function J(){try{let s=()=>{let l=b$1(),{events:g}=G().readEntriesAfterCursor(l.lastDrainedJournalId);g.length<=0||P();},r=await c(t.lock,O,s);return E({ran:r!==!1})}catch(s){return T(s)}}function U(){P();}function de(s){try{let r=s.params?.cardStoreRef;if(!r)return S("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(u$1=s.params?.boardRuntimeStoreRef,!u$1)return S("init requires params.boardRuntimeStoreRef \u2014 pass the board runtime store ref here");if(!m()){let W=a$1(Ge);I({lastDrainedJournalId:"",graph:p(W),runtimeByCardId:{}},null);}let l=s.params?.outputsStoreRef;if(!l)return S("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let g=s.params?.queueStoreRef;if(!g)return S("init requires params.queueStoreRef \u2014 pass the queue store ref here");let A=s.params?.fetchedSourcesStoreRef;if(!A)return S("init requires params.fetchedSourcesStoreRef \u2014 pass the fetched sources store ref here");if(c$1=s.params?.scratchStoreRef,!c$1)return S("init requires params.scratchStoreRef \u2014 pass the scratch store ref here");let F=s.params?.chatStoreRef;if(!F)return S("init requires params.chatStoreRef \u2014 pass the chat store ref here");let Q=s.params?.artifactsStoreRef;if(!Q)return S("init requires params.artifactsStoreRef \u2014 pass the artifacts store ref here");let D=k();D.writeBoardRuntimeStoreRef(u$1),D.writeCardStoreRef(r),D.writeOutputsStoreRef(l),D.writeQueueStoreRef(g),D.writeFetchedSourcesStoreRef(A),D.writeChatStoreRef(F),D.writeArtifactsStoreRef(Q);try{p$1().writeStatusSnapshot(Pe(d,q(b$1().graph)));}catch{}return E()}catch(r){return T(r)}}function me(s){try{let r=p$1().readStatusSnapshot();if(!r){r=Pe(d,q(b$1().graph));try{p$1().writeStatusSnapshot(r);}catch{}}return E(r)}catch(r){return T(r)}}function ie(s){try{let r=s.params?.id;if(!r)return S("removeCard requires params.id");try{t.kvStorage("card-upsert").delete(r);}catch{}return R({type:"task-removal",taskName:r,timestamp:Z()}),U(),E()}catch(r){return T(r)}}function Ce(s){try{let r=s.params?.cardId;if(!r)return S("addCardFiles requires params.cardId");let l=a$2(K()).appendFiles({params:{id:r},body:s.body});if(l.status!=="success")return l;let g=h({params:{cardId:r}});return g.status!=="success"?g:E({cardId:r,files_added:l.data.files_added,notified:!0})}catch(r){return T(r)}}function h(s){try{let r=s.params?.cardId;if(!r)return S("cardRefreshedNotify requires params.cardId");let l=K().readCard(r);return l?(X([{kind:"card_refreshed",cardId:r,card:l}]),E({cardId:r,notified:!0})):S(`Card "${r}" not found in board at ${e.value}`)}catch(r){return T(r)}}function v(s){try{let r=s.params?.id;return r?(R({type:"task-restart",taskName:r,timestamp:Z()}),U(),E()):S("retrigger requires params.id")}catch(r){return T(r)}}async function B(s){return $(),J()}function M(){let s=k().readFetchedSourcesStoreRef();if(!s)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return s}function V(){return t.blobStorageForRef(M())}function H(s){try{let r=s.params?.cardId,l=s.params?.all,g=!!s.params?.restart;if(!r&&!l)return S("upsertCard requires --card-id <id> or --all");let A=l?K().readAllCards().map(F=>F.id):[r];for(let F of A)if(!K().readCard(F))return S(`Card "${F}" not found in board at ${e.value}`);for(let F of A){let Q=K().readCard(F),D=Tt(Q),W=t.hashFn(D),te=t.kvStorage("card-upsert"),ge=te.read(F),Se=ge?.taskConfigHash!==W;if(!(!Se&&!g)){if(Se){let re=ge?.blobRef??K().readCardKey(F)??F;R({type:"task-upsert",taskName:F,taskConfig:D,timestamp:Z()}),te.write(F,{blobRef:re,taskConfigHash:W,updatedAt:Z()});}g&&R({type:"task-restart",taskName:F,timestamp:Z()});}}return U(),E()}catch(r){return T(r)}}function oe(s){try{let r=s.params?.token;if(!r)return S("taskFailed requires params.token");let l=s.params?.error??"unknown error",g=Be(r);return g?(R({type:"task-failed",taskName:g.taskName,error:l,timestamp:Z()}),U(),E()):S("Invalid callback token")}catch(r){return T(r)}}function pe(s){try{let r=s.params?.token;if(!r)return S("taskProgress requires params.token");let g=(s.body??{}).update??{},A=Be(r);return A?(R({type:"task-progress",taskName:A.taskName,update:g,timestamp:Z()}),U(),E()):S("Invalid callback token")}catch(r){return T(r)}}function be(s){try{let r=s.params?.token,l=s.params?.ref;if(!r)return S("sourceDataFetched requires params.token");if(!l)return S("sourceDataFetched requires params.ref");let g=At(r);if(!g)return S("Invalid source token");let{cbk:A,cid:F,b:Q,d:D,cs:W,rqt:te,dt:ge}=g,Se=_e(V(),ke=>t.resolveBlob(ke)),re=ge||t.genId();ge||Se.ingestSourceDataStaged(F,D,b(l),re);let we=Be(A);if(!we)return S("Invalid callback token embedded in source token");let ce=Z();return R({type:"task-progress",taskName:we.taskName,update:{bindTo:Q,outputFile:D,fetchedAt:ce,deliveryToken:re,sourceChecksum:W,rqt:te},timestamp:ce}),U(),E()}catch(r){return T(r)}}function ue(s){try{let r=s.params?.token,l=s.params?.reason??"unknown";if(!r)return S("sourceDataFetchFailure requires params.token");let g=At(r);if(!g)return S("Invalid source token");let{cbk:A,b:F,d:Q,cs:D,rqt:W}=g,te=Be(A);return te?(R({type:"task-progress",taskName:te.taskName,update:{bindTo:F,outputFile:Q,failure:!0,reason:l,sourceChecksum:D,rqt:W},timestamp:Z()}),U(),E()):S("Invalid callback token embedded in source token")}catch(r){return T(r)}}function _t(s){try{let r=k().readCardStoreRef();return r?E({storeRef:r}):S(`Board at ${e.value} has no card store configured`)}catch(r){return T(r)}}function Ot(s){try{return E({storeRef:u$1??null})}catch(r){return T(r)}}function qt(s){try{let r=k().readOutputsStoreRef();return r?E({storeRef:r}):S(`Board at ${e.value} has no outputs store configured`)}catch(r){return T(r)}}function Pt(s){try{return E({storeRef:c$1??null})}catch(r){return T(r)}}function Bt(s){try{let r=k().readChatStoreRef();return E({storeRef:r})}catch(r){return T(r)}}function Vt(s){try{let r=k().readArtifactsStoreRef();return E({storeRef:r})}catch(r){return T(r)}}function jt(s){try{let r=k().readFetchedSourcesStoreRef();return E({storeRef:r})}catch(r){return T(r)}}function Kt(s){try{let r=s.params?.key;if(!r)return S("getConfig requires params.key");let l=k(),g;switch(r){case "task-executor":g=C??null;break;case "chat-handler-flow":g=w??null;break;case "board-runtime-store-ref":g=l.readBoardRuntimeStoreRef();break;case "card-store-ref":g=l.readCardStoreRef();break;case "outputs-store-ref":g=l.readOutputsStoreRef();break;case "scratch-store-ref":g=c$1??null;break;case "chat-store-ref":g=l.readChatStoreRef();break;case "artifacts-store-ref":g=l.readArtifactsStoreRef();break;case "fetched-sources-store-ref":g=l.readFetchedSourcesStoreRef();break;default:return S(`getConfig: unknown key "${r}"`)}return E({value:g})}catch(r){return T(r)}}function Lt(s){try{let r=s.params?.key;if(!r)return S("getOutputsDataObject requires params.key");let l=p$1().readDataObject(r);return E(l)}catch(r){return T(r)}}function $t(s){try{return E(p$1().readAllDataObjects())}catch(r){return T(r)}}function Dt(s){try{let r=s.params?.key;if(!r)return S("getOutputsComputedValues requires params.key");let l=p$1().readComputedValues(r);return E(l)}catch(r){return T(r)}}function Nt(s){try{return E(p$1().readAllComputedValues())}catch(r){return T(r)}}function Ue(){return _e(V(),s=>t.resolveBlob(s))}function Qe(s){let r=V().keyRef?.(s);if(!r)throw new Error("configured fetched-sources store does not support keyRef");return a(r)}function Jt(s){try{let r=s.params?.key;if(!r)return S("getOutputsFetchedSources requires params.key");let l=Ue().listSources(r),g={};for(let A of l)g[A]=Qe(`${r}/${A}`);return E(g)}catch(r){return T(r)}}function Mt(s){try{let r=Ue(),l=new Set;for(let A of V().listKeys()){let F=A.indexOf("/");F>0&&!A.includes("/.staged/")&&l.add(A.slice(0,F));}let g={};for(let A of l){let F=r.listSources(A);if(F.length>0){g[A]={};for(let Q of F)g[A][Q]=Qe(`${A}/${Q}`);}}return E(g)}catch(r){return T(r)}}return {init:de,status:me,getBoardRuntimeStoreRef:Ot,getCardStoreRef:_t,getOutputsStoreRef:qt,getScratchStoreRef:Pt,getChatStoreRef:Bt,getArtifactsStoreRef:Vt,getFetchedSourcesStoreRef:jt,getConfig:Kt,getOutputsDataObject:Lt,getAllOutputsDataObjects:$t,getOutputsComputedValues:Dt,getAllOutputsComputedValues:Nt,getOutputsFetchedSources:Jt,getAllOutputsFetchedSources:Mt,removeCard:ie,addCardFiles:Ce,cardRefreshedNotify:h,retrigger:v,processAccumulatedEvents:B,upsertCard:H,taskFailed:oe,taskProgress:pe,sourceDataFetched:be,sourceDataFetchFailure:ue}}function Pr(e,t,n){let a=n?.taskExecutorRef,o=()=>{if(n){if(!n.boardRuntimeStoreRef)throw new Error(`Board at ${e.value} requires boardRuntimeStoreRef for non-core runtime operations.`);return qe(t.kvStorageForRef(n.boardRuntimeStoreRef))}return qe(t.kvStorage("config"))};function d(){let p=o().readCardStoreRef();if(!p)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let i=t.kvStorageForRef(p);return {readIndex(){return i.read("_index")},writeIndex(m){i.write("_index",m);},readCard(m){return i.read(m)},writeCard(m,b){return i.write(m,b),t.hashFn(b)},removeCard(m){i.delete(m);},cardExists(m){return i.read(m)!==null},defaultCardKey(m){return m}}}let u=()=>He(d(),t.onWarn??(()=>{}));function c(){return a??o().readTaskExecutorRef()}async function C(p,i){let m=t.validateSchema(i),b=[],I=c();if(I&&Array.isArray(i.source_defs))for(let O of i.source_defs){let j=typeof O.bindTo=="string"?O.bindTo:"(unknown)";try{let P;try{P=await t.invokeExecutor(I,"validate-source-def",{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(O)});}catch(J){let U=J;if(P=typeof U?.stdout=="string"?U.stdout:"",!P.trim()){b.push(`source "${j}": executor validate-source-def failed \u2014 ${J instanceof Error?J.message:String(J)}`);continue}}let $=JSON.parse(P.trim());if(!$.ok&&Array.isArray($.errors))for(let J of $.errors)b.push(`source "${j}": ${J}`);}catch(P){b.push(`source "${j}": executor validate-source-def failed \u2014 ${P instanceof Error?P.message:String(P)}`);}}let R=[...m.errors,...b];return E({cardId:p,isValid:R.length===0,issues:R})}function w(p,i){let m=p.params?.sourceIdx,b=p.params?.outRef;if(m===void 0)return S(`${i} requires params.sourceIdx`);if(!p.body||typeof p.body!="object"||Array.isArray(p.body))return S(`${i} requires card JSON object in body`);let I=p.body,R=I["card-content"]??I,O=I["mock-projections"]??{},j=R.source_defs??[];if(m<0||m>=j.length)return S(`sourceIdx ${m} out of range (card has ${j.length} source(s))`);let P=j[m],$=typeof P.bindTo=="string"?P.bindTo:"source";return {src:P,bindTo:$,outRef:b,mockProjections:O}}async function q(p){try{if(!p.body||typeof p.body!="object"||Array.isArray(p.body))return S("validateCardPreflight requires card JSON object in body");let i=p.body,m=i["card-content"]??i,b=typeof m.id=="string"?m.id:"(unknown)";return await C(b,m)}catch(i){return T(i)}}async function X(p){try{let i=w(p,"probeSourcePreflight");if("status"in i)return i;let m=c();if(!m)return S("No task-executor registered for this board");try{let b={...i.src,_projections:i.mockProjections},I=await t.invokeExecutor(m,"probe-source-preflight",{timeout:i.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(b)}),R=JSON.parse(I.trim());return R.ok?E({bindTo:i.bindTo,reachable:R.reachable,latencyMs:R.latencyMs,note:R.note}):S(R.error??"Preflight probe failed")}catch{return S("Executor does not support probe-source-preflight")}}catch(i){return T(i)}}async function Y(p){try{let i=w(p,"runSourcePreflight");if("status"in i)return i;let m=c();if(!m)return S("No task-executor registered for this board");try{let b$1={...i.src,_projections:i.mockProjections},I=await t.invokeExecutor(m,"run-source-preflight",{timeout:i.src.timeout??t.executorTimeouts?.probeMs??6e4,input:JSON.stringify(b$1)}),R=JSON.parse(I.trim());if(!R.ok)return E({bindTo:i.bindTo,ok:!1,result:null,issues:[R.error??"Preflight run failed"]});if(i.outRef){let O=b(i.outRef);t.absoluteBlob.write(O.value,JSON.stringify(R.resultValue,null,2));}return E({bindTo:typeof R.bindTo=="string"?R.bindTo:i.bindTo,ok:!0,result:R.resultValue??null,issues:[]})}catch(b){let I=b instanceof Error?b.message:String(b);return E({bindTo:i.bindTo,ok:!1,result:null,issues:[I]})}}catch(i){return T(i)}}async function ee(p){try{let i=c();if(!i)return S("No task-executor registered for this board");let m=await t.invokeExecutor(i,"describe-capabilities",{timeout:t.executorTimeouts?.describeMs??1e4});return E(JSON.parse(m.trim()))}catch(i){return T(i)}}function k(p){try{let i=p.body;if(!i||!Array.isArray(i.ops))return S("updatesInCardStore requires body.ops array");let m=i.ops,b=u();for(let I of m){let R=I.op,O=I.id;if(!O)return S('op is missing "id"');if(R==="update"){let j=I["card-content"];if(!j)return S(`update op for "${O}" is missing "card-content"`);b.writeCard(O,j);}else return S(`Unknown op type: "${R??"(none)"}"`)}return E()}catch(i){return T(i)}}function x(p){try{let i=p.body;if(!i||!Array.isArray(i.ids))return S("readFromCardStore requires body.ids array");let m=i.ids,b=u(),I=m.map(R=>({id:R,"card-content":b.readCard(R)}));return E({cards:I})}catch(i){return T(i)}}function G(p){try{if(!p.body||typeof p.body!="object"||Array.isArray(p.body))return S("evalCardCompute requires a JSON object in body");let i=p.body,m=i["card-content"]??i,b=typeof m.id=="string"?m.id:"(unknown)",I=i["mock-fetched-sources"]??{},R=i["mock-requires"]??{},O=m.compute;if(!O||!Array.isArray(O)||O.length===0)return E({cardId:b,ok:!0,computed_values:{},errors:[]});let j={id:b,card_data:m.card_data??{},requires:R,source_defs:m.source_defs,compute:O},P=a$3.runSync(j,{sourcesData:I}),$=P.node.computed_values??{},J=P.errors??[];return E({cardId:b,ok:J.length===0,computed_values:$,errors:J})}catch(i){return T(i)}}async function K(p){try{if(!p.body||typeof p.body!="object"||Array.isArray(p.body))return S("simulateCardCycle requires a JSON object in body");let i=p.body,m=i["card-content"]??i,b=typeof m.id=="string"?m.id:"(unknown)",I=i["mock-fetched-sources"]??{},R=i["mock-requires"]??{},O=await C(b,m),j=O.status==="success"?{isValid:O.data.isValid,issues:O.data.issues}:{isValid:!1,issues:[O.status==="fail"?O.error:"internal error"]},P=m.source_defs??[],$=m.card_data??{},J=[],U=[];if(P.length>0){J=a$3.enrichSourcesSync(P,{card_data:$,requires:R});for(let V of J){let H=V.projections,oe=V._projections;if(H&&oe){for(let pe of Object.keys(H))if(oe[pe]===void 0){let be=typeof V.bindTo=="string"?V.bindTo:"(unknown)";U.push({bindTo:be,key:pe,error:`Projection "${pe}" resolved to undefined`});}}}}let de=[],me={...I},ie=i["task-executor-ref"],Ce=(ie?.howToRun&&ie?.whatToRun?ie:void 0)??c();for(let V=0;V<J.length;V++){let H=J[V],oe=typeof H.bindTo=="string"?H.bindTo:`source_${V}`;if(!Ce){de.push({bindTo:oe,skipped:!0,error:"No task executor configured"});continue}try{let pe={...H},be=await t.invokeExecutor(Ce,"run-source-preflight",{timeout:H.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(pe)}),ue=JSON.parse(be.trim());ue.ok&&!Object.prototype.hasOwnProperty.call(I,oe)&&Object.prototype.hasOwnProperty.call(ue,"resultValue")&&(me[oe]=ue.resultValue),de.push({bindTo:oe,reachable:ue.reachable,latencyMs:ue.latencyMs,error:ue.ok?void 0:ue.error});}catch{de.push({bindTo:oe,skipped:!0,error:"Executor does not support run-source-preflight"});}}let h=m.compute,v={},B=[];if(h&&Array.isArray(h)&&h.length>0){let V={id:b,card_data:$,requires:R,source_defs:m.source_defs,compute:h},H=a$3.runSync(V,{sourcesData:me});v=H.node.computed_values??{},B=H.errors??[];}let M=j.isValid&&U.length===0&&B.length===0&&de.every(V=>V.reachable!==!1);return E({cardId:b,ok:M,validation:j,source_probes:de,projection_errors:U,fetched_sources:me,computed_values:v,compute_errors:B})}catch(i){return T(i)}}return {validateCardPreflight:q,probeSourcePreflight:X,runSourcePreflight:Y,evalCardCompute:G,simulateCardCycle:K,describeTaskExecutorCapabilities:ee,updatesInCardStore:k,readFromCardStore:x}}
|
|
2
|
+
export{pr as a,ft as b,gr as c,dt as d,cr as e,lr as f,fr as g,gt as h,Xt as i,Wt as j,St as k,He as l,Oe as m,Re as n,vr as o,kt as p,Rt as q,er as r,ht as s,Pe as t,Ge as u,xt as v,Et as w,Tt as x,qr as y,Pr as z};//# sourceMappingURL=chunk-DOFNXJ4C.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-DOFNXJ4C.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk37HDEW26_cjs=require('./chunk-37HDEW26.cjs');function l(e,r){return r?{...e,...r.pollIntervalMs!=null?{pollIntervalMs:r.pollIntervalMs}:{},...r.visibilityMs!=null?{visibilityMs:r.visibilityMs}:{},...r.concurrency!=null?{concurrency:r.concurrency}:{},...r.maxAttempts!=null?{maxAttempts:r.maxAttempts}:{}}:e}function f(e,r,u,s){return {id:e,async lease(o){return (await Promise.resolve(r.leaseRequests(o))).map(t=>({id:t.messageId,attempt:t.attempt,message:t.request,ack:()=>Promise.resolve(r.ackRequest(t.messageId,t.leaseToken)),nack:a=>Promise.resolve(r.nackRequest(t.messageId,t.leaseToken,a))}))},async handle(o){await u(o.args,o);},onError:s?(o,i)=>s(o,i.attempt,i.message):void 0}}function R(e,r,u,s){return {id:e,async lease(o){return (await Promise.resolve(r.lease(o))).map(t=>({id:t.id,attempt:t.attempt,message:t.body,ack:()=>Promise.resolve(r.ack(t.id,t.leaseToken)),nack:a=>Promise.resolve(r.nack(t.id,t.leaseToken,a))}))},async handle(){await u();},onError:s?(o,i)=>s(o,i.attempt):void 0}}function Q(e){let r=e.logger??{info(){},warn(){},error(){}},u=e.boardAdapter,s=e.runtime.queueLaneTuning??{},o=u.queueStorageForRef(e.queueStoreRef,"process-accumulated"),i=chunkBQUQTOPB_cjs.a(u)?chunk37HDEW26_cjs.a(u.queueStorageForRef(e.queueStoreRef,"chat-agent")):chunkGPCMBPLK_cjs.a(u.queueStorageForRef(e.queueStoreRef,"chat-agent")),t=[];if(t.push(l(R("process-accumulated",o,async()=>{let a=await e.runtime.__drainProcessAccumulatedLane();if(a.status!=="success")throw new Error(a.error||`__drainProcessAccumulatedLane returned ${a.status}`)},(a,n)=>{r.error(`[board-server] queued process-accumulated failed for ${e.boardId} (attempt ${n}): ${String(a&&a.message||a)}`);}),s.processAccumulated)),t.push(l(f("chat-agent",i,async(a,n)=>{await e.runtime.handleChatAgentRequest(n);},(a,n,c)=>{let p=typeof c.args?.cardId=="string"?c.args.cardId:"";r.error(`[board-server] queued chat-agent failed for ${e.boardId}${p?`/${p}`:""} (attempt ${n}): ${String(a&&a.message||a)}`);}),s.chatAgent)),e.executeTaskExecutorRequest){let a=chunkBQUQTOPB_cjs.a(u)?chunk37HDEW26_cjs.a(u.queueStorageForRef(e.queueStoreRef,"task-executor")):chunkGPCMBPLK_cjs.a(u.queueStorageForRef(e.queueStoreRef,"task-executor"));t.push(l(f("task-executor",a,e.executeTaskExecutorRequest,(n,c)=>{r.error(`[board-server] queued board-worker failed for ${e.boardId} (attempt ${c}): ${String(n&&n.message||n)}`);}),s.taskExecutor));}return chunkGPCMBPLK_cjs.b(t)}exports.a=Q;//# sourceMappingURL=chunk-ETW3BXHD.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-ETW3BXHD.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {b}from'./chunk-
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {b}from'./chunk-44L64VQ2.js';function p(t){return typeof t.journalStorage=="function"}function s(t){return typeof t.whatToRun=="string"?t.whatToRun.startsWith("b64:")?b(t.whatToRun).value:t.whatToRun:t.whatToRun.value}function c(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function f(t){let a=t.reduce((r,u)=>r+u.length,0),o=new Uint8Array(a),n=0;for(let r of t)o.set(r,n),n+=r.length;return o}export{p as a,s as b,c,f as d};//# sourceMappingURL=chunk-FOFGEABN.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-FOFGEABN.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';function a(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function n(e){return {...a(e),leaseToken:e.leaseToken,leaseExpiresAt:e.leaseExpiresAt}}function u(e){return {...a(e),reason:e.reason}}function o(e){return {enqueueRequest(r){return e.enqueue(r).id},enqueueRequestIfAbsent:e.enqueueIfAbsent?(r,t)=>{let s=e.enqueueIfAbsent(r,t);return s?s.id:null}:void 0,leaseRequests(r){return e.lease(r).map(n)},ackRequest(r,t){return e.ack(r,t)},nackRequest(r,t,s){return e.nack(r,t,s)},peekActive(){return e.peekActive().map(a)},peekDeadLetter(){return e.peekDeadLetter().map(u)}}}function d(e){return {lanes:e}}exports.a=o;exports.b=d;//# sourceMappingURL=chunk-GPCMBPLK.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-GPCMBPLK.cjs.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {b as b$2}from'./chunk-NNSBBO5R.js';import {b,a}from'./chunk-HEEDJEKM.js';import {a as a$1,d,x as x$1,t,u,n,w,v as v$1,k,b as b$3,c,h as h$1,i,j,o,s,r,q as q$1,p as p$1}from'./chunk-DOFNXJ4C.js';import {a as a$2,b as b$1}from'./chunk-44L64VQ2.js';import {q,p,a as a$3,u as u$1}from'./chunk-VGT3TRQG.js';import {a as a$4}from'./chunk-JMDHDY6M.js';async function Ye(r,a,u){let i=await r.tryAcquire();if(!i)return false;try{await a();}finally{await i();}return await u?.(),true}function Xe(r){return b(r)}function Ze(r,a){return {async readIndex(){return await r.read("_index")},writeIndex(u){return r.write("_index",u)},async readCard(u){return await r.read(u)},async writeCard(u,i){return await r.write(u,i),a(i)},removeCard(u){return r.delete(u)},async cardExists(u){return await r.read(u)!==null},defaultCardKey(u){return u}}}function et(r,a$1){async function u(){return await r.readIndex()??{}}return {async readCard(i){let p=(await u())[i];return !p||!await r.cardExists(p.key)?null:await r.readCard(p.key)},async readCardKey(i){return (await u())[i]?.key??null},async readAllCards(){let i=[];for(let[p,S]of Object.entries(await u())){if(!await r.cardExists(S.key))continue;let c=await r.readCard(S.key);c?i.push(c):a$1?.(`[card-store] could not read card "${p}" at key "${S.key}"`);}return i},async readChecksumIndex(){let i={};for(let[p,S]of Object.entries(await u()))i[p]=S.checksum;return i},async changedSince(i){let p=await u(),S=[];for(let[c,C]of Object.entries(p))i[c]!==C.checksum&&S.push(c);for(let c of Object.keys(i))p[c]||S.push(c);return S},async validateUpsert(i,p){let S=await u(),c=S[i],C=Object.entries(S).find(([,P])=>P.key===p);return c&&c.key!==p?{ok:false,error:`Card id "${i}" is already mapped to key "${c.key}", cannot remap to "${p}"`}:C&&C[0]!==i?{ok:false,error:`Key "${p}" is already mapped to card id "${C[0]}", cannot remap to "${i}"`}:{ok:true}},async writeCard(i,p,S){let c=await u(),C=S??c[i]?.key??r.defaultCardKey(i),P=await r.writeCard(C,p);c[i]={key:C,checksum:P,updatedAt:new Date().toISOString()},await r.writeIndex(c);},async patchCard(i,p,S){let c=await u(),C=c[i];if(!C||!await r.cardExists(C.key))throw new Error(`card "${i}" not found`);let P=await r.readCard(C.key);if(!P||typeof P!="object"||Array.isArray(P))throw new Error(`card "${i}" is not patchable`);let B=String(p||"").split(".").filter(Boolean),te=a(P,B,S),E=await r.writeCard(C.key,te);c[i]={key:C.key,checksum:E,updatedAt:new Date().toISOString()},await r.writeIndex(c);},async removeCard(i){let p=await u(),S=p[i];S&&(await r.removeCard(S.key),delete p[i],await r.writeIndex(p));},readIndex(){return u()}}}function Rt(r,a){return a$1(r,a)}function kt(r,a,u){return {blob:r,kv:a,journal:u}}function h(r){return r!==void 0?{status:"success",data:r}:{status:"success"}}function f(r){return {status:"fail",error:r}}function v(r){return {status:"error",error:r instanceof Error?r.message:String(r)}}function x(){return new Date().toISOString()}function ut(r){let a=new TextEncoder().encode(r),u=Array.from(a,i=>String.fromCharCode(i)).join("");return btoa(u).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function nt(r){let a=r.replace(/-/g,"+").replace(/_/g,"/"),u=a+"=".repeat((4-a.length%4)%4),i=atob(u),p=Uint8Array.from(i,S=>S.charCodeAt(0));return new TextDecoder().decode(p)}function ge(r){try{let a=JSON.parse(nt(r));return typeof a?.t=="string"?{taskName:a.t}:null}catch{return null}}function tt(r){return ut(JSON.stringify(r))}function rt(r){try{let a=JSON.parse(nt(r));return typeof a?.cbk=="string"&&typeof a?.cid=="string"&&typeof a?.b=="string"&&typeof a?.d=="string"?a:null}catch{return null}}function dt(r){return j(r,o,()=>({_sources:{}}))}function ct(r,a){return h$1(r,a)}function mt(r){return k(r)}function lt(r,a){return i(r,a)}function ft(r$1,a,u,i,p,S){return async c=>{let C=[],P=await u.cardStore.readCard(c.nodeId);if(!P)return "task-initiate-failure";let B=P.id,te=P.card_data??{},E=P.source_defs??[],re=E.filter(m=>m.optionalForCompletionGating!==true),b=await u.cardRuntimeStore.readRuntime(B),D=false,V=async()=>{D&&(await u.cardRuntimeStore.writeRuntime(B,b),D=false);},T=m=>p$1(b._sources[m]),K=(m,l)=>{b._sources[m]=p$1(l),D=true;},oe=c.taskState?.executionCount??0;if(b._lastExecutionCount!==oe&&(b._sources={},b._lastExecutionCount=oe,D=true),c.update){let m=c.update.outputFile;if(m){let l=T(m);if(c.update.failure){let R=c.update.rqt??l.lastRequestedToken??l.queueRequestedToken;R&&K(m,s(l,R));}else {let R=c.update.rqt;if(!l.lastCompletedToken||R>l.lastCompletedToken){let t=typeof c.update.deliveryToken=="string"?c.update.deliveryToken:void 0,e=t?await u.fetchedSourcesStore.commitSourceData(B,m,t):false;K(m,e?r(l,R):s(l,R));}}await V();}}let L={};for(let m of E){if(!m.outputFile)continue;let l=await u.fetchedSourcesStore.readSourceData(B,m.outputFile);l!==null&&(L[m.bindTo]=l);}let U={};for(let[m,l]of Object.entries(c.state??{}))if(l!==null&&typeof l=="object"&&!Array.isArray(l)){let R=l[m];U[m]=R!==void 0?R:l;}else U[m]=l;let J={id:B,card_data:{...te},requires:U,source_defs:E,compute:P.compute};J._sourcesData=L,P.compute&&a$4.runSync(J,{sourcesData:L}),(p??(()=>{}))(B,J.computed_values??{});let ne=a$4.enrichSourcesSync(Array.isArray(P.source_defs)?P.source_defs:void 0,{card_data:P.card_data,requires:U}),F={...P,source_defs:Array.isArray(ne)?ne.map(m=>({...m,boardDir:typeof m.boardDir=="string"&&m.boardDir?m.boardDir:r$1.value})):ne},M=x(),G=c.update?void 0:M,W=re.filter(m=>{let l=m.outputFile;if(typeof l!="string"||!l)return true;let R=T(l);G&&(R={...R,queueRequestedToken:G},K(l,R));let t=R.queueRequestedToken??R.lastRequestedToken??M;return q$1(R,t)==="dispatch"});if(await V(),W.length>0){let m=false,l=M;for(let R of W){let t=R.outputFile;if(typeof t!="string"||!t)continue;let e=T(t),s=e.queueRequestedToken??M;K(t,{...e,lastRequestedToken:s}),l=s,m=true;}return m&&await V(),m&&(C.push({taskKind:"source-fetch",payload:{boardRef:a$2(r$1),enrichedCard:F,callbackToken:c.callbackToken,rqt:l}}),await u.executionRequestStore.appendEntries(a,C)),"task-initiated"}if(re.some(m=>{let l=m.outputFile;if(typeof l!="string"||!l)return false;let R=T(l),t=R.queueRequestedToken??R.lastRequestedToken??M;return q$1(R,t)==="in-flight"}))return "task-initiated";let ye=P.provides??[],ae={};for(let{bindTo:m,ref:l}of ye)ae[m]=a$4.resolve(J,l);return (S??(()=>{}))(ae),E.filter(m=>{if(m.optionalForCompletionGating!==true)return false;let l=T(m.outputFile);return !l.lastRequestedToken||!l.lastCompletedToken?true:l.lastCompletedToken<=l.lastRequestedToken}).length>0&&C.push({taskKind:"source-fetch",payload:{boardRef:a$2(r$1),enrichedCard:F,callbackToken:c.callbackToken,rqt:M}}),i(c.nodeId,ae),C.length>0&&await u.executionRequestStore.appendEntries(a,C),"task-initiated"}}function Et(r,a,u$2={}){d(a.callbackTransport,"createAsyncBoardLiveCardsPublic");let i=a.callbackTransport,p$1=a.warn??(()=>{}),S=a$2(r),c$1=null,C=u$2.boardRuntimeStoreRef,P=u$2.scratchStoreRef,B=u$2.taskExecutorRef,te=u$2.chatHandlerFlow;function E(){if(!C)throw new Error(`Board at ${r.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return C}function re(t){if(t.length!==0)try{return Promise.resolve(a.publishBoardChangeNotifications?.(t)).catch(e=>{p$1(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${e instanceof Error?e.message:String(e)}`);})}catch(e){p$1(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${e instanceof Error?e.message:String(e)}`);return}}let b=()=>b$2(a.kvStorageForRef(E())),D=r.value,V=()=>b$3(a$1(()=>a.kvStorageForRef(E()),a.hashFn),"v1"),T=async()=>{let t=await b().readOutputsStoreRef();if(!t)throw new Error(`Board at ${r.value} has no outputs store configured.`);return mt(a.kvStorageForRef(t))},K=async()=>{let t=await b().readCardStoreRef();if(!t)throw new Error(`Board at ${r.value} has no card store configured.`);let e=a.kvStorageForRef(t);return et(Ze(Xe(e),a.hashFn),p$1)};async function oe(){return !!(await V().readSnapshot(D)).values[n]}async function L(){let t=await V().readSnapshot(D);if(!t.values[n])throw new Error(`Board not initialized at ${r.value}`);return w(t.values)}async function U(t,e){let s=await V().commitSnapshot(D,{schemaVersion:"v1",expectedVersion:e,deleteKeys:[],shallowMerge:v$1(t)});if(!s.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${e??"null"} current=${s.currentVersion??"null"}`)}let J=()=>c(a.journalStorageForRef(E()));async function ne(){return B??await b().readTaskExecutorRef()}async function F(t){await J().appendEvent(t);}async function M(){let t=await b().readFetchedSourcesStoreRef();if(!t)throw new Error(`Board at ${r.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return t}async function G(){return a.blobStorageForRef(await M())}async function W(){return ct(await G(),t=>a.resolveBlob(t))}async function pe(t){let e=(await G()).keyRef?.(t);if(!e)throw new Error("configured fetched-sources store does not support keyRef");let s=await Promise.resolve(e);return a$2(s)}async function ye(){let t$1=lt(a.kvStorageForRef(E()),async(o,d)=>{let k=o.payload,I=(k.enrichedCard??{}).id??k.cardId??"unknown";await F({type:"task-failed",taskName:I,error:d,timestamp:x()});}),e=dt(a.kvStorageForRef(E())),s=await G(),n=await W(),y=await K(),w=await T(),A=new Map,g=new Map,z=[],Q=[],$=[],H=new Map,Y=new Set,Re={async readRuntime(o){return A.get(o)??await e.readRuntime(o)},async writeRuntime(o,d){A.set(o,d),Se[o]=d;}},at={async readSourceData(o,d){let k=`${o}/${d}`;return g.has(k)?g.get(k):await n.readSourceData(o,d)},ingestSourceDataStaged(o,d,k,O){return n.ingestSourceDataStaged(o,d,k,O)},async commitSourceData(o,d,k){let O=`${o}/.staged/${k}/${d}`,I=await s.read(O);if(I==null){let j=await Promise.resolve(s.keyRef?.(O));j&&(I=await a.resolveBlob(j));}if(I==null)return false;let _=`${o}/${d}`,Z=I.trim();try{g.set(_,JSON.parse(Z));}catch{g.set(_,Z);}return z.push({cardId:o,outputFile:d,deliveryToken:k}),true},async hasSource(o,d){let k=`${o}/${d}`;return g.has(k)||await n.hasSource(o,d)},async listSources(o){let d=await n.listSources(o),k=[...g.keys()].filter(O=>O.startsWith(`${o}/`)).map(O=>O.slice(`${o}/`.length));return [...new Set([...d,...k])]}},ke=await L(),ot=q(ke.graph),Se={...ke.runtimeByCardId},{events:st,newCursor:Ce}=await J().readEntriesAfterCursor(ke.lastDrainedJournalId),se=st,ie=u$1(ot,{handlers:{"card-handler":ft(r,Ce,{cardStore:y,cardRuntimeStore:Re,fetchedSourcesStore:at,executionRequestStore:t$1},(o,d)=>{se.push({type:"task-completed",taskName:o,data:d,timestamp:x()});},(o,d)=>{Q.push({cardId:o,values:d});},o=>{$.push(o);})},onNodeRemoved:o=>{H.delete(o),A.delete(o),delete Se[o],Y.add(o);}});for(;se.length>0;){let o=se;se=[];for(let d of o)if(d.type==="task-restart"){let k=await y.readCard(d.taskName);k&&H.set(d.taskName,k);}ie.pushAll(o),await ie.waitForHandlers();}let Ie=ie.getState();await ie.dispose({wait:true}),await U({lastDrainedJournalId:Ce,graph:p(Ie),runtimeByCardId:Se},(await V().readSnapshot(D)).version);for(let{cardId:o,values:d}of Q)await w.writeComputedValues(o,d);for(let o of $)await w.writeDataObjects(o);for(let[o,d]of A)await e.writeRuntime(o,d);for(let o of z)await n.commitSourceData(o.cardId,o.outputFile,o.deliveryToken);let xe=t(S,Ie);await w.writeStatusSnapshot(xe);let ee=[];for(let{cardId:o,values:d}of Q)ee.push({kind:"computed_values",cardId:o,values:d});for(let o of $)for(let[d,k]of Object.entries(o))ee.push({kind:"data_object",key:d,payload:k});for(let[o,d]of H)ee.push({kind:"card_refreshed",cardId:o,card:d});for(let o of Y)ee.push({kind:"card_removed",cardId:o});ee.push({kind:"status",status:xe}),await re(ee);let X=await ne();if(!X)return;let Fe=a.supportsDirectSourceOutput?.(X)===true;await t$1.dispatchEntriesForJournalId(Ce,async o=>{if(o.taskKind!=="source-fetch"){p$1(`[async-process-accumulated-events] unknown taskKind "${o.taskKind}" \u2014 skipping`);return}let d=o.payload,k=d.enrichedCard?.id??"unknown",O=d.enrichedCard?.source_defs??[];if(X.howToRun==="queue-storage"&&Fe){try{let I=await b().readQueueStoreRef();if(!I)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let _=a.queueStorageForRef(I,"task-executor"),Z=typeof X.extra?.boardId=="string"?X.extra.boardId:void 0,j=[];for(let N of O){if(!N.outputFile)continue;let ue=a.genId(),de=`${k}/.staged/${ue}/${N.outputFile}`,qe=await Promise.resolve(s.keyRef?.(de));if(!qe)continue;let Te={ref:a$2(qe),deliveryToken:ue,outputFile:N.outputFile,cardId:k},it=tt({cbk:d.callbackToken,rg:r.value,br:a$2(r),cid:k,b:N.bindTo,d:N.outputFile,cs:void 0,rqt:d.rqt,dt:Te.deliveryToken});j.push({...Z?{boardId:Z}:{},ref:X,args:{source_def:N,base_ref:a$2(r),callback:i.createCallback(it),output:Te}});}j.length>0&&await _.enqueueMany(j);}catch(I){await F({type:"task-failed",taskName:k,error:I instanceof Error?I.message:String(I),timestamp:x()});}return}for(let I of O){if(!I.outputFile)continue;let _;if(Fe){let N=a.genId(),ue=`${k}/.staged/${N}/${I.outputFile}`,de=await Promise.resolve(s.keyRef?.(ue));de&&(_={ref:a$2(de),deliveryToken:N,outputFile:I.outputFile,cardId:k});}let Z=tt({cbk:d.callbackToken,rg:r.value,br:a$2(r),cid:k,b:I.bindTo,d:I.outputFile,cs:void 0,rqt:d.rqt,..._?{dt:_.deliveryToken}:{}}),j=await a.dispatchExecution(X,{source_def:I,base_ref:a$2(r),callback:i.createCallback(Z),..._?{output:_}:{}});j.dispatched||await F({type:"task-failed",taskName:k,error:j.error??"dispatch failed",timestamp:x()});}});}async function ae(){try{let t=async()=>{let s=await L(),{events:n}=await J().readEntriesAfterCursor(s.lastDrainedJournalId);n.length>0&&await m();},e=await Ye(a.lock,ye,t);return h({ran:e!==!1})}catch(t){return v(t)}}async function be(){return c$1||(c$1=ae().finally(()=>{c$1=null;}),c$1)}async function m(){let t=await b().readQueueStoreRef();if(!t)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=a.queueStorageForRef(t,"process-accumulated");e.enqueueIfAbsent?await e.enqueueIfAbsent({boardRef:a$2(r)},`process-accumulated:${a$2(r)}`):await e.enqueue({boardRef:a$2(r)}),await a.requestProcessAccumulated?.();}async function l(){let t=await b().readQueueStoreRef();if(!t)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=a.queueStorageForRef(t,"process-accumulated");for(;;){let s=await e.lease({max:64,visibilityMs:1e3});if(s.length<=0)return;for(let n of s)await e.ack(n.id,n.leaseToken);if(s.length<64)return}}function R(){m();}return {async init(t$1){try{let e=t$1.params?.cardStoreRef;if(!e)return f("init requires params.cardStoreRef");if(C=t$1.params?.boardRuntimeStoreRef,!C)return f("init requires params.boardRuntimeStoreRef");let s=t$1.params?.outputsStoreRef;if(!s)return f("init requires params.outputsStoreRef");let n=t$1.params?.queueStoreRef;if(!n)return f("init requires params.queueStoreRef");let y=t$1.params?.fetchedSourcesStoreRef;if(!y)return f("init requires params.fetchedSourcesStoreRef");if(P=t$1.params?.scratchStoreRef,!P)return f("init requires params.scratchStoreRef");let w=t$1.params?.chatStoreRef;if(!w)return f("init requires params.chatStoreRef");let A=t$1.params?.artifactsStoreRef;if(!A)return f("init requires params.artifactsStoreRef");await oe()||await U({lastDrainedJournalId:"",graph:p(a$3(u)),runtimeByCardId:{}},null);let g=b();return await g.writeBoardRuntimeStoreRef(C),await g.writeCardStoreRef(e),await g.writeOutputsStoreRef(s),await g.writeQueueStoreRef(n),await g.writeFetchedSourcesStoreRef(y),await g.writeChatStoreRef(w),await g.writeArtifactsStoreRef(A),await(await T()).writeStatusSnapshot(t(S,q((await L()).graph))),h()}catch(e){return v(e)}},async status(t$1){try{let e=await T(),s=await e.readStatusSnapshot();return s||(s=t(S,q((await L()).graph)),await e.writeStatusSnapshot(s)),h(s)}catch(e){return v(e)}},async getCardStoreRef(t){try{let e=await b().readCardStoreRef();return e?h({storeRef:e}):f(`Board at ${r.value} has no card store configured`)}catch(e){return v(e)}},async getBoardRuntimeStoreRef(t){try{return h({storeRef:C??null})}catch(e){return v(e)}},async getOutputsStoreRef(t){try{let e=await b().readOutputsStoreRef();return e?h({storeRef:e}):f(`Board at ${r.value} has no outputs store configured`)}catch(e){return v(e)}},async getScratchStoreRef(t){try{return h({storeRef:P??null})}catch(e){return v(e)}},async getChatStoreRef(t){try{return h({storeRef:await b().readChatStoreRef()})}catch(e){return v(e)}},async getArtifactsStoreRef(t){try{return h({storeRef:await b().readArtifactsStoreRef()})}catch(e){return v(e)}},async getFetchedSourcesStoreRef(t){try{return h({storeRef:await b().readFetchedSourcesStoreRef()})}catch(e){return v(e)}},async getConfig(t){try{let e=t.params?.key;if(!e)return f("getConfig requires params.key");let s=b(),n;switch(e){case "task-executor":n=B??null;break;case "chat-handler-flow":n=te??null;break;case "board-runtime-store-ref":n=await s.readBoardRuntimeStoreRef();break;case "card-store-ref":n=await s.readCardStoreRef();break;case "outputs-store-ref":n=await s.readOutputsStoreRef();break;case "scratch-store-ref":n=P??null;break;case "chat-store-ref":n=await s.readChatStoreRef();break;case "artifacts-store-ref":n=await s.readArtifactsStoreRef();break;case "fetched-sources-store-ref":n=await s.readFetchedSourcesStoreRef();break;default:return f(`getConfig: unknown key "${e}"`)}return h({value:n})}catch(e){return v(e)}},async getOutputsDataObject(t){try{let e=t.params?.key;return e?h(await(await T()).readDataObject(e)):f("getOutputsDataObject requires params.key")}catch(e){return v(e)}},async getAllOutputsDataObjects(t){try{return h(await(await T()).readAllDataObjects())}catch(e){return v(e)}},async getOutputsComputedValues(t){try{let e=t.params?.key;return e?h(await(await T()).readComputedValues(e)):f("getOutputsComputedValues requires params.key")}catch(e){return v(e)}},async getAllOutputsComputedValues(t){try{return h(await(await T()).readAllComputedValues())}catch(e){return v(e)}},async getOutputsFetchedSources(t){try{let e=t.params?.key;if(!e)return f("getOutputsFetchedSources requires params.key");let s=await(await W()).listSources(e),n={};for(let y of s)n[y]=await pe(`${e}/${y}`);return h(n)}catch(e){return v(e)}},async getAllOutputsFetchedSources(t){try{let e=await W(),s=await(await G()).listKeys(),n=new Set;for(let w of s){let A=w.indexOf("/");A>0&&!w.includes("/.staged/")&&n.add(w.slice(0,A));}let y={};for(let w of n){let A=await e.listSources(w);if(A.length!==0){y[w]={};for(let g of A)y[w][g]=await pe(`${w}/${g}`);}}return h(y)}catch(e){return v(e)}},async addCardFiles(t){try{let e=t.params?.cardId;if(!e)return f("addCardFiles requires params.cardId");let s=await K(),n=await s.readCard(e);if(!n)return f(`card "${e}" not found`);let y=t.body,w=Array.isArray(y)?y:y&&typeof y=="object"&&Array.isArray(y.files)?y.files:y!=null?[y]:null;if(!w||w.length===0)return f("addCardFiles requires a file metadata object, array, or body.files array");let A=n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?n.card_data:{},g=Array.isArray(A.files)?A.files:[],z=[...g,...w],Q=w.map((H,Y)=>({idx:g.length+Y,entry:H}));await s.writeCard(e,{...n,card_data:{...A,files:z}});let $=await this.cardRefreshedNotify({params:{cardId:e}});return $.status!=="success"?$:h({cardId:e,files_added:Q,notified:!0})}catch(e){return v(e)}},async cardRefreshedNotify(t){try{let e=t.params?.cardId;if(!e)return f("cardRefreshedNotify requires params.cardId");let s=await(await K()).readCard(e);return s?(await re([{kind:"card_refreshed",cardId:e,card:s}]),h({cardId:e,notified:!0})):f(`Card "${e}" not found in board at ${r.value}`)}catch(e){return v(e)}},async removeCard(t){try{let e=t.params?.id;if(!e)return f("removeCard requires params.id");try{await a.kvStorage("card-upsert").delete(e);}catch{}return await F({type:"task-removal",taskName:e,timestamp:x()}),R(),h()}catch(e){return v(e)}},async retrigger(t){try{let e=t.params?.id;return e?(await F({type:"task-restart",taskName:e,timestamp:x()}),R(),h()):f("retrigger requires params.id")}catch(e){return v(e)}},async processAccumulatedEvents(t){return await l(),be()},async upsertCard(t){try{let e=t.params?.cardId,s=t.params?.all,n=!!t.params?.restart;if(!e&&!s)return f("upsertCard requires --card-id <id> or --all");let y=await K(),w=s?(await y.readAllCards()).map(g=>g.id):[e];for(let g of w)if(!await y.readCard(g))return f(`Card "${g}" not found in board at ${r.value}`);let A=a.kvStorage("card-upsert");for(let g of w){let z=await y.readCard(g);if(!z)continue;let Q=x$1(z),$=a.hashFn(Q),H=await A.read(g),Y=H?.taskConfigHash!==$;if(!(!Y&&!n)){if(Y){let Re=H?.blobRef??await y.readCardKey(g)??g;await F({type:"task-upsert",taskName:g,taskConfig:Q,timestamp:x()}),await A.write(g,{blobRef:Re,taskConfigHash:$,updatedAt:x()});}n&&await F({type:"task-restart",taskName:g,timestamp:x()});}}return R(),h()}catch(e){return v(e)}},async taskFailed(t){try{let e=t.params?.token;if(!e)return f("taskFailed requires params.token");let s=t.params?.error??"unknown error",n=ge(e);return n?(await F({type:"task-failed",taskName:n.taskName,error:s,timestamp:x()}),R(),h()):f("Invalid callback token")}catch(e){return v(e)}},async taskProgress(t){try{let e=t.params?.token;if(!e)return f("taskProgress requires params.token");let s=(t.body??{}).update??{},n=ge(e);return n?(await F({type:"task-progress",taskName:n.taskName,update:s,timestamp:x()}),R(),h()):f("Invalid callback token")}catch(e){return v(e)}},async sourceDataFetched(t){try{let e=t.params?.token,s=t.params?.ref;if(!e)return f("sourceDataFetched requires params.token");if(!s)return f("sourceDataFetched requires params.ref");let n=rt(e);if(!n)return f("Invalid source token");let y=await W(),w=n.dt||a.genId();n.dt||await y.ingestSourceDataStaged(n.cid,n.d,b$1(s),w);let A=ge(n.cbk);return A?(await F({type:"task-progress",taskName:A.taskName,update:{bindTo:n.b,outputFile:n.d,fetchedAt:x(),deliveryToken:w,sourceChecksum:n.cs,rqt:n.rqt},timestamp:x()}),R(),h()):f("Invalid callback token embedded in source token")}catch(e){return v(e)}},async sourceDataFetchFailure(t){try{let e=t.params?.token,s=t.params?.reason??"unknown";if(!e)return f("sourceDataFetchFailure requires params.token");let n=rt(e);if(!n)return f("Invalid source token");let y=ge(n.cbk);return y?(await F({type:"task-progress",taskName:y.taskName,update:{bindTo:n.b,outputFile:n.d,failure:!0,reason:s,sourceChecksum:n.cs,rqt:n.rqt},timestamp:x()}),R(),h()):f("Invalid callback token embedded in source token")}catch(e){return v(e)}}}}
|
|
2
|
+
export{Ye as a,Xe as b,Ze as c,et as d,Rt as e,kt as f,Et as g};//# sourceMappingURL=chunk-GU3T75C4.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-GU3T75C4.js.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {n,h,i,j,a as a$7,b as b$2,k,l as l$1,c as c$3,m}from'./chunk-NU5NO5NM.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$8,c as c$4}from'./chunk-O7NOHKVR.js';import {a,b}from'./chunk-2GSI6C45.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$9,b as b$4}from'./chunk-ZJ5M5COT.js';import {a as a$4,d as d$1,b as b$3,c as c$2}from'./chunk-FOFGEABN.js';import {a as a$6,c as c$1}from'./chunk-O5UYCGIN.js';import {a as a$b}from'./chunk-RKKSVOP2.js';import {g,d,c,b as b$1}from'./chunk-GU3T75C4.js';import {a as a$a}from'./chunk-NNSBBO5R.js';import {y,z,l}from'./chunk-DOFNXJ4C.js';import {a as a$5}from'./chunk-KBELAKIY.js';import {a as a$1}from'./chunk-Q3OTUDIE.js';function ne(A){let{apiBasePath:F,json:C,readJsonBody:z,initBoardAndSetup:q,bootstrapBoard:x,buildPublishedRuntimePayload:V,createMcpControlplaneToolRegistry:U,retriggerCard:G,applyCardAction:N,resolveChatHandlerTarget:K,sendCardFileDownloadResponse:W}=A;async function rt(J,B,L){let u=J.method||"GET",i=L,S=i.pathname;try{if(u==="POST"&&S===`${F}/mcp-actions`){await x();let R=Date.now(),w=new Date(R).toISOString(),y=await z(J),d=typeof y.tool=="string"?y.tool.trim():"",M=y.args&&typeof y.args=="object"&&!Array.isArray(y.args)?y.args:{};if(!d)return C(B,400,{error:"tool is required"}),!0;let P=a$8(M,"card_id");if(!P)return C(B,400,{error:"MCP action requires card_id"}),!0;if(d==="retrigger-card"||d==="retrigger"){await G(P);let O=Date.now();return C(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:d,requestReceivedAt:w,requestReceivedAtMs:R,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:200}}),!0}let f=c$4(M,"payload");if(d==="chat-send"&&!await K(P)){let O=Date.now();return C(B,409,{error:`chat handler is not configured for card: ${P}`,requestReceivedAt:w,requestReceivedAtMs:R,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:409}),!0}if(d==="chat-send"){let O=typeof f["turn-id"]=="string"?f["turn-id"]:typeof f.turnId=="string"?f.turnId:typeof f.turn=="string"?f.turn:"";if(!O||!String(O).trim()){let Q=Date.now();return C(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${P}`,requestReceivedAt:w,requestReceivedAtMs:R,responseSentAt:new Date(Q).toISOString(),responseSentAtMs:Q,responseStatus:400}),!0}}await N(P,d,f);let H=Date.now();return C(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:d,requestReceivedAt:w,requestReceivedAtMs:R,responseSentAt:new Date(H).toISOString(),responseSentAtMs:H,responseStatus:200}}),!0}if(u==="POST"&&S===`${F}/mcp-controlplane`){await x();let R=await z(J),w=typeof R.tool=="string"?R.tool.trim():"",y=R.args&&typeof R.args=="object"&&!Array.isArray(R.args)?R.args:{};if(!w)return C(B,400,{error:"tool is required"}),!0;try{let d=await a$9(w,y,U());if(d&&typeof d=="object"&&!Array.isArray(d)){let M=d;if(M.status==="fail")return C(B,400,{error:b$4(d,"Request failed")}),!0;if(M.status==="error")return C(B,500,{error:b$4(d,"Internal error")}),!0}C(B,200,d);}catch(d){let M=typeof d?.statusCode=="number"?Number(d.statusCode):500,P=d instanceof Error?d.message:String(d);C(B,M,{error:P});}return !0}let k=S.match(new RegExp(`^${c$2(F)}/cards/([^/]+)/retrigger$`));if(u==="POST"&&k){await x();let R=decodeURIComponent(k[1]);return await G(R),C(B,200,{ok:!0}),!0}let v=S.match(new RegExp(`^${c$2(F)}/cards/([^/]+)/actions$`));if(u==="POST"&&v){await x();let R=decodeURIComponent(v[1]),w=Date.now(),y=new Date(w).toISOString(),d=await z(J),M=d?.actionType;if(M==="chat-send"&&!await K(R)){let f=Date.now();return C(B,409,{error:`chat handler is not configured for card: ${R}`,requestReceivedAt:y,requestReceivedAtMs:w,responseSentAt:new Date(f).toISOString(),responseSentAtMs:f,responseStatus:409}),!0}if(M==="chat-send"){let f=d?.payload??{},H=typeof f["turn-id"]=="string"?f["turn-id"]:typeof f.turnId=="string"?f.turnId:typeof f.turn=="string"?f.turn:"";if(!H||!String(H).trim()){let O=Date.now();return C(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${R}`,requestReceivedAt:y,requestReceivedAtMs:w,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:400}),!0}}await N(R,M,d?.payload);let P=Date.now();return C(B,200,{ok:!0,requestReceivedAt:y,requestReceivedAtMs:w,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:200}),!0}let j=S.match(new RegExp(`^${c$2(F)}/cards/([^/]+)/files/(\\d+)$`));if(u==="GET"&&j){let R=decodeURIComponent(j[1]),w=parseInt(j[2],10),y=i.searchParams.get("sn");return await W(B,R,w,y),!0}return !1}catch(k){let v=k?.statusCode||500;return C(B,v,{error:String(k?.message||k)}),true}}return {handleRuntimeApi:rt}}var oe={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},ae="chat-handler-flow-queue",ft="__probe__echo__probe__";function gr(A){let F=String(A.apiBasePath||"/api/board").replace(/\/$/,""),C={...oe,...A.corsHeaders||{}},z$1=A.queueLaneTuning??{},q=A.boardId||"",x=A.logger||{info:console.log,warn:console.warn,error:console.error},V=A.invocationAdapter,U=A.chatFlowRunner||null,G=A.notificationTransport||null,N=A.serverUrl||null,K=A.executionExtra||{},W=A.onSseClientConnected,rt=A.onSseClientDisconnected,J=A.onChannelSubscribed,B=A.onChannelUnsubscribed,L=a({readChatRecords:t=>bt(t),getChatProcessing:t=>Rt(t),readChatAfter:async(t,e)=>{let r=await ie(t,e);return {records:r.records,cursor:r.cursor}},onSseClientDisconnected:rt});function u(t){function e(o){if(Array.isArray(o))return o;if(o&&typeof o=="object"){let c=o;return Array.isArray(c.files)?c.files:[o]}return null}function r(o){return {async get(c){return o.get(c)},async set(c){return o.set(c)},async del(c){return o.del(c)},async patch(c){return o.patch(c)},async appendFiles(c){return o.appendFiles(c)}}}function a(o){function c(h){return {status:"success",data:h}}function p(h){return {status:"fail",error:h}}function l(h){return {status:"error",error:h instanceof Error?h.message:String(h)}}return {async get(h){try{let m=h.params?.id;if(m){let T=await o.readCard(m);return T?c({cards:[T]}):p(`card "${m}" not found`)}return c({cards:await o.readAllCards()})}catch(m){return l(m)}},async set(h){try{let m=h.body;if(m==null)return p("set requires a body (card object or array of cards)");let T=Array.isArray(m)?m:[m];for(let E of T){if(typeof E.id!="string")return p("each card must have a string `id` field");await o.writeCard(E.id,E);}return c({count:T.length})}catch(m){return l(m)}},async del(h){try{let m=h.body?.ids??[],T=h.params?.id,E=T?[...m,T]:m;if(E.length===0)return p("del requires body.ids (string[]) or params.id");for(let Y of E)await o.removeCard(Y);return c({count:E.length})}catch(m){return l(m)}},async patch(h){try{let m=h.params?.id,T=h.params?.path;if(!m)return p("patch requires params.id");if(!T)return p("patch requires params.path");let E=h.body,Y=E&&Object.prototype.hasOwnProperty.call(E,"value")?E.value:h.body;return await o.patchCard(m,T,Y),c({count:1})}catch(m){return l(m)}},async appendFiles(h){try{let m=h.params?.id;if(!m)return p("appendFiles requires params.id");let T=await o.readCard(m);if(!T)return p(`card "${m}" not found`);let E=e(h.body);if(!E||E.length===0)return p("appendFiles requires a file metadata object, array, or body.files array");let Y=T.card_data&&typeof T.card_data=="object"&&!Array.isArray(T.card_data)?T.card_data:{},Pt=Array.isArray(Y.files)?Y.files:[],_e=[...Pt,...E];return await o.patchCard(m,"card_data.files",_e),c({files_added:E.map((De,$e)=>({idx:Pt.length+$e,entry:De}))})}catch(m){return l(m)}}}}let n=a$4(t.boardAdapter)?g(t.baseRef,t.boardAdapter,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow}):y(t.baseRef,t.boardAdapter,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow}),s=t.nonCoreAdapter??(!a$4(t.boardAdapter)&&R(t.boardAdapter)?t.boardAdapter:null),g$1=t.nonCore??(s?z(t.baseRef,s,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),b=t.boardAdapter.chatStorageForRef(t.chatStoreRef),D,$=a$4(t.boardAdapter)?(()=>{let o=d(c(b$1(t.boardAdapter.kvStorageForRef(t.cardStoreRef)),t.boardAdapter.hashFn),x.warn),c$1=a(o);return D={get(p){return c$1.get(p)},set(p){return c$1.set(p)}},c$1})():(()=>{let o=t.boardAdapter.kvStorageForRef(t.cardStoreRef),p=a$5(l({readIndex:()=>o.read("_index"),writeIndex:l=>o.write("_index",l),readCard:l=>o.read(l),writeCard:(l,h)=>(o.write(l,h),l),removeCard:l=>{o.delete(l);},cardExists:l=>o.read(l)!==null,defaultCardKey:l=>l},x.warn));return D=p,r(p)})(),I;if(a$4(t.boardAdapter)){let o=t.boardAdapter.blobStorageForRef(t.artifactsStoreRef);I={async putBytes(c,p){if(o.writeBytes){await o.writeBytes(c,p);return}let l=JSON.stringify({__kind:"bytes-array",data:[...p]});await o.write(c,l);},async getBytes(c){if(o.readBytes){let l=await o.readBytes(c);if(l!==null)return l}let p=await o.read(c);if(p===null)return null;try{let l=JSON.parse(p);if(l&&l.__kind==="bytes-array"&&Array.isArray(l.data))return new Uint8Array(l.data)}catch{}return new TextEncoder().encode(p)},async listKeys(c){return await o.listKeys(c)}};}else {let o=t.boardAdapter.blobStorageForRef(t.artifactsStoreRef),c=a$6(o);I={putBytes(p,l,h){c.putBytes(p,l,h);},getBytes(p){return c.getBytes(p)},listKeys(p){return c.list(p).map(l=>l.key)}};}let Me={async init(o){return n.init(o)},async status(o){return n.status(o)},async getConfig(o){return n.getConfig(o)},async getAllOutputsDataObjects(o){return n.getAllOutputsDataObjects(o)},async getAllOutputsComputedValues(o){return n.getAllOutputsComputedValues(o)},async getOutputsFetchedSources(o){return n.getOutputsFetchedSources(o)},async upsertCard(o){return n.upsertCard(o)},async removeCard(o){return n.removeCard(o)},async cardRefreshedNotify(o){return n.cardRefreshedNotify(o)},async sourceDataFetched(o){return n.sourceDataFetched(o)},async sourceDataFetchFailure(o){return n.sourceDataFetchFailure(o)}};return {label:t.label,board:n,nonCore:g$1,publicCardStore:D,boardOps:Me,cardStoreOps:$,get filesArtifacts(){return I},get chatStorage(){return b},boardAdapter:t.boardAdapter,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:a$7(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let i$1=A.boards.map(u),S=new Map;function k$1(t){return S.get(t)??0}function v(t){return t.queueStoreRef}function j$1(t,e){if(a$4(t.boardAdapter)){let a=t.boardAdapter.queueStorageForRef(v(t),e);return a$a(a)}let r=t.boardAdapter.queueStorageForRef(v(t),e);return a$b(r)}function R(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function w(t){let e=i$1[k$1(t)];return {files:e?e.filesArtifacts:null}}function y$1(){return c$1()}function d$2(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function M(t){if(!t||t.notificationTeardown||!G||!t.notifyRef)return;let e=await G.subscribe(t.notifyRef,r=>{c$3(t.notification,r);let a=r.kind==="notification-batch"?r.notifications:[r];L.broadcastNotificationBatch(a);});t.notificationTeardown=e;}async function P(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let a=await t.boardOps.init({params:e,body:r});if(a.status!=="success")throw Object.assign(new Error(a.error||`init failed for ${t.label}`),{statusCode:500});if(await M(t),!t.chatHandlerFlow&&t.chatHandlerRef&&V.describe)try{let n=await V.describe(t.chatHandlerRef);n&&n.kind!=="chat-handler"?x.warn(`[init] chat-handler describe returned kind="${n.kind}", expected "chat-handler" for ${t.label}`):n&&x.info(`[init] chat-handler validated: ${n.name} (protocol ${n.protocolVersion}) for ${t.label}`);}catch(n){x.warn(`[init] chat-handler describe failed for ${t.label}: ${n?.message||String(n)}`);}t.initialized=true;}async function f(t){if(!t.boardAdapter.publishBoardChangeNotifications)return;let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&b$2(r.data)&&e.push({kind:"status",status:r.data});let a=await t.boardOps.getAllOutputsDataObjects({});if(a.status==="success"&&a.data!=null)for(let[s,g]of Object.entries(a.data))s&&e.push({kind:"data_object",key:s,payload:g});let n=await t.boardOps.getAllOutputsComputedValues({});if(n.status==="success"&&n.data!=null)for(let[s,g]of Object.entries(n.data))s&&e.push({kind:"computed_values",cardId:s,values:g});e.length>0&&t.boardAdapter.publishBoardChangeNotifications(e);}async function H(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),a=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let n of a)typeof n.id=="string"&&(S.set(n.id,e),await t.boardOps.upsertCard({params:{cardId:n.id}}));t.cardsBootstrapped=true;}async function O(){for(let t of i$1)await P(t);}async function Q(){await O();for(let t=0;t<i$1.length;t++)await f(i$1[t]),await H(i$1[t],t),await f(i$1[t]);}async function pt(t=false){t||await O();for(let e of i$1){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function Z(t){return i$1[k$1(t)]??null}async function nt(t){let e=Z(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let a=Array.isArray(r.data?.cards)?r.data.cards:[];return a.length>0?a[0]:null}async function mt(){let t=async r=>{if(!r)return [];let a=await r.cardStoreOps.get({});return a.status!=="success"||!Array.isArray(a.data?.cards)?[]:a.data.cards},e=[];for(let r of i$1)e.push(...await t(r));return e}function gt(){return i$1[0]??null}function se(t){return Z(t)??gt()}function _(t){let e=se(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ie(t,e){return await _(t).readAfter(t,e)}async function Rt(t){return await _(t).isProcessing(t)}async function at(t,e){await _(t).setProcessing(t,e),await L.broadcastCardChats(t,true);}let ce=a$1({append(t,e,r,a,n){return Promise.resolve(_(t).append(t,e,r,a,n)).then(async s=>(await L.broadcastCardChats(t,true),s))},readAll(t){return _(t).readAll(t)},readAfter(t,e){return _(t).readAfter(t,e)},clear(t){return _(t).clear(t)},setProcessing(t,e){return Promise.resolve(_(t).setProcessing(t,e)).then(async()=>{await L.broadcastCardChats(t,true);})},isProcessing(t){return _(t).isProcessing(t)},getConfig(t){return _(t).getConfig(t)},setConfig(t,e){return _(t).setConfig(t,e)}}),yt=n({boardContexts:i$1,cardOwnerIndex:S,cardContextForCard:t=>Z(t),readStatusSnapshot:()=>pe(),readDataObjectsByToken:()=>ge(),readCardRuntimeArtifacts:()=>me(),readCardFromStore:t=>nt(t),readCardDefinitions:()=>mt(),processAccumulatedLaneInternal:t=>pt(t),reportSourceFetched:(t,e)=>Bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>kt(t,{reason:e}),uploadCardFile:(t,e,r,a,n)=>Ct(t,e,r,a,n),chatStorePublic:ce,serverUrl:N,apiBasePath:F}),ue=yt.mcpCardStoreFacade,st=yt.createMcpFacade,de=h({boardId:q,bootstrapBoard:()=>Q(),sseHub:L,onChannelSubscribed:J,onChannelUnsubscribed:B,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>ue()});function le(t){return k(t)}function fe(){return l$1(st())}function wt(){return m({boardId:q,uploadCardFile:Ct,getMcpFacade:()=>st(),controlplane:de})}let it=i({boardId:q,boardContexts:i$1,readCardDefinitions:()=>mt(),readChatRecords:t=>bt(t),getChatProcessing:t=>Rt(t)}),pe=it.readStatusSnapshot,me=it.readCardRuntimeArtifacts,ge=it.readDataObjectsByToken,dt=it.buildPublishedRuntimePayload;async function ht(t,e,r){let a=r?.syncBoard!==false,n=r?.restartOnlyIfChanged===true,s=Z(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let g=await nt(t);if(!g)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let b=n?JSON.stringify(g):null,D=e(g)||g;if(n&&JSON.stringify(D)===b)return;let $=await s.cardStoreOps.set({body:D});if($.status!=="success")throw Object.assign(new Error($.error||`Failed to persist card: ${t}`),{statusCode:500});if(a){let I=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(I.status!=="success")throw Object.assign(new Error(I.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Re(t,e){await ht(t,e,{syncBoard:true});}async function ye(t,e){await ht(t,e,{syncBoard:false});}async function we(t){let e=Z(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 a=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(a.status!=="success")throw Object.assign(new Error(a.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function he(t){await _(t).clear(t);try{await at(t,!1);}catch{}}async function be(t,e,r,a,n=""){let s=typeof r=="string"?r.trim():"",g=await _(t).append(t,e||"system",s,a,n);return await L.broadcastCardChats(t,true),g}async function bt(t){return await _(t).readAll(t)}let Ct=j({safeCardId:t=>d$2(t),artifactsStores:t=>w(t),cardFileMetadataStore:()=>y$1(),readCardFromStore:t=>nt(t),updateCardLocalOnly:(t,e)=>ye(t,e),writeChatRecord:(t,e,r,a,n)=>be(t,e,r,a,n)}).uploadCardFile;async function St(t){let e=Z(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),n=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return n==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:n,handlerRef:s}}function Ce(t){let e=typeof t=="string"?t.trim():"";return e.length>=ft.length*2&&e.startsWith(ft)&&e.endsWith(ft)}async function Se(t,e,r=false,a="",n=false){try{let s=await St(t);if(!s){try{await at(t,!1);}catch{}return}let{ctx:g,handlerFlow:b,handlerRef:D}=s;if(!r)try{await at(t,!0);}catch{}let $={boardId:q,cardId:String(t),lastChatEntryId:e,...a?{turnId:a}:{},isProbe:!!n,...K,...N?{serverUrl:N}:{}},I=b!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:ae}}:D;a$4(g.boardAdapter)?await j$1(g,"chat-agent").enqueueRequest({boardId:q,ref:I,args:b!=null?{...$,__chatHandlerFlow:b}:$}):j$1(g,"chat-agent").enqueueRequest({boardId:q,ref:I,args:b!=null?{...$,__chatHandlerFlow:b}:$}),await Promise.resolve(g.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await at(t,!1);}catch{}x.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Ae(t,e,r){if(e.howToRun==="built-in"&&b$3(e)===ae){let a=U,n=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,a?a.run(n,s,{boardId:q,cardId:String(s.cardId||""),label:t.label,logger:x,serverUrl:N,executionExtra:K}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return V.invoke(e,r)}async function Be(t,e=false){e||await O();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",a=r?Z(r):gt();if(!a)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let n=await Ae(a,t.ref,t.args);if(!n.dispatched){if(r)try{await at(r,!1);}catch{}throw new Error(n.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function ke(t,e,r){if(e==="chat-send"){let n=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"",s=wt(),g=Ce(r?.text),b=await a$9("manage.add-chat-entry-and-any-attachments",{board_id:q,card_id:t,role:"user",text:r?.text,turn_id:n,files:[]},s);if(b?.status!=="success")throw new Error(b$4(b,`chat-send append failed for card ${t}`));let D=b?.data?.id;if(typeof D!="string"||!D)throw new Error(`chat-send did not return an append id for card ${t}`);let $=await a$9("setstate.chat-processing-started",{board_id:q,card_id:t},s);if($?.status!=="success")throw new Error(b$4($,`chat-send processing update failed for card ${t}`));Se(t,D,true,n,g);return}await Re(t,n=>{let s=new Date().toISOString(),g=n.card_data&&typeof n.card_data=="object"?n.card_data:{};if(n.card_data=g,e==="file-upload"){let b=y$1().normalizeIncoming(r?.files,s);return b.length>0&&y$1().merge(g,b),n}if(e==="action"){let b=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!b)return n;g.lastAction={buttonId:b,at:s},g.lastActionText=`${b} @ ${s}`;}return n});}function ct(t,e,r){let a=JSON.stringify(r),n=typeof Buffer<"u"?Buffer.byteLength(a):new TextEncoder().encode(a).length;t.writeHead(e,{...C,"Content-Type":"application/json; charset=utf-8","Content-Length":n}),t.end(a);}async function At(t,e,r){let a=await nt(t);if(!a)throw Object.assign(new Error("Card not found"),{statusCode:404});let n=y$1().resolve(a.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 s=n.file,g=d$2(t),b=w(t),D=String(s.stored_name||""),$=`${g}/${D}`,I=b.files?await b.files.getBytes($):null;if(!I)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:I}}async function Pe(t,e,r,a){let{fileRecord:n,bytes:s}=await At(e,r,a),g=String(n.name||n.stored_name||"download.bin"),b=String(n.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":b,"Content-Disposition":`attachment; filename="${g}"`,"Content-Length":s.length}),t.end(s);}function Fe(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 Oe(t,e,r){let a=t.split(/\r?\n/);return (e==="head"?a.slice(0,r):a.slice(-r)).join(`
|
|
2
|
+
`)}async function ut(t){let e=[];for await(let a of t)e.push(a);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 a=i$1[0];return a?a.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function kt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",a=i$1[0];return a?a.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let ve=b({sseHub:L,corsHeaders:C,json:ct,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:W,onChannelSubscribed:J,onChannelUnsubscribed:B,apiBasePath:F,readJsonBody:t=>ut(t),initBoardAndSetup:()=>O(),bootstrapBoard:()=>Q(),boardContexts:i$1,publishPersistedStateSnapshot:t=>f(t),upsertCardsFromSource:(t,e)=>H(t,e)}).handleWatchersRoutes,Te=a$2({apiBasePath:F,json:ct,readJsonBody:t=>ut(t),bootstrapBoard:()=>Q(),createMcpFacade:()=>st(),createMcpToolRegistry:t=>le(t),resolveCardFileDownloadPayload:(t,e,r)=>At(t,e,r),isLikelyTextMimeType:t=>Fe(t),sliceTextByLines:(t,e,r)=>Oe(t,e,r)}).handleAgentfaceApi,xe=a$3({apiBasePath:F,json:ct,readJsonBody:t=>ut(t),initBoardAndSetup:()=>O(),createMcpWebhookToolRegistry:()=>fe()}).handleWebhooksApi,Ee=ne({apiBasePath:F,json:ct,readJsonBody:t=>ut(t),initBoardAndSetup:()=>O(),bootstrapBoard:()=>Q(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>wt(),retriggerCard:t=>we(t),applyCardAction:(t,e,r)=>ke(t,e,r),resolveChatHandlerTarget:t=>St(t),sendCardFileDownloadResponse:(t,e,r,a)=>Pe(t,e,r,a)}).handleRuntimeApi;async function je(t,e,r){return !!(await Te(t,e,r)||await xe(t,e,r)||await ve(t,e,r)||await Ee(t,e,r))}return {get apiBasePath(){return F},get corsHeaders(){return C},get queueLaneTuning(){return z$1},handleRuntimeApi:je,buildPublishedRuntimePayload:dt,__drainProcessAccumulatedLane:pt,handleChatAgentRequest:Be,clearChatRecords:he,reportSourceFetched(t,e){return Bt(t,{ref:e})},reportSourceFetchFailure(t,e){return kt(t,{reason:e})},get cardStore(){return i$1[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Rr(A){let F=String(A.apiBasePath||"/api/boards").replace(/\/$/,""),C={...oe,...A.corsHeaders||{}},z=A.serverMetaStore,q=A.boardRuntimeFactory,x=new Map,V="boards-config.json";function U(){let u=z.getText(V);if(!u)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(u)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function G(u){z.putText(V,JSON.stringify(u,null,2));}function N(u){let i=String(u||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return i.length>0&&i.length<=64?i:null}function K(u){if(x.has(u))return x.get(u);let S=U().boards.find(v=>v.id===u)||{},k=q(u,S);return x.set(u,k),k}function W(u,i,S){let k=JSON.stringify(S),v=typeof Buffer<"u"?Buffer.byteLength(k):new TextEncoder().encode(k).length;u.writeHead(i,{...C,"Content-Type":"application/json; charset=utf-8","Content-Length":v}),u.end(k);}async function rt(u,i,S){let k=u.method||"GET",v=S.pathname;if(k==="GET"&&v===F)return W(i,200,{ok:true,boards:U().boards}),true;if(k==="POST"&&v===F){let j=[];for await(let f of u)j.push(f);let R=typeof Buffer<"u"?Buffer.concat(j).toString("utf-8").trim():new TextDecoder().decode(d$1(j)).trim(),w={};try{w=R?JSON.parse(R):{};}catch{w={};}let y=N(w.id);if(!y)return W(i,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let d=U();if(d.boards.some(f=>f.id===y))return W(i,409,{error:`Board "${y}" is already registered`}),true;let M=typeof w.label=="string"&&w.label.trim()?w.label.trim():y,P={id:y,label:M};for(let[f,H]of Object.entries(w))f==="id"||f==="label"||H!=null&&(P[f]=H);return d.boards.push(P),G(d),W(i,200,{ok:true,board:P}),true}return false}async function J(u,i,S){let v=S.pathname.match(new RegExp(`^${c$2(F)}/([^/]+)(/|$)`));if(!v)return false;let j=N(decodeURIComponent(v[1]));return j?U().boards.some(y=>y.id===j)?!!await K(j).handleRuntimeApi(u,i,S):(W(i,404,{error:`Board "${j}" not registered. POST ${F} with {id} to register it first.`}),true):(W(i,400,{error:"Invalid board id"}),true)}async function B(u,i,S){return !!(await rt(u,i,S)||await J(u,i,S))}function L(u){if(!U().boards.some(S=>S.id===u))throw Object.assign(new Error(`Board "${u}" not registered`),{statusCode:404});return {service:K(u)}}return {get apiBasePath(){return F},get corsHeaders(){return C},handleApi:B,requireBoardService:L}}export{gr as a,Rr as b};//# sourceMappingURL=chunk-H3EHFCDZ.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-H3EHFCDZ.js.map
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
'use strict';var child_process=require('child_process'),f=require('fs'),module$1=require('module'),u=require('path'),url=require('url');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 f__namespace=/*#__PURE__*/_interopNamespace(f);var u__namespace=/*#__PURE__*/_interopNamespace(u);var v=new Map;function X(e,r){let o=String(e||"").trim();if(!o)throw new Error("registerInProcessBoardWorkerCallback: key is required");v.set(o,r);}function Y(e){let r=String(e||"").trim();r&&v.delete(r);}async function B(e,r){let o=String(r||"").trim();if(!o)throw new Error("in-process-loop callback requires a non-empty handler key");let t=v.get(o);if(!t)throw new Error(`in-process-loop callback handler not registered: ${o}`);let n=await t(e);if(n&&n.status&&n.status!=="success")throw new Error(n.error||`in-process-loop callback failed with status: ${n.status}`)}function j(e,r,o){q(N(e),JSON.stringify({tool:"webhook.source-fetch-done",args:{token:r,ref:o}}));}function H(e,r,o){q(N(e),JSON.stringify({tool:"webhook.source-fetch-failed",args:{token:r,reason:o}}));}function N(e){return String(e||"").replace(/\/+$/,"")}function q(e,r){let o=`
|
|
2
|
+
const rawUrl = ${JSON.stringify(e)};
|
|
3
|
+
const rawBody = ${JSON.stringify(r)};
|
|
4
|
+
const u = new URL(rawUrl);
|
|
5
|
+
const {request} = require(u.protocol === 'https:' ? 'https' : 'http');
|
|
6
|
+
const h = { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(rawBody) };
|
|
7
|
+
const req = request({hostname:u.hostname,port:u.port,path:u.pathname+u.search,method:'POST',headers:h}, (res) => {
|
|
8
|
+
let responseBody = '';
|
|
9
|
+
res.setEncoding('utf8');
|
|
10
|
+
res.on('data', chunk => { responseBody += chunk; });
|
|
11
|
+
res.on('end', () => {
|
|
12
|
+
const code = res.statusCode || 500;
|
|
13
|
+
if (code < 200 || code >= 300) {
|
|
14
|
+
const msg = responseBody.trim() || res.statusMessage || ('HTTP ' + code);
|
|
15
|
+
process.stderr.write(msg);
|
|
16
|
+
process.exit(1);
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
req.on('error', e => { process.stderr.write(e.message); process.exit(1); });
|
|
21
|
+
req.write(rawBody);
|
|
22
|
+
req.end();
|
|
23
|
+
`,t=child_process.spawnSync(process.execPath,["-e",o],{encoding:"utf-8",windowsHide:true});if(t.status!==0)throw new Error(`http-post failed: ${t.stderr?.trim()}`)}var oe=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-H4TYOSMD.cjs', document.baseURI).href)));function O(e,r,o){L(e,["source-data-fetched","--ref",o,"--token",r],"reportComplete");}function A(e,r,o){L(e,["source-data-fetch-failure","--token",r,"--reason",o],"reportFailed");}function L(e,r,o){let t=te(e.whatToRun),{cmd:n,args:s}=ie(t),a=ne(e),i=se(e),p=ae(e),c=child_process.spawnSync(n,[...s,...r,...i?["--board-runtime-store-ref",i]:[],...p?["--queue-store-ref",p]:[],...a?["--notify-channel",a]:[]],{encoding:"utf-8",windowsHide:true});if(c.status!==0)throw new Error(`${o}: board CLI exited ${c.status}: ${c.stderr?.trim()}`)}function te(e){let r=ce(e);if(r.kind==="yaml-flow-cli"){let o=u__namespace.basename(r.value.trim());if(!o)throw new Error(`Invalid yaml-flow-cli ref: expected non-empty cli file name, got ${JSON.stringify(r.value)}`);let t=u__namespace.dirname(oe.resolve("yaml-flow/package.json")),n=o.replace(/\.[^.]+$/,""),s=u__namespace.join(t,"cli","bundled",`${n}.mjs`);if(f__namespace.existsSync(s))return s;let a=u__namespace.join(t,"cli","node",o);if(f__namespace.existsSync(a))return a;throw new Error(`Invalid yaml-flow-cli ref: could not find ${o} under cli/bundled or cli/node in ${t}`)}return r.value}function ne(e){let r=e.extra?.notifyChannel;return typeof r=="string"&&r.length>0?r:void 0}function se(e){let r=e.extra?.boardRuntimeStoreRef;return typeof r=="string"&&r.length>0?r:void 0}function ae(e){let r=e.extra?.queueStoreRef;return typeof r=="string"&&r.length>0?r:void 0}function ie(e){if(!e.endsWith(".ts"))return {cmd:process.execPath,args:[e]};let r=u__namespace.dirname(e),o=[];for(let n=1;n<=5;n++){let s=u__namespace.join(r,...Array(n).fill(".."),"node_modules");o.push(u__namespace.join(s,"tsx","dist","cli.mjs")),o.push(u__namespace.join(s,".bin","tsx"));}let t=o.find(n=>f__namespace.existsSync(n));return t?{cmd:process.execPath,args:[t,e]}:{cmd:"npx",args:["tsx",e]}}function ce(e){if(!e.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${e}`);let r=e.slice(4),o=r.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-r.length%4)%4),t;try{t=JSON.parse(Buffer.from(o,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let n=t;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:n.kind,value:n.value}}var I=new Map;function ue(e,r){let o=String(e||"").trim();if(!o)throw new Error("registerInProcessBoardWorkerInvoke: key is required");I.set(o,r);}function de(e){let r=String(e||"").trim();r&&I.delete(r);}async function T(e,r){let o=String(r||"").trim();if(!o)throw new Error("in-process board-worker invoke requires a non-empty handler key");let t=I.get(o);if(!t)throw new Error(`in-process board-worker invoke handler not registered: ${o}`);return await t(e)}var M=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-H4TYOSMD.cjs', document.baseURI).href))),W=u__namespace.default.dirname(url.fileURLToPath((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-H4TYOSMD.cjs', document.baseURI).href))));function J(e){if(!e.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${e}`);let r=e.slice(4),o=r.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-r.length%4)%4),t;try{t=JSON.parse(Buffer.from(o,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let n=t;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:n.kind,value:n.value}}function g(e){return `b64:${Buffer.from(JSON.stringify(e),"utf8").toString("base64").replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}`}function ke(){return {read(e){if(!f__namespace.default.existsSync(e))return null;try{return f__namespace.default.readFileSync(e,"utf-8")}catch{return null}},write(e,r){f__namespace.default.mkdirSync(u__namespace.default.dirname(e),{recursive:true}),f__namespace.default.writeFileSync(e,r,"utf-8");}}}function ze(e){if(e.kind==="fs-path")return ke();throw new Error(`Unsupported storage kind: "${e.kind}". Supported kinds: fs-path`)}function me(){let e=u__namespace.default.resolve(W,"./jsonata-sync.cjs");if(f__namespace.default.existsSync(e))return e;let r=u__namespace.default.resolve(W,"../../card-compute/jsonata-sync.cjs");return f__namespace.default.existsSync(r)?r:u__namespace.default.resolve(W,"../../../lib/jsonata-sync.cjs")}var ge=M(me());function he(e){e.registerFunction?.("fsPathRef",r=>g({kind:"fs-path",value:String(r)}),"<s:s>");}function l(e){return typeof e=="string"?J(e).value:e.value}function x(e){return e.howToRun==="local-node"||e.howToRun==="local-process"}function z(e){return e.howToRun==="http:post"||e.howToRun==="http:get"}function S(e){return e.howToRun==="in-process-loop"}function F(e){return {...e,whatToRun:typeof e.whatToRun=="string"?e.whatToRun:g(e.whatToRun)}}function we(e){return typeof e.whatToRun=="string"?e:{...e,whatToRun:g(e.whatToRun)}}function P(e,r){if(!e||typeof e!="object")throw new Error(`[board-worker-adapter] Step "${r}" returned a non-object result.`);let o=e,t=o.result??o.status;if(typeof t=="string"&&t.trim()){let n=o.data&&typeof o.data=="object"&&!Array.isArray(o.data)?{...o.data}:{},s=typeof o.error=="string"?o.error:void 0;return s&&!Object.prototype.hasOwnProperty.call(n,"error")&&(n.error=s),s?{result:t,data:n,error:s}:{result:t,data:n}}return {result:"success",data:{...o}}}function R(e){return {result:"failure",data:{error:e},error:e}}function k(e,r,o){try{let t=ge(e);return he(t),t.evaluate(r)}catch(t){let n=t instanceof Error?t.message:String(t);throw new Error(`[${o}] JSONata evaluation failed for "${e}": ${n}`)}}function K(e,r,o){if(!e||typeof e!="object")return {};let t={};if(Array.isArray(e.cmdTemplate)&&(t.cmdArgs=e.cmdTemplate.map(n=>String(k(n,r,`${o}.cmdTemplate`)))),typeof e.stdinTemplate=="string"&&(t.stdin=k(e.stdinTemplate,r,`${o}.stdinTemplate`)),typeof e.urlTemplate=="string"&&(t.url=String(k(e.urlTemplate,r,`${o}.urlTemplate`))),typeof e.headerTemplate=="string"){let n=k(e.headerTemplate,r,`${o}.headerTemplate`);if(!n||typeof n!="object"||Array.isArray(n))throw new Error(`[${o}.headerTemplate] expected an object result`);t.headers=n;}return typeof e.bodyTemplate=="string"&&(t.body=k(e.bodyTemplate,r,`${o}.bodyTemplate`)),t}function V(e){let r=String(e||"").trim();if(!r)return {};try{return JSON.parse(r)}catch{return {stdout:r}}}async function Fe(e,r){let o=U(e,r);if(x(e))return _(e,o);if(e.howToRun==="http:post")return ve(l(e.whatToRun),o);if(S(e))return T(o,l(e.whatToRun));throw new Error(`invokeBoardWorker: unsupported via.howToRun "${e.howToRun}"`)}function Ke(e,r){let o=U(e,r);if(x(e))return _(e,o);if(e.howToRun==="http:post")return Be(l(e.whatToRun),o);throw new Error(`invokeBoardWorkerSync: unsupported via.howToRun "${e.howToRun}"`)}function Re(e){let r=Q(e.whatToRun);switch(e.howToRun){case "local-node":return {command:process.execPath,baseArgs:[r]};case "local-python":return {command:process.platform==="win32"?"python":"python3",baseArgs:[r]};case "local-process":return {command:r,baseArgs:[]};default:throw new Error(`invokeStepMachineExecutionRef: unsupported local transport "${e.howToRun}"`)}}function $(e,r,o){if(!e||typeof e!="object")return r;let t={output:r},n=r.result,s=r.data,a=r.error;if(typeof e.resultExpr=="string"){let i=k(e.resultExpr,t,`${o}.resultExpr`);if(typeof i!="string"||!i.trim())throw new Error(`[${o}.resultExpr] expected a non-empty string result`);n=i;}if(typeof e.dataTemplate=="string"){let i=k(e.dataTemplate,t,`${o}.dataTemplate`);if(!i||typeof i!="object"||Array.isArray(i))throw new Error(`[${o}.dataTemplate] expected an object result`);s=i;}if(typeof e.errorExpr=="string"){let i=k(e.errorExpr,t,`${o}.errorExpr`);a=i!=null?String(i):void 0;}return a!==void 0?{result:n,data:s,error:a}:{result:n,data:s}}function ye(e,r,o,t){let n=o.label||"invokeStepMachineExecutionRef",s=K(e.argsMassaging,t,n),{command:a,baseArgs:i}=Re(e),p=s.stdin!==void 0?s.stdin:r,c=child_process.spawnSync(a,[...i,...s.cmdArgs||[]],{encoding:"utf-8",windowsHide:true,...p!==void 0?{input:JSON.stringify(p)}:{},...typeof o.timeoutMs=="number"&&o.timeoutMs>0?{timeout:Math.floor(o.timeoutMs)}:{},...e.howToRun==="local-process"&&process.platform==="win32"?{shell:true}:{}});if(c.error){let m=c.error instanceof Error?c.error.message:String(c.error);return R(m)}if(typeof c.status=="number"&&c.status!==0)return R(c.stderr?.trim()||`process exited ${c.status}`);let h=P(V(c.stdout||""),n);return e.outputTransforms&&h.result==="success"?$(e.outputTransforms,h,n):h}async function xe(e,r,o,t){let n=o.label||"invokeStepMachineExecutionRef",s=K(e.argsMassaging,t,n),a=s.url||l(e.whatToRun),i={"Content-Type":"application/json",...s.headers||{}},p=typeof o.timeoutMs=="number"&&o.timeoutMs>0?Math.floor(o.timeoutMs):0,c=p>0?new AbortController:null,h=c?setTimeout(()=>c.abort(),p):null;try{let m=s.body!==void 0?s.body:r,w=await fetch(a,{method:e.howToRun==="http:get"?"GET":"POST",headers:i,...e.howToRun==="http:get"?{}:{body:JSON.stringify(m)},...c?{signal:c.signal}:{}}),C=await w.text().catch(()=>"");if(!w.ok)return R(`HTTP ${w.status}: ${C||w.statusText||"request failed"}`);let b=P(V(C),n);return e.outputTransforms&&b.result==="success"?$(e.outputTransforms,b,n):b}catch(m){let w=m instanceof Error?m.message:String(m);return R(w)}finally{h&&clearTimeout(h);}}async function Ve(e,r,o={}){try{let t=we(e),n={...r&&typeof r=="object"&&!Array.isArray(r)?r:{},whatToRun:l(t.whatToRun),...t.extra?{extra:t.extra}:{}};if(t.howToRun==="local-node"||t.howToRun==="local-python"||t.howToRun==="local-process")return ye(t,r,o,n);if(t.howToRun==="http:post"||t.howToRun==="http:get")return xe(t,r,o,n);if(t.howToRun==="in-process-loop"){let s=await T(r,l(t.whatToRun)),a=P(s,o.label||"invokeStepMachineExecutionRef");return t.outputTransforms&&a.result==="success"?$(t.outputTransforms,a,o.label||"invokeStepMachineExecutionRef"):a}return R(`invokeStepMachineExecutionRef: unsupported howToRun "${t.howToRun}"`)}catch(t){let n=t instanceof Error?t.message:String(t);return R(n)}}function U(e,r){return {...r,...r.extra?{}:e.extra?{extra:e.extra}:{}}}function _(e,r){let o=Q(e.whatToRun),{cmd:t,args:n}=Ie(o),s=be(r),a=child_process.spawnSync(t,[...n,...s],{encoding:"utf-8",windowsHide:true,...typeof r.input=="string"?{input:r.input}:{}});if(a.status!==0){let i=new Error(`invokeBoardWorker: board worker exited ${a.status}: ${a.stderr?.trim()||"unknown error"}`);throw i.stdout=a.stdout??"",i.stderr=a.stderr??"",i}return G(a.stdout)}function be(e){let r=typeof e.subcommand=="string"?e.subcommand.trim():"";if(!r)throw new Error("invokeBoardWorker: request.subcommand is required");let o=[r];return typeof e.inRef=="string"&&e.inRef.trim()&&o.push("--in-ref",e.inRef.trim()),typeof e.outRef=="string"&&e.outRef.trim()&&o.push("--out-ref",e.outRef.trim()),typeof e.errRef=="string"&&e.errRef.trim()&&o.push("--err-ref",e.errRef.trim()),e.extra&&typeof e.extra=="object"&&!Array.isArray(e.extra)&&o.push("--extra",Buffer.from(JSON.stringify(e.extra)).toString("base64")),o}async function ve(e,r){return D(e,r)}function Be(e,r){return D(e,r)}function D(e,r){let o=`
|
|
24
|
+
const rawUrl = ${JSON.stringify(e)};
|
|
25
|
+
const rawBody = ${JSON.stringify(JSON.stringify(r))};
|
|
26
|
+
const u = new URL(rawUrl);
|
|
27
|
+
const mod = require(u.protocol === 'https:' ? 'https' : 'http');
|
|
28
|
+
const req = mod.request({ hostname: u.hostname, port: u.port, path: u.pathname + u.search, method: 'POST', headers: { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(rawBody) } }, (res) => {
|
|
29
|
+
let body = '';
|
|
30
|
+
res.setEncoding('utf8');
|
|
31
|
+
res.on('data', (chunk) => { body += chunk; });
|
|
32
|
+
res.on('end', () => {
|
|
33
|
+
const code = res.statusCode || 500;
|
|
34
|
+
if (code < 200 || code >= 300) {
|
|
35
|
+
process.stderr.write(body.trim() || res.statusMessage || ('HTTP ' + code));
|
|
36
|
+
process.exit(1);
|
|
37
|
+
}
|
|
38
|
+
process.stdout.write(body);
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
req.on('error', (err) => { process.stderr.write(err.message); process.exit(1); });
|
|
42
|
+
req.write(rawBody);
|
|
43
|
+
req.end();
|
|
44
|
+
`,t=child_process.spawnSync(process.execPath,["-e",o],{encoding:"utf-8",windowsHide:true});if(t.status!==0)throw new Error(`invokeBoardWorker: http-post failed: ${t.stderr?.trim()||"unknown error"}`);return G(t.stdout)}function G(e){let r=String(e||"").trim();if(!r)return {};try{return JSON.parse(r)}catch{return {stdout:r}}}function Q(e){let r=typeof e=="string"?J(e):e;if(r.kind==="yaml-flow-cli"){let o=u__namespace.default.basename(r.value.trim());if(!o)throw new Error(`Invalid yaml-flow-cli ref: expected non-empty cli file name, got ${JSON.stringify(r.value)}`);let t=u__namespace.default.dirname(M.resolve("yaml-flow/package.json")),n=o.replace(/\.[^.]+$/,""),s=u__namespace.default.join(t,"cli","bundled",`${n}.mjs`);if(f__namespace.default.existsSync(s))return s;let a=u__namespace.default.join(t,"cli","node",o);if(f__namespace.default.existsSync(a))return a;throw new Error(`Invalid yaml-flow-cli ref: could not find ${o} under cli/bundled or cli/node in ${t}`)}return r.value}function Ie(e){if(!e.endsWith(".ts"))return {cmd:process.execPath,args:[e]};let r=u__namespace.default.dirname(e),o=[];for(let n=1;n<=5;n++){let s=u__namespace.default.join(r,...Array(n).fill(".."),"node_modules");o.push(u__namespace.default.join(s,"tsx","dist","cli.mjs")),o.push(u__namespace.default.join(s,".bin","tsx"));}let t=o.find(n=>f__namespace.default.existsSync(n));return t?{cmd:process.execPath,args:[t,e]}:{cmd:"npx",args:["tsx",e]}}function Ue(e,r){let o=u__namespace.default.isAbsolute(e)?e:u__namespace.default.resolve(process.cwd(),e);return {meta:"task-executor",howToRun:"local-node",whatToRun:g({kind:"fs-path",value:o}),...r?{extra:r}:{}}}async function _e(e){let r=u__namespace.default.isAbsolute(e)?e:u__namespace.default.resolve(process.cwd(),e),o=await import(url.pathToFileURL(r).href),t=typeof o.executeTaskExecutorRequest=="function"?o.executeTaskExecutorRequest:typeof o.executeBoardWorkerRequest=="function"?o.executeBoardWorkerRequest:void 0;if(typeof t!="function")throw new Error(`Immediate board worker module must export executeTaskExecutorRequest(request) or executeBoardWorkerRequest(request): ${r}`);return t}function De(e,r={}){return async({subcommand:o,input:t,timeoutMs:n,extra:s})=>{if(typeof o!="string"||!o.trim())throw new Error("Immediate board worker hook requires subcommand");let a={...r,...s&&typeof s=="object"&&!Array.isArray(s)?s:{}};return await e({subcommand:o,...t!==void 0?{input:t}:{},...n!==void 0?{timeoutMs:n}:{},...Object.keys(a).length>0?{extra:a}:{}})}}function Ge(e,r){let{token:o,via:t}=e;if(x(t)){O(F(t),o,g(r));return}if(z(t)){j(l(t.whatToRun),o,g(r));return}if(S(t)){B({token:o,outcome:"success",ref:g(r)},l(t.whatToRun));return}throw new Error(`reportComplete: unsupported via.howToRun "${t.howToRun}"`)}function Qe(e,r){let{token:o,via:t}=e;if(x(t)){A(F(t),o,r);return}if(z(t)){H(l(t.whatToRun),o,r);return}if(S(t)){B({token:o,outcome:"failure",reason:r},l(t.whatToRun));return}throw new Error(`reportFailed: unsupported via.howToRun "${t.howToRun}"`)}exports.a=X;exports.b=Y;exports.c=ue;exports.d=de;exports.e=J;exports.f=g;exports.g=ze;exports.h=Fe;exports.i=Ke;exports.j=Ve;exports.k=Ue;exports.l=_e;exports.m=De;exports.n=Ge;exports.o=Qe;//# sourceMappingURL=chunk-H4TYOSMD.cjs.map
|
|
45
|
+
//# sourceMappingURL=chunk-H4TYOSMD.cjs.map
|