yaml-flow 8.9.2 → 8.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/browser/asset-integrity.json +5 -5
- package/browser/live-cards.js +15 -15
- package/browser/live-cards.schema.json +35 -53
- package/browser/server-runtime-controlface.js +2 -2
- package/examples/board/cards/card-concentration.json +64 -16
- package/examples/board/cards/card-my-identity.json +1 -4
- package/examples/board/cards/card-portfolio-intelligence.json +1 -5
- package/examples/board/cards/card-rebalance-sim.json +1 -4
- package/examples/board/cards/cardT-market-prices.json +1 -4
- package/examples/board/cards/cardT-portfolio-value.json +35 -10
- package/examples/board/cards/cardT-portfolio.json +1 -4
- package/lib/board-live-cards-mcp.cjs +1 -1
- package/lib/board-live-cards-mcp.d.cts +0 -2
- package/lib/board-live-cards-mcp.d.ts +0 -2
- 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.js +1 -1
- package/lib/card-compute/index.cjs +1 -1
- package/lib/card-compute/index.js +1 -1
- package/lib/card-validation.cjs +1 -1
- package/lib/card-validation.js +1 -1
- package/lib/chunk-2LGCYN35.js +2 -0
- package/lib/{chunk-BVQISI6G.js → chunk-5U5NMYGT.js} +3 -3
- package/lib/chunk-6M3RIGUH.js +2 -0
- package/lib/chunk-ATOQP3BD.js +2 -0
- package/lib/{chunk-WYKCHXBZ.cjs → chunk-BDT43KYE.cjs} +3 -3
- package/lib/chunk-CPJXGK2T.cjs +2 -0
- package/lib/{chunk-OEL5P7XE.js → chunk-CZ6ZFWFT.js} +2 -2
- package/lib/{chunk-7W4QQX7S.cjs → chunk-FFHG3CFU.cjs} +2 -2
- package/lib/chunk-GHUW6P4G.cjs +2 -0
- package/lib/{chunk-ZA4FS27N.js → chunk-H5FKNSCO.js} +3 -3
- package/lib/{chunk-GLKWEPX6.js → chunk-MEL5LKF7.js} +2 -2
- package/lib/{chunk-KSKPS6OO.cjs → chunk-NMOUBZXX.cjs} +2 -2
- package/lib/{chunk-GTHQJXYW.cjs → chunk-O65MSWUE.cjs} +2 -2
- package/lib/chunk-QBEQL4TL.cjs +2 -0
- package/lib/chunk-QEHKMLHA.cjs +3 -0
- package/lib/{chunk-YXKWIPQM.cjs → chunk-VNLMJEIX.cjs} +3 -3
- package/lib/{chunk-4VZL3GWU.js → chunk-WQANIJAQ.js} +3 -3
- package/lib/{chunk-N5RUH4NG.cjs → chunk-X5CZE2L7.cjs} +3 -3
- package/lib/chunk-YT76JNKE.js +3 -0
- package/lib/{chunk-7E5NKZIO.js → chunk-ZCU5O2LR.js} +2 -2
- 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.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.js +1 -1
- 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 +1 -1
- package/schema/live-cards.schema.json +35 -53
- package/lib/chunk-CBRVINMT.js +0 -2
- package/lib/chunk-E46UCDYN.js +0 -2
- package/lib/chunk-IRGTOCEU.cjs +0 -2
- package/lib/chunk-JHXRGPL7.cjs +0 -3
- package/lib/chunk-M53MX233.js +0 -3
- package/lib/chunk-NLC4FN7V.cjs +0 -2
- package/lib/chunk-RWAEV253.js +0 -2
- package/lib/chunk-UG55PF75.cjs +0 -2
package/lib/card-validation.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkCPJXGK2T_cjs=require('./chunk-CPJXGK2T.cjs');require('./chunk-QEHKMLHA.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"validateCardPreflight",{enumerable:true,get:function(){return chunkCPJXGK2T_cjs.a}});//# sourceMappingURL=card-validation.cjs.map
|
|
2
2
|
//# sourceMappingURL=card-validation.cjs.map
|
package/lib/card-validation.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{a as validateCardPreflight}from'./chunk-
|
|
1
|
+
export{a as validateCardPreflight}from'./chunk-2LGCYN35.js';import'./chunk-YT76JNKE.js';import'./chunk-MNEOJWPS.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=card-validation.js.map
|
|
2
2
|
//# sourceMappingURL=card-validation.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {b as b$1}from'./chunk-6MD6FVE3.js';import {a,d,x,t,u,n,w,v,k,b as b$2,c,h,i,j,o,s,r,q as q$1,p as p$1}from'./chunk-ZA4FS27N.js';import {a as a$1,b}from'./chunk-44L64VQ2.js';import {q,p,a as a$2,u as u$1}from'./chunk-VGT3TRQG.js';import {a as a$3}from'./chunk-E46UCDYN.js';import {e,f}from'./chunk-UGB7PC4P.js';async function et(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function gt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Ce(e,o){return gt(e)?e.then(o):o(e)}function tt(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]=tt(a[r],s):a[r]=s;return a}function ke(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]:ke(d,s,a)}}function rt(e){return {read:a=>e.read(a),get(a,r){return Ce(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 Ce(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return Ce(e.read(a),s=>e.write(a,tt(s??{},r)))},patch(a,r,s){return Ce(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,ke(d??{},f,s))})}}}function nt(e){return rt(e)}function at(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 ot(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,P]of Object.entries(s))r[f]!==P.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],P=Object.entries(d).find(([,k])=>k.key===s);return f&&f.key!==s?{ok:false,error:`Card id "${r}" is already mapped to key "${f.key}", cannot remap to "${s}"`}:P&&P[0]!==r?{ok:false,error:`Key "${s}" is already mapped to card id "${P[0]}", cannot remap to "${r}"`}:{ok:true}},async writeCard(r,s,d){let f=await a(),P=d??f[r]?.key??e.defaultCardKey(r),k=await e.writeCard(P,s);f[r]={key:P,checksum:k,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async patchCard(r,s,d){let f=await a(),P=f[r];if(!P||!await e.cardExists(P.key))throw new Error(`card "${r}" not found`);let k=await e.readCard(P.key);if(!k||typeof k!="object"||Array.isArray(k))throw new Error(`card "${r}" is not patchable`);let m=String(s||"").split(".").filter(Boolean),l=ke(k,m,d),R=await e.writeCard(P.key,l);f[r]={key:P.key,checksum:R,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 At(e,o){return a(e,o)}function It(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 R=e(m);if(R.length===1){await l(R[0]);return}await l(f({kind:"notification-batch",notifications:R}));}async function f$1(m){let l=m.params?.id;if(l){let R=await e$1.readCard(l);if(!R)throw new Error(`card "${l}" not found`);return [R]}return await e$1.readAllCards()}function P(m){return f({kind:"notification-batch",notifications:e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function k(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(P(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 R=Array.isArray(l)?l:[l];for(let w of R){if(typeof w.id!="string")return r("each card must have a string `id` field");await e$1.writeCard(w.id,w);}return await d(R.map(w=>({kind:"card_refreshed",cardId:w.id,card:w}))),a({count:R.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],R=m.params?.id,w=R?[...l,R]:l;if(w.length===0)return r("del requires body.ids (string[]) or params.id");for(let B of w)await e$1.removeCard(B);return await d(w.map(B=>({kind:"card_removed",cardId:B}))),a({count:w.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,R=m.params?.path;if(!l)return r("patch requires params.id");if(!R)return r("patch requires params.path");let w=m.body,B=w&&Object.prototype.hasOwnProperty.call(w,"value")?w.value:m.body;await e$1.patchCard(l,R,B);let x=await e$1.readCard(l);return x?(await d([{kind:"card_refreshed",cardId:l,card:x}]),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 R=await e$1.readCard(l);if(!R)return r(`card "${l}" not found`);let w=k(m.body);if(!w||w.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let B=R.card_data&&typeof R.card_data=="object"&&!Array.isArray(R.card_data)?R.card_data:{},x=Array.isArray(B.files)?B.files:[],L=[...x,...w],$=w.map((M,z)=>({idx:x.length+z,entry:M})),E=await this.patch({params:{id:l,path:"card_data.files"},body:{value:L}});return E.status!=="success"?E:a({files_added:$})}catch(l){return s(l)}}}}async function pt(e,o){return (await e.peekActive()).find(a=>a.id===o)}function Bt(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 pt(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 A(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function C(e){return {status:"fail",error:e}}function I(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function N(){return new Date().toISOString()}function yt(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 dt(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 we(e){try{let o=JSON.parse(dt(e));return typeof o?.t=="string"?{taskName:o.t}:null}catch{return null}}function it(e){return yt(JSON.stringify(e))}function ut(e){try{let o=JSON.parse(dt(e));return typeof o?.cbk=="string"&&typeof o?.cid=="string"&&typeof o?.b=="string"&&typeof o?.d=="string"?o:null}catch{return null}}function St(e){return j(e,o,()=>({_sources:{}}))}function Rt(e,o){return h(e,o)}function Ct(e){return k(e)}function kt(e,o){return i(e,o)}function wt(e,o,a,r$1,s$1,d){return async f=>{let P=[],k=await a.cardStore.readCard(f.nodeId);if(!k)return "task-initiate-failure";let m=k.id,l=k.card_data??{},R=k.source_defs??[],w=R,B=await a.cardRuntimeStore.readRuntime(m),x=false,L=async()=>{x&&(await a.cardRuntimeStore.writeRuntime(m,B),x=false);},$=S=>p$1(B._sources[S]),E=(S,y)=>{B._sources[S]=p$1(y),x=true;},M=f.taskState?.executionCount??0;if(B._lastExecutionCount!==M&&(B._sources={},B._lastExecutionCount=M,x=true),f.update){let S=f.update.outputFile;if(S){let y=$(S);if(f.update.failure){let T=f.update.rqt??y.lastRequestedToken??y.queueRequestedToken;T&&E(S,s(y,T));}else {let T=f.update.rqt;if(!y.lastCompletedToken||T>y.lastCompletedToken){let _=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,j=_?await a.fetchedSourcesStore.commitSourceData(m,S,_):false;E(S,j?r(y,T):s(y,T));}}await L();}}let z={};for(let S of R){if(!S.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,S.outputFile);y!==null&&(z[S.bindTo]=y);}let Q={};for(let[S,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let T=y[S];Q[S]=T!==void 0?T:y;}else Q[S]=y;let W={id:m,card_data:{...l},requires:Q,source_defs:R,compute:k.compute};W._sourcesData=z,k.compute&&a$3.runSync(W,{sourcesData:z}),(s$1??(()=>{}))(m,W.computed_values??{});let Y=a$3.enrichSourcesSync(Array.isArray(k.source_defs)?k.source_defs:void 0,{card_data:k.card_data,requires:Q}),he={...k,source_defs:Array.isArray(Y)?Y.map(S=>({...S,boardDir:typeof S.boardDir=="string"&&S.boardDir?S.boardDir:e.value})):Y},q=N(),de=f.update?void 0:q,X=w.filter(S=>{let y=S.outputFile;if(typeof y!="string"||!y)return true;let T=$(y);de&&(T={...T,queueRequestedToken:de},E(y,T));let _=T.queueRequestedToken??T.lastRequestedToken??q;return q$1(T,_)==="dispatch"});if(await L(),X.length>0){let S=false,y=q;for(let T of X){let _=T.outputFile;if(typeof _!="string"||!_)continue;let j=$(_),n=j.queueRequestedToken??q;E(_,{...j,lastRequestedToken:n}),y=n,S=true;}return S&&await L(),S&&(P.push({taskKind:"source-fetch",payload:{boardRef:a$1(e),enrichedCard:he,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,P)),"task-initiated"}if(w.some(S=>{let y=S.outputFile;if(typeof y!="string"||!y)return false;let T=$(y),_=T.queueRequestedToken??T.lastRequestedToken??q;return q$1(T,_)==="in-flight"}))return "task-initiated";let ce=k.provides??[],ie={};for(let{bindTo:S,ref:y}of ce)ie[S]=a$3.resolve(W,y);return (d??(()=>{}))(ie),r$1(f.nodeId,ie),P.length>0&&await a.executionRequestStore.appendEntries(o,P),"task-initiated"}}function Gt(e$1,o,a$3={}){d(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d$1=a$1(e$1),f$1=a$3.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),P=null,k=a$3.boardRuntimeStoreRef,m=a$3.scratchStoreRef,l=a$3.taskExecutorRef,R=a$3.chatHandlerFlow;function w$1(){if(!k)throw new Error(`Board at ${e$1.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return k}function B(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 x$1=()=>b$1(o.kvStorageForRef(w$1())),L=e$1.value,$=()=>b$2(a(()=>o.kvStorageForRef(w$1()),o.hashFn),"v1"),E=async()=>{let n=await x$1().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no outputs store configured.`);return Ct(o.kvStorageForRef(n))},M=async()=>{let n=await x$1().readCardStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no card store configured.`);let t=o.kvStorageForRef(n);return ot(at(nt(t),o.hashFn),s)};async function z(){return !!(await $().readSnapshot(L)).values[n]}async function Q(){let n$1=await $().readSnapshot(L);if(!n$1.values[n])throw new Error(`Board not initialized at ${e$1.value}`);return w(n$1.values)}async function W(n,t){let c=await $().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:v(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let Y=()=>c(o.journalStorageForRef(w$1()));async function he(){return l??await x$1().readTaskExecutorRef()}async function q$1(n){await Y().appendEvent(n);}async function de(){let n=await x$1().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 X(){return o.blobStorageForRef(await de())}async function se(){return Rt(await X(),n=>o.resolveBlob(n))}async function ce(n){let t=(await X()).keyRef?.(n);if(!t)throw new Error("configured fetched-sources store does not support keyRef");let c=await Promise.resolve(t);return a$1(c)}async function ie(){let n=kt(o.kvStorageForRef(w$1()),async(u,g)=>{let h=u.payload,O=(h.enrichedCard??{}).id??h.cardId??"unknown";await q$1({type:"task-failed",taskName:O,error:g,timestamp:N()});}),t$1=St(o.kvStorageForRef(w$1())),c=await X(),i=await se(),v=await M(),b=await E(),F=new Map,p$1=new Map,D=[],G=[],ne=[],ae=new Map,ue=new Set,Pe={async readRuntime(u){return F.get(u)??await t$1.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),be[u]=g;}},ct={async readSourceData(u,g){let h=`${u}/${g}`;return p$1.has(h)?p$1.get(h):await i.readSourceData(u,g)},ingestSourceDataStaged(u,g,h,V){return i.ingestSourceDataStaged(u,g,h,V)},async commitSourceData(u,g,h){let V=`${u}/.staged/${h}/${g}`,O=await c.read(V);if(O==null){let U=await Promise.resolve(c.keyRef?.(V));U&&(O=await o.resolveBlob(U));}if(O==null)return false;let J=`${u}/${g}`,ee=O.trim();try{p$1.set(J,JSON.parse(ee));}catch{p$1.set(J,ee);}return D.push({cardId:u,outputFile:g,deliveryToken:h}),true},async hasSource(u,g){let h=`${u}/${g}`;return p$1.has(h)||await i.hasSource(u,g)},async listSources(u){let g=await i.listSources(u),h=[...p$1.keys()].filter(V=>V.startsWith(`${u}/`)).map(V=>V.slice(`${u}/`.length));return [...new Set([...g,...h])]}},ve=await Q(),mt=q(ve.graph),be={...ve.runtimeByCardId},{events:lt,newCursor:Ae}=await Y().readEntriesAfterCursor(ve.lastDrainedJournalId),me=lt,le=u$1(mt,{handlers:{"card-handler":wt(e$1,Ae,{cardStore:v,cardRuntimeStore:Pe,fetchedSourcesStore:ct,executionRequestStore:n},(u,g)=>{me.push({type:"task-completed",taskName:u,data:g,timestamp:N()});},(u,g)=>{G.push({cardId:u,values:g});},u=>{ne.push(u);})},onNodeRemoved:u=>{ae.delete(u),F.delete(u),delete be[u],ue.add(u);}});for(;me.length>0;){let u=me;me=[];for(let g of u)if(g.type==="task-restart"){let h=await v.readCard(g.taskName);h&&ae.set(g.taskName,h);}le.pushAll(u),await le.waitForHandlers();}let Be=le.getState();await le.dispose({wait:true}),await W({lastDrainedJournalId:Ae,graph:p(Be),runtimeByCardId:be},(await $().readSnapshot(L)).version);for(let{cardId:u,values:g}of G)await b.writeComputedValues(u,g);for(let u of ne)await b.writeDataObjects(u);for(let[u,g]of F)await t$1.writeRuntime(u,g);for(let u of D)await i.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let qe=t(d$1,Be);await b.writeStatusSnapshot(qe);let oe=[];for(let{cardId:u,values:g}of G)oe.push({kind:"computed_values",cardId:u,values:g});for(let u of ne)for(let[g,h]of Object.entries(u))oe.push({kind:"data_object",key:g,payload:h});for(let[u,g]of ae)oe.push({kind:"card_refreshed",cardId:u,card:g});for(let u of ue)oe.push({kind:"card_removed",cardId:u});oe.push({kind:"status",status:qe}),await B(oe);let Z=await he();if(!Z)return;let Ee=o.supportsDirectSourceOutput?.(Z)===true;await n.dispatchEntriesForJournalId(Ae,async u=>{if(u.taskKind!=="source-fetch"){s(`[async-process-accumulated-events] unknown taskKind "${u.taskKind}" \u2014 skipping`);return}let g=u.payload,h=g.enrichedCard?.id??"unknown",V=g.enrichedCard?.source_defs??[];if(Z.howToRun==="queue-storage"&&Ee){try{let O=await x$1().readQueueStoreRef();if(!O)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let J=o.queueStorageForRef(O,"task-executor"),ee=typeof Z.extra?.boardId=="string"?Z.extra.boardId:void 0,U=[];for(let H of V){if(!H.outputFile)continue;let fe=o.genId(),ge=`${h}/.staged/${fe}/${H.outputFile}`,Ne=await Promise.resolve(c.keyRef?.(ge));if(!Ne)continue;let _e={ref:a$1(Ne),deliveryToken:fe,outputFile:H.outputFile,cardId:h},ft=it({cbk:g.callbackToken,rg:e$1.value,br:a$1(e$1),cid:h,b:H.bindTo,d:H.outputFile,cs:void 0,rqt:g.rqt,dt:_e.deliveryToken});U.push({...ee?{boardId:ee}:{},ref:Z,args:{source_def:H,base_ref:a$1(e$1),callback:r.createCallback(ft),output:_e}});}U.length>0&&await J.enqueueMany(U);}catch(O){await q$1({type:"task-failed",taskName:h,error:O instanceof Error?O.message:String(O),timestamp:N()});}return}for(let O of V){if(!O.outputFile)continue;let J;if(Ee){let H=o.genId(),fe=`${h}/.staged/${H}/${O.outputFile}`,ge=await Promise.resolve(c.keyRef?.(fe));ge&&(J={ref:a$1(ge),deliveryToken:H,outputFile:O.outputFile,cardId:h});}let ee=it({cbk:g.callbackToken,rg:e$1.value,br:a$1(e$1),cid:h,b:O.bindTo,d:O.outputFile,cs:void 0,rqt:g.rqt,...J?{dt:J.deliveryToken}:{}}),U=await o.dispatchExecution(Z,{source_def:O,base_ref:a$1(e$1),callback:r.createCallback(ee),...J?{output:J}:{}});U.dispatched||await q$1({type:"task-failed",taskName:h,error:U.error??"dispatch failed",timestamp:N()});}});}async function S(){try{let n=async()=>{let c=await Q(),{events:i}=await Y().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await T();},t=await et(o.lock,ie,n);return A({ran:t!==!1})}catch(n){return I(n)}}async function y(){return P||(P=S().finally(()=>{P=null;}),P)}async function T(){let n=await x$1().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");t.enqueueIfAbsent?await t.enqueueIfAbsent({boardRef:a$1(e$1)},`process-accumulated:${a$1(e$1)}`):await t.enqueue({boardRef:a$1(e$1)}),await o.requestProcessAccumulated?.();}async function _(){let n=await x$1().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 j(){T();}return {async init(n){try{let t$1=n.params?.cardStoreRef;if(!t$1)return C("init requires params.cardStoreRef");if(k=n.params?.boardRuntimeStoreRef,!k)return C("init requires params.boardRuntimeStoreRef");let c=n.params?.outputsStoreRef;if(!c)return C("init requires params.outputsStoreRef");let i=n.params?.queueStoreRef;if(!i)return C("init requires params.queueStoreRef");let v=n.params?.fetchedSourcesStoreRef;if(!v)return C("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let b=n.params?.chatStoreRef;if(!b)return C("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return C("init requires params.artifactsStoreRef");await z()||await W({lastDrainedJournalId:"",graph:p(a$2(u)),runtimeByCardId:{}},null);let p$1=x$1();return await p$1.writeBoardRuntimeStoreRef(k),await p$1.writeCardStoreRef(t$1),await p$1.writeOutputsStoreRef(c),await p$1.writeQueueStoreRef(i),await p$1.writeFetchedSourcesStoreRef(v),await p$1.writeChatStoreRef(b),await p$1.writeArtifactsStoreRef(F),await(await E()).writeStatusSnapshot(t(d$1,q((await Q()).graph))),A()}catch(t){return I(t)}},async status(n){try{let t$1=await E(),c=await t$1.readStatusSnapshot();return c||(c=t(d$1,q((await Q()).graph)),await t$1.writeStatusSnapshot(c)),A(c)}catch(t){return I(t)}},async getCardStoreRef(n){try{let t=await x$1().readCardStoreRef();return t?A({storeRef:t}):C(`Board at ${e$1.value} has no card store configured`)}catch(t){return I(t)}},async getBoardRuntimeStoreRef(n){try{return A({storeRef:k??null})}catch(t){return I(t)}},async getOutputsStoreRef(n){try{let t=await x$1().readOutputsStoreRef();return t?A({storeRef:t}):C(`Board at ${e$1.value} has no outputs store configured`)}catch(t){return I(t)}},async getScratchStoreRef(n){try{return A({storeRef:m??null})}catch(t){return I(t)}},async getChatStoreRef(n){try{return A({storeRef:await x$1().readChatStoreRef()})}catch(t){return I(t)}},async getArtifactsStoreRef(n){try{return A({storeRef:await x$1().readArtifactsStoreRef()})}catch(t){return I(t)}},async getFetchedSourcesStoreRef(n){try{return A({storeRef:await x$1().readFetchedSourcesStoreRef()})}catch(t){return I(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return C("getConfig requires params.key");let c=x$1(),i;switch(t){case "task-executor":i=l??null;break;case "chat-handler-flow":i=R??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 C(`getConfig: unknown key "${t}"`)}return A({value:i})}catch(t){return I(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;return t?A(await(await E()).readDataObject(t)):C("getOutputsDataObject requires params.key")}catch(t){return I(t)}},async getAllOutputsDataObjects(n){try{return A(await(await E()).readAllDataObjects())}catch(t){return I(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?A(await(await E()).readComputedValues(t)):C("getOutputsComputedValues requires params.key")}catch(t){return I(t)}},async getAllOutputsComputedValues(n){try{return A(await(await E()).readAllComputedValues())}catch(t){return I(t)}},async getOutputsFetchedSources(n){try{let t=n.params?.key;if(!t)return C("getOutputsFetchedSources requires params.key");let c=await(await se()).listSources(t),i={};for(let v of c)i[v]=await ce(`${t}/${v}`);return A(i)}catch(t){return I(t)}},async getAllOutputsFetchedSources(n){try{let t=await se(),c=await(await X()).listKeys(),i=new Set;for(let b of c){let F=b.indexOf("/");F>0&&!b.includes("/.staged/")&&i.add(b.slice(0,F));}let v={};for(let b of i){let F=await t.listSources(b);if(F.length!==0){v[b]={};for(let p of F)v[b][p]=await ce(`${b}/${p}`);}}return A(v)}catch(t){return I(t)}},async buildSseOneShotPayload(n){try{let t=await(await M()).readAllCards(),c=await this.status({});if(c.status!=="success")return c;let i=await this.getAllOutputsDataObjects({});if(i.status!=="success")return i;let v=await this.getAllOutputsComputedValues({});if(v.status!=="success")return v;let b=v.data,F={};for(let p of t){let D=typeof p?.id=="string"?p.id:null;if(!D)continue;let G=p.card_data&&typeof p.card_data=="object"&&!Array.isArray(p.card_data)?p.card_data:{};F[D]={schema_version:"v1",card_id:D,card_data:{...G},computed_values:b[D]&&typeof b[D]=="object"?b[D]:{}};}return A({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i.data,cardRuntimeById:F})}catch(t){return I(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return C("addCardFiles requires params.cardId");let i=await st(await M(),{emitNotification:f$1}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:A({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return I(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return C("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await q$1({type:"task-removal",taskName:t,timestamp:N()}),j(),A()}catch(t){return I(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await q$1({type:"task-restart",taskName:t,timestamp:N()}),j(),A()):C("retrigger requires params.id")}catch(t){return I(t)}},async processAccumulatedEvents(n){return await _(),y()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i=!!n.params?.restart;if(!t&&!c)return C("upsertCard requires --card-id <id> or --all");let v=await M(),b=c?(await v.readAllCards()).map(p=>p.id):[t];for(let p of b)if(!await v.readCard(p))return C(`Card "${p}" not found in board at ${e$1.value}`);let F=o.kvStorage("card-upsert");for(let p of b){let D=await v.readCard(p);if(!D)continue;let G=x(D),ne=o.hashFn(G),ae=await F.read(p),ue=ae?.taskConfigHash!==ne;if(!(!ue&&!i)){if(ue){let Pe=ae?.blobRef??await v.readCardKey(p)??p;await q$1({type:"task-upsert",taskName:p,taskConfig:G,timestamp:N()}),await F.write(p,{blobRef:Pe,taskConfigHash:ne,updatedAt:N()});}i&&await q$1({type:"task-restart",taskName:p,timestamp:N()});}}return j(),A()}catch(t){return I(t)}},async taskFailed(n){try{let t=n.params?.token;if(!t)return C("taskFailed requires params.token");let c=n.params?.error??"unknown error",i=we(t);return i?(await q$1({type:"task-failed",taskName:i.taskName,error:c,timestamp:N()}),j(),A()):C("Invalid callback token")}catch(t){return I(t)}},async taskProgress(n){try{let t=n.params?.token;if(!t)return C("taskProgress requires params.token");let c=(n.body??{}).update??{},i=we(t);return i?(await q$1({type:"task-progress",taskName:i.taskName,update:c,timestamp:N()}),j(),A()):C("Invalid callback token")}catch(t){return I(t)}},async sourceDataFetched(n){try{let t=n.params?.token,c=n.params?.ref;if(!t)return C("sourceDataFetched requires params.token");if(!c)return C("sourceDataFetched requires params.ref");let i=ut(t);if(!i)return C("Invalid source token");let v=await se(),b$1=i.dt||o.genId();i.dt||await v.ingestSourceDataStaged(i.cid,i.d,b(c),b$1);let F=we(i.cbk);return F?(await q$1({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:N(),deliveryToken:b$1,sourceChecksum:i.cs,rqt:i.rqt},timestamp:N()}),j(),A()):C("Invalid callback token embedded in source token")}catch(t){return I(t)}},async sourceDataFetchFailure(n){try{let t=n.params?.token,c=n.params?.reason??"unknown";if(!t)return C("sourceDataFetchFailure requires params.token");let i=ut(t);if(!i)return C("Invalid source token");let v=we(i.cbk);return v?(await q$1({type:"task-progress",taskName:v.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:N()}),j(),A()):C("Invalid callback token embedded in source token")}catch(t){return I(t)}}}}
|
|
2
|
-
export{et as a,nt as b,at as c,ot as d,At as e,It as f,st as g,Bt as h,Gt as i};//# sourceMappingURL=chunk-
|
|
3
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {b as b$1}from'./chunk-6MD6FVE3.js';import {a,d,x,t,u,n,w,v,k,b as b$2,c,h,i,j,o,s,r,q as q$1,p as p$1}from'./chunk-H5FKNSCO.js';import {a as a$1,b}from'./chunk-44L64VQ2.js';import {q,p,a as a$2,u as u$1}from'./chunk-VGT3TRQG.js';import {a as a$3}from'./chunk-ATOQP3BD.js';import {e,f}from'./chunk-UGB7PC4P.js';async function et(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function gt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Ce(e,o){return gt(e)?e.then(o):o(e)}function tt(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]=tt(a[r],s):a[r]=s;return a}function ke(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]:ke(d,s,a)}}function rt(e){return {read:a=>e.read(a),get(a,r){return Ce(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 Ce(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return Ce(e.read(a),s=>e.write(a,tt(s??{},r)))},patch(a,r,s){return Ce(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,ke(d??{},f,s))})}}}function nt(e){return rt(e)}function at(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 ot(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,P]of Object.entries(s))r[f]!==P.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],P=Object.entries(d).find(([,k])=>k.key===s);return f&&f.key!==s?{ok:false,error:`Card id "${r}" is already mapped to key "${f.key}", cannot remap to "${s}"`}:P&&P[0]!==r?{ok:false,error:`Key "${s}" is already mapped to card id "${P[0]}", cannot remap to "${r}"`}:{ok:true}},async writeCard(r,s,d){let f=await a(),P=d??f[r]?.key??e.defaultCardKey(r),k=await e.writeCard(P,s);f[r]={key:P,checksum:k,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async patchCard(r,s,d){let f=await a(),P=f[r];if(!P||!await e.cardExists(P.key))throw new Error(`card "${r}" not found`);let k=await e.readCard(P.key);if(!k||typeof k!="object"||Array.isArray(k))throw new Error(`card "${r}" is not patchable`);let m=String(s||"").split(".").filter(Boolean),l=ke(k,m,d),R=await e.writeCard(P.key,l);f[r]={key:P.key,checksum:R,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 At(e,o){return a(e,o)}function It(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 R=e(m);if(R.length===1){await l(R[0]);return}await l(f({kind:"notification-batch",notifications:R}));}async function f$1(m){let l=m.params?.id;if(l){let R=await e$1.readCard(l);if(!R)throw new Error(`card "${l}" not found`);return [R]}return await e$1.readAllCards()}function P(m){return f({kind:"notification-batch",notifications:e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function k(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(P(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 R=Array.isArray(l)?l:[l];for(let w of R){if(typeof w.id!="string")return r("each card must have a string `id` field");await e$1.writeCard(w.id,w);}return await d(R.map(w=>({kind:"card_refreshed",cardId:w.id,card:w}))),a({count:R.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],R=m.params?.id,w=R?[...l,R]:l;if(w.length===0)return r("del requires body.ids (string[]) or params.id");for(let B of w)await e$1.removeCard(B);return await d(w.map(B=>({kind:"card_removed",cardId:B}))),a({count:w.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,R=m.params?.path;if(!l)return r("patch requires params.id");if(!R)return r("patch requires params.path");let w=m.body,B=w&&Object.prototype.hasOwnProperty.call(w,"value")?w.value:m.body;await e$1.patchCard(l,R,B);let x=await e$1.readCard(l);return x?(await d([{kind:"card_refreshed",cardId:l,card:x}]),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 R=await e$1.readCard(l);if(!R)return r(`card "${l}" not found`);let w=k(m.body);if(!w||w.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let B=R.card_data&&typeof R.card_data=="object"&&!Array.isArray(R.card_data)?R.card_data:{},x=Array.isArray(B.files)?B.files:[],L=[...x,...w],$=w.map((M,z)=>({idx:x.length+z,entry:M})),E=await this.patch({params:{id:l,path:"card_data.files"},body:{value:L}});return E.status!=="success"?E:a({files_added:$})}catch(l){return s(l)}}}}async function pt(e,o){return (await e.peekActive()).find(a=>a.id===o)}function Bt(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 pt(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 A(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function C(e){return {status:"fail",error:e}}function I(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function N(){return new Date().toISOString()}function yt(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 dt(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 we(e){try{let o=JSON.parse(dt(e));return typeof o?.t=="string"?{taskName:o.t}:null}catch{return null}}function it(e){return yt(JSON.stringify(e))}function ut(e){try{let o=JSON.parse(dt(e));return typeof o?.cbk=="string"&&typeof o?.cid=="string"&&typeof o?.b=="string"&&typeof o?.d=="string"?o:null}catch{return null}}function St(e){return j(e,o,()=>({_sources:{}}))}function Rt(e,o){return h(e,o)}function Ct(e){return k(e)}function kt(e,o){return i(e,o)}function wt(e,o,a,r$1,s$1,d){return async f=>{let P=[],k=await a.cardStore.readCard(f.nodeId);if(!k)return "task-initiate-failure";let m=k.id,l=k.card_data??{},R=k.source_defs??[],w=R,B=await a.cardRuntimeStore.readRuntime(m),x=false,L=async()=>{x&&(await a.cardRuntimeStore.writeRuntime(m,B),x=false);},$=S=>p$1(B._sources[S]),E=(S,y)=>{B._sources[S]=p$1(y),x=true;},M=f.taskState?.executionCount??0;if(B._lastExecutionCount!==M&&(B._sources={},B._lastExecutionCount=M,x=true),f.update){let S=f.update.outputFile;if(S){let y=$(S);if(f.update.failure){let T=f.update.rqt??y.lastRequestedToken??y.queueRequestedToken;T&&E(S,s(y,T));}else {let T=f.update.rqt;if(!y.lastCompletedToken||T>y.lastCompletedToken){let _=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,j=_?await a.fetchedSourcesStore.commitSourceData(m,S,_):false;E(S,j?r(y,T):s(y,T));}}await L();}}let z={};for(let S of R){if(!S.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,S.outputFile);y!==null&&(z[S.bindTo]=y);}let Q={};for(let[S,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let T=y[S];Q[S]=T!==void 0?T:y;}else Q[S]=y;let W={id:m,card_data:{...l},requires:Q,source_defs:R,compute:k.compute};W._sourcesData=z,k.compute&&a$3.runSync(W,{sourcesData:z}),(s$1??(()=>{}))(m,W.computed_values??{});let Y=a$3.enrichSourcesSync(Array.isArray(k.source_defs)?k.source_defs:void 0,{card_data:k.card_data,requires:Q}),he={...k,source_defs:Array.isArray(Y)?Y.map(S=>({...S,boardDir:typeof S.boardDir=="string"&&S.boardDir?S.boardDir:e.value})):Y},q=N(),de=f.update?void 0:q,X=w.filter(S=>{let y=S.outputFile;if(typeof y!="string"||!y)return true;let T=$(y);de&&(T={...T,queueRequestedToken:de},E(y,T));let _=T.queueRequestedToken??T.lastRequestedToken??q;return q$1(T,_)==="dispatch"});if(await L(),X.length>0){let S=false,y=q;for(let T of X){let _=T.outputFile;if(typeof _!="string"||!_)continue;let j=$(_),n=j.queueRequestedToken??q;E(_,{...j,lastRequestedToken:n}),y=n,S=true;}return S&&await L(),S&&(P.push({taskKind:"source-fetch",payload:{boardRef:a$1(e),enrichedCard:he,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,P)),"task-initiated"}if(w.some(S=>{let y=S.outputFile;if(typeof y!="string"||!y)return false;let T=$(y),_=T.queueRequestedToken??T.lastRequestedToken??q;return q$1(T,_)==="in-flight"}))return "task-initiated";let ce=k.provides??[],ie={};for(let{bindTo:S,ref:y}of ce)ie[S]=a$3.resolve(W,y);return (d??(()=>{}))(ie),r$1(f.nodeId,ie),P.length>0&&await a.executionRequestStore.appendEntries(o,P),"task-initiated"}}function Gt(e$1,o,a$3={}){d(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d$1=a$1(e$1),f$1=a$3.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),P=null,k=a$3.boardRuntimeStoreRef,m=a$3.scratchStoreRef,l=a$3.taskExecutorRef,R=a$3.chatHandlerFlow;function w$1(){if(!k)throw new Error(`Board at ${e$1.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return k}function B(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 x$1=()=>b$1(o.kvStorageForRef(w$1())),L=e$1.value,$=()=>b$2(a(()=>o.kvStorageForRef(w$1()),o.hashFn),"v1"),E=async()=>{let n=await x$1().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no outputs store configured.`);return Ct(o.kvStorageForRef(n))},M=async()=>{let n=await x$1().readCardStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no card store configured.`);let t=o.kvStorageForRef(n);return ot(at(nt(t),o.hashFn),s)};async function z(){return !!(await $().readSnapshot(L)).values[n]}async function Q(){let n$1=await $().readSnapshot(L);if(!n$1.values[n])throw new Error(`Board not initialized at ${e$1.value}`);return w(n$1.values)}async function W(n,t){let c=await $().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:v(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let Y=()=>c(o.journalStorageForRef(w$1()));async function he(){return l??await x$1().readTaskExecutorRef()}async function q$1(n){await Y().appendEvent(n);}async function de(){let n=await x$1().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 X(){return o.blobStorageForRef(await de())}async function se(){return Rt(await X(),n=>o.resolveBlob(n))}async function ce(n){let t=(await X()).keyRef?.(n);if(!t)throw new Error("configured fetched-sources store does not support keyRef");let c=await Promise.resolve(t);return a$1(c)}async function ie(){let n=kt(o.kvStorageForRef(w$1()),async(u,g)=>{let h=u.payload,O=(h.enrichedCard??{}).id??h.cardId??"unknown";await q$1({type:"task-failed",taskName:O,error:g,timestamp:N()});}),t$1=St(o.kvStorageForRef(w$1())),c=await X(),i=await se(),v=await M(),b=await E(),F=new Map,p$1=new Map,D=[],G=[],ne=[],ae=new Map,ue=new Set,Pe={async readRuntime(u){return F.get(u)??await t$1.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),be[u]=g;}},ct={async readSourceData(u,g){let h=`${u}/${g}`;return p$1.has(h)?p$1.get(h):await i.readSourceData(u,g)},ingestSourceDataStaged(u,g,h,V){return i.ingestSourceDataStaged(u,g,h,V)},async commitSourceData(u,g,h){let V=`${u}/.staged/${h}/${g}`,O=await c.read(V);if(O==null){let U=await Promise.resolve(c.keyRef?.(V));U&&(O=await o.resolveBlob(U));}if(O==null)return false;let J=`${u}/${g}`,ee=O.trim();try{p$1.set(J,JSON.parse(ee));}catch{p$1.set(J,ee);}return D.push({cardId:u,outputFile:g,deliveryToken:h}),true},async hasSource(u,g){let h=`${u}/${g}`;return p$1.has(h)||await i.hasSource(u,g)},async listSources(u){let g=await i.listSources(u),h=[...p$1.keys()].filter(V=>V.startsWith(`${u}/`)).map(V=>V.slice(`${u}/`.length));return [...new Set([...g,...h])]}},ve=await Q(),mt=q(ve.graph),be={...ve.runtimeByCardId},{events:lt,newCursor:Ae}=await Y().readEntriesAfterCursor(ve.lastDrainedJournalId),me=lt,le=u$1(mt,{handlers:{"card-handler":wt(e$1,Ae,{cardStore:v,cardRuntimeStore:Pe,fetchedSourcesStore:ct,executionRequestStore:n},(u,g)=>{me.push({type:"task-completed",taskName:u,data:g,timestamp:N()});},(u,g)=>{G.push({cardId:u,values:g});},u=>{ne.push(u);})},onNodeRemoved:u=>{ae.delete(u),F.delete(u),delete be[u],ue.add(u);}});for(;me.length>0;){let u=me;me=[];for(let g of u)if(g.type==="task-restart"){let h=await v.readCard(g.taskName);h&&ae.set(g.taskName,h);}le.pushAll(u),await le.waitForHandlers();}let Be=le.getState();await le.dispose({wait:true}),await W({lastDrainedJournalId:Ae,graph:p(Be),runtimeByCardId:be},(await $().readSnapshot(L)).version);for(let{cardId:u,values:g}of G)await b.writeComputedValues(u,g);for(let u of ne)await b.writeDataObjects(u);for(let[u,g]of F)await t$1.writeRuntime(u,g);for(let u of D)await i.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let qe=t(d$1,Be);await b.writeStatusSnapshot(qe);let oe=[];for(let{cardId:u,values:g}of G)oe.push({kind:"computed_values",cardId:u,values:g});for(let u of ne)for(let[g,h]of Object.entries(u))oe.push({kind:"data_object",key:g,payload:h});for(let[u,g]of ae)oe.push({kind:"card_refreshed",cardId:u,card:g});for(let u of ue)oe.push({kind:"card_removed",cardId:u});oe.push({kind:"status",status:qe}),await B(oe);let Z=await he();if(!Z)return;let Ee=o.supportsDirectSourceOutput?.(Z)===true;await n.dispatchEntriesForJournalId(Ae,async u=>{if(u.taskKind!=="source-fetch"){s(`[async-process-accumulated-events] unknown taskKind "${u.taskKind}" \u2014 skipping`);return}let g=u.payload,h=g.enrichedCard?.id??"unknown",V=g.enrichedCard?.source_defs??[];if(Z.howToRun==="queue-storage"&&Ee){try{let O=await x$1().readQueueStoreRef();if(!O)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let J=o.queueStorageForRef(O,"task-executor"),ee=typeof Z.extra?.boardId=="string"?Z.extra.boardId:void 0,U=[];for(let H of V){if(!H.outputFile)continue;let fe=o.genId(),ge=`${h}/.staged/${fe}/${H.outputFile}`,Ne=await Promise.resolve(c.keyRef?.(ge));if(!Ne)continue;let _e={ref:a$1(Ne),deliveryToken:fe,outputFile:H.outputFile,cardId:h},ft=it({cbk:g.callbackToken,rg:e$1.value,br:a$1(e$1),cid:h,b:H.bindTo,d:H.outputFile,cs:void 0,rqt:g.rqt,dt:_e.deliveryToken});U.push({...ee?{boardId:ee}:{},ref:Z,args:{source_def:H,base_ref:a$1(e$1),callback:r.createCallback(ft),output:_e}});}U.length>0&&await J.enqueueMany(U);}catch(O){await q$1({type:"task-failed",taskName:h,error:O instanceof Error?O.message:String(O),timestamp:N()});}return}for(let O of V){if(!O.outputFile)continue;let J;if(Ee){let H=o.genId(),fe=`${h}/.staged/${H}/${O.outputFile}`,ge=await Promise.resolve(c.keyRef?.(fe));ge&&(J={ref:a$1(ge),deliveryToken:H,outputFile:O.outputFile,cardId:h});}let ee=it({cbk:g.callbackToken,rg:e$1.value,br:a$1(e$1),cid:h,b:O.bindTo,d:O.outputFile,cs:void 0,rqt:g.rqt,...J?{dt:J.deliveryToken}:{}}),U=await o.dispatchExecution(Z,{source_def:O,base_ref:a$1(e$1),callback:r.createCallback(ee),...J?{output:J}:{}});U.dispatched||await q$1({type:"task-failed",taskName:h,error:U.error??"dispatch failed",timestamp:N()});}});}async function S(){try{let n=async()=>{let c=await Q(),{events:i}=await Y().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await T();},t=await et(o.lock,ie,n);return A({ran:t!==!1})}catch(n){return I(n)}}async function y(){return P||(P=S().finally(()=>{P=null;}),P)}async function T(){let n=await x$1().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");t.enqueueIfAbsent?await t.enqueueIfAbsent({boardRef:a$1(e$1)},`process-accumulated:${a$1(e$1)}`):await t.enqueue({boardRef:a$1(e$1)}),await o.requestProcessAccumulated?.();}async function _(){let n=await x$1().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 j(){T();}return {async init(n){try{let t$1=n.params?.cardStoreRef;if(!t$1)return C("init requires params.cardStoreRef");if(k=n.params?.boardRuntimeStoreRef,!k)return C("init requires params.boardRuntimeStoreRef");let c=n.params?.outputsStoreRef;if(!c)return C("init requires params.outputsStoreRef");let i=n.params?.queueStoreRef;if(!i)return C("init requires params.queueStoreRef");let v=n.params?.fetchedSourcesStoreRef;if(!v)return C("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let b=n.params?.chatStoreRef;if(!b)return C("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return C("init requires params.artifactsStoreRef");await z()||await W({lastDrainedJournalId:"",graph:p(a$2(u)),runtimeByCardId:{}},null);let p$1=x$1();return await p$1.writeBoardRuntimeStoreRef(k),await p$1.writeCardStoreRef(t$1),await p$1.writeOutputsStoreRef(c),await p$1.writeQueueStoreRef(i),await p$1.writeFetchedSourcesStoreRef(v),await p$1.writeChatStoreRef(b),await p$1.writeArtifactsStoreRef(F),await(await E()).writeStatusSnapshot(t(d$1,q((await Q()).graph))),A()}catch(t){return I(t)}},async status(n){try{let t$1=await E(),c=await t$1.readStatusSnapshot();return c||(c=t(d$1,q((await Q()).graph)),await t$1.writeStatusSnapshot(c)),A(c)}catch(t){return I(t)}},async getCardStoreRef(n){try{let t=await x$1().readCardStoreRef();return t?A({storeRef:t}):C(`Board at ${e$1.value} has no card store configured`)}catch(t){return I(t)}},async getBoardRuntimeStoreRef(n){try{return A({storeRef:k??null})}catch(t){return I(t)}},async getOutputsStoreRef(n){try{let t=await x$1().readOutputsStoreRef();return t?A({storeRef:t}):C(`Board at ${e$1.value} has no outputs store configured`)}catch(t){return I(t)}},async getScratchStoreRef(n){try{return A({storeRef:m??null})}catch(t){return I(t)}},async getChatStoreRef(n){try{return A({storeRef:await x$1().readChatStoreRef()})}catch(t){return I(t)}},async getArtifactsStoreRef(n){try{return A({storeRef:await x$1().readArtifactsStoreRef()})}catch(t){return I(t)}},async getFetchedSourcesStoreRef(n){try{return A({storeRef:await x$1().readFetchedSourcesStoreRef()})}catch(t){return I(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return C("getConfig requires params.key");let c=x$1(),i;switch(t){case "task-executor":i=l??null;break;case "chat-handler-flow":i=R??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 C(`getConfig: unknown key "${t}"`)}return A({value:i})}catch(t){return I(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;return t?A(await(await E()).readDataObject(t)):C("getOutputsDataObject requires params.key")}catch(t){return I(t)}},async getAllOutputsDataObjects(n){try{return A(await(await E()).readAllDataObjects())}catch(t){return I(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?A(await(await E()).readComputedValues(t)):C("getOutputsComputedValues requires params.key")}catch(t){return I(t)}},async getAllOutputsComputedValues(n){try{return A(await(await E()).readAllComputedValues())}catch(t){return I(t)}},async getOutputsFetchedSources(n){try{let t=n.params?.key;if(!t)return C("getOutputsFetchedSources requires params.key");let c=await(await se()).listSources(t),i={};for(let v of c)i[v]=await ce(`${t}/${v}`);return A(i)}catch(t){return I(t)}},async getAllOutputsFetchedSources(n){try{let t=await se(),c=await(await X()).listKeys(),i=new Set;for(let b of c){let F=b.indexOf("/");F>0&&!b.includes("/.staged/")&&i.add(b.slice(0,F));}let v={};for(let b of i){let F=await t.listSources(b);if(F.length!==0){v[b]={};for(let p of F)v[b][p]=await ce(`${b}/${p}`);}}return A(v)}catch(t){return I(t)}},async buildSseOneShotPayload(n){try{let t=await(await M()).readAllCards(),c=await this.status({});if(c.status!=="success")return c;let i=await this.getAllOutputsDataObjects({});if(i.status!=="success")return i;let v=await this.getAllOutputsComputedValues({});if(v.status!=="success")return v;let b=v.data,F={};for(let p of t){let D=typeof p?.id=="string"?p.id:null;if(!D)continue;let G=p.card_data&&typeof p.card_data=="object"&&!Array.isArray(p.card_data)?p.card_data:{};F[D]={schema_version:"v1",card_id:D,card_data:{...G},computed_values:b[D]&&typeof b[D]=="object"?b[D]:{}};}return A({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i.data,cardRuntimeById:F})}catch(t){return I(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return C("addCardFiles requires params.cardId");let i=await st(await M(),{emitNotification:f$1}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:A({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return I(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return C("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await q$1({type:"task-removal",taskName:t,timestamp:N()}),j(),A()}catch(t){return I(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await q$1({type:"task-restart",taskName:t,timestamp:N()}),j(),A()):C("retrigger requires params.id")}catch(t){return I(t)}},async processAccumulatedEvents(n){return await _(),y()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i=!!n.params?.restart;if(!t&&!c)return C("upsertCard requires --card-id <id> or --all");let v=await M(),b=c?(await v.readAllCards()).map(p=>p.id):[t];for(let p of b)if(!await v.readCard(p))return C(`Card "${p}" not found in board at ${e$1.value}`);let F=o.kvStorage("card-upsert");for(let p of b){let D=await v.readCard(p);if(!D)continue;let G=x(D),ne=o.hashFn(G),ae=await F.read(p),ue=ae?.taskConfigHash!==ne;if(!(!ue&&!i)){if(ue){let Pe=ae?.blobRef??await v.readCardKey(p)??p;await q$1({type:"task-upsert",taskName:p,taskConfig:G,timestamp:N()}),await F.write(p,{blobRef:Pe,taskConfigHash:ne,updatedAt:N()});}i&&await q$1({type:"task-restart",taskName:p,timestamp:N()});}}return j(),A()}catch(t){return I(t)}},async taskFailed(n){try{let t=n.params?.token;if(!t)return C("taskFailed requires params.token");let c=n.params?.error??"unknown error",i=we(t);return i?(await q$1({type:"task-failed",taskName:i.taskName,error:c,timestamp:N()}),j(),A()):C("Invalid callback token")}catch(t){return I(t)}},async taskProgress(n){try{let t=n.params?.token;if(!t)return C("taskProgress requires params.token");let c=(n.body??{}).update??{},i=we(t);return i?(await q$1({type:"task-progress",taskName:i.taskName,update:c,timestamp:N()}),j(),A()):C("Invalid callback token")}catch(t){return I(t)}},async sourceDataFetched(n){try{let t=n.params?.token,c=n.params?.ref;if(!t)return C("sourceDataFetched requires params.token");if(!c)return C("sourceDataFetched requires params.ref");let i=ut(t);if(!i)return C("Invalid source token");let v=await se(),b$1=i.dt||o.genId();i.dt||await v.ingestSourceDataStaged(i.cid,i.d,b(c),b$1);let F=we(i.cbk);return F?(await q$1({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:N(),deliveryToken:b$1,sourceChecksum:i.cs,rqt:i.rqt},timestamp:N()}),j(),A()):C("Invalid callback token embedded in source token")}catch(t){return I(t)}},async sourceDataFetchFailure(n){try{let t=n.params?.token,c=n.params?.reason??"unknown";if(!t)return C("sourceDataFetchFailure requires params.token");let i=ut(t);if(!i)return C("Invalid source token");let v=we(i.cbk);return v?(await q$1({type:"task-progress",taskName:v.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:N()}),j(),A()):C("Invalid callback token embedded in source token")}catch(t){return I(t)}}}}
|
|
2
|
+
export{et as a,nt as b,at as c,ot as d,At as e,It as f,st as g,Bt as h,Gt as i};//# sourceMappingURL=chunk-5U5NMYGT.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-5U5NMYGT.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {a}from'./chunk-ATOQP3BD.js';function P(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 G(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 N(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 z(s,d){let u=n(s.view);return {elements:y(u.elements).map((g,h)=>{let R=n(g),b=n(R.data),k=typeof R.visible=="string"?!!N(d,R.visible):true,x=typeof b.bind=="string"?b.bind:void 0,S=typeof b.maxRows=="number"?b.maxRows:void 0,B=x?N(d,x):void 0,q={id:typeof R.id=="string"&&R.id?R.id:`element-${h}`,kind:R.kind,label:R.label,visible:k};return B!==void 0&&(q.resolved=Array.isArray(B)&&typeof S=="number"?B.slice(0,S):B),q})}}function Q(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"}],h={};for(let R of g){let b=n(R),k=typeof b.bindTo=="string"?b.bindTo:"",x=typeof b.ref=="string"?b.ref:"";if(!k||!x)continue;let S=N(d,x);S!==void 0&&(h[k]=S);}return h}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 j(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,h,R){let b=String(h||"").split(".").filter(Boolean);if(!b.length)return;let k=g;for(let x=0;x<b.length-1;x+=1){let S=b[x];(!k[S]||typeof k[S]!="object")&&(k[S]={}),k=k[S];}k[b[b.length-1]]=R;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let g=null,h=n(u.view),R=y(h.elements);for(let b of R){let k=n(n(b).data);if(typeof k.writeTo=="string"&&k.writeTo){g=k.writeTo;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,h]of Object.entries(d))g!=="_stagedFiles"&&(h!==null&&typeof h=="object"&&!Array.isArray(h)&&u[g]!==null&&typeof u[g]=="object"&&!Array.isArray(u[g])?u[g]={...u[g],...h}:u[g]=h);return u}function D(s){return n(s.__private).visible_controlplane_only===true}async function T(s,d){let u=await A(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:h,sourceFetchDone:R,sourceFetchFailed:b,uploadCardFile:k,buildFileDownloadUrl:x,readFetchedSourceJsonByRef:S}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function q(){let e=await A(p.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>n(r)).filter(r=>!D(r)):[]}function X(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 A(u.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:n(e.commonSourceDefFields),sourceKinds:n(e.sourceKinds)}}async function Z(){let e=n(await A(d.status({}),"status")),r=n(e.summary),t=y(e.cards),a=await A(p.get({}),"cardStore.get"),o=new Set((Array.isArray(a.cards)?a.cards.map(n):[]).filter(D).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 A(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 T(p,r)),c=j(i),l=y(o.requires_satisfied).filter(f=>typeof f=="string"&&!!f),I=y(o.provides_runtime).filter(f=>typeof f=="string"&&!!f),v=Object.fromEntries(await Promise.all(l.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),_=Object.fromEntries(await Promise.all(I.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),m=n(await A(d.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),C=await A(d.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),M=y(i.source_defs).map(n),w={};for(let f of M)typeof f.bindTo=="string"&&typeof f.outputFile=="string"&&(w[f.outputFile]=f.bindTo);let U={};for(let[f,F]of Object.entries(C)){let O=w[f]??f;if(!S||typeof F!="string"){U[O]=null;continue}try{U[O]=S({cardId:r,ref:F});}catch{U[O]=null;}}let L={card_data:n(i.card_data),requires:v,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:C,runtime_data:{requires:v,provides:_,computed_values:m,rendered_view:z(i,L)}}}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}:{}},I=Object.keys(l).length>0?{params:{cardId:r},body:l}:{params:{cardId:r}},v=P(await g.readAll(I),"chatStore.readAll"),_=n(await T(p,r)),m=y(n(_.card_data).files).map((w,U)=>({idx:U,stored_name:n(w).stored_name})).filter(w=>typeof w.stored_name=="string"&&w.stored_name.length>0),M=(Array.isArray(v.records)?v.records:[]).map(w=>{let L=n(w.payload),f={...w},F=typeof w?.role=="string"?w.role:typeof L.role=="string"?String(L.role):"",O=typeof w?.text=="string"?w.text:typeof L.text=="string"?String(L.text):"";if(F==="system"){let V=be(O);if(V!==null&&m.some(E=>E.idx===V)){let E=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${V}`;f.retrieval_hint=E,Object.keys(L).length>0&&typeof w.role!="string"&&(f.payload={...L,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 T(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:x({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 $(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(G(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:Q(a,o),rendered_view:z(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 T(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 A(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),I=n(r.computed_values),v={card_data:n(t.card_data),requires:e.mockRequires,fetched_sources:c,computed_values:I},_=[];for(let m of y(a.issues))typeof m=="string"&&m&&_.push(m);for(let m of o){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.error=="string"?C.error:"";w&&_.push(`${M}: ${w}`);}for(let m of i){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.key=="string"?C.key:"projection",U=typeof C.error=="string"?C.error:"projection failed";_.push(`${M}.${w}: ${U}`);}for(let m of l){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"compute",w=typeof C.error=="string"?C.error:"compute failed";_.push(`${M}: ${w}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:_,provides_outputs:Q(t,v),rendered_view:z(t,v)}}}async function K(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await A(p.get({params:{id:r}}),"cardStore.get");return (Array.isArray(t.cards)?t.cards.map(n):[]).map(o=>j(o))}async function W(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:X(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}`;P(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 W({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=P(await g.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),I=Array.isArray(l.records)?l.records.find(v=>v.role==="assistant"&&String(v.turn||"")===o):void 0;if(I)return {status:"success",data:{cardId:r,id:String(I.id),role:t,turn:o,files:Array.isArray(I.files)?I.files:[]}}}let i=await W({cardId:r,role:t,turn:o,files:e.files}),c=P(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 K({cardId:t}),i=n(o[0]),c=ve(i,a);return J({cardId:t,candidateCardContent:c},r)}async function J(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.candidateCardContent),o=j(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 $({candidateCardContent:o});}catch(m){let C=m instanceof Error?m.message:String(m);if(!/non-core adapter is not configured/i.test(C))throw m;i=null;}if(i!==null){let m=n(i),C=n(m.data);if(m.status!=="success"||C.isValid!==true)return {status:"fail",step:"validate",validation:i}}let c=null;try{c=await T(p,t);}catch{c=null;}let l=c?n(c):null;if(l&&D(l)&&!r.allowControlplaneOnlyCards)throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404});let I={...o,...l&&he(l,"__private")?{__private:l.__private}:{}},v=await p.set({body:I});P(v,"cardStore.set");let _;try{_=await d.upsertCard({params:{cardId:t,restart:!0}}),P(_,"upsertCard");}catch(m){try{c&&await p.set({body:c});}catch{}throw m}return {status:"success",data:{validation:i,card_saved:null,board_result:_}}}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 A(p.get({params:{id:t}}),"cardStore.get");if((Array.isArray(i.cards)?i.cards.map(n):[]).some(D))throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404})}let a=await d.removeCard({params:{id:t}});P(a,"removeCard");let o=await p.del({params:{id:t}});return P(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 A(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=j(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 $({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 T(p,r);}catch{l=null;}let I=l?n(n(l).__private):{},v={...a,__private:{...I,visible_controlplane_only:true}},_=await p.set({body:v});P(_,"cardStore.set");let m;try{m=await d.upsertCard({params:{cardId:r,restart:!0}}),P(m,"upsertCard");}catch(C){try{l&&await p.set({body:l});}catch{}throw C}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=G(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 P(await g.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function Ce(){let e=await B(h,"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 we(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 B(R,"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 B(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:q,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:$,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:K,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:J,manageRemoveCard:le,adminReadCard:pe,adminUpsertCard:me,getChatProcessing:fe,setChatProcessing:ge,webhookProcessAccumulated:Ce,webhookSourceFetchDone:we,webhookSourceFetchFailed:ye}}async function A(s,d){return P(await s,d)}export{Ae as a};//# sourceMappingURL=chunk-6M3RIGUH.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-6M3RIGUH.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import {createRequire}from'module';var g=createRequire(import.meta.url),u=g("./jsonata-sync.cjs"),p=u;function c(r,t){if(!t||!r)return;let s=t.split("."),e=r;for(let n=0;n<s.length;n++){if(e==null)return;e=e[s[n]];}return e}function f(r,t,s){let e=t.split("."),n=r;for(let o=0;o<e.length-1;o++)(n[e[o]]==null||typeof n[e[o]]!="object")&&(n[e[o]]={}),n=n[e[o]];n[e[e.length-1]]=s;}async function m(r,t){if(!r?.compute?.length)return r;r.card_data||(r.card_data={}),r.computed_values={},r._sourcesData=t?.sourcesData??{};let s=r.requires??{},e={card_data:r.card_data,requires:s,expects_data:s,fetched_sources:r._sourcesData,data:r.computed_values,computed_values:r.computed_values};for(let n of r.compute)try{let o=await u(n.expr).evaluate(e);f(r.computed_values,n.bindTo,o),e.computed_values=r.computed_values;}catch{}return r}function y(r,t){if(!r?.compute?.length)return {ok:true,node:r};r.card_data||(r.card_data={}),r.computed_values={},r._sourcesData=t?.sourcesData??{};let s=r.requires??{},e={card_data:r.card_data,requires:s,expects_data:s,fetched_sources:r._sourcesData,data:r.computed_values,computed_values:r.computed_values},n=[];for(let o of r.compute)try{let i=p(o.expr).evaluate(e);f(r.computed_values,o.bindTo,i),e.computed_values=r.computed_values;}catch(i){let a=i instanceof Error?i.message:String(i);n.push({bindTo:o.bindTo,error:a});}return n.length>0?{ok:true,node:r,errors:n}:{ok:true,node:r}}async function b(r,t,s){let e={...s??{},card_data:t.card_data??{},requires:t.requires??{},fetched_sources:t._sourcesData??{},computed_values:t.computed_values??{}};return u(r).evaluate(e)}function _(r,t){return t.startsWith("fetched_sources.")?c(r._sourcesData??{},t.slice(16)):c(r,t)}var d=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),v=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function h(r){let t=[];if(!r||typeof r!="object"||Array.isArray(r))return {ok:false,errors:["Node must be a non-null object"]};let s=r;(typeof s.id!="string"||!s.id)&&t.push("id: required, must be a non-empty string");for(let e of Object.keys(s))v.has(e)||t.push(`Unknown top-level key: "${e}"`);if((s.card_data==null||typeof s.card_data!="object"||Array.isArray(s.card_data))&&t.push("card_data: required, must be an object"),s.meta!=null)if(typeof s.meta!="object"||Array.isArray(s.meta))t.push("meta: must be an object");else {let e=s.meta;e.title!=null&&typeof e.title!="string"&&t.push("meta.title: must be a string"),e.tags!=null&&!Array.isArray(e.tags)&&t.push("meta.tags: must be an array");}if(s.requires!=null&&!Array.isArray(s.requires)&&t.push("requires: must be an array of strings"),s.provides!=null&&(Array.isArray(s.provides)?s.provides.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))t.push(`provides[${n}]: must be an object with bindTo and ref`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&t.push(`provides[${n}]: missing required "bindTo" string`),(typeof o.ref!="string"||!o.ref)&&t.push(`provides[${n}]: missing required "ref" string`);}}):t.push("provides: must be an array of { bindTo, ref } bindings")),s.compute!=null&&(Array.isArray(s.compute)?s.compute.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))t.push(`compute[${n}]: must be a compute step object`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&t.push(`compute[${n}]: missing required "bindTo" property`),(typeof o.expr!="string"||!o.expr)&&t.push(`compute[${n}]: missing required "expr" string (JSONata expression)`);}}):t.push("compute: must be an array of compute steps")),s.source_defs!=null)if(!Array.isArray(s.source_defs))t.push("source_defs: must be an array");else {let e=new Set,n=new Set;s.source_defs.forEach((o,i)=>{if(!o||typeof o!="object"||Array.isArray(o))t.push(`source_defs[${i}]: must be an object`);else {let a=o;typeof a.bindTo!="string"||!a.bindTo?t.push(`source_defs[${i}]: missing required "bindTo" property`):(e.has(a.bindTo)&&t.push(`source_defs[${i}]: bindTo "${a.bindTo}" is not unique across source_defs`),e.add(a.bindTo)),typeof a.outputFile!="string"||!a.outputFile?t.push(`source_defs[${i}]: missing required "outputFile" property`):(n.has(a.outputFile)&&t.push(`source_defs[${i}]: outputFile "${a.outputFile}" is not unique across source_defs`),n.add(a.outputFile));}});}if(s.view!=null)if(typeof s.view!="object"||Array.isArray(s.view))t.push("view: must be an object");else {let e=s.view;!Array.isArray(e.elements)||e.elements.length===0?t.push("view.elements: required, must be a non-empty array"):e.elements.forEach((n,o)=>{if(!n||typeof n!="object"){t.push(`view.elements[${o}]: must be an object`);return}!n.kind||typeof n.kind!="string"?t.push(`view.elements[${o}].kind: required, must be a string`):d.has(n.kind)||t.push(`view.elements[${o}].kind: unknown kind "${n.kind}". Valid: ${[...d].join(", ")}`),n.data!=null&&(typeof n.data!="object"||Array.isArray(n.data))&&t.push(`view.elements[${o}].data: must be an object`);});}return {ok:t.length===0,errors:t}}async function k(r,t){if(!r||r.length===0)return [];let s={card_data:t.card_data??{},requires:t.requires??{}};return Promise.all(r.map(async e=>{let n={};if(e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[o,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{n[o]=await u(i).evaluate(s);}catch{n[o]=void 0;}}return {...e,_projections:n}}))}function w(r,t){if(!r||r.length===0)return [];let s={card_data:t.card_data??{},requires:t.requires??{}};return r.map(e=>{let n={};if(e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[o,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{n[o]=p(i).evaluate(s);}catch{n[o]=void 0;}}return {...e,_projections:n}})}var j={run:m,runSync:y,eval:b,resolve:_,validate:h,enrichSources:k,enrichSourcesSync:w},$=j;export{j as a,$ as b};//# sourceMappingURL=chunk-ATOQP3BD.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-ATOQP3BD.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';var chunkLFVMX23W_cjs=require('./chunk-LFVMX23W.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunkKSKPS6OO_cjs=require('./chunk-KSKPS6OO.cjs'),chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkN5RUH4NG_cjs=require('./chunk-N5RUH4NG.cjs'),chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkYXKWIPQM_cjs=require('./chunk-YXKWIPQM.cjs'),chunk5XLFPPTY_cjs=require('./chunk-5XLFPPTY.cjs'),chunkSDJ3747Q_cjs=require('./chunk-SDJ3747Q.cjs'),chunkOF4FPYNI_cjs=require('./chunk-OF4FPYNI.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function ce(R){let{apiBasePath:h,json:w,readJsonBody:L,initBoardAndSetup:F,bootstrapBoard:v,buildPublishedRuntimePayload:W,createMcpControlplaneToolRegistry:j,retriggerCard:M,applyCardAction:I,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:$}=R;async function J(H,B,V){let l=H.method||"GET",A=V,u=A.pathname;try{if(l==="POST"&&u===`${h}/mcp-actions`){await v();let m=Date.now(),b=new Date(m).toISOString(),S=await L(H),f=typeof S.tool=="string"?S.tool.trim():"",T=S.args&&typeof S.args=="object"&&!Array.isArray(S.args)?S.args:{};if(!f)return w(B,400,{error:"tool is required"}),!0;let P=chunkLPXVVMQT_cjs.a(T,"card_id");if(!P)return w(B,400,{error:"MCP action requires card_id"}),!0;if(f==="retrigger-card"||f==="retrigger"){await M(P);let O=Date.now();return w(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:f,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:200}}),!0}let g=chunkLPXVVMQT_cjs.c(T,"payload");if(f==="chat-send"&&!await E(P)){let O=Date.now();return w(B,409,{error:`chat handler is not configured for card: ${P}`,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:409}),!0}if(f==="chat-send"){let O=typeof g["turn-id"]=="string"?g["turn-id"]:typeof g.turnId=="string"?g.turnId:typeof g.turn=="string"?g.turn:"";if(!O||!String(O).trim()){let at=Date.now();return w(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${P}`,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(at).toISOString(),responseSentAtMs:at,responseStatus:400}),!0}}await I(P,f,g);let _=Date.now();return w(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:f,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(_).toISOString(),responseSentAtMs:_,responseStatus:200}}),!0}if(l==="POST"&&u===`${h}/mcp-controlplane`){await v();let m=await L(H),b=typeof m.tool=="string"?m.tool.trim():"",S=m.args&&typeof m.args=="object"&&!Array.isArray(m.args)?m.args:{};if(!b)return w(B,400,{error:"tool is required"}),!0;try{let f=await chunk272IYUKT_cjs.a(b,S,j());if(f&&typeof f=="object"&&!Array.isArray(f)){let T=f;if(T.status==="fail")return w(B,400,{error:chunk272IYUKT_cjs.b(f,"Request failed")}),!0;if(T.status==="error")return w(B,500,{error:chunk272IYUKT_cjs.b(f,"Internal error")}),!0}w(B,200,f);}catch(f){let T=typeof f?.statusCode=="number"?Number(f.statusCode):500,P=f instanceof Error?f.message:String(f);w(B,T,{error:P});}return !0}let k=u.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/cards/([^/]+)/retrigger$`));if(l==="POST"&&k){await v();let m=decodeURIComponent(k[1]);return await M(m),w(B,200,{ok:!0}),!0}let x=u.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/cards/([^/]+)/actions$`));if(l==="POST"&&x){await v();let m=decodeURIComponent(x[1]),b=Date.now(),S=new Date(b).toISOString(),f=await L(H),T=f?.actionType;if(T==="chat-send"&&!await E(m)){let g=Date.now();return w(B,409,{error:`chat handler is not configured for card: ${m}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(g).toISOString(),responseSentAtMs:g,responseStatus:409}),!0}if(T==="chat-send"){let g=f?.payload??{},_=typeof g["turn-id"]=="string"?g["turn-id"]:typeof g.turnId=="string"?g.turnId:typeof g.turn=="string"?g.turn:"";if(!_||!String(_).trim()){let O=Date.now();return w(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${m}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:400}),!0}}await I(m,T,f?.payload);let P=Date.now();return w(B,200,{ok:!0,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:200}),!0}let N=u.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/cards/([^/]+)/files/(\\d+)$`));if(l==="GET"&&N){let m=decodeURIComponent(N[1]),b=parseInt(N[2],10),S=A.searchParams.get("sn");return await $(B,m,b,S),!0}return !1}catch(k){let x=k?.statusCode||500;return w(B,x,{error:String(k?.message||k)}),true}}return {handleRuntimeApi:J}}var ze=3e4;function Ke(R){let h=R.socket?.remoteAddress??"";return h==="127.0.0.1"||h==="::1"||h==="::ffff:127.0.0.1"}function ue(R){let{apiBasePath:h,emitNotifications:w,readJsonBody:L,json:F}=R,v=`${h}/notify-q`;async function W(j,M,I){if(I.pathname!==v)return false;if((j.method??"").toUpperCase()!=="POST")return F(M,405,{status:"error",error:"Method not allowed"}),true;if(!Ke(j))return F(M,403,{status:"error",error:"Forbidden"}),true;let E;try{E=await L(j);}catch{return F(M,400,{status:"error",error:"Invalid JSON body"}),true}if(!E||typeof E!="object"||!Array.isArray(E.notifications))return F(M,400,{status:"error",error:"body.notifications must be an array"}),true;let $=E.notifications,{accepted:J,rejected:H}=chunkKSKPS6OO_cjs.b($,Date.now(),ze);return J.length>0&&w(J),F(M,200,{status:"success",data:{accepted:J.length,rejected:H}}),true}return {handleNotifyRoute:W}}var le={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},de="chat-handler-flow-queue",ot="__probe__echo__probe__";function jr(R){let h=String(R.apiBasePath||"/api/board").replace(/\/$/,""),w={...le,...R.corsHeaders||{}},L=R.queueLaneTuning??{},F=R.boardId||"",v=R.logger||{info:console.log,warn:console.warn,error:console.error},W=R.invocationAdapter,j=R.chatFlowRunner||null,M=R.notificationTransport||null,I=R.serverUrl||null,E=R.executionExtra||{},$=R.onSseClientConnected,J=R.onSseClientDisconnected,H=R.onChannelSubscribed,B=R.onChannelUnsubscribed,V=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:J}),l=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function A(t){function e(a){return {...a,queueStorageForRef(d,C){return chunkSDJ3747Q_cjs.a(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}function r(a){return {...a,queueStorageForRef(d,C){return chunkN5RUH4NG_cjs.h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}function n(a){return {async get(d){return a.get(d)},async set(d){return a.set(d)},async del(d){return a.del(d)},async patch(d){return a.patch(d)},async appendFiles(d){return a.appendFiles(d)}}}function o(a){return {async get(d){return await a.get(d)},async set(d){return await a.set(d)},async del(d){return await a.del(d)},async patch(d){return await a.patch(d)},async appendFiles(d){return await a.appendFiles(d)}}}let s=null;function i(a){if(a.kind==="notification-batch"){O(a.notifications,s??void 0);return}O([a],s??void 0);}let c=chunkBQUQTOPB_cjs.a(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),D=t.nonCoreAdapter??(!chunkBQUQTOPB_cjs.a(c)&&b(c)?c:null),y=chunkBQUQTOPB_cjs.a(c)?chunkN5RUH4NG_cjs.i(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}):chunkYXKWIPQM_cjs.y(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}),q=t.nonCore??(D?chunkYXKWIPQM_cjs.z(t.baseRef,D,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c.chatStorageForRef(t.chatStoreRef),lt,We=chunkBQUQTOPB_cjs.a(c)?(()=>{let a=chunkN5RUH4NG_cjs.d(chunkN5RUH4NG_cjs.c(chunkN5RUH4NG_cjs.b(c.kvStorageForRef(t.cardStoreRef)),c.hashFn),v.warn),d=chunkN5RUH4NG_cjs.g(a,{emitNotification:i}),C=o(d);return lt={get(p){return C.get(p)},set(p){return C.set(p)}},C})():(()=>{let a=c.kvStorageForRef(t.cardStoreRef),C=chunk5XLFPPTY_cjs.a(chunkYXKWIPQM_cjs.l({readIndex:()=>a.read("_index"),writeIndex:p=>a.write("_index",p),readCard:p=>a.read(p),writeCard:(p,pt)=>(a.write(p,pt),p),removeCard:p=>{a.delete(p);},cardExists:p=>a.read(p)!==null,defaultCardKey:p=>p},v.warn),{emitNotification:i});return lt=C,n(C)})(),ft;if(chunkBQUQTOPB_cjs.a(c)){let a=c.blobStorageForRef(t.artifactsStoreRef);ft={async putBytes(d,C){if(a.writeBytes){await a.writeBytes(d,C);return}let p=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(d,p);},async getBytes(d){if(a.readBytes){let p=await a.readBytes(d);if(p!==null)return p}let C=await a.read(d);if(C===null)return null;try{let p=JSON.parse(C);if(p&&p.__kind==="bytes-array"&&Array.isArray(p.data))return new Uint8Array(p.data)}catch{}return new TextEncoder().encode(C)},async listKeys(d){return await a.listKeys(d)}};}else {let a=c.blobStorageForRef(t.artifactsStoreRef),d=chunkNBJTYAYN_cjs.a(a);ft={putBytes(C,p,pt){d.putBytes(C,p,pt);},getBytes(C){return d.getBytes(C)},listKeys(C){return d.list(C).map(p=>p.key)}};}let Je={async init(a){return y.init(a)},async status(a){return y.status(a)},async getConfig(a){return y.getConfig(a)},async getAllOutputsDataObjects(a){return y.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return y.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return y.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return y.buildSseOneShotPayload(a)},async upsertCard(a){return y.upsertCard(a)},async removeCard(a){return y.removeCard(a)},async sourceDataFetched(a){return y.sourceDataFetched(a)},async sourceDataFetchFailure(a){return y.sourceDataFetchFailure(a)}};return s={label:t.label,board:y,nonCore:q,publicCardStore:lt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return ft},get chatStorage(){return Ue},boardAdapter:c,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:chunkKSKPS6OO_cjs.c(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let u=R.boards.map(A),k=new Map;function x(t){return k.get(t)??0}function N(t){return t.queueStoreRef}function m(t,e){if(chunkBQUQTOPB_cjs.a(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(N(t),e);return chunkWRMOGPRG_cjs.a(n)}let r=t.boardAdapter.queueStorageForRef(N(t),e);return chunkGPCMBPLK_cjs.a(r)}function b(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function S(t){let e=u[x(t)];return {files:e?e.filesArtifacts:null}}function f(){return chunkNBJTYAYN_cjs.c()}function T(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function P(t){return "cardId"in t&&typeof t.cardId=="string"?z(t.cardId)??void 0:u[0]??void 0}function g(t){for(let e of t){let r=P(e);if(r)return r}return u[0]??void 0}function _(t,e={}){if(!t||t.length===0)return;let r=chunk2RIHC5TZ_cjs.e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??g(r);if(e.appendState!==false&&o&&chunkKSKPS6OO_cjs.e(o.notification,n),e.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&V.broadcastNotificationBatch(i),s.length>0&&l.broadcastNotificationBatch(s);}if(!(e.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function O(t,e){_(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function at(t){if(!t||t.notificationTeardown||!M||!t.notifyRef)return;let e=await M.subscribe(t.notifyRef,r=>{let n=chunkKSKPS6OO_cjs.a(r);_(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function fe(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let n=await t.boardOps.init({params:e,body:r});if(n.status!=="success")throw Object.assign(new Error(n.error||`init failed for ${t.label}`),{statusCode:500});if(await at(t),!t.chatHandlerFlow&&t.chatHandlerRef&&W.describe)try{let o=await W.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?v.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&v.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){v.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ut(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&chunkKSKPS6OO_cjs.d(r.data)&&e.push({kind:"status",status:r.data});let n=await t.boardOps.getAllOutputsDataObjects({});if(n.status==="success"&&n.data!=null)for(let[s,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&_(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function Rt(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),n=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let o of n)typeof o.id=="string"&&(k.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of u)await fe(t);}async function st(){await G();for(let t=0;t<u.length;t++)await ut(u[t]),await Rt(u[t],t),await ut(u[t]);}async function yt(t=false){t||await G();for(let e of u){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function z(t){return u[x(t)]??null}async function X(t){let e=z(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function pe(){let t=async r=>{if(!r)return [];let n=await r.cardStoreOps.get({});return n.status!=="success"||!Array.isArray(n.data?.cards)?[]:n.data.cards},e=[];for(let r of u)e.push(...await t(r));return e}function ht(){return u[0]??null}function me(t){return z(t)??ht()}function U(t){let e=me(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ge(t){return await U(t).isProcessing(t)}async function Y(t,e){let r=await tt.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let tt=chunkOF4FPYNI_cjs.a({append(t,e,r,n,o){return U(t).append(t,e,r,n,o)},readAll(t){return U(t).readAll(t)},readAfter(t,e){return U(t).readAfter(t,e)},clear(t){return U(t).clear(t)},setProcessing(t,e){return U(t).setProcessing(t,e)},isProcessing(t){return U(t).isProcessing(t)},getConfig(t){return U(t).getConfig(t)},setConfig(t,e){return U(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){O(t.notifications);return}O([t]);}}),wt=chunkKSKPS6OO_cjs.p({boardContexts:u,cardOwnerIndex:k,cardContextForCard:t=>z(t),readStatusSnapshot:()=>be(),readDataObjectsByToken:()=>Ce(),readCardRuntimeArtifacts:()=>Se(),readCardFromStore:t=>X(t),readCardDefinitions:()=>pe(),processAccumulatedLaneInternal:t=>yt(t),reportSourceFetched:(t,e)=>kt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Pt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>Ct(t,e,r,n,o),chatStorePublic:tt,serverUrl:I,apiBasePath:h}),Re=wt.mcpCardStoreFacade,it=wt.createMcpFacade,ye=chunkKSKPS6OO_cjs.j({boardId:F,bootstrapBoard:()=>st(),sseHub:V,onChannelSubscribed:H,onChannelUnsubscribed:B,getMcpFacade:()=>it(),getMcpCardStoreFacade:()=>Re()});function he(t){return chunkKSKPS6OO_cjs.m(t)}function we(){return chunkKSKPS6OO_cjs.n(it())}function bt(){return chunkKSKPS6OO_cjs.o({boardId:F,uploadCardFile:Ct,getMcpFacade:()=>it(),controlplane:ye})}let ct=chunkKSKPS6OO_cjs.k({boardId:F,boardContexts:u,readChatRecords:t=>Fe(t),getChatProcessing:t=>ge(t)}),be=ct.readStatusSnapshot,Se=ct.readCardRuntimeArtifacts,Ce=ct.readDataObjectsByToken,dt=ct.buildPublishedRuntimePayload;async function St(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=z(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await X(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,D=e(i)||i;if(o&&JSON.stringify(D)===c)return;let y=await s.cardStoreOps.set({body:D});if(y.status!=="success")throw Object.assign(new Error(y.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let q=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(q.status!=="success")throw Object.assign(new Error(q.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Ae(t,e){await St(t,e,{syncBoard:true});}async function Be(t,e){await St(t,e,{syncBoard:false});}async function ke(t){let e=z(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await X(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let n=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function Pe(t){let e=await tt.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await Y(t,!1);}catch{}}async function Oe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await tt.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function Fe(t){return await U(t).readAll(t)}let Ct=chunkKSKPS6OO_cjs.l({safeCardId:t=>T(t),artifactsStores:t=>S(t),cardFileMetadataStore:()=>f(),readCardFromStore:t=>X(t),updateCardLocalOnly:(t,e)=>Be(t,e),writeChatRecord:(t,e,r,n,o)=>Oe(t,e,r,n,o)}).uploadCardFile;async function At(t){let e=z(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function ve(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function xe(t,e,r=false,n="",o=""){try{let s=await At(t);if(!s){try{await Y(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:D}=s;if(!r)try{await Y(t,!0);}catch{}let y={boardId:F,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...E,...I?{serverUrl:I}:{}},q=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:de}}:D;chunkBQUQTOPB_cjs.a(i.boardAdapter)?await m(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}):m(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await Y(t,!1);}catch{}v.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Te(t,e,r){if(e.howToRun==="built-in"&&chunkBQUQTOPB_cjs.b(e)===de){let n=j,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:F,cardId:String(s.cardId||""),label:t.label,logger:v,serverUrl:I,executionExtra:E}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return W.invoke(e,r)}async function Ne(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?z(r):ht();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Te(n,t.ref,t.args);if(!o.dispatched){if(r)try{await Y(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Ee(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=bt(),i=ve(r?.text),c=i?i.text:r?.text,D=await chunk272IYUKT_cjs.a("manage.add-chat-entry-and-any-attachments",{board_id:F,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(D?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(D,`chat-send append failed for card ${t}`));let y=D?.data?.id;if(typeof y!="string"||!y)throw new Error(`chat-send did not return an append id for card ${t}`);let q=await chunk272IYUKT_cjs.a("setstate.chat-processing-started",{board_id:F,card_id:t},s);if(q?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(q,`chat-send processing update failed for card ${t}`));xe(t,y,true,o,i?.assistant||"");return}await Ae(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=f().normalizeIncoming(r?.files,s);return c.length>0&&f().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...w,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function Bt(t,e,r){let n=await X(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=f().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=T(t),c=S(t),D=String(s.stored_name||""),y=`${i}/${D}`,q=c.files?await c.files.getBytes(y):null;if(!q)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:q}}async function je(t,e,r,n){let{fileRecord:o,bytes:s}=await Bt(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function Me(t){let e=String(t||"").toLowerCase();return e.startsWith("text/")||e.includes("json")||e.includes("xml")||e.includes("javascript")||e.includes("typescript")||e.includes("yaml")||e.includes("csv")}function _e(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
|
|
2
|
-
`)}async function rt(t){let e=[];for await(let n of t)e.push(n);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(e)).trim();return r?JSON.parse(r):{}}async function kt(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let n=u[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Pt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=u[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let De=chunkLFVMX23W_cjs.b({sseHub:V,queueSseHub:l,corsHeaders:w,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:$,onChannelSubscribed:H,onChannelUnsubscribed:B,apiBasePath:h,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),boardContexts:u,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=chunk7FGPOGRV_cjs.a({apiBasePath:h,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>st(),createMcpFacade:()=>it(),createMcpToolRegistry:t=>he(t),resolveCardFileDownloadPayload:(t,e,r)=>Bt(t,e,r),isLikelyTextMimeType:t=>Me(t),sliceTextByLines:(t,e,r)=>_e(t,e,r)}).handleAgentfaceApi,Ie=chunkNM6O35RY_cjs.a({apiBasePath:h,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ce({apiBasePath:h,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>bt(),retriggerCard:t=>ke(t),applyCardAction:(t,e,r)=>Ee(t,e,r),resolveChatHandlerTarget:t=>At(t),sendCardFileDownloadResponse:(t,e,r,n)=>je(t,e,r,n)}).handleRuntimeApi,He=ue({apiBasePath:h,emitNotifications:t=>O(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Le(t,e,r){return !!(await qe(t,e,r)||await Ie(t,e,r)||await De(t,e,r)||await He(t,e,r)||await $e(t,e,r))}return {get apiBasePath(){return h},get corsHeaders(){return w},get queueLaneTuning(){return L},handleRuntimeApi:Le,emitNotification(t){if(t.kind==="notification-batch"){O(t.notifications);return}O([t]);},buildPublishedRuntimePayload:dt,__drainProcessAccumulatedLane:yt,handleChatAgentRequest:Ne,clearChatRecords:Pe,reportSourceFetched(t,e){return kt(t,{ref:e})},reportSourceFetchFailure(t,e){return Pt(t,{reason:e})},get cardStore(){return u[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Mr(R){let h=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),w={...le,...R.corsHeaders||{}},L=R.serverMetaStore,F=R.boardRuntimeFactory,v=new Map,W="boards-config.json";function j(){let l=L.getText(W);if(!l)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(l)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function M(l){L.putText(W,JSON.stringify(l,null,2));}function I(l){let A=String(l||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return A.length>0&&A.length<=64?A:null}function E(l){if(v.has(l))return v.get(l);let u=j().boards.find(x=>x.id===l)||{},k=F(l,u);return v.set(l,k),k}function $(l,A,u){let k=JSON.stringify(u),x=typeof Buffer<"u"?Buffer.byteLength(k):new TextEncoder().encode(k).length;l.writeHead(A,{...w,"Content-Type":"application/json; charset=utf-8","Content-Length":x}),l.end(k);}async function J(l,A,u){let k=l.method||"GET",x=u.pathname;if(k==="GET"&&x===h)return $(A,200,{ok:true,boards:j().boards}),true;if(k==="POST"&&x===h){let N=[];for await(let g of l)N.push(g);let m=typeof Buffer<"u"?Buffer.concat(N).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(N)).trim(),b={};try{b=m?JSON.parse(m):{};}catch{b={};}let S=I(b.id);if(!S)return $(A,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let f=j();if(f.boards.some(g=>g.id===S))return $(A,409,{error:`Board "${S}" is already registered`}),true;let T=typeof b.label=="string"&&b.label.trim()?b.label.trim():S,P={id:S,label:T};for(let[g,_]of Object.entries(b))g==="id"||g==="label"||_!=null&&(P[g]=_);return f.boards.push(P),M(f),$(A,200,{ok:true,board:P}),true}return false}async function H(l,A,u){let x=u.pathname.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/([^/]+)(/|$)`));if(!x)return false;let N=I(decodeURIComponent(x[1]));return N?j().boards.some(S=>S.id===N)?!!await E(N).handleRuntimeApi(l,A,u):($(A,404,{error:`Board "${N}" not registered. POST ${h} with {id} to register it first.`}),true):($(A,400,{error:"Invalid board id"}),true)}async function B(l,A,u){return !!(await J(l,A,u)||await H(l,A,u))}function V(l){if(!j().boards.some(u=>u.id===l))throw Object.assign(new Error(`Board "${l}" not registered`),{statusCode:404});return {service:E(l)}}return {get apiBasePath(){return h},get corsHeaders(){return w},handleApi:B,requireBoardService:V}}exports.a=jr;exports.b=Mr;//# sourceMappingURL=chunk-
|
|
3
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkLFVMX23W_cjs=require('./chunk-LFVMX23W.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunkNMOUBZXX_cjs=require('./chunk-NMOUBZXX.cjs'),chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkX5CZE2L7_cjs=require('./chunk-X5CZE2L7.cjs'),chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkVNLMJEIX_cjs=require('./chunk-VNLMJEIX.cjs'),chunk5XLFPPTY_cjs=require('./chunk-5XLFPPTY.cjs'),chunkSDJ3747Q_cjs=require('./chunk-SDJ3747Q.cjs'),chunkOF4FPYNI_cjs=require('./chunk-OF4FPYNI.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function ce(R){let{apiBasePath:h,json:w,readJsonBody:L,initBoardAndSetup:F,bootstrapBoard:v,buildPublishedRuntimePayload:W,createMcpControlplaneToolRegistry:j,retriggerCard:M,applyCardAction:I,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:$}=R;async function J(H,B,V){let l=H.method||"GET",A=V,u=A.pathname;try{if(l==="POST"&&u===`${h}/mcp-actions`){await v();let m=Date.now(),b=new Date(m).toISOString(),S=await L(H),f=typeof S.tool=="string"?S.tool.trim():"",T=S.args&&typeof S.args=="object"&&!Array.isArray(S.args)?S.args:{};if(!f)return w(B,400,{error:"tool is required"}),!0;let P=chunkLPXVVMQT_cjs.a(T,"card_id");if(!P)return w(B,400,{error:"MCP action requires card_id"}),!0;if(f==="retrigger-card"||f==="retrigger"){await M(P);let O=Date.now();return w(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:f,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:200}}),!0}let g=chunkLPXVVMQT_cjs.c(T,"payload");if(f==="chat-send"&&!await E(P)){let O=Date.now();return w(B,409,{error:`chat handler is not configured for card: ${P}`,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:409}),!0}if(f==="chat-send"){let O=typeof g["turn-id"]=="string"?g["turn-id"]:typeof g.turnId=="string"?g.turnId:typeof g.turn=="string"?g.turn:"";if(!O||!String(O).trim()){let at=Date.now();return w(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${P}`,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(at).toISOString(),responseSentAtMs:at,responseStatus:400}),!0}}await I(P,f,g);let _=Date.now();return w(B,200,{status:"success",data:{ok:!0,cardId:P,actionType:f,requestReceivedAt:b,requestReceivedAtMs:m,responseSentAt:new Date(_).toISOString(),responseSentAtMs:_,responseStatus:200}}),!0}if(l==="POST"&&u===`${h}/mcp-controlplane`){await v();let m=await L(H),b=typeof m.tool=="string"?m.tool.trim():"",S=m.args&&typeof m.args=="object"&&!Array.isArray(m.args)?m.args:{};if(!b)return w(B,400,{error:"tool is required"}),!0;try{let f=await chunk272IYUKT_cjs.a(b,S,j());if(f&&typeof f=="object"&&!Array.isArray(f)){let T=f;if(T.status==="fail")return w(B,400,{error:chunk272IYUKT_cjs.b(f,"Request failed")}),!0;if(T.status==="error")return w(B,500,{error:chunk272IYUKT_cjs.b(f,"Internal error")}),!0}w(B,200,f);}catch(f){let T=typeof f?.statusCode=="number"?Number(f.statusCode):500,P=f instanceof Error?f.message:String(f);w(B,T,{error:P});}return !0}let k=u.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/cards/([^/]+)/retrigger$`));if(l==="POST"&&k){await v();let m=decodeURIComponent(k[1]);return await M(m),w(B,200,{ok:!0}),!0}let x=u.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/cards/([^/]+)/actions$`));if(l==="POST"&&x){await v();let m=decodeURIComponent(x[1]),b=Date.now(),S=new Date(b).toISOString(),f=await L(H),T=f?.actionType;if(T==="chat-send"&&!await E(m)){let g=Date.now();return w(B,409,{error:`chat handler is not configured for card: ${m}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(g).toISOString(),responseSentAtMs:g,responseStatus:409}),!0}if(T==="chat-send"){let g=f?.payload??{},_=typeof g["turn-id"]=="string"?g["turn-id"]:typeof g.turnId=="string"?g.turnId:typeof g.turn=="string"?g.turn:"";if(!_||!String(_).trim()){let O=Date.now();return w(B,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${m}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(O).toISOString(),responseSentAtMs:O,responseStatus:400}),!0}}await I(m,T,f?.payload);let P=Date.now();return w(B,200,{ok:!0,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:200}),!0}let N=u.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/cards/([^/]+)/files/(\\d+)$`));if(l==="GET"&&N){let m=decodeURIComponent(N[1]),b=parseInt(N[2],10),S=A.searchParams.get("sn");return await $(B,m,b,S),!0}return !1}catch(k){let x=k?.statusCode||500;return w(B,x,{error:String(k?.message||k)}),true}}return {handleRuntimeApi:J}}var ze=3e4;function Ke(R){let h=R.socket?.remoteAddress??"";return h==="127.0.0.1"||h==="::1"||h==="::ffff:127.0.0.1"}function ue(R){let{apiBasePath:h,emitNotifications:w,readJsonBody:L,json:F}=R,v=`${h}/notify-q`;async function W(j,M,I){if(I.pathname!==v)return false;if((j.method??"").toUpperCase()!=="POST")return F(M,405,{status:"error",error:"Method not allowed"}),true;if(!Ke(j))return F(M,403,{status:"error",error:"Forbidden"}),true;let E;try{E=await L(j);}catch{return F(M,400,{status:"error",error:"Invalid JSON body"}),true}if(!E||typeof E!="object"||!Array.isArray(E.notifications))return F(M,400,{status:"error",error:"body.notifications must be an array"}),true;let $=E.notifications,{accepted:J,rejected:H}=chunkNMOUBZXX_cjs.b($,Date.now(),ze);return J.length>0&&w(J),F(M,200,{status:"success",data:{accepted:J.length,rejected:H}}),true}return {handleNotifyRoute:W}}var le={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},de="chat-handler-flow-queue",ot="__probe__echo__probe__";function jr(R){let h=String(R.apiBasePath||"/api/board").replace(/\/$/,""),w={...le,...R.corsHeaders||{}},L=R.queueLaneTuning??{},F=R.boardId||"",v=R.logger||{info:console.log,warn:console.warn,error:console.error},W=R.invocationAdapter,j=R.chatFlowRunner||null,M=R.notificationTransport||null,I=R.serverUrl||null,E=R.executionExtra||{},$=R.onSseClientConnected,J=R.onSseClientDisconnected,H=R.onChannelSubscribed,B=R.onChannelUnsubscribed,V=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:J}),l=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function A(t){function e(a){return {...a,queueStorageForRef(d,C){return chunkSDJ3747Q_cjs.a(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}function r(a){return {...a,queueStorageForRef(d,C){return chunkX5CZE2L7_cjs.h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i})}}}function n(a){return {async get(d){return a.get(d)},async set(d){return a.set(d)},async del(d){return a.del(d)},async patch(d){return a.patch(d)},async appendFiles(d){return a.appendFiles(d)}}}function o(a){return {async get(d){return await a.get(d)},async set(d){return await a.set(d)},async del(d){return await a.del(d)},async patch(d){return await a.patch(d)},async appendFiles(d){return await a.appendFiles(d)}}}let s=null;function i(a){if(a.kind==="notification-batch"){O(a.notifications,s??void 0);return}O([a],s??void 0);}let c=chunkBQUQTOPB_cjs.a(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),D=t.nonCoreAdapter??(!chunkBQUQTOPB_cjs.a(c)&&b(c)?c:null),y=chunkBQUQTOPB_cjs.a(c)?chunkX5CZE2L7_cjs.i(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}):chunkVNLMJEIX_cjs.y(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}),q=t.nonCore??(D?chunkVNLMJEIX_cjs.z(t.baseRef,D,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c.chatStorageForRef(t.chatStoreRef),lt,We=chunkBQUQTOPB_cjs.a(c)?(()=>{let a=chunkX5CZE2L7_cjs.d(chunkX5CZE2L7_cjs.c(chunkX5CZE2L7_cjs.b(c.kvStorageForRef(t.cardStoreRef)),c.hashFn),v.warn),d=chunkX5CZE2L7_cjs.g(a,{emitNotification:i}),C=o(d);return lt={get(p){return C.get(p)},set(p){return C.set(p)}},C})():(()=>{let a=c.kvStorageForRef(t.cardStoreRef),C=chunk5XLFPPTY_cjs.a(chunkVNLMJEIX_cjs.l({readIndex:()=>a.read("_index"),writeIndex:p=>a.write("_index",p),readCard:p=>a.read(p),writeCard:(p,pt)=>(a.write(p,pt),p),removeCard:p=>{a.delete(p);},cardExists:p=>a.read(p)!==null,defaultCardKey:p=>p},v.warn),{emitNotification:i});return lt=C,n(C)})(),ft;if(chunkBQUQTOPB_cjs.a(c)){let a=c.blobStorageForRef(t.artifactsStoreRef);ft={async putBytes(d,C){if(a.writeBytes){await a.writeBytes(d,C);return}let p=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(d,p);},async getBytes(d){if(a.readBytes){let p=await a.readBytes(d);if(p!==null)return p}let C=await a.read(d);if(C===null)return null;try{let p=JSON.parse(C);if(p&&p.__kind==="bytes-array"&&Array.isArray(p.data))return new Uint8Array(p.data)}catch{}return new TextEncoder().encode(C)},async listKeys(d){return await a.listKeys(d)}};}else {let a=c.blobStorageForRef(t.artifactsStoreRef),d=chunkNBJTYAYN_cjs.a(a);ft={putBytes(C,p,pt){d.putBytes(C,p,pt);},getBytes(C){return d.getBytes(C)},listKeys(C){return d.list(C).map(p=>p.key)}};}let Je={async init(a){return y.init(a)},async status(a){return y.status(a)},async getConfig(a){return y.getConfig(a)},async getAllOutputsDataObjects(a){return y.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return y.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return y.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return y.buildSseOneShotPayload(a)},async upsertCard(a){return y.upsertCard(a)},async removeCard(a){return y.removeCard(a)},async sourceDataFetched(a){return y.sourceDataFetched(a)},async sourceDataFetchFailure(a){return y.sourceDataFetchFailure(a)}};return s={label:t.label,board:y,nonCore:q,publicCardStore:lt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return ft},get chatStorage(){return Ue},boardAdapter:c,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:chunkNMOUBZXX_cjs.c(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let u=R.boards.map(A),k=new Map;function x(t){return k.get(t)??0}function N(t){return t.queueStoreRef}function m(t,e){if(chunkBQUQTOPB_cjs.a(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(N(t),e);return chunkWRMOGPRG_cjs.a(n)}let r=t.boardAdapter.queueStorageForRef(N(t),e);return chunkGPCMBPLK_cjs.a(r)}function b(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function S(t){let e=u[x(t)];return {files:e?e.filesArtifacts:null}}function f(){return chunkNBJTYAYN_cjs.c()}function T(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function P(t){return "cardId"in t&&typeof t.cardId=="string"?z(t.cardId)??void 0:u[0]??void 0}function g(t){for(let e of t){let r=P(e);if(r)return r}return u[0]??void 0}function _(t,e={}){if(!t||t.length===0)return;let r=chunk2RIHC5TZ_cjs.e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??g(r);if(e.appendState!==false&&o&&chunkNMOUBZXX_cjs.e(o.notification,n),e.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&V.broadcastNotificationBatch(i),s.length>0&&l.broadcastNotificationBatch(s);}if(!(e.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function O(t,e){_(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function at(t){if(!t||t.notificationTeardown||!M||!t.notifyRef)return;let e=await M.subscribe(t.notifyRef,r=>{let n=chunkNMOUBZXX_cjs.a(r);_(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function fe(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let n=await t.boardOps.init({params:e,body:r});if(n.status!=="success")throw Object.assign(new Error(n.error||`init failed for ${t.label}`),{statusCode:500});if(await at(t),!t.chatHandlerFlow&&t.chatHandlerRef&&W.describe)try{let o=await W.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?v.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&v.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){v.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ut(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&chunkNMOUBZXX_cjs.d(r.data)&&e.push({kind:"status",status:r.data});let n=await t.boardOps.getAllOutputsDataObjects({});if(n.status==="success"&&n.data!=null)for(let[s,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&_(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function Rt(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),n=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let o of n)typeof o.id=="string"&&(k.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of u)await fe(t);}async function st(){await G();for(let t=0;t<u.length;t++)await ut(u[t]),await Rt(u[t],t),await ut(u[t]);}async function yt(t=false){t||await G();for(let e of u){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function z(t){return u[x(t)]??null}async function X(t){let e=z(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function pe(){let t=async r=>{if(!r)return [];let n=await r.cardStoreOps.get({});return n.status!=="success"||!Array.isArray(n.data?.cards)?[]:n.data.cards},e=[];for(let r of u)e.push(...await t(r));return e}function ht(){return u[0]??null}function me(t){return z(t)??ht()}function U(t){let e=me(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ge(t){return await U(t).isProcessing(t)}async function Y(t,e){let r=await tt.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let tt=chunkOF4FPYNI_cjs.a({append(t,e,r,n,o){return U(t).append(t,e,r,n,o)},readAll(t){return U(t).readAll(t)},readAfter(t,e){return U(t).readAfter(t,e)},clear(t){return U(t).clear(t)},setProcessing(t,e){return U(t).setProcessing(t,e)},isProcessing(t){return U(t).isProcessing(t)},getConfig(t){return U(t).getConfig(t)},setConfig(t,e){return U(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){O(t.notifications);return}O([t]);}}),wt=chunkNMOUBZXX_cjs.p({boardContexts:u,cardOwnerIndex:k,cardContextForCard:t=>z(t),readStatusSnapshot:()=>be(),readDataObjectsByToken:()=>Ce(),readCardRuntimeArtifacts:()=>Se(),readCardFromStore:t=>X(t),readCardDefinitions:()=>pe(),processAccumulatedLaneInternal:t=>yt(t),reportSourceFetched:(t,e)=>kt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Pt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>Ct(t,e,r,n,o),chatStorePublic:tt,serverUrl:I,apiBasePath:h}),Re=wt.mcpCardStoreFacade,it=wt.createMcpFacade,ye=chunkNMOUBZXX_cjs.j({boardId:F,bootstrapBoard:()=>st(),sseHub:V,onChannelSubscribed:H,onChannelUnsubscribed:B,getMcpFacade:()=>it(),getMcpCardStoreFacade:()=>Re()});function he(t){return chunkNMOUBZXX_cjs.m(t)}function we(){return chunkNMOUBZXX_cjs.n(it())}function bt(){return chunkNMOUBZXX_cjs.o({boardId:F,uploadCardFile:Ct,getMcpFacade:()=>it(),controlplane:ye})}let ct=chunkNMOUBZXX_cjs.k({boardId:F,boardContexts:u,readChatRecords:t=>Fe(t),getChatProcessing:t=>ge(t)}),be=ct.readStatusSnapshot,Se=ct.readCardRuntimeArtifacts,Ce=ct.readDataObjectsByToken,dt=ct.buildPublishedRuntimePayload;async function St(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=z(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await X(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,D=e(i)||i;if(o&&JSON.stringify(D)===c)return;let y=await s.cardStoreOps.set({body:D});if(y.status!=="success")throw Object.assign(new Error(y.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let q=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(q.status!=="success")throw Object.assign(new Error(q.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Ae(t,e){await St(t,e,{syncBoard:true});}async function Be(t,e){await St(t,e,{syncBoard:false});}async function ke(t){let e=z(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await X(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let n=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function Pe(t){let e=await tt.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await Y(t,!1);}catch{}}async function Oe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await tt.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function Fe(t){return await U(t).readAll(t)}let Ct=chunkNMOUBZXX_cjs.l({safeCardId:t=>T(t),artifactsStores:t=>S(t),cardFileMetadataStore:()=>f(),readCardFromStore:t=>X(t),updateCardLocalOnly:(t,e)=>Be(t,e),writeChatRecord:(t,e,r,n,o)=>Oe(t,e,r,n,o)}).uploadCardFile;async function At(t){let e=z(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function ve(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function xe(t,e,r=false,n="",o=""){try{let s=await At(t);if(!s){try{await Y(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:D}=s;if(!r)try{await Y(t,!0);}catch{}let y={boardId:F,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...E,...I?{serverUrl:I}:{}},q=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:de}}:D;chunkBQUQTOPB_cjs.a(i.boardAdapter)?await m(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}):m(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await Y(t,!1);}catch{}v.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Te(t,e,r){if(e.howToRun==="built-in"&&chunkBQUQTOPB_cjs.b(e)===de){let n=j,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:F,cardId:String(s.cardId||""),label:t.label,logger:v,serverUrl:I,executionExtra:E}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return W.invoke(e,r)}async function Ne(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?z(r):ht();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Te(n,t.ref,t.args);if(!o.dispatched){if(r)try{await Y(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Ee(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=bt(),i=ve(r?.text),c=i?i.text:r?.text,D=await chunk272IYUKT_cjs.a("manage.add-chat-entry-and-any-attachments",{board_id:F,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(D?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(D,`chat-send append failed for card ${t}`));let y=D?.data?.id;if(typeof y!="string"||!y)throw new Error(`chat-send did not return an append id for card ${t}`);let q=await chunk272IYUKT_cjs.a("setstate.chat-processing-started",{board_id:F,card_id:t},s);if(q?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(q,`chat-send processing update failed for card ${t}`));xe(t,y,true,o,i?.assistant||"");return}await Ae(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=f().normalizeIncoming(r?.files,s);return c.length>0&&f().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...w,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function Bt(t,e,r){let n=await X(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=f().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=T(t),c=S(t),D=String(s.stored_name||""),y=`${i}/${D}`,q=c.files?await c.files.getBytes(y):null;if(!q)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:q}}async function je(t,e,r,n){let{fileRecord:o,bytes:s}=await Bt(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function Me(t){let e=String(t||"").toLowerCase();return e.startsWith("text/")||e.includes("json")||e.includes("xml")||e.includes("javascript")||e.includes("typescript")||e.includes("yaml")||e.includes("csv")}function _e(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
|
|
2
|
+
`)}async function rt(t){let e=[];for await(let n of t)e.push(n);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(e)).trim();return r?JSON.parse(r):{}}async function kt(t,e){let r=typeof e.ref=="string"?e.ref.trim():"";if(!r)return {status:"fail",error:"board-worker success callback requires body.ref"};let n=u[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Pt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=u[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let De=chunkLFVMX23W_cjs.b({sseHub:V,queueSseHub:l,corsHeaders:w,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:$,onChannelSubscribed:H,onChannelUnsubscribed:B,apiBasePath:h,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),boardContexts:u,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=chunk7FGPOGRV_cjs.a({apiBasePath:h,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>st(),createMcpFacade:()=>it(),createMcpToolRegistry:t=>he(t),resolveCardFileDownloadPayload:(t,e,r)=>Bt(t,e,r),isLikelyTextMimeType:t=>Me(t),sliceTextByLines:(t,e,r)=>_e(t,e,r)}).handleAgentfaceApi,Ie=chunkNM6O35RY_cjs.a({apiBasePath:h,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ce({apiBasePath:h,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>bt(),retriggerCard:t=>ke(t),applyCardAction:(t,e,r)=>Ee(t,e,r),resolveChatHandlerTarget:t=>At(t),sendCardFileDownloadResponse:(t,e,r,n)=>je(t,e,r,n)}).handleRuntimeApi,He=ue({apiBasePath:h,emitNotifications:t=>O(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Le(t,e,r){return !!(await qe(t,e,r)||await Ie(t,e,r)||await De(t,e,r)||await He(t,e,r)||await $e(t,e,r))}return {get apiBasePath(){return h},get corsHeaders(){return w},get queueLaneTuning(){return L},handleRuntimeApi:Le,emitNotification(t){if(t.kind==="notification-batch"){O(t.notifications);return}O([t]);},buildPublishedRuntimePayload:dt,__drainProcessAccumulatedLane:yt,handleChatAgentRequest:Ne,clearChatRecords:Pe,reportSourceFetched(t,e){return kt(t,{ref:e})},reportSourceFetchFailure(t,e){return Pt(t,{reason:e})},get cardStore(){return u[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function Mr(R){let h=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),w={...le,...R.corsHeaders||{}},L=R.serverMetaStore,F=R.boardRuntimeFactory,v=new Map,W="boards-config.json";function j(){let l=L.getText(W);if(!l)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(l)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function M(l){L.putText(W,JSON.stringify(l,null,2));}function I(l){let A=String(l||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return A.length>0&&A.length<=64?A:null}function E(l){if(v.has(l))return v.get(l);let u=j().boards.find(x=>x.id===l)||{},k=F(l,u);return v.set(l,k),k}function $(l,A,u){let k=JSON.stringify(u),x=typeof Buffer<"u"?Buffer.byteLength(k):new TextEncoder().encode(k).length;l.writeHead(A,{...w,"Content-Type":"application/json; charset=utf-8","Content-Length":x}),l.end(k);}async function J(l,A,u){let k=l.method||"GET",x=u.pathname;if(k==="GET"&&x===h)return $(A,200,{ok:true,boards:j().boards}),true;if(k==="POST"&&x===h){let N=[];for await(let g of l)N.push(g);let m=typeof Buffer<"u"?Buffer.concat(N).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(N)).trim(),b={};try{b=m?JSON.parse(m):{};}catch{b={};}let S=I(b.id);if(!S)return $(A,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let f=j();if(f.boards.some(g=>g.id===S))return $(A,409,{error:`Board "${S}" is already registered`}),true;let T=typeof b.label=="string"&&b.label.trim()?b.label.trim():S,P={id:S,label:T};for(let[g,_]of Object.entries(b))g==="id"||g==="label"||_!=null&&(P[g]=_);return f.boards.push(P),M(f),$(A,200,{ok:true,board:P}),true}return false}async function H(l,A,u){let x=u.pathname.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(h)}/([^/]+)(/|$)`));if(!x)return false;let N=I(decodeURIComponent(x[1]));return N?j().boards.some(S=>S.id===N)?!!await E(N).handleRuntimeApi(l,A,u):($(A,404,{error:`Board "${N}" not registered. POST ${h} with {id} to register it first.`}),true):($(A,400,{error:"Invalid board id"}),true)}async function B(l,A,u){return !!(await J(l,A,u)||await H(l,A,u))}function V(l){if(!j().boards.some(u=>u.id===l))throw Object.assign(new Error(`Board "${l}" not registered`),{statusCode:404});return {service:E(l)}}return {get apiBasePath(){return h},get corsHeaders(){return w},handleApi:B,requireBoardService:V}}exports.a=jr;exports.b=Mr;//# sourceMappingURL=chunk-BDT43KYE.cjs.map
|
|
3
|
+
//# sourceMappingURL=chunk-BDT43KYE.cjs.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 {b as b$1}from'./chunk-44L64VQ2.js';import {a as a$2}from'./chunk-RWAEV253.js';function v(a){if(!a||typeof a!="object")return false;let e=a;return typeof e.kind=="string"&&e.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let e=a;return e.kind==="notification-batch"?Array.isArray(e.notifications)?e.notifications.filter(v):[]:v(a)?[a]:[]}function X(a,e,i){let u=0;return {accepted:a.filter(R=>{if(!v(R))return u++,false;let _=R;return typeof _.sentAtMs=="number"&&e-_.sentAtMs>i?(u++,false):true}),rejected:u}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let e=a.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let e=a;return e.kind==="notification-batch"&&Array.isArray(e.notifications)}function V(a,e){if(e.kind==="status"){z(e.status)&&(a.status=e.status);return}if(e.kind==="computed_values"){a.computedValues[e.cardId]=e.values;return}if(e.kind==="data_object"){a.dataObjects[e.key]=e.payload;return}if(e.kind==="card_refreshed"){a.cards[e.cardId]=e.card;return}e.kind==="card_removed"&&(delete a.cards[e.cardId],delete a.computedValues[e.cardId]);}function Y(a,e){if(W(e)){for(let i of e.notifications)v(i)&&V(a,i);return}v(e)&&V(a,e);}function j(a,e){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||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function N(a,e){return j(await a,e)}function q(a$1){let e=a(a$1,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=e.split(".");if(!(i.length>=2&&i.every(f=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(f))))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 e}function E(a,e){let i=a.__private;for(let u of e.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,u))return {exists:false,value:null};i=i[u];}return {exists:true,value:i}}function oe(a$1){let{boardId:e,bootstrapBoard:i,sseHub:u,onChannelSubscribed:f,onChannelUnsubscribed:R,getMcpFacade:_,getMcpCardStoreFacade:r}=a$1;function g(s){let d=a(s,"board_id");if(!d)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(d!==e)throw Object.assign(new Error(`Unknown board_id: ${d}`),{statusCode:400})}function b(s){let d=a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function y(s){g(s);let d=b(s),n=a(s,"channel_name"),t=a(s,"card_id")||void 0;if(!n)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:n,...t?{cardId:t}:{}}}function c(s){g(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 C(s){await i();let{cardId:d}=c(s),n=b(s);if(!await u.subscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:true}}}async function m(s){await i();let{cardId:d}=c(s),n=b(s);if(!u.unsubscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:false}}}async function w(s,d){await i();let{clientId:n,channelName:t,cardId:o}=y(s);if(!u.has(n))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return d?(u.subscribeChannel(n,t,o),f?.(n,t,o?{cardId:o}:{})):(u.unsubscribeChannel(n,t,o),R?.(n,t,o?{cardId:o}:{})),{status:"success",data:{boardId:e,clientId:n,channelName:t,subscribed:d,...o?{cardId:o}:{}}}}async function S(s,d){let{cardId:n}=c(s);return await _().setChatProcessing({cardId:n,active:d}),{status:"success",data:{boardId:e,cardId:n,active:d}}}async function l(s){let{cardId:d}=c(s),n=await _().getChatProcessing({cardId:d});return {status:"success",data:{boardId:e,cardId:d,active:n.active}}}async function h(s){let{cardId:d}=c(s),n=q(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(n.split(".").includes("visible_controlplane_only")){let t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null,k=o?E(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:e,cardId:d,key:n}}}return j(await r().patch({params:{id:d,path:`__private.${n}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:e,cardId:d,key:n}}}async function I(s){let{cardId:d}=c(s),n=q(s),t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&t.cards[0]&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=E(o,n);return {status:"success",data:{boardId:e,cardId:d,key:n,exists:k.exists,value:k.value}}}return {requireCardArgs:c,subscribeChat:C,unsubscribeChat:m,watchChannel:w,setChatProcessing:S,getChatProcessing:l,setCardMeta:h,getCardMeta:I}}function ie(a){let{boardId:e,boardContexts:i,readChatRecords:u,getChatProcessing:f}=a;function R(c){if(c.length===0)return null;if(c.length===1)return c[0];let C=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],w={};for(let l of m)w[l]=0;for(let l of c){let h=l,I=Array.isArray(h.cards)?h.cards:[];C.push(...I);for(let s of m)w[s]+=Number(h?.summary?.[s]||0);}let S=c[0];return {...S,cards:C,summary:{...S.summary||{},card_count:C.length,...w}}}async function _(){let c=[];for(let C of i)try{let m=await C.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&c.push(m.data);}catch{}return c}async function r(){let C=(await _()).map(m=>m.statusSnapshot).filter(Boolean);if(C.length===0){let m=i.map(w=>w.notification.status).filter(Boolean);return R(m)}return R(C)}async function g(){let c={},C=await _();for(let m of C)Object.assign(c,m.cardRuntimeById||{});if(Object.keys(c).length>0)return c;for(let m of i)for(let[w,S]of Object.entries(m.notification.computedValues)){let l=m.notification.cards[w];c[w]={schema_version:"v1",card_id:w,card_data:l?.card_data??{},computed_values:S??{}};}return c}async function b(){let c={},C=await _();for(let m of C)Object.assign(c,m.dataObjectsByToken||{});if(Object.keys(c).length===0)for(let m of i)Object.assign(c,m.notification.dataObjects||{});return c}async function y(){let c=await _(),C=c.flatMap(l=>Array.isArray(l.cardDefinitions)?l.cardDefinitions:[]),m={},w={};for(let l of c)Object.assign(m,l.dataObjectsByToken||{}),Object.assign(w,l.cardRuntimeById||{});let S={};for(let l of C){if(!l?.id)continue;let h=l.id;try{let I=await u(h),s=await f(h);(I.length>0||s)&&(S[h]={messages:I.map(d=>({role:String(d.role||"system"),text:String(d.text||""),files:Array.isArray(d.files)?d.files:[]})),receiving:!1,processing:s});}catch{}}return {boardId:e,cardDefinitions:C,statusSnapshot:await r(),dataObjectsByToken:m,cardRuntimeById:w,cardChatsByCardId:S}}return {readStatusSnapshot:r,readCardRuntimeArtifacts:g,readDataObjectsByToken:b,buildPublishedRuntimePayload:y}}function K(a){let e=String(a||"").trim();if(!e)return "upload.bin";let i=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (i>=0?e.slice(i+1):e)||"upload.bin"}function ce(a){let{safeCardId:e,artifactsStores:i,cardFileMetadataStore:u,readCardFromStore:f,updateCardLocalOnly:R,writeChatRecord:_}=a;async function r(y){let c=[];try{let C=await f(y);if(!C)return c;let m=u().read(C.card_data&&typeof C.card_data=="object"?C.card_data:null);for(let w of m)c.push(String(w.stored_name??""));}catch{}return c}async function g(y,c,C,m){let w=e(y),S=i(y),l=K(c),h=await r(y),s=`${String(h.length+1).padStart(3,"0")}-${l}`.slice(-36);if(!S.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${y}`),{statusCode:500});return await S.files.putBytes(`${w}/${s}`,new Uint8Array(m),C||"application/octet-stream"),{name:l,stored_name:s,size:m.length,mime_type:C||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function b(y,c,C,m,w){if(!m.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let S=w?.inChat===true,l=await g(y,c,C,m),h=null;if(await R(y,I=>{let s=new Date().toISOString(),d=I.card_data&&typeof I.card_data=="object"?I.card_data:{};I.card_data=d;let n=u().normalizeIncoming([{name:l.name,stored_name:l.stored_name,size:l.size,mime_type:l.mime_type,uploaded_at:l.uploaded_at||s,chat:S}],s);return h=u().merge(d,n).findIndex(o=>o.stored_name===l.stored_name),I}),S&&w?.suppressChatRecordWrite!==true){let I=typeof h=="number"&&h>=0?` #${h}`:"";await _(y,"system",`file uploaded: ${l.name} as ${l.stored_name}${I}`,[],w?.turnId??"");}return {ok:true,file:{...l,...typeof h=="number"&&h>=0?{file_idx:h}:{},chat:S},...typeof h=="number"&&h>=0?{file_idx:h}:{}}}return {uploadCardFile:b,readCardStoredFileNames:r}}function pe(a$1){return {"discover.source-kinds":()=>a$1.discoverSourceKinds(),"inspect.board-runtime-status":()=>a$1.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>a$1.inspectCardDefinitionAndRuntime({cardId:a(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let i=b(e,"tail_turns"),u=b(e,"tail"),f=a(e,"turn_id"),R=e.all_turns===true,_=a(e,"tail_turns_before_id");return a$1.inspectChatMessagesOnCards({cardId:a(e,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...u!==void 0?{tail:u}:{},...f?{turnId:f}:{},...R?{allTurns:true}:{},..._?{tailTurnsBeforeId:_}:{}})},"inspect.file-contents":e=>a$1.inspectFileContents({cardId:a(e,"card_id"),fileIdx:Number(b(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>a$1.preflightValidateCandidateCardDefinition({candidateCardContent:d(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>a$1.preflightMaterializeCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:d(e,"mock_requires","mock_requires"),mockFetchedSources:d(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e$1=>a$1.preflightProbeSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e$1=>a$1.preflightRunSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e$1=>a$1.preflightRunSingleSourceInLiveCard({cardId:a(e$1,"card_id"),sourceIdx:e(e$1,"source_idx","source_idx"),mockRequires:d(e$1,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>a$1.preflightRunOneCycleWithCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:c(e,"mock_requires")}),"manage.read-card":e=>a$1.manageReadCard({cardId:a(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let i=a(e,"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(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...i?{turn:i}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"stage-ai-failure-message":e=>{let i=a(e,"turn_id"),u=a(e,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!u)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(e,"card_id"),role:"system",text:u,turn:i})},"manage.upsert-card":e=>a$1.manageUpsertCard({cardId:a(e,"card_id"),candidateCardContent:c(e,"candidate_card_content")}),"manage.remove-card":e=>a$1.manageRemoveCard({cardId:a(e,"card_id")})}}function me(a$1){return {"webhook.process-accumulated":()=>a$1.webhookProcessAccumulated(),"webhook.source-fetch-done":e=>a$1.webhookSourceFetchDone({token:a(e,"token"),ref:a(e,"ref")}),"webhook.source-fetch-failed":e=>a$1.webhookSourceFetchFailed({token:a(e,"token"),reason:a(e,"reason")})}}function fe(a$1){let{boardId:e,uploadCardFile:i,getMcpFacade:u,controlplane:f$1}=a$1;function R(r,g){let b=a(r,"board_id");if(!b)throw Object.assign(new Error(`${g} requires board_id`),{statusCode:400});if(b!==e)throw Object.assign(new Error(`Unknown board_id: ${b}`),{statusCode:400})}function _(r,g){let{cardId:b}=f$1.requireCardArgs(r),y=a(r,"turn_id");return R(r,g),u().manageAddChatAttachment({cardId:b,role:a(r,"role")||"user",...y?{turn:y}:{},files:[{file_name:a(r,"file_name"),content_type:a(r,"content_type")||"application/octet-stream",...typeof r.text=="string"?{text:r.text}:{},...typeof r.base64=="string"?{base64:r.base64}:{},...Array.isArray(r.bytes)?{bytes:r.bytes}:{}}]})}return {"list-runtime-cards":r=>(R(r,"list-runtime-cards"),u().listRuntimeCards()),"sse.subscribe-chat":r=>f$1.subscribeChat(r),"sse.unsubscribe-chat":r=>f$1.unsubscribeChat(r),"sse.watch-channel":r=>f$1.watchChannel(r,true),"sse.unwatch-channel":r=>f$1.watchChannel(r,false),"getstate.is-chat-processing":r=>f$1.getChatProcessing(r),"setstate.chat-processing-started":r=>f$1.setChatProcessing(r,true),"setstate.chat-processing-done":r=>f$1.setChatProcessing(r,false),"getstate.card-private":r=>f$1.getCardMeta(r),"setstate.card-private":r=>f$1.setCardMeta(r),"manage.upload-card-file":r=>{let g=a(r,"card_id"),b=a(r,"file_name"),y=a(r,"content_type")||"application/octet-stream",c=f(r);if(R(r,"manage.upload-card-file"),!g)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!c)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(g,b,y,c,{inChat:false})},"manage.add-chat-attachment":r=>_(r,"manage.add-chat-attachment"),"manage.add-chat-attachement":r=>_(r,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":r=>{let{cardId:g}=f$1.requireCardArgs(r),b=a(r,"role")||"user",y=a(r,"turn_id");return R(r,"manage.add-chat-entry-and-any-attachments"),u().manageAddChatEntryAndAnyAttachments({cardId:g,role:b,...typeof r.text=="string"?{text:r.text}:{},...y?{turn:y}:{},...Array.isArray(r.files)?{files:r.files}:{}})},"manage.patch-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.patch-card"),u().managePatchCard({cardId:g,patch:c(r,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.upsert-card"),u().manageUpsertCard({cardId:g,candidateCardContent:c(r,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.remove-card"),u().manageRemoveCard({cardId:g},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async r=>{let{cardId:g}=f$1.requireCardArgs(r);return {status:"success",data:{cards:await u().adminReadCard({cardId:g})}}},"manage.admin-upsert-card":r=>{let g=a(r,"board_id"),b=a(r,"card_id");if(!g)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(g!==e)throw Object.assign(new Error(`Unknown board_id: ${g}`),{statusCode:400});return u().adminUpsertCard({cardId:b,candidateCardContent:c(r,"candidate_card_content")})}}}function ye(a){let{boardContexts:e,cardOwnerIndex:i,cardContextForCard:u,readStatusSnapshot:f,readDataObjectsByToken:R,readCardRuntimeArtifacts:_,readCardFromStore:r,readCardDefinitions:g,processAccumulatedLaneInternal:b,reportSourceFetched:y,reportSourceFetchFailure:c,uploadCardFile:C,chatStorePublic:m,serverUrl:w,apiBasePath:S}=a;function l(){return e[0]??null}function h(){return {async status(){let n=await f();return n==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:n}},async getOutputsDataObject(n){let t=n?.params?.key;return t?{status:"success",data:(await R())[t]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(n){let t=n?.params?.key;return t?{status:"success",data:(await _())[t]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(n){let t=n?.params?.key;if(!t)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=u(t)??l();return o?o.boardOps.getOutputsFetchedSources({params:{key:t}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(n){let t=n?.params?.id;if(!t)return {status:"fail",error:"removeCard requires params.id"};let o=u(t)??l();return o?o.boardOps.removeCard({params:{id:t}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(n){let t=n?.params?.cardId;if(!t)return {status:"fail",error:"upsertCard requires params.cardId"};let o=u(t)??l();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:t,restart:n.params.restart===true}});if(k.status!=="success")return k;if(a$1(o.boardAdapter)){let P=await b(true);if(P.status!=="success")return P}return k}}}function I(){let n=()=>{let t=l();if(!t?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return t.nonCore};return {describeTaskExecutorCapabilities(t){return n().describeTaskExecutorCapabilities(t)},validateCardPreflight(t){return n().validateCardPreflight(t)},evalCardCompute(t){return n().evalCardCompute(t)},probeSourcePreflight(t){return n().probeSourcePreflight(t)},runSourcePreflight(t){return n().runSourcePreflight(t)},simulateCardCycle(t){return n().simulateCardCycle(t)}}}function s(){return {async get(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(t){let o=await r(t);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await g()}}},async set(n){let t=n.body;if(t==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(t)?t:[t];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 D=i.get(A)??0,L=e[D]??l();if(!L)return {status:"fail",error:"Board context is unavailable"};let T=await L.cardStoreOps.set({body:P});if(T.status!=="success")return T;i.set(A,D);}return {status:"success",data:{count:o.length}}},async del(n){let t=[n.params?.id,...n.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(t.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of t){let k=u(o)??l();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:t.length}}},async patch(n){let t=typeof n.params?.id=="string"?n.params.id:void 0,o=typeof n.params?.path=="string"?n.params.path:void 0;if(!t||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=u(t)??l();return k?k.cardStoreOps.patch(n):{status:"fail",error:"Board context is unavailable"}},async appendFiles(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(!t)return {status:"fail",error:"appendFiles requires params.id"};let o=u(t)??l();return o?o.cardStoreOps.appendFiles(n):{status:"fail",error:"Board context is unavailable"}}}}function d(){return a$2({board:h(),nonCore:I(),cardStore:s(),chatStore:m,processAccumulated:()=>b(true),sourceFetchDone:({token:n,ref:t})=>y(n,t),sourceFetchFailed:({token:n,reason:t})=>c(n,t),uploadCardFile({cardId:n,fileName:t,contentType:o,bytes:k,suppressChatRecordWrite:P}){return C(n,t,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:n,fileIdx:t,storedName:o}){let k=`${w||""}${S}/cards/${encodeURIComponent(n)}/files/${t}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:n,ref:t}){let o=u(n)??l();if(!o||a$1(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(b$1(t)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:h,mcpNonCoreFacade:I,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,q as h,E as i,oe as j,ie as k,ce as l,pe as m,me as n,fe as o,ye as p};//# sourceMappingURL=chunk-OEL5P7XE.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 {b as b$1}from'./chunk-44L64VQ2.js';import {a as a$2}from'./chunk-6M3RIGUH.js';function v(a){if(!a||typeof a!="object")return false;let e=a;return typeof e.kind=="string"&&e.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let e=a;return e.kind==="notification-batch"?Array.isArray(e.notifications)?e.notifications.filter(v):[]:v(a)?[a]:[]}function X(a,e,i){let u=0;return {accepted:a.filter(R=>{if(!v(R))return u++,false;let _=R;return typeof _.sentAtMs=="number"&&e-_.sentAtMs>i?(u++,false):true}),rejected:u}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let e=a.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let e=a;return e.kind==="notification-batch"&&Array.isArray(e.notifications)}function V(a,e){if(e.kind==="status"){z(e.status)&&(a.status=e.status);return}if(e.kind==="computed_values"){a.computedValues[e.cardId]=e.values;return}if(e.kind==="data_object"){a.dataObjects[e.key]=e.payload;return}if(e.kind==="card_refreshed"){a.cards[e.cardId]=e.card;return}e.kind==="card_removed"&&(delete a.cards[e.cardId],delete a.computedValues[e.cardId]);}function Y(a,e){if(W(e)){for(let i of e.notifications)v(i)&&V(a,i);return}v(e)&&V(a,e);}function j(a,e){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||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function N(a,e){return j(await a,e)}function q(a$1){let e=a(a$1,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=e.split(".");if(!(i.length>=2&&i.every(f=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(f))))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 e}function E(a,e){let i=a.__private;for(let u of e.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,u))return {exists:false,value:null};i=i[u];}return {exists:true,value:i}}function oe(a$1){let{boardId:e,bootstrapBoard:i,sseHub:u,onChannelSubscribed:f,onChannelUnsubscribed:R,getMcpFacade:_,getMcpCardStoreFacade:r}=a$1;function g(s){let d=a(s,"board_id");if(!d)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(d!==e)throw Object.assign(new Error(`Unknown board_id: ${d}`),{statusCode:400})}function b(s){let d=a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function y(s){g(s);let d=b(s),n=a(s,"channel_name"),t=a(s,"card_id")||void 0;if(!n)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:n,...t?{cardId:t}:{}}}function c(s){g(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 C(s){await i();let{cardId:d}=c(s),n=b(s);if(!await u.subscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:true}}}async function m(s){await i();let{cardId:d}=c(s),n=b(s);if(!u.unsubscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:false}}}async function w(s,d){await i();let{clientId:n,channelName:t,cardId:o}=y(s);if(!u.has(n))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return d?(u.subscribeChannel(n,t,o),f?.(n,t,o?{cardId:o}:{})):(u.unsubscribeChannel(n,t,o),R?.(n,t,o?{cardId:o}:{})),{status:"success",data:{boardId:e,clientId:n,channelName:t,subscribed:d,...o?{cardId:o}:{}}}}async function S(s,d){let{cardId:n}=c(s);return await _().setChatProcessing({cardId:n,active:d}),{status:"success",data:{boardId:e,cardId:n,active:d}}}async function l(s){let{cardId:d}=c(s),n=await _().getChatProcessing({cardId:d});return {status:"success",data:{boardId:e,cardId:d,active:n.active}}}async function h(s){let{cardId:d}=c(s),n=q(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(n.split(".").includes("visible_controlplane_only")){let t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null,k=o?E(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:e,cardId:d,key:n}}}return j(await r().patch({params:{id:d,path:`__private.${n}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:e,cardId:d,key:n}}}async function I(s){let{cardId:d}=c(s),n=q(s),t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&t.cards[0]&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=E(o,n);return {status:"success",data:{boardId:e,cardId:d,key:n,exists:k.exists,value:k.value}}}return {requireCardArgs:c,subscribeChat:C,unsubscribeChat:m,watchChannel:w,setChatProcessing:S,getChatProcessing:l,setCardMeta:h,getCardMeta:I}}function ie(a){let{boardId:e,boardContexts:i,readChatRecords:u,getChatProcessing:f}=a;function R(c){if(c.length===0)return null;if(c.length===1)return c[0];let C=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],w={};for(let l of m)w[l]=0;for(let l of c){let h=l,I=Array.isArray(h.cards)?h.cards:[];C.push(...I);for(let s of m)w[s]+=Number(h?.summary?.[s]||0);}let S=c[0];return {...S,cards:C,summary:{...S.summary||{},card_count:C.length,...w}}}async function _(){let c=[];for(let C of i)try{let m=await C.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&c.push(m.data);}catch{}return c}async function r(){let C=(await _()).map(m=>m.statusSnapshot).filter(Boolean);if(C.length===0){let m=i.map(w=>w.notification.status).filter(Boolean);return R(m)}return R(C)}async function g(){let c={},C=await _();for(let m of C)Object.assign(c,m.cardRuntimeById||{});if(Object.keys(c).length>0)return c;for(let m of i)for(let[w,S]of Object.entries(m.notification.computedValues)){let l=m.notification.cards[w];c[w]={schema_version:"v1",card_id:w,card_data:l?.card_data??{},computed_values:S??{}};}return c}async function b(){let c={},C=await _();for(let m of C)Object.assign(c,m.dataObjectsByToken||{});if(Object.keys(c).length===0)for(let m of i)Object.assign(c,m.notification.dataObjects||{});return c}async function y(){let c=await _(),C=c.flatMap(l=>Array.isArray(l.cardDefinitions)?l.cardDefinitions:[]),m={},w={};for(let l of c)Object.assign(m,l.dataObjectsByToken||{}),Object.assign(w,l.cardRuntimeById||{});let S={};for(let l of C){if(!l?.id)continue;let h=l.id;try{let I=await u(h),s=await f(h);(I.length>0||s)&&(S[h]={messages:I.map(d=>({role:String(d.role||"system"),text:String(d.text||""),files:Array.isArray(d.files)?d.files:[]})),receiving:!1,processing:s});}catch{}}return {boardId:e,cardDefinitions:C,statusSnapshot:await r(),dataObjectsByToken:m,cardRuntimeById:w,cardChatsByCardId:S}}return {readStatusSnapshot:r,readCardRuntimeArtifacts:g,readDataObjectsByToken:b,buildPublishedRuntimePayload:y}}function K(a){let e=String(a||"").trim();if(!e)return "upload.bin";let i=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (i>=0?e.slice(i+1):e)||"upload.bin"}function ce(a){let{safeCardId:e,artifactsStores:i,cardFileMetadataStore:u,readCardFromStore:f,updateCardLocalOnly:R,writeChatRecord:_}=a;async function r(y){let c=[];try{let C=await f(y);if(!C)return c;let m=u().read(C.card_data&&typeof C.card_data=="object"?C.card_data:null);for(let w of m)c.push(String(w.stored_name??""));}catch{}return c}async function g(y,c,C,m){let w=e(y),S=i(y),l=K(c),h=await r(y),s=`${String(h.length+1).padStart(3,"0")}-${l}`.slice(-36);if(!S.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${y}`),{statusCode:500});return await S.files.putBytes(`${w}/${s}`,new Uint8Array(m),C||"application/octet-stream"),{name:l,stored_name:s,size:m.length,mime_type:C||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function b(y,c,C,m,w){if(!m.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let S=w?.inChat===true,l=await g(y,c,C,m),h=null;if(await R(y,I=>{let s=new Date().toISOString(),d=I.card_data&&typeof I.card_data=="object"?I.card_data:{};I.card_data=d;let n=u().normalizeIncoming([{name:l.name,stored_name:l.stored_name,size:l.size,mime_type:l.mime_type,uploaded_at:l.uploaded_at||s,chat:S}],s);return h=u().merge(d,n).findIndex(o=>o.stored_name===l.stored_name),I}),S&&w?.suppressChatRecordWrite!==true){let I=typeof h=="number"&&h>=0?` #${h}`:"";await _(y,"system",`file uploaded: ${l.name} as ${l.stored_name}${I}`,[],w?.turnId??"");}return {ok:true,file:{...l,...typeof h=="number"&&h>=0?{file_idx:h}:{},chat:S},...typeof h=="number"&&h>=0?{file_idx:h}:{}}}return {uploadCardFile:b,readCardStoredFileNames:r}}function pe(a$1){return {"discover.source-kinds":()=>a$1.discoverSourceKinds(),"inspect.board-runtime-status":()=>a$1.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>a$1.inspectCardDefinitionAndRuntime({cardId:a(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let i=b(e,"tail_turns"),u=b(e,"tail"),f=a(e,"turn_id"),R=e.all_turns===true,_=a(e,"tail_turns_before_id");return a$1.inspectChatMessagesOnCards({cardId:a(e,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...u!==void 0?{tail:u}:{},...f?{turnId:f}:{},...R?{allTurns:true}:{},..._?{tailTurnsBeforeId:_}:{}})},"inspect.file-contents":e=>a$1.inspectFileContents({cardId:a(e,"card_id"),fileIdx:Number(b(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>a$1.preflightValidateCandidateCardDefinition({candidateCardContent:d(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>a$1.preflightMaterializeCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:d(e,"mock_requires","mock_requires"),mockFetchedSources:d(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e$1=>a$1.preflightProbeSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e$1=>a$1.preflightRunSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e$1=>a$1.preflightRunSingleSourceInLiveCard({cardId:a(e$1,"card_id"),sourceIdx:e(e$1,"source_idx","source_idx"),mockRequires:d(e$1,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>a$1.preflightRunOneCycleWithCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:c(e,"mock_requires")}),"manage.read-card":e=>a$1.manageReadCard({cardId:a(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let i=a(e,"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(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...i?{turn:i}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"stage-ai-failure-message":e=>{let i=a(e,"turn_id"),u=a(e,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!u)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(e,"card_id"),role:"system",text:u,turn:i})},"manage.upsert-card":e=>a$1.manageUpsertCard({cardId:a(e,"card_id"),candidateCardContent:c(e,"candidate_card_content")}),"manage.remove-card":e=>a$1.manageRemoveCard({cardId:a(e,"card_id")})}}function me(a$1){return {"webhook.process-accumulated":()=>a$1.webhookProcessAccumulated(),"webhook.source-fetch-done":e=>a$1.webhookSourceFetchDone({token:a(e,"token"),ref:a(e,"ref")}),"webhook.source-fetch-failed":e=>a$1.webhookSourceFetchFailed({token:a(e,"token"),reason:a(e,"reason")})}}function fe(a$1){let{boardId:e,uploadCardFile:i,getMcpFacade:u,controlplane:f$1}=a$1;function R(r,g){let b=a(r,"board_id");if(!b)throw Object.assign(new Error(`${g} requires board_id`),{statusCode:400});if(b!==e)throw Object.assign(new Error(`Unknown board_id: ${b}`),{statusCode:400})}function _(r,g){let{cardId:b}=f$1.requireCardArgs(r),y=a(r,"turn_id");return R(r,g),u().manageAddChatAttachment({cardId:b,role:a(r,"role")||"user",...y?{turn:y}:{},files:[{file_name:a(r,"file_name"),content_type:a(r,"content_type")||"application/octet-stream",...typeof r.text=="string"?{text:r.text}:{},...typeof r.base64=="string"?{base64:r.base64}:{},...Array.isArray(r.bytes)?{bytes:r.bytes}:{}}]})}return {"list-runtime-cards":r=>(R(r,"list-runtime-cards"),u().listRuntimeCards()),"sse.subscribe-chat":r=>f$1.subscribeChat(r),"sse.unsubscribe-chat":r=>f$1.unsubscribeChat(r),"sse.watch-channel":r=>f$1.watchChannel(r,true),"sse.unwatch-channel":r=>f$1.watchChannel(r,false),"getstate.is-chat-processing":r=>f$1.getChatProcessing(r),"setstate.chat-processing-started":r=>f$1.setChatProcessing(r,true),"setstate.chat-processing-done":r=>f$1.setChatProcessing(r,false),"getstate.card-private":r=>f$1.getCardMeta(r),"setstate.card-private":r=>f$1.setCardMeta(r),"manage.upload-card-file":r=>{let g=a(r,"card_id"),b=a(r,"file_name"),y=a(r,"content_type")||"application/octet-stream",c=f(r);if(R(r,"manage.upload-card-file"),!g)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!c)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(g,b,y,c,{inChat:false})},"manage.add-chat-attachment":r=>_(r,"manage.add-chat-attachment"),"manage.add-chat-attachement":r=>_(r,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":r=>{let{cardId:g}=f$1.requireCardArgs(r),b=a(r,"role")||"user",y=a(r,"turn_id");return R(r,"manage.add-chat-entry-and-any-attachments"),u().manageAddChatEntryAndAnyAttachments({cardId:g,role:b,...typeof r.text=="string"?{text:r.text}:{},...y?{turn:y}:{},...Array.isArray(r.files)?{files:r.files}:{}})},"manage.patch-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.patch-card"),u().managePatchCard({cardId:g,patch:c(r,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.upsert-card"),u().manageUpsertCard({cardId:g,candidateCardContent:c(r,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.remove-card"),u().manageRemoveCard({cardId:g},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async r=>{let{cardId:g}=f$1.requireCardArgs(r);return {status:"success",data:{cards:await u().adminReadCard({cardId:g})}}},"manage.admin-upsert-card":r=>{let g=a(r,"board_id"),b=a(r,"card_id");if(!g)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(g!==e)throw Object.assign(new Error(`Unknown board_id: ${g}`),{statusCode:400});return u().adminUpsertCard({cardId:b,candidateCardContent:c(r,"candidate_card_content")})}}}function ye(a){let{boardContexts:e,cardOwnerIndex:i,cardContextForCard:u,readStatusSnapshot:f,readDataObjectsByToken:R,readCardRuntimeArtifacts:_,readCardFromStore:r,readCardDefinitions:g,processAccumulatedLaneInternal:b,reportSourceFetched:y,reportSourceFetchFailure:c,uploadCardFile:C,chatStorePublic:m,serverUrl:w,apiBasePath:S}=a;function l(){return e[0]??null}function h(){return {async status(){let n=await f();return n==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:n}},async getOutputsDataObject(n){let t=n?.params?.key;return t?{status:"success",data:(await R())[t]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(n){let t=n?.params?.key;return t?{status:"success",data:(await _())[t]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(n){let t=n?.params?.key;if(!t)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=u(t)??l();return o?o.boardOps.getOutputsFetchedSources({params:{key:t}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(n){let t=n?.params?.id;if(!t)return {status:"fail",error:"removeCard requires params.id"};let o=u(t)??l();return o?o.boardOps.removeCard({params:{id:t}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(n){let t=n?.params?.cardId;if(!t)return {status:"fail",error:"upsertCard requires params.cardId"};let o=u(t)??l();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:t,restart:n.params.restart===true}});if(k.status!=="success")return k;if(a$1(o.boardAdapter)){let P=await b(true);if(P.status!=="success")return P}return k}}}function I(){let n=()=>{let t=l();if(!t?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return t.nonCore};return {describeTaskExecutorCapabilities(t){return n().describeTaskExecutorCapabilities(t)},validateCardPreflight(t){return n().validateCardPreflight(t)},evalCardCompute(t){return n().evalCardCompute(t)},probeSourcePreflight(t){return n().probeSourcePreflight(t)},runSourcePreflight(t){return n().runSourcePreflight(t)},simulateCardCycle(t){return n().simulateCardCycle(t)}}}function s(){return {async get(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(t){let o=await r(t);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await g()}}},async set(n){let t=n.body;if(t==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(t)?t:[t];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 D=i.get(A)??0,L=e[D]??l();if(!L)return {status:"fail",error:"Board context is unavailable"};let T=await L.cardStoreOps.set({body:P});if(T.status!=="success")return T;i.set(A,D);}return {status:"success",data:{count:o.length}}},async del(n){let t=[n.params?.id,...n.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(t.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of t){let k=u(o)??l();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:t.length}}},async patch(n){let t=typeof n.params?.id=="string"?n.params.id:void 0,o=typeof n.params?.path=="string"?n.params.path:void 0;if(!t||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=u(t)??l();return k?k.cardStoreOps.patch(n):{status:"fail",error:"Board context is unavailable"}},async appendFiles(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(!t)return {status:"fail",error:"appendFiles requires params.id"};let o=u(t)??l();return o?o.cardStoreOps.appendFiles(n):{status:"fail",error:"Board context is unavailable"}}}}function d(){return a$2({board:h(),nonCore:I(),cardStore:s(),chatStore:m,processAccumulated:()=>b(true),sourceFetchDone:({token:n,ref:t})=>y(n,t),sourceFetchFailed:({token:n,reason:t})=>c(n,t),uploadCardFile({cardId:n,fileName:t,contentType:o,bytes:k,suppressChatRecordWrite:P}){return C(n,t,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:n,fileIdx:t,storedName:o}){let k=`${w||""}${S}/cards/${encodeURIComponent(n)}/files/${t}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:n,ref:t}){let o=u(n)??l();if(!o||a$1(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(b$1(t)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:h,mcpNonCoreFacade:I,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,q as h,E as i,oe as j,ie as k,ce as l,pe as m,me as n,fe as o,ye as p};//# sourceMappingURL=chunk-CZ6ZFWFT.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-CZ6ZFWFT.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkUG55PF75_cjs=require('./chunk-UG55PF75.cjs');function b(e){return JSON.parse(JSON.stringify(e))}function E(e){let r=e.provides&&e.provides.length>0?e.provides.map(n=>n.bindTo):[e.id];return {requires:e.requires&&e.requires.length>0?[...e.requires]:void 0,provides:r,taskHandlers:[e.id],description:e.meta?.title??e.id}}function I(e){let r=new Map;for(let[n,u]of e.entries()){let o=u.provides&&u.provides.length>0?u.provides:[{bindTo:n,ref:"card_data"}];for(let h of o)r.set(h.bindTo,n);}return r}function O(e,r){let n=I(e),u=e.get(r);if(u){for(let o of u.requires??[])if(!n.has(o))throw new Error(`Card "${r}" requires token "${o}" but no card provides it`)}}var F={CARD_PREFIX:"yf:cards:",RUNTIME_OUT_PREFIX:"yf:runtime-out:cards:",STATUS_KEY:"yf:runtime-out:status",writeCard(e,r){try{localStorage.setItem(this.CARD_PREFIX+e,JSON.stringify(r));}catch(n){console.warn(`Failed to write card ${e} to localStorage:`,n);}},readCard(e){try{let r=localStorage.getItem(this.CARD_PREFIX+e);return r?JSON.parse(r):null}catch(r){return console.warn(`Failed to read card ${e} from localStorage:`,r),null}},readAllCards(e){let r={};for(let n of e){let u=this.readCard(n);u&&(r[n]=u);}return r},writeComputedArtifact(e){if(!(!e||!e.card_id))try{localStorage.setItem(this.RUNTIME_OUT_PREFIX+String(e.card_id),JSON.stringify(e));}catch(r){console.warn(`Failed to write computed artifact ${e.card_id}:`,r);}},readComputedArtifact(e){try{let r=localStorage.getItem(this.RUNTIME_OUT_PREFIX+e);return r?JSON.parse(r):null}catch(r){return console.warn(`Failed to read computed artifact ${e}:`,r),null}},readAllComputedArtifacts(e){let r={};for(let n of e){let u=this.readComputedArtifact(n);u&&(r[n]=u);}return r},writeStatusSnapshot(e){try{localStorage.setItem(this.STATUS_KEY,JSON.stringify(e));}catch(r){console.warn("Failed to write status snapshot to localStorage:",r);}},readStatusSnapshot(){try{let e=localStorage.getItem(this.STATUS_KEY);return e?JSON.parse(e):null}catch(e){return console.warn("Failed to read status snapshot from localStorage:",e),null}},clear(){let e=[];for(let r=0;r<localStorage.length;r++){let n=localStorage.key(r);n&&(n.startsWith(this.CARD_PREFIX)||n.startsWith(this.RUNTIME_OUT_PREFIX)||n===this.STATUS_KEY)&&e.push(n);}for(let r of e)localStorage.removeItem(r);}};function H(e,r={}){let n=Array.isArray(e)?{}:{id:e.id,title:e.title,mode:e.mode,positions:e.positions,settings:e.settings},u=Array.isArray(e)?e:e.nodes,o=new Map;for(let t of u){if(o.has(t.id))throw new Error(`Duplicate card ID: "${t.id}"`);o.set(t.id,b(t));}let h=new Set,S=r.taskExecutor,L=r.sourceAdapters??{},d=r.defaultSourceAdapter,m=null,A=(t,g)=>{let a={events:t,graph:g,nodes:v()};for(let w of h)w(a);},_=t=>async g=>{let a=o.get(t);if(!a)return "task-initiate-failure";let w={};for(let R of a.requires??[]){let y=g.state[R];if(!y||typeof y!="object")continue;let k=y.provides_data;!k||typeof k!="object"||Object.prototype.hasOwnProperty.call(k,R)&&(w[R]=k[R]);}let p={};if(a.source_defs&&a.source_defs.length>0){let R=L[t]??d,y=S?await S({card:a,input:g}):R?await R({card:a,input:g}):void 0;if(y&&typeof y=="object")for(let k of a.source_defs)Object.prototype.hasOwnProperty.call(y,k.bindTo)?p[k.bindTo]=y[k.bindTo]:a.source_defs.length===1&&(p[k.bindTo]=y);}let c={id:a.id,card_data:b(a.card_data??{}),requires:w,source_defs:a.source_defs,compute:a.compute};c._sourcesData=p,c.compute&&c.compute.length>0&&await chunkUG55PF75_cjs.a.run(c,{sourcesData:p});let T={};if(a.provides&&a.provides.length>0)for(let{bindTo:R,ref:y}of a.provides)T[R]=chunkUG55PF75_cjs.a.resolve(c,y);else T[a.id]={...c.card_data??{},...c.computed_values??{},...c._sourcesData??{}};let B={provides_data:T,card_data:c.card_data??{},computed_values:c.computed_values??{},fetched_sources:p,requires:w};return m?.resolveCallback(g.callbackToken,B),"task-initiated"},s={},f={};for(let[t,g]of o.entries())O(o,t),s[t]=E(g),f[t]=_(t);let l={id:n.id??`browser-board-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...n.settings??{},...r.graphSettings??{}},tasks:s},C=r.reactiveOptions?.onDrain,i=chunkG4XXRHL2_cjs.u(l,{...r.reactiveOptions??{},handlers:f,onDrain:(t,g,a)=>{C?.(t,g,a),A(t,g);}},r.executionId);m=i;function v(){let t=i.getState(),g=[];for(let[a,w]of o.entries()){let p=t.state.tasks[a]?.data,c=t.state.tasks[a],T={...w.card_data??{},...p&&typeof p.card_data=="object"?p.card_data:{}},B=c?.status==="running"?"loading":c?.status,R={...T,...B?{status:B}:{},...c?.lastUpdated?{lastRun:c.lastUpdated}:{},...c?.status==="failed"&&c.error?{error:c.error}:{}};g.push({id:a,card:b(w),card_data:R,requires:p&&typeof p.requires=="object"?b(p.requires):{},computed_values:p&&typeof p.computed_values=="object"?b(p.computed_values):{},runtime_state:c?b(c):{}});}return g}return {getGraph:()=>i,getState:()=>i.getState(),getSchedule:()=>i.getSchedule(),getNodes:()=>v(),getBoard:()=>({...n,nodes:v()}),subscribe(t){return h.add(t),t({events:[],graph:i.getState(),nodes:v()}),()=>h.delete(t)},addCard(t){if(o.has(t.id))throw new Error(`Card "${t.id}" already exists`);o.set(t.id,b(t)),O(o,t.id),i.registerHandler(t.id,_(t.id)),i.addNode(t.id,E(t));},upsertCard(t){o.set(t.id,b(t)),O(o,t.id),i.registerHandler(t.id,_(t.id)),i.addNode(t.id,E(t));},removeCard(t){o.delete(t),i.unregisterHandler(t),i.removeNode(t);},patchCardState(t,g){let a=o.get(t);if(!a)throw new Error(`Card "${t}" not found`);a.card_data={...a.card_data??{},...g},i.retrigger(t);},retrigger(t){i.retrigger(t);},retriggerAll(){i.retriggerAll(Array.from(o.keys()));},push(t){i.push(t);},pushAll(t){i.pushAll(t);},dispose(){h.clear(),i.dispose();}}}function G(e){return e==="running"||e==="in-progress"?"loading":e==="failed"?"error":"fresh"}function D(e){return e==="loading"?"in-progress":e==="error"?"failed":e==="stale"?"pending":e==="fresh"?"completed":"pending"}function M(e,r){let n=r&&typeof r=="object"&&!Array.isArray(r)?r:{};return {schema_version:n.schema_version||"v1",card_id:typeof n.card_id=="string"?n.card_id:e,card_data:n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?structuredClone(n.card_data):{},computed_values:n.computed_values&&typeof n.computed_values=="object"&&!Array.isArray(n.computed_values)?structuredClone(n.computed_values):{}}}function P(e,r){if(!e||typeof e!="object")throw new Error("payload must be an object");if(!r)throw new Error("cardId is required");let u=(Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).find(t=>t.id===r);if(!u)throw new Error(`cardDefinitions has no entry with id ${r}`);let o=e.statusSnapshot&&typeof e.statusSnapshot=="object"?e.statusSnapshot:{},h=e.cardRuntimeById&&typeof e.cardRuntimeById=="object"?e.cardRuntimeById:{},S=e.dataObjectsByToken&&typeof e.dataObjectsByToken=="object"?e.dataObjectsByToken:{},d=(Array.isArray(o.cards)?o.cards:[]).find(t=>t.name===r),m=structuredClone(u),A=M(r,h[r]),s={...m.card_data&&typeof m.card_data=="object"&&!Array.isArray(m.card_data)?m.card_data:{},...A.card_data||{},status:G(d?.status),lastRun:d?.runtime?.last_transition_at??null};d?.error?.message&&(s.error=d.error.message);let f=d?{task_status:d.status??null,card_status:G(d.status),runtime:structuredClone(d.runtime??{}),error:d.error?structuredClone(d.error):null,blocked_by:Array.isArray(d.blocked_by)?structuredClone(d.blocked_by):[],requires_missing:Array.isArray(d.requires_missing)?structuredClone(d.requires_missing):[]}:{task_status:null,card_status:s.status??"fresh",runtime:{last_transition_at:s.lastRun??null},error:s.error?{message:s.error}:null,blocked_by:[],requires_missing:[]},l=Array.isArray(m.requires)?m.requires:[],C={};for(let[t,g]of Object.entries(S))C[t]=structuredClone(g);for(let t of l)Object.prototype.hasOwnProperty.call(C,t)||(C[t]=null);let v=(e.cardChatsByCardId&&typeof e.cardChatsByCardId=="object"?e.cardChatsByCardId:{})[r],q=v?{messages:Array.isArray(v.messages)?v.messages:[],receiving:!!v.receiving,processing:!!v.processing}:null;return {id:r,card:m,card_data:s,requires:C,computed_values:A.computed_values,runtime_state:f,card_chats:q}}function $(e){if(!e||typeof e!="object")throw new Error("payload must be an object");return (Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).map(n=>P(e,n.id))}function J({boardPath:e,cardDefinitions:r,runtimeModels:n,graphState:u}){let o=Array.isArray(r)?r:[],h=Array.isArray(n)?n:[],S=new Map(h.map(s=>[s.id,s])),d=u.state?.tasks??{},m={};for(let s of h)s?.id&&(m[s.id]={schema_version:"v1",card_id:s.id,card_data:structuredClone(s.card_data??{}),computed_values:structuredClone(s.computed_values??{})});let A={};for(let s of Object.keys(d)){let f=d[s]?.data?.provides_data;if(f&&typeof f=="object")for(let l of Object.keys(f))A[l]=structuredClone(f[l]);}let _=o.map(s=>{let f=S.get(s.id)??{},l=d[s.id],C=typeof l?.status=="string"?l.status:D(f.card_data?.status),i=typeof l?.error=="string"?l.error:typeof f.card_data?.error=="string"?f.card_data.error:null;return {name:s.id,status:C,...i?{error:{message:i,code:"TASK_FAILED",at:l?.failedAt??null,source:"browser-runtime"}}:{},requires:Array.isArray(s.requires)?s.requires:[],requires_satisfied:[],requires_missing:[],provides_declared:Array.isArray(s.provides)?s.provides.map(v=>v.bindTo):[s.id],provides_runtime:Object.keys(l?.data?.provides_data??{}).sort(),blocked_by:[],unblocks:[],runtime:{attempt_count:l?.executionCount??0,restart_count:l?.retryCount??0,in_progress_since:C==="in-progress"?l?.startedAt??null:null,last_transition_at:l?.lastUpdated??f.card_data?.lastRun??null,last_completed_at:l?.completedAt??null,last_restarted_at:l?.startedAt??null,status_age_ms:null}}});return {cardDefinitions:structuredClone(o),cardRuntimeById:m,dataObjectsByToken:A,statusSnapshot:{schema_version:"v1",meta:{board:{path:e??"browser-runtime"}},summary:{card_count:_.length,completed:_.filter(s=>s.status==="completed").length,eligible:0,pending:_.filter(s=>s.status==="pending").length,blocked:0,unresolved:0,failed:_.filter(s=>s.status==="failed").length,in_progress:_.filter(s=>s.status==="in-progress").length,orphan_cards:0,topology:{edge_count:0,max_fan_out_card:null,max_fan_out:0}},cards:_}}}exports.a=F;exports.b=H;exports.c=P;exports.d=$;exports.e=J;//# sourceMappingURL=chunk-7W4QQX7S.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs');function b(e){return JSON.parse(JSON.stringify(e))}function E(e){let r=e.provides&&e.provides.length>0?e.provides.map(n=>n.bindTo):[e.id];return {requires:e.requires&&e.requires.length>0?[...e.requires]:void 0,provides:r,taskHandlers:[e.id],description:e.meta?.title??e.id}}function I(e){let r=new Map;for(let[n,u]of e.entries()){let o=u.provides&&u.provides.length>0?u.provides:[{bindTo:n,ref:"card_data"}];for(let h of o)r.set(h.bindTo,n);}return r}function O(e,r){let n=I(e),u=e.get(r);if(u){for(let o of u.requires??[])if(!n.has(o))throw new Error(`Card "${r}" requires token "${o}" but no card provides it`)}}var F={CARD_PREFIX:"yf:cards:",RUNTIME_OUT_PREFIX:"yf:runtime-out:cards:",STATUS_KEY:"yf:runtime-out:status",writeCard(e,r){try{localStorage.setItem(this.CARD_PREFIX+e,JSON.stringify(r));}catch(n){console.warn(`Failed to write card ${e} to localStorage:`,n);}},readCard(e){try{let r=localStorage.getItem(this.CARD_PREFIX+e);return r?JSON.parse(r):null}catch(r){return console.warn(`Failed to read card ${e} from localStorage:`,r),null}},readAllCards(e){let r={};for(let n of e){let u=this.readCard(n);u&&(r[n]=u);}return r},writeComputedArtifact(e){if(!(!e||!e.card_id))try{localStorage.setItem(this.RUNTIME_OUT_PREFIX+String(e.card_id),JSON.stringify(e));}catch(r){console.warn(`Failed to write computed artifact ${e.card_id}:`,r);}},readComputedArtifact(e){try{let r=localStorage.getItem(this.RUNTIME_OUT_PREFIX+e);return r?JSON.parse(r):null}catch(r){return console.warn(`Failed to read computed artifact ${e}:`,r),null}},readAllComputedArtifacts(e){let r={};for(let n of e){let u=this.readComputedArtifact(n);u&&(r[n]=u);}return r},writeStatusSnapshot(e){try{localStorage.setItem(this.STATUS_KEY,JSON.stringify(e));}catch(r){console.warn("Failed to write status snapshot to localStorage:",r);}},readStatusSnapshot(){try{let e=localStorage.getItem(this.STATUS_KEY);return e?JSON.parse(e):null}catch(e){return console.warn("Failed to read status snapshot from localStorage:",e),null}},clear(){let e=[];for(let r=0;r<localStorage.length;r++){let n=localStorage.key(r);n&&(n.startsWith(this.CARD_PREFIX)||n.startsWith(this.RUNTIME_OUT_PREFIX)||n===this.STATUS_KEY)&&e.push(n);}for(let r of e)localStorage.removeItem(r);}};function H(e,r={}){let n=Array.isArray(e)?{}:{id:e.id,title:e.title,mode:e.mode,positions:e.positions,settings:e.settings},u=Array.isArray(e)?e:e.nodes,o=new Map;for(let t of u){if(o.has(t.id))throw new Error(`Duplicate card ID: "${t.id}"`);o.set(t.id,b(t));}let h=new Set,S=r.taskExecutor,L=r.sourceAdapters??{},d=r.defaultSourceAdapter,m=null,A=(t,g)=>{let a={events:t,graph:g,nodes:v()};for(let w of h)w(a);},_=t=>async g=>{let a=o.get(t);if(!a)return "task-initiate-failure";let w={};for(let R of a.requires??[]){let y=g.state[R];if(!y||typeof y!="object")continue;let k=y.provides_data;!k||typeof k!="object"||Object.prototype.hasOwnProperty.call(k,R)&&(w[R]=k[R]);}let p={};if(a.source_defs&&a.source_defs.length>0){let R=L[t]??d,y=S?await S({card:a,input:g}):R?await R({card:a,input:g}):void 0;if(y&&typeof y=="object")for(let k of a.source_defs)Object.prototype.hasOwnProperty.call(y,k.bindTo)?p[k.bindTo]=y[k.bindTo]:a.source_defs.length===1&&(p[k.bindTo]=y);}let c={id:a.id,card_data:b(a.card_data??{}),requires:w,source_defs:a.source_defs,compute:a.compute};c._sourcesData=p,c.compute&&c.compute.length>0&&await chunkQBEQL4TL_cjs.a.run(c,{sourcesData:p});let T={};if(a.provides&&a.provides.length>0)for(let{bindTo:R,ref:y}of a.provides)T[R]=chunkQBEQL4TL_cjs.a.resolve(c,y);else T[a.id]={...c.card_data??{},...c.computed_values??{},...c._sourcesData??{}};let B={provides_data:T,card_data:c.card_data??{},computed_values:c.computed_values??{},fetched_sources:p,requires:w};return m?.resolveCallback(g.callbackToken,B),"task-initiated"},s={},f={};for(let[t,g]of o.entries())O(o,t),s[t]=E(g),f[t]=_(t);let l={id:n.id??`browser-board-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...n.settings??{},...r.graphSettings??{}},tasks:s},C=r.reactiveOptions?.onDrain,i=chunkG4XXRHL2_cjs.u(l,{...r.reactiveOptions??{},handlers:f,onDrain:(t,g,a)=>{C?.(t,g,a),A(t,g);}},r.executionId);m=i;function v(){let t=i.getState(),g=[];for(let[a,w]of o.entries()){let p=t.state.tasks[a]?.data,c=t.state.tasks[a],T={...w.card_data??{},...p&&typeof p.card_data=="object"?p.card_data:{}},B=c?.status==="running"?"loading":c?.status,R={...T,...B?{status:B}:{},...c?.lastUpdated?{lastRun:c.lastUpdated}:{},...c?.status==="failed"&&c.error?{error:c.error}:{}};g.push({id:a,card:b(w),card_data:R,requires:p&&typeof p.requires=="object"?b(p.requires):{},computed_values:p&&typeof p.computed_values=="object"?b(p.computed_values):{},runtime_state:c?b(c):{}});}return g}return {getGraph:()=>i,getState:()=>i.getState(),getSchedule:()=>i.getSchedule(),getNodes:()=>v(),getBoard:()=>({...n,nodes:v()}),subscribe(t){return h.add(t),t({events:[],graph:i.getState(),nodes:v()}),()=>h.delete(t)},addCard(t){if(o.has(t.id))throw new Error(`Card "${t.id}" already exists`);o.set(t.id,b(t)),O(o,t.id),i.registerHandler(t.id,_(t.id)),i.addNode(t.id,E(t));},upsertCard(t){o.set(t.id,b(t)),O(o,t.id),i.registerHandler(t.id,_(t.id)),i.addNode(t.id,E(t));},removeCard(t){o.delete(t),i.unregisterHandler(t),i.removeNode(t);},patchCardState(t,g){let a=o.get(t);if(!a)throw new Error(`Card "${t}" not found`);a.card_data={...a.card_data??{},...g},i.retrigger(t);},retrigger(t){i.retrigger(t);},retriggerAll(){i.retriggerAll(Array.from(o.keys()));},push(t){i.push(t);},pushAll(t){i.pushAll(t);},dispose(){h.clear(),i.dispose();}}}function G(e){return e==="running"||e==="in-progress"?"loading":e==="failed"?"error":"fresh"}function D(e){return e==="loading"?"in-progress":e==="error"?"failed":e==="stale"?"pending":e==="fresh"?"completed":"pending"}function M(e,r){let n=r&&typeof r=="object"&&!Array.isArray(r)?r:{};return {schema_version:n.schema_version||"v1",card_id:typeof n.card_id=="string"?n.card_id:e,card_data:n.card_data&&typeof n.card_data=="object"&&!Array.isArray(n.card_data)?structuredClone(n.card_data):{},computed_values:n.computed_values&&typeof n.computed_values=="object"&&!Array.isArray(n.computed_values)?structuredClone(n.computed_values):{}}}function P(e,r){if(!e||typeof e!="object")throw new Error("payload must be an object");if(!r)throw new Error("cardId is required");let u=(Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).find(t=>t.id===r);if(!u)throw new Error(`cardDefinitions has no entry with id ${r}`);let o=e.statusSnapshot&&typeof e.statusSnapshot=="object"?e.statusSnapshot:{},h=e.cardRuntimeById&&typeof e.cardRuntimeById=="object"?e.cardRuntimeById:{},S=e.dataObjectsByToken&&typeof e.dataObjectsByToken=="object"?e.dataObjectsByToken:{},d=(Array.isArray(o.cards)?o.cards:[]).find(t=>t.name===r),m=structuredClone(u),A=M(r,h[r]),s={...m.card_data&&typeof m.card_data=="object"&&!Array.isArray(m.card_data)?m.card_data:{},...A.card_data||{},status:G(d?.status),lastRun:d?.runtime?.last_transition_at??null};d?.error?.message&&(s.error=d.error.message);let f=d?{task_status:d.status??null,card_status:G(d.status),runtime:structuredClone(d.runtime??{}),error:d.error?structuredClone(d.error):null,blocked_by:Array.isArray(d.blocked_by)?structuredClone(d.blocked_by):[],requires_missing:Array.isArray(d.requires_missing)?structuredClone(d.requires_missing):[]}:{task_status:null,card_status:s.status??"fresh",runtime:{last_transition_at:s.lastRun??null},error:s.error?{message:s.error}:null,blocked_by:[],requires_missing:[]},l=Array.isArray(m.requires)?m.requires:[],C={};for(let[t,g]of Object.entries(S))C[t]=structuredClone(g);for(let t of l)Object.prototype.hasOwnProperty.call(C,t)||(C[t]=null);let v=(e.cardChatsByCardId&&typeof e.cardChatsByCardId=="object"?e.cardChatsByCardId:{})[r],q=v?{messages:Array.isArray(v.messages)?v.messages:[],receiving:!!v.receiving,processing:!!v.processing}:null;return {id:r,card:m,card_data:s,requires:C,computed_values:A.computed_values,runtime_state:f,card_chats:q}}function $(e){if(!e||typeof e!="object")throw new Error("payload must be an object");return (Array.isArray(e.cardDefinitions)?e.cardDefinitions:[]).map(n=>P(e,n.id))}function J({boardPath:e,cardDefinitions:r,runtimeModels:n,graphState:u}){let o=Array.isArray(r)?r:[],h=Array.isArray(n)?n:[],S=new Map(h.map(s=>[s.id,s])),d=u.state?.tasks??{},m={};for(let s of h)s?.id&&(m[s.id]={schema_version:"v1",card_id:s.id,card_data:structuredClone(s.card_data??{}),computed_values:structuredClone(s.computed_values??{})});let A={};for(let s of Object.keys(d)){let f=d[s]?.data?.provides_data;if(f&&typeof f=="object")for(let l of Object.keys(f))A[l]=structuredClone(f[l]);}let _=o.map(s=>{let f=S.get(s.id)??{},l=d[s.id],C=typeof l?.status=="string"?l.status:D(f.card_data?.status),i=typeof l?.error=="string"?l.error:typeof f.card_data?.error=="string"?f.card_data.error:null;return {name:s.id,status:C,...i?{error:{message:i,code:"TASK_FAILED",at:l?.failedAt??null,source:"browser-runtime"}}:{},requires:Array.isArray(s.requires)?s.requires:[],requires_satisfied:[],requires_missing:[],provides_declared:Array.isArray(s.provides)?s.provides.map(v=>v.bindTo):[s.id],provides_runtime:Object.keys(l?.data?.provides_data??{}).sort(),blocked_by:[],unblocks:[],runtime:{attempt_count:l?.executionCount??0,restart_count:l?.retryCount??0,in_progress_since:C==="in-progress"?l?.startedAt??null:null,last_transition_at:l?.lastUpdated??f.card_data?.lastRun??null,last_completed_at:l?.completedAt??null,last_restarted_at:l?.startedAt??null,status_age_ms:null}}});return {cardDefinitions:structuredClone(o),cardRuntimeById:m,dataObjectsByToken:A,statusSnapshot:{schema_version:"v1",meta:{board:{path:e??"browser-runtime"}},summary:{card_count:_.length,completed:_.filter(s=>s.status==="completed").length,eligible:0,pending:_.filter(s=>s.status==="pending").length,blocked:0,unresolved:0,failed:_.filter(s=>s.status==="failed").length,in_progress:_.filter(s=>s.status==="in-progress").length,orphan_cards:0,topology:{edge_count:0,max_fan_out_card:null,max_fan_out:0}},cards:_}}}exports.a=F;exports.b=H;exports.c=P;exports.d=$;exports.e=J;//# sourceMappingURL=chunk-FFHG3CFU.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-FFHG3CFU.cjs.map
|