yaml-flow 8.11.2 → 8.11.3

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 (34) hide show
  1. package/browser/adapters/firestore-storage.js +2 -2
  2. package/browser/adapters/localstorage-storage.js +3 -3
  3. package/browser/asset-integrity.json +5 -5
  4. package/browser/server-runtime-controlface.js +5 -5
  5. package/examples/board/test/server-http-test-browser.ts +8 -0
  6. package/examples/board/test/server-http-test.js +14 -18
  7. package/lib/board-live-cards-node.cjs +2 -2
  8. package/lib/board-live-cards-node.js +2 -2
  9. package/lib/board-live-cards-public.cjs +1 -1
  10. package/lib/board-live-cards-public.js +1 -1
  11. package/lib/board-live-cards-server-runtime.cjs +1 -1
  12. package/lib/board-live-cards-server-runtime.js +1 -1
  13. package/lib/chunk-5VTIOM2U.js +3 -0
  14. package/lib/chunk-BAG7MHZP.cjs +3 -0
  15. package/lib/chunk-EZOXABJ2.js +3 -0
  16. package/lib/chunk-HVLWVMG6.cjs +3 -0
  17. package/lib/chunk-SEUSFOMM.js +3 -0
  18. package/lib/{chunk-42ZOYXEV.cjs → chunk-YQ4MW72D.cjs} +3 -3
  19. package/lib/cloud-storage.cjs +1 -1
  20. package/lib/cloud-storage.js +1 -1
  21. package/lib/firestore-storage/index.cjs +1 -1
  22. package/lib/firestore-storage/index.js +1 -1
  23. package/lib/localstorage-storage/index.cjs +1 -1
  24. package/lib/localstorage-storage/index.js +1 -1
  25. package/lib/server-runtime/index.cjs +1 -1
  26. package/lib/server-runtime/index.js +1 -1
  27. package/lib/server-runtime-controlface/index.cjs +1 -1
  28. package/lib/server-runtime-controlface/index.js +1 -1
  29. package/package.json +1 -1
  30. package/lib/chunk-AHW6EMUO.js +0 -3
  31. package/lib/chunk-EYBDAEVO.cjs +0 -3
  32. package/lib/chunk-HFI2NAZJ.js +0 -3
  33. package/lib/chunk-LDVJPFIW.js +0 -3
  34. package/lib/chunk-ZOZ7ZDGA.cjs +0 -3
@@ -1,3 +0,0 @@
1
- import {a,b}from'./chunk-JB4Q2W7I.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$6,c as c$2}from'./chunk-O5UYCGIN.js';import {p,j,k,l,c as c$1,d as d$1,m,n,e as e$1,a as a$8,b as b$3,o}from'./chunk-CZ6ZFWFT.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$c}from'./chunk-RKKSVOP2.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$9,c as c$4}from'./chunk-O7NOHKVR.js';import {a as a$a,b as b$4}from'./chunk-ZJ5M5COT.js';import {i,d,c,b as b$1,g,h}from'./chunk-HFI2NAZJ.js';import {a as a$b}from'./chunk-6MD6FVE3.js';import {y,z,l as l$1}from'./chunk-AHW6EMUO.js';import {a as a$5}from'./chunk-7QNEV5S3.js';import {a as a$7}from'./chunk-BJGK5FNL.js';import {a as a$1}from'./chunk-NIBLKYXN.js';import {e}from'./chunk-UGB7PC4P.js';function ie(R){let{apiBasePath:w,json:b,readJsonBody:$,bootstrapBoard:A,createMcpControlplaneToolRegistry:x,retriggerCard:D,applyCardAction:N,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:q}=R;async function j(T,S,W){let H=T.method||"GET",J=W,f=J.pathname;try{if(H==="POST"&&f===`${w}/mcp-actions`){await A();let p=Date.now(),y=new Date(p).toISOString(),O=await $(T),l=typeof O.tool=="string"?O.tool.trim():"",B=O.args&&typeof O.args=="object"&&!Array.isArray(O.args)?O.args:{};if(!l)return b(S,400,{error:"tool is required"}),!0;let k=a$9(B,"card_id");if(!k)return b(S,400,{error:"MCP action requires card_id"}),!0;if(l==="retrigger-card"||l==="retrigger"){await D(k);let F=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:200}}),!0}let P=c$4(B,"payload");if(l==="chat-send"&&!await E(k)){let F=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:409}),!0}if(l==="chat-send"){let F=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!F||!String(F).trim()){let L=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(L).toISOString(),responseSentAtMs:L,responseStatus:400}),!0}}await N(k,l,P);let I=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(I).toISOString(),responseSentAtMs:I,responseStatus:200}}),!0}if(H==="POST"&&f===`${w}/mcp-controlplane`){await A();let p=await $(T),y=typeof p.tool=="string"?p.tool.trim():"",O=p.args&&typeof p.args=="object"&&!Array.isArray(p.args)?p.args:{};if(!y)return b(S,400,{error:"tool is required"}),!0;try{let l=await a$a(y,O,x());if(l&&typeof l=="object"&&!Array.isArray(l)){let B=l;if(B.status==="fail")return b(S,400,{error:b$4(l,"Request failed")}),!0;if(B.status==="error")return b(S,500,{error:b$4(l,"Internal error")}),!0}b(S,200,l);}catch(l){let B=typeof l?.statusCode=="number"?Number(l.statusCode):500,k=l instanceof Error?l.message:String(l);b(S,B,{error:k});}return !0}let g=f.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/retrigger$`));if(H==="POST"&&g){await A();let p=decodeURIComponent(g[1]);return await D(p),b(S,200,{ok:!0}),!0}let d=f.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/actions$`));if(H==="POST"&&d){await A();let p=decodeURIComponent(d[1]),y=Date.now(),O=new Date(y).toISOString(),l=await $(T),B=l?.actionType;if(B==="chat-send"&&!await E(p)){let P=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:409}),!0}if(B==="chat-send"){let P=l?.payload??{},I=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!I||!String(I).trim()){let F=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:400}),!0}}await N(p,B,l?.payload);let k=Date.now();return b(S,200,{ok:!0,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(k).toISOString(),responseSentAtMs:k,responseStatus:200}),!0}let v=f.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/files/(\\d+)$`));if(H==="GET"&&v){let p=decodeURIComponent(v[1]),y=parseInt(v[2],10),O=J.searchParams.get("sn");return await q(S,p,y,O),!0}return !1}catch(g){let d=g?.statusCode||500;return b(S,d,{error:String(g?.message||g)}),true}}return {handleRuntimeApi:j}}var ze=3e4;function Ke(R){let w=R.socket?.remoteAddress??"";return w==="127.0.0.1"||w==="::1"||w==="::ffff:127.0.0.1"}function ce(R){let{apiBasePath:w,emitNotifications:b,readJsonBody:$,json:A}=R,x=`${w}/notify-q`;async function D(N,E,q){if(q.pathname!==x)return false;if((N.method??"").toUpperCase()!=="POST")return A(E,405,{status:"error",error:"Method not allowed"}),true;if(!Ke(N))return A(E,403,{status:"error",error:"Forbidden"}),true;let j;try{j=await $(N);}catch{return A(E,400,{status:"error",error:"Invalid JSON body"}),true}if(!j||typeof j!="object"||!Array.isArray(j.notifications))return A(E,400,{status:"error",error:"body.notifications must be an array"}),true;let T=j.notifications,{accepted:S,rejected:W}=b$3(T,Date.now(),ze);return S.length>0&&b(S),A(E,200,{status:"success",data:{accepted:S.length,rejected:W}}),true}return {handleNotifyRoute:D}}var de={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},ue="chat-handler-flow-queue",ot="__probe__echo__probe__";function jr(R){let w=String(R.apiBasePath||"/api/board").replace(/\/$/,""),b$3={...de,...R.corsHeaders||{}},$=R.queueLaneTuning??{},A=R.boardId||"",x=R.logger||{info:console.log,warn:console.warn,error:console.error},D=R.invocationAdapter,N=R.chatFlowRunner||null,E=R.notificationTransport||null,q=R.serverUrl||null,j$1=R.executionExtra||{},T=R.onSseClientConnected,S=R.onSseClientDisconnected,W=R.onChannelSubscribed,H=R.onChannelUnsubscribed,J=a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:S}),f=a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function g$1(t){function e(a){return {...a,queueStorageForRef(u,C){return a$7(a.queueStorageForRef(u,C),{lane:C,emitNotification:i$1})}}}function r(a){return {...a,queueStorageForRef(u,C){return h(a.queueStorageForRef(u,C),{lane:C,emitNotification:i$1})}}}function n(a){return {async get(u){return a.get(u)},async set(u){return a.set(u)},async del(u){return a.del(u)},async patch(u){return a.patch(u)},async appendFiles(u){return a.appendFiles(u)}}}function o(a){return {async get(u){return await a.get(u)},async set(u){return await a.set(u)},async del(u){return await a.del(u)},async patch(u){return await a.patch(u)},async appendFiles(u){return await a.appendFiles(u)}}}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(t.boardAdapter),M=t.nonCoreAdapter??(!a$4(c$2)&&l$2(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}):y(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}),_=t.nonCore??(M?z(t.baseRef,M,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c$2.chatStorageForRef(t.chatStoreRef),dt,We=a$4(c$2)?(()=>{let a=d(c(b$1(c$2.kvStorageForRef(t.cardStoreRef)),c$2.hashFn),x.warn),u=g(a,{emitNotification:i$1}),C=o(u);return dt={get(m){return C.get(m)},set(m){return C.set(m)}},C})():(()=>{let a=c$2.kvStorageForRef(t.cardStoreRef),C=a$5(l$1({readIndex:()=>a.read("_index"),writeIndex:m=>a.write("_index",m),readCard:m=>a.read(m),writeCard:(m,ft)=>(a.write(m,ft),m),removeCard:m=>{a.delete(m);},cardExists:m=>a.read(m)!==null,defaultCardKey:m=>m},x.warn),{emitNotification:i$1});return dt=C,n(C)})(),lt;if(a$4(c$2)){let a=c$2.blobStorageForRef(t.artifactsStoreRef);lt={async putBytes(u,C){if(a.writeBytes){await a.writeBytes(u,C);return}let m=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(u,m);},async getBytes(u){if(a.readBytes){let m=await a.readBytes(u);if(m!==null)return m}let C=await a.read(u);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(u){return await a.listKeys(u)}};}else {let a=c$2.blobStorageForRef(t.artifactsStoreRef),u=a$6(a);lt={putBytes(C,m,ft){u.putBytes(C,m,ft);},getBytes(C){return u.getBytes(C)},listKeys(C){return u.list(C).map(m=>m.key)}};}let Je={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:_,publicCardStore:dt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return lt},get chatStorage(){return Ue},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 d$3=R.boards.map(g$1),v=new Map;function p$1(t){return v.get(t)??0}function y$1(t){return t.queueStoreRef}function O(t,e){if(a$4(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(y$1(t),e);return a$b(n)}let r=t.boardAdapter.queueStorageForRef(y$1(t),e);return a$c(r)}function l$2(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function B(t){let e=d$3[p$1(t)];return {files:e?e.filesArtifacts:null}}function k$1(){return c$2()}function P(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function I(t){return "cardId"in t&&typeof t.cardId=="string"?z$1(t.cardId)??void 0:d$3[0]??void 0}function F(t){for(let e of t){let r=I(e);if(r)return r}return d$3[0]??void 0}function L(t,e$2={}){if(!t||t.length===0)return;let r=e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e$2.ctx??F(r);if(e$2.appendState!==false&&o&&e$1(o.notification,n),e$2.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&J.broadcastNotificationBatch(i),s.length>0&&f.broadcastNotificationBatch(s);}if(!(e$2.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){L(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function le(t){if(!t||t.notificationTeardown||!E||!t.notifyRef)return;let e=await E.subscribe(t.notifyRef,r=>{let n=a$8(r);L(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function fe(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 le(t),!t.chatHandlerFlow&&t.chatHandlerRef&&D.describe)try{let o=await D.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?x.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&x.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){x.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ct(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&&L(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function gt(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"&&(v.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of d$3)await fe(t);}async function at(){await G();for(let t=0;t<d$3.length;t++)await ct(d$3[t]),await gt(d$3[t],t),await ct(d$3[t]);}async function Rt(t=false){t||await G();for(let e of d$3){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function z$1(t){return d$3[p$1(t)]??null}async function X(t){let e=z$1(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 pe(){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 d$3)e.push(...await t(r));return e}function yt(){return d$3[0]??null}function me(t){return z$1(t)??yt()}function U(t){let e=me(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ge(t){return await U(t).isProcessing(t)}async function Y(t,e){let r=await tt.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 tt=a$1({append(t,e,r,n,o){return U(t).append(t,e,r,n,o)},readAll(t){return U(t).readAll(t)},readAfter(t,e){return U(t).readAfter(t,e)},clear(t){return U(t).clear(t)},setProcessing(t,e){return U(t).setProcessing(t,e)},isProcessing(t){return U(t).isProcessing(t)},getConfig(t){return U(t).getConfig(t)},setConfig(t,e){return U(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);}}),ht=p({boardContexts:d$3,cardOwnerIndex:v,cardContextForCard:t=>z$1(t),readStatusSnapshot:()=>be(),readDataObjectsByToken:()=>Ce(),readCardRuntimeArtifacts:()=>Se(),readCardFromStore:t=>X(t),readCardDefinitions:()=>pe(),processAccumulatedLaneInternal:t=>Rt(t),reportSourceFetched:(t,e)=>Bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>kt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>St(t,e,r,n,o),chatStorePublic:tt,serverUrl:q,apiBasePath:w}),Re=ht.mcpCardStoreFacade,st=ht.createMcpFacade,ye=j({boardId:A,bootstrapBoard:()=>at(),sseHub:J,onChannelSubscribed:W,onChannelUnsubscribed:H,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>Re()});function he(t){return m(t)}function we(){return n(st())}function wt(){return o({boardId:A,uploadCardFile:St,getMcpFacade:()=>st(),controlplane:ye})}let it=k({boardId:A,boardContexts:d$3,readChatRecords:t=>Fe(t),getChatProcessing:t=>ge(t)}),be=it.readStatusSnapshot,Se=it.readCardRuntimeArtifacts,Ce=it.readDataObjectsByToken,ut=it.buildPublishedRuntimePayload;async function bt(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=z$1(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await X(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,M=e(i)||i;if(o&&JSON.stringify(M)===c)return;let h=await s.cardStoreOps.set({body:M});if(h.status!=="success")throw Object.assign(new Error(h.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let _=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(_.status!=="success")throw Object.assign(new Error(_.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Ae(t,e){await bt(t,e,{syncBoard:true});}async function Be(t,e){await bt(t,e,{syncBoard:false});}async function ke(t){let e=z$1(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await X(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 Pe(t){let e=await tt.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 Y(t,!1);}catch{}}async function Oe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await tt.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 Fe(t){return await U(t).readAll(t)}let St=l({safeCardId:t=>P(t),artifactsStores:t=>B(t),cardFileMetadataStore:()=>k$1(),readCardFromStore:t=>X(t),updateCardLocalOnly:(t,e)=>Be(t,e),writeChatRecord:(t,e,r,n,o)=>Oe(t,e,r,n,o)}).uploadCardFile;async function Ct(t){let e=z$1(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 ve(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 xe(t,e,r=false,n="",o=""){try{let s=await Ct(t);if(!s){try{await Y(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:M}=s;if(!r)try{await Y(t,!0);}catch{}let h={boardId:A,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...j$1,...q?{serverUrl:q}:{}},_=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:ue}}:M;a$4(i.boardAdapter)?await O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}):O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await Y(t,!1);}catch{}x.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Te(t,e,r){if(e.howToRun==="built-in"&&b$2(e)===ue){let n=N,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:A,cardId:String(s.cardId||""),label:t.label,logger:x,serverUrl:q,executionExtra:j$1}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return D.invoke(e,r)}async function Ne(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?z$1(r):yt();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 Te(n,t.ref,t.args);if(!o.dispatched){if(r)try{await Y(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Ee(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=wt(),i=ve(r?.text),c=i?i.text:r?.text,M=await a$a("manage.add-chat-entry-and-any-attachments",{board_id:A,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(M?.status!=="success")throw new Error(b$4(M,`chat-send append failed for card ${t}`));let h=M?.data?.id;if(typeof h!="string"||!h)throw new Error(`chat-send did not return an append id for card ${t}`);let _=await a$a("setstate.chat-processing-started",{board_id:A,card_id:t},s);if(_?.status!=="success")throw new Error(b$4(_,`chat-send processing update failed for card ${t}`));xe(t,h,true,o,i?.assistant||"");return}await Ae(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=k$1().normalizeIncoming(r?.files,s);return c.length>0&&k$1().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 At(t,e,r){let n=await X(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=k$1().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=P(t),c=B(t),M=String(s.stored_name||""),h=`${i}/${M}`,_=c.files?await c.files.getBytes(h):null;if(!_)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:_}}async function je(t,e,r,n){let{fileRecord:o,bytes:s}=await At(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 Me(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 _e(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 Bt(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let n=d$3[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function kt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=d$3[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let De=b({sseHub:J,queueSseHub:f,corsHeaders:b$3,json:et,buildPublishedRuntimePayload:()=>ut(),onSseClientConnected:T,onChannelSubscribed:W,onChannelUnsubscribed:H,apiBasePath:w,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>at(),boardContexts:d$3,publishPersistedStateSnapshot:t=>ct(t),upsertCardsFromSource:(t,e)=>gt(t,e)}).handleWatchersRoutes,qe=a$2({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpFacade:()=>st(),createMcpToolRegistry:t=>he(t),resolveCardFileDownloadPayload:(t,e,r)=>At(t,e,r),isLikelyTextMimeType:t=>Me(t),sliceTextByLines:(t,e,r)=>_e(t,e,r)}).handleAgentfaceApi,Ie=a$3({apiBasePath:w,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ie({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpControlplaneToolRegistry:()=>wt(),retriggerCard:t=>ke(t),applyCardAction:(t,e,r)=>Ee(t,e,r),resolveChatHandlerTarget:t=>Ct(t),sendCardFileDownloadResponse:(t,e,r,n)=>je(t,e,r,n)}).handleRuntimeApi,He=ce({apiBasePath:w,emitNotifications:t=>V(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Le(t,e,r){return !!(await qe(t,e,r)||await Ie(t,e,r)||await De(t,e,r)||await He(t,e,r)||await $e(t,e,r))}return {get apiBasePath(){return w},get corsHeaders(){return b$3},get queueLaneTuning(){return $},handleRuntimeApi:Le,emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);},buildPublishedRuntimePayload:ut,__drainProcessAccumulatedLane:Rt,handleChatAgentRequest:Ne,clearChatRecords:Pe,reportSourceFetched(t,e){return Bt(t,{ref:e})},reportSourceFetchFailure(t,e){return kt(t,{reason:e})},get cardStore(){return d$3[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Mr(R){let w=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),b={...de,...R.corsHeaders||{}},$=R.serverMetaStore,A=R.boardRuntimeFactory,x=new Map,D="boards-config.json";function N(){let f=$.getText(D);if(!f)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(f)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function E(f){$.putText(D,JSON.stringify(f,null,2));}function q(f){let g=String(f||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return g.length>0&&g.length<=64?g:null}function j(f){if(x.has(f))return x.get(f);let d=N().boards.find(p=>p.id===f)||{},v=A(f,d);return x.set(f,v),v}function T(f,g,d){let v=JSON.stringify(d),p=typeof Buffer<"u"?Buffer.byteLength(v):new TextEncoder().encode(v).length;f.writeHead(g,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":p}),f.end(v);}async function S(f,g,d){let v=f.method||"GET",p=d.pathname;if(v==="GET"&&p===w)return T(g,200,{ok:true,boards:N().boards}),true;if(v==="POST"&&p===w){let y=[];for await(let F of f)y.push(F);let O=typeof Buffer<"u"?Buffer.concat(y).toString("utf-8").trim():new TextDecoder().decode(d$2(y)).trim(),l={};try{l=O?JSON.parse(O):{};}catch{l={};}let B=q(l.id);if(!B)return T(g,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let k=N();if(k.boards.some(F=>F.id===B))return T(g,409,{error:`Board "${B}" is already registered`}),true;let P=typeof l.label=="string"&&l.label.trim()?l.label.trim():B,I={id:B,label:P};for(let[F,L]of Object.entries(l))F==="id"||F==="label"||L!=null&&(I[F]=L);return k.boards.push(I),E(k),T(g,200,{ok:true,board:I}),true}return false}async function W(f,g,d){let p=d.pathname.match(new RegExp(`^${c$3(w)}/([^/]+)(/|$)`));if(!p)return false;let y=q(decodeURIComponent(p[1]));return y?N().boards.some(B=>B.id===y)?!!await j(y).handleRuntimeApi(f,g,d):(T(g,404,{error:`Board "${y}" not registered. POST ${w} with {id} to register it first.`}),true):(T(g,400,{error:"Invalid board id"}),true)}async function H(f,g,d){return !!(await S(f,g,d)||await W(f,g,d))}function J(f){if(!N().boards.some(d=>d.id===f))throw Object.assign(new Error(`Board "${f}" not registered`),{statusCode:404});return {service:j(f)}}return {get apiBasePath(){return w},get corsHeaders(){return b},handleApi:H,requireBoardService:J}}export{jr as a,Mr as b};//# sourceMappingURL=chunk-LDVJPFIW.js.map
3
- //# sourceMappingURL=chunk-LDVJPFIW.js.map
@@ -1,3 +0,0 @@
1
- 'use strict';var chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkEYBDAEVO_cjs=require('./chunk-EYBDAEVO.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');async function rt(t,o,a){let r=await t.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function Rt(t){return typeof t=="object"&&t!==null&&"then"in t&&typeof t.then=="function"}function Ce(t,o){return Rt(t)?t.then(o):o(t)}function nt(t,o){let a={...t};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]=nt(a[r],s):a[r]=s;return a}function we(t,o,a){if(o.length===0)return t;let[r,...s]=o;if(s.length===0)return {...t,[r]:a};let d=t[r]!==null&&typeof t[r]=="object"&&!Array.isArray(t[r])?t[r]:{};return {...t,[r]:we(d,s,a)}}function at(t){return {read:a=>t.read(a),get(a,r){return Ce(t.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)=>t.write(a,r),delete:a=>t.delete(a),listKeys:a=>t.listKeys(a),shallowMerge(a,r){return Ce(t.read(a),s=>t.write(a,{...s??{},...r}))},deepMerge(a,r){return Ce(t.read(a),s=>t.write(a,nt(s??{},r)))},patch(a,r,s){return Ce(t.read(a),d=>{let f=r.split(".").filter(Boolean);return t.write(a,we(d??{},f,s))})}}}function ot(t){return at(t)}function st(t,o){return {async readIndex(){return await t.read("_index")},writeIndex(a){return t.write("_index",a)},async readCard(a){return await t.read(a)},async writeCard(a,r){return await t.write(a,r),o(r)},removeCard(a){return t.delete(a)},async cardExists(a){return await t.read(a)!==null},defaultCardKey(a){return a}}}function it(t,o){async function a(){return await t.readIndex()??{}}return {async readCard(r){let s=(await a())[r];return !s||!await t.cardExists(s.key)?null:await t.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 t.cardExists(d.key))continue;let f=await t.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??t.defaultCardKey(r),w=await t.writeCard(v,s);f[r]={key:v,checksum:w,updatedAt:new Date().toISOString()},await t.writeIndex(f);},async patchCard(r,s,d){let f=await a(),v=f[r];if(!v||!await t.cardExists(v.key))throw new Error(`card "${r}" not found`);let w=await t.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=we(w,m,d),k=await t.writeCard(v.key,l);f[r]={key:v.key,checksum:k,updatedAt:new Date().toISOString()},await t.writeIndex(f);},async removeCard(r){let s=await a(),d=s[r];d&&(await t.removeCard(d.key),delete s[r],await t.writeIndex(s));},readIndex(){return a()}}}function Ot(t,o){return chunkEYBDAEVO_cjs.a(t,o)}function Ft(t,o,a){return {blob:t,kv:o,journal:a}}function ut(t,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 k=chunk2RIHC5TZ_cjs.e(m);if(k.length===1){await l(k[0]);return}await l(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:k}));}async function f(m){let l=m.params?.id;if(l){let k=await t.readCard(l);if(!k)throw new Error(`card "${l}" not found`);return [k]}return await t.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 k=Array.isArray(l)?l:[l];for(let h of k){if(typeof h.id!="string")return r("each card must have a string `id` field");await t.writeCard(h.id,h);}return await d(k.map(h=>({kind:"card_refreshed",cardId:h.id,card:h}))),a({count:k.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],k=m.params?.id,h=k?[...l,k]:l;if(h.length===0)return r("del requires body.ids (string[]) or params.id");for(let B of h)await t.removeCard(B);return await d(h.map(B=>({kind:"card_removed",cardId:B}))),a({count:h.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,k=m.params?.path;if(!l)return r("patch requires params.id");if(!k)return r("patch requires params.path");let h=m.body,B=h&&Object.prototype.hasOwnProperty.call(h,"value")?h.value:m.body;await t.patchCard(l,k,B);let x=await t.readCard(l);return x?(await d([{kind:"card_refreshed",cardId:l,card:x}]),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 k=await t.readCard(l);if(!k)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 B=k.card_data&&typeof k.card_data=="object"&&!Array.isArray(k.card_data)?k.card_data:{},x=Array.isArray(B.files)?B.files:[],$=[...x,...h],V=h.map((L,z)=>({idx:x.length+z,entry:L})),E=await this.patch({params:{id:l,path:"card_data.files"},body:{value:$}});return E.status!=="success"?E:a({files_added:V})}catch(l){return s(l)}}}}async function kt(t,o){return (await t.peekActive()).find(a=>a.id===o)}function _t(t,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 t.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await t.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:t.enqueueIfAbsent?async(r,s)=>{let d=await t.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return t.lease(r)},ack(r,s){return t.ack(r,s)},nack(r,s,d){return t.nack(r,s,d)},peekActive(r){return t.peekActive(r)},peekDeadLetter(r){return t.peekDeadLetter(r)},async stage(r,s){return t.stage(r,s)},async commitStaged(r){let s=await t.commitStaged(r);if(s){let d=await kt(t,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return t.discardStaged(r,s)},peekStaged(r){return t.peekStaged(r)}}}function A(t){return t!==void 0?{status:"success",data:t}:{status:"success"}}function C(t){return {status:"fail",error:t}}function I(t){return {status:"error",error:t instanceof Error?t.message:String(t)}}var dt="sys_keys_board_state";function q(){return new Date().toISOString()}function Ct(t){let o=new TextEncoder().encode(t),a=Array.from(o,r=>String.fromCharCode(r)).join("");return btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function lt(t){let o=t.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 he(t){try{let o=JSON.parse(lt(t));return typeof o?.t=="string"?{taskName:o.t}:null}catch{return null}}function ct(t){return Ct(JSON.stringify(t))}function mt(t){try{let o=JSON.parse(lt(t));return typeof o?.cbk=="string"&&typeof o?.cid=="string"&&typeof o?.b=="string"&&typeof o?.d=="string"?o:null}catch{return null}}function wt(t){return chunkEYBDAEVO_cjs.j(t,chunkEYBDAEVO_cjs.o,()=>({_sources:{}}))}function ht(t,o){return chunkEYBDAEVO_cjs.h(t,o)}function Pt(t){return chunkEYBDAEVO_cjs.k(t)}function vt(t,o){return chunkEYBDAEVO_cjs.i(t,o)}function bt(t,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,l=w.card_data??{},k=w.source_defs??[],h=k,B=await a.cardRuntimeStore.readRuntime(m),x=false,$=async()=>{x&&(await a.cardRuntimeStore.writeRuntime(m,B),x=false);},V=p=>chunkEYBDAEVO_cjs.p(B._sources[p]),E=(p,S)=>{B._sources[p]=chunkEYBDAEVO_cjs.p(S),x=true;},L=f.taskState?.executionCount??0;if(B._lastExecutionCount!==L&&(B._sources={},B._lastExecutionCount=L,x=true),f.update){let p=f.update.outputFile;if(p){let S=V(p);if(f.update.failure){let T=f.update.rqt??S.lastRequestedToken??S.queueRequestedToken;T&&E(p,chunkEYBDAEVO_cjs.s(S,T));}else {let T=f.update.rqt;if(!S.lastCompletedToken||T>S.lastCompletedToken){let N=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,Z=N?await a.fetchedSourcesStore.commitSourceData(m,p,N):false;E(p,Z?chunkEYBDAEVO_cjs.r(S,T):chunkEYBDAEVO_cjs.s(S,T));}}await $();}}let z={};for(let p of k){if(!p.outputFile)continue;let S=await a.fetchedSourcesStore.readSourceData(m,p.outputFile);S!==null&&(z[p.bindTo]=S);}let M={};for(let[p,S]of Object.entries(f.state??{}))if(S!==null&&typeof S=="object"&&!Array.isArray(S)){let T=S[p];M[p]=T!==void 0?T:S;}else M[p]=S;let W={id:m,card_data:{...l},requires:M,source_defs:k,compute:w.compute};W._sourcesData=z,w.compute&&chunkQBEQL4TL_cjs.a.runSync(W,{sourcesData:z}),(s??(()=>{}))(m,W.computed_values??{});let Y=chunkQBEQL4TL_cjs.a.enrichSourcesSync(Array.isArray(w.source_defs)?w.source_defs:void 0,{card_data:w.card_data,requires:M}),Pe={...w,source_defs:Array.isArray(Y)?Y.map(p=>({...p,boardDir:typeof p.boardDir=="string"&&p.boardDir?p.boardDir:t.value})):Y},X=q(),me=f.update?void 0:X,ue=h.filter(p=>{let S=p.outputFile;if(typeof S!="string"||!S)return true;let T=V(S);me&&(T={...T,queueRequestedToken:me},E(S,T));let N=T.queueRequestedToken??T.lastRequestedToken??X;return chunkEYBDAEVO_cjs.q(T,N)==="dispatch"});if(await $(),ue.length>0){let p=false,S=X;for(let T of ue){let N=T.outputFile;if(typeof N!="string"||!N)continue;let Z=V(N),de=Z.queueRequestedToken??X;E(N,{...Z,lastRequestedToken:de}),S=de,p=true;}return p&&await $(),p&&(v.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(t),enrichedCard:Pe,callbackToken:f.callbackToken,rqt:S}}),await a.executionRequestStore.appendEntries(o,v)),"task-initiated"}if(h.some(p=>{let S=p.outputFile;if(typeof S!="string"||!S)return false;let T=V(S),N=T.queueRequestedToken??T.lastRequestedToken??X;return chunkEYBDAEVO_cjs.q(T,N)==="in-flight"}))return "task-initiated";let ve=w.provides??[],H={};for(let{bindTo:p,ref:S}of ve)H[p]=chunkQBEQL4TL_cjs.a.resolve(W,S);return (d??(()=>{}))(H),r(f.nodeId,H),v.length>0&&await a.executionRequestStore.appendEntries(o,v),"task-initiated"}}function Xt(t,o,a={}){chunkEYBDAEVO_cjs.d(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=chunkVQCIOKJV_cjs.a(t),f=a.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let e=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(e)}),v=null,w=a.boardRuntimeStoreRef,m=a.scratchStoreRef,l=a.taskExecutorRef,k=a.chatHandlerFlow;function h(){if(!w)throw new Error(`Board at ${t.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return w}function B(n){if(n.length!==0)try{let e=chunk2RIHC5TZ_cjs.e(n),c=chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:e});return Promise.resolve(f(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(e){s(`[async-board-live-cards-public] emitNotification failed: ${e instanceof Error?e.message:String(e)}`);return}}let x=()=>chunkWRMOGPRG_cjs.b(o.kvStorageForRef(h())),$=t.value,V=()=>chunkEYBDAEVO_cjs.b(chunkEYBDAEVO_cjs.a(()=>o.kvStorageForRef(h()),o.hashFn),"v1"),E=async()=>{let n=await x().readOutputsStoreRef();if(!n)throw new Error(`Board at ${t.value} has no outputs store configured.`);return Pt(o.kvStorageForRef(n))},L=async()=>{let n=await x().readCardStoreRef();if(!n)throw new Error(`Board at ${t.value} has no card store configured.`);let e=o.kvStorageForRef(n);return it(st(ot(e),o.hashFn),s)};async function z(){return !!(await V().readSnapshot($)).values[chunkEYBDAEVO_cjs.n]}async function M(){let n=await V().readSnapshot($);if(!n.values[chunkEYBDAEVO_cjs.n])throw new Error(`Board not initialized at ${t.value}`);return chunkEYBDAEVO_cjs.w(n.values)}async function W(n,e){let c=await V().commitSnapshot($,{schemaVersion:"v1",expectedVersion:e,deleteKeys:[],shallowMerge:chunkEYBDAEVO_cjs.v(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${e??"null"} current=${c.currentVersion??"null"}`)}let Y=()=>chunkEYBDAEVO_cjs.c(o.journalStorageForRef(h()));async function Pe(){return l??await x().readTaskExecutorRef()}function X(n){if(!n||typeof n!="object"||Array.isArray(n))return false;let e=n.__private;return !!e&&typeof e=="object"&&!Array.isArray(e)&&e.visible_controlplane_only===true}async function me(n){let e=await(await L()).readAllCards(),c=[...new Set(e.filter(R=>!X(R)).map(R=>R.id).filter(R=>typeof R=="string"&&R.length>0))].sort(),i=[...new Set(Object.keys(n).filter(R=>R&&R!==dt))].sort();return {card_ids:c,data_object_keys:i}}async function ue(){let n=await(await E()).readAllDataObjects();return {...n,[dt]:await me(n)}}async function j(n){await Y().appendEvent(n);}async function ve(){let n=await x().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${t.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function H(){return o.blobStorageForRef(await ve())}async function p(){return ht(await H(),n=>o.resolveBlob(n))}async function S(n){let e=(await H()).keyRef?.(n);if(!e)throw new Error("configured fetched-sources store does not support keyRef");let c=await Promise.resolve(e);return chunkVQCIOKJV_cjs.a(c)}async function T(){let n=vt(o.kvStorageForRef(h()),async(u,g)=>{let P=u.payload,F=(P.enrichedCard??{}).id??P.cardId??"unknown";await j({type:"task-failed",taskName:F,error:g,timestamp:q()});}),e=wt(o.kvStorageForRef(h())),c=await H(),i=await p(),R=await L(),b=await E(),O=new Map,y=new Map,K=[],G=[],oe=[],se=new Map,ce=new Set,be={async readRuntime(u){return O.get(u)??await e.readRuntime(u)},async writeRuntime(u,g){O.set(u,g),Ie[u]=g;}},gt={async readSourceData(u,g){let P=`${u}/${g}`;return y.has(P)?y.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}`,F=await c.read(D);if(F==null){let Q=await Promise.resolve(c.keyRef?.(D));Q&&(F=await o.resolveBlob(Q));}if(F==null)return false;let J=`${u}/${g}`,re=F.trim();try{y.set(J,JSON.parse(re));}catch{y.set(J,re);}return K.push({cardId:u,outputFile:g,deliveryToken:P}),true},async hasSource(u,g){let P=`${u}/${g}`;return y.has(P)||await i.hasSource(u,g)},async listSources(u){let g=await i.listSources(u),P=[...y.keys()].filter(D=>D.startsWith(`${u}/`)).map(D=>D.slice(`${u}/`.length));return [...new Set([...g,...P])]}},Ae=await M(),pt=chunkG4XXRHL2_cjs.q(Ae.graph),Ie={...Ae.runtimeByCardId},{events:yt,newCursor:xe}=await Y().readEntriesAfterCursor(Ae.lastDrainedJournalId),le=yt,fe=chunkG4XXRHL2_cjs.u(pt,{handlers:{"card-handler":bt(t,xe,{cardStore:R,cardRuntimeStore:be,fetchedSourcesStore:gt,executionRequestStore:n},(u,g)=>{le.push({type:"task-completed",taskName:u,data:g,timestamp:q()});},(u,g)=>{G.push({cardId:u,values:g});},u=>{oe.push(u);})},onNodeRemoved:u=>{se.delete(u),O.delete(u),delete Ie[u],ce.add(u);}});for(;le.length>0;){let u=le;le=[];for(let g of u)if(g.type==="task-restart"){let P=await R.readCard(g.taskName);P&&se.set(g.taskName,P);}fe.pushAll(u),await fe.waitForHandlers();}let Ee=fe.getState();await fe.dispose({wait:true}),await W({lastDrainedJournalId:xe,graph:chunkG4XXRHL2_cjs.p(Ee),runtimeByCardId:Ie},(await V().readSnapshot($)).version);for(let{cardId:u,values:g}of G)await b.writeComputedValues(u,g);for(let u of oe)await b.writeDataObjects(u);for(let[u,g]of O)await e.writeRuntime(u,g);for(let u of K)await i.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let Ne=chunkEYBDAEVO_cjs.t(d,Ee);await b.writeStatusSnapshot(Ne);let ie=[];for(let{cardId:u,values:g}of G)ie.push({kind:"computed_values",cardId:u,values:g});for(let u of oe)for(let[g,P]of Object.entries(u))ie.push({kind:"data_object",key:g,payload:P});for(let[u,g]of se)ie.push({kind:"card_refreshed",cardId:u,card:g});for(let u of ce)ie.push({kind:"card_removed",cardId:u});ie.push({kind:"status",status:Ne}),await B(ie);let te=await Pe();if(!te)return;let _e=o.supportsDirectSourceOutput?.(te)===true;await n.dispatchEntriesForJournalId(xe,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(te.howToRun==="queue-storage"&&_e){try{let F=await x().readQueueStoreRef();if(!F)throw new Error(`Board at ${t.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let J=o.queueStorageForRef(F,"task-executor"),re=typeof te.extra?.boardId=="string"?te.extra.boardId:void 0,Q=[];for(let U of D){if(!U.outputFile)continue;let ge=o.genId(),pe=`${P}/.staged/${ge}/${U.outputFile}`,je=await Promise.resolve(c.keyRef?.(pe));if(!je)continue;let Ke={ref:chunkVQCIOKJV_cjs.a(je),deliveryToken:ge,outputFile:U.outputFile,cardId:P},St=ct({cbk:g.callbackToken,rg:t.value,br:chunkVQCIOKJV_cjs.a(t),cid:P,b:U.bindTo,d:U.outputFile,cs:void 0,rqt:g.rqt,dt:Ke.deliveryToken});Q.push({...re?{boardId:re}:{},ref:te,args:{source_def:U,base_ref:chunkVQCIOKJV_cjs.a(t),callback:r.createCallback(St),output:Ke}});}Q.length>0&&await J.enqueueMany(Q);}catch(F){await j({type:"task-failed",taskName:P,error:F instanceof Error?F.message:String(F),timestamp:q()});}return}for(let F of D){if(!F.outputFile)continue;let J;if(_e){let U=o.genId(),ge=`${P}/.staged/${U}/${F.outputFile}`,pe=await Promise.resolve(c.keyRef?.(ge));pe&&(J={ref:chunkVQCIOKJV_cjs.a(pe),deliveryToken:U,outputFile:F.outputFile,cardId:P});}let re=ct({cbk:g.callbackToken,rg:t.value,br:chunkVQCIOKJV_cjs.a(t),cid:P,b:F.bindTo,d:F.outputFile,cs:void 0,rqt:g.rqt,...J?{dt:J.deliveryToken}:{}}),Q=await o.dispatchExecution(te,{source_def:F,base_ref:chunkVQCIOKJV_cjs.a(t),callback:r.createCallback(re),...J?{output:J}:{}});Q.dispatched||await j({type:"task-failed",taskName:P,error:Q.error??"dispatch failed",timestamp:q()});}});}async function N(){try{let n=async()=>{let c=await M(),{events:i}=await Y().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await de();},e=await rt(o.lock,T,n);return A({ran:e!==!1})}catch(n){return I(n)}}async function Z(){return v||(v=N().finally(()=>{v=null;}),v)}async function de(){let n=await x().readQueueStoreRef();if(!n)throw new Error(`Board at ${t.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=o.queueStorageForRef(n,"process-accumulated");e.enqueueIfAbsent?await e.enqueueIfAbsent({boardRef:chunkVQCIOKJV_cjs.a(t)},`process-accumulated:${chunkVQCIOKJV_cjs.a(t)}`):await e.enqueue({boardRef:chunkVQCIOKJV_cjs.a(t)}),await o.requestProcessAccumulated?.();}async function ft(){let n=await x().readQueueStoreRef();if(!n)throw new Error(`Board at ${t.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await e.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await e.ack(i.id,i.leaseToken);if(c.length<64)return}}function ee(){de();}return {async init(n){try{let e=n.params?.cardStoreRef;if(!e)return C("init requires params.cardStoreRef");if(w=n.params?.boardRuntimeStoreRef,!w)return C("init requires params.boardRuntimeStoreRef");let c=n.params?.outputsStoreRef;if(!c)return C("init requires params.outputsStoreRef");let i=n.params?.queueStoreRef;if(!i)return C("init requires params.queueStoreRef");let R=n.params?.fetchedSourcesStoreRef;if(!R)return C("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let b=n.params?.chatStoreRef;if(!b)return C("init requires params.chatStoreRef");let O=n.params?.artifactsStoreRef;if(!O)return C("init requires params.artifactsStoreRef");await z()||await W({lastDrainedJournalId:"",graph:chunkG4XXRHL2_cjs.p(chunkG4XXRHL2_cjs.a(chunkEYBDAEVO_cjs.u)),runtimeByCardId:{}},null);let y=x();return await y.writeBoardRuntimeStoreRef(w),await y.writeCardStoreRef(e),await y.writeOutputsStoreRef(c),await y.writeQueueStoreRef(i),await y.writeFetchedSourcesStoreRef(R),await y.writeChatStoreRef(b),await y.writeArtifactsStoreRef(O),await(await E()).writeStatusSnapshot(chunkEYBDAEVO_cjs.t(d,chunkG4XXRHL2_cjs.q((await M()).graph))),A()}catch(e){return I(e)}},async status(n){try{let e=await E(),c=await e.readStatusSnapshot();return c||(c=chunkEYBDAEVO_cjs.t(d,chunkG4XXRHL2_cjs.q((await M()).graph)),await e.writeStatusSnapshot(c)),A(c)}catch(e){return I(e)}},async getCardStoreRef(n){try{let e=await x().readCardStoreRef();return e?A({storeRef:e}):C(`Board at ${t.value} has no card store configured`)}catch(e){return I(e)}},async getBoardRuntimeStoreRef(n){try{return A({storeRef:w??null})}catch(e){return I(e)}},async getOutputsStoreRef(n){try{let e=await x().readOutputsStoreRef();return e?A({storeRef:e}):C(`Board at ${t.value} has no outputs store configured`)}catch(e){return I(e)}},async getScratchStoreRef(n){try{return A({storeRef:m??null})}catch(e){return I(e)}},async getChatStoreRef(n){try{return A({storeRef:await x().readChatStoreRef()})}catch(e){return I(e)}},async getArtifactsStoreRef(n){try{return A({storeRef:await x().readArtifactsStoreRef()})}catch(e){return I(e)}},async getFetchedSourcesStoreRef(n){try{return A({storeRef:await x().readFetchedSourcesStoreRef()})}catch(e){return I(e)}},async getConfig(n){try{let e=n.params?.key;if(!e)return C("getConfig requires params.key");let c=x(),i;switch(e){case "task-executor":i=l??null;break;case "chat-handler-flow":i=k??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 C(`getConfig: unknown key "${e}"`)}return A({value:i})}catch(e){return I(e)}},async getOutputsDataObject(n){try{let e=n.params?.key;if(!e)return C("getOutputsDataObject requires params.key");let c=await ue();return A(c[e]??null)}catch(e){return I(e)}},async getAllOutputsDataObjects(n){try{return A(await ue())}catch(e){return I(e)}},async getOutputsComputedValues(n){try{let e=n.params?.key;return e?A(await(await E()).readComputedValues(e)):C("getOutputsComputedValues requires params.key")}catch(e){return I(e)}},async getAllOutputsComputedValues(n){try{return A(await(await E()).readAllComputedValues())}catch(e){return I(e)}},async getOutputsFetchedSources(n){try{let e=n.params?.key;if(!e)return C("getOutputsFetchedSources requires params.key");let c=await(await p()).listSources(e),i={};for(let R of c)i[R]=await S(`${e}/${R}`);return A(i)}catch(e){return I(e)}},async getAllOutputsFetchedSources(n){try{let e=await p(),c=await(await H()).listKeys(),i=new Set;for(let b of c){let O=b.indexOf("/");O>0&&!b.includes("/.staged/")&&i.add(b.slice(0,O));}let R={};for(let b of i){let O=await e.listSources(b);if(O.length!==0){R[b]={};for(let y of O)R[b][y]=await S(`${b}/${y}`);}}return A(R)}catch(e){return I(e)}},async buildSseOneShotPayload(n){try{let e=await(await L()).readAllCards(),c=await this.status({});if(c.status!=="success")return c;let i=await this.getAllOutputsDataObjects({});if(i.status!=="success")return i;let R=await this.getAllOutputsComputedValues({});if(R.status!=="success")return R;let b=R.data,O={};for(let y of e){let K=typeof y?.id=="string"?y.id:null;if(!K)continue;let G=y.card_data&&typeof y.card_data=="object"&&!Array.isArray(y.card_data)?y.card_data:{};O[K]={schema_version:"v1",card_id:K,card_data:{...G},computed_values:b[K]&&typeof b[K]=="object"?b[K]:{}};}return A({cardDefinitions:e,statusSnapshot:c.data,dataObjectsByToken:i.data,cardRuntimeById:O})}catch(e){return I(e)}},async addCardFiles(n){try{let e=n.params?.cardId;if(!e)return C("addCardFiles requires params.cardId");let i=await ut(await L(),{emitNotification:f}).appendFiles({params:{id:e},body:n.body});return i.status!=="success"?i:A({cardId:e,files_added:i.data.files_added,notified:!0})}catch(e){return I(e)}},async removeCard(n){try{let e=n.params?.id;if(!e)return C("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(e);}catch{}return await j({type:"task-removal",taskName:e,timestamp:q()}),ee(),A()}catch(e){return I(e)}},async retrigger(n){try{let e=n.params?.id;return e?(await j({type:"task-restart",taskName:e,timestamp:q()}),ee(),A()):C("retrigger requires params.id")}catch(e){return I(e)}},async processAccumulatedEvents(n){return await ft(),Z()},async upsertCard(n){try{let e=n.params?.cardId,c=n.params?.all,i=!!n.params?.restart;if(!e&&!c)return C("upsertCard requires --card-id <id> or --all");let R=await L(),b=c?(await R.readAllCards()).map(y=>y.id):[e];for(let y of b)if(!await R.readCard(y))return C(`Card "${y}" not found in board at ${t.value}`);let O=o.kvStorage("card-upsert");for(let y of b){let K=await R.readCard(y);if(!K)continue;let G=chunkEYBDAEVO_cjs.x(K),oe=o.hashFn(G),se=await O.read(y),ce=se?.taskConfigHash!==oe;if(!(!ce&&!i)){if(ce){let be=se?.blobRef??await R.readCardKey(y)??y;await j({type:"task-upsert",taskName:y,taskConfig:G,timestamp:q()}),await O.write(y,{blobRef:be,taskConfigHash:oe,updatedAt:q()});}i&&await j({type:"task-restart",taskName:y,timestamp:q()});}}return ee(),A()}catch(e){return I(e)}},async taskFailed(n){try{let e=n.params?.token;if(!e)return C("taskFailed requires params.token");let c=n.params?.error??"unknown error",i=he(e);return i?(await j({type:"task-failed",taskName:i.taskName,error:c,timestamp:q()}),ee(),A()):C("Invalid callback token")}catch(e){return I(e)}},async taskProgress(n){try{let e=n.params?.token;if(!e)return C("taskProgress requires params.token");let c=(n.body??{}).update??{},i=he(e);return i?(await j({type:"task-progress",taskName:i.taskName,update:c,timestamp:q()}),ee(),A()):C("Invalid callback token")}catch(e){return I(e)}},async sourceDataFetched(n){try{let e=n.params?.token,c=n.params?.ref;if(!e)return C("sourceDataFetched requires params.token");if(!c)return C("sourceDataFetched requires params.ref");let i=mt(e);if(!i)return C("Invalid source token");let R=await p(),b=i.dt||o.genId();i.dt||await R.ingestSourceDataStaged(i.cid,i.d,chunkVQCIOKJV_cjs.b(c),b);let O=he(i.cbk);return O?(await j({type:"task-progress",taskName:O.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:q(),deliveryToken:b,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),ee(),A()):C("Invalid callback token embedded in source token")}catch(e){return I(e)}},async sourceDataFetchFailure(n){try{let e=n.params?.token,c=n.params?.reason??"unknown";if(!e)return C("sourceDataFetchFailure requires params.token");let i=mt(e);if(!i)return C("Invalid source token");let R=he(i.cbk);return R?(await j({type:"task-progress",taskName:R.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),ee(),A()):C("Invalid callback token embedded in source token")}catch(e){return I(e)}}}}
2
- exports.a=rt;exports.b=ot;exports.c=st;exports.d=it;exports.e=Ot;exports.f=Ft;exports.g=ut;exports.h=_t;exports.i=Xt;//# sourceMappingURL=chunk-ZOZ7ZDGA.cjs.map
3
- //# sourceMappingURL=chunk-ZOZ7ZDGA.cjs.map