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,3 +1,3 @@
|
|
|
1
|
-
import {b as b$2}from'./chunk-PEJRTZU3.js';import {a as a$1}from'./chunk-BRYV6CDD.js';import {q,p,a as a$3,t}from'./chunk-FULAMLUU.js';import {a,G,i,h,z,B,D,l,q as q$1,F,E as E$1,A,g,b as b$3,c,d,e as e$1,f as f$1,r,k,j,y,x,w,v}from'./chunk-MRESV3MD.js';import {a as a$2,b as b$1}from'./chunk-44L64VQ2.js';import {a as a$4}from'./chunk-YOY2JM5N.js';import {e,f}from'./chunk-UGB7PC4P.js';async function mt(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function Pt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function 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 a(e,o)}function _t(e,o,a){return {blob:e,kv:o,journal:a}}function St(e$1,o={}){function a(m){return {status:"success",data:m}}function r(m){return {status:"fail",error:m}}function s(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}async function d(m){let l=o.emitNotification;if(!l||m.length===0)return;let h=e(m);if(h.length===1){await l(h[0]);return}await l(f({kind:"notification-batch",notifications:h}));}async function f$1(m){let l=m.params?.id;if(l){let h=await e$1.readCard(l);if(!h)throw new Error(`card "${l}" not found`);return [h]}return await e$1.readAllCards()}function v(m){return f({kind:"notification-batch",notifications:e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function w(m){if(Array.isArray(m))return m;if(m&&typeof m=="object"){let l=m;return Array.isArray(l.files)?l.files:[m]}return null}return {async get(m){try{return a({cards:await f$1(m)})}catch(l){return s(l)}},async buildNotificationBatch(m){try{return a(v(await f$1(m)))}catch(l){return s(l)}},async set(m){try{let l=m.body;if(l==null)return r("set requires a body (card object or array of cards)");let 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$1.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$1.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$1.patchCard(l,h,_);let O=await e$1.readCard(l);return O?(await d([{kind:"card_refreshed",cardId:l,card:O}]),a({count:1})):r(`card "${l}" not found`)}catch(l){return s(l)}},async appendFiles(m){try{let l=m.params?.id;if(!l)return r("appendFiles requires params.id");let h=await e$1.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$1,o={}){async function a(r){let s=o.emitNotification;if(!s||r.length===0)return;let d=e(r);if(d.length===1){await s(d[0]);return}await s(f({kind:"notification-batch",notifications:d}));}return {async enqueue(r){let s=await e$1.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await e$1.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:e$1.enqueueIfAbsent?async(r,s)=>{let d=await e$1.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return e$1.lease(r)},ack(r,s){return e$1.ack(r,s)},nack(r,s,d){return e$1.nack(r,s,d)},peekActive(r){return e$1.peekActive(r)},peekDeadLetter(r){return e$1.peekDeadLetter(r)},async stage(r,s){return e$1.stage(r,s)},async commitStaged(r){let s=await e$1.commitStaged(r);if(s){let d=await vt(e$1,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return e$1.discardStaged(r,s)},peekStaged(r){return e$1.peekStaged(r)}}}function b(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function T(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function 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 f$1(e,r,()=>({_sources:{}}))}function It(e,o){return d(e,o)}function xt(e){return g(e)}function Tt(e,o){return e$1(e,o)}function Ot(e,o,a,r,s,d){return async f=>{let v$1=[],w$1=await a.cardStore.readCard(f.nodeId);if(!w$1)return "task-initiate-failure";let m=w$1.id;if(m===i){let p=a.activeTaskConfigs?.(),y={[h]:p?k((await Promise.all(Object.keys(p).filter(k=>k!==i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w$1.card_data??{},h$1=w$1.source_defs??[],S=await a.cardRuntimeStore.readRuntime(m),_=false,O=async()=>{_&&(await a.cardRuntimeStore.writeRuntime(m,S),_=false);},L=p=>v(S._sources[p]),J=(p,y)=>{S._sources[p]=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$1=L(p);if(f.update.failure){let k=f.update.rqt??y$1.lastRequestedToken??y$1.queueRequestedToken;k&&J(p,y(y$1,k));}else {let k=f.update.rqt;if(!y$1.lastCompletedToken||k>y$1.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?x(y$1,k):y(y$1,k));}}await O();}}let j$1={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];j$1[p]=k!==void 0?k:y;}else j$1[p]=y;let Y={id:m,card_data:{...l},requires:j$1,source_defs:h$1,compute:w$1.compute},W=a$4.enrichSourcesSync(Array.isArray(w$1.source_defs)?w$1.source_defs:void 0,{card_data:l,requires:j$1}).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$1.compute&&a$4.runSync(Y,{sourcesData:de}),(s??(()=>{}))(m,Y.computed_values??{});let fe={...w$1,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 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$1.push({taskKind:"source-fetch",payload:{boardRef:a$2(e),enrichedCard:fe,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v$1)),"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 w(k,D)==="in-flight"}))return "task-initiated";let pe=w$1.provides??[],me={};for(let{bindTo:p,ref:y}of pe)me[p]=a$4.resolve(Y,y);return (d??(()=>{}))(me),r(f.nodeId,me),v$1.length>0&&await a.executionRequestStore.appendEntries(o,v$1),"task-initiated"}}function nr(e$1,o,a$4={}){a$1(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=a$2(e$1),f$1=a$4.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),v=null,w=a$4.boardRuntimeStoreRef,m=a$4.scratchStoreRef,l$1=a$4.taskExecutorRef,h$1=a$4.chatHandlerFlow;function S(){if(!w)throw new Error(`Board at ${e$1.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return w}function _(n){if(n.length!==0)try{let t=e(n),c=f({kind:"notification-batch",notifications:t});return Promise.resolve(f$1(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(t){s(`[async-board-live-cards-public] emitNotification failed: ${t instanceof Error?t.message:String(t)}`);return}}let O=()=>b$2(o.kvStorageForRef(S())),L=e$1.value,J=()=>b$3(a(()=>o.kvStorageForRef(S()),o.hashFn),"v1"),V=async()=>{let n=await O().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no outputs store configured.`);return xt(o.kvStorageForRef(n))},j=async()=>{let n=await O().readCardStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no card store configured.`);let t=o.kvStorageForRef(n);return yt(pt(gt(t),o.hashFn),s)};async function Y(){return !!(await J().readSnapshot(L)).values[q$1]}async function ue(){let n=await J().readSnapshot(L);if(!n.values[q$1])throw new Error(`Board not initialized at ${e$1.value}`);return F(n.values)}async function W(n,t){let c=await J().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:E$1(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let ae=()=>c(o.journalStorageForRef(S()));async function de(){return l$1??await O().readTaskExecutorRef()}async function fe(){return A(await(await V()).readAllDataObjects())}async function B$1(n){await ae().appendEvent(n);}async function ge(){let n=await O().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function 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 a$2(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$1({type:"task-failed",taskName:q,error:g,timestamp:E()});}),t$1=At(o.kvStorageForRef(S())),c=await Z(),i$1=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$1.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),Te[u]=g;}},Ie={async readSourceData(u,g){let P=`${u}/${g}`;return C.has(P)?C.get(P):await i$1.readSourceData(u,g)},ingestSourceDataStaged(u,g,P,$){return i$1.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$1.hasSource(u,g)},async listSources(u){let g=await i$1.listSources(u),P=[...C.keys()].filter($=>$.startsWith(`${u}/`)).map($=>$.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await ue(),De=q(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await ae().readEntriesAfterCursor(xe.lastDrainedJournalId),ye=wt,Ve=()=>De.config.tasks,le=t(De,{handlers:{"card-handler":Ot(e$1,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: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$1.writeRuntime(u,g);for(let u of x)await i$1.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let Le=z(B(d,$e));await I.writeStatusSnapshot(Le);let 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!==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$1.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:a$2(Me),deliveryToken:Se,outputFile:z.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e$1.value,br:a$2(e$1),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:a$2(e$1),callback:r.createCallback(ht),output:Qe}});}G.length>0&&await U.enqueueMany(G);}catch(q){await B$1({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:a$2(ke),deliveryToken:z,outputFile:q.outputFile,cardId:P});}let te=kt({cbk:g.callbackToken,rg:e$1.value,br:a$2(e$1),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:a$2(e$1),callback:r.createCallback(te),...U?{output:U}:{}});G.dispatched||await B$1({type:"task-failed",taskName:P,error:G.error??"dispatch failed",timestamp:E()});}});}async function p$1(){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$1().finally(()=>{v=null;}),v)}async function k(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);await o.queueStorageForRef(n,"process-accumulated").enqueue({boardRef:a$2(e$1)}),await o.requestProcessAccumulated?.();}async function D$1(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await t.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await t.ack(i.id,i.leaseToken);if(c.length<64)return}}function 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$1=n.params?.queueStoreRef;if(!i$1)return R("init requires params.queueStoreRef");let A=n.params?.fetchedSourcesStoreRef;if(!A)return R("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let I=n.params?.chatStoreRef;if(!I)return R("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return R("init requires params.artifactsStoreRef");await Y()||await W({lastDrainedJournalId:"",graph:p(a$3(D)),runtimeByCardId:{}},null);let C=O();await C.writeBoardRuntimeStoreRef(w),await C.writeCardStoreRef(t),await C.writeOutputsStoreRef(c),await C.writeQueueStoreRef(i$1),await C.writeFetchedSourcesStoreRef(A),await C.writeChatStoreRef(I),await C.writeArtifactsStoreRef(F),await(await j()).writeCard(i,l());let x=o.kvStorage("card-upsert"),Q=l(),H=G(Q),X=o.hashFn(H),se=(await x.read(i))?.blobRef??await(await j()).readCardKey(i)??i;return await B$1({type:"task-upsert",taskName:i,taskConfig:H,timestamp:E()}),await x.write(i,{blobRef:se,taskConfigHash:X,updatedAt:E()}),await B$1({type:"task-restart",taskName:i,timestamp:E()}),K(),await(await V()).writeStatusSnapshot(z(B(d,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=z(B(d,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$1.value} has no card store configured`)}catch(t){return T(t)}},async getBoardRuntimeStoreRef(n){try{return b({storeRef:w??null})}catch(t){return T(t)}},async getOutputsStoreRef(n){try{let t=await O().readOutputsStoreRef();return t?b({storeRef:t}):R(`Board at ${e$1.value} has no outputs store configured`)}catch(t){return T(t)}},async getScratchStoreRef(n){try{return b({storeRef:m??null})}catch(t){return T(t)}},async getChatStoreRef(n){try{return b({storeRef:await O().readChatStoreRef()})}catch(t){return T(t)}},async getArtifactsStoreRef(n){try{return b({storeRef:await O().readArtifactsStoreRef()})}catch(t){return T(t)}},async getFetchedSourcesStoreRef(n){try{return b({storeRef:await O().readFetchedSourcesStoreRef()})}catch(t){return T(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return R("getConfig requires params.key");let c=O(),i;switch(t){case "task-executor":i=l$1??null;break;case "chat-handler-flow":i=h$1??null;break;case "board-runtime-store-ref":i=await c.readBoardRuntimeStoreRef();break;case "card-store-ref":i=await c.readCardStoreRef();break;case "outputs-store-ref":i=await c.readOutputsStoreRef();break;case "scratch-store-ref":i=m??null;break;case "chat-store-ref":i=await c.readChatStoreRef();break;case "artifacts-store-ref":i=await c.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=await c.readFetchedSourcesStoreRef();break;default:return R(`getConfig: unknown key "${t}"`)}return b({value:i})}catch(t){return T(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;if(!t)return R("getOutputsDataObject requires params.key");if(t===h)return b(null);let c=await 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!==i),c=await this.status({});if(c.status!=="success")return c;let i$1=await this.getAllOutputsDataObjects({});if(i$1.status!=="success")return i$1;let A=await this.getAllOutputsComputedValues({});if(A.status!=="success")return A;let I=A.data,F={};for(let C of t){let x=typeof C?.id=="string"?C.id:null;if(!x)continue;let Q=C.card_data&&typeof C.card_data=="object"&&!Array.isArray(C.card_data)?C.card_data:{};F[x]={schema_version:"v1",card_id:x,card_data:{...Q},computed_values:I[x]&&typeof I[x]=="object"?I[x]:{}};}return b({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i$1.data,cardRuntimeById:F})}catch(t){return T(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return R("addCardFiles requires params.cardId");let i=await St(await j(),{emitNotification:f$1}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:b({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return T(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return R("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await B$1({type:"task-removal",taskName:t,timestamp:E()}),t!==i&&await B$1({type:"task-restart",taskName:i,timestamp:E()}),K(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await B$1({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$1(),y()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i$1=!!n.params?.restart;if(!t&&!c)return R("upsertCard requires --card-id <id> or --all");let A=await 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$1.value}`);let F=o.kvStorage("card-upsert"),C=!1;for(let x of I){let Q=await A.readCard(x);if(!Q)continue;let H=G(Q),X=o.hashFn(H),oe=await F.read(x),se=oe?.taskConfigHash!==X;if(!(!se&&!i$1)){if(se){let Ie=oe?.blobRef??await A.readCardKey(x)??x;await B$1({type:"task-upsert",taskName:x,taskConfig:H,timestamp:E()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:E()}),C=C||x!==i;}i$1&&await B$1({type:"task-restart",taskName:x,timestamp:E()});}}return C&&await B$1({type:"task-restart",taskName: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$1({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$1({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,b$1(c),I);let F=Ae(i.cbk);return F?(await B$1({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$1({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}}}}
|
|
2
|
-
export{mt as a,gt as b,pt as c,yt as d,Nt as e,_t as f,St as g,$t as h,nr as i};//# sourceMappingURL=chunk-
|
|
3
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {b as b$2}from'./chunk-PEJRTZU3.js';import {a as a$1}from'./chunk-C7OY3PYL.js';import {q,p,a as a$3,t}from'./chunk-FULAMLUU.js';import {a,G,i,h,z,B,D,l,q as q$1,F,E as E$1,A,g,b as b$3,c,d,e as e$1,f as f$1,r,k,j,y,x,w,v}from'./chunk-QJQ53PLM.js';import {a as a$2,b as b$1}from'./chunk-44L64VQ2.js';import {a as a$4}from'./chunk-QE3QXEHI.js';import {e,f}from'./chunk-UGB7PC4P.js';async function mt(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function Pt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function 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 a(e,o)}function _t(e,o,a){return {blob:e,kv:o,journal:a}}function St(e$1,o={}){function a(m){return {status:"success",data:m}}function r(m){return {status:"fail",error:m}}function s(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}async function d(m){let l=o.emitNotification;if(!l||m.length===0)return;let h=e(m);if(h.length===1){await l(h[0]);return}await l(f({kind:"notification-batch",notifications:h}));}async function f$1(m){let l=m.params?.id;if(l){let h=await e$1.readCard(l);if(!h)throw new Error(`card "${l}" not found`);return [h]}return await e$1.readAllCards()}function v(m){return f({kind:"notification-batch",notifications:e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function w(m){if(Array.isArray(m))return m;if(m&&typeof m=="object"){let l=m;return Array.isArray(l.files)?l.files:[m]}return null}return {async get(m){try{return a({cards:await f$1(m)})}catch(l){return s(l)}},async buildNotificationBatch(m){try{return a(v(await f$1(m)))}catch(l){return s(l)}},async set(m){try{let l=m.body;if(l==null)return r("set requires a body (card object or array of cards)");let 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$1.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$1.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$1.patchCard(l,h,_);let O=await e$1.readCard(l);return O?(await d([{kind:"card_refreshed",cardId:l,card:O}]),a({count:1})):r(`card "${l}" not found`)}catch(l){return s(l)}},async appendFiles(m){try{let l=m.params?.id;if(!l)return r("appendFiles requires params.id");let h=await e$1.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$1,o={}){async function a(r){let s=o.emitNotification;if(!s||r.length===0)return;let d=e(r);if(d.length===1){await s(d[0]);return}await s(f({kind:"notification-batch",notifications:d}));}return {async enqueue(r){let s=await e$1.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await e$1.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:e$1.enqueueIfAbsent?async(r,s)=>{let d=await e$1.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return e$1.lease(r)},ack(r,s){return e$1.ack(r,s)},nack(r,s,d){return e$1.nack(r,s,d)},peekActive(r){return e$1.peekActive(r)},peekDeadLetter(r){return e$1.peekDeadLetter(r)},async stage(r,s){return e$1.stage(r,s)},async commitStaged(r){let s=await e$1.commitStaged(r);if(s){let d=await vt(e$1,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return e$1.discardStaged(r,s)},peekStaged(r){return e$1.peekStaged(r)}}}function b(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function T(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function 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 f$1(e,r,()=>({_sources:{}}))}function It(e,o){return d(e,o)}function xt(e){return g(e)}function Tt(e,o){return e$1(e,o)}function Ot(e,o,a,r,s,d){return async f=>{let v$1=[],w$1=await a.cardStore.readCard(f.nodeId);if(!w$1)return "task-initiate-failure";let m=w$1.id;if(m===i){let p=a.activeTaskConfigs?.(),y={[h]:p?k((await Promise.all(Object.keys(p).filter(k=>k!==i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w$1.card_data??{},h$1=w$1.source_defs??[],S=await a.cardRuntimeStore.readRuntime(m),_=false,O=async()=>{_&&(await a.cardRuntimeStore.writeRuntime(m,S),_=false);},L=p=>v(S._sources[p]),J=(p,y)=>{S._sources[p]=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$1=L(p);if(f.update.failure){let k=f.update.rqt??y$1.lastRequestedToken??y$1.queueRequestedToken;k&&J(p,y(y$1,k));}else {let k=f.update.rqt;if(!y$1.lastCompletedToken||k>y$1.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?x(y$1,k):y(y$1,k));}}await O();}}let j$1={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];j$1[p]=k!==void 0?k:y;}else j$1[p]=y;let Y={id:m,card_data:{...l},requires:j$1,source_defs:h$1,compute:w$1.compute},W=a$4.enrichSourcesSync(Array.isArray(w$1.source_defs)?w$1.source_defs:void 0,{card_data:l,requires:j$1}).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$1.compute&&a$4.runSync(Y,{sourcesData:de}),(s??(()=>{}))(m,Y.computed_values??{});let fe={...w$1,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 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$1.push({taskKind:"source-fetch",payload:{boardRef:a$2(e),enrichedCard:fe,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v$1)),"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 w(k,D)==="in-flight"}))return "task-initiated";let pe=w$1.provides??[],me={};for(let{bindTo:p,ref:y}of pe)me[p]=a$4.resolve(Y,y);return (d??(()=>{}))(me),r(f.nodeId,me),v$1.length>0&&await a.executionRequestStore.appendEntries(o,v$1),"task-initiated"}}function nr(e$1,o,a$4={}){a$1(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=a$2(e$1),f$1=a$4.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),v=null,w=a$4.boardRuntimeStoreRef,m=a$4.scratchStoreRef,l$1=a$4.taskExecutorRef,h$1=a$4.chatHandlerFlow;function S(){if(!w)throw new Error(`Board at ${e$1.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return w}function _(n){if(n.length!==0)try{let t=e(n),c=f({kind:"notification-batch",notifications:t});return Promise.resolve(f$1(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(t){s(`[async-board-live-cards-public] emitNotification failed: ${t instanceof Error?t.message:String(t)}`);return}}let O=()=>b$2(o.kvStorageForRef(S())),L=e$1.value,J=()=>b$3(a(()=>o.kvStorageForRef(S()),o.hashFn),"v1"),V=async()=>{let n=await O().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no outputs store configured.`);return xt(o.kvStorageForRef(n))},j=async()=>{let n=await O().readCardStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no card store configured.`);let t=o.kvStorageForRef(n);return yt(pt(gt(t),o.hashFn),s)};async function Y(){return !!(await J().readSnapshot(L)).values[q$1]}async function ue(){let n=await J().readSnapshot(L);if(!n.values[q$1])throw new Error(`Board not initialized at ${e$1.value}`);return F(n.values)}async function W(n,t){let c=await J().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:E$1(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let ae=()=>c(o.journalStorageForRef(S()));async function de(){return l$1??await O().readTaskExecutorRef()}async function fe(){return A(await(await V()).readAllDataObjects())}async function B$1(n){await ae().appendEvent(n);}async function ge(){let n=await O().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function 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 a$2(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$1({type:"task-failed",taskName:q,error:g,timestamp:E()});}),t$1=At(o.kvStorageForRef(S())),c=await Z(),i$1=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$1.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),Te[u]=g;}},Ie={async readSourceData(u,g){let P=`${u}/${g}`;return C.has(P)?C.get(P):await i$1.readSourceData(u,g)},ingestSourceDataStaged(u,g,P,$){return i$1.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$1.hasSource(u,g)},async listSources(u){let g=await i$1.listSources(u),P=[...C.keys()].filter($=>$.startsWith(`${u}/`)).map($=>$.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await ue(),De=q(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await ae().readEntriesAfterCursor(xe.lastDrainedJournalId),ye=wt,Ve=()=>De.config.tasks,le=t(De,{handlers:{"card-handler":Ot(e$1,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: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$1.writeRuntime(u,g);for(let u of x)await i$1.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let Le=z(B(d,$e));await I.writeStatusSnapshot(Le);let 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!==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$1.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:a$2(Me),deliveryToken:Se,outputFile:z.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e$1.value,br:a$2(e$1),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:a$2(e$1),callback:r.createCallback(ht),output:Qe}});}G.length>0&&await U.enqueueMany(G);}catch(q){await B$1({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:a$2(ke),deliveryToken:z,outputFile:q.outputFile,cardId:P});}let te=kt({cbk:g.callbackToken,rg:e$1.value,br:a$2(e$1),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:a$2(e$1),callback:r.createCallback(te),...U?{output:U}:{}});G.dispatched||await B$1({type:"task-failed",taskName:P,error:G.error??"dispatch failed",timestamp:E()});}});}async function p$1(){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$1().finally(()=>{v=null;}),v)}async function k(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);await o.queueStorageForRef(n,"process-accumulated").enqueue({boardRef:a$2(e$1)}),await o.requestProcessAccumulated?.();}async function D$1(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await t.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await t.ack(i.id,i.leaseToken);if(c.length<64)return}}function 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$1=n.params?.queueStoreRef;if(!i$1)return R("init requires params.queueStoreRef");let A=n.params?.fetchedSourcesStoreRef;if(!A)return R("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let I=n.params?.chatStoreRef;if(!I)return R("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return R("init requires params.artifactsStoreRef");await Y()||await W({lastDrainedJournalId:"",graph:p(a$3(D)),runtimeByCardId:{}},null);let C=O();await C.writeBoardRuntimeStoreRef(w),await C.writeCardStoreRef(t),await C.writeOutputsStoreRef(c),await C.writeQueueStoreRef(i$1),await C.writeFetchedSourcesStoreRef(A),await C.writeChatStoreRef(I),await C.writeArtifactsStoreRef(F),await(await j()).writeCard(i,l());let x=o.kvStorage("card-upsert"),Q=l(),H=G(Q),X=o.hashFn(H),se=(await x.read(i))?.blobRef??await(await j()).readCardKey(i)??i;return await B$1({type:"task-upsert",taskName:i,taskConfig:H,timestamp:E()}),await x.write(i,{blobRef:se,taskConfigHash:X,updatedAt:E()}),await B$1({type:"task-restart",taskName:i,timestamp:E()}),K(),await(await V()).writeStatusSnapshot(z(B(d,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=z(B(d,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$1.value} has no card store configured`)}catch(t){return T(t)}},async getBoardRuntimeStoreRef(n){try{return b({storeRef:w??null})}catch(t){return T(t)}},async getOutputsStoreRef(n){try{let t=await O().readOutputsStoreRef();return t?b({storeRef:t}):R(`Board at ${e$1.value} has no outputs store configured`)}catch(t){return T(t)}},async getScratchStoreRef(n){try{return b({storeRef:m??null})}catch(t){return T(t)}},async getChatStoreRef(n){try{return b({storeRef:await O().readChatStoreRef()})}catch(t){return T(t)}},async getArtifactsStoreRef(n){try{return b({storeRef:await O().readArtifactsStoreRef()})}catch(t){return T(t)}},async getFetchedSourcesStoreRef(n){try{return b({storeRef:await O().readFetchedSourcesStoreRef()})}catch(t){return T(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return R("getConfig requires params.key");let c=O(),i;switch(t){case "task-executor":i=l$1??null;break;case "chat-handler-flow":i=h$1??null;break;case "board-runtime-store-ref":i=await c.readBoardRuntimeStoreRef();break;case "card-store-ref":i=await c.readCardStoreRef();break;case "outputs-store-ref":i=await c.readOutputsStoreRef();break;case "scratch-store-ref":i=m??null;break;case "chat-store-ref":i=await c.readChatStoreRef();break;case "artifacts-store-ref":i=await c.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=await c.readFetchedSourcesStoreRef();break;default:return R(`getConfig: unknown key "${t}"`)}return b({value:i})}catch(t){return T(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;if(!t)return R("getOutputsDataObject requires params.key");if(t===h)return b(null);let c=await 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!==i),c=await this.status({});if(c.status!=="success")return c;let i$1=await this.getAllOutputsDataObjects({});if(i$1.status!=="success")return i$1;let A=await this.getAllOutputsComputedValues({});if(A.status!=="success")return A;let I=A.data,F={};for(let C of t){let x=typeof C?.id=="string"?C.id:null;if(!x)continue;let Q=C.card_data&&typeof C.card_data=="object"&&!Array.isArray(C.card_data)?C.card_data:{};F[x]={schema_version:"v1",card_id:x,card_data:{...Q},computed_values:I[x]&&typeof I[x]=="object"?I[x]:{}};}return b({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i$1.data,cardRuntimeById:F})}catch(t){return T(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return R("addCardFiles requires params.cardId");let i=await St(await j(),{emitNotification:f$1}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:b({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return T(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return R("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await B$1({type:"task-removal",taskName:t,timestamp:E()}),t!==i&&await B$1({type:"task-restart",taskName:i,timestamp:E()}),K(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await B$1({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$1(),y()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i$1=!!n.params?.restart;if(!t&&!c)return R("upsertCard requires --card-id <id> or --all");let A=await 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$1.value}`);let F=o.kvStorage("card-upsert"),C=!1;for(let x of I){let Q=await A.readCard(x);if(!Q)continue;let H=G(Q),X=o.hashFn(H),oe=await F.read(x),se=oe?.taskConfigHash!==X;if(!(!se&&!i$1)){if(se){let Ie=oe?.blobRef??await A.readCardKey(x)??x;await B$1({type:"task-upsert",taskName:x,taskConfig:H,timestamp:E()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:E()}),C=C||x!==i;}i$1&&await B$1({type:"task-restart",taskName:x,timestamp:E()});}}return C&&await B$1({type:"task-restart",taskName: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$1({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$1({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,b$1(c),I);let F=Ae(i.cbk);return F?(await B$1({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$1({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}}}}
|
|
2
|
+
export{mt as a,gt as b,pt as c,yt as d,Nt as e,_t as f,St as g,$t as h,nr as i};//# sourceMappingURL=chunk-E7SDEZSI.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-E7SDEZSI.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {a as a$1}from'./chunk-FOFGEABN.js';import {a,c,d,e,b,f}from'./chunk-O7NOHKVR.js';import {a as a$2}from'./chunk-NN52BT3Q.js';import {b as b$1}from'./chunk-44L64VQ2.js';function M(a){if(!a||typeof a!="object")return false;let t=a;return typeof t.kind=="string"&&t.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let t=a;return t.kind==="notification-batch"?Array.isArray(t.notifications)?t.notifications.filter(M):[]:M(a)?[a]:[]}function X(a,t,i){let c=0;return {accepted:a.filter(_=>{if(!M(_))return c++,false;let S=_;return typeof S.sentAtMs=="number"&&t-S.sentAtMs>i?(c++,false):true}),rejected:c}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let t=a.summary;return !t||typeof t!="object"?false:Number(t.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let t=a;return t.kind==="notification-batch"&&Array.isArray(t.notifications)}function V(a,t){if(t.kind==="status"){z(t.status)&&(a.status=t.status);return}if(t.kind==="computed_values"){a.computedValues[t.cardId]=t.values;return}if(t.kind==="data_object"){a.dataObjects[t.key]=t.payload;return}if(t.kind==="card_refreshed"){a.cards[t.cardId]=t.card;return}t.kind==="card_removed"&&(delete a.cards[t.cardId],delete a.computedValues[t.cardId]);}function Y(a,t){if(W(t)){for(let i of t.notifications)M(i)&&V(a,i);return}M(t)&&V(a,t);}function j(a,t){if(a?.status==="success")return Object.prototype.hasOwnProperty.call(a,"data")?a.data:void 0;throw a?.status==="fail"||a?.status==="error"?Object.assign(new Error(a.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function N(a,t){return j(await a,t)}function T(a$1){let t=a(a$1,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=t.split(".");if(!(i.length>=2&&i.every(g=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(g))))throw Object.assign(new Error("MCP tool requires a card private key with at least two identifier segments (e.g. chat.foundry_thread_id)"),{statusCode:400});return t}function q(a,t){let i=a.__private;for(let c of t.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,c))return {exists:false,value:null};i=i[c];}return {exists:true,value:i}}function ot(a$1){let{boardId:t,bootstrapBoard:i,sseHub:c,onChannelSubscribed:g,onChannelUnsubscribed:_,getMcpFacade:S,getMcpCardStoreFacade:n}=a$1;function f(s){let d=a(s,"board_id");if(!d)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(d!==t)throw Object.assign(new Error(`Unknown board_id: ${d}`),{statusCode:400})}function h(s){let d=a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function w(s){f(s);let d=h(s),e=a(s,"channel_name"),r=a(s,"card_id")||void 0;if(!e)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:e,...r?{cardId:r}:{}}}function R(s){f(s);let d=a(s,"card_id");if(!d)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:d}}async function I(s){await i();let{cardId:d}=R(s),e=h(s);if(!await c.subscribeChat(e,d))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:e,subscribed:true}}}async function u(s){await i();let{cardId:d}=R(s),e=h(s);if(!c.unsubscribeChat(e,d))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:e,subscribed:false}}}async function b(s,d){await i();let{clientId:e,channelName:r,cardId:o}=w(s);if(!c.has(e))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return d?(c.subscribeChannel(e,r,o),g?.(e,r,o?{cardId:o}:{})):(c.unsubscribeChannel(e,r,o),_?.(e,r,o?{cardId:o}:{})),{status:"success",data:{boardId:t,clientId:e,channelName:r,subscribed:d,...o?{cardId:o}:{}}}}async function m(s,d){let{cardId:e}=R(s);return await S().setChatProcessing({cardId:e,active:d}),{status:"success",data:{boardId:t,cardId:e,active:d}}}async function p(s){let{cardId:d}=R(s),e=await S().getChatProcessing({cardId:d});return {status:"success",data:{boardId:t,cardId:d,active:e.active}}}async function y(s){let{cardId:d}=R(s),e=T(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(e.split(".").includes("visible_controlplane_only")){let r=await N(n().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(r.cards)&&r.cards.length>0&&typeof r.cards[0]=="object"&&!Array.isArray(r.cards[0])?r.cards[0]:null,k=o?q(o,"visible_controlplane_only").value:void 0;if(s.value!==k)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:d,key:e}}}return j(await n().patch({params:{id:d,path:`__private.${e}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:d,key:e}}}async function C(s){let{cardId:d}=R(s),e=T(s),r=await N(n().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(r.cards)&&r.cards.length>0&&r.cards[0]&&typeof r.cards[0]=="object"&&!Array.isArray(r.cards[0])?r.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=q(o,e);return {status:"success",data:{boardId:t,cardId:d,key:e,exists:k.exists,value:k.value}}}return {requireCardArgs:R,subscribeChat:I,unsubscribeChat:u,watchChannel:b,setChatProcessing:m,getChatProcessing:p,setCardMeta:y,getCardMeta:C}}function it(a){let{boardId:t,boardContexts:i,readChatRecords:c,getChatProcessing:g}=a,_=Number.isInteger(a.chatBootstrapTailTurns)&&a.chatBootstrapTailTurns>0?a.chatBootstrapTailTurns:1;function S(u){return {role:String(u.role||"system"),text:String(u.text||""),files:Array.isArray(u.files)?u.files:[],...typeof u.turn=="string"&&u.turn?{turn:u.turn}:{}}}function n(u){if(u.length===0)return null;if(u.length===1)return u[0];let b=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],p={};for(let C of m)p[C]=0;for(let C of u){let s=C,d=Array.isArray(s.cards)?s.cards:[];b.push(...d);for(let e of m)p[e]+=Number(s?.summary?.[e]||0);}let y=u[0];return {...y,cards:b,summary:{...y.summary||{},card_count:b.length,...p}}}async function f(){let u=[];for(let b of i)try{let m=await b.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&u.push(m.data);}catch{}return u}async function h(){let b=(await f()).map(m=>m.statusSnapshot).filter(Boolean);if(b.length===0){let m=i.map(p=>p.notification.status).filter(Boolean);return n(m)}return n(b)}async function w(){let u={},b=await f();for(let m of b)Object.assign(u,m.cardRuntimeById||{});if(Object.keys(u).length>0)return u;for(let m of i)for(let[p,y]of Object.entries(m.notification.computedValues)){let C=m.notification.cards[p];u[p]={schema_version:"v1",card_id:p,card_data:C?.card_data??{},computed_values:y??{}};}return u}async function R(){let u={},b=await f();for(let m of b)Object.assign(u,m.dataObjectsByToken||{});if(Object.keys(u).length===0)for(let m of i)Object.assign(u,m.notification.dataObjects||{});return u}async function I(){let u=await f(),b=u.flatMap(C=>Array.isArray(C.cardDefinitions)?C.cardDefinitions:[]),m={},p={};for(let C of u)Object.assign(m,C.dataObjectsByToken||{}),Object.assign(p,C.cardRuntimeById||{});let y={};for(let C of b){if(!C?.id)continue;let s=C.id;try{let d=await c(s,{tailTurns:_}),e=await g(s);(d.length>0||e)&&(y[s]={messages:d.map(r=>S(r)),receiving:!1,processing:e});}catch{}}return {boardId:t,cardDefinitions:b,statusSnapshot:await h(),dataObjectsByToken:m,cardRuntimeById:p,cardChatsByCardId:y}}return {readStatusSnapshot:h,readCardRuntimeArtifacts:w,readDataObjectsByToken:R,buildPublishedRuntimePayload:I}}function K(a){let t=String(a||"").trim();if(!t)return "upload.bin";let i=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (i>=0?t.slice(i+1):t)||"upload.bin"}function ct(a){let{safeCardId:t,artifactsStores:i,cardFileMetadataStore:c,readCardFromStore:g,updateCardLocalOnly:_,writeChatRecord:S}=a;async function n(w){let R=[];try{let I=await g(w);if(!I)return R;let u=c().read(I.card_data&&typeof I.card_data=="object"?I.card_data:null);for(let b of u)R.push(String(b.stored_name??""));}catch{}return R}async function f(w,R,I,u){let b=t(w),m=i(w),p=K(R),y=await n(w),s=`${String(y.length+1).padStart(3,"0")}-${p}`.slice(-36);if(!m.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${w}`),{statusCode:500});return await m.files.putBytes(`${b}/${s}`,new Uint8Array(u),I||"application/octet-stream"),{name:p,stored_name:s,size:u.length,mime_type:I||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function h(w,R,I,u,b){if(!u.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let m=b?.inChat===true,p=await f(w,R,I,u),y=null;if(await _(w,C=>{let s=new Date().toISOString(),d=C.card_data&&typeof C.card_data=="object"?C.card_data:{};C.card_data=d;let e=c().normalizeIncoming([{name:p.name,stored_name:p.stored_name,size:p.size,mime_type:p.mime_type,uploaded_at:p.uploaded_at||s,chat:m}],s);return y=c().merge(d,e).findIndex(o=>o.stored_name===p.stored_name),C}),m&&b?.suppressChatRecordWrite!==true){let C=typeof y=="number"&&y>=0?` #${y}`:"";await S(w,"system",`file uploaded: ${p.name} as ${p.stored_name}${C}`,[],b?.turnId??"");}return {ok:true,file:{...p,...typeof y=="number"&&y>=0?{file_idx:y}:{},chat:m},...typeof y=="number"&&y>=0?{file_idx:y}:{}}}return {uploadCardFile:h,readCardStoredFileNames:n}}function pt(a$1){return {"discover.source-kinds":()=>a$1.discoverSourceKinds(),"inspect.board-runtime-status":()=>a$1.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>a$1.inspectCardDefinitionAndRuntime({cardId:a(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let i=b(t,"tail_turns"),c=b(t,"tail"),g=a(t,"turn_id"),_=t.all_turns===true,S=a(t,"tail_turns_before_id");return a$1.inspectChatMessagesOnCards({cardId:a(t,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...c!==void 0?{tail:c}:{},...g?{turnId:g}:{},..._?{allTurns:true}:{},...S?{tailTurnsBeforeId:S}:{}})},"inspect.file-contents":t=>a$1.inspectFileContents({cardId:a(t,"card_id"),fileIdx:Number(b(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>a$1.preflightValidateCandidateCardDefinition({candidateCardContent:d(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>a$1.preflightMaterializeCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockRequires:d(t,"mock_requires","mock_requires"),mockFetchedSources:d(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>a$1.preflightProbeSingleSourceInCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockProjections:c(t,"mock_projections"),sourceIdx:e(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>a$1.preflightRunSingleSourceInCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockProjections:c(t,"mock_projections"),sourceIdx:e(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>a$1.preflightRunSingleSourceInLiveCard({cardId:a(t,"card_id"),sourceIdx:e(t,"source_idx","source_idx"),mockRequires:d(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>a$1.preflightRunOneCycleWithCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockRequires:c(t,"mock_requires")}),"manage.read-card":t=>a$1.manageReadCard({cardId:a(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let i=a(t,"turn_id");if(!i)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...i?{turn:i}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"stage-ai-failure-message":t=>{let i=a(t,"turn_id"),c=a(t,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!c)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(t,"card_id"),role:"system",text:c,turn:i})},"manage.upsert-card":t=>a$1.manageUpsertCard({cardId:a(t,"card_id"),candidateCardContent:c(t,"candidate_card_content")}),"manage.remove-card":t=>a$1.manageRemoveCard({cardId:a(t,"card_id")})}}function mt(a$1){return {"webhook.process-accumulated":()=>a$1.webhookProcessAccumulated(),"webhook.source-fetch-done":t=>a$1.webhookSourceFetchDone({token:a(t,"token"),ref:a(t,"ref")}),"webhook.source-fetch-failed":t=>a$1.webhookSourceFetchFailed({token:a(t,"token"),reason:a(t,"reason")})}}function ft(a$1){let{boardId:t,uploadCardFile:i,getMcpFacade:c$1,controlplane:g}=a$1;function _(n,f){let h=a(n,"board_id");if(!h)throw Object.assign(new Error(`${f} requires board_id`),{statusCode:400});if(h!==t)throw Object.assign(new Error(`Unknown board_id: ${h}`),{statusCode:400})}function S(n,f){let{cardId:h}=g.requireCardArgs(n),w=a(n,"turn_id");return _(n,f),c$1().manageAddChatAttachment({cardId:h,role:a(n,"role")||"user",...w?{turn:w}:{},files:[{file_name:a(n,"file_name"),content_type:a(n,"content_type")||"application/octet-stream",...typeof n.text=="string"?{text:n.text}:{},...typeof n.base64=="string"?{base64:n.base64}:{},...Array.isArray(n.bytes)?{bytes:n.bytes}:{}}]})}return {"list-runtime-cards":n=>(_(n,"list-runtime-cards"),c$1().listRuntimeCards()),"sse.subscribe-chat":n=>g.subscribeChat(n),"sse.unsubscribe-chat":n=>g.unsubscribeChat(n),"sse.watch-channel":n=>g.watchChannel(n,true),"sse.unwatch-channel":n=>g.watchChannel(n,false),"getstate.is-chat-processing":n=>g.getChatProcessing(n),"setstate.chat-processing-started":n=>g.setChatProcessing(n,true),"setstate.chat-processing-done":n=>g.setChatProcessing(n,false),"getstate.card-private":n=>g.getCardMeta(n),"setstate.card-private":n=>g.setCardMeta(n),"manage.upload-card-file":n=>{let f$1=a(n,"card_id"),h=a(n,"file_name"),w=a(n,"content_type")||"application/octet-stream",R=f(n);if(_(n,"manage.upload-card-file"),!f$1)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!h)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!R)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(f$1,h,w,R,{inChat:false})},"manage.add-chat-attachment":n=>S(n,"manage.add-chat-attachment"),"manage.add-chat-attachement":n=>S(n,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":n=>{let{cardId:f}=g.requireCardArgs(n),h=a(n,"role")||"user",w=a(n,"turn_id");return _(n,"manage.add-chat-entry-and-any-attachments"),c$1().manageAddChatEntryAndAnyAttachments({cardId:f,role:h,...typeof n.text=="string"?{text:n.text}:{},...w?{turn:w}:{},...Array.isArray(n.files)?{files:n.files}:{}})},"manage.patch-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.patch-card"),c$1().managePatchCard({cardId:f,patch:c(n,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.upsert-card"),c$1().manageUpsertCard({cardId:f,candidateCardContent:c(n,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.remove-card"),c$1().manageRemoveCard({cardId:f},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async n=>{let{cardId:f}=g.requireCardArgs(n);return {status:"success",data:{cards:await c$1().adminReadCard({cardId:f})}}},"manage.admin-upsert-card":n=>{let f=a(n,"board_id"),h=a(n,"card_id");if(!f)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!h)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(f!==t)throw Object.assign(new Error(`Unknown board_id: ${f}`),{statusCode:400});return c$1().adminUpsertCard({cardId:h,candidateCardContent:c(n,"candidate_card_content")})}}}function yt(a){let{boardContexts:t,cardOwnerIndex:i,cardContextForCard:c,readStatusSnapshot:g,readDataObjectsByToken:_,readCardRuntimeArtifacts:S,readCardFromStore:n,readCardDefinitions:f,processAccumulatedLaneInternal:h,reportSourceFetched:w,reportSourceFetchFailure:R,uploadCardFile:I,chatStorePublic:u,serverUrl:b,apiBasePath:m}=a;function p(){return t[0]??null}function y(){return {async status(){let e=await g();return e==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:e}},async getOutputsDataObject(e){let r=e?.params?.key;return r?{status:"success",data:(await _())[r]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(e){let r=e?.params?.key;return r?{status:"success",data:(await S())[r]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(e){let r=e?.params?.key;if(!r)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=c(r)??p();return o?o.boardOps.getOutputsFetchedSources({params:{key:r}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(e){let r=e?.params?.id;if(!r)return {status:"fail",error:"removeCard requires params.id"};let o=c(r)??p();return o?o.boardOps.removeCard({params:{id:r}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(e){let r=e?.params?.cardId;if(!r)return {status:"fail",error:"upsertCard requires params.cardId"};let o=c(r)??p();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:r,restart:e.params.restart===true}});if(k.status!=="success")return k;if(a$1(o.boardAdapter)){let P=await h(true);if(P.status!=="success")return P}return k}}}function C(){let e=()=>{let r=p();if(!r?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return r.nonCore};return {describeTaskExecutorCapabilities(r){return e().describeTaskExecutorCapabilities(r)},validateCardPreflight(r){return e().validateCardPreflight(r)},evalCardCompute(r){return e().evalCardCompute(r)},probeSourcePreflight(r){return e().probeSourcePreflight(r)},runSourcePreflight(r){return e().runSourcePreflight(r)},simulateCardCycle(r){return e().simulateCardCycle(r)}}}function s(){return {async get(e){let r=typeof e.params?.id=="string"?e.params.id:void 0;if(r){let o=await n(r);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await f()}}},async set(e){let r=e.body;if(r==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(r)?r:[r];for(let k of o){let P=k,A=typeof P.id=="string"?P.id:"";if(!A)return {status:"fail",error:"each card must have a string `id` field"};let E=i.get(A)??0,D=t[E]??p();if(!D)return {status:"fail",error:"Board context is unavailable"};let L=await D.cardStoreOps.set({body:P});if(L.status!=="success")return L;i.set(A,E);}return {status:"success",data:{count:o.length}}},async del(e){let r=[e.params?.id,...e.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(r.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of r){let k=c(o)??p();if(!k)return {status:"fail",error:"Board context is unavailable"};let P=await k.cardStoreOps.del({params:{id:o}});if(P.status!=="success")return P;i.delete(o);}return {status:"success",data:{count:r.length}}},async patch(e){let r=typeof e.params?.id=="string"?e.params.id:void 0,o=typeof e.params?.path=="string"?e.params.path:void 0;if(!r||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=c(r)??p();return k?k.cardStoreOps.patch(e):{status:"fail",error:"Board context is unavailable"}},async appendFiles(e){let r=typeof e.params?.id=="string"?e.params.id:void 0;if(!r)return {status:"fail",error:"appendFiles requires params.id"};let o=c(r)??p();return o?o.cardStoreOps.appendFiles(e):{status:"fail",error:"Board context is unavailable"}}}}function d(){return a$2({board:y(),nonCore:C(),cardStore:s(),chatStore:u,processAccumulated:()=>h(true),sourceFetchDone:({token:e,ref:r})=>w(e,r),sourceFetchFailed:({token:e,reason:r})=>R(e,r),uploadCardFile({cardId:e,fileName:r,contentType:o,bytes:k,suppressChatRecordWrite:P}){return I(e,r,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:e,fileIdx:r,storedName:o}){let k=`${b||""}${m}/cards/${encodeURIComponent(e)}/files/${r}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:e,ref:r}){let o=c(e)??p();if(!o||a$1(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(b$1(r)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:y,mcpNonCoreFacade:C,mcpCardStoreFacade:s,createMcpFacade:d}}export{J as a,X as b,Q as c,z as d,Y as e,j as f,N as g,T as h,q as i,ot as j,it as k,ct as l,pt as m,mt as n,ft as o,yt as p};//# sourceMappingURL=chunk-PIPXFUEA.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {a as a$1}from'./chunk-FOFGEABN.js';import {a,c,d,e,b,f}from'./chunk-O7NOHKVR.js';import {a as a$2}from'./chunk-ONJG6QW6.js';import {b as b$1}from'./chunk-44L64VQ2.js';function M(a){if(!a||typeof a!="object")return false;let t=a;return typeof t.kind=="string"&&t.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let t=a;return t.kind==="notification-batch"?Array.isArray(t.notifications)?t.notifications.filter(M):[]:M(a)?[a]:[]}function X(a,t,i){let c=0;return {accepted:a.filter(_=>{if(!M(_))return c++,false;let S=_;return typeof S.sentAtMs=="number"&&t-S.sentAtMs>i?(c++,false):true}),rejected:c}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let t=a.summary;return !t||typeof t!="object"?false:Number(t.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let t=a;return t.kind==="notification-batch"&&Array.isArray(t.notifications)}function V(a,t){if(t.kind==="status"){z(t.status)&&(a.status=t.status);return}if(t.kind==="computed_values"){a.computedValues[t.cardId]=t.values;return}if(t.kind==="data_object"){a.dataObjects[t.key]=t.payload;return}if(t.kind==="card_refreshed"){a.cards[t.cardId]=t.card;return}t.kind==="card_removed"&&(delete a.cards[t.cardId],delete a.computedValues[t.cardId]);}function Y(a,t){if(W(t)){for(let i of t.notifications)M(i)&&V(a,i);return}M(t)&&V(a,t);}function j(a,t){if(a?.status==="success")return Object.prototype.hasOwnProperty.call(a,"data")?a.data:void 0;throw a?.status==="fail"||a?.status==="error"?Object.assign(new Error(a.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function N(a,t){return j(await a,t)}function T(a$1){let t=a(a$1,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=t.split(".");if(!(i.length>=2&&i.every(g=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(g))))throw Object.assign(new Error("MCP tool requires a card private key with at least two identifier segments (e.g. chat.foundry_thread_id)"),{statusCode:400});return t}function q(a,t){let i=a.__private;for(let c of t.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,c))return {exists:false,value:null};i=i[c];}return {exists:true,value:i}}function ot(a$1){let{boardId:t,bootstrapBoard:i,sseHub:c,onChannelSubscribed:g,onChannelUnsubscribed:_,getMcpFacade:S,getMcpCardStoreFacade:n}=a$1;function f(s){let d=a(s,"board_id");if(!d)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(d!==t)throw Object.assign(new Error(`Unknown board_id: ${d}`),{statusCode:400})}function h(s){let d=a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function w(s){f(s);let d=h(s),e=a(s,"channel_name"),r=a(s,"card_id")||void 0;if(!e)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:e,...r?{cardId:r}:{}}}function R(s){f(s);let d=a(s,"card_id");if(!d)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:d}}async function I(s){await i();let{cardId:d}=R(s),e=h(s);if(!await c.subscribeChat(e,d))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:e,subscribed:true}}}async function u(s){await i();let{cardId:d}=R(s),e=h(s);if(!c.unsubscribeChat(e,d))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:e,subscribed:false}}}async function b(s,d){await i();let{clientId:e,channelName:r,cardId:o}=w(s);if(!c.has(e))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return d?(c.subscribeChannel(e,r,o),g?.(e,r,o?{cardId:o}:{})):(c.unsubscribeChannel(e,r,o),_?.(e,r,o?{cardId:o}:{})),{status:"success",data:{boardId:t,clientId:e,channelName:r,subscribed:d,...o?{cardId:o}:{}}}}async function m(s,d){let{cardId:e}=R(s);return await S().setChatProcessing({cardId:e,active:d}),{status:"success",data:{boardId:t,cardId:e,active:d}}}async function p(s){let{cardId:d}=R(s),e=await S().getChatProcessing({cardId:d});return {status:"success",data:{boardId:t,cardId:d,active:e.active}}}async function y(s){let{cardId:d}=R(s),e=T(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(e.split(".").includes("visible_controlplane_only")){let r=await N(n().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(r.cards)&&r.cards.length>0&&typeof r.cards[0]=="object"&&!Array.isArray(r.cards[0])?r.cards[0]:null,k=o?q(o,"visible_controlplane_only").value:void 0;if(s.value!==k)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:d,key:e}}}return j(await n().patch({params:{id:d,path:`__private.${e}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:d,key:e}}}async function C(s){let{cardId:d}=R(s),e=T(s),r=await N(n().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(r.cards)&&r.cards.length>0&&r.cards[0]&&typeof r.cards[0]=="object"&&!Array.isArray(r.cards[0])?r.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=q(o,e);return {status:"success",data:{boardId:t,cardId:d,key:e,exists:k.exists,value:k.value}}}return {requireCardArgs:R,subscribeChat:I,unsubscribeChat:u,watchChannel:b,setChatProcessing:m,getChatProcessing:p,setCardMeta:y,getCardMeta:C}}function it(a){let{boardId:t,boardContexts:i,readChatRecords:c,getChatProcessing:g}=a,_=Number.isInteger(a.chatBootstrapTailTurns)&&a.chatBootstrapTailTurns>0?a.chatBootstrapTailTurns:1;function S(u){return {role:String(u.role||"system"),text:String(u.text||""),files:Array.isArray(u.files)?u.files:[],...typeof u.turn=="string"&&u.turn?{turn:u.turn}:{}}}function n(u){if(u.length===0)return null;if(u.length===1)return u[0];let b=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],p={};for(let C of m)p[C]=0;for(let C of u){let s=C,d=Array.isArray(s.cards)?s.cards:[];b.push(...d);for(let e of m)p[e]+=Number(s?.summary?.[e]||0);}let y=u[0];return {...y,cards:b,summary:{...y.summary||{},card_count:b.length,...p}}}async function f(){let u=[];for(let b of i)try{let m=await b.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&u.push(m.data);}catch{}return u}async function h(){let b=(await f()).map(m=>m.statusSnapshot).filter(Boolean);if(b.length===0){let m=i.map(p=>p.notification.status).filter(Boolean);return n(m)}return n(b)}async function w(){let u={},b=await f();for(let m of b)Object.assign(u,m.cardRuntimeById||{});if(Object.keys(u).length>0)return u;for(let m of i)for(let[p,y]of Object.entries(m.notification.computedValues)){let C=m.notification.cards[p];u[p]={schema_version:"v1",card_id:p,card_data:C?.card_data??{},computed_values:y??{}};}return u}async function R(){let u={},b=await f();for(let m of b)Object.assign(u,m.dataObjectsByToken||{});if(Object.keys(u).length===0)for(let m of i)Object.assign(u,m.notification.dataObjects||{});return u}async function I(){let u=await f(),b=u.flatMap(C=>Array.isArray(C.cardDefinitions)?C.cardDefinitions:[]),m={},p={};for(let C of u)Object.assign(m,C.dataObjectsByToken||{}),Object.assign(p,C.cardRuntimeById||{});let y={};for(let C of b){if(!C?.id)continue;let s=C.id;try{let d=await c(s,{tailTurns:_}),e=await g(s);(d.length>0||e)&&(y[s]={messages:d.map(r=>S(r)),receiving:!1,processing:e});}catch{}}return {boardId:t,cardDefinitions:b,statusSnapshot:await h(),dataObjectsByToken:m,cardRuntimeById:p,cardChatsByCardId:y}}return {readStatusSnapshot:h,readCardRuntimeArtifacts:w,readDataObjectsByToken:R,buildPublishedRuntimePayload:I}}function K(a){let t=String(a||"").trim();if(!t)return "upload.bin";let i=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (i>=0?t.slice(i+1):t)||"upload.bin"}function ct(a){let{safeCardId:t,artifactsStores:i,cardFileMetadataStore:c,readCardFromStore:g,updateCardLocalOnly:_,writeChatRecord:S}=a;async function n(w){let R=[];try{let I=await g(w);if(!I)return R;let u=c().read(I.card_data&&typeof I.card_data=="object"?I.card_data:null);for(let b of u)R.push(String(b.stored_name??""));}catch{}return R}async function f(w,R,I,u){let b=t(w),m=i(w),p=K(R),y=await n(w),s=`${String(y.length+1).padStart(3,"0")}-${p}`.slice(-36);if(!m.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${w}`),{statusCode:500});return await m.files.putBytes(`${b}/${s}`,new Uint8Array(u),I||"application/octet-stream"),{name:p,stored_name:s,size:u.length,mime_type:I||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function h(w,R,I,u,b){if(!u.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let m=b?.inChat===true,p=await f(w,R,I,u),y=null;if(await _(w,C=>{let s=new Date().toISOString(),d=C.card_data&&typeof C.card_data=="object"?C.card_data:{};C.card_data=d;let e=c().normalizeIncoming([{name:p.name,stored_name:p.stored_name,size:p.size,mime_type:p.mime_type,uploaded_at:p.uploaded_at||s,chat:m}],s);return y=c().merge(d,e).findIndex(o=>o.stored_name===p.stored_name),C}),m&&b?.suppressChatRecordWrite!==true){let C=typeof y=="number"&&y>=0?` #${y}`:"";await S(w,"system",`file uploaded: ${p.name} as ${p.stored_name}${C}`,[],b?.turnId??"");}return {ok:true,file:{...p,...typeof y=="number"&&y>=0?{file_idx:y}:{},chat:m},...typeof y=="number"&&y>=0?{file_idx:y}:{}}}return {uploadCardFile:h,readCardStoredFileNames:n}}function pt(a$1){return {"discover.source-kinds":()=>a$1.discoverSourceKinds(),"inspect.board-runtime-status":()=>a$1.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>a$1.inspectCardDefinitionAndRuntime({cardId:a(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let i=b(t,"tail_turns"),c=b(t,"tail"),g=a(t,"turn_id"),_=t.all_turns===true,S=a(t,"tail_turns_before_id");return a$1.inspectChatMessagesOnCards({cardId:a(t,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...c!==void 0?{tail:c}:{},...g?{turnId:g}:{},..._?{allTurns:true}:{},...S?{tailTurnsBeforeId:S}:{}})},"inspect.file-contents":t=>a$1.inspectFileContents({cardId:a(t,"card_id"),fileIdx:Number(b(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>a$1.preflightValidateCandidateCardDefinition({candidateCardContent:d(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>a$1.preflightMaterializeCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockRequires:d(t,"mock_requires","mock_requires"),mockFetchedSources:d(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>a$1.preflightProbeSingleSourceInCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockProjections:c(t,"mock_projections"),sourceIdx:e(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>a$1.preflightRunSingleSourceInCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockProjections:c(t,"mock_projections"),sourceIdx:e(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>a$1.preflightRunSingleSourceInLiveCard({cardId:a(t,"card_id"),sourceIdx:e(t,"source_idx","source_idx"),mockRequires:d(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>a$1.preflightRunOneCycleWithCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockRequires:c(t,"mock_requires")}),"manage.read-card":t=>a$1.manageReadCard({cardId:a(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let i=a(t,"turn_id");if(!i)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...i?{turn:i}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"stage-ai-failure-message":t=>{let i=a(t,"turn_id"),c=a(t,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!c)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(t,"card_id"),role:"system",text:c,turn:i})},"manage.upsert-card":t=>a$1.manageUpsertCard({cardId:a(t,"card_id"),candidateCardContent:c(t,"candidate_card_content")}),"manage.remove-card":t=>a$1.manageRemoveCard({cardId:a(t,"card_id")})}}function mt(a$1){return {"webhook.process-accumulated":()=>a$1.webhookProcessAccumulated(),"webhook.source-fetch-done":t=>a$1.webhookSourceFetchDone({token:a(t,"token"),ref:a(t,"ref")}),"webhook.source-fetch-failed":t=>a$1.webhookSourceFetchFailed({token:a(t,"token"),reason:a(t,"reason")})}}function ft(a$1){let{boardId:t,uploadCardFile:i,getMcpFacade:c$1,controlplane:g}=a$1;function _(n,f){let h=a(n,"board_id");if(!h)throw Object.assign(new Error(`${f} requires board_id`),{statusCode:400});if(h!==t)throw Object.assign(new Error(`Unknown board_id: ${h}`),{statusCode:400})}function S(n,f){let{cardId:h}=g.requireCardArgs(n),w=a(n,"turn_id");return _(n,f),c$1().manageAddChatAttachment({cardId:h,role:a(n,"role")||"user",...w?{turn:w}:{},files:[{file_name:a(n,"file_name"),content_type:a(n,"content_type")||"application/octet-stream",...typeof n.text=="string"?{text:n.text}:{},...typeof n.base64=="string"?{base64:n.base64}:{},...Array.isArray(n.bytes)?{bytes:n.bytes}:{}}]})}return {"list-runtime-cards":n=>(_(n,"list-runtime-cards"),c$1().listRuntimeCards()),"sse.subscribe-chat":n=>g.subscribeChat(n),"sse.unsubscribe-chat":n=>g.unsubscribeChat(n),"sse.watch-channel":n=>g.watchChannel(n,true),"sse.unwatch-channel":n=>g.watchChannel(n,false),"getstate.is-chat-processing":n=>g.getChatProcessing(n),"setstate.chat-processing-started":n=>g.setChatProcessing(n,true),"setstate.chat-processing-done":n=>g.setChatProcessing(n,false),"getstate.card-private":n=>g.getCardMeta(n),"setstate.card-private":n=>g.setCardMeta(n),"manage.upload-card-file":n=>{let f$1=a(n,"card_id"),h=a(n,"file_name"),w=a(n,"content_type")||"application/octet-stream",R=f(n);if(_(n,"manage.upload-card-file"),!f$1)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!h)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!R)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(f$1,h,w,R,{inChat:false})},"manage.add-chat-attachment":n=>S(n,"manage.add-chat-attachment"),"manage.add-chat-attachement":n=>S(n,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":n=>{let{cardId:f}=g.requireCardArgs(n),h=a(n,"role")||"user",w=a(n,"turn_id");return _(n,"manage.add-chat-entry-and-any-attachments"),c$1().manageAddChatEntryAndAnyAttachments({cardId:f,role:h,...typeof n.text=="string"?{text:n.text}:{},...w?{turn:w}:{},...Array.isArray(n.files)?{files:n.files}:{}})},"manage.patch-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.patch-card"),c$1().managePatchCard({cardId:f,patch:c(n,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.upsert-card"),c$1().manageUpsertCard({cardId:f,candidateCardContent:c(n,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.remove-card"),c$1().manageRemoveCard({cardId:f},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async n=>{let{cardId:f}=g.requireCardArgs(n);return {status:"success",data:{cards:await c$1().adminReadCard({cardId:f})}}},"manage.admin-upsert-card":n=>{let f=a(n,"board_id"),h=a(n,"card_id");if(!f)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!h)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(f!==t)throw Object.assign(new Error(`Unknown board_id: ${f}`),{statusCode:400});return c$1().adminUpsertCard({cardId:h,candidateCardContent:c(n,"candidate_card_content")})}}}function yt(a){let{boardContexts:t,cardOwnerIndex:i,cardContextForCard:c,readStatusSnapshot:g,readDataObjectsByToken:_,readCardRuntimeArtifacts:S,readCardFromStore:n,readCardDefinitions:f,processAccumulatedLaneInternal:h,reportSourceFetched:w,reportSourceFetchFailure:R,uploadCardFile:I,chatStorePublic:u,serverUrl:b,apiBasePath:m}=a;function p(){return t[0]??null}function y(){return {async status(){let e=await g();return e==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:e}},async getOutputsDataObject(e){let r=e?.params?.key;return r?{status:"success",data:(await _())[r]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(e){let r=e?.params?.key;return r?{status:"success",data:(await S())[r]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(e){let r=e?.params?.key;if(!r)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=c(r)??p();return o?o.boardOps.getOutputsFetchedSources({params:{key:r}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(e){let r=e?.params?.id;if(!r)return {status:"fail",error:"removeCard requires params.id"};let o=c(r)??p();return o?o.boardOps.removeCard({params:{id:r}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(e){let r=e?.params?.cardId;if(!r)return {status:"fail",error:"upsertCard requires params.cardId"};let o=c(r)??p();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:r,restart:e.params.restart===true}});if(k.status!=="success")return k;if(a$1(o.boardAdapter)){let P=await h(true);if(P.status!=="success")return P}return k}}}function C(){let e=()=>{let r=p();if(!r?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return r.nonCore};return {describeTaskExecutorCapabilities(r){return e().describeTaskExecutorCapabilities(r)},validateCardPreflight(r){return e().validateCardPreflight(r)},evalCardCompute(r){return e().evalCardCompute(r)},probeSourcePreflight(r){return e().probeSourcePreflight(r)},runSourcePreflight(r){return e().runSourcePreflight(r)},simulateCardCycle(r){return e().simulateCardCycle(r)}}}function s(){return {async get(e){let r=typeof e.params?.id=="string"?e.params.id:void 0;if(r){let o=await n(r);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await f()}}},async set(e){let r=e.body;if(r==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(r)?r:[r];for(let k of o){let P=k,A=typeof P.id=="string"?P.id:"";if(!A)return {status:"fail",error:"each card must have a string `id` field"};let E=i.get(A)??0,D=t[E]??p();if(!D)return {status:"fail",error:"Board context is unavailable"};let L=await D.cardStoreOps.set({body:P});if(L.status!=="success")return L;i.set(A,E);}return {status:"success",data:{count:o.length}}},async del(e){let r=[e.params?.id,...e.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(r.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of r){let k=c(o)??p();if(!k)return {status:"fail",error:"Board context is unavailable"};let P=await k.cardStoreOps.del({params:{id:o}});if(P.status!=="success")return P;i.delete(o);}return {status:"success",data:{count:r.length}}},async patch(e){let r=typeof e.params?.id=="string"?e.params.id:void 0,o=typeof e.params?.path=="string"?e.params.path:void 0;if(!r||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=c(r)??p();return k?k.cardStoreOps.patch(e):{status:"fail",error:"Board context is unavailable"}},async appendFiles(e){let r=typeof e.params?.id=="string"?e.params.id:void 0;if(!r)return {status:"fail",error:"appendFiles requires params.id"};let o=c(r)??p();return o?o.cardStoreOps.appendFiles(e):{status:"fail",error:"Board context is unavailable"}}}}function d(){return a$2({board:y(),nonCore:C(),cardStore:s(),chatStore:u,processAccumulated:()=>h(true),sourceFetchDone:({token:e,ref:r})=>w(e,r),sourceFetchFailed:({token:e,reason:r})=>R(e,r),uploadCardFile({cardId:e,fileName:r,contentType:o,bytes:k,suppressChatRecordWrite:P}){return I(e,r,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:e,fileIdx:r,storedName:o}){let k=`${b||""}${m}/cards/${encodeURIComponent(e)}/files/${r}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:e,ref:r}){let o=c(e)??p();if(!o||a$1(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(b$1(r)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:y,mcpNonCoreFacade:C,mcpCardStoreFacade:s,createMcpFacade:d}}export{J as a,X as b,Q as c,z as d,Y as e,j as f,N as g,T as h,q as i,ot as j,it as k,ct as l,pt as m,mt as n,ft as o,yt as p};//# sourceMappingURL=chunk-F6KRSQ7V.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-F6KRSQ7V.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var chunk66ZZIF2L_cjs=require('./chunk-66ZZIF2L.cjs');function x(s,d){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function Q(s,d){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${d} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function n(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function y(s){return Array.isArray(s)?s:[]}function K(s,d){if(typeof d!="string"||d.length===0)return;let u=s,p=d;p.startsWith("fetched_sources.")&&(u=n(s).fetched_sources,p=p.slice(16));for(let g of p.split(".")){if(u==null||typeof u!="object")return;u=u[g];}return u}function N(s,d){let u=n(s.view);return {elements:y(u.elements).map((g,R)=>{let h=n(g),b=n(h.data),k=n(h.spec),P=typeof h.visible=="string"?!!K(d,h.visible):true,v=typeof b.bind=="string"?b.bind:void 0,T=typeof k.maxRows=="number"?k.maxRows:typeof b.maxRows=="number"?b.maxRows:void 0,L=v?K(d,v):void 0,F={id:typeof h.id=="string"&&h.id?h.id:`element-${R}`,kind:h.kind,label:h.label,visible:P};return L!==void 0&&(F.resolved=Array.isArray(L)&&typeof T=="number"?L.slice(0,T):L),F})}}function X(s,d){let u=typeof s.id=="string"&&s.id?s.id:"card",p=y(s.provides),g=p.length>0?p:[{bindTo:u,ref:"card_data"}],R={};for(let h of g){let b=n(h),k=typeof b.bindTo=="string"?b.bindTo:"",P=typeof b.ref=="string"?b.ref:"";if(!k||!P)continue;let v=K(d,P);v!==void 0&&(R[k]=v);}return R}function be(s){if(typeof s!="string"||!s.trim())return null;let d=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!d)return null;let u=Number.parseInt(d[2],10);return !Number.isInteger(u)||u<0?null:u}function ke(s){return {"card-content":s}}function D(s){let d={...s};return delete d.__private,d}function he(s,d){return Object.prototype.hasOwnProperty.call(s,d)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,d){let u=Re(s);if(!d||Object.keys(d).length===0)return u;function p(g,R,h){let b=String(R||"").split(".").filter(Boolean);if(!b.length)return;let k=g;for(let P=0;P<b.length-1;P+=1){let v=b[P];(!k[v]||typeof k[v]!="object")&&(k[v]={}),k=k[v];}k[b[b.length-1]]=h;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let g=null,R=n(u.view),h=y(R.elements);for(let b of h){let k=n(b),P=n(k.data),v=typeof k.writeTo=="string"&&k.writeTo?k.writeTo:typeof P.writeTo=="string"?P.writeTo:"";if(v){g=v;break}}return g?p(u,g,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(u.card_data={...n(u.card_data),...d.fieldValues}),u}if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return u;for(let[g,R]of Object.entries(d))g!=="_stagedFiles"&&(R!==null&&typeof R=="object"&&!Array.isArray(R)&&u[g]!==null&&typeof u[g]=="object"&&!Array.isArray(u[g])?u[g]={...u[g],...R}:u[g]=R);return u}function $(s){return n(s.__private).visible_controlplane_only===true}async function O(s,d){let u=await S(s.get({params:{id:d}}),"cardStore.get"),p=Array.isArray(u?.cards)?u.cards:[];if(p.length===0)throw new Error(`Card "${d}" not found`);return p[0]}function Ae(s){let{board:d,nonCore:u,cardStore:p,chatStore:g,processAccumulated:R,sourceFetchDone:h,sourceFetchFailed:b,uploadCardFile:k,buildFileDownloadUrl:P,readFetchedSourceJsonByRef:v}=s;function T(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function L(){let e=await S(p.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>n(r)).filter(r=>!$(r)):[]}function F(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),a=atob(t);return Uint8Array.from(a,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=n(await S(u.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:n(e.commonSourceDefFields),sourceKinds:n(e.sourceKinds)}}async function Z(){let e=n(await S(d.status({}),"status")),r=n(e.summary),t=y(e.cards),a=await S(p.get({}),"cardStore.get"),o=new Set((Array.isArray(a.cards)?a.cards.map(n):[]).filter($).map(c=>typeof c.id=="string"?c.id:"").filter(Boolean)),i=t.filter(c=>!o.has(String(n(c).name??"")));return {meta:n(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:i.map(c=>{let l=n(c);return {"card-id":typeof l.name=="string"?l.name:null,status:l.status??null,error:l.error??null,requires:y(l.requires),requires_satisfied:y(l.requires_satisfied),requires_missing:y(l.requires_missing),provides_declared:y(l.provides_declared),provides_runtime:y(l.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=n(await S(d.status({}),"status")),o=y(t.cards).map(n).find(f=>f.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let i=n(await O(p,r)),c=D(i),l=y(o.requires_satisfied).filter(f=>typeof f=="string"&&!!f),A=y(o.provides_runtime).filter(f=>typeof f=="string"&&!!f),_=Object.fromEntries(await Promise.all(l.map(async f=>[f,await S(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),I=Object.fromEntries(await Promise.all(A.map(async f=>[f,await S(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),m=n(await S(d.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),w=await S(d.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),M=y(i.source_defs).map(n),C={};for(let f of M)typeof f.bindTo=="string"&&typeof f.outputFile=="string"&&(C[f.outputFile]=f.bindTo);let U={};for(let[f,j]of Object.entries(w)){let q=C[f]??f;if(!v||typeof j!="string"){U[q]=null;continue}try{U[q]=v({cardId:r,ref:j});}catch{U[q]=null;}}let B={card_data:n(i.card_data),requires:_,fetched_sources:U,computed_values:m};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:c,refs_for_fetched_source_files:w,runtime_data:{requires:_,provides:I,computed_values:m,rendered_view:N(i,B)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",a=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",i=a?void 0:e.lastUserTurns??(t?void 0:1),c=e.tail,l={...i===void 0?{}:{tailTurns:i},...t?{turnId:t}:{},...a?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},A=Object.keys(l).length>0?{params:{cardId:r},body:l}:{params:{cardId:r}},_=x(await g.readAll(A),"chatStore.readAll"),I=n(await O(p,r)),m=y(n(I.card_data).files).map((C,U)=>({idx:U,stored_name:n(C).stored_name})).filter(C=>typeof C.stored_name=="string"&&C.stored_name.length>0),M=(Array.isArray(_.records)?_.records:[]).map(C=>{let B=n(C.payload),f={...C},j=typeof C?.role=="string"?C.role:typeof B.role=="string"?String(B.role):"",q=typeof C?.text=="string"?C.text:typeof B.text=="string"?String(B.text):"";if(j==="system"){let z=be(q);if(z!==null&&m.some(E=>E.idx===z)){let E=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${z}`;f.retrieval_hint=E,Object.keys(B).length>0&&typeof C.role!="string"&&(f.payload={...B,retrieval_hint:E});}}return f});return {cardId:r,messages:typeof c=="number"&&c>=0?M.slice(-c):M}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let a=n(await O(p,r)),o=y(n(a.card_data).files).map(n);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let i=o[t],c=typeof i.stored_name=="string"?i.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:P({cardId:r,fileIdx:t,storedName:c}),...typeof i.name=="string"?{name:i.name}:{},...typeof i.stored_name=="string"?{stored_name:i.stored_name}:{},...typeof i.mime_type=="string"?{mime_type:i.mime_type}:{},...typeof i.size=="number"?{size:i.size}:{},...typeof i.uploaded_at=="string"?{uploaded_at:i.uploaded_at}:{}}}async function V(e){return await u.validateCardPreflight({body:ke(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=u.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=n(Q(r,"evalCardCompute")),a=n(e.candidateCardContent),o={card_data:n(a.card_data),requires:n(e.mockRequires),fetched_sources:n(e.mockFetchedSources),computed_values:n(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof a.id=="string"?a.id:"(unknown)",ok:t.ok===true,computed_values:n(t.computed_values),errors:y(t.errors).map(i=>{let c=n(i);return {bindTo:typeof c.bindTo=="string"?c.bindTo:"",error:typeof c.error=="string"?c.error:""}}),provides_outputs:X(a,o),rendered_view:N(a,o)}}}async function ae(e){return await u.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await u.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=n(await O(p,r)),a=y(t.source_defs).filter(i=>!!i&&typeof i=="object"&&!Array.isArray(i)),o={};if(e.sourceIdx>=0&&e.sourceIdx<a.length){let i=a[e.sourceIdx],c=chunk66ZZIF2L_cjs.a.enrichSourcesSync([i],{card_data:n(t.card_data),requires:e.mockRequires});Array.isArray(c)&&c.length>0&&(o=n(c[0]._projections));}return await u.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=n(await S(u.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=n(e.candidateCardContent),a=n(r.validation),o=y(r.source_probes),i=y(r.projection_errors),c=n(r.fetched_sources),l=y(r.compute_errors),A=n(r.computed_values),_={card_data:n(t.card_data),requires:e.mockRequires,fetched_sources:c,computed_values:A},I=[];for(let m of y(a.issues))typeof m=="string"&&m&&I.push(m);for(let m of o){let w=n(m),M=typeof w.bindTo=="string"?w.bindTo:"source",C=typeof w.error=="string"?w.error:"";C&&I.push(`${M}: ${C}`);}for(let m of i){let w=n(m),M=typeof w.bindTo=="string"?w.bindTo:"source",C=typeof w.key=="string"?w.key:"projection",U=typeof w.error=="string"?w.error:"projection failed";I.push(`${M}.${C}: ${U}`);}for(let m of l){let w=n(m),M=typeof w.bindTo=="string"?w.bindTo:"compute",C=typeof w.error=="string"?w.error:"compute failed";I.push(`${M}: ${C}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:I,provides_outputs:X(t,_),rendered_view:N(t,_)}}}async function W(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await S(p.get({params:{id:r}}),"cardStore.get");return (Array.isArray(t.cards)?t.cards.map(n):[]).map(o=>D(o))}async function J(e){let r=await Promise.all(y(e.files).map(async t=>{let a=n(t),o=String(a.file_name??a.fileName??a.name??"").trim(),i=String(a.content_type??a.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await k({cardId:e.cardId,fileName:o,contentType:i,bytes:F(a),suppressChatRecordWrite:true})}));for(let[t,a]of r.entries()){let o=n(a.file),i=typeof a.file_idx=="number"&&Number.isInteger(a.file_idx)&&a.file_idx>=0?a.file_idx:t,c=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`;x(await g.append({params:{cardId:e.cardId},body:{role:"system",text:c,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}return r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",a=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await J({cardId:r,role:t,turn:a,files:e.files});return {status:"success",data:{cardId:r,turn:a,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),a=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let l=x(await g.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),A=Array.isArray(l.records)?l.records.find(_=>_.role==="assistant"&&String(_.turn||"")===o):void 0;if(A)return {status:"success",data:{cardId:r,id:String(A.id),role:t,turn:o,files:Array.isArray(A.files)?A.files:[]}}}let i=await J({cardId:r,role:t,turn:o,files:e.files}),c=x(await g.append({params:{cardId:r},body:{role:t,text:a,files:i,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(c.id),role:t,turn:o,files:i}}}async function ue(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.patch);if(!t)throw new Error("managePatchCard requires cardId");let o=await W({cardId:t}),i=n(o[0]),c=ve(i,a);return H({cardId:t,candidateCardContent:c},r)}async function H(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.candidateCardContent),o=D(a);if(!t)throw new Error("manageUpsertCard requires cardId");if(typeof o.id!="string"||!o.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(o.id!==t)throw new Error(`candidateCardContent.id must match cardId (${t})`);let i=null;try{i=await V({candidateCardContent:o});}catch(m){let w=m instanceof Error?m.message:String(m);if(!/non-core adapter is not configured/i.test(w))throw m;i=null;}if(i!==null){let m=n(i),w=n(m.data);if(m.status!=="success"||w.isValid!==true)return {status:"fail",step:"validate",validation:i}}let c=null;try{c=await O(p,t);}catch{c=null;}let l=c?n(c):null;if(l&&$(l)&&!r.allowControlplaneOnlyCards)throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404});let A={...o,...l&&he(l,"__private")?{__private:l.__private}:{}},_=await p.set({body:A});x(_,"cardStore.set");let I;try{I=await d.upsertCard({params:{cardId:t,restart:!0}}),x(I,"upsertCard");}catch(m){try{c&&await p.set({body:c});}catch{}throw m}return {status:"success",data:{validation:i,card_saved:null,board_result:I}}}async function le(e,r={}){let t=String(e.cardId||"").trim();if(!t)throw new Error("manageRemoveCard requires cardId");if(!r.allowControlplaneOnlyCards){let i=await S(p.get({params:{id:t}}),"cardStore.get");if((Array.isArray(i.cards)?i.cards.map(n):[]).some($))throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404})}let a=await d.removeCard({params:{id:t}});x(a,"removeCard");let o=await p.del({params:{id:t}});return x(o,"cardStore.del"),{status:"success",data:{board_result:a,store_result:o}}}async function pe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await S(p.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(a=>n(a)):[]}async function me(e){let r=String(e.cardId||"").trim(),t=n(e.candidateCardContent),a=D(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof a.id!="string"||!a.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(a.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await V({candidateCardContent:a}),i=n(o),c=n(i.data);if(i.status!=="success"||c.isValid!==true)return {status:"fail",step:"validate",validation:o};let l=null;try{l=await O(p,r);}catch{l=null;}let A=l?n(n(l).__private):{},_={...a,__private:{...A,visible_controlplane_only:true}},I=await p.set({body:_});x(I,"cardStore.set");let m;try{m=await d.upsertCard({params:{cardId:r,restart:!0}}),x(m,"upsertCard");}catch(w){try{l&&await p.set({body:l});}catch{}throw w}return {status:"success",data:{validation:o,card_saved:null,board_result:m}}}async function fe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=Q(await g.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}async function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return x(await g.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function we(){let e=await T(R,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function Ce(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let a=await T(h,"webhook.source-fetch-done")({token:r,ref:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let a=await T(b,"webhook.source-fetch-failed")({token:r,reason:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}return {listRuntimeCards:L,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:V,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:W,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:H,manageRemoveCard:le,adminReadCard:pe,adminUpsertCard:me,getChatProcessing:fe,setChatProcessing:ge,webhookProcessAccumulated:we,webhookSourceFetchDone:Ce,webhookSourceFetchFailed:ye}}async function S(s,d){return x(await s,d)}exports.a=Ae;//# sourceMappingURL=chunk-G5UUXBIB.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-G5UUXBIB.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {c,n,m,l as l$1,k,j,i as i$1,h as h$1,g as g$1,f,e,d,t}from'./chunk-FULAMLUU.js';import {i,a,g,h,l}from'./chunk-R7SQQSDX.js';import {a as a$1}from'./chunk-YOY2JM5N.js';import {exec,execFile}from'child_process';function z(s){let{config:e,state:o}=s,a$1=i(e),i$1=Object.keys(a$1),d=0,c=0,l=0,f=0,t=0,r=0;for(let h of i$1){let T=o.tasks[h];if(!T||T.status===a.NOT_STARTED)t++;else switch(T.status){case a.RUNNING:d++;break;case a.COMPLETED:c++;break;case a.FAILED:l++;break;case "inactivated":r++;break;default:f++;}}let n={};for(let[h,T]of Object.entries(a$1)){for(let R of g(T))n[R]||(n[R]=[]),n[R].push(h);if(T.on)for(let R of Object.values(T.on))for(let g of R)n[g]||(n[g]=[]),n[g].includes(h)||n[g].push(h);if(T.on_failure)for(let R of T.on_failure)n[R]||(n[R]=[]),n[R].includes(h)||n[R].push(h);}let u=new Set,p=0,k=0;for(let[h$1,T]of Object.entries(a$1)){let R=o.tasks[h$1];if(R?.status===a.COMPLETED||R?.status===a.RUNNING)continue;let g=false,H=false;for(let x of h(T)){let q=n[x]||[];q.length===0?(u.add(x),g=true):q.every(Y=>{let W=o.tasks[Y];return W?.status===a.FAILED||W?.status==="inactivated"})&&(H=true);}g&&p++,H&&!g&&k++;}let m=[];for(let[h,T]of Object.entries(n))T.length>1&&m.push(h);let v=Q(a$1,n),b=Z(i$1,v);return {totalNodes:i$1.length,running:d,completed:c,failed:l,waiting:f,notStarted:t,disabled:r,unresolvedCount:p,blockedCount:k,openDependencies:[...u],cycles:b,conflictTokens:m}}function Q(s,e){let o={};for(let[a,i]of Object.entries(s)){o[a]=new Set;for(let d of h(i))for(let c of e[d]||[])c!==a&&o[a].add(c);}return o}function Z(s,e){let d={},c={},l=[];for(let t of s)d[t]=0,c[t]=null;function f(t){d[t]=1;for(let r of e[t]||[])if(d[r]===1){let n=[r],u=t;for(;u!==r;)n.push(u),u=c[u];n.push(r),n.reverse(),l.push(n);}else d[r]===0&&(c[r]=t,f(r));d[t]=2;}for(let t of s)d[t]===0&&f(t);return l}function B(s){let e={};for(let[o,a]of Object.entries(s)){for(let i of g(a))e[i]||(e[i]=[]),e[i].push(o);if(a.on)for(let i of Object.values(a.on))for(let d of i)e[d]||(e[d]=[]),e[d].includes(o)||e[d].push(o);if(a.on_failure)for(let i of a.on_failure)e[i]||(e[i]=[]),e[i].includes(o)||e[i].push(o);}return e}function V(s){let{config:e,state:o}=s,a=i(e),i$1=B(a),d=new Set([...o.availableOutputs]);for(let[n,u]of Object.entries(o.tasks))if(u.status==="completed"){let p=a[n];p&&g(p).forEach(k=>d.add(k));}let c=new Set;for(let n of Object.values(a))for(let u of h(n))c.add(u);let l$1=new Set,f=new Set;for(let n of c){if(d.has(n))continue;(i$1[n]||[]).length===0&&l$1.add(n);}let t=true;for(;t;){t=false;for(let[n,u]of Object.entries(a)){if(f.has(n))continue;let p=o.tasks[n];if(p?.status==="completed")continue;let k=l(p),v=h(u).some(b=>l$1.has(b));(k||v)&&(f.has(n)||(f.add(n),t=true));}for(let n of c){if(l$1.has(n)||d.has(n))continue;let u=i$1[n]||[],p=u.length>0&&u.every(k=>f.has(k)||l(o.tasks[k]));(u.length===0||p)&&(l$1.has(n)||(l$1.add(n),t=true));}}let r=[];for(let n of l$1){let u=i$1[n]||[],p;u.length===0?p="no-producer":p=u.every(m=>l(o.tasks[m]))?"all-producers-failed":"transitive",r.push({token:n,reason:p,producers:u});}return {tokens:r}}function ee(s){let{config:e,state:o}=s,a=i(e),{tokens:i$1}=V(s),d=new Set(i$1.map(l=>l.token)),c=[];for(let[l$1,f]of Object.entries(a)){let t=o.tasks[l$1];if(t?.status==="completed")continue;let n=h(f).filter(u=>d.has(u));n.length>0?c.push({nodeName:l$1,missingTokens:n}):l(t)&&c.push({nodeName:l$1,missingTokens:[]});}return {nodes:c}}function te(s,e){let o=i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a=B(o),i$1=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of h(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i$1.has(p)||(i$1.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,providesTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function ne(s,e){let o=i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a={};for(let[t,r]of Object.entries(o))for(let n of h(r))a[n]||(a[n]=[]),a[n].push(t);let i$1=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of g(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i$1.has(p)||(i$1.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,requiresTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function K(s){let e=[],{config:o,state:a$1}=s,i$1=i(o),d=Object.keys(i$1);for(let t of d)a$1.tasks[t]||e.push({severity:"error",code:"MISSING_STATE",message:`Task "${t}" exists in config but has no state entry`,tasks:[t]});for(let t of Object.keys(a$1.tasks))i$1[t]||e.push({severity:"warning",code:"ORPHAN_STATE",message:`State entry "${t}" has no corresponding task config`,tasks:[t]});for(let t of d){let r=a$1.tasks[t];r&&(r.status===a.RUNNING&&!r.startedAt&&e.push({severity:"warning",code:"RUNNING_WITHOUT_START",message:`Task "${t}" is running but has no startedAt timestamp`,tasks:[t]}),r.status===a.COMPLETED&&!r.completedAt&&e.push({severity:"warning",code:"COMPLETED_WITHOUT_TIMESTAMP",message:`Task "${t}" is completed but has no completedAt timestamp`,tasks:[t]}),r.status===a.FAILED&&(r.failedAt||e.push({severity:"warning",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no failedAt timestamp`,tasks:[t]}),r.error||e.push({severity:"info",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no error message`,tasks:[t]})));}let c=new Set;for(let t of d)if(a$1.tasks[t]?.status===a.COMPLETED)for(let n of g(i$1[t]))c.add(n);let l=new Set(a$1.availableOutputs),f=new Set;for(let t of Object.values(i$1)){for(let r of g(t))f.add(r);if(t.on)for(let r of Object.values(t.on))for(let n of r)f.add(n);if(t.on_failure)for(let r of t.on_failure)f.add(r);}for(let t of l)!c.has(t)&&!f.has(t)&&e.push({severity:"info",code:"INJECTED_TOKEN",message:`Token "${t}" is available but no task in the graph can produce it (likely injected)`,tokens:[t]});for(let t of c)l.has(t)||e.push({severity:"warning",code:"MISSING_OUTPUT",message:`Token "${t}" should be available (its producer completed) but is not in availableOutputs`,tokens:[t]});for(let t of d){let r=a$1.tasks[t];if(!r)continue;r.executionCount<0&&e.push({severity:"error",code:"INVALID_EXECUTION_COUNT",message:`Task "${t}" has negative execution count: ${r.executionCount}`,tasks:[t]});let n=i$1[t].maxExecutions;n!==void 0&&r.executionCount>n&&e.push({severity:"error",code:"EXCEEDED_MAX_EXECUTIONS",message:`Task "${t}" executed ${r.executionCount} times, exceeding maxExecutions of ${n}`,tasks:[t]});}return J(e)}function se(s){let{graph:e,handlers:o}=s,a=e.getState(),i$1=[],d=i(a.config),c=Object.keys(d),l=new Set(Object.keys(o)),f=new Set;for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)f.add(u);}for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)o[u]||i$1.push({severity:"error",code:"MISSING_HANDLER",message:`Task "${r}" references handler "${u}" but it is not in the registry`,tasks:[r]});}for(let r of l)f.has(r)||i$1.push({severity:"warning",code:"ORPHAN_HANDLER",message:`Handler "${r}" is registered but not referenced by any task's taskHandlers`,tasks:[r]});let t=K(a);return i$1.push(...t.issues),J(i$1)}function J(s){let e=s.filter(a=>a.severity==="error"),o=s.filter(a=>a.severity==="warning");return {valid:e.length===0,issues:s,errors:e,warnings:o}}function re(s,e){let o=s;for(let a of e)o=oe(o,a);return o}function oe(s,e$1){switch(e$1.type){case "add-node":return d(s,e$1.name,e$1.config);case "remove-node":return e(s,e$1.name);case "add-requires":return f(s,e$1.taskName,e$1.tokens);case "remove-requires":return g$1(s,e$1.taskName,e$1.tokens);case "add-provides":return h$1(s,e$1.taskName,e$1.tokens);case "remove-provides":return i$1(s,e$1.taskName,e$1.tokens);case "inject-tokens":return j(s,e$1.tokens);case "drain-tokens":return k(s,e$1.tokens);case "reset-node":return l$1(s,e$1.name);case "disable-node":return m(s,e$1.name);case "enable-node":return n(s,e$1.name);case "apply-events":return c(s,e$1.events);default:throw new Error(`Unknown mutation type: ${e$1.type}`)}}function ce(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(i=>e()(a,i)).catch(i=>e()(a,{},[i instanceof Error?i.message:String(i)])),"task-initiated"}}function de(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(()=>e()(a,{})).catch(()=>e()(a,{})),"task-initiated"}}function ue(s){let{command:e,cwd:o,env:a,timeoutMs:i=3e4,exitCodeMap:d,captureOutput:c=false,getResolve:l}=s;return async f=>{let{callbackToken:t,nodeId:r}=f,n=e.replace(/\$\{taskName\}/g,r);return exec(n,{cwd:o,env:a?{...process.env,...a}:void 0,timeout:i,maxBuffer:10*1024*1024},(u,p,k)=>{let m=u?.code??(u?1:0);if(m!==0&&!d?.[m]){l()(t,{},[`Command exited with code ${m}: ${k||u?.message}`]);return}let v={};c&&(v.stdout=p,v.stderr=k,v.exitCode=m),l()(t,v);}),"task-initiated"}}function X(s){let{command:e,args:o=[],cwd:a,env:i,timeoutMs:d=3e4,exitCodeMap:c,captureOutput:l=false,getResolve:f}=s;return async t=>{let{callbackToken:r,nodeId:n}=t,u=e.replace(/\$\{taskName\}/g,n),p=o.map(k=>k.replace(/\$\{taskName\}/g,n));return execFile(u,p,{cwd:a,env:i?{...process.env,...i}:void 0,timeout:d,maxBuffer:10*1024*1024,encoding:"utf8",windowsHide:true},(k,m,v)=>{let b=k?.code??(k?1:0);if(b!==0&&!c?.[b]){f()(r,{},[`Process exited with code ${b}: ${v||k?.message}`]);return}let h={};l&&(h.stdout=m,h.stderr=v,h.exitCode=b),f()(r,h);}),"task-initiated"}}function le(s){return s.endsWith(".js")||s.endsWith(".mjs")||s.endsWith(".ts")?"node":s.endsWith(".py")?"python3":(s.endsWith(".sh"),"bash")}function pe(s){let{scriptPath:e,runtime:o,args:a=[],cwd:i,timeoutMs:d=6e4,captureOutput:c=false,getResolve:l}=s,f=o??le(e),t=f==="node"?process.execPath:f;return X({command:t,args:[e,"${taskName}",...a],cwd:i,timeoutMs:d,captureOutput:c,getResolve:l})}function fe(s){let{url:e,method:o="POST",headers:a={},timeoutMs:i=3e4,failOnNon2xx:d=true,getResolve:c}=s;return async l=>{let{callbackToken:f,nodeId:t,config:r}=l,n=e.replace(/\$\{taskName\}/g,t),u=JSON.stringify({taskName:t,callbackToken:f,config:r}),p=new AbortController,k=setTimeout(()=>p.abort(),i);return fetch(n,{method:o,headers:{"Content-Type":"application/json",...a},body:u,signal:p.signal}).then(async m=>{if(clearTimeout(k),d&&!m.ok){let b=await m.text().catch(()=>"");c()(f,{},[`HTTP ${m.status}: ${b}`]);return}let v=await m.json().catch(()=>({}));c()(f,v);}).catch(m=>{clearTimeout(k),c()(f,{},[m instanceof Error?m.message:String(m)]);}),"task-initiated"}}function ge(s,e){return async o=>(s()(o.callbackToken,e??{}),"task-initiated")}function ke(s,e={}){let o,a={},i;if(!Array.isArray(s)&&"nodes"in s){let g=s;o=g.nodes,i=g.id,a=g.settings??{};}else o=s;let{sourceHandlers:d={},defaultSourceHandler:c,cardHandlers:l={},reactiveOptions:f={},graphSettings:t$1={},executionId:r}=e,n=new Map;for(let g of o){if(n.has(g.id))throw new Error(`Duplicate card ID: "${g.id}"`);n.set(g.id,g);}let u=e.sharedState??new Map,p={},k=new Set,m=new Map;for(let g of o)for(let H of g.provides??[{bindTo:g.id,ref:"card_data"}])k.add(H.bindTo),m.set(H.bindTo,g.id);for(let g of o){let H=g.requires??[];for(let x of H)if(!k.has(x))throw new Error(`Card "${g.id}" requires "${x}" but no card provides that token`);p[g.id]={requires:H.length>0?H:void 0,provides:(g.provides??[{bindTo:g.id,ref:"card_data"}]).map(x=>x.bindTo),taskHandlers:[g.id],description:g.meta?.title??g.id};}let v={id:i??`live-cards-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...a,...t$1},tasks:p},b={},h=null,T=()=>(g,H,x)=>{h.resolveCallback(g,H,x);};for(let g of o)g.source_defs&&g.source_defs.length>0?b[g.id]=me(g,d,c,u,T):b[g.id]=he(g,l,u,n,m,T);let R=t(v,{...f,handlers:b},r);return h=R,{graph:R,config:v,handlers:b,cards:n,sharedState:u}}function me(s,e,o,a,i){if(e[s.id]){let d=e[s.id];return async c=>d(c)}if(o){let d=o(s);return async c=>d(c)}return async d=>{let c={...s.card_data};return a.set(s.id,c),i()(d.callbackToken,c),"task-initiated"}}function he(s,e,o,a,i,d){if(e[s.id]){let c=e[s.id];return async l=>c(l)}return async c=>{let l={},f=s.requires??[];for(let u of f){let p=i.get(u)??u,k=o.get(p);k&&(l[u]=k[u]??k);}let t={id:s.id,card_data:{...s.card_data},requires:l,compute:s.compute};await a$1.run(t);let r;if(s.provides&&s.provides.length>0){r={};for(let{bindTo:u,ref:p}of s.provides)r[u]=a$1.resolve(t,p);}else r={...t.card_data,...t.computed_values};let n={...t.card_data,...t.computed_values};return o.set(s.id,n),d()(c.callbackToken,r),"task-initiated"}}export{z as a,V as b,ee as c,te as d,ne as e,K as f,se as g,re as h,ce as i,de as j,ue as k,X as l,pe as m,fe as n,ge as o,ke as p};//# sourceMappingURL=chunk-ROIYEFSE.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {c,n,m,l as l$1,k,j,i as i$1,h as h$1,g as g$1,f,e,d,t}from'./chunk-FULAMLUU.js';import {i,a,g,h,l}from'./chunk-R7SQQSDX.js';import {a as a$1}from'./chunk-QE3QXEHI.js';import {exec,execFile}from'child_process';function z(s){let{config:e,state:o}=s,a$1=i(e),i$1=Object.keys(a$1),d=0,c=0,l=0,f=0,t=0,r=0;for(let h of i$1){let T=o.tasks[h];if(!T||T.status===a.NOT_STARTED)t++;else switch(T.status){case a.RUNNING:d++;break;case a.COMPLETED:c++;break;case a.FAILED:l++;break;case "inactivated":r++;break;default:f++;}}let n={};for(let[h,T]of Object.entries(a$1)){for(let R of g(T))n[R]||(n[R]=[]),n[R].push(h);if(T.on)for(let R of Object.values(T.on))for(let g of R)n[g]||(n[g]=[]),n[g].includes(h)||n[g].push(h);if(T.on_failure)for(let R of T.on_failure)n[R]||(n[R]=[]),n[R].includes(h)||n[R].push(h);}let u=new Set,p=0,k=0;for(let[h$1,T]of Object.entries(a$1)){let R=o.tasks[h$1];if(R?.status===a.COMPLETED||R?.status===a.RUNNING)continue;let g=false,H=false;for(let x of h(T)){let q=n[x]||[];q.length===0?(u.add(x),g=true):q.every(Y=>{let W=o.tasks[Y];return W?.status===a.FAILED||W?.status==="inactivated"})&&(H=true);}g&&p++,H&&!g&&k++;}let m=[];for(let[h,T]of Object.entries(n))T.length>1&&m.push(h);let v=Q(a$1,n),b=Z(i$1,v);return {totalNodes:i$1.length,running:d,completed:c,failed:l,waiting:f,notStarted:t,disabled:r,unresolvedCount:p,blockedCount:k,openDependencies:[...u],cycles:b,conflictTokens:m}}function Q(s,e){let o={};for(let[a,i]of Object.entries(s)){o[a]=new Set;for(let d of h(i))for(let c of e[d]||[])c!==a&&o[a].add(c);}return o}function Z(s,e){let d={},c={},l=[];for(let t of s)d[t]=0,c[t]=null;function f(t){d[t]=1;for(let r of e[t]||[])if(d[r]===1){let n=[r],u=t;for(;u!==r;)n.push(u),u=c[u];n.push(r),n.reverse(),l.push(n);}else d[r]===0&&(c[r]=t,f(r));d[t]=2;}for(let t of s)d[t]===0&&f(t);return l}function B(s){let e={};for(let[o,a]of Object.entries(s)){for(let i of g(a))e[i]||(e[i]=[]),e[i].push(o);if(a.on)for(let i of Object.values(a.on))for(let d of i)e[d]||(e[d]=[]),e[d].includes(o)||e[d].push(o);if(a.on_failure)for(let i of a.on_failure)e[i]||(e[i]=[]),e[i].includes(o)||e[i].push(o);}return e}function V(s){let{config:e,state:o}=s,a=i(e),i$1=B(a),d=new Set([...o.availableOutputs]);for(let[n,u]of Object.entries(o.tasks))if(u.status==="completed"){let p=a[n];p&&g(p).forEach(k=>d.add(k));}let c=new Set;for(let n of Object.values(a))for(let u of h(n))c.add(u);let l$1=new Set,f=new Set;for(let n of c){if(d.has(n))continue;(i$1[n]||[]).length===0&&l$1.add(n);}let t=true;for(;t;){t=false;for(let[n,u]of Object.entries(a)){if(f.has(n))continue;let p=o.tasks[n];if(p?.status==="completed")continue;let k=l(p),v=h(u).some(b=>l$1.has(b));(k||v)&&(f.has(n)||(f.add(n),t=true));}for(let n of c){if(l$1.has(n)||d.has(n))continue;let u=i$1[n]||[],p=u.length>0&&u.every(k=>f.has(k)||l(o.tasks[k]));(u.length===0||p)&&(l$1.has(n)||(l$1.add(n),t=true));}}let r=[];for(let n of l$1){let u=i$1[n]||[],p;u.length===0?p="no-producer":p=u.every(m=>l(o.tasks[m]))?"all-producers-failed":"transitive",r.push({token:n,reason:p,producers:u});}return {tokens:r}}function ee(s){let{config:e,state:o}=s,a=i(e),{tokens:i$1}=V(s),d=new Set(i$1.map(l=>l.token)),c=[];for(let[l$1,f]of Object.entries(a)){let t=o.tasks[l$1];if(t?.status==="completed")continue;let n=h(f).filter(u=>d.has(u));n.length>0?c.push({nodeName:l$1,missingTokens:n}):l(t)&&c.push({nodeName:l$1,missingTokens:[]});}return {nodes:c}}function te(s,e){let o=i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a=B(o),i$1=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of h(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i$1.has(p)||(i$1.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,providesTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function ne(s,e){let o=i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a={};for(let[t,r]of Object.entries(o))for(let n of h(r))a[n]||(a[n]=[]),a[n].push(t);let i$1=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of g(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i$1.has(p)||(i$1.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,requiresTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function K(s){let e=[],{config:o,state:a$1}=s,i$1=i(o),d=Object.keys(i$1);for(let t of d)a$1.tasks[t]||e.push({severity:"error",code:"MISSING_STATE",message:`Task "${t}" exists in config but has no state entry`,tasks:[t]});for(let t of Object.keys(a$1.tasks))i$1[t]||e.push({severity:"warning",code:"ORPHAN_STATE",message:`State entry "${t}" has no corresponding task config`,tasks:[t]});for(let t of d){let r=a$1.tasks[t];r&&(r.status===a.RUNNING&&!r.startedAt&&e.push({severity:"warning",code:"RUNNING_WITHOUT_START",message:`Task "${t}" is running but has no startedAt timestamp`,tasks:[t]}),r.status===a.COMPLETED&&!r.completedAt&&e.push({severity:"warning",code:"COMPLETED_WITHOUT_TIMESTAMP",message:`Task "${t}" is completed but has no completedAt timestamp`,tasks:[t]}),r.status===a.FAILED&&(r.failedAt||e.push({severity:"warning",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no failedAt timestamp`,tasks:[t]}),r.error||e.push({severity:"info",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no error message`,tasks:[t]})));}let c=new Set;for(let t of d)if(a$1.tasks[t]?.status===a.COMPLETED)for(let n of g(i$1[t]))c.add(n);let l=new Set(a$1.availableOutputs),f=new Set;for(let t of Object.values(i$1)){for(let r of g(t))f.add(r);if(t.on)for(let r of Object.values(t.on))for(let n of r)f.add(n);if(t.on_failure)for(let r of t.on_failure)f.add(r);}for(let t of l)!c.has(t)&&!f.has(t)&&e.push({severity:"info",code:"INJECTED_TOKEN",message:`Token "${t}" is available but no task in the graph can produce it (likely injected)`,tokens:[t]});for(let t of c)l.has(t)||e.push({severity:"warning",code:"MISSING_OUTPUT",message:`Token "${t}" should be available (its producer completed) but is not in availableOutputs`,tokens:[t]});for(let t of d){let r=a$1.tasks[t];if(!r)continue;r.executionCount<0&&e.push({severity:"error",code:"INVALID_EXECUTION_COUNT",message:`Task "${t}" has negative execution count: ${r.executionCount}`,tasks:[t]});let n=i$1[t].maxExecutions;n!==void 0&&r.executionCount>n&&e.push({severity:"error",code:"EXCEEDED_MAX_EXECUTIONS",message:`Task "${t}" executed ${r.executionCount} times, exceeding maxExecutions of ${n}`,tasks:[t]});}return J(e)}function se(s){let{graph:e,handlers:o}=s,a=e.getState(),i$1=[],d=i(a.config),c=Object.keys(d),l=new Set(Object.keys(o)),f=new Set;for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)f.add(u);}for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)o[u]||i$1.push({severity:"error",code:"MISSING_HANDLER",message:`Task "${r}" references handler "${u}" but it is not in the registry`,tasks:[r]});}for(let r of l)f.has(r)||i$1.push({severity:"warning",code:"ORPHAN_HANDLER",message:`Handler "${r}" is registered but not referenced by any task's taskHandlers`,tasks:[r]});let t=K(a);return i$1.push(...t.issues),J(i$1)}function J(s){let e=s.filter(a=>a.severity==="error"),o=s.filter(a=>a.severity==="warning");return {valid:e.length===0,issues:s,errors:e,warnings:o}}function re(s,e){let o=s;for(let a of e)o=oe(o,a);return o}function oe(s,e$1){switch(e$1.type){case "add-node":return d(s,e$1.name,e$1.config);case "remove-node":return e(s,e$1.name);case "add-requires":return f(s,e$1.taskName,e$1.tokens);case "remove-requires":return g$1(s,e$1.taskName,e$1.tokens);case "add-provides":return h$1(s,e$1.taskName,e$1.tokens);case "remove-provides":return i$1(s,e$1.taskName,e$1.tokens);case "inject-tokens":return j(s,e$1.tokens);case "drain-tokens":return k(s,e$1.tokens);case "reset-node":return l$1(s,e$1.name);case "disable-node":return m(s,e$1.name);case "enable-node":return n(s,e$1.name);case "apply-events":return c(s,e$1.events);default:throw new Error(`Unknown mutation type: ${e$1.type}`)}}function ce(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(i=>e()(a,i)).catch(i=>e()(a,{},[i instanceof Error?i.message:String(i)])),"task-initiated"}}function de(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(()=>e()(a,{})).catch(()=>e()(a,{})),"task-initiated"}}function ue(s){let{command:e,cwd:o,env:a,timeoutMs:i=3e4,exitCodeMap:d,captureOutput:c=false,getResolve:l}=s;return async f=>{let{callbackToken:t,nodeId:r}=f,n=e.replace(/\$\{taskName\}/g,r);return exec(n,{cwd:o,env:a?{...process.env,...a}:void 0,timeout:i,maxBuffer:10*1024*1024},(u,p,k)=>{let m=u?.code??(u?1:0);if(m!==0&&!d?.[m]){l()(t,{},[`Command exited with code ${m}: ${k||u?.message}`]);return}let v={};c&&(v.stdout=p,v.stderr=k,v.exitCode=m),l()(t,v);}),"task-initiated"}}function X(s){let{command:e,args:o=[],cwd:a,env:i,timeoutMs:d=3e4,exitCodeMap:c,captureOutput:l=false,getResolve:f}=s;return async t=>{let{callbackToken:r,nodeId:n}=t,u=e.replace(/\$\{taskName\}/g,n),p=o.map(k=>k.replace(/\$\{taskName\}/g,n));return execFile(u,p,{cwd:a,env:i?{...process.env,...i}:void 0,timeout:d,maxBuffer:10*1024*1024,encoding:"utf8",windowsHide:true},(k,m,v)=>{let b=k?.code??(k?1:0);if(b!==0&&!c?.[b]){f()(r,{},[`Process exited with code ${b}: ${v||k?.message}`]);return}let h={};l&&(h.stdout=m,h.stderr=v,h.exitCode=b),f()(r,h);}),"task-initiated"}}function le(s){return s.endsWith(".js")||s.endsWith(".mjs")||s.endsWith(".ts")?"node":s.endsWith(".py")?"python3":(s.endsWith(".sh"),"bash")}function pe(s){let{scriptPath:e,runtime:o,args:a=[],cwd:i,timeoutMs:d=6e4,captureOutput:c=false,getResolve:l}=s,f=o??le(e),t=f==="node"?process.execPath:f;return X({command:t,args:[e,"${taskName}",...a],cwd:i,timeoutMs:d,captureOutput:c,getResolve:l})}function fe(s){let{url:e,method:o="POST",headers:a={},timeoutMs:i=3e4,failOnNon2xx:d=true,getResolve:c}=s;return async l=>{let{callbackToken:f,nodeId:t,config:r}=l,n=e.replace(/\$\{taskName\}/g,t),u=JSON.stringify({taskName:t,callbackToken:f,config:r}),p=new AbortController,k=setTimeout(()=>p.abort(),i);return fetch(n,{method:o,headers:{"Content-Type":"application/json",...a},body:u,signal:p.signal}).then(async m=>{if(clearTimeout(k),d&&!m.ok){let b=await m.text().catch(()=>"");c()(f,{},[`HTTP ${m.status}: ${b}`]);return}let v=await m.json().catch(()=>({}));c()(f,v);}).catch(m=>{clearTimeout(k),c()(f,{},[m instanceof Error?m.message:String(m)]);}),"task-initiated"}}function ge(s,e){return async o=>(s()(o.callbackToken,e??{}),"task-initiated")}function ke(s,e={}){let o,a={},i;if(!Array.isArray(s)&&"nodes"in s){let g=s;o=g.nodes,i=g.id,a=g.settings??{};}else o=s;let{sourceHandlers:d={},defaultSourceHandler:c,cardHandlers:l={},reactiveOptions:f={},graphSettings:t$1={},executionId:r}=e,n=new Map;for(let g of o){if(n.has(g.id))throw new Error(`Duplicate card ID: "${g.id}"`);n.set(g.id,g);}let u=e.sharedState??new Map,p={},k=new Set,m=new Map;for(let g of o)for(let H of g.provides??[{bindTo:g.id,ref:"card_data"}])k.add(H.bindTo),m.set(H.bindTo,g.id);for(let g of o){let H=g.requires??[];for(let x of H)if(!k.has(x))throw new Error(`Card "${g.id}" requires "${x}" but no card provides that token`);p[g.id]={requires:H.length>0?H:void 0,provides:(g.provides??[{bindTo:g.id,ref:"card_data"}]).map(x=>x.bindTo),taskHandlers:[g.id],description:g.meta?.title??g.id};}let v={id:i??`live-cards-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...a,...t$1},tasks:p},b={},h=null,T=()=>(g,H,x)=>{h.resolveCallback(g,H,x);};for(let g of o)g.source_defs&&g.source_defs.length>0?b[g.id]=me(g,d,c,u,T):b[g.id]=he(g,l,u,n,m,T);let R=t(v,{...f,handlers:b},r);return h=R,{graph:R,config:v,handlers:b,cards:n,sharedState:u}}function me(s,e,o,a,i){if(e[s.id]){let d=e[s.id];return async c=>d(c)}if(o){let d=o(s);return async c=>d(c)}return async d=>{let c={...s.card_data};return a.set(s.id,c),i()(d.callbackToken,c),"task-initiated"}}function he(s,e,o,a,i,d){if(e[s.id]){let c=e[s.id];return async l=>c(l)}return async c=>{let l={},f=s.requires??[];for(let u of f){let p=i.get(u)??u,k=o.get(p);k&&(l[u]=k[u]??k);}let t={id:s.id,card_data:{...s.card_data},requires:l,compute:s.compute};await a$1.run(t);let r;if(s.provides&&s.provides.length>0){r={};for(let{bindTo:u,ref:p}of s.provides)r[u]=a$1.resolve(t,p);}else r={...t.card_data,...t.computed_values};let n={...t.card_data,...t.computed_values};return o.set(s.id,n),d()(c.callbackToken,r),"task-initiated"}}export{z as a,V as b,ee as c,te as d,ne as e,K as f,se as g,re as h,ce as i,de as j,ue as k,X as l,pe as m,fe as n,ge as o,ke as p};//# sourceMappingURL=chunk-K2VRX4TC.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-K2VRX4TC.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {a}from'./chunk-QE3QXEHI.js';function x(s,d){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function Q(s,d){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${d} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function n(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function y(s){return Array.isArray(s)?s:[]}function K(s,d){if(typeof d!="string"||d.length===0)return;let u=s,p=d;p.startsWith("fetched_sources.")&&(u=n(s).fetched_sources,p=p.slice(16));for(let g of p.split(".")){if(u==null||typeof u!="object")return;u=u[g];}return u}function N(s,d){let u=n(s.view);return {elements:y(u.elements).map((g,R)=>{let h=n(g),b=n(h.data),k=n(h.spec),P=typeof h.visible=="string"?!!K(d,h.visible):true,v=typeof b.bind=="string"?b.bind:void 0,T=typeof k.maxRows=="number"?k.maxRows:typeof b.maxRows=="number"?b.maxRows:void 0,L=v?K(d,v):void 0,F={id:typeof h.id=="string"&&h.id?h.id:`element-${R}`,kind:h.kind,label:h.label,visible:P};return L!==void 0&&(F.resolved=Array.isArray(L)&&typeof T=="number"?L.slice(0,T):L),F})}}function X(s,d){let u=typeof s.id=="string"&&s.id?s.id:"card",p=y(s.provides),g=p.length>0?p:[{bindTo:u,ref:"card_data"}],R={};for(let h of g){let b=n(h),k=typeof b.bindTo=="string"?b.bindTo:"",P=typeof b.ref=="string"?b.ref:"";if(!k||!P)continue;let v=K(d,P);v!==void 0&&(R[k]=v);}return R}function be(s){if(typeof s!="string"||!s.trim())return null;let d=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!d)return null;let u=Number.parseInt(d[2],10);return !Number.isInteger(u)||u<0?null:u}function ke(s){return {"card-content":s}}function D(s){let d={...s};return delete d.__private,d}function he(s,d){return Object.prototype.hasOwnProperty.call(s,d)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,d){let u=Re(s);if(!d||Object.keys(d).length===0)return u;function p(g,R,h){let b=String(R||"").split(".").filter(Boolean);if(!b.length)return;let k=g;for(let P=0;P<b.length-1;P+=1){let v=b[P];(!k[v]||typeof k[v]!="object")&&(k[v]={}),k=k[v];}k[b[b.length-1]]=h;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let g=null,R=n(u.view),h=y(R.elements);for(let b of h){let k=n(b),P=n(k.data),v=typeof k.writeTo=="string"&&k.writeTo?k.writeTo:typeof P.writeTo=="string"?P.writeTo:"";if(v){g=v;break}}return g?p(u,g,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(u.card_data={...n(u.card_data),...d.fieldValues}),u}if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return u;for(let[g,R]of Object.entries(d))g!=="_stagedFiles"&&(R!==null&&typeof R=="object"&&!Array.isArray(R)&&u[g]!==null&&typeof u[g]=="object"&&!Array.isArray(u[g])?u[g]={...u[g],...R}:u[g]=R);return u}function $(s){return n(s.__private).visible_controlplane_only===true}async function O(s,d){let u=await S(s.get({params:{id:d}}),"cardStore.get"),p=Array.isArray(u?.cards)?u.cards:[];if(p.length===0)throw new Error(`Card "${d}" not found`);return p[0]}function Ae(s){let{board:d,nonCore:u,cardStore:p,chatStore:g,processAccumulated:R,sourceFetchDone:h,sourceFetchFailed:b,uploadCardFile:k,buildFileDownloadUrl:P,readFetchedSourceJsonByRef:v}=s;function T(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function L(){let e=await S(p.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>n(r)).filter(r=>!$(r)):[]}function F(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),a=atob(t);return Uint8Array.from(a,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=n(await S(u.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:n(e.commonSourceDefFields),sourceKinds:n(e.sourceKinds)}}async function Z(){let e=n(await S(d.status({}),"status")),r=n(e.summary),t=y(e.cards),a=await S(p.get({}),"cardStore.get"),o=new Set((Array.isArray(a.cards)?a.cards.map(n):[]).filter($).map(c=>typeof c.id=="string"?c.id:"").filter(Boolean)),i=t.filter(c=>!o.has(String(n(c).name??"")));return {meta:n(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:i.map(c=>{let l=n(c);return {"card-id":typeof l.name=="string"?l.name:null,status:l.status??null,error:l.error??null,requires:y(l.requires),requires_satisfied:y(l.requires_satisfied),requires_missing:y(l.requires_missing),provides_declared:y(l.provides_declared),provides_runtime:y(l.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=n(await S(d.status({}),"status")),o=y(t.cards).map(n).find(f=>f.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let i=n(await O(p,r)),c=D(i),l=y(o.requires_satisfied).filter(f=>typeof f=="string"&&!!f),A=y(o.provides_runtime).filter(f=>typeof f=="string"&&!!f),_=Object.fromEntries(await Promise.all(l.map(async f=>[f,await S(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),I=Object.fromEntries(await Promise.all(A.map(async f=>[f,await S(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),m=n(await S(d.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),w=await S(d.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),M=y(i.source_defs).map(n),C={};for(let f of M)typeof f.bindTo=="string"&&typeof f.outputFile=="string"&&(C[f.outputFile]=f.bindTo);let U={};for(let[f,j]of Object.entries(w)){let q=C[f]??f;if(!v||typeof j!="string"){U[q]=null;continue}try{U[q]=v({cardId:r,ref:j});}catch{U[q]=null;}}let B={card_data:n(i.card_data),requires:_,fetched_sources:U,computed_values:m};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:c,refs_for_fetched_source_files:w,runtime_data:{requires:_,provides:I,computed_values:m,rendered_view:N(i,B)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",a=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",i=a?void 0:e.lastUserTurns??(t?void 0:1),c=e.tail,l={...i===void 0?{}:{tailTurns:i},...t?{turnId:t}:{},...a?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},A=Object.keys(l).length>0?{params:{cardId:r},body:l}:{params:{cardId:r}},_=x(await g.readAll(A),"chatStore.readAll"),I=n(await O(p,r)),m=y(n(I.card_data).files).map((C,U)=>({idx:U,stored_name:n(C).stored_name})).filter(C=>typeof C.stored_name=="string"&&C.stored_name.length>0),M=(Array.isArray(_.records)?_.records:[]).map(C=>{let B=n(C.payload),f={...C},j=typeof C?.role=="string"?C.role:typeof B.role=="string"?String(B.role):"",q=typeof C?.text=="string"?C.text:typeof B.text=="string"?String(B.text):"";if(j==="system"){let z=be(q);if(z!==null&&m.some(E=>E.idx===z)){let E=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${z}`;f.retrieval_hint=E,Object.keys(B).length>0&&typeof C.role!="string"&&(f.payload={...B,retrieval_hint:E});}}return f});return {cardId:r,messages:typeof c=="number"&&c>=0?M.slice(-c):M}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let a=n(await O(p,r)),o=y(n(a.card_data).files).map(n);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let i=o[t],c=typeof i.stored_name=="string"?i.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:P({cardId:r,fileIdx:t,storedName:c}),...typeof i.name=="string"?{name:i.name}:{},...typeof i.stored_name=="string"?{stored_name:i.stored_name}:{},...typeof i.mime_type=="string"?{mime_type:i.mime_type}:{},...typeof i.size=="number"?{size:i.size}:{},...typeof i.uploaded_at=="string"?{uploaded_at:i.uploaded_at}:{}}}async function V(e){return await u.validateCardPreflight({body:ke(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=u.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=n(Q(r,"evalCardCompute")),a=n(e.candidateCardContent),o={card_data:n(a.card_data),requires:n(e.mockRequires),fetched_sources:n(e.mockFetchedSources),computed_values:n(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof a.id=="string"?a.id:"(unknown)",ok:t.ok===true,computed_values:n(t.computed_values),errors:y(t.errors).map(i=>{let c=n(i);return {bindTo:typeof c.bindTo=="string"?c.bindTo:"",error:typeof c.error=="string"?c.error:""}}),provides_outputs:X(a,o),rendered_view:N(a,o)}}}async function ae(e){return await u.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await u.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=n(await O(p,r)),a$1=y(t.source_defs).filter(i=>!!i&&typeof i=="object"&&!Array.isArray(i)),o={};if(e.sourceIdx>=0&&e.sourceIdx<a$1.length){let i=a$1[e.sourceIdx],c=a.enrichSourcesSync([i],{card_data:n(t.card_data),requires:e.mockRequires});Array.isArray(c)&&c.length>0&&(o=n(c[0]._projections));}return await u.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=n(await S(u.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=n(e.candidateCardContent),a=n(r.validation),o=y(r.source_probes),i=y(r.projection_errors),c=n(r.fetched_sources),l=y(r.compute_errors),A=n(r.computed_values),_={card_data:n(t.card_data),requires:e.mockRequires,fetched_sources:c,computed_values:A},I=[];for(let m of y(a.issues))typeof m=="string"&&m&&I.push(m);for(let m of o){let w=n(m),M=typeof w.bindTo=="string"?w.bindTo:"source",C=typeof w.error=="string"?w.error:"";C&&I.push(`${M}: ${C}`);}for(let m of i){let w=n(m),M=typeof w.bindTo=="string"?w.bindTo:"source",C=typeof w.key=="string"?w.key:"projection",U=typeof w.error=="string"?w.error:"projection failed";I.push(`${M}.${C}: ${U}`);}for(let m of l){let w=n(m),M=typeof w.bindTo=="string"?w.bindTo:"compute",C=typeof w.error=="string"?w.error:"compute failed";I.push(`${M}: ${C}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:I,provides_outputs:X(t,_),rendered_view:N(t,_)}}}async function W(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await S(p.get({params:{id:r}}),"cardStore.get");return (Array.isArray(t.cards)?t.cards.map(n):[]).map(o=>D(o))}async function J(e){let r=await Promise.all(y(e.files).map(async t=>{let a=n(t),o=String(a.file_name??a.fileName??a.name??"").trim(),i=String(a.content_type??a.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await k({cardId:e.cardId,fileName:o,contentType:i,bytes:F(a),suppressChatRecordWrite:true})}));for(let[t,a]of r.entries()){let o=n(a.file),i=typeof a.file_idx=="number"&&Number.isInteger(a.file_idx)&&a.file_idx>=0?a.file_idx:t,c=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`;x(await g.append({params:{cardId:e.cardId},body:{role:"system",text:c,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}return r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",a=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await J({cardId:r,role:t,turn:a,files:e.files});return {status:"success",data:{cardId:r,turn:a,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),a=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let l=x(await g.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),A=Array.isArray(l.records)?l.records.find(_=>_.role==="assistant"&&String(_.turn||"")===o):void 0;if(A)return {status:"success",data:{cardId:r,id:String(A.id),role:t,turn:o,files:Array.isArray(A.files)?A.files:[]}}}let i=await J({cardId:r,role:t,turn:o,files:e.files}),c=x(await g.append({params:{cardId:r},body:{role:t,text:a,files:i,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(c.id),role:t,turn:o,files:i}}}async function ue(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.patch);if(!t)throw new Error("managePatchCard requires cardId");let o=await W({cardId:t}),i=n(o[0]),c=ve(i,a);return H({cardId:t,candidateCardContent:c},r)}async function H(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.candidateCardContent),o=D(a);if(!t)throw new Error("manageUpsertCard requires cardId");if(typeof o.id!="string"||!o.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(o.id!==t)throw new Error(`candidateCardContent.id must match cardId (${t})`);let i=null;try{i=await V({candidateCardContent:o});}catch(m){let w=m instanceof Error?m.message:String(m);if(!/non-core adapter is not configured/i.test(w))throw m;i=null;}if(i!==null){let m=n(i),w=n(m.data);if(m.status!=="success"||w.isValid!==true)return {status:"fail",step:"validate",validation:i}}let c=null;try{c=await O(p,t);}catch{c=null;}let l=c?n(c):null;if(l&&$(l)&&!r.allowControlplaneOnlyCards)throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404});let A={...o,...l&&he(l,"__private")?{__private:l.__private}:{}},_=await p.set({body:A});x(_,"cardStore.set");let I;try{I=await d.upsertCard({params:{cardId:t,restart:!0}}),x(I,"upsertCard");}catch(m){try{c&&await p.set({body:c});}catch{}throw m}return {status:"success",data:{validation:i,card_saved:null,board_result:I}}}async function le(e,r={}){let t=String(e.cardId||"").trim();if(!t)throw new Error("manageRemoveCard requires cardId");if(!r.allowControlplaneOnlyCards){let i=await S(p.get({params:{id:t}}),"cardStore.get");if((Array.isArray(i.cards)?i.cards.map(n):[]).some($))throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404})}let a=await d.removeCard({params:{id:t}});x(a,"removeCard");let o=await p.del({params:{id:t}});return x(o,"cardStore.del"),{status:"success",data:{board_result:a,store_result:o}}}async function pe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await S(p.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(a=>n(a)):[]}async function me(e){let r=String(e.cardId||"").trim(),t=n(e.candidateCardContent),a=D(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof a.id!="string"||!a.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(a.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await V({candidateCardContent:a}),i=n(o),c=n(i.data);if(i.status!=="success"||c.isValid!==true)return {status:"fail",step:"validate",validation:o};let l=null;try{l=await O(p,r);}catch{l=null;}let A=l?n(n(l).__private):{},_={...a,__private:{...A,visible_controlplane_only:true}},I=await p.set({body:_});x(I,"cardStore.set");let m;try{m=await d.upsertCard({params:{cardId:r,restart:!0}}),x(m,"upsertCard");}catch(w){try{l&&await p.set({body:l});}catch{}throw w}return {status:"success",data:{validation:o,card_saved:null,board_result:m}}}async function fe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=Q(await g.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}async function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return x(await g.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function we(){let e=await T(R,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function Ce(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let a=await T(h,"webhook.source-fetch-done")({token:r,ref:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let a=await T(b,"webhook.source-fetch-failed")({token:r,reason:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}return {listRuntimeCards:L,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:V,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:W,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:H,manageRemoveCard:le,adminReadCard:pe,adminUpsertCard:me,getChatProcessing:fe,setChatProcessing:ge,webhookProcessAccumulated:we,webhookSourceFetchDone:Ce,webhookSourceFetchFailed:ye}}async function S(s,d){return x(await s,d)}export{Ae as a};//# sourceMappingURL=chunk-ONJG6QW6.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-ONJG6QW6.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunk7Y47QXMX_cjs=require('./chunk-7Y47QXMX.cjs'),chunkZV35WD6K_cjs=require('./chunk-ZV35WD6K.cjs'),child_process=require('child_process');function z(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),i=Object.keys(a),d=0,c=0,l=0,f=0,t=0,r=0;for(let h of i){let T=o.tasks[h];if(!T||T.status===chunk7Y47QXMX_cjs.a.NOT_STARTED)t++;else switch(T.status){case chunk7Y47QXMX_cjs.a.RUNNING:d++;break;case chunk7Y47QXMX_cjs.a.COMPLETED:c++;break;case chunk7Y47QXMX_cjs.a.FAILED:l++;break;case "inactivated":r++;break;default:f++;}}let n={};for(let[h,T]of Object.entries(a)){for(let R of chunk7Y47QXMX_cjs.g(T))n[R]||(n[R]=[]),n[R].push(h);if(T.on)for(let R of Object.values(T.on))for(let g of R)n[g]||(n[g]=[]),n[g].includes(h)||n[g].push(h);if(T.on_failure)for(let R of T.on_failure)n[R]||(n[R]=[]),n[R].includes(h)||n[R].push(h);}let u=new Set,p=0,k=0;for(let[h,T]of Object.entries(a)){let R=o.tasks[h];if(R?.status===chunk7Y47QXMX_cjs.a.COMPLETED||R?.status===chunk7Y47QXMX_cjs.a.RUNNING)continue;let g=false,H=false;for(let x of chunk7Y47QXMX_cjs.h(T)){let q=n[x]||[];q.length===0?(u.add(x),g=true):q.every(Y=>{let W=o.tasks[Y];return W?.status===chunk7Y47QXMX_cjs.a.FAILED||W?.status==="inactivated"})&&(H=true);}g&&p++,H&&!g&&k++;}let m=[];for(let[h,T]of Object.entries(n))T.length>1&&m.push(h);let v=Q(a,n),b=Z(i,v);return {totalNodes:i.length,running:d,completed:c,failed:l,waiting:f,notStarted:t,disabled:r,unresolvedCount:p,blockedCount:k,openDependencies:[...u],cycles:b,conflictTokens:m}}function Q(s,e){let o={};for(let[a,i]of Object.entries(s)){o[a]=new Set;for(let d of chunk7Y47QXMX_cjs.h(i))for(let c of e[d]||[])c!==a&&o[a].add(c);}return o}function Z(s,e){let d={},c={},l=[];for(let t of s)d[t]=0,c[t]=null;function f(t){d[t]=1;for(let r of e[t]||[])if(d[r]===1){let n=[r],u=t;for(;u!==r;)n.push(u),u=c[u];n.push(r),n.reverse(),l.push(n);}else d[r]===0&&(c[r]=t,f(r));d[t]=2;}for(let t of s)d[t]===0&&f(t);return l}function B(s){let e={};for(let[o,a]of Object.entries(s)){for(let i of chunk7Y47QXMX_cjs.g(a))e[i]||(e[i]=[]),e[i].push(o);if(a.on)for(let i of Object.values(a.on))for(let d of i)e[d]||(e[d]=[]),e[d].includes(o)||e[d].push(o);if(a.on_failure)for(let i of a.on_failure)e[i]||(e[i]=[]),e[i].includes(o)||e[i].push(o);}return e}function V(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),i=B(a),d=new Set([...o.availableOutputs]);for(let[n,u]of Object.entries(o.tasks))if(u.status==="completed"){let p=a[n];p&&chunk7Y47QXMX_cjs.g(p).forEach(k=>d.add(k));}let c=new Set;for(let n of Object.values(a))for(let u of chunk7Y47QXMX_cjs.h(n))c.add(u);let l=new Set,f=new Set;for(let n of c){if(d.has(n))continue;(i[n]||[]).length===0&&l.add(n);}let t=true;for(;t;){t=false;for(let[n,u]of Object.entries(a)){if(f.has(n))continue;let p=o.tasks[n];if(p?.status==="completed")continue;let k=chunk7Y47QXMX_cjs.l(p),v=chunk7Y47QXMX_cjs.h(u).some(b=>l.has(b));(k||v)&&(f.has(n)||(f.add(n),t=true));}for(let n of c){if(l.has(n)||d.has(n))continue;let u=i[n]||[],p=u.length>0&&u.every(k=>f.has(k)||chunk7Y47QXMX_cjs.l(o.tasks[k]));(u.length===0||p)&&(l.has(n)||(l.add(n),t=true));}}let r=[];for(let n of l){let u=i[n]||[],p;u.length===0?p="no-producer":p=u.every(m=>chunk7Y47QXMX_cjs.l(o.tasks[m]))?"all-producers-failed":"transitive",r.push({token:n,reason:p,producers:u});}return {tokens:r}}function ee(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),{tokens:i}=V(s),d=new Set(i.map(l=>l.token)),c=[];for(let[l,f]of Object.entries(a)){let t=o.tasks[l];if(t?.status==="completed")continue;let n=chunk7Y47QXMX_cjs.h(f).filter(u=>d.has(u));n.length>0?c.push({nodeName:l,missingTokens:n}):chunk7Y47QXMX_cjs.l(t)&&c.push({nodeName:l,missingTokens:[]});}return {nodes:c}}function te(s,e){let o=chunk7Y47QXMX_cjs.i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a=B(o),i=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of chunk7Y47QXMX_cjs.h(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i.has(p)||(i.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,providesTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function ne(s,e){let o=chunk7Y47QXMX_cjs.i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a={};for(let[t,r]of Object.entries(o))for(let n of chunk7Y47QXMX_cjs.h(r))a[n]||(a[n]=[]),a[n].push(t);let i=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of chunk7Y47QXMX_cjs.g(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i.has(p)||(i.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,requiresTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function K(s){let e=[],{config:o,state:a}=s,i=chunk7Y47QXMX_cjs.i(o),d=Object.keys(i);for(let t of d)a.tasks[t]||e.push({severity:"error",code:"MISSING_STATE",message:`Task "${t}" exists in config but has no state entry`,tasks:[t]});for(let t of Object.keys(a.tasks))i[t]||e.push({severity:"warning",code:"ORPHAN_STATE",message:`State entry "${t}" has no corresponding task config`,tasks:[t]});for(let t of d){let r=a.tasks[t];r&&(r.status===chunk7Y47QXMX_cjs.a.RUNNING&&!r.startedAt&&e.push({severity:"warning",code:"RUNNING_WITHOUT_START",message:`Task "${t}" is running but has no startedAt timestamp`,tasks:[t]}),r.status===chunk7Y47QXMX_cjs.a.COMPLETED&&!r.completedAt&&e.push({severity:"warning",code:"COMPLETED_WITHOUT_TIMESTAMP",message:`Task "${t}" is completed but has no completedAt timestamp`,tasks:[t]}),r.status===chunk7Y47QXMX_cjs.a.FAILED&&(r.failedAt||e.push({severity:"warning",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no failedAt timestamp`,tasks:[t]}),r.error||e.push({severity:"info",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no error message`,tasks:[t]})));}let c=new Set;for(let t of d)if(a.tasks[t]?.status===chunk7Y47QXMX_cjs.a.COMPLETED)for(let n of chunk7Y47QXMX_cjs.g(i[t]))c.add(n);let l=new Set(a.availableOutputs),f=new Set;for(let t of Object.values(i)){for(let r of chunk7Y47QXMX_cjs.g(t))f.add(r);if(t.on)for(let r of Object.values(t.on))for(let n of r)f.add(n);if(t.on_failure)for(let r of t.on_failure)f.add(r);}for(let t of l)!c.has(t)&&!f.has(t)&&e.push({severity:"info",code:"INJECTED_TOKEN",message:`Token "${t}" is available but no task in the graph can produce it (likely injected)`,tokens:[t]});for(let t of c)l.has(t)||e.push({severity:"warning",code:"MISSING_OUTPUT",message:`Token "${t}" should be available (its producer completed) but is not in availableOutputs`,tokens:[t]});for(let t of d){let r=a.tasks[t];if(!r)continue;r.executionCount<0&&e.push({severity:"error",code:"INVALID_EXECUTION_COUNT",message:`Task "${t}" has negative execution count: ${r.executionCount}`,tasks:[t]});let n=i[t].maxExecutions;n!==void 0&&r.executionCount>n&&e.push({severity:"error",code:"EXCEEDED_MAX_EXECUTIONS",message:`Task "${t}" executed ${r.executionCount} times, exceeding maxExecutions of ${n}`,tasks:[t]});}return J(e)}function se(s){let{graph:e,handlers:o}=s,a=e.getState(),i=[],d=chunk7Y47QXMX_cjs.i(a.config),c=Object.keys(d),l=new Set(Object.keys(o)),f=new Set;for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)f.add(u);}for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)o[u]||i.push({severity:"error",code:"MISSING_HANDLER",message:`Task "${r}" references handler "${u}" but it is not in the registry`,tasks:[r]});}for(let r of l)f.has(r)||i.push({severity:"warning",code:"ORPHAN_HANDLER",message:`Handler "${r}" is registered but not referenced by any task's taskHandlers`,tasks:[r]});let t=K(a);return i.push(...t.issues),J(i)}function J(s){let e=s.filter(a=>a.severity==="error"),o=s.filter(a=>a.severity==="warning");return {valid:e.length===0,issues:s,errors:e,warnings:o}}function re(s,e){let o=s;for(let a of e)o=oe(o,a);return o}function oe(s,e){switch(e.type){case "add-node":return chunkAW3COGCI_cjs.d(s,e.name,e.config);case "remove-node":return chunkAW3COGCI_cjs.e(s,e.name);case "add-requires":return chunkAW3COGCI_cjs.f(s,e.taskName,e.tokens);case "remove-requires":return chunkAW3COGCI_cjs.g(s,e.taskName,e.tokens);case "add-provides":return chunkAW3COGCI_cjs.h(s,e.taskName,e.tokens);case "remove-provides":return chunkAW3COGCI_cjs.i(s,e.taskName,e.tokens);case "inject-tokens":return chunkAW3COGCI_cjs.j(s,e.tokens);case "drain-tokens":return chunkAW3COGCI_cjs.k(s,e.tokens);case "reset-node":return chunkAW3COGCI_cjs.l(s,e.name);case "disable-node":return chunkAW3COGCI_cjs.m(s,e.name);case "enable-node":return chunkAW3COGCI_cjs.n(s,e.name);case "apply-events":return chunkAW3COGCI_cjs.c(s,e.events);default:throw new Error(`Unknown mutation type: ${e.type}`)}}function ce(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(i=>e()(a,i)).catch(i=>e()(a,{},[i instanceof Error?i.message:String(i)])),"task-initiated"}}function de(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(()=>e()(a,{})).catch(()=>e()(a,{})),"task-initiated"}}function ue(s){let{command:e,cwd:o,env:a,timeoutMs:i=3e4,exitCodeMap:d,captureOutput:c=false,getResolve:l}=s;return async f=>{let{callbackToken:t,nodeId:r}=f,n=e.replace(/\$\{taskName\}/g,r);return child_process.exec(n,{cwd:o,env:a?{...process.env,...a}:void 0,timeout:i,maxBuffer:10*1024*1024},(u,p,k)=>{let m=u?.code??(u?1:0);if(m!==0&&!d?.[m]){l()(t,{},[`Command exited with code ${m}: ${k||u?.message}`]);return}let v={};c&&(v.stdout=p,v.stderr=k,v.exitCode=m),l()(t,v);}),"task-initiated"}}function X(s){let{command:e,args:o=[],cwd:a,env:i,timeoutMs:d=3e4,exitCodeMap:c,captureOutput:l=false,getResolve:f}=s;return async t=>{let{callbackToken:r,nodeId:n}=t,u=e.replace(/\$\{taskName\}/g,n),p=o.map(k=>k.replace(/\$\{taskName\}/g,n));return child_process.execFile(u,p,{cwd:a,env:i?{...process.env,...i}:void 0,timeout:d,maxBuffer:10*1024*1024,encoding:"utf8",windowsHide:true},(k,m,v)=>{let b=k?.code??(k?1:0);if(b!==0&&!c?.[b]){f()(r,{},[`Process exited with code ${b}: ${v||k?.message}`]);return}let h={};l&&(h.stdout=m,h.stderr=v,h.exitCode=b),f()(r,h);}),"task-initiated"}}function le(s){return s.endsWith(".js")||s.endsWith(".mjs")||s.endsWith(".ts")?"node":s.endsWith(".py")?"python3":(s.endsWith(".sh"),"bash")}function pe(s){let{scriptPath:e,runtime:o,args:a=[],cwd:i,timeoutMs:d=6e4,captureOutput:c=false,getResolve:l}=s,f=o??le(e),t=f==="node"?process.execPath:f;return X({command:t,args:[e,"${taskName}",...a],cwd:i,timeoutMs:d,captureOutput:c,getResolve:l})}function fe(s){let{url:e,method:o="POST",headers:a={},timeoutMs:i=3e4,failOnNon2xx:d=true,getResolve:c}=s;return async l=>{let{callbackToken:f,nodeId:t,config:r}=l,n=e.replace(/\$\{taskName\}/g,t),u=JSON.stringify({taskName:t,callbackToken:f,config:r}),p=new AbortController,k=setTimeout(()=>p.abort(),i);return fetch(n,{method:o,headers:{"Content-Type":"application/json",...a},body:u,signal:p.signal}).then(async m=>{if(clearTimeout(k),d&&!m.ok){let b=await m.text().catch(()=>"");c()(f,{},[`HTTP ${m.status}: ${b}`]);return}let v=await m.json().catch(()=>({}));c()(f,v);}).catch(m=>{clearTimeout(k),c()(f,{},[m instanceof Error?m.message:String(m)]);}),"task-initiated"}}function ge(s,e){return async o=>(s()(o.callbackToken,e??{}),"task-initiated")}function ke(s,e={}){let o,a={},i;if(!Array.isArray(s)&&"nodes"in s){let g=s;o=g.nodes,i=g.id,a=g.settings??{};}else o=s;let{sourceHandlers:d={},defaultSourceHandler:c,cardHandlers:l={},reactiveOptions:f={},graphSettings:t={},executionId:r}=e,n=new Map;for(let g of o){if(n.has(g.id))throw new Error(`Duplicate card ID: "${g.id}"`);n.set(g.id,g);}let u=e.sharedState??new Map,p={},k=new Set,m=new Map;for(let g of o)for(let H of g.provides??[{bindTo:g.id,ref:"card_data"}])k.add(H.bindTo),m.set(H.bindTo,g.id);for(let g of o){let H=g.requires??[];for(let x of H)if(!k.has(x))throw new Error(`Card "${g.id}" requires "${x}" but no card provides that token`);p[g.id]={requires:H.length>0?H:void 0,provides:(g.provides??[{bindTo:g.id,ref:"card_data"}]).map(x=>x.bindTo),taskHandlers:[g.id],description:g.meta?.title??g.id};}let v={id:i??`live-cards-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...a,...t},tasks:p},b={},h=null,T=()=>(g,H,x)=>{h.resolveCallback(g,H,x);};for(let g of o)g.source_defs&&g.source_defs.length>0?b[g.id]=me(g,d,c,u,T):b[g.id]=he(g,l,u,n,m,T);let R=chunkAW3COGCI_cjs.t(v,{...f,handlers:b},r);return h=R,{graph:R,config:v,handlers:b,cards:n,sharedState:u}}function me(s,e,o,a,i){if(e[s.id]){let d=e[s.id];return async c=>d(c)}if(o){let d=o(s);return async c=>d(c)}return async d=>{let c={...s.card_data};return a.set(s.id,c),i()(d.callbackToken,c),"task-initiated"}}function he(s,e,o,a,i,d){if(e[s.id]){let c=e[s.id];return async l=>c(l)}return async c=>{let l={},f=s.requires??[];for(let u of f){let p=i.get(u)??u,k=o.get(p);k&&(l[u]=k[u]??k);}let t={id:s.id,card_data:{...s.card_data},requires:l,compute:s.compute};await chunkZV35WD6K_cjs.a.run(t);let r;if(s.provides&&s.provides.length>0){r={};for(let{bindTo:u,ref:p}of s.provides)r[u]=chunkZV35WD6K_cjs.a.resolve(t,p);}else r={...t.card_data,...t.computed_values};let n={...t.card_data,...t.computed_values};return o.set(s.id,n),d()(c.callbackToken,r),"task-initiated"}}exports.a=z;exports.b=V;exports.c=ee;exports.d=te;exports.e=ne;exports.f=K;exports.g=se;exports.h=re;exports.i=ce;exports.j=de;exports.k=ue;exports.l=X;exports.m=pe;exports.n=fe;exports.o=ge;exports.p=ke;//# sourceMappingURL=chunk-HOS2ZUFZ.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkAW3COGCI_cjs=require('./chunk-AW3COGCI.cjs'),chunk7Y47QXMX_cjs=require('./chunk-7Y47QXMX.cjs'),chunk66ZZIF2L_cjs=require('./chunk-66ZZIF2L.cjs'),child_process=require('child_process');function z(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),i=Object.keys(a),d=0,c=0,l=0,f=0,t=0,r=0;for(let h of i){let T=o.tasks[h];if(!T||T.status===chunk7Y47QXMX_cjs.a.NOT_STARTED)t++;else switch(T.status){case chunk7Y47QXMX_cjs.a.RUNNING:d++;break;case chunk7Y47QXMX_cjs.a.COMPLETED:c++;break;case chunk7Y47QXMX_cjs.a.FAILED:l++;break;case "inactivated":r++;break;default:f++;}}let n={};for(let[h,T]of Object.entries(a)){for(let R of chunk7Y47QXMX_cjs.g(T))n[R]||(n[R]=[]),n[R].push(h);if(T.on)for(let R of Object.values(T.on))for(let g of R)n[g]||(n[g]=[]),n[g].includes(h)||n[g].push(h);if(T.on_failure)for(let R of T.on_failure)n[R]||(n[R]=[]),n[R].includes(h)||n[R].push(h);}let u=new Set,p=0,k=0;for(let[h,T]of Object.entries(a)){let R=o.tasks[h];if(R?.status===chunk7Y47QXMX_cjs.a.COMPLETED||R?.status===chunk7Y47QXMX_cjs.a.RUNNING)continue;let g=false,H=false;for(let x of chunk7Y47QXMX_cjs.h(T)){let q=n[x]||[];q.length===0?(u.add(x),g=true):q.every(Y=>{let W=o.tasks[Y];return W?.status===chunk7Y47QXMX_cjs.a.FAILED||W?.status==="inactivated"})&&(H=true);}g&&p++,H&&!g&&k++;}let m=[];for(let[h,T]of Object.entries(n))T.length>1&&m.push(h);let v=Q(a,n),b=Z(i,v);return {totalNodes:i.length,running:d,completed:c,failed:l,waiting:f,notStarted:t,disabled:r,unresolvedCount:p,blockedCount:k,openDependencies:[...u],cycles:b,conflictTokens:m}}function Q(s,e){let o={};for(let[a,i]of Object.entries(s)){o[a]=new Set;for(let d of chunk7Y47QXMX_cjs.h(i))for(let c of e[d]||[])c!==a&&o[a].add(c);}return o}function Z(s,e){let d={},c={},l=[];for(let t of s)d[t]=0,c[t]=null;function f(t){d[t]=1;for(let r of e[t]||[])if(d[r]===1){let n=[r],u=t;for(;u!==r;)n.push(u),u=c[u];n.push(r),n.reverse(),l.push(n);}else d[r]===0&&(c[r]=t,f(r));d[t]=2;}for(let t of s)d[t]===0&&f(t);return l}function B(s){let e={};for(let[o,a]of Object.entries(s)){for(let i of chunk7Y47QXMX_cjs.g(a))e[i]||(e[i]=[]),e[i].push(o);if(a.on)for(let i of Object.values(a.on))for(let d of i)e[d]||(e[d]=[]),e[d].includes(o)||e[d].push(o);if(a.on_failure)for(let i of a.on_failure)e[i]||(e[i]=[]),e[i].includes(o)||e[i].push(o);}return e}function V(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),i=B(a),d=new Set([...o.availableOutputs]);for(let[n,u]of Object.entries(o.tasks))if(u.status==="completed"){let p=a[n];p&&chunk7Y47QXMX_cjs.g(p).forEach(k=>d.add(k));}let c=new Set;for(let n of Object.values(a))for(let u of chunk7Y47QXMX_cjs.h(n))c.add(u);let l=new Set,f=new Set;for(let n of c){if(d.has(n))continue;(i[n]||[]).length===0&&l.add(n);}let t=true;for(;t;){t=false;for(let[n,u]of Object.entries(a)){if(f.has(n))continue;let p=o.tasks[n];if(p?.status==="completed")continue;let k=chunk7Y47QXMX_cjs.l(p),v=chunk7Y47QXMX_cjs.h(u).some(b=>l.has(b));(k||v)&&(f.has(n)||(f.add(n),t=true));}for(let n of c){if(l.has(n)||d.has(n))continue;let u=i[n]||[],p=u.length>0&&u.every(k=>f.has(k)||chunk7Y47QXMX_cjs.l(o.tasks[k]));(u.length===0||p)&&(l.has(n)||(l.add(n),t=true));}}let r=[];for(let n of l){let u=i[n]||[],p;u.length===0?p="no-producer":p=u.every(m=>chunk7Y47QXMX_cjs.l(o.tasks[m]))?"all-producers-failed":"transitive",r.push({token:n,reason:p,producers:u});}return {tokens:r}}function ee(s){let{config:e,state:o}=s,a=chunk7Y47QXMX_cjs.i(e),{tokens:i}=V(s),d=new Set(i.map(l=>l.token)),c=[];for(let[l,f]of Object.entries(a)){let t=o.tasks[l];if(t?.status==="completed")continue;let n=chunk7Y47QXMX_cjs.h(f).filter(u=>d.has(u));n.length>0?c.push({nodeName:l,missingTokens:n}):chunk7Y47QXMX_cjs.l(t)&&c.push({nodeName:l,missingTokens:[]});}return {nodes:c}}function te(s,e){let o=chunk7Y47QXMX_cjs.i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a=B(o),i=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of chunk7Y47QXMX_cjs.h(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i.has(p)||(i.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,providesTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function ne(s,e){let o=chunk7Y47QXMX_cjs.i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a={};for(let[t,r]of Object.entries(o))for(let n of chunk7Y47QXMX_cjs.h(r))a[n]||(a[n]=[]),a[n].push(t);let i=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of chunk7Y47QXMX_cjs.g(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i.has(p)||(i.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,requiresTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function K(s){let e=[],{config:o,state:a}=s,i=chunk7Y47QXMX_cjs.i(o),d=Object.keys(i);for(let t of d)a.tasks[t]||e.push({severity:"error",code:"MISSING_STATE",message:`Task "${t}" exists in config but has no state entry`,tasks:[t]});for(let t of Object.keys(a.tasks))i[t]||e.push({severity:"warning",code:"ORPHAN_STATE",message:`State entry "${t}" has no corresponding task config`,tasks:[t]});for(let t of d){let r=a.tasks[t];r&&(r.status===chunk7Y47QXMX_cjs.a.RUNNING&&!r.startedAt&&e.push({severity:"warning",code:"RUNNING_WITHOUT_START",message:`Task "${t}" is running but has no startedAt timestamp`,tasks:[t]}),r.status===chunk7Y47QXMX_cjs.a.COMPLETED&&!r.completedAt&&e.push({severity:"warning",code:"COMPLETED_WITHOUT_TIMESTAMP",message:`Task "${t}" is completed but has no completedAt timestamp`,tasks:[t]}),r.status===chunk7Y47QXMX_cjs.a.FAILED&&(r.failedAt||e.push({severity:"warning",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no failedAt timestamp`,tasks:[t]}),r.error||e.push({severity:"info",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no error message`,tasks:[t]})));}let c=new Set;for(let t of d)if(a.tasks[t]?.status===chunk7Y47QXMX_cjs.a.COMPLETED)for(let n of chunk7Y47QXMX_cjs.g(i[t]))c.add(n);let l=new Set(a.availableOutputs),f=new Set;for(let t of Object.values(i)){for(let r of chunk7Y47QXMX_cjs.g(t))f.add(r);if(t.on)for(let r of Object.values(t.on))for(let n of r)f.add(n);if(t.on_failure)for(let r of t.on_failure)f.add(r);}for(let t of l)!c.has(t)&&!f.has(t)&&e.push({severity:"info",code:"INJECTED_TOKEN",message:`Token "${t}" is available but no task in the graph can produce it (likely injected)`,tokens:[t]});for(let t of c)l.has(t)||e.push({severity:"warning",code:"MISSING_OUTPUT",message:`Token "${t}" should be available (its producer completed) but is not in availableOutputs`,tokens:[t]});for(let t of d){let r=a.tasks[t];if(!r)continue;r.executionCount<0&&e.push({severity:"error",code:"INVALID_EXECUTION_COUNT",message:`Task "${t}" has negative execution count: ${r.executionCount}`,tasks:[t]});let n=i[t].maxExecutions;n!==void 0&&r.executionCount>n&&e.push({severity:"error",code:"EXCEEDED_MAX_EXECUTIONS",message:`Task "${t}" executed ${r.executionCount} times, exceeding maxExecutions of ${n}`,tasks:[t]});}return J(e)}function se(s){let{graph:e,handlers:o}=s,a=e.getState(),i=[],d=chunk7Y47QXMX_cjs.i(a.config),c=Object.keys(d),l=new Set(Object.keys(o)),f=new Set;for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)f.add(u);}for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)o[u]||i.push({severity:"error",code:"MISSING_HANDLER",message:`Task "${r}" references handler "${u}" but it is not in the registry`,tasks:[r]});}for(let r of l)f.has(r)||i.push({severity:"warning",code:"ORPHAN_HANDLER",message:`Handler "${r}" is registered but not referenced by any task's taskHandlers`,tasks:[r]});let t=K(a);return i.push(...t.issues),J(i)}function J(s){let e=s.filter(a=>a.severity==="error"),o=s.filter(a=>a.severity==="warning");return {valid:e.length===0,issues:s,errors:e,warnings:o}}function re(s,e){let o=s;for(let a of e)o=oe(o,a);return o}function oe(s,e){switch(e.type){case "add-node":return chunkAW3COGCI_cjs.d(s,e.name,e.config);case "remove-node":return chunkAW3COGCI_cjs.e(s,e.name);case "add-requires":return chunkAW3COGCI_cjs.f(s,e.taskName,e.tokens);case "remove-requires":return chunkAW3COGCI_cjs.g(s,e.taskName,e.tokens);case "add-provides":return chunkAW3COGCI_cjs.h(s,e.taskName,e.tokens);case "remove-provides":return chunkAW3COGCI_cjs.i(s,e.taskName,e.tokens);case "inject-tokens":return chunkAW3COGCI_cjs.j(s,e.tokens);case "drain-tokens":return chunkAW3COGCI_cjs.k(s,e.tokens);case "reset-node":return chunkAW3COGCI_cjs.l(s,e.name);case "disable-node":return chunkAW3COGCI_cjs.m(s,e.name);case "enable-node":return chunkAW3COGCI_cjs.n(s,e.name);case "apply-events":return chunkAW3COGCI_cjs.c(s,e.events);default:throw new Error(`Unknown mutation type: ${e.type}`)}}function ce(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(i=>e()(a,i)).catch(i=>e()(a,{},[i instanceof Error?i.message:String(i)])),"task-initiated"}}function de(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(()=>e()(a,{})).catch(()=>e()(a,{})),"task-initiated"}}function ue(s){let{command:e,cwd:o,env:a,timeoutMs:i=3e4,exitCodeMap:d,captureOutput:c=false,getResolve:l}=s;return async f=>{let{callbackToken:t,nodeId:r}=f,n=e.replace(/\$\{taskName\}/g,r);return child_process.exec(n,{cwd:o,env:a?{...process.env,...a}:void 0,timeout:i,maxBuffer:10*1024*1024},(u,p,k)=>{let m=u?.code??(u?1:0);if(m!==0&&!d?.[m]){l()(t,{},[`Command exited with code ${m}: ${k||u?.message}`]);return}let v={};c&&(v.stdout=p,v.stderr=k,v.exitCode=m),l()(t,v);}),"task-initiated"}}function X(s){let{command:e,args:o=[],cwd:a,env:i,timeoutMs:d=3e4,exitCodeMap:c,captureOutput:l=false,getResolve:f}=s;return async t=>{let{callbackToken:r,nodeId:n}=t,u=e.replace(/\$\{taskName\}/g,n),p=o.map(k=>k.replace(/\$\{taskName\}/g,n));return child_process.execFile(u,p,{cwd:a,env:i?{...process.env,...i}:void 0,timeout:d,maxBuffer:10*1024*1024,encoding:"utf8",windowsHide:true},(k,m,v)=>{let b=k?.code??(k?1:0);if(b!==0&&!c?.[b]){f()(r,{},[`Process exited with code ${b}: ${v||k?.message}`]);return}let h={};l&&(h.stdout=m,h.stderr=v,h.exitCode=b),f()(r,h);}),"task-initiated"}}function le(s){return s.endsWith(".js")||s.endsWith(".mjs")||s.endsWith(".ts")?"node":s.endsWith(".py")?"python3":(s.endsWith(".sh"),"bash")}function pe(s){let{scriptPath:e,runtime:o,args:a=[],cwd:i,timeoutMs:d=6e4,captureOutput:c=false,getResolve:l}=s,f=o??le(e),t=f==="node"?process.execPath:f;return X({command:t,args:[e,"${taskName}",...a],cwd:i,timeoutMs:d,captureOutput:c,getResolve:l})}function fe(s){let{url:e,method:o="POST",headers:a={},timeoutMs:i=3e4,failOnNon2xx:d=true,getResolve:c}=s;return async l=>{let{callbackToken:f,nodeId:t,config:r}=l,n=e.replace(/\$\{taskName\}/g,t),u=JSON.stringify({taskName:t,callbackToken:f,config:r}),p=new AbortController,k=setTimeout(()=>p.abort(),i);return fetch(n,{method:o,headers:{"Content-Type":"application/json",...a},body:u,signal:p.signal}).then(async m=>{if(clearTimeout(k),d&&!m.ok){let b=await m.text().catch(()=>"");c()(f,{},[`HTTP ${m.status}: ${b}`]);return}let v=await m.json().catch(()=>({}));c()(f,v);}).catch(m=>{clearTimeout(k),c()(f,{},[m instanceof Error?m.message:String(m)]);}),"task-initiated"}}function ge(s,e){return async o=>(s()(o.callbackToken,e??{}),"task-initiated")}function ke(s,e={}){let o,a={},i;if(!Array.isArray(s)&&"nodes"in s){let g=s;o=g.nodes,i=g.id,a=g.settings??{};}else o=s;let{sourceHandlers:d={},defaultSourceHandler:c,cardHandlers:l={},reactiveOptions:f={},graphSettings:t={},executionId:r}=e,n=new Map;for(let g of o){if(n.has(g.id))throw new Error(`Duplicate card ID: "${g.id}"`);n.set(g.id,g);}let u=e.sharedState??new Map,p={},k=new Set,m=new Map;for(let g of o)for(let H of g.provides??[{bindTo:g.id,ref:"card_data"}])k.add(H.bindTo),m.set(H.bindTo,g.id);for(let g of o){let H=g.requires??[];for(let x of H)if(!k.has(x))throw new Error(`Card "${g.id}" requires "${x}" but no card provides that token`);p[g.id]={requires:H.length>0?H:void 0,provides:(g.provides??[{bindTo:g.id,ref:"card_data"}]).map(x=>x.bindTo),taskHandlers:[g.id],description:g.meta?.title??g.id};}let v={id:i??`live-cards-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...a,...t},tasks:p},b={},h=null,T=()=>(g,H,x)=>{h.resolveCallback(g,H,x);};for(let g of o)g.source_defs&&g.source_defs.length>0?b[g.id]=me(g,d,c,u,T):b[g.id]=he(g,l,u,n,m,T);let R=chunkAW3COGCI_cjs.t(v,{...f,handlers:b},r);return h=R,{graph:R,config:v,handlers:b,cards:n,sharedState:u}}function me(s,e,o,a,i){if(e[s.id]){let d=e[s.id];return async c=>d(c)}if(o){let d=o(s);return async c=>d(c)}return async d=>{let c={...s.card_data};return a.set(s.id,c),i()(d.callbackToken,c),"task-initiated"}}function he(s,e,o,a,i,d){if(e[s.id]){let c=e[s.id];return async l=>c(l)}return async c=>{let l={},f=s.requires??[];for(let u of f){let p=i.get(u)??u,k=o.get(p);k&&(l[u]=k[u]??k);}let t={id:s.id,card_data:{...s.card_data},requires:l,compute:s.compute};await chunk66ZZIF2L_cjs.a.run(t);let r;if(s.provides&&s.provides.length>0){r={};for(let{bindTo:u,ref:p}of s.provides)r[u]=chunk66ZZIF2L_cjs.a.resolve(t,p);}else r={...t.card_data,...t.computed_values};let n={...t.card_data,...t.computed_values};return o.set(s.id,n),d()(c.callbackToken,r),"task-initiated"}}exports.a=z;exports.b=V;exports.c=ee;exports.d=te;exports.e=ne;exports.f=K;exports.g=se;exports.h=re;exports.i=ce;exports.j=de;exports.k=ue;exports.l=X;exports.m=pe;exports.n=fe;exports.o=ge;exports.p=ke;//# sourceMappingURL=chunk-P4WQJ7LA.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-P4WQJ7LA.cjs.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
'use strict';var chunkUJ7ZTV4J_cjs=require('./chunk-UJ7ZTV4J.cjs'),chunkGNFE24S7_cjs=require('./chunk-GNFE24S7.cjs'),j=require('ajv-formats'),module$1=require('module');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var j__default=/*#__PURE__*/_interopDefault(j);var g={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://nsreehari.github.io/boards/live-cards.schema.json",definitions:{bind_ref:{description:"A card data path reference, e.g. 'card_data.raw_quotes' or 'requires.upstream'",type:"string",pattern:"^(card_data|requires|fetched_sources|computed_values)(\\.|$)"},compute_expr:{description:"A declarative JSON compute expression",type:"object",required:["fn"],properties:{fn:{type:"string",description:"Function name from the built-in vocabulary",enum:["sum","avg","min","max","count","first","last","add","sub","mul","div","round","abs","mod","gt","gte","lt","lte","eq","neq","if","and","or","not","concat","upper","lower","template","filter","pluck","map","sort","slice","flat","unique","group","get","default","now","diff_days","format_date"]},input:{description:"card_data.path, literal, array of inputs, or nested compute_expr",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{$ref:"#/definitions/compute_expr"}]},field:{type:"string",description:"For pluck/sum/group \u2014 the object key to extract"},where:{$ref:"#/definitions/compute_expr",description:"For filter \u2014 predicate expression ($ = current item)"},cond:{$ref:"#/definitions/compute_expr",description:"For if \u2014 condition expression"},then:{description:"For if \u2014 value when cond is truthy"},else:{description:"For if \u2014 value when cond is falsy"},format:{type:"string",description:"For format_date \u2014 date format string"}}},meta:{type:"object",properties:{title:{type:"string"},presentation:{type:"object",description:"Semantic presentation hints authored on the card, expressed from the user's perception of the card on the Main Canvas. Content shape is inferred from view.elements[].kind; runtime placement and live drag/resize coordinates are frontend-managed and must not be authored into card JSON.",properties:{prominence:{type:"string",default:"standard",description:"How much the user should care about this card / how much attention it earns. Default: standard; omit unless a non-standard value is needed.",enum:["glance","standard","feature","spotlight"]},footprint:{type:"string",default:"standard",description:"How much room the card wants to render well, independent of attention. Default: standard; omit unless a non-standard value is needed.",enum:["compact","standard","wide","large"]},resizable:{type:"boolean",default:true,description:"Whether the user may resize this card at runtime. Default: true; omit unless it must be false."}},additionalProperties:true},tags:{type:"array",items:{type:"string"}}},additionalProperties:true},__private:{description:"Control-plane-owned private state. Stripped entirely from all regular /mcp read responses. Writable only via 'setstate.card-private' and 'manage.admin-upsert-card'. Agents must never author this field. Keys inside use plain names (no leading underscores).",type:"object",additionalProperties:true},requires:{type:"array",items:{type:"string"},description:"IDs of upstream nodes this node depends on"},provides:{type:"array",items:{type:"object",required:["bindTo","ref"],properties:{bindTo:{type:"string",description:"Token name published downstream"},ref:{type:"string",description:"Path to read value from (card_data.*, requires.*, fetched_sources.*, computed_values.*)"}}},description:"Explicit bindings exposing computed or card_data values downstream as named tokens"},compute_step:{description:"A single ordered compute step: reads card_data.*/requires.*/computed_values.*, writes to computed_values[bindTo]",type:"object",required:["bindTo","expr"],properties:{bindTo:{type:"string",description:"Key in computed_values to write result"},expr:{type:"string",description:"JSONata expression evaluated against { card_data, requires, fetched_sources, computed_values }"}}},source_def:{description:"One source entry. The engine requires 'bindTo' (compute namespace key) and 'outputFile' (delivery signal path). bindTo and outputFile must be unique across all source_defs in a card. Every other property is yours \u2014 add whatever your task-executor needs: kind, url, headers, mailbox, channel, model, query, etc. The full object is passed verbatim as the --in JSON to the executor.",type:"object",required:["bindTo","outputFile"],additionalProperties:true,properties:{bindTo:{type:"string",description:"Key under fetched_sources.* available in compute expressions"},outputFile:{type:"string",description:"Board-relative path the executor writes its JSON result to. Presence of this file signals delivery."},projections:{type:"object",description:"Named data projections from card_data or requires, evaluated before the executor is called. Each key is a ref name; each value is a JSONata expression rooted at card_data or requires. The resolved values are passed to the executor as _projections. fetched_sources, computed_values, and source_defs are not accessible here \u2014 sources run before those exist.",additionalProperties:{type:"string"}},skip_when:{type:"string",description:"JSONata over card_data/requires. Truthy skips this source."},timeout:{type:"integer",minimum:0,default:12e4,description:"Executor/script timeout in ms. Default: 120 000 (2 min)."},script:{type:"string",description:"Legacy direct-run: shell command executed when no .task-executor is registered. stdout is captured as the result."}}},render_element:{type:"object",required:["kind"],additionalProperties:false,properties:{kind:{enum:["metric","table","editable-table","chart","form","list","notes","todo","alert","narrative","badge","text","markdown","markup","selection","searchbox","query","ref","custom","actions"]},id:{type:"string",description:"Optional element ID for targeted updates and action routing"},label:{type:"string",description:"Heading above this element (also the metric/alert title)"},className:{type:"string",description:"Bootstrap grid class, e.g. 'col-12 col-md-6'"},containerStyle:{type:"object",description:"Inline style applied to the element container"},visible:{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 element shown only if truthy"},data:{allOf:[{$ref:"#/definitions/value_source"}],description:"The element value: { bind } (dynamic) or { value } (static literal)"},writeTo:{$ref:"#/definitions/write_ref"},spec:{type:"object",description:"Per-kind static configuration (constrained per kind below)"}},allOf:[{if:{properties:{kind:{const:"metric"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_empty"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"table"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_table"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"list"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_table"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"chart"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_chart"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"alert"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_alert"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"badge"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_badge"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"narrative"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_empty"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"text"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_text"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"markdown"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_empty"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"markup"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_empty"},writeTo:false},required:["data"]}},{if:{properties:{kind:{const:"actions"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_actions"},data:false,writeTo:false}}},{if:{properties:{kind:{const:"selection"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_single_field"}}}},{if:{properties:{kind:{const:"searchbox"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_searchbox"}}}},{if:{properties:{kind:{const:"query"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_searchbox"}}}},{if:{properties:{kind:{const:"form"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_form"}}}},{if:{properties:{kind:{const:"notes"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_empty"}}}},{if:{properties:{kind:{const:"todo"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_empty"}}}},{if:{properties:{kind:{const:"editable-table"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_editable_table"}}}},{if:{properties:{kind:{const:"ref"}},required:["kind"]},then:{properties:{spec:{$ref:"#/definitions/spec_ref"}}}}]},view:{type:"object",required:["elements"],properties:{elements:{type:"array",minItems:1,items:{$ref:"#/definitions/render_element"}}}},value_source:{description:"Element value source. Exactly one of `bind` (dynamic path) or `value` (static inline literal).",type:"object",oneOf:[{required:["bind"],additionalProperties:false,properties:{bind:{$ref:"#/definitions/bind_ref",description:"card_data/requires/fetched_sources/computed_values path to read the value from"}}},{required:["value"],additionalProperties:false,properties:{value:{description:"Static inline literal value (no binding)."}}}]},write_ref:{type:"string",pattern:"^card_data(\\.|$)",description:"card_data path the element writes user input to (input kinds only)"},spec_empty:{type:"object",additionalProperties:false,properties:{}},spec_table:{type:"object",additionalProperties:false,properties:{columns:{type:"array",items:{type:"string"},description:"Visible columns, in order"},maxRows:{type:"integer",description:"Max rows to display"},sortable:{type:"boolean",default:true,description:"Enable click-to-sort"},placeholder:{type:"string",description:"Empty-state message"}}},spec_chart:{type:"object",additionalProperties:false,properties:{chartType:{enum:["bar","line","area","scatter","pie","doughnut"],description:"Explicit chart type (else auto-detected)"},columns:{type:"array",items:{type:"string"},description:"First column is the label/x axis; rest are series"},labelKey:{type:"string",description:"Row key to use as the category/x label"},xKey:{type:"string",description:"Row key to use as the x axis (line charts)"},series:{type:"array",items:{type:"string"},description:"Row keys to plot as series"},stacked:{type:"boolean",description:"Stack bar/area series"},legend:{type:"boolean",default:true,description:"Show the legend"},grid:{type:"boolean",default:true,description:"Show the cartesian grid"},height:{type:"integer",default:220,description:"Chart height in pixels"}}},spec_alert:{type:"object",additionalProperties:false,properties:{thresholds:{type:"object",additionalProperties:false,properties:{green:{type:"string",description:"Comparison expr, e.g. '>=80'"},amber:{type:"string",description:"Comparison expr, e.g. '>=50'"}}}}},spec_badge:{type:"object",additionalProperties:false,properties:{colorMap:{type:"object",additionalProperties:{type:"string"},description:"value \u2192 tone/Bootstrap color"}}},spec_text:{type:"object",additionalProperties:false,properties:{format:{enum:["default","file-links"],description:"'file-links' renders the bound file array as download links"},style:{enum:["default","muted","muted-italic","heading"],description:"Display style"},hideIfEmpty:{type:"boolean",description:"Render nothing when the value is empty"}}},spec_actions:{type:"object",additionalProperties:false,required:["buttons"],properties:{buttons:{type:"array",description:"Button definitions; clicks emit an action save keyed by element id + button id",items:{type:"object",required:["id","label"],additionalProperties:false,properties:{id:{type:"string"},label:{type:"string"},style:{type:"string",description:"Bootstrap button variant, e.g. 'success', 'outline-danger'"},size:{type:"string",default:"sm"},disabled:{oneOf:[{type:"boolean"},{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 truthy = disabled"}]}}}}}},spec_form:{type:"object",additionalProperties:false,required:["fields"],properties:{fields:{type:"object",description:"JSON-Schema-ish { properties, required } describing the form fields"},discardLabel:{type:"string"},saveLabel:{type:"string"},validators:{type:"array",description:"Cross-field validation rules. Each item is a [jsonataExpr, errorMessage] pair; the expr is evaluated against { data: <current field values> } and must return true to pass. Required-field emptiness is already handled by fields.required, so validators are for format/relationship rules. Runs on blur and submit.",items:{type:"array",minItems:2,maxItems:2,items:{type:"string"}}}}},spec_single_field:{type:"object",additionalProperties:false,required:["fields"],properties:{fields:{type:"object",description:"Single-property JSON-Schema-ish { properties, required } for the control"}}},spec_searchbox:{type:"object",additionalProperties:false,required:["fields"],properties:{fields:{type:"object",description:"Single-property JSON-Schema-ish { properties, required } for the query field"},actionLabel:{type:"string",description:"Submit button label (default 'Search')"}}},spec_editable_table:{type:"object",additionalProperties:false,properties:{schema:{type:"object",description:"JSON-Schema-ish { properties } describing per-column cell types"},columns:{type:"array",items:{type:"string"},description:"Explicit column order"},addRow:{type:"boolean",default:true},deleteRow:{type:"boolean",default:true},placeholder:{type:"string"}}},spec_ref:{type:"object",additionalProperties:true,required:["viewBind"],properties:{viewBind:{$ref:"#/definitions/bind_ref",description:"Path to a computed view descriptor { kind, data?, spec? } selecting the effective kind at runtime"},fallbackKind:{enum:["metric","table","editable-table","chart","form","list","notes","todo","alert","narrative","badge","text","markdown","markup","selection","searchbox","query","ref","custom","actions"],description:"Kind to use when viewBind is absent/unresolved"},columns:{type:"array",items:{type:"string"},description:"Columns to forward to the resolved table/list view"}}}},title:"LiveCard",description:"A unified card node. Behavior depends on which sections are present (source_defs, compute, view, etc.)",type:"object",required:["id"],additionalProperties:false,properties:{id:{type:"string"},requires:{$ref:"#/definitions/requires"},provides:{$ref:"#/definitions/provides"},meta:{$ref:"#/definitions/meta"},__private:{$ref:"#/definitions/__private"},view:{$ref:"#/definitions/view"},card_data:{type:"object",description:"User editable data on card. Includes uploaded-file metadata maintained by host handlers. Not to be used for card static content.",properties:{files:{type:"array",description:"Optional uploaded-file metadata maintained by host handlers. Stored name is normalized and serial-prefixed (for example 001-my_file.pdf).",items:{type:"object",required:["name","stored_name"],properties:{name:{type:"string",minLength:1},stored_name:{type:"string",minLength:5,maxLength:32,pattern:"^[0-9]{3,}-[a-z0-9._-]+$"},size:{oneOf:[{type:"integer",minimum:0},{type:"null"}]},mime_type:{type:"string"},path:{type:"string",pattern:"^[^\\s]+/files/[0-9]{3,}-[a-z0-9._-]+$"},uploaded_at:{type:"string",format:"date-time"},chat:{type:"boolean",description:"Whether this file entry is associated with a chat interaction"}},additionalProperties:false}}},additionalProperties:true},source_defs:{type:"array",description:"Source entries. Each entry is passed verbatim to the board's .task-executor (registered via init --task-executor) as the --in JSON file. The executor fetches/generates the data and writes JSON to --out. If no executor is registered, the built-in executor runs the entry's 'cli' command directly. Sources gate completion.",items:{$ref:"#/definitions/source_def"}},compute:{type:"array",description:"Ordered array of compute steps. Each reads card_data.*/requires.*/fetched_sources.*/computed_values.* and writes to ephemeral computed_values[bindTo].",items:{$ref:"#/definitions/compute_step"}}}};var v=chunkGNFE24S7_cjs.b(chunkUJ7ZTV4J_cjs.q(),1);var A=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-P7STTKRO.cjs', document.baseURI).href))),E=A("./jsonata-sync.cjs"),m=null;var _=/\b(card_data|requires|fetched_sources|computed_values|source_defs)\b/g,N=/^\s*(card_data|requires|fetched_sources|computed_values|source_defs)(\.|$)/;function P(e){let t=new Set,s;for(_.lastIndex=0;(s=_.exec(e))!==null;)t.add(s[1]);return t}function w(e){let t=N.exec(e);return t?t[1]:null}function h(e,t,s,n){try{E(e);}catch(o){let d=o instanceof Error?o.message:String(o);n.push(`${t}: invalid JSONata expression (${d})`);return}let i=P(e);for(let o of i)s.has(o)||n.push(`${t}: disallowed namespace "${o}" in expression`);}function b(e,t,s){if(Array.isArray(e)){e.forEach((i,o)=>{b(i,`${t}/${o}`,s);});return}if(typeof e=="string"){let i=w(e);if(!i)return;new Set(["card_data","requires","computed_values"]).has(i)||s.push(`${t}: disallowed namespace "${i}" in view reference`);return}if(!e||typeof e!="object")return;let n=e;for(let[i,o]of Object.entries(n))b(o,`${t}/${i}`,s);}function T(){if(m)return m;let e=new v.default({allErrors:true});return j__default.default(e),m=e.compile(g),m}function R(e){let t=T(),s=t(e),n=(t.errors??[]).map(i=>`${i.instancePath||"/"}: ${i.message??"unknown error"}`);if(e&&typeof e=="object"&&!Array.isArray(e)){let i=e.source_defs;if(Array.isArray(i)){let o=new Set,d=new Set;i.forEach((p,l)=>{if(!p||typeof p!="object"||Array.isArray(p))return;let r=p;typeof r.bindTo=="string"&&r.bindTo&&(o.has(r.bindTo)&&n.push(`/source_defs/${l}/bindTo: bindTo "${r.bindTo}" must be unique across all source_defs`),o.add(r.bindTo)),typeof r.outputFile=="string"&&r.outputFile&&(d.has(r.outputFile)&&n.push(`/source_defs/${l}/outputFile: outputFile "${r.outputFile}" must be unique across all source_defs`),d.add(r.outputFile));});}}return !s||n.length>0?{ok:false,errors:n}:{ok:true,errors:[]}}function O(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:true,errors:[]};let s=e,n=s.compute;Array.isArray(n)&&n.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.expr;typeof a!="string"||a.trim().length===0||h(a,`/compute/${c}/expr`,new Set(["card_data","requires","fetched_sources","computed_values"]),t);});let i=new Set(["card_data","requires","fetched_sources","computed_values"]),o=s.provides;Array.isArray(o)&&o.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.ref;if(typeof a!="string"||a.trim().length===0)return;let u=w(a);u===null?t.push(`/provides/${c}/ref: path "${a}" must start with a valid namespace (${[...i].join(", ")})`):i.has(u)||t.push(`/provides/${c}/ref: disallowed namespace "${u}" in path "${a}" (valid: ${[...i].join(", ")})`);});let d=s.view;d&&typeof d=="object"&&!Array.isArray(d)&&b(d,"/view",t);let p=new Set(["card_data","requires"]),l=s.source_defs;return Array.isArray(l)&&l.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r,u=a.skip_when;typeof u=="string"&&u.trim().length>0&&h(u,`/source_defs/${c}/skip_when`,p,t);let f=a.projections;if(!(!f||typeof f!="object"||Array.isArray(f)))for(let[k,y]of Object.entries(f))typeof y!="string"||y.trim().length===0||h(y,`/source_defs/${c}/projections/${k}`,p,t);}),{ok:t.length===0,errors:t}}function I(e){return F(e)}function F(e){let t=R(e);if(!t.ok)return t;let s=O(e);return s.ok?{ok:true,errors:[]}:{ok:false,errors:s.errors}}
|
|
2
|
+
exports.a=R;exports.b=O;exports.c=I;exports.d=F;//# sourceMappingURL=chunk-P7STTKRO.cjs.map
|
|
3
|
+
//# sourceMappingURL=chunk-P7STTKRO.cjs.map
|