yaml-flow 8.9.1 → 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 +36 -59
- package/browser/server-runtime-controlface.js +4 -4
- 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.d.cts +0 -1
- package/lib/card-compute/index.d.ts +0 -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-5U5NMYGT.js +3 -0
- package/lib/chunk-6M3RIGUH.js +2 -0
- package/lib/chunk-ATOQP3BD.js +2 -0
- package/lib/{chunk-INRLKWC2.cjs → chunk-BDT43KYE.cjs} +3 -3
- package/lib/chunk-CPJXGK2T.cjs +2 -0
- package/lib/{chunk-7KSENEPK.js → chunk-CZ6ZFWFT.js} +2 -2
- package/lib/{chunk-XQAHHUZO.cjs → chunk-FFHG3CFU.cjs} +2 -2
- package/lib/chunk-GHUW6P4G.cjs +2 -0
- package/lib/chunk-H5FKNSCO.js +3 -0
- package/lib/{chunk-OPNGCSXJ.js → chunk-MEL5LKF7.js} +2 -2
- package/lib/{chunk-HDGEWOC2.cjs → chunk-NMOUBZXX.cjs} +2 -2
- package/lib/{chunk-JAL25FGA.cjs → chunk-O65MSWUE.cjs} +2 -2
- package/lib/{chunk-IXZG74EW.cjs → chunk-QBEQL4TL.cjs} +2 -2
- package/lib/chunk-QEHKMLHA.cjs +3 -0
- package/lib/chunk-VNLMJEIX.cjs +3 -0
- package/lib/{chunk-32GZ4ODA.js → chunk-WQANIJAQ.js} +3 -3
- package/lib/chunk-X5CZE2L7.cjs +3 -0
- package/lib/chunk-YT76JNKE.js +3 -0
- package/lib/{chunk-4HIEOBJC.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 +36 -59
- package/lib/chunk-3KC6LBOG.js +0 -3
- package/lib/chunk-FO4KNVU7.cjs +0 -2
- package/lib/chunk-HWYMZK3N.cjs +0 -3
- package/lib/chunk-JMDHDY6M.js +0 -2
- package/lib/chunk-ORBKEBNX.cjs +0 -2
- package/lib/chunk-RP2I3OLA.cjs +0 -3
- package/lib/chunk-TMS7KDKH.js +0 -3
- package/lib/chunk-UIUCNV3X.cjs +0 -3
- package/lib/chunk-VS4E7QFN.js +0 -3
- package/lib/chunk-XLHMUPBW.js +0 -2
- package/lib/chunk-YBYXCFAI.js +0 -2
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {a,b}from'./chunk-JB4Q2W7I.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$6,c as c$2}from'./chunk-O5UYCGIN.js';import {p,j,k,l,c as c$1,d as d$1,m,n,e as e$1,a as a$8,b as b$3,o}from'./chunk-7KSENEPK.js';import {a as a$4,d as d$2,b as b$2,c as c$3}from'./chunk-FOFGEABN.js';import {a as a$c}from'./chunk-RKKSVOP2.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$9,c as c$4}from'./chunk-O7NOHKVR.js';import {a as a$a,b as b$4}from'./chunk-ZJ5M5COT.js';import {i,d,c,b as b$1,g,h}from'./chunk-TMS7KDKH.js';import {a as a$b}from'./chunk-6MD6FVE3.js';import {y,z,l as l$1}from'./chunk-VS4E7QFN.js';import {a as a$5}from'./chunk-7QNEV5S3.js';import {a as a$7}from'./chunk-BJGK5FNL.js';import {a as a$1}from'./chunk-NIBLKYXN.js';import {e}from'./chunk-UGB7PC4P.js';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=a$9(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=c$4(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 a$a(b,S,j());if(f&&typeof f=="object"&&!Array.isArray(f)){let T=f;if(T.status==="fail")return w(B,400,{error:b$4(f,"Request failed")}),!0;if(T.status==="error")return w(B,500,{error:b$4(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(`^${c$3(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(`^${c$3(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(`^${c$3(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}=b$3($,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$1=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$1=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=a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:J}),l$2=a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function A(t){function e(a){return {...a,queueStorageForRef(d,C){return a$7(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}function r(a){return {...a,queueStorageForRef(d,C){return h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}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$1(a){if(a.kind==="notification-batch"){O(a.notifications,s??void 0);return}O([a],s??void 0);}let c$2=a$4(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),D=t.nonCoreAdapter??(!a$4(c$2)&&b$3(c$2)?c$2:null),y$1=a$4(c$2)?i(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}):y(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}),q=t.nonCore??(D?z(t.baseRef,D,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c$2.chatStorageForRef(t.chatStoreRef),lt,We=a$4(c$2)?(()=>{let a=d(c(b$1(c$2.kvStorageForRef(t.cardStoreRef)),c$2.hashFn),v.warn),d$1=g(a,{emitNotification:i$1}),C=o(d$1);return lt={get(p){return C.get(p)},set(p){return C.set(p)}},C})():(()=>{let a=c$2.kvStorageForRef(t.cardStoreRef),C=a$5(l$1({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$1});return lt=C,n(C)})(),ft;if(a$4(c$2)){let a=c$2.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$2.blobStorageForRef(t.artifactsStoreRef),d=a$6(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$1.init(a)},async status(a){return y$1.status(a)},async getConfig(a){return y$1.getConfig(a)},async getAllOutputsDataObjects(a){return y$1.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return y$1.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return y$1.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return y$1.buildSseOneShotPayload(a)},async upsertCard(a){return y$1.upsertCard(a)},async removeCard(a){return y$1.removeCard(a)},async sourceDataFetched(a){return y$1.sourceDataFetched(a)},async sourceDataFetchFailure(a){return y$1.sourceDataFetchFailure(a)}};return s={label:t.label,board:y$1,nonCore:q,publicCardStore:lt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return ft},get chatStorage(){return Ue},boardAdapter:c$2,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:c$1(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let u=R.boards.map(A),k$1=new Map;function x(t){return k$1.get(t)??0}function N(t){return t.queueStoreRef}function m$1(t,e){if(a$4(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(N(t),e);return a$b(n)}let r=t.boardAdapter.queueStorageForRef(N(t),e);return a$c(r)}function b$3(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 c$2()}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$1(t.cardId)??void 0:u[0]??void 0}function g$1(t){for(let e of t){let r=P(e);if(r)return r}return u[0]??void 0}function _(t,e$2={}){if(!t||t.length===0)return;let r=e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e$2.ctx??g$1(r);if(e$2.appendState!==false&&o&&e$1(o.notification,n),e$2.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$2.broadcastNotificationBatch(s);}if(!(e$2.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=a$8(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&&d$1(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$1.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$1(t){return u[x(t)]??null}async function X(t){let e=z$1(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$1(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=a$1({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=p({boardContexts:u,cardOwnerIndex:k$1,cardContextForCard:t=>z$1(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$1}),Re=wt.mcpCardStoreFacade,it=wt.createMcpFacade,ye=j({boardId:F,bootstrapBoard:()=>st(),sseHub:V,onChannelSubscribed:H,onChannelUnsubscribed:B,getMcpFacade:()=>it(),getMcpCardStoreFacade:()=>Re()});function he(t){return m(t)}function we(){return n(it())}function bt(){return o({boardId:F,uploadCardFile:Ct,getMcpFacade:()=>it(),controlplane:ye})}let ct=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$1(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$1(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=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$1(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;a$4(i.boardAdapter)?await m$1(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}):m$1(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"&&b$2(e)===de){let n=j$1,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$1(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 a$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(b$4(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 a$a("setstate.chat-processing-started",{board_id:F,card_id:t},s);if(q?.status!=="success")throw new Error(b$4(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(d$2(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=b({sseHub:V,queueSseHub:l$2,corsHeaders:w,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:$,onChannelSubscribed:H,onChannelUnsubscribed:B,apiBasePath:h$1,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),boardContexts:u,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=a$2({apiBasePath:h$1,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=a$3({apiBasePath:h$1,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ce({apiBasePath:h$1,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$1,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$1},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(d$2(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(`^${c$3(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}}export{jr as a,Mr as b};//# sourceMappingURL=chunk-
|
|
3
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {a,b}from'./chunk-JB4Q2W7I.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$6,c as c$2}from'./chunk-O5UYCGIN.js';import {p,j,k,l,c as c$1,d as d$1,m,n,e as e$1,a as a$8,b as b$3,o}from'./chunk-CZ6ZFWFT.js';import {a as a$4,d as d$2,b as b$2,c as c$3}from'./chunk-FOFGEABN.js';import {a as a$c}from'./chunk-RKKSVOP2.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$9,c as c$4}from'./chunk-O7NOHKVR.js';import {a as a$a,b as b$4}from'./chunk-ZJ5M5COT.js';import {i,d,c,b as b$1,g,h}from'./chunk-5U5NMYGT.js';import {a as a$b}from'./chunk-6MD6FVE3.js';import {y,z,l as l$1}from'./chunk-H5FKNSCO.js';import {a as a$5}from'./chunk-7QNEV5S3.js';import {a as a$7}from'./chunk-BJGK5FNL.js';import {a as a$1}from'./chunk-NIBLKYXN.js';import {e}from'./chunk-UGB7PC4P.js';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=a$9(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=c$4(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 a$a(b,S,j());if(f&&typeof f=="object"&&!Array.isArray(f)){let T=f;if(T.status==="fail")return w(B,400,{error:b$4(f,"Request failed")}),!0;if(T.status==="error")return w(B,500,{error:b$4(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(`^${c$3(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(`^${c$3(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(`^${c$3(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}=b$3($,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$1=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$1=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=a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:J}),l$2=a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function A(t){function e(a){return {...a,queueStorageForRef(d,C){return a$7(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}function r(a){return {...a,queueStorageForRef(d,C){return h(a.queueStorageForRef(d,C),{lane:C,emitNotification:i$1})}}}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$1(a){if(a.kind==="notification-batch"){O(a.notifications,s??void 0);return}O([a],s??void 0);}let c$2=a$4(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),D=t.nonCoreAdapter??(!a$4(c$2)&&b$3(c$2)?c$2:null),y$1=a$4(c$2)?i(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}):y(t.baseRef,c$2,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i$1}),q=t.nonCore??(D?z(t.baseRef,D,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c$2.chatStorageForRef(t.chatStoreRef),lt,We=a$4(c$2)?(()=>{let a=d(c(b$1(c$2.kvStorageForRef(t.cardStoreRef)),c$2.hashFn),v.warn),d$1=g(a,{emitNotification:i$1}),C=o(d$1);return lt={get(p){return C.get(p)},set(p){return C.set(p)}},C})():(()=>{let a=c$2.kvStorageForRef(t.cardStoreRef),C=a$5(l$1({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$1});return lt=C,n(C)})(),ft;if(a$4(c$2)){let a=c$2.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$2.blobStorageForRef(t.artifactsStoreRef),d=a$6(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$1.init(a)},async status(a){return y$1.status(a)},async getConfig(a){return y$1.getConfig(a)},async getAllOutputsDataObjects(a){return y$1.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return y$1.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return y$1.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return y$1.buildSseOneShotPayload(a)},async upsertCard(a){return y$1.upsertCard(a)},async removeCard(a){return y$1.removeCard(a)},async sourceDataFetched(a){return y$1.sourceDataFetched(a)},async sourceDataFetchFailure(a){return y$1.sourceDataFetchFailure(a)}};return s={label:t.label,board:y$1,nonCore:q,publicCardStore:lt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return ft},get chatStorage(){return Ue},boardAdapter:c$2,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:c$1(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let u=R.boards.map(A),k$1=new Map;function x(t){return k$1.get(t)??0}function N(t){return t.queueStoreRef}function m$1(t,e){if(a$4(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(N(t),e);return a$b(n)}let r=t.boardAdapter.queueStorageForRef(N(t),e);return a$c(r)}function b$3(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 c$2()}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$1(t.cardId)??void 0:u[0]??void 0}function g$1(t){for(let e of t){let r=P(e);if(r)return r}return u[0]??void 0}function _(t,e$2={}){if(!t||t.length===0)return;let r=e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e$2.ctx??g$1(r);if(e$2.appendState!==false&&o&&e$1(o.notification,n),e$2.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$2.broadcastNotificationBatch(s);}if(!(e$2.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=a$8(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&&d$1(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$1.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$1(t){return u[x(t)]??null}async function X(t){let e=z$1(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$1(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=a$1({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=p({boardContexts:u,cardOwnerIndex:k$1,cardContextForCard:t=>z$1(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$1}),Re=wt.mcpCardStoreFacade,it=wt.createMcpFacade,ye=j({boardId:F,bootstrapBoard:()=>st(),sseHub:V,onChannelSubscribed:H,onChannelUnsubscribed:B,getMcpFacade:()=>it(),getMcpCardStoreFacade:()=>Re()});function he(t){return m(t)}function we(){return n(it())}function bt(){return o({boardId:F,uploadCardFile:Ct,getMcpFacade:()=>it(),controlplane:ye})}let ct=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$1(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$1(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=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$1(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;a$4(i.boardAdapter)?await m$1(i,"chat-agent").enqueueRequest({boardId:F,ref:q,args:c!=null?{...y,__chatHandlerFlow:c}:y}):m$1(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"&&b$2(e)===de){let n=j$1,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$1(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 a$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(b$4(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 a$a("setstate.chat-processing-started",{board_id:F,card_id:t},s);if(q?.status!=="success")throw new Error(b$4(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(d$2(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=b({sseHub:V,queueSseHub:l$2,corsHeaders:w,json:et,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:$,onChannelSubscribed:H,onChannelUnsubscribed:B,apiBasePath:h$1,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>st(),boardContexts:u,publishPersistedStateSnapshot:t=>ut(t),upsertCardsFromSource:(t,e)=>Rt(t,e)}).handleWatchersRoutes,qe=a$2({apiBasePath:h$1,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=a$3({apiBasePath:h$1,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ce({apiBasePath:h$1,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$1,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$1},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(d$2(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(`^${c$3(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}}export{jr as a,Mr as b};//# sourceMappingURL=chunk-WQANIJAQ.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-WQANIJAQ.js.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
'use strict';var chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkVNLMJEIX_cjs=require('./chunk-VNLMJEIX.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');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 chunkVNLMJEIX_cjs.a(e,o)}function It(e,o,a){return {blob:e,kv:o,journal:a}}function st(e,o={}){function a(m){return {status:"success",data:m}}function r(m){return {status:"fail",error:m}}function s(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}async function d(m){let l=o.emitNotification;if(!l||m.length===0)return;let R=chunk2RIHC5TZ_cjs.e(m);if(R.length===1){await l(R[0]);return}await l(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:R}));}async function f(m){let l=m.params?.id;if(l){let R=await e.readCard(l);if(!R)throw new Error(`card "${l}" not found`);return [R]}return await e.readAllCards()}function P(m){return chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:chunk2RIHC5TZ_cjs.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(m)})}catch(l){return s(l)}},async buildNotificationBatch(m){try{return a(P(await f(m)))}catch(l){return s(l)}},async set(m){try{let l=m.body;if(l==null)return r("set requires a body (card object or array of cards)");let 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.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.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.patchCard(l,R,B);let x=await e.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.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,o={}){async function a(r){let s=o.emitNotification;if(!s||r.length===0)return;let d=chunk2RIHC5TZ_cjs.e(r);if(d.length===1){await s(d[0]);return}await s(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:d}));}return {async enqueue(r){let s=await e.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await e.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:e.enqueueIfAbsent?async(r,s)=>{let d=await e.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return e.lease(r)},ack(r,s){return e.ack(r,s)},nack(r,s,d){return e.nack(r,s,d)},peekActive(r){return e.peekActive(r)},peekDeadLetter(r){return e.peekDeadLetter(r)},async stage(r,s){return e.stage(r,s)},async commitStaged(r){let s=await e.commitStaged(r);if(s){let d=await pt(e,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return e.discardStaged(r,s)},peekStaged(r){return e.peekStaged(r)}}}function 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 chunkVNLMJEIX_cjs.j(e,chunkVNLMJEIX_cjs.o,()=>({_sources:{}}))}function Rt(e,o){return chunkVNLMJEIX_cjs.h(e,o)}function Ct(e){return chunkVNLMJEIX_cjs.k(e)}function kt(e,o){return chunkVNLMJEIX_cjs.i(e,o)}function wt(e,o,a,r,s,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=>chunkVNLMJEIX_cjs.p(B._sources[S]),E=(S,y)=>{B._sources[S]=chunkVNLMJEIX_cjs.p(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,chunkVNLMJEIX_cjs.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?chunkVNLMJEIX_cjs.r(y,T):chunkVNLMJEIX_cjs.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&&chunkQBEQL4TL_cjs.a.runSync(W,{sourcesData:z}),(s??(()=>{}))(m,W.computed_values??{});let Y=chunkQBEQL4TL_cjs.a.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 chunkVNLMJEIX_cjs.q(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:chunkVQCIOKJV_cjs.a(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 chunkVNLMJEIX_cjs.q(T,_)==="in-flight"}))return "task-initiated";let ce=k.provides??[],ie={};for(let{bindTo:S,ref:y}of ce)ie[S]=chunkQBEQL4TL_cjs.a.resolve(W,y);return (d??(()=>{}))(ie),r(f.nodeId,ie),P.length>0&&await a.executionRequestStore.appendEntries(o,P),"task-initiated"}}function Gt(e,o,a={}){chunkVNLMJEIX_cjs.d(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=chunkVQCIOKJV_cjs.a(e),f=a.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),P=null,k=a.boardRuntimeStoreRef,m=a.scratchStoreRef,l=a.taskExecutorRef,R=a.chatHandlerFlow;function w(){if(!k)throw new Error(`Board at ${e.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=chunk2RIHC5TZ_cjs.e(n),c=chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:t});return Promise.resolve(f(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(t){s(`[async-board-live-cards-public] emitNotification failed: ${t instanceof Error?t.message:String(t)}`);return}}let x=()=>chunkWRMOGPRG_cjs.b(o.kvStorageForRef(w())),L=e.value,$=()=>chunkVNLMJEIX_cjs.b(chunkVNLMJEIX_cjs.a(()=>o.kvStorageForRef(w()),o.hashFn),"v1"),E=async()=>{let n=await x().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e.value} has no outputs store configured.`);return Ct(o.kvStorageForRef(n))},M=async()=>{let n=await x().readCardStoreRef();if(!n)throw new Error(`Board at ${e.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[chunkVNLMJEIX_cjs.n]}async function Q(){let n=await $().readSnapshot(L);if(!n.values[chunkVNLMJEIX_cjs.n])throw new Error(`Board not initialized at ${e.value}`);return chunkVNLMJEIX_cjs.w(n.values)}async function W(n,t){let c=await $().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:chunkVNLMJEIX_cjs.v(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let Y=()=>chunkVNLMJEIX_cjs.c(o.journalStorageForRef(w()));async function he(){return l??await x().readTaskExecutorRef()}async function q(n){await Y().appendEvent(n);}async function de(){let n=await x().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function 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 chunkVQCIOKJV_cjs.a(c)}async function ie(){let n=kt(o.kvStorageForRef(w()),async(u,g)=>{let h=u.payload,O=(h.enrichedCard??{}).id??h.cardId??"unknown";await q({type:"task-failed",taskName:O,error:g,timestamp:N()});}),t=St(o.kvStorageForRef(w())),c=await X(),i=await se(),v=await M(),b=await E(),F=new Map,p=new Map,D=[],G=[],ne=[],ae=new Map,ue=new Set,Pe={async readRuntime(u){return F.get(u)??await t.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),be[u]=g;}},ct={async readSourceData(u,g){let h=`${u}/${g}`;return p.has(h)?p.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.set(J,JSON.parse(ee));}catch{p.set(J,ee);}return D.push({cardId:u,outputFile:g,deliveryToken:h}),true},async hasSource(u,g){let h=`${u}/${g}`;return p.has(h)||await i.hasSource(u,g)},async listSources(u){let g=await i.listSources(u),h=[...p.keys()].filter(V=>V.startsWith(`${u}/`)).map(V=>V.slice(`${u}/`.length));return [...new Set([...g,...h])]}},ve=await Q(),mt=chunkG4XXRHL2_cjs.q(ve.graph),be={...ve.runtimeByCardId},{events:lt,newCursor:Ae}=await Y().readEntriesAfterCursor(ve.lastDrainedJournalId),me=lt,le=chunkG4XXRHL2_cjs.u(mt,{handlers:{"card-handler":wt(e,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:chunkG4XXRHL2_cjs.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.writeRuntime(u,g);for(let u of D)await i.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let qe=chunkVNLMJEIX_cjs.t(d,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().readQueueStoreRef();if(!O)throw new Error(`Board at ${e.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:chunkVQCIOKJV_cjs.a(Ne),deliveryToken:fe,outputFile:H.outputFile,cardId:h},ft=it({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),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:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ft),output:_e}});}U.length>0&&await J.enqueueMany(U);}catch(O){await q({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:chunkVQCIOKJV_cjs.a(ge),deliveryToken:H,outputFile:O.outputFile,cardId:h});}let ee=it({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),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:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ee),...J?{output:J}:{}});U.dispatched||await q({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().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");t.enqueueIfAbsent?await t.enqueueIfAbsent({boardRef:chunkVQCIOKJV_cjs.a(e)},`process-accumulated:${chunkVQCIOKJV_cjs.a(e)}`):await t.enqueue({boardRef:chunkVQCIOKJV_cjs.a(e)}),await o.requestProcessAccumulated?.();}async function _(){let n=await x().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await t.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await t.ack(i.id,i.leaseToken);if(c.length<64)return}}function j(){T();}return {async init(n){try{let t=n.params?.cardStoreRef;if(!t)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:chunkG4XXRHL2_cjs.p(chunkG4XXRHL2_cjs.a(chunkVNLMJEIX_cjs.u)),runtimeByCardId:{}},null);let p=x();return await p.writeBoardRuntimeStoreRef(k),await p.writeCardStoreRef(t),await p.writeOutputsStoreRef(c),await p.writeQueueStoreRef(i),await p.writeFetchedSourcesStoreRef(v),await p.writeChatStoreRef(b),await p.writeArtifactsStoreRef(F),await(await E()).writeStatusSnapshot(chunkVNLMJEIX_cjs.t(d,chunkG4XXRHL2_cjs.q((await Q()).graph))),A()}catch(t){return I(t)}},async status(n){try{let t=await E(),c=await t.readStatusSnapshot();return c||(c=chunkVNLMJEIX_cjs.t(d,chunkG4XXRHL2_cjs.q((await Q()).graph)),await t.writeStatusSnapshot(c)),A(c)}catch(t){return I(t)}},async getCardStoreRef(n){try{let t=await x().readCardStoreRef();return t?A({storeRef:t}):C(`Board at ${e.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().readOutputsStoreRef();return t?A({storeRef:t}):C(`Board at ${e.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().readChatStoreRef()})}catch(t){return I(t)}},async getArtifactsStoreRef(n){try{return A({storeRef:await x().readArtifactsStoreRef()})}catch(t){return I(t)}},async getFetchedSourcesStoreRef(n){try{return A({storeRef:await x().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(),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}).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({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({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.value}`);let F=o.kvStorage("card-upsert");for(let p of b){let D=await v.readCard(p);if(!D)continue;let G=chunkVNLMJEIX_cjs.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({type:"task-upsert",taskName:p,taskConfig:G,timestamp:N()}),await F.write(p,{blobRef:Pe,taskConfigHash:ne,updatedAt:N()});}i&&await q({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({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({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=i.dt||o.genId();i.dt||await v.ingestSourceDataStaged(i.cid,i.d,chunkVQCIOKJV_cjs.b(c),b);let F=we(i.cbk);return F?(await q({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:N(),deliveryToken:b,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({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
|
+
exports.a=et;exports.b=nt;exports.c=at;exports.d=ot;exports.e=At;exports.f=It;exports.g=st;exports.h=Bt;exports.i=Gt;//# sourceMappingURL=chunk-X5CZE2L7.cjs.map
|
|
3
|
+
//# sourceMappingURL=chunk-X5CZE2L7.cjs.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {q as q$1}from'./chunk-MNEOJWPS.js';import {b as b$1}from'./chunk-FW4363Y4.js';import j from'ajv-formats';import {createRequire}from'module';var h={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://nsreehari.github.io/boards/live-cards.schema.json",definitions:{bind_ref:{description:"A card data path reference, e.g. 'card_data.raw_quotes' or 'requires.upstream'",type:"string",pattern:"^(card_data|requires|fetched_sources|computed_values)(\\.|$)"},bind_or_literal:{description:"A literal value or a bind reference object",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref"}},required:["bind"]}]},compute_expr:{description:"A declarative JSON compute expression",type:"object",required:["fn"],properties:{fn:{type:"string",description:"Function name from the built-in vocabulary",enum:["sum","avg","min","max","count","first","last","add","sub","mul","div","round","abs","mod","gt","gte","lt","lte","eq","neq","if","and","or","not","concat","upper","lower","template","filter","pluck","map","sort","slice","flat","unique","group","get","default","now","diff_days","format_date"]},input:{description:"card_data.path, literal, array of inputs, or nested compute_expr",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{$ref:"#/definitions/compute_expr"}]},field:{type:"string",description:"For pluck/sum/group \u2014 the object key to extract"},where:{$ref:"#/definitions/compute_expr",description:"For filter \u2014 predicate expression ($ = current item)"},cond:{$ref:"#/definitions/compute_expr",description:"For if \u2014 condition expression"},then:{description:"For if \u2014 value when cond is truthy"},else:{description:"For if \u2014 value when cond is falsy"},format:{type:"string",description:"For format_date \u2014 date format string"}}},meta:{type:"object",properties:{title:{type:"string"},presentation:{type:"object",description:"Semantic presentation hints authored on the card, expressed from the user's perception of the card on the Main Canvas. Content shape is inferred from view.elements[].kind; runtime placement and live drag/resize coordinates are frontend-managed and must not be authored into card JSON.",properties:{prominence:{type:"string",default:"standard",description:"How much the user should care about this card / how much attention it earns. Default: standard; omit unless a non-standard value is needed.",enum:["glance","standard","feature","spotlight"]},footprint:{type:"string",default:"standard",description:"How much room the card wants to render well, independent of attention. Default: standard; omit unless a non-standard value is needed.",enum:["compact","standard","wide","large"]},resizable:{type:"boolean",default:true,description:"Whether the user may resize this card at runtime. Default: true; omit unless it must be false."}},additionalProperties:true},tags:{type:"array",items:{type:"string"}}},additionalProperties:true},__private:{description:"Control-plane-owned private state. Stripped entirely from all regular /mcp read responses. Writable only via 'setstate.card-private' and 'manage.admin-upsert-card'. Agents must never author this field. Keys inside use plain names (no leading underscores).",type:"object",additionalProperties:true},requires:{type:"array",items:{type:"string"},description:"IDs of upstream nodes this node depends on"},provides:{type:"array",items:{type:"object",required:["bindTo","ref"],properties:{bindTo:{type:"string",description:"Token name published downstream"},ref:{type:"string",description:"Path to read value from (card_data.*, requires.*, fetched_sources.*, computed_values.*)"}}},description:"Explicit bindings exposing computed or card_data values downstream as named tokens"},compute_step:{description:"A single ordered compute step: reads card_data.*/requires.*/computed_values.*, writes to computed_values[bindTo]",type:"object",required:["bindTo","expr"],properties:{bindTo:{type:"string",description:"Key in computed_values to write result"},expr:{type:"string",description:"JSONata expression evaluated against { card_data, requires, fetched_sources, computed_values }"}}},source_def:{description:"One source entry. The engine requires 'bindTo' (compute namespace key) and 'outputFile' (delivery signal path). bindTo and outputFile must be unique across all source_defs in a card. Every other property is yours \u2014 add whatever your task-executor needs: kind, url, headers, mailbox, channel, model, query, etc. The full object is passed verbatim as the --in JSON to the executor.",type:"object",required:["bindTo","outputFile"],additionalProperties:true,properties:{bindTo:{type:"string",description:"Key under fetched_sources.* available in compute expressions"},outputFile:{type:"string",description:"Board-relative path the executor writes its JSON result to. Presence of this file signals delivery."},projections:{type:"object",description:"Named data projections from card_data or requires, evaluated before the executor is called. Each key is a ref name; each value is a JSONata expression rooted at card_data or requires. The resolved values are passed to the executor as _projections. fetched_sources, computed_values, and source_defs are not accessible here \u2014 sources run before those exist.",additionalProperties:{type:"string"}},timeout:{type:"integer",minimum:0,default:12e4,description:"Executor/script timeout in ms. Default: 120 000 (2 min)."},script:{type:"string",description:"Legacy direct-run: shell command executed when no .task-executor is registered. stdout is captured as the result."}}},render_element:{type:"object",required:["kind"],properties:{id:{type:"string",description:"Optional element ID for targeted updates"},kind:{enum:["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]},label:{type:"string",description:"Heading above this element"},className:{type:"string",description:"Bootstrap grid class, e.g. 'col-12 col-md-6'"},visible:{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 element shown only if truthy"},data:{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref",description:"card_data/requires/fetched_sources/computed_values path to read data from"},writeTo:{$ref:"#/definitions/bind_ref",description:"card_data path for user input (form, filter, todo, notes)"},columns:{type:"array",items:{type:"string"},description:"table: visible columns"},maxRows:{type:"integer",description:"table/list: max rows to display"},sortable:{type:"boolean",default:true,description:"table: enable click-to-sort"},placeholder:{type:"string",description:"Empty-state message"},chartType:{enum:["bar","line","pie","doughnut"]},chartOptions:{type:"object",description:"Chart.js options passthrough"},fields:{type:"object",description:"JSON Schema for form/filter fields"},thresholds:{type:"object",properties:{green:{type:"string"},amber:{type:"string"}}},colorMap:{type:"object",description:"badge: value \u2192 Bootstrap color"},style:{enum:["heading","muted","default"],description:"text: display style"},upload:{type:"boolean",default:true,description:"file-upload: show drop zone (false = read-only file list)"},accept:{type:"array",items:{type:"string"},description:"file-upload: allowed extensions"},multiple:{type:"boolean",default:true,description:"file-upload: allow multiple files"},fileAttach:{type:"boolean",default:false,description:"chat: enable inline file attachments"},fileAccept:{type:"array",items:{type:"string"},description:"chat: allowed attachment extensions"},buttons:{type:"array",description:"actions: button definitions",items:{type:"object",required:["id","label"],properties:{id:{type:"string"},label:{type:"string"},style:{type:"string",description:"Bootstrap button variant, e.g. 'success', 'outline-danger'"},size:{type:"string",default:"sm"},disabled:{oneOf:[{type:"boolean"},{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 truthy = disabled"}]}}}}}}}},view:{type:"object",required:["elements"],properties:{elements:{type:"array",minItems:1,items:{$ref:"#/definitions/render_element"}}}}},title:"LiveCard",description:"A unified card node. Behavior depends on which sections are present (source_defs, compute, view, etc.)",type:"object",required:["id"],additionalProperties:false,properties:{id:{type:"string"},requires:{$ref:"#/definitions/requires"},provides:{$ref:"#/definitions/provides"},meta:{$ref:"#/definitions/meta"},__private:{$ref:"#/definitions/__private"},view:{$ref:"#/definitions/view"},card_data:{type:"object",description:"User editable data on card. Includes uploaded-file metadata maintained by host handlers. Not to be used for card static content.",properties:{files:{type:"array",description:"Optional uploaded-file metadata maintained by host handlers. Stored name is normalized and serial-prefixed (for example 001-my_file.pdf).",items:{type:"object",required:["name","stored_name"],properties:{name:{type:"string",minLength:1},stored_name:{type:"string",minLength:5,maxLength:32,pattern:"^[0-9]{3,}-[a-z0-9._-]+$"},size:{oneOf:[{type:"integer",minimum:0},{type:"null"}]},mime_type:{type:"string"},path:{type:"string",pattern:"^[^\\s]+/files/[0-9]{3,}-[a-z0-9._-]+$"},uploaded_at:{type:"string",format:"date-time"},chat:{type:"boolean",description:"Whether this file entry is associated with a chat interaction"}},additionalProperties:false}}},additionalProperties:true},source_defs:{type:"array",description:"Source entries. Each entry is passed verbatim to the board's .task-executor (registered via init --task-executor) as the --in JSON file. The executor fetches/generates the data and writes JSON to --out. If no executor is registered, the built-in executor runs the entry's 'cli' command directly. Sources gate completion.",items:{$ref:"#/definitions/source_def"}},compute:{type:"array",description:"Ordered array of compute steps. Each reads card_data.*/requires.*/fetched_sources.*/computed_values.* and writes to ephemeral computed_values[bindTo].",items:{$ref:"#/definitions/compute_step"}}}};var _=b$1(q$1(),1);var k=createRequire(import.meta.url),q=k("./jsonata-sync.cjs"),f=null;var g=/\b(card_data|requires|fetched_sources|computed_values|source_defs)\b/g,N=/^\s*(card_data|requires|fetched_sources|computed_values|source_defs)(\.|$)/;function S(e){let t=new Set,s;for(g.lastIndex=0;(s=g.exec(e))!==null;)t.add(s[1]);return t}function v(e){let t=N.exec(e);return t?t[1]:null}function b(e,t,s,a){try{q(e);}catch(o){let d=o instanceof Error?o.message:String(o);a.push(`${t}: invalid JSONata expression (${d})`);return}let i=S(e);for(let o of i)s.has(o)||a.push(`${t}: disallowed namespace "${o}" in expression`);}function y(e,t,s){if(Array.isArray(e)){e.forEach((i,o)=>{y(i,`${t}/${o}`,s);});return}if(typeof e=="string"){let i=v(e);if(!i)return;new Set(["card_data","requires","computed_values"]).has(i)||s.push(`${t}: disallowed namespace "${i}" in view reference`);return}if(!e||typeof e!="object")return;let a=e;for(let[i,o]of Object.entries(a))y(o,`${t}/${i}`,s);}function E(){if(f)return f;let e=new _.default({allErrors:true});return j(e),f=e.compile(h),f}function O(e){let t=E(),s=t(e),a=(t.errors??[]).map(i=>`${i.instancePath||"/"}: ${i.message??"unknown error"}`);if(e&&typeof e=="object"&&!Array.isArray(e)){let i=e.source_defs;if(Array.isArray(i)){let o=new Set,d=new Set;i.forEach((c,u)=>{if(!c||typeof c!="object"||Array.isArray(c))return;let r=c;typeof r.bindTo=="string"&&r.bindTo&&(o.has(r.bindTo)&&a.push(`/source_defs/${u}/bindTo: bindTo "${r.bindTo}" must be unique across all source_defs`),o.add(r.bindTo)),typeof r.outputFile=="string"&&r.outputFile&&(d.has(r.outputFile)&&a.push(`/source_defs/${u}/outputFile: outputFile "${r.outputFile}" must be unique across all source_defs`),d.add(r.outputFile));});}}return !s||a.length>0?{ok:false,errors:a}:{ok:true,errors:[]}}function R(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:true,errors:[]};let s=e,a=s.compute;Array.isArray(a)&&a.forEach((r,p)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let n=r.expr;typeof n!="string"||n.trim().length===0||b(n,`/compute/${p}/expr`,new Set(["card_data","requires","fetched_sources","computed_values"]),t);});let i=new Set(["card_data","requires","fetched_sources","computed_values"]),o=s.provides;Array.isArray(o)&&o.forEach((r,p)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let n=r.ref;if(typeof n!="string"||n.trim().length===0)return;let l=v(n);l===null?t.push(`/provides/${p}/ref: path "${n}" must start with a valid namespace (${[...i].join(", ")})`):i.has(l)||t.push(`/provides/${p}/ref: disallowed namespace "${l}" in path "${n}" (valid: ${[...i].join(", ")})`);});let d=s.view;d&&typeof d=="object"&&!Array.isArray(d)&&y(d,"/view",t);let c=new Set(["card_data","requires"]),u=s.source_defs;return Array.isArray(u)&&u.forEach((r,p)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let n=r.projections;if(!(!n||typeof n!="object"||Array.isArray(n)))for(let[l,m]of Object.entries(n))typeof m!="string"||m.trim().length===0||b(m,`/source_defs/${p}/projections/${l}`,c,t);}),{ok:t.length===0,errors:t}}function V(e){return T(e)}function T(e){let t=O(e);if(!t.ok)return t;let s=R(e);return s.ok?{ok:true,errors:[]}:{ok:false,errors:s.errors}}
|
|
2
|
+
export{O as a,R as b,V as c,T as d};//# sourceMappingURL=chunk-YT76JNKE.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-YT76JNKE.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {u}from'./chunk-VGT3TRQG.js';import {a}from'./chunk-JMDHDY6M.js';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$1=Array.isArray(e)?e:e.nodes,o=new Map;for(let t of u$1){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$1=o.get(t);if(!a$1)return "task-initiate-failure";let w={};for(let R of a$1.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$1.source_defs&&a$1.source_defs.length>0){let R=L[t]??d,y=S?await S({card:a$1,input:g}):R?await R({card:a$1,input:g}):void 0;if(y&&typeof y=="object")for(let k of a$1.source_defs)Object.prototype.hasOwnProperty.call(y,k.bindTo)?p[k.bindTo]=y[k.bindTo]:a$1.source_defs.length===1&&(p[k.bindTo]=y);}let c={id:a$1.id,card_data:b(a$1.card_data??{}),requires:w,source_defs:a$1.source_defs,compute:a$1.compute};c._sourcesData=p,c.compute&&c.compute.length>0&&await a.run(c,{sourcesData:p});let T={};if(a$1.provides&&a$1.provides.length>0)for(let{bindTo:R,ref:y}of a$1.provides)T[R]=a.resolve(c,y);else T[a$1.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=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:_}}}export{F as a,H as b,P as c,$ as d,J as e};//# sourceMappingURL=chunk-4HIEOBJC.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {u}from'./chunk-VGT3TRQG.js';import {a}from'./chunk-ATOQP3BD.js';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$1=Array.isArray(e)?e:e.nodes,o=new Map;for(let t of u$1){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$1=o.get(t);if(!a$1)return "task-initiate-failure";let w={};for(let R of a$1.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$1.source_defs&&a$1.source_defs.length>0){let R=L[t]??d,y=S?await S({card:a$1,input:g}):R?await R({card:a$1,input:g}):void 0;if(y&&typeof y=="object")for(let k of a$1.source_defs)Object.prototype.hasOwnProperty.call(y,k.bindTo)?p[k.bindTo]=y[k.bindTo]:a$1.source_defs.length===1&&(p[k.bindTo]=y);}let c={id:a$1.id,card_data:b(a$1.card_data??{}),requires:w,source_defs:a$1.source_defs,compute:a$1.compute};c._sourcesData=p,c.compute&&c.compute.length>0&&await a.run(c,{sourcesData:p});let T={};if(a$1.provides&&a$1.provides.length>0)for(let{bindTo:R,ref:y}of a$1.provides)T[R]=a.resolve(c,y);else T[a$1.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=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:_}}}export{F as a,H as b,P as c,$ as d,J as e};//# sourceMappingURL=chunk-ZCU5O2LR.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-ZCU5O2LR.js.map
|
package/lib/cloud-storage.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var chunk6EJRZHFP_cjs=require('./chunk-6EJRZHFP.cjs'),
|
|
1
|
+
'use strict';var chunk6EJRZHFP_cjs=require('./chunk-6EJRZHFP.cjs'),chunkX5CZE2L7_cjs=require('./chunk-X5CZE2L7.cjs'),chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs');require('./chunk-VNLMJEIX.cjs'),require('./chunk-7JVHYHT2.cjs'),require('./chunk-VQCIOKJV.cjs'),require('./chunk-G4XXRHL2.cjs'),require('./chunk-LODXIALE.cjs'),require('./chunk-QBEQL4TL.cjs'),require('./chunk-QEHKMLHA.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-5XLFPPTY.cjs'),require('./chunk-2RIHC5TZ.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createAzureBlobStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.d}});Object.defineProperty(exports,"createAzureQueueStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.e}});Object.defineProperty(exports,"createCosmosAtomicRelayLock",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.c}});Object.defineProperty(exports,"createCosmosJournalStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.b}});Object.defineProperty(exports,"createCosmosKvStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.a}});Object.defineProperty(exports,"createAsyncBoardLiveCardsPublic",{enumerable:true,get:function(){return chunkX5CZE2L7_cjs.i}});Object.defineProperty(exports,"createAsyncCardStorageAdapter",{enumerable:true,get:function(){return chunkX5CZE2L7_cjs.c}});Object.defineProperty(exports,"createAsyncCardStore",{enumerable:true,get:function(){return chunkX5CZE2L7_cjs.d}});Object.defineProperty(exports,"createAsyncCardStorePublic",{enumerable:true,get:function(){return chunkX5CZE2L7_cjs.g}});Object.defineProperty(exports,"createAsyncJsonStorage",{enumerable:true,get:function(){return chunkX5CZE2L7_cjs.b}});Object.defineProperty(exports,"createAsyncQueueStoragePublic",{enumerable:true,get:function(){return chunkX5CZE2L7_cjs.h}});Object.defineProperty(exports,"createAsyncStateSnapshotAdapter",{enumerable:true,get:function(){return chunkX5CZE2L7_cjs.e}});Object.defineProperty(exports,"createAsyncStorageProvider",{enumerable:true,get:function(){return chunkX5CZE2L7_cjs.f}});Object.defineProperty(exports,"withAsyncRelayLock",{enumerable:true,get:function(){return chunkX5CZE2L7_cjs.a}});Object.defineProperty(exports,"createAsyncBoardConfigStore",{enumerable:true,get:function(){return chunkWRMOGPRG_cjs.b}});Object.defineProperty(exports,"createAsyncBoardWorkerStore",{enumerable:true,get:function(){return chunkWRMOGPRG_cjs.a}});Object.defineProperty(exports,"createHostedAsyncBoardPlatformAdapter",{enumerable:true,get:function(){return chunkWRMOGPRG_cjs.c}});//# sourceMappingURL=cloud-storage.cjs.map
|
|
2
2
|
//# sourceMappingURL=cloud-storage.cjs.map
|
package/lib/cloud-storage.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{d as createAzureBlobStorage,e as createAzureQueueStorage,c as createCosmosAtomicRelayLock,b as createCosmosJournalStorage,a as createCosmosKvStorage}from'./chunk-QLB6PKOT.js';export{i as createAsyncBoardLiveCardsPublic,c as createAsyncCardStorageAdapter,d as createAsyncCardStore,g as createAsyncCardStorePublic,b as createAsyncJsonStorage,h as createAsyncQueueStoragePublic,e as createAsyncStateSnapshotAdapter,f as createAsyncStorageProvider,a as withAsyncRelayLock}from'./chunk-
|
|
1
|
+
export{d as createAzureBlobStorage,e as createAzureQueueStorage,c as createCosmosAtomicRelayLock,b as createCosmosJournalStorage,a as createCosmosKvStorage}from'./chunk-QLB6PKOT.js';export{i as createAsyncBoardLiveCardsPublic,c as createAsyncCardStorageAdapter,d as createAsyncCardStore,g as createAsyncCardStorePublic,b as createAsyncJsonStorage,h as createAsyncQueueStoragePublic,e as createAsyncStateSnapshotAdapter,f as createAsyncStorageProvider,a as withAsyncRelayLock}from'./chunk-5U5NMYGT.js';export{b as createAsyncBoardConfigStore,a as createAsyncBoardWorkerStore,c as createHostedAsyncBoardPlatformAdapter}from'./chunk-6MD6FVE3.js';import'./chunk-H5FKNSCO.js';import'./chunk-ANKA7HEJ.js';import'./chunk-44L64VQ2.js';import'./chunk-VGT3TRQG.js';import'./chunk-WDPOGXTY.js';import'./chunk-ATOQP3BD.js';import'./chunk-YT76JNKE.js';import'./chunk-MNEOJWPS.js';import'./chunk-7QNEV5S3.js';import'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=cloud-storage.js.map
|
|
2
2
|
//# sourceMappingURL=cloud-storage.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkO65MSWUE_cjs=require('../chunk-O65MSWUE.cjs'),chunkG4XXRHL2_cjs=require('../chunk-G4XXRHL2.cjs');require('../chunk-LODXIALE.cjs'),require('../chunk-QBEQL4TL.cjs'),require('../chunk-QEHKMLHA.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createCallbackHandler",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.i}});Object.defineProperty(exports,"createFireAndForgetHandler",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.j}});Object.defineProperty(exports,"createNoopHandler",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.o}});Object.defineProperty(exports,"createProcessHandler",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.l}});Object.defineProperty(exports,"createScriptHandler",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.m}});Object.defineProperty(exports,"createShellHandler",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.k}});Object.defineProperty(exports,"createWebhookHandler",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.n}});Object.defineProperty(exports,"getDownstream",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.e}});Object.defineProperty(exports,"getUnreachableNodes",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.c}});Object.defineProperty(exports,"getUnreachableTokens",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.b}});Object.defineProperty(exports,"getUpstream",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.d}});Object.defineProperty(exports,"inspect",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.a}});Object.defineProperty(exports,"liveCardsToReactiveGraph",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.p}});Object.defineProperty(exports,"mutateGraph",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.h}});Object.defineProperty(exports,"validateLiveGraph",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.f}});Object.defineProperty(exports,"validateReactiveGraph",{enumerable:true,get:function(){return chunkO65MSWUE_cjs.g}});Object.defineProperty(exports,"MemoryJournal",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.s}});Object.defineProperty(exports,"addNode",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.d}});Object.defineProperty(exports,"addProvides",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.h}});Object.defineProperty(exports,"addRequires",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.f}});Object.defineProperty(exports,"applyEvent",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.b}});Object.defineProperty(exports,"applyEvents",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.c}});Object.defineProperty(exports,"computeDataHash",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.t}});Object.defineProperty(exports,"createLiveGraph",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.a}});Object.defineProperty(exports,"createReactiveGraph",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.u}});Object.defineProperty(exports,"disableNode",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.m}});Object.defineProperty(exports,"drainTokens",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.k}});Object.defineProperty(exports,"enableNode",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.n}});Object.defineProperty(exports,"getNode",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.o}});Object.defineProperty(exports,"injectTokens",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.j}});Object.defineProperty(exports,"removeNode",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.e}});Object.defineProperty(exports,"removeProvides",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.i}});Object.defineProperty(exports,"removeRequires",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.g}});Object.defineProperty(exports,"resetNode",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.l}});Object.defineProperty(exports,"restore",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.q}});Object.defineProperty(exports,"schedule",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.r}});Object.defineProperty(exports,"snapshot",{enumerable:true,get:function(){return chunkG4XXRHL2_cjs.p}});//# sourceMappingURL=index.cjs.map
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{i as createCallbackHandler,j as createFireAndForgetHandler,o as createNoopHandler,l as createProcessHandler,m as createScriptHandler,k as createShellHandler,n as createWebhookHandler,e as getDownstream,c as getUnreachableNodes,b as getUnreachableTokens,d as getUpstream,a as inspect,p as liveCardsToReactiveGraph,h as mutateGraph,f as validateLiveGraph,g as validateReactiveGraph}from'../chunk-
|
|
1
|
+
export{i as createCallbackHandler,j as createFireAndForgetHandler,o as createNoopHandler,l as createProcessHandler,m as createScriptHandler,k as createShellHandler,n as createWebhookHandler,e as getDownstream,c as getUnreachableNodes,b as getUnreachableTokens,d as getUpstream,a as inspect,p as liveCardsToReactiveGraph,h as mutateGraph,f as validateLiveGraph,g as validateReactiveGraph}from'../chunk-MEL5LKF7.js';export{s as MemoryJournal,d as addNode,h as addProvides,f as addRequires,b as applyEvent,c as applyEvents,t as computeDataHash,a as createLiveGraph,u as createReactiveGraph,m as disableNode,k as drainTokens,n as enableNode,o as getNode,j as injectTokens,e as removeNode,i as removeProvides,g as removeRequires,l as resetNode,q as restore,r as schedule,p as snapshot}from'../chunk-VGT3TRQG.js';import'../chunk-WDPOGXTY.js';import'../chunk-ATOQP3BD.js';import'../chunk-YT76JNKE.js';import'../chunk-MNEOJWPS.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';var chunkHFW7E2Z7_cjs=require('../chunk-HFW7E2Z7.cjs'),chunkMCPADH33_cjs=require('../chunk-MCPADH33.cjs');require('../chunk-6EJRZHFP.cjs'),require('../chunk-UIUCNV3X.cjs');var chunkWRMOGPRG_cjs=require('../chunk-WRMOGPRG.cjs');require('../chunk-RP2I3OLA.cjs'),require('../chunk-7JVHYHT2.cjs');var chunkVQCIOKJV_cjs=require('../chunk-VQCIOKJV.cjs');require('../chunk-G4XXRHL2.cjs'),require('../chunk-LODXIALE.cjs'),require('../chunk-IXZG74EW.cjs'),require('../chunk-HWYMZK3N.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-5XLFPPTY.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return chunkHFW7E2Z7_cjs.a(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return chunkVQCIOKJV_cjs.b(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return chunkVQCIOKJV_cjs.a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return chunkWRMOGPRG_cjs.c({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return chunkMCPADH33_cjs.b(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
|
|
1
|
+
'use strict';var chunkHFW7E2Z7_cjs=require('../chunk-HFW7E2Z7.cjs'),chunkMCPADH33_cjs=require('../chunk-MCPADH33.cjs');require('../chunk-6EJRZHFP.cjs'),require('../chunk-X5CZE2L7.cjs');var chunkWRMOGPRG_cjs=require('../chunk-WRMOGPRG.cjs');require('../chunk-VNLMJEIX.cjs'),require('../chunk-7JVHYHT2.cjs');var chunkVQCIOKJV_cjs=require('../chunk-VQCIOKJV.cjs');require('../chunk-G4XXRHL2.cjs'),require('../chunk-LODXIALE.cjs'),require('../chunk-QBEQL4TL.cjs'),require('../chunk-QEHKMLHA.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-5XLFPPTY.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return chunkHFW7E2Z7_cjs.a(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return chunkVQCIOKJV_cjs.b(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return chunkVQCIOKJV_cjs.a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return chunkWRMOGPRG_cjs.c({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return chunkMCPADH33_cjs.b(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
|
|
2
2
|
exports.createFirestoreArchiveFactory=P;exports.createFirestoreBlobStorage=w;exports.createFirestoreBoardAdapter=z;exports.createFirestoreBoardRefs=N;exports.createFirestoreBoardRuntimeBundle=Y;exports.createFirestoreJournalStorage=m;exports.createFirestoreKvStorage=A;exports.createFirestoreLock=J;exports.createFirestoreQueueStorage=W;exports.createFirestoreScratchStorage=O;exports.makeFirestoreRef=b;exports.serializeFirestoreRef=l;//# sourceMappingURL=index.cjs.map
|
|
3
3
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {a as a$1}from'../chunk-VS3BXEYK.js';import {b as b$1}from'../chunk-Y4WK7HE4.js';import'../chunk-QLB6PKOT.js';import'../chunk-TMS7KDKH.js';import {c as c$1}from'../chunk-6MD6FVE3.js';import'../chunk-VS4E7QFN.js';import'../chunk-ANKA7HEJ.js';import {a,b as b$2}from'../chunk-44L64VQ2.js';import'../chunk-VGT3TRQG.js';import'../chunk-WDPOGXTY.js';import'../chunk-JMDHDY6M.js';import'../chunk-3KC6LBOG.js';import'../chunk-MNEOJWPS.js';import'../chunk-7QNEV5S3.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return a$1(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return b$2(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return c$1({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return b$1(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
|
|
1
|
+
import {a as a$1}from'../chunk-VS3BXEYK.js';import {b as b$1}from'../chunk-Y4WK7HE4.js';import'../chunk-QLB6PKOT.js';import'../chunk-5U5NMYGT.js';import {c as c$1}from'../chunk-6MD6FVE3.js';import'../chunk-H5FKNSCO.js';import'../chunk-ANKA7HEJ.js';import {a,b as b$2}from'../chunk-44L64VQ2.js';import'../chunk-VGT3TRQG.js';import'../chunk-WDPOGXTY.js';import'../chunk-ATOQP3BD.js';import'../chunk-YT76JNKE.js';import'../chunk-MNEOJWPS.js';import'../chunk-7QNEV5S3.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return a$1(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return b$2(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return c$1({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return b$1(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
|
|
2
2
|
export{P as createFirestoreArchiveFactory,w as createFirestoreBlobStorage,z as createFirestoreBoardAdapter,N as createFirestoreBoardRefs,Y as createFirestoreBoardRuntimeBundle,m as createFirestoreJournalStorage,A as createFirestoreKvStorage,J as createFirestoreLock,W as createFirestoreQueueStorage,O as createFirestoreScratchStorage,b as makeFirestoreRef,l as serializeFirestoreRef};//# sourceMappingURL=index.js.map
|
|
3
3
|
//# sourceMappingURL=index.js.map
|