yaml-flow 8.11.7 → 8.11.8

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 (74) hide show
  1. package/browser/asset-integrity.json +5 -5
  2. package/browser/live-cards.schema.json +4 -0
  3. package/browser/server-runtime-controlface.js +4 -4
  4. package/examples/board/cards/card-rebalance-sim.json +4 -1
  5. package/lib/board-live-cards-mcp.cjs +1 -1
  6. package/lib/board-live-cards-mcp.js +1 -1
  7. package/lib/board-live-cards-node.cjs +6 -6
  8. package/lib/board-live-cards-node.js +6 -6
  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/board-livegraph-runtime/index.cjs +1 -1
  14. package/lib/board-livegraph-runtime/index.js +1 -1
  15. package/lib/card-compute/index.cjs +1 -1
  16. package/lib/card-compute/index.d.cts +6 -0
  17. package/lib/card-compute/index.d.ts +6 -0
  18. package/lib/card-compute/index.js +1 -1
  19. package/lib/card-store-public.cjs +1 -1
  20. package/lib/card-store-public.js +1 -1
  21. package/lib/card-validation.cjs +1 -1
  22. package/lib/card-validation.js +1 -1
  23. package/lib/{chunk-NOAERAOE.cjs → chunk-36KKCQVE.cjs} +2 -2
  24. package/lib/chunk-3DWVFRQD.cjs +3 -0
  25. package/lib/chunk-3SLSRX6Q.js +3 -0
  26. package/lib/{chunk-EHREWADE.js → chunk-4NWVZ7AW.js} +2 -2
  27. package/lib/chunk-543ZEGP7.cjs +2 -0
  28. package/lib/{chunk-YAPTL2MP.cjs → chunk-6SPWFJRG.cjs} +2 -2
  29. package/lib/{chunk-HKPVF5UI.js → chunk-BA25VGJP.js} +3 -3
  30. package/lib/chunk-BRYV6CDD.js +3 -0
  31. package/lib/chunk-EGZPROOH.cjs +3 -0
  32. package/lib/{chunk-GHUW6P4G.cjs → chunk-ESTFYRHF.cjs} +2 -2
  33. package/lib/{chunk-52XPRCZC.cjs → chunk-HOS2ZUFZ.cjs} +2 -2
  34. package/lib/chunk-JOQWJ3VR.cjs +2 -0
  35. package/lib/chunk-MRESV3MD.js +2 -0
  36. package/lib/chunk-MRIFSG7L.cjs +3 -0
  37. package/lib/{chunk-6M3RIGUH.js → chunk-NN52BT3Q.js} +2 -2
  38. package/lib/{chunk-TUQ6JBER.cjs → chunk-OR6B2H2Y.cjs} +3 -3
  39. package/lib/{chunk-I3ZOFU3F.js → chunk-PIPXFUEA.js} +2 -2
  40. package/lib/chunk-REZO2QJD.js +3 -0
  41. package/lib/{chunk-23PEDGFN.js → chunk-ROIYEFSE.js} +2 -2
  42. package/lib/chunk-UJQ7IML5.js +2 -0
  43. package/lib/chunk-YOY2JM5N.js +2 -0
  44. package/lib/chunk-ZV35WD6K.cjs +2 -0
  45. package/lib/cloud-storage.cjs +1 -1
  46. package/lib/cloud-storage.js +1 -1
  47. package/lib/continuous-event-graph/index.cjs +1 -1
  48. package/lib/continuous-event-graph/index.js +1 -1
  49. package/lib/firestore-storage/index.cjs +1 -1
  50. package/lib/firestore-storage/index.js +1 -1
  51. package/lib/index.cjs +2 -2
  52. package/lib/index.js +1 -1
  53. package/lib/localstorage-storage/index.cjs +1 -1
  54. package/lib/localstorage-storage/index.js +1 -1
  55. package/lib/server-runtime/index.cjs +1 -1
  56. package/lib/server-runtime/index.js +1 -1
  57. package/lib/server-runtime-controlface/index.cjs +1 -1
  58. package/lib/server-runtime-controlface/index.js +1 -1
  59. package/lib/server-runtime-core/index.cjs +1 -1
  60. package/lib/server-runtime-core/index.js +1 -1
  61. package/package.json +1 -1
  62. package/schema/live-cards.schema.json +4 -0
  63. package/lib/chunk-2LGCYN35.js +0 -2
  64. package/lib/chunk-3XPY7CCM.cjs +0 -3
  65. package/lib/chunk-ATOQP3BD.js +0 -2
  66. package/lib/chunk-CPJXGK2T.cjs +0 -2
  67. package/lib/chunk-J7KE7SPA.cjs +0 -2
  68. package/lib/chunk-K5TEZRZK.cjs +0 -3
  69. package/lib/chunk-QBEQL4TL.cjs +0 -2
  70. package/lib/chunk-QEHKMLHA.cjs +0 -3
  71. package/lib/chunk-RKLEBQUG.js +0 -3
  72. package/lib/chunk-WGYS2L4V.js +0 -2
  73. package/lib/chunk-X32SJDLT.js +0 -3
  74. package/lib/chunk-YT76JNKE.js +0 -3
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunk7Y47QXMX_cjs=require('./chunk-7Y47QXMX.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs'),child_process=require('child_process');function z(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),i=Object.keys(a),d=0,c=0,l=0,f=0,t=0,r=0;for(let h of i){let T=o.tasks[h];if(!T||T.status===chunk7Y47QXMX_cjs.a.NOT_STARTED)t++;else switch(T.status){case chunk7Y47QXMX_cjs.a.RUNNING:d++;break;case chunk7Y47QXMX_cjs.a.COMPLETED:c++;break;case chunk7Y47QXMX_cjs.a.FAILED:l++;break;case "inactivated":r++;break;default:f++;}}let n={};for(let[h,T]of Object.entries(a)){for(let R of chunk7Y47QXMX_cjs.g(T))n[R]||(n[R]=[]),n[R].push(h);if(T.on)for(let R of Object.values(T.on))for(let g of R)n[g]||(n[g]=[]),n[g].includes(h)||n[g].push(h);if(T.on_failure)for(let R of T.on_failure)n[R]||(n[R]=[]),n[R].includes(h)||n[R].push(h);}let u=new Set,p=0,k=0;for(let[h,T]of Object.entries(a)){let R=o.tasks[h];if(R?.status===chunk7Y47QXMX_cjs.a.COMPLETED||R?.status===chunk7Y47QXMX_cjs.a.RUNNING)continue;let g=false,H=false;for(let x of chunk7Y47QXMX_cjs.h(T)){let q=n[x]||[];q.length===0?(u.add(x),g=true):q.every(Y=>{let W=o.tasks[Y];return W?.status===chunk7Y47QXMX_cjs.a.FAILED||W?.status==="inactivated"})&&(H=true);}g&&p++,H&&!g&&k++;}let m=[];for(let[h,T]of Object.entries(n))T.length>1&&m.push(h);let v=Q(a,n),b=Z(i,v);return {totalNodes:i.length,running:d,completed:c,failed:l,waiting:f,notStarted:t,disabled:r,unresolvedCount:p,blockedCount:k,openDependencies:[...u],cycles:b,conflictTokens:m}}function Q(s,e){let o={};for(let[a,i]of Object.entries(s)){o[a]=new Set;for(let d of chunk7Y47QXMX_cjs.h(i))for(let c of e[d]||[])c!==a&&o[a].add(c);}return o}function Z(s,e){let d={},c={},l=[];for(let t of s)d[t]=0,c[t]=null;function f(t){d[t]=1;for(let r of e[t]||[])if(d[r]===1){let n=[r],u=t;for(;u!==r;)n.push(u),u=c[u];n.push(r),n.reverse(),l.push(n);}else d[r]===0&&(c[r]=t,f(r));d[t]=2;}for(let t of s)d[t]===0&&f(t);return l}function B(s){let e={};for(let[o,a]of Object.entries(s)){for(let i of chunk7Y47QXMX_cjs.g(a))e[i]||(e[i]=[]),e[i].push(o);if(a.on)for(let i of Object.values(a.on))for(let d of i)e[d]||(e[d]=[]),e[d].includes(o)||e[d].push(o);if(a.on_failure)for(let i of a.on_failure)e[i]||(e[i]=[]),e[i].includes(o)||e[i].push(o);}return e}function V(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),i=B(a),d=new Set([...o.availableOutputs]);for(let[n,u]of Object.entries(o.tasks))if(u.status==="completed"){let p=a[n];p&&chunk7Y47QXMX_cjs.g(p).forEach(k=>d.add(k));}let c=new Set;for(let n of Object.values(a))for(let u of chunk7Y47QXMX_cjs.h(n))c.add(u);let l=new Set,f=new Set;for(let n of c){if(d.has(n))continue;(i[n]||[]).length===0&&l.add(n);}let t=true;for(;t;){t=false;for(let[n,u]of Object.entries(a)){if(f.has(n))continue;let p=o.tasks[n];if(p?.status==="completed")continue;let k=chunk7Y47QXMX_cjs.l(p),v=chunk7Y47QXMX_cjs.h(u).some(b=>l.has(b));(k||v)&&(f.has(n)||(f.add(n),t=true));}for(let n of c){if(l.has(n)||d.has(n))continue;let u=i[n]||[],p=u.length>0&&u.every(k=>f.has(k)||chunk7Y47QXMX_cjs.l(o.tasks[k]));(u.length===0||p)&&(l.has(n)||(l.add(n),t=true));}}let r=[];for(let n of l){let u=i[n]||[],p;u.length===0?p="no-producer":p=u.every(m=>chunk7Y47QXMX_cjs.l(o.tasks[m]))?"all-producers-failed":"transitive",r.push({token:n,reason:p,producers:u});}return {tokens:r}}function ee(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),{tokens:i}=V(s),d=new Set(i.map(l=>l.token)),c=[];for(let[l,f]of Object.entries(a)){let t=o.tasks[l];if(t?.status==="completed")continue;let n=chunk7Y47QXMX_cjs.h(f).filter(u=>d.has(u));n.length>0?c.push({nodeName:l,missingTokens:n}):chunk7Y47QXMX_cjs.l(t)&&c.push({nodeName:l,missingTokens:[]});}return {nodes:c}}function te(s,e){let o=chunk7Y47QXMX_cjs.i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a=B(o),i=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of chunk7Y47QXMX_cjs.h(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i.has(p)||(i.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,providesTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function ne(s,e){let o=chunk7Y47QXMX_cjs.i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a={};for(let[t,r]of Object.entries(o))for(let n of chunk7Y47QXMX_cjs.h(r))a[n]||(a[n]=[]),a[n].push(t);let i=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of chunk7Y47QXMX_cjs.g(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i.has(p)||(i.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,requiresTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function K(s){let e=[],{config:o,state:a}=s,i=chunk7Y47QXMX_cjs.i(o),d=Object.keys(i);for(let t of d)a.tasks[t]||e.push({severity:"error",code:"MISSING_STATE",message:`Task "${t}" exists in config but has no state entry`,tasks:[t]});for(let t of Object.keys(a.tasks))i[t]||e.push({severity:"warning",code:"ORPHAN_STATE",message:`State entry "${t}" has no corresponding task config`,tasks:[t]});for(let t of d){let r=a.tasks[t];r&&(r.status===chunk7Y47QXMX_cjs.a.RUNNING&&!r.startedAt&&e.push({severity:"warning",code:"RUNNING_WITHOUT_START",message:`Task "${t}" is running but has no startedAt timestamp`,tasks:[t]}),r.status===chunk7Y47QXMX_cjs.a.COMPLETED&&!r.completedAt&&e.push({severity:"warning",code:"COMPLETED_WITHOUT_TIMESTAMP",message:`Task "${t}" is completed but has no completedAt timestamp`,tasks:[t]}),r.status===chunk7Y47QXMX_cjs.a.FAILED&&(r.failedAt||e.push({severity:"warning",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no failedAt timestamp`,tasks:[t]}),r.error||e.push({severity:"info",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no error message`,tasks:[t]})));}let c=new Set;for(let t of d)if(a.tasks[t]?.status===chunk7Y47QXMX_cjs.a.COMPLETED)for(let n of chunk7Y47QXMX_cjs.g(i[t]))c.add(n);let l=new Set(a.availableOutputs),f=new Set;for(let t of Object.values(i)){for(let r of chunk7Y47QXMX_cjs.g(t))f.add(r);if(t.on)for(let r of Object.values(t.on))for(let n of r)f.add(n);if(t.on_failure)for(let r of t.on_failure)f.add(r);}for(let t of l)!c.has(t)&&!f.has(t)&&e.push({severity:"info",code:"INJECTED_TOKEN",message:`Token "${t}" is available but no task in the graph can produce it (likely injected)`,tokens:[t]});for(let t of c)l.has(t)||e.push({severity:"warning",code:"MISSING_OUTPUT",message:`Token "${t}" should be available (its producer completed) but is not in availableOutputs`,tokens:[t]});for(let t of d){let r=a.tasks[t];if(!r)continue;r.executionCount<0&&e.push({severity:"error",code:"INVALID_EXECUTION_COUNT",message:`Task "${t}" has negative execution count: ${r.executionCount}`,tasks:[t]});let n=i[t].maxExecutions;n!==void 0&&r.executionCount>n&&e.push({severity:"error",code:"EXCEEDED_MAX_EXECUTIONS",message:`Task "${t}" executed ${r.executionCount} times, exceeding maxExecutions of ${n}`,tasks:[t]});}return J(e)}function se(s){let{graph:e,handlers:o}=s,a=e.getState(),i=[],d=chunk7Y47QXMX_cjs.i(a.config),c=Object.keys(d),l=new Set(Object.keys(o)),f=new Set;for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)f.add(u);}for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)o[u]||i.push({severity:"error",code:"MISSING_HANDLER",message:`Task "${r}" references handler "${u}" but it is not in the registry`,tasks:[r]});}for(let r of l)f.has(r)||i.push({severity:"warning",code:"ORPHAN_HANDLER",message:`Handler "${r}" is registered but not referenced by any task's taskHandlers`,tasks:[r]});let t=K(a);return i.push(...t.issues),J(i)}function J(s){let e=s.filter(a=>a.severity==="error"),o=s.filter(a=>a.severity==="warning");return {valid:e.length===0,issues:s,errors:e,warnings:o}}function re(s,e){let o=s;for(let a of e)o=oe(o,a);return o}function oe(s,e){switch(e.type){case "add-node":return chunkAW3COGCI_cjs.d(s,e.name,e.config);case "remove-node":return chunkAW3COGCI_cjs.e(s,e.name);case "add-requires":return chunkAW3COGCI_cjs.f(s,e.taskName,e.tokens);case "remove-requires":return chunkAW3COGCI_cjs.g(s,e.taskName,e.tokens);case "add-provides":return chunkAW3COGCI_cjs.h(s,e.taskName,e.tokens);case "remove-provides":return chunkAW3COGCI_cjs.i(s,e.taskName,e.tokens);case "inject-tokens":return chunkAW3COGCI_cjs.j(s,e.tokens);case "drain-tokens":return chunkAW3COGCI_cjs.k(s,e.tokens);case "reset-node":return chunkAW3COGCI_cjs.l(s,e.name);case "disable-node":return chunkAW3COGCI_cjs.m(s,e.name);case "enable-node":return chunkAW3COGCI_cjs.n(s,e.name);case "apply-events":return chunkAW3COGCI_cjs.c(s,e.events);default:throw new Error(`Unknown mutation type: ${e.type}`)}}function ce(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(i=>e()(a,i)).catch(i=>e()(a,{},[i instanceof Error?i.message:String(i)])),"task-initiated"}}function de(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(()=>e()(a,{})).catch(()=>e()(a,{})),"task-initiated"}}function ue(s){let{command:e,cwd:o,env:a,timeoutMs:i=3e4,exitCodeMap:d,captureOutput:c=false,getResolve:l}=s;return async f=>{let{callbackToken:t,nodeId:r}=f,n=e.replace(/\$\{taskName\}/g,r);return child_process.exec(n,{cwd:o,env:a?{...process.env,...a}:void 0,timeout:i,maxBuffer:10*1024*1024},(u,p,k)=>{let m=u?.code??(u?1:0);if(m!==0&&!d?.[m]){l()(t,{},[`Command exited with code ${m}: ${k||u?.message}`]);return}let v={};c&&(v.stdout=p,v.stderr=k,v.exitCode=m),l()(t,v);}),"task-initiated"}}function X(s){let{command:e,args:o=[],cwd:a,env:i,timeoutMs:d=3e4,exitCodeMap:c,captureOutput:l=false,getResolve:f}=s;return async t=>{let{callbackToken:r,nodeId:n}=t,u=e.replace(/\$\{taskName\}/g,n),p=o.map(k=>k.replace(/\$\{taskName\}/g,n));return child_process.execFile(u,p,{cwd:a,env:i?{...process.env,...i}:void 0,timeout:d,maxBuffer:10*1024*1024,encoding:"utf8",windowsHide:true},(k,m,v)=>{let b=k?.code??(k?1:0);if(b!==0&&!c?.[b]){f()(r,{},[`Process exited with code ${b}: ${v||k?.message}`]);return}let h={};l&&(h.stdout=m,h.stderr=v,h.exitCode=b),f()(r,h);}),"task-initiated"}}function le(s){return s.endsWith(".js")||s.endsWith(".mjs")||s.endsWith(".ts")?"node":s.endsWith(".py")?"python3":(s.endsWith(".sh"),"bash")}function pe(s){let{scriptPath:e,runtime:o,args:a=[],cwd:i,timeoutMs:d=6e4,captureOutput:c=false,getResolve:l}=s,f=o??le(e),t=f==="node"?process.execPath:f;return X({command:t,args:[e,"${taskName}",...a],cwd:i,timeoutMs:d,captureOutput:c,getResolve:l})}function fe(s){let{url:e,method:o="POST",headers:a={},timeoutMs:i=3e4,failOnNon2xx:d=true,getResolve:c}=s;return async l=>{let{callbackToken:f,nodeId:t,config:r}=l,n=e.replace(/\$\{taskName\}/g,t),u=JSON.stringify({taskName:t,callbackToken:f,config:r}),p=new AbortController,k=setTimeout(()=>p.abort(),i);return fetch(n,{method:o,headers:{"Content-Type":"application/json",...a},body:u,signal:p.signal}).then(async m=>{if(clearTimeout(k),d&&!m.ok){let b=await m.text().catch(()=>"");c()(f,{},[`HTTP ${m.status}: ${b}`]);return}let v=await m.json().catch(()=>({}));c()(f,v);}).catch(m=>{clearTimeout(k),c()(f,{},[m instanceof Error?m.message:String(m)]);}),"task-initiated"}}function ge(s,e){return async o=>(s()(o.callbackToken,e??{}),"task-initiated")}function ke(s,e={}){let o,a={},i;if(!Array.isArray(s)&&"nodes"in s){let g=s;o=g.nodes,i=g.id,a=g.settings??{};}else o=s;let{sourceHandlers:d={},defaultSourceHandler:c,cardHandlers:l={},reactiveOptions:f={},graphSettings:t={},executionId:r}=e,n=new Map;for(let g of o){if(n.has(g.id))throw new Error(`Duplicate card ID: "${g.id}"`);n.set(g.id,g);}let u=e.sharedState??new Map,p={},k=new Set,m=new Map;for(let g of o)for(let H of g.provides??[{bindTo:g.id,ref:"card_data"}])k.add(H.bindTo),m.set(H.bindTo,g.id);for(let g of o){let H=g.requires??[];for(let x of H)if(!k.has(x))throw new Error(`Card "${g.id}" requires "${x}" but no card provides that token`);p[g.id]={requires:H.length>0?H:void 0,provides:(g.provides??[{bindTo:g.id,ref:"card_data"}]).map(x=>x.bindTo),taskHandlers:[g.id],description:g.meta?.title??g.id};}let v={id:i??`live-cards-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...a,...t},tasks:p},b={},h=null,T=()=>(g,H,x)=>{h.resolveCallback(g,H,x);};for(let g of o)g.source_defs&&g.source_defs.length>0?b[g.id]=me(g,d,c,u,T):b[g.id]=he(g,l,u,n,m,T);let R=chunkAW3COGCI_cjs.t(v,{...f,handlers:b},r);return h=R,{graph:R,config:v,handlers:b,cards:n,sharedState:u}}function me(s,e,o,a,i){if(e[s.id]){let d=e[s.id];return async c=>d(c)}if(o){let d=o(s);return async c=>d(c)}return async d=>{let c={...s.card_data};return a.set(s.id,c),i()(d.callbackToken,c),"task-initiated"}}function he(s,e,o,a,i,d){if(e[s.id]){let c=e[s.id];return async l=>c(l)}return async c=>{let l={},f=s.requires??[];for(let u of f){let p=i.get(u)??u,k=o.get(p);k&&(l[u]=k[u]??k);}let t={id:s.id,card_data:{...s.card_data},requires:l,compute:s.compute};await chunkQBEQL4TL_cjs.a.run(t);let r;if(s.provides&&s.provides.length>0){r={};for(let{bindTo:u,ref:p}of s.provides)r[u]=chunkQBEQL4TL_cjs.a.resolve(t,p);}else r={...t.card_data,...t.computed_values};let n={...t.card_data,...t.computed_values};return o.set(s.id,n),d()(c.callbackToken,r),"task-initiated"}}exports.a=z;exports.b=V;exports.c=ee;exports.d=te;exports.e=ne;exports.f=K;exports.g=se;exports.h=re;exports.i=ce;exports.j=de;exports.k=ue;exports.l=X;exports.m=pe;exports.n=fe;exports.o=ge;exports.p=ke;//# sourceMappingURL=chunk-52XPRCZC.cjs.map
2
- //# sourceMappingURL=chunk-52XPRCZC.cjs.map
1
+ 'use strict';var chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunk7Y47QXMX_cjs=require('./chunk-7Y47QXMX.cjs'),chunkZV35WD6K_cjs=require('./chunk-ZV35WD6K.cjs'),child_process=require('child_process');function z(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),i=Object.keys(a),d=0,c=0,l=0,f=0,t=0,r=0;for(let h of i){let T=o.tasks[h];if(!T||T.status===chunk7Y47QXMX_cjs.a.NOT_STARTED)t++;else switch(T.status){case chunk7Y47QXMX_cjs.a.RUNNING:d++;break;case chunk7Y47QXMX_cjs.a.COMPLETED:c++;break;case chunk7Y47QXMX_cjs.a.FAILED:l++;break;case "inactivated":r++;break;default:f++;}}let n={};for(let[h,T]of Object.entries(a)){for(let R of chunk7Y47QXMX_cjs.g(T))n[R]||(n[R]=[]),n[R].push(h);if(T.on)for(let R of Object.values(T.on))for(let g of R)n[g]||(n[g]=[]),n[g].includes(h)||n[g].push(h);if(T.on_failure)for(let R of T.on_failure)n[R]||(n[R]=[]),n[R].includes(h)||n[R].push(h);}let u=new Set,p=0,k=0;for(let[h,T]of Object.entries(a)){let R=o.tasks[h];if(R?.status===chunk7Y47QXMX_cjs.a.COMPLETED||R?.status===chunk7Y47QXMX_cjs.a.RUNNING)continue;let g=false,H=false;for(let x of chunk7Y47QXMX_cjs.h(T)){let q=n[x]||[];q.length===0?(u.add(x),g=true):q.every(Y=>{let W=o.tasks[Y];return W?.status===chunk7Y47QXMX_cjs.a.FAILED||W?.status==="inactivated"})&&(H=true);}g&&p++,H&&!g&&k++;}let m=[];for(let[h,T]of Object.entries(n))T.length>1&&m.push(h);let v=Q(a,n),b=Z(i,v);return {totalNodes:i.length,running:d,completed:c,failed:l,waiting:f,notStarted:t,disabled:r,unresolvedCount:p,blockedCount:k,openDependencies:[...u],cycles:b,conflictTokens:m}}function Q(s,e){let o={};for(let[a,i]of Object.entries(s)){o[a]=new Set;for(let d of chunk7Y47QXMX_cjs.h(i))for(let c of e[d]||[])c!==a&&o[a].add(c);}return o}function Z(s,e){let d={},c={},l=[];for(let t of s)d[t]=0,c[t]=null;function f(t){d[t]=1;for(let r of e[t]||[])if(d[r]===1){let n=[r],u=t;for(;u!==r;)n.push(u),u=c[u];n.push(r),n.reverse(),l.push(n);}else d[r]===0&&(c[r]=t,f(r));d[t]=2;}for(let t of s)d[t]===0&&f(t);return l}function B(s){let e={};for(let[o,a]of Object.entries(s)){for(let i of chunk7Y47QXMX_cjs.g(a))e[i]||(e[i]=[]),e[i].push(o);if(a.on)for(let i of Object.values(a.on))for(let d of i)e[d]||(e[d]=[]),e[d].includes(o)||e[d].push(o);if(a.on_failure)for(let i of a.on_failure)e[i]||(e[i]=[]),e[i].includes(o)||e[i].push(o);}return e}function V(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),i=B(a),d=new Set([...o.availableOutputs]);for(let[n,u]of Object.entries(o.tasks))if(u.status==="completed"){let p=a[n];p&&chunk7Y47QXMX_cjs.g(p).forEach(k=>d.add(k));}let c=new Set;for(let n of Object.values(a))for(let u of chunk7Y47QXMX_cjs.h(n))c.add(u);let l=new Set,f=new Set;for(let n of c){if(d.has(n))continue;(i[n]||[]).length===0&&l.add(n);}let t=true;for(;t;){t=false;for(let[n,u]of Object.entries(a)){if(f.has(n))continue;let p=o.tasks[n];if(p?.status==="completed")continue;let k=chunk7Y47QXMX_cjs.l(p),v=chunk7Y47QXMX_cjs.h(u).some(b=>l.has(b));(k||v)&&(f.has(n)||(f.add(n),t=true));}for(let n of c){if(l.has(n)||d.has(n))continue;let u=i[n]||[],p=u.length>0&&u.every(k=>f.has(k)||chunk7Y47QXMX_cjs.l(o.tasks[k]));(u.length===0||p)&&(l.has(n)||(l.add(n),t=true));}}let r=[];for(let n of l){let u=i[n]||[],p;u.length===0?p="no-producer":p=u.every(m=>chunk7Y47QXMX_cjs.l(o.tasks[m]))?"all-producers-failed":"transitive",r.push({token:n,reason:p,producers:u});}return {tokens:r}}function ee(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),{tokens:i}=V(s),d=new Set(i.map(l=>l.token)),c=[];for(let[l,f]of Object.entries(a)){let t=o.tasks[l];if(t?.status==="completed")continue;let n=chunk7Y47QXMX_cjs.h(f).filter(u=>d.has(u));n.length>0?c.push({nodeName:l,missingTokens:n}):chunk7Y47QXMX_cjs.l(t)&&c.push({nodeName:l,missingTokens:[]});}return {nodes:c}}function te(s,e){let o=chunk7Y47QXMX_cjs.i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a=B(o),i=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of chunk7Y47QXMX_cjs.h(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i.has(p)||(i.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,providesTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function ne(s,e){let o=chunk7Y47QXMX_cjs.i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a={};for(let[t,r]of Object.entries(o))for(let n of chunk7Y47QXMX_cjs.h(r))a[n]||(a[n]=[]),a[n].push(t);let i=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of chunk7Y47QXMX_cjs.g(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i.has(p)||(i.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,requiresTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function K(s){let e=[],{config:o,state:a}=s,i=chunk7Y47QXMX_cjs.i(o),d=Object.keys(i);for(let t of d)a.tasks[t]||e.push({severity:"error",code:"MISSING_STATE",message:`Task "${t}" exists in config but has no state entry`,tasks:[t]});for(let t of Object.keys(a.tasks))i[t]||e.push({severity:"warning",code:"ORPHAN_STATE",message:`State entry "${t}" has no corresponding task config`,tasks:[t]});for(let t of d){let r=a.tasks[t];r&&(r.status===chunk7Y47QXMX_cjs.a.RUNNING&&!r.startedAt&&e.push({severity:"warning",code:"RUNNING_WITHOUT_START",message:`Task "${t}" is running but has no startedAt timestamp`,tasks:[t]}),r.status===chunk7Y47QXMX_cjs.a.COMPLETED&&!r.completedAt&&e.push({severity:"warning",code:"COMPLETED_WITHOUT_TIMESTAMP",message:`Task "${t}" is completed but has no completedAt timestamp`,tasks:[t]}),r.status===chunk7Y47QXMX_cjs.a.FAILED&&(r.failedAt||e.push({severity:"warning",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no failedAt timestamp`,tasks:[t]}),r.error||e.push({severity:"info",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no error message`,tasks:[t]})));}let c=new Set;for(let t of d)if(a.tasks[t]?.status===chunk7Y47QXMX_cjs.a.COMPLETED)for(let n of chunk7Y47QXMX_cjs.g(i[t]))c.add(n);let l=new Set(a.availableOutputs),f=new Set;for(let t of Object.values(i)){for(let r of chunk7Y47QXMX_cjs.g(t))f.add(r);if(t.on)for(let r of Object.values(t.on))for(let n of r)f.add(n);if(t.on_failure)for(let r of t.on_failure)f.add(r);}for(let t of l)!c.has(t)&&!f.has(t)&&e.push({severity:"info",code:"INJECTED_TOKEN",message:`Token "${t}" is available but no task in the graph can produce it (likely injected)`,tokens:[t]});for(let t of c)l.has(t)||e.push({severity:"warning",code:"MISSING_OUTPUT",message:`Token "${t}" should be available (its producer completed) but is not in availableOutputs`,tokens:[t]});for(let t of d){let r=a.tasks[t];if(!r)continue;r.executionCount<0&&e.push({severity:"error",code:"INVALID_EXECUTION_COUNT",message:`Task "${t}" has negative execution count: ${r.executionCount}`,tasks:[t]});let n=i[t].maxExecutions;n!==void 0&&r.executionCount>n&&e.push({severity:"error",code:"EXCEEDED_MAX_EXECUTIONS",message:`Task "${t}" executed ${r.executionCount} times, exceeding maxExecutions of ${n}`,tasks:[t]});}return J(e)}function se(s){let{graph:e,handlers:o}=s,a=e.getState(),i=[],d=chunk7Y47QXMX_cjs.i(a.config),c=Object.keys(d),l=new Set(Object.keys(o)),f=new Set;for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)f.add(u);}for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)o[u]||i.push({severity:"error",code:"MISSING_HANDLER",message:`Task "${r}" references handler "${u}" but it is not in the registry`,tasks:[r]});}for(let r of l)f.has(r)||i.push({severity:"warning",code:"ORPHAN_HANDLER",message:`Handler "${r}" is registered but not referenced by any task's taskHandlers`,tasks:[r]});let t=K(a);return i.push(...t.issues),J(i)}function J(s){let e=s.filter(a=>a.severity==="error"),o=s.filter(a=>a.severity==="warning");return {valid:e.length===0,issues:s,errors:e,warnings:o}}function re(s,e){let o=s;for(let a of e)o=oe(o,a);return o}function oe(s,e){switch(e.type){case "add-node":return chunkAW3COGCI_cjs.d(s,e.name,e.config);case "remove-node":return chunkAW3COGCI_cjs.e(s,e.name);case "add-requires":return chunkAW3COGCI_cjs.f(s,e.taskName,e.tokens);case "remove-requires":return chunkAW3COGCI_cjs.g(s,e.taskName,e.tokens);case "add-provides":return chunkAW3COGCI_cjs.h(s,e.taskName,e.tokens);case "remove-provides":return chunkAW3COGCI_cjs.i(s,e.taskName,e.tokens);case "inject-tokens":return chunkAW3COGCI_cjs.j(s,e.tokens);case "drain-tokens":return chunkAW3COGCI_cjs.k(s,e.tokens);case "reset-node":return chunkAW3COGCI_cjs.l(s,e.name);case "disable-node":return chunkAW3COGCI_cjs.m(s,e.name);case "enable-node":return chunkAW3COGCI_cjs.n(s,e.name);case "apply-events":return chunkAW3COGCI_cjs.c(s,e.events);default:throw new Error(`Unknown mutation type: ${e.type}`)}}function ce(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(i=>e()(a,i)).catch(i=>e()(a,{},[i instanceof Error?i.message:String(i)])),"task-initiated"}}function de(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(()=>e()(a,{})).catch(()=>e()(a,{})),"task-initiated"}}function ue(s){let{command:e,cwd:o,env:a,timeoutMs:i=3e4,exitCodeMap:d,captureOutput:c=false,getResolve:l}=s;return async f=>{let{callbackToken:t,nodeId:r}=f,n=e.replace(/\$\{taskName\}/g,r);return child_process.exec(n,{cwd:o,env:a?{...process.env,...a}:void 0,timeout:i,maxBuffer:10*1024*1024},(u,p,k)=>{let m=u?.code??(u?1:0);if(m!==0&&!d?.[m]){l()(t,{},[`Command exited with code ${m}: ${k||u?.message}`]);return}let v={};c&&(v.stdout=p,v.stderr=k,v.exitCode=m),l()(t,v);}),"task-initiated"}}function X(s){let{command:e,args:o=[],cwd:a,env:i,timeoutMs:d=3e4,exitCodeMap:c,captureOutput:l=false,getResolve:f}=s;return async t=>{let{callbackToken:r,nodeId:n}=t,u=e.replace(/\$\{taskName\}/g,n),p=o.map(k=>k.replace(/\$\{taskName\}/g,n));return child_process.execFile(u,p,{cwd:a,env:i?{...process.env,...i}:void 0,timeout:d,maxBuffer:10*1024*1024,encoding:"utf8",windowsHide:true},(k,m,v)=>{let b=k?.code??(k?1:0);if(b!==0&&!c?.[b]){f()(r,{},[`Process exited with code ${b}: ${v||k?.message}`]);return}let h={};l&&(h.stdout=m,h.stderr=v,h.exitCode=b),f()(r,h);}),"task-initiated"}}function le(s){return s.endsWith(".js")||s.endsWith(".mjs")||s.endsWith(".ts")?"node":s.endsWith(".py")?"python3":(s.endsWith(".sh"),"bash")}function pe(s){let{scriptPath:e,runtime:o,args:a=[],cwd:i,timeoutMs:d=6e4,captureOutput:c=false,getResolve:l}=s,f=o??le(e),t=f==="node"?process.execPath:f;return X({command:t,args:[e,"${taskName}",...a],cwd:i,timeoutMs:d,captureOutput:c,getResolve:l})}function fe(s){let{url:e,method:o="POST",headers:a={},timeoutMs:i=3e4,failOnNon2xx:d=true,getResolve:c}=s;return async l=>{let{callbackToken:f,nodeId:t,config:r}=l,n=e.replace(/\$\{taskName\}/g,t),u=JSON.stringify({taskName:t,callbackToken:f,config:r}),p=new AbortController,k=setTimeout(()=>p.abort(),i);return fetch(n,{method:o,headers:{"Content-Type":"application/json",...a},body:u,signal:p.signal}).then(async m=>{if(clearTimeout(k),d&&!m.ok){let b=await m.text().catch(()=>"");c()(f,{},[`HTTP ${m.status}: ${b}`]);return}let v=await m.json().catch(()=>({}));c()(f,v);}).catch(m=>{clearTimeout(k),c()(f,{},[m instanceof Error?m.message:String(m)]);}),"task-initiated"}}function ge(s,e){return async o=>(s()(o.callbackToken,e??{}),"task-initiated")}function ke(s,e={}){let o,a={},i;if(!Array.isArray(s)&&"nodes"in s){let g=s;o=g.nodes,i=g.id,a=g.settings??{};}else o=s;let{sourceHandlers:d={},defaultSourceHandler:c,cardHandlers:l={},reactiveOptions:f={},graphSettings:t={},executionId:r}=e,n=new Map;for(let g of o){if(n.has(g.id))throw new Error(`Duplicate card ID: "${g.id}"`);n.set(g.id,g);}let u=e.sharedState??new Map,p={},k=new Set,m=new Map;for(let g of o)for(let H of g.provides??[{bindTo:g.id,ref:"card_data"}])k.add(H.bindTo),m.set(H.bindTo,g.id);for(let g of o){let H=g.requires??[];for(let x of H)if(!k.has(x))throw new Error(`Card "${g.id}" requires "${x}" but no card provides that token`);p[g.id]={requires:H.length>0?H:void 0,provides:(g.provides??[{bindTo:g.id,ref:"card_data"}]).map(x=>x.bindTo),taskHandlers:[g.id],description:g.meta?.title??g.id};}let v={id:i??`live-cards-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...a,...t},tasks:p},b={},h=null,T=()=>(g,H,x)=>{h.resolveCallback(g,H,x);};for(let g of o)g.source_defs&&g.source_defs.length>0?b[g.id]=me(g,d,c,u,T):b[g.id]=he(g,l,u,n,m,T);let R=chunkAW3COGCI_cjs.t(v,{...f,handlers:b},r);return h=R,{graph:R,config:v,handlers:b,cards:n,sharedState:u}}function me(s,e,o,a,i){if(e[s.id]){let d=e[s.id];return async c=>d(c)}if(o){let d=o(s);return async c=>d(c)}return async d=>{let c={...s.card_data};return a.set(s.id,c),i()(d.callbackToken,c),"task-initiated"}}function he(s,e,o,a,i,d){if(e[s.id]){let c=e[s.id];return async l=>c(l)}return async c=>{let l={},f=s.requires??[];for(let u of f){let p=i.get(u)??u,k=o.get(p);k&&(l[u]=k[u]??k);}let t={id:s.id,card_data:{...s.card_data},requires:l,compute:s.compute};await chunkZV35WD6K_cjs.a.run(t);let r;if(s.provides&&s.provides.length>0){r={};for(let{bindTo:u,ref:p}of s.provides)r[u]=chunkZV35WD6K_cjs.a.resolve(t,p);}else r={...t.card_data,...t.computed_values};let n={...t.card_data,...t.computed_values};return o.set(s.id,n),d()(c.callbackToken,r),"task-initiated"}}exports.a=z;exports.b=V;exports.c=ee;exports.d=te;exports.e=ne;exports.f=K;exports.g=se;exports.h=re;exports.i=ce;exports.j=de;exports.k=ue;exports.l=X;exports.m=pe;exports.n=fe;exports.o=ge;exports.p=ke;//# sourceMappingURL=chunk-HOS2ZUFZ.cjs.map
2
+ //# sourceMappingURL=chunk-HOS2ZUFZ.cjs.map
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunk7JVHYHT2_cjs=require('./chunk-7JVHYHT2.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkVI36DRWG_cjs=require('./chunk-VI36DRWG.cjs'),chunkZV35WD6K_cjs=require('./chunk-ZV35WD6K.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function L(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function M(e,r){return L(e)?e.then(r):r(e)}function ee(e,r){let t={...e};for(let o of r.deleteKeys)delete t[o];return {...t,...r.shallowMerge}}function ve(e,r){return {readValues(o){let n=e(o);return M(n.listKeys(),s=>{let a=[...s].sort();if(a.length===0)return {version:null,values:{}};let i={},c=null;for(let f of a){let d=n.read(f);L(d)?c=(c??Promise.resolve()).then(async()=>{i[f]=await d;}):i[f]=d;}return c?c.then(()=>({version:r(i),values:i})):{version:r(i),values:i}})},writeValues(o,n,s){let a=e(o),i=null;for(let c of s){let f=a.delete(c);L(f)&&(i=(i??Promise.resolve()).then(()=>f).then(()=>{}));}for(let[c,f]of Object.entries(n)){let d=a.write(c,f);L(d)&&(i=(i??Promise.resolve()).then(()=>d).then(()=>{}));}return i?i.then(()=>r(n)):r(n)}}}function te(e,r){return {readSnapshot(t){return e.readValues(t)},commitSnapshot(t,o){if(o.schemaVersion!==r)throw new Error(`Unsupported snapshot schema version: ${o.schemaVersion}`);return M(e.readValues(t),n=>{if(n.version!==o.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let s=ee(n.values,o);return M(e.writeValues(t,s,o.deleteKeys),a=>({ok:true,newVersion:a}))})}}}function Z(e,r){if(!r)return e;let t=e.findIndex(o=>o.id===r);return t===-1?e:e.slice(t+1)}function re(e){return {readEntriesAfterCursor(r){let t=Z(e.readAllEntries(),r);return t.length===0?{events:[],newCursor:r}:{events:t.map(o=>o.event),newCursor:t[t.length-1].id}},pendingCount(r){return Z(e.readAllEntries(),r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function be(e){return {appendEvent(r){return e.append(r).then(()=>{})},async readEntriesAfterCursor(r){let t=await e.readAfter(r||null);return {events:t.entries.map(o=>o.payload),newCursor:t.newCursor??r}}}}function j(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function b(e,r){return j(e)?e.then(r):r(e)}function U(e,r){let t=null;for(let o of e){if(t){t=t.then(()=>r(o)).then(()=>{});continue}let n=r(o);j(n)&&(t=Promise.resolve(n).then(()=>{}));}return t??void 0}function pe(e){if(e==null)return null;let r=e.trim();if(!r)return null;try{return JSON.parse(r)}catch{return r}}function ge(e,r){let t=e.match(r);return t?t[1]:null}function ne(e,r,t){let o={},n=U(e,s=>{let a=t(s);if(a)return b(r(s),i=>{o[a]=i;})});return j(n)?n.then(()=>o):o}function oe(e,r){return {readSourceData(t,o){return b(e.read(`${t}/${o}`),pe)},ingestSourceDataStaged(t,o,n,s){return b(r(n),a=>e.write(`${t}/.staged/${s}/${o}`,a))},commitSourceData(t,o,n){let s=`${t}/.staged/${n}/${o}`,a=`${t}/${o}`;return e.renameKey(s,a)},hasSource(t,o){return e.exists(`${t}/${o}`)},listSources(t){return b(e.listKeys(`${t}/`),o=>o.filter(n=>!n.includes("/.staged/")).map(n=>n.slice(`${t}/`.length)))}}}function fe(e,r){let t=(o,n)=>{try{let s=n(o);return j(s)?s.catch(a=>r(o,a instanceof Error?a.message:String(a))):void 0}catch(s){try{return r(o,s instanceof Error?s.message:String(s))}catch{return}}};return {appendEntries(o,n){if(!(!o||n.length===0))return b(e.read(o),s=>e.write(o,[...s??[],...n]))},dispatchEntriesForJournalId(o,n){if(o)return b(e.read(o),s=>{let a=s;if(!(!a||a.length===0))return b(U(a,i=>t(i,n)),()=>e.delete(o))})}}}function me(e,r,t){return {readRuntime(o){return b(e.read(r(o)),n=>n??t())},writeRuntime(o,n){return e.write(r(o),n)}}}function se(e){return {writeComputedValues(r,t){return e.write(`cards/${r}/computed_values`,t)},readComputedValues(r){return e.read(`cards/${r}/computed_values`)},readAllComputedValues(){return b(e.listKeys("cards/"),r=>ne(r,t=>e.read(t),t=>ge(t,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(r){return U(Object.entries(r),([t,o])=>{if(t)return o===void 0?e.delete(`data-objects/${t}`):e.write(`data-objects/${t}`,o)})},readDataObject(r){return e.read(`data-objects/${r}`)},readAllDataObjects(){return b(e.listKeys("data-objects/"),r=>ne(r,t=>e.read(t),t=>t.slice(13)))},writeStatusSnapshot(r){return e.write("status",r)},readStatusSnapshot(){return e.read("status")}}}var T="sys_keys_board_state",_="__sys_keys_board_state_init";function ue(e){if(!e||typeof e!="object"||Array.isArray(e))return false;let r=e.__private;return !!r&&typeof r=="object"&&!Array.isArray(r)&&r.visible_controlplane_only===true}function Se(e){let r=e.filter(n=>!ue(n)),t=[...new Set(r.map(n=>n.id).filter(n=>typeof n=="string"&&n.length>0))].sort(),o=[...new Set(r.flatMap(n=>Array.isArray(n.provides)?n.provides:[]).map(n=>n&&typeof n=="object"&&!Array.isArray(n)?n.bindTo:void 0).filter(n=>typeof n=="string"&&n.length>0&&n!==T))].sort();return {card_ids:t,data_object_keys:o}}function ye(e,r){let t=e.filter(s=>!ue(s)),o=[...new Set(t.map(s=>s.id).filter(s=>typeof s=="string"&&s.length>0))].sort(),n=[...new Set(Object.entries(r).filter(([s])=>s!==_).flatMap(([,s])=>Array.isArray(s.provides)?s.provides:[]).filter(s=>typeof s=="string"&&s.length>0&&s!==T))].sort();return {card_ids:o,data_object_keys:n}}function Ve(){return {id:_,meta:{title:"System Keys Board State",synthetic:true},provides:[{bindTo:T,ref:`card_data.${T}`}],card_data:{[T]:{card_ids:[],data_object_keys:[]}},__private:{visible_controlplane_only:true}}}function Pe(e,r){function t(){return e.readIndex()??{}}function o(n,s,a){let i=String(s||"").split(".").filter(Boolean);if(i.length===0)return a&&typeof a=="object"&&!Array.isArray(a)?a:{value:a};let c={...n},f=c;for(let d=0;d<i.length-1;d++){let u=i[d],l=f[u],m=l&&typeof l=="object"&&!Array.isArray(l)?{...l}:{};f[u]=m,f=m;}return f[i[i.length-1]]=a,c}return {readCard(n){let s=t()[n];return !s||!e.cardExists(s.key)?null:e.readCard(s.key)},readCardKey(n){return t()[n]?.key??null},readAllCards(){let n=[];for(let[s,a]of Object.entries(t())){if(!e.cardExists(a.key))continue;let i=e.readCard(a.key);i?n.push(i):r?.(`[card-store] could not read card "${s}" at key "${a.key}"`);}return n},readChecksumIndex(){let n={};for(let[s,a]of Object.entries(t()))n[s]=a.checksum;return n},changedSince(n){let s=t(),a=[];for(let[i,c]of Object.entries(s))n[i]!==c.checksum&&a.push(i);for(let i of Object.keys(n))s[i]||a.push(i);return a},validateUpsert(n,s){let a=t(),i=a[n],c=Object.entries(a).find(([,f])=>f.key===s);return i&&i.key!==s?{ok:false,error:`Card id "${n}" is already mapped to key "${i.key}", cannot remap to "${s}"`}:c&&c[0]!==n?{ok:false,error:`Key "${s}" is already mapped to card id "${c[0]}", cannot remap to "${n}"`}:{ok:true}},writeCard(n,s,a){let i=t(),c=a??i[n]?.key??e.defaultCardKey(n),f=e.writeCard(c,s);i[n]={key:c,checksum:f,updatedAt:new Date().toISOString()},e.writeIndex(i);},patchCard(n,s,a){let i=t(),c=i[n];if(!c||!e.cardExists(c.key))throw new Error(`card "${n}" not found`);let f=e.readCard(c.key);if(!f||typeof f!="object"||Array.isArray(f))throw new Error(`card "${n}" is not patchable`);let d=o(f,s,a),u=e.writeCard(c.key,d);i[n]={key:c.key,checksum:u,updatedAt:new Date().toISOString()},e.writeIndex(i);},removeCard(n){let s=t(),a=s[n];a&&(e.removeCard(a.key),delete s[n],e.writeIndex(s));},readIndex(){return t()}}}function Ke(e,r){return oe(e,r)}function qe(e){return re(e)}var he="v1",H="board/graph",ce="board/lastJournalProcessedId";function Be(e){return `cards/${e}/runtime`}function Le(e){return te(e,he)}function je(e){function r(t){let o=e.read(t);return o==null?null:typeof o=="string"?o:JSON.stringify(o)}return {readTaskExecutorRef(){let t=r("task-executor");if(t?.trim())return chunk7JVHYHT2_cjs.c(t.trim())},writeTaskExecutorRef(t){e.write("task-executor",chunk7JVHYHT2_cjs.b(t));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(t){e.write("chat-handler-flow",t);},readBoardRuntimeStoreRef(){return r("board-runtime-store-ref")},writeBoardRuntimeStoreRef(t){e.write("board-runtime-store-ref",t);},readCardStoreRef(){return r("card-store-ref")},writeCardStoreRef(t){e.write("card-store-ref",t);},readOutputsStoreRef(){return r("outputs-store-ref")},writeOutputsStoreRef(t){e.write("outputs-store-ref",t);},readQueueStoreRef(){return r("queue-store-ref")},writeQueueStoreRef(t){e.write("queue-store-ref",t);},readScratchStoreRef(){return r("scratch-store-ref")},writeScratchStoreRef(t){e.write("scratch-store-ref",t);},readChatStoreRef(){return r("chat-store-ref")},writeChatStoreRef(t){e.write("chat-store-ref",t);},readArtifactsStoreRef(){return r("artifacts-store-ref")},writeArtifactsStoreRef(t){e.write("artifacts-store-ref",t);},readFetchedSourcesStoreRef(){return r("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(t){e.write("fetched-sources-store-ref",t);}}}function De(e){return se(e)}function ie(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function ke(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function ae(e,r){return e?.lastRequestedToken?ke(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<r?"dispatch":"idle":"dispatch"}function Ce(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"success"}}function de(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"failure"}}function $e(e){let r=e.cards.filter(i=>i.name!==_);if(r.length===e.cards.length)return e;let t=new Set;for(let i of r)for(let c of i.requires)t.add(c);let o=r.map(i=>({name:i.name,fanOut:i.unblocks.length})).sort((i,c)=>c.fanOut-i.fanOut||i.name.localeCompare(c.name)),n=o.length>0?o[0]:{name:null,fanOut:0},s=i=>r.filter(c=>c.status===i).length,a=r.filter(i=>i.requires.length===0&&i.unblocks.length===0).length;return {...e,summary:{...e.summary,card_count:r.length,completed:s("completed"),eligible:s("eligible"),pending:s("pending"),blocked:s("blocked"),unresolved:s("unresolved"),failed:s("failed"),in_progress:s("in-progress"),orphan_cards:a,topology:{edge_count:t.size,max_fan_out_card:n.name,max_fan_out:n.fanOut}},cards:r}}function Ne(e){let{[T]:r,...t}=e;return t}function Je(e,r){let t=r.state.tasks,o=r.config.tasks,n=Object.keys(t),s=chunkVI36DRWG_cjs.a(r),a={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},i=new Map;for(let p of s.pending)i.set(p.taskName,p.waitingOn);for(let p of s.unresolved)i.set(p.taskName,p.missingTokens);for(let p of s.blocked)i.set(p.taskName,p.failedTokens);let c=new Map;for(let[p,S]of Object.entries(o))for(let w of S.requires??[]){let k=c.get(w)??[];k.push(p),c.set(w,k);}let f=n.sort().map(p=>{let S=t[p],w=o[p]??{requires:[],provides:[]};S.status==="completed"?a.completed+=1:S.status==="failed"?a.failed+=1:S.status==="in-progress"&&(a.in_progress+=1);let k=w.requires??[],R=w.provides??[],I=Object.keys(S.data??{}).sort(),v=k.filter(x=>r.state.availableOutputs.includes(x)),D=k.filter(x=>!r.state.availableOutputs.includes(x)),E=i.get(p)??D,F=new Set;for(let x of R)for(let q of c.get(x)??[])q!==p&&F.add(q);let V=S.failedAt,O=S.error?{message:S.error,code:"TASK_FAILED",at:V,source:"task-runtime"}:void 0;return {name:p,status:S.status,error:O,requires:k,requires_satisfied:v,requires_missing:D,provides_declared:R,provides_runtime:I,blocked_by:E,unblocks:Array.from(F).sort(),runtime:{attempt_count:S.executionCount??0,restart_count:S.retryCount??0,in_progress_since:S.status==="in-progress"?S.startedAt??null:null,last_transition_at:S.lastUpdated??null,last_completed_at:S.completedAt??null,last_restarted_at:S.startedAt??null,status_age_ms:S.lastUpdated?0:null}}});a.pending=s.pending.length,a.blocked=s.blocked.length,a.unresolved=s.unresolved.length;let d=f.map(p=>({name:p.name,fanOut:p.unblocks.length})).sort((p,S)=>S.fanOut-p.fanOut||p.name.localeCompare(S.name)),u=d.length>0?d[0]:{name:null,fanOut:0},l=new Set;for(let p of Object.values(o))for(let S of p.requires??[])l.add(S);let m=0;for(let[p,S]of Object.entries(o)){let w=(S.requires??[]).length===0,R=(S.provides??[]).some(I=>(c.get(I)??[]).some(v=>v!==p));w&&!R&&(m+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:n.length,completed:a.completed,eligible:s.eligible.length,pending:a.pending,blocked:a.blocked,unresolved:a.unresolved,failed:a.failed,in_progress:a.in_progress,orphan_cards:m,topology:{edge_count:Array.from(l).length,max_fan_out_card:u.name,max_fan_out:u.fanOut}},cards:f}}function we(){return new Date().toISOString()}function Me(e,r,t,o,n,s,a){return async i=>{let c=[],f=t.cardStore.readCard(i.nodeId);if(!f)return "task-initiate-failure";let d=f.id;if(d===_){let g=t.activeTaskConfigs?.(),y={[T]:g?ye(Object.keys(g).filter(h=>h!==_).map(h=>t.cardStore.readCard(h)).filter(h=>!!h),g):Se(t.cardStore.readAllCards())};return (a??t.outputStore.writeDataObjects.bind(t.outputStore))(y),o(i.nodeId,y),"task-initiated"}let u=f.card_data??{},l=f.source_defs??[],m=t.cardRuntimeStore.readRuntime(d),p=false,S=()=>{p&&(t.cardRuntimeStore.writeRuntime(d,m),p=false);},w=g=>ie(m._sources[g]),k=(g,y)=>{m._sources[g]=ie(y),p=true;},R=i.taskState?.executionCount??0;if(m._lastExecutionCount!==R&&(m._sources={},m._lastExecutionCount=R,p=true),i.update){let g=i.update,y=g.outputFile;if(y){let h=w(y);if(g.failure){let C=g.rqt??h.lastRequestedToken??h.queueRequestedToken;C&&k(y,de(h,C));}else {let C=g.rqt;if(!h.lastCompletedToken||C>h.lastCompletedToken){let A=typeof g.deliveryToken=="string"?g.deliveryToken:void 0,K=false;A&&(K=t.fetchedSourcesStore.commitSourceData(d,y,A)),K?k(y,Ce(h,C)):k(y,de(h,C));}}S();}}let v={};for(let[g,y]of Object.entries(i.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let h=y[g];v[g]=h!==void 0?h:y;}else v[g]=y;let E=chunkZV35WD6K_cjs.a.enrichSourcesSync(Array.isArray(f.source_defs)?f.source_defs:void 0,{card_data:u,requires:v}).filter(g=>g._skip!==true),F=E,V={};for(let g of E)if(g.outputFile){let y=t.fetchedSourcesStore.readSourceData(d,g.outputFile);y!==null&&(V[g.bindTo]=y);}let O={id:d,card_data:{...u},requires:v,source_defs:l,compute:f.compute};O._sourcesData=V,f.compute&&chunkZV35WD6K_cjs.a.runSync(O,{sourcesData:V}),(s??t.outputStore.writeComputedValues.bind(t.outputStore))(d,O.computed_values??{});let x={...f},q=e.value;x.source_defs=Array.isArray(E)?E.map(g=>({...g,boardDir:typeof g.boardDir=="string"&&g.boardDir?g.boardDir:q})):E;let P=we(),G=i.update?void 0:P,z=F.filter(g=>{let y=g.outputFile;if(typeof y!="string"||!y)return true;let h=w(y);G&&(h={...h,queueRequestedToken:G},k(y,h));let C=h.queueRequestedToken??h.lastRequestedToken??P,A=ae(h,C);return A==="in-flight"?false:A==="dispatch"});if(S(),z.length>0){let g=false,y=P;for(let h of z){let C=h.outputFile;if(typeof C!="string"||!C)continue;let A=w(C),K=A.queueRequestedToken??P;k(C,{...A,lastRequestedToken:K}),y=K,g=true;}return g&&S(),g&&(c.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(e),enrichedCard:x,callbackToken:i.callbackToken,rqt:y}}),t.executionRequestStore.appendEntries(r,c)),"task-initiated"}if(F.some(g=>{let y=g.outputFile;if(typeof y!="string"||!y)return false;let h=w(y),C=h.queueRequestedToken??h.lastRequestedToken??P;return ae(h,C)==="in-flight"}))return "task-initiated";let le=f.provides??[],$={};for(let{bindTo:g,ref:y}of le)$[g]=chunkZV35WD6K_cjs.a.resolve(O,y);return (a??t.outputStore.writeDataObjects.bind(t.outputStore))($),o(i.nodeId,$),c.length>0&&t.executionRequestStore.appendEntries(r,c),"task-initiated"}}var Ue={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function He(e){return {[H]:e.graph,[ce]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function Ge(e){let r=e[H],t=e[ce],n=e.board?.runtimeByCardId;if(!r||typeof r!="object")throw new Error(`State snapshot is missing required key: ${H}`);return {graph:r,lastDrainedJournalId:typeof t=="string"?t:"",runtimeByCardId:n&&typeof n=="object"?n:{}}}function ze(e){let r=e.requires;return {provides:e.provides?.map(o=>o.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...r&&r.length>0?{requires:r}:{}}}function Xe(e,r={}){function t(d){return {status:"success",data:d}}function o(d){return {status:"fail",error:d}}function n(d){return {status:"error",error:d instanceof Error?d.message:String(d)}}function s(d){return d===_}async function a(d){let u=r.emitNotification;if(!u||d.length===0)return;let l=chunk2RIHC5TZ_cjs.e(d.filter(m=>m.kind!=="card_refreshed"?true:!s(m.cardId)));if(l.length!==0){if(l.length===1){await u(l[0]);return}await u(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:l}));}}function i(d){let u=d.params?.id;if(u){if(s(u))throw new Error(`card "${u}" not found`);let l=e.readCard(u);if(!l)throw new Error(`card "${u}" not found`);return [l]}return e.readAllCards().filter(l=>!s(l.id))}function c(d){let u=d.filter(l=>!s(l.id));return chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:chunk2RIHC5TZ_cjs.e(u.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function f(d){if(Array.isArray(d))return d;if(d&&typeof d=="object"){let u=d;return Array.isArray(u.files)?u.files:[d]}return null}return {get(d){try{return t({cards:i(d)})}catch(u){return n(u)}},buildNotificationBatch(d){try{return t(c(i(d)))}catch(u){return n(u)}},set(d){try{let u=d.body;if(u==null)return o("set requires a body (card object or array of cards)");let l=Array.isArray(u)?u:[u];for(let m of l){if(typeof m.id!="string")return o("each card must have a string `id` field");e.writeCard(m.id,m);}return a(l.map(m=>({kind:"card_refreshed",cardId:m.id,card:m}))),t({count:l.length})}catch(u){return n(u)}},del(d){try{let u=d.body?.ids??[],l=d.params?.id,m=l?[...u,l]:u;if(m.length===0)return o("del requires body.ids (string[]) or params.id");for(let p of m)e.removeCard(p);return a(m.map(p=>({kind:"card_removed",cardId:p}))),t({count:m.length})}catch(u){return n(u)}},patch(d){try{let u=d.params?.id,l=d.params?.path;if(!u)return o("patch requires params.id");if(!l)return o("patch requires params.path");let m=d.body,p=m&&Object.prototype.hasOwnProperty.call(m,"value")?m.value:d.body;e.patchCard(u,l,p);let S=e.readCard(u);return S?(a([{kind:"card_refreshed",cardId:u,card:S}]),t({count:1})):o(`card "${u}" not found`)}catch(u){return n(u)}},appendFiles(d){try{let u=d.params?.id;if(!u)return o("appendFiles requires params.id");let l=e.readCard(u);if(!l)return o(`card "${u}" not found`);let m=f(d.body);if(!m||m.length===0)return o("appendFiles requires a file metadata object, array, or body.files array");let p=l.card_data&&typeof l.card_data=="object"&&!Array.isArray(l.card_data)?l.card_data:{},S=Array.isArray(p.files)?p.files:[],w=[...S,...m],k=m.map((I,v)=>({idx:S.length+v,entry:I})),R=this.patch({params:{id:u,path:"card_data.files"},body:{value:w}});return R.status!=="success"?R:t({files_added:k})}catch(u){return n(u)}}}}exports.A=Ne;exports.B=Je;exports.C=Me;exports.D=Ue;exports.E=He;exports.F=Ge;exports.G=ze;exports.H=Xe;exports.a=ve;exports.b=te;exports.c=be;exports.d=oe;exports.e=fe;exports.f=me;exports.g=se;exports.h=T;exports.i=_;exports.j=Se;exports.k=ye;exports.l=Ve;exports.m=Pe;exports.n=Ke;exports.o=qe;exports.p=he;exports.q=H;exports.r=Be;exports.s=Le;exports.t=je;exports.u=De;exports.v=ie;exports.w=ae;exports.x=Ce;exports.y=de;exports.z=$e;//# sourceMappingURL=chunk-JOQWJ3VR.cjs.map
2
+ //# sourceMappingURL=chunk-JOQWJ3VR.cjs.map
@@ -0,0 +1,2 @@
1
+ import {b as b$1,c}from'./chunk-ANKA7HEJ.js';import {a as a$2}from'./chunk-44L64VQ2.js';import {a}from'./chunk-Q444D72R.js';import {a as a$1}from'./chunk-YOY2JM5N.js';import {e,f}from'./chunk-UGB7PC4P.js';function L(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function M(e,r){return L(e)?e.then(r):r(e)}function ee(e,r){let t={...e};for(let o of r.deleteKeys)delete t[o];return {...t,...r.shallowMerge}}function ve(e,r){return {readValues(o){let n=e(o);return M(n.listKeys(),s=>{let a=[...s].sort();if(a.length===0)return {version:null,values:{}};let i={},c=null;for(let f of a){let d=n.read(f);L(d)?c=(c??Promise.resolve()).then(async()=>{i[f]=await d;}):i[f]=d;}return c?c.then(()=>({version:r(i),values:i})):{version:r(i),values:i}})},writeValues(o,n,s){let a=e(o),i=null;for(let c of s){let f=a.delete(c);L(f)&&(i=(i??Promise.resolve()).then(()=>f).then(()=>{}));}for(let[c,f]of Object.entries(n)){let d=a.write(c,f);L(d)&&(i=(i??Promise.resolve()).then(()=>d).then(()=>{}));}return i?i.then(()=>r(n)):r(n)}}}function te(e,r){return {readSnapshot(t){return e.readValues(t)},commitSnapshot(t,o){if(o.schemaVersion!==r)throw new Error(`Unsupported snapshot schema version: ${o.schemaVersion}`);return M(e.readValues(t),n=>{if(n.version!==o.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let s=ee(n.values,o);return M(e.writeValues(t,s,o.deleteKeys),a=>({ok:true,newVersion:a}))})}}}function Z(e,r){if(!r)return e;let t=e.findIndex(o=>o.id===r);return t===-1?e:e.slice(t+1)}function re(e){return {readEntriesAfterCursor(r){let t=Z(e.readAllEntries(),r);return t.length===0?{events:[],newCursor:r}:{events:t.map(o=>o.event),newCursor:t[t.length-1].id}},pendingCount(r){return Z(e.readAllEntries(),r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function be(e){return {appendEvent(r){return e.append(r).then(()=>{})},async readEntriesAfterCursor(r){let t=await e.readAfter(r||null);return {events:t.entries.map(o=>o.payload),newCursor:t.newCursor??r}}}}function j(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function b(e,r){return j(e)?e.then(r):r(e)}function U(e,r){let t=null;for(let o of e){if(t){t=t.then(()=>r(o)).then(()=>{});continue}let n=r(o);j(n)&&(t=Promise.resolve(n).then(()=>{}));}return t??void 0}function pe(e){if(e==null)return null;let r=e.trim();if(!r)return null;try{return JSON.parse(r)}catch{return r}}function ge(e,r){let t=e.match(r);return t?t[1]:null}function ne(e,r,t){let o={},n=U(e,s=>{let a=t(s);if(a)return b(r(s),i=>{o[a]=i;})});return j(n)?n.then(()=>o):o}function oe(e,r){return {readSourceData(t,o){return b(e.read(`${t}/${o}`),pe)},ingestSourceDataStaged(t,o,n,s){return b(r(n),a=>e.write(`${t}/.staged/${s}/${o}`,a))},commitSourceData(t,o,n){let s=`${t}/.staged/${n}/${o}`,a=`${t}/${o}`;return e.renameKey(s,a)},hasSource(t,o){return e.exists(`${t}/${o}`)},listSources(t){return b(e.listKeys(`${t}/`),o=>o.filter(n=>!n.includes("/.staged/")).map(n=>n.slice(`${t}/`.length)))}}}function fe(e,r){let t=(o,n)=>{try{let s=n(o);return j(s)?s.catch(a=>r(o,a instanceof Error?a.message:String(a))):void 0}catch(s){try{return r(o,s instanceof Error?s.message:String(s))}catch{return}}};return {appendEntries(o,n){if(!(!o||n.length===0))return b(e.read(o),s=>e.write(o,[...s??[],...n]))},dispatchEntriesForJournalId(o,n){if(o)return b(e.read(o),s=>{let a=s;if(!(!a||a.length===0))return b(U(a,i=>t(i,n)),()=>e.delete(o))})}}}function me(e,r,t){return {readRuntime(o){return b(e.read(r(o)),n=>n??t())},writeRuntime(o,n){return e.write(r(o),n)}}}function se(e){return {writeComputedValues(r,t){return e.write(`cards/${r}/computed_values`,t)},readComputedValues(r){return e.read(`cards/${r}/computed_values`)},readAllComputedValues(){return b(e.listKeys("cards/"),r=>ne(r,t=>e.read(t),t=>ge(t,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(r){return U(Object.entries(r),([t,o])=>{if(t)return o===void 0?e.delete(`data-objects/${t}`):e.write(`data-objects/${t}`,o)})},readDataObject(r){return e.read(`data-objects/${r}`)},readAllDataObjects(){return b(e.listKeys("data-objects/"),r=>ne(r,t=>e.read(t),t=>t.slice(13)))},writeStatusSnapshot(r){return e.write("status",r)},readStatusSnapshot(){return e.read("status")}}}var T="sys_keys_board_state",_="__sys_keys_board_state_init";function ue(e){if(!e||typeof e!="object"||Array.isArray(e))return false;let r=e.__private;return !!r&&typeof r=="object"&&!Array.isArray(r)&&r.visible_controlplane_only===true}function Se(e){let r=e.filter(n=>!ue(n)),t=[...new Set(r.map(n=>n.id).filter(n=>typeof n=="string"&&n.length>0))].sort(),o=[...new Set(r.flatMap(n=>Array.isArray(n.provides)?n.provides:[]).map(n=>n&&typeof n=="object"&&!Array.isArray(n)?n.bindTo:void 0).filter(n=>typeof n=="string"&&n.length>0&&n!==T))].sort();return {card_ids:t,data_object_keys:o}}function ye(e,r){let t=e.filter(s=>!ue(s)),o=[...new Set(t.map(s=>s.id).filter(s=>typeof s=="string"&&s.length>0))].sort(),n=[...new Set(Object.entries(r).filter(([s])=>s!==_).flatMap(([,s])=>Array.isArray(s.provides)?s.provides:[]).filter(s=>typeof s=="string"&&s.length>0&&s!==T))].sort();return {card_ids:o,data_object_keys:n}}function Ve(){return {id:_,meta:{title:"System Keys Board State",synthetic:true},provides:[{bindTo:T,ref:`card_data.${T}`}],card_data:{[T]:{card_ids:[],data_object_keys:[]}},__private:{visible_controlplane_only:true}}}function Pe(e,r){function t(){return e.readIndex()??{}}function o(n,s,a){let i=String(s||"").split(".").filter(Boolean);if(i.length===0)return a&&typeof a=="object"&&!Array.isArray(a)?a:{value:a};let c={...n},f=c;for(let d=0;d<i.length-1;d++){let u=i[d],l=f[u],m=l&&typeof l=="object"&&!Array.isArray(l)?{...l}:{};f[u]=m,f=m;}return f[i[i.length-1]]=a,c}return {readCard(n){let s=t()[n];return !s||!e.cardExists(s.key)?null:e.readCard(s.key)},readCardKey(n){return t()[n]?.key??null},readAllCards(){let n=[];for(let[s,a]of Object.entries(t())){if(!e.cardExists(a.key))continue;let i=e.readCard(a.key);i?n.push(i):r?.(`[card-store] could not read card "${s}" at key "${a.key}"`);}return n},readChecksumIndex(){let n={};for(let[s,a]of Object.entries(t()))n[s]=a.checksum;return n},changedSince(n){let s=t(),a=[];for(let[i,c]of Object.entries(s))n[i]!==c.checksum&&a.push(i);for(let i of Object.keys(n))s[i]||a.push(i);return a},validateUpsert(n,s){let a=t(),i=a[n],c=Object.entries(a).find(([,f])=>f.key===s);return i&&i.key!==s?{ok:false,error:`Card id "${n}" is already mapped to key "${i.key}", cannot remap to "${s}"`}:c&&c[0]!==n?{ok:false,error:`Key "${s}" is already mapped to card id "${c[0]}", cannot remap to "${n}"`}:{ok:true}},writeCard(n,s,a){let i=t(),c=a??i[n]?.key??e.defaultCardKey(n),f=e.writeCard(c,s);i[n]={key:c,checksum:f,updatedAt:new Date().toISOString()},e.writeIndex(i);},patchCard(n,s,a){let i=t(),c=i[n];if(!c||!e.cardExists(c.key))throw new Error(`card "${n}" not found`);let f=e.readCard(c.key);if(!f||typeof f!="object"||Array.isArray(f))throw new Error(`card "${n}" is not patchable`);let d=o(f,s,a),u=e.writeCard(c.key,d);i[n]={key:c.key,checksum:u,updatedAt:new Date().toISOString()},e.writeIndex(i);},removeCard(n){let s=t(),a=s[n];a&&(e.removeCard(a.key),delete s[n],e.writeIndex(s));},readIndex(){return t()}}}function Ke(e,r){return oe(e,r)}function qe(e){return re(e)}var he="v1",H="board/graph",ce="board/lastJournalProcessedId";function Be(e){return `cards/${e}/runtime`}function Le(e){return te(e,he)}function je(e){function r(t){let o=e.read(t);return o==null?null:typeof o=="string"?o:JSON.stringify(o)}return {readTaskExecutorRef(){let t=r("task-executor");if(t?.trim())return c(t.trim())},writeTaskExecutorRef(t){e.write("task-executor",b$1(t));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(t){e.write("chat-handler-flow",t);},readBoardRuntimeStoreRef(){return r("board-runtime-store-ref")},writeBoardRuntimeStoreRef(t){e.write("board-runtime-store-ref",t);},readCardStoreRef(){return r("card-store-ref")},writeCardStoreRef(t){e.write("card-store-ref",t);},readOutputsStoreRef(){return r("outputs-store-ref")},writeOutputsStoreRef(t){e.write("outputs-store-ref",t);},readQueueStoreRef(){return r("queue-store-ref")},writeQueueStoreRef(t){e.write("queue-store-ref",t);},readScratchStoreRef(){return r("scratch-store-ref")},writeScratchStoreRef(t){e.write("scratch-store-ref",t);},readChatStoreRef(){return r("chat-store-ref")},writeChatStoreRef(t){e.write("chat-store-ref",t);},readArtifactsStoreRef(){return r("artifacts-store-ref")},writeArtifactsStoreRef(t){e.write("artifacts-store-ref",t);},readFetchedSourcesStoreRef(){return r("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(t){e.write("fetched-sources-store-ref",t);}}}function De(e){return se(e)}function ie(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function ke(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function ae(e,r){return e?.lastRequestedToken?ke(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<r?"dispatch":"idle":"dispatch"}function Ce(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"success"}}function de(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"failure"}}function $e(e){let r=e.cards.filter(i=>i.name!==_);if(r.length===e.cards.length)return e;let t=new Set;for(let i of r)for(let c of i.requires)t.add(c);let o=r.map(i=>({name:i.name,fanOut:i.unblocks.length})).sort((i,c)=>c.fanOut-i.fanOut||i.name.localeCompare(c.name)),n=o.length>0?o[0]:{name:null,fanOut:0},s=i=>r.filter(c=>c.status===i).length,a=r.filter(i=>i.requires.length===0&&i.unblocks.length===0).length;return {...e,summary:{...e.summary,card_count:r.length,completed:s("completed"),eligible:s("eligible"),pending:s("pending"),blocked:s("blocked"),unresolved:s("unresolved"),failed:s("failed"),in_progress:s("in-progress"),orphan_cards:a,topology:{edge_count:t.size,max_fan_out_card:n.name,max_fan_out:n.fanOut}},cards:r}}function Ne(e){let{[T]:r,...t}=e;return t}function Je(e,r){let t=r.state.tasks,o=r.config.tasks,n=Object.keys(t),s=a(r),a$1={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},i=new Map;for(let p of s.pending)i.set(p.taskName,p.waitingOn);for(let p of s.unresolved)i.set(p.taskName,p.missingTokens);for(let p of s.blocked)i.set(p.taskName,p.failedTokens);let c=new Map;for(let[p,S]of Object.entries(o))for(let w of S.requires??[]){let k=c.get(w)??[];k.push(p),c.set(w,k);}let f=n.sort().map(p=>{let S=t[p],w=o[p]??{requires:[],provides:[]};S.status==="completed"?a$1.completed+=1:S.status==="failed"?a$1.failed+=1:S.status==="in-progress"&&(a$1.in_progress+=1);let k=w.requires??[],R=w.provides??[],I=Object.keys(S.data??{}).sort(),v=k.filter(x=>r.state.availableOutputs.includes(x)),D=k.filter(x=>!r.state.availableOutputs.includes(x)),E=i.get(p)??D,F=new Set;for(let x of R)for(let q of c.get(x)??[])q!==p&&F.add(q);let V=S.failedAt,O=S.error?{message:S.error,code:"TASK_FAILED",at:V,source:"task-runtime"}:void 0;return {name:p,status:S.status,error:O,requires:k,requires_satisfied:v,requires_missing:D,provides_declared:R,provides_runtime:I,blocked_by:E,unblocks:Array.from(F).sort(),runtime:{attempt_count:S.executionCount??0,restart_count:S.retryCount??0,in_progress_since:S.status==="in-progress"?S.startedAt??null:null,last_transition_at:S.lastUpdated??null,last_completed_at:S.completedAt??null,last_restarted_at:S.startedAt??null,status_age_ms:S.lastUpdated?0:null}}});a$1.pending=s.pending.length,a$1.blocked=s.blocked.length,a$1.unresolved=s.unresolved.length;let d=f.map(p=>({name:p.name,fanOut:p.unblocks.length})).sort((p,S)=>S.fanOut-p.fanOut||p.name.localeCompare(S.name)),u=d.length>0?d[0]:{name:null,fanOut:0},l=new Set;for(let p of Object.values(o))for(let S of p.requires??[])l.add(S);let m=0;for(let[p,S]of Object.entries(o)){let w=(S.requires??[]).length===0,R=(S.provides??[]).some(I=>(c.get(I)??[]).some(v=>v!==p));w&&!R&&(m+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:n.length,completed:a$1.completed,eligible:s.eligible.length,pending:a$1.pending,blocked:a$1.blocked,unresolved:a$1.unresolved,failed:a$1.failed,in_progress:a$1.in_progress,orphan_cards:m,topology:{edge_count:Array.from(l).length,max_fan_out_card:u.name,max_fan_out:u.fanOut}},cards:f}}function we(){return new Date().toISOString()}function Me(e,r,t,o,n,s,a){return async i=>{let c=[],f=t.cardStore.readCard(i.nodeId);if(!f)return "task-initiate-failure";let d=f.id;if(d===_){let g=t.activeTaskConfigs?.(),y={[T]:g?ye(Object.keys(g).filter(h=>h!==_).map(h=>t.cardStore.readCard(h)).filter(h=>!!h),g):Se(t.cardStore.readAllCards())};return (a??t.outputStore.writeDataObjects.bind(t.outputStore))(y),o(i.nodeId,y),"task-initiated"}let u=f.card_data??{},l=f.source_defs??[],m=t.cardRuntimeStore.readRuntime(d),p=false,S=()=>{p&&(t.cardRuntimeStore.writeRuntime(d,m),p=false);},w=g=>ie(m._sources[g]),k=(g,y)=>{m._sources[g]=ie(y),p=true;},R=i.taskState?.executionCount??0;if(m._lastExecutionCount!==R&&(m._sources={},m._lastExecutionCount=R,p=true),i.update){let g=i.update,y=g.outputFile;if(y){let h=w(y);if(g.failure){let C=g.rqt??h.lastRequestedToken??h.queueRequestedToken;C&&k(y,de(h,C));}else {let C=g.rqt;if(!h.lastCompletedToken||C>h.lastCompletedToken){let A=typeof g.deliveryToken=="string"?g.deliveryToken:void 0,K=false;A&&(K=t.fetchedSourcesStore.commitSourceData(d,y,A)),K?k(y,Ce(h,C)):k(y,de(h,C));}}S();}}let v={};for(let[g,y]of Object.entries(i.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let h=y[g];v[g]=h!==void 0?h:y;}else v[g]=y;let E=a$1.enrichSourcesSync(Array.isArray(f.source_defs)?f.source_defs:void 0,{card_data:u,requires:v}).filter(g=>g._skip!==true),F=E,V={};for(let g of E)if(g.outputFile){let y=t.fetchedSourcesStore.readSourceData(d,g.outputFile);y!==null&&(V[g.bindTo]=y);}let O={id:d,card_data:{...u},requires:v,source_defs:l,compute:f.compute};O._sourcesData=V,f.compute&&a$1.runSync(O,{sourcesData:V}),(s??t.outputStore.writeComputedValues.bind(t.outputStore))(d,O.computed_values??{});let x={...f},q=e.value;x.source_defs=Array.isArray(E)?E.map(g=>({...g,boardDir:typeof g.boardDir=="string"&&g.boardDir?g.boardDir:q})):E;let P=we(),G=i.update?void 0:P,z=F.filter(g=>{let y=g.outputFile;if(typeof y!="string"||!y)return true;let h=w(y);G&&(h={...h,queueRequestedToken:G},k(y,h));let C=h.queueRequestedToken??h.lastRequestedToken??P,A=ae(h,C);return A==="in-flight"?false:A==="dispatch"});if(S(),z.length>0){let g=false,y=P;for(let h of z){let C=h.outputFile;if(typeof C!="string"||!C)continue;let A=w(C),K=A.queueRequestedToken??P;k(C,{...A,lastRequestedToken:K}),y=K,g=true;}return g&&S(),g&&(c.push({taskKind:"source-fetch",payload:{boardRef:a$2(e),enrichedCard:x,callbackToken:i.callbackToken,rqt:y}}),t.executionRequestStore.appendEntries(r,c)),"task-initiated"}if(F.some(g=>{let y=g.outputFile;if(typeof y!="string"||!y)return false;let h=w(y),C=h.queueRequestedToken??h.lastRequestedToken??P;return ae(h,C)==="in-flight"}))return "task-initiated";let le=f.provides??[],$={};for(let{bindTo:g,ref:y}of le)$[g]=a$1.resolve(O,y);return (a??t.outputStore.writeDataObjects.bind(t.outputStore))($),o(i.nodeId,$),c.length>0&&t.executionRequestStore.appendEntries(r,c),"task-initiated"}}var Ue={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function He(e){return {[H]:e.graph,[ce]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function Ge(e){let r=e[H],t=e[ce],n=e.board?.runtimeByCardId;if(!r||typeof r!="object")throw new Error(`State snapshot is missing required key: ${H}`);return {graph:r,lastDrainedJournalId:typeof t=="string"?t:"",runtimeByCardId:n&&typeof n=="object"?n:{}}}function ze(e){let r=e.requires;return {provides:e.provides?.map(o=>o.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...r&&r.length>0?{requires:r}:{}}}function Xe(e$1,r={}){function t(d){return {status:"success",data:d}}function o(d){return {status:"fail",error:d}}function n(d){return {status:"error",error:d instanceof Error?d.message:String(d)}}function s(d){return d===_}async function a(d){let u=r.emitNotification;if(!u||d.length===0)return;let l=e(d.filter(m=>m.kind!=="card_refreshed"?true:!s(m.cardId)));if(l.length!==0){if(l.length===1){await u(l[0]);return}await u(f({kind:"notification-batch",notifications:l}));}}function i(d){let u=d.params?.id;if(u){if(s(u))throw new Error(`card "${u}" not found`);let l=e$1.readCard(u);if(!l)throw new Error(`card "${u}" not found`);return [l]}return e$1.readAllCards().filter(l=>!s(l.id))}function c(d){let u=d.filter(l=>!s(l.id));return f({kind:"notification-batch",notifications:e(u.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function f$1(d){if(Array.isArray(d))return d;if(d&&typeof d=="object"){let u=d;return Array.isArray(u.files)?u.files:[d]}return null}return {get(d){try{return t({cards:i(d)})}catch(u){return n(u)}},buildNotificationBatch(d){try{return t(c(i(d)))}catch(u){return n(u)}},set(d){try{let u=d.body;if(u==null)return o("set requires a body (card object or array of cards)");let l=Array.isArray(u)?u:[u];for(let m of l){if(typeof m.id!="string")return o("each card must have a string `id` field");e$1.writeCard(m.id,m);}return a(l.map(m=>({kind:"card_refreshed",cardId:m.id,card:m}))),t({count:l.length})}catch(u){return n(u)}},del(d){try{let u=d.body?.ids??[],l=d.params?.id,m=l?[...u,l]:u;if(m.length===0)return o("del requires body.ids (string[]) or params.id");for(let p of m)e$1.removeCard(p);return a(m.map(p=>({kind:"card_removed",cardId:p}))),t({count:m.length})}catch(u){return n(u)}},patch(d){try{let u=d.params?.id,l=d.params?.path;if(!u)return o("patch requires params.id");if(!l)return o("patch requires params.path");let m=d.body,p=m&&Object.prototype.hasOwnProperty.call(m,"value")?m.value:d.body;e$1.patchCard(u,l,p);let S=e$1.readCard(u);return S?(a([{kind:"card_refreshed",cardId:u,card:S}]),t({count:1})):o(`card "${u}" not found`)}catch(u){return n(u)}},appendFiles(d){try{let u=d.params?.id;if(!u)return o("appendFiles requires params.id");let l=e$1.readCard(u);if(!l)return o(`card "${u}" not found`);let m=f$1(d.body);if(!m||m.length===0)return o("appendFiles requires a file metadata object, array, or body.files array");let p=l.card_data&&typeof l.card_data=="object"&&!Array.isArray(l.card_data)?l.card_data:{},S=Array.isArray(p.files)?p.files:[],w=[...S,...m],k=m.map((I,v)=>({idx:S.length+v,entry:I})),R=this.patch({params:{id:u,path:"card_data.files"},body:{value:w}});return R.status!=="success"?R:t({files_added:k})}catch(u){return n(u)}}}}export{Ne as A,Je as B,Me as C,Ue as D,He as E,Ge as F,ze as G,Xe as H,ve as a,te as b,be as c,oe as d,fe as e,me as f,se as g,T as h,_ as i,Se as j,ye as k,Ve as l,Pe as m,Ke as n,qe as o,he as p,H as q,Be as r,Le as s,je as t,De as u,ie as v,ae as w,Ce as x,de as y,$e as z};//# sourceMappingURL=chunk-MRESV3MD.js.map
2
+ //# sourceMappingURL=chunk-MRESV3MD.js.map
@@ -0,0 +1,3 @@
1
+ 'use strict';var chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs'),chunkEGZPROOH_cjs=require('./chunk-EGZPROOH.cjs'),chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunkJOQWJ3VR_cjs=require('./chunk-JOQWJ3VR.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkZV35WD6K_cjs=require('./chunk-ZV35WD6K.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 ve(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 be(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]:be(d,s,a)}}function ft(e){return {read:a=>e.read(a),get(a,r){return ve(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 ve(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return ve(e.read(a),s=>e.write(a,lt(s??{},r)))},patch(a,r,s){return ve(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,be(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=be(w,m,d),h=await e.writeCard(v.key,l);f[r]={key:v.key,checksum:h,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 chunkJOQWJ3VR_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 h=chunk2RIHC5TZ_cjs.e(m);if(h.length===1){await l(h[0]);return}await l(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:h}));}async function f(m){let l=m.params?.id;if(l){let h=await e.readCard(l);if(!h)throw new Error(`card "${l}" not found`);return [h]}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 h=Array.isArray(l)?l:[l];for(let S of h){if(typeof S.id!="string")return r("each card must have a string `id` field");await e.writeCard(S.id,S);}return await d(h.map(S=>({kind:"card_refreshed",cardId:S.id,card:S}))),a({count:h.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],h=m.params?.id,S=h?[...l,h]:l;if(S.length===0)return r("del requires body.ids (string[]) or params.id");for(let _ of S)await e.removeCard(_);return await d(S.map(_=>({kind:"card_removed",cardId:_}))),a({count:S.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,h=m.params?.path;if(!l)return r("patch requires params.id");if(!h)return r("patch requires params.path");let S=m.body,_=S&&Object.prototype.hasOwnProperty.call(S,"value")?S.value:m.body;await e.patchCard(l,h,_);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 h=await e.readCard(l);if(!h)return r(`card "${l}" not found`);let S=w(m.body);if(!S||S.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let _=h.card_data&&typeof h.card_data=="object"&&!Array.isArray(h.card_data)?h.card_data:{},O=Array.isArray(_.files)?_.files:[],L=[...O,...S],J=S.map((j,Y)=>({idx:O.length+Y,entry:j})),V=await this.patch({params:{id:l,path:"card_data.files"},body:{value:L}});return V.status!=="success"?V:a({files_added:J})}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 E(){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 Ae(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 chunkJOQWJ3VR_cjs.f(e,chunkJOQWJ3VR_cjs.r,()=>({_sources:{}}))}function It(e,o){return chunkJOQWJ3VR_cjs.d(e,o)}function xt(e){return chunkJOQWJ3VR_cjs.g(e)}function Tt(e,o){return chunkJOQWJ3VR_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===chunkJOQWJ3VR_cjs.i){let p=a.activeTaskConfigs?.(),y={[chunkJOQWJ3VR_cjs.h]:p?chunkJOQWJ3VR_cjs.k((await Promise.all(Object.keys(p).filter(k=>k!==chunkJOQWJ3VR_cjs.i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await chunkJOQWJ3VR_cjs.j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w.card_data??{},h=w.source_defs??[],S=await a.cardRuntimeStore.readRuntime(m),_=false,O=async()=>{_&&(await a.cardRuntimeStore.writeRuntime(m,S),_=false);},L=p=>chunkJOQWJ3VR_cjs.v(S._sources[p]),J=(p,y)=>{S._sources[p]=chunkJOQWJ3VR_cjs.v(y),_=true;},V=f.taskState?.executionCount??0;if(S._lastExecutionCount!==V&&(S._sources={},S._lastExecutionCount=V,_=true),f.update){let p=f.update.outputFile;if(p){let y=L(p);if(f.update.failure){let k=f.update.rqt??y.lastRequestedToken??y.queueRequestedToken;k&&J(p,chunkJOQWJ3VR_cjs.y(y,k));}else {let k=f.update.rqt;if(!y.lastCompletedToken||k>y.lastCompletedToken){let D=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,K=D?await a.fetchedSourcesStore.commitSourceData(m,p,D):false;J(p,K?chunkJOQWJ3VR_cjs.x(y,k):chunkJOQWJ3VR_cjs.y(y,k));}}await O();}}let j={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];j[p]=k!==void 0?k:y;}else j[p]=y;let Y={id:m,card_data:{...l},requires:j,source_defs:h,compute:w.compute},W=chunkZV35WD6K_cjs.a.enrichSourcesSync(Array.isArray(w.source_defs)?w.source_defs:void 0,{card_data:l,requires:j}).filter(p=>p._skip!==true),ae=W,de={};for(let p of W){if(!p.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,p.outputFile);y!==null&&(de[p.bindTo]=y);}Y._sourcesData=de,w.compute&&chunkZV35WD6K_cjs.a.runSync(Y,{sourcesData:de}),(s??(()=>{}))(m,Y.computed_values??{});let fe={...w,source_defs:Array.isArray(W)?W.map(p=>({...p,boardDir:typeof p.boardDir=="string"&&p.boardDir?p.boardDir:e.value})):W},B=E(),ge=f.update?void 0:B,Z=ae.filter(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return true;let k=L(y);ge&&(k={...k,queueRequestedToken:ge},J(y,k));let D=k.queueRequestedToken??k.lastRequestedToken??B;return chunkJOQWJ3VR_cjs.w(k,D)==="dispatch"});if(await O(),Z.length>0){let p=false,y=B;for(let k of Z){let D=k.outputFile;if(typeof D!="string"||!D)continue;let K=L(D),n=K.queueRequestedToken??B;J(D,{...K,lastRequestedToken:n}),y=n,p=true;}return p&&await O(),p&&(v.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(e),enrichedCard:fe,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v)),"task-initiated"}if(ae.some(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return false;let k=L(y),D=k.queueRequestedToken??k.lastRequestedToken??B;return chunkJOQWJ3VR_cjs.w(k,D)==="in-flight"}))return "task-initiated";let pe=w.provides??[],me={};for(let{bindTo:p,ref:y}of pe)me[p]=chunkZV35WD6K_cjs.a.resolve(Y,y);return (d??(()=>{}))(me),r(f.nodeId,me),v.length>0&&await a.executionRequestStore.appendEntries(o,v),"task-initiated"}}function nr(e,o,a={}){chunkEGZPROOH_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,h=a.chatHandlerFlow;function S(){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){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(S())),L=e.value,J=()=>chunkJOQWJ3VR_cjs.b(chunkJOQWJ3VR_cjs.a(()=>o.kvStorageForRef(S()),o.hashFn),"v1"),V=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))},j=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 Y(){return !!(await J().readSnapshot(L)).values[chunkJOQWJ3VR_cjs.q]}async function ue(){let n=await J().readSnapshot(L);if(!n.values[chunkJOQWJ3VR_cjs.q])throw new Error(`Board not initialized at ${e.value}`);return chunkJOQWJ3VR_cjs.F(n.values)}async function W(n,t){let c=await J().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:chunkJOQWJ3VR_cjs.E(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let ae=()=>chunkJOQWJ3VR_cjs.c(o.journalStorageForRef(S()));async function de(){return l??await O().readTaskExecutorRef()}async function fe(){return chunkJOQWJ3VR_cjs.A(await(await V()).readAllDataObjects())}async function B(n){await ae().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 Z(){return o.blobStorageForRef(await ge())}async function ce(){return It(await Z(),n=>o.resolveBlob(n))}async function pe(n){let t=(await Z()).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 me(){let n=Tt(o.kvStorageForRef(S()),async(u,g)=>{let P=u.payload,q=(P.enrichedCard??{}).id??P.cardId??"unknown";await B({type:"task-failed",taskName:q,error:g,timestamp:E()});}),t=At(o.kvStorageForRef(S())),c=await Z(),i=await ce(),A=await j(),I=await V(),F=new Map,C=new Map,x=[],Q=[],H=[],X=new Map,oe=new Set,se={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,$){return i.ingestSourceDataStaged(u,g,P,$)},async commitSourceData(u,g,P){let $=`${u}/.staged/${P}/${g}`,q=await c.read($);if(q==null){let G=await Promise.resolve(c.keyRef?.($));G&&(q=await o.resolveBlob(G));}if(q==null)return false;let U=`${u}/${g}`,te=q.trim();try{C.set(U,JSON.parse(te));}catch{C.set(U,te);}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($=>$.startsWith(`${u}/`)).map($=>$.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await ue(),De=chunkAW3COGCI_cjs.q(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await ae().readEntriesAfterCursor(xe.lastDrainedJournalId),ye=wt,Ve=()=>De.config.tasks,le=chunkAW3COGCI_cjs.t(De,{handlers:{"card-handler":Ot(e,Oe,{cardStore:A,cardRuntimeStore:se,fetchedSourcesStore:Ie,outputStore:I,executionRequestStore:n,activeTaskConfigs:()=>Ve()},(u,g)=>{ye.push({type:"task-completed",taskName:u,data:g,timestamp:E()});},(u,g)=>{Q.push({cardId:u,values:g});},u=>{H.push(u);})},onNodeRemoved:u=>{X.delete(u),F.delete(u),delete Te[u],oe.add(u);}});for(Ve=()=>le.getState().config.tasks;ye.length>0;){let u=ye;ye=[];for(let g of u)if(g.type==="task-restart"){let P=await A.readCard(g.taskName);P&&X.set(g.taskName,P);}le.pushAll(u),await le.waitForHandlers();}let $e=le.getState();await le.dispose({wait:true}),await W({lastDrainedJournalId:Oe,graph:chunkAW3COGCI_cjs.p($e),runtimeByCardId:Te},(await J().readSnapshot(L)).version);for(let{cardId:u,values:g}of Q)await I.writeComputedValues(u,g);for(let u of H)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=chunkJOQWJ3VR_cjs.z(chunkJOQWJ3VR_cjs.B(d,$e));await I.writeStatusSnapshot(Le);let ie=[];for(let{cardId:u,values:g}of Q)ie.push({kind:"computed_values",cardId:u,values:g});for(let u of H)for(let[g,P]of Object.entries(u))ie.push({kind:"data_object",key:g,payload:P});for(let[u,g]of X)u!==chunkJOQWJ3VR_cjs.i&&ie.push({kind:"card_refreshed",cardId:u,card:g});for(let u of oe)ie.push({kind:"card_removed",cardId:u});ie.push({kind:"status",status:Le}),await _(ie);let ee=await de();if(!ee)return;let Je=o.supportsDirectSourceOutput?.(ee)===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",$=g.enrichedCard?.source_defs??[];if(ee.howToRun==="queue-storage"&&Je){try{let q=await O().readQueueStoreRef();if(!q)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let U=o.queueStorageForRef(q,"task-executor"),te=typeof ee.extra?.boardId=="string"?ee.extra.boardId:void 0,G=[];for(let z of $){if(!z.outputFile)continue;let Se=o.genId(),ke=`${P}/.staged/${Se}/${z.outputFile}`,Me=await Promise.resolve(c.keyRef?.(ke));if(!Me)continue;let Qe={ref:chunkVQCIOKJV_cjs.a(Me),deliveryToken:Se,outputFile:z.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:z.bindTo,d:z.outputFile,cs:void 0,rqt:g.rqt,dt:Qe.deliveryToken});G.push({...te?{boardId:te}:{},ref:ee,args:{source_def:z,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ht),output:Qe}});}G.length>0&&await U.enqueueMany(G);}catch(q){await B({type:"task-failed",taskName:P,error:q instanceof Error?q.message:String(q),timestamp:E()});}return}for(let q of $){if(!q.outputFile)continue;let U;if(Je){let z=o.genId(),Se=`${P}/.staged/${z}/${q.outputFile}`,ke=await Promise.resolve(c.keyRef?.(Se));ke&&(U={ref:chunkVQCIOKJV_cjs.a(ke),deliveryToken:z,outputFile:q.outputFile,cardId:P});}let te=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:q.bindTo,d:q.outputFile,cs:void 0,rqt:g.rqt,...U?{dt:U.deliveryToken}:{}}),G=await o.dispatchExecution(ee,{source_def:q,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(te),...U?{output:U}:{}});G.dispatched||await B({type:"task-failed",taskName:P,error:G.error??"dispatch failed",timestamp:E()});}});}async function p(){try{let n=async()=>{let c=await ue(),{events:i}=await ae().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await k();},t=await mt(o.lock,me,n);return b({ran:t!==!1})}catch(n){return T(n)}}async function y(){return v||(v=p().finally(()=>{v=null;}),v)}async function k(){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 D(){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 K(){k();}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 Y()||await W({lastDrainedJournalId:"",graph:chunkAW3COGCI_cjs.p(chunkAW3COGCI_cjs.a(chunkJOQWJ3VR_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 j()).writeCard(chunkJOQWJ3VR_cjs.i,chunkJOQWJ3VR_cjs.l());let x=o.kvStorage("card-upsert"),Q=chunkJOQWJ3VR_cjs.l(),H=chunkJOQWJ3VR_cjs.G(Q),X=o.hashFn(H),se=(await x.read(chunkJOQWJ3VR_cjs.i))?.blobRef??await(await j()).readCardKey(chunkJOQWJ3VR_cjs.i)??chunkJOQWJ3VR_cjs.i;return await B({type:"task-upsert",taskName:chunkJOQWJ3VR_cjs.i,taskConfig:H,timestamp:E()}),await x.write(chunkJOQWJ3VR_cjs.i,{blobRef:se,taskConfigHash:X,updatedAt:E()}),await B({type:"task-restart",taskName:chunkJOQWJ3VR_cjs.i,timestamp:E()}),K(),await(await V()).writeStatusSnapshot(chunkJOQWJ3VR_cjs.z(chunkJOQWJ3VR_cjs.B(d,chunkAW3COGCI_cjs.q((await ue()).graph)))),b()}catch(t){return T(t)}},async status(n){try{let t=await V(),c=await t.readStatusSnapshot();return c||(c=chunkJOQWJ3VR_cjs.z(chunkJOQWJ3VR_cjs.B(d,chunkAW3COGCI_cjs.q((await ue()).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=h??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===chunkJOQWJ3VR_cjs.h)return b(null);let c=await fe();return b(c[t]??null)}catch(t){return T(t)}},async getAllOutputsDataObjects(n){try{return b(await fe())}catch(t){return T(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?b(await(await V()).readComputedValues(t)):R("getOutputsComputedValues requires params.key")}catch(t){return T(t)}},async getAllOutputsComputedValues(n){try{return b(await(await V()).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 ce()).listSources(t),i={};for(let A of c)i[A]=await pe(`${t}/${A}`);return b(i)}catch(t){return T(t)}},async getAllOutputsFetchedSources(n){try{let t=await ce(),c=await(await Z()).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 pe(`${I}/${C}`);}}return b(A)}catch(t){return T(t)}},async buildSseOneShotPayload(n){try{let t=(await(await j()).readAllCards()).filter(C=>C.id!==chunkJOQWJ3VR_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 j(),{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 B({type:"task-removal",taskName:t,timestamp:E()}),t!==chunkJOQWJ3VR_cjs.i&&await B({type:"task-restart",taskName:chunkJOQWJ3VR_cjs.i,timestamp:E()}),K(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await B({type:"task-restart",taskName:t,timestamp:E()}),K(),b()):R("retrigger requires params.id")}catch(t){return T(t)}},async processAccumulatedEvents(n){return await D(),y()},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 j(),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 H=chunkJOQWJ3VR_cjs.G(Q),X=o.hashFn(H),oe=await F.read(x),se=oe?.taskConfigHash!==X;if(!(!se&&!i)){if(se){let Ie=oe?.blobRef??await A.readCardKey(x)??x;await B({type:"task-upsert",taskName:x,taskConfig:H,timestamp:E()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:E()}),C=C||x!==chunkJOQWJ3VR_cjs.i;}i&&await B({type:"task-restart",taskName:x,timestamp:E()});}}return C&&await B({type:"task-restart",taskName:chunkJOQWJ3VR_cjs.i,timestamp:E()}),K(),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=Ae(t);return i?(await B({type:"task-failed",taskName:i.taskName,error:c,timestamp:E()}),K(),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=Ae(t);return i?(await B({type:"task-progress",taskName:i.taskName,update:c,timestamp:E()}),K(),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 ce(),I=i.dt||o.genId();i.dt||await A.ingestSourceDataStaged(i.cid,i.d,chunkVQCIOKJV_cjs.b(c),I);let F=Ae(i.cbk);return F?(await B({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:E(),deliveryToken:I,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),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=Ae(i.cbk);return A?(await B({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),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-MRIFSG7L.cjs.map
3
+ //# sourceMappingURL=chunk-MRIFSG7L.cjs.map
@@ -1,2 +1,2 @@
1
- import {a}from'./chunk-ATOQP3BD.js';function P(s,d){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function G(s,d){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${d} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function n(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function y(s){return Array.isArray(s)?s:[]}function N(s,d){if(typeof d!="string"||d.length===0)return;let u=s,p=d;p.startsWith("fetched_sources.")&&(u=n(s).fetched_sources,p=p.slice(16));for(let g of p.split(".")){if(u==null||typeof u!="object")return;u=u[g];}return u}function z(s,d){let u=n(s.view);return {elements:y(u.elements).map((g,h)=>{let R=n(g),b=n(R.data),k=typeof R.visible=="string"?!!N(d,R.visible):true,x=typeof b.bind=="string"?b.bind:void 0,S=typeof b.maxRows=="number"?b.maxRows:void 0,B=x?N(d,x):void 0,q={id:typeof R.id=="string"&&R.id?R.id:`element-${h}`,kind:R.kind,label:R.label,visible:k};return B!==void 0&&(q.resolved=Array.isArray(B)&&typeof S=="number"?B.slice(0,S):B),q})}}function Q(s,d){let u=typeof s.id=="string"&&s.id?s.id:"card",p=y(s.provides),g=p.length>0?p:[{bindTo:u,ref:"card_data"}],h={};for(let R of g){let b=n(R),k=typeof b.bindTo=="string"?b.bindTo:"",x=typeof b.ref=="string"?b.ref:"";if(!k||!x)continue;let S=N(d,x);S!==void 0&&(h[k]=S);}return h}function be(s){if(typeof s!="string"||!s.trim())return null;let d=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!d)return null;let u=Number.parseInt(d[2],10);return !Number.isInteger(u)||u<0?null:u}function ke(s){return {"card-content":s}}function j(s){let d={...s};return delete d.__private,d}function he(s,d){return Object.prototype.hasOwnProperty.call(s,d)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,d){let u=Re(s);if(!d||Object.keys(d).length===0)return u;function p(g,h,R){let b=String(h||"").split(".").filter(Boolean);if(!b.length)return;let k=g;for(let x=0;x<b.length-1;x+=1){let S=b[x];(!k[S]||typeof k[S]!="object")&&(k[S]={}),k=k[S];}k[b[b.length-1]]=R;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let g=null,h=n(u.view),R=y(h.elements);for(let b of R){let k=n(n(b).data);if(typeof k.writeTo=="string"&&k.writeTo){g=k.writeTo;break}}return g?p(u,g,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(u.card_data={...n(u.card_data),...d.fieldValues}),u}if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return u;for(let[g,h]of Object.entries(d))g!=="_stagedFiles"&&(h!==null&&typeof h=="object"&&!Array.isArray(h)&&u[g]!==null&&typeof u[g]=="object"&&!Array.isArray(u[g])?u[g]={...u[g],...h}:u[g]=h);return u}function D(s){return n(s.__private).visible_controlplane_only===true}async function T(s,d){let u=await A(s.get({params:{id:d}}),"cardStore.get"),p=Array.isArray(u?.cards)?u.cards:[];if(p.length===0)throw new Error(`Card "${d}" not found`);return p[0]}function Ae(s){let{board:d,nonCore:u,cardStore:p,chatStore:g,processAccumulated:h,sourceFetchDone:R,sourceFetchFailed:b,uploadCardFile:k,buildFileDownloadUrl:x,readFetchedSourceJsonByRef:S}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function q(){let e=await A(p.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>n(r)).filter(r=>!D(r)):[]}function X(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),a=atob(t);return Uint8Array.from(a,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=n(await A(u.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:n(e.commonSourceDefFields),sourceKinds:n(e.sourceKinds)}}async function Z(){let e=n(await A(d.status({}),"status")),r=n(e.summary),t=y(e.cards),a=await A(p.get({}),"cardStore.get"),o=new Set((Array.isArray(a.cards)?a.cards.map(n):[]).filter(D).map(c=>typeof c.id=="string"?c.id:"").filter(Boolean)),i=t.filter(c=>!o.has(String(n(c).name??"")));return {meta:n(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:i.map(c=>{let l=n(c);return {"card-id":typeof l.name=="string"?l.name:null,status:l.status??null,error:l.error??null,requires:y(l.requires),requires_satisfied:y(l.requires_satisfied),requires_missing:y(l.requires_missing),provides_declared:y(l.provides_declared),provides_runtime:y(l.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=n(await A(d.status({}),"status")),o=y(t.cards).map(n).find(f=>f.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let i=n(await T(p,r)),c=j(i),l=y(o.requires_satisfied).filter(f=>typeof f=="string"&&!!f),I=y(o.provides_runtime).filter(f=>typeof f=="string"&&!!f),v=Object.fromEntries(await Promise.all(l.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),_=Object.fromEntries(await Promise.all(I.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),m=n(await A(d.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),C=await A(d.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),M=y(i.source_defs).map(n),w={};for(let f of M)typeof f.bindTo=="string"&&typeof f.outputFile=="string"&&(w[f.outputFile]=f.bindTo);let U={};for(let[f,F]of Object.entries(C)){let O=w[f]??f;if(!S||typeof F!="string"){U[O]=null;continue}try{U[O]=S({cardId:r,ref:F});}catch{U[O]=null;}}let L={card_data:n(i.card_data),requires:v,fetched_sources:U,computed_values:m};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:c,refs_for_fetched_source_files:C,runtime_data:{requires:v,provides:_,computed_values:m,rendered_view:z(i,L)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",a=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",i=a?void 0:e.lastUserTurns??(t?void 0:1),c=e.tail,l={...i===void 0?{}:{tailTurns:i},...t?{turnId:t}:{},...a?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},I=Object.keys(l).length>0?{params:{cardId:r},body:l}:{params:{cardId:r}},v=P(await g.readAll(I),"chatStore.readAll"),_=n(await T(p,r)),m=y(n(_.card_data).files).map((w,U)=>({idx:U,stored_name:n(w).stored_name})).filter(w=>typeof w.stored_name=="string"&&w.stored_name.length>0),M=(Array.isArray(v.records)?v.records:[]).map(w=>{let L=n(w.payload),f={...w},F=typeof w?.role=="string"?w.role:typeof L.role=="string"?String(L.role):"",O=typeof w?.text=="string"?w.text:typeof L.text=="string"?String(L.text):"";if(F==="system"){let V=be(O);if(V!==null&&m.some(E=>E.idx===V)){let E=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${V}`;f.retrieval_hint=E,Object.keys(L).length>0&&typeof w.role!="string"&&(f.payload={...L,retrieval_hint:E});}}return f});return {cardId:r,messages:typeof c=="number"&&c>=0?M.slice(-c):M}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let a=n(await T(p,r)),o=y(n(a.card_data).files).map(n);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let i=o[t],c=typeof i.stored_name=="string"?i.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:x({cardId:r,fileIdx:t,storedName:c}),...typeof i.name=="string"?{name:i.name}:{},...typeof i.stored_name=="string"?{stored_name:i.stored_name}:{},...typeof i.mime_type=="string"?{mime_type:i.mime_type}:{},...typeof i.size=="number"?{size:i.size}:{},...typeof i.uploaded_at=="string"?{uploaded_at:i.uploaded_at}:{}}}async function $(e){return await u.validateCardPreflight({body:ke(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=u.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=n(G(r,"evalCardCompute")),a=n(e.candidateCardContent),o={card_data:n(a.card_data),requires:n(e.mockRequires),fetched_sources:n(e.mockFetchedSources),computed_values:n(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof a.id=="string"?a.id:"(unknown)",ok:t.ok===true,computed_values:n(t.computed_values),errors:y(t.errors).map(i=>{let c=n(i);return {bindTo:typeof c.bindTo=="string"?c.bindTo:"",error:typeof c.error=="string"?c.error:""}}),provides_outputs:Q(a,o),rendered_view:z(a,o)}}}async function ae(e){return await u.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await u.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=n(await T(p,r)),a$1=y(t.source_defs).filter(i=>!!i&&typeof i=="object"&&!Array.isArray(i)),o={};if(e.sourceIdx>=0&&e.sourceIdx<a$1.length){let i=a$1[e.sourceIdx],c=a.enrichSourcesSync([i],{card_data:n(t.card_data),requires:e.mockRequires});Array.isArray(c)&&c.length>0&&(o=n(c[0]._projections));}return await u.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=n(await A(u.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=n(e.candidateCardContent),a=n(r.validation),o=y(r.source_probes),i=y(r.projection_errors),c=n(r.fetched_sources),l=y(r.compute_errors),I=n(r.computed_values),v={card_data:n(t.card_data),requires:e.mockRequires,fetched_sources:c,computed_values:I},_=[];for(let m of y(a.issues))typeof m=="string"&&m&&_.push(m);for(let m of o){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.error=="string"?C.error:"";w&&_.push(`${M}: ${w}`);}for(let m of i){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.key=="string"?C.key:"projection",U=typeof C.error=="string"?C.error:"projection failed";_.push(`${M}.${w}: ${U}`);}for(let m of l){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"compute",w=typeof C.error=="string"?C.error:"compute failed";_.push(`${M}: ${w}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:_,provides_outputs:Q(t,v),rendered_view:z(t,v)}}}async function K(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await A(p.get({params:{id:r}}),"cardStore.get");return (Array.isArray(t.cards)?t.cards.map(n):[]).map(o=>j(o))}async function W(e){let r=await Promise.all(y(e.files).map(async t=>{let a=n(t),o=String(a.file_name??a.fileName??a.name??"").trim(),i=String(a.content_type??a.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await k({cardId:e.cardId,fileName:o,contentType:i,bytes:X(a),suppressChatRecordWrite:true})}));for(let[t,a]of r.entries()){let o=n(a.file),i=typeof a.file_idx=="number"&&Number.isInteger(a.file_idx)&&a.file_idx>=0?a.file_idx:t,c=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`;P(await g.append({params:{cardId:e.cardId},body:{role:"system",text:c,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}return r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",a=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await W({cardId:r,role:t,turn:a,files:e.files});return {status:"success",data:{cardId:r,turn:a,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),a=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let l=P(await g.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),I=Array.isArray(l.records)?l.records.find(v=>v.role==="assistant"&&String(v.turn||"")===o):void 0;if(I)return {status:"success",data:{cardId:r,id:String(I.id),role:t,turn:o,files:Array.isArray(I.files)?I.files:[]}}}let i=await W({cardId:r,role:t,turn:o,files:e.files}),c=P(await g.append({params:{cardId:r},body:{role:t,text:a,files:i,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(c.id),role:t,turn:o,files:i}}}async function ue(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.patch);if(!t)throw new Error("managePatchCard requires cardId");let o=await K({cardId:t}),i=n(o[0]),c=ve(i,a);return J({cardId:t,candidateCardContent:c},r)}async function J(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.candidateCardContent),o=j(a);if(!t)throw new Error("manageUpsertCard requires cardId");if(typeof o.id!="string"||!o.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(o.id!==t)throw new Error(`candidateCardContent.id must match cardId (${t})`);let i=null;try{i=await $({candidateCardContent:o});}catch(m){let C=m instanceof Error?m.message:String(m);if(!/non-core adapter is not configured/i.test(C))throw m;i=null;}if(i!==null){let m=n(i),C=n(m.data);if(m.status!=="success"||C.isValid!==true)return {status:"fail",step:"validate",validation:i}}let c=null;try{c=await T(p,t);}catch{c=null;}let l=c?n(c):null;if(l&&D(l)&&!r.allowControlplaneOnlyCards)throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404});let I={...o,...l&&he(l,"__private")?{__private:l.__private}:{}},v=await p.set({body:I});P(v,"cardStore.set");let _;try{_=await d.upsertCard({params:{cardId:t,restart:!0}}),P(_,"upsertCard");}catch(m){try{c&&await p.set({body:c});}catch{}throw m}return {status:"success",data:{validation:i,card_saved:null,board_result:_}}}async function le(e,r={}){let t=String(e.cardId||"").trim();if(!t)throw new Error("manageRemoveCard requires cardId");if(!r.allowControlplaneOnlyCards){let i=await A(p.get({params:{id:t}}),"cardStore.get");if((Array.isArray(i.cards)?i.cards.map(n):[]).some(D))throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404})}let a=await d.removeCard({params:{id:t}});P(a,"removeCard");let o=await p.del({params:{id:t}});return P(o,"cardStore.del"),{status:"success",data:{board_result:a,store_result:o}}}async function pe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await A(p.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(a=>n(a)):[]}async function me(e){let r=String(e.cardId||"").trim(),t=n(e.candidateCardContent),a=j(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof a.id!="string"||!a.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(a.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:a}),i=n(o),c=n(i.data);if(i.status!=="success"||c.isValid!==true)return {status:"fail",step:"validate",validation:o};let l=null;try{l=await T(p,r);}catch{l=null;}let I=l?n(n(l).__private):{},v={...a,__private:{...I,visible_controlplane_only:true}},_=await p.set({body:v});P(_,"cardStore.set");let m;try{m=await d.upsertCard({params:{cardId:r,restart:!0}}),P(m,"upsertCard");}catch(C){try{l&&await p.set({body:l});}catch{}throw C}return {status:"success",data:{validation:o,card_saved:null,board_result:m}}}async function fe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=G(await g.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}async function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return P(await g.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function Ce(){let e=await B(h,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function we(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let a=await B(R,"webhook.source-fetch-done")({token:r,ref:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let a=await B(b,"webhook.source-fetch-failed")({token:r,reason:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}return {listRuntimeCards:q,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:$,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:K,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:J,manageRemoveCard:le,adminReadCard:pe,adminUpsertCard:me,getChatProcessing:fe,setChatProcessing:ge,webhookProcessAccumulated:Ce,webhookSourceFetchDone:we,webhookSourceFetchFailed:ye}}async function A(s,d){return P(await s,d)}export{Ae as a};//# sourceMappingURL=chunk-6M3RIGUH.js.map
2
- //# sourceMappingURL=chunk-6M3RIGUH.js.map
1
+ import {a}from'./chunk-YOY2JM5N.js';function P(s,d){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function G(s,d){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${d} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function n(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function y(s){return Array.isArray(s)?s:[]}function N(s,d){if(typeof d!="string"||d.length===0)return;let u=s,p=d;p.startsWith("fetched_sources.")&&(u=n(s).fetched_sources,p=p.slice(16));for(let g of p.split(".")){if(u==null||typeof u!="object")return;u=u[g];}return u}function z(s,d){let u=n(s.view);return {elements:y(u.elements).map((g,h)=>{let R=n(g),b=n(R.data),k=typeof R.visible=="string"?!!N(d,R.visible):true,x=typeof b.bind=="string"?b.bind:void 0,S=typeof b.maxRows=="number"?b.maxRows:void 0,B=x?N(d,x):void 0,q={id:typeof R.id=="string"&&R.id?R.id:`element-${h}`,kind:R.kind,label:R.label,visible:k};return B!==void 0&&(q.resolved=Array.isArray(B)&&typeof S=="number"?B.slice(0,S):B),q})}}function Q(s,d){let u=typeof s.id=="string"&&s.id?s.id:"card",p=y(s.provides),g=p.length>0?p:[{bindTo:u,ref:"card_data"}],h={};for(let R of g){let b=n(R),k=typeof b.bindTo=="string"?b.bindTo:"",x=typeof b.ref=="string"?b.ref:"";if(!k||!x)continue;let S=N(d,x);S!==void 0&&(h[k]=S);}return h}function be(s){if(typeof s!="string"||!s.trim())return null;let d=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!d)return null;let u=Number.parseInt(d[2],10);return !Number.isInteger(u)||u<0?null:u}function ke(s){return {"card-content":s}}function j(s){let d={...s};return delete d.__private,d}function he(s,d){return Object.prototype.hasOwnProperty.call(s,d)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,d){let u=Re(s);if(!d||Object.keys(d).length===0)return u;function p(g,h,R){let b=String(h||"").split(".").filter(Boolean);if(!b.length)return;let k=g;for(let x=0;x<b.length-1;x+=1){let S=b[x];(!k[S]||typeof k[S]!="object")&&(k[S]={}),k=k[S];}k[b[b.length-1]]=R;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let g=null,h=n(u.view),R=y(h.elements);for(let b of R){let k=n(n(b).data);if(typeof k.writeTo=="string"&&k.writeTo){g=k.writeTo;break}}return g?p(u,g,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(u.card_data={...n(u.card_data),...d.fieldValues}),u}if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return u;for(let[g,h]of Object.entries(d))g!=="_stagedFiles"&&(h!==null&&typeof h=="object"&&!Array.isArray(h)&&u[g]!==null&&typeof u[g]=="object"&&!Array.isArray(u[g])?u[g]={...u[g],...h}:u[g]=h);return u}function D(s){return n(s.__private).visible_controlplane_only===true}async function T(s,d){let u=await A(s.get({params:{id:d}}),"cardStore.get"),p=Array.isArray(u?.cards)?u.cards:[];if(p.length===0)throw new Error(`Card "${d}" not found`);return p[0]}function Ae(s){let{board:d,nonCore:u,cardStore:p,chatStore:g,processAccumulated:h,sourceFetchDone:R,sourceFetchFailed:b,uploadCardFile:k,buildFileDownloadUrl:x,readFetchedSourceJsonByRef:S}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function q(){let e=await A(p.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>n(r)).filter(r=>!D(r)):[]}function X(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),a=atob(t);return Uint8Array.from(a,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=n(await A(u.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:n(e.commonSourceDefFields),sourceKinds:n(e.sourceKinds)}}async function Z(){let e=n(await A(d.status({}),"status")),r=n(e.summary),t=y(e.cards),a=await A(p.get({}),"cardStore.get"),o=new Set((Array.isArray(a.cards)?a.cards.map(n):[]).filter(D).map(c=>typeof c.id=="string"?c.id:"").filter(Boolean)),i=t.filter(c=>!o.has(String(n(c).name??"")));return {meta:n(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:i.map(c=>{let l=n(c);return {"card-id":typeof l.name=="string"?l.name:null,status:l.status??null,error:l.error??null,requires:y(l.requires),requires_satisfied:y(l.requires_satisfied),requires_missing:y(l.requires_missing),provides_declared:y(l.provides_declared),provides_runtime:y(l.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=n(await A(d.status({}),"status")),o=y(t.cards).map(n).find(f=>f.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let i=n(await T(p,r)),c=j(i),l=y(o.requires_satisfied).filter(f=>typeof f=="string"&&!!f),I=y(o.provides_runtime).filter(f=>typeof f=="string"&&!!f),v=Object.fromEntries(await Promise.all(l.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),_=Object.fromEntries(await Promise.all(I.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),m=n(await A(d.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),C=await A(d.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),M=y(i.source_defs).map(n),w={};for(let f of M)typeof f.bindTo=="string"&&typeof f.outputFile=="string"&&(w[f.outputFile]=f.bindTo);let U={};for(let[f,F]of Object.entries(C)){let O=w[f]??f;if(!S||typeof F!="string"){U[O]=null;continue}try{U[O]=S({cardId:r,ref:F});}catch{U[O]=null;}}let L={card_data:n(i.card_data),requires:v,fetched_sources:U,computed_values:m};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:c,refs_for_fetched_source_files:C,runtime_data:{requires:v,provides:_,computed_values:m,rendered_view:z(i,L)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",a=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",i=a?void 0:e.lastUserTurns??(t?void 0:1),c=e.tail,l={...i===void 0?{}:{tailTurns:i},...t?{turnId:t}:{},...a?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},I=Object.keys(l).length>0?{params:{cardId:r},body:l}:{params:{cardId:r}},v=P(await g.readAll(I),"chatStore.readAll"),_=n(await T(p,r)),m=y(n(_.card_data).files).map((w,U)=>({idx:U,stored_name:n(w).stored_name})).filter(w=>typeof w.stored_name=="string"&&w.stored_name.length>0),M=(Array.isArray(v.records)?v.records:[]).map(w=>{let L=n(w.payload),f={...w},F=typeof w?.role=="string"?w.role:typeof L.role=="string"?String(L.role):"",O=typeof w?.text=="string"?w.text:typeof L.text=="string"?String(L.text):"";if(F==="system"){let V=be(O);if(V!==null&&m.some(E=>E.idx===V)){let E=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${V}`;f.retrieval_hint=E,Object.keys(L).length>0&&typeof w.role!="string"&&(f.payload={...L,retrieval_hint:E});}}return f});return {cardId:r,messages:typeof c=="number"&&c>=0?M.slice(-c):M}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let a=n(await T(p,r)),o=y(n(a.card_data).files).map(n);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let i=o[t],c=typeof i.stored_name=="string"?i.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:x({cardId:r,fileIdx:t,storedName:c}),...typeof i.name=="string"?{name:i.name}:{},...typeof i.stored_name=="string"?{stored_name:i.stored_name}:{},...typeof i.mime_type=="string"?{mime_type:i.mime_type}:{},...typeof i.size=="number"?{size:i.size}:{},...typeof i.uploaded_at=="string"?{uploaded_at:i.uploaded_at}:{}}}async function $(e){return await u.validateCardPreflight({body:ke(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=u.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=n(G(r,"evalCardCompute")),a=n(e.candidateCardContent),o={card_data:n(a.card_data),requires:n(e.mockRequires),fetched_sources:n(e.mockFetchedSources),computed_values:n(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof a.id=="string"?a.id:"(unknown)",ok:t.ok===true,computed_values:n(t.computed_values),errors:y(t.errors).map(i=>{let c=n(i);return {bindTo:typeof c.bindTo=="string"?c.bindTo:"",error:typeof c.error=="string"?c.error:""}}),provides_outputs:Q(a,o),rendered_view:z(a,o)}}}async function ae(e){return await u.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await u.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=n(await T(p,r)),a$1=y(t.source_defs).filter(i=>!!i&&typeof i=="object"&&!Array.isArray(i)),o={};if(e.sourceIdx>=0&&e.sourceIdx<a$1.length){let i=a$1[e.sourceIdx],c=a.enrichSourcesSync([i],{card_data:n(t.card_data),requires:e.mockRequires});Array.isArray(c)&&c.length>0&&(o=n(c[0]._projections));}return await u.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=n(await A(u.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=n(e.candidateCardContent),a=n(r.validation),o=y(r.source_probes),i=y(r.projection_errors),c=n(r.fetched_sources),l=y(r.compute_errors),I=n(r.computed_values),v={card_data:n(t.card_data),requires:e.mockRequires,fetched_sources:c,computed_values:I},_=[];for(let m of y(a.issues))typeof m=="string"&&m&&_.push(m);for(let m of o){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.error=="string"?C.error:"";w&&_.push(`${M}: ${w}`);}for(let m of i){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.key=="string"?C.key:"projection",U=typeof C.error=="string"?C.error:"projection failed";_.push(`${M}.${w}: ${U}`);}for(let m of l){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"compute",w=typeof C.error=="string"?C.error:"compute failed";_.push(`${M}: ${w}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:_,provides_outputs:Q(t,v),rendered_view:z(t,v)}}}async function K(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await A(p.get({params:{id:r}}),"cardStore.get");return (Array.isArray(t.cards)?t.cards.map(n):[]).map(o=>j(o))}async function W(e){let r=await Promise.all(y(e.files).map(async t=>{let a=n(t),o=String(a.file_name??a.fileName??a.name??"").trim(),i=String(a.content_type??a.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await k({cardId:e.cardId,fileName:o,contentType:i,bytes:X(a),suppressChatRecordWrite:true})}));for(let[t,a]of r.entries()){let o=n(a.file),i=typeof a.file_idx=="number"&&Number.isInteger(a.file_idx)&&a.file_idx>=0?a.file_idx:t,c=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`;P(await g.append({params:{cardId:e.cardId},body:{role:"system",text:c,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}return r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",a=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await W({cardId:r,role:t,turn:a,files:e.files});return {status:"success",data:{cardId:r,turn:a,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),a=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let l=P(await g.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),I=Array.isArray(l.records)?l.records.find(v=>v.role==="assistant"&&String(v.turn||"")===o):void 0;if(I)return {status:"success",data:{cardId:r,id:String(I.id),role:t,turn:o,files:Array.isArray(I.files)?I.files:[]}}}let i=await W({cardId:r,role:t,turn:o,files:e.files}),c=P(await g.append({params:{cardId:r},body:{role:t,text:a,files:i,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(c.id),role:t,turn:o,files:i}}}async function ue(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.patch);if(!t)throw new Error("managePatchCard requires cardId");let o=await K({cardId:t}),i=n(o[0]),c=ve(i,a);return J({cardId:t,candidateCardContent:c},r)}async function J(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.candidateCardContent),o=j(a);if(!t)throw new Error("manageUpsertCard requires cardId");if(typeof o.id!="string"||!o.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(o.id!==t)throw new Error(`candidateCardContent.id must match cardId (${t})`);let i=null;try{i=await $({candidateCardContent:o});}catch(m){let C=m instanceof Error?m.message:String(m);if(!/non-core adapter is not configured/i.test(C))throw m;i=null;}if(i!==null){let m=n(i),C=n(m.data);if(m.status!=="success"||C.isValid!==true)return {status:"fail",step:"validate",validation:i}}let c=null;try{c=await T(p,t);}catch{c=null;}let l=c?n(c):null;if(l&&D(l)&&!r.allowControlplaneOnlyCards)throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404});let I={...o,...l&&he(l,"__private")?{__private:l.__private}:{}},v=await p.set({body:I});P(v,"cardStore.set");let _;try{_=await d.upsertCard({params:{cardId:t,restart:!0}}),P(_,"upsertCard");}catch(m){try{c&&await p.set({body:c});}catch{}throw m}return {status:"success",data:{validation:i,card_saved:null,board_result:_}}}async function le(e,r={}){let t=String(e.cardId||"").trim();if(!t)throw new Error("manageRemoveCard requires cardId");if(!r.allowControlplaneOnlyCards){let i=await A(p.get({params:{id:t}}),"cardStore.get");if((Array.isArray(i.cards)?i.cards.map(n):[]).some(D))throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404})}let a=await d.removeCard({params:{id:t}});P(a,"removeCard");let o=await p.del({params:{id:t}});return P(o,"cardStore.del"),{status:"success",data:{board_result:a,store_result:o}}}async function pe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await A(p.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(a=>n(a)):[]}async function me(e){let r=String(e.cardId||"").trim(),t=n(e.candidateCardContent),a=j(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof a.id!="string"||!a.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(a.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:a}),i=n(o),c=n(i.data);if(i.status!=="success"||c.isValid!==true)return {status:"fail",step:"validate",validation:o};let l=null;try{l=await T(p,r);}catch{l=null;}let I=l?n(n(l).__private):{},v={...a,__private:{...I,visible_controlplane_only:true}},_=await p.set({body:v});P(_,"cardStore.set");let m;try{m=await d.upsertCard({params:{cardId:r,restart:!0}}),P(m,"upsertCard");}catch(C){try{l&&await p.set({body:l});}catch{}throw C}return {status:"success",data:{validation:o,card_saved:null,board_result:m}}}async function fe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=G(await g.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}async function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return P(await g.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function Ce(){let e=await B(h,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function we(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let a=await B(R,"webhook.source-fetch-done")({token:r,ref:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let a=await B(b,"webhook.source-fetch-failed")({token:r,reason:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}return {listRuntimeCards:q,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:$,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:K,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:J,manageRemoveCard:le,adminReadCard:pe,adminUpsertCard:me,getChatProcessing:fe,setChatProcessing:ge,webhookProcessAccumulated:Ce,webhookSourceFetchDone:we,webhookSourceFetchFailed:ye}}async function A(s,d){return P(await s,d)}export{Ae as a};//# sourceMappingURL=chunk-NN52BT3Q.js.map
2
+ //# sourceMappingURL=chunk-NN52BT3Q.js.map
@@ -1,3 +1,3 @@
1
- 'use strict';var chunkLFVMX23W_cjs=require('./chunk-LFVMX23W.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunkNOAERAOE_cjs=require('./chunk-NOAERAOE.cjs'),chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkK5TEZRZK_cjs=require('./chunk-K5TEZRZK.cjs'),chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs'),chunk3XPY7CCM_cjs=require('./chunk-3XPY7CCM.cjs'),chunkJ7KE7SPA_cjs=require('./chunk-J7KE7SPA.cjs'),chunkSDJ3747Q_cjs=require('./chunk-SDJ3747Q.cjs'),chunkOF4FPYNI_cjs=require('./chunk-OF4FPYNI.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');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=chunkLPXVVMQT_cjs.a(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=chunkLPXVVMQT_cjs.c(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 chunk272IYUKT_cjs.a(y,k,$());if(u&&typeof u=="object"&&!Array.isArray(u)){let P=u;if(P.status==="fail")return b(S,400,{error:chunk272IYUKT_cjs.b(u,"Request failed")}),!0;if(P.status==="error")return b(S,500,{error:chunk272IYUKT_cjs.b(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(`^${chunkBQUQTOPB_cjs.c(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(`^${chunkBQUQTOPB_cjs.c(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(`^${chunkBQUQTOPB_cjs.c(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}=chunkNOAERAOE_cjs.b(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){let w=String(g.apiBasePath||"/api/board").replace(/\/$/,""),b={...le,...g.corsHeaders||{}},I=g.queueLaneTuning??{},B=g.boardId||"",$=Number.isInteger(g.chatBootstrapTailTurns)&&g.chatBootstrapTailTurns>0?g.chatBootstrapTailTurns:1,N=g.logger||{info:console.log,warn:console.warn,error:console.error},x=g.invocationAdapter,_=g.chatFlowRunner||null,H=g.notificationTransport||null,E=g.serverUrl||null,T=g.executionExtra||{},S=g.onSseClientConnected,z=g.onSseClientDisconnected,q=g.onChannelSubscribed,K=g.onChannelUnsubscribed,l=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async(t,e)=>await Q.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:z}),R=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function F(t){function e(a){return {...a,queueStorageForRef(d,C){return chunkSDJ3747Q_cjs.a(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}function r(a){return {...a,queueStorageForRef(d,C){return chunkK5TEZRZK_cjs.h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}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(a){if(a.kind==="notification-batch"){V(a.notifications,s??void 0);return}V([a],s??void 0);}let c=chunkBQUQTOPB_cjs.a(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),j=t.nonCoreAdapter??(!chunkBQUQTOPB_cjs.a(c)&&P(c)?c:null),h=chunkBQUQTOPB_cjs.a(c)?chunkK5TEZRZK_cjs.i(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}):chunk3XPY7CCM_cjs.e(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}),M=t.nonCore??(j?chunk3XPY7CCM_cjs.f(t.baseRef,j,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),We=c.chatStorageForRef(t.chatStoreRef),lt,Je=chunkBQUQTOPB_cjs.a(c)?(()=>{let a=chunkK5TEZRZK_cjs.d(chunkK5TEZRZK_cjs.c(chunkK5TEZRZK_cjs.b(c.kvStorageForRef(t.cardStoreRef)),c.hashFn),N.warn),d=chunkK5TEZRZK_cjs.g(a,{emitNotification:i}),C=o(d);return lt={get(m){return C.get(m)},set(m){return C.set(m)}},C})():(()=>{let a=c.kvStorageForRef(t.cardStoreRef),C=chunkJ7KE7SPA_cjs.H(chunkJ7KE7SPA_cjs.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});return lt=C,n(C)})(),ft;if(chunkBQUQTOPB_cjs.a(c)){let a=c.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.blobStorageForRef(t.artifactsStoreRef),d=chunkNBJTYAYN_cjs.a(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.init(a)},async status(a){return h.status(a)},async getConfig(a){return h.getConfig(a)},async getAllOutputsDataObjects(a){return h.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return h.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return h.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return h.buildSseOneShotPayload(a)},async upsertCard(a){return h.upsertCard(a)},async removeCard(a){return h.removeCard(a)},async sourceDataFetched(a){return h.sourceDataFetched(a)},async sourceDataFetchFailure(a){return h.sourceDataFetchFailure(a)}};return s={label:t.label,board:h,nonCore:M,publicCardStore:lt,boardOps:ze,cardStoreOps:Je,get filesArtifacts(){return ft},get chatStorage(){return We},boardAdapter:c,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:chunkNOAERAOE_cjs.c(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let p=g.boards.map(F),f=new Map;function y(t){return f.get(t)??0}function k(t){return t.queueStoreRef}function u(t,e){if(chunkBQUQTOPB_cjs.a(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(k(t),e);return chunkCSHNTZW4_cjs.a(n)}let r=t.boardAdapter.queueStorageForRef(k(t),e);return chunkGPCMBPLK_cjs.a(r)}function P(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function v(t){let e=p[y(t)];return {files:e?e.filesArtifacts:null}}function A(){return chunkNBJTYAYN_cjs.c()}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[0]??void 0}function U(t){for(let e of t){let r=O(e);if(r)return r}return p[0]??void 0}function ct(t,e={}){if(!t||t.length===0)return;let r=chunk2RIHC5TZ_cjs.e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??U(r);if(e.appendState!==false&&o&&chunkNOAERAOE_cjs.e(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.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||!t.notifyRef)return;let e=await H.subscribe(t.notifyRef,r=>{let n=chunkNOAERAOE_cjs.a(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&&chunkNOAERAOE_cjs.d(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.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of p)await pe(t);}async function at(){await G();for(let t=0;t<p.length;t++)await ut(p[t]),await Rt(p[t],t),await ut(p[t]);}async function yt(t=false){t||await G();for(let e of p){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function W(t){return p[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)e.push(...await t(r));return e}function ht(){return p[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=chunkOF4FPYNI_cjs.a({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=chunkNOAERAOE_cjs.p({boardContexts:p,cardOwnerIndex:f,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=chunkNOAERAOE_cjs.j({boardId:B,bootstrapBoard:()=>at(),sseHub:l,onChannelSubscribed:q,onChannelUnsubscribed:K,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>ye()});function we(t){return chunkNOAERAOE_cjs.m(t)}function be(){return chunkNOAERAOE_cjs.n(st())}function bt(){return chunkNOAERAOE_cjs.o({boardId:B,uploadCardFile:Ct,getMcpFacade:()=>st(),controlplane:he})}let it=chunkNOAERAOE_cjs.k({boardId:B,boardContexts:p,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=chunkNOAERAOE_cjs.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;chunkBQUQTOPB_cjs.a(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"&&chunkBQUQTOPB_cjs.b(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 chunk272IYUKT_cjs.a("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(chunk272IYUKT_cjs.b(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 chunk272IYUKT_cjs.a("setstate.chat-processing-started",{board_id:B,card_id:t},s);if(M?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(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,"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(chunkBQUQTOPB_cjs.d(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[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[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let Ie=chunkLFVMX23W_cjs.b({sseHub:l,queueSseHub:R,corsHeaders:b,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:S,onChannelSubscribed:q,onChannelUnsubscribed:K,apiBasePath:w,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>at(),boardContexts:p,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=chunk7FGPOGRV_cjs.a({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=chunkNM6O35RY_cjs.a({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},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[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(chunkBQUQTOPB_cjs.d(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(`^${chunkBQUQTOPB_cjs.c(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}}exports.a=Mr;exports.b=_r;//# sourceMappingURL=chunk-TUQ6JBER.cjs.map
3
- //# sourceMappingURL=chunk-TUQ6JBER.cjs.map
1
+ 'use strict';var chunkLFVMX23W_cjs=require('./chunk-LFVMX23W.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunk36KKCQVE_cjs=require('./chunk-36KKCQVE.cjs'),chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkMRIFSG7L_cjs=require('./chunk-MRIFSG7L.cjs'),chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs'),chunkEGZPROOH_cjs=require('./chunk-EGZPROOH.cjs'),chunkJOQWJ3VR_cjs=require('./chunk-JOQWJ3VR.cjs'),chunkSDJ3747Q_cjs=require('./chunk-SDJ3747Q.cjs'),chunkOF4FPYNI_cjs=require('./chunk-OF4FPYNI.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');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=chunkLPXVVMQT_cjs.a(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=chunkLPXVVMQT_cjs.c(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 chunk272IYUKT_cjs.a(y,k,$());if(u&&typeof u=="object"&&!Array.isArray(u)){let P=u;if(P.status==="fail")return b(S,400,{error:chunk272IYUKT_cjs.b(u,"Request failed")}),!0;if(P.status==="error")return b(S,500,{error:chunk272IYUKT_cjs.b(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(`^${chunkBQUQTOPB_cjs.c(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(`^${chunkBQUQTOPB_cjs.c(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(`^${chunkBQUQTOPB_cjs.c(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}=chunk36KKCQVE_cjs.b(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){let w=String(g.apiBasePath||"/api/board").replace(/\/$/,""),b={...le,...g.corsHeaders||{}},I=g.queueLaneTuning??{},B=g.boardId||"",$=Number.isInteger(g.chatBootstrapTailTurns)&&g.chatBootstrapTailTurns>0?g.chatBootstrapTailTurns:1,N=g.logger||{info:console.log,warn:console.warn,error:console.error},x=g.invocationAdapter,_=g.chatFlowRunner||null,H=g.notificationTransport||null,E=g.serverUrl||null,T=g.executionExtra||{},S=g.onSseClientConnected,z=g.onSseClientDisconnected,q=g.onChannelSubscribed,K=g.onChannelUnsubscribed,l=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async(t,e)=>await Q.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:z}),R=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function F(t){function e(a){return {...a,queueStorageForRef(d,C){return chunkSDJ3747Q_cjs.a(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}function r(a){return {...a,queueStorageForRef(d,C){return chunkMRIFSG7L_cjs.h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}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(a){if(a.kind==="notification-batch"){V(a.notifications,s??void 0);return}V([a],s??void 0);}let c=chunkBQUQTOPB_cjs.a(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),j=t.nonCoreAdapter??(!chunkBQUQTOPB_cjs.a(c)&&P(c)?c:null),h=chunkBQUQTOPB_cjs.a(c)?chunkMRIFSG7L_cjs.i(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}):chunkEGZPROOH_cjs.e(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}),M=t.nonCore??(j?chunkEGZPROOH_cjs.f(t.baseRef,j,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),We=c.chatStorageForRef(t.chatStoreRef),lt,Je=chunkBQUQTOPB_cjs.a(c)?(()=>{let a=chunkMRIFSG7L_cjs.d(chunkMRIFSG7L_cjs.c(chunkMRIFSG7L_cjs.b(c.kvStorageForRef(t.cardStoreRef)),c.hashFn),N.warn),d=chunkMRIFSG7L_cjs.g(a,{emitNotification:i}),C=o(d);return lt={get(m){return C.get(m)},set(m){return C.set(m)}},C})():(()=>{let a=c.kvStorageForRef(t.cardStoreRef),C=chunkJOQWJ3VR_cjs.H(chunkJOQWJ3VR_cjs.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});return lt=C,n(C)})(),ft;if(chunkBQUQTOPB_cjs.a(c)){let a=c.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.blobStorageForRef(t.artifactsStoreRef),d=chunkNBJTYAYN_cjs.a(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.init(a)},async status(a){return h.status(a)},async getConfig(a){return h.getConfig(a)},async getAllOutputsDataObjects(a){return h.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return h.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return h.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return h.buildSseOneShotPayload(a)},async upsertCard(a){return h.upsertCard(a)},async removeCard(a){return h.removeCard(a)},async sourceDataFetched(a){return h.sourceDataFetched(a)},async sourceDataFetchFailure(a){return h.sourceDataFetchFailure(a)}};return s={label:t.label,board:h,nonCore:M,publicCardStore:lt,boardOps:ze,cardStoreOps:Je,get filesArtifacts(){return ft},get chatStorage(){return We},boardAdapter:c,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:chunk36KKCQVE_cjs.c(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let p=g.boards.map(F),f=new Map;function y(t){return f.get(t)??0}function k(t){return t.queueStoreRef}function u(t,e){if(chunkBQUQTOPB_cjs.a(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(k(t),e);return chunkCSHNTZW4_cjs.a(n)}let r=t.boardAdapter.queueStorageForRef(k(t),e);return chunkGPCMBPLK_cjs.a(r)}function P(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function v(t){let e=p[y(t)];return {files:e?e.filesArtifacts:null}}function A(){return chunkNBJTYAYN_cjs.c()}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[0]??void 0}function U(t){for(let e of t){let r=O(e);if(r)return r}return p[0]??void 0}function ct(t,e={}){if(!t||t.length===0)return;let r=chunk2RIHC5TZ_cjs.e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??U(r);if(e.appendState!==false&&o&&chunk36KKCQVE_cjs.e(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.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||!t.notifyRef)return;let e=await H.subscribe(t.notifyRef,r=>{let n=chunk36KKCQVE_cjs.a(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&&chunk36KKCQVE_cjs.d(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.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of p)await pe(t);}async function at(){await G();for(let t=0;t<p.length;t++)await ut(p[t]),await Rt(p[t],t),await ut(p[t]);}async function yt(t=false){t||await G();for(let e of p){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function W(t){return p[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)e.push(...await t(r));return e}function ht(){return p[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=chunkOF4FPYNI_cjs.a({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=chunk36KKCQVE_cjs.p({boardContexts:p,cardOwnerIndex:f,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=chunk36KKCQVE_cjs.j({boardId:B,bootstrapBoard:()=>at(),sseHub:l,onChannelSubscribed:q,onChannelUnsubscribed:K,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>ye()});function we(t){return chunk36KKCQVE_cjs.m(t)}function be(){return chunk36KKCQVE_cjs.n(st())}function bt(){return chunk36KKCQVE_cjs.o({boardId:B,uploadCardFile:Ct,getMcpFacade:()=>st(),controlplane:he})}let it=chunk36KKCQVE_cjs.k({boardId:B,boardContexts:p,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=chunk36KKCQVE_cjs.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;chunkBQUQTOPB_cjs.a(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"&&chunkBQUQTOPB_cjs.b(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 chunk272IYUKT_cjs.a("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(chunk272IYUKT_cjs.b(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 chunk272IYUKT_cjs.a("setstate.chat-processing-started",{board_id:B,card_id:t},s);if(M?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(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,"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(chunkBQUQTOPB_cjs.d(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[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[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let Ie=chunkLFVMX23W_cjs.b({sseHub:l,queueSseHub:R,corsHeaders:b,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:S,onChannelSubscribed:q,onChannelUnsubscribed:K,apiBasePath:w,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>at(),boardContexts:p,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=chunk7FGPOGRV_cjs.a({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=chunkNM6O35RY_cjs.a({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},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[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(chunkBQUQTOPB_cjs.d(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(`^${chunkBQUQTOPB_cjs.c(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}}exports.a=Mr;exports.b=_r;//# sourceMappingURL=chunk-OR6B2H2Y.cjs.map
3
+ //# sourceMappingURL=chunk-OR6B2H2Y.cjs.map