yaml-flow 8.7.0 → 8.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (200) hide show
  1. package/browser/adapters/firebase-storage.js +2 -2
  2. package/browser/adapters/firestore-storage.js +2 -2
  3. package/browser/adapters/localstorage-storage.js +3 -3
  4. package/browser/asset-integrity.json +11 -15
  5. package/browser/live-cards.schema.json +10 -1
  6. package/browser/server-runtime-controlface.js +5 -5
  7. package/examples/ARCHITECTURE.md +0 -27
  8. package/examples/board/server/board-server.js +151 -101
  9. package/examples/board/server/board-worker/source_def_flows.json +0 -8
  10. package/examples/board/server/board-worker/task-executor.js +1 -3
  11. package/examples/board/test/server-http-test.js +181 -152
  12. package/examples/board-firestore/server/worker.js +9 -1
  13. package/examples/portfolio-tracker/portfolio-tracker.js +11 -1
  14. package/examples/portfolio-tracker/test/portfolio-t4.js +12 -2
  15. package/lib/{artifacts-store-lib-D9nMkVcE.d.cts → artifacts-store-lib-C6qBpMfU.d.cts} +1 -1
  16. package/lib/{artifacts-store-lib-DSSMqVL2.d.ts → artifacts-store-lib-D4qf7Q-7.d.ts} +1 -1
  17. package/lib/artifacts-store-public.d.cts +3 -3
  18. package/lib/artifacts-store-public.d.ts +3 -3
  19. package/lib/board-live-cards-mcp.cjs +1 -1
  20. package/lib/board-live-cards-mcp.d.cts +7 -7
  21. package/lib/board-live-cards-mcp.d.ts +7 -7
  22. package/lib/board-live-cards-mcp.js +1 -1
  23. package/lib/board-live-cards-node.cjs +8 -8
  24. package/lib/board-live-cards-node.d.cts +16 -14
  25. package/lib/board-live-cards-node.d.ts +16 -14
  26. package/lib/board-live-cards-node.js +8 -8
  27. package/lib/{board-live-cards-public-DQzPe7A9.d.cts → board-live-cards-public-BT5HrgqZ.d.cts} +82 -59
  28. package/lib/{board-live-cards-public-D-DJek3X.d.ts → board-live-cards-public-DSRamFm8.d.ts} +82 -59
  29. package/lib/{board-live-cards-public-async-CgMCYYft.d.cts → board-live-cards-public-async-CYjr4mgX.d.cts} +18 -8
  30. package/lib/{board-live-cards-public-async-3hUuHxDx.d.ts → board-live-cards-public-async-DlyC3PgC.d.ts} +18 -8
  31. package/lib/board-live-cards-public.cjs +1 -1
  32. package/lib/board-live-cards-public.d.cts +2 -2
  33. package/lib/board-live-cards-public.d.ts +2 -2
  34. package/lib/board-live-cards-public.js +1 -1
  35. package/lib/board-live-cards-server-runtime.cjs +1 -1
  36. package/lib/board-live-cards-server-runtime.d.cts +6 -8
  37. package/lib/board-live-cards-server-runtime.d.ts +6 -8
  38. package/lib/board-live-cards-server-runtime.js +1 -1
  39. package/lib/board-livegraph-runtime/index.cjs +1 -1
  40. package/lib/board-livegraph-runtime/index.js +1 -1
  41. package/lib/{board-platform-adapter-async-DOfEq_HC.d.cts → board-platform-adapter-async-BZIftm36.d.cts} +18 -14
  42. package/lib/{board-platform-adapter-async-JZPCzZnH.d.ts → board-platform-adapter-async-JP9V-U5E.d.ts} +18 -14
  43. package/lib/board-worker-adapter.cjs +1 -24
  44. package/lib/board-worker-adapter.d.cts +68 -3
  45. package/lib/board-worker-adapter.d.ts +68 -3
  46. package/lib/board-worker-adapter.js +1 -24
  47. package/lib/card-compute/index.cjs +1 -1
  48. package/lib/card-compute/index.js +1 -1
  49. package/lib/card-store-public.d.cts +2 -2
  50. package/lib/card-store-public.d.ts +2 -2
  51. package/lib/card-validation.cjs +1 -1
  52. package/lib/card-validation.js +1 -1
  53. package/lib/chat-store-public.cjs +1 -1
  54. package/lib/chat-store-public.d.cts +20 -20
  55. package/lib/chat-store-public.d.ts +20 -20
  56. package/lib/chat-store-public.js +1 -1
  57. package/lib/chunk-2GSI6C45.js +7 -0
  58. package/lib/chunk-35N7ONTH.js +2 -0
  59. package/lib/chunk-37HDEW26.cjs +2 -0
  60. package/lib/{chunk-PMUSJQSR.cjs → chunk-3CZCGNY4.cjs} +2 -2
  61. package/lib/chunk-3KC6LBOG.js +3 -0
  62. package/lib/{chunk-BQS3EIEK.js → chunk-44L64VQ2.js} +3 -3
  63. package/lib/chunk-6OPXQPSC.js +2 -0
  64. package/lib/chunk-7BTZCOT5.js +2 -0
  65. package/lib/{chunk-U2N6MCD5.cjs → chunk-7JVHYHT2.cjs} +2 -2
  66. package/lib/chunk-7QZ267XP.cjs +2 -0
  67. package/lib/{chunk-XQRNDX4Q.js → chunk-ANKA7HEJ.js} +2 -2
  68. package/lib/{chunk-KAWQPLIE.cjs → chunk-BQUQTOPB.cjs} +2 -2
  69. package/lib/chunk-CMFD27ZC.cjs +3 -0
  70. package/lib/chunk-DOFNXJ4C.js +3 -0
  71. package/lib/chunk-ETW3BXHD.cjs +2 -0
  72. package/lib/chunk-FO4KNVU7.cjs +2 -0
  73. package/lib/{chunk-SGV7PU4H.js → chunk-FOFGEABN.js} +2 -2
  74. package/lib/chunk-GPCMBPLK.cjs +2 -0
  75. package/lib/chunk-GU3T75C4.js +3 -0
  76. package/lib/chunk-H3EHFCDZ.js +3 -0
  77. package/lib/chunk-H4TYOSMD.cjs +45 -0
  78. package/lib/chunk-HFW7E2Z7.cjs +4 -0
  79. package/lib/chunk-HWYMZK3N.cjs +3 -0
  80. package/lib/chunk-IQIZA7TN.cjs +7 -0
  81. package/lib/chunk-J4MHQ7JF.js +45 -0
  82. package/lib/chunk-MCPADH33.cjs +2 -0
  83. package/lib/chunk-NBJTYAYN.cjs +2 -0
  84. package/lib/chunk-NDAKMJQK.cjs +3 -0
  85. package/lib/chunk-NNSBBO5R.js +2 -0
  86. package/lib/chunk-NU5NO5NM.js +2 -0
  87. package/lib/chunk-O4RKTQBP.cjs +3 -0
  88. package/lib/chunk-O5UYCGIN.js +2 -0
  89. package/lib/chunk-Q3OTUDIE.js +2 -0
  90. package/lib/chunk-R44X3RQB.cjs +2 -0
  91. package/lib/chunk-RKKSVOP2.js +2 -0
  92. package/lib/chunk-UB54HZA4.cjs +2 -0
  93. package/lib/{chunk-CIAJNUR4.js → chunk-VGDLSS2H.js} +2 -2
  94. package/lib/{chunk-SFVO2LB2.cjs → chunk-VQCIOKJV.cjs} +3 -3
  95. package/lib/chunk-VS3BXEYK.js +4 -0
  96. package/lib/chunk-Y4WK7HE4.js +2 -0
  97. package/lib/chunk-YBYXCFAI.js +2 -0
  98. package/lib/chunk-ZK3E7L4Y.cjs +2 -0
  99. package/lib/cloud-storage.cjs +1 -1
  100. package/lib/cloud-storage.d.cts +6 -6
  101. package/lib/cloud-storage.d.ts +6 -6
  102. package/lib/cloud-storage.js +1 -1
  103. package/lib/continuous-event-graph/index.cjs +1 -1
  104. package/lib/continuous-event-graph/index.js +1 -1
  105. package/lib/execution-refs.cjs +1 -1
  106. package/lib/execution-refs.js +1 -1
  107. package/lib/firebase-storage/index.cjs +2 -2
  108. package/lib/firebase-storage/index.d.cts +2 -2
  109. package/lib/firebase-storage/index.d.ts +2 -2
  110. package/lib/firebase-storage/index.js +2 -2
  111. package/lib/firestore-storage/index.cjs +2 -2
  112. package/lib/firestore-storage/index.d.cts +23 -8
  113. package/lib/firestore-storage/index.d.ts +23 -8
  114. package/lib/firestore-storage/index.js +2 -2
  115. package/lib/index.cjs +2 -2
  116. package/lib/index.d.cts +1 -1
  117. package/lib/index.d.ts +1 -1
  118. package/lib/index.js +1 -1
  119. package/lib/localstorage-storage/index.cjs +1 -1
  120. package/lib/localstorage-storage/index.d.cts +10 -6
  121. package/lib/localstorage-storage/index.d.ts +10 -6
  122. package/lib/localstorage-storage/index.js +1 -1
  123. package/lib/{mcp-tool-registries-W3TRj6O5.d.cts → mcp-tool-registries-CRtea2x4.d.cts} +3 -0
  124. package/lib/{mcp-tool-registries-BBObLYga.d.ts → mcp-tool-registries-D3rWSppt.d.ts} +3 -0
  125. package/lib/server-jobs-queue-runner/index.cjs +1 -1
  126. package/lib/server-jobs-queue-runner/index.d.cts +12 -9
  127. package/lib/server-jobs-queue-runner/index.d.ts +12 -9
  128. package/lib/server-jobs-queue-runner/index.js +1 -1
  129. package/lib/server-runtime/index.cjs +1 -1
  130. package/lib/server-runtime/index.d.cts +7 -9
  131. package/lib/server-runtime/index.d.ts +7 -9
  132. package/lib/server-runtime/index.js +1 -1
  133. package/lib/server-runtime-agentface/index.d.cts +7 -9
  134. package/lib/server-runtime-agentface/index.d.ts +7 -9
  135. package/lib/server-runtime-controlface/index.cjs +1 -1
  136. package/lib/server-runtime-controlface/index.d.cts +19 -71
  137. package/lib/server-runtime-controlface/index.d.ts +19 -71
  138. package/lib/server-runtime-controlface/index.js +1 -1
  139. package/lib/server-runtime-core/index.cjs +1 -1
  140. package/lib/server-runtime-core/index.d.cts +61 -21
  141. package/lib/server-runtime-core/index.d.ts +61 -21
  142. package/lib/server-runtime-core/index.js +1 -1
  143. package/lib/server-runtime-watchers/index.cjs +1 -1
  144. package/lib/server-runtime-watchers/index.d.cts +9 -65
  145. package/lib/server-runtime-watchers/index.d.ts +9 -65
  146. package/lib/server-runtime-watchers/index.js +1 -1
  147. package/lib/server-runtime-webhooks/index.d.cts +7 -9
  148. package/lib/server-runtime-webhooks/index.d.ts +7 -9
  149. package/lib/sse-hub-CYXisfXJ.d.cts +63 -0
  150. package/lib/sse-hub-Dodwtc3_.d.ts +63 -0
  151. package/lib/step-machine-public/index.cjs +1 -1
  152. package/lib/step-machine-public/index.d.cts +1 -1
  153. package/lib/step-machine-public/index.d.ts +1 -1
  154. package/lib/step-machine-public/index.js +1 -1
  155. package/lib/{storage-async-interface-BRR4eBjx.d.cts → storage-async-interface-CG0bMqvE.d.ts} +20 -1
  156. package/lib/{storage-async-interface-DhlOVPSp.d.ts → storage-async-interface-CyO-zwVQ.d.cts} +20 -1
  157. package/lib/{storage-interface-BFiD3kyB.d.ts → storage-interface-D-iEiTJA.d.cts} +45 -1
  158. package/lib/{storage-interface-BFiD3kyB.d.cts → storage-interface-D-iEiTJA.d.ts} +45 -1
  159. package/lib/stores/index.d.cts +1 -1
  160. package/lib/stores/index.d.ts +1 -1
  161. package/lib/stores/kv.d.cts +1 -1
  162. package/lib/stores/kv.d.ts +1 -1
  163. package/lib/{types-CF2xUcZW.d.ts → types-BtH3scgE.d.ts} +66 -29
  164. package/lib/{types-BzQY45dH.d.cts → types-Ch0u3FKP.d.cts} +66 -29
  165. package/package.json +4 -5
  166. package/schema/live-cards.schema.json +10 -1
  167. package/browser/board-livecards-client.js +0 -2
  168. package/examples/board/demo-shell-with-server.html +0 -272
  169. package/examples/board/doc.html +0 -465
  170. package/examples/board/server-config.json +0 -24
  171. package/lib/chat-storage-lib-B9Q34Dyv.d.cts +0 -54
  172. package/lib/chat-storage-lib-DB9iSai2.d.ts +0 -54
  173. package/lib/chunk-5XHOHTLZ.cjs +0 -2
  174. package/lib/chunk-6APH25VI.js +0 -2
  175. package/lib/chunk-76ON3V7R.js +0 -2
  176. package/lib/chunk-7ICPAABP.cjs +0 -7
  177. package/lib/chunk-CPAXTVBQ.cjs +0 -2
  178. package/lib/chunk-DDYSXP2A.cjs +0 -3
  179. package/lib/chunk-EGRHWZRV.js +0 -2
  180. package/lib/chunk-GL2OHR2E.cjs +0 -2
  181. package/lib/chunk-GYQXDNNI.cjs +0 -2
  182. package/lib/chunk-H5HBXPOI.cjs +0 -3
  183. package/lib/chunk-IPLSRN6P.cjs +0 -4
  184. package/lib/chunk-J5J6BG7B.js +0 -2
  185. package/lib/chunk-M3OU6IS5.cjs +0 -2
  186. package/lib/chunk-M6STQR5F.cjs +0 -2
  187. package/lib/chunk-N6P2JW4W.js +0 -3
  188. package/lib/chunk-NJJ7WEDT.cjs +0 -2
  189. package/lib/chunk-NKIQRCOM.cjs +0 -2
  190. package/lib/chunk-NMZ6XNLB.cjs +0 -3
  191. package/lib/chunk-OEFTOO47.cjs +0 -3
  192. package/lib/chunk-PRHQBGPT.js +0 -2
  193. package/lib/chunk-S44QZUDX.js +0 -2
  194. package/lib/chunk-TSN3RTXT.js +0 -4
  195. package/lib/chunk-VLBB3D6B.js +0 -3
  196. package/lib/chunk-VMW4Z6EF.js +0 -3
  197. package/lib/chunk-VXJHBWK3.js +0 -2
  198. package/lib/chunk-WHDEBJLT.js +0 -7
  199. package/lib/chunk-YGALANRO.js +0 -2
  200. package/lib/chunk-ZXQR7GHT.js +0 -3
@@ -0,0 +1,2 @@
1
+ import {a as a$1}from'./chunk-JMDHDY6M.js';function v(s,i){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function H(s,i){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${i} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function a(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function b(s){return Array.isArray(s)?s:[]}function z(s,i){if(typeof i!="string"||i.length===0)return;let c=s,u=i;u.startsWith("fetched_sources.")&&(c=a(s).fetched_sources,u=u.slice(16));for(let f of u.split(".")){if(c==null||typeof c!="object")return;c=c[f];}return c}function V(s,i){let c=a(s.view),u=b(c.elements);return {layout:c.layout,features:c.features,elements:u.map((f,_)=>{let I=a(f),k=a(I.data),R=typeof I.visible=="string"?!!z(i,I.visible):true,M=typeof k.bind=="string"?k.bind:void 0,P=typeof k.maxRows=="number"?k.maxRows:void 0,B=M?z(i,M):void 0,F={id:typeof I.id=="string"&&I.id?I.id:`element-${_}`,kind:I.kind,label:I.label,visible:R};return B!==void 0&&(F.resolved=Array.isArray(B)&&typeof P=="number"?B.slice(0,P):B),F})}}function G(s,i){let c=typeof s.id=="string"&&s.id?s.id:"card",u=b(s.provides),f=u.length>0?u:[{bindTo:c,ref:"card_data"}],_={};for(let I of f){let k=a(I),R=typeof k.bindTo=="string"?k.bindTo:"",M=typeof k.ref=="string"?k.ref:"";if(!R||!M)continue;let P=z(i,M);P!==void 0&&(_[R]=P);}return _}function he(s){if(typeof s!="string"||!s.trim())return null;let i=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!i)return null;let c=Number.parseInt(i[2],10);return !Number.isInteger(c)||c<0?null:c}function ke(s){return {"card-content":s}}function E(s){let i={...s};return delete i.__private,i}function D(s,i){return Object.prototype.hasOwnProperty.call(s,i)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,i){let c=Re(s);if(!i||Object.keys(i).length===0)return c;function u(f,_,I){let k=String(_||"").split(".").filter(Boolean);if(!k.length)return;let R=f;for(let M=0;M<k.length-1;M+=1){let P=k[M];(!R[P]||typeof R[P]!="object")&&(R[P]={}),R=R[P];}R[k[k.length-1]]=I;}if(i.fieldValues!==void 0&&i.fieldValues!==null){let f=null,_=a(c.view),I=b(_.elements);for(let k of I){let R=a(a(k).data);if(typeof R.writeTo=="string"&&R.writeTo){f=R.writeTo;break}}return f?u(c,f,i.fieldValues):typeof i.fieldValues=="object"&&!Array.isArray(i.fieldValues)&&(c.card_data={...a(c.card_data),...i.fieldValues}),c}if(Array.isArray(i._stagedFiles)&&i._stagedFiles.length>0)return c;for(let[f,_]of Object.entries(i))f!=="_stagedFiles"&&(_!==null&&typeof _=="object"&&!Array.isArray(_)&&c[f]!==null&&typeof c[f]=="object"&&!Array.isArray(c[f])?c[f]={...c[f],..._}:c[f]=_);return c}function Q(s){return a(s.__private).visible_controlplane_only===true}async function T(s,i){let c=await U(s.get({params:{id:i}}),"cardStore.get"),u=Array.isArray(c?.cards)?c.cards:[];if(u.length===0)throw new Error(`Card "${i}" not found`);return u[0]}function Ae(s){let{board:i,nonCore:c,cardStore:u,chatStore:f,processAccumulated:_,sourceFetchDone:I,sourceFetchFailed:k,uploadCardFile:R,buildFileDownloadUrl:M,readFetchedSourceJsonByRef:P}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function F(){let e=await U(u.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>a(r)):[]}function X(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),n=atob(t);return Uint8Array.from(n,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=a(await U(c.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:a(e.commonSourceDefFields),sourceKinds:a(e.sourceKinds)}}async function Z(){let e=a(await U(i.status({}),"status")),r=a(e.summary),t=b(e.cards);return {meta:a(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:t.map(n=>{let o=a(n);return {"card-id":typeof o.name=="string"?o.name:null,status:o.status??null,error:o.error??null,requires:b(o.requires),requires_satisfied:b(o.requires_satisfied),requires_missing:b(o.requires_missing),provides_declared:b(o.provides_declared),provides_runtime:b(o.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=a(await U(i.status({}),"status")),o=b(t.cards).map(a).find(p=>p.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let d=a(await T(u,r));if(Q(d))throw Object.assign(new Error(`card "${r}" not found`),{statusCode:404});let m=E(d),g=b(o.requires_satisfied).filter(p=>typeof p=="string"&&!!p),w=b(o.provides_runtime).filter(p=>typeof p=="string"&&!!p),h=Object.fromEntries(await Promise.all(g.map(async p=>[p,await U(i.getOutputsDataObject({params:{key:p}}),`getOutputsDataObject(${p})`)]))),A=Object.fromEntries(await Promise.all(w.map(async p=>[p,await U(i.getOutputsDataObject({params:{key:p}}),`getOutputsDataObject(${p})`)]))),C=a(await U(i.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),l=await U(i.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),S=b(d.source_defs).map(a),y={};for(let p of S)typeof p.bindTo=="string"&&typeof p.outputFile=="string"&&(y[p.outputFile]=p.bindTo);let x={};for(let[p,O]of Object.entries(l)){let q=y[p]??p;if(!P||typeof O!="string"){x[q]=null;continue}try{x[q]=P({cardId:r,ref:O});}catch{x[q]=null;}}let L={card_data:a(d.card_data),requires:h,fetched_sources:x,computed_values:C};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:m,refs_for_fetched_source_files:l,runtime_data:{requires:h,provides:A,computed_values:C,rendered_view:V(d,L)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",n=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",d=n?void 0:e.lastUserTurns??(t?void 0:1),m=e.tail,g={...d===void 0?{}:{tailTurns:d},...t?{turnId:t}:{},...n?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},w=Object.keys(g).length>0?{params:{cardId:r},body:g}:{params:{cardId:r}},h=v(await f.readAll(w),"chatStore.readAll"),A=a(await T(u,r)),C=b(a(A.card_data).files).map((y,x)=>({idx:x,stored_name:a(y).stored_name})).filter(y=>typeof y.stored_name=="string"&&y.stored_name.length>0),S=(Array.isArray(h.records)?h.records:[]).map(y=>{let L=a(y.payload),p={...y},O=typeof y?.role=="string"?y.role:typeof L.role=="string"?String(L.role):"",q=typeof y?.text=="string"?y.text:typeof L.text=="string"?String(L.text):"";if(O==="system"){let N=he(q);if(N!==null&&C.some(j=>j.idx===N)){let j=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${N}`;p.retrieval_hint=j,Object.keys(L).length>0&&typeof y.role!="string"&&(p.payload={...L,retrieval_hint:j});}}return p});return {cardId:r,messages:typeof m=="number"&&m>=0?S.slice(-m):S}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let n=a(await T(u,r)),o=b(a(n.card_data).files).map(a);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let d=o[t],m=typeof d.stored_name=="string"?d.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:M({cardId:r,fileIdx:t,storedName:m}),...typeof d.name=="string"?{name:d.name}:{},...typeof d.stored_name=="string"?{stored_name:d.stored_name}:{},...typeof d.mime_type=="string"?{mime_type:d.mime_type}:{},...typeof d.size=="number"?{size:d.size}:{},...typeof d.uploaded_at=="string"?{uploaded_at:d.uploaded_at}:{}}}async function $(e){return await c.validateCardPreflight({body:ke(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=c.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=a(H(r,"evalCardCompute")),n=a(e.candidateCardContent),o={card_data:a(n.card_data),requires:a(e.mockRequires),fetched_sources:a(e.mockFetchedSources),computed_values:a(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof n.id=="string"?n.id:"(unknown)",ok:t.ok===true,computed_values:a(t.computed_values),errors:b(t.errors).map(d=>{let m=a(d);return {bindTo:typeof m.bindTo=="string"?m.bindTo:"",error:typeof m.error=="string"?m.error:""}}),provides_outputs:G(n,o),rendered_view:V(n,o)}}}async function ae(e){return await c.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=a(await T(u,r)),n=b(t.source_defs).filter(d=>!!d&&typeof d=="object"&&!Array.isArray(d)),o={};if(e.sourceIdx>=0&&e.sourceIdx<n.length){let d=n[e.sourceIdx],m=a$1.enrichSourcesSync([d],{card_data:a(t.card_data),requires:e.mockRequires});Array.isArray(m)&&m.length>0&&(o=a(m[0]._projections));}return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=a(await U(c.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=a(e.candidateCardContent),n=a(r.validation),o=b(r.source_probes),d=b(r.projection_errors),m=a(r.fetched_sources),g=b(r.compute_errors),w=a(r.computed_values),h={card_data:a(t.card_data),requires:e.mockRequires,fetched_sources:m,computed_values:w},A=[];for(let C of b(n.issues))typeof C=="string"&&C&&A.push(C);for(let C of o){let l=a(C),S=typeof l.bindTo=="string"?l.bindTo:"source",y=typeof l.error=="string"?l.error:"";y&&A.push(`${S}: ${y}`);}for(let C of d){let l=a(C),S=typeof l.bindTo=="string"?l.bindTo:"source",y=typeof l.key=="string"?l.key:"projection",x=typeof l.error=="string"?l.error:"projection failed";A.push(`${S}.${y}: ${x}`);}for(let C of g){let l=a(C),S=typeof l.bindTo=="string"?l.bindTo:"compute",y=typeof l.error=="string"?l.error:"compute failed";A.push(`${S}: ${y}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:A,provides_outputs:G(t,h),rendered_view:V(t,h)}}}async function K(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await U(u.get({params:{id:r}}),"cardStore.get"),n=Array.isArray(t.cards)?t.cards.map(a):[];if(n.some(Q))throw Object.assign(new Error(`Card "${r}" not found`),{statusCode:404});return n.map(o=>E(o))}async function W(e){let r=await Promise.all(b(e.files).map(async t=>{let n=a(t),o=String(n.file_name??n.fileName??n.name??"").trim(),d=String(n.content_type??n.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await R({cardId:e.cardId,fileName:o,contentType:d,bytes:X(n),suppressChatRecordWrite:true})}));for(let[t,n]of r.entries()){let o=a(n.file),d=typeof n.file_idx=="number"&&Number.isInteger(n.file_idx)&&n.file_idx>=0?n.file_idx:t,m=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`;v(await f.append({params:{cardId:e.cardId},body:{role:"system",text:m,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}return r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",n=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await W({cardId:r,role:t,turn:n,files:e.files});return {status:"success",data:{cardId:r,turn:n,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),n=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let g=v(await f.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),w=Array.isArray(g.records)?g.records.find(h=>h.role==="assistant"&&String(h.turn||"")===o):void 0;if(w)return {status:"success",data:{cardId:r,id:String(w.id),role:t,turn:o,files:Array.isArray(w.files)?w.files:[]}}}let d=await W({cardId:r,role:t,turn:o,files:e.files}),m=v(await f.append({params:{cardId:r},body:{role:t,text:n,files:d,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(m.id),role:t,turn:o,files:d}}}async function ue(e){let r=String(e.cardId||"").trim(),t=a(e.patch);if(!r)throw new Error("managePatchCard requires cardId");let n=await K({cardId:r}),o=a(n[0]),m={...ve(o,t),...D(o,"meta")?{meta:o.meta}:{},...D(o,"__private")?{__private:o.__private}:{}},g=await u.set({body:m});v(g,"cardStore.set");let w;try{w=await i.upsertCard({params:{cardId:r,restart:!0}}),v(w,"upsertCard");}catch(A){try{await u.set({body:o});}catch{}throw A}let h=null;try{h=await i.cardRefreshedNotify({params:{cardId:r}}),v(h,"cardRefreshedNotify");}catch{h=null;}return {status:"success",data:{validation:null,card_saved:null,board_result:w,refresh_notify:h}}}async function le(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("manageUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:n}),d=a(o),m=a(d.data);if(d.status!=="success"||m.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let w=g?a(g):null,h={...n,...w&&D(w,"meta")?{meta:w.meta}:{},...w&&D(w,"__private")?{__private:w.__private}:{}},A=await u.set({body:h});v(A,"cardStore.set");let C;try{C=await i.upsertCard({params:{cardId:r,restart:!0}}),v(C,"upsertCard");}catch(S){try{g&&await u.set({body:g});}catch{}throw S}let l=null;try{l=await i.cardRefreshedNotify({params:{cardId:r}}),v(l,"cardRefreshedNotify");}catch{l=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:C,refresh_notify:l}}}async function me(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageRemoveCard requires cardId");let t=await i.removeCard({params:{id:r}});v(t,"removeCard");let n=await u.del({params:{id:r}});return v(n,"cardStore.del"),{status:"success",data:{board_result:t,store_result:n}}}async function pe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await U(u.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(n=>a(n)):[]}async function fe(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:n}),d=a(o),m=a(d.data);if(d.status!=="success"||m.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let w=g?a(a(g).__private):{},h={...n,__private:{...w,visible_controlplane_only:true}},A=await u.set({body:h});v(A,"cardStore.set");let C;try{C=await i.upsertCard({params:{cardId:r,restart:!0}}),v(C,"upsertCard");}catch(S){try{g&&await u.set({body:g});}catch{}throw S}let l=null;try{l=await i.cardRefreshedNotify({params:{cardId:r}}),v(l,"cardRefreshedNotify");}catch{l=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:C,refresh_notify:l}}}async function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=H(await f.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}async function we(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return v(await f.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function Ce(){let e=await B(_,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let n=await B(I,"webhook.source-fetch-done")({token:r,ref:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}async function be(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let n=await B(k,"webhook.source-fetch-failed")({token:r,reason:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}return {listRuntimeCards:F,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:$,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:K,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:le,manageRemoveCard:me,adminReadCard:pe,adminUpsertCard:fe,getChatProcessing:ge,setChatProcessing:we,webhookProcessAccumulated:Ce,webhookSourceFetchDone:ye,webhookSourceFetchFailed:be}}async function U(s,i){return v(await s,i)}export{Ae as a};//# sourceMappingURL=chunk-35N7ONTH.js.map
2
+ //# sourceMappingURL=chunk-35N7ONTH.js.map
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunk7JVHYHT2_cjs=require('./chunk-7JVHYHT2.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs');function c(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function l(e){return typeof e=="string"?e.startsWith("b64:")?chunkVQCIOKJV_cjs.b(e).value:e:e.value}function m(e){return {async enqueueRequest(t){return (await e.enqueue(t)).id},async leaseRequests(t){return (await e.lease(t)).map(r=>({...c(r),leaseToken:r.leaseToken,leaseExpiresAt:r.leaseExpiresAt}))},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,a){return e.nack(t,r,a)},async peekActive(){return (await e.peekActive()).map(c)},async peekDeadLetter(){return (await e.peekDeadLetter()).map(t=>({...c(t),reason:t.reason}))}}}function h(e){async function t(r){let a=await e.read(r);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}return {async readTaskExecutorRef(){let r=await t("task-executor");if(r?.trim())return chunk7JVHYHT2_cjs.c(r.trim())},writeTaskExecutorRef(r){return e.write("task-executor",chunk7JVHYHT2_cjs.b(r))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){return e.write("chat-handler-flow",r)},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){return e.write("board-runtime-store-ref",r)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){return e.write("card-store-ref",r)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){return e.write("outputs-store-ref",r)},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){return e.write("queue-store-ref",r)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){return e.write("scratch-store-ref",r)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){return e.write("chat-store-ref",r)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){return e.write("artifacts-store-ref",r)},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){return e.write("fetched-sources-store-ref",r)}}}function y(e){let t=e.callbackTransport,r=e.resolveBlob??(async o=>{let s=await e.blobStorage("").read(o.value);if(s==null)throw new Error(`Blob not found for ref ${o.kind}:${o.value}`);return s});async function a(o,s){if(o.howToRun==="queue-storage")return e.queueStoreRef?(await m(e.queueStorageForRef(e.queueStoreRef,"task-executor")).enqueueRequest({boardId:typeof o.extra?.boardId=="string"?o.extra.boardId:e.boardId,ref:o,args:s}),{dispatched:true}):{dispatched:false,error:"queue-storage dispatch requires queueStoreRef"};if(o.howToRun==="http:post"){let n=e.fetch??globalThis.fetch;if(!n)return {dispatched:false,error:"http:post dispatch requires fetch support"};let i=await n(l(o.whatToRun),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...s,...o.extra?{extra:o.extra}:{}})});if(!i.ok){let g=await i.text().catch(()=>"");return {dispatched:false,error:`HTTP ${i.status}: ${g}`}}return {dispatched:true}}return {dispatched:false,error:`Unsupported hosted async transport "${o.howToRun}"`}}return {kvStorage:e.kvStorage,kvStorageForRef:e.kvStorageForRef,blobStorage:e.blobStorage,blobStorageForRef:e.blobStorageForRef,chatStorageForRef:e.chatStorageForRef,queueStorageForRef:e.queueStorageForRef,scratchStorage:e.scratchStorage,scratchStorageForRef:e.scratchStorageForRef,archiveFactory:e.archiveFactory,archiveFactoryForRef:e.archiveFactoryForRef,journalStorage:e.journalStorage,journalStorageForRef:e.journalStorageForRef,lock:e.lock,get callbackTransport(){return t},set callbackTransport(o){t=o;},dispatchExecution:(o,s)=>e.dispatchExecution?.(o,s)??a(o,s),supportsDirectSourceOutput:e.supportsDirectSourceOutput,resolveBlob:r,hashFn:e.hashFn,genId:e.genId,requestProcessAccumulated:e.requestProcessAccumulated,publishBoardChangeNotifications:e.publishBoardChangeNotifications,warn:e.onWarn}}exports.a=m;exports.b=h;exports.c=y;//# sourceMappingURL=chunk-37HDEW26.cjs.map
2
+ //# sourceMappingURL=chunk-37HDEW26.cjs.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkSFVO2LB2_cjs=require('./chunk-SFVO2LB2.cjs'),module$1=require('module'),url=require('url'),path=require('path'),fs=require('fs');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var f=path.dirname(url.fileURLToPath((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-PMUSJQSR.cjs', document.baseURI).href)))),E=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-PMUSJQSR.cjs', document.baseURI).href)));function w(){let e=path.resolve(f,"./jsonata-sync.cjs");return fs.existsSync(e)?e:path.resolve(f,"../../card-compute/jsonata-sync.cjs")}var p=E(w());function u(e){e.registerFunction("fsPathRef",s=>chunkSFVO2LB2_cjs.a({kind:"fs-path",value:String(s)}),"<s:s>");}function R(e,s,c){if(!e||typeof e!="object")return {};let i={};if(Array.isArray(e.cmdTemplate)){let r=[];for(let n of e.cmdTemplate)try{let a=p(n);u(a),r.push(String(a.evaluate(s)));}catch(a){let t=a instanceof Error?a.message:String(a);throw new Error(`[${c}] argsMassaging.cmdTemplate failed on "${n}": ${t}`)}i.cmdArgs=r;}if(typeof e.stdinTemplate=="string")try{let r=p(e.stdinTemplate);u(r),i.stdin=r.evaluate(s);}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.stdinTemplate failed: ${n}`)}if(typeof e.urlTemplate=="string")try{let r=p(e.urlTemplate);u(r),i.url=String(r.evaluate(s));}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.urlTemplate failed: ${n}`)}if(typeof e.headerTemplate=="string")try{let r=p(e.headerTemplate);u(r);let n=r.evaluate(s);if(typeof n!="object"||n===null)throw new Error(`headerTemplate must produce an object, got: ${JSON.stringify(n)}`);i.headers=n;}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.headerTemplate failed: ${n}`)}if(typeof e.bodyTemplate=="string")try{let r=p(e.bodyTemplate);u(r),i.body=r.evaluate(s);}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.bodyTemplate failed: ${n}`)}return i}function _(e,s,c){if(!e||typeof e!="object")return s;let i={output:s},r=s.result,n=s.data,a=s.error;if(typeof e.resultExpr=="string")try{let t=p(e.resultExpr);u(t);let o=t.evaluate(i);if(typeof o!="string"||!o.trim())throw new Error(`resultExpr did not produce a non-empty string (got ${JSON.stringify(o)})`);r=o;}catch(t){let o=t instanceof Error?t.message:String(t);throw new Error(`[${c}] outputTransforms.resultExpr failed: ${o}`)}if(typeof e.dataTemplate=="string")try{let t=p(e.dataTemplate);u(t);let o=t.evaluate(i);if(!o||typeof o!="object"||Array.isArray(o))throw new Error(`dataTemplate did not produce an object (got ${JSON.stringify(o)})`);n=o;}catch(t){let o=t instanceof Error?t.message:String(t);throw new Error(`[${c}] outputTransforms.dataTemplate failed: ${o}`)}if(typeof e.errorExpr=="string")try{let t=p(e.errorExpr);u(t);let o=t.evaluate(i);a=o!=null?String(o):void 0;}catch(t){let o=t instanceof Error?t.message:String(t);throw new Error(`[${c}] outputTransforms.errorExpr failed: ${o}`)}return a!==void 0?{result:r,data:n,error:a}:{result:r,data:n}}exports.a=R;exports.b=_;//# sourceMappingURL=chunk-PMUSJQSR.cjs.map
2
- //# sourceMappingURL=chunk-PMUSJQSR.cjs.map
1
+ 'use strict';var chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),module$1=require('module'),url=require('url'),path=require('path'),fs=require('fs');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var f=path.dirname(url.fileURLToPath((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-3CZCGNY4.cjs', document.baseURI).href)))),E=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-3CZCGNY4.cjs', document.baseURI).href)));function w(){let e=path.resolve(f,"./jsonata-sync.cjs");return fs.existsSync(e)?e:path.resolve(f,"../../card-compute/jsonata-sync.cjs")}var p=E(w());function u(e){e.registerFunction("fsPathRef",s=>chunkVQCIOKJV_cjs.a({kind:"fs-path",value:String(s)}),"<s:s>");}function R(e,s,c){if(!e||typeof e!="object")return {};let i={};if(Array.isArray(e.cmdTemplate)){let r=[];for(let n of e.cmdTemplate)try{let a=p(n);u(a),r.push(String(a.evaluate(s)));}catch(a){let t=a instanceof Error?a.message:String(a);throw new Error(`[${c}] argsMassaging.cmdTemplate failed on "${n}": ${t}`)}i.cmdArgs=r;}if(typeof e.stdinTemplate=="string")try{let r=p(e.stdinTemplate);u(r),i.stdin=r.evaluate(s);}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.stdinTemplate failed: ${n}`)}if(typeof e.urlTemplate=="string")try{let r=p(e.urlTemplate);u(r),i.url=String(r.evaluate(s));}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.urlTemplate failed: ${n}`)}if(typeof e.headerTemplate=="string")try{let r=p(e.headerTemplate);u(r);let n=r.evaluate(s);if(typeof n!="object"||n===null)throw new Error(`headerTemplate must produce an object, got: ${JSON.stringify(n)}`);i.headers=n;}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.headerTemplate failed: ${n}`)}if(typeof e.bodyTemplate=="string")try{let r=p(e.bodyTemplate);u(r),i.body=r.evaluate(s);}catch(r){let n=r instanceof Error?r.message:String(r);throw new Error(`[${c}] argsMassaging.bodyTemplate failed: ${n}`)}return i}function _(e,s,c){if(!e||typeof e!="object")return s;let i={output:s},r=s.result,n=s.data,a=s.error;if(typeof e.resultExpr=="string")try{let t=p(e.resultExpr);u(t);let o=t.evaluate(i);if(typeof o!="string"||!o.trim())throw new Error(`resultExpr did not produce a non-empty string (got ${JSON.stringify(o)})`);r=o;}catch(t){let o=t instanceof Error?t.message:String(t);throw new Error(`[${c}] outputTransforms.resultExpr failed: ${o}`)}if(typeof e.dataTemplate=="string")try{let t=p(e.dataTemplate);u(t);let o=t.evaluate(i);if(!o||typeof o!="object"||Array.isArray(o))throw new Error(`dataTemplate did not produce an object (got ${JSON.stringify(o)})`);n=o;}catch(t){let o=t instanceof Error?t.message:String(t);throw new Error(`[${c}] outputTransforms.dataTemplate failed: ${o}`)}if(typeof e.errorExpr=="string")try{let t=p(e.errorExpr);u(t);let o=t.evaluate(i);a=o!=null?String(o):void 0;}catch(t){let o=t instanceof Error?t.message:String(t);throw new Error(`[${c}] outputTransforms.errorExpr failed: ${o}`)}return a!==void 0?{result:r,data:n,error:a}:{result:r,data:n}}exports.a=R;exports.b=_;//# sourceMappingURL=chunk-3CZCGNY4.cjs.map
2
+ //# sourceMappingURL=chunk-3CZCGNY4.cjs.map
@@ -0,0 +1,3 @@
1
+ import {q as q$1}from'./chunk-MNEOJWPS.js';import {b as b$1}from'./chunk-FW4363Y4.js';import A from'ajv-formats';import {createRequire}from'module';var h={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://nsreehari.github.io/boards/live-cards.schema.json",definitions:{bind_ref:{description:"A card data path reference, e.g. 'card_data.raw_quotes' or 'requires.upstream'",type:"string",pattern:"^(card_data|requires|fetched_sources|computed_values)(\\.|$)"},bind_or_literal:{description:"A literal value or a bind reference object",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref"}},required:["bind"]}]},compute_expr:{description:"A declarative JSON compute expression",type:"object",required:["fn"],properties:{fn:{type:"string",description:"Function name from the built-in vocabulary",enum:["sum","avg","min","max","count","first","last","add","sub","mul","div","round","abs","mod","gt","gte","lt","lte","eq","neq","if","and","or","not","concat","upper","lower","template","filter","pluck","map","sort","slice","flat","unique","group","get","default","now","diff_days","format_date"]},input:{description:"card_data.path, literal, array of inputs, or nested compute_expr",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{$ref:"#/definitions/compute_expr"}]},field:{type:"string",description:"For pluck/sum/group \u2014 the object key to extract"},where:{$ref:"#/definitions/compute_expr",description:"For filter \u2014 predicate expression ($ = current item)"},cond:{$ref:"#/definitions/compute_expr",description:"For if \u2014 condition expression"},then:{description:"For if \u2014 value when cond is truthy"},else:{description:"For if \u2014 value when cond is falsy"},format:{type:"string",description:"For format_date \u2014 date format string"}}},meta:{type:"object",properties:{title:{type:"string"},tags:{type:"array",items:{type:"string"}}},additionalProperties:true},__private:{description:"Control-plane-owned private state. Stripped entirely from all regular /mcp read responses. Writable only via 'setstate.card-private' and 'manage.admin-upsert-card'. Agents must never author this field. Keys inside use plain names (no leading underscores).",type:"object",additionalProperties:true},requires:{type:"array",items:{type:"string"},description:"IDs of upstream nodes this node depends on"},provides:{type:"array",items:{type:"object",required:["bindTo","ref"],properties:{bindTo:{type:"string",description:"Token name published downstream"},ref:{type:"string",description:"Path to read value from (card_data.*, requires.*, fetched_sources.*, computed_values.*)"}}},description:"Explicit bindings exposing computed or card_data values downstream as named tokens"},compute_step:{description:"A single ordered compute step: reads card_data.*/requires.*/computed_values.*, writes to computed_values[bindTo]",type:"object",required:["bindTo","expr"],properties:{bindTo:{type:"string",description:"Key in computed_values to write result"},expr:{type:"string",description:"JSONata expression evaluated against { card_data, requires, fetched_sources, computed_values }"}}},source_def:{description:"One source entry. The engine requires 'bindTo' (compute namespace key) and 'outputFile' (delivery signal path). bindTo and outputFile must be unique across all source_defs in a card. Every other property is yours \u2014 add whatever your task-executor needs: kind, url, headers, mailbox, channel, model, query, etc. The full object is passed verbatim as the --in JSON to the executor.",type:"object",required:["bindTo","outputFile"],additionalProperties:true,properties:{bindTo:{type:"string",description:"Key under fetched_sources.* available in compute expressions"},outputFile:{type:"string",description:"Board-relative path the executor writes its JSON result to. Presence of this file signals delivery."},projections:{type:"object",description:"Named data projections from card_data or requires, evaluated before the executor is called. Each key is a ref name; each value is a JSONata expression rooted at card_data or requires. The resolved values are passed to the executor as _projections. fetched_sources, computed_values, and source_defs are not accessible here \u2014 sources run before those exist.",additionalProperties:{type:"string"}},optionalForCompletionGating:{type:"boolean",default:false,description:"When true this source does not gate card completion. Default false when absent, so source_defs are completion-gating by default."},timeout:{type:"integer",minimum:0,default:12e4,description:"Executor/script timeout in ms. Default: 120 000 (2 min)."},script:{type:"string",description:"Legacy direct-run: shell command executed when no .task-executor is registered. stdout is captured as the result."}}},render_element:{type:"object",required:["kind"],properties:{id:{type:"string",description:"Optional element ID for targeted updates"},kind:{enum:["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]},label:{type:"string",description:"Heading above this element"},className:{type:"string",description:"Bootstrap grid class, e.g. 'col-12 col-md-6'"},visible:{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 element shown only if truthy"},data:{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref",description:"card_data/requires/fetched_sources/computed_values path to read data from"},writeTo:{$ref:"#/definitions/bind_ref",description:"card_data path for user input (form, filter, todo, notes)"},columns:{type:"array",items:{type:"string"},description:"table: visible columns"},maxRows:{type:"integer",description:"table/list: max rows to display"},sortable:{type:"boolean",default:true,description:"table: enable click-to-sort"},placeholder:{type:"string",description:"Empty-state message"},chartType:{enum:["bar","line","pie","doughnut"]},chartOptions:{type:"object",description:"Chart.js options passthrough"},fields:{type:"object",description:"JSON Schema for form/filter fields"},thresholds:{type:"object",properties:{green:{type:"string"},amber:{type:"string"}}},colorMap:{type:"object",description:"badge: value \u2192 Bootstrap color"},style:{enum:["heading","muted","default"],description:"text: display style"},upload:{type:"boolean",default:true,description:"file-upload: show drop zone (false = read-only file list)"},accept:{type:"array",items:{type:"string"},description:"file-upload: allowed extensions"},multiple:{type:"boolean",default:true,description:"file-upload: allow multiple files"},fileAttach:{type:"boolean",default:false,description:"chat: enable inline file attachments"},fileAccept:{type:"array",items:{type:"string"},description:"chat: allowed attachment extensions"},buttons:{type:"array",description:"actions: button definitions",items:{type:"object",required:["id","label"],properties:{id:{type:"string"},label:{type:"string"},style:{type:"string",description:"Bootstrap button variant, e.g. 'success', 'outline-danger'"},size:{type:"string",default:"sm"},disabled:{oneOf:[{type:"boolean"},{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 truthy = disabled"}]}}}}}}}},view:{type:"object",required:["elements"],properties:{elements:{type:"array",minItems:1,items:{$ref:"#/definitions/render_element"}},layout:{type:"object",properties:{board:{type:"object",properties:{col:{type:"integer",minimum:1,maximum:12},order:{type:"integer"}}},canvas:{type:"object",properties:{x:{type:"number"},y:{type:"number"},w:{type:"number"},h:{type:"number"}}}}},features:{type:"object",properties:{chat:{type:"boolean",default:false},notes:{type:"boolean",default:false},refresh:{type:"boolean",default:true}}}}}},title:"LiveCard",description:"A unified card node. Behavior depends on which sections are present (source_defs, compute, view, etc.)",type:"object",required:["id"],additionalProperties:false,properties:{id:{type:"string"},requires:{$ref:"#/definitions/requires"},provides:{$ref:"#/definitions/provides"},meta:{$ref:"#/definitions/meta"},__private:{$ref:"#/definitions/__private"},view:{$ref:"#/definitions/view"},card_data:{type:"object",description:"Authored card data and runtime metadata. Includes uploaded-file metadata maintained by host handlers and inference evaluation results.",properties:{files:{type:"array",description:"Optional uploaded-file metadata maintained by host handlers. Stored name is normalized and serial-prefixed (for example 001-my_file.pdf).",items:{type:"object",required:["name","stored_name"],properties:{name:{type:"string",minLength:1},stored_name:{type:"string",minLength:5,maxLength:32,pattern:"^[0-9]{3,}-[a-z0-9._-]+$"},size:{oneOf:[{type:"integer",minimum:0},{type:"null"}]},mime_type:{type:"string"},path:{type:"string",pattern:"^[^\\s]+/files/[0-9]{3,}-[a-z0-9._-]+$"},uploaded_at:{type:"string",format:"date-time"},chat:{type:"boolean",description:"Whether this file entry is associated with a chat interaction"}},additionalProperties:false}}},additionalProperties:true},source_defs:{type:"array",description:"Source entries. Each entry is passed verbatim to the board's .task-executor (registered via init --task-executor) as the --in JSON file. The executor fetches/generates the data and writes JSON to --out. If no executor is registered, the built-in executor runs the entry's 'cli' command directly. Sources gate completion by default. Set optionalForCompletionGating: true for enrichment-only source_defs that should not block task-completed.",items:{$ref:"#/definitions/source_def"}},compute:{type:"array",description:"Ordered array of compute steps. Each reads card_data.*/requires.*/fetched_sources.*/computed_values.* and writes to ephemeral computed_values[bindTo].",items:{$ref:"#/definitions/compute_step"}}}};var _=b$1(q$1(),1);var k=createRequire(import.meta.url),q=k("./jsonata-sync.cjs"),f=null;var b=/\b(card_data|requires|fetched_sources|computed_values|source_defs)\b/g,N=/^\s*(card_data|requires|fetched_sources|computed_values|source_defs)(\.|$)/;function S(e){let t=new Set,o;for(b.lastIndex=0;(o=b.exec(e))!==null;)t.add(o[1]);return t}function v(e){let t=N.exec(e);return t?t[1]:null}function g(e,t,o,n){try{q(e);}catch(s){let d=s instanceof Error?s.message:String(s);n.push(`${t}: invalid JSONata expression (${d})`);return}let i=S(e);for(let s of i)o.has(s)||n.push(`${t}: disallowed namespace "${s}" in expression`);}function y(e,t,o){if(Array.isArray(e)){e.forEach((i,s)=>{y(i,`${t}/${s}`,o);});return}if(typeof e=="string"){let i=v(e);if(!i)return;new Set(["card_data","requires","computed_values"]).has(i)||o.push(`${t}: disallowed namespace "${i}" in view reference`);return}if(!e||typeof e!="object")return;let n=e;for(let[i,s]of Object.entries(n))y(s,`${t}/${i}`,o);}function E(){if(f)return f;let e=new _.default({allErrors:true});return A(e),f=e.compile(h),f}function R(e){let t=E(),o=t(e),n=(t.errors??[]).map(i=>`${i.instancePath||"/"}: ${i.message??"unknown error"}`);if(e&&typeof e=="object"&&!Array.isArray(e)){let i=e.source_defs;if(Array.isArray(i)){let s=new Set,d=new Set;i.forEach((p,u)=>{if(!p||typeof p!="object"||Array.isArray(p))return;let r=p;typeof r.bindTo=="string"&&r.bindTo&&(s.has(r.bindTo)&&n.push(`/source_defs/${u}/bindTo: bindTo "${r.bindTo}" must be unique across all source_defs`),s.add(r.bindTo)),typeof r.outputFile=="string"&&r.outputFile&&(d.has(r.outputFile)&&n.push(`/source_defs/${u}/outputFile: outputFile "${r.outputFile}" must be unique across all source_defs`),d.add(r.outputFile));});}}return !o||n.length>0?{ok:false,errors:n}:{ok:true,errors:[]}}function T(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:true,errors:[]};let o=e,n=o.compute;Array.isArray(n)&&n.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.expr;typeof a!="string"||a.trim().length===0||g(a,`/compute/${c}/expr`,new Set(["card_data","requires","fetched_sources","computed_values"]),t);});let i=new Set(["card_data","requires","fetched_sources","computed_values"]),s=o.provides;Array.isArray(s)&&s.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.ref;if(typeof a!="string"||a.trim().length===0)return;let l=v(a);l===null?t.push(`/provides/${c}/ref: path "${a}" must start with a valid namespace (${[...i].join(", ")})`):i.has(l)||t.push(`/provides/${c}/ref: disallowed namespace "${l}" in path "${a}" (valid: ${[...i].join(", ")})`);});let d=o.view;d&&typeof d=="object"&&!Array.isArray(d)&&y(d,"/view",t);let p=new Set(["card_data","requires"]),u=o.source_defs;return Array.isArray(u)&&u.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.projections;if(!(!a||typeof a!="object"||Array.isArray(a)))for(let[l,m]of Object.entries(a))typeof m!="string"||m.trim().length===0||g(m,`/source_defs/${c}/projections/${l}`,p,t);}),{ok:t.length===0,errors:t}}function V(e){return O(e)}function O(e){let t=R(e);if(!t.ok)return t;let o=T(e);return o.ok?{ok:true,errors:[]}:{ok:false,errors:o.errors}}
2
+ export{R as a,T as b,V as c,O as d};//# sourceMappingURL=chunk-3KC6LBOG.js.map
3
+ //# sourceMappingURL=chunk-3KC6LBOG.js.map
@@ -1,3 +1,3 @@
1
- var s="b64:";function a(e){let n=new TextEncoder().encode(e),r=globalThis.Buffer,t;if(r)t=r.from(n).toString("base64");else if(typeof btoa=="function"){let o="";for(let i of n)o+=String.fromCharCode(i);t=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return t.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function g(e){let n=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),r=globalThis.Buffer;if(r)return r.from(n,"base64").toString("utf8");if(typeof atob=="function"){let t=atob(n),o=new Uint8Array(t.length);for(let i=0;i<t.length;i+=1)o[i]=t.charCodeAt(i);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function l(e){return `${s}${a(JSON.stringify(e))}`}function u(e){if(!e.startsWith(s))throw new Error(`Invalid ref format (expected ${s}<base64url(json)>): ${e}`);let n;try{n=JSON.parse(g(e.slice(s.length)));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!n||typeof n!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let r=n;if(typeof r.kind!="string"||typeof r.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:r.kind,value:r.value}}async function f(e,n,r){let t=e.tryAcquire();if(!t)return false;try{await n();}finally{t();}return r?.(),true}
2
- export{l as a,u as b,f as c};//# sourceMappingURL=chunk-BQS3EIEK.js.map
3
- //# sourceMappingURL=chunk-BQS3EIEK.js.map
1
+ var s="b64:";function a(e){let n=new TextEncoder().encode(e),r=globalThis.Buffer,t;if(r)t=r.from(n).toString("base64");else if(typeof btoa=="function"){let o="";for(let i of n)o+=String.fromCharCode(i);t=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return t.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function g(e){let n=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),r=globalThis.Buffer;if(r)return r.from(n,"base64").toString("utf8");if(typeof atob=="function"){let t=atob(n),o=new Uint8Array(t.length);for(let i=0;i<t.length;i+=1)o[i]=t.charCodeAt(i);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function u(e){return `${s}${a(JSON.stringify(e))}`}function l(e){if(!e.startsWith(s))throw new Error(`Invalid ref format (expected ${s}<base64url(json)>): ${e}`);let n;try{n=JSON.parse(g(e.slice(s.length)));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!n||typeof n!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let r=n;if(typeof r.kind!="string"||typeof r.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:r.kind,value:r.value}}async function d(e,n,r){let t=e.tryAcquire();if(!t)return false;try{await n();}finally{t();}return r?.(),true}
2
+ export{u as a,l as b,d as c};//# sourceMappingURL=chunk-44L64VQ2.js.map
3
+ //# sourceMappingURL=chunk-44L64VQ2.js.map
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-FOFGEABN.js';import {a as a$2,b}from'./chunk-RKKSVOP2.js';import {a as a$1}from'./chunk-NNSBBO5R.js';function l(e,r){return r?{...e,...r.pollIntervalMs!=null?{pollIntervalMs:r.pollIntervalMs}:{},...r.visibilityMs!=null?{visibilityMs:r.visibilityMs}:{},...r.concurrency!=null?{concurrency:r.concurrency}:{},...r.maxAttempts!=null?{maxAttempts:r.maxAttempts}:{}}:e}function f(e,r,u,s){return {id:e,async lease(o){return (await Promise.resolve(r.leaseRequests(o))).map(t=>({id:t.messageId,attempt:t.attempt,message:t.request,ack:()=>Promise.resolve(r.ackRequest(t.messageId,t.leaseToken)),nack:a=>Promise.resolve(r.nackRequest(t.messageId,t.leaseToken,a))}))},async handle(o){await u(o.args,o);},onError:s?(o,i)=>s(o,i.attempt,i.message):void 0}}function R(e,r,u,s){return {id:e,async lease(o){return (await Promise.resolve(r.lease(o))).map(t=>({id:t.id,attempt:t.attempt,message:t.body,ack:()=>Promise.resolve(r.ack(t.id,t.leaseToken)),nack:a=>Promise.resolve(r.nack(t.id,t.leaseToken,a))}))},async handle(){await u();},onError:s?(o,i)=>s(o,i.attempt):void 0}}function Q(e){let r=e.logger??{info(){},warn(){},error(){}},u=e.boardAdapter,s=e.runtime.queueLaneTuning??{},o=u.queueStorageForRef(e.queueStoreRef,"process-accumulated"),i=a(u)?a$1(u.queueStorageForRef(e.queueStoreRef,"chat-agent")):a$2(u.queueStorageForRef(e.queueStoreRef,"chat-agent")),t=[];if(t.push(l(R("process-accumulated",o,async()=>{let a=await e.runtime.__drainProcessAccumulatedLane();if(a.status!=="success")throw new Error(a.error||`__drainProcessAccumulatedLane returned ${a.status}`)},(a,n)=>{r.error(`[board-server] queued process-accumulated failed for ${e.boardId} (attempt ${n}): ${String(a&&a.message||a)}`);}),s.processAccumulated)),t.push(l(f("chat-agent",i,async(a,n)=>{await e.runtime.handleChatAgentRequest(n);},(a,n,c)=>{let p=typeof c.args?.cardId=="string"?c.args.cardId:"";r.error(`[board-server] queued chat-agent failed for ${e.boardId}${p?`/${p}`:""} (attempt ${n}): ${String(a&&a.message||a)}`);}),s.chatAgent)),e.executeTaskExecutorRequest){let a$3=a(u)?a$1(u.queueStorageForRef(e.queueStoreRef,"task-executor")):a$2(u.queueStorageForRef(e.queueStoreRef,"task-executor"));t.push(l(f("task-executor",a$3,e.executeTaskExecutorRequest,(n,c)=>{r.error(`[board-server] queued board-worker failed for ${e.boardId} (attempt ${c}): ${String(n&&n.message||n)}`);}),s.taskExecutor));}return b(t)}export{Q as a};//# sourceMappingURL=chunk-6OPXQPSC.js.map
2
+ //# sourceMappingURL=chunk-6OPXQPSC.js.map
@@ -0,0 +1,2 @@
1
+ function w(e){if(!e||typeof e!="object")return;let n=e;if(typeof n.statusCode=="number")return n.statusCode;if(typeof n.code=="number")return n.code}function l(e,n){return w(e)===n}function p(e,n,r){return n?typeof n=="function"?n(e):n:r}function A(e){return (e?.()??new Date).toISOString()}function L(e,n){if(n)return n();let r=String((e?.()??new Date).getTime()).padStart(13,"0"),o=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${r}-${o}`}function f(e){return {id:e.id,payload:e.payload}}function B(e,n={}){return {async read(r){let o=p(r,n.partitionKey,"kv");try{return (await e.item(r,o).read()).resource?.value??null}catch(t){if(l(t,404))return null;throw t}},async write(r,o){let t=p(r,n.partitionKey,"kv");await e.items.upsert({id:r,pk:t,kind:"kv",value:o});},async delete(r){let o=p(r,n.partitionKey,"kv");try{await e.item(r,o).delete();}catch(t){if(!l(t,404))throw t}},async listKeys(r=""){let{resources:o}=await e.items.query({query:"SELECT c.id FROM c WHERE c.kind = @kind AND STARTSWITH(c.id, @prefix)",parameters:[{name:"@kind",value:"kv"},{name:"@prefix",value:r}]}).fetchAll();return o.map(t=>t.id).sort()}}}function M(e,n,r={}){let o=p(n,r.partitionKey,`journal:${n}`);return {async append(t){let a={id:L(r.now,r.idFactory),pk:o,kind:"journal",streamKey:n,createdAt:A(r.now),payload:t};return await e.items.create(a),f(a)},async readAll(){let{resources:t}=await e.items.query({query:"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:o},{name:"@streamKey",value:n}]}).fetchAll();return t.sort((a,s)=>a.id.localeCompare(s.id)).map(f)},async readAfter(t){let{resources:a}=await e.items.query({query:t?"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey AND c.id > @cursor ORDER BY c.id":"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:o},{name:"@streamKey",value:n},...t?[{name:"@cursor",value:t}]:[]]}).fetchAll(),s=a.sort((u,d)=>u.id.localeCompare(d.id));return {entries:s.map(f),newCursor:s.length>0?s[s.length-1].id:t}},async clear(){let t=await this.readAll();await Promise.all(t.map(a=>e.item(a.id,o).delete()));}}}function P(e,n,r={}){let o=r.partitionKey??"lock",t=r.holderId??`holder-${Math.random().toString(36).slice(2,10)}`,a=r.now,s=r.ttlMs??3e4;function u(){let i=a?.()??new Date;return {id:n,pk:o,kind:"lock",held:true,holderId:t,expiresAt:new Date(i.getTime()+s).toISOString(),updatedAt:i.toISOString()}}function d(i){return {...i??{id:n,pk:o,kind:"lock"},kind:"lock",held:false,holderId:t,expiresAt:null,updatedAt:A(a)}}async function g(){try{return (await e.item(n,o).read()).resource??null}catch(i){if(l(i,404))return null;throw i}}function S(i){return i?.held?i.expiresAt?Date.parse(i.expiresAt)>(a?.()??new Date).getTime():true:false}return {async tryAcquire(){let i=await g(),b=u();if(i){if(S(i))return null;try{await e.item(n,o).replace(b,i._etag?{accessCondition:{type:"IfMatch",condition:i._etag}}:void 0);}catch(c){if(l(c,412)||l(c,409))return null;throw c}}else try{await e.items.create(b);}catch(c){if(l(c,409))return null;throw c}return async()=>{let c=await g();if(!c)return;let T=d(c);try{await e.item(n,o).replace(T,c._etag?{accessCondition:{type:"IfMatch",condition:c._etag}}:void 0);}catch{}}}}}function x(e){return new TextDecoder().decode(e)}function h(e,n={}){return {async read(r){if(!await e.getBlobClient(r).exists())return null;let o=await e.getBlobClient(r).downloadToBuffer();return x(o)},async write(r,o){await e.getBlockBlobClient(r).upload(o,new TextEncoder().encode(o).byteLength,{blobHTTPHeaders:{blobContentType:n.defaultContentType??"application/json; charset=utf-8"}});},exists(r){return e.getBlobClient(r).exists()},async remove(r){await e.getBlobClient(r).deleteIfExists();},async readBytes(r){return await e.getBlobClient(r).exists()?await e.getBlobClient(r).downloadToBuffer():null},async writeBytes(r,o){await e.getBlockBlobClient(r).upload(o,o.byteLength,{blobHTTPHeaders:{blobContentType:n.defaultContentType??"application/octet-stream"}});},async listKeys(r=""){let o=[];for await(let t of e.listBlobsFlat({prefix:r}))o.push(t.name);return o.sort()},async stat(r){if(!await e.getBlobClient(r).exists())return null;let o=await e.getBlobClient(r).getProperties();return {key:r,size:Number(o.contentLength??0),updatedAt:o.lastModified?.toISOString(),contentType:o.contentType}},keyRef(r){return n.keyRef?.(r)??{kind:"azure-blob-key",value:r}},async renameKey(r,o){let t=e.getBlobClient(r);if(!await t.exists())return false;let[a,s]=await Promise.all([t.downloadToBuffer(),t.getProperties()]);return await e.getBlockBlobClient(o).upload(a,a.byteLength,{blobHTTPHeaders:{blobContentType:s.contentType??n.defaultContentType??"application/octet-stream"}}),await t.deleteIfExists(),true}}}function C(e){if(!e||typeof e!="object")return;let n=e;if(typeof n.statusCode=="number")return n.statusCode;if(typeof n.code=="number")return n.code}function y(e){let n=JSON.stringify(e),r=globalThis.Buffer;if(r)return r.from(n,"utf-8").toString("base64");if(typeof btoa=="function")return btoa(n);throw new Error("No base64 encoder available in this runtime")}function k(e){let n=e??"",r=globalThis.Buffer;if(r)return JSON.parse(r.from(n,"base64").toString("utf-8"));if(typeof atob=="function")return JSON.parse(atob(n));throw new Error("No base64 decoder available in this runtime")}function m(e,n){return (e??n()).toISOString()}function D(e,n){return {id:String(e.messageId??""),body:k(e.messageText),enqueuedAt:m(e.insertedOn??e.insertionTime,n),attempt:Number(e.dequeueCount??0)}}function v(e,n){return {id:String(e.messageId??""),body:k(e.messageText),enqueuedAt:m(e.insertedOn??e.insertionTime,n),attempt:Number(e.dequeueCount??0),leaseToken:String(e.popReceipt??""),leaseExpiresAt:m(e.nextVisibleOn,n)}}function R(e,n={}){let r=n.now??(()=>new Date),o=new Map;return {async enqueue(t){let a=await e.sendMessage(y(t));return {id:String(a.messageId??""),body:t,enqueuedAt:m(a.insertionTime,r),attempt:0}},async enqueueMany(t){let a=[];for(let s of t)a.push(await this.enqueue(s));return a},async stage(t,a){let s=a?.dedupKey;if(s){for(let g of o.values())if(g.dedupKey===s)return null}let u=`staged:${crypto.randomUUID?.()??Math.random().toString(36).slice(2,10)}`,d={body:t,enqueuedAt:r().toISOString(),attempt:0,...s?{dedupKey:s}:{}};return o.set(u,d),{id:u,body:t,enqueuedAt:d.enqueuedAt,attempt:0}},async commitStaged(t){let a=o.get(t);return a?(o.delete(t),await e.sendMessage(y(a.body)),true):false},async discardStaged(t){return o.has(t)?(o.delete(t),true):false},async peekStaged(t=""){return Array.from(o.entries()).filter(([a])=>!t||a.startsWith(t)).map(([a,s])=>({id:a,body:s.body,enqueuedAt:s.enqueuedAt,attempt:s.attempt}))},async lease(t){return (await e.receiveMessages({numberOfMessages:t?.max,visibilityTimeout:t?.visibilityMs?Math.max(1,Math.ceil(t.visibilityMs/1e3)):void 0})).receivedMessageItems.map(s=>v(s,r))},async ack(t,a){try{return await e.deleteMessage(t,a),!0}catch(s){if(C(s)===404)return false;throw s}},async nack(t,a,s){try{if(s?.dead){if(!n.deadLetterQueueClient)return !1;let u={messageId:t,reason:s.reason??null};return await n.deadLetterQueueClient.sendMessage(y(u)),await e.deleteMessage(t,a),!0}return await e.updateMessage(t,a,y({requeued:!0}),0),!0}catch(u){if(C(u)===404)return false;throw u}},async peekActive(t=""){return (await e.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>D(s,r)).filter(s=>!t||s.id.startsWith(t))},async peekDeadLetter(t=""){return n.deadLetterQueueClient?(await n.deadLetterQueueClient.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>{let u=k(s.messageText);return {id:String(s.messageId??""),body:u,enqueuedAt:m(s.insertedOn??s.insertionTime,r),attempt:Number(s.dequeueCount??0),reason:typeof u.reason=="string"?u.reason:void 0}}).filter(s=>!t||s.id.startsWith(t)):[]}}}export{B as a,M as b,P as c,h as d,R as e};//# sourceMappingURL=chunk-7BTZCOT5.js.map
2
+ //# sourceMappingURL=chunk-7BTZCOT5.js.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkSFVO2LB2_cjs=require('./chunk-SFVO2LB2.cjs');function i(e,t){let n;return /\.m?js$/i.test(e)?n="local-node":/\.py$/i.test(e)?n="local-python":n="local-process",{meta:"task-executor",howToRun:n,whatToRun:chunkSFVO2LB2_cjs.a({kind:"fs-path",value:e}),...t?{extra:t}:{}}}function s(e){return JSON.stringify(e)}function a(e){let t;try{t=JSON.parse(e);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${e}`)}if(typeof t!="object"||t===null||typeof t.howToRun!="string"||typeof t.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${e}`);return t}exports.a=i;exports.b=s;exports.c=a;//# sourceMappingURL=chunk-U2N6MCD5.cjs.map
2
- //# sourceMappingURL=chunk-U2N6MCD5.cjs.map
1
+ 'use strict';var chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs');function i(e,t){let n;return /\.m?js$/i.test(e)?n="local-node":/\.py$/i.test(e)?n="local-python":n="local-process",{meta:"task-executor",howToRun:n,whatToRun:chunkVQCIOKJV_cjs.a({kind:"fs-path",value:e}),...t?{extra:t}:{}}}function s(e){return JSON.stringify(e)}function a(e){let t;try{t=JSON.parse(e);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${e}`)}if(typeof t!="object"||t===null||typeof t.howToRun!="string"||typeof t.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${e}`);return t}exports.a=i;exports.b=s;exports.c=a;//# sourceMappingURL=chunk-7JVHYHT2.cjs.map
2
+ //# sourceMappingURL=chunk-7JVHYHT2.cjs.map
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunkIXZG74EW_cjs=require('./chunk-IXZG74EW.cjs');function v(s,i){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function H(s,i){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${i} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function a(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function b(s){return Array.isArray(s)?s:[]}function z(s,i){if(typeof i!="string"||i.length===0)return;let c=s,u=i;u.startsWith("fetched_sources.")&&(c=a(s).fetched_sources,u=u.slice(16));for(let f of u.split(".")){if(c==null||typeof c!="object")return;c=c[f];}return c}function V(s,i){let c=a(s.view),u=b(c.elements);return {layout:c.layout,features:c.features,elements:u.map((f,_)=>{let I=a(f),k=a(I.data),R=typeof I.visible=="string"?!!z(i,I.visible):true,M=typeof k.bind=="string"?k.bind:void 0,P=typeof k.maxRows=="number"?k.maxRows:void 0,B=M?z(i,M):void 0,F={id:typeof I.id=="string"&&I.id?I.id:`element-${_}`,kind:I.kind,label:I.label,visible:R};return B!==void 0&&(F.resolved=Array.isArray(B)&&typeof P=="number"?B.slice(0,P):B),F})}}function G(s,i){let c=typeof s.id=="string"&&s.id?s.id:"card",u=b(s.provides),f=u.length>0?u:[{bindTo:c,ref:"card_data"}],_={};for(let I of f){let k=a(I),R=typeof k.bindTo=="string"?k.bindTo:"",M=typeof k.ref=="string"?k.ref:"";if(!R||!M)continue;let P=z(i,M);P!==void 0&&(_[R]=P);}return _}function he(s){if(typeof s!="string"||!s.trim())return null;let i=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!i)return null;let c=Number.parseInt(i[2],10);return !Number.isInteger(c)||c<0?null:c}function ke(s){return {"card-content":s}}function E(s){let i={...s};return delete i.__private,i}function D(s,i){return Object.prototype.hasOwnProperty.call(s,i)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,i){let c=Re(s);if(!i||Object.keys(i).length===0)return c;function u(f,_,I){let k=String(_||"").split(".").filter(Boolean);if(!k.length)return;let R=f;for(let M=0;M<k.length-1;M+=1){let P=k[M];(!R[P]||typeof R[P]!="object")&&(R[P]={}),R=R[P];}R[k[k.length-1]]=I;}if(i.fieldValues!==void 0&&i.fieldValues!==null){let f=null,_=a(c.view),I=b(_.elements);for(let k of I){let R=a(a(k).data);if(typeof R.writeTo=="string"&&R.writeTo){f=R.writeTo;break}}return f?u(c,f,i.fieldValues):typeof i.fieldValues=="object"&&!Array.isArray(i.fieldValues)&&(c.card_data={...a(c.card_data),...i.fieldValues}),c}if(Array.isArray(i._stagedFiles)&&i._stagedFiles.length>0)return c;for(let[f,_]of Object.entries(i))f!=="_stagedFiles"&&(_!==null&&typeof _=="object"&&!Array.isArray(_)&&c[f]!==null&&typeof c[f]=="object"&&!Array.isArray(c[f])?c[f]={...c[f],..._}:c[f]=_);return c}function Q(s){return a(s.__private).visible_controlplane_only===true}async function T(s,i){let c=await U(s.get({params:{id:i}}),"cardStore.get"),u=Array.isArray(c?.cards)?c.cards:[];if(u.length===0)throw new Error(`Card "${i}" not found`);return u[0]}function Ae(s){let{board:i,nonCore:c,cardStore:u,chatStore:f,processAccumulated:_,sourceFetchDone:I,sourceFetchFailed:k,uploadCardFile:R,buildFileDownloadUrl:M,readFetchedSourceJsonByRef:P}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function F(){let e=await U(u.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>a(r)):[]}function X(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),n=atob(t);return Uint8Array.from(n,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=a(await U(c.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:a(e.commonSourceDefFields),sourceKinds:a(e.sourceKinds)}}async function Z(){let e=a(await U(i.status({}),"status")),r=a(e.summary),t=b(e.cards);return {meta:a(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:t.map(n=>{let o=a(n);return {"card-id":typeof o.name=="string"?o.name:null,status:o.status??null,error:o.error??null,requires:b(o.requires),requires_satisfied:b(o.requires_satisfied),requires_missing:b(o.requires_missing),provides_declared:b(o.provides_declared),provides_runtime:b(o.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=a(await U(i.status({}),"status")),o=b(t.cards).map(a).find(p=>p.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let d=a(await T(u,r));if(Q(d))throw Object.assign(new Error(`card "${r}" not found`),{statusCode:404});let m=E(d),g=b(o.requires_satisfied).filter(p=>typeof p=="string"&&!!p),w=b(o.provides_runtime).filter(p=>typeof p=="string"&&!!p),h=Object.fromEntries(await Promise.all(g.map(async p=>[p,await U(i.getOutputsDataObject({params:{key:p}}),`getOutputsDataObject(${p})`)]))),A=Object.fromEntries(await Promise.all(w.map(async p=>[p,await U(i.getOutputsDataObject({params:{key:p}}),`getOutputsDataObject(${p})`)]))),C=a(await U(i.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),l=await U(i.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),S=b(d.source_defs).map(a),y={};for(let p of S)typeof p.bindTo=="string"&&typeof p.outputFile=="string"&&(y[p.outputFile]=p.bindTo);let x={};for(let[p,O]of Object.entries(l)){let q=y[p]??p;if(!P||typeof O!="string"){x[q]=null;continue}try{x[q]=P({cardId:r,ref:O});}catch{x[q]=null;}}let L={card_data:a(d.card_data),requires:h,fetched_sources:x,computed_values:C};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:m,refs_for_fetched_source_files:l,runtime_data:{requires:h,provides:A,computed_values:C,rendered_view:V(d,L)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",n=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",d=n?void 0:e.lastUserTurns??(t?void 0:1),m=e.tail,g={...d===void 0?{}:{tailTurns:d},...t?{turnId:t}:{},...n?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},w=Object.keys(g).length>0?{params:{cardId:r},body:g}:{params:{cardId:r}},h=v(await f.readAll(w),"chatStore.readAll"),A=a(await T(u,r)),C=b(a(A.card_data).files).map((y,x)=>({idx:x,stored_name:a(y).stored_name})).filter(y=>typeof y.stored_name=="string"&&y.stored_name.length>0),S=(Array.isArray(h.records)?h.records:[]).map(y=>{let L=a(y.payload),p={...y},O=typeof y?.role=="string"?y.role:typeof L.role=="string"?String(L.role):"",q=typeof y?.text=="string"?y.text:typeof L.text=="string"?String(L.text):"";if(O==="system"){let N=he(q);if(N!==null&&C.some(j=>j.idx===N)){let j=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${N}`;p.retrieval_hint=j,Object.keys(L).length>0&&typeof y.role!="string"&&(p.payload={...L,retrieval_hint:j});}}return p});return {cardId:r,messages:typeof m=="number"&&m>=0?S.slice(-m):S}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let n=a(await T(u,r)),o=b(a(n.card_data).files).map(a);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let d=o[t],m=typeof d.stored_name=="string"?d.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:M({cardId:r,fileIdx:t,storedName:m}),...typeof d.name=="string"?{name:d.name}:{},...typeof d.stored_name=="string"?{stored_name:d.stored_name}:{},...typeof d.mime_type=="string"?{mime_type:d.mime_type}:{},...typeof d.size=="number"?{size:d.size}:{},...typeof d.uploaded_at=="string"?{uploaded_at:d.uploaded_at}:{}}}async function $(e){return await c.validateCardPreflight({body:ke(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=c.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=a(H(r,"evalCardCompute")),n=a(e.candidateCardContent),o={card_data:a(n.card_data),requires:a(e.mockRequires),fetched_sources:a(e.mockFetchedSources),computed_values:a(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof n.id=="string"?n.id:"(unknown)",ok:t.ok===true,computed_values:a(t.computed_values),errors:b(t.errors).map(d=>{let m=a(d);return {bindTo:typeof m.bindTo=="string"?m.bindTo:"",error:typeof m.error=="string"?m.error:""}}),provides_outputs:G(n,o),rendered_view:V(n,o)}}}async function ae(e){return await c.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=a(await T(u,r)),n=b(t.source_defs).filter(d=>!!d&&typeof d=="object"&&!Array.isArray(d)),o={};if(e.sourceIdx>=0&&e.sourceIdx<n.length){let d=n[e.sourceIdx],m=chunkIXZG74EW_cjs.a.enrichSourcesSync([d],{card_data:a(t.card_data),requires:e.mockRequires});Array.isArray(m)&&m.length>0&&(o=a(m[0]._projections));}return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=a(await U(c.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=a(e.candidateCardContent),n=a(r.validation),o=b(r.source_probes),d=b(r.projection_errors),m=a(r.fetched_sources),g=b(r.compute_errors),w=a(r.computed_values),h={card_data:a(t.card_data),requires:e.mockRequires,fetched_sources:m,computed_values:w},A=[];for(let C of b(n.issues))typeof C=="string"&&C&&A.push(C);for(let C of o){let l=a(C),S=typeof l.bindTo=="string"?l.bindTo:"source",y=typeof l.error=="string"?l.error:"";y&&A.push(`${S}: ${y}`);}for(let C of d){let l=a(C),S=typeof l.bindTo=="string"?l.bindTo:"source",y=typeof l.key=="string"?l.key:"projection",x=typeof l.error=="string"?l.error:"projection failed";A.push(`${S}.${y}: ${x}`);}for(let C of g){let l=a(C),S=typeof l.bindTo=="string"?l.bindTo:"compute",y=typeof l.error=="string"?l.error:"compute failed";A.push(`${S}: ${y}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:A,provides_outputs:G(t,h),rendered_view:V(t,h)}}}async function K(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await U(u.get({params:{id:r}}),"cardStore.get"),n=Array.isArray(t.cards)?t.cards.map(a):[];if(n.some(Q))throw Object.assign(new Error(`Card "${r}" not found`),{statusCode:404});return n.map(o=>E(o))}async function W(e){let r=await Promise.all(b(e.files).map(async t=>{let n=a(t),o=String(n.file_name??n.fileName??n.name??"").trim(),d=String(n.content_type??n.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await R({cardId:e.cardId,fileName:o,contentType:d,bytes:X(n),suppressChatRecordWrite:true})}));for(let[t,n]of r.entries()){let o=a(n.file),d=typeof n.file_idx=="number"&&Number.isInteger(n.file_idx)&&n.file_idx>=0?n.file_idx:t,m=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`;v(await f.append({params:{cardId:e.cardId},body:{role:"system",text:m,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}return r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",n=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await W({cardId:r,role:t,turn:n,files:e.files});return {status:"success",data:{cardId:r,turn:n,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),n=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let g=v(await f.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),w=Array.isArray(g.records)?g.records.find(h=>h.role==="assistant"&&String(h.turn||"")===o):void 0;if(w)return {status:"success",data:{cardId:r,id:String(w.id),role:t,turn:o,files:Array.isArray(w.files)?w.files:[]}}}let d=await W({cardId:r,role:t,turn:o,files:e.files}),m=v(await f.append({params:{cardId:r},body:{role:t,text:n,files:d,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(m.id),role:t,turn:o,files:d}}}async function ue(e){let r=String(e.cardId||"").trim(),t=a(e.patch);if(!r)throw new Error("managePatchCard requires cardId");let n=await K({cardId:r}),o=a(n[0]),m={...ve(o,t),...D(o,"meta")?{meta:o.meta}:{},...D(o,"__private")?{__private:o.__private}:{}},g=await u.set({body:m});v(g,"cardStore.set");let w;try{w=await i.upsertCard({params:{cardId:r,restart:!0}}),v(w,"upsertCard");}catch(A){try{await u.set({body:o});}catch{}throw A}let h=null;try{h=await i.cardRefreshedNotify({params:{cardId:r}}),v(h,"cardRefreshedNotify");}catch{h=null;}return {status:"success",data:{validation:null,card_saved:null,board_result:w,refresh_notify:h}}}async function le(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("manageUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:n}),d=a(o),m=a(d.data);if(d.status!=="success"||m.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let w=g?a(g):null,h={...n,...w&&D(w,"meta")?{meta:w.meta}:{},...w&&D(w,"__private")?{__private:w.__private}:{}},A=await u.set({body:h});v(A,"cardStore.set");let C;try{C=await i.upsertCard({params:{cardId:r,restart:!0}}),v(C,"upsertCard");}catch(S){try{g&&await u.set({body:g});}catch{}throw S}let l=null;try{l=await i.cardRefreshedNotify({params:{cardId:r}}),v(l,"cardRefreshedNotify");}catch{l=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:C,refresh_notify:l}}}async function me(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageRemoveCard requires cardId");let t=await i.removeCard({params:{id:r}});v(t,"removeCard");let n=await u.del({params:{id:r}});return v(n,"cardStore.del"),{status:"success",data:{board_result:t,store_result:n}}}async function pe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await U(u.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(n=>a(n)):[]}async function fe(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:n}),d=a(o),m=a(d.data);if(d.status!=="success"||m.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let w=g?a(a(g).__private):{},h={...n,__private:{...w,visible_controlplane_only:true}},A=await u.set({body:h});v(A,"cardStore.set");let C;try{C=await i.upsertCard({params:{cardId:r,restart:!0}}),v(C,"upsertCard");}catch(S){try{g&&await u.set({body:g});}catch{}throw S}let l=null;try{l=await i.cardRefreshedNotify({params:{cardId:r}}),v(l,"cardRefreshedNotify");}catch{l=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:C,refresh_notify:l}}}async function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=H(await f.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}async function we(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return v(await f.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function Ce(){let e=await B(_,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let n=await B(I,"webhook.source-fetch-done")({token:r,ref:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}async function be(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let n=await B(k,"webhook.source-fetch-failed")({token:r,reason:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}return {listRuntimeCards:F,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:$,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:K,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:le,manageRemoveCard:me,adminReadCard:pe,adminUpsertCard:fe,getChatProcessing:ge,setChatProcessing:we,webhookProcessAccumulated:Ce,webhookSourceFetchDone:ye,webhookSourceFetchFailed:be}}async function U(s,i){return v(await s,i)}exports.a=Ae;//# sourceMappingURL=chunk-7QZ267XP.cjs.map
2
+ //# sourceMappingURL=chunk-7QZ267XP.cjs.map
@@ -1,2 +1,2 @@
1
- import {a as a$1}from'./chunk-BQS3EIEK.js';function i(e,t){let n;return /\.m?js$/i.test(e)?n="local-node":/\.py$/i.test(e)?n="local-python":n="local-process",{meta:"task-executor",howToRun:n,whatToRun:a$1({kind:"fs-path",value:e}),...t?{extra:t}:{}}}function s(e){return JSON.stringify(e)}function a(e){let t;try{t=JSON.parse(e);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${e}`)}if(typeof t!="object"||t===null||typeof t.howToRun!="string"||typeof t.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${e}`);return t}export{i as a,s as b,a as c};//# sourceMappingURL=chunk-XQRNDX4Q.js.map
2
- //# sourceMappingURL=chunk-XQRNDX4Q.js.map
1
+ import {a as a$1}from'./chunk-44L64VQ2.js';function i(e,t){let n;return /\.m?js$/i.test(e)?n="local-node":/\.py$/i.test(e)?n="local-python":n="local-process",{meta:"task-executor",howToRun:n,whatToRun:a$1({kind:"fs-path",value:e}),...t?{extra:t}:{}}}function s(e){return JSON.stringify(e)}function a(e){let t;try{t=JSON.parse(e);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${e}`)}if(typeof t!="object"||t===null||typeof t.howToRun!="string"||typeof t.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${e}`);return t}export{i as a,s as b,a as c};//# sourceMappingURL=chunk-ANKA7HEJ.js.map
2
+ //# sourceMappingURL=chunk-ANKA7HEJ.js.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkSFVO2LB2_cjs=require('./chunk-SFVO2LB2.cjs');function p(t){return typeof t.journalStorage=="function"}function s(t){return typeof t.whatToRun=="string"?t.whatToRun.startsWith("b64:")?chunkSFVO2LB2_cjs.b(t.whatToRun).value:t.whatToRun:t.whatToRun.value}function c(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function f(t){let a=t.reduce((r,u)=>r+u.length,0),o=new Uint8Array(a),n=0;for(let r of t)o.set(r,n),n+=r.length;return o}exports.a=p;exports.b=s;exports.c=c;exports.d=f;//# sourceMappingURL=chunk-KAWQPLIE.cjs.map
2
- //# sourceMappingURL=chunk-KAWQPLIE.cjs.map
1
+ 'use strict';var chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs');function p(t){return typeof t.journalStorage=="function"}function s(t){return typeof t.whatToRun=="string"?t.whatToRun.startsWith("b64:")?chunkVQCIOKJV_cjs.b(t.whatToRun).value:t.whatToRun:t.whatToRun.value}function c(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function f(t){let a=t.reduce((r,u)=>r+u.length,0),o=new Uint8Array(a),n=0;for(let r of t)o.set(r,n),n+=r.length;return o}exports.a=p;exports.b=s;exports.c=c;exports.d=f;//# sourceMappingURL=chunk-BQUQTOPB.cjs.map
2
+ //# sourceMappingURL=chunk-BQUQTOPB.cjs.map
@@ -0,0 +1,3 @@
1
+ 'use strict';var chunk37HDEW26_cjs=require('./chunk-37HDEW26.cjs'),chunkPBCDDO4V_cjs=require('./chunk-PBCDDO4V.cjs'),chunkNDAKMJQK_cjs=require('./chunk-NDAKMJQK.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkIXZG74EW_cjs=require('./chunk-IXZG74EW.cjs');async function Ye(r,a,u){let i=await r.tryAcquire();if(!i)return false;try{await a();}finally{await i();}return await u?.(),true}function Xe(r){return chunkPBCDDO4V_cjs.b(r)}function Ze(r,a){return {async readIndex(){return await r.read("_index")},writeIndex(u){return r.write("_index",u)},async readCard(u){return await r.read(u)},async writeCard(u,i){return await r.write(u,i),a(i)},removeCard(u){return r.delete(u)},async cardExists(u){return await r.read(u)!==null},defaultCardKey(u){return u}}}function et(r,a){async function u(){return await r.readIndex()??{}}return {async readCard(i){let p=(await u())[i];return !p||!await r.cardExists(p.key)?null:await r.readCard(p.key)},async readCardKey(i){return (await u())[i]?.key??null},async readAllCards(){let i=[];for(let[p,S]of Object.entries(await u())){if(!await r.cardExists(S.key))continue;let c=await r.readCard(S.key);c?i.push(c):a?.(`[card-store] could not read card "${p}" at key "${S.key}"`);}return i},async readChecksumIndex(){let i={};for(let[p,S]of Object.entries(await u()))i[p]=S.checksum;return i},async changedSince(i){let p=await u(),S=[];for(let[c,C]of Object.entries(p))i[c]!==C.checksum&&S.push(c);for(let c of Object.keys(i))p[c]||S.push(c);return S},async validateUpsert(i,p){let S=await u(),c=S[i],C=Object.entries(S).find(([,P])=>P.key===p);return c&&c.key!==p?{ok:false,error:`Card id "${i}" is already mapped to key "${c.key}", cannot remap to "${p}"`}:C&&C[0]!==i?{ok:false,error:`Key "${p}" is already mapped to card id "${C[0]}", cannot remap to "${i}"`}:{ok:true}},async writeCard(i,p,S){let c=await u(),C=S??c[i]?.key??r.defaultCardKey(i),P=await r.writeCard(C,p);c[i]={key:C,checksum:P,updatedAt:new Date().toISOString()},await r.writeIndex(c);},async patchCard(i,p,S){let c=await u(),C=c[i];if(!C||!await r.cardExists(C.key))throw new Error(`card "${i}" not found`);let P=await r.readCard(C.key);if(!P||typeof P!="object"||Array.isArray(P))throw new Error(`card "${i}" is not patchable`);let B=String(p||"").split(".").filter(Boolean),te=chunkPBCDDO4V_cjs.a(P,B,S),E=await r.writeCard(C.key,te);c[i]={key:C.key,checksum:E,updatedAt:new Date().toISOString()},await r.writeIndex(c);},async removeCard(i){let p=await u(),S=p[i];S&&(await r.removeCard(S.key),delete p[i],await r.writeIndex(p));},readIndex(){return u()}}}function Rt(r,a){return chunkNDAKMJQK_cjs.a(r,a)}function kt(r,a,u){return {blob:r,kv:a,journal:u}}function h(r){return r!==void 0?{status:"success",data:r}:{status:"success"}}function f(r){return {status:"fail",error:r}}function v(r){return {status:"error",error:r instanceof Error?r.message:String(r)}}function x(){return new Date().toISOString()}function ut(r){let a=new TextEncoder().encode(r),u=Array.from(a,i=>String.fromCharCode(i)).join("");return btoa(u).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function nt(r){let a=r.replace(/-/g,"+").replace(/_/g,"/"),u=a+"=".repeat((4-a.length%4)%4),i=atob(u),p=Uint8Array.from(i,S=>S.charCodeAt(0));return new TextDecoder().decode(p)}function ge(r){try{let a=JSON.parse(nt(r));return typeof a?.t=="string"?{taskName:a.t}:null}catch{return null}}function tt(r){return ut(JSON.stringify(r))}function rt(r){try{let a=JSON.parse(nt(r));return typeof a?.cbk=="string"&&typeof a?.cid=="string"&&typeof a?.b=="string"&&typeof a?.d=="string"?a:null}catch{return null}}function dt(r){return chunkNDAKMJQK_cjs.j(r,chunkNDAKMJQK_cjs.o,()=>({_sources:{}}))}function ct(r,a){return chunkNDAKMJQK_cjs.h(r,a)}function mt(r){return chunkNDAKMJQK_cjs.k(r)}function lt(r,a){return chunkNDAKMJQK_cjs.i(r,a)}function ft(r,a,u,i,p,S){return async c=>{let C=[],P=await u.cardStore.readCard(c.nodeId);if(!P)return "task-initiate-failure";let B=P.id,te=P.card_data??{},E=P.source_defs??[],re=E.filter(m=>m.optionalForCompletionGating!==true),b=await u.cardRuntimeStore.readRuntime(B),D=false,V=async()=>{D&&(await u.cardRuntimeStore.writeRuntime(B,b),D=false);},T=m=>chunkNDAKMJQK_cjs.p(b._sources[m]),K=(m,l)=>{b._sources[m]=chunkNDAKMJQK_cjs.p(l),D=true;},oe=c.taskState?.executionCount??0;if(b._lastExecutionCount!==oe&&(b._sources={},b._lastExecutionCount=oe,D=true),c.update){let m=c.update.outputFile;if(m){let l=T(m);if(c.update.failure){let R=c.update.rqt??l.lastRequestedToken??l.queueRequestedToken;R&&K(m,chunkNDAKMJQK_cjs.s(l,R));}else {let R=c.update.rqt;if(!l.lastCompletedToken||R>l.lastCompletedToken){let t=typeof c.update.deliveryToken=="string"?c.update.deliveryToken:void 0,e=t?await u.fetchedSourcesStore.commitSourceData(B,m,t):false;K(m,e?chunkNDAKMJQK_cjs.r(l,R):chunkNDAKMJQK_cjs.s(l,R));}}await V();}}let L={};for(let m of E){if(!m.outputFile)continue;let l=await u.fetchedSourcesStore.readSourceData(B,m.outputFile);l!==null&&(L[m.bindTo]=l);}let U={};for(let[m,l]of Object.entries(c.state??{}))if(l!==null&&typeof l=="object"&&!Array.isArray(l)){let R=l[m];U[m]=R!==void 0?R:l;}else U[m]=l;let J={id:B,card_data:{...te},requires:U,source_defs:E,compute:P.compute};J._sourcesData=L,P.compute&&chunkIXZG74EW_cjs.a.runSync(J,{sourcesData:L}),(p??(()=>{}))(B,J.computed_values??{});let ne=chunkIXZG74EW_cjs.a.enrichSourcesSync(Array.isArray(P.source_defs)?P.source_defs:void 0,{card_data:P.card_data,requires:U}),F={...P,source_defs:Array.isArray(ne)?ne.map(m=>({...m,boardDir:typeof m.boardDir=="string"&&m.boardDir?m.boardDir:r.value})):ne},M=x(),G=c.update?void 0:M,W=re.filter(m=>{let l=m.outputFile;if(typeof l!="string"||!l)return true;let R=T(l);G&&(R={...R,queueRequestedToken:G},K(l,R));let t=R.queueRequestedToken??R.lastRequestedToken??M;return chunkNDAKMJQK_cjs.q(R,t)==="dispatch"});if(await V(),W.length>0){let m=false,l=M;for(let R of W){let t=R.outputFile;if(typeof t!="string"||!t)continue;let e=T(t),s=e.queueRequestedToken??M;K(t,{...e,lastRequestedToken:s}),l=s,m=true;}return m&&await V(),m&&(C.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(r),enrichedCard:F,callbackToken:c.callbackToken,rqt:l}}),await u.executionRequestStore.appendEntries(a,C)),"task-initiated"}if(re.some(m=>{let l=m.outputFile;if(typeof l!="string"||!l)return false;let R=T(l),t=R.queueRequestedToken??R.lastRequestedToken??M;return chunkNDAKMJQK_cjs.q(R,t)==="in-flight"}))return "task-initiated";let ye=P.provides??[],ae={};for(let{bindTo:m,ref:l}of ye)ae[m]=chunkIXZG74EW_cjs.a.resolve(J,l);return (S??(()=>{}))(ae),E.filter(m=>{if(m.optionalForCompletionGating!==true)return false;let l=T(m.outputFile);return !l.lastRequestedToken||!l.lastCompletedToken?true:l.lastCompletedToken<=l.lastRequestedToken}).length>0&&C.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(r),enrichedCard:F,callbackToken:c.callbackToken,rqt:M}}),i(c.nodeId,ae),C.length>0&&await u.executionRequestStore.appendEntries(a,C),"task-initiated"}}function Et(r,a,u={}){chunkNDAKMJQK_cjs.d(a.callbackTransport,"createAsyncBoardLiveCardsPublic");let i=a.callbackTransport,p=a.warn??(()=>{}),S=chunkVQCIOKJV_cjs.a(r),c=null,C=u.boardRuntimeStoreRef,P=u.scratchStoreRef,B=u.taskExecutorRef,te=u.chatHandlerFlow;function E(){if(!C)throw new Error(`Board at ${r.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return C}function re(t){if(t.length!==0)try{return Promise.resolve(a.publishBoardChangeNotifications?.(t)).catch(e=>{p(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${e instanceof Error?e.message:String(e)}`);})}catch(e){p(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${e instanceof Error?e.message:String(e)}`);return}}let b=()=>chunk37HDEW26_cjs.b(a.kvStorageForRef(E())),D=r.value,V=()=>chunkNDAKMJQK_cjs.b(chunkNDAKMJQK_cjs.a(()=>a.kvStorageForRef(E()),a.hashFn),"v1"),T=async()=>{let t=await b().readOutputsStoreRef();if(!t)throw new Error(`Board at ${r.value} has no outputs store configured.`);return mt(a.kvStorageForRef(t))},K=async()=>{let t=await b().readCardStoreRef();if(!t)throw new Error(`Board at ${r.value} has no card store configured.`);let e=a.kvStorageForRef(t);return et(Ze(Xe(e),a.hashFn),p)};async function oe(){return !!(await V().readSnapshot(D)).values[chunkNDAKMJQK_cjs.n]}async function L(){let t=await V().readSnapshot(D);if(!t.values[chunkNDAKMJQK_cjs.n])throw new Error(`Board not initialized at ${r.value}`);return chunkNDAKMJQK_cjs.w(t.values)}async function U(t,e){let s=await V().commitSnapshot(D,{schemaVersion:"v1",expectedVersion:e,deleteKeys:[],shallowMerge:chunkNDAKMJQK_cjs.v(t)});if(!s.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${e??"null"} current=${s.currentVersion??"null"}`)}let J=()=>chunkNDAKMJQK_cjs.c(a.journalStorageForRef(E()));async function ne(){return B??await b().readTaskExecutorRef()}async function F(t){await J().appendEvent(t);}async function M(){let t=await b().readFetchedSourcesStoreRef();if(!t)throw new Error(`Board at ${r.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return t}async function G(){return a.blobStorageForRef(await M())}async function W(){return ct(await G(),t=>a.resolveBlob(t))}async function pe(t){let e=(await G()).keyRef?.(t);if(!e)throw new Error("configured fetched-sources store does not support keyRef");let s=await Promise.resolve(e);return chunkVQCIOKJV_cjs.a(s)}async function ye(){let t=lt(a.kvStorageForRef(E()),async(o,d)=>{let k=o.payload,I=(k.enrichedCard??{}).id??k.cardId??"unknown";await F({type:"task-failed",taskName:I,error:d,timestamp:x()});}),e=dt(a.kvStorageForRef(E())),s=await G(),n=await W(),y=await K(),w=await T(),A=new Map,g=new Map,z=[],Q=[],$=[],H=new Map,Y=new Set,Re={async readRuntime(o){return A.get(o)??await e.readRuntime(o)},async writeRuntime(o,d){A.set(o,d),Se[o]=d;}},at={async readSourceData(o,d){let k=`${o}/${d}`;return g.has(k)?g.get(k):await n.readSourceData(o,d)},ingestSourceDataStaged(o,d,k,O){return n.ingestSourceDataStaged(o,d,k,O)},async commitSourceData(o,d,k){let O=`${o}/.staged/${k}/${d}`,I=await s.read(O);if(I==null){let j=await Promise.resolve(s.keyRef?.(O));j&&(I=await a.resolveBlob(j));}if(I==null)return false;let _=`${o}/${d}`,Z=I.trim();try{g.set(_,JSON.parse(Z));}catch{g.set(_,Z);}return z.push({cardId:o,outputFile:d,deliveryToken:k}),true},async hasSource(o,d){let k=`${o}/${d}`;return g.has(k)||await n.hasSource(o,d)},async listSources(o){let d=await n.listSources(o),k=[...g.keys()].filter(O=>O.startsWith(`${o}/`)).map(O=>O.slice(`${o}/`.length));return [...new Set([...d,...k])]}},ke=await L(),ot=chunkG4XXRHL2_cjs.q(ke.graph),Se={...ke.runtimeByCardId},{events:st,newCursor:Ce}=await J().readEntriesAfterCursor(ke.lastDrainedJournalId),se=st,ie=chunkG4XXRHL2_cjs.u(ot,{handlers:{"card-handler":ft(r,Ce,{cardStore:y,cardRuntimeStore:Re,fetchedSourcesStore:at,executionRequestStore:t},(o,d)=>{se.push({type:"task-completed",taskName:o,data:d,timestamp:x()});},(o,d)=>{Q.push({cardId:o,values:d});},o=>{$.push(o);})},onNodeRemoved:o=>{H.delete(o),A.delete(o),delete Se[o],Y.add(o);}});for(;se.length>0;){let o=se;se=[];for(let d of o)if(d.type==="task-restart"){let k=await y.readCard(d.taskName);k&&H.set(d.taskName,k);}ie.pushAll(o),await ie.waitForHandlers();}let Ie=ie.getState();await ie.dispose({wait:true}),await U({lastDrainedJournalId:Ce,graph:chunkG4XXRHL2_cjs.p(Ie),runtimeByCardId:Se},(await V().readSnapshot(D)).version);for(let{cardId:o,values:d}of Q)await w.writeComputedValues(o,d);for(let o of $)await w.writeDataObjects(o);for(let[o,d]of A)await e.writeRuntime(o,d);for(let o of z)await n.commitSourceData(o.cardId,o.outputFile,o.deliveryToken);let xe=chunkNDAKMJQK_cjs.t(S,Ie);await w.writeStatusSnapshot(xe);let ee=[];for(let{cardId:o,values:d}of Q)ee.push({kind:"computed_values",cardId:o,values:d});for(let o of $)for(let[d,k]of Object.entries(o))ee.push({kind:"data_object",key:d,payload:k});for(let[o,d]of H)ee.push({kind:"card_refreshed",cardId:o,card:d});for(let o of Y)ee.push({kind:"card_removed",cardId:o});ee.push({kind:"status",status:xe}),await re(ee);let X=await ne();if(!X)return;let Fe=a.supportsDirectSourceOutput?.(X)===true;await t.dispatchEntriesForJournalId(Ce,async o=>{if(o.taskKind!=="source-fetch"){p(`[async-process-accumulated-events] unknown taskKind "${o.taskKind}" \u2014 skipping`);return}let d=o.payload,k=d.enrichedCard?.id??"unknown",O=d.enrichedCard?.source_defs??[];if(X.howToRun==="queue-storage"&&Fe){try{let I=await b().readQueueStoreRef();if(!I)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let _=a.queueStorageForRef(I,"task-executor"),Z=typeof X.extra?.boardId=="string"?X.extra.boardId:void 0,j=[];for(let N of O){if(!N.outputFile)continue;let ue=a.genId(),de=`${k}/.staged/${ue}/${N.outputFile}`,qe=await Promise.resolve(s.keyRef?.(de));if(!qe)continue;let Te={ref:chunkVQCIOKJV_cjs.a(qe),deliveryToken:ue,outputFile:N.outputFile,cardId:k},it=tt({cbk:d.callbackToken,rg:r.value,br:chunkVQCIOKJV_cjs.a(r),cid:k,b:N.bindTo,d:N.outputFile,cs:void 0,rqt:d.rqt,dt:Te.deliveryToken});j.push({...Z?{boardId:Z}:{},ref:X,args:{source_def:N,base_ref:chunkVQCIOKJV_cjs.a(r),callback:i.createCallback(it),output:Te}});}j.length>0&&await _.enqueueMany(j);}catch(I){await F({type:"task-failed",taskName:k,error:I instanceof Error?I.message:String(I),timestamp:x()});}return}for(let I of O){if(!I.outputFile)continue;let _;if(Fe){let N=a.genId(),ue=`${k}/.staged/${N}/${I.outputFile}`,de=await Promise.resolve(s.keyRef?.(ue));de&&(_={ref:chunkVQCIOKJV_cjs.a(de),deliveryToken:N,outputFile:I.outputFile,cardId:k});}let Z=tt({cbk:d.callbackToken,rg:r.value,br:chunkVQCIOKJV_cjs.a(r),cid:k,b:I.bindTo,d:I.outputFile,cs:void 0,rqt:d.rqt,..._?{dt:_.deliveryToken}:{}}),j=await a.dispatchExecution(X,{source_def:I,base_ref:chunkVQCIOKJV_cjs.a(r),callback:i.createCallback(Z),..._?{output:_}:{}});j.dispatched||await F({type:"task-failed",taskName:k,error:j.error??"dispatch failed",timestamp:x()});}});}async function ae(){try{let t=async()=>{let s=await L(),{events:n}=await J().readEntriesAfterCursor(s.lastDrainedJournalId);n.length>0&&await m();},e=await Ye(a.lock,ye,t);return h({ran:e!==!1})}catch(t){return v(t)}}async function be(){return c||(c=ae().finally(()=>{c=null;}),c)}async function m(){let t=await b().readQueueStoreRef();if(!t)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=a.queueStorageForRef(t,"process-accumulated");e.enqueueIfAbsent?await e.enqueueIfAbsent({boardRef:chunkVQCIOKJV_cjs.a(r)},`process-accumulated:${chunkVQCIOKJV_cjs.a(r)}`):await e.enqueue({boardRef:chunkVQCIOKJV_cjs.a(r)}),await a.requestProcessAccumulated?.();}async function l(){let t=await b().readQueueStoreRef();if(!t)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=a.queueStorageForRef(t,"process-accumulated");for(;;){let s=await e.lease({max:64,visibilityMs:1e3});if(s.length<=0)return;for(let n of s)await e.ack(n.id,n.leaseToken);if(s.length<64)return}}function R(){m();}return {async init(t){try{let e=t.params?.cardStoreRef;if(!e)return f("init requires params.cardStoreRef");if(C=t.params?.boardRuntimeStoreRef,!C)return f("init requires params.boardRuntimeStoreRef");let s=t.params?.outputsStoreRef;if(!s)return f("init requires params.outputsStoreRef");let n=t.params?.queueStoreRef;if(!n)return f("init requires params.queueStoreRef");let y=t.params?.fetchedSourcesStoreRef;if(!y)return f("init requires params.fetchedSourcesStoreRef");if(P=t.params?.scratchStoreRef,!P)return f("init requires params.scratchStoreRef");let w=t.params?.chatStoreRef;if(!w)return f("init requires params.chatStoreRef");let A=t.params?.artifactsStoreRef;if(!A)return f("init requires params.artifactsStoreRef");await oe()||await U({lastDrainedJournalId:"",graph:chunkG4XXRHL2_cjs.p(chunkG4XXRHL2_cjs.a(chunkNDAKMJQK_cjs.u)),runtimeByCardId:{}},null);let g=b();return await g.writeBoardRuntimeStoreRef(C),await g.writeCardStoreRef(e),await g.writeOutputsStoreRef(s),await g.writeQueueStoreRef(n),await g.writeFetchedSourcesStoreRef(y),await g.writeChatStoreRef(w),await g.writeArtifactsStoreRef(A),await(await T()).writeStatusSnapshot(chunkNDAKMJQK_cjs.t(S,chunkG4XXRHL2_cjs.q((await L()).graph))),h()}catch(e){return v(e)}},async status(t){try{let e=await T(),s=await e.readStatusSnapshot();return s||(s=chunkNDAKMJQK_cjs.t(S,chunkG4XXRHL2_cjs.q((await L()).graph)),await e.writeStatusSnapshot(s)),h(s)}catch(e){return v(e)}},async getCardStoreRef(t){try{let e=await b().readCardStoreRef();return e?h({storeRef:e}):f(`Board at ${r.value} has no card store configured`)}catch(e){return v(e)}},async getBoardRuntimeStoreRef(t){try{return h({storeRef:C??null})}catch(e){return v(e)}},async getOutputsStoreRef(t){try{let e=await b().readOutputsStoreRef();return e?h({storeRef:e}):f(`Board at ${r.value} has no outputs store configured`)}catch(e){return v(e)}},async getScratchStoreRef(t){try{return h({storeRef:P??null})}catch(e){return v(e)}},async getChatStoreRef(t){try{return h({storeRef:await b().readChatStoreRef()})}catch(e){return v(e)}},async getArtifactsStoreRef(t){try{return h({storeRef:await b().readArtifactsStoreRef()})}catch(e){return v(e)}},async getFetchedSourcesStoreRef(t){try{return h({storeRef:await b().readFetchedSourcesStoreRef()})}catch(e){return v(e)}},async getConfig(t){try{let e=t.params?.key;if(!e)return f("getConfig requires params.key");let s=b(),n;switch(e){case "task-executor":n=B??null;break;case "chat-handler-flow":n=te??null;break;case "board-runtime-store-ref":n=await s.readBoardRuntimeStoreRef();break;case "card-store-ref":n=await s.readCardStoreRef();break;case "outputs-store-ref":n=await s.readOutputsStoreRef();break;case "scratch-store-ref":n=P??null;break;case "chat-store-ref":n=await s.readChatStoreRef();break;case "artifacts-store-ref":n=await s.readArtifactsStoreRef();break;case "fetched-sources-store-ref":n=await s.readFetchedSourcesStoreRef();break;default:return f(`getConfig: unknown key "${e}"`)}return h({value:n})}catch(e){return v(e)}},async getOutputsDataObject(t){try{let e=t.params?.key;return e?h(await(await T()).readDataObject(e)):f("getOutputsDataObject requires params.key")}catch(e){return v(e)}},async getAllOutputsDataObjects(t){try{return h(await(await T()).readAllDataObjects())}catch(e){return v(e)}},async getOutputsComputedValues(t){try{let e=t.params?.key;return e?h(await(await T()).readComputedValues(e)):f("getOutputsComputedValues requires params.key")}catch(e){return v(e)}},async getAllOutputsComputedValues(t){try{return h(await(await T()).readAllComputedValues())}catch(e){return v(e)}},async getOutputsFetchedSources(t){try{let e=t.params?.key;if(!e)return f("getOutputsFetchedSources requires params.key");let s=await(await W()).listSources(e),n={};for(let y of s)n[y]=await pe(`${e}/${y}`);return h(n)}catch(e){return v(e)}},async getAllOutputsFetchedSources(t){try{let e=await W(),s=await(await G()).listKeys(),n=new Set;for(let w of s){let A=w.indexOf("/");A>0&&!w.includes("/.staged/")&&n.add(w.slice(0,A));}let y={};for(let w of n){let A=await e.listSources(w);if(A.length!==0){y[w]={};for(let g of A)y[w][g]=await pe(`${w}/${g}`);}}return h(y)}catch(e){return v(e)}},async addCardFiles(t){try{let e=t.params?.cardId;if(!e)return f("addCardFiles requires params.cardId");let s=await K(),n=await s.readCard(e);if(!n)return f(`card "${e}" not found`);let y=t.body,w=Array.isArray(y)?y:y&&typeof y=="object"&&Array.isArray(y.files)?y.files:y!=null?[y]:null;if(!w||w.length===0)return f("addCardFiles requires a file metadata object, array, or body.files array");let A=n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?n.card_data:{},g=Array.isArray(A.files)?A.files:[],z=[...g,...w],Q=w.map((H,Y)=>({idx:g.length+Y,entry:H}));await s.writeCard(e,{...n,card_data:{...A,files:z}});let $=await this.cardRefreshedNotify({params:{cardId:e}});return $.status!=="success"?$:h({cardId:e,files_added:Q,notified:!0})}catch(e){return v(e)}},async cardRefreshedNotify(t){try{let e=t.params?.cardId;if(!e)return f("cardRefreshedNotify requires params.cardId");let s=await(await K()).readCard(e);return s?(await re([{kind:"card_refreshed",cardId:e,card:s}]),h({cardId:e,notified:!0})):f(`Card "${e}" not found in board at ${r.value}`)}catch(e){return v(e)}},async removeCard(t){try{let e=t.params?.id;if(!e)return f("removeCard requires params.id");try{await a.kvStorage("card-upsert").delete(e);}catch{}return await F({type:"task-removal",taskName:e,timestamp:x()}),R(),h()}catch(e){return v(e)}},async retrigger(t){try{let e=t.params?.id;return e?(await F({type:"task-restart",taskName:e,timestamp:x()}),R(),h()):f("retrigger requires params.id")}catch(e){return v(e)}},async processAccumulatedEvents(t){return await l(),be()},async upsertCard(t){try{let e=t.params?.cardId,s=t.params?.all,n=!!t.params?.restart;if(!e&&!s)return f("upsertCard requires --card-id <id> or --all");let y=await K(),w=s?(await y.readAllCards()).map(g=>g.id):[e];for(let g of w)if(!await y.readCard(g))return f(`Card "${g}" not found in board at ${r.value}`);let A=a.kvStorage("card-upsert");for(let g of w){let z=await y.readCard(g);if(!z)continue;let Q=chunkNDAKMJQK_cjs.x(z),$=a.hashFn(Q),H=await A.read(g),Y=H?.taskConfigHash!==$;if(!(!Y&&!n)){if(Y){let Re=H?.blobRef??await y.readCardKey(g)??g;await F({type:"task-upsert",taskName:g,taskConfig:Q,timestamp:x()}),await A.write(g,{blobRef:Re,taskConfigHash:$,updatedAt:x()});}n&&await F({type:"task-restart",taskName:g,timestamp:x()});}}return R(),h()}catch(e){return v(e)}},async taskFailed(t){try{let e=t.params?.token;if(!e)return f("taskFailed requires params.token");let s=t.params?.error??"unknown error",n=ge(e);return n?(await F({type:"task-failed",taskName:n.taskName,error:s,timestamp:x()}),R(),h()):f("Invalid callback token")}catch(e){return v(e)}},async taskProgress(t){try{let e=t.params?.token;if(!e)return f("taskProgress requires params.token");let s=(t.body??{}).update??{},n=ge(e);return n?(await F({type:"task-progress",taskName:n.taskName,update:s,timestamp:x()}),R(),h()):f("Invalid callback token")}catch(e){return v(e)}},async sourceDataFetched(t){try{let e=t.params?.token,s=t.params?.ref;if(!e)return f("sourceDataFetched requires params.token");if(!s)return f("sourceDataFetched requires params.ref");let n=rt(e);if(!n)return f("Invalid source token");let y=await W(),w=n.dt||a.genId();n.dt||await y.ingestSourceDataStaged(n.cid,n.d,chunkVQCIOKJV_cjs.b(s),w);let A=ge(n.cbk);return A?(await F({type:"task-progress",taskName:A.taskName,update:{bindTo:n.b,outputFile:n.d,fetchedAt:x(),deliveryToken:w,sourceChecksum:n.cs,rqt:n.rqt},timestamp:x()}),R(),h()):f("Invalid callback token embedded in source token")}catch(e){return v(e)}},async sourceDataFetchFailure(t){try{let e=t.params?.token,s=t.params?.reason??"unknown";if(!e)return f("sourceDataFetchFailure requires params.token");let n=rt(e);if(!n)return f("Invalid source token");let y=ge(n.cbk);return y?(await F({type:"task-progress",taskName:y.taskName,update:{bindTo:n.b,outputFile:n.d,failure:!0,reason:s,sourceChecksum:n.cs,rqt:n.rqt},timestamp:x()}),R(),h()):f("Invalid callback token embedded in source token")}catch(e){return v(e)}}}}
2
+ exports.a=Ye;exports.b=Xe;exports.c=Ze;exports.d=et;exports.e=Rt;exports.f=kt;exports.g=Et;//# sourceMappingURL=chunk-CMFD27ZC.cjs.map
3
+ //# sourceMappingURL=chunk-CMFD27ZC.cjs.map
@@ -0,0 +1,3 @@
1
+ import {b as b$1,c as c$1}from'./chunk-ANKA7HEJ.js';import {a,b,c}from'./chunk-44L64VQ2.js';import {r,a as a$1,p,q,u}from'./chunk-VGT3TRQG.js';import {a as a$3}from'./chunk-JMDHDY6M.js';import {a as a$2}from'./chunk-KBELAKIY.js';function it(e){return typeof e=="string"&&e.trim().length>0}function ut(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.selfRef is required`);if(!it(e.howToRun))throw new Error(`${t}: adapter.selfRef.howToRun is required`);if(!it(e.whatToRun))throw new Error(`${t}: adapter.selfRef.whatToRun is required`)}function dt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.callbackTransport is required`);if(typeof e.createCallback!="function")throw new Error(`${t}: adapter.callbackTransport.createCallback is required`)}function Qt(e,t="callbackTransport"){return {createCallback(n){let a=e();return ut(a,t),{token:n,via:a}}}}function Ne(e){return Qt(()=>e,"createStaticExecutionRefCallbackTransport")}function cr(e){return Ne({meta:"board-live-cards",howToRun:"http:post",whatToRun:a({kind:"http-url",value:String(e||"").trim()})})}function lr(e){return Ne({meta:"board-live-cards",howToRun:"in-process-loop",whatToRun:a({kind:"in-process-loop",value:String(e||"").trim()})})}function fr(e){let t=typeof e=="string"?{notifyChannel:e}:e??{},n={};return t.notifyChannel&&(n.notifyChannel=t.notifyChannel),t.boardRuntimeStoreRef&&(n.boardRuntimeStoreRef=t.boardRuntimeStoreRef),t.queueStoreRef&&(n.queueStoreRef=t.queueStoreRef),Ne({meta:"board-live-cards",howToRun:"local-node",whatToRun:a({kind:"yaml-flow-cli",value:"board-live-cards-cli.js"}),...Object.keys(n).length>0?{extra:n}:{}})}function Ae(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Je(e,t){return Ae(e)?e.then(t):t(e)}function lt(e,t){let n={...e};for(let a of t.deleteKeys)delete n[a];return {...n,...t.shallowMerge}}function pr(e,t){return {readValues(a){let o=e(a);return Je(o.listKeys(),d=>{let u=[...d].sort();if(u.length===0)return {version:null,values:{}};let c={},C=null;for(let w of u){let q=o.read(w);Ae(q)?C=(C??Promise.resolve()).then(async()=>{c[w]=await q;}):c[w]=q;}return C?C.then(()=>({version:t(c),values:c})):{version:t(c),values:c}})},writeValues(a,o,d){let u=e(a),c=null;for(let C of d){let w=u.delete(C);Ae(w)&&(c=(c??Promise.resolve()).then(()=>w).then(()=>{}));}for(let[C,w]of Object.entries(o)){let q=u.write(C,w);Ae(q)&&(c=(c??Promise.resolve()).then(()=>q).then(()=>{}));}return c?c.then(()=>t(o)):t(o)}}}function ft(e,t){return {readSnapshot(n){return e.readValues(n)},commitSnapshot(n,a){if(a.schemaVersion!==t)throw new Error(`Unsupported snapshot schema version: ${a.schemaVersion}`);return Je(e.readValues(n),o=>{if(o.version!==a.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:o.version};let d=lt(o.values,a);return Je(e.writeValues(n,d,a.deleteKeys),u=>({ok:true,newVersion:u}))})}}}function ct(e,t){if(!t)return e;let n=e.findIndex(a=>a.id===t);return n===-1?e:e.slice(n+1)}function mt(e){return {readEntriesAfterCursor(t){let n=ct(e.readAllEntries(),t);return n.length===0?{events:[],newCursor:t}:{events:n.map(a=>a.event),newCursor:n[n.length-1].id}},pendingCount(t){return ct(e.readAllEntries(),t).length},appendEvent(t){e.appendEntry({id:e.generateId(),event:t});}}}function gr(e){return {appendEvent(t){return e.append(t).then(()=>{})},async readEntriesAfterCursor(t){let n=await e.readAfter(t||null);return {events:n.entries.map(a=>a.payload),newCursor:n.newCursor??t}}}}function Fe(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function ae(e,t){return Fe(e)?e.then(t):t(e)}function Me(e,t){let n=null;for(let a of e){if(n){n=n.then(()=>t(a)).then(()=>{});continue}let o=t(a);Fe(o)&&(n=Promise.resolve(o).then(()=>{}));}return n??void 0}function zt(e){if(e==null)return null;let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{return t}}function Yt(e,t){let n=e.match(t);return n?n[1]:null}function pt(e,t,n){let a={},o=Me(e,d=>{let u=n(d);if(u)return ae(t(d),c=>{a[u]=c;})});return Fe(o)?o.then(()=>a):a}function gt(e,t){return {readSourceData(n,a){return ae(e.read(`${n}/${a}`),zt)},ingestSourceDataStaged(n,a,o,d){return ae(t(o),u=>e.write(`${n}/.staged/${d}/${a}`,u))},commitSourceData(n,a,o){let d=`${n}/.staged/${o}/${a}`,u=`${n}/${a}`;return e.renameKey(d,u)},hasSource(n,a){return e.exists(`${n}/${a}`)},listSources(n){return ae(e.listKeys(`${n}/`),a=>a.filter(o=>!o.includes("/.staged/")).map(o=>o.slice(`${n}/`.length)))}}}function Xt(e,t){let n=(a,o)=>{try{let d=o(a);return Fe(d)?d.catch(u=>t(a,u instanceof Error?u.message:String(u))):void 0}catch(d){try{return t(a,d instanceof Error?d.message:String(d))}catch{return}}};return {appendEntries(a,o){if(!(!a||o.length===0))return ae(e.read(a),d=>e.write(a,[...d??[],...o]))},dispatchEntriesForJournalId(a,o){if(a)return ae(e.read(a),d=>{let u=d;if(!(!u||u.length===0))return ae(Me(u,c=>n(c,o)),()=>e.delete(a))})}}}function Wt(e,t,n){return {readRuntime(a){return ae(e.read(t(a)),o=>o??n())},writeRuntime(a,o){return e.write(t(a),o)}}}function St(e){return {writeComputedValues(t,n){return e.write(`cards/${t}/computed_values`,n)},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){return ae(e.listKeys("cards/"),t=>pt(t,n=>e.read(n),n=>Yt(n,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(t){return Me(Object.entries(t),([n,a])=>{if(n)return a===void 0?e.delete(`data-objects/${n}`):e.write(`data-objects/${n}`,a)})},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){return ae(e.listKeys("data-objects/"),t=>pt(t,n=>e.read(n),n=>n.slice(13)))},writeStatusSnapshot(t){return e.write("status",t)},readStatusSnapshot(){return e.read("status")}}}function He(e,t){function n(){return e.readIndex()??{}}function a(o,d,u){let c=String(d||"").split(".").filter(Boolean);if(c.length===0)return u&&typeof u=="object"&&!Array.isArray(u)?u:{value:u};let C={...o},w=C;for(let q=0;q<c.length-1;q++){let X=c[q],Y=w[X],ee=Y&&typeof Y=="object"&&!Array.isArray(Y)?{...Y}:{};w[X]=ee,w=ee;}return w[c[c.length-1]]=u,C}return {readCard(o){let d=n()[o];return !d||!e.cardExists(d.key)?null:e.readCard(d.key)},readCardKey(o){return n()[o]?.key??null},readAllCards(){let o=[];for(let[d,u]of Object.entries(n())){if(!e.cardExists(u.key))continue;let c=e.readCard(u.key);c?o.push(c):t?.(`[card-store] could not read card "${d}" at key "${u.key}"`);}return o},readChecksumIndex(){let o={};for(let[d,u]of Object.entries(n()))o[d]=u.checksum;return o},changedSince(o){let d=n(),u=[];for(let[c,C]of Object.entries(d))o[c]!==C.checksum&&u.push(c);for(let c of Object.keys(o))d[c]||u.push(c);return u},validateUpsert(o,d){let u=n(),c=u[o],C=Object.entries(u).find(([,w])=>w.key===d);return c&&c.key!==d?{ok:false,error:`Card id "${o}" is already mapped to key "${c.key}", cannot remap to "${d}"`}:C&&C[0]!==o?{ok:false,error:`Key "${d}" is already mapped to card id "${C[0]}", cannot remap to "${o}"`}:{ok:true}},writeCard(o,d,u){let c=n(),C=u??c[o]?.key??e.defaultCardKey(o),w=e.writeCard(C,d);c[o]={key:C,checksum:w,updatedAt:new Date().toISOString()},e.writeIndex(c);},patchCard(o,d,u){let c=n(),C=c[o];if(!C||!e.cardExists(C.key))throw new Error(`card "${o}" not found`);let w=e.readCard(C.key);if(!w||typeof w!="object"||Array.isArray(w))throw new Error(`card "${o}" is not patchable`);let q=a(w,d,u),X=e.writeCard(C.key,q);c[o]={key:C.key,checksum:X,updatedAt:new Date().toISOString()},e.writeIndex(c);},removeCard(o){let d=n(),u=d[o];u&&(e.removeCard(u.key),delete d[o],e.writeIndex(d));},readIndex(){return n()}}}function _e(e,t){return gt(e,t)}function yt(e){return mt(e)}var Oe="v1",Re="board/graph",Ct="board/lastJournalProcessedId";function vr(e){return `cards/${e}/runtime`}function bt(e){return ft(e,Oe)}function qe(e){function t(n){let a=e.read(n);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}return {readTaskExecutorRef(){let n=t("task-executor");if(n?.trim())return c$1(n.trim())},writeTaskExecutorRef(n){e.write("task-executor",b$1(n));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(n){e.write("chat-handler-flow",n);},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(n){e.write("board-runtime-store-ref",n);},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(n){e.write("card-store-ref",n);},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(n){e.write("outputs-store-ref",n);},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(n){e.write("queue-store-ref",n);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(n){e.write("scratch-store-ref",n);},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(n){e.write("chat-store-ref",n);},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(n){e.write("artifacts-store-ref",n);},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(n){e.write("fetched-sources-store-ref",n);}}}function wt(e){return St(e)}function kt(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function Zt(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function Rt(e,t){return e?.lastRequestedToken?Zt(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function er(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function ht(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function Pe(e,t){let n=t.state.tasks,a=t.config.tasks,o=Object.keys(n),d=r(t),u={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},c=new Map;for(let k of d.pending)c.set(k.taskName,k.waitingOn);for(let k of d.unresolved)c.set(k.taskName,k.missingTokens);for(let k of d.blocked)c.set(k.taskName,k.failedTokens);let C=new Map;for(let[k,x]of Object.entries(a))for(let G of x.requires??[]){let K=C.get(G)??[];K.push(k),C.set(G,K);}let w=o.sort().map(k=>{let x=n[k],G=a[k]??{requires:[],provides:[]};x.status==="completed"?u.completed+=1:x.status==="failed"?u.failed+=1:x.status==="in-progress"&&(u.in_progress+=1);let K=G.requires??[],p=G.provides??[],i=Object.keys(x.data??{}).sort(),m=K.filter(P=>t.state.availableOutputs.includes(P)),b=K.filter(P=>!t.state.availableOutputs.includes(P)),I=c.get(k)??b,R=new Set;for(let P of p)for(let $ of C.get(P)??[])$!==k&&R.add($);let O=x.failedAt,j=x.error?{message:x.error,code:"TASK_FAILED",at:O,source:"task-runtime"}:void 0;return {name:k,status:x.status,error:j,requires:K,requires_satisfied:m,requires_missing:b,provides_declared:p,provides_runtime:i,blocked_by:I,unblocks:Array.from(R).sort(),runtime:{attempt_count:x.executionCount??0,restart_count:x.retryCount??0,in_progress_since:x.status==="in-progress"?x.startedAt??null:null,last_transition_at:x.lastUpdated??null,last_completed_at:x.completedAt??null,last_restarted_at:x.startedAt??null,status_age_ms:x.lastUpdated?0:null}}});u.pending=d.pending.length,u.blocked=d.blocked.length,u.unresolved=d.unresolved.length;let q=w.map(k=>({name:k.name,fanOut:k.unblocks.length})).sort((k,x)=>x.fanOut-k.fanOut||k.name.localeCompare(x.name)),X=q.length>0?q[0]:{name:null,fanOut:0},Y=new Set;for(let k of Object.values(a))for(let x of k.requires??[])Y.add(x);let ee=0;for(let[k,x]of Object.entries(a)){let G=(x.requires??[]).length===0,p=(x.provides??[]).some(i=>(C.get(i)??[]).some(m=>m!==k));G&&!p&&(ee+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:o.length,completed:u.completed,eligible:d.eligible.length,pending:u.pending,blocked:u.blocked,unresolved:u.unresolved,failed:u.failed,in_progress:u.in_progress,orphan_cards:ee,topology:{edge_count:Array.from(Y).length,max_fan_out_card:X.name,max_fan_out:X.fanOut}},cards:w}}function tr(){return new Date().toISOString()}function vt(e,t,n,a$1,o,d,u){return async c=>{let C=[],w=n.cardStore.readCard(c.nodeId);if(!w)return "task-initiate-failure";let q=w.id,X=w.card_data??{},Y=w.source_defs??[],ee=Y.filter(h=>h.optionalForCompletionGating!==true),k=n.cardRuntimeStore.readRuntime(q),x=false,G=()=>{x&&(n.cardRuntimeStore.writeRuntime(q,k),x=false);},K=h=>kt(k._sources[h]),p=(h,v)=>{k._sources[h]=kt(v),x=true;},i=c.taskState?.executionCount??0;if(k._lastExecutionCount!==i&&(k._sources={},k._lastExecutionCount=i,x=true),c.update){let h=c.update,v=h.outputFile;if(v){let B=K(v);if(h.failure){let M=h.rqt??B.lastRequestedToken??B.queueRequestedToken;M&&p(v,ht(B,M));}else {let M=h.rqt;if(!B.lastCompletedToken||M>B.lastCompletedToken){let V=typeof h.deliveryToken=="string"?h.deliveryToken:void 0,H=false;V&&(H=n.fetchedSourcesStore.commitSourceData(q,v,V)),H?p(v,er(B,M)):p(v,ht(B,M));}}G();}}let b={};for(let h of Y)if(h.outputFile){let v=n.fetchedSourcesStore.readSourceData(q,h.outputFile);v!==null&&(b[h.bindTo]=v);}let I={};for(let[h,v]of Object.entries(c.state??{}))if(v!==null&&typeof v=="object"&&!Array.isArray(v)){let B=v[h];I[h]=B!==void 0?B:v;}else I[h]=v;let R={id:q,card_data:{...X},requires:I,source_defs:Y,compute:w.compute};R._sourcesData=b,w.compute&&a$3.runSync(R,{sourcesData:b}),(d??n.outputStore.writeComputedValues.bind(n.outputStore))(q,R.computed_values??{});let O={...w},j=a$3.enrichSourcesSync(Array.isArray(w.source_defs)?w.source_defs:void 0,{card_data:w.card_data,requires:I}),P=e.value;O.source_defs=Array.isArray(j)?j.map(h=>({...h,boardDir:typeof h.boardDir=="string"&&h.boardDir?h.boardDir:P})):j;let $=tr(),J=c.update?void 0:$,U=ee.filter(h=>{let v=h.outputFile;if(typeof v!="string"||!v)return true;let B=K(v);J&&(B={...B,queueRequestedToken:J},p(v,B));let M=B.queueRequestedToken??B.lastRequestedToken??$,V=Rt(B,M);return V==="in-flight"?false:V==="dispatch"});if(G(),U.length>0){let h=false,v=$;for(let B of U){let M=B.outputFile;if(typeof M!="string"||!M)continue;let V=K(M),H=V.queueRequestedToken??$;p(M,{...V,lastRequestedToken:H}),v=H,h=true;}return h&&G(),h&&(C.push({taskKind:"source-fetch",payload:{boardRef:a(e),enrichedCard:O,callbackToken:c.callbackToken,rqt:v}}),n.executionRequestStore.appendEntries(t,C)),"task-initiated"}if(ee.some(h=>{let v=h.outputFile;if(typeof v!="string"||!v)return false;let B=K(v),M=B.queueRequestedToken??B.lastRequestedToken??$;return Rt(B,M)==="in-flight"}))return "task-initiated";let me=w.provides??[],ie={};for(let{bindTo:h,ref:v}of me)ie[h]=a$3.resolve(R,v);return (u??n.outputStore.writeDataObjects.bind(n.outputStore))(ie),Y.filter(h=>{if(h.optionalForCompletionGating!==true)return false;let v=K(h.outputFile);return !v.lastRequestedToken||!v.lastCompletedToken?true:v.lastCompletedToken<=v.lastRequestedToken}).length>0&&C.push({taskKind:"source-fetch",payload:{boardRef:a(e),enrichedCard:O,callbackToken:c.callbackToken,rqt:$}}),a$1(c.nodeId,ie),C.length>0&&n.executionRequestStore.appendEntries(t,C),"task-initiated"}}var Ge={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function xt(e){return {[Re]:e.graph,[Ct]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function Et(e){let t=e[Re],n=e[Ct],o=e.board?.runtimeByCardId;if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${Re}`);return {graph:t,lastDrainedJournalId:typeof n=="string"?n:"",runtimeByCardId:o&&typeof o=="object"?o:{}}}function Tt(e){let t=e.requires;return {provides:e.provides?.map(a=>a.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...t&&t.length>0?{requires:t}:{}}}function E(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function S(e){return {status:"fail",error:e}}function T(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function rr(e){let t=new TextEncoder().encode(e),n=Array.from(t,a=>String.fromCharCode(a)).join("");return btoa(n).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Ft(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),n=t+"=".repeat((4-t.length%4)%4),a=atob(n),o=Uint8Array.from(a,d=>d.charCodeAt(0));return new TextDecoder().decode(o)}function Be(e){try{let t=JSON.parse(Ft(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function It(e){return rr(JSON.stringify(e))}function At(e){try{let t=JSON.parse(Ft(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function Z(){return new Date().toISOString()}function nr(e){let t=new Map;return {appendEntries(n,a){if(!n||a.length===0)return;let o=t.get(n)??[];t.set(n,[...o,...a]);},dispatchEntriesForJournalId(n,a){if(!n)return;let o=t.get(n);if(!(!o||o.length===0)){for(let d of o)try{a(d);}catch(u){try{e(d,u instanceof Error?u.message:String(u));}catch{}}t.delete(n);}}}}function qr(e,t,n={}){dt(t.callbackTransport,"createBoardLiveCardsPublic");let a$3=t.callbackTransport,o=t.onWarn??(()=>{}),d=a(e),u$1=n.boardRuntimeStoreRef,c$1=n.scratchStoreRef,C=n.taskExecutorRef,w=n.chatHandlerFlow;function q$1(){if(!u$1)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return u$1}function X(s){if(s.length!==0)try{let r=t.publishBoardChangeNotifications?.(s);r&&typeof r.catch=="function"&&r.catch(l=>o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${l instanceof Error?l.message:String(l)}`));}catch(r){o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${r instanceof Error?r.message:String(r)}`);}}function Y(){let s=k().readCardStoreRef();if(!s)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let r=t.kvStorageForRef(s);return {readIndex(){return r.read("_index")},writeIndex(l){r.write("_index",l);},readCard(l){return r.read(l)},writeCard(l,g){return r.write(l,g),t.hashFn(g)},removeCard(l){r.delete(l);},cardExists(l){return r.read(l)!==null},defaultCardKey(l){return l}}}let ee={readValues(s){let r=t.kvStorageForRef(q$1()),l=r.listKeys().sort();if(l.length===0)return {version:null,values:{}};let g={};for(let A of l)g[A]=r.read(A);return {version:t.hashFn(g),values:g}},writeValues(s,r,l){let g=t.kvStorageForRef(q$1());for(let A of l)g.delete(A);for(let[A,F]of Object.entries(r))g.write(A,F);return t.hashFn(r)}},k=()=>qe(t.kvStorageForRef(q$1())),x=()=>bt(ee),G=()=>yt(t.journalAdapterForRef(q$1())),K=()=>He(Y(),o),p$1=()=>{let s=k().readOutputsStoreRef();if(!s)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return wt(t.kvStorageForRef(s))};function i(){return C??k().readTaskExecutorRef()}function m(){return !!x().readSnapshot(e.value).values[Re]}function b$1(){let s=x().readSnapshot(e.value);if(!s.values[Re])throw new Error(`Board not initialized at ${e.value}`);return Et(s.values)}function I(s,r){let l=x().commitSnapshot(e.value,{schemaVersion:Oe,expectedVersion:r,commitId:t.genId(),committedAt:Z(),deleteKeys:[],shallowMerge:xt(s)});if(!l.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${r??"null"} current=${l.currentVersion??"null"}`)}function R(s){G().appendEvent(s);}async function O(){let r=nr((f,y)=>{let _=f.payload,L=(_?.enrichedCard??{}).id??_?.cardId??"unknown";R({type:"task-failed",taskName:L,error:y,timestamp:Z()});}),l=b$1(),g=q(l.graph),{events:A,newCursor:F}=G().readEntriesAfterCursor(l.lastDrainedJournalId),Q=V(),D=_e(Q,f=>t.resolveBlob(f)),W={...l.runtimeByCardId},te=new Map,ge={readRuntime(f){return te.get(f)??W[f]??{_sources:{}}},writeRuntime(f,y){te.set(f,y),W[f]=y;}},Se=[],re=new Map,we={readSourceData(f,y){let _=`${f}/${y}`;return re.has(_)?re.get(_):D.readSourceData(f,y)},ingestSourceDataStaged(f,y,_,se){D.ingestSourceDataStaged(f,y,_,se);},commitSourceData(f,y,_){let se=`${f}/.staged/${_}/${y}`,L=Q.read(se);if(L==null){let z=Q.keyRef?.(se);z&&(L=t.resolveBlob(z));}if(L==null)return false;let ne=`${f}/${y}`,le=L.trim();try{re.set(ne,JSON.parse(le));}catch{re.set(ne,le);}return Se.push({cardId:f,outputFile:y,deliveryToken:_}),true},hasSource(f,y){let _=`${f}/${y}`;return re.has(_)?true:D.hasSource(f,y)},listSources(f){let y=D.listSources(f),_=new Set;for(let L of re.keys())L.startsWith(`${f}/`)&&_.add(L.slice(`${f}/`.length));let se=new Set([...y,..._]);return Array.from(se)}},ce={cardStore:K(),cardRuntimeStore:ge,fetchedSourcesStore:we,outputStore:p$1(),executionRequestStore:r},ke=[],Ve=[],je=[],Ke=new Map,ze=new Set,Ht=(f,y)=>{ke.push({type:"task-completed",taskName:f,data:y,timestamp:Z()});},Le=(f,y)=>{R({type:"task-failed",taskName:f,error:y,timestamp:Z()});},ve=u(g,{handlers:{"card-handler":vt(e,F,ce,Ht,Le,(f,y)=>{Ve.push({cardId:f,values:y});},f=>{je.push(f);})},onNodeRemoved:f=>{Ke.delete(f),te.delete(f),delete W[f],ze.add(f);}});for(ke=A;ke.length>0;){let f=ke;ke=[];for(let y of f)if(y.type==="task-restart"){let _=ce.cardStore.readCard(y.taskName);_&&Ke.set(y.taskName,_);}ve.pushAll(f),await ve.waitForHandlers();}let Ye=ve.getState();await ve.dispose({wait:true});let Gt=x().readSnapshot(e.value).version;I({lastDrainedJournalId:F,graph:p(Ye),runtimeByCardId:W},Gt);for(let{cardId:f,values:y}of Ve)ce.outputStore.writeComputedValues(f,y);for(let f of je)ce.outputStore.writeDataObjects(f);for(let{cardId:f,outputFile:y,deliveryToken:_}of Se)D.commitSourceData(f,y,_);let xe;try{xe=Pe(d,Ye),ce.outputStore.writeStatusSnapshot(xe);}catch(f){o(`[board-live-cards-public] status publish failed: ${f instanceof Error?f.message:String(f)}`);}let he=[];for(let{cardId:f,values:y}of Ve)he.push({kind:"computed_values",cardId:f,values:y});for(let f of je)for(let[y,_]of Object.entries(f))y&&he.push({kind:"data_object",key:y,payload:_});for(let[f,y]of Ke)he.push({kind:"card_refreshed",cardId:f,card:y});for(let f of ze)he.push({kind:"card_removed",cardId:f});xe!==void 0&&he.push({kind:"status",status:xe}),X(he);let ye=i()??{howToRun:"built-in",whatToRun:a({kind:"built-in",value:"source-cli-task-executor"})},Xe=t.supportsDirectSourceOutput?.(ye)===true;r.dispatchEntriesForJournalId(F,f=>{if(f.taskKind!=="source-fetch"){o(`[process-accumulated-events] unknown taskKind "${f.taskKind}" \u2014 skipping`);return}let y=f.payload,_=y.enrichedCard?.id??"unknown",se=y.enrichedCard?.source_defs??[];if(ye.howToRun==="queue-storage"&&Xe){try{let L=t.queueStorageForRef(j(),"task-executor"),ne=typeof ye.extra?.boardId=="string"?ye.extra.boardId:void 0,le=[];for(let z of se){if(!z.outputFile){o(`[dispatch] source "${z.bindTo}" has no outputFile \u2014 skipping`);continue}let Ee=t.genId(),Te=`${_}/.staged/${Ee}/${z.outputFile}`,We=Q.keyRef?.(Te);if(!We)continue;let Ze={ref:a(We),deliveryToken:Ee,outputFile:z.outputFile,cardId:_},Ut=It({cbk:y.callbackToken,rg:e.value,br:a(e),cid:_,b:z.bindTo,d:z.outputFile,cs:void 0,rqt:y.rqt,dt:Ze.deliveryToken});le.push({...ne?{boardId:ne}:{},ref:ye,args:{source_def:z,base_ref:a(e),callback:a$3.createCallback(Ut),output:Ze}});}le.length>0&&L.enqueueMany(le);}catch(L){Le(_,L instanceof Error?L.message:String(L));}return}for(let L of se){if(!L.outputFile){o(`[dispatch] source "${L.bindTo}" has no outputFile \u2014 skipping`);continue}let ne;if(Xe){let z=t.genId(),Ee=`${_}/.staged/${z}/${L.outputFile}`,Te=Q.keyRef?.(Ee);Te&&(ne={ref:a(Te),deliveryToken:z,outputFile:L.outputFile,cardId:_});}let le=It({cbk:y.callbackToken,rg:e.value,br:a(e),cid:_,b:L.bindTo,d:L.outputFile,cs:void 0,rqt:y.rqt,...ne?{dt:ne.deliveryToken}:{}});t.dispatchExecution(ye,{source_def:L,base_ref:a(e),callback:a$3.createCallback(le),...ne?{output:ne}:{}}).catch(z=>Le(_,z instanceof Error?z.message:String(z)));}});}function j(){let s=k().readQueueStoreRef();if(!s)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);return s}function P(){let s=t.queueStorageForRef(j(),"process-accumulated");s.enqueueIfAbsent?s.enqueueIfAbsent({boardRef:a(e)},`process-accumulated:${a(e)}`):s.enqueue({boardRef:a(e)}),t.requestProcessAccumulated?.();}function $(){let s=t.queueStorageForRef(j(),"process-accumulated");for(;;){let r=s.lease({max:64,visibilityMs:1e3});if(r.length<=0)return;for(let l of r)s.ack(l.id,l.leaseToken);if(r.length<64)return}}async function J(){try{let s=()=>{let l=b$1(),{events:g}=G().readEntriesAfterCursor(l.lastDrainedJournalId);g.length<=0||P();},r=await c(t.lock,O,s);return E({ran:r!==!1})}catch(s){return T(s)}}function U(){P();}function de(s){try{let r=s.params?.cardStoreRef;if(!r)return S("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(u$1=s.params?.boardRuntimeStoreRef,!u$1)return S("init requires params.boardRuntimeStoreRef \u2014 pass the board runtime store ref here");if(!m()){let W=a$1(Ge);I({lastDrainedJournalId:"",graph:p(W),runtimeByCardId:{}},null);}let l=s.params?.outputsStoreRef;if(!l)return S("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let g=s.params?.queueStoreRef;if(!g)return S("init requires params.queueStoreRef \u2014 pass the queue store ref here");let A=s.params?.fetchedSourcesStoreRef;if(!A)return S("init requires params.fetchedSourcesStoreRef \u2014 pass the fetched sources store ref here");if(c$1=s.params?.scratchStoreRef,!c$1)return S("init requires params.scratchStoreRef \u2014 pass the scratch store ref here");let F=s.params?.chatStoreRef;if(!F)return S("init requires params.chatStoreRef \u2014 pass the chat store ref here");let Q=s.params?.artifactsStoreRef;if(!Q)return S("init requires params.artifactsStoreRef \u2014 pass the artifacts store ref here");let D=k();D.writeBoardRuntimeStoreRef(u$1),D.writeCardStoreRef(r),D.writeOutputsStoreRef(l),D.writeQueueStoreRef(g),D.writeFetchedSourcesStoreRef(A),D.writeChatStoreRef(F),D.writeArtifactsStoreRef(Q);try{p$1().writeStatusSnapshot(Pe(d,q(b$1().graph)));}catch{}return E()}catch(r){return T(r)}}function me(s){try{let r=p$1().readStatusSnapshot();if(!r){r=Pe(d,q(b$1().graph));try{p$1().writeStatusSnapshot(r);}catch{}}return E(r)}catch(r){return T(r)}}function ie(s){try{let r=s.params?.id;if(!r)return S("removeCard requires params.id");try{t.kvStorage("card-upsert").delete(r);}catch{}return R({type:"task-removal",taskName:r,timestamp:Z()}),U(),E()}catch(r){return T(r)}}function Ce(s){try{let r=s.params?.cardId;if(!r)return S("addCardFiles requires params.cardId");let l=a$2(K()).appendFiles({params:{id:r},body:s.body});if(l.status!=="success")return l;let g=h({params:{cardId:r}});return g.status!=="success"?g:E({cardId:r,files_added:l.data.files_added,notified:!0})}catch(r){return T(r)}}function h(s){try{let r=s.params?.cardId;if(!r)return S("cardRefreshedNotify requires params.cardId");let l=K().readCard(r);return l?(X([{kind:"card_refreshed",cardId:r,card:l}]),E({cardId:r,notified:!0})):S(`Card "${r}" not found in board at ${e.value}`)}catch(r){return T(r)}}function v(s){try{let r=s.params?.id;return r?(R({type:"task-restart",taskName:r,timestamp:Z()}),U(),E()):S("retrigger requires params.id")}catch(r){return T(r)}}async function B(s){return $(),J()}function M(){let s=k().readFetchedSourcesStoreRef();if(!s)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return s}function V(){return t.blobStorageForRef(M())}function H(s){try{let r=s.params?.cardId,l=s.params?.all,g=!!s.params?.restart;if(!r&&!l)return S("upsertCard requires --card-id <id> or --all");let A=l?K().readAllCards().map(F=>F.id):[r];for(let F of A)if(!K().readCard(F))return S(`Card "${F}" not found in board at ${e.value}`);for(let F of A){let Q=K().readCard(F),D=Tt(Q),W=t.hashFn(D),te=t.kvStorage("card-upsert"),ge=te.read(F),Se=ge?.taskConfigHash!==W;if(!(!Se&&!g)){if(Se){let re=ge?.blobRef??K().readCardKey(F)??F;R({type:"task-upsert",taskName:F,taskConfig:D,timestamp:Z()}),te.write(F,{blobRef:re,taskConfigHash:W,updatedAt:Z()});}g&&R({type:"task-restart",taskName:F,timestamp:Z()});}}return U(),E()}catch(r){return T(r)}}function oe(s){try{let r=s.params?.token;if(!r)return S("taskFailed requires params.token");let l=s.params?.error??"unknown error",g=Be(r);return g?(R({type:"task-failed",taskName:g.taskName,error:l,timestamp:Z()}),U(),E()):S("Invalid callback token")}catch(r){return T(r)}}function pe(s){try{let r=s.params?.token;if(!r)return S("taskProgress requires params.token");let g=(s.body??{}).update??{},A=Be(r);return A?(R({type:"task-progress",taskName:A.taskName,update:g,timestamp:Z()}),U(),E()):S("Invalid callback token")}catch(r){return T(r)}}function be(s){try{let r=s.params?.token,l=s.params?.ref;if(!r)return S("sourceDataFetched requires params.token");if(!l)return S("sourceDataFetched requires params.ref");let g=At(r);if(!g)return S("Invalid source token");let{cbk:A,cid:F,b:Q,d:D,cs:W,rqt:te,dt:ge}=g,Se=_e(V(),ke=>t.resolveBlob(ke)),re=ge||t.genId();ge||Se.ingestSourceDataStaged(F,D,b(l),re);let we=Be(A);if(!we)return S("Invalid callback token embedded in source token");let ce=Z();return R({type:"task-progress",taskName:we.taskName,update:{bindTo:Q,outputFile:D,fetchedAt:ce,deliveryToken:re,sourceChecksum:W,rqt:te},timestamp:ce}),U(),E()}catch(r){return T(r)}}function ue(s){try{let r=s.params?.token,l=s.params?.reason??"unknown";if(!r)return S("sourceDataFetchFailure requires params.token");let g=At(r);if(!g)return S("Invalid source token");let{cbk:A,b:F,d:Q,cs:D,rqt:W}=g,te=Be(A);return te?(R({type:"task-progress",taskName:te.taskName,update:{bindTo:F,outputFile:Q,failure:!0,reason:l,sourceChecksum:D,rqt:W},timestamp:Z()}),U(),E()):S("Invalid callback token embedded in source token")}catch(r){return T(r)}}function _t(s){try{let r=k().readCardStoreRef();return r?E({storeRef:r}):S(`Board at ${e.value} has no card store configured`)}catch(r){return T(r)}}function Ot(s){try{return E({storeRef:u$1??null})}catch(r){return T(r)}}function qt(s){try{let r=k().readOutputsStoreRef();return r?E({storeRef:r}):S(`Board at ${e.value} has no outputs store configured`)}catch(r){return T(r)}}function Pt(s){try{return E({storeRef:c$1??null})}catch(r){return T(r)}}function Bt(s){try{let r=k().readChatStoreRef();return E({storeRef:r})}catch(r){return T(r)}}function Vt(s){try{let r=k().readArtifactsStoreRef();return E({storeRef:r})}catch(r){return T(r)}}function jt(s){try{let r=k().readFetchedSourcesStoreRef();return E({storeRef:r})}catch(r){return T(r)}}function Kt(s){try{let r=s.params?.key;if(!r)return S("getConfig requires params.key");let l=k(),g;switch(r){case "task-executor":g=C??null;break;case "chat-handler-flow":g=w??null;break;case "board-runtime-store-ref":g=l.readBoardRuntimeStoreRef();break;case "card-store-ref":g=l.readCardStoreRef();break;case "outputs-store-ref":g=l.readOutputsStoreRef();break;case "scratch-store-ref":g=c$1??null;break;case "chat-store-ref":g=l.readChatStoreRef();break;case "artifacts-store-ref":g=l.readArtifactsStoreRef();break;case "fetched-sources-store-ref":g=l.readFetchedSourcesStoreRef();break;default:return S(`getConfig: unknown key "${r}"`)}return E({value:g})}catch(r){return T(r)}}function Lt(s){try{let r=s.params?.key;if(!r)return S("getOutputsDataObject requires params.key");let l=p$1().readDataObject(r);return E(l)}catch(r){return T(r)}}function $t(s){try{return E(p$1().readAllDataObjects())}catch(r){return T(r)}}function Dt(s){try{let r=s.params?.key;if(!r)return S("getOutputsComputedValues requires params.key");let l=p$1().readComputedValues(r);return E(l)}catch(r){return T(r)}}function Nt(s){try{return E(p$1().readAllComputedValues())}catch(r){return T(r)}}function Ue(){return _e(V(),s=>t.resolveBlob(s))}function Qe(s){let r=V().keyRef?.(s);if(!r)throw new Error("configured fetched-sources store does not support keyRef");return a(r)}function Jt(s){try{let r=s.params?.key;if(!r)return S("getOutputsFetchedSources requires params.key");let l=Ue().listSources(r),g={};for(let A of l)g[A]=Qe(`${r}/${A}`);return E(g)}catch(r){return T(r)}}function Mt(s){try{let r=Ue(),l=new Set;for(let A of V().listKeys()){let F=A.indexOf("/");F>0&&!A.includes("/.staged/")&&l.add(A.slice(0,F));}let g={};for(let A of l){let F=r.listSources(A);if(F.length>0){g[A]={};for(let Q of F)g[A][Q]=Qe(`${A}/${Q}`);}}return E(g)}catch(r){return T(r)}}return {init:de,status:me,getBoardRuntimeStoreRef:Ot,getCardStoreRef:_t,getOutputsStoreRef:qt,getScratchStoreRef:Pt,getChatStoreRef:Bt,getArtifactsStoreRef:Vt,getFetchedSourcesStoreRef:jt,getConfig:Kt,getOutputsDataObject:Lt,getAllOutputsDataObjects:$t,getOutputsComputedValues:Dt,getAllOutputsComputedValues:Nt,getOutputsFetchedSources:Jt,getAllOutputsFetchedSources:Mt,removeCard:ie,addCardFiles:Ce,cardRefreshedNotify:h,retrigger:v,processAccumulatedEvents:B,upsertCard:H,taskFailed:oe,taskProgress:pe,sourceDataFetched:be,sourceDataFetchFailure:ue}}function Pr(e,t,n){let a=n?.taskExecutorRef,o=()=>{if(n){if(!n.boardRuntimeStoreRef)throw new Error(`Board at ${e.value} requires boardRuntimeStoreRef for non-core runtime operations.`);return qe(t.kvStorageForRef(n.boardRuntimeStoreRef))}return qe(t.kvStorage("config"))};function d(){let p=o().readCardStoreRef();if(!p)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let i=t.kvStorageForRef(p);return {readIndex(){return i.read("_index")},writeIndex(m){i.write("_index",m);},readCard(m){return i.read(m)},writeCard(m,b){return i.write(m,b),t.hashFn(b)},removeCard(m){i.delete(m);},cardExists(m){return i.read(m)!==null},defaultCardKey(m){return m}}}let u=()=>He(d(),t.onWarn??(()=>{}));function c(){return a??o().readTaskExecutorRef()}async function C(p,i){let m=t.validateSchema(i),b=[],I=c();if(I&&Array.isArray(i.source_defs))for(let O of i.source_defs){let j=typeof O.bindTo=="string"?O.bindTo:"(unknown)";try{let P;try{P=await t.invokeExecutor(I,"validate-source-def",{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(O)});}catch(J){let U=J;if(P=typeof U?.stdout=="string"?U.stdout:"",!P.trim()){b.push(`source "${j}": executor validate-source-def failed \u2014 ${J instanceof Error?J.message:String(J)}`);continue}}let $=JSON.parse(P.trim());if(!$.ok&&Array.isArray($.errors))for(let J of $.errors)b.push(`source "${j}": ${J}`);}catch(P){b.push(`source "${j}": executor validate-source-def failed \u2014 ${P instanceof Error?P.message:String(P)}`);}}let R=[...m.errors,...b];return E({cardId:p,isValid:R.length===0,issues:R})}function w(p,i){let m=p.params?.sourceIdx,b=p.params?.outRef;if(m===void 0)return S(`${i} requires params.sourceIdx`);if(!p.body||typeof p.body!="object"||Array.isArray(p.body))return S(`${i} requires card JSON object in body`);let I=p.body,R=I["card-content"]??I,O=I["mock-projections"]??{},j=R.source_defs??[];if(m<0||m>=j.length)return S(`sourceIdx ${m} out of range (card has ${j.length} source(s))`);let P=j[m],$=typeof P.bindTo=="string"?P.bindTo:"source";return {src:P,bindTo:$,outRef:b,mockProjections:O}}async function q(p){try{if(!p.body||typeof p.body!="object"||Array.isArray(p.body))return S("validateCardPreflight requires card JSON object in body");let i=p.body,m=i["card-content"]??i,b=typeof m.id=="string"?m.id:"(unknown)";return await C(b,m)}catch(i){return T(i)}}async function X(p){try{let i=w(p,"probeSourcePreflight");if("status"in i)return i;let m=c();if(!m)return S("No task-executor registered for this board");try{let b={...i.src,_projections:i.mockProjections},I=await t.invokeExecutor(m,"probe-source-preflight",{timeout:i.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(b)}),R=JSON.parse(I.trim());return R.ok?E({bindTo:i.bindTo,reachable:R.reachable,latencyMs:R.latencyMs,note:R.note}):S(R.error??"Preflight probe failed")}catch{return S("Executor does not support probe-source-preflight")}}catch(i){return T(i)}}async function Y(p){try{let i=w(p,"runSourcePreflight");if("status"in i)return i;let m=c();if(!m)return S("No task-executor registered for this board");try{let b$1={...i.src,_projections:i.mockProjections},I=await t.invokeExecutor(m,"run-source-preflight",{timeout:i.src.timeout??t.executorTimeouts?.probeMs??6e4,input:JSON.stringify(b$1)}),R=JSON.parse(I.trim());if(!R.ok)return E({bindTo:i.bindTo,ok:!1,result:null,issues:[R.error??"Preflight run failed"]});if(i.outRef){let O=b(i.outRef);t.absoluteBlob.write(O.value,JSON.stringify(R.resultValue,null,2));}return E({bindTo:typeof R.bindTo=="string"?R.bindTo:i.bindTo,ok:!0,result:R.resultValue??null,issues:[]})}catch(b){let I=b instanceof Error?b.message:String(b);return E({bindTo:i.bindTo,ok:!1,result:null,issues:[I]})}}catch(i){return T(i)}}async function ee(p){try{let i=c();if(!i)return S("No task-executor registered for this board");let m=await t.invokeExecutor(i,"describe-capabilities",{timeout:t.executorTimeouts?.describeMs??1e4});return E(JSON.parse(m.trim()))}catch(i){return T(i)}}function k(p){try{let i=p.body;if(!i||!Array.isArray(i.ops))return S("updatesInCardStore requires body.ops array");let m=i.ops,b=u();for(let I of m){let R=I.op,O=I.id;if(!O)return S('op is missing "id"');if(R==="update"){let j=I["card-content"];if(!j)return S(`update op for "${O}" is missing "card-content"`);b.writeCard(O,j);}else return S(`Unknown op type: "${R??"(none)"}"`)}return E()}catch(i){return T(i)}}function x(p){try{let i=p.body;if(!i||!Array.isArray(i.ids))return S("readFromCardStore requires body.ids array");let m=i.ids,b=u(),I=m.map(R=>({id:R,"card-content":b.readCard(R)}));return E({cards:I})}catch(i){return T(i)}}function G(p){try{if(!p.body||typeof p.body!="object"||Array.isArray(p.body))return S("evalCardCompute requires a JSON object in body");let i=p.body,m=i["card-content"]??i,b=typeof m.id=="string"?m.id:"(unknown)",I=i["mock-fetched-sources"]??{},R=i["mock-requires"]??{},O=m.compute;if(!O||!Array.isArray(O)||O.length===0)return E({cardId:b,ok:!0,computed_values:{},errors:[]});let j={id:b,card_data:m.card_data??{},requires:R,source_defs:m.source_defs,compute:O},P=a$3.runSync(j,{sourcesData:I}),$=P.node.computed_values??{},J=P.errors??[];return E({cardId:b,ok:J.length===0,computed_values:$,errors:J})}catch(i){return T(i)}}async function K(p){try{if(!p.body||typeof p.body!="object"||Array.isArray(p.body))return S("simulateCardCycle requires a JSON object in body");let i=p.body,m=i["card-content"]??i,b=typeof m.id=="string"?m.id:"(unknown)",I=i["mock-fetched-sources"]??{},R=i["mock-requires"]??{},O=await C(b,m),j=O.status==="success"?{isValid:O.data.isValid,issues:O.data.issues}:{isValid:!1,issues:[O.status==="fail"?O.error:"internal error"]},P=m.source_defs??[],$=m.card_data??{},J=[],U=[];if(P.length>0){J=a$3.enrichSourcesSync(P,{card_data:$,requires:R});for(let V of J){let H=V.projections,oe=V._projections;if(H&&oe){for(let pe of Object.keys(H))if(oe[pe]===void 0){let be=typeof V.bindTo=="string"?V.bindTo:"(unknown)";U.push({bindTo:be,key:pe,error:`Projection "${pe}" resolved to undefined`});}}}}let de=[],me={...I},ie=i["task-executor-ref"],Ce=(ie?.howToRun&&ie?.whatToRun?ie:void 0)??c();for(let V=0;V<J.length;V++){let H=J[V],oe=typeof H.bindTo=="string"?H.bindTo:`source_${V}`;if(!Ce){de.push({bindTo:oe,skipped:!0,error:"No task executor configured"});continue}try{let pe={...H},be=await t.invokeExecutor(Ce,"run-source-preflight",{timeout:H.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(pe)}),ue=JSON.parse(be.trim());ue.ok&&!Object.prototype.hasOwnProperty.call(I,oe)&&Object.prototype.hasOwnProperty.call(ue,"resultValue")&&(me[oe]=ue.resultValue),de.push({bindTo:oe,reachable:ue.reachable,latencyMs:ue.latencyMs,error:ue.ok?void 0:ue.error});}catch{de.push({bindTo:oe,skipped:!0,error:"Executor does not support run-source-preflight"});}}let h=m.compute,v={},B=[];if(h&&Array.isArray(h)&&h.length>0){let V={id:b,card_data:$,requires:R,source_defs:m.source_defs,compute:h},H=a$3.runSync(V,{sourcesData:me});v=H.node.computed_values??{},B=H.errors??[];}let M=j.isValid&&U.length===0&&B.length===0&&de.every(V=>V.reachable!==!1);return E({cardId:b,ok:M,validation:j,source_probes:de,projection_errors:U,fetched_sources:me,computed_values:v,compute_errors:B})}catch(i){return T(i)}}return {validateCardPreflight:q,probeSourcePreflight:X,runSourcePreflight:Y,evalCardCompute:G,simulateCardCycle:K,describeTaskExecutorCapabilities:ee,updatesInCardStore:k,readFromCardStore:x}}
2
+ export{pr as a,ft as b,gr as c,dt as d,cr as e,lr as f,fr as g,gt as h,Xt as i,Wt as j,St as k,He as l,Oe as m,Re as n,vr as o,kt as p,Rt as q,er as r,ht as s,Pe as t,Ge as u,xt as v,Et as w,Tt as x,qr as y,Pr as z};//# sourceMappingURL=chunk-DOFNXJ4C.js.map
3
+ //# sourceMappingURL=chunk-DOFNXJ4C.js.map
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk37HDEW26_cjs=require('./chunk-37HDEW26.cjs');function l(e,r){return r?{...e,...r.pollIntervalMs!=null?{pollIntervalMs:r.pollIntervalMs}:{},...r.visibilityMs!=null?{visibilityMs:r.visibilityMs}:{},...r.concurrency!=null?{concurrency:r.concurrency}:{},...r.maxAttempts!=null?{maxAttempts:r.maxAttempts}:{}}:e}function f(e,r,u,s){return {id:e,async lease(o){return (await Promise.resolve(r.leaseRequests(o))).map(t=>({id:t.messageId,attempt:t.attempt,message:t.request,ack:()=>Promise.resolve(r.ackRequest(t.messageId,t.leaseToken)),nack:a=>Promise.resolve(r.nackRequest(t.messageId,t.leaseToken,a))}))},async handle(o){await u(o.args,o);},onError:s?(o,i)=>s(o,i.attempt,i.message):void 0}}function R(e,r,u,s){return {id:e,async lease(o){return (await Promise.resolve(r.lease(o))).map(t=>({id:t.id,attempt:t.attempt,message:t.body,ack:()=>Promise.resolve(r.ack(t.id,t.leaseToken)),nack:a=>Promise.resolve(r.nack(t.id,t.leaseToken,a))}))},async handle(){await u();},onError:s?(o,i)=>s(o,i.attempt):void 0}}function Q(e){let r=e.logger??{info(){},warn(){},error(){}},u=e.boardAdapter,s=e.runtime.queueLaneTuning??{},o=u.queueStorageForRef(e.queueStoreRef,"process-accumulated"),i=chunkBQUQTOPB_cjs.a(u)?chunk37HDEW26_cjs.a(u.queueStorageForRef(e.queueStoreRef,"chat-agent")):chunkGPCMBPLK_cjs.a(u.queueStorageForRef(e.queueStoreRef,"chat-agent")),t=[];if(t.push(l(R("process-accumulated",o,async()=>{let a=await e.runtime.__drainProcessAccumulatedLane();if(a.status!=="success")throw new Error(a.error||`__drainProcessAccumulatedLane returned ${a.status}`)},(a,n)=>{r.error(`[board-server] queued process-accumulated failed for ${e.boardId} (attempt ${n}): ${String(a&&a.message||a)}`);}),s.processAccumulated)),t.push(l(f("chat-agent",i,async(a,n)=>{await e.runtime.handleChatAgentRequest(n);},(a,n,c)=>{let p=typeof c.args?.cardId=="string"?c.args.cardId:"";r.error(`[board-server] queued chat-agent failed for ${e.boardId}${p?`/${p}`:""} (attempt ${n}): ${String(a&&a.message||a)}`);}),s.chatAgent)),e.executeTaskExecutorRequest){let a=chunkBQUQTOPB_cjs.a(u)?chunk37HDEW26_cjs.a(u.queueStorageForRef(e.queueStoreRef,"task-executor")):chunkGPCMBPLK_cjs.a(u.queueStorageForRef(e.queueStoreRef,"task-executor"));t.push(l(f("task-executor",a,e.executeTaskExecutorRequest,(n,c)=>{r.error(`[board-server] queued board-worker failed for ${e.boardId} (attempt ${c}): ${String(n&&n.message||n)}`);}),s.taskExecutor));}return chunkGPCMBPLK_cjs.b(t)}exports.a=Q;//# sourceMappingURL=chunk-ETW3BXHD.cjs.map
2
+ //# sourceMappingURL=chunk-ETW3BXHD.cjs.map
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunkHWYMZK3N_cjs=require('./chunk-HWYMZK3N.cjs');function s(r){let e=chunkHWYMZK3N_cjs.d(r);return {isValid:e.ok,issues:e.errors}}exports.a=s;//# sourceMappingURL=chunk-FO4KNVU7.cjs.map
2
+ //# sourceMappingURL=chunk-FO4KNVU7.cjs.map
@@ -1,2 +1,2 @@
1
- import {b}from'./chunk-BQS3EIEK.js';function p(t){return typeof t.journalStorage=="function"}function s(t){return typeof t.whatToRun=="string"?t.whatToRun.startsWith("b64:")?b(t.whatToRun).value:t.whatToRun:t.whatToRun.value}function c(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function f(t){let a=t.reduce((r,u)=>r+u.length,0),o=new Uint8Array(a),n=0;for(let r of t)o.set(r,n),n+=r.length;return o}export{p as a,s as b,c,f as d};//# sourceMappingURL=chunk-SGV7PU4H.js.map
2
- //# sourceMappingURL=chunk-SGV7PU4H.js.map
1
+ import {b}from'./chunk-44L64VQ2.js';function p(t){return typeof t.journalStorage=="function"}function s(t){return typeof t.whatToRun=="string"?t.whatToRun.startsWith("b64:")?b(t.whatToRun).value:t.whatToRun:t.whatToRun.value}function c(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function f(t){let a=t.reduce((r,u)=>r+u.length,0),o=new Uint8Array(a),n=0;for(let r of t)o.set(r,n),n+=r.length;return o}export{p as a,s as b,c,f as d};//# sourceMappingURL=chunk-FOFGEABN.js.map
2
+ //# sourceMappingURL=chunk-FOFGEABN.js.map
@@ -0,0 +1,2 @@
1
+ 'use strict';function a(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function n(e){return {...a(e),leaseToken:e.leaseToken,leaseExpiresAt:e.leaseExpiresAt}}function u(e){return {...a(e),reason:e.reason}}function o(e){return {enqueueRequest(r){return e.enqueue(r).id},enqueueRequestIfAbsent:e.enqueueIfAbsent?(r,t)=>{let s=e.enqueueIfAbsent(r,t);return s?s.id:null}:void 0,leaseRequests(r){return e.lease(r).map(n)},ackRequest(r,t){return e.ack(r,t)},nackRequest(r,t,s){return e.nack(r,t,s)},peekActive(){return e.peekActive().map(a)},peekDeadLetter(){return e.peekDeadLetter().map(u)}}}function d(e){return {lanes:e}}exports.a=o;exports.b=d;//# sourceMappingURL=chunk-GPCMBPLK.cjs.map
2
+ //# sourceMappingURL=chunk-GPCMBPLK.cjs.map
@@ -0,0 +1,3 @@
1
+ import {b as b$2}from'./chunk-NNSBBO5R.js';import {b,a}from'./chunk-HEEDJEKM.js';import {a as a$1,d,x as x$1,t,u,n,w,v as v$1,k,b as b$3,c,h as h$1,i,j,o,s,r,q as q$1,p as p$1}from'./chunk-DOFNXJ4C.js';import {a as a$2,b as b$1}from'./chunk-44L64VQ2.js';import {q,p,a as a$3,u as u$1}from'./chunk-VGT3TRQG.js';import {a as a$4}from'./chunk-JMDHDY6M.js';async function Ye(r,a,u){let i=await r.tryAcquire();if(!i)return false;try{await a();}finally{await i();}return await u?.(),true}function Xe(r){return b(r)}function Ze(r,a){return {async readIndex(){return await r.read("_index")},writeIndex(u){return r.write("_index",u)},async readCard(u){return await r.read(u)},async writeCard(u,i){return await r.write(u,i),a(i)},removeCard(u){return r.delete(u)},async cardExists(u){return await r.read(u)!==null},defaultCardKey(u){return u}}}function et(r,a$1){async function u(){return await r.readIndex()??{}}return {async readCard(i){let p=(await u())[i];return !p||!await r.cardExists(p.key)?null:await r.readCard(p.key)},async readCardKey(i){return (await u())[i]?.key??null},async readAllCards(){let i=[];for(let[p,S]of Object.entries(await u())){if(!await r.cardExists(S.key))continue;let c=await r.readCard(S.key);c?i.push(c):a$1?.(`[card-store] could not read card "${p}" at key "${S.key}"`);}return i},async readChecksumIndex(){let i={};for(let[p,S]of Object.entries(await u()))i[p]=S.checksum;return i},async changedSince(i){let p=await u(),S=[];for(let[c,C]of Object.entries(p))i[c]!==C.checksum&&S.push(c);for(let c of Object.keys(i))p[c]||S.push(c);return S},async validateUpsert(i,p){let S=await u(),c=S[i],C=Object.entries(S).find(([,P])=>P.key===p);return c&&c.key!==p?{ok:false,error:`Card id "${i}" is already mapped to key "${c.key}", cannot remap to "${p}"`}:C&&C[0]!==i?{ok:false,error:`Key "${p}" is already mapped to card id "${C[0]}", cannot remap to "${i}"`}:{ok:true}},async writeCard(i,p,S){let c=await u(),C=S??c[i]?.key??r.defaultCardKey(i),P=await r.writeCard(C,p);c[i]={key:C,checksum:P,updatedAt:new Date().toISOString()},await r.writeIndex(c);},async patchCard(i,p,S){let c=await u(),C=c[i];if(!C||!await r.cardExists(C.key))throw new Error(`card "${i}" not found`);let P=await r.readCard(C.key);if(!P||typeof P!="object"||Array.isArray(P))throw new Error(`card "${i}" is not patchable`);let B=String(p||"").split(".").filter(Boolean),te=a(P,B,S),E=await r.writeCard(C.key,te);c[i]={key:C.key,checksum:E,updatedAt:new Date().toISOString()},await r.writeIndex(c);},async removeCard(i){let p=await u(),S=p[i];S&&(await r.removeCard(S.key),delete p[i],await r.writeIndex(p));},readIndex(){return u()}}}function Rt(r,a){return a$1(r,a)}function kt(r,a,u){return {blob:r,kv:a,journal:u}}function h(r){return r!==void 0?{status:"success",data:r}:{status:"success"}}function f(r){return {status:"fail",error:r}}function v(r){return {status:"error",error:r instanceof Error?r.message:String(r)}}function x(){return new Date().toISOString()}function ut(r){let a=new TextEncoder().encode(r),u=Array.from(a,i=>String.fromCharCode(i)).join("");return btoa(u).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function nt(r){let a=r.replace(/-/g,"+").replace(/_/g,"/"),u=a+"=".repeat((4-a.length%4)%4),i=atob(u),p=Uint8Array.from(i,S=>S.charCodeAt(0));return new TextDecoder().decode(p)}function ge(r){try{let a=JSON.parse(nt(r));return typeof a?.t=="string"?{taskName:a.t}:null}catch{return null}}function tt(r){return ut(JSON.stringify(r))}function rt(r){try{let a=JSON.parse(nt(r));return typeof a?.cbk=="string"&&typeof a?.cid=="string"&&typeof a?.b=="string"&&typeof a?.d=="string"?a:null}catch{return null}}function dt(r){return j(r,o,()=>({_sources:{}}))}function ct(r,a){return h$1(r,a)}function mt(r){return k(r)}function lt(r,a){return i(r,a)}function ft(r$1,a,u,i,p,S){return async c=>{let C=[],P=await u.cardStore.readCard(c.nodeId);if(!P)return "task-initiate-failure";let B=P.id,te=P.card_data??{},E=P.source_defs??[],re=E.filter(m=>m.optionalForCompletionGating!==true),b=await u.cardRuntimeStore.readRuntime(B),D=false,V=async()=>{D&&(await u.cardRuntimeStore.writeRuntime(B,b),D=false);},T=m=>p$1(b._sources[m]),K=(m,l)=>{b._sources[m]=p$1(l),D=true;},oe=c.taskState?.executionCount??0;if(b._lastExecutionCount!==oe&&(b._sources={},b._lastExecutionCount=oe,D=true),c.update){let m=c.update.outputFile;if(m){let l=T(m);if(c.update.failure){let R=c.update.rqt??l.lastRequestedToken??l.queueRequestedToken;R&&K(m,s(l,R));}else {let R=c.update.rqt;if(!l.lastCompletedToken||R>l.lastCompletedToken){let t=typeof c.update.deliveryToken=="string"?c.update.deliveryToken:void 0,e=t?await u.fetchedSourcesStore.commitSourceData(B,m,t):false;K(m,e?r(l,R):s(l,R));}}await V();}}let L={};for(let m of E){if(!m.outputFile)continue;let l=await u.fetchedSourcesStore.readSourceData(B,m.outputFile);l!==null&&(L[m.bindTo]=l);}let U={};for(let[m,l]of Object.entries(c.state??{}))if(l!==null&&typeof l=="object"&&!Array.isArray(l)){let R=l[m];U[m]=R!==void 0?R:l;}else U[m]=l;let J={id:B,card_data:{...te},requires:U,source_defs:E,compute:P.compute};J._sourcesData=L,P.compute&&a$4.runSync(J,{sourcesData:L}),(p??(()=>{}))(B,J.computed_values??{});let ne=a$4.enrichSourcesSync(Array.isArray(P.source_defs)?P.source_defs:void 0,{card_data:P.card_data,requires:U}),F={...P,source_defs:Array.isArray(ne)?ne.map(m=>({...m,boardDir:typeof m.boardDir=="string"&&m.boardDir?m.boardDir:r$1.value})):ne},M=x(),G=c.update?void 0:M,W=re.filter(m=>{let l=m.outputFile;if(typeof l!="string"||!l)return true;let R=T(l);G&&(R={...R,queueRequestedToken:G},K(l,R));let t=R.queueRequestedToken??R.lastRequestedToken??M;return q$1(R,t)==="dispatch"});if(await V(),W.length>0){let m=false,l=M;for(let R of W){let t=R.outputFile;if(typeof t!="string"||!t)continue;let e=T(t),s=e.queueRequestedToken??M;K(t,{...e,lastRequestedToken:s}),l=s,m=true;}return m&&await V(),m&&(C.push({taskKind:"source-fetch",payload:{boardRef:a$2(r$1),enrichedCard:F,callbackToken:c.callbackToken,rqt:l}}),await u.executionRequestStore.appendEntries(a,C)),"task-initiated"}if(re.some(m=>{let l=m.outputFile;if(typeof l!="string"||!l)return false;let R=T(l),t=R.queueRequestedToken??R.lastRequestedToken??M;return q$1(R,t)==="in-flight"}))return "task-initiated";let ye=P.provides??[],ae={};for(let{bindTo:m,ref:l}of ye)ae[m]=a$4.resolve(J,l);return (S??(()=>{}))(ae),E.filter(m=>{if(m.optionalForCompletionGating!==true)return false;let l=T(m.outputFile);return !l.lastRequestedToken||!l.lastCompletedToken?true:l.lastCompletedToken<=l.lastRequestedToken}).length>0&&C.push({taskKind:"source-fetch",payload:{boardRef:a$2(r$1),enrichedCard:F,callbackToken:c.callbackToken,rqt:M}}),i(c.nodeId,ae),C.length>0&&await u.executionRequestStore.appendEntries(a,C),"task-initiated"}}function Et(r,a,u$2={}){d(a.callbackTransport,"createAsyncBoardLiveCardsPublic");let i=a.callbackTransport,p$1=a.warn??(()=>{}),S=a$2(r),c$1=null,C=u$2.boardRuntimeStoreRef,P=u$2.scratchStoreRef,B=u$2.taskExecutorRef,te=u$2.chatHandlerFlow;function E(){if(!C)throw new Error(`Board at ${r.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return C}function re(t){if(t.length!==0)try{return Promise.resolve(a.publishBoardChangeNotifications?.(t)).catch(e=>{p$1(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${e instanceof Error?e.message:String(e)}`);})}catch(e){p$1(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${e instanceof Error?e.message:String(e)}`);return}}let b=()=>b$2(a.kvStorageForRef(E())),D=r.value,V=()=>b$3(a$1(()=>a.kvStorageForRef(E()),a.hashFn),"v1"),T=async()=>{let t=await b().readOutputsStoreRef();if(!t)throw new Error(`Board at ${r.value} has no outputs store configured.`);return mt(a.kvStorageForRef(t))},K=async()=>{let t=await b().readCardStoreRef();if(!t)throw new Error(`Board at ${r.value} has no card store configured.`);let e=a.kvStorageForRef(t);return et(Ze(Xe(e),a.hashFn),p$1)};async function oe(){return !!(await V().readSnapshot(D)).values[n]}async function L(){let t=await V().readSnapshot(D);if(!t.values[n])throw new Error(`Board not initialized at ${r.value}`);return w(t.values)}async function U(t,e){let s=await V().commitSnapshot(D,{schemaVersion:"v1",expectedVersion:e,deleteKeys:[],shallowMerge:v$1(t)});if(!s.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${e??"null"} current=${s.currentVersion??"null"}`)}let J=()=>c(a.journalStorageForRef(E()));async function ne(){return B??await b().readTaskExecutorRef()}async function F(t){await J().appendEvent(t);}async function M(){let t=await b().readFetchedSourcesStoreRef();if(!t)throw new Error(`Board at ${r.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return t}async function G(){return a.blobStorageForRef(await M())}async function W(){return ct(await G(),t=>a.resolveBlob(t))}async function pe(t){let e=(await G()).keyRef?.(t);if(!e)throw new Error("configured fetched-sources store does not support keyRef");let s=await Promise.resolve(e);return a$2(s)}async function ye(){let t$1=lt(a.kvStorageForRef(E()),async(o,d)=>{let k=o.payload,I=(k.enrichedCard??{}).id??k.cardId??"unknown";await F({type:"task-failed",taskName:I,error:d,timestamp:x()});}),e=dt(a.kvStorageForRef(E())),s=await G(),n=await W(),y=await K(),w=await T(),A=new Map,g=new Map,z=[],Q=[],$=[],H=new Map,Y=new Set,Re={async readRuntime(o){return A.get(o)??await e.readRuntime(o)},async writeRuntime(o,d){A.set(o,d),Se[o]=d;}},at={async readSourceData(o,d){let k=`${o}/${d}`;return g.has(k)?g.get(k):await n.readSourceData(o,d)},ingestSourceDataStaged(o,d,k,O){return n.ingestSourceDataStaged(o,d,k,O)},async commitSourceData(o,d,k){let O=`${o}/.staged/${k}/${d}`,I=await s.read(O);if(I==null){let j=await Promise.resolve(s.keyRef?.(O));j&&(I=await a.resolveBlob(j));}if(I==null)return false;let _=`${o}/${d}`,Z=I.trim();try{g.set(_,JSON.parse(Z));}catch{g.set(_,Z);}return z.push({cardId:o,outputFile:d,deliveryToken:k}),true},async hasSource(o,d){let k=`${o}/${d}`;return g.has(k)||await n.hasSource(o,d)},async listSources(o){let d=await n.listSources(o),k=[...g.keys()].filter(O=>O.startsWith(`${o}/`)).map(O=>O.slice(`${o}/`.length));return [...new Set([...d,...k])]}},ke=await L(),ot=q(ke.graph),Se={...ke.runtimeByCardId},{events:st,newCursor:Ce}=await J().readEntriesAfterCursor(ke.lastDrainedJournalId),se=st,ie=u$1(ot,{handlers:{"card-handler":ft(r,Ce,{cardStore:y,cardRuntimeStore:Re,fetchedSourcesStore:at,executionRequestStore:t$1},(o,d)=>{se.push({type:"task-completed",taskName:o,data:d,timestamp:x()});},(o,d)=>{Q.push({cardId:o,values:d});},o=>{$.push(o);})},onNodeRemoved:o=>{H.delete(o),A.delete(o),delete Se[o],Y.add(o);}});for(;se.length>0;){let o=se;se=[];for(let d of o)if(d.type==="task-restart"){let k=await y.readCard(d.taskName);k&&H.set(d.taskName,k);}ie.pushAll(o),await ie.waitForHandlers();}let Ie=ie.getState();await ie.dispose({wait:true}),await U({lastDrainedJournalId:Ce,graph:p(Ie),runtimeByCardId:Se},(await V().readSnapshot(D)).version);for(let{cardId:o,values:d}of Q)await w.writeComputedValues(o,d);for(let o of $)await w.writeDataObjects(o);for(let[o,d]of A)await e.writeRuntime(o,d);for(let o of z)await n.commitSourceData(o.cardId,o.outputFile,o.deliveryToken);let xe=t(S,Ie);await w.writeStatusSnapshot(xe);let ee=[];for(let{cardId:o,values:d}of Q)ee.push({kind:"computed_values",cardId:o,values:d});for(let o of $)for(let[d,k]of Object.entries(o))ee.push({kind:"data_object",key:d,payload:k});for(let[o,d]of H)ee.push({kind:"card_refreshed",cardId:o,card:d});for(let o of Y)ee.push({kind:"card_removed",cardId:o});ee.push({kind:"status",status:xe}),await re(ee);let X=await ne();if(!X)return;let Fe=a.supportsDirectSourceOutput?.(X)===true;await t$1.dispatchEntriesForJournalId(Ce,async o=>{if(o.taskKind!=="source-fetch"){p$1(`[async-process-accumulated-events] unknown taskKind "${o.taskKind}" \u2014 skipping`);return}let d=o.payload,k=d.enrichedCard?.id??"unknown",O=d.enrichedCard?.source_defs??[];if(X.howToRun==="queue-storage"&&Fe){try{let I=await b().readQueueStoreRef();if(!I)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let _=a.queueStorageForRef(I,"task-executor"),Z=typeof X.extra?.boardId=="string"?X.extra.boardId:void 0,j=[];for(let N of O){if(!N.outputFile)continue;let ue=a.genId(),de=`${k}/.staged/${ue}/${N.outputFile}`,qe=await Promise.resolve(s.keyRef?.(de));if(!qe)continue;let Te={ref:a$2(qe),deliveryToken:ue,outputFile:N.outputFile,cardId:k},it=tt({cbk:d.callbackToken,rg:r.value,br:a$2(r),cid:k,b:N.bindTo,d:N.outputFile,cs:void 0,rqt:d.rqt,dt:Te.deliveryToken});j.push({...Z?{boardId:Z}:{},ref:X,args:{source_def:N,base_ref:a$2(r),callback:i.createCallback(it),output:Te}});}j.length>0&&await _.enqueueMany(j);}catch(I){await F({type:"task-failed",taskName:k,error:I instanceof Error?I.message:String(I),timestamp:x()});}return}for(let I of O){if(!I.outputFile)continue;let _;if(Fe){let N=a.genId(),ue=`${k}/.staged/${N}/${I.outputFile}`,de=await Promise.resolve(s.keyRef?.(ue));de&&(_={ref:a$2(de),deliveryToken:N,outputFile:I.outputFile,cardId:k});}let Z=tt({cbk:d.callbackToken,rg:r.value,br:a$2(r),cid:k,b:I.bindTo,d:I.outputFile,cs:void 0,rqt:d.rqt,..._?{dt:_.deliveryToken}:{}}),j=await a.dispatchExecution(X,{source_def:I,base_ref:a$2(r),callback:i.createCallback(Z),..._?{output:_}:{}});j.dispatched||await F({type:"task-failed",taskName:k,error:j.error??"dispatch failed",timestamp:x()});}});}async function ae(){try{let t=async()=>{let s=await L(),{events:n}=await J().readEntriesAfterCursor(s.lastDrainedJournalId);n.length>0&&await m();},e=await Ye(a.lock,ye,t);return h({ran:e!==!1})}catch(t){return v(t)}}async function be(){return c$1||(c$1=ae().finally(()=>{c$1=null;}),c$1)}async function m(){let t=await b().readQueueStoreRef();if(!t)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=a.queueStorageForRef(t,"process-accumulated");e.enqueueIfAbsent?await e.enqueueIfAbsent({boardRef:a$2(r)},`process-accumulated:${a$2(r)}`):await e.enqueue({boardRef:a$2(r)}),await a.requestProcessAccumulated?.();}async function l(){let t=await b().readQueueStoreRef();if(!t)throw new Error(`Board at ${r.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let e=a.queueStorageForRef(t,"process-accumulated");for(;;){let s=await e.lease({max:64,visibilityMs:1e3});if(s.length<=0)return;for(let n of s)await e.ack(n.id,n.leaseToken);if(s.length<64)return}}function R(){m();}return {async init(t$1){try{let e=t$1.params?.cardStoreRef;if(!e)return f("init requires params.cardStoreRef");if(C=t$1.params?.boardRuntimeStoreRef,!C)return f("init requires params.boardRuntimeStoreRef");let s=t$1.params?.outputsStoreRef;if(!s)return f("init requires params.outputsStoreRef");let n=t$1.params?.queueStoreRef;if(!n)return f("init requires params.queueStoreRef");let y=t$1.params?.fetchedSourcesStoreRef;if(!y)return f("init requires params.fetchedSourcesStoreRef");if(P=t$1.params?.scratchStoreRef,!P)return f("init requires params.scratchStoreRef");let w=t$1.params?.chatStoreRef;if(!w)return f("init requires params.chatStoreRef");let A=t$1.params?.artifactsStoreRef;if(!A)return f("init requires params.artifactsStoreRef");await oe()||await U({lastDrainedJournalId:"",graph:p(a$3(u)),runtimeByCardId:{}},null);let g=b();return await g.writeBoardRuntimeStoreRef(C),await g.writeCardStoreRef(e),await g.writeOutputsStoreRef(s),await g.writeQueueStoreRef(n),await g.writeFetchedSourcesStoreRef(y),await g.writeChatStoreRef(w),await g.writeArtifactsStoreRef(A),await(await T()).writeStatusSnapshot(t(S,q((await L()).graph))),h()}catch(e){return v(e)}},async status(t$1){try{let e=await T(),s=await e.readStatusSnapshot();return s||(s=t(S,q((await L()).graph)),await e.writeStatusSnapshot(s)),h(s)}catch(e){return v(e)}},async getCardStoreRef(t){try{let e=await b().readCardStoreRef();return e?h({storeRef:e}):f(`Board at ${r.value} has no card store configured`)}catch(e){return v(e)}},async getBoardRuntimeStoreRef(t){try{return h({storeRef:C??null})}catch(e){return v(e)}},async getOutputsStoreRef(t){try{let e=await b().readOutputsStoreRef();return e?h({storeRef:e}):f(`Board at ${r.value} has no outputs store configured`)}catch(e){return v(e)}},async getScratchStoreRef(t){try{return h({storeRef:P??null})}catch(e){return v(e)}},async getChatStoreRef(t){try{return h({storeRef:await b().readChatStoreRef()})}catch(e){return v(e)}},async getArtifactsStoreRef(t){try{return h({storeRef:await b().readArtifactsStoreRef()})}catch(e){return v(e)}},async getFetchedSourcesStoreRef(t){try{return h({storeRef:await b().readFetchedSourcesStoreRef()})}catch(e){return v(e)}},async getConfig(t){try{let e=t.params?.key;if(!e)return f("getConfig requires params.key");let s=b(),n;switch(e){case "task-executor":n=B??null;break;case "chat-handler-flow":n=te??null;break;case "board-runtime-store-ref":n=await s.readBoardRuntimeStoreRef();break;case "card-store-ref":n=await s.readCardStoreRef();break;case "outputs-store-ref":n=await s.readOutputsStoreRef();break;case "scratch-store-ref":n=P??null;break;case "chat-store-ref":n=await s.readChatStoreRef();break;case "artifacts-store-ref":n=await s.readArtifactsStoreRef();break;case "fetched-sources-store-ref":n=await s.readFetchedSourcesStoreRef();break;default:return f(`getConfig: unknown key "${e}"`)}return h({value:n})}catch(e){return v(e)}},async getOutputsDataObject(t){try{let e=t.params?.key;return e?h(await(await T()).readDataObject(e)):f("getOutputsDataObject requires params.key")}catch(e){return v(e)}},async getAllOutputsDataObjects(t){try{return h(await(await T()).readAllDataObjects())}catch(e){return v(e)}},async getOutputsComputedValues(t){try{let e=t.params?.key;return e?h(await(await T()).readComputedValues(e)):f("getOutputsComputedValues requires params.key")}catch(e){return v(e)}},async getAllOutputsComputedValues(t){try{return h(await(await T()).readAllComputedValues())}catch(e){return v(e)}},async getOutputsFetchedSources(t){try{let e=t.params?.key;if(!e)return f("getOutputsFetchedSources requires params.key");let s=await(await W()).listSources(e),n={};for(let y of s)n[y]=await pe(`${e}/${y}`);return h(n)}catch(e){return v(e)}},async getAllOutputsFetchedSources(t){try{let e=await W(),s=await(await G()).listKeys(),n=new Set;for(let w of s){let A=w.indexOf("/");A>0&&!w.includes("/.staged/")&&n.add(w.slice(0,A));}let y={};for(let w of n){let A=await e.listSources(w);if(A.length!==0){y[w]={};for(let g of A)y[w][g]=await pe(`${w}/${g}`);}}return h(y)}catch(e){return v(e)}},async addCardFiles(t){try{let e=t.params?.cardId;if(!e)return f("addCardFiles requires params.cardId");let s=await K(),n=await s.readCard(e);if(!n)return f(`card "${e}" not found`);let y=t.body,w=Array.isArray(y)?y:y&&typeof y=="object"&&Array.isArray(y.files)?y.files:y!=null?[y]:null;if(!w||w.length===0)return f("addCardFiles requires a file metadata object, array, or body.files array");let A=n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?n.card_data:{},g=Array.isArray(A.files)?A.files:[],z=[...g,...w],Q=w.map((H,Y)=>({idx:g.length+Y,entry:H}));await s.writeCard(e,{...n,card_data:{...A,files:z}});let $=await this.cardRefreshedNotify({params:{cardId:e}});return $.status!=="success"?$:h({cardId:e,files_added:Q,notified:!0})}catch(e){return v(e)}},async cardRefreshedNotify(t){try{let e=t.params?.cardId;if(!e)return f("cardRefreshedNotify requires params.cardId");let s=await(await K()).readCard(e);return s?(await re([{kind:"card_refreshed",cardId:e,card:s}]),h({cardId:e,notified:!0})):f(`Card "${e}" not found in board at ${r.value}`)}catch(e){return v(e)}},async removeCard(t){try{let e=t.params?.id;if(!e)return f("removeCard requires params.id");try{await a.kvStorage("card-upsert").delete(e);}catch{}return await F({type:"task-removal",taskName:e,timestamp:x()}),R(),h()}catch(e){return v(e)}},async retrigger(t){try{let e=t.params?.id;return e?(await F({type:"task-restart",taskName:e,timestamp:x()}),R(),h()):f("retrigger requires params.id")}catch(e){return v(e)}},async processAccumulatedEvents(t){return await l(),be()},async upsertCard(t){try{let e=t.params?.cardId,s=t.params?.all,n=!!t.params?.restart;if(!e&&!s)return f("upsertCard requires --card-id <id> or --all");let y=await K(),w=s?(await y.readAllCards()).map(g=>g.id):[e];for(let g of w)if(!await y.readCard(g))return f(`Card "${g}" not found in board at ${r.value}`);let A=a.kvStorage("card-upsert");for(let g of w){let z=await y.readCard(g);if(!z)continue;let Q=x$1(z),$=a.hashFn(Q),H=await A.read(g),Y=H?.taskConfigHash!==$;if(!(!Y&&!n)){if(Y){let Re=H?.blobRef??await y.readCardKey(g)??g;await F({type:"task-upsert",taskName:g,taskConfig:Q,timestamp:x()}),await A.write(g,{blobRef:Re,taskConfigHash:$,updatedAt:x()});}n&&await F({type:"task-restart",taskName:g,timestamp:x()});}}return R(),h()}catch(e){return v(e)}},async taskFailed(t){try{let e=t.params?.token;if(!e)return f("taskFailed requires params.token");let s=t.params?.error??"unknown error",n=ge(e);return n?(await F({type:"task-failed",taskName:n.taskName,error:s,timestamp:x()}),R(),h()):f("Invalid callback token")}catch(e){return v(e)}},async taskProgress(t){try{let e=t.params?.token;if(!e)return f("taskProgress requires params.token");let s=(t.body??{}).update??{},n=ge(e);return n?(await F({type:"task-progress",taskName:n.taskName,update:s,timestamp:x()}),R(),h()):f("Invalid callback token")}catch(e){return v(e)}},async sourceDataFetched(t){try{let e=t.params?.token,s=t.params?.ref;if(!e)return f("sourceDataFetched requires params.token");if(!s)return f("sourceDataFetched requires params.ref");let n=rt(e);if(!n)return f("Invalid source token");let y=await W(),w=n.dt||a.genId();n.dt||await y.ingestSourceDataStaged(n.cid,n.d,b$1(s),w);let A=ge(n.cbk);return A?(await F({type:"task-progress",taskName:A.taskName,update:{bindTo:n.b,outputFile:n.d,fetchedAt:x(),deliveryToken:w,sourceChecksum:n.cs,rqt:n.rqt},timestamp:x()}),R(),h()):f("Invalid callback token embedded in source token")}catch(e){return v(e)}},async sourceDataFetchFailure(t){try{let e=t.params?.token,s=t.params?.reason??"unknown";if(!e)return f("sourceDataFetchFailure requires params.token");let n=rt(e);if(!n)return f("Invalid source token");let y=ge(n.cbk);return y?(await F({type:"task-progress",taskName:y.taskName,update:{bindTo:n.b,outputFile:n.d,failure:!0,reason:s,sourceChecksum:n.cs,rqt:n.rqt},timestamp:x()}),R(),h()):f("Invalid callback token embedded in source token")}catch(e){return v(e)}}}}
2
+ export{Ye as a,Xe as b,Ze as c,et as d,Rt as e,kt as f,Et as g};//# sourceMappingURL=chunk-GU3T75C4.js.map
3
+ //# sourceMappingURL=chunk-GU3T75C4.js.map