yaml-flow 8.11.8 → 8.11.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/browser/asset-integrity.json +5 -5
- package/browser/live-cards.schema.json +775 -150
- package/browser/server-runtime-controlface.js +4 -4
- package/examples/board/cards/card-rebalance-sim.json +7 -5
- package/examples/board/cards/cardT-market-prices.json +3 -1
- package/examples/board/cards/cardT-portfolio-value.json +3 -1
- package/examples/board/cards/cardT-portfolio.json +4 -2
- package/examples/board/test/server-http-test-browser.ts +3 -1
- package/examples/board/test/server-http-test.js +3 -1
- package/examples/portfolio-tracker/portfolio-tracker.js +2 -2
- package/examples/portfolio-tracker/test/portfolio-t4.js +2 -2
- package/lib/board-live-cards-mcp.cjs +1 -1
- package/lib/board-live-cards-mcp.js +1 -1
- package/lib/board-live-cards-node.cjs +2 -2
- package/lib/board-live-cards-node.js +1 -1
- package/lib/board-live-cards-public.cjs +1 -1
- package/lib/board-live-cards-public.js +1 -1
- package/lib/board-live-cards-server-runtime.cjs +1 -1
- package/lib/board-live-cards-server-runtime.js +1 -1
- package/lib/board-livegraph-runtime/index.cjs +1 -1
- package/lib/board-livegraph-runtime/index.d.cts +1 -1
- package/lib/board-livegraph-runtime/index.d.ts +1 -1
- package/lib/board-livegraph-runtime/index.js +1 -1
- package/lib/card-compute/index.cjs +1 -1
- package/lib/card-compute/index.js +1 -1
- package/lib/card-store-public.cjs +1 -1
- package/lib/card-store-public.js +1 -1
- package/lib/card-validation.cjs +1 -1
- package/lib/card-validation.js +1 -1
- package/lib/{chunk-OR6B2H2Y.cjs → chunk-22S5GCQK.cjs} +3 -3
- package/lib/{chunk-BA25VGJP.js → chunk-3C52UCJC.js} +3 -3
- package/lib/{chunk-36KKCQVE.cjs → chunk-3HCH2ZFB.cjs} +2 -2
- package/lib/chunk-66ZZIF2L.cjs +2 -0
- package/lib/{chunk-4NWVZ7AW.js → chunk-72FB4M6P.js} +2 -2
- package/lib/chunk-AW6XLBHX.cjs +2 -0
- package/lib/chunk-BSZYTSFX.js +2 -0
- package/lib/{chunk-BRYV6CDD.js → chunk-C7OY3PYL.js} +3 -3
- package/lib/{chunk-EGZPROOH.cjs → chunk-C7RR2JCL.cjs} +3 -3
- package/lib/{chunk-JOQWJ3VR.cjs → chunk-CAID4CGO.cjs} +2 -2
- package/lib/chunk-CVTL2EFR.js +3 -0
- package/lib/{chunk-REZO2QJD.js → chunk-E7SDEZSI.js} +3 -3
- package/lib/{chunk-PIPXFUEA.js → chunk-F6KRSQ7V.js} +2 -2
- package/lib/chunk-G5UUXBIB.cjs +2 -0
- package/lib/{chunk-ROIYEFSE.js → chunk-K2VRX4TC.js} +2 -2
- package/lib/chunk-ONJG6QW6.js +2 -0
- package/lib/{chunk-HOS2ZUFZ.cjs → chunk-P4WQJ7LA.cjs} +2 -2
- package/lib/chunk-P7STTKRO.cjs +3 -0
- package/lib/{chunk-6SPWFJRG.cjs → chunk-PYYRDOD5.cjs} +2 -2
- package/lib/chunk-QE3QXEHI.js +2 -0
- package/lib/{chunk-MRESV3MD.js → chunk-QJQ53PLM.js} +2 -2
- package/lib/{chunk-MRIFSG7L.cjs → chunk-TIQ775WI.cjs} +3 -3
- package/lib/cloud-storage.cjs +1 -1
- package/lib/cloud-storage.js +1 -1
- package/lib/continuous-event-graph/index.cjs +1 -1
- package/lib/continuous-event-graph/index.d.cts +2 -2
- package/lib/continuous-event-graph/index.d.ts +2 -2
- package/lib/continuous-event-graph/index.js +1 -1
- package/lib/firestore-storage/index.cjs +1 -1
- package/lib/firestore-storage/index.js +1 -1
- package/lib/index.cjs +2 -2
- package/lib/index.d.cts +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.js +1 -1
- package/lib/{live-cards-bridge-Bwi-lbBT.d.cts → live-cards-bridge-D8kP3uog.d.cts} +2 -2
- package/lib/{live-cards-bridge-YL6AWawT.d.ts → live-cards-bridge-DMBSDgpk.d.ts} +2 -2
- package/lib/localstorage-storage/index.cjs +1 -1
- package/lib/localstorage-storage/index.js +1 -1
- package/lib/server-runtime/index.cjs +1 -1
- package/lib/server-runtime/index.js +1 -1
- package/lib/server-runtime-controlface/index.cjs +1 -1
- package/lib/server-runtime-controlface/index.js +1 -1
- package/lib/server-runtime-core/index.cjs +1 -1
- package/lib/server-runtime-core/index.js +1 -1
- package/package.json +2 -1
- package/schema/live-cards.schema.json +775 -150
- package/browser/live-cards.js +0 -108
- package/lib/chunk-3DWVFRQD.cjs +0 -3
- package/lib/chunk-3SLSRX6Q.js +0 -3
- package/lib/chunk-543ZEGP7.cjs +0 -2
- package/lib/chunk-ESTFYRHF.cjs +0 -2
- package/lib/chunk-NN52BT3Q.js +0 -2
- package/lib/chunk-UJQ7IML5.js +0 -2
- package/lib/chunk-YOY2JM5N.js +0 -2
- package/lib/chunk-ZV35WD6K.cjs +0 -2
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunkZV35WD6K_cjs=require('./chunk-ZV35WD6K.cjs');function b(e){return JSON.parse(JSON.stringify(e))}function E(e){let r=e.provides&&e.provides.length>0?e.provides.map(n=>n.bindTo):[e.id];return {requires:e.requires&&e.requires.length>0?[...e.requires]:void 0,provides:r,taskHandlers:[e.id],description:e.meta?.title??e.id}}function I(e){let r=new Map;for(let[n,u]of e.entries()){let o=u.provides&&u.provides.length>0?u.provides:[{bindTo:n,ref:"card_data"}];for(let h of o)r.set(h.bindTo,n);}return r}function O(e,r){let n=I(e),u=e.get(r);if(u){for(let o of u.requires??[])if(!n.has(o))throw new Error(`Card "${r}" requires token "${o}" but no card provides it`)}}var F={CARD_PREFIX:"yf:cards:",RUNTIME_OUT_PREFIX:"yf:runtime-out:cards:",STATUS_KEY:"yf:runtime-out:status",writeCard(e,r){try{localStorage.setItem(this.CARD_PREFIX+e,JSON.stringify(r));}catch(n){console.warn(`Failed to write card ${e} to localStorage:`,n);}},readCard(e){try{let r=localStorage.getItem(this.CARD_PREFIX+e);return r?JSON.parse(r):null}catch(r){return console.warn(`Failed to read card ${e} from localStorage:`,r),null}},readAllCards(e){let r={};for(let n of e){let u=this.readCard(n);u&&(r[n]=u);}return r},writeComputedArtifact(e){if(!(!e||!e.card_id))try{localStorage.setItem(this.RUNTIME_OUT_PREFIX+String(e.card_id),JSON.stringify(e));}catch(r){console.warn(`Failed to write computed artifact ${e.card_id}:`,r);}},readComputedArtifact(e){try{let r=localStorage.getItem(this.RUNTIME_OUT_PREFIX+e);return r?JSON.parse(r):null}catch(r){return console.warn(`Failed to read computed artifact ${e}:`,r),null}},readAllComputedArtifacts(e){let r={};for(let n of e){let u=this.readComputedArtifact(n);u&&(r[n]=u);}return r},writeStatusSnapshot(e){try{localStorage.setItem(this.STATUS_KEY,JSON.stringify(e));}catch(r){console.warn("Failed to write status snapshot to localStorage:",r);}},readStatusSnapshot(){try{let e=localStorage.getItem(this.STATUS_KEY);return e?JSON.parse(e):null}catch(e){return console.warn("Failed to read status snapshot from localStorage:",e),null}},clear(){let e=[];for(let r=0;r<localStorage.length;r++){let n=localStorage.key(r);n&&(n.startsWith(this.CARD_PREFIX)||n.startsWith(this.RUNTIME_OUT_PREFIX)||n===this.STATUS_KEY)&&e.push(n);}for(let r of e)localStorage.removeItem(r);}};function H(e,r={}){let n=Array.isArray(e)?{}:{id:e.id,title:e.title,mode:e.mode,positions:e.positions,settings:e.settings},u=Array.isArray(e)?e:e.nodes,o=new Map;for(let t of u){if(o.has(t.id))throw new Error(`Duplicate card ID: "${t.id}"`);o.set(t.id,b(t));}let h=new Set,S=r.taskExecutor,L=r.sourceAdapters??{},d=r.defaultSourceAdapter,m=null,A=(t,g)=>{let a={events:t,graph:g,nodes:v()};for(let w of h)w(a);},_=t=>async g=>{let a=o.get(t);if(!a)return "task-initiate-failure";let w={};for(let R of a.requires??[]){let y=g.state[R];if(!y||typeof y!="object")continue;let k=y.provides_data;!k||typeof k!="object"||Object.prototype.hasOwnProperty.call(k,R)&&(w[R]=k[R]);}let p={};if(a.source_defs&&a.source_defs.length>0){let R=L[t]??d,y=S?await S({card:a,input:g}):R?await R({card:a,input:g}):void 0;if(y&&typeof y=="object")for(let k of a.source_defs)Object.prototype.hasOwnProperty.call(y,k.bindTo)?p[k.bindTo]=y[k.bindTo]:a.source_defs.length===1&&(p[k.bindTo]=y);}let c={id:a.id,card_data:b(a.card_data??{}),requires:w,source_defs:a.source_defs,compute:a.compute};c._sourcesData=p,c.compute&&c.compute.length>0&&await chunkZV35WD6K_cjs.a.run(c,{sourcesData:p});let T={};if(a.provides&&a.provides.length>0)for(let{bindTo:R,ref:y}of a.provides)T[R]=chunkZV35WD6K_cjs.a.resolve(c,y);else T[a.id]={...c.card_data??{},...c.computed_values??{},...c._sourcesData??{}};let B={provides_data:T,card_data:c.card_data??{},computed_values:c.computed_values??{},fetched_sources:p,requires:w};return m?.resolveCallback(g.callbackToken,B),"task-initiated"},s={},f={};for(let[t,g]of o.entries())O(o,t),s[t]=E(g),f[t]=_(t);let l={id:n.id??`browser-board-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...n.settings??{},...r.graphSettings??{}},tasks:s},C=r.reactiveOptions?.onDrain,i=chunkAW3COGCI_cjs.t(l,{...r.reactiveOptions??{},handlers:f,onDrain:(t,g,a)=>{C?.(t,g,a),A(t,g);}},r.executionId);m=i;function v(){let t=i.getState(),g=[];for(let[a,w]of o.entries()){let p=t.state.tasks[a]?.data,c=t.state.tasks[a],T={...w.card_data??{},...p&&typeof p.card_data=="object"?p.card_data:{}},B=c?.status==="running"?"loading":c?.status,R={...T,...B?{status:B}:{},...c?.lastUpdated?{lastRun:c.lastUpdated}:{},...c?.status==="failed"&&c.error?{error:c.error}:{}};g.push({id:a,card:b(w),card_data:R,requires:p&&typeof p.requires=="object"?b(p.requires):{},computed_values:p&&typeof p.computed_values=="object"?b(p.computed_values):{},runtime_state:c?b(c):{}});}return g}return {getGraph:()=>i,getState:()=>i.getState(),getSchedule:()=>i.getSchedule(),getNodes:()=>v(),getBoard:()=>({...n,nodes:v()}),subscribe(t){return h.add(t),t({events:[],graph:i.getState(),nodes:v()}),()=>h.delete(t)},addCard(t){if(o.has(t.id))throw new Error(`Card "${t.id}" already exists`);o.set(t.id,b(t)),O(o,t.id),i.registerHandler(t.id,_(t.id)),i.addNode(t.id,E(t));},upsertCard(t){o.set(t.id,b(t)),O(o,t.id),i.registerHandler(t.id,_(t.id)),i.addNode(t.id,E(t));},removeCard(t){o.delete(t),i.unregisterHandler(t),i.removeNode(t);},patchCardState(t,g){let a=o.get(t);if(!a)throw new Error(`Card "${t}" not found`);a.card_data={...a.card_data??{},...g},i.retrigger(t);},retrigger(t){i.retrigger(t);},retriggerAll(){i.retriggerAll(Array.from(o.keys()));},push(t){i.push(t);},pushAll(t){i.pushAll(t);},dispose(){h.clear(),i.dispose();}}}function G(e){return e==="running"||e==="in-progress"?"loading":e==="failed"?"error":"fresh"}function D(e){return e==="loading"?"in-progress":e==="error"?"failed":e==="stale"?"pending":e==="fresh"?"completed":"pending"}function M(e,r){let n=r&&typeof r=="object"&&!Array.isArray(r)?r:{};return {schema_version:n.schema_version||"v1",card_id:typeof n.card_id=="string"?n.card_id:e,card_data:n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?structuredClone(n.card_data):{},computed_values:n.computed_values&&typeof n.computed_values=="object"&&!Array.isArray(n.computed_values)?structuredClone(n.computed_values):{}}}function P(e,r){if(!e||typeof e!="object")throw new Error("payload must be an object");if(!r)throw new Error("cardId is required");let u=(Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).find(t=>t.id===r);if(!u)throw new Error(`cardDefinitions has no entry with id ${r}`);let o=e.statusSnapshot&&typeof e.statusSnapshot=="object"?e.statusSnapshot:{},h=e.cardRuntimeById&&typeof e.cardRuntimeById=="object"?e.cardRuntimeById:{},S=e.dataObjectsByToken&&typeof e.dataObjectsByToken=="object"?e.dataObjectsByToken:{},d=(Array.isArray(o.cards)?o.cards:[]).find(t=>t.name===r),m=structuredClone(u),A=M(r,h[r]),s={...m.card_data&&typeof m.card_data=="object"&&!Array.isArray(m.card_data)?m.card_data:{},...A.card_data||{},status:G(d?.status),lastRun:d?.runtime?.last_transition_at??null};d?.error?.message&&(s.error=d.error.message);let f=d?{task_status:d.status??null,card_status:G(d.status),runtime:structuredClone(d.runtime??{}),error:d.error?structuredClone(d.error):null,blocked_by:Array.isArray(d.blocked_by)?structuredClone(d.blocked_by):[],requires_missing:Array.isArray(d.requires_missing)?structuredClone(d.requires_missing):[]}:{task_status:null,card_status:s.status??"fresh",runtime:{last_transition_at:s.lastRun??null},error:s.error?{message:s.error}:null,blocked_by:[],requires_missing:[]},l=Array.isArray(m.requires)?m.requires:[],C={};for(let[t,g]of Object.entries(S))C[t]=structuredClone(g);for(let t of l)Object.prototype.hasOwnProperty.call(C,t)||(C[t]=null);let v=(e.cardChatsByCardId&&typeof e.cardChatsByCardId=="object"?e.cardChatsByCardId:{})[r],q=v?{messages:Array.isArray(v.messages)?v.messages:[],receiving:!!v.receiving,processing:!!v.processing}:null;return {id:r,card:m,card_data:s,requires:C,computed_values:A.computed_values,runtime_state:f,card_chats:q}}function $(e){if(!e||typeof e!="object")throw new Error("payload must be an object");return (Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).map(n=>P(e,n.id))}function J({boardPath:e,cardDefinitions:r,runtimeModels:n,graphState:u}){let o=Array.isArray(r)?r:[],h=Array.isArray(n)?n:[],S=new Map(h.map(s=>[s.id,s])),d=u.state?.tasks??{},m={};for(let s of h)s?.id&&(m[s.id]={schema_version:"v1",card_id:s.id,card_data:structuredClone(s.card_data??{}),computed_values:structuredClone(s.computed_values??{})});let A={};for(let s of Object.keys(d)){let f=d[s]?.data?.provides_data;if(f&&typeof f=="object")for(let l of Object.keys(f))A[l]=structuredClone(f[l]);}let _=o.map(s=>{let f=S.get(s.id)??{},l=d[s.id],C=typeof l?.status=="string"?l.status:D(f.card_data?.status),i=typeof l?.error=="string"?l.error:typeof f.card_data?.error=="string"?f.card_data.error:null;return {name:s.id,status:C,...i?{error:{message:i,code:"TASK_FAILED",at:l?.failedAt??null,source:"browser-runtime"}}:{},requires:Array.isArray(s.requires)?s.requires:[],requires_satisfied:[],requires_missing:[],provides_declared:Array.isArray(s.provides)?s.provides.map(v=>v.bindTo):[s.id],provides_runtime:Object.keys(l?.data?.provides_data??{}).sort(),blocked_by:[],unblocks:[],runtime:{attempt_count:l?.executionCount??0,restart_count:l?.retryCount??0,in_progress_since:C==="in-progress"?l?.startedAt??null:null,last_transition_at:l?.lastUpdated??f.card_data?.lastRun??null,last_completed_at:l?.completedAt??null,last_restarted_at:l?.startedAt??null,status_age_ms:null}}});return {cardDefinitions:structuredClone(o),cardRuntimeById:m,dataObjectsByToken:A,statusSnapshot:{schema_version:"v1",meta:{board:{path:e??"browser-runtime"}},summary:{card_count:_.length,completed:_.filter(s=>s.status==="completed").length,eligible:0,pending:_.filter(s=>s.status==="pending").length,blocked:0,unresolved:0,failed:_.filter(s=>s.status==="failed").length,in_progress:_.filter(s=>s.status==="in-progress").length,orphan_cards:0,topology:{edge_count:0,max_fan_out_card:null,max_fan_out:0}},cards:_}}}exports.a=F;exports.b=H;exports.c=P;exports.d=$;exports.e=J;//# sourceMappingURL=chunk-6SPWFJRG.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunk66ZZIF2L_cjs=require('./chunk-66ZZIF2L.cjs');function b(e){return JSON.parse(JSON.stringify(e))}function E(e){let r=e.provides&&e.provides.length>0?e.provides.map(n=>n.bindTo):[e.id];return {requires:e.requires&&e.requires.length>0?[...e.requires]:void 0,provides:r,taskHandlers:[e.id],description:e.meta?.title??e.id}}function I(e){let r=new Map;for(let[n,u]of e.entries()){let o=u.provides&&u.provides.length>0?u.provides:[{bindTo:n,ref:"card_data"}];for(let h of o)r.set(h.bindTo,n);}return r}function O(e,r){let n=I(e),u=e.get(r);if(u){for(let o of u.requires??[])if(!n.has(o))throw new Error(`Card "${r}" requires token "${o}" but no card provides it`)}}var F={CARD_PREFIX:"yf:cards:",RUNTIME_OUT_PREFIX:"yf:runtime-out:cards:",STATUS_KEY:"yf:runtime-out:status",writeCard(e,r){try{localStorage.setItem(this.CARD_PREFIX+e,JSON.stringify(r));}catch(n){console.warn(`Failed to write card ${e} to localStorage:`,n);}},readCard(e){try{let r=localStorage.getItem(this.CARD_PREFIX+e);return r?JSON.parse(r):null}catch(r){return console.warn(`Failed to read card ${e} from localStorage:`,r),null}},readAllCards(e){let r={};for(let n of e){let u=this.readCard(n);u&&(r[n]=u);}return r},writeComputedArtifact(e){if(!(!e||!e.card_id))try{localStorage.setItem(this.RUNTIME_OUT_PREFIX+String(e.card_id),JSON.stringify(e));}catch(r){console.warn(`Failed to write computed artifact ${e.card_id}:`,r);}},readComputedArtifact(e){try{let r=localStorage.getItem(this.RUNTIME_OUT_PREFIX+e);return r?JSON.parse(r):null}catch(r){return console.warn(`Failed to read computed artifact ${e}:`,r),null}},readAllComputedArtifacts(e){let r={};for(let n of e){let u=this.readComputedArtifact(n);u&&(r[n]=u);}return r},writeStatusSnapshot(e){try{localStorage.setItem(this.STATUS_KEY,JSON.stringify(e));}catch(r){console.warn("Failed to write status snapshot to localStorage:",r);}},readStatusSnapshot(){try{let e=localStorage.getItem(this.STATUS_KEY);return e?JSON.parse(e):null}catch(e){return console.warn("Failed to read status snapshot from localStorage:",e),null}},clear(){let e=[];for(let r=0;r<localStorage.length;r++){let n=localStorage.key(r);n&&(n.startsWith(this.CARD_PREFIX)||n.startsWith(this.RUNTIME_OUT_PREFIX)||n===this.STATUS_KEY)&&e.push(n);}for(let r of e)localStorage.removeItem(r);}};function H(e,r={}){let n=Array.isArray(e)?{}:{id:e.id,title:e.title,mode:e.mode,positions:e.positions,settings:e.settings},u=Array.isArray(e)?e:e.nodes,o=new Map;for(let t of u){if(o.has(t.id))throw new Error(`Duplicate card ID: "${t.id}"`);o.set(t.id,b(t));}let h=new Set,S=r.taskExecutor,L=r.sourceAdapters??{},d=r.defaultSourceAdapter,m=null,A=(t,g)=>{let a={events:t,graph:g,nodes:v()};for(let w of h)w(a);},_=t=>async g=>{let a=o.get(t);if(!a)return "task-initiate-failure";let w={};for(let R of a.requires??[]){let y=g.state[R];if(!y||typeof y!="object")continue;let k=y.provides_data;!k||typeof k!="object"||Object.prototype.hasOwnProperty.call(k,R)&&(w[R]=k[R]);}let p={};if(a.source_defs&&a.source_defs.length>0){let R=L[t]??d,y=S?await S({card:a,input:g}):R?await R({card:a,input:g}):void 0;if(y&&typeof y=="object")for(let k of a.source_defs)Object.prototype.hasOwnProperty.call(y,k.bindTo)?p[k.bindTo]=y[k.bindTo]:a.source_defs.length===1&&(p[k.bindTo]=y);}let c={id:a.id,card_data:b(a.card_data??{}),requires:w,source_defs:a.source_defs,compute:a.compute};c._sourcesData=p,c.compute&&c.compute.length>0&&await chunk66ZZIF2L_cjs.a.run(c,{sourcesData:p});let T={};if(a.provides&&a.provides.length>0)for(let{bindTo:R,ref:y}of a.provides)T[R]=chunk66ZZIF2L_cjs.a.resolve(c,y);else T[a.id]={...c.card_data??{},...c.computed_values??{},...c._sourcesData??{}};let B={provides_data:T,card_data:c.card_data??{},computed_values:c.computed_values??{},fetched_sources:p,requires:w};return m?.resolveCallback(g.callbackToken,B),"task-initiated"},s={},f={};for(let[t,g]of o.entries())O(o,t),s[t]=E(g),f[t]=_(t);let l={id:n.id??`browser-board-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...n.settings??{},...r.graphSettings??{}},tasks:s},C=r.reactiveOptions?.onDrain,i=chunkAW3COGCI_cjs.t(l,{...r.reactiveOptions??{},handlers:f,onDrain:(t,g,a)=>{C?.(t,g,a),A(t,g);}},r.executionId);m=i;function v(){let t=i.getState(),g=[];for(let[a,w]of o.entries()){let p=t.state.tasks[a]?.data,c=t.state.tasks[a],T={...w.card_data??{},...p&&typeof p.card_data=="object"?p.card_data:{}},B=c?.status==="running"?"loading":c?.status,R={...T,...B?{status:B}:{},...c?.lastUpdated?{lastRun:c.lastUpdated}:{},...c?.status==="failed"&&c.error?{error:c.error}:{}};g.push({id:a,card:b(w),card_data:R,requires:p&&typeof p.requires=="object"?b(p.requires):{},computed_values:p&&typeof p.computed_values=="object"?b(p.computed_values):{},runtime_state:c?b(c):{}});}return g}return {getGraph:()=>i,getState:()=>i.getState(),getSchedule:()=>i.getSchedule(),getNodes:()=>v(),getBoard:()=>({...n,nodes:v()}),subscribe(t){return h.add(t),t({events:[],graph:i.getState(),nodes:v()}),()=>h.delete(t)},addCard(t){if(o.has(t.id))throw new Error(`Card "${t.id}" already exists`);o.set(t.id,b(t)),O(o,t.id),i.registerHandler(t.id,_(t.id)),i.addNode(t.id,E(t));},upsertCard(t){o.set(t.id,b(t)),O(o,t.id),i.registerHandler(t.id,_(t.id)),i.addNode(t.id,E(t));},removeCard(t){o.delete(t),i.unregisterHandler(t),i.removeNode(t);},patchCardState(t,g){let a=o.get(t);if(!a)throw new Error(`Card "${t}" not found`);a.card_data={...a.card_data??{},...g},i.retrigger(t);},retrigger(t){i.retrigger(t);},retriggerAll(){i.retriggerAll(Array.from(o.keys()));},push(t){i.push(t);},pushAll(t){i.pushAll(t);},dispose(){h.clear(),i.dispose();}}}function G(e){return e==="running"||e==="in-progress"?"loading":e==="failed"?"error":"fresh"}function D(e){return e==="loading"?"in-progress":e==="error"?"failed":e==="stale"?"pending":e==="fresh"?"completed":"pending"}function M(e,r){let n=r&&typeof r=="object"&&!Array.isArray(r)?r:{};return {schema_version:n.schema_version||"v1",card_id:typeof n.card_id=="string"?n.card_id:e,card_data:n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?structuredClone(n.card_data):{},computed_values:n.computed_values&&typeof n.computed_values=="object"&&!Array.isArray(n.computed_values)?structuredClone(n.computed_values):{}}}function P(e,r){if(!e||typeof e!="object")throw new Error("payload must be an object");if(!r)throw new Error("cardId is required");let u=(Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).find(t=>t.id===r);if(!u)throw new Error(`cardDefinitions has no entry with id ${r}`);let o=e.statusSnapshot&&typeof e.statusSnapshot=="object"?e.statusSnapshot:{},h=e.cardRuntimeById&&typeof e.cardRuntimeById=="object"?e.cardRuntimeById:{},S=e.dataObjectsByToken&&typeof e.dataObjectsByToken=="object"?e.dataObjectsByToken:{},d=(Array.isArray(o.cards)?o.cards:[]).find(t=>t.name===r),m=structuredClone(u),A=M(r,h[r]),s={...m.card_data&&typeof m.card_data=="object"&&!Array.isArray(m.card_data)?m.card_data:{},...A.card_data||{},status:G(d?.status),lastRun:d?.runtime?.last_transition_at??null};d?.error?.message&&(s.error=d.error.message);let f=d?{task_status:d.status??null,card_status:G(d.status),runtime:structuredClone(d.runtime??{}),error:d.error?structuredClone(d.error):null,blocked_by:Array.isArray(d.blocked_by)?structuredClone(d.blocked_by):[],requires_missing:Array.isArray(d.requires_missing)?structuredClone(d.requires_missing):[]}:{task_status:null,card_status:s.status??"fresh",runtime:{last_transition_at:s.lastRun??null},error:s.error?{message:s.error}:null,blocked_by:[],requires_missing:[]},l=Array.isArray(m.requires)?m.requires:[],C={};for(let[t,g]of Object.entries(S))C[t]=structuredClone(g);for(let t of l)Object.prototype.hasOwnProperty.call(C,t)||(C[t]=null);let v=(e.cardChatsByCardId&&typeof e.cardChatsByCardId=="object"?e.cardChatsByCardId:{})[r],q=v?{messages:Array.isArray(v.messages)?v.messages:[],receiving:!!v.receiving,processing:!!v.processing}:null;return {id:r,card:m,card_data:s,requires:C,computed_values:A.computed_values,runtime_state:f,card_chats:q}}function $(e){if(!e||typeof e!="object")throw new Error("payload must be an object");return (Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).map(n=>P(e,n.id))}function J({boardPath:e,cardDefinitions:r,runtimeModels:n,graphState:u}){let o=Array.isArray(r)?r:[],h=Array.isArray(n)?n:[],S=new Map(h.map(s=>[s.id,s])),d=u.state?.tasks??{},m={};for(let s of h)s?.id&&(m[s.id]={schema_version:"v1",card_id:s.id,card_data:structuredClone(s.card_data??{}),computed_values:structuredClone(s.computed_values??{})});let A={};for(let s of Object.keys(d)){let f=d[s]?.data?.provides_data;if(f&&typeof f=="object")for(let l of Object.keys(f))A[l]=structuredClone(f[l]);}let _=o.map(s=>{let f=S.get(s.id)??{},l=d[s.id],C=typeof l?.status=="string"?l.status:D(f.card_data?.status),i=typeof l?.error=="string"?l.error:typeof f.card_data?.error=="string"?f.card_data.error:null;return {name:s.id,status:C,...i?{error:{message:i,code:"TASK_FAILED",at:l?.failedAt??null,source:"browser-runtime"}}:{},requires:Array.isArray(s.requires)?s.requires:[],requires_satisfied:[],requires_missing:[],provides_declared:Array.isArray(s.provides)?s.provides.map(v=>v.bindTo):[s.id],provides_runtime:Object.keys(l?.data?.provides_data??{}).sort(),blocked_by:[],unblocks:[],runtime:{attempt_count:l?.executionCount??0,restart_count:l?.retryCount??0,in_progress_since:C==="in-progress"?l?.startedAt??null:null,last_transition_at:l?.lastUpdated??f.card_data?.lastRun??null,last_completed_at:l?.completedAt??null,last_restarted_at:l?.startedAt??null,status_age_ms:null}}});return {cardDefinitions:structuredClone(o),cardRuntimeById:m,dataObjectsByToken:A,statusSnapshot:{schema_version:"v1",meta:{board:{path:e??"browser-runtime"}},summary:{card_count:_.length,completed:_.filter(s=>s.status==="completed").length,eligible:0,pending:_.filter(s=>s.status==="pending").length,blocked:0,unresolved:0,failed:_.filter(s=>s.status==="failed").length,in_progress:_.filter(s=>s.status==="in-progress").length,orphan_cards:0,topology:{edge_count:0,max_fan_out_card:null,max_fan_out:0}},cards:_}}}exports.a=F;exports.b=H;exports.c=P;exports.d=$;exports.e=J;//# sourceMappingURL=chunk-PYYRDOD5.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-PYYRDOD5.cjs.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {createRequire}from'module';var g=createRequire(import.meta.url),u=g("./jsonata-sync.cjs"),c=u;function d(t,r){if(!r||!t)return;let s=r.split("."),e=t;for(let n=0;n<s.length;n++){if(e==null)return;e=e[s[n]];}return e}function f(t,r,s){let e=r.split("."),n=t;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(t,r){if(!t?.compute?.length)return t;t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=r?.sourcesData??{};let s=t.requires??{},e={card_data:t.card_data,requires:s,expects_data:s,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values};for(let n of t.compute)try{let o=await u(n.expr).evaluate(e);f(t.computed_values,n.bindTo,o),e.computed_values=t.computed_values;}catch{}return t}function y(t,r){if(!t?.compute?.length)return {ok:true,node:t};t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=r?.sourcesData??{};let s=t.requires??{},e={card_data:t.card_data,requires:s,expects_data:s,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values},n=[];for(let o of t.compute)try{let a=c(o.expr).evaluate(e);f(t.computed_values,o.bindTo,a),e.computed_values=t.computed_values;}catch(a){let i=a instanceof Error?a.message:String(a);n.push({bindTo:o.bindTo,error:i});}return n.length>0?{ok:true,node:t,errors:n}:{ok:true,node:t}}async function _(t,r,s){let e={...s??{},card_data:r.card_data??{},requires:r.requires??{},fetched_sources:r._sourcesData??{},computed_values:r.computed_values??{}};return u(t).evaluate(e)}function b(t,r){return r.startsWith("fetched_sources.")?d(t._sourcesData??{},r.slice(16)):d(t,r)}var p=new Set(["metric","table","editable-table","chart","form","list","notes","todo","alert","narrative","badge","text","markdown","markup","selection","searchbox","query","ref","custom","actions"]),h=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function k(t){let r=[];if(!t||typeof t!="object"||Array.isArray(t))return {ok:false,errors:["Node must be a non-null object"]};let s=t;(typeof s.id!="string"||!s.id)&&r.push("id: required, must be a non-empty string");for(let e of Object.keys(s))h.has(e)||r.push(`Unknown top-level key: "${e}"`);if((s.card_data==null||typeof s.card_data!="object"||Array.isArray(s.card_data))&&r.push("card_data: required, must be an object"),s.meta!=null)if(typeof s.meta!="object"||Array.isArray(s.meta))r.push("meta: must be an object");else {let e=s.meta;e.title!=null&&typeof e.title!="string"&&r.push("meta.title: must be a string"),e.tags!=null&&!Array.isArray(e.tags)&&r.push("meta.tags: must be an array");}if(s.requires!=null&&!Array.isArray(s.requires)&&r.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))r.push(`provides[${n}]: must be an object with bindTo and ref`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&r.push(`provides[${n}]: missing required "bindTo" string`),(typeof o.ref!="string"||!o.ref)&&r.push(`provides[${n}]: missing required "ref" string`);}}):r.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))r.push(`compute[${n}]: must be a compute step object`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&r.push(`compute[${n}]: missing required "bindTo" property`),(typeof o.expr!="string"||!o.expr)&&r.push(`compute[${n}]: missing required "expr" string (JSONata expression)`);}}):r.push("compute: must be an array of compute steps")),s.source_defs!=null)if(!Array.isArray(s.source_defs))r.push("source_defs: must be an array");else {let e=new Set,n=new Set;s.source_defs.forEach((o,a)=>{if(!o||typeof o!="object"||Array.isArray(o))r.push(`source_defs[${a}]: must be an object`);else {let i=o;typeof i.bindTo!="string"||!i.bindTo?r.push(`source_defs[${a}]: missing required "bindTo" property`):(e.has(i.bindTo)&&r.push(`source_defs[${a}]: bindTo "${i.bindTo}" is not unique across source_defs`),e.add(i.bindTo)),typeof i.outputFile!="string"||!i.outputFile?r.push(`source_defs[${a}]: missing required "outputFile" property`):(n.has(i.outputFile)&&r.push(`source_defs[${a}]: outputFile "${i.outputFile}" is not unique across source_defs`),n.add(i.outputFile));}});}if(s.view!=null)if(typeof s.view!="object"||Array.isArray(s.view))r.push("view: must be an object");else {let e=s.view;!Array.isArray(e.elements)||e.elements.length===0?r.push("view.elements: required, must be a non-empty array"):e.elements.forEach((n,o)=>{if(!n||typeof n!="object"){r.push(`view.elements[${o}]: must be an object`);return}!n.kind||typeof n.kind!="string"?r.push(`view.elements[${o}].kind: required, must be a string`):p.has(n.kind)||r.push(`view.elements[${o}].kind: unknown kind "${n.kind}". Valid: ${[...p].join(", ")}`),n.data!=null&&(typeof n.data!="object"||Array.isArray(n.data))&&r.push(`view.elements[${o}].data: must be an object`);});}return {ok:r.length===0,errors:r}}async function w(t,r){if(!t||t.length===0)return [];let s={card_data:r.card_data??{},requires:r.requires??{}};return Promise.all(t.map(async e=>{let n=false;if(typeof e.skip_when=="string"&&e.skip_when.trim().length>0)try{n=!!await u(e.skip_when).evaluate(s);}catch{n=false;}let o={};if(!n&&e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[a,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{o[a]=await u(i).evaluate(s);}catch{o[a]=void 0;}}return {...e,_projections:o,_skip:n}}))}function v(t,r){if(!t||t.length===0)return [];let s={card_data:r.card_data??{},requires:r.requires??{}};return t.map(e=>{let n=false;if(typeof e.skip_when=="string"&&e.skip_when.trim().length>0)try{n=!!c(e.skip_when).evaluate(s);}catch{n=false;}let o={};if(!n&&e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[a,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{o[a]=c(i).evaluate(s);}catch{o[a]=void 0;}}return {...e,_projections:o,_skip:n}})}var j={run:m,runSync:y,eval:_,resolve:b,validate:k,enrichSources:w,enrichSourcesSync:v},$=j;export{j as a,$ as b};//# sourceMappingURL=chunk-QE3QXEHI.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-QE3QXEHI.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {b as b$1,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-YOY2JM5N.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 M(e,r){return L(e)?e.then(r):r(e)}function ee(e,r){let t={...e};for(let o of r.deleteKeys)delete t[o];return {...t,...r.shallowMerge}}function ve(e,r){return {readValues(o){let n=e(o);return M(n.listKeys(),s=>{let a=[...s].sort();if(a.length===0)return {version:null,values:{}};let i={},c=null;for(let f of a){let d=n.read(f);L(d)?c=(c??Promise.resolve()).then(async()=>{i[f]=await d;}):i[f]=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 f=a.delete(c);L(f)&&(i=(i??Promise.resolve()).then(()=>f).then(()=>{}));}for(let[c,f]of Object.entries(n)){let d=a.write(c,f);L(d)&&(i=(i??Promise.resolve()).then(()=>d).then(()=>{}));}return i?i.then(()=>r(n)):r(n)}}}function te(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 M(e.readValues(t),n=>{if(n.version!==o.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let s=ee(n.values,o);return M(e.writeValues(t,s,o.deleteKeys),a=>({ok:true,newVersion:a}))})}}}function Z(e,r){if(!r)return e;let t=e.findIndex(o=>o.id===r);return t===-1?e:e.slice(t+1)}function re(e){return {readEntriesAfterCursor(r){let t=Z(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 Z(e.readAllEntries(),r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function be(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 b(e,r){return j(e)?e.then(r):r(e)}function U(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 pe(e){if(e==null)return null;let r=e.trim();if(!r)return null;try{return JSON.parse(r)}catch{return r}}function ge(e,r){let t=e.match(r);return t?t[1]:null}function ne(e,r,t){let o={},n=U(e,s=>{let a=t(s);if(a)return b(r(s),i=>{o[a]=i;})});return j(n)?n.then(()=>o):o}function oe(e,r){return {readSourceData(t,o){return b(e.read(`${t}/${o}`),pe)},ingestSourceDataStaged(t,o,n,s){return b(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 b(e.listKeys(`${t}/`),o=>o.filter(n=>!n.includes("/.staged/")).map(n=>n.slice(`${t}/`.length)))}}}function fe(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 b(e.read(o),s=>e.write(o,[...s??[],...n]))},dispatchEntriesForJournalId(o,n){if(o)return b(e.read(o),s=>{let a=s;if(!(!a||a.length===0))return b(U(a,i=>t(i,n)),()=>e.delete(o))})}}}function me(e,r,t){return {readRuntime(o){return b(e.read(r(o)),n=>n??t())},writeRuntime(o,n){return e.write(r(o),n)}}}function se(e){return {writeComputedValues(r,t){return e.write(`cards/${r}/computed_values`,t)},readComputedValues(r){return e.read(`cards/${r}/computed_values`)},readAllComputedValues(){return b(e.listKeys("cards/"),r=>ne(r,t=>e.read(t),t=>ge(t,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(r){return U(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 b(e.listKeys("data-objects/"),r=>ne(r,t=>e.read(t),t=>t.slice(13)))},writeStatusSnapshot(r){return e.write("status",r)},readStatusSnapshot(){return e.read("status")}}}var T="sys_keys_board_state",_="__sys_keys_board_state_init";function ue(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 Se(e){let r=e.filter(n=>!ue(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!==T))].sort();return {card_ids:t,data_object_keys:o}}function ye(e,r){let t=e.filter(s=>!ue(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!==_).flatMap(([,s])=>Array.isArray(s.provides)?s.provides:[]).filter(s=>typeof s=="string"&&s.length>0&&s!==T))].sort();return {card_ids:o,data_object_keys:n}}function Ve(){return {id:_,meta:{title:"System Keys Board State",synthetic:true},provides:[{bindTo:T,ref:`card_data.${T}`}],card_data:{[T]:{card_ids:[],data_object_keys:[]}},__private:{visible_controlplane_only:true}}}function Pe(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},f=c;for(let d=0;d<i.length-1;d++){let u=i[d],l=f[u],m=l&&typeof l=="object"&&!Array.isArray(l)?{...l}:{};f[u]=m,f=m;}return f[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(([,f])=>f.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),f=e.writeCard(c,s);i[n]={key:c,checksum:f,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 f=e.readCard(c.key);if(!f||typeof f!="object"||Array.isArray(f))throw new Error(`card "${n}" is not patchable`);let d=o(f,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 Ke(e,r){return oe(e,r)}function qe(e){return re(e)}var he="v1",H="board/graph",ce="board/lastJournalProcessedId";function Be(e){return `cards/${e}/runtime`}function Le(e){return te(e,he)}function je(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$1(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 De(e){return se(e)}function ie(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function ke(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function ae(e,r){return e?.lastRequestedToken?ke(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<r?"dispatch":"idle":"dispatch"}function Ce(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"success"}}function de(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"failure"}}function $e(e){let r=e.cards.filter(i=>i.name!==_);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 Ne(e){let{[T]:r,...t}=e;return t}function Je(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,S]of Object.entries(o))for(let w of S.requires??[]){let k=c.get(w)??[];k.push(p),c.set(w,k);}let f=n.sort().map(p=>{let S=t[p],w=o[p]??{requires:[],provides:[]};S.status==="completed"?a$1.completed+=1:S.status==="failed"?a$1.failed+=1:S.status==="in-progress"&&(a$1.in_progress+=1);let k=w.requires??[],R=w.provides??[],I=Object.keys(S.data??{}).sort(),v=k.filter(x=>r.state.availableOutputs.includes(x)),D=k.filter(x=>!r.state.availableOutputs.includes(x)),E=i.get(p)??D,F=new Set;for(let x of R)for(let q of c.get(x)??[])q!==p&&F.add(q);let V=S.failedAt,O=S.error?{message:S.error,code:"TASK_FAILED",at:V,source:"task-runtime"}:void 0;return {name:p,status:S.status,error:O,requires:k,requires_satisfied:v,requires_missing:D,provides_declared:R,provides_runtime:I,blocked_by:E,unblocks:Array.from(F).sort(),runtime:{attempt_count:S.executionCount??0,restart_count:S.retryCount??0,in_progress_since:S.status==="in-progress"?S.startedAt??null:null,last_transition_at:S.lastUpdated??null,last_completed_at:S.completedAt??null,last_restarted_at:S.startedAt??null,status_age_ms:S.lastUpdated?0:null}}});a$1.pending=s.pending.length,a$1.blocked=s.blocked.length,a$1.unresolved=s.unresolved.length;let d=f.map(p=>({name:p.name,fanOut:p.unblocks.length})).sort((p,S)=>S.fanOut-p.fanOut||p.name.localeCompare(S.name)),u=d.length>0?d[0]:{name:null,fanOut:0},l=new Set;for(let p of Object.values(o))for(let S of p.requires??[])l.add(S);let m=0;for(let[p,S]of Object.entries(o)){let w=(S.requires??[]).length===0,R=(S.provides??[]).some(I=>(c.get(I)??[]).some(v=>v!==p));w&&!R&&(m+=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:m,topology:{edge_count:Array.from(l).length,max_fan_out_card:u.name,max_fan_out:u.fanOut}},cards:f}}function we(){return new Date().toISOString()}function Me(e,r,t,o,n,s,a){return async i=>{let c=[],f=t.cardStore.readCard(i.nodeId);if(!f)return "task-initiate-failure";let d=f.id;if(d===_){let g=t.activeTaskConfigs?.(),y={[T]:g?ye(Object.keys(g).filter(h=>h!==_).map(h=>t.cardStore.readCard(h)).filter(h=>!!h),g):Se(t.cardStore.readAllCards())};return (a??t.outputStore.writeDataObjects.bind(t.outputStore))(y),o(i.nodeId,y),"task-initiated"}let u=f.card_data??{},l=f.source_defs??[],m=t.cardRuntimeStore.readRuntime(d),p=false,S=()=>{p&&(t.cardRuntimeStore.writeRuntime(d,m),p=false);},w=g=>ie(m._sources[g]),k=(g,y)=>{m._sources[g]=ie(y),p=true;},R=i.taskState?.executionCount??0;if(m._lastExecutionCount!==R&&(m._sources={},m._lastExecutionCount=R,p=true),i.update){let g=i.update,y=g.outputFile;if(y){let h=w(y);if(g.failure){let C=g.rqt??h.lastRequestedToken??h.queueRequestedToken;C&&k(y,de(h,C));}else {let C=g.rqt;if(!h.lastCompletedToken||C>h.lastCompletedToken){let A=typeof g.deliveryToken=="string"?g.deliveryToken:void 0,K=false;A&&(K=t.fetchedSourcesStore.commitSourceData(d,y,A)),K?k(y,Ce(h,C)):k(y,de(h,C));}}S();}}let v={};for(let[g,y]of Object.entries(i.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let h=y[g];v[g]=h!==void 0?h:y;}else v[g]=y;let E=a$1.enrichSourcesSync(Array.isArray(f.source_defs)?f.source_defs:void 0,{card_data:u,requires:v}).filter(g=>g._skip!==true),F=E,V={};for(let g of E)if(g.outputFile){let y=t.fetchedSourcesStore.readSourceData(d,g.outputFile);y!==null&&(V[g.bindTo]=y);}let O={id:d,card_data:{...u},requires:v,source_defs:l,compute:f.compute};O._sourcesData=V,f.compute&&a$1.runSync(O,{sourcesData:V}),(s??t.outputStore.writeComputedValues.bind(t.outputStore))(d,O.computed_values??{});let x={...f},q=e.value;x.source_defs=Array.isArray(E)?E.map(g=>({...g,boardDir:typeof g.boardDir=="string"&&g.boardDir?g.boardDir:q})):E;let P=we(),G=i.update?void 0:P,z=F.filter(g=>{let y=g.outputFile;if(typeof y!="string"||!y)return true;let h=w(y);G&&(h={...h,queueRequestedToken:G},k(y,h));let C=h.queueRequestedToken??h.lastRequestedToken??P,A=ae(h,C);return A==="in-flight"?false:A==="dispatch"});if(S(),z.length>0){let g=false,y=P;for(let h of z){let C=h.outputFile;if(typeof C!="string"||!C)continue;let A=w(C),K=A.queueRequestedToken??P;k(C,{...A,lastRequestedToken:K}),y=K,g=true;}return g&&S(),g&&(c.push({taskKind:"source-fetch",payload:{boardRef:a$2(e),enrichedCard:x,callbackToken:i.callbackToken,rqt:y}}),t.executionRequestStore.appendEntries(r,c)),"task-initiated"}if(F.some(g=>{let y=g.outputFile;if(typeof y!="string"||!y)return false;let h=w(y),C=h.queueRequestedToken??h.lastRequestedToken??P;return ae(h,C)==="in-flight"}))return "task-initiated";let le=f.provides??[],$={};for(let{bindTo:g,ref:y}of le)$[g]=a$1.resolve(O,y);return (a??t.outputStore.writeDataObjects.bind(t.outputStore))($),o(i.nodeId,$),c.length>0&&t.executionRequestStore.appendEntries(r,c),"task-initiated"}}var Ue={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function He(e){return {[H]:e.graph,[ce]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function Ge(e){let r=e[H],t=e[ce],n=e.board?.runtimeByCardId;if(!r||typeof r!="object")throw new Error(`State snapshot is missing required key: ${H}`);return {graph:r,lastDrainedJournalId:typeof t=="string"?t:"",runtimeByCardId:n&&typeof n=="object"?n:{}}}function ze(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 Xe(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===_}async function a(d){let u=r.emitNotification;if(!u||d.length===0)return;let l=e(d.filter(m=>m.kind!=="card_refreshed"?true:!s(m.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 f$1(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 m of l){if(typeof m.id!="string")return o("each card must have a string `id` field");e$1.writeCard(m.id,m);}return a(l.map(m=>({kind:"card_refreshed",cardId:m.id,card:m}))),t({count:l.length})}catch(u){return n(u)}},del(d){try{let u=d.body?.ids??[],l=d.params?.id,m=l?[...u,l]:u;if(m.length===0)return o("del requires body.ids (string[]) or params.id");for(let p of m)e$1.removeCard(p);return a(m.map(p=>({kind:"card_removed",cardId:p}))),t({count:m.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 m=d.body,p=m&&Object.prototype.hasOwnProperty.call(m,"value")?m.value:d.body;e$1.patchCard(u,l,p);let S=e$1.readCard(u);return S?(a([{kind:"card_refreshed",cardId:u,card:S}]),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 m=f$1(d.body);if(!m||m.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:{},S=Array.isArray(p.files)?p.files:[],w=[...S,...m],k=m.map((I,v)=>({idx:S.length+v,entry:I})),R=this.patch({params:{id:u,path:"card_data.files"},body:{value:w}});return R.status!=="success"?R:t({files_added:k})}catch(u){return n(u)}}}}export{Ne as A,Je as B,Me as C,Ue as D,He as E,Ge as F,ze as G,Xe as H,ve as a,te as b,be as c,oe as d,fe as e,me as f,se as g,T as h,_ as i,Se as j,ye as k,Ve as l,Pe as m,Ke as n,qe as o,he as p,H as q,Be as r,Le as s,je as t,De as u,ie as v,ae as w,Ce as x,de as y,$e as z};//# sourceMappingURL=chunk-MRESV3MD.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {b as b$1,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-QE3QXEHI.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 M(e,r){return L(e)?e.then(r):r(e)}function ee(e,r){let t={...e};for(let o of r.deleteKeys)delete t[o];return {...t,...r.shallowMerge}}function ve(e,r){return {readValues(o){let n=e(o);return M(n.listKeys(),s=>{let a=[...s].sort();if(a.length===0)return {version:null,values:{}};let i={},c=null;for(let f of a){let d=n.read(f);L(d)?c=(c??Promise.resolve()).then(async()=>{i[f]=await d;}):i[f]=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 f=a.delete(c);L(f)&&(i=(i??Promise.resolve()).then(()=>f).then(()=>{}));}for(let[c,f]of Object.entries(n)){let d=a.write(c,f);L(d)&&(i=(i??Promise.resolve()).then(()=>d).then(()=>{}));}return i?i.then(()=>r(n)):r(n)}}}function te(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 M(e.readValues(t),n=>{if(n.version!==o.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:n.version};let s=ee(n.values,o);return M(e.writeValues(t,s,o.deleteKeys),a=>({ok:true,newVersion:a}))})}}}function Z(e,r){if(!r)return e;let t=e.findIndex(o=>o.id===r);return t===-1?e:e.slice(t+1)}function re(e){return {readEntriesAfterCursor(r){let t=Z(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 Z(e.readAllEntries(),r).length},appendEvent(r){e.appendEntry({id:e.generateId(),event:r});}}}function be(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 b(e,r){return j(e)?e.then(r):r(e)}function U(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 pe(e){if(e==null)return null;let r=e.trim();if(!r)return null;try{return JSON.parse(r)}catch{return r}}function ge(e,r){let t=e.match(r);return t?t[1]:null}function ne(e,r,t){let o={},n=U(e,s=>{let a=t(s);if(a)return b(r(s),i=>{o[a]=i;})});return j(n)?n.then(()=>o):o}function oe(e,r){return {readSourceData(t,o){return b(e.read(`${t}/${o}`),pe)},ingestSourceDataStaged(t,o,n,s){return b(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 b(e.listKeys(`${t}/`),o=>o.filter(n=>!n.includes("/.staged/")).map(n=>n.slice(`${t}/`.length)))}}}function fe(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 b(e.read(o),s=>e.write(o,[...s??[],...n]))},dispatchEntriesForJournalId(o,n){if(o)return b(e.read(o),s=>{let a=s;if(!(!a||a.length===0))return b(U(a,i=>t(i,n)),()=>e.delete(o))})}}}function me(e,r,t){return {readRuntime(o){return b(e.read(r(o)),n=>n??t())},writeRuntime(o,n){return e.write(r(o),n)}}}function se(e){return {writeComputedValues(r,t){return e.write(`cards/${r}/computed_values`,t)},readComputedValues(r){return e.read(`cards/${r}/computed_values`)},readAllComputedValues(){return b(e.listKeys("cards/"),r=>ne(r,t=>e.read(t),t=>ge(t,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(r){return U(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 b(e.listKeys("data-objects/"),r=>ne(r,t=>e.read(t),t=>t.slice(13)))},writeStatusSnapshot(r){return e.write("status",r)},readStatusSnapshot(){return e.read("status")}}}var T="sys_keys_board_state",_="__sys_keys_board_state_init";function ue(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 Se(e){let r=e.filter(n=>!ue(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!==T))].sort();return {card_ids:t,data_object_keys:o}}function ye(e,r){let t=e.filter(s=>!ue(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!==_).flatMap(([,s])=>Array.isArray(s.provides)?s.provides:[]).filter(s=>typeof s=="string"&&s.length>0&&s!==T))].sort();return {card_ids:o,data_object_keys:n}}function Ve(){return {id:_,meta:{title:"System Keys Board State",synthetic:true},provides:[{bindTo:T,ref:`card_data.${T}`}],card_data:{[T]:{card_ids:[],data_object_keys:[]}},__private:{visible_controlplane_only:true}}}function Pe(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},f=c;for(let d=0;d<i.length-1;d++){let u=i[d],l=f[u],m=l&&typeof l=="object"&&!Array.isArray(l)?{...l}:{};f[u]=m,f=m;}return f[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(([,f])=>f.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),f=e.writeCard(c,s);i[n]={key:c,checksum:f,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 f=e.readCard(c.key);if(!f||typeof f!="object"||Array.isArray(f))throw new Error(`card "${n}" is not patchable`);let d=o(f,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 Ke(e,r){return oe(e,r)}function qe(e){return re(e)}var he="v1",H="board/graph",ce="board/lastJournalProcessedId";function Be(e){return `cards/${e}/runtime`}function Le(e){return te(e,he)}function je(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$1(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 De(e){return se(e)}function ie(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function ke(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function ae(e,r){return e?.lastRequestedToken?ke(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<r?"dispatch":"idle":"dispatch"}function Ce(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"success"}}function de(e,r){return {...e,lastCompletedToken:r,lastCompletionStatus:"failure"}}function $e(e){let r=e.cards.filter(i=>i.name!==_);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 Ne(e){let{[T]:r,...t}=e;return t}function Je(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,S]of Object.entries(o))for(let w of S.requires??[]){let k=c.get(w)??[];k.push(p),c.set(w,k);}let f=n.sort().map(p=>{let S=t[p],w=o[p]??{requires:[],provides:[]};S.status==="completed"?a$1.completed+=1:S.status==="failed"?a$1.failed+=1:S.status==="in-progress"&&(a$1.in_progress+=1);let k=w.requires??[],R=w.provides??[],I=Object.keys(S.data??{}).sort(),v=k.filter(x=>r.state.availableOutputs.includes(x)),D=k.filter(x=>!r.state.availableOutputs.includes(x)),E=i.get(p)??D,F=new Set;for(let x of R)for(let q of c.get(x)??[])q!==p&&F.add(q);let V=S.failedAt,O=S.error?{message:S.error,code:"TASK_FAILED",at:V,source:"task-runtime"}:void 0;return {name:p,status:S.status,error:O,requires:k,requires_satisfied:v,requires_missing:D,provides_declared:R,provides_runtime:I,blocked_by:E,unblocks:Array.from(F).sort(),runtime:{attempt_count:S.executionCount??0,restart_count:S.retryCount??0,in_progress_since:S.status==="in-progress"?S.startedAt??null:null,last_transition_at:S.lastUpdated??null,last_completed_at:S.completedAt??null,last_restarted_at:S.startedAt??null,status_age_ms:S.lastUpdated?0:null}}});a$1.pending=s.pending.length,a$1.blocked=s.blocked.length,a$1.unresolved=s.unresolved.length;let d=f.map(p=>({name:p.name,fanOut:p.unblocks.length})).sort((p,S)=>S.fanOut-p.fanOut||p.name.localeCompare(S.name)),u=d.length>0?d[0]:{name:null,fanOut:0},l=new Set;for(let p of Object.values(o))for(let S of p.requires??[])l.add(S);let m=0;for(let[p,S]of Object.entries(o)){let w=(S.requires??[]).length===0,R=(S.provides??[]).some(I=>(c.get(I)??[]).some(v=>v!==p));w&&!R&&(m+=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:m,topology:{edge_count:Array.from(l).length,max_fan_out_card:u.name,max_fan_out:u.fanOut}},cards:f}}function we(){return new Date().toISOString()}function Me(e,r,t,o,n,s,a){return async i=>{let c=[],f=t.cardStore.readCard(i.nodeId);if(!f)return "task-initiate-failure";let d=f.id;if(d===_){let g=t.activeTaskConfigs?.(),y={[T]:g?ye(Object.keys(g).filter(h=>h!==_).map(h=>t.cardStore.readCard(h)).filter(h=>!!h),g):Se(t.cardStore.readAllCards())};return (a??t.outputStore.writeDataObjects.bind(t.outputStore))(y),o(i.nodeId,y),"task-initiated"}let u=f.card_data??{},l=f.source_defs??[],m=t.cardRuntimeStore.readRuntime(d),p=false,S=()=>{p&&(t.cardRuntimeStore.writeRuntime(d,m),p=false);},w=g=>ie(m._sources[g]),k=(g,y)=>{m._sources[g]=ie(y),p=true;},R=i.taskState?.executionCount??0;if(m._lastExecutionCount!==R&&(m._sources={},m._lastExecutionCount=R,p=true),i.update){let g=i.update,y=g.outputFile;if(y){let h=w(y);if(g.failure){let C=g.rqt??h.lastRequestedToken??h.queueRequestedToken;C&&k(y,de(h,C));}else {let C=g.rqt;if(!h.lastCompletedToken||C>h.lastCompletedToken){let A=typeof g.deliveryToken=="string"?g.deliveryToken:void 0,K=false;A&&(K=t.fetchedSourcesStore.commitSourceData(d,y,A)),K?k(y,Ce(h,C)):k(y,de(h,C));}}S();}}let v={};for(let[g,y]of Object.entries(i.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let h=y[g];v[g]=h!==void 0?h:y;}else v[g]=y;let E=a$1.enrichSourcesSync(Array.isArray(f.source_defs)?f.source_defs:void 0,{card_data:u,requires:v}).filter(g=>g._skip!==true),F=E,V={};for(let g of E)if(g.outputFile){let y=t.fetchedSourcesStore.readSourceData(d,g.outputFile);y!==null&&(V[g.bindTo]=y);}let O={id:d,card_data:{...u},requires:v,source_defs:l,compute:f.compute};O._sourcesData=V,f.compute&&a$1.runSync(O,{sourcesData:V}),(s??t.outputStore.writeComputedValues.bind(t.outputStore))(d,O.computed_values??{});let x={...f},q=e.value;x.source_defs=Array.isArray(E)?E.map(g=>({...g,boardDir:typeof g.boardDir=="string"&&g.boardDir?g.boardDir:q})):E;let P=we(),G=i.update?void 0:P,z=F.filter(g=>{let y=g.outputFile;if(typeof y!="string"||!y)return true;let h=w(y);G&&(h={...h,queueRequestedToken:G},k(y,h));let C=h.queueRequestedToken??h.lastRequestedToken??P,A=ae(h,C);return A==="in-flight"?false:A==="dispatch"});if(S(),z.length>0){let g=false,y=P;for(let h of z){let C=h.outputFile;if(typeof C!="string"||!C)continue;let A=w(C),K=A.queueRequestedToken??P;k(C,{...A,lastRequestedToken:K}),y=K,g=true;}return g&&S(),g&&(c.push({taskKind:"source-fetch",payload:{boardRef:a$2(e),enrichedCard:x,callbackToken:i.callbackToken,rqt:y}}),t.executionRequestStore.appendEntries(r,c)),"task-initiated"}if(F.some(g=>{let y=g.outputFile;if(typeof y!="string"||!y)return false;let h=w(y),C=h.queueRequestedToken??h.lastRequestedToken??P;return ae(h,C)==="in-flight"}))return "task-initiated";let le=f.provides??[],$={};for(let{bindTo:g,ref:y}of le)$[g]=a$1.resolve(O,y);return (a??t.outputStore.writeDataObjects.bind(t.outputStore))($),o(i.nodeId,$),c.length>0&&t.executionRequestStore.appendEntries(r,c),"task-initiated"}}var Ue={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function He(e){return {[H]:e.graph,[ce]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function Ge(e){let r=e[H],t=e[ce],n=e.board?.runtimeByCardId;if(!r||typeof r!="object")throw new Error(`State snapshot is missing required key: ${H}`);return {graph:r,lastDrainedJournalId:typeof t=="string"?t:"",runtimeByCardId:n&&typeof n=="object"?n:{}}}function ze(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 Xe(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===_}async function a(d){let u=r.emitNotification;if(!u||d.length===0)return;let l=e(d.filter(m=>m.kind!=="card_refreshed"?true:!s(m.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 f$1(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 m of l){if(typeof m.id!="string")return o("each card must have a string `id` field");e$1.writeCard(m.id,m);}return a(l.map(m=>({kind:"card_refreshed",cardId:m.id,card:m}))),t({count:l.length})}catch(u){return n(u)}},del(d){try{let u=d.body?.ids??[],l=d.params?.id,m=l?[...u,l]:u;if(m.length===0)return o("del requires body.ids (string[]) or params.id");for(let p of m)e$1.removeCard(p);return a(m.map(p=>({kind:"card_removed",cardId:p}))),t({count:m.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 m=d.body,p=m&&Object.prototype.hasOwnProperty.call(m,"value")?m.value:d.body;e$1.patchCard(u,l,p);let S=e$1.readCard(u);return S?(a([{kind:"card_refreshed",cardId:u,card:S}]),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 m=f$1(d.body);if(!m||m.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:{},S=Array.isArray(p.files)?p.files:[],w=[...S,...m],k=m.map((I,v)=>({idx:S.length+v,entry:I})),R=this.patch({params:{id:u,path:"card_data.files"},body:{value:w}});return R.status!=="success"?R:t({files_added:k})}catch(u){return n(u)}}}}export{Ne as A,Je as B,Me as C,Ue as D,He as E,Ge as F,ze as G,Xe as H,ve as a,te as b,be as c,oe as d,fe as e,me as f,se as g,T as h,_ as i,Se as j,ye as k,Ve as l,Pe as m,Ke as n,qe as o,he as p,H as q,Be as r,Le as s,je as t,De as u,ie as v,ae as w,Ce as x,de as y,$e as z};//# sourceMappingURL=chunk-QJQ53PLM.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-QJQ53PLM.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';var chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs'),chunkEGZPROOH_cjs=require('./chunk-EGZPROOH.cjs'),chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunkJOQWJ3VR_cjs=require('./chunk-JOQWJ3VR.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkZV35WD6K_cjs=require('./chunk-ZV35WD6K.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 ve(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 be(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]:be(d,s,a)}}function ft(e){return {read:a=>e.read(a),get(a,r){return ve(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 ve(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return ve(e.read(a),s=>e.write(a,lt(s??{},r)))},patch(a,r,s){return ve(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,be(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=be(w,m,d),h=await e.writeCard(v.key,l);f[r]={key:v.key,checksum:h,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 chunkJOQWJ3VR_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 h=chunk2RIHC5TZ_cjs.e(m);if(h.length===1){await l(h[0]);return}await l(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:h}));}async function f(m){let l=m.params?.id;if(l){let h=await e.readCard(l);if(!h)throw new Error(`card "${l}" not found`);return [h]}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 h=Array.isArray(l)?l:[l];for(let S of h){if(typeof S.id!="string")return r("each card must have a string `id` field");await e.writeCard(S.id,S);}return await d(h.map(S=>({kind:"card_refreshed",cardId:S.id,card:S}))),a({count:h.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],h=m.params?.id,S=h?[...l,h]:l;if(S.length===0)return r("del requires body.ids (string[]) or params.id");for(let _ of S)await e.removeCard(_);return await d(S.map(_=>({kind:"card_removed",cardId:_}))),a({count:S.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,h=m.params?.path;if(!l)return r("patch requires params.id");if(!h)return r("patch requires params.path");let S=m.body,_=S&&Object.prototype.hasOwnProperty.call(S,"value")?S.value:m.body;await e.patchCard(l,h,_);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 h=await e.readCard(l);if(!h)return r(`card "${l}" not found`);let S=w(m.body);if(!S||S.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let _=h.card_data&&typeof h.card_data=="object"&&!Array.isArray(h.card_data)?h.card_data:{},O=Array.isArray(_.files)?_.files:[],L=[...O,...S],J=S.map((j,Y)=>({idx:O.length+Y,entry:j})),V=await this.patch({params:{id:l,path:"card_data.files"},body:{value:L}});return V.status!=="success"?V:a({files_added:J})}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 E(){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 Ae(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 chunkJOQWJ3VR_cjs.f(e,chunkJOQWJ3VR_cjs.r,()=>({_sources:{}}))}function It(e,o){return chunkJOQWJ3VR_cjs.d(e,o)}function xt(e){return chunkJOQWJ3VR_cjs.g(e)}function Tt(e,o){return chunkJOQWJ3VR_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===chunkJOQWJ3VR_cjs.i){let p=a.activeTaskConfigs?.(),y={[chunkJOQWJ3VR_cjs.h]:p?chunkJOQWJ3VR_cjs.k((await Promise.all(Object.keys(p).filter(k=>k!==chunkJOQWJ3VR_cjs.i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await chunkJOQWJ3VR_cjs.j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w.card_data??{},h=w.source_defs??[],S=await a.cardRuntimeStore.readRuntime(m),_=false,O=async()=>{_&&(await a.cardRuntimeStore.writeRuntime(m,S),_=false);},L=p=>chunkJOQWJ3VR_cjs.v(S._sources[p]),J=(p,y)=>{S._sources[p]=chunkJOQWJ3VR_cjs.v(y),_=true;},V=f.taskState?.executionCount??0;if(S._lastExecutionCount!==V&&(S._sources={},S._lastExecutionCount=V,_=true),f.update){let p=f.update.outputFile;if(p){let y=L(p);if(f.update.failure){let k=f.update.rqt??y.lastRequestedToken??y.queueRequestedToken;k&&J(p,chunkJOQWJ3VR_cjs.y(y,k));}else {let k=f.update.rqt;if(!y.lastCompletedToken||k>y.lastCompletedToken){let D=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,K=D?await a.fetchedSourcesStore.commitSourceData(m,p,D):false;J(p,K?chunkJOQWJ3VR_cjs.x(y,k):chunkJOQWJ3VR_cjs.y(y,k));}}await O();}}let j={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];j[p]=k!==void 0?k:y;}else j[p]=y;let Y={id:m,card_data:{...l},requires:j,source_defs:h,compute:w.compute},W=chunkZV35WD6K_cjs.a.enrichSourcesSync(Array.isArray(w.source_defs)?w.source_defs:void 0,{card_data:l,requires:j}).filter(p=>p._skip!==true),ae=W,de={};for(let p of W){if(!p.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,p.outputFile);y!==null&&(de[p.bindTo]=y);}Y._sourcesData=de,w.compute&&chunkZV35WD6K_cjs.a.runSync(Y,{sourcesData:de}),(s??(()=>{}))(m,Y.computed_values??{});let fe={...w,source_defs:Array.isArray(W)?W.map(p=>({...p,boardDir:typeof p.boardDir=="string"&&p.boardDir?p.boardDir:e.value})):W},B=E(),ge=f.update?void 0:B,Z=ae.filter(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return true;let k=L(y);ge&&(k={...k,queueRequestedToken:ge},J(y,k));let D=k.queueRequestedToken??k.lastRequestedToken??B;return chunkJOQWJ3VR_cjs.w(k,D)==="dispatch"});if(await O(),Z.length>0){let p=false,y=B;for(let k of Z){let D=k.outputFile;if(typeof D!="string"||!D)continue;let K=L(D),n=K.queueRequestedToken??B;J(D,{...K,lastRequestedToken:n}),y=n,p=true;}return p&&await O(),p&&(v.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(e),enrichedCard:fe,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v)),"task-initiated"}if(ae.some(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return false;let k=L(y),D=k.queueRequestedToken??k.lastRequestedToken??B;return chunkJOQWJ3VR_cjs.w(k,D)==="in-flight"}))return "task-initiated";let pe=w.provides??[],me={};for(let{bindTo:p,ref:y}of pe)me[p]=chunkZV35WD6K_cjs.a.resolve(Y,y);return (d??(()=>{}))(me),r(f.nodeId,me),v.length>0&&await a.executionRequestStore.appendEntries(o,v),"task-initiated"}}function nr(e,o,a={}){chunkEGZPROOH_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,h=a.chatHandlerFlow;function S(){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){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(S())),L=e.value,J=()=>chunkJOQWJ3VR_cjs.b(chunkJOQWJ3VR_cjs.a(()=>o.kvStorageForRef(S()),o.hashFn),"v1"),V=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))},j=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 Y(){return !!(await J().readSnapshot(L)).values[chunkJOQWJ3VR_cjs.q]}async function ue(){let n=await J().readSnapshot(L);if(!n.values[chunkJOQWJ3VR_cjs.q])throw new Error(`Board not initialized at ${e.value}`);return chunkJOQWJ3VR_cjs.F(n.values)}async function W(n,t){let c=await J().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:chunkJOQWJ3VR_cjs.E(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let ae=()=>chunkJOQWJ3VR_cjs.c(o.journalStorageForRef(S()));async function de(){return l??await O().readTaskExecutorRef()}async function fe(){return chunkJOQWJ3VR_cjs.A(await(await V()).readAllDataObjects())}async function B(n){await ae().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 Z(){return o.blobStorageForRef(await ge())}async function ce(){return It(await Z(),n=>o.resolveBlob(n))}async function pe(n){let t=(await Z()).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 me(){let n=Tt(o.kvStorageForRef(S()),async(u,g)=>{let P=u.payload,q=(P.enrichedCard??{}).id??P.cardId??"unknown";await B({type:"task-failed",taskName:q,error:g,timestamp:E()});}),t=At(o.kvStorageForRef(S())),c=await Z(),i=await ce(),A=await j(),I=await V(),F=new Map,C=new Map,x=[],Q=[],H=[],X=new Map,oe=new Set,se={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,$){return i.ingestSourceDataStaged(u,g,P,$)},async commitSourceData(u,g,P){let $=`${u}/.staged/${P}/${g}`,q=await c.read($);if(q==null){let G=await Promise.resolve(c.keyRef?.($));G&&(q=await o.resolveBlob(G));}if(q==null)return false;let U=`${u}/${g}`,te=q.trim();try{C.set(U,JSON.parse(te));}catch{C.set(U,te);}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($=>$.startsWith(`${u}/`)).map($=>$.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await ue(),De=chunkAW3COGCI_cjs.q(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await ae().readEntriesAfterCursor(xe.lastDrainedJournalId),ye=wt,Ve=()=>De.config.tasks,le=chunkAW3COGCI_cjs.t(De,{handlers:{"card-handler":Ot(e,Oe,{cardStore:A,cardRuntimeStore:se,fetchedSourcesStore:Ie,outputStore:I,executionRequestStore:n,activeTaskConfigs:()=>Ve()},(u,g)=>{ye.push({type:"task-completed",taskName:u,data:g,timestamp:E()});},(u,g)=>{Q.push({cardId:u,values:g});},u=>{H.push(u);})},onNodeRemoved:u=>{X.delete(u),F.delete(u),delete Te[u],oe.add(u);}});for(Ve=()=>le.getState().config.tasks;ye.length>0;){let u=ye;ye=[];for(let g of u)if(g.type==="task-restart"){let P=await A.readCard(g.taskName);P&&X.set(g.taskName,P);}le.pushAll(u),await le.waitForHandlers();}let $e=le.getState();await le.dispose({wait:true}),await W({lastDrainedJournalId:Oe,graph:chunkAW3COGCI_cjs.p($e),runtimeByCardId:Te},(await J().readSnapshot(L)).version);for(let{cardId:u,values:g}of Q)await I.writeComputedValues(u,g);for(let u of H)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=chunkJOQWJ3VR_cjs.z(chunkJOQWJ3VR_cjs.B(d,$e));await I.writeStatusSnapshot(Le);let ie=[];for(let{cardId:u,values:g}of Q)ie.push({kind:"computed_values",cardId:u,values:g});for(let u of H)for(let[g,P]of Object.entries(u))ie.push({kind:"data_object",key:g,payload:P});for(let[u,g]of X)u!==chunkJOQWJ3VR_cjs.i&&ie.push({kind:"card_refreshed",cardId:u,card:g});for(let u of oe)ie.push({kind:"card_removed",cardId:u});ie.push({kind:"status",status:Le}),await _(ie);let ee=await de();if(!ee)return;let Je=o.supportsDirectSourceOutput?.(ee)===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",$=g.enrichedCard?.source_defs??[];if(ee.howToRun==="queue-storage"&&Je){try{let q=await O().readQueueStoreRef();if(!q)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let U=o.queueStorageForRef(q,"task-executor"),te=typeof ee.extra?.boardId=="string"?ee.extra.boardId:void 0,G=[];for(let z of $){if(!z.outputFile)continue;let Se=o.genId(),ke=`${P}/.staged/${Se}/${z.outputFile}`,Me=await Promise.resolve(c.keyRef?.(ke));if(!Me)continue;let Qe={ref:chunkVQCIOKJV_cjs.a(Me),deliveryToken:Se,outputFile:z.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:z.bindTo,d:z.outputFile,cs:void 0,rqt:g.rqt,dt:Qe.deliveryToken});G.push({...te?{boardId:te}:{},ref:ee,args:{source_def:z,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ht),output:Qe}});}G.length>0&&await U.enqueueMany(G);}catch(q){await B({type:"task-failed",taskName:P,error:q instanceof Error?q.message:String(q),timestamp:E()});}return}for(let q of $){if(!q.outputFile)continue;let U;if(Je){let z=o.genId(),Se=`${P}/.staged/${z}/${q.outputFile}`,ke=await Promise.resolve(c.keyRef?.(Se));ke&&(U={ref:chunkVQCIOKJV_cjs.a(ke),deliveryToken:z,outputFile:q.outputFile,cardId:P});}let te=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:q.bindTo,d:q.outputFile,cs:void 0,rqt:g.rqt,...U?{dt:U.deliveryToken}:{}}),G=await o.dispatchExecution(ee,{source_def:q,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(te),...U?{output:U}:{}});G.dispatched||await B({type:"task-failed",taskName:P,error:G.error??"dispatch failed",timestamp:E()});}});}async function p(){try{let n=async()=>{let c=await ue(),{events:i}=await ae().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await k();},t=await mt(o.lock,me,n);return b({ran:t!==!1})}catch(n){return T(n)}}async function y(){return v||(v=p().finally(()=>{v=null;}),v)}async function k(){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 D(){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 K(){k();}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 Y()||await W({lastDrainedJournalId:"",graph:chunkAW3COGCI_cjs.p(chunkAW3COGCI_cjs.a(chunkJOQWJ3VR_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 j()).writeCard(chunkJOQWJ3VR_cjs.i,chunkJOQWJ3VR_cjs.l());let x=o.kvStorage("card-upsert"),Q=chunkJOQWJ3VR_cjs.l(),H=chunkJOQWJ3VR_cjs.G(Q),X=o.hashFn(H),se=(await x.read(chunkJOQWJ3VR_cjs.i))?.blobRef??await(await j()).readCardKey(chunkJOQWJ3VR_cjs.i)??chunkJOQWJ3VR_cjs.i;return await B({type:"task-upsert",taskName:chunkJOQWJ3VR_cjs.i,taskConfig:H,timestamp:E()}),await x.write(chunkJOQWJ3VR_cjs.i,{blobRef:se,taskConfigHash:X,updatedAt:E()}),await B({type:"task-restart",taskName:chunkJOQWJ3VR_cjs.i,timestamp:E()}),K(),await(await V()).writeStatusSnapshot(chunkJOQWJ3VR_cjs.z(chunkJOQWJ3VR_cjs.B(d,chunkAW3COGCI_cjs.q((await ue()).graph)))),b()}catch(t){return T(t)}},async status(n){try{let t=await V(),c=await t.readStatusSnapshot();return c||(c=chunkJOQWJ3VR_cjs.z(chunkJOQWJ3VR_cjs.B(d,chunkAW3COGCI_cjs.q((await ue()).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=h??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===chunkJOQWJ3VR_cjs.h)return b(null);let c=await fe();return b(c[t]??null)}catch(t){return T(t)}},async getAllOutputsDataObjects(n){try{return b(await fe())}catch(t){return T(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?b(await(await V()).readComputedValues(t)):R("getOutputsComputedValues requires params.key")}catch(t){return T(t)}},async getAllOutputsComputedValues(n){try{return b(await(await V()).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 ce()).listSources(t),i={};for(let A of c)i[A]=await pe(`${t}/${A}`);return b(i)}catch(t){return T(t)}},async getAllOutputsFetchedSources(n){try{let t=await ce(),c=await(await Z()).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 pe(`${I}/${C}`);}}return b(A)}catch(t){return T(t)}},async buildSseOneShotPayload(n){try{let t=(await(await j()).readAllCards()).filter(C=>C.id!==chunkJOQWJ3VR_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 j(),{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 B({type:"task-removal",taskName:t,timestamp:E()}),t!==chunkJOQWJ3VR_cjs.i&&await B({type:"task-restart",taskName:chunkJOQWJ3VR_cjs.i,timestamp:E()}),K(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await B({type:"task-restart",taskName:t,timestamp:E()}),K(),b()):R("retrigger requires params.id")}catch(t){return T(t)}},async processAccumulatedEvents(n){return await D(),y()},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 j(),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 H=chunkJOQWJ3VR_cjs.G(Q),X=o.hashFn(H),oe=await F.read(x),se=oe?.taskConfigHash!==X;if(!(!se&&!i)){if(se){let Ie=oe?.blobRef??await A.readCardKey(x)??x;await B({type:"task-upsert",taskName:x,taskConfig:H,timestamp:E()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:E()}),C=C||x!==chunkJOQWJ3VR_cjs.i;}i&&await B({type:"task-restart",taskName:x,timestamp:E()});}}return C&&await B({type:"task-restart",taskName:chunkJOQWJ3VR_cjs.i,timestamp:E()}),K(),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=Ae(t);return i?(await B({type:"task-failed",taskName:i.taskName,error:c,timestamp:E()}),K(),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=Ae(t);return i?(await B({type:"task-progress",taskName:i.taskName,update:c,timestamp:E()}),K(),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 ce(),I=i.dt||o.genId();i.dt||await A.ingestSourceDataStaged(i.cid,i.d,chunkVQCIOKJV_cjs.b(c),I);let F=Ae(i.cbk);return F?(await B({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:E(),deliveryToken:I,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),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=Ae(i.cbk);return A?(await B({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),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-
|
|
3
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs'),chunkC7RR2JCL_cjs=require('./chunk-C7RR2JCL.cjs'),chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunkCAID4CGO_cjs=require('./chunk-CAID4CGO.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunk66ZZIF2L_cjs=require('./chunk-66ZZIF2L.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 ve(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 be(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]:be(d,s,a)}}function ft(e){return {read:a=>e.read(a),get(a,r){return ve(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 ve(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return ve(e.read(a),s=>e.write(a,lt(s??{},r)))},patch(a,r,s){return ve(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,be(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=be(w,m,d),h=await e.writeCard(v.key,l);f[r]={key:v.key,checksum:h,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 chunkCAID4CGO_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 h=chunk2RIHC5TZ_cjs.e(m);if(h.length===1){await l(h[0]);return}await l(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:h}));}async function f(m){let l=m.params?.id;if(l){let h=await e.readCard(l);if(!h)throw new Error(`card "${l}" not found`);return [h]}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 h=Array.isArray(l)?l:[l];for(let S of h){if(typeof S.id!="string")return r("each card must have a string `id` field");await e.writeCard(S.id,S);}return await d(h.map(S=>({kind:"card_refreshed",cardId:S.id,card:S}))),a({count:h.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],h=m.params?.id,S=h?[...l,h]:l;if(S.length===0)return r("del requires body.ids (string[]) or params.id");for(let _ of S)await e.removeCard(_);return await d(S.map(_=>({kind:"card_removed",cardId:_}))),a({count:S.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,h=m.params?.path;if(!l)return r("patch requires params.id");if(!h)return r("patch requires params.path");let S=m.body,_=S&&Object.prototype.hasOwnProperty.call(S,"value")?S.value:m.body;await e.patchCard(l,h,_);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 h=await e.readCard(l);if(!h)return r(`card "${l}" not found`);let S=w(m.body);if(!S||S.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let _=h.card_data&&typeof h.card_data=="object"&&!Array.isArray(h.card_data)?h.card_data:{},O=Array.isArray(_.files)?_.files:[],L=[...O,...S],J=S.map((j,Y)=>({idx:O.length+Y,entry:j})),V=await this.patch({params:{id:l,path:"card_data.files"},body:{value:L}});return V.status!=="success"?V:a({files_added:J})}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 E(){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 Ae(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 chunkCAID4CGO_cjs.f(e,chunkCAID4CGO_cjs.r,()=>({_sources:{}}))}function It(e,o){return chunkCAID4CGO_cjs.d(e,o)}function xt(e){return chunkCAID4CGO_cjs.g(e)}function Tt(e,o){return chunkCAID4CGO_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===chunkCAID4CGO_cjs.i){let p=a.activeTaskConfigs?.(),y={[chunkCAID4CGO_cjs.h]:p?chunkCAID4CGO_cjs.k((await Promise.all(Object.keys(p).filter(k=>k!==chunkCAID4CGO_cjs.i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await chunkCAID4CGO_cjs.j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w.card_data??{},h=w.source_defs??[],S=await a.cardRuntimeStore.readRuntime(m),_=false,O=async()=>{_&&(await a.cardRuntimeStore.writeRuntime(m,S),_=false);},L=p=>chunkCAID4CGO_cjs.v(S._sources[p]),J=(p,y)=>{S._sources[p]=chunkCAID4CGO_cjs.v(y),_=true;},V=f.taskState?.executionCount??0;if(S._lastExecutionCount!==V&&(S._sources={},S._lastExecutionCount=V,_=true),f.update){let p=f.update.outputFile;if(p){let y=L(p);if(f.update.failure){let k=f.update.rqt??y.lastRequestedToken??y.queueRequestedToken;k&&J(p,chunkCAID4CGO_cjs.y(y,k));}else {let k=f.update.rqt;if(!y.lastCompletedToken||k>y.lastCompletedToken){let D=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,K=D?await a.fetchedSourcesStore.commitSourceData(m,p,D):false;J(p,K?chunkCAID4CGO_cjs.x(y,k):chunkCAID4CGO_cjs.y(y,k));}}await O();}}let j={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];j[p]=k!==void 0?k:y;}else j[p]=y;let Y={id:m,card_data:{...l},requires:j,source_defs:h,compute:w.compute},W=chunk66ZZIF2L_cjs.a.enrichSourcesSync(Array.isArray(w.source_defs)?w.source_defs:void 0,{card_data:l,requires:j}).filter(p=>p._skip!==true),ae=W,de={};for(let p of W){if(!p.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,p.outputFile);y!==null&&(de[p.bindTo]=y);}Y._sourcesData=de,w.compute&&chunk66ZZIF2L_cjs.a.runSync(Y,{sourcesData:de}),(s??(()=>{}))(m,Y.computed_values??{});let fe={...w,source_defs:Array.isArray(W)?W.map(p=>({...p,boardDir:typeof p.boardDir=="string"&&p.boardDir?p.boardDir:e.value})):W},B=E(),ge=f.update?void 0:B,Z=ae.filter(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return true;let k=L(y);ge&&(k={...k,queueRequestedToken:ge},J(y,k));let D=k.queueRequestedToken??k.lastRequestedToken??B;return chunkCAID4CGO_cjs.w(k,D)==="dispatch"});if(await O(),Z.length>0){let p=false,y=B;for(let k of Z){let D=k.outputFile;if(typeof D!="string"||!D)continue;let K=L(D),n=K.queueRequestedToken??B;J(D,{...K,lastRequestedToken:n}),y=n,p=true;}return p&&await O(),p&&(v.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(e),enrichedCard:fe,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v)),"task-initiated"}if(ae.some(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return false;let k=L(y),D=k.queueRequestedToken??k.lastRequestedToken??B;return chunkCAID4CGO_cjs.w(k,D)==="in-flight"}))return "task-initiated";let pe=w.provides??[],me={};for(let{bindTo:p,ref:y}of pe)me[p]=chunk66ZZIF2L_cjs.a.resolve(Y,y);return (d??(()=>{}))(me),r(f.nodeId,me),v.length>0&&await a.executionRequestStore.appendEntries(o,v),"task-initiated"}}function nr(e,o,a={}){chunkC7RR2JCL_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,h=a.chatHandlerFlow;function S(){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){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(S())),L=e.value,J=()=>chunkCAID4CGO_cjs.b(chunkCAID4CGO_cjs.a(()=>o.kvStorageForRef(S()),o.hashFn),"v1"),V=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))},j=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 Y(){return !!(await J().readSnapshot(L)).values[chunkCAID4CGO_cjs.q]}async function ue(){let n=await J().readSnapshot(L);if(!n.values[chunkCAID4CGO_cjs.q])throw new Error(`Board not initialized at ${e.value}`);return chunkCAID4CGO_cjs.F(n.values)}async function W(n,t){let c=await J().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:chunkCAID4CGO_cjs.E(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let ae=()=>chunkCAID4CGO_cjs.c(o.journalStorageForRef(S()));async function de(){return l??await O().readTaskExecutorRef()}async function fe(){return chunkCAID4CGO_cjs.A(await(await V()).readAllDataObjects())}async function B(n){await ae().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 Z(){return o.blobStorageForRef(await ge())}async function ce(){return It(await Z(),n=>o.resolveBlob(n))}async function pe(n){let t=(await Z()).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 me(){let n=Tt(o.kvStorageForRef(S()),async(u,g)=>{let P=u.payload,q=(P.enrichedCard??{}).id??P.cardId??"unknown";await B({type:"task-failed",taskName:q,error:g,timestamp:E()});}),t=At(o.kvStorageForRef(S())),c=await Z(),i=await ce(),A=await j(),I=await V(),F=new Map,C=new Map,x=[],Q=[],H=[],X=new Map,oe=new Set,se={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,$){return i.ingestSourceDataStaged(u,g,P,$)},async commitSourceData(u,g,P){let $=`${u}/.staged/${P}/${g}`,q=await c.read($);if(q==null){let G=await Promise.resolve(c.keyRef?.($));G&&(q=await o.resolveBlob(G));}if(q==null)return false;let U=`${u}/${g}`,te=q.trim();try{C.set(U,JSON.parse(te));}catch{C.set(U,te);}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($=>$.startsWith(`${u}/`)).map($=>$.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await ue(),De=chunkAW3COGCI_cjs.q(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await ae().readEntriesAfterCursor(xe.lastDrainedJournalId),ye=wt,Ve=()=>De.config.tasks,le=chunkAW3COGCI_cjs.t(De,{handlers:{"card-handler":Ot(e,Oe,{cardStore:A,cardRuntimeStore:se,fetchedSourcesStore:Ie,outputStore:I,executionRequestStore:n,activeTaskConfigs:()=>Ve()},(u,g)=>{ye.push({type:"task-completed",taskName:u,data:g,timestamp:E()});},(u,g)=>{Q.push({cardId:u,values:g});},u=>{H.push(u);})},onNodeRemoved:u=>{X.delete(u),F.delete(u),delete Te[u],oe.add(u);}});for(Ve=()=>le.getState().config.tasks;ye.length>0;){let u=ye;ye=[];for(let g of u)if(g.type==="task-restart"){let P=await A.readCard(g.taskName);P&&X.set(g.taskName,P);}le.pushAll(u),await le.waitForHandlers();}let $e=le.getState();await le.dispose({wait:true}),await W({lastDrainedJournalId:Oe,graph:chunkAW3COGCI_cjs.p($e),runtimeByCardId:Te},(await J().readSnapshot(L)).version);for(let{cardId:u,values:g}of Q)await I.writeComputedValues(u,g);for(let u of H)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=chunkCAID4CGO_cjs.z(chunkCAID4CGO_cjs.B(d,$e));await I.writeStatusSnapshot(Le);let ie=[];for(let{cardId:u,values:g}of Q)ie.push({kind:"computed_values",cardId:u,values:g});for(let u of H)for(let[g,P]of Object.entries(u))ie.push({kind:"data_object",key:g,payload:P});for(let[u,g]of X)u!==chunkCAID4CGO_cjs.i&&ie.push({kind:"card_refreshed",cardId:u,card:g});for(let u of oe)ie.push({kind:"card_removed",cardId:u});ie.push({kind:"status",status:Le}),await _(ie);let ee=await de();if(!ee)return;let Je=o.supportsDirectSourceOutput?.(ee)===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",$=g.enrichedCard?.source_defs??[];if(ee.howToRun==="queue-storage"&&Je){try{let q=await O().readQueueStoreRef();if(!q)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let U=o.queueStorageForRef(q,"task-executor"),te=typeof ee.extra?.boardId=="string"?ee.extra.boardId:void 0,G=[];for(let z of $){if(!z.outputFile)continue;let Se=o.genId(),ke=`${P}/.staged/${Se}/${z.outputFile}`,Me=await Promise.resolve(c.keyRef?.(ke));if(!Me)continue;let Qe={ref:chunkVQCIOKJV_cjs.a(Me),deliveryToken:Se,outputFile:z.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:z.bindTo,d:z.outputFile,cs:void 0,rqt:g.rqt,dt:Qe.deliveryToken});G.push({...te?{boardId:te}:{},ref:ee,args:{source_def:z,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ht),output:Qe}});}G.length>0&&await U.enqueueMany(G);}catch(q){await B({type:"task-failed",taskName:P,error:q instanceof Error?q.message:String(q),timestamp:E()});}return}for(let q of $){if(!q.outputFile)continue;let U;if(Je){let z=o.genId(),Se=`${P}/.staged/${z}/${q.outputFile}`,ke=await Promise.resolve(c.keyRef?.(Se));ke&&(U={ref:chunkVQCIOKJV_cjs.a(ke),deliveryToken:z,outputFile:q.outputFile,cardId:P});}let te=kt({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:P,b:q.bindTo,d:q.outputFile,cs:void 0,rqt:g.rqt,...U?{dt:U.deliveryToken}:{}}),G=await o.dispatchExecution(ee,{source_def:q,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(te),...U?{output:U}:{}});G.dispatched||await B({type:"task-failed",taskName:P,error:G.error??"dispatch failed",timestamp:E()});}});}async function p(){try{let n=async()=>{let c=await ue(),{events:i}=await ae().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await k();},t=await mt(o.lock,me,n);return b({ran:t!==!1})}catch(n){return T(n)}}async function y(){return v||(v=p().finally(()=>{v=null;}),v)}async function k(){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 D(){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 K(){k();}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 Y()||await W({lastDrainedJournalId:"",graph:chunkAW3COGCI_cjs.p(chunkAW3COGCI_cjs.a(chunkCAID4CGO_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 j()).writeCard(chunkCAID4CGO_cjs.i,chunkCAID4CGO_cjs.l());let x=o.kvStorage("card-upsert"),Q=chunkCAID4CGO_cjs.l(),H=chunkCAID4CGO_cjs.G(Q),X=o.hashFn(H),se=(await x.read(chunkCAID4CGO_cjs.i))?.blobRef??await(await j()).readCardKey(chunkCAID4CGO_cjs.i)??chunkCAID4CGO_cjs.i;return await B({type:"task-upsert",taskName:chunkCAID4CGO_cjs.i,taskConfig:H,timestamp:E()}),await x.write(chunkCAID4CGO_cjs.i,{blobRef:se,taskConfigHash:X,updatedAt:E()}),await B({type:"task-restart",taskName:chunkCAID4CGO_cjs.i,timestamp:E()}),K(),await(await V()).writeStatusSnapshot(chunkCAID4CGO_cjs.z(chunkCAID4CGO_cjs.B(d,chunkAW3COGCI_cjs.q((await ue()).graph)))),b()}catch(t){return T(t)}},async status(n){try{let t=await V(),c=await t.readStatusSnapshot();return c||(c=chunkCAID4CGO_cjs.z(chunkCAID4CGO_cjs.B(d,chunkAW3COGCI_cjs.q((await ue()).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=h??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===chunkCAID4CGO_cjs.h)return b(null);let c=await fe();return b(c[t]??null)}catch(t){return T(t)}},async getAllOutputsDataObjects(n){try{return b(await fe())}catch(t){return T(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?b(await(await V()).readComputedValues(t)):R("getOutputsComputedValues requires params.key")}catch(t){return T(t)}},async getAllOutputsComputedValues(n){try{return b(await(await V()).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 ce()).listSources(t),i={};for(let A of c)i[A]=await pe(`${t}/${A}`);return b(i)}catch(t){return T(t)}},async getAllOutputsFetchedSources(n){try{let t=await ce(),c=await(await Z()).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 pe(`${I}/${C}`);}}return b(A)}catch(t){return T(t)}},async buildSseOneShotPayload(n){try{let t=(await(await j()).readAllCards()).filter(C=>C.id!==chunkCAID4CGO_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 j(),{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 B({type:"task-removal",taskName:t,timestamp:E()}),t!==chunkCAID4CGO_cjs.i&&await B({type:"task-restart",taskName:chunkCAID4CGO_cjs.i,timestamp:E()}),K(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await B({type:"task-restart",taskName:t,timestamp:E()}),K(),b()):R("retrigger requires params.id")}catch(t){return T(t)}},async processAccumulatedEvents(n){return await D(),y()},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 j(),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 H=chunkCAID4CGO_cjs.G(Q),X=o.hashFn(H),oe=await F.read(x),se=oe?.taskConfigHash!==X;if(!(!se&&!i)){if(se){let Ie=oe?.blobRef??await A.readCardKey(x)??x;await B({type:"task-upsert",taskName:x,taskConfig:H,timestamp:E()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:E()}),C=C||x!==chunkCAID4CGO_cjs.i;}i&&await B({type:"task-restart",taskName:x,timestamp:E()});}}return C&&await B({type:"task-restart",taskName:chunkCAID4CGO_cjs.i,timestamp:E()}),K(),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=Ae(t);return i?(await B({type:"task-failed",taskName:i.taskName,error:c,timestamp:E()}),K(),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=Ae(t);return i?(await B({type:"task-progress",taskName:i.taskName,update:c,timestamp:E()}),K(),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 ce(),I=i.dt||o.genId();i.dt||await A.ingestSourceDataStaged(i.cid,i.d,chunkVQCIOKJV_cjs.b(c),I);let F=Ae(i.cbk);return F?(await B({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:E(),deliveryToken:I,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),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=Ae(i.cbk);return A?(await B({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),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-TIQ775WI.cjs.map
|
|
3
|
+
//# sourceMappingURL=chunk-TIQ775WI.cjs.map
|
package/lib/cloud-storage.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var chunk6EJRZHFP_cjs=require('./chunk-6EJRZHFP.cjs'),
|
|
1
|
+
'use strict';var chunk6EJRZHFP_cjs=require('./chunk-6EJRZHFP.cjs'),chunkTIQ775WI_cjs=require('./chunk-TIQ775WI.cjs'),chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs');require('./chunk-C7RR2JCL.cjs'),require('./chunk-AW3COGCI.cjs'),require('./chunk-SIPLKLWU.cjs'),require('./chunk-CAID4CGO.cjs'),require('./chunk-7JVHYHT2.cjs'),require('./chunk-VQCIOKJV.cjs'),require('./chunk-VI36DRWG.cjs'),require('./chunk-7Y47QXMX.cjs'),require('./chunk-66ZZIF2L.cjs'),require('./chunk-P7STTKRO.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-2RIHC5TZ.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createAzureBlobStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.d}});Object.defineProperty(exports,"createAzureQueueStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.e}});Object.defineProperty(exports,"createCosmosAtomicRelayLock",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.c}});Object.defineProperty(exports,"createCosmosJournalStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.b}});Object.defineProperty(exports,"createCosmosKvStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.a}});Object.defineProperty(exports,"createAsyncBoardLiveCardsPublic",{enumerable:true,get:function(){return chunkTIQ775WI_cjs.i}});Object.defineProperty(exports,"createAsyncCardStorageAdapter",{enumerable:true,get:function(){return chunkTIQ775WI_cjs.c}});Object.defineProperty(exports,"createAsyncCardStore",{enumerable:true,get:function(){return chunkTIQ775WI_cjs.d}});Object.defineProperty(exports,"createAsyncCardStorePublic",{enumerable:true,get:function(){return chunkTIQ775WI_cjs.g}});Object.defineProperty(exports,"createAsyncJsonStorage",{enumerable:true,get:function(){return chunkTIQ775WI_cjs.b}});Object.defineProperty(exports,"createAsyncQueueStoragePublic",{enumerable:true,get:function(){return chunkTIQ775WI_cjs.h}});Object.defineProperty(exports,"createAsyncStateSnapshotAdapter",{enumerable:true,get:function(){return chunkTIQ775WI_cjs.e}});Object.defineProperty(exports,"createAsyncStorageProvider",{enumerable:true,get:function(){return chunkTIQ775WI_cjs.f}});Object.defineProperty(exports,"withAsyncRelayLock",{enumerable:true,get:function(){return chunkTIQ775WI_cjs.a}});Object.defineProperty(exports,"createAsyncBoardConfigStore",{enumerable:true,get:function(){return chunkCSHNTZW4_cjs.b}});Object.defineProperty(exports,"createAsyncBoardWorkerStore",{enumerable:true,get:function(){return chunkCSHNTZW4_cjs.a}});Object.defineProperty(exports,"createHostedAsyncBoardPlatformAdapter",{enumerable:true,get:function(){return chunkCSHNTZW4_cjs.c}});//# sourceMappingURL=cloud-storage.cjs.map
|
|
2
2
|
//# sourceMappingURL=cloud-storage.cjs.map
|
package/lib/cloud-storage.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{d as createAzureBlobStorage,e as createAzureQueueStorage,c as createCosmosAtomicRelayLock,b as createCosmosJournalStorage,a as createCosmosKvStorage}from'./chunk-QLB6PKOT.js';export{i as createAsyncBoardLiveCardsPublic,c as createAsyncCardStorageAdapter,d as createAsyncCardStore,g as createAsyncCardStorePublic,b as createAsyncJsonStorage,h as createAsyncQueueStoragePublic,e as createAsyncStateSnapshotAdapter,f as createAsyncStorageProvider,a as withAsyncRelayLock}from'./chunk-
|
|
1
|
+
export{d as createAzureBlobStorage,e as createAzureQueueStorage,c as createCosmosAtomicRelayLock,b as createCosmosJournalStorage,a as createCosmosKvStorage}from'./chunk-QLB6PKOT.js';export{i as createAsyncBoardLiveCardsPublic,c as createAsyncCardStorageAdapter,d as createAsyncCardStore,g as createAsyncCardStorePublic,b as createAsyncJsonStorage,h as createAsyncQueueStoragePublic,e as createAsyncStateSnapshotAdapter,f as createAsyncStorageProvider,a as withAsyncRelayLock}from'./chunk-E7SDEZSI.js';export{b as createAsyncBoardConfigStore,a as createAsyncBoardWorkerStore,c as createHostedAsyncBoardPlatformAdapter}from'./chunk-PEJRTZU3.js';import'./chunk-C7OY3PYL.js';import'./chunk-FULAMLUU.js';import'./chunk-EOVTMJYZ.js';import'./chunk-QJQ53PLM.js';import'./chunk-ANKA7HEJ.js';import'./chunk-44L64VQ2.js';import'./chunk-Q444D72R.js';import'./chunk-R7SQQSDX.js';import'./chunk-QE3QXEHI.js';import'./chunk-CVTL2EFR.js';import'./chunk-MNEOJWPS.js';import'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=cloud-storage.js.map
|
|
2
2
|
//# sourceMappingURL=cloud-storage.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkP4WQJ7LA_cjs=require('../chunk-P4WQJ7LA.cjs'),chunkAW3COGCI_cjs=require('../chunk-AW3COGCI.cjs');require('../chunk-SIPLKLWU.cjs');var chunkVI36DRWG_cjs=require('../chunk-VI36DRWG.cjs');require('../chunk-7Y47QXMX.cjs'),require('../chunk-66ZZIF2L.cjs'),require('../chunk-P7STTKRO.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createCallbackHandler",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.i}});Object.defineProperty(exports,"createFireAndForgetHandler",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.j}});Object.defineProperty(exports,"createNoopHandler",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.o}});Object.defineProperty(exports,"createProcessHandler",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.l}});Object.defineProperty(exports,"createScriptHandler",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.m}});Object.defineProperty(exports,"createShellHandler",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.k}});Object.defineProperty(exports,"createWebhookHandler",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.n}});Object.defineProperty(exports,"getDownstream",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.e}});Object.defineProperty(exports,"getUnreachableNodes",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.c}});Object.defineProperty(exports,"getUnreachableTokens",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.b}});Object.defineProperty(exports,"getUpstream",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.d}});Object.defineProperty(exports,"inspect",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.a}});Object.defineProperty(exports,"liveCardsToReactiveGraph",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.p}});Object.defineProperty(exports,"mutateGraph",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.h}});Object.defineProperty(exports,"validateLiveGraph",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.f}});Object.defineProperty(exports,"validateReactiveGraph",{enumerable:true,get:function(){return chunkP4WQJ7LA_cjs.g}});Object.defineProperty(exports,"MemoryJournal",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.r}});Object.defineProperty(exports,"addNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.d}});Object.defineProperty(exports,"addProvides",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.h}});Object.defineProperty(exports,"addRequires",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.f}});Object.defineProperty(exports,"applyEvent",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.b}});Object.defineProperty(exports,"applyEvents",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.c}});Object.defineProperty(exports,"computeDataHash",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.s}});Object.defineProperty(exports,"createLiveGraph",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.a}});Object.defineProperty(exports,"createReactiveGraph",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.t}});Object.defineProperty(exports,"disableNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.m}});Object.defineProperty(exports,"drainTokens",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.k}});Object.defineProperty(exports,"enableNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.n}});Object.defineProperty(exports,"getNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.o}});Object.defineProperty(exports,"injectTokens",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.j}});Object.defineProperty(exports,"removeNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.e}});Object.defineProperty(exports,"removeProvides",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.i}});Object.defineProperty(exports,"removeRequires",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.g}});Object.defineProperty(exports,"resetNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.l}});Object.defineProperty(exports,"restore",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.q}});Object.defineProperty(exports,"snapshot",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.p}});Object.defineProperty(exports,"schedule",{enumerable:true,get:function(){return chunkVI36DRWG_cjs.a}});//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { d as LiveGraph, N as NodeInfo, f as LiveGraphSnapshot, D as DownstreamResult, U as UnreachableNodesResult, j as UnreachableTokensResult, l as UpstreamResult, e as LiveGraphHealth, R as ReactiveGraph, h as TaskHandlerInput, T as TaskHandlerFn } from '../live-cards-bridge-
|
|
2
|
-
export { B as BlockedTask, L as LiveBoard, a as LiveCard, b as LiveCardsToReactiveOptions, c as LiveCardsToReactiveResult, P as PendingTask, g as ReactiveGraphOptions, S as ScheduleResult, i as TaskHandlerReturn, k as UnresolvedDependency, o as computeDataHash, m as createReactiveGraph, n as liveCardsToReactiveGraph, s as schedule } from '../live-cards-bridge-
|
|
1
|
+
import { d as LiveGraph, N as NodeInfo, f as LiveGraphSnapshot, D as DownstreamResult, U as UnreachableNodesResult, j as UnreachableTokensResult, l as UpstreamResult, e as LiveGraphHealth, R as ReactiveGraph, h as TaskHandlerInput, T as TaskHandlerFn } from '../live-cards-bridge-D8kP3uog.cjs';
|
|
2
|
+
export { B as BlockedTask, L as LiveBoard, a as LiveCard, b as LiveCardsToReactiveOptions, c as LiveCardsToReactiveResult, P as PendingTask, g as ReactiveGraphOptions, S as ScheduleResult, i as TaskHandlerReturn, k as UnresolvedDependency, o as computeDataHash, m as createReactiveGraph, n as liveCardsToReactiveGraph, s as schedule } from '../live-cards-bridge-D8kP3uog.cjs';
|
|
3
3
|
import { T as TaskConfig, f as GraphEvent, G as GraphConfig } from '../types-BBhqYGhE.cjs';
|
|
4
4
|
export { c as ExecutionState, e as GraphEngineStore, g as GraphSettings } from '../types-BBhqYGhE.cjs';
|
|
5
5
|
import { a as GraphValidationResult } from '../validate-Dbu7ygys.cjs';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { d as LiveGraph, N as NodeInfo, f as LiveGraphSnapshot, D as DownstreamResult, U as UnreachableNodesResult, j as UnreachableTokensResult, l as UpstreamResult, e as LiveGraphHealth, R as ReactiveGraph, h as TaskHandlerInput, T as TaskHandlerFn } from '../live-cards-bridge-
|
|
2
|
-
export { B as BlockedTask, L as LiveBoard, a as LiveCard, b as LiveCardsToReactiveOptions, c as LiveCardsToReactiveResult, P as PendingTask, g as ReactiveGraphOptions, S as ScheduleResult, i as TaskHandlerReturn, k as UnresolvedDependency, o as computeDataHash, m as createReactiveGraph, n as liveCardsToReactiveGraph, s as schedule } from '../live-cards-bridge-
|
|
1
|
+
import { d as LiveGraph, N as NodeInfo, f as LiveGraphSnapshot, D as DownstreamResult, U as UnreachableNodesResult, j as UnreachableTokensResult, l as UpstreamResult, e as LiveGraphHealth, R as ReactiveGraph, h as TaskHandlerInput, T as TaskHandlerFn } from '../live-cards-bridge-DMBSDgpk.js';
|
|
2
|
+
export { B as BlockedTask, L as LiveBoard, a as LiveCard, b as LiveCardsToReactiveOptions, c as LiveCardsToReactiveResult, P as PendingTask, g as ReactiveGraphOptions, S as ScheduleResult, i as TaskHandlerReturn, k as UnresolvedDependency, o as computeDataHash, m as createReactiveGraph, n as liveCardsToReactiveGraph, s as schedule } from '../live-cards-bridge-DMBSDgpk.js';
|
|
3
3
|
import { T as TaskConfig, f as GraphEvent, G as GraphConfig } from '../types-BBhqYGhE.js';
|
|
4
4
|
export { c as ExecutionState, e as GraphEngineStore, g as GraphSettings } from '../types-BBhqYGhE.js';
|
|
5
5
|
import { a as GraphValidationResult } from '../validate-BAVzUJWa.js';
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{i as createCallbackHandler,j as createFireAndForgetHandler,o as createNoopHandler,l as createProcessHandler,m as createScriptHandler,k as createShellHandler,n as createWebhookHandler,e as getDownstream,c as getUnreachableNodes,b as getUnreachableTokens,d as getUpstream,a as inspect,p as liveCardsToReactiveGraph,h as mutateGraph,f as validateLiveGraph,g as validateReactiveGraph}from'../chunk-
|
|
1
|
+
export{i as createCallbackHandler,j as createFireAndForgetHandler,o as createNoopHandler,l as createProcessHandler,m as createScriptHandler,k as createShellHandler,n as createWebhookHandler,e as getDownstream,c as getUnreachableNodes,b as getUnreachableTokens,d as getUpstream,a as inspect,p as liveCardsToReactiveGraph,h as mutateGraph,f as validateLiveGraph,g as validateReactiveGraph}from'../chunk-K2VRX4TC.js';export{r as MemoryJournal,d as addNode,h as addProvides,f as addRequires,b as applyEvent,c as applyEvents,s as computeDataHash,a as createLiveGraph,t as createReactiveGraph,m as disableNode,k as drainTokens,n as enableNode,o as getNode,j as injectTokens,e as removeNode,i as removeProvides,g as removeRequires,l as resetNode,q as restore,p as snapshot}from'../chunk-FULAMLUU.js';import'../chunk-EOVTMJYZ.js';export{a as schedule}from'../chunk-Q444D72R.js';import'../chunk-R7SQQSDX.js';import'../chunk-QE3QXEHI.js';import'../chunk-CVTL2EFR.js';import'../chunk-MNEOJWPS.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';var chunkHFW7E2Z7_cjs=require('../chunk-HFW7E2Z7.cjs'),chunkMCPADH33_cjs=require('../chunk-MCPADH33.cjs');require('../chunk-6EJRZHFP.cjs'),require('../chunk-MRIFSG7L.cjs');var chunkCSHNTZW4_cjs=require('../chunk-CSHNTZW4.cjs');require('../chunk-EGZPROOH.cjs'),require('../chunk-AW3COGCI.cjs'),require('../chunk-SIPLKLWU.cjs'),require('../chunk-JOQWJ3VR.cjs'),require('../chunk-7JVHYHT2.cjs');var chunkVQCIOKJV_cjs=require('../chunk-VQCIOKJV.cjs');require('../chunk-VI36DRWG.cjs'),require('../chunk-7Y47QXMX.cjs'),require('../chunk-ZV35WD6K.cjs'),require('../chunk-3DWVFRQD.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return chunkHFW7E2Z7_cjs.a(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return chunkVQCIOKJV_cjs.b(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return chunkVQCIOKJV_cjs.a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return chunkCSHNTZW4_cjs.c({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return chunkMCPADH33_cjs.b(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
|
|
1
|
+
'use strict';var chunkHFW7E2Z7_cjs=require('../chunk-HFW7E2Z7.cjs'),chunkMCPADH33_cjs=require('../chunk-MCPADH33.cjs');require('../chunk-6EJRZHFP.cjs'),require('../chunk-TIQ775WI.cjs');var chunkCSHNTZW4_cjs=require('../chunk-CSHNTZW4.cjs');require('../chunk-C7RR2JCL.cjs'),require('../chunk-AW3COGCI.cjs'),require('../chunk-SIPLKLWU.cjs'),require('../chunk-CAID4CGO.cjs'),require('../chunk-7JVHYHT2.cjs');var chunkVQCIOKJV_cjs=require('../chunk-VQCIOKJV.cjs');require('../chunk-VI36DRWG.cjs'),require('../chunk-7Y47QXMX.cjs'),require('../chunk-66ZZIF2L.cjs'),require('../chunk-P7STTKRO.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return chunkHFW7E2Z7_cjs.a(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return chunkVQCIOKJV_cjs.b(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return chunkVQCIOKJV_cjs.a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return chunkCSHNTZW4_cjs.c({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return chunkMCPADH33_cjs.b(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
|
|
2
2
|
exports.createFirestoreArchiveFactory=P;exports.createFirestoreBlobStorage=w;exports.createFirestoreBoardAdapter=z;exports.createFirestoreBoardRefs=N;exports.createFirestoreBoardRuntimeBundle=Y;exports.createFirestoreJournalStorage=m;exports.createFirestoreKvStorage=A;exports.createFirestoreLock=J;exports.createFirestoreQueueStorage=W;exports.createFirestoreScratchStorage=O;exports.makeFirestoreRef=b;exports.serializeFirestoreRef=l;//# sourceMappingURL=index.cjs.map
|
|
3
3
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {a as a$1}from'../chunk-VS3BXEYK.js';import {b as b$1}from'../chunk-Y4WK7HE4.js';import'../chunk-QLB6PKOT.js';import'../chunk-REZO2QJD.js';import {c as c$1}from'../chunk-PEJRTZU3.js';import'../chunk-BRYV6CDD.js';import'../chunk-FULAMLUU.js';import'../chunk-EOVTMJYZ.js';import'../chunk-MRESV3MD.js';import'../chunk-ANKA7HEJ.js';import {a,b as b$2}from'../chunk-44L64VQ2.js';import'../chunk-Q444D72R.js';import'../chunk-R7SQQSDX.js';import'../chunk-YOY2JM5N.js';import'../chunk-3SLSRX6Q.js';import'../chunk-MNEOJWPS.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return a$1(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return b$2(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return c$1({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return b$1(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
|
|
1
|
+
import {a as a$1}from'../chunk-VS3BXEYK.js';import {b as b$1}from'../chunk-Y4WK7HE4.js';import'../chunk-QLB6PKOT.js';import'../chunk-E7SDEZSI.js';import {c as c$1}from'../chunk-PEJRTZU3.js';import'../chunk-C7OY3PYL.js';import'../chunk-FULAMLUU.js';import'../chunk-EOVTMJYZ.js';import'../chunk-QJQ53PLM.js';import'../chunk-ANKA7HEJ.js';import {a,b as b$2}from'../chunk-44L64VQ2.js';import'../chunk-Q444D72R.js';import'../chunk-R7SQQSDX.js';import'../chunk-QE3QXEHI.js';import'../chunk-CVTL2EFR.js';import'../chunk-MNEOJWPS.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return a$1(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return b$2(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return c$1({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return b$1(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
|
|
2
2
|
export{P as createFirestoreArchiveFactory,w as createFirestoreBlobStorage,z as createFirestoreBoardAdapter,N as createFirestoreBoardRefs,Y as createFirestoreBoardRuntimeBundle,m as createFirestoreJournalStorage,A as createFirestoreKvStorage,J as createFirestoreLock,W as createFirestoreQueueStorage,O as createFirestoreScratchStorage,b as makeFirestoreRef,l as serializeFirestoreRef};//# sourceMappingURL=index.js.map
|
|
3
3
|
//# sourceMappingURL=index.js.map
|