yaml-flow 8.8.5 → 8.8.7

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,8 +1,8 @@
1
- var ServerRuntimeControlface=(function(exports){'use strict';var ao=Object.defineProperty;var io=(e,t,r)=>t in e?ao(e,t,{enumerable:true,configurable:true,writable:true,value:r}):e[t]=r;var Nr=(e,t,r)=>io(e,t+"",r);var Lt="b64:";function uo(e){let t=new TextEncoder().encode(e),r=globalThis.Buffer,n;if(r)n=r.from(t).toString("base64");else if(typeof btoa=="function"){let o="";for(let s of t)o+=String.fromCharCode(s);n=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return n.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function co(e){let t=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),r=globalThis.Buffer;if(r)return r.from(t,"base64").toString("utf8");if(typeof atob=="function"){let n=atob(t),o=new Uint8Array(n.length);for(let s=0;s<n.length;s+=1)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function ke(e){return `${Lt}${uo(JSON.stringify(e))}`}function at(e){if(!e.startsWith(Lt))throw new Error(`Invalid ref format (expected ${Lt}<base64url(json)>): ${e}`);let t;try{t=JSON.parse(co(e.slice(Lt.length)));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let r=t;if(typeof r.kind!="string"||typeof r.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:r.kind,value:r.value}}async function $r(e,t,r){let n=e.tryAcquire();if(!n)return false;try{await t();}finally{n();}return r?.(),true}function ot(e){return typeof e.journalStorage=="function"}function Ur(e){return typeof e.whatToRun=="string"?e.whatToRun.startsWith("b64:")?at(e.whatToRun).value:e.whatToRun:e.whatToRun.value}function st(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function mr(e){let t=e.reduce((o,s)=>o+s.length,0),r=new Uint8Array(t),n=0;for(let o of e)r.set(o,n),n+=o.length;return r}function de(e,...t){for(let r of t)if(typeof e[r]=="string")return String(e[r]);return ""}function it(e,...t){for(let r of t)if(e[r]!==void 0)return Number(e[r])}function ut(e,...t){for(let r of t){let n=e[r];if(n&&typeof n=="object"&&!Array.isArray(n))return n}return {}}function ft(e,t,...r){for(let n of r){let o=e[n];if(o&&typeof o=="object"&&!Array.isArray(o))return o}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function Mt(e,t,...r){for(let n of r){let o=e[n];if(o!==void 0){let s=Number(o);if(Number.isFinite(s))return s}}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function Vr(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(t=>Math.max(0,Math.min(255,Number(t)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let t=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r);return Uint8Array.from(n,o=>o.charCodeAt(0))}return null}async function pt(e,t,r){let n=r[e];if(!n)throw Object.assign(new Error(`Unknown MCP tool: ${e}`),{statusCode:400});let o=await n(t);if(o&&typeof o=="object"&&!Array.isArray(o)){let s=o,i=s.status;if(i==="success")return Object.prototype.hasOwnProperty.call(s,"data")?o:{status:"success",data:{}};if(i==="fail"||i==="error")return o}return {status:"success",data:o}}function rt(e,t){if(!e||typeof e!="object"||Array.isArray(e))return t;let r=e;if(typeof r.error=="string"&&r.error.trim())return r.error;if(r.step==="validate"){let n=r.validation;if(n&&typeof n=="object"&&!Array.isArray(n)){let s=n.data;if(s&&typeof s=="object"&&!Array.isArray(s)){let i=s.issues;if(Array.isArray(i)){let p=i.find(T=>typeof T=="string"&&T.trim());if(typeof p=="string")return `Validation failed: ${p}`}let u=s.errors;if(Array.isArray(u)&&u.length>0)return "Validation failed"}}return "Validation failed"}return t}function gr(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,bootstrapBoard:s,buildPublishedRuntimePayload:i,createMcpControlplaneToolRegistry:u,retriggerCard:p,applyCardAction:T,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:y}=e;async function C(S,R,I){let x=S.method||"GET",A=I,F=A.pathname;try{if(x==="POST"&&F===`${t}/mcp-actions`){await s();let f=Date.now(),l=new Date(f).toISOString(),k=await n(S),_=typeof k.tool=="string"?k.tool.trim():"",$=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!_)return r(R,400,{error:"tool is required"}),!0;let J=de($,"card_id");if(!J)return r(R,400,{error:"MCP action requires card_id"}),!0;if(_==="retrigger-card"||_==="retrigger"){await p(J);let ie=Date.now();return r(R,200,{status:"success",data:{ok:!0,cardId:J,actionType:_,requestReceivedAt:l,requestReceivedAtMs:f,responseSentAt:new Date(ie).toISOString(),responseSentAtMs:ie,responseStatus:200}}),!0}let W=ut($,"payload");if(_==="chat-send"&&!await E(J)){let ie=Date.now();return r(R,409,{error:`chat handler is not configured for card: ${J}`,requestReceivedAt:l,requestReceivedAtMs:f,responseSentAt:new Date(ie).toISOString(),responseSentAtMs:ie,responseStatus:409}),!0}if(_==="chat-send"){let ie=typeof W["turn-id"]=="string"?W["turn-id"]:typeof W.turnId=="string"?W.turnId:typeof W.turn=="string"?W.turn:"";if(!ie||!String(ie).trim()){let X=Date.now();return r(R,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${J}`,requestReceivedAt:l,requestReceivedAtMs:f,responseSentAt:new Date(X).toISOString(),responseSentAtMs:X,responseStatus:400}),!0}}await T(J,_,W);let te=Date.now();return r(R,200,{status:"success",data:{ok:!0,cardId:J,actionType:_,requestReceivedAt:l,requestReceivedAtMs:f,responseSentAt:new Date(te).toISOString(),responseSentAtMs:te,responseStatus:200}}),!0}if(x==="POST"&&F===`${t}/mcp-controlplane`){await s();let f=await n(S),l=typeof f.tool=="string"?f.tool.trim():"",k=f.args&&typeof f.args=="object"&&!Array.isArray(f.args)?f.args:{};if(!l)return r(R,400,{error:"tool is required"}),!0;try{let _=await pt(l,k,u());if(_&&typeof _=="object"&&!Array.isArray(_)){let $=_;if($.status==="fail")return r(R,400,{error:rt(_,"Request failed")}),!0;if($.status==="error")return r(R,500,{error:rt(_,"Internal error")}),!0}r(R,200,_);}catch(_){let $=typeof _?.statusCode=="number"?Number(_.statusCode):500,J=_ instanceof Error?_.message:String(_);r(R,$,{error:J});}return !0}let c=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/retrigger$`));if(x==="POST"&&c){await s();let f=decodeURIComponent(c[1]);return await p(f),r(R,200,{ok:!0}),!0}let h=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/actions$`));if(x==="POST"&&h){await s();let f=decodeURIComponent(h[1]),l=Date.now(),k=new Date(l).toISOString(),_=await n(S),$=_?.actionType;if($==="chat-send"&&!await E(f)){let W=Date.now();return r(R,409,{error:`chat handler is not configured for card: ${f}`,requestReceivedAt:k,requestReceivedAtMs:l,responseSentAt:new Date(W).toISOString(),responseSentAtMs:W,responseStatus:409}),!0}if($==="chat-send"){let W=_?.payload??{},te=typeof W["turn-id"]=="string"?W["turn-id"]:typeof W.turnId=="string"?W.turnId:typeof W.turn=="string"?W.turn:"";if(!te||!String(te).trim()){let ie=Date.now();return r(R,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${f}`,requestReceivedAt:k,requestReceivedAtMs:l,responseSentAt:new Date(ie).toISOString(),responseSentAtMs:ie,responseStatus:400}),!0}}await T(f,$,_?.payload);let J=Date.now();return r(R,200,{ok:!0,requestReceivedAt:k,requestReceivedAtMs:l,responseSentAt:new Date(J).toISOString(),responseSentAtMs:J,responseStatus:200}),!0}let d=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/files/(\\d+)$`));if(x==="GET"&&d){let f=decodeURIComponent(d[1]),l=parseInt(d[2],10),k=A.searchParams.get("sn");return await y(R,f,l,k),!0}return !1}catch(c){let h=c?.statusCode||500;return r(R,h,{error:String(c?.message||c)}),true}}return {handleRuntimeApi:C}}function Dt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.callbackTransport is required`);if(typeof e.createCallback!="function")throw new Error(`${t}: adapter.callbackTransport.createCallback is required`)}var mt={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function Ye(e){return e?Array.isArray(e.provides)?e.provides:[]:[]}function gt(e){return e?Array.isArray(e.requires)?e.requires:[]:[]}function Kr(e){return e.tasks??{}}function yr(e){return e?e.status===mt.FAILED||e.status===mt.INACTIVATED:false}function Hr(e,t){return e.refreshStrategy??t?.refreshStrategy??"data-changed"}function Jr(e){return e.maxExecutions}function Gr(e,t){let r=new Set;for(let[n,o]of Object.entries(t))if(o.status===mt.COMPLETED){let s=e.tasks[n];s&&Ye(s).forEach(u=>r.add(u));}return Array.from(r)}function Wr(e,t){let r={};return e.forEach(n=>{let o=t[n];if(!o)return;Ye(o).forEach(i=>{r[i]||(r[i]=[]),r[i].push(n);});}),r}function Qr(e,t,r){let n=e.tasks[t]??Nt(),o={};if(r){let i=r.tasks[t],u=gt(i);for(let p of u)for(let[T,E]of Object.entries(r.tasks))if(Ye(E).includes(p)){let y=e.tasks[T];y?.lastDataHash&&(o[p]=y.lastDataHash);break}}let s={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:o};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function zr(e,t,r,n,o,s){let i=e.tasks[r]??Nt(),u=t.tasks[r];if(!u)throw new Error(`Task "${r}" not found in graph`);let p;n&&u.on&&u.on[n]?p=u.on[n]:p=Ye(u);let T=i.startConsumedHashes?{...i.startConsumedHashes}:{...i.lastConsumedHashes};if(!i.startConsumedHashes){let C=u.requires??[];for(let S of C)for(let[R,I]of Object.entries(t.tasks))if(Ye(I).includes(S)){let x=e.tasks[R];x?.lastDataHash&&(T[S]=x.lastDataHash);break}}let E={...i,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:i.executionCount+1,lastEpoch:i.executionCount+1,lastDataHash:o,data:s,lastConsumedHashes:T,error:void 0},y=[...new Set([...e.availableOutputs,...p])];return {...e,tasks:{...e.tasks,[r]:E},availableOutputs:y,lastUpdated:new Date().toISOString()}}function Yr(e,t,r,n){let o=e.tasks[r]??Nt(),s=t.tasks[r];if(s?.retry){let p=o.retryCount+1;if(p<=s.retry.max_attempts){let T={...o,status:"not-started",retryCount:p,lastUpdated:new Date().toISOString(),error:n};return {...e,tasks:{...e.tasks,[r]:T},lastUpdated:new Date().toISOString()}}}let i={...o,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:o.executionCount+1},u=e.availableOutputs;if(s?.on_failure&&s.on_failure.length>0&&(u=[...new Set([...e.availableOutputs,...s.on_failure])]),s?.circuit_breaker&&i.executionCount>=s.circuit_breaker.max_executions){let p=s.circuit_breaker.on_break;u=[...new Set([...u,...p])];}return {...e,tasks:{...e.tasks,[r]:i},availableOutputs:u,lastUpdated:new Date().toISOString()}}function Xr(e,t,r,n){let o=e.tasks[t]??Nt(),s={...o,progress:typeof n=="number"?n:o.progress,messages:[...o.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:o.status}]:[]],lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function Zr(e,t){let r=e.tasks[t];if(!r)return e;let n={...r,status:"not-started",startedAt:void 0,completedAt:void 0,failedAt:void 0,error:void 0,data:void 0,progress:null,lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:n},lastUpdated:new Date().toISOString()}}function Nt(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function St(e,t){let r=`live-${Date.now()}`,n={};for(let s of Object.keys(e.tasks))n[s]=tn();let o={status:"running",tasks:n,availableOutputs:[],stuckDetection:{is_stuck:false,stuck_description:null,outputs_unresolvable:[],tasks_blocked:[]},lastUpdated:new Date().toISOString(),executionId:r,executionConfig:{executionMode:e.settings.execution_mode??"eligibility-mode",conflictStrategy:e.settings.conflict_strategy??"alphabetical",completionStrategy:e.settings.completion}};return {config:e,state:o}}function lo(e,t){let{config:r,state:n}=e;if("executionId"in t&&t.executionId&&t.executionId!==n.executionId)return e;switch(t.type){case "task-started":return {config:r,state:Qr(n,t.taskName,r)};case "task-completed":return {config:r,state:zr(n,r,t.taskName,t.result,t.dataHash,t.data)};case "task-failed":return {config:r,state:Yr(n,r,t.taskName,t.error)};case "task-progress":return {config:r,state:Xr(n,t.taskName,t.message,t.progress)};case "task-restart":return {config:r,state:Zr(n,t.taskName)};case "inject-tokens":return {config:r,state:{...n,availableOutputs:[...new Set([...n.availableOutputs,...t.tokens])],lastUpdated:new Date().toISOString()}};case "agent-action":return {config:r,state:Ro(n,t.action)};case "task-upsert":return fo(e,t.taskName,t.taskConfig);case "task-removal":return po(e,t.taskName);case "node-requires-add":return mo(e,t.nodeName,t.tokens);case "node-requires-remove":return go(e,t.nodeName,t.tokens);case "node-provides-add":return yo(e,t.nodeName,t.tokens);case "node-provides-remove":return ho(e,t.nodeName,t.tokens);default:return e}}function en(e,t){return t.reduce((r,n)=>lo(r,n),e)}function fo(e,t,r){let n=!!e.config.tasks[t];return {config:{...e.config,tasks:{...e.config.tasks,[t]:r}},state:{...e.state,tasks:{...e.state.tasks,[t]:n?e.state.tasks[t]:tn()},lastUpdated:new Date().toISOString()}}}function po(e,t){if(!e.config.tasks[t])return e;let{[t]:r,...n}=e.config.tasks,{[t]:o,...s}=e.state.tasks;return {config:{...e.config,tasks:n},state:{...e.state,tasks:s,lastUpdated:new Date().toISOString()}}}function mo(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=gt(n),s=r.filter(i=>!o.includes(i));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:[...o,...s]}}},state:e.state}}function go(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=gt(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:s}}},state:e.state}}function yo(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=Ye(n),s=r.filter(i=>!o.includes(i));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:[...o,...s]}}},state:e.state}}function ho(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=Ye(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:s}}},state:e.state}}function yt(e){return {version:1,config:e.config,state:e.state,snapshotAt:new Date().toISOString()}}function ht(e){if(!e||typeof e!="object")throw new Error("Invalid snapshot: expected an object");let t=e;if(!t.config||typeof t.config!="object")throw new Error('Invalid snapshot: missing or invalid "config"');if(!t.state||typeof t.state!="object")throw new Error('Invalid snapshot: missing or invalid "state"');let r=t.config,n=t.state;if(!r.settings||typeof r.settings!="object")throw new Error("Invalid snapshot: config.settings missing");if(!r.tasks||typeof r.tasks!="object")throw new Error("Invalid snapshot: config.tasks missing");if(!n.tasks||typeof n.tasks!="object")throw new Error("Invalid snapshot: state.tasks missing");if(!Array.isArray(n.availableOutputs))throw new Error("Invalid snapshot: state.availableOutputs must be an array");return {config:r,state:n}}function tn(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Ro(e,t){let r=new Date().toISOString();switch(t){case "stop":return {...e,status:"stopped",lastUpdated:r};case "pause":return {...e,status:"paused",lastUpdated:r};case "resume":return {...e,status:"running",lastUpdated:r};default:return e}}function xt(e){let{config:t,state:r}=e,n=Kr(t);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let s=ko(n),i=Gr(t,r.tasks),u=new Set([...i,...r.availableOutputs]),p=[],T=[],E=[],y=[];for(let[S,R]of Object.entries(n)){let I=r.tasks[S],x=Hr(R,t.settings),A=x!=="once";if(I?.status===mt.RUNNING||yr(I))continue;let F=Jr(R);if(F!==void 0&&I&&I.executionCount>=F||R.circuit_breaker&&I&&I.executionCount>=R.circuit_breaker.max_executions||!A&&I?.status===mt.COMPLETED)continue;if(A&&I?.status===mt.COMPLETED){let l=gt(R),k=false;switch(x){case "data-changed":{l.length>0&&l.some($=>{for(let[J,W]of Object.entries(n))if(Ye(W).includes($)){let te=r.tasks[J];if(!te)continue;let ie=I.lastConsumedHashes?.[$];return te.lastDataHash==null?te.executionCount>I.lastEpoch:te.lastDataHash!==ie}return false})||(k=true);break}case "epoch-changed":{l.length>0&&l.some($=>{for(let[J,W]of Object.entries(n))if(Ye(W).includes($)){let te=r.tasks[J];if(te&&te.executionCount>I.lastEpoch)return true}return false})||(k=true);break}case "time-based":{let _=R.refreshInterval??0;if(_<=0){k=true;break}let $=I.completedAt;if(!$){k=true;break}(Date.now()-Date.parse($))/1e3<_&&(k=true);break}case "manual":k=true;break}if(k)continue}let c=gt(R);if(c.length===0){p.push(S);continue}let h=[],d=[],f=[];for(let l of c){if(u.has(l))continue;let k=s[l]||[];k.length===0?h.push(l):k.every($=>yr(r.tasks[$]))?f.push({token:l,failedProducer:k[0]}):d.push(l);}h.length>0?E.push({taskName:S,missingTokens:h}):f.length>0?y.push({taskName:S,failedTokens:f.map(l=>l.token),failedProducers:[...new Set(f.map(l=>l.failedProducer))]}):d.length>0?T.push({taskName:S,waitingOn:d}):p.push(S);}let C={};if(p.length>1){let S=Wr(p,n);for(let[R,I]of Object.entries(S))I.length>1&&(C[R]=I);}return {eligible:p,pending:T,unresolved:E,blocked:y,conflicts:C}}function ko(e){let t={};for(let[r,n]of Object.entries(e)){for(let o of Ye(n))t[o]||(t[o]=[]),t[o].push(r);if(n.on)for(let o of Object.values(n.on))for(let s of o)t[s]||(t[s]=[]),t[s].includes(r)||t[s].push(r);if(n.on_failure)for(let o of n.on_failure)t[o]||(t[o]=[]),t[o].includes(r)||t[o].push(r);}return t}var It=class{constructor(){Nr(this,"buffer",[]);}append(t){this.buffer.push(t);}drain(){let t=this.buffer;return this.buffer=[],t}get size(){return this.buffer.length}};function hr(e){let t=Rr(e);return Co(t)}function Rr(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return "["+e.map(Rr).join(",")+"]";let t=e;return "{"+Object.keys(t).sort().map(n=>JSON.stringify(n)+":"+Rr(t[n])).join(",")+"}"}function Co(e){let t=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let o=0;o<e.length;o++)t^=BigInt(e.charCodeAt(o)),t=t*r&n;return t.toString(16).padStart(16,"0")}function wo(e){if(typeof Buffer<"u")return Buffer.from(e,"utf8").toString("base64url");if(typeof btoa=="function"){let t=new TextEncoder().encode(e),r="";for(let n of t)r+=String.fromCharCode(n);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}throw new Error("No base64 encoder available in this runtime")}function So(e){if(typeof Buffer<"u")return Buffer.from(e,"base64url").toString("utf8");if(typeof atob=="function"){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=new Uint8Array(n.length);for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function rn(e){let t=JSON.stringify({t:e,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return wo(t)}function bo(e){try{let t=JSON.parse(So(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function $t(e,t,r){let{handlers:n,onNodeRemoved:o,onDrain:s}=t,i=new It,u="state"in e&&"config"in e?e:St(e),p=false,T=new Set,E=new Map(Object.entries(n)),y=new It,C=false,S=false;function R(){if(!p){if(C){S=true;return}C=true;try{do S=!1,I();while(S)}finally{C=false;}}}function I(){let c=y.drain(),h=i.drain(),d=[...c,...h];if(d.length>0&&(u=en(u,d),o)){for(let l of d)if(l.type==="task-removal")try{o(l.taskName);}catch(k){console.warn("[reactive] onNodeRemoved failed:",k instanceof Error?k.message:String(k));}}let f=xt(u);d.length>0&&s?.(d,u,f);for(let l of f.eligible)F(l);for(let l of d)if(l.type==="task-progress"){let{taskName:k,update:_}=l;if(!u.config.tasks[k])continue;let J=u.state.tasks[k];if(!J||J.status!=="running")continue;let W=rn(k),te=A(k,W,_).catch(ie=>{p||(y.append({type:"task-failed",taskName:k,error:ie.message??String(ie),timestamp:new Date().toISOString()}),R());}).finally(()=>{T.delete(te);});T.add(te);}}function x(c){let d=u.config.tasks[c].requires??[],f=new Map;for(let[k,_]of Object.entries(u.config.tasks))for(let $ of _.provides??[])f.set($,k);let l={};for(let k of d){let _=f.get(k);_?l[k]=u.state.tasks[_]?.data:l[k]=void 0;}return l}async function A(c,h,d){let f=u.config.tasks[c],l=f.taskHandlers??[],k=x(c);for(let _ of l){let $=E.get(_);if(!$)throw new Error(`Handler '${_}' not found in registry (task '${c}')`);let J={nodeId:c,state:k,taskState:u.state.tasks[c],config:f,callbackToken:h,update:d};if(await $(J)==="task-initiate-failure")throw new Error(`Handler '${_}' returned task-initiate-failure (task '${c}')`)}}function F(c){let d=u.config.tasks[c]?.taskHandlers;if(!d||d.length===0)return;y.append({type:"task-started",taskName:c,timestamp:new Date().toISOString()}),R();let f=rn(c),l=A(c,f).catch(k=>{p||(y.append({type:"task-failed",taskName:c,error:k.message??String(k),timestamp:new Date().toISOString()}),R());}).finally(()=>{T.delete(l);});T.add(l);}return {push(c){p||(c.type==="task-completed"&&c.data&&!c.dataHash&&(c={...c,dataHash:hr(c.data)}),i.append(c),R());},pushAll(c){if(!p){for(let h of c)h.type==="task-completed"&&h.data&&!h.dataHash?i.append({...h,dataHash:hr(h.data)}):i.append(h);R();}},resolveCallback(c,h,d){if(p)return;let f=bo(c);if(!f)return;let{taskName:l}=f;if(u.config.tasks[l]){if(d&&d.length>0)i.append({type:"task-failed",taskName:l,error:d.join("; "),timestamp:new Date().toISOString()});else {let k=h&&Object.keys(h).length>0?hr(h):void 0;i.append({type:"task-completed",taskName:l,data:h,dataHash:k,timestamp:new Date().toISOString()});}R();}},addNode(c,h){p||(i.append({type:"task-upsert",taskName:c,taskConfig:h,timestamp:new Date().toISOString()}),R());},removeNode(c){p||(i.append({type:"task-removal",taskName:c,timestamp:new Date().toISOString()}),R());},addRequires(c,h){p||(i.append({type:"node-requires-add",nodeName:c,tokens:h,timestamp:new Date().toISOString()}),R());},removeRequires(c,h){p||(i.append({type:"node-requires-remove",nodeName:c,tokens:h,timestamp:new Date().toISOString()}),R());},addProvides(c,h){p||(i.append({type:"node-provides-add",nodeName:c,tokens:h,timestamp:new Date().toISOString()}),R());},removeProvides(c,h){p||(i.append({type:"node-provides-remove",nodeName:c,tokens:h,timestamp:new Date().toISOString()}),R());},registerHandler(c,h){E.set(c,h);},unregisterHandler(c){E.delete(c);},retrigger(c){p||u.config.tasks[c]&&(i.append({type:"task-restart",taskName:c,timestamp:new Date().toISOString()}),R());},retriggerAll(c){if(!p){for(let h of c)u.config.tasks[h]&&i.append({type:"task-restart",taskName:h,timestamp:new Date().toISOString()});R();}},snapshot(){return yt(u)},getState(){return u},getSchedule(){return xt(u)},async waitForHandlers(){T.size>0&&await Promise.allSettled([...T]);},async dispose(c){c?.wait&&T.size>0&&await Promise.allSettled([...T]),p=true;}}}function Ut(){return function(e){if(e==="./jsonata-sync.cjs")return typeof globalThis<"u"&&globalThis.__jsonataSync||typeof globalThis<"u"&&globalThis.jsonataSync;throw new Error("Unsupported require in browser bundle: "+e)}}var vo=Ut();vo("./jsonata-sync.cjs");var Ao=Ut(),Vt=Ao("./jsonata-sync.cjs"),sn=Vt;function nn(e,t){if(!t||!e)return;let r=t.split("."),n=e;for(let o=0;o<r.length;o++){if(n==null)return;n=n[r[o]];}return n}function an(e,t,r){let n=t.split("."),o=e;for(let s=0;s<n.length-1;s++)(o[n[s]]==null||typeof o[n[s]]!="object")&&(o[n[s]]={}),o=o[n[s]];o[n[n.length-1]]=r;}async function xo(e,t){if(!e?.compute?.length)return e;e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values};for(let o of e.compute)try{let s=await Vt(o.expr).evaluate(n);an(e.computed_values,o.bindTo,s),n.computed_values=e.computed_values;}catch{}return e}function Io(e,t){if(!e?.compute?.length)return {ok:true,node:e};e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values},o=[];for(let s of e.compute)try{let i=sn(s.expr).evaluate(n);an(e.computed_values,s.bindTo,i),n.computed_values=e.computed_values;}catch(i){let u=i instanceof Error?i.message:String(i);o.push({bindTo:s.bindTo,error:u});}return o.length>0?{ok:true,node:e,errors:o}:{ok:true,node:e}}async function To(e,t,r){let n={...r??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return Vt(e).evaluate(n)}function Po(e,t){return t.startsWith("fetched_sources.")?nn(e._sourcesData??{},t.slice(16)):nn(e,t)}var on=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),_o=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function Eo(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:false,errors:["Node must be a non-null object"]};let r=e;(typeof r.id!="string"||!r.id)&&t.push("id: required, must be a non-empty string");for(let n of Object.keys(r))_o.has(n)||t.push(`Unknown top-level key: "${n}"`);if((r.card_data==null||typeof r.card_data!="object"||Array.isArray(r.card_data))&&t.push("card_data: required, must be an object"),r.meta!=null)if(typeof r.meta!="object"||Array.isArray(r.meta))t.push("meta: must be an object");else {let n=r.meta;n.title!=null&&typeof n.title!="string"&&t.push("meta.title: must be a string"),n.tags!=null&&!Array.isArray(n.tags)&&t.push("meta.tags: must be an array");}if(r.requires!=null&&!Array.isArray(r.requires)&&t.push("requires: must be an array of strings"),r.provides!=null&&(Array.isArray(r.provides)?r.provides.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`provides[${o}]: must be an object with bindTo and ref`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`provides[${o}]: missing required "bindTo" string`),(typeof s.ref!="string"||!s.ref)&&t.push(`provides[${o}]: missing required "ref" string`);}}):t.push("provides: must be an array of { bindTo, ref } bindings")),r.compute!=null&&(Array.isArray(r.compute)?r.compute.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`compute[${o}]: must be a compute step object`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`compute[${o}]: missing required "bindTo" property`),(typeof s.expr!="string"||!s.expr)&&t.push(`compute[${o}]: missing required "expr" string (JSONata expression)`);}}):t.push("compute: must be an array of compute steps")),r.source_defs!=null)if(!Array.isArray(r.source_defs))t.push("source_defs: must be an array");else {let n=new Set,o=new Set;r.source_defs.forEach((s,i)=>{if(!s||typeof s!="object"||Array.isArray(s))t.push(`source_defs[${i}]: must be an object`);else {let u=s;typeof u.bindTo!="string"||!u.bindTo?t.push(`source_defs[${i}]: missing required "bindTo" property`):(n.has(u.bindTo)&&t.push(`source_defs[${i}]: bindTo "${u.bindTo}" is not unique across source_defs`),n.add(u.bindTo)),typeof u.outputFile!="string"||!u.outputFile?t.push(`source_defs[${i}]: missing required "outputFile" property`):(o.has(u.outputFile)&&t.push(`source_defs[${i}]: outputFile "${u.outputFile}" is not unique across source_defs`),o.add(u.outputFile)),u.optionalForCompletionGating!=null&&typeof u.optionalForCompletionGating!="boolean"&&t.push(`source_defs[${i}]: optionalForCompletionGating must be a boolean`);}});}if(r.view!=null)if(typeof r.view!="object"||Array.isArray(r.view))t.push("view: must be an object");else {let n=r.view;!Array.isArray(n.elements)||n.elements.length===0?t.push("view.elements: required, must be a non-empty array"):n.elements.forEach((o,s)=>{if(!o||typeof o!="object"){t.push(`view.elements[${s}]: must be an object`);return}!o.kind||typeof o.kind!="string"?t.push(`view.elements[${s}].kind: required, must be a string`):on.has(o.kind)||t.push(`view.elements[${s}].kind: unknown kind "${o.kind}". Valid: ${[...on].join(", ")}`),o.data!=null&&(typeof o.data!="object"||Array.isArray(o.data))&&t.push(`view.elements[${s}].data: must be an object`);}),n.layout!=null&&(typeof n.layout!="object"||Array.isArray(n.layout))&&t.push("view.layout: must be an object"),n.features!=null&&(typeof n.features!="object"||Array.isArray(n.features))&&t.push("view.features: must be an object");}return {ok:t.length===0,errors:t}}async function Fo(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return Promise.all(e.map(async n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=await Vt(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}}))}function Bo(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return e.map(n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=sn(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}})}var ze={run:xo,runSync:Io,eval:To,resolve:Po,validate:Eo,enrichSources:Fo,enrichSourcesSync:Bo};function Kt(e){return JSON.stringify(e)}function Ht(e){let t;try{t=JSON.parse(e);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${e}`)}if(typeof t!="object"||t===null||typeof t.howToRun!="string"||typeof t.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${e}`);return t}function Jt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function kr(e,t){return Jt(e)?e.then(t):t(e)}function dn(e,t){let r={...e};for(let n of t.deleteKeys)delete r[n];return {...r,...t.shallowMerge}}function Cr(e,t){return {readValues(n){let o=e(n);return kr(o.listKeys(),s=>{let i=[...s].sort();if(i.length===0)return {version:null,values:{}};let u={},p=null;for(let T of i){let E=o.read(T);Jt(E)?p=(p??Promise.resolve()).then(async()=>{u[T]=await E;}):u[T]=E;}return p?p.then(()=>({version:t(u),values:u})):{version:t(u),values:u}})},writeValues(n,o,s){let i=e(n),u=null;for(let p of s){let T=i.delete(p);Jt(T)&&(u=(u??Promise.resolve()).then(()=>T).then(()=>{}));}for(let[p,T]of Object.entries(o)){let E=i.write(p,T);Jt(E)&&(u=(u??Promise.resolve()).then(()=>E).then(()=>{}));}return u?u.then(()=>t(o)):t(o)}}}function Gt(e,t){return {readSnapshot(r){return e.readValues(r)},commitSnapshot(r,n){if(n.schemaVersion!==t)throw new Error(`Unsupported snapshot schema version: ${n.schemaVersion}`);return kr(e.readValues(r),o=>{if(o.version!==n.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:o.version};let s=dn(o.values,n);return kr(e.writeValues(r,s,n.deleteKeys),i=>({ok:true,newVersion:i}))})}}}function un(e,t){if(!t)return e;let r=e.findIndex(n=>n.id===t);return r===-1?e:e.slice(r+1)}function cn(e){return {readEntriesAfterCursor(t){let r=un(e.readAllEntries(),t);return r.length===0?{events:[],newCursor:t}:{events:r.map(n=>n.event),newCursor:r[r.length-1].id}},pendingCount(t){return un(e.readAllEntries(),t).length},appendEvent(t){e.appendEntry({id:e.generateId(),event:t});}}}function ln(e){return {appendEvent(t){return e.append(t).then(()=>{})},async readEntriesAfterCursor(t){let r=await e.readAfter(t||null);return {events:r.entries.map(n=>n.payload),newCursor:r.newCursor??t}}}}function Wt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function dt(e,t){return Wt(e)?e.then(t):t(e)}function wr(e,t){let r=null;for(let n of e){if(r){r=r.then(()=>t(n)).then(()=>{});continue}let o=t(n);Wt(o)&&(r=Promise.resolve(o).then(()=>{}));}return r??void 0}function Oo(e){if(e==null)return null;let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{return t}}function qo(e,t){let r=e.match(t);return r?r[1]:null}function fn(e,t,r){let n={},o=wr(e,s=>{let i=r(s);if(i)return dt(t(s),u=>{n[i]=u;})});return Wt(o)?o.then(()=>n):n}function Qt(e,t){return {readSourceData(r,n){return dt(e.read(`${r}/${n}`),Oo)},ingestSourceDataStaged(r,n,o,s){return dt(t(o),i=>e.write(`${r}/.staged/${s}/${n}`,i))},commitSourceData(r,n,o){let s=`${r}/.staged/${o}/${n}`,i=`${r}/${n}`;return e.renameKey(s,i)},hasSource(r,n){return e.exists(`${r}/${n}`)},listSources(r){return dt(e.listKeys(`${r}/`),n=>n.filter(o=>!o.includes("/.staged/")).map(o=>o.slice(`${r}/`.length)))}}}function Sr(e,t){let r=(n,o)=>{try{let s=o(n);return Wt(s)?s.catch(i=>t(n,i instanceof Error?i.message:String(i))):void 0}catch(s){try{return t(n,s instanceof Error?s.message:String(s))}catch{return}}};return {appendEntries(n,o){if(!(!n||o.length===0))return dt(e.read(n),s=>e.write(n,[...s??[],...o]))},dispatchEntriesForJournalId(n,o){if(n)return dt(e.read(n),s=>{let i=s;if(!(!i||i.length===0))return dt(wr(i,u=>r(u,o)),()=>e.delete(n))})}}}function br(e,t,r){return {readRuntime(n){return dt(e.read(t(n)),o=>o??r())},writeRuntime(n,o){return e.write(t(n),o)}}}function zt(e){return {writeComputedValues(t,r){return e.write(`cards/${t}/computed_values`,r)},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){return dt(e.listKeys("cards/"),t=>fn(t,r=>e.read(r),r=>qo(r,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(t){return wr(Object.entries(t),([r,n])=>{if(r)return n===void 0?e.delete(`data-objects/${r}`):e.write(`data-objects/${r}`,n)})},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){return dt(e.listKeys("data-objects/"),t=>fn(t,r=>e.read(r),r=>r.slice(13)))},writeStatusSnapshot(t){return e.write("status",t)},readStatusSnapshot(){return e.read("status")}}}function Et(e,t){function r(){return e.readIndex()??{}}function n(o,s,i){let u=String(s||"").split(".").filter(Boolean);if(u.length===0)return i&&typeof i=="object"&&!Array.isArray(i)?i:{value:i};let p={...o},T=p;for(let E=0;E<u.length-1;E++){let y=u[E],C=T[y],S=C&&typeof C=="object"&&!Array.isArray(C)?{...C}:{};T[y]=S,T=S;}return T[u[u.length-1]]=i,p}return {readCard(o){let s=r()[o];return !s||!e.cardExists(s.key)?null:e.readCard(s.key)},readCardKey(o){return r()[o]?.key??null},readAllCards(){let o=[];for(let[s,i]of Object.entries(r())){if(!e.cardExists(i.key))continue;let u=e.readCard(i.key);u?o.push(u):t?.(`[card-store] could not read card "${s}" at key "${i.key}"`);}return o},readChecksumIndex(){let o={};for(let[s,i]of Object.entries(r()))o[s]=i.checksum;return o},changedSince(o){let s=r(),i=[];for(let[u,p]of Object.entries(s))o[u]!==p.checksum&&i.push(u);for(let u of Object.keys(o))s[u]||i.push(u);return i},validateUpsert(o,s){let i=r(),u=i[o],p=Object.entries(i).find(([,T])=>T.key===s);return u&&u.key!==s?{ok:false,error:`Card id "${o}" is already mapped to key "${u.key}", cannot remap to "${s}"`}:p&&p[0]!==o?{ok:false,error:`Key "${s}" is already mapped to card id "${p[0]}", cannot remap to "${o}"`}:{ok:true}},writeCard(o,s,i){let u=r(),p=i??u[o]?.key??e.defaultCardKey(o),T=e.writeCard(p,s);u[o]={key:p,checksum:T,updatedAt:new Date().toISOString()},e.writeIndex(u);},patchCard(o,s,i){let u=r(),p=u[o];if(!p||!e.cardExists(p.key))throw new Error(`card "${o}" not found`);let T=e.readCard(p.key);if(!T||typeof T!="object"||Array.isArray(T))throw new Error(`card "${o}" is not patchable`);let E=n(T,s,i),y=e.writeCard(p.key,E);u[o]={key:p.key,checksum:y,updatedAt:new Date().toISOString()},e.writeIndex(u);},removeCard(o){let s=r(),i=s[o];i&&(e.removeCard(i.key),delete s[o],e.writeIndex(s));},readIndex(){return r()}}}function Yt(e,t){return Qt(e,t)}function pn(e){return cn(e)}var Xt="v1",ct="board/graph",mn="board/lastJournalProcessedId";function gn(e){return `cards/${e}/runtime`}function yn(e){return Gt(e,Xt)}function Zt(e){function t(r){let n=e.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {readTaskExecutorRef(){let r=t("task-executor");if(r?.trim())return Ht(r.trim())},writeTaskExecutorRef(r){e.write("task-executor",Kt(r));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){e.write("chat-handler-flow",r);},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){e.write("board-runtime-store-ref",r);},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){e.write("card-store-ref",r);},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){e.write("outputs-store-ref",r);},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){e.write("queue-store-ref",r);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){e.write("scratch-store-ref",r);},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){e.write("chat-store-ref",r);},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){e.write("artifacts-store-ref",r);},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){e.write("fetched-sources-store-ref",r);}}}function hn(e){return zt(e)}function Tt(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function jo(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function Pt(e,t){return e?.lastRequestedToken?jo(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function vr(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function _t(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function Rt(e,t){let r=t.state.tasks,n=t.config.tasks,o=Object.keys(r),s=xt(t),i={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},u=new Map;for(let R of s.pending)u.set(R.taskName,R.waitingOn);for(let R of s.unresolved)u.set(R.taskName,R.missingTokens);for(let R of s.blocked)u.set(R.taskName,R.failedTokens);let p=new Map;for(let[R,I]of Object.entries(n))for(let x of I.requires??[]){let A=p.get(x)??[];A.push(R),p.set(x,A);}let T=o.sort().map(R=>{let I=r[R],x=n[R]??{requires:[],provides:[]};I.status==="completed"?i.completed+=1:I.status==="failed"?i.failed+=1:I.status==="in-progress"&&(i.in_progress+=1);let A=x.requires??[],F=x.provides??[],c=Object.keys(I.data??{}).sort(),h=A.filter($=>t.state.availableOutputs.includes($)),d=A.filter($=>!t.state.availableOutputs.includes($)),f=u.get(R)??d,l=new Set;for(let $ of F)for(let J of p.get($)??[])J!==R&&l.add(J);let k=I.failedAt,_=I.error?{message:I.error,code:"TASK_FAILED",at:k,source:"task-runtime"}:void 0;return {name:R,status:I.status,error:_,requires:A,requires_satisfied:h,requires_missing:d,provides_declared:F,provides_runtime:c,blocked_by:f,unblocks:Array.from(l).sort(),runtime:{attempt_count:I.executionCount??0,restart_count:I.retryCount??0,in_progress_since:I.status==="in-progress"?I.startedAt??null:null,last_transition_at:I.lastUpdated??null,last_completed_at:I.completedAt??null,last_restarted_at:I.startedAt??null,status_age_ms:I.lastUpdated?0:null}}});i.pending=s.pending.length,i.blocked=s.blocked.length,i.unresolved=s.unresolved.length;let E=T.map(R=>({name:R.name,fanOut:R.unblocks.length})).sort((R,I)=>I.fanOut-R.fanOut||R.name.localeCompare(I.name)),y=E.length>0?E[0]:{name:null,fanOut:0},C=new Set;for(let R of Object.values(n))for(let I of R.requires??[])C.add(I);let S=0;for(let[R,I]of Object.entries(n)){let x=(I.requires??[]).length===0,F=(I.provides??[]).some(c=>(p.get(c)??[]).some(h=>h!==R));x&&!F&&(S+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:o.length,completed:i.completed,eligible:s.eligible.length,pending:i.pending,blocked:i.blocked,unresolved:i.unresolved,failed:i.failed,in_progress:i.in_progress,orphan_cards:S,topology:{edge_count:Array.from(C).length,max_fan_out_card:y.name,max_fan_out:y.fanOut}},cards:T}}function Lo(){return new Date().toISOString()}function Rn(e,t,r,n,o,s,i){return async u=>{let p=[],T=r.cardStore.readCard(u.nodeId);if(!T)return "task-initiate-failure";let E=T.id,y=T.card_data??{},C=T.source_defs??[],S=C.filter(v=>v.optionalForCompletionGating!==true),R=r.cardRuntimeStore.readRuntime(E),I=false,x=()=>{I&&(r.cardRuntimeStore.writeRuntime(E,R),I=false);},A=v=>Tt(R._sources[v]),F=(v,g)=>{R._sources[v]=Tt(g),I=true;},c=u.taskState?.executionCount??0;if(R._lastExecutionCount!==c&&(R._sources={},R._lastExecutionCount=c,I=true),u.update){let v=u.update,g=v.outputFile;if(g){let L=A(g);if(v.failure){let D=v.rqt??L.lastRequestedToken??L.queueRequestedToken;D&&F(g,_t(L,D));}else {let D=v.rqt;if(!L.lastCompletedToken||D>L.lastCompletedToken){let H=typeof v.deliveryToken=="string"?v.deliveryToken:void 0,w=false;H&&(w=r.fetchedSourcesStore.commitSourceData(E,g,H)),w?F(g,vr(L,D)):F(g,_t(L,D));}}x();}}let d={};for(let v of C)if(v.outputFile){let g=r.fetchedSourcesStore.readSourceData(E,v.outputFile);g!==null&&(d[v.bindTo]=g);}let f={};for(let[v,g]of Object.entries(u.state??{}))if(g!==null&&typeof g=="object"&&!Array.isArray(g)){let L=g[v];f[v]=L!==void 0?L:g;}else f[v]=g;let l={id:E,card_data:{...y},requires:f,source_defs:C,compute:T.compute};l._sourcesData=d,T.compute&&ze.runSync(l,{sourcesData:d}),(s??r.outputStore.writeComputedValues.bind(r.outputStore))(E,l.computed_values??{});let k={...T},_=ze.enrichSourcesSync(Array.isArray(T.source_defs)?T.source_defs:void 0,{card_data:T.card_data,requires:f}),$=e.value;k.source_defs=Array.isArray(_)?_.map(v=>({...v,boardDir:typeof v.boardDir=="string"&&v.boardDir?v.boardDir:$})):_;let J=Lo(),W=u.update?void 0:J,te=S.filter(v=>{let g=v.outputFile;if(typeof g!="string"||!g)return true;let L=A(g);W&&(L={...L,queueRequestedToken:W},F(g,L));let D=L.queueRequestedToken??L.lastRequestedToken??J,H=Pt(L,D);return H==="in-flight"?false:H==="dispatch"});if(x(),te.length>0){let v=false,g=J;for(let L of te){let D=L.outputFile;if(typeof D!="string"||!D)continue;let H=A(D),w=H.queueRequestedToken??J;F(D,{...H,lastRequestedToken:w}),g=w,v=true;}return v&&x(),v&&(p.push({taskKind:"source-fetch",payload:{boardRef:ke(e),enrichedCard:k,callbackToken:u.callbackToken,rqt:g}}),r.executionRequestStore.appendEntries(t,p)),"task-initiated"}if(S.some(v=>{let g=v.outputFile;if(typeof g!="string"||!g)return false;let L=A(g),D=L.queueRequestedToken??L.lastRequestedToken??J;return Pt(L,D)==="in-flight"}))return "task-initiated";let X=T.provides??[],ee={};for(let{bindTo:v,ref:g}of X)ee[v]=ze.resolve(l,g);return (i??r.outputStore.writeDataObjects.bind(r.outputStore))(ee),C.filter(v=>{if(v.optionalForCompletionGating!==true)return false;let g=A(v.outputFile);return !g.lastRequestedToken||!g.lastCompletedToken?true:g.lastCompletedToken<=g.lastRequestedToken}).length>0&&p.push({taskKind:"source-fetch",payload:{boardRef:ke(e),enrichedCard:k,callbackToken:u.callbackToken,rqt:J}}),n(u.nodeId,ee),p.length>0&&r.executionRequestStore.appendEntries(t,p),"task-initiated"}}var Ft={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function er(e){return {[ct]:e.graph,[mn]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function tr(e){let t=e[ct],r=e[mn],o=e.board?.runtimeByCardId;if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${ct}`);return {graph:t,lastDrainedJournalId:typeof r=="string"?r:"",runtimeByCardId:o&&typeof o=="object"?o:{}}}function rr(e){let t=e.requires;return {provides:e.provides?.map(n=>n.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...t&&t.length>0?{requires:t}:{}}}function nr(e){function t(s){return {status:"success",data:s}}function r(s){return {status:"fail",error:s}}function n(s){return {status:"error",error:s instanceof Error?s.message:String(s)}}function o(s){if(Array.isArray(s))return s;if(s&&typeof s=="object"){let i=s;return Array.isArray(i.files)?i.files:[s]}return null}return {get(s){try{let i=s.params?.id;if(i){let u=e.readCard(i);return u?t({cards:[u]}):r(`card "${i}" not found`)}return t({cards:e.readAllCards()})}catch(i){return n(i)}},set(s){try{let i=s.body;if(i==null)return r("set requires a body (card object or array of cards)");let u=Array.isArray(i)?i:[i];for(let p of u){if(typeof p.id!="string")return r("each card must have a string `id` field");e.writeCard(p.id,p);}return t({count:u.length})}catch(i){return n(i)}},del(s){try{let i=s.body?.ids??[],u=s.params?.id,p=u?[...i,u]:i;if(p.length===0)return r("del requires body.ids (string[]) or params.id");for(let T of p)e.removeCard(T);return t({count:p.length})}catch(i){return n(i)}},patch(s){try{let i=s.params?.id,u=s.params?.path;if(!i)return r("patch requires params.id");if(!u)return r("patch requires params.path");let p=s.body,T=p&&Object.prototype.hasOwnProperty.call(p,"value")?p.value:s.body;return e.patchCard(i,u,T),t({count:1})}catch(i){return n(i)}},appendFiles(s){try{let i=s.params?.id;if(!i)return r("appendFiles requires params.id");let u=e.readCard(i);if(!u)return r(`card "${i}" not found`);let p=o(s.body);if(!p||p.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let T=u.card_data&&typeof u.card_data=="object"&&!Array.isArray(u.card_data)?u.card_data:{},E=Array.isArray(T.files)?T.files:[],y=[...E,...p],C=p.map((R,I)=>({idx:E.length+I,entry:R})),S=this.patch({params:{id:i,path:"card_data.files"},body:{value:y}});return S.status!=="success"?S:t({files_added:C})}catch(i){return n(i)}}}}function pe(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function se(e){return {status:"fail",error:e}}function Re(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function Mo(e){let t=new TextEncoder().encode(e),r=Array.from(t,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function wn(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function or(e){try{let t=JSON.parse(wn(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function kn(e){return Mo(JSON.stringify(e))}function Cn(e){try{let t=JSON.parse(wn(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function Xe(){return new Date().toISOString()}function Do(e){let t=new Map;return {appendEntries(r,n){if(!r||n.length===0)return;let o=t.get(r)??[];t.set(r,[...o,...n]);},dispatchEntriesForJournalId(r,n){if(!r)return;let o=t.get(r);if(!(!o||o.length===0)){for(let s of o)try{n(s);}catch(i){try{e(s,i instanceof Error?i.message:String(i));}catch{}}t.delete(r);}}}}function Sn(e,t,r={}){Dt(t.callbackTransport,"createBoardLiveCardsPublic");let n=t.callbackTransport,o=t.onWarn??(()=>{}),s=ke(e),i=r.boardRuntimeStoreRef,u=r.scratchStoreRef,p=r.taskExecutorRef,T=r.chatHandlerFlow;function E(){if(!i)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return i}function y(M){if(M.length!==0)try{let m=t.publishBoardChangeNotifications?.(M);m&&typeof m.catch=="function"&&m.catch(j=>o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${j instanceof Error?j.message:String(j)}`));}catch(m){o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${m instanceof Error?m.message:String(m)}`);}}function C(){let M=R().readCardStoreRef();if(!M)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let m=t.kvStorageForRef(M);return {readIndex(){return m.read("_index")},writeIndex(j){m.write("_index",j);},readCard(j){return m.read(j)},writeCard(j,K){return m.write(j,K),t.hashFn(K)},removeCard(j){m.delete(j);},cardExists(j){return m.read(j)!==null},defaultCardKey(j){return j}}}let S={readValues(M){let m=t.kvStorageForRef(E()),j=m.listKeys().sort();if(j.length===0)return {version:null,values:{}};let K={};for(let oe of j)K[oe]=m.read(oe);return {version:t.hashFn(K),values:K}},writeValues(M,m,j){let K=t.kvStorageForRef(E());for(let oe of j)K.delete(oe);for(let[oe,re]of Object.entries(m))K.write(oe,re);return t.hashFn(m)}},R=()=>Zt(t.kvStorageForRef(E())),I=()=>yn(S),x=()=>pn(t.journalAdapterForRef(E())),A=()=>Et(C(),o),F=()=>{let M=R().readOutputsStoreRef();if(!M)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return hn(t.kvStorageForRef(M))};function c(){return p??R().readTaskExecutorRef()}function h(){return !!I().readSnapshot(e.value).values[ct]}function d(){let M=I().readSnapshot(e.value);if(!M.values[ct])throw new Error(`Board not initialized at ${e.value}`);return tr(M.values)}function f(M,m){let j=I().commitSnapshot(e.value,{schemaVersion:Xt,expectedVersion:m,commitId:t.genId(),committedAt:Xe(),deleteKeys:[],shallowMerge:er(M)});if(!j.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${m??"null"} current=${j.currentVersion??"null"}`)}function l(M){x().appendEvent(M);}async function k(){let m=Do((B,N)=>{let Y=B.payload,le=(Y?.enrichedCard??{}).id??Y?.cardId??"unknown";l({type:"task-failed",taskName:le,error:N,timestamp:Xe()});}),j=d(),K=ht(j.graph),{events:oe,newCursor:re}=x().readEntriesAfterCursor(j.lastDrainedJournalId),Ae=H(),be=Yt(Ae,B=>t.resolveBlob(B)),Fe={...j.runtimeByCardId},qe=new Map,$e={readRuntime(B){return qe.get(B)??Fe[B]??{_sources:{}}},writeRuntime(B,N){qe.set(B,N),Fe[B]=N;}},We=[],He=new Map,lt={readSourceData(B,N){let Y=`${B}/${N}`;return He.has(Y)?He.get(Y):be.readSourceData(B,N)},ingestSourceDataStaged(B,N,Y,he){be.ingestSourceDataStaged(B,N,Y,he);},commitSourceData(B,N,Y){let he=`${B}/.staged/${Y}/${N}`,le=Ae.read(he);if(le==null){let De=Ae.keyRef?.(he);De&&(le=t.resolveBlob(De));}if(le==null)return false;let Te=`${B}/${N}`,Oe=le.trim();try{He.set(Te,JSON.parse(Oe));}catch{He.set(Te,Oe);}return We.push({cardId:B,outputFile:N,deliveryToken:Y}),true},hasSource(B,N){let Y=`${B}/${N}`;return He.has(Y)?true:be.hasSource(B,N)},listSources(B){let N=be.listSources(B),Y=new Set;for(let le of He.keys())le.startsWith(`${B}/`)&&Y.add(le.slice(`${B}/`.length));let he=new Set([...N,...Y]);return Array.from(he)}},et={cardStore:A(),cardRuntimeStore:$e,fetchedSourcesStore:lt,outputStore:F(),executionRequestStore:m},tt=[],kt=[],Ct=[],Ot=new Map,qt=new Set,Lr=(B,N)=>{tt.push({type:"task-completed",taskName:B,data:N,timestamp:Xe()});},vt=(B,N)=>{l({type:"task-failed",taskName:B,error:N,timestamp:Xe()});},At=$t(K,{handlers:{"card-handler":Rn(e,re,et,Lr,vt,(B,N)=>{kt.push({cardId:B,values:N});},B=>{Ct.push(B);})},onNodeRemoved:B=>{Ot.delete(B),qe.delete(B),delete Fe[B],qt.add(B);}});for(tt=oe;tt.length>0;){let B=tt;tt=[];for(let N of B)if(N.type==="task-restart"){let Y=et.cardStore.readCard(N.taskName);Y&&Ot.set(N.taskName,Y);}At.pushAll(B),await At.waitForHandlers();}let jt=At.getState();await At.dispose({wait:true});let pr=I().readSnapshot(e.value).version;f({lastDrainedJournalId:re,graph:yt(jt),runtimeByCardId:Fe},pr);for(let{cardId:B,values:N}of kt)et.outputStore.writeComputedValues(B,N);for(let B of Ct)et.outputStore.writeDataObjects(B);for(let{cardId:B,outputFile:N,deliveryToken:Y}of We)be.commitSourceData(B,N,Y);let a;try{a=Rt(s,jt),et.outputStore.writeStatusSnapshot(a);}catch(B){o(`[board-live-cards-public] status publish failed: ${B instanceof Error?B.message:String(B)}`);}let P=[];for(let{cardId:B,values:N}of kt)P.push({kind:"computed_values",cardId:B,values:N});for(let B of Ct)for(let[N,Y]of Object.entries(B))N&&P.push({kind:"data_object",key:N,payload:Y});for(let[B,N]of Ot)P.push({kind:"card_refreshed",cardId:B,card:N});for(let B of qt)P.push({kind:"card_removed",cardId:B});a!==void 0&&P.push({kind:"status",status:a}),y(P);let O=c()??{howToRun:"built-in",whatToRun:ke({kind:"built-in",value:"source-cli-task-executor"})},G=t.supportsDirectSourceOutput?.(O)===true;m.dispatchEntriesForJournalId(re,B=>{if(B.taskKind!=="source-fetch"){o(`[process-accumulated-events] unknown taskKind "${B.taskKind}" \u2014 skipping`);return}let N=B.payload,Y=N.enrichedCard?.id??"unknown",he=N.enrichedCard?.source_defs??[];if(O.howToRun==="queue-storage"&&G){try{let le=t.queueStorageForRef(_(),"task-executor"),Te=typeof O.extra?.boardId=="string"?O.extra.boardId:void 0,Oe=[];for(let De of he){if(!De.outputFile){o(`[dispatch] source "${De.bindTo}" has no outputFile \u2014 skipping`);continue}let Q=t.genId(),ue=`${Y}/.staged/${Q}/${De.outputFile}`,Ce=Ae.keyRef?.(ue);if(!Ce)continue;let ge={ref:ke(Ce),deliveryToken:Q,outputFile:De.outputFile,cardId:Y},Ie=kn({cbk:N.callbackToken,rg:e.value,br:ke(e),cid:Y,b:De.bindTo,d:De.outputFile,cs:void 0,rqt:N.rqt,dt:ge.deliveryToken});Oe.push({...Te?{boardId:Te}:{},ref:O,args:{source_def:De,base_ref:ke(e),callback:n.createCallback(Ie),output:ge}});}Oe.length>0&&le.enqueueMany(Oe);}catch(le){vt(Y,le instanceof Error?le.message:String(le));}return}for(let le of he){if(!le.outputFile){o(`[dispatch] source "${le.bindTo}" has no outputFile \u2014 skipping`);continue}let Te;if(G){let De=t.genId(),Q=`${Y}/.staged/${De}/${le.outputFile}`,ue=Ae.keyRef?.(Q);ue&&(Te={ref:ke(ue),deliveryToken:De,outputFile:le.outputFile,cardId:Y});}let Oe=kn({cbk:N.callbackToken,rg:e.value,br:ke(e),cid:Y,b:le.bindTo,d:le.outputFile,cs:void 0,rqt:N.rqt,...Te?{dt:Te.deliveryToken}:{}});t.dispatchExecution(O,{source_def:le,base_ref:ke(e),callback:n.createCallback(Oe),...Te?{output:Te}:{}}).catch(De=>vt(Y,De instanceof Error?De.message:String(De)));}});}function _(){let M=R().readQueueStoreRef();if(!M)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);return M}function $(){let M=t.queueStorageForRef(_(),"process-accumulated");M.enqueueIfAbsent?M.enqueueIfAbsent({boardRef:ke(e)},`process-accumulated:${ke(e)}`):M.enqueue({boardRef:ke(e)}),t.requestProcessAccumulated?.();}function J(){let M=t.queueStorageForRef(_(),"process-accumulated");for(;;){let m=M.lease({max:64,visibilityMs:1e3});if(m.length<=0)return;for(let j of m)M.ack(j.id,j.leaseToken);if(m.length<64)return}}async function W(){try{let M=()=>{let j=d(),{events:K}=x().readEntriesAfterCursor(j.lastDrainedJournalId);K.length<=0||$();},m=await $r(t.lock,k,M);return pe({ran:m!==!1})}catch(M){return Re(M)}}function te(){$();}function ie(M){try{let m=M.params?.cardStoreRef;if(!m)return se("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(i=M.params?.boardRuntimeStoreRef,!i)return se("init requires params.boardRuntimeStoreRef \u2014 pass the board runtime store ref here");if(!h()){let Fe=St(Ft);f({lastDrainedJournalId:"",graph:yt(Fe),runtimeByCardId:{}},null);}let j=M.params?.outputsStoreRef;if(!j)return se("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let K=M.params?.queueStoreRef;if(!K)return se("init requires params.queueStoreRef \u2014 pass the queue store ref here");let oe=M.params?.fetchedSourcesStoreRef;if(!oe)return se("init requires params.fetchedSourcesStoreRef \u2014 pass the fetched sources store ref here");if(u=M.params?.scratchStoreRef,!u)return se("init requires params.scratchStoreRef \u2014 pass the scratch store ref here");let re=M.params?.chatStoreRef;if(!re)return se("init requires params.chatStoreRef \u2014 pass the chat store ref here");let Ae=M.params?.artifactsStoreRef;if(!Ae)return se("init requires params.artifactsStoreRef \u2014 pass the artifacts store ref here");let be=R();be.writeBoardRuntimeStoreRef(i),be.writeCardStoreRef(m),be.writeOutputsStoreRef(j),be.writeQueueStoreRef(K),be.writeFetchedSourcesStoreRef(oe),be.writeChatStoreRef(re),be.writeArtifactsStoreRef(Ae);try{F().writeStatusSnapshot(Rt(s,ht(d().graph)));}catch{}return pe()}catch(m){return Re(m)}}function X(M){try{let m=F().readStatusSnapshot();if(!m){m=Rt(s,ht(d().graph));try{F().writeStatusSnapshot(m);}catch{}}return pe(m)}catch(m){return Re(m)}}function ee(M){try{let m=M.params?.id;if(!m)return se("removeCard requires params.id");try{t.kvStorage("card-upsert").delete(m);}catch{}return l({type:"task-removal",taskName:m,timestamp:Xe()}),te(),pe()}catch(m){return Re(m)}}function ne(M){try{let m=M.params?.cardId;if(!m)return se("addCardFiles requires params.cardId");let j=nr(A()).appendFiles({params:{id:m},body:M.body});if(j.status!=="success")return j;let K=v({params:{cardId:m}});return K.status!=="success"?K:pe({cardId:m,files_added:j.data.files_added,notified:!0})}catch(m){return Re(m)}}function v(M){try{let m=M.params?.cardId;if(!m)return se("cardRefreshedNotify requires params.cardId");let j=A().readCard(m);return j?(y([{kind:"card_refreshed",cardId:m,card:j}]),pe({cardId:m,notified:!0})):se(`Card "${m}" not found in board at ${e.value}`)}catch(m){return Re(m)}}function g(M){try{let m=M.params?.id;return m?(l({type:"task-restart",taskName:m,timestamp:Xe()}),te(),pe()):se("retrigger requires params.id")}catch(m){return Re(m)}}async function L(M){return J(),W()}function D(){let M=R().readFetchedSourcesStoreRef();if(!M)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return M}function H(){return t.blobStorageForRef(D())}function w(M){try{let m=M.params?.cardId,j=M.params?.all,K=!!M.params?.restart;if(!m&&!j)return se("upsertCard requires --card-id <id> or --all");let oe=j?A().readAllCards().map(re=>re.id):[m];for(let re of oe)if(!A().readCard(re))return se(`Card "${re}" not found in board at ${e.value}`);for(let re of oe){let Ae=A().readCard(re),be=rr(Ae),Fe=t.hashFn(be),qe=t.kvStorage("card-upsert"),$e=qe.read(re),We=$e?.taskConfigHash!==Fe;if(!(!We&&!K)){if(We){let He=$e?.blobRef??A().readCardKey(re)??re;l({type:"task-upsert",taskName:re,taskConfig:be,timestamp:Xe()}),qe.write(re,{blobRef:He,taskConfigHash:Fe,updatedAt:Xe()});}K&&l({type:"task-restart",taskName:re,timestamp:Xe()});}}return te(),pe()}catch(m){return Re(m)}}function b(M){try{let m=M.params?.token;if(!m)return se("taskFailed requires params.token");let j=M.params?.error??"unknown error",K=or(m);return K?(l({type:"task-failed",taskName:K.taskName,error:j,timestamp:Xe()}),te(),pe()):se("Invalid callback token")}catch(m){return Re(m)}}function q(M){try{let m=M.params?.token;if(!m)return se("taskProgress requires params.token");let K=(M.body??{}).update??{},oe=or(m);return oe?(l({type:"task-progress",taskName:oe.taskName,update:K,timestamp:Xe()}),te(),pe()):se("Invalid callback token")}catch(m){return Re(m)}}function U(M){try{let m=M.params?.token,j=M.params?.ref;if(!m)return se("sourceDataFetched requires params.token");if(!j)return se("sourceDataFetched requires params.ref");let K=Cn(m);if(!K)return se("Invalid source token");let{cbk:oe,cid:re,b:Ae,d:be,cs:Fe,rqt:qe,dt:$e}=K,We=Yt(H(),tt=>t.resolveBlob(tt)),He=$e||t.genId();$e||We.ingestSourceDataStaged(re,be,at(j),He);let lt=or(oe);if(!lt)return se("Invalid callback token embedded in source token");let et=Xe();return l({type:"task-progress",taskName:lt.taskName,update:{bindTo:Ae,outputFile:be,fetchedAt:et,deliveryToken:He,sourceChecksum:Fe,rqt:qe},timestamp:et}),te(),pe()}catch(m){return Re(m)}}function V(M){try{let m=M.params?.token,j=M.params?.reason??"unknown";if(!m)return se("sourceDataFetchFailure requires params.token");let K=Cn(m);if(!K)return se("Invalid source token");let{cbk:oe,b:re,d:Ae,cs:be,rqt:Fe}=K,qe=or(oe);return qe?(l({type:"task-progress",taskName:qe.taskName,update:{bindTo:re,outputFile:Ae,failure:!0,reason:j,sourceChecksum:be,rqt:Fe},timestamp:Xe()}),te(),pe()):se("Invalid callback token embedded in source token")}catch(m){return Re(m)}}function Z(M){try{let m=R().readCardStoreRef();return m?pe({storeRef:m}):se(`Board at ${e.value} has no card store configured`)}catch(m){return Re(m)}}function ae(M){try{return pe({storeRef:i??null})}catch(m){return Re(m)}}function fe(M){try{let m=R().readOutputsStoreRef();return m?pe({storeRef:m}):se(`Board at ${e.value} has no outputs store configured`)}catch(m){return Re(m)}}function we(M){try{return pe({storeRef:u??null})}catch(m){return Re(m)}}function Pe(M){try{let m=R().readChatStoreRef();return pe({storeRef:m})}catch(m){return Re(m)}}function Be(M){try{let m=R().readArtifactsStoreRef();return pe({storeRef:m})}catch(m){return Re(m)}}function Se(M){try{let m=R().readFetchedSourcesStoreRef();return pe({storeRef:m})}catch(m){return Re(m)}}function ce(M){try{let m=M.params?.key;if(!m)return se("getConfig requires params.key");let j=R(),K;switch(m){case "task-executor":K=p??null;break;case "chat-handler-flow":K=T??null;break;case "board-runtime-store-ref":K=j.readBoardRuntimeStoreRef();break;case "card-store-ref":K=j.readCardStoreRef();break;case "outputs-store-ref":K=j.readOutputsStoreRef();break;case "scratch-store-ref":K=u??null;break;case "chat-store-ref":K=j.readChatStoreRef();break;case "artifacts-store-ref":K=j.readArtifactsStoreRef();break;case "fetched-sources-store-ref":K=j.readFetchedSourcesStoreRef();break;default:return se(`getConfig: unknown key "${m}"`)}return pe({value:K})}catch(m){return Re(m)}}function Le(M){try{let m=M.params?.key;if(!m)return se("getOutputsDataObject requires params.key");let j=F().readDataObject(m);return pe(j)}catch(m){return Re(m)}}function ve(M){try{return pe(F().readAllDataObjects())}catch(m){return Re(m)}}function Me(M){try{let m=M.params?.key;if(!m)return se("getOutputsComputedValues requires params.key");let j=F().readComputedValues(m);return pe(j)}catch(m){return Re(m)}}function Ne(M){try{return pe(F().readAllComputedValues())}catch(m){return Re(m)}}function me(){return Yt(H(),M=>t.resolveBlob(M))}function Ze(M){let m=H().keyRef?.(M);if(!m)throw new Error("configured fetched-sources store does not support keyRef");return ke(m)}function Ke(M){try{let m=M.params?.key;if(!m)return se("getOutputsFetchedSources requires params.key");let j=me().listSources(m),K={};for(let oe of j)K[oe]=Ze(`${m}/${oe}`);return pe(K)}catch(m){return Re(m)}}function Ge(M){try{let m=me(),j=new Set;for(let oe of H().listKeys()){let re=oe.indexOf("/");re>0&&!oe.includes("/.staged/")&&j.add(oe.slice(0,re));}let K={};for(let oe of j){let re=m.listSources(oe);if(re.length>0){K[oe]={};for(let Ae of re)K[oe][Ae]=Ze(`${oe}/${Ae}`);}}return pe(K)}catch(m){return Re(m)}}return {init:ie,status:X,getBoardRuntimeStoreRef:ae,getCardStoreRef:Z,getOutputsStoreRef:fe,getScratchStoreRef:we,getChatStoreRef:Pe,getArtifactsStoreRef:Be,getFetchedSourcesStoreRef:Se,getConfig:ce,getOutputsDataObject:Le,getAllOutputsDataObjects:ve,getOutputsComputedValues:Me,getAllOutputsComputedValues:Ne,getOutputsFetchedSources:Ke,getAllOutputsFetchedSources:Ge,removeCard:ee,addCardFiles:ne,cardRefreshedNotify:v,retrigger:g,processAccumulatedEvents:L,upsertCard:w,taskFailed:b,taskProgress:q,sourceDataFetched:U,sourceDataFetchFailure:V}}function bn(e,t,r){let n=r?.taskExecutorRef,o=()=>{if(r){if(!r.boardRuntimeStoreRef)throw new Error(`Board at ${e.value} requires boardRuntimeStoreRef for non-core runtime operations.`);return Zt(t.kvStorageForRef(r.boardRuntimeStoreRef))}return Zt(t.kvStorage("config"))};function s(){let F=o().readCardStoreRef();if(!F)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let c=t.kvStorageForRef(F);return {readIndex(){return c.read("_index")},writeIndex(h){c.write("_index",h);},readCard(h){return c.read(h)},writeCard(h,d){return c.write(h,d),t.hashFn(d)},removeCard(h){c.delete(h);},cardExists(h){return c.read(h)!==null},defaultCardKey(h){return h}}}let i=()=>Et(s(),t.onWarn??(()=>{}));function u(){return n??o().readTaskExecutorRef()}async function p(F,c){let h=t.validateSchema(c),d=[],f=u();if(f&&Array.isArray(c.source_defs))for(let k of c.source_defs){let _=typeof k.bindTo=="string"?k.bindTo:"(unknown)";try{let $;try{$=await t.invokeExecutor(f,"validate-source-def",{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(k)});}catch(W){let te=W;if($=typeof te?.stdout=="string"?te.stdout:"",!$.trim()){d.push(`source "${_}": executor validate-source-def failed \u2014 ${W instanceof Error?W.message:String(W)}`);continue}}let J=JSON.parse($.trim());if(!J.ok&&Array.isArray(J.errors))for(let W of J.errors)d.push(`source "${_}": ${W}`);}catch($){d.push(`source "${_}": executor validate-source-def failed \u2014 ${$ instanceof Error?$.message:String($)}`);}}let l=[...h.errors,...d];return pe({cardId:F,isValid:l.length===0,issues:l})}function T(F,c){let h=F.params?.sourceIdx,d=F.params?.outRef;if(h===void 0)return se(`${c} requires params.sourceIdx`);if(!F.body||typeof F.body!="object"||Array.isArray(F.body))return se(`${c} requires card JSON object in body`);let f=F.body,l=f["card-content"]??f,k=f["mock-projections"]??{},_=l.source_defs??[];if(h<0||h>=_.length)return se(`sourceIdx ${h} out of range (card has ${_.length} source(s))`);let $=_[h],J=typeof $.bindTo=="string"?$.bindTo:"source";return {src:$,bindTo:J,outRef:d,mockProjections:k}}async function E(F){try{if(!F.body||typeof F.body!="object"||Array.isArray(F.body))return se("validateCardPreflight requires card JSON object in body");let c=F.body,h=c["card-content"]??c,d=typeof h.id=="string"?h.id:"(unknown)";return await p(d,h)}catch(c){return Re(c)}}async function y(F){try{let c=T(F,"probeSourcePreflight");if("status"in c)return c;let h=u();if(!h)return se("No task-executor registered for this board");try{let d={...c.src,_projections:c.mockProjections},f=await t.invokeExecutor(h,"probe-source-preflight",{timeout:c.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(d)}),l=JSON.parse(f.trim());return l.ok?pe({bindTo:c.bindTo,reachable:l.reachable,latencyMs:l.latencyMs,note:l.note}):se(l.error??"Preflight probe failed")}catch{return se("Executor does not support probe-source-preflight")}}catch(c){return Re(c)}}async function C(F){try{let c=T(F,"runSourcePreflight");if("status"in c)return c;let h=u();if(!h)return se("No task-executor registered for this board");try{let d={...c.src,_projections:c.mockProjections},f=await t.invokeExecutor(h,"run-source-preflight",{timeout:c.src.timeout??t.executorTimeouts?.probeMs??6e4,input:JSON.stringify(d)}),l=JSON.parse(f.trim());if(!l.ok)return pe({bindTo:c.bindTo,ok:!1,result:null,issues:[l.error??"Preflight run failed"]});if(c.outRef){let k=at(c.outRef);t.absoluteBlob.write(k.value,JSON.stringify(l.resultValue,null,2));}return pe({bindTo:typeof l.bindTo=="string"?l.bindTo:c.bindTo,ok:!0,result:l.resultValue??null,issues:[]})}catch(d){let f=d instanceof Error?d.message:String(d);return pe({bindTo:c.bindTo,ok:!1,result:null,issues:[f]})}}catch(c){return Re(c)}}async function S(F){try{let c=u();if(!c)return se("No task-executor registered for this board");let h=await t.invokeExecutor(c,"describe-capabilities",{timeout:t.executorTimeouts?.describeMs??1e4});return pe(JSON.parse(h.trim()))}catch(c){return Re(c)}}function R(F){try{let c=F.body;if(!c||!Array.isArray(c.ops))return se("updatesInCardStore requires body.ops array");let h=c.ops,d=i();for(let f of h){let l=f.op,k=f.id;if(!k)return se('op is missing "id"');if(l==="update"){let _=f["card-content"];if(!_)return se(`update op for "${k}" is missing "card-content"`);d.writeCard(k,_);}else return se(`Unknown op type: "${l??"(none)"}"`)}return pe()}catch(c){return Re(c)}}function I(F){try{let c=F.body;if(!c||!Array.isArray(c.ids))return se("readFromCardStore requires body.ids array");let h=c.ids,d=i(),f=h.map(l=>({id:l,"card-content":d.readCard(l)}));return pe({cards:f})}catch(c){return Re(c)}}function x(F){try{if(!F.body||typeof F.body!="object"||Array.isArray(F.body))return se("evalCardCompute requires a JSON object in body");let c=F.body,h=c["card-content"]??c,d=typeof h.id=="string"?h.id:"(unknown)",f=c["mock-fetched-sources"]??{},l=c["mock-requires"]??{},k=h.compute;if(!k||!Array.isArray(k)||k.length===0)return pe({cardId:d,ok:!0,computed_values:{},errors:[]});let _={id:d,card_data:h.card_data??{},requires:l,source_defs:h.source_defs,compute:k},$=ze.runSync(_,{sourcesData:f}),J=$.node.computed_values??{},W=$.errors??[];return pe({cardId:d,ok:W.length===0,computed_values:J,errors:W})}catch(c){return Re(c)}}async function A(F){try{if(!F.body||typeof F.body!="object"||Array.isArray(F.body))return se("simulateCardCycle requires a JSON object in body");let c=F.body,h=c["card-content"]??c,d=typeof h.id=="string"?h.id:"(unknown)",f=c["mock-fetched-sources"]??{},l=c["mock-requires"]??{},k=await p(d,h),_=k.status==="success"?{isValid:k.data.isValid,issues:k.data.issues}:{isValid:!1,issues:[k.status==="fail"?k.error:"internal error"]},$=h.source_defs??[],J=h.card_data??{},W=[],te=[];if($.length>0){W=ze.enrichSourcesSync($,{card_data:J,requires:l});for(let H of W){let w=H.projections,b=H._projections;if(w&&b){for(let q of Object.keys(w))if(b[q]===void 0){let U=typeof H.bindTo=="string"?H.bindTo:"(unknown)";te.push({bindTo:U,key:q,error:`Projection "${q}" resolved to undefined`});}}}}let ie=[],X={...f},ee=c["task-executor-ref"],ne=(ee?.howToRun&&ee?.whatToRun?ee:void 0)??u();for(let H=0;H<W.length;H++){let w=W[H],b=typeof w.bindTo=="string"?w.bindTo:`source_${H}`;if(!ne){ie.push({bindTo:b,skipped:!0,error:"No task executor configured"});continue}try{let q={...w},U=await t.invokeExecutor(ne,"run-source-preflight",{timeout:w.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(q)}),V=JSON.parse(U.trim());V.ok&&!Object.prototype.hasOwnProperty.call(f,b)&&Object.prototype.hasOwnProperty.call(V,"resultValue")&&(X[b]=V.resultValue),ie.push({bindTo:b,reachable:V.reachable,latencyMs:V.latencyMs,error:V.ok?void 0:V.error});}catch{ie.push({bindTo:b,skipped:!0,error:"Executor does not support run-source-preflight"});}}let v=h.compute,g={},L=[];if(v&&Array.isArray(v)&&v.length>0){let H={id:d,card_data:J,requires:l,source_defs:h.source_defs,compute:v},w=ze.runSync(H,{sourcesData:X});g=w.node.computed_values??{},L=w.errors??[];}let D=_.isValid&&te.length===0&&L.length===0&&ie.every(H=>H.reachable!==!1);return pe({cardId:d,ok:D,validation:_,source_probes:ie,projection_errors:te,fetched_sources:X,computed_values:g,compute_errors:L})}catch(c){return Re(c)}}return {validateCardPreflight:E,probeSourcePreflight:y,runSourcePreflight:C,evalCardCompute:x,simulateCardCycle:A,describeTaskExecutorCapabilities:S,updatesInCardStore:R,readFromCardStore:I}}async function vn(e,t,r){let n=await e.tryAcquire();if(!n)return false;try{await t();}finally{await n();}return await r?.(),true}function Ar(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function xr(e){return {async enqueueRequest(t){return (await e.enqueue(t)).id},async leaseRequests(t){return (await e.lease(t)).map(r=>({...Ar(r),leaseToken:r.leaseToken,leaseExpiresAt:r.leaseExpiresAt}))},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,n){return e.nack(t,r,n)},async peekActive(){return (await e.peekActive()).map(Ar)},async peekDeadLetter(){return (await e.peekDeadLetter()).map(t=>({...Ar(t),reason:t.reason}))}}}function An(e){async function t(r){let n=await e.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {async readTaskExecutorRef(){let r=await t("task-executor");if(r?.trim())return Ht(r.trim())},writeTaskExecutorRef(r){return e.write("task-executor",Kt(r))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){return e.write("chat-handler-flow",r)},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){return e.write("board-runtime-store-ref",r)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){return e.write("card-store-ref",r)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){return e.write("outputs-store-ref",r)},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){return e.write("queue-store-ref",r)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){return e.write("scratch-store-ref",r)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){return e.write("chat-store-ref",r)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){return e.write("artifacts-store-ref",r)},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){return e.write("fetched-sources-store-ref",r)}}}function No(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function sr(e,t){return No(e)?e.then(t):t(e)}function xn(e,t){let r={...e};for(let[n,o]of Object.entries(t))o!==null&&typeof o=="object"&&!Array.isArray(o)&&r[n]!==null&&typeof r[n]=="object"&&!Array.isArray(r[n])?r[n]=xn(r[n],o):r[n]=o;return r}function ar(e,t,r){if(t.length===0)return e;let[n,...o]=t;if(o.length===0)return {...e,[n]:r};let s=e[n]!==null&&typeof e[n]=="object"&&!Array.isArray(e[n])?e[n]:{};return {...e,[n]:ar(s,o,r)}}function In(e){return {read:r=>e.read(r),get(r,n){return sr(e.read(r),o=>{if(o===null)return null;let s=o;for(let i of n.split(".").filter(Boolean)){if(s===null||typeof s!="object"||Array.isArray(s))return null;s=s[i]??null;}return s??null})},write:(r,n)=>e.write(r,n),delete:r=>e.delete(r),listKeys:r=>e.listKeys(r),shallowMerge(r,n){return sr(e.read(r),o=>e.write(r,{...o??{},...n}))},deepMerge(r,n){return sr(e.read(r),o=>e.write(r,xn(o??{},n)))},patch(r,n,o){return sr(e.read(r),s=>{let i=n.split(".").filter(Boolean);return e.write(r,ar(s??{},i,o))})}}}function ir(e){return In(e)}function ur(e,t){return {async readIndex(){return await e.read("_index")},writeIndex(r){return e.write("_index",r)},async readCard(r){return await e.read(r)},async writeCard(r,n){return await e.write(r,n),t(n)},removeCard(r){return e.delete(r)},async cardExists(r){return await e.read(r)!==null},defaultCardKey(r){return r}}}function dr(e,t){async function r(){return await e.readIndex()??{}}return {async readCard(n){let o=(await r())[n];return !o||!await e.cardExists(o.key)?null:await e.readCard(o.key)},async readCardKey(n){return (await r())[n]?.key??null},async readAllCards(){let n=[];for(let[o,s]of Object.entries(await r())){if(!await e.cardExists(s.key))continue;let i=await e.readCard(s.key);i?n.push(i):t?.(`[card-store] could not read card "${o}" at key "${s.key}"`);}return n},async readChecksumIndex(){let n={};for(let[o,s]of Object.entries(await r()))n[o]=s.checksum;return n},async changedSince(n){let o=await r(),s=[];for(let[i,u]of Object.entries(o))n[i]!==u.checksum&&s.push(i);for(let i of Object.keys(n))o[i]||s.push(i);return s},async validateUpsert(n,o){let s=await r(),i=s[n],u=Object.entries(s).find(([,p])=>p.key===o);return i&&i.key!==o?{ok:false,error:`Card id "${n}" is already mapped to key "${i.key}", cannot remap to "${o}"`}:u&&u[0]!==n?{ok:false,error:`Key "${o}" is already mapped to card id "${u[0]}", cannot remap to "${n}"`}:{ok:true}},async writeCard(n,o,s){let i=await r(),u=s??i[n]?.key??e.defaultCardKey(n),p=await e.writeCard(u,o);i[n]={key:u,checksum:p,updatedAt:new Date().toISOString()},await e.writeIndex(i);},async patchCard(n,o,s){let i=await r(),u=i[n];if(!u||!await e.cardExists(u.key))throw new Error(`card "${n}" not found`);let p=await e.readCard(u.key);if(!p||typeof p!="object"||Array.isArray(p))throw new Error(`card "${n}" is not patchable`);let T=String(o||"").split(".").filter(Boolean),E=ar(p,T,s),y=await e.writeCard(u.key,E);i[n]={key:u.key,checksum:y,updatedAt:new Date().toISOString()},await e.writeIndex(i);},async removeCard(n){let o=await r(),s=o[n];s&&(await e.removeCard(s.key),delete o[n],await e.writeIndex(o));},readIndex(){return r()}}}function _e(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function ye(e){return {status:"fail",error:e}}function Ee(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function Qe(){return new Date().toISOString()}function $o(e){let t=new TextEncoder().encode(e),r=Array.from(t,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function _n(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function cr(e){try{let t=JSON.parse(_n(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function Tn(e){return $o(JSON.stringify(e))}function Pn(e){try{let t=JSON.parse(_n(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function Uo(e){return br(e,gn,()=>({_sources:{}}))}function Vo(e,t){return Qt(e,t)}function Ko(e){return zt(e)}function Ho(e,t){return Sr(e,t)}function Jo(e,t,r,n,o,s){return async i=>{let u=[],p=await r.cardStore.readCard(i.nodeId);if(!p)return "task-initiate-failure";let T=p.id,E=p.card_data??{},y=p.source_defs??[],C=y.filter(X=>X.optionalForCompletionGating!==true),S=await r.cardRuntimeStore.readRuntime(T),R=false,I=async()=>{R&&(await r.cardRuntimeStore.writeRuntime(T,S),R=false);},x=X=>Tt(S._sources[X]),A=(X,ee)=>{S._sources[X]=Tt(ee),R=true;},F=i.taskState?.executionCount??0;if(S._lastExecutionCount!==F&&(S._sources={},S._lastExecutionCount=F,R=true),i.update){let X=i.update.outputFile;if(X){let ee=x(X);if(i.update.failure){let ne=i.update.rqt??ee.lastRequestedToken??ee.queueRequestedToken;ne&&A(X,_t(ee,ne));}else {let ne=i.update.rqt;if(!ee.lastCompletedToken||ne>ee.lastCompletedToken){let v=typeof i.update.deliveryToken=="string"?i.update.deliveryToken:void 0,g=v?await r.fetchedSourcesStore.commitSourceData(T,X,v):false;A(X,g?vr(ee,ne):_t(ee,ne));}}await I();}}let c={};for(let X of y){if(!X.outputFile)continue;let ee=await r.fetchedSourcesStore.readSourceData(T,X.outputFile);ee!==null&&(c[X.bindTo]=ee);}let h={};for(let[X,ee]of Object.entries(i.state??{}))if(ee!==null&&typeof ee=="object"&&!Array.isArray(ee)){let ne=ee[X];h[X]=ne!==void 0?ne:ee;}else h[X]=ee;let d={id:T,card_data:{...E},requires:h,source_defs:y,compute:p.compute};d._sourcesData=c,p.compute&&ze.runSync(d,{sourcesData:c}),(o??(()=>{}))(T,d.computed_values??{});let f=ze.enrichSourcesSync(Array.isArray(p.source_defs)?p.source_defs:void 0,{card_data:p.card_data,requires:h}),l={...p,source_defs:Array.isArray(f)?f.map(X=>({...X,boardDir:typeof X.boardDir=="string"&&X.boardDir?X.boardDir:e.value})):f},k=Qe(),_=i.update?void 0:k,$=C.filter(X=>{let ee=X.outputFile;if(typeof ee!="string"||!ee)return true;let ne=x(ee);_&&(ne={...ne,queueRequestedToken:_},A(ee,ne));let v=ne.queueRequestedToken??ne.lastRequestedToken??k;return Pt(ne,v)==="dispatch"});if(await I(),$.length>0){let X=false,ee=k;for(let ne of $){let v=ne.outputFile;if(typeof v!="string"||!v)continue;let g=x(v),L=g.queueRequestedToken??k;A(v,{...g,lastRequestedToken:L}),ee=L,X=true;}return X&&await I(),X&&(u.push({taskKind:"source-fetch",payload:{boardRef:ke(e),enrichedCard:l,callbackToken:i.callbackToken,rqt:ee}}),await r.executionRequestStore.appendEntries(t,u)),"task-initiated"}if(C.some(X=>{let ee=X.outputFile;if(typeof ee!="string"||!ee)return false;let ne=x(ee),v=ne.queueRequestedToken??ne.lastRequestedToken??k;return Pt(ne,v)==="in-flight"}))return "task-initiated";let W=p.provides??[],te={};for(let{bindTo:X,ref:ee}of W)te[X]=ze.resolve(d,ee);return (s??(()=>{}))(te),y.filter(X=>{if(X.optionalForCompletionGating!==true)return false;let ee=x(X.outputFile);return !ee.lastRequestedToken||!ee.lastCompletedToken?true:ee.lastCompletedToken<=ee.lastRequestedToken}).length>0&&u.push({taskKind:"source-fetch",payload:{boardRef:ke(e),enrichedCard:l,callbackToken:i.callbackToken,rqt:k}}),n(i.nodeId,te),u.length>0&&await r.executionRequestStore.appendEntries(t,u),"task-initiated"}}function En(e,t,r={}){Dt(t.callbackTransport,"createAsyncBoardLiveCardsPublic");let n=t.callbackTransport,o=t.warn??(()=>{}),s=ke(e),i=null,u=r.boardRuntimeStoreRef,p=r.scratchStoreRef,T=r.taskExecutorRef,E=r.chatHandlerFlow;function y(){if(!u)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return u}function C(v){if(v.length!==0)try{return Promise.resolve(t.publishBoardChangeNotifications?.(v)).catch(g=>{o(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${g instanceof Error?g.message:String(g)}`);})}catch(g){o(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${g instanceof Error?g.message:String(g)}`);return}}let S=()=>An(t.kvStorageForRef(y())),R=e.value,I=()=>Gt(Cr(()=>t.kvStorageForRef(y()),t.hashFn),"v1"),x=async()=>{let v=await S().readOutputsStoreRef();if(!v)throw new Error(`Board at ${e.value} has no outputs store configured.`);return Ko(t.kvStorageForRef(v))},A=async()=>{let v=await S().readCardStoreRef();if(!v)throw new Error(`Board at ${e.value} has no card store configured.`);let g=t.kvStorageForRef(v);return dr(ur(ir(g),t.hashFn),o)};async function F(){return !!(await I().readSnapshot(R)).values[ct]}async function c(){let v=await I().readSnapshot(R);if(!v.values[ct])throw new Error(`Board not initialized at ${e.value}`);return tr(v.values)}async function h(v,g){let L=await I().commitSnapshot(R,{schemaVersion:"v1",expectedVersion:g,deleteKeys:[],shallowMerge:er(v)});if(!L.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${g??"null"} current=${L.currentVersion??"null"}`)}let d=()=>ln(t.journalStorageForRef(y()));async function f(){return T??await S().readTaskExecutorRef()}async function l(v){await d().appendEvent(v);}async function k(){let v=await S().readFetchedSourcesStoreRef();if(!v)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return v}async function _(){return t.blobStorageForRef(await k())}async function $(){return Vo(await _(),v=>t.resolveBlob(v))}async function J(v){let g=(await _()).keyRef?.(v);if(!g)throw new Error("configured fetched-sources store does not support keyRef");let L=await Promise.resolve(g);return ke(L)}async function W(){let v=Ho(t.kvStorageForRef(y()),async(m,j)=>{let K=m.payload,re=(K.enrichedCard??{}).id??K.cardId??"unknown";await l({type:"task-failed",taskName:re,error:j,timestamp:Qe()});}),g=Uo(t.kvStorageForRef(y())),L=await _(),D=await $(),H=await A(),w=await x(),b=new Map,q=new Map,U=[],V=[],Z=[],ae=new Map,fe=new Set,we={async readRuntime(m){return b.get(m)??await g.readRuntime(m)},async writeRuntime(m,j){b.set(m,j),ce[m]=j;}},Pe={async readSourceData(m,j){let K=`${m}/${j}`;return q.has(K)?q.get(K):await D.readSourceData(m,j)},ingestSourceDataStaged(m,j,K,oe){return D.ingestSourceDataStaged(m,j,K,oe)},async commitSourceData(m,j,K){let oe=`${m}/.staged/${K}/${j}`,re=await L.read(oe);if(re==null){let Fe=await Promise.resolve(L.keyRef?.(oe));Fe&&(re=await t.resolveBlob(Fe));}if(re==null)return false;let Ae=`${m}/${j}`,be=re.trim();try{q.set(Ae,JSON.parse(be));}catch{q.set(Ae,be);}return U.push({cardId:m,outputFile:j,deliveryToken:K}),true},async hasSource(m,j){let K=`${m}/${j}`;return q.has(K)||await D.hasSource(m,j)},async listSources(m){let j=await D.listSources(m),K=[...q.keys()].filter(oe=>oe.startsWith(`${m}/`)).map(oe=>oe.slice(`${m}/`.length));return [...new Set([...j,...K])]}},Be=await c(),Se=ht(Be.graph),ce={...Be.runtimeByCardId},{events:Le,newCursor:ve}=await d().readEntriesAfterCursor(Be.lastDrainedJournalId),Me=Le,Ne=$t(Se,{handlers:{"card-handler":Jo(e,ve,{cardStore:H,cardRuntimeStore:we,fetchedSourcesStore:Pe,executionRequestStore:v},(m,j)=>{Me.push({type:"task-completed",taskName:m,data:j,timestamp:Qe()});},(m,j)=>{V.push({cardId:m,values:j});},m=>{Z.push(m);})},onNodeRemoved:m=>{ae.delete(m),b.delete(m),delete ce[m],fe.add(m);}});for(;Me.length>0;){let m=Me;Me=[];for(let j of m)if(j.type==="task-restart"){let K=await H.readCard(j.taskName);K&&ae.set(j.taskName,K);}Ne.pushAll(m),await Ne.waitForHandlers();}let me=Ne.getState();await Ne.dispose({wait:true}),await h({lastDrainedJournalId:ve,graph:yt(me),runtimeByCardId:ce},(await I().readSnapshot(R)).version);for(let{cardId:m,values:j}of V)await w.writeComputedValues(m,j);for(let m of Z)await w.writeDataObjects(m);for(let[m,j]of b)await g.writeRuntime(m,j);for(let m of U)await D.commitSourceData(m.cardId,m.outputFile,m.deliveryToken);let Ze=Rt(s,me);await w.writeStatusSnapshot(Ze);let Ke=[];for(let{cardId:m,values:j}of V)Ke.push({kind:"computed_values",cardId:m,values:j});for(let m of Z)for(let[j,K]of Object.entries(m))Ke.push({kind:"data_object",key:j,payload:K});for(let[m,j]of ae)Ke.push({kind:"card_refreshed",cardId:m,card:j});for(let m of fe)Ke.push({kind:"card_removed",cardId:m});Ke.push({kind:"status",status:Ze}),await C(Ke);let Ge=await f();if(!Ge)return;let M=t.supportsDirectSourceOutput?.(Ge)===true;await v.dispatchEntriesForJournalId(ve,async m=>{if(m.taskKind!=="source-fetch"){o(`[async-process-accumulated-events] unknown taskKind "${m.taskKind}" \u2014 skipping`);return}let j=m.payload,K=j.enrichedCard?.id??"unknown",oe=j.enrichedCard?.source_defs??[];if(Ge.howToRun==="queue-storage"&&M){try{let re=await S().readQueueStoreRef();if(!re)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let Ae=t.queueStorageForRef(re,"task-executor"),be=typeof Ge.extra?.boardId=="string"?Ge.extra.boardId:void 0,Fe=[];for(let qe of oe){if(!qe.outputFile)continue;let $e=t.genId(),We=`${K}/.staged/${$e}/${qe.outputFile}`,He=await Promise.resolve(L.keyRef?.(We));if(!He)continue;let lt={ref:ke(He),deliveryToken:$e,outputFile:qe.outputFile,cardId:K},et=Tn({cbk:j.callbackToken,rg:e.value,br:ke(e),cid:K,b:qe.bindTo,d:qe.outputFile,cs:void 0,rqt:j.rqt,dt:lt.deliveryToken});Fe.push({...be?{boardId:be}:{},ref:Ge,args:{source_def:qe,base_ref:ke(e),callback:n.createCallback(et),output:lt}});}Fe.length>0&&await Ae.enqueueMany(Fe);}catch(re){await l({type:"task-failed",taskName:K,error:re instanceof Error?re.message:String(re),timestamp:Qe()});}return}for(let re of oe){if(!re.outputFile)continue;let Ae;if(M){let qe=t.genId(),$e=`${K}/.staged/${qe}/${re.outputFile}`,We=await Promise.resolve(L.keyRef?.($e));We&&(Ae={ref:ke(We),deliveryToken:qe,outputFile:re.outputFile,cardId:K});}let be=Tn({cbk:j.callbackToken,rg:e.value,br:ke(e),cid:K,b:re.bindTo,d:re.outputFile,cs:void 0,rqt:j.rqt,...Ae?{dt:Ae.deliveryToken}:{}}),Fe=await t.dispatchExecution(Ge,{source_def:re,base_ref:ke(e),callback:n.createCallback(be),...Ae?{output:Ae}:{}});Fe.dispatched||await l({type:"task-failed",taskName:K,error:Fe.error??"dispatch failed",timestamp:Qe()});}});}async function te(){try{let v=async()=>{let L=await c(),{events:D}=await d().readEntriesAfterCursor(L.lastDrainedJournalId);D.length>0&&await X();},g=await vn(t.lock,W,v);return _e({ran:g!==!1})}catch(v){return Ee(v)}}async function ie(){return i||(i=te().finally(()=>{i=null;}),i)}async function X(){let v=await S().readQueueStoreRef();if(!v)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let g=t.queueStorageForRef(v,"process-accumulated");g.enqueueIfAbsent?await g.enqueueIfAbsent({boardRef:ke(e)},`process-accumulated:${ke(e)}`):await g.enqueue({boardRef:ke(e)}),await t.requestProcessAccumulated?.();}async function ee(){let v=await S().readQueueStoreRef();if(!v)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let g=t.queueStorageForRef(v,"process-accumulated");for(;;){let L=await g.lease({max:64,visibilityMs:1e3});if(L.length<=0)return;for(let D of L)await g.ack(D.id,D.leaseToken);if(L.length<64)return}}function ne(){X();}return {async init(v){try{let g=v.params?.cardStoreRef;if(!g)return ye("init requires params.cardStoreRef");if(u=v.params?.boardRuntimeStoreRef,!u)return ye("init requires params.boardRuntimeStoreRef");let L=v.params?.outputsStoreRef;if(!L)return ye("init requires params.outputsStoreRef");let D=v.params?.queueStoreRef;if(!D)return ye("init requires params.queueStoreRef");let H=v.params?.fetchedSourcesStoreRef;if(!H)return ye("init requires params.fetchedSourcesStoreRef");if(p=v.params?.scratchStoreRef,!p)return ye("init requires params.scratchStoreRef");let w=v.params?.chatStoreRef;if(!w)return ye("init requires params.chatStoreRef");let b=v.params?.artifactsStoreRef;if(!b)return ye("init requires params.artifactsStoreRef");await F()||await h({lastDrainedJournalId:"",graph:yt(St(Ft)),runtimeByCardId:{}},null);let q=S();return await q.writeBoardRuntimeStoreRef(u),await q.writeCardStoreRef(g),await q.writeOutputsStoreRef(L),await q.writeQueueStoreRef(D),await q.writeFetchedSourcesStoreRef(H),await q.writeChatStoreRef(w),await q.writeArtifactsStoreRef(b),await(await x()).writeStatusSnapshot(Rt(s,ht((await c()).graph))),_e()}catch(g){return Ee(g)}},async status(v){try{let g=await x(),L=await g.readStatusSnapshot();return L||(L=Rt(s,ht((await c()).graph)),await g.writeStatusSnapshot(L)),_e(L)}catch(g){return Ee(g)}},async getCardStoreRef(v){try{let g=await S().readCardStoreRef();return g?_e({storeRef:g}):ye(`Board at ${e.value} has no card store configured`)}catch(g){return Ee(g)}},async getBoardRuntimeStoreRef(v){try{return _e({storeRef:u??null})}catch(g){return Ee(g)}},async getOutputsStoreRef(v){try{let g=await S().readOutputsStoreRef();return g?_e({storeRef:g}):ye(`Board at ${e.value} has no outputs store configured`)}catch(g){return Ee(g)}},async getScratchStoreRef(v){try{return _e({storeRef:p??null})}catch(g){return Ee(g)}},async getChatStoreRef(v){try{return _e({storeRef:await S().readChatStoreRef()})}catch(g){return Ee(g)}},async getArtifactsStoreRef(v){try{return _e({storeRef:await S().readArtifactsStoreRef()})}catch(g){return Ee(g)}},async getFetchedSourcesStoreRef(v){try{return _e({storeRef:await S().readFetchedSourcesStoreRef()})}catch(g){return Ee(g)}},async getConfig(v){try{let g=v.params?.key;if(!g)return ye("getConfig requires params.key");let L=S(),D;switch(g){case "task-executor":D=T??null;break;case "chat-handler-flow":D=E??null;break;case "board-runtime-store-ref":D=await L.readBoardRuntimeStoreRef();break;case "card-store-ref":D=await L.readCardStoreRef();break;case "outputs-store-ref":D=await L.readOutputsStoreRef();break;case "scratch-store-ref":D=p??null;break;case "chat-store-ref":D=await L.readChatStoreRef();break;case "artifacts-store-ref":D=await L.readArtifactsStoreRef();break;case "fetched-sources-store-ref":D=await L.readFetchedSourcesStoreRef();break;default:return ye(`getConfig: unknown key "${g}"`)}return _e({value:D})}catch(g){return Ee(g)}},async getOutputsDataObject(v){try{let g=v.params?.key;return g?_e(await(await x()).readDataObject(g)):ye("getOutputsDataObject requires params.key")}catch(g){return Ee(g)}},async getAllOutputsDataObjects(v){try{return _e(await(await x()).readAllDataObjects())}catch(g){return Ee(g)}},async getOutputsComputedValues(v){try{let g=v.params?.key;return g?_e(await(await x()).readComputedValues(g)):ye("getOutputsComputedValues requires params.key")}catch(g){return Ee(g)}},async getAllOutputsComputedValues(v){try{return _e(await(await x()).readAllComputedValues())}catch(g){return Ee(g)}},async getOutputsFetchedSources(v){try{let g=v.params?.key;if(!g)return ye("getOutputsFetchedSources requires params.key");let L=await(await $()).listSources(g),D={};for(let H of L)D[H]=await J(`${g}/${H}`);return _e(D)}catch(g){return Ee(g)}},async getAllOutputsFetchedSources(v){try{let g=await $(),L=await(await _()).listKeys(),D=new Set;for(let w of L){let b=w.indexOf("/");b>0&&!w.includes("/.staged/")&&D.add(w.slice(0,b));}let H={};for(let w of D){let b=await g.listSources(w);if(b.length!==0){H[w]={};for(let q of b)H[w][q]=await J(`${w}/${q}`);}}return _e(H)}catch(g){return Ee(g)}},async addCardFiles(v){try{let g=v.params?.cardId;if(!g)return ye("addCardFiles requires params.cardId");let L=await A(),D=await L.readCard(g);if(!D)return ye(`card "${g}" not found`);let H=v.body,w=Array.isArray(H)?H:H&&typeof H=="object"&&Array.isArray(H.files)?H.files:H!=null?[H]:null;if(!w||w.length===0)return ye("addCardFiles requires a file metadata object, array, or body.files array");let b=D.card_data&&typeof D.card_data=="object"&&!Array.isArray(D.card_data)?D.card_data:{},q=Array.isArray(b.files)?b.files:[],U=[...q,...w],V=w.map((ae,fe)=>({idx:q.length+fe,entry:ae}));await L.writeCard(g,{...D,card_data:{...b,files:U}});let Z=await this.cardRefreshedNotify({params:{cardId:g}});return Z.status!=="success"?Z:_e({cardId:g,files_added:V,notified:!0})}catch(g){return Ee(g)}},async cardRefreshedNotify(v){try{let g=v.params?.cardId;if(!g)return ye("cardRefreshedNotify requires params.cardId");let L=await(await A()).readCard(g);return L?(await C([{kind:"card_refreshed",cardId:g,card:L}]),_e({cardId:g,notified:!0})):ye(`Card "${g}" not found in board at ${e.value}`)}catch(g){return Ee(g)}},async removeCard(v){try{let g=v.params?.id;if(!g)return ye("removeCard requires params.id");try{await t.kvStorage("card-upsert").delete(g);}catch{}return await l({type:"task-removal",taskName:g,timestamp:Qe()}),ne(),_e()}catch(g){return Ee(g)}},async retrigger(v){try{let g=v.params?.id;return g?(await l({type:"task-restart",taskName:g,timestamp:Qe()}),ne(),_e()):ye("retrigger requires params.id")}catch(g){return Ee(g)}},async processAccumulatedEvents(v){return await ee(),ie()},async upsertCard(v){try{let g=v.params?.cardId,L=v.params?.all,D=!!v.params?.restart;if(!g&&!L)return ye("upsertCard requires --card-id <id> or --all");let H=await A(),w=L?(await H.readAllCards()).map(q=>q.id):[g];for(let q of w)if(!await H.readCard(q))return ye(`Card "${q}" not found in board at ${e.value}`);let b=t.kvStorage("card-upsert");for(let q of w){let U=await H.readCard(q);if(!U)continue;let V=rr(U),Z=t.hashFn(V),ae=await b.read(q),fe=ae?.taskConfigHash!==Z;if(!(!fe&&!D)){if(fe){let we=ae?.blobRef??await H.readCardKey(q)??q;await l({type:"task-upsert",taskName:q,taskConfig:V,timestamp:Qe()}),await b.write(q,{blobRef:we,taskConfigHash:Z,updatedAt:Qe()});}D&&await l({type:"task-restart",taskName:q,timestamp:Qe()});}}return ne(),_e()}catch(g){return Ee(g)}},async taskFailed(v){try{let g=v.params?.token;if(!g)return ye("taskFailed requires params.token");let L=v.params?.error??"unknown error",D=cr(g);return D?(await l({type:"task-failed",taskName:D.taskName,error:L,timestamp:Qe()}),ne(),_e()):ye("Invalid callback token")}catch(g){return Ee(g)}},async taskProgress(v){try{let g=v.params?.token;if(!g)return ye("taskProgress requires params.token");let L=(v.body??{}).update??{},D=cr(g);return D?(await l({type:"task-progress",taskName:D.taskName,update:L,timestamp:Qe()}),ne(),_e()):ye("Invalid callback token")}catch(g){return Ee(g)}},async sourceDataFetched(v){try{let g=v.params?.token,L=v.params?.ref;if(!g)return ye("sourceDataFetched requires params.token");if(!L)return ye("sourceDataFetched requires params.ref");let D=Pn(g);if(!D)return ye("Invalid source token");let H=await $(),w=D.dt||t.genId();D.dt||await H.ingestSourceDataStaged(D.cid,D.d,at(L),w);let b=cr(D.cbk);return b?(await l({type:"task-progress",taskName:b.taskName,update:{bindTo:D.b,outputFile:D.d,fetchedAt:Qe(),deliveryToken:w,sourceChecksum:D.cs,rqt:D.rqt},timestamp:Qe()}),ne(),_e()):ye("Invalid callback token embedded in source token")}catch(g){return Ee(g)}},async sourceDataFetchFailure(v){try{let g=v.params?.token,L=v.params?.reason??"unknown";if(!g)return ye("sourceDataFetchFailure requires params.token");let D=Pn(g);if(!D)return ye("Invalid source token");let H=cr(D.cbk);return H?(await l({type:"task-progress",taskName:H.taskName,update:{bindTo:D.b,outputFile:D.d,failure:!0,reason:L,sourceChecksum:D.cs,rqt:D.rqt},timestamp:Qe()}),ne(),_e()):ye("Invalid callback token embedded in source token")}catch(g){return Ee(g)}}}}function Ir(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function Go(e){return {...Ir(e),leaseToken:e.leaseToken,leaseExpiresAt:e.leaseExpiresAt}}function Wo(e){return {...Ir(e),reason:e.reason}}function Tr(e){return {enqueueRequest(t){return e.enqueue(t).id},enqueueRequestIfAbsent:e.enqueueIfAbsent?(t,r)=>{let n=e.enqueueIfAbsent(t,r);return n?n.id:null}:void 0,leaseRequests(t){return e.lease(t).map(Go)},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,n){return e.nack(t,r,n)},peekActive(){return e.peekActive().map(Ir)},peekDeadLetter(){return e.peekDeadLetter().map(Wo)}}}function Fn(){return new Date().toISOString()}function Bn(e){return new TextEncoder().encode(e).byteLength}function Qo(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function On(e){function t(r){let n=e.stat?Qo(e.stat(r)):null;if(n)return n;if(!e.exists(r))return null;let o=e.read(r);return o===null?{key:r}:{key:r,size:Bn(o)}}return {exists(r){return e.exists(r)},putText(r,n,o="text/plain; charset=utf-8"){e.write(r,n);let s=t(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??Fn(),s.size=s.size??Bn(n),s},putBytes(r,n,o="application/octet-stream"){if(e.writeBytes)e.writeBytes(r,n);else {let i=JSON.stringify({__kind:"bytes-array",data:[...n]});e.write(r,i);}let s=t(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??Fn(),s.size=s.size??n.byteLength,s},getText(r){let n=e.read(r);if(n===null){if(!e.readBytes)return null;let o=e.readBytes(r);return o===null?null:Buffer.from(o).toString("utf-8")}try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new TextDecoder("utf-8").decode(new Uint8Array(o.data))}catch{}return n},getBytes(r){if(e.readBytes){let o=e.readBytes(r);if(o!==null)return o}let n=e.read(r);if(n===null)return null;try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new Uint8Array(o.data)}catch{}return new TextEncoder().encode(n)},head:t,list(r=""){return e.listKeys(r).map(n=>t(n)??{key:n}).sort((n,o)=>n.key.localeCompare(o.key))},remove(r){e.remove(r);}}}function qn(){function e(o,s){if(!Array.isArray(o))return [];let i=[];for(let u of o){if(!u||typeof u!="object")continue;let p=u;typeof p.stored_name=="string"&&i.push({name:typeof p.name=="string"?p.name:p.stored_name,stored_name:p.stored_name,size:typeof p.size=="number"&&Number.isFinite(p.size)?p.size:null,mime_type:typeof p.mime_type=="string"?p.mime_type:null,uploaded_at:typeof p.uploaded_at=="string"?p.uploaded_at:s||null,chat:p.chat===true});}return i}function t(o){return !o||typeof o!="object"?[]:e(o.files,void 0)}function r(o,s){let i=t(o);if(s.length===0)return o.files=i,i;let u=new Set(i.map(p=>p.stored_name));for(let p of s)u.has(p.stored_name)||(i.push(p),u.add(p.stored_name));return o.files=i,i}function n(o,s,i){let u=t(o);if(!Number.isInteger(s)||s<0||s>=u.length)return {ok:false,reason:"index_out_of_range"};let p=u[s];return !p||!p.stored_name?{ok:false,reason:"missing_stored_name"}:i&&i!==p.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:p}}return {read:t,normalizeIncoming:e,merge:r,resolve:n}}function jn(e){function t(y){let C=typeof y=="number"?y:Number(y);return Number.isInteger(C)&&C>0?C:null}function r(y,C){let S=C;for(let R=y.length-1;R>=0;R-=1)if(y[R]?.role==="user"&&(S-=1,S===0))return y.slice(R);return y}function n(y){return y.some(C=>typeof C?.turn=="string"&&C.turn!=="")}function o(y,C){if(C<=0)return [];if(!n(y))return r(y,C);let S=new Map,R=[];for(let x of y){let A=typeof x?.turn=="string"?x.turn:"";S.has(A)||(S.set(A,[]),R.push(A)),S.get(A).push(x);}return R.slice(Math.max(0,R.length-C)).flatMap(x=>S.get(x)??[])}function s(y){return {status:"success",data:y}}function i(y){return {status:"fail",error:y}}function u(y){return {status:"error",error:y instanceof Error?y.message:String(y)}}async function p(y,C="command envelope"){let S=typeof y.cardId=="string"?y.cardId:void 0;if(!y.command)return i(`chat-store: ${C} missing "command"`);if(!S)return i(`chat-store: ${C} missing "cardId"`);if(y.command==="append")return await E.append({params:{cardId:S},body:{role:y.role,text:y.text,files:y.files,turn:y.turn}});if(y.command==="read-all")return await E.readAll({params:{cardId:S},body:{lastUserTurns:y.lastUserTurns,tailTurns:y.tailTurns,turnId:y.turnId,allTurns:y.allTurns,tailTurnsBeforeId:y.tailTurnsBeforeId}});if(y.command==="read-after")return await E.readAfter({params:{cardId:S},body:{cursor:y.cursor??null}});if(y.command==="clear")return await E.clear({params:{cardId:S}});if(y.command==="set-processing")return await E.setProcessing({params:{cardId:S},body:{active:y.active}});if(y.command==="is-processing")return await E.isProcessing({params:{cardId:S}});if(y.command==="get-config")return await E.getConfig({params:{cardId:S}});if(y.command==="set-config"){let{command:R,cardId:I,...x}=y;return await E.setConfig({params:{cardId:S},body:x})}return i(`chat-store: unknown command "${String(y.command)}"`)}async function T(y){if(!Array.isArray(y.commands)||y.commands.length===0)return i('chat-store: command envelope must include a non-empty "commands" array');let C=[];for(let S=0;S<y.commands.length;S+=1){let R=y.commands[S];if(!R||typeof R!="object"||Array.isArray(R))return i(`chat-store: command envelope entry ${S} must be an object`);let I={cardId:y.cardId,...R},x=await p(I,`command envelope entry ${S}`);if(x.status!=="success")return x;C.push({index:S,command:String(I.command),data:x.data});}return s({results:C})}let E={async append(y){try{let C=y.params?.cardId;if(!C)return i("append requires params.cardId");let S=y.body??{},R=typeof S.role=="string"?S.role:"",I=typeof S.text=="string"?S.text:"",x=Array.isArray(S.files)?S.files:[],A=typeof S.turn=="string"?S.turn:"";if(!R)return i("append requires body.role");let F=await e.append(C,R,I,x,A);return s({id:F})}catch(C){return u(C)}},async readAll(y){try{let C=y.params?.cardId;if(!C)return i("readAll requires params.cardId");let S=y.body??{},R=typeof S.turnId=="string"?S.turnId:"",I=S.allTurns===!0,x=typeof S.tailTurnsBeforeId=="string"?S.tailTurnsBeforeId:"",A=S.tailTurns===void 0?S.lastUserTurns:S.tailTurns,F=A===void 0?I||R?void 0:1:t(A);if(A!==void 0&&F===null)return i("readAll requires body.tailTurns (positive integer)");let c=await e.readAll(C),h=c.filter(d=>!R||String(d.turn||"")===R);if(x){let d=F;if(typeof d!="number"||!Number.isInteger(d)||d<=0)return i("readAll requires body.tailTurns (positive integer) when body.tailTurnsBeforeId is provided");let f=new Map,l=[];for(let J of c){let W=String(J.turn||"");f.has(W)||(f.set(W,[]),l.push(W)),f.get(W).push(J);}let k=l.findIndex(J=>J===x),_=Math.max(0,k-d);return h=(k===-1?[]:l.slice(_,k)).flatMap(J=>f.get(J)??[]),s({records:h})}return s(typeof F=="number"?{records:o(h,F)}:{records:h})}catch(C){return u(C)}},async readAfter(y){try{let C=y.params?.cardId;if(!C)return i("readAfter requires params.cardId");let R=(y.body??{}).cursor??null;return s(await e.readAfter(C,R))}catch(C){return u(C)}},async clear(y){try{let C=y.params?.cardId;return C?(await e.clear(C),s({ok:!0})):i("clear requires params.cardId")}catch(C){return u(C)}},async setProcessing(y){try{let C=y.params?.cardId;if(!C)return i("setProcessing requires params.cardId");let S=y.body??{};return typeof S.active!="boolean"?i("setProcessing requires body.active (boolean)"):(await e.setProcessing(C,S.active),s({ok:!0}))}catch(C){return u(C)}},async isProcessing(y){try{let C=y.params?.cardId;return C?s({active:await e.isProcessing(C)}):i("isProcessing requires params.cardId")}catch(C){return u(C)}},async getConfig(y){try{let C=y.params?.cardId;return C?s({config:await e.getConfig(C)}):i("getConfig requires params.cardId")}catch(C){return u(C)}},async setConfig(y){try{let C=y.params?.cardId;if(!C)return i("setConfig requires params.cardId");let S=y.body??{};return await e.setConfig(C,S),s({ok:!0})}catch(C){return u(C)}},run:p,runBatch:T};return E}function Ln(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Pr(e){if(!e||typeof e!="object")return false;let t=e.summary;return !t||typeof t!="object"?false:Number(t.card_count||0)>0}function _r(e,t){if(!t||typeof t!="object")return;let r=t;if(r.kind==="notification-batch"&&Array.isArray(r.notifications)){for(let n of r.notifications)_r(e,n);return}r.kind==="status"&&Pr(r.status)&&(e.status=r.status),r.kind==="computed_values"&&r.cardId&&(e.computedValues[r.cardId]=r.values),r.kind==="data_object"&&r.key&&(e.dataObjects[r.key]=r.payload),r.kind==="card_refreshed"&&r.cardId&&(e.cards[r.cardId]=r.card),r.kind==="card_removed"&&r.cardId&&(delete e.cards[r.cardId],delete e.computedValues[r.cardId]);}function Mn(e){let t=new Map,r=new Map,n=new Map,o=0,s=null;function i(d){let f=JSON.stringify(d);return o++,`id: ${o}
1
+ var ServerRuntimeControlface=(function(exports){'use strict';var ao=Object.defineProperty;var io=(e,t,r)=>t in e?ao(e,t,{enumerable:true,configurable:true,writable:true,value:r}):e[t]=r;var Nr=(e,t,r)=>io(e,t+"",r);var Lt="b64:";function uo(e){let t=new TextEncoder().encode(e),r=globalThis.Buffer,n;if(r)n=r.from(t).toString("base64");else if(typeof btoa=="function"){let o="";for(let s of t)o+=String.fromCharCode(s);n=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return n.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function co(e){let t=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),r=globalThis.Buffer;if(r)return r.from(t,"base64").toString("utf8");if(typeof atob=="function"){let n=atob(t),o=new Uint8Array(n.length);for(let s=0;s<n.length;s+=1)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function ke(e){return `${Lt}${uo(JSON.stringify(e))}`}function at(e){if(!e.startsWith(Lt))throw new Error(`Invalid ref format (expected ${Lt}<base64url(json)>): ${e}`);let t;try{t=JSON.parse(co(e.slice(Lt.length)));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${e}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${e}`);let r=t;if(typeof r.kind!="string"||typeof r.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${e}`);return {kind:r.kind,value:r.value}}async function $r(e,t,r){let n=e.tryAcquire();if(!n)return false;try{await t();}finally{n();}return r?.(),true}function ot(e){return typeof e.journalStorage=="function"}function Ur(e){return typeof e.whatToRun=="string"?e.whatToRun.startsWith("b64:")?at(e.whatToRun).value:e.whatToRun:e.whatToRun.value}function st(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function mr(e){let t=e.reduce((o,s)=>o+s.length,0),r=new Uint8Array(t),n=0;for(let o of e)r.set(o,n),n+=o.length;return r}function ue(e,...t){for(let r of t)if(typeof e[r]=="string")return String(e[r]);return ""}function it(e,...t){for(let r of t)if(e[r]!==void 0)return Number(e[r])}function ut(e,...t){for(let r of t){let n=e[r];if(n&&typeof n=="object"&&!Array.isArray(n))return n}return {}}function ft(e,t,...r){for(let n of r){let o=e[n];if(o&&typeof o=="object"&&!Array.isArray(o))return o}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function Mt(e,t,...r){for(let n of r){let o=e[n];if(o!==void 0){let s=Number(o);if(Number.isFinite(s))return s}}throw Object.assign(new Error(`MCP tool requires ${t}`),{statusCode:400})}function Vr(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(t=>Math.max(0,Math.min(255,Number(t)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let t=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r);return Uint8Array.from(n,o=>o.charCodeAt(0))}return null}async function pt(e,t,r){let n=r[e];if(!n)throw Object.assign(new Error(`Unknown MCP tool: ${e}`),{statusCode:400});let o=await n(t);if(o&&typeof o=="object"&&!Array.isArray(o)){let s=o,i=s.status;if(i==="success")return Object.prototype.hasOwnProperty.call(s,"data")?o:{status:"success",data:{}};if(i==="fail"||i==="error")return o}return {status:"success",data:o}}function rt(e,t){if(!e||typeof e!="object"||Array.isArray(e))return t;let r=e;if(typeof r.error=="string"&&r.error.trim())return r.error;if(r.step==="validate"){let n=r.validation;if(n&&typeof n=="object"&&!Array.isArray(n)){let s=n.data;if(s&&typeof s=="object"&&!Array.isArray(s)){let i=s.issues;if(Array.isArray(i)){let p=i.find(T=>typeof T=="string"&&T.trim());if(typeof p=="string")return `Validation failed: ${p}`}let u=s.errors;if(Array.isArray(u)&&u.length>0)return "Validation failed"}}return "Validation failed"}return t}function gr(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,bootstrapBoard:s,buildPublishedRuntimePayload:i,createMcpControlplaneToolRegistry:u,retriggerCard:p,applyCardAction:T,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:y}=e;async function C(S,R,I){let x=S.method||"GET",A=I,F=A.pathname;try{if(x==="POST"&&F===`${t}/mcp-actions`){await s();let f=Date.now(),l=new Date(f).toISOString(),k=await n(S),_=typeof k.tool=="string"?k.tool.trim():"",$=k.args&&typeof k.args=="object"&&!Array.isArray(k.args)?k.args:{};if(!_)return r(R,400,{error:"tool is required"}),!0;let J=ue($,"card_id");if(!J)return r(R,400,{error:"MCP action requires card_id"}),!0;if(_==="retrigger-card"||_==="retrigger"){await p(J);let ie=Date.now();return r(R,200,{status:"success",data:{ok:!0,cardId:J,actionType:_,requestReceivedAt:l,requestReceivedAtMs:f,responseSentAt:new Date(ie).toISOString(),responseSentAtMs:ie,responseStatus:200}}),!0}let W=ut($,"payload");if(_==="chat-send"&&!await E(J)){let ie=Date.now();return r(R,409,{error:`chat handler is not configured for card: ${J}`,requestReceivedAt:l,requestReceivedAtMs:f,responseSentAt:new Date(ie).toISOString(),responseSentAtMs:ie,responseStatus:409}),!0}if(_==="chat-send"){let ie=typeof W["turn-id"]=="string"?W["turn-id"]:typeof W.turnId=="string"?W.turnId:typeof W.turn=="string"?W.turn:"";if(!ie||!String(ie).trim()){let X=Date.now();return r(R,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${J}`,requestReceivedAt:l,requestReceivedAtMs:f,responseSentAt:new Date(X).toISOString(),responseSentAtMs:X,responseStatus:400}),!0}}await T(J,_,W);let te=Date.now();return r(R,200,{status:"success",data:{ok:!0,cardId:J,actionType:_,requestReceivedAt:l,requestReceivedAtMs:f,responseSentAt:new Date(te).toISOString(),responseSentAtMs:te,responseStatus:200}}),!0}if(x==="POST"&&F===`${t}/mcp-controlplane`){await s();let f=await n(S),l=typeof f.tool=="string"?f.tool.trim():"",k=f.args&&typeof f.args=="object"&&!Array.isArray(f.args)?f.args:{};if(!l)return r(R,400,{error:"tool is required"}),!0;try{let _=await pt(l,k,u());if(_&&typeof _=="object"&&!Array.isArray(_)){let $=_;if($.status==="fail")return r(R,400,{error:rt(_,"Request failed")}),!0;if($.status==="error")return r(R,500,{error:rt(_,"Internal error")}),!0}r(R,200,_);}catch(_){let $=typeof _?.statusCode=="number"?Number(_.statusCode):500,J=_ instanceof Error?_.message:String(_);r(R,$,{error:J});}return !0}let c=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/retrigger$`));if(x==="POST"&&c){await s();let f=decodeURIComponent(c[1]);return await p(f),r(R,200,{ok:!0}),!0}let h=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/actions$`));if(x==="POST"&&h){await s();let f=decodeURIComponent(h[1]),l=Date.now(),k=new Date(l).toISOString(),_=await n(S),$=_?.actionType;if($==="chat-send"&&!await E(f)){let W=Date.now();return r(R,409,{error:`chat handler is not configured for card: ${f}`,requestReceivedAt:k,requestReceivedAtMs:l,responseSentAt:new Date(W).toISOString(),responseSentAtMs:W,responseStatus:409}),!0}if($==="chat-send"){let W=_?.payload??{},te=typeof W["turn-id"]=="string"?W["turn-id"]:typeof W.turnId=="string"?W.turnId:typeof W.turn=="string"?W.turn:"";if(!te||!String(te).trim()){let ie=Date.now();return r(R,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${f}`,requestReceivedAt:k,requestReceivedAtMs:l,responseSentAt:new Date(ie).toISOString(),responseSentAtMs:ie,responseStatus:400}),!0}}await T(f,$,_?.payload);let J=Date.now();return r(R,200,{ok:!0,requestReceivedAt:k,requestReceivedAtMs:l,responseSentAt:new Date(J).toISOString(),responseSentAtMs:J,responseStatus:200}),!0}let d=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/files/(\\d+)$`));if(x==="GET"&&d){let f=decodeURIComponent(d[1]),l=parseInt(d[2],10),k=A.searchParams.get("sn");return await y(R,f,l,k),!0}return !1}catch(c){let h=c?.statusCode||500;return r(R,h,{error:String(c?.message||c)}),true}}return {handleRuntimeApi:C}}function Dt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.callbackTransport is required`);if(typeof e.createCallback!="function")throw new Error(`${t}: adapter.callbackTransport.createCallback is required`)}var mt={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function Ye(e){return e?Array.isArray(e.provides)?e.provides:[]:[]}function gt(e){return e?Array.isArray(e.requires)?e.requires:[]:[]}function Kr(e){return e.tasks??{}}function yr(e){return e?e.status===mt.FAILED||e.status===mt.INACTIVATED:false}function Hr(e,t){return e.refreshStrategy??t?.refreshStrategy??"data-changed"}function Jr(e){return e.maxExecutions}function Gr(e,t){let r=new Set;for(let[n,o]of Object.entries(t))if(o.status===mt.COMPLETED){let s=e.tasks[n];s&&Ye(s).forEach(u=>r.add(u));}return Array.from(r)}function Wr(e,t){let r={};return e.forEach(n=>{let o=t[n];if(!o)return;Ye(o).forEach(i=>{r[i]||(r[i]=[]),r[i].push(n);});}),r}function Qr(e,t,r){let n=e.tasks[t]??Nt(),o={};if(r){let i=r.tasks[t],u=gt(i);for(let p of u)for(let[T,E]of Object.entries(r.tasks))if(Ye(E).includes(p)){let y=e.tasks[T];y?.lastDataHash&&(o[p]=y.lastDataHash);break}}let s={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:o};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function zr(e,t,r,n,o,s){let i=e.tasks[r]??Nt(),u=t.tasks[r];if(!u)throw new Error(`Task "${r}" not found in graph`);let p;n&&u.on&&u.on[n]?p=u.on[n]:p=Ye(u);let T=i.startConsumedHashes?{...i.startConsumedHashes}:{...i.lastConsumedHashes};if(!i.startConsumedHashes){let C=u.requires??[];for(let S of C)for(let[R,I]of Object.entries(t.tasks))if(Ye(I).includes(S)){let x=e.tasks[R];x?.lastDataHash&&(T[S]=x.lastDataHash);break}}let E={...i,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:i.executionCount+1,lastEpoch:i.executionCount+1,lastDataHash:o,data:s,lastConsumedHashes:T,error:void 0},y=[...new Set([...e.availableOutputs,...p])];return {...e,tasks:{...e.tasks,[r]:E},availableOutputs:y,lastUpdated:new Date().toISOString()}}function Yr(e,t,r,n){let o=e.tasks[r]??Nt(),s=t.tasks[r];if(s?.retry){let p=o.retryCount+1;if(p<=s.retry.max_attempts){let T={...o,status:"not-started",retryCount:p,lastUpdated:new Date().toISOString(),error:n};return {...e,tasks:{...e.tasks,[r]:T},lastUpdated:new Date().toISOString()}}}let i={...o,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:o.executionCount+1},u=e.availableOutputs;if(s?.on_failure&&s.on_failure.length>0&&(u=[...new Set([...e.availableOutputs,...s.on_failure])]),s?.circuit_breaker&&i.executionCount>=s.circuit_breaker.max_executions){let p=s.circuit_breaker.on_break;u=[...new Set([...u,...p])];}return {...e,tasks:{...e.tasks,[r]:i},availableOutputs:u,lastUpdated:new Date().toISOString()}}function Xr(e,t,r,n){let o=e.tasks[t]??Nt(),s={...o,progress:typeof n=="number"?n:o.progress,messages:[...o.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:o.status}]:[]],lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function Zr(e,t){let r=e.tasks[t];if(!r)return e;let n={...r,status:"not-started",startedAt:void 0,completedAt:void 0,failedAt:void 0,error:void 0,data:void 0,progress:null,lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:n},lastUpdated:new Date().toISOString()}}function Nt(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function St(e,t){let r=`live-${Date.now()}`,n={};for(let s of Object.keys(e.tasks))n[s]=tn();let o={status:"running",tasks:n,availableOutputs:[],stuckDetection:{is_stuck:false,stuck_description:null,outputs_unresolvable:[],tasks_blocked:[]},lastUpdated:new Date().toISOString(),executionId:r,executionConfig:{executionMode:e.settings.execution_mode??"eligibility-mode",conflictStrategy:e.settings.conflict_strategy??"alphabetical",completionStrategy:e.settings.completion}};return {config:e,state:o}}function lo(e,t){let{config:r,state:n}=e;if("executionId"in t&&t.executionId&&t.executionId!==n.executionId)return e;switch(t.type){case "task-started":return {config:r,state:Qr(n,t.taskName,r)};case "task-completed":return {config:r,state:zr(n,r,t.taskName,t.result,t.dataHash,t.data)};case "task-failed":return {config:r,state:Yr(n,r,t.taskName,t.error)};case "task-progress":return {config:r,state:Xr(n,t.taskName,t.message,t.progress)};case "task-restart":return {config:r,state:Zr(n,t.taskName)};case "inject-tokens":return {config:r,state:{...n,availableOutputs:[...new Set([...n.availableOutputs,...t.tokens])],lastUpdated:new Date().toISOString()}};case "agent-action":return {config:r,state:Ro(n,t.action)};case "task-upsert":return fo(e,t.taskName,t.taskConfig);case "task-removal":return po(e,t.taskName);case "node-requires-add":return mo(e,t.nodeName,t.tokens);case "node-requires-remove":return go(e,t.nodeName,t.tokens);case "node-provides-add":return yo(e,t.nodeName,t.tokens);case "node-provides-remove":return ho(e,t.nodeName,t.tokens);default:return e}}function en(e,t){return t.reduce((r,n)=>lo(r,n),e)}function fo(e,t,r){let n=!!e.config.tasks[t];return {config:{...e.config,tasks:{...e.config.tasks,[t]:r}},state:{...e.state,tasks:{...e.state.tasks,[t]:n?e.state.tasks[t]:tn()},lastUpdated:new Date().toISOString()}}}function po(e,t){if(!e.config.tasks[t])return e;let{[t]:r,...n}=e.config.tasks,{[t]:o,...s}=e.state.tasks;return {config:{...e.config,tasks:n},state:{...e.state,tasks:s,lastUpdated:new Date().toISOString()}}}function mo(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=gt(n),s=r.filter(i=>!o.includes(i));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:[...o,...s]}}},state:e.state}}function go(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=gt(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:s}}},state:e.state}}function yo(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=Ye(n),s=r.filter(i=>!o.includes(i));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:[...o,...s]}}},state:e.state}}function ho(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=Ye(n),s=o.filter(i=>!r.includes(i));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:s}}},state:e.state}}function yt(e){return {version:1,config:e.config,state:e.state,snapshotAt:new Date().toISOString()}}function ht(e){if(!e||typeof e!="object")throw new Error("Invalid snapshot: expected an object");let t=e;if(!t.config||typeof t.config!="object")throw new Error('Invalid snapshot: missing or invalid "config"');if(!t.state||typeof t.state!="object")throw new Error('Invalid snapshot: missing or invalid "state"');let r=t.config,n=t.state;if(!r.settings||typeof r.settings!="object")throw new Error("Invalid snapshot: config.settings missing");if(!r.tasks||typeof r.tasks!="object")throw new Error("Invalid snapshot: config.tasks missing");if(!n.tasks||typeof n.tasks!="object")throw new Error("Invalid snapshot: state.tasks missing");if(!Array.isArray(n.availableOutputs))throw new Error("Invalid snapshot: state.availableOutputs must be an array");return {config:r,state:n}}function tn(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Ro(e,t){let r=new Date().toISOString();switch(t){case "stop":return {...e,status:"stopped",lastUpdated:r};case "pause":return {...e,status:"paused",lastUpdated:r};case "resume":return {...e,status:"running",lastUpdated:r};default:return e}}function xt(e){let{config:t,state:r}=e,n=Kr(t);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let s=ko(n),i=Gr(t,r.tasks),u=new Set([...i,...r.availableOutputs]),p=[],T=[],E=[],y=[];for(let[S,R]of Object.entries(n)){let I=r.tasks[S],x=Hr(R,t.settings),A=x!=="once";if(I?.status===mt.RUNNING||yr(I))continue;let F=Jr(R);if(F!==void 0&&I&&I.executionCount>=F||R.circuit_breaker&&I&&I.executionCount>=R.circuit_breaker.max_executions||!A&&I?.status===mt.COMPLETED)continue;if(A&&I?.status===mt.COMPLETED){let l=gt(R),k=false;switch(x){case "data-changed":{l.length>0&&l.some($=>{for(let[J,W]of Object.entries(n))if(Ye(W).includes($)){let te=r.tasks[J];if(!te)continue;let ie=I.lastConsumedHashes?.[$];return te.lastDataHash==null?te.executionCount>I.lastEpoch:te.lastDataHash!==ie}return false})||(k=true);break}case "epoch-changed":{l.length>0&&l.some($=>{for(let[J,W]of Object.entries(n))if(Ye(W).includes($)){let te=r.tasks[J];if(te&&te.executionCount>I.lastEpoch)return true}return false})||(k=true);break}case "time-based":{let _=R.refreshInterval??0;if(_<=0){k=true;break}let $=I.completedAt;if(!$){k=true;break}(Date.now()-Date.parse($))/1e3<_&&(k=true);break}case "manual":k=true;break}if(k)continue}let c=gt(R);if(c.length===0){p.push(S);continue}let h=[],d=[],f=[];for(let l of c){if(u.has(l))continue;let k=s[l]||[];k.length===0?h.push(l):k.every($=>yr(r.tasks[$]))?f.push({token:l,failedProducer:k[0]}):d.push(l);}h.length>0?E.push({taskName:S,missingTokens:h}):f.length>0?y.push({taskName:S,failedTokens:f.map(l=>l.token),failedProducers:[...new Set(f.map(l=>l.failedProducer))]}):d.length>0?T.push({taskName:S,waitingOn:d}):p.push(S);}let C={};if(p.length>1){let S=Wr(p,n);for(let[R,I]of Object.entries(S))I.length>1&&(C[R]=I);}return {eligible:p,pending:T,unresolved:E,blocked:y,conflicts:C}}function ko(e){let t={};for(let[r,n]of Object.entries(e)){for(let o of Ye(n))t[o]||(t[o]=[]),t[o].push(r);if(n.on)for(let o of Object.values(n.on))for(let s of o)t[s]||(t[s]=[]),t[s].includes(r)||t[s].push(r);if(n.on_failure)for(let o of n.on_failure)t[o]||(t[o]=[]),t[o].includes(r)||t[o].push(r);}return t}var It=class{constructor(){Nr(this,"buffer",[]);}append(t){this.buffer.push(t);}drain(){let t=this.buffer;return this.buffer=[],t}get size(){return this.buffer.length}};function hr(e){let t=Rr(e);return Co(t)}function Rr(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return "["+e.map(Rr).join(",")+"]";let t=e;return "{"+Object.keys(t).sort().map(n=>JSON.stringify(n)+":"+Rr(t[n])).join(",")+"}"}function Co(e){let t=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let o=0;o<e.length;o++)t^=BigInt(e.charCodeAt(o)),t=t*r&n;return t.toString(16).padStart(16,"0")}function wo(e){if(typeof Buffer<"u")return Buffer.from(e,"utf8").toString("base64url");if(typeof btoa=="function"){let t=new TextEncoder().encode(e),r="";for(let n of t)r+=String.fromCharCode(n);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}throw new Error("No base64 encoder available in this runtime")}function So(e){if(typeof Buffer<"u")return Buffer.from(e,"base64url").toString("utf8");if(typeof atob=="function"){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=new Uint8Array(n.length);for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function rn(e){let t=JSON.stringify({t:e,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return wo(t)}function bo(e){try{let t=JSON.parse(So(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function $t(e,t,r){let{handlers:n,onNodeRemoved:o,onDrain:s}=t,i=new It,u="state"in e&&"config"in e?e:St(e),p=false,T=new Set,E=new Map(Object.entries(n)),y=new It,C=false,S=false;function R(){if(!p){if(C){S=true;return}C=true;try{do S=!1,I();while(S)}finally{C=false;}}}function I(){let c=y.drain(),h=i.drain(),d=[...c,...h];if(d.length>0&&(u=en(u,d),o)){for(let l of d)if(l.type==="task-removal")try{o(l.taskName);}catch(k){console.warn("[reactive] onNodeRemoved failed:",k instanceof Error?k.message:String(k));}}let f=xt(u);d.length>0&&s?.(d,u,f);for(let l of f.eligible)F(l);for(let l of d)if(l.type==="task-progress"){let{taskName:k,update:_}=l;if(!u.config.tasks[k])continue;let J=u.state.tasks[k];if(!J||J.status!=="running")continue;let W=rn(k),te=A(k,W,_).catch(ie=>{p||(y.append({type:"task-failed",taskName:k,error:ie.message??String(ie),timestamp:new Date().toISOString()}),R());}).finally(()=>{T.delete(te);});T.add(te);}}function x(c){let d=u.config.tasks[c].requires??[],f=new Map;for(let[k,_]of Object.entries(u.config.tasks))for(let $ of _.provides??[])f.set($,k);let l={};for(let k of d){let _=f.get(k);_?l[k]=u.state.tasks[_]?.data:l[k]=void 0;}return l}async function A(c,h,d){let f=u.config.tasks[c],l=f.taskHandlers??[],k=x(c);for(let _ of l){let $=E.get(_);if(!$)throw new Error(`Handler '${_}' not found in registry (task '${c}')`);let J={nodeId:c,state:k,taskState:u.state.tasks[c],config:f,callbackToken:h,update:d};if(await $(J)==="task-initiate-failure")throw new Error(`Handler '${_}' returned task-initiate-failure (task '${c}')`)}}function F(c){let d=u.config.tasks[c]?.taskHandlers;if(!d||d.length===0)return;y.append({type:"task-started",taskName:c,timestamp:new Date().toISOString()}),R();let f=rn(c),l=A(c,f).catch(k=>{p||(y.append({type:"task-failed",taskName:c,error:k.message??String(k),timestamp:new Date().toISOString()}),R());}).finally(()=>{T.delete(l);});T.add(l);}return {push(c){p||(c.type==="task-completed"&&c.data&&!c.dataHash&&(c={...c,dataHash:hr(c.data)}),i.append(c),R());},pushAll(c){if(!p){for(let h of c)h.type==="task-completed"&&h.data&&!h.dataHash?i.append({...h,dataHash:hr(h.data)}):i.append(h);R();}},resolveCallback(c,h,d){if(p)return;let f=bo(c);if(!f)return;let{taskName:l}=f;if(u.config.tasks[l]){if(d&&d.length>0)i.append({type:"task-failed",taskName:l,error:d.join("; "),timestamp:new Date().toISOString()});else {let k=h&&Object.keys(h).length>0?hr(h):void 0;i.append({type:"task-completed",taskName:l,data:h,dataHash:k,timestamp:new Date().toISOString()});}R();}},addNode(c,h){p||(i.append({type:"task-upsert",taskName:c,taskConfig:h,timestamp:new Date().toISOString()}),R());},removeNode(c){p||(i.append({type:"task-removal",taskName:c,timestamp:new Date().toISOString()}),R());},addRequires(c,h){p||(i.append({type:"node-requires-add",nodeName:c,tokens:h,timestamp:new Date().toISOString()}),R());},removeRequires(c,h){p||(i.append({type:"node-requires-remove",nodeName:c,tokens:h,timestamp:new Date().toISOString()}),R());},addProvides(c,h){p||(i.append({type:"node-provides-add",nodeName:c,tokens:h,timestamp:new Date().toISOString()}),R());},removeProvides(c,h){p||(i.append({type:"node-provides-remove",nodeName:c,tokens:h,timestamp:new Date().toISOString()}),R());},registerHandler(c,h){E.set(c,h);},unregisterHandler(c){E.delete(c);},retrigger(c){p||u.config.tasks[c]&&(i.append({type:"task-restart",taskName:c,timestamp:new Date().toISOString()}),R());},retriggerAll(c){if(!p){for(let h of c)u.config.tasks[h]&&i.append({type:"task-restart",taskName:h,timestamp:new Date().toISOString()});R();}},snapshot(){return yt(u)},getState(){return u},getSchedule(){return xt(u)},async waitForHandlers(){T.size>0&&await Promise.allSettled([...T]);},async dispose(c){c?.wait&&T.size>0&&await Promise.allSettled([...T]),p=true;}}}function Ut(){return function(e){if(e==="./jsonata-sync.cjs")return typeof globalThis<"u"&&globalThis.__jsonataSync||typeof globalThis<"u"&&globalThis.jsonataSync;throw new Error("Unsupported require in browser bundle: "+e)}}var vo=Ut();vo("./jsonata-sync.cjs");var Ao=Ut(),Vt=Ao("./jsonata-sync.cjs"),sn=Vt;function nn(e,t){if(!t||!e)return;let r=t.split("."),n=e;for(let o=0;o<r.length;o++){if(n==null)return;n=n[r[o]];}return n}function an(e,t,r){let n=t.split("."),o=e;for(let s=0;s<n.length-1;s++)(o[n[s]]==null||typeof o[n[s]]!="object")&&(o[n[s]]={}),o=o[n[s]];o[n[n.length-1]]=r;}async function xo(e,t){if(!e?.compute?.length)return e;e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values};for(let o of e.compute)try{let s=await Vt(o.expr).evaluate(n);an(e.computed_values,o.bindTo,s),n.computed_values=e.computed_values;}catch{}return e}function Io(e,t){if(!e?.compute?.length)return {ok:true,node:e};e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values},o=[];for(let s of e.compute)try{let i=sn(s.expr).evaluate(n);an(e.computed_values,s.bindTo,i),n.computed_values=e.computed_values;}catch(i){let u=i instanceof Error?i.message:String(i);o.push({bindTo:s.bindTo,error:u});}return o.length>0?{ok:true,node:e,errors:o}:{ok:true,node:e}}async function To(e,t,r){let n={...r??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return Vt(e).evaluate(n)}function Po(e,t){return t.startsWith("fetched_sources.")?nn(e._sourcesData??{},t.slice(16)):nn(e,t)}var on=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),_o=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function Eo(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:false,errors:["Node must be a non-null object"]};let r=e;(typeof r.id!="string"||!r.id)&&t.push("id: required, must be a non-empty string");for(let n of Object.keys(r))_o.has(n)||t.push(`Unknown top-level key: "${n}"`);if((r.card_data==null||typeof r.card_data!="object"||Array.isArray(r.card_data))&&t.push("card_data: required, must be an object"),r.meta!=null)if(typeof r.meta!="object"||Array.isArray(r.meta))t.push("meta: must be an object");else {let n=r.meta;n.title!=null&&typeof n.title!="string"&&t.push("meta.title: must be a string"),n.tags!=null&&!Array.isArray(n.tags)&&t.push("meta.tags: must be an array");}if(r.requires!=null&&!Array.isArray(r.requires)&&t.push("requires: must be an array of strings"),r.provides!=null&&(Array.isArray(r.provides)?r.provides.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`provides[${o}]: must be an object with bindTo and ref`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`provides[${o}]: missing required "bindTo" string`),(typeof s.ref!="string"||!s.ref)&&t.push(`provides[${o}]: missing required "ref" string`);}}):t.push("provides: must be an array of { bindTo, ref } bindings")),r.compute!=null&&(Array.isArray(r.compute)?r.compute.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`compute[${o}]: must be a compute step object`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`compute[${o}]: missing required "bindTo" property`),(typeof s.expr!="string"||!s.expr)&&t.push(`compute[${o}]: missing required "expr" string (JSONata expression)`);}}):t.push("compute: must be an array of compute steps")),r.source_defs!=null)if(!Array.isArray(r.source_defs))t.push("source_defs: must be an array");else {let n=new Set,o=new Set;r.source_defs.forEach((s,i)=>{if(!s||typeof s!="object"||Array.isArray(s))t.push(`source_defs[${i}]: must be an object`);else {let u=s;typeof u.bindTo!="string"||!u.bindTo?t.push(`source_defs[${i}]: missing required "bindTo" property`):(n.has(u.bindTo)&&t.push(`source_defs[${i}]: bindTo "${u.bindTo}" is not unique across source_defs`),n.add(u.bindTo)),typeof u.outputFile!="string"||!u.outputFile?t.push(`source_defs[${i}]: missing required "outputFile" property`):(o.has(u.outputFile)&&t.push(`source_defs[${i}]: outputFile "${u.outputFile}" is not unique across source_defs`),o.add(u.outputFile)),u.optionalForCompletionGating!=null&&typeof u.optionalForCompletionGating!="boolean"&&t.push(`source_defs[${i}]: optionalForCompletionGating must be a boolean`);}});}if(r.view!=null)if(typeof r.view!="object"||Array.isArray(r.view))t.push("view: must be an object");else {let n=r.view;!Array.isArray(n.elements)||n.elements.length===0?t.push("view.elements: required, must be a non-empty array"):n.elements.forEach((o,s)=>{if(!o||typeof o!="object"){t.push(`view.elements[${s}]: must be an object`);return}!o.kind||typeof o.kind!="string"?t.push(`view.elements[${s}].kind: required, must be a string`):on.has(o.kind)||t.push(`view.elements[${s}].kind: unknown kind "${o.kind}". Valid: ${[...on].join(", ")}`),o.data!=null&&(typeof o.data!="object"||Array.isArray(o.data))&&t.push(`view.elements[${s}].data: must be an object`);}),n.layout!=null&&(typeof n.layout!="object"||Array.isArray(n.layout))&&t.push("view.layout: must be an object"),n.features!=null&&(typeof n.features!="object"||Array.isArray(n.features))&&t.push("view.features: must be an object");}return {ok:t.length===0,errors:t}}async function Fo(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return Promise.all(e.map(async n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=await Vt(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}}))}function Bo(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return e.map(n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,i]of Object.entries(n.projections))if(typeof i=="string"&&i.trim().length>0)try{o[s]=sn(i).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}})}var ze={run:xo,runSync:Io,eval:To,resolve:Po,validate:Eo,enrichSources:Fo,enrichSourcesSync:Bo};function Kt(e){return JSON.stringify(e)}function Ht(e){let t;try{t=JSON.parse(e);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${e}`)}if(typeof t!="object"||t===null||typeof t.howToRun!="string"||typeof t.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${e}`);return t}function Jt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function kr(e,t){return Jt(e)?e.then(t):t(e)}function dn(e,t){let r={...e};for(let n of t.deleteKeys)delete r[n];return {...r,...t.shallowMerge}}function Cr(e,t){return {readValues(n){let o=e(n);return kr(o.listKeys(),s=>{let i=[...s].sort();if(i.length===0)return {version:null,values:{}};let u={},p=null;for(let T of i){let E=o.read(T);Jt(E)?p=(p??Promise.resolve()).then(async()=>{u[T]=await E;}):u[T]=E;}return p?p.then(()=>({version:t(u),values:u})):{version:t(u),values:u}})},writeValues(n,o,s){let i=e(n),u=null;for(let p of s){let T=i.delete(p);Jt(T)&&(u=(u??Promise.resolve()).then(()=>T).then(()=>{}));}for(let[p,T]of Object.entries(o)){let E=i.write(p,T);Jt(E)&&(u=(u??Promise.resolve()).then(()=>E).then(()=>{}));}return u?u.then(()=>t(o)):t(o)}}}function Gt(e,t){return {readSnapshot(r){return e.readValues(r)},commitSnapshot(r,n){if(n.schemaVersion!==t)throw new Error(`Unsupported snapshot schema version: ${n.schemaVersion}`);return kr(e.readValues(r),o=>{if(o.version!==n.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:o.version};let s=dn(o.values,n);return kr(e.writeValues(r,s,n.deleteKeys),i=>({ok:true,newVersion:i}))})}}}function un(e,t){if(!t)return e;let r=e.findIndex(n=>n.id===t);return r===-1?e:e.slice(r+1)}function cn(e){return {readEntriesAfterCursor(t){let r=un(e.readAllEntries(),t);return r.length===0?{events:[],newCursor:t}:{events:r.map(n=>n.event),newCursor:r[r.length-1].id}},pendingCount(t){return un(e.readAllEntries(),t).length},appendEvent(t){e.appendEntry({id:e.generateId(),event:t});}}}function ln(e){return {appendEvent(t){return e.append(t).then(()=>{})},async readEntriesAfterCursor(t){let r=await e.readAfter(t||null);return {events:r.entries.map(n=>n.payload),newCursor:r.newCursor??t}}}}function Wt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function dt(e,t){return Wt(e)?e.then(t):t(e)}function wr(e,t){let r=null;for(let n of e){if(r){r=r.then(()=>t(n)).then(()=>{});continue}let o=t(n);Wt(o)&&(r=Promise.resolve(o).then(()=>{}));}return r??void 0}function Oo(e){if(e==null)return null;let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{return t}}function qo(e,t){let r=e.match(t);return r?r[1]:null}function fn(e,t,r){let n={},o=wr(e,s=>{let i=r(s);if(i)return dt(t(s),u=>{n[i]=u;})});return Wt(o)?o.then(()=>n):n}function Qt(e,t){return {readSourceData(r,n){return dt(e.read(`${r}/${n}`),Oo)},ingestSourceDataStaged(r,n,o,s){return dt(t(o),i=>e.write(`${r}/.staged/${s}/${n}`,i))},commitSourceData(r,n,o){let s=`${r}/.staged/${o}/${n}`,i=`${r}/${n}`;return e.renameKey(s,i)},hasSource(r,n){return e.exists(`${r}/${n}`)},listSources(r){return dt(e.listKeys(`${r}/`),n=>n.filter(o=>!o.includes("/.staged/")).map(o=>o.slice(`${r}/`.length)))}}}function Sr(e,t){let r=(n,o)=>{try{let s=o(n);return Wt(s)?s.catch(i=>t(n,i instanceof Error?i.message:String(i))):void 0}catch(s){try{return t(n,s instanceof Error?s.message:String(s))}catch{return}}};return {appendEntries(n,o){if(!(!n||o.length===0))return dt(e.read(n),s=>e.write(n,[...s??[],...o]))},dispatchEntriesForJournalId(n,o){if(n)return dt(e.read(n),s=>{let i=s;if(!(!i||i.length===0))return dt(wr(i,u=>r(u,o)),()=>e.delete(n))})}}}function br(e,t,r){return {readRuntime(n){return dt(e.read(t(n)),o=>o??r())},writeRuntime(n,o){return e.write(t(n),o)}}}function zt(e){return {writeComputedValues(t,r){return e.write(`cards/${t}/computed_values`,r)},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){return dt(e.listKeys("cards/"),t=>fn(t,r=>e.read(r),r=>qo(r,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(t){return wr(Object.entries(t),([r,n])=>{if(r)return n===void 0?e.delete(`data-objects/${r}`):e.write(`data-objects/${r}`,n)})},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){return dt(e.listKeys("data-objects/"),t=>fn(t,r=>e.read(r),r=>r.slice(13)))},writeStatusSnapshot(t){return e.write("status",t)},readStatusSnapshot(){return e.read("status")}}}function Et(e,t){function r(){return e.readIndex()??{}}function n(o,s,i){let u=String(s||"").split(".").filter(Boolean);if(u.length===0)return i&&typeof i=="object"&&!Array.isArray(i)?i:{value:i};let p={...o},T=p;for(let E=0;E<u.length-1;E++){let y=u[E],C=T[y],S=C&&typeof C=="object"&&!Array.isArray(C)?{...C}:{};T[y]=S,T=S;}return T[u[u.length-1]]=i,p}return {readCard(o){let s=r()[o];return !s||!e.cardExists(s.key)?null:e.readCard(s.key)},readCardKey(o){return r()[o]?.key??null},readAllCards(){let o=[];for(let[s,i]of Object.entries(r())){if(!e.cardExists(i.key))continue;let u=e.readCard(i.key);u?o.push(u):t?.(`[card-store] could not read card "${s}" at key "${i.key}"`);}return o},readChecksumIndex(){let o={};for(let[s,i]of Object.entries(r()))o[s]=i.checksum;return o},changedSince(o){let s=r(),i=[];for(let[u,p]of Object.entries(s))o[u]!==p.checksum&&i.push(u);for(let u of Object.keys(o))s[u]||i.push(u);return i},validateUpsert(o,s){let i=r(),u=i[o],p=Object.entries(i).find(([,T])=>T.key===s);return u&&u.key!==s?{ok:false,error:`Card id "${o}" is already mapped to key "${u.key}", cannot remap to "${s}"`}:p&&p[0]!==o?{ok:false,error:`Key "${s}" is already mapped to card id "${p[0]}", cannot remap to "${o}"`}:{ok:true}},writeCard(o,s,i){let u=r(),p=i??u[o]?.key??e.defaultCardKey(o),T=e.writeCard(p,s);u[o]={key:p,checksum:T,updatedAt:new Date().toISOString()},e.writeIndex(u);},patchCard(o,s,i){let u=r(),p=u[o];if(!p||!e.cardExists(p.key))throw new Error(`card "${o}" not found`);let T=e.readCard(p.key);if(!T||typeof T!="object"||Array.isArray(T))throw new Error(`card "${o}" is not patchable`);let E=n(T,s,i),y=e.writeCard(p.key,E);u[o]={key:p.key,checksum:y,updatedAt:new Date().toISOString()},e.writeIndex(u);},removeCard(o){let s=r(),i=s[o];i&&(e.removeCard(i.key),delete s[o],e.writeIndex(s));},readIndex(){return r()}}}function Yt(e,t){return Qt(e,t)}function pn(e){return cn(e)}var Xt="v1",ct="board/graph",mn="board/lastJournalProcessedId";function gn(e){return `cards/${e}/runtime`}function yn(e){return Gt(e,Xt)}function Zt(e){function t(r){let n=e.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {readTaskExecutorRef(){let r=t("task-executor");if(r?.trim())return Ht(r.trim())},writeTaskExecutorRef(r){e.write("task-executor",Kt(r));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){e.write("chat-handler-flow",r);},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){e.write("board-runtime-store-ref",r);},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){e.write("card-store-ref",r);},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){e.write("outputs-store-ref",r);},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){e.write("queue-store-ref",r);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){e.write("scratch-store-ref",r);},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){e.write("chat-store-ref",r);},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){e.write("artifacts-store-ref",r);},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){e.write("fetched-sources-store-ref",r);}}}function hn(e){return zt(e)}function Tt(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function jo(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function Pt(e,t){return e?.lastRequestedToken?jo(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function vr(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function _t(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function Rt(e,t){let r=t.state.tasks,n=t.config.tasks,o=Object.keys(r),s=xt(t),i={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},u=new Map;for(let R of s.pending)u.set(R.taskName,R.waitingOn);for(let R of s.unresolved)u.set(R.taskName,R.missingTokens);for(let R of s.blocked)u.set(R.taskName,R.failedTokens);let p=new Map;for(let[R,I]of Object.entries(n))for(let x of I.requires??[]){let A=p.get(x)??[];A.push(R),p.set(x,A);}let T=o.sort().map(R=>{let I=r[R],x=n[R]??{requires:[],provides:[]};I.status==="completed"?i.completed+=1:I.status==="failed"?i.failed+=1:I.status==="in-progress"&&(i.in_progress+=1);let A=x.requires??[],F=x.provides??[],c=Object.keys(I.data??{}).sort(),h=A.filter($=>t.state.availableOutputs.includes($)),d=A.filter($=>!t.state.availableOutputs.includes($)),f=u.get(R)??d,l=new Set;for(let $ of F)for(let J of p.get($)??[])J!==R&&l.add(J);let k=I.failedAt,_=I.error?{message:I.error,code:"TASK_FAILED",at:k,source:"task-runtime"}:void 0;return {name:R,status:I.status,error:_,requires:A,requires_satisfied:h,requires_missing:d,provides_declared:F,provides_runtime:c,blocked_by:f,unblocks:Array.from(l).sort(),runtime:{attempt_count:I.executionCount??0,restart_count:I.retryCount??0,in_progress_since:I.status==="in-progress"?I.startedAt??null:null,last_transition_at:I.lastUpdated??null,last_completed_at:I.completedAt??null,last_restarted_at:I.startedAt??null,status_age_ms:I.lastUpdated?0:null}}});i.pending=s.pending.length,i.blocked=s.blocked.length,i.unresolved=s.unresolved.length;let E=T.map(R=>({name:R.name,fanOut:R.unblocks.length})).sort((R,I)=>I.fanOut-R.fanOut||R.name.localeCompare(I.name)),y=E.length>0?E[0]:{name:null,fanOut:0},C=new Set;for(let R of Object.values(n))for(let I of R.requires??[])C.add(I);let S=0;for(let[R,I]of Object.entries(n)){let x=(I.requires??[]).length===0,F=(I.provides??[]).some(c=>(p.get(c)??[]).some(h=>h!==R));x&&!F&&(S+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:o.length,completed:i.completed,eligible:s.eligible.length,pending:i.pending,blocked:i.blocked,unresolved:i.unresolved,failed:i.failed,in_progress:i.in_progress,orphan_cards:S,topology:{edge_count:Array.from(C).length,max_fan_out_card:y.name,max_fan_out:y.fanOut}},cards:T}}function Lo(){return new Date().toISOString()}function Rn(e,t,r,n,o,s,i){return async u=>{let p=[],T=r.cardStore.readCard(u.nodeId);if(!T)return "task-initiate-failure";let E=T.id,y=T.card_data??{},C=T.source_defs??[],S=C.filter(v=>v.optionalForCompletionGating!==true),R=r.cardRuntimeStore.readRuntime(E),I=false,x=()=>{I&&(r.cardRuntimeStore.writeRuntime(E,R),I=false);},A=v=>Tt(R._sources[v]),F=(v,g)=>{R._sources[v]=Tt(g),I=true;},c=u.taskState?.executionCount??0;if(R._lastExecutionCount!==c&&(R._sources={},R._lastExecutionCount=c,I=true),u.update){let v=u.update,g=v.outputFile;if(g){let L=A(g);if(v.failure){let D=v.rqt??L.lastRequestedToken??L.queueRequestedToken;D&&F(g,_t(L,D));}else {let D=v.rqt;if(!L.lastCompletedToken||D>L.lastCompletedToken){let H=typeof v.deliveryToken=="string"?v.deliveryToken:void 0,w=false;H&&(w=r.fetchedSourcesStore.commitSourceData(E,g,H)),w?F(g,vr(L,D)):F(g,_t(L,D));}}x();}}let d={};for(let v of C)if(v.outputFile){let g=r.fetchedSourcesStore.readSourceData(E,v.outputFile);g!==null&&(d[v.bindTo]=g);}let f={};for(let[v,g]of Object.entries(u.state??{}))if(g!==null&&typeof g=="object"&&!Array.isArray(g)){let L=g[v];f[v]=L!==void 0?L:g;}else f[v]=g;let l={id:E,card_data:{...y},requires:f,source_defs:C,compute:T.compute};l._sourcesData=d,T.compute&&ze.runSync(l,{sourcesData:d}),(s??r.outputStore.writeComputedValues.bind(r.outputStore))(E,l.computed_values??{});let k={...T},_=ze.enrichSourcesSync(Array.isArray(T.source_defs)?T.source_defs:void 0,{card_data:T.card_data,requires:f}),$=e.value;k.source_defs=Array.isArray(_)?_.map(v=>({...v,boardDir:typeof v.boardDir=="string"&&v.boardDir?v.boardDir:$})):_;let J=Lo(),W=u.update?void 0:J,te=S.filter(v=>{let g=v.outputFile;if(typeof g!="string"||!g)return true;let L=A(g);W&&(L={...L,queueRequestedToken:W},F(g,L));let D=L.queueRequestedToken??L.lastRequestedToken??J,H=Pt(L,D);return H==="in-flight"?false:H==="dispatch"});if(x(),te.length>0){let v=false,g=J;for(let L of te){let D=L.outputFile;if(typeof D!="string"||!D)continue;let H=A(D),w=H.queueRequestedToken??J;F(D,{...H,lastRequestedToken:w}),g=w,v=true;}return v&&x(),v&&(p.push({taskKind:"source-fetch",payload:{boardRef:ke(e),enrichedCard:k,callbackToken:u.callbackToken,rqt:g}}),r.executionRequestStore.appendEntries(t,p)),"task-initiated"}if(S.some(v=>{let g=v.outputFile;if(typeof g!="string"||!g)return false;let L=A(g),D=L.queueRequestedToken??L.lastRequestedToken??J;return Pt(L,D)==="in-flight"}))return "task-initiated";let X=T.provides??[],ee={};for(let{bindTo:v,ref:g}of X)ee[v]=ze.resolve(l,g);return (i??r.outputStore.writeDataObjects.bind(r.outputStore))(ee),C.filter(v=>{if(v.optionalForCompletionGating!==true)return false;let g=A(v.outputFile);return !g.lastRequestedToken||!g.lastCompletedToken?true:g.lastCompletedToken<=g.lastRequestedToken}).length>0&&p.push({taskKind:"source-fetch",payload:{boardRef:ke(e),enrichedCard:k,callbackToken:u.callbackToken,rqt:J}}),n(u.nodeId,ee),p.length>0&&r.executionRequestStore.appendEntries(t,p),"task-initiated"}}var Ft={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function er(e){return {[ct]:e.graph,[mn]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function tr(e){let t=e[ct],r=e[mn],o=e.board?.runtimeByCardId;if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${ct}`);return {graph:t,lastDrainedJournalId:typeof r=="string"?r:"",runtimeByCardId:o&&typeof o=="object"?o:{}}}function rr(e){let t=e.requires;return {provides:e.provides?.map(n=>n.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...t&&t.length>0?{requires:t}:{}}}function nr(e){function t(s){return {status:"success",data:s}}function r(s){return {status:"fail",error:s}}function n(s){return {status:"error",error:s instanceof Error?s.message:String(s)}}function o(s){if(Array.isArray(s))return s;if(s&&typeof s=="object"){let i=s;return Array.isArray(i.files)?i.files:[s]}return null}return {get(s){try{let i=s.params?.id;if(i){let u=e.readCard(i);return u?t({cards:[u]}):r(`card "${i}" not found`)}return t({cards:e.readAllCards()})}catch(i){return n(i)}},set(s){try{let i=s.body;if(i==null)return r("set requires a body (card object or array of cards)");let u=Array.isArray(i)?i:[i];for(let p of u){if(typeof p.id!="string")return r("each card must have a string `id` field");e.writeCard(p.id,p);}return t({count:u.length})}catch(i){return n(i)}},del(s){try{let i=s.body?.ids??[],u=s.params?.id,p=u?[...i,u]:i;if(p.length===0)return r("del requires body.ids (string[]) or params.id");for(let T of p)e.removeCard(T);return t({count:p.length})}catch(i){return n(i)}},patch(s){try{let i=s.params?.id,u=s.params?.path;if(!i)return r("patch requires params.id");if(!u)return r("patch requires params.path");let p=s.body,T=p&&Object.prototype.hasOwnProperty.call(p,"value")?p.value:s.body;return e.patchCard(i,u,T),t({count:1})}catch(i){return n(i)}},appendFiles(s){try{let i=s.params?.id;if(!i)return r("appendFiles requires params.id");let u=e.readCard(i);if(!u)return r(`card "${i}" not found`);let p=o(s.body);if(!p||p.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let T=u.card_data&&typeof u.card_data=="object"&&!Array.isArray(u.card_data)?u.card_data:{},E=Array.isArray(T.files)?T.files:[],y=[...E,...p],C=p.map((R,I)=>({idx:E.length+I,entry:R})),S=this.patch({params:{id:i,path:"card_data.files"},body:{value:y}});return S.status!=="success"?S:t({files_added:C})}catch(i){return n(i)}}}}function pe(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function se(e){return {status:"fail",error:e}}function Re(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function Mo(e){let t=new TextEncoder().encode(e),r=Array.from(t,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function wn(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function or(e){try{let t=JSON.parse(wn(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function kn(e){return Mo(JSON.stringify(e))}function Cn(e){try{let t=JSON.parse(wn(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function Xe(){return new Date().toISOString()}function Do(e){let t=new Map;return {appendEntries(r,n){if(!r||n.length===0)return;let o=t.get(r)??[];t.set(r,[...o,...n]);},dispatchEntriesForJournalId(r,n){if(!r)return;let o=t.get(r);if(!(!o||o.length===0)){for(let s of o)try{n(s);}catch(i){try{e(s,i instanceof Error?i.message:String(i));}catch{}}t.delete(r);}}}}function Sn(e,t,r={}){Dt(t.callbackTransport,"createBoardLiveCardsPublic");let n=t.callbackTransport,o=t.onWarn??(()=>{}),s=ke(e),i=r.boardRuntimeStoreRef,u=r.scratchStoreRef,p=r.taskExecutorRef,T=r.chatHandlerFlow;function E(){if(!i)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return i}function y(M){if(M.length!==0)try{let m=t.publishBoardChangeNotifications?.(M);m&&typeof m.catch=="function"&&m.catch(j=>o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${j instanceof Error?j.message:String(j)}`));}catch(m){o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${m instanceof Error?m.message:String(m)}`);}}function C(){let M=R().readCardStoreRef();if(!M)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let m=t.kvStorageForRef(M);return {readIndex(){return m.read("_index")},writeIndex(j){m.write("_index",j);},readCard(j){return m.read(j)},writeCard(j,K){return m.write(j,K),t.hashFn(K)},removeCard(j){m.delete(j);},cardExists(j){return m.read(j)!==null},defaultCardKey(j){return j}}}let S={readValues(M){let m=t.kvStorageForRef(E()),j=m.listKeys().sort();if(j.length===0)return {version:null,values:{}};let K={};for(let oe of j)K[oe]=m.read(oe);return {version:t.hashFn(K),values:K}},writeValues(M,m,j){let K=t.kvStorageForRef(E());for(let oe of j)K.delete(oe);for(let[oe,re]of Object.entries(m))K.write(oe,re);return t.hashFn(m)}},R=()=>Zt(t.kvStorageForRef(E())),I=()=>yn(S),x=()=>pn(t.journalAdapterForRef(E())),A=()=>Et(C(),o),F=()=>{let M=R().readOutputsStoreRef();if(!M)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return hn(t.kvStorageForRef(M))};function c(){return p??R().readTaskExecutorRef()}function h(){return !!I().readSnapshot(e.value).values[ct]}function d(){let M=I().readSnapshot(e.value);if(!M.values[ct])throw new Error(`Board not initialized at ${e.value}`);return tr(M.values)}function f(M,m){let j=I().commitSnapshot(e.value,{schemaVersion:Xt,expectedVersion:m,commitId:t.genId(),committedAt:Xe(),deleteKeys:[],shallowMerge:er(M)});if(!j.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${m??"null"} current=${j.currentVersion??"null"}`)}function l(M){x().appendEvent(M);}async function k(){let m=Do((B,N)=>{let Y=B.payload,le=(Y?.enrichedCard??{}).id??Y?.cardId??"unknown";l({type:"task-failed",taskName:le,error:N,timestamp:Xe()});}),j=d(),K=ht(j.graph),{events:oe,newCursor:re}=x().readEntriesAfterCursor(j.lastDrainedJournalId),Ae=H(),be=Yt(Ae,B=>t.resolveBlob(B)),Fe={...j.runtimeByCardId},qe=new Map,$e={readRuntime(B){return qe.get(B)??Fe[B]??{_sources:{}}},writeRuntime(B,N){qe.set(B,N),Fe[B]=N;}},We=[],He=new Map,lt={readSourceData(B,N){let Y=`${B}/${N}`;return He.has(Y)?He.get(Y):be.readSourceData(B,N)},ingestSourceDataStaged(B,N,Y,he){be.ingestSourceDataStaged(B,N,Y,he);},commitSourceData(B,N,Y){let he=`${B}/.staged/${Y}/${N}`,le=Ae.read(he);if(le==null){let De=Ae.keyRef?.(he);De&&(le=t.resolveBlob(De));}if(le==null)return false;let Te=`${B}/${N}`,Oe=le.trim();try{He.set(Te,JSON.parse(Oe));}catch{He.set(Te,Oe);}return We.push({cardId:B,outputFile:N,deliveryToken:Y}),true},hasSource(B,N){let Y=`${B}/${N}`;return He.has(Y)?true:be.hasSource(B,N)},listSources(B){let N=be.listSources(B),Y=new Set;for(let le of He.keys())le.startsWith(`${B}/`)&&Y.add(le.slice(`${B}/`.length));let he=new Set([...N,...Y]);return Array.from(he)}},et={cardStore:A(),cardRuntimeStore:$e,fetchedSourcesStore:lt,outputStore:F(),executionRequestStore:m},tt=[],kt=[],Ct=[],Ot=new Map,qt=new Set,Lr=(B,N)=>{tt.push({type:"task-completed",taskName:B,data:N,timestamp:Xe()});},vt=(B,N)=>{l({type:"task-failed",taskName:B,error:N,timestamp:Xe()});},At=$t(K,{handlers:{"card-handler":Rn(e,re,et,Lr,vt,(B,N)=>{kt.push({cardId:B,values:N});},B=>{Ct.push(B);})},onNodeRemoved:B=>{Ot.delete(B),qe.delete(B),delete Fe[B],qt.add(B);}});for(tt=oe;tt.length>0;){let B=tt;tt=[];for(let N of B)if(N.type==="task-restart"){let Y=et.cardStore.readCard(N.taskName);Y&&Ot.set(N.taskName,Y);}At.pushAll(B),await At.waitForHandlers();}let jt=At.getState();await At.dispose({wait:true});let pr=I().readSnapshot(e.value).version;f({lastDrainedJournalId:re,graph:yt(jt),runtimeByCardId:Fe},pr);for(let{cardId:B,values:N}of kt)et.outputStore.writeComputedValues(B,N);for(let B of Ct)et.outputStore.writeDataObjects(B);for(let{cardId:B,outputFile:N,deliveryToken:Y}of We)be.commitSourceData(B,N,Y);let a;try{a=Rt(s,jt),et.outputStore.writeStatusSnapshot(a);}catch(B){o(`[board-live-cards-public] status publish failed: ${B instanceof Error?B.message:String(B)}`);}let P=[];for(let{cardId:B,values:N}of kt)P.push({kind:"computed_values",cardId:B,values:N});for(let B of Ct)for(let[N,Y]of Object.entries(B))N&&P.push({kind:"data_object",key:N,payload:Y});for(let[B,N]of Ot)P.push({kind:"card_refreshed",cardId:B,card:N});for(let B of qt)P.push({kind:"card_removed",cardId:B});a!==void 0&&P.push({kind:"status",status:a}),y(P);let O=c()??{howToRun:"built-in",whatToRun:ke({kind:"built-in",value:"source-cli-task-executor"})},G=t.supportsDirectSourceOutput?.(O)===true;m.dispatchEntriesForJournalId(re,B=>{if(B.taskKind!=="source-fetch"){o(`[process-accumulated-events] unknown taskKind "${B.taskKind}" \u2014 skipping`);return}let N=B.payload,Y=N.enrichedCard?.id??"unknown",he=N.enrichedCard?.source_defs??[];if(O.howToRun==="queue-storage"&&G){try{let le=t.queueStorageForRef(_(),"task-executor"),Te=typeof O.extra?.boardId=="string"?O.extra.boardId:void 0,Oe=[];for(let De of he){if(!De.outputFile){o(`[dispatch] source "${De.bindTo}" has no outputFile \u2014 skipping`);continue}let Q=t.genId(),de=`${Y}/.staged/${Q}/${De.outputFile}`,Ce=Ae.keyRef?.(de);if(!Ce)continue;let ge={ref:ke(Ce),deliveryToken:Q,outputFile:De.outputFile,cardId:Y},Ie=kn({cbk:N.callbackToken,rg:e.value,br:ke(e),cid:Y,b:De.bindTo,d:De.outputFile,cs:void 0,rqt:N.rqt,dt:ge.deliveryToken});Oe.push({...Te?{boardId:Te}:{},ref:O,args:{source_def:De,base_ref:ke(e),callback:n.createCallback(Ie),output:ge}});}Oe.length>0&&le.enqueueMany(Oe);}catch(le){vt(Y,le instanceof Error?le.message:String(le));}return}for(let le of he){if(!le.outputFile){o(`[dispatch] source "${le.bindTo}" has no outputFile \u2014 skipping`);continue}let Te;if(G){let De=t.genId(),Q=`${Y}/.staged/${De}/${le.outputFile}`,de=Ae.keyRef?.(Q);de&&(Te={ref:ke(de),deliveryToken:De,outputFile:le.outputFile,cardId:Y});}let Oe=kn({cbk:N.callbackToken,rg:e.value,br:ke(e),cid:Y,b:le.bindTo,d:le.outputFile,cs:void 0,rqt:N.rqt,...Te?{dt:Te.deliveryToken}:{}});t.dispatchExecution(O,{source_def:le,base_ref:ke(e),callback:n.createCallback(Oe),...Te?{output:Te}:{}}).catch(De=>vt(Y,De instanceof Error?De.message:String(De)));}});}function _(){let M=R().readQueueStoreRef();if(!M)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);return M}function $(){let M=t.queueStorageForRef(_(),"process-accumulated");M.enqueueIfAbsent?M.enqueueIfAbsent({boardRef:ke(e)},`process-accumulated:${ke(e)}`):M.enqueue({boardRef:ke(e)}),t.requestProcessAccumulated?.();}function J(){let M=t.queueStorageForRef(_(),"process-accumulated");for(;;){let m=M.lease({max:64,visibilityMs:1e3});if(m.length<=0)return;for(let j of m)M.ack(j.id,j.leaseToken);if(m.length<64)return}}async function W(){try{let M=()=>{let j=d(),{events:K}=x().readEntriesAfterCursor(j.lastDrainedJournalId);K.length<=0||$();},m=await $r(t.lock,k,M);return pe({ran:m!==!1})}catch(M){return Re(M)}}function te(){$();}function ie(M){try{let m=M.params?.cardStoreRef;if(!m)return se("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(i=M.params?.boardRuntimeStoreRef,!i)return se("init requires params.boardRuntimeStoreRef \u2014 pass the board runtime store ref here");if(!h()){let Fe=St(Ft);f({lastDrainedJournalId:"",graph:yt(Fe),runtimeByCardId:{}},null);}let j=M.params?.outputsStoreRef;if(!j)return se("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let K=M.params?.queueStoreRef;if(!K)return se("init requires params.queueStoreRef \u2014 pass the queue store ref here");let oe=M.params?.fetchedSourcesStoreRef;if(!oe)return se("init requires params.fetchedSourcesStoreRef \u2014 pass the fetched sources store ref here");if(u=M.params?.scratchStoreRef,!u)return se("init requires params.scratchStoreRef \u2014 pass the scratch store ref here");let re=M.params?.chatStoreRef;if(!re)return se("init requires params.chatStoreRef \u2014 pass the chat store ref here");let Ae=M.params?.artifactsStoreRef;if(!Ae)return se("init requires params.artifactsStoreRef \u2014 pass the artifacts store ref here");let be=R();be.writeBoardRuntimeStoreRef(i),be.writeCardStoreRef(m),be.writeOutputsStoreRef(j),be.writeQueueStoreRef(K),be.writeFetchedSourcesStoreRef(oe),be.writeChatStoreRef(re),be.writeArtifactsStoreRef(Ae);try{F().writeStatusSnapshot(Rt(s,ht(d().graph)));}catch{}return pe()}catch(m){return Re(m)}}function X(M){try{let m=F().readStatusSnapshot();if(!m){m=Rt(s,ht(d().graph));try{F().writeStatusSnapshot(m);}catch{}}return pe(m)}catch(m){return Re(m)}}function ee(M){try{let m=M.params?.id;if(!m)return se("removeCard requires params.id");try{t.kvStorage("card-upsert").delete(m);}catch{}return l({type:"task-removal",taskName:m,timestamp:Xe()}),te(),pe()}catch(m){return Re(m)}}function ne(M){try{let m=M.params?.cardId;if(!m)return se("addCardFiles requires params.cardId");let j=nr(A()).appendFiles({params:{id:m},body:M.body});if(j.status!=="success")return j;let K=v({params:{cardId:m}});return K.status!=="success"?K:pe({cardId:m,files_added:j.data.files_added,notified:!0})}catch(m){return Re(m)}}function v(M){try{let m=M.params?.cardId;if(!m)return se("cardRefreshedNotify requires params.cardId");let j=A().readCard(m);return j?(y([{kind:"card_refreshed",cardId:m,card:j}]),pe({cardId:m,notified:!0})):se(`Card "${m}" not found in board at ${e.value}`)}catch(m){return Re(m)}}function g(M){try{let m=M.params?.id;return m?(l({type:"task-restart",taskName:m,timestamp:Xe()}),te(),pe()):se("retrigger requires params.id")}catch(m){return Re(m)}}async function L(M){return J(),W()}function D(){let M=R().readFetchedSourcesStoreRef();if(!M)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return M}function H(){return t.blobStorageForRef(D())}function w(M){try{let m=M.params?.cardId,j=M.params?.all,K=!!M.params?.restart;if(!m&&!j)return se("upsertCard requires --card-id <id> or --all");let oe=j?A().readAllCards().map(re=>re.id):[m];for(let re of oe)if(!A().readCard(re))return se(`Card "${re}" not found in board at ${e.value}`);for(let re of oe){let Ae=A().readCard(re),be=rr(Ae),Fe=t.hashFn(be),qe=t.kvStorage("card-upsert"),$e=qe.read(re),We=$e?.taskConfigHash!==Fe;if(!(!We&&!K)){if(We){let He=$e?.blobRef??A().readCardKey(re)??re;l({type:"task-upsert",taskName:re,taskConfig:be,timestamp:Xe()}),qe.write(re,{blobRef:He,taskConfigHash:Fe,updatedAt:Xe()});}K&&l({type:"task-restart",taskName:re,timestamp:Xe()});}}return te(),pe()}catch(m){return Re(m)}}function b(M){try{let m=M.params?.token;if(!m)return se("taskFailed requires params.token");let j=M.params?.error??"unknown error",K=or(m);return K?(l({type:"task-failed",taskName:K.taskName,error:j,timestamp:Xe()}),te(),pe()):se("Invalid callback token")}catch(m){return Re(m)}}function q(M){try{let m=M.params?.token;if(!m)return se("taskProgress requires params.token");let K=(M.body??{}).update??{},oe=or(m);return oe?(l({type:"task-progress",taskName:oe.taskName,update:K,timestamp:Xe()}),te(),pe()):se("Invalid callback token")}catch(m){return Re(m)}}function U(M){try{let m=M.params?.token,j=M.params?.ref;if(!m)return se("sourceDataFetched requires params.token");if(!j)return se("sourceDataFetched requires params.ref");let K=Cn(m);if(!K)return se("Invalid source token");let{cbk:oe,cid:re,b:Ae,d:be,cs:Fe,rqt:qe,dt:$e}=K,We=Yt(H(),tt=>t.resolveBlob(tt)),He=$e||t.genId();$e||We.ingestSourceDataStaged(re,be,at(j),He);let lt=or(oe);if(!lt)return se("Invalid callback token embedded in source token");let et=Xe();return l({type:"task-progress",taskName:lt.taskName,update:{bindTo:Ae,outputFile:be,fetchedAt:et,deliveryToken:He,sourceChecksum:Fe,rqt:qe},timestamp:et}),te(),pe()}catch(m){return Re(m)}}function V(M){try{let m=M.params?.token,j=M.params?.reason??"unknown";if(!m)return se("sourceDataFetchFailure requires params.token");let K=Cn(m);if(!K)return se("Invalid source token");let{cbk:oe,b:re,d:Ae,cs:be,rqt:Fe}=K,qe=or(oe);return qe?(l({type:"task-progress",taskName:qe.taskName,update:{bindTo:re,outputFile:Ae,failure:!0,reason:j,sourceChecksum:be,rqt:Fe},timestamp:Xe()}),te(),pe()):se("Invalid callback token embedded in source token")}catch(m){return Re(m)}}function Z(M){try{let m=R().readCardStoreRef();return m?pe({storeRef:m}):se(`Board at ${e.value} has no card store configured`)}catch(m){return Re(m)}}function ae(M){try{return pe({storeRef:i??null})}catch(m){return Re(m)}}function fe(M){try{let m=R().readOutputsStoreRef();return m?pe({storeRef:m}):se(`Board at ${e.value} has no outputs store configured`)}catch(m){return Re(m)}}function we(M){try{return pe({storeRef:u??null})}catch(m){return Re(m)}}function Pe(M){try{let m=R().readChatStoreRef();return pe({storeRef:m})}catch(m){return Re(m)}}function Be(M){try{let m=R().readArtifactsStoreRef();return pe({storeRef:m})}catch(m){return Re(m)}}function Se(M){try{let m=R().readFetchedSourcesStoreRef();return pe({storeRef:m})}catch(m){return Re(m)}}function ce(M){try{let m=M.params?.key;if(!m)return se("getConfig requires params.key");let j=R(),K;switch(m){case "task-executor":K=p??null;break;case "chat-handler-flow":K=T??null;break;case "board-runtime-store-ref":K=j.readBoardRuntimeStoreRef();break;case "card-store-ref":K=j.readCardStoreRef();break;case "outputs-store-ref":K=j.readOutputsStoreRef();break;case "scratch-store-ref":K=u??null;break;case "chat-store-ref":K=j.readChatStoreRef();break;case "artifacts-store-ref":K=j.readArtifactsStoreRef();break;case "fetched-sources-store-ref":K=j.readFetchedSourcesStoreRef();break;default:return se(`getConfig: unknown key "${m}"`)}return pe({value:K})}catch(m){return Re(m)}}function Le(M){try{let m=M.params?.key;if(!m)return se("getOutputsDataObject requires params.key");let j=F().readDataObject(m);return pe(j)}catch(m){return Re(m)}}function ve(M){try{return pe(F().readAllDataObjects())}catch(m){return Re(m)}}function Me(M){try{let m=M.params?.key;if(!m)return se("getOutputsComputedValues requires params.key");let j=F().readComputedValues(m);return pe(j)}catch(m){return Re(m)}}function Ne(M){try{return pe(F().readAllComputedValues())}catch(m){return Re(m)}}function me(){return Yt(H(),M=>t.resolveBlob(M))}function Ze(M){let m=H().keyRef?.(M);if(!m)throw new Error("configured fetched-sources store does not support keyRef");return ke(m)}function Ke(M){try{let m=M.params?.key;if(!m)return se("getOutputsFetchedSources requires params.key");let j=me().listSources(m),K={};for(let oe of j)K[oe]=Ze(`${m}/${oe}`);return pe(K)}catch(m){return Re(m)}}function Ge(M){try{let m=me(),j=new Set;for(let oe of H().listKeys()){let re=oe.indexOf("/");re>0&&!oe.includes("/.staged/")&&j.add(oe.slice(0,re));}let K={};for(let oe of j){let re=m.listSources(oe);if(re.length>0){K[oe]={};for(let Ae of re)K[oe][Ae]=Ze(`${oe}/${Ae}`);}}return pe(K)}catch(m){return Re(m)}}return {init:ie,status:X,getBoardRuntimeStoreRef:ae,getCardStoreRef:Z,getOutputsStoreRef:fe,getScratchStoreRef:we,getChatStoreRef:Pe,getArtifactsStoreRef:Be,getFetchedSourcesStoreRef:Se,getConfig:ce,getOutputsDataObject:Le,getAllOutputsDataObjects:ve,getOutputsComputedValues:Me,getAllOutputsComputedValues:Ne,getOutputsFetchedSources:Ke,getAllOutputsFetchedSources:Ge,removeCard:ee,addCardFiles:ne,cardRefreshedNotify:v,retrigger:g,processAccumulatedEvents:L,upsertCard:w,taskFailed:b,taskProgress:q,sourceDataFetched:U,sourceDataFetchFailure:V}}function bn(e,t,r){let n=r?.taskExecutorRef,o=()=>{if(r){if(!r.boardRuntimeStoreRef)throw new Error(`Board at ${e.value} requires boardRuntimeStoreRef for non-core runtime operations.`);return Zt(t.kvStorageForRef(r.boardRuntimeStoreRef))}return Zt(t.kvStorage("config"))};function s(){let F=o().readCardStoreRef();if(!F)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let c=t.kvStorageForRef(F);return {readIndex(){return c.read("_index")},writeIndex(h){c.write("_index",h);},readCard(h){return c.read(h)},writeCard(h,d){return c.write(h,d),t.hashFn(d)},removeCard(h){c.delete(h);},cardExists(h){return c.read(h)!==null},defaultCardKey(h){return h}}}let i=()=>Et(s(),t.onWarn??(()=>{}));function u(){return n??o().readTaskExecutorRef()}async function p(F,c){let h=t.validateSchema(c),d=[],f=u();if(f&&Array.isArray(c.source_defs))for(let k of c.source_defs){let _=typeof k.bindTo=="string"?k.bindTo:"(unknown)";try{let $;try{$=await t.invokeExecutor(f,"validate-source-def",{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(k)});}catch(W){let te=W;if($=typeof te?.stdout=="string"?te.stdout:"",!$.trim()){d.push(`source "${_}": executor validate-source-def failed \u2014 ${W instanceof Error?W.message:String(W)}`);continue}}let J=JSON.parse($.trim());if(!J.ok&&Array.isArray(J.errors))for(let W of J.errors)d.push(`source "${_}": ${W}`);}catch($){d.push(`source "${_}": executor validate-source-def failed \u2014 ${$ instanceof Error?$.message:String($)}`);}}let l=[...h.errors,...d];return pe({cardId:F,isValid:l.length===0,issues:l})}function T(F,c){let h=F.params?.sourceIdx,d=F.params?.outRef;if(h===void 0)return se(`${c} requires params.sourceIdx`);if(!F.body||typeof F.body!="object"||Array.isArray(F.body))return se(`${c} requires card JSON object in body`);let f=F.body,l=f["card-content"]??f,k=f["mock-projections"]??{},_=l.source_defs??[];if(h<0||h>=_.length)return se(`sourceIdx ${h} out of range (card has ${_.length} source(s))`);let $=_[h],J=typeof $.bindTo=="string"?$.bindTo:"source";return {src:$,bindTo:J,outRef:d,mockProjections:k}}async function E(F){try{if(!F.body||typeof F.body!="object"||Array.isArray(F.body))return se("validateCardPreflight requires card JSON object in body");let c=F.body,h=c["card-content"]??c,d=typeof h.id=="string"?h.id:"(unknown)";return await p(d,h)}catch(c){return Re(c)}}async function y(F){try{let c=T(F,"probeSourcePreflight");if("status"in c)return c;let h=u();if(!h)return se("No task-executor registered for this board");try{let d={...c.src,_projections:c.mockProjections},f=await t.invokeExecutor(h,"probe-source-preflight",{timeout:c.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(d)}),l=JSON.parse(f.trim());return l.ok?pe({bindTo:c.bindTo,reachable:l.reachable,latencyMs:l.latencyMs,note:l.note}):se(l.error??"Preflight probe failed")}catch{return se("Executor does not support probe-source-preflight")}}catch(c){return Re(c)}}async function C(F){try{let c=T(F,"runSourcePreflight");if("status"in c)return c;let h=u();if(!h)return se("No task-executor registered for this board");try{let d={...c.src,_projections:c.mockProjections},f=await t.invokeExecutor(h,"run-source-preflight",{timeout:c.src.timeout??t.executorTimeouts?.probeMs??6e4,input:JSON.stringify(d)}),l=JSON.parse(f.trim());if(!l.ok)return pe({bindTo:c.bindTo,ok:!1,result:null,issues:[l.error??"Preflight run failed"]});if(c.outRef){let k=at(c.outRef);t.absoluteBlob.write(k.value,JSON.stringify(l.resultValue,null,2));}return pe({bindTo:typeof l.bindTo=="string"?l.bindTo:c.bindTo,ok:!0,result:l.resultValue??null,issues:[]})}catch(d){let f=d instanceof Error?d.message:String(d);return pe({bindTo:c.bindTo,ok:!1,result:null,issues:[f]})}}catch(c){return Re(c)}}async function S(F){try{let c=u();if(!c)return se("No task-executor registered for this board");let h=await t.invokeExecutor(c,"describe-capabilities",{timeout:t.executorTimeouts?.describeMs??1e4});return pe(JSON.parse(h.trim()))}catch(c){return Re(c)}}function R(F){try{let c=F.body;if(!c||!Array.isArray(c.ops))return se("updatesInCardStore requires body.ops array");let h=c.ops,d=i();for(let f of h){let l=f.op,k=f.id;if(!k)return se('op is missing "id"');if(l==="update"){let _=f["card-content"];if(!_)return se(`update op for "${k}" is missing "card-content"`);d.writeCard(k,_);}else return se(`Unknown op type: "${l??"(none)"}"`)}return pe()}catch(c){return Re(c)}}function I(F){try{let c=F.body;if(!c||!Array.isArray(c.ids))return se("readFromCardStore requires body.ids array");let h=c.ids,d=i(),f=h.map(l=>({id:l,"card-content":d.readCard(l)}));return pe({cards:f})}catch(c){return Re(c)}}function x(F){try{if(!F.body||typeof F.body!="object"||Array.isArray(F.body))return se("evalCardCompute requires a JSON object in body");let c=F.body,h=c["card-content"]??c,d=typeof h.id=="string"?h.id:"(unknown)",f=c["mock-fetched-sources"]??{},l=c["mock-requires"]??{},k=h.compute;if(!k||!Array.isArray(k)||k.length===0)return pe({cardId:d,ok:!0,computed_values:{},errors:[]});let _={id:d,card_data:h.card_data??{},requires:l,source_defs:h.source_defs,compute:k},$=ze.runSync(_,{sourcesData:f}),J=$.node.computed_values??{},W=$.errors??[];return pe({cardId:d,ok:W.length===0,computed_values:J,errors:W})}catch(c){return Re(c)}}async function A(F){try{if(!F.body||typeof F.body!="object"||Array.isArray(F.body))return se("simulateCardCycle requires a JSON object in body");let c=F.body,h=c["card-content"]??c,d=typeof h.id=="string"?h.id:"(unknown)",f=c["mock-fetched-sources"]??{},l=c["mock-requires"]??{},k=await p(d,h),_=k.status==="success"?{isValid:k.data.isValid,issues:k.data.issues}:{isValid:!1,issues:[k.status==="fail"?k.error:"internal error"]},$=h.source_defs??[],J=h.card_data??{},W=[],te=[];if($.length>0){W=ze.enrichSourcesSync($,{card_data:J,requires:l});for(let H of W){let w=H.projections,b=H._projections;if(w&&b){for(let q of Object.keys(w))if(b[q]===void 0){let U=typeof H.bindTo=="string"?H.bindTo:"(unknown)";te.push({bindTo:U,key:q,error:`Projection "${q}" resolved to undefined`});}}}}let ie=[],X={...f},ee=c["task-executor-ref"],ne=(ee?.howToRun&&ee?.whatToRun?ee:void 0)??u();for(let H=0;H<W.length;H++){let w=W[H],b=typeof w.bindTo=="string"?w.bindTo:`source_${H}`;if(!ne){ie.push({bindTo:b,skipped:!0,error:"No task executor configured"});continue}try{let q={...w},U=await t.invokeExecutor(ne,"run-source-preflight",{timeout:w.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(q)}),V=JSON.parse(U.trim());V.ok&&!Object.prototype.hasOwnProperty.call(f,b)&&Object.prototype.hasOwnProperty.call(V,"resultValue")&&(X[b]=V.resultValue),ie.push({bindTo:b,reachable:V.reachable,latencyMs:V.latencyMs,error:V.ok?void 0:V.error});}catch{ie.push({bindTo:b,skipped:!0,error:"Executor does not support run-source-preflight"});}}let v=h.compute,g={},L=[];if(v&&Array.isArray(v)&&v.length>0){let H={id:d,card_data:J,requires:l,source_defs:h.source_defs,compute:v},w=ze.runSync(H,{sourcesData:X});g=w.node.computed_values??{},L=w.errors??[];}let D=_.isValid&&te.length===0&&L.length===0&&ie.every(H=>H.reachable!==!1);return pe({cardId:d,ok:D,validation:_,source_probes:ie,projection_errors:te,fetched_sources:X,computed_values:g,compute_errors:L})}catch(c){return Re(c)}}return {validateCardPreflight:E,probeSourcePreflight:y,runSourcePreflight:C,evalCardCompute:x,simulateCardCycle:A,describeTaskExecutorCapabilities:S,updatesInCardStore:R,readFromCardStore:I}}async function vn(e,t,r){let n=await e.tryAcquire();if(!n)return false;try{await t();}finally{await n();}return await r?.(),true}function Ar(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function xr(e){return {async enqueueRequest(t){return (await e.enqueue(t)).id},async leaseRequests(t){return (await e.lease(t)).map(r=>({...Ar(r),leaseToken:r.leaseToken,leaseExpiresAt:r.leaseExpiresAt}))},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,n){return e.nack(t,r,n)},async peekActive(){return (await e.peekActive()).map(Ar)},async peekDeadLetter(){return (await e.peekDeadLetter()).map(t=>({...Ar(t),reason:t.reason}))}}}function An(e){async function t(r){let n=await e.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {async readTaskExecutorRef(){let r=await t("task-executor");if(r?.trim())return Ht(r.trim())},writeTaskExecutorRef(r){return e.write("task-executor",Kt(r))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){return e.write("chat-handler-flow",r)},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(r){return e.write("board-runtime-store-ref",r)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(r){return e.write("card-store-ref",r)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(r){return e.write("outputs-store-ref",r)},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(r){return e.write("queue-store-ref",r)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){return e.write("scratch-store-ref",r)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(r){return e.write("chat-store-ref",r)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(r){return e.write("artifacts-store-ref",r)},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(r){return e.write("fetched-sources-store-ref",r)}}}function No(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function sr(e,t){return No(e)?e.then(t):t(e)}function xn(e,t){let r={...e};for(let[n,o]of Object.entries(t))o!==null&&typeof o=="object"&&!Array.isArray(o)&&r[n]!==null&&typeof r[n]=="object"&&!Array.isArray(r[n])?r[n]=xn(r[n],o):r[n]=o;return r}function ar(e,t,r){if(t.length===0)return e;let[n,...o]=t;if(o.length===0)return {...e,[n]:r};let s=e[n]!==null&&typeof e[n]=="object"&&!Array.isArray(e[n])?e[n]:{};return {...e,[n]:ar(s,o,r)}}function In(e){return {read:r=>e.read(r),get(r,n){return sr(e.read(r),o=>{if(o===null)return null;let s=o;for(let i of n.split(".").filter(Boolean)){if(s===null||typeof s!="object"||Array.isArray(s))return null;s=s[i]??null;}return s??null})},write:(r,n)=>e.write(r,n),delete:r=>e.delete(r),listKeys:r=>e.listKeys(r),shallowMerge(r,n){return sr(e.read(r),o=>e.write(r,{...o??{},...n}))},deepMerge(r,n){return sr(e.read(r),o=>e.write(r,xn(o??{},n)))},patch(r,n,o){return sr(e.read(r),s=>{let i=n.split(".").filter(Boolean);return e.write(r,ar(s??{},i,o))})}}}function ir(e){return In(e)}function ur(e,t){return {async readIndex(){return await e.read("_index")},writeIndex(r){return e.write("_index",r)},async readCard(r){return await e.read(r)},async writeCard(r,n){return await e.write(r,n),t(n)},removeCard(r){return e.delete(r)},async cardExists(r){return await e.read(r)!==null},defaultCardKey(r){return r}}}function dr(e,t){async function r(){return await e.readIndex()??{}}return {async readCard(n){let o=(await r())[n];return !o||!await e.cardExists(o.key)?null:await e.readCard(o.key)},async readCardKey(n){return (await r())[n]?.key??null},async readAllCards(){let n=[];for(let[o,s]of Object.entries(await r())){if(!await e.cardExists(s.key))continue;let i=await e.readCard(s.key);i?n.push(i):t?.(`[card-store] could not read card "${o}" at key "${s.key}"`);}return n},async readChecksumIndex(){let n={};for(let[o,s]of Object.entries(await r()))n[o]=s.checksum;return n},async changedSince(n){let o=await r(),s=[];for(let[i,u]of Object.entries(o))n[i]!==u.checksum&&s.push(i);for(let i of Object.keys(n))o[i]||s.push(i);return s},async validateUpsert(n,o){let s=await r(),i=s[n],u=Object.entries(s).find(([,p])=>p.key===o);return i&&i.key!==o?{ok:false,error:`Card id "${n}" is already mapped to key "${i.key}", cannot remap to "${o}"`}:u&&u[0]!==n?{ok:false,error:`Key "${o}" is already mapped to card id "${u[0]}", cannot remap to "${n}"`}:{ok:true}},async writeCard(n,o,s){let i=await r(),u=s??i[n]?.key??e.defaultCardKey(n),p=await e.writeCard(u,o);i[n]={key:u,checksum:p,updatedAt:new Date().toISOString()},await e.writeIndex(i);},async patchCard(n,o,s){let i=await r(),u=i[n];if(!u||!await e.cardExists(u.key))throw new Error(`card "${n}" not found`);let p=await e.readCard(u.key);if(!p||typeof p!="object"||Array.isArray(p))throw new Error(`card "${n}" is not patchable`);let T=String(o||"").split(".").filter(Boolean),E=ar(p,T,s),y=await e.writeCard(u.key,E);i[n]={key:u.key,checksum:y,updatedAt:new Date().toISOString()},await e.writeIndex(i);},async removeCard(n){let o=await r(),s=o[n];s&&(await e.removeCard(s.key),delete o[n],await e.writeIndex(o));},readIndex(){return r()}}}function _e(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function ye(e){return {status:"fail",error:e}}function Ee(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function Qe(){return new Date().toISOString()}function $o(e){let t=new TextEncoder().encode(e),r=Array.from(t,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function _n(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function cr(e){try{let t=JSON.parse(_n(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function Tn(e){return $o(JSON.stringify(e))}function Pn(e){try{let t=JSON.parse(_n(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function Uo(e){return br(e,gn,()=>({_sources:{}}))}function Vo(e,t){return Qt(e,t)}function Ko(e){return zt(e)}function Ho(e,t){return Sr(e,t)}function Jo(e,t,r,n,o,s){return async i=>{let u=[],p=await r.cardStore.readCard(i.nodeId);if(!p)return "task-initiate-failure";let T=p.id,E=p.card_data??{},y=p.source_defs??[],C=y.filter(X=>X.optionalForCompletionGating!==true),S=await r.cardRuntimeStore.readRuntime(T),R=false,I=async()=>{R&&(await r.cardRuntimeStore.writeRuntime(T,S),R=false);},x=X=>Tt(S._sources[X]),A=(X,ee)=>{S._sources[X]=Tt(ee),R=true;},F=i.taskState?.executionCount??0;if(S._lastExecutionCount!==F&&(S._sources={},S._lastExecutionCount=F,R=true),i.update){let X=i.update.outputFile;if(X){let ee=x(X);if(i.update.failure){let ne=i.update.rqt??ee.lastRequestedToken??ee.queueRequestedToken;ne&&A(X,_t(ee,ne));}else {let ne=i.update.rqt;if(!ee.lastCompletedToken||ne>ee.lastCompletedToken){let v=typeof i.update.deliveryToken=="string"?i.update.deliveryToken:void 0,g=v?await r.fetchedSourcesStore.commitSourceData(T,X,v):false;A(X,g?vr(ee,ne):_t(ee,ne));}}await I();}}let c={};for(let X of y){if(!X.outputFile)continue;let ee=await r.fetchedSourcesStore.readSourceData(T,X.outputFile);ee!==null&&(c[X.bindTo]=ee);}let h={};for(let[X,ee]of Object.entries(i.state??{}))if(ee!==null&&typeof ee=="object"&&!Array.isArray(ee)){let ne=ee[X];h[X]=ne!==void 0?ne:ee;}else h[X]=ee;let d={id:T,card_data:{...E},requires:h,source_defs:y,compute:p.compute};d._sourcesData=c,p.compute&&ze.runSync(d,{sourcesData:c}),(o??(()=>{}))(T,d.computed_values??{});let f=ze.enrichSourcesSync(Array.isArray(p.source_defs)?p.source_defs:void 0,{card_data:p.card_data,requires:h}),l={...p,source_defs:Array.isArray(f)?f.map(X=>({...X,boardDir:typeof X.boardDir=="string"&&X.boardDir?X.boardDir:e.value})):f},k=Qe(),_=i.update?void 0:k,$=C.filter(X=>{let ee=X.outputFile;if(typeof ee!="string"||!ee)return true;let ne=x(ee);_&&(ne={...ne,queueRequestedToken:_},A(ee,ne));let v=ne.queueRequestedToken??ne.lastRequestedToken??k;return Pt(ne,v)==="dispatch"});if(await I(),$.length>0){let X=false,ee=k;for(let ne of $){let v=ne.outputFile;if(typeof v!="string"||!v)continue;let g=x(v),L=g.queueRequestedToken??k;A(v,{...g,lastRequestedToken:L}),ee=L,X=true;}return X&&await I(),X&&(u.push({taskKind:"source-fetch",payload:{boardRef:ke(e),enrichedCard:l,callbackToken:i.callbackToken,rqt:ee}}),await r.executionRequestStore.appendEntries(t,u)),"task-initiated"}if(C.some(X=>{let ee=X.outputFile;if(typeof ee!="string"||!ee)return false;let ne=x(ee),v=ne.queueRequestedToken??ne.lastRequestedToken??k;return Pt(ne,v)==="in-flight"}))return "task-initiated";let W=p.provides??[],te={};for(let{bindTo:X,ref:ee}of W)te[X]=ze.resolve(d,ee);return (s??(()=>{}))(te),y.filter(X=>{if(X.optionalForCompletionGating!==true)return false;let ee=x(X.outputFile);return !ee.lastRequestedToken||!ee.lastCompletedToken?true:ee.lastCompletedToken<=ee.lastRequestedToken}).length>0&&u.push({taskKind:"source-fetch",payload:{boardRef:ke(e),enrichedCard:l,callbackToken:i.callbackToken,rqt:k}}),n(i.nodeId,te),u.length>0&&await r.executionRequestStore.appendEntries(t,u),"task-initiated"}}function En(e,t,r={}){Dt(t.callbackTransport,"createAsyncBoardLiveCardsPublic");let n=t.callbackTransport,o=t.warn??(()=>{}),s=ke(e),i=null,u=r.boardRuntimeStoreRef,p=r.scratchStoreRef,T=r.taskExecutorRef,E=r.chatHandlerFlow;function y(){if(!u)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return u}function C(v){if(v.length!==0)try{return Promise.resolve(t.publishBoardChangeNotifications?.(v)).catch(g=>{o(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${g instanceof Error?g.message:String(g)}`);})}catch(g){o(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${g instanceof Error?g.message:String(g)}`);return}}let S=()=>An(t.kvStorageForRef(y())),R=e.value,I=()=>Gt(Cr(()=>t.kvStorageForRef(y()),t.hashFn),"v1"),x=async()=>{let v=await S().readOutputsStoreRef();if(!v)throw new Error(`Board at ${e.value} has no outputs store configured.`);return Ko(t.kvStorageForRef(v))},A=async()=>{let v=await S().readCardStoreRef();if(!v)throw new Error(`Board at ${e.value} has no card store configured.`);let g=t.kvStorageForRef(v);return dr(ur(ir(g),t.hashFn),o)};async function F(){return !!(await I().readSnapshot(R)).values[ct]}async function c(){let v=await I().readSnapshot(R);if(!v.values[ct])throw new Error(`Board not initialized at ${e.value}`);return tr(v.values)}async function h(v,g){let L=await I().commitSnapshot(R,{schemaVersion:"v1",expectedVersion:g,deleteKeys:[],shallowMerge:er(v)});if(!L.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${g??"null"} current=${L.currentVersion??"null"}`)}let d=()=>ln(t.journalStorageForRef(y()));async function f(){return T??await S().readTaskExecutorRef()}async function l(v){await d().appendEvent(v);}async function k(){let v=await S().readFetchedSourcesStoreRef();if(!v)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return v}async function _(){return t.blobStorageForRef(await k())}async function $(){return Vo(await _(),v=>t.resolveBlob(v))}async function J(v){let g=(await _()).keyRef?.(v);if(!g)throw new Error("configured fetched-sources store does not support keyRef");let L=await Promise.resolve(g);return ke(L)}async function W(){let v=Ho(t.kvStorageForRef(y()),async(m,j)=>{let K=m.payload,re=(K.enrichedCard??{}).id??K.cardId??"unknown";await l({type:"task-failed",taskName:re,error:j,timestamp:Qe()});}),g=Uo(t.kvStorageForRef(y())),L=await _(),D=await $(),H=await A(),w=await x(),b=new Map,q=new Map,U=[],V=[],Z=[],ae=new Map,fe=new Set,we={async readRuntime(m){return b.get(m)??await g.readRuntime(m)},async writeRuntime(m,j){b.set(m,j),ce[m]=j;}},Pe={async readSourceData(m,j){let K=`${m}/${j}`;return q.has(K)?q.get(K):await D.readSourceData(m,j)},ingestSourceDataStaged(m,j,K,oe){return D.ingestSourceDataStaged(m,j,K,oe)},async commitSourceData(m,j,K){let oe=`${m}/.staged/${K}/${j}`,re=await L.read(oe);if(re==null){let Fe=await Promise.resolve(L.keyRef?.(oe));Fe&&(re=await t.resolveBlob(Fe));}if(re==null)return false;let Ae=`${m}/${j}`,be=re.trim();try{q.set(Ae,JSON.parse(be));}catch{q.set(Ae,be);}return U.push({cardId:m,outputFile:j,deliveryToken:K}),true},async hasSource(m,j){let K=`${m}/${j}`;return q.has(K)||await D.hasSource(m,j)},async listSources(m){let j=await D.listSources(m),K=[...q.keys()].filter(oe=>oe.startsWith(`${m}/`)).map(oe=>oe.slice(`${m}/`.length));return [...new Set([...j,...K])]}},Be=await c(),Se=ht(Be.graph),ce={...Be.runtimeByCardId},{events:Le,newCursor:ve}=await d().readEntriesAfterCursor(Be.lastDrainedJournalId),Me=Le,Ne=$t(Se,{handlers:{"card-handler":Jo(e,ve,{cardStore:H,cardRuntimeStore:we,fetchedSourcesStore:Pe,executionRequestStore:v},(m,j)=>{Me.push({type:"task-completed",taskName:m,data:j,timestamp:Qe()});},(m,j)=>{V.push({cardId:m,values:j});},m=>{Z.push(m);})},onNodeRemoved:m=>{ae.delete(m),b.delete(m),delete ce[m],fe.add(m);}});for(;Me.length>0;){let m=Me;Me=[];for(let j of m)if(j.type==="task-restart"){let K=await H.readCard(j.taskName);K&&ae.set(j.taskName,K);}Ne.pushAll(m),await Ne.waitForHandlers();}let me=Ne.getState();await Ne.dispose({wait:true}),await h({lastDrainedJournalId:ve,graph:yt(me),runtimeByCardId:ce},(await I().readSnapshot(R)).version);for(let{cardId:m,values:j}of V)await w.writeComputedValues(m,j);for(let m of Z)await w.writeDataObjects(m);for(let[m,j]of b)await g.writeRuntime(m,j);for(let m of U)await D.commitSourceData(m.cardId,m.outputFile,m.deliveryToken);let Ze=Rt(s,me);await w.writeStatusSnapshot(Ze);let Ke=[];for(let{cardId:m,values:j}of V)Ke.push({kind:"computed_values",cardId:m,values:j});for(let m of Z)for(let[j,K]of Object.entries(m))Ke.push({kind:"data_object",key:j,payload:K});for(let[m,j]of ae)Ke.push({kind:"card_refreshed",cardId:m,card:j});for(let m of fe)Ke.push({kind:"card_removed",cardId:m});Ke.push({kind:"status",status:Ze}),await C(Ke);let Ge=await f();if(!Ge)return;let M=t.supportsDirectSourceOutput?.(Ge)===true;await v.dispatchEntriesForJournalId(ve,async m=>{if(m.taskKind!=="source-fetch"){o(`[async-process-accumulated-events] unknown taskKind "${m.taskKind}" \u2014 skipping`);return}let j=m.payload,K=j.enrichedCard?.id??"unknown",oe=j.enrichedCard?.source_defs??[];if(Ge.howToRun==="queue-storage"&&M){try{let re=await S().readQueueStoreRef();if(!re)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let Ae=t.queueStorageForRef(re,"task-executor"),be=typeof Ge.extra?.boardId=="string"?Ge.extra.boardId:void 0,Fe=[];for(let qe of oe){if(!qe.outputFile)continue;let $e=t.genId(),We=`${K}/.staged/${$e}/${qe.outputFile}`,He=await Promise.resolve(L.keyRef?.(We));if(!He)continue;let lt={ref:ke(He),deliveryToken:$e,outputFile:qe.outputFile,cardId:K},et=Tn({cbk:j.callbackToken,rg:e.value,br:ke(e),cid:K,b:qe.bindTo,d:qe.outputFile,cs:void 0,rqt:j.rqt,dt:lt.deliveryToken});Fe.push({...be?{boardId:be}:{},ref:Ge,args:{source_def:qe,base_ref:ke(e),callback:n.createCallback(et),output:lt}});}Fe.length>0&&await Ae.enqueueMany(Fe);}catch(re){await l({type:"task-failed",taskName:K,error:re instanceof Error?re.message:String(re),timestamp:Qe()});}return}for(let re of oe){if(!re.outputFile)continue;let Ae;if(M){let qe=t.genId(),$e=`${K}/.staged/${qe}/${re.outputFile}`,We=await Promise.resolve(L.keyRef?.($e));We&&(Ae={ref:ke(We),deliveryToken:qe,outputFile:re.outputFile,cardId:K});}let be=Tn({cbk:j.callbackToken,rg:e.value,br:ke(e),cid:K,b:re.bindTo,d:re.outputFile,cs:void 0,rqt:j.rqt,...Ae?{dt:Ae.deliveryToken}:{}}),Fe=await t.dispatchExecution(Ge,{source_def:re,base_ref:ke(e),callback:n.createCallback(be),...Ae?{output:Ae}:{}});Fe.dispatched||await l({type:"task-failed",taskName:K,error:Fe.error??"dispatch failed",timestamp:Qe()});}});}async function te(){try{let v=async()=>{let L=await c(),{events:D}=await d().readEntriesAfterCursor(L.lastDrainedJournalId);D.length>0&&await X();},g=await vn(t.lock,W,v);return _e({ran:g!==!1})}catch(v){return Ee(v)}}async function ie(){return i||(i=te().finally(()=>{i=null;}),i)}async function X(){let v=await S().readQueueStoreRef();if(!v)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let g=t.queueStorageForRef(v,"process-accumulated");g.enqueueIfAbsent?await g.enqueueIfAbsent({boardRef:ke(e)},`process-accumulated:${ke(e)}`):await g.enqueue({boardRef:ke(e)}),await t.requestProcessAccumulated?.();}async function ee(){let v=await S().readQueueStoreRef();if(!v)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let g=t.queueStorageForRef(v,"process-accumulated");for(;;){let L=await g.lease({max:64,visibilityMs:1e3});if(L.length<=0)return;for(let D of L)await g.ack(D.id,D.leaseToken);if(L.length<64)return}}function ne(){X();}return {async init(v){try{let g=v.params?.cardStoreRef;if(!g)return ye("init requires params.cardStoreRef");if(u=v.params?.boardRuntimeStoreRef,!u)return ye("init requires params.boardRuntimeStoreRef");let L=v.params?.outputsStoreRef;if(!L)return ye("init requires params.outputsStoreRef");let D=v.params?.queueStoreRef;if(!D)return ye("init requires params.queueStoreRef");let H=v.params?.fetchedSourcesStoreRef;if(!H)return ye("init requires params.fetchedSourcesStoreRef");if(p=v.params?.scratchStoreRef,!p)return ye("init requires params.scratchStoreRef");let w=v.params?.chatStoreRef;if(!w)return ye("init requires params.chatStoreRef");let b=v.params?.artifactsStoreRef;if(!b)return ye("init requires params.artifactsStoreRef");await F()||await h({lastDrainedJournalId:"",graph:yt(St(Ft)),runtimeByCardId:{}},null);let q=S();return await q.writeBoardRuntimeStoreRef(u),await q.writeCardStoreRef(g),await q.writeOutputsStoreRef(L),await q.writeQueueStoreRef(D),await q.writeFetchedSourcesStoreRef(H),await q.writeChatStoreRef(w),await q.writeArtifactsStoreRef(b),await(await x()).writeStatusSnapshot(Rt(s,ht((await c()).graph))),_e()}catch(g){return Ee(g)}},async status(v){try{let g=await x(),L=await g.readStatusSnapshot();return L||(L=Rt(s,ht((await c()).graph)),await g.writeStatusSnapshot(L)),_e(L)}catch(g){return Ee(g)}},async getCardStoreRef(v){try{let g=await S().readCardStoreRef();return g?_e({storeRef:g}):ye(`Board at ${e.value} has no card store configured`)}catch(g){return Ee(g)}},async getBoardRuntimeStoreRef(v){try{return _e({storeRef:u??null})}catch(g){return Ee(g)}},async getOutputsStoreRef(v){try{let g=await S().readOutputsStoreRef();return g?_e({storeRef:g}):ye(`Board at ${e.value} has no outputs store configured`)}catch(g){return Ee(g)}},async getScratchStoreRef(v){try{return _e({storeRef:p??null})}catch(g){return Ee(g)}},async getChatStoreRef(v){try{return _e({storeRef:await S().readChatStoreRef()})}catch(g){return Ee(g)}},async getArtifactsStoreRef(v){try{return _e({storeRef:await S().readArtifactsStoreRef()})}catch(g){return Ee(g)}},async getFetchedSourcesStoreRef(v){try{return _e({storeRef:await S().readFetchedSourcesStoreRef()})}catch(g){return Ee(g)}},async getConfig(v){try{let g=v.params?.key;if(!g)return ye("getConfig requires params.key");let L=S(),D;switch(g){case "task-executor":D=T??null;break;case "chat-handler-flow":D=E??null;break;case "board-runtime-store-ref":D=await L.readBoardRuntimeStoreRef();break;case "card-store-ref":D=await L.readCardStoreRef();break;case "outputs-store-ref":D=await L.readOutputsStoreRef();break;case "scratch-store-ref":D=p??null;break;case "chat-store-ref":D=await L.readChatStoreRef();break;case "artifacts-store-ref":D=await L.readArtifactsStoreRef();break;case "fetched-sources-store-ref":D=await L.readFetchedSourcesStoreRef();break;default:return ye(`getConfig: unknown key "${g}"`)}return _e({value:D})}catch(g){return Ee(g)}},async getOutputsDataObject(v){try{let g=v.params?.key;return g?_e(await(await x()).readDataObject(g)):ye("getOutputsDataObject requires params.key")}catch(g){return Ee(g)}},async getAllOutputsDataObjects(v){try{return _e(await(await x()).readAllDataObjects())}catch(g){return Ee(g)}},async getOutputsComputedValues(v){try{let g=v.params?.key;return g?_e(await(await x()).readComputedValues(g)):ye("getOutputsComputedValues requires params.key")}catch(g){return Ee(g)}},async getAllOutputsComputedValues(v){try{return _e(await(await x()).readAllComputedValues())}catch(g){return Ee(g)}},async getOutputsFetchedSources(v){try{let g=v.params?.key;if(!g)return ye("getOutputsFetchedSources requires params.key");let L=await(await $()).listSources(g),D={};for(let H of L)D[H]=await J(`${g}/${H}`);return _e(D)}catch(g){return Ee(g)}},async getAllOutputsFetchedSources(v){try{let g=await $(),L=await(await _()).listKeys(),D=new Set;for(let w of L){let b=w.indexOf("/");b>0&&!w.includes("/.staged/")&&D.add(w.slice(0,b));}let H={};for(let w of D){let b=await g.listSources(w);if(b.length!==0){H[w]={};for(let q of b)H[w][q]=await J(`${w}/${q}`);}}return _e(H)}catch(g){return Ee(g)}},async addCardFiles(v){try{let g=v.params?.cardId;if(!g)return ye("addCardFiles requires params.cardId");let L=await A(),D=await L.readCard(g);if(!D)return ye(`card "${g}" not found`);let H=v.body,w=Array.isArray(H)?H:H&&typeof H=="object"&&Array.isArray(H.files)?H.files:H!=null?[H]:null;if(!w||w.length===0)return ye("addCardFiles requires a file metadata object, array, or body.files array");let b=D.card_data&&typeof D.card_data=="object"&&!Array.isArray(D.card_data)?D.card_data:{},q=Array.isArray(b.files)?b.files:[],U=[...q,...w],V=w.map((ae,fe)=>({idx:q.length+fe,entry:ae}));await L.writeCard(g,{...D,card_data:{...b,files:U}});let Z=await this.cardRefreshedNotify({params:{cardId:g}});return Z.status!=="success"?Z:_e({cardId:g,files_added:V,notified:!0})}catch(g){return Ee(g)}},async cardRefreshedNotify(v){try{let g=v.params?.cardId;if(!g)return ye("cardRefreshedNotify requires params.cardId");let L=await(await A()).readCard(g);return L?(await C([{kind:"card_refreshed",cardId:g,card:L}]),_e({cardId:g,notified:!0})):ye(`Card "${g}" not found in board at ${e.value}`)}catch(g){return Ee(g)}},async removeCard(v){try{let g=v.params?.id;if(!g)return ye("removeCard requires params.id");try{await t.kvStorage("card-upsert").delete(g);}catch{}return await l({type:"task-removal",taskName:g,timestamp:Qe()}),ne(),_e()}catch(g){return Ee(g)}},async retrigger(v){try{let g=v.params?.id;return g?(await l({type:"task-restart",taskName:g,timestamp:Qe()}),ne(),_e()):ye("retrigger requires params.id")}catch(g){return Ee(g)}},async processAccumulatedEvents(v){return await ee(),ie()},async upsertCard(v){try{let g=v.params?.cardId,L=v.params?.all,D=!!v.params?.restart;if(!g&&!L)return ye("upsertCard requires --card-id <id> or --all");let H=await A(),w=L?(await H.readAllCards()).map(q=>q.id):[g];for(let q of w)if(!await H.readCard(q))return ye(`Card "${q}" not found in board at ${e.value}`);let b=t.kvStorage("card-upsert");for(let q of w){let U=await H.readCard(q);if(!U)continue;let V=rr(U),Z=t.hashFn(V),ae=await b.read(q),fe=ae?.taskConfigHash!==Z;if(!(!fe&&!D)){if(fe){let we=ae?.blobRef??await H.readCardKey(q)??q;await l({type:"task-upsert",taskName:q,taskConfig:V,timestamp:Qe()}),await b.write(q,{blobRef:we,taskConfigHash:Z,updatedAt:Qe()});}D&&await l({type:"task-restart",taskName:q,timestamp:Qe()});}}return ne(),_e()}catch(g){return Ee(g)}},async taskFailed(v){try{let g=v.params?.token;if(!g)return ye("taskFailed requires params.token");let L=v.params?.error??"unknown error",D=cr(g);return D?(await l({type:"task-failed",taskName:D.taskName,error:L,timestamp:Qe()}),ne(),_e()):ye("Invalid callback token")}catch(g){return Ee(g)}},async taskProgress(v){try{let g=v.params?.token;if(!g)return ye("taskProgress requires params.token");let L=(v.body??{}).update??{},D=cr(g);return D?(await l({type:"task-progress",taskName:D.taskName,update:L,timestamp:Qe()}),ne(),_e()):ye("Invalid callback token")}catch(g){return Ee(g)}},async sourceDataFetched(v){try{let g=v.params?.token,L=v.params?.ref;if(!g)return ye("sourceDataFetched requires params.token");if(!L)return ye("sourceDataFetched requires params.ref");let D=Pn(g);if(!D)return ye("Invalid source token");let H=await $(),w=D.dt||t.genId();D.dt||await H.ingestSourceDataStaged(D.cid,D.d,at(L),w);let b=cr(D.cbk);return b?(await l({type:"task-progress",taskName:b.taskName,update:{bindTo:D.b,outputFile:D.d,fetchedAt:Qe(),deliveryToken:w,sourceChecksum:D.cs,rqt:D.rqt},timestamp:Qe()}),ne(),_e()):ye("Invalid callback token embedded in source token")}catch(g){return Ee(g)}},async sourceDataFetchFailure(v){try{let g=v.params?.token,L=v.params?.reason??"unknown";if(!g)return ye("sourceDataFetchFailure requires params.token");let D=Pn(g);if(!D)return ye("Invalid source token");let H=cr(D.cbk);return H?(await l({type:"task-progress",taskName:H.taskName,update:{bindTo:D.b,outputFile:D.d,failure:!0,reason:L,sourceChecksum:D.cs,rqt:D.rqt},timestamp:Qe()}),ne(),_e()):ye("Invalid callback token embedded in source token")}catch(g){return Ee(g)}}}}function Ir(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function Go(e){return {...Ir(e),leaseToken:e.leaseToken,leaseExpiresAt:e.leaseExpiresAt}}function Wo(e){return {...Ir(e),reason:e.reason}}function Tr(e){return {enqueueRequest(t){return e.enqueue(t).id},enqueueRequestIfAbsent:e.enqueueIfAbsent?(t,r)=>{let n=e.enqueueIfAbsent(t,r);return n?n.id:null}:void 0,leaseRequests(t){return e.lease(t).map(Go)},ackRequest(t,r){return e.ack(t,r)},nackRequest(t,r,n){return e.nack(t,r,n)},peekActive(){return e.peekActive().map(Ir)},peekDeadLetter(){return e.peekDeadLetter().map(Wo)}}}function Fn(){return new Date().toISOString()}function Bn(e){return new TextEncoder().encode(e).byteLength}function Qo(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function On(e){function t(r){let n=e.stat?Qo(e.stat(r)):null;if(n)return n;if(!e.exists(r))return null;let o=e.read(r);return o===null?{key:r}:{key:r,size:Bn(o)}}return {exists(r){return e.exists(r)},putText(r,n,o="text/plain; charset=utf-8"){e.write(r,n);let s=t(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??Fn(),s.size=s.size??Bn(n),s},putBytes(r,n,o="application/octet-stream"){if(e.writeBytes)e.writeBytes(r,n);else {let i=JSON.stringify({__kind:"bytes-array",data:[...n]});e.write(r,i);}let s=t(r)??{key:r};return s.contentType=o,s.updatedAt=s.updatedAt??Fn(),s.size=s.size??n.byteLength,s},getText(r){let n=e.read(r);if(n===null){if(!e.readBytes)return null;let o=e.readBytes(r);return o===null?null:Buffer.from(o).toString("utf-8")}try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new TextDecoder("utf-8").decode(new Uint8Array(o.data))}catch{}return n},getBytes(r){if(e.readBytes){let o=e.readBytes(r);if(o!==null)return o}let n=e.read(r);if(n===null)return null;try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new Uint8Array(o.data)}catch{}return new TextEncoder().encode(n)},head:t,list(r=""){return e.listKeys(r).map(n=>t(n)??{key:n}).sort((n,o)=>n.key.localeCompare(o.key))},remove(r){e.remove(r);}}}function qn(){function e(o,s){if(!Array.isArray(o))return [];let i=[];for(let u of o){if(!u||typeof u!="object")continue;let p=u;typeof p.stored_name=="string"&&i.push({name:typeof p.name=="string"?p.name:p.stored_name,stored_name:p.stored_name,size:typeof p.size=="number"&&Number.isFinite(p.size)?p.size:null,mime_type:typeof p.mime_type=="string"?p.mime_type:null,uploaded_at:typeof p.uploaded_at=="string"?p.uploaded_at:s||null,chat:p.chat===true});}return i}function t(o){return !o||typeof o!="object"?[]:e(o.files,void 0)}function r(o,s){let i=t(o);if(s.length===0)return o.files=i,i;let u=new Set(i.map(p=>p.stored_name));for(let p of s)u.has(p.stored_name)||(i.push(p),u.add(p.stored_name));return o.files=i,i}function n(o,s,i){let u=t(o);if(!Number.isInteger(s)||s<0||s>=u.length)return {ok:false,reason:"index_out_of_range"};let p=u[s];return !p||!p.stored_name?{ok:false,reason:"missing_stored_name"}:i&&i!==p.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:p}}return {read:t,normalizeIncoming:e,merge:r,resolve:n}}function jn(e){function t(y){let C=typeof y=="number"?y:Number(y);return Number.isInteger(C)&&C>0?C:null}function r(y,C){let S=C;for(let R=y.length-1;R>=0;R-=1)if(y[R]?.role==="user"&&(S-=1,S===0))return y.slice(R);return y}function n(y){return y.some(C=>typeof C?.turn=="string"&&C.turn!=="")}function o(y,C){if(C<=0)return [];if(!n(y))return r(y,C);let S=new Map,R=[];for(let x of y){let A=typeof x?.turn=="string"?x.turn:"";S.has(A)||(S.set(A,[]),R.push(A)),S.get(A).push(x);}return R.slice(Math.max(0,R.length-C)).flatMap(x=>S.get(x)??[])}function s(y){return {status:"success",data:y}}function i(y){return {status:"fail",error:y}}function u(y){return {status:"error",error:y instanceof Error?y.message:String(y)}}async function p(y,C="command envelope"){let S=typeof y.cardId=="string"?y.cardId:void 0;if(!y.command)return i(`chat-store: ${C} missing "command"`);if(!S)return i(`chat-store: ${C} missing "cardId"`);if(y.command==="append")return await E.append({params:{cardId:S},body:{role:y.role,text:y.text,files:y.files,turn:y.turn}});if(y.command==="read-all")return await E.readAll({params:{cardId:S},body:{lastUserTurns:y.lastUserTurns,tailTurns:y.tailTurns,turnId:y.turnId,allTurns:y.allTurns,tailTurnsBeforeId:y.tailTurnsBeforeId}});if(y.command==="read-after")return await E.readAfter({params:{cardId:S},body:{cursor:y.cursor??null}});if(y.command==="clear")return await E.clear({params:{cardId:S}});if(y.command==="set-processing")return await E.setProcessing({params:{cardId:S},body:{active:y.active}});if(y.command==="is-processing")return await E.isProcessing({params:{cardId:S}});if(y.command==="get-config")return await E.getConfig({params:{cardId:S}});if(y.command==="set-config"){let{command:R,cardId:I,...x}=y;return await E.setConfig({params:{cardId:S},body:x})}return i(`chat-store: unknown command "${String(y.command)}"`)}async function T(y){if(!Array.isArray(y.commands)||y.commands.length===0)return i('chat-store: command envelope must include a non-empty "commands" array');let C=[];for(let S=0;S<y.commands.length;S+=1){let R=y.commands[S];if(!R||typeof R!="object"||Array.isArray(R))return i(`chat-store: command envelope entry ${S} must be an object`);let I={cardId:y.cardId,...R},x=await p(I,`command envelope entry ${S}`);if(x.status!=="success")return x;C.push({index:S,command:String(I.command),data:x.data});}return s({results:C})}let E={async append(y){try{let C=y.params?.cardId;if(!C)return i("append requires params.cardId");let S=y.body??{},R=typeof S.role=="string"?S.role:"",I=typeof S.text=="string"?S.text:"",x=Array.isArray(S.files)?S.files:[],A=typeof S.turn=="string"?S.turn:"";if(!R)return i("append requires body.role");let F=await e.append(C,R,I,x,A);return s({id:F})}catch(C){return u(C)}},async readAll(y){try{let C=y.params?.cardId;if(!C)return i("readAll requires params.cardId");let S=y.body??{},R=typeof S.turnId=="string"?S.turnId:"",I=S.allTurns===!0,x=typeof S.tailTurnsBeforeId=="string"?S.tailTurnsBeforeId:"",A=S.tailTurns===void 0?S.lastUserTurns:S.tailTurns,F=A===void 0?I||R?void 0:1:t(A);if(A!==void 0&&F===null)return i("readAll requires body.tailTurns (positive integer)");let c=await e.readAll(C),h=c.filter(d=>!R||String(d.turn||"")===R);if(x){let d=F;if(typeof d!="number"||!Number.isInteger(d)||d<=0)return i("readAll requires body.tailTurns (positive integer) when body.tailTurnsBeforeId is provided");let f=new Map,l=[];for(let J of c){let W=String(J.turn||"");f.has(W)||(f.set(W,[]),l.push(W)),f.get(W).push(J);}let k=l.findIndex(J=>J===x),_=Math.max(0,k-d);return h=(k===-1?[]:l.slice(_,k)).flatMap(J=>f.get(J)??[]),s({records:h})}return s(typeof F=="number"?{records:o(h,F)}:{records:h})}catch(C){return u(C)}},async readAfter(y){try{let C=y.params?.cardId;if(!C)return i("readAfter requires params.cardId");let R=(y.body??{}).cursor??null;return s(await e.readAfter(C,R))}catch(C){return u(C)}},async clear(y){try{let C=y.params?.cardId;return C?(await e.clear(C),s({ok:!0})):i("clear requires params.cardId")}catch(C){return u(C)}},async setProcessing(y){try{let C=y.params?.cardId;if(!C)return i("setProcessing requires params.cardId");let S=y.body??{};return typeof S.active!="boolean"?i("setProcessing requires body.active (boolean)"):(await e.setProcessing(C,S.active),s({ok:!0}))}catch(C){return u(C)}},async isProcessing(y){try{let C=y.params?.cardId;return C?s({active:await e.isProcessing(C)}):i("isProcessing requires params.cardId")}catch(C){return u(C)}},async getConfig(y){try{let C=y.params?.cardId;return C?s({config:await e.getConfig(C)}):i("getConfig requires params.cardId")}catch(C){return u(C)}},async setConfig(y){try{let C=y.params?.cardId;if(!C)return i("setConfig requires params.cardId");let S=y.body??{};return await e.setConfig(C,S),s({ok:!0})}catch(C){return u(C)}},run:p,runBatch:T};return E}function Ln(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Pr(e){if(!e||typeof e!="object")return false;let t=e.summary;return !t||typeof t!="object"?false:Number(t.card_count||0)>0}function _r(e,t){if(!t||typeof t!="object")return;let r=t;if(r.kind==="notification-batch"&&Array.isArray(r.notifications)){for(let n of r.notifications)_r(e,n);return}r.kind==="status"&&Pr(r.status)&&(e.status=r.status),r.kind==="computed_values"&&r.cardId&&(e.computedValues[r.cardId]=r.values),r.kind==="data_object"&&r.key&&(e.dataObjects[r.key]=r.payload),r.kind==="card_refreshed"&&r.cardId&&(e.cards[r.cardId]=r.card),r.kind==="card_removed"&&r.cardId&&(delete e.cards[r.cardId],delete e.computedValues[r.cardId]);}function Mn(e){let t=new Map,r=new Map,n=new Map,o=0,s=null;function i(d){let f=JSON.stringify(d);return o++,`id: ${o}
2
2
  data: ${f}
3
3
 
4
- `}function u(d){let f=d;try{f.flushHeaders?.();}catch{}try{f.flush?.();}catch{}try{f.socket?.setNoDelay?.(!0);}catch{}try{f.socket?.uncork?.();}catch{}}function p(d,f){let l=t.get(d);if(l&&!(f&&l.res!==f)){t.delete(d),I();try{e.onSseClientDisconnected?.(d);}catch{}try{l.res.end();}catch{}}}function T(d,f,l){let k=t.get(d);k&&p(d,k.res),t.set(d,{res:f,subscribedChatCardIds:l??new Set});}function E(d,f){let l=t.get(d);if(!l)return;let k=i(f);try{l.res.write(k),u(l.res);}catch{p(d,l.res);}}function y(){let d=new Set;for(let f of t.values())for(let l of f.subscribedChatCardIds)d.add(l);return Array.from(d)}async function C(d){let f=r.has(d)?r.get(d):null,{cursor:l}=await e.readChatAfter(d,f),k=await e.getChatProcessing(d),_=k!==(n.get(d)??false),$=l!==f;return $&&r.set(d,l),n.set(d,k),$||_}async function S(d,f){let l=await e.readChatRecords(d),k=Date.now();return {kind:"card_chats",cardId:d,sentAt:new Date(k).toISOString(),sentAtMs:k,messages:l.map(_=>({role:String(_.role||"system"),text:String(_.text||""),files:Array.isArray(_.files)?_.files:[],...typeof _.turn=="string"&&_.turn?{turn:_.turn}:{}})),receiving:f,processing:await e.getChatProcessing(d)}}async function R(d,f=true){let l={kind:"notification-batch",notifications:[await S(d,f)]};for(let[k,_]of t.entries())_.subscribedChatCardIds.has(d)&&E(k,l);}function I(){y().length>0||(s&&(clearInterval(s),s=null),r.clear(),n.clear());}function x(){if(s)return;let d=async()=>{let f=y();if(f.length===0){I();return}let l=new Set(f);for(let k of Array.from(r.keys()))l.has(k)||r.delete(k);for(let k of Array.from(n.keys()))l.has(k)||n.delete(k);for(let k of f)await C(k)&&await R(k,true);};d(),s=setInterval(()=>{d();},1e3);}async function A(d,f){let l=t.get(d);if(!l)return false;l.subscribedChatCardIds.add(f);let{cursor:k}=await e.readChatAfter(f,null);return r.set(f,k),n.set(f,await e.getChatProcessing(f)),x(),E(d,{kind:"notification-batch",notifications:[await S(f,true)]}),true}function F(d,f){let l=t.get(d);return l?(l.subscribedChatCardIds.delete(f),y().includes(f)||(r.delete(f),n.delete(f)),I(),true):false}function c(d){if(!d||typeof d!="object")return false;let f=d.kind;return f==="card_chats"||f==="chat_messages"}function h(d){if(!d||d.length===0)return;let f=[],l=new Set;for(let k of d)c(k)&&typeof k.cardId=="string"?l.add(String(k.cardId)):f.push(k);if(f.length>0){let k={kind:"notification-batch",notifications:f};for(let _ of t.keys())E(_,k);}for(let k of l)R(k,true);}return {size:()=>t.size,has:d=>t.has(d),get:d=>t.get(d),buildFrame:i,flushTransport:u,register:T,disconnect:p,writeFrame:E,subscribeChat:A,unsubscribeChat:F,broadcastNotificationBatch:h,broadcastCardChats:R}}function Er(e,t){if(e?.status==="success")return Object.prototype.hasOwnProperty.call(e,"data")?e.data:void 0;throw e?.status==="fail"||e?.status==="error"?Object.assign(new Error(e.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function Fr(e,t){return Er(await e,t)}function Br(e){let t=de(e,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let r=t.split(".");if(!(r.length>=2&&r[0]==="chat"&&r.every(o=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(o))))throw Object.assign(new Error("MCP tool only supports card private keys under chat.*"),{statusCode:400});return t}function Or(e,t){let r=e.__private;for(let n of t.split(".")){if(!r||typeof r!="object"||Array.isArray(r)||!Object.prototype.hasOwnProperty.call(r,n))return {exists:false,value:null};r=r[n];}return {exists:true,value:r}}function Dn(e){let{boardId:t,bootstrapBoard:r,sseHub:n,onChannelSubscribed:o,onChannelUnsubscribed:s,getMcpFacade:i,getMcpCardStoreFacade:u}=e;function p(c){let h=de(c,"board_id");if(!h)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(h!==t)throw Object.assign(new Error(`Unknown board_id: ${h}`),{statusCode:400})}function T(c){let h=de(c,"client_id");if(!h)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return h}function E(c){p(c);let h=T(c),d=de(c,"channel_name"),f=de(c,"card_id")||void 0;if(!d)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:h,channelName:d,...f?{cardId:f}:{}}}function y(c){p(c);let h=de(c,"card_id");if(!h)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:h}}async function C(c){await r();let{cardId:h}=y(c),d=T(c);if(!await n.subscribeChat(d,h))throw Object.assign(new Error(`SSE client not connected: ${d}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:h,clientId:d,subscribed:true}}}async function S(c){await r();let{cardId:h}=y(c),d=T(c);if(!n.unsubscribeChat(d,h))throw Object.assign(new Error(`SSE client not connected: ${d}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:h,clientId:d,subscribed:false}}}async function R(c,h){await r();let{clientId:d,channelName:f,cardId:l}=E(c);if(!n.has(d))throw Object.assign(new Error(`SSE client not connected: ${d}`),{statusCode:404});return h?o?.(d,f,l?{cardId:l}:{}):s?.(d,f,l?{cardId:l}:{}),{status:"success",data:{boardId:t,clientId:d,channelName:f,subscribed:h,...l?{cardId:l}:{}}}}async function I(c,h){let{cardId:d}=y(c);return await i().setChatProcessing({cardId:d,active:h}),{status:"success",data:{boardId:t,cardId:d,active:h}}}async function x(c){let{cardId:h}=y(c),d=await i().getChatProcessing({cardId:h});return {status:"success",data:{boardId:t,cardId:h,active:d.active}}}async function A(c){let{cardId:h}=y(c),d=Br(c);if(!Object.prototype.hasOwnProperty.call(c,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(d.split(".").includes("visible_controlplane_only")){let f=await Fr(u().get({params:{id:h}}),"cardStore.get"),l=Array.isArray(f.cards)&&f.cards.length>0&&typeof f.cards[0]=="object"&&!Array.isArray(f.cards[0])?f.cards[0]:null,k=l?Or(l,"visible_controlplane_only").value:void 0;if(c.value!==k)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:h,key:d}}}return Er(await u().patch({params:{id:h,path:`__private.${d}`},body:{value:c.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:h,key:d}}}async function F(c){let{cardId:h}=y(c),d=Br(c),f=await Fr(u().get({params:{id:h}}),"cardStore.get"),l=Array.isArray(f.cards)&&f.cards.length>0&&f.cards[0]&&typeof f.cards[0]=="object"&&!Array.isArray(f.cards[0])?f.cards[0]:null;if(!l)throw Object.assign(new Error(`Card "${h}" not found`),{statusCode:404});let k=Or(l,d);return {status:"success",data:{boardId:t,cardId:h,key:d,exists:k.exists,value:k.value}}}return {requireCardArgs:y,subscribeChat:C,unsubscribeChat:S,watchChannel:R,setChatProcessing:I,getChatProcessing:x,setCardMeta:A,getCardMeta:F}}function Nn(e){let{boardId:t,boardContexts:r,readCardDefinitions:n,readChatRecords:o,getChatProcessing:s}=e;async function i(){let E=(await Promise.all(r.map(async I=>{try{let x=I.boardAdapter.kvStorageForRef(I.outputsStoreRef),A=await Promise.resolve(x.read("status"));if(A!=null)return A}catch{}return I.notification.status}))).filter(Boolean);if(E.length===0)return null;if(E.length===1)return E[0];let y=[],C=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],S={};for(let I of C)S[I]=0;for(let I of E){let x=I,A=Array.isArray(x.cards)?x.cards:[];y.push(...A);for(let F of C)S[F]+=Number(x?.summary?.[F]||0);}let R=E[0];return {...R,cards:y,summary:{...R.summary||{},card_count:y.length,...S}}}async function u(){let E={},y=async C=>{try{let S=await C.boardOps.getAllOutputsComputedValues({});if(S.status==="success"&&S.data&&typeof S.data=="object"){for(let[R,I]of Object.entries(S.data)){let x=C.notification.cards[R];E[R]={schema_version:"v1",card_id:R,card_data:x?.card_data??{},computed_values:I??{}};}return}}catch{}for(let[S,R]of Object.entries(C.notification.computedValues)){let I=C.notification.cards[S];E[S]={schema_version:"v1",card_id:S,card_data:I?.card_data??{},computed_values:R??{}};}};for(let C of r)await y(C);return E}async function p(){let E={};for(let y of r){try{let C=await y.boardOps.getAllOutputsDataObjects({});if(C.status==="success"&&C.data&&typeof C.data=="object"){Object.assign(E,C.data);continue}}catch{}Object.assign(E,y.notification.dataObjects||{});}return E}async function T(){let E=await n(),y=await u(),C=await p(),S={};for(let I of E){if(!I?.id)continue;let x=I.id,A=y[x]||{},F={...A.card_data&&typeof A.card_data=="object"?A.card_data:I.card_data&&typeof I.card_data=="object"?I.card_data:{}};S[x]={schema_version:A.schema_version||"v1",card_id:A.card_id||x,card_data:F,computed_values:A.computed_values&&typeof A.computed_values=="object"?A.computed_values:{}};}let R={};for(let I of E){if(!I?.id)continue;let x=I.id;try{let A=await o(x),F=await s(x);(A.length>0||F)&&(R[x]={messages:A.map(c=>({role:String(c.role||"system"),text:String(c.text||""),files:Array.isArray(c.files)?c.files:[]})),receiving:!1,processing:F});}catch{}}return {boardId:t,cardDefinitions:E,statusSnapshot:await i(),dataObjectsByToken:C,cardRuntimeById:S,cardChatsByCardId:R}}return {readStatusSnapshot:i,readCardRuntimeArtifacts:u,readDataObjectsByToken:p,buildPublishedRuntimePayload:T}}function zo(e){let t=String(e||"").trim();if(!t)return "upload.bin";let r=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (r>=0?t.slice(r+1):t)||"upload.bin"}function $n(e){let{safeCardId:t,artifactsStores:r,cardFileMetadataStore:n,readCardFromStore:o,updateCardLocalOnly:s,writeChatRecord:i}=e;async function u(E){let y=[];try{let C=await o(E);if(!C)return y;let S=n().read(C.card_data&&typeof C.card_data=="object"?C.card_data:null);for(let R of S)y.push(String(R.stored_name??""));}catch{}return y}async function p(E,y,C,S){let R=t(E),I=r(E),x=zo(y),A=await u(E),c=`${String(A.length+1).padStart(3,"0")}-${x}`.slice(-36);if(!I.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${E}`),{statusCode:500});return await I.files.putBytes(`${R}/${c}`,new Uint8Array(S),C||"application/octet-stream"),{name:x,stored_name:c,size:S.length,mime_type:C||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function T(E,y,C,S,R){if(!S.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let I=R?.inChat===true,x=await p(E,y,C,S),A=null;if(await s(E,F=>{let c=new Date().toISOString(),h=F.card_data&&typeof F.card_data=="object"?F.card_data:{};F.card_data=h;let d=n().normalizeIncoming([{name:x.name,stored_name:x.stored_name,size:x.size,mime_type:x.mime_type,uploaded_at:x.uploaded_at||c,chat:I}],c);return A=n().merge(h,d).findIndex(l=>l.stored_name===x.stored_name),F}),I&&R?.suppressChatRecordWrite!==true){let F=typeof A=="number"&&A>=0?` #${A}`:"";await i(E,"system",`file uploaded: ${x.name} as ${x.stored_name}${F}`,[],R?.turnId??"");}return {ok:true,file:{...x,...typeof A=="number"&&A>=0?{file_idx:A}:{},chat:I},...typeof A=="number"&&A>=0?{file_idx:A}:{}}}return {uploadCardFile:T,readCardStoredFileNames:u}}function Un(e){return {"discover.source-kinds":()=>e.discoverSourceKinds(),"inspect.board-runtime-status":()=>e.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>e.inspectCardDefinitionAndRuntime({cardId:de(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let r=it(t,"tail_turns"),n=it(t,"tail"),o=de(t,"turn_id"),s=t.all_turns===true,i=de(t,"tail_turns_before_id");return e.inspectChatMessagesOnCards({cardId:de(t,"card_id"),...r!==void 0?{lastUserTurns:r}:{},...n!==void 0?{tail:n}:{},...o?{turnId:o}:{},...s?{allTurns:true}:{},...i?{tailTurnsBeforeId:i}:{}})},"inspect.file-contents":t=>e.inspectFileContents({cardId:de(t,"card_id"),fileIdx:Number(it(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>e.preflightValidateCandidateCardDefinition({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>e.preflightMaterializeCandidateCard({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content"),mockRequires:ft(t,"mock_requires","mock_requires"),mockFetchedSources:ft(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>e.preflightProbeSingleSourceInCandidateCard({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content"),mockProjections:ut(t,"mock_projections"),sourceIdx:Mt(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>e.preflightRunSingleSourceInCandidateCard({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content"),mockProjections:ut(t,"mock_projections"),sourceIdx:Mt(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>e.preflightRunSingleSourceInLiveCard({cardId:de(t,"card_id"),sourceIdx:Mt(t,"source_idx","source_idx"),mockRequires:ft(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>e.preflightRunOneCycleWithCandidateCard({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content"),mockRequires:ut(t,"mock_requires")}),"manage.read-card":t=>e.manageReadCard({cardId:de(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let r=de(t,"turn_id");if(!r)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return e.manageAddChatEntryAndAnyAttachments({cardId:de(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...r?{turn:r}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"manage.upsert-card":t=>e.manageUpsertCard({cardId:de(t,"card_id"),candidateCardContent:ut(t,"candidate_card_content")}),"manage.remove-card":t=>e.manageRemoveCard({cardId:de(t,"card_id")})}}function Vn(e){return {"webhook.process-accumulated":()=>e.webhookProcessAccumulated(),"webhook.source-fetch-done":t=>e.webhookSourceFetchDone({token:de(t,"token"),ref:de(t,"ref")}),"webhook.source-fetch-failed":t=>e.webhookSourceFetchFailed({token:de(t,"token"),reason:de(t,"reason")})}}function Kn(e){let{boardId:t,uploadCardFile:r,getMcpFacade:n,controlplane:o}=e;function s(u,p){let T=de(u,"board_id");if(!T)throw Object.assign(new Error(`${p} requires board_id`),{statusCode:400});if(T!==t)throw Object.assign(new Error(`Unknown board_id: ${T}`),{statusCode:400})}function i(u,p){let{cardId:T}=o.requireCardArgs(u),E=de(u,"turn_id");return s(u,p),n().manageAddChatAttachment({cardId:T,role:de(u,"role")||"user",...E?{turn:E}:{},files:[{file_name:de(u,"file_name"),content_type:de(u,"content_type")||"application/octet-stream",...typeof u.text=="string"?{text:u.text}:{},...typeof u.base64=="string"?{base64:u.base64}:{},...Array.isArray(u.bytes)?{bytes:u.bytes}:{}}]})}return {"list-runtime-cards":u=>(s(u,"list-runtime-cards"),n().listRuntimeCards()),"sse.subscribe-chat":u=>o.subscribeChat(u),"sse.unsubscribe-chat":u=>o.unsubscribeChat(u),"sse.watch-channel":u=>o.watchChannel(u,true),"sse.unwatch-channel":u=>o.watchChannel(u,false),"getstate.is-chat-processing":u=>o.getChatProcessing(u),"setstate.chat-processing-started":u=>o.setChatProcessing(u,true),"setstate.chat-processing-done":u=>o.setChatProcessing(u,false),"getstate.card-private":u=>o.getCardMeta(u),"setstate.card-private":u=>o.setCardMeta(u),"manage.upload-card-file":u=>{let p=de(u,"card_id"),T=de(u,"file_name"),E=de(u,"content_type")||"application/octet-stream",y=Vr(u);if(s(u,"manage.upload-card-file"),!p)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!T)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!y)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return r(p,T,E,y,{inChat:false})},"manage.add-chat-attachment":u=>i(u,"manage.add-chat-attachment"),"manage.add-chat-attachement":u=>i(u,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":u=>{let{cardId:p}=o.requireCardArgs(u),T=de(u,"role")||"user",E=de(u,"turn_id");return s(u,"manage.add-chat-entry-and-any-attachments"),n().manageAddChatEntryAndAnyAttachments({cardId:p,role:T,...typeof u.text=="string"?{text:u.text}:{},...E?{turn:E}:{},...Array.isArray(u.files)?{files:u.files}:{}})},"manage.patch-card":u=>{let{cardId:p}=o.requireCardArgs(u);return s(u,"manage.patch-card"),n().managePatchCard({cardId:p,patch:ut(u,"patch")})},"manage.upsert-card":u=>{let{cardId:p}=o.requireCardArgs(u);return s(u,"manage.upsert-card"),n().manageUpsertCard({cardId:p,candidateCardContent:ut(u,"candidate_card_content")})},"manage.remove-card":u=>{let{cardId:p}=o.requireCardArgs(u);return s(u,"manage.remove-card"),n().manageRemoveCard({cardId:p})},"manage.admin-read-card":async u=>{let{cardId:p}=o.requireCardArgs(u);return {status:"success",data:{cards:await n().adminReadCard({cardId:p})}}},"manage.admin-upsert-card":u=>{let p=de(u,"board_id"),T=de(u,"card_id");if(!p)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!T)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(p!==t)throw Object.assign(new Error(`Unknown board_id: ${p}`),{statusCode:400});return n().adminUpsertCard({cardId:T,candidateCardContent:ut(u,"candidate_card_content")})}}}function Ve(e,t){if(e?.status==="success")return Object.prototype.hasOwnProperty.call(e,"data")?e.data:void 0;throw e?.status==="fail"||e?.status==="error"?new Error(e.error||`${t} failed`):new Error(`${t} returned an unexpected response`)}function Hn(e,t){if(e?.status==="success"&&Object.prototype.hasOwnProperty.call(e,"data"))return e.data;throw e?.status==="success"?new Error(`${t} returned success without data`):e?.status==="fail"||e?.status==="error"?new Error(e.error||`${t} failed`):new Error(`${t} returned an unexpected response`)}function z(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}function je(e){return Array.isArray(e)?e:[]}function jr(e,t){if(typeof t!="string"||t.length===0)return;let r=e,n=t;n.startsWith("fetched_sources.")&&(r=z(e).fetched_sources,n=n.slice(16));for(let o of n.split(".")){if(r==null||typeof r!="object")return;r=r[o];}return r}function qr(e,t){let r=z(e.view),n=je(r.elements);return {layout:r.layout,features:r.features,elements:n.map((o,s)=>{let i=z(o),u=z(i.data),p=typeof i.visible=="string"?!!jr(t,i.visible):true,T=typeof u.bind=="string"?u.bind:void 0,E=typeof u.maxRows=="number"?u.maxRows:void 0,y=T?jr(t,T):void 0,C={id:typeof i.id=="string"&&i.id?i.id:`element-${s}`,kind:i.kind,label:i.label,visible:p};return y!==void 0&&(C.resolved=Array.isArray(y)&&typeof E=="number"?y.slice(0,E):y),C})}}function Jn(e,t){let r=typeof e.id=="string"&&e.id?e.id:"card",n=je(e.provides),o=n.length>0?n:[{bindTo:r,ref:"card_data"}],s={};for(let i of o){let u=z(i),p=typeof u.bindTo=="string"?u.bindTo:"",T=typeof u.ref=="string"?u.ref:"";if(!p||!T)continue;let E=jr(t,T);E!==void 0&&(s[p]=E);}return s}function Yo(e){if(typeof e!="string"||!e.trim())return null;let t=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(e.trim());if(!t)return null;let r=Number.parseInt(t[2],10);return !Number.isInteger(r)||r<0?null:r}function Xo(e){return {"card-content":e}}function lr(e){let t={...e};return delete t.__private,t}function fr(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function Zo(e){return typeof structuredClone=="function"?structuredClone(e):JSON.parse(JSON.stringify(e))}function es(e,t){let r=Zo(e);if(!t||Object.keys(t).length===0)return r;function n(o,s,i){let u=String(s||"").split(".").filter(Boolean);if(!u.length)return;let p=o;for(let T=0;T<u.length-1;T+=1){let E=u[T];(!p[E]||typeof p[E]!="object")&&(p[E]={}),p=p[E];}p[u[u.length-1]]=i;}if(t.fieldValues!==void 0&&t.fieldValues!==null){let o=null,s=z(r.view),i=je(s.elements);for(let u of i){let p=z(z(u).data);if(typeof p.writeTo=="string"&&p.writeTo){o=p.writeTo;break}}return o?n(r,o,t.fieldValues):typeof t.fieldValues=="object"&&!Array.isArray(t.fieldValues)&&(r.card_data={...z(r.card_data),...t.fieldValues}),r}if(Array.isArray(t._stagedFiles)&&t._stagedFiles.length>0)return r;for(let[o,s]of Object.entries(t))o!=="_stagedFiles"&&(s!==null&&typeof s=="object"&&!Array.isArray(s)&&r[o]!==null&&typeof r[o]=="object"&&!Array.isArray(r[o])?r[o]={...r[o],...s}:r[o]=s);return r}function Gn(e){return z(e.__private).visible_controlplane_only===true}async function bt(e,t){let r=await nt(e.get({params:{id:t}}),"cardStore.get"),n=Array.isArray(r?.cards)?r.cards:[];if(n.length===0)throw new Error(`Card "${t}" not found`);return n[0]}function Wn(e){let{board:t,nonCore:r,cardStore:n,chatStore:o,processAccumulated:s,sourceFetchDone:i,sourceFetchFailed:u,uploadCardFile:p,buildFileDownloadUrl:T,readFetchedSourceJsonByRef:E}=e;function y(w,b){if(typeof w=="function")return w;throw new Error(`${b} is not configured for this MCP facade`)}async function C(){let w=await nt(n.get({}),"cardStore.get");return Array.isArray(w.cards)?w.cards.map(b=>z(b)):[]}function S(w){if(Array.isArray(w.bytes))return new Uint8Array(w.bytes.map(b=>Math.max(0,Math.min(255,Number(b)||0))));if(typeof w.text=="string")return new TextEncoder().encode(w.text);if(typeof w.base64=="string"){let b=String(w.base64).replace(/-/g,"+").replace(/_/g,"/"),q=b+"=".repeat((4-b.length%4)%4),U=atob(q);return Uint8Array.from(U,V=>V.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function R(){let w=z(await nt(r.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:w.version,commonSourceFields:z(w.commonSourceDefFields),sourceKinds:z(w.sourceKinds)}}async function I(){let w=z(await nt(t.status({}),"status")),b=z(w.summary),q=je(w.cards);return {meta:z(w.meta),summary:{card_count:typeof b.card_count=="number"?b.card_count:0,completed:typeof b.completed=="number"?b.completed:0,eligible:typeof b.eligible=="number"?b.eligible:0,pending:typeof b.pending=="number"?b.pending:0,blocked:typeof b.blocked=="number"?b.blocked:0,in_progress:typeof b.in_progress=="number"?b.in_progress:0,failed:typeof b.failed=="number"?b.failed:0,unresolved:typeof b.unresolved=="number"?b.unresolved:0},cards:q.map(U=>{let V=z(U);return {"card-id":typeof V.name=="string"?V.name:null,status:V.status??null,error:V.error??null,requires:je(V.requires),requires_satisfied:je(V.requires_satisfied),requires_missing:je(V.requires_missing),provides_declared:je(V.provides_declared),provides_runtime:je(V.provides_runtime)}})}}async function x(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let q=z(await nt(t.status({}),"status")),V=je(q.cards).map(z).find(me=>me.name===b);if(!V)throw new Error(`card "${b}" not found in board status`);let Z=z(await bt(n,b));if(Gn(Z))throw Object.assign(new Error(`card "${b}" not found`),{statusCode:404});let ae=lr(Z),fe=je(V.requires_satisfied).filter(me=>typeof me=="string"&&!!me),we=je(V.provides_runtime).filter(me=>typeof me=="string"&&!!me),Pe=Object.fromEntries(await Promise.all(fe.map(async me=>[me,await nt(t.getOutputsDataObject({params:{key:me}}),`getOutputsDataObject(${me})`)]))),Be=Object.fromEntries(await Promise.all(we.map(async me=>[me,await nt(t.getOutputsDataObject({params:{key:me}}),`getOutputsDataObject(${me})`)]))),Se=z(await nt(t.getOutputsComputedValues({params:{key:b}}),"getOutputsComputedValues")),ce=await nt(t.getOutputsFetchedSources({params:{key:b}}),"getOutputsFetchedSources"),Le=je(Z.source_defs).map(z),ve={};for(let me of Le)typeof me.bindTo=="string"&&typeof me.outputFile=="string"&&(ve[me.outputFile]=me.bindTo);let Me={};for(let[me,Ze]of Object.entries(ce)){let Ke=ve[me]??me;if(!E||typeof Ze!="string"){Me[Ke]=null;continue}try{Me[Ke]=E({cardId:b,ref:Ze});}catch{Me[Ke]=null;}}let Ne={card_data:z(Z.card_data),requires:Pe,fetched_sources:Me,computed_values:Se};return {cardId:b,card_status_in_board:V,card_definition_and_static_data:ae,refs_for_fetched_source_files:ce,runtime_data:{requires:Pe,provides:Be,computed_values:Se,rendered_view:qr(Z,Ne)}}}async function A(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("inspectChatMessagesOnCards requires cardId");let q=typeof w.turnId=="string"?w.turnId:"",U=w.allTurns===true,V=typeof w.tailTurnsBeforeId=="string"?w.tailTurnsBeforeId:"",Z=U?void 0:w.lastUserTurns??(q?void 0:1),ae=w.tail,fe={...Z===void 0?{}:{tailTurns:Z},...q?{turnId:q}:{},...U?{allTurns:true}:{},...V?{tailTurnsBeforeId:V}:{}},we=Object.keys(fe).length>0?{params:{cardId:b},body:fe}:{params:{cardId:b}},Pe=Ve(await o.readAll(we),"chatStore.readAll"),Be=z(await bt(n,b)),Se=je(z(Be.card_data).files).map((ve,Me)=>({idx:Me,stored_name:z(ve).stored_name})).filter(ve=>typeof ve.stored_name=="string"&&ve.stored_name.length>0),Le=(Array.isArray(Pe.records)?Pe.records:[]).map(ve=>{let Ne=z(ve.payload),me={...ve},Ze=typeof ve?.role=="string"?ve.role:typeof Ne.role=="string"?String(Ne.role):"",Ke=typeof ve?.text=="string"?ve.text:typeof Ne.text=="string"?String(Ne.text):"";if(Ze==="system"){let Ge=Yo(Ke);if(Ge!==null&&Se.some(m=>m.idx===Ge)){let m=`Retrieve using inspect-file-contents --card-id ${b} --file-idx ${Ge}`;me.retrieval_hint=m,Object.keys(Ne).length>0&&typeof ve.role!="string"&&(me.payload={...Ne,retrieval_hint:m});}}return me});return {cardId:b,messages:typeof ae=="number"&&ae>=0?Le.slice(-ae):Le}}async function F(w){let b=String(w.cardId||"").trim(),q=Number(w.fileIdx);if(!b)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(q)||q<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let U=z(await bt(n,b)),V=je(z(U.card_data).files).map(z);if(q>=V.length)throw new Error(`attachment index ${q} is out of range for card "${b}"`);let Z=V[q],ae=typeof Z.stored_name=="string"?Z.stored_name:null;return {cardId:b,fileIdx:q,downloadUrl:T({cardId:b,fileIdx:q,storedName:ae}),...typeof Z.name=="string"?{name:Z.name}:{},...typeof Z.stored_name=="string"?{stored_name:Z.stored_name}:{},...typeof Z.mime_type=="string"?{mime_type:Z.mime_type}:{},...typeof Z.size=="number"?{size:Z.size}:{},...typeof Z.uploaded_at=="string"?{uploaded_at:Z.uploaded_at}:{}}}async function c(w){return await r.validateCardPreflight({body:Xo(w.candidateCardContent)})}function h(w){if(!w.mockRequires||typeof w.mockRequires!="object"||Array.isArray(w.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!w.mockFetchedSources||typeof w.mockFetchedSources!="object"||Array.isArray(w.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let b=r.evalCardCompute({body:{"card-content":w.candidateCardContent,"mock-requires":w.mockRequires,"mock-fetched-sources":w.mockFetchedSources}});if(b.status!=="success")return b;let q=z(Hn(b,"evalCardCompute")),U=z(w.candidateCardContent),V={card_data:z(U.card_data),requires:z(w.mockRequires),fetched_sources:z(w.mockFetchedSources),computed_values:z(q.computed_values)};return {status:"success",data:{cardId:typeof q.cardId=="string"?q.cardId:typeof U.id=="string"?U.id:"(unknown)",ok:q.ok===true,computed_values:z(q.computed_values),errors:je(q.errors).map(Z=>{let ae=z(Z);return {bindTo:typeof ae.bindTo=="string"?ae.bindTo:"",error:typeof ae.error=="string"?ae.error:""}}),provides_outputs:Jn(U,V),rendered_view:qr(U,V)}}}async function d(w){return await r.probeSourcePreflight({params:{sourceIdx:w.sourceIdx},body:{"card-content":w.candidateCardContent,"mock-projections":w.mockProjections}})}async function f(w){return await r.runSourcePreflight({params:{sourceIdx:w.sourceIdx},body:{"card-content":w.candidateCardContent,"mock-projections":w.mockProjections}})}async function l(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!w.mockRequires||typeof w.mockRequires!="object"||Array.isArray(w.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let q=z(await bt(n,b)),U=je(q.source_defs).filter(Z=>!!Z&&typeof Z=="object"&&!Array.isArray(Z)),V={};if(w.sourceIdx>=0&&w.sourceIdx<U.length){let Z=U[w.sourceIdx],ae=ze.enrichSourcesSync([Z],{card_data:z(q.card_data),requires:w.mockRequires});Array.isArray(ae)&&ae.length>0&&(V=z(ae[0]._projections));}return await r.runSourcePreflight({params:{sourceIdx:w.sourceIdx},body:{"card-content":q,"mock-requires":w.mockRequires,"mock-projections":V}})}async function k(w){let b=z(await nt(r.simulateCardCycle({body:{"card-content":w.candidateCardContent,"mock-requires":w.mockRequires}}),"simulateCardCycle")),q=z(w.candidateCardContent),U=z(b.validation),V=je(b.source_probes),Z=je(b.projection_errors),ae=z(b.fetched_sources),fe=je(b.compute_errors),we=z(b.computed_values),Pe={card_data:z(q.card_data),requires:w.mockRequires,fetched_sources:ae,computed_values:we},Be=[];for(let Se of je(U.issues))typeof Se=="string"&&Se&&Be.push(Se);for(let Se of V){let ce=z(Se),Le=typeof ce.bindTo=="string"?ce.bindTo:"source",ve=typeof ce.error=="string"?ce.error:"";ve&&Be.push(`${Le}: ${ve}`);}for(let Se of Z){let ce=z(Se),Le=typeof ce.bindTo=="string"?ce.bindTo:"source",ve=typeof ce.key=="string"?ce.key:"projection",Me=typeof ce.error=="string"?ce.error:"projection failed";Be.push(`${Le}.${ve}: ${Me}`);}for(let Se of fe){let ce=z(Se),Le=typeof ce.bindTo=="string"?ce.bindTo:"compute",ve=typeof ce.error=="string"?ce.error:"compute failed";Be.push(`${Le}: ${ve}`);}return {status:"success",data:{cardId:typeof b.cardId=="string"?b.cardId:"(unknown)",ok:b.ok===true,issues:Be,provides_outputs:Jn(q,Pe),rendered_view:qr(q,Pe)}}}async function _(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("manageReadCard requires cardId");let q=await nt(n.get({params:{id:b}}),"cardStore.get"),U=Array.isArray(q.cards)?q.cards.map(z):[];if(U.some(Gn))throw Object.assign(new Error(`Card "${b}" not found`),{statusCode:404});return U.map(V=>lr(V))}async function $(w){let b=await Promise.all(je(w.files).map(async q=>{let U=z(q),V=String(U.file_name??U.fileName??U.name??"").trim(),Z=String(U.content_type??U.contentType??"application/octet-stream");if(!V)throw new Error("file entry requires file_name");return await p({cardId:w.cardId,fileName:V,contentType:Z,bytes:S(U),suppressChatRecordWrite:true})}));for(let[q,U]of b.entries()){let V=z(U.file),Z=typeof U.file_idx=="number"&&Number.isInteger(U.file_idx)&&U.file_idx>=0?U.file_idx:q,ae=w.role==="assistant"?`AI generated: ${String(V.name||"")} as ${String(V.stored_name||"")} #${Z}`:`file uploaded: ${String(V.name||"")} as ${String(V.stored_name||"")} #${Z}`;Ve(await o.append({params:{cardId:w.cardId},body:{role:"system",text:ae,files:[],turn:w.turn}}),"chatStore.append(system attachment message)");}return b.map(q=>q.file)}async function J(w){let b=String(w.cardId||"").trim(),q=String(w.role||"user").trim()||"user",U=typeof w.turn=="string"?w.turn:"";if(!b)throw new Error("manageAddChatAttachment requires cardId");let V=await $({cardId:b,role:q,turn:U,files:w.files});return {status:"success",data:{cardId:b,turn:U,files:V}}}async function W(w){let b=String(w.cardId||"").trim(),q=String(w.role||"").trim(),U=typeof w.text=="string"?w.text:"",V=typeof w.turn=="string"?w.turn:"";if(!b)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!q)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(q==="assistant"&&V){let fe=Ve(await o.readAll({params:{cardId:b},body:{turnId:V}}),"chatStore.readAll(existing turn messages)"),we=Array.isArray(fe.records)?fe.records.find(Pe=>Pe.role==="assistant"&&String(Pe.turn||"")===V):void 0;if(we)return {status:"success",data:{cardId:b,id:String(we.id),role:q,turn:V,files:Array.isArray(we.files)?we.files:[]}}}let Z=await $({cardId:b,role:q,turn:V,files:w.files}),ae=Ve(await o.append({params:{cardId:b},body:{role:q,text:U,files:Z,turn:V}}),"chatStore.append");return {status:"success",data:{cardId:b,id:String(ae.id),role:q,turn:V,files:Z}}}async function te(w){let b=String(w.cardId||"").trim(),q=z(w.patch);if(!b)throw new Error("managePatchCard requires cardId");let U=await _({cardId:b}),V=z(U[0]),ae={...es(V,q),...fr(V,"meta")?{meta:V.meta}:{},...fr(V,"__private")?{__private:V.__private}:{}},fe=await n.set({body:ae});Ve(fe,"cardStore.set");let we;try{we=await t.upsertCard({params:{cardId:b,restart:!0}}),Ve(we,"upsertCard");}catch(Be){try{await n.set({body:V});}catch{}throw Be}let Pe=null;try{Pe=await t.cardRefreshedNotify({params:{cardId:b}}),Ve(Pe,"cardRefreshedNotify");}catch{Pe=null;}return {status:"success",data:{validation:null,card_saved:null,board_result:we,refresh_notify:Pe}}}async function ie(w){let b=String(w.cardId||"").trim(),q=z(w.candidateCardContent),U=lr(q);if(!b)throw new Error("manageUpsertCard requires cardId");if(typeof U.id!="string"||!U.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(U.id!==b)throw new Error(`candidateCardContent.id must match cardId (${b})`);let V=await c({candidateCardContent:U}),Z=z(V),ae=z(Z.data);if(Z.status!=="success"||ae.isValid!==true)return {status:"fail",step:"validate",validation:V};let fe=null;try{fe=await bt(n,b);}catch{fe=null;}let we=fe?z(fe):null,Pe={...U,...we&&fr(we,"meta")?{meta:we.meta}:{},...we&&fr(we,"__private")?{__private:we.__private}:{}},Be=await n.set({body:Pe});Ve(Be,"cardStore.set");let Se;try{Se=await t.upsertCard({params:{cardId:b,restart:!0}}),Ve(Se,"upsertCard");}catch(Le){try{fe&&await n.set({body:fe});}catch{}throw Le}let ce=null;try{ce=await t.cardRefreshedNotify({params:{cardId:b}}),Ve(ce,"cardRefreshedNotify");}catch{ce=null;}return {status:"success",data:{validation:V,card_saved:null,board_result:Se,refresh_notify:ce}}}async function X(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("manageRemoveCard requires cardId");let q=await t.removeCard({params:{id:b}});Ve(q,"removeCard");let U=await n.del({params:{id:b}});return Ve(U,"cardStore.del"),{status:"success",data:{board_result:q,store_result:U}}}async function ee(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("adminReadCard requires cardId");let q=await nt(n.get({params:{id:b}}),"cardStore.get");return Array.isArray(q.cards)?q.cards.map(U=>z(U)):[]}async function ne(w){let b=String(w.cardId||"").trim(),q=z(w.candidateCardContent),U=lr(q);if(!b)throw new Error("adminUpsertCard requires cardId");if(typeof U.id!="string"||!U.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(U.id!==b)throw new Error(`candidateCardContent.id must match cardId (${b})`);let V=await c({candidateCardContent:U}),Z=z(V),ae=z(Z.data);if(Z.status!=="success"||ae.isValid!==true)return {status:"fail",step:"validate",validation:V};let fe=null;try{fe=await bt(n,b);}catch{fe=null;}let we=fe?z(z(fe).__private):{},Pe={...U,__private:{...we,visible_controlplane_only:true}},Be=await n.set({body:Pe});Ve(Be,"cardStore.set");let Se;try{Se=await t.upsertCard({params:{cardId:b,restart:!0}}),Ve(Se,"upsertCard");}catch(Le){try{fe&&await n.set({body:fe});}catch{}throw Le}let ce=null;try{ce=await t.cardRefreshedNotify({params:{cardId:b}}),Ve(ce,"cardRefreshedNotify");}catch{ce=null;}return {status:"success",data:{validation:V,card_saved:null,board_result:Se,refresh_notify:ce}}}async function v(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("getChatProcessing requires cardId");let q=Hn(await o.isProcessing({params:{cardId:b}}),"chatStore.isProcessing");return {cardId:b,active:!!q.active}}async function g(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("setChatProcessing requires cardId");if(typeof w.active!="boolean")throw new Error("setChatProcessing requires boolean active");return Ve(await o.setProcessing({params:{cardId:b},body:{active:w.active}}),"chatStore.setProcessing"),{cardId:b,active:w.active}}async function L(){let w=await y(s,"webhook.process-accumulated")();return w?.status==="fail"||w?.status==="error"?w:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(w??{},"data")?w.data??null:null}}}async function D(w){let b=String(w.token||"").trim(),q=String(w.ref||"").trim();if(!b)throw new Error("webhookSourceFetchDone requires token");if(!q)throw new Error("webhookSourceFetchDone requires ref");let U=await y(i,"webhook.source-fetch-done")({token:b,ref:q});return U?.status==="fail"||U?.status==="error"?U:{status:"success",data:{token:b,ref:q,runtime_result:Object.prototype.hasOwnProperty.call(U??{},"data")?U.data??null:null}}}async function H(w){let b=String(w.token||"").trim(),q=String(w.reason||"").trim();if(!b)throw new Error("webhookSourceFetchFailed requires token");if(!q)throw new Error("webhookSourceFetchFailed requires reason");let U=await y(u,"webhook.source-fetch-failed")({token:b,reason:q});return U?.status==="fail"||U?.status==="error"?U:{status:"success",data:{token:b,reason:q,runtime_result:Object.prototype.hasOwnProperty.call(U??{},"data")?U.data??null:null}}}return {listRuntimeCards:C,discoverSourceKinds:R,inspectBoardRuntimeStatus:I,inspectCardDefinitionAndRuntime:x,inspectChatMessagesOnCards:A,inspectFileContents:F,preflightValidateCandidateCardDefinition:c,preflightMaterializeCandidateCard:h,preflightProbeSingleSourceInCandidateCard:d,preflightRunSingleSourceInCandidateCard:f,preflightRunSingleSourceInLiveCard:l,preflightRunOneCycleWithCandidateCard:k,manageReadCard:_,manageAddChatAttachment:J,manageAddChatEntryAndAnyAttachments:W,managePatchCard:te,manageUpsertCard:ie,manageRemoveCard:X,adminReadCard:ee,adminUpsertCard:ne,getChatProcessing:v,setChatProcessing:g,webhookProcessAccumulated:L,webhookSourceFetchDone:D,webhookSourceFetchFailed:H}}async function nt(e,t){return Ve(await e,t)}function Qn(e){let{boardContexts:t,cardOwnerIndex:r,cardContextForCard:n,readStatusSnapshot:o,readDataObjectsByToken:s,readCardRuntimeArtifacts:i,readCardFromStore:u,readCardDefinitions:p,processAccumulatedLaneInternal:T,reportSourceFetched:E,reportSourceFetchFailure:y,uploadCardFile:C,chatStorePublic:S,serverUrl:R,apiBasePath:I}=e;function x(){return t[0]??null}function A(){return {async status(){let d=await o();return d==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:d}},async getOutputsDataObject(d){let f=d?.params?.key;return f?{status:"success",data:(await s())[f]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(d){let f=d?.params?.key;return f?{status:"success",data:(await i())[f]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(d){let f=d?.params?.key;if(!f)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let l=n(f)??x();return l?l.boardOps.getOutputsFetchedSources({params:{key:f}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(d){let f=d?.params?.id;if(!f)return {status:"fail",error:"removeCard requires params.id"};let l=n(f)??x();return l?l.boardOps.removeCard({params:{id:f}}):{status:"fail",error:"Board context is unavailable"}},async cardRefreshedNotify(d){let f=d?.params?.cardId;if(!f)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let l=n(f)??x();return l?l.boardOps.cardRefreshedNotify({params:{cardId:f}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(d){let f=d?.params?.cardId;if(!f)return {status:"fail",error:"upsertCard requires params.cardId"};let l=n(f)??x();if(!l)return {status:"fail",error:"Board context is unavailable"};let k=await l.boardOps.upsertCard({params:{cardId:f,restart:d.params.restart===true}});if(k.status!=="success")return k;if(ot(l.boardAdapter)){let _=await T(true);if(_.status!=="success")return _}return k}}}function F(){let d=()=>{let f=x();if(!f?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return f.nonCore};return {describeTaskExecutorCapabilities(f){return d().describeTaskExecutorCapabilities(f)},validateCardPreflight(f){return d().validateCardPreflight(f)},evalCardCompute(f){return d().evalCardCompute(f)},probeSourcePreflight(f){return d().probeSourcePreflight(f)},runSourcePreflight(f){return d().runSourcePreflight(f)},simulateCardCycle(f){return d().simulateCardCycle(f)}}}function c(){return {async get(d){let f=typeof d.params?.id=="string"?d.params.id:void 0;if(f){let l=await u(f);return l?{status:"success",data:{cards:[l]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await p()}}},async set(d){let f=d.body;if(f==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let l=Array.isArray(f)?f:[f];for(let k of l){let _=k,$=typeof _.id=="string"?_.id:"";if(!$)return {status:"fail",error:"each card must have a string `id` field"};let J=r.get($)??0,W=t[J]??x();if(!W)return {status:"fail",error:"Board context is unavailable"};let te=await W.cardStoreOps.set({body:_});if(te.status!=="success")return te;r.set($,J);}return {status:"success",data:{count:l.length}}},async del(d){let f=[d.params?.id,...d.body?.ids??[]].filter(l=>typeof l=="string"&&!!l);if(f.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let l of f){let k=n(l)??x();if(!k)return {status:"fail",error:"Board context is unavailable"};let _=await k.cardStoreOps.del({params:{id:l}});if(_.status!=="success")return _;r.delete(l);}return {status:"success",data:{count:f.length}}},async patch(d){let f=typeof d.params?.id=="string"?d.params.id:void 0,l=typeof d.params?.path=="string"?d.params.path:void 0;if(!f||!l)return {status:"fail",error:"patch requires params.id and params.path"};let k=n(f)??x();return k?k.cardStoreOps.patch(d):{status:"fail",error:"Board context is unavailable"}},async appendFiles(d){let f=typeof d.params?.id=="string"?d.params.id:void 0;if(!f)return {status:"fail",error:"appendFiles requires params.id"};let l=n(f)??x();return l?l.cardStoreOps.appendFiles(d):{status:"fail",error:"Board context is unavailable"}}}}function h(){return Wn({board:A(),nonCore:F(),cardStore:c(),chatStore:S,processAccumulated:()=>T(true),sourceFetchDone:({token:d,ref:f})=>E(d,f),sourceFetchFailed:({token:d,reason:f})=>y(d,f),uploadCardFile({cardId:d,fileName:f,contentType:l,bytes:k,suppressChatRecordWrite:_}){return C(d,f,l,k,{inChat:true,..._===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:d,fileIdx:f,storedName:l}){let k=`${R||""}${I}/cards/${encodeURIComponent(d)}/files/${f}`;return l?`${k}?sn=${encodeURIComponent(l)}`:k},readFetchedSourceJsonByRef({cardId:d,ref:f}){let l=n(d)??x();if(!l||ot(l.boardAdapter))return null;let $=l.boardAdapter.resolveBlob(at(f)).trim();return $?JSON.parse($):null}})}return {mcpBoardFacade:A,mcpNonCoreFacade:F,mcpCardStoreFacade:c,createMcpFacade:h}}function zn(e){let{apiBasePath:t,json:r,readJsonBody:n,bootstrapBoard:o,createMcpFacade:s,createMcpToolRegistry:i,resolveCardFileDownloadPayload:u,isLikelyTextMimeType:p,sliceTextByLines:T}=e;async function E(y,C,S){let R=y.method||"GET",I=S,x=I.pathname;try{if(R==="POST"&&x===`${t}/mcp`){await o();let A=await n(y),F=typeof A.tool=="string"?A.tool.trim():"",c=A.args&&typeof A.args=="object"&&!Array.isArray(A.args)?A.args:{};if(!F)return r(C,400,{error:"tool is required"}),!0;if(F==="inspect.file-contents")return r(C,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let h=await pt(F,c,i(s()));if(h&&typeof h=="object"&&!Array.isArray(h)){let d=h;if(d.status==="fail")return r(C,400,{error:rt(h,"Request failed")}),!0;if(d.status==="error")return r(C,500,{error:rt(h,"Internal error")}),!0}r(C,200,h);}catch(h){let d=typeof h?.statusCode=="number"?Number(h.statusCode):500,f=h instanceof Error?h.message:String(h);r(C,d,{error:f});}return !0}if(R==="POST"&&x===`${t}/mcp-raw`){await o();let A=await n(y),F=typeof A.tool=="string"?A.tool.trim():"",c=A.args&&typeof A.args=="object"&&!Array.isArray(A.args)?A.args:{};if(!F)return r(C,400,{error:"tool is required"}),!0;if(F!=="inspect.file-contents")return r(C,400,{error:`Tool does not support raw response: ${F}`}),!0;let h=de(c,"card_id","cardId"),d=it(c,"file_idx","fileIdx"),f=it(c,"head-lines","headLines"),l=it(c,"tail-lines","tailLines"),k=it(c,"head-bytes","headBytes"),_=it(c,"tail-bytes","tailBytes");if(!h)return r(C,400,{error:"inspect.file-contents requires card_id"}),!0;if(d===void 0||!Number.isInteger(d)||d<0)return r(C,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([f,l,k,_].filter(L=>L!==void 0).length>1)return r(C,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[L,D]of [["head-lines",f],["tail-lines",l],["head-bytes",k],["tail-bytes",_]])if(D!==void 0&&(!Number.isInteger(D)||D<0))return r(C,400,{error:`inspect.file-contents requires ${L} to be a non-negative integer`}),!0;let J=await s().inspectFileContents({cardId:h,fileIdx:d}),W=typeof J?.stored_name=="string"?J.stored_name:null,{fileRecord:te,bytes:ie}=await u(h,d,W),X=String(te.name||te.stored_name||"download.bin"),ee=String(te.mime_type||"application/octet-stream"),ne=(I.searchParams.get("resp")||"").trim().toLowerCase();if(ne&&ne!=="json-b64")return r(C,400,{error:`unsupported resp mode: ${ne}`}),!0;let v=ne==="json-b64",g;if(f!==void 0||l!==void 0){if(!p(ee))return r(C,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let L=new TextDecoder().decode(ie),D=f!==void 0?T(L,"head",f):T(L,"tail",l);g=typeof Buffer<"u"?Buffer.from(D,"utf8"):new TextEncoder().encode(D);}else if(k!==void 0||_!==void 0){let L=k??_;g=k!==void 0?ie.slice(0,L):ie.slice(Math.max(0,ie.length-L));}else g=ie;if(v){let L=typeof Buffer<"u"?Buffer.from(g).toString("base64"):btoa(String.fromCharCode(...g));return r(C,200,{bodyBase64:L,mimeType:ee,filename:X,byteLength:g.length}),!0}return C.writeHead(200,{"Content-Type":ee,"Content-Disposition":`attachment; filename="${X}"`,"Content-Length":g.length}),C.end(g),!0}return !1}catch(A){let F=A?.statusCode||500;return r(C,F,{error:String(A?.message||A)}),true}}return {handleAgentfaceApi:E}}function Yn(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,createMcpWebhookToolRegistry:s}=e;async function i(u,p,T){let E=u.method||"GET",y=T.pathname;try{if(E==="POST"&&y===`${t}/mcp-webhooks`){await o();let C=await n(u),S=typeof C.tool=="string"?C.tool.trim():"",R=C.args&&typeof C.args=="object"&&!Array.isArray(C.args)?C.args:{};if(!S)return r(p,400,{error:"tool is required"}),!0;try{let I=await pt(S,R,s());if(I&&typeof I=="object"&&!Array.isArray(I)){let x=I;if(x.status==="fail")return r(p,400,{error:rt(I,"Request failed")}),!0;if(x.status==="error")return r(p,500,{error:rt(I,"Internal error")}),!0}r(p,200,I);}catch(I){let x=typeof I?.statusCode=="number"?Number(I.statusCode):500,A=I instanceof Error?I.message:String(I);r(p,x,{error:A});}return !0}return !1}catch(C){let S=C?.statusCode||500;return r(p,S,{error:String(C?.message||C)}),true}}return {handleWebhooksApi:i}}function Xn(e){let{sseHub:t,corsHeaders:r,json:n,buildPublishedRuntimePayload:o,onSseClientConnected:s,onChannelSubscribed:i,onChannelUnsubscribed:u}=e;function p(E,y,C,S,R){if(!t.has(y)){n(E,404,{error:`SSE client not connected: ${y}`});return}R?i?.(y,C,S):u?.(y,C,S),n(E,200,{ok:true,clientId:y,channelName:C,...S.cardId?{cardId:S.cardId}:{},subscribed:R});}async function T(E,y,C,S){let R=S?.oneShot===true,I=!R&&C?t.get(C):null,x=I?new Set(I.subscribedChatCardIds):new Set;y.writeHead(200,{...r,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),t.flushTransport(y);let A=await o(),F=t.buildFrame(A);if(y.write(F),R){y.end();return}if(!C)throw new Error("clientId is required for streaming SSE");t.register(C,y,x);try{s?.(C,h=>{t.writeFrame(C,h);});}catch{}let c=setInterval(()=>{try{y.write(`: keepalive
4
+ `}function u(d){let f=d;try{f.flushHeaders?.();}catch{}try{f.flush?.();}catch{}try{f.socket?.setNoDelay?.(!0);}catch{}try{f.socket?.uncork?.();}catch{}}function p(d,f){let l=t.get(d);if(l&&!(f&&l.res!==f)){t.delete(d),I();try{e.onSseClientDisconnected?.(d);}catch{}try{l.res.end();}catch{}}}function T(d,f,l){let k=t.get(d);k&&p(d,k.res),t.set(d,{res:f,subscribedChatCardIds:l??new Set});}function E(d,f){let l=t.get(d);if(!l)return;let k=i(f);try{l.res.write(k),u(l.res);}catch{p(d,l.res);}}function y(){let d=new Set;for(let f of t.values())for(let l of f.subscribedChatCardIds)d.add(l);return Array.from(d)}async function C(d){let f=r.has(d)?r.get(d):null,{cursor:l}=await e.readChatAfter(d,f),k=await e.getChatProcessing(d),_=k!==(n.get(d)??false),$=l!==f;return $&&r.set(d,l),n.set(d,k),$||_}async function S(d,f){let l=await e.readChatRecords(d),k=Date.now();return {kind:"card_chats",cardId:d,sentAt:new Date(k).toISOString(),sentAtMs:k,messages:l.map(_=>({role:String(_.role||"system"),text:String(_.text||""),files:Array.isArray(_.files)?_.files:[],...typeof _.turn=="string"&&_.turn?{turn:_.turn}:{}})),receiving:f,processing:await e.getChatProcessing(d)}}async function R(d,f=true){let l={kind:"notification-batch",notifications:[await S(d,f)]};for(let[k,_]of t.entries())_.subscribedChatCardIds.has(d)&&E(k,l);}function I(){y().length>0||(s&&(clearInterval(s),s=null),r.clear(),n.clear());}function x(){if(s)return;let d=async()=>{let f=y();if(f.length===0){I();return}let l=new Set(f);for(let k of Array.from(r.keys()))l.has(k)||r.delete(k);for(let k of Array.from(n.keys()))l.has(k)||n.delete(k);for(let k of f)await C(k)&&await R(k,true);};d(),s=setInterval(()=>{d();},1e3);}async function A(d,f){let l=t.get(d);if(!l)return false;l.subscribedChatCardIds.add(f);let{cursor:k}=await e.readChatAfter(f,null);return r.set(f,k),n.set(f,await e.getChatProcessing(f)),x(),E(d,{kind:"notification-batch",notifications:[await S(f,true)]}),true}function F(d,f){let l=t.get(d);return l?(l.subscribedChatCardIds.delete(f),y().includes(f)||(r.delete(f),n.delete(f)),I(),true):false}function c(d){if(!d||typeof d!="object")return false;let f=d.kind;return f==="card_chats"||f==="chat_messages"}function h(d){if(!d||d.length===0)return;let f=[],l=new Set;for(let k of d)c(k)&&typeof k.cardId=="string"?l.add(String(k.cardId)):f.push(k);if(f.length>0){let k={kind:"notification-batch",notifications:f};for(let _ of t.keys())E(_,k);}for(let k of l)R(k,true);}return {size:()=>t.size,has:d=>t.has(d),get:d=>t.get(d),buildFrame:i,flushTransport:u,register:T,disconnect:p,writeFrame:E,subscribeChat:A,unsubscribeChat:F,broadcastNotificationBatch:h,broadcastCardChats:R}}function Er(e,t){if(e?.status==="success")return Object.prototype.hasOwnProperty.call(e,"data")?e.data:void 0;throw e?.status==="fail"||e?.status==="error"?Object.assign(new Error(e.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function Fr(e,t){return Er(await e,t)}function Br(e){let t=ue(e,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let r=t.split(".");if(!(r.length>=2&&r[0]==="chat"&&r.every(o=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(o))))throw Object.assign(new Error("MCP tool only supports card private keys under chat.*"),{statusCode:400});return t}function Or(e,t){let r=e.__private;for(let n of t.split(".")){if(!r||typeof r!="object"||Array.isArray(r)||!Object.prototype.hasOwnProperty.call(r,n))return {exists:false,value:null};r=r[n];}return {exists:true,value:r}}function Dn(e){let{boardId:t,bootstrapBoard:r,sseHub:n,onChannelSubscribed:o,onChannelUnsubscribed:s,getMcpFacade:i,getMcpCardStoreFacade:u}=e;function p(c){let h=ue(c,"board_id");if(!h)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(h!==t)throw Object.assign(new Error(`Unknown board_id: ${h}`),{statusCode:400})}function T(c){let h=ue(c,"client_id");if(!h)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return h}function E(c){p(c);let h=T(c),d=ue(c,"channel_name"),f=ue(c,"card_id")||void 0;if(!d)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:h,channelName:d,...f?{cardId:f}:{}}}function y(c){p(c);let h=ue(c,"card_id");if(!h)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:h}}async function C(c){await r();let{cardId:h}=y(c),d=T(c);if(!await n.subscribeChat(d,h))throw Object.assign(new Error(`SSE client not connected: ${d}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:h,clientId:d,subscribed:true}}}async function S(c){await r();let{cardId:h}=y(c),d=T(c);if(!n.unsubscribeChat(d,h))throw Object.assign(new Error(`SSE client not connected: ${d}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:h,clientId:d,subscribed:false}}}async function R(c,h){await r();let{clientId:d,channelName:f,cardId:l}=E(c);if(!n.has(d))throw Object.assign(new Error(`SSE client not connected: ${d}`),{statusCode:404});return h?o?.(d,f,l?{cardId:l}:{}):s?.(d,f,l?{cardId:l}:{}),{status:"success",data:{boardId:t,clientId:d,channelName:f,subscribed:h,...l?{cardId:l}:{}}}}async function I(c,h){let{cardId:d}=y(c);return await i().setChatProcessing({cardId:d,active:h}),{status:"success",data:{boardId:t,cardId:d,active:h}}}async function x(c){let{cardId:h}=y(c),d=await i().getChatProcessing({cardId:h});return {status:"success",data:{boardId:t,cardId:h,active:d.active}}}async function A(c){let{cardId:h}=y(c),d=Br(c);if(!Object.prototype.hasOwnProperty.call(c,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(d.split(".").includes("visible_controlplane_only")){let f=await Fr(u().get({params:{id:h}}),"cardStore.get"),l=Array.isArray(f.cards)&&f.cards.length>0&&typeof f.cards[0]=="object"&&!Array.isArray(f.cards[0])?f.cards[0]:null,k=l?Or(l,"visible_controlplane_only").value:void 0;if(c.value!==k)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:h,key:d}}}return Er(await u().patch({params:{id:h,path:`__private.${d}`},body:{value:c.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:h,key:d}}}async function F(c){let{cardId:h}=y(c),d=Br(c),f=await Fr(u().get({params:{id:h}}),"cardStore.get"),l=Array.isArray(f.cards)&&f.cards.length>0&&f.cards[0]&&typeof f.cards[0]=="object"&&!Array.isArray(f.cards[0])?f.cards[0]:null;if(!l)throw Object.assign(new Error(`Card "${h}" not found`),{statusCode:404});let k=Or(l,d);return {status:"success",data:{boardId:t,cardId:h,key:d,exists:k.exists,value:k.value}}}return {requireCardArgs:y,subscribeChat:C,unsubscribeChat:S,watchChannel:R,setChatProcessing:I,getChatProcessing:x,setCardMeta:A,getCardMeta:F}}function Nn(e){let{boardId:t,boardContexts:r,readCardDefinitions:n,readChatRecords:o,getChatProcessing:s}=e;async function i(){let E=(await Promise.all(r.map(async I=>{try{let x=I.boardAdapter.kvStorageForRef(I.outputsStoreRef),A=await Promise.resolve(x.read("status"));if(A!=null)return A}catch{}return I.notification.status}))).filter(Boolean);if(E.length===0)return null;if(E.length===1)return E[0];let y=[],C=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],S={};for(let I of C)S[I]=0;for(let I of E){let x=I,A=Array.isArray(x.cards)?x.cards:[];y.push(...A);for(let F of C)S[F]+=Number(x?.summary?.[F]||0);}let R=E[0];return {...R,cards:y,summary:{...R.summary||{},card_count:y.length,...S}}}async function u(){let E={},y=async C=>{try{let S=await C.boardOps.getAllOutputsComputedValues({});if(S.status==="success"&&S.data&&typeof S.data=="object"){for(let[R,I]of Object.entries(S.data)){let x=C.notification.cards[R];E[R]={schema_version:"v1",card_id:R,card_data:x?.card_data??{},computed_values:I??{}};}return}}catch{}for(let[S,R]of Object.entries(C.notification.computedValues)){let I=C.notification.cards[S];E[S]={schema_version:"v1",card_id:S,card_data:I?.card_data??{},computed_values:R??{}};}};for(let C of r)await y(C);return E}async function p(){let E={};for(let y of r){try{let C=await y.boardOps.getAllOutputsDataObjects({});if(C.status==="success"&&C.data&&typeof C.data=="object"){Object.assign(E,C.data);continue}}catch{}Object.assign(E,y.notification.dataObjects||{});}return E}async function T(){let E=await n(),y=await u(),C=await p(),S={};for(let I of E){if(!I?.id)continue;let x=I.id,A=y[x]||{},F={...A.card_data&&typeof A.card_data=="object"?A.card_data:I.card_data&&typeof I.card_data=="object"?I.card_data:{}};S[x]={schema_version:A.schema_version||"v1",card_id:A.card_id||x,card_data:F,computed_values:A.computed_values&&typeof A.computed_values=="object"?A.computed_values:{}};}let R={};for(let I of E){if(!I?.id)continue;let x=I.id;try{let A=await o(x),F=await s(x);(A.length>0||F)&&(R[x]={messages:A.map(c=>({role:String(c.role||"system"),text:String(c.text||""),files:Array.isArray(c.files)?c.files:[]})),receiving:!1,processing:F});}catch{}}return {boardId:t,cardDefinitions:E,statusSnapshot:await i(),dataObjectsByToken:C,cardRuntimeById:S,cardChatsByCardId:R}}return {readStatusSnapshot:i,readCardRuntimeArtifacts:u,readDataObjectsByToken:p,buildPublishedRuntimePayload:T}}function zo(e){let t=String(e||"").trim();if(!t)return "upload.bin";let r=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (r>=0?t.slice(r+1):t)||"upload.bin"}function $n(e){let{safeCardId:t,artifactsStores:r,cardFileMetadataStore:n,readCardFromStore:o,updateCardLocalOnly:s,writeChatRecord:i}=e;async function u(E){let y=[];try{let C=await o(E);if(!C)return y;let S=n().read(C.card_data&&typeof C.card_data=="object"?C.card_data:null);for(let R of S)y.push(String(R.stored_name??""));}catch{}return y}async function p(E,y,C,S){let R=t(E),I=r(E),x=zo(y),A=await u(E),c=`${String(A.length+1).padStart(3,"0")}-${x}`.slice(-36);if(!I.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${E}`),{statusCode:500});return await I.files.putBytes(`${R}/${c}`,new Uint8Array(S),C||"application/octet-stream"),{name:x,stored_name:c,size:S.length,mime_type:C||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function T(E,y,C,S,R){if(!S.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let I=R?.inChat===true,x=await p(E,y,C,S),A=null;if(await s(E,F=>{let c=new Date().toISOString(),h=F.card_data&&typeof F.card_data=="object"?F.card_data:{};F.card_data=h;let d=n().normalizeIncoming([{name:x.name,stored_name:x.stored_name,size:x.size,mime_type:x.mime_type,uploaded_at:x.uploaded_at||c,chat:I}],c);return A=n().merge(h,d).findIndex(l=>l.stored_name===x.stored_name),F}),I&&R?.suppressChatRecordWrite!==true){let F=typeof A=="number"&&A>=0?` #${A}`:"";await i(E,"system",`file uploaded: ${x.name} as ${x.stored_name}${F}`,[],R?.turnId??"");}return {ok:true,file:{...x,...typeof A=="number"&&A>=0?{file_idx:A}:{},chat:I},...typeof A=="number"&&A>=0?{file_idx:A}:{}}}return {uploadCardFile:T,readCardStoredFileNames:u}}function Un(e){return {"discover.source-kinds":()=>e.discoverSourceKinds(),"inspect.board-runtime-status":()=>e.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>e.inspectCardDefinitionAndRuntime({cardId:ue(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let r=it(t,"tail_turns"),n=it(t,"tail"),o=ue(t,"turn_id"),s=t.all_turns===true,i=ue(t,"tail_turns_before_id");return e.inspectChatMessagesOnCards({cardId:ue(t,"card_id"),...r!==void 0?{lastUserTurns:r}:{},...n!==void 0?{tail:n}:{},...o?{turnId:o}:{},...s?{allTurns:true}:{},...i?{tailTurnsBeforeId:i}:{}})},"inspect.file-contents":t=>e.inspectFileContents({cardId:ue(t,"card_id"),fileIdx:Number(it(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>e.preflightValidateCandidateCardDefinition({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>e.preflightMaterializeCandidateCard({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content"),mockRequires:ft(t,"mock_requires","mock_requires"),mockFetchedSources:ft(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>e.preflightProbeSingleSourceInCandidateCard({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content"),mockProjections:ut(t,"mock_projections"),sourceIdx:Mt(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>e.preflightRunSingleSourceInCandidateCard({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content"),mockProjections:ut(t,"mock_projections"),sourceIdx:Mt(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>e.preflightRunSingleSourceInLiveCard({cardId:ue(t,"card_id"),sourceIdx:Mt(t,"source_idx","source_idx"),mockRequires:ft(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>e.preflightRunOneCycleWithCandidateCard({candidateCardContent:ft(t,"candidate_card_content","candidate_card_content"),mockRequires:ut(t,"mock_requires")}),"manage.read-card":t=>e.manageReadCard({cardId:ue(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let r=ue(t,"turn_id");if(!r)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return e.manageAddChatEntryAndAnyAttachments({cardId:ue(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...r?{turn:r}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"stage-ai-failure-message":t=>{let r=ue(t,"turn_id"),n=ue(t,"failure");if(!r)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!n)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return e.manageAddChatEntryAndAnyAttachments({cardId:ue(t,"card_id"),role:"system",text:n,turn:r})},"manage.upsert-card":t=>e.manageUpsertCard({cardId:ue(t,"card_id"),candidateCardContent:ut(t,"candidate_card_content")}),"manage.remove-card":t=>e.manageRemoveCard({cardId:ue(t,"card_id")})}}function Vn(e){return {"webhook.process-accumulated":()=>e.webhookProcessAccumulated(),"webhook.source-fetch-done":t=>e.webhookSourceFetchDone({token:ue(t,"token"),ref:ue(t,"ref")}),"webhook.source-fetch-failed":t=>e.webhookSourceFetchFailed({token:ue(t,"token"),reason:ue(t,"reason")})}}function Kn(e){let{boardId:t,uploadCardFile:r,getMcpFacade:n,controlplane:o}=e;function s(u,p){let T=ue(u,"board_id");if(!T)throw Object.assign(new Error(`${p} requires board_id`),{statusCode:400});if(T!==t)throw Object.assign(new Error(`Unknown board_id: ${T}`),{statusCode:400})}function i(u,p){let{cardId:T}=o.requireCardArgs(u),E=ue(u,"turn_id");return s(u,p),n().manageAddChatAttachment({cardId:T,role:ue(u,"role")||"user",...E?{turn:E}:{},files:[{file_name:ue(u,"file_name"),content_type:ue(u,"content_type")||"application/octet-stream",...typeof u.text=="string"?{text:u.text}:{},...typeof u.base64=="string"?{base64:u.base64}:{},...Array.isArray(u.bytes)?{bytes:u.bytes}:{}}]})}return {"list-runtime-cards":u=>(s(u,"list-runtime-cards"),n().listRuntimeCards()),"sse.subscribe-chat":u=>o.subscribeChat(u),"sse.unsubscribe-chat":u=>o.unsubscribeChat(u),"sse.watch-channel":u=>o.watchChannel(u,true),"sse.unwatch-channel":u=>o.watchChannel(u,false),"getstate.is-chat-processing":u=>o.getChatProcessing(u),"setstate.chat-processing-started":u=>o.setChatProcessing(u,true),"setstate.chat-processing-done":u=>o.setChatProcessing(u,false),"getstate.card-private":u=>o.getCardMeta(u),"setstate.card-private":u=>o.setCardMeta(u),"manage.upload-card-file":u=>{let p=ue(u,"card_id"),T=ue(u,"file_name"),E=ue(u,"content_type")||"application/octet-stream",y=Vr(u);if(s(u,"manage.upload-card-file"),!p)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!T)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!y)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return r(p,T,E,y,{inChat:false})},"manage.add-chat-attachment":u=>i(u,"manage.add-chat-attachment"),"manage.add-chat-attachement":u=>i(u,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":u=>{let{cardId:p}=o.requireCardArgs(u),T=ue(u,"role")||"user",E=ue(u,"turn_id");return s(u,"manage.add-chat-entry-and-any-attachments"),n().manageAddChatEntryAndAnyAttachments({cardId:p,role:T,...typeof u.text=="string"?{text:u.text}:{},...E?{turn:E}:{},...Array.isArray(u.files)?{files:u.files}:{}})},"manage.patch-card":u=>{let{cardId:p}=o.requireCardArgs(u);return s(u,"manage.patch-card"),n().managePatchCard({cardId:p,patch:ut(u,"patch")})},"manage.upsert-card":u=>{let{cardId:p}=o.requireCardArgs(u);return s(u,"manage.upsert-card"),n().manageUpsertCard({cardId:p,candidateCardContent:ut(u,"candidate_card_content")})},"manage.remove-card":u=>{let{cardId:p}=o.requireCardArgs(u);return s(u,"manage.remove-card"),n().manageRemoveCard({cardId:p})},"manage.admin-read-card":async u=>{let{cardId:p}=o.requireCardArgs(u);return {status:"success",data:{cards:await n().adminReadCard({cardId:p})}}},"manage.admin-upsert-card":u=>{let p=ue(u,"board_id"),T=ue(u,"card_id");if(!p)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!T)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(p!==t)throw Object.assign(new Error(`Unknown board_id: ${p}`),{statusCode:400});return n().adminUpsertCard({cardId:T,candidateCardContent:ut(u,"candidate_card_content")})}}}function Ve(e,t){if(e?.status==="success")return Object.prototype.hasOwnProperty.call(e,"data")?e.data:void 0;throw e?.status==="fail"||e?.status==="error"?new Error(e.error||`${t} failed`):new Error(`${t} returned an unexpected response`)}function Hn(e,t){if(e?.status==="success"&&Object.prototype.hasOwnProperty.call(e,"data"))return e.data;throw e?.status==="success"?new Error(`${t} returned success without data`):e?.status==="fail"||e?.status==="error"?new Error(e.error||`${t} failed`):new Error(`${t} returned an unexpected response`)}function z(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}function je(e){return Array.isArray(e)?e:[]}function jr(e,t){if(typeof t!="string"||t.length===0)return;let r=e,n=t;n.startsWith("fetched_sources.")&&(r=z(e).fetched_sources,n=n.slice(16));for(let o of n.split(".")){if(r==null||typeof r!="object")return;r=r[o];}return r}function qr(e,t){let r=z(e.view),n=je(r.elements);return {layout:r.layout,features:r.features,elements:n.map((o,s)=>{let i=z(o),u=z(i.data),p=typeof i.visible=="string"?!!jr(t,i.visible):true,T=typeof u.bind=="string"?u.bind:void 0,E=typeof u.maxRows=="number"?u.maxRows:void 0,y=T?jr(t,T):void 0,C={id:typeof i.id=="string"&&i.id?i.id:`element-${s}`,kind:i.kind,label:i.label,visible:p};return y!==void 0&&(C.resolved=Array.isArray(y)&&typeof E=="number"?y.slice(0,E):y),C})}}function Jn(e,t){let r=typeof e.id=="string"&&e.id?e.id:"card",n=je(e.provides),o=n.length>0?n:[{bindTo:r,ref:"card_data"}],s={};for(let i of o){let u=z(i),p=typeof u.bindTo=="string"?u.bindTo:"",T=typeof u.ref=="string"?u.ref:"";if(!p||!T)continue;let E=jr(t,T);E!==void 0&&(s[p]=E);}return s}function Yo(e){if(typeof e!="string"||!e.trim())return null;let t=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(e.trim());if(!t)return null;let r=Number.parseInt(t[2],10);return !Number.isInteger(r)||r<0?null:r}function Xo(e){return {"card-content":e}}function lr(e){let t={...e};return delete t.__private,t}function fr(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function Zo(e){return typeof structuredClone=="function"?structuredClone(e):JSON.parse(JSON.stringify(e))}function es(e,t){let r=Zo(e);if(!t||Object.keys(t).length===0)return r;function n(o,s,i){let u=String(s||"").split(".").filter(Boolean);if(!u.length)return;let p=o;for(let T=0;T<u.length-1;T+=1){let E=u[T];(!p[E]||typeof p[E]!="object")&&(p[E]={}),p=p[E];}p[u[u.length-1]]=i;}if(t.fieldValues!==void 0&&t.fieldValues!==null){let o=null,s=z(r.view),i=je(s.elements);for(let u of i){let p=z(z(u).data);if(typeof p.writeTo=="string"&&p.writeTo){o=p.writeTo;break}}return o?n(r,o,t.fieldValues):typeof t.fieldValues=="object"&&!Array.isArray(t.fieldValues)&&(r.card_data={...z(r.card_data),...t.fieldValues}),r}if(Array.isArray(t._stagedFiles)&&t._stagedFiles.length>0)return r;for(let[o,s]of Object.entries(t))o!=="_stagedFiles"&&(s!==null&&typeof s=="object"&&!Array.isArray(s)&&r[o]!==null&&typeof r[o]=="object"&&!Array.isArray(r[o])?r[o]={...r[o],...s}:r[o]=s);return r}function Gn(e){return z(e.__private).visible_controlplane_only===true}async function bt(e,t){let r=await nt(e.get({params:{id:t}}),"cardStore.get"),n=Array.isArray(r?.cards)?r.cards:[];if(n.length===0)throw new Error(`Card "${t}" not found`);return n[0]}function Wn(e){let{board:t,nonCore:r,cardStore:n,chatStore:o,processAccumulated:s,sourceFetchDone:i,sourceFetchFailed:u,uploadCardFile:p,buildFileDownloadUrl:T,readFetchedSourceJsonByRef:E}=e;function y(w,b){if(typeof w=="function")return w;throw new Error(`${b} is not configured for this MCP facade`)}async function C(){let w=await nt(n.get({}),"cardStore.get");return Array.isArray(w.cards)?w.cards.map(b=>z(b)):[]}function S(w){if(Array.isArray(w.bytes))return new Uint8Array(w.bytes.map(b=>Math.max(0,Math.min(255,Number(b)||0))));if(typeof w.text=="string")return new TextEncoder().encode(w.text);if(typeof w.base64=="string"){let b=String(w.base64).replace(/-/g,"+").replace(/_/g,"/"),q=b+"=".repeat((4-b.length%4)%4),U=atob(q);return Uint8Array.from(U,V=>V.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function R(){let w=z(await nt(r.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:w.version,commonSourceFields:z(w.commonSourceDefFields),sourceKinds:z(w.sourceKinds)}}async function I(){let w=z(await nt(t.status({}),"status")),b=z(w.summary),q=je(w.cards);return {meta:z(w.meta),summary:{card_count:typeof b.card_count=="number"?b.card_count:0,completed:typeof b.completed=="number"?b.completed:0,eligible:typeof b.eligible=="number"?b.eligible:0,pending:typeof b.pending=="number"?b.pending:0,blocked:typeof b.blocked=="number"?b.blocked:0,in_progress:typeof b.in_progress=="number"?b.in_progress:0,failed:typeof b.failed=="number"?b.failed:0,unresolved:typeof b.unresolved=="number"?b.unresolved:0},cards:q.map(U=>{let V=z(U);return {"card-id":typeof V.name=="string"?V.name:null,status:V.status??null,error:V.error??null,requires:je(V.requires),requires_satisfied:je(V.requires_satisfied),requires_missing:je(V.requires_missing),provides_declared:je(V.provides_declared),provides_runtime:je(V.provides_runtime)}})}}async function x(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let q=z(await nt(t.status({}),"status")),V=je(q.cards).map(z).find(me=>me.name===b);if(!V)throw new Error(`card "${b}" not found in board status`);let Z=z(await bt(n,b));if(Gn(Z))throw Object.assign(new Error(`card "${b}" not found`),{statusCode:404});let ae=lr(Z),fe=je(V.requires_satisfied).filter(me=>typeof me=="string"&&!!me),we=je(V.provides_runtime).filter(me=>typeof me=="string"&&!!me),Pe=Object.fromEntries(await Promise.all(fe.map(async me=>[me,await nt(t.getOutputsDataObject({params:{key:me}}),`getOutputsDataObject(${me})`)]))),Be=Object.fromEntries(await Promise.all(we.map(async me=>[me,await nt(t.getOutputsDataObject({params:{key:me}}),`getOutputsDataObject(${me})`)]))),Se=z(await nt(t.getOutputsComputedValues({params:{key:b}}),"getOutputsComputedValues")),ce=await nt(t.getOutputsFetchedSources({params:{key:b}}),"getOutputsFetchedSources"),Le=je(Z.source_defs).map(z),ve={};for(let me of Le)typeof me.bindTo=="string"&&typeof me.outputFile=="string"&&(ve[me.outputFile]=me.bindTo);let Me={};for(let[me,Ze]of Object.entries(ce)){let Ke=ve[me]??me;if(!E||typeof Ze!="string"){Me[Ke]=null;continue}try{Me[Ke]=E({cardId:b,ref:Ze});}catch{Me[Ke]=null;}}let Ne={card_data:z(Z.card_data),requires:Pe,fetched_sources:Me,computed_values:Se};return {cardId:b,card_status_in_board:V,card_definition_and_static_data:ae,refs_for_fetched_source_files:ce,runtime_data:{requires:Pe,provides:Be,computed_values:Se,rendered_view:qr(Z,Ne)}}}async function A(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("inspectChatMessagesOnCards requires cardId");let q=typeof w.turnId=="string"?w.turnId:"",U=w.allTurns===true,V=typeof w.tailTurnsBeforeId=="string"?w.tailTurnsBeforeId:"",Z=U?void 0:w.lastUserTurns??(q?void 0:1),ae=w.tail,fe={...Z===void 0?{}:{tailTurns:Z},...q?{turnId:q}:{},...U?{allTurns:true}:{},...V?{tailTurnsBeforeId:V}:{}},we=Object.keys(fe).length>0?{params:{cardId:b},body:fe}:{params:{cardId:b}},Pe=Ve(await o.readAll(we),"chatStore.readAll"),Be=z(await bt(n,b)),Se=je(z(Be.card_data).files).map((ve,Me)=>({idx:Me,stored_name:z(ve).stored_name})).filter(ve=>typeof ve.stored_name=="string"&&ve.stored_name.length>0),Le=(Array.isArray(Pe.records)?Pe.records:[]).map(ve=>{let Ne=z(ve.payload),me={...ve},Ze=typeof ve?.role=="string"?ve.role:typeof Ne.role=="string"?String(Ne.role):"",Ke=typeof ve?.text=="string"?ve.text:typeof Ne.text=="string"?String(Ne.text):"";if(Ze==="system"){let Ge=Yo(Ke);if(Ge!==null&&Se.some(m=>m.idx===Ge)){let m=`Retrieve using inspect-file-contents --card-id ${b} --file-idx ${Ge}`;me.retrieval_hint=m,Object.keys(Ne).length>0&&typeof ve.role!="string"&&(me.payload={...Ne,retrieval_hint:m});}}return me});return {cardId:b,messages:typeof ae=="number"&&ae>=0?Le.slice(-ae):Le}}async function F(w){let b=String(w.cardId||"").trim(),q=Number(w.fileIdx);if(!b)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(q)||q<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let U=z(await bt(n,b)),V=je(z(U.card_data).files).map(z);if(q>=V.length)throw new Error(`attachment index ${q} is out of range for card "${b}"`);let Z=V[q],ae=typeof Z.stored_name=="string"?Z.stored_name:null;return {cardId:b,fileIdx:q,downloadUrl:T({cardId:b,fileIdx:q,storedName:ae}),...typeof Z.name=="string"?{name:Z.name}:{},...typeof Z.stored_name=="string"?{stored_name:Z.stored_name}:{},...typeof Z.mime_type=="string"?{mime_type:Z.mime_type}:{},...typeof Z.size=="number"?{size:Z.size}:{},...typeof Z.uploaded_at=="string"?{uploaded_at:Z.uploaded_at}:{}}}async function c(w){return await r.validateCardPreflight({body:Xo(w.candidateCardContent)})}function h(w){if(!w.mockRequires||typeof w.mockRequires!="object"||Array.isArray(w.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!w.mockFetchedSources||typeof w.mockFetchedSources!="object"||Array.isArray(w.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let b=r.evalCardCompute({body:{"card-content":w.candidateCardContent,"mock-requires":w.mockRequires,"mock-fetched-sources":w.mockFetchedSources}});if(b.status!=="success")return b;let q=z(Hn(b,"evalCardCompute")),U=z(w.candidateCardContent),V={card_data:z(U.card_data),requires:z(w.mockRequires),fetched_sources:z(w.mockFetchedSources),computed_values:z(q.computed_values)};return {status:"success",data:{cardId:typeof q.cardId=="string"?q.cardId:typeof U.id=="string"?U.id:"(unknown)",ok:q.ok===true,computed_values:z(q.computed_values),errors:je(q.errors).map(Z=>{let ae=z(Z);return {bindTo:typeof ae.bindTo=="string"?ae.bindTo:"",error:typeof ae.error=="string"?ae.error:""}}),provides_outputs:Jn(U,V),rendered_view:qr(U,V)}}}async function d(w){return await r.probeSourcePreflight({params:{sourceIdx:w.sourceIdx},body:{"card-content":w.candidateCardContent,"mock-projections":w.mockProjections}})}async function f(w){return await r.runSourcePreflight({params:{sourceIdx:w.sourceIdx},body:{"card-content":w.candidateCardContent,"mock-projections":w.mockProjections}})}async function l(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!w.mockRequires||typeof w.mockRequires!="object"||Array.isArray(w.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let q=z(await bt(n,b)),U=je(q.source_defs).filter(Z=>!!Z&&typeof Z=="object"&&!Array.isArray(Z)),V={};if(w.sourceIdx>=0&&w.sourceIdx<U.length){let Z=U[w.sourceIdx],ae=ze.enrichSourcesSync([Z],{card_data:z(q.card_data),requires:w.mockRequires});Array.isArray(ae)&&ae.length>0&&(V=z(ae[0]._projections));}return await r.runSourcePreflight({params:{sourceIdx:w.sourceIdx},body:{"card-content":q,"mock-requires":w.mockRequires,"mock-projections":V}})}async function k(w){let b=z(await nt(r.simulateCardCycle({body:{"card-content":w.candidateCardContent,"mock-requires":w.mockRequires}}),"simulateCardCycle")),q=z(w.candidateCardContent),U=z(b.validation),V=je(b.source_probes),Z=je(b.projection_errors),ae=z(b.fetched_sources),fe=je(b.compute_errors),we=z(b.computed_values),Pe={card_data:z(q.card_data),requires:w.mockRequires,fetched_sources:ae,computed_values:we},Be=[];for(let Se of je(U.issues))typeof Se=="string"&&Se&&Be.push(Se);for(let Se of V){let ce=z(Se),Le=typeof ce.bindTo=="string"?ce.bindTo:"source",ve=typeof ce.error=="string"?ce.error:"";ve&&Be.push(`${Le}: ${ve}`);}for(let Se of Z){let ce=z(Se),Le=typeof ce.bindTo=="string"?ce.bindTo:"source",ve=typeof ce.key=="string"?ce.key:"projection",Me=typeof ce.error=="string"?ce.error:"projection failed";Be.push(`${Le}.${ve}: ${Me}`);}for(let Se of fe){let ce=z(Se),Le=typeof ce.bindTo=="string"?ce.bindTo:"compute",ve=typeof ce.error=="string"?ce.error:"compute failed";Be.push(`${Le}: ${ve}`);}return {status:"success",data:{cardId:typeof b.cardId=="string"?b.cardId:"(unknown)",ok:b.ok===true,issues:Be,provides_outputs:Jn(q,Pe),rendered_view:qr(q,Pe)}}}async function _(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("manageReadCard requires cardId");let q=await nt(n.get({params:{id:b}}),"cardStore.get"),U=Array.isArray(q.cards)?q.cards.map(z):[];if(U.some(Gn))throw Object.assign(new Error(`Card "${b}" not found`),{statusCode:404});return U.map(V=>lr(V))}async function $(w){let b=await Promise.all(je(w.files).map(async q=>{let U=z(q),V=String(U.file_name??U.fileName??U.name??"").trim(),Z=String(U.content_type??U.contentType??"application/octet-stream");if(!V)throw new Error("file entry requires file_name");return await p({cardId:w.cardId,fileName:V,contentType:Z,bytes:S(U),suppressChatRecordWrite:true})}));for(let[q,U]of b.entries()){let V=z(U.file),Z=typeof U.file_idx=="number"&&Number.isInteger(U.file_idx)&&U.file_idx>=0?U.file_idx:q,ae=w.role==="assistant"?`AI generated: ${String(V.name||"")} as ${String(V.stored_name||"")} #${Z}`:`file uploaded: ${String(V.name||"")} as ${String(V.stored_name||"")} #${Z}`;Ve(await o.append({params:{cardId:w.cardId},body:{role:"system",text:ae,files:[],turn:w.turn}}),"chatStore.append(system attachment message)");}return b.map(q=>q.file)}async function J(w){let b=String(w.cardId||"").trim(),q=String(w.role||"user").trim()||"user",U=typeof w.turn=="string"?w.turn:"";if(!b)throw new Error("manageAddChatAttachment requires cardId");let V=await $({cardId:b,role:q,turn:U,files:w.files});return {status:"success",data:{cardId:b,turn:U,files:V}}}async function W(w){let b=String(w.cardId||"").trim(),q=String(w.role||"").trim(),U=typeof w.text=="string"?w.text:"",V=typeof w.turn=="string"?w.turn:"";if(!b)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!q)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(q==="assistant"&&V){let fe=Ve(await o.readAll({params:{cardId:b},body:{turnId:V}}),"chatStore.readAll(existing turn messages)"),we=Array.isArray(fe.records)?fe.records.find(Pe=>Pe.role==="assistant"&&String(Pe.turn||"")===V):void 0;if(we)return {status:"success",data:{cardId:b,id:String(we.id),role:q,turn:V,files:Array.isArray(we.files)?we.files:[]}}}let Z=await $({cardId:b,role:q,turn:V,files:w.files}),ae=Ve(await o.append({params:{cardId:b},body:{role:q,text:U,files:Z,turn:V}}),"chatStore.append");return {status:"success",data:{cardId:b,id:String(ae.id),role:q,turn:V,files:Z}}}async function te(w){let b=String(w.cardId||"").trim(),q=z(w.patch);if(!b)throw new Error("managePatchCard requires cardId");let U=await _({cardId:b}),V=z(U[0]),ae={...es(V,q),...fr(V,"meta")?{meta:V.meta}:{},...fr(V,"__private")?{__private:V.__private}:{}},fe=await n.set({body:ae});Ve(fe,"cardStore.set");let we;try{we=await t.upsertCard({params:{cardId:b,restart:!0}}),Ve(we,"upsertCard");}catch(Be){try{await n.set({body:V});}catch{}throw Be}let Pe=null;try{Pe=await t.cardRefreshedNotify({params:{cardId:b}}),Ve(Pe,"cardRefreshedNotify");}catch{Pe=null;}return {status:"success",data:{validation:null,card_saved:null,board_result:we,refresh_notify:Pe}}}async function ie(w){let b=String(w.cardId||"").trim(),q=z(w.candidateCardContent),U=lr(q);if(!b)throw new Error("manageUpsertCard requires cardId");if(typeof U.id!="string"||!U.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(U.id!==b)throw new Error(`candidateCardContent.id must match cardId (${b})`);let V=await c({candidateCardContent:U}),Z=z(V),ae=z(Z.data);if(Z.status!=="success"||ae.isValid!==true)return {status:"fail",step:"validate",validation:V};let fe=null;try{fe=await bt(n,b);}catch{fe=null;}let we=fe?z(fe):null,Pe={...U,...we&&fr(we,"meta")?{meta:we.meta}:{},...we&&fr(we,"__private")?{__private:we.__private}:{}},Be=await n.set({body:Pe});Ve(Be,"cardStore.set");let Se;try{Se=await t.upsertCard({params:{cardId:b,restart:!0}}),Ve(Se,"upsertCard");}catch(Le){try{fe&&await n.set({body:fe});}catch{}throw Le}let ce=null;try{ce=await t.cardRefreshedNotify({params:{cardId:b}}),Ve(ce,"cardRefreshedNotify");}catch{ce=null;}return {status:"success",data:{validation:V,card_saved:null,board_result:Se,refresh_notify:ce}}}async function X(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("manageRemoveCard requires cardId");let q=await t.removeCard({params:{id:b}});Ve(q,"removeCard");let U=await n.del({params:{id:b}});return Ve(U,"cardStore.del"),{status:"success",data:{board_result:q,store_result:U}}}async function ee(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("adminReadCard requires cardId");let q=await nt(n.get({params:{id:b}}),"cardStore.get");return Array.isArray(q.cards)?q.cards.map(U=>z(U)):[]}async function ne(w){let b=String(w.cardId||"").trim(),q=z(w.candidateCardContent),U=lr(q);if(!b)throw new Error("adminUpsertCard requires cardId");if(typeof U.id!="string"||!U.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(U.id!==b)throw new Error(`candidateCardContent.id must match cardId (${b})`);let V=await c({candidateCardContent:U}),Z=z(V),ae=z(Z.data);if(Z.status!=="success"||ae.isValid!==true)return {status:"fail",step:"validate",validation:V};let fe=null;try{fe=await bt(n,b);}catch{fe=null;}let we=fe?z(z(fe).__private):{},Pe={...U,__private:{...we,visible_controlplane_only:true}},Be=await n.set({body:Pe});Ve(Be,"cardStore.set");let Se;try{Se=await t.upsertCard({params:{cardId:b,restart:!0}}),Ve(Se,"upsertCard");}catch(Le){try{fe&&await n.set({body:fe});}catch{}throw Le}let ce=null;try{ce=await t.cardRefreshedNotify({params:{cardId:b}}),Ve(ce,"cardRefreshedNotify");}catch{ce=null;}return {status:"success",data:{validation:V,card_saved:null,board_result:Se,refresh_notify:ce}}}async function v(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("getChatProcessing requires cardId");let q=Hn(await o.isProcessing({params:{cardId:b}}),"chatStore.isProcessing");return {cardId:b,active:!!q.active}}async function g(w){let b=String(w.cardId||"").trim();if(!b)throw new Error("setChatProcessing requires cardId");if(typeof w.active!="boolean")throw new Error("setChatProcessing requires boolean active");return Ve(await o.setProcessing({params:{cardId:b},body:{active:w.active}}),"chatStore.setProcessing"),{cardId:b,active:w.active}}async function L(){let w=await y(s,"webhook.process-accumulated")();return w?.status==="fail"||w?.status==="error"?w:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(w??{},"data")?w.data??null:null}}}async function D(w){let b=String(w.token||"").trim(),q=String(w.ref||"").trim();if(!b)throw new Error("webhookSourceFetchDone requires token");if(!q)throw new Error("webhookSourceFetchDone requires ref");let U=await y(i,"webhook.source-fetch-done")({token:b,ref:q});return U?.status==="fail"||U?.status==="error"?U:{status:"success",data:{token:b,ref:q,runtime_result:Object.prototype.hasOwnProperty.call(U??{},"data")?U.data??null:null}}}async function H(w){let b=String(w.token||"").trim(),q=String(w.reason||"").trim();if(!b)throw new Error("webhookSourceFetchFailed requires token");if(!q)throw new Error("webhookSourceFetchFailed requires reason");let U=await y(u,"webhook.source-fetch-failed")({token:b,reason:q});return U?.status==="fail"||U?.status==="error"?U:{status:"success",data:{token:b,reason:q,runtime_result:Object.prototype.hasOwnProperty.call(U??{},"data")?U.data??null:null}}}return {listRuntimeCards:C,discoverSourceKinds:R,inspectBoardRuntimeStatus:I,inspectCardDefinitionAndRuntime:x,inspectChatMessagesOnCards:A,inspectFileContents:F,preflightValidateCandidateCardDefinition:c,preflightMaterializeCandidateCard:h,preflightProbeSingleSourceInCandidateCard:d,preflightRunSingleSourceInCandidateCard:f,preflightRunSingleSourceInLiveCard:l,preflightRunOneCycleWithCandidateCard:k,manageReadCard:_,manageAddChatAttachment:J,manageAddChatEntryAndAnyAttachments:W,managePatchCard:te,manageUpsertCard:ie,manageRemoveCard:X,adminReadCard:ee,adminUpsertCard:ne,getChatProcessing:v,setChatProcessing:g,webhookProcessAccumulated:L,webhookSourceFetchDone:D,webhookSourceFetchFailed:H}}async function nt(e,t){return Ve(await e,t)}function Qn(e){let{boardContexts:t,cardOwnerIndex:r,cardContextForCard:n,readStatusSnapshot:o,readDataObjectsByToken:s,readCardRuntimeArtifacts:i,readCardFromStore:u,readCardDefinitions:p,processAccumulatedLaneInternal:T,reportSourceFetched:E,reportSourceFetchFailure:y,uploadCardFile:C,chatStorePublic:S,serverUrl:R,apiBasePath:I}=e;function x(){return t[0]??null}function A(){return {async status(){let d=await o();return d==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:d}},async getOutputsDataObject(d){let f=d?.params?.key;return f?{status:"success",data:(await s())[f]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(d){let f=d?.params?.key;return f?{status:"success",data:(await i())[f]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(d){let f=d?.params?.key;if(!f)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let l=n(f)??x();return l?l.boardOps.getOutputsFetchedSources({params:{key:f}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(d){let f=d?.params?.id;if(!f)return {status:"fail",error:"removeCard requires params.id"};let l=n(f)??x();return l?l.boardOps.removeCard({params:{id:f}}):{status:"fail",error:"Board context is unavailable"}},async cardRefreshedNotify(d){let f=d?.params?.cardId;if(!f)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let l=n(f)??x();return l?l.boardOps.cardRefreshedNotify({params:{cardId:f}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(d){let f=d?.params?.cardId;if(!f)return {status:"fail",error:"upsertCard requires params.cardId"};let l=n(f)??x();if(!l)return {status:"fail",error:"Board context is unavailable"};let k=await l.boardOps.upsertCard({params:{cardId:f,restart:d.params.restart===true}});if(k.status!=="success")return k;if(ot(l.boardAdapter)){let _=await T(true);if(_.status!=="success")return _}return k}}}function F(){let d=()=>{let f=x();if(!f?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return f.nonCore};return {describeTaskExecutorCapabilities(f){return d().describeTaskExecutorCapabilities(f)},validateCardPreflight(f){return d().validateCardPreflight(f)},evalCardCompute(f){return d().evalCardCompute(f)},probeSourcePreflight(f){return d().probeSourcePreflight(f)},runSourcePreflight(f){return d().runSourcePreflight(f)},simulateCardCycle(f){return d().simulateCardCycle(f)}}}function c(){return {async get(d){let f=typeof d.params?.id=="string"?d.params.id:void 0;if(f){let l=await u(f);return l?{status:"success",data:{cards:[l]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await p()}}},async set(d){let f=d.body;if(f==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let l=Array.isArray(f)?f:[f];for(let k of l){let _=k,$=typeof _.id=="string"?_.id:"";if(!$)return {status:"fail",error:"each card must have a string `id` field"};let J=r.get($)??0,W=t[J]??x();if(!W)return {status:"fail",error:"Board context is unavailable"};let te=await W.cardStoreOps.set({body:_});if(te.status!=="success")return te;r.set($,J);}return {status:"success",data:{count:l.length}}},async del(d){let f=[d.params?.id,...d.body?.ids??[]].filter(l=>typeof l=="string"&&!!l);if(f.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let l of f){let k=n(l)??x();if(!k)return {status:"fail",error:"Board context is unavailable"};let _=await k.cardStoreOps.del({params:{id:l}});if(_.status!=="success")return _;r.delete(l);}return {status:"success",data:{count:f.length}}},async patch(d){let f=typeof d.params?.id=="string"?d.params.id:void 0,l=typeof d.params?.path=="string"?d.params.path:void 0;if(!f||!l)return {status:"fail",error:"patch requires params.id and params.path"};let k=n(f)??x();return k?k.cardStoreOps.patch(d):{status:"fail",error:"Board context is unavailable"}},async appendFiles(d){let f=typeof d.params?.id=="string"?d.params.id:void 0;if(!f)return {status:"fail",error:"appendFiles requires params.id"};let l=n(f)??x();return l?l.cardStoreOps.appendFiles(d):{status:"fail",error:"Board context is unavailable"}}}}function h(){return Wn({board:A(),nonCore:F(),cardStore:c(),chatStore:S,processAccumulated:()=>T(true),sourceFetchDone:({token:d,ref:f})=>E(d,f),sourceFetchFailed:({token:d,reason:f})=>y(d,f),uploadCardFile({cardId:d,fileName:f,contentType:l,bytes:k,suppressChatRecordWrite:_}){return C(d,f,l,k,{inChat:true,..._===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:d,fileIdx:f,storedName:l}){let k=`${R||""}${I}/cards/${encodeURIComponent(d)}/files/${f}`;return l?`${k}?sn=${encodeURIComponent(l)}`:k},readFetchedSourceJsonByRef({cardId:d,ref:f}){let l=n(d)??x();if(!l||ot(l.boardAdapter))return null;let $=l.boardAdapter.resolveBlob(at(f)).trim();return $?JSON.parse($):null}})}return {mcpBoardFacade:A,mcpNonCoreFacade:F,mcpCardStoreFacade:c,createMcpFacade:h}}function zn(e){let{apiBasePath:t,json:r,readJsonBody:n,bootstrapBoard:o,createMcpFacade:s,createMcpToolRegistry:i,resolveCardFileDownloadPayload:u,isLikelyTextMimeType:p,sliceTextByLines:T}=e;async function E(y,C,S){let R=y.method||"GET",I=S,x=I.pathname;try{if(R==="POST"&&x===`${t}/mcp`){await o();let A=await n(y),F=typeof A.tool=="string"?A.tool.trim():"",c=A.args&&typeof A.args=="object"&&!Array.isArray(A.args)?A.args:{};if(!F)return r(C,400,{error:"tool is required"}),!0;if(F==="inspect.file-contents")return r(C,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let h=await pt(F,c,i(s()));if(h&&typeof h=="object"&&!Array.isArray(h)){let d=h;if(d.status==="fail")return r(C,400,{error:rt(h,"Request failed")}),!0;if(d.status==="error")return r(C,500,{error:rt(h,"Internal error")}),!0}r(C,200,h);}catch(h){let d=typeof h?.statusCode=="number"?Number(h.statusCode):500,f=h instanceof Error?h.message:String(h);r(C,d,{error:f});}return !0}if(R==="POST"&&x===`${t}/mcp-raw`){await o();let A=await n(y),F=typeof A.tool=="string"?A.tool.trim():"",c=A.args&&typeof A.args=="object"&&!Array.isArray(A.args)?A.args:{};if(!F)return r(C,400,{error:"tool is required"}),!0;if(F!=="inspect.file-contents")return r(C,400,{error:`Tool does not support raw response: ${F}`}),!0;let h=ue(c,"card_id","cardId"),d=it(c,"file_idx","fileIdx"),f=it(c,"head-lines","headLines"),l=it(c,"tail-lines","tailLines"),k=it(c,"head-bytes","headBytes"),_=it(c,"tail-bytes","tailBytes");if(!h)return r(C,400,{error:"inspect.file-contents requires card_id"}),!0;if(d===void 0||!Number.isInteger(d)||d<0)return r(C,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([f,l,k,_].filter(L=>L!==void 0).length>1)return r(C,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[L,D]of [["head-lines",f],["tail-lines",l],["head-bytes",k],["tail-bytes",_]])if(D!==void 0&&(!Number.isInteger(D)||D<0))return r(C,400,{error:`inspect.file-contents requires ${L} to be a non-negative integer`}),!0;let J=await s().inspectFileContents({cardId:h,fileIdx:d}),W=typeof J?.stored_name=="string"?J.stored_name:null,{fileRecord:te,bytes:ie}=await u(h,d,W),X=String(te.name||te.stored_name||"download.bin"),ee=String(te.mime_type||"application/octet-stream"),ne=(I.searchParams.get("resp")||"").trim().toLowerCase();if(ne&&ne!=="json-b64")return r(C,400,{error:`unsupported resp mode: ${ne}`}),!0;let v=ne==="json-b64",g;if(f!==void 0||l!==void 0){if(!p(ee))return r(C,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let L=new TextDecoder().decode(ie),D=f!==void 0?T(L,"head",f):T(L,"tail",l);g=typeof Buffer<"u"?Buffer.from(D,"utf8"):new TextEncoder().encode(D);}else if(k!==void 0||_!==void 0){let L=k??_;g=k!==void 0?ie.slice(0,L):ie.slice(Math.max(0,ie.length-L));}else g=ie;if(v){let L=typeof Buffer<"u"?Buffer.from(g).toString("base64"):btoa(String.fromCharCode(...g));return r(C,200,{bodyBase64:L,mimeType:ee,filename:X,byteLength:g.length}),!0}return C.writeHead(200,{"Content-Type":ee,"Content-Disposition":`attachment; filename="${X}"`,"Content-Length":g.length}),C.end(g),!0}return !1}catch(A){let F=A?.statusCode||500;return r(C,F,{error:String(A?.message||A)}),true}}return {handleAgentfaceApi:E}}function Yn(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,createMcpWebhookToolRegistry:s}=e;async function i(u,p,T){let E=u.method||"GET",y=T.pathname;try{if(E==="POST"&&y===`${t}/mcp-webhooks`){await o();let C=await n(u),S=typeof C.tool=="string"?C.tool.trim():"",R=C.args&&typeof C.args=="object"&&!Array.isArray(C.args)?C.args:{};if(!S)return r(p,400,{error:"tool is required"}),!0;try{let I=await pt(S,R,s());if(I&&typeof I=="object"&&!Array.isArray(I)){let x=I;if(x.status==="fail")return r(p,400,{error:rt(I,"Request failed")}),!0;if(x.status==="error")return r(p,500,{error:rt(I,"Internal error")}),!0}r(p,200,I);}catch(I){let x=typeof I?.statusCode=="number"?Number(I.statusCode):500,A=I instanceof Error?I.message:String(I);r(p,x,{error:A});}return !0}return !1}catch(C){let S=C?.statusCode||500;return r(p,S,{error:String(C?.message||C)}),true}}return {handleWebhooksApi:i}}function Xn(e){let{sseHub:t,corsHeaders:r,json:n,buildPublishedRuntimePayload:o,onSseClientConnected:s,onChannelSubscribed:i,onChannelUnsubscribed:u}=e;function p(E,y,C,S,R){if(!t.has(y)){n(E,404,{error:`SSE client not connected: ${y}`});return}R?i?.(y,C,S):u?.(y,C,S),n(E,200,{ok:true,clientId:y,channelName:C,...S.cardId?{cardId:S.cardId}:{},subscribed:R});}async function T(E,y,C,S){let R=S?.oneShot===true,I=!R&&C?t.get(C):null,x=I?new Set(I.subscribedChatCardIds):new Set;y.writeHead(200,{...r,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),t.flushTransport(y);let A=await o(),F=t.buildFrame(A);if(y.write(F),R){y.end();return}if(!C)throw new Error("clientId is required for streaming SSE");t.register(C,y,x);try{s?.(C,h=>{t.writeFrame(C,h);});}catch{}let c=setInterval(()=>{try{y.write(`: keepalive
5
5
 
6
- `);}catch{}},15e3);E.on("close",()=>{clearInterval(c),t.disconnect(C,y);});}return {handleChannelSubscription:p,handleSse:T}}function Zn(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,bootstrapBoard:s,boardContexts:i,publishPersistedStateSnapshot:u,upsertCardsFromSource:p,sseHub:T}=e,{handleSse:E,handleChannelSubscription:y}=Xn(e);async function C(S,R,I){let x=S.method||"GET",A=I,F=A.pathname;try{if(x==="GET"&&F===`${t}/sse`){let l=A.searchParams.has("one-shot");await o();let k=String(A.searchParams.get("clientId")||"").trim();if(!l&&!k)return r(R,400,{error:"clientId query param is required for SSE"}),!0;if(await E(S,R,k||void 0,{oneShot:l}),l)return !0;for(let _=0;_<i.length;_++)await u(i[_]),await p(i[_],_),await u(i[_]);return !0}let c=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(x==="POST"&&c){await s();let l=decodeURIComponent(c[1]),k=await n(S),_=typeof k?.clientId=="string"?k.clientId.trim():"";return _?await T.subscribeChat(_,l)?(r(R,200,{ok:!0,clientId:_,cardId:l,subscribed:!0}),!0):(r(R,404,{error:`SSE client not connected: ${_}`}),!0):(r(R,400,{error:"clientId is required"}),!0)}let h=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(x==="POST"&&h){await s();let l=decodeURIComponent(h[1]),k=await n(S),_=typeof k?.clientId=="string"?k.clientId.trim():"";return _?T.unsubscribeChat(_,l)?(r(R,200,{ok:!0,clientId:_,cardId:l,subscribed:!1}),!0):(r(R,404,{error:`SSE client not connected: ${_}`}),!0):(r(R,400,{error:"clientId is required"}),!0)}let d=F.match(new RegExp(`^${st(t)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(x==="POST"&&d){await s();let l=decodeURIComponent(d[1]),k=d[2]==="subscribe",_=await n(S),$=typeof _?.clientId=="string"?_.clientId.trim():"";return $?(y(R,$,l,{},k),!0):(r(R,400,{error:"clientId is required"}),!0)}let f=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(x==="POST"&&f){await s();let l=decodeURIComponent(f[1]),k=decodeURIComponent(f[2]),_=f[3]==="subscribe",$=await n(S),J=typeof $?.clientId=="string"?$.clientId.trim():"";return J?(y(R,J,k,{cardId:l},_),!0):(r(R,400,{error:"clientId is required"}),!0)}return !1}catch(c){let h=c?.statusCode||500;return r(R,h,{error:String(c?.message||c)}),true}}return {handleWatchersRoutes:C,handleSse:E,handleChannelSubscription:y}}var to={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},eo="chat-handler-flow-queue",Bt="__probe__echo__probe__";function ts(e){let t=String(e.apiBasePath||"/api/board").replace(/\/$/,""),r={...to,...e.corsHeaders||{}},n=e.queueLaneTuning??{},o=e.boardId||"",s=e.logger||{info:console.log,warn:console.warn,error:console.error},i=e.invocationAdapter,u=e.chatFlowRunner||null,p=e.notificationTransport||null,T=e.serverUrl||null,E=e.executionExtra||{},y=e.onSseClientConnected,C=e.onSseClientDisconnected,S=e.onChannelSubscribed,R=e.onChannelUnsubscribed,I=Mn({readChatRecords:a=>m(a),getChatProcessing:a=>b(a),readChatAfter:async(a,P)=>{let O=await w(a,P);return {records:O.records,cursor:O.cursor}},onSseClientDisconnected:C});function x(a){function P(Q){if(Array.isArray(Q))return Q;if(Q&&typeof Q=="object"){let ue=Q;return Array.isArray(ue.files)?ue.files:[Q]}return null}function O(Q){return {async get(ue){return Q.get(ue)},async set(ue){return Q.set(ue)},async del(ue){return Q.del(ue)},async patch(ue){return Q.patch(ue)},async appendFiles(ue){return Q.appendFiles(ue)}}}function G(Q){function ue(Ie){return {status:"success",data:Ie}}function Ce(Ie){return {status:"fail",error:Ie}}function ge(Ie){return {status:"error",error:Ie instanceof Error?Ie.message:String(Ie)}}return {async get(Ie){try{let xe=Ie.params?.id;if(xe){let Ue=await Q.readCard(xe);return Ue?ue({cards:[Ue]}):Ce(`card "${xe}" not found`)}return ue({cards:await Q.readAllCards()})}catch(xe){return ge(xe)}},async set(Ie){try{let xe=Ie.body;if(xe==null)return Ce("set requires a body (card object or array of cards)");let Ue=Array.isArray(xe)?xe:[xe];for(let Je of Ue){if(typeof Je.id!="string")return Ce("each card must have a string `id` field");await Q.writeCard(Je.id,Je);}return ue({count:Ue.length})}catch(xe){return ge(xe)}},async del(Ie){try{let xe=Ie.body?.ids??[],Ue=Ie.params?.id,Je=Ue?[...xe,Ue]:xe;if(Je.length===0)return Ce("del requires body.ids (string[]) or params.id");for(let wt of Je)await Q.removeCard(wt);return ue({count:Je.length})}catch(xe){return ge(xe)}},async patch(Ie){try{let xe=Ie.params?.id,Ue=Ie.params?.path;if(!xe)return Ce("patch requires params.id");if(!Ue)return Ce("patch requires params.path");let Je=Ie.body,wt=Je&&Object.prototype.hasOwnProperty.call(Je,"value")?Je.value:Ie.body;return await Q.patchCard(xe,Ue,wt),ue({count:1})}catch(xe){return ge(xe)}},async appendFiles(Ie){try{let xe=Ie.params?.id;if(!xe)return Ce("appendFiles requires params.id");let Ue=await Q.readCard(xe);if(!Ue)return Ce(`card "${xe}" not found`);let Je=P(Ie.body);if(!Je||Je.length===0)return Ce("appendFiles requires a file metadata object, array, or body.files array");let wt=Ue.card_data&&typeof Ue.card_data=="object"&&!Array.isArray(Ue.card_data)?Ue.card_data:{},Dr=Array.isArray(wt.files)?wt.files:[],no=[...Dr,...Je];return await Q.patchCard(xe,"card_data.files",no),ue({files_added:Je.map((oo,so)=>({idx:Dr.length+so,entry:oo}))})}catch(xe){return ge(xe)}}}}let B=ot(a.boardAdapter)?En(a.baseRef,a.boardAdapter,{boardRuntimeStoreRef:a.boardRuntimeStoreRef,scratchStoreRef:a.scratchStoreRef,taskExecutorRef:a.taskExecutorRef,chatHandlerFlow:a.chatHandlerFlow}):Sn(a.baseRef,a.boardAdapter,{boardRuntimeStoreRef:a.boardRuntimeStoreRef,scratchStoreRef:a.scratchStoreRef,taskExecutorRef:a.taskExecutorRef,chatHandlerFlow:a.chatHandlerFlow}),N=a.nonCoreAdapter??(!ot(a.boardAdapter)&&f(a.boardAdapter)?a.boardAdapter:null),Y=a.nonCore??(N?bn(a.baseRef,N,{boardRuntimeStoreRef:a.boardRuntimeStoreRef,taskExecutorRef:a.taskExecutorRef}):null),he=a.boardAdapter.chatStorageForRef(a.chatStoreRef),le,Te=ot(a.boardAdapter)?(()=>{let Q=dr(ur(ir(a.boardAdapter.kvStorageForRef(a.cardStoreRef)),a.boardAdapter.hashFn),s.warn),ue=G(Q);return le={get(Ce){return ue.get(Ce)},set(Ce){return ue.set(Ce)}},ue})():(()=>{let Q=a.boardAdapter.kvStorageForRef(a.cardStoreRef),Ce=nr(Et({readIndex:()=>Q.read("_index"),writeIndex:ge=>Q.write("_index",ge),readCard:ge=>Q.read(ge),writeCard:(ge,Ie)=>(Q.write(ge,Ie),ge),removeCard:ge=>{Q.delete(ge);},cardExists:ge=>Q.read(ge)!==null,defaultCardKey:ge=>ge},s.warn));return le=Ce,O(Ce)})(),Oe;if(ot(a.boardAdapter)){let Q=a.boardAdapter.blobStorageForRef(a.artifactsStoreRef);Oe={async putBytes(ue,Ce){if(Q.writeBytes){await Q.writeBytes(ue,Ce);return}let ge=JSON.stringify({__kind:"bytes-array",data:[...Ce]});await Q.write(ue,ge);},async getBytes(ue){if(Q.readBytes){let ge=await Q.readBytes(ue);if(ge!==null)return ge}let Ce=await Q.read(ue);if(Ce===null)return null;try{let ge=JSON.parse(Ce);if(ge&&ge.__kind==="bytes-array"&&Array.isArray(ge.data))return new Uint8Array(ge.data)}catch{}return new TextEncoder().encode(Ce)},async listKeys(ue){return await Q.listKeys(ue)}};}else {let Q=a.boardAdapter.blobStorageForRef(a.artifactsStoreRef),ue=On(Q);Oe={putBytes(Ce,ge,Ie){ue.putBytes(Ce,ge,Ie);},getBytes(Ce){return ue.getBytes(Ce)},listKeys(Ce){return ue.list(Ce).map(ge=>ge.key)}};}let De={async init(Q){return B.init(Q)},async status(Q){return B.status(Q)},async getConfig(Q){return B.getConfig(Q)},async getAllOutputsDataObjects(Q){return B.getAllOutputsDataObjects(Q)},async getAllOutputsComputedValues(Q){return B.getAllOutputsComputedValues(Q)},async getOutputsFetchedSources(Q){return B.getOutputsFetchedSources(Q)},async upsertCard(Q){return B.upsertCard(Q)},async removeCard(Q){return B.removeCard(Q)},async cardRefreshedNotify(Q){return B.cardRefreshedNotify(Q)},async sourceDataFetched(Q){return B.sourceDataFetched(Q)},async sourceDataFetchFailure(Q){return B.sourceDataFetchFailure(Q)}};return {label:a.label,board:B,nonCore:Y,publicCardStore:le,boardOps:De,cardStoreOps:Te,get filesArtifacts(){return Oe},get chatStorage(){return he},boardAdapter:a.boardAdapter,boardRuntimeStoreRef:a.boardRuntimeStoreRef,cardStoreRef:a.cardStoreRef,outputsStoreRef:a.outputsStoreRef,artifactsStoreRef:a.artifactsStoreRef,fetchedSourcesStoreRef:a.fetchedSourcesStoreRef,queueStoreRef:a.queueStoreRef,chatStoreRef:a.chatStoreRef,scratchStoreRef:a.scratchStoreRef,notifyRef:a.notifyRef,taskExecutorRef:a.taskExecutorRef,chatHandlerRef:a.chatHandlerRef,chatHandlerFlow:a.chatHandlerFlow,inferenceAdapterRef:a.inferenceAdapterRef,notification:Ln(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let A=e.boards.map(x),F=new Map;function c(a){return F.get(a)??0}function h(a){return a.queueStoreRef}function d(a,P){if(ot(a.boardAdapter)){let G=a.boardAdapter.queueStorageForRef(h(a),P);return xr(G)}let O=a.boardAdapter.queueStorageForRef(h(a),P);return Tr(O)}function f(a){let P=a;return typeof P.invokeExecutor=="function"&&typeof P.validateSchema=="function"}function l(a){let P=A[c(a)];return {files:P?P.filesArtifacts:null}}function k(){return qn()}function _(a){return String(a||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function $(a){if(!a||a.notificationTeardown||!p||!a.notifyRef)return;let P=await p.subscribe(a.notifyRef,O=>{_r(a.notification,O);let G=O.kind==="notification-batch"?O.notifications:[O];I.broadcastNotificationBatch(G);});a.notificationTeardown=P;}async function J(a){if(!a||a.initialized)return;let P={boardRuntimeStoreRef:a.boardRuntimeStoreRef,cardStoreRef:a.cardStoreRef,outputsStoreRef:a.outputsStoreRef,fetchedSourcesStoreRef:a.fetchedSourcesStoreRef,artifactsStoreRef:a.artifactsStoreRef,queueStoreRef:a.queueStoreRef,chatStoreRef:a.chatStoreRef,scratchStoreRef:a.scratchStoreRef},O={};a.taskExecutorRef&&(O["task-executor-ref"]=a.taskExecutorRef),a.chatHandlerFlow!==void 0&&(O["chat-handler-flow"]=a.chatHandlerFlow);let G=await a.boardOps.init({params:P,body:O});if(G.status!=="success")throw Object.assign(new Error(G.error||`init failed for ${a.label}`),{statusCode:500});if(await $(a),!a.chatHandlerFlow&&a.chatHandlerRef&&i.describe)try{let B=await i.describe(a.chatHandlerRef);B&&B.kind!=="chat-handler"?s.warn(`[init] chat-handler describe returned kind="${B.kind}", expected "chat-handler" for ${a.label}`):B&&s.info(`[init] chat-handler validated: ${B.name} (protocol ${B.protocolVersion}) for ${a.label}`);}catch(B){s.warn(`[init] chat-handler describe failed for ${a.label}: ${B?.message||String(B)}`);}a.initialized=true;}async function W(a){if(!a.boardAdapter.publishBoardChangeNotifications)return;let P=[],O=await a.boardOps.status({});O.status==="success"&&O.data!=null&&Pr(O.data)&&P.push({kind:"status",status:O.data});let G=await a.boardOps.getAllOutputsDataObjects({});if(G.status==="success"&&G.data!=null)for(let[N,Y]of Object.entries(G.data))N&&P.push({kind:"data_object",key:N,payload:Y});let B=await a.boardOps.getAllOutputsComputedValues({});if(B.status==="success"&&B.data!=null)for(let[N,Y]of Object.entries(B.data))N&&P.push({kind:"computed_values",cardId:N,values:Y});P.length>0&&a.boardAdapter.publishBoardChangeNotifications(P);}async function te(a,P){if(!a||a.cardsBootstrapped)return;let O=await a.cardStoreOps.get({}),G=O.status==="success"&&Array.isArray(O.data?.cards)?O.data.cards:[];for(let B of G)typeof B.id=="string"&&(F.set(B.id,P),await a.boardOps.upsertCard({params:{cardId:B.id}}));a.cardsBootstrapped=true;}async function ie(){for(let a of A)await J(a);}async function X(){await ie();for(let a=0;a<A.length;a++)await W(A[a]),await te(A[a],a),await W(A[a]);}async function ee(a=false){a||await ie();for(let P of A){let O=await P.board.processAccumulatedEvents({});if(O.status!=="success")return O}return {status:"success"}}function ne(a){return A[c(a)]??null}async function v(a){let P=ne(a);if(!P)return null;let O=await P.cardStoreOps.get({params:{id:a}});if(O.status!=="success")return null;let G=Array.isArray(O.data?.cards)?O.data.cards:[];return G.length>0?G[0]:null}async function g(){let a=async O=>{if(!O)return [];let G=await O.cardStoreOps.get({});return G.status!=="success"||!Array.isArray(G.data?.cards)?[]:G.data.cards},P=[];for(let O of A)P.push(...await a(O));return P}function L(){return A[0]??null}function D(a){return ne(a)??L()}function H(a){let P=D(a);if(!P)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${a}`),{statusCode:404});return P.chatStorage}async function w(a,P){return await H(a).readAfter(a,P)}async function b(a){return await H(a).isProcessing(a)}async function q(a,P){await H(a).setProcessing(a,P),await I.broadcastCardChats(a,true);}let U=jn({append(a,P,O,G,B){return Promise.resolve(H(a).append(a,P,O,G,B)).then(async N=>(await I.broadcastCardChats(a,true),N))},readAll(a){return H(a).readAll(a)},readAfter(a,P){return H(a).readAfter(a,P)},clear(a){return H(a).clear(a)},setProcessing(a,P){return Promise.resolve(H(a).setProcessing(a,P)).then(async()=>{await I.broadcastCardChats(a,true);})},isProcessing(a){return H(a).isProcessing(a)},getConfig(a){return H(a).getConfig(a)},setConfig(a,P){return H(a).setConfig(a,P)}}),V=Qn({boardContexts:A,cardOwnerIndex:F,cardContextForCard:a=>ne(a),readStatusSnapshot:()=>ce(),readDataObjectsByToken:()=>ve(),readCardRuntimeArtifacts:()=>Le(),readCardFromStore:a=>v(a),readCardDefinitions:()=>g(),processAccumulatedLaneInternal:a=>ee(a),reportSourceFetched:(a,P)=>kt(a,{ref:P}),reportSourceFetchFailure:(a,P)=>Ct(a,{reason:P}),uploadCardFile:(a,P,O,G,B)=>K(a,P,O,G,B),chatStorePublic:U,serverUrl:T,apiBasePath:t}),Z=V.mcpCardStoreFacade,ae=V.createMcpFacade,fe=Dn({boardId:o,bootstrapBoard:()=>X(),sseHub:I,onChannelSubscribed:S,onChannelUnsubscribed:R,getMcpFacade:()=>ae(),getMcpCardStoreFacade:()=>Z()});function we(a){return Un(a)}function Pe(){return Vn(ae())}function Be(){return Kn({boardId:o,uploadCardFile:K,getMcpFacade:()=>ae(),controlplane:fe})}let Se=Nn({boardId:o,boardContexts:A,readCardDefinitions:()=>g(),readChatRecords:a=>m(a),getChatProcessing:a=>b(a)}),ce=Se.readStatusSnapshot,Le=Se.readCardRuntimeArtifacts,ve=Se.readDataObjectsByToken,Me=Se.buildPublishedRuntimePayload;async function Ne(a,P,O){let G=O?.syncBoard!==false,B=O?.restartOnlyIfChanged===true,N=ne(a);if(!N)throw Object.assign(new Error(`Card not found: ${a}`),{statusCode:404});let Y=await v(a);if(!Y)throw Object.assign(new Error(`Card not found: ${a}`),{statusCode:404});let he=B?JSON.stringify(Y):null,le=P(Y)||Y;if(B&&JSON.stringify(le)===he)return;let Te=await N.cardStoreOps.set({body:le});if(Te.status!=="success")throw Object.assign(new Error(Te.error||`Failed to persist card: ${a}`),{statusCode:500});if(G){let Oe=await N.boardOps.upsertCard({params:{cardId:a,restart:true}});if(Oe.status!=="success")throw Object.assign(new Error(Oe.error||`Failed to upsert card: ${a}`),{statusCode:500})}}async function me(a,P){await Ne(a,P,{syncBoard:true});}async function Ze(a,P){await Ne(a,P,{syncBoard:false});}async function Ke(a){let P=ne(a);if(!P)throw Object.assign(new Error(`Card not found: ${a}`),{statusCode:404});if(!await v(a))throw Object.assign(new Error(`Card not found: ${a}`),{statusCode:404});let G=await P.boardOps.upsertCard({params:{cardId:a,restart:true}});if(G.status!=="success")throw Object.assign(new Error(G.error||`Failed to retrigger card: ${a}`),{statusCode:500})}async function Ge(a){await H(a).clear(a);try{await q(a,!1);}catch{}}async function M(a,P,O,G,B=""){let N=typeof O=="string"?O.trim():"",Y=await H(a).append(a,P||"system",N,G,B);return await I.broadcastCardChats(a,true),Y}async function m(a){return await H(a).readAll(a)}let K=$n({safeCardId:a=>_(a),artifactsStores:a=>l(a),cardFileMetadataStore:()=>k(),readCardFromStore:a=>v(a),updateCardLocalOnly:(a,P)=>Ze(a,P),writeChatRecord:(a,P,O,G,B)=>M(a,P,O,G,B)}).uploadCardFile;async function oe(a){let P=ne(a);if(!P)return null;let O=await P.boardOps.getConfig({params:{key:"chat-handler-flow"}}),B=(O.status==="success"?O.data?.value:null)??P.chatHandlerFlow??null,N=P.chatHandlerRef;return B==null&&(!N||typeof N!="object")?null:{ctx:P,handlerFlow:B,handlerRef:N}}function re(a){let P=typeof a=="string"?a.trim():"";if(P.length<Bt.length*2||!P.startsWith(Bt)||!P.endsWith(Bt))return null;let O=P.slice(Bt.length,P.length-Bt.length).trim(),G=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(O);return G?{assistant:G[1].trim().toLowerCase(),text:G[2].trim()}:{assistant:"echo",text:O}}async function Ae(a,P,O=false,G="",B=""){try{let N=await oe(a);if(!N){try{await q(a,!1);}catch{}return}let{ctx:Y,handlerFlow:he,handlerRef:le}=N;if(!O)try{await q(a,!0);}catch{}let Te={boardId:o,cardId:String(a),lastChatEntryId:P,...G?{turnId:G}:{},...typeof B=="string"&&B.trim()?{probe:B.trim()}:{},...E,...T?{serverUrl:T}:{}},Oe=he!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:eo}}:le;ot(Y.boardAdapter)?await d(Y,"chat-agent").enqueueRequest({boardId:o,ref:Oe,args:he!=null?{...Te,__chatHandlerFlow:he}:Te}):d(Y,"chat-agent").enqueueRequest({boardId:o,ref:Oe,args:he!=null?{...Te,__chatHandlerFlow:he}:Te}),await Promise.resolve(Y.boardAdapter.requestProcessAccumulated?.());}catch(N){try{await q(a,!1);}catch{}s.warn(`[chat-handler] queue failed for card "${a}": ${N instanceof Error?N.message:String(N)}`);}}async function be(a,P,O){if(P.howToRun==="built-in"&&Ur(P)===eo){let G=u,B=O.__chatHandlerFlow,N={...O};return delete N.__chatHandlerFlow,G?G.run(B,N,{boardId:o,cardId:String(N.cardId||""),label:a.label,logger:s,serverUrl:T,executionExtra:E}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return i.invoke(P,O)}async function Fe(a,P=false){P||await ie();let O=typeof a.args?.cardId=="string"?a.args.cardId:"",G=O?ne(O):L();if(!G)throw new Error(O?`Board context is unavailable for chat-agent request: ${O}`:"Board context is unavailable for chat-agent request");let B=await be(G,a.ref,a.args);if(!B.dispatched){if(O)try{await q(O,!1);}catch{}throw new Error(B.error||`chat-agent dispatch failed for card "${O||"unknown"}"`)}}async function qe(a,P,O){if(P==="chat-send"){let B=O&&typeof O["turn-id"]=="string"?O["turn-id"]:O&&typeof O.turnId=="string"?O.turnId:O&&typeof O.turn=="string"?O.turn:"";if(O&&"files"in O&&O.files!==void 0&&O.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 N=Be(),Y=re(O?.text),he=Y?Y.text:O?.text,le=await pt("manage.add-chat-entry-and-any-attachments",{board_id:o,card_id:a,role:"user",text:he,turn_id:B,files:[]},N);if(le?.status!=="success")throw new Error(rt(le,`chat-send append failed for card ${a}`));let Te=le?.data?.id;if(typeof Te!="string"||!Te)throw new Error(`chat-send did not return an append id for card ${a}`);let Oe=await pt("setstate.chat-processing-started",{board_id:o,card_id:a},N);if(Oe?.status!=="success")throw new Error(rt(Oe,`chat-send processing update failed for card ${a}`));Ae(a,Te,true,B,Y?.assistant||"");return}await me(a,B=>{let N=new Date().toISOString(),Y=B.card_data&&typeof B.card_data=="object"?B.card_data:{};if(B.card_data=Y,P==="file-upload"){let he=k().normalizeIncoming(O?.files,N);return he.length>0&&k().merge(Y,he),B}if(P==="action"){let he=O&&typeof O.buttonId=="string"?O.buttonId:"";if(!he)return B;Y.lastAction={buttonId:he,at:N},Y.lastActionText=`${he} @ ${N}`;}return B});}function $e(a,P,O){let G=JSON.stringify(O),B=typeof Buffer<"u"?Buffer.byteLength(G):new TextEncoder().encode(G).length;a.writeHead(P,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":B}),a.end(G);}async function We(a,P,O){let G=await v(a);if(!G)throw Object.assign(new Error("Card not found"),{statusCode:404});let B=k().resolve(G.card_data,P,O);if(!B.ok&&B.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!B.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let N=B.file,Y=_(a),he=l(a),le=String(N.stored_name||""),Te=`${Y}/${le}`,Oe=he.files?await he.files.getBytes(Te):null;if(!Oe)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:N,bytes:Oe}}async function He(a,P,O,G){let{fileRecord:B,bytes:N}=await We(P,O,G),Y=String(B.name||B.stored_name||"download.bin"),he=String(B.mime_type||"application/octet-stream");a.writeHead(200,{"Content-Type":he,"Content-Disposition":`attachment; filename="${Y}"`,"Content-Length":N.length}),a.end(N);}function lt(a){let P=String(a||"").toLowerCase();return P.startsWith("text/")||P.includes("json")||P.includes("xml")||P.includes("javascript")||P.includes("typescript")||P.includes("yaml")||P.includes("csv")}function et(a,P,O){let G=a.split(/\r?\n/);return (P==="head"?G.slice(0,O):G.slice(-O)).join(`
6
+ `);}catch{}},15e3);E.on("close",()=>{clearInterval(c),t.disconnect(C,y);});}return {handleChannelSubscription:p,handleSse:T}}function Zn(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,bootstrapBoard:s,boardContexts:i,publishPersistedStateSnapshot:u,upsertCardsFromSource:p,sseHub:T}=e,{handleSse:E,handleChannelSubscription:y}=Xn(e);async function C(S,R,I){let x=S.method||"GET",A=I,F=A.pathname;try{if(x==="GET"&&F===`${t}/sse`){let l=A.searchParams.has("one-shot");await o();let k=String(A.searchParams.get("clientId")||"").trim();if(!l&&!k)return r(R,400,{error:"clientId query param is required for SSE"}),!0;if(await E(S,R,k||void 0,{oneShot:l}),l)return !0;for(let _=0;_<i.length;_++)await u(i[_]),await p(i[_],_),await u(i[_]);return !0}let c=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(x==="POST"&&c){await s();let l=decodeURIComponent(c[1]),k=await n(S),_=typeof k?.clientId=="string"?k.clientId.trim():"";return _?await T.subscribeChat(_,l)?(r(R,200,{ok:!0,clientId:_,cardId:l,subscribed:!0}),!0):(r(R,404,{error:`SSE client not connected: ${_}`}),!0):(r(R,400,{error:"clientId is required"}),!0)}let h=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(x==="POST"&&h){await s();let l=decodeURIComponent(h[1]),k=await n(S),_=typeof k?.clientId=="string"?k.clientId.trim():"";return _?T.unsubscribeChat(_,l)?(r(R,200,{ok:!0,clientId:_,cardId:l,subscribed:!1}),!0):(r(R,404,{error:`SSE client not connected: ${_}`}),!0):(r(R,400,{error:"clientId is required"}),!0)}let d=F.match(new RegExp(`^${st(t)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(x==="POST"&&d){await s();let l=decodeURIComponent(d[1]),k=d[2]==="subscribe",_=await n(S),$=typeof _?.clientId=="string"?_.clientId.trim():"";return $?(y(R,$,l,{},k),!0):(r(R,400,{error:"clientId is required"}),!0)}let f=F.match(new RegExp(`^${st(t)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(x==="POST"&&f){await s();let l=decodeURIComponent(f[1]),k=decodeURIComponent(f[2]),_=f[3]==="subscribe",$=await n(S),J=typeof $?.clientId=="string"?$.clientId.trim():"";return J?(y(R,J,k,{cardId:l},_),!0):(r(R,400,{error:"clientId is required"}),!0)}return !1}catch(c){let h=c?.statusCode||500;return r(R,h,{error:String(c?.message||c)}),true}}return {handleWatchersRoutes:C,handleSse:E,handleChannelSubscription:y}}var to={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},eo="chat-handler-flow-queue",Bt="__probe__echo__probe__";function ts(e){let t=String(e.apiBasePath||"/api/board").replace(/\/$/,""),r={...to,...e.corsHeaders||{}},n=e.queueLaneTuning??{},o=e.boardId||"",s=e.logger||{info:console.log,warn:console.warn,error:console.error},i=e.invocationAdapter,u=e.chatFlowRunner||null,p=e.notificationTransport||null,T=e.serverUrl||null,E=e.executionExtra||{},y=e.onSseClientConnected,C=e.onSseClientDisconnected,S=e.onChannelSubscribed,R=e.onChannelUnsubscribed,I=Mn({readChatRecords:a=>m(a),getChatProcessing:a=>b(a),readChatAfter:async(a,P)=>{let O=await w(a,P);return {records:O.records,cursor:O.cursor}},onSseClientDisconnected:C});function x(a){function P(Q){if(Array.isArray(Q))return Q;if(Q&&typeof Q=="object"){let de=Q;return Array.isArray(de.files)?de.files:[Q]}return null}function O(Q){return {async get(de){return Q.get(de)},async set(de){return Q.set(de)},async del(de){return Q.del(de)},async patch(de){return Q.patch(de)},async appendFiles(de){return Q.appendFiles(de)}}}function G(Q){function de(Ie){return {status:"success",data:Ie}}function Ce(Ie){return {status:"fail",error:Ie}}function ge(Ie){return {status:"error",error:Ie instanceof Error?Ie.message:String(Ie)}}return {async get(Ie){try{let xe=Ie.params?.id;if(xe){let Ue=await Q.readCard(xe);return Ue?de({cards:[Ue]}):Ce(`card "${xe}" not found`)}return de({cards:await Q.readAllCards()})}catch(xe){return ge(xe)}},async set(Ie){try{let xe=Ie.body;if(xe==null)return Ce("set requires a body (card object or array of cards)");let Ue=Array.isArray(xe)?xe:[xe];for(let Je of Ue){if(typeof Je.id!="string")return Ce("each card must have a string `id` field");await Q.writeCard(Je.id,Je);}return de({count:Ue.length})}catch(xe){return ge(xe)}},async del(Ie){try{let xe=Ie.body?.ids??[],Ue=Ie.params?.id,Je=Ue?[...xe,Ue]:xe;if(Je.length===0)return Ce("del requires body.ids (string[]) or params.id");for(let wt of Je)await Q.removeCard(wt);return de({count:Je.length})}catch(xe){return ge(xe)}},async patch(Ie){try{let xe=Ie.params?.id,Ue=Ie.params?.path;if(!xe)return Ce("patch requires params.id");if(!Ue)return Ce("patch requires params.path");let Je=Ie.body,wt=Je&&Object.prototype.hasOwnProperty.call(Je,"value")?Je.value:Ie.body;return await Q.patchCard(xe,Ue,wt),de({count:1})}catch(xe){return ge(xe)}},async appendFiles(Ie){try{let xe=Ie.params?.id;if(!xe)return Ce("appendFiles requires params.id");let Ue=await Q.readCard(xe);if(!Ue)return Ce(`card "${xe}" not found`);let Je=P(Ie.body);if(!Je||Je.length===0)return Ce("appendFiles requires a file metadata object, array, or body.files array");let wt=Ue.card_data&&typeof Ue.card_data=="object"&&!Array.isArray(Ue.card_data)?Ue.card_data:{},Dr=Array.isArray(wt.files)?wt.files:[],no=[...Dr,...Je];return await Q.patchCard(xe,"card_data.files",no),de({files_added:Je.map((oo,so)=>({idx:Dr.length+so,entry:oo}))})}catch(xe){return ge(xe)}}}}let B=ot(a.boardAdapter)?En(a.baseRef,a.boardAdapter,{boardRuntimeStoreRef:a.boardRuntimeStoreRef,scratchStoreRef:a.scratchStoreRef,taskExecutorRef:a.taskExecutorRef,chatHandlerFlow:a.chatHandlerFlow}):Sn(a.baseRef,a.boardAdapter,{boardRuntimeStoreRef:a.boardRuntimeStoreRef,scratchStoreRef:a.scratchStoreRef,taskExecutorRef:a.taskExecutorRef,chatHandlerFlow:a.chatHandlerFlow}),N=a.nonCoreAdapter??(!ot(a.boardAdapter)&&f(a.boardAdapter)?a.boardAdapter:null),Y=a.nonCore??(N?bn(a.baseRef,N,{boardRuntimeStoreRef:a.boardRuntimeStoreRef,taskExecutorRef:a.taskExecutorRef}):null),he=a.boardAdapter.chatStorageForRef(a.chatStoreRef),le,Te=ot(a.boardAdapter)?(()=>{let Q=dr(ur(ir(a.boardAdapter.kvStorageForRef(a.cardStoreRef)),a.boardAdapter.hashFn),s.warn),de=G(Q);return le={get(Ce){return de.get(Ce)},set(Ce){return de.set(Ce)}},de})():(()=>{let Q=a.boardAdapter.kvStorageForRef(a.cardStoreRef),Ce=nr(Et({readIndex:()=>Q.read("_index"),writeIndex:ge=>Q.write("_index",ge),readCard:ge=>Q.read(ge),writeCard:(ge,Ie)=>(Q.write(ge,Ie),ge),removeCard:ge=>{Q.delete(ge);},cardExists:ge=>Q.read(ge)!==null,defaultCardKey:ge=>ge},s.warn));return le=Ce,O(Ce)})(),Oe;if(ot(a.boardAdapter)){let Q=a.boardAdapter.blobStorageForRef(a.artifactsStoreRef);Oe={async putBytes(de,Ce){if(Q.writeBytes){await Q.writeBytes(de,Ce);return}let ge=JSON.stringify({__kind:"bytes-array",data:[...Ce]});await Q.write(de,ge);},async getBytes(de){if(Q.readBytes){let ge=await Q.readBytes(de);if(ge!==null)return ge}let Ce=await Q.read(de);if(Ce===null)return null;try{let ge=JSON.parse(Ce);if(ge&&ge.__kind==="bytes-array"&&Array.isArray(ge.data))return new Uint8Array(ge.data)}catch{}return new TextEncoder().encode(Ce)},async listKeys(de){return await Q.listKeys(de)}};}else {let Q=a.boardAdapter.blobStorageForRef(a.artifactsStoreRef),de=On(Q);Oe={putBytes(Ce,ge,Ie){de.putBytes(Ce,ge,Ie);},getBytes(Ce){return de.getBytes(Ce)},listKeys(Ce){return de.list(Ce).map(ge=>ge.key)}};}let De={async init(Q){return B.init(Q)},async status(Q){return B.status(Q)},async getConfig(Q){return B.getConfig(Q)},async getAllOutputsDataObjects(Q){return B.getAllOutputsDataObjects(Q)},async getAllOutputsComputedValues(Q){return B.getAllOutputsComputedValues(Q)},async getOutputsFetchedSources(Q){return B.getOutputsFetchedSources(Q)},async upsertCard(Q){return B.upsertCard(Q)},async removeCard(Q){return B.removeCard(Q)},async cardRefreshedNotify(Q){return B.cardRefreshedNotify(Q)},async sourceDataFetched(Q){return B.sourceDataFetched(Q)},async sourceDataFetchFailure(Q){return B.sourceDataFetchFailure(Q)}};return {label:a.label,board:B,nonCore:Y,publicCardStore:le,boardOps:De,cardStoreOps:Te,get filesArtifacts(){return Oe},get chatStorage(){return he},boardAdapter:a.boardAdapter,boardRuntimeStoreRef:a.boardRuntimeStoreRef,cardStoreRef:a.cardStoreRef,outputsStoreRef:a.outputsStoreRef,artifactsStoreRef:a.artifactsStoreRef,fetchedSourcesStoreRef:a.fetchedSourcesStoreRef,queueStoreRef:a.queueStoreRef,chatStoreRef:a.chatStoreRef,scratchStoreRef:a.scratchStoreRef,notifyRef:a.notifyRef,taskExecutorRef:a.taskExecutorRef,chatHandlerRef:a.chatHandlerRef,chatHandlerFlow:a.chatHandlerFlow,inferenceAdapterRef:a.inferenceAdapterRef,notification:Ln(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let A=e.boards.map(x),F=new Map;function c(a){return F.get(a)??0}function h(a){return a.queueStoreRef}function d(a,P){if(ot(a.boardAdapter)){let G=a.boardAdapter.queueStorageForRef(h(a),P);return xr(G)}let O=a.boardAdapter.queueStorageForRef(h(a),P);return Tr(O)}function f(a){let P=a;return typeof P.invokeExecutor=="function"&&typeof P.validateSchema=="function"}function l(a){let P=A[c(a)];return {files:P?P.filesArtifacts:null}}function k(){return qn()}function _(a){return String(a||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function $(a){if(!a||a.notificationTeardown||!p||!a.notifyRef)return;let P=await p.subscribe(a.notifyRef,O=>{_r(a.notification,O);let G=O.kind==="notification-batch"?O.notifications:[O];I.broadcastNotificationBatch(G);});a.notificationTeardown=P;}async function J(a){if(!a||a.initialized)return;let P={boardRuntimeStoreRef:a.boardRuntimeStoreRef,cardStoreRef:a.cardStoreRef,outputsStoreRef:a.outputsStoreRef,fetchedSourcesStoreRef:a.fetchedSourcesStoreRef,artifactsStoreRef:a.artifactsStoreRef,queueStoreRef:a.queueStoreRef,chatStoreRef:a.chatStoreRef,scratchStoreRef:a.scratchStoreRef},O={};a.taskExecutorRef&&(O["task-executor-ref"]=a.taskExecutorRef),a.chatHandlerFlow!==void 0&&(O["chat-handler-flow"]=a.chatHandlerFlow);let G=await a.boardOps.init({params:P,body:O});if(G.status!=="success")throw Object.assign(new Error(G.error||`init failed for ${a.label}`),{statusCode:500});if(await $(a),!a.chatHandlerFlow&&a.chatHandlerRef&&i.describe)try{let B=await i.describe(a.chatHandlerRef);B&&B.kind!=="chat-handler"?s.warn(`[init] chat-handler describe returned kind="${B.kind}", expected "chat-handler" for ${a.label}`):B&&s.info(`[init] chat-handler validated: ${B.name} (protocol ${B.protocolVersion}) for ${a.label}`);}catch(B){s.warn(`[init] chat-handler describe failed for ${a.label}: ${B?.message||String(B)}`);}a.initialized=true;}async function W(a){if(!a.boardAdapter.publishBoardChangeNotifications)return;let P=[],O=await a.boardOps.status({});O.status==="success"&&O.data!=null&&Pr(O.data)&&P.push({kind:"status",status:O.data});let G=await a.boardOps.getAllOutputsDataObjects({});if(G.status==="success"&&G.data!=null)for(let[N,Y]of Object.entries(G.data))N&&P.push({kind:"data_object",key:N,payload:Y});let B=await a.boardOps.getAllOutputsComputedValues({});if(B.status==="success"&&B.data!=null)for(let[N,Y]of Object.entries(B.data))N&&P.push({kind:"computed_values",cardId:N,values:Y});P.length>0&&a.boardAdapter.publishBoardChangeNotifications(P);}async function te(a,P){if(!a||a.cardsBootstrapped)return;let O=await a.cardStoreOps.get({}),G=O.status==="success"&&Array.isArray(O.data?.cards)?O.data.cards:[];for(let B of G)typeof B.id=="string"&&(F.set(B.id,P),await a.boardOps.upsertCard({params:{cardId:B.id}}));a.cardsBootstrapped=true;}async function ie(){for(let a of A)await J(a);}async function X(){await ie();for(let a=0;a<A.length;a++)await W(A[a]),await te(A[a],a),await W(A[a]);}async function ee(a=false){a||await ie();for(let P of A){let O=await P.board.processAccumulatedEvents({});if(O.status!=="success")return O}return {status:"success"}}function ne(a){return A[c(a)]??null}async function v(a){let P=ne(a);if(!P)return null;let O=await P.cardStoreOps.get({params:{id:a}});if(O.status!=="success")return null;let G=Array.isArray(O.data?.cards)?O.data.cards:[];return G.length>0?G[0]:null}async function g(){let a=async O=>{if(!O)return [];let G=await O.cardStoreOps.get({});return G.status!=="success"||!Array.isArray(G.data?.cards)?[]:G.data.cards},P=[];for(let O of A)P.push(...await a(O));return P}function L(){return A[0]??null}function D(a){return ne(a)??L()}function H(a){let P=D(a);if(!P)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${a}`),{statusCode:404});return P.chatStorage}async function w(a,P){return await H(a).readAfter(a,P)}async function b(a){return await H(a).isProcessing(a)}async function q(a,P){await H(a).setProcessing(a,P),await I.broadcastCardChats(a,true);}let U=jn({append(a,P,O,G,B){return Promise.resolve(H(a).append(a,P,O,G,B)).then(async N=>(await I.broadcastCardChats(a,true),N))},readAll(a){return H(a).readAll(a)},readAfter(a,P){return H(a).readAfter(a,P)},clear(a){return H(a).clear(a)},setProcessing(a,P){return Promise.resolve(H(a).setProcessing(a,P)).then(async()=>{await I.broadcastCardChats(a,true);})},isProcessing(a){return H(a).isProcessing(a)},getConfig(a){return H(a).getConfig(a)},setConfig(a,P){return H(a).setConfig(a,P)}}),V=Qn({boardContexts:A,cardOwnerIndex:F,cardContextForCard:a=>ne(a),readStatusSnapshot:()=>ce(),readDataObjectsByToken:()=>ve(),readCardRuntimeArtifacts:()=>Le(),readCardFromStore:a=>v(a),readCardDefinitions:()=>g(),processAccumulatedLaneInternal:a=>ee(a),reportSourceFetched:(a,P)=>kt(a,{ref:P}),reportSourceFetchFailure:(a,P)=>Ct(a,{reason:P}),uploadCardFile:(a,P,O,G,B)=>K(a,P,O,G,B),chatStorePublic:U,serverUrl:T,apiBasePath:t}),Z=V.mcpCardStoreFacade,ae=V.createMcpFacade,fe=Dn({boardId:o,bootstrapBoard:()=>X(),sseHub:I,onChannelSubscribed:S,onChannelUnsubscribed:R,getMcpFacade:()=>ae(),getMcpCardStoreFacade:()=>Z()});function we(a){return Un(a)}function Pe(){return Vn(ae())}function Be(){return Kn({boardId:o,uploadCardFile:K,getMcpFacade:()=>ae(),controlplane:fe})}let Se=Nn({boardId:o,boardContexts:A,readCardDefinitions:()=>g(),readChatRecords:a=>m(a),getChatProcessing:a=>b(a)}),ce=Se.readStatusSnapshot,Le=Se.readCardRuntimeArtifacts,ve=Se.readDataObjectsByToken,Me=Se.buildPublishedRuntimePayload;async function Ne(a,P,O){let G=O?.syncBoard!==false,B=O?.restartOnlyIfChanged===true,N=ne(a);if(!N)throw Object.assign(new Error(`Card not found: ${a}`),{statusCode:404});let Y=await v(a);if(!Y)throw Object.assign(new Error(`Card not found: ${a}`),{statusCode:404});let he=B?JSON.stringify(Y):null,le=P(Y)||Y;if(B&&JSON.stringify(le)===he)return;let Te=await N.cardStoreOps.set({body:le});if(Te.status!=="success")throw Object.assign(new Error(Te.error||`Failed to persist card: ${a}`),{statusCode:500});if(G){let Oe=await N.boardOps.upsertCard({params:{cardId:a,restart:true}});if(Oe.status!=="success")throw Object.assign(new Error(Oe.error||`Failed to upsert card: ${a}`),{statusCode:500})}}async function me(a,P){await Ne(a,P,{syncBoard:true});}async function Ze(a,P){await Ne(a,P,{syncBoard:false});}async function Ke(a){let P=ne(a);if(!P)throw Object.assign(new Error(`Card not found: ${a}`),{statusCode:404});if(!await v(a))throw Object.assign(new Error(`Card not found: ${a}`),{statusCode:404});let G=await P.boardOps.upsertCard({params:{cardId:a,restart:true}});if(G.status!=="success")throw Object.assign(new Error(G.error||`Failed to retrigger card: ${a}`),{statusCode:500})}async function Ge(a){await H(a).clear(a);try{await q(a,!1);}catch{}}async function M(a,P,O,G,B=""){let N=typeof O=="string"?O.trim():"",Y=await H(a).append(a,P||"system",N,G,B);return await I.broadcastCardChats(a,true),Y}async function m(a){return await H(a).readAll(a)}let K=$n({safeCardId:a=>_(a),artifactsStores:a=>l(a),cardFileMetadataStore:()=>k(),readCardFromStore:a=>v(a),updateCardLocalOnly:(a,P)=>Ze(a,P),writeChatRecord:(a,P,O,G,B)=>M(a,P,O,G,B)}).uploadCardFile;async function oe(a){let P=ne(a);if(!P)return null;let O=await P.boardOps.getConfig({params:{key:"chat-handler-flow"}}),B=(O.status==="success"?O.data?.value:null)??P.chatHandlerFlow??null,N=P.chatHandlerRef;return B==null&&(!N||typeof N!="object")?null:{ctx:P,handlerFlow:B,handlerRef:N}}function re(a){let P=typeof a=="string"?a.trim():"";if(P.length<Bt.length*2||!P.startsWith(Bt)||!P.endsWith(Bt))return null;let O=P.slice(Bt.length,P.length-Bt.length).trim(),G=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(O);return G?{assistant:G[1].trim().toLowerCase(),text:G[2].trim()}:{assistant:"echo",text:O}}async function Ae(a,P,O=false,G="",B=""){try{let N=await oe(a);if(!N){try{await q(a,!1);}catch{}return}let{ctx:Y,handlerFlow:he,handlerRef:le}=N;if(!O)try{await q(a,!0);}catch{}let Te={boardId:o,cardId:String(a),lastChatEntryId:P,...G?{turnId:G}:{},...typeof B=="string"&&B.trim()?{probe:B.trim()}:{},...E,...T?{serverUrl:T}:{}},Oe=he!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:eo}}:le;ot(Y.boardAdapter)?await d(Y,"chat-agent").enqueueRequest({boardId:o,ref:Oe,args:he!=null?{...Te,__chatHandlerFlow:he}:Te}):d(Y,"chat-agent").enqueueRequest({boardId:o,ref:Oe,args:he!=null?{...Te,__chatHandlerFlow:he}:Te}),await Promise.resolve(Y.boardAdapter.requestProcessAccumulated?.());}catch(N){try{await q(a,!1);}catch{}s.warn(`[chat-handler] queue failed for card "${a}": ${N instanceof Error?N.message:String(N)}`);}}async function be(a,P,O){if(P.howToRun==="built-in"&&Ur(P)===eo){let G=u,B=O.__chatHandlerFlow,N={...O};return delete N.__chatHandlerFlow,G?G.run(B,N,{boardId:o,cardId:String(N.cardId||""),label:a.label,logger:s,serverUrl:T,executionExtra:E}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return i.invoke(P,O)}async function Fe(a,P=false){P||await ie();let O=typeof a.args?.cardId=="string"?a.args.cardId:"",G=O?ne(O):L();if(!G)throw new Error(O?`Board context is unavailable for chat-agent request: ${O}`:"Board context is unavailable for chat-agent request");let B=await be(G,a.ref,a.args);if(!B.dispatched){if(O)try{await q(O,!1);}catch{}throw new Error(B.error||`chat-agent dispatch failed for card "${O||"unknown"}"`)}}async function qe(a,P,O){if(P==="chat-send"){let B=O&&typeof O["turn-id"]=="string"?O["turn-id"]:O&&typeof O.turnId=="string"?O.turnId:O&&typeof O.turn=="string"?O.turn:"";if(O&&"files"in O&&O.files!==void 0&&O.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 N=Be(),Y=re(O?.text),he=Y?Y.text:O?.text,le=await pt("manage.add-chat-entry-and-any-attachments",{board_id:o,card_id:a,role:"user",text:he,turn_id:B,files:[]},N);if(le?.status!=="success")throw new Error(rt(le,`chat-send append failed for card ${a}`));let Te=le?.data?.id;if(typeof Te!="string"||!Te)throw new Error(`chat-send did not return an append id for card ${a}`);let Oe=await pt("setstate.chat-processing-started",{board_id:o,card_id:a},N);if(Oe?.status!=="success")throw new Error(rt(Oe,`chat-send processing update failed for card ${a}`));Ae(a,Te,true,B,Y?.assistant||"");return}await me(a,B=>{let N=new Date().toISOString(),Y=B.card_data&&typeof B.card_data=="object"?B.card_data:{};if(B.card_data=Y,P==="file-upload"){let he=k().normalizeIncoming(O?.files,N);return he.length>0&&k().merge(Y,he),B}if(P==="action"){let he=O&&typeof O.buttonId=="string"?O.buttonId:"";if(!he)return B;Y.lastAction={buttonId:he,at:N},Y.lastActionText=`${he} @ ${N}`;}return B});}function $e(a,P,O){let G=JSON.stringify(O),B=typeof Buffer<"u"?Buffer.byteLength(G):new TextEncoder().encode(G).length;a.writeHead(P,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":B}),a.end(G);}async function We(a,P,O){let G=await v(a);if(!G)throw Object.assign(new Error("Card not found"),{statusCode:404});let B=k().resolve(G.card_data,P,O);if(!B.ok&&B.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!B.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let N=B.file,Y=_(a),he=l(a),le=String(N.stored_name||""),Te=`${Y}/${le}`,Oe=he.files?await he.files.getBytes(Te):null;if(!Oe)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:N,bytes:Oe}}async function He(a,P,O,G){let{fileRecord:B,bytes:N}=await We(P,O,G),Y=String(B.name||B.stored_name||"download.bin"),he=String(B.mime_type||"application/octet-stream");a.writeHead(200,{"Content-Type":he,"Content-Disposition":`attachment; filename="${Y}"`,"Content-Length":N.length}),a.end(N);}function lt(a){let P=String(a||"").toLowerCase();return P.startsWith("text/")||P.includes("json")||P.includes("xml")||P.includes("javascript")||P.includes("typescript")||P.includes("yaml")||P.includes("csv")}function et(a,P,O){let G=a.split(/\r?\n/);return (P==="head"?G.slice(0,O):G.slice(-O)).join(`
7
7
  `)}async function tt(a){let P=[];for await(let G of a)P.push(G);let O=typeof Buffer<"u"?Buffer.concat(P).toString("utf-8").trim():new TextDecoder().decode(mr(P)).trim();return O?JSON.parse(O):{}}async function kt(a,P){let O=typeof P.ref=="string"?P.ref.trim():"";if(!O)return {status:"fail",error:"board-worker success callback requires body.ref"};let G=A[0];return G?G.boardOps.sourceDataFetched({params:{token:a,ref:O}}):{status:"fail",error:"no board context"}}async function Ct(a,P){let O=typeof P.reason=="string"&&P.reason.trim()?P.reason:"unknown",G=A[0];return G?G.boardOps.sourceDataFetchFailure({params:{token:a,reason:O}}):{status:"fail",error:"no board context"}}let qt=Zn({sseHub:I,corsHeaders:r,json:$e,buildPublishedRuntimePayload:()=>Me(),onSseClientConnected:y,onChannelSubscribed:S,onChannelUnsubscribed:R,apiBasePath:t,readJsonBody:a=>tt(a),initBoardAndSetup:()=>ie(),bootstrapBoard:()=>X(),boardContexts:A,publishPersistedStateSnapshot:a=>W(a),upsertCardsFromSource:(a,P)=>te(a,P)}).handleWatchersRoutes,vt=zn({apiBasePath:t,json:$e,readJsonBody:a=>tt(a),bootstrapBoard:()=>X(),createMcpFacade:()=>ae(),createMcpToolRegistry:a=>we(a),resolveCardFileDownloadPayload:(a,P,O)=>We(a,P,O),isLikelyTextMimeType:a=>lt(a),sliceTextByLines:(a,P,O)=>et(a,P,O)}).handleAgentfaceApi,Mr=Yn({apiBasePath:t,json:$e,readJsonBody:a=>tt(a),initBoardAndSetup:()=>ie(),createMcpWebhookToolRegistry:()=>Pe()}).handleWebhooksApi,jt=gr({apiBasePath:t,json:$e,readJsonBody:a=>tt(a),initBoardAndSetup:()=>ie(),bootstrapBoard:()=>X(),buildPublishedRuntimePayload:()=>Me(),createMcpControlplaneToolRegistry:()=>Be(),retriggerCard:a=>Ke(a),applyCardAction:(a,P,O)=>qe(a,P,O),resolveChatHandlerTarget:a=>oe(a),sendCardFileDownloadResponse:(a,P,O,G)=>He(a,P,O,G)}).handleRuntimeApi;async function pr(a,P,O){return !!(await vt(a,P,O)||await Mr(a,P,O)||await qt(a,P,O)||await jt(a,P,O))}return {get apiBasePath(){return t},get corsHeaders(){return r},get queueLaneTuning(){return n},handleRuntimeApi:pr,buildPublishedRuntimePayload:Me,__drainProcessAccumulatedLane:ee,handleChatAgentRequest:Fe,clearChatRecords:Ge,reportSourceFetched(a,P){return kt(a,{ref:P})},reportSourceFetchFailure(a,P){return Ct(a,{reason:P})},get cardStore(){return A[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function rs(e){let t=String(e.apiBasePath||"/api/boards").replace(/\/$/,""),r={...to,...e.corsHeaders||{}},n=e.serverMetaStore,o=e.boardRuntimeFactory,s=new Map,i="boards-config.json";function u(){let x=n.getText(i);if(!x)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(x)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function p(x){n.putText(i,JSON.stringify(x,null,2));}function T(x){let A=String(x||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return A.length>0&&A.length<=64?A:null}function E(x){if(s.has(x))return s.get(x);let F=u().boards.find(h=>h.id===x)||{},c=o(x,F);return s.set(x,c),c}function y(x,A,F){let c=JSON.stringify(F),h=typeof Buffer<"u"?Buffer.byteLength(c):new TextEncoder().encode(c).length;x.writeHead(A,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":h}),x.end(c);}async function C(x,A,F){let c=x.method||"GET",h=F.pathname;if(c==="GET"&&h===t)return y(A,200,{ok:true,boards:u().boards}),true;if(c==="POST"&&h===t){let d=[];for await(let W of x)d.push(W);let f=typeof Buffer<"u"?Buffer.concat(d).toString("utf-8").trim():new TextDecoder().decode(mr(d)).trim(),l={};try{l=f?JSON.parse(f):{};}catch{l={};}let k=T(l.id);if(!k)return y(A,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let _=u();if(_.boards.some(W=>W.id===k))return y(A,409,{error:`Board "${k}" is already registered`}),true;let $=typeof l.label=="string"&&l.label.trim()?l.label.trim():k,J={id:k,label:$};for(let[W,te]of Object.entries(l))W==="id"||W==="label"||te!=null&&(J[W]=te);return _.boards.push(J),p(_),y(A,200,{ok:true,board:J}),true}return false}async function S(x,A,F){let h=F.pathname.match(new RegExp(`^${st(t)}/([^/]+)(/|$)`));if(!h)return false;let d=T(decodeURIComponent(h[1]));return d?u().boards.some(k=>k.id===d)?!!await E(d).handleRuntimeApi(x,A,F):(y(A,404,{error:`Board "${d}" not registered. POST ${t} with {id} to register it first.`}),true):(y(A,400,{error:"Invalid board id"}),true)}async function R(x,A,F){return !!(await C(x,A,F)||await S(x,A,F))}function I(x){if(!u().boards.some(F=>F.id===x))throw Object.assign(new Error(`Board "${x}" not registered`),{statusCode:404});return {service:E(x)}}return {get apiBasePath(){return t},get corsHeaders(){return r},handleApi:R,requireBoardService:I}}exports.createMultiBoardServerRuntime=rs;exports.createRoutesRuntimeApi=gr;exports.createSingleBoardServerRuntime=ts;return exports;})({});//# sourceMappingURL=server-runtime-controlface.js.map
8
8
  //# sourceMappingURL=server-runtime-controlface.js.map