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,3 @@
1
+ import {n,h,i,j,a as a$7,b as b$2,k,l as l$1,c as c$3,m}from'./chunk-NU5NO5NM.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$8,c as c$4}from'./chunk-O7NOHKVR.js';import {a,b}from'./chunk-2GSI6C45.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$9,b as b$4}from'./chunk-ZJ5M5COT.js';import {a as a$4,d as d$1,b as b$3,c as c$2}from'./chunk-FOFGEABN.js';import {a as a$6,c as c$1}from'./chunk-O5UYCGIN.js';import {a as a$b}from'./chunk-RKKSVOP2.js';import {g,d,c,b as b$1}from'./chunk-GU3T75C4.js';import {a as a$a}from'./chunk-NNSBBO5R.js';import {y,z,l}from'./chunk-DOFNXJ4C.js';import {a as a$5}from'./chunk-KBELAKIY.js';import {a as a$1}from'./chunk-Q3OTUDIE.js';function ne(A){let{apiBasePath:F,json:C,readJsonBody:z,initBoardAndSetup:q,bootstrapBoard:x,buildPublishedRuntimePayload:V,createMcpControlplaneToolRegistry:U,retriggerCard:G,applyCardAction:N,resolveChatHandlerTarget:K,sendCardFileDownloadResponse:W}=A;async function rt(J,B,L){let u=J.method||"GET",i=L,S=i.pathname;try{if(u==="POST"&&S===`${F}/mcp-actions`){await x();let R=Date.now(),w=new Date(R).toISOString(),y=await z(J),d=typeof y.tool=="string"?y.tool.trim():"",M=y.args&&typeof y.args=="object"&&!Array.isArray(y.args)?y.args:{};if(!d)return C(B,400,{error:"tool is required"}),!0;let P=a$8(M,"card_id");if(!P)return C(B,400,{error:"MCP action requires card_id"}),!0;if(d==="retrigger-card"||d==="retrigger"){await G(P);let O=Date.now();return C(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:d,requestReceivedAt:w,requestReceivedAtMs:R,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:200}}),!0}let f=c$4(M,"payload");if(d==="chat-send"&&!await K(P)){let O=Date.now();return C(B,409,{error:`chat handler is not configured for card: ${P}`,requestReceivedAt:w,requestReceivedAtMs:R,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:409}),!0}if(d==="chat-send"){let O=typeof f["turn-id"]=="string"?f["turn-id"]:typeof f.turnId=="string"?f.turnId:typeof f.turn=="string"?f.turn:"";if(!O||!String(O).trim()){let Q=Date.now();return C(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${P}`,requestReceivedAt:w,requestReceivedAtMs:R,responseSentAt:new Date(Q).toISOString(),responseSentAtMs:Q,responseStatus:400}),!0}}await N(P,d,f);let H=Date.now();return C(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:d,requestReceivedAt:w,requestReceivedAtMs:R,responseSentAt:new Date(H).toISOString(),responseSentAtMs:H,responseStatus:200}}),!0}if(u==="POST"&&S===`${F}/mcp-controlplane`){await x();let R=await z(J),w=typeof R.tool=="string"?R.tool.trim():"",y=R.args&&typeof R.args=="object"&&!Array.isArray(R.args)?R.args:{};if(!w)return C(B,400,{error:"tool is required"}),!0;try{let d=await a$9(w,y,U());if(d&&typeof d=="object"&&!Array.isArray(d)){let M=d;if(M.status==="fail")return C(B,400,{error:b$4(d,"Request failed")}),!0;if(M.status==="error")return C(B,500,{error:b$4(d,"Internal error")}),!0}C(B,200,d);}catch(d){let M=typeof d?.statusCode=="number"?Number(d.statusCode):500,P=d instanceof Error?d.message:String(d);C(B,M,{error:P});}return !0}let k=S.match(new RegExp(`^${c$2(F)}/cards/([^/]+)/retrigger$`));if(u==="POST"&&k){await x();let R=decodeURIComponent(k[1]);return await G(R),C(B,200,{ok:!0}),!0}let v=S.match(new RegExp(`^${c$2(F)}/cards/([^/]+)/actions$`));if(u==="POST"&&v){await x();let R=decodeURIComponent(v[1]),w=Date.now(),y=new Date(w).toISOString(),d=await z(J),M=d?.actionType;if(M==="chat-send"&&!await K(R)){let f=Date.now();return C(B,409,{error:`chat handler is not configured for card: ${R}`,requestReceivedAt:y,requestReceivedAtMs:w,responseSentAt:new Date(f).toISOString(),responseSentAtMs:f,responseStatus:409}),!0}if(M==="chat-send"){let f=d?.payload??{},H=typeof f["turn-id"]=="string"?f["turn-id"]:typeof f.turnId=="string"?f.turnId:typeof f.turn=="string"?f.turn:"";if(!H||!String(H).trim()){let O=Date.now();return C(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${R}`,requestReceivedAt:y,requestReceivedAtMs:w,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:400}),!0}}await N(R,M,d?.payload);let P=Date.now();return C(B,200,{ok:!0,requestReceivedAt:y,requestReceivedAtMs:w,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:200}),!0}let j=S.match(new RegExp(`^${c$2(F)}/cards/([^/]+)/files/(\\d+)$`));if(u==="GET"&&j){let R=decodeURIComponent(j[1]),w=parseInt(j[2],10),y=i.searchParams.get("sn");return await W(B,R,w,y),!0}return !1}catch(k){let v=k?.statusCode||500;return C(B,v,{error:String(k?.message||k)}),true}}return {handleRuntimeApi:rt}}var oe={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},ae="chat-handler-flow-queue",ft="__probe__echo__probe__";function gr(A){let F=String(A.apiBasePath||"/api/board").replace(/\/$/,""),C={...oe,...A.corsHeaders||{}},z$1=A.queueLaneTuning??{},q=A.boardId||"",x=A.logger||{info:console.log,warn:console.warn,error:console.error},V=A.invocationAdapter,U=A.chatFlowRunner||null,G=A.notificationTransport||null,N=A.serverUrl||null,K=A.executionExtra||{},W=A.onSseClientConnected,rt=A.onSseClientDisconnected,J=A.onChannelSubscribed,B=A.onChannelUnsubscribed,L=a({readChatRecords:t=>bt(t),getChatProcessing:t=>Rt(t),readChatAfter:async(t,e)=>{let r=await ie(t,e);return {records:r.records,cursor:r.cursor}},onSseClientDisconnected:rt});function u(t){function e(o){if(Array.isArray(o))return o;if(o&&typeof o=="object"){let c=o;return Array.isArray(c.files)?c.files:[o]}return null}function r(o){return {async get(c){return o.get(c)},async set(c){return o.set(c)},async del(c){return o.del(c)},async patch(c){return o.patch(c)},async appendFiles(c){return o.appendFiles(c)}}}function a(o){function c(h){return {status:"success",data:h}}function p(h){return {status:"fail",error:h}}function l(h){return {status:"error",error:h instanceof Error?h.message:String(h)}}return {async get(h){try{let m=h.params?.id;if(m){let T=await o.readCard(m);return T?c({cards:[T]}):p(`card "${m}" not found`)}return c({cards:await o.readAllCards()})}catch(m){return l(m)}},async set(h){try{let m=h.body;if(m==null)return p("set requires a body (card object or array of cards)");let T=Array.isArray(m)?m:[m];for(let E of T){if(typeof E.id!="string")return p("each card must have a string `id` field");await o.writeCard(E.id,E);}return c({count:T.length})}catch(m){return l(m)}},async del(h){try{let m=h.body?.ids??[],T=h.params?.id,E=T?[...m,T]:m;if(E.length===0)return p("del requires body.ids (string[]) or params.id");for(let Y of E)await o.removeCard(Y);return c({count:E.length})}catch(m){return l(m)}},async patch(h){try{let m=h.params?.id,T=h.params?.path;if(!m)return p("patch requires params.id");if(!T)return p("patch requires params.path");let E=h.body,Y=E&&Object.prototype.hasOwnProperty.call(E,"value")?E.value:h.body;return await o.patchCard(m,T,Y),c({count:1})}catch(m){return l(m)}},async appendFiles(h){try{let m=h.params?.id;if(!m)return p("appendFiles requires params.id");let T=await o.readCard(m);if(!T)return p(`card "${m}" not found`);let E=e(h.body);if(!E||E.length===0)return p("appendFiles requires a file metadata object, array, or body.files array");let Y=T.card_data&&typeof T.card_data=="object"&&!Array.isArray(T.card_data)?T.card_data:{},Pt=Array.isArray(Y.files)?Y.files:[],_e=[...Pt,...E];return await o.patchCard(m,"card_data.files",_e),c({files_added:E.map((De,$e)=>({idx:Pt.length+$e,entry:De}))})}catch(m){return l(m)}}}}let n=a$4(t.boardAdapter)?g(t.baseRef,t.boardAdapter,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow}):y(t.baseRef,t.boardAdapter,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow}),s=t.nonCoreAdapter??(!a$4(t.boardAdapter)&&R(t.boardAdapter)?t.boardAdapter:null),g$1=t.nonCore??(s?z(t.baseRef,s,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),b=t.boardAdapter.chatStorageForRef(t.chatStoreRef),D,$=a$4(t.boardAdapter)?(()=>{let o=d(c(b$1(t.boardAdapter.kvStorageForRef(t.cardStoreRef)),t.boardAdapter.hashFn),x.warn),c$1=a(o);return D={get(p){return c$1.get(p)},set(p){return c$1.set(p)}},c$1})():(()=>{let o=t.boardAdapter.kvStorageForRef(t.cardStoreRef),p=a$5(l({readIndex:()=>o.read("_index"),writeIndex:l=>o.write("_index",l),readCard:l=>o.read(l),writeCard:(l,h)=>(o.write(l,h),l),removeCard:l=>{o.delete(l);},cardExists:l=>o.read(l)!==null,defaultCardKey:l=>l},x.warn));return D=p,r(p)})(),I;if(a$4(t.boardAdapter)){let o=t.boardAdapter.blobStorageForRef(t.artifactsStoreRef);I={async putBytes(c,p){if(o.writeBytes){await o.writeBytes(c,p);return}let l=JSON.stringify({__kind:"bytes-array",data:[...p]});await o.write(c,l);},async getBytes(c){if(o.readBytes){let l=await o.readBytes(c);if(l!==null)return l}let p=await o.read(c);if(p===null)return null;try{let l=JSON.parse(p);if(l&&l.__kind==="bytes-array"&&Array.isArray(l.data))return new Uint8Array(l.data)}catch{}return new TextEncoder().encode(p)},async listKeys(c){return await o.listKeys(c)}};}else {let o=t.boardAdapter.blobStorageForRef(t.artifactsStoreRef),c=a$6(o);I={putBytes(p,l,h){c.putBytes(p,l,h);},getBytes(p){return c.getBytes(p)},listKeys(p){return c.list(p).map(l=>l.key)}};}let Me={async init(o){return n.init(o)},async status(o){return n.status(o)},async getConfig(o){return n.getConfig(o)},async getAllOutputsDataObjects(o){return n.getAllOutputsDataObjects(o)},async getAllOutputsComputedValues(o){return n.getAllOutputsComputedValues(o)},async getOutputsFetchedSources(o){return n.getOutputsFetchedSources(o)},async upsertCard(o){return n.upsertCard(o)},async removeCard(o){return n.removeCard(o)},async cardRefreshedNotify(o){return n.cardRefreshedNotify(o)},async sourceDataFetched(o){return n.sourceDataFetched(o)},async sourceDataFetchFailure(o){return n.sourceDataFetchFailure(o)}};return {label:t.label,board:n,nonCore:g$1,publicCardStore:D,boardOps:Me,cardStoreOps:$,get filesArtifacts(){return I},get chatStorage(){return b},boardAdapter:t.boardAdapter,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:a$7(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let i$1=A.boards.map(u),S=new Map;function k$1(t){return S.get(t)??0}function v(t){return t.queueStoreRef}function j$1(t,e){if(a$4(t.boardAdapter)){let a=t.boardAdapter.queueStorageForRef(v(t),e);return a$a(a)}let r=t.boardAdapter.queueStorageForRef(v(t),e);return a$b(r)}function R(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function w(t){let e=i$1[k$1(t)];return {files:e?e.filesArtifacts:null}}function y$1(){return c$1()}function d$2(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function M(t){if(!t||t.notificationTeardown||!G||!t.notifyRef)return;let e=await G.subscribe(t.notifyRef,r=>{c$3(t.notification,r);let a=r.kind==="notification-batch"?r.notifications:[r];L.broadcastNotificationBatch(a);});t.notificationTeardown=e;}async function P(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let a=await t.boardOps.init({params:e,body:r});if(a.status!=="success")throw Object.assign(new Error(a.error||`init failed for ${t.label}`),{statusCode:500});if(await M(t),!t.chatHandlerFlow&&t.chatHandlerRef&&V.describe)try{let n=await V.describe(t.chatHandlerRef);n&&n.kind!=="chat-handler"?x.warn(`[init] chat-handler describe returned kind="${n.kind}", expected "chat-handler" for ${t.label}`):n&&x.info(`[init] chat-handler validated: ${n.name} (protocol ${n.protocolVersion}) for ${t.label}`);}catch(n){x.warn(`[init] chat-handler describe failed for ${t.label}: ${n?.message||String(n)}`);}t.initialized=true;}async function f(t){if(!t.boardAdapter.publishBoardChangeNotifications)return;let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&b$2(r.data)&&e.push({kind:"status",status:r.data});let a=await t.boardOps.getAllOutputsDataObjects({});if(a.status==="success"&&a.data!=null)for(let[s,g]of Object.entries(a.data))s&&e.push({kind:"data_object",key:s,payload:g});let n=await t.boardOps.getAllOutputsComputedValues({});if(n.status==="success"&&n.data!=null)for(let[s,g]of Object.entries(n.data))s&&e.push({kind:"computed_values",cardId:s,values:g});e.length>0&&t.boardAdapter.publishBoardChangeNotifications(e);}async function H(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),a=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let n of a)typeof n.id=="string"&&(S.set(n.id,e),await t.boardOps.upsertCard({params:{cardId:n.id}}));t.cardsBootstrapped=true;}async function O(){for(let t of i$1)await P(t);}async function Q(){await O();for(let t=0;t<i$1.length;t++)await f(i$1[t]),await H(i$1[t],t),await f(i$1[t]);}async function pt(t=false){t||await O();for(let e of i$1){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function Z(t){return i$1[k$1(t)]??null}async function nt(t){let e=Z(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let a=Array.isArray(r.data?.cards)?r.data.cards:[];return a.length>0?a[0]:null}async function mt(){let t=async r=>{if(!r)return [];let a=await r.cardStoreOps.get({});return a.status!=="success"||!Array.isArray(a.data?.cards)?[]:a.data.cards},e=[];for(let r of i$1)e.push(...await t(r));return e}function gt(){return i$1[0]??null}function se(t){return Z(t)??gt()}function _(t){let e=se(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ie(t,e){return await _(t).readAfter(t,e)}async function Rt(t){return await _(t).isProcessing(t)}async function at(t,e){await _(t).setProcessing(t,e),await L.broadcastCardChats(t,true);}let ce=a$1({append(t,e,r,a,n){return Promise.resolve(_(t).append(t,e,r,a,n)).then(async s=>(await L.broadcastCardChats(t,true),s))},readAll(t){return _(t).readAll(t)},readAfter(t,e){return _(t).readAfter(t,e)},clear(t){return _(t).clear(t)},setProcessing(t,e){return Promise.resolve(_(t).setProcessing(t,e)).then(async()=>{await L.broadcastCardChats(t,true);})},isProcessing(t){return _(t).isProcessing(t)},getConfig(t){return _(t).getConfig(t)},setConfig(t,e){return _(t).setConfig(t,e)}}),yt=n({boardContexts:i$1,cardOwnerIndex:S,cardContextForCard:t=>Z(t),readStatusSnapshot:()=>pe(),readDataObjectsByToken:()=>ge(),readCardRuntimeArtifacts:()=>me(),readCardFromStore:t=>nt(t),readCardDefinitions:()=>mt(),processAccumulatedLaneInternal:t=>pt(t),reportSourceFetched:(t,e)=>Bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>kt(t,{reason:e}),uploadCardFile:(t,e,r,a,n)=>Ct(t,e,r,a,n),chatStorePublic:ce,serverUrl:N,apiBasePath:F}),ue=yt.mcpCardStoreFacade,st=yt.createMcpFacade,de=h({boardId:q,bootstrapBoard:()=>Q(),sseHub:L,onChannelSubscribed:J,onChannelUnsubscribed:B,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>ue()});function le(t){return k(t)}function fe(){return l$1(st())}function wt(){return m({boardId:q,uploadCardFile:Ct,getMcpFacade:()=>st(),controlplane:de})}let it=i({boardId:q,boardContexts:i$1,readCardDefinitions:()=>mt(),readChatRecords:t=>bt(t),getChatProcessing:t=>Rt(t)}),pe=it.readStatusSnapshot,me=it.readCardRuntimeArtifacts,ge=it.readDataObjectsByToken,dt=it.buildPublishedRuntimePayload;async function ht(t,e,r){let a=r?.syncBoard!==false,n=r?.restartOnlyIfChanged===true,s=Z(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let g=await nt(t);if(!g)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let b=n?JSON.stringify(g):null,D=e(g)||g;if(n&&JSON.stringify(D)===b)return;let $=await s.cardStoreOps.set({body:D});if($.status!=="success")throw Object.assign(new Error($.error||`Failed to persist card: ${t}`),{statusCode:500});if(a){let I=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(I.status!=="success")throw Object.assign(new Error(I.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Re(t,e){await ht(t,e,{syncBoard:true});}async function ye(t,e){await ht(t,e,{syncBoard:false});}async function we(t){let e=Z(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await nt(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let a=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(a.status!=="success")throw Object.assign(new Error(a.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function he(t){await _(t).clear(t);try{await at(t,!1);}catch{}}async function be(t,e,r,a,n=""){let s=typeof r=="string"?r.trim():"",g=await _(t).append(t,e||"system",s,a,n);return await L.broadcastCardChats(t,true),g}async function bt(t){return await _(t).readAll(t)}let Ct=j({safeCardId:t=>d$2(t),artifactsStores:t=>w(t),cardFileMetadataStore:()=>y$1(),readCardFromStore:t=>nt(t),updateCardLocalOnly:(t,e)=>ye(t,e),writeChatRecord:(t,e,r,a,n)=>be(t,e,r,a,n)}).uploadCardFile;async function St(t){let e=Z(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),n=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return n==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:n,handlerRef:s}}function Ce(t){let e=typeof t=="string"?t.trim():"";return e.length>=ft.length*2&&e.startsWith(ft)&&e.endsWith(ft)}async function Se(t,e,r=false,a="",n=false){try{let s=await St(t);if(!s){try{await at(t,!1);}catch{}return}let{ctx:g,handlerFlow:b,handlerRef:D}=s;if(!r)try{await at(t,!0);}catch{}let $={boardId:q,cardId:String(t),lastChatEntryId:e,...a?{turnId:a}:{},isProbe:!!n,...K,...N?{serverUrl:N}:{}},I=b!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:ae}}:D;a$4(g.boardAdapter)?await j$1(g,"chat-agent").enqueueRequest({boardId:q,ref:I,args:b!=null?{...$,__chatHandlerFlow:b}:$}):j$1(g,"chat-agent").enqueueRequest({boardId:q,ref:I,args:b!=null?{...$,__chatHandlerFlow:b}:$}),await Promise.resolve(g.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await at(t,!1);}catch{}x.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Ae(t,e,r){if(e.howToRun==="built-in"&&b$3(e)===ae){let a=U,n=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,a?a.run(n,s,{boardId:q,cardId:String(s.cardId||""),label:t.label,logger:x,serverUrl:N,executionExtra:K}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return V.invoke(e,r)}async function Be(t,e=false){e||await O();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",a=r?Z(r):gt();if(!a)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let n=await Ae(a,t.ref,t.args);if(!n.dispatched){if(r)try{await at(r,!1);}catch{}throw new Error(n.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function ke(t,e,r){if(e==="chat-send"){let n=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"",s=wt(),g=Ce(r?.text),b=await a$9("manage.add-chat-entry-and-any-attachments",{board_id:q,card_id:t,role:"user",text:r?.text,turn_id:n,files:[]},s);if(b?.status!=="success")throw new Error(b$4(b,`chat-send append failed for card ${t}`));let D=b?.data?.id;if(typeof D!="string"||!D)throw new Error(`chat-send did not return an append id for card ${t}`);let $=await a$9("setstate.chat-processing-started",{board_id:q,card_id:t},s);if($?.status!=="success")throw new Error(b$4($,`chat-send processing update failed for card ${t}`));Se(t,D,true,n,g);return}await Re(t,n=>{let s=new Date().toISOString(),g=n.card_data&&typeof n.card_data=="object"?n.card_data:{};if(n.card_data=g,e==="file-upload"){let b=y$1().normalizeIncoming(r?.files,s);return b.length>0&&y$1().merge(g,b),n}if(e==="action"){let b=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!b)return n;g.lastAction={buttonId:b,at:s},g.lastActionText=`${b} @ ${s}`;}return n});}function ct(t,e,r){let a=JSON.stringify(r),n=typeof Buffer<"u"?Buffer.byteLength(a):new TextEncoder().encode(a).length;t.writeHead(e,{...C,"Content-Type":"application/json; charset=utf-8","Content-Length":n}),t.end(a);}async function At(t,e,r){let a=await nt(t);if(!a)throw Object.assign(new Error("Card not found"),{statusCode:404});let n=y$1().resolve(a.card_data,e,r);if(!n.ok&&n.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!n.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=n.file,g=d$2(t),b=w(t),D=String(s.stored_name||""),$=`${g}/${D}`,I=b.files?await b.files.getBytes($):null;if(!I)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:I}}async function Pe(t,e,r,a){let{fileRecord:n,bytes:s}=await At(e,r,a),g=String(n.name||n.stored_name||"download.bin"),b=String(n.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":b,"Content-Disposition":`attachment; filename="${g}"`,"Content-Length":s.length}),t.end(s);}function Fe(t){let e=String(t||"").toLowerCase();return e.startsWith("text/")||e.includes("json")||e.includes("xml")||e.includes("javascript")||e.includes("typescript")||e.includes("yaml")||e.includes("csv")}function Oe(t,e,r){let a=t.split(/\r?\n/);return (e==="head"?a.slice(0,r):a.slice(-r)).join(`
2
+ `)}async function ut(t){let e=[];for await(let a of t)e.push(a);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(d$1(e)).trim();return r?JSON.parse(r):{}}async function Bt(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let a=i$1[0];return a?a.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function kt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",a=i$1[0];return a?a.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let ve=b({sseHub:L,corsHeaders:C,json:ct,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:W,onChannelSubscribed:J,onChannelUnsubscribed:B,apiBasePath:F,readJsonBody:t=>ut(t),initBoardAndSetup:()=>O(),bootstrapBoard:()=>Q(),boardContexts:i$1,publishPersistedStateSnapshot:t=>f(t),upsertCardsFromSource:(t,e)=>H(t,e)}).handleWatchersRoutes,Te=a$2({apiBasePath:F,json:ct,readJsonBody:t=>ut(t),bootstrapBoard:()=>Q(),createMcpFacade:()=>st(),createMcpToolRegistry:t=>le(t),resolveCardFileDownloadPayload:(t,e,r)=>At(t,e,r),isLikelyTextMimeType:t=>Fe(t),sliceTextByLines:(t,e,r)=>Oe(t,e,r)}).handleAgentfaceApi,xe=a$3({apiBasePath:F,json:ct,readJsonBody:t=>ut(t),initBoardAndSetup:()=>O(),createMcpWebhookToolRegistry:()=>fe()}).handleWebhooksApi,Ee=ne({apiBasePath:F,json:ct,readJsonBody:t=>ut(t),initBoardAndSetup:()=>O(),bootstrapBoard:()=>Q(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>wt(),retriggerCard:t=>we(t),applyCardAction:(t,e,r)=>ke(t,e,r),resolveChatHandlerTarget:t=>St(t),sendCardFileDownloadResponse:(t,e,r,a)=>Pe(t,e,r,a)}).handleRuntimeApi;async function je(t,e,r){return !!(await Te(t,e,r)||await xe(t,e,r)||await ve(t,e,r)||await Ee(t,e,r))}return {get apiBasePath(){return F},get corsHeaders(){return C},get queueLaneTuning(){return z$1},handleRuntimeApi:je,buildPublishedRuntimePayload:dt,__drainProcessAccumulatedLane:pt,handleChatAgentRequest:Be,clearChatRecords:he,reportSourceFetched(t,e){return Bt(t,{ref:e})},reportSourceFetchFailure(t,e){return kt(t,{reason:e})},get cardStore(){return i$1[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Rr(A){let F=String(A.apiBasePath||"/api/boards").replace(/\/$/,""),C={...oe,...A.corsHeaders||{}},z=A.serverMetaStore,q=A.boardRuntimeFactory,x=new Map,V="boards-config.json";function U(){let u=z.getText(V);if(!u)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(u)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function G(u){z.putText(V,JSON.stringify(u,null,2));}function N(u){let i=String(u||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return i.length>0&&i.length<=64?i:null}function K(u){if(x.has(u))return x.get(u);let S=U().boards.find(v=>v.id===u)||{},k=q(u,S);return x.set(u,k),k}function W(u,i,S){let k=JSON.stringify(S),v=typeof Buffer<"u"?Buffer.byteLength(k):new TextEncoder().encode(k).length;u.writeHead(i,{...C,"Content-Type":"application/json; charset=utf-8","Content-Length":v}),u.end(k);}async function rt(u,i,S){let k=u.method||"GET",v=S.pathname;if(k==="GET"&&v===F)return W(i,200,{ok:true,boards:U().boards}),true;if(k==="POST"&&v===F){let j=[];for await(let f of u)j.push(f);let R=typeof Buffer<"u"?Buffer.concat(j).toString("utf-8").trim():new TextDecoder().decode(d$1(j)).trim(),w={};try{w=R?JSON.parse(R):{};}catch{w={};}let y=N(w.id);if(!y)return W(i,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let d=U();if(d.boards.some(f=>f.id===y))return W(i,409,{error:`Board "${y}" is already registered`}),true;let M=typeof w.label=="string"&&w.label.trim()?w.label.trim():y,P={id:y,label:M};for(let[f,H]of Object.entries(w))f==="id"||f==="label"||H!=null&&(P[f]=H);return d.boards.push(P),G(d),W(i,200,{ok:true,board:P}),true}return false}async function J(u,i,S){let v=S.pathname.match(new RegExp(`^${c$2(F)}/([^/]+)(/|$)`));if(!v)return false;let j=N(decodeURIComponent(v[1]));return j?U().boards.some(y=>y.id===j)?!!await K(j).handleRuntimeApi(u,i,S):(W(i,404,{error:`Board "${j}" not registered. POST ${F} with {id} to register it first.`}),true):(W(i,400,{error:"Invalid board id"}),true)}async function B(u,i,S){return !!(await rt(u,i,S)||await J(u,i,S))}function L(u){if(!U().boards.some(S=>S.id===u))throw Object.assign(new Error(`Board "${u}" not registered`),{statusCode:404});return {service:K(u)}}return {get apiBasePath(){return F},get corsHeaders(){return C},handleApi:B,requireBoardService:L}}export{gr as a,Rr as b};//# sourceMappingURL=chunk-H3EHFCDZ.js.map
3
+ //# sourceMappingURL=chunk-H3EHFCDZ.js.map
@@ -0,0 +1,45 @@
1
+ 'use strict';var child_process=require('child_process'),f=require('fs'),module$1=require('module'),u=require('path'),url=require('url');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var f__namespace=/*#__PURE__*/_interopNamespace(f);var u__namespace=/*#__PURE__*/_interopNamespace(u);var v=new Map;function X(e,r){let o=String(e||"").trim();if(!o)throw new Error("registerInProcessBoardWorkerCallback: key is required");v.set(o,r);}function Y(e){let r=String(e||"").trim();r&&v.delete(r);}async function B(e,r){let o=String(r||"").trim();if(!o)throw new Error("in-process-loop callback requires a non-empty handler key");let t=v.get(o);if(!t)throw new Error(`in-process-loop callback handler not registered: ${o}`);let n=await t(e);if(n&&n.status&&n.status!=="success")throw new Error(n.error||`in-process-loop callback failed with status: ${n.status}`)}function j(e,r,o){q(N(e),JSON.stringify({tool:"webhook.source-fetch-done",args:{token:r,ref:o}}));}function H(e,r,o){q(N(e),JSON.stringify({tool:"webhook.source-fetch-failed",args:{token:r,reason:o}}));}function N(e){return String(e||"").replace(/\/+$/,"")}function q(e,r){let o=`
2
+ const rawUrl = ${JSON.stringify(e)};
3
+ const rawBody = ${JSON.stringify(r)};
4
+ const u = new URL(rawUrl);
5
+ const {request} = require(u.protocol === 'https:' ? 'https' : 'http');
6
+ const h = { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(rawBody) };
7
+ const req = request({hostname:u.hostname,port:u.port,path:u.pathname+u.search,method:'POST',headers:h}, (res) => {
8
+ let responseBody = '';
9
+ res.setEncoding('utf8');
10
+ res.on('data', chunk => { responseBody += chunk; });
11
+ res.on('end', () => {
12
+ const code = res.statusCode || 500;
13
+ if (code < 200 || code >= 300) {
14
+ const msg = responseBody.trim() || res.statusMessage || ('HTTP ' + code);
15
+ process.stderr.write(msg);
16
+ process.exit(1);
17
+ }
18
+ });
19
+ });
20
+ req.on('error', e => { process.stderr.write(e.message); process.exit(1); });
21
+ req.write(rawBody);
22
+ req.end();
23
+ `,t=child_process.spawnSync(process.execPath,["-e",o],{encoding:"utf-8",windowsHide:true});if(t.status!==0)throw new Error(`http-post failed: ${t.stderr?.trim()}`)}var oe=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-H4TYOSMD.cjs', document.baseURI).href)));function O(e,r,o){L(e,["source-data-fetched","--ref",o,"--token",r],"reportComplete");}function A(e,r,o){L(e,["source-data-fetch-failure","--token",r,"--reason",o],"reportFailed");}function L(e,r,o){let t=te(e.whatToRun),{cmd:n,args:s}=ie(t),a=ne(e),i=se(e),p=ae(e),c=child_process.spawnSync(n,[...s,...r,...i?["--board-runtime-store-ref",i]:[],...p?["--queue-store-ref",p]:[],...a?["--notify-channel",a]:[]],{encoding:"utf-8",windowsHide:true});if(c.status!==0)throw new Error(`${o}: board CLI exited ${c.status}: ${c.stderr?.trim()}`)}function te(e){let r=ce(e);if(r.kind==="yaml-flow-cli"){let o=u__namespace.basename(r.value.trim());if(!o)throw new Error(`Invalid yaml-flow-cli ref: expected non-empty cli file name, got ${JSON.stringify(r.value)}`);let t=u__namespace.dirname(oe.resolve("yaml-flow/package.json")),n=o.replace(/\.[^.]+$/,""),s=u__namespace.join(t,"cli","bundled",`${n}.mjs`);if(f__namespace.existsSync(s))return s;let a=u__namespace.join(t,"cli","node",o);if(f__namespace.existsSync(a))return a;throw new Error(`Invalid yaml-flow-cli ref: could not find ${o} under cli/bundled or cli/node in ${t}`)}return r.value}function ne(e){let r=e.extra?.notifyChannel;return typeof r=="string"&&r.length>0?r:void 0}function se(e){let r=e.extra?.boardRuntimeStoreRef;return typeof r=="string"&&r.length>0?r:void 0}function ae(e){let r=e.extra?.queueStoreRef;return typeof r=="string"&&r.length>0?r:void 0}function ie(e){if(!e.endsWith(".ts"))return {cmd:process.execPath,args:[e]};let r=u__namespace.dirname(e),o=[];for(let n=1;n<=5;n++){let s=u__namespace.join(r,...Array(n).fill(".."),"node_modules");o.push(u__namespace.join(s,"tsx","dist","cli.mjs")),o.push(u__namespace.join(s,".bin","tsx"));}let t=o.find(n=>f__namespace.existsSync(n));return t?{cmd:process.execPath,args:[t,e]}:{cmd:"npx",args:["tsx",e]}}function ce(e){if(!e.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${e}`);let r=e.slice(4),o=r.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-r.length%4)%4),t;try{t=JSON.parse(Buffer.from(o,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let n=t;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:n.kind,value:n.value}}var I=new Map;function ue(e,r){let o=String(e||"").trim();if(!o)throw new Error("registerInProcessBoardWorkerInvoke: key is required");I.set(o,r);}function de(e){let r=String(e||"").trim();r&&I.delete(r);}async function T(e,r){let o=String(r||"").trim();if(!o)throw new Error("in-process board-worker invoke requires a non-empty handler key");let t=I.get(o);if(!t)throw new Error(`in-process board-worker invoke handler not registered: ${o}`);return await t(e)}var M=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-H4TYOSMD.cjs', document.baseURI).href))),W=u__namespace.default.dirname(url.fileURLToPath((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-H4TYOSMD.cjs', document.baseURI).href))));function J(e){if(!e.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${e}`);let r=e.slice(4),o=r.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-r.length%4)%4),t;try{t=JSON.parse(Buffer.from(o,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let n=t;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:n.kind,value:n.value}}function g(e){return `b64:${Buffer.from(JSON.stringify(e),"utf8").toString("base64").replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}`}function ke(){return {read(e){if(!f__namespace.default.existsSync(e))return null;try{return f__namespace.default.readFileSync(e,"utf-8")}catch{return null}},write(e,r){f__namespace.default.mkdirSync(u__namespace.default.dirname(e),{recursive:true}),f__namespace.default.writeFileSync(e,r,"utf-8");}}}function ze(e){if(e.kind==="fs-path")return ke();throw new Error(`Unsupported storage kind: "${e.kind}". Supported kinds: fs-path`)}function me(){let e=u__namespace.default.resolve(W,"./jsonata-sync.cjs");if(f__namespace.default.existsSync(e))return e;let r=u__namespace.default.resolve(W,"../../card-compute/jsonata-sync.cjs");return f__namespace.default.existsSync(r)?r:u__namespace.default.resolve(W,"../../../lib/jsonata-sync.cjs")}var ge=M(me());function he(e){e.registerFunction?.("fsPathRef",r=>g({kind:"fs-path",value:String(r)}),"<s:s>");}function l(e){return typeof e=="string"?J(e).value:e.value}function x(e){return e.howToRun==="local-node"||e.howToRun==="local-process"}function z(e){return e.howToRun==="http:post"||e.howToRun==="http:get"}function S(e){return e.howToRun==="in-process-loop"}function F(e){return {...e,whatToRun:typeof e.whatToRun=="string"?e.whatToRun:g(e.whatToRun)}}function we(e){return typeof e.whatToRun=="string"?e:{...e,whatToRun:g(e.whatToRun)}}function P(e,r){if(!e||typeof e!="object")throw new Error(`[board-worker-adapter] Step "${r}" returned a non-object result.`);let o=e,t=o.result??o.status;if(typeof t=="string"&&t.trim()){let n=o.data&&typeof o.data=="object"&&!Array.isArray(o.data)?{...o.data}:{},s=typeof o.error=="string"?o.error:void 0;return s&&!Object.prototype.hasOwnProperty.call(n,"error")&&(n.error=s),s?{result:t,data:n,error:s}:{result:t,data:n}}return {result:"success",data:{...o}}}function R(e){return {result:"failure",data:{error:e},error:e}}function k(e,r,o){try{let t=ge(e);return he(t),t.evaluate(r)}catch(t){let n=t instanceof Error?t.message:String(t);throw new Error(`[${o}] JSONata evaluation failed for "${e}": ${n}`)}}function K(e,r,o){if(!e||typeof e!="object")return {};let t={};if(Array.isArray(e.cmdTemplate)&&(t.cmdArgs=e.cmdTemplate.map(n=>String(k(n,r,`${o}.cmdTemplate`)))),typeof e.stdinTemplate=="string"&&(t.stdin=k(e.stdinTemplate,r,`${o}.stdinTemplate`)),typeof e.urlTemplate=="string"&&(t.url=String(k(e.urlTemplate,r,`${o}.urlTemplate`))),typeof e.headerTemplate=="string"){let n=k(e.headerTemplate,r,`${o}.headerTemplate`);if(!n||typeof n!="object"||Array.isArray(n))throw new Error(`[${o}.headerTemplate] expected an object result`);t.headers=n;}return typeof e.bodyTemplate=="string"&&(t.body=k(e.bodyTemplate,r,`${o}.bodyTemplate`)),t}function V(e){let r=String(e||"").trim();if(!r)return {};try{return JSON.parse(r)}catch{return {stdout:r}}}async function Fe(e,r){let o=U(e,r);if(x(e))return _(e,o);if(e.howToRun==="http:post")return ve(l(e.whatToRun),o);if(S(e))return T(o,l(e.whatToRun));throw new Error(`invokeBoardWorker: unsupported via.howToRun "${e.howToRun}"`)}function Ke(e,r){let o=U(e,r);if(x(e))return _(e,o);if(e.howToRun==="http:post")return Be(l(e.whatToRun),o);throw new Error(`invokeBoardWorkerSync: unsupported via.howToRun "${e.howToRun}"`)}function Re(e){let r=Q(e.whatToRun);switch(e.howToRun){case "local-node":return {command:process.execPath,baseArgs:[r]};case "local-python":return {command:process.platform==="win32"?"python":"python3",baseArgs:[r]};case "local-process":return {command:r,baseArgs:[]};default:throw new Error(`invokeStepMachineExecutionRef: unsupported local transport "${e.howToRun}"`)}}function $(e,r,o){if(!e||typeof e!="object")return r;let t={output:r},n=r.result,s=r.data,a=r.error;if(typeof e.resultExpr=="string"){let i=k(e.resultExpr,t,`${o}.resultExpr`);if(typeof i!="string"||!i.trim())throw new Error(`[${o}.resultExpr] expected a non-empty string result`);n=i;}if(typeof e.dataTemplate=="string"){let i=k(e.dataTemplate,t,`${o}.dataTemplate`);if(!i||typeof i!="object"||Array.isArray(i))throw new Error(`[${o}.dataTemplate] expected an object result`);s=i;}if(typeof e.errorExpr=="string"){let i=k(e.errorExpr,t,`${o}.errorExpr`);a=i!=null?String(i):void 0;}return a!==void 0?{result:n,data:s,error:a}:{result:n,data:s}}function ye(e,r,o,t){let n=o.label||"invokeStepMachineExecutionRef",s=K(e.argsMassaging,t,n),{command:a,baseArgs:i}=Re(e),p=s.stdin!==void 0?s.stdin:r,c=child_process.spawnSync(a,[...i,...s.cmdArgs||[]],{encoding:"utf-8",windowsHide:true,...p!==void 0?{input:JSON.stringify(p)}:{},...typeof o.timeoutMs=="number"&&o.timeoutMs>0?{timeout:Math.floor(o.timeoutMs)}:{},...e.howToRun==="local-process"&&process.platform==="win32"?{shell:true}:{}});if(c.error){let m=c.error instanceof Error?c.error.message:String(c.error);return R(m)}if(typeof c.status=="number"&&c.status!==0)return R(c.stderr?.trim()||`process exited ${c.status}`);let h=P(V(c.stdout||""),n);return e.outputTransforms&&h.result==="success"?$(e.outputTransforms,h,n):h}async function xe(e,r,o,t){let n=o.label||"invokeStepMachineExecutionRef",s=K(e.argsMassaging,t,n),a=s.url||l(e.whatToRun),i={"Content-Type":"application/json",...s.headers||{}},p=typeof o.timeoutMs=="number"&&o.timeoutMs>0?Math.floor(o.timeoutMs):0,c=p>0?new AbortController:null,h=c?setTimeout(()=>c.abort(),p):null;try{let m=s.body!==void 0?s.body:r,w=await fetch(a,{method:e.howToRun==="http:get"?"GET":"POST",headers:i,...e.howToRun==="http:get"?{}:{body:JSON.stringify(m)},...c?{signal:c.signal}:{}}),C=await w.text().catch(()=>"");if(!w.ok)return R(`HTTP ${w.status}: ${C||w.statusText||"request failed"}`);let b=P(V(C),n);return e.outputTransforms&&b.result==="success"?$(e.outputTransforms,b,n):b}catch(m){let w=m instanceof Error?m.message:String(m);return R(w)}finally{h&&clearTimeout(h);}}async function Ve(e,r,o={}){try{let t=we(e),n={...r&&typeof r=="object"&&!Array.isArray(r)?r:{},whatToRun:l(t.whatToRun),...t.extra?{extra:t.extra}:{}};if(t.howToRun==="local-node"||t.howToRun==="local-python"||t.howToRun==="local-process")return ye(t,r,o,n);if(t.howToRun==="http:post"||t.howToRun==="http:get")return xe(t,r,o,n);if(t.howToRun==="in-process-loop"){let s=await T(r,l(t.whatToRun)),a=P(s,o.label||"invokeStepMachineExecutionRef");return t.outputTransforms&&a.result==="success"?$(t.outputTransforms,a,o.label||"invokeStepMachineExecutionRef"):a}return R(`invokeStepMachineExecutionRef: unsupported howToRun "${t.howToRun}"`)}catch(t){let n=t instanceof Error?t.message:String(t);return R(n)}}function U(e,r){return {...r,...r.extra?{}:e.extra?{extra:e.extra}:{}}}function _(e,r){let o=Q(e.whatToRun),{cmd:t,args:n}=Ie(o),s=be(r),a=child_process.spawnSync(t,[...n,...s],{encoding:"utf-8",windowsHide:true,...typeof r.input=="string"?{input:r.input}:{}});if(a.status!==0){let i=new Error(`invokeBoardWorker: board worker exited ${a.status}: ${a.stderr?.trim()||"unknown error"}`);throw i.stdout=a.stdout??"",i.stderr=a.stderr??"",i}return G(a.stdout)}function be(e){let r=typeof e.subcommand=="string"?e.subcommand.trim():"";if(!r)throw new Error("invokeBoardWorker: request.subcommand is required");let o=[r];return typeof e.inRef=="string"&&e.inRef.trim()&&o.push("--in-ref",e.inRef.trim()),typeof e.outRef=="string"&&e.outRef.trim()&&o.push("--out-ref",e.outRef.trim()),typeof e.errRef=="string"&&e.errRef.trim()&&o.push("--err-ref",e.errRef.trim()),e.extra&&typeof e.extra=="object"&&!Array.isArray(e.extra)&&o.push("--extra",Buffer.from(JSON.stringify(e.extra)).toString("base64")),o}async function ve(e,r){return D(e,r)}function Be(e,r){return D(e,r)}function D(e,r){let o=`
24
+ const rawUrl = ${JSON.stringify(e)};
25
+ const rawBody = ${JSON.stringify(JSON.stringify(r))};
26
+ const u = new URL(rawUrl);
27
+ const mod = require(u.protocol === 'https:' ? 'https' : 'http');
28
+ const req = mod.request({ hostname: u.hostname, port: u.port, path: u.pathname + u.search, method: 'POST', headers: { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(rawBody) } }, (res) => {
29
+ let body = '';
30
+ res.setEncoding('utf8');
31
+ res.on('data', (chunk) => { body += chunk; });
32
+ res.on('end', () => {
33
+ const code = res.statusCode || 500;
34
+ if (code < 200 || code >= 300) {
35
+ process.stderr.write(body.trim() || res.statusMessage || ('HTTP ' + code));
36
+ process.exit(1);
37
+ }
38
+ process.stdout.write(body);
39
+ });
40
+ });
41
+ req.on('error', (err) => { process.stderr.write(err.message); process.exit(1); });
42
+ req.write(rawBody);
43
+ req.end();
44
+ `,t=child_process.spawnSync(process.execPath,["-e",o],{encoding:"utf-8",windowsHide:true});if(t.status!==0)throw new Error(`invokeBoardWorker: http-post failed: ${t.stderr?.trim()||"unknown error"}`);return G(t.stdout)}function G(e){let r=String(e||"").trim();if(!r)return {};try{return JSON.parse(r)}catch{return {stdout:r}}}function Q(e){let r=typeof e=="string"?J(e):e;if(r.kind==="yaml-flow-cli"){let o=u__namespace.default.basename(r.value.trim());if(!o)throw new Error(`Invalid yaml-flow-cli ref: expected non-empty cli file name, got ${JSON.stringify(r.value)}`);let t=u__namespace.default.dirname(M.resolve("yaml-flow/package.json")),n=o.replace(/\.[^.]+$/,""),s=u__namespace.default.join(t,"cli","bundled",`${n}.mjs`);if(f__namespace.default.existsSync(s))return s;let a=u__namespace.default.join(t,"cli","node",o);if(f__namespace.default.existsSync(a))return a;throw new Error(`Invalid yaml-flow-cli ref: could not find ${o} under cli/bundled or cli/node in ${t}`)}return r.value}function Ie(e){if(!e.endsWith(".ts"))return {cmd:process.execPath,args:[e]};let r=u__namespace.default.dirname(e),o=[];for(let n=1;n<=5;n++){let s=u__namespace.default.join(r,...Array(n).fill(".."),"node_modules");o.push(u__namespace.default.join(s,"tsx","dist","cli.mjs")),o.push(u__namespace.default.join(s,".bin","tsx"));}let t=o.find(n=>f__namespace.default.existsSync(n));return t?{cmd:process.execPath,args:[t,e]}:{cmd:"npx",args:["tsx",e]}}function Ue(e,r){let o=u__namespace.default.isAbsolute(e)?e:u__namespace.default.resolve(process.cwd(),e);return {meta:"task-executor",howToRun:"local-node",whatToRun:g({kind:"fs-path",value:o}),...r?{extra:r}:{}}}async function _e(e){let r=u__namespace.default.isAbsolute(e)?e:u__namespace.default.resolve(process.cwd(),e),o=await import(url.pathToFileURL(r).href),t=typeof o.executeTaskExecutorRequest=="function"?o.executeTaskExecutorRequest:typeof o.executeBoardWorkerRequest=="function"?o.executeBoardWorkerRequest:void 0;if(typeof t!="function")throw new Error(`Immediate board worker module must export executeTaskExecutorRequest(request) or executeBoardWorkerRequest(request): ${r}`);return t}function De(e,r={}){return async({subcommand:o,input:t,timeoutMs:n,extra:s})=>{if(typeof o!="string"||!o.trim())throw new Error("Immediate board worker hook requires subcommand");let a={...r,...s&&typeof s=="object"&&!Array.isArray(s)?s:{}};return await e({subcommand:o,...t!==void 0?{input:t}:{},...n!==void 0?{timeoutMs:n}:{},...Object.keys(a).length>0?{extra:a}:{}})}}function Ge(e,r){let{token:o,via:t}=e;if(x(t)){O(F(t),o,g(r));return}if(z(t)){j(l(t.whatToRun),o,g(r));return}if(S(t)){B({token:o,outcome:"success",ref:g(r)},l(t.whatToRun));return}throw new Error(`reportComplete: unsupported via.howToRun "${t.howToRun}"`)}function Qe(e,r){let{token:o,via:t}=e;if(x(t)){A(F(t),o,r);return}if(z(t)){H(l(t.whatToRun),o,r);return}if(S(t)){B({token:o,outcome:"failure",reason:r},l(t.whatToRun));return}throw new Error(`reportFailed: unsupported via.howToRun "${t.howToRun}"`)}exports.a=X;exports.b=Y;exports.c=ue;exports.d=de;exports.e=J;exports.f=g;exports.g=ze;exports.h=Fe;exports.i=Ke;exports.j=Ve;exports.k=Ue;exports.l=_e;exports.m=De;exports.n=Ge;exports.o=Qe;//# sourceMappingURL=chunk-H4TYOSMD.cjs.map
45
+ //# sourceMappingURL=chunk-H4TYOSMD.cjs.map
@@ -0,0 +1,4 @@
1
+ 'use strict';function k(o){if(o==null||typeof o!="object")return JSON.stringify(o);if(Array.isArray(o))return `[${o.map(k).join(",")}]`;let r=o;return `{${Object.keys(r).sort().map(u=>`${JSON.stringify(u)}:${k(r[u])}`).join(",")}}`}function I(o,r){let S=r>>>0;for(let u=0;u<o.length;u++)S^=o.charCodeAt(u),S=Math.imul(S,16777619)>>>0;return S}function F(o){let r=k(o),S=I(r,2166136261),u=I(r,3735928559),h=I(r,19088743),s=I(r,4277009102);return [S,u,h,s].map(l=>l.toString(16).padStart(8,"0")).join("")}function J(o){function r(s){return `${o}:blob:${s}`}let S=new TextEncoder;function u(s){if(typeof btoa=="function"){let l="";for(let n=0;n<s.length;n++)l+=String.fromCharCode(s[n]);return btoa(l)}return ""}function h(s){if(typeof atob=="function"){let l=atob(s),n=new Uint8Array(l.length);for(let a=0;a<l.length;a++)n[a]=l.charCodeAt(a);return n}return new Uint8Array}return {read(s){return globalThis.localStorage.getItem(r(s))},write(s,l){globalThis.localStorage.setItem(r(s),l);},exists(s){return globalThis.localStorage.getItem(r(s))!==null},remove(s){globalThis.localStorage.removeItem(r(s));},readBytes(s){let l=globalThis.localStorage.getItem(r(s));if(l===null)return null;try{let n=JSON.parse(l);if(n&&n.__kind==="bytes-b64"&&typeof n.data=="string")return h(n.data)}catch{}return S.encode(l)},writeBytes(s,l){let n=JSON.stringify({__kind:"bytes-b64",data:u(l)});globalThis.localStorage.setItem(r(s),n);},listKeys(s){let l=r(s??""),n=[];for(let a=0;a<globalThis.localStorage.length;a++){let g=globalThis.localStorage.key(a);g&&g.startsWith(l)&&n.push(g.slice(r("").length));}return n.sort()},stat(s){let l=globalThis.localStorage.getItem(r(s));if(l===null)return null;let n=S.encode(l).byteLength;try{let a=JSON.parse(l);a&&a.__kind==="bytes-b64"&&typeof a.data=="string"&&(n=h(a.data).byteLength);}catch{}return {key:s,size:n}},renameKey(s,l){let n=globalThis.localStorage.getItem(r(s));return n===null?false:(globalThis.localStorage.setItem(r(l),n),globalThis.localStorage.removeItem(r(s)),true)}}}var N=":scratch-marker",C=":scratch-config",T=":scratch:",L=1440*60*1e3,O=720*60*1e3,B=200;function $(o,r){if(!o)return r;let S=o.replace(/[^A-Za-z0-9._-]/g,"_");return S.length>0?S:r}function W(o){let r=`${o}${N}`,S=`${o}${C}`,u=t=>`${o}${T}${t}`,h=t=>`${o}${T}${t}:__ts`,s=globalThis.localStorage.getItem(r)===null;if(s)try{globalThis.localStorage.setItem(r,`scratch-store
2
+ ${new Date().toISOString()}`);}catch{}function l(){let t=globalThis.localStorage.getItem(S);if(t===null)return {};try{let e=JSON.parse(t);return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}catch{return {}}}function n(t){try{globalThis.localStorage.setItem(S,JSON.stringify(t));}catch{}}if(s){let t=l();typeof t["retention.lastSweepAt"]!="number"&&(t["retention.lastSweepAt"]=Date.now(),n(t));}function a(){if(globalThis.localStorage.getItem(r)===null)return;let t=l(),e=typeof t["retention.maxAgeMs"]=="number"?t["retention.maxAgeMs"]:L,i=typeof t["retention.sweepIntervalMs"]=="number"?t["retention.sweepIntervalMs"]:O;if(e<=0||i<=0)return;let d=typeof t["retention.lastSweepAt"]=="number"?t["retention.lastSweepAt"]:0,y=Date.now();if(y-d<i)return;t["retention.lastSweepAt"]=y,n(t);let f=y,m=`${o}${T}`,b=[];for(let w=0;w<globalThis.localStorage.length;w++){let p=globalThis.localStorage.key(w);p&&p.startsWith(m)&&!p.endsWith(":__ts")&&b.push(p);}for(let w of b){if(Date.now()-f>B)break;let p=globalThis.localStorage.getItem(`${w}:__ts`),_=p===null?0:Number(p);if(Number.isFinite(_)&&_>0&&y-_>e){try{globalThis.localStorage.removeItem(w);}catch{}try{globalThis.localStorage.removeItem(`${w}:__ts`);}catch{}}}}function g(t,e){let i=$(t,"scratch"),d=$(e,".json"),y=d.startsWith(".")?d:`.${d}`,f=Math.random().toString(36).slice(2,10);return `${i}-${Date.now()}-${f}${y}`}function c(t,e){globalThis.localStorage.setItem(u(t),e),globalThis.localStorage.setItem(h(t),String(Date.now()));}return {read(t){return globalThis.localStorage.getItem(u(t))},write(t,e){c(t,e);try{a();}catch{}},exists(t){return globalThis.localStorage.getItem(u(t))!==null},remove(t){try{globalThis.localStorage.removeItem(u(t));}catch{}try{globalThis.localStorage.removeItem(h(t));}catch{}},readBytes(t){let e=globalThis.localStorage.getItem(u(t));return e===null?null:new TextEncoder().encode(e)},writeBytes(t,e){let i="";for(let d=0;d<e.length;d++)i+=String.fromCharCode(e[d]);c(t,i);try{a();}catch{}},stat(t){let e=globalThis.localStorage.getItem(u(t));if(e===null)return null;let i=globalThis.localStorage.getItem(h(t)),d=i===null?null:Number(i);return {key:t,size:new TextEncoder().encode(e).byteLength,updatedAt:d!==null&&Number.isFinite(d)?new Date(d).toISOString():void 0}},listKeys(t){let e=`${o}${T}`,i=[];for(let d=0;d<globalThis.localStorage.length;d++){let y=globalThis.localStorage.key(d);if(y&&y.startsWith(e)&&!y.endsWith(":__ts")){let f=y.slice(e.length);(!t||f.startsWith(t))&&i.push(f);}}return i.sort()},getUniqueKey(t,e){return g(t,e)},create(t,e,i){let d=g(e,i);c(d,t);try{a();}catch{}return d},keyRef(t){return {kind:"local-storage-scratch",value:t,extra:{prefix:o}}},renameKey(t,e){let i=globalThis.localStorage.getItem(u(t));if(i===null)return false;c(e,i);try{globalThis.localStorage.removeItem(u(t));}catch{}try{globalThis.localStorage.removeItem(h(t));}catch{}return true},config:{get(t){return l()[t]??null},set(t,e){let i=l();e==null?delete i[t]:i[t]=e,n(i);}}}}var M=":archive-marker",R=":archive-config",A=":archive:stream:",v=":archive:blob:";function E(o){let r=o.replace(/[^A-Za-z0-9._-]/g,"_");if(!r)throw new Error("Archive segment name cannot be empty after sanitization");return r}function D(o){let r=`${o}${M}`,S=`${o}${R}`,u=n=>`${o}${A}${n}`;if(globalThis.localStorage.getItem(r)===null)try{globalThis.localStorage.setItem(r,`archive-store
3
+ ${new Date().toISOString()}`);}catch{}function h(){let n=globalThis.localStorage.getItem(S);if(n===null)return {};try{let a=JSON.parse(n);return a&&typeof a=="object"&&!Array.isArray(a)?a:{}}catch{return {}}}function s(n){try{globalThis.localStorage.setItem(S,JSON.stringify(n));}catch{}}function l(){if(globalThis.localStorage.getItem(r)===null)return;let n=h(),a=typeof n["retention.maxAgeMs"]=="number"?n["retention.maxAgeMs"]:0,g=typeof n["retention.sweepIntervalMs"]=="number"?n["retention.sweepIntervalMs"]:0;if(a<=0||g<=0)return;let c=typeof n["retention.lastSweepAt"]=="number"?n["retention.lastSweepAt"]:0,t=Date.now();if(t-c<g)return;n["retention.lastSweepAt"]=t,s(n);let e=`${o}${A}`;for(let i=0;i<globalThis.localStorage.length;i++){let d=globalThis.localStorage.key(i);if(!d||!d.startsWith(e))continue;let y=globalThis.localStorage.getItem(d);if(y)try{let f=JSON.parse(y),m=f.filter(b=>typeof b.__ts!="number"||t-b.__ts<=a);m.length!==f.length&&globalThis.localStorage.setItem(d,JSON.stringify(m));}catch{}}}return {stream(n){let a=E(n),g=u(a);function c(){let e=globalThis.localStorage.getItem(g);if(!e)return [];try{return JSON.parse(e)}catch{return []}}function t(e){try{globalThis.localStorage.setItem(g,JSON.stringify(e));}catch{}}return {append(e){let i={id:globalThis.crypto.randomUUID(),payload:e,__ts:Date.now()},d=c();d.push(i),t(d);try{l();}catch{}return {id:i.id,payload:i.payload}},readAll(){return c().map(e=>({id:e.id,payload:e.payload}))},readAfter(e){let i=c();if(!e){let m=i.map(b=>({id:b.id,payload:b.payload}));return {entries:m,newCursor:m.length>0?m[m.length-1].id:null}}let d=i.findIndex(m=>m.id===e),f=(d===-1?i:i.slice(d+1)).map(m=>({id:m.id,payload:m.payload}));return {entries:f,newCursor:f.length>0?f[f.length-1].id:e}},clear(){try{globalThis.localStorage.removeItem(g);}catch{}}}},blob(n){let a=E(n),g=J(`${o}${v}${a}`);return {read:c=>g.read(c),write:(c,t)=>{g.write(c,t);try{l();}catch{}},exists:c=>g.exists(c),remove:c=>g.remove(c),readBytes:g.readBytes?c=>g.readBytes(c):void 0,writeBytes:g.writeBytes?(c,t)=>{g.writeBytes(c,t);try{l();}catch{}}:void 0,listKeys:c=>g.listKeys(c),stat:g.stat?c=>g.stat(c):void 0,renameKey:(c,t)=>g.renameKey(c,t)}},listStreams(n){let a=`${o}${A}`,g=[];for(let c=0;c<globalThis.localStorage.length;c++){let t=globalThis.localStorage.key(c);if(!t||!t.startsWith(a))continue;let e=t.slice(a.length);(!n||e.startsWith(n))&&g.push(e);}return g.sort()},listBlobs(n){let a=`${o}${v}`,g=new Set;for(let c=0;c<globalThis.localStorage.length;c++){let t=globalThis.localStorage.key(c);if(!t||!t.startsWith(a))continue;let e=t.slice(a.length),i=e.indexOf(":"),d=i===-1?e:e.slice(0,i);(!n||d.startsWith(n))&&g.add(d);}return Array.from(g).sort()},config:{get(n){return h()[n]??null},set(n,a){let g=h();a==null?delete g[n]:g[n]=a,s(g);}}}}function j(o){function r(S){return `${o}:kv:${S}`}return {read(S){let u=globalThis.localStorage.getItem(r(S));if(u===null)return null;try{return JSON.parse(u)}catch{return null}},write(S,u){globalThis.localStorage.setItem(r(S),JSON.stringify(u));},delete(S){globalThis.localStorage.removeItem(r(S));},listKeys(S){let u=r(S??""),h=[];for(let s=0;s<globalThis.localStorage.length;s++){let l=globalThis.localStorage.key(s);l!==null&&l.startsWith(u)&&h.push(l.slice(r("").length));}return h}}}function H(o){function r(){let u=globalThis.localStorage.getItem(o);if(!u)return [];try{return JSON.parse(u)}catch{return []}}function S(u){globalThis.localStorage.setItem(o,JSON.stringify(u));}return {readAllEntries(){return r()},appendEntry(u){let h=r();h.push(u),S(h);},generateId(){return globalThis.crypto.randomUUID()}}}exports.a=F;exports.b=J;exports.c=W;exports.d=D;exports.e=j;exports.f=H;//# sourceMappingURL=chunk-HFW7E2Z7.cjs.map
4
+ //# sourceMappingURL=chunk-HFW7E2Z7.cjs.map
@@ -0,0 +1,3 @@
1
+ 'use strict';var chunkUJ7ZTV4J_cjs=require('./chunk-UJ7ZTV4J.cjs'),chunkGNFE24S7_cjs=require('./chunk-GNFE24S7.cjs'),A=require('ajv-formats'),module$1=require('module');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var A__default=/*#__PURE__*/_interopDefault(A);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 _=chunkGNFE24S7_cjs.b(chunkUJ7ZTV4J_cjs.q(),1);var k=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-HWYMZK3N.cjs', document.baseURI).href))),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__default.default(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
+ exports.a=R;exports.b=T;exports.c=V;exports.d=O;//# sourceMappingURL=chunk-HWYMZK3N.cjs.map
3
+ //# sourceMappingURL=chunk-HWYMZK3N.cjs.map
@@ -0,0 +1,7 @@
1
+ 'use strict';var chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs');function D(h){let o=new Map,a=new Map,d=new Map,k=0,b=null;function m(e){let t=JSON.stringify(e);return k++,`id: ${k}
2
+ data: ${t}
3
+
4
+ `}function y(e){let t=e;try{t.flushHeaders?.();}catch{}try{t.flush?.();}catch{}try{t.socket?.setNoDelay?.(!0);}catch{}try{t.socket?.uncork?.();}catch{}}function I(e,t){let n=o.get(e);if(n&&!(t&&n.res!==t)){o.delete(e),C();try{h.onSseClientDisconnected?.(e);}catch{}try{n.res.end();}catch{}}}function P(e,t,n){let s=o.get(e);s&&I(e,s.res),o.set(e,{res:t,subscribedChatCardIds:n??new Set});}function f(e,t){let n=o.get(e);if(!n)return;let s=m(t);try{n.res.write(s),y(n.res);}catch{I(e,n.res);}}function c(){let e=new Set;for(let t of o.values())for(let n of t.subscribedChatCardIds)e.add(n);return Array.from(e)}async function l(e){let t=a.has(e)?a.get(e):null,{cursor:n}=await h.readChatAfter(e,t),s=await h.getChatProcessing(e),r=s!==(d.get(e)??false),w=n!==t;return w&&a.set(e,n),d.set(e,s),w||r}async function u(e,t){let n=await h.readChatRecords(e),s=Date.now();return {kind:"card_chats",cardId:e,sentAt:new Date(s).toISOString(),sentAtMs:s,messages:n.map(r=>({role:String(r.role||"system"),text:String(r.text||""),files:Array.isArray(r.files)?r.files:[]})),receiving:t,processing:await h.getChatProcessing(e)}}async function i(e,t=true){let n={kind:"notification-batch",notifications:[await u(e,t)]};for(let[s,r]of o.entries())r.subscribedChatCardIds.has(e)&&f(s,n);}function C(){c().length>0||(b&&(clearInterval(b),b=null),a.clear(),d.clear());}function p(){if(b)return;let e=async()=>{let t=c();if(t.length===0){C();return}let n=new Set(t);for(let s of Array.from(a.keys()))n.has(s)||a.delete(s);for(let s of Array.from(d.keys()))n.has(s)||d.delete(s);for(let s of t)await l(s)&&await i(s,true);};e(),b=setInterval(()=>{e();},1e3);}async function v(e,t){let n=o.get(e);if(!n)return false;n.subscribedChatCardIds.add(t);let{cursor:s}=await h.readChatAfter(t,null);return a.set(t,s),d.set(t,await h.getChatProcessing(t)),p(),f(e,{kind:"notification-batch",notifications:[await u(t,true)]}),true}function R(e,t){let n=o.get(e);return n?(n.subscribedChatCardIds.delete(t),c().includes(t)||(a.delete(t),d.delete(t)),C(),true):false}function g(e){if(!e||typeof e!="object")return false;let t=e.kind;return t==="card_chats"||t==="chat_messages"}function S(e){if(!e||e.length===0)return;let t=[],n=new Set;for(let s of e)g(s)&&typeof s.cardId=="string"?n.add(String(s.cardId)):t.push(s);if(t.length>0){let s={kind:"notification-batch",notifications:t};for(let r of o.keys())f(r,s);}for(let s of n)i(s,true);}return {size:()=>o.size,has:e=>o.has(e),get:e=>o.get(e),buildFrame:m,flushTransport:y,register:P,disconnect:I,writeFrame:f,subscribeChat:v,unsubscribeChat:R,broadcastNotificationBatch:S,broadcastCardChats:i}}function A(h){let{sseHub:o,corsHeaders:a,json:d,buildPublishedRuntimePayload:k,onSseClientConnected:b,onChannelSubscribed:m,onChannelUnsubscribed:y}=h;function I(f,c,l,u,i){if(!o.has(c)){d(f,404,{error:`SSE client not connected: ${c}`});return}i?m?.(c,l,u):y?.(c,l,u),d(f,200,{ok:true,clientId:c,channelName:l,...u.cardId?{cardId:u.cardId}:{},subscribed:i});}async function P(f,c,l,u){let i=u?.oneShot===true,C=!i&&l?o.get(l):null,p=C?new Set(C.subscribedChatCardIds):new Set;c.writeHead(200,{...a,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),o.flushTransport(c);let v=await k(),R=o.buildFrame(v);if(c.write(R),i){c.end();return}if(!l)throw new Error("clientId is required for streaming SSE");o.register(l,c,p);try{b?.(l,S=>{o.writeFrame(l,S);});}catch{}let g=setInterval(()=>{try{c.write(`: keepalive
5
+
6
+ `);}catch{}},15e3);f.on("close",()=>{clearInterval(g),o.disconnect(l,c);});}return {handleChannelSubscription:I,handleSse:P}}function T(h){let{apiBasePath:o,json:a,readJsonBody:d,initBoardAndSetup:k,bootstrapBoard:b,boardContexts:m,publishPersistedStateSnapshot:y,upsertCardsFromSource:I,sseHub:P}=h,{handleSse:f,handleChannelSubscription:c}=A(h);async function l(u,i,C){let p=u.method||"GET",v=C,R=v.pathname;try{if(p==="GET"&&R===`${o}/sse`){let n=v.searchParams.has("one-shot");await k();let s=String(v.searchParams.get("clientId")||"").trim();if(!n&&!s)return a(i,400,{error:"clientId query param is required for SSE"}),!0;if(await f(u,i,s||void 0,{oneShot:n}),n)return !0;for(let r=0;r<m.length;r++)await y(m[r]),await I(m[r],r),await y(m[r]);return !0}let g=R.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(o)}/cards/([^/]+)/chats/subscribe-sse$`));if(p==="POST"&&g){await b();let n=decodeURIComponent(g[1]),s=await d(u),r=typeof s?.clientId=="string"?s.clientId.trim():"";return r?await P.subscribeChat(r,n)?(a(i,200,{ok:!0,clientId:r,cardId:n,subscribed:!0}),!0):(a(i,404,{error:`SSE client not connected: ${r}`}),!0):(a(i,400,{error:"clientId is required"}),!0)}let S=R.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(o)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(p==="POST"&&S){await b();let n=decodeURIComponent(S[1]),s=await d(u),r=typeof s?.clientId=="string"?s.clientId.trim():"";return r?P.unsubscribeChat(r,n)?(a(i,200,{ok:!0,clientId:r,cardId:n,subscribed:!1}),!0):(a(i,404,{error:`SSE client not connected: ${r}`}),!0):(a(i,400,{error:"clientId is required"}),!0)}let e=R.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(o)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&e){await b();let n=decodeURIComponent(e[1]),s=e[2]==="subscribe",r=await d(u),w=typeof r?.clientId=="string"?r.clientId.trim():"";return w?(c(i,w,n,{},s),!0):(a(i,400,{error:"clientId is required"}),!0)}let t=R.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(o)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&t){await b();let n=decodeURIComponent(t[1]),s=decodeURIComponent(t[2]),r=t[3]==="subscribe",w=await d(u),H=typeof w?.clientId=="string"?w.clientId.trim():"";return H?(c(i,H,s,{cardId:n},r),!0):(a(i,400,{error:"clientId is required"}),!0)}return !1}catch(g){let S=g?.statusCode||500;return a(i,S,{error:String(g?.message||g)}),true}}return {handleWatchersRoutes:l,handleSse:f,handleChannelSubscription:c}}exports.a=D;exports.b=T;//# sourceMappingURL=chunk-IQIZA7TN.cjs.map
7
+ //# sourceMappingURL=chunk-IQIZA7TN.cjs.map
@@ -0,0 +1,45 @@
1
+ import {spawnSync}from'child_process';import*as f from'fs';import f__default from'fs';import {createRequire}from'module';import*as u from'path';import u__default from'path';import {fileURLToPath,pathToFileURL}from'url';var v=new Map;function X(e,r){let o=String(e||"").trim();if(!o)throw new Error("registerInProcessBoardWorkerCallback: key is required");v.set(o,r);}function Y(e){let r=String(e||"").trim();r&&v.delete(r);}async function B(e,r){let o=String(r||"").trim();if(!o)throw new Error("in-process-loop callback requires a non-empty handler key");let t=v.get(o);if(!t)throw new Error(`in-process-loop callback handler not registered: ${o}`);let n=await t(e);if(n&&n.status&&n.status!=="success")throw new Error(n.error||`in-process-loop callback failed with status: ${n.status}`)}function j(e,r,o){q(N(e),JSON.stringify({tool:"webhook.source-fetch-done",args:{token:r,ref:o}}));}function H(e,r,o){q(N(e),JSON.stringify({tool:"webhook.source-fetch-failed",args:{token:r,reason:o}}));}function N(e){return String(e||"").replace(/\/+$/,"")}function q(e,r){let o=`
2
+ const rawUrl = ${JSON.stringify(e)};
3
+ const rawBody = ${JSON.stringify(r)};
4
+ const u = new URL(rawUrl);
5
+ const {request} = require(u.protocol === 'https:' ? 'https' : 'http');
6
+ const h = { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(rawBody) };
7
+ const req = request({hostname:u.hostname,port:u.port,path:u.pathname+u.search,method:'POST',headers:h}, (res) => {
8
+ let responseBody = '';
9
+ res.setEncoding('utf8');
10
+ res.on('data', chunk => { responseBody += chunk; });
11
+ res.on('end', () => {
12
+ const code = res.statusCode || 500;
13
+ if (code < 200 || code >= 300) {
14
+ const msg = responseBody.trim() || res.statusMessage || ('HTTP ' + code);
15
+ process.stderr.write(msg);
16
+ process.exit(1);
17
+ }
18
+ });
19
+ });
20
+ req.on('error', e => { process.stderr.write(e.message); process.exit(1); });
21
+ req.write(rawBody);
22
+ req.end();
23
+ `,t=spawnSync(process.execPath,["-e",o],{encoding:"utf-8",windowsHide:true});if(t.status!==0)throw new Error(`http-post failed: ${t.stderr?.trim()}`)}var oe=createRequire(import.meta.url);function O(e,r,o){L(e,["source-data-fetched","--ref",o,"--token",r],"reportComplete");}function A(e,r,o){L(e,["source-data-fetch-failure","--token",r,"--reason",o],"reportFailed");}function L(e,r,o){let t=te(e.whatToRun),{cmd:n,args:s}=ie(t),a=ne(e),i=se(e),p=ae(e),c=spawnSync(n,[...s,...r,...i?["--board-runtime-store-ref",i]:[],...p?["--queue-store-ref",p]:[],...a?["--notify-channel",a]:[]],{encoding:"utf-8",windowsHide:true});if(c.status!==0)throw new Error(`${o}: board CLI exited ${c.status}: ${c.stderr?.trim()}`)}function te(e){let r=ce(e);if(r.kind==="yaml-flow-cli"){let o=u.basename(r.value.trim());if(!o)throw new Error(`Invalid yaml-flow-cli ref: expected non-empty cli file name, got ${JSON.stringify(r.value)}`);let t=u.dirname(oe.resolve("yaml-flow/package.json")),n=o.replace(/\.[^.]+$/,""),s=u.join(t,"cli","bundled",`${n}.mjs`);if(f.existsSync(s))return s;let a=u.join(t,"cli","node",o);if(f.existsSync(a))return a;throw new Error(`Invalid yaml-flow-cli ref: could not find ${o} under cli/bundled or cli/node in ${t}`)}return r.value}function ne(e){let r=e.extra?.notifyChannel;return typeof r=="string"&&r.length>0?r:void 0}function se(e){let r=e.extra?.boardRuntimeStoreRef;return typeof r=="string"&&r.length>0?r:void 0}function ae(e){let r=e.extra?.queueStoreRef;return typeof r=="string"&&r.length>0?r:void 0}function ie(e){if(!e.endsWith(".ts"))return {cmd:process.execPath,args:[e]};let r=u.dirname(e),o=[];for(let n=1;n<=5;n++){let s=u.join(r,...Array(n).fill(".."),"node_modules");o.push(u.join(s,"tsx","dist","cli.mjs")),o.push(u.join(s,".bin","tsx"));}let t=o.find(n=>f.existsSync(n));return t?{cmd:process.execPath,args:[t,e]}:{cmd:"npx",args:["tsx",e]}}function ce(e){if(!e.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${e}`);let r=e.slice(4),o=r.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-r.length%4)%4),t;try{t=JSON.parse(Buffer.from(o,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let n=t;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:n.kind,value:n.value}}var I=new Map;function ue(e,r){let o=String(e||"").trim();if(!o)throw new Error("registerInProcessBoardWorkerInvoke: key is required");I.set(o,r);}function de(e){let r=String(e||"").trim();r&&I.delete(r);}async function T(e,r){let o=String(r||"").trim();if(!o)throw new Error("in-process board-worker invoke requires a non-empty handler key");let t=I.get(o);if(!t)throw new Error(`in-process board-worker invoke handler not registered: ${o}`);return await t(e)}var M=createRequire(import.meta.url),W=u__default.dirname(fileURLToPath(import.meta.url));function J(e){if(!e.startsWith("b64:"))throw new Error(`Invalid ref format (expected b64:<base64url(json)>): ${e}`);let r=e.slice(4),o=r.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-r.length%4)%4),t;try{t=JSON.parse(Buffer.from(o,"base64").toString("utf8"));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let n=t;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:n.kind,value:n.value}}function g(e){return `b64:${Buffer.from(JSON.stringify(e),"utf8").toString("base64").replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}`}function ke(){return {read(e){if(!f__default.existsSync(e))return null;try{return f__default.readFileSync(e,"utf-8")}catch{return null}},write(e,r){f__default.mkdirSync(u__default.dirname(e),{recursive:true}),f__default.writeFileSync(e,r,"utf-8");}}}function ze(e){if(e.kind==="fs-path")return ke();throw new Error(`Unsupported storage kind: "${e.kind}". Supported kinds: fs-path`)}function me(){let e=u__default.resolve(W,"./jsonata-sync.cjs");if(f__default.existsSync(e))return e;let r=u__default.resolve(W,"../../card-compute/jsonata-sync.cjs");return f__default.existsSync(r)?r:u__default.resolve(W,"../../../lib/jsonata-sync.cjs")}var ge=M(me());function he(e){e.registerFunction?.("fsPathRef",r=>g({kind:"fs-path",value:String(r)}),"<s:s>");}function l(e){return typeof e=="string"?J(e).value:e.value}function x(e){return e.howToRun==="local-node"||e.howToRun==="local-process"}function z(e){return e.howToRun==="http:post"||e.howToRun==="http:get"}function S(e){return e.howToRun==="in-process-loop"}function F(e){return {...e,whatToRun:typeof e.whatToRun=="string"?e.whatToRun:g(e.whatToRun)}}function we(e){return typeof e.whatToRun=="string"?e:{...e,whatToRun:g(e.whatToRun)}}function P(e,r){if(!e||typeof e!="object")throw new Error(`[board-worker-adapter] Step "${r}" returned a non-object result.`);let o=e,t=o.result??o.status;if(typeof t=="string"&&t.trim()){let n=o.data&&typeof o.data=="object"&&!Array.isArray(o.data)?{...o.data}:{},s=typeof o.error=="string"?o.error:void 0;return s&&!Object.prototype.hasOwnProperty.call(n,"error")&&(n.error=s),s?{result:t,data:n,error:s}:{result:t,data:n}}return {result:"success",data:{...o}}}function R(e){return {result:"failure",data:{error:e},error:e}}function k(e,r,o){try{let t=ge(e);return he(t),t.evaluate(r)}catch(t){let n=t instanceof Error?t.message:String(t);throw new Error(`[${o}] JSONata evaluation failed for "${e}": ${n}`)}}function K(e,r,o){if(!e||typeof e!="object")return {};let t={};if(Array.isArray(e.cmdTemplate)&&(t.cmdArgs=e.cmdTemplate.map(n=>String(k(n,r,`${o}.cmdTemplate`)))),typeof e.stdinTemplate=="string"&&(t.stdin=k(e.stdinTemplate,r,`${o}.stdinTemplate`)),typeof e.urlTemplate=="string"&&(t.url=String(k(e.urlTemplate,r,`${o}.urlTemplate`))),typeof e.headerTemplate=="string"){let n=k(e.headerTemplate,r,`${o}.headerTemplate`);if(!n||typeof n!="object"||Array.isArray(n))throw new Error(`[${o}.headerTemplate] expected an object result`);t.headers=n;}return typeof e.bodyTemplate=="string"&&(t.body=k(e.bodyTemplate,r,`${o}.bodyTemplate`)),t}function V(e){let r=String(e||"").trim();if(!r)return {};try{return JSON.parse(r)}catch{return {stdout:r}}}async function Fe(e,r){let o=U(e,r);if(x(e))return _(e,o);if(e.howToRun==="http:post")return ve(l(e.whatToRun),o);if(S(e))return T(o,l(e.whatToRun));throw new Error(`invokeBoardWorker: unsupported via.howToRun "${e.howToRun}"`)}function Ke(e,r){let o=U(e,r);if(x(e))return _(e,o);if(e.howToRun==="http:post")return Be(l(e.whatToRun),o);throw new Error(`invokeBoardWorkerSync: unsupported via.howToRun "${e.howToRun}"`)}function Re(e){let r=Q(e.whatToRun);switch(e.howToRun){case "local-node":return {command:process.execPath,baseArgs:[r]};case "local-python":return {command:process.platform==="win32"?"python":"python3",baseArgs:[r]};case "local-process":return {command:r,baseArgs:[]};default:throw new Error(`invokeStepMachineExecutionRef: unsupported local transport "${e.howToRun}"`)}}function $(e,r,o){if(!e||typeof e!="object")return r;let t={output:r},n=r.result,s=r.data,a=r.error;if(typeof e.resultExpr=="string"){let i=k(e.resultExpr,t,`${o}.resultExpr`);if(typeof i!="string"||!i.trim())throw new Error(`[${o}.resultExpr] expected a non-empty string result`);n=i;}if(typeof e.dataTemplate=="string"){let i=k(e.dataTemplate,t,`${o}.dataTemplate`);if(!i||typeof i!="object"||Array.isArray(i))throw new Error(`[${o}.dataTemplate] expected an object result`);s=i;}if(typeof e.errorExpr=="string"){let i=k(e.errorExpr,t,`${o}.errorExpr`);a=i!=null?String(i):void 0;}return a!==void 0?{result:n,data:s,error:a}:{result:n,data:s}}function ye(e,r,o,t){let n=o.label||"invokeStepMachineExecutionRef",s=K(e.argsMassaging,t,n),{command:a,baseArgs:i}=Re(e),p=s.stdin!==void 0?s.stdin:r,c=spawnSync(a,[...i,...s.cmdArgs||[]],{encoding:"utf-8",windowsHide:true,...p!==void 0?{input:JSON.stringify(p)}:{},...typeof o.timeoutMs=="number"&&o.timeoutMs>0?{timeout:Math.floor(o.timeoutMs)}:{},...e.howToRun==="local-process"&&process.platform==="win32"?{shell:true}:{}});if(c.error){let m=c.error instanceof Error?c.error.message:String(c.error);return R(m)}if(typeof c.status=="number"&&c.status!==0)return R(c.stderr?.trim()||`process exited ${c.status}`);let h=P(V(c.stdout||""),n);return e.outputTransforms&&h.result==="success"?$(e.outputTransforms,h,n):h}async function xe(e,r,o,t){let n=o.label||"invokeStepMachineExecutionRef",s=K(e.argsMassaging,t,n),a=s.url||l(e.whatToRun),i={"Content-Type":"application/json",...s.headers||{}},p=typeof o.timeoutMs=="number"&&o.timeoutMs>0?Math.floor(o.timeoutMs):0,c=p>0?new AbortController:null,h=c?setTimeout(()=>c.abort(),p):null;try{let m=s.body!==void 0?s.body:r,w=await fetch(a,{method:e.howToRun==="http:get"?"GET":"POST",headers:i,...e.howToRun==="http:get"?{}:{body:JSON.stringify(m)},...c?{signal:c.signal}:{}}),C=await w.text().catch(()=>"");if(!w.ok)return R(`HTTP ${w.status}: ${C||w.statusText||"request failed"}`);let b=P(V(C),n);return e.outputTransforms&&b.result==="success"?$(e.outputTransforms,b,n):b}catch(m){let w=m instanceof Error?m.message:String(m);return R(w)}finally{h&&clearTimeout(h);}}async function Ve(e,r,o={}){try{let t=we(e),n={...r&&typeof r=="object"&&!Array.isArray(r)?r:{},whatToRun:l(t.whatToRun),...t.extra?{extra:t.extra}:{}};if(t.howToRun==="local-node"||t.howToRun==="local-python"||t.howToRun==="local-process")return ye(t,r,o,n);if(t.howToRun==="http:post"||t.howToRun==="http:get")return xe(t,r,o,n);if(t.howToRun==="in-process-loop"){let s=await T(r,l(t.whatToRun)),a=P(s,o.label||"invokeStepMachineExecutionRef");return t.outputTransforms&&a.result==="success"?$(t.outputTransforms,a,o.label||"invokeStepMachineExecutionRef"):a}return R(`invokeStepMachineExecutionRef: unsupported howToRun "${t.howToRun}"`)}catch(t){let n=t instanceof Error?t.message:String(t);return R(n)}}function U(e,r){return {...r,...r.extra?{}:e.extra?{extra:e.extra}:{}}}function _(e,r){let o=Q(e.whatToRun),{cmd:t,args:n}=Ie(o),s=be(r),a=spawnSync(t,[...n,...s],{encoding:"utf-8",windowsHide:true,...typeof r.input=="string"?{input:r.input}:{}});if(a.status!==0){let i=new Error(`invokeBoardWorker: board worker exited ${a.status}: ${a.stderr?.trim()||"unknown error"}`);throw i.stdout=a.stdout??"",i.stderr=a.stderr??"",i}return G(a.stdout)}function be(e){let r=typeof e.subcommand=="string"?e.subcommand.trim():"";if(!r)throw new Error("invokeBoardWorker: request.subcommand is required");let o=[r];return typeof e.inRef=="string"&&e.inRef.trim()&&o.push("--in-ref",e.inRef.trim()),typeof e.outRef=="string"&&e.outRef.trim()&&o.push("--out-ref",e.outRef.trim()),typeof e.errRef=="string"&&e.errRef.trim()&&o.push("--err-ref",e.errRef.trim()),e.extra&&typeof e.extra=="object"&&!Array.isArray(e.extra)&&o.push("--extra",Buffer.from(JSON.stringify(e.extra)).toString("base64")),o}async function ve(e,r){return D(e,r)}function Be(e,r){return D(e,r)}function D(e,r){let o=`
24
+ const rawUrl = ${JSON.stringify(e)};
25
+ const rawBody = ${JSON.stringify(JSON.stringify(r))};
26
+ const u = new URL(rawUrl);
27
+ const mod = require(u.protocol === 'https:' ? 'https' : 'http');
28
+ const req = mod.request({ hostname: u.hostname, port: u.port, path: u.pathname + u.search, method: 'POST', headers: { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(rawBody) } }, (res) => {
29
+ let body = '';
30
+ res.setEncoding('utf8');
31
+ res.on('data', (chunk) => { body += chunk; });
32
+ res.on('end', () => {
33
+ const code = res.statusCode || 500;
34
+ if (code < 200 || code >= 300) {
35
+ process.stderr.write(body.trim() || res.statusMessage || ('HTTP ' + code));
36
+ process.exit(1);
37
+ }
38
+ process.stdout.write(body);
39
+ });
40
+ });
41
+ req.on('error', (err) => { process.stderr.write(err.message); process.exit(1); });
42
+ req.write(rawBody);
43
+ req.end();
44
+ `,t=spawnSync(process.execPath,["-e",o],{encoding:"utf-8",windowsHide:true});if(t.status!==0)throw new Error(`invokeBoardWorker: http-post failed: ${t.stderr?.trim()||"unknown error"}`);return G(t.stdout)}function G(e){let r=String(e||"").trim();if(!r)return {};try{return JSON.parse(r)}catch{return {stdout:r}}}function Q(e){let r=typeof e=="string"?J(e):e;if(r.kind==="yaml-flow-cli"){let o=u__default.basename(r.value.trim());if(!o)throw new Error(`Invalid yaml-flow-cli ref: expected non-empty cli file name, got ${JSON.stringify(r.value)}`);let t=u__default.dirname(M.resolve("yaml-flow/package.json")),n=o.replace(/\.[^.]+$/,""),s=u__default.join(t,"cli","bundled",`${n}.mjs`);if(f__default.existsSync(s))return s;let a=u__default.join(t,"cli","node",o);if(f__default.existsSync(a))return a;throw new Error(`Invalid yaml-flow-cli ref: could not find ${o} under cli/bundled or cli/node in ${t}`)}return r.value}function Ie(e){if(!e.endsWith(".ts"))return {cmd:process.execPath,args:[e]};let r=u__default.dirname(e),o=[];for(let n=1;n<=5;n++){let s=u__default.join(r,...Array(n).fill(".."),"node_modules");o.push(u__default.join(s,"tsx","dist","cli.mjs")),o.push(u__default.join(s,".bin","tsx"));}let t=o.find(n=>f__default.existsSync(n));return t?{cmd:process.execPath,args:[t,e]}:{cmd:"npx",args:["tsx",e]}}function Ue(e,r){let o=u__default.isAbsolute(e)?e:u__default.resolve(process.cwd(),e);return {meta:"task-executor",howToRun:"local-node",whatToRun:g({kind:"fs-path",value:o}),...r?{extra:r}:{}}}async function _e(e){let r=u__default.isAbsolute(e)?e:u__default.resolve(process.cwd(),e),o=await import(pathToFileURL(r).href),t=typeof o.executeTaskExecutorRequest=="function"?o.executeTaskExecutorRequest:typeof o.executeBoardWorkerRequest=="function"?o.executeBoardWorkerRequest:void 0;if(typeof t!="function")throw new Error(`Immediate board worker module must export executeTaskExecutorRequest(request) or executeBoardWorkerRequest(request): ${r}`);return t}function De(e,r={}){return async({subcommand:o,input:t,timeoutMs:n,extra:s})=>{if(typeof o!="string"||!o.trim())throw new Error("Immediate board worker hook requires subcommand");let a={...r,...s&&typeof s=="object"&&!Array.isArray(s)?s:{}};return await e({subcommand:o,...t!==void 0?{input:t}:{},...n!==void 0?{timeoutMs:n}:{},...Object.keys(a).length>0?{extra:a}:{}})}}function Ge(e,r){let{token:o,via:t}=e;if(x(t)){O(F(t),o,g(r));return}if(z(t)){j(l(t.whatToRun),o,g(r));return}if(S(t)){B({token:o,outcome:"success",ref:g(r)},l(t.whatToRun));return}throw new Error(`reportComplete: unsupported via.howToRun "${t.howToRun}"`)}function Qe(e,r){let{token:o,via:t}=e;if(x(t)){A(F(t),o,r);return}if(z(t)){H(l(t.whatToRun),o,r);return}if(S(t)){B({token:o,outcome:"failure",reason:r},l(t.whatToRun));return}throw new Error(`reportFailed: unsupported via.howToRun "${t.howToRun}"`)}export{X as a,Y as b,ue as c,de as d,J as e,g as f,ze as g,Fe as h,Ke as i,Ve as j,Ue as k,_e as l,De as m,Ge as n,Qe as o};//# sourceMappingURL=chunk-J4MHQ7JF.js.map
45
+ //# sourceMappingURL=chunk-J4MHQ7JF.js.map
@@ -0,0 +1,2 @@
1
+ 'use strict';function d(a){return String(a).replace(/[^a-zA-Z0-9_-]/g,"_")}function c(a){let e=a.payload??{};return {id:a.id,role:typeof e.role=="string"?e.role:"system",text:typeof e.text=="string"?e.text:"",files:Array.isArray(e.files)?e.files:[],turn:typeof e.turn=="string"?e.turn:"",updated_at:typeof e.updated_at=="string"?e.updated_at:""}}function p(a,e){let o=t=>`chats/${d(t)}/processing`,r=t=>`chats/${d(t)}/config`;return {append(t,n,i,s=[],g=""){return a(t).append({role:n,text:i,files:s,turn:g,updated_at:new Date().toISOString()}).id},readAll(t){return a(t).readAll().map(c)},readAfter(t,n){let i=a(t).readAfter(n);return {records:i.entries.map(c),cursor:i.newCursor}},clear(t){a(t).clear?.();},setProcessing(t,n){n?e.write(o(t),true):e.delete(o(t));},isProcessing(t){return e.read(o(t))===true},getConfig(t){return e.read(r(t))??{}},setConfig(t,n){let i=e.read(r(t))??{};e.write(r(t),{...i,...n});}}}function f(a,e){let o=t=>`chats/${d(t)}/processing`,r=t=>`chats/${d(t)}/config`;return {async append(t,n,i,s=[],g=""){return (await a(t).append({role:n,text:i,files:s,turn:g,updated_at:new Date().toISOString()})).id},async readAll(t){return (await a(t).readAll()).map(c)},async readAfter(t,n){let i=await a(t).readAfter(n);return {records:i.entries.map(c),cursor:i.newCursor}},async clear(t){await a(t).clear?.();},async setProcessing(t,n){n?await e.write(o(t),true):await e.delete(o(t));},async isProcessing(t){return await e.read(o(t))===true},async getConfig(t){return await e.read(r(t))??{}},async setConfig(t,n){let i=await e.read(r(t))??{};await e.write(r(t),{...i,...n});}}}function u(){let a=globalThis.crypto;return typeof a?.randomUUID=="function"?String(a.randomUUID()):`id-${Date.now()}-${Math.random().toString(36).slice(2)}`}function S(){let a=new Map,e=new Map;function o(r){return a.has(r)||a.set(r,[]),a.get(r)}return {append(r,t,n,i=[],s=""){let g={id:u(),role:t,text:n,files:i,turn:s,updated_at:new Date().toISOString()};return o(r).push(g),g.id},readAll(r){return o(r).slice()},readAfter(r,t){let n=o(r);if(!t)return {records:n.slice(),cursor:n.length>0?n[n.length-1].id:null};let i=n.findIndex(g=>g.id===t),s=i===-1?n.slice():n.slice(i+1);return {records:s,cursor:s.length>0?s[s.length-1].id:t}},clear(r){a.set(r,[]);},setProcessing(r,t){t?e.set(`p:${r}`,true):e.delete(`p:${r}`);},isProcessing(r){return e.get(`p:${r}`)===true},getConfig(r){return e.get(`c:${r}`)??{}},setConfig(r,t){let n=e.get(`c:${r}`)??{};e.set(`c:${r}`,{...n,...t});}}}exports.a=p;exports.b=f;exports.c=S;//# sourceMappingURL=chunk-MCPADH33.cjs.map
2
+ //# sourceMappingURL=chunk-MCPADH33.cjs.map
@@ -0,0 +1,2 @@
1
+ 'use strict';function m(){return new Date().toISOString()}function p(e){return new TextEncoder().encode(e).byteLength}function A(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function S(e){let i=String(e||"").match(/^(\d+)[-_]/);return i?parseInt(i[1],10):0}function w(e){let i=String(e||"").trim();if(!i)return "upload.bin";let n=Math.max(i.lastIndexOf("/"),i.lastIndexOf("\\"));return (n>=0?i.slice(n+1):i)||"upload.bin"}function h(e){return String(e||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function k(e){if(!e||e===".")return "";let i=String(e).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return i?`.${i}`:""}function F(e){let i=w(e),n=i.lastIndexOf(".");return n<=0||n===i.length-1?{stem:i,ext:""}:{stem:i.slice(0,n),ext:i.slice(n)}}function z(e){let i=e.lastIndexOf("/");return i>=0?e.slice(i+1):e}function I(e){function i(n){let s=e.stat?A(e.stat(n)):null;if(s)return s;if(!e.exists(n))return null;let t=e.read(n);return t===null?{key:n}:{key:n,size:p(t)}}return {exists(n){return e.exists(n)},putText(n,s,t="text/plain; charset=utf-8"){e.write(n,s);let a=i(n)??{key:n};return a.contentType=t,a.updatedAt=a.updatedAt??m(),a.size=a.size??p(s),a},putBytes(n,s,t="application/octet-stream"){if(e.writeBytes)e.writeBytes(n,s);else {let o=JSON.stringify({__kind:"bytes-array",data:[...s]});e.write(n,o);}let a=i(n)??{key:n};return a.contentType=t,a.updatedAt=a.updatedAt??m(),a.size=a.size??s.byteLength,a},getText(n){let s=e.read(n);if(s===null){if(!e.readBytes)return null;let t=e.readBytes(n);return t===null?null:Buffer.from(t).toString("utf-8")}try{let t=JSON.parse(s);if(t&&t.__kind==="bytes-array"&&Array.isArray(t.data))return new TextDecoder("utf-8").decode(new Uint8Array(t.data))}catch{}return s},getBytes(n){if(e.readBytes){let t=e.readBytes(n);if(t!==null)return t}let s=e.read(n);if(s===null)return null;try{let t=JSON.parse(s);if(t&&t.__kind==="bytes-array"&&Array.isArray(t.data))return new Uint8Array(t.data)}catch{}return new TextEncoder().encode(s)},head:i,list(n=""){return e.listKeys(n).map(s=>i(s)??{key:s}).sort((s,t)=>s.key.localeCompare(t.key))},remove(n){e.remove(n);}}}function C(e){function i(t,a){let o=0,u=[];Array.isArray(a)&&u.push(...a);for(let r of e.list(`${t}/`))u.push(z(r.key));for(let r of u){let l=S(r);Number.isFinite(l)&&l>o&&(o=l);}return o+1}function n(t,a,o){let u=Number(o?.maxLen||32),{stem:r,ext:l}=F(t),y=k(l),x=h(r),f=`${String(a).padStart(3,"0")}-`,d=y,g=u-f.length-d.length;g<1&&(d="",g=u-f.length);let _=x.slice(0,Math.max(1,g)),c=`${f}${_}${d}`;return c.length>u&&(c=c.slice(0,u).replace(/\.$/,"")),c}function s(t,a,o){let u=i(t,o?.seedNames),r=n(a,u,{maxLen:o?.maxLen});for(;e.exists(`${t}/${r}`);)u+=1,r=n(a,u,{maxLen:o?.maxLen});return r}return {nextSerial:i,buildStoredName:n,allocateStoredName:s}}function B(){function e(t,a){if(!Array.isArray(t))return [];let o=[];for(let u of t){if(!u||typeof u!="object")continue;let r=u;typeof r.stored_name=="string"&&o.push({name:typeof r.name=="string"?r.name:r.stored_name,stored_name:r.stored_name,size:typeof r.size=="number"&&Number.isFinite(r.size)?r.size:null,mime_type:typeof r.mime_type=="string"?r.mime_type:null,uploaded_at:typeof r.uploaded_at=="string"?r.uploaded_at:a||null,chat:r.chat===true});}return o}function i(t){return !t||typeof t!="object"?[]:e(t.files,void 0)}function n(t,a){let o=i(t);if(a.length===0)return t.files=o,o;let u=new Set(o.map(r=>r.stored_name));for(let r of a)u.has(r.stored_name)||(o.push(r),u.add(r.stored_name));return t.files=o,o}function s(t,a,o){let u=i(t);if(!Number.isInteger(a)||a<0||a>=u.length)return {ok:false,reason:"index_out_of_range"};let r=u[a];return !r||!r.stored_name?{ok:false,reason:"missing_stored_name"}:o&&o!==r.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:r}}return {read:i,normalizeIncoming:e,merge:n,resolve:s}}exports.a=I;exports.b=C;exports.c=B;//# sourceMappingURL=chunk-NBJTYAYN.cjs.map
2
+ //# sourceMappingURL=chunk-NBJTYAYN.cjs.map
@@ -0,0 +1,3 @@
1
+ 'use strict';var chunk7JVHYHT2_cjs=require('./chunk-7JVHYHT2.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkIXZG74EW_cjs=require('./chunk-IXZG74EW.cjs'),chunkYMEIPKLW_cjs=require('./chunk-YMEIPKLW.cjs');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:chunkVQCIOKJV_cjs.a({kind:"http-url",value:String(e||"").trim()})})}function lr(e){return Ne({meta:"board-live-cards",howToRun:"in-process-loop",whatToRun:chunkVQCIOKJV_cjs.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:chunkVQCIOKJV_cjs.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 chunk7JVHYHT2_cjs.c(n.trim())},writeTaskExecutorRef(n){e.write("task-executor",chunk7JVHYHT2_cjs.b(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=chunkG4XXRHL2_cjs.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,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&&chunkIXZG74EW_cjs.a.runSync(R,{sourcesData:b}),(d??n.outputStore.writeComputedValues.bind(n.outputStore))(q,R.computed_values??{});let O={...w},j=chunkIXZG74EW_cjs.a.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:chunkVQCIOKJV_cjs.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]=chunkIXZG74EW_cjs.a.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:chunkVQCIOKJV_cjs.a(e),enrichedCard:O,callbackToken:c.callbackToken,rqt:$}}),a(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=t.callbackTransport,o=t.onWarn??(()=>{}),d=chunkVQCIOKJV_cjs.a(e),u=n.boardRuntimeStoreRef,c=n.scratchStoreRef,C=n.taskExecutorRef,w=n.chatHandlerFlow;function q(){if(!u)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return u}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()),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());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())),x=()=>bt(ee),G=()=>yt(t.journalAdapterForRef(q())),K=()=>He(Y(),o),p=()=>{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(){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(),g=chunkG4XXRHL2_cjs.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(),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=chunkG4XXRHL2_cjs.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:chunkG4XXRHL2_cjs.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:chunkVQCIOKJV_cjs.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:chunkVQCIOKJV_cjs.a(We),deliveryToken:Ee,outputFile:z.outputFile,cardId:_},Ut=It({cbk:y.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.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:chunkVQCIOKJV_cjs.a(e),callback:a.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:chunkVQCIOKJV_cjs.a(Te),deliveryToken:z,outputFile:L.outputFile,cardId:_});}let le=It({cbk:y.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.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:chunkVQCIOKJV_cjs.a(e),callback:a.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:chunkVQCIOKJV_cjs.a(e)},`process-accumulated:${chunkVQCIOKJV_cjs.a(e)}`):s.enqueue({boardRef:chunkVQCIOKJV_cjs.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(),{events:g}=G().readEntriesAfterCursor(l.lastDrainedJournalId);g.length<=0||P();},r=await chunkVQCIOKJV_cjs.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=s.params?.boardRuntimeStoreRef,!u)return S("init requires params.boardRuntimeStoreRef \u2014 pass the board runtime store ref here");if(!m()){let W=chunkG4XXRHL2_cjs.a(Ge);I({lastDrainedJournalId:"",graph:chunkG4XXRHL2_cjs.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=s.params?.scratchStoreRef,!c)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),D.writeCardStoreRef(r),D.writeOutputsStoreRef(l),D.writeQueueStoreRef(g),D.writeFetchedSourcesStoreRef(A),D.writeChatStoreRef(F),D.writeArtifactsStoreRef(Q);try{p().writeStatusSnapshot(Pe(d,chunkG4XXRHL2_cjs.q(b().graph)));}catch{}return E()}catch(r){return T(r)}}function me(s){try{let r=p().readStatusSnapshot();if(!r){r=Pe(d,chunkG4XXRHL2_cjs.q(b().graph));try{p().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=chunkYMEIPKLW_cjs.a(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,chunkVQCIOKJV_cjs.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??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??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??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().readDataObject(r);return E(l)}catch(r){return T(r)}}function $t(s){try{return E(p().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().readComputedValues(r);return E(l)}catch(r){return T(r)}}function Nt(s){try{return E(p().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 chunkVQCIOKJV_cjs.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={...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)}),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=chunkVQCIOKJV_cjs.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=chunkIXZG74EW_cjs.a.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=chunkIXZG74EW_cjs.a.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=chunkIXZG74EW_cjs.a.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
+ exports.a=pr;exports.b=ft;exports.c=gr;exports.d=dt;exports.e=cr;exports.f=lr;exports.g=fr;exports.h=gt;exports.i=Xt;exports.j=Wt;exports.k=St;exports.l=He;exports.m=Oe;exports.n=Re;exports.o=vr;exports.p=kt;exports.q=Rt;exports.r=er;exports.s=ht;exports.t=Pe;exports.u=Ge;exports.v=xt;exports.w=Et;exports.x=Tt;exports.y=qr;exports.z=Pr;//# sourceMappingURL=chunk-NDAKMJQK.cjs.map
3
+ //# sourceMappingURL=chunk-NDAKMJQK.cjs.map
@@ -0,0 +1,2 @@
1
+ import {b,c as c$1}from'./chunk-ANKA7HEJ.js';import {b as b$1}from'./chunk-44L64VQ2.js';function c(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function l(e){return typeof e=="string"?e.startsWith("b64:")?b$1(e).value:e:e.value}function m(e){return {async enqueueRequest(t){return (await e.enqueue(t)).id},async leaseRequests(t){return (await e.lease(t)).map(r=>({...c(r),leaseToken:r.leaseToken,leaseExpiresAt:r.leaseExpiresAt}))},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,a){return e.nack(t,r,a)},async peekActive(){return (await e.peekActive()).map(c)},async peekDeadLetter(){return (await e.peekDeadLetter()).map(t=>({...c(t),reason:t.reason}))}}}function h(e){async function t(r){let a=await e.read(r);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}return {async readTaskExecutorRef(){let r=await t("task-executor");if(r?.trim())return c$1(r.trim())},writeTaskExecutorRef(r){return e.write("task-executor",b(r))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){return e.write("chat-handler-flow",r)},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){return e.write("board-runtime-store-ref",r)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){return e.write("card-store-ref",r)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){return e.write("outputs-store-ref",r)},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){return e.write("queue-store-ref",r)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){return e.write("scratch-store-ref",r)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){return e.write("chat-store-ref",r)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){return e.write("artifacts-store-ref",r)},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){return e.write("fetched-sources-store-ref",r)}}}function y(e){let t=e.callbackTransport,r=e.resolveBlob??(async o=>{let s=await e.blobStorage("").read(o.value);if(s==null)throw new Error(`Blob not found for ref ${o.kind}:${o.value}`);return s});async function a(o,s){if(o.howToRun==="queue-storage")return e.queueStoreRef?(await m(e.queueStorageForRef(e.queueStoreRef,"task-executor")).enqueueRequest({boardId:typeof o.extra?.boardId=="string"?o.extra.boardId:e.boardId,ref:o,args:s}),{dispatched:true}):{dispatched:false,error:"queue-storage dispatch requires queueStoreRef"};if(o.howToRun==="http:post"){let n=e.fetch??globalThis.fetch;if(!n)return {dispatched:false,error:"http:post dispatch requires fetch support"};let i=await n(l(o.whatToRun),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...s,...o.extra?{extra:o.extra}:{}})});if(!i.ok){let g=await i.text().catch(()=>"");return {dispatched:false,error:`HTTP ${i.status}: ${g}`}}return {dispatched:true}}return {dispatched:false,error:`Unsupported hosted async transport "${o.howToRun}"`}}return {kvStorage:e.kvStorage,kvStorageForRef:e.kvStorageForRef,blobStorage:e.blobStorage,blobStorageForRef:e.blobStorageForRef,chatStorageForRef:e.chatStorageForRef,queueStorageForRef:e.queueStorageForRef,scratchStorage:e.scratchStorage,scratchStorageForRef:e.scratchStorageForRef,archiveFactory:e.archiveFactory,archiveFactoryForRef:e.archiveFactoryForRef,journalStorage:e.journalStorage,journalStorageForRef:e.journalStorageForRef,lock:e.lock,get callbackTransport(){return t},set callbackTransport(o){t=o;},dispatchExecution:(o,s)=>e.dispatchExecution?.(o,s)??a(o,s),supportsDirectSourceOutput:e.supportsDirectSourceOutput,resolveBlob:r,hashFn:e.hashFn,genId:e.genId,requestProcessAccumulated:e.requestProcessAccumulated,publishBoardChangeNotifications:e.publishBoardChangeNotifications,warn:e.onWarn}}export{m as a,h as b,y as c};//# sourceMappingURL=chunk-NNSBBO5R.js.map
2
+ //# sourceMappingURL=chunk-NNSBBO5R.js.map
@@ -0,0 +1,2 @@
1
+ import {a,c,d,e,b,f}from'./chunk-O7NOHKVR.js';import {a as a$1}from'./chunk-FOFGEABN.js';import {b as b$1}from'./chunk-44L64VQ2.js';import {a as a$2}from'./chunk-35N7ONTH.js';function W(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function V(s){if(!s||typeof s!="object")return false;let e=s.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function H(s,e){if(!e||typeof e!="object")return;let n=e;if(n.kind==="notification-batch"&&Array.isArray(n.notifications)){for(let l of n.notifications)H(s,l);return}n.kind==="status"&&V(n.status)&&(s.status=n.status),n.kind==="computed_values"&&n.cardId&&(s.computedValues[n.cardId]=n.values),n.kind==="data_object"&&n.key&&(s.dataObjects[n.key]=n.payload),n.kind==="card_refreshed"&&n.cardId&&(s.cards[n.cardId]=n.card),n.kind==="card_removed"&&n.cardId&&(delete s.cards[n.cardId],delete s.computedValues[n.cardId]);}function j(s,e){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?Object.assign(new Error(s.error||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function B(s,e){return j(await s,e)}function D(s){let e=a(s,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let n=e.split(".");if(!(n.length>=2&&n[0]==="chat"&&n.every(h=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(h))))throw Object.assign(new Error("MCP tool only supports card private keys under chat.*"),{statusCode:400});return e}function q(s,e){let n=s.__private;for(let l of e.split(".")){if(!n||typeof n!="object"||Array.isArray(n)||!Object.prototype.hasOwnProperty.call(n,l))return {exists:false,value:null};n=n[l];}return {exists:true,value:n}}function Q(s){let{boardId:e,bootstrapBoard:n,sseHub:l,onChannelSubscribed:h,onChannelUnsubscribed:v,getMcpFacade:I,getMcpCardStoreFacade:r}=s;function C(d){let u=a(d,"board_id");if(!u)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(u!==e)throw Object.assign(new Error(`Unknown board_id: ${u}`),{statusCode:400})}function w(d){let u=a(d,"client_id");if(!u)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return u}function c(d){C(d);let u=w(d),a$1=a(d,"channel_name"),t=a(d,"card_id")||void 0;if(!a$1)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:u,channelName:a$1,...t?{cardId:t}:{}}}function g(d){C(d);let u=a(d,"card_id");if(!u)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:u}}async function b(d){await n();let{cardId:u}=g(d),a=w(d);if(!await l.subscribeChat(a,u))throw Object.assign(new Error(`SSE client not connected: ${a}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:u,clientId:a,subscribed:true}}}async function y(d){await n();let{cardId:u}=g(d),a=w(d);if(!l.unsubscribeChat(a,u))throw Object.assign(new Error(`SSE client not connected: ${a}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:u,clientId:a,subscribed:false}}}async function k(d,u){await n();let{clientId:a,channelName:t,cardId:o}=c(d);if(!l.has(a))throw Object.assign(new Error(`SSE client not connected: ${a}`),{statusCode:404});return u?h?.(a,t,o?{cardId:o}:{}):v?.(a,t,o?{cardId:o}:{}),{status:"success",data:{boardId:e,clientId:a,channelName:t,subscribed:u,...o?{cardId:o}:{}}}}async function f(d,u){let{cardId:a}=g(d);return await I().setChatProcessing({cardId:a,active:u}),{status:"success",data:{boardId:e,cardId:a,active:u}}}async function i(d){let{cardId:u}=g(d),a=await I().getChatProcessing({cardId:u});return {status:"success",data:{boardId:e,cardId:u,active:a.active}}}async function m(d){let{cardId:u}=g(d),a=D(d);if(!Object.prototype.hasOwnProperty.call(d,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(a.split(".").includes("visible_controlplane_only")){let t=await B(r().get({params:{id:u}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null,R=o?q(o,"visible_controlplane_only").value:void 0;if(d.value!==R)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:e,cardId:u,key:a}}}return j(await r().patch({params:{id:u,path:`__private.${a}`},body:{value:d.value}}),"cardStore.patch"),{status:"success",data:{boardId:e,cardId:u,key:a}}}async function _(d){let{cardId:u}=g(d),a=D(d),t=await B(r().get({params:{id:u}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&t.cards[0]&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${u}" not found`),{statusCode:404});let R=q(o,a);return {status:"success",data:{boardId:e,cardId:u,key:a,exists:R.exists,value:R.value}}}return {requireCardArgs:g,subscribeChat:b,unsubscribeChat:y,watchChannel:k,setChatProcessing:f,getChatProcessing:i,setCardMeta:m,getCardMeta:_}}function ee(s){let{boardId:e,boardContexts:n,readCardDefinitions:l,readChatRecords:h,getChatProcessing:v}=s;async function I(){let c=(await Promise.all(n.map(async f=>{try{let i=f.boardAdapter.kvStorageForRef(f.outputsStoreRef),m=await Promise.resolve(i.read("status"));if(m!=null)return m}catch{}return f.notification.status}))).filter(Boolean);if(c.length===0)return null;if(c.length===1)return c[0];let g=[],b=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],y={};for(let f of b)y[f]=0;for(let f of c){let i=f,m=Array.isArray(i.cards)?i.cards:[];g.push(...m);for(let _ of b)y[_]+=Number(i?.summary?.[_]||0);}let k=c[0];return {...k,cards:g,summary:{...k.summary||{},card_count:g.length,...y}}}async function r(){let c={},g=async b=>{try{let y=await b.boardOps.getAllOutputsComputedValues({});if(y.status==="success"&&y.data&&typeof y.data=="object"){for(let[k,f]of Object.entries(y.data)){let i=b.notification.cards[k];c[k]={schema_version:"v1",card_id:k,card_data:i?.card_data??{},computed_values:f??{}};}return}}catch{}for(let[y,k]of Object.entries(b.notification.computedValues)){let f=b.notification.cards[y];c[y]={schema_version:"v1",card_id:y,card_data:f?.card_data??{},computed_values:k??{}};}};for(let b of n)await g(b);return c}async function C(){let c={};for(let g of n){try{let b=await g.boardOps.getAllOutputsDataObjects({});if(b.status==="success"&&b.data&&typeof b.data=="object"){Object.assign(c,b.data);continue}}catch{}Object.assign(c,g.notification.dataObjects||{});}return c}async function w(){let c=await l(),g=await r(),b=await C(),y={};for(let f of c){if(!f?.id)continue;let i=f.id,m=g[i]||{},_={...m.card_data&&typeof m.card_data=="object"?m.card_data:f.card_data&&typeof f.card_data=="object"?f.card_data:{}};y[i]={schema_version:m.schema_version||"v1",card_id:m.card_id||i,card_data:_,computed_values:m.computed_values&&typeof m.computed_values=="object"?m.computed_values:{}};}let k={};for(let f of c){if(!f?.id)continue;let i=f.id;try{let m=await h(i),_=await v(i);(m.length>0||_)&&(k[i]={messages:m.map(d=>({role:String(d.role||"system"),text:String(d.text||""),files:Array.isArray(d.files)?d.files:[]})),receiving:!1,processing:_});}catch{}}return {boardId:e,cardDefinitions:c,statusSnapshot:await I(),dataObjectsByToken:b,cardRuntimeById:y,cardChatsByCardId:k}}return {readStatusSnapshot:I,readCardRuntimeArtifacts:r,readDataObjectsByToken:C,buildPublishedRuntimePayload:w}}function z(s){let e=String(s||"").trim();if(!e)return "upload.bin";let n=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (n>=0?e.slice(n+1):e)||"upload.bin"}function re(s){let{safeCardId:e,artifactsStores:n,cardFileMetadataStore:l,readCardFromStore:h,updateCardLocalOnly:v,writeChatRecord:I}=s;async function r(c){let g=[];try{let b=await h(c);if(!b)return g;let y=l().read(b.card_data&&typeof b.card_data=="object"?b.card_data:null);for(let k of y)g.push(String(k.stored_name??""));}catch{}return g}async function C(c,g,b,y){let k=e(c),f=n(c),i=z(g),m=await r(c),d=`${String(m.length+1).padStart(3,"0")}-${i}`.slice(-36);if(!f.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${c}`),{statusCode:500});return await f.files.putBytes(`${k}/${d}`,new Uint8Array(y),b||"application/octet-stream"),{name:i,stored_name:d,size:y.length,mime_type:b||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function w(c,g,b,y,k){if(!y.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let f=k?.inChat===true,i=await C(c,g,b,y),m=null;if(await v(c,_=>{let d=new Date().toISOString(),u=_.card_data&&typeof _.card_data=="object"?_.card_data:{};_.card_data=u;let a=l().normalizeIncoming([{name:i.name,stored_name:i.stored_name,size:i.size,mime_type:i.mime_type,uploaded_at:i.uploaded_at||d,chat:f}],d);return m=l().merge(u,a).findIndex(o=>o.stored_name===i.stored_name),_}),f&&k?.suppressChatRecordWrite!==true){let _=typeof m=="number"&&m>=0?` #${m}`:"";await I(c,"system",`file uploaded: ${i.name} as ${i.stored_name}${_}`,[],k?.turnId??"");}return {ok:true,file:{...i,...typeof m=="number"&&m>=0?{file_idx:m}:{},chat:f},...typeof m=="number"&&m>=0?{file_idx:m}:{}}}return {uploadCardFile:w,readCardStoredFileNames:r}}function se(s){return {"discover.source-kinds":()=>s.discoverSourceKinds(),"inspect.board-runtime-status":()=>s.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>s.inspectCardDefinitionAndRuntime({cardId:a(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let n=b(e,"tail_turns"),l=b(e,"tail"),h=a(e,"turn_id"),v=e.all_turns===true,I=a(e,"tail_turns_before_id");return s.inspectChatMessagesOnCards({cardId:a(e,"card_id"),...n!==void 0?{lastUserTurns:n}:{},...l!==void 0?{tail:l}:{},...h?{turnId:h}:{},...v?{allTurns:true}:{},...I?{tailTurnsBeforeId:I}:{}})},"inspect.file-contents":e=>s.inspectFileContents({cardId:a(e,"card_id"),fileIdx:Number(b(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>s.preflightValidateCandidateCardDefinition({candidateCardContent:d(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>s.preflightMaterializeCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:d(e,"mock_requires","mock_requires"),mockFetchedSources:d(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e$1=>s.preflightProbeSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e$1=>s.preflightRunSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e$1=>s.preflightRunSingleSourceInLiveCard({cardId:a(e$1,"card_id"),sourceIdx:e(e$1,"source_idx","source_idx"),mockRequires:d(e$1,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>s.preflightRunOneCycleWithCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:c(e,"mock_requires")}),"manage.read-card":e=>s.manageReadCard({cardId:a(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let n=a(e,"turn_id");if(!n)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return s.manageAddChatEntryAndAnyAttachments({cardId:a(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...n?{turn:n}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"manage.upsert-card":e=>s.manageUpsertCard({cardId:a(e,"card_id"),candidateCardContent:c(e,"candidate_card_content")}),"manage.remove-card":e=>s.manageRemoveCard({cardId:a(e,"card_id")})}}function oe(s){return {"webhook.process-accumulated":()=>s.webhookProcessAccumulated(),"webhook.source-fetch-done":e=>s.webhookSourceFetchDone({token:a(e,"token"),ref:a(e,"ref")}),"webhook.source-fetch-failed":e=>s.webhookSourceFetchFailed({token:a(e,"token"),reason:a(e,"reason")})}}function de(s){let{boardId:e,uploadCardFile:n,getMcpFacade:l,controlplane:h}=s;function v(r,C){let w=a(r,"board_id");if(!w)throw Object.assign(new Error(`${C} requires board_id`),{statusCode:400});if(w!==e)throw Object.assign(new Error(`Unknown board_id: ${w}`),{statusCode:400})}function I(r,C){let{cardId:w}=h.requireCardArgs(r),c=a(r,"turn_id");return v(r,C),l().manageAddChatAttachment({cardId:w,role:a(r,"role")||"user",...c?{turn:c}:{},files:[{file_name:a(r,"file_name"),content_type:a(r,"content_type")||"application/octet-stream",...typeof r.text=="string"?{text:r.text}:{},...typeof r.base64=="string"?{base64:r.base64}:{},...Array.isArray(r.bytes)?{bytes:r.bytes}:{}}]})}return {"list-runtime-cards":r=>(v(r,"list-runtime-cards"),l().listRuntimeCards()),"sse.subscribe-chat":r=>h.subscribeChat(r),"sse.unsubscribe-chat":r=>h.unsubscribeChat(r),"sse.watch-channel":r=>h.watchChannel(r,true),"sse.unwatch-channel":r=>h.watchChannel(r,false),"getstate.is-chat-processing":r=>h.getChatProcessing(r),"setstate.chat-processing-started":r=>h.setChatProcessing(r,true),"setstate.chat-processing-done":r=>h.setChatProcessing(r,false),"getstate.card-private":r=>h.getCardMeta(r),"setstate.card-private":r=>h.setCardMeta(r),"manage.upload-card-file":r=>{let C=a(r,"card_id"),w=a(r,"file_name"),c=a(r,"content_type")||"application/octet-stream",g=f(r);if(v(r,"manage.upload-card-file"),!C)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!w)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!g)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return n(C,w,c,g,{inChat:false})},"manage.add-chat-attachment":r=>I(r,"manage.add-chat-attachment"),"manage.add-chat-attachement":r=>I(r,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":r=>{let{cardId:C}=h.requireCardArgs(r),w=a(r,"role")||"user",c=a(r,"turn_id");return v(r,"manage.add-chat-entry-and-any-attachments"),l().manageAddChatEntryAndAnyAttachments({cardId:C,role:w,...typeof r.text=="string"?{text:r.text}:{},...c?{turn:c}:{},...Array.isArray(r.files)?{files:r.files}:{}})},"manage.patch-card":r=>{let{cardId:C}=h.requireCardArgs(r);return v(r,"manage.patch-card"),l().managePatchCard({cardId:C,patch:c(r,"patch")})},"manage.upsert-card":r=>{let{cardId:C}=h.requireCardArgs(r);return v(r,"manage.upsert-card"),l().manageUpsertCard({cardId:C,candidateCardContent:c(r,"candidate_card_content")})},"manage.remove-card":r=>{let{cardId:C}=h.requireCardArgs(r);return v(r,"manage.remove-card"),l().manageRemoveCard({cardId:C})},"manage.admin-read-card":async r=>{let{cardId:C}=h.requireCardArgs(r);return {status:"success",data:{cards:await l().adminReadCard({cardId:C})}}},"manage.admin-upsert-card":r=>{let C=a(r,"board_id"),w=a(r,"card_id");if(!C)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!w)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(C!==e)throw Object.assign(new Error(`Unknown board_id: ${C}`),{statusCode:400});return l().adminUpsertCard({cardId:w,candidateCardContent:c(r,"candidate_card_content")})}}}function pe(s){let{boardContexts:e,cardOwnerIndex:n,cardContextForCard:l,readStatusSnapshot:h,readDataObjectsByToken:v,readCardRuntimeArtifacts:I,readCardFromStore:r,readCardDefinitions:C,processAccumulatedLaneInternal:w,reportSourceFetched:c,reportSourceFetchFailure:g,uploadCardFile:b,chatStorePublic:y,serverUrl:k,apiBasePath:f}=s;function i(){return e[0]??null}function m(){return {async status(){let a=await h();return a==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:a}},async getOutputsDataObject(a){let t=a?.params?.key;return t?{status:"success",data:(await v())[t]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(a){let t=a?.params?.key;return t?{status:"success",data:(await I())[t]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(a){let t=a?.params?.key;if(!t)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=l(t)??i();return o?o.boardOps.getOutputsFetchedSources({params:{key:t}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(a){let t=a?.params?.id;if(!t)return {status:"fail",error:"removeCard requires params.id"};let o=l(t)??i();return o?o.boardOps.removeCard({params:{id:t}}):{status:"fail",error:"Board context is unavailable"}},async cardRefreshedNotify(a){let t=a?.params?.cardId;if(!t)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let o=l(t)??i();return o?o.boardOps.cardRefreshedNotify({params:{cardId:t}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(a){let t=a?.params?.cardId;if(!t)return {status:"fail",error:"upsertCard requires params.cardId"};let o=l(t)??i();if(!o)return {status:"fail",error:"Board context is unavailable"};let R=await o.boardOps.upsertCard({params:{cardId:t,restart:a.params.restart===true}});if(R.status!=="success")return R;if(a$1(o.boardAdapter)){let P=await w(true);if(P.status!=="success")return P}return R}}}function _(){let a=()=>{let t=i();if(!t?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return t.nonCore};return {describeTaskExecutorCapabilities(t){return a().describeTaskExecutorCapabilities(t)},validateCardPreflight(t){return a().validateCardPreflight(t)},evalCardCompute(t){return a().evalCardCompute(t)},probeSourcePreflight(t){return a().probeSourcePreflight(t)},runSourcePreflight(t){return a().runSourcePreflight(t)},simulateCardCycle(t){return a().simulateCardCycle(t)}}}function d(){return {async get(a){let t=typeof a.params?.id=="string"?a.params.id:void 0;if(t){let o=await r(t);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await C()}}},async set(a){let t=a.body;if(t==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(t)?t:[t];for(let R of o){let P=R,A=typeof P.id=="string"?P.id:"";if(!A)return {status:"fail",error:"each card must have a string `id` field"};let E=n.get(A)??0,N=e[E]??i();if(!N)return {status:"fail",error:"Board context is unavailable"};let T=await N.cardStoreOps.set({body:P});if(T.status!=="success")return T;n.set(A,E);}return {status:"success",data:{count:o.length}}},async del(a){let t=[a.params?.id,...a.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(t.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of t){let R=l(o)??i();if(!R)return {status:"fail",error:"Board context is unavailable"};let P=await R.cardStoreOps.del({params:{id:o}});if(P.status!=="success")return P;n.delete(o);}return {status:"success",data:{count:t.length}}},async patch(a){let t=typeof a.params?.id=="string"?a.params.id:void 0,o=typeof a.params?.path=="string"?a.params.path:void 0;if(!t||!o)return {status:"fail",error:"patch requires params.id and params.path"};let R=l(t)??i();return R?R.cardStoreOps.patch(a):{status:"fail",error:"Board context is unavailable"}},async appendFiles(a){let t=typeof a.params?.id=="string"?a.params.id:void 0;if(!t)return {status:"fail",error:"appendFiles requires params.id"};let o=l(t)??i();return o?o.cardStoreOps.appendFiles(a):{status:"fail",error:"Board context is unavailable"}}}}function u(){return a$2({board:m(),nonCore:_(),cardStore:d(),chatStore:y,processAccumulated:()=>w(true),sourceFetchDone:({token:a,ref:t})=>c(a,t),sourceFetchFailed:({token:a,reason:t})=>g(a,t),uploadCardFile({cardId:a,fileName:t,contentType:o,bytes:R,suppressChatRecordWrite:P}){return b(a,t,o,R,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:a,fileIdx:t,storedName:o}){let R=`${k||""}${f}/cards/${encodeURIComponent(a)}/files/${t}`;return o?`${R}?sn=${encodeURIComponent(o)}`:R},readFetchedSourceJsonByRef({cardId:a,ref:t}){let o=l(a)??i();if(!o||a$1(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(b$1(t)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:m,mcpNonCoreFacade:_,mcpCardStoreFacade:d,createMcpFacade:u}}export{W as a,V as b,H as c,j as d,B as e,D as f,q as g,Q as h,ee as i,re as j,se as k,oe as l,de as m,pe as n};//# sourceMappingURL=chunk-NU5NO5NM.js.map
2
+ //# sourceMappingURL=chunk-NU5NO5NM.js.map