yaml-flow 8.6.4 → 8.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (173) hide show
  1. package/browser/adapters/firebase-storage.js +3 -0
  2. package/browser/adapters/firestore-storage.js +3 -0
  3. package/browser/adapters/localstorage-storage.js +4 -0
  4. package/browser/asset-integrity.json +22 -6
  5. package/browser/live-cards.schema.json +10 -1
  6. package/browser/server-runtime-controlface.js +8 -0
  7. package/examples/ARCHITECTURE.md +5 -32
  8. package/examples/board/demo-shell-with-server.html +2 -2
  9. package/examples/board/doc.html +2 -2
  10. package/examples/board/server/board-server.js +4 -2
  11. package/examples/board/test/server-http-test.js +73 -79
  12. package/examples/board-firestore/README.md +81 -0
  13. package/examples/board-firestore/browser/board-runtime.js +263 -0
  14. package/examples/board-firestore/firestore.indexes.json +29 -0
  15. package/examples/board-firestore/package.json +14 -0
  16. package/examples/board-firestore/server/adapters/firestore-archive-factory.js +59 -0
  17. package/examples/board-firestore/server/adapters/firestore-blob-storage.js +82 -0
  18. package/examples/board-firestore/server/adapters/firestore-board-adapter.js +127 -0
  19. package/examples/board-firestore/server/adapters/firestore-journal-storage.js +54 -0
  20. package/examples/board-firestore/server/adapters/firestore-kv-storage.js +47 -0
  21. package/examples/board-firestore/server/adapters/firestore-lock.js +62 -0
  22. package/examples/board-firestore/server/adapters/firestore-queue-storage.js +186 -0
  23. package/examples/board-firestore/server/adapters/firestore-scratch-storage.js +50 -0
  24. package/examples/board-firestore/server/worker.js +146 -0
  25. package/lib/{artifacts-store-lib-BR-Samty.d.cts → artifacts-store-lib-D9nMkVcE.d.cts} +1 -1
  26. package/lib/{artifacts-store-lib-DT7XlWUL.d.ts → artifacts-store-lib-DSSMqVL2.d.ts} +1 -1
  27. package/lib/artifacts-store-public.d.cts +2 -2
  28. package/lib/artifacts-store-public.d.ts +2 -2
  29. package/lib/board-live-cards-mcp.cjs +1 -1
  30. package/lib/board-live-cards-mcp.d.cts +51 -3
  31. package/lib/board-live-cards-mcp.d.ts +51 -3
  32. package/lib/board-live-cards-mcp.js +1 -1
  33. package/lib/board-live-cards-node.cjs +5 -5
  34. package/lib/board-live-cards-node.d.cts +16 -11
  35. package/lib/board-live-cards-node.d.ts +16 -11
  36. package/lib/board-live-cards-node.js +5 -5
  37. package/lib/{board-live-cards-public-BMUIPOrc.d.ts → board-live-cards-public-JNRKfBZy.d.ts} +1 -1
  38. package/lib/{board-live-cards-public-wkNmBIRC.d.cts → board-live-cards-public-LlVUQPL2.d.cts} +1 -1
  39. package/lib/board-live-cards-public-async-Di9QB141.d.cts +55 -0
  40. package/lib/board-live-cards-public-async-fwd1QI82.d.ts +55 -0
  41. package/lib/board-live-cards-public.cjs +1 -1
  42. package/lib/board-live-cards-public.d.cts +1 -1
  43. package/lib/board-live-cards-public.d.ts +1 -1
  44. package/lib/board-live-cards-public.js +1 -1
  45. package/lib/board-live-cards-server-runtime.cjs +1 -1
  46. package/lib/board-live-cards-server-runtime.d.cts +10 -6
  47. package/lib/board-live-cards-server-runtime.d.ts +10 -6
  48. package/lib/board-live-cards-server-runtime.js +1 -1
  49. package/lib/board-livegraph-runtime/index.cjs +1 -1
  50. package/lib/board-livegraph-runtime/index.js +1 -1
  51. package/lib/board-platform-adapter-async-BfHmHdx2.d.cts +129 -0
  52. package/lib/board-platform-adapter-async-DYahVzIK.d.ts +129 -0
  53. package/lib/board-worker-adapter.cjs +3 -3
  54. package/lib/board-worker-adapter.js +3 -3
  55. package/lib/card-compute/index.cjs +1 -1
  56. package/lib/card-compute/index.js +1 -1
  57. package/lib/card-store-public.d.cts +1 -1
  58. package/lib/card-store-public.d.ts +1 -1
  59. package/lib/card-validation.cjs +1 -1
  60. package/lib/card-validation.js +1 -1
  61. package/lib/{chat-storage-lib-BIUbE-fM.d.cts → chat-storage-lib-B9Q34Dyv.d.cts} +1 -1
  62. package/lib/{chat-storage-lib-BlG-sobS.d.ts → chat-storage-lib-DB9iSai2.d.ts} +1 -1
  63. package/lib/chat-store-public.d.cts +2 -2
  64. package/lib/chat-store-public.d.ts +2 -2
  65. package/lib/chunk-272IYUKT.cjs +2 -0
  66. package/lib/chunk-3KC6LBOG.js +3 -0
  67. package/lib/chunk-5XHOHTLZ.cjs +2 -0
  68. package/lib/chunk-6APH25VI.js +2 -0
  69. package/lib/chunk-76C7N4YT.js +3 -0
  70. package/lib/chunk-7FGPOGRV.cjs +2 -0
  71. package/lib/chunk-7ICPAABP.cjs +7 -0
  72. package/lib/chunk-ASR44K7H.cjs +3 -0
  73. package/lib/chunk-CPAXTVBQ.cjs +2 -0
  74. package/lib/chunk-EGRHWZRV.js +2 -0
  75. package/lib/chunk-EZENHAVZ.cjs +2 -0
  76. package/lib/chunk-FO4KNVU7.cjs +2 -0
  77. package/lib/chunk-GL2OHR2E.cjs +2 -0
  78. package/lib/chunk-HWYMZK3N.cjs +3 -0
  79. package/lib/chunk-IPLSRN6P.cjs +4 -0
  80. package/lib/{chunk-H5HBXPOI.cjs → chunk-J6EGN6S4.cjs} +3 -3
  81. package/lib/chunk-JH37NJGP.js +3 -0
  82. package/lib/chunk-JJL5VOQZ.cjs +3 -0
  83. package/lib/chunk-KAWQPLIE.cjs +2 -0
  84. package/lib/chunk-LPXVVMQT.cjs +2 -0
  85. package/lib/chunk-NJJ7WEDT.cjs +2 -0
  86. package/lib/chunk-NKIQRCOM.cjs +2 -0
  87. package/lib/chunk-NM6O35RY.cjs +2 -0
  88. package/lib/chunk-NTICU4OK.js +2 -0
  89. package/lib/chunk-O7NOHKVR.js +2 -0
  90. package/lib/chunk-PBOQ4HYB.cjs +2 -0
  91. package/lib/{chunk-VMW4Z6EF.js → chunk-PRKRXAVN.js} +3 -3
  92. package/lib/chunk-QJVR3FWQ.js +2 -0
  93. package/lib/chunk-S44QZUDX.js +2 -0
  94. package/lib/chunk-SGV7PU4H.js +2 -0
  95. package/lib/chunk-TSN3RTXT.js +4 -0
  96. package/lib/chunk-VXJHBWK3.js +2 -0
  97. package/lib/chunk-WHDEBJLT.js +7 -0
  98. package/lib/chunk-XYN5D3GL.js +2 -0
  99. package/lib/chunk-YBYXCFAI.js +2 -0
  100. package/lib/chunk-YGALANRO.js +2 -0
  101. package/lib/chunk-ZCNN6XPV.js +2 -0
  102. package/lib/chunk-ZJ5M5COT.js +2 -0
  103. package/lib/cloud-storage.cjs +1 -1
  104. package/lib/cloud-storage.d.cts +5 -3
  105. package/lib/cloud-storage.d.ts +5 -3
  106. package/lib/cloud-storage.js +1 -1
  107. package/lib/continuous-event-graph/index.cjs +1 -1
  108. package/lib/continuous-event-graph/index.js +1 -1
  109. package/lib/firebase-storage/index.cjs +3 -0
  110. package/lib/firebase-storage/index.d.cts +57 -0
  111. package/lib/firebase-storage/index.d.ts +57 -0
  112. package/lib/firebase-storage/index.js +3 -0
  113. package/lib/firestore-storage/index.cjs +3 -0
  114. package/lib/firestore-storage/index.d.cts +111 -0
  115. package/lib/firestore-storage/index.d.ts +111 -0
  116. package/lib/firestore-storage/index.js +3 -0
  117. package/lib/index.cjs +2 -2
  118. package/lib/index.js +1 -1
  119. package/lib/localstorage-storage/index.cjs +2 -0
  120. package/lib/localstorage-storage/index.d.cts +39 -0
  121. package/lib/localstorage-storage/index.d.ts +39 -0
  122. package/lib/localstorage-storage/index.js +2 -0
  123. package/lib/mcp-tool-registries-BBObLYga.d.ts +41 -0
  124. package/lib/mcp-tool-registries-W3TRj6O5.d.cts +41 -0
  125. package/lib/queue-lane-registry-PaZuFpwp.d.cts +30 -0
  126. package/lib/queue-lane-registry-PaZuFpwp.d.ts +30 -0
  127. package/lib/server-jobs-queue-runner/index.cjs +2 -0
  128. package/lib/server-jobs-queue-runner/index.d.cts +22 -0
  129. package/lib/server-jobs-queue-runner/index.d.ts +22 -0
  130. package/lib/server-jobs-queue-runner/index.js +2 -0
  131. package/lib/server-runtime/index.cjs +1 -1
  132. package/lib/server-runtime/index.d.cts +11 -17
  133. package/lib/server-runtime/index.d.ts +11 -17
  134. package/lib/server-runtime/index.js +1 -1
  135. package/lib/server-runtime-agentface/index.cjs +2 -0
  136. package/lib/server-runtime-agentface/index.d.cts +53 -0
  137. package/lib/server-runtime-agentface/index.d.ts +53 -0
  138. package/lib/server-runtime-agentface/index.js +2 -0
  139. package/lib/server-runtime-controlface/index.cjs +2 -0
  140. package/lib/server-runtime-controlface/index.d.cts +29 -0
  141. package/lib/server-runtime-controlface/index.d.ts +29 -0
  142. package/lib/server-runtime-controlface/index.js +2 -0
  143. package/lib/server-runtime-core/index.cjs +2 -0
  144. package/lib/server-runtime-core/index.d.cts +378 -0
  145. package/lib/server-runtime-core/index.d.ts +378 -0
  146. package/lib/server-runtime-core/index.js +2 -0
  147. package/lib/server-runtime-watchers/index.cjs +2 -0
  148. package/lib/server-runtime-watchers/index.d.cts +127 -0
  149. package/lib/server-runtime-watchers/index.d.ts +127 -0
  150. package/lib/server-runtime-watchers/index.js +2 -0
  151. package/lib/server-runtime-webhooks/index.cjs +2 -0
  152. package/lib/server-runtime-webhooks/index.d.cts +34 -0
  153. package/lib/server-runtime-webhooks/index.d.ts +34 -0
  154. package/lib/server-runtime-webhooks/index.js +2 -0
  155. package/lib/storage-async-interface-BRR4eBjx.d.cts +81 -0
  156. package/lib/storage-async-interface-DhlOVPSp.d.ts +81 -0
  157. package/lib/{queue-lane-registry-BPKWWgd4.d.cts → types-Ba8H5_Wo.d.cts} +10 -34
  158. package/lib/{queue-lane-registry-Be6c0ftj.d.ts → types-SO5OZm4s.d.ts} +10 -34
  159. package/package.json +46 -2
  160. package/schema/live-cards.schema.json +10 -1
  161. package/examples/board-local/demo-shell-localstorage.html +0 -843
  162. package/lib/board-live-cards-public-async-DKZqbJVU.d.ts +0 -256
  163. package/lib/board-live-cards-public-async-dMWNbWq6.d.cts +0 -256
  164. package/lib/chunk-KXWT3CY6.cjs +0 -8
  165. package/lib/chunk-MLVTJASJ.js +0 -2
  166. package/lib/chunk-N6P2JW4W.js +0 -3
  167. package/lib/chunk-NMZ6XNLB.cjs +0 -3
  168. package/lib/chunk-OEFTOO47.cjs +0 -3
  169. package/lib/chunk-OJLA6NLU.js +0 -8
  170. package/lib/chunk-R5L5WUKN.js +0 -2
  171. package/lib/chunk-VLBB3D6B.js +0 -3
  172. package/lib/chunk-WOALA3V5.cjs +0 -2
  173. package/lib/chunk-YEB5QHGE.cjs +0 -2
@@ -0,0 +1,8 @@
1
+ var ServerRuntimeControlface=(function(exports){'use strict';var Yn=Object.defineProperty;var Xn=(e,t,r)=>t in e?Yn(e,t,{enumerable:true,configurable:true,writable:true,value:r}):e[t]=r;var Er=(e,t,r)=>Xn(e,t+"",r);var Pt="b64:";function Zn(e){let t=new TextEncoder().encode(e),r=globalThis.Buffer,n;if(r)n=r.from(t).toString("base64");else if(typeof btoa=="function"){let o="";for(let s of t)o+=String.fromCharCode(s);n=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return n.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function eo(e){let t=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),r=globalThis.Buffer;if(r)return r.from(t,"base64").toString("utf8");if(typeof atob=="function"){let n=atob(t),o=new Uint8Array(n.length);for(let s=0;s<n.length;s+=1)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function ve(e){return `${Pt}${Zn(JSON.stringify(e))}`}function Qe(e){if(!e.startsWith(Pt))throw new Error(`Invalid ref format (expected ${Pt}<base64url(json)>): ${e}`);let t;try{t=JSON.parse(eo(e.slice(Pt.length)));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let r=t;if(typeof r.kind!="string"||typeof r.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:r.kind,value:r.value}}async function Or(e,t,r){let n=e.tryAcquire();if(!n)return false;try{await t();}finally{n();}return r?.(),true}function ze(e){return typeof e.journalStorage=="function"}function Br(e){return typeof e.whatToRun=="string"?e.whatToRun.startsWith("b64:")?Qe(e.whatToRun).value:e.whatToRun:e.whatToRun.value}function We(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function lr(e){let t=e.reduce((o,s)=>o+s.length,0),r=new Uint8Array(t),n=0;for(let o of e)r.set(o,n),n+=o.length;return r}async function mt(e,t,r){let n=r[e];if(!n)throw Object.assign(new Error(`Unknown MCP tool: ${e}`),{statusCode:400});let o=await n(t);if(o&&typeof o=="object"&&!Array.isArray(o)){let s=o,i=s.status;if(i==="success")return Object.prototype.hasOwnProperty.call(s,"data")?o:{status:"success",data:{}};if(i==="fail"||i==="error")return o}return {status:"success",data:o}}function Ze(e,t){if(!e||typeof e!="object"||Array.isArray(e))return t;let r=e;if(typeof r.error=="string"&&r.error.trim())return r.error;if(r.step==="validate"){let n=r.validation;if(n&&typeof n=="object"&&!Array.isArray(n)){let s=n.data;if(s&&typeof s=="object"&&!Array.isArray(s)){let i=s.issues;if(Array.isArray(i)){let u=i.find(b=>typeof b=="string"&&b.trim());if(typeof u=="string")return `Validation failed: ${u}`}let a=s.errors;if(Array.isArray(a)&&a.length>0)return "Validation failed"}}return "Validation failed"}return t}function fr(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,bootstrapBoard:s,buildPublishedRuntimePayload:i,createMcpControlplaneToolRegistry:a,retriggerCard:u,applyCardAction:b,resolveChatHandlerTarget:A,sendCardFileDownloadResponse:f}=e;async function g(v,C,R){let l=v.method||"GET",y=R,O=y.pathname;try{if(l==="GET"&&O===`${t}/init-board`)return await o(),r(C,200,await i()),!0;if(l==="POST"&&O===`${t}/mcp-controlplane`){await s();let p=await n(v),k=typeof p.tool=="string"?p.tool.trim():"",S=p.args&&typeof p.args=="object"&&!Array.isArray(p.args)?p.args:{};if(!k)return r(C,400,{error:"tool is required"}),!0;try{let B=await mt(k,S,a());if(B&&typeof B=="object"&&!Array.isArray(B)){let x=B;if(x.status==="fail")return r(C,400,{error:Ze(B,"Request failed")}),!0;if(x.status==="error")return r(C,500,{error:Ze(B,"Internal error")}),!0}r(C,200,B);}catch(B){let x=typeof B?.statusCode=="number"?Number(B.statusCode):500,h=B instanceof Error?B.message:String(B);r(C,x,{error:h});}return !0}let w=O.match(new RegExp(`^${We(t)}/cards/([^/]+)/retrigger$`));if(l==="POST"&&w){await s();let p=decodeURIComponent(w[1]);return await u(p),r(C,200,{ok:!0}),!0}let _=O.match(new RegExp(`^${We(t)}/cards/([^/]+)/actions$`));if(l==="POST"&&_){await s();let p=decodeURIComponent(_[1]),k=Date.now(),S=new Date(k).toISOString(),B=await n(v),x=B?.actionType;if(x==="chat-send"&&!await A(p)){let D=Date.now();return r(C,409,{error:`chat handler is not configured for card: ${p}`,requestReceivedAt:S,requestReceivedAtMs:k,responseSentAt:new Date(D).toISOString(),responseSentAtMs:D,responseStatus:409}),!0}if(x==="chat-send"){let D=B?.payload??{},j=typeof D["turn-id"]=="string"?D["turn-id"]:typeof D.turnId=="string"?D.turnId:typeof D.turn=="string"?D.turn:"";if(!j||!String(j).trim()){let X=Date.now();return r(C,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${p}`,requestReceivedAt:S,requestReceivedAtMs:k,responseSentAt:new Date(X).toISOString(),responseSentAtMs:X,responseStatus:400}),!0}}await b(p,x,B?.payload);let h=Date.now();return r(C,200,{ok:!0,requestReceivedAt:S,requestReceivedAtMs:k,responseSentAt:new Date(h).toISOString(),responseSentAtMs:h,responseStatus:200}),!0}let m=O.match(new RegExp(`^${We(t)}/cards/([^/]+)/files/(\\d+)$`));if(l==="GET"&&m){let p=decodeURIComponent(m[1]),k=parseInt(m[2],10),S=y.searchParams.get("sn");return await f(C,p,k,S),!0}return !1}catch(w){let _=w?.statusCode||500;return r(C,_,{error:String(w?.message||w)}),true}}return {handleRuntimeApi:g}}function _t(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.callbackTransport is required`);if(typeof e.createCallback!="function")throw new Error(`${t}: adapter.callbackTransport.createCallback is required`)}var st={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function Je(e){return e?Array.isArray(e.provides)?e.provides:[]:[]}function at(e){return e?Array.isArray(e.requires)?e.requires:[]:[]}function Fr(e){return e.tasks??{}}function pr(e){return e?e.status===st.FAILED||e.status===st.INACTIVATED:false}function qr(e,t){return e.refreshStrategy??t?.refreshStrategy??"data-changed"}function jr(e){return e.maxExecutions}function Lr(e,t){let r=new Set;for(let[n,o]of Object.entries(t))if(o.status===st.COMPLETED){let s=e.tasks[n];s&&Je(s).forEach(a=>r.add(a));}return Array.from(r)}function Dr(e,t){let r={};return e.forEach(n=>{let o=t[n];if(!o)return;Je(o).forEach(i=>{r[i]||(r[i]=[]),r[i].push(n);});}),r}function Mr(e,t,r){let n=e.tasks[t]??Et(),o={};if(r){let i=r.tasks[t],a=at(i);for(let u of a)for(let[b,A]of Object.entries(r.tasks))if(Je(A).includes(u)){let f=e.tasks[b];f?.lastDataHash&&(o[u]=f.lastDataHash);break}}let s={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:o};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function Nr(e,t,r,n,o,s){let i=e.tasks[r]??Et(),a=t.tasks[r];if(!a)throw new Error(`Task "${r}" not found in graph`);let u;n&&a.on&&a.on[n]?u=a.on[n]:u=Je(a);let b=i.startConsumedHashes?{...i.startConsumedHashes}:{...i.lastConsumedHashes};if(!i.startConsumedHashes){let g=a.requires??[];for(let v of g)for(let[C,R]of Object.entries(t.tasks))if(Je(R).includes(v)){let l=e.tasks[C];l?.lastDataHash&&(b[v]=l.lastDataHash);break}}let A={...i,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:i.executionCount+1,lastEpoch:i.executionCount+1,lastDataHash:o,data:s,lastConsumedHashes:b,error:void 0},f=[...new Set([...e.availableOutputs,...u])];return {...e,tasks:{...e.tasks,[r]:A},availableOutputs:f,lastUpdated:new Date().toISOString()}}function $r(e,t,r,n){let o=e.tasks[r]??Et(),s=t.tasks[r];if(s?.retry){let u=o.retryCount+1;if(u<=s.retry.max_attempts){let b={...o,status:"not-started",retryCount:u,lastUpdated:new Date().toISOString(),error:n};return {...e,tasks:{...e.tasks,[r]:b},lastUpdated:new Date().toISOString()}}}let i={...o,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:o.executionCount+1},a=e.availableOutputs;if(s?.on_failure&&s.on_failure.length>0&&(a=[...new Set([...e.availableOutputs,...s.on_failure])]),s?.circuit_breaker&&i.executionCount>=s.circuit_breaker.max_executions){let u=s.circuit_breaker.on_break;a=[...new Set([...a,...u])];}return {...e,tasks:{...e.tasks,[r]:i},availableOutputs:a,lastUpdated:new Date().toISOString()}}function Ur(e,t,r,n){let o=e.tasks[t]??Et(),s={...o,progress:typeof n=="number"?n:o.progress,messages:[...o.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:o.status}]:[]],lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function Vr(e,t){let r=e.tasks[t];if(!r)return e;let n={...r,status:"not-started",startedAt:void 0,completedAt:void 0,failedAt:void 0,error:void 0,data:void 0,progress:null,lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:n},lastUpdated:new Date().toISOString()}}function Et(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function gt(e,t){let r=`live-${Date.now()}`,n={};for(let s of Object.keys(e.tasks))n[s]=Hr();let o={status:"running",tasks:n,availableOutputs:[],stuckDetection:{is_stuck:false,stuck_description:null,outputs_unresolvable:[],tasks_blocked:[]},lastUpdated:new Date().toISOString(),executionId:r,executionConfig:{executionMode:e.settings.execution_mode??"eligibility-mode",conflictStrategy:e.settings.conflict_strategy??"alphabetical",completionStrategy:e.settings.completion}};return {config:e,state:o}}function to(e,t){let{config:r,state:n}=e;if("executionId"in t&&t.executionId&&t.executionId!==n.executionId)return e;switch(t.type){case "task-started":return {config:r,state:Mr(n,t.taskName,r)};case "task-completed":return {config:r,state:Nr(n,r,t.taskName,t.result,t.dataHash,t.data)};case "task-failed":return {config:r,state:$r(n,r,t.taskName,t.error)};case "task-progress":return {config:r,state:Ur(n,t.taskName,t.message,t.progress)};case "task-restart":return {config:r,state:Vr(n,t.taskName)};case "inject-tokens":return {config:r,state:{...n,availableOutputs:[...new Set([...n.availableOutputs,...t.tokens])],lastUpdated:new Date().toISOString()}};case "agent-action":return {config:r,state:co(n,t.action)};case "task-upsert":return ro(e,t.taskName,t.taskConfig);case "task-removal":return no(e,t.taskName);case "node-requires-add":return oo(e,t.nodeName,t.tokens);case "node-requires-remove":return so(e,t.nodeName,t.tokens);case "node-provides-add":return ao(e,t.nodeName,t.tokens);case "node-provides-remove":return io(e,t.nodeName,t.tokens);default:return e}}function Kr(e,t){return t.reduce((r,n)=>to(r,n),e)}function ro(e,t,r){let n=!!e.config.tasks[t];return {config:{...e.config,tasks:{...e.config.tasks,[t]:r}},state:{...e.state,tasks:{...e.state.tasks,[t]:n?e.state.tasks[t]:Hr()},lastUpdated:new Date().toISOString()}}}function no(e,t){if(!e.config.tasks[t])return e;let{[t]:r,...n}=e.config.tasks,{[t]:o,...s}=e.state.tasks;return {config:{...e.config,tasks:n},state:{...e.state,tasks:s,lastUpdated:new Date().toISOString()}}}function oo(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=at(n),s=r.filter(i=>!o.includes(i));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:[...o,...s]}}},state:e.state}}function so(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=at(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:s}}},state:e.state}}function ao(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=Je(n),s=r.filter(i=>!o.includes(i));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:[...o,...s]}}},state:e.state}}function io(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=Je(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:s}}},state:e.state}}function it(e){return {version:1,config:e.config,state:e.state,snapshotAt:new Date().toISOString()}}function dt(e){if(!e||typeof e!="object")throw new Error("Invalid snapshot: expected an object");let t=e;if(!t.config||typeof t.config!="object")throw new Error('Invalid snapshot: missing or invalid "config"');if(!t.state||typeof t.state!="object")throw new Error('Invalid snapshot: missing or invalid "state"');let r=t.config,n=t.state;if(!r.settings||typeof r.settings!="object")throw new Error("Invalid snapshot: config.settings missing");if(!r.tasks||typeof r.tasks!="object")throw new Error("Invalid snapshot: config.tasks missing");if(!n.tasks||typeof n.tasks!="object")throw new Error("Invalid snapshot: state.tasks missing");if(!Array.isArray(n.availableOutputs))throw new Error("Invalid snapshot: state.availableOutputs must be an array");return {config:r,state:n}}function Hr(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function co(e,t){let r=new Date().toISOString();switch(t){case "stop":return {...e,status:"stopped",lastUpdated:r};case "pause":return {...e,status:"paused",lastUpdated:r};case "resume":return {...e,status:"running",lastUpdated:r};default:return e}}function wt(e){let{config:t,state:r}=e,n=Fr(t);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let s=uo(n),i=Lr(t,r.tasks),a=new Set([...i,...r.availableOutputs]),u=[],b=[],A=[],f=[];for(let[v,C]of Object.entries(n)){let R=r.tasks[v],l=qr(C,t.settings),y=l!=="once";if(R?.status===st.RUNNING||pr(R))continue;let O=jr(C);if(O!==void 0&&R&&R.executionCount>=O||C.circuit_breaker&&R&&R.executionCount>=C.circuit_breaker.max_executions||!y&&R?.status===st.COMPLETED)continue;if(y&&R?.status===st.COMPLETED){let k=at(C),S=false;switch(l){case "data-changed":{k.length>0&&k.some(x=>{for(let[h,D]of Object.entries(n))if(Je(D).includes(x)){let j=r.tasks[h];if(!j)continue;let X=R.lastConsumedHashes?.[x];return j.lastDataHash==null?j.executionCount>R.lastEpoch:j.lastDataHash!==X}return false})||(S=true);break}case "epoch-changed":{k.length>0&&k.some(x=>{for(let[h,D]of Object.entries(n))if(Je(D).includes(x)){let j=r.tasks[h];if(j&&j.executionCount>R.lastEpoch)return true}return false})||(S=true);break}case "time-based":{let B=C.refreshInterval??0;if(B<=0){S=true;break}let x=R.completedAt;if(!x){S=true;break}(Date.now()-Date.parse(x))/1e3<B&&(S=true);break}case "manual":S=true;break}if(S)continue}let w=at(C);if(w.length===0){u.push(v);continue}let _=[],m=[],p=[];for(let k of w){if(a.has(k))continue;let S=s[k]||[];S.length===0?_.push(k):S.every(x=>pr(r.tasks[x]))?p.push({token:k,failedProducer:S[0]}):m.push(k);}_.length>0?A.push({taskName:v,missingTokens:_}):p.length>0?f.push({taskName:v,failedTokens:p.map(k=>k.token),failedProducers:[...new Set(p.map(k=>k.failedProducer))]}):m.length>0?b.push({taskName:v,waitingOn:m}):u.push(v);}let g={};if(u.length>1){let v=Dr(u,n);for(let[C,R]of Object.entries(v))R.length>1&&(g[C]=R);}return {eligible:u,pending:b,unresolved:A,blocked:f,conflicts:g}}function uo(e){let t={};for(let[r,n]of Object.entries(e)){for(let o of Je(n))t[o]||(t[o]=[]),t[o].push(r);if(n.on)for(let o of Object.values(n.on))for(let s of o)t[s]||(t[s]=[]),t[s].includes(r)||t[s].push(r);if(n.on_failure)for(let o of n.on_failure)t[o]||(t[o]=[]),t[o].includes(r)||t[o].push(r);}return t}var St=class{constructor(){Er(this,"buffer",[]);}append(t){this.buffer.push(t);}drain(){let t=this.buffer;return this.buffer=[],t}get size(){return this.buffer.length}};function mr(e){let t=gr(e);return lo(t)}function gr(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return "["+e.map(gr).join(",")+"]";let t=e;return "{"+Object.keys(t).sort().map(n=>JSON.stringify(n)+":"+gr(t[n])).join(",")+"}"}function lo(e){let t=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let o=0;o<e.length;o++)t^=BigInt(e.charCodeAt(o)),t=t*r&n;return t.toString(16).padStart(16,"0")}function fo(e){if(typeof Buffer<"u")return Buffer.from(e,"utf8").toString("base64url");if(typeof btoa=="function"){let t=new TextEncoder().encode(e),r="";for(let n of t)r+=String.fromCharCode(n);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}throw new Error("No base64 encoder available in this runtime")}function po(e){if(typeof Buffer<"u")return Buffer.from(e,"base64url").toString("utf8");if(typeof atob=="function"){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=new Uint8Array(n.length);for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function Jr(e){let t=JSON.stringify({t:e,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return fo(t)}function mo(e){try{let t=JSON.parse(po(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function Ot(e,t,r){let{handlers:n,onNodeRemoved:o,onDrain:s}=t,i=new St,a="state"in e&&"config"in e?e:gt(e),u=false,b=new Set,A=new Map(Object.entries(n)),f=new St,g=false,v=false;function C(){if(!u){if(g){v=true;return}g=true;try{do v=!1,R();while(v)}finally{g=false;}}}function R(){let w=f.drain(),_=i.drain(),m=[...w,..._];if(m.length>0&&(a=Kr(a,m),o)){for(let k of m)if(k.type==="task-removal")try{o(k.taskName);}catch(S){console.warn("[reactive] onNodeRemoved failed:",S instanceof Error?S.message:String(S));}}let p=wt(a);m.length>0&&s?.(m,a,p);for(let k of p.eligible)O(k);for(let k of m)if(k.type==="task-progress"){let{taskName:S,update:B}=k;if(!a.config.tasks[S])continue;let h=a.state.tasks[S];if(!h||h.status!=="running")continue;let D=Jr(S),j=y(S,D,B).catch(X=>{u||(f.append({type:"task-failed",taskName:S,error:X.message??String(X),timestamp:new Date().toISOString()}),C());}).finally(()=>{b.delete(j);});b.add(j);}}function l(w){let m=a.config.tasks[w].requires??[],p=new Map;for(let[S,B]of Object.entries(a.config.tasks))for(let x of B.provides??[])p.set(x,S);let k={};for(let S of m){let B=p.get(S);B?k[S]=a.state.tasks[B]?.data:k[S]=void 0;}return k}async function y(w,_,m){let p=a.config.tasks[w],k=p.taskHandlers??[],S=l(w);for(let B of k){let x=A.get(B);if(!x)throw new Error(`Handler '${B}' not found in registry (task '${w}')`);let h={nodeId:w,state:S,taskState:a.state.tasks[w],config:p,callbackToken:_,update:m};if(await x(h)==="task-initiate-failure")throw new Error(`Handler '${B}' returned task-initiate-failure (task '${w}')`)}}function O(w){let m=a.config.tasks[w]?.taskHandlers;if(!m||m.length===0)return;f.append({type:"task-started",taskName:w,timestamp:new Date().toISOString()}),C();let p=Jr(w),k=y(w,p).catch(S=>{u||(f.append({type:"task-failed",taskName:w,error:S.message??String(S),timestamp:new Date().toISOString()}),C());}).finally(()=>{b.delete(k);});b.add(k);}return {push(w){u||(w.type==="task-completed"&&w.data&&!w.dataHash&&(w={...w,dataHash:mr(w.data)}),i.append(w),C());},pushAll(w){if(!u){for(let _ of w)_.type==="task-completed"&&_.data&&!_.dataHash?i.append({..._,dataHash:mr(_.data)}):i.append(_);C();}},resolveCallback(w,_,m){if(u)return;let p=mo(w);if(!p)return;let{taskName:k}=p;if(a.config.tasks[k]){if(m&&m.length>0)i.append({type:"task-failed",taskName:k,error:m.join("; "),timestamp:new Date().toISOString()});else {let S=_&&Object.keys(_).length>0?mr(_):void 0;i.append({type:"task-completed",taskName:k,data:_,dataHash:S,timestamp:new Date().toISOString()});}C();}},addNode(w,_){u||(i.append({type:"task-upsert",taskName:w,taskConfig:_,timestamp:new Date().toISOString()}),C());},removeNode(w){u||(i.append({type:"task-removal",taskName:w,timestamp:new Date().toISOString()}),C());},addRequires(w,_){u||(i.append({type:"node-requires-add",nodeName:w,tokens:_,timestamp:new Date().toISOString()}),C());},removeRequires(w,_){u||(i.append({type:"node-requires-remove",nodeName:w,tokens:_,timestamp:new Date().toISOString()}),C());},addProvides(w,_){u||(i.append({type:"node-provides-add",nodeName:w,tokens:_,timestamp:new Date().toISOString()}),C());},removeProvides(w,_){u||(i.append({type:"node-provides-remove",nodeName:w,tokens:_,timestamp:new Date().toISOString()}),C());},registerHandler(w,_){A.set(w,_);},unregisterHandler(w){A.delete(w);},retrigger(w){u||a.config.tasks[w]&&(i.append({type:"task-restart",taskName:w,timestamp:new Date().toISOString()}),C());},retriggerAll(w){if(!u){for(let _ of w)a.config.tasks[_]&&i.append({type:"task-restart",taskName:_,timestamp:new Date().toISOString()});C();}},snapshot(){return it(a)},getState(){return a},getSchedule(){return wt(a)},async waitForHandlers(){b.size>0&&await Promise.allSettled([...b]);},async dispose(w){w?.wait&&b.size>0&&await Promise.allSettled([...b]),u=true;}}}function Bt(){return function(e){if(e==="./jsonata-sync.cjs")return typeof globalThis<"u"&&globalThis.__jsonataSync||typeof globalThis<"u"&&globalThis.jsonataSync;throw new Error("Unsupported require in browser bundle: "+e)}}var go=Bt();go("./jsonata-sync.cjs");var yo=Bt(),Ft=yo("./jsonata-sync.cjs"),Qr=Ft;function Gr(e,t){if(!t||!e)return;let r=t.split("."),n=e;for(let o=0;o<r.length;o++){if(n==null)return;n=n[r[o]];}return n}function zr(e,t,r){let n=t.split("."),o=e;for(let s=0;s<n.length-1;s++)(o[n[s]]==null||typeof o[n[s]]!="object")&&(o[n[s]]={}),o=o[n[s]];o[n[n.length-1]]=r;}async function ho(e,t){if(!e?.compute?.length)return e;e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values};for(let o of e.compute)try{let s=await Ft(o.expr).evaluate(n);zr(e.computed_values,o.bindTo,s),n.computed_values=e.computed_values;}catch{}return e}function ko(e,t){if(!e?.compute?.length)return {ok:true,node:e};e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values},o=[];for(let s of e.compute)try{let i=Qr(s.expr).evaluate(n);zr(e.computed_values,s.bindTo,i),n.computed_values=e.computed_values;}catch(i){let a=i instanceof Error?i.message:String(i);o.push({bindTo:s.bindTo,error:a});}return o.length>0?{ok:true,node:e,errors:o}:{ok:true,node:e}}async function Co(e,t,r){let n={...r??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return Ft(e).evaluate(n)}function Ro(e,t){return t.startsWith("fetched_sources.")?Gr(e._sourcesData??{},t.slice(16)):Gr(e,t)}var Wr=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),wo=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function So(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:false,errors:["Node must be a non-null object"]};let r=e;(typeof r.id!="string"||!r.id)&&t.push("id: required, must be a non-empty string");for(let n of Object.keys(r))wo.has(n)||t.push(`Unknown top-level key: "${n}"`);if((r.card_data==null||typeof r.card_data!="object"||Array.isArray(r.card_data))&&t.push("card_data: required, must be an object"),r.meta!=null)if(typeof r.meta!="object"||Array.isArray(r.meta))t.push("meta: must be an object");else {let n=r.meta;n.title!=null&&typeof n.title!="string"&&t.push("meta.title: must be a string"),n.tags!=null&&!Array.isArray(n.tags)&&t.push("meta.tags: must be an array");}if(r.requires!=null&&!Array.isArray(r.requires)&&t.push("requires: must be an array of strings"),r.provides!=null&&(Array.isArray(r.provides)?r.provides.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`provides[${o}]: must be an object with bindTo and ref`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`provides[${o}]: missing required "bindTo" string`),(typeof s.ref!="string"||!s.ref)&&t.push(`provides[${o}]: missing required "ref" string`);}}):t.push("provides: must be an array of { bindTo, ref } bindings")),r.compute!=null&&(Array.isArray(r.compute)?r.compute.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`compute[${o}]: must be a compute step object`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`compute[${o}]: missing required "bindTo" property`),(typeof s.expr!="string"||!s.expr)&&t.push(`compute[${o}]: missing required "expr" string (JSONata expression)`);}}):t.push("compute: must be an array of compute steps")),r.source_defs!=null)if(!Array.isArray(r.source_defs))t.push("source_defs: must be an array");else {let n=new Set,o=new Set;r.source_defs.forEach((s,i)=>{if(!s||typeof s!="object"||Array.isArray(s))t.push(`source_defs[${i}]: must be an object`);else {let a=s;typeof a.bindTo!="string"||!a.bindTo?t.push(`source_defs[${i}]: missing required "bindTo" property`):(n.has(a.bindTo)&&t.push(`source_defs[${i}]: bindTo "${a.bindTo}" is not unique across source_defs`),n.add(a.bindTo)),typeof a.outputFile!="string"||!a.outputFile?t.push(`source_defs[${i}]: missing required "outputFile" property`):(o.has(a.outputFile)&&t.push(`source_defs[${i}]: outputFile "${a.outputFile}" is not unique across source_defs`),o.add(a.outputFile)),a.optionalForCompletionGating!=null&&typeof a.optionalForCompletionGating!="boolean"&&t.push(`source_defs[${i}]: optionalForCompletionGating must be a boolean`);}});}if(r.view!=null)if(typeof r.view!="object"||Array.isArray(r.view))t.push("view: must be an object");else {let n=r.view;!Array.isArray(n.elements)||n.elements.length===0?t.push("view.elements: required, must be a non-empty array"):n.elements.forEach((o,s)=>{if(!o||typeof o!="object"){t.push(`view.elements[${s}]: must be an object`);return}!o.kind||typeof o.kind!="string"?t.push(`view.elements[${s}].kind: required, must be a string`):Wr.has(o.kind)||t.push(`view.elements[${s}].kind: unknown kind "${o.kind}". Valid: ${[...Wr].join(", ")}`),o.data!=null&&(typeof o.data!="object"||Array.isArray(o.data))&&t.push(`view.elements[${s}].data: must be an object`);}),n.layout!=null&&(typeof n.layout!="object"||Array.isArray(n.layout))&&t.push("view.layout: must be an object"),n.features!=null&&(typeof n.features!="object"||Array.isArray(n.features))&&t.push("view.features: must be an object");}return {ok:t.length===0,errors:t}}async function bo(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return Promise.all(e.map(async n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=await Ft(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}}))}function vo(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return e.map(n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=Qr(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}})}var $e={run:ho,runSync:ko,eval:Co,resolve:Ro,validate:So,enrichSources:bo,enrichSourcesSync:vo};function qt(e){return JSON.stringify(e)}function jt(e){let t;try{t=JSON.parse(e);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${e}`)}if(typeof t!="object"||t===null||typeof t.howToRun!="string"||typeof t.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${e}`);return t}function Lt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function yr(e,t){return Lt(e)?e.then(t):t(e)}function Xr(e,t){let r={...e};for(let n of t.deleteKeys)delete r[n];return {...r,...t.shallowMerge}}function hr(e,t){return {readValues(n){let o=e(n);return yr(o.listKeys(),s=>{let i=[...s].sort();if(i.length===0)return {version:null,values:{}};let a={},u=null;for(let b of i){let A=o.read(b);Lt(A)?u=(u??Promise.resolve()).then(async()=>{a[b]=await A;}):a[b]=A;}return u?u.then(()=>({version:t(a),values:a})):{version:t(a),values:a}})},writeValues(n,o,s){let i=e(n),a=null;for(let u of s){let b=i.delete(u);Lt(b)&&(a=(a??Promise.resolve()).then(()=>b).then(()=>{}));}for(let[u,b]of Object.entries(o)){let A=i.write(u,b);Lt(A)&&(a=(a??Promise.resolve()).then(()=>A).then(()=>{}));}return a?a.then(()=>t(o)):t(o)}}}function Dt(e,t){return {readSnapshot(r){return e.readValues(r)},commitSnapshot(r,n){if(n.schemaVersion!==t)throw new Error(`Unsupported snapshot schema version: ${n.schemaVersion}`);return yr(e.readValues(r),o=>{if(o.version!==n.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:o.version};let s=Xr(o.values,n);return yr(e.writeValues(r,s,n.deleteKeys),i=>({ok:true,newVersion:i}))})}}}function Yr(e,t){if(!t)return e;let r=e.findIndex(n=>n.id===t);return r===-1?e:e.slice(r+1)}function Zr(e){return {readEntriesAfterCursor(t){let r=Yr(e.readAllEntries(),t);return r.length===0?{events:[],newCursor:t}:{events:r.map(n=>n.event),newCursor:r[r.length-1].id}},pendingCount(t){return Yr(e.readAllEntries(),t).length},appendEvent(t){e.appendEntry({id:e.generateId(),event:t});}}}function en(e){return {appendEvent(t){return e.append(t).then(()=>{})},async readEntriesAfterCursor(t){let r=await e.readAfter(t||null);return {events:r.entries.map(n=>n.payload),newCursor:r.newCursor??t}}}}function Mt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function De(e,t){return Mt(e)?e.then(t):t(e)}function kr(e,t){let r=null;for(let n of e){if(r){r=r.then(()=>t(n)).then(()=>{});continue}let o=t(n);Mt(o)&&(r=Promise.resolve(o).then(()=>{}));}return r??void 0}function Ao(e){if(e==null)return null;let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{return t}}function xo(e,t){let r=e.match(t);return r?r[1]:null}function tn(e,t,r){let n={},o=kr(e,s=>{let i=r(s);if(i)return De(t(s),a=>{n[i]=a;})});return Mt(o)?o.then(()=>n):n}function Nt(e,t){let r=n=>De(e.read(n),o=>o??(e.keyRef?De(e.keyRef(n),s=>s?De(t(s),i=>i??null):null):null));return {readSourceData(n,o){return De(e.read(`${n}/${o}`),Ao)},ingestSourceDataStaged(n,o,s,i){return De(t(s),a=>e.write(`${n}/.staged/${i}/${o}`,a))},commitSourceData(n,o,s){let i=`${n}/.staged/${s}/${o}`;return De(r(i),a=>a==null?false:De(e.write(`${n}/${o}`,a),()=>De(e.remove(i),()=>true)))},hasSource(n,o){return e.exists(`${n}/${o}`)},listSources(n){return De(e.listKeys(`${n}/`),o=>o.filter(s=>!s.includes("/.staged/")).map(s=>s.slice(`${n}/`.length)))}}}function $t(e,t){let r=(n,o)=>{try{let s=o(n);return Mt(s)?s.catch(i=>t(n,i instanceof Error?i.message:String(i))):void 0}catch(s){try{return t(n,s instanceof Error?s.message:String(s))}catch{return}}};return {appendEntries(n,o){if(!(!n||o.length===0))return De(e.read(n),s=>e.write(n,[...s??[],...o]))},dispatchEntriesForJournalId(n,o){if(n)return De(e.read(n),s=>{let i=s;if(!(!i||i.length===0))return De(kr(i,a=>r(a,o)),()=>e.delete(n))})}}}function Ut(e,t,r){return {readRuntime(n){return De(e.read(t(n)),o=>o??r())},writeRuntime(n,o){return e.write(t(n),o)}}}function Vt(e){return {writeComputedValues(t,r){return e.write(`cards/${t}/computed_values`,r)},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){return De(e.listKeys("cards/"),t=>tn(t,r=>e.read(r),r=>xo(r,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(t){return kr(Object.entries(t),([r,n])=>{if(r)return e.write(`data-objects/${r}`,n)})},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){return De(e.listKeys("data-objects/"),t=>tn(t,r=>e.read(r),r=>r.slice(13)))},writeStatusSnapshot(t){return e.write("status",t)},readStatusSnapshot(){return e.read("status")}}}function xt(e,t){function r(){return e.readIndex()??{}}function n(o,s,i){let a=String(s||"").split(".").filter(Boolean);if(a.length===0)return i&&typeof i=="object"&&!Array.isArray(i)?i:{value:i};let u={...o},b=u;for(let A=0;A<a.length-1;A++){let f=a[A],g=b[f],v=g&&typeof g=="object"&&!Array.isArray(g)?{...g}:{};b[f]=v,b=v;}return b[a[a.length-1]]=i,u}return {readCard(o){let s=r()[o];return !s||!e.cardExists(s.key)?null:e.readCard(s.key)},readCardKey(o){return r()[o]?.key??null},readAllCards(){let o=[];for(let[s,i]of Object.entries(r())){if(!e.cardExists(i.key))continue;let a=e.readCard(i.key);a?o.push(a):t?.(`[card-store] could not read card "${s}" at key "${i.key}"`);}return o},readChecksumIndex(){let o={};for(let[s,i]of Object.entries(r()))o[s]=i.checksum;return o},changedSince(o){let s=r(),i=[];for(let[a,u]of Object.entries(s))o[a]!==u.checksum&&i.push(a);for(let a of Object.keys(o))s[a]||i.push(a);return i},validateUpsert(o,s){let i=r(),a=i[o],u=Object.entries(i).find(([,b])=>b.key===s);return a&&a.key!==s?{ok:false,error:`Card id "${o}" is already mapped to key "${a.key}", cannot remap to "${s}"`}:u&&u[0]!==o?{ok:false,error:`Key "${s}" is already mapped to card id "${u[0]}", cannot remap to "${o}"`}:{ok:true}},writeCard(o,s,i){let a=r(),u=i??a[o]?.key??e.defaultCardKey(o),b=e.writeCard(u,s);a[o]={key:u,checksum:b,updatedAt:new Date().toISOString()},e.writeIndex(a);},patchCard(o,s,i){let a=r(),u=a[o];if(!u||!e.cardExists(u.key))throw new Error(`card "${o}" not found`);let b=e.readCard(u.key);if(!b||typeof b!="object"||Array.isArray(b))throw new Error(`card "${o}" is not patchable`);let A=n(b,s,i),f=e.writeCard(u.key,A);a[o]={key:u.key,checksum:f,updatedAt:new Date().toISOString()},e.writeIndex(a);},removeCard(o){let s=r(),i=s[o];i&&(e.removeCard(i.key),delete s[o],e.writeIndex(s));},readIndex(){return r()}}}function Kt(e,t){return Nt(e,t)}function rn(e){return Zr(e)}function nn(e,t){return $t(e,t)}var Ht="v1",Ye="board/graph",on="board/lastJournalProcessedId";function Cr(e){return `cards/${e}/runtime`}function sn(e){return Ut(e,Cr,()=>({_sources:{}}))}function an(e){return Dt(e,Ht)}function Rr(e){function t(r){let n=e.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {readTaskExecutorRef(){let r=t("task-executor");if(r?.trim())return jt(r.trim())},writeTaskExecutorRef(r){e.write("task-executor",qt(r));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){e.write("chat-handler-flow",r);},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){e.write("card-store-ref",r);},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){e.write("outputs-store-ref",r);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){e.write("scratch-store-ref",r);},readArchiveStoreRef(){return t("archive-store-ref")},writeArchiveStoreRef(r){e.write("archive-store-ref",r);},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){e.write("chat-store-ref",r);},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){e.write("artifacts-store-ref",r);}}}function dn(e){return Vt(e)}function bt(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function Io(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function vt(e,t){return e?.lastRequestedToken?Io(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function wr(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function At(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function ct(e,t){let r=t.state.tasks,n=t.config.tasks,o=Object.keys(r),s=wt(t),i={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},a=new Map;for(let C of s.pending)a.set(C.taskName,C.waitingOn);for(let C of s.unresolved)a.set(C.taskName,C.missingTokens);for(let C of s.blocked)a.set(C.taskName,C.failedTokens);let u=new Map;for(let[C,R]of Object.entries(n))for(let l of R.requires??[]){let y=u.get(l)??[];y.push(C),u.set(l,y);}let b=o.sort().map(C=>{let R=r[C],l=n[C]??{requires:[],provides:[]};R.status==="completed"?i.completed+=1:R.status==="failed"?i.failed+=1:R.status==="in-progress"&&(i.in_progress+=1);let y=l.requires??[],O=l.provides??[],w=Object.keys(R.data??{}).sort(),_=y.filter(x=>t.state.availableOutputs.includes(x)),m=y.filter(x=>!t.state.availableOutputs.includes(x)),p=a.get(C)??m,k=new Set;for(let x of O)for(let h of u.get(x)??[])h!==C&&k.add(h);let S=R.failedAt,B=R.error?{message:R.error,code:"TASK_FAILED",at:S,source:"task-runtime"}:void 0;return {name:C,status:R.status,error:B,requires:y,requires_satisfied:_,requires_missing:m,provides_declared:O,provides_runtime:w,blocked_by:p,unblocks:Array.from(k).sort(),runtime:{attempt_count:R.executionCount??0,restart_count:R.retryCount??0,in_progress_since:R.status==="in-progress"?R.startedAt??null:null,last_transition_at:R.lastUpdated??null,last_completed_at:R.completedAt??null,last_restarted_at:R.startedAt??null,status_age_ms:R.lastUpdated?0:null}}});i.pending=s.pending.length,i.blocked=s.blocked.length,i.unresolved=s.unresolved.length;let A=b.map(C=>({name:C.name,fanOut:C.unblocks.length})).sort((C,R)=>R.fanOut-C.fanOut||C.name.localeCompare(R.name)),f=A.length>0?A[0]:{name:null,fanOut:0},g=new Set;for(let C of Object.values(n))for(let R of C.requires??[])g.add(R);let v=0;for(let[C,R]of Object.entries(n)){let l=(R.requires??[]).length===0,O=(R.provides??[]).some(w=>(u.get(w)??[]).some(_=>_!==C));l&&!O&&(v+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:o.length,completed:i.completed,eligible:s.eligible.length,pending:i.pending,blocked:i.blocked,unresolved:i.unresolved,failed:i.failed,in_progress:i.in_progress,orphan_cards:v,topology:{edge_count:Array.from(g).length,max_fan_out_card:f.name,max_fan_out:f.fanOut}},cards:b}}function To(){return new Date().toISOString()}function cn(e,t,r,n,o,s,i){return async a=>{let u=[],b=r.cardStore.readCard(a.nodeId);if(!b)return "task-initiate-failure";let A=b.id,f=b.card_data??{},g=b.source_defs??[],v=g.filter(H=>H.optionalForCompletionGating!==true),C=r.cardRuntimeStore.readRuntime(A),R=false,l=()=>{R&&(r.cardRuntimeStore.writeRuntime(A,C),R=false);},y=H=>bt(C._sources[H]),O=(H,M)=>{C._sources[H]=bt(M),R=true;},w=a.taskState?.executionCount??0;if(C._lastExecutionCount!==w&&(C._sources={},C._lastExecutionCount=w,R=true),a.update){let H=a.update,M=H.outputFile;if(M){let z=y(M);if(H.failure){let oe=H.rqt??z.lastRequestedToken??z.queueRequestedToken;oe&&O(M,At(z,oe));}else {let oe=H.rqt;if(!z.lastCompletedToken||oe>z.lastCompletedToken){let we=typeof H.deliveryToken=="string"?H.deliveryToken:void 0,T=false;we&&(T=r.fetchedSourcesStore.commitSourceData(A,M,we)),T?O(M,wr(z,oe)):O(M,At(z,oe));}}l();}}let m={};for(let H of g)if(H.outputFile){let M=r.fetchedSourcesStore.readSourceData(A,H.outputFile);M!==null&&(m[H.bindTo]=M);}let p={};for(let[H,M]of Object.entries(a.state??{}))if(M!==null&&typeof M=="object"&&!Array.isArray(M)){let z=M[H];p[H]=z!==void 0?z:M;}else p[H]=M;let k={id:A,card_data:{...f},requires:p,source_defs:g,compute:b.compute};k._sourcesData=m,b.compute&&$e.runSync(k,{sourcesData:m}),(s??r.outputStore.writeComputedValues.bind(r.outputStore))(A,k.computed_values??{});let S={...b},B=$e.enrichSourcesSync(Array.isArray(b.source_defs)?b.source_defs:void 0,{card_data:b.card_data,requires:p}),x=e.value;S.source_defs=Array.isArray(B)?B.map(H=>({...H,boardDir:typeof H.boardDir=="string"&&H.boardDir?H.boardDir:x})):B;let h=To(),D=a.update?void 0:h,j=v.filter(H=>{let M=H.outputFile;if(typeof M!="string"||!M)return true;let z=y(M);D&&(z={...z,queueRequestedToken:D},O(M,z));let oe=z.queueRequestedToken??z.lastRequestedToken??h,we=vt(z,oe);return we==="in-flight"?false:we==="dispatch"});if(l(),j.length>0){let H=false,M=h;for(let z of j){let oe=z.outputFile;if(typeof oe!="string"||!oe)continue;let we=y(oe),T=we.queueRequestedToken??h;O(oe,{...we,lastRequestedToken:T}),M=T,H=true;}return H&&l(),H&&(u.push({taskKind:"source-fetch",payload:{boardRef:ve(e),enrichedCard:S,callbackToken:a.callbackToken,rqt:M}}),r.executionRequestStore.appendEntries(t,u)),"task-initiated"}if(v.some(H=>{let M=H.outputFile;if(typeof M!="string"||!M)return false;let z=y(M),oe=z.queueRequestedToken??z.lastRequestedToken??h;return vt(z,oe)==="in-flight"}))return "task-initiated";let N=b.provides??[],$={};for(let{bindTo:H,ref:M}of N)$[H]=$e.resolve(k,M);return (i??r.outputStore.writeDataObjects.bind(r.outputStore))($),g.filter(H=>{if(H.optionalForCompletionGating!==true)return false;let M=y(H.outputFile);return !M.lastRequestedToken||!M.lastCompletedToken?true:M.lastCompletedToken<=M.lastRequestedToken}).length>0&&u.push({taskKind:"source-fetch",payload:{boardRef:ve(e),enrichedCard:S,callbackToken:a.callbackToken,rqt:h}}),n(a.nodeId,$),u.length>0&&r.executionRequestStore.appendEntries(t,u),"task-initiated"}}var It={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function Jt(e){return {[Ye]:e.graph,[on]:e.lastDrainedJournalId}}function Gt(e){let t=e[Ye],r=e[on];if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${Ye}`);return {graph:t,lastDrainedJournalId:typeof r=="string"?r:""}}function Wt(e){let t=e.requires;return {provides:e.provides?.map(n=>n.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...t&&t.length>0?{requires:t}:{}}}function Qt(e){function t(s){return {status:"success",data:s}}function r(s){return {status:"fail",error:s}}function n(s){return {status:"error",error:s instanceof Error?s.message:String(s)}}function o(s){if(Array.isArray(s))return s;if(s&&typeof s=="object"){let i=s;return Array.isArray(i.files)?i.files:[s]}return null}return {get(s){try{let i=s.params?.id;if(i){let a=e.readCard(i);return a?t({cards:[a]}):r(`card "${i}" not found`)}return t({cards:e.readAllCards()})}catch(i){return n(i)}},set(s){try{let i=s.body;if(i==null)return r("set requires a body (card object or array of cards)");let a=Array.isArray(i)?i:[i];for(let u of a){if(typeof u.id!="string")return r("each card must have a string `id` field");e.writeCard(u.id,u);}return t({count:a.length})}catch(i){return n(i)}},del(s){try{let i=s.body?.ids??[],a=s.params?.id,u=a?[...i,a]:i;if(u.length===0)return r("del requires body.ids (string[]) or params.id");for(let b of u)e.removeCard(b);return t({count:u.length})}catch(i){return n(i)}},patch(s){try{let i=s.params?.id,a=s.params?.path;if(!i)return r("patch requires params.id");if(!a)return r("patch requires params.path");let u=s.body,b=u&&Object.prototype.hasOwnProperty.call(u,"value")?u.value:s.body;return e.patchCard(i,a,b),t({count:1})}catch(i){return n(i)}},appendFiles(s){try{let i=s.params?.id;if(!i)return r("appendFiles requires params.id");let a=e.readCard(i);if(!a)return r(`card "${i}" not found`);let u=o(s.body);if(!u||u.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let b=a.card_data&&typeof a.card_data=="object"&&!Array.isArray(a.card_data)?a.card_data:{},A=Array.isArray(b.files)?b.files:[],f=[...A,...u],g=u.map((C,R)=>({idx:A.length+R,entry:C})),v=this.patch({params:{id:i,path:"card_data.files"},body:{value:f}});return v.status!=="success"?v:t({files_added:g})}catch(i){return n(i)}}}}function ce(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function ae(e){return {status:"fail",error:e}}function me(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function Po(e){let t=new TextEncoder().encode(e),r=Array.from(t,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function ln(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function zt(e){try{let t=JSON.parse(ln(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function _o(e){return Po(JSON.stringify(e))}function un(e){try{let t=JSON.parse(ln(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function Me(){return new Date().toISOString()}function fn(e,t){_t(t.callbackTransport,"createBoardLiveCardsPublic");let r=t.callbackTransport,n=t.onWarn??(()=>{}),o=ve(e);function s(q){if(q.length!==0)try{let c=t.publishBoardChangeNotifications?.(q);c&&typeof c.catch=="function"&&c.catch(E=>n(`[board-live-cards-public] publishBoardChangeNotifications failed: ${E instanceof Error?E.message:String(E)}`));}catch(c){n(`[board-live-cards-public] publishBoardChangeNotifications failed: ${c instanceof Error?c.message:String(c)}`);}}function i(){let q=u().readCardStoreRef();if(!q)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let c=t.kvStorageForRef(q);return {readIndex(){return c.read("_index")},writeIndex(E){c.write("_index",E);},readCard(E){return c.read(E)},writeCard(E,L){return c.write(E,L),t.hashFn(L)},removeCard(E){c.delete(E);},cardExists(E){return c.read(E)!==null},defaultCardKey(E){return E}}}let a={readValues(q){let c=t.kvStorage("state-snapshot"),E=c.listKeys().sort();if(E.length===0)return {version:null,values:{}};let L={};for(let ee of E)L[ee]=c.read(ee);return {version:t.hashFn(L),values:L}},writeValues(q,c,E){let L=t.kvStorage("state-snapshot");for(let ee of E)L.delete(ee);for(let[ee,ne]of Object.entries(c))L.write(ee,ne);return t.hashFn(c)}},u=()=>Rr(t.kvStorage("config")),b=()=>an(a),A=()=>rn(t.journalAdapter()),f=()=>xt(i(),n),g=()=>{let q=u().readOutputsStoreRef();if(!q)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return dn(t.kvStorageForRef(q))},v=()=>{let q=u().readArchiveStoreRef();return q?t.archiveFactoryForRef(q):t.archiveFactory()};function C(){return !!b().readSnapshot(e.value).values[Ye]}function R(){let q=b().readSnapshot(e.value);if(!q.values[Ye])throw new Error(`Board not initialized at ${e.value}`);return Gt(q.values)}function l(q,c){let E=b().commitSnapshot(e.value,{schemaVersion:Ht,expectedVersion:c,commitId:t.genId(),committedAt:Me(),deleteKeys:[],shallowMerge:Jt(q)});if(!E.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${c??"null"} current=${E.currentVersion??"null"}`)}function y(q){A().appendEvent(q);}async function O(){let q=(Q,d)=>{let P=Q.payload,V=(P?.enrichedCard??{}).id??P?.cardId??"unknown";y({type:"task-failed",taskName:V,error:d,timestamp:Me()});},c=nn(t.kvStorage("execution-requests"),q),E=sn(t.kvStorage("card-runtime")),L=Kt(t.blobStorage("sources"),Q=>t.resolveBlob(Q)),ee=new Map,ne={readRuntime(Q){return ee.get(Q)??E.readRuntime(Q)},writeRuntime(Q,d){ee.set(Q,d);}},te=[],le=new Map,Se={readSourceData(Q,d){let P=`${Q}/${d}`;return le.has(P)?le.get(P):L.readSourceData(Q,d)},ingestSourceDataStaged(Q,d,P,F){L.ingestSourceDataStaged(Q,d,P,F);},commitSourceData(Q,d,P){let F=`${Q}/.staged/${P}/${d}`,V=t.blobStorage("sources"),K=V.read(F);if(K==null){let _e=V.keyRef?.(F);_e&&(K=t.resolveBlob(_e));}if(K==null)return false;let se=`${Q}/${d}`,fe=K.trim();try{le.set(se,JSON.parse(fe));}catch{le.set(se,fe);}return te.push({cardId:Q,outputFile:d,deliveryToken:P}),true},hasSource(Q,d){let P=`${Q}/${d}`;return le.has(P)?true:L.hasSource(Q,d)},listSources(Q){let d=L.listSources(Q),P=new Set;for(let V of le.keys())V.startsWith(`${Q}/`)&&P.add(V.slice(`${Q}/`.length));let F=new Set([...d,...P]);return Array.from(F)}},be={cardStore:f(),cardRuntimeStore:ne,fetchedSourcesStore:Se,outputStore:g(),executionRequestStore:c},Ve=R(),je=dt(Ve.graph),{events:tt,newCursor:rt}=A().readEntriesAfterCursor(Ve.lastDrainedJournalId),Ke=[],nt=[],ht=[],kt=new Map,Tt=new Set,lt=(Q,d)=>{Ke.push({type:"task-completed",taskName:Q,data:d,timestamp:Me()});try{v().stream("exec-history").append({taskName:Q,status:"completed",completedAt:Me()});}catch{}},Ct=(Q,d)=>{y({type:"task-failed",taskName:Q,error:d,timestamp:Me()});try{v().stream("exec-history").append({taskName:Q,status:"failed",error:d,completedAt:Me()});}catch{}},ft=Ot(je,{handlers:{"card-handler":cn(e,rt,be,lt,Ct,(Q,d)=>{nt.push({cardId:Q,values:d});},Q=>{ht.push(Q);})},onNodeRemoved:Q=>{kt.delete(Q),ee.delete(Q),Tt.add(Q);}});for(Ke=tt;Ke.length>0;){let Q=Ke;Ke=[];for(let d of Q)if(d.type==="task-restart"){let P=be.cardStore.readCard(d.taskName);P&&kt.set(d.taskName,P);}ft.pushAll(Q),await ft.waitForHandlers();}let ir=ft.getState();await ft.dispose({wait:true});let dr=b().readSnapshot(e.value).version;l({lastDrainedJournalId:rt,graph:it(ir)},dr);for(let{cardId:Q,values:d}of nt)be.outputStore.writeComputedValues(Q,d);for(let Q of ht)be.outputStore.writeDataObjects(Q);for(let[Q,d]of ee)E.writeRuntime(Q,d);for(let{cardId:Q,outputFile:d,deliveryToken:P}of te)L.commitSourceData(Q,d,P);let Rt;try{Rt=ct(o,ir),be.outputStore.writeStatusSnapshot(Rt);}catch(Q){n(`[board-live-cards-public] status publish failed: ${Q instanceof Error?Q.message:String(Q)}`);}let ot=[];for(let{cardId:Q,values:d}of nt)ot.push({kind:"computed_values",cardId:Q,values:d});for(let Q of ht)for(let[d,P]of Object.entries(Q))d&&ot.push({kind:"data_object",key:d,payload:P});for(let[Q,d]of kt)ot.push({kind:"card_refreshed",cardId:Q,card:d});for(let Q of Tt)ot.push({kind:"card_removed",cardId:Q});Rt!==void 0&&ot.push({kind:"status",status:Rt}),s(ot);let cr=u().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:ve({kind:"built-in",value:"source-cli-task-executor"})},ur=t.supportsDirectSourceOutput?.(cr)===true;c.dispatchEntriesForJournalId(rt,Q=>{if(Q.taskKind!=="source-fetch"){n(`[process-accumulated-events] unknown taskKind "${Q.taskKind}" \u2014 skipping`);return}let d=Q.payload,P=d.enrichedCard?.id??"unknown",F=d.enrichedCard?.source_defs??[];for(let V of F){if(!V.outputFile){n(`[dispatch] source "${V.bindTo}" has no outputFile \u2014 skipping`);continue}let K;if(ur){let fe=t.genId(),_e=`${P}/.staged/${fe}/${V.outputFile}`,Pe=t.blobStorage("sources").keyRef?.(_e);Pe?K={ref:ve(Pe),deliveryToken:fe,outputFile:V.outputFile,cardId:P}:n("[dispatch] hosted board-worker requested but sources BlobStorage cannot produce portable refs; falling back to scratch protocol");}let se=_o({cbk:d.callbackToken,rg:e.value,br:ve(e),cid:P,b:V.bindTo,d:V.outputFile,cs:void 0,rqt:d.rqt,...K?{dt:K.deliveryToken}:{}});t.dispatchExecution(cr,{source_def:V,base_ref:ve(e),callback:r.createCallback(se),...K?{output:K}:{}}).catch(fe=>Ct(P,fe instanceof Error?fe.message:String(fe)));}});}function w(){let q=t.processAccumulatedStore();q.enqueueIfAbsent?q.enqueueIfAbsent({boardRef:ve(e)},`process-accumulated:${ve(e)}`):q.enqueue({boardRef:ve(e)}),t.requestProcessAccumulated?.();}function _(){let q=t.processAccumulatedStore();for(;;){let c=q.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let E of c)q.ack(E.id,E.leaseToken);if(c.length<64)return}}async function m(){try{let q=()=>{let E=R(),{events:L}=A().readEntriesAfterCursor(E.lastDrainedJournalId);L.length<=0||w();},c=await Or(t.lock,O,q);return ce({ran:c!==!1})}catch(q){return me(q)}}function p(){w();}function k(q){try{let c=q.params?.cardStoreRef;if(!c)return ae("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!C()){let be=gt(It);l({lastDrainedJournalId:"",graph:it(be)},null);}let E=q.params?.outputsStoreRef;if(!E)return ae("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let L=q.params?.scratchStoreRef,ee=q.params?.archiveStoreRef,ne=q.params?.chatStoreRef,te=q.params?.artifactsStoreRef,le=u();le.writeCardStoreRef(c),le.writeOutputsStoreRef(E),L&&le.writeScratchStoreRef(L),ee&&le.writeArchiveStoreRef(ee),ne&&le.writeChatStoreRef(ne),te&&le.writeArtifactsStoreRef(te);let Se=q.body??{};Se["task-executor-ref"]&&le.writeTaskExecutorRef(Se["task-executor-ref"]),Object.prototype.hasOwnProperty.call(Se,"chat-handler-flow")&&le.writeChatHandlerFlow(Se["chat-handler-flow"]);try{g().writeStatusSnapshot(ct(o,dt(R().graph)));}catch{}return ce()}catch(c){return me(c)}}function S(q){try{let c=g().readStatusSnapshot();if(!c){c=ct(o,dt(R().graph));try{g().writeStatusSnapshot(c);}catch{}}return ce(c)}catch(c){return me(c)}}function B(q){try{let c=q.params?.id;if(!c)return ae("removeCard requires params.id");try{t.kvStorage("card-upsert").delete(c);}catch{}return y({type:"task-removal",taskName:c,timestamp:Me()}),p(),ce()}catch(c){return me(c)}}function x(q){try{let c=q.params?.cardId;if(!c)return ae("addCardFiles requires params.cardId");let E=Qt(f()).appendFiles({params:{id:c},body:q.body});if(E.status!=="success")return E;let L=h({params:{cardId:c}});return L.status!=="success"?L:ce({cardId:c,files_added:E.data.files_added,notified:!0})}catch(c){return me(c)}}function h(q){try{let c=q.params?.cardId;if(!c)return ae("cardRefreshedNotify requires params.cardId");let E=f().readCard(c);return E?(s([{kind:"card_refreshed",cardId:c,card:E}]),ce({cardId:c,notified:!0})):ae(`Card "${c}" not found in board at ${e.value}`)}catch(c){return me(c)}}function D(q){try{let c=q.params?.id;return c?(y({type:"task-restart",taskName:c,timestamp:Me()}),p(),ce()):ae("retrigger requires params.id")}catch(c){return me(c)}}async function j(q){return _(),m()}function X(q){try{let c=q.params?.cardId,E=q.params?.all,L=!!q.params?.restart;if(!c&&!E)return ae("upsertCard requires --card-id <id> or --all");let ee=E?f().readAllCards().map(ne=>ne.id):[c];for(let ne of ee)if(!f().readCard(ne))return ae(`Card "${ne}" not found in board at ${e.value}`);for(let ne of ee){let te=f().readCard(ne),le=Wt(te),Se=t.hashFn(le),be=t.kvStorage("card-upsert"),Ve=be.read(ne),je=Ve?.taskConfigHash!==Se;if(!(!je&&!L)){if(je){let tt=Ve?.blobRef??f().readCardKey(ne)??ne;y({type:"task-upsert",taskName:ne,taskConfig:le,timestamp:Me()}),be.write(ne,{blobRef:tt,taskConfigHash:Se,updatedAt:Me()});}L&&y({type:"task-restart",taskName:ne,timestamp:Me()});}}return p(),ce()}catch(c){return me(c)}}function N(q){try{let c=q.params?.token;if(!c)return ae("taskFailed requires params.token");let E=q.params?.error??"unknown error",L=zt(c);if(!L)return ae("Invalid callback token");y({type:"task-failed",taskName:L.taskName,error:E,timestamp:Me()});try{v().stream("exec-history").append({taskName:L.taskName,status:"failed",error:E,completedAt:Me()});}catch{}return p(),ce()}catch(c){return me(c)}}function $(q){try{let c=q.params?.token;if(!c)return ae("taskProgress requires params.token");let L=(q.body??{}).update??{},ee=zt(c);return ee?(y({type:"task-progress",taskName:ee.taskName,update:L,timestamp:Me()}),p(),ce()):ae("Invalid callback token")}catch(c){return me(c)}}function Z(q){try{let c=q.params?.token,E=q.params?.ref;if(!c)return ae("sourceDataFetched requires params.token");if(!E)return ae("sourceDataFetched requires params.ref");let L=un(c);if(!L)return ae("Invalid source token");let{cbk:ee,cid:ne,b:te,d:le,cs:Se,rqt:be,dt:Ve}=L,je=Kt(t.blobStorage("sources"),nt=>t.resolveBlob(nt)),tt=Ve||t.genId();Ve||je.ingestSourceDataStaged(ne,le,Qe(E),tt);let rt=zt(ee);if(!rt)return ae("Invalid callback token embedded in source token");let Ke=Me();return y({type:"task-progress",taskName:rt.taskName,update:{bindTo:te,outputFile:le,fetchedAt:Ke,deliveryToken:tt,sourceChecksum:Se,rqt:be},timestamp:Ke}),p(),ce()}catch(c){return me(c)}}function H(q){try{let c=q.params?.token,E=q.params?.reason??"unknown";if(!c)return ae("sourceDataFetchFailure requires params.token");let L=un(c);if(!L)return ae("Invalid source token");let{cbk:ee,b:ne,d:te,cs:le,rqt:Se}=L,be=zt(ee);return be?(y({type:"task-progress",taskName:be.taskName,update:{bindTo:ne,outputFile:te,failure:!0,reason:E,sourceChecksum:le,rqt:Se},timestamp:Me()}),p(),ce()):ae("Invalid callback token embedded in source token")}catch(c){return me(c)}}function M(q){try{let c=u().readCardStoreRef();return c?ce({storeRef:c}):ae(`Board at ${e.value} has no card store configured`)}catch(c){return me(c)}}function z(q){try{let c=u().readOutputsStoreRef();return c?ce({storeRef:c}):ae(`Board at ${e.value} has no outputs store configured`)}catch(c){return me(c)}}function oe(q){try{let c=u().readScratchStoreRef();return ce({storeRef:c})}catch(c){return me(c)}}function we(q){try{let c=u().readArchiveStoreRef();return ce({storeRef:c})}catch(c){return me(c)}}function T(q){try{let c=u().readChatStoreRef();return ce({storeRef:c})}catch(c){return me(c)}}function I(q){try{let c=u().readArtifactsStoreRef();return ce({storeRef:c})}catch(c){return me(c)}}function U(q){try{let c=q.params?.key;if(!c)return ae("getConfig requires params.key");let E=u(),L;switch(c){case "task-executor":L=E.readTaskExecutorRef()??null;break;case "chat-handler-flow":L=E.readChatHandlerFlow()??null;break;case "card-store-ref":L=E.readCardStoreRef();break;case "outputs-store-ref":L=E.readOutputsStoreRef();break;case "scratch-store-ref":L=E.readScratchStoreRef();break;case "archive-store-ref":L=E.readArchiveStoreRef();break;case "chat-store-ref":L=E.readChatStoreRef();break;case "artifacts-store-ref":L=E.readArtifactsStoreRef();break;default:return ae(`getConfig: unknown key "${c}"`)}return ce({value:L})}catch(c){return me(c)}}function J(q){try{let c=q.params?.key;if(!c)return ae("getOutputsDataObject requires params.key");let E=g().readDataObject(c);return ce(E)}catch(c){return me(c)}}function G(q){try{return ce(g().readAllDataObjects())}catch(c){return me(c)}}function re(q){try{let c=q.params?.key;if(!c)return ae("getOutputsComputedValues requires params.key");let E=g().readComputedValues(c);return ce(E)}catch(c){return me(c)}}function de(q){try{return ce(g().readAllComputedValues())}catch(c){return me(c)}}function pe(){return Kt(t.blobStorage("sources"),q=>t.resolveBlob(q))}function ye(q){let c=t.blobStorage("sources").keyRef?.(q);return c?ve(c):q}function he(q){try{let c=q.params?.key;if(!c)return ae("getOutputsFetchedSources requires params.key");let E=pe().listSources(c),L={};for(let ee of E)L[ee]=ye(`${c}/${ee}`);return ce(L)}catch(c){return me(c)}}function xe(q){try{let c=pe(),E=new Set;for(let ee of t.blobStorage("sources").listKeys()){let ne=ee.indexOf("/");ne>0&&!ee.includes("/.staged/")&&E.add(ee.slice(0,ne));}let L={};for(let ee of E){let ne=c.listSources(ee);if(ne.length>0){L[ee]={};for(let te of ne)L[ee][te]=ye(`${ee}/${te}`);}}return ce(L)}catch(c){return me(c)}}return {init:k,status:S,getCardStoreRef:M,getOutputsStoreRef:z,getScratchStoreRef:oe,getArchiveStoreRef:we,getChatStoreRef:T,getArtifactsStoreRef:I,getConfig:U,getOutputsDataObject:J,getAllOutputsDataObjects:G,getOutputsComputedValues:re,getAllOutputsComputedValues:de,getOutputsFetchedSources:he,getAllOutputsFetchedSources:xe,removeCard:B,addCardFiles:x,cardRefreshedNotify:h,retrigger:D,processAccumulatedEvents:j,upsertCard:X,taskFailed:N,taskProgress:$,sourceDataFetched:Z,sourceDataFetchFailure:H}}function pn(e,t){let r=()=>Rr(t.kvStorage("config"));function n(){let R=r().readCardStoreRef();if(!R)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let l=t.kvStorageForRef(R);return {readIndex(){return l.read("_index")},writeIndex(y){l.write("_index",y);},readCard(y){return l.read(y)},writeCard(y,O){return l.write(y,O),t.hashFn(O)},removeCard(y){l.delete(y);},cardExists(y){return l.read(y)!==null},defaultCardKey(y){return y}}}let o=()=>xt(n(),t.onWarn??(()=>{}));async function s(R,l){let y=t.validateSchema(l),O=[],w=r().readTaskExecutorRef();if(w&&Array.isArray(l.source_defs))for(let m of l.source_defs){let p=typeof m.bindTo=="string"?m.bindTo:"(unknown)";try{let k;try{k=await t.invokeExecutor(w,"validate-source-def",{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(m)});}catch(B){let x=B;if(k=typeof x?.stdout=="string"?x.stdout:"",!k.trim()){O.push(`source "${p}": executor validate-source-def failed \u2014 ${B instanceof Error?B.message:String(B)}`);continue}}let S=JSON.parse(k.trim());if(!S.ok&&Array.isArray(S.errors))for(let B of S.errors)O.push(`source "${p}": ${B}`);}catch(k){O.push(`source "${p}": executor validate-source-def failed \u2014 ${k instanceof Error?k.message:String(k)}`);}}let _=[...y.errors,...O];return ce({cardId:R,isValid:_.length===0,issues:_})}function i(R,l){let y=R.params?.sourceIdx,O=R.params?.outRef;if(y===void 0)return ae(`${l} requires params.sourceIdx`);if(!R.body||typeof R.body!="object"||Array.isArray(R.body))return ae(`${l} requires card JSON object in body`);let w=R.body,_=w["card-content"]??w,m=w["mock-projections"]??{},p=_.source_defs??[];if(y<0||y>=p.length)return ae(`sourceIdx ${y} out of range (card has ${p.length} source(s))`);let k=p[y],S=typeof k.bindTo=="string"?k.bindTo:"source";return {src:k,bindTo:S,outRef:O,mockProjections:m}}async function a(R){try{if(!R.body||typeof R.body!="object"||Array.isArray(R.body))return ae("validateCardPreflight requires card JSON object in body");let l=R.body,y=l["card-content"]??l,O=typeof y.id=="string"?y.id:"(unknown)";return await s(O,y)}catch(l){return me(l)}}async function u(R){try{let l=i(R,"probeSourcePreflight");if("status"in l)return l;let y=r().readTaskExecutorRef();if(!y)return ae("No task-executor registered for this board");try{let O={...l.src,_projections:l.mockProjections},w=await t.invokeExecutor(y,"probe-source-preflight",{timeout:l.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(O)}),_=JSON.parse(w.trim());return _.ok?ce({bindTo:l.bindTo,reachable:_.reachable,latencyMs:_.latencyMs,note:_.note}):ae(_.error??"Preflight probe failed")}catch{return ae("Executor does not support probe-source-preflight")}}catch(l){return me(l)}}async function b(R){try{let l=i(R,"runSourcePreflight");if("status"in l)return l;let y=r().readTaskExecutorRef();if(!y)return ae("No task-executor registered for this board");try{let O={...l.src,_projections:l.mockProjections},w=await t.invokeExecutor(y,"run-source-preflight",{timeout:l.src.timeout??t.executorTimeouts?.probeMs??6e4,input:JSON.stringify(O)}),_=JSON.parse(w.trim());if(!_.ok)return ce({bindTo:l.bindTo,ok:!1,result:null,issues:[_.error??"Preflight run failed"]});if(l.outRef){let m=Qe(l.outRef);t.absoluteBlob.write(m.value,JSON.stringify(_.resultValue,null,2));}return ce({bindTo:typeof _.bindTo=="string"?_.bindTo:l.bindTo,ok:!0,result:_.resultValue??null,issues:[]})}catch(O){let w=O instanceof Error?O.message:String(O);return ce({bindTo:l.bindTo,ok:!1,result:null,issues:[w]})}}catch(l){return me(l)}}async function A(R){try{let l=r().readTaskExecutorRef();if(!l)return ae("No task-executor registered for this board");let y=await t.invokeExecutor(l,"describe-capabilities",{timeout:t.executorTimeouts?.describeMs??1e4});return ce(JSON.parse(y.trim()))}catch(l){return me(l)}}function f(R){try{let l=R.body;if(!l||!Array.isArray(l.ops))return ae("updatesInCardStore requires body.ops array");let y=l.ops,O=o();for(let w of y){let _=w.op,m=w.id;if(!m)return ae('op is missing "id"');if(_==="update"){let p=w["card-content"];if(!p)return ae(`update op for "${m}" is missing "card-content"`);O.writeCard(m,p);}else return ae(`Unknown op type: "${_??"(none)"}"`)}return ce()}catch(l){return me(l)}}function g(R){try{let l=R.body;if(!l||!Array.isArray(l.ids))return ae("readFromCardStore requires body.ids array");let y=l.ids,O=o(),w=y.map(_=>({id:_,"card-content":O.readCard(_)}));return ce({cards:w})}catch(l){return me(l)}}function v(R){try{if(!R.body||typeof R.body!="object"||Array.isArray(R.body))return ae("evalCardCompute requires a JSON object in body");let l=R.body,y=l["card-content"]??l,O=typeof y.id=="string"?y.id:"(unknown)",w=l["mock-fetched-sources"]??{},_=l["mock-requires"]??{},m=y.compute;if(!m||!Array.isArray(m)||m.length===0)return ce({cardId:O,ok:!0,computed_values:{},errors:[]});let p={id:O,card_data:y.card_data??{},requires:_,source_defs:y.source_defs,compute:m},k=$e.runSync(p,{sourcesData:w}),S=k.node.computed_values??{},B=k.errors??[];return ce({cardId:O,ok:B.length===0,computed_values:S,errors:B})}catch(l){return me(l)}}async function C(R){try{if(!R.body||typeof R.body!="object"||Array.isArray(R.body))return ae("simulateCardCycle requires a JSON object in body");let l=R.body,y=l["card-content"]??l,O=typeof y.id=="string"?y.id:"(unknown)",w=l["mock-fetched-sources"]??{},_=l["mock-requires"]??{},m=await s(O,y),p=m.status==="success"?{isValid:m.data.isValid,issues:m.data.issues}:{isValid:!1,issues:[m.status==="fail"?m.error:"internal error"]},k=y.source_defs??[],S=y.card_data??{},B=[],x=[];if(k.length>0){B=$e.enrichSourcesSync(k,{card_data:S,requires:_});for(let M of B){let z=M.projections,oe=M._projections;if(z&&oe){for(let we of Object.keys(z))if(oe[we]===void 0){let T=typeof M.bindTo=="string"?M.bindTo:"(unknown)";x.push({bindTo:T,key:we,error:`Projection "${we}" resolved to undefined`});}}}}let h=[],D={...w},j=l["task-executor-ref"],X=(j?.howToRun&&j?.whatToRun?j:void 0)??r().readTaskExecutorRef();for(let M=0;M<B.length;M++){let z=B[M],oe=typeof z.bindTo=="string"?z.bindTo:`source_${M}`;if(!X){h.push({bindTo:oe,skipped:!0,error:"No task executor configured"});continue}try{let we={...z},T=await t.invokeExecutor(X,"run-source-preflight",{timeout:z.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(we)}),I=JSON.parse(T.trim());I.ok&&!Object.prototype.hasOwnProperty.call(w,oe)&&Object.prototype.hasOwnProperty.call(I,"resultValue")&&(D[oe]=I.resultValue),h.push({bindTo:oe,reachable:I.reachable,latencyMs:I.latencyMs,error:I.ok?void 0:I.error});}catch{h.push({bindTo:oe,skipped:!0,error:"Executor does not support run-source-preflight"});}}let N=y.compute,$={},Z=[];if(N&&Array.isArray(N)&&N.length>0){let M={id:O,card_data:S,requires:_,source_defs:y.source_defs,compute:N},z=$e.runSync(M,{sourcesData:D});$=z.node.computed_values??{},Z=z.errors??[];}let H=p.isValid&&x.length===0&&Z.length===0&&h.every(M=>M.reachable!==!1);return ce({cardId:O,ok:H,validation:p,source_probes:h,projection_errors:x,fetched_sources:D,computed_values:$,compute_errors:Z})}catch(l){return me(l)}}return {validateCardPreflight:a,probeSourcePreflight:u,runSourcePreflight:b,evalCardCompute:v,simulateCardCycle:C,describeTaskExecutorCapabilities:A,updatesInCardStore:f,readFromCardStore:g}}async function mn(e,t,r){let n=await e.tryAcquire();if(!n)return false;try{await t();}finally{await n();}return await r?.(),true}function gn(e){async function t(r){let n=await e.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {async readTaskExecutorRef(){let r=await t("task-executor");if(r?.trim())return jt(r.trim())},writeTaskExecutorRef(r){return e.write("task-executor",qt(r))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){return e.write("chat-handler-flow",r)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){return e.write("card-store-ref",r)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){return e.write("outputs-store-ref",r)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){return e.write("scratch-store-ref",r)},readArchiveStoreRef(){return t("archive-store-ref")},writeArchiveStoreRef(r){return e.write("archive-store-ref",r)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){return e.write("chat-store-ref",r)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){return e.write("artifacts-store-ref",r)}}}function Eo(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Yt(e,t){return Eo(e)?e.then(t):t(e)}function yn(e,t){let r={...e};for(let[n,o]of Object.entries(t))o!==null&&typeof o=="object"&&!Array.isArray(o)&&r[n]!==null&&typeof r[n]=="object"&&!Array.isArray(r[n])?r[n]=yn(r[n],o):r[n]=o;return r}function Xt(e,t,r){if(t.length===0)return e;let[n,...o]=t;if(o.length===0)return {...e,[n]:r};let s=e[n]!==null&&typeof e[n]=="object"&&!Array.isArray(e[n])?e[n]:{};return {...e,[n]:Xt(s,o,r)}}function hn(e){return {read:r=>e.read(r),get(r,n){return Yt(e.read(r),o=>{if(o===null)return null;let s=o;for(let i of n.split(".").filter(Boolean)){if(s===null||typeof s!="object"||Array.isArray(s))return null;s=s[i]??null;}return s??null})},write:(r,n)=>e.write(r,n),delete:r=>e.delete(r),listKeys:r=>e.listKeys(r),shallowMerge(r,n){return Yt(e.read(r),o=>e.write(r,{...o??{},...n}))},deepMerge(r,n){return Yt(e.read(r),o=>e.write(r,yn(o??{},n)))},patch(r,n,o){return Yt(e.read(r),s=>{let i=n.split(".").filter(Boolean);return e.write(r,Xt(s??{},i,o))})}}}function Zt(e){return hn(e)}function er(e,t){return {async readIndex(){return await e.read("_index")},writeIndex(r){return e.write("_index",r)},async readCard(r){return await e.read(r)},async writeCard(r,n){return await e.write(r,n),t(n)},removeCard(r){return e.delete(r)},async cardExists(r){return await e.read(r)!==null},defaultCardKey(r){return r}}}function tr(e,t){async function r(){return await e.readIndex()??{}}return {async readCard(n){let o=(await r())[n];return !o||!await e.cardExists(o.key)?null:await e.readCard(o.key)},async readCardKey(n){return (await r())[n]?.key??null},async readAllCards(){let n=[];for(let[o,s]of Object.entries(await r())){if(!await e.cardExists(s.key))continue;let i=await e.readCard(s.key);i?n.push(i):t?.(`[card-store] could not read card "${o}" at key "${s.key}"`);}return n},async readChecksumIndex(){let n={};for(let[o,s]of Object.entries(await r()))n[o]=s.checksum;return n},async changedSince(n){let o=await r(),s=[];for(let[i,a]of Object.entries(o))n[i]!==a.checksum&&s.push(i);for(let i of Object.keys(n))o[i]||s.push(i);return s},async validateUpsert(n,o){let s=await r(),i=s[n],a=Object.entries(s).find(([,u])=>u.key===o);return i&&i.key!==o?{ok:false,error:`Card id "${n}" is already mapped to key "${i.key}", cannot remap to "${o}"`}:a&&a[0]!==n?{ok:false,error:`Key "${o}" is already mapped to card id "${a[0]}", cannot remap to "${n}"`}:{ok:true}},async writeCard(n,o,s){let i=await r(),a=s??i[n]?.key??e.defaultCardKey(n),u=await e.writeCard(a,o);i[n]={key:a,checksum:u,updatedAt:new Date().toISOString()},await e.writeIndex(i);},async patchCard(n,o,s){let i=await r(),a=i[n];if(!a||!await e.cardExists(a.key))throw new Error(`card "${n}" not found`);let u=await e.readCard(a.key);if(!u||typeof u!="object"||Array.isArray(u))throw new Error(`card "${n}" is not patchable`);let b=String(o||"").split(".").filter(Boolean),A=Xt(u,b,s),f=await e.writeCard(a.key,A);i[n]={key:a.key,checksum:f,updatedAt:new Date().toISOString()},await e.writeIndex(i);},async removeCard(n){let o=await r(),s=o[n];s&&(await e.removeCard(s.key),delete o[n],await e.writeIndex(o));},readIndex(){return r()}}}function Ie(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function Re(e){return {status:"fail",error:e}}function Te(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function Ue(){return new Date().toISOString()}function Oo(e){let t=new TextEncoder().encode(e),r=Array.from(t,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Cn(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function rr(e){try{let t=JSON.parse(Cn(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function Bo(e){return Oo(JSON.stringify(e))}function kn(e){try{let t=JSON.parse(Cn(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function Fo(e){return Ut(e,Cr,()=>({_sources:{}}))}function qo(e,t){return Nt(e,t)}function jo(e){return Vt(e)}function Lo(e,t){return $t(e,t)}function Do(e,t,r,n,o,s){return async i=>{let a=[],u=await r.cardStore.readCard(i.nodeId);if(!u)return "task-initiate-failure";let b=u.id,A=u.card_data??{},f=u.source_defs??[],g=f.filter(N=>N.optionalForCompletionGating!==true),v=await r.cardRuntimeStore.readRuntime(b),C=false,R=async()=>{C&&(await r.cardRuntimeStore.writeRuntime(b,v),C=false);},l=N=>bt(v._sources[N]),y=(N,$)=>{v._sources[N]=bt($),C=true;},O=i.taskState?.executionCount??0;if(v._lastExecutionCount!==O&&(v._sources={},v._lastExecutionCount=O,C=true),i.update){let N=i.update.outputFile;if(N){let $=l(N);if(i.update.failure){let Z=i.update.rqt??$.lastRequestedToken??$.queueRequestedToken;Z&&y(N,At($,Z));}else {let Z=i.update.rqt;if(!$.lastCompletedToken||Z>$.lastCompletedToken){let H=typeof i.update.deliveryToken=="string"?i.update.deliveryToken:void 0,M=H?await r.fetchedSourcesStore.commitSourceData(b,N,H):false;y(N,M?wr($,Z):At($,Z));}}await R();}}let w={};for(let N of f){if(!N.outputFile)continue;let $=await r.fetchedSourcesStore.readSourceData(b,N.outputFile);$!==null&&(w[N.bindTo]=$);}let _={};for(let[N,$]of Object.entries(i.state??{}))if($!==null&&typeof $=="object"&&!Array.isArray($)){let Z=$[N];_[N]=Z!==void 0?Z:$;}else _[N]=$;let m={id:b,card_data:{...A},requires:_,source_defs:f,compute:u.compute};m._sourcesData=w,u.compute&&$e.runSync(m,{sourcesData:w}),(o??(()=>{}))(b,m.computed_values??{});let p=$e.enrichSourcesSync(Array.isArray(u.source_defs)?u.source_defs:void 0,{card_data:u.card_data,requires:_}),k={...u,source_defs:Array.isArray(p)?p.map(N=>({...N,boardDir:typeof N.boardDir=="string"&&N.boardDir?N.boardDir:e.value})):p},S=Ue(),B=i.update?void 0:S,x=g.filter(N=>{let $=N.outputFile;if(typeof $!="string"||!$)return true;let Z=l($);B&&(Z={...Z,queueRequestedToken:B},y($,Z));let H=Z.queueRequestedToken??Z.lastRequestedToken??S;return vt(Z,H)==="dispatch"});if(await R(),x.length>0){let N=false,$=S;for(let Z of x){let H=Z.outputFile;if(typeof H!="string"||!H)continue;let M=l(H),z=M.queueRequestedToken??S;y(H,{...M,lastRequestedToken:z}),$=z,N=true;}return N&&await R(),N&&(a.push({taskKind:"source-fetch",payload:{boardRef:ve(e),enrichedCard:k,callbackToken:i.callbackToken,rqt:$}}),await r.executionRequestStore.appendEntries(t,a)),"task-initiated"}if(g.some(N=>{let $=N.outputFile;if(typeof $!="string"||!$)return false;let Z=l($),H=Z.queueRequestedToken??Z.lastRequestedToken??S;return vt(Z,H)==="in-flight"}))return "task-initiated";let D=u.provides??[],j={};for(let{bindTo:N,ref:$}of D)j[N]=$e.resolve(m,$);return (s??(()=>{}))(j),f.filter(N=>{if(N.optionalForCompletionGating!==true)return false;let $=l(N.outputFile);return !$.lastRequestedToken||!$.lastCompletedToken?true:$.lastCompletedToken<=$.lastRequestedToken}).length>0&&a.push({taskKind:"source-fetch",payload:{boardRef:ve(e),enrichedCard:k,callbackToken:i.callbackToken,rqt:S}}),n(i.nodeId,j),a.length>0&&await r.executionRequestStore.appendEntries(t,a),"task-initiated"}}function Rn(e,t){_t(t.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=t.callbackTransport,n=t.warn??(()=>{}),o=ve(e),s=null;function i(x){if(x.length!==0)try{return Promise.resolve(t.publishBoardChangeNotifications?.(x)).catch(h=>{n(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${h instanceof Error?h.message:String(h)}`);})}catch(h){n(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${h instanceof Error?h.message:String(h)}`);return}}let a=()=>gn(t.kvStorage("config")),u=()=>t.kvStorage("state-snapshot"),b=e.value,A=()=>Dt(hr(()=>u(),t.hashFn),"v1"),f=async()=>{let x=await a().readOutputsStoreRef();if(!x)throw new Error(`Board at ${e.value} has no outputs store configured.`);return jo(t.kvStorageForRef(x))},g=async()=>{let x=await a().readCardStoreRef();if(!x)throw new Error(`Board at ${e.value} has no card store configured.`);let h=t.kvStorageForRef(x);return tr(er(Zt(h),t.hashFn),n)};async function v(){return !!(await A().readSnapshot(b)).values[Ye]}async function C(){let x=await A().readSnapshot(b);if(!x.values[Ye])throw new Error(`Board not initialized at ${e.value}`);return Gt(x.values)}async function R(x,h){let D=await A().commitSnapshot(b,{schemaVersion:"v1",expectedVersion:h,deleteKeys:[],shallowMerge:Jt(x)});if(!D.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${h??"null"} current=${D.currentVersion??"null"}`)}let l=()=>en(t.journalStorage());async function y(x){await l().appendEvent(x);}function O(){return qo(t.blobStorage("sources"),x=>t.resolveBlob(x))}async function w(x){let h=await Promise.resolve(t.blobStorage("sources").keyRef?.(x));return h?ve(h):x}async function _(){let x=Lo(t.kvStorage("execution-requests"),async(c,E)=>{let L=c.payload,ne=(L.enrichedCard??{}).id??L.cardId??"unknown";await y({type:"task-failed",taskName:ne,error:E,timestamp:Ue()});}),h=Fo(t.kvStorage("card-runtime")),D=O(),j=await g(),X=await f(),N=new Map,$=new Map,Z=[],H=[],M=[],z=new Map,oe=new Set,we={async readRuntime(c){return N.get(c)??await h.readRuntime(c)},async writeRuntime(c,E){N.set(c,E);}},T={async readSourceData(c,E){let L=`${c}/${E}`;return $.has(L)?$.get(L):await D.readSourceData(c,E)},ingestSourceDataStaged(c,E,L,ee){return D.ingestSourceDataStaged(c,E,L,ee)},async commitSourceData(c,E,L){let ee=`${c}/.staged/${L}/${E}`,ne=t.blobStorage("sources"),te=await ne.read(ee);if(te==null){let be=await ne.keyRef?.(ee);be&&(te=await t.resolveBlob(be));}if(te==null)return false;let le=`${c}/${E}`,Se=te.trim();try{$.set(le,JSON.parse(Se));}catch{$.set(le,Se);}return Z.push({cardId:c,outputFile:E,deliveryToken:L}),true},async hasSource(c,E){let L=`${c}/${E}`;return $.has(L)||await D.hasSource(c,E)},async listSources(c){let E=await D.listSources(c),L=[...$.keys()].filter(ee=>ee.startsWith(`${c}/`)).map(ee=>ee.slice(`${c}/`.length));return [...new Set([...E,...L])]}},I=await C(),U=dt(I.graph),{events:J,newCursor:G}=await l().readEntriesAfterCursor(I.lastDrainedJournalId),re=J,de=Ot(U,{handlers:{"card-handler":Do(e,G,{cardStore:j,cardRuntimeStore:we,fetchedSourcesStore:T,executionRequestStore:x},(c,E)=>{re.push({type:"task-completed",taskName:c,data:E,timestamp:Ue()});},(c,E)=>{H.push({cardId:c,values:E});},c=>{M.push(c);})},onNodeRemoved:c=>{z.delete(c),N.delete(c),oe.add(c);}});for(;re.length>0;){let c=re;re=[];for(let E of c)if(E.type==="task-restart"){let L=await j.readCard(E.taskName);L&&z.set(E.taskName,L);}de.pushAll(c),await de.waitForHandlers();}let pe=de.getState();await de.dispose({wait:true}),await R({lastDrainedJournalId:G,graph:it(pe)},(await A().readSnapshot(b)).version);for(let{cardId:c,values:E}of H)await X.writeComputedValues(c,E);for(let c of M)await X.writeDataObjects(c);for(let[c,E]of N)await h.writeRuntime(c,E);for(let c of Z)await D.commitSourceData(c.cardId,c.outputFile,c.deliveryToken);let ye=ct(o,pe);await X.writeStatusSnapshot(ye);let he=[];for(let{cardId:c,values:E}of H)he.push({kind:"computed_values",cardId:c,values:E});for(let c of M)for(let[E,L]of Object.entries(c))he.push({kind:"data_object",key:E,payload:L});for(let[c,E]of z)he.push({kind:"card_refreshed",cardId:c,card:E});for(let c of oe)he.push({kind:"card_removed",cardId:c});he.push({kind:"status",status:ye}),await i(he);let xe=await a().readTaskExecutorRef();if(!xe)return;let q=t.supportsDirectSourceOutput?.(xe)===true;await x.dispatchEntriesForJournalId(G,async c=>{if(c.taskKind!=="source-fetch"){n(`[async-process-accumulated-events] unknown taskKind "${c.taskKind}" \u2014 skipping`);return}let E=c.payload,L=E.enrichedCard?.id??"unknown",ee=E.enrichedCard?.source_defs??[];for(let ne of ee){if(!ne.outputFile)continue;let te;if(q){let be=t.genId(),Ve=`${L}/.staged/${be}/${ne.outputFile}`,je=await Promise.resolve(t.blobStorage("sources").keyRef?.(Ve));je&&(te={ref:ve(je),deliveryToken:be,outputFile:ne.outputFile,cardId:L});}let le=Bo({cbk:E.callbackToken,rg:e.value,br:ve(e),cid:L,b:ne.bindTo,d:ne.outputFile,cs:void 0,rqt:E.rqt,...te?{dt:te.deliveryToken}:{}}),Se=await t.dispatchExecution(xe,{source_def:ne,base_ref:ve(e),callback:r.createCallback(le),...te?{output:te}:{}});Se.dispatched||await y({type:"task-failed",taskName:L,error:Se.error??"dispatch failed",timestamp:Ue()});}});}async function m(){try{let x=async()=>{let D=await C(),{events:j}=await l().readEntriesAfterCursor(D.lastDrainedJournalId);j.length>0&&await k();},h=await mn(t.lock,_,x);return Ie({ran:h!==!1})}catch(x){return Te(x)}}async function p(){return s||(s=m().finally(()=>{s=null;}),s)}async function k(){let x=t.processAccumulatedStore();x.enqueueIfAbsent?await x.enqueueIfAbsent({boardRef:ve(e)},`process-accumulated:${ve(e)}`):await x.enqueue({boardRef:ve(e)}),await t.requestProcessAccumulated?.();}async function S(){let x=t.processAccumulatedStore();for(;;){let h=await x.lease({max:64,visibilityMs:1e3});if(h.length<=0)return;for(let D of h)await x.ack(D.id,D.leaseToken);if(h.length<64)return}}function B(){k();}return {async init(x){try{let h=x.params?.cardStoreRef;if(!h)return Re("init requires params.cardStoreRef");let D=x.params?.outputsStoreRef;if(!D)return Re("init requires params.outputsStoreRef");await v()||await R({lastDrainedJournalId:"",graph:it(gt(It))},null);let j=a();await j.writeCardStoreRef(h),await j.writeOutputsStoreRef(D);let X=x.params?.scratchStoreRef,N=x.params?.archiveStoreRef,$=x.params?.chatStoreRef,Z=x.params?.artifactsStoreRef;X&&await j.writeScratchStoreRef(X),N&&await j.writeArchiveStoreRef(N),$&&await j.writeChatStoreRef($),Z&&await j.writeArtifactsStoreRef(Z);let H=x.body??{};return H["task-executor-ref"]&&await j.writeTaskExecutorRef(H["task-executor-ref"]),Object.prototype.hasOwnProperty.call(H,"chat-handler-flow")&&await j.writeChatHandlerFlow(H["chat-handler-flow"]),await(await f()).writeStatusSnapshot(ct(o,dt((await C()).graph))),Ie()}catch(h){return Te(h)}},async status(x){try{let h=await f(),D=await h.readStatusSnapshot();return D||(D=ct(o,dt((await C()).graph)),await h.writeStatusSnapshot(D)),Ie(D)}catch(h){return Te(h)}},async getCardStoreRef(x){try{let h=await a().readCardStoreRef();return h?Ie({storeRef:h}):Re(`Board at ${e.value} has no card store configured`)}catch(h){return Te(h)}},async getOutputsStoreRef(x){try{let h=await a().readOutputsStoreRef();return h?Ie({storeRef:h}):Re(`Board at ${e.value} has no outputs store configured`)}catch(h){return Te(h)}},async getScratchStoreRef(x){try{return Ie({storeRef:await a().readScratchStoreRef()})}catch(h){return Te(h)}},async getArchiveStoreRef(x){try{return Ie({storeRef:await a().readArchiveStoreRef()})}catch(h){return Te(h)}},async getChatStoreRef(x){try{return Ie({storeRef:await a().readChatStoreRef()})}catch(h){return Te(h)}},async getArtifactsStoreRef(x){try{return Ie({storeRef:await a().readArtifactsStoreRef()})}catch(h){return Te(h)}},async getConfig(x){try{let h=x.params?.key;if(!h)return Re("getConfig requires params.key");let D=a(),j;switch(h){case "task-executor":j=await D.readTaskExecutorRef()??null;break;case "chat-handler-flow":j=await D.readChatHandlerFlow()??null;break;case "card-store-ref":j=await D.readCardStoreRef();break;case "outputs-store-ref":j=await D.readOutputsStoreRef();break;case "scratch-store-ref":j=await D.readScratchStoreRef();break;case "archive-store-ref":j=await D.readArchiveStoreRef();break;case "chat-store-ref":j=await D.readChatStoreRef();break;case "artifacts-store-ref":j=await D.readArtifactsStoreRef();break;default:return Re(`getConfig: unknown key "${h}"`)}return Ie({value:j})}catch(h){return Te(h)}},async getOutputsDataObject(x){try{let h=x.params?.key;return h?Ie(await(await f()).readDataObject(h)):Re("getOutputsDataObject requires params.key")}catch(h){return Te(h)}},async getAllOutputsDataObjects(x){try{return Ie(await(await f()).readAllDataObjects())}catch(h){return Te(h)}},async getOutputsComputedValues(x){try{let h=x.params?.key;return h?Ie(await(await f()).readComputedValues(h)):Re("getOutputsComputedValues requires params.key")}catch(h){return Te(h)}},async getAllOutputsComputedValues(x){try{return Ie(await(await f()).readAllComputedValues())}catch(h){return Te(h)}},async getOutputsFetchedSources(x){try{let h=x.params?.key;if(!h)return Re("getOutputsFetchedSources requires params.key");let D=await O().listSources(h),j={};for(let X of D)j[X]=await w(`${h}/${X}`);return Ie(j)}catch(h){return Te(h)}},async getAllOutputsFetchedSources(x){try{let h=O(),D=await t.blobStorage("sources").listKeys(),j=new Set;for(let N of D){let $=N.indexOf("/");$>0&&!N.includes("/.staged/")&&j.add(N.slice(0,$));}let X={};for(let N of j){let $=await h.listSources(N);if($.length!==0){X[N]={};for(let Z of $)X[N][Z]=await w(`${N}/${Z}`);}}return Ie(X)}catch(h){return Te(h)}},async addCardFiles(x){try{let h=x.params?.cardId;if(!h)return Re("addCardFiles requires params.cardId");let D=await g(),j=await D.readCard(h);if(!j)return Re(`card "${h}" not found`);let X=x.body,N=Array.isArray(X)?X:X&&typeof X=="object"&&Array.isArray(X.files)?X.files:X!=null?[X]:null;if(!N||N.length===0)return Re("addCardFiles requires a file metadata object, array, or body.files array");let $=j.card_data&&typeof j.card_data=="object"&&!Array.isArray(j.card_data)?j.card_data:{},Z=Array.isArray($.files)?$.files:[],H=[...Z,...N],M=N.map((oe,we)=>({idx:Z.length+we,entry:oe}));await D.writeCard(h,{...j,card_data:{...$,files:H}});let z=await this.cardRefreshedNotify({params:{cardId:h}});return z.status!=="success"?z:Ie({cardId:h,files_added:M,notified:!0})}catch(h){return Te(h)}},async cardRefreshedNotify(x){try{let h=x.params?.cardId;if(!h)return Re("cardRefreshedNotify requires params.cardId");let D=await(await g()).readCard(h);return D?(await i([{kind:"card_refreshed",cardId:h,card:D}]),Ie({cardId:h,notified:!0})):Re(`Card "${h}" not found in board at ${e.value}`)}catch(h){return Te(h)}},async removeCard(x){try{let h=x.params?.id;if(!h)return Re("removeCard requires params.id");try{await t.kvStorage("card-upsert").delete(h);}catch{}return await y({type:"task-removal",taskName:h,timestamp:Ue()}),B(),Ie()}catch(h){return Te(h)}},async retrigger(x){try{let h=x.params?.id;return h?(await y({type:"task-restart",taskName:h,timestamp:Ue()}),B(),Ie()):Re("retrigger requires params.id")}catch(h){return Te(h)}},async processAccumulatedEvents(x){return await S(),p()},async upsertCard(x){try{let h=x.params?.cardId,D=x.params?.all,j=!!x.params?.restart;if(!h&&!D)return Re("upsertCard requires --card-id <id> or --all");let X=await g(),N=D?(await X.readAllCards()).map(Z=>Z.id):[h];for(let Z of N)if(!await X.readCard(Z))return Re(`Card "${Z}" not found in board at ${e.value}`);let $=t.kvStorage("card-upsert");for(let Z of N){let H=await X.readCard(Z);if(!H)continue;let M=Wt(H),z=t.hashFn(M),oe=await $.read(Z),we=oe?.taskConfigHash!==z;if(!(!we&&!j)){if(we){let T=oe?.blobRef??await X.readCardKey(Z)??Z;await y({type:"task-upsert",taskName:Z,taskConfig:M,timestamp:Ue()}),await $.write(Z,{blobRef:T,taskConfigHash:z,updatedAt:Ue()});}j&&await y({type:"task-restart",taskName:Z,timestamp:Ue()});}}return B(),Ie()}catch(h){return Te(h)}},async taskFailed(x){try{let h=x.params?.token;if(!h)return Re("taskFailed requires params.token");let D=x.params?.error??"unknown error",j=rr(h);return j?(await y({type:"task-failed",taskName:j.taskName,error:D,timestamp:Ue()}),B(),Ie()):Re("Invalid callback token")}catch(h){return Te(h)}},async taskProgress(x){try{let h=x.params?.token;if(!h)return Re("taskProgress requires params.token");let D=(x.body??{}).update??{},j=rr(h);return j?(await y({type:"task-progress",taskName:j.taskName,update:D,timestamp:Ue()}),B(),Ie()):Re("Invalid callback token")}catch(h){return Te(h)}},async sourceDataFetched(x){try{let h=x.params?.token,D=x.params?.ref;if(!h)return Re("sourceDataFetched requires params.token");if(!D)return Re("sourceDataFetched requires params.ref");let j=kn(h);if(!j)return Re("Invalid source token");let X=O(),N=j.dt||t.genId();j.dt||await X.ingestSourceDataStaged(j.cid,j.d,Qe(D),N);let $=rr(j.cbk);return $?(await y({type:"task-progress",taskName:$.taskName,update:{bindTo:j.b,outputFile:j.d,fetchedAt:Ue(),deliveryToken:N,sourceChecksum:j.cs,rqt:j.rqt},timestamp:Ue()}),B(),Ie()):Re("Invalid callback token embedded in source token")}catch(h){return Te(h)}},async sourceDataFetchFailure(x){try{let h=x.params?.token,D=x.params?.reason??"unknown";if(!h)return Re("sourceDataFetchFailure requires params.token");let j=kn(h);if(!j)return Re("Invalid source token");let X=rr(j.cbk);return X?(await y({type:"task-progress",taskName:X.taskName,update:{bindTo:j.b,outputFile:j.d,failure:!0,reason:D,sourceChecksum:j.cs,rqt:j.rqt},timestamp:Ue()}),B(),Ie()):Re("Invalid callback token embedded in source token")}catch(h){return Te(h)}}}}function wn(){return new Date().toISOString()}function Sn(e){return new TextEncoder().encode(e).byteLength}function Mo(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function bn(e){function t(r){let n=e.stat?Mo(e.stat(r)):null;if(n)return n;if(!e.exists(r))return null;let o=e.read(r);return o===null?{key:r}:{key:r,size:Sn(o)}}return {exists(r){return e.exists(r)},putText(r,n,o="text/plain; charset=utf-8"){e.write(r,n);let s=t(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??wn(),s.size=s.size??Sn(n),s},putBytes(r,n,o="application/octet-stream"){if(e.writeBytes)e.writeBytes(r,n);else {let i=JSON.stringify({__kind:"bytes-array",data:[...n]});e.write(r,i);}let s=t(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??wn(),s.size=s.size??n.byteLength,s},getText(r){let n=e.read(r);if(n===null){if(!e.readBytes)return null;let o=e.readBytes(r);return o===null?null:Buffer.from(o).toString("utf-8")}try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new TextDecoder("utf-8").decode(new Uint8Array(o.data))}catch{}return n},getBytes(r){if(e.readBytes){let o=e.readBytes(r);if(o!==null)return o}let n=e.read(r);if(n===null)return null;try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new Uint8Array(o.data)}catch{}return new TextEncoder().encode(n)},head:t,list(r=""){return e.listKeys(r).map(n=>t(n)??{key:n}).sort((n,o)=>n.key.localeCompare(o.key))},remove(r){e.remove(r);}}}function vn(){function e(o,s){if(!Array.isArray(o))return [];let i=[];for(let a of o){if(!a||typeof a!="object")continue;let u=a;typeof u.stored_name=="string"&&i.push({name:typeof u.name=="string"?u.name:u.stored_name,stored_name:u.stored_name,size:typeof u.size=="number"&&Number.isFinite(u.size)?u.size:null,mime_type:typeof u.mime_type=="string"?u.mime_type:null,uploaded_at:typeof u.uploaded_at=="string"?u.uploaded_at:s||null,chat:u.chat===true});}return i}function t(o){return !o||typeof o!="object"?[]:e(o.files,void 0)}function r(o,s){let i=t(o);if(s.length===0)return o.files=i,i;let a=new Set(i.map(u=>u.stored_name));for(let u of s)a.has(u.stored_name)||(i.push(u),a.add(u.stored_name));return o.files=i,i}function n(o,s,i){let a=t(o);if(!Number.isInteger(s)||s<0||s>=a.length)return {ok:false,reason:"index_out_of_range"};let u=a[s];return !u||!u.stored_name?{ok:false,reason:"missing_stored_name"}:i&&i!==u.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:u}}return {read:t,normalizeIncoming:e,merge:r,resolve:n}}function No(){let e=globalThis.crypto;return typeof e?.randomUUID=="function"?String(e.randomUUID()):`id-${Date.now()}-${Math.random().toString(36).slice(2)}`}function An(){let e=new Map,t=new Map;function r(n){return e.has(n)||e.set(n,[]),e.get(n)}return {append(n,o,s,i=[],a=""){let u={id:No(),role:o,text:s,files:i,turn:a,updated_at:new Date().toISOString()};return r(n).push(u),u.id},readAll(n){return r(n).slice()},readAfter(n,o){let s=r(n);if(!o)return {records:s.slice(),cursor:s.length>0?s[s.length-1].id:null};let i=s.findIndex(u=>u.id===o),a=i===-1?s.slice():s.slice(i+1);return {records:a,cursor:a.length>0?a[a.length-1].id:o}},clear(n){e.set(n,[]);},setProcessing(n,o){o?t.set(`p:${n}`,true):t.delete(`p:${n}`);},isProcessing(n){return t.get(`p:${n}`)===true},getConfig(n){return t.get(`c:${n}`)??{}},setConfig(n,o){let s=t.get(`c:${n}`)??{};t.set(`c:${n}`,{...s,...o});}}}function xn(e){function t(f){let g=typeof f=="number"?f:Number(f);return Number.isInteger(g)&&g>0?g:null}function r(f,g){let v=g;for(let C=f.length-1;C>=0;C-=1)if(f[C]?.role==="user"&&(v-=1,v===0))return f.slice(C);return f}function n(f){return f.some(g=>typeof g?.turn=="string"&&g.turn!=="")}function o(f,g){if(g<=0)return [];if(!n(f))return r(f,g);let v=new Map,C=[];for(let l of f){let y=typeof l?.turn=="string"?l.turn:"";v.has(y)||(v.set(y,[]),C.push(y)),v.get(y).push(l);}return C.slice(Math.max(0,C.length-g)).flatMap(l=>v.get(l)??[])}function s(f){return {status:"success",data:f}}function i(f){return {status:"fail",error:f}}function a(f){return {status:"error",error:f instanceof Error?f.message:String(f)}}function u(f,g="command envelope"){let v=typeof f.cardId=="string"?f.cardId:void 0;if(!f.command)return i(`chat-store: ${g} missing "command"`);if(!v)return i(`chat-store: ${g} missing "cardId"`);if(f.command==="append")return A.append({params:{cardId:v},body:{role:f.role,text:f.text,files:f.files,turn:f.turn}});if(f.command==="read-all")return A.readAll({params:{cardId:v},body:{lastUserTurns:f.lastUserTurns,tailTurns:f.tailTurns,turnId:f.turnId,allTurns:f.allTurns,tailTurnsBeforeId:f.tailTurnsBeforeId}});if(f.command==="read-after")return A.readAfter({params:{cardId:v},body:{cursor:f.cursor??null}});if(f.command==="clear")return A.clear({params:{cardId:v}});if(f.command==="set-processing")return A.setProcessing({params:{cardId:v},body:{active:f.active}});if(f.command==="is-processing")return A.isProcessing({params:{cardId:v}});if(f.command==="get-config")return A.getConfig({params:{cardId:v}});if(f.command==="set-config"){let{command:C,cardId:R,...l}=f;return A.setConfig({params:{cardId:v},body:l})}return i(`chat-store: unknown command "${String(f.command)}"`)}function b(f){if(!Array.isArray(f.commands)||f.commands.length===0)return i('chat-store: command envelope must include a non-empty "commands" array');let g=[];for(let v=0;v<f.commands.length;v+=1){let C=f.commands[v];if(!C||typeof C!="object"||Array.isArray(C))return i(`chat-store: command envelope entry ${v} must be an object`);let R={cardId:f.cardId,...C},l=u(R,`command envelope entry ${v}`);if(l.status!=="success")return l;g.push({index:v,command:String(R.command),data:l.data});}return s({results:g})}let A={append(f){try{let g=f.params?.cardId;if(!g)return i("append requires params.cardId");let v=f.body??{},C=typeof v.role=="string"?v.role:"",R=typeof v.text=="string"?v.text:"",l=Array.isArray(v.files)?v.files:[],y=typeof v.turn=="string"?v.turn:"";if(!C)return i("append requires body.role");let O=e.append(g,C,R,l,y);return s({id:O})}catch(g){return a(g)}},readAll(f){try{let g=f.params?.cardId;if(!g)return i("readAll requires params.cardId");let v=f.body??{},C=typeof v.turnId=="string"?v.turnId:"",R=v.allTurns===!0,l=typeof v.tailTurnsBeforeId=="string"?v.tailTurnsBeforeId:"",y=v.tailTurns===void 0?v.lastUserTurns:v.tailTurns,O=y===void 0?R||C?void 0:1:t(y);if(y!==void 0&&O===null)return i("readAll requires body.tailTurns (positive integer)");let w=e.readAll(g),_=w.filter(m=>!C||String(m.turn||"")===C);if(l){let m=O;if(typeof m!="number"||!Number.isInteger(m)||m<=0)return i("readAll requires body.tailTurns (positive integer) when body.tailTurnsBeforeId is provided");let p=new Map,k=[];for(let h of w){let D=String(h.turn||"");p.has(D)||(p.set(D,[]),k.push(D)),p.get(D).push(h);}let S=k.findIndex(h=>h===l),B=Math.max(0,S-m);return _=(S===-1?[]:k.slice(B,S)).flatMap(h=>p.get(h)??[]),s({records:_})}return s(typeof O=="number"?{records:o(_,O)}:{records:_})}catch(g){return a(g)}},readAfter(f){try{let g=f.params?.cardId;if(!g)return i("readAfter requires params.cardId");let C=(f.body??{}).cursor??null;return s(e.readAfter(g,C))}catch(g){return a(g)}},clear(f){try{let g=f.params?.cardId;return g?(e.clear(g),s({ok:!0})):i("clear requires params.cardId")}catch(g){return a(g)}},setProcessing(f){try{let g=f.params?.cardId;if(!g)return i("setProcessing requires params.cardId");let v=f.body??{};return typeof v.active!="boolean"?i("setProcessing requires body.active (boolean)"):(e.setProcessing(g,v.active),s({ok:!0}))}catch(g){return a(g)}},isProcessing(f){try{let g=f.params?.cardId;return g?s({active:e.isProcessing(g)}):i("isProcessing requires params.cardId")}catch(g){return a(g)}},getConfig(f){try{let g=f.params?.cardId;return g?s({config:e.getConfig(g)}):i("getConfig requires params.cardId")}catch(g){return a(g)}},setConfig(f){try{let g=f.params?.cardId;if(!g)return i("setConfig requires params.cardId");let v=f.body??{};return e.setConfig(g,v),s({ok:!0})}catch(g){return a(g)}},run:u,runBatch:b};return A}function In(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Sr(e){if(!e||typeof e!="object")return false;let t=e.summary;return !t||typeof t!="object"?false:Number(t.card_count||0)>0}function br(e,t){if(!t||typeof t!="object")return;let r=t;if(r.kind==="notification-batch"&&Array.isArray(r.notifications)){for(let n of r.notifications)br(e,n);return}r.kind==="status"&&Sr(r.status)&&(e.status=r.status),r.kind==="computed_values"&&r.cardId&&(e.computedValues[r.cardId]=r.values),r.kind==="data_object"&&r.key&&(e.dataObjects[r.key]=r.payload),r.kind==="card_refreshed"&&r.cardId&&(e.cards[r.cardId]=r.card),r.kind==="card_removed"&&r.cardId&&(delete e.cards[r.cardId],delete e.computedValues[r.cardId]);}function Tn(e){let t=new Map,r=new Map,n=new Map,o=0,s=null;function i(m){let p=JSON.stringify(m);return o++,`id: ${o}
2
+ data: ${p}
3
+
4
+ `}function a(m){let p=m;try{p.flushHeaders?.();}catch{}try{p.flush?.();}catch{}try{p.socket?.setNoDelay?.(!0);}catch{}try{p.socket?.uncork?.();}catch{}}function u(m,p){let k=t.get(m);if(k&&!(p&&k.res!==p)){t.delete(m),R();try{e.onSseClientDisconnected?.(m);}catch{}try{k.res.end();}catch{}}}function b(m,p,k){let S=t.get(m);S&&u(m,S.res),t.set(m,{res:p,subscribedChatCardIds:k??new Set});}function A(m,p){let k=t.get(m);if(!k)return;let S=i(p);try{k.res.write(S),a(k.res);}catch{u(m,k.res);}}function f(){let m=new Set;for(let p of t.values())for(let k of p.subscribedChatCardIds)m.add(k);return Array.from(m)}function g(m){let p=r.has(m)?r.get(m):null,{cursor:k}=e.chatStorage.readAfter(m,p),S=e.chatStorage.isProcessing(m),B=S!==(n.get(m)??false),x=k!==p;return x&&r.set(m,k),n.set(m,S),x||B}function v(m,p){let k=e.readChatRecords(m),S=Date.now();return {kind:"card_chats",cardId:m,sentAt:new Date(S).toISOString(),sentAtMs:S,messages:k.map(B=>({role:String(B.role||"system"),text:String(B.text||""),files:Array.isArray(B.files)?B.files:[]})),receiving:p,processing:e.chatStorage.isProcessing(m)}}function C(m,p=true){let k={kind:"notification-batch",notifications:[v(m,p)]};for(let[S,B]of t.entries())B.subscribedChatCardIds.has(m)&&A(S,k);}function R(){f().length>0||(s&&(clearInterval(s),s=null),r.clear(),n.clear());}function l(){if(s)return;let m=()=>{let p=f();if(p.length===0){R();return}let k=new Set(p);for(let S of Array.from(r.keys()))k.has(S)||r.delete(S);for(let S of Array.from(n.keys()))k.has(S)||n.delete(S);for(let S of p)g(S)&&C(S,true);};m(),s=setInterval(m,1e3);}function y(m,p){let k=t.get(m);if(!k)return false;k.subscribedChatCardIds.add(p);let{cursor:S}=e.chatStorage.readAfter(p,null);return r.set(p,S),n.set(p,e.chatStorage.isProcessing(p)),l(),A(m,{kind:"notification-batch",notifications:[v(p,true)]}),true}function O(m,p){let k=t.get(m);return k?(k.subscribedChatCardIds.delete(p),f().includes(p)||(r.delete(p),n.delete(p)),R(),true):false}function w(m){if(!m||typeof m!="object")return false;let p=m.kind;return p==="card_chats"||p==="chat_messages"}function _(m){if(!m||m.length===0)return;let p=[],k=new Set;for(let S of m)w(S)&&typeof S.cardId=="string"?k.add(String(S.cardId)):p.push(S);if(p.length>0){let S={kind:"notification-batch",notifications:p};for(let B of t.keys())A(B,S);}for(let S of k)C(S,true);}return {size:()=>t.size,has:m=>t.has(m),get:m=>t.get(m),buildFrame:i,flushTransport:a,register:b,disconnect:u,writeFrame:A,subscribeChat:y,unsubscribeChat:O,broadcastNotificationBatch:_,broadcastCardChats:C}}function ue(e,...t){for(let r of t)if(typeof e[r]=="string")return String(e[r]);return ""}function Xe(e,...t){for(let r of t)if(e[r]!==void 0)return Number(e[r])}function ut(e,...t){for(let r of t){let n=e[r];if(n&&typeof n=="object"&&!Array.isArray(n))return n}return {}}function et(e,t,...r){for(let n of r){let o=e[n];if(o&&typeof o=="object"&&!Array.isArray(o))return o}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function nr(e,t,...r){for(let n of r){let o=e[n];if(o!==void 0){let s=Number(o);if(Number.isFinite(s))return s}}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function Pn(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(t=>Math.max(0,Math.min(255,Number(t)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let t=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r);return Uint8Array.from(n,o=>o.charCodeAt(0))}return null}function vr(e,t){if(e?.status==="success")return Object.prototype.hasOwnProperty.call(e,"data")?e.data:void 0;throw e?.status==="fail"||e?.status==="error"?Object.assign(new Error(e.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function Ar(e,t){return vr(await e,t)}function xr(e){let t=ue(e,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let r=t.split(".");if(!(r.length>=2&&r[0]==="chat"&&r.every(o=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(o))))throw Object.assign(new Error("MCP tool only supports card private keys under chat.*"),{statusCode:400});return t}function Ir(e,t){let r=e.__private;for(let n of t.split(".")){if(!r||typeof r!="object"||Array.isArray(r)||!Object.prototype.hasOwnProperty.call(r,n))return {exists:false,value:null};r=r[n];}return {exists:true,value:r}}function _n(e){let{boardId:t,getMcpFacade:r,getMcpCardStoreFacade:n}=e;function o(b){let A=ue(b,"board_id"),f=ue(b,"card_id");if(!A)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(!f)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});if(A!==t)throw Object.assign(new Error(`Unknown board_id: ${A}`),{statusCode:400});return {cardId:f}}function s(b,A){let{cardId:f}=o(b);return r().setChatProcessing({cardId:f,active:A}),{status:"success",data:{boardId:t,cardId:f,active:A}}}function i(b){let{cardId:A}=o(b),f=r().getChatProcessing({cardId:A});return {status:"success",data:{boardId:t,cardId:A,active:f.active}}}async function a(b){let{cardId:A}=o(b),f=xr(b);if(!Object.prototype.hasOwnProperty.call(b,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(f.split(".").includes("visible_controlplane_only")){let g=await Ar(n().get({params:{id:A}}),"cardStore.get"),v=Array.isArray(g.cards)&&g.cards.length>0&&typeof g.cards[0]=="object"&&!Array.isArray(g.cards[0])?g.cards[0]:null,C=v?Ir(v,"visible_controlplane_only").value:void 0;if(b.value!==C)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:A,key:f}}}return vr(await n().patch({params:{id:A,path:`__private.${f}`},body:{value:b.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:A,key:f}}}async function u(b){let{cardId:A}=o(b),f=xr(b),g=await Ar(n().get({params:{id:A}}),"cardStore.get"),v=Array.isArray(g.cards)&&g.cards.length>0&&g.cards[0]&&typeof g.cards[0]=="object"&&!Array.isArray(g.cards[0])?g.cards[0]:null;if(!v)throw Object.assign(new Error(`Card "${A}" not found`),{statusCode:404});let C=Ir(v,f);return {status:"success",data:{boardId:t,cardId:A,key:f,exists:C.exists,value:C.value}}}return {requireCardArgs:o,setChatProcessing:s,getChatProcessing:i,setCardMeta:a,getCardMeta:u}}function En(e){let{boardId:t,boardContexts:r,readCardDefinitions:n,readChatRecords:o,getChatProcessing:s}=e;async function i(){let A=(await Promise.all(r.map(async R=>{try{let l=R.boardAdapter.kvStorageForRef(R.outputsStoreRef),y=await Promise.resolve(l.read("status"));if(y!=null)return y}catch{}return R.notification.status}))).filter(Boolean);if(A.length===0)return null;if(A.length===1)return A[0];let f=[],g=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],v={};for(let R of g)v[R]=0;for(let R of A){let l=R,y=Array.isArray(l.cards)?l.cards:[];f.push(...y);for(let O of g)v[O]+=Number(l?.summary?.[O]||0);}let C=A[0];return {...C,cards:f,summary:{...C.summary||{},card_count:f.length,...v}}}async function a(){let A={},f=async g=>{try{let v=await g.boardOps.getAllOutputsComputedValues({});if(v.status==="success"&&v.data&&typeof v.data=="object"){for(let[C,R]of Object.entries(v.data)){let l=g.notification.cards[C];A[C]={schema_version:"v1",card_id:C,card_data:l?.card_data??{},computed_values:R??{}};}return}}catch{}for(let[v,C]of Object.entries(g.notification.computedValues)){let R=g.notification.cards[v];A[v]={schema_version:"v1",card_id:v,card_data:R?.card_data??{},computed_values:C??{}};}};for(let g of r)await f(g);return A}async function u(){let A={};for(let f of r){try{let g=await f.boardOps.getAllOutputsDataObjects({});if(g.status==="success"&&g.data&&typeof g.data=="object"){Object.assign(A,g.data);continue}}catch{}Object.assign(A,f.notification.dataObjects||{});}return A}async function b(){let A=await n(),f=await a(),g=await u(),v={};for(let R of A){if(!R?.id)continue;let l=R.id,y=f[l]||{},O={...y.card_data&&typeof y.card_data=="object"?y.card_data:R.card_data&&typeof R.card_data=="object"?R.card_data:{}};v[l]={schema_version:y.schema_version||"v1",card_id:y.card_id||l,card_data:O,computed_values:y.computed_values&&typeof y.computed_values=="object"?y.computed_values:{}};}let C={};for(let R of A){if(!R?.id)continue;let l=R.id;try{let y=o(l),O=s(l);(y.length>0||O)&&(C[l]={messages:y.map(w=>({role:String(w.role||"system"),text:String(w.text||""),files:Array.isArray(w.files)?w.files:[]})),receiving:!1,processing:O});}catch{}}return {boardId:t,cardDefinitions:A,statusSnapshot:await i(),dataObjectsByToken:g,cardRuntimeById:v,cardChatsByCardId:C}}return {readStatusSnapshot:i,readCardRuntimeArtifacts:a,readDataObjectsByToken:u,buildPublishedRuntimePayload:b}}function $o(e){let t=String(e||"").trim();if(!t)return "upload.bin";let r=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (r>=0?t.slice(r+1):t)||"upload.bin"}function On(e){let{safeCardId:t,artifactsStores:r,cardFileMetadataStore:n,readCardFromStore:o,updateCardLocalOnly:s,writeChatRecord:i}=e;async function a(A){let f=[];try{let g=await o(A);if(!g)return f;let v=n().read(g.card_data&&typeof g.card_data=="object"?g.card_data:null);for(let C of v)f.push(String(C.stored_name??""));}catch{}return f}async function u(A,f,g,v){let C=t(A),R=r(A),l=$o(f),y=await a(A),w=`${String(y.length+1).padStart(3,"0")}-${l}`.slice(-36);return R.files&&await R.files.putBytes(`${C}/${w}`,new Uint8Array(v),g||"application/octet-stream"),{name:l,stored_name:w,size:v.length,mime_type:g||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function b(A,f,g,v,C){if(!v.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let R=C?.inChat===true,l=await u(A,f,g,v),y=null;if(await s(A,O=>{let w=new Date().toISOString(),_=O.card_data&&typeof O.card_data=="object"?O.card_data:{};O.card_data=_;let m=n().normalizeIncoming([{name:l.name,stored_name:l.stored_name,size:l.size,mime_type:l.mime_type,uploaded_at:l.uploaded_at||w,chat:R}],w);return y=n().merge(_,m).findIndex(k=>k.stored_name===l.stored_name),O}),R&&C?.suppressChatRecordWrite!==true){let O=typeof y=="number"&&y>=0?` #${y}`:"";i(A,"system",`file uploaded: ${l.name} as ${l.stored_name}${O}`,[],C?.turnId??"");}return {ok:true,file:{...l,...typeof y=="number"&&y>=0?{file_idx:y}:{},chat:R},...typeof y=="number"&&y>=0?{file_idx:y}:{}}}return {uploadCardFile:b,readCardStoredFileNames:a}}function Bn(e){return {"discover.source-kinds":()=>e.discoverSourceKinds(),"inspect.board-runtime-status":()=>e.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>e.inspectCardDefinitionAndRuntime({cardId:ue(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let r=Xe(t,"tail_turns"),n=Xe(t,"tail"),o=ue(t,"turn_id"),s=t.all_turns===true,i=ue(t,"tail_turns_before_id");return e.inspectChatMessagesOnCards({cardId:ue(t,"card_id"),...r!==void 0?{lastUserTurns:r}:{},...n!==void 0?{tail:n}:{},...o?{turnId:o}:{},...s?{allTurns:true}:{},...i?{tailTurnsBeforeId:i}:{}})},"inspect.file-contents":t=>e.inspectFileContents({cardId:ue(t,"card_id"),fileIdx:Number(Xe(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>e.preflightValidateCandidateCardDefinition({candidateCardContent:et(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>e.preflightMaterializeCandidateCard({candidateCardContent:et(t,"candidate_card_content","candidate_card_content"),mockRequires:et(t,"mock_requires","mock_requires"),mockFetchedSources:et(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>e.preflightProbeSingleSourceInCandidateCard({candidateCardContent:et(t,"candidate_card_content","candidate_card_content"),mockProjections:ut(t,"mock_projections"),sourceIdx:nr(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>e.preflightRunSingleSourceInCandidateCard({candidateCardContent:et(t,"candidate_card_content","candidate_card_content"),mockProjections:ut(t,"mock_projections"),sourceIdx:nr(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>e.preflightRunSingleSourceInLiveCard({cardId:ue(t,"card_id"),sourceIdx:nr(t,"source_idx","source_idx"),mockRequires:et(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>e.preflightRunOneCycleWithCandidateCard({candidateCardContent:et(t,"candidate_card_content","candidate_card_content"),mockRequires:ut(t,"mock_requires")}),"manage.read-card":t=>e.manageReadCard({cardId:ue(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let r=ue(t,"turn_id");if(!r)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return e.manageAddChatEntryAndAnyAttachments({cardId:ue(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...r?{turn:r}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"manage.upsert-card":t=>e.manageUpsertCard({cardId:ue(t,"card_id"),candidateCardContent:ut(t,"candidate_card_content")}),"manage.remove-card":t=>e.manageRemoveCard({cardId:ue(t,"card_id")})}}function Fn(e){return {"webhook.process-accumulated":()=>e.webhookProcessAccumulated(),"webhook.source-fetch-done":t=>e.webhookSourceFetchDone({token:ue(t,"token"),ref:ue(t,"ref")}),"webhook.source-fetch-failed":t=>e.webhookSourceFetchFailed({token:ue(t,"token"),reason:ue(t,"reason")})}}function qn(e){let{boardId:t,uploadCardFile:r,getMcpFacade:n,controlplane:o}=e;function s(a,u){let b=ue(a,"board_id");if(!b)throw Object.assign(new Error(`${u} requires board_id`),{statusCode:400});if(b!==t)throw Object.assign(new Error(`Unknown board_id: ${b}`),{statusCode:400})}function i(a,u){let{cardId:b}=o.requireCardArgs(a),A=ue(a,"turn_id");return s(a,u),n().manageAddChatAttachment({cardId:b,role:ue(a,"role")||"user",...A?{turn:A}:{},files:[{file_name:ue(a,"file_name"),content_type:ue(a,"content_type")||"application/octet-stream",...typeof a.text=="string"?{text:a.text}:{},...typeof a.base64=="string"?{base64:a.base64}:{},...Array.isArray(a.bytes)?{bytes:a.bytes}:{}}]})}return {"list-runtime-cards":a=>(s(a,"list-runtime-cards"),n().listRuntimeCards()),"getstate.is-chat-processing":a=>o.getChatProcessing(a),"setstate.chat-processing-started":a=>o.setChatProcessing(a,true),"setstate.chat-processing-done":a=>o.setChatProcessing(a,false),"getstate.card-private":a=>o.getCardMeta(a),"setstate.card-private":a=>o.setCardMeta(a),"manage.upload-card-file":a=>{let u=ue(a,"card_id"),b=ue(a,"file_name"),A=ue(a,"content_type")||"application/octet-stream",f=Pn(a);if(s(a,"manage.upload-card-file"),!u)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!f)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return r(u,b,A,f,{inChat:false})},"manage.add-chat-attachment":a=>i(a,"manage.add-chat-attachment"),"manage.add-chat-attachement":a=>i(a,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":a=>{let{cardId:u}=o.requireCardArgs(a),b=ue(a,"role")||"user",A=ue(a,"turn_id");return s(a,"manage.add-chat-entry-and-any-attachments"),n().manageAddChatEntryAndAnyAttachments({cardId:u,role:b,...typeof a.text=="string"?{text:a.text}:{},...A?{turn:A}:{},...Array.isArray(a.files)?{files:a.files}:{}})},"manage.patch-card":a=>{let{cardId:u}=o.requireCardArgs(a);return s(a,"manage.patch-card"),n().managePatchCard({cardId:u,patch:ut(a,"patch")})},"manage.upsert-card":a=>{let{cardId:u}=o.requireCardArgs(a);return s(a,"manage.upsert-card"),n().manageUpsertCard({cardId:u,candidateCardContent:ut(a,"candidate_card_content")})},"manage.remove-card":a=>{let{cardId:u}=o.requireCardArgs(a);return s(a,"manage.remove-card"),n().manageRemoveCard({cardId:u})},"manage.admin-read-card":async a=>{let{cardId:u}=o.requireCardArgs(a);return {status:"success",data:{cards:await n().adminReadCard({cardId:u})}}},"manage.admin-upsert-card":a=>{let u=ue(a,"board_id"),b=ue(a,"card_id");if(!u)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(u!==t)throw Object.assign(new Error(`Unknown board_id: ${u}`),{statusCode:400});return n().adminUpsertCard({cardId:b,candidateCardContent:ut(a,"candidate_card_content")})}}}function qe(e,t){if(e?.status==="success")return Object.prototype.hasOwnProperty.call(e,"data")?e.data:void 0;throw e?.status==="fail"||e?.status==="error"?new Error(e.error||`${t} failed`):new Error(`${t} returned an unexpected response`)}function jn(e,t){if(e?.status==="success"&&Object.prototype.hasOwnProperty.call(e,"data"))return e.data;throw e?.status==="success"?new Error(`${t} returned success without data`):e?.status==="fail"||e?.status==="error"?new Error(e.error||`${t} failed`):new Error(`${t} returned an unexpected response`)}function Y(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}function Ee(e){return Array.isArray(e)?e:[]}function Pr(e,t){if(typeof t!="string"||t.length===0)return;let r=e,n=t;n.startsWith("fetched_sources.")&&(r=Y(e).fetched_sources,n=n.slice(16));for(let o of n.split(".")){if(r==null||typeof r!="object")return;r=r[o];}return r}function Tr(e,t){let r=Y(e.view),n=Ee(r.elements);return {layout:r.layout,features:r.features,elements:n.map((o,s)=>{let i=Y(o),a=Y(i.data),u=typeof i.visible=="string"?!!Pr(t,i.visible):true,b=typeof a.bind=="string"?a.bind:void 0,A=typeof a.maxRows=="number"?a.maxRows:void 0,f=b?Pr(t,b):void 0,g={id:typeof i.id=="string"&&i.id?i.id:`element-${s}`,kind:i.kind,label:i.label,visible:u};return f!==void 0&&(g.resolved=Array.isArray(f)&&typeof A=="number"?f.slice(0,A):f),g})}}function Ln(e,t){let r=typeof e.id=="string"&&e.id?e.id:"card",n=Ee(e.provides),o=n.length>0?n:[{bindTo:r,ref:"card_data"}],s={};for(let i of o){let a=Y(i),u=typeof a.bindTo=="string"?a.bindTo:"",b=typeof a.ref=="string"?a.ref:"";if(!u||!b)continue;let A=Pr(t,b);A!==void 0&&(s[u]=A);}return s}function Uo(e){if(typeof e!="string"||!e.trim())return null;let t=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(e.trim());if(!t)return null;let r=Number.parseInt(t[2],10);return !Number.isInteger(r)||r<0?null:r}function Vo(e){return {"card-content":e}}function or(e){let t={...e};return delete t.__private,t}function sr(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function Ko(e){return typeof structuredClone=="function"?structuredClone(e):JSON.parse(JSON.stringify(e))}function Ho(e,t){let r=Ko(e);if(!t||Object.keys(t).length===0)return r;function n(o,s,i){let a=String(s||"").split(".").filter(Boolean);if(!a.length)return;let u=o;for(let b=0;b<a.length-1;b+=1){let A=a[b];(!u[A]||typeof u[A]!="object")&&(u[A]={}),u=u[A];}u[a[a.length-1]]=i;}if(t.fieldValues!==void 0&&t.fieldValues!==null){let o=null,s=Y(r.view),i=Ee(s.elements);for(let a of i){let u=Y(Y(a).data);if(typeof u.writeTo=="string"&&u.writeTo){o=u.writeTo;break}}return o?n(r,o,t.fieldValues):typeof t.fieldValues=="object"&&!Array.isArray(t.fieldValues)&&(r.card_data={...Y(r.card_data),...t.fieldValues}),r}if(Array.isArray(t._stagedFiles)&&t._stagedFiles.length>0)return r;for(let[o,s]of Object.entries(t))o!=="_stagedFiles"&&(s!==null&&typeof s=="object"&&!Array.isArray(s)&&r[o]!==null&&typeof r[o]=="object"&&!Array.isArray(r[o])?r[o]={...r[o],...s}:r[o]=s);return r}function Dn(e){return Y(e.__private).visible_controlplane_only===true}async function yt(e,t){let r=await Ge(e.get({params:{id:t}}),"cardStore.get"),n=Array.isArray(r?.cards)?r.cards:[];if(n.length===0)throw new Error(`Card "${t}" not found`);return n[0]}function Mn(e){let{board:t,nonCore:r,cardStore:n,chatStore:o,processAccumulated:s,sourceFetchDone:i,sourceFetchFailed:a,uploadCardFile:u,buildFileDownloadUrl:b,readFetchedSourceJsonByRef:A}=e;function f(T,I){if(typeof T=="function")return T;throw new Error(`${I} is not configured for this MCP facade`)}async function g(){let T=await Ge(n.get({}),"cardStore.get");return Array.isArray(T.cards)?T.cards.map(I=>Y(I)):[]}function v(T){if(Array.isArray(T.bytes))return new Uint8Array(T.bytes.map(I=>Math.max(0,Math.min(255,Number(I)||0))));if(typeof T.text=="string")return new TextEncoder().encode(T.text);if(typeof T.base64=="string"){let I=String(T.base64).replace(/-/g,"+").replace(/_/g,"/"),U=I+"=".repeat((4-I.length%4)%4),J=atob(U);return Uint8Array.from(J,G=>G.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function C(){let T=Y(await Ge(r.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:T.version,commonSourceFields:Y(T.commonSourceDefFields),sourceKinds:Y(T.sourceKinds)}}async function R(){let T=Y(await Ge(t.status({}),"status")),I=Y(T.summary),U=Ee(T.cards);return {meta:Y(T.meta),summary:{card_count:typeof I.card_count=="number"?I.card_count:0,completed:typeof I.completed=="number"?I.completed:0,eligible:typeof I.eligible=="number"?I.eligible:0,pending:typeof I.pending=="number"?I.pending:0,blocked:typeof I.blocked=="number"?I.blocked:0,in_progress:typeof I.in_progress=="number"?I.in_progress:0,failed:typeof I.failed=="number"?I.failed:0,unresolved:typeof I.unresolved=="number"?I.unresolved:0},cards:U.map(J=>{let G=Y(J);return {"card-id":typeof G.name=="string"?G.name:null,status:G.status??null,error:G.error??null,requires:Ee(G.requires),requires_satisfied:Ee(G.requires_satisfied),requires_missing:Ee(G.requires_missing),provides_declared:Ee(G.provides_declared),provides_runtime:Ee(G.provides_runtime)}})}}async function l(T){let I=String(T.cardId||"").trim();if(!I)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let U=Y(await Ge(t.status({}),"status")),G=Ee(U.cards).map(Y).find(te=>te.name===I);if(!G)throw new Error(`card "${I}" not found in board status`);let re=Y(await yt(n,I));if(Dn(re))throw Object.assign(new Error(`card "${I}" not found`),{statusCode:404});let de=or(re),pe=Ee(G.requires_satisfied).filter(te=>typeof te=="string"&&!!te),ye=Ee(G.provides_runtime).filter(te=>typeof te=="string"&&!!te),he=Object.fromEntries(await Promise.all(pe.map(async te=>[te,await Ge(t.getOutputsDataObject({params:{key:te}}),`getOutputsDataObject(${te})`)]))),xe=Object.fromEntries(await Promise.all(ye.map(async te=>[te,await Ge(t.getOutputsDataObject({params:{key:te}}),`getOutputsDataObject(${te})`)]))),q=Y(await Ge(t.getOutputsComputedValues({params:{key:I}}),"getOutputsComputedValues")),c=await Ge(t.getOutputsFetchedSources({params:{key:I}}),"getOutputsFetchedSources"),E=Ee(re.source_defs).map(Y),L={};for(let te of E)typeof te.bindTo=="string"&&typeof te.outputFile=="string"&&(L[te.outputFile]=te.bindTo);let ee={};for(let[te,le]of Object.entries(c)){let Se=L[te]??te;if(!A||typeof le!="string"){ee[Se]=null;continue}try{ee[Se]=A({cardId:I,ref:le});}catch{ee[Se]=null;}}let ne={card_data:Y(re.card_data),requires:he,fetched_sources:ee,computed_values:q};return {cardId:I,card_status_in_board:G,card_definition_and_static_data:de,refs_for_fetched_source_files:c,runtime_data:{requires:he,provides:xe,computed_values:q,rendered_view:Tr(re,ne)}}}async function y(T){let I=String(T.cardId||"").trim();if(!I)throw new Error("inspectChatMessagesOnCards requires cardId");let U=typeof T.turnId=="string"?T.turnId:"",J=T.allTurns===true,G=typeof T.tailTurnsBeforeId=="string"?T.tailTurnsBeforeId:"",re=J?void 0:T.lastUserTurns??(U?void 0:1),de=T.tail,pe={...re===void 0?{}:{tailTurns:re},...U?{turnId:U}:{},...J?{allTurns:true}:{},...G?{tailTurnsBeforeId:G}:{}},ye=Object.keys(pe).length>0?{params:{cardId:I},body:pe}:{params:{cardId:I}},he=qe(o.readAll(ye),"chatStore.readAll"),xe=Y(await yt(n,I)),q=Ee(Y(xe.card_data).files).map((L,ee)=>({idx:ee,stored_name:Y(L).stored_name})).filter(L=>typeof L.stored_name=="string"&&L.stored_name.length>0),E=(Array.isArray(he.records)?he.records:[]).map(L=>{let ne=Y(L.payload),te={...L},le=typeof L?.role=="string"?L.role:typeof ne.role=="string"?String(ne.role):"",Se=typeof L?.text=="string"?L.text:typeof ne.text=="string"?String(ne.text):"";if(le==="system"){let be=Uo(Se);if(be!==null&&q.some(je=>je.idx===be)){let je=`Retrieve using inspect-file-contents --card-id ${I} --file-idx ${be}`;te.retrieval_hint=je,Object.keys(ne).length>0&&typeof L.role!="string"&&(te.payload={...ne,retrieval_hint:je});}}return te});return {cardId:I,messages:typeof de=="number"&&de>=0?E.slice(-de):E}}async function O(T){let I=String(T.cardId||"").trim(),U=Number(T.fileIdx);if(!I)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(U)||U<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let J=Y(await yt(n,I)),G=Ee(Y(J.card_data).files).map(Y);if(U>=G.length)throw new Error(`attachment index ${U} is out of range for card "${I}"`);let re=G[U],de=typeof re.stored_name=="string"?re.stored_name:null;return {cardId:I,fileIdx:U,downloadUrl:b({cardId:I,fileIdx:U,storedName:de}),...typeof re.name=="string"?{name:re.name}:{},...typeof re.stored_name=="string"?{stored_name:re.stored_name}:{},...typeof re.mime_type=="string"?{mime_type:re.mime_type}:{},...typeof re.size=="number"?{size:re.size}:{},...typeof re.uploaded_at=="string"?{uploaded_at:re.uploaded_at}:{}}}async function w(T){return await r.validateCardPreflight({body:Vo(T.candidateCardContent)})}function _(T){if(!T.mockRequires||typeof T.mockRequires!="object"||Array.isArray(T.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!T.mockFetchedSources||typeof T.mockFetchedSources!="object"||Array.isArray(T.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let I=r.evalCardCompute({body:{"card-content":T.candidateCardContent,"mock-requires":T.mockRequires,"mock-fetched-sources":T.mockFetchedSources}});if(I.status!=="success")return I;let U=Y(jn(I,"evalCardCompute")),J=Y(T.candidateCardContent),G={card_data:Y(J.card_data),requires:Y(T.mockRequires),fetched_sources:Y(T.mockFetchedSources),computed_values:Y(U.computed_values)};return {status:"success",data:{cardId:typeof U.cardId=="string"?U.cardId:typeof J.id=="string"?J.id:"(unknown)",ok:U.ok===true,computed_values:Y(U.computed_values),errors:Ee(U.errors).map(re=>{let de=Y(re);return {bindTo:typeof de.bindTo=="string"?de.bindTo:"",error:typeof de.error=="string"?de.error:""}}),provides_outputs:Ln(J,G),rendered_view:Tr(J,G)}}}async function m(T){return await r.probeSourcePreflight({params:{sourceIdx:T.sourceIdx},body:{"card-content":T.candidateCardContent,"mock-projections":T.mockProjections}})}async function p(T){return await r.runSourcePreflight({params:{sourceIdx:T.sourceIdx},body:{"card-content":T.candidateCardContent,"mock-projections":T.mockProjections}})}async function k(T){let I=String(T.cardId||"").trim();if(!I)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!T.mockRequires||typeof T.mockRequires!="object"||Array.isArray(T.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let U=Y(await yt(n,I)),J=Ee(U.source_defs).filter(re=>!!re&&typeof re=="object"&&!Array.isArray(re)),G={};if(T.sourceIdx>=0&&T.sourceIdx<J.length){let re=J[T.sourceIdx],de=$e.enrichSourcesSync([re],{card_data:Y(U.card_data),requires:T.mockRequires});Array.isArray(de)&&de.length>0&&(G=Y(de[0]._projections));}return await r.runSourcePreflight({params:{sourceIdx:T.sourceIdx},body:{"card-content":U,"mock-requires":T.mockRequires,"mock-projections":G}})}async function S(T){let I=Y(await Ge(r.simulateCardCycle({body:{"card-content":T.candidateCardContent,"mock-requires":T.mockRequires}}),"simulateCardCycle")),U=Y(T.candidateCardContent),J=Y(I.validation),G=Ee(I.source_probes),re=Ee(I.projection_errors),de=Y(I.fetched_sources),pe=Ee(I.compute_errors),ye=Y(I.computed_values),he={card_data:Y(U.card_data),requires:T.mockRequires,fetched_sources:de,computed_values:ye},xe=[];for(let q of Ee(J.issues))typeof q=="string"&&q&&xe.push(q);for(let q of G){let c=Y(q),E=typeof c.bindTo=="string"?c.bindTo:"source",L=typeof c.error=="string"?c.error:"";L&&xe.push(`${E}: ${L}`);}for(let q of re){let c=Y(q),E=typeof c.bindTo=="string"?c.bindTo:"source",L=typeof c.key=="string"?c.key:"projection",ee=typeof c.error=="string"?c.error:"projection failed";xe.push(`${E}.${L}: ${ee}`);}for(let q of pe){let c=Y(q),E=typeof c.bindTo=="string"?c.bindTo:"compute",L=typeof c.error=="string"?c.error:"compute failed";xe.push(`${E}: ${L}`);}return {status:"success",data:{cardId:typeof I.cardId=="string"?I.cardId:"(unknown)",ok:I.ok===true,issues:xe,provides_outputs:Ln(U,he),rendered_view:Tr(U,he)}}}async function B(T){let I=String(T.cardId||"").trim();if(!I)throw new Error("manageReadCard requires cardId");let U=await Ge(n.get({params:{id:I}}),"cardStore.get"),J=Array.isArray(U.cards)?U.cards.map(Y):[];if(J.some(Dn))throw Object.assign(new Error(`Card "${I}" not found`),{statusCode:404});return J.map(G=>or(G))}async function x(T){let I=await Promise.all(Ee(T.files).map(async U=>{let J=Y(U),G=String(J.file_name??J.fileName??J.name??"").trim(),re=String(J.content_type??J.contentType??"application/octet-stream");if(!G)throw new Error("file entry requires file_name");return await u({cardId:T.cardId,fileName:G,contentType:re,bytes:v(J),suppressChatRecordWrite:true})}));return I.forEach((U,J)=>{let G=Y(U.file),re=typeof U.file_idx=="number"&&Number.isInteger(U.file_idx)&&U.file_idx>=0?U.file_idx:J,de=T.role==="assistant"?`AI generated: ${String(G.name||"")} as ${String(G.stored_name||"")} #${re}`:`file uploaded: ${String(G.name||"")} as ${String(G.stored_name||"")} #${re}`;qe(o.append({params:{cardId:T.cardId},body:{role:"system",text:de,files:[],turn:T.turn}}),"chatStore.append(system attachment message)");}),I.map(U=>U.file)}async function h(T){let I=String(T.cardId||"").trim(),U=String(T.role||"user").trim()||"user",J=typeof T.turn=="string"?T.turn:"";if(!I)throw new Error("manageAddChatAttachment requires cardId");let G=await x({cardId:I,role:U,turn:J,files:T.files});return {status:"success",data:{cardId:I,turn:J,files:G}}}async function D(T){let I=String(T.cardId||"").trim(),U=String(T.role||"").trim(),J=typeof T.text=="string"?T.text:"",G=typeof T.turn=="string"?T.turn:"";if(!I)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!U)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(U==="assistant"&&G){let pe=qe(o.readAll({params:{cardId:I},body:{turnId:G}}),"chatStore.readAll(existing turn messages)"),ye=Array.isArray(pe.records)?pe.records.find(he=>he.role==="assistant"&&String(he.turn||"")===G):void 0;if(ye)return {status:"success",data:{cardId:I,id:String(ye.id),role:U,turn:G,files:Array.isArray(ye.files)?ye.files:[]}}}let re=await x({cardId:I,role:U,turn:G,files:T.files}),de=qe(o.append({params:{cardId:I},body:{role:U,text:J,files:re,turn:G}}),"chatStore.append");return {status:"success",data:{cardId:I,id:String(de.id),role:U,turn:G,files:re}}}async function j(T){let I=String(T.cardId||"").trim(),U=Y(T.patch);if(!I)throw new Error("managePatchCard requires cardId");let J=await B({cardId:I}),G=Y(J[0]),de={...Ho(G,U),...sr(G,"meta")?{meta:G.meta}:{},...sr(G,"__private")?{__private:G.__private}:{}},pe=await n.set({body:de});qe(pe,"cardStore.set");let ye;try{ye=await t.upsertCard({params:{cardId:I,restart:!0}}),qe(ye,"upsertCard");}catch(xe){try{await n.set({body:G});}catch{}throw xe}let he=null;try{he=await t.cardRefreshedNotify({params:{cardId:I}}),qe(he,"cardRefreshedNotify");}catch{he=null;}return {status:"success",data:{validation:null,card_saved:null,board_result:ye,refresh_notify:he}}}async function X(T){let I=String(T.cardId||"").trim(),U=Y(T.candidateCardContent),J=or(U);if(!I)throw new Error("manageUpsertCard requires cardId");if(typeof J.id!="string"||!J.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(J.id!==I)throw new Error(`candidateCardContent.id must match cardId (${I})`);let G=await w({candidateCardContent:J}),re=Y(G),de=Y(re.data);if(re.status!=="success"||de.isValid!==true)return {status:"fail",step:"validate",validation:G};let pe=null;try{pe=await yt(n,I);}catch{pe=null;}let ye=pe?Y(pe):null,he={...J,...ye&&sr(ye,"meta")?{meta:ye.meta}:{},...ye&&sr(ye,"__private")?{__private:ye.__private}:{}},xe=await n.set({body:he});qe(xe,"cardStore.set");let q;try{q=await t.upsertCard({params:{cardId:I,restart:!0}}),qe(q,"upsertCard");}catch(E){try{pe&&await n.set({body:pe});}catch{}throw E}let c=null;try{c=await t.cardRefreshedNotify({params:{cardId:I}}),qe(c,"cardRefreshedNotify");}catch{c=null;}return {status:"success",data:{validation:G,card_saved:null,board_result:q,refresh_notify:c}}}async function N(T){let I=String(T.cardId||"").trim();if(!I)throw new Error("manageRemoveCard requires cardId");let U=await t.removeCard({params:{id:I}});qe(U,"removeCard");let J=await n.del({params:{id:I}});return qe(J,"cardStore.del"),{status:"success",data:{board_result:U,store_result:J}}}async function $(T){let I=String(T.cardId||"").trim();if(!I)throw new Error("adminReadCard requires cardId");let U=await Ge(n.get({params:{id:I}}),"cardStore.get");return Array.isArray(U.cards)?U.cards.map(J=>Y(J)):[]}async function Z(T){let I=String(T.cardId||"").trim(),U=Y(T.candidateCardContent),J=or(U);if(!I)throw new Error("adminUpsertCard requires cardId");if(typeof J.id!="string"||!J.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(J.id!==I)throw new Error(`candidateCardContent.id must match cardId (${I})`);let G=await w({candidateCardContent:J}),re=Y(G),de=Y(re.data);if(re.status!=="success"||de.isValid!==true)return {status:"fail",step:"validate",validation:G};let pe=null;try{pe=await yt(n,I);}catch{pe=null;}let ye=pe?Y(Y(pe).__private):{},he={...J,__private:{...ye,visible_controlplane_only:true}},xe=await n.set({body:he});qe(xe,"cardStore.set");let q;try{q=await t.upsertCard({params:{cardId:I,restart:!0}}),qe(q,"upsertCard");}catch(E){try{pe&&await n.set({body:pe});}catch{}throw E}let c=null;try{c=await t.cardRefreshedNotify({params:{cardId:I}}),qe(c,"cardRefreshedNotify");}catch{c=null;}return {status:"success",data:{validation:G,card_saved:null,board_result:q,refresh_notify:c}}}function H(T){let I=String(T.cardId||"").trim();if(!I)throw new Error("getChatProcessing requires cardId");let U=jn(o.isProcessing({params:{cardId:I}}),"chatStore.isProcessing");return {cardId:I,active:!!U.active}}function M(T){let I=String(T.cardId||"").trim();if(!I)throw new Error("setChatProcessing requires cardId");if(typeof T.active!="boolean")throw new Error("setChatProcessing requires boolean active");return qe(o.setProcessing({params:{cardId:I},body:{active:T.active}}),"chatStore.setProcessing"),{cardId:I,active:T.active}}async function z(){let T=await f(s,"webhook.process-accumulated")();return T?.status==="fail"||T?.status==="error"?T:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(T??{},"data")?T.data??null:null}}}async function oe(T){let I=String(T.token||"").trim(),U=String(T.ref||"").trim();if(!I)throw new Error("webhookSourceFetchDone requires token");if(!U)throw new Error("webhookSourceFetchDone requires ref");let J=await f(i,"webhook.source-fetch-done")({token:I,ref:U});return J?.status==="fail"||J?.status==="error"?J:{status:"success",data:{token:I,ref:U,runtime_result:Object.prototype.hasOwnProperty.call(J??{},"data")?J.data??null:null}}}async function we(T){let I=String(T.token||"").trim(),U=String(T.reason||"").trim();if(!I)throw new Error("webhookSourceFetchFailed requires token");if(!U)throw new Error("webhookSourceFetchFailed requires reason");let J=await f(a,"webhook.source-fetch-failed")({token:I,reason:U});return J?.status==="fail"||J?.status==="error"?J:{status:"success",data:{token:I,reason:U,runtime_result:Object.prototype.hasOwnProperty.call(J??{},"data")?J.data??null:null}}}return {listRuntimeCards:g,discoverSourceKinds:C,inspectBoardRuntimeStatus:R,inspectCardDefinitionAndRuntime:l,inspectChatMessagesOnCards:y,inspectFileContents:O,preflightValidateCandidateCardDefinition:w,preflightMaterializeCandidateCard:_,preflightProbeSingleSourceInCandidateCard:m,preflightRunSingleSourceInCandidateCard:p,preflightRunSingleSourceInLiveCard:k,preflightRunOneCycleWithCandidateCard:S,manageReadCard:B,manageAddChatAttachment:h,manageAddChatEntryAndAnyAttachments:D,managePatchCard:j,manageUpsertCard:X,manageRemoveCard:N,adminReadCard:$,adminUpsertCard:Z,getChatProcessing:H,setChatProcessing:M,webhookProcessAccumulated:z,webhookSourceFetchDone:oe,webhookSourceFetchFailed:we}}async function Ge(e,t){return qe(await e,t)}function Nn(e){let{boardContexts:t,cardOwnerIndex:r,cardContextForCard:n,readStatusSnapshot:o,readDataObjectsByToken:s,readCardRuntimeArtifacts:i,readCardFromStore:a,readCardDefinitions:u,processAccumulatedLaneInternal:b,reportSourceFetched:A,reportSourceFetchFailure:f,uploadCardFile:g,chatStorePublic:v,serverUrl:C,apiBasePath:R}=e;function l(){return t[0]??null}function y(){return {async status(){let m=await o();return m==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:m}},async getOutputsDataObject(m){let p=m?.params?.key;return p?{status:"success",data:(await s())[p]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(m){let p=m?.params?.key;return p?{status:"success",data:(await i())[p]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(m){let p=m?.params?.key;if(!p)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let k=n(p)??l();return k?k.boardOps.getOutputsFetchedSources({params:{key:p}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(m){let p=m?.params?.id;if(!p)return {status:"fail",error:"removeCard requires params.id"};let k=n(p)??l();return k?k.boardOps.removeCard({params:{id:p}}):{status:"fail",error:"Board context is unavailable"}},async cardRefreshedNotify(m){let p=m?.params?.cardId;if(!p)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let k=n(p)??l();return k?k.boardOps.cardRefreshedNotify({params:{cardId:p}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(m){let p=m?.params?.cardId;if(!p)return {status:"fail",error:"upsertCard requires params.cardId"};let k=n(p)??l();if(!k)return {status:"fail",error:"Board context is unavailable"};let S=await k.boardOps.upsertCard({params:{cardId:p,restart:m.params.restart===true}});if(S.status!=="success")return S;if(ze(k.boardAdapter)){let B=await b(true);if(B.status!=="success")return B}return S}}}function O(){let m=()=>{let p=l();if(!p?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return p.nonCore};return {describeTaskExecutorCapabilities(p){return m().describeTaskExecutorCapabilities(p)},validateCardPreflight(p){return m().validateCardPreflight(p)},evalCardCompute(p){return m().evalCardCompute(p)},probeSourcePreflight(p){return m().probeSourcePreflight(p)},runSourcePreflight(p){return m().runSourcePreflight(p)},simulateCardCycle(p){return m().simulateCardCycle(p)}}}function w(){return {async get(m){let p=typeof m.params?.id=="string"?m.params.id:void 0;if(p){let k=await a(p);return k?{status:"success",data:{cards:[k]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await u()}}},async set(m){let p=m.body;if(p==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let k=Array.isArray(p)?p:[p];for(let S of k){let B=S,x=typeof B.id=="string"?B.id:"";if(!x)return {status:"fail",error:"each card must have a string `id` field"};let h=r.get(x)??0,D=t[h]??l();if(!D)return {status:"fail",error:"Board context is unavailable"};let j=await D.cardStoreOps.set({body:B});if(j.status!=="success")return j;r.set(x,h);}return {status:"success",data:{count:k.length}}},async del(m){let p=[m.params?.id,...m.body?.ids??[]].filter(k=>typeof k=="string"&&!!k);if(p.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let k of p){let S=n(k)??l();if(!S)return {status:"fail",error:"Board context is unavailable"};let B=await S.cardStoreOps.del({params:{id:k}});if(B.status!=="success")return B;r.delete(k);}return {status:"success",data:{count:p.length}}},async patch(m){let p=typeof m.params?.id=="string"?m.params.id:void 0,k=typeof m.params?.path=="string"?m.params.path:void 0;if(!p||!k)return {status:"fail",error:"patch requires params.id and params.path"};let S=n(p)??l();return S?S.cardStoreOps.patch(m):{status:"fail",error:"Board context is unavailable"}},async appendFiles(m){let p=typeof m.params?.id=="string"?m.params.id:void 0;if(!p)return {status:"fail",error:"appendFiles requires params.id"};let k=n(p)??l();return k?k.cardStoreOps.appendFiles(m):{status:"fail",error:"Board context is unavailable"}}}}function _(){return Mn({board:y(),nonCore:O(),cardStore:w(),chatStore:v,processAccumulated:()=>b(true),sourceFetchDone:({token:m,ref:p})=>A(m,p),sourceFetchFailed:({token:m,reason:p})=>f(m,p),uploadCardFile({cardId:m,fileName:p,contentType:k,bytes:S,suppressChatRecordWrite:B}){return g(m,p,k,S,{inChat:true,...B===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:m,fileIdx:p,storedName:k}){let S=`${C||""}${R}/cards/${encodeURIComponent(m)}/files/${p}`;return k?`${S}?sn=${encodeURIComponent(k)}`:S},readFetchedSourceJsonByRef({cardId:m,ref:p}){let k=n(m)??l();if(!k||ze(k.boardAdapter))return null;let x=k.boardAdapter.resolveBlob(Qe(p)).trim();return x?JSON.parse(x):null}})}return {mcpBoardFacade:y,mcpNonCoreFacade:O,mcpCardStoreFacade:w,createMcpFacade:_}}function $n(e){let{apiBasePath:t,json:r,readJsonBody:n,bootstrapBoard:o,createMcpFacade:s,createMcpToolRegistry:i,resolveCardFileDownloadPayload:a,isLikelyTextMimeType:u,sliceTextByLines:b}=e;async function A(f,g,v){let C=f.method||"GET",R=v,l=R.pathname;try{if(C==="POST"&&l===`${t}/mcp`){await o();let y=await n(f),O=typeof y.tool=="string"?y.tool.trim():"",w=y.args&&typeof y.args=="object"&&!Array.isArray(y.args)?y.args:{};if(!O)return r(g,400,{error:"tool is required"}),!0;if(O==="inspect.file-contents")return r(g,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let _=await mt(O,w,i(s()));if(_&&typeof _=="object"&&!Array.isArray(_)){let m=_;if(m.status==="fail")return r(g,400,{error:Ze(_,"Request failed")}),!0;if(m.status==="error")return r(g,500,{error:Ze(_,"Internal error")}),!0}r(g,200,_);}catch(_){let m=typeof _?.statusCode=="number"?Number(_.statusCode):500,p=_ instanceof Error?_.message:String(_);r(g,m,{error:p});}return !0}if(C==="POST"&&l===`${t}/mcp-raw`){await o();let y=await n(f),O=typeof y.tool=="string"?y.tool.trim():"",w=y.args&&typeof y.args=="object"&&!Array.isArray(y.args)?y.args:{};if(!O)return r(g,400,{error:"tool is required"}),!0;if(O!=="inspect.file-contents")return r(g,400,{error:`Tool does not support raw response: ${O}`}),!0;let _=ue(w,"card_id","cardId"),m=Xe(w,"file_idx","fileIdx"),p=Xe(w,"head-lines","headLines"),k=Xe(w,"tail-lines","tailLines"),S=Xe(w,"head-bytes","headBytes"),B=Xe(w,"tail-bytes","tailBytes");if(!_)return r(g,400,{error:"inspect.file-contents requires card_id"}),!0;if(m===void 0||!Number.isInteger(m)||m<0)return r(g,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([p,k,S,B].filter(z=>z!==void 0).length>1)return r(g,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[z,oe]of [["head-lines",p],["tail-lines",k],["head-bytes",S],["tail-bytes",B]])if(oe!==void 0&&(!Number.isInteger(oe)||oe<0))return r(g,400,{error:`inspect.file-contents requires ${z} to be a non-negative integer`}),!0;let h=await s().inspectFileContents({cardId:_,fileIdx:m}),D=typeof h?.stored_name=="string"?h.stored_name:null,{fileRecord:j,bytes:X}=await a(_,m,D),N=String(j.name||j.stored_name||"download.bin"),$=String(j.mime_type||"application/octet-stream"),Z=(R.searchParams.get("resp")||"").trim().toLowerCase();if(Z&&Z!=="json-b64")return r(g,400,{error:`unsupported resp mode: ${Z}`}),!0;let H=Z==="json-b64",M;if(p!==void 0||k!==void 0){if(!u($))return r(g,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let z=new TextDecoder().decode(X),oe=p!==void 0?b(z,"head",p):b(z,"tail",k);M=typeof Buffer<"u"?Buffer.from(oe,"utf8"):new TextEncoder().encode(oe);}else if(S!==void 0||B!==void 0){let z=S??B;M=S!==void 0?X.slice(0,z):X.slice(Math.max(0,X.length-z));}else M=X;if(H){let z=typeof Buffer<"u"?Buffer.from(M).toString("base64"):btoa(String.fromCharCode(...M));return r(g,200,{bodyBase64:z,mimeType:$,filename:N,byteLength:M.length}),!0}return g.writeHead(200,{"Content-Type":$,"Content-Disposition":`attachment; filename="${N}"`,"Content-Length":M.length}),g.end(M),!0}return !1}catch(y){let O=y?.statusCode||500;return r(g,O,{error:String(y?.message||y)}),true}}return {handleAgentfaceApi:A}}function Un(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,createMcpWebhookToolRegistry:s}=e;async function i(a,u,b){let A=a.method||"GET",f=b.pathname;try{if(A==="POST"&&f===`${t}/mcp-webhooks`){await o();let g=await n(a),v=typeof g.tool=="string"?g.tool.trim():"",C=g.args&&typeof g.args=="object"&&!Array.isArray(g.args)?g.args:{};if(!v)return r(u,400,{error:"tool is required"}),!0;try{let R=await mt(v,C,s());if(R&&typeof R=="object"&&!Array.isArray(R)){let l=R;if(l.status==="fail")return r(u,400,{error:Ze(R,"Request failed")}),!0;if(l.status==="error")return r(u,500,{error:Ze(R,"Internal error")}),!0}r(u,200,R);}catch(R){let l=typeof R?.statusCode=="number"?Number(R.statusCode):500,y=R instanceof Error?R.message:String(R);r(u,l,{error:y});}return !0}return !1}catch(g){let v=g?.statusCode||500;return r(u,v,{error:String(g?.message||g)}),true}}return {handleWebhooksApi:i}}function Vn(e){let{sseHub:t,corsHeaders:r,json:n,buildPublishedRuntimePayload:o,onSseClientConnected:s,onChannelSubscribed:i,onChannelUnsubscribed:a}=e;function u(A,f,g,v,C){if(!t.has(f)){n(A,404,{error:`SSE client not connected: ${f}`});return}C?i?.(f,g,v):a?.(f,g,v),n(A,200,{ok:true,clientId:f,channelName:g,...v.cardId?{cardId:v.cardId}:{},subscribed:C});}async function b(A,f,g){let v=t.get(g),C=v?new Set(v.subscribedChatCardIds):new Set;f.writeHead(200,{...r,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),t.flushTransport(f),t.register(g,f,C);let R=await o(),l=t.buildFrame(R);f.write(l);try{s?.(g,O=>{t.writeFrame(g,O);});}catch{}let y=setInterval(()=>{try{f.write(`: keepalive
5
+
6
+ `);}catch{}},15e3);A.on("close",()=>{clearInterval(y),t.disconnect(g,f);});}return {handleChannelSubscription:u,handleSse:b}}function Kn(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,bootstrapBoard:s,boardContexts:i,publishPersistedStateSnapshot:a,upsertCardsFromSource:u,sseHub:b}=e,{handleSse:A,handleChannelSubscription:f}=Vn(e);async function g(v,C,R){let l=v.method||"GET",y=R,O=y.pathname;try{if(l==="GET"&&O===`${t}/sse`){await o();let k=String(y.searchParams.get("clientId")||"").trim();if(!k)return r(C,400,{error:"clientId query param is required for SSE"}),!0;await A(v,C,k);for(let S=0;S<i.length;S++)await a(i[S]),await u(i[S],S),await a(i[S]);return !0}let w=O.match(new RegExp(`^${We(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(l==="POST"&&w){await s();let k=decodeURIComponent(w[1]),S=await n(v),B=typeof S?.clientId=="string"?S.clientId.trim():"";return B?b.subscribeChat(B,k)?(r(C,200,{ok:!0,clientId:B,cardId:k,subscribed:!0}),!0):(r(C,404,{error:`SSE client not connected: ${B}`}),!0):(r(C,400,{error:"clientId is required"}),!0)}let _=O.match(new RegExp(`^${We(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(l==="POST"&&_){await s();let k=decodeURIComponent(_[1]),S=await n(v),B=typeof S?.clientId=="string"?S.clientId.trim():"";return B?b.unsubscribeChat(B,k)?(r(C,200,{ok:!0,clientId:B,cardId:k,subscribed:!1}),!0):(r(C,404,{error:`SSE client not connected: ${B}`}),!0):(r(C,400,{error:"clientId is required"}),!0)}let m=O.match(new RegExp(`^${We(t)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(l==="POST"&&m){await s();let k=decodeURIComponent(m[1]),S=m[2]==="subscribe",B=await n(v),x=typeof B?.clientId=="string"?B.clientId.trim():"";return x?(f(C,x,k,{},S),!0):(r(C,400,{error:"clientId is required"}),!0)}let p=O.match(new RegExp(`^${We(t)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(l==="POST"&&p){await s();let k=decodeURIComponent(p[1]),S=decodeURIComponent(p[2]),B=p[3]==="subscribe",x=await n(v),h=typeof x?.clientId=="string"?x.clientId.trim():"";return h?(f(C,h,S,{cardId:k},B),!0):(r(C,400,{error:"clientId is required"}),!0)}return !1}catch(w){let _=w?.statusCode||500;return r(C,_,{error:String(w?.message||w)}),true}}return {handleWatchersRoutes:g,handleSse:A,handleChannelSubscription:f}}var Jn={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},Hn="chat-handler-flow-queue";function Jo(e){let t=String(e.apiBasePath||"/api/board").replace(/\/$/,""),r={...Jn,...e.corsHeaders||{}},n=e.queueLaneTuning??{},o=e.boardId||"",s=e.logger||{info:console.log,warn:console.warn,error:console.error},i=e.invocationAdapter,a=e.chatFlowRunner||null,u=e.chatStorage??An(),b=xn(u),A=e.notificationTransport||null,f=e.serverUrl||null,g=e.executionExtra||{},v=e.onSseClientConnected,C=e.onSseClientDisconnected,R=e.onChannelSubscribed,l=e.onChannelUnsubscribed,y=Tn({chatStorage:u,readChatRecords:d=>te(d),onSseClientDisconnected:C});function O(d){function P(W){if(Array.isArray(W))return W;if(W&&typeof W=="object"){let ie=W;return Array.isArray(ie.files)?ie.files:[W]}return null}function F(W){return {async get(ie){return W.get(ie)},async set(ie){return W.set(ie)},async del(ie){return W.del(ie)},async patch(ie){return W.patch(ie)},async appendFiles(ie){return W.appendFiles(ie)}}}function V(W){function ie(Ae){return {status:"success",data:Ae}}function ke(Ae){return {status:"fail",error:Ae}}function ge(Ae){return {status:"error",error:Ae instanceof Error?Ae.message:String(Ae)}}return {async get(Ae){try{let Ce=Ae.params?.id;if(Ce){let Fe=await W.readCard(Ce);return Fe?ie({cards:[Fe]}):ke(`card "${Ce}" not found`)}return ie({cards:await W.readAllCards()})}catch(Ce){return ge(Ce)}},async set(Ae){try{let Ce=Ae.body;if(Ce==null)return ke("set requires a body (card object or array of cards)");let Fe=Array.isArray(Ce)?Ce:[Ce];for(let Le of Fe){if(typeof Le.id!="string")return ke("each card must have a string `id` field");await W.writeCard(Le.id,Le);}return ie({count:Fe.length})}catch(Ce){return ge(Ce)}},async del(Ae){try{let Ce=Ae.body?.ids??[],Fe=Ae.params?.id,Le=Fe?[...Ce,Fe]:Ce;if(Le.length===0)return ke("del requires body.ids (string[]) or params.id");for(let pt of Le)await W.removeCard(pt);return ie({count:Le.length})}catch(Ce){return ge(Ce)}},async patch(Ae){try{let Ce=Ae.params?.id,Fe=Ae.params?.path;if(!Ce)return ke("patch requires params.id");if(!Fe)return ke("patch requires params.path");let Le=Ae.body,pt=Le&&Object.prototype.hasOwnProperty.call(Le,"value")?Le.value:Ae.body;return await W.patchCard(Ce,Fe,pt),ie({count:1})}catch(Ce){return ge(Ce)}},async appendFiles(Ae){try{let Ce=Ae.params?.id;if(!Ce)return ke("appendFiles requires params.id");let Fe=await W.readCard(Ce);if(!Fe)return ke(`card "${Ce}" not found`);let Le=P(Ae.body);if(!Le||Le.length===0)return ke("appendFiles requires a file metadata object, array, or body.files array");let pt=Fe.card_data&&typeof Fe.card_data=="object"&&!Array.isArray(Fe.card_data)?Fe.card_data:{},_r=Array.isArray(pt.files)?pt.files:[],Wn=[..._r,...Le];return await W.patchCard(Ce,"card_data.files",Wn),ie({files_added:Le.map((Qn,zn)=>({idx:_r.length+zn,entry:Qn}))})}catch(Ce){return ge(Ce)}}}}let K=ze(d.boardAdapter)?Rn(d.baseRef,d.boardAdapter):fn(d.baseRef,d.boardAdapter),se=d.nonCoreAdapter??(!ze(d.boardAdapter)&&p(d.boardAdapter)?d.boardAdapter:null),fe=d.nonCore??(se?pn(d.baseRef,se):null),_e,Pe=ze(d.boardAdapter)?(()=>{let W=tr(er(Zt(d.boardAdapter.kvStorageForRef(d.cardStoreRef)),d.boardAdapter.hashFn),s.warn),ie=V(W);return _e={get(ke){return ie.get(ke)},set(ke){return ie.set(ke)}},ie})():(()=>{let W=d.boardAdapter.kvStorageForRef(d.cardStoreRef),ke=Qt(xt({readIndex:()=>W.read("_index"),writeIndex:ge=>W.write("_index",ge),readCard:ge=>W.read(ge),writeCard:(ge,Ae)=>(W.write(ge,Ae),ge),removeCard:ge=>{W.delete(ge);},cardExists:ge=>W.read(ge)!==null,defaultCardKey:ge=>ge},s.warn));return _e=ke,F(ke)})(),Be=d.artifactsAdapter||d.boardAdapter,Oe=d.filesArtifactsStore??null,Ne=Oe?{putBytes(W,ie,ke){Oe.putBytes(W,ie,ke);},getBytes(W){return Oe.getBytes(W)},listKeys(W){return Oe.list(W).map(ie=>ie.key)}}:null;if(!Ne&&!ze(Be)){let W=d.artifactsAdapter?Be.blobStorage(""):Be.blobStorage("files"),ie=bn(W);Ne={putBytes(ke,ge,Ae){ie.putBytes(ke,ge,Ae);},getBytes(ke){return ie.getBytes(ke)},listKeys(ke){return ie.list(ke).map(ge=>ge.key)}};}else if(!Ne&&ze(Be)){let W=d.artifactsAdapter?Be.blobStorage(""):Be.blobStorage("files");Ne={async putBytes(ie,ke){if(W.writeBytes){await W.writeBytes(ie,ke);return}let ge=JSON.stringify({__kind:"bytes-array",data:[...ke]});await W.write(ie,ge);},async getBytes(ie){if(W.readBytes){let ge=await W.readBytes(ie);if(ge!==null)return ge}let ke=await W.read(ie);if(ke===null)return null;try{let ge=JSON.parse(ke);if(ge&&ge.__kind==="bytes-array"&&Array.isArray(ge.data))return new Uint8Array(ge.data)}catch{}return new TextEncoder().encode(ke)},async listKeys(ie){return await W.listKeys(ie)}};}let He={async init(W){return K.init(W)},async status(W){return K.status(W)},async getConfig(W){return K.getConfig(W)},async getAllOutputsDataObjects(W){return K.getAllOutputsDataObjects(W)},async getAllOutputsComputedValues(W){return K.getAllOutputsComputedValues(W)},async getOutputsFetchedSources(W){return K.getOutputsFetchedSources(W)},async upsertCard(W){return K.upsertCard(W)},async removeCard(W){return K.removeCard(W)},async cardRefreshedNotify(W){return K.cardRefreshedNotify(W)},async sourceDataFetched(W){return K.sourceDataFetched(W)},async sourceDataFetchFailure(W){return K.sourceDataFetchFailure(W)}};return {label:d.label,board:K,nonCore:fe,publicCardStore:_e,boardOps:He,cardStoreOps:Pe,get filesArtifacts(){return Ne},boardAdapter:d.boardAdapter,cardStoreRef:d.cardStoreRef,outputsStoreRef:d.outputsStoreRef,artifactsStoreRef:d.artifactsStoreRef,chatStoreRef:d.chatStoreRef,scratchStoreRef:d.scratchStoreRef,archiveStoreRef:d.archiveStoreRef,notifyRef:d.notifyRef,taskExecutorRef:d.taskExecutorRef,chatHandlerRef:d.chatHandlerRef,chatHandlerFlow:d.chatHandlerFlow,inferenceAdapterRef:d.inferenceAdapterRef,notification:In(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let w=e.boards.map(O),_=new Map;function m(d){return _.get(d)??0}function p(d){let P=d;return typeof P.invokeExecutor=="function"&&typeof P.validateSchema=="function"}function k(d){let P=w[m(d)];return {files:P?P.filesArtifacts:null}}function S(){return vn()}function B(d){return String(d||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function x(d){if(!d||d.notificationTeardown||!A||!d.notifyRef)return;let P=await A.subscribe(d.notifyRef,F=>{br(d.notification,F);let V=F.kind==="notification-batch"?F.notifications:[F];y.broadcastNotificationBatch(V);});d.notificationTeardown=P;}async function h(d){if(!d||d.initialized)return;let P={cardStoreRef:d.cardStoreRef,outputsStoreRef:d.outputsStoreRef};d.artifactsStoreRef&&(P.artifactsStoreRef=d.artifactsStoreRef),d.chatStoreRef&&(P.chatStoreRef=d.chatStoreRef),d.scratchStoreRef&&(P.scratchStoreRef=d.scratchStoreRef),d.archiveStoreRef&&(P.archiveStoreRef=d.archiveStoreRef);let F={};d.taskExecutorRef&&(F["task-executor-ref"]=d.taskExecutorRef),d.chatHandlerFlow!==void 0&&(F["chat-handler-flow"]=d.chatHandlerFlow),d.inferenceAdapterRef&&(F["inference-adapter-ref"]=d.inferenceAdapterRef);let V=await d.boardOps.init({params:P,body:F});if(V.status!=="success")throw Object.assign(new Error(V.error||`init failed for ${d.label}`),{statusCode:500});if(await x(d),!d.chatHandlerFlow&&d.chatHandlerRef&&i.describe)try{let K=await i.describe(d.chatHandlerRef);K&&K.kind!=="chat-handler"?s.warn(`[init] chat-handler describe returned kind="${K.kind}", expected "chat-handler" for ${d.label}`):K&&s.info(`[init] chat-handler validated: ${K.name} (protocol ${K.protocolVersion}) for ${d.label}`);}catch(K){s.warn(`[init] chat-handler describe failed for ${d.label}: ${K?.message||String(K)}`);}d.initialized=true;}async function D(d){if(!d.boardAdapter.publishBoardChangeNotifications)return;let P=[],F=await d.boardOps.status({});F.status==="success"&&F.data!=null&&Sr(F.data)&&P.push({kind:"status",status:F.data});let V=await d.boardOps.getAllOutputsDataObjects({});if(V.status==="success"&&V.data!=null)for(let[se,fe]of Object.entries(V.data))se&&P.push({kind:"data_object",key:se,payload:fe});let K=await d.boardOps.getAllOutputsComputedValues({});if(K.status==="success"&&K.data!=null)for(let[se,fe]of Object.entries(K.data))se&&P.push({kind:"computed_values",cardId:se,values:fe});P.length>0&&d.boardAdapter.publishBoardChangeNotifications(P);}async function j(d,P){if(!d||d.cardsBootstrapped)return;let F=await d.cardStoreOps.get({}),V=F.status==="success"&&Array.isArray(F.data?.cards)?F.data.cards:[];for(let K of V)typeof K.id=="string"&&(_.set(K.id,P),await d.boardOps.upsertCard({params:{cardId:K.id}}));d.cardsBootstrapped=true;}async function X(){for(let d of w)await h(d);}async function N(){await X();for(let d=0;d<w.length;d++)await D(w[d]),await j(w[d],d),await D(w[d]);}async function $(d=false){d||await X();for(let P of w){let F=await P.board.processAccumulatedEvents({});if(F.status!=="success")return F}return {status:"success"}}async function Z(){return await X(),$(true)}function H(d){return w[m(d)]??null}async function M(d){let P=H(d);if(!P)return null;let F=await P.cardStoreOps.get({params:{id:d}});if(F.status!=="success")return null;let V=Array.isArray(F.data?.cards)?F.data.cards:[];return V.length>0?V[0]:null}async function z(){let d=async F=>{if(!F)return [];let V=await F.cardStoreOps.get({});return V.status!=="success"||!Array.isArray(V.data?.cards)?[]:V.data.cards},P=[];for(let F of w)P.push(...await d(F));return P}function oe(){return w[0]??null}let we=Nn({boardContexts:w,cardOwnerIndex:_,cardContextForCard:d=>H(d),readStatusSnapshot:()=>pe(),readDataObjectsByToken:()=>he(),readCardRuntimeArtifacts:()=>ye(),readCardFromStore:d=>M(d),readCardDefinitions:()=>z(),processAccumulatedLaneInternal:d=>$(d),reportSourceFetched:(d,P)=>Ct(d,{ref:P}),reportSourceFetchFailure:(d,P)=>ar(d,{reason:P}),uploadCardFile:(d,P,F,V,K)=>Se(d,P,F,V,K),chatStorePublic:b,serverUrl:f,apiBasePath:t}),T=we.mcpCardStoreFacade,I=we.createMcpFacade,U=_n({boardId:o,getMcpFacade:()=>I(),getMcpCardStoreFacade:()=>T()});function J(d){return Bn(d)}function G(){return Fn(I())}function re(){return qn({boardId:o,uploadCardFile:Se,getMcpFacade:()=>I(),controlplane:U})}let de=En({boardId:o,boardContexts:w,readCardDefinitions:()=>z(),readChatRecords:d=>te(d),getChatProcessing:d=>I().getChatProcessing({cardId:d}).active}),pe=de.readStatusSnapshot,ye=de.readCardRuntimeArtifacts,he=de.readDataObjectsByToken,xe=de.buildPublishedRuntimePayload;async function q(d,P,F){let V=F?.syncBoard!==false,K=F?.restartOnlyIfChanged===true,se=H(d);if(!se)throw Object.assign(new Error(`Card not found: ${d}`),{statusCode:404});let fe=await M(d);if(!fe)throw Object.assign(new Error(`Card not found: ${d}`),{statusCode:404});let _e=K?JSON.stringify(fe):null,Pe=P(fe)||fe;if(K&&JSON.stringify(Pe)===_e)return;let Be=await se.cardStoreOps.set({body:Pe});if(Be.status!=="success")throw Object.assign(new Error(Be.error||`Failed to persist card: ${d}`),{statusCode:500});if(V){let Oe=await se.boardOps.upsertCard({params:{cardId:d,restart:true}});if(Oe.status!=="success")throw Object.assign(new Error(Oe.error||`Failed to upsert card: ${d}`),{statusCode:500})}}async function c(d,P){await q(d,P,{syncBoard:true});}async function E(d,P){await q(d,P,{syncBoard:false});}async function L(d){let P=H(d);if(!P)throw Object.assign(new Error(`Card not found: ${d}`),{statusCode:404});if(!await M(d))throw Object.assign(new Error(`Card not found: ${d}`),{statusCode:404});let V=await P.boardOps.upsertCard({params:{cardId:d,restart:true}});if(V.status!=="success")throw Object.assign(new Error(V.error||`Failed to retrigger card: ${d}`),{statusCode:500})}function ee(d){u.clear(d);try{I().setChatProcessing({cardId:d,active:!1});}catch{}}function ne(d,P,F,V,K=""){let se=typeof F=="string"?F.trim():"";return u.append(d,P||"system",se,V,K)}function te(d){return u.readAll(d)}let Se=On({safeCardId:d=>B(d),artifactsStores:d=>k(d),cardFileMetadataStore:()=>S(),readCardFromStore:d=>M(d),updateCardLocalOnly:(d,P)=>E(d,P),writeChatRecord:(d,P,F,V,K)=>ne(d,P,F,V,K)}).uploadCardFile;async function be(d){let P=H(d);if(!P)return null;let F=await P.boardOps.getConfig({params:{key:"chat-handler-flow"}}),V=F.status==="success"?F.data?.value:null,K=P.chatHandlerRef;return V==null&&(!K||typeof K!="object")?null:{ctx:P,handlerFlow:V,handlerRef:K}}async function Ve(d,P,F=false,V=""){let K=await be(d);if(!K)return;let{ctx:se,handlerFlow:fe,handlerRef:_e}=K;if(!F)try{I().setChatProcessing({cardId:d,active:!0});}catch{}let Pe={boardId:o,cardId:String(d),lastChatEntryId:P,...V?{turnId:V}:{},...g,...f?{serverUrl:f}:{}},Be=fe!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:Hn}}:_e;try{ze(se.boardAdapter)?await se.boardAdapter.chatAgentStore().enqueueRequest({boardId:o,ref:Be,args:fe!=null?{...Pe,__chatHandlerFlow:fe}:Pe}):se.boardAdapter.chatAgentStore().enqueueRequest({boardId:o,ref:Be,args:fe!=null?{...Pe,__chatHandlerFlow:fe}:Pe}),await Promise.resolve(se.boardAdapter.requestProcessAccumulated?.());}catch(Oe){try{I().setChatProcessing({cardId:d,active:!1});}catch{}s.warn(`[chat-handler] queue failed for card "${d}": ${Oe instanceof Error?Oe.message:String(Oe)}`);}}async function je(d,P,F){if(P.howToRun==="built-in"&&Br(P)===Hn){let V=a,K=F.__chatHandlerFlow,se={...F};return delete se.__chatHandlerFlow,V?V.run(K,se,{boardId:o,cardId:String(se.cardId||""),label:d.label,logger:s,serverUrl:f,executionExtra:g}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return i.invoke(P,F)}async function tt(d,P=false){P||await X();let F=typeof d.args?.cardId=="string"?d.args.cardId:"",V=F?H(F):oe();if(!V)throw new Error(F?`Board context is unavailable for chat-agent request: ${F}`:"Board context is unavailable for chat-agent request");let K=await je(V,d.ref,d.args);if(!K.dispatched){if(F)try{u.setProcessing(F,!1);}catch{}throw new Error(K.error||`chat-agent dispatch failed for card "${F||"unknown"}"`)}}async function rt(d,P,F){let V=P==="chat-send"?E:c,K;await V(d,se=>{let fe=new Date().toISOString(),_e=se.card_data&&typeof se.card_data=="object"?se.card_data:{};if(se.card_data=_e,P==="chat-send"){let Pe=F&&typeof F.text=="string"?F.text.trim():"",Be=F&&typeof F["turn-id"]=="string"?F["turn-id"]:F&&typeof F.turnId=="string"?F.turnId:F&&typeof F.turn=="string"?F.turn:"",Oe=[];if(Array.isArray(F?.files)){for(let Ne of F.files)if(Ne){if(typeof Ne=="string"){Oe.push({name:Ne});continue}if(typeof Ne=="object"){let He=Ne;typeof He.name=="string"&&Oe.push({name:He.name,size:He.size,mime_type:He.mime_type,uploaded_at:He.uploaded_at,stored_name:He.stored_name,chat:He.chat===true});}}}if(Pe||Oe.length>0){let Ne=b.runBatch({cardId:d,commands:[{command:"append",role:"user",text:Pe,files:Oe,turn:Be},{command:"set-processing",active:true}]});if(Ne.status!=="success")throw new Error(Ne.error);let He=Ne.data.results[0]?.data?.id;if(typeof He!="string"||!He)throw new Error(`chat-send did not return an append id for card ${d}`);K={cardId:d,lastEntryId:He,processingAlreadySet:true,turnId:Be};try{y.broadcastCardChats(d);}catch{}}return se}if(P==="file-upload"){let Pe=S().normalizeIncoming(F?.files,fe);return Pe.length>0&&S().merge(_e,Pe),se}if(P==="action"){let Pe=F&&typeof F.buttonId=="string"?F.buttonId:"";if(!Pe)return se;_e.lastAction={buttonId:Pe,at:fe},_e.lastActionText=`${Pe} @ ${fe}`;}return se}),K&&Ve(K.cardId,K.lastEntryId,K.processingAlreadySet,K.turnId??"");}function Ke(d,P,F){let V=JSON.stringify(F),K=typeof Buffer<"u"?Buffer.byteLength(V):new TextEncoder().encode(V).length;d.writeHead(P,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":K}),d.end(V);}async function nt(d,P,F){let V=await M(d);if(!V)throw Object.assign(new Error("Card not found"),{statusCode:404});let K=S().resolve(V.card_data,P,F);if(!K.ok&&K.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!K.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let se=K.file,fe=B(d),_e=k(d),Pe=String(se.stored_name||""),Be=`${fe}/${Pe}`,Oe=_e.files?await _e.files.getBytes(Be):null;if(!Oe)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:se,bytes:Oe}}async function ht(d,P,F,V){let{fileRecord:K,bytes:se}=await nt(P,F,V),fe=String(K.name||K.stored_name||"download.bin"),_e=String(K.mime_type||"application/octet-stream");d.writeHead(200,{"Content-Type":_e,"Content-Disposition":`attachment; filename="${fe}"`,"Content-Length":se.length}),d.end(se);}function kt(d){let P=String(d||"").toLowerCase();return P.startsWith("text/")||P.includes("json")||P.includes("xml")||P.includes("javascript")||P.includes("typescript")||P.includes("yaml")||P.includes("csv")}function Tt(d,P,F){let V=d.split(/\r?\n/);return (P==="head"?V.slice(0,F):V.slice(-F)).join(`
7
+ `)}async function lt(d){let P=[];for await(let V of d)P.push(V);let F=typeof Buffer<"u"?Buffer.concat(P).toString("utf-8").trim():new TextDecoder().decode(lr(P)).trim();return F?JSON.parse(F):{}}async function Ct(d,P){let F=typeof P.ref=="string"?P.ref.trim():"";if(!F)return {status:"fail",error:"board-worker success callback requires body.ref"};let V=w[0];return V?V.boardOps.sourceDataFetched({params:{token:d,ref:F}}):{status:"fail",error:"no board context"}}async function ar(d,P){let F=typeof P.reason=="string"&&P.reason.trim()?P.reason:"unknown",V=w[0];return V?V.boardOps.sourceDataFetchFailure({params:{token:d,reason:F}}):{status:"fail",error:"no board context"}}let ft=Kn({sseHub:y,corsHeaders:r,json:Ke,buildPublishedRuntimePayload:()=>xe(),onSseClientConnected:v,onChannelSubscribed:R,onChannelUnsubscribed:l,apiBasePath:t,readJsonBody:d=>lt(d),initBoardAndSetup:()=>X(),bootstrapBoard:()=>N(),boardContexts:w,publishPersistedStateSnapshot:d=>D(d),upsertCardsFromSource:(d,P)=>j(d,P)}).handleWatchersRoutes,dr=$n({apiBasePath:t,json:Ke,readJsonBody:d=>lt(d),bootstrapBoard:()=>N(),createMcpFacade:()=>I(),createMcpToolRegistry:d=>J(d),resolveCardFileDownloadPayload:(d,P,F)=>nt(d,P,F),isLikelyTextMimeType:d=>kt(d),sliceTextByLines:(d,P,F)=>Tt(d,P,F)}).handleAgentfaceApi,ot=Un({apiBasePath:t,json:Ke,readJsonBody:d=>lt(d),initBoardAndSetup:()=>X(),createMcpWebhookToolRegistry:()=>G()}).handleWebhooksApi,ur=fr({apiBasePath:t,json:Ke,readJsonBody:d=>lt(d),initBoardAndSetup:()=>X(),bootstrapBoard:()=>N(),buildPublishedRuntimePayload:()=>xe(),createMcpControlplaneToolRegistry:()=>re(),retriggerCard:d=>L(d),applyCardAction:(d,P,F)=>rt(d,P,F),resolveChatHandlerTarget:d=>be(d),sendCardFileDownloadResponse:(d,P,F,V)=>ht(d,P,F,V)}).handleRuntimeApi;async function Q(d,P,F){return !!(await dr(d,P,F)||await ot(d,P,F)||await ft(d,P,F)||await ur(d,P,F))}return {get apiBasePath(){return t},get corsHeaders(){return r},get queueLaneTuning(){return n},handleRuntimeApi:Q,buildPublishedRuntimePayload:xe,processAccumulatedEvents:Z,processAccumulatedLane:$,handleChatAgentRequest:tt,clearChatRecords:ee,reportSourceFetched(d,P){return Ct(d,{ref:P})},reportSourceFetchFailure(d,P){return ar(d,{reason:P})},get cardStore(){return w[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Go(e){let t=String(e.apiBasePath||"/api/boards").replace(/\/$/,""),r={...Jn,...e.corsHeaders||{}},n=e.serverMetaStore,o=e.boardRuntimeFactory,s=new Map,i="boards-config.json";function a(){let l=n.getText(i);if(!l)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(l)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function u(l){n.putText(i,JSON.stringify(l,null,2));}function b(l){let y=String(l||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return y.length>0&&y.length<=64?y:null}function A(l){if(s.has(l))return s.get(l);let O=a().boards.find(_=>_.id===l)||{},w=o(l,O);return s.set(l,w),w}function f(l,y,O){let w=JSON.stringify(O),_=typeof Buffer<"u"?Buffer.byteLength(w):new TextEncoder().encode(w).length;l.writeHead(y,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":_}),l.end(w);}async function g(l,y,O){let w=l.method||"GET",_=O.pathname;if(w==="GET"&&_===t)return f(y,200,{ok:true,boards:a().boards}),true;if(w==="POST"&&_===t){let m=[];for await(let D of l)m.push(D);let p=typeof Buffer<"u"?Buffer.concat(m).toString("utf-8").trim():new TextDecoder().decode(lr(m)).trim(),k={};try{k=p?JSON.parse(p):{};}catch{k={};}let S=b(k.id);if(!S)return f(y,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let B=a();if(B.boards.some(D=>D.id===S))return f(y,409,{error:`Board "${S}" is already registered`}),true;let x=typeof k.label=="string"&&k.label.trim()?k.label.trim():S,h={id:S,label:x};for(let[D,j]of Object.entries(k))D==="id"||D==="label"||j!=null&&(h[D]=j);return B.boards.push(h),u(B),f(y,200,{ok:true,board:h}),true}return false}async function v(l,y,O){let _=O.pathname.match(new RegExp(`^${We(t)}/([^/]+)(/|$)`));if(!_)return false;let m=b(decodeURIComponent(_[1]));return m?a().boards.some(S=>S.id===m)?!!await A(m).handleRuntimeApi(l,y,O):(f(y,404,{error:`Board "${m}" not registered. POST ${t} with {id} to register it first.`}),true):(f(y,400,{error:"Invalid board id"}),true)}async function C(l,y,O){return !!(await g(l,y,O)||await v(l,y,O))}function R(l){if(!a().boards.some(O=>O.id===l))throw Object.assign(new Error(`Board "${l}" not registered`),{statusCode:404});return {service:A(l)}}return {get apiBasePath(){return t},get corsHeaders(){return r},handleApi:C,requireBoardService:R}}exports.createMultiBoardServerRuntime=Go;exports.createRoutesRuntimeApi=fr;exports.createSingleBoardServerRuntime=Jo;return exports;})({});//# sourceMappingURL=server-runtime-controlface.js.map
8
+ //# sourceMappingURL=server-runtime-controlface.js.map
@@ -72,39 +72,13 @@ Include them with a `<script>` tag. Each sets a global on `window`.
72
72
 
73
73
  ### compute-jsonata.js → `window.jsonataSync`
74
74
 
75
- Vendored jsonata engine for in-browser card computation.
76
- **Must be loaded before** `board-livecards-localstorage.js`.
75
+ Vendored jsonata engine for browser bundles that need in-browser card computation.
77
76
 
78
77
  ```html
79
78
  <script src="compute-jsonata.js"></script>
80
79
  ```
81
80
 
82
- No public API — just sets `window.jsonataSync` for the other bundles to pick up.
83
-
84
- ---
85
-
86
- ### board-livecards-localstorage.js → `window.BoardLiveCardsLocalStorage`
87
-
88
- **Drop-in full board engine for the browser** — no server required.
89
-
90
- Bundles: board engine + card computation + localStorage adapter.
91
- Ideal for demos, offline use, or prototyping before wiring up a server.
92
-
93
- ```html
94
- <script src="compute-jsonata.js"></script>
95
- <script src="board-livecards-localstorage.js"></script>
96
- <script>
97
- const app = BoardLiveCardsLocalStorage.create('my-board', {
98
- cards: [ /* card JSON objects */ ],
99
- taskExecutor: async (ref, args) => { /* your async task handler */ },
100
- });
101
- await app.bootstrap();
102
- const state = app.getState();
103
- // → feed to live-cards.js via LiveCard.init(...)
104
- </script>
105
- ```
106
-
107
- Key exports: `create()`, `selectLiveCardModel()`, `selectAllLiveCardModels()`
81
+ No public API — just sets `window.jsonataSync` for other bundles to pick up.
108
82
 
109
83
  ---
110
84
 
@@ -181,8 +155,7 @@ charts fall back to tables and markdown renders as escaped plain text.
181
155
  <script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
182
156
  <script src="https://cdn.jsdelivr.net/npm/dompurify/dist/purify.min.js"></script>
183
157
 
184
- <!-- 2. yaml-flow bundles — order matters -->
185
- <script src="compute-jsonata.js"></script> <!-- sets window.jsonataSync -->
186
- <script src="board-livecards-localstorage.js"></script> <!-- or board-livecards-client.js -->
187
- <script src="live-cards.js"></script> <!-- sets window.LiveCard -->
158
+ <!-- 2. yaml-flow bundles -->
159
+ <script src="board-livecards-client.js"></script>
160
+ <script src="live-cards.js"></script>
188
161
  ```
@@ -19,8 +19,8 @@
19
19
  <script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
20
20
  <script src="https://cdn.jsdelivr.net/npm/dompurify/dist/purify.min.js"></script>
21
21
  <script src="https://cdn.jsdelivr.net/npm/leader-line/leader-line.min.js"></script>
22
- <script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.4/browser/live-cards.js"></script>
23
- <script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.4/browser/board-livecards-client.js"></script>
22
+ <script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.7.1/browser/live-cards.js"></script>
23
+ <script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.7.1/browser/board-livecards-client.js"></script>
24
24
  </head>
25
25
  <body class="bg-light">
26
26
  <div class="container-fluid py-3">
@@ -37,8 +37,8 @@
37
37
  <script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
38
38
  <script src="https://cdn.jsdelivr.net/npm/dompurify/dist/purify.min.js"></script>
39
39
  <script src="https://cdn.jsdelivr.net/npm/leader-line/leader-line.min.js"></script>
40
- <script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.4/browser/live-cards.js"></script>
41
- <script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.4/browser/board-livecards-client.js"></script>
40
+ <script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.7.1/browser/live-cards.js"></script>
41
+ <script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.7.1/browser/board-livecards-client.js"></script>
42
42
  </head>
43
43
  <body class="bg-light">
44
44
  <div class="container-fluid py-3">
@@ -11,8 +11,10 @@ import { fileURLToPath, pathToFileURL } from 'node:url';
11
11
  import {
12
12
  createMultiBoardServerRuntime,
13
13
  createSingleBoardServerRuntime,
14
- createHostedBoardQueueLaneRegistry,
15
14
  } from 'yaml-flow/board-live-cards-server-runtime';
15
+ import {
16
+ createHostedBoardQueueLaneRegistry,
17
+ } from 'yaml-flow/server-jobs-queue-runner';
16
18
  import {
17
19
  createHostedAsyncBoardPlatformAdapter,
18
20
  } from 'yaml-flow/cloud-storage';
@@ -316,7 +318,7 @@ function makeBoardWorkerCallbackTransport(serverUrl, boardApiBasePath, transport
316
318
  const normalizedServerUrl = typeof serverUrl === 'string' ? serverUrl.trim().replace(/\/+$/, '') : '';
317
319
  const normalizedApiBasePath = typeof boardApiBasePath === 'string' ? boardApiBasePath.trim().replace(/\/+$/, '') : '';
318
320
  if (!normalizedServerUrl || !normalizedApiBasePath) return undefined;
319
- return createHttpBoardCallbackTransport(`${normalizedServerUrl}${normalizedApiBasePath}/callback/board-worker`);
321
+ return createHttpBoardCallbackTransport(`${normalizedServerUrl}${normalizedApiBasePath}/mcp-webhooks`);
320
322
  }
321
323
 
322
324
  async function readJsonRequest(req) {