yaml-flow 8.4.23 → 8.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/browser/asset-integrity.json +3 -3
- package/cli/browser-api/board-live-cards-browser-adapter.d.ts +1 -1
- package/cli/browser-api/board-live-cards-browser-adapter.js +1 -1
- package/cli/bundled/board-live-cards-cli.mjs +14 -14
- package/cli/bundled/chat-store-cli.mjs +6 -6
- package/cli/{types-juH2nFpz.d.ts → types-D2s3VzyY.d.ts} +3 -2
- package/examples/board/demo-shell-with-server.html +2 -2
- package/examples/board/doc.html +2 -2
- package/examples/board/server/board-server.js +8 -0
- package/examples/board/server/chat-flow/copilot-chat/assistant.js +4 -2
- package/examples/board/server/chat-flow/flow-steps.json +70 -10
- package/examples/board/test/server-http-mcp-test.js +791 -0
- package/examples/board/test/server-http-test.js +32 -15
- package/examples/board-local/demo-shell-localstorage.html +3 -3
- package/lib/artifacts-store-public.d.cts +1 -1
- package/lib/artifacts-store-public.d.ts +1 -1
- package/lib/board-live-cards-mcp.cjs +2 -0
- package/lib/board-live-cards-mcp.d.cts +259 -0
- package/lib/board-live-cards-mcp.d.ts +259 -0
- package/lib/board-live-cards-mcp.js +2 -0
- package/lib/board-live-cards-node.cjs +14 -14
- package/lib/board-live-cards-node.d.cts +8 -6
- package/lib/board-live-cards-node.d.ts +8 -6
- package/lib/board-live-cards-node.js +14 -14
- package/lib/{board-live-cards-public-B4RcYPC_.d.cts → board-live-cards-public-CvkDfZQ7.d.cts} +1 -1
- package/lib/{board-live-cards-public-ydXuA4zh.d.ts → board-live-cards-public-DdVhH4M-.d.ts} +1 -1
- package/lib/board-live-cards-public.cjs +1 -1
- package/lib/board-live-cards-public.d.cts +1 -1
- package/lib/board-live-cards-public.d.ts +1 -1
- package/lib/board-live-cards-public.js +1 -1
- package/lib/board-live-cards-server-runtime.cjs +5 -4
- package/lib/board-live-cards-server-runtime.d.cts +3 -3
- package/lib/board-live-cards-server-runtime.d.ts +3 -3
- package/lib/board-live-cards-server-runtime.js +5 -4
- package/lib/card-store-public.d.cts +1 -1
- package/lib/card-store-public.d.ts +1 -1
- package/lib/{chat-storage-lib-B1wU27y3.d.cts → chat-storage-lib-0imhRX3l.d.cts} +2 -1
- package/lib/{chat-storage-lib-DsF4kPon.d.ts → chat-storage-lib-CJn7a6OH.d.ts} +2 -1
- package/lib/chat-store-public.cjs +1 -1
- package/lib/chat-store-public.d.cts +2 -2
- package/lib/chat-store-public.d.ts +2 -2
- package/lib/chat-store-public.js +1 -1
- package/lib/server-runtime/index.cjs +5 -4
- package/lib/server-runtime/index.d.cts +4 -4
- package/lib/server-runtime/index.d.ts +4 -4
- package/lib/server-runtime/index.js +5 -4
- package/lib/{types-D501gMQt.d.cts → types-NM_d_1oZ.d.cts} +5 -2
- package/lib/{types-1L1D33mr.d.ts → types-QNI__eAf.d.ts} +5 -2
- package/package.json +10 -2
- package/browser/board-livecards-localstorage.js +0 -10
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import {createRequire}from'module';import'ajv-formats';var st="b64:";function vr(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 s="";for(let a of t)s+=String.fromCharCode(a);n=btoa(s);}else throw new Error("No base64 encoder available in this runtime");return n.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function xr(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),s=new Uint8Array(n.length);for(let a=0;a<n.length;a+=1)s[a]=n.charCodeAt(a);return new TextDecoder().decode(s)}throw new Error("No base64 decoder available in this runtime")}function be(e){return `${st}${vr(JSON.stringify(e))}`}function At(e){if(!e.startsWith(st))throw new Error(`Invalid ref format (expected ${st}<base64url(json)>): ${e}`);let t;try{t=JSON.parse(xr(e.slice(st.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 Et(e,t,r){let n=e.tryAcquire();if(!n)return false;try{await t();}finally{n();}return r?.(),true}var je={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function ge(e){return e?Array.isArray(e.provides)?e.provides:[]:[]}function Ne(e){return e?Array.isArray(e.requires)?e.requires:[]:[]}function _t(e){return e.tasks??{}}function bt(e){return e?e.status===je.FAILED||e.status===je.INACTIVATED:false}function It(e,t){return e.refreshStrategy??t?.refreshStrategy??"data-changed"}function Tt(e){return e.maxExecutions}function Ot(e,t){let r=new Set;for(let[n,s]of Object.entries(t))if(s.status===je.COMPLETED){let a=e.tasks[n];a&&ge(a).forEach(c=>r.add(c));}return Array.from(r)}function jt(e,t){let r={};return e.forEach(n=>{let s=t[n];if(!s)return;ge(s).forEach(u=>{r[u]||(r[u]=[]),r[u].push(n);});}),r}function Nt(e,t,r){let n=e.tasks[t]??at(),s={};if(r){let u=r.tasks[t],c=Ne(u);for(let f of c)for(let[g,m]of Object.entries(r.tasks))if(ge(m).includes(f)){let R=e.tasks[g];R?.lastDataHash&&(s[f]=R.lastDataHash);break}}let a={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:s};return {...e,tasks:{...e.tasks,[t]:a},lastUpdated:new Date().toISOString()}}function $t(e,t,r,n,s,a){let u=e.tasks[r]??at(),c=t.tasks[r];if(!c)throw new Error(`Task "${r}" not found in graph`);let f;n&&c.on&&c.on[n]?f=c.on[n]:f=ge(c);let g=u.startConsumedHashes?{...u.startConsumedHashes}:{...u.lastConsumedHashes};if(!u.startConsumedHashes){let O=c.requires??[];for(let F of O)for(let[S,x]of Object.entries(t.tasks))if(ge(x).includes(F)){let b=e.tasks[S];b?.lastDataHash&&(g[F]=b.lastDataHash);break}}let m={...u,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:u.executionCount+1,lastEpoch:u.executionCount+1,lastDataHash:s,data:a,lastConsumedHashes:g,error:void 0},R=[...new Set([...e.availableOutputs,...f])];return {...e,tasks:{...e.tasks,[r]:m},availableOutputs:R,lastUpdated:new Date().toISOString()}}function Ft(e,t,r,n){let s=e.tasks[r]??at(),a=t.tasks[r];if(a?.retry){let f=s.retryCount+1;if(f<=a.retry.max_attempts){let g={...s,status:"not-started",retryCount:f,lastUpdated:new Date().toISOString(),error:n};return {...e,tasks:{...e.tasks,[r]:g},lastUpdated:new Date().toISOString()}}}let u={...s,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:s.executionCount+1},c=e.availableOutputs;if(a?.on_failure&&a.on_failure.length>0&&(c=[...new Set([...e.availableOutputs,...a.on_failure])]),a?.circuit_breaker&&u.executionCount>=a.circuit_breaker.max_executions){let f=a.circuit_breaker.on_break;c=[...new Set([...c,...f])];}return {...e,tasks:{...e.tasks,[r]:u},availableOutputs:c,lastUpdated:new Date().toISOString()}}function Pt(e,t,r,n){let s=e.tasks[t]??at(),a={...s,progress:typeof n=="number"?n:s.progress,messages:[...s.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:s.status}]:[]],lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:a},lastUpdated:new Date().toISOString()}}function Dt(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 at(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function it(e,t){let r=`live-${Date.now()}`,n={};for(let a of Object.keys(e.tasks))n[a]=qt();let s={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:s}}function Ar(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:Nt(n,t.taskName,r)};case "task-completed":return {config:r,state:$t(n,r,t.taskName,t.result,t.dataHash,t.data)};case "task-failed":return {config:r,state:Ft(n,r,t.taskName,t.error)};case "task-progress":return {config:r,state:Pt(n,t.taskName,t.message,t.progress)};case "task-restart":return {config:r,state:Dt(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:Nr(n,t.action)};case "task-upsert":return Er(e,t.taskName,t.taskConfig);case "task-removal":return _r(e,t.taskName);case "node-requires-add":return Ir(e,t.nodeName,t.tokens);case "node-requires-remove":return Tr(e,t.nodeName,t.tokens);case "node-provides-add":return Or(e,t.nodeName,t.tokens);case "node-provides-remove":return jr(e,t.nodeName,t.tokens);default:return e}}function Bt(e,t){return t.reduce((r,n)=>Ar(r,n),e)}function Er(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]:qt()},lastUpdated:new Date().toISOString()}}}function _r(e,t){if(!e.config.tasks[t])return e;let{[t]:r,...n}=e.config.tasks,{[t]:s,...a}=e.state.tasks;return {config:{...e.config,tasks:n},state:{...e.state,tasks:a,lastUpdated:new Date().toISOString()}}}function Ir(e,t,r){let n=e.config.tasks[t];if(!n)return e;let s=Ne(n),a=r.filter(u=>!s.includes(u));return a.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:[...s,...a]}}},state:e.state}}function Tr(e,t,r){let n=e.config.tasks[t];if(!n)return e;let s=Ne(n),a=s.filter(u=>!r.includes(u));return a.length===s.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:a}}},state:e.state}}function Or(e,t,r){let n=e.config.tasks[t];if(!n)return e;let s=ge(n),a=r.filter(u=>!s.includes(u));return a.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:[...s,...a]}}},state:e.state}}function jr(e,t,r){let n=e.config.tasks[t];if(!n)return e;let s=ge(n),a=s.filter(u=>!r.includes(u));return a.length===s.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:a}}},state:e.state}}function Je(e){return {version:1,config:e.config,state:e.state,snapshotAt:new Date().toISOString()}}function ut(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 qt(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Nr(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 ze(e){let{config:t,state:r}=e,n=_t(t);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let a=$r(n),u=Ot(t,r.tasks),c=new Set([...u,...r.availableOutputs]),f=[],g=[],m=[],R=[];for(let[F,S]of Object.entries(n)){let x=r.tasks[F],b=It(S,t.settings),N=b!=="once";if(x?.status===je.RUNNING||bt(x))continue;let L=Tt(S);if(L!==void 0&&x&&x.executionCount>=L||S.circuit_breaker&&x&&x.executionCount>=S.circuit_breaker.max_executions||!N&&x?.status===je.COMPLETED)continue;if(N&&x?.status===je.COMPLETED){let A=Ne(S),E=false;switch(b){case "data-changed":{A.length>0&&A.some(H=>{for(let[W,oe]of Object.entries(n))if(ge(oe).includes(H)){let se=r.tasks[W];if(!se)continue;let Ce=x.lastConsumedHashes?.[H];return se.lastDataHash==null?se.executionCount>x.lastEpoch:se.lastDataHash!==Ce}return false})||(E=true);break}case "epoch-changed":{A.length>0&&A.some(H=>{for(let[W,oe]of Object.entries(n))if(ge(oe).includes(H)){let se=r.tasks[W];if(se&&se.executionCount>x.lastEpoch)return true}return false})||(E=true);break}case "time-based":{let z=S.refreshInterval??0;if(z<=0){E=true;break}let H=x.completedAt;if(!H){E=true;break}(Date.now()-Date.parse(H))/1e3<z&&(E=true);break}case "manual":E=true;break}if(E)continue}let y=Ne(S);if(y.length===0){f.push(F);continue}let T=[],I=[],U=[];for(let A of y){if(c.has(A))continue;let E=a[A]||[];E.length===0?T.push(A):E.every(H=>bt(r.tasks[H]))?U.push({token:A,failedProducer:E[0]}):I.push(A);}T.length>0?m.push({taskName:F,missingTokens:T}):U.length>0?R.push({taskName:F,failedTokens:U.map(A=>A.token),failedProducers:[...new Set(U.map(A=>A.failedProducer))]}):I.length>0?g.push({taskName:F,waitingOn:I}):f.push(F);}let O={};if(f.length>1){let F=jt(f,n);for(let[S,x]of Object.entries(F))x.length>1&&(O[S]=x);}return {eligible:f,pending:g,unresolved:m,blocked:R,conflicts:O}}function $r(e){let t={};for(let[r,n]of Object.entries(e)){for(let s of ge(n))t[s]||(t[s]=[]),t[s].push(r);if(n.on)for(let s of Object.values(n.on))for(let a of s)t[a]||(t[a]=[]),t[a].includes(r)||t[a].push(r);if(n.on_failure)for(let s of n.on_failure)t[s]||(t[s]=[]),t[s].includes(r)||t[s].push(r);}return t}var We=class{buffer=[];append(t){this.buffer.push(t);}drain(){let t=this.buffer;return this.buffer=[],t}get size(){return this.buffer.length}};function wt(e){let t=vt(e);return Fr(t)}function vt(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return "["+e.map(vt).join(",")+"]";let t=e;return "{"+Object.keys(t).sort().map(n=>JSON.stringify(n)+":"+vt(t[n])).join(",")+"}"}function Fr(e){let t=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let s=0;s<e.length;s++)t^=BigInt(e.charCodeAt(s)),t=t*r&n;return t.toString(16).padStart(16,"0")}function Pr(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 Dr(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),s=new Uint8Array(n.length);for(let a=0;a<n.length;a++)s[a]=n.charCodeAt(a);return new TextDecoder().decode(s)}throw new Error("No base64 decoder available in this runtime")}function Lt(e){let t=JSON.stringify({t:e,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return Pr(t)}function Br(e){try{let t=JSON.parse(Dr(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function Gt(e,t,r){let{handlers:n,onNodeRemoved:s,onDrain:a}=t,u=new We,c="state"in e&&"config"in e?e:it(e),f=false,g=new Set,m=new Map(Object.entries(n)),R=new We,O=false,F=false;function S(){if(!f){if(O){F=true;return}O=true;try{do F=!1,x();while(F)}finally{O=false;}}}function x(){let y=R.drain(),T=u.drain(),I=[...y,...T];if(I.length>0&&(c=Bt(c,I),s)){for(let A of I)if(A.type==="task-removal")try{s(A.taskName);}catch(E){console.warn("[reactive] onNodeRemoved failed:",E instanceof Error?E.message:String(E));}}let U=ze(c);I.length>0&&a?.(I,c,U);for(let A of U.eligible)L(A);for(let A of I)if(A.type==="task-progress"){let{taskName:E,update:z}=A;if(!c.config.tasks[E])continue;let W=c.state.tasks[E];if(!W||W.status!=="running")continue;let oe=Lt(E),se=N(E,oe,z).catch(Ce=>{f||(R.append({type:"task-failed",taskName:E,error:Ce.message??String(Ce),timestamp:new Date().toISOString()}),S());}).finally(()=>{g.delete(se);});g.add(se);}}function b(y){let I=c.config.tasks[y].requires??[],U=new Map;for(let[E,z]of Object.entries(c.config.tasks))for(let H of z.provides??[])U.set(H,E);let A={};for(let E of I){let z=U.get(E);z?A[E]=c.state.tasks[z]?.data:A[E]=void 0;}return A}async function N(y,T,I){let U=c.config.tasks[y],A=U.taskHandlers??[],E=b(y);for(let z of A){let H=m.get(z);if(!H)throw new Error(`Handler '${z}' not found in registry (task '${y}')`);let W={nodeId:y,state:E,taskState:c.state.tasks[y],config:U,callbackToken:T,update:I};if(await H(W)==="task-initiate-failure")throw new Error(`Handler '${z}' returned task-initiate-failure (task '${y}')`)}}function L(y){let I=c.config.tasks[y]?.taskHandlers;if(!I||I.length===0)return;R.append({type:"task-started",taskName:y,timestamp:new Date().toISOString()}),S();let U=Lt(y),A=N(y,U).catch(E=>{f||(R.append({type:"task-failed",taskName:y,error:E.message??String(E),timestamp:new Date().toISOString()}),S());}).finally(()=>{g.delete(A);});g.add(A);}return {push(y){f||(y.type==="task-completed"&&y.data&&!y.dataHash&&(y={...y,dataHash:wt(y.data)}),u.append(y),S());},pushAll(y){if(!f){for(let T of y)T.type==="task-completed"&&T.data&&!T.dataHash?u.append({...T,dataHash:wt(T.data)}):u.append(T);S();}},resolveCallback(y,T,I){if(f)return;let U=Br(y);if(!U)return;let{taskName:A}=U;if(c.config.tasks[A]){if(I&&I.length>0)u.append({type:"task-failed",taskName:A,error:I.join("; "),timestamp:new Date().toISOString()});else {let E=T&&Object.keys(T).length>0?wt(T):void 0;u.append({type:"task-completed",taskName:A,data:T,dataHash:E,timestamp:new Date().toISOString()});}S();}},addNode(y,T){f||(u.append({type:"task-upsert",taskName:y,taskConfig:T,timestamp:new Date().toISOString()}),S());},removeNode(y){f||(u.append({type:"task-removal",taskName:y,timestamp:new Date().toISOString()}),S());},addRequires(y,T){f||(u.append({type:"node-requires-add",nodeName:y,tokens:T,timestamp:new Date().toISOString()}),S());},removeRequires(y,T){f||(u.append({type:"node-requires-remove",nodeName:y,tokens:T,timestamp:new Date().toISOString()}),S());},addProvides(y,T){f||(u.append({type:"node-provides-add",nodeName:y,tokens:T,timestamp:new Date().toISOString()}),S());},removeProvides(y,T){f||(u.append({type:"node-provides-remove",nodeName:y,tokens:T,timestamp:new Date().toISOString()}),S());},registerHandler(y,T){m.set(y,T);},unregisterHandler(y){m.delete(y);},retrigger(y){f||c.config.tasks[y]&&(u.append({type:"task-restart",taskName:y,timestamp:new Date().toISOString()}),S());},retriggerAll(y){if(!f){for(let T of y)c.config.tasks[T]&&u.append({type:"task-restart",taskName:T,timestamp:new Date().toISOString()});S();}},snapshot(){return Je(c)},getState(){return c},getSchedule(){return ze(c)},async waitForHandlers(){g.size>0&&await Promise.allSettled([...g]);},async dispose(y){y?.wait&&g.size>0&&await Promise.allSettled([...g]),f=true;}}}var Lr=createRequire(import.meta.url);Lr("./jsonata-sync.cjs");var Vr=createRequire(import.meta.url),ct=Vr("./jsonata-sync.cjs"),Ut=ct;function Vt(e,t){if(!t||!e)return;let r=t.split("."),n=e;for(let s=0;s<r.length;s++){if(n==null)return;n=n[r[s]];}return n}function Ht(e,t,r){let n=t.split("."),s=e;for(let a=0;a<n.length-1;a++)(s[n[a]]==null||typeof s[n[a]]!="object")&&(s[n[a]]={}),s=s[n[a]];s[n[n.length-1]]=r;}async function Mr(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 s of e.compute)try{let a=await ct(s.expr).evaluate(n);Ht(e.computed_values,s.bindTo,a),n.computed_values=e.computed_values;}catch{}return e}function Ur(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},s=[];for(let a of e.compute)try{let u=Ut(a.expr).evaluate(n);Ht(e.computed_values,a.bindTo,u),n.computed_values=e.computed_values;}catch(u){let c=u instanceof Error?u.message:String(u);s.push({bindTo:a.bindTo,error:c});}return s.length>0?{ok:true,node:e,errors:s}:{ok:true,node:e}}async function Hr(e,t,r){let n={...r??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return ct(e).evaluate(n)}function Kr(e,t){return t.startsWith("fetched_sources.")?Vt(e._sourcesData??{},t.slice(16)):Vt(e,t)}var Mt=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),Jr=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function zr(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))Jr.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,s)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`provides[${s}]: must be an object with bindTo and ref`);else {let a=n;(typeof a.bindTo!="string"||!a.bindTo)&&t.push(`provides[${s}]: missing required "bindTo" string`),(typeof a.ref!="string"||!a.ref)&&t.push(`provides[${s}]: 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,s)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`compute[${s}]: must be a compute step object`);else {let a=n;(typeof a.bindTo!="string"||!a.bindTo)&&t.push(`compute[${s}]: missing required "bindTo" property`),(typeof a.expr!="string"||!a.expr)&&t.push(`compute[${s}]: 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,s=new Set;r.source_defs.forEach((a,u)=>{if(!a||typeof a!="object"||Array.isArray(a))t.push(`source_defs[${u}]: must be an object`);else {let c=a;typeof c.bindTo!="string"||!c.bindTo?t.push(`source_defs[${u}]: missing required "bindTo" property`):(n.has(c.bindTo)&&t.push(`source_defs[${u}]: bindTo "${c.bindTo}" is not unique across source_defs`),n.add(c.bindTo)),typeof c.outputFile!="string"||!c.outputFile?t.push(`source_defs[${u}]: missing required "outputFile" property`):(s.has(c.outputFile)&&t.push(`source_defs[${u}]: outputFile "${c.outputFile}" is not unique across source_defs`),s.add(c.outputFile)),c.optionalForCompletionGating!=null&&typeof c.optionalForCompletionGating!="boolean"&&t.push(`source_defs[${u}]: 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((s,a)=>{if(!s||typeof s!="object"){t.push(`view.elements[${a}]: must be an object`);return}!s.kind||typeof s.kind!="string"?t.push(`view.elements[${a}].kind: required, must be a string`):Mt.has(s.kind)||t.push(`view.elements[${a}].kind: unknown kind "${s.kind}". Valid: ${[...Mt].join(", ")}`),s.data!=null&&(typeof s.data!="object"||Array.isArray(s.data))&&t.push(`view.elements[${a}].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 Wr(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 s={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[a,u]of Object.entries(n.projections))if(typeof u=="string"&&u.trim().length>0)try{s[a]=await ct(u).evaluate(r);}catch{s[a]=void 0;}}return {...n,_projections:s}}))}function Yr(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return e.map(n=>{let s={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[a,u]of Object.entries(n.projections))if(typeof u=="string"&&u.trim().length>0)try{s[a]=Ut(u).evaluate(r);}catch{s[a]=void 0;}}return {...n,_projections:s}})}var Ye={run:Mr,runSync:Ur,eval:Hr,resolve:Kr,validate:zr,enrichSources:Wr,enrichSourcesSync:Yr};function Kt(e){return JSON.stringify(e)}function Jt(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 dt(e,t){function r(){return e.readIndex()??{}}function n(s,a,u){let c=String(a||"").split(".").filter(Boolean);if(c.length===0)return u&&typeof u=="object"&&!Array.isArray(u)?u:{value:u};let f={...s},g=f;for(let m=0;m<c.length-1;m++){let R=c[m],O=g[R],F=O&&typeof O=="object"&&!Array.isArray(O)?{...O}:{};g[R]=F,g=F;}return g[c[c.length-1]]=u,f}return {readCard(s){let a=r()[s];return !a||!e.cardExists(a.key)?null:e.readCard(a.key)},readCardKey(s){return r()[s]?.key??null},readAllCards(){let s=[];for(let[a,u]of Object.entries(r())){if(!e.cardExists(u.key))continue;let c=e.readCard(u.key);c?s.push(c):t?.(`[card-store] could not read card "${a}" at key "${u.key}"`);}return s},readChecksumIndex(){let s={};for(let[a,u]of Object.entries(r()))s[a]=u.checksum;return s},changedSince(s){let a=r(),u=[];for(let[c,f]of Object.entries(a))s[c]!==f.checksum&&u.push(c);for(let c of Object.keys(s))a[c]||u.push(c);return u},validateUpsert(s,a){let u=r(),c=u[s],f=Object.entries(u).find(([,g])=>g.key===a);return c&&c.key!==a?{ok:false,error:`Card id "${s}" is already mapped to key "${c.key}", cannot remap to "${a}"`}:f&&f[0]!==s?{ok:false,error:`Key "${a}" is already mapped to card id "${f[0]}", cannot remap to "${s}"`}:{ok:true}},writeCard(s,a,u){let c=r(),f=u??c[s]?.key??e.defaultCardKey(s),g=e.writeCard(f,a);c[s]={key:f,checksum:g,updatedAt:new Date().toISOString()},e.writeIndex(c);},patchCard(s,a,u){let c=r(),f=c[s];if(!f||!e.cardExists(f.key))throw new Error(`card "${s}" not found`);let g=e.readCard(f.key);if(!g||typeof g!="object"||Array.isArray(g))throw new Error(`card "${s}" is not patchable`);let m=n(g,a,u),R=e.writeCard(f.key,m);c[s]={key:f.key,checksum:R,updatedAt:new Date().toISOString()},e.writeIndex(c);},removeCard(s){let a=r(),u=a[s];u&&(e.removeCard(u.key),delete a[s],e.writeIndex(a));},readIndex(){return r()}}}function lt(e,t){return {readSourceData(r,n){let s=e.read(`${r}/${n}`);if(s==null)return null;let a=s.trim();if(!a)return null;try{return JSON.parse(a)}catch{return a}},ingestSourceDataStaged(r,n,s,a){let u=t(s);e.write(`${r}/.staged/${a}/${n}`,u);},commitSourceData(r,n,s){let a=`${r}/.staged/${s}/${n}`,u=e.read(a);return u==null?false:(e.write(`${r}/${n}`,u),e.remove(a),true)},hasSource(r,n){return e.exists(`${r}/${n}`)},listSources(r){return e.listKeys(`${r}/`).filter(n=>!n.includes("/.staged/")).map(n=>n.slice(`${r}/`.length))}}}function Zt(e){function t(r){let n=e.readAllEntries();if(!r)return n;let s=n.findIndex(a=>a.id===r);return s===-1?n:n.slice(s+1)}return {readEntriesAfterCursor(r){let n=t(r);return n.length===0?{events:[],newCursor:r}:{events:n.map(s=>s.event),newCursor:n[n.length-1].id}},pendingCount(r){return t(r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function Qt(e,t){return {appendEntries(r,n){if(!r||n.length===0)return;let s=e.read(r)??[];e.write(r,[...s,...n]);},dispatchEntriesForJournalId(r,n){if(!r)return;let s=e.read(r);if(!(!s||s.length===0)){for(let a of s)try{n(a);}catch(u){let c=u instanceof Error?u.message:String(u);try{t(a,c);}catch{}}e.delete(r);}}}}var ft="v1",Fe="board/graph",er="board/lastJournalProcessedId";function zt(e){return `cards/${e}/runtime`}function tr(e){return {readRuntime(t){return e.read(zt(t))??{_sources:{}}},writeRuntime(t,r){e.write(zt(t),r);}}}function Xr(e,t){let r={...e};for(let n of t.deleteKeys)delete r[n];return {...r,...t.shallowMerge}}function rr(e){return {readSnapshot(t){return e.readValues(t)},commitSnapshot(t,r){if(r.schemaVersion!==ft)throw new Error(`Unsupported snapshot schema version: ${r.schemaVersion}`);let n=e.readValues(t);if(n.version!==r.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let s=Xr(n.values,r);return {ok:true,newVersion:e.writeValues(t,s,r.deleteKeys)}}}}function nr(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 Jt(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);},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);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){e.write("scratch-store-ref",r);},readArchiveStoreRef(){return t("archive-store-ref")},writeArchiveStoreRef(r){e.write("archive-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);}}}function or(e){return {writeComputedValues(t,r){e.write(`cards/${t}/computed_values`,r);},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){let t={};for(let r of e.listKeys("cards/")){let n=r.match(/^cards\/([^/]+)\/computed_values$/);n&&(t[n[1]]=e.read(r));}return t},writeDataObjects(t){for(let[r,n]of Object.entries(t))r&&e.write(`data-objects/${r}`,n);},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){let t={};for(let r of e.listKeys("data-objects/"))t[r.slice(13)]=e.read(r);return t},writeStatusSnapshot(t){e.write("status",t);},readStatusSnapshot(){return e.read("status")}}}function Wt(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function Zr(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function Yt(e,t){return e?.lastRequestedToken?Zr(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function Qr(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function Xt(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function gt(e,t){let r=t.state.tasks,n=t.config.tasks,s=Object.keys(r),a=ze(t),u={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},c=new Map;for(let S of a.pending)c.set(S.taskName,S.waitingOn);for(let S of a.unresolved)c.set(S.taskName,S.missingTokens);for(let S of a.blocked)c.set(S.taskName,S.failedTokens);let f=new Map;for(let[S,x]of Object.entries(n))for(let b of x.requires??[]){let N=f.get(b)??[];N.push(S),f.set(b,N);}let g=s.sort().map(S=>{let x=r[S],b=n[S]??{requires:[],provides:[]};x.status==="completed"?u.completed+=1:x.status==="failed"?u.failed+=1:x.status==="in-progress"&&(u.in_progress+=1);let N=b.requires??[],L=b.provides??[],y=Object.keys(x.data??{}).sort(),T=N.filter(H=>t.state.availableOutputs.includes(H)),I=N.filter(H=>!t.state.availableOutputs.includes(H)),U=c.get(S)??I,A=new Set;for(let H of L)for(let W of f.get(H)??[])W!==S&&A.add(W);let E=x.failedAt,z=x.error?{message:x.error,code:"TASK_FAILED",at:E,source:"task-runtime"}:void 0;return {name:S,status:x.status,error:z,requires:N,requires_satisfied:T,requires_missing:I,provides_declared:L,provides_runtime:y,blocked_by:U,unblocks:Array.from(A).sort(),runtime:{attempt_count:x.executionCount??0,restart_count:x.retryCount??0,in_progress_since:x.status==="in-progress"?x.startedAt??null:null,last_transition_at:x.lastUpdated??null,last_completed_at:x.completedAt??null,last_restarted_at:x.startedAt??null,status_age_ms:x.lastUpdated?0:null}}});u.pending=a.pending.length,u.blocked=a.blocked.length,u.unresolved=a.unresolved.length;let m=g.map(S=>({name:S.name,fanOut:S.unblocks.length})).sort((S,x)=>x.fanOut-S.fanOut||S.name.localeCompare(x.name)),R=m.length>0?m[0]:{name:null,fanOut:0},O=new Set;for(let S of Object.values(n))for(let x of S.requires??[])O.add(x);let F=0;for(let[S,x]of Object.entries(n)){let b=(x.requires??[]).length===0,L=(x.provides??[]).some(y=>(f.get(y)??[]).some(T=>T!==S));b&&!L&&(F+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:s.length,completed:u.completed,eligible:a.eligible.length,pending:u.pending,blocked:u.blocked,unresolved:u.unresolved,failed:u.failed,in_progress:u.in_progress,orphan_cards:F,topology:{edge_count:Array.from(O).length,max_fan_out_card:R.name,max_fan_out:R.fanOut}},cards:g}}function en(){return new Date().toISOString()}function sr(e,t,r,n,s,a,u){return async c=>{let f=[],g=r.cardStore.readCard(c.nodeId);if(!g)return "task-initiate-failure";let m=g.id,R=g.card_data??{},O=g.source_defs??[],F=O.filter(P=>P.optionalForCompletionGating!==true),S=r.cardRuntimeStore.readRuntime(m),x=false,b=()=>{x&&(r.cardRuntimeStore.writeRuntime(m,S),x=false);},N=P=>Wt(S._sources[P]),L=(P,D)=>{S._sources[P]=Wt(D),x=true;},y=c.taskState?.executionCount??0;if(S._lastExecutionCount!==y&&(S._sources={},S._lastExecutionCount=y,x=true),c.update){let P=c.update,D=P.outputFile;if(D){let Y=N(D);if(P.failure){let ae=P.rqt??Y.lastRequestedToken??Y.queueRequestedToken;ae&&L(D,Xt(Y,ae));}else {let ae=P.rqt;if(!Y.lastCompletedToken||ae>Y.lastCompletedToken){let pe=typeof P.deliveryToken=="string"?P.deliveryToken:void 0,ve=false;pe&&(ve=r.fetchedSourcesStore.commitSourceData(m,D,pe)),ve?L(D,Qr(Y,ae)):L(D,Xt(Y,ae));}}b();}}let I={};for(let P of O)if(P.outputFile){let D=r.fetchedSourcesStore.readSourceData(m,P.outputFile);D!==null&&(I[P.bindTo]=D);}let U={};for(let[P,D]of Object.entries(c.state??{}))if(D!==null&&typeof D=="object"&&!Array.isArray(D)){let Y=D[P];U[P]=Y!==void 0?Y:D;}else U[P]=D;let A={id:m,card_data:{...R},requires:U,source_defs:O,compute:g.compute};A._sourcesData=I,g.compute&&Ye.runSync(A,{sourcesData:I}),(a??r.outputStore.writeComputedValues.bind(r.outputStore))(m,A.computed_values??{});let E={...g},z=Ye.enrichSourcesSync(Array.isArray(g.source_defs)?g.source_defs:void 0,{card_data:g.card_data,requires:U}),H=e.value;E.source_defs=Array.isArray(z)?z.map(P=>({...P,boardDir:typeof P.boardDir=="string"&&P.boardDir?P.boardDir:H})):z;let W=en(),oe=c.update?void 0:W,se=F.filter(P=>{let D=P.outputFile;if(typeof D!="string"||!D)return true;let Y=N(D);oe&&(Y={...Y,queueRequestedToken:oe},L(D,Y));let ae=Y.queueRequestedToken??Y.lastRequestedToken??W,pe=Yt(Y,ae);return pe==="in-flight"?false:pe==="dispatch"});if(b(),se.length>0){let P=false,D=W;for(let Y of se){let ae=Y.outputFile;if(typeof ae!="string"||!ae)continue;let pe=N(ae),ve=pe.queueRequestedToken??W;L(ae,{...pe,lastRequestedToken:ve}),D=ve,P=true;}return P&&b(),P&&(f.push({taskKind:"source-fetch",payload:{boardRef:be(e),enrichedCard:E,callbackToken:c.callbackToken,rqt:D}}),r.executionRequestStore.appendEntries(t,f)),"task-initiated"}if(F.some(P=>{let D=P.outputFile;if(typeof D!="string"||!D)return false;let Y=N(D),ae=Y.queueRequestedToken??Y.lastRequestedToken??W;return Yt(Y,ae)==="in-flight"}))return "task-initiated";let Pe=g.provides??[],we={};for(let{bindTo:P,ref:D}of Pe)we[P]=Ye.resolve(A,D);return (u??r.outputStore.writeDataObjects.bind(r.outputStore))(we),O.filter(P=>{if(P.optionalForCompletionGating!==true)return false;let D=N(P.outputFile);return !D.lastRequestedToken||!D.lastCompletedToken?true:D.lastCompletedToken<=D.lastRequestedToken}).length>0&&f.push({taskKind:"source-fetch",payload:{boardRef:be(e),enrichedCard:E,callbackToken:c.callbackToken,rqt:W}}),n(c.nodeId,we),f.length>0&&r.executionRequestStore.appendEntries(t,f),"task-initiated"}}var xt={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function ar(e){return {[Fe]:e.graph,[er]:e.lastDrainedJournalId}}function ir(e){let t=e[Fe],r=e[er];if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${Fe}`);return {graph:t,lastDrainedJournalId:typeof r=="string"?r:""}}function ur(e){let t=e.requires,r=e.provides?.map(n=>n.bindTo)??[];return {requires:t&&t.length>0?t:void 0,provides:r,taskHandlers:["card-handler"],description:e.meta?.title??e.id}}function pt(e){function t(a){return {status:"success",data:a}}function r(a){return {status:"fail",error:a}}function n(a){return {status:"error",error:a instanceof Error?a.message:String(a)}}function s(a){if(Array.isArray(a))return a;if(a&&typeof a=="object"){let u=a;return Array.isArray(u.files)?u.files:[a]}return null}return {get(a){try{let u=a.params?.id;if(u){let c=e.readCard(u);return c?t({cards:[c]}):r(`card "${u}" not found`)}return t({cards:e.readAllCards()})}catch(u){return n(u)}},set(a){try{let u=a.body;if(u==null)return r("set requires a body (card object or array of cards)");let c=Array.isArray(u)?u:[u];for(let f of c){if(typeof f.id!="string")return r("each card must have a string `id` field");e.writeCard(f.id,f);}return t({count:c.length})}catch(u){return n(u)}},del(a){try{let u=a.body?.ids??[],c=a.params?.id,f=c?[...u,c]:u;if(f.length===0)return r("del requires body.ids (string[]) or params.id");for(let g of f)e.removeCard(g);return t({count:f.length})}catch(u){return n(u)}},patch(a){try{let u=a.params?.id,c=a.params?.path;if(!u)return r("patch requires params.id");if(!c)return r("patch requires params.path");let f=a.body,g=f&&Object.prototype.hasOwnProperty.call(f,"value")?f.value:a.body;return e.patchCard(u,c,g),t({count:1})}catch(u){return n(u)}},appendFiles(a){try{let u=a.params?.id;if(!u)return r("appendFiles requires params.id");let c=e.readCard(u);if(!c)return r(`card "${u}" not found`);let f=s(a.body);if(!f||f.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let g=c.card_data&&typeof c.card_data=="object"&&!Array.isArray(c.card_data)?c.card_data:{},m=Array.isArray(g.files)?g.files:[],R=[...m,...f],O=f.map((S,x)=>({idx:m.length+x,entry:S})),F=this.patch({params:{id:u,path:"card_data.files"},body:{value:R}});return F.status!=="success"?F:t({files_added:O})}catch(u){return n(u)}}}}function te(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function X(e){return {status:"fail",error:e}}function re(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function tn(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 dr(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),s=Uint8Array.from(n,a=>a.charCodeAt(0));return new TextDecoder().decode(s)}function mt(e){try{let t=JSON.parse(dr(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function rn(e){return tn(JSON.stringify(e))}function cr(e){try{let t=JSON.parse(dr(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function ue(){return new Date().toISOString()}function lr(e,t){let r=t.onWarn??(()=>{}),n=be(e);function s(C){if(C.length!==0)try{let l=t.publishBoardChangeNotifications?.(C);l&&typeof l.catch=="function"&&l.catch(w=>r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${w instanceof Error?w.message:String(w)}`));}catch(l){r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${l instanceof Error?l.message:String(l)}`);}}function a(){let C=c().readCardStoreRef();if(!C)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let l=t.kvStorageForRef(C);return {readIndex(){return l.read("_index")},writeIndex(w){l.write("_index",w);},readCard(w){return l.read(w)},writeCard(w,_){return l.write(w,_),t.hashFn(_)},removeCard(w){l.delete(w);},cardExists(w){return l.read(w)!==null},defaultCardKey(w){return w}}}let u={readValues(C){let l=t.kvStorage("state-snapshot"),w=l.listKeys().sort();if(w.length===0)return {version:null,values:{}};let _={};for(let G of w)_[G]=l.read(G);return {version:t.hashFn(_),values:_}},writeValues(C,l,w){let _=t.kvStorage("state-snapshot");for(let G of w)_.delete(G);for(let[G,K]of Object.entries(l))_.write(G,K);return t.hashFn(l)}},c=()=>nr(t.kvStorage("config")),f=()=>rr(u),g=()=>Zt(t.journalAdapter()),m=()=>dt(a(),r),R=()=>{let C=c().readOutputsStoreRef();if(!C)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return or(t.kvStorageForRef(C))},O=()=>{let C=c().readArchiveStoreRef();return C?t.archiveFactoryForRef(C):t.archiveFactory()};function F(){return !!f().readSnapshot(e.value).values[Fe]}function S(){let C=f().readSnapshot(e.value);if(!C.values[Fe])throw new Error(`Board not initialized at ${e.value}`);return ir(C.values)}function x(C,l){let w=f().commitSnapshot(e.value,{schemaVersion:ft,expectedVersion:l,commitId:t.genId(),committedAt:ue(),deleteKeys:[],shallowMerge:ar(C)});if(!w.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${l??"null"} current=${w.currentVersion??"null"}`)}function b(C){g().appendEvent(C);}async function N(){let C=(v,o)=>{let i=v.payload,p=(i?.enrichedCard??{}).id??i?.cardId??"unknown";b({type:"task-failed",taskName:p,error:o,timestamp:ue()});},l=Qt(t.kvStorage("execution-requests"),C),w=tr(t.kvStorage("card-runtime")),_=lt(t.blobStorage("sources"),v=>t.resolveBlob(v)),G=new Map,K={readRuntime(v){return G.get(v)??w.readRuntime(v)},writeRuntime(v,o){G.set(v,o);}},ie=[],Q=new Map,q={readSourceData(v,o){let i=`${v}/${o}`;return Q.has(i)?Q.get(i):_.readSourceData(v,o)},ingestSourceDataStaged(v,o,i,d){_.ingestSourceDataStaged(v,o,i,d);},commitSourceData(v,o,i){let d=`${v}/.staged/${i}/${o}`,h=t.blobStorage("sources").read(d);if(h==null)return false;let k=`${v}/${o}`,j=h.trim();try{Q.set(k,JSON.parse(j));}catch{Q.set(k,j);}return ie.push({cardId:v,outputFile:o,deliveryToken:i}),true},hasSource(v,o){let i=`${v}/${o}`;return Q.has(i)?true:_.hasSource(v,o)},listSources(v){let o=_.listSources(v),i=new Set;for(let p of Q.keys())p.startsWith(`${v}/`)&&i.add(p.slice(`${v}/`.length));let d=new Set([...o,...i]);return Array.from(d)}},ne={cardStore:m(),cardRuntimeStore:K,fetchedSourcesStore:q,outputStore:R(),executionRequestStore:l},xe=S(),Se=ut(xe.graph),{events:Ae,newCursor:Ee}=g().readEntriesAfterCursor(xe.lastDrainedJournalId),Re=[],$e=[],Te=[],Be=new Map,qe=new Set,Ct=(v,o)=>{Re.push({type:"task-completed",taskName:v,data:o,timestamp:ue()});try{O().stream("exec-history").append({taskName:v,status:"completed",completedAt:ue()});}catch{}},He=(v,o)=>{b({type:"task-failed",taskName:v,error:o,timestamp:ue()});try{O().stream("exec-history").append({taskName:v,status:"failed",error:o,completedAt:ue()});}catch{}},Le=Gt(Se,{handlers:{"card-handler":sr(e,Ee,ne,Ct,He,(v,o)=>{$e.push({cardId:v,values:o});},v=>{Te.push(v);})},onNodeRemoved:v=>{Be.delete(v),G.delete(v),qe.add(v);}});for(Re=Ae;Re.length>0;){let v=Re;Re=[];for(let o of v)if(o.type==="task-restart"){let i=ne.cardStore.readCard(o.taskName);i&&Be.set(o.taskName,i);}Le.pushAll(v),await Le.waitForHandlers();}let et=Le.getState();await Le.dispose({wait:true});let St=f().readSnapshot(e.value).version;x({lastDrainedJournalId:Ee,graph:Je(et)},St);for(let{cardId:v,values:o}of $e)ne.outputStore.writeComputedValues(v,o);for(let v of Te)ne.outputStore.writeDataObjects(v);for(let[v,o]of G)w.writeRuntime(v,o);for(let{cardId:v,outputFile:o,deliveryToken:i}of ie)_.commitSourceData(v,o,i);let Ge;try{Ge=gt(n,et),ne.outputStore.writeStatusSnapshot(Ge);}catch(v){r(`[board-live-cards-public] status publish failed: ${v instanceof Error?v.message:String(v)}`);}let _e=[];for(let{cardId:v,values:o}of $e)_e.push({kind:"computed_values",cardId:v,values:o});for(let v of Te)for(let[o,i]of Object.entries(v))o&&_e.push({kind:"data_object",key:o,payload:i});for(let[v,o]of Be)_e.push({kind:"card_refreshed",cardId:v,card:o});for(let v of qe)_e.push({kind:"card_removed",cardId:v});Ge!==void 0&&_e.push({kind:"status",status:Ge}),s(_e);let Rt=c().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:be({kind:"built-in",value:"source-cli-task-executor"})};l.dispatchEntriesForJournalId(Ee,v=>{if(v.taskKind!=="source-fetch"){r(`[process-accumulated-events] unknown taskKind "${v.taskKind}" \u2014 skipping`);return}let o=v.payload,i=o.enrichedCard?.id??"unknown",d=o.enrichedCard?.source_defs??[];for(let p of d){if(!p.outputFile){r(`[dispatch] source "${p.bindTo}" has no outputFile \u2014 skipping`);continue}let h=rn({cbk:o.callbackToken,rg:e.value,br:be(e),cid:i,b:p.bindTo,d:p.outputFile,cs:void 0,rqt:o.rqt});t.dispatchExecution(Rt,{source_def:p,base_ref:be(e),callback:{token:h,via:t.selfRef}}).catch(k=>He(i,k instanceof Error?k.message:String(k)));}});}async function L(){try{let C=()=>{let w=S(),{events:_}=g().readEntriesAfterCursor(w.lastDrainedJournalId);_.length<=0||(L(),t.requestProcessAccumulated?.());},l=await Et(t.lock,N,C);return te({ran:l!==!1})}catch(C){return re(C)}}function y(){L(),t.requestProcessAccumulated?.();}function T(C){try{let l=C.params?.cardStoreRef;if(!l)return X("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!F()){let ne=it(xt);x({lastDrainedJournalId:"",graph:Je(ne)},null);}let w=C.params?.outputsStoreRef;if(!w)return X("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let _=C.params?.scratchStoreRef,G=C.params?.archiveStoreRef,K=C.params?.chatStoreRef,ie=C.params?.artifactsStoreRef,Q=c();Q.writeCardStoreRef(l),Q.writeOutputsStoreRef(w),_&&Q.writeScratchStoreRef(_),G&&Q.writeArchiveStoreRef(G),K&&Q.writeChatStoreRef(K),ie&&Q.writeArtifactsStoreRef(ie);let q=C.body??{};q["task-executor-ref"]&&Q.writeTaskExecutorRef(q["task-executor-ref"]),Object.prototype.hasOwnProperty.call(q,"chat-handler-flow")&&Q.writeChatHandlerFlow(q["chat-handler-flow"]);try{R().writeStatusSnapshot(gt(n,ut(S().graph)));}catch{}return te()}catch(l){return re(l)}}function I(C){try{let l=R().readStatusSnapshot();if(!l){l=gt(n,ut(S().graph));try{R().writeStatusSnapshot(l);}catch{}}return te(l)}catch(l){return re(l)}}function U(C){try{let l=C.params?.id;return l?(b({type:"task-removal",taskName:l,timestamp:ue()}),y(),te()):X("removeCard requires params.id")}catch(l){return re(l)}}function A(C){try{let l=C.params?.cardId;if(!l)return X("addCardFiles requires params.cardId");let w=pt(m()).appendFiles({params:{id:l},body:C.body});if(w.status!=="success")return w;let _=E({params:{cardId:l}});return _.status!=="success"?_:te({cardId:l,files_added:w.data.files_added,notified:!0})}catch(l){return re(l)}}function E(C){try{let l=C.params?.cardId;if(!l)return X("cardRefreshedNotify requires params.cardId");let w=m().readCard(l);return w?(s([{kind:"card_refreshed",cardId:l,card:w}]),te({cardId:l,notified:!0})):X(`Card "${l}" not found in board at ${e.value}`)}catch(l){return re(l)}}function z(C){try{let l=C.params?.id;return l?(b({type:"task-restart",taskName:l,timestamp:ue()}),y(),te()):X("retrigger requires params.id")}catch(l){return re(l)}}async function H(C){return L()}function W(C){try{let l=C.params?.cardId,w=C.params?.all,_=!!C.params?.restart;if(!l&&!w)return X("upsertCard requires --card-id <id> or --all");let G=w?m().readAllCards().map(K=>K.id):[l];for(let K of G)if(!m().readCard(K))return X(`Card "${K}" not found in board at ${e.value}`);for(let K of G){let ie=m().readCard(K),Q=ur(ie),q=t.hashFn(Q),ne=t.kvStorage("card-upsert"),xe=ne.read(K),Se=xe?.taskConfigHash!==q;if(!(!Se&&!_)){if(Se){let Ae=xe?.blobRef??m().readCardKey(K)??K;b({type:"task-upsert",taskName:K,taskConfig:Q,timestamp:ue()}),ne.write(K,{blobRef:Ae,taskConfigHash:q,updatedAt:ue()});}_&&b({type:"task-restart",taskName:K,timestamp:ue()});}}return y(),te()}catch(l){return re(l)}}function oe(C){try{let l=C.params?.token;if(!l)return X("taskFailed requires params.token");let w=C.params?.error??"unknown error",_=mt(l);if(!_)return X("Invalid callback token");b({type:"task-failed",taskName:_.taskName,error:w,timestamp:ue()});try{O().stream("exec-history").append({taskName:_.taskName,status:"failed",error:w,completedAt:ue()});}catch{}return y(),te()}catch(l){return re(l)}}function se(C){try{let l=C.params?.token;if(!l)return X("taskProgress requires params.token");let _=(C.body??{}).update??{},G=mt(l);return G?(b({type:"task-progress",taskName:G.taskName,update:_,timestamp:ue()}),y(),te()):X("Invalid callback token")}catch(l){return re(l)}}function Ce(C){try{let l=C.params?.token,w=C.params?.ref;if(!l)return X("sourceDataFetched requires params.token");if(!w)return X("sourceDataFetched requires params.ref");let _=cr(l);if(!_)return X("Invalid source token");let{cbk:G,cid:K,b:ie,d:Q,cs:q,rqt:ne}=_,xe=lt(t.blobStorage("sources"),Re=>t.resolveBlob(Re)),Se=t.genId();xe.ingestSourceDataStaged(K,Q,At(w),Se);let Ae=mt(G);if(!Ae)return X("Invalid callback token embedded in source token");let Ee=ue();return b({type:"task-progress",taskName:Ae.taskName,update:{bindTo:ie,outputFile:Q,fetchedAt:Ee,deliveryToken:Se,sourceChecksum:q,rqt:ne},timestamp:Ee}),y(),te()}catch(l){return re(l)}}function Pe(C){try{let l=C.params?.token,w=C.params?.reason??"unknown";if(!l)return X("sourceDataFetchFailure requires params.token");let _=cr(l);if(!_)return X("Invalid source token");let{cbk:G,b:K,d:ie,cs:Q,rqt:q}=_,ne=mt(G);return ne?(b({type:"task-progress",taskName:ne.taskName,update:{bindTo:K,outputFile:ie,failure:!0,reason:w,sourceChecksum:Q,rqt:q},timestamp:ue()}),y(),te()):X("Invalid callback token embedded in source token")}catch(l){return re(l)}}function we(C){try{let l=c().readCardStoreRef();return l?te({storeRef:l}):X(`Board at ${e.value} has no card store configured`)}catch(l){return re(l)}}function le(C){try{let l=c().readOutputsStoreRef();return l?te({storeRef:l}):X(`Board at ${e.value} has no outputs store configured`)}catch(l){return re(l)}}function P(C){try{let l=c().readScratchStoreRef();return te({storeRef:l})}catch(l){return re(l)}}function D(C){try{let l=c().readArchiveStoreRef();return te({storeRef:l})}catch(l){return re(l)}}function Y(C){try{let l=c().readChatStoreRef();return te({storeRef:l})}catch(l){return re(l)}}function ae(C){try{let l=c().readArtifactsStoreRef();return te({storeRef:l})}catch(l){return re(l)}}function pe(C){try{let l=C.params?.key;if(!l)return X("getConfig requires params.key");let w=c(),_;switch(l){case "task-executor":_=w.readTaskExecutorRef()??null;break;case "chat-handler-flow":_=w.readChatHandlerFlow()??null;break;case "card-store-ref":_=w.readCardStoreRef();break;case "outputs-store-ref":_=w.readOutputsStoreRef();break;case "scratch-store-ref":_=w.readScratchStoreRef();break;case "archive-store-ref":_=w.readArchiveStoreRef();break;case "chat-store-ref":_=w.readChatStoreRef();break;case "artifacts-store-ref":_=w.readArtifactsStoreRef();break;default:return X(`getConfig: unknown key "${l}"`)}return te({value:_})}catch(l){return re(l)}}function ve(C){try{let l=C.params?.key;if(!l)return X("getOutputsDataObject requires params.key");let w=R().readDataObject(l);return te(w)}catch(l){return re(l)}}function De(C){try{return te(R().readAllDataObjects())}catch(l){return re(l)}}function Me(C){try{let l=C.params?.key;if(!l)return X("getOutputsComputedValues requires params.key");let w=R().readComputedValues(l);return te(w)}catch(l){return re(l)}}function ht(C){try{return te(R().readAllComputedValues())}catch(l){return re(l)}}function Ue(){return lt(t.blobStorage("sources"),C=>t.resolveBlob(C))}function Xe(C){let l=t.blobStorage("sources").keyRef?.(C);return l?be(l):C}function yt(C){try{let l=C.params?.key;if(!l)return X("getOutputsFetchedSources requires params.key");let w=Ue().listSources(l),_={};for(let G of w)_[G]=Xe(`${l}/${G}`);return te(_)}catch(l){return re(l)}}function kt(C){try{let l=Ue(),w=new Set;for(let G of t.blobStorage("sources").listKeys()){let K=G.indexOf("/");K>0&&!G.includes("/.staged/")&&w.add(G.slice(0,K));}let _={};for(let G of w){let K=l.listSources(G);if(K.length>0){_[G]={};for(let ie of K)_[G][ie]=Xe(`${G}/${ie}`);}}return te(_)}catch(l){return re(l)}}return {init:T,status:I,getCardStoreRef:we,getOutputsStoreRef:le,getScratchStoreRef:P,getArchiveStoreRef:D,getChatStoreRef:Y,getArtifactsStoreRef:ae,getConfig:pe,getOutputsDataObject:ve,getAllOutputsDataObjects:De,getOutputsComputedValues:Me,getAllOutputsComputedValues:ht,getOutputsFetchedSources:yt,getAllOutputsFetchedSources:kt,removeCard:U,addCardFiles:A,cardRefreshedNotify:E,retrigger:z,processAccumulatedEvents:H,upsertCard:W,taskFailed:oe,taskProgress:se,sourceDataFetched:Ce,sourceDataFetchFailure:Pe}}function fr(){return new Date().toISOString()}function gr(e){return new TextEncoder().encode(e).byteLength}function nn(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function on(e){let t=String(e||"").match(/^(\d+)[-_]/);return t?parseInt(t[1],10):0}function sn(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 an(e){return String(e||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function un(e){if(!e||e===".")return "";let t=String(e).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return t?`.${t}`:""}function cn(e){let t=sn(e),r=t.lastIndexOf(".");return r<=0||r===t.length-1?{stem:t,ext:""}:{stem:t.slice(0,r),ext:t.slice(r)}}function dn(e){let t=e.lastIndexOf("/");return t>=0?e.slice(t+1):e}function pr(e){function t(r){let n=e.stat?nn(e.stat(r)):null;if(n)return n;if(!e.exists(r))return null;let s=e.read(r);return s===null?{key:r}:{key:r,size:gr(s)}}return {exists(r){return e.exists(r)},putText(r,n,s="text/plain; charset=utf-8"){e.write(r,n);let a=t(r)??{key:r};return a.contentType=s,a.updatedAt=a.updatedAt??fr(),a.size=a.size??gr(n),a},putBytes(r,n,s="application/octet-stream"){if(e.writeBytes)e.writeBytes(r,n);else {let u=JSON.stringify({__kind:"bytes-array",data:[...n]});e.write(r,u);}let a=t(r)??{key:r};return a.contentType=s,a.updatedAt=a.updatedAt??fr(),a.size=a.size??n.byteLength,a},getText(r){let n=e.read(r);if(n===null){if(!e.readBytes)return null;let s=e.readBytes(r);return s===null?null:Buffer.from(s).toString("utf-8")}try{let s=JSON.parse(n);if(s&&s.__kind==="bytes-array"&&Array.isArray(s.data))return new TextDecoder("utf-8").decode(new Uint8Array(s.data))}catch{}return n},getBytes(r){if(e.readBytes){let s=e.readBytes(r);if(s!==null)return s}let n=e.read(r);if(n===null)return null;try{let s=JSON.parse(n);if(s&&s.__kind==="bytes-array"&&Array.isArray(s.data))return new Uint8Array(s.data)}catch{}return new TextEncoder().encode(n)},head:t,list(r=""){return e.listKeys(r).map(n=>t(n)??{key:n}).sort((n,s)=>n.key.localeCompare(s.key))},remove(r){e.remove(r);}}}function mr(e){function t(s,a){let u=0,c=[];Array.isArray(a)&&c.push(...a);for(let f of e.list(`${s}/`))c.push(dn(f.key));for(let f of c){let g=on(f);Number.isFinite(g)&&g>u&&(u=g);}return u+1}function r(s,a,u){let c=Number(u?.maxLen||32),{stem:f,ext:g}=cn(s),m=un(g),R=an(f),O=`${String(a).padStart(3,"0")}-`,F=m,S=c-O.length-F.length;S<1&&(F="",S=c-O.length);let x=R.slice(0,Math.max(1,S)),b=`${O}${x}${F}`;return b.length>c&&(b=b.slice(0,c).replace(/\.$/,"")),b}function n(s,a,u){let c=t(s,u?.seedNames),f=r(a,c,{maxLen:u?.maxLen});for(;e.exists(`${s}/${f}`);)c+=1,f=r(a,c,{maxLen:u?.maxLen});return f}return {nextSerial:t,buildStoredName:r,allocateStoredName:n}}function hr(){function e(s,a){if(!Array.isArray(s))return [];let u=[];for(let c of s){if(!c||typeof c!="object")continue;let f=c;typeof f.stored_name=="string"&&u.push({name:typeof f.name=="string"?f.name:f.stored_name,stored_name:f.stored_name,size:typeof f.size=="number"&&Number.isFinite(f.size)?f.size:null,mime_type:typeof f.mime_type=="string"?f.mime_type:null,uploaded_at:typeof f.uploaded_at=="string"?f.uploaded_at:a||null,chat:f.chat===true});}return u}function t(s){return !s||typeof s!="object"?[]:e(s.files,void 0)}function r(s,a){let u=t(s);if(a.length===0)return s.files=u,u;let c=new Set(u.map(f=>f.stored_name));for(let f of a)c.has(f.stored_name)||(u.push(f),c.add(f.stored_name));return s.files=u,u}function n(s,a,u){let c=t(s);if(!Number.isInteger(a)||a<0||a>=c.length)return {ok:false,reason:"index_out_of_range"};let f=c[a];return !f||!f.stored_name?{ok:false,reason:"missing_stored_name"}:u&&u!==f.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:f}}return {read:t,normalizeIncoming:e,merge:r,resolve:n}}function ln(){let e=globalThis.crypto;return typeof e?.randomUUID=="function"?String(e.randomUUID()):`id-${Date.now()}-${Math.random().toString(36).slice(2)}`}function yr(){let e=new Map,t=new Map;function r(n){return e.has(n)||e.set(n,[]),e.get(n)}return {append(n,s,a,u=[]){let c={id:ln(),role:s,text:a,files:u,updated_at:new Date().toISOString()};return r(n).push(c),c.id},readAll(n){return r(n).slice()},readAfter(n,s){let a=r(n);if(!s)return {records:a.slice(),cursor:a.length>0?a[a.length-1].id:null};let u=a.findIndex(f=>f.id===s),c=u===-1?a.slice():a.slice(u+1);return {records:c,cursor:c.length>0?c[c.length-1].id:s}},clear(n){e.set(n,[]);},setProcessing(n,s){s?t.set(`p:${n}`,true):t.delete(`p:${n}`);},isProcessing(n){return t.get(`p:${n}`)===true},getConfig(n){return t.get(`c:${n}`)??{}},setConfig(n,s){let a=t.get(`c:${n}`)??{};t.set(`c:${n}`,{...a,...s});}}}function kr(e){function t(g){let m=typeof g=="number"?g:Number(g);return Number.isInteger(m)&&m>0?m:null}function r(g,m){let R=m;for(let O=g.length-1;O>=0;O-=1)if(g[O]?.role==="user"&&(R-=1,R===0))return g.slice(O);return g}function n(g){return {status:"success",data:g}}function s(g){return {status:"fail",error:g}}function a(g){return {status:"error",error:g instanceof Error?g.message:String(g)}}function u(g,m="command envelope"){let R=typeof g.cardId=="string"?g.cardId:void 0;if(!g.command)return s(`chat-store: ${m} missing "command"`);if(!R)return s(`chat-store: ${m} missing "cardId"`);if(g.command==="append")return f.append({params:{cardId:R},body:{role:g.role,text:g.text,files:g.files}});if(g.command==="read-all")return f.readAll({params:{cardId:R},body:{lastUserTurns:g.lastUserTurns}});if(g.command==="read-after")return f.readAfter({params:{cardId:R},body:{cursor:g.cursor??null}});if(g.command==="clear")return f.clear({params:{cardId:R}});if(g.command==="set-processing")return f.setProcessing({params:{cardId:R},body:{active:g.active}});if(g.command==="is-processing")return f.isProcessing({params:{cardId:R}});if(g.command==="get-config")return f.getConfig({params:{cardId:R}});if(g.command==="set-config"){let{command:O,cardId:F,...S}=g;return f.setConfig({params:{cardId:R},body:S})}return s(`chat-store: unknown command "${String(g.command)}"`)}function c(g){if(!Array.isArray(g.commands)||g.commands.length===0)return s('chat-store: command envelope must include a non-empty "commands" array');let m=[];for(let R=0;R<g.commands.length;R+=1){let O=g.commands[R];if(!O||typeof O!="object"||Array.isArray(O))return s(`chat-store: command envelope entry ${R} must be an object`);let F={cardId:g.cardId,...O},S=u(F,`command envelope entry ${R}`);if(S.status!=="success")return S;m.push({index:R,command:String(F.command),data:S.data});}return n({results:m})}let f={append(g){try{let m=g.params?.cardId;if(!m)return s("append requires params.cardId");let R=g.body??{},O=typeof R.role=="string"?R.role:"",F=typeof R.text=="string"?R.text:"",S=Array.isArray(R.files)?R.files:[];if(!O)return s("append requires body.role");let x=e.append(m,O,F,S);return n({id:x})}catch(m){return a(m)}},readAll(g){try{let m=g.params?.cardId;if(!m)return s("readAll requires params.cardId");let R=g.body??{},O=e.readAll(m);if(R.lastUserTurns===void 0)return n({records:O});let F=t(R.lastUserTurns);return F===null?s("readAll requires body.lastUserTurns (positive integer)"):n({records:r(O,F)})}catch(m){return a(m)}},readAfter(g){try{let m=g.params?.cardId;if(!m)return s("readAfter requires params.cardId");let O=(g.body??{}).cursor??null;return n(e.readAfter(m,O))}catch(m){return a(m)}},clear(g){try{let m=g.params?.cardId;return m?(e.clear(m),n({ok:!0})):s("clear requires params.cardId")}catch(m){return a(m)}},setProcessing(g){try{let m=g.params?.cardId;if(!m)return s("setProcessing requires params.cardId");let R=g.body??{};return typeof R.active!="boolean"?s("setProcessing requires body.active (boolean)"):(e.setProcessing(m,R.active),n({ok:!0}))}catch(m){return a(m)}},isProcessing(g){try{let m=g.params?.cardId;return m?n({active:e.isProcessing(m)}):s("isProcessing requires params.cardId")}catch(m){return a(m)}},getConfig(g){try{let m=g.params?.cardId;return m?n({config:e.getConfig(m)}):s("getConfig requires params.cardId")}catch(m){return a(m)}},setConfig(g){try{let m=g.params?.cardId;if(!m)return s("setConfig requires params.cardId");let R=g.body??{};return e.setConfig(m,R),n({ok:!0})}catch(m){return a(m)}},run:u,runBatch:c};return f}var Cr={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},fn=32;function gn(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Sr(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 Rr(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)Rr(e,n);return}r.kind==="status"&&Sr(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 yo(e){let t=String(e.apiBasePath||"/api/board").replace(/\/$/,""),r={...Cr,...e.corsHeaders||{}},n=e.boardId||"",s=e.logger||{info:console.log,warn:console.warn,error:console.error},a=e.invocationAdapter,u=e.chatFlowRunner||null,c=e.chatStorage??yr(),f=kr(c),g=e.notificationTransport||null,m=e.serverUrl||null,R=e.executionExtra||{},O=e.onSseClientConnected,F=e.onSseClientDisconnected,S=e.onChannelSubscribed,x=e.onChannelUnsubscribed,b=new Map,N=new Map,L=new Map,y=null;function T(o){let i=lr(o.baseRef,o.boardAdapter),d=o.boardAdapter.kvStorageForRef(o.cardStoreRef),h=pt(dt({readIndex:()=>d.read("_index"),writeIndex:$=>d.write("_index",$),readCard:$=>d.read($),writeCard:($,J)=>(d.write($,J),$),cardExists:$=>d.read($)!==null,defaultCardKey:$=>$},s.warn)),k=o.artifactsAdapter||o.boardAdapter,j=o.filesArtifactsStore??null,B=null;return {label:o.label,board:i,cardStore:h,get filesArtifacts(){return B??=j??pr(k.blobStorage("files"))},boardAdapter:o.boardAdapter,cardStoreRef:o.cardStoreRef,outputsStoreRef:o.outputsStoreRef,scratchStoreRef:o.scratchStoreRef,archiveStoreRef:o.archiveStoreRef,notifyRef:o.notifyRef,taskExecutorRef:o.taskExecutorRef,chatHandlerRef:o.chatHandlerRef,chatHandlerFlow:o.chatHandlerFlow,inferenceAdapterRef:o.inferenceAdapterRef,notification:gn(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let I=e.boards.map(T),U=new Map;function A(o){return U.get(o)??0}function E(o){let i=I[A(o)];return {files:i?i.filesArtifacts:null}}function z(o){let i=E(o);return i.files?mr(i.files):null}function H(){return hr()}function W(o){return String(o||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function oe(o){if(!o||o.notificationTeardown||!g||!o.notifyRef)return;let i=await g.subscribe(o.notifyRef,d=>{Rr(o.notification,d);let p=d.kind==="notification-batch"?d.notifications:[d];_e(p);});o.notificationTeardown=i;}async function se(o){if(!o||o.initialized)return;let i={cardStoreRef:o.cardStoreRef,outputsStoreRef:o.outputsStoreRef};o.scratchStoreRef&&(i.scratchStoreRef=o.scratchStoreRef),o.archiveStoreRef&&(i.archiveStoreRef=o.archiveStoreRef);let d={};o.taskExecutorRef&&(d["task-executor-ref"]=o.taskExecutorRef),o.chatHandlerFlow!==void 0&&(d["chat-handler-flow"]=o.chatHandlerFlow),o.inferenceAdapterRef&&(d["inference-adapter-ref"]=o.inferenceAdapterRef);let p=o.board.init({params:i,body:d});if(p.status!=="success")throw Object.assign(new Error(p.error||`init failed for ${o.label}`),{statusCode:500});if(await oe(o),!o.chatHandlerFlow&&o.chatHandlerRef&&a.describe)try{let h=await a.describe(o.chatHandlerRef);h&&h.kind!=="chat-handler"?s.warn(`[init] chat-handler describe returned kind="${h.kind}", expected "chat-handler" for ${o.label}`):h&&s.info(`[init] chat-handler validated: ${h.name} (protocol ${h.protocolVersion}) for ${o.label}`);}catch(h){s.warn(`[init] chat-handler describe failed for ${o.label}: ${h?.message||String(h)}`);}o.initialized=true;}function Ce(o){if(!o.boardAdapter.publishBoardChangeNotifications)return;let i=[],d=o.board.status({});d.status==="success"&&d.data!=null&&Sr(d.data)&&i.push({kind:"status",status:d.data});let p=o.board.getAllOutputsDataObjects({});if(p.status==="success"&&p.data!=null)for(let[k,j]of Object.entries(p.data))k&&i.push({kind:"data_object",key:k,payload:j});let h=o.board.getAllOutputsComputedValues({});if(h.status==="success"&&h.data!=null)for(let[k,j]of Object.entries(h.data))k&&i.push({kind:"computed_values",cardId:k,values:j});i.length>0&&o.boardAdapter.publishBoardChangeNotifications(i);}function Pe(o,i){if(!o||o.cardsBootstrapped)return;let d=o.cardStore.get({}),p=d.status==="success"&&Array.isArray(d.data?.cards)?d.data.cards:[];for(let h of p)typeof h.id=="string"&&(U.set(h.id,i),o.board.upsertCard({params:{cardId:h.id}}));o.cardsBootstrapped=true;}async function we(){for(let o of I)await se(o);}async function le(){await we();for(let o=0;o<I.length;o++)Ce(I[o]),Pe(I[o],o);}function P(o){return I[A(o)]??null}function D(o){let i=P(o);if(!i)return null;let d=i.cardStore.get({params:{id:o}});if(d.status!=="success")return null;let p=Array.isArray(d.data?.cards)?d.data.cards:[];return p.length>0?p[0]:null}function Y(){let o=d=>{if(!d||!d.cardStore)return [];let p=d.cardStore.get({});return p.status!=="success"||!Array.isArray(p.data?.cards)?[]:p.data.cards},i=[];for(let d of I)i.push(...o(d));return i}function ae(){let o=I.map(k=>{try{let B=k.boardAdapter.kvStorageForRef(k.outputsStoreRef).read("status");if(B!=null)return B}catch{}return k.notification.status}).filter(Boolean);if(o.length===0)return null;if(o.length===1)return o[0];let i=[],d=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],p={};for(let k of d)p[k]=0;for(let k of o){let j=k,B=Array.isArray(j.cards)?j.cards:[];i.push(...B);for(let $ of d)p[$]+=Number(j?.summary?.[$]||0);}let h=o[0];return {...h,cards:i,summary:{...h.summary||{},card_count:i.length,...p}}}function pe(){let o={},i=d=>{for(let[p,h]of Object.entries(d.notification.computedValues)){let k=d.notification.cards[p];o[p]={schema_version:"v1",card_id:p,card_data:k?.card_data??{},computed_values:h??{}};}};for(let d of I)i(d);return o}function ve(){let o={};for(let i of I)Object.assign(o,i.notification.dataObjects||{});return o}function De(){let o=Y(),i=pe(),d=ve(),p={};for(let k of o){if(!k?.id)continue;let j=k.id,B=i[j]||{},$={...B.card_data&&typeof B.card_data=="object"?B.card_data:k.card_data&&typeof k.card_data=="object"?k.card_data:{}};p[j]={schema_version:B.schema_version||"v1",card_id:B.card_id||j,card_data:$,computed_values:B.computed_values&&typeof B.computed_values=="object"?B.computed_values:{}};}let h={};for(let k of o){if(!k?.id)continue;let j=k.id;try{let B=w(j),$=c.isProcessing(j);(B.length>0||$)&&(h[j]={messages:B.map(J=>({role:String(J.role||"system"),text:String(J.text||""),files:Array.isArray(J.files)?J.files:[]})),receiving:!1,processing:$});}catch{}}return {boardId:n,cardDefinitions:o,statusSnapshot:ae(),dataObjectsByToken:d,cardRuntimeById:p,cardChatsByCardId:h}}function Me(o,i,d){let p=d?.syncBoard!==false,h=d?.restartOnlyIfChanged===true,k=P(o);if(!k)throw Object.assign(new Error(`Card not found: ${o}`),{statusCode:404});let j=D(o);if(!j)throw Object.assign(new Error(`Card not found: ${o}`),{statusCode:404});let B=h?JSON.stringify(j):null,$=i(j)||j;if(h&&JSON.stringify($)===B)return;let J=k.cardStore.set({body:$});if(J.status!=="success")throw Object.assign(new Error(J.error||`Failed to persist card: ${o}`),{statusCode:500});if(p){let Z=k.board.upsertCard({params:{cardId:o,restart:true}});if(Z.status!=="success")throw Object.assign(new Error(Z.error||`Failed to upsert card: ${o}`),{statusCode:500})}}function ht(o,i){Me(o,i,{syncBoard:true});}function Ue(o,i){Me(o,i,{syncBoard:false});}function Xe(o){let i=P(o);if(!i)throw Object.assign(new Error(`Card not found: ${o}`),{statusCode:404});if(!D(o))throw Object.assign(new Error(`Card not found: ${o}`),{statusCode:404});let p=i.board.upsertCard({params:{cardId:o,restart:true}});if(p.status!=="success")throw Object.assign(new Error(p.error||`Failed to retrigger card: ${o}`),{statusCode:500})}function yt(o,i){Me(o,d=>{if(!i||typeof i!="object"||Object.keys(i).length===0)return d;function p(h,k,j){let B=String(k||"").split(".").filter(Boolean);if(!B.length)return;let $=h;for(let J=0;J<B.length-1;J++){let Z=B[J];(!$[Z]||typeof $[Z]!="object")&&($[Z]={}),$=$[Z];}$[B[B.length-1]]=j;}if(i.fieldValues!==void 0&&i.fieldValues!==null){let h=null,k=d.view;if(k&&Array.isArray(k.elements)){for(let j of k.elements)if(j?.data&&j.data.writeTo){h=j.data.writeTo;break}}h?p(d,h,i.fieldValues):typeof i.fieldValues=="object"&&!Array.isArray(i.fieldValues)&&(d.card_data={...d.card_data||{},...i.fieldValues});}else {if(Array.isArray(i._stagedFiles)&&i._stagedFiles.length>0)return d;for(let[h,k]of Object.entries(i))h!=="_stagedFiles"&&(k!==null&&typeof k=="object"&&!Array.isArray(k)&&d[h]!==null&&typeof d[h]=="object"&&!Array.isArray(d[h])?d[h]={...d[h],...k}:d[h]=k);}return d},{syncBoard:true,restartOnlyIfChanged:true});}function kt(o){let i=String(o||"").trim();if(!i)return "upload.bin";let d=Math.max(i.lastIndexOf("/"),i.lastIndexOf("\\"));return (d>=0?i.slice(d+1):i)||"upload.bin"}function C(o){c.clear(o),c.setProcessing(o,false);}function l(o,i,d,p){let h=typeof d=="string"?d.trim():"";return c.append(o,i,h,p)}function w(o){return c.readAll(o)}function _(o){let i=[];try{let d=D(o);if(!d)return i;let p=H().read(d.card_data&&typeof d.card_data=="object"?d.card_data:null);for(let h of p)i.push(h.stored_name);}catch{}return i}function G(o,i,d,p){let h=W(o),k=E(o),j=kt(i),B=z(o),$=B?B.allocateStoredName(h,j,{seedNames:_(o),maxLen:fn}):`${String(Date.now())}-${j}`;return k.files&&k.files.putBytes(`${h}/${$}`,new Uint8Array(p),d||"application/octet-stream"),{name:j,stored_name:$,size:p.length,mime_type:d||"application/octet-stream",uploaded_at:new Date().toISOString()}}function K(o){let i=P(o);if(!i)return null;let d=i.board.getConfig({params:{key:"chat-handler-flow"}}),p=d.status==="success"?d.data?.value:null,h=i.chatHandlerRef;return p==null&&(!h||typeof h!="object")?null:{ctx:i,handlerFlow:p,handlerRef:h}}function ie(o,i,d=false){let p=K(o);if(!p)return;let{ctx:h,handlerFlow:k,handlerRef:j}=p;if(!d)try{c.setProcessing(o,!0);}catch{}let B={boardId:n,cardId:String(o),lastChatEntryId:i,...R,...m?{serverUrl:m}:{}};if(!u&&k!=null){try{c.setProcessing(o,!1);}catch{}s.warn(`[chat-handler-flow] configured for card "${o}" but no chatFlowRunner was provided`);return}if(k!=null){let J=u;if(!J)return;J.run(k,B,{boardId:n,cardId:String(o),label:h.label,logger:s,serverUrl:m,executionExtra:R}).then(Z=>{if(Z.dispatched)s.info(`[chat-handler-flow] invoked for card "${o}" (boardId: "${n}")`);else {try{c.setProcessing(o,!1);}catch{}s.warn(`[chat-handler-flow] dispatch failed for card "${o}": ${Z.error||"unknown"}`);}},Z=>{try{c.setProcessing(o,!1);}catch{}s.warn(`[chat-handler-flow] invoke failed for card "${o}": ${Z?.message||String(Z)}`);});return}let $=j;$&&a.invoke($,B).then(J=>{if(J.dispatched)s.info(`[chat-handler] invoked for card "${o}" (boardId: "${n}")`);else {try{c.setProcessing(o,!1);}catch{}s.warn(`[chat-handler] dispatch failed for card "${o}": ${J.error||"unknown"}`);}},J=>{try{c.setProcessing(o,!1);}catch{}s.warn(`[chat-handler] invoke failed for card "${o}": ${J?.message||String(J)}`);});}function Q(o,i,d){let p=i==="chat-send"?Ue:ht,h;p(o,k=>{let j=new Date().toISOString(),B=k.card_data&&typeof k.card_data=="object"?k.card_data:{};if(k.card_data=B,i==="chat-send"){let $=d&&typeof d.text=="string"?d.text.trim():"",J=[];if(Array.isArray(d?.files)){for(let Z of d.files)if(Z){if(typeof Z=="string"){J.push({name:Z});continue}if(typeof Z=="object"){let fe=Z;typeof fe.name=="string"&&J.push({name:fe.name,size:fe.size,mime_type:fe.mime_type,uploaded_at:fe.uploaded_at,stored_name:fe.stored_name,chat:fe.chat===true});}}}if($||J.length>0){let Z=f.runBatch({cardId:o,commands:[{command:"append",role:"user",text:$,files:J},{command:"set-processing",active:true}]});if(Z.status!=="success")throw new Error(Z.error);let fe=Z.data.results[0]?.data?.id;if(typeof fe!="string"||!fe)throw new Error(`chat-send did not return an append id for card ${o}`);h={cardId:o,lastEntryId:fe,processingAlreadySet:true};try{let rt=w(o);_e([{kind:"card_chats",cardId:o,messages:rt.map(Oe=>({role:String(Oe.role||"system"),text:String(Oe.text||""),files:Array.isArray(Oe.files)?Oe.files:[]})),receiving:!0,processing:c.isProcessing(o)}]);}catch{}}return k}if(i==="file-upload"){let $=H().normalizeIncoming(d?.files,j);return $.length>0&&H().merge(B,$),k}if(i==="action"){let $=d&&typeof d.buttonId=="string"?d.buttonId:"";if(!$)return k;B.lastAction={buttonId:$,at:j},B.lastActionText=`${$} @ ${j}`;}return k}),h&&ie(h.cardId,h.lastEntryId,h.processingAlreadySet);}function q(o,i,d){let p=JSON.stringify(d),h=typeof Buffer<"u"?Buffer.byteLength(p):new TextEncoder().encode(p).length;o.writeHead(i,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":h}),o.end(p);}async function ne(o){let i=[];for await(let p of o)i.push(p);let d=typeof Buffer<"u"?Buffer.concat(i).toString("utf-8").trim():new TextDecoder().decode(Se(i)).trim();return d?JSON.parse(d):{}}async function xe(o){let i=[];for await(let d of o)i.push(d);return typeof Buffer<"u"?Buffer.concat(i):Se(i)}function Se(o){let i=o.reduce((h,k)=>h+k.length,0),d=new Uint8Array(i),p=0;for(let h of o)d.set(h,p),p+=h.length;return d}let Ae=0;function Ee(o){let i=JSON.stringify(o);return Ae++,`id: ${Ae}
|
|
2
|
-
|
|
1
|
+
import {createRequire}from'module';import'ajv-formats';var vt="b64:";function Zr(e){let t=new TextEncoder().encode(e),r=globalThis.Buffer,s;if(r)s=r.from(t).toString("base64");else if(typeof btoa=="function"){let a="";for(let i of t)a+=String.fromCharCode(i);s=btoa(a);}else throw new Error("No base64 encoder available in this runtime");return s.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function Qr(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 s=atob(t),a=new Uint8Array(s.length);for(let i=0;i<s.length;i+=1)a[i]=s.charCodeAt(i);return new TextDecoder().decode(a)}throw new Error("No base64 decoder available in this runtime")}function Ne(e){return `${vt}${Zr(JSON.stringify(e))}`}function ut(e){if(!e.startsWith(vt))throw new Error(`Invalid ref format (expected ${vt}<base64url(json)>): ${e}`);let t;try{t=JSON.parse(Qr(e.slice(vt.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 Wt(e,t,r){let s=e.tryAcquire();if(!s)return false;try{await t();}finally{s();}return r?.(),true}var Qe={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function Pe(e){return e?Array.isArray(e.provides)?e.provides:[]:[]}function et(e){return e?Array.isArray(e.requires)?e.requires:[]:[]}function Yt(e){return e.tasks??{}}function Ut(e){return e?e.status===Qe.FAILED||e.status===Qe.INACTIVATED:false}function Xt(e,t){return e.refreshStrategy??t?.refreshStrategy??"data-changed"}function Zt(e){return e.maxExecutions}function Qt(e,t){let r=new Set;for(let[s,a]of Object.entries(t))if(a.status===Qe.COMPLETED){let i=e.tasks[s];i&&Pe(i).forEach(u=>r.add(u));}return Array.from(r)}function er(e,t){let r={};return e.forEach(s=>{let a=t[s];if(!a)return;Pe(a).forEach(c=>{r[c]||(r[c]=[]),r[c].push(s);});}),r}function tr(e,t,r){let s=e.tasks[t]??xt(),a={};if(r){let c=r.tasks[t],u=et(c);for(let m of u)for(let[h,b]of Object.entries(r.tasks))if(Pe(b).includes(m)){let v=e.tasks[h];v?.lastDataHash&&(a[m]=v.lastDataHash);break}}let i={...s,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:a};return {...e,tasks:{...e.tasks,[t]:i},lastUpdated:new Date().toISOString()}}function rr(e,t,r,s,a,i){let c=e.tasks[r]??xt(),u=t.tasks[r];if(!u)throw new Error(`Task "${r}" not found in graph`);let m;s&&u.on&&u.on[s]?m=u.on[s]:m=Pe(u);let h=c.startConsumedHashes?{...c.startConsumedHashes}:{...c.lastConsumedHashes};if(!c.startConsumedHashes){let M=u.requires??[];for(let J of M)for(let[A,B]of Object.entries(t.tasks))if(Pe(B).includes(J)){let E=e.tasks[A];E?.lastDataHash&&(h[J]=E.lastDataHash);break}}let b={...c,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:c.executionCount+1,lastEpoch:c.executionCount+1,lastDataHash:a,data:i,lastConsumedHashes:h,error:void 0},v=[...new Set([...e.availableOutputs,...m])];return {...e,tasks:{...e.tasks,[r]:b},availableOutputs:v,lastUpdated:new Date().toISOString()}}function nr(e,t,r,s){let a=e.tasks[r]??xt(),i=t.tasks[r];if(i?.retry){let m=a.retryCount+1;if(m<=i.retry.max_attempts){let h={...a,status:"not-started",retryCount:m,lastUpdated:new Date().toISOString(),error:s};return {...e,tasks:{...e.tasks,[r]:h},lastUpdated:new Date().toISOString()}}}let c={...a,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:s,executionCount:a.executionCount+1},u=e.availableOutputs;if(i?.on_failure&&i.on_failure.length>0&&(u=[...new Set([...e.availableOutputs,...i.on_failure])]),i?.circuit_breaker&&c.executionCount>=i.circuit_breaker.max_executions){let m=i.circuit_breaker.on_break;u=[...new Set([...u,...m])];}return {...e,tasks:{...e.tasks,[r]:c},availableOutputs:u,lastUpdated:new Date().toISOString()}}function or(e,t,r,s){let a=e.tasks[t]??xt(),i={...a,progress:typeof s=="number"?s:a.progress,messages:[...a.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:a.status}]:[]],lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:i},lastUpdated:new Date().toISOString()}}function sr(e,t){let r=e.tasks[t];if(!r)return e;let s={...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]:s},lastUpdated:new Date().toISOString()}}function xt(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function At(e,t){let r=`live-${Date.now()}`,s={};for(let i of Object.keys(e.tasks))s[i]=ir();let a={status:"running",tasks:s,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:a}}function en(e,t){let{config:r,state:s}=e;if("executionId"in t&&t.executionId&&t.executionId!==s.executionId)return e;switch(t.type){case "task-started":return {config:r,state:tr(s,t.taskName,r)};case "task-completed":return {config:r,state:rr(s,r,t.taskName,t.result,t.dataHash,t.data)};case "task-failed":return {config:r,state:nr(s,r,t.taskName,t.error)};case "task-progress":return {config:r,state:or(s,t.taskName,t.message,t.progress)};case "task-restart":return {config:r,state:sr(s,t.taskName)};case "inject-tokens":return {config:r,state:{...s,availableOutputs:[...new Set([...s.availableOutputs,...t.tokens])],lastUpdated:new Date().toISOString()}};case "agent-action":return {config:r,state:dn(s,t.action)};case "task-upsert":return tn(e,t.taskName,t.taskConfig);case "task-removal":return rn(e,t.taskName);case "node-requires-add":return nn(e,t.nodeName,t.tokens);case "node-requires-remove":return on(e,t.nodeName,t.tokens);case "node-provides-add":return sn(e,t.nodeName,t.tokens);case "node-provides-remove":return an(e,t.nodeName,t.tokens);default:return e}}function ar(e,t){return t.reduce((r,s)=>en(r,s),e)}function tn(e,t,r){let s=!!e.config.tasks[t];return {config:{...e.config,tasks:{...e.config.tasks,[t]:r}},state:{...e.state,tasks:{...e.state.tasks,[t]:s?e.state.tasks[t]:ir()},lastUpdated:new Date().toISOString()}}}function rn(e,t){if(!e.config.tasks[t])return e;let{[t]:r,...s}=e.config.tasks,{[t]:a,...i}=e.state.tasks;return {config:{...e.config,tasks:s},state:{...e.state,tasks:i,lastUpdated:new Date().toISOString()}}}function nn(e,t,r){let s=e.config.tasks[t];if(!s)return e;let a=et(s),i=r.filter(c=>!a.includes(c));return i.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...s,requires:[...a,...i]}}},state:e.state}}function on(e,t,r){let s=e.config.tasks[t];if(!s)return e;let a=et(s),i=a.filter(c=>!r.includes(c));return i.length===a.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...s,requires:i}}},state:e.state}}function sn(e,t,r){let s=e.config.tasks[t];if(!s)return e;let a=Pe(s),i=r.filter(c=>!a.includes(c));return i.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...s,provides:[...a,...i]}}},state:e.state}}function an(e,t,r){let s=e.config.tasks[t];if(!s)return e;let a=Pe(s),i=a.filter(c=>!r.includes(c));return i.length===a.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...s,provides:i}}},state:e.state}}function Ct(e){return {version:1,config:e.config,state:e.state,snapshotAt:new Date().toISOString()}}function It(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,s=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(!s.tasks||typeof s.tasks!="object")throw new Error("Invalid snapshot: state.tasks missing");if(!Array.isArray(s.availableOutputs))throw new Error("Invalid snapshot: state.availableOutputs must be an array");return {config:r,state:s}}function ir(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function dn(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 kt(e){let{config:t,state:r}=e,s=Yt(t);if(Object.keys(s).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let i=cn(s),c=Qt(t,r.tasks),u=new Set([...c,...r.availableOutputs]),m=[],h=[],b=[],v=[];for(let[J,A]of Object.entries(s)){let B=r.tasks[J],E=Xt(A,t.settings),V=E!=="once";if(B?.status===Qe.RUNNING||Ut(B))continue;let Y=Zt(A);if(Y!==void 0&&B&&B.executionCount>=Y||A.circuit_breaker&&B&&B.executionCount>=A.circuit_breaker.max_executions||!V&&B?.status===Qe.COMPLETED)continue;if(V&&B?.status===Qe.COMPLETED){let l=et(A),f=false;switch(E){case "data-changed":{l.length>0&&l.some(T=>{for(let[w,_]of Object.entries(s))if(Pe(_).includes(T)){let F=r.tasks[w];if(!F)continue;let oe=B.lastConsumedHashes?.[T];return F.lastDataHash==null?F.executionCount>B.lastEpoch:F.lastDataHash!==oe}return false})||(f=true);break}case "epoch-changed":{l.length>0&&l.some(T=>{for(let[w,_]of Object.entries(s))if(Pe(_).includes(T)){let F=r.tasks[w];if(F&&F.executionCount>B.lastEpoch)return true}return false})||(f=true);break}case "time-based":{let R=A.refreshInterval??0;if(R<=0){f=true;break}let T=B.completedAt;if(!T){f=true;break}(Date.now()-Date.parse(T))/1e3<R&&(f=true);break}case "manual":f=true;break}if(f)continue}let x=et(A);if(x.length===0){m.push(J);continue}let L=[],k=[],y=[];for(let l of x){if(u.has(l))continue;let f=i[l]||[];f.length===0?L.push(l):f.every(T=>Ut(r.tasks[T]))?y.push({token:l,failedProducer:f[0]}):k.push(l);}L.length>0?b.push({taskName:J,missingTokens:L}):y.length>0?v.push({taskName:J,failedTokens:y.map(l=>l.token),failedProducers:[...new Set(y.map(l=>l.failedProducer))]}):k.length>0?h.push({taskName:J,waitingOn:k}):m.push(J);}let M={};if(m.length>1){let J=er(m,s);for(let[A,B]of Object.entries(J))B.length>1&&(M[A]=B);}return {eligible:m,pending:h,unresolved:b,blocked:v,conflicts:M}}function cn(e){let t={};for(let[r,s]of Object.entries(e)){for(let a of Pe(s))t[a]||(t[a]=[]),t[a].push(r);if(s.on)for(let a of Object.values(s.on))for(let i of a)t[i]||(t[i]=[]),t[i].includes(r)||t[i].push(r);if(s.on_failure)for(let a of s.on_failure)t[a]||(t[a]=[]),t[a].includes(r)||t[a].push(r);}return t}var Rt=class{buffer=[];append(t){this.buffer.push(t);}drain(){let t=this.buffer;return this.buffer=[],t}get size(){return this.buffer.length}};function Gt(e){let t=Vt(e);return un(t)}function Vt(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return "["+e.map(Vt).join(",")+"]";let t=e;return "{"+Object.keys(t).sort().map(s=>JSON.stringify(s)+":"+Vt(t[s])).join(",")+"}"}function un(e){let t=0xcbf29ce484222325n,r=0x100000001b3n,s=0xffffffffffffffffn;for(let a=0;a<e.length;a++)t^=BigInt(e.charCodeAt(a)),t=t*r&s;return t.toString(16).padStart(16,"0")}function ln(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 s of t)r+=String.fromCharCode(s);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}throw new Error("No base64 encoder available in this runtime")}function fn(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),s=atob(r),a=new Uint8Array(s.length);for(let i=0;i<s.length;i++)a[i]=s.charCodeAt(i);return new TextDecoder().decode(a)}throw new Error("No base64 decoder available in this runtime")}function dr(e){let t=JSON.stringify({t:e,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return ln(t)}function pn(e){try{let t=JSON.parse(fn(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function cr(e,t,r){let{handlers:s,onNodeRemoved:a,onDrain:i}=t,c=new Rt,u="state"in e&&"config"in e?e:At(e),m=false,h=new Set,b=new Map(Object.entries(s)),v=new Rt,M=false,J=false;function A(){if(!m){if(M){J=true;return}M=true;try{do J=!1,B();while(J)}finally{M=false;}}}function B(){let x=v.drain(),L=c.drain(),k=[...x,...L];if(k.length>0&&(u=ar(u,k),a)){for(let l of k)if(l.type==="task-removal")try{a(l.taskName);}catch(f){console.warn("[reactive] onNodeRemoved failed:",f instanceof Error?f.message:String(f));}}let y=kt(u);k.length>0&&i?.(k,u,y);for(let l of y.eligible)Y(l);for(let l of k)if(l.type==="task-progress"){let{taskName:f,update:R}=l;if(!u.config.tasks[f])continue;let w=u.state.tasks[f];if(!w||w.status!=="running")continue;let _=dr(f),F=V(f,_,R).catch(oe=>{m||(v.append({type:"task-failed",taskName:f,error:oe.message??String(oe),timestamp:new Date().toISOString()}),A());}).finally(()=>{h.delete(F);});h.add(F);}}function E(x){let k=u.config.tasks[x].requires??[],y=new Map;for(let[f,R]of Object.entries(u.config.tasks))for(let T of R.provides??[])y.set(T,f);let l={};for(let f of k){let R=y.get(f);R?l[f]=u.state.tasks[R]?.data:l[f]=void 0;}return l}async function V(x,L,k){let y=u.config.tasks[x],l=y.taskHandlers??[],f=E(x);for(let R of l){let T=b.get(R);if(!T)throw new Error(`Handler '${R}' not found in registry (task '${x}')`);let w={nodeId:x,state:f,taskState:u.state.tasks[x],config:y,callbackToken:L,update:k};if(await T(w)==="task-initiate-failure")throw new Error(`Handler '${R}' returned task-initiate-failure (task '${x}')`)}}function Y(x){let k=u.config.tasks[x]?.taskHandlers;if(!k||k.length===0)return;v.append({type:"task-started",taskName:x,timestamp:new Date().toISOString()}),A();let y=dr(x),l=V(x,y).catch(f=>{m||(v.append({type:"task-failed",taskName:x,error:f.message??String(f),timestamp:new Date().toISOString()}),A());}).finally(()=>{h.delete(l);});h.add(l);}return {push(x){m||(x.type==="task-completed"&&x.data&&!x.dataHash&&(x={...x,dataHash:Gt(x.data)}),c.append(x),A());},pushAll(x){if(!m){for(let L of x)L.type==="task-completed"&&L.data&&!L.dataHash?c.append({...L,dataHash:Gt(L.data)}):c.append(L);A();}},resolveCallback(x,L,k){if(m)return;let y=pn(x);if(!y)return;let{taskName:l}=y;if(u.config.tasks[l]){if(k&&k.length>0)c.append({type:"task-failed",taskName:l,error:k.join("; "),timestamp:new Date().toISOString()});else {let f=L&&Object.keys(L).length>0?Gt(L):void 0;c.append({type:"task-completed",taskName:l,data:L,dataHash:f,timestamp:new Date().toISOString()});}A();}},addNode(x,L){m||(c.append({type:"task-upsert",taskName:x,taskConfig:L,timestamp:new Date().toISOString()}),A());},removeNode(x){m||(c.append({type:"task-removal",taskName:x,timestamp:new Date().toISOString()}),A());},addRequires(x,L){m||(c.append({type:"node-requires-add",nodeName:x,tokens:L,timestamp:new Date().toISOString()}),A());},removeRequires(x,L){m||(c.append({type:"node-requires-remove",nodeName:x,tokens:L,timestamp:new Date().toISOString()}),A());},addProvides(x,L){m||(c.append({type:"node-provides-add",nodeName:x,tokens:L,timestamp:new Date().toISOString()}),A());},removeProvides(x,L){m||(c.append({type:"node-provides-remove",nodeName:x,tokens:L,timestamp:new Date().toISOString()}),A());},registerHandler(x,L){b.set(x,L);},unregisterHandler(x){b.delete(x);},retrigger(x){m||u.config.tasks[x]&&(c.append({type:"task-restart",taskName:x,timestamp:new Date().toISOString()}),A());},retriggerAll(x){if(!m){for(let L of x)u.config.tasks[L]&&c.append({type:"task-restart",taskName:L,timestamp:new Date().toISOString()});A();}},snapshot(){return Ct(u)},getState(){return u},getSchedule(){return kt(u)},async waitForHandlers(){h.size>0&&await Promise.allSettled([...h]);},async dispose(x){x?.wait&&h.size>0&&await Promise.allSettled([...h]),m=true;}}}var mn=createRequire(import.meta.url);mn("./jsonata-sync.cjs");var yn=createRequire(import.meta.url),_t=yn("./jsonata-sync.cjs"),fr=_t;function ur(e,t){if(!t||!e)return;let r=t.split("."),s=e;for(let a=0;a<r.length;a++){if(s==null)return;s=s[r[a]];}return s}function pr(e,t,r){let s=t.split("."),a=e;for(let i=0;i<s.length-1;i++)(a[s[i]]==null||typeof a[s[i]]!="object")&&(a[s[i]]={}),a=a[s[i]];a[s[s.length-1]]=r;}async function Cn(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??{},s={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 a of e.compute)try{let i=await _t(a.expr).evaluate(s);pr(e.computed_values,a.bindTo,i),s.computed_values=e.computed_values;}catch{}return e}function kn(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??{},s={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values},a=[];for(let i of e.compute)try{let c=fr(i.expr).evaluate(s);pr(e.computed_values,i.bindTo,c),s.computed_values=e.computed_values;}catch(c){let u=c instanceof Error?c.message:String(c);a.push({bindTo:i.bindTo,error:u});}return a.length>0?{ok:true,node:e,errors:a}:{ok:true,node:e}}async function Rn(e,t,r){let s={...r??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return _t(e).evaluate(s)}function bn(e,t){return t.startsWith("fetched_sources.")?ur(e._sourcesData??{},t.slice(16)):ur(e,t)}var lr=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),Sn=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function wn(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 s of Object.keys(r))Sn.has(s)||t.push(`Unknown top-level key: "${s}"`);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 s=r.meta;s.title!=null&&typeof s.title!="string"&&t.push("meta.title: must be a string"),s.tags!=null&&!Array.isArray(s.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((s,a)=>{if(!s||typeof s!="object"||Array.isArray(s))t.push(`provides[${a}]: must be an object with bindTo and ref`);else {let i=s;(typeof i.bindTo!="string"||!i.bindTo)&&t.push(`provides[${a}]: missing required "bindTo" string`),(typeof i.ref!="string"||!i.ref)&&t.push(`provides[${a}]: 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((s,a)=>{if(!s||typeof s!="object"||Array.isArray(s))t.push(`compute[${a}]: must be a compute step object`);else {let i=s;(typeof i.bindTo!="string"||!i.bindTo)&&t.push(`compute[${a}]: missing required "bindTo" property`),(typeof i.expr!="string"||!i.expr)&&t.push(`compute[${a}]: 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 s=new Set,a=new Set;r.source_defs.forEach((i,c)=>{if(!i||typeof i!="object"||Array.isArray(i))t.push(`source_defs[${c}]: must be an object`);else {let u=i;typeof u.bindTo!="string"||!u.bindTo?t.push(`source_defs[${c}]: missing required "bindTo" property`):(s.has(u.bindTo)&&t.push(`source_defs[${c}]: bindTo "${u.bindTo}" is not unique across source_defs`),s.add(u.bindTo)),typeof u.outputFile!="string"||!u.outputFile?t.push(`source_defs[${c}]: missing required "outputFile" property`):(a.has(u.outputFile)&&t.push(`source_defs[${c}]: outputFile "${u.outputFile}" is not unique across source_defs`),a.add(u.outputFile)),u.optionalForCompletionGating!=null&&typeof u.optionalForCompletionGating!="boolean"&&t.push(`source_defs[${c}]: 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 s=r.view;!Array.isArray(s.elements)||s.elements.length===0?t.push("view.elements: required, must be a non-empty array"):s.elements.forEach((a,i)=>{if(!a||typeof a!="object"){t.push(`view.elements[${i}]: must be an object`);return}!a.kind||typeof a.kind!="string"?t.push(`view.elements[${i}].kind: required, must be a string`):lr.has(a.kind)||t.push(`view.elements[${i}].kind: unknown kind "${a.kind}". Valid: ${[...lr].join(", ")}`),a.data!=null&&(typeof a.data!="object"||Array.isArray(a.data))&&t.push(`view.elements[${i}].data: must be an object`);}),s.layout!=null&&(typeof s.layout!="object"||Array.isArray(s.layout))&&t.push("view.layout: must be an object"),s.features!=null&&(typeof s.features!="object"||Array.isArray(s.features))&&t.push("view.features: must be an object");}return {ok:t.length===0,errors:t}}async function vn(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return Promise.all(e.map(async s=>{let a={};if(s.projections&&typeof s.projections=="object"&&!Array.isArray(s.projections)){for(let[i,c]of Object.entries(s.projections))if(typeof c=="string"&&c.trim().length>0)try{a[i]=await _t(c).evaluate(r);}catch{a[i]=void 0;}}return {...s,_projections:a}}))}function xn(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return e.map(s=>{let a={};if(s.projections&&typeof s.projections=="object"&&!Array.isArray(s.projections)){for(let[i,c]of Object.entries(s.projections))if(typeof c=="string"&&c.trim().length>0)try{a[i]=fr(c).evaluate(r);}catch{a[i]=void 0;}}return {...s,_projections:a}})}var tt={run:Cn,runSync:kn,eval:Rn,resolve:bn,validate:wn,enrichSources:vn,enrichSourcesSync:xn};function gr(e){return JSON.stringify(e)}function mr(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 bt(e,t){function r(){return e.readIndex()??{}}function s(a,i,c){let u=String(i||"").split(".").filter(Boolean);if(u.length===0)return c&&typeof c=="object"&&!Array.isArray(c)?c:{value:c};let m={...a},h=m;for(let b=0;b<u.length-1;b++){let v=u[b],M=h[v],J=M&&typeof M=="object"&&!Array.isArray(M)?{...M}:{};h[v]=J,h=J;}return h[u[u.length-1]]=c,m}return {readCard(a){let i=r()[a];return !i||!e.cardExists(i.key)?null:e.readCard(i.key)},readCardKey(a){return r()[a]?.key??null},readAllCards(){let a=[];for(let[i,c]of Object.entries(r())){if(!e.cardExists(c.key))continue;let u=e.readCard(c.key);u?a.push(u):t?.(`[card-store] could not read card "${i}" at key "${c.key}"`);}return a},readChecksumIndex(){let a={};for(let[i,c]of Object.entries(r()))a[i]=c.checksum;return a},changedSince(a){let i=r(),c=[];for(let[u,m]of Object.entries(i))a[u]!==m.checksum&&c.push(u);for(let u of Object.keys(a))i[u]||c.push(u);return c},validateUpsert(a,i){let c=r(),u=c[a],m=Object.entries(c).find(([,h])=>h.key===i);return u&&u.key!==i?{ok:false,error:`Card id "${a}" is already mapped to key "${u.key}", cannot remap to "${i}"`}:m&&m[0]!==a?{ok:false,error:`Key "${i}" is already mapped to card id "${m[0]}", cannot remap to "${a}"`}:{ok:true}},writeCard(a,i,c){let u=r(),m=c??u[a]?.key??e.defaultCardKey(a),h=e.writeCard(m,i);u[a]={key:m,checksum:h,updatedAt:new Date().toISOString()},e.writeIndex(u);},patchCard(a,i,c){let u=r(),m=u[a];if(!m||!e.cardExists(m.key))throw new Error(`card "${a}" not found`);let h=e.readCard(m.key);if(!h||typeof h!="object"||Array.isArray(h))throw new Error(`card "${a}" is not patchable`);let b=s(h,i,c),v=e.writeCard(m.key,b);u[a]={key:m.key,checksum:v,updatedAt:new Date().toISOString()},e.writeIndex(u);},removeCard(a){let i=r(),c=i[a];c&&(e.removeCard(c.key),delete i[a],e.writeIndex(i));},readIndex(){return r()}}}function Et(e,t){return {readSourceData(r,s){let a=e.read(`${r}/${s}`);if(a==null)return null;let i=a.trim();if(!i)return null;try{return JSON.parse(i)}catch{return i}},ingestSourceDataStaged(r,s,a,i){let c=t(a);e.write(`${r}/.staged/${i}/${s}`,c);},commitSourceData(r,s,a){let i=`${r}/.staged/${a}/${s}`,c=e.read(i);return c==null?false:(e.write(`${r}/${s}`,c),e.remove(i),true)},hasSource(r,s){return e.exists(`${r}/${s}`)},listSources(r){return e.listKeys(`${r}/`).filter(s=>!s.includes("/.staged/")).map(s=>s.slice(`${r}/`.length))}}}function Rr(e){function t(r){let s=e.readAllEntries();if(!r)return s;let a=s.findIndex(i=>i.id===r);return a===-1?s:s.slice(a+1)}return {readEntriesAfterCursor(r){let s=t(r);return s.length===0?{events:[],newCursor:r}:{events:s.map(a=>a.event),newCursor:s[s.length-1].id}},pendingCount(r){return t(r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function br(e,t){return {appendEntries(r,s){if(!r||s.length===0)return;let a=e.read(r)??[];e.write(r,[...a,...s]);},dispatchEntriesForJournalId(r,s){if(!r)return;let a=e.read(r);if(!(!a||a.length===0)){for(let i of a)try{s(i);}catch(c){let u=c instanceof Error?c.message:String(c);try{t(i,u);}catch{}}e.delete(r);}}}}var Tt="v1",ot="board/graph",Sr="board/lastJournalProcessedId";function hr(e){return `cards/${e}/runtime`}function wr(e){return {readRuntime(t){return e.read(hr(t))??{_sources:{}}},writeRuntime(t,r){e.write(hr(t),r);}}}function An(e,t){let r={...e};for(let s of t.deleteKeys)delete r[s];return {...r,...t.shallowMerge}}function vr(e){return {readSnapshot(t){return e.readValues(t)},commitSnapshot(t,r){if(r.schemaVersion!==Tt)throw new Error(`Unsupported snapshot schema version: ${r.schemaVersion}`);let s=e.readValues(t);if(s.version!==r.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:s.version};let a=An(s.values,r);return {ok:true,newVersion:e.writeValues(t,a,r.deleteKeys)}}}}function Kt(e){function t(r){let s=e.read(r);return s==null?null:typeof s=="string"?s:JSON.stringify(s)}return {readTaskExecutorRef(){let r=t("task-executor");if(r?.trim())return mr(r.trim())},writeTaskExecutorRef(r){e.write("task-executor",gr(r));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(r){e.write("chat-handler-flow",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);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(r){e.write("scratch-store-ref",r);},readArchiveStoreRef(){return t("archive-store-ref")},writeArchiveStoreRef(r){e.write("archive-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);}}}function xr(e){return {writeComputedValues(t,r){e.write(`cards/${t}/computed_values`,r);},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){let t={};for(let r of e.listKeys("cards/")){let s=r.match(/^cards\/([^/]+)\/computed_values$/);s&&(t[s[1]]=e.read(r));}return t},writeDataObjects(t){for(let[r,s]of Object.entries(t))r&&e.write(`data-objects/${r}`,s);},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){let t={};for(let r of e.listKeys("data-objects/"))t[r.slice(13)]=e.read(r);return t},writeStatusSnapshot(t){e.write("status",t);},readStatusSnapshot(){return e.read("status")}}}function yr(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function In(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function Cr(e,t){return e?.lastRequestedToken?In(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function _n(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function kr(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function Ot(e,t){let r=t.state.tasks,s=t.config.tasks,a=Object.keys(r),i=kt(t),c={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},u=new Map;for(let A of i.pending)u.set(A.taskName,A.waitingOn);for(let A of i.unresolved)u.set(A.taskName,A.missingTokens);for(let A of i.blocked)u.set(A.taskName,A.failedTokens);let m=new Map;for(let[A,B]of Object.entries(s))for(let E of B.requires??[]){let V=m.get(E)??[];V.push(A),m.set(E,V);}let h=a.sort().map(A=>{let B=r[A],E=s[A]??{requires:[],provides:[]};B.status==="completed"?c.completed+=1:B.status==="failed"?c.failed+=1:B.status==="in-progress"&&(c.in_progress+=1);let V=E.requires??[],Y=E.provides??[],x=Object.keys(B.data??{}).sort(),L=V.filter(T=>t.state.availableOutputs.includes(T)),k=V.filter(T=>!t.state.availableOutputs.includes(T)),y=u.get(A)??k,l=new Set;for(let T of Y)for(let w of m.get(T)??[])w!==A&&l.add(w);let f=B.failedAt,R=B.error?{message:B.error,code:"TASK_FAILED",at:f,source:"task-runtime"}:void 0;return {name:A,status:B.status,error:R,requires:V,requires_satisfied:L,requires_missing:k,provides_declared:Y,provides_runtime:x,blocked_by:y,unblocks:Array.from(l).sort(),runtime:{attempt_count:B.executionCount??0,restart_count:B.retryCount??0,in_progress_since:B.status==="in-progress"?B.startedAt??null:null,last_transition_at:B.lastUpdated??null,last_completed_at:B.completedAt??null,last_restarted_at:B.startedAt??null,status_age_ms:B.lastUpdated?0:null}}});c.pending=i.pending.length,c.blocked=i.blocked.length,c.unresolved=i.unresolved.length;let b=h.map(A=>({name:A.name,fanOut:A.unblocks.length})).sort((A,B)=>B.fanOut-A.fanOut||A.name.localeCompare(B.name)),v=b.length>0?b[0]:{name:null,fanOut:0},M=new Set;for(let A of Object.values(s))for(let B of A.requires??[])M.add(B);let J=0;for(let[A,B]of Object.entries(s)){let E=(B.requires??[]).length===0,Y=(B.provides??[]).some(x=>(m.get(x)??[]).some(L=>L!==A));E&&!Y&&(J+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:a.length,completed:c.completed,eligible:i.eligible.length,pending:c.pending,blocked:c.blocked,unresolved:c.unresolved,failed:c.failed,in_progress:c.in_progress,orphan_cards:J,topology:{edge_count:Array.from(M).length,max_fan_out_card:v.name,max_fan_out:v.fanOut}},cards:h}}function En(){return new Date().toISOString()}function Ar(e,t,r,s,a,i,c){return async u=>{let m=[],h=r.cardStore.readCard(u.nodeId);if(!h)return "task-initiate-failure";let b=h.id,v=h.card_data??{},M=h.source_defs??[],J=M.filter(N=>N.optionalForCompletionGating!==true),A=r.cardRuntimeStore.readRuntime(b),B=false,E=()=>{B&&(r.cardRuntimeStore.writeRuntime(b,A),B=false);},V=N=>yr(A._sources[N]),Y=(N,$)=>{A._sources[N]=yr($),B=true;},x=u.taskState?.executionCount??0;if(A._lastExecutionCount!==x&&(A._sources={},A._lastExecutionCount=x,B=true),u.update){let N=u.update,$=N.outputFile;if($){let D=V($);if(N.failure){let se=N.rqt??D.lastRequestedToken??D.queueRequestedToken;se&&Y($,kr(D,se));}else {let se=N.rqt;if(!D.lastCompletedToken||se>D.lastCompletedToken){let te=typeof N.deliveryToken=="string"?N.deliveryToken:void 0,Z=false;te&&(Z=r.fetchedSourcesStore.commitSourceData(b,$,te)),Z?Y($,_n(D,se)):Y($,kr(D,se));}}E();}}let k={};for(let N of M)if(N.outputFile){let $=r.fetchedSourcesStore.readSourceData(b,N.outputFile);$!==null&&(k[N.bindTo]=$);}let y={};for(let[N,$]of Object.entries(u.state??{}))if($!==null&&typeof $=="object"&&!Array.isArray($)){let D=$[N];y[N]=D!==void 0?D:$;}else y[N]=$;let l={id:b,card_data:{...v},requires:y,source_defs:M,compute:h.compute};l._sourcesData=k,h.compute&&tt.runSync(l,{sourcesData:k}),(i??r.outputStore.writeComputedValues.bind(r.outputStore))(b,l.computed_values??{});let f={...h},R=tt.enrichSourcesSync(Array.isArray(h.source_defs)?h.source_defs:void 0,{card_data:h.card_data,requires:y}),T=e.value;f.source_defs=Array.isArray(R)?R.map(N=>({...N,boardDir:typeof N.boardDir=="string"&&N.boardDir?N.boardDir:T})):R;let w=En(),_=u.update?void 0:w,F=J.filter(N=>{let $=N.outputFile;if(typeof $!="string"||!$)return true;let D=V($);_&&(D={...D,queueRequestedToken:_},Y($,D));let se=D.queueRequestedToken??D.lastRequestedToken??w,te=Cr(D,se);return te==="in-flight"?false:te==="dispatch"});if(E(),F.length>0){let N=false,$=w;for(let D of F){let se=D.outputFile;if(typeof se!="string"||!se)continue;let te=V(se),Z=te.queueRequestedToken??w;Y(se,{...te,lastRequestedToken:Z}),$=Z,N=true;}return N&&E(),N&&(m.push({taskKind:"source-fetch",payload:{boardRef:Ne(e),enrichedCard:f,callbackToken:u.callbackToken,rqt:$}}),r.executionRequestStore.appendEntries(t,m)),"task-initiated"}if(J.some(N=>{let $=N.outputFile;if(typeof $!="string"||!$)return false;let D=V($),se=D.queueRequestedToken??D.lastRequestedToken??w;return Cr(D,se)==="in-flight"}))return "task-initiated";let X=h.provides??[],ce={};for(let{bindTo:N,ref:$}of X)ce[N]=tt.resolve(l,$);return (c??r.outputStore.writeDataObjects.bind(r.outputStore))(ce),M.filter(N=>{if(N.optionalForCompletionGating!==true)return false;let $=V(N.outputFile);return !$.lastRequestedToken||!$.lastCompletedToken?true:$.lastCompletedToken<=$.lastRequestedToken}).length>0&&m.push({taskKind:"source-fetch",payload:{boardRef:Ne(e),enrichedCard:f,callbackToken:u.callbackToken,rqt:w}}),s(u.nodeId,ce),m.length>0&&r.executionRequestStore.appendEntries(t,m),"task-initiated"}}var Ht={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function Ir(e){return {[ot]:e.graph,[Sr]:e.lastDrainedJournalId}}function _r(e){let t=e[ot],r=e[Sr];if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${ot}`);return {graph:t,lastDrainedJournalId:typeof r=="string"?r:""}}function Er(e){let t=e.requires,r=e.provides?.map(s=>s.bindTo)??[];return {requires:t&&t.length>0?t:void 0,provides:r,taskHandlers:["card-handler"],description:e.meta?.title??e.id}}function jt(e){function t(i){return {status:"success",data:i}}function r(i){return {status:"fail",error:i}}function s(i){return {status:"error",error:i instanceof Error?i.message:String(i)}}function a(i){if(Array.isArray(i))return i;if(i&&typeof i=="object"){let c=i;return Array.isArray(c.files)?c.files:[i]}return null}return {get(i){try{let c=i.params?.id;if(c){let u=e.readCard(c);return u?t({cards:[u]}):r(`card "${c}" not found`)}return t({cards:e.readAllCards()})}catch(c){return s(c)}},set(i){try{let c=i.body;if(c==null)return r("set requires a body (card object or array of cards)");let u=Array.isArray(c)?c:[c];for(let m of u){if(typeof m.id!="string")return r("each card must have a string `id` field");e.writeCard(m.id,m);}return t({count:u.length})}catch(c){return s(c)}},del(i){try{let c=i.body?.ids??[],u=i.params?.id,m=u?[...c,u]:c;if(m.length===0)return r("del requires body.ids (string[]) or params.id");for(let h of m)e.removeCard(h);return t({count:m.length})}catch(c){return s(c)}},patch(i){try{let c=i.params?.id,u=i.params?.path;if(!c)return r("patch requires params.id");if(!u)return r("patch requires params.path");let m=i.body,h=m&&Object.prototype.hasOwnProperty.call(m,"value")?m.value:i.body;return e.patchCard(c,u,h),t({count:1})}catch(c){return s(c)}},appendFiles(i){try{let c=i.params?.id;if(!c)return r("appendFiles requires params.id");let u=e.readCard(c);if(!u)return r(`card "${c}" not found`);let m=a(i.body);if(!m||m.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let h=u.card_data&&typeof u.card_data=="object"&&!Array.isArray(u.card_data)?u.card_data:{},b=Array.isArray(h.files)?h.files:[],v=[...b,...m],M=m.map((A,B)=>({idx:b.length+B,entry:A})),J=this.patch({params:{id:c,path:"card_data.files"},body:{value:v}});return J.status!=="success"?J:t({files_added:M})}catch(c){return s(c)}}}}function re(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function H(e){return {status:"fail",error:e}}function ne(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function Tn(e){let t=new TextEncoder().encode(e),r=Array.from(t,s=>String.fromCharCode(s)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Or(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),s=atob(r),a=Uint8Array.from(s,i=>i.charCodeAt(0));return new TextDecoder().decode(a)}function Bt(e){try{let t=JSON.parse(Or(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function On(e){return Tn(JSON.stringify(e))}function Tr(e){try{let t=JSON.parse(Or(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function _e(){return new Date().toISOString()}function jr(e,t){let r=t.onWarn??(()=>{}),s=Ne(e);function a(I){if(I.length!==0)try{let g=t.publishBoardChangeNotifications?.(I);g&&typeof g.catch=="function"&&g.catch(j=>r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${j instanceof Error?j.message:String(j)}`));}catch(g){r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${g instanceof Error?g.message:String(g)}`);}}function i(){let I=u().readCardStoreRef();if(!I)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let g=t.kvStorageForRef(I);return {readIndex(){return g.read("_index")},writeIndex(j){g.write("_index",j);},readCard(j){return g.read(j)},writeCard(j,U){return g.write(j,U),t.hashFn(U)},removeCard(j){g.delete(j);},cardExists(j){return g.read(j)!==null},defaultCardKey(j){return j}}}let c={readValues(I){let g=t.kvStorage("state-snapshot"),j=g.listKeys().sort();if(j.length===0)return {version:null,values:{}};let U={};for(let Q of j)U[Q]=g.read(Q);return {version:t.hashFn(U),values:U}},writeValues(I,g,j){let U=t.kvStorage("state-snapshot");for(let Q of j)U.delete(Q);for(let[Q,ie]of Object.entries(g))U.write(Q,ie);return t.hashFn(g)}},u=()=>Kt(t.kvStorage("config")),m=()=>vr(c),h=()=>Rr(t.journalAdapter()),b=()=>bt(i(),r),v=()=>{let I=u().readOutputsStoreRef();if(!I)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return xr(t.kvStorageForRef(I))},M=()=>{let I=u().readArchiveStoreRef();return I?t.archiveFactoryForRef(I):t.archiveFactory()};function J(){return !!m().readSnapshot(e.value).values[ot]}function A(){let I=m().readSnapshot(e.value);if(!I.values[ot])throw new Error(`Board not initialized at ${e.value}`);return _r(I.values)}function B(I,g){let j=m().commitSnapshot(e.value,{schemaVersion:Tt,expectedVersion:g,commitId:t.genId(),committedAt:_e(),deleteKeys:[],shallowMerge:Ir(I)});if(!j.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${g??"null"} current=${j.currentVersion??"null"}`)}function E(I){h().appendEvent(I);}async function V(){let I=(P,z)=>{let fe=P.payload,je=(fe?.enrichedCard??{}).id??fe?.cardId??"unknown";E({type:"task-failed",taskName:je,error:z,timestamp:_e()});},g=br(t.kvStorage("execution-requests"),I),j=wr(t.kvStorage("card-runtime")),U=Et(t.blobStorage("sources"),P=>t.resolveBlob(P)),Q=new Map,ie={readRuntime(P){return Q.get(P)??j.readRuntime(P)},writeRuntime(P,z){Q.set(P,z);}},Ie=[],he=new Map,Te={readSourceData(P,z){let fe=`${P}/${z}`;return he.has(fe)?he.get(fe):U.readSourceData(P,z)},ingestSourceDataStaged(P,z,fe,Fe){U.ingestSourceDataStaged(P,z,fe,Fe);},commitSourceData(P,z,fe){let Fe=`${P}/.staged/${fe}/${z}`,Ye=t.blobStorage("sources").read(Fe);if(Ye==null)return false;let Xe=`${P}/${z}`,pt=Ye.trim();try{he.set(Xe,JSON.parse(pt));}catch{he.set(Xe,pt);}return Ie.push({cardId:P,outputFile:z,deliveryToken:fe}),true},hasSource(P,z){let fe=`${P}/${z}`;return he.has(fe)?true:U.hasSource(P,z)},listSources(P){let z=U.listSources(P),fe=new Set;for(let je of he.keys())je.startsWith(`${P}/`)&&fe.add(je.slice(`${P}/`.length));let Fe=new Set([...z,...fe]);return Array.from(Fe)}},Ae={cardStore:b(),cardRuntimeStore:ie,fetchedSourcesStore:Te,outputStore:v(),executionRequestStore:g},Ue=A(),Ge=It(Ue.graph),{events:We,newCursor:qe}=h().readEntriesAfterCursor(Ue.lastDrainedJournalId),Ve=[],lt=[],rt=[],st=new Map,St=new Set,Pt=(P,z)=>{Ve.push({type:"task-completed",taskName:P,data:z,timestamp:_e()});try{M().stream("exec-history").append({taskName:P,status:"completed",completedAt:_e()});}catch{}},ee=(P,z)=>{E({type:"task-failed",taskName:P,error:z,timestamp:_e()});try{M().stream("exec-history").append({taskName:P,status:"failed",error:z,completedAt:_e()});}catch{}},at=cr(Ge,{handlers:{"card-handler":Ar(e,qe,Ae,Pt,ee,(P,z)=>{lt.push({cardId:P,values:z});},P=>{rt.push(P);})},onNodeRemoved:P=>{st.delete(P),Q.delete(P),St.add(P);}});for(Ve=We;Ve.length>0;){let P=Ve;Ve=[];for(let z of P)if(z.type==="task-restart"){let fe=Ae.cardStore.readCard(z.taskName);fe&&st.set(z.taskName,fe);}at.pushAll(P),await at.waitForHandlers();}let ft=at.getState();await at.dispose({wait:true});let $e=m().readSnapshot(e.value).version;B({lastDrainedJournalId:qe,graph:Ct(ft)},$e);for(let{cardId:P,values:z}of lt)Ae.outputStore.writeComputedValues(P,z);for(let P of rt)Ae.outputStore.writeDataObjects(P);for(let[P,z]of Q)j.writeRuntime(P,z);for(let{cardId:P,outputFile:z,deliveryToken:fe}of Ie)U.commitSourceData(P,z,fe);let it;try{it=Ot(s,ft),Ae.outputStore.writeStatusSnapshot(it);}catch(P){r(`[board-live-cards-public] status publish failed: ${P instanceof Error?P.message:String(P)}`);}let Ke=[];for(let{cardId:P,values:z}of lt)Ke.push({kind:"computed_values",cardId:P,values:z});for(let P of rt)for(let[z,fe]of Object.entries(P))z&&Ke.push({kind:"data_object",key:z,payload:fe});for(let[P,z]of st)Ke.push({kind:"card_refreshed",cardId:P,card:z});for(let P of St)Ke.push({kind:"card_removed",cardId:P});it!==void 0&&Ke.push({kind:"status",status:it}),a(Ke);let wt=u().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:Ne({kind:"built-in",value:"source-cli-task-executor"})};g.dispatchEntriesForJournalId(qe,P=>{if(P.taskKind!=="source-fetch"){r(`[process-accumulated-events] unknown taskKind "${P.taskKind}" \u2014 skipping`);return}let z=P.payload,fe=z.enrichedCard?.id??"unknown",Fe=z.enrichedCard?.source_defs??[];for(let je of Fe){if(!je.outputFile){r(`[dispatch] source "${je.bindTo}" has no outputFile \u2014 skipping`);continue}let Ye=On({cbk:z.callbackToken,rg:e.value,br:Ne(e),cid:fe,b:je.bindTo,d:je.outputFile,cs:void 0,rqt:z.rqt});t.dispatchExecution(wt,{source_def:je,base_ref:Ne(e),callback:{token:Ye,via:t.selfRef}}).catch(Xe=>ee(fe,Xe instanceof Error?Xe.message:String(Xe)));}});}async function Y(){try{let I=()=>{let j=A(),{events:U}=h().readEntriesAfterCursor(j.lastDrainedJournalId);U.length<=0||(Y(),t.requestProcessAccumulated?.());},g=await Wt(t.lock,V,I);return re({ran:g!==!1})}catch(I){return ne(I)}}function x(){Y(),t.requestProcessAccumulated?.();}function L(I){try{let g=I.params?.cardStoreRef;if(!g)return H("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!J()){let Ae=At(Ht);B({lastDrainedJournalId:"",graph:Ct(Ae)},null);}let j=I.params?.outputsStoreRef;if(!j)return H("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let U=I.params?.scratchStoreRef,Q=I.params?.archiveStoreRef,ie=I.params?.chatStoreRef,Ie=I.params?.artifactsStoreRef,he=u();he.writeCardStoreRef(g),he.writeOutputsStoreRef(j),U&&he.writeScratchStoreRef(U),Q&&he.writeArchiveStoreRef(Q),ie&&he.writeChatStoreRef(ie),Ie&&he.writeArtifactsStoreRef(Ie);let Te=I.body??{};Te["task-executor-ref"]&&he.writeTaskExecutorRef(Te["task-executor-ref"]),Object.prototype.hasOwnProperty.call(Te,"chat-handler-flow")&&he.writeChatHandlerFlow(Te["chat-handler-flow"]);try{v().writeStatusSnapshot(Ot(s,It(A().graph)));}catch{}return re()}catch(g){return ne(g)}}function k(I){try{let g=v().readStatusSnapshot();if(!g){g=Ot(s,It(A().graph));try{v().writeStatusSnapshot(g);}catch{}}return re(g)}catch(g){return ne(g)}}function y(I){try{let g=I.params?.id;return g?(E({type:"task-removal",taskName:g,timestamp:_e()}),x(),re()):H("removeCard requires params.id")}catch(g){return ne(g)}}function l(I){try{let g=I.params?.cardId;if(!g)return H("addCardFiles requires params.cardId");let j=jt(b()).appendFiles({params:{id:g},body:I.body});if(j.status!=="success")return j;let U=f({params:{cardId:g}});return U.status!=="success"?U:re({cardId:g,files_added:j.data.files_added,notified:!0})}catch(g){return ne(g)}}function f(I){try{let g=I.params?.cardId;if(!g)return H("cardRefreshedNotify requires params.cardId");let j=b().readCard(g);return j?(a([{kind:"card_refreshed",cardId:g,card:j}]),re({cardId:g,notified:!0})):H(`Card "${g}" not found in board at ${e.value}`)}catch(g){return ne(g)}}function R(I){try{let g=I.params?.id;return g?(E({type:"task-restart",taskName:g,timestamp:_e()}),x(),re()):H("retrigger requires params.id")}catch(g){return ne(g)}}async function T(I){return Y()}function w(I){try{let g=I.params?.cardId,j=I.params?.all,U=!!I.params?.restart;if(!g&&!j)return H("upsertCard requires --card-id <id> or --all");let Q=j?b().readAllCards().map(ie=>ie.id):[g];for(let ie of Q)if(!b().readCard(ie))return H(`Card "${ie}" not found in board at ${e.value}`);for(let ie of Q){let Ie=b().readCard(ie),he=Er(Ie),Te=t.hashFn(he),Ae=t.kvStorage("card-upsert"),Ue=Ae.read(ie),Ge=Ue?.taskConfigHash!==Te;if(!(!Ge&&!U)){if(Ge){let We=Ue?.blobRef??b().readCardKey(ie)??ie;E({type:"task-upsert",taskName:ie,taskConfig:he,timestamp:_e()}),Ae.write(ie,{blobRef:We,taskConfigHash:Te,updatedAt:_e()});}U&&E({type:"task-restart",taskName:ie,timestamp:_e()});}}return x(),re()}catch(g){return ne(g)}}function _(I){try{let g=I.params?.token;if(!g)return H("taskFailed requires params.token");let j=I.params?.error??"unknown error",U=Bt(g);if(!U)return H("Invalid callback token");E({type:"task-failed",taskName:U.taskName,error:j,timestamp:_e()});try{M().stream("exec-history").append({taskName:U.taskName,status:"failed",error:j,completedAt:_e()});}catch{}return x(),re()}catch(g){return ne(g)}}function F(I){try{let g=I.params?.token;if(!g)return H("taskProgress requires params.token");let U=(I.body??{}).update??{},Q=Bt(g);return Q?(E({type:"task-progress",taskName:Q.taskName,update:U,timestamp:_e()}),x(),re()):H("Invalid callback token")}catch(g){return ne(g)}}function oe(I){try{let g=I.params?.token,j=I.params?.ref;if(!g)return H("sourceDataFetched requires params.token");if(!j)return H("sourceDataFetched requires params.ref");let U=Tr(g);if(!U)return H("Invalid source token");let{cbk:Q,cid:ie,b:Ie,d:he,cs:Te,rqt:Ae}=U,Ue=Et(t.blobStorage("sources"),Ve=>t.resolveBlob(Ve)),Ge=t.genId();Ue.ingestSourceDataStaged(ie,he,ut(j),Ge);let We=Bt(Q);if(!We)return H("Invalid callback token embedded in source token");let qe=_e();return E({type:"task-progress",taskName:We.taskName,update:{bindTo:Ie,outputFile:he,fetchedAt:qe,deliveryToken:Ge,sourceChecksum:Te,rqt:Ae},timestamp:qe}),x(),re()}catch(g){return ne(g)}}function X(I){try{let g=I.params?.token,j=I.params?.reason??"unknown";if(!g)return H("sourceDataFetchFailure requires params.token");let U=Tr(g);if(!U)return H("Invalid source token");let{cbk:Q,b:ie,d:Ie,cs:he,rqt:Te}=U,Ae=Bt(Q);return Ae?(E({type:"task-progress",taskName:Ae.taskName,update:{bindTo:ie,outputFile:Ie,failure:!0,reason:j,sourceChecksum:he,rqt:Te},timestamp:_e()}),x(),re()):H("Invalid callback token embedded in source token")}catch(g){return ne(g)}}function ce(I){try{let g=u().readCardStoreRef();return g?re({storeRef:g}):H(`Board at ${e.value} has no card store configured`)}catch(g){return ne(g)}}function ye(I){try{let g=u().readOutputsStoreRef();return g?re({storeRef:g}):H(`Board at ${e.value} has no outputs store configured`)}catch(g){return ne(g)}}function N(I){try{let g=u().readScratchStoreRef();return re({storeRef:g})}catch(g){return ne(g)}}function $(I){try{let g=u().readArchiveStoreRef();return re({storeRef:g})}catch(g){return ne(g)}}function D(I){try{let g=u().readChatStoreRef();return re({storeRef:g})}catch(g){return ne(g)}}function se(I){try{let g=u().readArtifactsStoreRef();return re({storeRef:g})}catch(g){return ne(g)}}function te(I){try{let g=I.params?.key;if(!g)return H("getConfig requires params.key");let j=u(),U;switch(g){case "task-executor":U=j.readTaskExecutorRef()??null;break;case "chat-handler-flow":U=j.readChatHandlerFlow()??null;break;case "card-store-ref":U=j.readCardStoreRef();break;case "outputs-store-ref":U=j.readOutputsStoreRef();break;case "scratch-store-ref":U=j.readScratchStoreRef();break;case "archive-store-ref":U=j.readArchiveStoreRef();break;case "chat-store-ref":U=j.readChatStoreRef();break;case "artifacts-store-ref":U=j.readArtifactsStoreRef();break;default:return H(`getConfig: unknown key "${g}"`)}return re({value:U})}catch(g){return ne(g)}}function Z(I){try{let g=I.params?.key;if(!g)return H("getOutputsDataObject requires params.key");let j=v().readDataObject(g);return re(j)}catch(g){return ne(g)}}function Ce(I){try{return re(v().readAllDataObjects())}catch(g){return ne(g)}}function pe(I){try{let g=I.params?.key;if(!g)return H("getOutputsComputedValues requires params.key");let j=v().readComputedValues(g);return re(j)}catch(g){return ne(g)}}function Se(I){try{return re(v().readAllComputedValues())}catch(g){return ne(g)}}function me(){return Et(t.blobStorage("sources"),I=>t.resolveBlob(I))}function ke(I){let g=t.blobStorage("sources").keyRef?.(I);return g?Ne(g):I}function ve(I){try{let g=I.params?.key;if(!g)return H("getOutputsFetchedSources requires params.key");let j=me().listSources(g),U={};for(let Q of j)U[Q]=ke(`${g}/${Q}`);return re(U)}catch(g){return ne(g)}}function Nt(I){try{let g=me(),j=new Set;for(let Q of t.blobStorage("sources").listKeys()){let ie=Q.indexOf("/");ie>0&&!Q.includes("/.staged/")&&j.add(Q.slice(0,ie));}let U={};for(let Q of j){let ie=g.listSources(Q);if(ie.length>0){U[Q]={};for(let Ie of ie)U[Q][Ie]=ke(`${Q}/${Ie}`);}}return re(U)}catch(g){return ne(g)}}return {init:L,status:k,getCardStoreRef:ce,getOutputsStoreRef:ye,getScratchStoreRef:N,getArchiveStoreRef:$,getChatStoreRef:D,getArtifactsStoreRef:se,getConfig:te,getOutputsDataObject:Z,getAllOutputsDataObjects:Ce,getOutputsComputedValues:pe,getAllOutputsComputedValues:Se,getOutputsFetchedSources:ve,getAllOutputsFetchedSources:Nt,removeCard:y,addCardFiles:l,cardRefreshedNotify:f,retrigger:R,processAccumulatedEvents:T,upsertCard:w,taskFailed:_,taskProgress:F,sourceDataFetched:oe,sourceDataFetchFailure:X}}function Br(e,t){let r=()=>Kt(t.kvStorage("config"));function s(){let k=r().readCardStoreRef();if(!k)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let y=t.kvStorageForRef(k);return {readIndex(){return y.read("_index")},writeIndex(l){y.write("_index",l);},readCard(l){return y.read(l)},writeCard(l,f){return y.write(l,f),t.hashFn(f)},removeCard(l){y.delete(l);},cardExists(l){return y.read(l)!==null},defaultCardKey(l){return l}}}let a=()=>bt(s(),t.onWarn??(()=>{})),i=()=>{let k=r().readScratchStoreRef();return k?t.scratchStorageForRef(k):t.scratchStorage()};function c(k,y){let l=t.validateSchema(y),f=[],R=r().readTaskExecutorRef();if(R&&Array.isArray(y.source_defs))for(let w of y.source_defs){let _=typeof w.bindTo=="string"?w.bindTo:"(unknown)";try{let F;try{F=t.invokeExecutorSync(R,"validate-source-def",[],{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(w)});}catch(X){let ce=X;if(F=typeof ce?.stdout=="string"?ce.stdout:"",!F.trim()){f.push(`source "${_}": executor validate-source-def failed \u2014 ${X instanceof Error?X.message:String(X)}`);continue}}let oe=JSON.parse(F.trim());if(!oe.ok&&Array.isArray(oe.errors))for(let X of oe.errors)f.push(`source "${_}": ${X}`);}catch(F){f.push(`source "${_}": executor validate-source-def failed \u2014 ${F instanceof Error?F.message:String(F)}`);}}let T=[...l.errors,...f];return re({cardId:k,isValid:T.length===0,issues:T})}function u(k,y){let l=r().readTaskExecutorRef();if(!l)throw new Error("No task-executor registered for this board");let f=typeof k.bindTo=="string"?k.bindTo:"source",R=i(),T={...k,boardDir:e.value,_projections:y},w=R.create(JSON.stringify(T,null,2),`probe-in-${f}`,".json"),_=R.getUniqueKey(`probe-out-${f}`,".json"),F=R.getUniqueKey(`probe-err-${f}`,".txt"),oe=Ne(R.keyRef(w)),X=Ne(R.keyRef(_)),ce=Ne(R.keyRef(F)),ye=null;try{if(t.invokeExecutorSync(l,"run-source-fetch",["--in-ref",oe,"--out-ref",X,"--err-ref",ce],{timeout:k.timeout??t.executorTimeouts?.probeMs??6e4}),ye=R.read(_),ye===null)throw new Error("Executor produced no output file")}catch(N){let $=R.read(F)?.trim()??(N instanceof Error?N.message:String(N));throw new Error(`Probe failed: ${$}`)}finally{try{R.remove(w);}catch{}try{R.remove(F);}catch{}}return {bindTo:f,result:ye}}function m(k,y,l){let f;try{f=u(k,y);}catch(R){return H(R instanceof Error?R.message:String(R))}if(l){let R=ut(l);t.absoluteBlob.write(R.value,f.result);}return re({bindTo:f.bindTo,resultSizeBytes:f.result.length})}function h(k,y){let l=k.params?.sourceIdx,f=k.params?.outRef;if(l===void 0)return H(`${y} requires params.sourceIdx`);if(!k.body||typeof k.body!="object"||Array.isArray(k.body))return H(`${y} requires card JSON object in body`);let R=k.body,T=R["card-content"]??R,w=R["mock-projections"]??{},_=T.source_defs??[];if(l<0||l>=_.length)return H(`sourceIdx ${l} out of range (card has ${_.length} source(s))`);let F=_[l],oe=typeof F.bindTo=="string"?F.bindTo:"source";return {src:F,bindTo:oe,outRef:f,mockProjections:w}}function b(k){try{let y=k.params?.cardId,l=k.params?.all;if(!y&&!l)return H("validateCard requires --card-id <id> or --all");let f=l?a().readAllCards().map(T=>T.id):[y],R=[];for(let T of f){let w=a().readCard(T);if(!w){R.push({cardId:T,isValid:!1,issues:[`Card "${T}" not found`]});continue}let _=c(T,w);if(_.status!=="success")return _;R.push(_.data);}return re(R)}catch(y){return ne(y)}}function v(k){try{if(!k.body||typeof k.body!="object"||Array.isArray(k.body))return H("validateCardPreflight requires card JSON object in body");let y=k.body,l=y["card-content"]??y,f=typeof l.id=="string"?l.id:"(unknown)";return c(f,l)}catch(y){return ne(y)}}function M(k){try{let y=k.params?.cardId,l=k.params?.sourceIdx,f=k.params?.outRef;if(!y)return H("probeSource requires params.cardId");if(l===void 0)return H("probeSource requires params.sourceIdx");let T=(k.body??{})["mock-projections"]??{},w=a().readCard(y);if(!w)return H(`Card "${y}" not found`);let _=w.source_defs??[];return l<0||l>=_.length?H(`sourceIdx ${l} out of range (card has ${_.length} source(s))`):m(_[l],T,f)}catch(y){return ne(y)}}function J(k){try{let y=k.params?.outRef,l=k.body;if(!l)return H('probeTmpSource requires body with "source-def" and "mock-projections"');let f=l["source-def"],R=l["mock-projections"]??{};return f?m(f,R,y):H('probeTmpSource body requires "source-def"')}catch(y){return ne(y)}}function A(k){try{let y=h(k,"probeSourcePreflight");if("status"in y)return y;let l=r().readTaskExecutorRef();if(!l)return H("No task-executor registered for this board");try{let f={...y.src,_projections:y.mockProjections},R=t.invokeExecutorSync(l,"probe-source-preflight",[],{timeout:y.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(f)}),T=JSON.parse(R.trim());return T.ok?re({bindTo:y.bindTo,reachable:T.reachable,latencyMs:T.latencyMs,note:T.note}):H(T.error??"Preflight probe failed")}catch{return H("Executor does not support probe-source-preflight")}}catch(y){return ne(y)}}function B(k){try{let y=h(k,"runSourcePreflight");if("status"in y)return y;let l=r().readTaskExecutorRef();if(l)try{let w={...y.src,_projections:y.mockProjections},_=t.invokeExecutorSync(l,"run-source-preflight",[],{timeout:y.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(w)}),F=JSON.parse(_.trim());return F.ok?re({bindTo:F.bindTo??y.bindTo,reachable:F.reachable,latencyMs:F.latencyMs,kind:F.kind,resultValue:F.resultValue,note:F.note}):H(F.error??"Source preflight failed")}catch{}let f=Date.now(),R=u(y.src,y.mockProjections);if(y.outRef){let w=ut(y.outRef);t.absoluteBlob.write(w.value,R.result);}let T=R.result;try{T=JSON.parse(R.result);}catch{}return re({bindTo:R.bindTo,reachable:!0,latencyMs:Date.now()-f,resultValue:T,note:"Actual fetch preflight passed"})}catch(y){return ne(y)}}function E(k){try{let y=r().readTaskExecutorRef();if(!y)return H("No task-executor registered for this board");let l=t.invokeExecutorSync(y,"describe-capabilities",[],{timeout:t.executorTimeouts?.describeMs??1e4});return re(JSON.parse(l.trim()))}catch(y){return ne(y)}}function V(k){try{let y=k.body;if(!y||!Array.isArray(y.ops))return H("updatesInCardStore requires body.ops array");let l=y.ops,f=a();for(let R of l){let T=R.op,w=R.id;if(!w)return H('op is missing "id"');if(T==="update"){let _=R["card-content"];if(!_)return H(`update op for "${w}" is missing "card-content"`);f.writeCard(w,_);}else return H(`Unknown op type: "${T??"(none)"}"`)}return re()}catch(y){return ne(y)}}function Y(k){try{let y=k.body;if(!y||!Array.isArray(y.ids))return H("readFromCardStore requires body.ids array");let l=y.ids,f=a(),R=l.map(T=>({id:T,"card-content":f.readCard(T)}));return re({cards:R})}catch(y){return ne(y)}}function x(k){try{if(!k.body||typeof k.body!="object"||Array.isArray(k.body))return H("evalCardCompute requires a JSON object in body");let y=k.body,l=y["card-content"]??y,f=typeof l.id=="string"?l.id:"(unknown)",R=y["mock-fetched-sources"]??{},T=y["mock-requires"]??{},w=l.compute;if(!w||!Array.isArray(w)||w.length===0)return re({cardId:f,ok:!0,computed_values:{},errors:[]});let _={id:f,card_data:l.card_data??{},requires:T,source_defs:l.source_defs,compute:w},F=tt.runSync(_,{sourcesData:R}),oe=F.node.computed_values??{},X=F.errors??[];return re({cardId:f,ok:X.length===0,computed_values:oe,errors:X})}catch(y){return ne(y)}}function L(k){try{if(!k.body||typeof k.body!="object"||Array.isArray(k.body))return H("simulateCardCycle requires a JSON object in body");let y=k.body,l=y["card-content"]??y,f=typeof l.id=="string"?l.id:"(unknown)",R=y["mock-fetched-sources"]??{},T=y["mock-requires"]??{},w=c(f,l),_=w.status==="success"?{isValid:w.data.isValid,issues:w.data.issues}:{isValid:!1,issues:[w.status==="fail"?w.error:"internal error"]},F=l.source_defs??[],oe=l.card_data??{},X=[],ce=[];if(F.length>0){X=tt.enrichSourcesSync(F,{card_data:oe,requires:T});for(let Ce of X){let pe=Ce.projections,Se=Ce._projections;if(pe&&Se){for(let me of Object.keys(pe))if(Se[me]===void 0){let ke=typeof Ce.bindTo=="string"?Ce.bindTo:"(unknown)";ce.push({bindTo:ke,key:me,error:`Projection "${me}" resolved to undefined`});}}}}let ye=[],N=y["task-executor-ref"],$=(N?.howToRun&&N?.whatToRun?N:void 0)??r().readTaskExecutorRef();for(let Ce=0;Ce<X.length;Ce++){let pe=X[Ce],Se=typeof pe.bindTo=="string"?pe.bindTo:`source_${Ce}`;if(!$){ye.push({bindTo:Se,skipped:!0,error:"No task executor configured"});continue}try{let me={...pe},ke=t.invokeExecutorSync($,"run-source-preflight",[],{timeout:pe.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(me)}),ve=JSON.parse(ke.trim());ye.push({bindTo:Se,reachable:ve.reachable,latencyMs:ve.latencyMs,error:ve.ok?void 0:ve.error});}catch{ye.push({bindTo:Se,skipped:!0,error:"Executor does not support run-source-preflight"});}}let D=l.compute,se={},te=[];if(D&&Array.isArray(D)&&D.length>0){let Ce={id:f,card_data:oe,requires:T,source_defs:l.source_defs,compute:D},pe=tt.runSync(Ce,{sourcesData:R});se=pe.node.computed_values??{},te=pe.errors??[];}let Z=_.isValid&&ce.length===0&&te.length===0&&ye.every(Ce=>Ce.reachable!==!1);return re({cardId:f,ok:Z,validation:_,source_probes:ye,projection_errors:ce,computed_values:se,compute_errors:te})}catch(y){return ne(y)}}return {validateCard:b,validateCardPreflight:v,probeSource:M,probeTmpSource:J,probeSourcePreflight:A,runSourcePreflight:B,evalCardCompute:x,simulateCardCycle:L,describeTaskExecutorCapabilities:E,updatesInCardStore:V,readFromCardStore:Y}}function Ee(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 ge(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}function Be(e){return Array.isArray(e)?e:[]}function Fr(e,t){if(typeof t!="string"||t.length===0)return;let r=e,s=t;s.startsWith("fetched_sources.")&&(r=ge(e).fetched_sources,s=s.slice(16));for(let a of s.split(".")){if(r==null||typeof r!="object")return;r=r[a];}return r}function jn(e,t){let r=ge(e.view),s=Be(r.elements);return {layout:r.layout,features:r.features,elements:s.map((a,i)=>{let c=ge(a),u=ge(c.data),m=typeof c.visible=="string"?!!Fr(t,c.visible):true,h=typeof u.bind=="string"?u.bind:void 0,b=h?Fr(t,h):void 0,v={id:typeof c.id=="string"&&c.id?c.id:`element-${i}`,kind:c.kind,label:c.label,visible:m};return h&&(v.bind=h),Array.isArray(u.columns)&&(v.columns=u.columns),typeof u.maxRows=="number"&&(v.maxRows=u.maxRows),b!==void 0&&(v.resolved=Array.isArray(b)&&typeof v.maxRows=="number"?b.slice(0,v.maxRows):b),v})}}function Bn(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 Fn(e){return {"card-content":e}}function Ft(e,t){let r=Ee(e.get({params:{id:t}}),"cardStore.get"),s=Array.isArray(r?.cards)?r.cards:[];if(s.length===0)throw new Error(`Card "${t}" not found`);return s[0]}function Nr(e){let{board:t,nonCore:r,cardStore:s,chatStore:a,uploadCardFile:i,buildFileDownloadUrl:c,readFetchedSourceJsonByRef:u}=e;function m(l){if(Array.isArray(l.bytes))return new Uint8Array(l.bytes.map(f=>Math.max(0,Math.min(255,Number(f)||0))));if(typeof l.text=="string")return new TextEncoder().encode(l.text);if(typeof l.base64=="string"){let f=String(l.base64).replace(/-/g,"+").replace(/_/g,"/"),R=f+"=".repeat((4-f.length%4)%4),T=atob(R);return Uint8Array.from(T,w=>w.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}function h(){let l=ge(Ee(r.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:l.version,commonSourceFields:ge(l.commonSourceDefFields),sourceKinds:ge(l.sourceKinds)}}function b(){let l=ge(Ee(t.status({}),"status")),f=ge(l.summary),R=Be(l.cards);return {meta:ge(l.meta),summary:{card_count:typeof f.card_count=="number"?f.card_count:0,completed:typeof f.completed=="number"?f.completed:0,eligible:typeof f.eligible=="number"?f.eligible:0,pending:typeof f.pending=="number"?f.pending:0,blocked:typeof f.blocked=="number"?f.blocked:0,in_progress:typeof f.in_progress=="number"?f.in_progress:0,failed:typeof f.failed=="number"?f.failed:0,unresolved:typeof f.unresolved=="number"?f.unresolved:0},cards:R.map(T=>{let w=ge(T);return {"card-id":typeof w.name=="string"?w.name:null,status:w.status??null,error:w.error??null,requires:Be(w.requires),requires_satisfied:Be(w.requires_satisfied),requires_missing:Be(w.requires_missing),provides_declared:Be(w.provides_declared),provides_runtime:Be(w.provides_runtime)}})}}function v(l){let f=String(l.cardId||"").trim();if(!f)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let R=ge(Ee(t.status({}),"status")),w=Be(R.cards).map(ge).find(Z=>Z.name===f);if(!w)throw new Error(`card "${f}" not found in board status`);let _=ge(Ft(s,f)),F=Be(w.requires_satisfied).filter(Z=>typeof Z=="string"&&!!Z),oe=Be(w.provides_runtime).filter(Z=>typeof Z=="string"&&!!Z),X=Object.fromEntries(F.map(Z=>[Z,Ee(t.getOutputsDataObject({params:{key:Z}}),`getOutputsDataObject(${Z})`)])),ce=Object.fromEntries(oe.map(Z=>[Z,Ee(t.getOutputsDataObject({params:{key:Z}}),`getOutputsDataObject(${Z})`)])),ye=ge(Ee(t.getOutputsComputedValues({params:{key:f}}),"getOutputsComputedValues")),N=Ee(t.getOutputsFetchedSources({params:{key:f}}),"getOutputsFetchedSources"),$=Be(_.source_defs).map(ge),D={};for(let Z of $)typeof Z.bindTo=="string"&&typeof Z.outputFile=="string"&&(D[Z.outputFile]=Z.bindTo);let se={};for(let[Z,Ce]of Object.entries(N)){let pe=D[Z]??Z;if(!u||typeof Ce!="string"){se[pe]=null;continue}try{se[pe]=u({cardId:f,ref:Ce});}catch{se[pe]=null;}}let te={card_data:ge(_.card_data),requires:X,fetched_sources:se,computed_values:ye};return {cardId:f,card_status_in_board:w,card_definition_and_static_data:_,refs_for_fetched_source_files:N,runtime_data:{requires:X,provides:ce,computed_values:ye,rendered_view:jn(_,te)}}}function M(l){let f=String(l.cardId||"").trim();if(!f)throw new Error("inspectChatMessagesOnCards requires cardId");let R=typeof l.turnId=="string"?l.turnId:"",T=l.allTurns===true,w=typeof l.tailTurnsBeforeId=="string"?l.tailTurnsBeforeId:"",_=T?void 0:l.lastUserTurns??(R?void 0:1),F=l.tail,oe=_===void 0?{params:{cardId:f}}:{params:{cardId:f},body:{lastUserTurns:_}},X=Ee(a.readAll(oe),"chatStore.readAll"),ce=ge(Ft(s,f)),ye=Be(ge(ce.card_data).files).map((D,se)=>({idx:se,stored_name:ge(D).stored_name})).filter(D=>typeof D.stored_name=="string"&&D.stored_name.length>0),N=(Array.isArray(X.records)?X.records:[]).filter(D=>R?typeof D?.turn=="string"?D.turn===R:R==="":true);if(w){if(_===void 0||!Number.isInteger(_)||_<=0)throw new Error("inspectChatMessagesOnCards requires tail-turns when tail-turns-before-id is provided");let D=new Map,se=[];for(let pe of Array.isArray(X.records)?X.records:[]){let Se=typeof pe?.turn=="string"?pe.turn:"";D.has(Se)||(D.set(Se,[]),se.push(Se)),D.get(Se).push(pe);}let te=se.findIndex(pe=>pe===w),Z=Math.max(0,te-_);N=(te===-1?[]:se.slice(Z,te)).flatMap(pe=>D.get(pe)??[]);}let $=N.map(D=>{let te=ge(D.payload),Z={...D},Ce=typeof D?.role=="string"?D.role:typeof te.role=="string"?String(te.role):"",pe=typeof D?.text=="string"?D.text:typeof te.text=="string"?String(te.text):"";if(Ce==="system"){let Se=Bn(pe);if(Se!==null&&ye.some(ke=>ke.idx===Se)){let ke=`Retrieve using inspect-file-contents --card-id ${f} --file-idx ${Se}`;Z.retrieval_hint=ke,Object.keys(te).length>0&&typeof D.role!="string"&&(Z.payload={...te,retrieval_hint:ke});}}return Z});return {cardId:f,messages:typeof F=="number"&&F>=0?$.slice(-F):$}}function J(l){let f=String(l.cardId||"").trim(),R=Number(l.fileIdx);if(!f)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(R)||R<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let T=ge(Ft(s,f)),w=Be(ge(T.card_data).files).map(ge);if(R>=w.length)throw new Error(`attachment index ${R} is out of range for card "${f}"`);let _=w[R],F=typeof _.stored_name=="string"?_.stored_name:null;return {cardId:f,fileIdx:R,downloadUrl:c({cardId:f,fileIdx:R,storedName:F}),...typeof _.name=="string"?{name:_.name}:{},...typeof _.stored_name=="string"?{stored_name:_.stored_name}:{},...typeof _.mime_type=="string"?{mime_type:_.mime_type}:{},...typeof _.size=="number"?{size:_.size}:{},...typeof _.uploaded_at=="string"?{uploaded_at:_.uploaded_at}:{}}}function A(l){return r.validateCardPreflight({body:Fn(l.candidateCardContent)})}function B(l){return r.evalCardCompute({body:{"card-content":l.candidateCardContent,"mock-requires":l.mockRequires,"mock-fetched-sources":l.mockFetchedSources}})}function E(l){return r.probeSourcePreflight({params:{sourceIdx:l.sourceIdx},body:{"card-content":l.candidateCardContent,"mock-projections":l.mockProjections}})}function V(l){return r.runSourcePreflight({params:{sourceIdx:l.sourceIdx},body:{"card-content":l.candidateCardContent,"mock-projections":l.mockProjections}})}function Y(l){return r.simulateCardCycle({body:{"card-content":l.candidateCardContent,"mock-requires":l.mockRequires}})}function x(l){let f=String(l.cardId||"").trim();if(!f)throw new Error("manageReadCard requires cardId");let R=Ee(s.get({params:{id:f}}),"cardStore.get");return Array.isArray(R.cards)?R.cards:[]}function L(l){let f=String(l.cardId||"").trim(),R=String(l.role||"").trim(),T=typeof l.text=="string"?l.text:"",w=typeof l.turn=="string"?l.turn:"";if(!f)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!R)throw new Error("manageAddChatEntryAndAnyAttachments requires role");let _=Be(l.files).map(oe=>{let X=ge(oe),ce=String(X.file_name??X.fileName??X.name??"").trim(),ye=String(X.content_type??X.contentType??"application/octet-stream");if(!ce)throw new Error("file entry requires file_name");return i({cardId:f,fileName:ce,contentType:ye,bytes:m(X)}).file});_.forEach((oe,X)=>{let ce=R==="assistant"?`AI generated: ${String(oe.name||"")} as ${String(oe.stored_name||"")} #${X}`:`file uploaded: ${String(oe.name||"")} as ${String(oe.stored_name||"")} #${X}`;Ee(a.append({params:{cardId:f},body:{role:"system",text:ce,files:[],turn:w}}),"chatStore.append(system attachment message)");});let F=Ee(a.append({params:{cardId:f},body:{role:R,text:T,files:_,turn:w}}),"chatStore.append");return {status:"success",data:{cardId:f,id:String(F.id),role:R,turn:w,files:_}}}function k(l){let f=String(l.cardId||"").trim(),R=ge(l.candidateCardContent);if(!f)throw new Error("manageUpsertCard requires cardId");if(typeof R.id!="string"||!R.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(R.id!==f)throw new Error(`candidateCardContent.id must match cardId (${f})`);let T=A({candidateCardContent:R}),w=ge(T),_=ge(w.data);if(w.status!=="success"||_.isValid!==true)return {status:"fail",step:"validate",validation:T};let F=null;try{F=Ft(s,f);}catch{F=null;}let oe=s.set({body:R});Ee(oe,"cardStore.set");let X;try{X=t.upsertCard({params:{cardId:f,restart:!0}}),Ee(X,"upsertCard");}catch(ye){try{F&&s.set({body:F});}catch{}throw ye}let ce=null;try{ce=t.cardRefreshedNotify({params:{cardId:f}}),Ee(ce,"cardRefreshedNotify");}catch{ce=null;}return {status:"success",data:{validation:T,card_saved:null,board_result:X,refresh_notify:ce}}}function y(l){let f=String(l.cardId||"").trim();if(!f)throw new Error("manageDeprecate requires cardId");let R=t.removeCard({params:{id:f}});return Ee(R,"removeCard"),R}return {discoverSourceKinds:h,inspectBoardRuntimeStatus:b,inspectCardDefinitionAndRuntime:v,inspectChatMessagesOnCards:M,inspectFileContents:J,preflightValidateCandidateCardDefinition:A,preflightMaterializeCandidateCard:B,preflightProbeSingleSourceInCandidateCard:E,preflightRunSingleSourceInCandidateCard:V,preflightRunOneCycleWithCandidateCard:Y,manageReadCard:x,manageAddChatEntryAndAnyAttachments:L,manageUpsertCard:k,manageDeprecate:y}}function Pr(){return new Date().toISOString()}function $r(e){return new TextEncoder().encode(e).byteLength}function Nn(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function Pn(e){let t=String(e||"").match(/^(\d+)[-_]/);return t?parseInt(t[1],10):0}function $n(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 Dn(e){return String(e||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function qn(e){if(!e||e===".")return "";let t=String(e).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return t?`.${t}`:""}function Ln(e){let t=$n(e),r=t.lastIndexOf(".");return r<=0||r===t.length-1?{stem:t,ext:""}:{stem:t.slice(0,r),ext:t.slice(r)}}function Mn(e){let t=e.lastIndexOf("/");return t>=0?e.slice(t+1):e}function Dr(e){function t(r){let s=e.stat?Nn(e.stat(r)):null;if(s)return s;if(!e.exists(r))return null;let a=e.read(r);return a===null?{key:r}:{key:r,size:$r(a)}}return {exists(r){return e.exists(r)},putText(r,s,a="text/plain; charset=utf-8"){e.write(r,s);let i=t(r)??{key:r};return i.contentType=a,i.updatedAt=i.updatedAt??Pr(),i.size=i.size??$r(s),i},putBytes(r,s,a="application/octet-stream"){if(e.writeBytes)e.writeBytes(r,s);else {let c=JSON.stringify({__kind:"bytes-array",data:[...s]});e.write(r,c);}let i=t(r)??{key:r};return i.contentType=a,i.updatedAt=i.updatedAt??Pr(),i.size=i.size??s.byteLength,i},getText(r){let s=e.read(r);if(s===null){if(!e.readBytes)return null;let a=e.readBytes(r);return a===null?null:Buffer.from(a).toString("utf-8")}try{let a=JSON.parse(s);if(a&&a.__kind==="bytes-array"&&Array.isArray(a.data))return new TextDecoder("utf-8").decode(new Uint8Array(a.data))}catch{}return s},getBytes(r){if(e.readBytes){let a=e.readBytes(r);if(a!==null)return a}let s=e.read(r);if(s===null)return null;try{let a=JSON.parse(s);if(a&&a.__kind==="bytes-array"&&Array.isArray(a.data))return new Uint8Array(a.data)}catch{}return new TextEncoder().encode(s)},head:t,list(r=""){return e.listKeys(r).map(s=>t(s)??{key:s}).sort((s,a)=>s.key.localeCompare(a.key))},remove(r){e.remove(r);}}}function qr(e){function t(a,i){let c=0,u=[];Array.isArray(i)&&u.push(...i);for(let m of e.list(`${a}/`))u.push(Mn(m.key));for(let m of u){let h=Pn(m);Number.isFinite(h)&&h>c&&(c=h);}return c+1}function r(a,i,c){let u=Number(c?.maxLen||32),{stem:m,ext:h}=Ln(a),b=qn(h),v=Dn(m),M=`${String(i).padStart(3,"0")}-`,J=b,A=u-M.length-J.length;A<1&&(J="",A=u-M.length);let B=v.slice(0,Math.max(1,A)),E=`${M}${B}${J}`;return E.length>u&&(E=E.slice(0,u).replace(/\.$/,"")),E}function s(a,i,c){let u=t(a,c?.seedNames),m=r(i,u,{maxLen:c?.maxLen});for(;e.exists(`${a}/${m}`);)u+=1,m=r(i,u,{maxLen:c?.maxLen});return m}return {nextSerial:t,buildStoredName:r,allocateStoredName:s}}function Lr(){function e(a,i){if(!Array.isArray(a))return [];let c=[];for(let u of a){if(!u||typeof u!="object")continue;let m=u;typeof m.stored_name=="string"&&c.push({name:typeof m.name=="string"?m.name:m.stored_name,stored_name:m.stored_name,size:typeof m.size=="number"&&Number.isFinite(m.size)?m.size:null,mime_type:typeof m.mime_type=="string"?m.mime_type:null,uploaded_at:typeof m.uploaded_at=="string"?m.uploaded_at:i||null,chat:m.chat===true});}return c}function t(a){return !a||typeof a!="object"?[]:e(a.files,void 0)}function r(a,i){let c=t(a);if(i.length===0)return a.files=c,c;let u=new Set(c.map(m=>m.stored_name));for(let m of i)u.has(m.stored_name)||(c.push(m),u.add(m.stored_name));return a.files=c,c}function s(a,i,c){let u=t(a);if(!Number.isInteger(i)||i<0||i>=u.length)return {ok:false,reason:"index_out_of_range"};let m=u[i];return !m||!m.stored_name?{ok:false,reason:"missing_stored_name"}:c&&c!==m.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:m}}return {read:t,normalizeIncoming:e,merge:r,resolve:s}}function Un(){let e=globalThis.crypto;return typeof e?.randomUUID=="function"?String(e.randomUUID()):`id-${Date.now()}-${Math.random().toString(36).slice(2)}`}function Mr(){let e=new Map,t=new Map;function r(s){return e.has(s)||e.set(s,[]),e.get(s)}return {append(s,a,i,c=[],u=""){let m={id:Un(),role:a,text:i,files:c,turn:u,updated_at:new Date().toISOString()};return r(s).push(m),m.id},readAll(s){return r(s).slice()},readAfter(s,a){let i=r(s);if(!a)return {records:i.slice(),cursor:i.length>0?i[i.length-1].id:null};let c=i.findIndex(m=>m.id===a),u=c===-1?i.slice():i.slice(c+1);return {records:u,cursor:u.length>0?u[u.length-1].id:a}},clear(s){e.set(s,[]);},setProcessing(s,a){a?t.set(`p:${s}`,true):t.delete(`p:${s}`);},isProcessing(s){return t.get(`p:${s}`)===true},getConfig(s){return t.get(`c:${s}`)??{}},setConfig(s,a){let i=t.get(`c:${s}`)??{};t.set(`c:${s}`,{...i,...a});}}}function Ur(e){function t(h){let b=typeof h=="number"?h:Number(h);return Number.isInteger(b)&&b>0?b:null}function r(h,b){let v=b;for(let M=h.length-1;M>=0;M-=1)if(h[M]?.role==="user"&&(v-=1,v===0))return h.slice(M);return h}function s(h){return {status:"success",data:h}}function a(h){return {status:"fail",error:h}}function i(h){return {status:"error",error:h instanceof Error?h.message:String(h)}}function c(h,b="command envelope"){let v=typeof h.cardId=="string"?h.cardId:void 0;if(!h.command)return a(`chat-store: ${b} missing "command"`);if(!v)return a(`chat-store: ${b} missing "cardId"`);if(h.command==="append")return m.append({params:{cardId:v},body:{role:h.role,text:h.text,files:h.files,turn:h.turn}});if(h.command==="read-all")return m.readAll({params:{cardId:v},body:{lastUserTurns:h.lastUserTurns}});if(h.command==="read-after")return m.readAfter({params:{cardId:v},body:{cursor:h.cursor??null}});if(h.command==="clear")return m.clear({params:{cardId:v}});if(h.command==="set-processing")return m.setProcessing({params:{cardId:v},body:{active:h.active}});if(h.command==="is-processing")return m.isProcessing({params:{cardId:v}});if(h.command==="get-config")return m.getConfig({params:{cardId:v}});if(h.command==="set-config"){let{command:M,cardId:J,...A}=h;return m.setConfig({params:{cardId:v},body:A})}return a(`chat-store: unknown command "${String(h.command)}"`)}function u(h){if(!Array.isArray(h.commands)||h.commands.length===0)return a('chat-store: command envelope must include a non-empty "commands" array');let b=[];for(let v=0;v<h.commands.length;v+=1){let M=h.commands[v];if(!M||typeof M!="object"||Array.isArray(M))return a(`chat-store: command envelope entry ${v} must be an object`);let J={cardId:h.cardId,...M},A=c(J,`command envelope entry ${v}`);if(A.status!=="success")return A;b.push({index:v,command:String(J.command),data:A.data});}return s({results:b})}let m={append(h){try{let b=h.params?.cardId;if(!b)return a("append requires params.cardId");let v=h.body??{},M=typeof v.role=="string"?v.role:"",J=typeof v.text=="string"?v.text:"",A=Array.isArray(v.files)?v.files:[],B=typeof v.turn=="string"?v.turn:"";if(!M)return a("append requires body.role");let E=e.append(b,M,J,A,B);return s({id:E})}catch(b){return i(b)}},readAll(h){try{let b=h.params?.cardId;if(!b)return a("readAll requires params.cardId");let v=h.body??{},M=e.readAll(b);if(v.lastUserTurns===void 0)return s({records:M});let J=t(v.lastUserTurns);return J===null?a("readAll requires body.lastUserTurns (positive integer)"):s({records:r(M,J)})}catch(b){return i(b)}},readAfter(h){try{let b=h.params?.cardId;if(!b)return a("readAfter requires params.cardId");let M=(h.body??{}).cursor??null;return s(e.readAfter(b,M))}catch(b){return i(b)}},clear(h){try{let b=h.params?.cardId;return b?(e.clear(b),s({ok:!0})):a("clear requires params.cardId")}catch(b){return i(b)}},setProcessing(h){try{let b=h.params?.cardId;if(!b)return a("setProcessing requires params.cardId");let v=h.body??{};return typeof v.active!="boolean"?a("setProcessing requires body.active (boolean)"):(e.setProcessing(b,v.active),s({ok:!0}))}catch(b){return i(b)}},isProcessing(h){try{let b=h.params?.cardId;return b?s({active:e.isProcessing(b)}):a("isProcessing requires params.cardId")}catch(b){return i(b)}},getConfig(h){try{let b=h.params?.cardId;return b?s({config:e.getConfig(b)}):a("getConfig requires params.cardId")}catch(b){return i(b)}},setConfig(h){try{let b=h.params?.cardId;if(!b)return a("setConfig requires params.cardId");let v=h.body??{};return e.setConfig(b,v),s({ok:!0})}catch(b){return i(b)}},run:c,runBatch:u};return m}var Gr={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},Gn=32;function Vn(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Vr(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 Kr(e,t){if(!t||typeof t!="object")return;let r=t;if(r.kind==="notification-batch"&&Array.isArray(r.notifications)){for(let s of r.notifications)Kr(e,s);return}r.kind==="status"&&Vr(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 Yo(e){let t=String(e.apiBasePath||"/api/board").replace(/\/$/,""),r={...Gr,...e.corsHeaders||{}},s=e.boardId||"",a=e.logger||{info:console.log,warn:console.warn,error:console.error},i=e.invocationAdapter,c=e.chatFlowRunner||null,u=e.chatStorage??Mr(),m=Ur(u),h=e.notificationTransport||null,b=e.serverUrl||null,v=e.executionExtra||{},M=e.onSseClientConnected,J=e.onSseClientDisconnected,A=e.onChannelSubscribed,B=e.onChannelUnsubscribed,E=new Map,V=new Map,Y=new Map,x=null;function L(o){let n=jr(o.baseRef,o.boardAdapter),d=o.nonCoreAdapter??(f(o.boardAdapter)?o.boardAdapter:null),p=d?Br(o.baseRef,d):null,C=o.boardAdapter.kvStorageForRef(o.cardStoreRef),O=jt(bt({readIndex:()=>C.read("_index"),writeIndex:le=>C.write("_index",le),readCard:le=>C.read(le),writeCard:(le,xe)=>(C.write(le,xe),le),cardExists:le=>C.read(le)!==null,defaultCardKey:le=>le},a.warn)),q=o.artifactsAdapter||o.boardAdapter,G=o.filesArtifactsStore??null,ue=o.artifactsAdapter?q.blobStorage(""):q.blobStorage("files"),de=null;return {label:o.label,board:n,nonCore:p,cardStore:O,get filesArtifacts(){return de??=G??Dr(ue)},boardAdapter:o.boardAdapter,cardStoreRef:o.cardStoreRef,outputsStoreRef:o.outputsStoreRef,artifactsStoreRef:o.artifactsStoreRef,scratchStoreRef:o.scratchStoreRef,archiveStoreRef:o.archiveStoreRef,notifyRef:o.notifyRef,taskExecutorRef:o.taskExecutorRef,chatHandlerRef:o.chatHandlerRef,chatHandlerFlow:o.chatHandlerFlow,inferenceAdapterRef:o.inferenceAdapterRef,notification:Vn(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let k=e.boards.map(L),y=new Map;function l(o){return y.get(o)??0}function f(o){let n=o;return typeof n.invokeExecutorSync=="function"&&typeof n.validateSchema=="function"}function R(o){let n=k[l(o)];return {files:n?n.filesArtifacts:null}}function T(o){let n=R(o);return n.files?qr(n.files):null}function w(){return Lr()}function _(o){return String(o||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function F(o){if(!o||o.notificationTeardown||!h||!o.notifyRef)return;let n=await h.subscribe(o.notifyRef,d=>{Kr(o.notification,d);let p=d.kind==="notification-batch"?d.notifications:[d];Jt(p);});o.notificationTeardown=n;}async function oe(o){if(!o||o.initialized)return;let n={cardStoreRef:o.cardStoreRef,outputsStoreRef:o.outputsStoreRef};o.artifactsStoreRef&&(n.artifactsStoreRef=o.artifactsStoreRef),o.scratchStoreRef&&(n.scratchStoreRef=o.scratchStoreRef),o.archiveStoreRef&&(n.archiveStoreRef=o.archiveStoreRef);let d={};o.taskExecutorRef&&(d["task-executor-ref"]=o.taskExecutorRef),o.chatHandlerFlow!==void 0&&(d["chat-handler-flow"]=o.chatHandlerFlow),o.inferenceAdapterRef&&(d["inference-adapter-ref"]=o.inferenceAdapterRef);let p=o.board.init({params:n,body:d});if(p.status!=="success")throw Object.assign(new Error(p.error||`init failed for ${o.label}`),{statusCode:500});if(await F(o),!o.chatHandlerFlow&&o.chatHandlerRef&&i.describe)try{let C=await i.describe(o.chatHandlerRef);C&&C.kind!=="chat-handler"?a.warn(`[init] chat-handler describe returned kind="${C.kind}", expected "chat-handler" for ${o.label}`):C&&a.info(`[init] chat-handler validated: ${C.name} (protocol ${C.protocolVersion}) for ${o.label}`);}catch(C){a.warn(`[init] chat-handler describe failed for ${o.label}: ${C?.message||String(C)}`);}o.initialized=true;}function X(o){if(!o.boardAdapter.publishBoardChangeNotifications)return;let n=[],d=o.board.status({});d.status==="success"&&d.data!=null&&Vr(d.data)&&n.push({kind:"status",status:d.data});let p=o.board.getAllOutputsDataObjects({});if(p.status==="success"&&p.data!=null)for(let[S,O]of Object.entries(p.data))S&&n.push({kind:"data_object",key:S,payload:O});let C=o.board.getAllOutputsComputedValues({});if(C.status==="success"&&C.data!=null)for(let[S,O]of Object.entries(C.data))S&&n.push({kind:"computed_values",cardId:S,values:O});n.length>0&&o.boardAdapter.publishBoardChangeNotifications(n);}function ce(o,n){if(!o||o.cardsBootstrapped)return;let d=o.cardStore.get({}),p=d.status==="success"&&Array.isArray(d.data?.cards)?d.data.cards:[];for(let C of p)typeof C.id=="string"&&(y.set(C.id,n),o.board.upsertCard({params:{cardId:C.id}}));o.cardsBootstrapped=true;}async function ye(){for(let o of k)await oe(o);}async function N(){await ye();for(let o=0;o<k.length;o++)X(k[o]),ce(k[o],o);}function $(o){return k[l(o)]??null}function D(o){let n=$(o);if(!n)return null;let d=n.cardStore.get({params:{id:o}});if(d.status!=="success")return null;let p=Array.isArray(d.data?.cards)?d.data.cards:[];return p.length>0?p[0]:null}function se(){let o=d=>{if(!d||!d.cardStore)return [];let p=d.cardStore.get({});return p.status!=="success"||!Array.isArray(p.data?.cards)?[]:p.data.cards},n=[];for(let d of k)n.push(...o(d));return n}function te(){return k[0]??null}function Z(){return {status(){let o=g();return o==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:o}},getOutputsDataObject(o){let n=o?.params?.key;return n?{status:"success",data:U()[n]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},getOutputsComputedValues(o){let n=o?.params?.key;return n?{status:"success",data:j()[n]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},getOutputsFetchedSources(o){let n=o?.params?.key;if(!n)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let d=$(n)??te();return d?d.board.getOutputsFetchedSources({params:{key:n}}):{status:"fail",error:"Board context is unavailable"}},removeCard(o){let n=o?.params?.id;if(!n)return {status:"fail",error:"removeCard requires params.id"};let d=$(n)??te();return d?d.board.removeCard({params:{id:n}}):{status:"fail",error:"Board context is unavailable"}},cardRefreshedNotify(o){let n=o?.params?.cardId;if(!n)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let d=$(n)??te();return d?d.board.cardRefreshedNotify({params:{cardId:n}}):{status:"fail",error:"Board context is unavailable"}},upsertCard(o){let n=o?.params?.cardId;if(!n)return {status:"fail",error:"upsertCard requires params.cardId"};let d=$(n)??te();return d?d.board.upsertCard({params:{cardId:n,restart:o.params.restart===true}}):{status:"fail",error:"Board context is unavailable"}}}}function Ce(){let o=()=>{let n=te();if(!n?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return n.nonCore};return {describeTaskExecutorCapabilities(n){return o().describeTaskExecutorCapabilities(n)},validateCardPreflight(n){return o().validateCardPreflight(n)},evalCardCompute(n){return o().evalCardCompute(n)},probeSourcePreflight(n){return o().probeSourcePreflight(n)},runSourcePreflight(n){return o().runSourcePreflight(n)},simulateCardCycle(n){return o().simulateCardCycle(n)}}}function pe(){return {get(o){let n=typeof o.params?.id=="string"?o.params.id:void 0;if(n){let d=D(n);return d?{status:"success",data:{cards:[d]}}:{status:"fail",error:`card "${n}" not found`}}return {status:"success",data:{cards:se()}}},set(o){let n=o.body;if(n==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let d=Array.isArray(n)?n:[n];for(let p of d){let C=p,S=typeof C.id=="string"?C.id:"";if(!S)return {status:"fail",error:"each card must have a string `id` field"};let O=y.get(S)??0,q=k[O]??te();if(!q)return {status:"fail",error:"Board context is unavailable"};let G=q.cardStore.set({body:C});if(G.status!=="success")return G;y.set(S,O);}return {status:"success",data:{count:d.length}}},del(o){let n=[o.params?.id,...o.body?.ids??[]].filter(d=>typeof d=="string"&&!!d);if(n.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let d of n){let p=$(d)??te();if(!p)return {status:"fail",error:"Board context is unavailable"};let C=p.cardStore.del({params:{id:d}});if(C.status!=="success")return C;y.delete(d);}return {status:"success",data:{count:n.length}}},patch(o){let n=typeof o.params?.id=="string"?o.params.id:void 0,d=typeof o.params?.path=="string"?o.params.path:void 0;if(!n||!d)return {status:"fail",error:"patch requires params.id and params.path"};let p=$(n)??te();return p?p.cardStore.patch(o):{status:"fail",error:"Board context is unavailable"}},appendFiles(o){let n=typeof o.params?.id=="string"?o.params.id:void 0;if(!n)return {status:"fail",error:"appendFiles requires params.id"};let d=$(n)??te();return d?d.cardStore.appendFiles(o):{status:"fail",error:"Board context is unavailable"}}}}function Se(){return Nr({board:Z(),nonCore:Ce(),cardStore:pe(),chatStore:m,uploadCardFile({cardId:o,fileName:n,contentType:d,bytes:p}){return rt(o,n,d,p,{inChat:false})},buildFileDownloadUrl({cardId:o,fileIdx:n,storedName:d}){let p=`${b||""}${t}/cards/${encodeURIComponent(o)}/files/${n}`;return d?`${p}?sn=${encodeURIComponent(d)}`:p},readFetchedSourceJsonByRef({cardId:o,ref:n}){let d=$(o)??te();if(!d)return null;let C=d.boardAdapter.resolveBlob(ut(n)).trim();return C?JSON.parse(C):null}})}function me(o,...n){for(let d of n)if(typeof o[d]=="string")return String(o[d]);return ""}function ke(o,...n){for(let d of n)if(o[d]!==void 0)return Number(o[d])}function ve(o,...n){for(let d of n){let p=o[d];if(p&&typeof p=="object"&&!Array.isArray(p))return p}return {}}function Nt(o){return {"discover.source-kinds":()=>o.discoverSourceKinds(),"inspect.board-runtime-status":()=>o.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":n=>o.inspectCardDefinitionAndRuntime({cardId:me(n,"card_id","cardId")}),"inspect.chat-messages-on-cards":n=>{let d=ke(n,"tail-turns"),p=ke(n,"tail"),C=me(n,"turn-id"),S=n["all-turns"]===true,O=me(n,"tail-turns-before-id");return o.inspectChatMessagesOnCards({cardId:me(n,"card_id","cardId"),...d!==void 0?{lastUserTurns:d}:{},...p!==void 0?{tail:p}:{},...C?{turnId:C}:{},...S?{allTurns:true}:{},...O?{tailTurnsBeforeId:O}:{}})},"inspect.file-contents":n=>o.inspectFileContents({cardId:me(n,"card_id","cardId"),fileIdx:Number(ke(n,"file_idx","fileIdx"))}),"preflight.validate-candidate-card-definition":n=>o.preflightValidateCandidateCardDefinition({candidateCardContent:ve(n,"candidate_card_content","candidateCardContent")}),"preflight.materialize-candidate-card":n=>o.preflightMaterializeCandidateCard({candidateCardContent:ve(n,"candidate_card_content","candidateCardContent"),mockRequires:ve(n,"mock_requires","mockRequires"),mockFetchedSources:ve(n,"mock_fetched_sources","mockFetchedSources")}),"preflight.probe-single-source-in-candidate-card":n=>o.preflightProbeSingleSourceInCandidateCard({candidateCardContent:ve(n,"candidate_card_content","candidateCardContent"),mockProjections:ve(n,"mock_projections","mockProjections"),sourceIdx:Number(ke(n,"source_idx","sourceIdx"))}),"preflight.run-single-source-in-candidate-card":n=>o.preflightRunSingleSourceInCandidateCard({candidateCardContent:ve(n,"candidate_card_content","candidateCardContent"),mockProjections:ve(n,"mock_projections","mockProjections"),sourceIdx:Number(ke(n,"source_idx","sourceIdx"))}),"preflight.run-one-cycle-with-candidate-card":n=>o.preflightRunOneCycleWithCandidateCard({candidateCardContent:ve(n,"candidate_card_content","candidateCardContent"),mockRequires:ve(n,"mock_requires","mockRequires")}),"manage.read-card":n=>o.manageReadCard({cardId:me(n,"card_id","cardId")}),"stage-ai-response-and-any-attachments":n=>o.manageAddChatEntryAndAnyAttachments({cardId:me(n,"card_id","cardId"),role:"assistant",...typeof n.text=="string"?{text:n.text}:{},...typeof me(n,"turn-id","turnId","turn")=="string"&&me(n,"turn-id","turnId","turn")!==""?{turn:me(n,"turn-id","turnId","turn")}:{},...Array.isArray(n.files)?{files:n.files}:{}}),"manage.upload-card-file":n=>{let d=me(n,"card_id","cardId"),p=me(n,"file_name","fileName","name"),C=me(n,"content_type","contentType")||"application/octet-stream",S=null;if(Array.isArray(n.bytes))S=new Uint8Array(n.bytes.map(O=>Math.max(0,Math.min(255,Number(O)||0))));else if(typeof n.text=="string")S=new TextEncoder().encode(n.text);else if(typeof n.base64=="string"){let O=String(n.base64).replace(/-/g,"+").replace(/_/g,"/"),q=O+"=".repeat((4-O.length%4)%4),G=atob(q);S=Uint8Array.from(G,ue=>ue.charCodeAt(0));}if(!d)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!p)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!S)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return rt(d,p,C,S,{inChat:false})},"manage.upsert-card":n=>o.manageUpsertCard({cardId:me(n,"card_id","cardId"),candidateCardContent:ve(n,"candidate_card_content","candidateCardContent")}),"manage.deprecate":n=>o.manageDeprecate({cardId:me(n,"card_id","cardId")})}}function I(o,n){let d=Nt(Se())[o];if(!d)throw Object.assign(new Error(`Unknown MCP tool: ${o}`),{statusCode:400});return d(n)}function g(){let o=k.map(S=>{try{let q=S.boardAdapter.kvStorageForRef(S.outputsStoreRef).read("status");if(q!=null)return q}catch{}return S.notification.status}).filter(Boolean);if(o.length===0)return null;if(o.length===1)return o[0];let n=[],d=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],p={};for(let S of d)p[S]=0;for(let S of o){let O=S,q=Array.isArray(O.cards)?O.cards:[];n.push(...q);for(let G of d)p[G]+=Number(O?.summary?.[G]||0);}let C=o[0];return {...C,cards:n,summary:{...C.summary||{},card_count:n.length,...p}}}function j(){let o={},n=d=>{for(let[p,C]of Object.entries(d.notification.computedValues)){let S=d.notification.cards[p];o[p]={schema_version:"v1",card_id:p,card_data:S?.card_data??{},computed_values:C??{}};}};for(let d of k)n(d);return o}function U(){let o={};for(let n of k)Object.assign(o,n.notification.dataObjects||{});return o}function Q(){let o=se(),n=j(),d=U(),p={};for(let S of o){if(!S?.id)continue;let O=S.id,q=n[O]||{},G={...q.card_data&&typeof q.card_data=="object"?q.card_data:S.card_data&&typeof S.card_data=="object"?S.card_data:{}};p[O]={schema_version:q.schema_version||"v1",card_id:q.card_id||O,card_data:G,computed_values:q.computed_values&&typeof q.computed_values=="object"?q.computed_values:{}};}let C={};for(let S of o){if(!S?.id)continue;let O=S.id;try{let q=qe(O),G=u.isProcessing(O);(q.length>0||G)&&(C[O]={messages:q.map(ue=>({role:String(ue.role||"system"),text:String(ue.text||""),files:Array.isArray(ue.files)?ue.files:[]})),receiving:!1,processing:G});}catch{}}return {boardId:s,cardDefinitions:o,statusSnapshot:g(),dataObjectsByToken:d,cardRuntimeById:p,cardChatsByCardId:C}}function ie(o,n,d){let p=d?.syncBoard!==false,C=d?.restartOnlyIfChanged===true,S=$(o);if(!S)throw Object.assign(new Error(`Card not found: ${o}`),{statusCode:404});let O=D(o);if(!O)throw Object.assign(new Error(`Card not found: ${o}`),{statusCode:404});let q=C?JSON.stringify(O):null,G=n(O)||O;if(C&&JSON.stringify(G)===q)return;let ue=S.cardStore.set({body:G});if(ue.status!=="success")throw Object.assign(new Error(ue.error||`Failed to persist card: ${o}`),{statusCode:500});if(p){let de=S.board.upsertCard({params:{cardId:o,restart:true}});if(de.status!=="success")throw Object.assign(new Error(de.error||`Failed to upsert card: ${o}`),{statusCode:500})}}function Ie(o,n){ie(o,n,{syncBoard:true});}function he(o,n){ie(o,n,{syncBoard:false});}function Te(o){let n=$(o);if(!n)throw Object.assign(new Error(`Card not found: ${o}`),{statusCode:404});if(!D(o))throw Object.assign(new Error(`Card not found: ${o}`),{statusCode:404});let p=n.board.upsertCard({params:{cardId:o,restart:true}});if(p.status!=="success")throw Object.assign(new Error(p.error||`Failed to retrigger card: ${o}`),{statusCode:500})}function Ae(o,n){ie(o,d=>{if(!n||typeof n!="object"||Object.keys(n).length===0)return d;function p(C,S,O){let q=String(S||"").split(".").filter(Boolean);if(!q.length)return;let G=C;for(let ue=0;ue<q.length-1;ue++){let de=q[ue];(!G[de]||typeof G[de]!="object")&&(G[de]={}),G=G[de];}G[q[q.length-1]]=O;}if(n.fieldValues!==void 0&&n.fieldValues!==null){let C=null,S=d.view;if(S&&Array.isArray(S.elements)){for(let O of S.elements)if(O?.data&&O.data.writeTo){C=O.data.writeTo;break}}C?p(d,C,n.fieldValues):typeof n.fieldValues=="object"&&!Array.isArray(n.fieldValues)&&(d.card_data={...d.card_data||{},...n.fieldValues});}else {if(Array.isArray(n._stagedFiles)&&n._stagedFiles.length>0)return d;for(let[C,S]of Object.entries(n))C!=="_stagedFiles"&&(S!==null&&typeof S=="object"&&!Array.isArray(S)&&d[C]!==null&&typeof d[C]=="object"&&!Array.isArray(d[C])?d[C]={...d[C],...S}:d[C]=S);}return d},{syncBoard:true,restartOnlyIfChanged:true});}function Ue(o){let n=String(o||"").trim();if(!n)return "upload.bin";let d=Math.max(n.lastIndexOf("/"),n.lastIndexOf("\\"));return (d>=0?n.slice(d+1):n)||"upload.bin"}function Ge(o){u.clear(o),u.setProcessing(o,false);}function We(o,n,d,p,C=""){let S=typeof d=="string"?d.trim():"";return u.append(o,n,S,p,C)}function qe(o){return u.readAll(o)}function Ve(o){let n=[];try{let d=D(o);if(!d)return n;let p=w().read(d.card_data&&typeof d.card_data=="object"?d.card_data:null);for(let C of p)n.push(C.stored_name);}catch{}return n}function lt(o,n,d,p){let C=_(o),S=R(o),O=Ue(n),q=T(o),G=q?q.allocateStoredName(C,O,{seedNames:Ve(o),maxLen:Gn}):`${String(Date.now())}-${O}`;return S.files&&S.files.putBytes(`${C}/${G}`,new Uint8Array(p),d||"application/octet-stream"),{name:O,stored_name:G,size:p.length,mime_type:d||"application/octet-stream",uploaded_at:new Date().toISOString()}}function rt(o,n,d,p,C){if(!p.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let S=C?.inChat===true,O=lt(o,n,d,p),q=null;if(he(o,G=>{let ue=new Date().toISOString(),de=G.card_data&&typeof G.card_data=="object"?G.card_data:{};G.card_data=de;let le=w().normalizeIncoming([{name:O.name,stored_name:O.stored_name,size:O.size,mime_type:O.mime_type,uploaded_at:O.uploaded_at||ue,chat:S}],ue);return q=w().merge(de,le).findIndex(nt=>nt.stored_name===O.stored_name),G}),S){let G=typeof q=="number"&&q>=0?` #${q}`:"";We(o,"system",`file uploaded: ${O.name} as ${O.stored_name}${G}`,[],C?.turnId??"");}return {ok:true,file:O}}function st(o){let n=$(o);if(!n)return null;let d=n.board.getConfig({params:{key:"chat-handler-flow"}}),p=d.status==="success"?d.data?.value:null,C=n.chatHandlerRef;return p==null&&(!C||typeof C!="object")?null:{ctx:n,handlerFlow:p,handlerRef:C}}function St(o,n,d=false,p=""){let C=st(o);if(!C)return;let{ctx:S,handlerFlow:O,handlerRef:q}=C;if(!d)try{u.setProcessing(o,!0);}catch{}let G={boardId:s,cardId:String(o),lastChatEntryId:n,...p?{turnId:p}:{},...v,...b?{serverUrl:b}:{}};if(!c&&O!=null){try{u.setProcessing(o,!1);}catch{}a.warn(`[chat-handler-flow] configured for card "${o}" but no chatFlowRunner was provided`);return}if(O!=null){let de=c;if(!de)return;de.run(O,G,{boardId:s,cardId:String(o),label:S.label,logger:a,serverUrl:b,executionExtra:v}).then(le=>{if(le.dispatched)a.info(`[chat-handler-flow] invoked for card "${o}" (boardId: "${s}")`);else {try{u.setProcessing(o,!1);}catch{}a.warn(`[chat-handler-flow] dispatch failed for card "${o}": ${le.error||"unknown"}`);}},le=>{try{u.setProcessing(o,!1);}catch{}a.warn(`[chat-handler-flow] invoke failed for card "${o}": ${le?.message||String(le)}`);});return}let ue=q;ue&&i.invoke(ue,G).then(de=>{if(de.dispatched)a.info(`[chat-handler] invoked for card "${o}" (boardId: "${s}")`);else {try{u.setProcessing(o,!1);}catch{}a.warn(`[chat-handler] dispatch failed for card "${o}": ${de.error||"unknown"}`);}},de=>{try{u.setProcessing(o,!1);}catch{}a.warn(`[chat-handler] invoke failed for card "${o}": ${de?.message||String(de)}`);});}function Pt(o,n,d){let p=n==="chat-send"?he:Ie,C;p(o,S=>{let O=new Date().toISOString(),q=S.card_data&&typeof S.card_data=="object"?S.card_data:{};if(S.card_data=q,n==="chat-send"){let G=d&&typeof d.text=="string"?d.text.trim():"",ue=d&&typeof d["turn-id"]=="string"?d["turn-id"]:d&&typeof d.turnId=="string"?d.turnId:d&&typeof d.turn=="string"?d.turn:"",de=[];if(Array.isArray(d?.files)){for(let le of d.files)if(le){if(typeof le=="string"){de.push({name:le});continue}if(typeof le=="object"){let xe=le;typeof xe.name=="string"&&de.push({name:xe.name,size:xe.size,mime_type:xe.mime_type,uploaded_at:xe.uploaded_at,stored_name:xe.stored_name,chat:xe.chat===true});}}}if(G||de.length>0){let le=m.runBatch({cardId:o,commands:[{command:"append",role:"user",text:G,files:de,turn:ue},{command:"set-processing",active:true}]});if(le.status!=="success")throw new Error(le.error);let xe=le.data.results[0]?.data?.id;if(typeof xe!="string"||!xe)throw new Error(`chat-send did not return an append id for card ${o}`);C={cardId:o,lastEntryId:xe,processingAlreadySet:true,turnId:ue};try{let gt=qe(o);Jt([{kind:"card_chats",cardId:o,messages:gt.map(K=>({role:String(K.role||"system"),text:String(K.text||""),files:Array.isArray(K.files)?K.files:[]})),receiving:!0,processing:u.isProcessing(o)}]);}catch{}}return S}if(n==="file-upload"){let G=w().normalizeIncoming(d?.files,O);return G.length>0&&w().merge(q,G),S}if(n==="action"){let G=d&&typeof d.buttonId=="string"?d.buttonId:"";if(!G)return S;q.lastAction={buttonId:G,at:O},q.lastActionText=`${G} @ ${O}`;}return S}),C&&St(C.cardId,C.lastEntryId,C.processingAlreadySet,C.turnId??"");}function ee(o,n,d){let p=JSON.stringify(d),C=typeof Buffer<"u"?Buffer.byteLength(p):new TextEncoder().encode(p).length;o.writeHead(n,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":C}),o.end(p);}function $t(o,n,d){let p=D(o);if(!p)throw Object.assign(new Error("Card not found"),{statusCode:404});let C=w().resolve(p.card_data,n,d);if(!C.ok&&C.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!C.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let S=C.file,O=_(o),q=R(o),G=String(S.stored_name||""),ue=`${O}/${G}`,de=q.files?q.files.getBytes(ue):null;if(!de)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:S,bytes:de}}function Dt(o,n,d,p){let{fileRecord:C,bytes:S}=$t(n,d,p),O=String(C.name||C.stored_name||"download.bin"),q=String(C.mime_type||"application/octet-stream");o.writeHead(200,{"Content-Type":q,"Content-Disposition":`attachment; filename="${O}"`,"Content-Length":S.length}),o.end(S);}function at(o){let n=String(o||"").toLowerCase();return n.startsWith("text/")||n.includes("json")||n.includes("xml")||n.includes("javascript")||n.includes("typescript")||n.includes("yaml")||n.includes("csv")}function ft(o,n,d){let p=o.split(/\r?\n/);return (n==="head"?p.slice(0,d):p.slice(-d)).join(`
|
|
2
|
+
`)}async function $e(o){let n=[];for await(let p of o)n.push(p);let d=typeof Buffer<"u"?Buffer.concat(n).toString("utf-8").trim():new TextDecoder().decode(Ke(n)).trim();return d?JSON.parse(d):{}}async function it(o){let n=[];for await(let d of o)n.push(d);return typeof Buffer<"u"?Buffer.concat(n):Ke(n)}function Ke(o){let n=o.reduce((C,S)=>C+S.length,0),d=new Uint8Array(n),p=0;for(let C of o)d.set(C,p),p+=C.length;return d}let wt=0;function P(o){let n=JSON.stringify(o);return wt++,`id: ${wt}
|
|
3
|
+
data: ${n}
|
|
3
4
|
|
|
4
|
-
`}function
|
|
5
|
+
`}function z(o){let n=o;try{n.flushHeaders?.();}catch{}try{n.flush?.();}catch{}try{n.socket?.setNoDelay?.(!0);}catch{}try{n.socket?.uncork?.();}catch{}}function fe(o,n){let d=E.get(o);if(d&&!(n&&d.res!==n)){E.delete(o),Lt();try{J?.(o);}catch{}try{d.res.end();}catch{}}}function Fe(o,n){let d=E.get(o);if(!d)return;let p=P(n);try{d.res.write(p),z(d.res);}catch{fe(o,d.res);}}function je(o,n,d,p,C){if(!E.has(n)){ee(o,404,{error:`SSE client not connected: ${n}`});return}C?A?.(n,d,p):B?.(n,d,p),ee(o,200,{ok:true,clientId:n,channelName:d,...p.cardId?{cardId:p.cardId}:{},subscribed:C});}function Ye(){let o=new Set;for(let n of E.values())for(let d of n.subscribedChatCardIds)o.add(d);return Array.from(o)}function Xe(o){let n=V.has(o)?V.get(o):null,{cursor:d}=u.readAfter(o,n),p=u.isProcessing(o),C=p!==(Y.get(o)??false),S=d!==n;return S&&V.set(o,d),Y.set(o,p),S||C}function pt(o,n=true){let d=qe(o),p=Date.now();return {kind:"card_chats",cardId:o,sentAt:new Date(p).toISOString(),sentAtMs:p,messages:d.map(C=>({role:String(C.role||"system"),text:String(C.text||""),files:Array.isArray(C.files)?C.files:[]})),receiving:n,processing:u.isProcessing(o)}}function qt(o,n=true){let d={kind:"notification-batch",notifications:[pt(o,n)]};for(let[p,C]of E.entries())C.subscribedChatCardIds.has(o)&&Fe(p,d);}function Lt(){Ye().length>0||(x&&(clearInterval(x),x=null),V.clear(),Y.clear());}function Hr(){if(x)return;let o=()=>{let n=Ye();if(n.length===0){Lt();return}let d=new Set(n);for(let p of Array.from(V.keys()))d.has(p)||V.delete(p);for(let p of Array.from(Y.keys()))d.has(p)||Y.delete(p);for(let p of n)Xe(p)&&qt(p,true);};o(),x=setInterval(o,1e3);}function Jr(o,n){let d=E.get(o);if(!d)return false;d.subscribedChatCardIds.add(n);let{cursor:p}=u.readAfter(n,null);return V.set(n,p),Y.set(n,u.isProcessing(n)),Hr(),Fe(o,{kind:"notification-batch",notifications:[pt(n,true)]}),true}function zr(o,n){let d=E.get(o);return d?(d.subscribedChatCardIds.delete(n),Ye().includes(n)||(V.delete(n),Y.delete(n)),Lt(),true):false}function Wr(o){if(!o||typeof o!="object")return false;let n=o.kind;return n==="card_chats"||n==="chat_messages"}function Jt(o){if(!o||o.length===0)return;let n=[],d=new Set;for(let p of o)Wr(p)&&typeof p.cardId=="string"?d.add(String(p.cardId)):n.push(p);if(n.length>0){let p={kind:"notification-batch",notifications:n};for(let C of E.keys())Fe(C,p);}for(let p of d)qt(p,true);}function Yr(o,n,d){let p=E.get(d),C=p?new Set(p.subscribedChatCardIds):new Set;p&&fe(d,p.res),n.writeHead(200,{...r,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),z(n),E.set(d,{res:n,subscribedChatCardIds:C});let S=Q(),O=P(S);n.write(O);try{M?.(d,G=>{Fe(d,G);});}catch{}let q=setInterval(()=>{try{n.write(`: keepalive
|
|
5
6
|
|
|
6
|
-
`);}catch{}},15e3);o.on("close",()=>{clearInterval(B),$e(d,i);});}async function v(o,i,d){let p=o.method||"GET",h=d,k=h.pathname;try{if(p==="GET"&&k===`${t}/init-board`)return await we(),q(i,200,De()),!0;if(p==="GET"&&k===`${t}/sse`){await we();let V=String(h.searchParams.get("clientId")||"").trim();if(!V)return q(i,400,{error:"clientId query param is required for SSE"}),!0;Rt(o,i,V);for(let M=0;M<I.length;M++)Ce(I[M]),Pe(I[M],M);return !0}if(p==="GET"&&k===`${t}/board-status`)return q(i,200,De()),!0;let j=k.match(new RegExp(`^${ke(t)}/cards/([^/]+)$`));if(p==="GET"&&j){await le();let V=decodeURIComponent(j[1]),M=D(V);return M?(q(i,200,M),!0):(q(i,404,{error:`card not found: ${V}`}),!0)}if(p==="PATCH"&&j){await le();let V=decodeURIComponent(j[1]),M=await ne(o);return yt(V,M),q(i,200,{ok:!0}),!0}let B=k.match(new RegExp(`^${ke(t)}/cards/([^/]+)/retrigger$`));if(p==="POST"&&B){await le();let V=decodeURIComponent(B[1]);return Xe(V),q(i,200,{ok:!0}),!0}let $=k.match(new RegExp(`^${ke(t)}/cards/([^/]+)/actions$`));if(p==="POST"&&$){await le();let V=decodeURIComponent($[1]),M=Date.now(),ee=new Date(M).toISOString(),ce=await ne(o),de=ce?.actionType;if(de==="chat-send"&&!K(V)){let Ie=Date.now();return q(i,409,{error:`chat handler is not configured for card: ${V}`,requestReceivedAt:ee,requestReceivedAtMs:M,responseSentAt:new Date(Ie).toISOString(),responseSentAtMs:Ie,responseStatus:409}),!0}Q(V,de,ce?.payload);let me=Date.now();return q(i,200,{ok:!0,requestReceivedAt:ee,requestReceivedAtMs:M,responseSentAt:new Date(me).toISOString(),responseSentAtMs:me,responseStatus:200}),!0}let J=k.match(new RegExp(`^${ke(t)}/cards/([^/]+)/chats$`));if(p==="GET"&&J){await le();let V=decodeURIComponent(J[1]);return q(i,200,{ok:!0,messages:w(V)}),!0}if(p==="POST"&&J){await le();let V=decodeURIComponent(J[1]),M=await ne(o),ee=typeof M?.role=="string"?M.role:"assistant",ce=typeof M?.text=="string"?M.text:"",de=Array.isArray(M?.files)?M.files:[],me=M?.done===!0,Ie=c.append(V,ee,ce,de);return me&&c.setProcessing(V,!1),Ze(V,!me),q(i,200,{ok:!0,id:Ie}),!0}let Z=k.match(new RegExp(`^${ke(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(p==="POST"&&Z){await le();let V=decodeURIComponent(Z[1]),M=await ne(o),ee=typeof M?.clientId=="string"?M.clientId.trim():"";return ee?et(ee,V)?(q(i,200,{ok:!0,clientId:ee,cardId:V,subscribed:!0}),!0):(q(i,404,{error:`SSE client not connected: ${ee}`}),!0):(q(i,400,{error:"clientId is required"}),!0)}let fe=k.match(new RegExp(`^${ke(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(p==="POST"&&fe){await le();let V=decodeURIComponent(fe[1]),M=await ne(o),ee=typeof M?.clientId=="string"?M.clientId.trim():"";return ee?St(ee,V)?(q(i,200,{ok:!0,clientId:ee,cardId:V,subscribed:!1}),!0):(q(i,404,{error:`SSE client not connected: ${ee}`}),!0):(q(i,400,{error:"clientId is required"}),!0)}let tt=k.match(new RegExp(`^${ke(t)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&tt){await le();let V=decodeURIComponent(tt[1]),M=tt[2]==="subscribe",ee=await ne(o),ce=typeof ee?.clientId=="string"?ee.clientId.trim():"";return ce?(Be(i,ce,V,{},M),!0):(q(i,400,{error:"clientId is required"}),!0)}let Ke=k.match(new RegExp(`^${ke(t)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&Ke){await le();let V=decodeURIComponent(Ke[1]),M=decodeURIComponent(Ke[2]),ee=Ke[3]==="subscribe",ce=await ne(o),de=typeof ce?.clientId=="string"?ce.clientId.trim():"";return de?(Be(i,de,M,{cardId:V},ee),!0):(q(i,400,{error:"clientId is required"}),!0)}let rt=k.match(new RegExp(`^${ke(t)}/cards/([^/]+)/files$`));if(p==="POST"&&rt){await le();let V=decodeURIComponent(rt[1]),M=String(h.searchParams.get("inChat")||"").toLowerCase()==="true",ee=o.headers["x-file-name"],ce=String(o.headers["content-type"]||"application/octet-stream"),de=Array.isArray(ee)?ee[0]:ee,me=de?decodeURIComponent(String(de)):"upload.bin",Ie=await xe(o);if(!Ie.length)return q(i,400,{error:"Empty upload body"}),!0;let he=G(V,me,ce,Ie),Ve=null;if(Ue(V,ye=>{let nt=new Date().toISOString(),ot=ye.card_data&&typeof ye.card_data=="object"?ye.card_data:{};ye.card_data=ot;let br=H().normalizeIncoming([{name:he.name,stored_name:he.stored_name,size:he.size,mime_type:he.mime_type,uploaded_at:he.uploaded_at||nt,chat:M}],nt);return Ve=H().merge(ot,br).findIndex(wr=>wr.stored_name===he.stored_name),ye}),M){let ye=typeof Ve=="number"&&Ve>=0?` #${Ve}`:"";l(V,"system",`file uploaded: ${he.name} as ${he.stored_name}${ye}`,[]);}return q(i,200,{ok:!0,file:he}),!0}let Oe=k.match(new RegExp(`^${ke(t)}/cards/([^/]+)/files/(\\d+)$`));if(p==="GET"&&Oe){let V=decodeURIComponent(Oe[1]),M=parseInt(Oe[2],10),ee=h.searchParams.get("sn"),ce=D(V);if(!ce)return q(i,404,{error:"Card not found"}),!0;let de=H().resolve(ce.card_data,M,ee);if(!de.ok&&de.reason==="stale_reference")return q(i,409,{error:"File reference is stale. Refresh and try again."}),!0;if(!de.ok)return q(i,404,{error:"File not found"}),!0;let me=de.file,Ie=W(V),he=E(V),Ve=`${Ie}/${me.stored_name}`,ye=he.files?he.files.getBytes(Ve):null;if(!ye)return q(i,404,{error:"File not found"}),!0;let nt=me.name||me.stored_name,ot=me.mime_type||"application/octet-stream";return i.writeHead(200,{"Content-Type":ot,"Content-Disposition":`attachment; filename="${nt}"`,"Content-Length":ye.length}),i.end(ye),!0}return !1}catch(j){let B=j?.statusCode||500;return q(i,B,{error:String(j?.message||j)}),true}}return {get apiBasePath(){return t},get corsHeaders(){return r},handleRuntimeApi:v,buildPublishedRuntimePayload:De,clearChatRecords:C,reportSourceFetched(o,i){let d=I[0];return d?d.board.sourceDataFetched({params:{token:o,ref:i}}):{status:"fail",error:"no board context"}},reportSourceFetchFailure(o,i){let d=I[0];return d?d.board.sourceDataFetchFailure({params:{token:o,reason:i}}):{status:"fail",error:"no board context"}},get cardStore(){return I[0]?.cardStore??{set(){return {status:"fail",error:"no board context"}}}}}}function ko(e){let t=String(e.apiBasePath||"/api/boards").replace(/\/$/,""),r={...Cr,...e.corsHeaders||{}},n=e.serverMetaStore,s=e.boardRuntimeFactory,a=new Map,u="boards-config.json";function c(){let b=n.getText(u);if(!b)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(b)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function f(b){n.putText(u,JSON.stringify(b,null,2));}function g(b){let N=String(b||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return N.length>0&&N.length<=64?N:null}function m(b){if(a.has(b))return a.get(b);let L=c().boards.find(T=>T.id===b)||{},y=s(b,L);return a.set(b,y),y}function R(b,N,L){let y=JSON.stringify(L),T=typeof Buffer<"u"?Buffer.byteLength(y):new TextEncoder().encode(y).length;b.writeHead(N,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":T}),b.end(y);}async function O(b,N,L){let y=b.method||"GET",T=L.pathname;if(y==="GET"&&T===t)return R(N,200,{ok:true,boards:c().boards}),true;if(y==="POST"&&T===t){let I=[];for await(let oe of b)I.push(oe);let U=typeof Buffer<"u"?Buffer.concat(I).toString("utf-8").trim():new TextDecoder().decode(pn(I)).trim(),A={};try{A=U?JSON.parse(U):{};}catch{A={};}let E=g(A.id);if(!E)return R(N,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let z=c();if(z.boards.some(oe=>oe.id===E))return R(N,409,{error:`Board "${E}" is already registered`}),true;let H=typeof A.label=="string"&&A.label.trim()?A.label.trim():E,W={id:E,label:H};for(let[oe,se]of Object.entries(A))oe==="id"||oe==="label"||se!=null&&(W[oe]=se);return z.boards.push(W),f(z),R(N,200,{ok:true,board:W}),true}return false}async function F(b,N,L){let T=L.pathname.match(new RegExp(`^${ke(t)}/([^/]+)(/|$)`));if(!T)return false;let I=g(decodeURIComponent(T[1]));return I?c().boards.some(E=>E.id===I)?!!await m(I).handleRuntimeApi(b,N,L):(R(N,404,{error:`Board "${I}" not registered. POST ${t} with {id} to register it first.`}),true):(R(N,400,{error:"Invalid board id"}),true)}async function S(b,N,L){return !!(await O(b,N,L)||await F(b,N,L))}function x(b){if(!c().boards.some(L=>L.id===b))throw Object.assign(new Error(`Board "${b}" not registered`),{statusCode:404});return {service:m(b)}}return {get apiBasePath(){return t},get corsHeaders(){return r},handleApi:S,requireBoardService:x}}function ke(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function pn(e){let t=e.reduce((s,a)=>s+a.length,0),r=new Uint8Array(t),n=0;for(let s of e)r.set(s,n),n+=s.length;return r}export{ko as createMultiBoardServerRuntime,yo as createSingleBoardServerRuntime};//# sourceMappingURL=board-live-cards-server-runtime.js.map
|
|
7
|
+
`);}catch{}},15e3);o.on("close",()=>{clearInterval(q),fe(d,n);});}async function Xr(o,n,d){let p=o.method||"GET",C=d,S=C.pathname;try{if(p==="GET"&&S===`${t}/init-board`)return await ye(),ee(n,200,Q()),!0;if(p==="GET"&&S===`${t}/sse`){await ye();let K=String(C.searchParams.get("clientId")||"").trim();if(!K)return ee(n,400,{error:"clientId query param is required for SSE"}),!0;Yr(o,n,K);for(let W=0;W<k.length;W++)X(k[W]),ce(k[W],W);return !0}if(p==="GET"&&S===`${t}/board-status`)return ee(n,200,Q()),!0;if(p==="POST"&&S===`${t}/mcp`){await N();let K=await $e(o),W=typeof K.tool=="string"?K.tool.trim():"",ae=K.args&&typeof K.args=="object"&&!Array.isArray(K.args)?K.args:{};return W?W==="inspect.file-contents"?(ee(n,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0):(ee(n,200,I(W,ae)),!0):(ee(n,400,{error:"tool is required"}),!0)}if(p==="POST"&&S===`${t}/mcp-raw`){await N();let K=await $e(o),W=typeof K.tool=="string"?K.tool.trim():"",ae=K.args&&typeof K.args=="object"&&!Array.isArray(K.args)?K.args:{};if(!W)return ee(n,400,{error:"tool is required"}),!0;if(W!=="inspect.file-contents")return ee(n,400,{error:`Tool does not support raw response: ${W}`}),!0;let Re=me(ae,"card_id","cardId"),we=ke(ae,"file_idx","fileIdx"),be=ke(ae,"head-lines","headLines"),Oe=ke(ae,"tail-lines","tailLines"),Le=ke(ae,"head-bytes","headBytes"),Me=ke(ae,"tail-bytes","tailBytes");if(!Re)return ee(n,400,{error:"inspect.file-contents requires card_id"}),!0;if(we===void 0||!Number.isInteger(we)||we<0)return ee(n,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([be,Oe,Le,Me].filter(Je=>Je!==void 0).length>1)return ee(n,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[Je,ze]of [["head-lines",be],["tail-lines",Oe],["head-bytes",Le],["tail-bytes",Me]])if(ze!==void 0&&(!Number.isInteger(ze)||ze<0))return ee(n,400,{error:`inspect.file-contents requires ${Je} to be a non-negative integer`}),!0;let dt=Se().inspectFileContents({cardId:Re,fileIdx:we}),ct=typeof dt?.stored_name=="string"?dt.stored_name:null,{fileRecord:ht,bytes:yt}=$t(Re,we,ct),He=String(ht.name||ht.stored_name||"download.bin"),Ze=String(ht.mime_type||"application/octet-stream");if(be!==void 0||Oe!==void 0){if(!at(Ze))return ee(n,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let Je=new TextDecoder().decode(yt),ze=be!==void 0?ft(Je,"head",be):ft(Je,"tail",Oe),zt=typeof Buffer<"u"?Buffer.from(ze,"utf8"):new TextEncoder().encode(ze);return n.writeHead(200,{"Content-Type":Ze,"Content-Disposition":`attachment; filename="${He}"`,"Content-Length":zt.length}),n.end(zt),!0}if(Le!==void 0||Me!==void 0){let Je=Le??Me,ze=Le!==void 0?yt.slice(0,Je):yt.slice(Math.max(0,yt.length-Je));return n.writeHead(200,{"Content-Type":Ze,"Content-Disposition":`attachment; filename="${He}"`,"Content-Length":ze.length}),n.end(ze),!0}return Dt(n,Re,we,ct),!0}let O=S.match(new RegExp(`^${De(t)}/cards/([^/]+)$`));if(p==="GET"&&O){await N();let K=decodeURIComponent(O[1]),W=D(K);return W?(ee(n,200,W),!0):(ee(n,404,{error:`card not found: ${K}`}),!0)}if(p==="PATCH"&&O){await N();let K=decodeURIComponent(O[1]),W=await $e(o);return Ae(K,W),ee(n,200,{ok:!0}),!0}let q=S.match(new RegExp(`^${De(t)}/cards/([^/]+)/retrigger$`));if(p==="POST"&&q){await N();let K=decodeURIComponent(q[1]);return Te(K),ee(n,200,{ok:!0}),!0}let G=S.match(new RegExp(`^${De(t)}/cards/([^/]+)/actions$`));if(p==="POST"&&G){await N();let K=decodeURIComponent(G[1]),W=Date.now(),ae=new Date(W).toISOString(),Re=await $e(o),we=Re?.actionType;if(we==="chat-send"&&!st(K)){let Oe=Date.now();return ee(n,409,{error:`chat handler is not configured for card: ${K}`,requestReceivedAt:ae,requestReceivedAtMs:W,responseSentAt:new Date(Oe).toISOString(),responseSentAtMs:Oe,responseStatus:409}),!0}Pt(K,we,Re?.payload);let be=Date.now();return ee(n,200,{ok:!0,requestReceivedAt:ae,requestReceivedAtMs:W,responseSentAt:new Date(be).toISOString(),responseSentAtMs:be,responseStatus:200}),!0}let ue=S.match(new RegExp(`^${De(t)}/cards/([^/]+)/chats$`));if(p==="GET"&&ue){await N();let K=decodeURIComponent(ue[1]),W=String(C.searchParams.get("turn-id")||""),ae=String(C.searchParams.get("all-turns")||"").toLowerCase()==="true",Re=String(C.searchParams.get("tail-turns-before-id")||""),we=C.searchParams.get("tail-turns"),be=we==null||we===""?ae||W?void 0:1:Number.parseInt(we,10),Oe=be===void 0?m.readAll({params:{cardId:K}}):m.readAll({params:{cardId:K},body:{lastUserTurns:be}});if(Oe.status!=="success")return ee(n,400,{error:Oe.error||"Failed to read chats"}),!0;let Le=Oe.data.records.filter(Me=>!W||String(Me.turn||"")===W);if(Re){if(be===void 0||!Number.isInteger(be)||be<=0)return ee(n,400,{error:"tail-turns is required when tail-turns-before-id is provided"}),!0;let Me=m.readAll({params:{cardId:K}});if(Me.status!=="success")return ee(n,400,{error:Me.error||"Failed to read chats"}),!0;let mt=new Map,dt=[];for(let He of Me.data.records){let Ze=String(He.turn||"");mt.has(Ze)||(mt.set(Ze,[]),dt.push(Ze)),mt.get(Ze).push(He);}let ct=dt.findIndex(He=>He===Re),ht=Math.max(0,ct-be);Le=(ct===-1?[]:dt.slice(ht,ct)).flatMap(He=>mt.get(He)??[]);}return ee(n,200,{ok:!0,messages:Le}),!0}if(p==="POST"&&ue){await N();let K=decodeURIComponent(ue[1]),W=await $e(o),ae=typeof W?.role=="string"?W.role:"assistant",Re=typeof W?.text=="string"?W.text:"",we=Array.isArray(W?.files)?W.files:[],be=W?.done===!0,Oe=u.append(K,ae,Re,we);return be&&u.setProcessing(K,!1),qt(K,!be),ee(n,200,{ok:!0,id:Oe}),!0}let de=S.match(new RegExp(`^${De(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(p==="POST"&&de){await N();let K=decodeURIComponent(de[1]),W=await $e(o),ae=typeof W?.clientId=="string"?W.clientId.trim():"";return ae?Jr(ae,K)?(ee(n,200,{ok:!0,clientId:ae,cardId:K,subscribed:!0}),!0):(ee(n,404,{error:`SSE client not connected: ${ae}`}),!0):(ee(n,400,{error:"clientId is required"}),!0)}let le=S.match(new RegExp(`^${De(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(p==="POST"&&le){await N();let K=decodeURIComponent(le[1]),W=await $e(o),ae=typeof W?.clientId=="string"?W.clientId.trim():"";return ae?zr(ae,K)?(ee(n,200,{ok:!0,clientId:ae,cardId:K,subscribed:!1}),!0):(ee(n,404,{error:`SSE client not connected: ${ae}`}),!0):(ee(n,400,{error:"clientId is required"}),!0)}let xe=S.match(new RegExp(`^${De(t)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&xe){await N();let K=decodeURIComponent(xe[1]),W=xe[2]==="subscribe",ae=await $e(o),Re=typeof ae?.clientId=="string"?ae.clientId.trim():"";return Re?(je(n,Re,K,{},W),!0):(ee(n,400,{error:"clientId is required"}),!0)}let nt=S.match(new RegExp(`^${De(t)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&nt){await N();let K=decodeURIComponent(nt[1]),W=decodeURIComponent(nt[2]),ae=nt[3]==="subscribe",Re=await $e(o),we=typeof Re?.clientId=="string"?Re.clientId.trim():"";return we?(je(n,we,W,{cardId:K},ae),!0):(ee(n,400,{error:"clientId is required"}),!0)}let Mt=S.match(new RegExp(`^${De(t)}/cards/([^/]+)/files$`));if(p==="POST"&&Mt){await N();let K=decodeURIComponent(Mt[1]),W=String(C.searchParams.get("inChat")||"").toLowerCase()==="true",ae=String(C.searchParams.get("turn-id")||""),Re=o.headers["x-file-name"],we=String(o.headers["content-type"]||"application/octet-stream"),be=Array.isArray(Re)?Re[0]:Re,Oe=be?decodeURIComponent(String(be)):"upload.bin",Le=await it(o);return ee(n,200,rt(K,Oe,we,Le,{inChat:W,turnId:ae})),!0}let gt=S.match(new RegExp(`^${De(t)}/cards/([^/]+)/files/(\\d+)$`));if(p==="GET"&>){let K=decodeURIComponent(gt[1]),W=parseInt(gt[2],10),ae=C.searchParams.get("sn");return Dt(n,K,W,ae),!0}return !1}catch(O){let q=O?.statusCode||500;return ee(n,q,{error:String(O?.message||O)}),true}}return {get apiBasePath(){return t},get corsHeaders(){return r},handleRuntimeApi:Xr,buildPublishedRuntimePayload:Q,clearChatRecords:Ge,reportSourceFetched(o,n){let d=k[0];return d?d.board.sourceDataFetched({params:{token:o,ref:n}}):{status:"fail",error:"no board context"}},reportSourceFetchFailure(o,n){let d=k[0];return d?d.board.sourceDataFetchFailure({params:{token:o,reason:n}}):{status:"fail",error:"no board context"}},get cardStore(){return k[0]?.cardStore??{set(){return {status:"fail",error:"no board context"}}}}}}function Xo(e){let t=String(e.apiBasePath||"/api/boards").replace(/\/$/,""),r={...Gr,...e.corsHeaders||{}},s=e.serverMetaStore,a=e.boardRuntimeFactory,i=new Map,c="boards-config.json";function u(){let E=s.getText(c);if(!E)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(E)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function m(E){s.putText(c,JSON.stringify(E,null,2));}function h(E){let V=String(E||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return V.length>0&&V.length<=64?V:null}function b(E){if(i.has(E))return i.get(E);let Y=u().boards.find(L=>L.id===E)||{},x=a(E,Y);return i.set(E,x),x}function v(E,V,Y){let x=JSON.stringify(Y),L=typeof Buffer<"u"?Buffer.byteLength(x):new TextEncoder().encode(x).length;E.writeHead(V,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":L}),E.end(x);}async function M(E,V,Y){let x=E.method||"GET",L=Y.pathname;if(x==="GET"&&L===t)return v(V,200,{ok:true,boards:u().boards}),true;if(x==="POST"&&L===t){let k=[];for await(let _ of E)k.push(_);let y=typeof Buffer<"u"?Buffer.concat(k).toString("utf-8").trim():new TextDecoder().decode(Kn(k)).trim(),l={};try{l=y?JSON.parse(y):{};}catch{l={};}let f=h(l.id);if(!f)return v(V,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let R=u();if(R.boards.some(_=>_.id===f))return v(V,409,{error:`Board "${f}" is already registered`}),true;let T=typeof l.label=="string"&&l.label.trim()?l.label.trim():f,w={id:f,label:T};for(let[_,F]of Object.entries(l))_==="id"||_==="label"||F!=null&&(w[_]=F);return R.boards.push(w),m(R),v(V,200,{ok:true,board:w}),true}return false}async function J(E,V,Y){let L=Y.pathname.match(new RegExp(`^${De(t)}/([^/]+)(/|$)`));if(!L)return false;let k=h(decodeURIComponent(L[1]));return k?u().boards.some(f=>f.id===k)?!!await b(k).handleRuntimeApi(E,V,Y):(v(V,404,{error:`Board "${k}" not registered. POST ${t} with {id} to register it first.`}),true):(v(V,400,{error:"Invalid board id"}),true)}async function A(E,V,Y){return !!(await M(E,V,Y)||await J(E,V,Y))}function B(E){if(!u().boards.some(Y=>Y.id===E))throw Object.assign(new Error(`Board "${E}" not registered`),{statusCode:404});return {service:b(E)}}return {get apiBasePath(){return t},get corsHeaders(){return r},handleApi:A,requireBoardService:B}}function De(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Kn(e){let t=e.reduce((a,i)=>a+i.length,0),r=new Uint8Array(t),s=0;for(let a of e)r.set(a,s),s+=a.length;return r}export{Xo as createMultiBoardServerRuntime,Yo as createSingleBoardServerRuntime};//# sourceMappingURL=board-live-cards-server-runtime.js.map
|
|
7
8
|
//# sourceMappingURL=board-live-cards-server-runtime.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { a as CommandInput, C as CommandResult, L as LiveCard, b as CardAdminStore } from './board-live-cards-public-CvkDfZQ7.cjs';
|
|
2
2
|
import './storage-interface-B2WD9D5n.cjs';
|
|
3
3
|
import './execution-refs.cjs';
|
|
4
4
|
import './types-BBhqYGhE.cjs';
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { a as CommandInput, C as CommandResult, L as LiveCard, b as CardAdminStore } from './board-live-cards-public-DdVhH4M-.js';
|
|
2
2
|
import './storage-interface-B2WD9D5n.js';
|
|
3
3
|
import './execution-refs.js';
|
|
4
4
|
import './types-BBhqYGhE.js';
|
|
@@ -15,6 +15,7 @@ interface ChatRecord {
|
|
|
15
15
|
role: string;
|
|
16
16
|
text: string;
|
|
17
17
|
files: unknown[];
|
|
18
|
+
turn: string;
|
|
18
19
|
updated_at: string;
|
|
19
20
|
}
|
|
20
21
|
interface ChatConfig {
|
|
@@ -27,7 +28,7 @@ interface ChatReadAfterResult {
|
|
|
27
28
|
}
|
|
28
29
|
interface ChatStorage {
|
|
29
30
|
/** Append a message; returns the new entry id (usable as a cursor). */
|
|
30
|
-
append(cardId: string, role: string, text: string, files?: unknown[]): string;
|
|
31
|
+
append(cardId: string, role: string, text: string, files?: unknown[], turn?: string): string;
|
|
31
32
|
/** Read all messages in insertion order. */
|
|
32
33
|
readAll(cardId: string): ChatRecord[];
|
|
33
34
|
/**
|
|
@@ -15,6 +15,7 @@ interface ChatRecord {
|
|
|
15
15
|
role: string;
|
|
16
16
|
text: string;
|
|
17
17
|
files: unknown[];
|
|
18
|
+
turn: string;
|
|
18
19
|
updated_at: string;
|
|
19
20
|
}
|
|
20
21
|
interface ChatConfig {
|
|
@@ -27,7 +28,7 @@ interface ChatReadAfterResult {
|
|
|
27
28
|
}
|
|
28
29
|
interface ChatStorage {
|
|
29
30
|
/** Append a message; returns the new entry id (usable as a cursor). */
|
|
30
|
-
append(cardId: string, role: string, text: string, files?: unknown[]): string;
|
|
31
|
+
append(cardId: string, role: string, text: string, files?: unknown[], turn?: string): string;
|
|
31
32
|
/** Read all messages in insertion order. */
|
|
32
33
|
readAll(cardId: string): ChatRecord[];
|
|
33
34
|
/**
|