yaml-flow 8.11.0 → 8.11.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkBDT43KYE_cjs=require('./chunk-BDT43KYE.cjs');require('./chunk-LFVMX23W.cjs'),require('./chunk-NM6O35RY.cjs'),require('./chunk-NBJTYAYN.cjs'),require('./chunk-NMOUBZXX.cjs');var chunkBQJVCCFU_cjs=require('./chunk-BQJVCCFU.cjs');require('./chunk-BQUQTOPB.cjs'),require('./chunk-GPCMBPLK.cjs'),require('./chunk-7FGPOGRV.cjs'),require('./chunk-LPXVVMQT.cjs'),require('./chunk-272IYUKT.cjs'),require('./chunk-X5CZE2L7.cjs'),require('./chunk-WRMOGPRG.cjs'),require('./chunk-VNLMJEIX.cjs'),require('./chunk-7JVHYHT2.cjs'),require('./chunk-VQCIOKJV.cjs'),require('./chunk-G4XXRHL2.cjs'),require('./chunk-LODXIALE.cjs'),require('./chunk-GHUW6P4G.cjs'),require('./chunk-QBEQL4TL.cjs'),require('./chunk-QEHKMLHA.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-5XLFPPTY.cjs'),require('./chunk-SDJ3747Q.cjs'),require('./chunk-OF4FPYNI.cjs'),require('./chunk-2RIHC5TZ.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createMultiBoardServerRuntime",{enumerable:true,get:function(){return chunkBDT43KYE_cjs.b}});Object.defineProperty(exports,"createSingleBoardServerRuntime",{enumerable:true,get:function(){return chunkBDT43KYE_cjs.a}});Object.defineProperty(exports,"createHostedBoardQueueLaneRegistry",{enumerable:true,get:function(){return chunkBQJVCCFU_cjs.a}});//# sourceMappingURL=board-live-cards-server-runtime.cjs.map
1
+ 'use strict';var chunkU6JMXOER_cjs=require('./chunk-U6JMXOER.cjs');require('./chunk-LFVMX23W.cjs'),require('./chunk-NM6O35RY.cjs'),require('./chunk-NBJTYAYN.cjs'),require('./chunk-NMOUBZXX.cjs');var chunkBQJVCCFU_cjs=require('./chunk-BQJVCCFU.cjs');require('./chunk-BQUQTOPB.cjs'),require('./chunk-GPCMBPLK.cjs'),require('./chunk-7FGPOGRV.cjs'),require('./chunk-LPXVVMQT.cjs'),require('./chunk-272IYUKT.cjs'),require('./chunk-X5CZE2L7.cjs'),require('./chunk-WRMOGPRG.cjs'),require('./chunk-VNLMJEIX.cjs'),require('./chunk-7JVHYHT2.cjs'),require('./chunk-VQCIOKJV.cjs'),require('./chunk-G4XXRHL2.cjs'),require('./chunk-LODXIALE.cjs'),require('./chunk-GHUW6P4G.cjs'),require('./chunk-QBEQL4TL.cjs'),require('./chunk-QEHKMLHA.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-5XLFPPTY.cjs'),require('./chunk-SDJ3747Q.cjs'),require('./chunk-OF4FPYNI.cjs'),require('./chunk-2RIHC5TZ.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createMultiBoardServerRuntime",{enumerable:true,get:function(){return chunkU6JMXOER_cjs.b}});Object.defineProperty(exports,"createSingleBoardServerRuntime",{enumerable:true,get:function(){return chunkU6JMXOER_cjs.a}});Object.defineProperty(exports,"createHostedBoardQueueLaneRegistry",{enumerable:true,get:function(){return chunkBQJVCCFU_cjs.a}});//# sourceMappingURL=board-live-cards-server-runtime.cjs.map
2
2
  //# sourceMappingURL=board-live-cards-server-runtime.cjs.map
@@ -1,2 +1,2 @@
1
- export{b as createMultiBoardServerRuntime,a as createSingleBoardServerRuntime}from'./chunk-WQANIJAQ.js';import'./chunk-JB4Q2W7I.js';import'./chunk-XYN5D3GL.js';import'./chunk-O5UYCGIN.js';import'./chunk-CZ6ZFWFT.js';export{a as createHostedBoardQueueLaneRegistry}from'./chunk-7UJQMFVS.js';import'./chunk-FOFGEABN.js';import'./chunk-RKKSVOP2.js';import'./chunk-NTICU4OK.js';import'./chunk-O7NOHKVR.js';import'./chunk-ZJ5M5COT.js';import'./chunk-5U5NMYGT.js';import'./chunk-6MD6FVE3.js';import'./chunk-H5FKNSCO.js';import'./chunk-ANKA7HEJ.js';import'./chunk-44L64VQ2.js';import'./chunk-VGT3TRQG.js';import'./chunk-WDPOGXTY.js';import'./chunk-6M3RIGUH.js';import'./chunk-ATOQP3BD.js';import'./chunk-YT76JNKE.js';import'./chunk-MNEOJWPS.js';import'./chunk-7QNEV5S3.js';import'./chunk-BJGK5FNL.js';import'./chunk-NIBLKYXN.js';import'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=board-live-cards-server-runtime.js.map
1
+ export{b as createMultiBoardServerRuntime,a as createSingleBoardServerRuntime}from'./chunk-4LHFO56U.js';import'./chunk-JB4Q2W7I.js';import'./chunk-XYN5D3GL.js';import'./chunk-O5UYCGIN.js';import'./chunk-CZ6ZFWFT.js';export{a as createHostedBoardQueueLaneRegistry}from'./chunk-7UJQMFVS.js';import'./chunk-FOFGEABN.js';import'./chunk-RKKSVOP2.js';import'./chunk-NTICU4OK.js';import'./chunk-O7NOHKVR.js';import'./chunk-ZJ5M5COT.js';import'./chunk-5U5NMYGT.js';import'./chunk-6MD6FVE3.js';import'./chunk-H5FKNSCO.js';import'./chunk-ANKA7HEJ.js';import'./chunk-44L64VQ2.js';import'./chunk-VGT3TRQG.js';import'./chunk-WDPOGXTY.js';import'./chunk-6M3RIGUH.js';import'./chunk-ATOQP3BD.js';import'./chunk-YT76JNKE.js';import'./chunk-MNEOJWPS.js';import'./chunk-7QNEV5S3.js';import'./chunk-BJGK5FNL.js';import'./chunk-NIBLKYXN.js';import'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=board-live-cards-server-runtime.js.map
2
2
  //# sourceMappingURL=board-live-cards-server-runtime.js.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');require('./chunk-GNFE24S7.cjs');function k(a){return JSON.parse(JSON.stringify(a))}function v(a,o){if(a===o)return a;try{if(JSON.stringify(a)===JSON.stringify(o))return a}catch{}return o}function m(a,o){if(a===o)return true;try{return JSON.stringify(a)===JSON.stringify(o)}catch{return false}}function B(a){return a==="running"||a==="in-progress"?"loading":a==="failed"?"error":"fresh"}function S(a,o,h){let C=a,l=(C&&Array.isArray(C.cardDefinitions)?C.cardDefinitions:[]).map(d=>d.id),f=o&&o.modelsById||{},_={};for(let d of l){let p=h(a,d),t=f[d];if(!t){_[d]=p;continue}let r=p.card_chats!=null?v(t.card_chats,p.card_chats??null):t.card_chats??null,e={id:p.id,card:v(t.card,p.card),card_data:v(t.card_data,p.card_data),requires:v(t.requires,p.requires),computed_values:v(t.computed_values,p.computed_values),runtime_state:v(t.runtime_state,p.runtime_state),card_chats:r};_[d]=e.card===t.card&&e.card_data===t.card_data&&e.requires===t.requires&&e.computed_values===t.computed_values&&e.runtime_state===t.runtime_state&&e.card_chats===t.card_chats?t:e;}let u=o?.cardWatchParties||{},g=Object.fromEntries(l.filter(d=>Object.prototype.hasOwnProperty.call(u,d)).map(d=>[d,u[d]]));return {payload:a,cardIds:l,modelsById:_,cardWatchParties:g}}function q(a,o={}){if(!a)return a;let h=typeof o.includeCard=="function"?o.includeCard:(()=>true),C=typeof o.mapCard=="function"?o.mapCard:(u=>u),c=false,l=[],f={};for(let u of a.cardIds){let g=a.modelsById[u];if(!g){c=true;continue}if(!h(g,a)){c=true;continue}let d=C(g,a);if(!d||d.id!==u)throw new Error(`deriveBoardState: mapped card must preserve id "${u}"`);d!==g&&(c=true),l.push(u),f[u]=d;}let _=typeof o.mapPayload=="function"?o.mapPayload(a.payload,{sourceState:a,cardIds:l,modelsById:f}):a.payload;return _!==a.payload&&(c=true),!c&&l.length===a.cardIds.length?a:{payload:_,cardIds:l,modelsById:f,cardWatchParties:a.cardWatchParties}}function x(a,o,h,C){if(!a||!Array.isArray(o)||o.length===0)return a;let c=a.modelsById,l=a.cardIds,f=a.cardWatchParties||{},_=false,u=false,g={};for(let t of l){let r=c[t],e=r&&r.requires;if(e&&typeof e=="object")for(let s of Object.keys(e))(g[s]=g[s]||[]).push(t);}function d(){_||(c={...c},_=true);}function p(t){if(t.kind!=="card_watchparty"||!t.cardId||!t.channel)return;let r=f[t.cardId]||{},e=Array.isArray(r[t.channel])?r[t.channel]:[],s=e;if(t.clear){if(e.length===0)return;s=[];}else if(t.replace){let i=Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0,n={payload:t.payload,ts:i};if(e.length===1&&e[0]?.ts===n.ts&&m(e[0]?.payload,n.payload))return;s=[n];}else {let i={payload:t.payload,ts:Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0};s=[...e,i];}f={...f,[t.cardId]:{...r,[t.channel]:s}},u=true;}for(let t of o)if(!(!t||!t.kind)){if(t.kind==="card_watchparty"){p(t);continue}if(chunk2RIHC5TZ_cjs.c(t)){if(t.kind==="card_chats"){let r=t.cardId,e=c[r];if(!e)continue;let s=Array.isArray(t.messages)?t.messages:e.card_chats?.messages??[],i=typeof t.receiving=="boolean"?t.receiving:e.card_chats?.receiving??false,n=typeof t.processing=="boolean"?t.processing:e.card_chats?.processing??false,y={messages:s,receiving:i,processing:n};if(m(e.card_chats,y))continue;d(),c[r]={...e,card_chats:y},u=true;}else if(t.kind==="chat_messages"){let r=t.cardId,e=c[r];if(!e)continue;let s=Array.isArray(t.messages)?t.messages:[],i=e.card_chats||{receiving:false,processing:false},n={messages:s,receiving:i.receiving,processing:!!i.processing};if(m(e.card_chats,n))continue;d(),c[r]={...e,card_chats:n},u=true;}else if(t.kind==="chat_processing"){let r=t.cardId,e=c[r];if(!e)continue;let s=e.card_chats||{messages:[],receiving:false},i={messages:s.messages,receiving:s.receiving,processing:t.active===true};if(m(e.card_chats,i))continue;d(),c[r]={...e,card_chats:i},u=true;}continue}if(chunk2RIHC5TZ_cjs.b(t)){if(t.kind==="computed_values"){let r=t.cardId,e=c[r];if(!e)continue;let s=t.values||{};if(m(e.computed_values,s))continue;d(),c[r]={...e,computed_values:s},u=true;}else if(t.kind==="data_object"){let r=t.key,e=t.payload,s=g[r]||[];for(let i of s){let n=c[i];if(!n)continue;let y=n.requires||{};m(y[r],e)||(d(),c[i]={...n,requires:{...y,[r]:e}},u=true);}}else if(t.kind==="card_refreshed"){let r=t.cardId,e=null,s=c[r],i=t.card;if(s&&i&&typeof i=="object"&&!Array.isArray(i)){let n=i,y=n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?n.card_data:s.card_data,b=n.requires&&typeof n.requires=="object"&&!Array.isArray(n.requires)?n.requires:s.requires,w=n.computed_values&&typeof n.computed_values=="object"&&!Array.isArray(n.computed_values)?n.computed_values:s.computed_values,A=n.runtime_state&&typeof n.runtime_state=="object"&&!Array.isArray(n.runtime_state)?n.runtime_state:s.runtime_state;e={...s,card:i,card_data:y,requires:b,computed_values:w,runtime_state:A};}if(!e)try{let n=C();n&&(e=h(n,r));}catch{}if(!e||s&&m(s.card,e.card)&&m(s.card_data,e.card_data)&&m(s.requires,e.requires)&&m(s.computed_values,e.computed_values)&&m(s.runtime_state,e.runtime_state))continue;d(),c[r]=e,l.includes(r)||(l=[...l,r]),u=true;}else if(t.kind==="card_removed"){let r=t.cardId;if(!c[r])continue;if(d(),delete c[r],l=l.filter(e=>e!==r),Object.prototype.hasOwnProperty.call(f,r)){let e={...f};delete e[r],f=e;}u=true;}else if(t.kind==="status"){let r=t.status?.cards??[];for(let e of r){let s=e?.name;if(!s||!c[s])continue;let i=c[s],n=B(e.status),y={...i.card_data||{},status:n,lastRun:e.runtime?.last_transition_at??null,...e.error?.message?{error:e.error.message}:{}};e.error?.message||delete y.error;let b={task_status:e.status??null,card_status:n,runtime:e.runtime?k(e.runtime):{},error:e.error?k(e.error):null,blocked_by:Array.isArray(e.blocked_by)?k(e.blocked_by):[],requires_missing:Array.isArray(e.requires_missing)?k(e.requires_missing):[]};m(i.card_data,y)&&m(i.runtime_state,b)||(d(),c[s]={...i,card_data:y,runtime_state:b},u=true);}}}}return u?{payload:a.payload,cardIds:l,modelsById:c,cardWatchParties:f}:a}exports.applyNotification=x;exports.buildBoardState=S;exports.deriveBoardState=q;//# sourceMappingURL=board-state-reducer.cjs.map
1
+ 'use strict';var chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');require('./chunk-GNFE24S7.cjs');function b(n){return JSON.parse(JSON.stringify(n))}function k(n,i){if(n===i)return n;try{if(JSON.stringify(n)===JSON.stringify(i))return n}catch{}return i}function m(n,i){if(n===i)return true;try{return JSON.stringify(n)===JSON.stringify(i)}catch{return false}}function q(n){return n==="running"||n==="in-progress"?"loading":n==="failed"?"error":"fresh"}function x(n,i,h){let v=n,f=(v&&Array.isArray(v.cardDefinitions)?v.cardDefinitions:[]).map(p=>p.id),g=i&&i.modelsById||{},o={};for(let p of f){let t=h(n,p),a=g[p];if(!a){o[p]=t;continue}let e=t.card_chats!=null?k(a.card_chats,t.card_chats??null):a.card_chats??null,r={id:t.id,card:k(a.card,t.card),card_data:k(a.card_data,t.card_data),requires:k(a.requires,t.requires),computed_values:k(a.computed_values,t.computed_values),runtime_state:k(a.runtime_state,t.runtime_state),card_chats:e};o[p]=r.card===a.card&&r.card_data===a.card_data&&r.requires===a.requires&&r.computed_values===a.computed_values&&r.runtime_state===a.runtime_state&&r.card_chats===a.card_chats?a:r;}let y=i?.cardWatchParties||{},l=Object.fromEntries(f.filter(p=>Object.prototype.hasOwnProperty.call(y,p)).map(p=>[p,y[p]])),_=i?.pendingComputedValues||{},C=Object.fromEntries(Object.entries(_).filter(([p])=>!f.includes(p)));return {payload:n,cardIds:f,modelsById:o,cardWatchParties:l,pendingComputedValues:C}}function S(n,i={}){if(!n)return n;let h=typeof i.includeCard=="function"?i.includeCard:(()=>true),v=typeof i.mapCard=="function"?i.mapCard:(y=>y),d=false,f=[],g={};for(let y of n.cardIds){let l=n.modelsById[y];if(!l){d=true;continue}if(!h(l,n)){d=true;continue}let _=v(l,n);if(!_||_.id!==y)throw new Error(`deriveBoardState: mapped card must preserve id "${y}"`);_!==l&&(d=true),f.push(y),g[y]=_;}let o=typeof i.mapPayload=="function"?i.mapPayload(n.payload,{sourceState:n,cardIds:f,modelsById:g}):n.payload;return o!==n.payload&&(d=true),!d&&f.length===n.cardIds.length?n:{payload:o,cardIds:f,modelsById:g,cardWatchParties:n.cardWatchParties,pendingComputedValues:n.pendingComputedValues}}function O(n,i,h,v){if(!n||!Array.isArray(i)||i.length===0)return n;let d=n.modelsById,f=n.cardIds,g=n.cardWatchParties||{},o=n.pendingComputedValues||{},y=false,l=false,_={};for(let t of f){let a=d[t],e=a&&a.requires;if(e&&typeof e=="object")for(let r of Object.keys(e))(_[r]=_[r]||[]).push(t);}function C(){y||(d={...d},y=true);}function p(t){if(t.kind!=="card_watchparty"||!t.cardId||!t.channel)return;let a=g[t.cardId]||{},e=Array.isArray(a[t.channel])?a[t.channel]:[],r=e;if(t.clear){if(e.length===0)return;r=[];}else if(t.replace){let c=Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0,u={payload:t.payload,ts:c};if(e.length===1&&e[0]?.ts===u.ts&&m(e[0]?.payload,u.payload))return;r=[u];}else {let c={payload:t.payload,ts:Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0};r=[...e,c];}g={...g,[t.cardId]:{...a,[t.channel]:r}},l=true;}for(let t of i)if(!(!t||!t.kind)){if(t.kind==="card_watchparty"){p(t);continue}if(chunk2RIHC5TZ_cjs.c(t)){if(t.kind==="card_chats"){let a=t.cardId,e=d[a];if(!e)continue;let r=Array.isArray(t.messages)?t.messages:e.card_chats?.messages??[],c=typeof t.receiving=="boolean"?t.receiving:e.card_chats?.receiving??false,u=typeof t.processing=="boolean"?t.processing:e.card_chats?.processing??false,s={messages:r,receiving:c,processing:u};if(m(e.card_chats,s))continue;C(),d[a]={...e,card_chats:s},l=true;}else if(t.kind==="chat_messages"){let a=t.cardId,e=d[a];if(!e)continue;let r=Array.isArray(t.messages)?t.messages:[],c=e.card_chats||{receiving:false,processing:false},u={messages:r,receiving:c.receiving,processing:!!c.processing};if(m(e.card_chats,u))continue;C(),d[a]={...e,card_chats:u},l=true;}else if(t.kind==="chat_processing"){let a=t.cardId,e=d[a];if(!e)continue;let r=e.card_chats||{messages:[],receiving:false},c={messages:r.messages,receiving:r.receiving,processing:t.active===true};if(m(e.card_chats,c))continue;C(),d[a]={...e,card_chats:c},l=true;}continue}if(chunk2RIHC5TZ_cjs.b(t)){if(t.kind==="computed_values"){let a=t.cardId,e=d[a],r=t.values||{};if(!e){let c=o[a];if(m(c,r))continue;o={...o,[a]:b(r)},l=true;continue}if(m(e.computed_values,r))continue;C(),d[a]={...e,computed_values:r},l=true;}else if(t.kind==="data_object"){let a=t.key,e=t.payload,r=_[a]||[];for(let c of r){let u=d[c];if(!u)continue;let s=u.requires||{};m(s[a],e)||(C(),d[c]={...u,requires:{...s,[a]:e}},l=true);}}else if(t.kind==="card_refreshed"){let a=t.cardId,e=null,r=d[a],c=t.card;if(r&&c&&typeof c=="object"&&!Array.isArray(c)){let s=c,w=s.card_data&&typeof s.card_data=="object"&&!Array.isArray(s.card_data)?s.card_data:r.card_data,A=s.requires&&typeof s.requires=="object"&&!Array.isArray(s.requires)?s.requires:r.requires,B=s.computed_values&&typeof s.computed_values=="object"&&!Array.isArray(s.computed_values)?s.computed_values:r.computed_values,P=s.runtime_state&&typeof s.runtime_state=="object"&&!Array.isArray(s.runtime_state)?s.runtime_state:r.runtime_state;e={...r,card:c,card_data:w,requires:A,computed_values:B,runtime_state:P};}if(!e)try{let s=v();s&&(e=h(s,a));}catch{}if(!e)continue;let u=o[a];if(u!==void 0&&!m(e.computed_values,u)&&(e={...e,computed_values:b(u)}),r&&m(r.card,e.card)&&m(r.card_data,e.card_data)&&m(r.requires,e.requires)&&m(r.computed_values,e.computed_values)&&m(r.runtime_state,e.runtime_state))continue;C(),d[a]=e,f.includes(a)||(f=[...f,a]),Object.prototype.hasOwnProperty.call(o,a)&&(o={...o},delete o[a]),l=true;}else if(t.kind==="card_removed"){let a=t.cardId;if(!d[a])continue;if(C(),delete d[a],f=f.filter(e=>e!==a),Object.prototype.hasOwnProperty.call(g,a)){let e={...g};delete e[a],g=e;}Object.prototype.hasOwnProperty.call(o,a)&&(o={...o},delete o[a]),l=true;}else if(t.kind==="status"){let a=t.status?.cards??[];for(let e of a){let r=e?.name;if(!r||!d[r])continue;let c=d[r],u=q(e.status),s={...c.card_data||{},status:u,lastRun:e.runtime?.last_transition_at??null,...e.error?.message?{error:e.error.message}:{}};e.error?.message||delete s.error;let w={task_status:e.status??null,card_status:u,runtime:e.runtime?b(e.runtime):{},error:e.error?b(e.error):null,blocked_by:Array.isArray(e.blocked_by)?b(e.blocked_by):[],requires_missing:Array.isArray(e.requires_missing)?b(e.requires_missing):[]};m(c.card_data,s)&&m(c.runtime_state,w)||(C(),d[r]={...c,card_data:s,runtime_state:w},l=true);}}}}return l?{payload:n.payload,cardIds:f,modelsById:d,cardWatchParties:g,pendingComputedValues:o}:n}exports.applyNotification=O;exports.buildBoardState=x;exports.deriveBoardState=S;//# sourceMappingURL=board-state-reducer.cjs.map
2
2
  //# sourceMappingURL=board-state-reducer.cjs.map
@@ -35,6 +35,7 @@ interface BoardState {
35
35
  cardIds: string[];
36
36
  modelsById: Record<string, CardModel>;
37
37
  cardWatchParties: Record<string, CardWatchPartyChannelState>;
38
+ pendingComputedValues: Record<string, unknown>;
38
39
  }
39
40
  interface DeriveBoardStateOptions {
40
41
  includeCard?: (model: CardModel, sourceState: BoardState) => boolean;
@@ -35,6 +35,7 @@ interface BoardState {
35
35
  cardIds: string[];
36
36
  modelsById: Record<string, CardModel>;
37
37
  cardWatchParties: Record<string, CardWatchPartyChannelState>;
38
+ pendingComputedValues: Record<string, unknown>;
38
39
  }
39
40
  interface DeriveBoardStateOptions {
40
41
  includeCard?: (model: CardModel, sourceState: BoardState) => boolean;
@@ -1,2 +1,2 @@
1
- import {c,b}from'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';function k(a){return JSON.parse(JSON.stringify(a))}function v(a,o){if(a===o)return a;try{if(JSON.stringify(a)===JSON.stringify(o))return a}catch{}return o}function m(a,o){if(a===o)return true;try{return JSON.stringify(a)===JSON.stringify(o)}catch{return false}}function B(a){return a==="running"||a==="in-progress"?"loading":a==="failed"?"error":"fresh"}function S(a,o,h){let C=a,l=(C&&Array.isArray(C.cardDefinitions)?C.cardDefinitions:[]).map(d=>d.id),f=o&&o.modelsById||{},_={};for(let d of l){let p=h(a,d),t=f[d];if(!t){_[d]=p;continue}let r=p.card_chats!=null?v(t.card_chats,p.card_chats??null):t.card_chats??null,e={id:p.id,card:v(t.card,p.card),card_data:v(t.card_data,p.card_data),requires:v(t.requires,p.requires),computed_values:v(t.computed_values,p.computed_values),runtime_state:v(t.runtime_state,p.runtime_state),card_chats:r};_[d]=e.card===t.card&&e.card_data===t.card_data&&e.requires===t.requires&&e.computed_values===t.computed_values&&e.runtime_state===t.runtime_state&&e.card_chats===t.card_chats?t:e;}let u=o?.cardWatchParties||{},g=Object.fromEntries(l.filter(d=>Object.prototype.hasOwnProperty.call(u,d)).map(d=>[d,u[d]]));return {payload:a,cardIds:l,modelsById:_,cardWatchParties:g}}function q(a,o={}){if(!a)return a;let h=typeof o.includeCard=="function"?o.includeCard:(()=>true),C=typeof o.mapCard=="function"?o.mapCard:(u=>u),c=false,l=[],f={};for(let u of a.cardIds){let g=a.modelsById[u];if(!g){c=true;continue}if(!h(g,a)){c=true;continue}let d=C(g,a);if(!d||d.id!==u)throw new Error(`deriveBoardState: mapped card must preserve id "${u}"`);d!==g&&(c=true),l.push(u),f[u]=d;}let _=typeof o.mapPayload=="function"?o.mapPayload(a.payload,{sourceState:a,cardIds:l,modelsById:f}):a.payload;return _!==a.payload&&(c=true),!c&&l.length===a.cardIds.length?a:{payload:_,cardIds:l,modelsById:f,cardWatchParties:a.cardWatchParties}}function x(a,o,h,C){if(!a||!Array.isArray(o)||o.length===0)return a;let c$1=a.modelsById,l=a.cardIds,f=a.cardWatchParties||{},_=false,u=false,g={};for(let t of l){let r=c$1[t],e=r&&r.requires;if(e&&typeof e=="object")for(let s of Object.keys(e))(g[s]=g[s]||[]).push(t);}function d(){_||(c$1={...c$1},_=true);}function p(t){if(t.kind!=="card_watchparty"||!t.cardId||!t.channel)return;let r=f[t.cardId]||{},e=Array.isArray(r[t.channel])?r[t.channel]:[],s=e;if(t.clear){if(e.length===0)return;s=[];}else if(t.replace){let i=Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0,n={payload:t.payload,ts:i};if(e.length===1&&e[0]?.ts===n.ts&&m(e[0]?.payload,n.payload))return;s=[n];}else {let i={payload:t.payload,ts:Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0};s=[...e,i];}f={...f,[t.cardId]:{...r,[t.channel]:s}},u=true;}for(let t of o)if(!(!t||!t.kind)){if(t.kind==="card_watchparty"){p(t);continue}if(c(t)){if(t.kind==="card_chats"){let r=t.cardId,e=c$1[r];if(!e)continue;let s=Array.isArray(t.messages)?t.messages:e.card_chats?.messages??[],i=typeof t.receiving=="boolean"?t.receiving:e.card_chats?.receiving??false,n=typeof t.processing=="boolean"?t.processing:e.card_chats?.processing??false,y={messages:s,receiving:i,processing:n};if(m(e.card_chats,y))continue;d(),c$1[r]={...e,card_chats:y},u=true;}else if(t.kind==="chat_messages"){let r=t.cardId,e=c$1[r];if(!e)continue;let s=Array.isArray(t.messages)?t.messages:[],i=e.card_chats||{receiving:false,processing:false},n={messages:s,receiving:i.receiving,processing:!!i.processing};if(m(e.card_chats,n))continue;d(),c$1[r]={...e,card_chats:n},u=true;}else if(t.kind==="chat_processing"){let r=t.cardId,e=c$1[r];if(!e)continue;let s=e.card_chats||{messages:[],receiving:false},i={messages:s.messages,receiving:s.receiving,processing:t.active===true};if(m(e.card_chats,i))continue;d(),c$1[r]={...e,card_chats:i},u=true;}continue}if(b(t)){if(t.kind==="computed_values"){let r=t.cardId,e=c$1[r];if(!e)continue;let s=t.values||{};if(m(e.computed_values,s))continue;d(),c$1[r]={...e,computed_values:s},u=true;}else if(t.kind==="data_object"){let r=t.key,e=t.payload,s=g[r]||[];for(let i of s){let n=c$1[i];if(!n)continue;let y=n.requires||{};m(y[r],e)||(d(),c$1[i]={...n,requires:{...y,[r]:e}},u=true);}}else if(t.kind==="card_refreshed"){let r=t.cardId,e=null,s=c$1[r],i=t.card;if(s&&i&&typeof i=="object"&&!Array.isArray(i)){let n=i,y=n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?n.card_data:s.card_data,b=n.requires&&typeof n.requires=="object"&&!Array.isArray(n.requires)?n.requires:s.requires,w=n.computed_values&&typeof n.computed_values=="object"&&!Array.isArray(n.computed_values)?n.computed_values:s.computed_values,A=n.runtime_state&&typeof n.runtime_state=="object"&&!Array.isArray(n.runtime_state)?n.runtime_state:s.runtime_state;e={...s,card:i,card_data:y,requires:b,computed_values:w,runtime_state:A};}if(!e)try{let n=C();n&&(e=h(n,r));}catch{}if(!e||s&&m(s.card,e.card)&&m(s.card_data,e.card_data)&&m(s.requires,e.requires)&&m(s.computed_values,e.computed_values)&&m(s.runtime_state,e.runtime_state))continue;d(),c$1[r]=e,l.includes(r)||(l=[...l,r]),u=true;}else if(t.kind==="card_removed"){let r=t.cardId;if(!c$1[r])continue;if(d(),delete c$1[r],l=l.filter(e=>e!==r),Object.prototype.hasOwnProperty.call(f,r)){let e={...f};delete e[r],f=e;}u=true;}else if(t.kind==="status"){let r=t.status?.cards??[];for(let e of r){let s=e?.name;if(!s||!c$1[s])continue;let i=c$1[s],n=B(e.status),y={...i.card_data||{},status:n,lastRun:e.runtime?.last_transition_at??null,...e.error?.message?{error:e.error.message}:{}};e.error?.message||delete y.error;let b={task_status:e.status??null,card_status:n,runtime:e.runtime?k(e.runtime):{},error:e.error?k(e.error):null,blocked_by:Array.isArray(e.blocked_by)?k(e.blocked_by):[],requires_missing:Array.isArray(e.requires_missing)?k(e.requires_missing):[]};m(i.card_data,y)&&m(i.runtime_state,b)||(d(),c$1[s]={...i,card_data:y,runtime_state:b},u=true);}}}}return u?{payload:a.payload,cardIds:l,modelsById:c$1,cardWatchParties:f}:a}export{x as applyNotification,S as buildBoardState,q as deriveBoardState};//# sourceMappingURL=board-state-reducer.js.map
1
+ import {c,b as b$1}from'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';function b(n){return JSON.parse(JSON.stringify(n))}function k(n,i){if(n===i)return n;try{if(JSON.stringify(n)===JSON.stringify(i))return n}catch{}return i}function m(n,i){if(n===i)return true;try{return JSON.stringify(n)===JSON.stringify(i)}catch{return false}}function q(n){return n==="running"||n==="in-progress"?"loading":n==="failed"?"error":"fresh"}function x(n,i,h){let v=n,f=(v&&Array.isArray(v.cardDefinitions)?v.cardDefinitions:[]).map(p=>p.id),g=i&&i.modelsById||{},o={};for(let p of f){let t=h(n,p),a=g[p];if(!a){o[p]=t;continue}let e=t.card_chats!=null?k(a.card_chats,t.card_chats??null):a.card_chats??null,r={id:t.id,card:k(a.card,t.card),card_data:k(a.card_data,t.card_data),requires:k(a.requires,t.requires),computed_values:k(a.computed_values,t.computed_values),runtime_state:k(a.runtime_state,t.runtime_state),card_chats:e};o[p]=r.card===a.card&&r.card_data===a.card_data&&r.requires===a.requires&&r.computed_values===a.computed_values&&r.runtime_state===a.runtime_state&&r.card_chats===a.card_chats?a:r;}let y=i?.cardWatchParties||{},l=Object.fromEntries(f.filter(p=>Object.prototype.hasOwnProperty.call(y,p)).map(p=>[p,y[p]])),_=i?.pendingComputedValues||{},C=Object.fromEntries(Object.entries(_).filter(([p])=>!f.includes(p)));return {payload:n,cardIds:f,modelsById:o,cardWatchParties:l,pendingComputedValues:C}}function S(n,i={}){if(!n)return n;let h=typeof i.includeCard=="function"?i.includeCard:(()=>true),v=typeof i.mapCard=="function"?i.mapCard:(y=>y),d=false,f=[],g={};for(let y of n.cardIds){let l=n.modelsById[y];if(!l){d=true;continue}if(!h(l,n)){d=true;continue}let _=v(l,n);if(!_||_.id!==y)throw new Error(`deriveBoardState: mapped card must preserve id "${y}"`);_!==l&&(d=true),f.push(y),g[y]=_;}let o=typeof i.mapPayload=="function"?i.mapPayload(n.payload,{sourceState:n,cardIds:f,modelsById:g}):n.payload;return o!==n.payload&&(d=true),!d&&f.length===n.cardIds.length?n:{payload:o,cardIds:f,modelsById:g,cardWatchParties:n.cardWatchParties,pendingComputedValues:n.pendingComputedValues}}function O(n,i,h,v){if(!n||!Array.isArray(i)||i.length===0)return n;let d=n.modelsById,f=n.cardIds,g=n.cardWatchParties||{},o=n.pendingComputedValues||{},y=false,l=false,_={};for(let t of f){let a=d[t],e=a&&a.requires;if(e&&typeof e=="object")for(let r of Object.keys(e))(_[r]=_[r]||[]).push(t);}function C(){y||(d={...d},y=true);}function p(t){if(t.kind!=="card_watchparty"||!t.cardId||!t.channel)return;let a=g[t.cardId]||{},e=Array.isArray(a[t.channel])?a[t.channel]:[],r=e;if(t.clear){if(e.length===0)return;r=[];}else if(t.replace){let c=Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0,u={payload:t.payload,ts:c};if(e.length===1&&e[0]?.ts===u.ts&&m(e[0]?.payload,u.payload))return;r=[u];}else {let c={payload:t.payload,ts:Number.isFinite(Number(t.sentAtMs))?Number(t.sentAtMs):0};r=[...e,c];}g={...g,[t.cardId]:{...a,[t.channel]:r}},l=true;}for(let t of i)if(!(!t||!t.kind)){if(t.kind==="card_watchparty"){p(t);continue}if(c(t)){if(t.kind==="card_chats"){let a=t.cardId,e=d[a];if(!e)continue;let r=Array.isArray(t.messages)?t.messages:e.card_chats?.messages??[],c=typeof t.receiving=="boolean"?t.receiving:e.card_chats?.receiving??false,u=typeof t.processing=="boolean"?t.processing:e.card_chats?.processing??false,s={messages:r,receiving:c,processing:u};if(m(e.card_chats,s))continue;C(),d[a]={...e,card_chats:s},l=true;}else if(t.kind==="chat_messages"){let a=t.cardId,e=d[a];if(!e)continue;let r=Array.isArray(t.messages)?t.messages:[],c=e.card_chats||{receiving:false,processing:false},u={messages:r,receiving:c.receiving,processing:!!c.processing};if(m(e.card_chats,u))continue;C(),d[a]={...e,card_chats:u},l=true;}else if(t.kind==="chat_processing"){let a=t.cardId,e=d[a];if(!e)continue;let r=e.card_chats||{messages:[],receiving:false},c={messages:r.messages,receiving:r.receiving,processing:t.active===true};if(m(e.card_chats,c))continue;C(),d[a]={...e,card_chats:c},l=true;}continue}if(b$1(t)){if(t.kind==="computed_values"){let a=t.cardId,e=d[a],r=t.values||{};if(!e){let c=o[a];if(m(c,r))continue;o={...o,[a]:b(r)},l=true;continue}if(m(e.computed_values,r))continue;C(),d[a]={...e,computed_values:r},l=true;}else if(t.kind==="data_object"){let a=t.key,e=t.payload,r=_[a]||[];for(let c of r){let u=d[c];if(!u)continue;let s=u.requires||{};m(s[a],e)||(C(),d[c]={...u,requires:{...s,[a]:e}},l=true);}}else if(t.kind==="card_refreshed"){let a=t.cardId,e=null,r=d[a],c=t.card;if(r&&c&&typeof c=="object"&&!Array.isArray(c)){let s=c,w=s.card_data&&typeof s.card_data=="object"&&!Array.isArray(s.card_data)?s.card_data:r.card_data,A=s.requires&&typeof s.requires=="object"&&!Array.isArray(s.requires)?s.requires:r.requires,B=s.computed_values&&typeof s.computed_values=="object"&&!Array.isArray(s.computed_values)?s.computed_values:r.computed_values,P=s.runtime_state&&typeof s.runtime_state=="object"&&!Array.isArray(s.runtime_state)?s.runtime_state:r.runtime_state;e={...r,card:c,card_data:w,requires:A,computed_values:B,runtime_state:P};}if(!e)try{let s=v();s&&(e=h(s,a));}catch{}if(!e)continue;let u=o[a];if(u!==void 0&&!m(e.computed_values,u)&&(e={...e,computed_values:b(u)}),r&&m(r.card,e.card)&&m(r.card_data,e.card_data)&&m(r.requires,e.requires)&&m(r.computed_values,e.computed_values)&&m(r.runtime_state,e.runtime_state))continue;C(),d[a]=e,f.includes(a)||(f=[...f,a]),Object.prototype.hasOwnProperty.call(o,a)&&(o={...o},delete o[a]),l=true;}else if(t.kind==="card_removed"){let a=t.cardId;if(!d[a])continue;if(C(),delete d[a],f=f.filter(e=>e!==a),Object.prototype.hasOwnProperty.call(g,a)){let e={...g};delete e[a],g=e;}Object.prototype.hasOwnProperty.call(o,a)&&(o={...o},delete o[a]),l=true;}else if(t.kind==="status"){let a=t.status?.cards??[];for(let e of a){let r=e?.name;if(!r||!d[r])continue;let c=d[r],u=q(e.status),s={...c.card_data||{},status:u,lastRun:e.runtime?.last_transition_at??null,...e.error?.message?{error:e.error.message}:{}};e.error?.message||delete s.error;let w={task_status:e.status??null,card_status:u,runtime:e.runtime?b(e.runtime):{},error:e.error?b(e.error):null,blocked_by:Array.isArray(e.blocked_by)?b(e.blocked_by):[],requires_missing:Array.isArray(e.requires_missing)?b(e.requires_missing):[]};m(c.card_data,s)&&m(c.runtime_state,w)||(C(),d[r]={...c,card_data:s,runtime_state:w},l=true);}}}}return l?{payload:n.payload,cardIds:f,modelsById:d,cardWatchParties:g,pendingComputedValues:o}:n}export{O as applyNotification,x as buildBoardState,S as deriveBoardState};//# sourceMappingURL=board-state-reducer.js.map
2
2
  //# sourceMappingURL=board-state-reducer.js.map
@@ -0,0 +1,3 @@
1
+ import {a,b}from'./chunk-JB4Q2W7I.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$6,c as c$2}from'./chunk-O5UYCGIN.js';import {p,j,k,l,c as c$1,d as d$1,m,n,e as e$1,a as a$8,b as b$3,o}from'./chunk-CZ6ZFWFT.js';import {a as a$4,d as d$2,b as b$2,c as c$3}from'./chunk-FOFGEABN.js';import {a as a$c}from'./chunk-RKKSVOP2.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$9,c as c$4}from'./chunk-O7NOHKVR.js';import {a as a$a,b as b$4}from'./chunk-ZJ5M5COT.js';import {i,d,c,b as b$1,g,h}from'./chunk-5U5NMYGT.js';import {a as a$b}from'./chunk-6MD6FVE3.js';import {y,z,l as l$1}from'./chunk-H5FKNSCO.js';import {a as a$5}from'./chunk-7QNEV5S3.js';import {a as a$7}from'./chunk-BJGK5FNL.js';import {a as a$1}from'./chunk-NIBLKYXN.js';import {e}from'./chunk-UGB7PC4P.js';function ie(R){let{apiBasePath:w,json:b,readJsonBody:$,bootstrapBoard:A,createMcpControlplaneToolRegistry:x,retriggerCard:D,applyCardAction:N,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:q}=R;async function j(T,S,W){let H=T.method||"GET",J=W,f=J.pathname;try{if(H==="POST"&&f===`${w}/mcp-actions`){await A();let p=Date.now(),y=new Date(p).toISOString(),O=await $(T),l=typeof O.tool=="string"?O.tool.trim():"",B=O.args&&typeof O.args=="object"&&!Array.isArray(O.args)?O.args:{};if(!l)return b(S,400,{error:"tool is required"}),!0;let k=a$9(B,"card_id");if(!k)return b(S,400,{error:"MCP action requires card_id"}),!0;if(l==="retrigger-card"||l==="retrigger"){await D(k);let F=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:200}}),!0}let P=c$4(B,"payload");if(l==="chat-send"&&!await E(k)){let F=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:409}),!0}if(l==="chat-send"){let F=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!F||!String(F).trim()){let L=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(L).toISOString(),responseSentAtMs:L,responseStatus:400}),!0}}await N(k,l,P);let I=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(I).toISOString(),responseSentAtMs:I,responseStatus:200}}),!0}if(H==="POST"&&f===`${w}/mcp-controlplane`){await A();let p=await $(T),y=typeof p.tool=="string"?p.tool.trim():"",O=p.args&&typeof p.args=="object"&&!Array.isArray(p.args)?p.args:{};if(!y)return b(S,400,{error:"tool is required"}),!0;try{let l=await a$a(y,O,x());if(l&&typeof l=="object"&&!Array.isArray(l)){let B=l;if(B.status==="fail")return b(S,400,{error:b$4(l,"Request failed")}),!0;if(B.status==="error")return b(S,500,{error:b$4(l,"Internal error")}),!0}b(S,200,l);}catch(l){let B=typeof l?.statusCode=="number"?Number(l.statusCode):500,k=l instanceof Error?l.message:String(l);b(S,B,{error:k});}return !0}let g=f.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/retrigger$`));if(H==="POST"&&g){await A();let p=decodeURIComponent(g[1]);return await D(p),b(S,200,{ok:!0}),!0}let d=f.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/actions$`));if(H==="POST"&&d){await A();let p=decodeURIComponent(d[1]),y=Date.now(),O=new Date(y).toISOString(),l=await $(T),B=l?.actionType;if(B==="chat-send"&&!await E(p)){let P=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:409}),!0}if(B==="chat-send"){let P=l?.payload??{},I=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!I||!String(I).trim()){let F=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:400}),!0}}await N(p,B,l?.payload);let k=Date.now();return b(S,200,{ok:!0,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(k).toISOString(),responseSentAtMs:k,responseStatus:200}),!0}let v=f.match(new RegExp(`^${c$3(w)}/cards/([^/]+)/files/(\\d+)$`));if(H==="GET"&&v){let p=decodeURIComponent(v[1]),y=parseInt(v[2],10),O=J.searchParams.get("sn");return await q(S,p,y,O),!0}return !1}catch(g){let d=g?.statusCode||500;return b(S,d,{error:String(g?.message||g)}),true}}return {handleRuntimeApi:j}}var ze=3e4;function Ke(R){let w=R.socket?.remoteAddress??"";return w==="127.0.0.1"||w==="::1"||w==="::ffff:127.0.0.1"}function ce(R){let{apiBasePath:w,emitNotifications:b,readJsonBody:$,json:A}=R,x=`${w}/notify-q`;async function D(N,E,q){if(q.pathname!==x)return false;if((N.method??"").toUpperCase()!=="POST")return A(E,405,{status:"error",error:"Method not allowed"}),true;if(!Ke(N))return A(E,403,{status:"error",error:"Forbidden"}),true;let j;try{j=await $(N);}catch{return A(E,400,{status:"error",error:"Invalid JSON body"}),true}if(!j||typeof j!="object"||!Array.isArray(j.notifications))return A(E,400,{status:"error",error:"body.notifications must be an array"}),true;let T=j.notifications,{accepted:S,rejected:W}=b$3(T,Date.now(),ze);return S.length>0&&b(S),A(E,200,{status:"success",data:{accepted:S.length,rejected:W}}),true}return {handleNotifyRoute:D}}var de={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},ue="chat-handler-flow-queue",ot="__probe__echo__probe__";function jr(R){let w=String(R.apiBasePath||"/api/board").replace(/\/$/,""),b$3={...de,...R.corsHeaders||{}},$=R.queueLaneTuning??{},A=R.boardId||"",x=R.logger||{info:console.log,warn:console.warn,error:console.error},D=R.invocationAdapter,N=R.chatFlowRunner||null,E=R.notificationTransport||null,q=R.serverUrl||null,j$1=R.executionExtra||{},T=R.onSseClientConnected,S=R.onSseClientDisconnected,W=R.onChannelSubscribed,H=R.onChannelUnsubscribed,J=a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:S}),f=a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function g$1(t){function e(a){return {...a,queueStorageForRef(u,C){return a$7(a.queueStorageForRef(u,C),{lane:C,emitNotification:i$1})}}}function r(a){return {...a,queueStorageForRef(u,C){return h(a.queueStorageForRef(u,C),{lane:C,emitNotification:i$1})}}}function n(a){return {async get(u){return a.get(u)},async set(u){return a.set(u)},async del(u){return a.del(u)},async patch(u){return a.patch(u)},async appendFiles(u){return a.appendFiles(u)}}}function o(a){return {async get(u){return await a.get(u)},async set(u){return await a.set(u)},async del(u){return await a.del(u)},async patch(u){return await a.patch(u)},async appendFiles(u){return await a.appendFiles(u)}}}let s=null;function i$1(a){if(a.kind==="notification-batch"){V(a.notifications,s??void 0);return}V([a],s??void 0);}let c$2=a$4(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),M=t.nonCoreAdapter??(!a$4(c$2)&&l$2(c$2)?c$2:null),h$1=a$4(c$2)?i(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}):y(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}),_=t.nonCore??(M?z(t.baseRef,M,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c$2.chatStorageForRef(t.chatStoreRef),dt,We=a$4(c$2)?(()=>{let a=d(c(b$1(c$2.kvStorageForRef(t.cardStoreRef)),c$2.hashFn),x.warn),u=g(a,{emitNotification:i$1}),C=o(u);return dt={get(m){return C.get(m)},set(m){return C.set(m)}},C})():(()=>{let a=c$2.kvStorageForRef(t.cardStoreRef),C=a$5(l$1({readIndex:()=>a.read("_index"),writeIndex:m=>a.write("_index",m),readCard:m=>a.read(m),writeCard:(m,ft)=>(a.write(m,ft),m),removeCard:m=>{a.delete(m);},cardExists:m=>a.read(m)!==null,defaultCardKey:m=>m},x.warn),{emitNotification:i$1});return dt=C,n(C)})(),lt;if(a$4(c$2)){let a=c$2.blobStorageForRef(t.artifactsStoreRef);lt={async putBytes(u,C){if(a.writeBytes){await a.writeBytes(u,C);return}let m=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(u,m);},async getBytes(u){if(a.readBytes){let m=await a.readBytes(u);if(m!==null)return m}let C=await a.read(u);if(C===null)return null;try{let m=JSON.parse(C);if(m&&m.__kind==="bytes-array"&&Array.isArray(m.data))return new Uint8Array(m.data)}catch{}return new TextEncoder().encode(C)},async listKeys(u){return await a.listKeys(u)}};}else {let a=c$2.blobStorageForRef(t.artifactsStoreRef),u=a$6(a);lt={putBytes(C,m,ft){u.putBytes(C,m,ft);},getBytes(C){return u.getBytes(C)},listKeys(C){return u.list(C).map(m=>m.key)}};}let Je={async init(a){return h$1.init(a)},async status(a){return h$1.status(a)},async getConfig(a){return h$1.getConfig(a)},async getAllOutputsDataObjects(a){return h$1.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return h$1.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return h$1.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return h$1.buildSseOneShotPayload(a)},async upsertCard(a){return h$1.upsertCard(a)},async removeCard(a){return h$1.removeCard(a)},async sourceDataFetched(a){return h$1.sourceDataFetched(a)},async sourceDataFetchFailure(a){return h$1.sourceDataFetchFailure(a)}};return s={label:t.label,board:h$1,nonCore:_,publicCardStore:dt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return lt},get chatStorage(){return Ue},boardAdapter:c$2,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:c$1(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let d$3=R.boards.map(g$1),v=new Map;function p$1(t){return v.get(t)??0}function y$1(t){return t.queueStoreRef}function O(t,e){if(a$4(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(y$1(t),e);return a$b(n)}let r=t.boardAdapter.queueStorageForRef(y$1(t),e);return a$c(r)}function l$2(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function B(t){let e=d$3[p$1(t)];return {files:e?e.filesArtifacts:null}}function k$1(){return c$2()}function P(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function I(t){return "cardId"in t&&typeof t.cardId=="string"?z$1(t.cardId)??void 0:d$3[0]??void 0}function F(t){for(let e of t){let r=I(e);if(r)return r}return d$3[0]??void 0}function L(t,e$2={}){if(!t||t.length===0)return;let r=e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e$2.ctx??F(r);if(e$2.appendState!==false&&o&&e$1(o.notification,n),e$2.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&J.broadcastNotificationBatch(i),s.length>0&&f.broadcastNotificationBatch(s);}if(!(e$2.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function V(t,e){L(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function le(t){if(!t||t.notificationTeardown||!E||!t.notifyRef)return;let e=await E.subscribe(t.notifyRef,r=>{let n=a$8(r);L(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function fe(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let 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 le(t),!t.chatHandlerFlow&&t.chatHandlerRef&&D.describe)try{let o=await D.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?x.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&x.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){x.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ct(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&d$1(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,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&L(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function gt(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 o of n)typeof o.id=="string"&&(v.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of d$3)await fe(t);}async function at(){await G();for(let t=0;t<d$3.length;t++)await ct(d$3[t]),await gt(d$3[t],t),await ct(d$3[t]);}async function Rt(t=false){t||await G();for(let e of d$3){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function z$1(t){return d$3[p$1(t)]??null}async function X(t){let e=z$1(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 pe(){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 d$3)e.push(...await t(r));return e}function yt(){return d$3[0]??null}function me(t){return z$1(t)??yt()}function U(t){let e=me(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ge(t){return await U(t).isProcessing(t)}async function Y(t,e){let r=await tt.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let tt=a$1({append(t,e,r,n,o){return U(t).append(t,e,r,n,o)},readAll(t){return U(t).readAll(t)},readAfter(t,e){return U(t).readAfter(t,e)},clear(t){return U(t).clear(t)},setProcessing(t,e){return U(t).setProcessing(t,e)},isProcessing(t){return U(t).isProcessing(t)},getConfig(t){return U(t).getConfig(t)},setConfig(t,e){return U(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);}}),ht=p({boardContexts:d$3,cardOwnerIndex:v,cardContextForCard:t=>z$1(t),readStatusSnapshot:()=>be(),readDataObjectsByToken:()=>Ce(),readCardRuntimeArtifacts:()=>Se(),readCardFromStore:t=>X(t),readCardDefinitions:()=>pe(),processAccumulatedLaneInternal:t=>Rt(t),reportSourceFetched:(t,e)=>Bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>kt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>St(t,e,r,n,o),chatStorePublic:tt,serverUrl:q,apiBasePath:w}),Re=ht.mcpCardStoreFacade,st=ht.createMcpFacade,ye=j({boardId:A,bootstrapBoard:()=>at(),sseHub:J,onChannelSubscribed:W,onChannelUnsubscribed:H,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>Re()});function he(t){return m(t)}function we(){return n(st())}function wt(){return o({boardId:A,uploadCardFile:St,getMcpFacade:()=>st(),controlplane:ye})}let it=k({boardId:A,boardContexts:d$3,readChatRecords:t=>Fe(t),getChatProcessing:t=>ge(t)}),be=it.readStatusSnapshot,Se=it.readCardRuntimeArtifacts,Ce=it.readDataObjectsByToken,ut=it.buildPublishedRuntimePayload;async function bt(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=z$1(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await X(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,M=e(i)||i;if(o&&JSON.stringify(M)===c)return;let h=await s.cardStoreOps.set({body:M});if(h.status!=="success")throw Object.assign(new Error(h.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let _=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(_.status!=="success")throw Object.assign(new Error(_.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Ae(t,e){await bt(t,e,{syncBoard:true});}async function Be(t,e){await bt(t,e,{syncBoard:false});}async function ke(t){let e=z$1(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await X(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 Pe(t){let e=await tt.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await Y(t,!1);}catch{}}async function Oe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await tt.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function Fe(t){return await U(t).readAll(t)}let St=l({safeCardId:t=>P(t),artifactsStores:t=>B(t),cardFileMetadataStore:()=>k$1(),readCardFromStore:t=>X(t),updateCardLocalOnly:(t,e)=>Be(t,e),writeChatRecord:(t,e,r,n,o)=>Oe(t,e,r,n,o)}).uploadCardFile;async function Ct(t){let e=z$1(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function ve(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function xe(t,e,r=false,n="",o=""){try{let s=await Ct(t);if(!s){try{await Y(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:M}=s;if(!r)try{await Y(t,!0);}catch{}let h={boardId:A,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...j$1,...q?{serverUrl:q}:{}},_=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:ue}}:M;a$4(i.boardAdapter)?await O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}):O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await Y(t,!1);}catch{}x.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Te(t,e,r){if(e.howToRun==="built-in"&&b$2(e)===ue){let n=N,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:A,cardId:String(s.cardId||""),label:t.label,logger:x,serverUrl:q,executionExtra:j$1}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return D.invoke(e,r)}async function Ne(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?z$1(r):yt();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Te(n,t.ref,t.args);if(!o.dispatched){if(r)try{await Y(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Ee(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=wt(),i=ve(r?.text),c=i?i.text:r?.text,M=await a$a("manage.add-chat-entry-and-any-attachments",{board_id:A,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(M?.status!=="success")throw new Error(b$4(M,`chat-send append failed for card ${t}`));let h=M?.data?.id;if(typeof h!="string"||!h)throw new Error(`chat-send did not return an append id for card ${t}`);let _=await a$a("setstate.chat-processing-started",{board_id:A,card_id:t},s);if(_?.status!=="success")throw new Error(b$4(_,`chat-send processing update failed for card ${t}`));xe(t,h,true,o,i?.assistant||"");return}await Ae(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=k$1().normalizeIncoming(r?.files,s);return c.length>0&&k$1().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...b$3,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function At(t,e,r){let n=await X(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=k$1().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=P(t),c=B(t),M=String(s.stored_name||""),h=`${i}/${M}`,_=c.files?await c.files.getBytes(h):null;if(!_)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:_}}async function je(t,e,r,n){let{fileRecord:o,bytes:s}=await At(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function Me(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 _e(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
2
+ `)}async function rt(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(d$2(e)).trim();return r?JSON.parse(r):{}}async function Bt(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let n=d$3[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function kt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=d$3[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let De=b({sseHub:J,queueSseHub:f,corsHeaders:b$3,json:et,buildPublishedRuntimePayload:()=>ut(),onSseClientConnected:T,onChannelSubscribed:W,onChannelUnsubscribed:H,apiBasePath:w,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>at(),boardContexts:d$3,publishPersistedStateSnapshot:t=>ct(t),upsertCardsFromSource:(t,e)=>gt(t,e)}).handleWatchersRoutes,qe=a$2({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpFacade:()=>st(),createMcpToolRegistry:t=>he(t),resolveCardFileDownloadPayload:(t,e,r)=>At(t,e,r),isLikelyTextMimeType:t=>Me(t),sliceTextByLines:(t,e,r)=>_e(t,e,r)}).handleAgentfaceApi,Ie=a$3({apiBasePath:w,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ie({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpControlplaneToolRegistry:()=>wt(),retriggerCard:t=>ke(t),applyCardAction:(t,e,r)=>Ee(t,e,r),resolveChatHandlerTarget:t=>Ct(t),sendCardFileDownloadResponse:(t,e,r,n)=>je(t,e,r,n)}).handleRuntimeApi,He=ce({apiBasePath:w,emitNotifications:t=>V(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Le(t,e,r){return !!(await qe(t,e,r)||await Ie(t,e,r)||await De(t,e,r)||await He(t,e,r)||await $e(t,e,r))}return {get apiBasePath(){return w},get corsHeaders(){return b$3},get queueLaneTuning(){return $},handleRuntimeApi:Le,emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);},buildPublishedRuntimePayload:ut,__drainProcessAccumulatedLane:Rt,handleChatAgentRequest:Ne,clearChatRecords:Pe,reportSourceFetched(t,e){return Bt(t,{ref:e})},reportSourceFetchFailure(t,e){return kt(t,{reason:e})},get cardStore(){return d$3[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Mr(R){let w=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),b={...de,...R.corsHeaders||{}},$=R.serverMetaStore,A=R.boardRuntimeFactory,x=new Map,D="boards-config.json";function N(){let f=$.getText(D);if(!f)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(f)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function E(f){$.putText(D,JSON.stringify(f,null,2));}function q(f){let g=String(f||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return g.length>0&&g.length<=64?g:null}function j(f){if(x.has(f))return x.get(f);let d=N().boards.find(p=>p.id===f)||{},v=A(f,d);return x.set(f,v),v}function T(f,g,d){let v=JSON.stringify(d),p=typeof Buffer<"u"?Buffer.byteLength(v):new TextEncoder().encode(v).length;f.writeHead(g,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":p}),f.end(v);}async function S(f,g,d){let v=f.method||"GET",p=d.pathname;if(v==="GET"&&p===w)return T(g,200,{ok:true,boards:N().boards}),true;if(v==="POST"&&p===w){let y=[];for await(let F of f)y.push(F);let O=typeof Buffer<"u"?Buffer.concat(y).toString("utf-8").trim():new TextDecoder().decode(d$2(y)).trim(),l={};try{l=O?JSON.parse(O):{};}catch{l={};}let B=q(l.id);if(!B)return T(g,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let k=N();if(k.boards.some(F=>F.id===B))return T(g,409,{error:`Board "${B}" is already registered`}),true;let P=typeof l.label=="string"&&l.label.trim()?l.label.trim():B,I={id:B,label:P};for(let[F,L]of Object.entries(l))F==="id"||F==="label"||L!=null&&(I[F]=L);return k.boards.push(I),E(k),T(g,200,{ok:true,board:I}),true}return false}async function W(f,g,d){let p=d.pathname.match(new RegExp(`^${c$3(w)}/([^/]+)(/|$)`));if(!p)return false;let y=q(decodeURIComponent(p[1]));return y?N().boards.some(B=>B.id===y)?!!await j(y).handleRuntimeApi(f,g,d):(T(g,404,{error:`Board "${y}" not registered. POST ${w} with {id} to register it first.`}),true):(T(g,400,{error:"Invalid board id"}),true)}async function H(f,g,d){return !!(await S(f,g,d)||await W(f,g,d))}function J(f){if(!N().boards.some(d=>d.id===f))throw Object.assign(new Error(`Board "${f}" not registered`),{statusCode:404});return {service:j(f)}}return {get apiBasePath(){return w},get corsHeaders(){return b},handleApi:H,requireBoardService:J}}export{jr as a,Mr as b};//# sourceMappingURL=chunk-4LHFO56U.js.map
3
+ //# sourceMappingURL=chunk-4LHFO56U.js.map
@@ -0,0 +1,3 @@
1
+ 'use strict';var chunkLFVMX23W_cjs=require('./chunk-LFVMX23W.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunkNMOUBZXX_cjs=require('./chunk-NMOUBZXX.cjs'),chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkX5CZE2L7_cjs=require('./chunk-X5CZE2L7.cjs'),chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkVNLMJEIX_cjs=require('./chunk-VNLMJEIX.cjs'),chunk5XLFPPTY_cjs=require('./chunk-5XLFPPTY.cjs'),chunkSDJ3747Q_cjs=require('./chunk-SDJ3747Q.cjs'),chunkOF4FPYNI_cjs=require('./chunk-OF4FPYNI.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function ie(R){let{apiBasePath:w,json:b,readJsonBody:$,bootstrapBoard:A,createMcpControlplaneToolRegistry:x,retriggerCard:D,applyCardAction:N,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:q}=R;async function j(T,S,W){let H=T.method||"GET",J=W,f=J.pathname;try{if(H==="POST"&&f===`${w}/mcp-actions`){await A();let p=Date.now(),y=new Date(p).toISOString(),O=await $(T),l=typeof O.tool=="string"?O.tool.trim():"",B=O.args&&typeof O.args=="object"&&!Array.isArray(O.args)?O.args:{};if(!l)return b(S,400,{error:"tool is required"}),!0;let k=chunkLPXVVMQT_cjs.a(B,"card_id");if(!k)return b(S,400,{error:"MCP action requires card_id"}),!0;if(l==="retrigger-card"||l==="retrigger"){await D(k);let F=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:200}}),!0}let P=chunkLPXVVMQT_cjs.c(B,"payload");if(l==="chat-send"&&!await E(k)){let F=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:409}),!0}if(l==="chat-send"){let F=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!F||!String(F).trim()){let L=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(L).toISOString(),responseSentAtMs:L,responseStatus:400}),!0}}await N(k,l,P);let I=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(I).toISOString(),responseSentAtMs:I,responseStatus:200}}),!0}if(H==="POST"&&f===`${w}/mcp-controlplane`){await A();let p=await $(T),y=typeof p.tool=="string"?p.tool.trim():"",O=p.args&&typeof p.args=="object"&&!Array.isArray(p.args)?p.args:{};if(!y)return b(S,400,{error:"tool is required"}),!0;try{let l=await chunk272IYUKT_cjs.a(y,O,x());if(l&&typeof l=="object"&&!Array.isArray(l)){let B=l;if(B.status==="fail")return b(S,400,{error:chunk272IYUKT_cjs.b(l,"Request failed")}),!0;if(B.status==="error")return b(S,500,{error:chunk272IYUKT_cjs.b(l,"Internal error")}),!0}b(S,200,l);}catch(l){let B=typeof l?.statusCode=="number"?Number(l.statusCode):500,k=l instanceof Error?l.message:String(l);b(S,B,{error:k});}return !0}let g=f.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/cards/([^/]+)/retrigger$`));if(H==="POST"&&g){await A();let p=decodeURIComponent(g[1]);return await D(p),b(S,200,{ok:!0}),!0}let d=f.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/cards/([^/]+)/actions$`));if(H==="POST"&&d){await A();let p=decodeURIComponent(d[1]),y=Date.now(),O=new Date(y).toISOString(),l=await $(T),B=l?.actionType;if(B==="chat-send"&&!await E(p)){let P=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:409}),!0}if(B==="chat-send"){let P=l?.payload??{},I=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!I||!String(I).trim()){let F=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:400}),!0}}await N(p,B,l?.payload);let k=Date.now();return b(S,200,{ok:!0,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(k).toISOString(),responseSentAtMs:k,responseStatus:200}),!0}let v=f.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/cards/([^/]+)/files/(\\d+)$`));if(H==="GET"&&v){let p=decodeURIComponent(v[1]),y=parseInt(v[2],10),O=J.searchParams.get("sn");return await q(S,p,y,O),!0}return !1}catch(g){let d=g?.statusCode||500;return b(S,d,{error:String(g?.message||g)}),true}}return {handleRuntimeApi:j}}var ze=3e4;function Ke(R){let w=R.socket?.remoteAddress??"";return w==="127.0.0.1"||w==="::1"||w==="::ffff:127.0.0.1"}function ce(R){let{apiBasePath:w,emitNotifications:b,readJsonBody:$,json:A}=R,x=`${w}/notify-q`;async function D(N,E,q){if(q.pathname!==x)return false;if((N.method??"").toUpperCase()!=="POST")return A(E,405,{status:"error",error:"Method not allowed"}),true;if(!Ke(N))return A(E,403,{status:"error",error:"Forbidden"}),true;let j;try{j=await $(N);}catch{return A(E,400,{status:"error",error:"Invalid JSON body"}),true}if(!j||typeof j!="object"||!Array.isArray(j.notifications))return A(E,400,{status:"error",error:"body.notifications must be an array"}),true;let T=j.notifications,{accepted:S,rejected:W}=chunkNMOUBZXX_cjs.b(T,Date.now(),ze);return S.length>0&&b(S),A(E,200,{status:"success",data:{accepted:S.length,rejected:W}}),true}return {handleNotifyRoute:D}}var de={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},ue="chat-handler-flow-queue",ot="__probe__echo__probe__";function jr(R){let w=String(R.apiBasePath||"/api/board").replace(/\/$/,""),b={...de,...R.corsHeaders||{}},$=R.queueLaneTuning??{},A=R.boardId||"",x=R.logger||{info:console.log,warn:console.warn,error:console.error},D=R.invocationAdapter,N=R.chatFlowRunner||null,E=R.notificationTransport||null,q=R.serverUrl||null,j=R.executionExtra||{},T=R.onSseClientConnected,S=R.onSseClientDisconnected,W=R.onChannelSubscribed,H=R.onChannelUnsubscribed,J=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:S}),f=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function g(t){function e(a){return {...a,queueStorageForRef(u,C){return chunkSDJ3747Q_cjs.a(a.queueStorageForRef(u,C),{lane:C,emitNotification:i})}}}function r(a){return {...a,queueStorageForRef(u,C){return chunkX5CZE2L7_cjs.h(a.queueStorageForRef(u,C),{lane:C,emitNotification:i})}}}function n(a){return {async get(u){return a.get(u)},async set(u){return a.set(u)},async del(u){return a.del(u)},async patch(u){return a.patch(u)},async appendFiles(u){return a.appendFiles(u)}}}function o(a){return {async get(u){return await a.get(u)},async set(u){return await a.set(u)},async del(u){return await a.del(u)},async patch(u){return await a.patch(u)},async appendFiles(u){return await a.appendFiles(u)}}}let s=null;function i(a){if(a.kind==="notification-batch"){V(a.notifications,s??void 0);return}V([a],s??void 0);}let c=chunkBQUQTOPB_cjs.a(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),M=t.nonCoreAdapter??(!chunkBQUQTOPB_cjs.a(c)&&l(c)?c:null),h=chunkBQUQTOPB_cjs.a(c)?chunkX5CZE2L7_cjs.i(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}):chunkVNLMJEIX_cjs.y(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}),_=t.nonCore??(M?chunkVNLMJEIX_cjs.z(t.baseRef,M,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c.chatStorageForRef(t.chatStoreRef),dt,We=chunkBQUQTOPB_cjs.a(c)?(()=>{let a=chunkX5CZE2L7_cjs.d(chunkX5CZE2L7_cjs.c(chunkX5CZE2L7_cjs.b(c.kvStorageForRef(t.cardStoreRef)),c.hashFn),x.warn),u=chunkX5CZE2L7_cjs.g(a,{emitNotification:i}),C=o(u);return dt={get(m){return C.get(m)},set(m){return C.set(m)}},C})():(()=>{let a=c.kvStorageForRef(t.cardStoreRef),C=chunk5XLFPPTY_cjs.a(chunkVNLMJEIX_cjs.l({readIndex:()=>a.read("_index"),writeIndex:m=>a.write("_index",m),readCard:m=>a.read(m),writeCard:(m,ft)=>(a.write(m,ft),m),removeCard:m=>{a.delete(m);},cardExists:m=>a.read(m)!==null,defaultCardKey:m=>m},x.warn),{emitNotification:i});return dt=C,n(C)})(),lt;if(chunkBQUQTOPB_cjs.a(c)){let a=c.blobStorageForRef(t.artifactsStoreRef);lt={async putBytes(u,C){if(a.writeBytes){await a.writeBytes(u,C);return}let m=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(u,m);},async getBytes(u){if(a.readBytes){let m=await a.readBytes(u);if(m!==null)return m}let C=await a.read(u);if(C===null)return null;try{let m=JSON.parse(C);if(m&&m.__kind==="bytes-array"&&Array.isArray(m.data))return new Uint8Array(m.data)}catch{}return new TextEncoder().encode(C)},async listKeys(u){return await a.listKeys(u)}};}else {let a=c.blobStorageForRef(t.artifactsStoreRef),u=chunkNBJTYAYN_cjs.a(a);lt={putBytes(C,m,ft){u.putBytes(C,m,ft);},getBytes(C){return u.getBytes(C)},listKeys(C){return u.list(C).map(m=>m.key)}};}let Je={async init(a){return h.init(a)},async status(a){return h.status(a)},async getConfig(a){return h.getConfig(a)},async getAllOutputsDataObjects(a){return h.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return h.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return h.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return h.buildSseOneShotPayload(a)},async upsertCard(a){return h.upsertCard(a)},async removeCard(a){return h.removeCard(a)},async sourceDataFetched(a){return h.sourceDataFetched(a)},async sourceDataFetchFailure(a){return h.sourceDataFetchFailure(a)}};return s={label:t.label,board:h,nonCore:_,publicCardStore:dt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return lt},get chatStorage(){return Ue},boardAdapter:c,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:chunkNMOUBZXX_cjs.c(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let d=R.boards.map(g),v=new Map;function p(t){return v.get(t)??0}function y(t){return t.queueStoreRef}function O(t,e){if(chunkBQUQTOPB_cjs.a(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(y(t),e);return chunkWRMOGPRG_cjs.a(n)}let r=t.boardAdapter.queueStorageForRef(y(t),e);return chunkGPCMBPLK_cjs.a(r)}function l(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function B(t){let e=d[p(t)];return {files:e?e.filesArtifacts:null}}function k(){return chunkNBJTYAYN_cjs.c()}function P(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function I(t){return "cardId"in t&&typeof t.cardId=="string"?z(t.cardId)??void 0:d[0]??void 0}function F(t){for(let e of t){let r=I(e);if(r)return r}return d[0]??void 0}function L(t,e={}){if(!t||t.length===0)return;let r=chunk2RIHC5TZ_cjs.e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??F(r);if(e.appendState!==false&&o&&chunkNMOUBZXX_cjs.e(o.notification,n),e.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&J.broadcastNotificationBatch(i),s.length>0&&f.broadcastNotificationBatch(s);}if(!(e.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function V(t,e){L(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function le(t){if(!t||t.notificationTeardown||!E||!t.notifyRef)return;let e=await E.subscribe(t.notifyRef,r=>{let n=chunkNMOUBZXX_cjs.a(r);L(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function fe(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let 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 le(t),!t.chatHandlerFlow&&t.chatHandlerRef&&D.describe)try{let o=await D.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?x.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&x.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){x.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ct(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&chunkNMOUBZXX_cjs.d(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,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&L(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function gt(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 o of n)typeof o.id=="string"&&(v.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of d)await fe(t);}async function at(){await G();for(let t=0;t<d.length;t++)await ct(d[t]),await gt(d[t],t),await ct(d[t]);}async function Rt(t=false){t||await G();for(let e of d){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function z(t){return d[p(t)]??null}async function X(t){let e=z(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function pe(){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 d)e.push(...await t(r));return e}function yt(){return d[0]??null}function me(t){return z(t)??yt()}function U(t){let e=me(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ge(t){return await U(t).isProcessing(t)}async function Y(t,e){let r=await tt.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let tt=chunkOF4FPYNI_cjs.a({append(t,e,r,n,o){return U(t).append(t,e,r,n,o)},readAll(t){return U(t).readAll(t)},readAfter(t,e){return U(t).readAfter(t,e)},clear(t){return U(t).clear(t)},setProcessing(t,e){return U(t).setProcessing(t,e)},isProcessing(t){return U(t).isProcessing(t)},getConfig(t){return U(t).getConfig(t)},setConfig(t,e){return U(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);}}),ht=chunkNMOUBZXX_cjs.p({boardContexts:d,cardOwnerIndex:v,cardContextForCard:t=>z(t),readStatusSnapshot:()=>be(),readDataObjectsByToken:()=>Ce(),readCardRuntimeArtifacts:()=>Se(),readCardFromStore:t=>X(t),readCardDefinitions:()=>pe(),processAccumulatedLaneInternal:t=>Rt(t),reportSourceFetched:(t,e)=>Bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>kt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>St(t,e,r,n,o),chatStorePublic:tt,serverUrl:q,apiBasePath:w}),Re=ht.mcpCardStoreFacade,st=ht.createMcpFacade,ye=chunkNMOUBZXX_cjs.j({boardId:A,bootstrapBoard:()=>at(),sseHub:J,onChannelSubscribed:W,onChannelUnsubscribed:H,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>Re()});function he(t){return chunkNMOUBZXX_cjs.m(t)}function we(){return chunkNMOUBZXX_cjs.n(st())}function wt(){return chunkNMOUBZXX_cjs.o({boardId:A,uploadCardFile:St,getMcpFacade:()=>st(),controlplane:ye})}let it=chunkNMOUBZXX_cjs.k({boardId:A,boardContexts:d,readChatRecords:t=>Fe(t),getChatProcessing:t=>ge(t)}),be=it.readStatusSnapshot,Se=it.readCardRuntimeArtifacts,Ce=it.readDataObjectsByToken,ut=it.buildPublishedRuntimePayload;async function bt(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=z(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await X(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,M=e(i)||i;if(o&&JSON.stringify(M)===c)return;let h=await s.cardStoreOps.set({body:M});if(h.status!=="success")throw Object.assign(new Error(h.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let _=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(_.status!=="success")throw Object.assign(new Error(_.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Ae(t,e){await bt(t,e,{syncBoard:true});}async function Be(t,e){await bt(t,e,{syncBoard:false});}async function ke(t){let e=z(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await X(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 Pe(t){let e=await tt.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await Y(t,!1);}catch{}}async function Oe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await tt.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function Fe(t){return await U(t).readAll(t)}let St=chunkNMOUBZXX_cjs.l({safeCardId:t=>P(t),artifactsStores:t=>B(t),cardFileMetadataStore:()=>k(),readCardFromStore:t=>X(t),updateCardLocalOnly:(t,e)=>Be(t,e),writeChatRecord:(t,e,r,n,o)=>Oe(t,e,r,n,o)}).uploadCardFile;async function Ct(t){let e=z(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function ve(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function xe(t,e,r=false,n="",o=""){try{let s=await Ct(t);if(!s){try{await Y(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:M}=s;if(!r)try{await Y(t,!0);}catch{}let h={boardId:A,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...j,...q?{serverUrl:q}:{}},_=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:ue}}:M;chunkBQUQTOPB_cjs.a(i.boardAdapter)?await O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}):O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await Y(t,!1);}catch{}x.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Te(t,e,r){if(e.howToRun==="built-in"&&chunkBQUQTOPB_cjs.b(e)===ue){let n=N,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:A,cardId:String(s.cardId||""),label:t.label,logger:x,serverUrl:q,executionExtra:j}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return D.invoke(e,r)}async function Ne(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?z(r):yt();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Te(n,t.ref,t.args);if(!o.dispatched){if(r)try{await Y(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Ee(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=wt(),i=ve(r?.text),c=i?i.text:r?.text,M=await chunk272IYUKT_cjs.a("manage.add-chat-entry-and-any-attachments",{board_id:A,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(M?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(M,`chat-send append failed for card ${t}`));let h=M?.data?.id;if(typeof h!="string"||!h)throw new Error(`chat-send did not return an append id for card ${t}`);let _=await chunk272IYUKT_cjs.a("setstate.chat-processing-started",{board_id:A,card_id:t},s);if(_?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(_,`chat-send processing update failed for card ${t}`));xe(t,h,true,o,i?.assistant||"");return}await Ae(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=k().normalizeIncoming(r?.files,s);return c.length>0&&k().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function At(t,e,r){let n=await X(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=k().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=P(t),c=B(t),M=String(s.stored_name||""),h=`${i}/${M}`,_=c.files?await c.files.getBytes(h):null;if(!_)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:_}}async function je(t,e,r,n){let{fileRecord:o,bytes:s}=await At(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function Me(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 _e(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
2
+ `)}async function rt(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(chunkBQUQTOPB_cjs.d(e)).trim();return r?JSON.parse(r):{}}async function Bt(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let n=d[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function kt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=d[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let De=chunkLFVMX23W_cjs.b({sseHub:J,queueSseHub:f,corsHeaders:b,json:et,buildPublishedRuntimePayload:()=>ut(),onSseClientConnected:T,onChannelSubscribed:W,onChannelUnsubscribed:H,apiBasePath:w,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>at(),boardContexts:d,publishPersistedStateSnapshot:t=>ct(t),upsertCardsFromSource:(t,e)=>gt(t,e)}).handleWatchersRoutes,qe=chunk7FGPOGRV_cjs.a({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpFacade:()=>st(),createMcpToolRegistry:t=>he(t),resolveCardFileDownloadPayload:(t,e,r)=>At(t,e,r),isLikelyTextMimeType:t=>Me(t),sliceTextByLines:(t,e,r)=>_e(t,e,r)}).handleAgentfaceApi,Ie=chunkNM6O35RY_cjs.a({apiBasePath:w,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ie({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpControlplaneToolRegistry:()=>wt(),retriggerCard:t=>ke(t),applyCardAction:(t,e,r)=>Ee(t,e,r),resolveChatHandlerTarget:t=>Ct(t),sendCardFileDownloadResponse:(t,e,r,n)=>je(t,e,r,n)}).handleRuntimeApi,He=ce({apiBasePath:w,emitNotifications:t=>V(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Le(t,e,r){return !!(await qe(t,e,r)||await Ie(t,e,r)||await De(t,e,r)||await He(t,e,r)||await $e(t,e,r))}return {get apiBasePath(){return w},get corsHeaders(){return b},get queueLaneTuning(){return $},handleRuntimeApi:Le,emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);},buildPublishedRuntimePayload:ut,__drainProcessAccumulatedLane:Rt,handleChatAgentRequest:Ne,clearChatRecords:Pe,reportSourceFetched(t,e){return Bt(t,{ref:e})},reportSourceFetchFailure(t,e){return kt(t,{reason:e})},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 Mr(R){let w=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),b={...de,...R.corsHeaders||{}},$=R.serverMetaStore,A=R.boardRuntimeFactory,x=new Map,D="boards-config.json";function N(){let f=$.getText(D);if(!f)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(f)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function E(f){$.putText(D,JSON.stringify(f,null,2));}function q(f){let g=String(f||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return g.length>0&&g.length<=64?g:null}function j(f){if(x.has(f))return x.get(f);let d=N().boards.find(p=>p.id===f)||{},v=A(f,d);return x.set(f,v),v}function T(f,g,d){let v=JSON.stringify(d),p=typeof Buffer<"u"?Buffer.byteLength(v):new TextEncoder().encode(v).length;f.writeHead(g,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":p}),f.end(v);}async function S(f,g,d){let v=f.method||"GET",p=d.pathname;if(v==="GET"&&p===w)return T(g,200,{ok:true,boards:N().boards}),true;if(v==="POST"&&p===w){let y=[];for await(let F of f)y.push(F);let O=typeof Buffer<"u"?Buffer.concat(y).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(y)).trim(),l={};try{l=O?JSON.parse(O):{};}catch{l={};}let B=q(l.id);if(!B)return T(g,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let k=N();if(k.boards.some(F=>F.id===B))return T(g,409,{error:`Board "${B}" is already registered`}),true;let P=typeof l.label=="string"&&l.label.trim()?l.label.trim():B,I={id:B,label:P};for(let[F,L]of Object.entries(l))F==="id"||F==="label"||L!=null&&(I[F]=L);return k.boards.push(I),E(k),T(g,200,{ok:true,board:I}),true}return false}async function W(f,g,d){let p=d.pathname.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/([^/]+)(/|$)`));if(!p)return false;let y=q(decodeURIComponent(p[1]));return y?N().boards.some(B=>B.id===y)?!!await j(y).handleRuntimeApi(f,g,d):(T(g,404,{error:`Board "${y}" not registered. POST ${w} with {id} to register it first.`}),true):(T(g,400,{error:"Invalid board id"}),true)}async function H(f,g,d){return !!(await S(f,g,d)||await W(f,g,d))}function J(f){if(!N().boards.some(d=>d.id===f))throw Object.assign(new Error(`Board "${f}" not registered`),{statusCode:404});return {service:j(f)}}return {get apiBasePath(){return w},get corsHeaders(){return b},handleApi:H,requireBoardService:J}}exports.a=jr;exports.b=Mr;//# sourceMappingURL=chunk-U6JMXOER.cjs.map
3
+ //# sourceMappingURL=chunk-U6JMXOER.cjs.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkBDT43KYE_cjs=require('../chunk-BDT43KYE.cjs');require('../chunk-LFVMX23W.cjs'),require('../chunk-NM6O35RY.cjs'),require('../chunk-NBJTYAYN.cjs'),require('../chunk-NMOUBZXX.cjs');var chunkBQJVCCFU_cjs=require('../chunk-BQJVCCFU.cjs');require('../chunk-BQUQTOPB.cjs'),require('../chunk-GPCMBPLK.cjs'),require('../chunk-7FGPOGRV.cjs'),require('../chunk-LPXVVMQT.cjs'),require('../chunk-272IYUKT.cjs'),require('../chunk-X5CZE2L7.cjs'),require('../chunk-WRMOGPRG.cjs'),require('../chunk-VNLMJEIX.cjs'),require('../chunk-7JVHYHT2.cjs'),require('../chunk-VQCIOKJV.cjs'),require('../chunk-G4XXRHL2.cjs'),require('../chunk-LODXIALE.cjs'),require('../chunk-GHUW6P4G.cjs'),require('../chunk-QBEQL4TL.cjs'),require('../chunk-QEHKMLHA.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-5XLFPPTY.cjs'),require('../chunk-SDJ3747Q.cjs'),require('../chunk-OF4FPYNI.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createMultiBoardServerRuntime",{enumerable:true,get:function(){return chunkBDT43KYE_cjs.b}});Object.defineProperty(exports,"createSingleBoardServerRuntime",{enumerable:true,get:function(){return chunkBDT43KYE_cjs.a}});Object.defineProperty(exports,"createHostedBoardQueueLaneRegistry",{enumerable:true,get:function(){return chunkBQJVCCFU_cjs.a}});//# sourceMappingURL=index.cjs.map
1
+ 'use strict';var chunkU6JMXOER_cjs=require('../chunk-U6JMXOER.cjs');require('../chunk-LFVMX23W.cjs'),require('../chunk-NM6O35RY.cjs'),require('../chunk-NBJTYAYN.cjs'),require('../chunk-NMOUBZXX.cjs');var chunkBQJVCCFU_cjs=require('../chunk-BQJVCCFU.cjs');require('../chunk-BQUQTOPB.cjs'),require('../chunk-GPCMBPLK.cjs'),require('../chunk-7FGPOGRV.cjs'),require('../chunk-LPXVVMQT.cjs'),require('../chunk-272IYUKT.cjs'),require('../chunk-X5CZE2L7.cjs'),require('../chunk-WRMOGPRG.cjs'),require('../chunk-VNLMJEIX.cjs'),require('../chunk-7JVHYHT2.cjs'),require('../chunk-VQCIOKJV.cjs'),require('../chunk-G4XXRHL2.cjs'),require('../chunk-LODXIALE.cjs'),require('../chunk-GHUW6P4G.cjs'),require('../chunk-QBEQL4TL.cjs'),require('../chunk-QEHKMLHA.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-5XLFPPTY.cjs'),require('../chunk-SDJ3747Q.cjs'),require('../chunk-OF4FPYNI.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createMultiBoardServerRuntime",{enumerable:true,get:function(){return chunkU6JMXOER_cjs.b}});Object.defineProperty(exports,"createSingleBoardServerRuntime",{enumerable:true,get:function(){return chunkU6JMXOER_cjs.a}});Object.defineProperty(exports,"createHostedBoardQueueLaneRegistry",{enumerable:true,get:function(){return chunkBQJVCCFU_cjs.a}});//# sourceMappingURL=index.cjs.map
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1,2 +1,2 @@
1
- export{b as createMultiBoardServerRuntime,a as createSingleBoardServerRuntime}from'../chunk-WQANIJAQ.js';import'../chunk-JB4Q2W7I.js';import'../chunk-XYN5D3GL.js';import'../chunk-O5UYCGIN.js';import'../chunk-CZ6ZFWFT.js';export{a as createHostedBoardQueueLaneRegistry}from'../chunk-7UJQMFVS.js';import'../chunk-FOFGEABN.js';import'../chunk-RKKSVOP2.js';import'../chunk-NTICU4OK.js';import'../chunk-O7NOHKVR.js';import'../chunk-ZJ5M5COT.js';import'../chunk-5U5NMYGT.js';import'../chunk-6MD6FVE3.js';import'../chunk-H5FKNSCO.js';import'../chunk-ANKA7HEJ.js';import'../chunk-44L64VQ2.js';import'../chunk-VGT3TRQG.js';import'../chunk-WDPOGXTY.js';import'../chunk-6M3RIGUH.js';import'../chunk-ATOQP3BD.js';import'../chunk-YT76JNKE.js';import'../chunk-MNEOJWPS.js';import'../chunk-7QNEV5S3.js';import'../chunk-BJGK5FNL.js';import'../chunk-NIBLKYXN.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
1
+ export{b as createMultiBoardServerRuntime,a as createSingleBoardServerRuntime}from'../chunk-4LHFO56U.js';import'../chunk-JB4Q2W7I.js';import'../chunk-XYN5D3GL.js';import'../chunk-O5UYCGIN.js';import'../chunk-CZ6ZFWFT.js';export{a as createHostedBoardQueueLaneRegistry}from'../chunk-7UJQMFVS.js';import'../chunk-FOFGEABN.js';import'../chunk-RKKSVOP2.js';import'../chunk-NTICU4OK.js';import'../chunk-O7NOHKVR.js';import'../chunk-ZJ5M5COT.js';import'../chunk-5U5NMYGT.js';import'../chunk-6MD6FVE3.js';import'../chunk-H5FKNSCO.js';import'../chunk-ANKA7HEJ.js';import'../chunk-44L64VQ2.js';import'../chunk-VGT3TRQG.js';import'../chunk-WDPOGXTY.js';import'../chunk-6M3RIGUH.js';import'../chunk-ATOQP3BD.js';import'../chunk-YT76JNKE.js';import'../chunk-MNEOJWPS.js';import'../chunk-7QNEV5S3.js';import'../chunk-BJGK5FNL.js';import'../chunk-NIBLKYXN.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkBDT43KYE_cjs=require('../chunk-BDT43KYE.cjs');require('../chunk-LFVMX23W.cjs'),require('../chunk-NM6O35RY.cjs'),require('../chunk-NBJTYAYN.cjs'),require('../chunk-NMOUBZXX.cjs'),require('../chunk-BQJVCCFU.cjs'),require('../chunk-BQUQTOPB.cjs'),require('../chunk-GPCMBPLK.cjs'),require('../chunk-7FGPOGRV.cjs'),require('../chunk-LPXVVMQT.cjs'),require('../chunk-272IYUKT.cjs'),require('../chunk-X5CZE2L7.cjs'),require('../chunk-WRMOGPRG.cjs'),require('../chunk-VNLMJEIX.cjs'),require('../chunk-7JVHYHT2.cjs'),require('../chunk-VQCIOKJV.cjs'),require('../chunk-G4XXRHL2.cjs'),require('../chunk-LODXIALE.cjs'),require('../chunk-GHUW6P4G.cjs'),require('../chunk-QBEQL4TL.cjs'),require('../chunk-QEHKMLHA.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-5XLFPPTY.cjs'),require('../chunk-SDJ3747Q.cjs'),require('../chunk-OF4FPYNI.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');var a=["/mcp","/mcp-raw","/mcp-actions","/mcp-controlplane","/mcp-webhooks","/notify-q"];function l(n,e){return a.some(r=>e===`${n}${r}`)}function s(n,e){return a.some(r=>{let i=`${r}`;if(!e.startsWith(`${n}/`)||!e.endsWith(i))return false;let t=e.slice(n.length+1,e.length-i.length);return t.length>0&&!t.includes("/")})}function c(n){let e=chunkBDT43KYE_cjs.a(n);return {...e,async handleRuntimeApi(r,i,t){return l(e.apiBasePath,t.pathname)?e.handleRuntimeApi(r,i,t):false}}}function d(n){let e=chunkBDT43KYE_cjs.b(n);return {...e,async handleApi(r,i,t){return s(e.apiBasePath,t.pathname)?e.handleApi(r,i,t):false}}}exports.createMultiBoardServerRuntime=d;exports.createSingleBoardServerRuntime=c;//# sourceMappingURL=index.cjs.map
1
+ 'use strict';var chunkU6JMXOER_cjs=require('../chunk-U6JMXOER.cjs');require('../chunk-LFVMX23W.cjs'),require('../chunk-NM6O35RY.cjs'),require('../chunk-NBJTYAYN.cjs'),require('../chunk-NMOUBZXX.cjs'),require('../chunk-BQJVCCFU.cjs'),require('../chunk-BQUQTOPB.cjs'),require('../chunk-GPCMBPLK.cjs'),require('../chunk-7FGPOGRV.cjs'),require('../chunk-LPXVVMQT.cjs'),require('../chunk-272IYUKT.cjs'),require('../chunk-X5CZE2L7.cjs'),require('../chunk-WRMOGPRG.cjs'),require('../chunk-VNLMJEIX.cjs'),require('../chunk-7JVHYHT2.cjs'),require('../chunk-VQCIOKJV.cjs'),require('../chunk-G4XXRHL2.cjs'),require('../chunk-LODXIALE.cjs'),require('../chunk-GHUW6P4G.cjs'),require('../chunk-QBEQL4TL.cjs'),require('../chunk-QEHKMLHA.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-5XLFPPTY.cjs'),require('../chunk-SDJ3747Q.cjs'),require('../chunk-OF4FPYNI.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');var a=["/mcp","/mcp-raw","/mcp-actions","/mcp-controlplane","/mcp-webhooks","/notify-q"];function l(n,e){return a.some(r=>e===`${n}${r}`)}function s(n,e){return a.some(r=>{let i=`${r}`;if(!e.startsWith(`${n}/`)||!e.endsWith(i))return false;let t=e.slice(n.length+1,e.length-i.length);return t.length>0&&!t.includes("/")})}function c(n){let e=chunkU6JMXOER_cjs.a(n);return {...e,async handleRuntimeApi(r,i,t){return l(e.apiBasePath,t.pathname)?e.handleRuntimeApi(r,i,t):false}}}function d(n){let e=chunkU6JMXOER_cjs.b(n);return {...e,async handleApi(r,i,t){return s(e.apiBasePath,t.pathname)?e.handleApi(r,i,t):false}}}exports.createMultiBoardServerRuntime=d;exports.createSingleBoardServerRuntime=c;//# sourceMappingURL=index.cjs.map
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1,2 +1,2 @@
1
- import {a as a$1,b}from'../chunk-WQANIJAQ.js';import'../chunk-JB4Q2W7I.js';import'../chunk-XYN5D3GL.js';import'../chunk-O5UYCGIN.js';import'../chunk-CZ6ZFWFT.js';import'../chunk-7UJQMFVS.js';import'../chunk-FOFGEABN.js';import'../chunk-RKKSVOP2.js';import'../chunk-NTICU4OK.js';import'../chunk-O7NOHKVR.js';import'../chunk-ZJ5M5COT.js';import'../chunk-5U5NMYGT.js';import'../chunk-6MD6FVE3.js';import'../chunk-H5FKNSCO.js';import'../chunk-ANKA7HEJ.js';import'../chunk-44L64VQ2.js';import'../chunk-VGT3TRQG.js';import'../chunk-WDPOGXTY.js';import'../chunk-6M3RIGUH.js';import'../chunk-ATOQP3BD.js';import'../chunk-YT76JNKE.js';import'../chunk-MNEOJWPS.js';import'../chunk-7QNEV5S3.js';import'../chunk-BJGK5FNL.js';import'../chunk-NIBLKYXN.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';var a=["/mcp","/mcp-raw","/mcp-actions","/mcp-controlplane","/mcp-webhooks","/notify-q"];function l(n,e){return a.some(r=>e===`${n}${r}`)}function s(n,e){return a.some(r=>{let i=`${r}`;if(!e.startsWith(`${n}/`)||!e.endsWith(i))return false;let t=e.slice(n.length+1,e.length-i.length);return t.length>0&&!t.includes("/")})}function c(n){let e=a$1(n);return {...e,async handleRuntimeApi(r,i,t){return l(e.apiBasePath,t.pathname)?e.handleRuntimeApi(r,i,t):false}}}function d(n){let e=b(n);return {...e,async handleApi(r,i,t){return s(e.apiBasePath,t.pathname)?e.handleApi(r,i,t):false}}}export{d as createMultiBoardServerRuntime,c as createSingleBoardServerRuntime};//# sourceMappingURL=index.js.map
1
+ import {a as a$1,b}from'../chunk-4LHFO56U.js';import'../chunk-JB4Q2W7I.js';import'../chunk-XYN5D3GL.js';import'../chunk-O5UYCGIN.js';import'../chunk-CZ6ZFWFT.js';import'../chunk-7UJQMFVS.js';import'../chunk-FOFGEABN.js';import'../chunk-RKKSVOP2.js';import'../chunk-NTICU4OK.js';import'../chunk-O7NOHKVR.js';import'../chunk-ZJ5M5COT.js';import'../chunk-5U5NMYGT.js';import'../chunk-6MD6FVE3.js';import'../chunk-H5FKNSCO.js';import'../chunk-ANKA7HEJ.js';import'../chunk-44L64VQ2.js';import'../chunk-VGT3TRQG.js';import'../chunk-WDPOGXTY.js';import'../chunk-6M3RIGUH.js';import'../chunk-ATOQP3BD.js';import'../chunk-YT76JNKE.js';import'../chunk-MNEOJWPS.js';import'../chunk-7QNEV5S3.js';import'../chunk-BJGK5FNL.js';import'../chunk-NIBLKYXN.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';var a=["/mcp","/mcp-raw","/mcp-actions","/mcp-controlplane","/mcp-webhooks","/notify-q"];function l(n,e){return a.some(r=>e===`${n}${r}`)}function s(n,e){return a.some(r=>{let i=`${r}`;if(!e.startsWith(`${n}/`)||!e.endsWith(i))return false;let t=e.slice(n.length+1,e.length-i.length);return t.length>0&&!t.includes("/")})}function c(n){let e=a$1(n);return {...e,async handleRuntimeApi(r,i,t){return l(e.apiBasePath,t.pathname)?e.handleRuntimeApi(r,i,t):false}}}function d(n){let e=b(n);return {...e,async handleApi(r,i,t){return s(e.apiBasePath,t.pathname)?e.handleApi(r,i,t):false}}}export{d as createMultiBoardServerRuntime,c as createSingleBoardServerRuntime};//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "yaml-flow",
3
- "version": "8.11.0",
3
+ "version": "8.11.1",
4
4
  "description": "Unified workflow engine: step-machine (sequential) + event-graph (stateless DAG) with pluggable storage",
5
5
  "author": "",
6
6
  "license": "MIT",
@@ -1,3 +0,0 @@
1
- 'use strict';var chunkLFVMX23W_cjs=require('./chunk-LFVMX23W.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunkNMOUBZXX_cjs=require('./chunk-NMOUBZXX.cjs'),chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkX5CZE2L7_cjs=require('./chunk-X5CZE2L7.cjs'),chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkVNLMJEIX_cjs=require('./chunk-VNLMJEIX.cjs'),chunk5XLFPPTY_cjs=require('./chunk-5XLFPPTY.cjs'),chunkSDJ3747Q_cjs=require('./chunk-SDJ3747Q.cjs'),chunkOF4FPYNI_cjs=require('./chunk-OF4FPYNI.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function ce(R){let{apiBasePath:h,json:w,readJsonBody:L,initBoardAndSetup:F,bootstrapBoard:v,buildPublishedRuntimePayload:W,createMcpControlplaneToolRegistry:j,retriggerCard:M,applyCardAction:I,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:$}=R;async function J(H,B,V){let l=H.method||"GET",A=V,u=A.pathname;try{if(l==="POST"&&u===`${h}/mcp-actions`){await v();let m=Date.now(),b=new Date(m).toISOString(),S=await L(H),f=typeof S.tool=="string"?S.tool.trim():"",T=S.args&&typeof S.args=="object"&&!Array.isArray(S.args)?S.args:{};if(!f)return w(B,400,{error:"tool is required"}),!0;let P=chunkLPXVVMQT_cjs.a(T,"card_id");if(!P)return w(B,400,{error:"MCP action requires card_id"}),!0;if(f==="retrigger-card"||f==="retrigger"){await M(P);let O=Date.now();return w(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:f,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:200}}),!0}let g=chunkLPXVVMQT_cjs.c(T,"payload");if(f==="chat-send"&&!await E(P)){let O=Date.now();return w(B,409,{error:`chat handler is not configured for card: ${P}`,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:409}),!0}if(f==="chat-send"){let O=typeof g["turn-id"]=="string"?g["turn-id"]:typeof g.turnId=="string"?g.turnId:typeof g.turn=="string"?g.turn:"";if(!O||!String(O).trim()){let at=Date.now();return w(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${P}`,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(at).toISOString(),responseSentAtMs:at,responseStatus:400}),!0}}await I(P,f,g);let _=Date.now();return w(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:f,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(_).toISOString(),responseSentAtMs:_,responseStatus:200}}),!0}if(l==="POST"&&u===`${h}/mcp-controlplane`){await v();let m=await L(H),b=typeof m.tool=="string"?m.tool.trim():"",S=m.args&&typeof m.args=="object"&&!Array.isArray(m.args)?m.args:{};if(!b)return w(B,400,{error:"tool is required"}),!0;try{let f=await chunk272IYUKT_cjs.a(b,S,j());if(f&&typeof f=="object"&&!Array.isArray(f)){let T=f;if(T.status==="fail")return w(B,400,{error:chunk272IYUKT_cjs.b(f,"Request failed")}),!0;if(T.status==="error")return w(B,500,{error:chunk272IYUKT_cjs.b(f,"Internal error")}),!0}w(B,200,f);}catch(f){let T=typeof f?.statusCode=="number"?Number(f.statusCode):500,P=f instanceof Error?f.message:String(f);w(B,T,{error:P});}return !0}let k=u.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/cards/([^/]+)/retrigger$`));if(l==="POST"&&k){await v();let m=decodeURIComponent(k[1]);return await M(m),w(B,200,{ok:!0}),!0}let x=u.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/cards/([^/]+)/actions$`));if(l==="POST"&&x){await v();let m=decodeURIComponent(x[1]),b=Date.now(),S=new Date(b).toISOString(),f=await L(H),T=f?.actionType;if(T==="chat-send"&&!await E(m)){let g=Date.now();return w(B,409,{error:`chat handler is not configured for card: ${m}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(g).toISOString(),responseSentAtMs:g,responseStatus:409}),!0}if(T==="chat-send"){let g=f?.payload??{},_=typeof g["turn-id"]=="string"?g["turn-id"]:typeof g.turnId=="string"?g.turnId:typeof g.turn=="string"?g.turn:"";if(!_||!String(_).trim()){let O=Date.now();return w(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${m}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:400}),!0}}await I(m,T,f?.payload);let P=Date.now();return w(B,200,{ok:!0,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:200}),!0}let N=u.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/cards/([^/]+)/files/(\\d+)$`));if(l==="GET"&&N){let m=decodeURIComponent(N[1]),b=parseInt(N[2],10),S=A.searchParams.get("sn");return await $(B,m,b,S),!0}return !1}catch(k){let x=k?.statusCode||500;return w(B,x,{error:String(k?.message||k)}),true}}return {handleRuntimeApi:J}}var ze=3e4;function Ke(R){let h=R.socket?.remoteAddress??"";return h==="127.0.0.1"||h==="::1"||h==="::ffff:127.0.0.1"}function ue(R){let{apiBasePath:h,emitNotifications:w,readJsonBody:L,json:F}=R,v=`${h}/notify-q`;async function W(j,M,I){if(I.pathname!==v)return false;if((j.method??"").toUpperCase()!=="POST")return F(M,405,{status:"error",error:"Method not allowed"}),true;if(!Ke(j))return F(M,403,{status:"error",error:"Forbidden"}),true;let E;try{E=await L(j);}catch{return F(M,400,{status:"error",error:"Invalid JSON body"}),true}if(!E||typeof E!="object"||!Array.isArray(E.notifications))return F(M,400,{status:"error",error:"body.notifications must be an array"}),true;let $=E.notifications,{accepted:J,rejected:H}=chunkNMOUBZXX_cjs.b($,Date.now(),ze);return J.length>0&&w(J),F(M,200,{status:"success",data:{accepted:J.length,rejected:H}}),true}return {handleNotifyRoute:W}}var le={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},de="chat-handler-flow-queue",ot="__probe__echo__probe__";function jr(R){let h=String(R.apiBasePath||"/api/board").replace(/\/$/,""),w={...le,...R.corsHeaders||{}},L=R.queueLaneTuning??{},F=R.boardId||"",v=R.logger||{info:console.log,warn:console.warn,error:console.error},W=R.invocationAdapter,j=R.chatFlowRunner||null,M=R.notificationTransport||null,I=R.serverUrl||null,E=R.executionExtra||{},$=R.onSseClientConnected,J=R.onSseClientDisconnected,H=R.onChannelSubscribed,B=R.onChannelUnsubscribed,V=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:J}),l=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function A(t){function e(a){return {...a,queueStorageForRef(d,C){return chunkSDJ3747Q_cjs.a(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}function r(a){return {...a,queueStorageForRef(d,C){return chunkX5CZE2L7_cjs.h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}function n(a){return {async get(d){return a.get(d)},async set(d){return a.set(d)},async del(d){return a.del(d)},async patch(d){return a.patch(d)},async appendFiles(d){return a.appendFiles(d)}}}function o(a){return {async get(d){return await a.get(d)},async set(d){return await a.set(d)},async del(d){return await a.del(d)},async patch(d){return await a.patch(d)},async appendFiles(d){return await a.appendFiles(d)}}}let s=null;function i(a){if(a.kind==="notification-batch"){O(a.notifications,s??void 0);return}O([a],s??void 0);}let c=chunkBQUQTOPB_cjs.a(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),D=t.nonCoreAdapter??(!chunkBQUQTOPB_cjs.a(c)&&b(c)?c:null),y=chunkBQUQTOPB_cjs.a(c)?chunkX5CZE2L7_cjs.i(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}):chunkVNLMJEIX_cjs.y(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}),q=t.nonCore??(D?chunkVNLMJEIX_cjs.z(t.baseRef,D,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c.chatStorageForRef(t.chatStoreRef),lt,We=chunkBQUQTOPB_cjs.a(c)?(()=>{let a=chunkX5CZE2L7_cjs.d(chunkX5CZE2L7_cjs.c(chunkX5CZE2L7_cjs.b(c.kvStorageForRef(t.cardStoreRef)),c.hashFn),v.warn),d=chunkX5CZE2L7_cjs.g(a,{emitNotification:i}),C=o(d);return lt={get(p){return C.get(p)},set(p){return C.set(p)}},C})():(()=>{let a=c.kvStorageForRef(t.cardStoreRef),C=chunk5XLFPPTY_cjs.a(chunkVNLMJEIX_cjs.l({readIndex:()=>a.read("_index"),writeIndex:p=>a.write("_index",p),readCard:p=>a.read(p),writeCard:(p,pt)=>(a.write(p,pt),p),removeCard:p=>{a.delete(p);},cardExists:p=>a.read(p)!==null,defaultCardKey:p=>p},v.warn),{emitNotification:i});return lt=C,n(C)})(),ft;if(chunkBQUQTOPB_cjs.a(c)){let a=c.blobStorageForRef(t.artifactsStoreRef);ft={async putBytes(d,C){if(a.writeBytes){await a.writeBytes(d,C);return}let p=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(d,p);},async getBytes(d){if(a.readBytes){let p=await a.readBytes(d);if(p!==null)return p}let C=await a.read(d);if(C===null)return null;try{let p=JSON.parse(C);if(p&&p.__kind==="bytes-array"&&Array.isArray(p.data))return new Uint8Array(p.data)}catch{}return new TextEncoder().encode(C)},async listKeys(d){return await a.listKeys(d)}};}else {let a=c.blobStorageForRef(t.artifactsStoreRef),d=chunkNBJTYAYN_cjs.a(a);ft={putBytes(C,p,pt){d.putBytes(C,p,pt);},getBytes(C){return d.getBytes(C)},listKeys(C){return d.list(C).map(p=>p.key)}};}let Je={async init(a){return y.init(a)},async status(a){return y.status(a)},async getConfig(a){return y.getConfig(a)},async getAllOutputsDataObjects(a){return y.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return y.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return y.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return y.buildSseOneShotPayload(a)},async upsertCard(a){return y.upsertCard(a)},async removeCard(a){return y.removeCard(a)},async sourceDataFetched(a){return y.sourceDataFetched(a)},async sourceDataFetchFailure(a){return y.sourceDataFetchFailure(a)}};return s={label:t.label,board:y,nonCore:q,publicCardStore:lt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return ft},get chatStorage(){return Ue},boardAdapter:c,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:chunkNMOUBZXX_cjs.c(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let u=R.boards.map(A),k=new Map;function x(t){return k.get(t)??0}function N(t){return t.queueStoreRef}function m(t,e){if(chunkBQUQTOPB_cjs.a(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(N(t),e);return chunkWRMOGPRG_cjs.a(n)}let r=t.boardAdapter.queueStorageForRef(N(t),e);return chunkGPCMBPLK_cjs.a(r)}function b(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function S(t){let e=u[x(t)];return {files:e?e.filesArtifacts:null}}function f(){return chunkNBJTYAYN_cjs.c()}function T(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function P(t){return "cardId"in t&&typeof t.cardId=="string"?z(t.cardId)??void 0:u[0]??void 0}function g(t){for(let e of t){let r=P(e);if(r)return r}return u[0]??void 0}function _(t,e={}){if(!t||t.length===0)return;let r=chunk2RIHC5TZ_cjs.e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??g(r);if(e.appendState!==false&&o&&chunkNMOUBZXX_cjs.e(o.notification,n),e.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&V.broadcastNotificationBatch(i),s.length>0&&l.broadcastNotificationBatch(s);}if(!(e.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function O(t,e){_(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function at(t){if(!t||t.notificationTeardown||!M||!t.notifyRef)return;let e=await M.subscribe(t.notifyRef,r=>{let n=chunkNMOUBZXX_cjs.a(r);_(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function fe(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let 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 at(t),!t.chatHandlerFlow&&t.chatHandlerRef&&W.describe)try{let o=await W.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?v.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&v.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){v.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ut(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&chunkNMOUBZXX_cjs.d(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,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&_(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function Rt(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 o of n)typeof o.id=="string"&&(k.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of u)await fe(t);}async function st(){await G();for(let t=0;t<u.length;t++)await ut(u[t]),await Rt(u[t],t),await ut(u[t]);}async function yt(t=false){t||await G();for(let e of u){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function z(t){return u[x(t)]??null}async function X(t){let e=z(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function pe(){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 u)e.push(...await t(r));return e}function ht(){return u[0]??null}function me(t){return z(t)??ht()}function U(t){let e=me(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ge(t){return await U(t).isProcessing(t)}async function Y(t,e){let r=await tt.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let tt=chunkOF4FPYNI_cjs.a({append(t,e,r,n,o){return U(t).append(t,e,r,n,o)},readAll(t){return U(t).readAll(t)},readAfter(t,e){return U(t).readAfter(t,e)},clear(t){return U(t).clear(t)},setProcessing(t,e){return U(t).setProcessing(t,e)},isProcessing(t){return U(t).isProcessing(t)},getConfig(t){return U(t).getConfig(t)},setConfig(t,e){return U(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){O(t.notifications);return}O([t]);}}),wt=chunkNMOUBZXX_cjs.p({boardContexts:u,cardOwnerIndex:k,cardContextForCard:t=>z(t),readStatusSnapshot:()=>be(),readDataObjectsByToken:()=>Ce(),readCardRuntimeArtifacts:()=>Se(),readCardFromStore:t=>X(t),readCardDefinitions:()=>pe(),processAccumulatedLaneInternal:t=>yt(t),reportSourceFetched:(t,e)=>kt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Pt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>Ct(t,e,r,n,o),chatStorePublic:tt,serverUrl:I,apiBasePath:h}),Re=wt.mcpCardStoreFacade,it=wt.createMcpFacade,ye=chunkNMOUBZXX_cjs.j({boardId:F,bootstrapBoard:()=>st(),sseHub:V,onChannelSubscribed:H,onChannelUnsubscribed:B,getMcpFacade:()=>it(),getMcpCardStoreFacade:()=>Re()});function he(t){return chunkNMOUBZXX_cjs.m(t)}function we(){return chunkNMOUBZXX_cjs.n(it())}function bt(){return chunkNMOUBZXX_cjs.o({boardId:F,uploadCardFile:Ct,getMcpFacade:()=>it(),controlplane:ye})}let ct=chunkNMOUBZXX_cjs.k({boardId:F,boardContexts:u,readChatRecords:t=>Fe(t),getChatProcessing:t=>ge(t)}),be=ct.readStatusSnapshot,Se=ct.readCardRuntimeArtifacts,Ce=ct.readDataObjectsByToken,dt=ct.buildPublishedRuntimePayload;async function St(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=z(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await X(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,D=e(i)||i;if(o&&JSON.stringify(D)===c)return;let y=await s.cardStoreOps.set({body:D});if(y.status!=="success")throw Object.assign(new Error(y.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let q=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(q.status!=="success")throw Object.assign(new Error(q.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Ae(t,e){await St(t,e,{syncBoard:true});}async function Be(t,e){await St(t,e,{syncBoard:false});}async function ke(t){let e=z(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await X(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 Pe(t){let e=await tt.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await Y(t,!1);}catch{}}async function Oe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await tt.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function Fe(t){return await U(t).readAll(t)}let Ct=chunkNMOUBZXX_cjs.l({safeCardId:t=>T(t),artifactsStores:t=>S(t),cardFileMetadataStore:()=>f(),readCardFromStore:t=>X(t),updateCardLocalOnly:(t,e)=>Be(t,e),writeChatRecord:(t,e,r,n,o)=>Oe(t,e,r,n,o)}).uploadCardFile;async function At(t){let e=z(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function ve(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function xe(t,e,r=false,n="",o=""){try{let s=await At(t);if(!s){try{await Y(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:D}=s;if(!r)try{await Y(t,!0);}catch{}let y={boardId:F,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...E,...I?{serverUrl:I}:{}},q=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:de}}:D;chunkBQUQTOPB_cjs.a(i.boardAdapter)?await m(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}):m(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await Y(t,!1);}catch{}v.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Te(t,e,r){if(e.howToRun==="built-in"&&chunkBQUQTOPB_cjs.b(e)===de){let n=j,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:F,cardId:String(s.cardId||""),label:t.label,logger:v,serverUrl:I,executionExtra:E}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return W.invoke(e,r)}async function Ne(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?z(r):ht();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Te(n,t.ref,t.args);if(!o.dispatched){if(r)try{await Y(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Ee(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=bt(),i=ve(r?.text),c=i?i.text:r?.text,D=await chunk272IYUKT_cjs.a("manage.add-chat-entry-and-any-attachments",{board_id:F,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(D?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(D,`chat-send append failed for card ${t}`));let y=D?.data?.id;if(typeof y!="string"||!y)throw new Error(`chat-send did not return an append id for card ${t}`);let q=await chunk272IYUKT_cjs.a("setstate.chat-processing-started",{board_id:F,card_id:t},s);if(q?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(q,`chat-send processing update failed for card ${t}`));xe(t,y,true,o,i?.assistant||"");return}await Ae(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=f().normalizeIncoming(r?.files,s);return c.length>0&&f().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...w,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function Bt(t,e,r){let n=await X(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=f().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=T(t),c=S(t),D=String(s.stored_name||""),y=`${i}/${D}`,q=c.files?await c.files.getBytes(y):null;if(!q)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:q}}async function je(t,e,r,n){let{fileRecord:o,bytes:s}=await Bt(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function Me(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 _e(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
2
- `)}async function rt(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(chunkBQUQTOPB_cjs.d(e)).trim();return r?JSON.parse(r):{}}async function kt(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=u[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Pt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=u[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let De=chunkLFVMX23W_cjs.b({sseHub:V,queueSseHub:l,corsHeaders:w,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:$,onChannelSubscribed:H,onChannelUnsubscribed:B,apiBasePath:h,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),boardContexts:u,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=chunk7FGPOGRV_cjs.a({apiBasePath:h,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>st(),createMcpFacade:()=>it(),createMcpToolRegistry:t=>he(t),resolveCardFileDownloadPayload:(t,e,r)=>Bt(t,e,r),isLikelyTextMimeType:t=>Me(t),sliceTextByLines:(t,e,r)=>_e(t,e,r)}).handleAgentfaceApi,Ie=chunkNM6O35RY_cjs.a({apiBasePath:h,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ce({apiBasePath:h,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>bt(),retriggerCard:t=>ke(t),applyCardAction:(t,e,r)=>Ee(t,e,r),resolveChatHandlerTarget:t=>At(t),sendCardFileDownloadResponse:(t,e,r,n)=>je(t,e,r,n)}).handleRuntimeApi,He=ue({apiBasePath:h,emitNotifications:t=>O(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Le(t,e,r){return !!(await qe(t,e,r)||await Ie(t,e,r)||await De(t,e,r)||await He(t,e,r)||await $e(t,e,r))}return {get apiBasePath(){return h},get corsHeaders(){return w},get queueLaneTuning(){return L},handleRuntimeApi:Le,emitNotification(t){if(t.kind==="notification-batch"){O(t.notifications);return}O([t]);},buildPublishedRuntimePayload:dt,__drainProcessAccumulatedLane:yt,handleChatAgentRequest:Ne,clearChatRecords:Pe,reportSourceFetched(t,e){return kt(t,{ref:e})},reportSourceFetchFailure(t,e){return Pt(t,{reason:e})},get cardStore(){return u[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Mr(R){let h=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),w={...le,...R.corsHeaders||{}},L=R.serverMetaStore,F=R.boardRuntimeFactory,v=new Map,W="boards-config.json";function j(){let l=L.getText(W);if(!l)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(l)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function M(l){L.putText(W,JSON.stringify(l,null,2));}function I(l){let A=String(l||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return A.length>0&&A.length<=64?A:null}function E(l){if(v.has(l))return v.get(l);let u=j().boards.find(x=>x.id===l)||{},k=F(l,u);return v.set(l,k),k}function $(l,A,u){let k=JSON.stringify(u),x=typeof Buffer<"u"?Buffer.byteLength(k):new TextEncoder().encode(k).length;l.writeHead(A,{...w,"Content-Type":"application/json; charset=utf-8","Content-Length":x}),l.end(k);}async function J(l,A,u){let k=l.method||"GET",x=u.pathname;if(k==="GET"&&x===h)return $(A,200,{ok:true,boards:j().boards}),true;if(k==="POST"&&x===h){let N=[];for await(let g of l)N.push(g);let m=typeof Buffer<"u"?Buffer.concat(N).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(N)).trim(),b={};try{b=m?JSON.parse(m):{};}catch{b={};}let S=I(b.id);if(!S)return $(A,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let f=j();if(f.boards.some(g=>g.id===S))return $(A,409,{error:`Board "${S}" is already registered`}),true;let T=typeof b.label=="string"&&b.label.trim()?b.label.trim():S,P={id:S,label:T};for(let[g,_]of Object.entries(b))g==="id"||g==="label"||_!=null&&(P[g]=_);return f.boards.push(P),M(f),$(A,200,{ok:true,board:P}),true}return false}async function H(l,A,u){let x=u.pathname.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/([^/]+)(/|$)`));if(!x)return false;let N=I(decodeURIComponent(x[1]));return N?j().boards.some(S=>S.id===N)?!!await E(N).handleRuntimeApi(l,A,u):($(A,404,{error:`Board "${N}" not registered. POST ${h} with {id} to register it first.`}),true):($(A,400,{error:"Invalid board id"}),true)}async function B(l,A,u){return !!(await J(l,A,u)||await H(l,A,u))}function V(l){if(!j().boards.some(u=>u.id===l))throw Object.assign(new Error(`Board "${l}" not registered`),{statusCode:404});return {service:E(l)}}return {get apiBasePath(){return h},get corsHeaders(){return w},handleApi:B,requireBoardService:V}}exports.a=jr;exports.b=Mr;//# sourceMappingURL=chunk-BDT43KYE.cjs.map
3
- //# sourceMappingURL=chunk-BDT43KYE.cjs.map
@@ -1,3 +0,0 @@
1
- import {a,b}from'./chunk-JB4Q2W7I.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$6,c as c$2}from'./chunk-O5UYCGIN.js';import {p,j,k,l,c as c$1,d as d$1,m,n,e as e$1,a as a$8,b as b$3,o}from'./chunk-CZ6ZFWFT.js';import {a as a$4,d as d$2,b as b$2,c as c$3}from'./chunk-FOFGEABN.js';import {a as a$c}from'./chunk-RKKSVOP2.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$9,c as c$4}from'./chunk-O7NOHKVR.js';import {a as a$a,b as b$4}from'./chunk-ZJ5M5COT.js';import {i,d,c,b as b$1,g,h}from'./chunk-5U5NMYGT.js';import {a as a$b}from'./chunk-6MD6FVE3.js';import {y,z,l as l$1}from'./chunk-H5FKNSCO.js';import {a as a$5}from'./chunk-7QNEV5S3.js';import {a as a$7}from'./chunk-BJGK5FNL.js';import {a as a$1}from'./chunk-NIBLKYXN.js';import {e}from'./chunk-UGB7PC4P.js';function ce(R){let{apiBasePath:h,json:w,readJsonBody:L,initBoardAndSetup:F,bootstrapBoard:v,buildPublishedRuntimePayload:W,createMcpControlplaneToolRegistry:j,retriggerCard:M,applyCardAction:I,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:$}=R;async function J(H,B,V){let l=H.method||"GET",A=V,u=A.pathname;try{if(l==="POST"&&u===`${h}/mcp-actions`){await v();let m=Date.now(),b=new Date(m).toISOString(),S=await L(H),f=typeof S.tool=="string"?S.tool.trim():"",T=S.args&&typeof S.args=="object"&&!Array.isArray(S.args)?S.args:{};if(!f)return w(B,400,{error:"tool is required"}),!0;let P=a$9(T,"card_id");if(!P)return w(B,400,{error:"MCP action requires card_id"}),!0;if(f==="retrigger-card"||f==="retrigger"){await M(P);let O=Date.now();return w(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:f,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:200}}),!0}let g=c$4(T,"payload");if(f==="chat-send"&&!await E(P)){let O=Date.now();return w(B,409,{error:`chat handler is not configured for card: ${P}`,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:409}),!0}if(f==="chat-send"){let O=typeof g["turn-id"]=="string"?g["turn-id"]:typeof g.turnId=="string"?g.turnId:typeof g.turn=="string"?g.turn:"";if(!O||!String(O).trim()){let at=Date.now();return w(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${P}`,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(at).toISOString(),responseSentAtMs:at,responseStatus:400}),!0}}await I(P,f,g);let _=Date.now();return w(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:f,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(_).toISOString(),responseSentAtMs:_,responseStatus:200}}),!0}if(l==="POST"&&u===`${h}/mcp-controlplane`){await v();let m=await L(H),b=typeof m.tool=="string"?m.tool.trim():"",S=m.args&&typeof m.args=="object"&&!Array.isArray(m.args)?m.args:{};if(!b)return w(B,400,{error:"tool is required"}),!0;try{let f=await a$a(b,S,j());if(f&&typeof f=="object"&&!Array.isArray(f)){let T=f;if(T.status==="fail")return w(B,400,{error:b$4(f,"Request failed")}),!0;if(T.status==="error")return w(B,500,{error:b$4(f,"Internal error")}),!0}w(B,200,f);}catch(f){let T=typeof f?.statusCode=="number"?Number(f.statusCode):500,P=f instanceof Error?f.message:String(f);w(B,T,{error:P});}return !0}let k=u.match(new RegExp(`^${c$3(h)}/cards/([^/]+)/retrigger$`));if(l==="POST"&&k){await v();let m=decodeURIComponent(k[1]);return await M(m),w(B,200,{ok:!0}),!0}let x=u.match(new RegExp(`^${c$3(h)}/cards/([^/]+)/actions$`));if(l==="POST"&&x){await v();let m=decodeURIComponent(x[1]),b=Date.now(),S=new Date(b).toISOString(),f=await L(H),T=f?.actionType;if(T==="chat-send"&&!await E(m)){let g=Date.now();return w(B,409,{error:`chat handler is not configured for card: ${m}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(g).toISOString(),responseSentAtMs:g,responseStatus:409}),!0}if(T==="chat-send"){let g=f?.payload??{},_=typeof g["turn-id"]=="string"?g["turn-id"]:typeof g.turnId=="string"?g.turnId:typeof g.turn=="string"?g.turn:"";if(!_||!String(_).trim()){let O=Date.now();return w(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${m}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:400}),!0}}await I(m,T,f?.payload);let P=Date.now();return w(B,200,{ok:!0,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:200}),!0}let N=u.match(new RegExp(`^${c$3(h)}/cards/([^/]+)/files/(\\d+)$`));if(l==="GET"&&N){let m=decodeURIComponent(N[1]),b=parseInt(N[2],10),S=A.searchParams.get("sn");return await $(B,m,b,S),!0}return !1}catch(k){let x=k?.statusCode||500;return w(B,x,{error:String(k?.message||k)}),true}}return {handleRuntimeApi:J}}var ze=3e4;function Ke(R){let h=R.socket?.remoteAddress??"";return h==="127.0.0.1"||h==="::1"||h==="::ffff:127.0.0.1"}function ue(R){let{apiBasePath:h,emitNotifications:w,readJsonBody:L,json:F}=R,v=`${h}/notify-q`;async function W(j,M,I){if(I.pathname!==v)return false;if((j.method??"").toUpperCase()!=="POST")return F(M,405,{status:"error",error:"Method not allowed"}),true;if(!Ke(j))return F(M,403,{status:"error",error:"Forbidden"}),true;let E;try{E=await L(j);}catch{return F(M,400,{status:"error",error:"Invalid JSON body"}),true}if(!E||typeof E!="object"||!Array.isArray(E.notifications))return F(M,400,{status:"error",error:"body.notifications must be an array"}),true;let $=E.notifications,{accepted:J,rejected:H}=b$3($,Date.now(),ze);return J.length>0&&w(J),F(M,200,{status:"success",data:{accepted:J.length,rejected:H}}),true}return {handleNotifyRoute:W}}var le={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},de="chat-handler-flow-queue",ot="__probe__echo__probe__";function jr(R){let h$1=String(R.apiBasePath||"/api/board").replace(/\/$/,""),w={...le,...R.corsHeaders||{}},L=R.queueLaneTuning??{},F=R.boardId||"",v=R.logger||{info:console.log,warn:console.warn,error:console.error},W=R.invocationAdapter,j$1=R.chatFlowRunner||null,M=R.notificationTransport||null,I=R.serverUrl||null,E=R.executionExtra||{},$=R.onSseClientConnected,J=R.onSseClientDisconnected,H=R.onChannelSubscribed,B=R.onChannelUnsubscribed,V=a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:J}),l$2=a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function A(t){function e(a){return {...a,queueStorageForRef(d,C){return a$7(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}function r(a){return {...a,queueStorageForRef(d,C){return h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}function n(a){return {async get(d){return a.get(d)},async set(d){return a.set(d)},async del(d){return a.del(d)},async patch(d){return a.patch(d)},async appendFiles(d){return a.appendFiles(d)}}}function o(a){return {async get(d){return await a.get(d)},async set(d){return await a.set(d)},async del(d){return await a.del(d)},async patch(d){return await a.patch(d)},async appendFiles(d){return await a.appendFiles(d)}}}let s=null;function i$1(a){if(a.kind==="notification-batch"){O(a.notifications,s??void 0);return}O([a],s??void 0);}let c$2=a$4(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),D=t.nonCoreAdapter??(!a$4(c$2)&&b$3(c$2)?c$2:null),y$1=a$4(c$2)?i(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}):y(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}),q=t.nonCore??(D?z(t.baseRef,D,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c$2.chatStorageForRef(t.chatStoreRef),lt,We=a$4(c$2)?(()=>{let a=d(c(b$1(c$2.kvStorageForRef(t.cardStoreRef)),c$2.hashFn),v.warn),d$1=g(a,{emitNotification:i$1}),C=o(d$1);return lt={get(p){return C.get(p)},set(p){return C.set(p)}},C})():(()=>{let a=c$2.kvStorageForRef(t.cardStoreRef),C=a$5(l$1({readIndex:()=>a.read("_index"),writeIndex:p=>a.write("_index",p),readCard:p=>a.read(p),writeCard:(p,pt)=>(a.write(p,pt),p),removeCard:p=>{a.delete(p);},cardExists:p=>a.read(p)!==null,defaultCardKey:p=>p},v.warn),{emitNotification:i$1});return lt=C,n(C)})(),ft;if(a$4(c$2)){let a=c$2.blobStorageForRef(t.artifactsStoreRef);ft={async putBytes(d,C){if(a.writeBytes){await a.writeBytes(d,C);return}let p=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(d,p);},async getBytes(d){if(a.readBytes){let p=await a.readBytes(d);if(p!==null)return p}let C=await a.read(d);if(C===null)return null;try{let p=JSON.parse(C);if(p&&p.__kind==="bytes-array"&&Array.isArray(p.data))return new Uint8Array(p.data)}catch{}return new TextEncoder().encode(C)},async listKeys(d){return await a.listKeys(d)}};}else {let a=c$2.blobStorageForRef(t.artifactsStoreRef),d=a$6(a);ft={putBytes(C,p,pt){d.putBytes(C,p,pt);},getBytes(C){return d.getBytes(C)},listKeys(C){return d.list(C).map(p=>p.key)}};}let Je={async init(a){return y$1.init(a)},async status(a){return y$1.status(a)},async getConfig(a){return y$1.getConfig(a)},async getAllOutputsDataObjects(a){return y$1.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return y$1.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return y$1.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return y$1.buildSseOneShotPayload(a)},async upsertCard(a){return y$1.upsertCard(a)},async removeCard(a){return y$1.removeCard(a)},async sourceDataFetched(a){return y$1.sourceDataFetched(a)},async sourceDataFetchFailure(a){return y$1.sourceDataFetchFailure(a)}};return s={label:t.label,board:y$1,nonCore:q,publicCardStore:lt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return ft},get chatStorage(){return Ue},boardAdapter:c$2,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:c$1(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let u=R.boards.map(A),k$1=new Map;function x(t){return k$1.get(t)??0}function N(t){return t.queueStoreRef}function m$1(t,e){if(a$4(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(N(t),e);return a$b(n)}let r=t.boardAdapter.queueStorageForRef(N(t),e);return a$c(r)}function b$3(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function S(t){let e=u[x(t)];return {files:e?e.filesArtifacts:null}}function f(){return c$2()}function T(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function P(t){return "cardId"in t&&typeof t.cardId=="string"?z$1(t.cardId)??void 0:u[0]??void 0}function g$1(t){for(let e of t){let r=P(e);if(r)return r}return u[0]??void 0}function _(t,e$2={}){if(!t||t.length===0)return;let r=e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e$2.ctx??g$1(r);if(e$2.appendState!==false&&o&&e$1(o.notification,n),e$2.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&V.broadcastNotificationBatch(i),s.length>0&&l$2.broadcastNotificationBatch(s);}if(!(e$2.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function O(t,e){_(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function at(t){if(!t||t.notificationTeardown||!M||!t.notifyRef)return;let e=await M.subscribe(t.notifyRef,r=>{let n=a$8(r);_(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function fe(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let 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 at(t),!t.chatHandlerFlow&&t.chatHandlerRef&&W.describe)try{let o=await W.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?v.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&v.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){v.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ut(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&d$1(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,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&_(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function Rt(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 o of n)typeof o.id=="string"&&(k$1.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of u)await fe(t);}async function st(){await G();for(let t=0;t<u.length;t++)await ut(u[t]),await Rt(u[t],t),await ut(u[t]);}async function yt(t=false){t||await G();for(let e of u){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function z$1(t){return u[x(t)]??null}async function X(t){let e=z$1(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 pe(){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 u)e.push(...await t(r));return e}function ht(){return u[0]??null}function me(t){return z$1(t)??ht()}function U(t){let e=me(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ge(t){return await U(t).isProcessing(t)}async function Y(t,e){let r=await tt.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let tt=a$1({append(t,e,r,n,o){return U(t).append(t,e,r,n,o)},readAll(t){return U(t).readAll(t)},readAfter(t,e){return U(t).readAfter(t,e)},clear(t){return U(t).clear(t)},setProcessing(t,e){return U(t).setProcessing(t,e)},isProcessing(t){return U(t).isProcessing(t)},getConfig(t){return U(t).getConfig(t)},setConfig(t,e){return U(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){O(t.notifications);return}O([t]);}}),wt=p({boardContexts:u,cardOwnerIndex:k$1,cardContextForCard:t=>z$1(t),readStatusSnapshot:()=>be(),readDataObjectsByToken:()=>Ce(),readCardRuntimeArtifacts:()=>Se(),readCardFromStore:t=>X(t),readCardDefinitions:()=>pe(),processAccumulatedLaneInternal:t=>yt(t),reportSourceFetched:(t,e)=>kt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Pt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>Ct(t,e,r,n,o),chatStorePublic:tt,serverUrl:I,apiBasePath:h$1}),Re=wt.mcpCardStoreFacade,it=wt.createMcpFacade,ye=j({boardId:F,bootstrapBoard:()=>st(),sseHub:V,onChannelSubscribed:H,onChannelUnsubscribed:B,getMcpFacade:()=>it(),getMcpCardStoreFacade:()=>Re()});function he(t){return m(t)}function we(){return n(it())}function bt(){return o({boardId:F,uploadCardFile:Ct,getMcpFacade:()=>it(),controlplane:ye})}let ct=k({boardId:F,boardContexts:u,readChatRecords:t=>Fe(t),getChatProcessing:t=>ge(t)}),be=ct.readStatusSnapshot,Se=ct.readCardRuntimeArtifacts,Ce=ct.readDataObjectsByToken,dt=ct.buildPublishedRuntimePayload;async function St(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=z$1(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await X(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,D=e(i)||i;if(o&&JSON.stringify(D)===c)return;let y=await s.cardStoreOps.set({body:D});if(y.status!=="success")throw Object.assign(new Error(y.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let q=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(q.status!=="success")throw Object.assign(new Error(q.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Ae(t,e){await St(t,e,{syncBoard:true});}async function Be(t,e){await St(t,e,{syncBoard:false});}async function ke(t){let e=z$1(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await X(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 Pe(t){let e=await tt.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await Y(t,!1);}catch{}}async function Oe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await tt.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function Fe(t){return await U(t).readAll(t)}let Ct=l({safeCardId:t=>T(t),artifactsStores:t=>S(t),cardFileMetadataStore:()=>f(),readCardFromStore:t=>X(t),updateCardLocalOnly:(t,e)=>Be(t,e),writeChatRecord:(t,e,r,n,o)=>Oe(t,e,r,n,o)}).uploadCardFile;async function At(t){let e=z$1(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function ve(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function xe(t,e,r=false,n="",o=""){try{let s=await At(t);if(!s){try{await Y(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:D}=s;if(!r)try{await Y(t,!0);}catch{}let y={boardId:F,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...E,...I?{serverUrl:I}:{}},q=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:de}}:D;a$4(i.boardAdapter)?await m$1(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}):m$1(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await Y(t,!1);}catch{}v.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Te(t,e,r){if(e.howToRun==="built-in"&&b$2(e)===de){let n=j$1,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:F,cardId:String(s.cardId||""),label:t.label,logger:v,serverUrl:I,executionExtra:E}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return W.invoke(e,r)}async function Ne(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?z$1(r):ht();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Te(n,t.ref,t.args);if(!o.dispatched){if(r)try{await Y(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Ee(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=bt(),i=ve(r?.text),c=i?i.text:r?.text,D=await a$a("manage.add-chat-entry-and-any-attachments",{board_id:F,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(D?.status!=="success")throw new Error(b$4(D,`chat-send append failed for card ${t}`));let y=D?.data?.id;if(typeof y!="string"||!y)throw new Error(`chat-send did not return an append id for card ${t}`);let q=await a$a("setstate.chat-processing-started",{board_id:F,card_id:t},s);if(q?.status!=="success")throw new Error(b$4(q,`chat-send processing update failed for card ${t}`));xe(t,y,true,o,i?.assistant||"");return}await Ae(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=f().normalizeIncoming(r?.files,s);return c.length>0&&f().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...w,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function Bt(t,e,r){let n=await X(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=f().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=T(t),c=S(t),D=String(s.stored_name||""),y=`${i}/${D}`,q=c.files?await c.files.getBytes(y):null;if(!q)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:q}}async function je(t,e,r,n){let{fileRecord:o,bytes:s}=await Bt(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function Me(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 _e(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
2
- `)}async function rt(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(d$2(e)).trim();return r?JSON.parse(r):{}}async function kt(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=u[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Pt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=u[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let De=b({sseHub:V,queueSseHub:l$2,corsHeaders:w,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:$,onChannelSubscribed:H,onChannelUnsubscribed:B,apiBasePath:h$1,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),boardContexts:u,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=a$2({apiBasePath:h$1,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>st(),createMcpFacade:()=>it(),createMcpToolRegistry:t=>he(t),resolveCardFileDownloadPayload:(t,e,r)=>Bt(t,e,r),isLikelyTextMimeType:t=>Me(t),sliceTextByLines:(t,e,r)=>_e(t,e,r)}).handleAgentfaceApi,Ie=a$3({apiBasePath:h$1,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ce({apiBasePath:h$1,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>bt(),retriggerCard:t=>ke(t),applyCardAction:(t,e,r)=>Ee(t,e,r),resolveChatHandlerTarget:t=>At(t),sendCardFileDownloadResponse:(t,e,r,n)=>je(t,e,r,n)}).handleRuntimeApi,He=ue({apiBasePath:h$1,emitNotifications:t=>O(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Le(t,e,r){return !!(await qe(t,e,r)||await Ie(t,e,r)||await De(t,e,r)||await He(t,e,r)||await $e(t,e,r))}return {get apiBasePath(){return h$1},get corsHeaders(){return w},get queueLaneTuning(){return L},handleRuntimeApi:Le,emitNotification(t){if(t.kind==="notification-batch"){O(t.notifications);return}O([t]);},buildPublishedRuntimePayload:dt,__drainProcessAccumulatedLane:yt,handleChatAgentRequest:Ne,clearChatRecords:Pe,reportSourceFetched(t,e){return kt(t,{ref:e})},reportSourceFetchFailure(t,e){return Pt(t,{reason:e})},get cardStore(){return u[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Mr(R){let h=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),w={...le,...R.corsHeaders||{}},L=R.serverMetaStore,F=R.boardRuntimeFactory,v=new Map,W="boards-config.json";function j(){let l=L.getText(W);if(!l)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(l)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function M(l){L.putText(W,JSON.stringify(l,null,2));}function I(l){let A=String(l||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return A.length>0&&A.length<=64?A:null}function E(l){if(v.has(l))return v.get(l);let u=j().boards.find(x=>x.id===l)||{},k=F(l,u);return v.set(l,k),k}function $(l,A,u){let k=JSON.stringify(u),x=typeof Buffer<"u"?Buffer.byteLength(k):new TextEncoder().encode(k).length;l.writeHead(A,{...w,"Content-Type":"application/json; charset=utf-8","Content-Length":x}),l.end(k);}async function J(l,A,u){let k=l.method||"GET",x=u.pathname;if(k==="GET"&&x===h)return $(A,200,{ok:true,boards:j().boards}),true;if(k==="POST"&&x===h){let N=[];for await(let g of l)N.push(g);let m=typeof Buffer<"u"?Buffer.concat(N).toString("utf-8").trim():new TextDecoder().decode(d$2(N)).trim(),b={};try{b=m?JSON.parse(m):{};}catch{b={};}let S=I(b.id);if(!S)return $(A,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let f=j();if(f.boards.some(g=>g.id===S))return $(A,409,{error:`Board "${S}" is already registered`}),true;let T=typeof b.label=="string"&&b.label.trim()?b.label.trim():S,P={id:S,label:T};for(let[g,_]of Object.entries(b))g==="id"||g==="label"||_!=null&&(P[g]=_);return f.boards.push(P),M(f),$(A,200,{ok:true,board:P}),true}return false}async function H(l,A,u){let x=u.pathname.match(new RegExp(`^${c$3(h)}/([^/]+)(/|$)`));if(!x)return false;let N=I(decodeURIComponent(x[1]));return N?j().boards.some(S=>S.id===N)?!!await E(N).handleRuntimeApi(l,A,u):($(A,404,{error:`Board "${N}" not registered. POST ${h} with {id} to register it first.`}),true):($(A,400,{error:"Invalid board id"}),true)}async function B(l,A,u){return !!(await J(l,A,u)||await H(l,A,u))}function V(l){if(!j().boards.some(u=>u.id===l))throw Object.assign(new Error(`Board "${l}" not registered`),{statusCode:404});return {service:E(l)}}return {get apiBasePath(){return h},get corsHeaders(){return w},handleApi:B,requireBoardService:V}}export{jr as a,Mr as b};//# sourceMappingURL=chunk-WQANIJAQ.js.map
3
- //# sourceMappingURL=chunk-WQANIJAQ.js.map