yaml-flow 8.6.2 → 8.6.3
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.
- package/browser/asset-integrity.json +3 -3
- package/examples/board/demo-shell-with-server.html +2 -2
- package/examples/board/doc.html +2 -2
- package/examples/board-local/demo-shell-localstorage.html +3 -3
- package/lib/board-live-cards-server-runtime.cjs +1 -1
- package/lib/board-live-cards-server-runtime.js +1 -1
- package/lib/chunk-GLIX37VG.cjs +8 -0
- package/lib/chunk-LRVAVWAG.js +8 -0
- package/lib/server-runtime/index.cjs +1 -1
- package/lib/server-runtime/index.js +1 -1
- package/package.json +1 -1
- package/lib/chunk-KQX6R4PV.cjs +0 -8
- package/lib/chunk-OSWJKJLB.js +0 -8
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
{
|
|
2
|
-
"generatedAt": "2026-
|
|
2
|
+
"generatedAt": "2026-06-01T09:44:06.733Z",
|
|
3
3
|
"algorithm": "sha256",
|
|
4
4
|
"files": {
|
|
5
5
|
"browser/board-livecards-localstorage.js": {
|
|
6
|
-
"sha256": "sha256-
|
|
7
|
-
"bytes":
|
|
6
|
+
"sha256": "sha256-cEKaHP3dc8Vw2t8nS1LdKCj2vDBwZRs+QmImVDkyCb0=",
|
|
7
|
+
"bytes": 188339
|
|
8
8
|
},
|
|
9
9
|
"browser/live-cards.schema.json": {
|
|
10
10
|
"sha256": "sha256-F5nfqDzZ5L3p0lLTMxGt4YtMa2sVzdNPh8sbQ8OiXHE=",
|
|
@@ -19,8 +19,8 @@
|
|
|
19
19
|
<script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
|
|
20
20
|
<script src="https://cdn.jsdelivr.net/npm/dompurify/dist/purify.min.js"></script>
|
|
21
21
|
<script src="https://cdn.jsdelivr.net/npm/leader-line/leader-line.min.js"></script>
|
|
22
|
-
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.
|
|
23
|
-
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.
|
|
22
|
+
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.3/browser/live-cards.js"></script>
|
|
23
|
+
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.3/browser/board-livecards-client.js"></script>
|
|
24
24
|
</head>
|
|
25
25
|
<body class="bg-light">
|
|
26
26
|
<div class="container-fluid py-3">
|
package/examples/board/doc.html
CHANGED
|
@@ -37,8 +37,8 @@
|
|
|
37
37
|
<script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
|
|
38
38
|
<script src="https://cdn.jsdelivr.net/npm/dompurify/dist/purify.min.js"></script>
|
|
39
39
|
<script src="https://cdn.jsdelivr.net/npm/leader-line/leader-line.min.js"></script>
|
|
40
|
-
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.
|
|
41
|
-
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.
|
|
40
|
+
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.3/browser/live-cards.js"></script>
|
|
41
|
+
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.3/browser/board-livecards-client.js"></script>
|
|
42
42
|
</head>
|
|
43
43
|
<body class="bg-light">
|
|
44
44
|
<div class="container-fluid py-3">
|
|
@@ -6,13 +6,13 @@
|
|
|
6
6
|
<title>Example Board Demo (LocalStorage Runtime)</title>
|
|
7
7
|
<link rel="icon" type="image/svg+xml" href="../../browser/favicon.svg" />
|
|
8
8
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css" rel="stylesheet" />
|
|
9
|
-
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.
|
|
9
|
+
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.3/browser/compute-jsonata.js"></script>
|
|
10
10
|
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
|
|
11
11
|
<script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"></script>
|
|
12
12
|
<script src="https://cdn.jsdelivr.net/npm/dompurify/dist/purify.min.js"></script>
|
|
13
13
|
<script src="https://cdn.jsdelivr.net/npm/leader-line/leader-line.min.js"></script>
|
|
14
|
-
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.
|
|
15
|
-
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.
|
|
14
|
+
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.3/browser/live-cards.js"></script>
|
|
15
|
+
<script src="https://cdn.jsdelivr.net/npm/yaml-flow@8.6.3/browser/board-livecards-localstorage.js"></script>
|
|
16
16
|
</head>
|
|
17
17
|
<body class="bg-light">
|
|
18
18
|
<div class="container-fluid py-3">
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkGLIX37VG_cjs=require('./chunk-GLIX37VG.cjs');require('./chunk-WOALA3V5.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-GJJMEAVN.cjs'),require('./chunk-IXZG74EW.cjs'),require('./chunk-NMZ6XNLB.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-YMEIPKLW.cjs'),require('./chunk-GYQXDNNI.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createHostedBoardQueueLaneRegistry",{enumerable:true,get:function(){return chunkGLIX37VG_cjs.a}});Object.defineProperty(exports,"createMultiBoardServerRuntime",{enumerable:true,get:function(){return chunkGLIX37VG_cjs.c}});Object.defineProperty(exports,"createSingleBoardServerRuntime",{enumerable:true,get:function(){return chunkGLIX37VG_cjs.b}});//# sourceMappingURL=board-live-cards-server-runtime.cjs.map
|
|
2
2
|
//# sourceMappingURL=board-live-cards-server-runtime.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{a as createHostedBoardQueueLaneRegistry,c as createMultiBoardServerRuntime,b as createSingleBoardServerRuntime}from'./chunk-
|
|
1
|
+
export{a as createHostedBoardQueueLaneRegistry,c as createMultiBoardServerRuntime,b as createSingleBoardServerRuntime}from'./chunk-LRVAVWAG.js';import'./chunk-MLVTJASJ.js';import'./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-SCWHDI3I.js';import'./chunk-JMDHDY6M.js';import'./chunk-VLBB3D6B.js';import'./chunk-MNEOJWPS.js';import'./chunk-KBELAKIY.js';import'./chunk-76ON3V7R.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=board-live-cards-server-runtime.js.map
|
|
2
2
|
//# sourceMappingURL=board-live-cards-server-runtime.js.map
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
'use strict';var chunkWOALA3V5_cjs=require('./chunk-WOALA3V5.cjs'),chunkH5HBXPOI_cjs=require('./chunk-H5HBXPOI.cjs'),chunkOEFTOO47_cjs=require('./chunk-OEFTOO47.cjs'),chunkSFVO2LB2_cjs=require('./chunk-SFVO2LB2.cjs'),chunkGJJMEAVN_cjs=require('./chunk-GJJMEAVN.cjs'),chunkYMEIPKLW_cjs=require('./chunk-YMEIPKLW.cjs'),chunkGYQXDNNI_cjs=require('./chunk-GYQXDNNI.cjs');function wt(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Qe(r){if(!r||typeof r!="object")return false;let t=r.summary;return !t||typeof t!="object"?false:Number(t.card_count||0)>0}function ze(r,t){if(!t||typeof t!="object")return;let s=t;if(s.kind==="notification-batch"&&Array.isArray(s.notifications)){for(let o of s.notifications)ze(r,o);return}s.kind==="status"&&Qe(s.status)&&(r.status=s.status),s.kind==="computed_values"&&s.cardId&&(r.computedValues[s.cardId]=s.values),s.kind==="data_object"&&s.key&&(r.dataObjects[s.key]=s.payload),s.kind==="card_refreshed"&&s.cardId&&(r.cards[s.cardId]=s.card),s.kind==="card_removed"&&s.cardId&&(delete r.cards[s.cardId],delete r.computedValues[s.cardId]);}function ge(r){return typeof r.journalStorage=="function"}function Ct(r){return typeof r.whatToRun=="string"?r.whatToRun.startsWith("b64:")?chunkSFVO2LB2_cjs.b(r.whatToRun).value:r.whatToRun:r.whatToRun.value}function se(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function He(r){let t=r.reduce((u,p)=>u+p.length,0),s=new Uint8Array(t),o=0;for(let u of r)s.set(u,o),o+=u.length;return s}function ht(r){let t=new Map,s=new Map,o=new Map,u=0,p=null;function R(i){let m=JSON.stringify(i);return u++,`id: ${u}
|
|
2
|
+
data: ${m}
|
|
3
|
+
|
|
4
|
+
`}function C(i){let m=i;try{m.flushHeaders?.();}catch{}try{m.flush?.();}catch{}try{m.socket?.setNoDelay?.(!0);}catch{}try{m.socket?.uncork?.();}catch{}}function F(i,m){let A=t.get(i);if(A&&!(m&&A.res!==m)){t.delete(i),j();try{r.onSseClientDisconnected?.(i);}catch{}try{A.res.end();}catch{}}}function T(i,m,A){let P=t.get(i);P&&F(i,P.res),t.set(i,{res:m,subscribedChatCardIds:A??new Set});}function g(i,m){let A=t.get(i);if(!A)return;let P=R(m);try{A.res.write(P),C(A.res);}catch{F(i,A.res);}}function b(){let i=new Set;for(let m of t.values())for(let A of m.subscribedChatCardIds)i.add(A);return Array.from(i)}function S(i){let m=s.has(i)?s.get(i):null,{cursor:A}=r.chatStorage.readAfter(i,m),P=r.chatStorage.isProcessing(i),G=P!==(o.get(i)??false),ue=A!==m;return ue&&s.set(i,A),o.set(i,P),ue||G}function O(i,m){let A=r.readChatRecords(i),P=Date.now();return {kind:"card_chats",cardId:i,sentAt:new Date(P).toISOString(),sentAtMs:P,messages:A.map(G=>({role:String(G.role||"system"),text:String(G.text||""),files:Array.isArray(G.files)?G.files:[]})),receiving:m,processing:r.chatStorage.isProcessing(i)}}function x(i,m=true){let A={kind:"notification-batch",notifications:[O(i,m)]};for(let[P,G]of t.entries())G.subscribedChatCardIds.has(i)&&g(P,A);}function j(){b().length>0||(p&&(clearInterval(p),p=null),s.clear(),o.clear());}function w(){if(p)return;let i=()=>{let m=b();if(m.length===0){j();return}let A=new Set(m);for(let P of Array.from(s.keys()))A.has(P)||s.delete(P);for(let P of Array.from(o.keys()))A.has(P)||o.delete(P);for(let P of m)S(P)&&x(P,true);};i(),p=setInterval(i,1e3);}function v(i,m){let A=t.get(i);if(!A)return false;A.subscribedChatCardIds.add(m);let{cursor:P}=r.chatStorage.readAfter(m,null);return s.set(m,P),o.set(m,r.chatStorage.isProcessing(m)),w(),g(i,{kind:"notification-batch",notifications:[O(m,true)]}),true}function L(i,m){let A=t.get(i);return A?(A.subscribedChatCardIds.delete(m),b().includes(m)||(s.delete(m),o.delete(m)),j(),true):false}function d(i){if(!i||typeof i!="object")return false;let m=i.kind;return m==="card_chats"||m==="chat_messages"}function l(i){if(!i||i.length===0)return;let m=[],A=new Set;for(let P of i)d(P)&&typeof P.cardId=="string"?A.add(String(P.cardId)):m.push(P);if(m.length>0){let P={kind:"notification-batch",notifications:m};for(let G of t.keys())g(G,P);}for(let P of A)x(P,true);}return {size:()=>t.size,has:i=>t.has(i),get:i=>t.get(i),buildFrame:R,flushTransport:C,register:T,disconnect:F,writeFrame:g,subscribeChat:v,unsubscribeChat:L,broadcastNotificationBatch:l,broadcastCardChats:x}}function z(r,...t){for(let s of t)if(typeof r[s]=="string")return String(r[s]);return ""}function ye(r,...t){for(let s of t)if(r[s]!==void 0)return Number(r[s])}function _e(r,...t){for(let s of t){let o=r[s];if(o&&typeof o=="object"&&!Array.isArray(o))return o}return {}}function he(r,t,...s){for(let o of s){let u=r[o];if(u&&typeof u=="object"&&!Array.isArray(u))return u}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function We(r,t,...s){for(let o of s){let u=r[o];if(u!==void 0){let p=Number(u);if(Number.isFinite(p))return p}}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function Rt(r){if(Array.isArray(r.bytes))return new Uint8Array(r.bytes.map(t=>Math.max(0,Math.min(255,Number(t)||0))));if(typeof r.text=="string")return new TextEncoder().encode(r.text);if(typeof r.base64=="string"){let t=String(r.base64).replace(/-/g,"+").replace(/_/g,"/"),s=t+"=".repeat((4-t.length%4)%4),o=atob(s);return Uint8Array.from(o,u=>u.charCodeAt(0))}return null}function Je(r,t){if(r?.status==="success")return Object.prototype.hasOwnProperty.call(r,"data")?r.data:void 0;throw r?.status==="fail"||r?.status==="error"?Object.assign(new Error(r.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function Ke(r,t){return Je(await r,t)}function Ge(r){let t=z(r,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let s=t.split(".");if(!(s.length>=2&&s[0]==="chat"&&s.every(u=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(u))))throw Object.assign(new Error("MCP tool only supports card meta keys under chat.*"),{statusCode:400});return t}function Ze(r,t){let s=r.meta;for(let o of t.split(".")){if(!s||typeof s!="object"||Array.isArray(s)||!Object.prototype.hasOwnProperty.call(s,o))return {exists:false,value:null};s=s[o];}return {exists:true,value:s}}function kt(r){let{boardId:t,getMcpFacade:s,getMcpCardStoreFacade:o}=r;function u(T){let g=z(T,"board_id"),b=z(T,"card_id");if(!g)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(!b)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});if(g!==t)throw Object.assign(new Error(`Unknown board_id: ${g}`),{statusCode:400});return {cardId:b}}function p(T,g){let{cardId:b}=u(T);return s().setChatProcessing({cardId:b,active:g}),{status:"success",data:{boardId:t,cardId:b,active:g}}}function R(T){let{cardId:g}=u(T),b=s().getChatProcessing({cardId:g});return {status:"success",data:{boardId:t,cardId:g,active:b.active}}}async function C(T){let{cardId:g}=u(T),b=Ge(T);if(!Object.prototype.hasOwnProperty.call(T,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(b.split(".").includes("__visible_controlplane_only")){let S=await Ke(o().get({params:{id:g}}),"cardStore.get"),O=Array.isArray(S.cards)&&S.cards.length>0&&typeof S.cards[0]=="object"&&!Array.isArray(S.cards[0])?S.cards[0]:null,x=O?Ze(O,"__visible_controlplane_only").value:void 0;if(T.value!==x)throw Object.assign(new Error("MCP tool cannot change the reserved meta flag __visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:g,key:b}}}return Je(await o().patch({params:{id:g,path:`meta.${b}`},body:{value:T.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:g,key:b}}}async function F(T){let{cardId:g}=u(T),b=Ge(T),S=await Ke(o().get({params:{id:g}}),"cardStore.get"),O=Array.isArray(S.cards)&&S.cards.length>0&&S.cards[0]&&typeof S.cards[0]=="object"&&!Array.isArray(S.cards[0])?S.cards[0]:null;if(!O)throw Object.assign(new Error(`Card "${g}" not found`),{statusCode:404});let x=Ze(O,b);return {status:"success",data:{boardId:t,cardId:g,key:b,exists:x.exists,value:x.value}}}return {requireCardArgs:u,setChatProcessing:p,getChatProcessing:R,setCardMeta:C,getCardMeta:F}}function St(r){let{boardId:t,boardContexts:s,readCardDefinitions:o,readChatRecords:u,getChatProcessing:p}=r;async function R(){let g=(await Promise.all(s.map(async j=>{try{let w=j.boardAdapter.kvStorageForRef(j.outputsStoreRef),v=await Promise.resolve(w.read("status"));if(v!=null)return v}catch{}return j.notification.status}))).filter(Boolean);if(g.length===0)return null;if(g.length===1)return g[0];let b=[],S=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],O={};for(let j of S)O[j]=0;for(let j of g){let w=j,v=Array.isArray(w.cards)?w.cards:[];b.push(...v);for(let L of S)O[L]+=Number(w?.summary?.[L]||0);}let x=g[0];return {...x,cards:b,summary:{...x.summary||{},card_count:b.length,...O}}}async function C(){let g={},b=async S=>{try{let O=await S.boardOps.getAllOutputsComputedValues({});if(O.status==="success"&&O.data&&typeof O.data=="object"){for(let[x,j]of Object.entries(O.data)){let w=S.notification.cards[x];g[x]={schema_version:"v1",card_id:x,card_data:w?.card_data??{},computed_values:j??{}};}return}}catch{}for(let[O,x]of Object.entries(S.notification.computedValues)){let j=S.notification.cards[O];g[O]={schema_version:"v1",card_id:O,card_data:j?.card_data??{},computed_values:x??{}};}};for(let S of s)await b(S);return g}async function F(){let g={};for(let b of s){try{let S=await b.boardOps.getAllOutputsDataObjects({});if(S.status==="success"&&S.data&&typeof S.data=="object"){Object.assign(g,S.data);continue}}catch{}Object.assign(g,b.notification.dataObjects||{});}return g}async function T(){let g=await o(),b=await C(),S=await F(),O={};for(let j of g){if(!j?.id)continue;let w=j.id,v=b[w]||{},L={...v.card_data&&typeof v.card_data=="object"?v.card_data:j.card_data&&typeof j.card_data=="object"?j.card_data:{}};O[w]={schema_version:v.schema_version||"v1",card_id:v.card_id||w,card_data:L,computed_values:v.computed_values&&typeof v.computed_values=="object"?v.computed_values:{}};}let x={};for(let j of g){if(!j?.id)continue;let w=j.id;try{let v=u(w),L=p(w);(v.length>0||L)&&(x[w]={messages:v.map(d=>({role:String(d.role||"system"),text:String(d.text||""),files:Array.isArray(d.files)?d.files:[]})),receiving:!1,processing:L});}catch{}}return {boardId:t,cardDefinitions:g,statusSnapshot:await R(),dataObjectsByToken:S,cardRuntimeById:O,cardChatsByCardId:x}}return {readStatusSnapshot:R,readCardRuntimeArtifacts:C,readDataObjectsByToken:F,buildPublishedRuntimePayload:T}}function Ht(r){let t=String(r||"").trim();if(!t)return "upload.bin";let s=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (s>=0?t.slice(s+1):t)||"upload.bin"}function At(r){let{safeCardId:t,artifactsStores:s,cardFileMetadataStore:o,readCardFromStore:u,updateCardLocalOnly:p,writeChatRecord:R}=r;async function C(g){let b=[];try{let S=await u(g);if(!S)return b;let O=o().read(S.card_data&&typeof S.card_data=="object"?S.card_data:null);for(let x of O)b.push(String(x.stored_name??""));}catch{}return b}async function F(g,b,S,O){let x=t(g),j=s(g),w=Ht(b),v=await C(g),d=`${String(v.length+1).padStart(3,"0")}-${w}`.slice(-36);return j.files&&await j.files.putBytes(`${x}/${d}`,new Uint8Array(O),S||"application/octet-stream"),{name:w,stored_name:d,size:O.length,mime_type:S||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function T(g,b,S,O,x){if(!O.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let j=x?.inChat===true,w=await F(g,b,S,O),v=null;if(await p(g,L=>{let d=new Date().toISOString(),l=L.card_data&&typeof L.card_data=="object"?L.card_data:{};L.card_data=l;let i=o().normalizeIncoming([{name:w.name,stored_name:w.stored_name,size:w.size,mime_type:w.mime_type,uploaded_at:w.uploaded_at||d,chat:j}],d);return v=o().merge(l,i).findIndex(A=>A.stored_name===w.stored_name),L}),j){let L=typeof v=="number"&&v>=0?` #${v}`:"";R(g,"system",`file uploaded: ${w.name} as ${w.stored_name}${L}`,[],x?.turnId??"");}return {ok:true,file:w}}return {uploadCardFile:T,readCardStoredFileNames:C}}function vt(r){return {"discover.source-kinds":()=>r.discoverSourceKinds(),"inspect.board-runtime-status":()=>r.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>r.inspectCardDefinitionAndRuntime({cardId:z(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let s=ye(t,"tail_turns"),o=ye(t,"tail"),u=z(t,"turn_id"),p=t.all_turns===true,R=z(t,"tail_turns_before_id");return r.inspectChatMessagesOnCards({cardId:z(t,"card_id"),...s!==void 0?{lastUserTurns:s}:{},...o!==void 0?{tail:o}:{},...u?{turnId:u}:{},...p?{allTurns:true}:{},...R?{tailTurnsBeforeId:R}:{}})},"inspect.file-contents":t=>r.inspectFileContents({cardId:z(t,"card_id"),fileIdx:Number(ye(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>r.preflightValidateCandidateCardDefinition({candidateCardContent:he(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>r.preflightMaterializeCandidateCard({candidateCardContent:he(t,"candidate_card_content","candidate_card_content"),mockRequires:he(t,"mock_requires","mock_requires"),mockFetchedSources:he(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>r.preflightProbeSingleSourceInCandidateCard({candidateCardContent:he(t,"candidate_card_content","candidate_card_content"),mockProjections:_e(t,"mock_projections"),sourceIdx:We(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>r.preflightRunSingleSourceInCandidateCard({candidateCardContent:he(t,"candidate_card_content","candidate_card_content"),mockProjections:_e(t,"mock_projections"),sourceIdx:We(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>r.preflightRunSingleSourceInLiveCard({cardId:z(t,"card_id"),sourceIdx:We(t,"source_idx","source_idx"),mockRequires:he(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>r.preflightRunOneCycleWithCandidateCard({candidateCardContent:he(t,"candidate_card_content","candidate_card_content"),mockRequires:_e(t,"mock_requires")}),"manage.read-card":t=>r.manageReadCard({cardId:z(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let s=z(t,"turn_id");if(!s)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return r.manageAddChatEntryAndAnyAttachments({cardId:z(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...s?{turn:s}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"manage.upsert-card":t=>r.manageUpsertCard({cardId:z(t,"card_id"),candidateCardContent:_e(t,"candidate_card_content")}),"manage.remove-card":t=>r.manageRemoveCard({cardId:z(t,"card_id")})}}function Pt(r){let{boardId:t,uploadCardFile:s,getMcpFacade:o,controlplane:u}=r;return {"getstate.is-chat-processing":p=>u.getChatProcessing(p),"setstate.chat-processing-started":p=>u.setChatProcessing(p,true),"setstate.chat-processing-done":p=>u.setChatProcessing(p,false),"getstate.card-meta":p=>u.getCardMeta(p),"setstate.card-meta":p=>u.setCardMeta(p),"manage.upload-card-file":p=>{let R=z(p,"board_id"),C=z(p,"card_id"),F=z(p,"file_name"),T=z(p,"content_type")||"application/octet-stream",g=Rt(p);if(!R)throw Object.assign(new Error("manage.upload-card-file requires board_id"),{statusCode:400});if(R!==t)throw Object.assign(new Error(`Unknown board_id: ${R}`),{statusCode:400});if(!C)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!F)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!g)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return s(C,F,T,g,{inChat:false})},"manage.admin-read-card":async p=>{let{cardId:R}=u.requireCardArgs(p);return {status:"success",data:{cards:await o().adminReadCard({cardId:R})}}},"manage.admin-upsert-card":p=>{let R=z(p,"board_id"),C=z(p,"card_id");if(!R)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!C)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(R!==t)throw Object.assign(new Error(`Unknown board_id: ${R}`),{statusCode:400});return o().adminUpsertCard({cardId:C,candidateCardContent:_e(p,"candidate_card_content")})}}}function Bt(r){let{boardContexts:t,cardOwnerIndex:s,cardContextForCard:o,readStatusSnapshot:u,readDataObjectsByToken:p,readCardRuntimeArtifacts:R,readCardFromStore:C,readCardDefinitions:F,processAccumulatedLaneInternal:T,uploadCardFile:g,chatStorePublic:b,serverUrl:S,apiBasePath:O}=r;function x(){return t[0]??null}function j(){return {async status(){let d=await u();return d==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:d}},async getOutputsDataObject(d){let l=d?.params?.key;return l?{status:"success",data:(await p())[l]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(d){let l=d?.params?.key;return l?{status:"success",data:(await R())[l]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(d){let l=d?.params?.key;if(!l)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let i=o(l)??x();return i?i.boardOps.getOutputsFetchedSources({params:{key:l}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(d){let l=d?.params?.id;if(!l)return {status:"fail",error:"removeCard requires params.id"};let i=o(l)??x();return i?i.boardOps.removeCard({params:{id:l}}):{status:"fail",error:"Board context is unavailable"}},async cardRefreshedNotify(d){let l=d?.params?.cardId;if(!l)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let i=o(l)??x();return i?i.boardOps.cardRefreshedNotify({params:{cardId:l}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(d){let l=d?.params?.cardId;if(!l)return {status:"fail",error:"upsertCard requires params.cardId"};let i=o(l)??x();if(!i)return {status:"fail",error:"Board context is unavailable"};let m=await i.boardOps.upsertCard({params:{cardId:l,restart:d.params.restart===true}});if(m.status!=="success")return m;if(ge(i.boardAdapter)){let A=await T(true);if(A.status!=="success")return A}return m}}}function w(){let d=()=>{let l=x();if(!l?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return l.nonCore};return {describeTaskExecutorCapabilities(l){return d().describeTaskExecutorCapabilities(l)},validateCardPreflight(l){return d().validateCardPreflight(l)},evalCardCompute(l){return d().evalCardCompute(l)},probeSourcePreflight(l){return d().probeSourcePreflight(l)},runSourcePreflight(l){return d().runSourcePreflight(l)},simulateCardCycle(l){return d().simulateCardCycle(l)}}}function v(){return {async get(d){let l=typeof d.params?.id=="string"?d.params.id:void 0;if(l){let i=await C(l);return i?{status:"success",data:{cards:[i]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await F()}}},async set(d){let l=d.body;if(l==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let i=Array.isArray(l)?l:[l];for(let m of i){let A=m,P=typeof A.id=="string"?A.id:"";if(!P)return {status:"fail",error:"each card must have a string `id` field"};let G=s.get(P)??0,ue=t[G]??x();if(!ue)return {status:"fail",error:"Board context is unavailable"};let fe=await ue.cardStoreOps.set({body:A});if(fe.status!=="success")return fe;s.set(P,G);}return {status:"success",data:{count:i.length}}},async del(d){let l=[d.params?.id,...d.body?.ids??[]].filter(i=>typeof i=="string"&&!!i);if(l.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let i of l){let m=o(i)??x();if(!m)return {status:"fail",error:"Board context is unavailable"};let A=await m.cardStoreOps.del({params:{id:i}});if(A.status!=="success")return A;s.delete(i);}return {status:"success",data:{count:l.length}}},async patch(d){let l=typeof d.params?.id=="string"?d.params.id:void 0,i=typeof d.params?.path=="string"?d.params.path:void 0;if(!l||!i)return {status:"fail",error:"patch requires params.id and params.path"};let m=o(l)??x();return m?m.cardStoreOps.patch(d):{status:"fail",error:"Board context is unavailable"}},async appendFiles(d){let l=typeof d.params?.id=="string"?d.params.id:void 0;if(!l)return {status:"fail",error:"appendFiles requires params.id"};let i=o(l)??x();return i?i.cardStoreOps.appendFiles(d):{status:"fail",error:"Board context is unavailable"}}}}function L(){return chunkGJJMEAVN_cjs.a({board:j(),nonCore:w(),cardStore:v(),chatStore:b,uploadCardFile({cardId:d,fileName:l,contentType:i,bytes:m}){return g(d,l,i,m,{inChat:false})},buildFileDownloadUrl({cardId:d,fileIdx:l,storedName:i}){let m=`${S||""}${O}/cards/${encodeURIComponent(d)}/files/${l}`;return i?`${m}?sn=${encodeURIComponent(i)}`:m},readFetchedSourceJsonByRef({cardId:d,ref:l}){let i=o(d)??x();if(!i||ge(i.boardAdapter))return null;let P=i.boardAdapter.resolveBlob(chunkSFVO2LB2_cjs.b(l)).trim();return P?JSON.parse(P):null}})}return {mcpBoardFacade:j,mcpNonCoreFacade:w,mcpCardStoreFacade:v,createMcpFacade:L}}function It(r){let{sseHub:t,corsHeaders:s,json:o,buildPublishedRuntimePayload:u,onSseClientConnected:p,onChannelSubscribed:R,onChannelUnsubscribed:C}=r;function F(g,b,S,O,x){if(!t.has(b)){o(g,404,{error:`SSE client not connected: ${b}`});return}x?R?.(b,S,O):C?.(b,S,O),o(g,200,{ok:true,clientId:b,channelName:S,...O.cardId?{cardId:O.cardId}:{},subscribed:x});}async function T(g,b,S){let O=t.get(S),x=O?new Set(O.subscribedChatCardIds):new Set;b.writeHead(200,{...s,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),t.flushTransport(b),t.register(S,b,x);let j=await u(),w=t.buildFrame(j);b.write(w);try{p?.(S,L=>{t.writeFrame(S,L);});}catch{}let v=setInterval(()=>{try{b.write(`: keepalive
|
|
5
|
+
|
|
6
|
+
`);}catch{}},15e3);g.on("close",()=>{clearInterval(v),t.disconnect(S,b);});}return {handleChannelSubscription:F,handleSse:T}}async function Xe(r,t,s){let o=s[r];if(!o)throw Object.assign(new Error(`Unknown MCP tool: ${r}`),{statusCode:400});let u=await o(t);if(u&&typeof u=="object"&&!Array.isArray(u)){let p=u,R=p.status;if(R==="success")return Object.prototype.hasOwnProperty.call(p,"data")?u:{status:"success",data:{}};if(R==="fail"||R==="error")return u}return {status:"success",data:u}}function Me(r,t){if(!r||typeof r!="object"||Array.isArray(r))return t;let s=r;if(typeof s.error=="string"&&s.error.trim())return s.error;if(s.step==="validate"){let o=s.validation;if(o&&typeof o=="object"&&!Array.isArray(o)){let p=o.data;if(p&&typeof p=="object"&&!Array.isArray(p)){let R=p.issues;if(Array.isArray(R)){let F=R.find(T=>typeof T=="string"&&T.trim());if(typeof F=="string")return `Validation failed: ${F}`}let C=p.errors;if(Array.isArray(C)&&C.length>0)return "Validation failed"}}return "Validation failed"}return t}function xt(r){let{apiBasePath:t,boardContexts:s,json:o,readJsonBody:u,readRawBody:p,initBoardAndSetup:R,bootstrapBoard:C,buildPublishedRuntimePayload:F,publishPersistedStateSnapshot:T,upsertCardsFromSource:g,applyBoardWorkerCallback:b,handleSse:S,handleChannelSubscription:O,createMcpFacade:x,createMcpToolRegistry:j,createMcpControlplaneToolRegistry:w,readCardFromStore:v,patchCard:L,retriggerCard:d,applyCardAction:l,resolveChatHandlerTarget:i,chatStorePublic:m,chatStorage:A,sseHub:P,uploadCardFile:G,sendCardFileDownloadResponse:ue,resolveCardFileDownloadPayload:fe,isLikelyTextMimeType:ie,sliceTextByLines:be}=r;async function Se(ee,I,Ve){let W=ee.method||"GET",te=Ve,Y=te.pathname;try{if(W==="GET"&&Y===`${t}/init-board`)return await R(),o(I,200,await F()),!0;if(W==="GET"&&Y===`${t}/sse`){await R();let k=String(te.searchParams.get("clientId")||"").trim();if(!k)return o(I,400,{error:"clientId query param is required for SSE"}),!0;await S(ee,I,k);for(let h=0;h<s.length;h++)await T(s[h]),await g(s[h],h),await T(s[h]);return !0}if(W==="GET"&&Y===`${t}/board-status`)return o(I,200,await F()),!0;let we=Y.match(new RegExp(`^${se(t)}/callback/board-worker/([^/]+)/(success|failure)$`));if(W==="POST"&&we){await R();let k=decodeURIComponent(we[1]),h=we[2],M=await u(ee),B=await b(k,h,M);return o(I,B.statusCode,B.body),!0}if(W==="POST"&&Y===`${t}/mcp`){await C();let k=await u(ee),h=typeof k.tool=="string"?k.tool.trim():"",M=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!h)return o(I,400,{error:"tool is required"}),!0;if(h==="inspect.file-contents")return o(I,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let B=await Xe(h,M,j(x()));if(B&&typeof B=="object"&&!Array.isArray(B)){let q=B;if(q.status==="fail")return o(I,400,{error:Me(B,"Request failed")}),!0;if(q.status==="error")return o(I,500,{error:Me(B,"Internal error")}),!0}o(I,200,B);}catch(B){let q=typeof B?.statusCode=="number"?Number(B.statusCode):500,Z=B instanceof Error?B.message:String(B);o(I,q,{error:Z});}return !0}if(W==="POST"&&Y===`${t}/mcp-controlplane`){await C();let k=await u(ee),h=typeof k.tool=="string"?k.tool.trim():"",M=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!h)return o(I,400,{error:"tool is required"}),!0;try{let B=await Xe(h,M,w());if(B&&typeof B=="object"&&!Array.isArray(B)){let q=B;if(q.status==="fail")return o(I,400,{error:Me(B,"Request failed")}),!0;if(q.status==="error")return o(I,500,{error:Me(B,"Internal error")}),!0}o(I,200,B);}catch(B){let q=typeof B?.statusCode=="number"?Number(B.statusCode):500,Z=B instanceof Error?B.message:String(B);o(I,q,{error:Z});}return !0}if(W==="POST"&&Y===`${t}/mcp-raw`){await C();let k=await u(ee),h=typeof k.tool=="string"?k.tool.trim():"",M=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!h)return o(I,400,{error:"tool is required"}),!0;if(h!=="inspect.file-contents")return o(I,400,{error:`Tool does not support raw response: ${h}`}),!0;let B=z(M,"card_id","cardId"),q=ye(M,"file_idx","fileIdx"),Z=ye(M,"head-lines","headLines"),Q=ye(M,"tail-lines","tailLines"),ne=ye(M,"head-bytes","headBytes"),le=ye(M,"tail-bytes","tailBytes");if(!B)return o(I,400,{error:"inspect.file-contents requires card_id"}),!0;if(q===void 0||!Number.isInteger(q)||q<0)return o(I,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([Z,Q,ne,le].filter(ce=>ce!==void 0).length>1)return o(I,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[ce,ke]of [["head-lines",Z],["tail-lines",Q],["head-bytes",ne],["tail-bytes",le]])if(ke!==void 0&&(!Number.isInteger(ke)||ke<0))return o(I,400,{error:`inspect.file-contents requires ${ce} to be a non-negative integer`}),!0;let Ie=await x().inspectFileContents({cardId:B,fileIdx:q}),$e=typeof Ie?.stored_name=="string"?Ie.stored_name:null,{fileRecord:Fe,bytes:Ae}=await fe(B,q,$e),qe=String(Fe.name||Fe.stored_name||"download.bin"),Te=String(Fe.mime_type||"application/octet-stream"),ve=(te.searchParams.get("resp")||"").trim().toLowerCase();if(ve&&ve!=="json-b64")return o(I,400,{error:`unsupported resp mode: ${ve}`}),!0;let Ne=ve==="json-b64",me;if(Z!==void 0||Q!==void 0){if(!ie(Te))return o(I,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let ce=new TextDecoder().decode(Ae),ke=Z!==void 0?be(ce,"head",Z):be(ce,"tail",Q);me=typeof Buffer<"u"?Buffer.from(ke,"utf8"):new TextEncoder().encode(ke);}else if(ne!==void 0||le!==void 0){let ce=ne??le;me=ne!==void 0?Ae.slice(0,ce):Ae.slice(Math.max(0,Ae.length-ce));}else me=Ae;if(Ne){let ce=typeof Buffer<"u"?Buffer.from(me).toString("base64"):btoa(String.fromCharCode(...me));return o(I,200,{bodyBase64:ce,mimeType:Te,filename:qe,byteLength:me.length}),!0}return I.writeHead(200,{"Content-Type":Te,"Content-Disposition":`attachment; filename="${qe}"`,"Content-Length":me.length}),I.end(me),!0}let Ce=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)$`));if(W==="GET"&&Ce){await C();let k=decodeURIComponent(Ce[1]),h=await v(k);return h?(o(I,200,h),!0):(o(I,404,{error:`card not found: ${k}`}),!0)}if(W==="PATCH"&&Ce){await C();let k=decodeURIComponent(Ce[1]),h=await u(ee);return await L(k,h),o(I,200,{ok:!0}),!0}let je=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/retrigger$`));if(W==="POST"&&je){await C();let k=decodeURIComponent(je[1]);return await d(k),o(I,200,{ok:!0}),!0}let pe=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/actions$`));if(W==="POST"&&pe){await C();let k=decodeURIComponent(pe[1]),h=Date.now(),M=new Date(h).toISOString(),B=await u(ee),q=B?.actionType;if(q==="chat-send"&&!await i(k)){let Q=Date.now();return o(I,409,{error:`chat handler is not configured for card: ${k}`,requestReceivedAt:M,requestReceivedAtMs:h,responseSentAt:new Date(Q).toISOString(),responseSentAtMs:Q,responseStatus:409}),!0}if(q==="chat-send"){let Q=B?.payload??{},ne=typeof Q["turn-id"]=="string"?Q["turn-id"]:typeof Q.turnId=="string"?Q.turnId:typeof Q.turn=="string"?Q.turn:"";if(!ne||!String(ne).trim()){let le=Date.now();return o(I,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${k}`,requestReceivedAt:M,requestReceivedAtMs:h,responseSentAt:new Date(le).toISOString(),responseSentAtMs:le,responseStatus:400}),!0}}await l(k,q,B?.payload);let Z=Date.now();return o(I,200,{ok:!0,requestReceivedAt:M,requestReceivedAtMs:h,responseSentAt:new Date(Z).toISOString(),responseSentAtMs:Z,responseStatus:200}),!0}let Pe=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/chats$`));if(W==="GET"&&Pe){await C();let k=decodeURIComponent(Pe[1]),h=String(te.searchParams.get("turn-id")||""),M=String(te.searchParams.get("all-turns")||"").toLowerCase()==="true",B=String(te.searchParams.get("tail-turns-before-id")||""),q=te.searchParams.get("tail-turns"),Z=q==null||q===""?M||h?void 0:1:Number.parseInt(q,10),Q=m.readAll({params:{cardId:k},body:{...Z===void 0?{}:{tailTurns:Z},...h?{turnId:h}:{},...M?{allTurns:!0}:{},...B?{tailTurnsBeforeId:B}:{}}});if(Q.status!=="success")return o(I,400,{error:Q.error||"Failed to read chats"}),!0;let ne=Q.data.records;return o(I,200,{ok:!0,messages:ne}),!0}if(W==="POST"&&Pe){await C();let k=decodeURIComponent(Pe[1]),h=await u(ee),M=typeof h?.role=="string"?h.role:"assistant",B=typeof h?.text=="string"?h.text:"",q=Array.isArray(h?.files)?h.files:[],Z=typeof h?.turn=="string"?h.turn:typeof h?.["turn-id"]=="string"?h["turn-id"]:typeof h?.turnId=="string"?h.turnId:"",Q=h?.done===!0,ne=A.append(k,M,B,q,Z);return Q&&A.setProcessing(k,!1),P.broadcastCardChats(k,!Q),o(I,200,{ok:!0,id:ne}),!0}let Ee=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(W==="POST"&&Ee){await C();let k=decodeURIComponent(Ee[1]),h=await u(ee),M=typeof h?.clientId=="string"?h.clientId.trim():"";return M?P.subscribeChat(M,k)?(o(I,200,{ok:!0,clientId:M,cardId:k,subscribed:!0}),!0):(o(I,404,{error:`SSE client not connected: ${M}`}),!0):(o(I,400,{error:"clientId is required"}),!0)}let Le=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(W==="POST"&&Le){await C();let k=decodeURIComponent(Le[1]),h=await u(ee),M=typeof h?.clientId=="string"?h.clientId.trim():"";return M?P.unsubscribeChat(M,k)?(o(I,200,{ok:!0,clientId:M,cardId:k,subscribed:!1}),!0):(o(I,404,{error:`SSE client not connected: ${M}`}),!0):(o(I,400,{error:"clientId is required"}),!0)}let Re=Y.match(new RegExp(`^${se(t)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(W==="POST"&&Re){await C();let k=decodeURIComponent(Re[1]),h=Re[2]==="subscribe",M=await u(ee),B=typeof M?.clientId=="string"?M.clientId.trim():"";return B?(O(I,B,k,{},h),!0):(o(I,400,{error:"clientId is required"}),!0)}let Be=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(W==="POST"&&Be){await C();let k=decodeURIComponent(Be[1]),h=decodeURIComponent(Be[2]),M=Be[3]==="subscribe",B=await u(ee),q=typeof B?.clientId=="string"?B.clientId.trim():"";return q?(O(I,q,h,{cardId:k},M),!0):(o(I,400,{error:"clientId is required"}),!0)}let De=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/files$`));if(W==="POST"&&De){await C();let k=decodeURIComponent(De[1]),h=String(te.searchParams.get("inChat")||"").toLowerCase()==="true",M=String(te.searchParams.get("turn-id")||"").trim();if(h&&!M)return o(I,400,{error:`file upload with inChat=true requires a non-empty 'turn-id' query parameter for card: ${k}`}),!0;let B=ee.headers["x-file-name"],q=String(ee.headers["content-type"]||"application/octet-stream"),Z=Array.isArray(B)?B[0]:B,Q=Z?decodeURIComponent(String(Z)):"upload.bin",ne=await p(ee);return o(I,200,await G(k,Q,q,ne,{inChat:h,turnId:M})),!0}let Oe=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/files/(\\d+)$`));if(W==="GET"&&Oe){let k=decodeURIComponent(Oe[1]),h=parseInt(Oe[2],10),M=te.searchParams.get("sn");return await ue(I,k,h,M),!0}return !1}catch(we){let Ce=we?.statusCode||500;return o(I,Ce,{error:String(we?.message||we)}),true}}return {handleRuntimeApi:Se}}function Ye(r,t){return t?{...r,...t.pollIntervalMs!=null?{pollIntervalMs:t.pollIntervalMs}:{},...t.visibilityMs!=null?{visibilityMs:t.visibilityMs}:{},...t.concurrency!=null?{concurrency:t.concurrency}:{},...t.maxAttempts!=null?{maxAttempts:t.maxAttempts}:{}}:r}function _t(r,t,s,o){return {id:r,async lease(u){return (await Promise.resolve(t.leaseRequests(u))).map(R=>({id:R.messageId,attempt:R.attempt,message:R.request,ack:()=>Promise.resolve(t.ackRequest(R.messageId,R.leaseToken)),nack:C=>Promise.resolve(t.nackRequest(R.messageId,R.leaseToken,C))}))},async handle(u){await s(u.args,u);},onError:o?(u,p)=>o(u,p.attempt,p.message):void 0}}function Wt(r,t,s,o){return {id:r,async lease(u){return (await Promise.resolve(t.lease(u))).map(R=>({id:R.id,attempt:R.attempt,message:R.body,ack:()=>Promise.resolve(t.ack(R.id,R.leaseToken)),nack:C=>Promise.resolve(t.nack(R.id,R.leaseToken,C))}))},async handle(){await s();},onError:o?(u,p)=>o(u,p.attempt):void 0}}function br(r){let t=r.logger??{info(){},warn(){},error(){}},s=r.boardAdapter,o=r.runtime.queueLaneTuning??{},u=s.processAccumulatedStore(),p=s.chatAgentStore(),R=[];if(R.push(Ye(Wt("process-accumulated",u,async()=>{let C=await r.runtime.processAccumulatedLane();if(C.status!=="success")throw new Error(C.error||`processAccumulatedLane returned ${C.status}`)},(C,F)=>{t.error(`[board-server] queued process-accumulated failed for ${r.boardId} (attempt ${F}): ${String(C&&C.message||C)}`);}),o.processAccumulated)),R.push(Ye(_t("chat-agent",p,async(C,F)=>{await r.runtime.handleChatAgentRequest(F);},(C,F,T)=>{let g=typeof T.args?.cardId=="string"?T.args.cardId:"";t.error(`[board-server] queued chat-agent failed for ${r.boardId}${g?`/${g}`:""} (attempt ${F}): ${String(C&&C.message||C)}`);}),o.chatAgent)),r.executeTaskExecutorRequest){let C=s.boardWorkerStore();R.push(Ye(_t("task-executor",C,r.executeTaskExecutorRequest,(F,T)=>{t.error(`[board-server] queued board-worker failed for ${r.boardId} (attempt ${T}): ${String(F&&F.message||F)}`);}),o.taskExecutor));}return chunkWOALA3V5_cjs.f(R)}var Ft={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},Ot="chat-handler-flow-queue";function Lr(r){let t=String(r.apiBasePath||"/api/board").replace(/\/$/,""),s={...Ft,...r.corsHeaders||{}},o=r.queueLaneTuning??{},u=r.boardId||"",p=r.logger||{info:console.log,warn:console.warn,error:console.error},R=r.invocationAdapter,C=r.chatFlowRunner||null,F=r.chatStorage??chunkWOALA3V5_cjs.b(),T=chunkGYQXDNNI_cjs.a(F),g=r.notificationTransport||null,b=r.serverUrl||null,S=r.executionExtra||{},O=r.onSseClientConnected,x=r.onSseClientDisconnected,j=r.onChannelSubscribed,w=r.onChannelUnsubscribed,v=ht({chatStorage:F,readChatRecords:e=>le(e),onSseClientDisconnected:x});function L(e){function n(y){if(Array.isArray(y))return y;if(y&&typeof y=="object"){let E=y;return Array.isArray(E.files)?E.files:[y]}return null}function a(y){return {async get(E){return y.get(E)},async set(E){return y.set(E)},async del(E){return y.del(E)},async patch(E){return y.patch(E)},async appendFiles(E){return y.appendFiles(E)}}}function f(y){function E(V){return {status:"success",data:V}}function $(V){return {status:"fail",error:V}}function D(V){return {status:"error",error:V instanceof Error?V.message:String(V)}}return {async get(V){try{let U=V.params?.id;if(U){let re=await y.readCard(U);return re?E({cards:[re]}):$(`card "${U}" not found`)}return E({cards:await y.readAllCards()})}catch(U){return D(U)}},async set(V){try{let U=V.body;if(U==null)return $("set requires a body (card object or array of cards)");let re=Array.isArray(U)?U:[U];for(let ae of re){if(typeof ae.id!="string")return $("each card must have a string `id` field");await y.writeCard(ae.id,ae);}return E({count:re.length})}catch(U){return D(U)}},async del(V){try{let U=V.body?.ids??[],re=V.params?.id,ae=re?[...U,re]:U;if(ae.length===0)return $("del requires body.ids (string[]) or params.id");for(let xe of ae)await y.removeCard(xe);return E({count:ae.length})}catch(U){return D(U)}},async patch(V){try{let U=V.params?.id,re=V.params?.path;if(!U)return $("patch requires params.id");if(!re)return $("patch requires params.path");let ae=V.body,xe=ae&&Object.prototype.hasOwnProperty.call(ae,"value")?ae.value:V.body;return await y.patchCard(U,re,xe),E({count:1})}catch(U){return D(U)}},async appendFiles(V){try{let U=V.params?.id;if(!U)return $("appendFiles requires params.id");let re=await y.readCard(U);if(!re)return $(`card "${U}" not found`);let ae=n(V.body);if(!ae||ae.length===0)return $("appendFiles requires a file metadata object, array, or body.files array");let xe=re.card_data&&typeof re.card_data=="object"&&!Array.isArray(re.card_data)?re.card_data:{},nt=Array.isArray(xe.files)?xe.files:[],qt=[...nt,...ae];return await y.patchCard(U,"card_data.files",qt),E({files_added:ae.map((Nt,Ut)=>({idx:nt.length+Ut,entry:Nt}))})}catch(U){return D(U)}}}}let c=ge(e.boardAdapter)?chunkH5HBXPOI_cjs.j(e.baseRef,e.boardAdapter):chunkOEFTOO47_cjs.y(e.baseRef,e.boardAdapter),_=e.nonCoreAdapter??(!ge(e.boardAdapter)&&m(e.boardAdapter)?e.boardAdapter:null),N=_?chunkOEFTOO47_cjs.z(e.baseRef,_):null,K,H=ge(e.boardAdapter)?(()=>{let y=chunkH5HBXPOI_cjs.d(chunkH5HBXPOI_cjs.c(chunkH5HBXPOI_cjs.b(e.boardAdapter.kvStorageForRef(e.cardStoreRef)),e.boardAdapter.hashFn),p.warn),E=f(y);return K={get($){return E.get($)},set($){return E.set($)}},E})():(()=>{let y=e.boardAdapter.kvStorageForRef(e.cardStoreRef),$=chunkYMEIPKLW_cjs.a(chunkOEFTOO47_cjs.l({readIndex:()=>y.read("_index"),writeIndex:D=>y.write("_index",D),readCard:D=>y.read(D),writeCard:(D,V)=>(y.write(D,V),D),removeCard:D=>{y.delete(D);},cardExists:D=>y.read(D)!==null,defaultCardKey:D=>D},p.warn));return K=$,a($)})(),X=e.artifactsAdapter||e.boardAdapter,J=e.filesArtifactsStore??null,oe=J?{putBytes(y,E,$){J.putBytes(y,E,$);},getBytes(y){return J.getBytes(y)},listKeys(y){return J.list(y).map(E=>E.key)}}:null;if(!oe&&!ge(X)){let y=e.artifactsAdapter?X.blobStorage(""):X.blobStorage("files"),E=chunkWOALA3V5_cjs.c(y);oe={putBytes($,D,V){E.putBytes($,D,V);},getBytes($){return E.getBytes($)},listKeys($){return E.list($).map(D=>D.key)}};}else if(!oe&&ge(X)){let y=e.artifactsAdapter?X.blobStorage(""):X.blobStorage("files");oe={async putBytes(E,$){if(y.writeBytes){await y.writeBytes(E,$);return}let D=JSON.stringify({__kind:"bytes-array",data:[...$]});await y.write(E,D);},async getBytes(E){if(y.readBytes){let D=await y.readBytes(E);if(D!==null)return D}let $=await y.read(E);if($===null)return null;try{let D=JSON.parse($);if(D&&D.__kind==="bytes-array"&&Array.isArray(D.data))return new Uint8Array(D.data)}catch{}return new TextEncoder().encode($)},async listKeys(E){return await y.listKeys(E)}};}let de={async init(y){return c.init(y)},async status(y){return c.status(y)},async getConfig(y){return c.getConfig(y)},async getAllOutputsDataObjects(y){return c.getAllOutputsDataObjects(y)},async getAllOutputsComputedValues(y){return c.getAllOutputsComputedValues(y)},async getOutputsFetchedSources(y){return c.getOutputsFetchedSources(y)},async upsertCard(y){return c.upsertCard(y)},async removeCard(y){return c.removeCard(y)},async cardRefreshedNotify(y){return c.cardRefreshedNotify(y)},async sourceDataFetched(y){return c.sourceDataFetched(y)},async sourceDataFetchFailure(y){return c.sourceDataFetchFailure(y)}};return {label:e.label,board:c,nonCore:N,publicCardStore:K,boardOps:de,cardStoreOps:H,get filesArtifacts(){return oe},boardAdapter:e.boardAdapter,cardStoreRef:e.cardStoreRef,outputsStoreRef:e.outputsStoreRef,artifactsStoreRef:e.artifactsStoreRef,scratchStoreRef:e.scratchStoreRef,archiveStoreRef:e.archiveStoreRef,notifyRef:e.notifyRef,taskExecutorRef:e.taskExecutorRef,chatHandlerRef:e.chatHandlerRef,chatHandlerFlow:e.chatHandlerFlow,inferenceAdapterRef:e.inferenceAdapterRef,notification:wt(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let d=r.boards.map(L),l=new Map;function i(e){return l.get(e)??0}function m(e){let n=e;return typeof n.invokeExecutor=="function"&&typeof n.validateSchema=="function"}function A(e){let n=d[i(e)];return {files:n?n.filesArtifacts:null}}function P(){return chunkWOALA3V5_cjs.e()}function G(e){return String(e||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function ue(e){if(!e||e.notificationTeardown||!g||!e.notifyRef)return;let n=await g.subscribe(e.notifyRef,a=>{ze(e.notification,a);let f=a.kind==="notification-batch"?a.notifications:[a];v.broadcastNotificationBatch(f);});e.notificationTeardown=n;}async function fe(e){if(!e||e.initialized)return;let n={cardStoreRef:e.cardStoreRef,outputsStoreRef:e.outputsStoreRef};e.artifactsStoreRef&&(n.artifactsStoreRef=e.artifactsStoreRef),e.scratchStoreRef&&(n.scratchStoreRef=e.scratchStoreRef),e.archiveStoreRef&&(n.archiveStoreRef=e.archiveStoreRef);let a={};e.taskExecutorRef&&(a["task-executor-ref"]=e.taskExecutorRef),e.chatHandlerFlow!==void 0&&(a["chat-handler-flow"]=e.chatHandlerFlow),e.inferenceAdapterRef&&(a["inference-adapter-ref"]=e.inferenceAdapterRef);let f=await e.boardOps.init({params:n,body:a});if(f.status!=="success")throw Object.assign(new Error(f.error||`init failed for ${e.label}`),{statusCode:500});if(await ue(e),!e.chatHandlerFlow&&e.chatHandlerRef&&R.describe)try{let c=await R.describe(e.chatHandlerRef);c&&c.kind!=="chat-handler"?p.warn(`[init] chat-handler describe returned kind="${c.kind}", expected "chat-handler" for ${e.label}`):c&&p.info(`[init] chat-handler validated: ${c.name} (protocol ${c.protocolVersion}) for ${e.label}`);}catch(c){p.warn(`[init] chat-handler describe failed for ${e.label}: ${c?.message||String(c)}`);}e.initialized=true;}async function ie(e){if(!e.boardAdapter.publishBoardChangeNotifications)return;let n=[],a=await e.boardOps.status({});a.status==="success"&&a.data!=null&&Qe(a.data)&&n.push({kind:"status",status:a.data});let f=await e.boardOps.getAllOutputsDataObjects({});if(f.status==="success"&&f.data!=null)for(let[_,N]of Object.entries(f.data))_&&n.push({kind:"data_object",key:_,payload:N});let c=await e.boardOps.getAllOutputsComputedValues({});if(c.status==="success"&&c.data!=null)for(let[_,N]of Object.entries(c.data))_&&n.push({kind:"computed_values",cardId:_,values:N});n.length>0&&e.boardAdapter.publishBoardChangeNotifications(n);}async function be(e,n){if(!e||e.cardsBootstrapped)return;let a=await e.cardStoreOps.get({}),f=a.status==="success"&&Array.isArray(a.data?.cards)?a.data.cards:[];for(let c of f)typeof c.id=="string"&&(l.set(c.id,n),await e.boardOps.upsertCard({params:{cardId:c.id}}));e.cardsBootstrapped=true;}async function Se(){for(let e of d)await fe(e);}async function ee(){await Se();for(let e=0;e<d.length;e++)await ie(d[e]),await be(d[e],e),await ie(d[e]);}async function I(e=false){e||await Se();for(let n of d){let a=await n.board.processAccumulatedEvents({});if(a.status!=="success")return a}return {status:"success"}}async function Ve(){return await Se(),I(true)}function W(e){return d[i(e)]??null}async function te(e){let n=W(e);if(!n)return null;let a=await n.cardStoreOps.get({params:{id:e}});if(a.status!=="success")return null;let f=Array.isArray(a.data?.cards)?a.data.cards:[];return f.length>0?f[0]:null}async function Y(){let e=async a=>{if(!a)return [];let f=await a.cardStoreOps.get({});return f.status!=="success"||!Array.isArray(f.data?.cards)?[]:f.data.cards},n=[];for(let a of d)n.push(...await e(a));return n}function we(){return d[0]??null}let Ce=Bt({boardContexts:d,cardOwnerIndex:l,cardContextForCard:e=>W(e),readStatusSnapshot:()=>Be(),readDataObjectsByToken:()=>Oe(),readCardRuntimeArtifacts:()=>De(),readCardFromStore:e=>te(e),readCardDefinitions:()=>Y(),processAccumulatedLaneInternal:e=>I(e),uploadCardFile:(e,n,a,f,c)=>Ie(e,n,a,f,c),chatStorePublic:T,serverUrl:b,apiBasePath:t}),je=Ce.mcpCardStoreFacade,pe=Ce.createMcpFacade,Pe=kt({boardId:u,getMcpFacade:()=>pe(),getMcpCardStoreFacade:()=>je()});function Ee(e){return vt(e)}function Le(){return Pt({boardId:u,uploadCardFile:Ie,getMcpFacade:()=>pe(),controlplane:Pe})}let Re=St({boardId:u,boardContexts:d,readCardDefinitions:()=>Y(),readChatRecords:e=>le(e),getChatProcessing:e=>pe().getChatProcessing({cardId:e}).active}),Be=Re.readStatusSnapshot,De=Re.readCardRuntimeArtifacts,Oe=Re.readDataObjectsByToken,k=Re.buildPublishedRuntimePayload;async function h(e,n,a){let f=a?.syncBoard!==false,c=a?.restartOnlyIfChanged===true,_=W(e);if(!_)throw Object.assign(new Error(`Card not found: ${e}`),{statusCode:404});let N=await te(e);if(!N)throw Object.assign(new Error(`Card not found: ${e}`),{statusCode:404});let K=c?JSON.stringify(N):null,H=n(N)||N;if(c&&JSON.stringify(H)===K)return;let X=await _.cardStoreOps.set({body:H});if(X.status!=="success")throw Object.assign(new Error(X.error||`Failed to persist card: ${e}`),{statusCode:500});if(f){let J=await _.boardOps.upsertCard({params:{cardId:e,restart:true}});if(J.status!=="success")throw Object.assign(new Error(J.error||`Failed to upsert card: ${e}`),{statusCode:500})}}async function M(e,n){await h(e,n,{syncBoard:true});}async function B(e,n){await h(e,n,{syncBoard:false});}async function q(e){let n=W(e);if(!n)throw Object.assign(new Error(`Card not found: ${e}`),{statusCode:404});if(!await te(e))throw Object.assign(new Error(`Card not found: ${e}`),{statusCode:404});let f=await n.boardOps.upsertCard({params:{cardId:e,restart:true}});if(f.status!=="success")throw Object.assign(new Error(f.error||`Failed to retrigger card: ${e}`),{statusCode:500})}async function Z(e,n){await h(e,a=>{if(!n||typeof n!="object"||Object.keys(n).length===0)return a;function f(c,_,N){let K=String(_||"").split(".").filter(Boolean);if(!K.length)return;let H=c;for(let X=0;X<K.length-1;X++){let J=K[X];(!H[J]||typeof H[J]!="object")&&(H[J]={}),H=H[J];}H[K[K.length-1]]=N;}if(n.fieldValues!==void 0&&n.fieldValues!==null){let c=null,_=a.view;if(_&&Array.isArray(_.elements)){for(let N of _.elements)if(N?.data&&N.data.writeTo){c=N.data.writeTo;break}}c?f(a,c,n.fieldValues):typeof n.fieldValues=="object"&&!Array.isArray(n.fieldValues)&&(a.card_data={...a.card_data||{},...n.fieldValues});}else {if(Array.isArray(n._stagedFiles)&&n._stagedFiles.length>0)return a;for(let[c,_]of Object.entries(n))c!=="_stagedFiles"&&(_!==null&&typeof _=="object"&&!Array.isArray(_)&&a[c]!==null&&typeof a[c]=="object"&&!Array.isArray(a[c])?a[c]={...a[c],..._}:a[c]=_);}return a},{syncBoard:true,restartOnlyIfChanged:true});}function Q(e){F.clear(e);try{pe().setChatProcessing({cardId:e,active:!1});}catch{}}function ne(e,n,a,f,c=""){let _=typeof a=="string"?a.trim():"";return F.append(e,n||"system",_,f,c)}function le(e){return F.readAll(e)}let Ie=At({safeCardId:e=>G(e),artifactsStores:e=>A(e),cardFileMetadataStore:()=>P(),readCardFromStore:e=>te(e),updateCardLocalOnly:(e,n)=>B(e,n),writeChatRecord:(e,n,a,f,c)=>ne(e,n,a,f,c)}).uploadCardFile;async function $e(e){let n=W(e);if(!n)return null;let a=await n.boardOps.getConfig({params:{key:"chat-handler-flow"}}),f=a.status==="success"?a.data?.value:null,c=n.chatHandlerRef;return f==null&&(!c||typeof c!="object")?null:{ctx:n,handlerFlow:f,handlerRef:c}}async function Fe(e,n,a=false,f=""){let c=await $e(e);if(!c)return;let{ctx:_,handlerFlow:N,handlerRef:K}=c;if(!a)try{pe().setChatProcessing({cardId:e,active:!0});}catch{}let H={boardId:u,cardId:String(e),lastChatEntryId:n,...f?{turnId:f}:{},...S,...b?{serverUrl:b}:{}},X=N!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:Ot}}:K;try{ge(_.boardAdapter)?await _.boardAdapter.chatAgentStore().enqueueRequest({boardId:u,ref:X,args:N!=null?{...H,__chatHandlerFlow:N}:H}):_.boardAdapter.chatAgentStore().enqueueRequest({boardId:u,ref:X,args:N!=null?{...H,__chatHandlerFlow:N}:H}),await Promise.resolve(_.boardAdapter.requestProcessAccumulated?.());}catch(J){try{pe().setChatProcessing({cardId:e,active:!1});}catch{}p.warn(`[chat-handler] queue failed for card "${e}": ${J instanceof Error?J.message:String(J)}`);}}async function Ae(e,n,a){if(n.howToRun==="built-in"&&Ct(n)===Ot){let f=C,c=a.__chatHandlerFlow,_={...a};return delete _.__chatHandlerFlow,f?f.run(c,_,{boardId:u,cardId:String(_.cardId||""),label:e.label,logger:p,serverUrl:b,executionExtra:S}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return R.invoke(n,a)}async function qe(e,n=false){n||await Se();let a=typeof e.args?.cardId=="string"?e.args.cardId:"",f=a?W(a):we();if(!f)throw new Error(a?`Board context is unavailable for chat-agent request: ${a}`:"Board context is unavailable for chat-agent request");let c=await Ae(f,e.ref,e.args);if(!c.dispatched){if(a)try{F.setProcessing(a,!1);}catch{}throw new Error(c.error||`chat-agent dispatch failed for card "${a||"unknown"}"`)}}async function Te(e,n,a){let f=n==="chat-send"?B:M,c;await f(e,_=>{let N=new Date().toISOString(),K=_.card_data&&typeof _.card_data=="object"?_.card_data:{};if(_.card_data=K,n==="chat-send"){let H=a&&typeof a.text=="string"?a.text.trim():"",X=a&&typeof a["turn-id"]=="string"?a["turn-id"]:a&&typeof a.turnId=="string"?a.turnId:a&&typeof a.turn=="string"?a.turn:"",J=[];if(Array.isArray(a?.files)){for(let oe of a.files)if(oe){if(typeof oe=="string"){J.push({name:oe});continue}if(typeof oe=="object"){let de=oe;typeof de.name=="string"&&J.push({name:de.name,size:de.size,mime_type:de.mime_type,uploaded_at:de.uploaded_at,stored_name:de.stored_name,chat:de.chat===true});}}}if(H||J.length>0){let oe=T.runBatch({cardId:e,commands:[{command:"append",role:"user",text:H,files:J,turn:X},{command:"set-processing",active:true}]});if(oe.status!=="success")throw new Error(oe.error);let de=oe.data.results[0]?.data?.id;if(typeof de!="string"||!de)throw new Error(`chat-send did not return an append id for card ${e}`);c={cardId:e,lastEntryId:de,processingAlreadySet:true,turnId:X};try{let $=le(e);v.broadcastNotificationBatch([{kind:"card_chats",cardId:e,messages:$.map(D=>({role:String(D.role||"system"),text:String(D.text||""),files:Array.isArray(D.files)?D.files:[]})),receiving:!0,processing:F.isProcessing(e)}]);}catch{}}return _}if(n==="file-upload"){let H=P().normalizeIncoming(a?.files,N);return H.length>0&&P().merge(K,H),_}if(n==="action"){let H=a&&typeof a.buttonId=="string"?a.buttonId:"";if(!H)return _;K.lastAction={buttonId:H,at:N},K.lastActionText=`${H} @ ${N}`;}return _}),c&&Fe(c.cardId,c.lastEntryId,c.processingAlreadySet,c.turnId??"");}function ve(e,n,a){let f=JSON.stringify(a),c=typeof Buffer<"u"?Buffer.byteLength(f):new TextEncoder().encode(f).length;e.writeHead(n,{...s,"Content-Type":"application/json; charset=utf-8","Content-Length":c}),e.end(f);}async function Ne(e,n,a){let f=await te(e);if(!f)throw Object.assign(new Error("Card not found"),{statusCode:404});let c=P().resolve(f.card_data,n,a);if(!c.ok&&c.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!c.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let _=c.file,N=G(e),K=A(e),H=String(_.stored_name||""),X=`${N}/${H}`,J=K.files?await K.files.getBytes(X):null;if(!J)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:_,bytes:J}}async function me(e,n,a,f){let{fileRecord:c,bytes:_}=await Ne(n,a,f),N=String(c.name||c.stored_name||"download.bin"),K=String(c.mime_type||"application/octet-stream");e.writeHead(200,{"Content-Type":K,"Content-Disposition":`attachment; filename="${N}"`,"Content-Length":_.length}),e.end(_);}function ce(e){let n=String(e||"").toLowerCase();return n.startsWith("text/")||n.includes("json")||n.includes("xml")||n.includes("javascript")||n.includes("typescript")||n.includes("yaml")||n.includes("csv")}function ke(e,n,a){let f=e.split(/\r?\n/);return (n==="head"?f.slice(0,a):f.slice(-a)).join(`
|
|
7
|
+
`)}async function Mt(e){let n=[];for await(let f of e)n.push(f);let a=typeof Buffer<"u"?Buffer.concat(n).toString("utf-8").trim():new TextDecoder().decode(He(n)).trim();return a?JSON.parse(a):{}}async function jt(e){let n=[];for await(let a of e)n.push(a);return typeof Buffer<"u"?Buffer.concat(n):He(n)}async function et(e,n){let a=typeof n.ref=="string"?n.ref.trim():"";if(!a)return {status:"fail",error:"board-worker success callback requires body.ref"};let f=d[0];return f?f.boardOps.sourceDataFetched({params:{token:e,ref:a}}):{status:"fail",error:"no board context"}}async function tt(e,n){let a=typeof n.reason=="string"&&n.reason.trim()?n.reason:"unknown",f=d[0];return f?f.boardOps.sourceDataFetchFailure({params:{token:e,reason:a}}):{status:"fail",error:"no board context"}}async function Et(e,n,a){let f=String(e||"").trim();if(!f)return {statusCode:400,body:{error:"callback token is required"}};let c=n==="success"?await et(f,a):await tt(f,a);return c.status==="success"?{statusCode:200,body:c}:c.status==="fail"?{statusCode:400,body:{error:c.error}}:{statusCode:500,body:{error:c.error}}}let rt=It({sseHub:v,corsHeaders:s,json:ve,buildPublishedRuntimePayload:()=>k(),onSseClientConnected:O,onChannelSubscribed:j,onChannelUnsubscribed:w}),Lt=rt.handleChannelSubscription,Dt=rt.handleSse,$t=xt({apiBasePath:t,boardContexts:d,json:ve,readJsonBody:e=>Mt(e),readRawBody:e=>jt(e),initBoardAndSetup:()=>Se(),bootstrapBoard:()=>ee(),buildPublishedRuntimePayload:()=>k(),publishPersistedStateSnapshot:e=>ie(e),upsertCardsFromSource:(e,n)=>be(e,n),applyBoardWorkerCallback:(e,n,a)=>Et(e,n,a),handleSse:(e,n,a)=>Dt(e,n,a),handleChannelSubscription:(e,n,a,f,c)=>Lt(e,n,a,f,c),createMcpFacade:()=>pe(),createMcpToolRegistry:e=>Ee(e),createMcpControlplaneToolRegistry:()=>Le(),readCardFromStore:e=>te(e),patchCard:(e,n)=>Z(e,n),retriggerCard:e=>q(e),applyCardAction:(e,n,a)=>Te(e,n,a),resolveChatHandlerTarget:e=>$e(e),chatStorePublic:T,chatStorage:{append:(e,n,a,f,c)=>F.append(e,n,a,f,c),setProcessing:(e,n)=>F.setProcessing(e,n)},sseHub:v,uploadCardFile:(e,n,a,f,c)=>Ie(e,n,a,f,c),sendCardFileDownloadResponse:(e,n,a,f)=>me(e,n,a,f),resolveCardFileDownloadPayload:(e,n,a)=>Ne(e,n,a),isLikelyTextMimeType:e=>ce(e),sliceTextByLines:(e,n,a)=>ke(e,n,a)}).handleRuntimeApi;return {get apiBasePath(){return t},get corsHeaders(){return s},get queueLaneTuning(){return o},handleRuntimeApi:$t,buildPublishedRuntimePayload:k,processAccumulatedEvents:Ve,processAccumulatedLane:I,handleChatAgentRequest:qe,clearChatRecords:Q,reportSourceFetched(e,n){return et(e,{ref:n})},reportSourceFetchFailure(e,n){return tt(e,{reason:n})},get cardStore(){return d[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Dr(r){let t=String(r.apiBasePath||"/api/boards").replace(/\/$/,""),s={...Ft,...r.corsHeaders||{}},o=r.serverMetaStore,u=r.boardRuntimeFactory,p=new Map,R="boards-config.json";function C(){let w=o.getText(R);if(!w)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(w)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function F(w){o.putText(R,JSON.stringify(w,null,2));}function T(w){let v=String(w||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return v.length>0&&v.length<=64?v:null}function g(w){if(p.has(w))return p.get(w);let L=C().boards.find(l=>l.id===w)||{},d=u(w,L);return p.set(w,d),d}function b(w,v,L){let d=JSON.stringify(L),l=typeof Buffer<"u"?Buffer.byteLength(d):new TextEncoder().encode(d).length;w.writeHead(v,{...s,"Content-Type":"application/json; charset=utf-8","Content-Length":l}),w.end(d);}async function S(w,v,L){let d=w.method||"GET",l=L.pathname;if(d==="GET"&&l===t)return b(v,200,{ok:true,boards:C().boards}),true;if(d==="POST"&&l===t){let i=[];for await(let ie of w)i.push(ie);let m=typeof Buffer<"u"?Buffer.concat(i).toString("utf-8").trim():new TextDecoder().decode(He(i)).trim(),A={};try{A=m?JSON.parse(m):{};}catch{A={};}let P=T(A.id);if(!P)return b(v,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let G=C();if(G.boards.some(ie=>ie.id===P))return b(v,409,{error:`Board "${P}" is already registered`}),true;let ue=typeof A.label=="string"&&A.label.trim()?A.label.trim():P,fe={id:P,label:ue};for(let[ie,be]of Object.entries(A))ie==="id"||ie==="label"||be!=null&&(fe[ie]=be);return G.boards.push(fe),F(G),b(v,200,{ok:true,board:fe}),true}return false}async function O(w,v,L){let l=L.pathname.match(new RegExp(`^${se(t)}/([^/]+)(/|$)`));if(!l)return false;let i=T(decodeURIComponent(l[1]));return i?C().boards.some(P=>P.id===i)?!!await g(i).handleRuntimeApi(w,v,L):(b(v,404,{error:`Board "${i}" not registered. POST ${t} with {id} to register it first.`}),true):(b(v,400,{error:"Invalid board id"}),true)}async function x(w,v,L){return !!(await S(w,v,L)||await O(w,v,L))}function j(w){if(!C().boards.some(L=>L.id===w))throw Object.assign(new Error(`Board "${w}" not registered`),{statusCode:404});return {service:g(w)}}return {get apiBasePath(){return t},get corsHeaders(){return s},handleApi:x,requireBoardService:j}}exports.a=br;exports.b=Lr;exports.c=Dr;//# sourceMappingURL=chunk-GLIX37VG.cjs.map
|
|
8
|
+
//# sourceMappingURL=chunk-GLIX37VG.cjs.map
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import {f,b,c as c$1,e}from'./chunk-MLVTJASJ.js';import {j,d,c,b as b$1}from'./chunk-VMW4Z6EF.js';import {y,z as z$1,l}from'./chunk-N6P2JW4W.js';import {b as b$2}from'./chunk-BQS3EIEK.js';import {a as a$2}from'./chunk-SCWHDI3I.js';import {a as a$1}from'./chunk-KBELAKIY.js';import {a}from'./chunk-76ON3V7R.js';function wt(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Qe(r){if(!r||typeof r!="object")return false;let t=r.summary;return !t||typeof t!="object"?false:Number(t.card_count||0)>0}function ze(r,t){if(!t||typeof t!="object")return;let s=t;if(s.kind==="notification-batch"&&Array.isArray(s.notifications)){for(let o of s.notifications)ze(r,o);return}s.kind==="status"&&Qe(s.status)&&(r.status=s.status),s.kind==="computed_values"&&s.cardId&&(r.computedValues[s.cardId]=s.values),s.kind==="data_object"&&s.key&&(r.dataObjects[s.key]=s.payload),s.kind==="card_refreshed"&&s.cardId&&(r.cards[s.cardId]=s.card),s.kind==="card_removed"&&s.cardId&&(delete r.cards[s.cardId],delete r.computedValues[s.cardId]);}function ge(r){return typeof r.journalStorage=="function"}function Ct(r){return typeof r.whatToRun=="string"?r.whatToRun.startsWith("b64:")?b$2(r.whatToRun).value:r.whatToRun:r.whatToRun.value}function se(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function He(r){let t=r.reduce((u,p)=>u+p.length,0),s=new Uint8Array(t),o=0;for(let u of r)s.set(u,o),o+=u.length;return s}function ht(r){let t=new Map,s=new Map,o=new Map,u=0,p=null;function R(i){let m=JSON.stringify(i);return u++,`id: ${u}
|
|
2
|
+
data: ${m}
|
|
3
|
+
|
|
4
|
+
`}function C(i){let m=i;try{m.flushHeaders?.();}catch{}try{m.flush?.();}catch{}try{m.socket?.setNoDelay?.(!0);}catch{}try{m.socket?.uncork?.();}catch{}}function F(i,m){let A=t.get(i);if(A&&!(m&&A.res!==m)){t.delete(i),j();try{r.onSseClientDisconnected?.(i);}catch{}try{A.res.end();}catch{}}}function T(i,m,A){let P=t.get(i);P&&F(i,P.res),t.set(i,{res:m,subscribedChatCardIds:A??new Set});}function g(i,m){let A=t.get(i);if(!A)return;let P=R(m);try{A.res.write(P),C(A.res);}catch{F(i,A.res);}}function b(){let i=new Set;for(let m of t.values())for(let A of m.subscribedChatCardIds)i.add(A);return Array.from(i)}function S(i){let m=s.has(i)?s.get(i):null,{cursor:A}=r.chatStorage.readAfter(i,m),P=r.chatStorage.isProcessing(i),G=P!==(o.get(i)??false),ue=A!==m;return ue&&s.set(i,A),o.set(i,P),ue||G}function O(i,m){let A=r.readChatRecords(i),P=Date.now();return {kind:"card_chats",cardId:i,sentAt:new Date(P).toISOString(),sentAtMs:P,messages:A.map(G=>({role:String(G.role||"system"),text:String(G.text||""),files:Array.isArray(G.files)?G.files:[]})),receiving:m,processing:r.chatStorage.isProcessing(i)}}function x(i,m=true){let A={kind:"notification-batch",notifications:[O(i,m)]};for(let[P,G]of t.entries())G.subscribedChatCardIds.has(i)&&g(P,A);}function j(){b().length>0||(p&&(clearInterval(p),p=null),s.clear(),o.clear());}function w(){if(p)return;let i=()=>{let m=b();if(m.length===0){j();return}let A=new Set(m);for(let P of Array.from(s.keys()))A.has(P)||s.delete(P);for(let P of Array.from(o.keys()))A.has(P)||o.delete(P);for(let P of m)S(P)&&x(P,true);};i(),p=setInterval(i,1e3);}function v(i,m){let A=t.get(i);if(!A)return false;A.subscribedChatCardIds.add(m);let{cursor:P}=r.chatStorage.readAfter(m,null);return s.set(m,P),o.set(m,r.chatStorage.isProcessing(m)),w(),g(i,{kind:"notification-batch",notifications:[O(m,true)]}),true}function L(i,m){let A=t.get(i);return A?(A.subscribedChatCardIds.delete(m),b().includes(m)||(s.delete(m),o.delete(m)),j(),true):false}function d(i){if(!i||typeof i!="object")return false;let m=i.kind;return m==="card_chats"||m==="chat_messages"}function l(i){if(!i||i.length===0)return;let m=[],A=new Set;for(let P of i)d(P)&&typeof P.cardId=="string"?A.add(String(P.cardId)):m.push(P);if(m.length>0){let P={kind:"notification-batch",notifications:m};for(let G of t.keys())g(G,P);}for(let P of A)x(P,true);}return {size:()=>t.size,has:i=>t.has(i),get:i=>t.get(i),buildFrame:R,flushTransport:C,register:T,disconnect:F,writeFrame:g,subscribeChat:v,unsubscribeChat:L,broadcastNotificationBatch:l,broadcastCardChats:x}}function z(r,...t){for(let s of t)if(typeof r[s]=="string")return String(r[s]);return ""}function ye(r,...t){for(let s of t)if(r[s]!==void 0)return Number(r[s])}function _e(r,...t){for(let s of t){let o=r[s];if(o&&typeof o=="object"&&!Array.isArray(o))return o}return {}}function he(r,t,...s){for(let o of s){let u=r[o];if(u&&typeof u=="object"&&!Array.isArray(u))return u}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function We(r,t,...s){for(let o of s){let u=r[o];if(u!==void 0){let p=Number(u);if(Number.isFinite(p))return p}}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function Rt(r){if(Array.isArray(r.bytes))return new Uint8Array(r.bytes.map(t=>Math.max(0,Math.min(255,Number(t)||0))));if(typeof r.text=="string")return new TextEncoder().encode(r.text);if(typeof r.base64=="string"){let t=String(r.base64).replace(/-/g,"+").replace(/_/g,"/"),s=t+"=".repeat((4-t.length%4)%4),o=atob(s);return Uint8Array.from(o,u=>u.charCodeAt(0))}return null}function Je(r,t){if(r?.status==="success")return Object.prototype.hasOwnProperty.call(r,"data")?r.data:void 0;throw r?.status==="fail"||r?.status==="error"?Object.assign(new Error(r.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function Ke(r,t){return Je(await r,t)}function Ge(r){let t=z(r,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let s=t.split(".");if(!(s.length>=2&&s[0]==="chat"&&s.every(u=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(u))))throw Object.assign(new Error("MCP tool only supports card meta keys under chat.*"),{statusCode:400});return t}function Ze(r,t){let s=r.meta;for(let o of t.split(".")){if(!s||typeof s!="object"||Array.isArray(s)||!Object.prototype.hasOwnProperty.call(s,o))return {exists:false,value:null};s=s[o];}return {exists:true,value:s}}function kt(r){let{boardId:t,getMcpFacade:s,getMcpCardStoreFacade:o}=r;function u(T){let g=z(T,"board_id"),b=z(T,"card_id");if(!g)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(!b)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});if(g!==t)throw Object.assign(new Error(`Unknown board_id: ${g}`),{statusCode:400});return {cardId:b}}function p(T,g){let{cardId:b}=u(T);return s().setChatProcessing({cardId:b,active:g}),{status:"success",data:{boardId:t,cardId:b,active:g}}}function R(T){let{cardId:g}=u(T),b=s().getChatProcessing({cardId:g});return {status:"success",data:{boardId:t,cardId:g,active:b.active}}}async function C(T){let{cardId:g}=u(T),b=Ge(T);if(!Object.prototype.hasOwnProperty.call(T,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(b.split(".").includes("__visible_controlplane_only")){let S=await Ke(o().get({params:{id:g}}),"cardStore.get"),O=Array.isArray(S.cards)&&S.cards.length>0&&typeof S.cards[0]=="object"&&!Array.isArray(S.cards[0])?S.cards[0]:null,x=O?Ze(O,"__visible_controlplane_only").value:void 0;if(T.value!==x)throw Object.assign(new Error("MCP tool cannot change the reserved meta flag __visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:g,key:b}}}return Je(await o().patch({params:{id:g,path:`meta.${b}`},body:{value:T.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:g,key:b}}}async function F(T){let{cardId:g}=u(T),b=Ge(T),S=await Ke(o().get({params:{id:g}}),"cardStore.get"),O=Array.isArray(S.cards)&&S.cards.length>0&&S.cards[0]&&typeof S.cards[0]=="object"&&!Array.isArray(S.cards[0])?S.cards[0]:null;if(!O)throw Object.assign(new Error(`Card "${g}" not found`),{statusCode:404});let x=Ze(O,b);return {status:"success",data:{boardId:t,cardId:g,key:b,exists:x.exists,value:x.value}}}return {requireCardArgs:u,setChatProcessing:p,getChatProcessing:R,setCardMeta:C,getCardMeta:F}}function St(r){let{boardId:t,boardContexts:s,readCardDefinitions:o,readChatRecords:u,getChatProcessing:p}=r;async function R(){let g=(await Promise.all(s.map(async j=>{try{let w=j.boardAdapter.kvStorageForRef(j.outputsStoreRef),v=await Promise.resolve(w.read("status"));if(v!=null)return v}catch{}return j.notification.status}))).filter(Boolean);if(g.length===0)return null;if(g.length===1)return g[0];let b=[],S=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],O={};for(let j of S)O[j]=0;for(let j of g){let w=j,v=Array.isArray(w.cards)?w.cards:[];b.push(...v);for(let L of S)O[L]+=Number(w?.summary?.[L]||0);}let x=g[0];return {...x,cards:b,summary:{...x.summary||{},card_count:b.length,...O}}}async function C(){let g={},b=async S=>{try{let O=await S.boardOps.getAllOutputsComputedValues({});if(O.status==="success"&&O.data&&typeof O.data=="object"){for(let[x,j]of Object.entries(O.data)){let w=S.notification.cards[x];g[x]={schema_version:"v1",card_id:x,card_data:w?.card_data??{},computed_values:j??{}};}return}}catch{}for(let[O,x]of Object.entries(S.notification.computedValues)){let j=S.notification.cards[O];g[O]={schema_version:"v1",card_id:O,card_data:j?.card_data??{},computed_values:x??{}};}};for(let S of s)await b(S);return g}async function F(){let g={};for(let b of s){try{let S=await b.boardOps.getAllOutputsDataObjects({});if(S.status==="success"&&S.data&&typeof S.data=="object"){Object.assign(g,S.data);continue}}catch{}Object.assign(g,b.notification.dataObjects||{});}return g}async function T(){let g=await o(),b=await C(),S=await F(),O={};for(let j of g){if(!j?.id)continue;let w=j.id,v=b[w]||{},L={...v.card_data&&typeof v.card_data=="object"?v.card_data:j.card_data&&typeof j.card_data=="object"?j.card_data:{}};O[w]={schema_version:v.schema_version||"v1",card_id:v.card_id||w,card_data:L,computed_values:v.computed_values&&typeof v.computed_values=="object"?v.computed_values:{}};}let x={};for(let j of g){if(!j?.id)continue;let w=j.id;try{let v=u(w),L=p(w);(v.length>0||L)&&(x[w]={messages:v.map(d=>({role:String(d.role||"system"),text:String(d.text||""),files:Array.isArray(d.files)?d.files:[]})),receiving:!1,processing:L});}catch{}}return {boardId:t,cardDefinitions:g,statusSnapshot:await R(),dataObjectsByToken:S,cardRuntimeById:O,cardChatsByCardId:x}}return {readStatusSnapshot:R,readCardRuntimeArtifacts:C,readDataObjectsByToken:F,buildPublishedRuntimePayload:T}}function Ht(r){let t=String(r||"").trim();if(!t)return "upload.bin";let s=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (s>=0?t.slice(s+1):t)||"upload.bin"}function At(r){let{safeCardId:t,artifactsStores:s,cardFileMetadataStore:o,readCardFromStore:u,updateCardLocalOnly:p,writeChatRecord:R}=r;async function C(g){let b=[];try{let S=await u(g);if(!S)return b;let O=o().read(S.card_data&&typeof S.card_data=="object"?S.card_data:null);for(let x of O)b.push(String(x.stored_name??""));}catch{}return b}async function F(g,b,S,O){let x=t(g),j=s(g),w=Ht(b),v=await C(g),d=`${String(v.length+1).padStart(3,"0")}-${w}`.slice(-36);return j.files&&await j.files.putBytes(`${x}/${d}`,new Uint8Array(O),S||"application/octet-stream"),{name:w,stored_name:d,size:O.length,mime_type:S||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function T(g,b,S,O,x){if(!O.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let j=x?.inChat===true,w=await F(g,b,S,O),v=null;if(await p(g,L=>{let d=new Date().toISOString(),l=L.card_data&&typeof L.card_data=="object"?L.card_data:{};L.card_data=l;let i=o().normalizeIncoming([{name:w.name,stored_name:w.stored_name,size:w.size,mime_type:w.mime_type,uploaded_at:w.uploaded_at||d,chat:j}],d);return v=o().merge(l,i).findIndex(A=>A.stored_name===w.stored_name),L}),j){let L=typeof v=="number"&&v>=0?` #${v}`:"";R(g,"system",`file uploaded: ${w.name} as ${w.stored_name}${L}`,[],x?.turnId??"");}return {ok:true,file:w}}return {uploadCardFile:T,readCardStoredFileNames:C}}function vt(r){return {"discover.source-kinds":()=>r.discoverSourceKinds(),"inspect.board-runtime-status":()=>r.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>r.inspectCardDefinitionAndRuntime({cardId:z(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let s=ye(t,"tail_turns"),o=ye(t,"tail"),u=z(t,"turn_id"),p=t.all_turns===true,R=z(t,"tail_turns_before_id");return r.inspectChatMessagesOnCards({cardId:z(t,"card_id"),...s!==void 0?{lastUserTurns:s}:{},...o!==void 0?{tail:o}:{},...u?{turnId:u}:{},...p?{allTurns:true}:{},...R?{tailTurnsBeforeId:R}:{}})},"inspect.file-contents":t=>r.inspectFileContents({cardId:z(t,"card_id"),fileIdx:Number(ye(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>r.preflightValidateCandidateCardDefinition({candidateCardContent:he(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>r.preflightMaterializeCandidateCard({candidateCardContent:he(t,"candidate_card_content","candidate_card_content"),mockRequires:he(t,"mock_requires","mock_requires"),mockFetchedSources:he(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>r.preflightProbeSingleSourceInCandidateCard({candidateCardContent:he(t,"candidate_card_content","candidate_card_content"),mockProjections:_e(t,"mock_projections"),sourceIdx:We(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>r.preflightRunSingleSourceInCandidateCard({candidateCardContent:he(t,"candidate_card_content","candidate_card_content"),mockProjections:_e(t,"mock_projections"),sourceIdx:We(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>r.preflightRunSingleSourceInLiveCard({cardId:z(t,"card_id"),sourceIdx:We(t,"source_idx","source_idx"),mockRequires:he(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>r.preflightRunOneCycleWithCandidateCard({candidateCardContent:he(t,"candidate_card_content","candidate_card_content"),mockRequires:_e(t,"mock_requires")}),"manage.read-card":t=>r.manageReadCard({cardId:z(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let s=z(t,"turn_id");if(!s)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return r.manageAddChatEntryAndAnyAttachments({cardId:z(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...s?{turn:s}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"manage.upsert-card":t=>r.manageUpsertCard({cardId:z(t,"card_id"),candidateCardContent:_e(t,"candidate_card_content")}),"manage.remove-card":t=>r.manageRemoveCard({cardId:z(t,"card_id")})}}function Pt(r){let{boardId:t,uploadCardFile:s,getMcpFacade:o,controlplane:u}=r;return {"getstate.is-chat-processing":p=>u.getChatProcessing(p),"setstate.chat-processing-started":p=>u.setChatProcessing(p,true),"setstate.chat-processing-done":p=>u.setChatProcessing(p,false),"getstate.card-meta":p=>u.getCardMeta(p),"setstate.card-meta":p=>u.setCardMeta(p),"manage.upload-card-file":p=>{let R=z(p,"board_id"),C=z(p,"card_id"),F=z(p,"file_name"),T=z(p,"content_type")||"application/octet-stream",g=Rt(p);if(!R)throw Object.assign(new Error("manage.upload-card-file requires board_id"),{statusCode:400});if(R!==t)throw Object.assign(new Error(`Unknown board_id: ${R}`),{statusCode:400});if(!C)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!F)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!g)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return s(C,F,T,g,{inChat:false})},"manage.admin-read-card":async p=>{let{cardId:R}=u.requireCardArgs(p);return {status:"success",data:{cards:await o().adminReadCard({cardId:R})}}},"manage.admin-upsert-card":p=>{let R=z(p,"board_id"),C=z(p,"card_id");if(!R)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!C)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(R!==t)throw Object.assign(new Error(`Unknown board_id: ${R}`),{statusCode:400});return o().adminUpsertCard({cardId:C,candidateCardContent:_e(p,"candidate_card_content")})}}}function Bt(r){let{boardContexts:t,cardOwnerIndex:s,cardContextForCard:o,readStatusSnapshot:u,readDataObjectsByToken:p,readCardRuntimeArtifacts:R,readCardFromStore:C,readCardDefinitions:F,processAccumulatedLaneInternal:T,uploadCardFile:g,chatStorePublic:b,serverUrl:S,apiBasePath:O}=r;function x(){return t[0]??null}function j(){return {async status(){let d=await u();return d==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:d}},async getOutputsDataObject(d){let l=d?.params?.key;return l?{status:"success",data:(await p())[l]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(d){let l=d?.params?.key;return l?{status:"success",data:(await R())[l]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(d){let l=d?.params?.key;if(!l)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let i=o(l)??x();return i?i.boardOps.getOutputsFetchedSources({params:{key:l}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(d){let l=d?.params?.id;if(!l)return {status:"fail",error:"removeCard requires params.id"};let i=o(l)??x();return i?i.boardOps.removeCard({params:{id:l}}):{status:"fail",error:"Board context is unavailable"}},async cardRefreshedNotify(d){let l=d?.params?.cardId;if(!l)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let i=o(l)??x();return i?i.boardOps.cardRefreshedNotify({params:{cardId:l}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(d){let l=d?.params?.cardId;if(!l)return {status:"fail",error:"upsertCard requires params.cardId"};let i=o(l)??x();if(!i)return {status:"fail",error:"Board context is unavailable"};let m=await i.boardOps.upsertCard({params:{cardId:l,restart:d.params.restart===true}});if(m.status!=="success")return m;if(ge(i.boardAdapter)){let A=await T(true);if(A.status!=="success")return A}return m}}}function w(){let d=()=>{let l=x();if(!l?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return l.nonCore};return {describeTaskExecutorCapabilities(l){return d().describeTaskExecutorCapabilities(l)},validateCardPreflight(l){return d().validateCardPreflight(l)},evalCardCompute(l){return d().evalCardCompute(l)},probeSourcePreflight(l){return d().probeSourcePreflight(l)},runSourcePreflight(l){return d().runSourcePreflight(l)},simulateCardCycle(l){return d().simulateCardCycle(l)}}}function v(){return {async get(d){let l=typeof d.params?.id=="string"?d.params.id:void 0;if(l){let i=await C(l);return i?{status:"success",data:{cards:[i]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await F()}}},async set(d){let l=d.body;if(l==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let i=Array.isArray(l)?l:[l];for(let m of i){let A=m,P=typeof A.id=="string"?A.id:"";if(!P)return {status:"fail",error:"each card must have a string `id` field"};let G=s.get(P)??0,ue=t[G]??x();if(!ue)return {status:"fail",error:"Board context is unavailable"};let fe=await ue.cardStoreOps.set({body:A});if(fe.status!=="success")return fe;s.set(P,G);}return {status:"success",data:{count:i.length}}},async del(d){let l=[d.params?.id,...d.body?.ids??[]].filter(i=>typeof i=="string"&&!!i);if(l.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let i of l){let m=o(i)??x();if(!m)return {status:"fail",error:"Board context is unavailable"};let A=await m.cardStoreOps.del({params:{id:i}});if(A.status!=="success")return A;s.delete(i);}return {status:"success",data:{count:l.length}}},async patch(d){let l=typeof d.params?.id=="string"?d.params.id:void 0,i=typeof d.params?.path=="string"?d.params.path:void 0;if(!l||!i)return {status:"fail",error:"patch requires params.id and params.path"};let m=o(l)??x();return m?m.cardStoreOps.patch(d):{status:"fail",error:"Board context is unavailable"}},async appendFiles(d){let l=typeof d.params?.id=="string"?d.params.id:void 0;if(!l)return {status:"fail",error:"appendFiles requires params.id"};let i=o(l)??x();return i?i.cardStoreOps.appendFiles(d):{status:"fail",error:"Board context is unavailable"}}}}function L(){return a$2({board:j(),nonCore:w(),cardStore:v(),chatStore:b,uploadCardFile({cardId:d,fileName:l,contentType:i,bytes:m}){return g(d,l,i,m,{inChat:false})},buildFileDownloadUrl({cardId:d,fileIdx:l,storedName:i}){let m=`${S||""}${O}/cards/${encodeURIComponent(d)}/files/${l}`;return i?`${m}?sn=${encodeURIComponent(i)}`:m},readFetchedSourceJsonByRef({cardId:d,ref:l}){let i=o(d)??x();if(!i||ge(i.boardAdapter))return null;let P=i.boardAdapter.resolveBlob(b$2(l)).trim();return P?JSON.parse(P):null}})}return {mcpBoardFacade:j,mcpNonCoreFacade:w,mcpCardStoreFacade:v,createMcpFacade:L}}function It(r){let{sseHub:t,corsHeaders:s,json:o,buildPublishedRuntimePayload:u,onSseClientConnected:p,onChannelSubscribed:R,onChannelUnsubscribed:C}=r;function F(g,b,S,O,x){if(!t.has(b)){o(g,404,{error:`SSE client not connected: ${b}`});return}x?R?.(b,S,O):C?.(b,S,O),o(g,200,{ok:true,clientId:b,channelName:S,...O.cardId?{cardId:O.cardId}:{},subscribed:x});}async function T(g,b,S){let O=t.get(S),x=O?new Set(O.subscribedChatCardIds):new Set;b.writeHead(200,{...s,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),t.flushTransport(b),t.register(S,b,x);let j=await u(),w=t.buildFrame(j);b.write(w);try{p?.(S,L=>{t.writeFrame(S,L);});}catch{}let v=setInterval(()=>{try{b.write(`: keepalive
|
|
5
|
+
|
|
6
|
+
`);}catch{}},15e3);g.on("close",()=>{clearInterval(v),t.disconnect(S,b);});}return {handleChannelSubscription:F,handleSse:T}}async function Xe(r,t,s){let o=s[r];if(!o)throw Object.assign(new Error(`Unknown MCP tool: ${r}`),{statusCode:400});let u=await o(t);if(u&&typeof u=="object"&&!Array.isArray(u)){let p=u,R=p.status;if(R==="success")return Object.prototype.hasOwnProperty.call(p,"data")?u:{status:"success",data:{}};if(R==="fail"||R==="error")return u}return {status:"success",data:u}}function Me(r,t){if(!r||typeof r!="object"||Array.isArray(r))return t;let s=r;if(typeof s.error=="string"&&s.error.trim())return s.error;if(s.step==="validate"){let o=s.validation;if(o&&typeof o=="object"&&!Array.isArray(o)){let p=o.data;if(p&&typeof p=="object"&&!Array.isArray(p)){let R=p.issues;if(Array.isArray(R)){let F=R.find(T=>typeof T=="string"&&T.trim());if(typeof F=="string")return `Validation failed: ${F}`}let C=p.errors;if(Array.isArray(C)&&C.length>0)return "Validation failed"}}return "Validation failed"}return t}function xt(r){let{apiBasePath:t,boardContexts:s,json:o,readJsonBody:u,readRawBody:p,initBoardAndSetup:R,bootstrapBoard:C,buildPublishedRuntimePayload:F,publishPersistedStateSnapshot:T,upsertCardsFromSource:g,applyBoardWorkerCallback:b,handleSse:S,handleChannelSubscription:O,createMcpFacade:x,createMcpToolRegistry:j,createMcpControlplaneToolRegistry:w,readCardFromStore:v,patchCard:L,retriggerCard:d,applyCardAction:l,resolveChatHandlerTarget:i,chatStorePublic:m,chatStorage:A,sseHub:P,uploadCardFile:G,sendCardFileDownloadResponse:ue,resolveCardFileDownloadPayload:fe,isLikelyTextMimeType:ie,sliceTextByLines:be}=r;async function Se(ee,I,Ve){let W=ee.method||"GET",te=Ve,Y=te.pathname;try{if(W==="GET"&&Y===`${t}/init-board`)return await R(),o(I,200,await F()),!0;if(W==="GET"&&Y===`${t}/sse`){await R();let k=String(te.searchParams.get("clientId")||"").trim();if(!k)return o(I,400,{error:"clientId query param is required for SSE"}),!0;await S(ee,I,k);for(let h=0;h<s.length;h++)await T(s[h]),await g(s[h],h),await T(s[h]);return !0}if(W==="GET"&&Y===`${t}/board-status`)return o(I,200,await F()),!0;let we=Y.match(new RegExp(`^${se(t)}/callback/board-worker/([^/]+)/(success|failure)$`));if(W==="POST"&&we){await R();let k=decodeURIComponent(we[1]),h=we[2],M=await u(ee),B=await b(k,h,M);return o(I,B.statusCode,B.body),!0}if(W==="POST"&&Y===`${t}/mcp`){await C();let k=await u(ee),h=typeof k.tool=="string"?k.tool.trim():"",M=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!h)return o(I,400,{error:"tool is required"}),!0;if(h==="inspect.file-contents")return o(I,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let B=await Xe(h,M,j(x()));if(B&&typeof B=="object"&&!Array.isArray(B)){let q=B;if(q.status==="fail")return o(I,400,{error:Me(B,"Request failed")}),!0;if(q.status==="error")return o(I,500,{error:Me(B,"Internal error")}),!0}o(I,200,B);}catch(B){let q=typeof B?.statusCode=="number"?Number(B.statusCode):500,Z=B instanceof Error?B.message:String(B);o(I,q,{error:Z});}return !0}if(W==="POST"&&Y===`${t}/mcp-controlplane`){await C();let k=await u(ee),h=typeof k.tool=="string"?k.tool.trim():"",M=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!h)return o(I,400,{error:"tool is required"}),!0;try{let B=await Xe(h,M,w());if(B&&typeof B=="object"&&!Array.isArray(B)){let q=B;if(q.status==="fail")return o(I,400,{error:Me(B,"Request failed")}),!0;if(q.status==="error")return o(I,500,{error:Me(B,"Internal error")}),!0}o(I,200,B);}catch(B){let q=typeof B?.statusCode=="number"?Number(B.statusCode):500,Z=B instanceof Error?B.message:String(B);o(I,q,{error:Z});}return !0}if(W==="POST"&&Y===`${t}/mcp-raw`){await C();let k=await u(ee),h=typeof k.tool=="string"?k.tool.trim():"",M=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!h)return o(I,400,{error:"tool is required"}),!0;if(h!=="inspect.file-contents")return o(I,400,{error:`Tool does not support raw response: ${h}`}),!0;let B=z(M,"card_id","cardId"),q=ye(M,"file_idx","fileIdx"),Z=ye(M,"head-lines","headLines"),Q=ye(M,"tail-lines","tailLines"),ne=ye(M,"head-bytes","headBytes"),le=ye(M,"tail-bytes","tailBytes");if(!B)return o(I,400,{error:"inspect.file-contents requires card_id"}),!0;if(q===void 0||!Number.isInteger(q)||q<0)return o(I,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([Z,Q,ne,le].filter(ce=>ce!==void 0).length>1)return o(I,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[ce,ke]of [["head-lines",Z],["tail-lines",Q],["head-bytes",ne],["tail-bytes",le]])if(ke!==void 0&&(!Number.isInteger(ke)||ke<0))return o(I,400,{error:`inspect.file-contents requires ${ce} to be a non-negative integer`}),!0;let Ie=await x().inspectFileContents({cardId:B,fileIdx:q}),$e=typeof Ie?.stored_name=="string"?Ie.stored_name:null,{fileRecord:Fe,bytes:Ae}=await fe(B,q,$e),qe=String(Fe.name||Fe.stored_name||"download.bin"),Te=String(Fe.mime_type||"application/octet-stream"),ve=(te.searchParams.get("resp")||"").trim().toLowerCase();if(ve&&ve!=="json-b64")return o(I,400,{error:`unsupported resp mode: ${ve}`}),!0;let Ne=ve==="json-b64",me;if(Z!==void 0||Q!==void 0){if(!ie(Te))return o(I,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let ce=new TextDecoder().decode(Ae),ke=Z!==void 0?be(ce,"head",Z):be(ce,"tail",Q);me=typeof Buffer<"u"?Buffer.from(ke,"utf8"):new TextEncoder().encode(ke);}else if(ne!==void 0||le!==void 0){let ce=ne??le;me=ne!==void 0?Ae.slice(0,ce):Ae.slice(Math.max(0,Ae.length-ce));}else me=Ae;if(Ne){let ce=typeof Buffer<"u"?Buffer.from(me).toString("base64"):btoa(String.fromCharCode(...me));return o(I,200,{bodyBase64:ce,mimeType:Te,filename:qe,byteLength:me.length}),!0}return I.writeHead(200,{"Content-Type":Te,"Content-Disposition":`attachment; filename="${qe}"`,"Content-Length":me.length}),I.end(me),!0}let Ce=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)$`));if(W==="GET"&&Ce){await C();let k=decodeURIComponent(Ce[1]),h=await v(k);return h?(o(I,200,h),!0):(o(I,404,{error:`card not found: ${k}`}),!0)}if(W==="PATCH"&&Ce){await C();let k=decodeURIComponent(Ce[1]),h=await u(ee);return await L(k,h),o(I,200,{ok:!0}),!0}let je=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/retrigger$`));if(W==="POST"&&je){await C();let k=decodeURIComponent(je[1]);return await d(k),o(I,200,{ok:!0}),!0}let pe=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/actions$`));if(W==="POST"&&pe){await C();let k=decodeURIComponent(pe[1]),h=Date.now(),M=new Date(h).toISOString(),B=await u(ee),q=B?.actionType;if(q==="chat-send"&&!await i(k)){let Q=Date.now();return o(I,409,{error:`chat handler is not configured for card: ${k}`,requestReceivedAt:M,requestReceivedAtMs:h,responseSentAt:new Date(Q).toISOString(),responseSentAtMs:Q,responseStatus:409}),!0}if(q==="chat-send"){let Q=B?.payload??{},ne=typeof Q["turn-id"]=="string"?Q["turn-id"]:typeof Q.turnId=="string"?Q.turnId:typeof Q.turn=="string"?Q.turn:"";if(!ne||!String(ne).trim()){let le=Date.now();return o(I,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${k}`,requestReceivedAt:M,requestReceivedAtMs:h,responseSentAt:new Date(le).toISOString(),responseSentAtMs:le,responseStatus:400}),!0}}await l(k,q,B?.payload);let Z=Date.now();return o(I,200,{ok:!0,requestReceivedAt:M,requestReceivedAtMs:h,responseSentAt:new Date(Z).toISOString(),responseSentAtMs:Z,responseStatus:200}),!0}let Pe=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/chats$`));if(W==="GET"&&Pe){await C();let k=decodeURIComponent(Pe[1]),h=String(te.searchParams.get("turn-id")||""),M=String(te.searchParams.get("all-turns")||"").toLowerCase()==="true",B=String(te.searchParams.get("tail-turns-before-id")||""),q=te.searchParams.get("tail-turns"),Z=q==null||q===""?M||h?void 0:1:Number.parseInt(q,10),Q=m.readAll({params:{cardId:k},body:{...Z===void 0?{}:{tailTurns:Z},...h?{turnId:h}:{},...M?{allTurns:!0}:{},...B?{tailTurnsBeforeId:B}:{}}});if(Q.status!=="success")return o(I,400,{error:Q.error||"Failed to read chats"}),!0;let ne=Q.data.records;return o(I,200,{ok:!0,messages:ne}),!0}if(W==="POST"&&Pe){await C();let k=decodeURIComponent(Pe[1]),h=await u(ee),M=typeof h?.role=="string"?h.role:"assistant",B=typeof h?.text=="string"?h.text:"",q=Array.isArray(h?.files)?h.files:[],Z=typeof h?.turn=="string"?h.turn:typeof h?.["turn-id"]=="string"?h["turn-id"]:typeof h?.turnId=="string"?h.turnId:"",Q=h?.done===!0,ne=A.append(k,M,B,q,Z);return Q&&A.setProcessing(k,!1),P.broadcastCardChats(k,!Q),o(I,200,{ok:!0,id:ne}),!0}let Ee=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(W==="POST"&&Ee){await C();let k=decodeURIComponent(Ee[1]),h=await u(ee),M=typeof h?.clientId=="string"?h.clientId.trim():"";return M?P.subscribeChat(M,k)?(o(I,200,{ok:!0,clientId:M,cardId:k,subscribed:!0}),!0):(o(I,404,{error:`SSE client not connected: ${M}`}),!0):(o(I,400,{error:"clientId is required"}),!0)}let Le=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(W==="POST"&&Le){await C();let k=decodeURIComponent(Le[1]),h=await u(ee),M=typeof h?.clientId=="string"?h.clientId.trim():"";return M?P.unsubscribeChat(M,k)?(o(I,200,{ok:!0,clientId:M,cardId:k,subscribed:!1}),!0):(o(I,404,{error:`SSE client not connected: ${M}`}),!0):(o(I,400,{error:"clientId is required"}),!0)}let Re=Y.match(new RegExp(`^${se(t)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(W==="POST"&&Re){await C();let k=decodeURIComponent(Re[1]),h=Re[2]==="subscribe",M=await u(ee),B=typeof M?.clientId=="string"?M.clientId.trim():"";return B?(O(I,B,k,{},h),!0):(o(I,400,{error:"clientId is required"}),!0)}let Be=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(W==="POST"&&Be){await C();let k=decodeURIComponent(Be[1]),h=decodeURIComponent(Be[2]),M=Be[3]==="subscribe",B=await u(ee),q=typeof B?.clientId=="string"?B.clientId.trim():"";return q?(O(I,q,h,{cardId:k},M),!0):(o(I,400,{error:"clientId is required"}),!0)}let De=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/files$`));if(W==="POST"&&De){await C();let k=decodeURIComponent(De[1]),h=String(te.searchParams.get("inChat")||"").toLowerCase()==="true",M=String(te.searchParams.get("turn-id")||"").trim();if(h&&!M)return o(I,400,{error:`file upload with inChat=true requires a non-empty 'turn-id' query parameter for card: ${k}`}),!0;let B=ee.headers["x-file-name"],q=String(ee.headers["content-type"]||"application/octet-stream"),Z=Array.isArray(B)?B[0]:B,Q=Z?decodeURIComponent(String(Z)):"upload.bin",ne=await p(ee);return o(I,200,await G(k,Q,q,ne,{inChat:h,turnId:M})),!0}let Oe=Y.match(new RegExp(`^${se(t)}/cards/([^/]+)/files/(\\d+)$`));if(W==="GET"&&Oe){let k=decodeURIComponent(Oe[1]),h=parseInt(Oe[2],10),M=te.searchParams.get("sn");return await ue(I,k,h,M),!0}return !1}catch(we){let Ce=we?.statusCode||500;return o(I,Ce,{error:String(we?.message||we)}),true}}return {handleRuntimeApi:Se}}function Ye(r,t){return t?{...r,...t.pollIntervalMs!=null?{pollIntervalMs:t.pollIntervalMs}:{},...t.visibilityMs!=null?{visibilityMs:t.visibilityMs}:{},...t.concurrency!=null?{concurrency:t.concurrency}:{},...t.maxAttempts!=null?{maxAttempts:t.maxAttempts}:{}}:r}function _t(r,t,s,o){return {id:r,async lease(u){return (await Promise.resolve(t.leaseRequests(u))).map(R=>({id:R.messageId,attempt:R.attempt,message:R.request,ack:()=>Promise.resolve(t.ackRequest(R.messageId,R.leaseToken)),nack:C=>Promise.resolve(t.nackRequest(R.messageId,R.leaseToken,C))}))},async handle(u){await s(u.args,u);},onError:o?(u,p)=>o(u,p.attempt,p.message):void 0}}function Wt(r,t,s,o){return {id:r,async lease(u){return (await Promise.resolve(t.lease(u))).map(R=>({id:R.id,attempt:R.attempt,message:R.body,ack:()=>Promise.resolve(t.ack(R.id,R.leaseToken)),nack:C=>Promise.resolve(t.nack(R.id,R.leaseToken,C))}))},async handle(){await s();},onError:o?(u,p)=>o(u,p.attempt):void 0}}function br(r){let t=r.logger??{info(){},warn(){},error(){}},s=r.boardAdapter,o=r.runtime.queueLaneTuning??{},u=s.processAccumulatedStore(),p=s.chatAgentStore(),R=[];if(R.push(Ye(Wt("process-accumulated",u,async()=>{let C=await r.runtime.processAccumulatedLane();if(C.status!=="success")throw new Error(C.error||`processAccumulatedLane returned ${C.status}`)},(C,F)=>{t.error(`[board-server] queued process-accumulated failed for ${r.boardId} (attempt ${F}): ${String(C&&C.message||C)}`);}),o.processAccumulated)),R.push(Ye(_t("chat-agent",p,async(C,F)=>{await r.runtime.handleChatAgentRequest(F);},(C,F,T)=>{let g=typeof T.args?.cardId=="string"?T.args.cardId:"";t.error(`[board-server] queued chat-agent failed for ${r.boardId}${g?`/${g}`:""} (attempt ${F}): ${String(C&&C.message||C)}`);}),o.chatAgent)),r.executeTaskExecutorRequest){let C=s.boardWorkerStore();R.push(Ye(_t("task-executor",C,r.executeTaskExecutorRequest,(F,T)=>{t.error(`[board-server] queued board-worker failed for ${r.boardId} (attempt ${T}): ${String(F&&F.message||F)}`);}),o.taskExecutor));}return f(R)}var Ft={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},Ot="chat-handler-flow-queue";function Lr(r){let t=String(r.apiBasePath||"/api/board").replace(/\/$/,""),s={...Ft,...r.corsHeaders||{}},o=r.queueLaneTuning??{},u=r.boardId||"",p=r.logger||{info:console.log,warn:console.warn,error:console.error},R=r.invocationAdapter,C=r.chatFlowRunner||null,F=r.chatStorage??b(),T=a(F),g=r.notificationTransport||null,b$2=r.serverUrl||null,S=r.executionExtra||{},O=r.onSseClientConnected,x=r.onSseClientDisconnected,j$1=r.onChannelSubscribed,w=r.onChannelUnsubscribed,v=ht({chatStorage:F,readChatRecords:e=>le(e),onSseClientDisconnected:x});function L(e){function n(y){if(Array.isArray(y))return y;if(y&&typeof y=="object"){let E=y;return Array.isArray(E.files)?E.files:[y]}return null}function a(y){return {async get(E){return y.get(E)},async set(E){return y.set(E)},async del(E){return y.del(E)},async patch(E){return y.patch(E)},async appendFiles(E){return y.appendFiles(E)}}}function f(y){function E(V){return {status:"success",data:V}}function $(V){return {status:"fail",error:V}}function D(V){return {status:"error",error:V instanceof Error?V.message:String(V)}}return {async get(V){try{let U=V.params?.id;if(U){let re=await y.readCard(U);return re?E({cards:[re]}):$(`card "${U}" not found`)}return E({cards:await y.readAllCards()})}catch(U){return D(U)}},async set(V){try{let U=V.body;if(U==null)return $("set requires a body (card object or array of cards)");let re=Array.isArray(U)?U:[U];for(let ae of re){if(typeof ae.id!="string")return $("each card must have a string `id` field");await y.writeCard(ae.id,ae);}return E({count:re.length})}catch(U){return D(U)}},async del(V){try{let U=V.body?.ids??[],re=V.params?.id,ae=re?[...U,re]:U;if(ae.length===0)return $("del requires body.ids (string[]) or params.id");for(let xe of ae)await y.removeCard(xe);return E({count:ae.length})}catch(U){return D(U)}},async patch(V){try{let U=V.params?.id,re=V.params?.path;if(!U)return $("patch requires params.id");if(!re)return $("patch requires params.path");let ae=V.body,xe=ae&&Object.prototype.hasOwnProperty.call(ae,"value")?ae.value:V.body;return await y.patchCard(U,re,xe),E({count:1})}catch(U){return D(U)}},async appendFiles(V){try{let U=V.params?.id;if(!U)return $("appendFiles requires params.id");let re=await y.readCard(U);if(!re)return $(`card "${U}" not found`);let ae=n(V.body);if(!ae||ae.length===0)return $("appendFiles requires a file metadata object, array, or body.files array");let xe=re.card_data&&typeof re.card_data=="object"&&!Array.isArray(re.card_data)?re.card_data:{},nt=Array.isArray(xe.files)?xe.files:[],qt=[...nt,...ae];return await y.patchCard(U,"card_data.files",qt),E({files_added:ae.map((Nt,Ut)=>({idx:nt.length+Ut,entry:Nt}))})}catch(U){return D(U)}}}}let c$2=ge(e.boardAdapter)?j(e.baseRef,e.boardAdapter):y(e.baseRef,e.boardAdapter),_=e.nonCoreAdapter??(!ge(e.boardAdapter)&&m(e.boardAdapter)?e.boardAdapter:null),N=_?z$1(e.baseRef,_):null,K,H=ge(e.boardAdapter)?(()=>{let y=d(c(b$1(e.boardAdapter.kvStorageForRef(e.cardStoreRef)),e.boardAdapter.hashFn),p.warn),E=f(y);return K={get($){return E.get($)},set($){return E.set($)}},E})():(()=>{let y=e.boardAdapter.kvStorageForRef(e.cardStoreRef),$=a$1(l({readIndex:()=>y.read("_index"),writeIndex:D=>y.write("_index",D),readCard:D=>y.read(D),writeCard:(D,V)=>(y.write(D,V),D),removeCard:D=>{y.delete(D);},cardExists:D=>y.read(D)!==null,defaultCardKey:D=>D},p.warn));return K=$,a($)})(),X=e.artifactsAdapter||e.boardAdapter,J=e.filesArtifactsStore??null,oe=J?{putBytes(y,E,$){J.putBytes(y,E,$);},getBytes(y){return J.getBytes(y)},listKeys(y){return J.list(y).map(E=>E.key)}}:null;if(!oe&&!ge(X)){let y=e.artifactsAdapter?X.blobStorage(""):X.blobStorage("files"),E=c$1(y);oe={putBytes($,D,V){E.putBytes($,D,V);},getBytes($){return E.getBytes($)},listKeys($){return E.list($).map(D=>D.key)}};}else if(!oe&&ge(X)){let y=e.artifactsAdapter?X.blobStorage(""):X.blobStorage("files");oe={async putBytes(E,$){if(y.writeBytes){await y.writeBytes(E,$);return}let D=JSON.stringify({__kind:"bytes-array",data:[...$]});await y.write(E,D);},async getBytes(E){if(y.readBytes){let D=await y.readBytes(E);if(D!==null)return D}let $=await y.read(E);if($===null)return null;try{let D=JSON.parse($);if(D&&D.__kind==="bytes-array"&&Array.isArray(D.data))return new Uint8Array(D.data)}catch{}return new TextEncoder().encode($)},async listKeys(E){return await y.listKeys(E)}};}let de={async init(y){return c$2.init(y)},async status(y){return c$2.status(y)},async getConfig(y){return c$2.getConfig(y)},async getAllOutputsDataObjects(y){return c$2.getAllOutputsDataObjects(y)},async getAllOutputsComputedValues(y){return c$2.getAllOutputsComputedValues(y)},async getOutputsFetchedSources(y){return c$2.getOutputsFetchedSources(y)},async upsertCard(y){return c$2.upsertCard(y)},async removeCard(y){return c$2.removeCard(y)},async cardRefreshedNotify(y){return c$2.cardRefreshedNotify(y)},async sourceDataFetched(y){return c$2.sourceDataFetched(y)},async sourceDataFetchFailure(y){return c$2.sourceDataFetchFailure(y)}};return {label:e.label,board:c$2,nonCore:N,publicCardStore:K,boardOps:de,cardStoreOps:H,get filesArtifacts(){return oe},boardAdapter:e.boardAdapter,cardStoreRef:e.cardStoreRef,outputsStoreRef:e.outputsStoreRef,artifactsStoreRef:e.artifactsStoreRef,scratchStoreRef:e.scratchStoreRef,archiveStoreRef:e.archiveStoreRef,notifyRef:e.notifyRef,taskExecutorRef:e.taskExecutorRef,chatHandlerRef:e.chatHandlerRef,chatHandlerFlow:e.chatHandlerFlow,inferenceAdapterRef:e.inferenceAdapterRef,notification:wt(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let d$1=r.boards.map(L),l$1=new Map;function i(e){return l$1.get(e)??0}function m(e){let n=e;return typeof n.invokeExecutor=="function"&&typeof n.validateSchema=="function"}function A(e){let n=d$1[i(e)];return {files:n?n.filesArtifacts:null}}function P(){return e()}function G(e){return String(e||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function ue(e){if(!e||e.notificationTeardown||!g||!e.notifyRef)return;let n=await g.subscribe(e.notifyRef,a=>{ze(e.notification,a);let f=a.kind==="notification-batch"?a.notifications:[a];v.broadcastNotificationBatch(f);});e.notificationTeardown=n;}async function fe(e){if(!e||e.initialized)return;let n={cardStoreRef:e.cardStoreRef,outputsStoreRef:e.outputsStoreRef};e.artifactsStoreRef&&(n.artifactsStoreRef=e.artifactsStoreRef),e.scratchStoreRef&&(n.scratchStoreRef=e.scratchStoreRef),e.archiveStoreRef&&(n.archiveStoreRef=e.archiveStoreRef);let a={};e.taskExecutorRef&&(a["task-executor-ref"]=e.taskExecutorRef),e.chatHandlerFlow!==void 0&&(a["chat-handler-flow"]=e.chatHandlerFlow),e.inferenceAdapterRef&&(a["inference-adapter-ref"]=e.inferenceAdapterRef);let f=await e.boardOps.init({params:n,body:a});if(f.status!=="success")throw Object.assign(new Error(f.error||`init failed for ${e.label}`),{statusCode:500});if(await ue(e),!e.chatHandlerFlow&&e.chatHandlerRef&&R.describe)try{let c=await R.describe(e.chatHandlerRef);c&&c.kind!=="chat-handler"?p.warn(`[init] chat-handler describe returned kind="${c.kind}", expected "chat-handler" for ${e.label}`):c&&p.info(`[init] chat-handler validated: ${c.name} (protocol ${c.protocolVersion}) for ${e.label}`);}catch(c){p.warn(`[init] chat-handler describe failed for ${e.label}: ${c?.message||String(c)}`);}e.initialized=true;}async function ie(e){if(!e.boardAdapter.publishBoardChangeNotifications)return;let n=[],a=await e.boardOps.status({});a.status==="success"&&a.data!=null&&Qe(a.data)&&n.push({kind:"status",status:a.data});let f=await e.boardOps.getAllOutputsDataObjects({});if(f.status==="success"&&f.data!=null)for(let[_,N]of Object.entries(f.data))_&&n.push({kind:"data_object",key:_,payload:N});let c=await e.boardOps.getAllOutputsComputedValues({});if(c.status==="success"&&c.data!=null)for(let[_,N]of Object.entries(c.data))_&&n.push({kind:"computed_values",cardId:_,values:N});n.length>0&&e.boardAdapter.publishBoardChangeNotifications(n);}async function be(e,n){if(!e||e.cardsBootstrapped)return;let a=await e.cardStoreOps.get({}),f=a.status==="success"&&Array.isArray(a.data?.cards)?a.data.cards:[];for(let c of f)typeof c.id=="string"&&(l$1.set(c.id,n),await e.boardOps.upsertCard({params:{cardId:c.id}}));e.cardsBootstrapped=true;}async function Se(){for(let e of d$1)await fe(e);}async function ee(){await Se();for(let e=0;e<d$1.length;e++)await ie(d$1[e]),await be(d$1[e],e),await ie(d$1[e]);}async function I(e=false){e||await Se();for(let n of d$1){let a=await n.board.processAccumulatedEvents({});if(a.status!=="success")return a}return {status:"success"}}async function Ve(){return await Se(),I(true)}function W(e){return d$1[i(e)]??null}async function te(e){let n=W(e);if(!n)return null;let a=await n.cardStoreOps.get({params:{id:e}});if(a.status!=="success")return null;let f=Array.isArray(a.data?.cards)?a.data.cards:[];return f.length>0?f[0]:null}async function Y(){let e=async a=>{if(!a)return [];let f=await a.cardStoreOps.get({});return f.status!=="success"||!Array.isArray(f.data?.cards)?[]:f.data.cards},n=[];for(let a of d$1)n.push(...await e(a));return n}function we(){return d$1[0]??null}let Ce=Bt({boardContexts:d$1,cardOwnerIndex:l$1,cardContextForCard:e=>W(e),readStatusSnapshot:()=>Be(),readDataObjectsByToken:()=>Oe(),readCardRuntimeArtifacts:()=>De(),readCardFromStore:e=>te(e),readCardDefinitions:()=>Y(),processAccumulatedLaneInternal:e=>I(e),uploadCardFile:(e,n,a,f,c)=>Ie(e,n,a,f,c),chatStorePublic:T,serverUrl:b$2,apiBasePath:t}),je=Ce.mcpCardStoreFacade,pe=Ce.createMcpFacade,Pe=kt({boardId:u,getMcpFacade:()=>pe(),getMcpCardStoreFacade:()=>je()});function Ee(e){return vt(e)}function Le(){return Pt({boardId:u,uploadCardFile:Ie,getMcpFacade:()=>pe(),controlplane:Pe})}let Re=St({boardId:u,boardContexts:d$1,readCardDefinitions:()=>Y(),readChatRecords:e=>le(e),getChatProcessing:e=>pe().getChatProcessing({cardId:e}).active}),Be=Re.readStatusSnapshot,De=Re.readCardRuntimeArtifacts,Oe=Re.readDataObjectsByToken,k=Re.buildPublishedRuntimePayload;async function h(e,n,a){let f=a?.syncBoard!==false,c=a?.restartOnlyIfChanged===true,_=W(e);if(!_)throw Object.assign(new Error(`Card not found: ${e}`),{statusCode:404});let N=await te(e);if(!N)throw Object.assign(new Error(`Card not found: ${e}`),{statusCode:404});let K=c?JSON.stringify(N):null,H=n(N)||N;if(c&&JSON.stringify(H)===K)return;let X=await _.cardStoreOps.set({body:H});if(X.status!=="success")throw Object.assign(new Error(X.error||`Failed to persist card: ${e}`),{statusCode:500});if(f){let J=await _.boardOps.upsertCard({params:{cardId:e,restart:true}});if(J.status!=="success")throw Object.assign(new Error(J.error||`Failed to upsert card: ${e}`),{statusCode:500})}}async function M(e,n){await h(e,n,{syncBoard:true});}async function B(e,n){await h(e,n,{syncBoard:false});}async function q(e){let n=W(e);if(!n)throw Object.assign(new Error(`Card not found: ${e}`),{statusCode:404});if(!await te(e))throw Object.assign(new Error(`Card not found: ${e}`),{statusCode:404});let f=await n.boardOps.upsertCard({params:{cardId:e,restart:true}});if(f.status!=="success")throw Object.assign(new Error(f.error||`Failed to retrigger card: ${e}`),{statusCode:500})}async function Z(e,n){await h(e,a=>{if(!n||typeof n!="object"||Object.keys(n).length===0)return a;function f(c,_,N){let K=String(_||"").split(".").filter(Boolean);if(!K.length)return;let H=c;for(let X=0;X<K.length-1;X++){let J=K[X];(!H[J]||typeof H[J]!="object")&&(H[J]={}),H=H[J];}H[K[K.length-1]]=N;}if(n.fieldValues!==void 0&&n.fieldValues!==null){let c=null,_=a.view;if(_&&Array.isArray(_.elements)){for(let N of _.elements)if(N?.data&&N.data.writeTo){c=N.data.writeTo;break}}c?f(a,c,n.fieldValues):typeof n.fieldValues=="object"&&!Array.isArray(n.fieldValues)&&(a.card_data={...a.card_data||{},...n.fieldValues});}else {if(Array.isArray(n._stagedFiles)&&n._stagedFiles.length>0)return a;for(let[c,_]of Object.entries(n))c!=="_stagedFiles"&&(_!==null&&typeof _=="object"&&!Array.isArray(_)&&a[c]!==null&&typeof a[c]=="object"&&!Array.isArray(a[c])?a[c]={...a[c],..._}:a[c]=_);}return a},{syncBoard:true,restartOnlyIfChanged:true});}function Q(e){F.clear(e);try{pe().setChatProcessing({cardId:e,active:!1});}catch{}}function ne(e,n,a,f,c=""){let _=typeof a=="string"?a.trim():"";return F.append(e,n||"system",_,f,c)}function le(e){return F.readAll(e)}let Ie=At({safeCardId:e=>G(e),artifactsStores:e=>A(e),cardFileMetadataStore:()=>P(),readCardFromStore:e=>te(e),updateCardLocalOnly:(e,n)=>B(e,n),writeChatRecord:(e,n,a,f,c)=>ne(e,n,a,f,c)}).uploadCardFile;async function $e(e){let n=W(e);if(!n)return null;let a=await n.boardOps.getConfig({params:{key:"chat-handler-flow"}}),f=a.status==="success"?a.data?.value:null,c=n.chatHandlerRef;return f==null&&(!c||typeof c!="object")?null:{ctx:n,handlerFlow:f,handlerRef:c}}async function Fe(e,n,a=false,f=""){let c=await $e(e);if(!c)return;let{ctx:_,handlerFlow:N,handlerRef:K}=c;if(!a)try{pe().setChatProcessing({cardId:e,active:!0});}catch{}let H={boardId:u,cardId:String(e),lastChatEntryId:n,...f?{turnId:f}:{},...S,...b$2?{serverUrl:b$2}:{}},X=N!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:Ot}}:K;try{ge(_.boardAdapter)?await _.boardAdapter.chatAgentStore().enqueueRequest({boardId:u,ref:X,args:N!=null?{...H,__chatHandlerFlow:N}:H}):_.boardAdapter.chatAgentStore().enqueueRequest({boardId:u,ref:X,args:N!=null?{...H,__chatHandlerFlow:N}:H}),await Promise.resolve(_.boardAdapter.requestProcessAccumulated?.());}catch(J){try{pe().setChatProcessing({cardId:e,active:!1});}catch{}p.warn(`[chat-handler] queue failed for card "${e}": ${J instanceof Error?J.message:String(J)}`);}}async function Ae(e,n,a){if(n.howToRun==="built-in"&&Ct(n)===Ot){let f=C,c=a.__chatHandlerFlow,_={...a};return delete _.__chatHandlerFlow,f?f.run(c,_,{boardId:u,cardId:String(_.cardId||""),label:e.label,logger:p,serverUrl:b$2,executionExtra:S}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return R.invoke(n,a)}async function qe(e,n=false){n||await Se();let a=typeof e.args?.cardId=="string"?e.args.cardId:"",f=a?W(a):we();if(!f)throw new Error(a?`Board context is unavailable for chat-agent request: ${a}`:"Board context is unavailable for chat-agent request");let c=await Ae(f,e.ref,e.args);if(!c.dispatched){if(a)try{F.setProcessing(a,!1);}catch{}throw new Error(c.error||`chat-agent dispatch failed for card "${a||"unknown"}"`)}}async function Te(e,n,a){let f=n==="chat-send"?B:M,c;await f(e,_=>{let N=new Date().toISOString(),K=_.card_data&&typeof _.card_data=="object"?_.card_data:{};if(_.card_data=K,n==="chat-send"){let H=a&&typeof a.text=="string"?a.text.trim():"",X=a&&typeof a["turn-id"]=="string"?a["turn-id"]:a&&typeof a.turnId=="string"?a.turnId:a&&typeof a.turn=="string"?a.turn:"",J=[];if(Array.isArray(a?.files)){for(let oe of a.files)if(oe){if(typeof oe=="string"){J.push({name:oe});continue}if(typeof oe=="object"){let de=oe;typeof de.name=="string"&&J.push({name:de.name,size:de.size,mime_type:de.mime_type,uploaded_at:de.uploaded_at,stored_name:de.stored_name,chat:de.chat===true});}}}if(H||J.length>0){let oe=T.runBatch({cardId:e,commands:[{command:"append",role:"user",text:H,files:J,turn:X},{command:"set-processing",active:true}]});if(oe.status!=="success")throw new Error(oe.error);let de=oe.data.results[0]?.data?.id;if(typeof de!="string"||!de)throw new Error(`chat-send did not return an append id for card ${e}`);c={cardId:e,lastEntryId:de,processingAlreadySet:true,turnId:X};try{let $=le(e);v.broadcastNotificationBatch([{kind:"card_chats",cardId:e,messages:$.map(D=>({role:String(D.role||"system"),text:String(D.text||""),files:Array.isArray(D.files)?D.files:[]})),receiving:!0,processing:F.isProcessing(e)}]);}catch{}}return _}if(n==="file-upload"){let H=P().normalizeIncoming(a?.files,N);return H.length>0&&P().merge(K,H),_}if(n==="action"){let H=a&&typeof a.buttonId=="string"?a.buttonId:"";if(!H)return _;K.lastAction={buttonId:H,at:N},K.lastActionText=`${H} @ ${N}`;}return _}),c&&Fe(c.cardId,c.lastEntryId,c.processingAlreadySet,c.turnId??"");}function ve(e,n,a){let f=JSON.stringify(a),c=typeof Buffer<"u"?Buffer.byteLength(f):new TextEncoder().encode(f).length;e.writeHead(n,{...s,"Content-Type":"application/json; charset=utf-8","Content-Length":c}),e.end(f);}async function Ne(e,n,a){let f=await te(e);if(!f)throw Object.assign(new Error("Card not found"),{statusCode:404});let c=P().resolve(f.card_data,n,a);if(!c.ok&&c.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!c.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let _=c.file,N=G(e),K=A(e),H=String(_.stored_name||""),X=`${N}/${H}`,J=K.files?await K.files.getBytes(X):null;if(!J)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:_,bytes:J}}async function me(e,n,a,f){let{fileRecord:c,bytes:_}=await Ne(n,a,f),N=String(c.name||c.stored_name||"download.bin"),K=String(c.mime_type||"application/octet-stream");e.writeHead(200,{"Content-Type":K,"Content-Disposition":`attachment; filename="${N}"`,"Content-Length":_.length}),e.end(_);}function ce(e){let n=String(e||"").toLowerCase();return n.startsWith("text/")||n.includes("json")||n.includes("xml")||n.includes("javascript")||n.includes("typescript")||n.includes("yaml")||n.includes("csv")}function ke(e,n,a){let f=e.split(/\r?\n/);return (n==="head"?f.slice(0,a):f.slice(-a)).join(`
|
|
7
|
+
`)}async function Mt(e){let n=[];for await(let f of e)n.push(f);let a=typeof Buffer<"u"?Buffer.concat(n).toString("utf-8").trim():new TextDecoder().decode(He(n)).trim();return a?JSON.parse(a):{}}async function jt(e){let n=[];for await(let a of e)n.push(a);return typeof Buffer<"u"?Buffer.concat(n):He(n)}async function et(e,n){let a=typeof n.ref=="string"?n.ref.trim():"";if(!a)return {status:"fail",error:"board-worker success callback requires body.ref"};let f=d$1[0];return f?f.boardOps.sourceDataFetched({params:{token:e,ref:a}}):{status:"fail",error:"no board context"}}async function tt(e,n){let a=typeof n.reason=="string"&&n.reason.trim()?n.reason:"unknown",f=d$1[0];return f?f.boardOps.sourceDataFetchFailure({params:{token:e,reason:a}}):{status:"fail",error:"no board context"}}async function Et(e,n,a){let f=String(e||"").trim();if(!f)return {statusCode:400,body:{error:"callback token is required"}};let c=n==="success"?await et(f,a):await tt(f,a);return c.status==="success"?{statusCode:200,body:c}:c.status==="fail"?{statusCode:400,body:{error:c.error}}:{statusCode:500,body:{error:c.error}}}let rt=It({sseHub:v,corsHeaders:s,json:ve,buildPublishedRuntimePayload:()=>k(),onSseClientConnected:O,onChannelSubscribed:j$1,onChannelUnsubscribed:w}),Lt=rt.handleChannelSubscription,Dt=rt.handleSse,$t=xt({apiBasePath:t,boardContexts:d$1,json:ve,readJsonBody:e=>Mt(e),readRawBody:e=>jt(e),initBoardAndSetup:()=>Se(),bootstrapBoard:()=>ee(),buildPublishedRuntimePayload:()=>k(),publishPersistedStateSnapshot:e=>ie(e),upsertCardsFromSource:(e,n)=>be(e,n),applyBoardWorkerCallback:(e,n,a)=>Et(e,n,a),handleSse:(e,n,a)=>Dt(e,n,a),handleChannelSubscription:(e,n,a,f,c)=>Lt(e,n,a,f,c),createMcpFacade:()=>pe(),createMcpToolRegistry:e=>Ee(e),createMcpControlplaneToolRegistry:()=>Le(),readCardFromStore:e=>te(e),patchCard:(e,n)=>Z(e,n),retriggerCard:e=>q(e),applyCardAction:(e,n,a)=>Te(e,n,a),resolveChatHandlerTarget:e=>$e(e),chatStorePublic:T,chatStorage:{append:(e,n,a,f,c)=>F.append(e,n,a,f,c),setProcessing:(e,n)=>F.setProcessing(e,n)},sseHub:v,uploadCardFile:(e,n,a,f,c)=>Ie(e,n,a,f,c),sendCardFileDownloadResponse:(e,n,a,f)=>me(e,n,a,f),resolveCardFileDownloadPayload:(e,n,a)=>Ne(e,n,a),isLikelyTextMimeType:e=>ce(e),sliceTextByLines:(e,n,a)=>ke(e,n,a)}).handleRuntimeApi;return {get apiBasePath(){return t},get corsHeaders(){return s},get queueLaneTuning(){return o},handleRuntimeApi:$t,buildPublishedRuntimePayload:k,processAccumulatedEvents:Ve,processAccumulatedLane:I,handleChatAgentRequest:qe,clearChatRecords:Q,reportSourceFetched(e,n){return et(e,{ref:n})},reportSourceFetchFailure(e,n){return tt(e,{reason:n})},get cardStore(){return d$1[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Dr(r){let t=String(r.apiBasePath||"/api/boards").replace(/\/$/,""),s={...Ft,...r.corsHeaders||{}},o=r.serverMetaStore,u=r.boardRuntimeFactory,p=new Map,R="boards-config.json";function C(){let w=o.getText(R);if(!w)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(w)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function F(w){o.putText(R,JSON.stringify(w,null,2));}function T(w){let v=String(w||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return v.length>0&&v.length<=64?v:null}function g(w){if(p.has(w))return p.get(w);let L=C().boards.find(l=>l.id===w)||{},d=u(w,L);return p.set(w,d),d}function b(w,v,L){let d=JSON.stringify(L),l=typeof Buffer<"u"?Buffer.byteLength(d):new TextEncoder().encode(d).length;w.writeHead(v,{...s,"Content-Type":"application/json; charset=utf-8","Content-Length":l}),w.end(d);}async function S(w,v,L){let d=w.method||"GET",l=L.pathname;if(d==="GET"&&l===t)return b(v,200,{ok:true,boards:C().boards}),true;if(d==="POST"&&l===t){let i=[];for await(let ie of w)i.push(ie);let m=typeof Buffer<"u"?Buffer.concat(i).toString("utf-8").trim():new TextDecoder().decode(He(i)).trim(),A={};try{A=m?JSON.parse(m):{};}catch{A={};}let P=T(A.id);if(!P)return b(v,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let G=C();if(G.boards.some(ie=>ie.id===P))return b(v,409,{error:`Board "${P}" is already registered`}),true;let ue=typeof A.label=="string"&&A.label.trim()?A.label.trim():P,fe={id:P,label:ue};for(let[ie,be]of Object.entries(A))ie==="id"||ie==="label"||be!=null&&(fe[ie]=be);return G.boards.push(fe),F(G),b(v,200,{ok:true,board:fe}),true}return false}async function O(w,v,L){let l=L.pathname.match(new RegExp(`^${se(t)}/([^/]+)(/|$)`));if(!l)return false;let i=T(decodeURIComponent(l[1]));return i?C().boards.some(P=>P.id===i)?!!await g(i).handleRuntimeApi(w,v,L):(b(v,404,{error:`Board "${i}" not registered. POST ${t} with {id} to register it first.`}),true):(b(v,400,{error:"Invalid board id"}),true)}async function x(w,v,L){return !!(await S(w,v,L)||await O(w,v,L))}function j(w){if(!C().boards.some(L=>L.id===w))throw Object.assign(new Error(`Board "${w}" not registered`),{statusCode:404});return {service:g(w)}}return {get apiBasePath(){return t},get corsHeaders(){return s},handleApi:x,requireBoardService:j}}export{br as a,Lr as b,Dr as c};//# sourceMappingURL=chunk-LRVAVWAG.js.map
|
|
8
|
+
//# sourceMappingURL=chunk-LRVAVWAG.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkGLIX37VG_cjs=require('../chunk-GLIX37VG.cjs');require('../chunk-WOALA3V5.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-GJJMEAVN.cjs'),require('../chunk-IXZG74EW.cjs'),require('../chunk-NMZ6XNLB.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-YMEIPKLW.cjs'),require('../chunk-GYQXDNNI.cjs'),require('../chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createHostedBoardQueueLaneRegistry",{enumerable:true,get:function(){return chunkGLIX37VG_cjs.a}});Object.defineProperty(exports,"createMultiBoardServerRuntime",{enumerable:true,get:function(){return chunkGLIX37VG_cjs.c}});Object.defineProperty(exports,"createSingleBoardServerRuntime",{enumerable:true,get:function(){return chunkGLIX37VG_cjs.b}});//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{a as createHostedBoardQueueLaneRegistry,c as createMultiBoardServerRuntime,b as createSingleBoardServerRuntime}from'../chunk-
|
|
1
|
+
export{a as createHostedBoardQueueLaneRegistry,c as createMultiBoardServerRuntime,b as createSingleBoardServerRuntime}from'../chunk-LRVAVWAG.js';import'../chunk-MLVTJASJ.js';import'../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-SCWHDI3I.js';import'../chunk-JMDHDY6M.js';import'../chunk-VLBB3D6B.js';import'../chunk-MNEOJWPS.js';import'../chunk-KBELAKIY.js';import'../chunk-76ON3V7R.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/package.json
CHANGED
package/lib/chunk-KQX6R4PV.cjs
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
'use strict';var chunkWOALA3V5_cjs=require('./chunk-WOALA3V5.cjs'),chunkH5HBXPOI_cjs=require('./chunk-H5HBXPOI.cjs'),chunkOEFTOO47_cjs=require('./chunk-OEFTOO47.cjs'),chunkSFVO2LB2_cjs=require('./chunk-SFVO2LB2.cjs'),chunkGJJMEAVN_cjs=require('./chunk-GJJMEAVN.cjs'),chunkYMEIPKLW_cjs=require('./chunk-YMEIPKLW.cjs'),chunkGYQXDNNI_cjs=require('./chunk-GYQXDNNI.cjs');function Ie(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Nt(c){if(!c||typeof c!="object")return false;let l=c.summary;return !l||typeof l!="object"?false:Number(l.card_count||0)>0}function Dt(c,l){if(!l||typeof l!="object")return;let y=l;if(y.kind==="notification-batch"&&Array.isArray(y.notifications)){for(let _ of y.notifications)Dt(c,_);return}y.kind==="status"&&Nt(y.status)&&(c.status=y.status),y.kind==="computed_values"&&y.cardId&&(c.computedValues[y.cardId]=y.values),y.kind==="data_object"&&y.key&&(c.dataObjects[y.key]=y.payload),y.kind==="card_refreshed"&&y.cardId&&(c.cards[y.cardId]=y.card),y.kind==="card_removed"&&y.cardId&&(delete c.cards[y.cardId],delete c.computedValues[y.cardId]);}function nt(c){return typeof c.journalStorage=="function"}function Oe(c){return typeof c.whatToRun=="string"?c.whatToRun.startsWith("b64:")?chunkSFVO2LB2_cjs.b(c.whatToRun).value:c.whatToRun:c.whatToRun.value}function V(c){return c.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function vt(c){let l=c.reduce((h,x)=>h+x.length,0),y=new Uint8Array(l),_=0;for(let h of c)y.set(h,_),_+=h.length;return y}function E(c,...l){for(let y of l)if(typeof c[y]=="string")return String(c[y]);return ""}function at(c,...l){for(let y of l)if(c[y]!==void 0)return Number(c[y])}function lt(c,...l){for(let y of l){let _=c[y];if(_&&typeof _=="object"&&!Array.isArray(_))return _}return {}}function st(c,l,...y){for(let _ of y){let h=c[_];if(h&&typeof h=="object"&&!Array.isArray(h))return h}throw Object.assign(new Error(`MCP tool requires ${l}`),{statusCode:400})}function _t(c,l,...y){for(let _ of y){let h=c[_];if(h!==void 0){let x=Number(h);if(Number.isFinite(x))return x}}throw Object.assign(new Error(`MCP tool requires ${l}`),{statusCode:400})}function xe(c){if(Array.isArray(c.bytes))return new Uint8Array(c.bytes.map(l=>Math.max(0,Math.min(255,Number(l)||0))));if(typeof c.text=="string")return new TextEncoder().encode(c.text);if(typeof c.base64=="string"){let l=String(c.base64).replace(/-/g,"+").replace(/_/g,"/"),y=l+"=".repeat((4-l.length%4)%4),_=atob(y);return Uint8Array.from(_,h=>h.charCodeAt(0))}return null}function Ut(c,l){return l?{...c,...l.pollIntervalMs!=null?{pollIntervalMs:l.pollIntervalMs}:{},...l.visibilityMs!=null?{visibilityMs:l.visibilityMs}:{},...l.concurrency!=null?{concurrency:l.concurrency}:{},...l.maxAttempts!=null?{maxAttempts:l.maxAttempts}:{}}:c}function Pe(c,l,y,_){return {id:c,async lease(h){return (await Promise.resolve(l.leaseRequests(h))).map(I=>({id:I.messageId,attempt:I.attempt,message:I.request,ack:()=>Promise.resolve(l.ackRequest(I.messageId,I.leaseToken)),nack:O=>Promise.resolve(l.nackRequest(I.messageId,I.leaseToken,O))}))},async handle(h){await y(h.args,h);},onError:_?(h,x)=>_(h,x.attempt,x.message):void 0}}function gr(c,l,y,_){return {id:c,async lease(h){return (await Promise.resolve(l.lease(h))).map(I=>({id:I.id,attempt:I.attempt,message:I.body,ack:()=>Promise.resolve(l.ack(I.id,I.leaseToken)),nack:O=>Promise.resolve(l.nack(I.id,I.leaseToken,O))}))},async handle(){await y();},onError:_?(h,x)=>_(h,x.attempt):void 0}}function kr(c){let l=c.logger??{info(){},warn(){},error(){}},y=c.boardAdapter,_=c.runtime.queueLaneTuning??{},h=y.processAccumulatedStore(),x=y.chatAgentStore(),I=[];if(I.push(Ut(gr("process-accumulated",h,async()=>{let O=await c.runtime.processAccumulatedLane();if(O.status!=="success")throw new Error(O.error||`processAccumulatedLane returned ${O.status}`)},(O,P)=>{l.error(`[board-server] queued process-accumulated failed for ${c.boardId} (attempt ${P}): ${String(O&&O.message||O)}`);}),_.processAccumulated)),I.push(Ut(Pe("chat-agent",x,async(O,P)=>{await c.runtime.handleChatAgentRequest(P);},(O,P,W)=>{let ot=typeof W.args?.cardId=="string"?W.args.cardId:"";l.error(`[board-server] queued chat-agent failed for ${c.boardId}${ot?`/${ot}`:""} (attempt ${P}): ${String(O&&O.message||O)}`);}),_.chatAgent)),c.executeTaskExecutorRequest){let O=y.boardWorkerStore();I.push(Ut(Pe("task-executor",O,c.executeTaskExecutorRequest,(P,W)=>{l.error(`[board-server] queued board-worker failed for ${c.boardId} (attempt ${W}): ${String(P&&P.message||P)}`);}),_.taskExecutor));}return chunkWOALA3V5_cjs.f(I)}var Te={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},je="chat-handler-flow-queue";function qr(c){let l=String(c.apiBasePath||"/api/board").replace(/\/$/,""),y={...Te,...c.corsHeaders||{}},_=c.queueLaneTuning??{},h=c.boardId||"",x=c.logger||{info:console.log,warn:console.warn,error:console.error},I=c.invocationAdapter,O=c.chatFlowRunner||null,P=c.chatStorage??chunkWOALA3V5_cjs.b(),W=chunkGYQXDNNI_cjs.a(P),ot=c.notificationTransport||null,z=c.serverUrl||null,mt=c.executionExtra||{},Bt=c.onSseClientConnected,It=c.onSseClientDisconnected,Ot=c.onChannelSubscribed,B=c.onChannelUnsubscribed,v=new Map,F=new Map,M=new Map,D=null;function Z(t){function e(u){if(Array.isArray(u))return u;if(u&&typeof u=="object"){let b=u;return Array.isArray(b.files)?b.files:[u]}return null}function r(u){return {async get(b){return u.get(b)},async set(b){return u.set(b)},async del(b){return u.del(b)},async patch(b){return u.patch(b)},async appendFiles(b){return u.appendFiles(b)}}}function n(u){function b(i){return {status:"success",data:i}}function A(i){return {status:"fail",error:i}}function R(i){return {status:"error",error:i instanceof Error?i.message:String(i)}}return {async get(i){try{let o=i.params?.id;if(o){let g=await u.readCard(o);return g?b({cards:[g]}):A(`card "${o}" not found`)}return b({cards:await u.readAllCards()})}catch(o){return R(o)}},async set(i){try{let o=i.body;if(o==null)return A("set requires a body (card object or array of cards)");let g=Array.isArray(o)?o:[o];for(let f of g){if(typeof f.id!="string")return A("each card must have a string `id` field");await u.writeCard(f.id,f);}return b({count:g.length})}catch(o){return R(o)}},async del(i){try{let o=i.body?.ids??[],g=i.params?.id,f=g?[...o,g]:o;if(f.length===0)return A("del requires body.ids (string[]) or params.id");for(let k of f)await u.removeCard(k);return b({count:f.length})}catch(o){return R(o)}},async patch(i){try{let o=i.params?.id,g=i.params?.path;if(!o)return A("patch requires params.id");if(!g)return A("patch requires params.path");let f=i.body,k=f&&Object.prototype.hasOwnProperty.call(f,"value")?f.value:i.body;return await u.patchCard(o,g,k),b({count:1})}catch(o){return R(o)}},async appendFiles(i){try{let o=i.params?.id;if(!o)return A("appendFiles requires params.id");let g=await u.readCard(o);if(!g)return A(`card "${o}" not found`);let f=e(i.body);if(!f||f.length===0)return A("appendFiles requires a file metadata object, array, or body.files array");let k=g.card_data&&typeof g.card_data=="object"&&!Array.isArray(g.card_data)?g.card_data:{},$=Array.isArray(k.files)?k.files:[],T=[...$,...f];return await u.patchCard(o,"card_data.files",T),b({files_added:f.map((N,rt)=>({idx:$.length+rt,entry:N}))})}catch(o){return R(o)}}}}let a=nt(t.boardAdapter)?chunkH5HBXPOI_cjs.j(t.baseRef,t.boardAdapter):chunkOEFTOO47_cjs.y(t.baseRef,t.boardAdapter),s=t.nonCoreAdapter??(!nt(t.boardAdapter)&&ft(t.boardAdapter)?t.boardAdapter:null),d=s?chunkOEFTOO47_cjs.z(t.baseRef,s):null,p,m=nt(t.boardAdapter)?(()=>{let u=chunkH5HBXPOI_cjs.d(chunkH5HBXPOI_cjs.c(chunkH5HBXPOI_cjs.b(t.boardAdapter.kvStorageForRef(t.cardStoreRef)),t.boardAdapter.hashFn),x.warn),b=n(u);return p={get(A){return b.get(A)},set(A){return b.set(A)}},b})():(()=>{let u=t.boardAdapter.kvStorageForRef(t.cardStoreRef),A=chunkYMEIPKLW_cjs.a(chunkOEFTOO47_cjs.l({readIndex:()=>u.read("_index"),writeIndex:R=>u.write("_index",R),readCard:R=>u.read(R),writeCard:(R,i)=>(u.write(R,i),R),removeCard:R=>{u.delete(R);},cardExists:R=>u.read(R)!==null,defaultCardKey:R=>R},x.warn));return p=A,r(A)})(),C=t.artifactsAdapter||t.boardAdapter,S=t.filesArtifactsStore??null,q=S?{putBytes(u,b,A){S.putBytes(u,b,A);},getBytes(u){return S.getBytes(u)},listKeys(u){return S.list(u).map(b=>b.key)}}:null;if(!q&&!nt(C)){let u=t.artifactsAdapter?C.blobStorage(""):C.blobStorage("files"),b=chunkWOALA3V5_cjs.c(u);q={putBytes(A,R,i){b.putBytes(A,R,i);},getBytes(A){return b.getBytes(A)},listKeys(A){return b.list(A).map(R=>R.key)}};}else if(!q&&nt(C)){let u=t.artifactsAdapter?C.blobStorage(""):C.blobStorage("files");q={async putBytes(b,A){if(u.writeBytes){await u.writeBytes(b,A);return}let R=JSON.stringify({__kind:"bytes-array",data:[...A]});await u.write(b,R);},async getBytes(b){if(u.readBytes){let R=await u.readBytes(b);if(R!==null)return R}let A=await u.read(b);if(A===null)return null;try{let R=JSON.parse(A);if(R&&R.__kind==="bytes-array"&&Array.isArray(R.data))return new Uint8Array(R.data)}catch{}return new TextEncoder().encode(A)},async listKeys(b){return await u.listKeys(b)}};}let L={async init(u){return a.init(u)},async status(u){return a.status(u)},async getConfig(u){return a.getConfig(u)},async getAllOutputsDataObjects(u){return a.getAllOutputsDataObjects(u)},async getAllOutputsComputedValues(u){return a.getAllOutputsComputedValues(u)},async getOutputsFetchedSources(u){return a.getOutputsFetchedSources(u)},async upsertCard(u){return a.upsertCard(u)},async removeCard(u){return a.removeCard(u)},async cardRefreshedNotify(u){return a.cardRefreshedNotify(u)},async sourceDataFetched(u){return a.sourceDataFetched(u)},async sourceDataFetchFailure(u){return a.sourceDataFetchFailure(u)}};return {label:t.label,board:a,nonCore:d,publicCardStore:p,boardOps:L,cardStoreOps:m,get filesArtifacts(){return q},boardAdapter:t.boardAdapter,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,scratchStoreRef:t.scratchStoreRef,archiveStoreRef:t.archiveStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:Ie(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let j=c.boards.map(Z),U=new Map;function X(t){return U.get(t)??0}function ft(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function yt(t){let e=j[X(t)];return {files:e?e.filesArtifacts:null}}function Y(){return chunkWOALA3V5_cjs.e()}function tt(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function pt(t){if(!t||t.notificationTeardown||!ot||!t.notifyRef)return;let e=await ot.subscribe(t.notifyRef,r=>{Dt(t.notification,r);let n=r.kind==="notification-batch"?r.notifications:[r];le(n);});t.notificationTeardown=e;}async function Ee(t){if(!t||t.initialized)return;let e={cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef};t.artifactsStoreRef&&(e.artifactsStoreRef=t.artifactsStoreRef),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 n=await t.boardOps.init({params:e,body:r});if(n.status!=="success")throw Object.assign(new Error(n.error||`init failed for ${t.label}`),{statusCode:500});if(await pt(t),!t.chatHandlerFlow&&t.chatHandlerRef&&I.describe)try{let a=await I.describe(t.chatHandlerRef);a&&a.kind!=="chat-handler"?x.warn(`[init] chat-handler describe returned kind="${a.kind}", expected "chat-handler" for ${t.label}`):a&&x.info(`[init] chat-handler validated: ${a.name} (protocol ${a.protocolVersion}) for ${t.label}`);}catch(a){x.warn(`[init] chat-handler describe failed for ${t.label}: ${a?.message||String(a)}`);}t.initialized=true;}async function wt(t){if(!t.boardAdapter.publishBoardChangeNotifications)return;let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&Nt(r.data)&&e.push({kind:"status",status:r.data});let n=await t.boardOps.getAllOutputsDataObjects({});if(n.status==="success"&&n.data!=null)for(let[s,d]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:d});let a=await t.boardOps.getAllOutputsComputedValues({});if(a.status==="success"&&a.data!=null)for(let[s,d]of Object.entries(a.data))s&&e.push({kind:"computed_values",cardId:s,values:d});e.length>0&&t.boardAdapter.publishBoardChangeNotifications(e);}async function Ht(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),n=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let a of n)typeof a.id=="string"&&(U.set(a.id,e),await t.boardOps.upsertCard({params:{cardId:a.id}}));t.cardsBootstrapped=true;}async function ct(){for(let t of j)await Ee(t);}async function H(){await ct();for(let t=0;t<j.length;t++)await wt(j[t]),await Ht(j[t],t),await wt(j[t]);}async function xt(t=false){t||await ct();for(let e of j){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}async function $e(){return await ct(),xt(true)}function Q(t){return j[X(t)]??null}async function dt(t){let e=Q(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function Qt(){let t=async r=>{if(!r)return [];let n=await r.cardStoreOps.get({});return n.status!=="success"||!Array.isArray(n.data?.cards)?[]:n.data.cards},e=[];for(let r of j)e.push(...await t(r));return e}function J(){return j[0]??null}function Fe(){return {async status(){let t=await Zt();return t==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:t}},async getOutputsDataObject(t){let e=t?.params?.key;return e?{status:"success",data:(await Yt())[e]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(t){let e=t?.params?.key;return e?{status:"success",data:(await Xt())[e]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(t){let e=t?.params?.key;if(!e)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let r=Q(e)??J();return r?r.boardOps.getOutputsFetchedSources({params:{key:e}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(t){let e=t?.params?.id;if(!e)return {status:"fail",error:"removeCard requires params.id"};let r=Q(e)??J();return r?r.boardOps.removeCard({params:{id:e}}):{status:"fail",error:"Board context is unavailable"}},async cardRefreshedNotify(t){let e=t?.params?.cardId;if(!e)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let r=Q(e)??J();return r?r.boardOps.cardRefreshedNotify({params:{cardId:e}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(t){let e=t?.params?.cardId;if(!e)return {status:"fail",error:"upsertCard requires params.cardId"};let r=Q(e)??J();if(!r)return {status:"fail",error:"Board context is unavailable"};let n=await r.boardOps.upsertCard({params:{cardId:e,restart:t.params.restart===true}});if(n.status!=="success")return n;if(nt(r.boardAdapter)){let a=await xt(true);if(a.status!=="success")return a}return n}}}function qe(){let t=()=>{let e=J();if(!e?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return e.nonCore};return {describeTaskExecutorCapabilities(e){return t().describeTaskExecutorCapabilities(e)},validateCardPreflight(e){return t().validateCardPreflight(e)},evalCardCompute(e){return t().evalCardCompute(e)},probeSourcePreflight(e){return t().probeSourcePreflight(e)},runSourcePreflight(e){return t().runSourcePreflight(e)},simulateCardCycle(e){return t().simulateCardCycle(e)}}}function bt(){return {async get(t){let e=typeof t.params?.id=="string"?t.params.id:void 0;if(e){let r=await dt(e);return r?{status:"success",data:{cards:[r]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await Qt()}}},async set(t){let e=t.body;if(e==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let r=Array.isArray(e)?e:[e];for(let n of r){let a=n,s=typeof a.id=="string"?a.id:"";if(!s)return {status:"fail",error:"each card must have a string `id` field"};let d=U.get(s)??0,p=j[d]??J();if(!p)return {status:"fail",error:"Board context is unavailable"};let m=await p.cardStoreOps.set({body:a});if(m.status!=="success")return m;U.set(s,d);}return {status:"success",data:{count:r.length}}},async del(t){let e=[t.params?.id,...t.body?.ids??[]].filter(r=>typeof r=="string"&&!!r);if(e.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let r of e){let n=Q(r)??J();if(!n)return {status:"fail",error:"Board context is unavailable"};let a=await n.cardStoreOps.del({params:{id:r}});if(a.status!=="success")return a;U.delete(r);}return {status:"success",data:{count:e.length}}},async patch(t){let e=typeof t.params?.id=="string"?t.params.id:void 0,r=typeof t.params?.path=="string"?t.params.path:void 0;if(!e||!r)return {status:"fail",error:"patch requires params.id and params.path"};let n=Q(e)??J();return n?n.cardStoreOps.patch(t):{status:"fail",error:"Board context is unavailable"}},async appendFiles(t){let e=typeof t.params?.id=="string"?t.params.id:void 0;if(!e)return {status:"fail",error:"appendFiles requires params.id"};let r=Q(e)??J();return r?r.cardStoreOps.appendFiles(t):{status:"fail",error:"Board context is unavailable"}}}}function et(){return chunkGJJMEAVN_cjs.a({board:Fe(),nonCore:qe(),cardStore:bt(),chatStore:W,uploadCardFile({cardId:t,fileName:e,contentType:r,bytes:n}){return Tt(t,e,r,n,{inChat:false})},buildFileDownloadUrl({cardId:t,fileIdx:e,storedName:r}){let n=`${z||""}${l}/cards/${encodeURIComponent(t)}/files/${e}`;return r?`${n}?sn=${encodeURIComponent(r)}`:n},readFetchedSourceJsonByRef({cardId:t,ref:e}){let r=Q(t)??J();if(!r||nt(r.boardAdapter))return null;let a=r.boardAdapter.resolveBlob(chunkSFVO2LB2_cjs.b(e)).trim();return a?JSON.parse(a):null}})}function Vt(t,e){let r=E(t,"board_id"),n=E(t,"card_id");if(!r)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(!n)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});if(r!==h)throw Object.assign(new Error(`Unknown board_id: ${r}`),{statusCode:400});return et().setChatProcessing({cardId:n,active:e}),{status:"success",data:{boardId:h,cardId:n,active:e}}}function ht(t){let e=E(t,"board_id"),r=E(t,"card_id");if(!e)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(!r)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});if(e!==h)throw Object.assign(new Error(`Unknown board_id: ${e}`),{statusCode:400});return {cardId:r}}function Wt(t,e){if(t?.status==="success")return Object.prototype.hasOwnProperty.call(t,"data")?t.data:void 0;throw t?.status==="fail"||t?.status==="error"?Object.assign(new Error(t.error||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function zt(t,e){return Wt(await t,e)}function Jt(t){let e=E(t,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let r=e.split(".");if(!(r.length>=2&&r[0]==="chat"&&r.every(a=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(a))))throw Object.assign(new Error("MCP tool only supports card meta keys under chat.*"),{statusCode:400});return e}function Kt(t,e){let r=t.meta;for(let n of e.split(".")){if(!r||typeof r!="object"||Array.isArray(r)||!Object.prototype.hasOwnProperty.call(r,n))return {exists:false,value:null};r=r[n];}return {exists:true,value:r}}function Me(t){let{cardId:e}=ht(t),r=et().getChatProcessing({cardId:e});return {status:"success",data:{boardId:h,cardId:e,active:r.active}}}async function Le(t){let{cardId:e}=ht(t),r=Jt(t);if(!Object.prototype.hasOwnProperty.call(t,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(r.split(".").includes("__visible_controlplane_only")){let n=await zt(bt().get({params:{id:e}}),"cardStore.get"),a=Array.isArray(n.cards)&&n.cards.length>0&&typeof n.cards[0]=="object"&&!Array.isArray(n.cards[0])?n.cards[0]:null,s=a?Kt(a,"__visible_controlplane_only").value:void 0;if(t.value!==s)throw Object.assign(new Error("MCP tool cannot change the reserved meta flag __visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:h,cardId:e,key:r}}}return Wt(await bt().patch({params:{id:e,path:`meta.${r}`},body:{value:t.value}}),"cardStore.patch"),{status:"success",data:{boardId:h,cardId:e,key:r}}}async function Ne(t){let{cardId:e}=ht(t),r=Jt(t),n=await zt(bt().get({params:{id:e}}),"cardStore.get"),a=Array.isArray(n.cards)&&n.cards.length>0&&n.cards[0]&&typeof n.cards[0]=="object"&&!Array.isArray(n.cards[0])?n.cards[0]:null;if(!a)throw Object.assign(new Error(`Card "${e}" not found`),{statusCode:404});let s=Kt(a,r);return {status:"success",data:{boardId:h,cardId:e,key:r,exists:s.exists,value:s.value}}}function De(t){return {"discover.source-kinds":()=>t.discoverSourceKinds(),"inspect.board-runtime-status":()=>t.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>t.inspectCardDefinitionAndRuntime({cardId:E(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let r=at(e,"tail_turns"),n=at(e,"tail"),a=E(e,"turn_id"),s=e.all_turns===true,d=E(e,"tail_turns_before_id");return t.inspectChatMessagesOnCards({cardId:E(e,"card_id"),...r!==void 0?{lastUserTurns:r}:{},...n!==void 0?{tail:n}:{},...a?{turnId:a}:{},...s?{allTurns:true}:{},...d?{tailTurnsBeforeId:d}:{}})},"inspect.file-contents":e=>t.inspectFileContents({cardId:E(e,"card_id"),fileIdx:Number(at(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>t.preflightValidateCandidateCardDefinition({candidateCardContent:st(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>t.preflightMaterializeCandidateCard({candidateCardContent:st(e,"candidate_card_content","candidate_card_content"),mockRequires:st(e,"mock_requires","mock_requires"),mockFetchedSources:st(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e=>t.preflightProbeSingleSourceInCandidateCard({candidateCardContent:st(e,"candidate_card_content","candidate_card_content"),mockProjections:lt(e,"mock_projections"),sourceIdx:_t(e,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e=>t.preflightRunSingleSourceInCandidateCard({candidateCardContent:st(e,"candidate_card_content","candidate_card_content"),mockProjections:lt(e,"mock_projections"),sourceIdx:_t(e,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e=>t.preflightRunSingleSourceInLiveCard({cardId:E(e,"card_id"),sourceIdx:_t(e,"source_idx","source_idx"),mockRequires:st(e,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>t.preflightRunOneCycleWithCandidateCard({candidateCardContent:st(e,"candidate_card_content","candidate_card_content"),mockRequires:lt(e,"mock_requires")}),"manage.read-card":e=>t.manageReadCard({cardId:E(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let r=E(e,"turn_id");if(!r)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return t.manageAddChatEntryAndAnyAttachments({cardId:E(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...r?{turn:r}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"manage.upsert-card":e=>t.manageUpsertCard({cardId:E(e,"card_id"),candidateCardContent:lt(e,"candidate_card_content")}),"manage.remove-card":e=>t.manageRemoveCard({cardId:E(e,"card_id")})}}function Ue(){return {"getstate.is-chat-processing":t=>Me(t),"setstate.chat-processing-started":t=>Vt(t,true),"setstate.chat-processing-done":t=>Vt(t,false),"getstate.card-meta":t=>Ne(t),"setstate.card-meta":t=>Le(t),"manage.upload-card-file":t=>{let e=E(t,"board_id"),r=E(t,"card_id"),n=E(t,"file_name"),a=E(t,"content_type")||"application/octet-stream",s=xe(t);if(!e)throw Object.assign(new Error("manage.upload-card-file requires board_id"),{statusCode:400});if(e!==h)throw Object.assign(new Error(`Unknown board_id: ${e}`),{statusCode:400});if(!r)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!n)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!s)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return Tt(r,n,a,s,{inChat:false})},"manage.admin-read-card":async t=>{let{cardId:e}=ht(t);return {status:"success",data:{cards:await et().adminReadCard({cardId:e})}}},"manage.admin-upsert-card":t=>{let e=E(t,"board_id"),r=E(t,"card_id");if(!e)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!r)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(e!==h)throw Object.assign(new Error(`Unknown board_id: ${e}`),{statusCode:400});return et().adminUpsertCard({cardId:r,candidateCardContent:lt(t,"candidate_card_content")})}}}async function Gt(t,e,r){let n=r[t];if(!n)throw Object.assign(new Error(`Unknown MCP tool: ${t}`),{statusCode:400});let a=await n(e);if(a&&typeof a=="object"&&!Array.isArray(a)){let s=a,d=s.status;if(d==="success")return Object.prototype.hasOwnProperty.call(s,"data")?a:{status:"success",data:{}};if(d==="fail"||d==="error")return a}return {status:"success",data:a}}function Rt(t,e){if(!t||typeof t!="object"||Array.isArray(t))return e;let r=t;if(typeof r.error=="string"&&r.error.trim())return r.error;if(r.step==="validate"){let n=r.validation;if(n&&typeof n=="object"&&!Array.isArray(n)){let s=n.data;if(s&&typeof s=="object"&&!Array.isArray(s)){let d=s.issues;if(Array.isArray(d)){let m=d.find(C=>typeof C=="string"&&C.trim());if(typeof m=="string")return `Validation failed: ${m}`}let p=s.errors;if(Array.isArray(p)&&p.length>0)return "Validation failed"}}return "Validation failed"}return e}async function Zt(){let t=(await Promise.all(j.map(async s=>{try{let d=s.boardAdapter.kvStorageForRef(s.outputsStoreRef),p=await Promise.resolve(d.read("status"));if(p!=null)return p}catch{}return s.notification.status}))).filter(Boolean);if(t.length===0)return null;if(t.length===1)return t[0];let e=[],r=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],n={};for(let s of r)n[s]=0;for(let s of t){let d=s,p=Array.isArray(d.cards)?d.cards:[];e.push(...p);for(let m of r)n[m]+=Number(d?.summary?.[m]||0);}let a=t[0];return {...a,cards:e,summary:{...a.summary||{},card_count:e.length,...n}}}async function Xt(){let t={},e=async r=>{try{let n=await r.boardOps.getAllOutputsComputedValues({});if(n.status==="success"&&n.data&&typeof n.data=="object"){for(let[a,s]of Object.entries(n.data)){let d=r.notification.cards[a];t[a]={schema_version:"v1",card_id:a,card_data:d?.card_data??{},computed_values:s??{}};}return}}catch{}for(let[n,a]of Object.entries(r.notification.computedValues)){let s=r.notification.cards[n];t[n]={schema_version:"v1",card_id:n,card_data:s?.card_data??{},computed_values:a??{}};}};for(let r of j)await e(r);return t}async function Yt(){let t={};for(let e of j){try{let r=await e.boardOps.getAllOutputsDataObjects({});if(r.status==="success"&&r.data&&typeof r.data=="object"){Object.assign(t,r.data);continue}}catch{}Object.assign(t,e.notification.dataObjects||{});}return t}async function Ct(){let t=await Qt(),e=await Xt(),r=await Yt(),n={};for(let s of t){if(!s?.id)continue;let d=s.id,p=e[d]||{},m={...p.card_data&&typeof p.card_data=="object"?p.card_data:s.card_data&&typeof s.card_data=="object"?s.card_data:{}};n[d]={schema_version:p.schema_version||"v1",card_id:p.card_id||d,card_data:m,computed_values:p.computed_values&&typeof p.computed_values=="object"?p.computed_values:{}};}let a={};for(let s of t){if(!s?.id)continue;let d=s.id;try{let p=jt(d),m=et().getChatProcessing({cardId:d}).active;(p.length>0||m)&&(a[d]={messages:p.map(C=>({role:String(C.role||"system"),text:String(C.text||""),files:Array.isArray(C.files)?C.files:[]})),receiving:!1,processing:m});}catch{}}return {boardId:h,cardDefinitions:t,statusSnapshot:await Zt(),dataObjectsByToken:r,cardRuntimeById:n,cardChatsByCardId:a}}async function Pt(t,e,r){let n=r?.syncBoard!==false,a=r?.restartOnlyIfChanged===true,s=Q(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let d=await dt(t);if(!d)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let p=a?JSON.stringify(d):null,m=e(d)||d;if(a&&JSON.stringify(m)===p)return;let C=await s.cardStoreOps.set({body:m});if(C.status!=="success")throw Object.assign(new Error(C.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let S=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(S.status!=="success")throw Object.assign(new Error(S.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function He(t,e){await Pt(t,e,{syncBoard:true});}async function te(t,e){await Pt(t,e,{syncBoard:false});}async function Qe(t){let e=Q(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await dt(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let n=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function Ve(t,e){await Pt(t,r=>{if(!e||typeof e!="object"||Object.keys(e).length===0)return r;function n(a,s,d){let p=String(s||"").split(".").filter(Boolean);if(!p.length)return;let m=a;for(let C=0;C<p.length-1;C++){let S=p[C];(!m[S]||typeof m[S]!="object")&&(m[S]={}),m=m[S];}m[p[p.length-1]]=d;}if(e.fieldValues!==void 0&&e.fieldValues!==null){let a=null,s=r.view;if(s&&Array.isArray(s.elements)){for(let d of s.elements)if(d?.data&&d.data.writeTo){a=d.data.writeTo;break}}a?n(r,a,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[a,s]of Object.entries(e))a!=="_stagedFiles"&&(s!==null&&typeof s=="object"&&!Array.isArray(s)&&r[a]!==null&&typeof r[a]=="object"&&!Array.isArray(r[a])?r[a]={...r[a],...s}:r[a]=s);}return r},{syncBoard:true,restartOnlyIfChanged:true});}function We(t){let e=String(t||"").trim();if(!e)return "upload.bin";let r=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (r>=0?e.slice(r+1):e)||"upload.bin"}function ze(t){P.clear(t);try{et().setChatProcessing({cardId:t,active:!1});}catch{}}function Je(t,e,r,n,a=""){let s=typeof r=="string"?r.trim():"";return P.append(t,e,s,n,a)}function jt(t){return P.readAll(t)}async function Ke(t){let e=[];try{let r=await dt(t);if(!r)return e;let n=Y().read(r.card_data&&typeof r.card_data=="object"?r.card_data:null);for(let a of n)e.push(a.stored_name);}catch{}return e}async function Ge(t,e,r,n){let a=tt(t),s=yt(t),d=We(e),p=await Ke(t),C=`${String(p.length+1).padStart(3,"0")}-${d}`.slice(-36);return s.files&&await s.files.putBytes(`${a}/${C}`,new Uint8Array(n),r||"application/octet-stream"),{name:d,stored_name:C,size:n.length,mime_type:r||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function Tt(t,e,r,n,a){if(!n.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let s=a?.inChat===true,d=await Ge(t,e,r,n),p=null;if(await te(t,m=>{let C=new Date().toISOString(),S=m.card_data&&typeof m.card_data=="object"?m.card_data:{};m.card_data=S;let q=Y().normalizeIncoming([{name:d.name,stored_name:d.stored_name,size:d.size,mime_type:d.mime_type,uploaded_at:d.uploaded_at||C,chat:s}],C);return p=Y().merge(S,q).findIndex(u=>u.stored_name===d.stored_name),m}),s){let m=typeof p=="number"&&p>=0?` #${p}`:"";Je(t,"system",`file uploaded: ${d.name} as ${d.stored_name}${m}`,[],a?.turnId??"");}return {ok:true,file:d}}async function ee(t){let e=Q(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),n=r.status==="success"?r.data?.value:null,a=e.chatHandlerRef;return n==null&&(!a||typeof a!="object")?null:{ctx:e,handlerFlow:n,handlerRef:a}}async function Ze(t,e,r=false,n=""){let a=await ee(t);if(!a)return;let{ctx:s,handlerFlow:d,handlerRef:p}=a;if(!r)try{et().setChatProcessing({cardId:t,active:!0});}catch{}let m={boardId:h,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...mt,...z?{serverUrl:z}:{}},C=d!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:je}}:p;try{nt(s.boardAdapter)?await s.boardAdapter.chatAgentStore().enqueueRequest({boardId:h,ref:C,args:d!=null?{...m,__chatHandlerFlow:d}:m}):s.boardAdapter.chatAgentStore().enqueueRequest({boardId:h,ref:C,args:d!=null?{...m,__chatHandlerFlow:d}:m}),await Promise.resolve(s.boardAdapter.requestProcessAccumulated?.());}catch(S){try{et().setChatProcessing({cardId:t,active:!1});}catch{}x.warn(`[chat-handler] queue failed for card "${t}": ${S instanceof Error?S.message:String(S)}`);}}async function Xe(t,e,r){if(e.howToRun==="built-in"&&Oe(e)===je){let n=O,a=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(a,s,{boardId:h,cardId:String(s.cardId||""),label:t.label,logger:x,serverUrl:z,executionExtra:mt}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return I.invoke(e,r)}async function Ye(t,e=false){e||await ct();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?Q(r):J();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let a=await Xe(n,t.ref,t.args);if(!a.dispatched){if(r)try{P.setProcessing(r,!1);}catch{}throw new Error(a.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function tr(t,e,r){let n=e==="chat-send"?te:He,a;await n(t,s=>{let d=new Date().toISOString(),p=s.card_data&&typeof s.card_data=="object"?s.card_data:{};if(s.card_data=p,e==="chat-send"){let m=r&&typeof r.text=="string"?r.text.trim():"",C=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"",S=[];if(Array.isArray(r?.files)){for(let q of r.files)if(q){if(typeof q=="string"){S.push({name:q});continue}if(typeof q=="object"){let L=q;typeof L.name=="string"&&S.push({name:L.name,size:L.size,mime_type:L.mime_type,uploaded_at:L.uploaded_at,stored_name:L.stored_name,chat:L.chat===true});}}}if(m||S.length>0){let q=W.runBatch({cardId:t,commands:[{command:"append",role:"user",text:m,files:S,turn:C},{command:"set-processing",active:true}]});if(q.status!=="success")throw new Error(q.error);let L=q.data.results[0]?.data?.id;if(typeof L!="string"||!L)throw new Error(`chat-send did not return an append id for card ${t}`);a={cardId:t,lastEntryId:L,processingAlreadySet:true,turnId:C};try{let A=jt(t);le([{kind:"card_chats",cardId:t,messages:A.map(R=>({role:String(R.role||"system"),text:String(R.text||""),files:Array.isArray(R.files)?R.files:[]})),receiving:!0,processing:P.isProcessing(t)}]);}catch{}}return s}if(e==="file-upload"){let m=Y().normalizeIncoming(r?.files,d);return m.length>0&&Y().merge(p,m),s}if(e==="action"){let m=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!m)return s;p.lastAction={buttonId:m,at:d},p.lastActionText=`${m} @ ${d}`;}return s}),a&&Ze(a.cardId,a.lastEntryId,a.processingAlreadySet,a.turnId??"");}function w(t,e,r){let n=JSON.stringify(r),a=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...y,"Content-Type":"application/json; charset=utf-8","Content-Length":a}),t.end(n);}async function re(t,e,r){let n=await dt(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let a=Y().resolve(n.card_data,e,r);if(!a.ok&&a.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!a.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=a.file,d=tt(t),p=yt(t),m=String(s.stored_name||""),C=`${d}/${m}`,S=p.files?await p.files.getBytes(C):null;if(!S)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:S}}async function er(t,e,r,n){let{fileRecord:a,bytes:s}=await re(e,r,n),d=String(a.name||a.stored_name||"download.bin"),p=String(a.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":p,"Content-Disposition":`attachment; filename="${d}"`,"Content-Length":s.length}),t.end(s);}function rr(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 ne(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
|
|
2
|
-
`)}async function K(t){let e=[];for await(let n of t)e.push(n);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(vt(e)).trim();return r?JSON.parse(r):{}}async function nr(t){let e=[];for await(let r of t)e.push(r);return typeof Buffer<"u"?Buffer.concat(e):vt(e)}async function ae(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let n=j[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function se(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=j[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}async function ar(t,e,r){let n=String(t||"").trim();if(!n)return {statusCode:400,body:{error:"callback token is required"}};let a=e==="success"?await ae(n,r):await se(n,r);return a.status==="success"?{statusCode:200,body:a}:a.status==="fail"?{statusCode:400,body:{error:a.error}}:{statusCode:500,body:{error:a.error}}}let oe=0;function ie(t){let e=JSON.stringify(t);return oe++,`id: ${oe}
|
|
3
|
-
data: ${e}
|
|
4
|
-
|
|
5
|
-
`}function ce(t){let e=t;try{e.flushHeaders?.();}catch{}try{e.flush?.();}catch{}try{e.socket?.setNoDelay?.(!0);}catch{}try{e.socket?.uncork?.();}catch{}}function Et(t,e){let r=v.get(t);if(r&&!(e&&r.res!==e)){v.delete(t),qt();try{It?.(t);}catch{}try{r.res.end();}catch{}}}function kt(t,e){let r=v.get(t);if(!r)return;let n=ie(e);try{r.res.write(n),ce(r.res);}catch{Et(t,r.res);}}function de(t,e,r,n,a){if(!v.has(e)){w(t,404,{error:`SSE client not connected: ${e}`});return}a?Ot?.(e,r,n):B?.(e,r,n),w(t,200,{ok:true,clientId:e,channelName:r,...n.cardId?{cardId:n.cardId}:{},subscribed:a});}function $t(){let t=new Set;for(let e of v.values())for(let r of e.subscribedChatCardIds)t.add(r);return Array.from(t)}function sr(t){let e=F.has(t)?F.get(t):null,{cursor:r}=P.readAfter(t,e),n=P.isProcessing(t),a=n!==(M.get(t)??false),s=r!==e;return s&&F.set(t,r),M.set(t,n),s||a}function ue(t,e=true){let r=jt(t),n=Date.now();return {kind:"card_chats",cardId:t,sentAt:new Date(n).toISOString(),sentAtMs:n,messages:r.map(a=>({role:String(a.role||"system"),text:String(a.text||""),files:Array.isArray(a.files)?a.files:[]})),receiving:e,processing:P.isProcessing(t)}}function Ft(t,e=true){let r={kind:"notification-batch",notifications:[ue(t,e)]};for(let[n,a]of v.entries())a.subscribedChatCardIds.has(t)&&kt(n,r);}function qt(){$t().length>0||(D&&(clearInterval(D),D=null),F.clear(),M.clear());}function or(){if(D)return;let t=()=>{let e=$t();if(e.length===0){qt();return}let r=new Set(e);for(let n of Array.from(F.keys()))r.has(n)||F.delete(n);for(let n of Array.from(M.keys()))r.has(n)||M.delete(n);for(let n of e)sr(n)&&Ft(n,true);};t(),D=setInterval(t,1e3);}function ir(t,e){let r=v.get(t);if(!r)return false;r.subscribedChatCardIds.add(e);let{cursor:n}=P.readAfter(e,null);return F.set(e,n),M.set(e,P.isProcessing(e)),or(),kt(t,{kind:"notification-batch",notifications:[ue(e,true)]}),true}function cr(t,e){let r=v.get(t);return r?(r.subscribedChatCardIds.delete(e),$t().includes(e)||(F.delete(e),M.delete(e)),qt(),true):false}function dr(t){if(!t||typeof t!="object")return false;let e=t.kind;return e==="card_chats"||e==="chat_messages"}function le(t){if(!t||t.length===0)return;let e=[],r=new Set;for(let n of t)dr(n)&&typeof n.cardId=="string"?r.add(String(n.cardId)):e.push(n);if(e.length>0){let n={kind:"notification-batch",notifications:e};for(let a of v.keys())kt(a,n);}for(let n of r)Ft(n,true);}async function ur(t,e,r){let n=v.get(r),a=n?new Set(n.subscribedChatCardIds):new Set;n&&Et(r,n.res),e.writeHead(200,{...y,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),ce(e),v.set(r,{res:e,subscribedChatCardIds:a});let s=await Ct(),d=ie(s);e.write(d);try{Bt?.(r,m=>{kt(r,m);});}catch{}let p=setInterval(()=>{try{e.write(`: keepalive
|
|
6
|
-
|
|
7
|
-
`);}catch{}},15e3);t.on("close",()=>{clearInterval(p),Et(r,e);});}async function lr(t,e,r){let n=t.method||"GET",a=r,s=a.pathname;try{if(n==="GET"&&s===`${l}/init-board`)return await ct(),w(e,200,await Ct()),!0;if(n==="GET"&&s===`${l}/sse`){await ct();let i=String(a.searchParams.get("clientId")||"").trim();if(!i)return w(e,400,{error:"clientId query param is required for SSE"}),!0;await ur(t,e,i);for(let o=0;o<j.length;o++)await wt(j[o]),await Ht(j[o],o),await wt(j[o]);return !0}if(n==="GET"&&s===`${l}/board-status`)return w(e,200,await Ct()),!0;let d=s.match(new RegExp(`^${V(l)}/callback/board-worker/([^/]+)/(success|failure)$`));if(n==="POST"&&d){await ct();let i=decodeURIComponent(d[1]),o=d[2],g=await K(t),f=await ar(i,o,g);return w(e,f.statusCode,f.body),!0}if(n==="POST"&&s===`${l}/mcp`){await H();let i=await K(t),o=typeof i.tool=="string"?i.tool.trim():"",g=i.args&&typeof i.args=="object"&&!Array.isArray(i.args)?i.args:{};if(!o)return w(e,400,{error:"tool is required"}),!0;if(o==="inspect.file-contents")return w(e,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let f=await Gt(o,g,De(et()));if(f&&typeof f=="object"&&!Array.isArray(f)){let k=f;if(k.status==="fail")return w(e,400,{error:Rt(f,"Request failed")}),!0;if(k.status==="error")return w(e,500,{error:Rt(f,"Internal error")}),!0}w(e,200,f);}catch(f){let k=typeof f?.statusCode=="number"?Number(f.statusCode):500,$=f instanceof Error?f.message:String(f);w(e,k,{error:$});}return !0}if(n==="POST"&&s===`${l}/mcp-controlplane`){await H();let i=await K(t),o=typeof i.tool=="string"?i.tool.trim():"",g=i.args&&typeof i.args=="object"&&!Array.isArray(i.args)?i.args:{};if(!o)return w(e,400,{error:"tool is required"}),!0;try{let f=await Gt(o,g,Ue());if(f&&typeof f=="object"&&!Array.isArray(f)){let k=f;if(k.status==="fail")return w(e,400,{error:Rt(f,"Request failed")}),!0;if(k.status==="error")return w(e,500,{error:Rt(f,"Internal error")}),!0}w(e,200,f);}catch(f){let k=typeof f?.statusCode=="number"?Number(f.statusCode):500,$=f instanceof Error?f.message:String(f);w(e,k,{error:$});}return !0}if(n==="POST"&&s===`${l}/mcp-raw`){await H();let i=await K(t),o=typeof i.tool=="string"?i.tool.trim():"",g=i.args&&typeof i.args=="object"&&!Array.isArray(i.args)?i.args:{};if(!o)return w(e,400,{error:"tool is required"}),!0;if(o!=="inspect.file-contents")return w(e,400,{error:`Tool does not support raw response: ${o}`}),!0;let f=E(g,"card_id","cardId"),k=at(g,"file_idx","fileIdx"),$=at(g,"head-lines","headLines"),T=at(g,"tail-lines","tailLines"),N=at(g,"head-bytes","headBytes"),rt=at(g,"tail-bytes","tailBytes");if(!f)return w(e,400,{error:"inspect.file-contents requires card_id"}),!0;if(k===void 0||!Number.isInteger(k)||k<0)return w(e,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([$,T,N,rt].filter(G=>G!==void 0).length>1)return w(e,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[G,ut]of [["head-lines",$],["tail-lines",T],["head-bytes",N],["tail-bytes",rt]])if(ut!==void 0&&(!Number.isInteger(ut)||ut<0))return w(e,400,{error:`inspect.file-contents requires ${G} to be a non-negative integer`}),!0;let fe=await et().inspectFileContents({cardId:f,fileIdx:k}),fr=typeof fe?.stored_name=="string"?fe.stored_name:null,{fileRecord:Mt,bytes:gt}=await re(f,k,fr),pe=String(Mt.name||Mt.stored_name||"download.bin"),Lt=String(Mt.mime_type||"application/octet-stream"),At=(a.searchParams.get("resp")||"").trim().toLowerCase();if(At&&At!=="json-b64")return w(e,400,{error:`unsupported resp mode: ${At}`}),!0;let pr=At==="json-b64",it;if($!==void 0||T!==void 0){if(!rr(Lt))return w(e,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let G=new TextDecoder().decode(gt),ut=$!==void 0?ne(G,"head",$):ne(G,"tail",T);it=typeof Buffer<"u"?Buffer.from(ut,"utf8"):new TextEncoder().encode(ut);}else if(N!==void 0||rt!==void 0){let G=N??rt;it=N!==void 0?gt.slice(0,G):gt.slice(Math.max(0,gt.length-G));}else it=gt;if(pr){let G=typeof Buffer<"u"?Buffer.from(it).toString("base64"):btoa(String.fromCharCode(...it));return w(e,200,{bodyBase64:G,mimeType:Lt,filename:pe,byteLength:it.length}),!0}return e.writeHead(200,{"Content-Type":Lt,"Content-Disposition":`attachment; filename="${pe}"`,"Content-Length":it.length}),e.end(it),!0}let p=s.match(new RegExp(`^${V(l)}/cards/([^/]+)$`));if(n==="GET"&&p){await H();let i=decodeURIComponent(p[1]),o=await dt(i);return o?(w(e,200,o),!0):(w(e,404,{error:`card not found: ${i}`}),!0)}if(n==="PATCH"&&p){await H();let i=decodeURIComponent(p[1]),o=await K(t);return await Ve(i,o),w(e,200,{ok:!0}),!0}let m=s.match(new RegExp(`^${V(l)}/cards/([^/]+)/retrigger$`));if(n==="POST"&&m){await H();let i=decodeURIComponent(m[1]);return await Qe(i),w(e,200,{ok:!0}),!0}let C=s.match(new RegExp(`^${V(l)}/cards/([^/]+)/actions$`));if(n==="POST"&&C){await H();let i=decodeURIComponent(C[1]),o=Date.now(),g=new Date(o).toISOString(),f=await K(t),k=f?.actionType;if(k==="chat-send"&&!await ee(i)){let T=Date.now();return w(e,409,{error:`chat handler is not configured for card: ${i}`,requestReceivedAt:g,requestReceivedAtMs:o,responseSentAt:new Date(T).toISOString(),responseSentAtMs:T,responseStatus:409}),!0}if(k==="chat-send"){let T=f?.payload??{},N=typeof T["turn-id"]=="string"?T["turn-id"]:typeof T.turnId=="string"?T.turnId:typeof T.turn=="string"?T.turn:"";if(!N||!String(N).trim()){let rt=Date.now();return w(e,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${i}`,requestReceivedAt:g,requestReceivedAtMs:o,responseSentAt:new Date(rt).toISOString(),responseSentAtMs:rt,responseStatus:400}),!0}}await tr(i,k,f?.payload);let $=Date.now();return w(e,200,{ok:!0,requestReceivedAt:g,requestReceivedAtMs:o,responseSentAt:new Date($).toISOString(),responseSentAtMs:$,responseStatus:200}),!0}let S=s.match(new RegExp(`^${V(l)}/cards/([^/]+)/chats$`));if(n==="GET"&&S){await H();let i=decodeURIComponent(S[1]),o=String(a.searchParams.get("turn-id")||""),g=String(a.searchParams.get("all-turns")||"").toLowerCase()==="true",f=String(a.searchParams.get("tail-turns-before-id")||""),k=a.searchParams.get("tail-turns"),$=k==null||k===""?g||o?void 0:1:Number.parseInt(k,10),T=W.readAll({params:{cardId:i},body:{...$===void 0?{}:{tailTurns:$},...o?{turnId:o}:{},...g?{allTurns:!0}:{},...f?{tailTurnsBeforeId:f}:{}}});if(T.status!=="success")return w(e,400,{error:T.error||"Failed to read chats"}),!0;let N=T.data.records;return w(e,200,{ok:!0,messages:N}),!0}if(n==="POST"&&S){await H();let i=decodeURIComponent(S[1]),o=await K(t),g=typeof o?.role=="string"?o.role:"assistant",f=typeof o?.text=="string"?o.text:"",k=Array.isArray(o?.files)?o.files:[],$=typeof o?.turn=="string"?o.turn:typeof o?.["turn-id"]=="string"?o["turn-id"]:typeof o?.turnId=="string"?o.turnId:"",T=o?.done===!0,N=P.append(i,g,f,k,$);return T&&P.setProcessing(i,!1),Ft(i,!T),w(e,200,{ok:!0,id:N}),!0}let q=s.match(new RegExp(`^${V(l)}/cards/([^/]+)/chats/subscribe-sse$`));if(n==="POST"&&q){await H();let i=decodeURIComponent(q[1]),o=await K(t),g=typeof o?.clientId=="string"?o.clientId.trim():"";return g?ir(g,i)?(w(e,200,{ok:!0,clientId:g,cardId:i,subscribed:!0}),!0):(w(e,404,{error:`SSE client not connected: ${g}`}),!0):(w(e,400,{error:"clientId is required"}),!0)}let L=s.match(new RegExp(`^${V(l)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(n==="POST"&&L){await H();let i=decodeURIComponent(L[1]),o=await K(t),g=typeof o?.clientId=="string"?o.clientId.trim():"";return g?cr(g,i)?(w(e,200,{ok:!0,clientId:g,cardId:i,subscribed:!1}),!0):(w(e,404,{error:`SSE client not connected: ${g}`}),!0):(w(e,400,{error:"clientId is required"}),!0)}let u=s.match(new RegExp(`^${V(l)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(n==="POST"&&u){await H();let i=decodeURIComponent(u[1]),o=u[2]==="subscribe",g=await K(t),f=typeof g?.clientId=="string"?g.clientId.trim():"";return f?(de(e,f,i,{},o),!0):(w(e,400,{error:"clientId is required"}),!0)}let b=s.match(new RegExp(`^${V(l)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(n==="POST"&&b){await H();let i=decodeURIComponent(b[1]),o=decodeURIComponent(b[2]),g=b[3]==="subscribe",f=await K(t),k=typeof f?.clientId=="string"?f.clientId.trim():"";return k?(de(e,k,o,{cardId:i},g),!0):(w(e,400,{error:"clientId is required"}),!0)}let A=s.match(new RegExp(`^${V(l)}/cards/([^/]+)/files$`));if(n==="POST"&&A){await H();let i=decodeURIComponent(A[1]),o=String(a.searchParams.get("inChat")||"").toLowerCase()==="true",g=String(a.searchParams.get("turn-id")||"").trim();if(o&&!g)return w(e,400,{error:`file upload with inChat=true requires a non-empty 'turn-id' query parameter for card: ${i}`}),!0;let f=t.headers["x-file-name"],k=String(t.headers["content-type"]||"application/octet-stream"),$=Array.isArray(f)?f[0]:f,T=$?decodeURIComponent(String($)):"upload.bin",N=await nr(t);return w(e,200,await Tt(i,T,k,N,{inChat:o,turnId:g})),!0}let R=s.match(new RegExp(`^${V(l)}/cards/([^/]+)/files/(\\d+)$`));if(n==="GET"&&R){let i=decodeURIComponent(R[1]),o=parseInt(R[2],10),g=a.searchParams.get("sn");return await er(e,i,o,g),!0}return !1}catch(d){let p=d?.statusCode||500;return w(e,p,{error:String(d?.message||d)}),true}}return {get apiBasePath(){return l},get corsHeaders(){return y},get queueLaneTuning(){return _},handleRuntimeApi:lr,buildPublishedRuntimePayload:Ct,processAccumulatedEvents:$e,processAccumulatedLane:xt,handleChatAgentRequest:Ye,clearChatRecords:ze,reportSourceFetched(t,e){return ae(t,{ref:e})},reportSourceFetchFailure(t,e){return se(t,{reason:e})},get cardStore(){return j[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Mr(c){let l=String(c.apiBasePath||"/api/boards").replace(/\/$/,""),y={...Te,...c.corsHeaders||{}},_=c.serverMetaStore,h=c.boardRuntimeFactory,x=new Map,I="boards-config.json";function O(){let B=_.getText(I);if(!B)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(B)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function P(B){_.putText(I,JSON.stringify(B,null,2));}function W(B){let v=String(B||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return v.length>0&&v.length<=64?v:null}function ot(B){if(x.has(B))return x.get(B);let F=O().boards.find(D=>D.id===B)||{},M=h(B,F);return x.set(B,M),M}function z(B,v,F){let M=JSON.stringify(F),D=typeof Buffer<"u"?Buffer.byteLength(M):new TextEncoder().encode(M).length;B.writeHead(v,{...y,"Content-Type":"application/json; charset=utf-8","Content-Length":D}),B.end(M);}async function mt(B,v,F){let M=B.method||"GET",D=F.pathname;if(M==="GET"&&D===l)return z(v,200,{ok:true,boards:O().boards}),true;if(M==="POST"&&D===l){let Z=[];for await(let tt of B)Z.push(tt);let j=typeof Buffer<"u"?Buffer.concat(Z).toString("utf-8").trim():new TextDecoder().decode(vt(Z)).trim(),U={};try{U=j?JSON.parse(j):{};}catch{U={};}let X=W(U.id);if(!X)return z(v,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let ft=O();if(ft.boards.some(tt=>tt.id===X))return z(v,409,{error:`Board "${X}" is already registered`}),true;let yt=typeof U.label=="string"&&U.label.trim()?U.label.trim():X,Y={id:X,label:yt};for(let[tt,pt]of Object.entries(U))tt==="id"||tt==="label"||pt!=null&&(Y[tt]=pt);return ft.boards.push(Y),P(ft),z(v,200,{ok:true,board:Y}),true}return false}async function Bt(B,v,F){let D=F.pathname.match(new RegExp(`^${V(l)}/([^/]+)(/|$)`));if(!D)return false;let Z=W(decodeURIComponent(D[1]));return Z?O().boards.some(X=>X.id===Z)?!!await ot(Z).handleRuntimeApi(B,v,F):(z(v,404,{error:`Board "${Z}" not registered. POST ${l} with {id} to register it first.`}),true):(z(v,400,{error:"Invalid board id"}),true)}async function It(B,v,F){return !!(await mt(B,v,F)||await Bt(B,v,F))}function Ot(B){if(!O().boards.some(F=>F.id===B))throw Object.assign(new Error(`Board "${B}" not registered`),{statusCode:404});return {service:ot(B)}}return {get apiBasePath(){return l},get corsHeaders(){return y},handleApi:It,requireBoardService:Ot}}exports.a=kr;exports.b=qr;exports.c=Mr;//# sourceMappingURL=chunk-KQX6R4PV.cjs.map
|
|
8
|
-
//# sourceMappingURL=chunk-KQX6R4PV.cjs.map
|
package/lib/chunk-OSWJKJLB.js
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import {f,b,c as c$1,e}from'./chunk-MLVTJASJ.js';import {j,d,c,b as b$1}from'./chunk-VMW4Z6EF.js';import {y,z,l}from'./chunk-N6P2JW4W.js';import {b as b$2}from'./chunk-BQS3EIEK.js';import {a as a$2}from'./chunk-SCWHDI3I.js';import {a as a$1}from'./chunk-KBELAKIY.js';import {a}from'./chunk-76ON3V7R.js';function Ie(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Nt(c){if(!c||typeof c!="object")return false;let l=c.summary;return !l||typeof l!="object"?false:Number(l.card_count||0)>0}function Dt(c,l){if(!l||typeof l!="object")return;let y=l;if(y.kind==="notification-batch"&&Array.isArray(y.notifications)){for(let _ of y.notifications)Dt(c,_);return}y.kind==="status"&&Nt(y.status)&&(c.status=y.status),y.kind==="computed_values"&&y.cardId&&(c.computedValues[y.cardId]=y.values),y.kind==="data_object"&&y.key&&(c.dataObjects[y.key]=y.payload),y.kind==="card_refreshed"&&y.cardId&&(c.cards[y.cardId]=y.card),y.kind==="card_removed"&&y.cardId&&(delete c.cards[y.cardId],delete c.computedValues[y.cardId]);}function nt(c){return typeof c.journalStorage=="function"}function Oe(c){return typeof c.whatToRun=="string"?c.whatToRun.startsWith("b64:")?b$2(c.whatToRun).value:c.whatToRun:c.whatToRun.value}function V(c){return c.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function vt(c){let l=c.reduce((h,x)=>h+x.length,0),y=new Uint8Array(l),_=0;for(let h of c)y.set(h,_),_+=h.length;return y}function E(c,...l){for(let y of l)if(typeof c[y]=="string")return String(c[y]);return ""}function at(c,...l){for(let y of l)if(c[y]!==void 0)return Number(c[y])}function lt(c,...l){for(let y of l){let _=c[y];if(_&&typeof _=="object"&&!Array.isArray(_))return _}return {}}function st(c,l,...y){for(let _ of y){let h=c[_];if(h&&typeof h=="object"&&!Array.isArray(h))return h}throw Object.assign(new Error(`MCP tool requires ${l}`),{statusCode:400})}function _t(c,l,...y){for(let _ of y){let h=c[_];if(h!==void 0){let x=Number(h);if(Number.isFinite(x))return x}}throw Object.assign(new Error(`MCP tool requires ${l}`),{statusCode:400})}function xe(c){if(Array.isArray(c.bytes))return new Uint8Array(c.bytes.map(l=>Math.max(0,Math.min(255,Number(l)||0))));if(typeof c.text=="string")return new TextEncoder().encode(c.text);if(typeof c.base64=="string"){let l=String(c.base64).replace(/-/g,"+").replace(/_/g,"/"),y=l+"=".repeat((4-l.length%4)%4),_=atob(y);return Uint8Array.from(_,h=>h.charCodeAt(0))}return null}function Ut(c,l){return l?{...c,...l.pollIntervalMs!=null?{pollIntervalMs:l.pollIntervalMs}:{},...l.visibilityMs!=null?{visibilityMs:l.visibilityMs}:{},...l.concurrency!=null?{concurrency:l.concurrency}:{},...l.maxAttempts!=null?{maxAttempts:l.maxAttempts}:{}}:c}function Pe(c,l,y,_){return {id:c,async lease(h){return (await Promise.resolve(l.leaseRequests(h))).map(I=>({id:I.messageId,attempt:I.attempt,message:I.request,ack:()=>Promise.resolve(l.ackRequest(I.messageId,I.leaseToken)),nack:O=>Promise.resolve(l.nackRequest(I.messageId,I.leaseToken,O))}))},async handle(h){await y(h.args,h);},onError:_?(h,x)=>_(h,x.attempt,x.message):void 0}}function gr(c,l,y,_){return {id:c,async lease(h){return (await Promise.resolve(l.lease(h))).map(I=>({id:I.id,attempt:I.attempt,message:I.body,ack:()=>Promise.resolve(l.ack(I.id,I.leaseToken)),nack:O=>Promise.resolve(l.nack(I.id,I.leaseToken,O))}))},async handle(){await y();},onError:_?(h,x)=>_(h,x.attempt):void 0}}function kr(c){let l=c.logger??{info(){},warn(){},error(){}},y=c.boardAdapter,_=c.runtime.queueLaneTuning??{},h=y.processAccumulatedStore(),x=y.chatAgentStore(),I=[];if(I.push(Ut(gr("process-accumulated",h,async()=>{let O=await c.runtime.processAccumulatedLane();if(O.status!=="success")throw new Error(O.error||`processAccumulatedLane returned ${O.status}`)},(O,P)=>{l.error(`[board-server] queued process-accumulated failed for ${c.boardId} (attempt ${P}): ${String(O&&O.message||O)}`);}),_.processAccumulated)),I.push(Ut(Pe("chat-agent",x,async(O,P)=>{await c.runtime.handleChatAgentRequest(P);},(O,P,W)=>{let ot=typeof W.args?.cardId=="string"?W.args.cardId:"";l.error(`[board-server] queued chat-agent failed for ${c.boardId}${ot?`/${ot}`:""} (attempt ${P}): ${String(O&&O.message||O)}`);}),_.chatAgent)),c.executeTaskExecutorRequest){let O=y.boardWorkerStore();I.push(Ut(Pe("task-executor",O,c.executeTaskExecutorRequest,(P,W)=>{l.error(`[board-server] queued board-worker failed for ${c.boardId} (attempt ${W}): ${String(P&&P.message||P)}`);}),_.taskExecutor));}return f(I)}var Te={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},je="chat-handler-flow-queue";function qr(c$2){let l$1=String(c$2.apiBasePath||"/api/board").replace(/\/$/,""),y$1={...Te,...c$2.corsHeaders||{}},_=c$2.queueLaneTuning??{},h=c$2.boardId||"",x=c$2.logger||{info:console.log,warn:console.warn,error:console.error},I=c$2.invocationAdapter,O=c$2.chatFlowRunner||null,P=c$2.chatStorage??b(),W=a(P),ot=c$2.notificationTransport||null,z$1=c$2.serverUrl||null,mt=c$2.executionExtra||{},Bt=c$2.onSseClientConnected,It=c$2.onSseClientDisconnected,Ot=c$2.onChannelSubscribed,B=c$2.onChannelUnsubscribed,v=new Map,F=new Map,M=new Map,D=null;function Z(t){function e(u){if(Array.isArray(u))return u;if(u&&typeof u=="object"){let b=u;return Array.isArray(b.files)?b.files:[u]}return null}function r(u){return {async get(b){return u.get(b)},async set(b){return u.set(b)},async del(b){return u.del(b)},async patch(b){return u.patch(b)},async appendFiles(b){return u.appendFiles(b)}}}function n(u){function b(i){return {status:"success",data:i}}function A(i){return {status:"fail",error:i}}function R(i){return {status:"error",error:i instanceof Error?i.message:String(i)}}return {async get(i){try{let o=i.params?.id;if(o){let g=await u.readCard(o);return g?b({cards:[g]}):A(`card "${o}" not found`)}return b({cards:await u.readAllCards()})}catch(o){return R(o)}},async set(i){try{let o=i.body;if(o==null)return A("set requires a body (card object or array of cards)");let g=Array.isArray(o)?o:[o];for(let f of g){if(typeof f.id!="string")return A("each card must have a string `id` field");await u.writeCard(f.id,f);}return b({count:g.length})}catch(o){return R(o)}},async del(i){try{let o=i.body?.ids??[],g=i.params?.id,f=g?[...o,g]:o;if(f.length===0)return A("del requires body.ids (string[]) or params.id");for(let k of f)await u.removeCard(k);return b({count:f.length})}catch(o){return R(o)}},async patch(i){try{let o=i.params?.id,g=i.params?.path;if(!o)return A("patch requires params.id");if(!g)return A("patch requires params.path");let f=i.body,k=f&&Object.prototype.hasOwnProperty.call(f,"value")?f.value:i.body;return await u.patchCard(o,g,k),b({count:1})}catch(o){return R(o)}},async appendFiles(i){try{let o=i.params?.id;if(!o)return A("appendFiles requires params.id");let g=await u.readCard(o);if(!g)return A(`card "${o}" not found`);let f=e(i.body);if(!f||f.length===0)return A("appendFiles requires a file metadata object, array, or body.files array");let k=g.card_data&&typeof g.card_data=="object"&&!Array.isArray(g.card_data)?g.card_data:{},$=Array.isArray(k.files)?k.files:[],T=[...$,...f];return await u.patchCard(o,"card_data.files",T),b({files_added:f.map((N,rt)=>({idx:$.length+rt,entry:N}))})}catch(o){return R(o)}}}}let a=nt(t.boardAdapter)?j(t.baseRef,t.boardAdapter):y(t.baseRef,t.boardAdapter),s=t.nonCoreAdapter??(!nt(t.boardAdapter)&&ft(t.boardAdapter)?t.boardAdapter:null),d$1=s?z(t.baseRef,s):null,p,m=nt(t.boardAdapter)?(()=>{let u=d(c(b$1(t.boardAdapter.kvStorageForRef(t.cardStoreRef)),t.boardAdapter.hashFn),x.warn),b=n(u);return p={get(A){return b.get(A)},set(A){return b.set(A)}},b})():(()=>{let u=t.boardAdapter.kvStorageForRef(t.cardStoreRef),A=a$1(l({readIndex:()=>u.read("_index"),writeIndex:R=>u.write("_index",R),readCard:R=>u.read(R),writeCard:(R,i)=>(u.write(R,i),R),removeCard:R=>{u.delete(R);},cardExists:R=>u.read(R)!==null,defaultCardKey:R=>R},x.warn));return p=A,r(A)})(),C=t.artifactsAdapter||t.boardAdapter,S=t.filesArtifactsStore??null,q=S?{putBytes(u,b,A){S.putBytes(u,b,A);},getBytes(u){return S.getBytes(u)},listKeys(u){return S.list(u).map(b=>b.key)}}:null;if(!q&&!nt(C)){let u=t.artifactsAdapter?C.blobStorage(""):C.blobStorage("files"),b=c$1(u);q={putBytes(A,R,i){b.putBytes(A,R,i);},getBytes(A){return b.getBytes(A)},listKeys(A){return b.list(A).map(R=>R.key)}};}else if(!q&&nt(C)){let u=t.artifactsAdapter?C.blobStorage(""):C.blobStorage("files");q={async putBytes(b,A){if(u.writeBytes){await u.writeBytes(b,A);return}let R=JSON.stringify({__kind:"bytes-array",data:[...A]});await u.write(b,R);},async getBytes(b){if(u.readBytes){let R=await u.readBytes(b);if(R!==null)return R}let A=await u.read(b);if(A===null)return null;try{let R=JSON.parse(A);if(R&&R.__kind==="bytes-array"&&Array.isArray(R.data))return new Uint8Array(R.data)}catch{}return new TextEncoder().encode(A)},async listKeys(b){return await u.listKeys(b)}};}let L={async init(u){return a.init(u)},async status(u){return a.status(u)},async getConfig(u){return a.getConfig(u)},async getAllOutputsDataObjects(u){return a.getAllOutputsDataObjects(u)},async getAllOutputsComputedValues(u){return a.getAllOutputsComputedValues(u)},async getOutputsFetchedSources(u){return a.getOutputsFetchedSources(u)},async upsertCard(u){return a.upsertCard(u)},async removeCard(u){return a.removeCard(u)},async cardRefreshedNotify(u){return a.cardRefreshedNotify(u)},async sourceDataFetched(u){return a.sourceDataFetched(u)},async sourceDataFetchFailure(u){return a.sourceDataFetchFailure(u)}};return {label:t.label,board:a,nonCore:d$1,publicCardStore:p,boardOps:L,cardStoreOps:m,get filesArtifacts(){return q},boardAdapter:t.boardAdapter,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,scratchStoreRef:t.scratchStoreRef,archiveStoreRef:t.archiveStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:Ie(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let j$1=c$2.boards.map(Z),U=new Map;function X(t){return U.get(t)??0}function ft(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function yt(t){let e=j$1[X(t)];return {files:e?e.filesArtifacts:null}}function Y(){return e()}function tt(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function pt(t){if(!t||t.notificationTeardown||!ot||!t.notifyRef)return;let e=await ot.subscribe(t.notifyRef,r=>{Dt(t.notification,r);let n=r.kind==="notification-batch"?r.notifications:[r];le(n);});t.notificationTeardown=e;}async function Ee(t){if(!t||t.initialized)return;let e={cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef};t.artifactsStoreRef&&(e.artifactsStoreRef=t.artifactsStoreRef),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 n=await t.boardOps.init({params:e,body:r});if(n.status!=="success")throw Object.assign(new Error(n.error||`init failed for ${t.label}`),{statusCode:500});if(await pt(t),!t.chatHandlerFlow&&t.chatHandlerRef&&I.describe)try{let a=await I.describe(t.chatHandlerRef);a&&a.kind!=="chat-handler"?x.warn(`[init] chat-handler describe returned kind="${a.kind}", expected "chat-handler" for ${t.label}`):a&&x.info(`[init] chat-handler validated: ${a.name} (protocol ${a.protocolVersion}) for ${t.label}`);}catch(a){x.warn(`[init] chat-handler describe failed for ${t.label}: ${a?.message||String(a)}`);}t.initialized=true;}async function wt(t){if(!t.boardAdapter.publishBoardChangeNotifications)return;let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&Nt(r.data)&&e.push({kind:"status",status:r.data});let n=await t.boardOps.getAllOutputsDataObjects({});if(n.status==="success"&&n.data!=null)for(let[s,d]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:d});let a=await t.boardOps.getAllOutputsComputedValues({});if(a.status==="success"&&a.data!=null)for(let[s,d]of Object.entries(a.data))s&&e.push({kind:"computed_values",cardId:s,values:d});e.length>0&&t.boardAdapter.publishBoardChangeNotifications(e);}async function Ht(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),n=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let a of n)typeof a.id=="string"&&(U.set(a.id,e),await t.boardOps.upsertCard({params:{cardId:a.id}}));t.cardsBootstrapped=true;}async function ct(){for(let t of j$1)await Ee(t);}async function H(){await ct();for(let t=0;t<j$1.length;t++)await wt(j$1[t]),await Ht(j$1[t],t),await wt(j$1[t]);}async function xt(t=false){t||await ct();for(let e of j$1){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}async function $e(){return await ct(),xt(true)}function Q(t){return j$1[X(t)]??null}async function dt(t){let e=Q(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function Qt(){let t=async r=>{if(!r)return [];let n=await r.cardStoreOps.get({});return n.status!=="success"||!Array.isArray(n.data?.cards)?[]:n.data.cards},e=[];for(let r of j$1)e.push(...await t(r));return e}function J(){return j$1[0]??null}function Fe(){return {async status(){let t=await Zt();return t==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:t}},async getOutputsDataObject(t){let e=t?.params?.key;return e?{status:"success",data:(await Yt())[e]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(t){let e=t?.params?.key;return e?{status:"success",data:(await Xt())[e]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(t){let e=t?.params?.key;if(!e)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let r=Q(e)??J();return r?r.boardOps.getOutputsFetchedSources({params:{key:e}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(t){let e=t?.params?.id;if(!e)return {status:"fail",error:"removeCard requires params.id"};let r=Q(e)??J();return r?r.boardOps.removeCard({params:{id:e}}):{status:"fail",error:"Board context is unavailable"}},async cardRefreshedNotify(t){let e=t?.params?.cardId;if(!e)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let r=Q(e)??J();return r?r.boardOps.cardRefreshedNotify({params:{cardId:e}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(t){let e=t?.params?.cardId;if(!e)return {status:"fail",error:"upsertCard requires params.cardId"};let r=Q(e)??J();if(!r)return {status:"fail",error:"Board context is unavailable"};let n=await r.boardOps.upsertCard({params:{cardId:e,restart:t.params.restart===true}});if(n.status!=="success")return n;if(nt(r.boardAdapter)){let a=await xt(true);if(a.status!=="success")return a}return n}}}function qe(){let t=()=>{let e=J();if(!e?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return e.nonCore};return {describeTaskExecutorCapabilities(e){return t().describeTaskExecutorCapabilities(e)},validateCardPreflight(e){return t().validateCardPreflight(e)},evalCardCompute(e){return t().evalCardCompute(e)},probeSourcePreflight(e){return t().probeSourcePreflight(e)},runSourcePreflight(e){return t().runSourcePreflight(e)},simulateCardCycle(e){return t().simulateCardCycle(e)}}}function bt(){return {async get(t){let e=typeof t.params?.id=="string"?t.params.id:void 0;if(e){let r=await dt(e);return r?{status:"success",data:{cards:[r]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await Qt()}}},async set(t){let e=t.body;if(e==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let r=Array.isArray(e)?e:[e];for(let n of r){let a=n,s=typeof a.id=="string"?a.id:"";if(!s)return {status:"fail",error:"each card must have a string `id` field"};let d=U.get(s)??0,p=j$1[d]??J();if(!p)return {status:"fail",error:"Board context is unavailable"};let m=await p.cardStoreOps.set({body:a});if(m.status!=="success")return m;U.set(s,d);}return {status:"success",data:{count:r.length}}},async del(t){let e=[t.params?.id,...t.body?.ids??[]].filter(r=>typeof r=="string"&&!!r);if(e.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let r of e){let n=Q(r)??J();if(!n)return {status:"fail",error:"Board context is unavailable"};let a=await n.cardStoreOps.del({params:{id:r}});if(a.status!=="success")return a;U.delete(r);}return {status:"success",data:{count:e.length}}},async patch(t){let e=typeof t.params?.id=="string"?t.params.id:void 0,r=typeof t.params?.path=="string"?t.params.path:void 0;if(!e||!r)return {status:"fail",error:"patch requires params.id and params.path"};let n=Q(e)??J();return n?n.cardStoreOps.patch(t):{status:"fail",error:"Board context is unavailable"}},async appendFiles(t){let e=typeof t.params?.id=="string"?t.params.id:void 0;if(!e)return {status:"fail",error:"appendFiles requires params.id"};let r=Q(e)??J();return r?r.cardStoreOps.appendFiles(t):{status:"fail",error:"Board context is unavailable"}}}}function et(){return a$2({board:Fe(),nonCore:qe(),cardStore:bt(),chatStore:W,uploadCardFile({cardId:t,fileName:e,contentType:r,bytes:n}){return Tt(t,e,r,n,{inChat:false})},buildFileDownloadUrl({cardId:t,fileIdx:e,storedName:r}){let n=`${z$1||""}${l$1}/cards/${encodeURIComponent(t)}/files/${e}`;return r?`${n}?sn=${encodeURIComponent(r)}`:n},readFetchedSourceJsonByRef({cardId:t,ref:e}){let r=Q(t)??J();if(!r||nt(r.boardAdapter))return null;let a=r.boardAdapter.resolveBlob(b$2(e)).trim();return a?JSON.parse(a):null}})}function Vt(t,e){let r=E(t,"board_id"),n=E(t,"card_id");if(!r)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(!n)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});if(r!==h)throw Object.assign(new Error(`Unknown board_id: ${r}`),{statusCode:400});return et().setChatProcessing({cardId:n,active:e}),{status:"success",data:{boardId:h,cardId:n,active:e}}}function ht(t){let e=E(t,"board_id"),r=E(t,"card_id");if(!e)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(!r)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});if(e!==h)throw Object.assign(new Error(`Unknown board_id: ${e}`),{statusCode:400});return {cardId:r}}function Wt(t,e){if(t?.status==="success")return Object.prototype.hasOwnProperty.call(t,"data")?t.data:void 0;throw t?.status==="fail"||t?.status==="error"?Object.assign(new Error(t.error||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function zt(t,e){return Wt(await t,e)}function Jt(t){let e=E(t,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let r=e.split(".");if(!(r.length>=2&&r[0]==="chat"&&r.every(a=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(a))))throw Object.assign(new Error("MCP tool only supports card meta keys under chat.*"),{statusCode:400});return e}function Kt(t,e){let r=t.meta;for(let n of e.split(".")){if(!r||typeof r!="object"||Array.isArray(r)||!Object.prototype.hasOwnProperty.call(r,n))return {exists:false,value:null};r=r[n];}return {exists:true,value:r}}function Me(t){let{cardId:e}=ht(t),r=et().getChatProcessing({cardId:e});return {status:"success",data:{boardId:h,cardId:e,active:r.active}}}async function Le(t){let{cardId:e}=ht(t),r=Jt(t);if(!Object.prototype.hasOwnProperty.call(t,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(r.split(".").includes("__visible_controlplane_only")){let n=await zt(bt().get({params:{id:e}}),"cardStore.get"),a=Array.isArray(n.cards)&&n.cards.length>0&&typeof n.cards[0]=="object"&&!Array.isArray(n.cards[0])?n.cards[0]:null,s=a?Kt(a,"__visible_controlplane_only").value:void 0;if(t.value!==s)throw Object.assign(new Error("MCP tool cannot change the reserved meta flag __visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:h,cardId:e,key:r}}}return Wt(await bt().patch({params:{id:e,path:`meta.${r}`},body:{value:t.value}}),"cardStore.patch"),{status:"success",data:{boardId:h,cardId:e,key:r}}}async function Ne(t){let{cardId:e}=ht(t),r=Jt(t),n=await zt(bt().get({params:{id:e}}),"cardStore.get"),a=Array.isArray(n.cards)&&n.cards.length>0&&n.cards[0]&&typeof n.cards[0]=="object"&&!Array.isArray(n.cards[0])?n.cards[0]:null;if(!a)throw Object.assign(new Error(`Card "${e}" not found`),{statusCode:404});let s=Kt(a,r);return {status:"success",data:{boardId:h,cardId:e,key:r,exists:s.exists,value:s.value}}}function De(t){return {"discover.source-kinds":()=>t.discoverSourceKinds(),"inspect.board-runtime-status":()=>t.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>t.inspectCardDefinitionAndRuntime({cardId:E(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let r=at(e,"tail_turns"),n=at(e,"tail"),a=E(e,"turn_id"),s=e.all_turns===true,d=E(e,"tail_turns_before_id");return t.inspectChatMessagesOnCards({cardId:E(e,"card_id"),...r!==void 0?{lastUserTurns:r}:{},...n!==void 0?{tail:n}:{},...a?{turnId:a}:{},...s?{allTurns:true}:{},...d?{tailTurnsBeforeId:d}:{}})},"inspect.file-contents":e=>t.inspectFileContents({cardId:E(e,"card_id"),fileIdx:Number(at(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>t.preflightValidateCandidateCardDefinition({candidateCardContent:st(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>t.preflightMaterializeCandidateCard({candidateCardContent:st(e,"candidate_card_content","candidate_card_content"),mockRequires:st(e,"mock_requires","mock_requires"),mockFetchedSources:st(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e=>t.preflightProbeSingleSourceInCandidateCard({candidateCardContent:st(e,"candidate_card_content","candidate_card_content"),mockProjections:lt(e,"mock_projections"),sourceIdx:_t(e,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e=>t.preflightRunSingleSourceInCandidateCard({candidateCardContent:st(e,"candidate_card_content","candidate_card_content"),mockProjections:lt(e,"mock_projections"),sourceIdx:_t(e,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e=>t.preflightRunSingleSourceInLiveCard({cardId:E(e,"card_id"),sourceIdx:_t(e,"source_idx","source_idx"),mockRequires:st(e,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>t.preflightRunOneCycleWithCandidateCard({candidateCardContent:st(e,"candidate_card_content","candidate_card_content"),mockRequires:lt(e,"mock_requires")}),"manage.read-card":e=>t.manageReadCard({cardId:E(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let r=E(e,"turn_id");if(!r)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return t.manageAddChatEntryAndAnyAttachments({cardId:E(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...r?{turn:r}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"manage.upsert-card":e=>t.manageUpsertCard({cardId:E(e,"card_id"),candidateCardContent:lt(e,"candidate_card_content")}),"manage.remove-card":e=>t.manageRemoveCard({cardId:E(e,"card_id")})}}function Ue(){return {"getstate.is-chat-processing":t=>Me(t),"setstate.chat-processing-started":t=>Vt(t,true),"setstate.chat-processing-done":t=>Vt(t,false),"getstate.card-meta":t=>Ne(t),"setstate.card-meta":t=>Le(t),"manage.upload-card-file":t=>{let e=E(t,"board_id"),r=E(t,"card_id"),n=E(t,"file_name"),a=E(t,"content_type")||"application/octet-stream",s=xe(t);if(!e)throw Object.assign(new Error("manage.upload-card-file requires board_id"),{statusCode:400});if(e!==h)throw Object.assign(new Error(`Unknown board_id: ${e}`),{statusCode:400});if(!r)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!n)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!s)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return Tt(r,n,a,s,{inChat:false})},"manage.admin-read-card":async t=>{let{cardId:e}=ht(t);return {status:"success",data:{cards:await et().adminReadCard({cardId:e})}}},"manage.admin-upsert-card":t=>{let e=E(t,"board_id"),r=E(t,"card_id");if(!e)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!r)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(e!==h)throw Object.assign(new Error(`Unknown board_id: ${e}`),{statusCode:400});return et().adminUpsertCard({cardId:r,candidateCardContent:lt(t,"candidate_card_content")})}}}async function Gt(t,e,r){let n=r[t];if(!n)throw Object.assign(new Error(`Unknown MCP tool: ${t}`),{statusCode:400});let a=await n(e);if(a&&typeof a=="object"&&!Array.isArray(a)){let s=a,d=s.status;if(d==="success")return Object.prototype.hasOwnProperty.call(s,"data")?a:{status:"success",data:{}};if(d==="fail"||d==="error")return a}return {status:"success",data:a}}function Rt(t,e){if(!t||typeof t!="object"||Array.isArray(t))return e;let r=t;if(typeof r.error=="string"&&r.error.trim())return r.error;if(r.step==="validate"){let n=r.validation;if(n&&typeof n=="object"&&!Array.isArray(n)){let s=n.data;if(s&&typeof s=="object"&&!Array.isArray(s)){let d=s.issues;if(Array.isArray(d)){let m=d.find(C=>typeof C=="string"&&C.trim());if(typeof m=="string")return `Validation failed: ${m}`}let p=s.errors;if(Array.isArray(p)&&p.length>0)return "Validation failed"}}return "Validation failed"}return e}async function Zt(){let t=(await Promise.all(j$1.map(async s=>{try{let d=s.boardAdapter.kvStorageForRef(s.outputsStoreRef),p=await Promise.resolve(d.read("status"));if(p!=null)return p}catch{}return s.notification.status}))).filter(Boolean);if(t.length===0)return null;if(t.length===1)return t[0];let e=[],r=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],n={};for(let s of r)n[s]=0;for(let s of t){let d=s,p=Array.isArray(d.cards)?d.cards:[];e.push(...p);for(let m of r)n[m]+=Number(d?.summary?.[m]||0);}let a=t[0];return {...a,cards:e,summary:{...a.summary||{},card_count:e.length,...n}}}async function Xt(){let t={},e=async r=>{try{let n=await r.boardOps.getAllOutputsComputedValues({});if(n.status==="success"&&n.data&&typeof n.data=="object"){for(let[a,s]of Object.entries(n.data)){let d=r.notification.cards[a];t[a]={schema_version:"v1",card_id:a,card_data:d?.card_data??{},computed_values:s??{}};}return}}catch{}for(let[n,a]of Object.entries(r.notification.computedValues)){let s=r.notification.cards[n];t[n]={schema_version:"v1",card_id:n,card_data:s?.card_data??{},computed_values:a??{}};}};for(let r of j$1)await e(r);return t}async function Yt(){let t={};for(let e of j$1){try{let r=await e.boardOps.getAllOutputsDataObjects({});if(r.status==="success"&&r.data&&typeof r.data=="object"){Object.assign(t,r.data);continue}}catch{}Object.assign(t,e.notification.dataObjects||{});}return t}async function Ct(){let t=await Qt(),e=await Xt(),r=await Yt(),n={};for(let s of t){if(!s?.id)continue;let d=s.id,p=e[d]||{},m={...p.card_data&&typeof p.card_data=="object"?p.card_data:s.card_data&&typeof s.card_data=="object"?s.card_data:{}};n[d]={schema_version:p.schema_version||"v1",card_id:p.card_id||d,card_data:m,computed_values:p.computed_values&&typeof p.computed_values=="object"?p.computed_values:{}};}let a={};for(let s of t){if(!s?.id)continue;let d=s.id;try{let p=jt(d),m=et().getChatProcessing({cardId:d}).active;(p.length>0||m)&&(a[d]={messages:p.map(C=>({role:String(C.role||"system"),text:String(C.text||""),files:Array.isArray(C.files)?C.files:[]})),receiving:!1,processing:m});}catch{}}return {boardId:h,cardDefinitions:t,statusSnapshot:await Zt(),dataObjectsByToken:r,cardRuntimeById:n,cardChatsByCardId:a}}async function Pt(t,e,r){let n=r?.syncBoard!==false,a=r?.restartOnlyIfChanged===true,s=Q(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let d=await dt(t);if(!d)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let p=a?JSON.stringify(d):null,m=e(d)||d;if(a&&JSON.stringify(m)===p)return;let C=await s.cardStoreOps.set({body:m});if(C.status!=="success")throw Object.assign(new Error(C.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let S=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(S.status!=="success")throw Object.assign(new Error(S.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function He(t,e){await Pt(t,e,{syncBoard:true});}async function te(t,e){await Pt(t,e,{syncBoard:false});}async function Qe(t){let e=Q(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await dt(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let n=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function Ve(t,e){await Pt(t,r=>{if(!e||typeof e!="object"||Object.keys(e).length===0)return r;function n(a,s,d){let p=String(s||"").split(".").filter(Boolean);if(!p.length)return;let m=a;for(let C=0;C<p.length-1;C++){let S=p[C];(!m[S]||typeof m[S]!="object")&&(m[S]={}),m=m[S];}m[p[p.length-1]]=d;}if(e.fieldValues!==void 0&&e.fieldValues!==null){let a=null,s=r.view;if(s&&Array.isArray(s.elements)){for(let d of s.elements)if(d?.data&&d.data.writeTo){a=d.data.writeTo;break}}a?n(r,a,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[a,s]of Object.entries(e))a!=="_stagedFiles"&&(s!==null&&typeof s=="object"&&!Array.isArray(s)&&r[a]!==null&&typeof r[a]=="object"&&!Array.isArray(r[a])?r[a]={...r[a],...s}:r[a]=s);}return r},{syncBoard:true,restartOnlyIfChanged:true});}function We(t){let e=String(t||"").trim();if(!e)return "upload.bin";let r=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (r>=0?e.slice(r+1):e)||"upload.bin"}function ze(t){P.clear(t);try{et().setChatProcessing({cardId:t,active:!1});}catch{}}function Je(t,e,r,n,a=""){let s=typeof r=="string"?r.trim():"";return P.append(t,e,s,n,a)}function jt(t){return P.readAll(t)}async function Ke(t){let e=[];try{let r=await dt(t);if(!r)return e;let n=Y().read(r.card_data&&typeof r.card_data=="object"?r.card_data:null);for(let a of n)e.push(a.stored_name);}catch{}return e}async function Ge(t,e,r,n){let a=tt(t),s=yt(t),d=We(e),p=await Ke(t),C=`${String(p.length+1).padStart(3,"0")}-${d}`.slice(-36);return s.files&&await s.files.putBytes(`${a}/${C}`,new Uint8Array(n),r||"application/octet-stream"),{name:d,stored_name:C,size:n.length,mime_type:r||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function Tt(t,e,r,n,a){if(!n.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let s=a?.inChat===true,d=await Ge(t,e,r,n),p=null;if(await te(t,m=>{let C=new Date().toISOString(),S=m.card_data&&typeof m.card_data=="object"?m.card_data:{};m.card_data=S;let q=Y().normalizeIncoming([{name:d.name,stored_name:d.stored_name,size:d.size,mime_type:d.mime_type,uploaded_at:d.uploaded_at||C,chat:s}],C);return p=Y().merge(S,q).findIndex(u=>u.stored_name===d.stored_name),m}),s){let m=typeof p=="number"&&p>=0?` #${p}`:"";Je(t,"system",`file uploaded: ${d.name} as ${d.stored_name}${m}`,[],a?.turnId??"");}return {ok:true,file:d}}async function ee(t){let e=Q(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),n=r.status==="success"?r.data?.value:null,a=e.chatHandlerRef;return n==null&&(!a||typeof a!="object")?null:{ctx:e,handlerFlow:n,handlerRef:a}}async function Ze(t,e,r=false,n=""){let a=await ee(t);if(!a)return;let{ctx:s,handlerFlow:d,handlerRef:p}=a;if(!r)try{et().setChatProcessing({cardId:t,active:!0});}catch{}let m={boardId:h,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...mt,...z$1?{serverUrl:z$1}:{}},C=d!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:je}}:p;try{nt(s.boardAdapter)?await s.boardAdapter.chatAgentStore().enqueueRequest({boardId:h,ref:C,args:d!=null?{...m,__chatHandlerFlow:d}:m}):s.boardAdapter.chatAgentStore().enqueueRequest({boardId:h,ref:C,args:d!=null?{...m,__chatHandlerFlow:d}:m}),await Promise.resolve(s.boardAdapter.requestProcessAccumulated?.());}catch(S){try{et().setChatProcessing({cardId:t,active:!1});}catch{}x.warn(`[chat-handler] queue failed for card "${t}": ${S instanceof Error?S.message:String(S)}`);}}async function Xe(t,e,r){if(e.howToRun==="built-in"&&Oe(e)===je){let n=O,a=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(a,s,{boardId:h,cardId:String(s.cardId||""),label:t.label,logger:x,serverUrl:z$1,executionExtra:mt}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return I.invoke(e,r)}async function Ye(t,e=false){e||await ct();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?Q(r):J();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let a=await Xe(n,t.ref,t.args);if(!a.dispatched){if(r)try{P.setProcessing(r,!1);}catch{}throw new Error(a.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function tr(t,e,r){let n=e==="chat-send"?te:He,a;await n(t,s=>{let d=new Date().toISOString(),p=s.card_data&&typeof s.card_data=="object"?s.card_data:{};if(s.card_data=p,e==="chat-send"){let m=r&&typeof r.text=="string"?r.text.trim():"",C=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"",S=[];if(Array.isArray(r?.files)){for(let q of r.files)if(q){if(typeof q=="string"){S.push({name:q});continue}if(typeof q=="object"){let L=q;typeof L.name=="string"&&S.push({name:L.name,size:L.size,mime_type:L.mime_type,uploaded_at:L.uploaded_at,stored_name:L.stored_name,chat:L.chat===true});}}}if(m||S.length>0){let q=W.runBatch({cardId:t,commands:[{command:"append",role:"user",text:m,files:S,turn:C},{command:"set-processing",active:true}]});if(q.status!=="success")throw new Error(q.error);let L=q.data.results[0]?.data?.id;if(typeof L!="string"||!L)throw new Error(`chat-send did not return an append id for card ${t}`);a={cardId:t,lastEntryId:L,processingAlreadySet:true,turnId:C};try{let A=jt(t);le([{kind:"card_chats",cardId:t,messages:A.map(R=>({role:String(R.role||"system"),text:String(R.text||""),files:Array.isArray(R.files)?R.files:[]})),receiving:!0,processing:P.isProcessing(t)}]);}catch{}}return s}if(e==="file-upload"){let m=Y().normalizeIncoming(r?.files,d);return m.length>0&&Y().merge(p,m),s}if(e==="action"){let m=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!m)return s;p.lastAction={buttonId:m,at:d},p.lastActionText=`${m} @ ${d}`;}return s}),a&&Ze(a.cardId,a.lastEntryId,a.processingAlreadySet,a.turnId??"");}function w(t,e,r){let n=JSON.stringify(r),a=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...y$1,"Content-Type":"application/json; charset=utf-8","Content-Length":a}),t.end(n);}async function re(t,e,r){let n=await dt(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let a=Y().resolve(n.card_data,e,r);if(!a.ok&&a.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!a.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=a.file,d=tt(t),p=yt(t),m=String(s.stored_name||""),C=`${d}/${m}`,S=p.files?await p.files.getBytes(C):null;if(!S)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:S}}async function er(t,e,r,n){let{fileRecord:a,bytes:s}=await re(e,r,n),d=String(a.name||a.stored_name||"download.bin"),p=String(a.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":p,"Content-Disposition":`attachment; filename="${d}"`,"Content-Length":s.length}),t.end(s);}function rr(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 ne(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
|
|
2
|
-
`)}async function K(t){let e=[];for await(let n of t)e.push(n);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(vt(e)).trim();return r?JSON.parse(r):{}}async function nr(t){let e=[];for await(let r of t)e.push(r);return typeof Buffer<"u"?Buffer.concat(e):vt(e)}async function ae(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let n=j$1[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function se(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=j$1[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}async function ar(t,e,r){let n=String(t||"").trim();if(!n)return {statusCode:400,body:{error:"callback token is required"}};let a=e==="success"?await ae(n,r):await se(n,r);return a.status==="success"?{statusCode:200,body:a}:a.status==="fail"?{statusCode:400,body:{error:a.error}}:{statusCode:500,body:{error:a.error}}}let oe=0;function ie(t){let e=JSON.stringify(t);return oe++,`id: ${oe}
|
|
3
|
-
data: ${e}
|
|
4
|
-
|
|
5
|
-
`}function ce(t){let e=t;try{e.flushHeaders?.();}catch{}try{e.flush?.();}catch{}try{e.socket?.setNoDelay?.(!0);}catch{}try{e.socket?.uncork?.();}catch{}}function Et(t,e){let r=v.get(t);if(r&&!(e&&r.res!==e)){v.delete(t),qt();try{It?.(t);}catch{}try{r.res.end();}catch{}}}function kt(t,e){let r=v.get(t);if(!r)return;let n=ie(e);try{r.res.write(n),ce(r.res);}catch{Et(t,r.res);}}function de(t,e,r,n,a){if(!v.has(e)){w(t,404,{error:`SSE client not connected: ${e}`});return}a?Ot?.(e,r,n):B?.(e,r,n),w(t,200,{ok:true,clientId:e,channelName:r,...n.cardId?{cardId:n.cardId}:{},subscribed:a});}function $t(){let t=new Set;for(let e of v.values())for(let r of e.subscribedChatCardIds)t.add(r);return Array.from(t)}function sr(t){let e=F.has(t)?F.get(t):null,{cursor:r}=P.readAfter(t,e),n=P.isProcessing(t),a=n!==(M.get(t)??false),s=r!==e;return s&&F.set(t,r),M.set(t,n),s||a}function ue(t,e=true){let r=jt(t),n=Date.now();return {kind:"card_chats",cardId:t,sentAt:new Date(n).toISOString(),sentAtMs:n,messages:r.map(a=>({role:String(a.role||"system"),text:String(a.text||""),files:Array.isArray(a.files)?a.files:[]})),receiving:e,processing:P.isProcessing(t)}}function Ft(t,e=true){let r={kind:"notification-batch",notifications:[ue(t,e)]};for(let[n,a]of v.entries())a.subscribedChatCardIds.has(t)&&kt(n,r);}function qt(){$t().length>0||(D&&(clearInterval(D),D=null),F.clear(),M.clear());}function or(){if(D)return;let t=()=>{let e=$t();if(e.length===0){qt();return}let r=new Set(e);for(let n of Array.from(F.keys()))r.has(n)||F.delete(n);for(let n of Array.from(M.keys()))r.has(n)||M.delete(n);for(let n of e)sr(n)&&Ft(n,true);};t(),D=setInterval(t,1e3);}function ir(t,e){let r=v.get(t);if(!r)return false;r.subscribedChatCardIds.add(e);let{cursor:n}=P.readAfter(e,null);return F.set(e,n),M.set(e,P.isProcessing(e)),or(),kt(t,{kind:"notification-batch",notifications:[ue(e,true)]}),true}function cr(t,e){let r=v.get(t);return r?(r.subscribedChatCardIds.delete(e),$t().includes(e)||(F.delete(e),M.delete(e)),qt(),true):false}function dr(t){if(!t||typeof t!="object")return false;let e=t.kind;return e==="card_chats"||e==="chat_messages"}function le(t){if(!t||t.length===0)return;let e=[],r=new Set;for(let n of t)dr(n)&&typeof n.cardId=="string"?r.add(String(n.cardId)):e.push(n);if(e.length>0){let n={kind:"notification-batch",notifications:e};for(let a of v.keys())kt(a,n);}for(let n of r)Ft(n,true);}async function ur(t,e,r){let n=v.get(r),a=n?new Set(n.subscribedChatCardIds):new Set;n&&Et(r,n.res),e.writeHead(200,{...y$1,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),ce(e),v.set(r,{res:e,subscribedChatCardIds:a});let s=await Ct(),d=ie(s);e.write(d);try{Bt?.(r,m=>{kt(r,m);});}catch{}let p=setInterval(()=>{try{e.write(`: keepalive
|
|
6
|
-
|
|
7
|
-
`);}catch{}},15e3);t.on("close",()=>{clearInterval(p),Et(r,e);});}async function lr(t,e,r){let n=t.method||"GET",a=r,s=a.pathname;try{if(n==="GET"&&s===`${l$1}/init-board`)return await ct(),w(e,200,await Ct()),!0;if(n==="GET"&&s===`${l$1}/sse`){await ct();let i=String(a.searchParams.get("clientId")||"").trim();if(!i)return w(e,400,{error:"clientId query param is required for SSE"}),!0;await ur(t,e,i);for(let o=0;o<j$1.length;o++)await wt(j$1[o]),await Ht(j$1[o],o),await wt(j$1[o]);return !0}if(n==="GET"&&s===`${l$1}/board-status`)return w(e,200,await Ct()),!0;let d=s.match(new RegExp(`^${V(l$1)}/callback/board-worker/([^/]+)/(success|failure)$`));if(n==="POST"&&d){await ct();let i=decodeURIComponent(d[1]),o=d[2],g=await K(t),f=await ar(i,o,g);return w(e,f.statusCode,f.body),!0}if(n==="POST"&&s===`${l$1}/mcp`){await H();let i=await K(t),o=typeof i.tool=="string"?i.tool.trim():"",g=i.args&&typeof i.args=="object"&&!Array.isArray(i.args)?i.args:{};if(!o)return w(e,400,{error:"tool is required"}),!0;if(o==="inspect.file-contents")return w(e,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let f=await Gt(o,g,De(et()));if(f&&typeof f=="object"&&!Array.isArray(f)){let k=f;if(k.status==="fail")return w(e,400,{error:Rt(f,"Request failed")}),!0;if(k.status==="error")return w(e,500,{error:Rt(f,"Internal error")}),!0}w(e,200,f);}catch(f){let k=typeof f?.statusCode=="number"?Number(f.statusCode):500,$=f instanceof Error?f.message:String(f);w(e,k,{error:$});}return !0}if(n==="POST"&&s===`${l$1}/mcp-controlplane`){await H();let i=await K(t),o=typeof i.tool=="string"?i.tool.trim():"",g=i.args&&typeof i.args=="object"&&!Array.isArray(i.args)?i.args:{};if(!o)return w(e,400,{error:"tool is required"}),!0;try{let f=await Gt(o,g,Ue());if(f&&typeof f=="object"&&!Array.isArray(f)){let k=f;if(k.status==="fail")return w(e,400,{error:Rt(f,"Request failed")}),!0;if(k.status==="error")return w(e,500,{error:Rt(f,"Internal error")}),!0}w(e,200,f);}catch(f){let k=typeof f?.statusCode=="number"?Number(f.statusCode):500,$=f instanceof Error?f.message:String(f);w(e,k,{error:$});}return !0}if(n==="POST"&&s===`${l$1}/mcp-raw`){await H();let i=await K(t),o=typeof i.tool=="string"?i.tool.trim():"",g=i.args&&typeof i.args=="object"&&!Array.isArray(i.args)?i.args:{};if(!o)return w(e,400,{error:"tool is required"}),!0;if(o!=="inspect.file-contents")return w(e,400,{error:`Tool does not support raw response: ${o}`}),!0;let f=E(g,"card_id","cardId"),k=at(g,"file_idx","fileIdx"),$=at(g,"head-lines","headLines"),T=at(g,"tail-lines","tailLines"),N=at(g,"head-bytes","headBytes"),rt=at(g,"tail-bytes","tailBytes");if(!f)return w(e,400,{error:"inspect.file-contents requires card_id"}),!0;if(k===void 0||!Number.isInteger(k)||k<0)return w(e,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([$,T,N,rt].filter(G=>G!==void 0).length>1)return w(e,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[G,ut]of [["head-lines",$],["tail-lines",T],["head-bytes",N],["tail-bytes",rt]])if(ut!==void 0&&(!Number.isInteger(ut)||ut<0))return w(e,400,{error:`inspect.file-contents requires ${G} to be a non-negative integer`}),!0;let fe=await et().inspectFileContents({cardId:f,fileIdx:k}),fr=typeof fe?.stored_name=="string"?fe.stored_name:null,{fileRecord:Mt,bytes:gt}=await re(f,k,fr),pe=String(Mt.name||Mt.stored_name||"download.bin"),Lt=String(Mt.mime_type||"application/octet-stream"),At=(a.searchParams.get("resp")||"").trim().toLowerCase();if(At&&At!=="json-b64")return w(e,400,{error:`unsupported resp mode: ${At}`}),!0;let pr=At==="json-b64",it;if($!==void 0||T!==void 0){if(!rr(Lt))return w(e,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let G=new TextDecoder().decode(gt),ut=$!==void 0?ne(G,"head",$):ne(G,"tail",T);it=typeof Buffer<"u"?Buffer.from(ut,"utf8"):new TextEncoder().encode(ut);}else if(N!==void 0||rt!==void 0){let G=N??rt;it=N!==void 0?gt.slice(0,G):gt.slice(Math.max(0,gt.length-G));}else it=gt;if(pr){let G=typeof Buffer<"u"?Buffer.from(it).toString("base64"):btoa(String.fromCharCode(...it));return w(e,200,{bodyBase64:G,mimeType:Lt,filename:pe,byteLength:it.length}),!0}return e.writeHead(200,{"Content-Type":Lt,"Content-Disposition":`attachment; filename="${pe}"`,"Content-Length":it.length}),e.end(it),!0}let p=s.match(new RegExp(`^${V(l$1)}/cards/([^/]+)$`));if(n==="GET"&&p){await H();let i=decodeURIComponent(p[1]),o=await dt(i);return o?(w(e,200,o),!0):(w(e,404,{error:`card not found: ${i}`}),!0)}if(n==="PATCH"&&p){await H();let i=decodeURIComponent(p[1]),o=await K(t);return await Ve(i,o),w(e,200,{ok:!0}),!0}let m=s.match(new RegExp(`^${V(l$1)}/cards/([^/]+)/retrigger$`));if(n==="POST"&&m){await H();let i=decodeURIComponent(m[1]);return await Qe(i),w(e,200,{ok:!0}),!0}let C=s.match(new RegExp(`^${V(l$1)}/cards/([^/]+)/actions$`));if(n==="POST"&&C){await H();let i=decodeURIComponent(C[1]),o=Date.now(),g=new Date(o).toISOString(),f=await K(t),k=f?.actionType;if(k==="chat-send"&&!await ee(i)){let T=Date.now();return w(e,409,{error:`chat handler is not configured for card: ${i}`,requestReceivedAt:g,requestReceivedAtMs:o,responseSentAt:new Date(T).toISOString(),responseSentAtMs:T,responseStatus:409}),!0}if(k==="chat-send"){let T=f?.payload??{},N=typeof T["turn-id"]=="string"?T["turn-id"]:typeof T.turnId=="string"?T.turnId:typeof T.turn=="string"?T.turn:"";if(!N||!String(N).trim()){let rt=Date.now();return w(e,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${i}`,requestReceivedAt:g,requestReceivedAtMs:o,responseSentAt:new Date(rt).toISOString(),responseSentAtMs:rt,responseStatus:400}),!0}}await tr(i,k,f?.payload);let $=Date.now();return w(e,200,{ok:!0,requestReceivedAt:g,requestReceivedAtMs:o,responseSentAt:new Date($).toISOString(),responseSentAtMs:$,responseStatus:200}),!0}let S=s.match(new RegExp(`^${V(l$1)}/cards/([^/]+)/chats$`));if(n==="GET"&&S){await H();let i=decodeURIComponent(S[1]),o=String(a.searchParams.get("turn-id")||""),g=String(a.searchParams.get("all-turns")||"").toLowerCase()==="true",f=String(a.searchParams.get("tail-turns-before-id")||""),k=a.searchParams.get("tail-turns"),$=k==null||k===""?g||o?void 0:1:Number.parseInt(k,10),T=W.readAll({params:{cardId:i},body:{...$===void 0?{}:{tailTurns:$},...o?{turnId:o}:{},...g?{allTurns:!0}:{},...f?{tailTurnsBeforeId:f}:{}}});if(T.status!=="success")return w(e,400,{error:T.error||"Failed to read chats"}),!0;let N=T.data.records;return w(e,200,{ok:!0,messages:N}),!0}if(n==="POST"&&S){await H();let i=decodeURIComponent(S[1]),o=await K(t),g=typeof o?.role=="string"?o.role:"assistant",f=typeof o?.text=="string"?o.text:"",k=Array.isArray(o?.files)?o.files:[],$=typeof o?.turn=="string"?o.turn:typeof o?.["turn-id"]=="string"?o["turn-id"]:typeof o?.turnId=="string"?o.turnId:"",T=o?.done===!0,N=P.append(i,g,f,k,$);return T&&P.setProcessing(i,!1),Ft(i,!T),w(e,200,{ok:!0,id:N}),!0}let q=s.match(new RegExp(`^${V(l$1)}/cards/([^/]+)/chats/subscribe-sse$`));if(n==="POST"&&q){await H();let i=decodeURIComponent(q[1]),o=await K(t),g=typeof o?.clientId=="string"?o.clientId.trim():"";return g?ir(g,i)?(w(e,200,{ok:!0,clientId:g,cardId:i,subscribed:!0}),!0):(w(e,404,{error:`SSE client not connected: ${g}`}),!0):(w(e,400,{error:"clientId is required"}),!0)}let L=s.match(new RegExp(`^${V(l$1)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(n==="POST"&&L){await H();let i=decodeURIComponent(L[1]),o=await K(t),g=typeof o?.clientId=="string"?o.clientId.trim():"";return g?cr(g,i)?(w(e,200,{ok:!0,clientId:g,cardId:i,subscribed:!1}),!0):(w(e,404,{error:`SSE client not connected: ${g}`}),!0):(w(e,400,{error:"clientId is required"}),!0)}let u=s.match(new RegExp(`^${V(l$1)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(n==="POST"&&u){await H();let i=decodeURIComponent(u[1]),o=u[2]==="subscribe",g=await K(t),f=typeof g?.clientId=="string"?g.clientId.trim():"";return f?(de(e,f,i,{},o),!0):(w(e,400,{error:"clientId is required"}),!0)}let b=s.match(new RegExp(`^${V(l$1)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(n==="POST"&&b){await H();let i=decodeURIComponent(b[1]),o=decodeURIComponent(b[2]),g=b[3]==="subscribe",f=await K(t),k=typeof f?.clientId=="string"?f.clientId.trim():"";return k?(de(e,k,o,{cardId:i},g),!0):(w(e,400,{error:"clientId is required"}),!0)}let A=s.match(new RegExp(`^${V(l$1)}/cards/([^/]+)/files$`));if(n==="POST"&&A){await H();let i=decodeURIComponent(A[1]),o=String(a.searchParams.get("inChat")||"").toLowerCase()==="true",g=String(a.searchParams.get("turn-id")||"").trim();if(o&&!g)return w(e,400,{error:`file upload with inChat=true requires a non-empty 'turn-id' query parameter for card: ${i}`}),!0;let f=t.headers["x-file-name"],k=String(t.headers["content-type"]||"application/octet-stream"),$=Array.isArray(f)?f[0]:f,T=$?decodeURIComponent(String($)):"upload.bin",N=await nr(t);return w(e,200,await Tt(i,T,k,N,{inChat:o,turnId:g})),!0}let R=s.match(new RegExp(`^${V(l$1)}/cards/([^/]+)/files/(\\d+)$`));if(n==="GET"&&R){let i=decodeURIComponent(R[1]),o=parseInt(R[2],10),g=a.searchParams.get("sn");return await er(e,i,o,g),!0}return !1}catch(d){let p=d?.statusCode||500;return w(e,p,{error:String(d?.message||d)}),true}}return {get apiBasePath(){return l$1},get corsHeaders(){return y$1},get queueLaneTuning(){return _},handleRuntimeApi:lr,buildPublishedRuntimePayload:Ct,processAccumulatedEvents:$e,processAccumulatedLane:xt,handleChatAgentRequest:Ye,clearChatRecords:ze,reportSourceFetched(t,e){return ae(t,{ref:e})},reportSourceFetchFailure(t,e){return se(t,{reason:e})},get cardStore(){return j$1[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Mr(c){let l=String(c.apiBasePath||"/api/boards").replace(/\/$/,""),y={...Te,...c.corsHeaders||{}},_=c.serverMetaStore,h=c.boardRuntimeFactory,x=new Map,I="boards-config.json";function O(){let B=_.getText(I);if(!B)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(B)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function P(B){_.putText(I,JSON.stringify(B,null,2));}function W(B){let v=String(B||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return v.length>0&&v.length<=64?v:null}function ot(B){if(x.has(B))return x.get(B);let F=O().boards.find(D=>D.id===B)||{},M=h(B,F);return x.set(B,M),M}function z(B,v,F){let M=JSON.stringify(F),D=typeof Buffer<"u"?Buffer.byteLength(M):new TextEncoder().encode(M).length;B.writeHead(v,{...y,"Content-Type":"application/json; charset=utf-8","Content-Length":D}),B.end(M);}async function mt(B,v,F){let M=B.method||"GET",D=F.pathname;if(M==="GET"&&D===l)return z(v,200,{ok:true,boards:O().boards}),true;if(M==="POST"&&D===l){let Z=[];for await(let tt of B)Z.push(tt);let j=typeof Buffer<"u"?Buffer.concat(Z).toString("utf-8").trim():new TextDecoder().decode(vt(Z)).trim(),U={};try{U=j?JSON.parse(j):{};}catch{U={};}let X=W(U.id);if(!X)return z(v,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let ft=O();if(ft.boards.some(tt=>tt.id===X))return z(v,409,{error:`Board "${X}" is already registered`}),true;let yt=typeof U.label=="string"&&U.label.trim()?U.label.trim():X,Y={id:X,label:yt};for(let[tt,pt]of Object.entries(U))tt==="id"||tt==="label"||pt!=null&&(Y[tt]=pt);return ft.boards.push(Y),P(ft),z(v,200,{ok:true,board:Y}),true}return false}async function Bt(B,v,F){let D=F.pathname.match(new RegExp(`^${V(l)}/([^/]+)(/|$)`));if(!D)return false;let Z=W(decodeURIComponent(D[1]));return Z?O().boards.some(X=>X.id===Z)?!!await ot(Z).handleRuntimeApi(B,v,F):(z(v,404,{error:`Board "${Z}" not registered. POST ${l} with {id} to register it first.`}),true):(z(v,400,{error:"Invalid board id"}),true)}async function It(B,v,F){return !!(await mt(B,v,F)||await Bt(B,v,F))}function Ot(B){if(!O().boards.some(F=>F.id===B))throw Object.assign(new Error(`Board "${B}" not registered`),{statusCode:404});return {service:ot(B)}}return {get apiBasePath(){return l},get corsHeaders(){return y},handleApi:It,requireBoardService:Ot}}export{kr as a,qr as b,Mr as c};//# sourceMappingURL=chunk-OSWJKJLB.js.map
|
|
8
|
-
//# sourceMappingURL=chunk-OSWJKJLB.js.map
|