yaml-flow 8.11.7 → 8.11.8

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.
Files changed (74) hide show
  1. package/browser/asset-integrity.json +5 -5
  2. package/browser/live-cards.schema.json +4 -0
  3. package/browser/server-runtime-controlface.js +4 -4
  4. package/examples/board/cards/card-rebalance-sim.json +4 -1
  5. package/lib/board-live-cards-mcp.cjs +1 -1
  6. package/lib/board-live-cards-mcp.js +1 -1
  7. package/lib/board-live-cards-node.cjs +6 -6
  8. package/lib/board-live-cards-node.js +6 -6
  9. package/lib/board-live-cards-public.cjs +1 -1
  10. package/lib/board-live-cards-public.js +1 -1
  11. package/lib/board-live-cards-server-runtime.cjs +1 -1
  12. package/lib/board-live-cards-server-runtime.js +1 -1
  13. package/lib/board-livegraph-runtime/index.cjs +1 -1
  14. package/lib/board-livegraph-runtime/index.js +1 -1
  15. package/lib/card-compute/index.cjs +1 -1
  16. package/lib/card-compute/index.d.cts +6 -0
  17. package/lib/card-compute/index.d.ts +6 -0
  18. package/lib/card-compute/index.js +1 -1
  19. package/lib/card-store-public.cjs +1 -1
  20. package/lib/card-store-public.js +1 -1
  21. package/lib/card-validation.cjs +1 -1
  22. package/lib/card-validation.js +1 -1
  23. package/lib/{chunk-NOAERAOE.cjs → chunk-36KKCQVE.cjs} +2 -2
  24. package/lib/chunk-3DWVFRQD.cjs +3 -0
  25. package/lib/chunk-3SLSRX6Q.js +3 -0
  26. package/lib/{chunk-EHREWADE.js → chunk-4NWVZ7AW.js} +2 -2
  27. package/lib/chunk-543ZEGP7.cjs +2 -0
  28. package/lib/{chunk-YAPTL2MP.cjs → chunk-6SPWFJRG.cjs} +2 -2
  29. package/lib/{chunk-HKPVF5UI.js → chunk-BA25VGJP.js} +3 -3
  30. package/lib/chunk-BRYV6CDD.js +3 -0
  31. package/lib/chunk-EGZPROOH.cjs +3 -0
  32. package/lib/{chunk-GHUW6P4G.cjs → chunk-ESTFYRHF.cjs} +2 -2
  33. package/lib/{chunk-52XPRCZC.cjs → chunk-HOS2ZUFZ.cjs} +2 -2
  34. package/lib/chunk-JOQWJ3VR.cjs +2 -0
  35. package/lib/chunk-MRESV3MD.js +2 -0
  36. package/lib/chunk-MRIFSG7L.cjs +3 -0
  37. package/lib/{chunk-6M3RIGUH.js → chunk-NN52BT3Q.js} +2 -2
  38. package/lib/{chunk-TUQ6JBER.cjs → chunk-OR6B2H2Y.cjs} +3 -3
  39. package/lib/{chunk-I3ZOFU3F.js → chunk-PIPXFUEA.js} +2 -2
  40. package/lib/chunk-REZO2QJD.js +3 -0
  41. package/lib/{chunk-23PEDGFN.js → chunk-ROIYEFSE.js} +2 -2
  42. package/lib/chunk-UJQ7IML5.js +2 -0
  43. package/lib/chunk-YOY2JM5N.js +2 -0
  44. package/lib/chunk-ZV35WD6K.cjs +2 -0
  45. package/lib/cloud-storage.cjs +1 -1
  46. package/lib/cloud-storage.js +1 -1
  47. package/lib/continuous-event-graph/index.cjs +1 -1
  48. package/lib/continuous-event-graph/index.js +1 -1
  49. package/lib/firestore-storage/index.cjs +1 -1
  50. package/lib/firestore-storage/index.js +1 -1
  51. package/lib/index.cjs +2 -2
  52. package/lib/index.js +1 -1
  53. package/lib/localstorage-storage/index.cjs +1 -1
  54. package/lib/localstorage-storage/index.js +1 -1
  55. package/lib/server-runtime/index.cjs +1 -1
  56. package/lib/server-runtime/index.js +1 -1
  57. package/lib/server-runtime-controlface/index.cjs +1 -1
  58. package/lib/server-runtime-controlface/index.js +1 -1
  59. package/lib/server-runtime-core/index.cjs +1 -1
  60. package/lib/server-runtime-core/index.js +1 -1
  61. package/package.json +1 -1
  62. package/schema/live-cards.schema.json +4 -0
  63. package/lib/chunk-2LGCYN35.js +0 -2
  64. package/lib/chunk-3XPY7CCM.cjs +0 -3
  65. package/lib/chunk-ATOQP3BD.js +0 -2
  66. package/lib/chunk-CPJXGK2T.cjs +0 -2
  67. package/lib/chunk-J7KE7SPA.cjs +0 -2
  68. package/lib/chunk-K5TEZRZK.cjs +0 -3
  69. package/lib/chunk-QBEQL4TL.cjs +0 -2
  70. package/lib/chunk-QEHKMLHA.cjs +0 -3
  71. package/lib/chunk-RKLEBQUG.js +0 -3
  72. package/lib/chunk-WGYS2L4V.js +0 -2
  73. package/lib/chunk-X32SJDLT.js +0 -3
  74. package/lib/chunk-YT76JNKE.js +0 -3
@@ -1,2 +0,0 @@
1
- import {createRequire}from'module';var g=createRequire(import.meta.url),u=g("./jsonata-sync.cjs"),p=u;function c(r,t){if(!t||!r)return;let s=t.split("."),e=r;for(let n=0;n<s.length;n++){if(e==null)return;e=e[s[n]];}return e}function f(r,t,s){let e=t.split("."),n=r;for(let o=0;o<e.length-1;o++)(n[e[o]]==null||typeof n[e[o]]!="object")&&(n[e[o]]={}),n=n[e[o]];n[e[e.length-1]]=s;}async function m(r,t){if(!r?.compute?.length)return r;r.card_data||(r.card_data={}),r.computed_values={},r._sourcesData=t?.sourcesData??{};let s=r.requires??{},e={card_data:r.card_data,requires:s,expects_data:s,fetched_sources:r._sourcesData,data:r.computed_values,computed_values:r.computed_values};for(let n of r.compute)try{let o=await u(n.expr).evaluate(e);f(r.computed_values,n.bindTo,o),e.computed_values=r.computed_values;}catch{}return r}function y(r,t){if(!r?.compute?.length)return {ok:true,node:r};r.card_data||(r.card_data={}),r.computed_values={},r._sourcesData=t?.sourcesData??{};let s=r.requires??{},e={card_data:r.card_data,requires:s,expects_data:s,fetched_sources:r._sourcesData,data:r.computed_values,computed_values:r.computed_values},n=[];for(let o of r.compute)try{let i=p(o.expr).evaluate(e);f(r.computed_values,o.bindTo,i),e.computed_values=r.computed_values;}catch(i){let a=i instanceof Error?i.message:String(i);n.push({bindTo:o.bindTo,error:a});}return n.length>0?{ok:true,node:r,errors:n}:{ok:true,node:r}}async function b(r,t,s){let e={...s??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return u(r).evaluate(e)}function _(r,t){return t.startsWith("fetched_sources.")?c(r._sourcesData??{},t.slice(16)):c(r,t)}var d=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),v=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function h(r){let t=[];if(!r||typeof r!="object"||Array.isArray(r))return {ok:false,errors:["Node must be a non-null object"]};let s=r;(typeof s.id!="string"||!s.id)&&t.push("id: required, must be a non-empty string");for(let e of Object.keys(s))v.has(e)||t.push(`Unknown top-level key: "${e}"`);if((s.card_data==null||typeof s.card_data!="object"||Array.isArray(s.card_data))&&t.push("card_data: required, must be an object"),s.meta!=null)if(typeof s.meta!="object"||Array.isArray(s.meta))t.push("meta: must be an object");else {let e=s.meta;e.title!=null&&typeof e.title!="string"&&t.push("meta.title: must be a string"),e.tags!=null&&!Array.isArray(e.tags)&&t.push("meta.tags: must be an array");}if(s.requires!=null&&!Array.isArray(s.requires)&&t.push("requires: must be an array of strings"),s.provides!=null&&(Array.isArray(s.provides)?s.provides.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))t.push(`provides[${n}]: must be an object with bindTo and ref`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&t.push(`provides[${n}]: missing required "bindTo" string`),(typeof o.ref!="string"||!o.ref)&&t.push(`provides[${n}]: missing required "ref" string`);}}):t.push("provides: must be an array of { bindTo, ref } bindings")),s.compute!=null&&(Array.isArray(s.compute)?s.compute.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))t.push(`compute[${n}]: must be a compute step object`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&t.push(`compute[${n}]: missing required "bindTo" property`),(typeof o.expr!="string"||!o.expr)&&t.push(`compute[${n}]: missing required "expr" string (JSONata expression)`);}}):t.push("compute: must be an array of compute steps")),s.source_defs!=null)if(!Array.isArray(s.source_defs))t.push("source_defs: must be an array");else {let e=new Set,n=new Set;s.source_defs.forEach((o,i)=>{if(!o||typeof o!="object"||Array.isArray(o))t.push(`source_defs[${i}]: must be an object`);else {let a=o;typeof a.bindTo!="string"||!a.bindTo?t.push(`source_defs[${i}]: missing required "bindTo" property`):(e.has(a.bindTo)&&t.push(`source_defs[${i}]: bindTo "${a.bindTo}" is not unique across source_defs`),e.add(a.bindTo)),typeof a.outputFile!="string"||!a.outputFile?t.push(`source_defs[${i}]: missing required "outputFile" property`):(n.has(a.outputFile)&&t.push(`source_defs[${i}]: outputFile "${a.outputFile}" is not unique across source_defs`),n.add(a.outputFile));}});}if(s.view!=null)if(typeof s.view!="object"||Array.isArray(s.view))t.push("view: must be an object");else {let e=s.view;!Array.isArray(e.elements)||e.elements.length===0?t.push("view.elements: required, must be a non-empty array"):e.elements.forEach((n,o)=>{if(!n||typeof n!="object"){t.push(`view.elements[${o}]: must be an object`);return}!n.kind||typeof n.kind!="string"?t.push(`view.elements[${o}].kind: required, must be a string`):d.has(n.kind)||t.push(`view.elements[${o}].kind: unknown kind "${n.kind}". Valid: ${[...d].join(", ")}`),n.data!=null&&(typeof n.data!="object"||Array.isArray(n.data))&&t.push(`view.elements[${o}].data: must be an object`);});}return {ok:t.length===0,errors:t}}async function k(r,t){if(!r||r.length===0)return [];let s={card_data:t.card_data??{},requires:t.requires??{}};return Promise.all(r.map(async e=>{let n={};if(e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[o,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{n[o]=await u(i).evaluate(s);}catch{n[o]=void 0;}}return {...e,_projections:n}}))}function w(r,t){if(!r||r.length===0)return [];let s={card_data:t.card_data??{},requires:t.requires??{}};return r.map(e=>{let n={};if(e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[o,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{n[o]=p(i).evaluate(s);}catch{n[o]=void 0;}}return {...e,_projections:n}})}var j={run:m,runSync:y,eval:b,resolve:_,validate:h,enrichSources:k,enrichSourcesSync:w},$=j;export{j as a,$ as b};//# sourceMappingURL=chunk-ATOQP3BD.js.map
2
- //# sourceMappingURL=chunk-ATOQP3BD.js.map
@@ -1,2 +0,0 @@
1
- 'use strict';var chunkQEHKMLHA_cjs=require('./chunk-QEHKMLHA.cjs');function s(r){let e=chunkQEHKMLHA_cjs.d(r);return {isValid:e.ok,issues:e.errors}}exports.a=s;//# sourceMappingURL=chunk-CPJXGK2T.cjs.map
2
- //# sourceMappingURL=chunk-CPJXGK2T.cjs.map
@@ -1,2 +0,0 @@
1
- 'use strict';var chunk7JVHYHT2_cjs=require('./chunk-7JVHYHT2.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkVI36DRWG_cjs=require('./chunk-VI36DRWG.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function L(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function J(e,r){return L(e)?e.then(r):r(e)}function Z(e,r){let t={...e};for(let o of r.deleteKeys)delete t[o];return {...t,...r.shallowMerge}}function Re(e,r){return {readValues(o){let n=e(o);return J(n.listKeys(),s=>{let a=[...s].sort();if(a.length===0)return {version:null,values:{}};let i={},c=null;for(let g of a){let d=n.read(g);L(d)?c=(c??Promise.resolve()).then(async()=>{i[g]=await d;}):i[g]=d;}return c?c.then(()=>({version:r(i),values:i})):{version:r(i),values:i}})},writeValues(o,n,s){let a=e(o),i=null;for(let c of s){let g=a.delete(c);L(g)&&(i=(i??Promise.resolve()).then(()=>g).then(()=>{}));}for(let[c,g]of Object.entries(n)){let d=a.write(c,g);L(d)&&(i=(i??Promise.resolve()).then(()=>d).then(()=>{}));}return i?i.then(()=>r(n)):r(n)}}}function ee(e,r){return {readSnapshot(t){return e.readValues(t)},commitSnapshot(t,o){if(o.schemaVersion!==r)throw new Error(`Unsupported snapshot schema version: ${o.schemaVersion}`);return J(e.readValues(t),n=>{if(n.version!==o.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let s=Z(n.values,o);return J(e.writeValues(t,s,o.deleteKeys),a=>({ok:true,newVersion:a}))})}}}function X(e,r){if(!r)return e;let t=e.findIndex(o=>o.id===r);return t===-1?e:e.slice(t+1)}function te(e){return {readEntriesAfterCursor(r){let t=X(e.readAllEntries(),r);return t.length===0?{events:[],newCursor:r}:{events:t.map(o=>o.event),newCursor:t[t.length-1].id}},pendingCount(r){return X(e.readAllEntries(),r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function ve(e){return {appendEvent(r){return e.append(r).then(()=>{})},async readEntriesAfterCursor(r){let t=await e.readAfter(r||null);return {events:t.entries.map(o=>o.payload),newCursor:t.newCursor??r}}}}function j(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function v(e,r){return j(e)?e.then(r):r(e)}function M(e,r){let t=null;for(let o of e){if(t){t=t.then(()=>r(o)).then(()=>{});continue}let n=r(o);j(n)&&(t=Promise.resolve(n).then(()=>{}));}return t??void 0}function le(e){if(e==null)return null;let r=e.trim();if(!r)return null;try{return JSON.parse(r)}catch{return r}}function pe(e,r){let t=e.match(r);return t?t[1]:null}function re(e,r,t){let o={},n=M(e,s=>{let a=t(s);if(a)return v(r(s),i=>{o[a]=i;})});return j(n)?n.then(()=>o):o}function ne(e,r){return {readSourceData(t,o){return v(e.read(`${t}/${o}`),le)},ingestSourceDataStaged(t,o,n,s){return v(r(n),a=>e.write(`${t}/.staged/${s}/${o}`,a))},commitSourceData(t,o,n){let s=`${t}/.staged/${n}/${o}`,a=`${t}/${o}`;return e.renameKey(s,a)},hasSource(t,o){return e.exists(`${t}/${o}`)},listSources(t){return v(e.listKeys(`${t}/`),o=>o.filter(n=>!n.includes("/.staged/")).map(n=>n.slice(`${t}/`.length)))}}}function ge(e,r){let t=(o,n)=>{try{let s=n(o);return j(s)?s.catch(a=>r(o,a instanceof Error?a.message:String(a))):void 0}catch(s){try{return r(o,s instanceof Error?s.message:String(s))}catch{return}}};return {appendEntries(o,n){if(!(!o||n.length===0))return v(e.read(o),s=>e.write(o,[...s??[],...n]))},dispatchEntriesForJournalId(o,n){if(o)return v(e.read(o),s=>{let a=s;if(!(!a||a.length===0))return v(M(a,i=>t(i,n)),()=>e.delete(o))})}}}function fe(e,r,t){return {readRuntime(o){return v(e.read(r(o)),n=>n??t())},writeRuntime(o,n){return e.write(r(o),n)}}}function oe(e){return {writeComputedValues(r,t){return e.write(`cards/${r}/computed_values`,t)},readComputedValues(r){return e.read(`cards/${r}/computed_values`)},readAllComputedValues(){return v(e.listKeys("cards/"),r=>re(r,t=>e.read(t),t=>pe(t,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(r){return M(Object.entries(r),([t,o])=>{if(t)return o===void 0?e.delete(`data-objects/${t}`):e.write(`data-objects/${t}`,o)})},readDataObject(r){return e.read(`data-objects/${r}`)},readAllDataObjects(){return v(e.listKeys("data-objects/"),r=>re(r,t=>e.read(t),t=>t.slice(13)))},writeStatusSnapshot(r){return e.write("status",r)},readStatusSnapshot(){return e.read("status")}}}var _="sys_keys_board_state",I="__sys_keys_board_state_init";function de(e){if(!e||typeof e!="object"||Array.isArray(e))return false;let r=e.__private;return !!r&&typeof r=="object"&&!Array.isArray(r)&&r.visible_controlplane_only===true}function me(e){let r=e.filter(n=>!de(n)),t=[...new Set(r.map(n=>n.id).filter(n=>typeof n=="string"&&n.length>0))].sort(),o=[...new Set(r.flatMap(n=>Array.isArray(n.provides)?n.provides:[]).map(n=>n&&typeof n=="object"&&!Array.isArray(n)?n.bindTo:void 0).filter(n=>typeof n=="string"&&n.length>0&&n!==_))].sort();return {card_ids:t,data_object_keys:o}}function Se(e,r){let t=e.filter(s=>!de(s)),o=[...new Set(t.map(s=>s.id).filter(s=>typeof s=="string"&&s.length>0))].sort(),n=[...new Set(Object.entries(r).filter(([s])=>s!==I).flatMap(([,s])=>Array.isArray(s.provides)?s.provides:[]).filter(s=>typeof s=="string"&&s.length>0&&s!==_))].sort();return {card_ids:o,data_object_keys:n}}function Fe(){return {id:I,meta:{title:"System Keys Board State",synthetic:true},provides:[{bindTo:_,ref:`card_data.${_}`}],card_data:{[_]:{card_ids:[],data_object_keys:[]}},__private:{visible_controlplane_only:true}}}function Ve(e,r){function t(){return e.readIndex()??{}}function o(n,s,a){let i=String(s||"").split(".").filter(Boolean);if(i.length===0)return a&&typeof a=="object"&&!Array.isArray(a)?a:{value:a};let c={...n},g=c;for(let d=0;d<i.length-1;d++){let u=i[d],l=g[u],y=l&&typeof l=="object"&&!Array.isArray(l)?{...l}:{};g[u]=y,g=y;}return g[i[i.length-1]]=a,c}return {readCard(n){let s=t()[n];return !s||!e.cardExists(s.key)?null:e.readCard(s.key)},readCardKey(n){return t()[n]?.key??null},readAllCards(){let n=[];for(let[s,a]of Object.entries(t())){if(!e.cardExists(a.key))continue;let i=e.readCard(a.key);i?n.push(i):r?.(`[card-store] could not read card "${s}" at key "${a.key}"`);}return n},readChecksumIndex(){let n={};for(let[s,a]of Object.entries(t()))n[s]=a.checksum;return n},changedSince(n){let s=t(),a=[];for(let[i,c]of Object.entries(s))n[i]!==c.checksum&&a.push(i);for(let i of Object.keys(n))s[i]||a.push(i);return a},validateUpsert(n,s){let a=t(),i=a[n],c=Object.entries(a).find(([,g])=>g.key===s);return i&&i.key!==s?{ok:false,error:`Card id "${n}" is already mapped to key "${i.key}", cannot remap to "${s}"`}:c&&c[0]!==n?{ok:false,error:`Key "${s}" is already mapped to card id "${c[0]}", cannot remap to "${n}"`}:{ok:true}},writeCard(n,s,a){let i=t(),c=a??i[n]?.key??e.defaultCardKey(n),g=e.writeCard(c,s);i[n]={key:c,checksum:g,updatedAt:new Date().toISOString()},e.writeIndex(i);},patchCard(n,s,a){let i=t(),c=i[n];if(!c||!e.cardExists(c.key))throw new Error(`card "${n}" not found`);let g=e.readCard(c.key);if(!g||typeof g!="object"||Array.isArray(g))throw new Error(`card "${n}" is not patchable`);let d=o(g,s,a),u=e.writeCard(c.key,d);i[n]={key:c.key,checksum:u,updatedAt:new Date().toISOString()},e.writeIndex(i);},removeCard(n){let s=t(),a=s[n];a&&(e.removeCard(a.key),delete s[n],e.writeIndex(s));},readIndex(){return t()}}}function Pe(e,r){return ne(e,r)}function Ke(e){return te(e)}var ye="v1",U="board/graph",ue="board/lastJournalProcessedId";function qe(e){return `cards/${e}/runtime`}function Be(e){return ee(e,ye)}function Le(e){function r(t){let o=e.read(t);return o==null?null:typeof o=="string"?o:JSON.stringify(o)}return {readTaskExecutorRef(){let t=r("task-executor");if(t?.trim())return chunk7JVHYHT2_cjs.c(t.trim())},writeTaskExecutorRef(t){e.write("task-executor",chunk7JVHYHT2_cjs.b(t));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(t){e.write("chat-handler-flow",t);},readBoardRuntimeStoreRef(){return r("board-runtime-store-ref")},writeBoardRuntimeStoreRef(t){e.write("board-runtime-store-ref",t);},readCardStoreRef(){return r("card-store-ref")},writeCardStoreRef(t){e.write("card-store-ref",t);},readOutputsStoreRef(){return r("outputs-store-ref")},writeOutputsStoreRef(t){e.write("outputs-store-ref",t);},readQueueStoreRef(){return r("queue-store-ref")},writeQueueStoreRef(t){e.write("queue-store-ref",t);},readScratchStoreRef(){return r("scratch-store-ref")},writeScratchStoreRef(t){e.write("scratch-store-ref",t);},readChatStoreRef(){return r("chat-store-ref")},writeChatStoreRef(t){e.write("chat-store-ref",t);},readArtifactsStoreRef(){return r("artifacts-store-ref")},writeArtifactsStoreRef(t){e.write("artifacts-store-ref",t);},readFetchedSourcesStoreRef(){return r("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(t){e.write("fetched-sources-store-ref",t);}}}function je(e){return oe(e)}function se(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function he(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function ie(e,r){return e?.lastRequestedToken?he(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<r?"dispatch":"idle":"dispatch"}function ke(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"success"}}function ae(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"failure"}}function De(e){let r=e.cards.filter(i=>i.name!==I);if(r.length===e.cards.length)return e;let t=new Set;for(let i of r)for(let c of i.requires)t.add(c);let o=r.map(i=>({name:i.name,fanOut:i.unblocks.length})).sort((i,c)=>c.fanOut-i.fanOut||i.name.localeCompare(c.name)),n=o.length>0?o[0]:{name:null,fanOut:0},s=i=>r.filter(c=>c.status===i).length,a=r.filter(i=>i.requires.length===0&&i.unblocks.length===0).length;return {...e,summary:{...e.summary,card_count:r.length,completed:s("completed"),eligible:s("eligible"),pending:s("pending"),blocked:s("blocked"),unresolved:s("unresolved"),failed:s("failed"),in_progress:s("in-progress"),orphan_cards:a,topology:{edge_count:t.size,max_fan_out_card:n.name,max_fan_out:n.fanOut}},cards:r}}function $e(e){let{[_]:r,...t}=e;return t}function Ne(e,r){let t=r.state.tasks,o=r.config.tasks,n=Object.keys(t),s=chunkVI36DRWG_cjs.a(r),a={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},i=new Map;for(let p of s.pending)i.set(p.taskName,p.waitingOn);for(let p of s.unresolved)i.set(p.taskName,p.missingTokens);for(let p of s.blocked)i.set(p.taskName,p.failedTokens);let c=new Map;for(let[p,f]of Object.entries(o))for(let w of f.requires??[]){let C=c.get(w)??[];C.push(p),c.set(w,C);}let g=n.sort().map(p=>{let f=t[p],w=o[p]??{requires:[],provides:[]};f.status==="completed"?a.completed+=1:f.status==="failed"?a.failed+=1:f.status==="in-progress"&&(a.in_progress+=1);let C=w.requires??[],R=w.provides??[],b=Object.keys(f.data??{}).sort(),O=C.filter(T=>r.state.availableOutputs.includes(T)),F=C.filter(T=>!r.state.availableOutputs.includes(T)),V=i.get(p)??F,E=new Set;for(let T of R)for(let x of c.get(T)??[])x!==p&&E.add(x);let q=f.failedAt,P=f.error?{message:f.error,code:"TASK_FAILED",at:q,source:"task-runtime"}:void 0;return {name:p,status:f.status,error:P,requires:C,requires_satisfied:O,requires_missing:F,provides_declared:R,provides_runtime:b,blocked_by:V,unblocks:Array.from(E).sort(),runtime:{attempt_count:f.executionCount??0,restart_count:f.retryCount??0,in_progress_since:f.status==="in-progress"?f.startedAt??null:null,last_transition_at:f.lastUpdated??null,last_completed_at:f.completedAt??null,last_restarted_at:f.startedAt??null,status_age_ms:f.lastUpdated?0:null}}});a.pending=s.pending.length,a.blocked=s.blocked.length,a.unresolved=s.unresolved.length;let d=g.map(p=>({name:p.name,fanOut:p.unblocks.length})).sort((p,f)=>f.fanOut-p.fanOut||p.name.localeCompare(f.name)),u=d.length>0?d[0]:{name:null,fanOut:0},l=new Set;for(let p of Object.values(o))for(let f of p.requires??[])l.add(f);let y=0;for(let[p,f]of Object.entries(o)){let w=(f.requires??[]).length===0,R=(f.provides??[]).some(b=>(c.get(b)??[]).some(O=>O!==p));w&&!R&&(y+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:n.length,completed:a.completed,eligible:s.eligible.length,pending:a.pending,blocked:a.blocked,unresolved:a.unresolved,failed:a.failed,in_progress:a.in_progress,orphan_cards:y,topology:{edge_count:Array.from(l).length,max_fan_out_card:u.name,max_fan_out:u.fanOut}},cards:g}}function Ce(){return new Date().toISOString()}function Je(e,r,t,o,n,s,a){return async i=>{let c=[],g=t.cardStore.readCard(i.nodeId);if(!g)return "task-initiate-failure";let d=g.id;if(d===I){let m=t.activeTaskConfigs?.(),S={[_]:m?Se(Object.keys(m).filter(h=>h!==I).map(h=>t.cardStore.readCard(h)).filter(h=>!!h),m):me(t.cardStore.readAllCards())};return (a??t.outputStore.writeDataObjects.bind(t.outputStore))(S),o(i.nodeId,S),"task-initiated"}let u=g.card_data??{},l=g.source_defs??[],y=l,p=t.cardRuntimeStore.readRuntime(d),f=false,w=()=>{f&&(t.cardRuntimeStore.writeRuntime(d,p),f=false);},C=m=>se(p._sources[m]),R=(m,S)=>{p._sources[m]=se(S),f=true;},b=i.taskState?.executionCount??0;if(p._lastExecutionCount!==b&&(p._sources={},p._lastExecutionCount=b,f=true),i.update){let m=i.update,S=m.outputFile;if(S){let h=C(S);if(m.failure){let k=m.rqt??h.lastRequestedToken??h.queueRequestedToken;k&&R(S,ae(h,k));}else {let k=m.rqt;if(!h.lastCompletedToken||k>h.lastCompletedToken){let A=typeof m.deliveryToken=="string"?m.deliveryToken:void 0,K=false;A&&(K=t.fetchedSourcesStore.commitSourceData(d,S,A)),K?R(S,ke(h,k)):R(S,ae(h,k));}}w();}}let F={};for(let m of l)if(m.outputFile){let S=t.fetchedSourcesStore.readSourceData(d,m.outputFile);S!==null&&(F[m.bindTo]=S);}let V={};for(let[m,S]of Object.entries(i.state??{}))if(S!==null&&typeof S=="object"&&!Array.isArray(S)){let h=S[m];V[m]=h!==void 0?h:S;}else V[m]=S;let E={id:d,card_data:{...u},requires:V,source_defs:l,compute:g.compute};E._sourcesData=F,g.compute&&chunkQBEQL4TL_cjs.a.runSync(E,{sourcesData:F}),(s??t.outputStore.writeComputedValues.bind(t.outputStore))(d,E.computed_values??{});let q={...g},P=chunkQBEQL4TL_cjs.a.enrichSourcesSync(Array.isArray(g.source_defs)?g.source_defs:void 0,{card_data:g.card_data,requires:V}),T=e.value;q.source_defs=Array.isArray(P)?P.map(m=>({...m,boardDir:typeof m.boardDir=="string"&&m.boardDir?m.boardDir:T})):P;let x=Ce(),H=i.update?void 0:x,G=y.filter(m=>{let S=m.outputFile;if(typeof S!="string"||!S)return true;let h=C(S);H&&(h={...h,queueRequestedToken:H},R(S,h));let k=h.queueRequestedToken??h.lastRequestedToken??x,A=ie(h,k);return A==="in-flight"?false:A==="dispatch"});if(w(),G.length>0){let m=false,S=x;for(let h of G){let k=h.outputFile;if(typeof k!="string"||!k)continue;let A=C(k),K=A.queueRequestedToken??x;R(k,{...A,lastRequestedToken:K}),S=K,m=true;}return m&&w(),m&&(c.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(e),enrichedCard:q,callbackToken:i.callbackToken,rqt:S}}),t.executionRequestStore.appendEntries(r,c)),"task-initiated"}if(y.some(m=>{let S=m.outputFile;if(typeof S!="string"||!S)return false;let h=C(S),k=h.queueRequestedToken??h.lastRequestedToken??x;return ie(h,k)==="in-flight"}))return "task-initiated";let ce=g.provides??[],D={};for(let{bindTo:m,ref:S}of ce)D[m]=chunkQBEQL4TL_cjs.a.resolve(E,S);return (a??t.outputStore.writeDataObjects.bind(t.outputStore))(D),o(i.nodeId,D),c.length>0&&t.executionRequestStore.appendEntries(r,c),"task-initiated"}}var Me={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function Ue(e){return {[U]:e.graph,[ue]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function He(e){let r=e[U],t=e[ue],n=e.board?.runtimeByCardId;if(!r||typeof r!="object")throw new Error(`State snapshot is missing required key: ${U}`);return {graph:r,lastDrainedJournalId:typeof t=="string"?t:"",runtimeByCardId:n&&typeof n=="object"?n:{}}}function Ge(e){let r=e.requires;return {provides:e.provides?.map(o=>o.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...r&&r.length>0?{requires:r}:{}}}function We(e,r={}){function t(d){return {status:"success",data:d}}function o(d){return {status:"fail",error:d}}function n(d){return {status:"error",error:d instanceof Error?d.message:String(d)}}function s(d){return d===I}async function a(d){let u=r.emitNotification;if(!u||d.length===0)return;let l=chunk2RIHC5TZ_cjs.e(d.filter(y=>y.kind!=="card_refreshed"?true:!s(y.cardId)));if(l.length!==0){if(l.length===1){await u(l[0]);return}await u(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:l}));}}function i(d){let u=d.params?.id;if(u){if(s(u))throw new Error(`card "${u}" not found`);let l=e.readCard(u);if(!l)throw new Error(`card "${u}" not found`);return [l]}return e.readAllCards().filter(l=>!s(l.id))}function c(d){let u=d.filter(l=>!s(l.id));return chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:chunk2RIHC5TZ_cjs.e(u.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function g(d){if(Array.isArray(d))return d;if(d&&typeof d=="object"){let u=d;return Array.isArray(u.files)?u.files:[d]}return null}return {get(d){try{return t({cards:i(d)})}catch(u){return n(u)}},buildNotificationBatch(d){try{return t(c(i(d)))}catch(u){return n(u)}},set(d){try{let u=d.body;if(u==null)return o("set requires a body (card object or array of cards)");let l=Array.isArray(u)?u:[u];for(let y of l){if(typeof y.id!="string")return o("each card must have a string `id` field");e.writeCard(y.id,y);}return a(l.map(y=>({kind:"card_refreshed",cardId:y.id,card:y}))),t({count:l.length})}catch(u){return n(u)}},del(d){try{let u=d.body?.ids??[],l=d.params?.id,y=l?[...u,l]:u;if(y.length===0)return o("del requires body.ids (string[]) or params.id");for(let p of y)e.removeCard(p);return a(y.map(p=>({kind:"card_removed",cardId:p}))),t({count:y.length})}catch(u){return n(u)}},patch(d){try{let u=d.params?.id,l=d.params?.path;if(!u)return o("patch requires params.id");if(!l)return o("patch requires params.path");let y=d.body,p=y&&Object.prototype.hasOwnProperty.call(y,"value")?y.value:d.body;e.patchCard(u,l,p);let f=e.readCard(u);return f?(a([{kind:"card_refreshed",cardId:u,card:f}]),t({count:1})):o(`card "${u}" not found`)}catch(u){return n(u)}},appendFiles(d){try{let u=d.params?.id;if(!u)return o("appendFiles requires params.id");let l=e.readCard(u);if(!l)return o(`card "${u}" not found`);let y=g(d.body);if(!y||y.length===0)return o("appendFiles requires a file metadata object, array, or body.files array");let p=l.card_data&&typeof l.card_data=="object"&&!Array.isArray(l.card_data)?l.card_data:{},f=Array.isArray(p.files)?p.files:[],w=[...f,...y],C=y.map((b,O)=>({idx:f.length+O,entry:b})),R=this.patch({params:{id:u,path:"card_data.files"},body:{value:w}});return R.status!=="success"?R:t({files_added:C})}catch(u){return n(u)}}}}exports.A=$e;exports.B=Ne;exports.C=Je;exports.D=Me;exports.E=Ue;exports.F=He;exports.G=Ge;exports.H=We;exports.a=Re;exports.b=ee;exports.c=ve;exports.d=ne;exports.e=ge;exports.f=fe;exports.g=oe;exports.h=_;exports.i=I;exports.j=me;exports.k=Se;exports.l=Fe;exports.m=Ve;exports.n=Pe;exports.o=Ke;exports.p=ye;exports.q=U;exports.r=qe;exports.s=Be;exports.t=Le;exports.u=je;exports.v=se;exports.w=ie;exports.x=ke;exports.y=ae;exports.z=De;//# sourceMappingURL=chunk-J7KE7SPA.cjs.map
2
- //# sourceMappingURL=chunk-J7KE7SPA.cjs.map
@@ -1,3 +0,0 @@
1
- 'use strict';var chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs'),chunk3XPY7CCM_cjs=require('./chunk-3XPY7CCM.cjs'),chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunkJ7KE7SPA_cjs=require('./chunk-J7KE7SPA.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');async function mt(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function Pt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Pe(e,o){return Pt(e)?e.then(o):o(e)}function lt(e,o){let a={...e};for(let[r,s]of Object.entries(o))s!==null&&typeof s=="object"&&!Array.isArray(s)&&a[r]!==null&&typeof a[r]=="object"&&!Array.isArray(a[r])?a[r]=lt(a[r],s):a[r]=s;return a}function ve(e,o,a){if(o.length===0)return e;let[r,...s]=o;if(s.length===0)return {...e,[r]:a};let d=e[r]!==null&&typeof e[r]=="object"&&!Array.isArray(e[r])?e[r]:{};return {...e,[r]:ve(d,s,a)}}function ft(e){return {read:a=>e.read(a),get(a,r){return Pe(e.read(a),s=>{if(s===null)return null;let d=s;for(let f of r.split(".").filter(Boolean)){if(d===null||typeof d!="object"||Array.isArray(d))return null;d=d[f]??null;}return d??null})},write:(a,r)=>e.write(a,r),delete:a=>e.delete(a),listKeys:a=>e.listKeys(a),shallowMerge(a,r){return Pe(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return Pe(e.read(a),s=>e.write(a,lt(s??{},r)))},patch(a,r,s){return Pe(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,ve(d??{},f,s))})}}}function gt(e){return ft(e)}function pt(e,o){return {async readIndex(){return await e.read("_index")},writeIndex(a){return e.write("_index",a)},async readCard(a){return await e.read(a)},async writeCard(a,r){return await e.write(a,r),o(r)},removeCard(a){return e.delete(a)},async cardExists(a){return await e.read(a)!==null},defaultCardKey(a){return a}}}function yt(e,o){async function a(){return await e.readIndex()??{}}return {async readCard(r){let s=(await a())[r];return !s||!await e.cardExists(s.key)?null:await e.readCard(s.key)},async readCardKey(r){return (await a())[r]?.key??null},async readAllCards(){let r=[];for(let[s,d]of Object.entries(await a())){if(!await e.cardExists(d.key))continue;let f=await e.readCard(d.key);f?r.push(f):o?.(`[card-store] could not read card "${s}" at key "${d.key}"`);}return r},async readChecksumIndex(){let r={};for(let[s,d]of Object.entries(await a()))r[s]=d.checksum;return r},async changedSince(r){let s=await a(),d=[];for(let[f,v]of Object.entries(s))r[f]!==v.checksum&&d.push(f);for(let f of Object.keys(r))s[f]||d.push(f);return d},async validateUpsert(r,s){let d=await a(),f=d[r],v=Object.entries(d).find(([,w])=>w.key===s);return f&&f.key!==s?{ok:false,error:`Card id "${r}" is already mapped to key "${f.key}", cannot remap to "${s}"`}:v&&v[0]!==r?{ok:false,error:`Key "${s}" is already mapped to card id "${v[0]}", cannot remap to "${r}"`}:{ok:true}},async writeCard(r,s,d){let f=await a(),v=d??f[r]?.key??e.defaultCardKey(r),w=await e.writeCard(v,s);f[r]={key:v,checksum:w,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async patchCard(r,s,d){let f=await a(),v=f[r];if(!v||!await e.cardExists(v.key))throw new Error(`card "${r}" not found`);let w=await e.readCard(v.key);if(!w||typeof w!="object"||Array.isArray(w))throw new Error(`card "${r}" is not patchable`);let m=String(s||"").split(".").filter(Boolean),l=ve(w,m,d),S=await e.writeCard(v.key,l);f[r]={key:v.key,checksum:S,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async removeCard(r){let s=await a(),d=s[r];d&&(await e.removeCard(d.key),delete s[r],await e.writeIndex(s));},readIndex(){return a()}}}function Nt(e,o){return chunkJ7KE7SPA_cjs.a(e,o)}function _t(e,o,a){return {blob:e,kv:o,journal:a}}function St(e,o={}){function a(m){return {status:"success",data:m}}function r(m){return {status:"fail",error:m}}function s(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}async function d(m){let l=o.emitNotification;if(!l||m.length===0)return;let S=chunk2RIHC5TZ_cjs.e(m);if(S.length===1){await l(S[0]);return}await l(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:S}));}async function f(m){let l=m.params?.id;if(l){let S=await e.readCard(l);if(!S)throw new Error(`card "${l}" not found`);return [S]}return await e.readAllCards()}function v(m){return chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:chunk2RIHC5TZ_cjs.e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function w(m){if(Array.isArray(m))return m;if(m&&typeof m=="object"){let l=m;return Array.isArray(l.files)?l.files:[m]}return null}return {async get(m){try{return a({cards:await f(m)})}catch(l){return s(l)}},async buildNotificationBatch(m){try{return a(v(await f(m)))}catch(l){return s(l)}},async set(m){try{let l=m.body;if(l==null)return r("set requires a body (card object or array of cards)");let S=Array.isArray(l)?l:[l];for(let h of S){if(typeof h.id!="string")return r("each card must have a string `id` field");await e.writeCard(h.id,h);}return await d(S.map(h=>({kind:"card_refreshed",cardId:h.id,card:h}))),a({count:S.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],S=m.params?.id,h=S?[...l,S]:l;if(h.length===0)return r("del requires body.ids (string[]) or params.id");for(let N of h)await e.removeCard(N);return await d(h.map(N=>({kind:"card_removed",cardId:N}))),a({count:h.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,S=m.params?.path;if(!l)return r("patch requires params.id");if(!S)return r("patch requires params.path");let h=m.body,N=h&&Object.prototype.hasOwnProperty.call(h,"value")?h.value:m.body;await e.patchCard(l,S,N);let O=await e.readCard(l);return O?(await d([{kind:"card_refreshed",cardId:l,card:O}]),a({count:1})):r(`card "${l}" not found`)}catch(l){return s(l)}},async appendFiles(m){try{let l=m.params?.id;if(!l)return r("appendFiles requires params.id");let S=await e.readCard(l);if(!S)return r(`card "${l}" not found`);let h=w(m.body);if(!h||h.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let N=S.card_data&&typeof S.card_data=="object"&&!Array.isArray(S.card_data)?S.card_data:{},O=Array.isArray(N.files)?N.files:[],M=[...O,...h],V=h.map(($,Z)=>({idx:O.length+Z,entry:$})),K=await this.patch({params:{id:l,path:"card_data.files"},body:{value:M}});return K.status!=="success"?K:a({files_added:V})}catch(l){return s(l)}}}}async function vt(e,o){return (await e.peekActive()).find(a=>a.id===o)}function $t(e,o={}){async function a(r){let s=o.emitNotification;if(!s||r.length===0)return;let d=chunk2RIHC5TZ_cjs.e(r);if(d.length===1){await s(d[0]);return}await s(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:d}));}return {async enqueue(r){let s=await e.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await e.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:e.enqueueIfAbsent?async(r,s)=>{let d=await e.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return e.lease(r)},ack(r,s){return e.ack(r,s)},nack(r,s,d){return e.nack(r,s,d)},peekActive(r){return e.peekActive(r)},peekDeadLetter(r){return e.peekDeadLetter(r)},async stage(r,s){return e.stage(r,s)},async commitStaged(r){let s=await e.commitStaged(r);if(s){let d=await vt(e,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return e.discardStaged(r,s)},peekStaged(r){return e.peekStaged(r)}}}function b(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function T(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function q(){return new Date().toISOString()}function bt(e){let o=new TextEncoder().encode(e),a=Array.from(o,r=>String.fromCharCode(r)).join("");return btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Rt(e){let o=e.replace(/-/g,"+").replace(/_/g,"/"),a=o+"=".repeat((4-o.length%4)%4),r=atob(a),s=Uint8Array.from(r,d=>d.charCodeAt(0));return new TextDecoder().decode(s)}function be(e){try{let o=JSON.parse(Rt(e));return typeof o?.t=="string"?{taskName:o.t}:null}catch{return null}}function kt(e){return bt(JSON.stringify(e))}function Ct(e){try{let o=JSON.parse(Rt(e));return typeof o?.cbk=="string"&&typeof o?.cid=="string"&&typeof o?.b=="string"&&typeof o?.d=="string"?o:null}catch{return null}}function At(e){return chunkJ7KE7SPA_cjs.f(e,chunkJ7KE7SPA_cjs.r,()=>({_sources:{}}))}function It(e,o){return chunkJ7KE7SPA_cjs.d(e,o)}function xt(e){return chunkJ7KE7SPA_cjs.g(e)}function Tt(e,o){return chunkJ7KE7SPA_cjs.e(e,o)}function Ot(e,o,a,r,s,d){return async f=>{let v=[],w=await a.cardStore.readCard(f.nodeId);if(!w)return "task-initiate-failure";let m=w.id;if(m===chunkJ7KE7SPA_cjs.i){let p=a.activeTaskConfigs?.(),y={[chunkJ7KE7SPA_cjs.h]:p?chunkJ7KE7SPA_cjs.k((await Promise.all(Object.keys(p).filter(k=>k!==chunkJ7KE7SPA_cjs.i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await chunkJ7KE7SPA_cjs.j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w.card_data??{},S=w.source_defs??[],h=S,N=await a.cardRuntimeStore.readRuntime(m),O=false,M=async()=>{O&&(await a.cardRuntimeStore.writeRuntime(m,N),O=false);},V=p=>chunkJ7KE7SPA_cjs.v(N._sources[p]),K=(p,y)=>{N._sources[p]=chunkJ7KE7SPA_cjs.v(y),O=true;},$=f.taskState?.executionCount??0;if(N._lastExecutionCount!==$&&(N._sources={},N._lastExecutionCount=$,O=true),f.update){let p=f.update.outputFile;if(p){let y=V(p);if(f.update.failure){let k=f.update.rqt??y.lastRequestedToken??y.queueRequestedToken;k&&K(p,chunkJ7KE7SPA_cjs.y(y,k));}else {let k=f.update.rqt;if(!y.lastCompletedToken||k>y.lastCompletedToken){let j=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,re=j?await a.fetchedSourcesStore.commitSourceData(m,p,j):false;K(p,re?chunkJ7KE7SPA_cjs.x(y,k):chunkJ7KE7SPA_cjs.y(y,k));}}await M();}}let Z={};for(let p of S){if(!p.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,p.outputFile);y!==null&&(Z[p.bindTo]=y);}let H={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];H[p]=k!==void 0?k:y;}else H[p]=y;let ee={id:m,card_data:{...l},requires:H,source_defs:S,compute:w.compute};ee._sourcesData=Z,w.compute&&chunkQBEQL4TL_cjs.a.runSync(ee,{sourcesData:Z}),(s??(()=>{}))(m,ee.computed_values??{});let te=chunkQBEQL4TL_cjs.a.enrichSourcesSync(Array.isArray(w.source_defs)?w.source_defs:void 0,{card_data:w.card_data,requires:H}),Ae={...w,source_defs:Array.isArray(te)?te.map(p=>({...p,boardDir:typeof p.boardDir=="string"&&p.boardDir?p.boardDir:e.value})):te},W=q(),E=f.update?void 0:W,ge=h.filter(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return true;let k=V(y);E&&(k={...k,queueRequestedToken:E},K(y,k));let j=k.queueRequestedToken??k.lastRequestedToken??W;return chunkJ7KE7SPA_cjs.w(k,j)==="dispatch"});if(await M(),ge.length>0){let p=false,y=W;for(let k of ge){let j=k.outputFile;if(typeof j!="string"||!j)continue;let re=V(j),L=re.queueRequestedToken??W;K(j,{...re,lastRequestedToken:L}),y=L,p=true;}return p&&await M(),p&&(v.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(e),enrichedCard:Ae,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v)),"task-initiated"}if(h.some(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return false;let k=V(y),j=k.queueRequestedToken??k.lastRequestedToken??W;return chunkJ7KE7SPA_cjs.w(k,j)==="in-flight"}))return "task-initiated";let ie=w.provides??[],ue={};for(let{bindTo:p,ref:y}of ie)ue[p]=chunkQBEQL4TL_cjs.a.resolve(ee,y);return (d??(()=>{}))(ue),r(f.nodeId,ue),v.length>0&&await a.executionRequestStore.appendEntries(o,v),"task-initiated"}}function nr(e,o,a={}){chunk3XPY7CCM_cjs.a(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=chunkVQCIOKJV_cjs.a(e),f=a.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),v=null,w=a.boardRuntimeStoreRef,m=a.scratchStoreRef,l=a.taskExecutorRef,S=a.chatHandlerFlow;function h(){if(!w)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return w}function N(n){if(n.length!==0)try{let t=chunk2RIHC5TZ_cjs.e(n),c=chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:t});return Promise.resolve(f(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(t){s(`[async-board-live-cards-public] emitNotification failed: ${t instanceof Error?t.message:String(t)}`);return}}let O=()=>chunkCSHNTZW4_cjs.b(o.kvStorageForRef(h())),M=e.value,V=()=>chunkJ7KE7SPA_cjs.b(chunkJ7KE7SPA_cjs.a(()=>o.kvStorageForRef(h()),o.hashFn),"v1"),K=async()=>{let n=await O().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e.value} has no outputs store configured.`);return xt(o.kvStorageForRef(n))},$=async()=>{let n=await O().readCardStoreRef();if(!n)throw new Error(`Board at ${e.value} has no card store configured.`);let t=o.kvStorageForRef(n);return yt(pt(gt(t),o.hashFn),s)};async function Z(){return !!(await V().readSnapshot(M)).values[chunkJ7KE7SPA_cjs.q]}async function H(){let n=await V().readSnapshot(M);if(!n.values[chunkJ7KE7SPA_cjs.q])throw new Error(`Board not initialized at ${e.value}`);return chunkJ7KE7SPA_cjs.F(n.values)}async function ee(n,t){let c=await V().commitSnapshot(M,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:chunkJ7KE7SPA_cjs.E(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let te=()=>chunkJ7KE7SPA_cjs.c(o.journalStorageForRef(h()));async function Ae(){return l??await O().readTaskExecutorRef()}async function W(){return chunkJ7KE7SPA_cjs.A(await(await K()).readAllDataObjects())}async function E(n){await te().appendEvent(n);}async function ge(){let n=await O().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function le(){return o.blobStorageForRef(await ge())}async function ie(){return It(await le(),n=>o.resolveBlob(n))}async function ue(n){let t=(await le()).keyRef?.(n);if(!t)throw new Error("configured fetched-sources store does not support keyRef");let c=await Promise.resolve(t);return chunkVQCIOKJV_cjs.a(c)}async function p(){let n=Tt(o.kvStorageForRef(h()),async(u,g)=>{let P=u.payload,B=(P.enrichedCard??{}).id??P.cardId??"unknown";await E({type:"task-failed",taskName:B,error:g,timestamp:q()});}),t=At(o.kvStorageForRef(h())),c=await le(),i=await ie(),A=await $(),I=await K(),F=new Map,C=new Map,x=[],Q=[],G=[],X=new Map,de=new Set,ce={async readRuntime(u){return F.get(u)??await t.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),Te[u]=g;}},Ie={async readSourceData(u,g){let P=`${u}/${g}`;return C.has(P)?C.get(P):await i.readSourceData(u,g)},ingestSourceDataStaged(u,g,P,D){return i.ingestSourceDataStaged(u,g,P,D)},async commitSourceData(u,g,P){let D=`${u}/.staged/${P}/${g}`,B=await c.read(D);if(B==null){let z=await Promise.resolve(c.keyRef?.(D));z&&(B=await o.resolveBlob(z));}if(B==null)return false;let U=`${u}/${g}`,ae=B.trim();try{C.set(U,JSON.parse(ae));}catch{C.set(U,ae);}return x.push({cardId:u,outputFile:g,deliveryToken:P}),true},async hasSource(u,g){let P=`${u}/${g}`;return C.has(P)||await i.hasSource(u,g)},async listSources(u){let g=await i.listSources(u),P=[...C.keys()].filter(D=>D.startsWith(`${u}/`)).map(D=>D.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await H(),De=chunkAW3COGCI_cjs.q(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await te().readEntriesAfterCursor(xe.lastDrainedJournalId),pe=wt,Ve=()=>De.config.tasks,fe=chunkAW3COGCI_cjs.t(De,{handlers:{"card-handler":Ot(e,Oe,{cardStore:A,cardRuntimeStore:ce,fetchedSourcesStore:Ie,outputStore:I,executionRequestStore:n,activeTaskConfigs:()=>Ve()},(u,g)=>{pe.push({type:"task-completed",taskName:u,data:g,timestamp:q()});},(u,g)=>{Q.push({cardId:u,values:g});},u=>{G.push(u);})},onNodeRemoved:u=>{X.delete(u),F.delete(u),delete Te[u],de.add(u);}});for(Ve=()=>fe.getState().config.tasks;pe.length>0;){let u=pe;pe=[];for(let g of u)if(g.type==="task-restart"){let P=await A.readCard(g.taskName);P&&X.set(g.taskName,P);}fe.pushAll(u),await fe.waitForHandlers();}let $e=fe.getState();await fe.dispose({wait:true}),await ee({lastDrainedJournalId:Oe,graph:chunkAW3COGCI_cjs.p($e),runtimeByCardId:Te},(await V().readSnapshot(M)).version);for(let{cardId:u,values:g}of Q)await I.writeComputedValues(u,g);for(let u of G)await I.writeDataObjects(u);for(let[u,g]of F)await t.writeRuntime(u,g);for(let u of x)await i.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let Le=chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(d,$e));await I.writeStatusSnapshot(Le);let me=[];for(let{cardId:u,values:g}of Q)me.push({kind:"computed_values",cardId:u,values:g});for(let u of G)for(let[g,P]of Object.entries(u))me.push({kind:"data_object",key:g,payload:P});for(let[u,g]of X)u!==chunkJ7KE7SPA_cjs.i&&me.push({kind:"card_refreshed",cardId:u,card:g});for(let u of de)me.push({kind:"card_removed",cardId:u});me.push({kind:"status",status:Le}),await N(me);let ne=await Ae();if(!ne)return;let Je=o.supportsDirectSourceOutput?.(ne)===true;await n.dispatchEntriesForJournalId(Oe,async u=>{if(u.taskKind!=="source-fetch"){s(`[async-process-accumulated-events] unknown taskKind "${u.taskKind}" \u2014 skipping`);return}let g=u.payload,P=g.enrichedCard?.id??"unknown",D=g.enrichedCard?.source_defs??[];if(ne.howToRun==="queue-storage"&&Je){try{let B=await O().readQueueStoreRef();if(!B)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let U=o.queueStorageForRef(B,"task-executor"),ae=typeof ne.extra?.boardId=="string"?ne.extra.boardId:void 0,z=[];for(let Y of D){if(!Y.outputFile)continue;let ye=o.genId(),Se=`${P}/.staged/${ye}/${Y.outputFile}`,Me=await Promise.resolve(c.keyRef?.(Se));if(!Me)continue;let Qe={ref:chunkVQCIOKJV_cjs.a(Me),deliveryToken:ye,outputFile:Y.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:Y.bindTo,d:Y.outputFile,cs:void 0,rqt:g.rqt,dt:Qe.deliveryToken});z.push({...ae?{boardId:ae}:{},ref:ne,args:{source_def:Y,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ht),output:Qe}});}z.length>0&&await U.enqueueMany(z);}catch(B){await E({type:"task-failed",taskName:P,error:B instanceof Error?B.message:String(B),timestamp:q()});}return}for(let B of D){if(!B.outputFile)continue;let U;if(Je){let Y=o.genId(),ye=`${P}/.staged/${Y}/${B.outputFile}`,Se=await Promise.resolve(c.keyRef?.(ye));Se&&(U={ref:chunkVQCIOKJV_cjs.a(Se),deliveryToken:Y,outputFile:B.outputFile,cardId:P});}let ae=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:B.bindTo,d:B.outputFile,cs:void 0,rqt:g.rqt,...U?{dt:U.deliveryToken}:{}}),z=await o.dispatchExecution(ne,{source_def:B,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ae),...U?{output:U}:{}});z.dispatched||await E({type:"task-failed",taskName:P,error:z.error??"dispatch failed",timestamp:q()});}});}async function y(){try{let n=async()=>{let c=await H(),{events:i}=await te().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await j();},t=await mt(o.lock,p,n);return b({ran:t!==!1})}catch(n){return T(n)}}async function k(){return v||(v=y().finally(()=>{v=null;}),v)}async function j(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);await o.queueStorageForRef(n,"process-accumulated").enqueue({boardRef:chunkVQCIOKJV_cjs.a(e)}),await o.requestProcessAccumulated?.();}async function re(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await t.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await t.ack(i.id,i.leaseToken);if(c.length<64)return}}function L(){j();}return {async init(n){try{let t=n.params?.cardStoreRef;if(!t)return R("init requires params.cardStoreRef");if(w=n.params?.boardRuntimeStoreRef,!w)return R("init requires params.boardRuntimeStoreRef");let c=n.params?.outputsStoreRef;if(!c)return R("init requires params.outputsStoreRef");let i=n.params?.queueStoreRef;if(!i)return R("init requires params.queueStoreRef");let A=n.params?.fetchedSourcesStoreRef;if(!A)return R("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let I=n.params?.chatStoreRef;if(!I)return R("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return R("init requires params.artifactsStoreRef");await Z()||await ee({lastDrainedJournalId:"",graph:chunkAW3COGCI_cjs.p(chunkAW3COGCI_cjs.a(chunkJ7KE7SPA_cjs.D)),runtimeByCardId:{}},null);let C=O();await C.writeBoardRuntimeStoreRef(w),await C.writeCardStoreRef(t),await C.writeOutputsStoreRef(c),await C.writeQueueStoreRef(i),await C.writeFetchedSourcesStoreRef(A),await C.writeChatStoreRef(I),await C.writeArtifactsStoreRef(F),await(await $()).writeCard(chunkJ7KE7SPA_cjs.i,chunkJ7KE7SPA_cjs.l());let x=o.kvStorage("card-upsert"),Q=chunkJ7KE7SPA_cjs.l(),G=chunkJ7KE7SPA_cjs.G(Q),X=o.hashFn(G),ce=(await x.read(chunkJ7KE7SPA_cjs.i))?.blobRef??await(await $()).readCardKey(chunkJ7KE7SPA_cjs.i)??chunkJ7KE7SPA_cjs.i;return await E({type:"task-upsert",taskName:chunkJ7KE7SPA_cjs.i,taskConfig:G,timestamp:q()}),await x.write(chunkJ7KE7SPA_cjs.i,{blobRef:ce,taskConfigHash:X,updatedAt:q()}),await E({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:q()}),L(),await(await K()).writeStatusSnapshot(chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(d,chunkAW3COGCI_cjs.q((await H()).graph)))),b()}catch(t){return T(t)}},async status(n){try{let t=await K(),c=await t.readStatusSnapshot();return c||(c=chunkJ7KE7SPA_cjs.z(chunkJ7KE7SPA_cjs.B(d,chunkAW3COGCI_cjs.q((await H()).graph))),await t.writeStatusSnapshot(c)),b(c)}catch(t){return T(t)}},async getCardStoreRef(n){try{let t=await O().readCardStoreRef();return t?b({storeRef:t}):R(`Board at ${e.value} has no card store configured`)}catch(t){return T(t)}},async getBoardRuntimeStoreRef(n){try{return b({storeRef:w??null})}catch(t){return T(t)}},async getOutputsStoreRef(n){try{let t=await O().readOutputsStoreRef();return t?b({storeRef:t}):R(`Board at ${e.value} has no outputs store configured`)}catch(t){return T(t)}},async getScratchStoreRef(n){try{return b({storeRef:m??null})}catch(t){return T(t)}},async getChatStoreRef(n){try{return b({storeRef:await O().readChatStoreRef()})}catch(t){return T(t)}},async getArtifactsStoreRef(n){try{return b({storeRef:await O().readArtifactsStoreRef()})}catch(t){return T(t)}},async getFetchedSourcesStoreRef(n){try{return b({storeRef:await O().readFetchedSourcesStoreRef()})}catch(t){return T(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return R("getConfig requires params.key");let c=O(),i;switch(t){case "task-executor":i=l??null;break;case "chat-handler-flow":i=S??null;break;case "board-runtime-store-ref":i=await c.readBoardRuntimeStoreRef();break;case "card-store-ref":i=await c.readCardStoreRef();break;case "outputs-store-ref":i=await c.readOutputsStoreRef();break;case "scratch-store-ref":i=m??null;break;case "chat-store-ref":i=await c.readChatStoreRef();break;case "artifacts-store-ref":i=await c.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=await c.readFetchedSourcesStoreRef();break;default:return R(`getConfig: unknown key "${t}"`)}return b({value:i})}catch(t){return T(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;if(!t)return R("getOutputsDataObject requires params.key");if(t===chunkJ7KE7SPA_cjs.h)return b(null);let c=await W();return b(c[t]??null)}catch(t){return T(t)}},async getAllOutputsDataObjects(n){try{return b(await W())}catch(t){return T(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?b(await(await K()).readComputedValues(t)):R("getOutputsComputedValues requires params.key")}catch(t){return T(t)}},async getAllOutputsComputedValues(n){try{return b(await(await K()).readAllComputedValues())}catch(t){return T(t)}},async getOutputsFetchedSources(n){try{let t=n.params?.key;if(!t)return R("getOutputsFetchedSources requires params.key");let c=await(await ie()).listSources(t),i={};for(let A of c)i[A]=await ue(`${t}/${A}`);return b(i)}catch(t){return T(t)}},async getAllOutputsFetchedSources(n){try{let t=await ie(),c=await(await le()).listKeys(),i=new Set;for(let I of c){let F=I.indexOf("/");F>0&&!I.includes("/.staged/")&&i.add(I.slice(0,F));}let A={};for(let I of i){let F=await t.listSources(I);if(F.length!==0){A[I]={};for(let C of F)A[I][C]=await ue(`${I}/${C}`);}}return b(A)}catch(t){return T(t)}},async buildSseOneShotPayload(n){try{let t=(await(await $()).readAllCards()).filter(C=>C.id!==chunkJ7KE7SPA_cjs.i),c=await this.status({});if(c.status!=="success")return c;let i=await this.getAllOutputsDataObjects({});if(i.status!=="success")return i;let A=await this.getAllOutputsComputedValues({});if(A.status!=="success")return A;let I=A.data,F={};for(let C of t){let x=typeof C?.id=="string"?C.id:null;if(!x)continue;let Q=C.card_data&&typeof C.card_data=="object"&&!Array.isArray(C.card_data)?C.card_data:{};F[x]={schema_version:"v1",card_id:x,card_data:{...Q},computed_values:I[x]&&typeof I[x]=="object"?I[x]:{}};}return b({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i.data,cardRuntimeById:F})}catch(t){return T(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return R("addCardFiles requires params.cardId");let i=await St(await $(),{emitNotification:f}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:b({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return T(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return R("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await E({type:"task-removal",taskName:t,timestamp:q()}),t!==chunkJ7KE7SPA_cjs.i&&await E({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:q()}),L(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await E({type:"task-restart",taskName:t,timestamp:q()}),L(),b()):R("retrigger requires params.id")}catch(t){return T(t)}},async processAccumulatedEvents(n){return await re(),k()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i=!!n.params?.restart;if(!t&&!c)return R("upsertCard requires --card-id <id> or --all");let A=await $(),I=c?(await A.readAllCards()).map(x=>x.id):[t];for(let x of I)if(!await A.readCard(x))return R(`Card "${x}" not found in board at ${e.value}`);let F=o.kvStorage("card-upsert"),C=!1;for(let x of I){let Q=await A.readCard(x);if(!Q)continue;let G=chunkJ7KE7SPA_cjs.G(Q),X=o.hashFn(G),de=await F.read(x),ce=de?.taskConfigHash!==X;if(!(!ce&&!i)){if(ce){let Ie=de?.blobRef??await A.readCardKey(x)??x;await E({type:"task-upsert",taskName:x,taskConfig:G,timestamp:q()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:q()}),C=C||x!==chunkJ7KE7SPA_cjs.i;}i&&await E({type:"task-restart",taskName:x,timestamp:q()});}}return C&&await E({type:"task-restart",taskName:chunkJ7KE7SPA_cjs.i,timestamp:q()}),L(),b()}catch(t){return T(t)}},async taskFailed(n){try{let t=n.params?.token;if(!t)return R("taskFailed requires params.token");let c=n.params?.error??"unknown error",i=be(t);return i?(await E({type:"task-failed",taskName:i.taskName,error:c,timestamp:q()}),L(),b()):R("Invalid callback token")}catch(t){return T(t)}},async taskProgress(n){try{let t=n.params?.token;if(!t)return R("taskProgress requires params.token");let c=(n.body??{}).update??{},i=be(t);return i?(await E({type:"task-progress",taskName:i.taskName,update:c,timestamp:q()}),L(),b()):R("Invalid callback token")}catch(t){return T(t)}},async sourceDataFetched(n){try{let t=n.params?.token,c=n.params?.ref;if(!t)return R("sourceDataFetched requires params.token");if(!c)return R("sourceDataFetched requires params.ref");let i=Ct(t);if(!i)return R("Invalid source token");let A=await ie(),I=i.dt||o.genId();i.dt||await A.ingestSourceDataStaged(i.cid,i.d,chunkVQCIOKJV_cjs.b(c),I);let F=be(i.cbk);return F?(await E({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:q(),deliveryToken:I,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),L(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}},async sourceDataFetchFailure(n){try{let t=n.params?.token,c=n.params?.reason??"unknown";if(!t)return R("sourceDataFetchFailure requires params.token");let i=Ct(t);if(!i)return R("Invalid source token");let A=be(i.cbk);return A?(await E({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),L(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}}}}
2
- exports.a=mt;exports.b=gt;exports.c=pt;exports.d=yt;exports.e=Nt;exports.f=_t;exports.g=St;exports.h=$t;exports.i=nr;//# sourceMappingURL=chunk-K5TEZRZK.cjs.map
3
- //# sourceMappingURL=chunk-K5TEZRZK.cjs.map
@@ -1,2 +0,0 @@
1
- 'use strict';var module$1=require('module');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var g=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-QBEQL4TL.cjs', document.baseURI).href))),u=g("./jsonata-sync.cjs"),p=u;function c(r,t){if(!t||!r)return;let s=t.split("."),e=r;for(let n=0;n<s.length;n++){if(e==null)return;e=e[s[n]];}return e}function f(r,t,s){let e=t.split("."),n=r;for(let o=0;o<e.length-1;o++)(n[e[o]]==null||typeof n[e[o]]!="object")&&(n[e[o]]={}),n=n[e[o]];n[e[e.length-1]]=s;}async function m(r,t){if(!r?.compute?.length)return r;r.card_data||(r.card_data={}),r.computed_values={},r._sourcesData=t?.sourcesData??{};let s=r.requires??{},e={card_data:r.card_data,requires:s,expects_data:s,fetched_sources:r._sourcesData,data:r.computed_values,computed_values:r.computed_values};for(let n of r.compute)try{let o=await u(n.expr).evaluate(e);f(r.computed_values,n.bindTo,o),e.computed_values=r.computed_values;}catch{}return r}function y(r,t){if(!r?.compute?.length)return {ok:true,node:r};r.card_data||(r.card_data={}),r.computed_values={},r._sourcesData=t?.sourcesData??{};let s=r.requires??{},e={card_data:r.card_data,requires:s,expects_data:s,fetched_sources:r._sourcesData,data:r.computed_values,computed_values:r.computed_values},n=[];for(let o of r.compute)try{let i=p(o.expr).evaluate(e);f(r.computed_values,o.bindTo,i),e.computed_values=r.computed_values;}catch(i){let a=i instanceof Error?i.message:String(i);n.push({bindTo:o.bindTo,error:a});}return n.length>0?{ok:true,node:r,errors:n}:{ok:true,node:r}}async function b(r,t,s){let e={...s??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return u(r).evaluate(e)}function _(r,t){return t.startsWith("fetched_sources.")?c(r._sourcesData??{},t.slice(16)):c(r,t)}var d=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),v=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function h(r){let t=[];if(!r||typeof r!="object"||Array.isArray(r))return {ok:false,errors:["Node must be a non-null object"]};let s=r;(typeof s.id!="string"||!s.id)&&t.push("id: required, must be a non-empty string");for(let e of Object.keys(s))v.has(e)||t.push(`Unknown top-level key: "${e}"`);if((s.card_data==null||typeof s.card_data!="object"||Array.isArray(s.card_data))&&t.push("card_data: required, must be an object"),s.meta!=null)if(typeof s.meta!="object"||Array.isArray(s.meta))t.push("meta: must be an object");else {let e=s.meta;e.title!=null&&typeof e.title!="string"&&t.push("meta.title: must be a string"),e.tags!=null&&!Array.isArray(e.tags)&&t.push("meta.tags: must be an array");}if(s.requires!=null&&!Array.isArray(s.requires)&&t.push("requires: must be an array of strings"),s.provides!=null&&(Array.isArray(s.provides)?s.provides.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))t.push(`provides[${n}]: must be an object with bindTo and ref`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&t.push(`provides[${n}]: missing required "bindTo" string`),(typeof o.ref!="string"||!o.ref)&&t.push(`provides[${n}]: missing required "ref" string`);}}):t.push("provides: must be an array of { bindTo, ref } bindings")),s.compute!=null&&(Array.isArray(s.compute)?s.compute.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))t.push(`compute[${n}]: must be a compute step object`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&t.push(`compute[${n}]: missing required "bindTo" property`),(typeof o.expr!="string"||!o.expr)&&t.push(`compute[${n}]: missing required "expr" string (JSONata expression)`);}}):t.push("compute: must be an array of compute steps")),s.source_defs!=null)if(!Array.isArray(s.source_defs))t.push("source_defs: must be an array");else {let e=new Set,n=new Set;s.source_defs.forEach((o,i)=>{if(!o||typeof o!="object"||Array.isArray(o))t.push(`source_defs[${i}]: must be an object`);else {let a=o;typeof a.bindTo!="string"||!a.bindTo?t.push(`source_defs[${i}]: missing required "bindTo" property`):(e.has(a.bindTo)&&t.push(`source_defs[${i}]: bindTo "${a.bindTo}" is not unique across source_defs`),e.add(a.bindTo)),typeof a.outputFile!="string"||!a.outputFile?t.push(`source_defs[${i}]: missing required "outputFile" property`):(n.has(a.outputFile)&&t.push(`source_defs[${i}]: outputFile "${a.outputFile}" is not unique across source_defs`),n.add(a.outputFile));}});}if(s.view!=null)if(typeof s.view!="object"||Array.isArray(s.view))t.push("view: must be an object");else {let e=s.view;!Array.isArray(e.elements)||e.elements.length===0?t.push("view.elements: required, must be a non-empty array"):e.elements.forEach((n,o)=>{if(!n||typeof n!="object"){t.push(`view.elements[${o}]: must be an object`);return}!n.kind||typeof n.kind!="string"?t.push(`view.elements[${o}].kind: required, must be a string`):d.has(n.kind)||t.push(`view.elements[${o}].kind: unknown kind "${n.kind}". Valid: ${[...d].join(", ")}`),n.data!=null&&(typeof n.data!="object"||Array.isArray(n.data))&&t.push(`view.elements[${o}].data: must be an object`);});}return {ok:t.length===0,errors:t}}async function k(r,t){if(!r||r.length===0)return [];let s={card_data:t.card_data??{},requires:t.requires??{}};return Promise.all(r.map(async e=>{let n={};if(e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[o,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{n[o]=await u(i).evaluate(s);}catch{n[o]=void 0;}}return {...e,_projections:n}}))}function w(r,t){if(!r||r.length===0)return [];let s={card_data:t.card_data??{},requires:t.requires??{}};return r.map(e=>{let n={};if(e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[o,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{n[o]=p(i).evaluate(s);}catch{n[o]=void 0;}}return {...e,_projections:n}})}var j={run:m,runSync:y,eval:b,resolve:_,validate:h,enrichSources:k,enrichSourcesSync:w},$=j;exports.a=j;exports.b=$;//# sourceMappingURL=chunk-QBEQL4TL.cjs.map
2
- //# sourceMappingURL=chunk-QBEQL4TL.cjs.map
@@ -1,3 +0,0 @@
1
- 'use strict';var chunkUJ7ZTV4J_cjs=require('./chunk-UJ7ZTV4J.cjs'),chunkGNFE24S7_cjs=require('./chunk-GNFE24S7.cjs'),j=require('ajv-formats'),module$1=require('module');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var j__default=/*#__PURE__*/_interopDefault(j);var h={$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"},presentation:{type:"object",description:"Semantic presentation hints authored on the card, expressed from the user's perception of the card on the Main Canvas. Content shape is inferred from view.elements[].kind; runtime placement and live drag/resize coordinates are frontend-managed and must not be authored into card JSON.",properties:{prominence:{type:"string",default:"standard",description:"How much the user should care about this card / how much attention it earns. Default: standard; omit unless a non-standard value is needed.",enum:["glance","standard","feature","spotlight"]},footprint:{type:"string",default:"standard",description:"How much room the card wants to render well, independent of attention. Default: standard; omit unless a non-standard value is needed.",enum:["compact","standard","wide","large"]},resizable:{type:"boolean",default:true,description:"Whether the user may resize this card at runtime. Default: true; omit unless it must be false."}},additionalProperties:true},tags:{type:"array",items:{type:"string"}}},additionalProperties:true},__private:{description:"Control-plane-owned private state. Stripped entirely from all regular /mcp read responses. Writable only via 'setstate.card-private' and 'manage.admin-upsert-card'. Agents must never author this field. Keys inside use plain names (no leading underscores).",type:"object",additionalProperties:true},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"}},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"}}}}},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"},__private:{$ref:"#/definitions/__private"},view:{$ref:"#/definitions/view"},card_data:{type:"object",description:"User editable data on card. Includes uploaded-file metadata maintained by host handlers. Not to be used for card static content.",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"},chat:{type:"boolean",description:"Whether this file entry is associated with a chat interaction"}},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.",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 _=chunkGNFE24S7_cjs.b(chunkUJ7ZTV4J_cjs.q(),1);var k=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-QEHKMLHA.cjs', document.baseURI).href))),q=k("./jsonata-sync.cjs"),f=null;var g=/\b(card_data|requires|fetched_sources|computed_values|source_defs)\b/g,N=/^\s*(card_data|requires|fetched_sources|computed_values|source_defs)(\.|$)/;function S(e){let t=new Set,s;for(g.lastIndex=0;(s=g.exec(e))!==null;)t.add(s[1]);return t}function v(e){let t=N.exec(e);return t?t[1]:null}function b(e,t,s,a){try{q(e);}catch(o){let d=o instanceof Error?o.message:String(o);a.push(`${t}: invalid JSONata expression (${d})`);return}let i=S(e);for(let o of i)s.has(o)||a.push(`${t}: disallowed namespace "${o}" in expression`);}function y(e,t,s){if(Array.isArray(e)){e.forEach((i,o)=>{y(i,`${t}/${o}`,s);});return}if(typeof e=="string"){let i=v(e);if(!i)return;new Set(["card_data","requires","computed_values"]).has(i)||s.push(`${t}: disallowed namespace "${i}" in view reference`);return}if(!e||typeof e!="object")return;let a=e;for(let[i,o]of Object.entries(a))y(o,`${t}/${i}`,s);}function E(){if(f)return f;let e=new _.default({allErrors:true});return j__default.default(e),f=e.compile(h),f}function O(e){let t=E(),s=t(e),a=(t.errors??[]).map(i=>`${i.instancePath||"/"}: ${i.message??"unknown error"}`);if(e&&typeof e=="object"&&!Array.isArray(e)){let i=e.source_defs;if(Array.isArray(i)){let o=new Set,d=new Set;i.forEach((c,u)=>{if(!c||typeof c!="object"||Array.isArray(c))return;let r=c;typeof r.bindTo=="string"&&r.bindTo&&(o.has(r.bindTo)&&a.push(`/source_defs/${u}/bindTo: bindTo "${r.bindTo}" must be unique across all source_defs`),o.add(r.bindTo)),typeof r.outputFile=="string"&&r.outputFile&&(d.has(r.outputFile)&&a.push(`/source_defs/${u}/outputFile: outputFile "${r.outputFile}" must be unique across all source_defs`),d.add(r.outputFile));});}}return !s||a.length>0?{ok:false,errors:a}:{ok:true,errors:[]}}function R(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:true,errors:[]};let s=e,a=s.compute;Array.isArray(a)&&a.forEach((r,p)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let n=r.expr;typeof n!="string"||n.trim().length===0||b(n,`/compute/${p}/expr`,new Set(["card_data","requires","fetched_sources","computed_values"]),t);});let i=new Set(["card_data","requires","fetched_sources","computed_values"]),o=s.provides;Array.isArray(o)&&o.forEach((r,p)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let n=r.ref;if(typeof n!="string"||n.trim().length===0)return;let l=v(n);l===null?t.push(`/provides/${p}/ref: path "${n}" must start with a valid namespace (${[...i].join(", ")})`):i.has(l)||t.push(`/provides/${p}/ref: disallowed namespace "${l}" in path "${n}" (valid: ${[...i].join(", ")})`);});let d=s.view;d&&typeof d=="object"&&!Array.isArray(d)&&y(d,"/view",t);let c=new Set(["card_data","requires"]),u=s.source_defs;return Array.isArray(u)&&u.forEach((r,p)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let n=r.projections;if(!(!n||typeof n!="object"||Array.isArray(n)))for(let[l,m]of Object.entries(n))typeof m!="string"||m.trim().length===0||b(m,`/source_defs/${p}/projections/${l}`,c,t);}),{ok:t.length===0,errors:t}}function V(e){return T(e)}function T(e){let t=O(e);if(!t.ok)return t;let s=R(e);return s.ok?{ok:true,errors:[]}:{ok:false,errors:s.errors}}
2
- exports.a=O;exports.b=R;exports.c=V;exports.d=T;//# sourceMappingURL=chunk-QEHKMLHA.cjs.map
3
- //# sourceMappingURL=chunk-QEHKMLHA.cjs.map
@@ -1,3 +0,0 @@
1
- import {b as b$2}from'./chunk-PEJRTZU3.js';import {a as a$1}from'./chunk-X32SJDLT.js';import {q as q$1,p,a as a$3,t}from'./chunk-FULAMLUU.js';import {a,G,i,h,z,B,D,l,q as q$2,F,E,A,g,b as b$3,c,d,e as e$1,f as f$1,r,k,j,y,x,w,v}from'./chunk-WGYS2L4V.js';import {a as a$2,b as b$1}from'./chunk-44L64VQ2.js';import {a as a$4}from'./chunk-ATOQP3BD.js';import {e,f}from'./chunk-UGB7PC4P.js';async function mt(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function Pt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Pe(e,o){return Pt(e)?e.then(o):o(e)}function lt(e,o){let a={...e};for(let[r,s]of Object.entries(o))s!==null&&typeof s=="object"&&!Array.isArray(s)&&a[r]!==null&&typeof a[r]=="object"&&!Array.isArray(a[r])?a[r]=lt(a[r],s):a[r]=s;return a}function ve(e,o,a){if(o.length===0)return e;let[r,...s]=o;if(s.length===0)return {...e,[r]:a};let d=e[r]!==null&&typeof e[r]=="object"&&!Array.isArray(e[r])?e[r]:{};return {...e,[r]:ve(d,s,a)}}function ft(e){return {read:a=>e.read(a),get(a,r){return Pe(e.read(a),s=>{if(s===null)return null;let d=s;for(let f of r.split(".").filter(Boolean)){if(d===null||typeof d!="object"||Array.isArray(d))return null;d=d[f]??null;}return d??null})},write:(a,r)=>e.write(a,r),delete:a=>e.delete(a),listKeys:a=>e.listKeys(a),shallowMerge(a,r){return Pe(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return Pe(e.read(a),s=>e.write(a,lt(s??{},r)))},patch(a,r,s){return Pe(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,ve(d??{},f,s))})}}}function gt(e){return ft(e)}function pt(e,o){return {async readIndex(){return await e.read("_index")},writeIndex(a){return e.write("_index",a)},async readCard(a){return await e.read(a)},async writeCard(a,r){return await e.write(a,r),o(r)},removeCard(a){return e.delete(a)},async cardExists(a){return await e.read(a)!==null},defaultCardKey(a){return a}}}function yt(e,o){async function a(){return await e.readIndex()??{}}return {async readCard(r){let s=(await a())[r];return !s||!await e.cardExists(s.key)?null:await e.readCard(s.key)},async readCardKey(r){return (await a())[r]?.key??null},async readAllCards(){let r=[];for(let[s,d]of Object.entries(await a())){if(!await e.cardExists(d.key))continue;let f=await e.readCard(d.key);f?r.push(f):o?.(`[card-store] could not read card "${s}" at key "${d.key}"`);}return r},async readChecksumIndex(){let r={};for(let[s,d]of Object.entries(await a()))r[s]=d.checksum;return r},async changedSince(r){let s=await a(),d=[];for(let[f,v]of Object.entries(s))r[f]!==v.checksum&&d.push(f);for(let f of Object.keys(r))s[f]||d.push(f);return d},async validateUpsert(r,s){let d=await a(),f=d[r],v=Object.entries(d).find(([,w])=>w.key===s);return f&&f.key!==s?{ok:false,error:`Card id "${r}" is already mapped to key "${f.key}", cannot remap to "${s}"`}:v&&v[0]!==r?{ok:false,error:`Key "${s}" is already mapped to card id "${v[0]}", cannot remap to "${r}"`}:{ok:true}},async writeCard(r,s,d){let f=await a(),v=d??f[r]?.key??e.defaultCardKey(r),w=await e.writeCard(v,s);f[r]={key:v,checksum:w,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async patchCard(r,s,d){let f=await a(),v=f[r];if(!v||!await e.cardExists(v.key))throw new Error(`card "${r}" not found`);let w=await e.readCard(v.key);if(!w||typeof w!="object"||Array.isArray(w))throw new Error(`card "${r}" is not patchable`);let m=String(s||"").split(".").filter(Boolean),l=ve(w,m,d),S=await e.writeCard(v.key,l);f[r]={key:v.key,checksum:S,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async removeCard(r){let s=await a(),d=s[r];d&&(await e.removeCard(d.key),delete s[r],await e.writeIndex(s));},readIndex(){return a()}}}function Nt(e,o){return a(e,o)}function _t(e,o,a){return {blob:e,kv:o,journal:a}}function St(e$1,o={}){function a(m){return {status:"success",data:m}}function r(m){return {status:"fail",error:m}}function s(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}async function d(m){let l=o.emitNotification;if(!l||m.length===0)return;let S=e(m);if(S.length===1){await l(S[0]);return}await l(f({kind:"notification-batch",notifications:S}));}async function f$1(m){let l=m.params?.id;if(l){let S=await e$1.readCard(l);if(!S)throw new Error(`card "${l}" not found`);return [S]}return await e$1.readAllCards()}function v(m){return f({kind:"notification-batch",notifications:e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function w(m){if(Array.isArray(m))return m;if(m&&typeof m=="object"){let l=m;return Array.isArray(l.files)?l.files:[m]}return null}return {async get(m){try{return a({cards:await f$1(m)})}catch(l){return s(l)}},async buildNotificationBatch(m){try{return a(v(await f$1(m)))}catch(l){return s(l)}},async set(m){try{let l=m.body;if(l==null)return r("set requires a body (card object or array of cards)");let S=Array.isArray(l)?l:[l];for(let h of S){if(typeof h.id!="string")return r("each card must have a string `id` field");await e$1.writeCard(h.id,h);}return await d(S.map(h=>({kind:"card_refreshed",cardId:h.id,card:h}))),a({count:S.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],S=m.params?.id,h=S?[...l,S]:l;if(h.length===0)return r("del requires body.ids (string[]) or params.id");for(let N of h)await e$1.removeCard(N);return await d(h.map(N=>({kind:"card_removed",cardId:N}))),a({count:h.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,S=m.params?.path;if(!l)return r("patch requires params.id");if(!S)return r("patch requires params.path");let h=m.body,N=h&&Object.prototype.hasOwnProperty.call(h,"value")?h.value:m.body;await e$1.patchCard(l,S,N);let O=await e$1.readCard(l);return O?(await d([{kind:"card_refreshed",cardId:l,card:O}]),a({count:1})):r(`card "${l}" not found`)}catch(l){return s(l)}},async appendFiles(m){try{let l=m.params?.id;if(!l)return r("appendFiles requires params.id");let S=await e$1.readCard(l);if(!S)return r(`card "${l}" not found`);let h=w(m.body);if(!h||h.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let N=S.card_data&&typeof S.card_data=="object"&&!Array.isArray(S.card_data)?S.card_data:{},O=Array.isArray(N.files)?N.files:[],M=[...O,...h],V=h.map(($,Z)=>({idx:O.length+Z,entry:$})),K=await this.patch({params:{id:l,path:"card_data.files"},body:{value:M}});return K.status!=="success"?K:a({files_added:V})}catch(l){return s(l)}}}}async function vt(e,o){return (await e.peekActive()).find(a=>a.id===o)}function $t(e$1,o={}){async function a(r){let s=o.emitNotification;if(!s||r.length===0)return;let d=e(r);if(d.length===1){await s(d[0]);return}await s(f({kind:"notification-batch",notifications:d}));}return {async enqueue(r){let s=await e$1.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await e$1.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:e$1.enqueueIfAbsent?async(r,s)=>{let d=await e$1.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return e$1.lease(r)},ack(r,s){return e$1.ack(r,s)},nack(r,s,d){return e$1.nack(r,s,d)},peekActive(r){return e$1.peekActive(r)},peekDeadLetter(r){return e$1.peekDeadLetter(r)},async stage(r,s){return e$1.stage(r,s)},async commitStaged(r){let s=await e$1.commitStaged(r);if(s){let d=await vt(e$1,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return e$1.discardStaged(r,s)},peekStaged(r){return e$1.peekStaged(r)}}}function b(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function T(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function q(){return new Date().toISOString()}function bt(e){let o=new TextEncoder().encode(e),a=Array.from(o,r=>String.fromCharCode(r)).join("");return btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Rt(e){let o=e.replace(/-/g,"+").replace(/_/g,"/"),a=o+"=".repeat((4-o.length%4)%4),r=atob(a),s=Uint8Array.from(r,d=>d.charCodeAt(0));return new TextDecoder().decode(s)}function be(e){try{let o=JSON.parse(Rt(e));return typeof o?.t=="string"?{taskName:o.t}:null}catch{return null}}function kt(e){return bt(JSON.stringify(e))}function Ct(e){try{let o=JSON.parse(Rt(e));return typeof o?.cbk=="string"&&typeof o?.cid=="string"&&typeof o?.b=="string"&&typeof o?.d=="string"?o:null}catch{return null}}function At(e){return f$1(e,r,()=>({_sources:{}}))}function It(e,o){return d(e,o)}function xt(e){return g(e)}function Tt(e,o){return e$1(e,o)}function Ot(e,o,a,r,s,d){return async f=>{let v$1=[],w$1=await a.cardStore.readCard(f.nodeId);if(!w$1)return "task-initiate-failure";let m=w$1.id;if(m===i){let p=a.activeTaskConfigs?.(),y={[h]:p?k((await Promise.all(Object.keys(p).filter(k=>k!==i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w$1.card_data??{},S=w$1.source_defs??[],h$1=S,N=await a.cardRuntimeStore.readRuntime(m),O=false,M=async()=>{O&&(await a.cardRuntimeStore.writeRuntime(m,N),O=false);},V=p=>v(N._sources[p]),K=(p,y)=>{N._sources[p]=v(y),O=true;},$=f.taskState?.executionCount??0;if(N._lastExecutionCount!==$&&(N._sources={},N._lastExecutionCount=$,O=true),f.update){let p=f.update.outputFile;if(p){let y$1=V(p);if(f.update.failure){let k=f.update.rqt??y$1.lastRequestedToken??y$1.queueRequestedToken;k&&K(p,y(y$1,k));}else {let k=f.update.rqt;if(!y$1.lastCompletedToken||k>y$1.lastCompletedToken){let j=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,re=j?await a.fetchedSourcesStore.commitSourceData(m,p,j):false;K(p,re?x(y$1,k):y(y$1,k));}}await M();}}let Z={};for(let p of S){if(!p.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,p.outputFile);y!==null&&(Z[p.bindTo]=y);}let H={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];H[p]=k!==void 0?k:y;}else H[p]=y;let ee={id:m,card_data:{...l},requires:H,source_defs:S,compute:w$1.compute};ee._sourcesData=Z,w$1.compute&&a$4.runSync(ee,{sourcesData:Z}),(s??(()=>{}))(m,ee.computed_values??{});let te=a$4.enrichSourcesSync(Array.isArray(w$1.source_defs)?w$1.source_defs:void 0,{card_data:w$1.card_data,requires:H}),Ae={...w$1,source_defs:Array.isArray(te)?te.map(p=>({...p,boardDir:typeof p.boardDir=="string"&&p.boardDir?p.boardDir:e.value})):te},W=q(),E=f.update?void 0:W,ge=h$1.filter(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return true;let k=V(y);E&&(k={...k,queueRequestedToken:E},K(y,k));let j=k.queueRequestedToken??k.lastRequestedToken??W;return w(k,j)==="dispatch"});if(await M(),ge.length>0){let p=false,y=W;for(let k of ge){let j=k.outputFile;if(typeof j!="string"||!j)continue;let re=V(j),L=re.queueRequestedToken??W;K(j,{...re,lastRequestedToken:L}),y=L,p=true;}return p&&await M(),p&&(v$1.push({taskKind:"source-fetch",payload:{boardRef:a$2(e),enrichedCard:Ae,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v$1)),"task-initiated"}if(h$1.some(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return false;let k=V(y),j=k.queueRequestedToken??k.lastRequestedToken??W;return w(k,j)==="in-flight"}))return "task-initiated";let ie=w$1.provides??[],ue={};for(let{bindTo:p,ref:y}of ie)ue[p]=a$4.resolve(ee,y);return (d??(()=>{}))(ue),r(f.nodeId,ue),v$1.length>0&&await a.executionRequestStore.appendEntries(o,v$1),"task-initiated"}}function nr(e$1,o,a$4={}){a$1(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=a$2(e$1),f$1=a$4.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),v=null,w=a$4.boardRuntimeStoreRef,m=a$4.scratchStoreRef,l$1=a$4.taskExecutorRef,S=a$4.chatHandlerFlow;function h$1(){if(!w)throw new Error(`Board at ${e$1.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return w}function N(n){if(n.length!==0)try{let t=e(n),c=f({kind:"notification-batch",notifications:t});return Promise.resolve(f$1(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(t){s(`[async-board-live-cards-public] emitNotification failed: ${t instanceof Error?t.message:String(t)}`);return}}let O=()=>b$2(o.kvStorageForRef(h$1())),M=e$1.value,V=()=>b$3(a(()=>o.kvStorageForRef(h$1()),o.hashFn),"v1"),K=async()=>{let n=await O().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no outputs store configured.`);return xt(o.kvStorageForRef(n))},$=async()=>{let n=await O().readCardStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no card store configured.`);let t=o.kvStorageForRef(n);return yt(pt(gt(t),o.hashFn),s)};async function Z(){return !!(await V().readSnapshot(M)).values[q$2]}async function H(){let n=await V().readSnapshot(M);if(!n.values[q$2])throw new Error(`Board not initialized at ${e$1.value}`);return F(n.values)}async function ee(n,t){let c=await V().commitSnapshot(M,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:E(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let te=()=>c(o.journalStorageForRef(h$1()));async function Ae(){return l$1??await O().readTaskExecutorRef()}async function W(){return A(await(await K()).readAllDataObjects())}async function E$1(n){await te().appendEvent(n);}async function ge(){let n=await O().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function le(){return o.blobStorageForRef(await ge())}async function ie(){return It(await le(),n=>o.resolveBlob(n))}async function ue(n){let t=(await le()).keyRef?.(n);if(!t)throw new Error("configured fetched-sources store does not support keyRef");let c=await Promise.resolve(t);return a$2(c)}async function p$1(){let n=Tt(o.kvStorageForRef(h$1()),async(u,g)=>{let P=u.payload,B=(P.enrichedCard??{}).id??P.cardId??"unknown";await E$1({type:"task-failed",taskName:B,error:g,timestamp:q()});}),t$1=At(o.kvStorageForRef(h$1())),c=await le(),i$1=await ie(),A=await $(),I=await K(),F=new Map,C=new Map,x=[],Q=[],G=[],X=new Map,de=new Set,ce={async readRuntime(u){return F.get(u)??await t$1.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),Te[u]=g;}},Ie={async readSourceData(u,g){let P=`${u}/${g}`;return C.has(P)?C.get(P):await i$1.readSourceData(u,g)},ingestSourceDataStaged(u,g,P,D){return i$1.ingestSourceDataStaged(u,g,P,D)},async commitSourceData(u,g,P){let D=`${u}/.staged/${P}/${g}`,B=await c.read(D);if(B==null){let z=await Promise.resolve(c.keyRef?.(D));z&&(B=await o.resolveBlob(z));}if(B==null)return false;let U=`${u}/${g}`,ae=B.trim();try{C.set(U,JSON.parse(ae));}catch{C.set(U,ae);}return x.push({cardId:u,outputFile:g,deliveryToken:P}),true},async hasSource(u,g){let P=`${u}/${g}`;return C.has(P)||await i$1.hasSource(u,g)},async listSources(u){let g=await i$1.listSources(u),P=[...C.keys()].filter(D=>D.startsWith(`${u}/`)).map(D=>D.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await H(),De=q$1(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await te().readEntriesAfterCursor(xe.lastDrainedJournalId),pe=wt,Ve=()=>De.config.tasks,fe=t(De,{handlers:{"card-handler":Ot(e$1,Oe,{cardStore:A,cardRuntimeStore:ce,fetchedSourcesStore:Ie,outputStore:I,executionRequestStore:n,activeTaskConfigs:()=>Ve()},(u,g)=>{pe.push({type:"task-completed",taskName:u,data:g,timestamp:q()});},(u,g)=>{Q.push({cardId:u,values:g});},u=>{G.push(u);})},onNodeRemoved:u=>{X.delete(u),F.delete(u),delete Te[u],de.add(u);}});for(Ve=()=>fe.getState().config.tasks;pe.length>0;){let u=pe;pe=[];for(let g of u)if(g.type==="task-restart"){let P=await A.readCard(g.taskName);P&&X.set(g.taskName,P);}fe.pushAll(u),await fe.waitForHandlers();}let $e=fe.getState();await fe.dispose({wait:true}),await ee({lastDrainedJournalId:Oe,graph:p($e),runtimeByCardId:Te},(await V().readSnapshot(M)).version);for(let{cardId:u,values:g}of Q)await I.writeComputedValues(u,g);for(let u of G)await I.writeDataObjects(u);for(let[u,g]of F)await t$1.writeRuntime(u,g);for(let u of x)await i$1.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let Le=z(B(d,$e));await I.writeStatusSnapshot(Le);let me=[];for(let{cardId:u,values:g}of Q)me.push({kind:"computed_values",cardId:u,values:g});for(let u of G)for(let[g,P]of Object.entries(u))me.push({kind:"data_object",key:g,payload:P});for(let[u,g]of X)u!==i&&me.push({kind:"card_refreshed",cardId:u,card:g});for(let u of de)me.push({kind:"card_removed",cardId:u});me.push({kind:"status",status:Le}),await N(me);let ne=await Ae();if(!ne)return;let Je=o.supportsDirectSourceOutput?.(ne)===true;await n.dispatchEntriesForJournalId(Oe,async u=>{if(u.taskKind!=="source-fetch"){s(`[async-process-accumulated-events] unknown taskKind "${u.taskKind}" \u2014 skipping`);return}let g=u.payload,P=g.enrichedCard?.id??"unknown",D=g.enrichedCard?.source_defs??[];if(ne.howToRun==="queue-storage"&&Je){try{let B=await O().readQueueStoreRef();if(!B)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let U=o.queueStorageForRef(B,"task-executor"),ae=typeof ne.extra?.boardId=="string"?ne.extra.boardId:void 0,z=[];for(let Y of D){if(!Y.outputFile)continue;let ye=o.genId(),Se=`${P}/.staged/${ye}/${Y.outputFile}`,Me=await Promise.resolve(c.keyRef?.(Se));if(!Me)continue;let Qe={ref:a$2(Me),deliveryToken:ye,outputFile:Y.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e$1.value,br:a$2(e$1),cid:P,b:Y.bindTo,d:Y.outputFile,cs:void 0,rqt:g.rqt,dt:Qe.deliveryToken});z.push({...ae?{boardId:ae}:{},ref:ne,args:{source_def:Y,base_ref:a$2(e$1),callback:r.createCallback(ht),output:Qe}});}z.length>0&&await U.enqueueMany(z);}catch(B){await E$1({type:"task-failed",taskName:P,error:B instanceof Error?B.message:String(B),timestamp:q()});}return}for(let B of D){if(!B.outputFile)continue;let U;if(Je){let Y=o.genId(),ye=`${P}/.staged/${Y}/${B.outputFile}`,Se=await Promise.resolve(c.keyRef?.(ye));Se&&(U={ref:a$2(Se),deliveryToken:Y,outputFile:B.outputFile,cardId:P});}let ae=kt({cbk:g.callbackToken,rg:e$1.value,br:a$2(e$1),cid:P,b:B.bindTo,d:B.outputFile,cs:void 0,rqt:g.rqt,...U?{dt:U.deliveryToken}:{}}),z=await o.dispatchExecution(ne,{source_def:B,base_ref:a$2(e$1),callback:r.createCallback(ae),...U?{output:U}:{}});z.dispatched||await E$1({type:"task-failed",taskName:P,error:z.error??"dispatch failed",timestamp:q()});}});}async function y(){try{let n=async()=>{let c=await H(),{events:i}=await te().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await j();},t=await mt(o.lock,p$1,n);return b({ran:t!==!1})}catch(n){return T(n)}}async function k(){return v||(v=y().finally(()=>{v=null;}),v)}async function j(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);await o.queueStorageForRef(n,"process-accumulated").enqueue({boardRef:a$2(e$1)}),await o.requestProcessAccumulated?.();}async function re(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await t.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await t.ack(i.id,i.leaseToken);if(c.length<64)return}}function L(){j();}return {async init(n){try{let t=n.params?.cardStoreRef;if(!t)return R("init requires params.cardStoreRef");if(w=n.params?.boardRuntimeStoreRef,!w)return R("init requires params.boardRuntimeStoreRef");let c=n.params?.outputsStoreRef;if(!c)return R("init requires params.outputsStoreRef");let i$1=n.params?.queueStoreRef;if(!i$1)return R("init requires params.queueStoreRef");let A=n.params?.fetchedSourcesStoreRef;if(!A)return R("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let I=n.params?.chatStoreRef;if(!I)return R("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return R("init requires params.artifactsStoreRef");await Z()||await ee({lastDrainedJournalId:"",graph:p(a$3(D)),runtimeByCardId:{}},null);let C=O();await C.writeBoardRuntimeStoreRef(w),await C.writeCardStoreRef(t),await C.writeOutputsStoreRef(c),await C.writeQueueStoreRef(i$1),await C.writeFetchedSourcesStoreRef(A),await C.writeChatStoreRef(I),await C.writeArtifactsStoreRef(F),await(await $()).writeCard(i,l());let x=o.kvStorage("card-upsert"),Q=l(),G$1=G(Q),X=o.hashFn(G$1),ce=(await x.read(i))?.blobRef??await(await $()).readCardKey(i)??i;return await E$1({type:"task-upsert",taskName:i,taskConfig:G$1,timestamp:q()}),await x.write(i,{blobRef:ce,taskConfigHash:X,updatedAt:q()}),await E$1({type:"task-restart",taskName:i,timestamp:q()}),L(),await(await K()).writeStatusSnapshot(z(B(d,q$1((await H()).graph)))),b()}catch(t){return T(t)}},async status(n){try{let t=await K(),c=await t.readStatusSnapshot();return c||(c=z(B(d,q$1((await H()).graph))),await t.writeStatusSnapshot(c)),b(c)}catch(t){return T(t)}},async getCardStoreRef(n){try{let t=await O().readCardStoreRef();return t?b({storeRef:t}):R(`Board at ${e$1.value} has no card store configured`)}catch(t){return T(t)}},async getBoardRuntimeStoreRef(n){try{return b({storeRef:w??null})}catch(t){return T(t)}},async getOutputsStoreRef(n){try{let t=await O().readOutputsStoreRef();return t?b({storeRef:t}):R(`Board at ${e$1.value} has no outputs store configured`)}catch(t){return T(t)}},async getScratchStoreRef(n){try{return b({storeRef:m??null})}catch(t){return T(t)}},async getChatStoreRef(n){try{return b({storeRef:await O().readChatStoreRef()})}catch(t){return T(t)}},async getArtifactsStoreRef(n){try{return b({storeRef:await O().readArtifactsStoreRef()})}catch(t){return T(t)}},async getFetchedSourcesStoreRef(n){try{return b({storeRef:await O().readFetchedSourcesStoreRef()})}catch(t){return T(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return R("getConfig requires params.key");let c=O(),i;switch(t){case "task-executor":i=l$1??null;break;case "chat-handler-flow":i=S??null;break;case "board-runtime-store-ref":i=await c.readBoardRuntimeStoreRef();break;case "card-store-ref":i=await c.readCardStoreRef();break;case "outputs-store-ref":i=await c.readOutputsStoreRef();break;case "scratch-store-ref":i=m??null;break;case "chat-store-ref":i=await c.readChatStoreRef();break;case "artifacts-store-ref":i=await c.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=await c.readFetchedSourcesStoreRef();break;default:return R(`getConfig: unknown key "${t}"`)}return b({value:i})}catch(t){return T(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;if(!t)return R("getOutputsDataObject requires params.key");if(t===h)return b(null);let c=await W();return b(c[t]??null)}catch(t){return T(t)}},async getAllOutputsDataObjects(n){try{return b(await W())}catch(t){return T(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?b(await(await K()).readComputedValues(t)):R("getOutputsComputedValues requires params.key")}catch(t){return T(t)}},async getAllOutputsComputedValues(n){try{return b(await(await K()).readAllComputedValues())}catch(t){return T(t)}},async getOutputsFetchedSources(n){try{let t=n.params?.key;if(!t)return R("getOutputsFetchedSources requires params.key");let c=await(await ie()).listSources(t),i={};for(let A of c)i[A]=await ue(`${t}/${A}`);return b(i)}catch(t){return T(t)}},async getAllOutputsFetchedSources(n){try{let t=await ie(),c=await(await le()).listKeys(),i=new Set;for(let I of c){let F=I.indexOf("/");F>0&&!I.includes("/.staged/")&&i.add(I.slice(0,F));}let A={};for(let I of i){let F=await t.listSources(I);if(F.length!==0){A[I]={};for(let C of F)A[I][C]=await ue(`${I}/${C}`);}}return b(A)}catch(t){return T(t)}},async buildSseOneShotPayload(n){try{let t=(await(await $()).readAllCards()).filter(C=>C.id!==i),c=await this.status({});if(c.status!=="success")return c;let i$1=await this.getAllOutputsDataObjects({});if(i$1.status!=="success")return i$1;let A=await this.getAllOutputsComputedValues({});if(A.status!=="success")return A;let I=A.data,F={};for(let C of t){let x=typeof C?.id=="string"?C.id:null;if(!x)continue;let Q=C.card_data&&typeof C.card_data=="object"&&!Array.isArray(C.card_data)?C.card_data:{};F[x]={schema_version:"v1",card_id:x,card_data:{...Q},computed_values:I[x]&&typeof I[x]=="object"?I[x]:{}};}return b({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i$1.data,cardRuntimeById:F})}catch(t){return T(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return R("addCardFiles requires params.cardId");let i=await St(await $(),{emitNotification:f$1}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:b({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return T(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return R("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await E$1({type:"task-removal",taskName:t,timestamp:q()}),t!==i&&await E$1({type:"task-restart",taskName:i,timestamp:q()}),L(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await E$1({type:"task-restart",taskName:t,timestamp:q()}),L(),b()):R("retrigger requires params.id")}catch(t){return T(t)}},async processAccumulatedEvents(n){return await re(),k()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i$1=!!n.params?.restart;if(!t&&!c)return R("upsertCard requires --card-id <id> or --all");let A=await $(),I=c?(await A.readAllCards()).map(x=>x.id):[t];for(let x of I)if(!await A.readCard(x))return R(`Card "${x}" not found in board at ${e$1.value}`);let F=o.kvStorage("card-upsert"),C=!1;for(let x of I){let Q=await A.readCard(x);if(!Q)continue;let G$1=G(Q),X=o.hashFn(G$1),de=await F.read(x),ce=de?.taskConfigHash!==X;if(!(!ce&&!i$1)){if(ce){let Ie=de?.blobRef??await A.readCardKey(x)??x;await E$1({type:"task-upsert",taskName:x,taskConfig:G$1,timestamp:q()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:q()}),C=C||x!==i;}i$1&&await E$1({type:"task-restart",taskName:x,timestamp:q()});}}return C&&await E$1({type:"task-restart",taskName:i,timestamp:q()}),L(),b()}catch(t){return T(t)}},async taskFailed(n){try{let t=n.params?.token;if(!t)return R("taskFailed requires params.token");let c=n.params?.error??"unknown error",i=be(t);return i?(await E$1({type:"task-failed",taskName:i.taskName,error:c,timestamp:q()}),L(),b()):R("Invalid callback token")}catch(t){return T(t)}},async taskProgress(n){try{let t=n.params?.token;if(!t)return R("taskProgress requires params.token");let c=(n.body??{}).update??{},i=be(t);return i?(await E$1({type:"task-progress",taskName:i.taskName,update:c,timestamp:q()}),L(),b()):R("Invalid callback token")}catch(t){return T(t)}},async sourceDataFetched(n){try{let t=n.params?.token,c=n.params?.ref;if(!t)return R("sourceDataFetched requires params.token");if(!c)return R("sourceDataFetched requires params.ref");let i=Ct(t);if(!i)return R("Invalid source token");let A=await ie(),I=i.dt||o.genId();i.dt||await A.ingestSourceDataStaged(i.cid,i.d,b$1(c),I);let F=be(i.cbk);return F?(await E$1({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:q(),deliveryToken:I,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),L(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}},async sourceDataFetchFailure(n){try{let t=n.params?.token,c=n.params?.reason??"unknown";if(!t)return R("sourceDataFetchFailure requires params.token");let i=Ct(t);if(!i)return R("Invalid source token");let A=be(i.cbk);return A?(await E$1({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:q()}),L(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}}}}
2
- export{mt as a,gt as b,pt as c,yt as d,Nt as e,_t as f,St as g,$t as h,nr as i};//# sourceMappingURL=chunk-RKLEBQUG.js.map
3
- //# sourceMappingURL=chunk-RKLEBQUG.js.map
@@ -1,2 +0,0 @@
1
- import {b,c}from'./chunk-ANKA7HEJ.js';import {a as a$2}from'./chunk-44L64VQ2.js';import {a}from'./chunk-Q444D72R.js';import {a as a$1}from'./chunk-ATOQP3BD.js';import {e,f}from'./chunk-UGB7PC4P.js';function L(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function J(e,r){return L(e)?e.then(r):r(e)}function Z(e,r){let t={...e};for(let o of r.deleteKeys)delete t[o];return {...t,...r.shallowMerge}}function Re(e,r){return {readValues(o){let n=e(o);return J(n.listKeys(),s=>{let a=[...s].sort();if(a.length===0)return {version:null,values:{}};let i={},c=null;for(let g of a){let d=n.read(g);L(d)?c=(c??Promise.resolve()).then(async()=>{i[g]=await d;}):i[g]=d;}return c?c.then(()=>({version:r(i),values:i})):{version:r(i),values:i}})},writeValues(o,n,s){let a=e(o),i=null;for(let c of s){let g=a.delete(c);L(g)&&(i=(i??Promise.resolve()).then(()=>g).then(()=>{}));}for(let[c,g]of Object.entries(n)){let d=a.write(c,g);L(d)&&(i=(i??Promise.resolve()).then(()=>d).then(()=>{}));}return i?i.then(()=>r(n)):r(n)}}}function ee(e,r){return {readSnapshot(t){return e.readValues(t)},commitSnapshot(t,o){if(o.schemaVersion!==r)throw new Error(`Unsupported snapshot schema version: ${o.schemaVersion}`);return J(e.readValues(t),n=>{if(n.version!==o.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let s=Z(n.values,o);return J(e.writeValues(t,s,o.deleteKeys),a=>({ok:true,newVersion:a}))})}}}function X(e,r){if(!r)return e;let t=e.findIndex(o=>o.id===r);return t===-1?e:e.slice(t+1)}function te(e){return {readEntriesAfterCursor(r){let t=X(e.readAllEntries(),r);return t.length===0?{events:[],newCursor:r}:{events:t.map(o=>o.event),newCursor:t[t.length-1].id}},pendingCount(r){return X(e.readAllEntries(),r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function ve(e){return {appendEvent(r){return e.append(r).then(()=>{})},async readEntriesAfterCursor(r){let t=await e.readAfter(r||null);return {events:t.entries.map(o=>o.payload),newCursor:t.newCursor??r}}}}function j(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function v(e,r){return j(e)?e.then(r):r(e)}function M(e,r){let t=null;for(let o of e){if(t){t=t.then(()=>r(o)).then(()=>{});continue}let n=r(o);j(n)&&(t=Promise.resolve(n).then(()=>{}));}return t??void 0}function le(e){if(e==null)return null;let r=e.trim();if(!r)return null;try{return JSON.parse(r)}catch{return r}}function pe(e,r){let t=e.match(r);return t?t[1]:null}function re(e,r,t){let o={},n=M(e,s=>{let a=t(s);if(a)return v(r(s),i=>{o[a]=i;})});return j(n)?n.then(()=>o):o}function ne(e,r){return {readSourceData(t,o){return v(e.read(`${t}/${o}`),le)},ingestSourceDataStaged(t,o,n,s){return v(r(n),a=>e.write(`${t}/.staged/${s}/${o}`,a))},commitSourceData(t,o,n){let s=`${t}/.staged/${n}/${o}`,a=`${t}/${o}`;return e.renameKey(s,a)},hasSource(t,o){return e.exists(`${t}/${o}`)},listSources(t){return v(e.listKeys(`${t}/`),o=>o.filter(n=>!n.includes("/.staged/")).map(n=>n.slice(`${t}/`.length)))}}}function ge(e,r){let t=(o,n)=>{try{let s=n(o);return j(s)?s.catch(a=>r(o,a instanceof Error?a.message:String(a))):void 0}catch(s){try{return r(o,s instanceof Error?s.message:String(s))}catch{return}}};return {appendEntries(o,n){if(!(!o||n.length===0))return v(e.read(o),s=>e.write(o,[...s??[],...n]))},dispatchEntriesForJournalId(o,n){if(o)return v(e.read(o),s=>{let a=s;if(!(!a||a.length===0))return v(M(a,i=>t(i,n)),()=>e.delete(o))})}}}function fe(e,r,t){return {readRuntime(o){return v(e.read(r(o)),n=>n??t())},writeRuntime(o,n){return e.write(r(o),n)}}}function oe(e){return {writeComputedValues(r,t){return e.write(`cards/${r}/computed_values`,t)},readComputedValues(r){return e.read(`cards/${r}/computed_values`)},readAllComputedValues(){return v(e.listKeys("cards/"),r=>re(r,t=>e.read(t),t=>pe(t,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(r){return M(Object.entries(r),([t,o])=>{if(t)return o===void 0?e.delete(`data-objects/${t}`):e.write(`data-objects/${t}`,o)})},readDataObject(r){return e.read(`data-objects/${r}`)},readAllDataObjects(){return v(e.listKeys("data-objects/"),r=>re(r,t=>e.read(t),t=>t.slice(13)))},writeStatusSnapshot(r){return e.write("status",r)},readStatusSnapshot(){return e.read("status")}}}var _="sys_keys_board_state",I="__sys_keys_board_state_init";function de(e){if(!e||typeof e!="object"||Array.isArray(e))return false;let r=e.__private;return !!r&&typeof r=="object"&&!Array.isArray(r)&&r.visible_controlplane_only===true}function me(e){let r=e.filter(n=>!de(n)),t=[...new Set(r.map(n=>n.id).filter(n=>typeof n=="string"&&n.length>0))].sort(),o=[...new Set(r.flatMap(n=>Array.isArray(n.provides)?n.provides:[]).map(n=>n&&typeof n=="object"&&!Array.isArray(n)?n.bindTo:void 0).filter(n=>typeof n=="string"&&n.length>0&&n!==_))].sort();return {card_ids:t,data_object_keys:o}}function Se(e,r){let t=e.filter(s=>!de(s)),o=[...new Set(t.map(s=>s.id).filter(s=>typeof s=="string"&&s.length>0))].sort(),n=[...new Set(Object.entries(r).filter(([s])=>s!==I).flatMap(([,s])=>Array.isArray(s.provides)?s.provides:[]).filter(s=>typeof s=="string"&&s.length>0&&s!==_))].sort();return {card_ids:o,data_object_keys:n}}function Fe(){return {id:I,meta:{title:"System Keys Board State",synthetic:true},provides:[{bindTo:_,ref:`card_data.${_}`}],card_data:{[_]:{card_ids:[],data_object_keys:[]}},__private:{visible_controlplane_only:true}}}function Ve(e,r){function t(){return e.readIndex()??{}}function o(n,s,a){let i=String(s||"").split(".").filter(Boolean);if(i.length===0)return a&&typeof a=="object"&&!Array.isArray(a)?a:{value:a};let c={...n},g=c;for(let d=0;d<i.length-1;d++){let u=i[d],l=g[u],y=l&&typeof l=="object"&&!Array.isArray(l)?{...l}:{};g[u]=y,g=y;}return g[i[i.length-1]]=a,c}return {readCard(n){let s=t()[n];return !s||!e.cardExists(s.key)?null:e.readCard(s.key)},readCardKey(n){return t()[n]?.key??null},readAllCards(){let n=[];for(let[s,a]of Object.entries(t())){if(!e.cardExists(a.key))continue;let i=e.readCard(a.key);i?n.push(i):r?.(`[card-store] could not read card "${s}" at key "${a.key}"`);}return n},readChecksumIndex(){let n={};for(let[s,a]of Object.entries(t()))n[s]=a.checksum;return n},changedSince(n){let s=t(),a=[];for(let[i,c]of Object.entries(s))n[i]!==c.checksum&&a.push(i);for(let i of Object.keys(n))s[i]||a.push(i);return a},validateUpsert(n,s){let a=t(),i=a[n],c=Object.entries(a).find(([,g])=>g.key===s);return i&&i.key!==s?{ok:false,error:`Card id "${n}" is already mapped to key "${i.key}", cannot remap to "${s}"`}:c&&c[0]!==n?{ok:false,error:`Key "${s}" is already mapped to card id "${c[0]}", cannot remap to "${n}"`}:{ok:true}},writeCard(n,s,a){let i=t(),c=a??i[n]?.key??e.defaultCardKey(n),g=e.writeCard(c,s);i[n]={key:c,checksum:g,updatedAt:new Date().toISOString()},e.writeIndex(i);},patchCard(n,s,a){let i=t(),c=i[n];if(!c||!e.cardExists(c.key))throw new Error(`card "${n}" not found`);let g=e.readCard(c.key);if(!g||typeof g!="object"||Array.isArray(g))throw new Error(`card "${n}" is not patchable`);let d=o(g,s,a),u=e.writeCard(c.key,d);i[n]={key:c.key,checksum:u,updatedAt:new Date().toISOString()},e.writeIndex(i);},removeCard(n){let s=t(),a=s[n];a&&(e.removeCard(a.key),delete s[n],e.writeIndex(s));},readIndex(){return t()}}}function Pe(e,r){return ne(e,r)}function Ke(e){return te(e)}var ye="v1",U="board/graph",ue="board/lastJournalProcessedId";function qe(e){return `cards/${e}/runtime`}function Be(e){return ee(e,ye)}function Le(e){function r(t){let o=e.read(t);return o==null?null:typeof o=="string"?o:JSON.stringify(o)}return {readTaskExecutorRef(){let t=r("task-executor");if(t?.trim())return c(t.trim())},writeTaskExecutorRef(t){e.write("task-executor",b(t));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(t){e.write("chat-handler-flow",t);},readBoardRuntimeStoreRef(){return r("board-runtime-store-ref")},writeBoardRuntimeStoreRef(t){e.write("board-runtime-store-ref",t);},readCardStoreRef(){return r("card-store-ref")},writeCardStoreRef(t){e.write("card-store-ref",t);},readOutputsStoreRef(){return r("outputs-store-ref")},writeOutputsStoreRef(t){e.write("outputs-store-ref",t);},readQueueStoreRef(){return r("queue-store-ref")},writeQueueStoreRef(t){e.write("queue-store-ref",t);},readScratchStoreRef(){return r("scratch-store-ref")},writeScratchStoreRef(t){e.write("scratch-store-ref",t);},readChatStoreRef(){return r("chat-store-ref")},writeChatStoreRef(t){e.write("chat-store-ref",t);},readArtifactsStoreRef(){return r("artifacts-store-ref")},writeArtifactsStoreRef(t){e.write("artifacts-store-ref",t);},readFetchedSourcesStoreRef(){return r("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(t){e.write("fetched-sources-store-ref",t);}}}function je(e){return oe(e)}function se(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function he(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function ie(e,r){return e?.lastRequestedToken?he(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<r?"dispatch":"idle":"dispatch"}function ke(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"success"}}function ae(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"failure"}}function De(e){let r=e.cards.filter(i=>i.name!==I);if(r.length===e.cards.length)return e;let t=new Set;for(let i of r)for(let c of i.requires)t.add(c);let o=r.map(i=>({name:i.name,fanOut:i.unblocks.length})).sort((i,c)=>c.fanOut-i.fanOut||i.name.localeCompare(c.name)),n=o.length>0?o[0]:{name:null,fanOut:0},s=i=>r.filter(c=>c.status===i).length,a=r.filter(i=>i.requires.length===0&&i.unblocks.length===0).length;return {...e,summary:{...e.summary,card_count:r.length,completed:s("completed"),eligible:s("eligible"),pending:s("pending"),blocked:s("blocked"),unresolved:s("unresolved"),failed:s("failed"),in_progress:s("in-progress"),orphan_cards:a,topology:{edge_count:t.size,max_fan_out_card:n.name,max_fan_out:n.fanOut}},cards:r}}function $e(e){let{[_]:r,...t}=e;return t}function Ne(e,r){let t=r.state.tasks,o=r.config.tasks,n=Object.keys(t),s=a(r),a$1={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},i=new Map;for(let p of s.pending)i.set(p.taskName,p.waitingOn);for(let p of s.unresolved)i.set(p.taskName,p.missingTokens);for(let p of s.blocked)i.set(p.taskName,p.failedTokens);let c=new Map;for(let[p,f]of Object.entries(o))for(let w of f.requires??[]){let C=c.get(w)??[];C.push(p),c.set(w,C);}let g=n.sort().map(p=>{let f=t[p],w=o[p]??{requires:[],provides:[]};f.status==="completed"?a$1.completed+=1:f.status==="failed"?a$1.failed+=1:f.status==="in-progress"&&(a$1.in_progress+=1);let C=w.requires??[],R=w.provides??[],b=Object.keys(f.data??{}).sort(),O=C.filter(T=>r.state.availableOutputs.includes(T)),F=C.filter(T=>!r.state.availableOutputs.includes(T)),V=i.get(p)??F,E=new Set;for(let T of R)for(let x of c.get(T)??[])x!==p&&E.add(x);let q=f.failedAt,P=f.error?{message:f.error,code:"TASK_FAILED",at:q,source:"task-runtime"}:void 0;return {name:p,status:f.status,error:P,requires:C,requires_satisfied:O,requires_missing:F,provides_declared:R,provides_runtime:b,blocked_by:V,unblocks:Array.from(E).sort(),runtime:{attempt_count:f.executionCount??0,restart_count:f.retryCount??0,in_progress_since:f.status==="in-progress"?f.startedAt??null:null,last_transition_at:f.lastUpdated??null,last_completed_at:f.completedAt??null,last_restarted_at:f.startedAt??null,status_age_ms:f.lastUpdated?0:null}}});a$1.pending=s.pending.length,a$1.blocked=s.blocked.length,a$1.unresolved=s.unresolved.length;let d=g.map(p=>({name:p.name,fanOut:p.unblocks.length})).sort((p,f)=>f.fanOut-p.fanOut||p.name.localeCompare(f.name)),u=d.length>0?d[0]:{name:null,fanOut:0},l=new Set;for(let p of Object.values(o))for(let f of p.requires??[])l.add(f);let y=0;for(let[p,f]of Object.entries(o)){let w=(f.requires??[]).length===0,R=(f.provides??[]).some(b=>(c.get(b)??[]).some(O=>O!==p));w&&!R&&(y+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:n.length,completed:a$1.completed,eligible:s.eligible.length,pending:a$1.pending,blocked:a$1.blocked,unresolved:a$1.unresolved,failed:a$1.failed,in_progress:a$1.in_progress,orphan_cards:y,topology:{edge_count:Array.from(l).length,max_fan_out_card:u.name,max_fan_out:u.fanOut}},cards:g}}function Ce(){return new Date().toISOString()}function Je(e,r,t,o,n,s,a){return async i=>{let c=[],g=t.cardStore.readCard(i.nodeId);if(!g)return "task-initiate-failure";let d=g.id;if(d===I){let m=t.activeTaskConfigs?.(),S={[_]:m?Se(Object.keys(m).filter(h=>h!==I).map(h=>t.cardStore.readCard(h)).filter(h=>!!h),m):me(t.cardStore.readAllCards())};return (a??t.outputStore.writeDataObjects.bind(t.outputStore))(S),o(i.nodeId,S),"task-initiated"}let u=g.card_data??{},l=g.source_defs??[],y=l,p=t.cardRuntimeStore.readRuntime(d),f=false,w=()=>{f&&(t.cardRuntimeStore.writeRuntime(d,p),f=false);},C=m=>se(p._sources[m]),R=(m,S)=>{p._sources[m]=se(S),f=true;},b=i.taskState?.executionCount??0;if(p._lastExecutionCount!==b&&(p._sources={},p._lastExecutionCount=b,f=true),i.update){let m=i.update,S=m.outputFile;if(S){let h=C(S);if(m.failure){let k=m.rqt??h.lastRequestedToken??h.queueRequestedToken;k&&R(S,ae(h,k));}else {let k=m.rqt;if(!h.lastCompletedToken||k>h.lastCompletedToken){let A=typeof m.deliveryToken=="string"?m.deliveryToken:void 0,K=false;A&&(K=t.fetchedSourcesStore.commitSourceData(d,S,A)),K?R(S,ke(h,k)):R(S,ae(h,k));}}w();}}let F={};for(let m of l)if(m.outputFile){let S=t.fetchedSourcesStore.readSourceData(d,m.outputFile);S!==null&&(F[m.bindTo]=S);}let V={};for(let[m,S]of Object.entries(i.state??{}))if(S!==null&&typeof S=="object"&&!Array.isArray(S)){let h=S[m];V[m]=h!==void 0?h:S;}else V[m]=S;let E={id:d,card_data:{...u},requires:V,source_defs:l,compute:g.compute};E._sourcesData=F,g.compute&&a$1.runSync(E,{sourcesData:F}),(s??t.outputStore.writeComputedValues.bind(t.outputStore))(d,E.computed_values??{});let q={...g},P=a$1.enrichSourcesSync(Array.isArray(g.source_defs)?g.source_defs:void 0,{card_data:g.card_data,requires:V}),T=e.value;q.source_defs=Array.isArray(P)?P.map(m=>({...m,boardDir:typeof m.boardDir=="string"&&m.boardDir?m.boardDir:T})):P;let x=Ce(),H=i.update?void 0:x,G=y.filter(m=>{let S=m.outputFile;if(typeof S!="string"||!S)return true;let h=C(S);H&&(h={...h,queueRequestedToken:H},R(S,h));let k=h.queueRequestedToken??h.lastRequestedToken??x,A=ie(h,k);return A==="in-flight"?false:A==="dispatch"});if(w(),G.length>0){let m=false,S=x;for(let h of G){let k=h.outputFile;if(typeof k!="string"||!k)continue;let A=C(k),K=A.queueRequestedToken??x;R(k,{...A,lastRequestedToken:K}),S=K,m=true;}return m&&w(),m&&(c.push({taskKind:"source-fetch",payload:{boardRef:a$2(e),enrichedCard:q,callbackToken:i.callbackToken,rqt:S}}),t.executionRequestStore.appendEntries(r,c)),"task-initiated"}if(y.some(m=>{let S=m.outputFile;if(typeof S!="string"||!S)return false;let h=C(S),k=h.queueRequestedToken??h.lastRequestedToken??x;return ie(h,k)==="in-flight"}))return "task-initiated";let ce=g.provides??[],D={};for(let{bindTo:m,ref:S}of ce)D[m]=a$1.resolve(E,S);return (a??t.outputStore.writeDataObjects.bind(t.outputStore))(D),o(i.nodeId,D),c.length>0&&t.executionRequestStore.appendEntries(r,c),"task-initiated"}}var Me={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function Ue(e){return {[U]:e.graph,[ue]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function He(e){let r=e[U],t=e[ue],n=e.board?.runtimeByCardId;if(!r||typeof r!="object")throw new Error(`State snapshot is missing required key: ${U}`);return {graph:r,lastDrainedJournalId:typeof t=="string"?t:"",runtimeByCardId:n&&typeof n=="object"?n:{}}}function Ge(e){let r=e.requires;return {provides:e.provides?.map(o=>o.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...r&&r.length>0?{requires:r}:{}}}function We(e$1,r={}){function t(d){return {status:"success",data:d}}function o(d){return {status:"fail",error:d}}function n(d){return {status:"error",error:d instanceof Error?d.message:String(d)}}function s(d){return d===I}async function a(d){let u=r.emitNotification;if(!u||d.length===0)return;let l=e(d.filter(y=>y.kind!=="card_refreshed"?true:!s(y.cardId)));if(l.length!==0){if(l.length===1){await u(l[0]);return}await u(f({kind:"notification-batch",notifications:l}));}}function i(d){let u=d.params?.id;if(u){if(s(u))throw new Error(`card "${u}" not found`);let l=e$1.readCard(u);if(!l)throw new Error(`card "${u}" not found`);return [l]}return e$1.readAllCards().filter(l=>!s(l.id))}function c(d){let u=d.filter(l=>!s(l.id));return f({kind:"notification-batch",notifications:e(u.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function g(d){if(Array.isArray(d))return d;if(d&&typeof d=="object"){let u=d;return Array.isArray(u.files)?u.files:[d]}return null}return {get(d){try{return t({cards:i(d)})}catch(u){return n(u)}},buildNotificationBatch(d){try{return t(c(i(d)))}catch(u){return n(u)}},set(d){try{let u=d.body;if(u==null)return o("set requires a body (card object or array of cards)");let l=Array.isArray(u)?u:[u];for(let y of l){if(typeof y.id!="string")return o("each card must have a string `id` field");e$1.writeCard(y.id,y);}return a(l.map(y=>({kind:"card_refreshed",cardId:y.id,card:y}))),t({count:l.length})}catch(u){return n(u)}},del(d){try{let u=d.body?.ids??[],l=d.params?.id,y=l?[...u,l]:u;if(y.length===0)return o("del requires body.ids (string[]) or params.id");for(let p of y)e$1.removeCard(p);return a(y.map(p=>({kind:"card_removed",cardId:p}))),t({count:y.length})}catch(u){return n(u)}},patch(d){try{let u=d.params?.id,l=d.params?.path;if(!u)return o("patch requires params.id");if(!l)return o("patch requires params.path");let y=d.body,p=y&&Object.prototype.hasOwnProperty.call(y,"value")?y.value:d.body;e$1.patchCard(u,l,p);let f=e$1.readCard(u);return f?(a([{kind:"card_refreshed",cardId:u,card:f}]),t({count:1})):o(`card "${u}" not found`)}catch(u){return n(u)}},appendFiles(d){try{let u=d.params?.id;if(!u)return o("appendFiles requires params.id");let l=e$1.readCard(u);if(!l)return o(`card "${u}" not found`);let y=g(d.body);if(!y||y.length===0)return o("appendFiles requires a file metadata object, array, or body.files array");let p=l.card_data&&typeof l.card_data=="object"&&!Array.isArray(l.card_data)?l.card_data:{},f=Array.isArray(p.files)?p.files:[],w=[...f,...y],C=y.map((b,O)=>({idx:f.length+O,entry:b})),R=this.patch({params:{id:u,path:"card_data.files"},body:{value:w}});return R.status!=="success"?R:t({files_added:C})}catch(u){return n(u)}}}}export{$e as A,Ne as B,Je as C,Me as D,Ue as E,He as F,Ge as G,We as H,Re as a,ee as b,ve as c,ne as d,ge as e,fe as f,oe as g,_ as h,I as i,me as j,Se as k,Fe as l,Ve as m,Pe as n,Ke as o,ye as p,U as q,qe as r,Be as s,Le as t,je as u,se as v,ie as w,ke as x,ae as y,De as z};//# sourceMappingURL=chunk-WGYS2L4V.js.map
2
- //# sourceMappingURL=chunk-WGYS2L4V.js.map
@@ -1,3 +0,0 @@
1
- import {a as a$1,p,q,t as t$1}from'./chunk-FULAMLUU.js';import {D,l,z,B,i,H,G,n,h,A,q as q$1,p as p$1,E,t,m as m$1,u,F,s,o,C}from'./chunk-WGYS2L4V.js';import {a,b,c}from'./chunk-44L64VQ2.js';import {a as a$2}from'./chunk-ATOQP3BD.js';import {e,f}from'./chunk-UGB7PC4P.js';function Rt(o){return typeof o=="string"&&o.trim().length>0}function Ct(o,r){if(!o||typeof o!="object")throw new Error(`${r}: adapter.selfRef is required`);if(!Rt(o.howToRun))throw new Error(`${r}: adapter.selfRef.howToRun is required`);if(!Rt(o.whatToRun))throw new Error(`${r}: adapter.selfRef.whatToRun is required`)}function kt(o,r){if(!o||typeof o!="object")throw new Error(`${r}: adapter.callbackTransport is required`);if(typeof o.createCallback!="function")throw new Error(`${r}: adapter.callbackTransport.createCallback is required`)}function $t(o,r="callbackTransport"){return {createCallback(S){let _=o();return Ct(_,r),{token:S,via:_}}}}function He(o){return $t(()=>o,"createStaticExecutionRefCallbackTransport")}function Yt(o){return He({meta:"board-live-cards",howToRun:"http:post",whatToRun:a({kind:"http-url",value:String(o||"").trim()})})}function Ut(o){return He({meta:"board-live-cards",howToRun:"in-process-loop",whatToRun:a({kind:"in-process-loop",value:String(o||"").trim()})})}function Xt(o){let r=typeof o=="string"?{notifyChannel:o}:o??{},S={};return r.notifyChannel&&(S.notifyChannel=r.notifyChannel),r.boardRuntimeStoreRef&&(S.boardRuntimeStoreRef=r.boardRuntimeStoreRef),r.queueStoreRef&&(S.queueStoreRef=r.queueStoreRef),He({meta:"board-live-cards",howToRun:"built-in",whatToRun:a({kind:"built-in",value:"board-live-cards"}),...Object.keys(S).length>0?{extra:S}:{}})}function m(o){return o!==void 0?{status:"success",data:o}:{status:"success"}}function d(o){return {status:"fail",error:o}}function g(o){return {status:"error",error:o instanceof Error?o.message:String(o)}}function Dt(o){let r=new TextEncoder().encode(o),S=Array.from(r,_=>String.fromCharCode(_)).join("");return btoa(S).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function bt(o){let r=o.replace(/-/g,"+").replace(/_/g,"/"),S=r+"=".repeat((4-r.length%4)%4),_=atob(S),E=Uint8Array.from(_,M=>M.charCodeAt(0));return new TextDecoder().decode(E)}function _e(o){try{let r=JSON.parse(bt(o));return typeof r?.t=="string"?{taskName:r.t}:null}catch{return null}}function ht(o){return Dt(JSON.stringify(o))}function St(o){try{let r=JSON.parse(bt(o));return typeof r?.cbk=="string"&&typeof r?.cid=="string"&&typeof r?.b=="string"&&typeof r?.d=="string"?r:null}catch{return null}}function N(){return new Date().toISOString()}function Vt(o){let r=new Map;return {appendEntries(S,_){if(!S||_.length===0)return;let E=r.get(S)??[];r.set(S,[...E,..._]);},dispatchEntriesForJournalId(S,_){if(!S)return;let E=r.get(S);if(!(!E||E.length===0)){for(let M of E)try{_(M);}catch(j){try{o(M,j instanceof Error?j.message:String(j));}catch{}}r.delete(S);}}}}function sr(o$1,r,S={}){kt(r.callbackTransport,"createBoardLiveCardsPublic");let _=r.callbackTransport,E$1=r.onWarn??(()=>{}),M=a(o$1),j=S.boardRuntimeStoreRef,G$1=S.scratchStoreRef,ue=S.taskExecutorRef,Re=S.chatHandlerFlow,Ce=S.emitNotification??(t=>{if(!r.publishBoardChangeNotifications)return;let e=t.kind==="notification-batch"?t.notifications:[t];return r.publishBoardChangeNotifications(e)});function te(){if(!j)throw new Error(`Board at ${o$1.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return j}function Fe(t){if(t.length!==0)try{let e$1=e(t),s=f({kind:"notification-batch",notifications:e$1}),i=Ce(s);i&&typeof i.catch=="function"&&i.catch(f=>E$1(`[board-live-cards-public] emitNotification failed: ${f instanceof Error?f.message:String(f)}`));}catch(e){E$1(`[board-live-cards-public] emitNotification failed: ${e instanceof Error?e.message:String(e)}`);}}function Oe(){let t=q$2().readCardStoreRef();if(!t)throw new Error(`Board at ${o$1.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let e=r.kvStorageForRef(t);return {readIndex(){return e.read("_index")},writeIndex(s){e.write("_index",s);},readCard(s){return e.read(s)},writeCard(s,i){return e.write(s,i),r.hashFn(i)},removeCard(s){e.delete(s);},cardExists(s){return e.read(s)!==null},defaultCardKey(s){return s}}}let Pe={readValues(t){let e=r.kvStorageForRef(te()),s=e.listKeys().sort();if(s.length===0)return {version:null,values:{}};let i={};for(let f of s)i[f]=e.read(f);return {version:r.hashFn(i),values:i}},writeValues(t,e,s){let i=r.kvStorageForRef(te());for(let f of s)i.delete(f);for(let[f,v]of Object.entries(e))i.write(f,v);return r.hashFn(e)}},q$2=()=>t(r.kvStorageForRef(te())),re=()=>s(Pe),ce=()=>o(r.journalAdapterForRef(te())),l$1=()=>m$1(Oe(),E$1),n$1=()=>{let t=q$2().readOutputsStoreRef();if(!t)throw new Error(`Board at ${o$1.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return u(r.kvStorageForRef(t))};function u$1(){return ue??q$2().readTaskExecutorRef()}function R(){return !!re().readSnapshot(o$1.value).values[q$1]}function y(){let t=re().readSnapshot(o$1.value);if(!t.values[q$1])throw new Error(`Board not initialized at ${o$1.value}`);return F(t.values)}function k(t,e){let s=re().commitSnapshot(o$1.value,{schemaVersion:p$1,expectedVersion:e,commitId:r.genId(),committedAt:N(),deleteKeys:[],shallowMerge:E(t)});if(!s.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${e??"null"} current=${s.currentVersion??"null"}`)}function p$2(t){ce().appendEvent(t);}async function A$1(){let e=Vt((a,c)=>{let h=a.payload,w=(h?.enrichedCard??{}).id??h?.cardId??"unknown";p$2({type:"task-failed",taskName:w,error:c,timestamp:N()});}),s=y(),i$1=q(s.graph),{events:f,newCursor:v}=ce().readEntriesAfterCursor(s.lastDrainedJournalId),C$1=x(),b=n(C$1,a=>r.resolveBlob(a)),I={...s.runtimeByCardId},P=new Map,Q={readRuntime(a){return P.get(a)??I[a]??{_sources:{}}},writeRuntime(a,c){P.set(a,c),I[a]=c;}},W=[],J=new Map,se={readSourceData(a,c){let h=`${a}/${c}`;return J.has(h)?J.get(h):b.readSourceData(a,c)},ingestSourceDataStaged(a,c,h,H){b.ingestSourceDataStaged(a,c,h,H);},commitSourceData(a,c,h){let H=`${a}/.staged/${h}/${c}`,w=C$1.read(H);if(w==null){let B=C$1.keyRef?.(H);B&&(w=r.resolveBlob(B));}if(w==null)return false;let L=`${a}/${c}`,X=w.trim();try{J.set(L,JSON.parse(X));}catch{J.set(L,X);}return W.push({cardId:a,outputFile:c,deliveryToken:h}),true},hasSource(a,c){let h=`${a}/${c}`;return J.has(h)?true:b.hasSource(a,c)},listSources(a){let c=b.listSources(a),h=new Set;for(let w of J.keys())w.startsWith(`${a}/`)&&h.add(w.slice(`${a}/`.length));let H=new Set([...c,...h]);return Array.from(H)}},me=()=>i$1.config.tasks,Z={cardStore:l$1(),cardRuntimeStore:Q,fetchedSourcesStore:se,outputStore:n$1(),executionRequestStore:e,activeTaskConfigs:()=>me()},pe=[],qe=[],je=[],$e=new Map,ze=new Set,Nt=(a,c)=>{pe.push({type:"task-completed",taskName:a,data:c,timestamp:N()});},De=(a,c)=>{p$2({type:"task-failed",taskName:a,error:c,timestamp:N()});},ge=t$1(i$1,{handlers:{"card-handler":C(o$1,v,Z,Nt,De,(a,c)=>{qe.push({cardId:a,values:c});},a=>{je.push(a);})},onNodeRemoved:a=>{$e.delete(a),P.delete(a),delete I[a],ze.add(a);}});for(me=()=>ge.getState().config.tasks,pe=f;pe.length>0;){let a=pe;pe=[];for(let c of a)if(c.type==="task-restart"){let h=Z.cardStore.readCard(c.taskName);h&&$e.set(c.taskName,h);}ge.pushAll(a),await ge.waitForHandlers();}let Qe=ge.getState();await ge.dispose({wait:true});let qt=re().readSnapshot(o$1.value).version;k({lastDrainedJournalId:v,graph:p(Qe),runtimeByCardId:I},qt);for(let{cardId:a,values:c}of qe)Z.outputStore.writeComputedValues(a,c);for(let a of je)Z.outputStore.writeDataObjects(a);for(let{cardId:a,outputFile:c,deliveryToken:h}of W)b.commitSourceData(a,c,h);let Se;try{Se=z(B(M,Qe)),Z.outputStore.writeStatusSnapshot(Se);}catch(a){E$1(`[board-live-cards-public] status publish failed: ${a instanceof Error?a.message:String(a)}`);}let ae=[];for(let{cardId:a,values:c}of qe)ae.push({kind:"computed_values",cardId:a,values:c});for(let a of je)for(let[c,h]of Object.entries(a))c&&ae.push({kind:"data_object",key:c,payload:h});for(let[a,c]of $e)a!==i&&ae.push({kind:"card_refreshed",cardId:a,card:c});for(let a of ze)ae.push({kind:"card_removed",cardId:a});Se!==void 0&&ae.push({kind:"status",status:Se}),Fe(ae);let ie=u$1()??{howToRun:"built-in",whatToRun:a({kind:"built-in",value:"source-cli-task-executor"})},We=r.supportsDirectSourceOutput?.(ie)===true;e.dispatchEntriesForJournalId(v,a$1=>{if(a$1.taskKind!=="source-fetch"){E$1(`[process-accumulated-events] unknown taskKind "${a$1.taskKind}" \u2014 skipping`);return}let c=a$1.payload,h=c.enrichedCard?.id??"unknown",H=c.enrichedCard?.source_defs??[];if(ie.howToRun==="queue-storage"&&We){try{let w=r.queueStorageForRef(T(),"task-executor"),L=typeof ie.extra?.boardId=="string"?ie.extra.boardId:void 0,X=[];for(let B of H){if(!B.outputFile){E$1(`[dispatch] source "${B.bindTo}" has no outputFile \u2014 skipping`);continue}let be=r.genId(),ye=`${h}/.staged/${be}/${B.outputFile}`,Ze=C$1.keyRef?.(ye);if(!Ze)continue;let et={ref:a(Ze),deliveryToken:be,outputFile:B.outputFile,cardId:h},jt=ht({cbk:c.callbackToken,rg:o$1.value,br:a(o$1),cid:h,b:B.bindTo,d:B.outputFile,cs:void 0,rqt:c.rqt,dt:et.deliveryToken});X.push({...L?{boardId:L}:{},ref:ie,args:{source_def:B,base_ref:a(o$1),callback:_.createCallback(jt),output:et}});}X.length>0&&w.enqueueMany(X);}catch(w){De(h,w instanceof Error?w.message:String(w));}return}for(let w of H){if(!w.outputFile){E$1(`[dispatch] source "${w.bindTo}" has no outputFile \u2014 skipping`);continue}let L;if(We){let B=r.genId(),be=`${h}/.staged/${B}/${w.outputFile}`,ye=C$1.keyRef?.(be);ye&&(L={ref:a(ye),deliveryToken:B,outputFile:w.outputFile,cardId:h});}let X=ht({cbk:c.callbackToken,rg:o$1.value,br:a(o$1),cid:h,b:w.bindTo,d:w.outputFile,cs:void 0,rqt:c.rqt,...L?{dt:L.deliveryToken}:{}});r.dispatchExecution(ie,{source_def:w,base_ref:a(o$1),callback:_.createCallback(X),...L?{output:L}:{}}).catch(B=>De(h,B instanceof Error?B.message:String(B)));}});}function T(){let t=q$2().readQueueStoreRef();if(!t)throw new Error(`Board at ${o$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);return t}function $(){r.queueStorageForRef(T(),"process-accumulated").enqueue({boardRef:a(o$1)}),r.requestProcessAccumulated?.();}function F$1(){let t=r.queueStorageForRef(T(),"process-accumulated");for(;;){let e=t.lease({max:64,visibilityMs:1e3});if(e.length<=0)return;for(let s of e)t.ack(s.id,s.leaseToken);if(e.length<64)return}}async function U(){try{let t=()=>{let s=y(),{events:i}=ce().readEntriesAfterCursor(s.lastDrainedJournalId);i.length<=0||$();},e=await c(r.lock,A$1,t);return m({ran:e!==!1})}catch(t){return g(t)}}function D$1(){$();}function de(t){try{let e=t.params?.cardStoreRef;if(!e)return d("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(j=t.params?.boardRuntimeStoreRef,!j)return d("init requires params.boardRuntimeStoreRef \u2014 pass the board runtime store ref here");if(!R()){let P=a$1(D);k({lastDrainedJournalId:"",graph:p(P),runtimeByCardId:{}},null);}let s=t.params?.outputsStoreRef;if(!s)return d("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let i=t.params?.queueStoreRef;if(!i)return d("init requires params.queueStoreRef \u2014 pass the queue store ref here");let f=t.params?.fetchedSourcesStoreRef;if(!f)return d("init requires params.fetchedSourcesStoreRef \u2014 pass the fetched sources store ref here");G$1=t.params?.scratchStoreRef;let v=t.params?.chatStoreRef;if(!v)return d("init requires params.chatStoreRef \u2014 pass the chat store ref here");let C=t.params?.artifactsStoreRef;if(!C)return d("init requires params.artifactsStoreRef \u2014 pass the artifacts store ref here");let b=q$2();b.writeBoardRuntimeStoreRef(j),b.writeCardStoreRef(e),b.writeOutputsStoreRef(s),b.writeQueueStoreRef(i),b.writeFetchedSourcesStoreRef(f),b.writeChatStoreRef(v),b.writeArtifactsStoreRef(C),l$1().writeCard(l().id,l());let I=V({params:{cardId:l().id,restart:!0}});if(I.status!=="success")return I;try{n$1().writeStatusSnapshot(z(B(M,q(y().graph))));}catch{}return m()}catch(e){return g(e)}}function ne(t){try{let e=n$1().readStatusSnapshot();if(!e){e=z(B(M,q(y().graph)));try{n$1().writeStatusSnapshot(e);}catch{}}return m(e)}catch(e){return g(e)}}function ke(t){try{let e=t.params?.id;if(!e)return d("removeCard requires params.id");try{r.kvStorage("card-upsert").delete(e);}catch{}return p$2({type:"task-removal",taskName:e,timestamp:N()}),e!==i&&p$2({type:"task-restart",taskName:i,timestamp:N()}),D$1(),m()}catch(e){return g(e)}}function oe(t){try{let e=t.params?.cardId;if(!e)return d("addCardFiles requires params.cardId");let s=H(l$1(),{emitNotification:Ce}).appendFiles({params:{id:e},body:t.body});return s.status!=="success"?s:m({cardId:e,files_added:s.data.files_added,notified:!0})}catch(e){return g(e)}}function he(t){try{let e=t.params?.id;return e?(p$2({type:"task-restart",taskName:e,timestamp:N()}),D$1(),m()):d("retrigger requires params.id")}catch(e){return g(e)}}async function le(t){return F$1(),U()}function Ne(){let t=q$2().readFetchedSourcesStoreRef();if(!t)throw new Error(`Board at ${o$1.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return t}function x(){return r.blobStorageForRef(Ne())}function V(t){try{let e=t.params?.cardId,s=t.params?.all,i$1=!!t.params?.restart;if(!e&&!s)return d("upsertCard requires --card-id <id> or --all");let f=s?l$1().readAllCards().map(C=>C.id):[e];for(let C of f)if(!l$1().readCard(C))return d(`Card "${C}" not found in board at ${o$1.value}`);let v=!1;for(let C of f){let b=l$1().readCard(C),I=G(b),P=r.hashFn(I),Q=r.kvStorage("card-upsert"),W=Q.read(C),J=W?.taskConfigHash!==P;if(!(!J&&!i$1)){if(J){let se=W?.blobRef??l$1().readCardKey(C)??C;p$2({type:"task-upsert",taskName:C,taskConfig:I,timestamp:N()}),Q.write(C,{blobRef:se,taskConfigHash:P,updatedAt:N()}),v=v||C!==i;}i$1&&p$2({type:"task-restart",taskName:C,timestamp:N()});}}return v&&p$2({type:"task-restart",taskName:i,timestamp:N()}),D$1(),m()}catch(e){return g(e)}}function K(t){try{let e=t.params?.token;if(!e)return d("taskFailed requires params.token");let s=t.params?.error??"unknown error",i=_e(e);return i?(p$2({type:"task-failed",taskName:i.taskName,error:s,timestamp:N()}),D$1(),m()):d("Invalid callback token")}catch(e){return g(e)}}function z$1(t){try{let e=t.params?.token;if(!e)return d("taskProgress requires params.token");let i=(t.body??{}).update??{},f=_e(e);return f?(p$2({type:"task-progress",taskName:f.taskName,update:i,timestamp:N()}),D$1(),m()):d("Invalid callback token")}catch(e){return g(e)}}function fe(t){try{let e=t.params?.token,s=t.params?.ref;if(!e)return d("sourceDataFetched requires params.token");if(!s)return d("sourceDataFetched requires params.ref");let i=St(e);if(!i)return d("Invalid source token");let{cbk:f,cid:v,b:C,d:b$1,cs:I,rqt:P,dt:Q}=i,W=n(x(),Z=>r.resolveBlob(Z)),J=Q||r.genId();Q||W.ingestSourceDataStaged(v,b$1,b(s),J);let se=_e(f);if(!se)return d("Invalid callback token embedded in source token");let me=N();return p$2({type:"task-progress",taskName:se.taskName,update:{bindTo:C,outputFile:b$1,fetchedAt:me,deliveryToken:J,sourceChecksum:I,rqt:P},timestamp:me}),D$1(),m()}catch(e){return g(e)}}function Y(t){try{let e=t.params?.token,s=t.params?.reason??"unknown";if(!e)return d("sourceDataFetchFailure requires params.token");let i=St(e);if(!i)return d("Invalid source token");let{cbk:f,b:v,d:C,cs:b,rqt:I}=i,P=_e(f);return P?(p$2({type:"task-progress",taskName:P.taskName,update:{bindTo:v,outputFile:C,failure:!0,reason:s,sourceChecksum:b,rqt:I},timestamp:N()}),D$1(),m()):d("Invalid callback token embedded in source token")}catch(e){return g(e)}}function yt(t){try{let e=q$2().readCardStoreRef();return e?m({storeRef:e}):d(`Board at ${o$1.value} has no card store configured`)}catch(e){return g(e)}}function vt(t){try{return m({storeRef:j??null})}catch(e){return g(e)}}function wt(t){try{let e=q$2().readOutputsStoreRef();return e?m({storeRef:e}):d(`Board at ${o$1.value} has no outputs store configured`)}catch(e){return g(e)}}function Tt(t){try{return m({storeRef:G$1??null})}catch(e){return g(e)}}function It(t){try{let e=q$2().readChatStoreRef();return m({storeRef:e})}catch(e){return g(e)}}function xt(t){try{let e=q$2().readArtifactsStoreRef();return m({storeRef:e})}catch(e){return g(e)}}function Et(t){try{let e=q$2().readFetchedSourcesStoreRef();return m({storeRef:e})}catch(e){return g(e)}}function At(t){try{let e=t.params?.key;if(!e)return d("getConfig requires params.key");let s=q$2(),i;switch(e){case "task-executor":i=ue??null;break;case "chat-handler-flow":i=Re??null;break;case "board-runtime-store-ref":i=s.readBoardRuntimeStoreRef();break;case "card-store-ref":i=s.readCardStoreRef();break;case "outputs-store-ref":i=s.readOutputsStoreRef();break;case "scratch-store-ref":i=G$1??null;break;case "chat-store-ref":i=s.readChatStoreRef();break;case "artifacts-store-ref":i=s.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=s.readFetchedSourcesStoreRef();break;default:return d(`getConfig: unknown key "${e}"`)}return m({value:i})}catch(e){return g(e)}}function Bt(t){try{let e=t.params?.key;if(!e)return d("getOutputsDataObject requires params.key");if(e===h)return m(null);let s=n$1().readDataObject(e);return m(s)}catch(e){return g(e)}}function Ge(t){try{return m(A(n$1().readAllDataObjects()))}catch(e){return g(e)}}function _t(t){try{let e=t.params?.key;if(!e)return d("getOutputsComputedValues requires params.key");let s=n$1().readComputedValues(e);return m(s)}catch(e){return g(e)}}function Ye(t){try{return m(n$1().readAllComputedValues())}catch(e){return g(e)}}function Ue(){return n(x(),t=>r.resolveBlob(t))}function Xe(t){let e=x().keyRef?.(t);if(!e)throw new Error("configured fetched-sources store does not support keyRef");return a(e)}function Ft(t){try{let e=t.params?.key;if(!e)return d("getOutputsFetchedSources requires params.key");let s=Ue().listSources(e),i={};for(let f of s)i[f]=Xe(`${e}/${f}`);return m(i)}catch(e){return g(e)}}function Ot(t){try{let e=Ue(),s=new Set;for(let f of x().listKeys()){let v=f.indexOf("/");v>0&&!f.includes("/.staged/")&&s.add(f.slice(0,v));}let i={};for(let f of s){let v=e.listSources(f);if(v.length>0){i[f]={};for(let C of v)i[f][C]=Xe(`${f}/${C}`);}}return m(i)}catch(e){return g(e)}}function Pt(t){try{let e=l$1().readAllCards().filter(b=>b.id!==i),s=ne({});if(s.status!=="success")return s;let i$1=Ge({});if(i$1.status!=="success")return i$1;let f=Ye({});if(f.status!=="success")return f;let v=f.data,C={};for(let b of e){let I=typeof b?.id=="string"?b.id:null;if(!I)continue;let P=b.card_data&&typeof b.card_data=="object"&&!Array.isArray(b.card_data)?b.card_data:{};C[I]={schema_version:"v1",card_id:I,card_data:{...P},computed_values:v[I]&&typeof v[I]=="object"?v[I]:{}};}return m({cardDefinitions:e,statusSnapshot:s.data,dataObjectsByToken:i$1.data,cardRuntimeById:C})}catch(e){return g(e)}}return {init:de,status:ne,getBoardRuntimeStoreRef:vt,getCardStoreRef:yt,getOutputsStoreRef:wt,getScratchStoreRef:Tt,getChatStoreRef:It,getArtifactsStoreRef:xt,getFetchedSourcesStoreRef:Et,getConfig:At,getOutputsDataObject:Bt,getAllOutputsDataObjects:Ge,getOutputsComputedValues:_t,getAllOutputsComputedValues:Ye,getOutputsFetchedSources:Ft,getAllOutputsFetchedSources:Ot,buildSseOneShotPayload:Pt,removeCard:ke,addCardFiles:oe,retrigger:he,processAccumulatedEvents:le,upsertCard:V,taskFailed:K,taskProgress:z$1,sourceDataFetched:fe,sourceDataFetchFailure:Y}}function ar(o,r,S){let _=S?.taskExecutorRef,E=()=>{if(S){if(!S.boardRuntimeStoreRef)throw new Error(`Board at ${o.value} requires boardRuntimeStoreRef for non-core runtime operations.`);return t(r.kvStorageForRef(S.boardRuntimeStoreRef))}return t(r.kvStorage("config"))};function M(){let l=E().readCardStoreRef();if(!l)throw new Error(`Board at ${o.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let n=r.kvStorageForRef(l);return {readIndex(){return n.read("_index")},writeIndex(u){n.write("_index",u);},readCard(u){return n.read(u)},writeCard(u,R){return n.write(u,R),r.hashFn(R)},removeCard(u){n.delete(u);},cardExists(u){return n.read(u)!==null},defaultCardKey(u){return u}}}let j=()=>m$1(M(),r.onWarn??(()=>{}));function G(){return _??E().readTaskExecutorRef()}async function ue(l,n){let u=r.validateSchema(n),R=[],y=G();if(y&&Array.isArray(n.source_defs))for(let p of n.source_defs){let A=typeof p.bindTo=="string"?p.bindTo:"(unknown)";try{let T;try{T=await r.invokeExecutor(y,"validate-source-def",{timeout:r.executorTimeouts?.validationMs??1e4,input:JSON.stringify(p)});}catch(F){let U=F;if(T=typeof U?.stdout=="string"?U.stdout:"",!T.trim()){R.push(`source "${A}": executor validate-source-def failed \u2014 ${F instanceof Error?F.message:String(F)}`);continue}}let $=JSON.parse(T.trim());if(!$.ok&&Array.isArray($.errors))for(let F of $.errors)R.push(`source "${A}": ${F}`);}catch(T){R.push(`source "${A}": executor validate-source-def failed \u2014 ${T instanceof Error?T.message:String(T)}`);}}let k=[...u.errors,...R];return m({cardId:l,isValid:k.length===0,issues:k})}function Re(l,n){let u=l.params?.sourceIdx,R=l.params?.outRef;if(u===void 0)return d(`${n} requires params.sourceIdx`);if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return d(`${n} requires card JSON object in body`);let y=l.body,k=y["card-content"]??y,p=y["mock-projections"]??{},A=k.source_defs??[];if(u<0||u>=A.length)return d(`sourceIdx ${u} out of range (card has ${A.length} source(s))`);let T=A[u],$=typeof T.bindTo=="string"?T.bindTo:"source";return {src:T,bindTo:$,outRef:R,mockProjections:p}}async function Ce(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return d("validateCardPreflight requires card JSON object in body");let n=l.body,u=n["card-content"]??n,R=typeof u.id=="string"?u.id:"(unknown)";return await ue(R,u)}catch(n){return g(n)}}async function te(l){try{let n=Re(l,"probeSourcePreflight");if("status"in n)return n;let u=G();if(!u)return d("No task-executor registered for this board");try{let R={...n.src,_projections:n.mockProjections},y=await r.invokeExecutor(u,"probe-source-preflight",{timeout:n.src.timeout??r.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(R)}),k=JSON.parse(y.trim());return k.ok?m({bindTo:n.bindTo,reachable:k.reachable,latencyMs:k.latencyMs,note:k.note}):d(k.error??"Preflight probe failed")}catch{return d("Executor does not support probe-source-preflight")}}catch(n){return g(n)}}async function Fe(l){try{let n=Re(l,"runSourcePreflight");if("status"in n)return n;let u=G();if(!u)return d("No task-executor registered for this board");try{let R={...n.src,_projections:n.mockProjections},y=await r.invokeExecutor(u,"run-source-preflight",{timeout:n.src.timeout??r.executorTimeouts?.probeMs??6e4,input:JSON.stringify(R)}),k=JSON.parse(y.trim());if(!k.ok)return m({bindTo:n.bindTo,ok:!1,result:null,issues:[k.error??"Preflight run failed"]});if(n.outRef){let p=b(n.outRef);r.absoluteBlob.write(p.value,JSON.stringify(k.resultValue,null,2));}return m({bindTo:typeof k.bindTo=="string"?k.bindTo:n.bindTo,ok:!0,result:k.resultValue??null,issues:[]})}catch(R){let y=R instanceof Error?R.message:String(R);return m({bindTo:n.bindTo,ok:!1,result:null,issues:[y]})}}catch(n){return g(n)}}async function Oe(l){try{let n=G();if(!n)return d("No task-executor registered for this board");let u=await r.invokeExecutor(n,"describe-capabilities",{timeout:r.executorTimeouts?.describeMs??1e4});return m(JSON.parse(u.trim()))}catch(n){return g(n)}}function Pe(l){try{let n=l.body;if(!n||!Array.isArray(n.ops))return d("updatesInCardStore requires body.ops array");let u=n.ops,R=j();for(let y of u){let k=y.op,p=y.id;if(!p)return d('op is missing "id"');if(k==="update"){let A=y["card-content"];if(!A)return d(`update op for "${p}" is missing "card-content"`);R.writeCard(p,A);}else return d(`Unknown op type: "${k??"(none)"}"`)}return m()}catch(n){return g(n)}}function q(l){try{let n=l.body;if(!n||!Array.isArray(n.ids))return d("readFromCardStore requires body.ids array");let u=n.ids,R=j(),y=u.map(k=>({id:k,"card-content":R.readCard(k)}));return m({cards:y})}catch(n){return g(n)}}function re(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return d("evalCardCompute requires a JSON object in body");let n=l.body,u=n["card-content"]??n,R=typeof u.id=="string"?u.id:"(unknown)",y=n["mock-fetched-sources"]??{},k=n["mock-requires"]??{},p=u.compute;if(!p||!Array.isArray(p)||p.length===0)return m({cardId:R,ok:!0,computed_values:{},errors:[]});let A={id:R,card_data:u.card_data??{},requires:k,source_defs:u.source_defs,compute:p},T=a$2.runSync(A,{sourcesData:y}),$=T.node.computed_values??{},F=T.errors??[];return m({cardId:R,ok:F.length===0,computed_values:$,errors:F})}catch(n){return g(n)}}async function ce(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return d("simulateCardCycle requires a JSON object in body");let n=l.body,u=n["card-content"]??n,R=typeof u.id=="string"?u.id:"(unknown)",y=n["mock-fetched-sources"]??{},k=n["mock-requires"]??{},p=await ue(R,u),A=p.status==="success"?{isValid:p.data.isValid,issues:p.data.issues}:{isValid:!1,issues:[p.status==="fail"?p.error:"internal error"]},T=u.source_defs??[],$=u.card_data??{},F=[],U=[];if(T.length>0){F=a$2.enrichSourcesSync(T,{card_data:$,requires:k});for(let x of F){let V=x.projections,K=x._projections;if(V&&K){for(let z of Object.keys(V))if(K[z]===void 0){let fe=typeof x.bindTo=="string"?x.bindTo:"(unknown)";U.push({bindTo:fe,key:z,error:`Projection "${z}" resolved to undefined`});}}}}let D=[],de={...y},ne=n["task-executor-ref"],ke=(ne?.howToRun&&ne?.whatToRun?ne:void 0)??G();for(let x=0;x<F.length;x++){let V=F[x],K=typeof V.bindTo=="string"?V.bindTo:`source_${x}`;if(!ke){D.push({bindTo:K,skipped:!0,error:"No task executor configured"});continue}try{let z={...V},fe=await r.invokeExecutor(ke,"run-source-preflight",{timeout:V.timeout??r.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(z)}),Y=JSON.parse(fe.trim());Y.ok&&!Object.prototype.hasOwnProperty.call(y,K)&&Object.prototype.hasOwnProperty.call(Y,"resultValue")&&(de[K]=Y.resultValue),D.push({bindTo:K,reachable:Y.reachable,latencyMs:Y.latencyMs,error:Y.ok?void 0:Y.error});}catch{D.push({bindTo:K,skipped:!0,error:"Executor does not support run-source-preflight"});}}let oe=u.compute,he={},le=[];if(oe&&Array.isArray(oe)&&oe.length>0){let x={id:R,card_data:$,requires:k,source_defs:u.source_defs,compute:oe},V=a$2.runSync(x,{sourcesData:de});he=V.node.computed_values??{},le=V.errors??[];}let Ne=A.isValid&&U.length===0&&le.length===0&&D.every(x=>x.reachable!==!1);return m({cardId:R,ok:Ne,validation:A,source_probes:D,projection_errors:U,fetched_sources:de,computed_values:he,compute_errors:le})}catch(n){return g(n)}}return {validateCardPreflight:Ce,probeSourcePreflight:te,runSourcePreflight:Fe,evalCardCompute:re,simulateCardCycle:ce,describeTaskExecutorCapabilities:Oe,updatesInCardStore:Pe,readFromCardStore:q}}
2
- export{kt as a,Yt as b,Ut as c,Xt as d,sr as e,ar as f};//# sourceMappingURL=chunk-X32SJDLT.js.map
3
- //# sourceMappingURL=chunk-X32SJDLT.js.map
@@ -1,3 +0,0 @@
1
- import {q as q$1}from'./chunk-MNEOJWPS.js';import {b as b$1}from'./chunk-FW4363Y4.js';import j from'ajv-formats';import {createRequire}from'module';var h={$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"},presentation:{type:"object",description:"Semantic presentation hints authored on the card, expressed from the user's perception of the card on the Main Canvas. Content shape is inferred from view.elements[].kind; runtime placement and live drag/resize coordinates are frontend-managed and must not be authored into card JSON.",properties:{prominence:{type:"string",default:"standard",description:"How much the user should care about this card / how much attention it earns. Default: standard; omit unless a non-standard value is needed.",enum:["glance","standard","feature","spotlight"]},footprint:{type:"string",default:"standard",description:"How much room the card wants to render well, independent of attention. Default: standard; omit unless a non-standard value is needed.",enum:["compact","standard","wide","large"]},resizable:{type:"boolean",default:true,description:"Whether the user may resize this card at runtime. Default: true; omit unless it must be false."}},additionalProperties:true},tags:{type:"array",items:{type:"string"}}},additionalProperties:true},__private:{description:"Control-plane-owned private state. Stripped entirely from all regular /mcp read responses. Writable only via 'setstate.card-private' and 'manage.admin-upsert-card'. Agents must never author this field. Keys inside use plain names (no leading underscores).",type:"object",additionalProperties:true},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"}},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"}}}}},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"},__private:{$ref:"#/definitions/__private"},view:{$ref:"#/definitions/view"},card_data:{type:"object",description:"User editable data on card. Includes uploaded-file metadata maintained by host handlers. Not to be used for card static content.",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"},chat:{type:"boolean",description:"Whether this file entry is associated with a chat interaction"}},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.",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 _=b$1(q$1(),1);var k=createRequire(import.meta.url),q=k("./jsonata-sync.cjs"),f=null;var g=/\b(card_data|requires|fetched_sources|computed_values|source_defs)\b/g,N=/^\s*(card_data|requires|fetched_sources|computed_values|source_defs)(\.|$)/;function S(e){let t=new Set,s;for(g.lastIndex=0;(s=g.exec(e))!==null;)t.add(s[1]);return t}function v(e){let t=N.exec(e);return t?t[1]:null}function b(e,t,s,a){try{q(e);}catch(o){let d=o instanceof Error?o.message:String(o);a.push(`${t}: invalid JSONata expression (${d})`);return}let i=S(e);for(let o of i)s.has(o)||a.push(`${t}: disallowed namespace "${o}" in expression`);}function y(e,t,s){if(Array.isArray(e)){e.forEach((i,o)=>{y(i,`${t}/${o}`,s);});return}if(typeof e=="string"){let i=v(e);if(!i)return;new Set(["card_data","requires","computed_values"]).has(i)||s.push(`${t}: disallowed namespace "${i}" in view reference`);return}if(!e||typeof e!="object")return;let a=e;for(let[i,o]of Object.entries(a))y(o,`${t}/${i}`,s);}function E(){if(f)return f;let e=new _.default({allErrors:true});return j(e),f=e.compile(h),f}function O(e){let t=E(),s=t(e),a=(t.errors??[]).map(i=>`${i.instancePath||"/"}: ${i.message??"unknown error"}`);if(e&&typeof e=="object"&&!Array.isArray(e)){let i=e.source_defs;if(Array.isArray(i)){let o=new Set,d=new Set;i.forEach((c,u)=>{if(!c||typeof c!="object"||Array.isArray(c))return;let r=c;typeof r.bindTo=="string"&&r.bindTo&&(o.has(r.bindTo)&&a.push(`/source_defs/${u}/bindTo: bindTo "${r.bindTo}" must be unique across all source_defs`),o.add(r.bindTo)),typeof r.outputFile=="string"&&r.outputFile&&(d.has(r.outputFile)&&a.push(`/source_defs/${u}/outputFile: outputFile "${r.outputFile}" must be unique across all source_defs`),d.add(r.outputFile));});}}return !s||a.length>0?{ok:false,errors:a}:{ok:true,errors:[]}}function R(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:true,errors:[]};let s=e,a=s.compute;Array.isArray(a)&&a.forEach((r,p)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let n=r.expr;typeof n!="string"||n.trim().length===0||b(n,`/compute/${p}/expr`,new Set(["card_data","requires","fetched_sources","computed_values"]),t);});let i=new Set(["card_data","requires","fetched_sources","computed_values"]),o=s.provides;Array.isArray(o)&&o.forEach((r,p)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let n=r.ref;if(typeof n!="string"||n.trim().length===0)return;let l=v(n);l===null?t.push(`/provides/${p}/ref: path "${n}" must start with a valid namespace (${[...i].join(", ")})`):i.has(l)||t.push(`/provides/${p}/ref: disallowed namespace "${l}" in path "${n}" (valid: ${[...i].join(", ")})`);});let d=s.view;d&&typeof d=="object"&&!Array.isArray(d)&&y(d,"/view",t);let c=new Set(["card_data","requires"]),u=s.source_defs;return Array.isArray(u)&&u.forEach((r,p)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let n=r.projections;if(!(!n||typeof n!="object"||Array.isArray(n)))for(let[l,m]of Object.entries(n))typeof m!="string"||m.trim().length===0||b(m,`/source_defs/${p}/projections/${l}`,c,t);}),{ok:t.length===0,errors:t}}function V(e){return T(e)}function T(e){let t=O(e);if(!t.ok)return t;let s=R(e);return s.ok?{ok:true,errors:[]}:{ok:false,errors:s.errors}}
2
- export{O as a,R as b,V as c,T as d};//# sourceMappingURL=chunk-YT76JNKE.js.map
3
- //# sourceMappingURL=chunk-YT76JNKE.js.map