yaml-flow 8.11.5 → 8.11.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (90) hide show
  1. package/browser/adapters/localstorage-storage.js +1 -1
  2. package/browser/asset-integrity.json +4 -4
  3. package/browser/board-sse-state.js +2 -0
  4. package/browser/server-runtime-controlface.js +1 -1
  5. package/examples/board-container/board-container-lifecycle-example.js +67 -0
  6. package/lib/board-container-lifecycle-D5gz6kB1.d.cts +57 -0
  7. package/lib/board-container-lifecycle-D5gz6kB1.d.ts +57 -0
  8. package/lib/board-live-cards-node.cjs +8 -8
  9. package/lib/board-live-cards-node.d.cts +24 -9
  10. package/lib/board-live-cards-node.d.ts +24 -9
  11. package/lib/board-live-cards-node.js +8 -8
  12. package/lib/{board-live-cards-public-async-U98IXUBx.d.ts → board-live-cards-public-async-D72v-MTi.d.ts} +1 -1
  13. package/lib/{board-live-cards-public-async-Cl0M3j5P.d.cts → board-live-cards-public-async-DtgoCVRv.d.cts} +1 -1
  14. package/lib/board-live-cards-public.cjs +1 -1
  15. package/lib/board-live-cards-public.d.cts +4 -4
  16. package/lib/board-live-cards-public.d.ts +4 -4
  17. package/lib/board-live-cards-public.js +1 -1
  18. package/lib/board-live-cards-server-runtime.cjs +1 -1
  19. package/lib/board-live-cards-server-runtime.d.cts +3 -3
  20. package/lib/board-live-cards-server-runtime.d.ts +3 -3
  21. package/lib/board-live-cards-server-runtime.js +1 -1
  22. package/lib/{board-platform-adapter-async-ByBRFn1G.d.ts → board-platform-adapter-async-CVvZYqNy.d.ts} +2 -2
  23. package/lib/{board-platform-adapter-async-DjBwE0m9.d.cts → board-platform-adapter-async-O7EUvJ3W.d.cts} +2 -2
  24. package/lib/board-sse-state.cjs +2 -0
  25. package/lib/board-sse-state.d.cts +19 -0
  26. package/lib/board-sse-state.d.ts +19 -0
  27. package/lib/board-sse-state.js +2 -0
  28. package/lib/board-state-reducer.cjs +1 -1
  29. package/lib/board-state-reducer.js +1 -1
  30. package/lib/{chunk-WE7JOO4T.cjs → chunk-3XPY7CCM.cjs} +2 -2
  31. package/lib/chunk-73LKIKD3.cjs +2 -0
  32. package/lib/chunk-7SBE7A6E.cjs +2 -0
  33. package/lib/{chunk-7UJQMFVS.js → chunk-AN7MLI7X.js} +2 -2
  34. package/lib/chunk-CAQHA4GK.js +2 -0
  35. package/lib/chunk-CJQEM63S.cjs +2 -0
  36. package/lib/{chunk-WRMOGPRG.cjs → chunk-CSHNTZW4.cjs} +2 -2
  37. package/lib/chunk-F3A3ZNF6.js +2 -0
  38. package/lib/{chunk-CODPG5MY.js → chunk-HKPVF5UI.js} +3 -3
  39. package/lib/chunk-IXZV5BS5.js +2 -0
  40. package/lib/{chunk-5RUSICUC.cjs → chunk-K5TEZRZK.cjs} +3 -3
  41. package/lib/{chunk-6MD6FVE3.js → chunk-PEJRTZU3.js} +2 -2
  42. package/lib/{chunk-QKWQ4HRE.js → chunk-RKLEBQUG.js} +3 -3
  43. package/lib/{chunk-ZWXZ5DBX.cjs → chunk-TUQ6JBER.cjs} +3 -3
  44. package/lib/{chunk-BQJVCCFU.cjs → chunk-U5BGE52X.cjs} +2 -2
  45. package/lib/{chunk-HOSD6UHA.js → chunk-X32SJDLT.js} +2 -2
  46. package/lib/cloud-storage.cjs +1 -1
  47. package/lib/cloud-storage.d.cts +2 -2
  48. package/lib/cloud-storage.d.ts +2 -2
  49. package/lib/cloud-storage.js +1 -1
  50. package/lib/firestore-storage/index.cjs +1 -1
  51. package/lib/firestore-storage/index.d.cts +1 -1
  52. package/lib/firestore-storage/index.d.ts +1 -1
  53. package/lib/firestore-storage/index.js +1 -1
  54. package/lib/index.cjs +2 -2
  55. package/lib/index.d.cts +1 -0
  56. package/lib/index.d.ts +1 -0
  57. package/lib/index.js +1 -1
  58. package/lib/localstorage-storage/index.cjs +1 -1
  59. package/lib/localstorage-storage/index.d.cts +1 -1
  60. package/lib/localstorage-storage/index.d.ts +1 -1
  61. package/lib/localstorage-storage/index.js +1 -1
  62. package/lib/notification-consumer/index.cjs +1 -1
  63. package/lib/notification-consumer/index.js +1 -1
  64. package/lib/server-jobs-queue-runner/index.cjs +1 -1
  65. package/lib/server-jobs-queue-runner/index.d.cts +3 -3
  66. package/lib/server-jobs-queue-runner/index.d.ts +3 -3
  67. package/lib/server-jobs-queue-runner/index.js +1 -1
  68. package/lib/server-runtime/index.cjs +1 -1
  69. package/lib/server-runtime/index.d.cts +4 -4
  70. package/lib/server-runtime/index.d.ts +4 -4
  71. package/lib/server-runtime/index.js +1 -1
  72. package/lib/server-runtime-agentface/index.d.cts +3 -3
  73. package/lib/server-runtime-agentface/index.d.ts +3 -3
  74. package/lib/server-runtime-controlface/index.cjs +1 -1
  75. package/lib/server-runtime-controlface/index.d.cts +3 -3
  76. package/lib/server-runtime-controlface/index.d.ts +3 -3
  77. package/lib/server-runtime-controlface/index.js +1 -1
  78. package/lib/server-runtime-core/index.cjs +1 -1
  79. package/lib/server-runtime-core/index.d.cts +5 -5
  80. package/lib/server-runtime-core/index.d.ts +5 -5
  81. package/lib/server-runtime-core/index.js +1 -1
  82. package/lib/server-runtime-watchers/index.d.cts +5 -5
  83. package/lib/server-runtime-watchers/index.d.ts +5 -5
  84. package/lib/server-runtime-webhooks/index.d.cts +3 -3
  85. package/lib/server-runtime-webhooks/index.d.ts +3 -3
  86. package/lib/{sse-hub-D_QHswxL.d.ts → sse-hub-BGQWPQJP.d.ts} +1 -1
  87. package/lib/{sse-hub-XO6crN9o.d.cts → sse-hub-DViWG1m-.d.cts} +1 -1
  88. package/lib/{types-B8Yieskx.d.ts → types-D5rknZ9j.d.ts} +2 -2
  89. package/lib/{types-gTf9pAyC.d.cts → types-VIrQZ8CW.d.cts} +2 -2
  90. package/package.json +6 -1
@@ -1,3 +1,3 @@
1
1
  'use strict';var chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunkJ7KE7SPA_cjs=require('./chunk-J7KE7SPA.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function Rt(o){return typeof o=="string"&&o.trim().length>0}function Ct(o,r){if(!o||typeof o!="object")throw new Error(`${r}: adapter.selfRef is required`);if(!Rt(o.howToRun))throw new Error(`${r}: adapter.selfRef.howToRun is required`);if(!Rt(o.whatToRun))throw new Error(`${r}: adapter.selfRef.whatToRun is required`)}function kt(o,r){if(!o||typeof o!="object")throw new Error(`${r}: adapter.callbackTransport is required`);if(typeof o.createCallback!="function")throw new Error(`${r}: adapter.callbackTransport.createCallback is required`)}function $t(o,r="callbackTransport"){return {createCallback(S){let _=o();return Ct(_,r),{token:S,via:_}}}}function He(o){return $t(()=>o,"createStaticExecutionRefCallbackTransport")}function Yt(o){return He({meta:"board-live-cards",howToRun:"http:post",whatToRun:chunkVQCIOKJV_cjs.a({kind:"http-url",value:String(o||"").trim()})})}function Ut(o){return He({meta:"board-live-cards",howToRun:"in-process-loop",whatToRun:chunkVQCIOKJV_cjs.a({kind:"in-process-loop",value:String(o||"").trim()})})}function Xt(o){let r=typeof o=="string"?{notifyChannel:o}:o??{},S={};return r.notifyChannel&&(S.notifyChannel=r.notifyChannel),r.boardRuntimeStoreRef&&(S.boardRuntimeStoreRef=r.boardRuntimeStoreRef),r.queueStoreRef&&(S.queueStoreRef=r.queueStoreRef),He({meta:"board-live-cards",howToRun:"built-in",whatToRun:chunkVQCIOKJV_cjs.a({kind:"built-in",value:"board-live-cards"}),...Object.keys(S).length>0?{extra:S}:{}})}function m(o){return o!==void 0?{status:"success",data:o}:{status:"success"}}function d(o){return {status:"fail",error:o}}function g(o){return {status:"error",error:o instanceof Error?o.message:String(o)}}function Dt(o){let r=new TextEncoder().encode(o),S=Array.from(r,_=>String.fromCharCode(_)).join("");return btoa(S).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function bt(o){let r=o.replace(/-/g,"+").replace(/_/g,"/"),S=r+"=".repeat((4-r.length%4)%4),_=atob(S),E=Uint8Array.from(_,M=>M.charCodeAt(0));return new TextDecoder().decode(E)}function _e(o){try{let r=JSON.parse(bt(o));return typeof r?.t=="string"?{taskName:r.t}:null}catch{return null}}function ht(o){return Dt(JSON.stringify(o))}function St(o){try{let r=JSON.parse(bt(o));return typeof r?.cbk=="string"&&typeof r?.cid=="string"&&typeof r?.b=="string"&&typeof r?.d=="string"?r:null}catch{return null}}function N(){return new Date().toISOString()}function Vt(o){let r=new Map;return {appendEntries(S,_){if(!S||_.length===0)return;let E=r.get(S)??[];r.set(S,[...E,..._]);},dispatchEntriesForJournalId(S,_){if(!S)return;let E=r.get(S);if(!(!E||E.length===0)){for(let M of E)try{_(M);}catch(j){try{o(M,j instanceof Error?j.message:String(j));}catch{}}r.delete(S);}}}}function sr(o,r,S={}){kt(r.callbackTransport,"createBoardLiveCardsPublic");let _=r.callbackTransport,E=r.onWarn??(()=>{}),M=chunkVQCIOKJV_cjs.a(o),j=S.boardRuntimeStoreRef,G=S.scratchStoreRef,ue=S.taskExecutorRef,Re=S.chatHandlerFlow,Ce=S.emitNotification??(t=>{if(!r.publishBoardChangeNotifications)return;let e=t.kind==="notification-batch"?t.notifications:[t];return r.publishBoardChangeNotifications(e)});function te(){if(!j)throw new Error(`Board at ${o.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return j}function Fe(t){if(t.length!==0)try{let e=chunk2RIHC5TZ_cjs.e(t),s=chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:e}),i=Ce(s);i&&typeof i.catch=="function"&&i.catch(f=>E(`[board-live-cards-public] emitNotification failed: ${f instanceof Error?f.message:String(f)}`));}catch(e){E(`[board-live-cards-public] emitNotification failed: ${e instanceof Error?e.message:String(e)}`);}}function Oe(){let t=q().readCardStoreRef();if(!t)throw new Error(`Board at ${o.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let e=r.kvStorageForRef(t);return {readIndex(){return e.read("_index")},writeIndex(s){e.write("_index",s);},readCard(s){return e.read(s)},writeCard(s,i){return e.write(s,i),r.hashFn(i)},removeCard(s){e.delete(s);},cardExists(s){return e.read(s)!==null},defaultCardKey(s){return s}}}let Pe={readValues(t){let e=r.kvStorageForRef(te()),s=e.listKeys().sort();if(s.length===0)return {version:null,values:{}};let i={};for(let f of s)i[f]=e.read(f);return {version:r.hashFn(i),values:i}},writeValues(t,e,s){let i=r.kvStorageForRef(te());for(let f of s)i.delete(f);for(let[f,v]of Object.entries(e))i.write(f,v);return r.hashFn(e)}},q=()=>chunkJ7KE7SPA_cjs.t(r.kvStorageForRef(te())),re=()=>chunkJ7KE7SPA_cjs.s(Pe),ce=()=>chunkJ7KE7SPA_cjs.o(r.journalAdapterForRef(te())),l=()=>chunkJ7KE7SPA_cjs.m(Oe(),E),n=()=>{let t=q().readOutputsStoreRef();if(!t)throw new Error(`Board at ${o.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return chunkJ7KE7SPA_cjs.u(r.kvStorageForRef(t))};function u(){return ue??q().readTaskExecutorRef()}function R(){return !!re().readSnapshot(o.value).values[chunkJ7KE7SPA_cjs.q]}function y(){let t=re().readSnapshot(o.value);if(!t.values[chunkJ7KE7SPA_cjs.q])throw new Error(`Board not initialized at ${o.value}`);return chunkJ7KE7SPA_cjs.F(t.values)}function k(t,e){let s=re().commitSnapshot(o.value,{schemaVersion:chunkJ7KE7SPA_cjs.p,expectedVersion:e,commitId:r.genId(),committedAt:N(),deleteKeys:[],shallowMerge:chunkJ7KE7SPA_cjs.E(t)});if(!s.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${e??"null"} current=${s.currentVersion??"null"}`)}function p(t){ce().appendEvent(t);}async function A(){let e=Vt((a,c)=>{let h=a.payload,w=(h?.enrichedCard??{}).id??h?.cardId??"unknown";p({type:"task-failed",taskName:w,error:c,timestamp:N()});}),s=y(),i=chunkAW3COGCI_cjs.q(s.graph),{events:f,newCursor:v}=ce().readEntriesAfterCursor(s.lastDrainedJournalId),C=x(),b=chunkJ7KE7SPA_cjs.n(C,a=>r.resolveBlob(a)),I={...s.runtimeByCardId},P=new Map,Q={readRuntime(a){return P.get(a)??I[a]??{_sources:{}}},writeRuntime(a,c){P.set(a,c),I[a]=c;}},W=[],J=new Map,se={readSourceData(a,c){let h=`${a}/${c}`;return J.has(h)?J.get(h):b.readSourceData(a,c)},ingestSourceDataStaged(a,c,h,H){b.ingestSourceDataStaged(a,c,h,H);},commitSourceData(a,c,h){let H=`${a}/.staged/${h}/${c}`,w=C.read(H);if(w==null){let B=C.keyRef?.(H);B&&(w=r.resolveBlob(B));}if(w==null)return false;let L=`${a}/${c}`,X=w.trim();try{J.set(L,JSON.parse(X));}catch{J.set(L,X);}return W.push({cardId:a,outputFile:c,deliveryToken:h}),true},hasSource(a,c){let h=`${a}/${c}`;return J.has(h)?true:b.hasSource(a,c)},listSources(a){let c=b.listSources(a),h=new Set;for(let w of J.keys())w.startsWith(`${a}/`)&&h.add(w.slice(`${a}/`.length));let H=new Set([...c,...h]);return Array.from(H)}},me=()=>i.config.tasks,Z={cardStore:l(),cardRuntimeStore:Q,fetchedSourcesStore:se,outputStore:n(),executionRequestStore:e,activeTaskConfigs:()=>me()},pe=[],qe=[],je=[],$e=new Map,ze=new Set,Nt=(a,c)=>{pe.push({type:"task-completed",taskName:a,data:c,timestamp:N()});},De=(a,c)=>{p({type:"task-failed",taskName:a,error:c,timestamp:N()});},ge=chunkAW3COGCI_cjs.t(i,{handlers:{"card-handler":chunkJ7KE7SPA_cjs.C(o,v,Z,Nt,De,(a,c)=>{qe.push({cardId:a,values:c});},a=>{je.push(a);})},onNodeRemoved:a=>{$e.delete(a),P.delete(a),delete I[a],ze.add(a);}});for(me=()=>ge.getState().config.tasks,pe=f;pe.length>0;){let a=pe;pe=[];for(let c of a)if(c.type==="task-restart"){let h=Z.cardStore.readCard(c.taskName);h&&$e.set(c.taskName,h);}ge.pushAll(a),await ge.waitForHandlers();}let Qe=ge.getState();await ge.dispose({wait:true});let qt=re().readSnapshot(o.value).version;k({lastDrainedJournalId:v,graph:chunkAW3COGCI_cjs.p(Qe),runtimeByCardId:I},qt);for(let{cardId:a,values:c}of qe)Z.outputStore.writeComputedValues(a,c);for(let a of je)Z.outputStore.writeDataObjects(a);for(let{cardId:a,outputFile:c,deliveryToken:h}of W)b.commitSourceData(a,c,h);let Se;try{Se=chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(M,Qe)),Z.outputStore.writeStatusSnapshot(Se);}catch(a){E(`[board-live-cards-public] status publish failed: ${a instanceof Error?a.message:String(a)}`);}let ae=[];for(let{cardId:a,values:c}of qe)ae.push({kind:"computed_values",cardId:a,values:c});for(let a of je)for(let[c,h]of Object.entries(a))c&&ae.push({kind:"data_object",key:c,payload:h});for(let[a,c]of $e)a!==chunkJ7KE7SPA_cjs.i&&ae.push({kind:"card_refreshed",cardId:a,card:c});for(let a of ze)ae.push({kind:"card_removed",cardId:a});Se!==void 0&&ae.push({kind:"status",status:Se}),Fe(ae);let ie=u()??{howToRun:"built-in",whatToRun:chunkVQCIOKJV_cjs.a({kind:"built-in",value:"source-cli-task-executor"})},We=r.supportsDirectSourceOutput?.(ie)===true;e.dispatchEntriesForJournalId(v,a=>{if(a.taskKind!=="source-fetch"){E(`[process-accumulated-events] unknown taskKind "${a.taskKind}" \u2014 skipping`);return}let c=a.payload,h=c.enrichedCard?.id??"unknown",H=c.enrichedCard?.source_defs??[];if(ie.howToRun==="queue-storage"&&We){try{let w=r.queueStorageForRef(T(),"task-executor"),L=typeof ie.extra?.boardId=="string"?ie.extra.boardId:void 0,X=[];for(let B of H){if(!B.outputFile){E(`[dispatch] source "${B.bindTo}" has no outputFile \u2014 skipping`);continue}let be=r.genId(),ye=`${h}/.staged/${be}/${B.outputFile}`,Ze=C.keyRef?.(ye);if(!Ze)continue;let et={ref:chunkVQCIOKJV_cjs.a(Ze),deliveryToken:be,outputFile:B.outputFile,cardId:h},jt=ht({cbk:c.callbackToken,rg:o.value,br:chunkVQCIOKJV_cjs.a(o),cid:h,b:B.bindTo,d:B.outputFile,cs:void 0,rqt:c.rqt,dt:et.deliveryToken});X.push({...L?{boardId:L}:{},ref:ie,args:{source_def:B,base_ref:chunkVQCIOKJV_cjs.a(o),callback:_.createCallback(jt),output:et}});}X.length>0&&w.enqueueMany(X);}catch(w){De(h,w instanceof Error?w.message:String(w));}return}for(let w of H){if(!w.outputFile){E(`[dispatch] source "${w.bindTo}" has no outputFile \u2014 skipping`);continue}let L;if(We){let B=r.genId(),be=`${h}/.staged/${B}/${w.outputFile}`,ye=C.keyRef?.(be);ye&&(L={ref:chunkVQCIOKJV_cjs.a(ye),deliveryToken:B,outputFile:w.outputFile,cardId:h});}let X=ht({cbk:c.callbackToken,rg:o.value,br:chunkVQCIOKJV_cjs.a(o),cid:h,b:w.bindTo,d:w.outputFile,cs:void 0,rqt:c.rqt,...L?{dt:L.deliveryToken}:{}});r.dispatchExecution(ie,{source_def:w,base_ref:chunkVQCIOKJV_cjs.a(o),callback:_.createCallback(X),...L?{output:L}:{}}).catch(B=>De(h,B instanceof Error?B.message:String(B)));}});}function T(){let t=q().readQueueStoreRef();if(!t)throw new Error(`Board at ${o.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);return t}function $(){r.queueStorageForRef(T(),"process-accumulated").enqueue({boardRef:chunkVQCIOKJV_cjs.a(o)}),r.requestProcessAccumulated?.();}function F(){let t=r.queueStorageForRef(T(),"process-accumulated");for(;;){let e=t.lease({max:64,visibilityMs:1e3});if(e.length<=0)return;for(let s of e)t.ack(s.id,s.leaseToken);if(e.length<64)return}}async function U(){try{let t=()=>{let s=y(),{events:i}=ce().readEntriesAfterCursor(s.lastDrainedJournalId);i.length<=0||$();},e=await chunkVQCIOKJV_cjs.c(r.lock,A,t);return m({ran:e!==!1})}catch(t){return g(t)}}function D(){$();}function de(t){try{let e=t.params?.cardStoreRef;if(!e)return d("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(j=t.params?.boardRuntimeStoreRef,!j)return d("init requires params.boardRuntimeStoreRef \u2014 pass the board runtime store ref here");if(!R()){let P=chunkAW3COGCI_cjs.a(chunkJ7KE7SPA_cjs.D);k({lastDrainedJournalId:"",graph:chunkAW3COGCI_cjs.p(P),runtimeByCardId:{}},null);}let s=t.params?.outputsStoreRef;if(!s)return d("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let i=t.params?.queueStoreRef;if(!i)return d("init requires params.queueStoreRef \u2014 pass the queue store ref here");let f=t.params?.fetchedSourcesStoreRef;if(!f)return d("init requires params.fetchedSourcesStoreRef \u2014 pass the fetched sources store ref here");G=t.params?.scratchStoreRef;let v=t.params?.chatStoreRef;if(!v)return d("init requires params.chatStoreRef \u2014 pass the chat store ref here");let C=t.params?.artifactsStoreRef;if(!C)return d("init requires params.artifactsStoreRef \u2014 pass the artifacts store ref here");let b=q();b.writeBoardRuntimeStoreRef(j),b.writeCardStoreRef(e),b.writeOutputsStoreRef(s),b.writeQueueStoreRef(i),b.writeFetchedSourcesStoreRef(f),b.writeChatStoreRef(v),b.writeArtifactsStoreRef(C),l().writeCard(chunkJ7KE7SPA_cjs.l().id,chunkJ7KE7SPA_cjs.l());let I=V({params:{cardId:chunkJ7KE7SPA_cjs.l().id,restart:!0}});if(I.status!=="success")return I;try{n().writeStatusSnapshot(chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(M,chunkAW3COGCI_cjs.q(y().graph))));}catch{}return m()}catch(e){return g(e)}}function ne(t){try{let e=n().readStatusSnapshot();if(!e){e=chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(M,chunkAW3COGCI_cjs.q(y().graph)));try{n().writeStatusSnapshot(e);}catch{}}return m(e)}catch(e){return g(e)}}function ke(t){try{let e=t.params?.id;if(!e)return d("removeCard requires params.id");try{r.kvStorage("card-upsert").delete(e);}catch{}return p({type:"task-removal",taskName:e,timestamp:N()}),e!==chunkJ7KE7SPA_cjs.i&&p({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:N()}),D(),m()}catch(e){return g(e)}}function oe(t){try{let e=t.params?.cardId;if(!e)return d("addCardFiles requires params.cardId");let s=chunkJ7KE7SPA_cjs.H(l(),{emitNotification:Ce}).appendFiles({params:{id:e},body:t.body});return s.status!=="success"?s:m({cardId:e,files_added:s.data.files_added,notified:!0})}catch(e){return g(e)}}function he(t){try{let e=t.params?.id;return e?(p({type:"task-restart",taskName:e,timestamp:N()}),D(),m()):d("retrigger requires params.id")}catch(e){return g(e)}}async function le(t){return F(),U()}function Ne(){let t=q().readFetchedSourcesStoreRef();if(!t)throw new Error(`Board at ${o.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return t}function x(){return r.blobStorageForRef(Ne())}function V(t){try{let e=t.params?.cardId,s=t.params?.all,i=!!t.params?.restart;if(!e&&!s)return d("upsertCard requires --card-id <id> or --all");let f=s?l().readAllCards().map(C=>C.id):[e];for(let C of f)if(!l().readCard(C))return d(`Card "${C}" not found in board at ${o.value}`);let v=!1;for(let C of f){let b=l().readCard(C),I=chunkJ7KE7SPA_cjs.G(b),P=r.hashFn(I),Q=r.kvStorage("card-upsert"),W=Q.read(C),J=W?.taskConfigHash!==P;if(!(!J&&!i)){if(J){let se=W?.blobRef??l().readCardKey(C)??C;p({type:"task-upsert",taskName:C,taskConfig:I,timestamp:N()}),Q.write(C,{blobRef:se,taskConfigHash:P,updatedAt:N()}),v=v||C!==chunkJ7KE7SPA_cjs.i;}i&&p({type:"task-restart",taskName:C,timestamp:N()});}}return v&&p({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:N()}),D(),m()}catch(e){return g(e)}}function K(t){try{let e=t.params?.token;if(!e)return d("taskFailed requires params.token");let s=t.params?.error??"unknown error",i=_e(e);return i?(p({type:"task-failed",taskName:i.taskName,error:s,timestamp:N()}),D(),m()):d("Invalid callback token")}catch(e){return g(e)}}function z(t){try{let e=t.params?.token;if(!e)return d("taskProgress requires params.token");let i=(t.body??{}).update??{},f=_e(e);return f?(p({type:"task-progress",taskName:f.taskName,update:i,timestamp:N()}),D(),m()):d("Invalid callback token")}catch(e){return g(e)}}function fe(t){try{let e=t.params?.token,s=t.params?.ref;if(!e)return d("sourceDataFetched requires params.token");if(!s)return d("sourceDataFetched requires params.ref");let i=St(e);if(!i)return d("Invalid source token");let{cbk:f,cid:v,b:C,d:b,cs:I,rqt:P,dt:Q}=i,W=chunkJ7KE7SPA_cjs.n(x(),Z=>r.resolveBlob(Z)),J=Q||r.genId();Q||W.ingestSourceDataStaged(v,b,chunkVQCIOKJV_cjs.b(s),J);let se=_e(f);if(!se)return d("Invalid callback token embedded in source token");let me=N();return p({type:"task-progress",taskName:se.taskName,update:{bindTo:C,outputFile:b,fetchedAt:me,deliveryToken:J,sourceChecksum:I,rqt:P},timestamp:me}),D(),m()}catch(e){return g(e)}}function Y(t){try{let e=t.params?.token,s=t.params?.reason??"unknown";if(!e)return d("sourceDataFetchFailure requires params.token");let i=St(e);if(!i)return d("Invalid source token");let{cbk:f,b:v,d:C,cs:b,rqt:I}=i,P=_e(f);return P?(p({type:"task-progress",taskName:P.taskName,update:{bindTo:v,outputFile:C,failure:!0,reason:s,sourceChecksum:b,rqt:I},timestamp:N()}),D(),m()):d("Invalid callback token embedded in source token")}catch(e){return g(e)}}function yt(t){try{let e=q().readCardStoreRef();return e?m({storeRef:e}):d(`Board at ${o.value} has no card store configured`)}catch(e){return g(e)}}function vt(t){try{return m({storeRef:j??null})}catch(e){return g(e)}}function wt(t){try{let e=q().readOutputsStoreRef();return e?m({storeRef:e}):d(`Board at ${o.value} has no outputs store configured`)}catch(e){return g(e)}}function Tt(t){try{return m({storeRef:G??null})}catch(e){return g(e)}}function It(t){try{let e=q().readChatStoreRef();return m({storeRef:e})}catch(e){return g(e)}}function xt(t){try{let e=q().readArtifactsStoreRef();return m({storeRef:e})}catch(e){return g(e)}}function Et(t){try{let e=q().readFetchedSourcesStoreRef();return m({storeRef:e})}catch(e){return g(e)}}function At(t){try{let e=t.params?.key;if(!e)return d("getConfig requires params.key");let s=q(),i;switch(e){case "task-executor":i=ue??null;break;case "chat-handler-flow":i=Re??null;break;case "board-runtime-store-ref":i=s.readBoardRuntimeStoreRef();break;case "card-store-ref":i=s.readCardStoreRef();break;case "outputs-store-ref":i=s.readOutputsStoreRef();break;case "scratch-store-ref":i=G??null;break;case "chat-store-ref":i=s.readChatStoreRef();break;case "artifacts-store-ref":i=s.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=s.readFetchedSourcesStoreRef();break;default:return d(`getConfig: unknown key "${e}"`)}return m({value:i})}catch(e){return g(e)}}function Bt(t){try{let e=t.params?.key;if(!e)return d("getOutputsDataObject requires params.key");if(e===chunkJ7KE7SPA_cjs.h)return m(null);let s=n().readDataObject(e);return m(s)}catch(e){return g(e)}}function Ge(t){try{return m(chunkJ7KE7SPA_cjs.A(n().readAllDataObjects()))}catch(e){return g(e)}}function _t(t){try{let e=t.params?.key;if(!e)return d("getOutputsComputedValues requires params.key");let s=n().readComputedValues(e);return m(s)}catch(e){return g(e)}}function Ye(t){try{return m(n().readAllComputedValues())}catch(e){return g(e)}}function Ue(){return chunkJ7KE7SPA_cjs.n(x(),t=>r.resolveBlob(t))}function Xe(t){let e=x().keyRef?.(t);if(!e)throw new Error("configured fetched-sources store does not support keyRef");return chunkVQCIOKJV_cjs.a(e)}function Ft(t){try{let e=t.params?.key;if(!e)return d("getOutputsFetchedSources requires params.key");let s=Ue().listSources(e),i={};for(let f of s)i[f]=Xe(`${e}/${f}`);return m(i)}catch(e){return g(e)}}function Ot(t){try{let e=Ue(),s=new Set;for(let f of x().listKeys()){let v=f.indexOf("/");v>0&&!f.includes("/.staged/")&&s.add(f.slice(0,v));}let i={};for(let f of s){let v=e.listSources(f);if(v.length>0){i[f]={};for(let C of v)i[f][C]=Xe(`${f}/${C}`);}}return m(i)}catch(e){return g(e)}}function Pt(t){try{let e=l().readAllCards().filter(b=>b.id!==chunkJ7KE7SPA_cjs.i),s=ne({});if(s.status!=="success")return s;let i=Ge({});if(i.status!=="success")return i;let f=Ye({});if(f.status!=="success")return f;let v=f.data,C={};for(let b of e){let I=typeof b?.id=="string"?b.id:null;if(!I)continue;let P=b.card_data&&typeof b.card_data=="object"&&!Array.isArray(b.card_data)?b.card_data:{};C[I]={schema_version:"v1",card_id:I,card_data:{...P},computed_values:v[I]&&typeof v[I]=="object"?v[I]:{}};}return m({cardDefinitions:e,statusSnapshot:s.data,dataObjectsByToken:i.data,cardRuntimeById:C})}catch(e){return g(e)}}return {init:de,status:ne,getBoardRuntimeStoreRef:vt,getCardStoreRef:yt,getOutputsStoreRef:wt,getScratchStoreRef:Tt,getChatStoreRef:It,getArtifactsStoreRef:xt,getFetchedSourcesStoreRef:Et,getConfig:At,getOutputsDataObject:Bt,getAllOutputsDataObjects:Ge,getOutputsComputedValues:_t,getAllOutputsComputedValues:Ye,getOutputsFetchedSources:Ft,getAllOutputsFetchedSources:Ot,buildSseOneShotPayload:Pt,removeCard:ke,addCardFiles:oe,retrigger:he,processAccumulatedEvents:le,upsertCard:V,taskFailed:K,taskProgress:z,sourceDataFetched:fe,sourceDataFetchFailure:Y}}function ar(o,r,S){let _=S?.taskExecutorRef,E=()=>{if(S){if(!S.boardRuntimeStoreRef)throw new Error(`Board at ${o.value} requires boardRuntimeStoreRef for non-core runtime operations.`);return chunkJ7KE7SPA_cjs.t(r.kvStorageForRef(S.boardRuntimeStoreRef))}return chunkJ7KE7SPA_cjs.t(r.kvStorage("config"))};function M(){let l=E().readCardStoreRef();if(!l)throw new Error(`Board at ${o.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let n=r.kvStorageForRef(l);return {readIndex(){return n.read("_index")},writeIndex(u){n.write("_index",u);},readCard(u){return n.read(u)},writeCard(u,R){return n.write(u,R),r.hashFn(R)},removeCard(u){n.delete(u);},cardExists(u){return n.read(u)!==null},defaultCardKey(u){return u}}}let j=()=>chunkJ7KE7SPA_cjs.m(M(),r.onWarn??(()=>{}));function G(){return _??E().readTaskExecutorRef()}async function ue(l,n){let u=r.validateSchema(n),R=[],y=G();if(y&&Array.isArray(n.source_defs))for(let p of n.source_defs){let A=typeof p.bindTo=="string"?p.bindTo:"(unknown)";try{let T;try{T=await r.invokeExecutor(y,"validate-source-def",{timeout:r.executorTimeouts?.validationMs??1e4,input:JSON.stringify(p)});}catch(F){let U=F;if(T=typeof U?.stdout=="string"?U.stdout:"",!T.trim()){R.push(`source "${A}": executor validate-source-def failed \u2014 ${F instanceof Error?F.message:String(F)}`);continue}}let $=JSON.parse(T.trim());if(!$.ok&&Array.isArray($.errors))for(let F of $.errors)R.push(`source "${A}": ${F}`);}catch(T){R.push(`source "${A}": executor validate-source-def failed \u2014 ${T instanceof Error?T.message:String(T)}`);}}let k=[...u.errors,...R];return m({cardId:l,isValid:k.length===0,issues:k})}function Re(l,n){let u=l.params?.sourceIdx,R=l.params?.outRef;if(u===void 0)return d(`${n} requires params.sourceIdx`);if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return d(`${n} requires card JSON object in body`);let y=l.body,k=y["card-content"]??y,p=y["mock-projections"]??{},A=k.source_defs??[];if(u<0||u>=A.length)return d(`sourceIdx ${u} out of range (card has ${A.length} source(s))`);let T=A[u],$=typeof T.bindTo=="string"?T.bindTo:"source";return {src:T,bindTo:$,outRef:R,mockProjections:p}}async function Ce(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return d("validateCardPreflight requires card JSON object in body");let n=l.body,u=n["card-content"]??n,R=typeof u.id=="string"?u.id:"(unknown)";return await ue(R,u)}catch(n){return g(n)}}async function te(l){try{let n=Re(l,"probeSourcePreflight");if("status"in n)return n;let u=G();if(!u)return d("No task-executor registered for this board");try{let R={...n.src,_projections:n.mockProjections},y=await r.invokeExecutor(u,"probe-source-preflight",{timeout:n.src.timeout??r.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(R)}),k=JSON.parse(y.trim());return k.ok?m({bindTo:n.bindTo,reachable:k.reachable,latencyMs:k.latencyMs,note:k.note}):d(k.error??"Preflight probe failed")}catch{return d("Executor does not support probe-source-preflight")}}catch(n){return g(n)}}async function Fe(l){try{let n=Re(l,"runSourcePreflight");if("status"in n)return n;let u=G();if(!u)return d("No task-executor registered for this board");try{let R={...n.src,_projections:n.mockProjections},y=await r.invokeExecutor(u,"run-source-preflight",{timeout:n.src.timeout??r.executorTimeouts?.probeMs??6e4,input:JSON.stringify(R)}),k=JSON.parse(y.trim());if(!k.ok)return m({bindTo:n.bindTo,ok:!1,result:null,issues:[k.error??"Preflight run failed"]});if(n.outRef){let p=chunkVQCIOKJV_cjs.b(n.outRef);r.absoluteBlob.write(p.value,JSON.stringify(k.resultValue,null,2));}return m({bindTo:typeof k.bindTo=="string"?k.bindTo:n.bindTo,ok:!0,result:k.resultValue??null,issues:[]})}catch(R){let y=R instanceof Error?R.message:String(R);return m({bindTo:n.bindTo,ok:!1,result:null,issues:[y]})}}catch(n){return g(n)}}async function Oe(l){try{let n=G();if(!n)return d("No task-executor registered for this board");let u=await r.invokeExecutor(n,"describe-capabilities",{timeout:r.executorTimeouts?.describeMs??1e4});return m(JSON.parse(u.trim()))}catch(n){return g(n)}}function Pe(l){try{let n=l.body;if(!n||!Array.isArray(n.ops))return d("updatesInCardStore requires body.ops array");let u=n.ops,R=j();for(let y of u){let k=y.op,p=y.id;if(!p)return d('op is missing "id"');if(k==="update"){let A=y["card-content"];if(!A)return d(`update op for "${p}" is missing "card-content"`);R.writeCard(p,A);}else return d(`Unknown op type: "${k??"(none)"}"`)}return m()}catch(n){return g(n)}}function q(l){try{let n=l.body;if(!n||!Array.isArray(n.ids))return d("readFromCardStore requires body.ids array");let u=n.ids,R=j(),y=u.map(k=>({id:k,"card-content":R.readCard(k)}));return m({cards:y})}catch(n){return g(n)}}function re(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return d("evalCardCompute requires a JSON object in body");let n=l.body,u=n["card-content"]??n,R=typeof u.id=="string"?u.id:"(unknown)",y=n["mock-fetched-sources"]??{},k=n["mock-requires"]??{},p=u.compute;if(!p||!Array.isArray(p)||p.length===0)return m({cardId:R,ok:!0,computed_values:{},errors:[]});let A={id:R,card_data:u.card_data??{},requires:k,source_defs:u.source_defs,compute:p},T=chunkQBEQL4TL_cjs.a.runSync(A,{sourcesData:y}),$=T.node.computed_values??{},F=T.errors??[];return m({cardId:R,ok:F.length===0,computed_values:$,errors:F})}catch(n){return g(n)}}async function ce(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return d("simulateCardCycle requires a JSON object in body");let n=l.body,u=n["card-content"]??n,R=typeof u.id=="string"?u.id:"(unknown)",y=n["mock-fetched-sources"]??{},k=n["mock-requires"]??{},p=await ue(R,u),A=p.status==="success"?{isValid:p.data.isValid,issues:p.data.issues}:{isValid:!1,issues:[p.status==="fail"?p.error:"internal error"]},T=u.source_defs??[],$=u.card_data??{},F=[],U=[];if(T.length>0){F=chunkQBEQL4TL_cjs.a.enrichSourcesSync(T,{card_data:$,requires:k});for(let x of F){let V=x.projections,K=x._projections;if(V&&K){for(let z of Object.keys(V))if(K[z]===void 0){let fe=typeof x.bindTo=="string"?x.bindTo:"(unknown)";U.push({bindTo:fe,key:z,error:`Projection "${z}" resolved to undefined`});}}}}let D=[],de={...y},ne=n["task-executor-ref"],ke=(ne?.howToRun&&ne?.whatToRun?ne:void 0)??G();for(let x=0;x<F.length;x++){let V=F[x],K=typeof V.bindTo=="string"?V.bindTo:`source_${x}`;if(!ke){D.push({bindTo:K,skipped:!0,error:"No task executor configured"});continue}try{let z={...V},fe=await r.invokeExecutor(ke,"run-source-preflight",{timeout:V.timeout??r.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(z)}),Y=JSON.parse(fe.trim());Y.ok&&!Object.prototype.hasOwnProperty.call(y,K)&&Object.prototype.hasOwnProperty.call(Y,"resultValue")&&(de[K]=Y.resultValue),D.push({bindTo:K,reachable:Y.reachable,latencyMs:Y.latencyMs,error:Y.ok?void 0:Y.error});}catch{D.push({bindTo:K,skipped:!0,error:"Executor does not support run-source-preflight"});}}let oe=u.compute,he={},le=[];if(oe&&Array.isArray(oe)&&oe.length>0){let x={id:R,card_data:$,requires:k,source_defs:u.source_defs,compute:oe},V=chunkQBEQL4TL_cjs.a.runSync(x,{sourcesData:de});he=V.node.computed_values??{},le=V.errors??[];}let Ne=A.isValid&&U.length===0&&le.length===0&&D.every(x=>x.reachable!==!1);return m({cardId:R,ok:Ne,validation:A,source_probes:D,projection_errors:U,fetched_sources:de,computed_values:he,compute_errors:le})}catch(n){return g(n)}}return {validateCardPreflight:Ce,probeSourcePreflight:te,runSourcePreflight:Fe,evalCardCompute:re,simulateCardCycle:ce,describeTaskExecutorCapabilities:Oe,updatesInCardStore:Pe,readFromCardStore:q}}
2
- exports.a=kt;exports.b=Yt;exports.c=Ut;exports.d=Xt;exports.e=sr;exports.f=ar;//# sourceMappingURL=chunk-WE7JOO4T.cjs.map
3
- //# sourceMappingURL=chunk-WE7JOO4T.cjs.map
2
+ exports.a=kt;exports.b=Yt;exports.c=Ut;exports.d=Xt;exports.e=sr;exports.f=ar;//# sourceMappingURL=chunk-3XPY7CCM.cjs.map
3
+ //# sourceMappingURL=chunk-3XPY7CCM.cjs.map
@@ -0,0 +1,2 @@
1
+ 'use strict';function s(o){return !o||typeof o!="object"||Array.isArray(o)?null:o}function g(o){let t=s(o);return s(t?.metadata)??{}}function P(o,t){let a=g(o),d=s(s(t)?.metadata);return d?{...a,...d}:a}function C(o){let t=o.storage,a=o.hydrate,d=typeof o.resolveWorkspaceDir=="function"?o.resolveWorkspaceDir:()=>"";async function f(){return (await t.list()).map(({id:e,record:n})=>a(e,n))}async function l(r){let e=await t.get(r);return e?a(r,e):null}async function p(r){return t.has(r)}async function y(r,e,n={}){if(await t.has(r)){let i=new Error(`board '${r}' already exists`);throw i.code="EEXIST",i}let c=a(r,e);return typeof t.provision=="function"?await t.provision(r,e,n):(await t.put(r,e),n.layout==null?typeof t.removeLayout=="function"&&await t.removeLayout(r):typeof t.setLayout=="function"&&await t.setLayout(r,n.layout)),c}async function w(r,e){return y(r,e)}async function T(r,e){let n=await t.get(r);if(!n)return null;let i={...s(n)??{},metadata:{...g(n),...s(e)??{}}},u=a(r,i);return await t.set(r,i),u}async function v(r,e){let n=await t.get(r);if(!n)return null;let c=s(n),i=s(e),u={...c??{},...i??{},metadata:P(n,e)},h=a(r,u);return await t.set(r,u),h}async function L(r){return typeof t.getLayout!="function"?null:t.getLayout(r)}async function R(r,e){if(typeof t.setLayout!="function")throw new Error(`board-container storage kind '${t.kind??""}' does not support layout writes`);return await t.setLayout(r,e),e}async function k(r){typeof t.removeLayout=="function"&&await t.removeLayout(r);}async function m(r){let e=await t.get(r);if(!e)return null;let n=typeof t.archive=="function"?t.archive.bind(t):typeof t.deprecate=="function"?t.deprecate.bind(t):null;if(!n)throw new Error(`board-container storage kind '${t.kind??""}' does not support archive`);let c=a(r,e),i=d(c,e),u=await n(r,{workspaceDir:i});return u?{board:c,...u}:null}return {kind:t.kind??"board-container",storage:t,list:f,get:l,has:p,provision:y,add:w,saveMeta:T,saveRecord:v,getLayout:L,saveLayout:R,removeLayout:k,deprecate:m}}exports.a=C;//# sourceMappingURL=chunk-73LKIKD3.cjs.map
2
+ //# sourceMappingURL=chunk-73LKIKD3.cjs.map
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function b(n){return JSON.parse(JSON.stringify(n))}function k(n,i){if(n===i)return n;try{if(JSON.stringify(n)===JSON.stringify(i))return n}catch{}return i}function m(n,i){if(n===i)return true;try{return JSON.stringify(n)===JSON.stringify(i)}catch{return false}}function B(n){return n==="running"||n==="in-progress"?"loading":n==="failed"?"error":"fresh"}function O(n,i,C){let v=n,f=(v&&Array.isArray(v.cardDefinitions)?v.cardDefinitions:[]).map(p=>p.id),g=i&&i.modelsById||{},o={};for(let p of f){let t=C(n,p),a=g[p];if(!a){o[p]=t;continue}let e=t.card_chats!=null?k(a.card_chats,t.card_chats??null):a.card_chats??null,r={id:t.id,card:k(a.card,t.card),card_data:k(a.card_data,t.card_data),requires:k(a.requires,t.requires),computed_values:k(a.computed_values,t.computed_values),runtime_state:k(a.runtime_state,t.runtime_state),card_chats:e};o[p]=r.card===a.card&&r.card_data===a.card_data&&r.requires===a.requires&&r.computed_values===a.computed_values&&r.runtime_state===a.runtime_state&&r.card_chats===a.card_chats?a:r;}let y=i?.cardWatchParties||{},l=Object.fromEntries(f.filter(p=>Object.prototype.hasOwnProperty.call(y,p)).map(p=>[p,y[p]])),_=i?.pendingComputedValues||{},h=Object.fromEntries(Object.entries(_).filter(([p])=>!f.includes(p)));return {payload:n,cardIds:f,modelsById:o,cardWatchParties:l,pendingComputedValues:h}}function N(n,i={}){if(!n)return n;let C=typeof i.includeCard=="function"?i.includeCard:(()=>true),v=typeof i.mapCard=="function"?i.mapCard:(y=>y),d=false,f=[],g={};for(let y of n.cardIds){let l=n.modelsById[y];if(!l){d=true;continue}if(!C(l,n)){d=true;continue}let _=v(l,n);if(!_||_.id!==y)throw new Error(`deriveBoardState: mapped card must preserve id "${y}"`);_!==l&&(d=true),f.push(y),g[y]=_;}let o=typeof i.mapPayload=="function"?i.mapPayload(n.payload,{sourceState:n,cardIds:f,modelsById:g}):n.payload;return o!==n.payload&&(d=true),!d&&f.length===n.cardIds.length?n:{payload:o,cardIds:f,modelsById:g,cardWatchParties:n.cardWatchParties,pendingComputedValues:n.pendingComputedValues}}function j(n,i,C,v){if(!n||!Array.isArray(i)||i.length===0)return n;let d=n.modelsById,f=n.cardIds,g=n.cardWatchParties||{},o=n.pendingComputedValues||{},y=false,l=false,_={};for(let t of f){let a=d[t],e=a&&a.requires;if(e&&typeof e=="object")for(let r of Object.keys(e))(_[r]=_[r]||[]).push(t);}function h(){y||(d={...d},y=true);}function p(t){if(t.kind!=="card_watchparty"||!t.cardId||!t.channel)return;let a=g[t.cardId]||{},e=Array.isArray(a[t.channel])?a[t.channel]:[],r=e;if(t.clear){if(e.length===0)return;r=[];}else if(t.replace){let c=Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0,u={payload:t.payload,ts:c};if(e.length===1&&e[0]?.ts===u.ts&&m(e[0]?.payload,u.payload))return;r=[u];}else {let c={payload:t.payload,ts:Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0};r=[...e,c];}g={...g,[t.cardId]:{...a,[t.channel]:r}},l=true;}for(let t of i)if(!(!t||!t.kind)){if(t.kind==="card_watchparty"){p(t);continue}if(chunk2RIHC5TZ_cjs.c(t)){if(t.kind==="card_chats"){let a=t.cardId,e=d[a];if(!e)continue;let r=Array.isArray(t.messages)?t.messages:e.card_chats?.messages??[],c=typeof t.receiving=="boolean"?t.receiving:e.card_chats?.receiving??false,u=typeof t.processing=="boolean"?t.processing:e.card_chats?.processing??false,s={messages:r,receiving:c,processing:u};if(m(e.card_chats,s))continue;h(),d[a]={...e,card_chats:s},l=true;}else if(t.kind==="chat_messages"){let a=t.cardId,e=d[a];if(!e)continue;let r=Array.isArray(t.messages)?t.messages:[],c=e.card_chats||{receiving:false,processing:false},u={messages:r,receiving:c.receiving,processing:!!c.processing};if(m(e.card_chats,u))continue;h(),d[a]={...e,card_chats:u},l=true;}else if(t.kind==="chat_processing"){let a=t.cardId,e=d[a];if(!e)continue;let r=e.card_chats||{messages:[],receiving:false},c={messages:r.messages,receiving:r.receiving,processing:t.active===true};if(m(e.card_chats,c))continue;h(),d[a]={...e,card_chats:c},l=true;}continue}if(chunk2RIHC5TZ_cjs.b(t)){if(t.kind==="computed_values"){let a=t.cardId,e=d[a],r=t.values||{};if(!e){let c=o[a];if(m(c,r))continue;o={...o,[a]:b(r)},l=true;continue}if(m(e.computed_values,r))continue;h(),d[a]={...e,computed_values:r},l=true;}else if(t.kind==="data_object"){let a=t.key,e=t.payload,r=_[a]||[];for(let c of r){let u=d[c];if(!u)continue;let s=u.requires||{};m(s[a],e)||(h(),d[c]={...u,requires:{...s,[a]:e}},l=true);}}else if(t.kind==="card_refreshed"){let a=t.cardId,e=null,r=d[a],c=t.card;if(r&&c&&typeof c=="object"&&!Array.isArray(c)){let s=c,w=s.card_data&&typeof s.card_data=="object"&&!Array.isArray(s.card_data)?s.card_data:r.card_data,M=s.requires&&typeof s.requires=="object"&&!Array.isArray(s.requires)?s.requires:r.requires,P=s.computed_values&&typeof s.computed_values=="object"&&!Array.isArray(s.computed_values)?s.computed_values:r.computed_values,q=s.runtime_state&&typeof s.runtime_state=="object"&&!Array.isArray(s.runtime_state)?s.runtime_state:r.runtime_state;e={...r,card:c,card_data:w,requires:M,computed_values:P,runtime_state:q};}if(!e)try{let s=v();s&&(e=C(s,a));}catch{}if(!e)continue;let u=o[a];if(u!==void 0&&!m(e.computed_values,u)&&(e={...e,computed_values:b(u)}),r&&m(r.card,e.card)&&m(r.card_data,e.card_data)&&m(r.requires,e.requires)&&m(r.computed_values,e.computed_values)&&m(r.runtime_state,e.runtime_state))continue;h(),d[a]=e,f.includes(a)||(f=[...f,a]),Object.prototype.hasOwnProperty.call(o,a)&&(o={...o},delete o[a]),l=true;}else if(t.kind==="card_removed"){let a=t.cardId;if(!d[a])continue;if(h(),delete d[a],f=f.filter(e=>e!==a),Object.prototype.hasOwnProperty.call(g,a)){let e={...g};delete e[a],g=e;}Object.prototype.hasOwnProperty.call(o,a)&&(o={...o},delete o[a]),l=true;}else if(t.kind==="status"){let a=t.status?.cards??[];for(let e of a){let r=e?.name;if(!r||!d[r])continue;let c=d[r],u=B(e.status),s={...c.card_data||{},status:u,lastRun:e.runtime?.last_transition_at??null,...e.error?.message?{error:e.error.message}:{}};e.error?.message||delete s.error;let w={task_status:e.status??null,card_status:u,runtime:e.runtime?b(e.runtime):{},error:e.error?b(e.error):null,blocked_by:Array.isArray(e.blocked_by)?b(e.blocked_by):[],requires_missing:Array.isArray(e.requires_missing)?b(e.requires_missing):[]};m(c.card_data,s)&&m(c.runtime_state,w)||(h(),d[r]={...c,card_data:s,runtime_state:w},l=true);}}}}return l?{payload:n.payload,cardIds:f,modelsById:d,cardWatchParties:g,pendingComputedValues:o}:n}exports.a=O;exports.b=N;exports.c=j;//# sourceMappingURL=chunk-7SBE7A6E.cjs.map
2
+ //# sourceMappingURL=chunk-7SBE7A6E.cjs.map
@@ -1,2 +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-6MD6FVE3.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-7UJQMFVS.js.map
2
- //# sourceMappingURL=chunk-7UJQMFVS.js.map
1
+ import {a}from'./chunk-FOFGEABN.js';import {a as a$2,b}from'./chunk-RKKSVOP2.js';import {a as a$1}from'./chunk-PEJRTZU3.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-AN7MLI7X.js.map
2
+ //# sourceMappingURL=chunk-AN7MLI7X.js.map
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-UGB7PC4P.js';function n(i){if(!i||typeof i!="object")return false;let t=i;return typeof t.kind=="string"&&t.kind.length>0&&t.kind!=="notification-batch"}function u(i){return a(i)?i.notifications:n(i)?[i]:[]}export{n as a,u as b};//# sourceMappingURL=chunk-CAQHA4GK.js.map
2
+ //# sourceMappingURL=chunk-CAQHA4GK.js.map
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function n(i){if(!i||typeof i!="object")return false;let t=i;return typeof t.kind=="string"&&t.kind.length>0&&t.kind!=="notification-batch"}function u(i){return chunk2RIHC5TZ_cjs.a(i)?i.notifications:n(i)?[i]:[]}exports.a=n;exports.b=u;//# sourceMappingURL=chunk-CJQEM63S.cjs.map
2
+ //# sourceMappingURL=chunk-CJQEM63S.cjs.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunk7JVHYHT2_cjs=require('./chunk-7JVHYHT2.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs');function c(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function l(e){return typeof e=="string"?e.startsWith("b64:")?chunkVQCIOKJV_cjs.b(e).value:e:e.value}function m(e){return {async enqueueRequest(t){return (await e.enqueue(t)).id},async leaseRequests(t){return (await e.lease(t)).map(r=>({...c(r),leaseToken:r.leaseToken,leaseExpiresAt:r.leaseExpiresAt}))},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,a){return e.nack(t,r,a)},async peekActive(){return (await e.peekActive()).map(c)},async peekDeadLetter(){return (await e.peekDeadLetter()).map(t=>({...c(t),reason:t.reason}))}}}function h(e){async function t(r){let a=await e.read(r);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}return {async readTaskExecutorRef(){let r=await t("task-executor");if(r?.trim())return chunk7JVHYHT2_cjs.c(r.trim())},writeTaskExecutorRef(r){return e.write("task-executor",chunk7JVHYHT2_cjs.b(r))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){return e.write("chat-handler-flow",r)},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){return e.write("board-runtime-store-ref",r)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){return e.write("card-store-ref",r)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){return e.write("outputs-store-ref",r)},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){return e.write("queue-store-ref",r)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){return e.write("scratch-store-ref",r)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){return e.write("chat-store-ref",r)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){return e.write("artifacts-store-ref",r)},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){return e.write("fetched-sources-store-ref",r)}}}function y(e){let t=e.callbackTransport,r=e.resolveBlob??(async o=>{let s=await e.blobStorage("").read(o.value);if(s==null)throw new Error(`Blob not found for ref ${o.kind}:${o.value}`);return s});async function a(o,s){if(o.howToRun==="queue-storage")return e.queueStoreRef?(await m(e.queueStorageForRef(e.queueStoreRef,"task-executor")).enqueueRequest({boardId:typeof o.extra?.boardId=="string"?o.extra.boardId:e.boardId,ref:o,args:s}),{dispatched:true}):{dispatched:false,error:"queue-storage dispatch requires queueStoreRef"};if(o.howToRun==="http:post"){let n=e.fetch??globalThis.fetch;if(!n)return {dispatched:false,error:"http:post dispatch requires fetch support"};let i=await n(l(o.whatToRun),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...s,...o.extra?{extra:o.extra}:{}})});if(!i.ok){let g=await i.text().catch(()=>"");return {dispatched:false,error:`HTTP ${i.status}: ${g}`}}return {dispatched:true}}return {dispatched:false,error:`Unsupported hosted async transport "${o.howToRun}"`}}return {kvStorage:e.kvStorage,kvStorageForRef:e.kvStorageForRef,blobStorage:e.blobStorage,blobStorageForRef:e.blobStorageForRef,chatStorageForRef:e.chatStorageForRef,queueStorageForRef:e.queueStorageForRef,scratchStorage:e.scratchStorage,scratchStorageForRef:e.scratchStorageForRef,archiveFactory:e.archiveFactory,archiveFactoryForRef:e.archiveFactoryForRef,journalStorage:e.journalStorage,journalStorageForRef:e.journalStorageForRef,lock:e.lock,get callbackTransport(){return t},set callbackTransport(o){t=o;},dispatchExecution:(o,s)=>e.dispatchExecution?.(o,s)??a(o,s),supportsDirectSourceOutput:e.supportsDirectSourceOutput,resolveBlob:r,hashFn:e.hashFn,genId:e.genId,requestProcessAccumulated:e.requestProcessAccumulated,publishBoardChangeNotifications:e.publishBoardChangeNotifications,warn:e.onWarn}}exports.a=m;exports.b=h;exports.c=y;//# sourceMappingURL=chunk-WRMOGPRG.cjs.map
2
- //# sourceMappingURL=chunk-WRMOGPRG.cjs.map
1
+ 'use strict';var chunk7JVHYHT2_cjs=require('./chunk-7JVHYHT2.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs');function c(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function l(e){return typeof e=="string"?e.startsWith("b64:")?chunkVQCIOKJV_cjs.b(e).value:e:e.value}function m(e){return {async enqueueRequest(t){return (await e.enqueue(t)).id},async leaseRequests(t){return (await e.lease(t)).map(r=>({...c(r),leaseToken:r.leaseToken,leaseExpiresAt:r.leaseExpiresAt}))},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,a){return e.nack(t,r,a)},async peekActive(){return (await e.peekActive()).map(c)},async peekDeadLetter(){return (await e.peekDeadLetter()).map(t=>({...c(t),reason:t.reason}))}}}function h(e){async function t(r){let a=await e.read(r);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}return {async readTaskExecutorRef(){let r=await t("task-executor");if(r?.trim())return chunk7JVHYHT2_cjs.c(r.trim())},writeTaskExecutorRef(r){return e.write("task-executor",chunk7JVHYHT2_cjs.b(r))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){return e.write("chat-handler-flow",r)},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){return e.write("board-runtime-store-ref",r)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){return e.write("card-store-ref",r)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){return e.write("outputs-store-ref",r)},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){return e.write("queue-store-ref",r)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){return e.write("scratch-store-ref",r)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){return e.write("chat-store-ref",r)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){return e.write("artifacts-store-ref",r)},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){return e.write("fetched-sources-store-ref",r)}}}function y(e){let t=e.callbackTransport,r=e.resolveBlob??(async o=>{let s=await e.blobStorage("").read(o.value);if(s==null)throw new Error(`Blob not found for ref ${o.kind}:${o.value}`);return s});async function a(o,s){if(o.howToRun==="queue-storage")return e.queueStoreRef?(await m(e.queueStorageForRef(e.queueStoreRef,"task-executor")).enqueueRequest({boardId:typeof o.extra?.boardId=="string"?o.extra.boardId:e.boardId,ref:o,args:s}),{dispatched:true}):{dispatched:false,error:"queue-storage dispatch requires queueStoreRef"};if(o.howToRun==="http:post"){let n=e.fetch??globalThis.fetch;if(!n)return {dispatched:false,error:"http:post dispatch requires fetch support"};let i=await n(l(o.whatToRun),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...s,...o.extra?{extra:o.extra}:{}})});if(!i.ok){let g=await i.text().catch(()=>"");return {dispatched:false,error:`HTTP ${i.status}: ${g}`}}return {dispatched:true}}return {dispatched:false,error:`Unsupported hosted async transport "${o.howToRun}"`}}return {kvStorage:e.kvStorage,kvStorageForRef:e.kvStorageForRef,blobStorage:e.blobStorage,blobStorageForRef:e.blobStorageForRef,chatStorageForRef:e.chatStorageForRef,queueStorageForRef:e.queueStorageForRef,scratchStorage:e.scratchStorage,scratchStorageForRef:e.scratchStorageForRef,archiveFactory:e.archiveFactory,archiveFactoryForRef:e.archiveFactoryForRef,journalStorage:e.journalStorage,journalStorageForRef:e.journalStorageForRef,lock:e.lock,get callbackTransport(){return t},set callbackTransport(o){t=o;},dispatchExecution:(o,s)=>e.dispatchExecution?.(o,s)??a(o,s),supportsDirectSourceOutput:e.supportsDirectSourceOutput,resolveBlob:r,hashFn:e.hashFn,genId:e.genId,requestProcessAccumulated:e.requestProcessAccumulated,publishBoardChangeNotifications:e.publishBoardChangeNotifications,warn:e.onWarn}}exports.a=m;exports.b=h;exports.c=y;//# sourceMappingURL=chunk-CSHNTZW4.cjs.map
2
+ //# sourceMappingURL=chunk-CSHNTZW4.cjs.map
@@ -0,0 +1,2 @@
1
+ function s(o){return !o||typeof o!="object"||Array.isArray(o)?null:o}function g(o){let t=s(o);return s(t?.metadata)??{}}function P(o,t){let a=g(o),d=s(s(t)?.metadata);return d?{...a,...d}:a}function C(o){let t=o.storage,a=o.hydrate,d=typeof o.resolveWorkspaceDir=="function"?o.resolveWorkspaceDir:()=>"";async function f(){return (await t.list()).map(({id:e,record:n})=>a(e,n))}async function l(r){let e=await t.get(r);return e?a(r,e):null}async function p(r){return t.has(r)}async function y(r,e,n={}){if(await t.has(r)){let i=new Error(`board '${r}' already exists`);throw i.code="EEXIST",i}let c=a(r,e);return typeof t.provision=="function"?await t.provision(r,e,n):(await t.put(r,e),n.layout==null?typeof t.removeLayout=="function"&&await t.removeLayout(r):typeof t.setLayout=="function"&&await t.setLayout(r,n.layout)),c}async function w(r,e){return y(r,e)}async function T(r,e){let n=await t.get(r);if(!n)return null;let i={...s(n)??{},metadata:{...g(n),...s(e)??{}}},u=a(r,i);return await t.set(r,i),u}async function v(r,e){let n=await t.get(r);if(!n)return null;let c=s(n),i=s(e),u={...c??{},...i??{},metadata:P(n,e)},h=a(r,u);return await t.set(r,u),h}async function L(r){return typeof t.getLayout!="function"?null:t.getLayout(r)}async function R(r,e){if(typeof t.setLayout!="function")throw new Error(`board-container storage kind '${t.kind??""}' does not support layout writes`);return await t.setLayout(r,e),e}async function k(r){typeof t.removeLayout=="function"&&await t.removeLayout(r);}async function m(r){let e=await t.get(r);if(!e)return null;let n=typeof t.archive=="function"?t.archive.bind(t):typeof t.deprecate=="function"?t.deprecate.bind(t):null;if(!n)throw new Error(`board-container storage kind '${t.kind??""}' does not support archive`);let c=a(r,e),i=d(c,e),u=await n(r,{workspaceDir:i});return u?{board:c,...u}:null}return {kind:t.kind??"board-container",storage:t,list:f,get:l,has:p,provision:y,add:w,saveMeta:T,saveRecord:v,getLayout:L,saveLayout:R,removeLayout:k,deprecate:m}}export{C as a};//# sourceMappingURL=chunk-F3A3ZNF6.js.map
2
+ //# sourceMappingURL=chunk-F3A3ZNF6.js.map
@@ -1,3 +1,3 @@
1
- import {a,b}from'./chunk-JB4Q2W7I.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$5,c as c$2}from'./chunk-O5UYCGIN.js';import {p,j,k,l,c as c$1,d as d$1,m as m$1,n,e as e$2,a as a$7,b as b$3,o}from'./chunk-I3ZOFU3F.js';import {a as a$4,d as d$2,b as b$2,c as c$3}from'./chunk-FOFGEABN.js';import {a as a$b}from'./chunk-RKKSVOP2.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 as a$9,b as b$4}from'./chunk-ZJ5M5COT.js';import {i,d,c,b as b$1,g,h}from'./chunk-QKWQ4HRE.js';import {a as a$a}from'./chunk-6MD6FVE3.js';import {e,f}from'./chunk-HOSD6UHA.js';import {H,m}from'./chunk-WGYS2L4V.js';import {a as a$6}from'./chunk-BJGK5FNL.js';import {a as a$1}from'./chunk-NIBLKYXN.js';import {e as e$1}from'./chunk-UGB7PC4P.js';function ce(g){let{apiBasePath:w,json:b,readJsonBody:I,bootstrapBoard:B,createMcpControlplaneToolRegistry:$,retriggerCard:N,applyCardAction:x,resolveChatHandlerTarget:_,sendCardFileDownloadResponse:H}=g;async function E(T,S,z){let q=T.method||"GET",K=z,l=K.pathname;try{if(q==="POST"&&l===`${w}/mcp-actions`){await B();let f=Date.now(),y=new Date(f).toISOString(),k=await I(T),u=typeof k.tool=="string"?k.tool.trim():"",P=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!u)return b(S,400,{error:"tool is required"}),!0;let v=a$8(P,"card_id");if(!v)return b(S,400,{error:"MCP action requires card_id"}),!0;if(u==="retrigger-card"||u==="retrigger"){await N(v);let O=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:v,actionType:u,requestReceivedAt:y,requestReceivedAtMs:f,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:200}}),!0}let A=c$4(P,"payload");if(u==="chat-send"&&!await _(v)){let O=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${v}`,requestReceivedAt:y,requestReceivedAtMs:f,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:409}),!0}if(u==="chat-send"){let O=typeof A["turn-id"]=="string"?A["turn-id"]:typeof A.turnId=="string"?A.turnId:typeof A.turn=="string"?A.turn:"";if(!O||!String(O).trim()){let U=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${v}`,requestReceivedAt:y,requestReceivedAtMs:f,responseSentAt:new Date(U).toISOString(),responseSentAtMs:U,responseStatus:400}),!0}}await x(v,u,A);let D=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:v,actionType:u,requestReceivedAt:y,requestReceivedAtMs:f,responseSentAt:new Date(D).toISOString(),responseSentAtMs:D,responseStatus:200}}),!0}if(q==="POST"&&l===`${w}/mcp-controlplane`){await B();let f=await I(T),y=typeof f.tool=="string"?f.tool.trim():"",k=f.args&&typeof f.args=="object"&&!Array.isArray(f.args)?f.args:{};if(!y)return b(S,400,{error:"tool is required"}),!0;try{let u=await a$9(y,k,$());if(u&&typeof u=="object"&&!Array.isArray(u)){let P=u;if(P.status==="fail")return b(S,400,{error:b$4(u,"Request failed")}),!0;if(P.status==="error")return b(S,500,{error:b$4(u,"Internal error")}),!0}b(S,200,u);}catch(u){let P=typeof u?.statusCode=="number"?Number(u.statusCode):500,v=u instanceof Error?u.message:String(u);b(S,P,{error:v});}return !0}let R=l.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/retrigger$`));if(q==="POST"&&R){await B();let f=decodeURIComponent(R[1]);return await N(f),b(S,200,{ok:!0}),!0}let F=l.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/actions$`));if(q==="POST"&&F){await B();let f=decodeURIComponent(F[1]),y=Date.now(),k=new Date(y).toISOString(),u=await I(T),P=u?.actionType;if(P==="chat-send"&&!await _(f)){let A=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${f}`,requestReceivedAt:k,requestReceivedAtMs:y,responseSentAt:new Date(A).toISOString(),responseSentAtMs:A,responseStatus:409}),!0}if(P==="chat-send"){let A=u?.payload??{},D=typeof A["turn-id"]=="string"?A["turn-id"]:typeof A.turnId=="string"?A.turnId:typeof A.turn=="string"?A.turn:"";if(!D||!String(D).trim()){let O=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${f}`,requestReceivedAt:k,requestReceivedAtMs:y,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:400}),!0}}await x(f,P,u?.payload);let v=Date.now();return b(S,200,{ok:!0,requestReceivedAt:k,requestReceivedAtMs:y,responseSentAt:new Date(v).toISOString(),responseSentAtMs:v,responseStatus:200}),!0}let p=l.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/files/(\\d+)$`));if(q==="GET"&&p){let f=decodeURIComponent(p[1]),y=parseInt(p[2],10),k=K.searchParams.get("sn");return await H(S,f,y,k),!0}return !1}catch(R){let F=R?.statusCode||500;return b(S,F,{error:String(R?.message||R)}),true}}return {handleRuntimeApi:E}}var Ke=3e4;function Ve(g){let w=g.socket?.remoteAddress??"";return w==="127.0.0.1"||w==="::1"||w==="::ffff:127.0.0.1"}function ue(g){let{apiBasePath:w,emitNotifications:b,readJsonBody:I,json:B}=g,$=`${w}/notify-q`;async function N(x,_,H){if(H.pathname!==$)return false;if((x.method??"").toUpperCase()!=="POST")return B(_,405,{status:"error",error:"Method not allowed"}),true;if(!Ve(x))return B(_,403,{status:"error",error:"Forbidden"}),true;let E;try{E=await I(x);}catch{return B(_,400,{status:"error",error:"Invalid JSON body"}),true}if(!E||typeof E!="object"||!Array.isArray(E.notifications))return B(_,400,{status:"error",error:"body.notifications must be an array"}),true;let T=E.notifications,{accepted:S,rejected:z}=b$3(T,Date.now(),Ke);return S.length>0&&b(S),B(_,200,{status:"success",data:{accepted:S.length,rejected:z}}),true}return {handleNotifyRoute:N}}var le={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},de="chat-handler-flow-queue",ot="__probe__echo__probe__";function Mr(g$1){let w=String(g$1.apiBasePath||"/api/board").replace(/\/$/,""),b$3={...le,...g$1.corsHeaders||{}},I=g$1.queueLaneTuning??{},B=g$1.boardId||"",$=Number.isInteger(g$1.chatBootstrapTailTurns)&&g$1.chatBootstrapTailTurns>0?g$1.chatBootstrapTailTurns:1,N=g$1.logger||{info:console.log,warn:console.warn,error:console.error},x=g$1.invocationAdapter,_=g$1.chatFlowRunner||null,H$1=g$1.notificationTransport||null,E=g$1.serverUrl||null,T=g$1.executionExtra||{},S=g$1.onSseClientConnected,z=g$1.onSseClientDisconnected,q=g$1.onChannelSubscribed,K=g$1.onChannelUnsubscribed,l$1=a({buildChatOneShotBatch:async(t,e)=>await Q.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:z}),R=a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function F(t){function e$1(a){return {...a,queueStorageForRef(d,C){return a$6(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}function r(a){return {...a,queueStorageForRef(d,C){return h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}function n(a){return {async get(d){return a.get(d)},async set(d){return a.set(d)},async del(d){return a.del(d)},async patch(d){return a.patch(d)},async appendFiles(d){return a.appendFiles(d)}}}function o(a){return {async get(d){return await a.get(d)},async set(d){return await a.set(d)},async del(d){return await a.del(d)},async patch(d){return await a.patch(d)},async appendFiles(d){return await a.appendFiles(d)}}}let s=null;function i$1(a){if(a.kind==="notification-batch"){V(a.notifications,s??void 0);return}V([a],s??void 0);}let c$2=a$4(t.boardAdapter)?r(t.boardAdapter):e$1(t.boardAdapter),j=t.nonCoreAdapter??(!a$4(c$2)&&P(c$2)?c$2:null),h$1=a$4(c$2)?i(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}):e(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}),M=t.nonCore??(j?f(t.baseRef,j,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),We=c$2.chatStorageForRef(t.chatStoreRef),lt,Je=a$4(c$2)?(()=>{let a=d(c(b$1(c$2.kvStorageForRef(t.cardStoreRef)),c$2.hashFn),N.warn),d$1=g(a,{emitNotification:i$1}),C=o(d$1);return lt={get(m){return C.get(m)},set(m){return C.set(m)}},C})():(()=>{let a=c$2.kvStorageForRef(t.cardStoreRef),C=H(m({readIndex:()=>a.read("_index"),writeIndex:m=>a.write("_index",m),readCard:m=>a.read(m),writeCard:(m,pt)=>(a.write(m,pt),m),removeCard:m=>{a.delete(m);},cardExists:m=>a.read(m)!==null,defaultCardKey:m=>m},N.warn),{emitNotification:i$1});return lt=C,n(C)})(),ft;if(a$4(c$2)){let a=c$2.blobStorageForRef(t.artifactsStoreRef);ft={async putBytes(d,C){if(a.writeBytes){await a.writeBytes(d,C);return}let m=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(d,m);},async getBytes(d){if(a.readBytes){let m=await a.readBytes(d);if(m!==null)return m}let C=await a.read(d);if(C===null)return null;try{let m=JSON.parse(C);if(m&&m.__kind==="bytes-array"&&Array.isArray(m.data))return new Uint8Array(m.data)}catch{}return new TextEncoder().encode(C)},async listKeys(d){return await a.listKeys(d)}};}else {let a=c$2.blobStorageForRef(t.artifactsStoreRef),d=a$5(a);ft={putBytes(C,m,pt){d.putBytes(C,m,pt);},getBytes(C){return d.getBytes(C)},listKeys(C){return d.list(C).map(m=>m.key)}};}let ze={async init(a){return h$1.init(a)},async status(a){return h$1.status(a)},async getConfig(a){return h$1.getConfig(a)},async getAllOutputsDataObjects(a){return h$1.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return h$1.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return h$1.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return h$1.buildSseOneShotPayload(a)},async upsertCard(a){return h$1.upsertCard(a)},async removeCard(a){return h$1.removeCard(a)},async sourceDataFetched(a){return h$1.sourceDataFetched(a)},async sourceDataFetchFailure(a){return h$1.sourceDataFetchFailure(a)}};return s={label:t.label,board:h$1,nonCore:M,publicCardStore:lt,boardOps:ze,cardStoreOps:Je,get filesArtifacts(){return ft},get chatStorage(){return We},boardAdapter:c$2,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:c$1(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let p$1=g$1.boards.map(F),f$1=new Map;function y(t){return f$1.get(t)??0}function k$1(t){return t.queueStoreRef}function u(t,e){if(a$4(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(k$1(t),e);return a$a(n)}let r=t.boardAdapter.queueStorageForRef(k$1(t),e);return a$b(r)}function P(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function v(t){let e=p$1[y(t)];return {files:e?e.filesArtifacts:null}}function A(){return c$2()}function D(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function O(t){return "cardId"in t&&typeof t.cardId=="string"?W(t.cardId)??void 0:p$1[0]??void 0}function U(t){for(let e of t){let r=O(e);if(r)return r}return p$1[0]??void 0}function ct(t,e={}){if(!t||t.length===0)return;let r=e$1(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??U(r);if(e.appendState!==false&&o&&e$2(o.notification,n),e.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&l$1.broadcastNotificationBatch(i),s.length>0&&R.broadcastNotificationBatch(s);}if(!(e.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function V(t,e){ct(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function fe(t){if(!t||t.notificationTeardown||!H$1||!t.notifyRef)return;let e=await H$1.subscribe(t.notifyRef,r=>{let n=a$7(r);ct(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function pe(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 n=await t.boardOps.init({params:e,body:r});if(n.status!=="success")throw Object.assign(new Error(n.error||`init failed for ${t.label}`),{statusCode:500});if(await fe(t),!t.chatHandlerFlow&&t.chatHandlerRef&&x.describe)try{let o=await x.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?N.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&N.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){N.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ut(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&d$1(r.data)&&e.push({kind:"status",status:r.data});let n=await t.boardOps.getAllOutputsDataObjects({});if(n.status==="success"&&n.data!=null)for(let[s,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&ct(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function Rt(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),n=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let o of n)typeof o.id=="string"&&(f$1.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of p$1)await pe(t);}async function at(){await G();for(let t=0;t<p$1.length;t++)await ut(p$1[t]),await Rt(p$1[t],t),await ut(p$1[t]);}async function yt(t=false){t||await G();for(let e of p$1){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function W(t){return p$1[y(t)]??null}async function Y(t){let e=W(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function me(){let t=async r=>{if(!r)return [];let n=await r.cardStoreOps.get({});return n.status!=="success"||!Array.isArray(n.data?.cards)?[]:n.data.cards},e=[];for(let r of p$1)e.push(...await t(r));return e}function ht(){return p$1[0]??null}function ge(t){return W(t)??ht()}function L(t){let e=ge(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function Re(t){return await L(t).isProcessing(t)}async function tt(t,e){let r=await Q.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let Q=a$1({append(t,e,r,n,o){return L(t).append(t,e,r,n,o)},readAll(t){return L(t).readAll(t)},readAfter(t,e){return L(t).readAfter(t,e)},clear(t){return L(t).clear(t)},setProcessing(t,e){return L(t).setProcessing(t,e)},isProcessing(t){return L(t).isProcessing(t)},getConfig(t){return L(t).getConfig(t)},setConfig(t,e){return L(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);}}),wt=p({boardContexts:p$1,cardOwnerIndex:f$1,cardContextForCard:t=>W(t),readStatusSnapshot:()=>Se(),readDataObjectsByToken:()=>Ae(),readCardRuntimeArtifacts:()=>Ce(),readCardFromStore:t=>Y(t),readCardDefinitions:()=>me(),processAccumulatedLaneInternal:t=>yt(t),reportSourceFetched:(t,e)=>kt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Pt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>Ct(t,e,r,n,o),chatStorePublic:Q,serverUrl:E,apiBasePath:w}),ye=wt.mcpCardStoreFacade,st=wt.createMcpFacade,he=j({boardId:B,bootstrapBoard:()=>at(),sseHub:l$1,onChannelSubscribed:q,onChannelUnsubscribed:K,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>ye()});function we(t){return m$1(t)}function be(){return n(st())}function bt(){return o({boardId:B,uploadCardFile:Ct,getMcpFacade:()=>st(),controlplane:he})}let it=k({boardId:B,boardContexts:p$1,readChatRecords:(t,e)=>ve(t,e),getChatProcessing:t=>Re(t),chatBootstrapTailTurns:$}),Se=it.readStatusSnapshot,Ce=it.readCardRuntimeArtifacts,Ae=it.readDataObjectsByToken,dt=it.buildPublishedRuntimePayload;async function St(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=W(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await Y(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,j=e(i)||i;if(o&&JSON.stringify(j)===c)return;let h=await s.cardStoreOps.set({body:j});if(h.status!=="success")throw Object.assign(new Error(h.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let M=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(M.status!=="success")throw Object.assign(new Error(M.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Be(t,e){await St(t,e,{syncBoard:true});}async function ke(t,e){await St(t,e,{syncBoard:false});}async function Pe(t){let e=W(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await Y(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let n=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function Oe(t){let e=await Q.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await tt(t,!1);}catch{}}async function Fe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await Q.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function ve(t,e){let r=Number.isInteger(e?.tailTurns)&&e?.tailTurns>0?e?.tailTurns:void 0,n=await Q.readAll({params:{cardId:t},...r===void 0?{}:{body:{tailTurns:r}}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to read chat records for card: ${t}`),{statusCode:500});return Array.isArray(n.data?.records)?n.data.records:[]}let Ct=l({safeCardId:t=>D(t),artifactsStores:t=>v(t),cardFileMetadataStore:()=>A(),readCardFromStore:t=>Y(t),updateCardLocalOnly:(t,e)=>ke(t,e),writeChatRecord:(t,e,r,n,o)=>Fe(t,e,r,n,o)}).uploadCardFile;async function At(t){let e=W(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function xe(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function Te(t,e,r=false,n="",o=""){try{let s=await At(t);if(!s){try{await tt(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:j}=s;if(!r)try{await tt(t,!0);}catch{}let h={boardId:B,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...T,...E?{serverUrl:E}:{}},M=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:de}}:j;a$4(i.boardAdapter)?await u(i,"chat-agent").enqueueRequest({boardId:B,ref:M,args:c!=null?{...h,__chatHandlerFlow:c}:h}):u(i,"chat-agent").enqueueRequest({boardId:B,ref:M,args:c!=null?{...h,__chatHandlerFlow:c}:h}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await tt(t,!1);}catch{}N.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Ne(t,e,r){if(e.howToRun==="built-in"&&b$2(e)===de){let n=_,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:B,cardId:String(s.cardId||""),label:t.label,logger:N,serverUrl:E,executionExtra:T}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return x.invoke(e,r)}async function Ee(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?W(r):ht();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Ne(n,t.ref,t.args);if(!o.dispatched){if(r)try{await tt(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function je(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=bt(),i=xe(r?.text),c=i?i.text:r?.text,j=await a$9("manage.add-chat-entry-and-any-attachments",{board_id:B,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(j?.status!=="success")throw new Error(b$4(j,`chat-send append failed for card ${t}`));let h=j?.data?.id;if(typeof h!="string"||!h)throw new Error(`chat-send did not return an append id for card ${t}`);let M=await a$9("setstate.chat-processing-started",{board_id:B,card_id:t},s);if(M?.status!=="success")throw new Error(b$4(M,`chat-send processing update failed for card ${t}`));Te(t,h,true,o,i?.assistant||"");return}await Be(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=A().normalizeIncoming(r?.files,s);return c.length>0&&A().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...b$3,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function Bt(t,e,r){let n=await Y(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=A().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=D(t),c=v(t),j=String(s.stored_name||""),h=`${i}/${j}`,M=c.files?await c.files.getBytes(h):null;if(!M)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:M}}async function Me(t,e,r,n){let{fileRecord:o,bytes:s}=await Bt(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function _e(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 De(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
2
- `)}async function rt(t){let e=[];for await(let n of t)e.push(n);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(d$2(e)).trim();return r?JSON.parse(r):{}}async function kt(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 n=p$1[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Pt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=p$1[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let Ie=b({sseHub:l$1,queueSseHub:R,corsHeaders:b$3,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:S,onChannelSubscribed:q,onChannelUnsubscribed:K,apiBasePath:w,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>at(),boardContexts:p$1,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=a$2({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpFacade:()=>st(),createMcpToolRegistry:t=>we(t),resolveCardFileDownloadPayload:(t,e,r)=>Bt(t,e,r),isLikelyTextMimeType:t=>_e(t),sliceTextByLines:(t,e,r)=>De(t,e,r)}).handleAgentfaceApi,$e=a$3({apiBasePath:w,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>be()}).handleWebhooksApi,He=ce({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpControlplaneToolRegistry:()=>bt(),retriggerCard:t=>Pe(t),applyCardAction:(t,e,r)=>je(t,e,r),resolveChatHandlerTarget:t=>At(t),sendCardFileDownloadResponse:(t,e,r,n)=>Me(t,e,r,n)}).handleRuntimeApi,Le=ue({apiBasePath:w,emitNotifications:t=>V(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Ue(t,e,r){return !!(await qe(t,e,r)||await $e(t,e,r)||await Ie(t,e,r)||await Le(t,e,r)||await He(t,e,r))}return {get apiBasePath(){return w},get corsHeaders(){return b$3},get queueLaneTuning(){return I},handleRuntimeApi:Ue,emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);},buildPublishedRuntimePayload:dt,__drainProcessAccumulatedLane:yt,handleChatAgentRequest:Ee,clearChatRecords:Oe,reportSourceFetched(t,e){return kt(t,{ref:e})},reportSourceFetchFailure(t,e){return Pt(t,{reason:e})},get cardStore(){return p$1[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function _r(g){let w=String(g.apiBasePath||"/api/boards").replace(/\/$/,""),b={...le,...g.corsHeaders||{}},I=g.serverMetaStore,B=g.boardRuntimeFactory,$=new Map,N="boards-config.json";function x(){let l=I.getText(N);if(!l)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(l)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function _(l){I.putText(N,JSON.stringify(l,null,2));}function H(l){let R=String(l||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return R.length>0&&R.length<=64?R:null}function E(l){if($.has(l))return $.get(l);let F=x().boards.find(f=>f.id===l)||{},p=B(l,F);return $.set(l,p),p}function T(l,R,F){let p=JSON.stringify(F),f=typeof Buffer<"u"?Buffer.byteLength(p):new TextEncoder().encode(p).length;l.writeHead(R,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":f}),l.end(p);}async function S(l,R,F){let p=l.method||"GET",f=F.pathname;if(p==="GET"&&f===w)return T(R,200,{ok:true,boards:x().boards}),true;if(p==="POST"&&f===w){let y=[];for await(let O of l)y.push(O);let k=typeof Buffer<"u"?Buffer.concat(y).toString("utf-8").trim():new TextDecoder().decode(d$2(y)).trim(),u={};try{u=k?JSON.parse(k):{};}catch{u={};}let P=H(u.id);if(!P)return T(R,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let v=x();if(v.boards.some(O=>O.id===P))return T(R,409,{error:`Board "${P}" is already registered`}),true;let A=typeof u.label=="string"&&u.label.trim()?u.label.trim():P,D={id:P,label:A};for(let[O,U]of Object.entries(u))O==="id"||O==="label"||U!=null&&(D[O]=U);return v.boards.push(D),_(v),T(R,200,{ok:true,board:D}),true}return false}async function z(l,R,F){let f=F.pathname.match(new RegExp(`^${c$3(w)}/([^/]+)(/|$)`));if(!f)return false;let y=H(decodeURIComponent(f[1]));return y?x().boards.some(P=>P.id===y)?!!await E(y).handleRuntimeApi(l,R,F):(T(R,404,{error:`Board "${y}" not registered. POST ${w} with {id} to register it first.`}),true):(T(R,400,{error:"Invalid board id"}),true)}async function q(l,R,F){return !!(await S(l,R,F)||await z(l,R,F))}function K(l){if(!x().boards.some(F=>F.id===l))throw Object.assign(new Error(`Board "${l}" not registered`),{statusCode:404});return {service:E(l)}}return {get apiBasePath(){return w},get corsHeaders(){return b},handleApi:q,requireBoardService:K}}export{Mr as a,_r as b};//# sourceMappingURL=chunk-CODPG5MY.js.map
3
- //# sourceMappingURL=chunk-CODPG5MY.js.map
1
+ import {a,b}from'./chunk-JB4Q2W7I.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$5,c as c$2}from'./chunk-O5UYCGIN.js';import {p,j,k,l,c as c$1,d as d$1,m as m$1,n,e as e$2,a as a$7,b as b$3,o}from'./chunk-I3ZOFU3F.js';import {a as a$4,d as d$2,b as b$2,c as c$3}from'./chunk-FOFGEABN.js';import {a as a$b}from'./chunk-RKKSVOP2.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 as a$9,b as b$4}from'./chunk-ZJ5M5COT.js';import {i,d,c,b as b$1,g,h}from'./chunk-RKLEBQUG.js';import {a as a$a}from'./chunk-PEJRTZU3.js';import {e,f}from'./chunk-X32SJDLT.js';import {H,m}from'./chunk-WGYS2L4V.js';import {a as a$6}from'./chunk-BJGK5FNL.js';import {a as a$1}from'./chunk-NIBLKYXN.js';import {e as e$1}from'./chunk-UGB7PC4P.js';function ce(g){let{apiBasePath:w,json:b,readJsonBody:I,bootstrapBoard:B,createMcpControlplaneToolRegistry:$,retriggerCard:N,applyCardAction:x,resolveChatHandlerTarget:_,sendCardFileDownloadResponse:H}=g;async function E(T,S,z){let q=T.method||"GET",K=z,l=K.pathname;try{if(q==="POST"&&l===`${w}/mcp-actions`){await B();let f=Date.now(),y=new Date(f).toISOString(),k=await I(T),u=typeof k.tool=="string"?k.tool.trim():"",P=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!u)return b(S,400,{error:"tool is required"}),!0;let v=a$8(P,"card_id");if(!v)return b(S,400,{error:"MCP action requires card_id"}),!0;if(u==="retrigger-card"||u==="retrigger"){await N(v);let O=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:v,actionType:u,requestReceivedAt:y,requestReceivedAtMs:f,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:200}}),!0}let A=c$4(P,"payload");if(u==="chat-send"&&!await _(v)){let O=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${v}`,requestReceivedAt:y,requestReceivedAtMs:f,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:409}),!0}if(u==="chat-send"){let O=typeof A["turn-id"]=="string"?A["turn-id"]:typeof A.turnId=="string"?A.turnId:typeof A.turn=="string"?A.turn:"";if(!O||!String(O).trim()){let U=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${v}`,requestReceivedAt:y,requestReceivedAtMs:f,responseSentAt:new Date(U).toISOString(),responseSentAtMs:U,responseStatus:400}),!0}}await x(v,u,A);let D=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:v,actionType:u,requestReceivedAt:y,requestReceivedAtMs:f,responseSentAt:new Date(D).toISOString(),responseSentAtMs:D,responseStatus:200}}),!0}if(q==="POST"&&l===`${w}/mcp-controlplane`){await B();let f=await I(T),y=typeof f.tool=="string"?f.tool.trim():"",k=f.args&&typeof f.args=="object"&&!Array.isArray(f.args)?f.args:{};if(!y)return b(S,400,{error:"tool is required"}),!0;try{let u=await a$9(y,k,$());if(u&&typeof u=="object"&&!Array.isArray(u)){let P=u;if(P.status==="fail")return b(S,400,{error:b$4(u,"Request failed")}),!0;if(P.status==="error")return b(S,500,{error:b$4(u,"Internal error")}),!0}b(S,200,u);}catch(u){let P=typeof u?.statusCode=="number"?Number(u.statusCode):500,v=u instanceof Error?u.message:String(u);b(S,P,{error:v});}return !0}let R=l.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/retrigger$`));if(q==="POST"&&R){await B();let f=decodeURIComponent(R[1]);return await N(f),b(S,200,{ok:!0}),!0}let F=l.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/actions$`));if(q==="POST"&&F){await B();let f=decodeURIComponent(F[1]),y=Date.now(),k=new Date(y).toISOString(),u=await I(T),P=u?.actionType;if(P==="chat-send"&&!await _(f)){let A=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${f}`,requestReceivedAt:k,requestReceivedAtMs:y,responseSentAt:new Date(A).toISOString(),responseSentAtMs:A,responseStatus:409}),!0}if(P==="chat-send"){let A=u?.payload??{},D=typeof A["turn-id"]=="string"?A["turn-id"]:typeof A.turnId=="string"?A.turnId:typeof A.turn=="string"?A.turn:"";if(!D||!String(D).trim()){let O=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${f}`,requestReceivedAt:k,requestReceivedAtMs:y,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:400}),!0}}await x(f,P,u?.payload);let v=Date.now();return b(S,200,{ok:!0,requestReceivedAt:k,requestReceivedAtMs:y,responseSentAt:new Date(v).toISOString(),responseSentAtMs:v,responseStatus:200}),!0}let p=l.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/files/(\\d+)$`));if(q==="GET"&&p){let f=decodeURIComponent(p[1]),y=parseInt(p[2],10),k=K.searchParams.get("sn");return await H(S,f,y,k),!0}return !1}catch(R){let F=R?.statusCode||500;return b(S,F,{error:String(R?.message||R)}),true}}return {handleRuntimeApi:E}}var Ke=3e4;function Ve(g){let w=g.socket?.remoteAddress??"";return w==="127.0.0.1"||w==="::1"||w==="::ffff:127.0.0.1"}function ue(g){let{apiBasePath:w,emitNotifications:b,readJsonBody:I,json:B}=g,$=`${w}/notify-q`;async function N(x,_,H){if(H.pathname!==$)return false;if((x.method??"").toUpperCase()!=="POST")return B(_,405,{status:"error",error:"Method not allowed"}),true;if(!Ve(x))return B(_,403,{status:"error",error:"Forbidden"}),true;let E;try{E=await I(x);}catch{return B(_,400,{status:"error",error:"Invalid JSON body"}),true}if(!E||typeof E!="object"||!Array.isArray(E.notifications))return B(_,400,{status:"error",error:"body.notifications must be an array"}),true;let T=E.notifications,{accepted:S,rejected:z}=b$3(T,Date.now(),Ke);return S.length>0&&b(S),B(_,200,{status:"success",data:{accepted:S.length,rejected:z}}),true}return {handleNotifyRoute:N}}var le={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},de="chat-handler-flow-queue",ot="__probe__echo__probe__";function Mr(g$1){let w=String(g$1.apiBasePath||"/api/board").replace(/\/$/,""),b$3={...le,...g$1.corsHeaders||{}},I=g$1.queueLaneTuning??{},B=g$1.boardId||"",$=Number.isInteger(g$1.chatBootstrapTailTurns)&&g$1.chatBootstrapTailTurns>0?g$1.chatBootstrapTailTurns:1,N=g$1.logger||{info:console.log,warn:console.warn,error:console.error},x=g$1.invocationAdapter,_=g$1.chatFlowRunner||null,H$1=g$1.notificationTransport||null,E=g$1.serverUrl||null,T=g$1.executionExtra||{},S=g$1.onSseClientConnected,z=g$1.onSseClientDisconnected,q=g$1.onChannelSubscribed,K=g$1.onChannelUnsubscribed,l$1=a({buildChatOneShotBatch:async(t,e)=>await Q.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:z}),R=a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function F(t){function e$1(a){return {...a,queueStorageForRef(d,C){return a$6(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}function r(a){return {...a,queueStorageForRef(d,C){return h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}function n(a){return {async get(d){return a.get(d)},async set(d){return a.set(d)},async del(d){return a.del(d)},async patch(d){return a.patch(d)},async appendFiles(d){return a.appendFiles(d)}}}function o(a){return {async get(d){return await a.get(d)},async set(d){return await a.set(d)},async del(d){return await a.del(d)},async patch(d){return await a.patch(d)},async appendFiles(d){return await a.appendFiles(d)}}}let s=null;function i$1(a){if(a.kind==="notification-batch"){V(a.notifications,s??void 0);return}V([a],s??void 0);}let c$2=a$4(t.boardAdapter)?r(t.boardAdapter):e$1(t.boardAdapter),j=t.nonCoreAdapter??(!a$4(c$2)&&P(c$2)?c$2:null),h$1=a$4(c$2)?i(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}):e(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}),M=t.nonCore??(j?f(t.baseRef,j,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),We=c$2.chatStorageForRef(t.chatStoreRef),lt,Je=a$4(c$2)?(()=>{let a=d(c(b$1(c$2.kvStorageForRef(t.cardStoreRef)),c$2.hashFn),N.warn),d$1=g(a,{emitNotification:i$1}),C=o(d$1);return lt={get(m){return C.get(m)},set(m){return C.set(m)}},C})():(()=>{let a=c$2.kvStorageForRef(t.cardStoreRef),C=H(m({readIndex:()=>a.read("_index"),writeIndex:m=>a.write("_index",m),readCard:m=>a.read(m),writeCard:(m,pt)=>(a.write(m,pt),m),removeCard:m=>{a.delete(m);},cardExists:m=>a.read(m)!==null,defaultCardKey:m=>m},N.warn),{emitNotification:i$1});return lt=C,n(C)})(),ft;if(a$4(c$2)){let a=c$2.blobStorageForRef(t.artifactsStoreRef);ft={async putBytes(d,C){if(a.writeBytes){await a.writeBytes(d,C);return}let m=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(d,m);},async getBytes(d){if(a.readBytes){let m=await a.readBytes(d);if(m!==null)return m}let C=await a.read(d);if(C===null)return null;try{let m=JSON.parse(C);if(m&&m.__kind==="bytes-array"&&Array.isArray(m.data))return new Uint8Array(m.data)}catch{}return new TextEncoder().encode(C)},async listKeys(d){return await a.listKeys(d)}};}else {let a=c$2.blobStorageForRef(t.artifactsStoreRef),d=a$5(a);ft={putBytes(C,m,pt){d.putBytes(C,m,pt);},getBytes(C){return d.getBytes(C)},listKeys(C){return d.list(C).map(m=>m.key)}};}let ze={async init(a){return h$1.init(a)},async status(a){return h$1.status(a)},async getConfig(a){return h$1.getConfig(a)},async getAllOutputsDataObjects(a){return h$1.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return h$1.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return h$1.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return h$1.buildSseOneShotPayload(a)},async upsertCard(a){return h$1.upsertCard(a)},async removeCard(a){return h$1.removeCard(a)},async sourceDataFetched(a){return h$1.sourceDataFetched(a)},async sourceDataFetchFailure(a){return h$1.sourceDataFetchFailure(a)}};return s={label:t.label,board:h$1,nonCore:M,publicCardStore:lt,boardOps:ze,cardStoreOps:Je,get filesArtifacts(){return ft},get chatStorage(){return We},boardAdapter:c$2,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:c$1(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let p$1=g$1.boards.map(F),f$1=new Map;function y(t){return f$1.get(t)??0}function k$1(t){return t.queueStoreRef}function u(t,e){if(a$4(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(k$1(t),e);return a$a(n)}let r=t.boardAdapter.queueStorageForRef(k$1(t),e);return a$b(r)}function P(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function v(t){let e=p$1[y(t)];return {files:e?e.filesArtifacts:null}}function A(){return c$2()}function D(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function O(t){return "cardId"in t&&typeof t.cardId=="string"?W(t.cardId)??void 0:p$1[0]??void 0}function U(t){for(let e of t){let r=O(e);if(r)return r}return p$1[0]??void 0}function ct(t,e={}){if(!t||t.length===0)return;let r=e$1(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??U(r);if(e.appendState!==false&&o&&e$2(o.notification,n),e.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&l$1.broadcastNotificationBatch(i),s.length>0&&R.broadcastNotificationBatch(s);}if(!(e.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store"||i.category==="chat-store"||i.category==="hosted-runtime");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function V(t,e){ct(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function fe(t){if(!t||t.notificationTeardown||!H$1||!t.notifyRef)return;let e=await H$1.subscribe(t.notifyRef,r=>{let n=a$7(r);ct(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function pe(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 n=await t.boardOps.init({params:e,body:r});if(n.status!=="success")throw Object.assign(new Error(n.error||`init failed for ${t.label}`),{statusCode:500});if(await fe(t),!t.chatHandlerFlow&&t.chatHandlerRef&&x.describe)try{let o=await x.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?N.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&N.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){N.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ut(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&d$1(r.data)&&e.push({kind:"status",status:r.data});let n=await t.boardOps.getAllOutputsDataObjects({});if(n.status==="success"&&n.data!=null)for(let[s,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&ct(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function Rt(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),n=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let o of n)typeof o.id=="string"&&(f$1.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of p$1)await pe(t);}async function at(){await G();for(let t=0;t<p$1.length;t++)await ut(p$1[t]),await Rt(p$1[t],t),await ut(p$1[t]);}async function yt(t=false){t||await G();for(let e of p$1){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function W(t){return p$1[y(t)]??null}async function Y(t){let e=W(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function me(){let t=async r=>{if(!r)return [];let n=await r.cardStoreOps.get({});return n.status!=="success"||!Array.isArray(n.data?.cards)?[]:n.data.cards},e=[];for(let r of p$1)e.push(...await t(r));return e}function ht(){return p$1[0]??null}function ge(t){return W(t)??ht()}function L(t){let e=ge(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function Re(t){return await L(t).isProcessing(t)}async function tt(t,e){let r=await Q.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let Q=a$1({append(t,e,r,n,o){return L(t).append(t,e,r,n,o)},readAll(t){return L(t).readAll(t)},readAfter(t,e){return L(t).readAfter(t,e)},clear(t){return L(t).clear(t)},setProcessing(t,e){return L(t).setProcessing(t,e)},isProcessing(t){return L(t).isProcessing(t)},getConfig(t){return L(t).getConfig(t)},setConfig(t,e){return L(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);}}),wt=p({boardContexts:p$1,cardOwnerIndex:f$1,cardContextForCard:t=>W(t),readStatusSnapshot:()=>Se(),readDataObjectsByToken:()=>Ae(),readCardRuntimeArtifacts:()=>Ce(),readCardFromStore:t=>Y(t),readCardDefinitions:()=>me(),processAccumulatedLaneInternal:t=>yt(t),reportSourceFetched:(t,e)=>kt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Pt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>Ct(t,e,r,n,o),chatStorePublic:Q,serverUrl:E,apiBasePath:w}),ye=wt.mcpCardStoreFacade,st=wt.createMcpFacade,he=j({boardId:B,bootstrapBoard:()=>at(),sseHub:l$1,onChannelSubscribed:q,onChannelUnsubscribed:K,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>ye()});function we(t){return m$1(t)}function be(){return n(st())}function bt(){return o({boardId:B,uploadCardFile:Ct,getMcpFacade:()=>st(),controlplane:he})}let it=k({boardId:B,boardContexts:p$1,readChatRecords:(t,e)=>ve(t,e),getChatProcessing:t=>Re(t),chatBootstrapTailTurns:$}),Se=it.readStatusSnapshot,Ce=it.readCardRuntimeArtifacts,Ae=it.readDataObjectsByToken,dt=it.buildPublishedRuntimePayload;async function St(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=W(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await Y(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,j=e(i)||i;if(o&&JSON.stringify(j)===c)return;let h=await s.cardStoreOps.set({body:j});if(h.status!=="success")throw Object.assign(new Error(h.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let M=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(M.status!=="success")throw Object.assign(new Error(M.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Be(t,e){await St(t,e,{syncBoard:true});}async function ke(t,e){await St(t,e,{syncBoard:false});}async function Pe(t){let e=W(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await Y(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let n=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function Oe(t){let e=await Q.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await tt(t,!1);}catch{}}async function Fe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await Q.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function ve(t,e){let r=Number.isInteger(e?.tailTurns)&&e?.tailTurns>0?e?.tailTurns:void 0,n=await Q.readAll({params:{cardId:t},...r===void 0?{}:{body:{tailTurns:r}}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to read chat records for card: ${t}`),{statusCode:500});return Array.isArray(n.data?.records)?n.data.records:[]}let Ct=l({safeCardId:t=>D(t),artifactsStores:t=>v(t),cardFileMetadataStore:()=>A(),readCardFromStore:t=>Y(t),updateCardLocalOnly:(t,e)=>ke(t,e),writeChatRecord:(t,e,r,n,o)=>Fe(t,e,r,n,o)}).uploadCardFile;async function At(t){let e=W(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function xe(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function Te(t,e,r=false,n="",o=""){try{let s=await At(t);if(!s){try{await tt(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:j}=s;if(!r)try{await tt(t,!0);}catch{}let h={boardId:B,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...T,...E?{serverUrl:E}:{}},M=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:de}}:j;a$4(i.boardAdapter)?await u(i,"chat-agent").enqueueRequest({boardId:B,ref:M,args:c!=null?{...h,__chatHandlerFlow:c}:h}):u(i,"chat-agent").enqueueRequest({boardId:B,ref:M,args:c!=null?{...h,__chatHandlerFlow:c}:h}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await tt(t,!1);}catch{}N.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Ne(t,e,r){if(e.howToRun==="built-in"&&b$2(e)===de){let n=_,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:B,cardId:String(s.cardId||""),label:t.label,logger:N,serverUrl:E,executionExtra:T}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return x.invoke(e,r)}async function Ee(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?W(r):ht();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Ne(n,t.ref,t.args);if(!o.dispatched){if(r)try{await tt(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function je(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=bt(),i=xe(r?.text),c=i?i.text:r?.text,j=await a$9("manage.add-chat-entry-and-any-attachments",{board_id:B,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(j?.status!=="success")throw new Error(b$4(j,`chat-send append failed for card ${t}`));let h=j?.data?.id;if(typeof h!="string"||!h)throw new Error(`chat-send did not return an append id for card ${t}`);let M=await a$9("setstate.chat-processing-started",{board_id:B,card_id:t},s);if(M?.status!=="success")throw new Error(b$4(M,`chat-send processing update failed for card ${t}`));Te(t,h,true,o,i?.assistant||"");return}await Be(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=A().normalizeIncoming(r?.files,s);return c.length>0&&A().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...b$3,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function Bt(t,e,r){let n=await Y(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=A().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=D(t),c=v(t),j=String(s.stored_name||""),h=`${i}/${j}`,M=c.files?await c.files.getBytes(h):null;if(!M)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:M}}async function Me(t,e,r,n){let{fileRecord:o,bytes:s}=await Bt(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function _e(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 De(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
2
+ `)}async function rt(t){let e=[];for await(let n of t)e.push(n);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(d$2(e)).trim();return r?JSON.parse(r):{}}async function kt(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 n=p$1[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Pt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=p$1[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let Ie=b({sseHub:l$1,queueSseHub:R,corsHeaders:b$3,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:S,onChannelSubscribed:q,onChannelUnsubscribed:K,apiBasePath:w,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>at(),boardContexts:p$1,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=a$2({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpFacade:()=>st(),createMcpToolRegistry:t=>we(t),resolveCardFileDownloadPayload:(t,e,r)=>Bt(t,e,r),isLikelyTextMimeType:t=>_e(t),sliceTextByLines:(t,e,r)=>De(t,e,r)}).handleAgentfaceApi,$e=a$3({apiBasePath:w,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>be()}).handleWebhooksApi,He=ce({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpControlplaneToolRegistry:()=>bt(),retriggerCard:t=>Pe(t),applyCardAction:(t,e,r)=>je(t,e,r),resolveChatHandlerTarget:t=>At(t),sendCardFileDownloadResponse:(t,e,r,n)=>Me(t,e,r,n)}).handleRuntimeApi,Le=ue({apiBasePath:w,emitNotifications:t=>V(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Ue(t,e,r){return !!(await qe(t,e,r)||await $e(t,e,r)||await Ie(t,e,r)||await Le(t,e,r)||await He(t,e,r))}return {get apiBasePath(){return w},get corsHeaders(){return b$3},get queueLaneTuning(){return I},handleRuntimeApi:Ue,emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);},buildPublishedRuntimePayload:dt,__drainProcessAccumulatedLane:yt,handleChatAgentRequest:Ee,clearChatRecords:Oe,reportSourceFetched(t,e){return kt(t,{ref:e})},reportSourceFetchFailure(t,e){return Pt(t,{reason:e})},get cardStore(){return p$1[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function _r(g){let w=String(g.apiBasePath||"/api/boards").replace(/\/$/,""),b={...le,...g.corsHeaders||{}},I=g.serverMetaStore,B=g.boardRuntimeFactory,$=new Map,N="boards-config.json";function x(){let l=I.getText(N);if(!l)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(l)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function _(l){I.putText(N,JSON.stringify(l,null,2));}function H(l){let R=String(l||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return R.length>0&&R.length<=64?R:null}function E(l){if($.has(l))return $.get(l);let F=x().boards.find(f=>f.id===l)||{},p=B(l,F);return $.set(l,p),p}function T(l,R,F){let p=JSON.stringify(F),f=typeof Buffer<"u"?Buffer.byteLength(p):new TextEncoder().encode(p).length;l.writeHead(R,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":f}),l.end(p);}async function S(l,R,F){let p=l.method||"GET",f=F.pathname;if(p==="GET"&&f===w)return T(R,200,{ok:true,boards:x().boards}),true;if(p==="POST"&&f===w){let y=[];for await(let O of l)y.push(O);let k=typeof Buffer<"u"?Buffer.concat(y).toString("utf-8").trim():new TextDecoder().decode(d$2(y)).trim(),u={};try{u=k?JSON.parse(k):{};}catch{u={};}let P=H(u.id);if(!P)return T(R,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let v=x();if(v.boards.some(O=>O.id===P))return T(R,409,{error:`Board "${P}" is already registered`}),true;let A=typeof u.label=="string"&&u.label.trim()?u.label.trim():P,D={id:P,label:A};for(let[O,U]of Object.entries(u))O==="id"||O==="label"||U!=null&&(D[O]=U);return v.boards.push(D),_(v),T(R,200,{ok:true,board:D}),true}return false}async function z(l,R,F){let f=F.pathname.match(new RegExp(`^${c$3(w)}/([^/]+)(/|$)`));if(!f)return false;let y=H(decodeURIComponent(f[1]));return y?x().boards.some(P=>P.id===y)?!!await E(y).handleRuntimeApi(l,R,F):(T(R,404,{error:`Board "${y}" not registered. POST ${w} with {id} to register it first.`}),true):(T(R,400,{error:"Invalid board id"}),true)}async function q(l,R,F){return !!(await S(l,R,F)||await z(l,R,F))}function K(l){if(!x().boards.some(F=>F.id===l))throw Object.assign(new Error(`Board "${l}" not registered`),{statusCode:404});return {service:E(l)}}return {get apiBasePath(){return w},get corsHeaders(){return b},handleApi:q,requireBoardService:K}}export{Mr as a,_r as b};//# sourceMappingURL=chunk-HKPVF5UI.js.map
3
+ //# sourceMappingURL=chunk-HKPVF5UI.js.map
@@ -0,0 +1,2 @@
1
+ import {c,b as b$1}from'./chunk-UGB7PC4P.js';function b(n){return JSON.parse(JSON.stringify(n))}function k(n,i){if(n===i)return n;try{if(JSON.stringify(n)===JSON.stringify(i))return n}catch{}return i}function m(n,i){if(n===i)return true;try{return JSON.stringify(n)===JSON.stringify(i)}catch{return false}}function B(n){return n==="running"||n==="in-progress"?"loading":n==="failed"?"error":"fresh"}function O(n,i,C){let v=n,f=(v&&Array.isArray(v.cardDefinitions)?v.cardDefinitions:[]).map(p=>p.id),g=i&&i.modelsById||{},o={};for(let p of f){let t=C(n,p),a=g[p];if(!a){o[p]=t;continue}let e=t.card_chats!=null?k(a.card_chats,t.card_chats??null):a.card_chats??null,r={id:t.id,card:k(a.card,t.card),card_data:k(a.card_data,t.card_data),requires:k(a.requires,t.requires),computed_values:k(a.computed_values,t.computed_values),runtime_state:k(a.runtime_state,t.runtime_state),card_chats:e};o[p]=r.card===a.card&&r.card_data===a.card_data&&r.requires===a.requires&&r.computed_values===a.computed_values&&r.runtime_state===a.runtime_state&&r.card_chats===a.card_chats?a:r;}let y=i?.cardWatchParties||{},l=Object.fromEntries(f.filter(p=>Object.prototype.hasOwnProperty.call(y,p)).map(p=>[p,y[p]])),_=i?.pendingComputedValues||{},h=Object.fromEntries(Object.entries(_).filter(([p])=>!f.includes(p)));return {payload:n,cardIds:f,modelsById:o,cardWatchParties:l,pendingComputedValues:h}}function N(n,i={}){if(!n)return n;let C=typeof i.includeCard=="function"?i.includeCard:(()=>true),v=typeof i.mapCard=="function"?i.mapCard:(y=>y),d=false,f=[],g={};for(let y of n.cardIds){let l=n.modelsById[y];if(!l){d=true;continue}if(!C(l,n)){d=true;continue}let _=v(l,n);if(!_||_.id!==y)throw new Error(`deriveBoardState: mapped card must preserve id "${y}"`);_!==l&&(d=true),f.push(y),g[y]=_;}let o=typeof i.mapPayload=="function"?i.mapPayload(n.payload,{sourceState:n,cardIds:f,modelsById:g}):n.payload;return o!==n.payload&&(d=true),!d&&f.length===n.cardIds.length?n:{payload:o,cardIds:f,modelsById:g,cardWatchParties:n.cardWatchParties,pendingComputedValues:n.pendingComputedValues}}function j(n,i,C,v){if(!n||!Array.isArray(i)||i.length===0)return n;let d=n.modelsById,f=n.cardIds,g=n.cardWatchParties||{},o=n.pendingComputedValues||{},y=false,l=false,_={};for(let t of f){let a=d[t],e=a&&a.requires;if(e&&typeof e=="object")for(let r of Object.keys(e))(_[r]=_[r]||[]).push(t);}function h(){y||(d={...d},y=true);}function p(t){if(t.kind!=="card_watchparty"||!t.cardId||!t.channel)return;let a=g[t.cardId]||{},e=Array.isArray(a[t.channel])?a[t.channel]:[],r=e;if(t.clear){if(e.length===0)return;r=[];}else if(t.replace){let c=Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0,u={payload:t.payload,ts:c};if(e.length===1&&e[0]?.ts===u.ts&&m(e[0]?.payload,u.payload))return;r=[u];}else {let c={payload:t.payload,ts:Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0};r=[...e,c];}g={...g,[t.cardId]:{...a,[t.channel]:r}},l=true;}for(let t of i)if(!(!t||!t.kind)){if(t.kind==="card_watchparty"){p(t);continue}if(c(t)){if(t.kind==="card_chats"){let a=t.cardId,e=d[a];if(!e)continue;let r=Array.isArray(t.messages)?t.messages:e.card_chats?.messages??[],c=typeof t.receiving=="boolean"?t.receiving:e.card_chats?.receiving??false,u=typeof t.processing=="boolean"?t.processing:e.card_chats?.processing??false,s={messages:r,receiving:c,processing:u};if(m(e.card_chats,s))continue;h(),d[a]={...e,card_chats:s},l=true;}else if(t.kind==="chat_messages"){let a=t.cardId,e=d[a];if(!e)continue;let r=Array.isArray(t.messages)?t.messages:[],c=e.card_chats||{receiving:false,processing:false},u={messages:r,receiving:c.receiving,processing:!!c.processing};if(m(e.card_chats,u))continue;h(),d[a]={...e,card_chats:u},l=true;}else if(t.kind==="chat_processing"){let a=t.cardId,e=d[a];if(!e)continue;let r=e.card_chats||{messages:[],receiving:false},c={messages:r.messages,receiving:r.receiving,processing:t.active===true};if(m(e.card_chats,c))continue;h(),d[a]={...e,card_chats:c},l=true;}continue}if(b$1(t)){if(t.kind==="computed_values"){let a=t.cardId,e=d[a],r=t.values||{};if(!e){let c=o[a];if(m(c,r))continue;o={...o,[a]:b(r)},l=true;continue}if(m(e.computed_values,r))continue;h(),d[a]={...e,computed_values:r},l=true;}else if(t.kind==="data_object"){let a=t.key,e=t.payload,r=_[a]||[];for(let c of r){let u=d[c];if(!u)continue;let s=u.requires||{};m(s[a],e)||(h(),d[c]={...u,requires:{...s,[a]:e}},l=true);}}else if(t.kind==="card_refreshed"){let a=t.cardId,e=null,r=d[a],c=t.card;if(r&&c&&typeof c=="object"&&!Array.isArray(c)){let s=c,w=s.card_data&&typeof s.card_data=="object"&&!Array.isArray(s.card_data)?s.card_data:r.card_data,M=s.requires&&typeof s.requires=="object"&&!Array.isArray(s.requires)?s.requires:r.requires,P=s.computed_values&&typeof s.computed_values=="object"&&!Array.isArray(s.computed_values)?s.computed_values:r.computed_values,q=s.runtime_state&&typeof s.runtime_state=="object"&&!Array.isArray(s.runtime_state)?s.runtime_state:r.runtime_state;e={...r,card:c,card_data:w,requires:M,computed_values:P,runtime_state:q};}if(!e)try{let s=v();s&&(e=C(s,a));}catch{}if(!e)continue;let u=o[a];if(u!==void 0&&!m(e.computed_values,u)&&(e={...e,computed_values:b(u)}),r&&m(r.card,e.card)&&m(r.card_data,e.card_data)&&m(r.requires,e.requires)&&m(r.computed_values,e.computed_values)&&m(r.runtime_state,e.runtime_state))continue;h(),d[a]=e,f.includes(a)||(f=[...f,a]),Object.prototype.hasOwnProperty.call(o,a)&&(o={...o},delete o[a]),l=true;}else if(t.kind==="card_removed"){let a=t.cardId;if(!d[a])continue;if(h(),delete d[a],f=f.filter(e=>e!==a),Object.prototype.hasOwnProperty.call(g,a)){let e={...g};delete e[a],g=e;}Object.prototype.hasOwnProperty.call(o,a)&&(o={...o},delete o[a]),l=true;}else if(t.kind==="status"){let a=t.status?.cards??[];for(let e of a){let r=e?.name;if(!r||!d[r])continue;let c=d[r],u=B(e.status),s={...c.card_data||{},status:u,lastRun:e.runtime?.last_transition_at??null,...e.error?.message?{error:e.error.message}:{}};e.error?.message||delete s.error;let w={task_status:e.status??null,card_status:u,runtime:e.runtime?b(e.runtime):{},error:e.error?b(e.error):null,blocked_by:Array.isArray(e.blocked_by)?b(e.blocked_by):[],requires_missing:Array.isArray(e.requires_missing)?b(e.requires_missing):[]};m(c.card_data,s)&&m(c.runtime_state,w)||(h(),d[r]={...c,card_data:s,runtime_state:w},l=true);}}}}return l?{payload:n.payload,cardIds:f,modelsById:d,cardWatchParties:g,pendingComputedValues:o}:n}export{O as a,N as b,j as c};//# sourceMappingURL=chunk-IXZV5BS5.js.map
2
+ //# sourceMappingURL=chunk-IXZV5BS5.js.map
@@ -1,3 +1,3 @@
1
- 'use strict';var chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkWE7JOO4T_cjs=require('./chunk-WE7JOO4T.cjs'),chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunkJ7KE7SPA_cjs=require('./chunk-J7KE7SPA.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');async function mt(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function Pt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Pe(e,o){return Pt(e)?e.then(o):o(e)}function lt(e,o){let a={...e};for(let[r,s]of Object.entries(o))s!==null&&typeof s=="object"&&!Array.isArray(s)&&a[r]!==null&&typeof a[r]=="object"&&!Array.isArray(a[r])?a[r]=lt(a[r],s):a[r]=s;return a}function ve(e,o,a){if(o.length===0)return e;let[r,...s]=o;if(s.length===0)return {...e,[r]:a};let d=e[r]!==null&&typeof e[r]=="object"&&!Array.isArray(e[r])?e[r]:{};return {...e,[r]:ve(d,s,a)}}function ft(e){return {read:a=>e.read(a),get(a,r){return Pe(e.read(a),s=>{if(s===null)return null;let d=s;for(let f of r.split(".").filter(Boolean)){if(d===null||typeof d!="object"||Array.isArray(d))return null;d=d[f]??null;}return d??null})},write:(a,r)=>e.write(a,r),delete:a=>e.delete(a),listKeys:a=>e.listKeys(a),shallowMerge(a,r){return Pe(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return Pe(e.read(a),s=>e.write(a,lt(s??{},r)))},patch(a,r,s){return Pe(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,ve(d??{},f,s))})}}}function gt(e){return ft(e)}function pt(e,o){return {async readIndex(){return await e.read("_index")},writeIndex(a){return e.write("_index",a)},async readCard(a){return await e.read(a)},async writeCard(a,r){return await e.write(a,r),o(r)},removeCard(a){return e.delete(a)},async cardExists(a){return await e.read(a)!==null},defaultCardKey(a){return a}}}function yt(e,o){async function a(){return await e.readIndex()??{}}return {async readCard(r){let s=(await a())[r];return !s||!await e.cardExists(s.key)?null:await e.readCard(s.key)},async readCardKey(r){return (await a())[r]?.key??null},async readAllCards(){let r=[];for(let[s,d]of Object.entries(await a())){if(!await e.cardExists(d.key))continue;let f=await e.readCard(d.key);f?r.push(f):o?.(`[card-store] could not read card "${s}" at key "${d.key}"`);}return r},async readChecksumIndex(){let r={};for(let[s,d]of Object.entries(await a()))r[s]=d.checksum;return r},async changedSince(r){let s=await a(),d=[];for(let[f,v]of Object.entries(s))r[f]!==v.checksum&&d.push(f);for(let f of Object.keys(r))s[f]||d.push(f);return d},async validateUpsert(r,s){let d=await a(),f=d[r],v=Object.entries(d).find(([,w])=>w.key===s);return f&&f.key!==s?{ok:false,error:`Card id "${r}" is already mapped to key "${f.key}", cannot remap to "${s}"`}:v&&v[0]!==r?{ok:false,error:`Key "${s}" is already mapped to card id "${v[0]}", cannot remap to "${r}"`}:{ok:true}},async writeCard(r,s,d){let f=await a(),v=d??f[r]?.key??e.defaultCardKey(r),w=await e.writeCard(v,s);f[r]={key:v,checksum:w,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async patchCard(r,s,d){let f=await a(),v=f[r];if(!v||!await e.cardExists(v.key))throw new Error(`card "${r}" not found`);let w=await e.readCard(v.key);if(!w||typeof w!="object"||Array.isArray(w))throw new Error(`card "${r}" is not patchable`);let m=String(s||"").split(".").filter(Boolean),l=ve(w,m,d),S=await e.writeCard(v.key,l);f[r]={key:v.key,checksum:S,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async removeCard(r){let s=await a(),d=s[r];d&&(await e.removeCard(d.key),delete s[r],await e.writeIndex(s));},readIndex(){return a()}}}function Nt(e,o){return chunkJ7KE7SPA_cjs.a(e,o)}function _t(e,o,a){return {blob:e,kv:o,journal:a}}function St(e,o={}){function a(m){return {status:"success",data:m}}function r(m){return {status:"fail",error:m}}function s(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}async function d(m){let l=o.emitNotification;if(!l||m.length===0)return;let S=chunk2RIHC5TZ_cjs.e(m);if(S.length===1){await l(S[0]);return}await l(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:S}));}async function f(m){let l=m.params?.id;if(l){let S=await e.readCard(l);if(!S)throw new Error(`card "${l}" not found`);return [S]}return await e.readAllCards()}function v(m){return chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:chunk2RIHC5TZ_cjs.e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function w(m){if(Array.isArray(m))return m;if(m&&typeof m=="object"){let l=m;return Array.isArray(l.files)?l.files:[m]}return null}return {async get(m){try{return a({cards:await f(m)})}catch(l){return s(l)}},async buildNotificationBatch(m){try{return a(v(await f(m)))}catch(l){return s(l)}},async set(m){try{let l=m.body;if(l==null)return r("set requires a body (card object or array of cards)");let S=Array.isArray(l)?l:[l];for(let h of S){if(typeof h.id!="string")return r("each card must have a string `id` field");await e.writeCard(h.id,h);}return await d(S.map(h=>({kind:"card_refreshed",cardId:h.id,card:h}))),a({count:S.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],S=m.params?.id,h=S?[...l,S]:l;if(h.length===0)return r("del requires body.ids (string[]) or params.id");for(let N of h)await e.removeCard(N);return await d(h.map(N=>({kind:"card_removed",cardId:N}))),a({count:h.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,S=m.params?.path;if(!l)return r("patch requires params.id");if(!S)return r("patch requires params.path");let h=m.body,N=h&&Object.prototype.hasOwnProperty.call(h,"value")?h.value:m.body;await e.patchCard(l,S,N);let O=await e.readCard(l);return O?(await d([{kind:"card_refreshed",cardId:l,card:O}]),a({count:1})):r(`card "${l}" not found`)}catch(l){return s(l)}},async appendFiles(m){try{let l=m.params?.id;if(!l)return r("appendFiles requires params.id");let S=await e.readCard(l);if(!S)return r(`card "${l}" not found`);let h=w(m.body);if(!h||h.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let N=S.card_data&&typeof S.card_data=="object"&&!Array.isArray(S.card_data)?S.card_data:{},O=Array.isArray(N.files)?N.files:[],M=[...O,...h],V=h.map(($,Z)=>({idx:O.length+Z,entry:$})),K=await this.patch({params:{id:l,path:"card_data.files"},body:{value:M}});return K.status!=="success"?K:a({files_added:V})}catch(l){return s(l)}}}}async function vt(e,o){return (await e.peekActive()).find(a=>a.id===o)}function $t(e,o={}){async function a(r){let s=o.emitNotification;if(!s||r.length===0)return;let d=chunk2RIHC5TZ_cjs.e(r);if(d.length===1){await s(d[0]);return}await s(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:d}));}return {async enqueue(r){let s=await e.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await e.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:e.enqueueIfAbsent?async(r,s)=>{let d=await e.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return e.lease(r)},ack(r,s){return e.ack(r,s)},nack(r,s,d){return e.nack(r,s,d)},peekActive(r){return e.peekActive(r)},peekDeadLetter(r){return e.peekDeadLetter(r)},async stage(r,s){return e.stage(r,s)},async commitStaged(r){let s=await e.commitStaged(r);if(s){let d=await vt(e,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return e.discardStaged(r,s)},peekStaged(r){return e.peekStaged(r)}}}function b(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function T(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function q(){return new Date().toISOString()}function bt(e){let o=new TextEncoder().encode(e),a=Array.from(o,r=>String.fromCharCode(r)).join("");return btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Rt(e){let o=e.replace(/-/g,"+").replace(/_/g,"/"),a=o+"=".repeat((4-o.length%4)%4),r=atob(a),s=Uint8Array.from(r,d=>d.charCodeAt(0));return new TextDecoder().decode(s)}function be(e){try{let o=JSON.parse(Rt(e));return typeof o?.t=="string"?{taskName:o.t}:null}catch{return null}}function kt(e){return bt(JSON.stringify(e))}function Ct(e){try{let o=JSON.parse(Rt(e));return typeof o?.cbk=="string"&&typeof o?.cid=="string"&&typeof o?.b=="string"&&typeof o?.d=="string"?o:null}catch{return null}}function At(e){return chunkJ7KE7SPA_cjs.f(e,chunkJ7KE7SPA_cjs.r,()=>({_sources:{}}))}function It(e,o){return chunkJ7KE7SPA_cjs.d(e,o)}function xt(e){return chunkJ7KE7SPA_cjs.g(e)}function Tt(e,o){return chunkJ7KE7SPA_cjs.e(e,o)}function Ot(e,o,a,r,s,d){return async f=>{let v=[],w=await a.cardStore.readCard(f.nodeId);if(!w)return "task-initiate-failure";let m=w.id;if(m===chunkJ7KE7SPA_cjs.i){let p=a.activeTaskConfigs?.(),y={[chunkJ7KE7SPA_cjs.h]:p?chunkJ7KE7SPA_cjs.k((await Promise.all(Object.keys(p).filter(k=>k!==chunkJ7KE7SPA_cjs.i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await chunkJ7KE7SPA_cjs.j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w.card_data??{},S=w.source_defs??[],h=S,N=await a.cardRuntimeStore.readRuntime(m),O=false,M=async()=>{O&&(await a.cardRuntimeStore.writeRuntime(m,N),O=false);},V=p=>chunkJ7KE7SPA_cjs.v(N._sources[p]),K=(p,y)=>{N._sources[p]=chunkJ7KE7SPA_cjs.v(y),O=true;},$=f.taskState?.executionCount??0;if(N._lastExecutionCount!==$&&(N._sources={},N._lastExecutionCount=$,O=true),f.update){let p=f.update.outputFile;if(p){let y=V(p);if(f.update.failure){let k=f.update.rqt??y.lastRequestedToken??y.queueRequestedToken;k&&K(p,chunkJ7KE7SPA_cjs.y(y,k));}else {let k=f.update.rqt;if(!y.lastCompletedToken||k>y.lastCompletedToken){let j=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,re=j?await a.fetchedSourcesStore.commitSourceData(m,p,j):false;K(p,re?chunkJ7KE7SPA_cjs.x(y,k):chunkJ7KE7SPA_cjs.y(y,k));}}await M();}}let Z={};for(let p of S){if(!p.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,p.outputFile);y!==null&&(Z[p.bindTo]=y);}let H={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];H[p]=k!==void 0?k:y;}else H[p]=y;let ee={id:m,card_data:{...l},requires:H,source_defs:S,compute:w.compute};ee._sourcesData=Z,w.compute&&chunkQBEQL4TL_cjs.a.runSync(ee,{sourcesData:Z}),(s??(()=>{}))(m,ee.computed_values??{});let te=chunkQBEQL4TL_cjs.a.enrichSourcesSync(Array.isArray(w.source_defs)?w.source_defs:void 0,{card_data:w.card_data,requires:H}),Ae={...w,source_defs:Array.isArray(te)?te.map(p=>({...p,boardDir:typeof p.boardDir=="string"&&p.boardDir?p.boardDir:e.value})):te},W=q(),E=f.update?void 0:W,ge=h.filter(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return true;let k=V(y);E&&(k={...k,queueRequestedToken:E},K(y,k));let j=k.queueRequestedToken??k.lastRequestedToken??W;return chunkJ7KE7SPA_cjs.w(k,j)==="dispatch"});if(await M(),ge.length>0){let p=false,y=W;for(let k of ge){let j=k.outputFile;if(typeof j!="string"||!j)continue;let re=V(j),L=re.queueRequestedToken??W;K(j,{...re,lastRequestedToken:L}),y=L,p=true;}return p&&await M(),p&&(v.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(e),enrichedCard:Ae,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v)),"task-initiated"}if(h.some(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return false;let k=V(y),j=k.queueRequestedToken??k.lastRequestedToken??W;return chunkJ7KE7SPA_cjs.w(k,j)==="in-flight"}))return "task-initiated";let ie=w.provides??[],ue={};for(let{bindTo:p,ref:y}of ie)ue[p]=chunkQBEQL4TL_cjs.a.resolve(ee,y);return (d??(()=>{}))(ue),r(f.nodeId,ue),v.length>0&&await a.executionRequestStore.appendEntries(o,v),"task-initiated"}}function nr(e,o,a={}){chunkWE7JOO4T_cjs.a(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=chunkVQCIOKJV_cjs.a(e),f=a.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),v=null,w=a.boardRuntimeStoreRef,m=a.scratchStoreRef,l=a.taskExecutorRef,S=a.chatHandlerFlow;function h(){if(!w)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return w}function N(n){if(n.length!==0)try{let t=chunk2RIHC5TZ_cjs.e(n),c=chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:t});return Promise.resolve(f(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(t){s(`[async-board-live-cards-public] emitNotification failed: ${t instanceof Error?t.message:String(t)}`);return}}let O=()=>chunkWRMOGPRG_cjs.b(o.kvStorageForRef(h())),M=e.value,V=()=>chunkJ7KE7SPA_cjs.b(chunkJ7KE7SPA_cjs.a(()=>o.kvStorageForRef(h()),o.hashFn),"v1"),K=async()=>{let n=await O().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e.value} has no outputs store configured.`);return xt(o.kvStorageForRef(n))},$=async()=>{let n=await O().readCardStoreRef();if(!n)throw new Error(`Board at ${e.value} has no card store configured.`);let t=o.kvStorageForRef(n);return yt(pt(gt(t),o.hashFn),s)};async function Z(){return !!(await V().readSnapshot(M)).values[chunkJ7KE7SPA_cjs.q]}async function H(){let n=await V().readSnapshot(M);if(!n.values[chunkJ7KE7SPA_cjs.q])throw new Error(`Board not initialized at ${e.value}`);return chunkJ7KE7SPA_cjs.F(n.values)}async function ee(n,t){let c=await V().commitSnapshot(M,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:chunkJ7KE7SPA_cjs.E(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let te=()=>chunkJ7KE7SPA_cjs.c(o.journalStorageForRef(h()));async function Ae(){return l??await O().readTaskExecutorRef()}async function W(){return chunkJ7KE7SPA_cjs.A(await(await K()).readAllDataObjects())}async function E(n){await te().appendEvent(n);}async function ge(){let n=await O().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function le(){return o.blobStorageForRef(await ge())}async function ie(){return It(await le(),n=>o.resolveBlob(n))}async function ue(n){let t=(await le()).keyRef?.(n);if(!t)throw new Error("configured fetched-sources store does not support keyRef");let c=await Promise.resolve(t);return chunkVQCIOKJV_cjs.a(c)}async function p(){let n=Tt(o.kvStorageForRef(h()),async(u,g)=>{let P=u.payload,B=(P.enrichedCard??{}).id??P.cardId??"unknown";await E({type:"task-failed",taskName:B,error:g,timestamp:q()});}),t=At(o.kvStorageForRef(h())),c=await le(),i=await ie(),A=await $(),I=await K(),F=new Map,C=new Map,x=[],Q=[],G=[],X=new Map,de=new Set,ce={async readRuntime(u){return F.get(u)??await t.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),Te[u]=g;}},Ie={async readSourceData(u,g){let P=`${u}/${g}`;return C.has(P)?C.get(P):await i.readSourceData(u,g)},ingestSourceDataStaged(u,g,P,D){return i.ingestSourceDataStaged(u,g,P,D)},async commitSourceData(u,g,P){let D=`${u}/.staged/${P}/${g}`,B=await c.read(D);if(B==null){let z=await Promise.resolve(c.keyRef?.(D));z&&(B=await o.resolveBlob(z));}if(B==null)return false;let U=`${u}/${g}`,ae=B.trim();try{C.set(U,JSON.parse(ae));}catch{C.set(U,ae);}return x.push({cardId:u,outputFile:g,deliveryToken:P}),true},async hasSource(u,g){let P=`${u}/${g}`;return C.has(P)||await i.hasSource(u,g)},async listSources(u){let g=await i.listSources(u),P=[...C.keys()].filter(D=>D.startsWith(`${u}/`)).map(D=>D.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await H(),De=chunkAW3COGCI_cjs.q(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await te().readEntriesAfterCursor(xe.lastDrainedJournalId),pe=wt,Ve=()=>De.config.tasks,fe=chunkAW3COGCI_cjs.t(De,{handlers:{"card-handler":Ot(e,Oe,{cardStore:A,cardRuntimeStore:ce,fetchedSourcesStore:Ie,outputStore:I,executionRequestStore:n,activeTaskConfigs:()=>Ve()},(u,g)=>{pe.push({type:"task-completed",taskName:u,data:g,timestamp:q()});},(u,g)=>{Q.push({cardId:u,values:g});},u=>{G.push(u);})},onNodeRemoved:u=>{X.delete(u),F.delete(u),delete Te[u],de.add(u);}});for(Ve=()=>fe.getState().config.tasks;pe.length>0;){let u=pe;pe=[];for(let g of u)if(g.type==="task-restart"){let P=await A.readCard(g.taskName);P&&X.set(g.taskName,P);}fe.pushAll(u),await fe.waitForHandlers();}let $e=fe.getState();await fe.dispose({wait:true}),await ee({lastDrainedJournalId:Oe,graph:chunkAW3COGCI_cjs.p($e),runtimeByCardId:Te},(await V().readSnapshot(M)).version);for(let{cardId:u,values:g}of Q)await I.writeComputedValues(u,g);for(let u of G)await I.writeDataObjects(u);for(let[u,g]of F)await t.writeRuntime(u,g);for(let u of x)await i.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let Le=chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(d,$e));await I.writeStatusSnapshot(Le);let me=[];for(let{cardId:u,values:g}of Q)me.push({kind:"computed_values",cardId:u,values:g});for(let u of G)for(let[g,P]of Object.entries(u))me.push({kind:"data_object",key:g,payload:P});for(let[u,g]of X)u!==chunkJ7KE7SPA_cjs.i&&me.push({kind:"card_refreshed",cardId:u,card:g});for(let u of de)me.push({kind:"card_removed",cardId:u});me.push({kind:"status",status:Le}),await N(me);let ne=await Ae();if(!ne)return;let Je=o.supportsDirectSourceOutput?.(ne)===true;await n.dispatchEntriesForJournalId(Oe,async u=>{if(u.taskKind!=="source-fetch"){s(`[async-process-accumulated-events] unknown taskKind "${u.taskKind}" \u2014 skipping`);return}let g=u.payload,P=g.enrichedCard?.id??"unknown",D=g.enrichedCard?.source_defs??[];if(ne.howToRun==="queue-storage"&&Je){try{let B=await O().readQueueStoreRef();if(!B)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let U=o.queueStorageForRef(B,"task-executor"),ae=typeof ne.extra?.boardId=="string"?ne.extra.boardId:void 0,z=[];for(let Y of D){if(!Y.outputFile)continue;let ye=o.genId(),Se=`${P}/.staged/${ye}/${Y.outputFile}`,Me=await Promise.resolve(c.keyRef?.(Se));if(!Me)continue;let Qe={ref:chunkVQCIOKJV_cjs.a(Me),deliveryToken:ye,outputFile:Y.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:Y.bindTo,d:Y.outputFile,cs:void 0,rqt:g.rqt,dt:Qe.deliveryToken});z.push({...ae?{boardId:ae}:{},ref:ne,args:{source_def:Y,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ht),output:Qe}});}z.length>0&&await U.enqueueMany(z);}catch(B){await E({type:"task-failed",taskName:P,error:B instanceof Error?B.message:String(B),timestamp:q()});}return}for(let B of D){if(!B.outputFile)continue;let U;if(Je){let Y=o.genId(),ye=`${P}/.staged/${Y}/${B.outputFile}`,Se=await Promise.resolve(c.keyRef?.(ye));Se&&(U={ref:chunkVQCIOKJV_cjs.a(Se),deliveryToken:Y,outputFile:B.outputFile,cardId:P});}let ae=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:B.bindTo,d:B.outputFile,cs:void 0,rqt:g.rqt,...U?{dt:U.deliveryToken}:{}}),z=await o.dispatchExecution(ne,{source_def:B,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ae),...U?{output:U}:{}});z.dispatched||await E({type:"task-failed",taskName:P,error:z.error??"dispatch failed",timestamp:q()});}});}async function y(){try{let n=async()=>{let c=await H(),{events:i}=await te().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await j();},t=await mt(o.lock,p,n);return b({ran:t!==!1})}catch(n){return T(n)}}async function k(){return v||(v=y().finally(()=>{v=null;}),v)}async function j(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);await o.queueStorageForRef(n,"process-accumulated").enqueue({boardRef:chunkVQCIOKJV_cjs.a(e)}),await o.requestProcessAccumulated?.();}async function re(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await t.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await t.ack(i.id,i.leaseToken);if(c.length<64)return}}function L(){j();}return {async init(n){try{let t=n.params?.cardStoreRef;if(!t)return R("init requires params.cardStoreRef");if(w=n.params?.boardRuntimeStoreRef,!w)return R("init requires params.boardRuntimeStoreRef");let c=n.params?.outputsStoreRef;if(!c)return R("init requires params.outputsStoreRef");let i=n.params?.queueStoreRef;if(!i)return R("init requires params.queueStoreRef");let A=n.params?.fetchedSourcesStoreRef;if(!A)return R("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let I=n.params?.chatStoreRef;if(!I)return R("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return R("init requires params.artifactsStoreRef");await Z()||await ee({lastDrainedJournalId:"",graph:chunkAW3COGCI_cjs.p(chunkAW3COGCI_cjs.a(chunkJ7KE7SPA_cjs.D)),runtimeByCardId:{}},null);let C=O();await C.writeBoardRuntimeStoreRef(w),await C.writeCardStoreRef(t),await C.writeOutputsStoreRef(c),await C.writeQueueStoreRef(i),await C.writeFetchedSourcesStoreRef(A),await C.writeChatStoreRef(I),await C.writeArtifactsStoreRef(F),await(await $()).writeCard(chunkJ7KE7SPA_cjs.i,chunkJ7KE7SPA_cjs.l());let x=o.kvStorage("card-upsert"),Q=chunkJ7KE7SPA_cjs.l(),G=chunkJ7KE7SPA_cjs.G(Q),X=o.hashFn(G),ce=(await x.read(chunkJ7KE7SPA_cjs.i))?.blobRef??await(await $()).readCardKey(chunkJ7KE7SPA_cjs.i)??chunkJ7KE7SPA_cjs.i;return await E({type:"task-upsert",taskName:chunkJ7KE7SPA_cjs.i,taskConfig:G,timestamp:q()}),await x.write(chunkJ7KE7SPA_cjs.i,{blobRef:ce,taskConfigHash:X,updatedAt:q()}),await E({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:q()}),L(),await(await K()).writeStatusSnapshot(chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(d,chunkAW3COGCI_cjs.q((await H()).graph)))),b()}catch(t){return T(t)}},async status(n){try{let t=await K(),c=await t.readStatusSnapshot();return c||(c=chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(d,chunkAW3COGCI_cjs.q((await H()).graph))),await t.writeStatusSnapshot(c)),b(c)}catch(t){return T(t)}},async getCardStoreRef(n){try{let t=await O().readCardStoreRef();return t?b({storeRef:t}):R(`Board at ${e.value} has no card store configured`)}catch(t){return T(t)}},async getBoardRuntimeStoreRef(n){try{return b({storeRef:w??null})}catch(t){return T(t)}},async getOutputsStoreRef(n){try{let t=await O().readOutputsStoreRef();return t?b({storeRef:t}):R(`Board at ${e.value} has no outputs store configured`)}catch(t){return T(t)}},async getScratchStoreRef(n){try{return b({storeRef:m??null})}catch(t){return T(t)}},async getChatStoreRef(n){try{return b({storeRef:await O().readChatStoreRef()})}catch(t){return T(t)}},async getArtifactsStoreRef(n){try{return b({storeRef:await O().readArtifactsStoreRef()})}catch(t){return T(t)}},async getFetchedSourcesStoreRef(n){try{return b({storeRef:await O().readFetchedSourcesStoreRef()})}catch(t){return T(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return R("getConfig requires params.key");let c=O(),i;switch(t){case "task-executor":i=l??null;break;case "chat-handler-flow":i=S??null;break;case "board-runtime-store-ref":i=await c.readBoardRuntimeStoreRef();break;case "card-store-ref":i=await c.readCardStoreRef();break;case "outputs-store-ref":i=await c.readOutputsStoreRef();break;case "scratch-store-ref":i=m??null;break;case "chat-store-ref":i=await c.readChatStoreRef();break;case "artifacts-store-ref":i=await c.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=await c.readFetchedSourcesStoreRef();break;default:return R(`getConfig: unknown key "${t}"`)}return b({value:i})}catch(t){return T(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;if(!t)return R("getOutputsDataObject requires params.key");if(t===chunkJ7KE7SPA_cjs.h)return b(null);let c=await W();return b(c[t]??null)}catch(t){return T(t)}},async getAllOutputsDataObjects(n){try{return b(await W())}catch(t){return T(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?b(await(await K()).readComputedValues(t)):R("getOutputsComputedValues requires params.key")}catch(t){return T(t)}},async getAllOutputsComputedValues(n){try{return b(await(await K()).readAllComputedValues())}catch(t){return T(t)}},async getOutputsFetchedSources(n){try{let t=n.params?.key;if(!t)return R("getOutputsFetchedSources requires params.key");let c=await(await ie()).listSources(t),i={};for(let A of c)i[A]=await ue(`${t}/${A}`);return b(i)}catch(t){return T(t)}},async getAllOutputsFetchedSources(n){try{let t=await ie(),c=await(await le()).listKeys(),i=new Set;for(let I of c){let F=I.indexOf("/");F>0&&!I.includes("/.staged/")&&i.add(I.slice(0,F));}let A={};for(let I of i){let F=await t.listSources(I);if(F.length!==0){A[I]={};for(let C of F)A[I][C]=await ue(`${I}/${C}`);}}return b(A)}catch(t){return T(t)}},async buildSseOneShotPayload(n){try{let t=(await(await $()).readAllCards()).filter(C=>C.id!==chunkJ7KE7SPA_cjs.i),c=await this.status({});if(c.status!=="success")return c;let i=await this.getAllOutputsDataObjects({});if(i.status!=="success")return i;let A=await this.getAllOutputsComputedValues({});if(A.status!=="success")return A;let I=A.data,F={};for(let C of t){let x=typeof C?.id=="string"?C.id:null;if(!x)continue;let Q=C.card_data&&typeof C.card_data=="object"&&!Array.isArray(C.card_data)?C.card_data:{};F[x]={schema_version:"v1",card_id:x,card_data:{...Q},computed_values:I[x]&&typeof I[x]=="object"?I[x]:{}};}return b({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i.data,cardRuntimeById:F})}catch(t){return T(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return R("addCardFiles requires params.cardId");let i=await St(await $(),{emitNotification:f}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:b({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return T(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return R("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await E({type:"task-removal",taskName:t,timestamp:q()}),t!==chunkJ7KE7SPA_cjs.i&&await E({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:q()}),L(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await E({type:"task-restart",taskName:t,timestamp:q()}),L(),b()):R("retrigger requires params.id")}catch(t){return T(t)}},async processAccumulatedEvents(n){return await re(),k()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i=!!n.params?.restart;if(!t&&!c)return R("upsertCard requires --card-id <id> or --all");let A=await $(),I=c?(await A.readAllCards()).map(x=>x.id):[t];for(let x of I)if(!await A.readCard(x))return R(`Card "${x}" not found in board at ${e.value}`);let F=o.kvStorage("card-upsert"),C=!1;for(let x of I){let Q=await A.readCard(x);if(!Q)continue;let G=chunkJ7KE7SPA_cjs.G(Q),X=o.hashFn(G),de=await F.read(x),ce=de?.taskConfigHash!==X;if(!(!ce&&!i)){if(ce){let Ie=de?.blobRef??await A.readCardKey(x)??x;await E({type:"task-upsert",taskName:x,taskConfig:G,timestamp:q()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:q()}),C=C||x!==chunkJ7KE7SPA_cjs.i;}i&&await E({type:"task-restart",taskName:x,timestamp:q()});}}return C&&await E({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:q()}),L(),b()}catch(t){return T(t)}},async taskFailed(n){try{let t=n.params?.token;if(!t)return R("taskFailed requires params.token");let c=n.params?.error??"unknown error",i=be(t);return i?(await E({type:"task-failed",taskName:i.taskName,error:c,timestamp:q()}),L(),b()):R("Invalid callback token")}catch(t){return T(t)}},async taskProgress(n){try{let t=n.params?.token;if(!t)return R("taskProgress requires params.token");let c=(n.body??{}).update??{},i=be(t);return i?(await E({type:"task-progress",taskName:i.taskName,update:c,timestamp:q()}),L(),b()):R("Invalid callback token")}catch(t){return T(t)}},async sourceDataFetched(n){try{let t=n.params?.token,c=n.params?.ref;if(!t)return R("sourceDataFetched requires params.token");if(!c)return R("sourceDataFetched requires params.ref");let i=Ct(t);if(!i)return R("Invalid source token");let A=await ie(),I=i.dt||o.genId();i.dt||await A.ingestSourceDataStaged(i.cid,i.d,chunkVQCIOKJV_cjs.b(c),I);let F=be(i.cbk);return F?(await E({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:q(),deliveryToken:I,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),L(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}},async sourceDataFetchFailure(n){try{let t=n.params?.token,c=n.params?.reason??"unknown";if(!t)return R("sourceDataFetchFailure requires params.token");let i=Ct(t);if(!i)return R("Invalid source token");let A=be(i.cbk);return A?(await E({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),L(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}}}}
2
- exports.a=mt;exports.b=gt;exports.c=pt;exports.d=yt;exports.e=Nt;exports.f=_t;exports.g=St;exports.h=$t;exports.i=nr;//# sourceMappingURL=chunk-5RUSICUC.cjs.map
3
- //# sourceMappingURL=chunk-5RUSICUC.cjs.map
1
+ 'use strict';var chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs'),chunk3XPY7CCM_cjs=require('./chunk-3XPY7CCM.cjs'),chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunkJ7KE7SPA_cjs=require('./chunk-J7KE7SPA.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');async function mt(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function Pt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Pe(e,o){return Pt(e)?e.then(o):o(e)}function lt(e,o){let a={...e};for(let[r,s]of Object.entries(o))s!==null&&typeof s=="object"&&!Array.isArray(s)&&a[r]!==null&&typeof a[r]=="object"&&!Array.isArray(a[r])?a[r]=lt(a[r],s):a[r]=s;return a}function ve(e,o,a){if(o.length===0)return e;let[r,...s]=o;if(s.length===0)return {...e,[r]:a};let d=e[r]!==null&&typeof e[r]=="object"&&!Array.isArray(e[r])?e[r]:{};return {...e,[r]:ve(d,s,a)}}function ft(e){return {read:a=>e.read(a),get(a,r){return Pe(e.read(a),s=>{if(s===null)return null;let d=s;for(let f of r.split(".").filter(Boolean)){if(d===null||typeof d!="object"||Array.isArray(d))return null;d=d[f]??null;}return d??null})},write:(a,r)=>e.write(a,r),delete:a=>e.delete(a),listKeys:a=>e.listKeys(a),shallowMerge(a,r){return Pe(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return Pe(e.read(a),s=>e.write(a,lt(s??{},r)))},patch(a,r,s){return Pe(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,ve(d??{},f,s))})}}}function gt(e){return ft(e)}function pt(e,o){return {async readIndex(){return await e.read("_index")},writeIndex(a){return e.write("_index",a)},async readCard(a){return await e.read(a)},async writeCard(a,r){return await e.write(a,r),o(r)},removeCard(a){return e.delete(a)},async cardExists(a){return await e.read(a)!==null},defaultCardKey(a){return a}}}function yt(e,o){async function a(){return await e.readIndex()??{}}return {async readCard(r){let s=(await a())[r];return !s||!await e.cardExists(s.key)?null:await e.readCard(s.key)},async readCardKey(r){return (await a())[r]?.key??null},async readAllCards(){let r=[];for(let[s,d]of Object.entries(await a())){if(!await e.cardExists(d.key))continue;let f=await e.readCard(d.key);f?r.push(f):o?.(`[card-store] could not read card "${s}" at key "${d.key}"`);}return r},async readChecksumIndex(){let r={};for(let[s,d]of Object.entries(await a()))r[s]=d.checksum;return r},async changedSince(r){let s=await a(),d=[];for(let[f,v]of Object.entries(s))r[f]!==v.checksum&&d.push(f);for(let f of Object.keys(r))s[f]||d.push(f);return d},async validateUpsert(r,s){let d=await a(),f=d[r],v=Object.entries(d).find(([,w])=>w.key===s);return f&&f.key!==s?{ok:false,error:`Card id "${r}" is already mapped to key "${f.key}", cannot remap to "${s}"`}:v&&v[0]!==r?{ok:false,error:`Key "${s}" is already mapped to card id "${v[0]}", cannot remap to "${r}"`}:{ok:true}},async writeCard(r,s,d){let f=await a(),v=d??f[r]?.key??e.defaultCardKey(r),w=await e.writeCard(v,s);f[r]={key:v,checksum:w,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async patchCard(r,s,d){let f=await a(),v=f[r];if(!v||!await e.cardExists(v.key))throw new Error(`card "${r}" not found`);let w=await e.readCard(v.key);if(!w||typeof w!="object"||Array.isArray(w))throw new Error(`card "${r}" is not patchable`);let m=String(s||"").split(".").filter(Boolean),l=ve(w,m,d),S=await e.writeCard(v.key,l);f[r]={key:v.key,checksum:S,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async removeCard(r){let s=await a(),d=s[r];d&&(await e.removeCard(d.key),delete s[r],await e.writeIndex(s));},readIndex(){return a()}}}function Nt(e,o){return chunkJ7KE7SPA_cjs.a(e,o)}function _t(e,o,a){return {blob:e,kv:o,journal:a}}function St(e,o={}){function a(m){return {status:"success",data:m}}function r(m){return {status:"fail",error:m}}function s(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}async function d(m){let l=o.emitNotification;if(!l||m.length===0)return;let S=chunk2RIHC5TZ_cjs.e(m);if(S.length===1){await l(S[0]);return}await l(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:S}));}async function f(m){let l=m.params?.id;if(l){let S=await e.readCard(l);if(!S)throw new Error(`card "${l}" not found`);return [S]}return await e.readAllCards()}function v(m){return chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:chunk2RIHC5TZ_cjs.e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function w(m){if(Array.isArray(m))return m;if(m&&typeof m=="object"){let l=m;return Array.isArray(l.files)?l.files:[m]}return null}return {async get(m){try{return a({cards:await f(m)})}catch(l){return s(l)}},async buildNotificationBatch(m){try{return a(v(await f(m)))}catch(l){return s(l)}},async set(m){try{let l=m.body;if(l==null)return r("set requires a body (card object or array of cards)");let S=Array.isArray(l)?l:[l];for(let h of S){if(typeof h.id!="string")return r("each card must have a string `id` field");await e.writeCard(h.id,h);}return await d(S.map(h=>({kind:"card_refreshed",cardId:h.id,card:h}))),a({count:S.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],S=m.params?.id,h=S?[...l,S]:l;if(h.length===0)return r("del requires body.ids (string[]) or params.id");for(let N of h)await e.removeCard(N);return await d(h.map(N=>({kind:"card_removed",cardId:N}))),a({count:h.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,S=m.params?.path;if(!l)return r("patch requires params.id");if(!S)return r("patch requires params.path");let h=m.body,N=h&&Object.prototype.hasOwnProperty.call(h,"value")?h.value:m.body;await e.patchCard(l,S,N);let O=await e.readCard(l);return O?(await d([{kind:"card_refreshed",cardId:l,card:O}]),a({count:1})):r(`card "${l}" not found`)}catch(l){return s(l)}},async appendFiles(m){try{let l=m.params?.id;if(!l)return r("appendFiles requires params.id");let S=await e.readCard(l);if(!S)return r(`card "${l}" not found`);let h=w(m.body);if(!h||h.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let N=S.card_data&&typeof S.card_data=="object"&&!Array.isArray(S.card_data)?S.card_data:{},O=Array.isArray(N.files)?N.files:[],M=[...O,...h],V=h.map(($,Z)=>({idx:O.length+Z,entry:$})),K=await this.patch({params:{id:l,path:"card_data.files"},body:{value:M}});return K.status!=="success"?K:a({files_added:V})}catch(l){return s(l)}}}}async function vt(e,o){return (await e.peekActive()).find(a=>a.id===o)}function $t(e,o={}){async function a(r){let s=o.emitNotification;if(!s||r.length===0)return;let d=chunk2RIHC5TZ_cjs.e(r);if(d.length===1){await s(d[0]);return}await s(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:d}));}return {async enqueue(r){let s=await e.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await e.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:e.enqueueIfAbsent?async(r,s)=>{let d=await e.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return e.lease(r)},ack(r,s){return e.ack(r,s)},nack(r,s,d){return e.nack(r,s,d)},peekActive(r){return e.peekActive(r)},peekDeadLetter(r){return e.peekDeadLetter(r)},async stage(r,s){return e.stage(r,s)},async commitStaged(r){let s=await e.commitStaged(r);if(s){let d=await vt(e,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return e.discardStaged(r,s)},peekStaged(r){return e.peekStaged(r)}}}function b(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function T(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function q(){return new Date().toISOString()}function bt(e){let o=new TextEncoder().encode(e),a=Array.from(o,r=>String.fromCharCode(r)).join("");return btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Rt(e){let o=e.replace(/-/g,"+").replace(/_/g,"/"),a=o+"=".repeat((4-o.length%4)%4),r=atob(a),s=Uint8Array.from(r,d=>d.charCodeAt(0));return new TextDecoder().decode(s)}function be(e){try{let o=JSON.parse(Rt(e));return typeof o?.t=="string"?{taskName:o.t}:null}catch{return null}}function kt(e){return bt(JSON.stringify(e))}function Ct(e){try{let o=JSON.parse(Rt(e));return typeof o?.cbk=="string"&&typeof o?.cid=="string"&&typeof o?.b=="string"&&typeof o?.d=="string"?o:null}catch{return null}}function At(e){return chunkJ7KE7SPA_cjs.f(e,chunkJ7KE7SPA_cjs.r,()=>({_sources:{}}))}function It(e,o){return chunkJ7KE7SPA_cjs.d(e,o)}function xt(e){return chunkJ7KE7SPA_cjs.g(e)}function Tt(e,o){return chunkJ7KE7SPA_cjs.e(e,o)}function Ot(e,o,a,r,s,d){return async f=>{let v=[],w=await a.cardStore.readCard(f.nodeId);if(!w)return "task-initiate-failure";let m=w.id;if(m===chunkJ7KE7SPA_cjs.i){let p=a.activeTaskConfigs?.(),y={[chunkJ7KE7SPA_cjs.h]:p?chunkJ7KE7SPA_cjs.k((await Promise.all(Object.keys(p).filter(k=>k!==chunkJ7KE7SPA_cjs.i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await chunkJ7KE7SPA_cjs.j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w.card_data??{},S=w.source_defs??[],h=S,N=await a.cardRuntimeStore.readRuntime(m),O=false,M=async()=>{O&&(await a.cardRuntimeStore.writeRuntime(m,N),O=false);},V=p=>chunkJ7KE7SPA_cjs.v(N._sources[p]),K=(p,y)=>{N._sources[p]=chunkJ7KE7SPA_cjs.v(y),O=true;},$=f.taskState?.executionCount??0;if(N._lastExecutionCount!==$&&(N._sources={},N._lastExecutionCount=$,O=true),f.update){let p=f.update.outputFile;if(p){let y=V(p);if(f.update.failure){let k=f.update.rqt??y.lastRequestedToken??y.queueRequestedToken;k&&K(p,chunkJ7KE7SPA_cjs.y(y,k));}else {let k=f.update.rqt;if(!y.lastCompletedToken||k>y.lastCompletedToken){let j=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,re=j?await a.fetchedSourcesStore.commitSourceData(m,p,j):false;K(p,re?chunkJ7KE7SPA_cjs.x(y,k):chunkJ7KE7SPA_cjs.y(y,k));}}await M();}}let Z={};for(let p of S){if(!p.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,p.outputFile);y!==null&&(Z[p.bindTo]=y);}let H={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];H[p]=k!==void 0?k:y;}else H[p]=y;let ee={id:m,card_data:{...l},requires:H,source_defs:S,compute:w.compute};ee._sourcesData=Z,w.compute&&chunkQBEQL4TL_cjs.a.runSync(ee,{sourcesData:Z}),(s??(()=>{}))(m,ee.computed_values??{});let te=chunkQBEQL4TL_cjs.a.enrichSourcesSync(Array.isArray(w.source_defs)?w.source_defs:void 0,{card_data:w.card_data,requires:H}),Ae={...w,source_defs:Array.isArray(te)?te.map(p=>({...p,boardDir:typeof p.boardDir=="string"&&p.boardDir?p.boardDir:e.value})):te},W=q(),E=f.update?void 0:W,ge=h.filter(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return true;let k=V(y);E&&(k={...k,queueRequestedToken:E},K(y,k));let j=k.queueRequestedToken??k.lastRequestedToken??W;return chunkJ7KE7SPA_cjs.w(k,j)==="dispatch"});if(await M(),ge.length>0){let p=false,y=W;for(let k of ge){let j=k.outputFile;if(typeof j!="string"||!j)continue;let re=V(j),L=re.queueRequestedToken??W;K(j,{...re,lastRequestedToken:L}),y=L,p=true;}return p&&await M(),p&&(v.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(e),enrichedCard:Ae,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v)),"task-initiated"}if(h.some(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return false;let k=V(y),j=k.queueRequestedToken??k.lastRequestedToken??W;return chunkJ7KE7SPA_cjs.w(k,j)==="in-flight"}))return "task-initiated";let ie=w.provides??[],ue={};for(let{bindTo:p,ref:y}of ie)ue[p]=chunkQBEQL4TL_cjs.a.resolve(ee,y);return (d??(()=>{}))(ue),r(f.nodeId,ue),v.length>0&&await a.executionRequestStore.appendEntries(o,v),"task-initiated"}}function nr(e,o,a={}){chunk3XPY7CCM_cjs.a(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=chunkVQCIOKJV_cjs.a(e),f=a.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),v=null,w=a.boardRuntimeStoreRef,m=a.scratchStoreRef,l=a.taskExecutorRef,S=a.chatHandlerFlow;function h(){if(!w)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return w}function N(n){if(n.length!==0)try{let t=chunk2RIHC5TZ_cjs.e(n),c=chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:t});return Promise.resolve(f(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(t){s(`[async-board-live-cards-public] emitNotification failed: ${t instanceof Error?t.message:String(t)}`);return}}let O=()=>chunkCSHNTZW4_cjs.b(o.kvStorageForRef(h())),M=e.value,V=()=>chunkJ7KE7SPA_cjs.b(chunkJ7KE7SPA_cjs.a(()=>o.kvStorageForRef(h()),o.hashFn),"v1"),K=async()=>{let n=await O().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e.value} has no outputs store configured.`);return xt(o.kvStorageForRef(n))},$=async()=>{let n=await O().readCardStoreRef();if(!n)throw new Error(`Board at ${e.value} has no card store configured.`);let t=o.kvStorageForRef(n);return yt(pt(gt(t),o.hashFn),s)};async function Z(){return !!(await V().readSnapshot(M)).values[chunkJ7KE7SPA_cjs.q]}async function H(){let n=await V().readSnapshot(M);if(!n.values[chunkJ7KE7SPA_cjs.q])throw new Error(`Board not initialized at ${e.value}`);return chunkJ7KE7SPA_cjs.F(n.values)}async function ee(n,t){let c=await V().commitSnapshot(M,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:chunkJ7KE7SPA_cjs.E(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let te=()=>chunkJ7KE7SPA_cjs.c(o.journalStorageForRef(h()));async function Ae(){return l??await O().readTaskExecutorRef()}async function W(){return chunkJ7KE7SPA_cjs.A(await(await K()).readAllDataObjects())}async function E(n){await te().appendEvent(n);}async function ge(){let n=await O().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function le(){return o.blobStorageForRef(await ge())}async function ie(){return It(await le(),n=>o.resolveBlob(n))}async function ue(n){let t=(await le()).keyRef?.(n);if(!t)throw new Error("configured fetched-sources store does not support keyRef");let c=await Promise.resolve(t);return chunkVQCIOKJV_cjs.a(c)}async function p(){let n=Tt(o.kvStorageForRef(h()),async(u,g)=>{let P=u.payload,B=(P.enrichedCard??{}).id??P.cardId??"unknown";await E({type:"task-failed",taskName:B,error:g,timestamp:q()});}),t=At(o.kvStorageForRef(h())),c=await le(),i=await ie(),A=await $(),I=await K(),F=new Map,C=new Map,x=[],Q=[],G=[],X=new Map,de=new Set,ce={async readRuntime(u){return F.get(u)??await t.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),Te[u]=g;}},Ie={async readSourceData(u,g){let P=`${u}/${g}`;return C.has(P)?C.get(P):await i.readSourceData(u,g)},ingestSourceDataStaged(u,g,P,D){return i.ingestSourceDataStaged(u,g,P,D)},async commitSourceData(u,g,P){let D=`${u}/.staged/${P}/${g}`,B=await c.read(D);if(B==null){let z=await Promise.resolve(c.keyRef?.(D));z&&(B=await o.resolveBlob(z));}if(B==null)return false;let U=`${u}/${g}`,ae=B.trim();try{C.set(U,JSON.parse(ae));}catch{C.set(U,ae);}return x.push({cardId:u,outputFile:g,deliveryToken:P}),true},async hasSource(u,g){let P=`${u}/${g}`;return C.has(P)||await i.hasSource(u,g)},async listSources(u){let g=await i.listSources(u),P=[...C.keys()].filter(D=>D.startsWith(`${u}/`)).map(D=>D.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await H(),De=chunkAW3COGCI_cjs.q(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await te().readEntriesAfterCursor(xe.lastDrainedJournalId),pe=wt,Ve=()=>De.config.tasks,fe=chunkAW3COGCI_cjs.t(De,{handlers:{"card-handler":Ot(e,Oe,{cardStore:A,cardRuntimeStore:ce,fetchedSourcesStore:Ie,outputStore:I,executionRequestStore:n,activeTaskConfigs:()=>Ve()},(u,g)=>{pe.push({type:"task-completed",taskName:u,data:g,timestamp:q()});},(u,g)=>{Q.push({cardId:u,values:g});},u=>{G.push(u);})},onNodeRemoved:u=>{X.delete(u),F.delete(u),delete Te[u],de.add(u);}});for(Ve=()=>fe.getState().config.tasks;pe.length>0;){let u=pe;pe=[];for(let g of u)if(g.type==="task-restart"){let P=await A.readCard(g.taskName);P&&X.set(g.taskName,P);}fe.pushAll(u),await fe.waitForHandlers();}let $e=fe.getState();await fe.dispose({wait:true}),await ee({lastDrainedJournalId:Oe,graph:chunkAW3COGCI_cjs.p($e),runtimeByCardId:Te},(await V().readSnapshot(M)).version);for(let{cardId:u,values:g}of Q)await I.writeComputedValues(u,g);for(let u of G)await I.writeDataObjects(u);for(let[u,g]of F)await t.writeRuntime(u,g);for(let u of x)await i.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let Le=chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(d,$e));await I.writeStatusSnapshot(Le);let me=[];for(let{cardId:u,values:g}of Q)me.push({kind:"computed_values",cardId:u,values:g});for(let u of G)for(let[g,P]of Object.entries(u))me.push({kind:"data_object",key:g,payload:P});for(let[u,g]of X)u!==chunkJ7KE7SPA_cjs.i&&me.push({kind:"card_refreshed",cardId:u,card:g});for(let u of de)me.push({kind:"card_removed",cardId:u});me.push({kind:"status",status:Le}),await N(me);let ne=await Ae();if(!ne)return;let Je=o.supportsDirectSourceOutput?.(ne)===true;await n.dispatchEntriesForJournalId(Oe,async u=>{if(u.taskKind!=="source-fetch"){s(`[async-process-accumulated-events] unknown taskKind "${u.taskKind}" \u2014 skipping`);return}let g=u.payload,P=g.enrichedCard?.id??"unknown",D=g.enrichedCard?.source_defs??[];if(ne.howToRun==="queue-storage"&&Je){try{let B=await O().readQueueStoreRef();if(!B)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let U=o.queueStorageForRef(B,"task-executor"),ae=typeof ne.extra?.boardId=="string"?ne.extra.boardId:void 0,z=[];for(let Y of D){if(!Y.outputFile)continue;let ye=o.genId(),Se=`${P}/.staged/${ye}/${Y.outputFile}`,Me=await Promise.resolve(c.keyRef?.(Se));if(!Me)continue;let Qe={ref:chunkVQCIOKJV_cjs.a(Me),deliveryToken:ye,outputFile:Y.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:Y.bindTo,d:Y.outputFile,cs:void 0,rqt:g.rqt,dt:Qe.deliveryToken});z.push({...ae?{boardId:ae}:{},ref:ne,args:{source_def:Y,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ht),output:Qe}});}z.length>0&&await U.enqueueMany(z);}catch(B){await E({type:"task-failed",taskName:P,error:B instanceof Error?B.message:String(B),timestamp:q()});}return}for(let B of D){if(!B.outputFile)continue;let U;if(Je){let Y=o.genId(),ye=`${P}/.staged/${Y}/${B.outputFile}`,Se=await Promise.resolve(c.keyRef?.(ye));Se&&(U={ref:chunkVQCIOKJV_cjs.a(Se),deliveryToken:Y,outputFile:B.outputFile,cardId:P});}let ae=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:B.bindTo,d:B.outputFile,cs:void 0,rqt:g.rqt,...U?{dt:U.deliveryToken}:{}}),z=await o.dispatchExecution(ne,{source_def:B,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ae),...U?{output:U}:{}});z.dispatched||await E({type:"task-failed",taskName:P,error:z.error??"dispatch failed",timestamp:q()});}});}async function y(){try{let n=async()=>{let c=await H(),{events:i}=await te().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await j();},t=await mt(o.lock,p,n);return b({ran:t!==!1})}catch(n){return T(n)}}async function k(){return v||(v=y().finally(()=>{v=null;}),v)}async function j(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);await o.queueStorageForRef(n,"process-accumulated").enqueue({boardRef:chunkVQCIOKJV_cjs.a(e)}),await o.requestProcessAccumulated?.();}async function re(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await t.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await t.ack(i.id,i.leaseToken);if(c.length<64)return}}function L(){j();}return {async init(n){try{let t=n.params?.cardStoreRef;if(!t)return R("init requires params.cardStoreRef");if(w=n.params?.boardRuntimeStoreRef,!w)return R("init requires params.boardRuntimeStoreRef");let c=n.params?.outputsStoreRef;if(!c)return R("init requires params.outputsStoreRef");let i=n.params?.queueStoreRef;if(!i)return R("init requires params.queueStoreRef");let A=n.params?.fetchedSourcesStoreRef;if(!A)return R("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let I=n.params?.chatStoreRef;if(!I)return R("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return R("init requires params.artifactsStoreRef");await Z()||await ee({lastDrainedJournalId:"",graph:chunkAW3COGCI_cjs.p(chunkAW3COGCI_cjs.a(chunkJ7KE7SPA_cjs.D)),runtimeByCardId:{}},null);let C=O();await C.writeBoardRuntimeStoreRef(w),await C.writeCardStoreRef(t),await C.writeOutputsStoreRef(c),await C.writeQueueStoreRef(i),await C.writeFetchedSourcesStoreRef(A),await C.writeChatStoreRef(I),await C.writeArtifactsStoreRef(F),await(await $()).writeCard(chunkJ7KE7SPA_cjs.i,chunkJ7KE7SPA_cjs.l());let x=o.kvStorage("card-upsert"),Q=chunkJ7KE7SPA_cjs.l(),G=chunkJ7KE7SPA_cjs.G(Q),X=o.hashFn(G),ce=(await x.read(chunkJ7KE7SPA_cjs.i))?.blobRef??await(await $()).readCardKey(chunkJ7KE7SPA_cjs.i)??chunkJ7KE7SPA_cjs.i;return await E({type:"task-upsert",taskName:chunkJ7KE7SPA_cjs.i,taskConfig:G,timestamp:q()}),await x.write(chunkJ7KE7SPA_cjs.i,{blobRef:ce,taskConfigHash:X,updatedAt:q()}),await E({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:q()}),L(),await(await K()).writeStatusSnapshot(chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(d,chunkAW3COGCI_cjs.q((await H()).graph)))),b()}catch(t){return T(t)}},async status(n){try{let t=await K(),c=await t.readStatusSnapshot();return c||(c=chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(d,chunkAW3COGCI_cjs.q((await H()).graph))),await t.writeStatusSnapshot(c)),b(c)}catch(t){return T(t)}},async getCardStoreRef(n){try{let t=await O().readCardStoreRef();return t?b({storeRef:t}):R(`Board at ${e.value} has no card store configured`)}catch(t){return T(t)}},async getBoardRuntimeStoreRef(n){try{return b({storeRef:w??null})}catch(t){return T(t)}},async getOutputsStoreRef(n){try{let t=await O().readOutputsStoreRef();return t?b({storeRef:t}):R(`Board at ${e.value} has no outputs store configured`)}catch(t){return T(t)}},async getScratchStoreRef(n){try{return b({storeRef:m??null})}catch(t){return T(t)}},async getChatStoreRef(n){try{return b({storeRef:await O().readChatStoreRef()})}catch(t){return T(t)}},async getArtifactsStoreRef(n){try{return b({storeRef:await O().readArtifactsStoreRef()})}catch(t){return T(t)}},async getFetchedSourcesStoreRef(n){try{return b({storeRef:await O().readFetchedSourcesStoreRef()})}catch(t){return T(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return R("getConfig requires params.key");let c=O(),i;switch(t){case "task-executor":i=l??null;break;case "chat-handler-flow":i=S??null;break;case "board-runtime-store-ref":i=await c.readBoardRuntimeStoreRef();break;case "card-store-ref":i=await c.readCardStoreRef();break;case "outputs-store-ref":i=await c.readOutputsStoreRef();break;case "scratch-store-ref":i=m??null;break;case "chat-store-ref":i=await c.readChatStoreRef();break;case "artifacts-store-ref":i=await c.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=await c.readFetchedSourcesStoreRef();break;default:return R(`getConfig: unknown key "${t}"`)}return b({value:i})}catch(t){return T(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;if(!t)return R("getOutputsDataObject requires params.key");if(t===chunkJ7KE7SPA_cjs.h)return b(null);let c=await W();return b(c[t]??null)}catch(t){return T(t)}},async getAllOutputsDataObjects(n){try{return b(await W())}catch(t){return T(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?b(await(await K()).readComputedValues(t)):R("getOutputsComputedValues requires params.key")}catch(t){return T(t)}},async getAllOutputsComputedValues(n){try{return b(await(await K()).readAllComputedValues())}catch(t){return T(t)}},async getOutputsFetchedSources(n){try{let t=n.params?.key;if(!t)return R("getOutputsFetchedSources requires params.key");let c=await(await ie()).listSources(t),i={};for(let A of c)i[A]=await ue(`${t}/${A}`);return b(i)}catch(t){return T(t)}},async getAllOutputsFetchedSources(n){try{let t=await ie(),c=await(await le()).listKeys(),i=new Set;for(let I of c){let F=I.indexOf("/");F>0&&!I.includes("/.staged/")&&i.add(I.slice(0,F));}let A={};for(let I of i){let F=await t.listSources(I);if(F.length!==0){A[I]={};for(let C of F)A[I][C]=await ue(`${I}/${C}`);}}return b(A)}catch(t){return T(t)}},async buildSseOneShotPayload(n){try{let t=(await(await $()).readAllCards()).filter(C=>C.id!==chunkJ7KE7SPA_cjs.i),c=await this.status({});if(c.status!=="success")return c;let i=await this.getAllOutputsDataObjects({});if(i.status!=="success")return i;let A=await this.getAllOutputsComputedValues({});if(A.status!=="success")return A;let I=A.data,F={};for(let C of t){let x=typeof C?.id=="string"?C.id:null;if(!x)continue;let Q=C.card_data&&typeof C.card_data=="object"&&!Array.isArray(C.card_data)?C.card_data:{};F[x]={schema_version:"v1",card_id:x,card_data:{...Q},computed_values:I[x]&&typeof I[x]=="object"?I[x]:{}};}return b({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i.data,cardRuntimeById:F})}catch(t){return T(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return R("addCardFiles requires params.cardId");let i=await St(await $(),{emitNotification:f}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:b({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return T(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return R("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await E({type:"task-removal",taskName:t,timestamp:q()}),t!==chunkJ7KE7SPA_cjs.i&&await E({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:q()}),L(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await E({type:"task-restart",taskName:t,timestamp:q()}),L(),b()):R("retrigger requires params.id")}catch(t){return T(t)}},async processAccumulatedEvents(n){return await re(),k()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i=!!n.params?.restart;if(!t&&!c)return R("upsertCard requires --card-id <id> or --all");let A=await $(),I=c?(await A.readAllCards()).map(x=>x.id):[t];for(let x of I)if(!await A.readCard(x))return R(`Card "${x}" not found in board at ${e.value}`);let F=o.kvStorage("card-upsert"),C=!1;for(let x of I){let Q=await A.readCard(x);if(!Q)continue;let G=chunkJ7KE7SPA_cjs.G(Q),X=o.hashFn(G),de=await F.read(x),ce=de?.taskConfigHash!==X;if(!(!ce&&!i)){if(ce){let Ie=de?.blobRef??await A.readCardKey(x)??x;await E({type:"task-upsert",taskName:x,taskConfig:G,timestamp:q()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:q()}),C=C||x!==chunkJ7KE7SPA_cjs.i;}i&&await E({type:"task-restart",taskName:x,timestamp:q()});}}return C&&await E({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:q()}),L(),b()}catch(t){return T(t)}},async taskFailed(n){try{let t=n.params?.token;if(!t)return R("taskFailed requires params.token");let c=n.params?.error??"unknown error",i=be(t);return i?(await E({type:"task-failed",taskName:i.taskName,error:c,timestamp:q()}),L(),b()):R("Invalid callback token")}catch(t){return T(t)}},async taskProgress(n){try{let t=n.params?.token;if(!t)return R("taskProgress requires params.token");let c=(n.body??{}).update??{},i=be(t);return i?(await E({type:"task-progress",taskName:i.taskName,update:c,timestamp:q()}),L(),b()):R("Invalid callback token")}catch(t){return T(t)}},async sourceDataFetched(n){try{let t=n.params?.token,c=n.params?.ref;if(!t)return R("sourceDataFetched requires params.token");if(!c)return R("sourceDataFetched requires params.ref");let i=Ct(t);if(!i)return R("Invalid source token");let A=await ie(),I=i.dt||o.genId();i.dt||await A.ingestSourceDataStaged(i.cid,i.d,chunkVQCIOKJV_cjs.b(c),I);let F=be(i.cbk);return F?(await E({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:q(),deliveryToken:I,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),L(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}},async sourceDataFetchFailure(n){try{let t=n.params?.token,c=n.params?.reason??"unknown";if(!t)return R("sourceDataFetchFailure requires params.token");let i=Ct(t);if(!i)return R("Invalid source token");let A=be(i.cbk);return A?(await E({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),L(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}}}}
2
+ exports.a=mt;exports.b=gt;exports.c=pt;exports.d=yt;exports.e=Nt;exports.f=_t;exports.g=St;exports.h=$t;exports.i=nr;//# sourceMappingURL=chunk-K5TEZRZK.cjs.map
3
+ //# sourceMappingURL=chunk-K5TEZRZK.cjs.map
@@ -1,2 +1,2 @@
1
- import {b,c as c$1}from'./chunk-ANKA7HEJ.js';import {b as b$1}from'./chunk-44L64VQ2.js';function c(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function l(e){return typeof e=="string"?e.startsWith("b64:")?b$1(e).value:e:e.value}function m(e){return {async enqueueRequest(t){return (await e.enqueue(t)).id},async leaseRequests(t){return (await e.lease(t)).map(r=>({...c(r),leaseToken:r.leaseToken,leaseExpiresAt:r.leaseExpiresAt}))},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,a){return e.nack(t,r,a)},async peekActive(){return (await e.peekActive()).map(c)},async peekDeadLetter(){return (await e.peekDeadLetter()).map(t=>({...c(t),reason:t.reason}))}}}function h(e){async function t(r){let a=await e.read(r);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}return {async readTaskExecutorRef(){let r=await t("task-executor");if(r?.trim())return c$1(r.trim())},writeTaskExecutorRef(r){return e.write("task-executor",b(r))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){return e.write("chat-handler-flow",r)},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){return e.write("board-runtime-store-ref",r)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){return e.write("card-store-ref",r)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){return e.write("outputs-store-ref",r)},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){return e.write("queue-store-ref",r)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){return e.write("scratch-store-ref",r)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){return e.write("chat-store-ref",r)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){return e.write("artifacts-store-ref",r)},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){return e.write("fetched-sources-store-ref",r)}}}function y(e){let t=e.callbackTransport,r=e.resolveBlob??(async o=>{let s=await e.blobStorage("").read(o.value);if(s==null)throw new Error(`Blob not found for ref ${o.kind}:${o.value}`);return s});async function a(o,s){if(o.howToRun==="queue-storage")return e.queueStoreRef?(await m(e.queueStorageForRef(e.queueStoreRef,"task-executor")).enqueueRequest({boardId:typeof o.extra?.boardId=="string"?o.extra.boardId:e.boardId,ref:o,args:s}),{dispatched:true}):{dispatched:false,error:"queue-storage dispatch requires queueStoreRef"};if(o.howToRun==="http:post"){let n=e.fetch??globalThis.fetch;if(!n)return {dispatched:false,error:"http:post dispatch requires fetch support"};let i=await n(l(o.whatToRun),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...s,...o.extra?{extra:o.extra}:{}})});if(!i.ok){let g=await i.text().catch(()=>"");return {dispatched:false,error:`HTTP ${i.status}: ${g}`}}return {dispatched:true}}return {dispatched:false,error:`Unsupported hosted async transport "${o.howToRun}"`}}return {kvStorage:e.kvStorage,kvStorageForRef:e.kvStorageForRef,blobStorage:e.blobStorage,blobStorageForRef:e.blobStorageForRef,chatStorageForRef:e.chatStorageForRef,queueStorageForRef:e.queueStorageForRef,scratchStorage:e.scratchStorage,scratchStorageForRef:e.scratchStorageForRef,archiveFactory:e.archiveFactory,archiveFactoryForRef:e.archiveFactoryForRef,journalStorage:e.journalStorage,journalStorageForRef:e.journalStorageForRef,lock:e.lock,get callbackTransport(){return t},set callbackTransport(o){t=o;},dispatchExecution:(o,s)=>e.dispatchExecution?.(o,s)??a(o,s),supportsDirectSourceOutput:e.supportsDirectSourceOutput,resolveBlob:r,hashFn:e.hashFn,genId:e.genId,requestProcessAccumulated:e.requestProcessAccumulated,publishBoardChangeNotifications:e.publishBoardChangeNotifications,warn:e.onWarn}}export{m as a,h as b,y as c};//# sourceMappingURL=chunk-6MD6FVE3.js.map
2
- //# sourceMappingURL=chunk-6MD6FVE3.js.map
1
+ import {b,c as c$1}from'./chunk-ANKA7HEJ.js';import {b as b$1}from'./chunk-44L64VQ2.js';function c(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function l(e){return typeof e=="string"?e.startsWith("b64:")?b$1(e).value:e:e.value}function m(e){return {async enqueueRequest(t){return (await e.enqueue(t)).id},async leaseRequests(t){return (await e.lease(t)).map(r=>({...c(r),leaseToken:r.leaseToken,leaseExpiresAt:r.leaseExpiresAt}))},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,a){return e.nack(t,r,a)},async peekActive(){return (await e.peekActive()).map(c)},async peekDeadLetter(){return (await e.peekDeadLetter()).map(t=>({...c(t),reason:t.reason}))}}}function h(e){async function t(r){let a=await e.read(r);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}return {async readTaskExecutorRef(){let r=await t("task-executor");if(r?.trim())return c$1(r.trim())},writeTaskExecutorRef(r){return e.write("task-executor",b(r))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){return e.write("chat-handler-flow",r)},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){return e.write("board-runtime-store-ref",r)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){return e.write("card-store-ref",r)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){return e.write("outputs-store-ref",r)},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){return e.write("queue-store-ref",r)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){return e.write("scratch-store-ref",r)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){return e.write("chat-store-ref",r)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){return e.write("artifacts-store-ref",r)},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){return e.write("fetched-sources-store-ref",r)}}}function y(e){let t=e.callbackTransport,r=e.resolveBlob??(async o=>{let s=await e.blobStorage("").read(o.value);if(s==null)throw new Error(`Blob not found for ref ${o.kind}:${o.value}`);return s});async function a(o,s){if(o.howToRun==="queue-storage")return e.queueStoreRef?(await m(e.queueStorageForRef(e.queueStoreRef,"task-executor")).enqueueRequest({boardId:typeof o.extra?.boardId=="string"?o.extra.boardId:e.boardId,ref:o,args:s}),{dispatched:true}):{dispatched:false,error:"queue-storage dispatch requires queueStoreRef"};if(o.howToRun==="http:post"){let n=e.fetch??globalThis.fetch;if(!n)return {dispatched:false,error:"http:post dispatch requires fetch support"};let i=await n(l(o.whatToRun),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...s,...o.extra?{extra:o.extra}:{}})});if(!i.ok){let g=await i.text().catch(()=>"");return {dispatched:false,error:`HTTP ${i.status}: ${g}`}}return {dispatched:true}}return {dispatched:false,error:`Unsupported hosted async transport "${o.howToRun}"`}}return {kvStorage:e.kvStorage,kvStorageForRef:e.kvStorageForRef,blobStorage:e.blobStorage,blobStorageForRef:e.blobStorageForRef,chatStorageForRef:e.chatStorageForRef,queueStorageForRef:e.queueStorageForRef,scratchStorage:e.scratchStorage,scratchStorageForRef:e.scratchStorageForRef,archiveFactory:e.archiveFactory,archiveFactoryForRef:e.archiveFactoryForRef,journalStorage:e.journalStorage,journalStorageForRef:e.journalStorageForRef,lock:e.lock,get callbackTransport(){return t},set callbackTransport(o){t=o;},dispatchExecution:(o,s)=>e.dispatchExecution?.(o,s)??a(o,s),supportsDirectSourceOutput:e.supportsDirectSourceOutput,resolveBlob:r,hashFn:e.hashFn,genId:e.genId,requestProcessAccumulated:e.requestProcessAccumulated,publishBoardChangeNotifications:e.publishBoardChangeNotifications,warn:e.onWarn}}export{m as a,h as b,y as c};//# sourceMappingURL=chunk-PEJRTZU3.js.map
2
+ //# sourceMappingURL=chunk-PEJRTZU3.js.map