yaml-flow 8.1.1 → 8.2.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/browser/board-livecards-localstorage.js +5 -5
- package/cli/browser-api/board-live-cards-browser-adapter.d.ts +1 -1
- package/cli/node/board-live-cards-cli.js +6 -6
- package/cli/node/card-store-cli.js +4 -4
- package/cli/node/fs-board-adapter.d.ts +2 -2
- package/cli/node/fs-board-adapter.js +7 -7
- package/cli/node/step-machine-cli.js +3 -3
- package/cli/{types-D2XnLbBj.d.ts → types-CSiGbY__.d.ts} +1 -1
- package/examples/board/demo-chat-copilot.flow.json +38 -0
- package/examples/board/{demo-chat-handler.js → demo-chat-copilot.js} +55 -39
- package/examples/board/demo-chat-echo.flow.json +38 -0
- package/examples/board/demo-chat-echo.js +92 -0
- package/examples/board/demo-server-config.copilot-chat.json +10 -0
- package/examples/board/demo-server-config.json +2 -2
- package/examples/board/demo-server.js +57 -8
- package/examples/board/demo-shell-with-server.html +2 -2
- package/examples/board/test/demo-http-test.js +45 -0
- package/examples/board-local/demo-shell-localstorage.html +3 -3
- package/lib/{artifacts-store-lib-public-BWC3YuLa.d.ts → artifacts-store-lib-public-BPW_C15z.d.ts} +1 -1
- package/lib/{artifacts-store-lib-public-DBICnGL6.d.cts → artifacts-store-lib-public-DfU9t5-S.d.cts} +1 -1
- package/lib/artifacts-store-public.d.cts +2 -2
- package/lib/artifacts-store-public.d.ts +2 -2
- package/lib/board-live-cards-node.cjs +7 -7
- package/lib/board-live-cards-node.d.cts +5 -5
- package/lib/board-live-cards-node.d.ts +5 -5
- package/lib/board-live-cards-node.js +7 -7
- package/lib/{board-live-cards-public-dJAl5IL-.d.ts → board-live-cards-public-B8b_0k_j.d.ts} +1 -1
- package/lib/{board-live-cards-public-BF9FP0mL.d.cts → board-live-cards-public-W2zK59m0.d.cts} +1 -1
- package/lib/board-live-cards-public.cjs +2 -2
- 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 +2 -2
- package/lib/board-live-cards-server-runtime.cjs +5 -5
- package/lib/board-live-cards-server-runtime.d.cts +2 -2
- package/lib/board-live-cards-server-runtime.d.ts +2 -2
- package/lib/board-live-cards-server-runtime.js +5 -5
- package/lib/card-store-public.d.cts +1 -1
- package/lib/card-store-public.d.ts +1 -1
- package/lib/server-runtime/index.cjs +5 -5
- package/lib/server-runtime/index.d.cts +3 -3
- package/lib/server-runtime/index.d.ts +3 -3
- package/lib/server-runtime/index.js +5 -5
- package/lib/step-machine-public/index.cjs +3 -3
- package/lib/step-machine-public/index.d.cts +26 -9
- package/lib/step-machine-public/index.d.ts +26 -9
- package/lib/step-machine-public/index.js +3 -3
- package/lib/{types-D48hpnTR.d.ts → types-Bm7IFD7r.d.ts} +22 -2
- package/lib/{types-CXBzvC0s.d.cts → types-seTI8zta.d.cts} +22 -2
- package/package.json +1 -1
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
{
|
|
2
|
-
"generatedAt": "2026-05-
|
|
2
|
+
"generatedAt": "2026-05-15T21:41:59.391Z",
|
|
3
3
|
"algorithm": "sha256",
|
|
4
4
|
"files": {
|
|
5
5
|
"browser/board-livecards-localstorage.js": {
|
|
6
|
-
"sha256": "sha256-
|
|
7
|
-
"bytes":
|
|
6
|
+
"sha256": "sha256-tNQN+zCYqhEofqkwja7NJsTkkW9nikRqwwJLr0q2AH4=",
|
|
7
|
+
"bytes": 88350
|
|
8
8
|
},
|
|
9
9
|
"browser/live-cards.schema.json": {
|
|
10
10
|
"sha256": "sha256-9CUv3YSTpgq3k0Dsi8bs7bNUlGoBA1SGWMCBSZcbzys=",
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
var BoardLiveCardsLocalStorage=(function(exports){'use strict';var Pr=Object.defineProperty;var Dr=(e,t,r)=>t in e?Pr(e,t,{enumerable:true,configurable:true,writable:true,value:r}):e[t]=r;var qt=(e,t,r)=>Dr(e,t+"",r);var ot="b64:";function qr(e){let t=new TextEncoder().encode(e),r=globalThis.Buffer,n;if(r)n=r.from(t).toString("base64");else if(typeof btoa=="function"){let o="";for(let s of t)o+=String.fromCharCode(s);n=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return n.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function Mr(e){let t=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),r=globalThis.Buffer;if(r)return r.from(t,"base64").toString("utf8");if(typeof atob=="function"){let n=atob(t),o=new Uint8Array(n.length);for(let s=0;s<n.length;s+=1)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function te(e){return `${ot}${qr(JSON.stringify(e))}`}function Se(e){if(!e.startsWith(ot))throw new Error(`Invalid ref format (expected ${ot}<base64url(json)>): ${e}`);let t;try{t=JSON.parse(Mr(e.slice(ot.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 Mt(e,t,r){let n=e.tryAcquire();if(!n)return false;try{await t();}finally{n();}return r?.(),true}var ke={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function ue(e){return e?Array.isArray(e.provides)?e.provides:[]:[]}function Ce(e){return e?Array.isArray(e.requires)?e.requires:[]:[]}function at(e){return e.tasks??{}}function it(e){return e?e.status===ke.FAILED||e.status===ke.INACTIVATED:false}function Gt(e,t){return e.refreshStrategy??t?.refreshStrategy??"data-changed"}function Ht(e){return e.maxExecutions}function Ut(e,t){let r=new Set;for(let[n,o]of Object.entries(t))if(o.status===ke.COMPLETED){let s=e.tasks[n];s&&ue(s).forEach(c=>r.add(c));}return Array.from(r)}function Vt(e,t){let r={};return e.forEach(n=>{let o=t[n];if(!o)return;ue(o).forEach(a=>{r[a]||(r[a]=[]),r[a].push(n);});}),r}function Jt(e,t,r){let n=e.tasks[t]??ct(),o={};if(r){let a=r.tasks[t],c=Ce(a);for(let u of c)for(let[y,k]of Object.entries(r.tasks))if(ue(k).includes(u)){let R=e.tasks[y];R?.lastDataHash&&(o[u]=R.lastDataHash);break}}let s={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:o};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function Kt(e,t,r,n,o,s){let a=e.tasks[r]??ct(),c=t.tasks[r];if(!c)throw new Error(`Task "${r}" not found in graph`);let u;n&&c.on&&c.on[n]?u=c.on[n]:u=ue(c);let y=a.startConsumedHashes?{...a.startConsumedHashes}:{...a.lastConsumedHashes};if(!a.startConsumedHashes){let p=c.requires??[];for(let g of p)for(let[h,f]of Object.entries(t.tasks))if(ue(f).includes(g)){let j=e.tasks[h];j?.lastDataHash&&(y[g]=j.lastDataHash);break}}let k={...a,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:a.executionCount+1,lastEpoch:a.executionCount+1,lastDataHash:o,data:s,lastConsumedHashes:y,error:void 0},R=[...new Set([...e.availableOutputs,...u])];return {...e,tasks:{...e.tasks,[r]:k},availableOutputs:R,lastUpdated:new Date().toISOString()}}function zt(e,t,r,n){let o=e.tasks[r]??ct(),s=t.tasks[r];if(s?.retry){let u=o.retryCount+1;if(u<=s.retry.max_attempts){let y={...o,status:"not-started",retryCount:u,lastUpdated:new Date().toISOString(),error:n};return {...e,tasks:{...e.tasks,[r]:y},lastUpdated:new Date().toISOString()}}}let a={...o,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:o.executionCount+1},c=e.availableOutputs;if(s?.on_failure&&s.on_failure.length>0&&(c=[...new Set([...e.availableOutputs,...s.on_failure])]),s?.circuit_breaker&&a.executionCount>=s.circuit_breaker.max_executions){let u=s.circuit_breaker.on_break;c=[...new Set([...c,...u])];}return {...e,tasks:{...e.tasks,[r]:a},availableOutputs:c,lastUpdated:new Date().toISOString()}}function Wt(e,t,r,n){let o=e.tasks[t]??ct(),s={...o,progress:typeof n=="number"?n:o.progress,messages:[...o.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:o.status}]:[]],lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function Xt(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 ct(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Ke(e,t){let r=`live-${Date.now()}`,n={};for(let s of Object.keys(e.tasks))n[s]=Qt();let o={status:"running",tasks:n,availableOutputs:[],stuckDetection:{is_stuck:false,stuck_description:null,outputs_unresolvable:[],tasks_blocked:[]},lastUpdated:new Date().toISOString(),executionId:r,executionConfig:{executionMode:e.settings.execution_mode??"eligibility-mode",conflictStrategy:e.settings.conflict_strategy??"alphabetical",completionStrategy:e.settings.completion}};return {config:e,state:o}}function Yt(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:Jt(n,t.taskName,r)};case "task-completed":return {config:r,state:Kt(n,r,t.taskName,t.result,t.dataHash,t.data)};case "task-failed":return {config:r,state:zt(n,r,t.taskName,t.error)};case "task-progress":return {config:r,state:Wt(n,t.taskName,t.message,t.progress)};case "task-restart":return {config:r,state:Xt(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:Gr(n,t.action)};case "task-upsert":return vt(e,t.taskName,t.taskConfig);case "task-removal":return wt(e,t.taskName);case "node-requires-add":return xt(e,t.nodeName,t.tokens);case "node-requires-remove":return _t(e,t.nodeName,t.tokens);case "node-provides-add":return At(e,t.nodeName,t.tokens);case "node-provides-remove":return Tt(e,t.nodeName,t.tokens);default:return e}}function dt(e,t){return t.reduce((r,n)=>Yt(r,n),e)}function vt(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 wt(e,t){if(!e.config.tasks[t])return e;let{[t]:r,...n}=e.config.tasks,{[t]:o,...s}=e.state.tasks;return {config:{...e.config,tasks:n},state:{...e.state,tasks:s,lastUpdated:new Date().toISOString()}}}function xt(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=Ce(n),s=r.filter(a=>!o.includes(a));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:[...o,...s]}}},state:e.state}}function _t(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=Ce(n),s=o.filter(a=>!r.includes(a));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:s}}},state:e.state}}function At(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=ue(n),s=r.filter(a=>!o.includes(a));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:[...o,...s]}}},state:e.state}}function Tt(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=ue(n),s=o.filter(a=>!r.includes(a));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:s}}},state:e.state}}function De(e){return {version:1,config:e.config,state:e.state,snapshotAt:new Date().toISOString()}}function ze(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 Gr(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 qe(e){let{config:t,state:r}=e,n=at(t);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let s=Hr(n),a=Ut(t,r.tasks),c=new Set([...a,...r.availableOutputs]),u=[],y=[],k=[],R=[];for(let[g,h]of Object.entries(n)){let f=r.tasks[g],j=Gt(h,t.settings),E=j!=="once";if(f?.status===ke.RUNNING||it(f))continue;let C=Ht(h);if(C!==void 0&&f&&f.executionCount>=C||h.circuit_breaker&&f&&f.executionCount>=h.circuit_breaker.max_executions||!E&&f?.status===ke.COMPLETED)continue;if(E&&f?.status===ke.COMPLETED){let _=Ce(h),O=false;switch(j){case "data-changed":{_.length>0&&_.some(G=>{for(let[W,re]of Object.entries(n))if(ue(re).includes(G)){let ne=r.tasks[W];if(!ne)continue;let Te=f.lastConsumedHashes?.[G];return ne.lastDataHash==null?ne.executionCount>f.lastEpoch:ne.lastDataHash!==Te}return false})||(O=true);break}case "epoch-changed":{_.length>0&&_.some(G=>{for(let[W,re]of Object.entries(n))if(ue(re).includes(G)){let ne=r.tasks[W];if(ne&&ne.executionCount>f.lastEpoch)return true}return false})||(O=true);break}case "time-based":{let U=h.refreshInterval??0;if(U<=0){O=true;break}let G=f.completedAt;if(!G){O=true;break}(Date.now()-Date.parse(G))/1e3<U&&(O=true);break}case "manual":O=true;break}if(O)continue}let x=Ce(h);if(x.length===0){u.push(g);continue}let P=[],T=[],I=[];for(let _ of x){if(c.has(_))continue;let O=s[_]||[];O.length===0?P.push(_):O.every(G=>it(r.tasks[G]))?I.push({token:_,failedProducer:O[0]}):T.push(_);}P.length>0?k.push({taskName:g,missingTokens:P}):I.length>0?R.push({taskName:g,failedTokens:I.map(_=>_.token),failedProducers:[...new Set(I.map(_=>_.failedProducer))]}):T.length>0?y.push({taskName:g,waitingOn:T}):u.push(g);}let p={};if(u.length>1){let g=Vt(u,n);for(let[h,f]of Object.entries(g))f.length>1&&(p[h]=f);}return {eligible:u,pending:y,unresolved:k,blocked:R,conflicts:p}}function Hr(e){let t={};for(let[r,n]of Object.entries(e)){for(let o of ue(n))t[o]||(t[o]=[]),t[o].push(r);if(n.on)for(let o of Object.values(n.on))for(let s of o)t[s]||(t[s]=[]),t[s].includes(r)||t[s].push(r);if(n.on_failure)for(let o of n.on_failure)t[o]||(t[o]=[]),t[o].includes(r)||t[o].push(r);}return t}var Me=class{constructor(){qt(this,"buffer",[]);}append(t){this.buffer.push(t);}drain(){let t=this.buffer;return this.buffer=[],t}get size(){return this.buffer.length}};function ut(e){let t=Et(e);return Ur(t)}function Et(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return "["+e.map(Et).join(",")+"]";let t=e;return "{"+Object.keys(t).sort().map(n=>JSON.stringify(n)+":"+Et(t[n])).join(",")+"}"}function Ur(e){let t=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let o=0;o<e.length;o++)t^=BigInt(e.charCodeAt(o)),t=t*r&n;return t.toString(16).padStart(16,"0")}function Vr(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 Jr(e){if(typeof Buffer<"u")return Buffer.from(e,"base64url").toString("utf8");if(typeof atob=="function"){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=new Uint8Array(n.length);for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function Zt(e){let t=JSON.stringify({t:e,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return Vr(t)}function Kr(e){try{let t=JSON.parse(Jr(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function We(e,t,r){let{handlers:n,onDrain:o}=t,s=new Me,a="state"in e&&"config"in e?e:Ke(e),c=false,u=new Set,y=new Map(Object.entries(n)),k=new Me,R=false,p=false;function g(){if(!c){if(R){p=true;return}R=true;try{do p=!1,h();while(p)}finally{R=false;}}}function h(){let C=k.drain(),x=s.drain(),P=[...C,...x];P.length>0&&(a=dt(a,P));let T=qe(a);P.length>0&&o?.(P,a,T);for(let I of T.eligible)E(I);for(let I of P)if(I.type==="task-progress"){let{taskName:_,update:O}=I;if(!a.config.tasks[_])continue;let G=a.state.tasks[_];if(!G||G.status!=="running")continue;let W=Zt(_),re=j(_,W,O).catch(ne=>{c||(k.append({type:"task-failed",taskName:_,error:ne.message??String(ne),timestamp:new Date().toISOString()}),g());}).finally(()=>{u.delete(re);});u.add(re);}}function f(C){let P=a.config.tasks[C].requires??[],T=new Map;for(let[_,O]of Object.entries(a.config.tasks))for(let U of O.provides??[])T.set(U,_);let I={};for(let _ of P){let O=T.get(_);O?I[_]=a.state.tasks[O]?.data:I[_]=void 0;}return I}async function j(C,x,P){let T=a.config.tasks[C],I=T.taskHandlers??[],_=f(C);for(let O of I){let U=y.get(O);if(!U)throw new Error(`Handler '${O}' not found in registry (task '${C}')`);let G={nodeId:C,state:_,taskState:a.state.tasks[C],config:T,callbackToken:x,update:P};if(await U(G)==="task-initiate-failure")throw new Error(`Handler '${O}' returned task-initiate-failure (task '${C}')`)}}function E(C){let P=a.config.tasks[C]?.taskHandlers;if(!P||P.length===0)return;k.append({type:"task-started",taskName:C,timestamp:new Date().toISOString()}),g();let T=Zt(C),I=j(C,T).catch(_=>{c||(k.append({type:"task-failed",taskName:C,error:_.message??String(_),timestamp:new Date().toISOString()}),g());}).finally(()=>{u.delete(I);});u.add(I);}return {push(C){c||(C.type==="task-completed"&&C.data&&!C.dataHash&&(C={...C,dataHash:ut(C.data)}),s.append(C),g());},pushAll(C){if(!c){for(let x of C)x.type==="task-completed"&&x.data&&!x.dataHash?s.append({...x,dataHash:ut(x.data)}):s.append(x);g();}},resolveCallback(C,x,P){if(c)return;let T=Kr(C);if(!T)return;let{taskName:I}=T;if(a.config.tasks[I]){if(P&&P.length>0)s.append({type:"task-failed",taskName:I,error:P.join("; "),timestamp:new Date().toISOString()});else {let _=x&&Object.keys(x).length>0?ut(x):void 0;s.append({type:"task-completed",taskName:I,data:x,dataHash:_,timestamp:new Date().toISOString()});}g();}},addNode(C,x){c||(s.append({type:"task-upsert",taskName:C,taskConfig:x,timestamp:new Date().toISOString()}),g());},removeNode(C){c||(s.append({type:"task-removal",taskName:C,timestamp:new Date().toISOString()}),g());},addRequires(C,x){c||(s.append({type:"node-requires-add",nodeName:C,tokens:x,timestamp:new Date().toISOString()}),g());},removeRequires(C,x){c||(s.append({type:"node-requires-remove",nodeName:C,tokens:x,timestamp:new Date().toISOString()}),g());},addProvides(C,x){c||(s.append({type:"node-provides-add",nodeName:C,tokens:x,timestamp:new Date().toISOString()}),g());},removeProvides(C,x){c||(s.append({type:"node-provides-remove",nodeName:C,tokens:x,timestamp:new Date().toISOString()}),g());},registerHandler(C,x){y.set(C,x);},unregisterHandler(C){y.delete(C);},retrigger(C){c||a.config.tasks[C]&&(s.append({type:"task-restart",taskName:C,timestamp:new Date().toISOString()}),g());},retriggerAll(C){if(!c){for(let x of C)a.config.tasks[x]&&s.append({type:"task-restart",taskName:x,timestamp:new Date().toISOString()});g();}},snapshot(){return De(a)},getState(){return a},getSchedule(){return qe(a)},async waitForHandlers(){u.size>0&&await Promise.allSettled([...u]);},async dispose(C){C?.wait&&u.size>0&&await Promise.allSettled([...u]),c=true;}}}function lt(){return function(e){if(e==="./jsonata-sync.cjs")return typeof globalThis<"u"&&globalThis.__jsonataSync||typeof globalThis<"u"&&globalThis.jsonataSync;throw new Error("Unsupported require in browser bundle: "+e)}}var zr=lt();zr("./jsonata-sync.cjs");var Wr=lt(),ft=Wr("./jsonata-sync.cjs"),rr=ft;function er(e,t){if(!t||!e)return;let r=t.split("."),n=e;for(let o=0;o<r.length;o++){if(n==null)return;n=n[r[o]];}return n}function nr(e,t,r){let n=t.split("."),o=e;for(let s=0;s<n.length-1;s++)(o[n[s]]==null||typeof o[n[s]]!="object")&&(o[n[s]]={}),o=o[n[s]];o[n[n.length-1]]=r;}async function Xr(e,t){if(!e?.compute?.length)return e;e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values};for(let o of e.compute)try{let s=await ft(o.expr).evaluate(n);nr(e.computed_values,o.bindTo,s),n.computed_values=e.computed_values;}catch{}return e}function Yr(e,t){if(!e?.compute?.length)return {ok:true,node:e};e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values},o=[];for(let s of e.compute)try{let a=rr(s.expr).evaluate(n);nr(e.computed_values,s.bindTo,a),n.computed_values=e.computed_values;}catch(a){let c=a instanceof Error?a.message:String(a);o.push({bindTo:s.bindTo,error:c});}return o.length>0?{ok:true,node:e,errors:o}:{ok:true,node:e}}async function Qr(e,t,r){let n={...r??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return ft(e).evaluate(n)}function Zr(e,t){return t.startsWith("fetched_sources.")?er(e._sourcesData??{},t.slice(16)):er(e,t)}var tr=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),en=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function tn(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))en.has(n)||t.push(`Unknown top-level key: "${n}"`);if((r.card_data==null||typeof r.card_data!="object"||Array.isArray(r.card_data))&&t.push("card_data: required, must be an object"),r.meta!=null)if(typeof r.meta!="object"||Array.isArray(r.meta))t.push("meta: must be an object");else {let n=r.meta;n.title!=null&&typeof n.title!="string"&&t.push("meta.title: must be a string"),n.tags!=null&&!Array.isArray(n.tags)&&t.push("meta.tags: must be an array");}if(r.requires!=null&&!Array.isArray(r.requires)&&t.push("requires: must be an array of strings"),r.provides!=null&&(Array.isArray(r.provides)?r.provides.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`provides[${o}]: must be an object with bindTo and ref`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`provides[${o}]: missing required "bindTo" string`),(typeof s.ref!="string"||!s.ref)&&t.push(`provides[${o}]: missing required "ref" string`);}}):t.push("provides: must be an array of { bindTo, ref } bindings")),r.compute!=null&&(Array.isArray(r.compute)?r.compute.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`compute[${o}]: must be a compute step object`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`compute[${o}]: missing required "bindTo" property`),(typeof s.expr!="string"||!s.expr)&&t.push(`compute[${o}]: missing required "expr" string (JSONata expression)`);}}):t.push("compute: must be an array of compute steps")),r.source_defs!=null)if(!Array.isArray(r.source_defs))t.push("source_defs: must be an array");else {let n=new Set,o=new Set;r.source_defs.forEach((s,a)=>{if(!s||typeof s!="object"||Array.isArray(s))t.push(`source_defs[${a}]: must be an object`);else {let c=s;typeof c.bindTo!="string"||!c.bindTo?t.push(`source_defs[${a}]: missing required "bindTo" property`):(n.has(c.bindTo)&&t.push(`source_defs[${a}]: bindTo "${c.bindTo}" is not unique across source_defs`),n.add(c.bindTo)),typeof c.outputFile!="string"||!c.outputFile?t.push(`source_defs[${a}]: missing required "outputFile" property`):(o.has(c.outputFile)&&t.push(`source_defs[${a}]: outputFile "${c.outputFile}" is not unique across source_defs`),o.add(c.outputFile)),c.optionalForCompletionGating!=null&&typeof c.optionalForCompletionGating!="boolean"&&t.push(`source_defs[${a}]: optionalForCompletionGating must be a boolean`);}});}if(r.view!=null)if(typeof r.view!="object"||Array.isArray(r.view))t.push("view: must be an object");else {let n=r.view;!Array.isArray(n.elements)||n.elements.length===0?t.push("view.elements: required, must be a non-empty array"):n.elements.forEach((o,s)=>{if(!o||typeof o!="object"){t.push(`view.elements[${s}]: must be an object`);return}!o.kind||typeof o.kind!="string"?t.push(`view.elements[${s}].kind: required, must be a string`):tr.has(o.kind)||t.push(`view.elements[${s}].kind: unknown kind "${o.kind}". Valid: ${[...tr].join(", ")}`),o.data!=null&&(typeof o.data!="object"||Array.isArray(o.data))&&t.push(`view.elements[${s}].data: must be an object`);}),n.layout!=null&&(typeof n.layout!="object"||Array.isArray(n.layout))&&t.push("view.layout: must be an object"),n.features!=null&&(typeof n.features!="object"||Array.isArray(n.features))&&t.push("view.features: must be an object");}return {ok:t.length===0,errors:t}}async function rn(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return Promise.all(e.map(async n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,a]of Object.entries(n.projections))if(typeof a=="string"&&a.trim().length>0)try{o[s]=await ft(a).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}}))}function nn(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return e.map(n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,a]of Object.entries(n.projections))if(typeof a=="string"&&a.trim().length>0)try{o[s]=rr(a).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}})}var Be={run:Xr,runSync:Yr,eval:Qr,resolve:Zr,validate:tn,enrichSources:rn,enrichSourcesSync:nn};function It(e){return JSON.stringify(e)}function Ot(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 pt(e,t){function r(){return e.readIndex()??{}}function n(o,s,a){let c=String(s||"").split(".").filter(Boolean);if(c.length===0)return a&&typeof a=="object"&&!Array.isArray(a)?a:{value:a};let u={...o},y=u;for(let k=0;k<c.length-1;k++){let R=c[k],p=y[R],g=p&&typeof p=="object"&&!Array.isArray(p)?{...p}:{};y[R]=g,y=g;}return y[c[c.length-1]]=a,u}return {readCard(o){let s=r()[o];return !s||!e.cardExists(s.key)?null:e.readCard(s.key)},readCardKey(o){return r()[o]?.key??null},readAllCards(){let o=[];for(let[s,a]of Object.entries(r())){if(!e.cardExists(a.key))continue;let c=e.readCard(a.key);c?o.push(c):t?.(`[card-store] could not read card "${s}" at key "${a.key}"`);}return o},readChecksumIndex(){let o={};for(let[s,a]of Object.entries(r()))o[s]=a.checksum;return o},changedSince(o){let s=r(),a=[];for(let[c,u]of Object.entries(s))o[c]!==u.checksum&&a.push(c);for(let c of Object.keys(o))s[c]||a.push(c);return a},validateUpsert(o,s){let a=r(),c=a[o],u=Object.entries(a).find(([,y])=>y.key===s);return c&&c.key!==s?{ok:false,error:`Card id "${o}" is already mapped to key "${c.key}", cannot remap to "${s}"`}:u&&u[0]!==o?{ok:false,error:`Key "${s}" is already mapped to card id "${u[0]}", cannot remap to "${o}"`}:{ok:true}},writeCard(o,s,a){let c=r(),u=a??c[o]?.key??e.defaultCardKey(o),y=e.writeCard(u,s);c[o]={key:u,checksum:y,updatedAt:new Date().toISOString()},e.writeIndex(c);},patchCard(o,s,a){let c=r(),u=c[o];if(!u||!e.cardExists(u.key))throw new Error(`card "${o}" not found`);let y=e.readCard(u.key);if(!y||typeof y!="object"||Array.isArray(y))throw new Error(`card "${o}" is not patchable`);let k=n(y,s,a),R=e.writeCard(u.key,k);c[o]={key:u.key,checksum:R,updatedAt:new Date().toISOString()},e.writeIndex(c);},removeCard(o){let s=r();s[o]&&(delete s[o],e.writeIndex(s));},readIndex(){return r()}}}function jt(e,t){return {readSourceData(r,n){let o=e.read(`${r}/${n}`);if(o==null)return null;let s=o.trim();if(!s)return null;try{return JSON.parse(s)}catch{return s}},ingestSourceDataStaged(r,n,o,s){let a=t(o);e.write(`${r}/.staged/${s}/${n}`,a);},commitSourceData(r,n,o){let s=`${r}/.staged/${o}/${n}`,a=e.read(s);return a==null?false:(e.write(`${r}/${n}`,a),e.remove(s),true)},hasSource(r,n){return e.exists(`${r}/${n}`)}}}function ar(e){function t(r){let n=e.readAllEntries();if(!r)return n;let o=n.findIndex(s=>s.id===r);return o===-1?n:n.slice(o+1)}return {readEntriesAfterCursor(r){let n=t(r);return n.length===0?{events:[],newCursor:r}:{events:n.map(o=>o.event),newCursor:n[n.length-1].id}},pendingCount(r){return t(r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function ir(e,t){return {appendEntries(r,n){if(!r||n.length===0)return;let o=e.read(r)??[];e.write(r,[...o,...n]);},dispatchEntriesForJournalId(r,n){if(!r)return;let o=e.read(r);if(!(!o||o.length===0)){for(let s of o)try{n(s);}catch(a){let c=a instanceof Error?a.message:String(a);try{t(s,c);}catch{}}e.delete(r);}}}}var gt="v1",Le="board/graph",cr="board/lastJournalProcessedId";function sr(e){return `cards/${e}/runtime`}function dr(e){return {readRuntime(t){return e.read(sr(t))??{_sources:{}}},writeRuntime(t,r){e.write(sr(t),r);}}}function sn(e,t){let r={...e};for(let n of t.deleteKeys)delete r[n];return {...r,...t.shallowMerge}}function ur(e){return {readSnapshot(t){return e.readValues(t)},commitSnapshot(t,r){if(r.schemaVersion!==gt)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 o=sn(n.values,r);return {ok:true,newVersion:e.writeValues(t,o,r.deleteKeys)}}}}function lr(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 Ot(r.trim())},writeTaskExecutorRef(r){e.write("task-executor",It(r));},readChatHandlerRef(){let r=t("chat-handler");if(r?.trim())return Ot(r.trim())},writeChatHandlerRef(r){e.write("chat-handler",It(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);},readChatHandler(){return t("chat-handler")?.trim()||void 0},writeChatHandler(r){e.write("chat-handler",r);}}}function fr(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 on(e){return e?.lastRequestedAt?!e.lastFetchedAt||e.lastFetchedAt<e.lastRequestedAt:false}function an(e,t){return e?.lastRequestedAt?on(e)?"in-flight":!e.lastFetchedAt||e.lastFetchedAt<t?"dispatch":"idle":"dispatch"}function cn(e,t){let r={...e,lastFetchedAt:t};return delete r.lastError,r}function or(e,t){let r={...e,lastError:t};return delete r.lastFetchedAt,r}function mt(e,t){let r=t.state.tasks,n=t.config.tasks,o=Object.keys(r),s=qe(t),a={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},c=new Map;for(let h of s.pending)c.set(h.taskName,h.waitingOn);for(let h of s.unresolved)c.set(h.taskName,h.missingTokens);for(let h of s.blocked)c.set(h.taskName,h.failedTokens);let u=new Map;for(let[h,f]of Object.entries(n))for(let j of f.requires??[]){let E=u.get(j)??[];E.push(h),u.set(j,E);}let y=o.sort().map(h=>{let f=r[h],j=n[h]??{requires:[],provides:[]};f.status==="completed"?a.completed+=1:f.status==="failed"?a.failed+=1:f.status==="in-progress"&&(a.in_progress+=1);let E=j.requires??[],C=j.provides??[],x=Object.keys(f.data??{}).sort(),P=E.filter(G=>t.state.availableOutputs.includes(G)),T=E.filter(G=>!t.state.availableOutputs.includes(G)),I=c.get(h)??T,_=new Set;for(let G of C)for(let W of u.get(G)??[])W!==h&&_.add(W);let O=f.failedAt,U=f.error?{message:f.error,code:"TASK_FAILED",at:O,source:"task-runtime"}:void 0;return {name:h,status:f.status,error:U,requires:E,requires_satisfied:P,requires_missing:T,provides_declared:C,provides_runtime:x,blocked_by:I,unblocks:Array.from(_).sort(),runtime:{attempt_count:f.executionCount??0,restart_count:f.retryCount??0,in_progress_since:f.status==="in-progress"?f.startedAt??null:null,last_transition_at:f.lastUpdated??null,last_completed_at:f.completedAt??null,last_restarted_at:f.startedAt??null,status_age_ms:f.lastUpdated?0:null}}});a.pending=s.pending.length,a.blocked=s.blocked.length,a.unresolved=s.unresolved.length;let k=y.map(h=>({name:h.name,fanOut:h.unblocks.length})).sort((h,f)=>f.fanOut-h.fanOut||h.name.localeCompare(f.name)),R=k.length>0?k[0]:{name:null,fanOut:0},p=new Set;for(let h of Object.values(n))for(let f of h.requires??[])p.add(f);let g=0;for(let[h,f]of Object.entries(n)){let j=(f.requires??[]).length===0,C=(f.provides??[]).some(x=>(u.get(x)??[]).some(P=>P!==h));j&&!C&&(g+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:o.length,completed:a.completed,eligible:s.eligible.length,pending:a.pending,blocked:a.blocked,unresolved:a.unresolved,failed:a.failed,in_progress:a.in_progress,orphan_cards:g,topology:{edge_count:Array.from(p).length,max_fan_out_card:R.name,max_fan_out:R.fanOut}},cards:y}}function dn(){return new Date().toISOString()}function pr(e,t,r,n,o,s,a){return async c=>{let u=[],y=r.cardStore.readCard(c.nodeId);if(!y)return "task-initiate-failure";let k=y.id,R=y.card_data??{},p=y.source_defs??[],g=p.filter(q=>q.optionalForCompletionGating!==true),h=r.cardRuntimeStore.readRuntime(k),f=false,j=()=>{f&&(r.cardRuntimeStore.writeRuntime(k,h),f=false);},E=q=>({...h._sources[q]??{}}),C=(q,M)=>{h._sources[q]=M,f=true;},x=c.taskState?.executionCount??0,P=h._lastExecutionCount;if(typeof P=="number"&&P!==x&&(h._sources={},f=true),P!==x&&(h._lastExecutionCount=x,f=true),c.update){let q=c.update,M=q.outputFile;if(M){let v=E(M);if(q.failure)C(M,or(v,q.reason??"unknown"));else {let m=q.rqt;if(!v.lastFetchedAt||m>v.lastFetchedAt){let A=typeof q.deliveryToken=="string"?q.deliveryToken:void 0,F=false;A&&(F=r.fetchedSourcesStore.commitSourceData(k,M,A)),F?C(M,cn(v,m)):C(M,or(v,`source delivery commit failed for ${M} token=${String(A)}`));}}j();}}let T={};for(let q of p)if(q.outputFile){let M=r.fetchedSourcesStore.readSourceData(k,q.outputFile);M!==null&&(T[q.bindTo]=M);}let I={};for(let[q,M]of Object.entries(c.state??{}))if(M!==null&&typeof M=="object"&&!Array.isArray(M)){let v=M[q];I[q]=v!==void 0?v:M;}else I[q]=M;let _={id:k,card_data:{...R},requires:I,source_defs:p,compute:y.compute};_._sourcesData=T,y.compute&&Be.runSync(_,{sourcesData:T}),(s??r.outputStore.writeComputedValues.bind(r.outputStore))(k,_.computed_values??{});let O={...y},U=Be.enrichSourcesSync(Array.isArray(y.source_defs)?y.source_defs:void 0,{card_data:y.card_data,requires:I}),G=e.value;O.source_defs=Array.isArray(U)?U.map(q=>({...q,boardDir:typeof q.boardDir=="string"&&q.boardDir?q.boardDir:G})):U;let W=dn(),re=c.update?void 0:W,ne=g.filter(q=>{let M=q.outputFile;if(typeof M!="string"||!M)return true;let v=E(M);re&&(v={...v,queueRequestedAt:re},C(M,v));let m=v.queueRequestedAt??v.lastRequestedAt??W,A=an(v,m);return A==="in-flight"?false:A==="dispatch"});if(j(),ne.length>0){let q=false,M=W;for(let v of ne){let m=v.outputFile;if(typeof m!="string"||!m)continue;let A=E(m),F=A.queueRequestedAt??W;C(m,{...A,lastRequestedAt:F}),M=F,q=true;}return q&&j(),q&&(u.push({taskKind:"source-fetch",payload:{boardRef:te(e),enrichedCard:O,callbackToken:c.callbackToken,rqt:M}}),r.executionRequestStore.appendEntries(t,u)),"task-initiated"}let Te=y.provides??[],Ee={};for(let{bindTo:q,ref:M}of Te)Ee[q]=Be.resolve(_,M);return (a??r.outputStore.writeDataObjects.bind(r.outputStore))(Ee),p.filter(q=>{if(q.optionalForCompletionGating!==true)return false;let M=E(q.outputFile);return !M.lastRequestedAt||!M.lastFetchedAt?true:M.lastFetchedAt<=M.lastRequestedAt}).length>0&&u.push({taskKind:"source-fetch",payload:{boardRef:te(e),enrichedCard:O,callbackToken:c.callbackToken,rqt:W}}),n(c.nodeId,Ee),u.length>0&&r.executionRequestStore.appendEntries(t,u),"task-initiated"}}var Nt={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function gr(e){return {[Le]:e.graph,[cr]:e.lastDrainedJournalId}}function mr(e){let t=e[Le],r=e[cr];if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${Le}`);return {graph:t,lastDrainedJournalId:typeof r=="string"?r:""}}function hr(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 se(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function Z(e){return {status:"fail",error:e}}function oe(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function un(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 kr(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function ht(e){try{let t=JSON.parse(kr(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function ln(e){return un(JSON.stringify(e))}function yr(e){try{let t=JSON.parse(kr(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function fe(){return new Date().toISOString()}function br(e,t){let r=t.onWarn??(()=>{}),n=te(e);function o(v){if(v.length!==0)try{let m=t.publishBoardChangeNotifications?.(v);m&&typeof m.catch=="function"&&m.catch(A=>r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${A instanceof Error?A.message:String(A)}`));}catch(m){r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${m instanceof Error?m.message:String(m)}`);}}function s(){let v=c().readCardStoreRef();if(!v)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let m=t.kvStorageForRef(v);return {readIndex(){return m.read("_index")},writeIndex(A){m.write("_index",A);},readCard(A){return m.read(A)},writeCard(A,F){return m.write(A,F),t.hashFn(F)},cardExists(A){return m.read(A)!==null},defaultCardKey(A){return A}}}let a={readValues(v){let m=t.kvStorage("state-snapshot"),A=m.listKeys().sort();if(A.length===0)return {version:null,values:{}};let F={};for(let z of A)F[z]=m.read(z);return {version:t.hashFn(F),values:F}},writeValues(v,m,A){let F=t.kvStorage("state-snapshot");for(let z of A)F.delete(z);for(let[z,Q]of Object.entries(m))F.write(z,Q);return t.hashFn(m)}},c=()=>lr(t.kvStorage("config")),u=()=>ur(a),y=()=>ar(t.journalAdapter()),k=()=>pt(s(),r),R=()=>{let v=c().readOutputsStoreRef();if(!v)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return fr(t.kvStorageForRef(v))};function p(){return !!u().readSnapshot(e.value).values[Le]}function g(){let v=u().readSnapshot(e.value);if(!v.values[Le])throw new Error(`Board not initialized at ${e.value}`);return mr(v.values)}function h(v,m){let A=u().commitSnapshot(e.value,{schemaVersion:gt,expectedVersion:m,commitId:t.genId(),committedAt:fe(),deleteKeys:[],shallowMerge:gr(v)});if(!A.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${m??"null"} current=${A.currentVersion??"null"}`)}function f(v){y().appendEvent(v);}async function j(){let v=(N,D)=>{let X=N.payload,he=(X?.enrichedCard??{}).id??X?.cardId??"unknown";f({type:"task-failed",taskName:he,error:D,timestamp:fe()});},m=ir(t.kvStorage("execution-requests"),v),A=dr(t.kvStorage("card-runtime")),F=jt(t.blobStorage("sources"),N=>t.resolveBlob(N)),z=new Map,Q={readRuntime(N){return z.get(N)??A.readRuntime(N)},writeRuntime(N,D){z.set(N,D);}},me=[],ae=new Map,le={readSourceData(N,D){let X=`${N}/${D}`;return ae.has(X)?ae.get(X):F.readSourceData(N,D)},ingestSourceDataStaged(N,D,X,Ae){F.ingestSourceDataStaged(N,D,X,Ae);},commitSourceData(N,D,X){let Ae=`${N}/.staged/${X}/${D}`,i=t.blobStorage("sources").read(Ae);if(i==null)return false;let d=`${N}/${D}`,l=i.trim();try{ae.set(d,JSON.parse(l));}catch{ae.set(d,l);}return me.push({cardId:N,outputFile:D,deliveryToken:X}),true},hasSource(N,D){let X=`${N}/${D}`;return ae.has(X)?true:F.hasSource(N,D)}},ie={cardStore:k(),cardRuntimeStore:Q,fetchedSourcesStore:le,outputStore:R(),executionRequestStore:m},be=g(),Re=ze(be.graph),{events:ve,newCursor:we}=y().readEntriesAfterCursor(be.lastDrainedJournalId),J=[],xe=[],He=[],Ue=new Map,Ze=(N,D)=>{J.push({type:"task-completed",taskName:N,data:D,timestamp:fe()});},Ve=(N,D)=>f({type:"task-failed",taskName:N,error:D,timestamp:fe()}),Ie=We(Re,{handlers:{"card-handler":pr(e,we,ie,Ze,Ve,(N,D)=>{xe.push({cardId:N,values:D});},N=>{He.push(N);})}});for(J=ve;J.length>0;){let N=J;J=[];for(let D of N)if(D.type==="task-restart"){let X=ie.cardStore.readCard(D.taskName);X&&Ue.set(D.taskName,X);}Ie.pushAll(N),await Ie.waitForHandlers();}let Je=Ie.getState();await Ie.dispose({wait:true});let rt=u().readSnapshot(e.value).version;h({lastDrainedJournalId:we,graph:De(Je)},rt);for(let{cardId:N,values:D}of xe)ie.outputStore.writeComputedValues(N,D);for(let N of He)ie.outputStore.writeDataObjects(N);for(let[N,D]of z)A.writeRuntime(N,D);for(let{cardId:N,outputFile:D,deliveryToken:X}of me)F.commitSourceData(N,D,X);let _e;try{_e=mt(n,Je),ie.outputStore.writeStatusSnapshot(_e);}catch(N){r(`[board-live-cards-public] status publish failed: ${N instanceof Error?N.message:String(N)}`);}let Oe=[];for(let{cardId:N,values:D}of xe)Oe.push({kind:"computed_values",cardId:N,values:D});for(let N of He)for(let[D,X]of Object.entries(N))D&&Oe.push({kind:"data_object",key:D,payload:X});for(let[N,D]of Ue)Oe.push({kind:"card_refreshed",cardId:N,card:D});_e!==void 0&&Oe.push({kind:"status",status:_e}),o(Oe);let St=c().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:te({kind:"built-in",value:"source-cli-task-executor"})};m.dispatchEntriesForJournalId(we,N=>{if(N.taskKind!=="source-fetch"){r(`[process-accumulated-events] unknown taskKind "${N.taskKind}" \u2014 skipping`);return}let D=N.payload,X=D.enrichedCard?.id??"unknown",Ae=D.enrichedCard?.source_defs??[];for(let he of Ae){if(!he.outputFile){r(`[dispatch] source "${he.bindTo}" has no outputFile \u2014 skipping`);continue}let i=ln({cbk:D.callbackToken,rg:e.value,br:te(e),cid:X,b:he.bindTo,d:he.outputFile,cs:void 0,rqt:D.rqt});t.dispatchExecution(St,{source_def:he,base_ref:te(e),callback:{token:i,via:t.selfRef}}).catch(d=>Ve(X,d instanceof Error?d.message:String(d)));}});}async function E(){try{let v=()=>{let A=g(),{events:F}=y().readEntriesAfterCursor(A.lastDrainedJournalId);F.length<=0||(E(),t.requestProcessAccumulated?.());},m=await Mt(t.lock,j,v);return se({ran:m!==!1})}catch(v){return oe(v)}}function C(v){try{let m=v.params?.cardStoreRef;if(!m)return Z("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!p()){let Q=Ke(Nt);h({lastDrainedJournalId:"",graph:De(Q)},null);}let A=v.params?.outputsStoreRef;if(!A)return Z("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let F=c();F.writeCardStoreRef(m),F.writeOutputsStoreRef(A);let z=v.body??{};z["task-executor-ref"]&&F.writeTaskExecutorRef(z["task-executor-ref"]),z["chat-handler-ref"]&&F.writeChatHandlerRef(z["chat-handler-ref"]);try{R().writeStatusSnapshot(mt(n,ze(g().graph)));}catch{}return se()}catch(m){return oe(m)}}function x(v){try{let m=R().readStatusSnapshot();if(!m){m=mt(n,ze(g().graph));try{R().writeStatusSnapshot(m);}catch{}}return se(m)}catch(m){return oe(m)}}function P(v){try{let m=v.params?.id;return m?(f({type:"task-removal",taskName:m,timestamp:fe()}),E(),se()):Z("removeCard requires params.id")}catch(m){return oe(m)}}function T(v){try{let m=v.params?.id;return m?(f({type:"task-restart",taskName:m,timestamp:fe()}),E(),se()):Z("retrigger requires params.id")}catch(m){return oe(m)}}async function I(v){return E()}function _(v){try{let m=v.params?.cardId,A=v.params?.all,F=!!v.params?.restart;if(!m&&!A)return Z("upsertCard requires --card-id <id> or --all");let z=A?k().readAllCards().map(Q=>Q.id):[m];for(let Q of z)if(!k().readCard(Q))return Z(`Card "${Q}" not found in board at ${e.value}`);for(let Q of z){let me=k().readCard(Q),ae=hr(me),le=t.hashFn(ae),ie=t.kvStorage("card-upsert"),be=ie.read(Q),Re=be?.taskConfigHash!==le;if(!(!Re&&!F)){if(Re){let ve=be?.blobRef??k().readCardKey(Q)??Q;f({type:"task-upsert",taskName:Q,taskConfig:ae,timestamp:fe()}),ie.write(Q,{blobRef:ve,taskConfigHash:le,updatedAt:fe()});}F&&f({type:"task-restart",taskName:Q,timestamp:fe()});}}return E(),se()}catch(m){return oe(m)}}function O(v){try{let m=v.params?.token;if(!m)return Z("taskFailed requires params.token");let A=v.params?.error??"unknown error",F=ht(m);return F?(f({type:"task-failed",taskName:F.taskName,error:A,timestamp:fe()}),E(),se()):Z("Invalid callback token")}catch(m){return oe(m)}}function U(v){try{let m=v.params?.token;if(!m)return Z("taskProgress requires params.token");let F=(v.body??{}).update??{},z=ht(m);return z?(f({type:"task-progress",taskName:z.taskName,update:F,timestamp:fe()}),E(),se()):Z("Invalid callback token")}catch(m){return oe(m)}}function G(v){try{let m=v.params?.token,A=v.params?.ref;if(!m)return Z("sourceDataFetched requires params.token");if(!A)return Z("sourceDataFetched requires params.ref");let F=yr(m);if(!F)return Z("Invalid source token");let{cbk:z,cid:Q,b:me,d:ae,cs:le,rqt:ie}=F,be=jt(t.blobStorage("sources"),J=>t.resolveBlob(J)),Re=t.genId();be.ingestSourceDataStaged(Q,ae,Se(A),Re);let ve=ht(z);if(!ve)return Z("Invalid callback token embedded in source token");let we=fe();return f({type:"task-progress",taskName:ve.taskName,update:{bindTo:me,outputFile:ae,fetchedAt:we,deliveryToken:Re,sourceChecksum:le,rqt:ie},timestamp:we}),E(),se()}catch(m){return oe(m)}}function W(v){try{let m=v.params?.token,A=v.params?.reason??"unknown";if(!m)return Z("sourceDataFetchFailure requires params.token");let F=yr(m);if(!F)return Z("Invalid source token");let{cbk:z,b:Q,d:me,cs:ae}=F,le=ht(z);return le?(f({type:"task-progress",taskName:le.taskName,update:{bindTo:Q,outputFile:me,failure:!0,reason:A,sourceChecksum:ae},timestamp:fe()}),E(),se()):Z("Invalid callback token embedded in source token")}catch(m){return oe(m)}}function re(v){try{let m=c().readCardStoreRef();return m?se({storeRef:m}):Z(`Board at ${e.value} has no card store configured`)}catch(m){return oe(m)}}function ne(v){try{let m=c().readOutputsStoreRef();return m?se({storeRef:m}):Z(`Board at ${e.value} has no outputs store configured`)}catch(m){return oe(m)}}function Te(v){try{let m=v.params?.key;if(!m)return Z("getConfig requires params.key");let A=c(),F;switch(m){case "task-executor":F=A.readTaskExecutorRef()??null;break;case "chat-handler":F=A.readChatHandlerRef()??null;break;case "card-store-ref":F=A.readCardStoreRef();break;case "outputs-store-ref":F=A.readOutputsStoreRef();break;default:return Z(`getConfig: unknown key "${m}"`)}return se({value:F})}catch(m){return oe(m)}}function Ee(v){try{let m=v.params?.key;if(!m)return Z("getOutputsDataObject requires params.key");let A=R().readDataObject(m);return se(A)}catch(m){return oe(m)}}function Qe(v){try{return se(R().readAllDataObjects())}catch(m){return oe(m)}}function q(v){try{let m=v.params?.key;if(!m)return Z("getOutputsComputedValues requires params.key");let A=R().readComputedValues(m);return se(A)}catch(m){return oe(m)}}function M(v){try{return se(R().readAllComputedValues())}catch(m){return oe(m)}}return {init:C,status:x,getCardStoreRef:re,getOutputsStoreRef:ne,getConfig:Te,getOutputsDataObject:Ee,getAllOutputsDataObjects:Qe,getOutputsComputedValues:q,getAllOutputsComputedValues:M,removeCard:P,retrigger:T,processAccumulatedEvents:I,upsertCard:_,taskFailed:O,taskProgress:U,sourceDataFetched:G,sourceDataFetchFailure:W}}function Rr(e){function t(o){return {status:"success",data:o}}function r(o){return {status:"fail",error:o}}function n(o){return {status:"error",error:o instanceof Error?o.message:String(o)}}return {get(o){try{let s=o.params?.id;if(s){let a=e.readCard(s);return a?t({cards:[a]}):r(`card "${s}" not found`)}return t({cards:e.readAllCards()})}catch(s){return n(s)}},set(o){try{let s=o.body;if(s==null)return r("set requires a body (card object or array of cards)");let a=Array.isArray(s)?s:[s];for(let c of a){if(typeof c.id!="string")return r("each card must have a string `id` field");e.writeCard(c.id,c);}return t({count:a.length})}catch(s){return n(s)}},del(o){try{let s=o.body?.ids??[],a=o.params?.id,c=a?[...s,a]:s;if(c.length===0)return r("del requires body.ids (string[]) or params.id");for(let u of c)e.removeCard(u);return t({count:c.length})}catch(s){return n(s)}},patch(o){try{let s=o.params?.id,a=o.params?.path;if(!s)return r("patch requires params.id");if(!a)return r("patch requires params.path");let c=o.body,u=c&&Object.prototype.hasOwnProperty.call(c,"value")?c.value:o.body;return e.patchCard(s,a,u),t({count:1})}catch(s){return n(s)}}}}var yt=".artifacts-index.json";function Sr(){return new Date().toISOString()}function Cr(e){return new TextEncoder().encode(e).byteLength}function Xe(e){let t=e.read(yt);if(!t)return {entries:{}};try{let r=JSON.parse(t);if(r&&r.entries&&typeof r.entries=="object")return r}catch{}return {entries:{}}}function Bt(e,t){e.write(yt,JSON.stringify(t,null,2));}function fn(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function vr(e,t,r){e.entries[t]={key:t,size:r.size,updatedAt:r.updatedAt,contentType:r.contentType};}function Lt(e){let t=String(e||"").match(/^(\d+)[-_]/);return t?parseInt(t[1],10):0}function pn(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 gn(e){return String(e||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function mn(e){if(!e||e===".")return "";let t=String(e).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return t?`.${t}`:""}function hn(e){let t=pn(e),r=t.lastIndexOf(".");return r<=0||r===t.length-1?{stem:t,ext:""}:{stem:t.slice(0,r),ext:t.slice(r)}}function yn(e){let t=e.lastIndexOf("/");return t>=0?e.slice(t+1):e}function $t(e){function t(r){let n=e.stat?fn(e.stat(r)):null;if(n)return n;let s=Xe(e).entries[r];if(s)return {...s};if(!e.exists(r))return null;let a=e.read(r);return a===null?{key:r}:{key:r,size:Cr(a)}}return {exists(r){return e.exists(r)},putText(r,n,o="text/plain; charset=utf-8"){e.write(r,n);let s=t(r)??{key:r};s.contentType=o,s.updatedAt=s.updatedAt??Sr(),s.size=s.size??Cr(n);let a=Xe(e);return vr(a,r,s),Bt(e,a),s},putBytes(r,n,o="application/octet-stream"){if(e.writeBytes)e.writeBytes(r,n);else {let c=JSON.stringify({__kind:"bytes-array",data:[...n]});e.write(r,c);}let s=t(r)??{key:r};s.contentType=o,s.updatedAt=s.updatedAt??Sr(),s.size=s.size??n.byteLength;let a=Xe(e);return vr(a,r,s),Bt(e,a),s},getText(r){let n=e.read(r);if(n===null){if(!e.readBytes)return null;let o=e.readBytes(r);return o===null?null:Buffer.from(o).toString("utf-8")}try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new TextDecoder("utf-8").decode(new Uint8Array(o.data))}catch{}return n},getBytes(r){if(e.readBytes){let o=e.readBytes(r);if(o!==null)return o}let n=e.read(r);if(n===null)return null;try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new Uint8Array(o.data)}catch{}return new TextEncoder().encode(n)},head:t,list(r=""){let n=new Map;if(e.listKeys)for(let s of e.listKeys(r)){if(s===yt)continue;let a=t(s)??{key:s};n.set(s,a);}let o=Xe(e);for(let[s,a]of Object.entries(o.entries))s===yt||r&&!s.startsWith(r)||n.has(s)||n.set(s,{...a});return [...n.values()].sort((s,a)=>s.key.localeCompare(a.key))},remove(r){e.remove(r);let n=Xe(e);delete n.entries[r],Bt(e,n);}}}function wr(e,t){let r=t?.indexFileName;function n(R){return `${R}/${r}`}function o(R){let p=e.getText(n(R));if(!p)return [];try{let g=JSON.parse(p);return Array.isArray(g)?g.filter(h=>h&&typeof h.stored_name=="string").map(h=>({serial:Number(h.serial||Lt(String(h.stored_name))||0),role:String(h.role||"system").toLowerCase(),stored_name:String(h.stored_name),path:typeof h.path=="string"?h.path:`${R}/chats/${String(h.stored_name)}`,updated_at:typeof h.updated_at=="string"?h.updated_at:null})):[]}catch{return []}}function s(R,p){e.putText(n(R),JSON.stringify(p,null,2),"application/json; charset=utf-8");}function a(R){let p=o(R),g=0;for(let h of p){let f=Number(h.serial||0);Number.isFinite(f)&&f>g&&(g=f);}return g+1}function c(R,p){let g=o(R);g.push(p),s(R,g);}function u(R){let p=o(R),g=[];for(let h of p){let f=`${R}/${h.stored_name}`,j=e.getText(f);j!==null&&g.push({serial:Number(h.serial||Lt(h.stored_name)||0),role:String(h.role||"system").toLowerCase(),text:j,path:typeof h.path=="string"?h.path:`${R}/chats/${h.stored_name}`,stored_name:h.stored_name,updated_at:h.updated_at||null});}return g.sort((h,f)=>h.serial-f.serial||h.stored_name.localeCompare(f.stored_name)),g}function y(R){let p=`${R}/`;for(let g of e.list(p))e.remove(g.key);}function k(R){let p=`${R}/`,g=e.list(p),h=0,f=0,j=false;for(let E of g){let C=E.key.slice(p.length);if(C===".processing"){j=true;continue}if(!/^(\d+)[-_]([a-z0-9_-]+)\.txt$/i.test(C))continue;h+=1;let x=E.updatedAt?Number(new Date(E.updatedAt).getTime()||0):0;x>f&&(f=x);}return {count:h,latest_mtime_ms:f,processing:j}}return {indexKey:n,loadIndex:o,saveIndex:s,nextSerial:a,appendIndexRecord:c,readRecords:u,clear:y,readSignal:k}}function xr(e){function t(o,s){let a=0,c=[];Array.isArray(s)&&c.push(...s);for(let u of e.list(`${o}/`))c.push(yn(u.key));for(let u of c){let y=Lt(u);Number.isFinite(y)&&y>a&&(a=y);}return a+1}function r(o,s,a){let c=Number(a?.maxLen||32),{stem:u,ext:y}=hn(o),k=mn(y),R=gn(u),p=`${String(s).padStart(3,"0")}-`,g=k,h=c-p.length-g.length;h<1&&(g="",h=c-p.length);let f=R.slice(0,Math.max(1,h)),j=`${p}${f}${g}`;return j.length>c&&(j=j.slice(0,c).replace(/\.$/,"")),j}function n(o,s,a){let c=t(o,a?.seedNames),u=r(s,c,{maxLen:a?.maxLen});for(;e.exists(`${o}/${u}`);)c+=1,u=r(s,c,{maxLen:a?.maxLen});return u}return {nextSerial:t,buildStoredName:r,allocateStoredName:n}}function _r(){function e(o,s){if(!Array.isArray(o))return [];let a=[];for(let c of o){if(!c||typeof c!="object")continue;let u=c;typeof u.stored_name=="string"&&a.push({name:typeof u.name=="string"?u.name:u.stored_name,stored_name:u.stored_name,size:typeof u.size=="number"&&Number.isFinite(u.size)?u.size:null,mime_type:typeof u.mime_type=="string"?u.mime_type:null,path:typeof u.path=="string"?u.path:null,uploaded_at:typeof u.uploaded_at=="string"?u.uploaded_at:s||null});}return a}function t(o){return !o||typeof o!="object"?[]:e(o.files,void 0)}function r(o,s){let a=t(o);if(s.length===0)return o.files=a,a;let c=new Set(a.map(u=>u.stored_name));for(let u of s)c.has(u.stored_name)||(a.push(u),c.add(u.stored_name));return o.files=a,a}function n(o,s,a){let c=t(o);if(!Number.isInteger(s)||s<0||s>=c.length)return {ok:false,reason:"index_out_of_range"};let u=c[s];return !u||!u.stored_name?{ok:false,reason:"missing_stored_name"}:a&&a!==u.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:u}}return {read:t,normalizeIncoming:e,merge:r,resolve:n}}var kn={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},bn=32;function Rn(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Ar(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 Tr(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)Tr(e,n);return}r.kind==="status"&&Ar(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);}function Er(e){let t=String(e.apiBasePath||"/api/board").replace(/\/$/,""),r={...kn,...e.corsHeaders||{}},n=e.boardId||"",o=e.logger||{info:console.log,warn:console.warn,error:console.error},s=e.invocationAdapter,a=e.notificationTransport||null,c=e.serverUrl||null,u=e.executionExtra||{},y=new Map,k=new Map,R=null;function p(i){let d=br(i.baseRef,i.boardAdapter),l=i.boardAdapter.kvStorageForRef(i.cardStoreRef),S=Rr(pt({readIndex:()=>l.read("_index"),writeIndex:L=>l.write("_index",L),readCard:L=>l.read(L),writeCard:(L,K)=>(l.write(L,K),L),cardExists:L=>l.read(L)!==null,defaultCardKey:L=>L},o.warn)),w=i.artifactsAdapter||i.boardAdapter,$=null,B=null;return {label:i.label,board:d,cardStore:S,get filesArtifacts(){return $??($=$t(w.blobStorage("files")))},get chatsArtifacts(){return B??(B=$t(w.blobStorage("chats")))},boardAdapter:i.boardAdapter,cardStoreRef:i.cardStoreRef,outputsStoreRef:i.outputsStoreRef,notifyRef:i.notifyRef,taskExecutorRef:i.taskExecutorRef,chatHandlerRef:i.chatHandlerRef,inferenceAdapterRef:i.inferenceAdapterRef,notification:Rn(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let g=e.boards.map(p),h=new Map;function f(i){return h.get(i)??0}function j(i){let d=g[f(i)];return {files:d?d.filesArtifacts:null,chats:d?d.chatsArtifacts:null}}function E(i){let d=j(i);return d.chats?wr(d.chats,{indexFileName:".index.json"}):null}function C(i){let d=j(i);return d.files?xr(d.files):null}function x(){return _r()}function P(i){return String(i||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function T(i){if(!i||i.notificationTeardown||!a||!i.notifyRef)return;let d=await a.subscribe(i.notifyRef,l=>{Tr(i.notification,l);let b=l.kind==="notification-batch"?l.notifications:[l];X(b);});i.notificationTeardown=d;}async function I(i){if(!i||i.initialized)return;let d={cardStoreRef:i.cardStoreRef,outputsStoreRef:i.outputsStoreRef},l={};i.taskExecutorRef&&(l["task-executor-ref"]=i.taskExecutorRef),i.chatHandlerRef&&(l["chat-handler-ref"]=i.chatHandlerRef),i.inferenceAdapterRef&&(l["inference-adapter-ref"]=i.inferenceAdapterRef);let b=i.board.init({params:d,body:l});if(b.status!=="success")throw Object.assign(new Error(b.error||`init failed for ${i.label}`),{statusCode:500});if(await T(i),i.chatHandlerRef&&s.describe)try{let S=await s.describe(i.chatHandlerRef);S&&S.kind!=="chat-handler"?o.warn(`[init] chat-handler describe returned kind="${S.kind}", expected "chat-handler" for ${i.label}`):S&&o.info(`[init] chat-handler validated: ${S.name} (protocol ${S.protocolVersion}) for ${i.label}`);}catch(S){o.warn(`[init] chat-handler describe failed for ${i.label}: ${S?.message||String(S)}`);}i.initialized=true;}function _(i){if(!i.boardAdapter.publishBoardChangeNotifications)return;let d=[],l=i.board.status({});l.status==="success"&&l.data!=null&&Ar(l.data)&&d.push({kind:"status",status:l.data});let b=i.board.getAllOutputsDataObjects({});if(b.status==="success"&&b.data!=null)for(let[w,$]of Object.entries(b.data))w&&d.push({kind:"data_object",key:w,payload:$});let S=i.board.getAllOutputsComputedValues({});if(S.status==="success"&&S.data!=null)for(let[w,$]of Object.entries(S.data))w&&d.push({kind:"computed_values",cardId:w,values:$});d.length>0&&i.boardAdapter.publishBoardChangeNotifications(d);}function O(i,d){if(!i||i.cardsBootstrapped)return;let l=i.cardStore.get({}),b=l.status==="success"&&Array.isArray(l.data?.cards)?l.data.cards:[];for(let S of b)typeof S.id=="string"&&(h.set(S.id,d),i.board.upsertCard({params:{cardId:S.id}}));i.cardsBootstrapped=true;}async function U(){for(let i of g)await I(i);}async function G(){await U();for(let i=0;i<g.length;i++)_(g[i]),O(g[i],i);}function W(i){return g[f(i)]??null}function re(i){let d=W(i);if(!d)return null;let l=d.cardStore.get({params:{id:i}});if(l.status!=="success")return null;let b=Array.isArray(l.data?.cards)?l.data.cards:[];return b.length>0?b[0]:null}function ne(){let i=l=>{if(!l||!l.cardStore)return [];let b=l.cardStore.get({});return b.status!=="success"||!Array.isArray(b.data?.cards)?[]:b.data.cards},d=[];for(let l of g)d.push(...i(l));return d}function Te(){let i=g.map(w=>{try{let B=w.boardAdapter.kvStorageForRef(w.outputsStoreRef).read("status");if(B!=null)return B}catch{}return w.notification.status}).filter(Boolean);if(i.length===0)return null;if(i.length===1)return i[0];let d=[],l=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],b={};for(let w of l)b[w]=0;for(let w of i){let $=w,B=Array.isArray($.cards)?$.cards:[];d.push(...B);for(let L of l)b[L]+=Number($?.summary?.[L]||0);}let S=i[0];return {...S,cards:d,summary:{...S.summary||{},card_count:d.length,...b}}}function Ee(){let i={},d=l=>{for(let[b,S]of Object.entries(l.notification.computedValues)){let w=l.notification.cards[b];i[b]={schema_version:"v1",card_id:b,card_data:w?.card_data??{},computed_values:S??{}};}};for(let l of g)d(l);return i}function Qe(){let i={};for(let d of g)Object.assign(i,d.notification.dataObjects||{});return i}function q(i){let d=P(i),l=E(i);return l?l.readSignal(d):{count:0,latest_mtime_ms:0,processing:false}}function M(){let i=ne(),d=Ee(),l=Qe(),b={};for(let w of i){if(!w?.id)continue;let $=w.id,B=d[$]||{},L={...B.card_data&&typeof B.card_data=="object"?B.card_data:w.card_data&&typeof w.card_data=="object"?w.card_data:{}};b[$]={schema_version:B.schema_version||"v1",card_id:B.card_id||$,card_data:L,computed_values:B.computed_values&&typeof B.computed_values=="object"?B.computed_values:{}};}let S={};for(let w of i){if(!w?.id)continue;let $=w.id;try{let B=q($),L=ie($);(L.length>0||B.processing)&&(S[$]={messages:L.map(K=>({role:String(K.role||"system"),text:String(K.text||""),files:Array.isArray(K.files)?K.files:[]})),receiving:!1,processing:!!B.processing});}catch{}}return {boardId:n,cardDefinitions:i,statusSnapshot:Te(),dataObjectsByToken:l,cardRuntimeById:b,cardChatsByCardId:S}}function v(i,d,l){let b=l?.syncBoard!==false,S=W(i);if(!S)throw Object.assign(new Error(`Card not found: ${i}`),{statusCode:404});let w=re(i);if(!w)throw Object.assign(new Error(`Card not found: ${i}`),{statusCode:404});let $=d(w)||w,B=S.cardStore.set({body:$});if(B.status!=="success")throw Object.assign(new Error(B.error||`Failed to persist card: ${i}`),{statusCode:500});if(b){let L=S.board.upsertCard({params:{cardId:i,restart:true}});if(L.status!=="success")throw Object.assign(new Error(L.error||`Failed to upsert card: ${i}`),{statusCode:500})}}function m(i,d){v(i,d,{syncBoard:true});}function A(i,d){v(i,d,{syncBoard:false});}function F(i,d){m(i,l=>{if(!d||typeof d!="object"||Object.keys(d).length===0)return l;function b(S,w,$){let B=String(w||"").split(".").filter(Boolean);if(!B.length)return;let L=S;for(let K=0;K<B.length-1;K++){let Y=B[K];(!L[Y]||typeof L[Y]!="object")&&(L[Y]={}),L=L[Y];}L[B[B.length-1]]=$;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let S=null,w=l.view;if(w&&Array.isArray(w.elements)){for(let $ of w.elements)if($?.data&&$.data.writeTo){S=$.data.writeTo;break}}S?b(l,S,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(l.card_data={...l.card_data||{},...d.fieldValues});}else {if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return l;for(let[S,w]of Object.entries(d))S!=="_stagedFiles"&&(w!==null&&typeof w=="object"&&!Array.isArray(w)&&l[S]!==null&&typeof l[S]=="object"&&!Array.isArray(l[S])?l[S]={...l[S],...w}:l[S]=w);}return l});}function z(i){let d=String(i||"").match(/^(\d+)[-_]/);return d?parseInt(d[1],10):0}function Q(i){let d=String(i||"").trim();if(!d)return "upload.bin";let l=Math.max(d.lastIndexOf("/"),d.lastIndexOf("\\"));return (l>=0?d.slice(l+1):d)||"upload.bin"}function me(i){let d=P(i),l=E(i);l&&l.clear(d);}function ae(i,d){let l=P(i),b=E(i),S=b?b.nextSerial(l):1,w=String(d||"system").toLowerCase().replace(/[^a-z0-9_-]/g,"_")||"system";return `${String(S).padStart(3,"0")}_${w}.txt`}function le(i,d,l,b){let S=new Date().toISOString(),w=P(i),$=j(i),B=ae(i,d||"system"),L=`${w}/${B}`,K=[],Y=typeof l=="string"?l.trim():"";Y&&K.push(Y);let ce=Array.isArray(b)?b:[];if(ce.length){K.length&&K.push(""),K.push("files:");for(let H of ce){if(!H||typeof H!="object")continue;let ee=typeof H.name=="string"?H.name:"file",de=typeof H.stored_name=="string"?H.stored_name:"";K.push(de?`- ${ee} -> ${de}`:`- ${ee}`);}}$.chats&&$.chats.putText(L,`${K.join(`
|
|
1
|
+
var BoardLiveCardsLocalStorage=(function(exports){'use strict';var Dr=Object.defineProperty;var qr=(e,t,r)=>t in e?Dr(e,t,{enumerable:true,configurable:true,writable:true,value:r}):e[t]=r;var Dt=(e,t,r)=>qr(e,t+"",r);var st="b64:";function Mr(e){let t=new TextEncoder().encode(e),r=globalThis.Buffer,n;if(r)n=r.from(t).toString("base64");else if(typeof btoa=="function"){let o="";for(let s of t)o+=String.fromCharCode(s);n=btoa(o);}else throw new Error("No base64 encoder available in this runtime");return n.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function Gr(e){let t=e.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-e.length%4)%4),r=globalThis.Buffer;if(r)return r.from(t,"base64").toString("utf8");if(typeof atob=="function"){let n=atob(t),o=new Uint8Array(n.length);for(let s=0;s<n.length;s+=1)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function re(e){return `${st}${Mr(JSON.stringify(e))}`}function we(e){if(!e.startsWith(st))throw new Error(`Invalid ref format (expected ${st}<base64url(json)>): ${e}`);let t;try{t=JSON.parse(Gr(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 qt(e,t,r){let n=e.tryAcquire();if(!n)return false;try{await t();}finally{n();}return r?.(),true}var be={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function ue(e){return e?Array.isArray(e.provides)?e.provides:[]:[]}function xe(e){return e?Array.isArray(e.requires)?e.requires:[]:[]}function at(e){return e.tasks??{}}function it(e){return e?e.status===be.FAILED||e.status===be.INACTIVATED:false}function Mt(e,t){return e.refreshStrategy??t?.refreshStrategy??"data-changed"}function Gt(e){return e.maxExecutions}function Ht(e,t){let r=new Set;for(let[n,o]of Object.entries(t))if(o.status===be.COMPLETED){let s=e.tasks[n];s&&ue(s).forEach(c=>r.add(c));}return Array.from(r)}function Ut(e,t){let r={};return e.forEach(n=>{let o=t[n];if(!o)return;ue(o).forEach(a=>{r[a]||(r[a]=[]),r[a].push(n);});}),r}function Vt(e,t,r){let n=e.tasks[t]??ct(),o={};if(r){let a=r.tasks[t],c=xe(a);for(let u of c)for(let[k,h]of Object.entries(r.tasks))if(ue(h).includes(u)){let R=e.tasks[k];R?.lastDataHash&&(o[u]=R.lastDataHash);break}}let s={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:o};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function Jt(e,t,r,n,o,s){let a=e.tasks[r]??ct(),c=t.tasks[r];if(!c)throw new Error(`Task "${r}" not found in graph`);let u;n&&c.on&&c.on[n]?u=c.on[n]:u=ue(c);let k=a.startConsumedHashes?{...a.startConsumedHashes}:{...a.lastConsumedHashes};if(!a.startConsumedHashes){let p=c.requires??[];for(let y of p)for(let[f,g]of Object.entries(t.tasks))if(ue(g).includes(y)){let $=e.tasks[f];$?.lastDataHash&&(k[y]=$.lastDataHash);break}}let h={...a,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:a.executionCount+1,lastEpoch:a.executionCount+1,lastDataHash:o,data:s,lastConsumedHashes:k,error:void 0},R=[...new Set([...e.availableOutputs,...u])];return {...e,tasks:{...e.tasks,[r]:h},availableOutputs:R,lastUpdated:new Date().toISOString()}}function Kt(e,t,r,n){let o=e.tasks[r]??ct(),s=t.tasks[r];if(s?.retry){let u=o.retryCount+1;if(u<=s.retry.max_attempts){let k={...o,status:"not-started",retryCount:u,lastUpdated:new Date().toISOString(),error:n};return {...e,tasks:{...e.tasks,[r]:k},lastUpdated:new Date().toISOString()}}}let a={...o,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:o.executionCount+1},c=e.availableOutputs;if(s?.on_failure&&s.on_failure.length>0&&(c=[...new Set([...e.availableOutputs,...s.on_failure])]),s?.circuit_breaker&&a.executionCount>=s.circuit_breaker.max_executions){let u=s.circuit_breaker.on_break;c=[...new Set([...c,...u])];}return {...e,tasks:{...e.tasks,[r]:a},availableOutputs:c,lastUpdated:new Date().toISOString()}}function zt(e,t,r,n){let o=e.tasks[t]??ct(),s={...o,progress:typeof n=="number"?n:o.progress,messages:[...o.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:o.status}]:[]],lastUpdated:new Date().toISOString()};return {...e,tasks:{...e.tasks,[t]:s},lastUpdated:new Date().toISOString()}}function Wt(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 ct(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Ke(e,t){let r=`live-${Date.now()}`,n={};for(let s of Object.keys(e.tasks))n[s]=Yt();let o={status:"running",tasks:n,availableOutputs:[],stuckDetection:{is_stuck:false,stuck_description:null,outputs_unresolvable:[],tasks_blocked:[]},lastUpdated:new Date().toISOString(),executionId:r,executionConfig:{executionMode:e.settings.execution_mode??"eligibility-mode",conflictStrategy:e.settings.conflict_strategy??"alphabetical",completionStrategy:e.settings.completion}};return {config:e,state:o}}function Xt(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:Vt(n,t.taskName,r)};case "task-completed":return {config:r,state:Jt(n,r,t.taskName,t.result,t.dataHash,t.data)};case "task-failed":return {config:r,state:Kt(n,r,t.taskName,t.error)};case "task-progress":return {config:r,state:zt(n,t.taskName,t.message,t.progress)};case "task-restart":return {config:r,state:Wt(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:Hr(n,t.action)};case "task-upsert":return wt(e,t.taskName,t.taskConfig);case "task-removal":return xt(e,t.taskName);case "node-requires-add":return _t(e,t.nodeName,t.tokens);case "node-requires-remove":return At(e,t.nodeName,t.tokens);case "node-provides-add":return Tt(e,t.nodeName,t.tokens);case "node-provides-remove":return Et(e,t.nodeName,t.tokens);default:return e}}function dt(e,t){return t.reduce((r,n)=>Xt(r,n),e)}function wt(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]:Yt()},lastUpdated:new Date().toISOString()}}}function xt(e,t){if(!e.config.tasks[t])return e;let{[t]:r,...n}=e.config.tasks,{[t]:o,...s}=e.state.tasks;return {config:{...e.config,tasks:n},state:{...e.state,tasks:s,lastUpdated:new Date().toISOString()}}}function _t(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=xe(n),s=r.filter(a=>!o.includes(a));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:[...o,...s]}}},state:e.state}}function At(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=xe(n),s=o.filter(a=>!r.includes(a));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,requires:s}}},state:e.state}}function Tt(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=ue(n),s=r.filter(a=>!o.includes(a));return s.length===0?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:[...o,...s]}}},state:e.state}}function Et(e,t,r){let n=e.config.tasks[t];if(!n)return e;let o=ue(n),s=o.filter(a=>!r.includes(a));return s.length===o.length?e:{config:{...e.config,tasks:{...e.config.tasks,[t]:{...n,provides:s}}},state:e.state}}function Me(e){return {version:1,config:e.config,state:e.state,snapshotAt:new Date().toISOString()}}function ze(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 Yt(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Hr(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 Ge(e){let{config:t,state:r}=e,n=at(t);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let s=Ur(n),a=Ht(t,r.tasks),c=new Set([...a,...r.availableOutputs]),u=[],k=[],h=[],R=[];for(let[y,f]of Object.entries(n)){let g=r.tasks[y],$=Mt(f,t.settings),E=$!=="once";if(g?.status===be.RUNNING||it(g))continue;let C=Gt(f);if(C!==void 0&&g&&g.executionCount>=C||f.circuit_breaker&&g&&g.executionCount>=f.circuit_breaker.max_executions||!E&&g?.status===be.COMPLETED)continue;if(E&&g?.status===be.COMPLETED){let A=xe(f),O=false;switch($){case "data-changed":{A.length>0&&A.some(H=>{for(let[K,ie]of Object.entries(n))if(ue(ie).includes(H)){let te=r.tasks[K];if(!te)continue;let Ie=g.lastConsumedHashes?.[H];return te.lastDataHash==null?te.executionCount>g.lastEpoch:te.lastDataHash!==Ie}return false})||(O=true);break}case "epoch-changed":{A.length>0&&A.some(H=>{for(let[K,ie]of Object.entries(n))if(ue(ie).includes(H)){let te=r.tasks[K];if(te&&te.executionCount>g.lastEpoch)return true}return false})||(O=true);break}case "time-based":{let J=f.refreshInterval??0;if(J<=0){O=true;break}let H=g.completedAt;if(!H){O=true;break}(Date.now()-Date.parse(H))/1e3<J&&(O=true);break}case "manual":O=true;break}if(O)continue}let _=xe(f);if(_.length===0){u.push(y);continue}let P=[],x=[],I=[];for(let A of _){if(c.has(A))continue;let O=s[A]||[];O.length===0?P.push(A):O.every(H=>it(r.tasks[H]))?I.push({token:A,failedProducer:O[0]}):x.push(A);}P.length>0?h.push({taskName:y,missingTokens:P}):I.length>0?R.push({taskName:y,failedTokens:I.map(A=>A.token),failedProducers:[...new Set(I.map(A=>A.failedProducer))]}):x.length>0?k.push({taskName:y,waitingOn:x}):u.push(y);}let p={};if(u.length>1){let y=Ut(u,n);for(let[f,g]of Object.entries(y))g.length>1&&(p[f]=g);}return {eligible:u,pending:k,unresolved:h,blocked:R,conflicts:p}}function Ur(e){let t={};for(let[r,n]of Object.entries(e)){for(let o of ue(n))t[o]||(t[o]=[]),t[o].push(r);if(n.on)for(let o of Object.values(n.on))for(let s of o)t[s]||(t[s]=[]),t[s].includes(r)||t[s].push(r);if(n.on_failure)for(let o of n.on_failure)t[o]||(t[o]=[]),t[o].includes(r)||t[o].push(r);}return t}var He=class{constructor(){Dt(this,"buffer",[]);}append(t){this.buffer.push(t);}drain(){let t=this.buffer;return this.buffer=[],t}get size(){return this.buffer.length}};function ut(e){let t=It(e);return Vr(t)}function It(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return "["+e.map(It).join(",")+"]";let t=e;return "{"+Object.keys(t).sort().map(n=>JSON.stringify(n)+":"+It(t[n])).join(",")+"}"}function Vr(e){let t=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let o=0;o<e.length;o++)t^=BigInt(e.charCodeAt(o)),t=t*r&n;return t.toString(16).padStart(16,"0")}function Jr(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 Kr(e){if(typeof Buffer<"u")return Buffer.from(e,"base64url").toString("utf8");if(typeof atob=="function"){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=new Uint8Array(n.length);for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);return new TextDecoder().decode(o)}throw new Error("No base64 decoder available in this runtime")}function Qt(e){let t=JSON.stringify({t:e,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return Jr(t)}function zr(e){try{let t=JSON.parse(Kr(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function We(e,t,r){let{handlers:n,onDrain:o}=t,s=new He,a="state"in e&&"config"in e?e:Ke(e),c=false,u=new Set,k=new Map(Object.entries(n)),h=new He,R=false,p=false;function y(){if(!c){if(R){p=true;return}R=true;try{do p=!1,f();while(p)}finally{R=false;}}}function f(){let C=h.drain(),_=s.drain(),P=[...C,..._];P.length>0&&(a=dt(a,P));let x=Ge(a);P.length>0&&o?.(P,a,x);for(let I of x.eligible)E(I);for(let I of P)if(I.type==="task-progress"){let{taskName:A,update:O}=I;if(!a.config.tasks[A])continue;let H=a.state.tasks[A];if(!H||H.status!=="running")continue;let K=Qt(A),ie=$(A,K,O).catch(te=>{c||(h.append({type:"task-failed",taskName:A,error:te.message??String(te),timestamp:new Date().toISOString()}),y());}).finally(()=>{u.delete(ie);});u.add(ie);}}function g(C){let P=a.config.tasks[C].requires??[],x=new Map;for(let[A,O]of Object.entries(a.config.tasks))for(let J of O.provides??[])x.set(J,A);let I={};for(let A of P){let O=x.get(A);O?I[A]=a.state.tasks[O]?.data:I[A]=void 0;}return I}async function $(C,_,P){let x=a.config.tasks[C],I=x.taskHandlers??[],A=g(C);for(let O of I){let J=k.get(O);if(!J)throw new Error(`Handler '${O}' not found in registry (task '${C}')`);let H={nodeId:C,state:A,taskState:a.state.tasks[C],config:x,callbackToken:_,update:P};if(await J(H)==="task-initiate-failure")throw new Error(`Handler '${O}' returned task-initiate-failure (task '${C}')`)}}function E(C){let P=a.config.tasks[C]?.taskHandlers;if(!P||P.length===0)return;h.append({type:"task-started",taskName:C,timestamp:new Date().toISOString()}),y();let x=Qt(C),I=$(C,x).catch(A=>{c||(h.append({type:"task-failed",taskName:C,error:A.message??String(A),timestamp:new Date().toISOString()}),y());}).finally(()=>{u.delete(I);});u.add(I);}return {push(C){c||(C.type==="task-completed"&&C.data&&!C.dataHash&&(C={...C,dataHash:ut(C.data)}),s.append(C),y());},pushAll(C){if(!c){for(let _ of C)_.type==="task-completed"&&_.data&&!_.dataHash?s.append({..._,dataHash:ut(_.data)}):s.append(_);y();}},resolveCallback(C,_,P){if(c)return;let x=zr(C);if(!x)return;let{taskName:I}=x;if(a.config.tasks[I]){if(P&&P.length>0)s.append({type:"task-failed",taskName:I,error:P.join("; "),timestamp:new Date().toISOString()});else {let A=_&&Object.keys(_).length>0?ut(_):void 0;s.append({type:"task-completed",taskName:I,data:_,dataHash:A,timestamp:new Date().toISOString()});}y();}},addNode(C,_){c||(s.append({type:"task-upsert",taskName:C,taskConfig:_,timestamp:new Date().toISOString()}),y());},removeNode(C){c||(s.append({type:"task-removal",taskName:C,timestamp:new Date().toISOString()}),y());},addRequires(C,_){c||(s.append({type:"node-requires-add",nodeName:C,tokens:_,timestamp:new Date().toISOString()}),y());},removeRequires(C,_){c||(s.append({type:"node-requires-remove",nodeName:C,tokens:_,timestamp:new Date().toISOString()}),y());},addProvides(C,_){c||(s.append({type:"node-provides-add",nodeName:C,tokens:_,timestamp:new Date().toISOString()}),y());},removeProvides(C,_){c||(s.append({type:"node-provides-remove",nodeName:C,tokens:_,timestamp:new Date().toISOString()}),y());},registerHandler(C,_){k.set(C,_);},unregisterHandler(C){k.delete(C);},retrigger(C){c||a.config.tasks[C]&&(s.append({type:"task-restart",taskName:C,timestamp:new Date().toISOString()}),y());},retriggerAll(C){if(!c){for(let _ of C)a.config.tasks[_]&&s.append({type:"task-restart",taskName:_,timestamp:new Date().toISOString()});y();}},snapshot(){return Me(a)},getState(){return a},getSchedule(){return Ge(a)},async waitForHandlers(){u.size>0&&await Promise.allSettled([...u]);},async dispose(C){C?.wait&&u.size>0&&await Promise.allSettled([...u]),c=true;}}}function lt(){return function(e){if(e==="./jsonata-sync.cjs")return typeof globalThis<"u"&&globalThis.__jsonataSync||typeof globalThis<"u"&&globalThis.jsonataSync;throw new Error("Unsupported require in browser bundle: "+e)}}var Wr=lt();Wr("./jsonata-sync.cjs");var Xr=lt(),ft=Xr("./jsonata-sync.cjs"),tr=ft;function Zt(e,t){if(!t||!e)return;let r=t.split("."),n=e;for(let o=0;o<r.length;o++){if(n==null)return;n=n[r[o]];}return n}function rr(e,t,r){let n=t.split("."),o=e;for(let s=0;s<n.length-1;s++)(o[n[s]]==null||typeof o[n[s]]!="object")&&(o[n[s]]={}),o=o[n[s]];o[n[n.length-1]]=r;}async function Yr(e,t){if(!e?.compute?.length)return e;e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values};for(let o of e.compute)try{let s=await ft(o.expr).evaluate(n);rr(e.computed_values,o.bindTo,s),n.computed_values=e.computed_values;}catch{}return e}function Qr(e,t){if(!e?.compute?.length)return {ok:true,node:e};e.card_data||(e.card_data={}),e.computed_values={},e._sourcesData=t?.sourcesData??{};let r=e.requires??{},n={card_data:e.card_data,requires:r,expects_data:r,fetched_sources:e._sourcesData,data:e.computed_values,computed_values:e.computed_values},o=[];for(let s of e.compute)try{let a=tr(s.expr).evaluate(n);rr(e.computed_values,s.bindTo,a),n.computed_values=e.computed_values;}catch(a){let c=a instanceof Error?a.message:String(a);o.push({bindTo:s.bindTo,error:c});}return o.length>0?{ok:true,node:e,errors:o}:{ok:true,node:e}}async function Zr(e,t,r){let n={...r??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return ft(e).evaluate(n)}function en(e,t){return t.startsWith("fetched_sources.")?Zt(e._sourcesData??{},t.slice(16)):Zt(e,t)}var er=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),tn=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function rn(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))tn.has(n)||t.push(`Unknown top-level key: "${n}"`);if((r.card_data==null||typeof r.card_data!="object"||Array.isArray(r.card_data))&&t.push("card_data: required, must be an object"),r.meta!=null)if(typeof r.meta!="object"||Array.isArray(r.meta))t.push("meta: must be an object");else {let n=r.meta;n.title!=null&&typeof n.title!="string"&&t.push("meta.title: must be a string"),n.tags!=null&&!Array.isArray(n.tags)&&t.push("meta.tags: must be an array");}if(r.requires!=null&&!Array.isArray(r.requires)&&t.push("requires: must be an array of strings"),r.provides!=null&&(Array.isArray(r.provides)?r.provides.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`provides[${o}]: must be an object with bindTo and ref`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`provides[${o}]: missing required "bindTo" string`),(typeof s.ref!="string"||!s.ref)&&t.push(`provides[${o}]: missing required "ref" string`);}}):t.push("provides: must be an array of { bindTo, ref } bindings")),r.compute!=null&&(Array.isArray(r.compute)?r.compute.forEach((n,o)=>{if(!n||typeof n!="object"||Array.isArray(n))t.push(`compute[${o}]: must be a compute step object`);else {let s=n;(typeof s.bindTo!="string"||!s.bindTo)&&t.push(`compute[${o}]: missing required "bindTo" property`),(typeof s.expr!="string"||!s.expr)&&t.push(`compute[${o}]: missing required "expr" string (JSONata expression)`);}}):t.push("compute: must be an array of compute steps")),r.source_defs!=null)if(!Array.isArray(r.source_defs))t.push("source_defs: must be an array");else {let n=new Set,o=new Set;r.source_defs.forEach((s,a)=>{if(!s||typeof s!="object"||Array.isArray(s))t.push(`source_defs[${a}]: must be an object`);else {let c=s;typeof c.bindTo!="string"||!c.bindTo?t.push(`source_defs[${a}]: missing required "bindTo" property`):(n.has(c.bindTo)&&t.push(`source_defs[${a}]: bindTo "${c.bindTo}" is not unique across source_defs`),n.add(c.bindTo)),typeof c.outputFile!="string"||!c.outputFile?t.push(`source_defs[${a}]: missing required "outputFile" property`):(o.has(c.outputFile)&&t.push(`source_defs[${a}]: outputFile "${c.outputFile}" is not unique across source_defs`),o.add(c.outputFile)),c.optionalForCompletionGating!=null&&typeof c.optionalForCompletionGating!="boolean"&&t.push(`source_defs[${a}]: optionalForCompletionGating must be a boolean`);}});}if(r.view!=null)if(typeof r.view!="object"||Array.isArray(r.view))t.push("view: must be an object");else {let n=r.view;!Array.isArray(n.elements)||n.elements.length===0?t.push("view.elements: required, must be a non-empty array"):n.elements.forEach((o,s)=>{if(!o||typeof o!="object"){t.push(`view.elements[${s}]: must be an object`);return}!o.kind||typeof o.kind!="string"?t.push(`view.elements[${s}].kind: required, must be a string`):er.has(o.kind)||t.push(`view.elements[${s}].kind: unknown kind "${o.kind}". Valid: ${[...er].join(", ")}`),o.data!=null&&(typeof o.data!="object"||Array.isArray(o.data))&&t.push(`view.elements[${s}].data: must be an object`);}),n.layout!=null&&(typeof n.layout!="object"||Array.isArray(n.layout))&&t.push("view.layout: must be an object"),n.features!=null&&(typeof n.features!="object"||Array.isArray(n.features))&&t.push("view.features: must be an object");}return {ok:t.length===0,errors:t}}async function nn(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return Promise.all(e.map(async n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,a]of Object.entries(n.projections))if(typeof a=="string"&&a.trim().length>0)try{o[s]=await ft(a).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}}))}function on(e,t){if(!e||e.length===0)return [];let r={card_data:t.card_data??{},requires:t.requires??{}};return e.map(n=>{let o={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[s,a]of Object.entries(n.projections))if(typeof a=="string"&&a.trim().length>0)try{o[s]=tr(a).evaluate(r);}catch{o[s]=void 0;}}return {...n,_projections:o}})}var $e={run:Yr,runSync:Qr,eval:Zr,resolve:en,validate:rn,enrichSources:nn,enrichSourcesSync:on};function nr(e){return JSON.stringify(e)}function or(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 pt(e,t){function r(){return e.readIndex()??{}}function n(o,s,a){let c=String(s||"").split(".").filter(Boolean);if(c.length===0)return a&&typeof a=="object"&&!Array.isArray(a)?a:{value:a};let u={...o},k=u;for(let h=0;h<c.length-1;h++){let R=c[h],p=k[R],y=p&&typeof p=="object"&&!Array.isArray(p)?{...p}:{};k[R]=y,k=y;}return k[c[c.length-1]]=a,u}return {readCard(o){let s=r()[o];return !s||!e.cardExists(s.key)?null:e.readCard(s.key)},readCardKey(o){return r()[o]?.key??null},readAllCards(){let o=[];for(let[s,a]of Object.entries(r())){if(!e.cardExists(a.key))continue;let c=e.readCard(a.key);c?o.push(c):t?.(`[card-store] could not read card "${s}" at key "${a.key}"`);}return o},readChecksumIndex(){let o={};for(let[s,a]of Object.entries(r()))o[s]=a.checksum;return o},changedSince(o){let s=r(),a=[];for(let[c,u]of Object.entries(s))o[c]!==u.checksum&&a.push(c);for(let c of Object.keys(o))s[c]||a.push(c);return a},validateUpsert(o,s){let a=r(),c=a[o],u=Object.entries(a).find(([,k])=>k.key===s);return c&&c.key!==s?{ok:false,error:`Card id "${o}" is already mapped to key "${c.key}", cannot remap to "${s}"`}:u&&u[0]!==o?{ok:false,error:`Key "${s}" is already mapped to card id "${u[0]}", cannot remap to "${o}"`}:{ok:true}},writeCard(o,s,a){let c=r(),u=a??c[o]?.key??e.defaultCardKey(o),k=e.writeCard(u,s);c[o]={key:u,checksum:k,updatedAt:new Date().toISOString()},e.writeIndex(c);},patchCard(o,s,a){let c=r(),u=c[o];if(!u||!e.cardExists(u.key))throw new Error(`card "${o}" not found`);let k=e.readCard(u.key);if(!k||typeof k!="object"||Array.isArray(k))throw new Error(`card "${o}" is not patchable`);let h=n(k,s,a),R=e.writeCard(u.key,h);c[o]={key:u.key,checksum:R,updatedAt:new Date().toISOString()},e.writeIndex(c);},removeCard(o){let s=r();s[o]&&(delete s[o],e.writeIndex(s));},readIndex(){return r()}}}function Ot(e,t){return {readSourceData(r,n){let o=e.read(`${r}/${n}`);if(o==null)return null;let s=o.trim();if(!s)return null;try{return JSON.parse(s)}catch{return s}},ingestSourceDataStaged(r,n,o,s){let a=t(o);e.write(`${r}/.staged/${s}/${n}`,a);},commitSourceData(r,n,o){let s=`${r}/.staged/${o}/${n}`,a=e.read(s);return a==null?false:(e.write(`${r}/${n}`,a),e.remove(s),true)},hasSource(r,n){return e.exists(`${r}/${n}`)}}}function ir(e){function t(r){let n=e.readAllEntries();if(!r)return n;let o=n.findIndex(s=>s.id===r);return o===-1?n:n.slice(o+1)}return {readEntriesAfterCursor(r){let n=t(r);return n.length===0?{events:[],newCursor:r}:{events:n.map(o=>o.event),newCursor:n[n.length-1].id}},pendingCount(r){return t(r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function cr(e,t){return {appendEntries(r,n){if(!r||n.length===0)return;let o=e.read(r)??[];e.write(r,[...o,...n]);},dispatchEntriesForJournalId(r,n){if(!r)return;let o=e.read(r);if(!(!o||o.length===0)){for(let s of o)try{n(s);}catch(a){let c=a instanceof Error?a.message:String(a);try{t(s,c);}catch{}}e.delete(r);}}}}var gt="v1",Le="board/graph",dr="board/lastJournalProcessedId";function sr(e){return `cards/${e}/runtime`}function ur(e){return {readRuntime(t){return e.read(sr(t))??{_sources:{}}},writeRuntime(t,r){e.write(sr(t),r);}}}function sn(e,t){let r={...e};for(let n of t.deleteKeys)delete r[n];return {...r,...t.shallowMerge}}function lr(e){return {readSnapshot(t){return e.readValues(t)},commitSnapshot(t,r){if(r.schemaVersion!==gt)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 o=sn(n.values,r);return {ok:true,newVersion:e.writeValues(t,o,r.deleteKeys)}}}}function fr(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 or(r.trim())},writeTaskExecutorRef(r){e.write("task-executor",nr(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);}}}function pr(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 an(e){return e?.lastRequestedAt?!e.lastFetchedAt||e.lastFetchedAt<e.lastRequestedAt:false}function cn(e,t){return e?.lastRequestedAt?an(e)?"in-flight":!e.lastFetchedAt||e.lastFetchedAt<t?"dispatch":"idle":"dispatch"}function dn(e,t){let r={...e,lastFetchedAt:t};return delete r.lastError,r}function ar(e,t){let r={...e,lastError:t};return delete r.lastFetchedAt,r}function mt(e,t){let r=t.state.tasks,n=t.config.tasks,o=Object.keys(r),s=Ge(t),a={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},c=new Map;for(let f of s.pending)c.set(f.taskName,f.waitingOn);for(let f of s.unresolved)c.set(f.taskName,f.missingTokens);for(let f of s.blocked)c.set(f.taskName,f.failedTokens);let u=new Map;for(let[f,g]of Object.entries(n))for(let $ of g.requires??[]){let E=u.get($)??[];E.push(f),u.set($,E);}let k=o.sort().map(f=>{let g=r[f],$=n[f]??{requires:[],provides:[]};g.status==="completed"?a.completed+=1:g.status==="failed"?a.failed+=1:g.status==="in-progress"&&(a.in_progress+=1);let E=$.requires??[],C=$.provides??[],_=Object.keys(g.data??{}).sort(),P=E.filter(H=>t.state.availableOutputs.includes(H)),x=E.filter(H=>!t.state.availableOutputs.includes(H)),I=c.get(f)??x,A=new Set;for(let H of C)for(let K of u.get(H)??[])K!==f&&A.add(K);let O=g.failedAt,J=g.error?{message:g.error,code:"TASK_FAILED",at:O,source:"task-runtime"}:void 0;return {name:f,status:g.status,error:J,requires:E,requires_satisfied:P,requires_missing:x,provides_declared:C,provides_runtime:_,blocked_by:I,unblocks:Array.from(A).sort(),runtime:{attempt_count:g.executionCount??0,restart_count:g.retryCount??0,in_progress_since:g.status==="in-progress"?g.startedAt??null:null,last_transition_at:g.lastUpdated??null,last_completed_at:g.completedAt??null,last_restarted_at:g.startedAt??null,status_age_ms:g.lastUpdated?0:null}}});a.pending=s.pending.length,a.blocked=s.blocked.length,a.unresolved=s.unresolved.length;let h=k.map(f=>({name:f.name,fanOut:f.unblocks.length})).sort((f,g)=>g.fanOut-f.fanOut||f.name.localeCompare(g.name)),R=h.length>0?h[0]:{name:null,fanOut:0},p=new Set;for(let f of Object.values(n))for(let g of f.requires??[])p.add(g);let y=0;for(let[f,g]of Object.entries(n)){let $=(g.requires??[]).length===0,C=(g.provides??[]).some(_=>(u.get(_)??[]).some(P=>P!==f));$&&!C&&(y+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:o.length,completed:a.completed,eligible:s.eligible.length,pending:a.pending,blocked:a.blocked,unresolved:a.unresolved,failed:a.failed,in_progress:a.in_progress,orphan_cards:y,topology:{edge_count:Array.from(p).length,max_fan_out_card:R.name,max_fan_out:R.fanOut}},cards:k}}function un(){return new Date().toISOString()}function gr(e,t,r,n,o,s,a){return async c=>{let u=[],k=r.cardStore.readCard(c.nodeId);if(!k)return "task-initiate-failure";let h=k.id,R=k.card_data??{},p=k.source_defs??[],y=p.filter(M=>M.optionalForCompletionGating!==true),f=r.cardRuntimeStore.readRuntime(h),g=false,$=()=>{g&&(r.cardRuntimeStore.writeRuntime(h,f),g=false);},E=M=>({...f._sources[M]??{}}),C=(M,q)=>{f._sources[M]=q,g=true;},_=c.taskState?.executionCount??0,P=f._lastExecutionCount;if(typeof P=="number"&&P!==_&&(f._sources={},g=true),P!==_&&(f._lastExecutionCount=_,g=true),c.update){let M=c.update,q=M.outputFile;if(q){let v=E(q);if(M.failure)C(q,ar(v,M.reason??"unknown"));else {let m=M.rqt;if(!v.lastFetchedAt||m>v.lastFetchedAt){let T=typeof M.deliveryToken=="string"?M.deliveryToken:void 0,F=false;T&&(F=r.fetchedSourcesStore.commitSourceData(h,q,T)),F?C(q,dn(v,m)):C(q,ar(v,`source delivery commit failed for ${q} token=${String(T)}`));}}$();}}let x={};for(let M of p)if(M.outputFile){let q=r.fetchedSourcesStore.readSourceData(h,M.outputFile);q!==null&&(x[M.bindTo]=q);}let I={};for(let[M,q]of Object.entries(c.state??{}))if(q!==null&&typeof q=="object"&&!Array.isArray(q)){let v=q[M];I[M]=v!==void 0?v:q;}else I[M]=q;let A={id:h,card_data:{...R},requires:I,source_defs:p,compute:k.compute};A._sourcesData=x,k.compute&&$e.runSync(A,{sourcesData:x}),(s??r.outputStore.writeComputedValues.bind(r.outputStore))(h,A.computed_values??{});let O={...k},J=$e.enrichSourcesSync(Array.isArray(k.source_defs)?k.source_defs:void 0,{card_data:k.card_data,requires:I}),H=e.value;O.source_defs=Array.isArray(J)?J.map(M=>({...M,boardDir:typeof M.boardDir=="string"&&M.boardDir?M.boardDir:H})):J;let K=un(),ie=c.update?void 0:K,te=y.filter(M=>{let q=M.outputFile;if(typeof q!="string"||!q)return true;let v=E(q);ie&&(v={...v,queueRequestedAt:ie},C(q,v));let m=v.queueRequestedAt??v.lastRequestedAt??K,T=cn(v,m);return T==="in-flight"?false:T==="dispatch"});if($(),te.length>0){let M=false,q=K;for(let v of te){let m=v.outputFile;if(typeof m!="string"||!m)continue;let T=E(m),F=T.queueRequestedAt??K;C(m,{...T,lastRequestedAt:F}),q=F,M=true;}return M&&$(),M&&(u.push({taskKind:"source-fetch",payload:{boardRef:re(e),enrichedCard:O,callbackToken:c.callbackToken,rqt:q}}),r.executionRequestStore.appendEntries(t,u)),"task-initiated"}let Ie=k.provides??[],Oe={};for(let{bindTo:M,ref:q}of Ie)Oe[M]=$e.resolve(A,q);return (a??r.outputStore.writeDataObjects.bind(r.outputStore))(Oe),p.filter(M=>{if(M.optionalForCompletionGating!==true)return false;let q=E(M.outputFile);return !q.lastRequestedAt||!q.lastFetchedAt?true:q.lastFetchedAt<=q.lastRequestedAt}).length>0&&u.push({taskKind:"source-fetch",payload:{boardRef:re(e),enrichedCard:O,callbackToken:c.callbackToken,rqt:K}}),n(c.nodeId,Oe),u.length>0&&r.executionRequestStore.appendEntries(t,u),"task-initiated"}}var jt={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function mr(e){return {[Le]:e.graph,[dr]:e.lastDrainedJournalId}}function hr(e){let t=e[Le],r=e[dr];if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${Le}`);return {graph:t,lastDrainedJournalId:typeof r=="string"?r:""}}function yr(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 se(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function Q(e){return {status:"fail",error:e}}function ae(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function ln(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 br(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=t+"=".repeat((4-t.length%4)%4),n=atob(r),o=Uint8Array.from(n,s=>s.charCodeAt(0));return new TextDecoder().decode(o)}function ht(e){try{let t=JSON.parse(br(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function fn(e){return ln(JSON.stringify(e))}function kr(e){try{let t=JSON.parse(br(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function fe(){return new Date().toISOString()}function Rr(e,t){let r=t.onWarn??(()=>{}),n=re(e);function o(v){if(v.length!==0)try{let m=t.publishBoardChangeNotifications?.(v);m&&typeof m.catch=="function"&&m.catch(T=>r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${T instanceof Error?T.message:String(T)}`));}catch(m){r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${m instanceof Error?m.message:String(m)}`);}}function s(){let v=c().readCardStoreRef();if(!v)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let m=t.kvStorageForRef(v);return {readIndex(){return m.read("_index")},writeIndex(T){m.write("_index",T);},readCard(T){return m.read(T)},writeCard(T,F){return m.write(T,F),t.hashFn(F)},cardExists(T){return m.read(T)!==null},defaultCardKey(T){return T}}}let a={readValues(v){let m=t.kvStorage("state-snapshot"),T=m.listKeys().sort();if(T.length===0)return {version:null,values:{}};let F={};for(let z of T)F[z]=m.read(z);return {version:t.hashFn(F),values:F}},writeValues(v,m,T){let F=t.kvStorage("state-snapshot");for(let z of T)F.delete(z);for(let[z,X]of Object.entries(m))F.write(z,X);return t.hashFn(m)}},c=()=>fr(t.kvStorage("config")),u=()=>lr(a),k=()=>ir(t.journalAdapter()),h=()=>pt(s(),r),R=()=>{let v=c().readOutputsStoreRef();if(!v)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return pr(t.kvStorageForRef(v))};function p(){return !!u().readSnapshot(e.value).values[Le]}function y(){let v=u().readSnapshot(e.value);if(!v.values[Le])throw new Error(`Board not initialized at ${e.value}`);return hr(v.values)}function f(v,m){let T=u().commitSnapshot(e.value,{schemaVersion:gt,expectedVersion:m,commitId:t.genId(),committedAt:fe(),deleteKeys:[],shallowMerge:mr(v)});if(!T.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${m??"null"} current=${T.currentVersion??"null"}`)}function g(v){k().appendEvent(v);}async function $(){let v=(j,D)=>{let Y=j.payload,ke=(Y?.enrichedCard??{}).id??Y?.cardId??"unknown";g({type:"task-failed",taskName:ke,error:D,timestamp:fe()});},m=cr(t.kvStorage("execution-requests"),v),T=ur(t.kvStorage("card-runtime")),F=Ot(t.blobStorage("sources"),j=>t.resolveBlob(j)),z=new Map,X={readRuntime(j){return z.get(j)??T.readRuntime(j)},writeRuntime(j,D){z.set(j,D);}},ye=[],ce=new Map,me={readSourceData(j,D){let Y=`${j}/${D}`;return ce.has(Y)?ce.get(Y):F.readSourceData(j,D)},ingestSourceDataStaged(j,D,Y,ve){F.ingestSourceDataStaged(j,D,Y,ve);},commitSourceData(j,D,Y){let ve=`${j}/.staged/${Y}/${D}`,Pe=t.blobStorage("sources").read(ve);if(Pe==null)return false;let i=`${j}/${D}`,d=Pe.trim();try{ce.set(i,JSON.parse(d));}catch{ce.set(i,d);}return ye.push({cardId:j,outputFile:D,deliveryToken:Y}),true},hasSource(j,D){let Y=`${j}/${D}`;return ce.has(Y)?true:F.hasSource(j,D)}},le={cardStore:h(),cardRuntimeStore:X,fetchedSourcesStore:me,outputStore:R(),executionRequestStore:m},pe=y(),Re=ze(pe.graph),{events:_e,newCursor:Ae}=k().readEntriesAfterCursor(pe.lastDrainedJournalId),Se=[],W=[],Te=[],Ze=new Map,et=(j,D)=>{Se.push({type:"task-completed",taskName:j,data:D,timestamp:fe()});},Ve=(j,D)=>g({type:"task-failed",taskName:j,error:D,timestamp:fe()}),Ee=We(Re,{handlers:{"card-handler":gr(e,Ae,le,et,Ve,(j,D)=>{W.push({cardId:j,values:D});},j=>{Te.push(j);})}});for(Se=_e;Se.length>0;){let j=Se;Se=[];for(let D of j)if(D.type==="task-restart"){let Y=le.cardStore.readCard(D.taskName);Y&&Ze.set(D.taskName,Y);}Ee.pushAll(j),await Ee.waitForHandlers();}let Je=Ee.getState();await Ee.dispose({wait:true});let rt=u().readSnapshot(e.value).version;f({lastDrainedJournalId:Ae,graph:Me(Je)},rt);for(let{cardId:j,values:D}of W)le.outputStore.writeComputedValues(j,D);for(let j of Te)le.outputStore.writeDataObjects(j);for(let[j,D]of z)T.writeRuntime(j,D);for(let{cardId:j,outputFile:D,deliveryToken:Y}of ye)F.commitSourceData(j,D,Y);let je;try{je=mt(n,Je),le.outputStore.writeStatusSnapshot(je);}catch(j){r(`[board-live-cards-public] status publish failed: ${j instanceof Error?j.message:String(j)}`);}let Ce=[];for(let{cardId:j,values:D}of W)Ce.push({kind:"computed_values",cardId:j,values:D});for(let j of Te)for(let[D,Y]of Object.entries(j))D&&Ce.push({kind:"data_object",key:D,payload:Y});for(let[j,D]of Ze)Ce.push({kind:"card_refreshed",cardId:j,card:D});je!==void 0&&Ce.push({kind:"status",status:je}),o(Ce);let Ct=c().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:re({kind:"built-in",value:"source-cli-task-executor"})};m.dispatchEntriesForJournalId(Ae,j=>{if(j.taskKind!=="source-fetch"){r(`[process-accumulated-events] unknown taskKind "${j.taskKind}" \u2014 skipping`);return}let D=j.payload,Y=D.enrichedCard?.id??"unknown",ve=D.enrichedCard?.source_defs??[];for(let ke of ve){if(!ke.outputFile){r(`[dispatch] source "${ke.bindTo}" has no outputFile \u2014 skipping`);continue}let Pe=fn({cbk:D.callbackToken,rg:e.value,br:re(e),cid:Y,b:ke.bindTo,d:ke.outputFile,cs:void 0,rqt:D.rqt});t.dispatchExecution(Ct,{source_def:ke,base_ref:re(e),callback:{token:Pe,via:t.selfRef}}).catch(i=>Ve(Y,i instanceof Error?i.message:String(i)));}});}async function E(){try{let v=()=>{let T=y(),{events:F}=k().readEntriesAfterCursor(T.lastDrainedJournalId);F.length<=0||(E(),t.requestProcessAccumulated?.());},m=await qt(t.lock,$,v);return se({ran:m!==!1})}catch(v){return ae(v)}}function C(v){try{let m=v.params?.cardStoreRef;if(!m)return Q("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!p()){let X=Ke(jt);f({lastDrainedJournalId:"",graph:Me(X)},null);}let T=v.params?.outputsStoreRef;if(!T)return Q("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let F=c();F.writeCardStoreRef(m),F.writeOutputsStoreRef(T);let z=v.body??{};z["task-executor-ref"]&&F.writeTaskExecutorRef(z["task-executor-ref"]),Object.prototype.hasOwnProperty.call(z,"chat-handler-flow")&&F.writeChatHandlerFlow(z["chat-handler-flow"]);try{R().writeStatusSnapshot(mt(n,ze(y().graph)));}catch{}return se()}catch(m){return ae(m)}}function _(v){try{let m=R().readStatusSnapshot();if(!m){m=mt(n,ze(y().graph));try{R().writeStatusSnapshot(m);}catch{}}return se(m)}catch(m){return ae(m)}}function P(v){try{let m=v.params?.id;return m?(g({type:"task-removal",taskName:m,timestamp:fe()}),E(),se()):Q("removeCard requires params.id")}catch(m){return ae(m)}}function x(v){try{let m=v.params?.id;return m?(g({type:"task-restart",taskName:m,timestamp:fe()}),E(),se()):Q("retrigger requires params.id")}catch(m){return ae(m)}}async function I(v){return E()}function A(v){try{let m=v.params?.cardId,T=v.params?.all,F=!!v.params?.restart;if(!m&&!T)return Q("upsertCard requires --card-id <id> or --all");let z=T?h().readAllCards().map(X=>X.id):[m];for(let X of z)if(!h().readCard(X))return Q(`Card "${X}" not found in board at ${e.value}`);for(let X of z){let ye=h().readCard(X),ce=yr(ye),me=t.hashFn(ce),le=t.kvStorage("card-upsert"),pe=le.read(X),Re=pe?.taskConfigHash!==me;if(!(!Re&&!F)){if(Re){let _e=pe?.blobRef??h().readCardKey(X)??X;g({type:"task-upsert",taskName:X,taskConfig:ce,timestamp:fe()}),le.write(X,{blobRef:_e,taskConfigHash:me,updatedAt:fe()});}F&&g({type:"task-restart",taskName:X,timestamp:fe()});}}return E(),se()}catch(m){return ae(m)}}function O(v){try{let m=v.params?.token;if(!m)return Q("taskFailed requires params.token");let T=v.params?.error??"unknown error",F=ht(m);return F?(g({type:"task-failed",taskName:F.taskName,error:T,timestamp:fe()}),E(),se()):Q("Invalid callback token")}catch(m){return ae(m)}}function J(v){try{let m=v.params?.token;if(!m)return Q("taskProgress requires params.token");let F=(v.body??{}).update??{},z=ht(m);return z?(g({type:"task-progress",taskName:z.taskName,update:F,timestamp:fe()}),E(),se()):Q("Invalid callback token")}catch(m){return ae(m)}}function H(v){try{let m=v.params?.token,T=v.params?.ref;if(!m)return Q("sourceDataFetched requires params.token");if(!T)return Q("sourceDataFetched requires params.ref");let F=kr(m);if(!F)return Q("Invalid source token");let{cbk:z,cid:X,b:ye,d:ce,cs:me,rqt:le}=F,pe=Ot(t.blobStorage("sources"),Se=>t.resolveBlob(Se)),Re=t.genId();pe.ingestSourceDataStaged(X,ce,we(T),Re);let _e=ht(z);if(!_e)return Q("Invalid callback token embedded in source token");let Ae=fe();return g({type:"task-progress",taskName:_e.taskName,update:{bindTo:ye,outputFile:ce,fetchedAt:Ae,deliveryToken:Re,sourceChecksum:me,rqt:le},timestamp:Ae}),E(),se()}catch(m){return ae(m)}}function K(v){try{let m=v.params?.token,T=v.params?.reason??"unknown";if(!m)return Q("sourceDataFetchFailure requires params.token");let F=kr(m);if(!F)return Q("Invalid source token");let{cbk:z,b:X,d:ye,cs:ce}=F,me=ht(z);return me?(g({type:"task-progress",taskName:me.taskName,update:{bindTo:X,outputFile:ye,failure:!0,reason:T,sourceChecksum:ce},timestamp:fe()}),E(),se()):Q("Invalid callback token embedded in source token")}catch(m){return ae(m)}}function ie(v){try{let m=c().readCardStoreRef();return m?se({storeRef:m}):Q(`Board at ${e.value} has no card store configured`)}catch(m){return ae(m)}}function te(v){try{let m=c().readOutputsStoreRef();return m?se({storeRef:m}):Q(`Board at ${e.value} has no outputs store configured`)}catch(m){return ae(m)}}function Ie(v){try{let m=v.params?.key;if(!m)return Q("getConfig requires params.key");let T=c(),F;switch(m){case "task-executor":F=T.readTaskExecutorRef()??null;break;case "chat-handler-flow":F=T.readChatHandlerFlow()??null;break;case "card-store-ref":F=T.readCardStoreRef();break;case "outputs-store-ref":F=T.readOutputsStoreRef();break;default:return Q(`getConfig: unknown key "${m}"`)}return se({value:F})}catch(m){return ae(m)}}function Oe(v){try{let m=v.params?.key;if(!m)return Q("getOutputsDataObject requires params.key");let T=R().readDataObject(m);return se(T)}catch(m){return ae(m)}}function Qe(v){try{return se(R().readAllDataObjects())}catch(m){return ae(m)}}function M(v){try{let m=v.params?.key;if(!m)return Q("getOutputsComputedValues requires params.key");let T=R().readComputedValues(m);return se(T)}catch(m){return ae(m)}}function q(v){try{return se(R().readAllComputedValues())}catch(m){return ae(m)}}return {init:C,status:_,getCardStoreRef:ie,getOutputsStoreRef:te,getConfig:Ie,getOutputsDataObject:Oe,getAllOutputsDataObjects:Qe,getOutputsComputedValues:M,getAllOutputsComputedValues:q,removeCard:P,retrigger:x,processAccumulatedEvents:I,upsertCard:A,taskFailed:O,taskProgress:J,sourceDataFetched:H,sourceDataFetchFailure:K}}function Sr(e){function t(o){return {status:"success",data:o}}function r(o){return {status:"fail",error:o}}function n(o){return {status:"error",error:o instanceof Error?o.message:String(o)}}return {get(o){try{let s=o.params?.id;if(s){let a=e.readCard(s);return a?t({cards:[a]}):r(`card "${s}" not found`)}return t({cards:e.readAllCards()})}catch(s){return n(s)}},set(o){try{let s=o.body;if(s==null)return r("set requires a body (card object or array of cards)");let a=Array.isArray(s)?s:[s];for(let c of a){if(typeof c.id!="string")return r("each card must have a string `id` field");e.writeCard(c.id,c);}return t({count:a.length})}catch(s){return n(s)}},del(o){try{let s=o.body?.ids??[],a=o.params?.id,c=a?[...s,a]:s;if(c.length===0)return r("del requires body.ids (string[]) or params.id");for(let u of c)e.removeCard(u);return t({count:c.length})}catch(s){return n(s)}},patch(o){try{let s=o.params?.id,a=o.params?.path;if(!s)return r("patch requires params.id");if(!a)return r("patch requires params.path");let c=o.body,u=c&&Object.prototype.hasOwnProperty.call(c,"value")?c.value:o.body;return e.patchCard(s,a,u),t({count:1})}catch(s){return n(s)}}}}var yt=".artifacts-index.json";function Cr(){return new Date().toISOString()}function vr(e){return new TextEncoder().encode(e).byteLength}function Xe(e){let t=e.read(yt);if(!t)return {entries:{}};try{let r=JSON.parse(t);if(r&&r.entries&&typeof r.entries=="object")return r}catch{}return {entries:{}}}function Nt(e,t){e.write(yt,JSON.stringify(t,null,2));}function pn(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function wr(e,t,r){e.entries[t]={key:t,size:r.size,updatedAt:r.updatedAt,contentType:r.contentType};}function Bt(e){let t=String(e||"").match(/^(\d+)[-_]/);return t?parseInt(t[1],10):0}function gn(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 mn(e){return String(e||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function hn(e){if(!e||e===".")return "";let t=String(e).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return t?`.${t}`:""}function yn(e){let t=gn(e),r=t.lastIndexOf(".");return r<=0||r===t.length-1?{stem:t,ext:""}:{stem:t.slice(0,r),ext:t.slice(r)}}function kn(e){let t=e.lastIndexOf("/");return t>=0?e.slice(t+1):e}function $t(e){function t(r){let n=e.stat?pn(e.stat(r)):null;if(n)return n;let s=Xe(e).entries[r];if(s)return {...s};if(!e.exists(r))return null;let a=e.read(r);return a===null?{key:r}:{key:r,size:vr(a)}}return {exists(r){return e.exists(r)},putText(r,n,o="text/plain; charset=utf-8"){e.write(r,n);let s=t(r)??{key:r};s.contentType=o,s.updatedAt=s.updatedAt??Cr(),s.size=s.size??vr(n);let a=Xe(e);return wr(a,r,s),Nt(e,a),s},putBytes(r,n,o="application/octet-stream"){if(e.writeBytes)e.writeBytes(r,n);else {let c=JSON.stringify({__kind:"bytes-array",data:[...n]});e.write(r,c);}let s=t(r)??{key:r};s.contentType=o,s.updatedAt=s.updatedAt??Cr(),s.size=s.size??n.byteLength;let a=Xe(e);return wr(a,r,s),Nt(e,a),s},getText(r){let n=e.read(r);if(n===null){if(!e.readBytes)return null;let o=e.readBytes(r);return o===null?null:Buffer.from(o).toString("utf-8")}try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new TextDecoder("utf-8").decode(new Uint8Array(o.data))}catch{}return n},getBytes(r){if(e.readBytes){let o=e.readBytes(r);if(o!==null)return o}let n=e.read(r);if(n===null)return null;try{let o=JSON.parse(n);if(o&&o.__kind==="bytes-array"&&Array.isArray(o.data))return new Uint8Array(o.data)}catch{}return new TextEncoder().encode(n)},head:t,list(r=""){let n=new Map;if(e.listKeys)for(let s of e.listKeys(r)){if(s===yt)continue;let a=t(s)??{key:s};n.set(s,a);}let o=Xe(e);for(let[s,a]of Object.entries(o.entries))s===yt||r&&!s.startsWith(r)||n.has(s)||n.set(s,{...a});return [...n.values()].sort((s,a)=>s.key.localeCompare(a.key))},remove(r){e.remove(r);let n=Xe(e);delete n.entries[r],Nt(e,n);}}}function xr(e,t){let r=t?.indexFileName;function n(R){return `${R}/${r}`}function o(R){let p=e.getText(n(R));if(!p)return [];try{let y=JSON.parse(p);return Array.isArray(y)?y.filter(f=>f&&typeof f.stored_name=="string").map(f=>({serial:Number(f.serial||Bt(String(f.stored_name))||0),role:String(f.role||"system").toLowerCase(),stored_name:String(f.stored_name),path:typeof f.path=="string"?f.path:`${R}/chats/${String(f.stored_name)}`,updated_at:typeof f.updated_at=="string"?f.updated_at:null})):[]}catch{return []}}function s(R,p){e.putText(n(R),JSON.stringify(p,null,2),"application/json; charset=utf-8");}function a(R){let p=o(R),y=0;for(let f of p){let g=Number(f.serial||0);Number.isFinite(g)&&g>y&&(y=g);}return y+1}function c(R,p){let y=o(R);y.push(p),s(R,y);}function u(R){let p=o(R),y=[];for(let f of p){let g=`${R}/${f.stored_name}`,$=e.getText(g);$!==null&&y.push({serial:Number(f.serial||Bt(f.stored_name)||0),role:String(f.role||"system").toLowerCase(),text:$,path:typeof f.path=="string"?f.path:`${R}/chats/${f.stored_name}`,stored_name:f.stored_name,updated_at:f.updated_at||null});}return y.sort((f,g)=>f.serial-g.serial||f.stored_name.localeCompare(g.stored_name)),y}function k(R){let p=`${R}/`;for(let y of e.list(p))e.remove(y.key);}function h(R){let p=`${R}/`,y=e.list(p),f=0,g=0,$=false;for(let E of y){let C=E.key.slice(p.length);if(C===".processing"){$=true;continue}if(!/^(\d+)[-_]([a-z0-9_-]+)\.txt$/i.test(C))continue;f+=1;let _=E.updatedAt?Number(new Date(E.updatedAt).getTime()||0):0;_>g&&(g=_);}return {count:f,latest_mtime_ms:g,processing:$}}return {indexKey:n,loadIndex:o,saveIndex:s,nextSerial:a,appendIndexRecord:c,readRecords:u,clear:k,readSignal:h}}function _r(e){function t(o,s){let a=0,c=[];Array.isArray(s)&&c.push(...s);for(let u of e.list(`${o}/`))c.push(kn(u.key));for(let u of c){let k=Bt(u);Number.isFinite(k)&&k>a&&(a=k);}return a+1}function r(o,s,a){let c=Number(a?.maxLen||32),{stem:u,ext:k}=yn(o),h=hn(k),R=mn(u),p=`${String(s).padStart(3,"0")}-`,y=h,f=c-p.length-y.length;f<1&&(y="",f=c-p.length);let g=R.slice(0,Math.max(1,f)),$=`${p}${g}${y}`;return $.length>c&&($=$.slice(0,c).replace(/\.$/,"")),$}function n(o,s,a){let c=t(o,a?.seedNames),u=r(s,c,{maxLen:a?.maxLen});for(;e.exists(`${o}/${u}`);)c+=1,u=r(s,c,{maxLen:a?.maxLen});return u}return {nextSerial:t,buildStoredName:r,allocateStoredName:n}}function Ar(){function e(o,s){if(!Array.isArray(o))return [];let a=[];for(let c of o){if(!c||typeof c!="object")continue;let u=c;typeof u.stored_name=="string"&&a.push({name:typeof u.name=="string"?u.name:u.stored_name,stored_name:u.stored_name,size:typeof u.size=="number"&&Number.isFinite(u.size)?u.size:null,mime_type:typeof u.mime_type=="string"?u.mime_type:null,path:typeof u.path=="string"?u.path:null,uploaded_at:typeof u.uploaded_at=="string"?u.uploaded_at:s||null});}return a}function t(o){return !o||typeof o!="object"?[]:e(o.files,void 0)}function r(o,s){let a=t(o);if(s.length===0)return o.files=a,a;let c=new Set(a.map(u=>u.stored_name));for(let u of s)c.has(u.stored_name)||(a.push(u),c.add(u.stored_name));return o.files=a,a}function n(o,s,a){let c=t(o);if(!Number.isInteger(s)||s<0||s>=c.length)return {ok:false,reason:"index_out_of_range"};let u=c[s];return !u||!u.stored_name?{ok:false,reason:"missing_stored_name"}:a&&a!==u.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:u}}return {read:t,normalizeIncoming:e,merge:r,resolve:n}}var bn={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},Rn=32;function Sn(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function Tr(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 Er(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)Er(e,n);return}r.kind==="status"&&Tr(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);}function Ir(e){let t=String(e.apiBasePath||"/api/board").replace(/\/$/,""),r={...bn,...e.corsHeaders||{}},n=e.boardId||"",o=e.logger||{info:console.log,warn:console.warn,error:console.error},s=e.invocationAdapter,a=e.chatFlowRunner||null,c=e.notificationTransport||null,u=e.serverUrl||null,k=e.executionExtra||{},h=new Map,R=new Map,p=null;function y(i){let d=Rr(i.baseRef,i.boardAdapter),l=i.boardAdapter.kvStorageForRef(i.cardStoreRef),S=Sr(pt({readIndex:()=>l.read("_index"),writeIndex:N=>l.write("_index",N),readCard:N=>l.read(N),writeCard:(N,V)=>(l.write(N,V),N),cardExists:N=>l.read(N)!==null,defaultCardKey:N=>N},o.warn)),w=i.artifactsAdapter||i.boardAdapter,B=null,L=null;return {label:i.label,board:d,cardStore:S,get filesArtifacts(){return B??(B=$t(w.blobStorage("files")))},get chatsArtifacts(){return L??(L=$t(w.blobStorage("chats")))},boardAdapter:i.boardAdapter,cardStoreRef:i.cardStoreRef,outputsStoreRef:i.outputsStoreRef,notifyRef:i.notifyRef,taskExecutorRef:i.taskExecutorRef,chatHandlerRef:i.chatHandlerRef,chatHandlerFlow:i.chatHandlerFlow,inferenceAdapterRef:i.inferenceAdapterRef,notification:Sn(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let f=e.boards.map(y),g=new Map;function $(i){return g.get(i)??0}function E(i){let d=f[$(i)];return {files:d?d.filesArtifacts:null,chats:d?d.chatsArtifacts:null}}function C(i){let d=E(i);return d.chats?xr(d.chats,{indexFileName:".index.json"}):null}function _(i){let d=E(i);return d.files?_r(d.files):null}function P(){return Ar()}function x(i){return String(i||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function I(i){if(!i||i.notificationTeardown||!c||!i.notifyRef)return;let d=await c.subscribe(i.notifyRef,l=>{Er(i.notification,l);let b=l.kind==="notification-batch"?l.notifications:[l];ve(b);});i.notificationTeardown=d;}async function A(i){if(!i||i.initialized)return;let d={cardStoreRef:i.cardStoreRef,outputsStoreRef:i.outputsStoreRef},l={};i.taskExecutorRef&&(l["task-executor-ref"]=i.taskExecutorRef),i.chatHandlerFlow!==void 0&&(l["chat-handler-flow"]=i.chatHandlerFlow),i.inferenceAdapterRef&&(l["inference-adapter-ref"]=i.inferenceAdapterRef);let b=i.board.init({params:d,body:l});if(b.status!=="success")throw Object.assign(new Error(b.error||`init failed for ${i.label}`),{statusCode:500});if(await I(i),!i.chatHandlerFlow&&i.chatHandlerRef&&s.describe)try{let S=await s.describe(i.chatHandlerRef);S&&S.kind!=="chat-handler"?o.warn(`[init] chat-handler describe returned kind="${S.kind}", expected "chat-handler" for ${i.label}`):S&&o.info(`[init] chat-handler validated: ${S.name} (protocol ${S.protocolVersion}) for ${i.label}`);}catch(S){o.warn(`[init] chat-handler describe failed for ${i.label}: ${S?.message||String(S)}`);}i.initialized=true;}function O(i){if(!i.boardAdapter.publishBoardChangeNotifications)return;let d=[],l=i.board.status({});l.status==="success"&&l.data!=null&&Tr(l.data)&&d.push({kind:"status",status:l.data});let b=i.board.getAllOutputsDataObjects({});if(b.status==="success"&&b.data!=null)for(let[w,B]of Object.entries(b.data))w&&d.push({kind:"data_object",key:w,payload:B});let S=i.board.getAllOutputsComputedValues({});if(S.status==="success"&&S.data!=null)for(let[w,B]of Object.entries(S.data))w&&d.push({kind:"computed_values",cardId:w,values:B});d.length>0&&i.boardAdapter.publishBoardChangeNotifications(d);}function J(i,d){if(!i||i.cardsBootstrapped)return;let l=i.cardStore.get({}),b=l.status==="success"&&Array.isArray(l.data?.cards)?l.data.cards:[];for(let S of b)typeof S.id=="string"&&(g.set(S.id,d),i.board.upsertCard({params:{cardId:S.id}}));i.cardsBootstrapped=true;}async function H(){for(let i of f)await A(i);}async function K(){await H();for(let i=0;i<f.length;i++)O(f[i]),J(f[i],i);}function ie(i){return f[$(i)]??null}function te(i){let d=ie(i);if(!d)return null;let l=d.cardStore.get({params:{id:i}});if(l.status!=="success")return null;let b=Array.isArray(l.data?.cards)?l.data.cards:[];return b.length>0?b[0]:null}function Ie(){let i=l=>{if(!l||!l.cardStore)return [];let b=l.cardStore.get({});return b.status!=="success"||!Array.isArray(b.data?.cards)?[]:b.data.cards},d=[];for(let l of f)d.push(...i(l));return d}function Oe(){let i=f.map(w=>{try{let L=w.boardAdapter.kvStorageForRef(w.outputsStoreRef).read("status");if(L!=null)return L}catch{}return w.notification.status}).filter(Boolean);if(i.length===0)return null;if(i.length===1)return i[0];let d=[],l=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],b={};for(let w of l)b[w]=0;for(let w of i){let B=w,L=Array.isArray(B.cards)?B.cards:[];d.push(...L);for(let N of l)b[N]+=Number(B?.summary?.[N]||0);}let S=i[0];return {...S,cards:d,summary:{...S.summary||{},card_count:d.length,...b}}}function Qe(){let i={},d=l=>{for(let[b,S]of Object.entries(l.notification.computedValues)){let w=l.notification.cards[b];i[b]={schema_version:"v1",card_id:b,card_data:w?.card_data??{},computed_values:S??{}};}};for(let l of f)d(l);return i}function M(){let i={};for(let d of f)Object.assign(i,d.notification.dataObjects||{});return i}function q(i){let d=x(i),l=C(i);return l?l.readSignal(d):{count:0,latest_mtime_ms:0,processing:false}}function v(){let i=Ie(),d=Qe(),l=M(),b={};for(let w of i){if(!w?.id)continue;let B=w.id,L=d[B]||{},N={...L.card_data&&typeof L.card_data=="object"?L.card_data:w.card_data&&typeof w.card_data=="object"?w.card_data:{}};b[B]={schema_version:L.schema_version||"v1",card_id:L.card_id||B,card_data:N,computed_values:L.computed_values&&typeof L.computed_values=="object"?L.computed_values:{}};}let S={};for(let w of i){if(!w?.id)continue;let B=w.id;try{let L=q(B),N=pe(B);(N.length>0||L.processing)&&(S[B]={messages:N.map(V=>({role:String(V.role||"system"),text:String(V.text||""),files:Array.isArray(V.files)?V.files:[]})),receiving:!1,processing:!!L.processing});}catch{}}return {boardId:n,cardDefinitions:i,statusSnapshot:Oe(),dataObjectsByToken:l,cardRuntimeById:b,cardChatsByCardId:S}}function m(i,d,l){let b=l?.syncBoard!==false,S=ie(i);if(!S)throw Object.assign(new Error(`Card not found: ${i}`),{statusCode:404});let w=te(i);if(!w)throw Object.assign(new Error(`Card not found: ${i}`),{statusCode:404});let B=d(w)||w,L=S.cardStore.set({body:B});if(L.status!=="success")throw Object.assign(new Error(L.error||`Failed to persist card: ${i}`),{statusCode:500});if(b){let N=S.board.upsertCard({params:{cardId:i,restart:true}});if(N.status!=="success")throw Object.assign(new Error(N.error||`Failed to upsert card: ${i}`),{statusCode:500})}}function T(i,d){m(i,d,{syncBoard:true});}function F(i,d){m(i,d,{syncBoard:false});}function z(i,d){T(i,l=>{if(!d||typeof d!="object"||Object.keys(d).length===0)return l;function b(S,w,B){let L=String(w||"").split(".").filter(Boolean);if(!L.length)return;let N=S;for(let V=0;V<L.length-1;V++){let Z=L[V];(!N[Z]||typeof N[Z]!="object")&&(N[Z]={}),N=N[Z];}N[L[L.length-1]]=B;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let S=null,w=l.view;if(w&&Array.isArray(w.elements)){for(let B of w.elements)if(B?.data&&B.data.writeTo){S=B.data.writeTo;break}}S?b(l,S,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(l.card_data={...l.card_data||{},...d.fieldValues});}else {if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return l;for(let[S,w]of Object.entries(d))S!=="_stagedFiles"&&(w!==null&&typeof w=="object"&&!Array.isArray(w)&&l[S]!==null&&typeof l[S]=="object"&&!Array.isArray(l[S])?l[S]={...l[S],...w}:l[S]=w);}return l});}function X(i){let d=String(i||"").match(/^(\d+)[-_]/);return d?parseInt(d[1],10):0}function ye(i){let d=String(i||"").trim();if(!d)return "upload.bin";let l=Math.max(d.lastIndexOf("/"),d.lastIndexOf("\\"));return (l>=0?d.slice(l+1):d)||"upload.bin"}function ce(i){let d=x(i),l=C(i);l&&l.clear(d);}function me(i,d){let l=x(i),b=C(i),S=b?b.nextSerial(l):1,w=String(d||"system").toLowerCase().replace(/[^a-z0-9_-]/g,"_")||"system";return `${String(S).padStart(3,"0")}_${w}.txt`}function le(i,d,l,b){let S=new Date().toISOString(),w=x(i),B=E(i),L=me(i,d||"system"),N=`${w}/${L}`,V=[],Z=typeof l=="string"?l.trim():"";Z&&V.push(Z);let oe=Array.isArray(b)?b:[];if(oe.length){V.length&&V.push(""),V.push("files:");for(let G of oe){if(!G||typeof G!="object")continue;let ee=typeof G.name=="string"?G.name:"file",de=typeof G.stored_name=="string"?G.stored_name:"";V.push(de?`- ${ee} -> ${de}`:`- ${ee}`);}}B.chats&&B.chats.putText(N,`${V.join(`
|
|
2
2
|
`)}
|
|
3
|
-
`);let
|
|
3
|
+
`);let ne=X(L),U=C(i);return U&&U.appendIndexRecord(w,{serial:ne,role:d||"system",stored_name:L,path:`${i}/chats/${L}`,updated_at:S}),{at:S,role:d||"system",text:Z,files:oe,path:`${i}/chats/${L}`}}function pe(i){let d=x(i),l=C(i);return l?l.readRecords(d).map(b=>({...b,path:`${i}/chats/${b.stored_name}`})):[]}function Re(i){let d=[];try{let l=te(i);if(!l)return d;let b=P().read(l.card_data&&typeof l.card_data=="object"?l.card_data:null);for(let S of b)d.push(S.stored_name);}catch{}return d}function _e(i,d,l,b){let S=x(i),w=E(i),B=ye(d),L=_(i),N=L?L.allocateStoredName(S,B,{seedNames:Re(i),maxLen:Rn}):`${String(Date.now())}-${B}`;return w.files&&w.files.putBytes(`${S}/${N}`,new Uint8Array(b),l||"application/octet-stream"),{name:B,stored_name:N,size:b.length,mime_type:l||"application/octet-stream",path:`${i}/files/${N}`,uploaded_at:new Date().toISOString()}}function Ae(i,d,l){let b=ie(i);if(!b)return;let S=b.board.getConfig({params:{key:"chat-handler-flow"}});if(S.status!=="success")return;let w=S.data?.value,B=b.chatHandlerRef;if(w==null&&(!B||typeof B!="object"))return;let L=x(i),N=E(i),V=`${L}/.processing`;try{N.chats?.putText(V,"","text/plain; charset=utf-8");}catch{}let Z={boardId:n,cardId:String(i),chatsKeyPrefix:d,chatProcessingMarkerKey:V,lastChatFile:l,...k,...u?{serverUrl:u}:{}};if(!a&&w!=null){try{N.chats?.remove(V);}catch{}o.warn(`[chat-handler-flow] configured for card "${i}" but no chatFlowRunner was provided`);return}if(w!=null){let ne=a;if(!ne)return;ne.run(w,Z,{boardId:n,cardId:String(i),label:b.label,logger:o,serverUrl:u,executionExtra:k}).then(U=>{if(U.dispatched)o.info(`[chat-handler-flow] invoked for card "${i}" (boardId: "${n}")`);else {try{N.chats?.remove(V);}catch{}o.warn(`[chat-handler-flow] dispatch failed for card "${i}": ${U.error||"unknown"}`);}},U=>{try{N.chats?.remove(V);}catch{}o.warn(`[chat-handler-flow] invoke failed for card "${i}": ${U?.message||String(U)}`);});return}let oe=B;oe&&s.invoke(oe,Z).then(ne=>{if(ne.dispatched)o.info(`[chat-handler] invoked for card "${i}" (boardId: "${n}")`);else {try{N.chats?.remove(V);}catch{}o.warn(`[chat-handler] dispatch failed for card "${i}": ${ne.error||"unknown"}`);}},ne=>{try{N.chats?.remove(V);}catch{}o.warn(`[chat-handler] invoke failed for card "${i}": ${ne?.message||String(ne)}`);});}function Se(i,d,l){let b=d==="chat-send"?F:T,S;b(i,w=>{let B=new Date().toISOString(),L=w.card_data&&typeof w.card_data=="object"?w.card_data:{};if(w.card_data=L,d==="chat-send"){let N=l&&typeof l.text=="string"?l.text.trim():"",V=[];if(Array.isArray(l?.files)){for(let Z of l.files)if(Z){if(typeof Z=="string"){V.push({name:Z});continue}if(typeof Z=="object"){let oe=Z;typeof oe.name=="string"&&V.push({name:oe.name,size:oe.size,mime_type:oe.mime_type,path:oe.path,uploaded_at:oe.uploaded_at,stored_name:oe.stored_name});}}}if(N||V.length>0){let Z=x(i),ne=le(i,"user",N,V).path,U=ne.includes("/")?ne.slice(ne.lastIndexOf("/")+1):ne;S={chatsKeyPrefix:`${Z}/chats`,lastChatFile:U};for(let G of V){if(!G||typeof G!="object")continue;let ee=typeof G.name=="string"?G.name:"file",de=typeof G.stored_name=="string"?G.stored_name:null;de&&le(i,"system",`File ${ee} uploaded as ${de}.`,[]);}try{let G=pe(i),ee=q(i);ve([{kind:"card_chats",cardId:i,messages:G.map(de=>({role:String(de.role||"system"),text:String(de.text||""),files:Array.isArray(de.files)?de.files:[]})),receiving:!0,processing:!!ee.processing}]);}catch{}}return w}if(d==="file-upload"){let N=P().normalizeIncoming(l?.files,B);return N.length>0&&P().merge(L,N),w}if(d==="action"){let N=l&&typeof l.buttonId=="string"?l.buttonId:"";if(!N)return w;L.lastAction={buttonId:N,at:B},L.lastActionText=`${N} @ ${B}`;}return w}),S&&Ae(i,S.chatsKeyPrefix,S.lastChatFile);}function W(i,d,l){let b=JSON.stringify(l),S=typeof Buffer<"u"?Buffer.byteLength(b):new TextEncoder().encode(b).length;i.writeHead(d,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":S}),i.end(b);}async function Te(i){let d=[];for await(let b of i)d.push(b);let l=typeof Buffer<"u"?Buffer.concat(d).toString("utf-8").trim():new TextDecoder().decode(et(d)).trim();return l?JSON.parse(l):{}}async function Ze(i){let d=[];for await(let l of i)d.push(l);return typeof Buffer<"u"?Buffer.concat(d):et(d)}function et(i){let d=i.reduce((S,w)=>S+w.length,0),l=new Uint8Array(d),b=0;for(let S of i)l.set(S,b),b+=S.length;return l}let Ve=0;function St(i){let d=JSON.stringify(i);return Ve++,`id: ${Ve}
|
|
4
4
|
data: ${d}
|
|
5
5
|
|
|
6
|
-
`}function
|
|
6
|
+
`}function tt(i,d){let l=h.get(i);if(!l)return;let b=St(d);try{l.res.write(b);}catch{h.delete(i);}}function Ee(){let i=new Set;for(let d of h.values())for(let l of d.subscribedChatCardIds)i.add(l);return Array.from(i)}function Je(i){let d=q(i);return `${d.count}:${d.latest_mtime_ms}:${d.processing?1:0}`}function rt(i,d=true){let l=pe(i),b=q(i);return {kind:"card_chats",cardId:i,messages:l.map(S=>({role:String(S.role||"system"),text:String(S.text||""),files:Array.isArray(S.files)?S.files:[]})),receiving:d,processing:!!b.processing}}function je(i,d=true){let l={kind:"notification-batch",notifications:[rt(i,d)]};for(let[b,S]of h.entries())S.subscribedChatCardIds.has(i)&&tt(b,l);}function Ce(){Ee().length>0||(p&&(clearInterval(p),p=null),R.clear());}function Ct(){p||(p=setInterval(()=>{let i=Ee();if(i.length===0){Ce();return}let d=new Set(i);for(let l of Array.from(R.keys()))d.has(l)||R.delete(l);for(let l of i){let b=Je(l);R.get(l)!==b&&(R.set(l,b),je(l,true));}},1e3));}function j(i,d){let l=h.get(i);return l?(l.subscribedChatCardIds.add(d),R.set(d,Je(d)),Ct(),tt(i,{kind:"notification-batch",notifications:[rt(d,true)]}),true):false}function D(i,d){let l=h.get(i);return l?(l.subscribedChatCardIds.delete(d),Ee().includes(d)||R.delete(d),Ce(),true):false}function Y(i){if(!i||typeof i!="object")return false;let d=i.kind;return d==="card_chats"||d==="chat_messages"}function ve(i){if(!i||i.length===0)return;let d=[],l=new Set;for(let b of i)Y(b)&&typeof b.cardId=="string"?l.add(String(b.cardId)):d.push(b);if(d.length>0){let b={kind:"notification-batch",notifications:d};for(let S of h.keys())tt(S,b);}for(let b of l)je(b,true);}function ke(i,d,l){let b=h.get(l),S=b?new Set(b.subscribedChatCardIds):new Set;if(b)try{b.res.end();}catch{}d.writeHead(200,{...r,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),h.set(l,{res:d,subscribedChatCardIds:S});let w=v(),B=St(w);d.write(B);let L=setInterval(()=>{try{d.write(`: keepalive
|
|
7
7
|
|
|
8
|
-
`);}catch{}},15e3);i.on("close",()=>{clearInterval(B),y.delete(l),_e(),d.end();});}async function he(i,d,l){let b=i.method||"GET",S=l,w=S.pathname;try{if(b==="GET"&&w===`${t}/init-board`)return await U(),J(d,200,M()),!0;if(b==="GET"&&w===`${t}/sse`){await U();let V=String(S.searchParams.get("clientId")||"").trim();if(!V)return J(d,400,{error:"clientId query param is required for SSE"}),!0;Ae(i,d,V);for(let H=0;H<g.length;H++)_(g[H]),O(g[H],H);return !0}if(b==="GET"&&w===`${t}/board-status`)return J(d,200,M()),!0;let $=w.match(new RegExp(`^${$e(t)}/cards/([^/]+)$`));if(b==="GET"&&$){await G();let V=decodeURIComponent($[1]),H=re(V);return H?(J(d,200,H),!0):(J(d,404,{error:`card not found: ${V}`}),!0)}if(b==="PATCH"&&$){await G();let V=decodeURIComponent($[1]),H=await xe(i);return F(V,H),J(d,200,{ok:!0}),!0}let B=w.match(new RegExp(`^${$e(t)}/cards/([^/]+)/actions$`));if(b==="POST"&&B){await G();let V=decodeURIComponent(B[1]),H=await xe(i);return we(V,H?.actionType,H?.payload),J(d,200,{ok:!0}),!0}let L=w.match(new RegExp(`^${$e(t)}/cards/([^/]+)/chats$`));if(b==="GET"&&L){await G();let V=decodeURIComponent(L[1]);return J(d,200,{ok:!0,messages:ie(V)}),!0}let K=w.match(new RegExp(`^${$e(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(b==="POST"&&K){await G();let V=decodeURIComponent(K[1]),H=await xe(i),ee=typeof H?.clientId=="string"?H.clientId.trim():"";return ee?St(ee,V)?(J(d,200,{ok:!0,clientId:ee,cardId:V,subscribed:!0}),!0):(J(d,404,{error:`SSE client not connected: ${ee}`}),!0):(J(d,400,{error:"clientId is required"}),!0)}let Y=w.match(new RegExp(`^${$e(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(b==="POST"&&Y){await G();let V=decodeURIComponent(Y[1]),H=await xe(i),ee=typeof H?.clientId=="string"?H.clientId.trim():"";return ee?N(ee,V)?(J(d,200,{ok:!0,clientId:ee,cardId:V,subscribed:!1}),!0):(J(d,404,{error:`SSE client not connected: ${ee}`}),!0):(J(d,400,{error:"clientId is required"}),!0)}let ce=w.match(new RegExp(`^${$e(t)}/cards/([^/]+)/files$`));if(b==="POST"&&ce){await G();let V=decodeURIComponent(ce[1]),H=String(S.searchParams.get("inChat")||"").toLowerCase()==="true",ee=i.headers["x-file-name"],de=String(i.headers["content-type"]||"application/octet-stream"),je=Array.isArray(ee)?ee[0]:ee,Fe=je?decodeURIComponent(String(je)):"upload.bin",nt=await He(i);if(!nt.length)return J(d,400,{error:"Empty upload body"}),!0;let pe=Re(V,Fe,de,nt);return H&&(A(V,Ne=>{let Pe=new Date().toISOString(),st=Ne.card_data&&typeof Ne.card_data=="object"?Ne.card_data:{};Ne.card_data=st;let Ct=x().normalizeIncoming([{name:pe.name,stored_name:pe.stored_name,size:pe.size,mime_type:pe.mime_type,path:pe.path,uploaded_at:pe.uploaded_at||Pe}],Pe);return x().merge(st,Ct),Ne}),le(V,"system",`file uploaded: ${pe.name} as ${pe.stored_name}`,[])),J(d,200,{ok:!0,file:pe}),!0}let ye=w.match(new RegExp(`^${$e(t)}/cards/([^/]+)/files/(\\d+)$`));if(b==="GET"&&ye){let V=decodeURIComponent(ye[1]),H=parseInt(ye[2],10),ee=S.searchParams.get("sn"),de=re(V);if(!de)return J(d,404,{error:"Card not found"}),!0;let je=x().resolve(de.card_data,H,ee);if(!je.ok&&je.reason==="stale_reference")return J(d,409,{error:"File reference is stale. Refresh and try again."}),!0;if(!je.ok)return J(d,404,{error:"File not found"}),!0;let Fe=je.file,nt=P(V),pe=j(V),Ne=`${nt}/${Fe.stored_name}`,Pe=pe.files?pe.files.getBytes(Ne):null;if(!Pe)return J(d,404,{error:"File not found"}),!0;let st=Fe.name||Fe.stored_name,Ct=Fe.mime_type||"application/octet-stream";return d.writeHead(200,{"Content-Type":Ct,"Content-Disposition":`attachment; filename="${st}"`,"Content-Length":Pe.length}),d.end(Pe),!0}return !1}catch($){let B=$?.statusCode||500;return J(d,B,{error:String($?.message||$)}),true}}return {get apiBasePath(){return t},get corsHeaders(){return r},handleRuntimeApi:he,buildPublishedRuntimePayload:M,clearChatRecords:me,reportSourceFetched(i,d){let l=g[0];return l?l.board.sourceDataFetched({params:{token:i,ref:d}}):{status:"fail",error:"no board context"}},reportSourceFetchFailure(i,d){let l=g[0];return l?l.board.sourceDataFetchFailure({params:{token:i,reason:d}}):{status:"fail",error:"no board context"}},get cardStore(){return g[0]?.cardStore??{set(){return {status:"fail",error:"no board context"}}}}}}function $e(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Ft(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return `[${e.map(Ft).join(",")}]`;let t=e;return `{${Object.keys(t).sort().map(n=>`${JSON.stringify(n)}:${Ft(t[n])}`).join(",")}}`}function kt(e,t){let r=t>>>0;for(let n=0;n<e.length;n++)r^=e.charCodeAt(n),r=Math.imul(r,16777619)>>>0;return r}function Ir(e){let t=Ft(e),r=kt(t,2166136261),n=kt(t,3735928559),o=kt(t,19088743),s=kt(t,4277009102);return [r,n,o,s].map(a=>a.toString(16).padStart(8,"0")).join("")}function Pt(e){function t(s){return `${e}:blob:${s}`}let r=new TextEncoder;function n(s){if(typeof btoa=="function"){let a="";for(let c=0;c<s.length;c++)a+=String.fromCharCode(s[c]);return btoa(a)}return ""}function o(s){if(typeof atob=="function"){let a=atob(s),c=new Uint8Array(a.length);for(let u=0;u<a.length;u++)c[u]=a.charCodeAt(u);return c}return new Uint8Array}return {read(s){return globalThis.localStorage.getItem(t(s))},write(s,a){globalThis.localStorage.setItem(t(s),a);},exists(s){return globalThis.localStorage.getItem(t(s))!==null},remove(s){globalThis.localStorage.removeItem(t(s));},readBytes(s){let a=globalThis.localStorage.getItem(t(s));if(a===null)return null;try{let c=JSON.parse(a);if(c&&c.__kind==="bytes-b64"&&typeof c.data=="string")return o(c.data)}catch{}return r.encode(a)},writeBytes(s,a){let c=JSON.stringify({__kind:"bytes-b64",data:n(a)});globalThis.localStorage.setItem(t(s),c);},listKeys(s){let a=t(s??""),c=[];for(let u=0;u<globalThis.localStorage.length;u++){let y=globalThis.localStorage.key(u);y&&y.startsWith(a)&&c.push(y.slice(t("").length));}return c.sort()},stat(s){let a=globalThis.localStorage.getItem(t(s));if(a===null)return null;let c=r.encode(a).byteLength;try{let u=JSON.parse(a);u&&u.__kind==="bytes-b64"&&typeof u.data=="string"&&(c=o(u.data).byteLength);}catch{}return {key:s,size:c}}}}function Dt(e){function t(r){return `${e}:kv:${r}`}return {read(r){let n=globalThis.localStorage.getItem(t(r));if(n===null)return null;try{return JSON.parse(n)}catch{return null}},write(r,n){globalThis.localStorage.setItem(t(r),JSON.stringify(n));},delete(r){globalThis.localStorage.removeItem(t(r));},listKeys(r){let n=t(r??""),o=[];for(let s=0;s<globalThis.localStorage.length;s++){let a=globalThis.localStorage.key(s);a!==null&&a.startsWith(n)&&o.push(a.slice(t("").length));}return o}}}function Or(e){function t(){let n=globalThis.localStorage.getItem(e);if(!n)return [];try{return JSON.parse(n)}catch{return []}}function r(n){globalThis.localStorage.setItem(e,JSON.stringify(n));}return {readAllEntries(){return t()},appendEntry(n){let o=t();o.push(n),r(o);},generateId(){return globalThis.crypto.randomUUID()}}}function Sn(){let e=false;return {tryAcquire(){return e?null:(e=true,()=>{e=false;})}}}var jr=new Map;function bt(e){let t=jr.get(e);if(!t){let r=new Set;t={publish(n){for(let o of r)o(n);},subscribe(n){return r.add(n),()=>{r.delete(n);}}},jr.set(e,t);}return t}function Nr(){return {async subscribe(e,t){return e.kind!=="in-memory-bus"?(console.warn(`[in-memory-transport] unsupported kind: ${e.kind}`),()=>{}):bt(e.value).subscribe(n=>{let o=n;if(o&&o.kind==="notification-batch"&&Array.isArray(o.notifications)){for(let s of o.notifications)t(s);return}t(n);})}}}function Br(e,t){let r=t?.callbackBaseUrl?{meta:"board-live-cards",howToRun:"http:post",whatToRun:t.callbackBaseUrl}:{meta:"board-live-cards",howToRun:"in-browser",whatToRun:te({kind:"in-browser",value:e})},n=new Map,o=new Map,s=Sn();return {kvStorage:a=>Dt(`${e}:${a}`),blobStorage:a=>Pt(a?`${e}:${a}`:e),journalAdapter:()=>Or(`${e}:journal`),lock:s,selfRef:r,async dispatchExecution(a,c){if(a.howToRun==="http:post")try{let u=a.whatToRun,y=typeof u=="object"?u.value:Se(u).value,k=await fetch(y,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(c)});return k.ok?{dispatched:!0}:{dispatched:!1,error:`HTTP ${k.status}: ${k.statusText}`}}catch(u){return {dispatched:false,error:u instanceof Error?u.message:String(u)}}if(a.howToRun==="http:get")try{let u=a.whatToRun,y=typeof u=="object"?u.value:Se(u).value,k=new URLSearchParams(Object.entries(c).filter(([,g])=>g!=null).map(([g,h])=>[g,String(h)])),R=`${y}?${k.toString()}`,p=await fetch(R);return p.ok?{dispatched:!0}:{dispatched:!1,error:`HTTP ${p.status}: ${p.statusText}`}}catch(u){return {dispatched:false,error:u instanceof Error?u.message:String(u)}}if(a.howToRun==="in-browser"){let u=a.whatToRun,y=typeof u=="object"?u.value:Se(u).value,k=n.get(y);return k?k(a,c):{dispatched:false,error:`No in-browser handler registered for: ${y}`}}return {dispatched:false,error:`Browser adapter: unsupported dispatch kind (got: ${a.howToRun})`}},resolveBlob(a){if(a.kind==="in-memory"){let y=o.get(a.value);if(y==null)throw new Error(`resolveBlob: in-memory blob not found: ${te(a)}`);return y}let u=Pt(e).read(a.value);if(u===null)throw new Error(`resolveBlob: blob not found: ${te(a)}`);return u},hashFn:Ir,genId:()=>globalThis.crypto.randomUUID().replace(/-/g,""),kvStorageForRef:a=>Dt(Se(a).value),publishBoardChangeNotifications(a){if(!t?.notifyChannel||a.length===0)return;bt(t.notifyChannel).publish({kind:"notification-batch",notifications:a});},onWarn:t?.onWarn,registerHandler(a,c){n.set(a,c);},writeMemoryBlob(a,c){return o.set(a,c),te({kind:"in-memory",value:a})}}}function Lr(e){return e==="running"||e==="in-progress"?"loading":e==="failed"?"error":"fresh"}function An(e,t){let r=t&&typeof t=="object"&&!Array.isArray(t)?t:{};return {schema_version:r.schema_version||"v1",card_id:typeof r.card_id=="string"?r.card_id:e,card_data:r.card_data&&typeof r.card_data=="object"&&!Array.isArray(r.card_data)?structuredClone(r.card_data):{},computed_values:r.computed_values&&typeof r.computed_values=="object"&&!Array.isArray(r.computed_values)?structuredClone(r.computed_values):{}}}function Ye(e,t){if(!e||typeof e!="object")throw new Error("payload must be an object");if(!t)throw new Error("cardId is required");let n=(Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).find(x=>x.id===t);if(!n)throw new Error(`cardDefinitions has no entry with id ${t}`);let o=e.statusSnapshot&&typeof e.statusSnapshot=="object"?e.statusSnapshot:{},s=e.cardRuntimeById&&typeof e.cardRuntimeById=="object"?e.cardRuntimeById:{},a=e.dataObjectsByToken&&typeof e.dataObjectsByToken=="object"?e.dataObjectsByToken:{},u=(Array.isArray(o.cards)?o.cards:[]).find(x=>x.name===t),y=structuredClone(n),k=An(t,s[t]),p={...y.card_data&&typeof y.card_data=="object"&&!Array.isArray(y.card_data)?y.card_data:{},...k.card_data||{},status:Lr(u?.status),lastRun:u?.runtime?.last_transition_at??null};u?.error?.message&&(p.error=u.error.message);let g=u?{task_status:u.status??null,card_status:Lr(u.status),runtime:structuredClone(u.runtime??{}),error:u.error?structuredClone(u.error):null,blocked_by:Array.isArray(u.blocked_by)?structuredClone(u.blocked_by):[],requires_missing:Array.isArray(u.requires_missing)?structuredClone(u.requires_missing):[]}:{task_status:null,card_status:p.status??"fresh",runtime:{last_transition_at:p.lastRun??null},error:p.error?{message:p.error}:null,blocked_by:[],requires_missing:[]},h=Array.isArray(y.requires)?y.requires:[],f={};for(let[x,P]of Object.entries(a))f[x]=structuredClone(P);for(let x of h)Object.prototype.hasOwnProperty.call(f,x)||(f[x]=null);let E=(e.cardChatsByCardId&&typeof e.cardChatsByCardId=="object"?e.cardChatsByCardId:{})[t],C=E?{messages:Array.isArray(E.messages)?E.messages:[],receiving:!!E.receiving,processing:!!E.processing}:null;return {id:t,card:y,card_data:p,requires:f,computed_values:k.computed_values,runtime_state:g,card_chats:C}}function Tn(e){if(!e||typeof e!="object")throw new Error("payload must be an object");return (Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).map(r=>Ye(e,r.id))}function Rt(e){return JSON.parse(JSON.stringify(e))}function Ge(e,t){if(e===t)return e;try{if(JSON.stringify(e)===JSON.stringify(t))return e}catch{}return t}function ge(e,t){if(e===t)return true;try{return JSON.stringify(e)===JSON.stringify(t)}catch{return false}}function En(e){return e==="running"||e==="in-progress"?"loading":e==="failed"?"error":"fresh"}function $r(e,t,r){let n=e,s=(n&&Array.isArray(n.cardDefinitions)?n.cardDefinitions:[]).map(u=>u.id),a=t&&t.modelsById||{},c={};for(let u of s){let y=r(e,u),k=a[u];if(!k){c[u]=y;continue}let R=y.card_chats!=null?Ge(k.card_chats,y.card_chats??null):k.card_chats??null,p={id:y.id,card:Ge(k.card,y.card),card_data:Ge(k.card_data,y.card_data),requires:Ge(k.requires,y.requires),computed_values:Ge(k.computed_values,y.computed_values),runtime_state:Ge(k.runtime_state,y.runtime_state),card_chats:R};c[u]=p.card===k.card&&p.card_data===k.card_data&&p.requires===k.requires&&p.computed_values===k.computed_values&&p.runtime_state===k.runtime_state&&p.card_chats===k.card_chats?k:p;}return {payload:e,cardIds:s,modelsById:c}}function Fr(e,t,r,n){if(!e||!Array.isArray(t)||t.length===0)return e;let o=e.modelsById,s=e.cardIds,a=false,c=false,u={};for(let k of s){let R=o[k],p=R&&R.requires;if(p&&typeof p=="object")for(let g of Object.keys(p))(u[g]=u[g]||[]).push(k);}function y(){a||(o={...o},a=true);}for(let k of t)if(!(!k||!k.kind)){if(k.kind==="computed_values"){let R=k.cardId,p=o[R];if(!p)continue;let g=k.values||{};if(ge(p.computed_values,g))continue;y(),o[R]={...p,computed_values:g},c=true;}else if(k.kind==="data_object"){let R=k.key,p=k.payload,g=u[R]||[];for(let h of g){let f=o[h];if(!f)continue;let j=f.requires||{};ge(j[R],p)||(y(),o[h]={...f,requires:{...j,[R]:p}},c=true);}}else if(k.kind==="card_refreshed"){let R=k.cardId,p=null,g=o[R],h=k.card;if(g&&h&&typeof h=="object"&&!Array.isArray(h)){let f=h,j=f.card_data&&typeof f.card_data=="object"&&!Array.isArray(f.card_data)?f.card_data:g.card_data,E=f.requires&&typeof f.requires=="object"&&!Array.isArray(f.requires)?f.requires:g.requires,C=f.computed_values&&typeof f.computed_values=="object"&&!Array.isArray(f.computed_values)?f.computed_values:g.computed_values,x=f.runtime_state&&typeof f.runtime_state=="object"&&!Array.isArray(f.runtime_state)?f.runtime_state:g.runtime_state;p={...g,card:h,card_data:j,requires:E,computed_values:C,runtime_state:x};}if(!p)try{let f=n();f&&(p=r(f,R));}catch{}if(!p||g&&ge(g.card,p.card)&&ge(g.card_data,p.card_data)&&ge(g.requires,p.requires)&&ge(g.computed_values,p.computed_values)&&ge(g.runtime_state,p.runtime_state))continue;y(),o[R]=p,s.includes(R)||(s=[...s,R]),c=true;}else if(k.kind==="card_chats"){let R=k.cardId,p=o[R];if(!p)continue;let g=Array.isArray(k.messages)?k.messages:p.card_chats?.messages??[],h=typeof k.receiving=="boolean"?k.receiving:p.card_chats?.receiving??false,f=typeof k.processing=="boolean"?k.processing:p.card_chats?.processing??false,j={messages:g,receiving:h,processing:f};if(ge(p.card_chats,j))continue;y(),o[R]={...p,card_chats:j},c=true;}else if(k.kind==="chat_messages"){let R=k.cardId,p=o[R];if(!p)continue;let g=Array.isArray(k.messages)?k.messages:[],h=p.card_chats||{receiving:false,processing:false},f={messages:g,receiving:h.receiving,processing:!!h.processing};if(ge(p.card_chats,f))continue;y(),o[R]={...p,card_chats:f},c=true;}else if(k.kind==="status"){let R=k.status?.cards??[];for(let p of R){let g=p?.name;if(!g||!o[g])continue;let h=o[g],f=En(p.status),j={...h.card_data||{},status:f,lastRun:p.runtime?.last_transition_at??null,...p.error?.message?{error:p.error.message}:{}};p.error?.message||delete j.error;let E={task_status:p.status??null,card_status:f,runtime:p.runtime?Rt(p.runtime):{},error:p.error?Rt(p.error):null,blocked_by:Array.isArray(p.blocked_by)?Rt(p.blocked_by):[],requires_missing:Array.isArray(p.requires_missing)?Rt(p.requires_missing):[]};ge(h.card_data,j)&&ge(h.runtime_state,E)||(y(),o[g]={...h,card_data:j,runtime_state:E},c=true);}}}return c?{payload:e.payload,cardIds:s,modelsById:o}:e}function Lo(e,t){let r=t?.cards??[],n=t?.onWarn??(()=>{}),o=`${e}:notify`,s=Br(e,{callbackBaseUrl:t?.callbackBaseUrl,notifyChannel:o,onWarn:n}),a=Se(te({kind:"localstorage",value:e})),c=te({kind:"localstorage",value:`${e}:card-store`}),u=te({kind:"localstorage",value:`${e}:outputs`}),y=t?.taskExecutor??null,k=t?.chatHandler??null,R=te({kind:"in-browser",value:`${e}:task-executor`}),p=te({kind:"in-browser",value:`${e}:chat-handler`});y&&s.registerHandler(R,y),k&&s.registerHandler(p,k);let g={async invoke(T,I){return T.howToRun==="in-browser",s.dispatchExecution(T,I)}},h=t?.taskExecutorRef??(y?{meta:"task-executor",howToRun:"in-browser",whatToRun:R}:void 0),f=t?.chatHandlerRef??(k?{meta:"chat-handler",howToRun:"in-browser",whatToRun:p}:void 0),j=Nr(),E=Er({boardId:e,boards:[{label:e,boardAdapter:s,baseRef:a,cardStoreRef:c,outputsStoreRef:u,notifyRef:{kind:"in-memory-bus",value:o},taskExecutorRef:h,chatHandlerRef:f}],invocationAdapter:g,notificationTransport:j,logger:{info:(...T)=>console.log("[board]",...T),warn:(...T)=>{n(String(T[0])),console.warn("[board]",...T);},error:(...T)=>console.error("[board]",...T)}});r.length&&E.cardStore.set({body:r}),t?.onBoardChange&&bt(o).subscribe(I=>{let _=I;!_||_.kind!=="notification-batch"||!Array.isArray(_.notifications)||_.notifications.length===0||t.onBoardChange?.({notifications:_.notifications});});function C(T,I,_){let O=_?JSON.stringify(_):"",U=new TextEncoder().encode(O),G=false;return {method:T,url:I,headers:{"content-type":"application/json"},on(W,re){},[Symbol.asyncIterator](){let W={async next(){return G?{done:true,value:void 0}:(G=true,{done:false,value:U})},[Symbol.asyncIterator](){return W}};return W}}}function x(){let T=200,I=[];return {res:{writeHead(O){T=O;},write(O){return I.push(typeof O=="string"?O:new TextDecoder().decode(O)),true},end(O){O&&I.push(typeof O=="string"?O:new TextDecoder().decode(O));}},getResult:()=>{let O=I.join(""),U;try{U=JSON.parse(O);}catch{U=O;}return {status:T,body:U}}}}let P=E.apiBasePath;return {async bootstrap(){let T=C("GET",`${P}/bootstrap`),{res:I}=x();await E.handleRuntimeApi(T,I,new URL(`http://localhost${P}/bootstrap`));},getState(){return E.buildPublishedRuntimePayload()},async patchCard(T,I){let _=`${P}/cards/${encodeURIComponent(T)}`,O=C("PATCH",_,I),{res:U}=x();await E.handleRuntimeApi(O,U,new URL(`http://localhost${_}`));},async applyCardAction(T,I,_){let O=`${P}/cards/${encodeURIComponent(T)}/actions`,U=C("POST",O,{actionType:I,payload:_}),{res:G}=x();await E.handleRuntimeApi(U,G,new URL(`http://localhost${O}`));},readChatRecords(T){let I=`${P}/cards/${encodeURIComponent(T)}/chats`,_=C("GET",I),O=x();E.handleRuntimeApi(_,O.res,new URL(`http://localhost${I}`));let G=O.getResult().body;return Array.isArray(G?.messages)?G.messages:[]},clearChatRecords(T){E.clearChatRecords(T);},writeMemoryBlob(T,I){return s.writeMemoryBlob(T,I)},reportSourceFetched(T,I){E.reportSourceFetched(T,I);},reportSourceFetchFailure(T,I){E.reportSourceFetchFailure(T,I);},get runtime(){return E}}}function Po(e,t){return $r(e,t,Ye)}function Do(e,t,r){return Fr(e,t,Ye,r)}
|
|
9
|
-
exports.applyNotification=
|
|
8
|
+
`);}catch{}},15e3);i.on("close",()=>{clearInterval(L),h.delete(l),Ce(),d.end();});}async function Pe(i,d,l){let b=i.method||"GET",S=l,w=S.pathname;try{if(b==="GET"&&w===`${t}/init-board`)return await H(),W(d,200,v()),!0;if(b==="GET"&&w===`${t}/sse`){await H();let U=String(S.searchParams.get("clientId")||"").trim();if(!U)return W(d,400,{error:"clientId query param is required for SSE"}),!0;ke(i,d,U);for(let G=0;G<f.length;G++)O(f[G]),J(f[G],G);return !0}if(b==="GET"&&w===`${t}/board-status`)return W(d,200,v()),!0;let B=w.match(new RegExp(`^${Fe(t)}/cards/([^/]+)$`));if(b==="GET"&&B){await K();let U=decodeURIComponent(B[1]),G=te(U);return G?(W(d,200,G),!0):(W(d,404,{error:`card not found: ${U}`}),!0)}if(b==="PATCH"&&B){await K();let U=decodeURIComponent(B[1]),G=await Te(i);return z(U,G),W(d,200,{ok:!0}),!0}let L=w.match(new RegExp(`^${Fe(t)}/cards/([^/]+)/actions$`));if(b==="POST"&&L){await K();let U=decodeURIComponent(L[1]),G=await Te(i);return Se(U,G?.actionType,G?.payload),W(d,200,{ok:!0}),!0}let N=w.match(new RegExp(`^${Fe(t)}/cards/([^/]+)/chats$`));if(b==="GET"&&N){await K();let U=decodeURIComponent(N[1]);return W(d,200,{ok:!0,messages:pe(U)}),!0}let V=w.match(new RegExp(`^${Fe(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(b==="POST"&&V){await K();let U=decodeURIComponent(V[1]),G=await Te(i),ee=typeof G?.clientId=="string"?G.clientId.trim():"";return ee?j(ee,U)?(W(d,200,{ok:!0,clientId:ee,cardId:U,subscribed:!0}),!0):(W(d,404,{error:`SSE client not connected: ${ee}`}),!0):(W(d,400,{error:"clientId is required"}),!0)}let Z=w.match(new RegExp(`^${Fe(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(b==="POST"&&Z){await K();let U=decodeURIComponent(Z[1]),G=await Te(i),ee=typeof G?.clientId=="string"?G.clientId.trim():"";return ee?D(ee,U)?(W(d,200,{ok:!0,clientId:ee,cardId:U,subscribed:!1}),!0):(W(d,404,{error:`SSE client not connected: ${ee}`}),!0):(W(d,400,{error:"clientId is required"}),!0)}let oe=w.match(new RegExp(`^${Fe(t)}/cards/([^/]+)/files$`));if(b==="POST"&&oe){await K();let U=decodeURIComponent(oe[1]),G=String(S.searchParams.get("inChat")||"").toLowerCase()==="true",ee=i.headers["x-file-name"],de=String(i.headers["content-type"]||"application/octet-stream"),Ne=Array.isArray(ee)?ee[0]:ee,De=Ne?decodeURIComponent(String(Ne)):"upload.bin",nt=await Ze(i);if(!nt.length)return W(d,400,{error:"Empty upload body"}),!0;let ge=_e(U,De,de,nt);return G&&(F(U,Be=>{let qe=new Date().toISOString(),ot=Be.card_data&&typeof Be.card_data=="object"?Be.card_data:{};Be.card_data=ot;let vt=P().normalizeIncoming([{name:ge.name,stored_name:ge.stored_name,size:ge.size,mime_type:ge.mime_type,path:ge.path,uploaded_at:ge.uploaded_at||qe}],qe);return P().merge(ot,vt),Be}),le(U,"system",`file uploaded: ${ge.name} as ${ge.stored_name}`,[])),W(d,200,{ok:!0,file:ge}),!0}let ne=w.match(new RegExp(`^${Fe(t)}/cards/([^/]+)/files/(\\d+)$`));if(b==="GET"&&ne){let U=decodeURIComponent(ne[1]),G=parseInt(ne[2],10),ee=S.searchParams.get("sn"),de=te(U);if(!de)return W(d,404,{error:"Card not found"}),!0;let Ne=P().resolve(de.card_data,G,ee);if(!Ne.ok&&Ne.reason==="stale_reference")return W(d,409,{error:"File reference is stale. Refresh and try again."}),!0;if(!Ne.ok)return W(d,404,{error:"File not found"}),!0;let De=Ne.file,nt=x(U),ge=E(U),Be=`${nt}/${De.stored_name}`,qe=ge.files?ge.files.getBytes(Be):null;if(!qe)return W(d,404,{error:"File not found"}),!0;let ot=De.name||De.stored_name,vt=De.mime_type||"application/octet-stream";return d.writeHead(200,{"Content-Type":vt,"Content-Disposition":`attachment; filename="${ot}"`,"Content-Length":qe.length}),d.end(qe),!0}return !1}catch(B){let L=B?.statusCode||500;return W(d,L,{error:String(B?.message||B)}),true}}return {get apiBasePath(){return t},get corsHeaders(){return r},handleRuntimeApi:Pe,buildPublishedRuntimePayload:v,clearChatRecords:ce,reportSourceFetched(i,d){let l=f[0];return l?l.board.sourceDataFetched({params:{token:i,ref:d}}):{status:"fail",error:"no board context"}},reportSourceFetchFailure(i,d){let l=f[0];return l?l.board.sourceDataFetchFailure({params:{token:i,reason:d}}):{status:"fail",error:"no board context"}},get cardStore(){return f[0]?.cardStore??{set(){return {status:"fail",error:"no board context"}}}}}}function Fe(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function Lt(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return `[${e.map(Lt).join(",")}]`;let t=e;return `{${Object.keys(t).sort().map(n=>`${JSON.stringify(n)}:${Lt(t[n])}`).join(",")}}`}function kt(e,t){let r=t>>>0;for(let n=0;n<e.length;n++)r^=e.charCodeAt(n),r=Math.imul(r,16777619)>>>0;return r}function Or(e){let t=Lt(e),r=kt(t,2166136261),n=kt(t,3735928559),o=kt(t,19088743),s=kt(t,4277009102);return [r,n,o,s].map(a=>a.toString(16).padStart(8,"0")).join("")}function Ft(e){function t(s){return `${e}:blob:${s}`}let r=new TextEncoder;function n(s){if(typeof btoa=="function"){let a="";for(let c=0;c<s.length;c++)a+=String.fromCharCode(s[c]);return btoa(a)}return ""}function o(s){if(typeof atob=="function"){let a=atob(s),c=new Uint8Array(a.length);for(let u=0;u<a.length;u++)c[u]=a.charCodeAt(u);return c}return new Uint8Array}return {read(s){return globalThis.localStorage.getItem(t(s))},write(s,a){globalThis.localStorage.setItem(t(s),a);},exists(s){return globalThis.localStorage.getItem(t(s))!==null},remove(s){globalThis.localStorage.removeItem(t(s));},readBytes(s){let a=globalThis.localStorage.getItem(t(s));if(a===null)return null;try{let c=JSON.parse(a);if(c&&c.__kind==="bytes-b64"&&typeof c.data=="string")return o(c.data)}catch{}return r.encode(a)},writeBytes(s,a){let c=JSON.stringify({__kind:"bytes-b64",data:n(a)});globalThis.localStorage.setItem(t(s),c);},listKeys(s){let a=t(s??""),c=[];for(let u=0;u<globalThis.localStorage.length;u++){let k=globalThis.localStorage.key(u);k&&k.startsWith(a)&&c.push(k.slice(t("").length));}return c.sort()},stat(s){let a=globalThis.localStorage.getItem(t(s));if(a===null)return null;let c=r.encode(a).byteLength;try{let u=JSON.parse(a);u&&u.__kind==="bytes-b64"&&typeof u.data=="string"&&(c=o(u.data).byteLength);}catch{}return {key:s,size:c}}}}function Pt(e){function t(r){return `${e}:kv:${r}`}return {read(r){let n=globalThis.localStorage.getItem(t(r));if(n===null)return null;try{return JSON.parse(n)}catch{return null}},write(r,n){globalThis.localStorage.setItem(t(r),JSON.stringify(n));},delete(r){globalThis.localStorage.removeItem(t(r));},listKeys(r){let n=t(r??""),o=[];for(let s=0;s<globalThis.localStorage.length;s++){let a=globalThis.localStorage.key(s);a!==null&&a.startsWith(n)&&o.push(a.slice(t("").length));}return o}}}function jr(e){function t(){let n=globalThis.localStorage.getItem(e);if(!n)return [];try{return JSON.parse(n)}catch{return []}}function r(n){globalThis.localStorage.setItem(e,JSON.stringify(n));}return {readAllEntries(){return t()},appendEntry(n){let o=t();o.push(n),r(o);},generateId(){return globalThis.crypto.randomUUID()}}}function Cn(){let e=false;return {tryAcquire(){return e?null:(e=true,()=>{e=false;})}}}var Nr=new Map;function bt(e){let t=Nr.get(e);if(!t){let r=new Set;t={publish(n){for(let o of r)o(n);},subscribe(n){return r.add(n),()=>{r.delete(n);}}},Nr.set(e,t);}return t}function Br(){return {async subscribe(e,t){return e.kind!=="in-memory-bus"?(console.warn(`[in-memory-transport] unsupported kind: ${e.kind}`),()=>{}):bt(e.value).subscribe(n=>{let o=n;if(o&&o.kind==="notification-batch"&&Array.isArray(o.notifications)){for(let s of o.notifications)t(s);return}t(n);})}}}function $r(e,t){let r=t?.callbackBaseUrl?{meta:"board-live-cards",howToRun:"http:post",whatToRun:t.callbackBaseUrl}:{meta:"board-live-cards",howToRun:"in-browser",whatToRun:re({kind:"in-browser",value:e})},n=new Map,o=new Map,s=Cn();return {kvStorage:a=>Pt(`${e}:${a}`),blobStorage:a=>Ft(a?`${e}:${a}`:e),journalAdapter:()=>jr(`${e}:journal`),lock:s,selfRef:r,async dispatchExecution(a,c){if(a.howToRun==="http:post")try{let u=a.whatToRun,k=typeof u=="object"?u.value:we(u).value,h=await fetch(k,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(c)});return h.ok?{dispatched:!0}:{dispatched:!1,error:`HTTP ${h.status}: ${h.statusText}`}}catch(u){return {dispatched:false,error:u instanceof Error?u.message:String(u)}}if(a.howToRun==="http:get")try{let u=a.whatToRun,k=typeof u=="object"?u.value:we(u).value,h=new URLSearchParams(Object.entries(c).filter(([,y])=>y!=null).map(([y,f])=>[y,String(f)])),R=`${k}?${h.toString()}`,p=await fetch(R);return p.ok?{dispatched:!0}:{dispatched:!1,error:`HTTP ${p.status}: ${p.statusText}`}}catch(u){return {dispatched:false,error:u instanceof Error?u.message:String(u)}}if(a.howToRun==="in-browser"){let u=a.whatToRun,k=typeof u=="object"?u.value:we(u).value,h=n.get(k);return h?h(a,c):{dispatched:false,error:`No in-browser handler registered for: ${k}`}}return {dispatched:false,error:`Browser adapter: unsupported dispatch kind (got: ${a.howToRun})`}},resolveBlob(a){if(a.kind==="in-memory"){let k=o.get(a.value);if(k==null)throw new Error(`resolveBlob: in-memory blob not found: ${re(a)}`);return k}let u=Ft(e).read(a.value);if(u===null)throw new Error(`resolveBlob: blob not found: ${re(a)}`);return u},hashFn:Or,genId:()=>globalThis.crypto.randomUUID().replace(/-/g,""),kvStorageForRef:a=>Pt(we(a).value),publishBoardChangeNotifications(a){if(!t?.notifyChannel||a.length===0)return;bt(t.notifyChannel).publish({kind:"notification-batch",notifications:a});},onWarn:t?.onWarn,registerHandler(a,c){n.set(a,c);},writeMemoryBlob(a,c){return o.set(a,c),re({kind:"in-memory",value:a})}}}function Lr(e){return e==="running"||e==="in-progress"?"loading":e==="failed"?"error":"fresh"}function Tn(e,t){let r=t&&typeof t=="object"&&!Array.isArray(t)?t:{};return {schema_version:r.schema_version||"v1",card_id:typeof r.card_id=="string"?r.card_id:e,card_data:r.card_data&&typeof r.card_data=="object"&&!Array.isArray(r.card_data)?structuredClone(r.card_data):{},computed_values:r.computed_values&&typeof r.computed_values=="object"&&!Array.isArray(r.computed_values)?structuredClone(r.computed_values):{}}}function Ye(e,t){if(!e||typeof e!="object")throw new Error("payload must be an object");if(!t)throw new Error("cardId is required");let n=(Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).find(_=>_.id===t);if(!n)throw new Error(`cardDefinitions has no entry with id ${t}`);let o=e.statusSnapshot&&typeof e.statusSnapshot=="object"?e.statusSnapshot:{},s=e.cardRuntimeById&&typeof e.cardRuntimeById=="object"?e.cardRuntimeById:{},a=e.dataObjectsByToken&&typeof e.dataObjectsByToken=="object"?e.dataObjectsByToken:{},u=(Array.isArray(o.cards)?o.cards:[]).find(_=>_.name===t),k=structuredClone(n),h=Tn(t,s[t]),p={...k.card_data&&typeof k.card_data=="object"&&!Array.isArray(k.card_data)?k.card_data:{},...h.card_data||{},status:Lr(u?.status),lastRun:u?.runtime?.last_transition_at??null};u?.error?.message&&(p.error=u.error.message);let y=u?{task_status:u.status??null,card_status:Lr(u.status),runtime:structuredClone(u.runtime??{}),error:u.error?structuredClone(u.error):null,blocked_by:Array.isArray(u.blocked_by)?structuredClone(u.blocked_by):[],requires_missing:Array.isArray(u.requires_missing)?structuredClone(u.requires_missing):[]}:{task_status:null,card_status:p.status??"fresh",runtime:{last_transition_at:p.lastRun??null},error:p.error?{message:p.error}:null,blocked_by:[],requires_missing:[]},f=Array.isArray(k.requires)?k.requires:[],g={};for(let[_,P]of Object.entries(a))g[_]=structuredClone(P);for(let _ of f)Object.prototype.hasOwnProperty.call(g,_)||(g[_]=null);let E=(e.cardChatsByCardId&&typeof e.cardChatsByCardId=="object"?e.cardChatsByCardId:{})[t],C=E?{messages:Array.isArray(E.messages)?E.messages:[],receiving:!!E.receiving,processing:!!E.processing}:null;return {id:t,card:k,card_data:p,requires:g,computed_values:h.computed_values,runtime_state:y,card_chats:C}}function En(e){if(!e||typeof e!="object")throw new Error("payload must be an object");return (Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).map(r=>Ye(e,r.id))}function Rt(e){return JSON.parse(JSON.stringify(e))}function Ue(e,t){if(e===t)return e;try{if(JSON.stringify(e)===JSON.stringify(t))return e}catch{}return t}function he(e,t){if(e===t)return true;try{return JSON.stringify(e)===JSON.stringify(t)}catch{return false}}function In(e){return e==="running"||e==="in-progress"?"loading":e==="failed"?"error":"fresh"}function Fr(e,t,r){let n=e,s=(n&&Array.isArray(n.cardDefinitions)?n.cardDefinitions:[]).map(u=>u.id),a=t&&t.modelsById||{},c={};for(let u of s){let k=r(e,u),h=a[u];if(!h){c[u]=k;continue}let R=k.card_chats!=null?Ue(h.card_chats,k.card_chats??null):h.card_chats??null,p={id:k.id,card:Ue(h.card,k.card),card_data:Ue(h.card_data,k.card_data),requires:Ue(h.requires,k.requires),computed_values:Ue(h.computed_values,k.computed_values),runtime_state:Ue(h.runtime_state,k.runtime_state),card_chats:R};c[u]=p.card===h.card&&p.card_data===h.card_data&&p.requires===h.requires&&p.computed_values===h.computed_values&&p.runtime_state===h.runtime_state&&p.card_chats===h.card_chats?h:p;}return {payload:e,cardIds:s,modelsById:c}}function Pr(e,t,r,n){if(!e||!Array.isArray(t)||t.length===0)return e;let o=e.modelsById,s=e.cardIds,a=false,c=false,u={};for(let h of s){let R=o[h],p=R&&R.requires;if(p&&typeof p=="object")for(let y of Object.keys(p))(u[y]=u[y]||[]).push(h);}function k(){a||(o={...o},a=true);}for(let h of t)if(!(!h||!h.kind)){if(h.kind==="computed_values"){let R=h.cardId,p=o[R];if(!p)continue;let y=h.values||{};if(he(p.computed_values,y))continue;k(),o[R]={...p,computed_values:y},c=true;}else if(h.kind==="data_object"){let R=h.key,p=h.payload,y=u[R]||[];for(let f of y){let g=o[f];if(!g)continue;let $=g.requires||{};he($[R],p)||(k(),o[f]={...g,requires:{...$,[R]:p}},c=true);}}else if(h.kind==="card_refreshed"){let R=h.cardId,p=null,y=o[R],f=h.card;if(y&&f&&typeof f=="object"&&!Array.isArray(f)){let g=f,$=g.card_data&&typeof g.card_data=="object"&&!Array.isArray(g.card_data)?g.card_data:y.card_data,E=g.requires&&typeof g.requires=="object"&&!Array.isArray(g.requires)?g.requires:y.requires,C=g.computed_values&&typeof g.computed_values=="object"&&!Array.isArray(g.computed_values)?g.computed_values:y.computed_values,_=g.runtime_state&&typeof g.runtime_state=="object"&&!Array.isArray(g.runtime_state)?g.runtime_state:y.runtime_state;p={...y,card:f,card_data:$,requires:E,computed_values:C,runtime_state:_};}if(!p)try{let g=n();g&&(p=r(g,R));}catch{}if(!p||y&&he(y.card,p.card)&&he(y.card_data,p.card_data)&&he(y.requires,p.requires)&&he(y.computed_values,p.computed_values)&&he(y.runtime_state,p.runtime_state))continue;k(),o[R]=p,s.includes(R)||(s=[...s,R]),c=true;}else if(h.kind==="card_chats"){let R=h.cardId,p=o[R];if(!p)continue;let y=Array.isArray(h.messages)?h.messages:p.card_chats?.messages??[],f=typeof h.receiving=="boolean"?h.receiving:p.card_chats?.receiving??false,g=typeof h.processing=="boolean"?h.processing:p.card_chats?.processing??false,$={messages:y,receiving:f,processing:g};if(he(p.card_chats,$))continue;k(),o[R]={...p,card_chats:$},c=true;}else if(h.kind==="chat_messages"){let R=h.cardId,p=o[R];if(!p)continue;let y=Array.isArray(h.messages)?h.messages:[],f=p.card_chats||{receiving:false,processing:false},g={messages:y,receiving:f.receiving,processing:!!f.processing};if(he(p.card_chats,g))continue;k(),o[R]={...p,card_chats:g},c=true;}else if(h.kind==="status"){let R=h.status?.cards??[];for(let p of R){let y=p?.name;if(!y||!o[y])continue;let f=o[y],g=In(p.status),$={...f.card_data||{},status:g,lastRun:p.runtime?.last_transition_at??null,...p.error?.message?{error:p.error.message}:{}};p.error?.message||delete $.error;let E={task_status:p.status??null,card_status:g,runtime:p.runtime?Rt(p.runtime):{},error:p.error?Rt(p.error):null,blocked_by:Array.isArray(p.blocked_by)?Rt(p.blocked_by):[],requires_missing:Array.isArray(p.requires_missing)?Rt(p.requires_missing):[]};he(f.card_data,$)&&he(f.runtime_state,E)||(k(),o[y]={...f,card_data:$,runtime_state:E},c=true);}}}return c?{payload:e.payload,cardIds:s,modelsById:o}:e}function Ls(e,t){let r=t?.cards??[],n=t?.onWarn??(()=>{}),o=`${e}:notify`,s=$r(e,{callbackBaseUrl:t?.callbackBaseUrl,notifyChannel:o,onWarn:n}),a=we(re({kind:"localstorage",value:e})),c=re({kind:"localstorage",value:`${e}:card-store`}),u=re({kind:"localstorage",value:`${e}:outputs`}),k=t?.taskExecutor??null,h=t?.chatHandler??null,R=re({kind:"in-browser",value:`${e}:task-executor`}),p=re({kind:"in-browser",value:`${e}:chat-handler`});k&&s.registerHandler(R,k),h&&s.registerHandler(p,h);let y={async invoke(x,I){return x.howToRun==="in-browser",s.dispatchExecution(x,I)}},f=t?.taskExecutorRef??(k?{meta:"task-executor",howToRun:"in-browser",whatToRun:R}:void 0),g=t?.chatHandlerRef??(h?{meta:"chat-handler",howToRun:"in-browser",whatToRun:p}:void 0),$=Br(),E=Ir({boardId:e,boards:[{label:e,boardAdapter:s,baseRef:a,cardStoreRef:c,outputsStoreRef:u,notifyRef:{kind:"in-memory-bus",value:o},taskExecutorRef:f,chatHandlerRef:g}],invocationAdapter:y,notificationTransport:$,logger:{info:(...x)=>console.log("[board]",...x),warn:(...x)=>{n(String(x[0])),console.warn("[board]",...x);},error:(...x)=>console.error("[board]",...x)}});r.length&&E.cardStore.set({body:r}),t?.onBoardChange&&bt(o).subscribe(I=>{let A=I;!A||A.kind!=="notification-batch"||!Array.isArray(A.notifications)||A.notifications.length===0||t.onBoardChange?.({notifications:A.notifications});});function C(x,I,A){let O=A?JSON.stringify(A):"",J=new TextEncoder().encode(O),H=false;return {method:x,url:I,headers:{"content-type":"application/json"},on(K,ie){},[Symbol.asyncIterator](){let K={async next(){return H?{done:true,value:void 0}:(H=true,{done:false,value:J})},[Symbol.asyncIterator](){return K}};return K}}}function _(){let x=200,I=[];return {res:{writeHead(O){x=O;},write(O){return I.push(typeof O=="string"?O:new TextDecoder().decode(O)),true},end(O){O&&I.push(typeof O=="string"?O:new TextDecoder().decode(O));}},getResult:()=>{let O=I.join(""),J;try{J=JSON.parse(O);}catch{J=O;}return {status:x,body:J}}}}let P=E.apiBasePath;return {async bootstrap(){let x=C("GET",`${P}/bootstrap`),{res:I}=_();await E.handleRuntimeApi(x,I,new URL(`http://localhost${P}/bootstrap`));},getState(){return E.buildPublishedRuntimePayload()},async patchCard(x,I){let A=`${P}/cards/${encodeURIComponent(x)}`,O=C("PATCH",A,I),{res:J}=_();await E.handleRuntimeApi(O,J,new URL(`http://localhost${A}`));},async applyCardAction(x,I,A){let O=`${P}/cards/${encodeURIComponent(x)}/actions`,J=C("POST",O,{actionType:I,payload:A}),{res:H}=_();await E.handleRuntimeApi(J,H,new URL(`http://localhost${O}`));},readChatRecords(x){let I=`${P}/cards/${encodeURIComponent(x)}/chats`,A=C("GET",I),O=_();E.handleRuntimeApi(A,O.res,new URL(`http://localhost${I}`));let H=O.getResult().body;return Array.isArray(H?.messages)?H.messages:[]},clearChatRecords(x){E.clearChatRecords(x);},writeMemoryBlob(x,I){return s.writeMemoryBlob(x,I)},reportSourceFetched(x,I){E.reportSourceFetched(x,I);},reportSourceFetchFailure(x,I){E.reportSourceFetchFailure(x,I);},get runtime(){return E}}}function Ds(e,t){return Fr(e,t,Ye)}function qs(e,t,r){return Pr(e,t,Ye,r)}
|
|
9
|
+
exports.applyNotification=qs;exports.buildBoardState=Ds;exports.create=Ls;exports.selectAllLiveCardModels=En;exports.selectLiveCardModel=Ye;return exports;})({});//# sourceMappingURL=board-livecards-localstorage.js.map
|
|
10
10
|
//# sourceMappingURL=board-livecards-localstorage.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { B as BoardPlatformAdapter, N as NotificationTransport } from '../types-
|
|
1
|
+
import { B as BoardPlatformAdapter, N as NotificationTransport } from '../types-CSiGbY__.js';
|
|
2
2
|
import { E as ExecutionRef } from '../execution-interface-ftO1W7Po.js';
|
|
3
3
|
import '../board-live-cards-lib-tjYsPt5U.js';
|
|
4
4
|
|