yaml-flow 8.6.4 → 8.7.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 (146) hide show
  1. package/browser/adapters/firebase-storage.js +3 -0
  2. package/browser/adapters/firestore-storage.js +3 -0
  3. package/browser/adapters/localstorage-storage.js +4 -0
  4. package/browser/asset-integrity.json +20 -4
  5. package/browser/server-runtime-controlface.js +8 -0
  6. package/examples/ARCHITECTURE.md +5 -32
  7. package/examples/board/demo-shell-with-server.html +2 -2
  8. package/examples/board/doc.html +2 -2
  9. package/examples/board/server/board-server.js +4 -2
  10. package/examples/board-firestore/README.md +81 -0
  11. package/examples/board-firestore/browser/board-runtime.js +263 -0
  12. package/examples/board-firestore/firestore.indexes.json +29 -0
  13. package/examples/board-firestore/package.json +14 -0
  14. package/examples/board-firestore/server/adapters/firestore-archive-factory.js +59 -0
  15. package/examples/board-firestore/server/adapters/firestore-blob-storage.js +82 -0
  16. package/examples/board-firestore/server/adapters/firestore-board-adapter.js +127 -0
  17. package/examples/board-firestore/server/adapters/firestore-journal-storage.js +54 -0
  18. package/examples/board-firestore/server/adapters/firestore-kv-storage.js +47 -0
  19. package/examples/board-firestore/server/adapters/firestore-lock.js +62 -0
  20. package/examples/board-firestore/server/adapters/firestore-queue-storage.js +186 -0
  21. package/examples/board-firestore/server/adapters/firestore-scratch-storage.js +50 -0
  22. package/examples/board-firestore/server/worker.js +146 -0
  23. package/lib/{artifacts-store-lib-BR-Samty.d.cts → artifacts-store-lib-D9nMkVcE.d.cts} +1 -1
  24. package/lib/{artifacts-store-lib-DT7XlWUL.d.ts → artifacts-store-lib-DSSMqVL2.d.ts} +1 -1
  25. package/lib/artifacts-store-public.d.cts +2 -2
  26. package/lib/artifacts-store-public.d.ts +2 -2
  27. package/lib/board-live-cards-mcp.cjs +1 -1
  28. package/lib/board-live-cards-mcp.d.cts +50 -3
  29. package/lib/board-live-cards-mcp.d.ts +50 -3
  30. package/lib/board-live-cards-mcp.js +1 -1
  31. package/lib/board-live-cards-node.cjs +8 -8
  32. package/lib/board-live-cards-node.d.cts +13 -9
  33. package/lib/board-live-cards-node.d.ts +13 -9
  34. package/lib/board-live-cards-node.js +8 -8
  35. package/lib/{board-live-cards-public-BMUIPOrc.d.ts → board-live-cards-public-D-DJek3X.d.ts} +1 -1
  36. package/lib/{board-live-cards-public-wkNmBIRC.d.cts → board-live-cards-public-DQzPe7A9.d.cts} +1 -1
  37. package/lib/board-live-cards-public-async-3hUuHxDx.d.ts +55 -0
  38. package/lib/board-live-cards-public-async-CgMCYYft.d.cts +55 -0
  39. package/lib/board-live-cards-public.d.cts +1 -1
  40. package/lib/board-live-cards-public.d.ts +1 -1
  41. package/lib/board-live-cards-server-runtime.cjs +1 -1
  42. package/lib/board-live-cards-server-runtime.d.cts +10 -6
  43. package/lib/board-live-cards-server-runtime.d.ts +10 -6
  44. package/lib/board-live-cards-server-runtime.js +1 -1
  45. package/lib/board-platform-adapter-async-DOfEq_HC.d.cts +129 -0
  46. package/lib/board-platform-adapter-async-JZPCzZnH.d.ts +129 -0
  47. package/lib/board-worker-adapter.cjs +3 -3
  48. package/lib/board-worker-adapter.js +3 -3
  49. package/lib/card-store-public.d.cts +1 -1
  50. package/lib/card-store-public.d.ts +1 -1
  51. package/lib/{chat-storage-lib-BIUbE-fM.d.cts → chat-storage-lib-B9Q34Dyv.d.cts} +1 -1
  52. package/lib/{chat-storage-lib-BlG-sobS.d.ts → chat-storage-lib-DB9iSai2.d.ts} +1 -1
  53. package/lib/chat-store-public.d.cts +2 -2
  54. package/lib/chat-store-public.d.ts +2 -2
  55. package/lib/chunk-272IYUKT.cjs +2 -0
  56. package/lib/chunk-5XHOHTLZ.cjs +2 -0
  57. package/lib/chunk-6APH25VI.js +2 -0
  58. package/lib/chunk-7FGPOGRV.cjs +2 -0
  59. package/lib/chunk-7ICPAABP.cjs +7 -0
  60. package/lib/chunk-CPAXTVBQ.cjs +2 -0
  61. package/lib/chunk-DDYSXP2A.cjs +3 -0
  62. package/lib/chunk-EGRHWZRV.js +2 -0
  63. package/lib/chunk-GL2OHR2E.cjs +2 -0
  64. package/lib/chunk-IPLSRN6P.cjs +4 -0
  65. package/lib/chunk-J5J6BG7B.js +2 -0
  66. package/lib/chunk-KAWQPLIE.cjs +2 -0
  67. package/lib/chunk-LPXVVMQT.cjs +2 -0
  68. package/lib/chunk-M3OU6IS5.cjs +2 -0
  69. package/lib/chunk-M6STQR5F.cjs +2 -0
  70. package/lib/chunk-NJJ7WEDT.cjs +2 -0
  71. package/lib/chunk-NKIQRCOM.cjs +2 -0
  72. package/lib/chunk-NM6O35RY.cjs +2 -0
  73. package/lib/chunk-NTICU4OK.js +2 -0
  74. package/lib/chunk-O7NOHKVR.js +2 -0
  75. package/lib/chunk-PRHQBGPT.js +2 -0
  76. package/lib/chunk-S44QZUDX.js +2 -0
  77. package/lib/chunk-SGV7PU4H.js +2 -0
  78. package/lib/chunk-TSN3RTXT.js +4 -0
  79. package/lib/chunk-VXJHBWK3.js +2 -0
  80. package/lib/chunk-WHDEBJLT.js +7 -0
  81. package/lib/chunk-XYN5D3GL.js +2 -0
  82. package/lib/chunk-YGALANRO.js +2 -0
  83. package/lib/chunk-ZJ5M5COT.js +2 -0
  84. package/lib/chunk-ZXQR7GHT.js +3 -0
  85. package/lib/cloud-storage.cjs +1 -1
  86. package/lib/cloud-storage.d.cts +5 -3
  87. package/lib/cloud-storage.d.ts +5 -3
  88. package/lib/cloud-storage.js +1 -1
  89. package/lib/firebase-storage/index.cjs +3 -0
  90. package/lib/firebase-storage/index.d.cts +57 -0
  91. package/lib/firebase-storage/index.d.ts +57 -0
  92. package/lib/firebase-storage/index.js +3 -0
  93. package/lib/firestore-storage/index.cjs +3 -0
  94. package/lib/firestore-storage/index.d.cts +98 -0
  95. package/lib/firestore-storage/index.d.ts +98 -0
  96. package/lib/firestore-storage/index.js +3 -0
  97. package/lib/localstorage-storage/index.cjs +2 -0
  98. package/lib/localstorage-storage/index.d.cts +39 -0
  99. package/lib/localstorage-storage/index.d.ts +39 -0
  100. package/lib/localstorage-storage/index.js +2 -0
  101. package/lib/mcp-tool-registries-BBObLYga.d.ts +41 -0
  102. package/lib/mcp-tool-registries-W3TRj6O5.d.cts +41 -0
  103. package/lib/queue-lane-registry-PaZuFpwp.d.cts +30 -0
  104. package/lib/queue-lane-registry-PaZuFpwp.d.ts +30 -0
  105. package/lib/server-jobs-queue-runner/index.cjs +2 -0
  106. package/lib/server-jobs-queue-runner/index.d.cts +22 -0
  107. package/lib/server-jobs-queue-runner/index.d.ts +22 -0
  108. package/lib/server-jobs-queue-runner/index.js +2 -0
  109. package/lib/server-runtime/index.cjs +1 -1
  110. package/lib/server-runtime/index.d.cts +11 -17
  111. package/lib/server-runtime/index.d.ts +11 -17
  112. package/lib/server-runtime/index.js +1 -1
  113. package/lib/server-runtime-agentface/index.cjs +2 -0
  114. package/lib/server-runtime-agentface/index.d.cts +53 -0
  115. package/lib/server-runtime-agentface/index.d.ts +53 -0
  116. package/lib/server-runtime-agentface/index.js +2 -0
  117. package/lib/server-runtime-controlface/index.cjs +2 -0
  118. package/lib/server-runtime-controlface/index.d.cts +80 -0
  119. package/lib/server-runtime-controlface/index.d.ts +80 -0
  120. package/lib/server-runtime-controlface/index.js +2 -0
  121. package/lib/server-runtime-core/index.cjs +2 -0
  122. package/lib/server-runtime-core/index.d.cts +376 -0
  123. package/lib/server-runtime-core/index.d.ts +376 -0
  124. package/lib/server-runtime-core/index.js +2 -0
  125. package/lib/server-runtime-watchers/index.cjs +2 -0
  126. package/lib/server-runtime-watchers/index.d.cts +127 -0
  127. package/lib/server-runtime-watchers/index.d.ts +127 -0
  128. package/lib/server-runtime-watchers/index.js +2 -0
  129. package/lib/server-runtime-webhooks/index.cjs +2 -0
  130. package/lib/server-runtime-webhooks/index.d.cts +34 -0
  131. package/lib/server-runtime-webhooks/index.d.ts +34 -0
  132. package/lib/server-runtime-webhooks/index.js +2 -0
  133. package/lib/storage-async-interface-BRR4eBjx.d.cts +81 -0
  134. package/lib/storage-async-interface-DhlOVPSp.d.ts +81 -0
  135. package/lib/{queue-lane-registry-BPKWWgd4.d.cts → types-BzQY45dH.d.cts} +8 -34
  136. package/lib/{queue-lane-registry-Be6c0ftj.d.ts → types-CF2xUcZW.d.ts} +8 -34
  137. package/package.json +46 -2
  138. package/examples/board-local/demo-shell-localstorage.html +0 -843
  139. package/lib/board-live-cards-public-async-DKZqbJVU.d.ts +0 -256
  140. package/lib/board-live-cards-public-async-dMWNbWq6.d.cts +0 -256
  141. package/lib/chunk-KXWT3CY6.cjs +0 -8
  142. package/lib/chunk-MLVTJASJ.js +0 -2
  143. package/lib/chunk-OJLA6NLU.js +0 -8
  144. package/lib/chunk-R5L5WUKN.js +0 -2
  145. package/lib/chunk-WOALA3V5.cjs +0 -2
  146. package/lib/chunk-YEB5QHGE.cjs +0 -2
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunkIXZG74EW_cjs=require('./chunk-IXZG74EW.cjs');function A(s,i){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function H(s,i){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${i} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function a(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function y(s){return Array.isArray(s)?s:[]}function N(s,i){if(typeof i!="string"||i.length===0)return;let c=s,u=i;u.startsWith("fetched_sources.")&&(c=a(s).fetched_sources,u=u.slice(16));for(let p of u.split(".")){if(c==null||typeof c!="object")return;c=c[p];}return c}function V(s,i){let c=a(s.view),u=y(c.elements);return {layout:c.layout,features:c.features,elements:u.map((p,k)=>{let R=a(p),b=a(R.data),h=typeof R.visible=="string"?!!N(i,R.visible):true,U=typeof b.bind=="string"?b.bind:void 0,S=typeof b.maxRows=="number"?b.maxRows:void 0,B=U?N(i,U):void 0,F={id:typeof R.id=="string"&&R.id?R.id:`element-${k}`,kind:R.kind,label:R.label,visible:h};return B!==void 0&&(F.resolved=Array.isArray(B)&&typeof S=="number"?B.slice(0,S):B),F})}}function G(s,i){let c=typeof s.id=="string"&&s.id?s.id:"card",u=y(s.provides),p=u.length>0?u:[{bindTo:c,ref:"card_data"}],k={};for(let R of p){let b=a(R),h=typeof b.bindTo=="string"?b.bindTo:"",U=typeof b.ref=="string"?b.ref:"";if(!h||!U)continue;let S=N(i,U);S!==void 0&&(k[h]=S);}return k}function be(s){if(typeof s!="string"||!s.trim())return null;let i=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!i)return null;let c=Number.parseInt(i[2],10);return !Number.isInteger(c)||c<0?null:c}function he(s){return {"card-content":s}}function E(s){let{meta:i,...c}=s;return c}function ke(s,i){return Object.prototype.hasOwnProperty.call(s,i)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,i){let c=Re(s);if(!i||Object.keys(i).length===0)return c;function u(p,k,R){let b=String(k||"").split(".").filter(Boolean);if(!b.length)return;let h=p;for(let U=0;U<b.length-1;U+=1){let S=b[U];(!h[S]||typeof h[S]!="object")&&(h[S]={}),h=h[S];}h[b[b.length-1]]=R;}if(i.fieldValues!==void 0&&i.fieldValues!==null){let p=null,k=a(c.view),R=y(k.elements);for(let b of R){let h=a(a(b).data);if(typeof h.writeTo=="string"&&h.writeTo){p=h.writeTo;break}}return p?u(c,p,i.fieldValues):typeof i.fieldValues=="object"&&!Array.isArray(i.fieldValues)&&(c.card_data={...a(c.card_data),...i.fieldValues}),c}if(Array.isArray(i._stagedFiles)&&i._stagedFiles.length>0)return c;for(let[p,k]of Object.entries(i))p!=="_stagedFiles"&&(k!==null&&typeof k=="object"&&!Array.isArray(k)&&c[p]!==null&&typeof c[p]=="object"&&!Array.isArray(c[p])?c[p]={...c[p],...k}:c[p]=k);return c}function Q(s){return a(s.meta).__visible_controlplane_only===true}async function T(s,i){let c=await M(s.get({params:{id:i}}),"cardStore.get"),u=Array.isArray(c?.cards)?c.cards:[];if(u.length===0)throw new Error(`Card "${i}" not found`);return u[0]}function Ae(s){let{board:i,nonCore:c,cardStore:u,chatStore:p,processAccumulated:k,sourceFetchDone:R,sourceFetchFailed:b,uploadCardFile:h,buildFileDownloadUrl:U,readFetchedSourceJsonByRef:S}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function F(){let e=await M(u.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>a(r)):[]}function X(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),n=atob(t);return Uint8Array.from(n,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=a(await M(c.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:a(e.commonSourceDefFields),sourceKinds:a(e.sourceKinds)}}async function Z(){let e=a(await M(i.status({}),"status")),r=a(e.summary),t=y(e.cards);return {meta:a(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:t.map(n=>{let o=a(n);return {"card-id":typeof o.name=="string"?o.name:null,status:o.status??null,error:o.error??null,requires:y(o.requires),requires_satisfied:y(o.requires_satisfied),requires_missing:y(o.requires_missing),provides_declared:y(o.provides_declared),provides_runtime:y(o.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=a(await M(i.status({}),"status")),o=y(t.cards).map(a).find(m=>m.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let d=a(await T(u,r));if(Q(d))throw Object.assign(new Error(`card "${r}" not found`),{statusCode:404});let f=E(d),g=y(o.requires_satisfied).filter(m=>typeof m=="string"&&!!m),_=y(o.provides_runtime).filter(m=>typeof m=="string"&&!!m),v=Object.fromEntries(await Promise.all(g.map(async m=>[m,await M(i.getOutputsDataObject({params:{key:m}}),`getOutputsDataObject(${m})`)]))),I=Object.fromEntries(await Promise.all(_.map(async m=>[m,await M(i.getOutputsDataObject({params:{key:m}}),`getOutputsDataObject(${m})`)]))),w=a(await M(i.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),l=await M(i.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),P=y(d.source_defs).map(a),C={};for(let m of P)typeof m.bindTo=="string"&&typeof m.outputFile=="string"&&(C[m.outputFile]=m.bindTo);let x={};for(let[m,O]of Object.entries(l)){let q=C[m]??m;if(!S||typeof O!="string"){x[q]=null;continue}try{x[q]=S({cardId:r,ref:O});}catch{x[q]=null;}}let L={card_data:a(d.card_data),requires:v,fetched_sources:x,computed_values:w};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:f,refs_for_fetched_source_files:l,runtime_data:{requires:v,provides:I,computed_values:w,rendered_view:V(d,L)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",n=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",d=n?void 0:e.lastUserTurns??(t?void 0:1),f=e.tail,g={...d===void 0?{}:{tailTurns:d},...t?{turnId:t}:{},...n?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},_=Object.keys(g).length>0?{params:{cardId:r},body:g}:{params:{cardId:r}},v=A(p.readAll(_),"chatStore.readAll"),I=a(await T(u,r)),w=y(a(I.card_data).files).map((C,x)=>({idx:x,stored_name:a(C).stored_name})).filter(C=>typeof C.stored_name=="string"&&C.stored_name.length>0),P=(Array.isArray(v.records)?v.records:[]).map(C=>{let L=a(C.payload),m={...C},O=typeof C?.role=="string"?C.role:typeof L.role=="string"?String(L.role):"",q=typeof C?.text=="string"?C.text:typeof L.text=="string"?String(L.text):"";if(O==="system"){let $=be(q);if($!==null&&w.some(j=>j.idx===$)){let j=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${$}`;m.retrieval_hint=j,Object.keys(L).length>0&&typeof C.role!="string"&&(m.payload={...L,retrieval_hint:j});}}return m});return {cardId:r,messages:typeof f=="number"&&f>=0?P.slice(-f):P}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let n=a(await T(u,r)),o=y(a(n.card_data).files).map(a);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let d=o[t],f=typeof d.stored_name=="string"?d.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:U({cardId:r,fileIdx:t,storedName:f}),...typeof d.name=="string"?{name:d.name}:{},...typeof d.stored_name=="string"?{stored_name:d.stored_name}:{},...typeof d.mime_type=="string"?{mime_type:d.mime_type}:{},...typeof d.size=="number"?{size:d.size}:{},...typeof d.uploaded_at=="string"?{uploaded_at:d.uploaded_at}:{}}}async function D(e){return await c.validateCardPreflight({body:he(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=c.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=a(H(r,"evalCardCompute")),n=a(e.candidateCardContent),o={card_data:a(n.card_data),requires:a(e.mockRequires),fetched_sources:a(e.mockFetchedSources),computed_values:a(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof n.id=="string"?n.id:"(unknown)",ok:t.ok===true,computed_values:a(t.computed_values),errors:y(t.errors).map(d=>{let f=a(d);return {bindTo:typeof f.bindTo=="string"?f.bindTo:"",error:typeof f.error=="string"?f.error:""}}),provides_outputs:G(n,o),rendered_view:V(n,o)}}}async function ae(e){return await c.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=a(await T(u,r)),n=y(t.source_defs).filter(d=>!!d&&typeof d=="object"&&!Array.isArray(d)),o={};if(e.sourceIdx>=0&&e.sourceIdx<n.length){let d=n[e.sourceIdx],f=chunkIXZG74EW_cjs.a.enrichSourcesSync([d],{card_data:a(t.card_data),requires:e.mockRequires});Array.isArray(f)&&f.length>0&&(o=a(f[0]._projections));}return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=a(await M(c.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=a(e.candidateCardContent),n=a(r.validation),o=y(r.source_probes),d=y(r.projection_errors),f=a(r.fetched_sources),g=y(r.compute_errors),_=a(r.computed_values),v={card_data:a(t.card_data),requires:e.mockRequires,fetched_sources:f,computed_values:_},I=[];for(let w of y(n.issues))typeof w=="string"&&w&&I.push(w);for(let w of o){let l=a(w),P=typeof l.bindTo=="string"?l.bindTo:"source",C=typeof l.error=="string"?l.error:"";C&&I.push(`${P}: ${C}`);}for(let w of d){let l=a(w),P=typeof l.bindTo=="string"?l.bindTo:"source",C=typeof l.key=="string"?l.key:"projection",x=typeof l.error=="string"?l.error:"projection failed";I.push(`${P}.${C}: ${x}`);}for(let w of g){let l=a(w),P=typeof l.bindTo=="string"?l.bindTo:"compute",C=typeof l.error=="string"?l.error:"compute failed";I.push(`${P}: ${C}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:I,provides_outputs:G(t,v),rendered_view:V(t,v)}}}async function z(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await M(u.get({params:{id:r}}),"cardStore.get"),n=Array.isArray(t.cards)?t.cards.map(a):[];if(n.some(Q))throw Object.assign(new Error(`Card "${r}" not found`),{statusCode:404});return n.map(o=>E(o))}async function K(e){let r=await Promise.all(y(e.files).map(async t=>{let n=a(t),o=String(n.file_name??n.fileName??n.name??"").trim(),d=String(n.content_type??n.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await h({cardId:e.cardId,fileName:o,contentType:d,bytes:X(n)})}));return r.forEach((t,n)=>{let o=a(t.file),d=typeof t.file_idx=="number"&&Number.isInteger(t.file_idx)&&t.file_idx>=0?t.file_idx:n,f=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`;A(p.append({params:{cardId:e.cardId},body:{role:"system",text:f,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}),r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",n=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await K({cardId:r,role:t,turn:n,files:e.files});return {status:"success",data:{cardId:r,turn:n,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),n=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let g=A(p.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),_=Array.isArray(g.records)?g.records.find(v=>v.role==="assistant"&&String(v.turn||"")===o):void 0;if(_)return {status:"success",data:{cardId:r,id:String(_.id),role:t,turn:o,files:Array.isArray(_.files)?_.files:[]}}}let d=await K({cardId:r,role:t,turn:o,files:e.files}),f=A(p.append({params:{cardId:r},body:{role:t,text:n,files:d,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(f.id),role:t,turn:o,files:d}}}async function ue(e){let r=String(e.cardId||"").trim(),t=a(e.patch);if(!r)throw new Error("managePatchCard requires cardId");let n=await z({cardId:r}),o=a(n[0]),d=ve(o,t);return J({cardId:r,candidateCardContent:d})}async function J(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("manageUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await D({candidateCardContent:n}),d=a(o),f=a(d.data);if(d.status!=="success"||f.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let _=g&&ke(a(g),"meta")?{...n,meta:a(g).meta}:n,v=await u.set({body:_});A(v,"cardStore.set");let I;try{I=await i.upsertCard({params:{cardId:r,restart:!0}}),A(I,"upsertCard");}catch(l){try{g&&await u.set({body:g});}catch{}throw l}let w=null;try{w=await i.cardRefreshedNotify({params:{cardId:r}}),A(w,"cardRefreshedNotify");}catch{w=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:I,refresh_notify:w}}}async function le(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageRemoveCard requires cardId");let t=await i.removeCard({params:{id:r}});A(t,"removeCard");let n=await u.del({params:{id:r}});return A(n,"cardStore.del"),{status:"success",data:{board_result:t,store_result:n}}}async function me(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await M(u.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(n=>a(n)):[]}async function pe(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await D({candidateCardContent:n}),d=a(o),f=a(d.data);if(d.status!=="success"||f.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let _=g?a(a(g).meta):{},v={...n,meta:{..._,__visible_controlplane_only:true}},I=await u.set({body:v});A(I,"cardStore.set");let w;try{w=await i.upsertCard({params:{cardId:r,restart:!0}}),A(w,"upsertCard");}catch(P){try{g&&await u.set({body:g});}catch{}throw P}let l=null;try{l=await i.cardRefreshedNotify({params:{cardId:r}}),A(l,"cardRefreshedNotify");}catch{l=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:w,refresh_notify:l}}}function fe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=H(p.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return A(p.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function we(){let e=await B(k,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function Ce(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let n=await B(R,"webhook.source-fetch-done")({token:r,ref:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let n=await B(b,"webhook.source-fetch-failed")({token:r,reason:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}return {listRuntimeCards:F,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:D,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:z,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:J,manageRemoveCard:le,adminReadCard:me,adminUpsertCard:pe,getChatProcessing:fe,setChatProcessing:ge,webhookProcessAccumulated:we,webhookSourceFetchDone:Ce,webhookSourceFetchFailed:ye}}async function M(s,i){return A(await s,i)}exports.a=Ae;//# sourceMappingURL=chunk-M6STQR5F.cjs.map
2
+ //# sourceMappingURL=chunk-M6STQR5F.cjs.map
@@ -0,0 +1,2 @@
1
+ 'use strict';function p(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function m(e){let n=e.payload??{};return {id:e.id,role:typeof n.role=="string"?n.role:"system",text:typeof n.text=="string"?n.text:"",files:Array.isArray(n.files)?n.files:[],turn:typeof n.turn=="string"?n.turn:"",updated_at:typeof n.updated_at=="string"?n.updated_at:""}}function R(e,n){let a=t=>`chats/${p(t)}/processing`,r=t=>`chats/${p(t)}/config`;return {append(t,i,o,u=[],s=""){return e(t).append({role:i,text:o,files:u,turn:s,updated_at:new Date().toISOString()}).id},readAll(t){return e(t).readAll().map(m)},readAfter(t,i){let o=e(t).readAfter(i);return {records:o.entries.map(m),cursor:o.newCursor}},clear(t){e(t).clear?.();},setProcessing(t,i){i?n.write(a(t),true):n.delete(a(t));},isProcessing(t){return n.read(a(t))===true},getConfig(t){return n.read(r(t))??{}},setConfig(t,i){let o=n.read(r(t))??{};n.write(r(t),{...o,...i});}}}function S(){let e=globalThis.crypto;return typeof e?.randomUUID=="function"?String(e.randomUUID()):`id-${Date.now()}-${Math.random().toString(36).slice(2)}`}function $(){let e=new Map,n=new Map;function a(r){return e.has(r)||e.set(r,[]),e.get(r)}return {append(r,t,i,o=[],u=""){let s={id:S(),role:t,text:i,files:o,turn:u,updated_at:new Date().toISOString()};return a(r).push(s),s.id},readAll(r){return a(r).slice()},readAfter(r,t){let i=a(r);if(!t)return {records:i.slice(),cursor:i.length>0?i[i.length-1].id:null};let o=i.findIndex(s=>s.id===t),u=o===-1?i.slice():i.slice(o+1);return {records:u,cursor:u.length>0?u[u.length-1].id:t}},clear(r){e.set(r,[]);},setProcessing(r,t){t?n.set(`p:${r}`,true):n.delete(`p:${r}`);},isProcessing(r){return n.get(`p:${r}`)===true},getConfig(r){return n.get(`c:${r}`)??{}},setConfig(r,t){let i=n.get(`c:${r}`)??{};n.set(`c:${r}`,{...i,...t});}}}function y(){return new Date().toISOString()}function x(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 w(e){let n=String(e||"").match(/^(\d+)[-_]/);return n?parseInt(n[1],10):0}function I(e){let n=String(e||"").trim();if(!n)return "upload.bin";let a=Math.max(n.lastIndexOf("/"),n.lastIndexOf("\\"));return (a>=0?n.slice(a+1):n)||"upload.bin"}function k(e){return String(e||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function z(e){if(!e||e===".")return "";let n=String(e).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return n?`.${n}`:""}function F(e){let n=I(e),a=n.lastIndexOf(".");return a<=0||a===n.length-1?{stem:n,ext:""}:{stem:n.slice(0,a),ext:n.slice(a)}}function M(e){let n=e.lastIndexOf("/");return n>=0?e.slice(n+1):e}function L(e){function n(a){let r=e.stat?A(e.stat(a)):null;if(r)return r;if(!e.exists(a))return null;let t=e.read(a);return t===null?{key:a}:{key:a,size:x(t)}}return {exists(a){return e.exists(a)},putText(a,r,t="text/plain; charset=utf-8"){e.write(a,r);let i=n(a)??{key:a};return i.contentType=t,i.updatedAt=i.updatedAt??y(),i.size=i.size??x(r),i},putBytes(a,r,t="application/octet-stream"){if(e.writeBytes)e.writeBytes(a,r);else {let o=JSON.stringify({__kind:"bytes-array",data:[...r]});e.write(a,o);}let i=n(a)??{key:a};return i.contentType=t,i.updatedAt=i.updatedAt??y(),i.size=i.size??r.byteLength,i},getText(a){let r=e.read(a);if(r===null){if(!e.readBytes)return null;let t=e.readBytes(a);return t===null?null:Buffer.from(t).toString("utf-8")}try{let t=JSON.parse(r);if(t&&t.__kind==="bytes-array"&&Array.isArray(t.data))return new TextDecoder("utf-8").decode(new Uint8Array(t.data))}catch{}return r},getBytes(a){if(e.readBytes){let t=e.readBytes(a);if(t!==null)return t}let r=e.read(a);if(r===null)return null;try{let t=JSON.parse(r);if(t&&t.__kind==="bytes-array"&&Array.isArray(t.data))return new Uint8Array(t.data)}catch{}return new TextEncoder().encode(r)},head:n,list(a=""){return e.listKeys(a).map(r=>n(r)??{key:r}).sort((r,t)=>r.key.localeCompare(t.key))},remove(a){e.remove(a);}}}function b(e){function n(t,i){let o=0,u=[];Array.isArray(i)&&u.push(...i);for(let s of e.list(`${t}/`))u.push(M(s.key));for(let s of u){let l=w(s);Number.isFinite(l)&&l>o&&(o=l);}return o+1}function a(t,i,o){let u=Number(o?.maxLen||32),{stem:s,ext:l}=F(t),h=z(l),C=k(s),d=`${String(i).padStart(3,"0")}-`,g=h,f=u-d.length-g.length;f<1&&(g="",f=u-d.length);let _=C.slice(0,Math.max(1,f)),c=`${d}${_}${g}`;return c.length>u&&(c=c.slice(0,u).replace(/\.$/,"")),c}function r(t,i,o){let u=n(t,o?.seedNames),s=a(i,u,{maxLen:o?.maxLen});for(;e.exists(`${t}/${s}`);)u+=1,s=a(i,u,{maxLen:o?.maxLen});return s}return {nextSerial:n,buildStoredName:a,allocateStoredName:r}}function N(){function e(t,i){if(!Array.isArray(t))return [];let o=[];for(let u of t){if(!u||typeof u!="object")continue;let s=u;typeof s.stored_name=="string"&&o.push({name:typeof s.name=="string"?s.name:s.stored_name,stored_name:s.stored_name,size:typeof s.size=="number"&&Number.isFinite(s.size)?s.size:null,mime_type:typeof s.mime_type=="string"?s.mime_type:null,uploaded_at:typeof s.uploaded_at=="string"?s.uploaded_at:i||null,chat:s.chat===true});}return o}function n(t){return !t||typeof t!="object"?[]:e(t.files,void 0)}function a(t,i){let o=n(t);if(i.length===0)return t.files=o,o;let u=new Set(o.map(s=>s.stored_name));for(let s of i)u.has(s.stored_name)||(o.push(s),u.add(s.stored_name));return t.files=o,o}function r(t,i,o){let u=n(t);if(!Number.isInteger(i)||i<0||i>=u.length)return {ok:false,reason:"index_out_of_range"};let s=u[i];return !s||!s.stored_name?{ok:false,reason:"missing_stored_name"}:o&&o!==s.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:s}}return {read:n,normalizeIncoming:e,merge:a,resolve:r}}exports.a=R;exports.b=$;exports.c=L;exports.d=b;exports.e=N;//# sourceMappingURL=chunk-NJJ7WEDT.cjs.map
2
+ //# sourceMappingURL=chunk-NJJ7WEDT.cjs.map
@@ -0,0 +1,2 @@
1
+ 'use strict';//# sourceMappingURL=chunk-NKIQRCOM.cjs.map
2
+ //# sourceMappingURL=chunk-NKIQRCOM.cjs.map
@@ -0,0 +1,2 @@
1
+ 'use strict';var chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs');function w(c){let{apiBasePath:p,json:t,readJsonBody:m,initBoardAndSetup:d,createMcpWebhookToolRegistry:R}=c;async function l(i,r,y){let g=i.method||"GET",b=y.pathname;try{if(g==="POST"&&b===`${p}/mcp-webhooks`){await d();let o=await m(i),s=typeof o.tool=="string"?o.tool.trim():"",f=o.args&&typeof o.args=="object"&&!Array.isArray(o.args)?o.args:{};if(!s)return t(r,400,{error:"tool is required"}),!0;try{let e=await chunk272IYUKT_cjs.a(s,f,R());if(e&&typeof e=="object"&&!Array.isArray(e)){let n=e;if(n.status==="fail")return t(r,400,{error:chunk272IYUKT_cjs.b(e,"Request failed")}),!0;if(n.status==="error")return t(r,500,{error:chunk272IYUKT_cjs.b(e,"Internal error")}),!0}t(r,200,e);}catch(e){let n=typeof e?.statusCode=="number"?Number(e.statusCode):500,h=e instanceof Error?e.message:String(e);t(r,n,{error:h});}return !0}return !1}catch(o){let s=o?.statusCode||500;return t(r,s,{error:String(o?.message||o)}),true}}return {handleWebhooksApi:l}}exports.a=w;//# sourceMappingURL=chunk-NM6O35RY.cjs.map
2
+ //# sourceMappingURL=chunk-NM6O35RY.cjs.map
@@ -0,0 +1,2 @@
1
+ import {a as a$1,b as b$1}from'./chunk-O7NOHKVR.js';import {a,b}from'./chunk-ZJ5M5COT.js';function G(q){let{apiBasePath:x,json:r,readJsonBody:k,bootstrapBoard:T,createMcpFacade:B,createMcpToolRegistry:I,resolveCardFileDownloadPayload:j,isLikelyTextMimeType:v,sliceTextByLines:C}=q;async function D(b$2,e,N){let A=b$2.method||"GET",M=N,L=M.pathname;try{if(A==="POST"&&L===`${x}/mcp`){await T();let t=await k(b$2),i=typeof t.tool=="string"?t.tool.trim():"",a$1=t.args&&typeof t.args=="object"&&!Array.isArray(t.args)?t.args:{};if(!i)return r(e,400,{error:"tool is required"}),!0;if(i==="inspect.file-contents")return r(e,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let n=await a(i,a$1,I(B()));if(n&&typeof n=="object"&&!Array.isArray(n)){let s=n;if(s.status==="fail")return r(e,400,{error:b(n,"Request failed")}),!0;if(s.status==="error")return r(e,500,{error:b(n,"Internal error")}),!0}r(e,200,n);}catch(n){let s=typeof n?.statusCode=="number"?Number(n.statusCode):500,d=n instanceof Error?n.message:String(n);r(e,s,{error:d});}return !0}if(A==="POST"&&L===`${x}/mcp-raw`){await T();let t=await k(b$2),i=typeof t.tool=="string"?t.tool.trim():"",a=t.args&&typeof t.args=="object"&&!Array.isArray(t.args)?t.args:{};if(!i)return r(e,400,{error:"tool is required"}),!0;if(i!=="inspect.file-contents")return r(e,400,{error:`Tool does not support raw response: ${i}`}),!0;let n=a$1(a,"card_id","cardId"),s=b$1(a,"file_idx","fileIdx"),d=b$1(a,"head-lines","headLines"),m=b$1(a,"tail-lines","tailLines"),f=b$1(a,"head-bytes","headBytes"),y=b$1(a,"tail-bytes","tailBytes");if(!n)return r(e,400,{error:"inspect.file-contents requires card_id"}),!0;if(s===void 0||!Number.isInteger(s)||s<0)return r(e,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([d,m,f,y].filter(o=>o!==void 0).length>1)return r(e,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[o,u]of [["head-lines",d],["tail-lines",m],["head-bytes",f],["tail-bytes",y]])if(u!==void 0&&(!Number.isInteger(u)||u<0))return r(e,400,{error:`inspect.file-contents requires ${o} to be a non-negative integer`}),!0;let F=await B().inspectFileContents({cardId:n,fileIdx:s}),$=typeof F?.stored_name=="string"?F.stored_name:null,{fileRecord:R,bytes:p}=await j(n,s,$),P=String(R.name||R.stored_name||"download.bin"),w=String(R.mime_type||"application/octet-stream"),g=(M.searchParams.get("resp")||"").trim().toLowerCase();if(g&&g!=="json-b64")return r(e,400,{error:`unsupported resp mode: ${g}`}),!0;let U=g==="json-b64",c;if(d!==void 0||m!==void 0){if(!v(w))return r(e,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let o=new TextDecoder().decode(p),u=d!==void 0?C(o,"head",d):C(o,"tail",m);c=typeof Buffer<"u"?Buffer.from(u,"utf8"):new TextEncoder().encode(u);}else if(f!==void 0||y!==void 0){let o=f??y;c=f!==void 0?p.slice(0,o):p.slice(Math.max(0,p.length-o));}else c=p;if(U){let o=typeof Buffer<"u"?Buffer.from(c).toString("base64"):btoa(String.fromCharCode(...c));return r(e,200,{bodyBase64:o,mimeType:w,filename:P,byteLength:c.length}),!0}return e.writeHead(200,{"Content-Type":w,"Content-Disposition":`attachment; filename="${P}"`,"Content-Length":c.length}),e.end(c),!0}return !1}catch(t){let i=t?.statusCode||500;return r(e,i,{error:String(t?.message||t)}),true}}return {handleAgentfaceApi:D}}export{G as a};//# sourceMappingURL=chunk-NTICU4OK.js.map
2
+ //# sourceMappingURL=chunk-NTICU4OK.js.map
@@ -0,0 +1,2 @@
1
+ function u(n,...r){for(let e of r)if(typeof n[e]=="string")return String(n[e]);return ""}function s(n,...r){for(let e of r)if(n[e]!==void 0)return Number(n[e])}function c(n,...r){for(let e of r){let t=n[e];if(t&&typeof t=="object"&&!Array.isArray(t))return t}return {}}function f(n,r,...e){for(let t of e){let o=n[t];if(o&&typeof o=="object"&&!Array.isArray(o))return o}throw Object.assign(new Error(`MCP tool requires ${r}`),{statusCode:400})}function d(n,r,...e){for(let t of e){let o=n[t];if(o!==void 0){let i=Number(o);if(Number.isFinite(i))return i}}throw Object.assign(new Error(`MCP tool requires ${r}`),{statusCode:400})}function g(n){if(Array.isArray(n.bytes))return new Uint8Array(n.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof n.text=="string")return new TextEncoder().encode(n.text);if(typeof n.base64=="string"){let r=String(n.base64).replace(/-/g,"+").replace(/_/g,"/"),e=r+"=".repeat((4-r.length%4)%4),t=atob(e);return Uint8Array.from(t,o=>o.charCodeAt(0))}return null}export{u as a,s as b,c,f as d,d as e,g as f};//# sourceMappingURL=chunk-O7NOHKVR.js.map
2
+ //# sourceMappingURL=chunk-O7NOHKVR.js.map
@@ -0,0 +1,2 @@
1
+ import {a as a$1}from'./chunk-JMDHDY6M.js';function A(s,i){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function H(s,i){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${i} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${i} failed`):new Error(`${i} returned an unexpected response`)}function a(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function y(s){return Array.isArray(s)?s:[]}function N(s,i){if(typeof i!="string"||i.length===0)return;let c=s,u=i;u.startsWith("fetched_sources.")&&(c=a(s).fetched_sources,u=u.slice(16));for(let p of u.split(".")){if(c==null||typeof c!="object")return;c=c[p];}return c}function V(s,i){let c=a(s.view),u=y(c.elements);return {layout:c.layout,features:c.features,elements:u.map((p,k)=>{let R=a(p),b=a(R.data),h=typeof R.visible=="string"?!!N(i,R.visible):true,U=typeof b.bind=="string"?b.bind:void 0,S=typeof b.maxRows=="number"?b.maxRows:void 0,B=U?N(i,U):void 0,F={id:typeof R.id=="string"&&R.id?R.id:`element-${k}`,kind:R.kind,label:R.label,visible:h};return B!==void 0&&(F.resolved=Array.isArray(B)&&typeof S=="number"?B.slice(0,S):B),F})}}function G(s,i){let c=typeof s.id=="string"&&s.id?s.id:"card",u=y(s.provides),p=u.length>0?u:[{bindTo:c,ref:"card_data"}],k={};for(let R of p){let b=a(R),h=typeof b.bindTo=="string"?b.bindTo:"",U=typeof b.ref=="string"?b.ref:"";if(!h||!U)continue;let S=N(i,U);S!==void 0&&(k[h]=S);}return k}function be(s){if(typeof s!="string"||!s.trim())return null;let i=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!i)return null;let c=Number.parseInt(i[2],10);return !Number.isInteger(c)||c<0?null:c}function he(s){return {"card-content":s}}function E(s){let{meta:i,...c}=s;return c}function ke(s,i){return Object.prototype.hasOwnProperty.call(s,i)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,i){let c=Re(s);if(!i||Object.keys(i).length===0)return c;function u(p,k,R){let b=String(k||"").split(".").filter(Boolean);if(!b.length)return;let h=p;for(let U=0;U<b.length-1;U+=1){let S=b[U];(!h[S]||typeof h[S]!="object")&&(h[S]={}),h=h[S];}h[b[b.length-1]]=R;}if(i.fieldValues!==void 0&&i.fieldValues!==null){let p=null,k=a(c.view),R=y(k.elements);for(let b of R){let h=a(a(b).data);if(typeof h.writeTo=="string"&&h.writeTo){p=h.writeTo;break}}return p?u(c,p,i.fieldValues):typeof i.fieldValues=="object"&&!Array.isArray(i.fieldValues)&&(c.card_data={...a(c.card_data),...i.fieldValues}),c}if(Array.isArray(i._stagedFiles)&&i._stagedFiles.length>0)return c;for(let[p,k]of Object.entries(i))p!=="_stagedFiles"&&(k!==null&&typeof k=="object"&&!Array.isArray(k)&&c[p]!==null&&typeof c[p]=="object"&&!Array.isArray(c[p])?c[p]={...c[p],...k}:c[p]=k);return c}function Q(s){return a(s.meta).__visible_controlplane_only===true}async function T(s,i){let c=await M(s.get({params:{id:i}}),"cardStore.get"),u=Array.isArray(c?.cards)?c.cards:[];if(u.length===0)throw new Error(`Card "${i}" not found`);return u[0]}function Ae(s){let{board:i,nonCore:c,cardStore:u,chatStore:p,processAccumulated:k,sourceFetchDone:R,sourceFetchFailed:b,uploadCardFile:h,buildFileDownloadUrl:U,readFetchedSourceJsonByRef:S}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function F(){let e=await M(u.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>a(r)):[]}function X(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),n=atob(t);return Uint8Array.from(n,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=a(await M(c.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:a(e.commonSourceDefFields),sourceKinds:a(e.sourceKinds)}}async function Z(){let e=a(await M(i.status({}),"status")),r=a(e.summary),t=y(e.cards);return {meta:a(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:t.map(n=>{let o=a(n);return {"card-id":typeof o.name=="string"?o.name:null,status:o.status??null,error:o.error??null,requires:y(o.requires),requires_satisfied:y(o.requires_satisfied),requires_missing:y(o.requires_missing),provides_declared:y(o.provides_declared),provides_runtime:y(o.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=a(await M(i.status({}),"status")),o=y(t.cards).map(a).find(m=>m.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let d=a(await T(u,r));if(Q(d))throw Object.assign(new Error(`card "${r}" not found`),{statusCode:404});let f=E(d),g=y(o.requires_satisfied).filter(m=>typeof m=="string"&&!!m),_=y(o.provides_runtime).filter(m=>typeof m=="string"&&!!m),v=Object.fromEntries(await Promise.all(g.map(async m=>[m,await M(i.getOutputsDataObject({params:{key:m}}),`getOutputsDataObject(${m})`)]))),I=Object.fromEntries(await Promise.all(_.map(async m=>[m,await M(i.getOutputsDataObject({params:{key:m}}),`getOutputsDataObject(${m})`)]))),w=a(await M(i.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),l=await M(i.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),P=y(d.source_defs).map(a),C={};for(let m of P)typeof m.bindTo=="string"&&typeof m.outputFile=="string"&&(C[m.outputFile]=m.bindTo);let x={};for(let[m,O]of Object.entries(l)){let q=C[m]??m;if(!S||typeof O!="string"){x[q]=null;continue}try{x[q]=S({cardId:r,ref:O});}catch{x[q]=null;}}let L={card_data:a(d.card_data),requires:v,fetched_sources:x,computed_values:w};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:f,refs_for_fetched_source_files:l,runtime_data:{requires:v,provides:I,computed_values:w,rendered_view:V(d,L)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",n=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",d=n?void 0:e.lastUserTurns??(t?void 0:1),f=e.tail,g={...d===void 0?{}:{tailTurns:d},...t?{turnId:t}:{},...n?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},_=Object.keys(g).length>0?{params:{cardId:r},body:g}:{params:{cardId:r}},v=A(p.readAll(_),"chatStore.readAll"),I=a(await T(u,r)),w=y(a(I.card_data).files).map((C,x)=>({idx:x,stored_name:a(C).stored_name})).filter(C=>typeof C.stored_name=="string"&&C.stored_name.length>0),P=(Array.isArray(v.records)?v.records:[]).map(C=>{let L=a(C.payload),m={...C},O=typeof C?.role=="string"?C.role:typeof L.role=="string"?String(L.role):"",q=typeof C?.text=="string"?C.text:typeof L.text=="string"?String(L.text):"";if(O==="system"){let $=be(q);if($!==null&&w.some(j=>j.idx===$)){let j=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${$}`;m.retrieval_hint=j,Object.keys(L).length>0&&typeof C.role!="string"&&(m.payload={...L,retrieval_hint:j});}}return m});return {cardId:r,messages:typeof f=="number"&&f>=0?P.slice(-f):P}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let n=a(await T(u,r)),o=y(a(n.card_data).files).map(a);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let d=o[t],f=typeof d.stored_name=="string"?d.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:U({cardId:r,fileIdx:t,storedName:f}),...typeof d.name=="string"?{name:d.name}:{},...typeof d.stored_name=="string"?{stored_name:d.stored_name}:{},...typeof d.mime_type=="string"?{mime_type:d.mime_type}:{},...typeof d.size=="number"?{size:d.size}:{},...typeof d.uploaded_at=="string"?{uploaded_at:d.uploaded_at}:{}}}async function D(e){return await c.validateCardPreflight({body:he(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=c.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=a(H(r,"evalCardCompute")),n=a(e.candidateCardContent),o={card_data:a(n.card_data),requires:a(e.mockRequires),fetched_sources:a(e.mockFetchedSources),computed_values:a(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof n.id=="string"?n.id:"(unknown)",ok:t.ok===true,computed_values:a(t.computed_values),errors:y(t.errors).map(d=>{let f=a(d);return {bindTo:typeof f.bindTo=="string"?f.bindTo:"",error:typeof f.error=="string"?f.error:""}}),provides_outputs:G(n,o),rendered_view:V(n,o)}}}async function ae(e){return await c.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=a(await T(u,r)),n=y(t.source_defs).filter(d=>!!d&&typeof d=="object"&&!Array.isArray(d)),o={};if(e.sourceIdx>=0&&e.sourceIdx<n.length){let d=n[e.sourceIdx],f=a$1.enrichSourcesSync([d],{card_data:a(t.card_data),requires:e.mockRequires});Array.isArray(f)&&f.length>0&&(o=a(f[0]._projections));}return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=a(await M(c.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=a(e.candidateCardContent),n=a(r.validation),o=y(r.source_probes),d=y(r.projection_errors),f=a(r.fetched_sources),g=y(r.compute_errors),_=a(r.computed_values),v={card_data:a(t.card_data),requires:e.mockRequires,fetched_sources:f,computed_values:_},I=[];for(let w of y(n.issues))typeof w=="string"&&w&&I.push(w);for(let w of o){let l=a(w),P=typeof l.bindTo=="string"?l.bindTo:"source",C=typeof l.error=="string"?l.error:"";C&&I.push(`${P}: ${C}`);}for(let w of d){let l=a(w),P=typeof l.bindTo=="string"?l.bindTo:"source",C=typeof l.key=="string"?l.key:"projection",x=typeof l.error=="string"?l.error:"projection failed";I.push(`${P}.${C}: ${x}`);}for(let w of g){let l=a(w),P=typeof l.bindTo=="string"?l.bindTo:"compute",C=typeof l.error=="string"?l.error:"compute failed";I.push(`${P}: ${C}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:I,provides_outputs:G(t,v),rendered_view:V(t,v)}}}async function z(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await M(u.get({params:{id:r}}),"cardStore.get"),n=Array.isArray(t.cards)?t.cards.map(a):[];if(n.some(Q))throw Object.assign(new Error(`Card "${r}" not found`),{statusCode:404});return n.map(o=>E(o))}async function K(e){let r=await Promise.all(y(e.files).map(async t=>{let n=a(t),o=String(n.file_name??n.fileName??n.name??"").trim(),d=String(n.content_type??n.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await h({cardId:e.cardId,fileName:o,contentType:d,bytes:X(n)})}));return r.forEach((t,n)=>{let o=a(t.file),d=typeof t.file_idx=="number"&&Number.isInteger(t.file_idx)&&t.file_idx>=0?t.file_idx:n,f=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${d}`;A(p.append({params:{cardId:e.cardId},body:{role:"system",text:f,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}),r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",n=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await K({cardId:r,role:t,turn:n,files:e.files});return {status:"success",data:{cardId:r,turn:n,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),n=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let g=A(p.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),_=Array.isArray(g.records)?g.records.find(v=>v.role==="assistant"&&String(v.turn||"")===o):void 0;if(_)return {status:"success",data:{cardId:r,id:String(_.id),role:t,turn:o,files:Array.isArray(_.files)?_.files:[]}}}let d=await K({cardId:r,role:t,turn:o,files:e.files}),f=A(p.append({params:{cardId:r},body:{role:t,text:n,files:d,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(f.id),role:t,turn:o,files:d}}}async function ue(e){let r=String(e.cardId||"").trim(),t=a(e.patch);if(!r)throw new Error("managePatchCard requires cardId");let n=await z({cardId:r}),o=a(n[0]),d=ve(o,t);return J({cardId:r,candidateCardContent:d})}async function J(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("manageUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await D({candidateCardContent:n}),d=a(o),f=a(d.data);if(d.status!=="success"||f.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let _=g&&ke(a(g),"meta")?{...n,meta:a(g).meta}:n,v=await u.set({body:_});A(v,"cardStore.set");let I;try{I=await i.upsertCard({params:{cardId:r,restart:!0}}),A(I,"upsertCard");}catch(l){try{g&&await u.set({body:g});}catch{}throw l}let w=null;try{w=await i.cardRefreshedNotify({params:{cardId:r}}),A(w,"cardRefreshedNotify");}catch{w=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:I,refresh_notify:w}}}async function le(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageRemoveCard requires cardId");let t=await i.removeCard({params:{id:r}});A(t,"removeCard");let n=await u.del({params:{id:r}});return A(n,"cardStore.del"),{status:"success",data:{board_result:t,store_result:n}}}async function me(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await M(u.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(n=>a(n)):[]}async function pe(e){let r=String(e.cardId||"").trim(),t=a(e.candidateCardContent),n=E(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof n.id!="string"||!n.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(n.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await D({candidateCardContent:n}),d=a(o),f=a(d.data);if(d.status!=="success"||f.isValid!==true)return {status:"fail",step:"validate",validation:o};let g=null;try{g=await T(u,r);}catch{g=null;}let _=g?a(a(g).meta):{},v={...n,meta:{..._,__visible_controlplane_only:true}},I=await u.set({body:v});A(I,"cardStore.set");let w;try{w=await i.upsertCard({params:{cardId:r,restart:!0}}),A(w,"upsertCard");}catch(P){try{g&&await u.set({body:g});}catch{}throw P}let l=null;try{l=await i.cardRefreshedNotify({params:{cardId:r}}),A(l,"cardRefreshedNotify");}catch{l=null;}return {status:"success",data:{validation:o,card_saved:null,board_result:w,refresh_notify:l}}}function fe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=H(p.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return A(p.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function we(){let e=await B(k,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function Ce(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let n=await B(R,"webhook.source-fetch-done")({token:r,ref:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let n=await B(b,"webhook.source-fetch-failed")({token:r,reason:t});return n?.status==="fail"||n?.status==="error"?n:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(n??{},"data")?n.data??null:null}}}return {listRuntimeCards:F,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:D,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:z,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:J,manageRemoveCard:le,adminReadCard:me,adminUpsertCard:pe,getChatProcessing:fe,setChatProcessing:ge,webhookProcessAccumulated:we,webhookSourceFetchDone:Ce,webhookSourceFetchFailed:ye}}async function M(s,i){return A(await s,i)}export{Ae as a};//# sourceMappingURL=chunk-PRHQBGPT.js.map
2
+ //# sourceMappingURL=chunk-PRHQBGPT.js.map
@@ -0,0 +1,2 @@
1
+ function T(e){if(!e||typeof e!="object")return;let t=e;if(typeof t.statusCode=="number")return t.statusCode;if(typeof t.code=="number")return t.code}function c(e,t){return T(e)===t}function l(e,t,r){return t?typeof t=="function"?t(e):t:r}function b(e){return (e?.()??new Date).toISOString()}function L(e,t){if(t)return t();let r=String((e?.()??new Date).getTime()).padStart(13,"0"),n=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${r}-${n}`}function p(e){return {id:e.id,payload:e.payload}}function B(e,t={}){return {async read(r){let n=l(r,t.partitionKey,"kv");try{return (await e.item(r,n).read()).resource?.value??null}catch(o){if(c(o,404))return null;throw o}},async write(r,n){let o=l(r,t.partitionKey,"kv");await e.items.upsert({id:r,pk:o,kind:"kv",value:n});},async delete(r){let n=l(r,t.partitionKey,"kv");try{await e.item(r,n).delete();}catch(o){if(!c(o,404))throw o}},async listKeys(r=""){let{resources:n}=await e.items.query({query:"SELECT c.id FROM c WHERE c.kind = @kind AND STARTSWITH(c.id, @prefix)",parameters:[{name:"@kind",value:"kv"},{name:"@prefix",value:r}]}).fetchAll();return n.map(o=>o.id).sort()}}}function x(e,t,r={}){let n=l(t,r.partitionKey,`journal:${t}`);return {async append(o){let s={id:L(r.now,r.idFactory),pk:n,kind:"journal",streamKey:t,createdAt:b(r.now),payload:o};return await e.items.create(s),p(s)},async readAll(){let{resources:o}=await e.items.query({query:"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:n},{name:"@streamKey",value:t}]}).fetchAll();return o.sort((s,a)=>s.id.localeCompare(a.id)).map(p)},async readAfter(o){let{resources:s}=await e.items.query({query:o?"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey AND c.id > @cursor ORDER BY c.id":"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:n},{name:"@streamKey",value:t},...o?[{name:"@cursor",value:o}]:[]]}).fetchAll(),a=s.sort((m,g)=>m.id.localeCompare(g.id));return {entries:a.map(p),newCursor:a.length>0?a[a.length-1].id:o}},async clear(){let o=await this.readAll();await Promise.all(o.map(s=>e.item(s.id,n).delete()));}}}function D(e,t,r={}){let n=r.partitionKey??"lock",o=r.holderId??`holder-${Math.random().toString(36).slice(2,10)}`,s=r.now,a=r.ttlMs??3e4;function m(){let i=s?.()??new Date;return {id:t,pk:n,kind:"lock",held:true,holderId:o,expiresAt:new Date(i.getTime()+a).toISOString(),updatedAt:i.toISOString()}}function g(i){return {...i??{id:t,pk:n,kind:"lock"},kind:"lock",held:false,holderId:o,expiresAt:null,updatedAt:b(s)}}async function k(){try{return (await e.item(t,n).read()).resource??null}catch(i){if(c(i,404))return null;throw i}}function S(i){return i?.held?i.expiresAt?Date.parse(i.expiresAt)>(s?.()??new Date).getTime():true:false}return {async tryAcquire(){let i=await k(),A=m();if(i){if(S(i))return null;try{await e.item(t,n).replace(A,i._etag?{accessCondition:{type:"IfMatch",condition:i._etag}}:void 0);}catch(u){if(c(u,412)||c(u,409))return null;throw u}}else try{await e.items.create(A);}catch(u){if(c(u,409))return null;throw u}return async()=>{let u=await k();if(!u)return;let w=g(u);try{await e.item(t,n).replace(w,u._etag?{accessCondition:{type:"IfMatch",condition:u._etag}}:void 0);}catch{}}}}}function M(e){return new TextDecoder().decode(e)}function P(e,t={}){return {async read(r){if(!await e.getBlobClient(r).exists())return null;let n=await e.getBlobClient(r).downloadToBuffer();return M(n)},async write(r,n){await e.getBlockBlobClient(r).upload(n,new TextEncoder().encode(n).byteLength,{blobHTTPHeaders:{blobContentType:t.defaultContentType??"application/json; charset=utf-8"}});},exists(r){return e.getBlobClient(r).exists()},async remove(r){await e.getBlobClient(r).deleteIfExists();},async readBytes(r){return await e.getBlobClient(r).exists()?await e.getBlobClient(r).downloadToBuffer():null},async writeBytes(r,n){await e.getBlockBlobClient(r).upload(n,n.byteLength,{blobHTTPHeaders:{blobContentType:t.defaultContentType??"application/octet-stream"}});},async listKeys(r=""){let n=[];for await(let o of e.listBlobsFlat({prefix:r}))n.push(o.name);return n.sort()},async stat(r){if(!await e.getBlobClient(r).exists())return null;let n=await e.getBlobClient(r).getProperties();return {key:r,size:Number(n.contentLength??0),updatedAt:n.lastModified?.toISOString(),contentType:n.contentType}},keyRef(r){return t.keyRef?.(r)??{kind:"azure-blob-key",value:r}}}}function C(e){if(!e||typeof e!="object")return;let t=e;if(typeof t.statusCode=="number")return t.statusCode;if(typeof t.code=="number")return t.code}function y(e){let t=JSON.stringify(e),r=globalThis.Buffer;if(r)return r.from(t,"utf-8").toString("base64");if(typeof btoa=="function")return btoa(t);throw new Error("No base64 encoder available in this runtime")}function f(e){let t=e??"",r=globalThis.Buffer;if(r)return JSON.parse(r.from(t,"base64").toString("utf-8"));if(typeof atob=="function")return JSON.parse(atob(t));throw new Error("No base64 decoder available in this runtime")}function d(e,t){return (e??t()).toISOString()}function v(e,t){return {id:String(e.messageId??""),body:f(e.messageText),enqueuedAt:d(e.insertedOn??e.insertionTime,t),attempt:Number(e.dequeueCount??0)}}function h(e,t){return {id:String(e.messageId??""),body:f(e.messageText),enqueuedAt:d(e.insertedOn??e.insertionTime,t),attempt:Number(e.dequeueCount??0),leaseToken:String(e.popReceipt??""),leaseExpiresAt:d(e.nextVisibleOn,t)}}function R(e,t={}){let r=t.now??(()=>new Date);return {async enqueue(n){let o=await e.sendMessage(y(n));return {id:String(o.messageId??""),body:n,enqueuedAt:d(o.insertionTime,r),attempt:0}},async lease(n){return (await e.receiveMessages({numberOfMessages:n?.max,visibilityTimeout:n?.visibilityMs?Math.max(1,Math.ceil(n.visibilityMs/1e3)):void 0})).receivedMessageItems.map(s=>h(s,r))},async ack(n,o){try{return await e.deleteMessage(n,o),!0}catch(s){if(C(s)===404)return false;throw s}},async nack(n,o,s){try{if(s?.dead){if(!t.deadLetterQueueClient)return !1;let a={messageId:n,reason:s.reason??null};return await t.deadLetterQueueClient.sendMessage(y(a)),await e.deleteMessage(n,o),!0}return await e.updateMessage(n,o,y({requeued:!0}),0),!0}catch(a){if(C(a)===404)return false;throw a}},async peekActive(n=""){return (await e.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>v(s,r)).filter(s=>!n||s.id.startsWith(n))},async peekDeadLetter(n=""){return t.deadLetterQueueClient?(await t.deadLetterQueueClient.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>{let a=f(s.messageText);return {id:String(s.messageId??""),body:a,enqueuedAt:d(s.insertedOn??s.insertionTime,r),attempt:Number(s.dequeueCount??0),reason:typeof a.reason=="string"?a.reason:void 0}}).filter(s=>!n||s.id.startsWith(n)):[]}}}export{B as a,x as b,D as c,P as d,R as e};//# sourceMappingURL=chunk-S44QZUDX.js.map
2
+ //# sourceMappingURL=chunk-S44QZUDX.js.map
@@ -0,0 +1,2 @@
1
+ import {b}from'./chunk-BQS3EIEK.js';function p(t){return typeof t.journalStorage=="function"}function s(t){return typeof t.whatToRun=="string"?t.whatToRun.startsWith("b64:")?b(t.whatToRun).value:t.whatToRun:t.whatToRun.value}function c(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function f(t){let a=t.reduce((r,u)=>r+u.length,0),o=new Uint8Array(a),n=0;for(let r of t)o.set(r,n),n+=r.length;return o}export{p as a,s as b,c,f as d};//# sourceMappingURL=chunk-SGV7PU4H.js.map
2
+ //# sourceMappingURL=chunk-SGV7PU4H.js.map
@@ -0,0 +1,4 @@
1
+ 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 _(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 K(o){let r=k(o),S=_(r,2166136261),u=_(r,3735928559),h=_(r,19088743),s=_(r,4277009102);return [S,u,h,s].map(i=>i.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 i="";for(let n=0;n<s.length;n++)i+=String.fromCharCode(s[n]);return btoa(i)}return ""}function h(s){if(typeof atob=="function"){let i=atob(s),n=new Uint8Array(i.length);for(let a=0;a<i.length;a++)n[a]=i.charCodeAt(a);return n}return new Uint8Array}return {read(s){return globalThis.localStorage.getItem(r(s))},write(s,i){globalThis.localStorage.setItem(r(s),i);},exists(s){return globalThis.localStorage.getItem(r(s))!==null},remove(s){globalThis.localStorage.removeItem(r(s));},readBytes(s){let i=globalThis.localStorage.getItem(r(s));if(i===null)return null;try{let n=JSON.parse(i);if(n&&n.__kind==="bytes-b64"&&typeof n.data=="string")return h(n.data)}catch{}return S.encode(i)},writeBytes(s,i){let n=JSON.stringify({__kind:"bytes-b64",data:u(i)});globalThis.localStorage.setItem(r(s),n);},listKeys(s){let i=r(s??""),n=[];for(let a=0;a<globalThis.localStorage.length;a++){let l=globalThis.localStorage.key(a);l&&l.startsWith(i)&&n.push(l.slice(r("").length));}return n.sort()},stat(s){let i=globalThis.localStorage.getItem(r(s));if(i===null)return null;let n=S.encode(i).byteLength;try{let a=JSON.parse(i);a&&a.__kind==="bytes-b64"&&typeof a.data=="string"&&(n=h(a.data).byteLength);}catch{}return {key:s,size:n}}}}var N=":scratch-marker",C=":scratch-config",A=":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}${A}${t}`,h=t=>`${o}${A}${t}:__ts`,s=globalThis.localStorage.getItem(r)===null;if(s)try{globalThis.localStorage.setItem(r,`scratch-store
2
+ ${new Date().toISOString()}`);}catch{}function i(){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=i();typeof t["retention.lastSweepAt"]!="number"&&(t["retention.lastSweepAt"]=Date.now(),n(t));}function a(){if(globalThis.localStorage.getItem(r)===null)return;let t=i(),e=typeof t["retention.maxAgeMs"]=="number"?t["retention.maxAgeMs"]:L,c=typeof t["retention.sweepIntervalMs"]=="number"?t["retention.sweepIntervalMs"]:O;if(e<=0||c<=0)return;let g=typeof t["retention.lastSweepAt"]=="number"?t["retention.lastSweepAt"]:0,y=Date.now();if(y-g<c)return;t["retention.lastSweepAt"]=y,n(t);let f=y,m=`${o}${A}`,b=[];for(let p=0;p<globalThis.localStorage.length;p++){let w=globalThis.localStorage.key(p);w&&w.startsWith(m)&&!w.endsWith(":__ts")&&b.push(w);}for(let p of b){if(Date.now()-f>B)break;let w=globalThis.localStorage.getItem(`${p}:__ts`),I=w===null?0:Number(w);if(Number.isFinite(I)&&I>0&&y-I>e){try{globalThis.localStorage.removeItem(p);}catch{}try{globalThis.localStorage.removeItem(`${p}:__ts`);}catch{}}}}function l(t,e){let c=$(t,"scratch"),g=$(e,".json"),y=g.startsWith(".")?g:`.${g}`,f=Math.random().toString(36).slice(2,10);return `${c}-${Date.now()}-${f}${y}`}function d(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){d(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 c="";for(let g=0;g<e.length;g++)c+=String.fromCharCode(e[g]);d(t,c);try{a();}catch{}},stat(t){let e=globalThis.localStorage.getItem(u(t));if(e===null)return null;let c=globalThis.localStorage.getItem(h(t)),g=c===null?null:Number(c);return {key:t,size:new TextEncoder().encode(e).byteLength,updatedAt:g!==null&&Number.isFinite(g)?new Date(g).toISOString():void 0}},listKeys(t){let e=`${o}${A}`,c=[];for(let g=0;g<globalThis.localStorage.length;g++){let y=globalThis.localStorage.key(g);if(y&&y.startsWith(e)&&!y.endsWith(":__ts")){let f=y.slice(e.length);(!t||f.startsWith(t))&&c.push(f);}}return c.sort()},getUniqueKey(t,e){return l(t,e)},create(t,e,c){let g=l(e,c);d(g,t);try{a();}catch{}return g},keyRef(t){return {kind:"local-storage-scratch",value:t,extra:{prefix:o}}},config:{get(t){return i()[t]??null},set(t,e){let c=i();e==null?delete c[t]:c[t]=e,n(c);}}}}var M=":archive-marker",R=":archive-config",T=":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}${T}${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 i(){if(globalThis.localStorage.getItem(r)===null)return;let n=h(),a=typeof n["retention.maxAgeMs"]=="number"?n["retention.maxAgeMs"]:0,l=typeof n["retention.sweepIntervalMs"]=="number"?n["retention.sweepIntervalMs"]:0;if(a<=0||l<=0)return;let d=typeof n["retention.lastSweepAt"]=="number"?n["retention.lastSweepAt"]:0,t=Date.now();if(t-d<l)return;n["retention.lastSweepAt"]=t,s(n);let e=`${o}${T}`;for(let c=0;c<globalThis.localStorage.length;c++){let g=globalThis.localStorage.key(c);if(!g||!g.startsWith(e))continue;let y=globalThis.localStorage.getItem(g);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(g,JSON.stringify(m));}catch{}}}return {stream(n){let a=E(n),l=u(a);function d(){let e=globalThis.localStorage.getItem(l);if(!e)return [];try{return JSON.parse(e)}catch{return []}}function t(e){try{globalThis.localStorage.setItem(l,JSON.stringify(e));}catch{}}return {append(e){let c={id:globalThis.crypto.randomUUID(),payload:e,__ts:Date.now()},g=d();g.push(c),t(g);try{i();}catch{}return {id:c.id,payload:c.payload}},readAll(){return d().map(e=>({id:e.id,payload:e.payload}))},readAfter(e){let c=d();if(!e){let m=c.map(b=>({id:b.id,payload:b.payload}));return {entries:m,newCursor:m.length>0?m[m.length-1].id:null}}let g=c.findIndex(m=>m.id===e),f=(g===-1?c:c.slice(g+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(l);}catch{}}}},blob(n){let a=E(n),l=J(`${o}${v}${a}`);return {read:d=>l.read(d),write:(d,t)=>{l.write(d,t);try{i();}catch{}},exists:d=>l.exists(d),remove:d=>l.remove(d),readBytes:l.readBytes?d=>l.readBytes(d):void 0,writeBytes:l.writeBytes?(d,t)=>{l.writeBytes(d,t);try{i();}catch{}}:void 0,listKeys:d=>l.listKeys(d),stat:l.stat?d=>l.stat(d):void 0}},listStreams(n){let a=`${o}${T}`,l=[];for(let d=0;d<globalThis.localStorage.length;d++){let t=globalThis.localStorage.key(d);if(!t||!t.startsWith(a))continue;let e=t.slice(a.length);(!n||e.startsWith(n))&&l.push(e);}return l.sort()},listBlobs(n){let a=`${o}${v}`,l=new Set;for(let d=0;d<globalThis.localStorage.length;d++){let t=globalThis.localStorage.key(d);if(!t||!t.startsWith(a))continue;let e=t.slice(a.length),c=e.indexOf(":"),g=c===-1?e:e.slice(0,c);(!n||g.startsWith(n))&&l.add(g);}return Array.from(l).sort()},config:{get(n){return h()[n]??null},set(n,a){let l=h();a==null?delete l[n]:l[n]=a,s(l);}}}}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 i=globalThis.localStorage.key(s);i!==null&&i.startsWith(u)&&h.push(i.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()}}}export{K as a,J as b,W as c,D as d,j as e,H as f};//# sourceMappingURL=chunk-TSN3RTXT.js.map
4
+ //# sourceMappingURL=chunk-TSN3RTXT.js.map
@@ -0,0 +1,2 @@
1
+ function a(e){return {lanes:e}}export{a};//# sourceMappingURL=chunk-VXJHBWK3.js.map
2
+ //# sourceMappingURL=chunk-VXJHBWK3.js.map
@@ -0,0 +1,7 @@
1
+ import {c}from'./chunk-SGV7PU4H.js';function A(h){let r=new Map,a=new Map,d=new Map,I=0,b=null;function g(e){let t=JSON.stringify(e);return I++,`id: ${I}
2
+ data: ${t}
3
+
4
+ `}function C(e){let t=e;try{t.flushHeaders?.();}catch{}try{t.flush?.();}catch{}try{t.socket?.setNoDelay?.(!0);}catch{}try{t.socket?.uncork?.();}catch{}}function y(e,t){let s=r.get(e);if(s&&!(t&&s.res!==t)){r.delete(e),w();try{h.onSseClientDisconnected?.(e);}catch{}try{s.res.end();}catch{}}}function v(e,t,s){let n=r.get(e);n&&y(e,n.res),r.set(e,{res:t,subscribedChatCardIds:s??new Set});}function f(e,t){let s=r.get(e);if(!s)return;let n=g(t);try{s.res.write(n),C(s.res);}catch{y(e,s.res);}}function c(){let e=new Set;for(let t of r.values())for(let s of t.subscribedChatCardIds)e.add(s);return Array.from(e)}function l(e){let t=a.has(e)?a.get(e):null,{cursor:s}=h.chatStorage.readAfter(e,t),n=h.chatStorage.isProcessing(e),o=n!==(d.get(e)??false),S=s!==t;return S&&a.set(e,s),d.set(e,n),S||o}function u(e,t){let s=h.readChatRecords(e),n=Date.now();return {kind:"card_chats",cardId:e,sentAt:new Date(n).toISOString(),sentAtMs:n,messages:s.map(o=>({role:String(o.role||"system"),text:String(o.text||""),files:Array.isArray(o.files)?o.files:[]})),receiving:t,processing:h.chatStorage.isProcessing(e)}}function i(e,t=true){let s={kind:"notification-batch",notifications:[u(e,t)]};for(let[n,o]of r.entries())o.subscribedChatCardIds.has(e)&&f(n,s);}function w(){c().length>0||(b&&(clearInterval(b),b=null),a.clear(),d.clear());}function p(){if(b)return;let e=()=>{let t=c();if(t.length===0){w();return}let s=new Set(t);for(let n of Array.from(a.keys()))s.has(n)||a.delete(n);for(let n of Array.from(d.keys()))s.has(n)||d.delete(n);for(let n of t)l(n)&&i(n,true);};e(),b=setInterval(e,1e3);}function k(e,t){let s=r.get(e);if(!s)return false;s.subscribedChatCardIds.add(t);let{cursor:n}=h.chatStorage.readAfter(t,null);return a.set(t,n),d.set(t,h.chatStorage.isProcessing(t)),p(),f(e,{kind:"notification-batch",notifications:[u(t,true)]}),true}function m(e,t){let s=r.get(e);return s?(s.subscribedChatCardIds.delete(t),c().includes(t)||(a.delete(t),d.delete(t)),w(),true):false}function R(e){if(!e||typeof e!="object")return false;let t=e.kind;return t==="card_chats"||t==="chat_messages"}function P(e){if(!e||e.length===0)return;let t=[],s=new Set;for(let n of e)R(n)&&typeof n.cardId=="string"?s.add(String(n.cardId)):t.push(n);if(t.length>0){let n={kind:"notification-batch",notifications:t};for(let o of r.keys())f(o,n);}for(let n of s)i(n,true);}return {size:()=>r.size,has:e=>r.has(e),get:e=>r.get(e),buildFrame:g,flushTransport:C,register:v,disconnect:y,writeFrame:f,subscribeChat:k,unsubscribeChat:m,broadcastNotificationBatch:P,broadcastCardChats:i}}function D(h){let{sseHub:r,corsHeaders:a,json:d,buildPublishedRuntimePayload:I,onSseClientConnected:b,onChannelSubscribed:g,onChannelUnsubscribed:C}=h;function y(f,c,l,u,i){if(!r.has(c)){d(f,404,{error:`SSE client not connected: ${c}`});return}i?g?.(c,l,u):C?.(c,l,u),d(f,200,{ok:true,clientId:c,channelName:l,...u.cardId?{cardId:u.cardId}:{},subscribed:i});}async function v(f,c,l){let u=r.get(l),i=u?new Set(u.subscribedChatCardIds):new Set;c.writeHead(200,{...a,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),r.flushTransport(c),r.register(l,c,i);let w=await I(),p=r.buildFrame(w);c.write(p);try{b?.(l,m=>{r.writeFrame(l,m);});}catch{}let k=setInterval(()=>{try{c.write(`: keepalive
5
+
6
+ `);}catch{}},15e3);f.on("close",()=>{clearInterval(k),r.disconnect(l,c);});}return {handleChannelSubscription:y,handleSse:v}}function T(h){let{apiBasePath:r,json:a,readJsonBody:d,initBoardAndSetup:I,bootstrapBoard:b,boardContexts:g,publishPersistedStateSnapshot:C,upsertCardsFromSource:y,sseHub:v}=h,{handleSse:f,handleChannelSubscription:c$1}=D(h);async function l(u,i,w){let p=u.method||"GET",k=w,m=k.pathname;try{if(p==="GET"&&m===`${r}/sse`){await I();let s=String(k.searchParams.get("clientId")||"").trim();if(!s)return a(i,400,{error:"clientId query param is required for SSE"}),!0;await f(u,i,s);for(let n=0;n<g.length;n++)await C(g[n]),await y(g[n],n),await C(g[n]);return !0}let R=m.match(new RegExp(`^${c(r)}/cards/([^/]+)/chats/subscribe-sse$`));if(p==="POST"&&R){await b();let s=decodeURIComponent(R[1]),n=await d(u),o=typeof n?.clientId=="string"?n.clientId.trim():"";return o?v.subscribeChat(o,s)?(a(i,200,{ok:!0,clientId:o,cardId:s,subscribed:!0}),!0):(a(i,404,{error:`SSE client not connected: ${o}`}),!0):(a(i,400,{error:"clientId is required"}),!0)}let P=m.match(new RegExp(`^${c(r)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(p==="POST"&&P){await b();let s=decodeURIComponent(P[1]),n=await d(u),o=typeof n?.clientId=="string"?n.clientId.trim():"";return o?v.unsubscribeChat(o,s)?(a(i,200,{ok:!0,clientId:o,cardId:s,subscribed:!1}),!0):(a(i,404,{error:`SSE client not connected: ${o}`}),!0):(a(i,400,{error:"clientId is required"}),!0)}let e=m.match(new RegExp(`^${c(r)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&e){await b();let s=decodeURIComponent(e[1]),n=e[2]==="subscribe",o=await d(u),S=typeof o?.clientId=="string"?o.clientId.trim():"";return S?(c$1(i,S,s,{},n),!0):(a(i,400,{error:"clientId is required"}),!0)}let t=m.match(new RegExp(`^${c(r)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&t){await b();let s=decodeURIComponent(t[1]),n=decodeURIComponent(t[2]),o=t[3]==="subscribe",S=await d(u),H=typeof S?.clientId=="string"?S.clientId.trim():"";return H?(c$1(i,H,n,{cardId:s},o),!0):(a(i,400,{error:"clientId is required"}),!0)}return !1}catch(R){let P=R?.statusCode||500;return a(i,P,{error:String(R?.message||R)}),true}}return {handleWatchersRoutes:l,handleSse:f,handleChannelSubscription:c$1}}export{A as a,T as b};//# sourceMappingURL=chunk-WHDEBJLT.js.map
7
+ //# sourceMappingURL=chunk-WHDEBJLT.js.map
@@ -0,0 +1,2 @@
1
+ import {a,b}from'./chunk-ZJ5M5COT.js';function w(c){let{apiBasePath:p,json:t,readJsonBody:m,initBoardAndSetup:d,createMcpWebhookToolRegistry:R}=c;async function l(i,r,y){let g=i.method||"GET",b$1=y.pathname;try{if(g==="POST"&&b$1===`${p}/mcp-webhooks`){await d();let o=await m(i),s=typeof o.tool=="string"?o.tool.trim():"",f=o.args&&typeof o.args=="object"&&!Array.isArray(o.args)?o.args:{};if(!s)return t(r,400,{error:"tool is required"}),!0;try{let e=await a(s,f,R());if(e&&typeof e=="object"&&!Array.isArray(e)){let n=e;if(n.status==="fail")return t(r,400,{error:b(e,"Request failed")}),!0;if(n.status==="error")return t(r,500,{error:b(e,"Internal error")}),!0}t(r,200,e);}catch(e){let n=typeof e?.statusCode=="number"?Number(e.statusCode):500,h=e instanceof Error?e.message:String(e);t(r,n,{error:h});}return !0}return !1}catch(o){let s=o?.statusCode||500;return t(r,s,{error:String(o?.message||o)}),true}}return {handleWebhooksApi:l}}export{w as a};//# sourceMappingURL=chunk-XYN5D3GL.js.map
2
+ //# sourceMappingURL=chunk-XYN5D3GL.js.map
@@ -0,0 +1,2 @@
1
+ import {a}from'./chunk-VXJHBWK3.js';function d(a,e){return e?{...a,...e.pollIntervalMs!=null?{pollIntervalMs:e.pollIntervalMs}:{},...e.visibilityMs!=null?{visibilityMs:e.visibilityMs}:{},...e.concurrency!=null?{concurrency:e.concurrency}:{},...e.maxAttempts!=null?{maxAttempts:e.maxAttempts}:{}}:a}function p(a,e,c,s){return {id:a,async lease(o){return (await Promise.resolve(e.leaseRequests(o))).map(r=>({id:r.messageId,attempt:r.attempt,message:r.request,ack:()=>Promise.resolve(e.ackRequest(r.messageId,r.leaseToken)),nack:t=>Promise.resolve(e.nackRequest(r.messageId,r.leaseToken,t))}))},async handle(o){await c(o.args,o);},onError:s?(o,u)=>s(o,u.attempt,u.message):void 0}}function l(a,e,c,s){return {id:a,async lease(o){return (await Promise.resolve(e.lease(o))).map(r=>({id:r.id,attempt:r.attempt,message:r.body,ack:()=>Promise.resolve(e.ack(r.id,r.leaseToken)),nack:t=>Promise.resolve(e.nack(r.id,r.leaseToken,t))}))},async handle(){await c();},onError:s?(o,u)=>s(o,u.attempt):void 0}}function y(a$1){let e=a$1.logger??{info(){},warn(){},error(){}},c=a$1.boardAdapter,s=a$1.runtime.queueLaneTuning??{},o=c.processAccumulatedStore(),u=c.chatAgentStore(),r=[];if(r.push(d(l("process-accumulated",o,async()=>{let t=await a$1.runtime.processAccumulatedLane();if(t.status!=="success")throw new Error(t.error||`processAccumulatedLane returned ${t.status}`)},(t,n)=>{e.error(`[board-server] queued process-accumulated failed for ${a$1.boardId} (attempt ${n}): ${String(t&&t.message||t)}`);}),s.processAccumulated)),r.push(d(p("chat-agent",u,async(t,n)=>{await a$1.runtime.handleChatAgentRequest(n);},(t,n,i)=>{let m=typeof i.args?.cardId=="string"?i.args.cardId:"";e.error(`[board-server] queued chat-agent failed for ${a$1.boardId}${m?`/${m}`:""} (attempt ${n}): ${String(t&&t.message||t)}`);}),s.chatAgent)),a$1.executeTaskExecutorRequest){let t=c.boardWorkerStore();r.push(d(p("task-executor",t,a$1.executeTaskExecutorRequest,(n,i)=>{e.error(`[board-server] queued board-worker failed for ${a$1.boardId} (attempt ${i}): ${String(n&&n.message||n)}`);}),s.taskExecutor));}return a(r)}export{y as a};//# sourceMappingURL=chunk-YGALANRO.js.map
2
+ //# sourceMappingURL=chunk-YGALANRO.js.map
@@ -0,0 +1,2 @@
1
+ async function u(t,i,o){let s=o[t];if(!s)throw Object.assign(new Error(`Unknown MCP tool: ${t}`),{statusCode:400});let r=await s(i);if(r&&typeof r=="object"&&!Array.isArray(r)){let n=r,e=n.status;if(e==="success")return Object.prototype.hasOwnProperty.call(n,"data")?r:{status:"success",data:{}};if(e==="fail"||e==="error")return r}return {status:"success",data:r}}function f(t,i){if(!t||typeof t!="object"||Array.isArray(t))return i;let o=t;if(typeof o.error=="string"&&o.error.trim())return o.error;if(o.step==="validate"){let s=o.validation;if(s&&typeof s=="object"&&!Array.isArray(s)){let n=s.data;if(n&&typeof n=="object"&&!Array.isArray(n)){let e=n.issues;if(Array.isArray(e)){let c=e.find(d=>typeof d=="string"&&d.trim());if(typeof c=="string")return `Validation failed: ${c}`}let a=n.errors;if(Array.isArray(a)&&a.length>0)return "Validation failed"}}return "Validation failed"}return i}export{u as a,f as b};//# sourceMappingURL=chunk-ZJ5M5COT.js.map
2
+ //# sourceMappingURL=chunk-ZJ5M5COT.js.map
@@ -0,0 +1,3 @@
1
+ import {n,h,i,j,a as a$7,b as b$4,k,l as l$1,m,c as c$3}from'./chunk-J5J6BG7B.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$1,b as b$1}from'./chunk-WHDEBJLT.js';import {c,a as a$5,d as d$1,b as b$5}from'./chunk-SGV7PU4H.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$4,b as b$2}from'./chunk-ZJ5M5COT.js';import {b,c as c$2,e}from'./chunk-6APH25VI.js';import {j as j$1,d,c as c$1,b as b$3}from'./chunk-VMW4Z6EF.js';import {y,z,l}from'./chunk-N6P2JW4W.js';import {a as a$6}from'./chunk-KBELAKIY.js';import {a}from'./chunk-76ON3V7R.js';function te(S){let{apiBasePath:v,json:h,readJsonBody:Z,readRawBody:V,initBoardAndSetup:N,bootstrapBoard:$,buildPublishedRuntimePayload:K,createMcpControlplaneToolRegistry:Q,readCardFromStore:tt,patchCard:nt,retriggerCard:U,applyCardAction:ot,resolveChatHandlerTarget:it,createMcpFacade:ct,chatStorePublic:dt,uploadCardFile:m,sendCardFileDownloadResponse:C}=S;async function I(d,u,q){let x=d.method||"GET",O=q,P=O.pathname;try{if(x==="GET"&&P===`${v}/init-board`)return await N(),h(u,200,await K()),!0;if(x==="GET"&&P===`${v}/board-status`)return h(u,200,await K()),!0;if(x==="POST"&&P===`${v}/mcp-controlplane`){await $();let f=await Z(d),c=typeof f.tool=="string"?f.tool.trim():"",j=f.args&&typeof f.args=="object"&&!Array.isArray(f.args)?f.args:{};if(!c)return h(u,400,{error:"tool is required"}),!0;try{let l=await a$4(c,j,Q());if(l&&typeof l=="object"&&!Array.isArray(l)){let k=l;if(k.status==="fail")return h(u,400,{error:b$2(l,"Request failed")}),!0;if(k.status==="error")return h(u,500,{error:b$2(l,"Internal error")}),!0}h(u,200,l);}catch(l){let k=typeof l?.statusCode=="number"?Number(l.statusCode):500,L=l instanceof Error?l.message:String(l);h(u,k,{error:L});}return !0}let D=P.match(new RegExp(`^${c(v)}/cards/([^/]+)$`));if(x==="GET"&&D){await $();let f=decodeURIComponent(D[1]),c=await tt(f);return c?(h(u,200,c),!0):(h(u,404,{error:`card not found: ${f}`}),!0)}if(x==="PATCH"&&D){await $();let f=decodeURIComponent(D[1]),c=await Z(d);return await nt(f,c),h(u,200,{ok:!0}),!0}let et=P.match(new RegExp(`^${c(v)}/cards/([^/]+)/retrigger$`));if(x==="POST"&&et){await $();let f=decodeURIComponent(et[1]);return await U(f),h(u,200,{ok:!0}),!0}let rt=P.match(new RegExp(`^${c(v)}/cards/([^/]+)/actions$`));if(x==="POST"&&rt){await $();let f=decodeURIComponent(rt[1]),c=Date.now(),j=new Date(c).toISOString(),l=await Z(d),k=l?.actionType;if(k==="chat-send"&&!await it(f)){let T=Date.now();return h(u,409,{error:`chat handler is not configured for card: ${f}`,requestReceivedAt:j,requestReceivedAtMs:c,responseSentAt:new Date(T).toISOString(),responseSentAtMs:T,responseStatus:409}),!0}if(k==="chat-send"){let T=l?.payload??{},W=typeof T["turn-id"]=="string"?T["turn-id"]:typeof T.turnId=="string"?T.turnId:typeof T.turn=="string"?T.turn:"";if(!W||!String(W).trim()){let ut=Date.now();return h(u,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${f}`,requestReceivedAt:j,requestReceivedAtMs:c,responseSentAt:new Date(ut).toISOString(),responseSentAtMs:ut,responseStatus:400}),!0}}await ot(f,k,l?.payload);let L=Date.now();return h(u,200,{ok:!0,requestReceivedAt:j,requestReceivedAtMs:c,responseSentAt:new Date(L).toISOString(),responseSentAtMs:L,responseStatus:200}),!0}let M=P.match(new RegExp(`^${c(v)}/cards/([^/]+)/chats$`));if(x==="GET"&&M){await $();let f=decodeURIComponent(M[1]),c=String(O.searchParams.get("turn-id")||""),j=String(O.searchParams.get("all-turns")||"").toLowerCase()==="true",l=String(O.searchParams.get("tail-turns-before-id")||""),k=O.searchParams.get("tail-turns"),L=k==null||k===""?j||c?void 0:1:Number.parseInt(k,10),T=dt.readAll({params:{cardId:f},body:{...L===void 0?{}:{tailTurns:L},...c?{turnId:c}:{},...j?{allTurns:!0}:{},...l?{tailTurnsBeforeId:l}:{}}});if(T.status!=="success")return h(u,400,{error:T.error||"Failed to read chats"}),!0;let W=T.data.records;return h(u,200,{ok:!0,messages:W}),!0}if(x==="POST"&&M){await $();let f=decodeURIComponent(M[1]),c=await Z(d),j=typeof c?.role=="string"?c.role:"assistant",l=typeof c?.text=="string"?c.text:"",k=Array.isArray(c?.files)?c.files:[],L=typeof c?.turn=="string"?c.turn:typeof c?.["turn-id"]=="string"?c["turn-id"]:typeof c?.turnId=="string"?c.turnId:"",T=c?.done===!0,W=ct(),G=(await W.manageAddChatEntryAndAnyAttachments({cardId:f,role:j,text:l,files:k,turn:L})).data.id;return T&&W.setChatProcessing({cardId:f,active:!1}),h(u,200,{ok:!0,id:G}),!0}let X=P.match(new RegExp(`^${c(v)}/cards/([^/]+)/files$`));if(x==="POST"&&X){await $();let f=decodeURIComponent(X[1]),c=String(O.searchParams.get("inChat")||"").toLowerCase()==="true",j=String(O.searchParams.get("turn-id")||"").trim();if(c&&!j)return h(u,400,{error:`file upload with inChat=true requires a non-empty 'turn-id' query parameter for card: ${f}`}),!0;let l=d.headers["x-file-name"],k=String(d.headers["content-type"]||"application/octet-stream"),L=Array.isArray(l)?l[0]:l,T=L?decodeURIComponent(String(L)):"upload.bin",W=await V(d);return h(u,200,await m(f,T,k,W,{inChat:c,turnId:j})),!0}let z=P.match(new RegExp(`^${c(v)}/cards/([^/]+)/files/(\\d+)$`));if(x==="GET"&&z){let f=decodeURIComponent(z[1]),c=parseInt(z[2],10),j=O.searchParams.get("sn");return await C(u,f,c,j),!0}return !1}catch(D){let et=D?.statusCode||500;return h(u,et,{error:String(D?.message||D)}),true}}return {handleRuntimeApi:I}}var re={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},ee="chat-handler-flow-queue";function or(S){let v=String(S.apiBasePath||"/api/board").replace(/\/$/,""),h$1={...re,...S.corsHeaders||{}},Z=S.queueLaneTuning??{},V=S.boardId||"",N=S.logger||{info:console.log,warn:console.warn,error:console.error},$=S.invocationAdapter,K=S.chatFlowRunner||null,Q=S.chatStorage??b(),tt=a(Q),nt=S.notificationTransport||null,U=S.serverUrl||null,ot=S.executionExtra||{},it=S.onSseClientConnected,ct=S.onSseClientDisconnected,dt=S.onChannelSubscribed,m$1=S.onChannelUnsubscribed,C=a$1({chatStorage:Q,readChatRecords:t=>bt(t),onSseClientDisconnected:ct});function I(t){function e(o){if(Array.isArray(o))return o;if(o&&typeof o=="object"){let i=o;return Array.isArray(i.files)?i.files:[o]}return null}function r(o){return {async get(i){return o.get(i)},async set(i){return o.set(i)},async del(i){return o.del(i)},async patch(i){return o.patch(i)},async appendFiles(i){return o.appendFiles(i)}}}function a(o){function i(b){return {status:"success",data:b}}function g(b){return {status:"fail",error:b}}function p(b){return {status:"error",error:b instanceof Error?b.message:String(b)}}return {async get(b){try{let R=b.params?.id;if(R){let E=await o.readCard(R);return E?i({cards:[E]}):g(`card "${R}" not found`)}return i({cards:await o.readAllCards()})}catch(R){return p(R)}},async set(b){try{let R=b.body;if(R==null)return g("set requires a body (card object or array of cards)");let E=Array.isArray(R)?R:[R];for(let _ of E){if(typeof _.id!="string")return g("each card must have a string `id` field");await o.writeCard(_.id,_);}return i({count:E.length})}catch(R){return p(R)}},async del(b){try{let R=b.body?.ids??[],E=b.params?.id,_=E?[...R,E]:R;if(_.length===0)return g("del requires body.ids (string[]) or params.id");for(let st of _)await o.removeCard(st);return i({count:_.length})}catch(R){return p(R)}},async patch(b){try{let R=b.params?.id,E=b.params?.path;if(!R)return g("patch requires params.id");if(!E)return g("patch requires params.path");let _=b.body,st=_&&Object.prototype.hasOwnProperty.call(_,"value")?_.value:b.body;return await o.patchCard(R,E,st),i({count:1})}catch(R){return p(R)}},async appendFiles(b){try{let R=b.params?.id;if(!R)return g("appendFiles requires params.id");let E=await o.readCard(R);if(!E)return g(`card "${R}" not found`);let _=e(b.body);if(!_||_.length===0)return g("appendFiles requires a file metadata object, array, or body.files array");let st=E.card_data&&typeof E.card_data=="object"&&!Array.isArray(E.card_data)?E.card_data:{},Bt=Array.isArray(st.files)?st.files:[],Fe=[...Bt,..._];return await o.patchCard(R,"card_data.files",Fe),i({files_added:_.map((Oe,Te)=>({idx:Bt.length+Te,entry:Oe}))})}catch(R){return p(R)}}}}let n=a$5(t.boardAdapter)?j$1(t.baseRef,t.boardAdapter):y(t.baseRef,t.boardAdapter),s=t.nonCoreAdapter??(!a$5(t.boardAdapter)&&x(t.boardAdapter)?t.boardAdapter:null),y$1=s?z(t.baseRef,s):null,B,w=a$5(t.boardAdapter)?(()=>{let o=d(c$1(b$3(t.boardAdapter.kvStorageForRef(t.cardStoreRef)),t.boardAdapter.hashFn),N.warn),i=a(o);return B={get(g){return i.get(g)},set(g){return i.set(g)}},i})():(()=>{let o=t.boardAdapter.kvStorageForRef(t.cardStoreRef),g=a$6(l({readIndex:()=>o.read("_index"),writeIndex:p=>o.write("_index",p),readCard:p=>o.read(p),writeCard:(p,b)=>(o.write(p,b),p),removeCard:p=>{o.delete(p);},cardExists:p=>o.read(p)!==null,defaultCardKey:p=>p},N.warn));return B=g,r(g)})(),F=t.artifactsAdapter||t.boardAdapter,A=t.filesArtifactsStore??null,H=A?{putBytes(o,i,g){A.putBytes(o,i,g);},getBytes(o){return A.getBytes(o)},listKeys(o){return A.list(o).map(i=>i.key)}}:null;if(!H&&!a$5(F)){let o=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files"),i=c$2(o);H={putBytes(g,p,b){i.putBytes(g,p,b);},getBytes(g){return i.getBytes(g)},listKeys(g){return i.list(g).map(p=>p.key)}};}else if(!H&&a$5(F)){let o=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files");H={async putBytes(i,g){if(o.writeBytes){await o.writeBytes(i,g);return}let p=JSON.stringify({__kind:"bytes-array",data:[...g]});await o.write(i,p);},async getBytes(i){if(o.readBytes){let p=await o.readBytes(i);if(p!==null)return p}let g=await o.read(i);if(g===null)return null;try{let p=JSON.parse(g);if(p&&p.__kind==="bytes-array"&&Array.isArray(p.data))return new Uint8Array(p.data)}catch{}return new TextEncoder().encode(g)},async listKeys(i){return await o.listKeys(i)}};}let J={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:y$1,publicCardStore:B,boardOps:J,cardStoreOps:w,get filesArtifacts(){return H},boardAdapter:t.boardAdapter,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,archiveStoreRef:t.archiveStoreRef,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 d$2=S.boards.map(I),u=new Map;function q(t){return u.get(t)??0}function x(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function O(t){let e=d$2[q(t)];return {files:e?e.filesArtifacts:null}}function P(){return e()}function D(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function et(t){if(!t||t.notificationTeardown||!nt||!t.notifyRef)return;let e=await nt.subscribe(t.notifyRef,r=>{c$3(t.notification,r);let a=r.kind==="notification-batch"?r.notifications:[r];C.broadcastNotificationBatch(a);});t.notificationTeardown=e;}async function rt(t){if(!t||t.initialized)return;let e={cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef};t.artifactsStoreRef&&(e.artifactsStoreRef=t.artifactsStoreRef),t.chatStoreRef&&(e.chatStoreRef=t.chatStoreRef),t.scratchStoreRef&&(e.scratchStoreRef=t.scratchStoreRef),t.archiveStoreRef&&(e.archiveStoreRef=t.archiveStoreRef);let r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow),t.inferenceAdapterRef&&(r["inference-adapter-ref"]=t.inferenceAdapterRef);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 et(t),!t.chatHandlerFlow&&t.chatHandlerRef&&$.describe)try{let n=await $.describe(t.chatHandlerRef);n&&n.kind!=="chat-handler"?N.warn(`[init] chat-handler describe returned kind="${n.kind}", expected "chat-handler" for ${t.label}`):n&&N.info(`[init] chat-handler validated: ${n.name} (protocol ${n.protocolVersion}) for ${t.label}`);}catch(n){N.warn(`[init] chat-handler describe failed for ${t.label}: ${n?.message||String(n)}`);}t.initialized=true;}async function M(t){if(!t.boardAdapter.publishBoardChangeNotifications)return;let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&b$4(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,y]of Object.entries(a.data))s&&e.push({kind:"data_object",key:s,payload:y});let n=await t.boardOps.getAllOutputsComputedValues({});if(n.status==="success"&&n.data!=null)for(let[s,y]of Object.entries(n.data))s&&e.push({kind:"computed_values",cardId:s,values:y});e.length>0&&t.boardAdapter.publishBoardChangeNotifications(e);}async function X(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"&&(u.set(n.id,e),await t.boardOps.upsertCard({params:{cardId:n.id}}));t.cardsBootstrapped=true;}async function z$1(){for(let t of d$2)await rt(t);}async function f(){await z$1();for(let t=0;t<d$2.length;t++)await M(d$2[t]),await X(d$2[t],t),await M(d$2[t]);}async function c(t=false){t||await z$1();for(let e of d$2){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}async function j$2(){return await z$1(),c(true)}function l$2(t){return d$2[q(t)]??null}async function k$1(t){let e=l$2(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 L(){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 d$2)e.push(...await t(r));return e}function T(){return d$2[0]??null}let W=n({boardContexts:d$2,cardOwnerIndex:u,cardContextForCard:t=>l$2(t),readStatusSnapshot:()=>ie(),readDataObjectsByToken:()=>de(),readCardRuntimeArtifacts:()=>ce(),readCardFromStore:t=>k$1(t),readCardDefinitions:()=>L(),processAccumulatedLaneInternal:t=>c(t),reportSourceFetched:(t,e)=>St(t,{ref:e}),reportSourceFetchFailure:(t,e)=>kt(t,{reason:e}),uploadCardFile:(t,e,r,a,n)=>Rt(t,e,r,a,n),chatStorePublic:tt,serverUrl:U,apiBasePath:v}),ut=W.mcpCardStoreFacade,G=W.createMcpFacade,ne=h({boardId:V,getMcpFacade:()=>G(),getMcpCardStoreFacade:()=>ut()});function ae(t){return k(t)}function oe(){return l$1(G())}function se(){return m({boardId:V,uploadCardFile:Rt,getMcpFacade:()=>G(),controlplane:ne})}let lt=i({boardId:V,boardContexts:d$2,readCardDefinitions:()=>L(),readChatRecords:t=>bt(t),getChatProcessing:t=>G().getChatProcessing({cardId:t}).active}),ie=lt.readStatusSnapshot,ce=lt.readCardRuntimeArtifacts,de=lt.readDataObjectsByToken,gt=lt.buildPublishedRuntimePayload;async function yt(t,e,r){let a=r?.syncBoard!==false,n=r?.restartOnlyIfChanged===true,s=l$2(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let y=await k$1(t);if(!y)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let B=n?JSON.stringify(y):null,w=e(y)||y;if(n&&JSON.stringify(w)===B)return;let F=await s.cardStoreOps.set({body:w});if(F.status!=="success")throw Object.assign(new Error(F.error||`Failed to persist card: ${t}`),{statusCode:500});if(a){let A=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(A.status!=="success")throw Object.assign(new Error(A.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function ue(t,e){await yt(t,e,{syncBoard:true});}async function ht(t,e){await yt(t,e,{syncBoard:false});}async function le(t){let e=l$2(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await k$1(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 fe(t,e){await yt(t,r=>{if(!e||typeof e!="object"||Object.keys(e).length===0)return r;function a(n,s,y){let B=String(s||"").split(".").filter(Boolean);if(!B.length)return;let w=n;for(let F=0;F<B.length-1;F++){let A=B[F];(!w[A]||typeof w[A]!="object")&&(w[A]={}),w=w[A];}w[B[B.length-1]]=y;}if(e.fieldValues!==void 0&&e.fieldValues!==null){let n=null,s=r.view;if(s&&Array.isArray(s.elements)){for(let y of s.elements)if(y?.data&&y.data.writeTo){n=y.data.writeTo;break}}n?a(r,n,e.fieldValues):typeof e.fieldValues=="object"&&!Array.isArray(e.fieldValues)&&(r.card_data={...r.card_data||{},...e.fieldValues});}else {if(Array.isArray(e._stagedFiles)&&e._stagedFiles.length>0)return r;for(let[n,s]of Object.entries(e))n!=="_stagedFiles"&&(s!==null&&typeof s=="object"&&!Array.isArray(s)&&r[n]!==null&&typeof r[n]=="object"&&!Array.isArray(r[n])?r[n]={...r[n],...s}:r[n]=s);}return r},{syncBoard:true,restartOnlyIfChanged:true});}function pe(t){Q.clear(t);try{G().setChatProcessing({cardId:t,active:!1});}catch{}}function me(t,e,r,a,n=""){let s=typeof r=="string"?r.trim():"";return Q.append(t,e||"system",s,a,n)}function bt(t){return Q.readAll(t)}let Rt=j({safeCardId:t=>D(t),artifactsStores:t=>O(t),cardFileMetadataStore:()=>P(),readCardFromStore:t=>k$1(t),updateCardLocalOnly:(t,e)=>ht(t,e),writeChatRecord:(t,e,r,a,n)=>me(t,e,r,a,n)}).uploadCardFile;async function Ct(t){let e=l$2(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),a=r.status==="success"?r.data?.value:null,n=e.chatHandlerRef;return a==null&&(!n||typeof n!="object")?null:{ctx:e,handlerFlow:a,handlerRef:n}}async function ge(t,e,r=false,a=""){let n=await Ct(t);if(!n)return;let{ctx:s,handlerFlow:y,handlerRef:B}=n;if(!r)try{G().setChatProcessing({cardId:t,active:!0});}catch{}let w={boardId:V,cardId:String(t),lastChatEntryId:e,...a?{turnId:a}:{},...ot,...U?{serverUrl:U}:{}},F=y!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:ee}}:B;try{a$5(s.boardAdapter)?await s.boardAdapter.chatAgentStore().enqueueRequest({boardId:V,ref:F,args:y!=null?{...w,__chatHandlerFlow:y}:w}):s.boardAdapter.chatAgentStore().enqueueRequest({boardId:V,ref:F,args:y!=null?{...w,__chatHandlerFlow:y}:w}),await Promise.resolve(s.boardAdapter.requestProcessAccumulated?.());}catch(A){try{G().setChatProcessing({cardId:t,active:!1});}catch{}N.warn(`[chat-handler] queue failed for card "${t}": ${A instanceof Error?A.message:String(A)}`);}}async function ye(t,e,r){if(e.howToRun==="built-in"&&b$5(e)===ee){let a=K,n=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,a?a.run(n,s,{boardId:V,cardId:String(s.cardId||""),label:t.label,logger:N,serverUrl:U,executionExtra:ot}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return $.invoke(e,r)}async function Re(t,e=false){e||await z$1();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",a=r?l$2(r):T();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 ye(a,t.ref,t.args);if(!n.dispatched){if(r)try{Q.setProcessing(r,!1);}catch{}throw new Error(n.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function we(t,e,r){let a=e==="chat-send"?ht:ue,n;await a(t,s=>{let y=new Date().toISOString(),B=s.card_data&&typeof s.card_data=="object"?s.card_data:{};if(s.card_data=B,e==="chat-send"){let w=r&&typeof r.text=="string"?r.text.trim():"",F=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"",A=[];if(Array.isArray(r?.files)){for(let H of r.files)if(H){if(typeof H=="string"){A.push({name:H});continue}if(typeof H=="object"){let J=H;typeof J.name=="string"&&A.push({name:J.name,size:J.size,mime_type:J.mime_type,uploaded_at:J.uploaded_at,stored_name:J.stored_name,chat:J.chat===true});}}}if(w||A.length>0){let H=tt.runBatch({cardId:t,commands:[{command:"append",role:"user",text:w,files:A,turn:F},{command:"set-processing",active:true}]});if(H.status!=="success")throw new Error(H.error);let J=H.data.results[0]?.data?.id;if(typeof J!="string"||!J)throw new Error(`chat-send did not return an append id for card ${t}`);n={cardId:t,lastEntryId:J,processingAlreadySet:true,turnId:F};try{C.broadcastCardChats(t);}catch{}}return s}if(e==="file-upload"){let w=P().normalizeIncoming(r?.files,y);return w.length>0&&P().merge(B,w),s}if(e==="action"){let w=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!w)return s;B.lastAction={buttonId:w,at:y},B.lastActionText=`${w} @ ${y}`;}return s}),n&&ge(n.cardId,n.lastEntryId,n.processingAlreadySet,n.turnId??"");}function ft(t,e,r){let a=JSON.stringify(r),n=typeof Buffer<"u"?Buffer.byteLength(a):new TextEncoder().encode(a).length;t.writeHead(e,{...h$1,"Content-Type":"application/json; charset=utf-8","Content-Length":n}),t.end(a);}async function At(t,e,r){let a=await k$1(t);if(!a)throw Object.assign(new Error("Card not found"),{statusCode:404});let n=P().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,y=D(t),B=O(t),w=String(s.stored_name||""),F=`${y}/${w}`,A=B.files?await B.files.getBytes(F):null;if(!A)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:A}}async function he(t,e,r,a){let{fileRecord:n,bytes:s}=await At(e,r,a),y=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="${y}"`,"Content-Length":s.length}),t.end(s);}function be(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 Ce(t,e,r){let a=t.split(/\r?\n/);return (e==="head"?a.slice(0,r):a.slice(-r)).join(`
2
+ `)}async function pt(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 Ae(t){let e=[];for await(let r of t)e.push(r);return typeof Buffer<"u"?Buffer.concat(e):d$1(e)}async function St(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=d$2[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=d$2[0];return a?a.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let Se=b$1({sseHub:C,corsHeaders:h$1,json:ft,buildPublishedRuntimePayload:()=>gt(),onSseClientConnected:it,onChannelSubscribed:dt,onChannelUnsubscribed:m$1,apiBasePath:v,readJsonBody:t=>pt(t),initBoardAndSetup:()=>z$1(),bootstrapBoard:()=>f(),boardContexts:d$2,publishPersistedStateSnapshot:t=>M(t),upsertCardsFromSource:(t,e)=>X(t,e)}).handleWatchersRoutes,ke=a$2({apiBasePath:v,json:ft,readJsonBody:t=>pt(t),bootstrapBoard:()=>f(),createMcpFacade:()=>G(),createMcpToolRegistry:t=>ae(t),resolveCardFileDownloadPayload:(t,e,r)=>At(t,e,r),isLikelyTextMimeType:t=>be(t),sliceTextByLines:(t,e,r)=>Ce(t,e,r)}).handleAgentfaceApi,Be=a$3({apiBasePath:v,json:ft,readJsonBody:t=>pt(t),initBoardAndSetup:()=>z$1(),createMcpWebhookToolRegistry:()=>oe()}).handleWebhooksApi,ve=te({apiBasePath:v,json:ft,readJsonBody:t=>pt(t),readRawBody:t=>Ae(t),initBoardAndSetup:()=>z$1(),bootstrapBoard:()=>f(),buildPublishedRuntimePayload:()=>gt(),createMcpControlplaneToolRegistry:()=>se(),readCardFromStore:t=>k$1(t),patchCard:(t,e)=>fe(t,e),retriggerCard:t=>le(t),applyCardAction:(t,e,r)=>we(t,e,r),resolveChatHandlerTarget:t=>Ct(t),createMcpFacade:()=>G(),chatStorePublic:tt,uploadCardFile:(t,e,r,a,n)=>Rt(t,e,r,a,n),sendCardFileDownloadResponse:(t,e,r,a)=>he(t,e,r,a)}).handleRuntimeApi;async function Pe(t,e,r){return !!(await ke(t,e,r)||await Be(t,e,r)||await Se(t,e,r)||await ve(t,e,r))}return {get apiBasePath(){return v},get corsHeaders(){return h$1},get queueLaneTuning(){return Z},handleRuntimeApi:Pe,buildPublishedRuntimePayload:gt,processAccumulatedEvents:j$2,processAccumulatedLane:c,handleChatAgentRequest:Re,clearChatRecords:pe,reportSourceFetched(t,e){return St(t,{ref:e})},reportSourceFetchFailure(t,e){return kt(t,{reason:e})},get cardStore(){return d$2[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function sr(S){let v=String(S.apiBasePath||"/api/boards").replace(/\/$/,""),h={...re,...S.corsHeaders||{}},Z=S.serverMetaStore,V=S.boardRuntimeFactory,N=new Map,$="boards-config.json";function K(){let m=Z.getText($);if(!m)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(m)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function Q(m){Z.putText($,JSON.stringify(m,null,2));}function tt(m){let C=String(m||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return C.length>0&&C.length<=64?C:null}function nt(m){if(N.has(m))return N.get(m);let I=K().boards.find(u=>u.id===m)||{},d=V(m,I);return N.set(m,d),d}function U(m,C,I){let d=JSON.stringify(I),u=typeof Buffer<"u"?Buffer.byteLength(d):new TextEncoder().encode(d).length;m.writeHead(C,{...h,"Content-Type":"application/json; charset=utf-8","Content-Length":u}),m.end(d);}async function ot(m,C,I){let d=m.method||"GET",u=I.pathname;if(d==="GET"&&u===v)return U(C,200,{ok:true,boards:K().boards}),true;if(d==="POST"&&u===v){let q=[];for await(let M of m)q.push(M);let x=typeof Buffer<"u"?Buffer.concat(q).toString("utf-8").trim():new TextDecoder().decode(d$1(q)).trim(),O={};try{O=x?JSON.parse(x):{};}catch{O={};}let P=tt(O.id);if(!P)return U(C,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let D=K();if(D.boards.some(M=>M.id===P))return U(C,409,{error:`Board "${P}" is already registered`}),true;let et=typeof O.label=="string"&&O.label.trim()?O.label.trim():P,rt={id:P,label:et};for(let[M,X]of Object.entries(O))M==="id"||M==="label"||X!=null&&(rt[M]=X);return D.boards.push(rt),Q(D),U(C,200,{ok:true,board:rt}),true}return false}async function it(m,C,I){let u=I.pathname.match(new RegExp(`^${c(v)}/([^/]+)(/|$)`));if(!u)return false;let q=tt(decodeURIComponent(u[1]));return q?K().boards.some(P=>P.id===q)?!!await nt(q).handleRuntimeApi(m,C,I):(U(C,404,{error:`Board "${q}" not registered. POST ${v} with {id} to register it first.`}),true):(U(C,400,{error:"Invalid board id"}),true)}async function ct(m,C,I){return !!(await ot(m,C,I)||await it(m,C,I))}function dt(m){if(!K().boards.some(I=>I.id===m))throw Object.assign(new Error(`Board "${m}" not registered`),{statusCode:404});return {service:nt(m)}}return {get apiBasePath(){return v},get corsHeaders(){return h},handleApi:ct,requireBoardService:dt}}export{te as a,or as b,sr as c};//# sourceMappingURL=chunk-ZXQR7GHT.js.map
3
+ //# sourceMappingURL=chunk-ZXQR7GHT.js.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkH5HBXPOI_cjs=require('./chunk-H5HBXPOI.cjs');require('./chunk-PBCDDO4V.cjs'),require('./chunk-OEFTOO47.cjs'),require('./chunk-U2N6MCD5.cjs'),require('./chunk-SFVO2LB2.cjs'),require('./chunk-G4XXRHL2.cjs'),require('./chunk-LODXIALE.cjs'),require('./chunk-IXZG74EW.cjs'),require('./chunk-NMZ6XNLB.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-YMEIPKLW.cjs'),require('./chunk-GNFE24S7.cjs');function Q(e){if(!e||typeof e!="object")return;let t=e;if(typeof t.statusCode=="number")return t.statusCode;if(typeof t.code=="number")return t.code}function c(e,t){return Q(e)===t}function l(e,t,r){return t?typeof t=="function"?t(e):t:r}function b(e){return (e?.()??new Date).toISOString()}function O(e,t){if(t)return t();let r=String((e?.()??new Date).getTime()).padStart(13,"0"),n=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${r}-${n}`}function p(e){return {id:e.id,payload:e.payload}}function z(e,t={}){return {async read(r){let n=l(r,t.partitionKey,"kv");try{return (await e.item(r,n).read()).resource?.value??null}catch(o){if(c(o,404))return null;throw o}},async write(r,n){let o=l(r,t.partitionKey,"kv");await e.items.upsert({id:r,pk:o,kind:"kv",value:n});},async delete(r){let n=l(r,t.partitionKey,"kv");try{await e.item(r,n).delete();}catch(o){if(!c(o,404))throw o}},async listKeys(r=""){let{resources:n}=await e.items.query({query:"SELECT c.id FROM c WHERE c.kind = @kind AND STARTSWITH(c.id, @prefix)",parameters:[{name:"@kind",value:"kv"},{name:"@prefix",value:r}]}).fetchAll();return n.map(o=>o.id).sort()}}}function I(e,t,r={}){let n=l(t,r.partitionKey,`journal:${t}`);return {async append(o){let s={id:O(r.now,r.idFactory),pk:n,kind:"journal",streamKey:t,createdAt:b(r.now),payload:o};return await e.items.create(s),p(s)},async readAll(){let{resources:o}=await e.items.query({query:"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:n},{name:"@streamKey",value:t}]}).fetchAll();return o.sort((s,a)=>s.id.localeCompare(a.id)).map(p)},async readAfter(o){let{resources:s}=await e.items.query({query:o?"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey AND c.id > @cursor ORDER BY c.id":"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:n},{name:"@streamKey",value:t},...o?[{name:"@cursor",value:o}]:[]]}).fetchAll(),a=s.sort((m,g)=>m.id.localeCompare(g.id));return {entries:a.map(p),newCursor:a.length>0?a[a.length-1].id:o}},async clear(){let o=await this.readAll();await Promise.all(o.map(s=>e.item(s.id,n).delete()));}}}function K(e,t,r={}){let n=r.partitionKey??"lock",o=r.holderId??`holder-${Math.random().toString(36).slice(2,10)}`,s=r.now,a=r.ttlMs??3e4;function m(){let i=s?.()??new Date;return {id:t,pk:n,kind:"lock",held:true,holderId:o,expiresAt:new Date(i.getTime()+a).toISOString(),updatedAt:i.toISOString()}}function g(i){return {...i??{id:t,pk:n,kind:"lock"},kind:"lock",held:false,holderId:o,expiresAt:null,updatedAt:b(s)}}async function k(){try{return (await e.item(t,n).read()).resource??null}catch(i){if(c(i,404))return null;throw i}}function S(i){return i?.held?i.expiresAt?Date.parse(i.expiresAt)>(s?.()??new Date).getTime():true:false}return {async tryAcquire(){let i=await k(),A=m();if(i){if(S(i))return null;try{await e.item(t,n).replace(A,i._etag?{accessCondition:{type:"IfMatch",condition:i._etag}}:void 0);}catch(u){if(c(u,412)||c(u,409))return null;throw u}}else try{await e.items.create(A);}catch(u){if(c(u,409))return null;throw u}return async()=>{let u=await k();if(!u)return;let w=g(u);try{await e.item(t,n).replace(w,u._etag?{accessCondition:{type:"IfMatch",condition:u._etag}}:void 0);}catch{}}}}}function E(e){return new TextDecoder().decode(e)}function J(e,t={}){return {async read(r){if(!await e.getBlobClient(r).exists())return null;let n=await e.getBlobClient(r).downloadToBuffer();return E(n)},async write(r,n){await e.getBlockBlobClient(r).upload(n,new TextEncoder().encode(n).byteLength,{blobHTTPHeaders:{blobContentType:t.defaultContentType??"application/json; charset=utf-8"}});},exists(r){return e.getBlobClient(r).exists()},async remove(r){await e.getBlobClient(r).deleteIfExists();},async readBytes(r){return await e.getBlobClient(r).exists()?await e.getBlobClient(r).downloadToBuffer():null},async writeBytes(r,n){await e.getBlockBlobClient(r).upload(n,n.byteLength,{blobHTTPHeaders:{blobContentType:t.defaultContentType??"application/octet-stream"}});},async listKeys(r=""){let n=[];for await(let o of e.listBlobsFlat({prefix:r}))n.push(o.name);return n.sort()},async stat(r){if(!await e.getBlobClient(r).exists())return null;let n=await e.getBlobClient(r).getProperties();return {key:r,size:Number(n.contentLength??0),updatedAt:n.lastModified?.toISOString(),contentType:n.contentType}},keyRef(r){return t.keyRef?.(r)??{kind:"azure-blob-key",value:r}}}}function C(e){if(!e||typeof e!="object")return;let t=e;if(typeof t.statusCode=="number")return t.statusCode;if(typeof t.code=="number")return t.code}function y(e){let t=JSON.stringify(e),r=globalThis.Buffer;if(r)return r.from(t,"utf-8").toString("base64");if(typeof btoa=="function")return btoa(t);throw new Error("No base64 encoder available in this runtime")}function f(e){let t=e??"",r=globalThis.Buffer;if(r)return JSON.parse(r.from(t,"base64").toString("utf-8"));if(typeof atob=="function")return JSON.parse(atob(t));throw new Error("No base64 decoder available in this runtime")}function d(e,t){return (e??t()).toISOString()}function q(e,t){return {id:String(e.messageId??""),body:f(e.messageText),enqueuedAt:d(e.insertedOn??e.insertionTime,t),attempt:Number(e.dequeueCount??0)}}function j(e,t){return {id:String(e.messageId??""),body:f(e.messageText),enqueuedAt:d(e.insertedOn??e.insertionTime,t),attempt:Number(e.dequeueCount??0),leaseToken:String(e.popReceipt??""),leaseExpiresAt:d(e.nextVisibleOn,t)}}function N(e,t={}){let r=t.now??(()=>new Date);return {async enqueue(n){let o=await e.sendMessage(y(n));return {id:String(o.messageId??""),body:n,enqueuedAt:d(o.insertionTime,r),attempt:0}},async lease(n){return (await e.receiveMessages({numberOfMessages:n?.max,visibilityTimeout:n?.visibilityMs?Math.max(1,Math.ceil(n.visibilityMs/1e3)):void 0})).receivedMessageItems.map(s=>j(s,r))},async ack(n,o){try{return await e.deleteMessage(n,o),!0}catch(s){if(C(s)===404)return false;throw s}},async nack(n,o,s){try{if(s?.dead){if(!t.deadLetterQueueClient)return !1;let a={messageId:n,reason:s.reason??null};return await t.deadLetterQueueClient.sendMessage(y(a)),await e.deleteMessage(n,o),!0}return await e.updateMessage(n,o,y({requeued:!0}),0),!0}catch(a){if(C(a)===404)return false;throw a}},async peekActive(n=""){return (await e.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>q(s,r)).filter(s=>!n||s.id.startsWith(n))},async peekDeadLetter(n=""){return t.deadLetterQueueClient?(await t.deadLetterQueueClient.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>{let a=f(s.messageText);return {id:String(s.messageId??""),body:a,enqueuedAt:d(s.insertedOn??s.insertionTime,r),attempt:Number(s.dequeueCount??0),reason:typeof a.reason=="string"?a.reason:void 0}}).filter(s=>!n||s.id.startsWith(n)):[]}}}Object.defineProperty(exports,"createAsyncBoardConfigStore",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.h}});Object.defineProperty(exports,"createAsyncBoardLiveCardsPublic",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.j}});Object.defineProperty(exports,"createAsyncBoardWorkerStore",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.g}});Object.defineProperty(exports,"createAsyncCardStorageAdapter",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.c}});Object.defineProperty(exports,"createAsyncCardStore",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.d}});Object.defineProperty(exports,"createAsyncJsonStorage",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.b}});Object.defineProperty(exports,"createAsyncStateSnapshotAdapter",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.e}});Object.defineProperty(exports,"createAsyncStorageProvider",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.f}});Object.defineProperty(exports,"createHostedAsyncBoardPlatformAdapter",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.i}});Object.defineProperty(exports,"withAsyncRelayLock",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.a}});exports.createAzureBlobStorage=J;exports.createAzureQueueStorage=N;exports.createCosmosAtomicRelayLock=K;exports.createCosmosJournalStorage=I;exports.createCosmosKvStorage=z;//# sourceMappingURL=cloud-storage.cjs.map
1
+ 'use strict';var chunk5XHOHTLZ_cjs=require('./chunk-5XHOHTLZ.cjs'),chunkH5HBXPOI_cjs=require('./chunk-H5HBXPOI.cjs');require('./chunk-PBCDDO4V.cjs'),require('./chunk-OEFTOO47.cjs'),require('./chunk-U2N6MCD5.cjs'),require('./chunk-SFVO2LB2.cjs'),require('./chunk-G4XXRHL2.cjs'),require('./chunk-LODXIALE.cjs'),require('./chunk-IXZG74EW.cjs'),require('./chunk-NMZ6XNLB.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-YMEIPKLW.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createAzureBlobStorage",{enumerable:true,get:function(){return chunk5XHOHTLZ_cjs.d}});Object.defineProperty(exports,"createAzureQueueStorage",{enumerable:true,get:function(){return chunk5XHOHTLZ_cjs.e}});Object.defineProperty(exports,"createCosmosAtomicRelayLock",{enumerable:true,get:function(){return chunk5XHOHTLZ_cjs.c}});Object.defineProperty(exports,"createCosmosJournalStorage",{enumerable:true,get:function(){return chunk5XHOHTLZ_cjs.b}});Object.defineProperty(exports,"createCosmosKvStorage",{enumerable:true,get:function(){return chunk5XHOHTLZ_cjs.a}});Object.defineProperty(exports,"createAsyncBoardConfigStore",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.h}});Object.defineProperty(exports,"createAsyncBoardLiveCardsPublic",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.j}});Object.defineProperty(exports,"createAsyncBoardWorkerStore",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.g}});Object.defineProperty(exports,"createAsyncCardStorageAdapter",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.c}});Object.defineProperty(exports,"createAsyncCardStore",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.d}});Object.defineProperty(exports,"createAsyncJsonStorage",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.b}});Object.defineProperty(exports,"createAsyncStateSnapshotAdapter",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.e}});Object.defineProperty(exports,"createAsyncStorageProvider",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.f}});Object.defineProperty(exports,"createHostedAsyncBoardPlatformAdapter",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.i}});Object.defineProperty(exports,"withAsyncRelayLock",{enumerable:true,get:function(){return chunkH5HBXPOI_cjs.a}});//# sourceMappingURL=cloud-storage.cjs.map
2
2
  //# sourceMappingURL=cloud-storage.cjs.map
@@ -1,6 +1,8 @@
1
- import { b as AsyncJSONStorage, c as AsyncKVStorage, d as AsyncBlobStorage, e as AsyncJournalStorage, f as AsyncStorageProvider, g as AsyncAtomicRelayLock, h as AsyncQueueStorage } from './board-live-cards-public-async-dMWNbWq6.cjs';
2
- export { i as AsyncBoardConfigStore, A as AsyncBoardLiveCardsPublic, a as AsyncBoardPlatformAdapter, j as AsyncBoardWorkerDeadLetterRequest, k as AsyncBoardWorkerLeasedRequest, l as AsyncBoardWorkerQueuedRequest, m as AsyncBoardWorkerRequest, n as AsyncBoardWorkerStore, H as HostedAsyncBoardPlatformAdapterOptions, o as HostedFetchLike, p as HostedFetchResponseLike, q as createAsyncBoardConfigStore, r as createAsyncBoardLiveCardsPublic, s as createAsyncBoardWorkerStore, t as createHostedAsyncBoardPlatformAdapter, w as withAsyncRelayLock } from './board-live-cards-public-async-dMWNbWq6.cjs';
3
- import { L as LiveCard, i as CardChecksumIndex, j as CardUpsertValidation, k as CardIndex, S as StateSnapshotReadView } from './board-live-cards-public-wkNmBIRC.cjs';
1
+ import { g as AsyncJSONStorage, c as AsyncKVStorage, a as AsyncBlobStorage, b as AsyncJournalStorage, h as AsyncStorageProvider, d as AsyncAtomicRelayLock, e as AsyncQueueStorage } from './storage-async-interface-BRR4eBjx.cjs';
2
+ export { w as withAsyncRelayLock } from './storage-async-interface-BRR4eBjx.cjs';
3
+ import { L as LiveCard, i as CardChecksumIndex, j as CardUpsertValidation, k as CardIndex, S as StateSnapshotReadView } from './board-live-cards-public-DQzPe7A9.cjs';
4
+ export { a as AsyncBoardConfigStore, A as AsyncBoardPlatformAdapter, b as AsyncBoardWorkerDeadLetterRequest, c as AsyncBoardWorkerLeasedRequest, d as AsyncBoardWorkerQueuedRequest, e as AsyncBoardWorkerRequest, f as AsyncBoardWorkerStore, H as HostedAsyncBoardPlatformAdapterOptions, g as HostedFetchLike, h as HostedFetchResponseLike, i as createAsyncBoardConfigStore, j as createAsyncBoardWorkerStore, k as createHostedAsyncBoardPlatformAdapter } from './board-platform-adapter-async-DOfEq_HC.cjs';
5
+ export { A as AsyncBoardLiveCardsPublic, c as createAsyncBoardLiveCardsPublic } from './board-live-cards-public-async-CgMCYYft.cjs';
4
6
  import { a as KindValueRef } from './storage-interface-BFiD3kyB.cjs';
5
7
  import './execution-refs.cjs';
6
8
  import './types-BBhqYGhE.cjs';
@@ -1,6 +1,8 @@
1
- import { b as AsyncJSONStorage, c as AsyncKVStorage, d as AsyncBlobStorage, e as AsyncJournalStorage, f as AsyncStorageProvider, g as AsyncAtomicRelayLock, h as AsyncQueueStorage } from './board-live-cards-public-async-DKZqbJVU.js';
2
- export { i as AsyncBoardConfigStore, A as AsyncBoardLiveCardsPublic, a as AsyncBoardPlatformAdapter, j as AsyncBoardWorkerDeadLetterRequest, k as AsyncBoardWorkerLeasedRequest, l as AsyncBoardWorkerQueuedRequest, m as AsyncBoardWorkerRequest, n as AsyncBoardWorkerStore, H as HostedAsyncBoardPlatformAdapterOptions, o as HostedFetchLike, p as HostedFetchResponseLike, q as createAsyncBoardConfigStore, r as createAsyncBoardLiveCardsPublic, s as createAsyncBoardWorkerStore, t as createHostedAsyncBoardPlatformAdapter, w as withAsyncRelayLock } from './board-live-cards-public-async-DKZqbJVU.js';
3
- import { L as LiveCard, i as CardChecksumIndex, j as CardUpsertValidation, k as CardIndex, S as StateSnapshotReadView } from './board-live-cards-public-BMUIPOrc.js';
1
+ import { g as AsyncJSONStorage, c as AsyncKVStorage, a as AsyncBlobStorage, b as AsyncJournalStorage, h as AsyncStorageProvider, d as AsyncAtomicRelayLock, e as AsyncQueueStorage } from './storage-async-interface-DhlOVPSp.js';
2
+ export { w as withAsyncRelayLock } from './storage-async-interface-DhlOVPSp.js';
3
+ import { L as LiveCard, i as CardChecksumIndex, j as CardUpsertValidation, k as CardIndex, S as StateSnapshotReadView } from './board-live-cards-public-D-DJek3X.js';
4
+ export { a as AsyncBoardConfigStore, A as AsyncBoardPlatformAdapter, b as AsyncBoardWorkerDeadLetterRequest, c as AsyncBoardWorkerLeasedRequest, d as AsyncBoardWorkerQueuedRequest, e as AsyncBoardWorkerRequest, f as AsyncBoardWorkerStore, H as HostedAsyncBoardPlatformAdapterOptions, g as HostedFetchLike, h as HostedFetchResponseLike, i as createAsyncBoardConfigStore, j as createAsyncBoardWorkerStore, k as createHostedAsyncBoardPlatformAdapter } from './board-platform-adapter-async-JZPCzZnH.js';
5
+ export { A as AsyncBoardLiveCardsPublic, c as createAsyncBoardLiveCardsPublic } from './board-live-cards-public-async-3hUuHxDx.js';
4
6
  import { a as KindValueRef } from './storage-interface-BFiD3kyB.js';
5
7
  import './execution-refs.js';
6
8
  import './types-BBhqYGhE.js';
@@ -1,2 +1,2 @@
1
- export{h as createAsyncBoardConfigStore,j as createAsyncBoardLiveCardsPublic,g as createAsyncBoardWorkerStore,c as createAsyncCardStorageAdapter,d as createAsyncCardStore,b as createAsyncJsonStorage,e as createAsyncStateSnapshotAdapter,f as createAsyncStorageProvider,i as createHostedAsyncBoardPlatformAdapter,a as withAsyncRelayLock}from'./chunk-VMW4Z6EF.js';import'./chunk-HEEDJEKM.js';import'./chunk-N6P2JW4W.js';import'./chunk-XQRNDX4Q.js';import'./chunk-BQS3EIEK.js';import'./chunk-VGT3TRQG.js';import'./chunk-WDPOGXTY.js';import'./chunk-JMDHDY6M.js';import'./chunk-VLBB3D6B.js';import'./chunk-MNEOJWPS.js';import'./chunk-KBELAKIY.js';import'./chunk-FW4363Y4.js';function Q(e){if(!e||typeof e!="object")return;let t=e;if(typeof t.statusCode=="number")return t.statusCode;if(typeof t.code=="number")return t.code}function c(e,t){return Q(e)===t}function l(e,t,r){return t?typeof t=="function"?t(e):t:r}function b(e){return (e?.()??new Date).toISOString()}function O(e,t){if(t)return t();let r=String((e?.()??new Date).getTime()).padStart(13,"0"),n=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${r}-${n}`}function p(e){return {id:e.id,payload:e.payload}}function z(e,t={}){return {async read(r){let n=l(r,t.partitionKey,"kv");try{return (await e.item(r,n).read()).resource?.value??null}catch(o){if(c(o,404))return null;throw o}},async write(r,n){let o=l(r,t.partitionKey,"kv");await e.items.upsert({id:r,pk:o,kind:"kv",value:n});},async delete(r){let n=l(r,t.partitionKey,"kv");try{await e.item(r,n).delete();}catch(o){if(!c(o,404))throw o}},async listKeys(r=""){let{resources:n}=await e.items.query({query:"SELECT c.id FROM c WHERE c.kind = @kind AND STARTSWITH(c.id, @prefix)",parameters:[{name:"@kind",value:"kv"},{name:"@prefix",value:r}]}).fetchAll();return n.map(o=>o.id).sort()}}}function I(e,t,r={}){let n=l(t,r.partitionKey,`journal:${t}`);return {async append(o){let s={id:O(r.now,r.idFactory),pk:n,kind:"journal",streamKey:t,createdAt:b(r.now),payload:o};return await e.items.create(s),p(s)},async readAll(){let{resources:o}=await e.items.query({query:"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:n},{name:"@streamKey",value:t}]}).fetchAll();return o.sort((s,a)=>s.id.localeCompare(a.id)).map(p)},async readAfter(o){let{resources:s}=await e.items.query({query:o?"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey AND c.id > @cursor ORDER BY c.id":"SELECT * FROM c WHERE c.kind = @kind AND c.pk = @pk AND c.streamKey = @streamKey ORDER BY c.id",parameters:[{name:"@kind",value:"journal"},{name:"@pk",value:n},{name:"@streamKey",value:t},...o?[{name:"@cursor",value:o}]:[]]}).fetchAll(),a=s.sort((m,g)=>m.id.localeCompare(g.id));return {entries:a.map(p),newCursor:a.length>0?a[a.length-1].id:o}},async clear(){let o=await this.readAll();await Promise.all(o.map(s=>e.item(s.id,n).delete()));}}}function K(e,t,r={}){let n=r.partitionKey??"lock",o=r.holderId??`holder-${Math.random().toString(36).slice(2,10)}`,s=r.now,a=r.ttlMs??3e4;function m(){let i=s?.()??new Date;return {id:t,pk:n,kind:"lock",held:true,holderId:o,expiresAt:new Date(i.getTime()+a).toISOString(),updatedAt:i.toISOString()}}function g(i){return {...i??{id:t,pk:n,kind:"lock"},kind:"lock",held:false,holderId:o,expiresAt:null,updatedAt:b(s)}}async function k(){try{return (await e.item(t,n).read()).resource??null}catch(i){if(c(i,404))return null;throw i}}function S(i){return i?.held?i.expiresAt?Date.parse(i.expiresAt)>(s?.()??new Date).getTime():true:false}return {async tryAcquire(){let i=await k(),A=m();if(i){if(S(i))return null;try{await e.item(t,n).replace(A,i._etag?{accessCondition:{type:"IfMatch",condition:i._etag}}:void 0);}catch(u){if(c(u,412)||c(u,409))return null;throw u}}else try{await e.items.create(A);}catch(u){if(c(u,409))return null;throw u}return async()=>{let u=await k();if(!u)return;let w=g(u);try{await e.item(t,n).replace(w,u._etag?{accessCondition:{type:"IfMatch",condition:u._etag}}:void 0);}catch{}}}}}function E(e){return new TextDecoder().decode(e)}function J(e,t={}){return {async read(r){if(!await e.getBlobClient(r).exists())return null;let n=await e.getBlobClient(r).downloadToBuffer();return E(n)},async write(r,n){await e.getBlockBlobClient(r).upload(n,new TextEncoder().encode(n).byteLength,{blobHTTPHeaders:{blobContentType:t.defaultContentType??"application/json; charset=utf-8"}});},exists(r){return e.getBlobClient(r).exists()},async remove(r){await e.getBlobClient(r).deleteIfExists();},async readBytes(r){return await e.getBlobClient(r).exists()?await e.getBlobClient(r).downloadToBuffer():null},async writeBytes(r,n){await e.getBlockBlobClient(r).upload(n,n.byteLength,{blobHTTPHeaders:{blobContentType:t.defaultContentType??"application/octet-stream"}});},async listKeys(r=""){let n=[];for await(let o of e.listBlobsFlat({prefix:r}))n.push(o.name);return n.sort()},async stat(r){if(!await e.getBlobClient(r).exists())return null;let n=await e.getBlobClient(r).getProperties();return {key:r,size:Number(n.contentLength??0),updatedAt:n.lastModified?.toISOString(),contentType:n.contentType}},keyRef(r){return t.keyRef?.(r)??{kind:"azure-blob-key",value:r}}}}function C(e){if(!e||typeof e!="object")return;let t=e;if(typeof t.statusCode=="number")return t.statusCode;if(typeof t.code=="number")return t.code}function y(e){let t=JSON.stringify(e),r=globalThis.Buffer;if(r)return r.from(t,"utf-8").toString("base64");if(typeof btoa=="function")return btoa(t);throw new Error("No base64 encoder available in this runtime")}function f(e){let t=e??"",r=globalThis.Buffer;if(r)return JSON.parse(r.from(t,"base64").toString("utf-8"));if(typeof atob=="function")return JSON.parse(atob(t));throw new Error("No base64 decoder available in this runtime")}function d(e,t){return (e??t()).toISOString()}function q(e,t){return {id:String(e.messageId??""),body:f(e.messageText),enqueuedAt:d(e.insertedOn??e.insertionTime,t),attempt:Number(e.dequeueCount??0)}}function j(e,t){return {id:String(e.messageId??""),body:f(e.messageText),enqueuedAt:d(e.insertedOn??e.insertionTime,t),attempt:Number(e.dequeueCount??0),leaseToken:String(e.popReceipt??""),leaseExpiresAt:d(e.nextVisibleOn,t)}}function N(e,t={}){let r=t.now??(()=>new Date);return {async enqueue(n){let o=await e.sendMessage(y(n));return {id:String(o.messageId??""),body:n,enqueuedAt:d(o.insertionTime,r),attempt:0}},async lease(n){return (await e.receiveMessages({numberOfMessages:n?.max,visibilityTimeout:n?.visibilityMs?Math.max(1,Math.ceil(n.visibilityMs/1e3)):void 0})).receivedMessageItems.map(s=>j(s,r))},async ack(n,o){try{return await e.deleteMessage(n,o),!0}catch(s){if(C(s)===404)return false;throw s}},async nack(n,o,s){try{if(s?.dead){if(!t.deadLetterQueueClient)return !1;let a={messageId:n,reason:s.reason??null};return await t.deadLetterQueueClient.sendMessage(y(a)),await e.deleteMessage(n,o),!0}return await e.updateMessage(n,o,y({requeued:!0}),0),!0}catch(a){if(C(a)===404)return false;throw a}},async peekActive(n=""){return (await e.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>q(s,r)).filter(s=>!n||s.id.startsWith(n))},async peekDeadLetter(n=""){return t.deadLetterQueueClient?(await t.deadLetterQueueClient.peekMessages({numberOfMessages:32})).peekedMessageItems.map(s=>{let a=f(s.messageText);return {id:String(s.messageId??""),body:a,enqueuedAt:d(s.insertedOn??s.insertionTime,r),attempt:Number(s.dequeueCount??0),reason:typeof a.reason=="string"?a.reason:void 0}}).filter(s=>!n||s.id.startsWith(n)):[]}}}export{J as createAzureBlobStorage,N as createAzureQueueStorage,K as createCosmosAtomicRelayLock,I as createCosmosJournalStorage,z as createCosmosKvStorage};//# sourceMappingURL=cloud-storage.js.map
1
+ export{d as createAzureBlobStorage,e as createAzureQueueStorage,c as createCosmosAtomicRelayLock,b as createCosmosJournalStorage,a as createCosmosKvStorage}from'./chunk-S44QZUDX.js';export{h as createAsyncBoardConfigStore,j as createAsyncBoardLiveCardsPublic,g as createAsyncBoardWorkerStore,c as createAsyncCardStorageAdapter,d as createAsyncCardStore,b as createAsyncJsonStorage,e as createAsyncStateSnapshotAdapter,f as createAsyncStorageProvider,i as createHostedAsyncBoardPlatformAdapter,a as withAsyncRelayLock}from'./chunk-VMW4Z6EF.js';import'./chunk-HEEDJEKM.js';import'./chunk-N6P2JW4W.js';import'./chunk-XQRNDX4Q.js';import'./chunk-BQS3EIEK.js';import'./chunk-VGT3TRQG.js';import'./chunk-WDPOGXTY.js';import'./chunk-JMDHDY6M.js';import'./chunk-VLBB3D6B.js';import'./chunk-MNEOJWPS.js';import'./chunk-KBELAKIY.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=cloud-storage.js.map
2
2
  //# sourceMappingURL=cloud-storage.js.map
@@ -0,0 +1,3 @@
1
+ 'use strict';require('../chunk-GNFE24S7.cjs');var h=new TextEncoder;function y(o){let r="";for(let i of h.encode(String(o)))r+=String.fromCharCode(i);return (typeof btoa=="function"?btoa(r):Buffer.from(r,"binary").toString("base64")).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function p(o){let r=String(o).replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-String(o).length%4)%4),s=typeof atob=="function"?atob(r):Buffer.from(r,"base64").toString("binary"),i=new Uint8Array(s.length);for(let n=0;n<s.length;n+=1)i[n]=s.charCodeAt(n);return new TextDecoder().decode(i)}function g(...o){return o.map(r=>String(r??"").trim()).filter(Boolean).join("/")}function u(o){return !!(o&&typeof o=="object"&&o.code==="storage/object-not-found")}function S(o,r){let s=o.ref(r);function i(e){return s.child(y(e))}async function n(e){let t=await e.getDownloadURL(),c=await fetch(t,{cache:"no-store"});if(!c.ok)throw new Error(`Failed to fetch storage object ${e.fullPath}: ${c.status}`);return c.text()}async function a(e){let t=await e.getDownloadURL(),c=await fetch(t,{cache:"no-store"});if(!c.ok)throw new Error(`Failed to fetch storage object ${e.fullPath}: ${c.status}`);return new Uint8Array(await c.arrayBuffer())}async function l(){let e=[];async function t(c){let d=await c.listAll();for(let f of d.prefixes)await t(f);for(let f of d.items){let w=f.name||f.fullPath.slice(s.fullPath.length+1);e.push(p(w));}}try{await t(s);}catch(c){if(u(c))return [];throw c}return e.sort()}return {async read(e){try{return await n(i(e))}catch(t){if(u(t))return null;throw t}},async write(e,t){await i(e).putString(String(t),"raw",{contentType:"text/plain; charset=utf-8"});},async exists(e){try{return await i(e).getMetadata(),!0}catch(t){if(u(t))return false;throw t}},async remove(e){try{await i(e).delete();}catch(t){if(!u(t))throw t}},async readBytes(e){try{return await a(i(e))}catch(t){if(u(t))return null;throw t}},async writeBytes(e,t){await i(e).put(t,{contentType:"application/octet-stream"});},async listKeys(e=""){let t=await l();return e?t.filter(c=>c.startsWith(e)):t},async stat(e){try{let t=await i(e).getMetadata();return {key:e,size:Number(t.size??0),updatedAt:t.updated??void 0,contentType:t.contentType??void 0}}catch(t){if(u(t))return null;throw t}},keyRef(e){return {kind:"firebase-storage",value:g(r,y(e))}}}}function b(o,r){let s=S(o,r);async function i(n="scratch-",a=""){let l=globalThis.crypto?.randomUUID?.()??`${Date.now()}-${Math.random().toString(36).slice(2,10)}`;return `${n}${l}${a}`}return {...s,getUniqueKey:i,async create(n,a="scratch-",l=""){let e=await i(a,l);return await s.write(e,n),e},keyRef(n){return {kind:"firebase-storage",value:g(r,y(n))}},config:{async get(n){let a=await s.read(`__config__/${n}`);if(a==null)return null;try{return JSON.parse(a)}catch{return a}},async set(n,a){await s.write(`__config__/${n}`,JSON.stringify(a));}}}}function m(o,r,s){let i=g("boards",s,"blobs"),n=g("boards",s,"scratch");return {...o,blobStorage(a){return S(r,g(i,a||"root"))},scratchStorage(){return b(r,n)},scratchStorageForRef(){return b(r,n)},async resolveBlob(a){if(a?.kind==="firebase-storage"&&typeof a.value=="string"){let l=await r.ref(a.value).getDownloadURL(),e=await fetch(l,{cache:"no-store"});if(!e.ok)throw new Error(`Failed to resolve storage blob ${a.value}: ${e.status}`);return e.text()}return typeof o.resolveBlob=="function"?o.resolveBlob(a):null}}}
2
+ exports.createFirebaseStorageBlobStore=S;exports.createFirebaseStorageScratchStore=b;exports.wrapWithFirebaseStorageBlobs=m;//# sourceMappingURL=index.cjs.map
3
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1,57 @@
1
+ import { a as KindValueRef } from '../storage-interface-BFiD3kyB.cjs';
2
+ import { a as AsyncBlobStorage, f as AsyncScratchStorage } from '../storage-async-interface-BRR4eBjx.cjs';
3
+
4
+ /**
5
+ * firebase-storage — browser-safe Firebase Storage (Google Cloud Storage) blob
6
+ * primitives + a helper that swaps any existing `AsyncBoardPlatformAdapter`'s
7
+ * blob/scratch namespaces over to Firebase Storage.
8
+ *
9
+ * This module never imports firebase. The host application initializes
10
+ * `firebase.app()` and passes the resulting `firebase.storage()` handle in.
11
+ * That keeps Firebase SDK init (project-specific, host-app concern) out of
12
+ * yaml-flow while letting any consumer reuse the same Storage adapter wiring.
13
+ */
14
+
15
+ interface FirebaseStorageMetadataLike {
16
+ readonly size?: number | string;
17
+ readonly updated?: string;
18
+ readonly contentType?: string;
19
+ }
20
+ interface FirebaseStorageListResultLike {
21
+ readonly items: FirebaseStorageReferenceLike[];
22
+ readonly prefixes: FirebaseStorageReferenceLike[];
23
+ }
24
+ interface FirebaseStorageReferenceLike {
25
+ readonly fullPath: string;
26
+ readonly name: string;
27
+ child(path: string): FirebaseStorageReferenceLike;
28
+ getDownloadURL(): Promise<string>;
29
+ getMetadata(): Promise<FirebaseStorageMetadataLike>;
30
+ delete(): Promise<void>;
31
+ listAll(): Promise<FirebaseStorageListResultLike>;
32
+ putString(data: string, format?: 'raw' | 'base64' | 'base64url' | 'data_url', metadata?: {
33
+ contentType?: string;
34
+ }): Promise<unknown>;
35
+ put(data: ArrayBuffer | Uint8Array | Blob, metadata?: {
36
+ contentType?: string;
37
+ }): Promise<unknown>;
38
+ }
39
+ interface FirebaseStorageLike {
40
+ ref(path?: string): FirebaseStorageReferenceLike;
41
+ }
42
+ interface FirebaseStorageBlobStore extends AsyncBlobStorage {
43
+ keyRef(key: string): KindValueRef;
44
+ }
45
+ declare function createFirebaseStorageBlobStore(storage: FirebaseStorageLike, basePath: string): FirebaseStorageBlobStore;
46
+ declare function createFirebaseStorageScratchStore(storage: FirebaseStorageLike, basePath: string): AsyncScratchStorage;
47
+ /**
48
+ * Replace the blob/scratch namespaces of an existing board adapter (e.g. one
49
+ * produced by `createFirestoreBoardAdapter`) with Firebase Storage-backed
50
+ * implementations rooted at `boards/<boardId>/{blobs,scratch}/`.
51
+ *
52
+ * Pass in a Firebase Storage handle (`firebase.app().storage()`). All other
53
+ * adapter methods are forwarded unchanged.
54
+ */
55
+ declare function wrapWithFirebaseStorageBlobs<T extends Record<string, any>>(boardAdapter: T, storage: FirebaseStorageLike, boardId: string): T;
56
+
57
+ export { type FirebaseStorageBlobStore, type FirebaseStorageLike, type FirebaseStorageListResultLike, type FirebaseStorageMetadataLike, type FirebaseStorageReferenceLike, createFirebaseStorageBlobStore, createFirebaseStorageScratchStore, wrapWithFirebaseStorageBlobs };
@@ -0,0 +1,57 @@
1
+ import { a as KindValueRef } from '../storage-interface-BFiD3kyB.js';
2
+ import { a as AsyncBlobStorage, f as AsyncScratchStorage } from '../storage-async-interface-DhlOVPSp.js';
3
+
4
+ /**
5
+ * firebase-storage — browser-safe Firebase Storage (Google Cloud Storage) blob
6
+ * primitives + a helper that swaps any existing `AsyncBoardPlatformAdapter`'s
7
+ * blob/scratch namespaces over to Firebase Storage.
8
+ *
9
+ * This module never imports firebase. The host application initializes
10
+ * `firebase.app()` and passes the resulting `firebase.storage()` handle in.
11
+ * That keeps Firebase SDK init (project-specific, host-app concern) out of
12
+ * yaml-flow while letting any consumer reuse the same Storage adapter wiring.
13
+ */
14
+
15
+ interface FirebaseStorageMetadataLike {
16
+ readonly size?: number | string;
17
+ readonly updated?: string;
18
+ readonly contentType?: string;
19
+ }
20
+ interface FirebaseStorageListResultLike {
21
+ readonly items: FirebaseStorageReferenceLike[];
22
+ readonly prefixes: FirebaseStorageReferenceLike[];
23
+ }
24
+ interface FirebaseStorageReferenceLike {
25
+ readonly fullPath: string;
26
+ readonly name: string;
27
+ child(path: string): FirebaseStorageReferenceLike;
28
+ getDownloadURL(): Promise<string>;
29
+ getMetadata(): Promise<FirebaseStorageMetadataLike>;
30
+ delete(): Promise<void>;
31
+ listAll(): Promise<FirebaseStorageListResultLike>;
32
+ putString(data: string, format?: 'raw' | 'base64' | 'base64url' | 'data_url', metadata?: {
33
+ contentType?: string;
34
+ }): Promise<unknown>;
35
+ put(data: ArrayBuffer | Uint8Array | Blob, metadata?: {
36
+ contentType?: string;
37
+ }): Promise<unknown>;
38
+ }
39
+ interface FirebaseStorageLike {
40
+ ref(path?: string): FirebaseStorageReferenceLike;
41
+ }
42
+ interface FirebaseStorageBlobStore extends AsyncBlobStorage {
43
+ keyRef(key: string): KindValueRef;
44
+ }
45
+ declare function createFirebaseStorageBlobStore(storage: FirebaseStorageLike, basePath: string): FirebaseStorageBlobStore;
46
+ declare function createFirebaseStorageScratchStore(storage: FirebaseStorageLike, basePath: string): AsyncScratchStorage;
47
+ /**
48
+ * Replace the blob/scratch namespaces of an existing board adapter (e.g. one
49
+ * produced by `createFirestoreBoardAdapter`) with Firebase Storage-backed
50
+ * implementations rooted at `boards/<boardId>/{blobs,scratch}/`.
51
+ *
52
+ * Pass in a Firebase Storage handle (`firebase.app().storage()`). All other
53
+ * adapter methods are forwarded unchanged.
54
+ */
55
+ declare function wrapWithFirebaseStorageBlobs<T extends Record<string, any>>(boardAdapter: T, storage: FirebaseStorageLike, boardId: string): T;
56
+
57
+ export { type FirebaseStorageBlobStore, type FirebaseStorageLike, type FirebaseStorageListResultLike, type FirebaseStorageMetadataLike, type FirebaseStorageReferenceLike, createFirebaseStorageBlobStore, createFirebaseStorageScratchStore, wrapWithFirebaseStorageBlobs };
@@ -0,0 +1,3 @@
1
+ import'../chunk-FW4363Y4.js';var h=new TextEncoder;function y(o){let r="";for(let i of h.encode(String(o)))r+=String.fromCharCode(i);return (typeof btoa=="function"?btoa(r):Buffer.from(r,"binary").toString("base64")).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function p(o){let r=String(o).replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-String(o).length%4)%4),s=typeof atob=="function"?atob(r):Buffer.from(r,"base64").toString("binary"),i=new Uint8Array(s.length);for(let n=0;n<s.length;n+=1)i[n]=s.charCodeAt(n);return new TextDecoder().decode(i)}function g(...o){return o.map(r=>String(r??"").trim()).filter(Boolean).join("/")}function u(o){return !!(o&&typeof o=="object"&&o.code==="storage/object-not-found")}function S(o,r){let s=o.ref(r);function i(e){return s.child(y(e))}async function n(e){let t=await e.getDownloadURL(),c=await fetch(t,{cache:"no-store"});if(!c.ok)throw new Error(`Failed to fetch storage object ${e.fullPath}: ${c.status}`);return c.text()}async function a(e){let t=await e.getDownloadURL(),c=await fetch(t,{cache:"no-store"});if(!c.ok)throw new Error(`Failed to fetch storage object ${e.fullPath}: ${c.status}`);return new Uint8Array(await c.arrayBuffer())}async function l(){let e=[];async function t(c){let d=await c.listAll();for(let f of d.prefixes)await t(f);for(let f of d.items){let w=f.name||f.fullPath.slice(s.fullPath.length+1);e.push(p(w));}}try{await t(s);}catch(c){if(u(c))return [];throw c}return e.sort()}return {async read(e){try{return await n(i(e))}catch(t){if(u(t))return null;throw t}},async write(e,t){await i(e).putString(String(t),"raw",{contentType:"text/plain; charset=utf-8"});},async exists(e){try{return await i(e).getMetadata(),!0}catch(t){if(u(t))return false;throw t}},async remove(e){try{await i(e).delete();}catch(t){if(!u(t))throw t}},async readBytes(e){try{return await a(i(e))}catch(t){if(u(t))return null;throw t}},async writeBytes(e,t){await i(e).put(t,{contentType:"application/octet-stream"});},async listKeys(e=""){let t=await l();return e?t.filter(c=>c.startsWith(e)):t},async stat(e){try{let t=await i(e).getMetadata();return {key:e,size:Number(t.size??0),updatedAt:t.updated??void 0,contentType:t.contentType??void 0}}catch(t){if(u(t))return null;throw t}},keyRef(e){return {kind:"firebase-storage",value:g(r,y(e))}}}}function b(o,r){let s=S(o,r);async function i(n="scratch-",a=""){let l=globalThis.crypto?.randomUUID?.()??`${Date.now()}-${Math.random().toString(36).slice(2,10)}`;return `${n}${l}${a}`}return {...s,getUniqueKey:i,async create(n,a="scratch-",l=""){let e=await i(a,l);return await s.write(e,n),e},keyRef(n){return {kind:"firebase-storage",value:g(r,y(n))}},config:{async get(n){let a=await s.read(`__config__/${n}`);if(a==null)return null;try{return JSON.parse(a)}catch{return a}},async set(n,a){await s.write(`__config__/${n}`,JSON.stringify(a));}}}}function m(o,r,s){let i=g("boards",s,"blobs"),n=g("boards",s,"scratch");return {...o,blobStorage(a){return S(r,g(i,a||"root"))},scratchStorage(){return b(r,n)},scratchStorageForRef(){return b(r,n)},async resolveBlob(a){if(a?.kind==="firebase-storage"&&typeof a.value=="string"){let l=await r.ref(a.value).getDownloadURL(),e=await fetch(l,{cache:"no-store"});if(!e.ok)throw new Error(`Failed to resolve storage blob ${a.value}: ${e.status}`);return e.text()}return typeof o.resolveBlob=="function"?o.resolveBlob(a):null}}}
2
+ export{S as createFirebaseStorageBlobStore,b as createFirebaseStorageScratchStore,m as wrapWithFirebaseStorageBlobs};//# sourceMappingURL=index.js.map
3
+ //# sourceMappingURL=index.js.map