yaml-flow 8.0.4 → 8.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  {
2
- "generatedAt": "2026-05-14T19:57:39.460Z",
2
+ "generatedAt": "2026-05-14T20:10:56.442Z",
3
3
  "algorithm": "sha256",
4
4
  "files": {
5
5
  "browser/board-livecards-localstorage.js": {
@@ -10,6 +10,6 @@ import {spawn,execFile,execFileSync}from'child_process';import*as P from'fs';imp
10
10
  `)+`
11
11
  `,s=Lr.get(t);if(s&&!s.socket.destroyed){s.ready?s.socket.write(n):s.queue.push(n);return}let o=Kc(t),a=Wo.createConnection(o);s={socket:a,ready:false,queue:[n]},Lr.set(t,s),a.on("connect",()=>{s.ready=true;for(let i of s.queue)a.write(i);s.queue.length=0;}),a.on("error",i=>{r?.(`[named-pipe publish] ${o}: ${i instanceof Error?i.message:String(i)}`),Lr.delete(t);}),a.on("close",()=>{Lr.delete(t);});}function Gn(){return {executeSync(t,e,r){return Zo({command:t,args:e,cwd:r?.cwd,timeoutMs:r?.timeout,env:r?.env},{encoding:r?.encoding,input:r?.input})},executeAsync(t,e,r){Gc({command:t,args:e},r);},resolveInvocation(t,e){let r=Bc({command:t,args:e});return {cmd:r.command,args:r.args??[]}},splitCommand:Qo,spawnDetached(t,e){Br({command:t,args:e});}}}var na=dirname(fileURLToPath(import.meta.url)),Wc=createRequire(import.meta.url);function Yc(){let t=resolve(na,"./jsonata-sync.cjs");return existsSync(t)?t:resolve(na,"../../card-compute/jsonata-sync.cjs")}var yt=Wc(Yc());function sa(t,e,r){if(!t||typeof t!="object")return {};let n={};if(Array.isArray(t.cmdTemplate)){let s=[];for(let o of t.cmdTemplate)try{s.push(String(yt(o).evaluate(e)));}catch(a){let i=a instanceof Error?a.message:String(a);throw new Error(`[${r}] argsMassaging.cmdTemplate failed on "${o}": ${i}`)}n.cmdArgs=s;}if(typeof t.stdinTemplate=="string")try{n.stdin=yt(t.stdinTemplate).evaluate(e);}catch(s){let o=s instanceof Error?s.message:String(s);throw new Error(`[${r}] argsMassaging.stdinTemplate failed: ${o}`)}if(typeof t.urlTemplate=="string")try{n.url=String(yt(t.urlTemplate).evaluate(e));}catch(s){let o=s instanceof Error?s.message:String(s);throw new Error(`[${r}] argsMassaging.urlTemplate failed: ${o}`)}if(typeof t.headerTemplate=="string")try{let s=yt(t.headerTemplate).evaluate(e);if(typeof s!="object"||s===null)throw new Error(`headerTemplate must produce an object, got: ${JSON.stringify(s)}`);n.headers=s;}catch(s){let o=s instanceof Error?s.message:String(s);throw new Error(`[${r}] argsMassaging.headerTemplate failed: ${o}`)}if(typeof t.bodyTemplate=="string")try{n.body=yt(t.bodyTemplate).evaluate(e);}catch(s){let o=s instanceof Error?s.message:String(s);throw new Error(`[${r}] argsMassaging.bodyTemplate failed: ${o}`)}return n}function Xc(t,e){let r=typeof t=="object"?t.value:ke(t).value;switch(r){case "source-cli-task-executor":{let n=ce.join(e,"source-cli-task-executor.js");if(P.existsSync(n))return {command:process.execPath,args:[n]};let s=ce.join(e,"source-cli-task-executor.ts"),o=ce.join(e,"..","..","node_modules","tsx","dist","cli.mjs"),a=ce.join(e,"..","..","node_modules",".bin","tsx"),i=P.existsSync(o)?o:a;return P.existsSync(s)&&P.existsSync(i)?{command:process.execPath,args:[i,s]}:{command:process.execPath,args:[n]}}case "board-live-cards":{let{cmd:n,args:s}=Vn(e,"_",[]);return {command:n,args:s}}default:throw new Error(`resolveBuiltIn: unknown built-in name "${r}". Supported: source-cli-task-executor, board-live-cards`)}}function oa(t,e){if(t.howToRun==="built-in"){let{command:n,args:s}=Xc(t.whatToRun,e);return {command:n,baseArgs:s}}let r=typeof t.whatToRun=="object"?t.whatToRun.value:ke(t.whatToRun).value;switch(t.howToRun){case "local-node":return {command:process.execPath,baseArgs:[r]};case "local-python":return {command:process.platform==="win32"?"python":"python3",baseArgs:[r]};case "local-process":return {command:r,baseArgs:[]};default:throw new Error(`resolveBaseInvocation: howToRun "${t.howToRun}" is not a local transport`)}}function Qc(t,e){let r=[t.subcommand];return t.inRef&&r.push("--in-ref",t.inRef),t.outRef&&r.push("--out-ref",t.outRef),t.errRef&&r.push("--err-ref",t.errRef),e&&r.push("--extra",Buffer.from(JSON.stringify(e)).toString("base64")),r}function Zc(t,e){return {subcommand:t.subcommand,...t.inRef?{inRef:t.inRef}:{},...t.outRef?{outRef:t.outRef}:{},...t.errRef?{errRef:t.errRef}:{},...e?{extra:e}:{}}}function aa(t,e){return oa(t,e)}async function ed(t,e){let r={...e,whatToRun:t.whatToRun},n=sa(t.argsMassaging,r,"_invokeTaskExecutorHttp"),s=n.url??(typeof t.whatToRun=="object"?t.whatToRun.value:ke(t.whatToRun).value),o=n.body?n.body:Zc(e,t.extra),a={"Content-Type":"application/json"},i=n.headers?{...a,...n.headers}:a,u=await fetch(s,{method:t.howToRun==="http:get"?"GET":"POST",headers:i,body:JSON.stringify(o)});if(!u.ok){let d=await u.text().catch(()=>"");return {status:"error",error:`HTTP ${u.status}: ${d}`}}let c=await u.json().catch(()=>null);return c&&typeof c.status=="string"?c:{status:"success"}}function ia(t,e,r){if(t.howToRun==="http:post"||t.howToRun==="http:get"){ed(t,e).catch(i=>{console.error(`[dispatchTaskExecutorDetached] HTTP dispatch failed: ${i.message}`);});return}let{command:s,baseArgs:o}=oa(t,r),a=Qc(e,t.extra);Br({command:s,args:[...o,...a]});}function td(){return {read(t){if(!P.existsSync(t))return null;try{return P.readFileSync(t,"utf-8")}catch{return null}},write(t,e){P.mkdirSync(ce.dirname(t),{recursive:true}),P.writeFileSync(t,e,"utf-8");}}}function ua(t){return td();}function tr(t,e){if(process.platform!=="win32"){P.renameSync(t,e);return}let r=[10,20,40,80,160];for(let n=0;n<=r.length;n++)try{P.renameSync(t,e);return}catch(s){let o=s.code;if((o==="EPERM"||o==="EBUSY")&&n<r.length){Atomics.wait(new Int32Array(new SharedArrayBuffer(4)),0,0,r[n]);continue}throw s}}function Gr(t){function e(s){return ce.join(t,...s.split("/"))}function r(s){return ce.relative(t,s).replace(/\\/g,"/")}function n(s,o){if(P.existsSync(s))for(let a of P.readdirSync(s,{withFileTypes:true})){let i=ce.join(s,a.name);if(a.isDirectory()){n(i,o);continue}a.isFile()&&o.push(r(i));}}return {read(s){let o=e(s);if(!P.existsSync(o))return null;try{return P.readFileSync(o,"utf-8")}catch{return null}},write(s,o){let a=e(s),i=`${a}.${process.pid}.${randomUUID()}.tmp`;P.mkdirSync(ce.dirname(a),{recursive:true}),P.writeFileSync(i,o,"utf-8"),tr(i,a);},exists(s){return P.existsSync(e(s))},remove(s){let o=e(s);try{P.existsSync(o)&&P.unlinkSync(o);}catch{}},readBytes(s){let o=e(s);if(!P.existsSync(o))return null;try{return new Uint8Array(P.readFileSync(o))}catch{return null}},writeBytes(s,o){let a=e(s),i=`${a}.${process.pid}.${randomUUID()}.tmp`;P.mkdirSync(ce.dirname(a),{recursive:true}),P.writeFileSync(i,Buffer.from(o)),tr(i,a);},listKeys(s){let o=[];n(t,o);let a=o.sort();return s?a.filter(i=>i.startsWith(s)):a},stat(s){let o=e(s);if(!P.existsSync(o))return null;try{let a=P.statSync(o);return {key:s,size:Number(a.size||0),updatedAt:new Date(a.mtimeMs).toISOString()}}catch{return null}}}}function Jn(){return {read(t){if(!P.existsSync(t))return null;try{return P.readFileSync(t,"utf-8")}catch{return null}},write(t,e){let r=`${t}.${process.pid}.${randomUUID()}.tmp`;P.mkdirSync(ce.dirname(t),{recursive:true}),P.writeFileSync(r,e,"utf-8"),tr(r,t);},exists(t){return P.existsSync(t)},remove(t){try{P.existsSync(t)&&P.unlinkSync(t);}catch{}},readBytes(t){if(!P.existsSync(t))return null;try{return new Uint8Array(P.readFileSync(t))}catch{return null}},writeBytes(t,e){let r=`${t}.${process.pid}.${randomUUID()}.tmp`;P.mkdirSync(ce.dirname(t),{recursive:true}),P.writeFileSync(r,Buffer.from(e)),tr(r,t);},stat(t){if(!P.existsSync(t))return null;try{let e=P.statSync(t);return {key:t,size:Number(e.size||0),updatedAt:new Date(e.mtimeMs).toISOString()}}catch{return null}}}}function Hn(t){function e(n){return ce.join(t,...n.split("/"))+".json"}function r(n,s,o,a){if(P.existsSync(n))for(let i of P.readdirSync(n,{withFileTypes:true})){let u=s?`${s}/${i.name}`:i.name;if(i.isDirectory()){r(ce.join(n,i.name),u,o,a);continue}if(!i.isFile()||!i.name.endsWith(".json"))continue;let c=u.replace(/\.json$/,"");(!o||c.startsWith(o))&&a.push(c);}}return {read(n){let s=e(n);if(!P.existsSync(s))return null;try{return JSON.parse(P.readFileSync(s,"utf-8"))}catch{return null}},write(n,s){let o=e(n),a=`${o}.${process.pid}.${randomUUID()}.tmp`;P.mkdirSync(ce.dirname(o),{recursive:true}),P.writeFileSync(a,JSON.stringify(s,null,2),"utf-8"),tr(a,o);},delete(n){let s=e(n);try{P.existsSync(s)&&P.unlinkSync(s);}catch{}},listKeys(n){let s=[];return r(t,"",n,s),s.sort()}}}function Un(t){if(t==null||typeof t!="object")return JSON.stringify(t);if(Array.isArray(t))return `[${t.map(Un).join(",")}]`;let e=t;return `{${Object.keys(e).sort().map(n=>`${JSON.stringify(n)}:${Un(e[n])}`).join(",")}}`}function ca(t){return createHash("sha256").update(Un(t)).digest("hex")}function da(t){let e=ce.join(t,"board-journal.jsonl");return {readAllEntries(){if(!P.existsSync(e))return [];let r=P.readFileSync(e,"utf-8").trim();return r?r.split(`
12
12
  `).filter(Boolean).map(n=>JSON.parse(n)):[]},appendEntry(r){P.appendFileSync(e,JSON.stringify(r)+`
13
- `,"utf-8");},generateId(){return randomUUID()}}}function la(t){return {tryAcquire(){try{if(!P.existsSync(t)){P.mkdirSync(ce.dirname(t),{recursive:!0});try{P.writeFileSync(t,"{}",{flag:"wx"});}catch{}}return lockSync(t,{retries:0})}catch{return null}}}}var fa={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://nsreehari.github.io/boards/live-cards.schema.json",definitions:{bind_ref:{description:"A card data path reference, e.g. 'card_data.raw_quotes' or 'requires.upstream'",type:"string",pattern:"^(card_data|requires|fetched_sources|computed_values)(\\.|$)"},bind_or_literal:{description:"A literal value or a bind reference object",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref"}},required:["bind"]}]},compute_expr:{description:"A declarative JSON compute expression",type:"object",required:["fn"],properties:{fn:{type:"string",description:"Function name from the built-in vocabulary",enum:["sum","avg","min","max","count","first","last","add","sub","mul","div","round","abs","mod","gt","gte","lt","lte","eq","neq","if","and","or","not","concat","upper","lower","template","filter","pluck","map","sort","slice","flat","unique","group","get","default","now","diff_days","format_date"]},input:{description:"card_data.path, literal, array of inputs, or nested compute_expr",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{$ref:"#/definitions/compute_expr"}]},field:{type:"string",description:"For pluck/sum/group \u2014 the object key to extract"},where:{$ref:"#/definitions/compute_expr",description:"For filter \u2014 predicate expression ($ = current item)"},cond:{$ref:"#/definitions/compute_expr",description:"For if \u2014 condition expression"},then:{description:"For if \u2014 value when cond is truthy"},else:{description:"For if \u2014 value when cond is falsy"},format:{type:"string",description:"For format_date \u2014 date format string"}}},meta:{type:"object",properties:{title:{type:"string"},tags:{type:"array",items:{type:"string"}}}},requires:{type:"array",items:{type:"string"},description:"IDs of upstream nodes this node depends on"},provides:{type:"array",items:{type:"object",required:["bindTo","ref"],properties:{bindTo:{type:"string",description:"Token name published downstream"},ref:{type:"string",description:"Path to read value from (card_data.*, requires.*, fetched_sources.*, computed_values.*)"}}},description:"Explicit bindings exposing computed or card_data values downstream as named tokens"},compute_step:{description:"A single ordered compute step: reads card_data.*/requires.*/computed_values.*, writes to computed_values[bindTo]",type:"object",required:["bindTo","expr"],properties:{bindTo:{type:"string",description:"Key in computed_values to write result"},expr:{type:"string",description:"JSONata expression evaluated against { card_data, requires, fetched_sources, computed_values }"}}},source_def:{description:"One source entry. The engine requires 'bindTo' (compute namespace key) and 'outputFile' (delivery signal path). bindTo and outputFile must be unique across all source_defs in a card. Every other property is yours \u2014 add whatever your task-executor needs: kind, url, headers, mailbox, channel, model, query, etc. The full object is passed verbatim as the --in JSON to the executor.",type:"object",required:["bindTo","outputFile"],additionalProperties:true,properties:{bindTo:{type:"string",description:"Key under fetched_sources.* available in compute expressions"},outputFile:{type:"string",description:"Board-relative path the executor writes its JSON result to. Presence of this file signals delivery."},projections:{type:"object",description:"Named data projections from card_data or requires, evaluated before the executor is called. Each key is a ref name; each value is a JSONata expression rooted at card_data or requires. The resolved values are passed to the executor as _projections. fetched_sources, computed_values, and source_defs are not accessible here \u2014 sources run before those exist.",additionalProperties:{type:"string"}},optionalForCompletionGating:{type:"boolean",default:false,description:"When true this source does not gate card completion. Default false when absent, so source_defs are completion-gating by default."},timeout:{type:"integer",minimum:0,default:12e4,description:"Executor/script timeout in ms. Default: 120 000 (2 min)."},script:{type:"string",description:"Legacy direct-run: shell command executed when no .task-executor is registered. stdout is captured as the result."}}},render_element:{type:"object",required:["kind"],properties:{id:{type:"string",description:"Optional element ID for targeted updates"},kind:{enum:["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]},label:{type:"string",description:"Heading above this element"},className:{type:"string",description:"Bootstrap grid class, e.g. 'col-12 col-md-6'"},visible:{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 element shown only if truthy"},data:{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref",description:"card_data/requires/fetched_sources/computed_values path to read data from"},writeTo:{$ref:"#/definitions/bind_ref",description:"card_data path for user input (form, filter, todo, notes)"},columns:{type:"array",items:{type:"string"},description:"table: visible columns"},maxRows:{type:"integer",description:"table/list: max rows to display"},sortable:{type:"boolean",default:true,description:"table: enable click-to-sort"},placeholder:{type:"string",description:"Empty-state message"},chartType:{enum:["bar","line","pie","doughnut"]},chartOptions:{type:"object",description:"Chart.js options passthrough"},fields:{type:"object",description:"JSON Schema for form/filter fields"},thresholds:{type:"object",properties:{green:{type:"string"},amber:{type:"string"}}},colorMap:{type:"object",description:"badge: value \u2192 Bootstrap color"},style:{enum:["heading","muted","default"],description:"text: display style"},upload:{type:"boolean",default:true,description:"file-upload: show drop zone (false = read-only file list)"},accept:{type:"array",items:{type:"string"},description:"file-upload: allowed extensions"},multiple:{type:"boolean",default:true,description:"file-upload: allow multiple files"},fileAttach:{type:"boolean",default:false,description:"chat: enable inline file attachments"},fileAccept:{type:"array",items:{type:"string"},description:"chat: allowed attachment extensions"},buttons:{type:"array",description:"actions: button definitions",items:{type:"object",required:["id","label"],properties:{id:{type:"string"},label:{type:"string"},style:{type:"string",description:"Bootstrap button variant, e.g. 'success', 'outline-danger'"},size:{type:"string",default:"sm"},disabled:{oneOf:[{type:"boolean"},{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 truthy = disabled"}]}}}}}}}},view:{type:"object",required:["elements"],properties:{elements:{type:"array",minItems:1,items:{$ref:"#/definitions/render_element"}},layout:{type:"object",properties:{board:{type:"object",properties:{col:{type:"integer",minimum:1,maximum:12},order:{type:"integer"}}},canvas:{type:"object",properties:{x:{type:"number"},y:{type:"number"},w:{type:"number"},h:{type:"number"}}}}},features:{type:"object",properties:{chat:{type:"boolean",default:false},notes:{type:"boolean",default:false},refresh:{type:"boolean",default:true}}}}}},title:"LiveCard",description:"A unified card node. Behavior depends on which sections are present (source_defs, compute, view, etc.)",type:"object",required:["id"],additionalProperties:false,properties:{id:{type:"string"},requires:{$ref:"#/definitions/requires"},provides:{$ref:"#/definitions/provides"},meta:{$ref:"#/definitions/meta"},view:{$ref:"#/definitions/view"},card_data:{type:"object",description:"Authored card data and runtime metadata. Includes uploaded-file metadata maintained by host handlers and inference evaluation results.",properties:{files:{type:"array",description:"Optional uploaded-file metadata maintained by host handlers. Stored name is normalized and serial-prefixed (for example 001-my_file.pdf).",items:{type:"object",required:["name","stored_name"],properties:{name:{type:"string",minLength:1},stored_name:{type:"string",minLength:5,maxLength:32,pattern:"^[0-9]{3,}-[a-z0-9._-]+$"},size:{oneOf:[{type:"integer",minimum:0},{type:"null"}]},mime_type:{type:"string"},path:{type:"string",pattern:"^[^\\s]+/files/[0-9]{3,}-[a-z0-9._-]+$"},uploaded_at:{type:"string",format:"date-time"}},additionalProperties:false}}},additionalProperties:true},source_defs:{type:"array",description:"Source entries. Each entry is passed verbatim to the board's .task-executor (registered via init --task-executor) as the --in JSON file. The executor fetches/generates the data and writes JSON to --out. If no executor is registered, the built-in executor runs the entry's 'cli' command directly. Sources gate completion by default. Set optionalForCompletionGating: true for enrichment-only source_defs that should not block task-completed.",items:{$ref:"#/definitions/source_def"}},compute:{type:"array",description:"Ordered array of compute steps. Each reads card_data.*/requires.*/fetched_sources.*/computed_values.* and writes to ephemeral computed_values[bindTo].",items:{$ref:"#/definitions/compute_step"}}}};var Bu=jc(Mu());var jh=createRequire(import.meta.url),Nh=jh("./jsonata-sync.cjs"),Cn=null;var Lu=/\b(card_data|requires|fetched_sources|computed_values|source_defs)\b/g,qh=/^\s*(card_data|requires|fetched_sources|computed_values|source_defs)(\.|$)/;function Dh(t){let e=new Set,r;for(Lu.lastIndex=0;(r=Lu.exec(t))!==null;)e.add(r[1]);return e}function Gu(t){let e=qh.exec(t);return e?e[1]:null}function Vu(t,e,r,n){try{Nh(t);}catch(o){let a=o instanceof Error?o.message:String(o);n.push(`${e}: invalid JSONata expression (${a})`);return}let s=Dh(t);for(let o of s)r.has(o)||n.push(`${e}: disallowed namespace "${o}" in expression`);}function Oo(t,e,r){if(Array.isArray(t)){t.forEach((s,o)=>{Oo(s,`${e}/${o}`,r);});return}if(typeof t=="string"){let s=Gu(t);if(!s)return;new Set(["card_data","requires","computed_values"]).has(s)||r.push(`${e}: disallowed namespace "${s}" in view reference`);return}if(!t||typeof t!="object")return;let n=t;for(let[s,o]of Object.entries(n))Oo(o,`${e}/${s}`,r);}function Fh(){if(Cn)return Cn;let t=new Bu.default({allErrors:true});return Ph(t),Cn=t.compile(fa),Cn}function Ku(t){let e=Fh(),r=e(t),n=(e.errors??[]).map(s=>`${s.instancePath||"/"}: ${s.message??"unknown error"}`);if(t&&typeof t=="object"&&!Array.isArray(t)){let s=t.source_defs;if(Array.isArray(s)){let o=new Set,a=new Set;s.forEach((i,u)=>{if(!i||typeof i!="object"||Array.isArray(i))return;let c=i;typeof c.bindTo=="string"&&c.bindTo&&(o.has(c.bindTo)&&n.push(`/source_defs/${u}/bindTo: bindTo "${c.bindTo}" must be unique across all source_defs`),o.add(c.bindTo)),typeof c.outputFile=="string"&&c.outputFile&&(a.has(c.outputFile)&&n.push(`/source_defs/${u}/outputFile: outputFile "${c.outputFile}" must be unique across all source_defs`),a.add(c.outputFile));});}}return !r||n.length>0?{ok:false,errors:n}:{ok:true,errors:[]}}function Uu(t){let e=[];if(!t||typeof t!="object"||Array.isArray(t))return {ok:true,errors:[]};let r=t,n=r.compute;Array.isArray(n)&&n.forEach((c,d)=>{if(!c||typeof c!="object"||Array.isArray(c))return;let l=c.expr;typeof l!="string"||l.trim().length===0||Vu(l,`/compute/${d}/expr`,new Set(["card_data","requires","fetched_sources","computed_values"]),e);});let s=new Set(["card_data","requires","fetched_sources","computed_values"]),o=r.provides;Array.isArray(o)&&o.forEach((c,d)=>{if(!c||typeof c!="object"||Array.isArray(c))return;let l=c.ref;if(typeof l!="string"||l.trim().length===0)return;let b=Gu(l);b===null?e.push(`/provides/${d}/ref: path "${l}" must start with a valid namespace (${[...s].join(", ")})`):s.has(b)||e.push(`/provides/${d}/ref: disallowed namespace "${b}" in path "${l}" (valid: ${[...s].join(", ")})`);});let a=r.view;a&&typeof a=="object"&&!Array.isArray(a)&&Oo(a,"/view",e);let i=new Set(["card_data","requires"]),u=r.source_defs;return Array.isArray(u)&&u.forEach((c,d)=>{if(!c||typeof c!="object"||Array.isArray(c))return;let l=c.projections;if(!(!l||typeof l!="object"||Array.isArray(l)))for(let[b,y]of Object.entries(l))typeof y!="string"||y.trim().length===0||Vu(y,`/source_defs/${d}/projections/${b}`,i,e);}),{ok:e.length===0,errors:e}}function jo(t){let e=Ku(t);if(!e.ok)return e;let r=Uu(t);return r.ok?{ok:true,errors:[]}:{ok:false,errors:r.errors}}var ut={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function xe(t){return t?Array.isArray(t.provides)?t.provides:[]:[]}function ct(t){return t?Array.isArray(t.requires)?t.requires:[]:[]}function Ju(t){return t.tasks??{}}function No(t){return t?t.status===ut.FAILED||t.status===ut.INACTIVATED:false}function Hu(t,e){return t.refreshStrategy??e?.refreshStrategy??"data-changed"}function zu(t){return t.maxExecutions}function Wu(t,e){let r=new Set;for(let[n,s]of Object.entries(e))if(s.status===ut.COMPLETED){let o=t.tasks[n];o&&xe(o).forEach(i=>r.add(i));}return Array.from(r)}function Yu(t,e){let r={};return t.forEach(n=>{let s=e[n];if(!s)return;xe(s).forEach(a=>{r[a]||(r[a]=[]),r[a].push(n);});}),r}function Xu(t,e,r){let n=t.tasks[e]??$n(),s={};if(r){let a=r.tasks[e],i=ct(a);for(let u of i)for(let[c,d]of Object.entries(r.tasks))if(xe(d).includes(u)){let l=t.tasks[c];l?.lastDataHash&&(s[u]=l.lastDataHash);break}}let o={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:s};return {...t,tasks:{...t.tasks,[e]:o},lastUpdated:new Date().toISOString()}}function Qu(t,e,r,n,s,o){let a=t.tasks[r]??$n(),i=e.tasks[r];if(!i)throw new Error(`Task "${r}" not found in graph`);let u;n&&i.on&&i.on[n]?u=i.on[n]:u=xe(i);let c=a.startConsumedHashes?{...a.startConsumedHashes}:{...a.lastConsumedHashes};if(!a.startConsumedHashes){let b=i.requires??[];for(let y of b)for(let[m,p]of Object.entries(e.tasks))if(xe(p).includes(y)){let k=t.tasks[m];k?.lastDataHash&&(c[y]=k.lastDataHash);break}}let d={...a,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:a.executionCount+1,lastEpoch:a.executionCount+1,lastDataHash:s,data:o,lastConsumedHashes:c,error:void 0},l=[...new Set([...t.availableOutputs,...u])];return {...t,tasks:{...t.tasks,[r]:d},availableOutputs:l,lastUpdated:new Date().toISOString()}}function Zu(t,e,r,n){let s=t.tasks[r]??$n(),o=e.tasks[r];if(o?.retry){let u=s.retryCount+1;if(u<=o.retry.max_attempts){let c={...s,status:"not-started",retryCount:u,lastUpdated:new Date().toISOString(),error:n};return {...t,tasks:{...t.tasks,[r]:c},lastUpdated:new Date().toISOString()}}}let a={...s,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:s.executionCount+1},i=t.availableOutputs;if(o?.on_failure&&o.on_failure.length>0&&(i=[...new Set([...t.availableOutputs,...o.on_failure])]),o?.circuit_breaker&&a.executionCount>=o.circuit_breaker.max_executions){let u=o.circuit_breaker.on_break;i=[...new Set([...i,...u])];}return {...t,tasks:{...t.tasks,[r]:a},availableOutputs:i,lastUpdated:new Date().toISOString()}}function ec(t,e,r,n){let s=t.tasks[e]??$n(),o={...s,progress:typeof n=="number"?n:s.progress,messages:[...s.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:s.status}]:[]],lastUpdated:new Date().toISOString()};return {...t,tasks:{...t.tasks,[e]:o},lastUpdated:new Date().toISOString()}}function tc(t,e){let r=t.tasks[e];if(!r)return t;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 {...t,tasks:{...t.tasks,[e]:n},lastUpdated:new Date().toISOString()}}function $n(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function xn(t,e){let r=`live-${Date.now()}`,n={};for(let o of Object.keys(t.tasks))n[o]=nc();let s={status:"running",tasks:n,availableOutputs:[],stuckDetection:{is_stuck:false,stuck_description:null,outputs_unresolvable:[],tasks_blocked:[]},lastUpdated:new Date().toISOString(),executionId:r,executionConfig:{executionMode:t.settings.execution_mode??"eligibility-mode",conflictStrategy:t.settings.conflict_strategy??"alphabetical",completionStrategy:t.settings.completion}};return {config:t,state:s}}function Mh(t,e){let{config:r,state:n}=t;if("executionId"in e&&e.executionId&&e.executionId!==n.executionId)return t;switch(e.type){case "task-started":return {config:r,state:Xu(n,e.taskName,r)};case "task-completed":return {config:r,state:Qu(n,r,e.taskName,e.result,e.dataHash,e.data)};case "task-failed":return {config:r,state:Zu(n,r,e.taskName,e.error)};case "task-progress":return {config:r,state:ec(n,e.taskName,e.message,e.progress)};case "task-restart":return {config:r,state:tc(n,e.taskName)};case "inject-tokens":return {config:r,state:{...n,availableOutputs:[...new Set([...n.availableOutputs,...e.tokens])],lastUpdated:new Date().toISOString()}};case "agent-action":return {config:r,state:Jh(n,e.action)};case "task-upsert":return Lh(t,e.taskName,e.taskConfig);case "task-removal":return Vh(t,e.taskName);case "node-requires-add":return Bh(t,e.nodeName,e.tokens);case "node-requires-remove":return Gh(t,e.nodeName,e.tokens);case "node-provides-add":return Kh(t,e.nodeName,e.tokens);case "node-provides-remove":return Uh(t,e.nodeName,e.tokens);default:return t}}function rc(t,e){return e.reduce((r,n)=>Mh(r,n),t)}function Lh(t,e,r){let n=!!t.config.tasks[e];return {config:{...t.config,tasks:{...t.config.tasks,[e]:r}},state:{...t.state,tasks:{...t.state.tasks,[e]:n?t.state.tasks[e]:nc()},lastUpdated:new Date().toISOString()}}}function Vh(t,e){if(!t.config.tasks[e])return t;let{[e]:r,...n}=t.config.tasks,{[e]:s,...o}=t.state.tasks;return {config:{...t.config,tasks:n},state:{...t.state,tasks:o,lastUpdated:new Date().toISOString()}}}function Bh(t,e,r){let n=t.config.tasks[e];if(!n)return t;let s=ct(n),o=r.filter(a=>!s.includes(a));return o.length===0?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,requires:[...s,...o]}}},state:t.state}}function Gh(t,e,r){let n=t.config.tasks[e];if(!n)return t;let s=ct(n),o=s.filter(a=>!r.includes(a));return o.length===s.length?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,requires:o}}},state:t.state}}function Kh(t,e,r){let n=t.config.tasks[e];if(!n)return t;let s=xe(n),o=r.filter(a=>!s.includes(a));return o.length===0?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,provides:[...s,...o]}}},state:t.state}}function Uh(t,e,r){let n=t.config.tasks[e];if(!n)return t;let s=xe(n),o=s.filter(a=>!r.includes(a));return o.length===s.length?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,provides:o}}},state:t.state}}function Ar(t){return {version:1,config:t.config,state:t.state,snapshotAt:new Date().toISOString()}}function En(t){if(!t||typeof t!="object")throw new Error("Invalid snapshot: expected an object");let e=t;if(!e.config||typeof e.config!="object")throw new Error('Invalid snapshot: missing or invalid "config"');if(!e.state||typeof e.state!="object")throw new Error('Invalid snapshot: missing or invalid "state"');let r=e.config,n=e.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 nc(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Jh(t,e){let r=new Date().toISOString();switch(e){case "stop":return {...t,status:"stopped",lastUpdated:r};case "pause":return {...t,status:"paused",lastUpdated:r};case "resume":return {...t,status:"running",lastUpdated:r};default:return t}}function Ir(t){let{config:e,state:r}=t,n=Ju(e);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let o=Hh(n),a=Wu(e,r.tasks),i=new Set([...a,...r.availableOutputs]),u=[],c=[],d=[],l=[];for(let[y,m]of Object.entries(n)){let p=r.tasks[y],k=Hu(m,e.settings),h=k!=="once";if(p?.status===ut.RUNNING||No(p))continue;let f=zu(m);if(f!==void 0&&p&&p.executionCount>=f||m.circuit_breaker&&p&&p.executionCount>=m.circuit_breaker.max_executions||!h&&p?.status===ut.COMPLETED)continue;if(h&&p?.status===ut.COMPLETED){let _=ct(m),$=false;switch(k){case "data-changed":{_.length>0&&_.some(q=>{for(let[F,re]of Object.entries(n))if(xe(re).includes(q)){let U=r.tasks[F];if(!U)continue;let de=p.lastConsumedHashes?.[q];return U.lastDataHash==null?U.executionCount>p.lastEpoch:U.lastDataHash!==de}return false})||($=true);break}case "epoch-changed":{_.length>0&&_.some(q=>{for(let[F,re]of Object.entries(n))if(xe(re).includes(q)){let U=r.tasks[F];if(U&&U.executionCount>p.lastEpoch)return true}return false})||($=true);break}case "time-based":{let N=m.refreshInterval??0;if(N<=0){$=true;break}let q=p.completedAt;if(!q){$=true;break}(Date.now()-Date.parse(q))/1e3<N&&($=true);break}case "manual":$=true;break}if($)continue}let g=ct(m);if(g.length===0){u.push(y);continue}let S=[],w=[],C=[];for(let _ of g){if(i.has(_))continue;let $=o[_]||[];$.length===0?S.push(_):$.every(q=>No(r.tasks[q]))?C.push({token:_,failedProducer:$[0]}):w.push(_);}S.length>0?d.push({taskName:y,missingTokens:S}):C.length>0?l.push({taskName:y,failedTokens:C.map(_=>_.token),failedProducers:[...new Set(C.map(_=>_.failedProducer))]}):w.length>0?c.push({taskName:y,waitingOn:w}):u.push(y);}let b={};if(u.length>1){let y=Yu(u,n);for(let[m,p]of Object.entries(y))p.length>1&&(b[m]=p);}return {eligible:u,pending:c,unresolved:d,blocked:l,conflicts:b}}function Hh(t){let e={};for(let[r,n]of Object.entries(t)){for(let s of xe(n))e[s]||(e[s]=[]),e[s].push(r);if(n.on)for(let s of Object.values(n.on))for(let o of s)e[o]||(e[o]=[]),e[o].includes(r)||e[o].push(r);if(n.on_failure)for(let s of n.on_failure)e[s]||(e[s]=[]),e[s].includes(r)||e[s].push(r);}return e}var Pr=class{buffer=[];append(e){this.buffer.push(e);}drain(){let e=this.buffer;return this.buffer=[],e}get size(){return this.buffer.length}};function qo(t){let e=Do(t);return zh(e)}function Do(t){if(t==null||typeof t!="object")return JSON.stringify(t);if(Array.isArray(t))return "["+t.map(Do).join(",")+"]";let e=t;return "{"+Object.keys(e).sort().map(n=>JSON.stringify(n)+":"+Do(e[n])).join(",")+"}"}function zh(t){let e=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let s=0;s<t.length;s++)e^=BigInt(t.charCodeAt(s)),e=e*r&n;return e.toString(16).padStart(16,"0")}function Wh(t){if(typeof Buffer<"u")return Buffer.from(t,"utf8").toString("base64url");if(typeof btoa=="function"){let e=new TextEncoder().encode(t),r="";for(let n of e)r+=String.fromCharCode(n);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}throw new Error("No base64 encoder available in this runtime")}function Yh(t){if(typeof Buffer<"u")return Buffer.from(t,"base64url").toString("utf8");if(typeof atob=="function"){let e=t.replace(/-/g,"+").replace(/_/g,"/"),r=e+"=".repeat((4-e.length%4)%4),n=atob(r),s=new Uint8Array(n.length);for(let o=0;o<n.length;o++)s[o]=n.charCodeAt(o);return new TextDecoder().decode(s)}throw new Error("No base64 decoder available in this runtime")}function sc(t){let e=JSON.stringify({t,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return Wh(e)}function Xh(t){try{let e=JSON.parse(Yh(t));return typeof e?.t=="string"?{taskName:e.t}:null}catch{return null}}function oc(t,e,r){let{handlers:n,onDrain:s}=e,o=new Pr,a="state"in t&&"config"in t?t:xn(t),i=false,u=new Set,c=new Map(Object.entries(n)),d=new Pr,l=false,b=false;function y(){if(!i){if(l){b=true;return}l=true;try{do b=!1,m();while(b)}finally{l=false;}}}function m(){let f=d.drain(),g=o.drain(),S=[...f,...g];S.length>0&&(a=rc(a,S));let w=Ir(a);S.length>0&&s?.(S,a,w);for(let C of w.eligible)h(C);for(let C of S)if(C.type==="task-progress"){let{taskName:_,update:$}=C;if(!a.config.tasks[_])continue;let q=a.state.tasks[_];if(!q||q.status!=="running")continue;let F=sc(_),re=k(_,F,$).catch(U=>{i||(d.append({type:"task-failed",taskName:_,error:U.message??String(U),timestamp:new Date().toISOString()}),y());}).finally(()=>{u.delete(re);});u.add(re);}}function p(f){let S=a.config.tasks[f].requires??[],w=new Map;for(let[_,$]of Object.entries(a.config.tasks))for(let N of $.provides??[])w.set(N,_);let C={};for(let _ of S){let $=w.get(_);$?C[_]=a.state.tasks[$]?.data:C[_]=void 0;}return C}async function k(f,g,S){let w=a.config.tasks[f],C=w.taskHandlers??[],_=p(f);for(let $ of C){let N=c.get($);if(!N)throw new Error(`Handler '${$}' not found in registry (task '${f}')`);let q={nodeId:f,state:_,taskState:a.state.tasks[f],config:w,callbackToken:g,update:S};if(await N(q)==="task-initiate-failure")throw new Error(`Handler '${$}' returned task-initiate-failure (task '${f}')`)}}function h(f){let S=a.config.tasks[f]?.taskHandlers;if(!S||S.length===0)return;d.append({type:"task-started",taskName:f,timestamp:new Date().toISOString()}),y();let w=sc(f),C=k(f,w).catch(_=>{i||(d.append({type:"task-failed",taskName:f,error:_.message??String(_),timestamp:new Date().toISOString()}),y());}).finally(()=>{u.delete(C);});u.add(C);}return {push(f){i||(f.type==="task-completed"&&f.data&&!f.dataHash&&(f={...f,dataHash:qo(f.data)}),o.append(f),y());},pushAll(f){if(!i){for(let g of f)g.type==="task-completed"&&g.data&&!g.dataHash?o.append({...g,dataHash:qo(g.data)}):o.append(g);y();}},resolveCallback(f,g,S){if(i)return;let w=Xh(f);if(!w)return;let{taskName:C}=w;if(a.config.tasks[C]){if(S&&S.length>0)o.append({type:"task-failed",taskName:C,error:S.join("; "),timestamp:new Date().toISOString()});else {let _=g&&Object.keys(g).length>0?qo(g):void 0;o.append({type:"task-completed",taskName:C,data:g,dataHash:_,timestamp:new Date().toISOString()});}y();}},addNode(f,g){i||(o.append({type:"task-upsert",taskName:f,taskConfig:g,timestamp:new Date().toISOString()}),y());},removeNode(f){i||(o.append({type:"task-removal",taskName:f,timestamp:new Date().toISOString()}),y());},addRequires(f,g){i||(o.append({type:"node-requires-add",nodeName:f,tokens:g,timestamp:new Date().toISOString()}),y());},removeRequires(f,g){i||(o.append({type:"node-requires-remove",nodeName:f,tokens:g,timestamp:new Date().toISOString()}),y());},addProvides(f,g){i||(o.append({type:"node-provides-add",nodeName:f,tokens:g,timestamp:new Date().toISOString()}),y());},removeProvides(f,g){i||(o.append({type:"node-provides-remove",nodeName:f,tokens:g,timestamp:new Date().toISOString()}),y());},registerHandler(f,g){c.set(f,g);},unregisterHandler(f){c.delete(f);},retrigger(f){i||a.config.tasks[f]&&(o.append({type:"task-restart",taskName:f,timestamp:new Date().toISOString()}),y());},retriggerAll(f){if(!i){for(let g of f)a.config.tasks[g]&&o.append({type:"task-restart",taskName:g,timestamp:new Date().toISOString()});y();}},snapshot(){return Ar(a)},getState(){return a},getSchedule(){return Ir(a)},async waitForHandlers(){u.size>0&&await Promise.allSettled([...u]);},async dispose(f){f?.wait&&u.size>0&&await Promise.allSettled([...u]),i=true;}}}var Zh=createRequire(import.meta.url),Tn=Zh("./jsonata-sync.cjs"),uc=Tn;function ac(t,e){if(!e||!t)return;let r=e.split("."),n=t;for(let s=0;s<r.length;s++){if(n==null)return;n=n[r[s]];}return n}function cc(t,e,r){let n=e.split("."),s=t;for(let o=0;o<n.length-1;o++)(s[n[o]]==null||typeof s[n[o]]!="object")&&(s[n[o]]={}),s=s[n[o]];s[n[n.length-1]]=r;}async function eg(t,e){if(!t?.compute?.length)return t;t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=e?.sourcesData??{};let r=t.requires??{},n={card_data:t.card_data,requires:r,expects_data:r,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values};for(let s of t.compute)try{let o=await Tn(s.expr).evaluate(n);cc(t.computed_values,s.bindTo,o),n.computed_values=t.computed_values;}catch{}return t}function tg(t,e){if(!t?.compute?.length)return {ok:true,node:t};t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=e?.sourcesData??{};let r=t.requires??{},n={card_data:t.card_data,requires:r,expects_data:r,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values},s=[];for(let o of t.compute)try{let a=uc(o.expr).evaluate(n);cc(t.computed_values,o.bindTo,a),n.computed_values=t.computed_values;}catch(a){let i=a instanceof Error?a.message:String(a);s.push({bindTo:o.bindTo,error:i});}return s.length>0?{ok:true,node:t,errors:s}:{ok:true,node:t}}async function rg(t,e,r){let n={...r??{},card_data:e.card_data??{},requires:e.requires??{},fetched_sources:e._sourcesData??{},computed_values:e.computed_values??{}};return Tn(t).evaluate(n)}function ng(t,e){return e.startsWith("fetched_sources.")?ac(t._sourcesData??{},e.slice(16)):ac(t,e)}var ic=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),sg=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function og(t){let e=[];if(!t||typeof t!="object"||Array.isArray(t))return {ok:false,errors:["Node must be a non-null object"]};let r=t;(typeof r.id!="string"||!r.id)&&e.push("id: required, must be a non-empty string");for(let n of Object.keys(r))sg.has(n)||e.push(`Unknown top-level key: "${n}"`);if((r.card_data==null||typeof r.card_data!="object"||Array.isArray(r.card_data))&&e.push("card_data: required, must be an object"),r.meta!=null)if(typeof r.meta!="object"||Array.isArray(r.meta))e.push("meta: must be an object");else {let n=r.meta;n.title!=null&&typeof n.title!="string"&&e.push("meta.title: must be a string"),n.tags!=null&&!Array.isArray(n.tags)&&e.push("meta.tags: must be an array");}if(r.requires!=null&&!Array.isArray(r.requires)&&e.push("requires: must be an array of strings"),r.provides!=null&&(Array.isArray(r.provides)?r.provides.forEach((n,s)=>{if(!n||typeof n!="object"||Array.isArray(n))e.push(`provides[${s}]: must be an object with bindTo and ref`);else {let o=n;(typeof o.bindTo!="string"||!o.bindTo)&&e.push(`provides[${s}]: missing required "bindTo" string`),(typeof o.ref!="string"||!o.ref)&&e.push(`provides[${s}]: missing required "ref" string`);}}):e.push("provides: must be an array of { bindTo, ref } bindings")),r.compute!=null&&(Array.isArray(r.compute)?r.compute.forEach((n,s)=>{if(!n||typeof n!="object"||Array.isArray(n))e.push(`compute[${s}]: must be a compute step object`);else {let o=n;(typeof o.bindTo!="string"||!o.bindTo)&&e.push(`compute[${s}]: missing required "bindTo" property`),(typeof o.expr!="string"||!o.expr)&&e.push(`compute[${s}]: missing required "expr" string (JSONata expression)`);}}):e.push("compute: must be an array of compute steps")),r.source_defs!=null)if(!Array.isArray(r.source_defs))e.push("source_defs: must be an array");else {let n=new Set,s=new Set;r.source_defs.forEach((o,a)=>{if(!o||typeof o!="object"||Array.isArray(o))e.push(`source_defs[${a}]: must be an object`);else {let i=o;typeof i.bindTo!="string"||!i.bindTo?e.push(`source_defs[${a}]: missing required "bindTo" property`):(n.has(i.bindTo)&&e.push(`source_defs[${a}]: bindTo "${i.bindTo}" is not unique across source_defs`),n.add(i.bindTo)),typeof i.outputFile!="string"||!i.outputFile?e.push(`source_defs[${a}]: missing required "outputFile" property`):(s.has(i.outputFile)&&e.push(`source_defs[${a}]: outputFile "${i.outputFile}" is not unique across source_defs`),s.add(i.outputFile)),i.optionalForCompletionGating!=null&&typeof i.optionalForCompletionGating!="boolean"&&e.push(`source_defs[${a}]: optionalForCompletionGating must be a boolean`);}});}if(r.view!=null)if(typeof r.view!="object"||Array.isArray(r.view))e.push("view: must be an object");else {let n=r.view;!Array.isArray(n.elements)||n.elements.length===0?e.push("view.elements: required, must be a non-empty array"):n.elements.forEach((s,o)=>{if(!s||typeof s!="object"){e.push(`view.elements[${o}]: must be an object`);return}!s.kind||typeof s.kind!="string"?e.push(`view.elements[${o}].kind: required, must be a string`):ic.has(s.kind)||e.push(`view.elements[${o}].kind: unknown kind "${s.kind}". Valid: ${[...ic].join(", ")}`),s.data!=null&&(typeof s.data!="object"||Array.isArray(s.data))&&e.push(`view.elements[${o}].data: must be an object`);}),n.layout!=null&&(typeof n.layout!="object"||Array.isArray(n.layout))&&e.push("view.layout: must be an object"),n.features!=null&&(typeof n.features!="object"||Array.isArray(n.features))&&e.push("view.features: must be an object");}return {ok:e.length===0,errors:e}}async function ag(t,e){if(!t||t.length===0)return [];let r={card_data:e.card_data??{},requires:e.requires??{}};return Promise.all(t.map(async n=>{let s={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[o,a]of Object.entries(n.projections))if(typeof a=="string"&&a.trim().length>0)try{s[o]=await Tn(a).evaluate(r);}catch{s[o]=void 0;}}return {...n,_projections:s}}))}function ig(t,e){if(!t||t.length===0)return [];let r={card_data:e.card_data??{},requires:e.requires??{}};return t.map(n=>{let s={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[o,a]of Object.entries(n.projections))if(typeof a=="string"&&a.trim().length>0)try{s[o]=uc(a).evaluate(r);}catch{s[o]=void 0;}}return {...n,_projections:s}})}var dt={run:eg,runSync:tg,eval:rg,resolve:ng,validate:og,enrichSources:ag,enrichSourcesSync:ig};function An(t){return JSON.stringify(t)}function In(t){let e;try{e=JSON.parse(t);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${t}`)}if(typeof e!="object"||e===null||typeof e.howToRun!="string"||typeof e.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${t}`);return e}function Pn(t,e){function r(){return t.readIndex()??{}}function n(s,o,a){let i=String(o||"").split(".").filter(Boolean);if(i.length===0)return a&&typeof a=="object"&&!Array.isArray(a)?a:{value:a};let u={...s},c=u;for(let d=0;d<i.length-1;d++){let l=i[d],b=c[l],y=b&&typeof b=="object"&&!Array.isArray(b)?{...b}:{};c[l]=y,c=y;}return c[i[i.length-1]]=a,u}return {readCard(s){let o=r()[s];return !o||!t.cardExists(o.key)?null:t.readCard(o.key)},readCardKey(s){return r()[s]?.key??null},readAllCards(){let s=[];for(let[o,a]of Object.entries(r())){if(!t.cardExists(a.key))continue;let i=t.readCard(a.key);i?s.push(i):e?.(`[card-store] could not read card "${o}" at key "${a.key}"`);}return s},readChecksumIndex(){let s={};for(let[o,a]of Object.entries(r()))s[o]=a.checksum;return s},changedSince(s){let o=r(),a=[];for(let[i,u]of Object.entries(o))s[i]!==u.checksum&&a.push(i);for(let i of Object.keys(s))o[i]||a.push(i);return a},validateUpsert(s,o){let a=r(),i=a[s],u=Object.entries(a).find(([,c])=>c.key===o);return i&&i.key!==o?{ok:false,error:`Card id "${s}" is already mapped to key "${i.key}", cannot remap to "${o}"`}:u&&u[0]!==s?{ok:false,error:`Key "${o}" is already mapped to card id "${u[0]}", cannot remap to "${s}"`}:{ok:true}},writeCard(s,o,a){let i=r(),u=a??i[s]?.key??t.defaultCardKey(s),c=t.writeCard(u,o);i[s]={key:u,checksum:c,updatedAt:new Date().toISOString()},t.writeIndex(i);},patchCard(s,o,a){let i=r(),u=i[s];if(!u||!t.cardExists(u.key))throw new Error(`card "${s}" not found`);let c=t.readCard(u.key);if(!c||typeof c!="object"||Array.isArray(c))throw new Error(`card "${s}" is not patchable`);let d=n(c,o,a),l=t.writeCard(u.key,d);i[s]={key:u.key,checksum:l,updatedAt:new Date().toISOString()},t.writeIndex(i);},removeCard(s){let o=r();o[s]&&(delete o[s],t.writeIndex(o));},readIndex(){return r()}}}function Fo(t,e){return {readSourceData(r,n){let s=t.read(`${r}/${n}`);if(s==null)return null;let o=s.trim();if(!o)return null;try{return JSON.parse(o)}catch{return o}},ingestSourceDataStaged(r,n,s,o){let a=e(s);t.write(`${r}/.staged/${o}/${n}`,a);},commitSourceData(r,n,s){let o=`${r}/.staged/${s}/${n}`,a=t.read(o);return a==null?false:(t.write(`${r}/${n}`,a),t.remove(o),true)},hasSource(r,n){return t.exists(`${r}/${n}`)}}}function fc(t){function e(r){let n=t.readAllEntries();if(!r)return n;let s=n.findIndex(o=>o.id===r);return s===-1?n:n.slice(s+1)}return {readEntriesAfterCursor(r){let n=e(r);return n.length===0?{events:[],newCursor:r}:{events:n.map(s=>s.event),newCursor:n[n.length-1].id}},pendingCount(r){return e(r).length},appendEvent(r){t.appendEntry({id:t.generateId(),event:r});}}}function pc(t,e){return {appendEntries(r,n){if(!r||n.length===0)return;let s=t.read(r)??[];t.write(r,[...s,...n]);},dispatchEntriesForJournalId(r,n){if(!r)return;let s=t.read(r);if(!(!s||s.length===0)){for(let o of s)try{n(o);}catch(a){let i=a instanceof Error?a.message:String(a);try{e(o,i);}catch{}}t.delete(r);}}}}var Or="v1",lt="board/graph",mc="board/lastJournalProcessedId";function dc(t){return `cards/${t}/runtime`}function hc(t){return {readRuntime(e){return t.read(dc(e))??{_sources:{}}},writeRuntime(e,r){t.write(dc(e),r);}}}function ug(t,e){let r={...t};for(let n of e.deleteKeys)delete r[n];return {...r,...e.shallowMerge}}function gc(t){return {readSnapshot(e){return t.readValues(e)},commitSnapshot(e,r){if(r.schemaVersion!==Or)throw new Error(`Unsupported snapshot schema version: ${r.schemaVersion}`);let n=t.readValues(e);if(n.version!==r.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let s=ug(n.values,r);return {ok:true,newVersion:t.writeValues(e,s,r.deleteKeys)}}}}function Mo(t){function e(r){let n=t.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {readTaskExecutorRef(){let r=e("task-executor");if(r?.trim())return In(r.trim())},writeTaskExecutorRef(r){t.write("task-executor",An(r));},readChatHandlerRef(){let r=e("chat-handler");if(r?.trim())return In(r.trim())},writeChatHandlerRef(r){t.write("chat-handler",An(r));},readCardStoreRef(){return e("card-store-ref")},writeCardStoreRef(r){t.write("card-store-ref",r);},readOutputsStoreRef(){return e("outputs-store-ref")},writeOutputsStoreRef(r){t.write("outputs-store-ref",r);},readChatHandler(){return e("chat-handler")?.trim()||void 0},writeChatHandler(r){t.write("chat-handler",r);}}}function yc(t){return {writeComputedValues(e,r){t.write(`cards/${e}/computed_values`,r);},readComputedValues(e){return t.read(`cards/${e}/computed_values`)},readAllComputedValues(){let e={};for(let r of t.listKeys("cards/")){let n=r.match(/^cards\/([^/]+)\/computed_values$/);n&&(e[n[1]]=t.read(r));}return e},writeDataObjects(e){for(let[r,n]of Object.entries(e))r&&t.write(`data-objects/${r}`,n);},readDataObject(e){return t.read(`data-objects/${e}`)},readAllDataObjects(){let e={};for(let r of t.listKeys("data-objects/"))e[r.slice(13)]=t.read(r);return e},writeStatusSnapshot(e){t.write("status",e);},readStatusSnapshot(){return t.read("status")}}}function cg(t){return t?.lastRequestedAt?!t.lastFetchedAt||t.lastFetchedAt<t.lastRequestedAt:false}function dg(t,e){return t?.lastRequestedAt?cg(t)?"in-flight":!t.lastFetchedAt||t.lastFetchedAt<e?"dispatch":"idle":"dispatch"}function lg(t,e){let r={...t,lastFetchedAt:e};return delete r.lastError,r}function lc(t,e){let r={...t,lastError:e};return delete r.lastFetchedAt,r}function On(t,e){let r=e.state.tasks,n=e.config.tasks,s=Object.keys(r),o=Ir(e),a={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},i=new Map;for(let m of o.pending)i.set(m.taskName,m.waitingOn);for(let m of o.unresolved)i.set(m.taskName,m.missingTokens);for(let m of o.blocked)i.set(m.taskName,m.failedTokens);let u=new Map;for(let[m,p]of Object.entries(n))for(let k of p.requires??[]){let h=u.get(k)??[];h.push(m),u.set(k,h);}let c=s.sort().map(m=>{let p=r[m],k=n[m]??{requires:[],provides:[]};p.status==="completed"?a.completed+=1:p.status==="failed"?a.failed+=1:p.status==="in-progress"&&(a.in_progress+=1);let h=k.requires??[],f=k.provides??[],g=Object.keys(p.data??{}).sort(),S=h.filter(q=>e.state.availableOutputs.includes(q)),w=h.filter(q=>!e.state.availableOutputs.includes(q)),C=i.get(m)??w,_=new Set;for(let q of f)for(let F of u.get(q)??[])F!==m&&_.add(F);let $=p.failedAt,N=p.error?{message:p.error,code:"TASK_FAILED",at:$,source:"task-runtime"}:void 0;return {name:m,status:p.status,error:N,requires:h,requires_satisfied:S,requires_missing:w,provides_declared:f,provides_runtime:g,blocked_by:C,unblocks:Array.from(_).sort(),runtime:{attempt_count:p.executionCount??0,restart_count:p.retryCount??0,in_progress_since:p.status==="in-progress"?p.startedAt??null:null,last_transition_at:p.lastUpdated??null,last_completed_at:p.completedAt??null,last_restarted_at:p.startedAt??null,status_age_ms:p.lastUpdated?0:null}}});a.pending=o.pending.length,a.blocked=o.blocked.length,a.unresolved=o.unresolved.length;let d=c.map(m=>({name:m.name,fanOut:m.unblocks.length})).sort((m,p)=>p.fanOut-m.fanOut||m.name.localeCompare(p.name)),l=d.length>0?d[0]:{name:null,fanOut:0},b=new Set;for(let m of Object.values(n))for(let p of m.requires??[])b.add(p);let y=0;for(let[m,p]of Object.entries(n)){let k=(p.requires??[]).length===0,f=(p.provides??[]).some(g=>(u.get(g)??[]).some(S=>S!==m));k&&!f&&(y+=1);}return {schema_version:"v1",meta:{board:{path:t}},summary:{card_count:s.length,completed:a.completed,eligible:o.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(b).length,max_fan_out_card:l.name,max_fan_out:l.fanOut}},cards:c}}function fg(){return new Date().toISOString()}function vc(t,e,r,n,s,o,a){return async i=>{let u=[],c=r.cardStore.readCard(i.nodeId);if(!c)return "task-initiate-failure";let d=c.id,l=c.card_data??{},b=c.source_defs??[],y=b.filter(M=>M.optionalForCompletionGating!==true),m=r.cardRuntimeStore.readRuntime(d),p=false,k=()=>{p&&(r.cardRuntimeStore.writeRuntime(d,m),p=false);},h=M=>({...m._sources[M]??{}}),f=(M,V)=>{m._sources[M]=V,p=true;},g=i.taskState?.executionCount??0,S=m._lastExecutionCount;if(typeof S=="number"&&S!==g&&(m._sources={},p=true),S!==g&&(m._lastExecutionCount=g,p=true),i.update){let M=i.update,V=M.outputFile;if(V){let R=h(V);if(M.failure)f(V,lc(R,M.reason??"unknown"));else {let v=M.rqt;if(!R.lastFetchedAt||v>R.lastFetchedAt){let x=typeof M.deliveryToken=="string"?M.deliveryToken:void 0,A=false;x&&(A=r.fetchedSourcesStore.commitSourceData(d,V,x)),A?f(V,lg(R,v)):f(V,lc(R,`source delivery commit failed for ${V} token=${String(x)}`));}}k();}}let w={};for(let M of b)if(M.outputFile){let V=r.fetchedSourcesStore.readSourceData(d,M.outputFile);V!==null&&(w[M.bindTo]=V);}let C={};for(let[M,V]of Object.entries(i.state??{}))if(V!==null&&typeof V=="object"&&!Array.isArray(V)){let R=V[M];C[M]=R!==void 0?R:V;}else C[M]=V;let _={id:d,card_data:{...l},requires:C,source_defs:b,compute:c.compute};_._sourcesData=w,c.compute&&dt.runSync(_,{sourcesData:w}),(o??r.outputStore.writeComputedValues.bind(r.outputStore))(d,_.computed_values??{});let $={...c},N=dt.enrichSourcesSync(Array.isArray(c.source_defs)?c.source_defs:void 0,{card_data:c.card_data,requires:C}),q=t.value;$.source_defs=Array.isArray(N)?N.map(M=>({...M,boardDir:typeof M.boardDir=="string"&&M.boardDir?M.boardDir:q})):N;let F=fg(),re=i.update?void 0:F,U=y.filter(M=>{let V=M.outputFile;if(typeof V!="string"||!V)return true;let R=h(V);re&&(R={...R,queueRequestedAt:re},f(V,R));let v=R.queueRequestedAt??R.lastRequestedAt??F,x=dg(R,v);return x==="in-flight"?false:x==="dispatch"});if(k(),U.length>0){let M=false,V=F;for(let R of U){let v=R.outputFile;if(typeof v!="string"||!v)continue;let x=h(v),A=x.queueRequestedAt??F;f(v,{...x,lastRequestedAt:A}),V=A,M=true;}return M&&k(),M&&(u.push({taskKind:"source-fetch",payload:{boardRef:ie(t),enrichedCard:$,callbackToken:i.callbackToken,rqt:V}}),r.executionRequestStore.appendEntries(e,u)),"task-initiated"}let de=c.provides??[],Fe={};for(let{bindTo:M,ref:V}of de)Fe[M]=dt.resolve(_,V);return (a??r.outputStore.writeDataObjects.bind(r.outputStore))(Fe),b.filter(M=>{if(M.optionalForCompletionGating!==true)return false;let V=h(M.outputFile);return !V.lastRequestedAt||!V.lastFetchedAt?true:V.lastFetchedAt<=V.lastRequestedAt}).length>0&&u.push({taskKind:"source-fetch",payload:{boardRef:ie(t),enrichedCard:$,callbackToken:i.callbackToken,rqt:F}}),n(i.nodeId,Fe),u.length>0&&r.executionRequestStore.appendEntries(e,u),"task-initiated"}}var jn={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function bc(t){return {[lt]:t.graph,[mc]:t.lastDrainedJournalId}}function kc(t){let e=t[lt],r=t[mc];if(!e||typeof e!="object")throw new Error(`State snapshot is missing required key: ${lt}`);return {graph:e,lastDrainedJournalId:typeof r=="string"?r:""}}function wc(t){let e=t.requires,r=t.provides?.map(n=>n.bindTo)??[];return {requires:e&&e.length>0?e:void 0,provides:r,taskHandlers:["card-handler"],description:t.meta?.title??t.id}}function Q(t){return t!==void 0?{status:"success",data:t}:{status:"success"}}function j(t){return {status:"fail",error:t}}function ee(t){return {status:"error",error:t instanceof Error?t.message:String(t)}}function pg(t){let e=new TextEncoder().encode(t),r=Array.from(e,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function _c(t){let e=t.replace(/-/g,"+").replace(/_/g,"/"),r=e+"=".repeat((4-e.length%4)%4),n=atob(r),s=Uint8Array.from(n,o=>o.charCodeAt(0));return new TextDecoder().decode(s)}function Nn(t){try{let e=JSON.parse(_c(t));return typeof e?.t=="string"?{taskName:e.t}:null}catch{return null}}function mg(t){return pg(JSON.stringify(t))}function Sc(t){try{let e=JSON.parse(_c(t));return typeof e?.cbk=="string"&&typeof e?.cid=="string"&&typeof e?.b=="string"&&typeof e?.d=="string"?e:null}catch{return null}}function Ee(){return new Date().toISOString()}function jr(t,e){let r=e.onWarn??(()=>{}),n=ie(t);function s(R){if(R.length!==0)try{let v=e.publishBoardChangeNotifications?.(R);v&&typeof v.catch=="function"&&v.catch(x=>r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${x instanceof Error?x.message:String(x)}`));}catch(v){r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${v instanceof Error?v.message:String(v)}`);}}function o(){let R=i().readCardStoreRef();if(!R)throw new Error(`Board at ${t.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let v=e.kvStorageForRef(R);return {readIndex(){return v.read("_index")},writeIndex(x){v.write("_index",x);},readCard(x){return v.read(x)},writeCard(x,A){return v.write(x,A),e.hashFn(A)},cardExists(x){return v.read(x)!==null},defaultCardKey(x){return x}}}let a={readValues(R){let v=e.kvStorage("state-snapshot"),x=v.listKeys().sort();if(x.length===0)return {version:null,values:{}};let A={};for(let Y of x)A[Y]=v.read(Y);return {version:e.hashFn(A),values:A}},writeValues(R,v,x){let A=e.kvStorage("state-snapshot");for(let Y of x)A.delete(Y);for(let[Y,te]of Object.entries(v))A.write(Y,te);return e.hashFn(v)}},i=()=>Mo(e.kvStorage("config")),u=()=>gc(a),c=()=>fc(e.journalAdapter()),d=()=>Pn(o(),r),l=()=>{let R=i().readOutputsStoreRef();if(!R)throw new Error(`Board at ${t.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return yc(e.kvStorageForRef(R))};function b(){return !!u().readSnapshot(t.value).values[lt]}function y(){let R=u().readSnapshot(t.value);if(!R.values[lt])throw new Error(`Board not initialized at ${t.value}`);return kc(R.values)}function m(R,v){let x=u().commitSnapshot(t.value,{schemaVersion:Or,expectedVersion:v,commitId:e.genId(),committedAt:Ee(),deleteKeys:[],shallowMerge:bc(R)});if(!x.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${v??"null"} current=${x.currentVersion??"null"}`)}function p(R){c().appendEvent(R);}async function k(){let R=(I,D)=>{let ae=I.payload,Qe=(ae?.enrichedCard??{}).id??ae?.cardId??"unknown";p({type:"task-failed",taskName:Qe,error:D,timestamp:Ee()});},v=pc(e.kvStorage("execution-requests"),R),x=hc(e.kvStorage("card-runtime")),A=Fo(e.blobStorage("sources"),I=>e.resolveBlob(I)),Y=new Map,te={readRuntime(I){return Y.get(I)??x.readRuntime(I)},writeRuntime(I,D){Y.set(I,D);}},Ce=[],$e=new Map,Ke={readSourceData(I,D){let ae=`${I}/${D}`;return $e.has(ae)?$e.get(ae):A.readSourceData(I,D)},ingestSourceDataStaged(I,D,ae,Pt){A.ingestSourceDataStaged(I,D,ae,Pt);},commitSourceData(I,D,ae){let Pt=`${I}/.staged/${ae}/${D}`,Fr=e.blobStorage("sources").read(Pt);if(Fr==null)return false;let Ot=`${I}/${D}`,Ko=Fr.trim();try{$e.set(Ot,JSON.parse(Ko));}catch{$e.set(Ot,Ko);}return Ce.push({cardId:I,outputFile:D,deliveryToken:ae}),true},hasSource(I,D){let ae=`${I}/${D}`;return $e.has(ae)?true:A.hasSource(I,D)}},Me={cardStore:d(),cardRuntimeStore:te,fetchedSourcesStore:Ke,outputStore:l(),executionRequestStore:v},mt=y(),ht=En(mt.graph),{events:At,newCursor:It}=c().readEntriesAfterCursor(mt.lastDrainedJournalId),gt=[],qn=[],Dn=[],Vo=new Map,Cc=(I,D)=>{gt.push({type:"task-completed",taskName:I,data:D,timestamp:Ee()});},Bo=(I,D)=>p({type:"task-failed",taskName:I,error:D,timestamp:Ee()}),qr=oc(ht,{handlers:{"card-handler":vc(t,It,Me,Cc,Bo,(I,D)=>{qn.push({cardId:I,values:D});},I=>{Dn.push(I);})}});for(gt=At;gt.length>0;){let I=gt;gt=[];for(let D of I)if(D.type==="task-restart"){let ae=Me.cardStore.readCard(D.taskName);ae&&Vo.set(D.taskName,ae);}qr.pushAll(I),await qr.waitForHandlers();}let Go=qr.getState();await qr.dispose({wait:true});let $c=u().readSnapshot(t.value).version;m({lastDrainedJournalId:It,graph:Ar(Go)},$c);for(let{cardId:I,values:D}of qn)Me.outputStore.writeComputedValues(I,D);for(let I of Dn)Me.outputStore.writeDataObjects(I);for(let[I,D]of Y)x.writeRuntime(I,D);for(let{cardId:I,outputFile:D,deliveryToken:ae}of Ce)A.commitSourceData(I,D,ae);let Dr;try{Dr=On(n,Go),Me.outputStore.writeStatusSnapshot(Dr);}catch(I){r(`[board-live-cards-public] status publish failed: ${I instanceof Error?I.message:String(I)}`);}let Xt=[];for(let{cardId:I,values:D}of qn)Xt.push({kind:"computed_values",cardId:I,values:D});for(let I of Dn)for(let[D,ae]of Object.entries(I))D&&Xt.push({kind:"data_object",key:D,payload:ae});for(let[I,D]of Vo)Xt.push({kind:"card_refreshed",cardId:I,card:D});Dr!==void 0&&Xt.push({kind:"status",status:Dr}),s(Xt);let xc=i().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:ie({kind:"built-in",value:"source-cli-task-executor"})};v.dispatchEntriesForJournalId(It,I=>{if(I.taskKind!=="source-fetch"){r(`[process-accumulated-events] unknown taskKind "${I.taskKind}" \u2014 skipping`);return}let D=I.payload,ae=D.enrichedCard?.id??"unknown",Pt=D.enrichedCard?.source_defs??[];for(let Qe of Pt){if(!Qe.outputFile){r(`[dispatch] source "${Qe.bindTo}" has no outputFile \u2014 skipping`);continue}let Fr=mg({cbk:D.callbackToken,rg:t.value,br:ie(t),cid:ae,b:Qe.bindTo,d:Qe.outputFile,cs:void 0,rqt:D.rqt});e.dispatchExecution(xc,{source_def:Qe,base_ref:ie(t),callback:{token:Fr,via:e.selfRef}}).catch(Ot=>Bo(ae,Ot instanceof Error?Ot.message:String(Ot)));}});}async function h(){try{let R=()=>{let x=y(),{events:A}=c().readEntriesAfterCursor(x.lastDrainedJournalId);A.length<=0||(h(),e.requestProcessAccumulated?.());},v=await Jo(e.lock,k,R);return Q({ran:v!==!1})}catch(R){return ee(R)}}function f(R){try{let v=R.params?.cardStoreRef;if(!v)return j("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!b()){let te=xn(jn);m({lastDrainedJournalId:"",graph:Ar(te)},null);}let x=R.params?.outputsStoreRef;if(!x)return j("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let A=i();A.writeCardStoreRef(v),A.writeOutputsStoreRef(x);let Y=R.body??{};Y["task-executor-ref"]&&A.writeTaskExecutorRef(Y["task-executor-ref"]),Y["chat-handler-ref"]&&A.writeChatHandlerRef(Y["chat-handler-ref"]);try{l().writeStatusSnapshot(On(n,En(y().graph)));}catch{}return Q()}catch(v){return ee(v)}}function g(R){try{let v=l().readStatusSnapshot();if(!v){v=On(n,En(y().graph));try{l().writeStatusSnapshot(v);}catch{}}return Q(v)}catch(v){return ee(v)}}function S(R){try{let v=R.params?.id;return v?(p({type:"task-removal",taskName:v,timestamp:Ee()}),h(),Q()):j("removeCard requires params.id")}catch(v){return ee(v)}}function w(R){try{let v=R.params?.id;return v?(p({type:"task-restart",taskName:v,timestamp:Ee()}),h(),Q()):j("retrigger requires params.id")}catch(v){return ee(v)}}async function C(R){return h()}function _(R){try{let v=R.params?.cardId,x=R.params?.all,A=!!R.params?.restart;if(!v&&!x)return j("upsertCard requires --card-id <id> or --all");let Y=x?d().readAllCards().map(te=>te.id):[v];for(let te of Y)if(!d().readCard(te))return j(`Card "${te}" not found in board at ${t.value}`);for(let te of Y){let Ce=d().readCard(te),$e=wc(Ce),Ke=e.hashFn($e),Me=e.kvStorage("card-upsert"),mt=Me.read(te),ht=mt?.taskConfigHash!==Ke;if(!(!ht&&!A)){if(ht){let At=mt?.blobRef??d().readCardKey(te)??te;p({type:"task-upsert",taskName:te,taskConfig:$e,timestamp:Ee()}),Me.write(te,{blobRef:At,taskConfigHash:Ke,updatedAt:Ee()});}A&&p({type:"task-restart",taskName:te,timestamp:Ee()});}}return h(),Q()}catch(v){return ee(v)}}function $(R){try{let v=R.params?.token;if(!v)return j("taskFailed requires params.token");let x=R.params?.error??"unknown error",A=Nn(v);return A?(p({type:"task-failed",taskName:A.taskName,error:x,timestamp:Ee()}),h(),Q()):j("Invalid callback token")}catch(v){return ee(v)}}function N(R){try{let v=R.params?.token;if(!v)return j("taskProgress requires params.token");let A=(R.body??{}).update??{},Y=Nn(v);return Y?(p({type:"task-progress",taskName:Y.taskName,update:A,timestamp:Ee()}),h(),Q()):j("Invalid callback token")}catch(v){return ee(v)}}function q(R){try{let v=R.params?.token,x=R.params?.ref;if(!v)return j("sourceDataFetched requires params.token");if(!x)return j("sourceDataFetched requires params.ref");let A=Sc(v);if(!A)return j("Invalid source token");let{cbk:Y,cid:te,b:Ce,d:$e,cs:Ke,rqt:Me}=A,mt=Fo(e.blobStorage("sources"),gt=>e.resolveBlob(gt)),ht=e.genId();mt.ingestSourceDataStaged(te,$e,ke(x),ht);let At=Nn(Y);if(!At)return j("Invalid callback token embedded in source token");let It=Ee();return p({type:"task-progress",taskName:At.taskName,update:{bindTo:Ce,outputFile:$e,fetchedAt:It,deliveryToken:ht,sourceChecksum:Ke,rqt:Me},timestamp:It}),h(),Q()}catch(v){return ee(v)}}function F(R){try{let v=R.params?.token,x=R.params?.reason??"unknown";if(!v)return j("sourceDataFetchFailure requires params.token");let A=Sc(v);if(!A)return j("Invalid source token");let{cbk:Y,b:te,d:Ce,cs:$e}=A,Ke=Nn(Y);return Ke?(p({type:"task-progress",taskName:Ke.taskName,update:{bindTo:te,outputFile:Ce,failure:!0,reason:x,sourceChecksum:$e},timestamp:Ee()}),h(),Q()):j("Invalid callback token embedded in source token")}catch(v){return ee(v)}}function re(R){try{let v=i().readCardStoreRef();return v?Q({storeRef:v}):j(`Board at ${t.value} has no card store configured`)}catch(v){return ee(v)}}function U(R){try{let v=i().readOutputsStoreRef();return v?Q({storeRef:v}):j(`Board at ${t.value} has no outputs store configured`)}catch(v){return ee(v)}}function de(R){try{let v=R.params?.key;if(!v)return j("getConfig requires params.key");let x=i(),A;switch(v){case "task-executor":A=x.readTaskExecutorRef()??null;break;case "chat-handler":A=x.readChatHandlerRef()??null;break;case "card-store-ref":A=x.readCardStoreRef();break;case "outputs-store-ref":A=x.readOutputsStoreRef();break;default:return j(`getConfig: unknown key "${v}"`)}return Q({value:A})}catch(v){return ee(v)}}function Fe(R){try{let v=R.params?.key;if(!v)return j("getOutputsDataObject requires params.key");let x=l().readDataObject(v);return Q(x)}catch(v){return ee(v)}}function pt(R){try{return Q(l().readAllDataObjects())}catch(v){return ee(v)}}function M(R){try{let v=R.params?.key;if(!v)return j("getOutputsComputedValues requires params.key");let x=l().readComputedValues(v);return Q(x)}catch(v){return ee(v)}}function V(R){try{return Q(l().readAllComputedValues())}catch(v){return ee(v)}}return {init:f,status:g,getCardStoreRef:re,getOutputsStoreRef:U,getConfig:de,getOutputsDataObject:Fe,getAllOutputsDataObjects:pt,getOutputsComputedValues:M,getAllOutputsComputedValues:V,removeCard:S,retrigger:w,processAccumulatedEvents:C,upsertCard:_,taskFailed:$,taskProgress:N,sourceDataFetched:q,sourceDataFetchFailure:F}}function ft(t,e){let r=()=>Mo(e.kvStorage("config"));function n(){let h=r().readCardStoreRef();if(!h)throw new Error(`Board at ${t.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let f=e.kvStorageForRef(h);return {readIndex(){return f.read("_index")},writeIndex(g){f.write("_index",g);},readCard(g){return f.read(g)},writeCard(g,S){return f.write(g,S),e.hashFn(S)},cardExists(g){return f.read(g)!==null},defaultCardKey(g){return g}}}let s=()=>Pn(n(),e.onWarn??(()=>{}));function o(h,f){let g=e.validateSchema(f),S=[],w=r().readTaskExecutorRef();if(w&&Array.isArray(f.source_defs))for(let _ of f.source_defs){let $=typeof _.bindTo=="string"?_.bindTo:"(unknown)";try{let N;try{N=e.invokeExecutorSync(w,"validate-source-def",[],{timeout:e.executorTimeouts?.validationMs??1e4,input:JSON.stringify(_)});}catch(F){let re=F;if(N=typeof re?.stdout=="string"?re.stdout:"",!N.trim()){S.push(`source "${$}": executor validate-source-def failed \u2014 ${F instanceof Error?F.message:String(F)}`);continue}}let q=JSON.parse(N.trim());if(!q.ok&&Array.isArray(q.errors))for(let F of q.errors)S.push(`source "${$}": ${F}`);}catch(N){S.push(`source "${$}": executor validate-source-def failed \u2014 ${N instanceof Error?N.message:String(N)}`);}}let C=[...g.errors,...S];return Q({cardId:h,isValid:C.length===0,issues:C})}function a(h,f,g){let S=r().readTaskExecutorRef();if(!S)return j("No task-executor registered for this board");let w=typeof h.bindTo=="string"?h.bindTo:"source",C=e.makeTempFilePath(`probe-in-${w}`),_=e.makeTempFilePath(`probe-out-${w}`),$=e.makeTempFilePath(`probe-err-${w}`,".txt"),N={...h,boardDir:t.value,_projections:f},q=ie({kind:"fs-path",value:C}),F=ie({kind:"fs-path",value:_}),re=ie({kind:"fs-path",value:$});e.absoluteBlob.write(C,JSON.stringify(N,null,2));let U=null;try{if(e.invokeExecutorSync(S,"run-source-fetch",["--in-ref",q,"--out-ref",F,"--err-ref",re],{timeout:h.timeout??e.executorTimeouts?.probeMs??6e4}),U=e.absoluteBlob.read(_),U===null)return j("Executor produced no output file")}catch(de){let Fe=e.absoluteBlob.read($)?.trim()??(de instanceof Error?de.message:String(de));return j(`Probe failed: ${Fe}`)}finally{try{e.absoluteBlob.remove(C);}catch{}try{e.absoluteBlob.remove($);}catch{}}if(g){let de=ke(g);e.absoluteBlob.write(de.value,U);}else try{e.absoluteBlob.remove(_);}catch{}return Q({bindTo:w,resultSizeBytes:U.length})}function i(h){try{let f=h.params?.cardId,g=h.params?.all;if(!f&&!g)return j("validateCard requires --card-id <id> or --all");let S=g?s().readAllCards().map(C=>C.id):[f],w=[];for(let C of S){let _=s().readCard(C);if(!_){w.push({cardId:C,isValid:!1,issues:[`Card "${C}" not found`]});continue}let $=o(C,_);if($.status!=="success")return $;w.push($.data);}return Q(w)}catch(f){return ee(f)}}function u(h){try{if(!h.body||typeof h.body!="object"||Array.isArray(h.body))return j("validateCardPreflight requires card JSON object in body");let f=h.body,g=f["card-content"]??f,S=typeof g.id=="string"?g.id:"(unknown)",w=o(S,g),C=r().readTaskExecutorRef();if(C)try{let _=e.invokeExecutorSync(C,"validate-card-preflight",[],{timeout:e.executorTimeouts?.validationMs??1e4,input:JSON.stringify(g)}),$=JSON.parse(_.trim());if(!$.ok&&Array.isArray($.errors)&&$.errors.length>0){let N=[...w.status==="success"?w.data.issues:[],...$.errors];return Q({cardId:S,isValid:!1,issues:N})}}catch{}return w}catch(f){return ee(f)}}function c(h){try{let f=h.params?.cardId,g=h.params?.sourceIdx,S=h.params?.outRef;if(!f)return j("probeSource requires params.cardId");if(g===void 0)return j("probeSource requires params.sourceIdx");let C=(h.body??{})["mock-projections"]??{},_=s().readCard(f);if(!_)return j(`Card "${f}" not found`);let $=_.source_defs??[];return g<0||g>=$.length?j(`sourceIdx ${g} out of range (card has ${$.length} source(s))`):a($[g],C,S)}catch(f){return ee(f)}}function d(h){try{let f=h.params?.outRef,g=h.body;if(!g)return j('probeTmpSource requires body with "source-def" and "mock-projections"');let S=g["source-def"],w=g["mock-projections"]??{};return S?a(S,w,f):j('probeTmpSource body requires "source-def"')}catch(f){return ee(f)}}function l(h){try{let f=h.params?.sourceIdx,g=h.params?.outRef;if(f===void 0)return j("probeSourcePreflight requires params.sourceIdx");if(!h.body||typeof h.body!="object"||Array.isArray(h.body))return j("probeSourcePreflight requires card JSON object in body");let S=h.body,w=S["card-content"]??S,C=S["mock-projections"]??{},_=w.source_defs??[];if(f<0||f>=_.length)return j(`sourceIdx ${f} out of range (card has ${_.length} source(s))`);let $=_[f],N=r().readTaskExecutorRef();if(N){let q=typeof $.bindTo=="string"?$.bindTo:"source";try{let F={...$,_projections:C},re=e.invokeExecutorSync(N,"probe-source-preflight",[],{timeout:$.timeout??e.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(F)}),U=JSON.parse(re.trim());return U.ok?Q({bindTo:q,reachable:U.reachable,latencyMs:U.latencyMs,note:U.note}):j(U.error??"Preflight probe failed")}catch{}}return a($,C,g)}catch(f){return ee(f)}}function b(h){try{let f=r().readTaskExecutorRef();if(!f)return j("No task-executor registered for this board");let g=e.invokeExecutorSync(f,"describe-capabilities",[],{timeout:e.executorTimeouts?.describeMs??1e4});return Q(JSON.parse(g.trim()))}catch(f){return ee(f)}}function y(h){try{let f=h.body;if(!f||!Array.isArray(f.ops))return j("updatesInCardStore requires body.ops array");let g=f.ops,S=s();for(let w of g){let C=w.op,_=w.id;if(!_)return j('op is missing "id"');if(C==="update"){let $=w["card-content"];if(!$)return j(`update op for "${_}" is missing "card-content"`);S.writeCard(_,$);}else return j(`Unknown op type: "${C??"(none)"}"`)}return Q()}catch(f){return ee(f)}}function m(h){try{let f=h.body;if(!f||!Array.isArray(f.ids))return j("readFromCardStore requires body.ids array");let g=f.ids,S=s(),w=g.map(C=>({id:C,"card-content":S.readCard(C)}));return Q({cards:w})}catch(f){return ee(f)}}function p(h){try{if(!h.body||typeof h.body!="object"||Array.isArray(h.body))return j("evalCardCompute requires a JSON object in body");let f=h.body,g=f["card-content"]??f,S=typeof g.id=="string"?g.id:"(unknown)",w=f["mock-fetched-sources"]??{},C=f["mock-requires"]??{},_=g.compute;if(!_||!Array.isArray(_)||_.length===0)return Q({cardId:S,ok:!0,computed_values:{},errors:[]});let $={id:S,card_data:g.card_data??{},requires:C,source_defs:g.source_defs,compute:_},N=dt.runSync($,{sourcesData:w}),q=N.node.computed_values??{},F=N.errors??[];return Q({cardId:S,ok:F.length===0,computed_values:q,errors:F})}catch(f){return ee(f)}}function k(h){try{if(!h.body||typeof h.body!="object"||Array.isArray(h.body))return j("simulateCardCycle requires a JSON object in body");let f=h.body,g=f["card-content"]??f,S=typeof g.id=="string"?g.id:"(unknown)",w=f["mock-fetched-sources"]??{},C=f["mock-requires"]??{},_=o(S,g),$=_.status==="success"?{isValid:_.data.isValid,issues:_.data.issues}:{isValid:!1,issues:[_.status==="fail"?_.error:"internal error"]},N=g.source_defs??[],q=g.card_data??{},F=[],re=[];if(N.length>0){F=dt.enrichSourcesSync(N,{card_data:q,requires:C});for(let v of F){let x=v.projections,A=v._projections;if(x&&A){for(let Y of Object.keys(x))if(A[Y]===void 0){let te=typeof v.bindTo=="string"?v.bindTo:"(unknown)";re.push({bindTo:te,key:Y,error:`Projection "${Y}" resolved to undefined`});}}}}let U=[],de=f["task-executor-ref"],Fe=(de?.howToRun&&de?.whatToRun?de:void 0)??r().readTaskExecutorRef();for(let v=0;v<F.length;v++){let x=F[v],A=typeof x.bindTo=="string"?x.bindTo:`source_${v}`;if(!Fe){U.push({bindTo:A,skipped:!0,error:"No task executor configured"});continue}try{let Y={...x},te=e.invokeExecutorSync(Fe,"probe-source-preflight",[],{timeout:x.timeout??1e4,input:JSON.stringify(Y)}),Ce=JSON.parse(te.trim());U.push({bindTo:A,reachable:Ce.reachable,latencyMs:Ce.latencyMs,error:Ce.ok?void 0:Ce.error});}catch{U.push({bindTo:A,skipped:!0,error:"Executor does not support probe-source-preflight"});}}let pt=g.compute,M={},V=[];if(pt&&Array.isArray(pt)&&pt.length>0){let v={id:S,card_data:q,requires:C,source_defs:g.source_defs,compute:pt},x=dt.runSync(v,{sourcesData:w});M=x.node.computed_values??{},V=x.errors??[];}let R=$.isValid&&re.length===0&&V.length===0&&U.every(v=>v.reachable!==!1);return Q({cardId:S,ok:R,validation:$,source_probes:U,projection_errors:re,computed_values:M,compute_errors:V})}catch(f){return ee(f)}}return {validateCard:i,validateCardPreflight:u,probeSource:c,probeTmpSource:d,probeSourcePreflight:l,evalCardCompute:p,simulateCardCycle:k,describeTaskExecutorCapabilities:b,updatesInCardStore:y,readFromCardStore:m}}var hg=".board.lock";function gg(t,e){return typeof t=="string"?{cliDir:t,opts:e}:{cliDir:void 0,opts:t}}function yg(t,e){return typeof t=="string"?{cliDir:t,opts:e}:{cliDir:void 0,opts:t}}function Rc(t){if(t)return t;let e=Vr(import.meta.url),r=[e,jt(e,"..","cli","node"),jt(e,"..","..","cli","node")];for(let n of r)try{return Bn(n),n}catch{}throw new Error(`createFsBoardPlatformAdapter: could not resolve a public CLI directory from module dir ${e}`)}function Nr(t,e,r){let{cliDir:n,opts:s}=gg(e,r),o=Rc(n),a=t.value,i=s?.suppressSpawn?"":Bn(o),u={meta:"board-live-cards",howToRun:"local-node",whatToRun:i?ie({kind:"fs-path",value:i}):"",...s?.notifyChannel?{extra:{notifyChannel:s.notifyChannel}}:{}};return {kvStorage:c=>Hn(jt(a,`.${c}`)),blobStorage:c=>c?Gr(jt(a,c)):Gr(a),journalAdapter:()=>da(a),lock:la(jt(a,hg)),selfRef:u,async dispatchExecution(c,d){if(s?.suppressSpawn)return {dispatched:false};try{let l=d.source_def?.bindTo??Mn().slice(0,8),b=Qt(a,`exec-in-${l}`),y=Qt(a,`exec-out-${l}`),m=Qt(a,`exec-err-${l}`,".txt"),p=ie({kind:"fs-path",value:b}),k=ie({kind:"fs-path",value:y}),h=ie({kind:"fs-path",value:m});return ua({kind:"fs-path",value:b}).write(b,JSON.stringify(d,null,2)),ia(c,{subcommand:"run-source-fetch",inRef:p,outRef:k,errRef:h},o),{dispatched:!0}}catch(l){return {dispatched:false,error:l instanceof Error?l.message:String(l)}}},resolveBlob(c){let d=Yo(c.value)?Jn().read(c.value):Gr(a).read(c.value);if(d===null)throw new Error(`resolveBlob: blob not found: ::${c.kind}::${c.value}`);return d},hashFn:ca,genId:()=>Xo(`${Date.now()}-${Math.random()}`).slice(0,32),kvStorageForRef:c=>Hn(ke(c).value),requestProcessAccumulated(){s?.suppressSpawn||ea(o,t,s?.notifyChannel);},publishBoardChangeNotifications(c){if(!s?.notifyChannel||c.length===0)return;let d=c.map(l=>({id:Mn(),ts:new Date().toISOString(),boardRef:ie(t),notification:l}));ta(s.notifyChannel,d,s.onWarn);},onWarn:s?.onWarn}}function Et(t,e,r){let{cliDir:n,opts:s}=yg(e,r),o=Rc(n),a=Nr(t,o,s),i=Gn();return {...a,invokeExecutorSync(u,c,d,l){let{command:b,baseArgs:y}=aa(u,o),m=u.extra?["--extra",Buffer.from(JSON.stringify(u.extra)).toString("base64")]:[];return i.executeSync(b,[...y,c,...d,...m],{timeout:l?.timeout??3e4,encoding:"utf-8",input:l?.input})},validateSchema(u){let c=jo(u);return {ok:c.errors.length===0,errors:c.errors}},makeTempFilePath(u,c){return Qt(t.value,u,c)},absoluteBlob:Jn()}}function Lo(t){try{let e=JSON.parse(Buffer.from(t,"base64url").toString());return typeof e.br=="string"?e.br:null}catch{return null}}var Ye=Vr(import.meta.url);function ge(t,e,r){let n=t.indexOf(e),s=n!==-1?t[n+1]:void 0;if(!s)throw new Error(`Missing ${e}
13
+ `,"utf-8");},generateId(){return randomUUID()}}}function la(t){return {tryAcquire(){try{if(!P.existsSync(t)){P.mkdirSync(ce.dirname(t),{recursive:!0});try{P.writeFileSync(t,"{}",{flag:"wx"});}catch{}}return lockSync(t,{retries:0})}catch{return null}}}}var fa={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://nsreehari.github.io/boards/live-cards.schema.json",definitions:{bind_ref:{description:"A card data path reference, e.g. 'card_data.raw_quotes' or 'requires.upstream'",type:"string",pattern:"^(card_data|requires|fetched_sources|computed_values)(\\.|$)"},bind_or_literal:{description:"A literal value or a bind reference object",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref"}},required:["bind"]}]},compute_expr:{description:"A declarative JSON compute expression",type:"object",required:["fn"],properties:{fn:{type:"string",description:"Function name from the built-in vocabulary",enum:["sum","avg","min","max","count","first","last","add","sub","mul","div","round","abs","mod","gt","gte","lt","lte","eq","neq","if","and","or","not","concat","upper","lower","template","filter","pluck","map","sort","slice","flat","unique","group","get","default","now","diff_days","format_date"]},input:{description:"card_data.path, literal, array of inputs, or nested compute_expr",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{$ref:"#/definitions/compute_expr"}]},field:{type:"string",description:"For pluck/sum/group \u2014 the object key to extract"},where:{$ref:"#/definitions/compute_expr",description:"For filter \u2014 predicate expression ($ = current item)"},cond:{$ref:"#/definitions/compute_expr",description:"For if \u2014 condition expression"},then:{description:"For if \u2014 value when cond is truthy"},else:{description:"For if \u2014 value when cond is falsy"},format:{type:"string",description:"For format_date \u2014 date format string"}}},meta:{type:"object",properties:{title:{type:"string"},tags:{type:"array",items:{type:"string"}}}},requires:{type:"array",items:{type:"string"},description:"IDs of upstream nodes this node depends on"},provides:{type:"array",items:{type:"object",required:["bindTo","ref"],properties:{bindTo:{type:"string",description:"Token name published downstream"},ref:{type:"string",description:"Path to read value from (card_data.*, requires.*, fetched_sources.*, computed_values.*)"}}},description:"Explicit bindings exposing computed or card_data values downstream as named tokens"},compute_step:{description:"A single ordered compute step: reads card_data.*/requires.*/computed_values.*, writes to computed_values[bindTo]",type:"object",required:["bindTo","expr"],properties:{bindTo:{type:"string",description:"Key in computed_values to write result"},expr:{type:"string",description:"JSONata expression evaluated against { card_data, requires, fetched_sources, computed_values }"}}},source_def:{description:"One source entry. The engine requires 'bindTo' (compute namespace key) and 'outputFile' (delivery signal path). bindTo and outputFile must be unique across all source_defs in a card. Every other property is yours \u2014 add whatever your task-executor needs: kind, url, headers, mailbox, channel, model, query, etc. The full object is passed verbatim as the --in JSON to the executor.",type:"object",required:["bindTo","outputFile"],additionalProperties:true,properties:{bindTo:{type:"string",description:"Key under fetched_sources.* available in compute expressions"},outputFile:{type:"string",description:"Board-relative path the executor writes its JSON result to. Presence of this file signals delivery."},projections:{type:"object",description:"Named data projections from card_data or requires, evaluated before the executor is called. Each key is a ref name; each value is a JSONata expression rooted at card_data or requires. The resolved values are passed to the executor as _projections. fetched_sources, computed_values, and source_defs are not accessible here \u2014 sources run before those exist.",additionalProperties:{type:"string"}},optionalForCompletionGating:{type:"boolean",default:false,description:"When true this source does not gate card completion. Default false when absent, so source_defs are completion-gating by default."},timeout:{type:"integer",minimum:0,default:12e4,description:"Executor/script timeout in ms. Default: 120 000 (2 min)."},script:{type:"string",description:"Legacy direct-run: shell command executed when no .task-executor is registered. stdout is captured as the result."}}},render_element:{type:"object",required:["kind"],properties:{id:{type:"string",description:"Optional element ID for targeted updates"},kind:{enum:["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]},label:{type:"string",description:"Heading above this element"},className:{type:"string",description:"Bootstrap grid class, e.g. 'col-12 col-md-6'"},visible:{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 element shown only if truthy"},data:{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref",description:"card_data/requires/fetched_sources/computed_values path to read data from"},writeTo:{$ref:"#/definitions/bind_ref",description:"card_data path for user input (form, filter, todo, notes)"},columns:{type:"array",items:{type:"string"},description:"table: visible columns"},maxRows:{type:"integer",description:"table/list: max rows to display"},sortable:{type:"boolean",default:true,description:"table: enable click-to-sort"},placeholder:{type:"string",description:"Empty-state message"},chartType:{enum:["bar","line","pie","doughnut"]},chartOptions:{type:"object",description:"Chart.js options passthrough"},fields:{type:"object",description:"JSON Schema for form/filter fields"},thresholds:{type:"object",properties:{green:{type:"string"},amber:{type:"string"}}},colorMap:{type:"object",description:"badge: value \u2192 Bootstrap color"},style:{enum:["heading","muted","default"],description:"text: display style"},upload:{type:"boolean",default:true,description:"file-upload: show drop zone (false = read-only file list)"},accept:{type:"array",items:{type:"string"},description:"file-upload: allowed extensions"},multiple:{type:"boolean",default:true,description:"file-upload: allow multiple files"},fileAttach:{type:"boolean",default:false,description:"chat: enable inline file attachments"},fileAccept:{type:"array",items:{type:"string"},description:"chat: allowed attachment extensions"},buttons:{type:"array",description:"actions: button definitions",items:{type:"object",required:["id","label"],properties:{id:{type:"string"},label:{type:"string"},style:{type:"string",description:"Bootstrap button variant, e.g. 'success', 'outline-danger'"},size:{type:"string",default:"sm"},disabled:{oneOf:[{type:"boolean"},{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 truthy = disabled"}]}}}}}}}},view:{type:"object",required:["elements"],properties:{elements:{type:"array",minItems:1,items:{$ref:"#/definitions/render_element"}},layout:{type:"object",properties:{board:{type:"object",properties:{col:{type:"integer",minimum:1,maximum:12},order:{type:"integer"}}},canvas:{type:"object",properties:{x:{type:"number"},y:{type:"number"},w:{type:"number"},h:{type:"number"}}}}},features:{type:"object",properties:{chat:{type:"boolean",default:false},notes:{type:"boolean",default:false},refresh:{type:"boolean",default:true}}}}}},title:"LiveCard",description:"A unified card node. Behavior depends on which sections are present (source_defs, compute, view, etc.)",type:"object",required:["id"],additionalProperties:false,properties:{id:{type:"string"},requires:{$ref:"#/definitions/requires"},provides:{$ref:"#/definitions/provides"},meta:{$ref:"#/definitions/meta"},view:{$ref:"#/definitions/view"},card_data:{type:"object",description:"Authored card data and runtime metadata. Includes uploaded-file metadata maintained by host handlers and inference evaluation results.",properties:{files:{type:"array",description:"Optional uploaded-file metadata maintained by host handlers. Stored name is normalized and serial-prefixed (for example 001-my_file.pdf).",items:{type:"object",required:["name","stored_name"],properties:{name:{type:"string",minLength:1},stored_name:{type:"string",minLength:5,maxLength:32,pattern:"^[0-9]{3,}-[a-z0-9._-]+$"},size:{oneOf:[{type:"integer",minimum:0},{type:"null"}]},mime_type:{type:"string"},path:{type:"string",pattern:"^[^\\s]+/files/[0-9]{3,}-[a-z0-9._-]+$"},uploaded_at:{type:"string",format:"date-time"}},additionalProperties:false}}},additionalProperties:true},source_defs:{type:"array",description:"Source entries. Each entry is passed verbatim to the board's .task-executor (registered via init --task-executor) as the --in JSON file. The executor fetches/generates the data and writes JSON to --out. If no executor is registered, the built-in executor runs the entry's 'cli' command directly. Sources gate completion by default. Set optionalForCompletionGating: true for enrichment-only source_defs that should not block task-completed.",items:{$ref:"#/definitions/source_def"}},compute:{type:"array",description:"Ordered array of compute steps. Each reads card_data.*/requires.*/fetched_sources.*/computed_values.* and writes to ephemeral computed_values[bindTo].",items:{$ref:"#/definitions/compute_step"}}}};var Bu=jc(Mu());var jh=createRequire(import.meta.url),Nh=jh("./jsonata-sync.cjs"),Cn=null;var Lu=/\b(card_data|requires|fetched_sources|computed_values|source_defs)\b/g,qh=/^\s*(card_data|requires|fetched_sources|computed_values|source_defs)(\.|$)/;function Dh(t){let e=new Set,r;for(Lu.lastIndex=0;(r=Lu.exec(t))!==null;)e.add(r[1]);return e}function Gu(t){let e=qh.exec(t);return e?e[1]:null}function Vu(t,e,r,n){try{Nh(t);}catch(o){let a=o instanceof Error?o.message:String(o);n.push(`${e}: invalid JSONata expression (${a})`);return}let s=Dh(t);for(let o of s)r.has(o)||n.push(`${e}: disallowed namespace "${o}" in expression`);}function Oo(t,e,r){if(Array.isArray(t)){t.forEach((s,o)=>{Oo(s,`${e}/${o}`,r);});return}if(typeof t=="string"){let s=Gu(t);if(!s)return;new Set(["card_data","requires","computed_values"]).has(s)||r.push(`${e}: disallowed namespace "${s}" in view reference`);return}if(!t||typeof t!="object")return;let n=t;for(let[s,o]of Object.entries(n))Oo(o,`${e}/${s}`,r);}function Fh(){if(Cn)return Cn;let t=new Bu.default({allErrors:true});return Ph(t),Cn=t.compile(fa),Cn}function Ku(t){let e=Fh(),r=e(t),n=(e.errors??[]).map(s=>`${s.instancePath||"/"}: ${s.message??"unknown error"}`);if(t&&typeof t=="object"&&!Array.isArray(t)){let s=t.source_defs;if(Array.isArray(s)){let o=new Set,a=new Set;s.forEach((i,u)=>{if(!i||typeof i!="object"||Array.isArray(i))return;let c=i;typeof c.bindTo=="string"&&c.bindTo&&(o.has(c.bindTo)&&n.push(`/source_defs/${u}/bindTo: bindTo "${c.bindTo}" must be unique across all source_defs`),o.add(c.bindTo)),typeof c.outputFile=="string"&&c.outputFile&&(a.has(c.outputFile)&&n.push(`/source_defs/${u}/outputFile: outputFile "${c.outputFile}" must be unique across all source_defs`),a.add(c.outputFile));});}}return !r||n.length>0?{ok:false,errors:n}:{ok:true,errors:[]}}function Uu(t){let e=[];if(!t||typeof t!="object"||Array.isArray(t))return {ok:true,errors:[]};let r=t,n=r.compute;Array.isArray(n)&&n.forEach((c,d)=>{if(!c||typeof c!="object"||Array.isArray(c))return;let l=c.expr;typeof l!="string"||l.trim().length===0||Vu(l,`/compute/${d}/expr`,new Set(["card_data","requires","fetched_sources","computed_values"]),e);});let s=new Set(["card_data","requires","fetched_sources","computed_values"]),o=r.provides;Array.isArray(o)&&o.forEach((c,d)=>{if(!c||typeof c!="object"||Array.isArray(c))return;let l=c.ref;if(typeof l!="string"||l.trim().length===0)return;let b=Gu(l);b===null?e.push(`/provides/${d}/ref: path "${l}" must start with a valid namespace (${[...s].join(", ")})`):s.has(b)||e.push(`/provides/${d}/ref: disallowed namespace "${b}" in path "${l}" (valid: ${[...s].join(", ")})`);});let a=r.view;a&&typeof a=="object"&&!Array.isArray(a)&&Oo(a,"/view",e);let i=new Set(["card_data","requires"]),u=r.source_defs;return Array.isArray(u)&&u.forEach((c,d)=>{if(!c||typeof c!="object"||Array.isArray(c))return;let l=c.projections;if(!(!l||typeof l!="object"||Array.isArray(l)))for(let[b,y]of Object.entries(l))typeof y!="string"||y.trim().length===0||Vu(y,`/source_defs/${d}/projections/${b}`,i,e);}),{ok:e.length===0,errors:e}}function jo(t){let e=Ku(t);if(!e.ok)return e;let r=Uu(t);return r.ok?{ok:true,errors:[]}:{ok:false,errors:r.errors}}var ut={RUNNING:"running",COMPLETED:"completed",FAILED:"failed",INACTIVATED:"inactivated"};function xe(t){return t?Array.isArray(t.provides)?t.provides:[]:[]}function ct(t){return t?Array.isArray(t.requires)?t.requires:[]:[]}function Ju(t){return t.tasks??{}}function No(t){return t?t.status===ut.FAILED||t.status===ut.INACTIVATED:false}function Hu(t,e){return t.refreshStrategy??e?.refreshStrategy??"data-changed"}function zu(t){return t.maxExecutions}function Wu(t,e){let r=new Set;for(let[n,s]of Object.entries(e))if(s.status===ut.COMPLETED){let o=t.tasks[n];o&&xe(o).forEach(i=>r.add(i));}return Array.from(r)}function Yu(t,e){let r={};return t.forEach(n=>{let s=e[n];if(!s)return;xe(s).forEach(a=>{r[a]||(r[a]=[]),r[a].push(n);});}),r}function Xu(t,e,r){let n=t.tasks[e]??$n(),s={};if(r){let a=r.tasks[e],i=ct(a);for(let u of i)for(let[c,d]of Object.entries(r.tasks))if(xe(d).includes(u)){let l=t.tasks[c];l?.lastDataHash&&(s[u]=l.lastDataHash);break}}let o={...n,status:"running",startedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),progress:0,error:void 0,startConsumedHashes:s};return {...t,tasks:{...t.tasks,[e]:o},lastUpdated:new Date().toISOString()}}function Qu(t,e,r,n,s,o){let a=t.tasks[r]??$n(),i=e.tasks[r];if(!i)throw new Error(`Task "${r}" not found in graph`);let u;n&&i.on&&i.on[n]?u=i.on[n]:u=xe(i);let c=a.startConsumedHashes?{...a.startConsumedHashes}:{...a.lastConsumedHashes};if(!a.startConsumedHashes){let b=i.requires??[];for(let y of b)for(let[m,p]of Object.entries(e.tasks))if(xe(p).includes(y)){let k=t.tasks[m];k?.lastDataHash&&(c[y]=k.lastDataHash);break}}let d={...a,status:"completed",completedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),executionCount:a.executionCount+1,lastEpoch:a.executionCount+1,lastDataHash:s,data:o,lastConsumedHashes:c,error:void 0},l=[...new Set([...t.availableOutputs,...u])];return {...t,tasks:{...t.tasks,[r]:d},availableOutputs:l,lastUpdated:new Date().toISOString()}}function Zu(t,e,r,n){let s=t.tasks[r]??$n(),o=e.tasks[r];if(o?.retry){let u=s.retryCount+1;if(u<=o.retry.max_attempts){let c={...s,status:"not-started",retryCount:u,lastUpdated:new Date().toISOString(),error:n};return {...t,tasks:{...t.tasks,[r]:c},lastUpdated:new Date().toISOString()}}}let a={...s,status:"failed",failedAt:new Date().toISOString(),lastUpdated:new Date().toISOString(),error:n,executionCount:s.executionCount+1},i=t.availableOutputs;if(o?.on_failure&&o.on_failure.length>0&&(i=[...new Set([...t.availableOutputs,...o.on_failure])]),o?.circuit_breaker&&a.executionCount>=o.circuit_breaker.max_executions){let u=o.circuit_breaker.on_break;i=[...new Set([...i,...u])];}return {...t,tasks:{...t.tasks,[r]:a},availableOutputs:i,lastUpdated:new Date().toISOString()}}function ec(t,e,r,n){let s=t.tasks[e]??$n(),o={...s,progress:typeof n=="number"?n:s.progress,messages:[...s.messages??[],...r?[{message:r,timestamp:new Date().toISOString(),status:s.status}]:[]],lastUpdated:new Date().toISOString()};return {...t,tasks:{...t.tasks,[e]:o},lastUpdated:new Date().toISOString()}}function tc(t,e){let r=t.tasks[e];if(!r)return t;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 {...t,tasks:{...t.tasks,[e]:n},lastUpdated:new Date().toISOString()}}function $n(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function xn(t,e){let r=`live-${Date.now()}`,n={};for(let o of Object.keys(t.tasks))n[o]=nc();let s={status:"running",tasks:n,availableOutputs:[],stuckDetection:{is_stuck:false,stuck_description:null,outputs_unresolvable:[],tasks_blocked:[]},lastUpdated:new Date().toISOString(),executionId:r,executionConfig:{executionMode:t.settings.execution_mode??"eligibility-mode",conflictStrategy:t.settings.conflict_strategy??"alphabetical",completionStrategy:t.settings.completion}};return {config:t,state:s}}function Mh(t,e){let{config:r,state:n}=t;if("executionId"in e&&e.executionId&&e.executionId!==n.executionId)return t;switch(e.type){case "task-started":return {config:r,state:Xu(n,e.taskName,r)};case "task-completed":return {config:r,state:Qu(n,r,e.taskName,e.result,e.dataHash,e.data)};case "task-failed":return {config:r,state:Zu(n,r,e.taskName,e.error)};case "task-progress":return {config:r,state:ec(n,e.taskName,e.message,e.progress)};case "task-restart":return {config:r,state:tc(n,e.taskName)};case "inject-tokens":return {config:r,state:{...n,availableOutputs:[...new Set([...n.availableOutputs,...e.tokens])],lastUpdated:new Date().toISOString()}};case "agent-action":return {config:r,state:Jh(n,e.action)};case "task-upsert":return Lh(t,e.taskName,e.taskConfig);case "task-removal":return Vh(t,e.taskName);case "node-requires-add":return Bh(t,e.nodeName,e.tokens);case "node-requires-remove":return Gh(t,e.nodeName,e.tokens);case "node-provides-add":return Kh(t,e.nodeName,e.tokens);case "node-provides-remove":return Uh(t,e.nodeName,e.tokens);default:return t}}function rc(t,e){return e.reduce((r,n)=>Mh(r,n),t)}function Lh(t,e,r){let n=!!t.config.tasks[e];return {config:{...t.config,tasks:{...t.config.tasks,[e]:r}},state:{...t.state,tasks:{...t.state.tasks,[e]:n?t.state.tasks[e]:nc()},lastUpdated:new Date().toISOString()}}}function Vh(t,e){if(!t.config.tasks[e])return t;let{[e]:r,...n}=t.config.tasks,{[e]:s,...o}=t.state.tasks;return {config:{...t.config,tasks:n},state:{...t.state,tasks:o,lastUpdated:new Date().toISOString()}}}function Bh(t,e,r){let n=t.config.tasks[e];if(!n)return t;let s=ct(n),o=r.filter(a=>!s.includes(a));return o.length===0?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,requires:[...s,...o]}}},state:t.state}}function Gh(t,e,r){let n=t.config.tasks[e];if(!n)return t;let s=ct(n),o=s.filter(a=>!r.includes(a));return o.length===s.length?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,requires:o}}},state:t.state}}function Kh(t,e,r){let n=t.config.tasks[e];if(!n)return t;let s=xe(n),o=r.filter(a=>!s.includes(a));return o.length===0?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,provides:[...s,...o]}}},state:t.state}}function Uh(t,e,r){let n=t.config.tasks[e];if(!n)return t;let s=xe(n),o=s.filter(a=>!r.includes(a));return o.length===s.length?t:{config:{...t.config,tasks:{...t.config.tasks,[e]:{...n,provides:o}}},state:t.state}}function Ar(t){return {version:1,config:t.config,state:t.state,snapshotAt:new Date().toISOString()}}function En(t){if(!t||typeof t!="object")throw new Error("Invalid snapshot: expected an object");let e=t;if(!e.config||typeof e.config!="object")throw new Error('Invalid snapshot: missing or invalid "config"');if(!e.state||typeof e.state!="object")throw new Error('Invalid snapshot: missing or invalid "state"');let r=e.config,n=e.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 nc(){return {status:"not-started",executionCount:0,retryCount:0,lastEpoch:0,messages:[],progress:null}}function Jh(t,e){let r=new Date().toISOString();switch(e){case "stop":return {...t,status:"stopped",lastUpdated:r};case "pause":return {...t,status:"paused",lastUpdated:r};case "resume":return {...t,status:"running",lastUpdated:r};default:return t}}function Ir(t){let{config:e,state:r}=t,n=Ju(e);if(Object.keys(n).length===0)return {eligible:[],pending:[],unresolved:[],blocked:[],conflicts:{}};let o=Hh(n),a=Wu(e,r.tasks),i=new Set([...a,...r.availableOutputs]),u=[],c=[],d=[],l=[];for(let[y,m]of Object.entries(n)){let p=r.tasks[y],k=Hu(m,e.settings),h=k!=="once";if(p?.status===ut.RUNNING||No(p))continue;let f=zu(m);if(f!==void 0&&p&&p.executionCount>=f||m.circuit_breaker&&p&&p.executionCount>=m.circuit_breaker.max_executions||!h&&p?.status===ut.COMPLETED)continue;if(h&&p?.status===ut.COMPLETED){let _=ct(m),$=false;switch(k){case "data-changed":{_.length>0&&_.some(q=>{for(let[F,re]of Object.entries(n))if(xe(re).includes(q)){let U=r.tasks[F];if(!U)continue;let de=p.lastConsumedHashes?.[q];return U.lastDataHash==null?U.executionCount>p.lastEpoch:U.lastDataHash!==de}return false})||($=true);break}case "epoch-changed":{_.length>0&&_.some(q=>{for(let[F,re]of Object.entries(n))if(xe(re).includes(q)){let U=r.tasks[F];if(U&&U.executionCount>p.lastEpoch)return true}return false})||($=true);break}case "time-based":{let N=m.refreshInterval??0;if(N<=0){$=true;break}let q=p.completedAt;if(!q){$=true;break}(Date.now()-Date.parse(q))/1e3<N&&($=true);break}case "manual":$=true;break}if($)continue}let g=ct(m);if(g.length===0){u.push(y);continue}let S=[],w=[],C=[];for(let _ of g){if(i.has(_))continue;let $=o[_]||[];$.length===0?S.push(_):$.every(q=>No(r.tasks[q]))?C.push({token:_,failedProducer:$[0]}):w.push(_);}S.length>0?d.push({taskName:y,missingTokens:S}):C.length>0?l.push({taskName:y,failedTokens:C.map(_=>_.token),failedProducers:[...new Set(C.map(_=>_.failedProducer))]}):w.length>0?c.push({taskName:y,waitingOn:w}):u.push(y);}let b={};if(u.length>1){let y=Yu(u,n);for(let[m,p]of Object.entries(y))p.length>1&&(b[m]=p);}return {eligible:u,pending:c,unresolved:d,blocked:l,conflicts:b}}function Hh(t){let e={};for(let[r,n]of Object.entries(t)){for(let s of xe(n))e[s]||(e[s]=[]),e[s].push(r);if(n.on)for(let s of Object.values(n.on))for(let o of s)e[o]||(e[o]=[]),e[o].includes(r)||e[o].push(r);if(n.on_failure)for(let s of n.on_failure)e[s]||(e[s]=[]),e[s].includes(r)||e[s].push(r);}return e}var Pr=class{buffer=[];append(e){this.buffer.push(e);}drain(){let e=this.buffer;return this.buffer=[],e}get size(){return this.buffer.length}};function qo(t){let e=Do(t);return zh(e)}function Do(t){if(t==null||typeof t!="object")return JSON.stringify(t);if(Array.isArray(t))return "["+t.map(Do).join(",")+"]";let e=t;return "{"+Object.keys(e).sort().map(n=>JSON.stringify(n)+":"+Do(e[n])).join(",")+"}"}function zh(t){let e=0xcbf29ce484222325n,r=0x100000001b3n,n=0xffffffffffffffffn;for(let s=0;s<t.length;s++)e^=BigInt(t.charCodeAt(s)),e=e*r&n;return e.toString(16).padStart(16,"0")}function Wh(t){if(typeof Buffer<"u")return Buffer.from(t,"utf8").toString("base64url");if(typeof btoa=="function"){let e=new TextEncoder().encode(t),r="";for(let n of e)r+=String.fromCharCode(n);return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}throw new Error("No base64 encoder available in this runtime")}function Yh(t){if(typeof Buffer<"u")return Buffer.from(t,"base64url").toString("utf8");if(typeof atob=="function"){let e=t.replace(/-/g,"+").replace(/_/g,"/"),r=e+"=".repeat((4-e.length%4)%4),n=atob(r),s=new Uint8Array(n.length);for(let o=0;o<n.length;o++)s[o]=n.charCodeAt(o);return new TextDecoder().decode(s)}throw new Error("No base64 decoder available in this runtime")}function sc(t){let e=JSON.stringify({t,n:Date.now().toString(36)+Math.random().toString(36).slice(2,6)});return Wh(e)}function Xh(t){try{let e=JSON.parse(Yh(t));return typeof e?.t=="string"?{taskName:e.t}:null}catch{return null}}function oc(t,e,r){let{handlers:n,onDrain:s}=e,o=new Pr,a="state"in t&&"config"in t?t:xn(t),i=false,u=new Set,c=new Map(Object.entries(n)),d=new Pr,l=false,b=false;function y(){if(!i){if(l){b=true;return}l=true;try{do b=!1,m();while(b)}finally{l=false;}}}function m(){let f=d.drain(),g=o.drain(),S=[...f,...g];S.length>0&&(a=rc(a,S));let w=Ir(a);S.length>0&&s?.(S,a,w);for(let C of w.eligible)h(C);for(let C of S)if(C.type==="task-progress"){let{taskName:_,update:$}=C;if(!a.config.tasks[_])continue;let q=a.state.tasks[_];if(!q||q.status!=="running")continue;let F=sc(_),re=k(_,F,$).catch(U=>{i||(d.append({type:"task-failed",taskName:_,error:U.message??String(U),timestamp:new Date().toISOString()}),y());}).finally(()=>{u.delete(re);});u.add(re);}}function p(f){let S=a.config.tasks[f].requires??[],w=new Map;for(let[_,$]of Object.entries(a.config.tasks))for(let N of $.provides??[])w.set(N,_);let C={};for(let _ of S){let $=w.get(_);$?C[_]=a.state.tasks[$]?.data:C[_]=void 0;}return C}async function k(f,g,S){let w=a.config.tasks[f],C=w.taskHandlers??[],_=p(f);for(let $ of C){let N=c.get($);if(!N)throw new Error(`Handler '${$}' not found in registry (task '${f}')`);let q={nodeId:f,state:_,taskState:a.state.tasks[f],config:w,callbackToken:g,update:S};if(await N(q)==="task-initiate-failure")throw new Error(`Handler '${$}' returned task-initiate-failure (task '${f}')`)}}function h(f){let S=a.config.tasks[f]?.taskHandlers;if(!S||S.length===0)return;d.append({type:"task-started",taskName:f,timestamp:new Date().toISOString()}),y();let w=sc(f),C=k(f,w).catch(_=>{i||(d.append({type:"task-failed",taskName:f,error:_.message??String(_),timestamp:new Date().toISOString()}),y());}).finally(()=>{u.delete(C);});u.add(C);}return {push(f){i||(f.type==="task-completed"&&f.data&&!f.dataHash&&(f={...f,dataHash:qo(f.data)}),o.append(f),y());},pushAll(f){if(!i){for(let g of f)g.type==="task-completed"&&g.data&&!g.dataHash?o.append({...g,dataHash:qo(g.data)}):o.append(g);y();}},resolveCallback(f,g,S){if(i)return;let w=Xh(f);if(!w)return;let{taskName:C}=w;if(a.config.tasks[C]){if(S&&S.length>0)o.append({type:"task-failed",taskName:C,error:S.join("; "),timestamp:new Date().toISOString()});else {let _=g&&Object.keys(g).length>0?qo(g):void 0;o.append({type:"task-completed",taskName:C,data:g,dataHash:_,timestamp:new Date().toISOString()});}y();}},addNode(f,g){i||(o.append({type:"task-upsert",taskName:f,taskConfig:g,timestamp:new Date().toISOString()}),y());},removeNode(f){i||(o.append({type:"task-removal",taskName:f,timestamp:new Date().toISOString()}),y());},addRequires(f,g){i||(o.append({type:"node-requires-add",nodeName:f,tokens:g,timestamp:new Date().toISOString()}),y());},removeRequires(f,g){i||(o.append({type:"node-requires-remove",nodeName:f,tokens:g,timestamp:new Date().toISOString()}),y());},addProvides(f,g){i||(o.append({type:"node-provides-add",nodeName:f,tokens:g,timestamp:new Date().toISOString()}),y());},removeProvides(f,g){i||(o.append({type:"node-provides-remove",nodeName:f,tokens:g,timestamp:new Date().toISOString()}),y());},registerHandler(f,g){c.set(f,g);},unregisterHandler(f){c.delete(f);},retrigger(f){i||a.config.tasks[f]&&(o.append({type:"task-restart",taskName:f,timestamp:new Date().toISOString()}),y());},retriggerAll(f){if(!i){for(let g of f)a.config.tasks[g]&&o.append({type:"task-restart",taskName:g,timestamp:new Date().toISOString()});y();}},snapshot(){return Ar(a)},getState(){return a},getSchedule(){return Ir(a)},async waitForHandlers(){u.size>0&&await Promise.allSettled([...u]);},async dispose(f){f?.wait&&u.size>0&&await Promise.allSettled([...u]),i=true;}}}var Zh=createRequire(import.meta.url),Tn=Zh("./jsonata-sync.cjs"),uc=Tn;function ac(t,e){if(!e||!t)return;let r=e.split("."),n=t;for(let s=0;s<r.length;s++){if(n==null)return;n=n[r[s]];}return n}function cc(t,e,r){let n=e.split("."),s=t;for(let o=0;o<n.length-1;o++)(s[n[o]]==null||typeof s[n[o]]!="object")&&(s[n[o]]={}),s=s[n[o]];s[n[n.length-1]]=r;}async function eg(t,e){if(!t?.compute?.length)return t;t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=e?.sourcesData??{};let r=t.requires??{},n={card_data:t.card_data,requires:r,expects_data:r,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values};for(let s of t.compute)try{let o=await Tn(s.expr).evaluate(n);cc(t.computed_values,s.bindTo,o),n.computed_values=t.computed_values;}catch{}return t}function tg(t,e){if(!t?.compute?.length)return {ok:true,node:t};t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=e?.sourcesData??{};let r=t.requires??{},n={card_data:t.card_data,requires:r,expects_data:r,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values},s=[];for(let o of t.compute)try{let a=uc(o.expr).evaluate(n);cc(t.computed_values,o.bindTo,a),n.computed_values=t.computed_values;}catch(a){let i=a instanceof Error?a.message:String(a);s.push({bindTo:o.bindTo,error:i});}return s.length>0?{ok:true,node:t,errors:s}:{ok:true,node:t}}async function rg(t,e,r){let n={...r??{},card_data:e.card_data??{},requires:e.requires??{},fetched_sources:e._sourcesData??{},computed_values:e.computed_values??{}};return Tn(t).evaluate(n)}function ng(t,e){return e.startsWith("fetched_sources.")?ac(t._sourcesData??{},e.slice(16)):ac(t,e)}var ic=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),sg=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function og(t){let e=[];if(!t||typeof t!="object"||Array.isArray(t))return {ok:false,errors:["Node must be a non-null object"]};let r=t;(typeof r.id!="string"||!r.id)&&e.push("id: required, must be a non-empty string");for(let n of Object.keys(r))sg.has(n)||e.push(`Unknown top-level key: "${n}"`);if((r.card_data==null||typeof r.card_data!="object"||Array.isArray(r.card_data))&&e.push("card_data: required, must be an object"),r.meta!=null)if(typeof r.meta!="object"||Array.isArray(r.meta))e.push("meta: must be an object");else {let n=r.meta;n.title!=null&&typeof n.title!="string"&&e.push("meta.title: must be a string"),n.tags!=null&&!Array.isArray(n.tags)&&e.push("meta.tags: must be an array");}if(r.requires!=null&&!Array.isArray(r.requires)&&e.push("requires: must be an array of strings"),r.provides!=null&&(Array.isArray(r.provides)?r.provides.forEach((n,s)=>{if(!n||typeof n!="object"||Array.isArray(n))e.push(`provides[${s}]: must be an object with bindTo and ref`);else {let o=n;(typeof o.bindTo!="string"||!o.bindTo)&&e.push(`provides[${s}]: missing required "bindTo" string`),(typeof o.ref!="string"||!o.ref)&&e.push(`provides[${s}]: missing required "ref" string`);}}):e.push("provides: must be an array of { bindTo, ref } bindings")),r.compute!=null&&(Array.isArray(r.compute)?r.compute.forEach((n,s)=>{if(!n||typeof n!="object"||Array.isArray(n))e.push(`compute[${s}]: must be a compute step object`);else {let o=n;(typeof o.bindTo!="string"||!o.bindTo)&&e.push(`compute[${s}]: missing required "bindTo" property`),(typeof o.expr!="string"||!o.expr)&&e.push(`compute[${s}]: missing required "expr" string (JSONata expression)`);}}):e.push("compute: must be an array of compute steps")),r.source_defs!=null)if(!Array.isArray(r.source_defs))e.push("source_defs: must be an array");else {let n=new Set,s=new Set;r.source_defs.forEach((o,a)=>{if(!o||typeof o!="object"||Array.isArray(o))e.push(`source_defs[${a}]: must be an object`);else {let i=o;typeof i.bindTo!="string"||!i.bindTo?e.push(`source_defs[${a}]: missing required "bindTo" property`):(n.has(i.bindTo)&&e.push(`source_defs[${a}]: bindTo "${i.bindTo}" is not unique across source_defs`),n.add(i.bindTo)),typeof i.outputFile!="string"||!i.outputFile?e.push(`source_defs[${a}]: missing required "outputFile" property`):(s.has(i.outputFile)&&e.push(`source_defs[${a}]: outputFile "${i.outputFile}" is not unique across source_defs`),s.add(i.outputFile)),i.optionalForCompletionGating!=null&&typeof i.optionalForCompletionGating!="boolean"&&e.push(`source_defs[${a}]: optionalForCompletionGating must be a boolean`);}});}if(r.view!=null)if(typeof r.view!="object"||Array.isArray(r.view))e.push("view: must be an object");else {let n=r.view;!Array.isArray(n.elements)||n.elements.length===0?e.push("view.elements: required, must be a non-empty array"):n.elements.forEach((s,o)=>{if(!s||typeof s!="object"){e.push(`view.elements[${o}]: must be an object`);return}!s.kind||typeof s.kind!="string"?e.push(`view.elements[${o}].kind: required, must be a string`):ic.has(s.kind)||e.push(`view.elements[${o}].kind: unknown kind "${s.kind}". Valid: ${[...ic].join(", ")}`),s.data!=null&&(typeof s.data!="object"||Array.isArray(s.data))&&e.push(`view.elements[${o}].data: must be an object`);}),n.layout!=null&&(typeof n.layout!="object"||Array.isArray(n.layout))&&e.push("view.layout: must be an object"),n.features!=null&&(typeof n.features!="object"||Array.isArray(n.features))&&e.push("view.features: must be an object");}return {ok:e.length===0,errors:e}}async function ag(t,e){if(!t||t.length===0)return [];let r={card_data:e.card_data??{},requires:e.requires??{}};return Promise.all(t.map(async n=>{let s={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[o,a]of Object.entries(n.projections))if(typeof a=="string"&&a.trim().length>0)try{s[o]=await Tn(a).evaluate(r);}catch{s[o]=void 0;}}return {...n,_projections:s}}))}function ig(t,e){if(!t||t.length===0)return [];let r={card_data:e.card_data??{},requires:e.requires??{}};return t.map(n=>{let s={};if(n.projections&&typeof n.projections=="object"&&!Array.isArray(n.projections)){for(let[o,a]of Object.entries(n.projections))if(typeof a=="string"&&a.trim().length>0)try{s[o]=uc(a).evaluate(r);}catch{s[o]=void 0;}}return {...n,_projections:s}})}var dt={run:eg,runSync:tg,eval:rg,resolve:ng,validate:og,enrichSources:ag,enrichSourcesSync:ig};function An(t){return JSON.stringify(t)}function In(t){let e;try{e=JSON.parse(t);}catch{throw new Error(`parseExecutionRef: invalid JSON \u2014 ${t}`)}if(typeof e!="object"||e===null||typeof e.howToRun!="string"||typeof e.whatToRun!="string")throw new Error(`parseExecutionRef: missing required fields howToRun/whatToRun \u2014 ${t}`);return e}function Pn(t,e){function r(){return t.readIndex()??{}}function n(s,o,a){let i=String(o||"").split(".").filter(Boolean);if(i.length===0)return a&&typeof a=="object"&&!Array.isArray(a)?a:{value:a};let u={...s},c=u;for(let d=0;d<i.length-1;d++){let l=i[d],b=c[l],y=b&&typeof b=="object"&&!Array.isArray(b)?{...b}:{};c[l]=y,c=y;}return c[i[i.length-1]]=a,u}return {readCard(s){let o=r()[s];return !o||!t.cardExists(o.key)?null:t.readCard(o.key)},readCardKey(s){return r()[s]?.key??null},readAllCards(){let s=[];for(let[o,a]of Object.entries(r())){if(!t.cardExists(a.key))continue;let i=t.readCard(a.key);i?s.push(i):e?.(`[card-store] could not read card "${o}" at key "${a.key}"`);}return s},readChecksumIndex(){let s={};for(let[o,a]of Object.entries(r()))s[o]=a.checksum;return s},changedSince(s){let o=r(),a=[];for(let[i,u]of Object.entries(o))s[i]!==u.checksum&&a.push(i);for(let i of Object.keys(s))o[i]||a.push(i);return a},validateUpsert(s,o){let a=r(),i=a[s],u=Object.entries(a).find(([,c])=>c.key===o);return i&&i.key!==o?{ok:false,error:`Card id "${s}" is already mapped to key "${i.key}", cannot remap to "${o}"`}:u&&u[0]!==s?{ok:false,error:`Key "${o}" is already mapped to card id "${u[0]}", cannot remap to "${s}"`}:{ok:true}},writeCard(s,o,a){let i=r(),u=a??i[s]?.key??t.defaultCardKey(s),c=t.writeCard(u,o);i[s]={key:u,checksum:c,updatedAt:new Date().toISOString()},t.writeIndex(i);},patchCard(s,o,a){let i=r(),u=i[s];if(!u||!t.cardExists(u.key))throw new Error(`card "${s}" not found`);let c=t.readCard(u.key);if(!c||typeof c!="object"||Array.isArray(c))throw new Error(`card "${s}" is not patchable`);let d=n(c,o,a),l=t.writeCard(u.key,d);i[s]={key:u.key,checksum:l,updatedAt:new Date().toISOString()},t.writeIndex(i);},removeCard(s){let o=r();o[s]&&(delete o[s],t.writeIndex(o));},readIndex(){return r()}}}function Fo(t,e){return {readSourceData(r,n){let s=t.read(`${r}/${n}`);if(s==null)return null;let o=s.trim();if(!o)return null;try{return JSON.parse(o)}catch{return o}},ingestSourceDataStaged(r,n,s,o){let a=e(s);t.write(`${r}/.staged/${o}/${n}`,a);},commitSourceData(r,n,s){let o=`${r}/.staged/${s}/${n}`,a=t.read(o);return a==null?false:(t.write(`${r}/${n}`,a),t.remove(o),true)},hasSource(r,n){return t.exists(`${r}/${n}`)}}}function fc(t){function e(r){let n=t.readAllEntries();if(!r)return n;let s=n.findIndex(o=>o.id===r);return s===-1?n:n.slice(s+1)}return {readEntriesAfterCursor(r){let n=e(r);return n.length===0?{events:[],newCursor:r}:{events:n.map(s=>s.event),newCursor:n[n.length-1].id}},pendingCount(r){return e(r).length},appendEvent(r){t.appendEntry({id:t.generateId(),event:r});}}}function pc(t,e){return {appendEntries(r,n){if(!r||n.length===0)return;let s=t.read(r)??[];t.write(r,[...s,...n]);},dispatchEntriesForJournalId(r,n){if(!r)return;let s=t.read(r);if(!(!s||s.length===0)){for(let o of s)try{n(o);}catch(a){let i=a instanceof Error?a.message:String(a);try{e(o,i);}catch{}}t.delete(r);}}}}var Or="v1",lt="board/graph",mc="board/lastJournalProcessedId";function dc(t){return `cards/${t}/runtime`}function hc(t){return {readRuntime(e){return t.read(dc(e))??{_sources:{}}},writeRuntime(e,r){t.write(dc(e),r);}}}function ug(t,e){let r={...t};for(let n of e.deleteKeys)delete r[n];return {...r,...e.shallowMerge}}function gc(t){return {readSnapshot(e){return t.readValues(e)},commitSnapshot(e,r){if(r.schemaVersion!==Or)throw new Error(`Unsupported snapshot schema version: ${r.schemaVersion}`);let n=t.readValues(e);if(n.version!==r.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let s=ug(n.values,r);return {ok:true,newVersion:t.writeValues(e,s,r.deleteKeys)}}}}function Mo(t){function e(r){let n=t.read(r);return n==null?null:typeof n=="string"?n:JSON.stringify(n)}return {readTaskExecutorRef(){let r=e("task-executor");if(r?.trim())return In(r.trim())},writeTaskExecutorRef(r){t.write("task-executor",An(r));},readChatHandlerRef(){let r=e("chat-handler");if(r?.trim())return In(r.trim())},writeChatHandlerRef(r){t.write("chat-handler",An(r));},readCardStoreRef(){return e("card-store-ref")},writeCardStoreRef(r){t.write("card-store-ref",r);},readOutputsStoreRef(){return e("outputs-store-ref")},writeOutputsStoreRef(r){t.write("outputs-store-ref",r);},readChatHandler(){return e("chat-handler")?.trim()||void 0},writeChatHandler(r){t.write("chat-handler",r);}}}function yc(t){return {writeComputedValues(e,r){t.write(`cards/${e}/computed_values`,r);},readComputedValues(e){return t.read(`cards/${e}/computed_values`)},readAllComputedValues(){let e={};for(let r of t.listKeys("cards/")){let n=r.match(/^cards\/([^/]+)\/computed_values$/);n&&(e[n[1]]=t.read(r));}return e},writeDataObjects(e){for(let[r,n]of Object.entries(e))r&&t.write(`data-objects/${r}`,n);},readDataObject(e){return t.read(`data-objects/${e}`)},readAllDataObjects(){let e={};for(let r of t.listKeys("data-objects/"))e[r.slice(13)]=t.read(r);return e},writeStatusSnapshot(e){t.write("status",e);},readStatusSnapshot(){return t.read("status")}}}function cg(t){return t?.lastRequestedAt?!t.lastFetchedAt||t.lastFetchedAt<t.lastRequestedAt:false}function dg(t,e){return t?.lastRequestedAt?cg(t)?"in-flight":!t.lastFetchedAt||t.lastFetchedAt<e?"dispatch":"idle":"dispatch"}function lg(t,e){let r={...t,lastFetchedAt:e};return delete r.lastError,r}function lc(t,e){let r={...t,lastError:e};return delete r.lastFetchedAt,r}function On(t,e){let r=e.state.tasks,n=e.config.tasks,s=Object.keys(r),o=Ir(e),a={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},i=new Map;for(let m of o.pending)i.set(m.taskName,m.waitingOn);for(let m of o.unresolved)i.set(m.taskName,m.missingTokens);for(let m of o.blocked)i.set(m.taskName,m.failedTokens);let u=new Map;for(let[m,p]of Object.entries(n))for(let k of p.requires??[]){let h=u.get(k)??[];h.push(m),u.set(k,h);}let c=s.sort().map(m=>{let p=r[m],k=n[m]??{requires:[],provides:[]};p.status==="completed"?a.completed+=1:p.status==="failed"?a.failed+=1:p.status==="in-progress"&&(a.in_progress+=1);let h=k.requires??[],f=k.provides??[],g=Object.keys(p.data??{}).sort(),S=h.filter(q=>e.state.availableOutputs.includes(q)),w=h.filter(q=>!e.state.availableOutputs.includes(q)),C=i.get(m)??w,_=new Set;for(let q of f)for(let F of u.get(q)??[])F!==m&&_.add(F);let $=p.failedAt,N=p.error?{message:p.error,code:"TASK_FAILED",at:$,source:"task-runtime"}:void 0;return {name:m,status:p.status,error:N,requires:h,requires_satisfied:S,requires_missing:w,provides_declared:f,provides_runtime:g,blocked_by:C,unblocks:Array.from(_).sort(),runtime:{attempt_count:p.executionCount??0,restart_count:p.retryCount??0,in_progress_since:p.status==="in-progress"?p.startedAt??null:null,last_transition_at:p.lastUpdated??null,last_completed_at:p.completedAt??null,last_restarted_at:p.startedAt??null,status_age_ms:p.lastUpdated?0:null}}});a.pending=o.pending.length,a.blocked=o.blocked.length,a.unresolved=o.unresolved.length;let d=c.map(m=>({name:m.name,fanOut:m.unblocks.length})).sort((m,p)=>p.fanOut-m.fanOut||m.name.localeCompare(p.name)),l=d.length>0?d[0]:{name:null,fanOut:0},b=new Set;for(let m of Object.values(n))for(let p of m.requires??[])b.add(p);let y=0;for(let[m,p]of Object.entries(n)){let k=(p.requires??[]).length===0,f=(p.provides??[]).some(g=>(u.get(g)??[]).some(S=>S!==m));k&&!f&&(y+=1);}return {schema_version:"v1",meta:{board:{path:t}},summary:{card_count:s.length,completed:a.completed,eligible:o.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(b).length,max_fan_out_card:l.name,max_fan_out:l.fanOut}},cards:c}}function fg(){return new Date().toISOString()}function vc(t,e,r,n,s,o,a){return async i=>{let u=[],c=r.cardStore.readCard(i.nodeId);if(!c)return "task-initiate-failure";let d=c.id,l=c.card_data??{},b=c.source_defs??[],y=b.filter(M=>M.optionalForCompletionGating!==true),m=r.cardRuntimeStore.readRuntime(d),p=false,k=()=>{p&&(r.cardRuntimeStore.writeRuntime(d,m),p=false);},h=M=>({...m._sources[M]??{}}),f=(M,V)=>{m._sources[M]=V,p=true;},g=i.taskState?.executionCount??0,S=m._lastExecutionCount;if(typeof S=="number"&&S!==g&&(m._sources={},p=true),S!==g&&(m._lastExecutionCount=g,p=true),i.update){let M=i.update,V=M.outputFile;if(V){let R=h(V);if(M.failure)f(V,lc(R,M.reason??"unknown"));else {let v=M.rqt;if(!R.lastFetchedAt||v>R.lastFetchedAt){let x=typeof M.deliveryToken=="string"?M.deliveryToken:void 0,A=false;x&&(A=r.fetchedSourcesStore.commitSourceData(d,V,x)),A?f(V,lg(R,v)):f(V,lc(R,`source delivery commit failed for ${V} token=${String(x)}`));}}k();}}let w={};for(let M of b)if(M.outputFile){let V=r.fetchedSourcesStore.readSourceData(d,M.outputFile);V!==null&&(w[M.bindTo]=V);}let C={};for(let[M,V]of Object.entries(i.state??{}))if(V!==null&&typeof V=="object"&&!Array.isArray(V)){let R=V[M];C[M]=R!==void 0?R:V;}else C[M]=V;let _={id:d,card_data:{...l},requires:C,source_defs:b,compute:c.compute};_._sourcesData=w,c.compute&&dt.runSync(_,{sourcesData:w}),(o??r.outputStore.writeComputedValues.bind(r.outputStore))(d,_.computed_values??{});let $={...c},N=dt.enrichSourcesSync(Array.isArray(c.source_defs)?c.source_defs:void 0,{card_data:c.card_data,requires:C}),q=t.value;$.source_defs=Array.isArray(N)?N.map(M=>({...M,boardDir:typeof M.boardDir=="string"&&M.boardDir?M.boardDir:q})):N;let F=fg(),re=i.update?void 0:F,U=y.filter(M=>{let V=M.outputFile;if(typeof V!="string"||!V)return true;let R=h(V);re&&(R={...R,queueRequestedAt:re},f(V,R));let v=R.queueRequestedAt??R.lastRequestedAt??F,x=dg(R,v);return x==="in-flight"?false:x==="dispatch"});if(k(),U.length>0){let M=false,V=F;for(let R of U){let v=R.outputFile;if(typeof v!="string"||!v)continue;let x=h(v),A=x.queueRequestedAt??F;f(v,{...x,lastRequestedAt:A}),V=A,M=true;}return M&&k(),M&&(u.push({taskKind:"source-fetch",payload:{boardRef:ie(t),enrichedCard:$,callbackToken:i.callbackToken,rqt:V}}),r.executionRequestStore.appendEntries(e,u)),"task-initiated"}let de=c.provides??[],Fe={};for(let{bindTo:M,ref:V}of de)Fe[M]=dt.resolve(_,V);return (a??r.outputStore.writeDataObjects.bind(r.outputStore))(Fe),b.filter(M=>{if(M.optionalForCompletionGating!==true)return false;let V=h(M.outputFile);return !V.lastRequestedAt||!V.lastFetchedAt?true:V.lastFetchedAt<=V.lastRequestedAt}).length>0&&u.push({taskKind:"source-fetch",payload:{boardRef:ie(t),enrichedCard:$,callbackToken:i.callbackToken,rqt:F}}),n(i.nodeId,Fe),u.length>0&&r.executionRequestStore.appendEntries(e,u),"task-initiated"}}var jn={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function bc(t){return {[lt]:t.graph,[mc]:t.lastDrainedJournalId}}function kc(t){let e=t[lt],r=t[mc];if(!e||typeof e!="object")throw new Error(`State snapshot is missing required key: ${lt}`);return {graph:e,lastDrainedJournalId:typeof r=="string"?r:""}}function wc(t){let e=t.requires,r=t.provides?.map(n=>n.bindTo)??[];return {requires:e&&e.length>0?e:void 0,provides:r,taskHandlers:["card-handler"],description:t.meta?.title??t.id}}function Q(t){return t!==void 0?{status:"success",data:t}:{status:"success"}}function j(t){return {status:"fail",error:t}}function ee(t){return {status:"error",error:t instanceof Error?t.message:String(t)}}function pg(t){let e=new TextEncoder().encode(t),r=Array.from(e,n=>String.fromCharCode(n)).join("");return btoa(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function _c(t){let e=t.replace(/-/g,"+").replace(/_/g,"/"),r=e+"=".repeat((4-e.length%4)%4),n=atob(r),s=Uint8Array.from(n,o=>o.charCodeAt(0));return new TextDecoder().decode(s)}function Nn(t){try{let e=JSON.parse(_c(t));return typeof e?.t=="string"?{taskName:e.t}:null}catch{return null}}function mg(t){return pg(JSON.stringify(t))}function Sc(t){try{let e=JSON.parse(_c(t));return typeof e?.cbk=="string"&&typeof e?.cid=="string"&&typeof e?.b=="string"&&typeof e?.d=="string"?e:null}catch{return null}}function Ee(){return new Date().toISOString()}function jr(t,e){let r=e.onWarn??(()=>{}),n=ie(t);function s(R){if(R.length!==0)try{let v=e.publishBoardChangeNotifications?.(R);v&&typeof v.catch=="function"&&v.catch(x=>r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${x instanceof Error?x.message:String(x)}`));}catch(v){r(`[board-live-cards-public] publishBoardChangeNotifications failed: ${v instanceof Error?v.message:String(v)}`);}}function o(){let R=i().readCardStoreRef();if(!R)throw new Error(`Board at ${t.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let v=e.kvStorageForRef(R);return {readIndex(){return v.read("_index")},writeIndex(x){v.write("_index",x);},readCard(x){return v.read(x)},writeCard(x,A){return v.write(x,A),e.hashFn(A)},cardExists(x){return v.read(x)!==null},defaultCardKey(x){return x}}}let a={readValues(R){let v=e.kvStorage("state-snapshot"),x=v.listKeys().sort();if(x.length===0)return {version:null,values:{}};let A={};for(let Y of x)A[Y]=v.read(Y);return {version:e.hashFn(A),values:A}},writeValues(R,v,x){let A=e.kvStorage("state-snapshot");for(let Y of x)A.delete(Y);for(let[Y,te]of Object.entries(v))A.write(Y,te);return e.hashFn(v)}},i=()=>Mo(e.kvStorage("config")),u=()=>gc(a),c=()=>fc(e.journalAdapter()),d=()=>Pn(o(),r),l=()=>{let R=i().readOutputsStoreRef();if(!R)throw new Error(`Board at ${t.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return yc(e.kvStorageForRef(R))};function b(){return !!u().readSnapshot(t.value).values[lt]}function y(){let R=u().readSnapshot(t.value);if(!R.values[lt])throw new Error(`Board not initialized at ${t.value}`);return kc(R.values)}function m(R,v){let x=u().commitSnapshot(t.value,{schemaVersion:Or,expectedVersion:v,commitId:e.genId(),committedAt:Ee(),deleteKeys:[],shallowMerge:bc(R)});if(!x.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${v??"null"} current=${x.currentVersion??"null"}`)}function p(R){c().appendEvent(R);}async function k(){let R=(I,D)=>{let ae=I.payload,Qe=(ae?.enrichedCard??{}).id??ae?.cardId??"unknown";p({type:"task-failed",taskName:Qe,error:D,timestamp:Ee()});},v=pc(e.kvStorage("execution-requests"),R),x=hc(e.kvStorage("card-runtime")),A=Fo(e.blobStorage("sources"),I=>e.resolveBlob(I)),Y=new Map,te={readRuntime(I){return Y.get(I)??x.readRuntime(I)},writeRuntime(I,D){Y.set(I,D);}},Ce=[],$e=new Map,Ke={readSourceData(I,D){let ae=`${I}/${D}`;return $e.has(ae)?$e.get(ae):A.readSourceData(I,D)},ingestSourceDataStaged(I,D,ae,Pt){A.ingestSourceDataStaged(I,D,ae,Pt);},commitSourceData(I,D,ae){let Pt=`${I}/.staged/${ae}/${D}`,Fr=e.blobStorage("sources").read(Pt);if(Fr==null)return false;let Ot=`${I}/${D}`,Ko=Fr.trim();try{$e.set(Ot,JSON.parse(Ko));}catch{$e.set(Ot,Ko);}return Ce.push({cardId:I,outputFile:D,deliveryToken:ae}),true},hasSource(I,D){let ae=`${I}/${D}`;return $e.has(ae)?true:A.hasSource(I,D)}},Me={cardStore:d(),cardRuntimeStore:te,fetchedSourcesStore:Ke,outputStore:l(),executionRequestStore:v},mt=y(),ht=En(mt.graph),{events:At,newCursor:It}=c().readEntriesAfterCursor(mt.lastDrainedJournalId),gt=[],qn=[],Dn=[],Vo=new Map,Cc=(I,D)=>{gt.push({type:"task-completed",taskName:I,data:D,timestamp:Ee()});},Bo=(I,D)=>p({type:"task-failed",taskName:I,error:D,timestamp:Ee()}),qr=oc(ht,{handlers:{"card-handler":vc(t,It,Me,Cc,Bo,(I,D)=>{qn.push({cardId:I,values:D});},I=>{Dn.push(I);})}});for(gt=At;gt.length>0;){let I=gt;gt=[];for(let D of I)if(D.type==="task-restart"){let ae=Me.cardStore.readCard(D.taskName);ae&&Vo.set(D.taskName,ae);}qr.pushAll(I),await qr.waitForHandlers();}let Go=qr.getState();await qr.dispose({wait:true});let $c=u().readSnapshot(t.value).version;m({lastDrainedJournalId:It,graph:Ar(Go)},$c);for(let{cardId:I,values:D}of qn)Me.outputStore.writeComputedValues(I,D);for(let I of Dn)Me.outputStore.writeDataObjects(I);for(let[I,D]of Y)x.writeRuntime(I,D);for(let{cardId:I,outputFile:D,deliveryToken:ae}of Ce)A.commitSourceData(I,D,ae);let Dr;try{Dr=On(n,Go),Me.outputStore.writeStatusSnapshot(Dr);}catch(I){r(`[board-live-cards-public] status publish failed: ${I instanceof Error?I.message:String(I)}`);}let Xt=[];for(let{cardId:I,values:D}of qn)Xt.push({kind:"computed_values",cardId:I,values:D});for(let I of Dn)for(let[D,ae]of Object.entries(I))D&&Xt.push({kind:"data_object",key:D,payload:ae});for(let[I,D]of Vo)Xt.push({kind:"card_refreshed",cardId:I,card:D});Dr!==void 0&&Xt.push({kind:"status",status:Dr}),s(Xt);let xc=i().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:ie({kind:"built-in",value:"source-cli-task-executor"})};v.dispatchEntriesForJournalId(It,I=>{if(I.taskKind!=="source-fetch"){r(`[process-accumulated-events] unknown taskKind "${I.taskKind}" \u2014 skipping`);return}let D=I.payload,ae=D.enrichedCard?.id??"unknown",Pt=D.enrichedCard?.source_defs??[];for(let Qe of Pt){if(!Qe.outputFile){r(`[dispatch] source "${Qe.bindTo}" has no outputFile \u2014 skipping`);continue}let Fr=mg({cbk:D.callbackToken,rg:t.value,br:ie(t),cid:ae,b:Qe.bindTo,d:Qe.outputFile,cs:void 0,rqt:D.rqt});e.dispatchExecution(xc,{source_def:Qe,base_ref:ie(t),callback:{token:Fr,via:e.selfRef}}).catch(Ot=>Bo(ae,Ot instanceof Error?Ot.message:String(Ot)));}});}async function h(){try{let R=()=>{let x=y(),{events:A}=c().readEntriesAfterCursor(x.lastDrainedJournalId);A.length<=0||(h(),e.requestProcessAccumulated?.());},v=await Jo(e.lock,k,R);return Q({ran:v!==!1})}catch(R){return ee(R)}}function f(R){try{let v=R.params?.cardStoreRef;if(!v)return j("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!b()){let te=xn(jn);m({lastDrainedJournalId:"",graph:Ar(te)},null);}let x=R.params?.outputsStoreRef;if(!x)return j("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let A=i();A.writeCardStoreRef(v),A.writeOutputsStoreRef(x);let Y=R.body??{};Y["task-executor-ref"]&&A.writeTaskExecutorRef(Y["task-executor-ref"]),Y["chat-handler-ref"]&&A.writeChatHandlerRef(Y["chat-handler-ref"]);try{l().writeStatusSnapshot(On(n,En(y().graph)));}catch{}return Q()}catch(v){return ee(v)}}function g(R){try{let v=l().readStatusSnapshot();if(!v){v=On(n,En(y().graph));try{l().writeStatusSnapshot(v);}catch{}}return Q(v)}catch(v){return ee(v)}}function S(R){try{let v=R.params?.id;return v?(p({type:"task-removal",taskName:v,timestamp:Ee()}),h(),Q()):j("removeCard requires params.id")}catch(v){return ee(v)}}function w(R){try{let v=R.params?.id;return v?(p({type:"task-restart",taskName:v,timestamp:Ee()}),h(),Q()):j("retrigger requires params.id")}catch(v){return ee(v)}}async function C(R){return h()}function _(R){try{let v=R.params?.cardId,x=R.params?.all,A=!!R.params?.restart;if(!v&&!x)return j("upsertCard requires --card-id <id> or --all");let Y=x?d().readAllCards().map(te=>te.id):[v];for(let te of Y)if(!d().readCard(te))return j(`Card "${te}" not found in board at ${t.value}`);for(let te of Y){let Ce=d().readCard(te),$e=wc(Ce),Ke=e.hashFn($e),Me=e.kvStorage("card-upsert"),mt=Me.read(te),ht=mt?.taskConfigHash!==Ke;if(!(!ht&&!A)){if(ht){let At=mt?.blobRef??d().readCardKey(te)??te;p({type:"task-upsert",taskName:te,taskConfig:$e,timestamp:Ee()}),Me.write(te,{blobRef:At,taskConfigHash:Ke,updatedAt:Ee()});}A&&p({type:"task-restart",taskName:te,timestamp:Ee()});}}return h(),Q()}catch(v){return ee(v)}}function $(R){try{let v=R.params?.token;if(!v)return j("taskFailed requires params.token");let x=R.params?.error??"unknown error",A=Nn(v);return A?(p({type:"task-failed",taskName:A.taskName,error:x,timestamp:Ee()}),h(),Q()):j("Invalid callback token")}catch(v){return ee(v)}}function N(R){try{let v=R.params?.token;if(!v)return j("taskProgress requires params.token");let A=(R.body??{}).update??{},Y=Nn(v);return Y?(p({type:"task-progress",taskName:Y.taskName,update:A,timestamp:Ee()}),h(),Q()):j("Invalid callback token")}catch(v){return ee(v)}}function q(R){try{let v=R.params?.token,x=R.params?.ref;if(!v)return j("sourceDataFetched requires params.token");if(!x)return j("sourceDataFetched requires params.ref");let A=Sc(v);if(!A)return j("Invalid source token");let{cbk:Y,cid:te,b:Ce,d:$e,cs:Ke,rqt:Me}=A,mt=Fo(e.blobStorage("sources"),gt=>e.resolveBlob(gt)),ht=e.genId();mt.ingestSourceDataStaged(te,$e,ke(x),ht);let At=Nn(Y);if(!At)return j("Invalid callback token embedded in source token");let It=Ee();return p({type:"task-progress",taskName:At.taskName,update:{bindTo:Ce,outputFile:$e,fetchedAt:It,deliveryToken:ht,sourceChecksum:Ke,rqt:Me},timestamp:It}),h(),Q()}catch(v){return ee(v)}}function F(R){try{let v=R.params?.token,x=R.params?.reason??"unknown";if(!v)return j("sourceDataFetchFailure requires params.token");let A=Sc(v);if(!A)return j("Invalid source token");let{cbk:Y,b:te,d:Ce,cs:$e}=A,Ke=Nn(Y);return Ke?(p({type:"task-progress",taskName:Ke.taskName,update:{bindTo:te,outputFile:Ce,failure:!0,reason:x,sourceChecksum:$e},timestamp:Ee()}),h(),Q()):j("Invalid callback token embedded in source token")}catch(v){return ee(v)}}function re(R){try{let v=i().readCardStoreRef();return v?Q({storeRef:v}):j(`Board at ${t.value} has no card store configured`)}catch(v){return ee(v)}}function U(R){try{let v=i().readOutputsStoreRef();return v?Q({storeRef:v}):j(`Board at ${t.value} has no outputs store configured`)}catch(v){return ee(v)}}function de(R){try{let v=R.params?.key;if(!v)return j("getConfig requires params.key");let x=i(),A;switch(v){case "task-executor":A=x.readTaskExecutorRef()??null;break;case "chat-handler":A=x.readChatHandlerRef()??null;break;case "card-store-ref":A=x.readCardStoreRef();break;case "outputs-store-ref":A=x.readOutputsStoreRef();break;default:return j(`getConfig: unknown key "${v}"`)}return Q({value:A})}catch(v){return ee(v)}}function Fe(R){try{let v=R.params?.key;if(!v)return j("getOutputsDataObject requires params.key");let x=l().readDataObject(v);return Q(x)}catch(v){return ee(v)}}function pt(R){try{return Q(l().readAllDataObjects())}catch(v){return ee(v)}}function M(R){try{let v=R.params?.key;if(!v)return j("getOutputsComputedValues requires params.key");let x=l().readComputedValues(v);return Q(x)}catch(v){return ee(v)}}function V(R){try{return Q(l().readAllComputedValues())}catch(v){return ee(v)}}return {init:f,status:g,getCardStoreRef:re,getOutputsStoreRef:U,getConfig:de,getOutputsDataObject:Fe,getAllOutputsDataObjects:pt,getOutputsComputedValues:M,getAllOutputsComputedValues:V,removeCard:S,retrigger:w,processAccumulatedEvents:C,upsertCard:_,taskFailed:$,taskProgress:N,sourceDataFetched:q,sourceDataFetchFailure:F}}function ft(t,e){let r=()=>Mo(e.kvStorage("config"));function n(){let h=r().readCardStoreRef();if(!h)throw new Error(`Board at ${t.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let f=e.kvStorageForRef(h);return {readIndex(){return f.read("_index")},writeIndex(g){f.write("_index",g);},readCard(g){return f.read(g)},writeCard(g,S){return f.write(g,S),e.hashFn(S)},cardExists(g){return f.read(g)!==null},defaultCardKey(g){return g}}}let s=()=>Pn(n(),e.onWarn??(()=>{}));function o(h,f){let g=e.validateSchema(f),S=[],w=r().readTaskExecutorRef();if(w&&Array.isArray(f.source_defs))for(let _ of f.source_defs){let $=typeof _.bindTo=="string"?_.bindTo:"(unknown)";try{let N;try{N=e.invokeExecutorSync(w,"validate-source-def",[],{timeout:e.executorTimeouts?.validationMs??1e4,input:JSON.stringify(_)});}catch(F){let re=F;if(N=typeof re?.stdout=="string"?re.stdout:"",!N.trim()){S.push(`source "${$}": executor validate-source-def failed \u2014 ${F instanceof Error?F.message:String(F)}`);continue}}let q=JSON.parse(N.trim());if(!q.ok&&Array.isArray(q.errors))for(let F of q.errors)S.push(`source "${$}": ${F}`);}catch(N){S.push(`source "${$}": executor validate-source-def failed \u2014 ${N instanceof Error?N.message:String(N)}`);}}let C=[...g.errors,...S];return Q({cardId:h,isValid:C.length===0,issues:C})}function a(h,f,g){let S=r().readTaskExecutorRef();if(!S)return j("No task-executor registered for this board");let w=typeof h.bindTo=="string"?h.bindTo:"source",C=e.makeTempFilePath(`probe-in-${w}`),_=e.makeTempFilePath(`probe-out-${w}`),$=e.makeTempFilePath(`probe-err-${w}`,".txt"),N={...h,boardDir:t.value,_projections:f},q=ie({kind:"fs-path",value:C}),F=ie({kind:"fs-path",value:_}),re=ie({kind:"fs-path",value:$});e.absoluteBlob.write(C,JSON.stringify(N,null,2));let U=null;try{if(e.invokeExecutorSync(S,"run-source-fetch",["--in-ref",q,"--out-ref",F,"--err-ref",re],{timeout:h.timeout??e.executorTimeouts?.probeMs??6e4}),U=e.absoluteBlob.read(_),U===null)return j("Executor produced no output file")}catch(de){let Fe=e.absoluteBlob.read($)?.trim()??(de instanceof Error?de.message:String(de));return j(`Probe failed: ${Fe}`)}finally{try{e.absoluteBlob.remove(C);}catch{}try{e.absoluteBlob.remove($);}catch{}}if(g){let de=ke(g);e.absoluteBlob.write(de.value,U);}else try{e.absoluteBlob.remove(_);}catch{}return Q({bindTo:w,resultSizeBytes:U.length})}function i(h){try{let f=h.params?.cardId,g=h.params?.all;if(!f&&!g)return j("validateCard requires --card-id <id> or --all");let S=g?s().readAllCards().map(C=>C.id):[f],w=[];for(let C of S){let _=s().readCard(C);if(!_){w.push({cardId:C,isValid:!1,issues:[`Card "${C}" not found`]});continue}let $=o(C,_);if($.status!=="success")return $;w.push($.data);}return Q(w)}catch(f){return ee(f)}}function u(h){try{if(!h.body||typeof h.body!="object"||Array.isArray(h.body))return j("validateCardPreflight requires card JSON object in body");let f=h.body,g=f["card-content"]??f,S=typeof g.id=="string"?g.id:"(unknown)",w=o(S,g),C=r().readTaskExecutorRef();if(C)try{let _=e.invokeExecutorSync(C,"validate-card-preflight",[],{timeout:e.executorTimeouts?.validationMs??1e4,input:JSON.stringify(g)}),$=JSON.parse(_.trim());if(!$.ok&&Array.isArray($.errors)&&$.errors.length>0){let N=[...w.status==="success"?w.data.issues:[],...$.errors];return Q({cardId:S,isValid:!1,issues:N})}}catch{}return w}catch(f){return ee(f)}}function c(h){try{let f=h.params?.cardId,g=h.params?.sourceIdx,S=h.params?.outRef;if(!f)return j("probeSource requires params.cardId");if(g===void 0)return j("probeSource requires params.sourceIdx");let C=(h.body??{})["mock-projections"]??{},_=s().readCard(f);if(!_)return j(`Card "${f}" not found`);let $=_.source_defs??[];return g<0||g>=$.length?j(`sourceIdx ${g} out of range (card has ${$.length} source(s))`):a($[g],C,S)}catch(f){return ee(f)}}function d(h){try{let f=h.params?.outRef,g=h.body;if(!g)return j('probeTmpSource requires body with "source-def" and "mock-projections"');let S=g["source-def"],w=g["mock-projections"]??{};return S?a(S,w,f):j('probeTmpSource body requires "source-def"')}catch(f){return ee(f)}}function l(h){try{let f=h.params?.sourceIdx,g=h.params?.outRef;if(f===void 0)return j("probeSourcePreflight requires params.sourceIdx");if(!h.body||typeof h.body!="object"||Array.isArray(h.body))return j("probeSourcePreflight requires card JSON object in body");let S=h.body,w=S["card-content"]??S,C=S["mock-projections"]??{},_=w.source_defs??[];if(f<0||f>=_.length)return j(`sourceIdx ${f} out of range (card has ${_.length} source(s))`);let $=_[f],N=r().readTaskExecutorRef();if(N){let q=typeof $.bindTo=="string"?$.bindTo:"source";try{let F={...$,_projections:C},re=e.invokeExecutorSync(N,"probe-source-preflight",[],{timeout:$.timeout??e.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(F)}),U=JSON.parse(re.trim());return U.ok?Q({bindTo:q,reachable:U.reachable,latencyMs:U.latencyMs,note:U.note}):j(U.error??"Preflight probe failed")}catch{}}return a($,C,g)}catch(f){return ee(f)}}function b(h){try{let f=r().readTaskExecutorRef();if(!f)return j("No task-executor registered for this board");let g=e.invokeExecutorSync(f,"describe-capabilities",[],{timeout:e.executorTimeouts?.describeMs??1e4});return Q(JSON.parse(g.trim()))}catch(f){return ee(f)}}function y(h){try{let f=h.body;if(!f||!Array.isArray(f.ops))return j("updatesInCardStore requires body.ops array");let g=f.ops,S=s();for(let w of g){let C=w.op,_=w.id;if(!_)return j('op is missing "id"');if(C==="update"){let $=w["card-content"];if(!$)return j(`update op for "${_}" is missing "card-content"`);S.writeCard(_,$);}else return j(`Unknown op type: "${C??"(none)"}"`)}return Q()}catch(f){return ee(f)}}function m(h){try{let f=h.body;if(!f||!Array.isArray(f.ids))return j("readFromCardStore requires body.ids array");let g=f.ids,S=s(),w=g.map(C=>({id:C,"card-content":S.readCard(C)}));return Q({cards:w})}catch(f){return ee(f)}}function p(h){try{if(!h.body||typeof h.body!="object"||Array.isArray(h.body))return j("evalCardCompute requires a JSON object in body");let f=h.body,g=f["card-content"]??f,S=typeof g.id=="string"?g.id:"(unknown)",w=f["mock-fetched-sources"]??{},C=f["mock-requires"]??{},_=g.compute;if(!_||!Array.isArray(_)||_.length===0)return Q({cardId:S,ok:!0,computed_values:{},errors:[]});let $={id:S,card_data:g.card_data??{},requires:C,source_defs:g.source_defs,compute:_},N=dt.runSync($,{sourcesData:w}),q=N.node.computed_values??{},F=N.errors??[];return Q({cardId:S,ok:F.length===0,computed_values:q,errors:F})}catch(f){return ee(f)}}function k(h){try{if(!h.body||typeof h.body!="object"||Array.isArray(h.body))return j("simulateCardCycle requires a JSON object in body");let f=h.body,g=f["card-content"]??f,S=typeof g.id=="string"?g.id:"(unknown)",w=f["mock-fetched-sources"]??{},C=f["mock-requires"]??{},_=o(S,g),$=_.status==="success"?{isValid:_.data.isValid,issues:_.data.issues}:{isValid:!1,issues:[_.status==="fail"?_.error:"internal error"]},N=g.source_defs??[],q=g.card_data??{},F=[],re=[];if(N.length>0){F=dt.enrichSourcesSync(N,{card_data:q,requires:C});for(let v of F){let x=v.projections,A=v._projections;if(x&&A){for(let Y of Object.keys(x))if(A[Y]===void 0){let te=typeof v.bindTo=="string"?v.bindTo:"(unknown)";re.push({bindTo:te,key:Y,error:`Projection "${Y}" resolved to undefined`});}}}}let U=[],de=f["task-executor-ref"],Fe=(de?.howToRun&&de?.whatToRun?de:void 0)??r().readTaskExecutorRef();for(let v=0;v<F.length;v++){let x=F[v],A=typeof x.bindTo=="string"?x.bindTo:`source_${v}`;if(!Fe){U.push({bindTo:A,skipped:!0,error:"No task executor configured"});continue}try{let Y={...x},te=e.invokeExecutorSync(Fe,"probe-source-preflight",[],{timeout:x.timeout??e.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(Y)}),Ce=JSON.parse(te.trim());U.push({bindTo:A,reachable:Ce.reachable,latencyMs:Ce.latencyMs,error:Ce.ok?void 0:Ce.error});}catch{U.push({bindTo:A,skipped:!0,error:"Executor does not support probe-source-preflight"});}}let pt=g.compute,M={},V=[];if(pt&&Array.isArray(pt)&&pt.length>0){let v={id:S,card_data:q,requires:C,source_defs:g.source_defs,compute:pt},x=dt.runSync(v,{sourcesData:w});M=x.node.computed_values??{},V=x.errors??[];}let R=$.isValid&&re.length===0&&V.length===0&&U.every(v=>v.reachable!==!1);return Q({cardId:S,ok:R,validation:$,source_probes:U,projection_errors:re,computed_values:M,compute_errors:V})}catch(f){return ee(f)}}return {validateCard:i,validateCardPreflight:u,probeSource:c,probeTmpSource:d,probeSourcePreflight:l,evalCardCompute:p,simulateCardCycle:k,describeTaskExecutorCapabilities:b,updatesInCardStore:y,readFromCardStore:m}}var hg=".board.lock";function gg(t,e){return typeof t=="string"?{cliDir:t,opts:e}:{cliDir:void 0,opts:t}}function yg(t,e){return typeof t=="string"?{cliDir:t,opts:e}:{cliDir:void 0,opts:t}}function Rc(t){if(t)return t;let e=Vr(import.meta.url),r=[e,jt(e,"..","cli","node"),jt(e,"..","..","cli","node")];for(let n of r)try{return Bn(n),n}catch{}throw new Error(`createFsBoardPlatformAdapter: could not resolve a public CLI directory from module dir ${e}`)}function Nr(t,e,r){let{cliDir:n,opts:s}=gg(e,r),o=Rc(n),a=t.value,i=s?.suppressSpawn?"":Bn(o),u={meta:"board-live-cards",howToRun:"local-node",whatToRun:i?ie({kind:"fs-path",value:i}):"",...s?.notifyChannel?{extra:{notifyChannel:s.notifyChannel}}:{}};return {kvStorage:c=>Hn(jt(a,`.${c}`)),blobStorage:c=>c?Gr(jt(a,c)):Gr(a),journalAdapter:()=>da(a),lock:la(jt(a,hg)),selfRef:u,async dispatchExecution(c,d){if(s?.suppressSpawn)return {dispatched:false};try{let l=d.source_def?.bindTo??Mn().slice(0,8),b=Qt(a,`exec-in-${l}`),y=Qt(a,`exec-out-${l}`),m=Qt(a,`exec-err-${l}`,".txt"),p=ie({kind:"fs-path",value:b}),k=ie({kind:"fs-path",value:y}),h=ie({kind:"fs-path",value:m});return ua({kind:"fs-path",value:b}).write(b,JSON.stringify(d,null,2)),ia(c,{subcommand:"run-source-fetch",inRef:p,outRef:k,errRef:h},o),{dispatched:!0}}catch(l){return {dispatched:false,error:l instanceof Error?l.message:String(l)}}},resolveBlob(c){let d=Yo(c.value)?Jn().read(c.value):Gr(a).read(c.value);if(d===null)throw new Error(`resolveBlob: blob not found: ::${c.kind}::${c.value}`);return d},hashFn:ca,genId:()=>Xo(`${Date.now()}-${Math.random()}`).slice(0,32),kvStorageForRef:c=>Hn(ke(c).value),requestProcessAccumulated(){s?.suppressSpawn||ea(o,t,s?.notifyChannel);},publishBoardChangeNotifications(c){if(!s?.notifyChannel||c.length===0)return;let d=c.map(l=>({id:Mn(),ts:new Date().toISOString(),boardRef:ie(t),notification:l}));ta(s.notifyChannel,d,s.onWarn);},onWarn:s?.onWarn}}function Et(t,e,r){let{cliDir:n,opts:s}=yg(e,r),o=Rc(n),a=Nr(t,o,s),i=Gn();return {...a,invokeExecutorSync(u,c,d,l){let{command:b,baseArgs:y}=aa(u,o),m=u.extra?["--extra",Buffer.from(JSON.stringify(u.extra)).toString("base64")]:[];return i.executeSync(b,[...y,c,...d,...m],{timeout:l?.timeout??3e4,encoding:"utf-8",input:l?.input})},validateSchema(u){let c=jo(u);return {ok:c.errors.length===0,errors:c.errors}},makeTempFilePath(u,c){return Qt(t.value,u,c)},absoluteBlob:Jn()}}function Lo(t){try{let e=JSON.parse(Buffer.from(t,"base64url").toString());return typeof e.br=="string"?e.br:null}catch{return null}}var Ye=Vr(import.meta.url);function ge(t,e,r){let n=t.indexOf(e),s=n!==-1?t[n+1]:void 0;if(!s)throw new Error(`Missing ${e}
14
14
  Usage: ${r}`);return s}function Xe(t,e){let r=t.indexOf(e);return r!==-1?t[r+1]:void 0}function oe(t){console.log(JSON.stringify(t,null,2));}async function Tt(){if(process.stdin.isTTY)return;let t=[];for await(let r of process.stdin)t.push(Buffer.isBuffer(r)?r:Buffer.from(r));let e=Buffer.concat(t).toString("utf-8").trim();if(e)return JSON.parse(e)}async function vg(t){let e=t[0],r=t.slice(1);if(e==="help"||e==="--help"||e==="-h"){console.log("board-live-cards \u2014 see board-live-cards-cli-PARAMS.md for command reference");return}let n=Xe(r,"--base-ref"),s=Xe(r,"--notify-channel"),o=n?ke(n):void 0;if(e==="source-data-fetched"){let u=ge(r,"--token","source-data-fetched --token <token> --ref <sourcefile>"),c=ge(r,"--ref","source-data-fetched --token <token> --ref <sourcefile>"),d=Lo(u);if(!d)throw new Error("source-data-fetched: could not decode board ref from token \u2014 is this a valid source token?");let l=ke(d),b=jr(l,Nr(l,Ye,{onWarn:console.warn,notifyChannel:s}));oe(b.sourceDataFetched({params:{token:u,ref:c}}));return}if(e==="source-data-fetch-failure"){let u=ge(r,"--token","source-data-fetch-failure --token <token> [--reason <message>]"),c=Lo(u);if(!c)throw new Error("source-data-fetch-failure: could not decode board ref from token \u2014 is this a valid source token?");let d=ke(c),l=jr(d,Nr(d,Ye,{onWarn:console.warn,notifyChannel:s})),b={token:u},y=Xe(r,"--reason");y&&(b.reason=y),oe(l.sourceDataFetchFailure({params:b}));return}if(e==="validate-card-preflight"){let u=o??{kind:"fs-path",value:Ze(".")},c=ft(u,Et(u,Ye,{onWarn:console.warn})),d=await Tt();oe(c.validateCardPreflight({body:d}));return}if(e==="probe-source-preflight"){let u=ge(r,"--source-idx","probe-source-preflight --source-idx <n>"),c=Xe(r,"--out-ref"),d=o??{kind:"fs-path",value:Ze(".")},l=ft(d,Et(d,Ye,{onWarn:console.warn})),b=await Tt(),y={sourceIdx:parseInt(u,10)};c&&(y.outRef=c),oe(l.probeSourcePreflight({params:y,body:b}));return}if(e==="eval-card-compute"){let u=o??{kind:"fs-path",value:Ze(".")},c=ft(u,Et(u,Ye,{onWarn:console.warn})),d=await Tt();oe(c.evalCardCompute({body:d}));return}if(e==="simulate-card-cycle"){let u=o??{kind:"fs-path",value:Ze(".")},c=ft(u,Et(u,Ye,{onWarn:console.warn})),d=await Tt();oe(c.simulateCardCycle({body:d}));return}if(e==="probe-tmp-source"){let u=ge(r,"--out-ref","probe-tmp-source --out-ref <ref>"),c=o??{kind:"fs-path",value:Ze(".")},d=ft(c,Et(c,Ye,{onWarn:console.warn})),l=await Tt();oe(d.probeTmpSource({params:{outRef:u},body:l}));return}if(!o)throw new Error(`--base-ref is required for command "${e??"(none)"}"`);let a=()=>jr(o,Nr(o,Ye,{onWarn:console.warn,notifyChannel:s})),i=()=>ft(o,Et(o,Ye,{onWarn:console.warn}));switch(e){case "init":{let u=ge(r,"--card-store-ref","init --base-ref <ref> --card-store-ref <b64-ref> --outputs-store-ref <b64-ref>"),c=ge(r,"--outputs-store-ref","init --base-ref <ref> --card-store-ref <b64-ref> --outputs-store-ref <b64-ref>"),d=await Tt();oe(a().init({params:{cardStoreRef:u,outputsStoreRef:c},body:d}));return}case "status":{oe(a().status({}));return}case "get-card-store-ref":{oe(a().getCardStoreRef({}));return}case "get-outputs-store-ref":{oe(a().getOutputsStoreRef({}));return}case "get-outputs":{let u=ge(r,"--type","get-outputs --base-ref <ref> --type <data-object|computed-values> [--key <key>] [--all]"),c=r.includes("--all");if(u==="data-object")if(c)oe(a().getAllOutputsDataObjects({}));else {let d=ge(r,"--key","get-outputs --type data-object --base-ref <ref> --key <datakey>");oe(a().getOutputsDataObject({params:{key:d}}));}else if(u==="computed-values")if(c)oe(a().getAllOutputsComputedValues({}));else {let d=ge(r,"--key","get-outputs --type computed-values --base-ref <ref> --key <card-id>");oe(a().getOutputsComputedValues({params:{key:d}}));}else throw new Error(`get-outputs: unknown --type "${u}", expected data-object | computed-values`);return}case "remove-card":{let u=ge(r,"--id","remove-card --base-ref <ref> --id <card-id>");oe(a().removeCard({params:{id:u}}));return}case "retrigger":{let u=ge(r,"--id","retrigger --base-ref <ref> --id <card-id>");oe(a().retrigger({params:{id:u}}));return}case "process-accumulated-events":{oe(await a().processAccumulatedEvents({}));return}case "upsert-card":{let u=Xe(r,"--card-id"),c=r.includes("--all"),d=r.includes("--restart");if(!u&&!c)throw new Error("upsert-card requires --card-id <id> or --all");let l={};u&&(l.cardId=u),c&&(l.all=true),d&&(l.restart=true),oe(a().upsertCard({params:l}));return}case "task-failed":{let c={token:ge(r,"--token","task-failed --base-ref <ref> --token <token> [--error <message>]")},d=Xe(r,"--error");d&&(c.error=d),oe(a().taskFailed({params:c}));return}case "task-progress":{let u=ge(r,"--token","task-progress --base-ref <ref> --token <token> [--update <json>]"),c=Xe(r,"--update"),d=c?JSON.parse(c):{};oe(a().taskProgress({params:{token:u},body:{update:d}}));return}case "validate-card":{let u=Xe(r,"--card-id"),c=r.includes("--all");if(!u&&!c)throw new Error("validate-card requires --card-id <id> or --all");let d={};u&&(d.cardId=u),c&&(d.all=true),oe(i().validateCard({params:d}));return}case "probe-source":{let u=ge(r,"--card-id","probe-source --base-ref <ref> --card-id <id> --source-idx <n> --out-ref <ref>"),c=ge(r,"--source-idx","probe-source --base-ref <ref> --card-id <id> --source-idx <n> --out-ref <ref>"),d=Xe(r,"--out-ref"),l=await Tt(),b={cardId:u,sourceIdx:parseInt(c,10)};d&&(b.outRef=d),oe(i().probeSource({params:b,body:l}));return}case "describe-task-executor-capabilities":{oe(i().describeTaskExecutorCapabilities({}));return}default:throw new Error(`Unknown command: ${e??"(none)"}`)}}var bg=process.argv[1]&&Ze(process.argv[1])===Ze(new URL(import.meta.url).pathname.replace(/^\/([A-Z]:)/,"$1"));bg&&vg(process.argv.slice(2)).catch(t=>{let e=t instanceof Error?t.message:String(t);console.error(e),process.exit(1);});export{vg as cli};//# sourceMappingURL=board-live-cards-cli.js.map
15
15
  //# sourceMappingURL=board-live-cards-cli.js.map