yaml-flow 8.7.1 → 8.8.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/adapters/firebase-storage.js +2 -2
- package/browser/adapters/firestore-storage.js +2 -2
- package/browser/adapters/localstorage-storage.js +3 -3
- package/browser/asset-integrity.json +9 -13
- package/browser/server-runtime-controlface.js +5 -5
- package/examples/ARCHITECTURE.md +0 -27
- package/examples/board/server/board-server.js +150 -100
- package/examples/board/server/board-worker/source_def_flows.json +0 -8
- package/examples/board/server/board-worker/task-executor.js +1 -3
- package/examples/board/test/server-http-test.js +108 -73
- package/examples/board-firestore/server/worker.js +8 -0
- package/examples/portfolio-tracker/portfolio-tracker.js +11 -1
- package/examples/portfolio-tracker/test/portfolio-t4.js +12 -2
- package/lib/{artifacts-store-lib-D9nMkVcE.d.cts → artifacts-store-lib-C6qBpMfU.d.cts} +1 -1
- package/lib/{artifacts-store-lib-DSSMqVL2.d.ts → artifacts-store-lib-D4qf7Q-7.d.ts} +1 -1
- package/lib/artifacts-store-public.d.cts +3 -3
- package/lib/artifacts-store-public.d.ts +3 -3
- package/lib/board-live-cards-mcp.cjs +1 -1
- package/lib/board-live-cards-mcp.d.cts +6 -7
- package/lib/board-live-cards-mcp.d.ts +6 -7
- package/lib/board-live-cards-mcp.js +1 -1
- package/lib/board-live-cards-node.cjs +8 -8
- package/lib/board-live-cards-node.d.cts +15 -14
- package/lib/board-live-cards-node.d.ts +15 -14
- package/lib/board-live-cards-node.js +8 -8
- package/lib/{board-live-cards-public-LlVUQPL2.d.cts → board-live-cards-public-BT5HrgqZ.d.cts} +82 -59
- package/lib/{board-live-cards-public-JNRKfBZy.d.ts → board-live-cards-public-DSRamFm8.d.ts} +82 -59
- package/lib/{board-live-cards-public-async-Di9QB141.d.cts → board-live-cards-public-async-CYjr4mgX.d.cts} +18 -8
- package/lib/{board-live-cards-public-async-fwd1QI82.d.ts → board-live-cards-public-async-DlyC3PgC.d.ts} +18 -8
- package/lib/board-live-cards-public.cjs +1 -1
- package/lib/board-live-cards-public.d.cts +2 -2
- package/lib/board-live-cards-public.d.ts +2 -2
- 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.d.cts +6 -8
- package/lib/board-live-cards-server-runtime.d.ts +6 -8
- package/lib/board-live-cards-server-runtime.js +1 -1
- package/lib/{board-platform-adapter-async-BfHmHdx2.d.cts → board-platform-adapter-async-BZIftm36.d.cts} +18 -14
- package/lib/{board-platform-adapter-async-DYahVzIK.d.ts → board-platform-adapter-async-JP9V-U5E.d.ts} +18 -14
- package/lib/board-worker-adapter.cjs +1 -24
- package/lib/board-worker-adapter.d.cts +68 -3
- package/lib/board-worker-adapter.d.ts +68 -3
- package/lib/board-worker-adapter.js +1 -24
- package/lib/card-store-public.d.cts +2 -2
- package/lib/card-store-public.d.ts +2 -2
- package/lib/chat-store-public.cjs +1 -1
- package/lib/chat-store-public.d.cts +20 -20
- package/lib/chat-store-public.d.ts +20 -20
- package/lib/chat-store-public.js +1 -1
- package/lib/chunk-2GSI6C45.js +7 -0
- package/lib/chunk-35N7ONTH.js +2 -0
- package/lib/chunk-37HDEW26.cjs +2 -0
- package/lib/{chunk-PMUSJQSR.cjs → chunk-3CZCGNY4.cjs} +2 -2
- package/lib/{chunk-BQS3EIEK.js → chunk-44L64VQ2.js} +3 -3
- package/lib/chunk-6OPXQPSC.js +2 -0
- package/lib/chunk-7BTZCOT5.js +2 -0
- package/lib/{chunk-U2N6MCD5.cjs → chunk-7JVHYHT2.cjs} +2 -2
- package/lib/chunk-7QZ267XP.cjs +2 -0
- package/lib/{chunk-XQRNDX4Q.js → chunk-ANKA7HEJ.js} +2 -2
- package/lib/{chunk-KAWQPLIE.cjs → chunk-BQUQTOPB.cjs} +2 -2
- package/lib/chunk-CMFD27ZC.cjs +3 -0
- package/lib/chunk-DOFNXJ4C.js +3 -0
- package/lib/chunk-ETW3BXHD.cjs +2 -0
- package/lib/{chunk-SGV7PU4H.js → chunk-FOFGEABN.js} +2 -2
- package/lib/chunk-GPCMBPLK.cjs +2 -0
- package/lib/chunk-GU3T75C4.js +3 -0
- package/lib/chunk-H3EHFCDZ.js +3 -0
- package/lib/chunk-H4TYOSMD.cjs +45 -0
- package/lib/chunk-HFW7E2Z7.cjs +4 -0
- package/lib/chunk-IQIZA7TN.cjs +7 -0
- package/lib/chunk-J4MHQ7JF.js +45 -0
- package/lib/chunk-MCPADH33.cjs +2 -0
- package/lib/chunk-NBJTYAYN.cjs +2 -0
- package/lib/chunk-NDAKMJQK.cjs +3 -0
- package/lib/chunk-NNSBBO5R.js +2 -0
- package/lib/chunk-NU5NO5NM.js +2 -0
- package/lib/chunk-O4RKTQBP.cjs +3 -0
- package/lib/chunk-O5UYCGIN.js +2 -0
- package/lib/chunk-Q3OTUDIE.js +2 -0
- package/lib/chunk-R44X3RQB.cjs +2 -0
- package/lib/chunk-RKKSVOP2.js +2 -0
- package/lib/chunk-UB54HZA4.cjs +2 -0
- package/lib/{chunk-CIAJNUR4.js → chunk-VGDLSS2H.js} +2 -2
- package/lib/{chunk-SFVO2LB2.cjs → chunk-VQCIOKJV.cjs} +3 -3
- package/lib/chunk-VS3BXEYK.js +4 -0
- package/lib/chunk-Y4WK7HE4.js +2 -0
- package/lib/chunk-ZK3E7L4Y.cjs +2 -0
- package/lib/cloud-storage.cjs +1 -1
- package/lib/cloud-storage.d.cts +6 -6
- package/lib/cloud-storage.d.ts +6 -6
- package/lib/cloud-storage.js +1 -1
- package/lib/execution-refs.cjs +1 -1
- package/lib/execution-refs.js +1 -1
- package/lib/firebase-storage/index.cjs +2 -2
- package/lib/firebase-storage/index.d.cts +2 -2
- package/lib/firebase-storage/index.d.ts +2 -2
- package/lib/firebase-storage/index.js +2 -2
- package/lib/firestore-storage/index.cjs +2 -2
- package/lib/firestore-storage/index.d.cts +12 -10
- package/lib/firestore-storage/index.d.ts +12 -10
- package/lib/firestore-storage/index.js +2 -2
- package/lib/index.d.cts +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/localstorage-storage/index.cjs +1 -1
- package/lib/localstorage-storage/index.d.cts +10 -6
- package/lib/localstorage-storage/index.d.ts +10 -6
- package/lib/localstorage-storage/index.js +1 -1
- package/lib/{mcp-tool-registries-W3TRj6O5.d.cts → mcp-tool-registries-CRtea2x4.d.cts} +3 -0
- package/lib/{mcp-tool-registries-BBObLYga.d.ts → mcp-tool-registries-D3rWSppt.d.ts} +3 -0
- package/lib/server-jobs-queue-runner/index.cjs +1 -1
- package/lib/server-jobs-queue-runner/index.d.cts +12 -9
- package/lib/server-jobs-queue-runner/index.d.ts +12 -9
- package/lib/server-jobs-queue-runner/index.js +1 -1
- package/lib/server-runtime/index.cjs +1 -1
- package/lib/server-runtime/index.d.cts +7 -9
- package/lib/server-runtime/index.d.ts +7 -9
- package/lib/server-runtime/index.js +1 -1
- package/lib/server-runtime-agentface/index.d.cts +7 -9
- package/lib/server-runtime-agentface/index.d.ts +7 -9
- package/lib/server-runtime-controlface/index.cjs +1 -1
- package/lib/server-runtime-controlface/index.d.cts +8 -9
- package/lib/server-runtime-controlface/index.d.ts +8 -9
- package/lib/server-runtime-controlface/index.js +1 -1
- package/lib/server-runtime-core/index.cjs +1 -1
- package/lib/server-runtime-core/index.d.cts +59 -21
- package/lib/server-runtime-core/index.d.ts +59 -21
- package/lib/server-runtime-core/index.js +1 -1
- package/lib/server-runtime-watchers/index.cjs +1 -1
- package/lib/server-runtime-watchers/index.d.cts +9 -65
- package/lib/server-runtime-watchers/index.d.ts +9 -65
- package/lib/server-runtime-watchers/index.js +1 -1
- package/lib/server-runtime-webhooks/index.d.cts +7 -9
- package/lib/server-runtime-webhooks/index.d.ts +7 -9
- package/lib/sse-hub-CYXisfXJ.d.cts +63 -0
- package/lib/sse-hub-Dodwtc3_.d.ts +63 -0
- package/lib/step-machine-public/index.cjs +1 -1
- package/lib/step-machine-public/index.d.cts +1 -1
- package/lib/step-machine-public/index.d.ts +1 -1
- package/lib/step-machine-public/index.js +1 -1
- package/lib/{storage-async-interface-BRR4eBjx.d.cts → storage-async-interface-CG0bMqvE.d.ts} +20 -1
- package/lib/{storage-async-interface-DhlOVPSp.d.ts → storage-async-interface-CyO-zwVQ.d.cts} +20 -1
- package/lib/{storage-interface-BFiD3kyB.d.ts → storage-interface-D-iEiTJA.d.cts} +45 -1
- package/lib/{storage-interface-BFiD3kyB.d.cts → storage-interface-D-iEiTJA.d.ts} +45 -1
- package/lib/stores/index.d.cts +1 -1
- package/lib/stores/index.d.ts +1 -1
- package/lib/stores/kv.d.cts +1 -1
- package/lib/stores/kv.d.ts +1 -1
- package/lib/{types-SO5OZm4s.d.ts → types-BtH3scgE.d.ts} +64 -29
- package/lib/{types-Ba8H5_Wo.d.cts → types-Ch0u3FKP.d.cts} +64 -29
- package/package.json +4 -5
- package/browser/board-livecards-client.js +0 -2
- package/examples/board/demo-shell-with-server.html +0 -272
- package/examples/board/doc.html +0 -465
- package/examples/board/server-config.json +0 -24
- package/lib/chat-storage-lib-B9Q34Dyv.d.cts +0 -54
- package/lib/chat-storage-lib-DB9iSai2.d.ts +0 -54
- package/lib/chunk-5XHOHTLZ.cjs +0 -2
- package/lib/chunk-6APH25VI.js +0 -2
- package/lib/chunk-76C7N4YT.js +0 -3
- package/lib/chunk-76ON3V7R.js +0 -2
- package/lib/chunk-7ICPAABP.cjs +0 -7
- package/lib/chunk-ASR44K7H.cjs +0 -3
- package/lib/chunk-CPAXTVBQ.cjs +0 -2
- package/lib/chunk-EGRHWZRV.js +0 -2
- package/lib/chunk-EZENHAVZ.cjs +0 -2
- package/lib/chunk-GL2OHR2E.cjs +0 -2
- package/lib/chunk-GYQXDNNI.cjs +0 -2
- package/lib/chunk-IPLSRN6P.cjs +0 -4
- package/lib/chunk-J6EGN6S4.cjs +0 -3
- package/lib/chunk-JH37NJGP.js +0 -3
- package/lib/chunk-JJL5VOQZ.cjs +0 -3
- package/lib/chunk-NJJ7WEDT.cjs +0 -2
- package/lib/chunk-NKIQRCOM.cjs +0 -2
- package/lib/chunk-PBOQ4HYB.cjs +0 -2
- package/lib/chunk-PRKRXAVN.js +0 -3
- package/lib/chunk-QJVR3FWQ.js +0 -2
- package/lib/chunk-S44QZUDX.js +0 -2
- package/lib/chunk-TSN3RTXT.js +0 -4
- package/lib/chunk-VXJHBWK3.js +0 -2
- package/lib/chunk-WHDEBJLT.js +0 -7
- package/lib/chunk-YGALANRO.js +0 -2
- package/lib/chunk-ZCNN6XPV.js +0 -2
package/lib/chunk-76C7N4YT.js
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import {n,h,i,j,a as a$6,b as b$3,k,l as l$1,c as c$3,m}from'./chunk-QJVR3FWQ.js';import {a as a$2}from'./chunk-NTICU4OK.js';import {a as a$1,b as b$1}from'./chunk-WHDEBJLT.js';import {a as a$4,d as d$1,b as b$4,c as c$2}from'./chunk-SGV7PU4H.js';import {a as a$3}from'./chunk-XYN5D3GL.js';import {a as a$7,b as b$5}from'./chunk-ZJ5M5COT.js';import {b,c as c$1,e}from'./chunk-6APH25VI.js';import {j as j$1,d,c,b as b$2}from'./chunk-PRKRXAVN.js';import {y,z,l}from'./chunk-JH37NJGP.js';import {a as a$5}from'./chunk-KBELAKIY.js';import {a}from'./chunk-76ON3V7R.js';function Zt(R){let{apiBasePath:k,json:v,readJsonBody:K,initBoardAndSetup:H,bootstrapBoard:I,buildPublishedRuntimePayload:W,createMcpControlplaneToolRegistry:U,retriggerCard:L,applyCardAction:G,resolveChatHandlerTarget:V,sendCardFileDownloadResponse:_}=R;async function X(Q,x,rt){let c=Q.method||"GET",p=rt,h=p.pathname;try{if(c==="GET"&&h===`${k}/init-board`)return await H(),v(x,200,await W()),!0;if(c==="POST"&&h===`${k}/mcp-controlplane`){await I();let w=await K(Q),b=typeof w.tool=="string"?w.tool.trim():"",S=w.args&&typeof w.args=="object"&&!Array.isArray(w.args)?w.args:{};if(!b)return v(x,400,{error:"tool is required"}),!0;try{let g=await a$7(b,S,U());if(g&&typeof g=="object"&&!Array.isArray(g)){let $=g;if($.status==="fail")return v(x,400,{error:b$5(g,"Request failed")}),!0;if($.status==="error")return v(x,500,{error:b$5(g,"Internal error")}),!0}v(x,200,g);}catch(g){let $=typeof g?.statusCode=="number"?Number(g.statusCode):500,N=g instanceof Error?g.message:String(g);v(x,$,{error:N});}return !0}let d=h.match(new RegExp(`^${c$2(k)}/cards/([^/]+)/retrigger$`));if(c==="POST"&&d){await I();let w=decodeURIComponent(d[1]);return await L(w),v(x,200,{ok:!0}),!0}let O=h.match(new RegExp(`^${c$2(k)}/cards/([^/]+)/actions$`));if(c==="POST"&&O){await I();let w=decodeURIComponent(O[1]),b=Date.now(),S=new Date(b).toISOString(),g=await K(Q),$=g?.actionType;if($==="chat-send"&&!await V(w)){let C=Date.now();return v(x,409,{error:`chat handler is not configured for card: ${w}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(C).toISOString(),responseSentAtMs:C,responseStatus:409}),!0}if($==="chat-send"){let C=g?.payload??{},J=typeof C["turn-id"]=="string"?C["turn-id"]:typeof C.turnId=="string"?C.turnId:typeof C.turn=="string"?C.turn:"";if(!J||!String(J).trim()){let q=Date.now();return v(x,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${w}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(q).toISOString(),responseSentAtMs:q,responseStatus:400}),!0}}await G(w,$,g?.payload);let N=Date.now();return v(x,200,{ok:!0,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(N).toISOString(),responseSentAtMs:N,responseStatus:200}),!0}let E=h.match(new RegExp(`^${c$2(k)}/cards/([^/]+)/files/(\\d+)$`));if(c==="GET"&&E){let w=decodeURIComponent(E[1]),b=parseInt(E[2],10),S=p.searchParams.get("sn");return await _(x,w,b,S),!0}return !1}catch(d){let O=d?.statusCode||500;return v(x,O,{error:String(d?.message||d)}),true}}return {handleRuntimeApi:X}}var Yt={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},Xt="chat-handler-flow-queue";function nr(R){let k$1=String(R.apiBasePath||"/api/board").replace(/\/$/,""),v={...Yt,...R.corsHeaders||{}},K=R.queueLaneTuning??{},H=R.boardId||"",I=R.logger||{info:console.log,warn:console.warn,error:console.error},W=R.invocationAdapter,U=R.chatFlowRunner||null,L=R.chatStorage??b(),G=a(L),V=R.notificationTransport||null,_=R.serverUrl||null,X=R.executionExtra||{},Q=R.onSseClientConnected,x=R.onSseClientDisconnected,rt=R.onChannelSubscribed,c$2=R.onChannelUnsubscribed,p=a$1({chatStorage:L,readChatRecords:t=>yt(t),onSseClientDisconnected:x});function h$1(t){function e(a){if(Array.isArray(a))return a;if(a&&typeof a=="object"){let s=a;return Array.isArray(s.files)?s.files:[a]}return null}function r(a){return {async get(s){return a.get(s)},async set(s){return a.set(s)},async del(s){return a.del(s)},async patch(s){return a.patch(s)},async appendFiles(s){return a.appendFiles(s)}}}function o(a){function s(m){return {status:"success",data:m}}function l(m){return {status:"fail",error:m}}function u(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}return {async get(m){try{let f=m.params?.id;if(f){let T=await a.readCard(f);return T?s({cards:[T]}):l(`card "${f}" not found`)}return s({cards:await a.readAllCards()})}catch(f){return u(f)}},async set(m){try{let f=m.body;if(f==null)return l("set requires a body (card object or array of cards)");let T=Array.isArray(f)?f:[f];for(let j of T){if(typeof j.id!="string")return l("each card must have a string `id` field");await a.writeCard(j.id,j);}return s({count:T.length})}catch(f){return u(f)}},async del(m){try{let f=m.body?.ids??[],T=m.params?.id,j=T?[...f,T]:f;if(j.length===0)return l("del requires body.ids (string[]) or params.id");for(let tt of j)await a.removeCard(tt);return s({count:j.length})}catch(f){return u(f)}},async patch(m){try{let f=m.params?.id,T=m.params?.path;if(!f)return l("patch requires params.id");if(!T)return l("patch requires params.path");let j=m.body,tt=j&&Object.prototype.hasOwnProperty.call(j,"value")?j.value:m.body;return await a.patchCard(f,T,tt),s({count:1})}catch(f){return u(f)}},async appendFiles(m){try{let f=m.params?.id;if(!f)return l("appendFiles requires params.id");let T=await a.readCard(f);if(!T)return l(`card "${f}" not found`);let j=e(m.body);if(!j||j.length===0)return l("appendFiles requires a file metadata object, array, or body.files array");let tt=T.card_data&&typeof T.card_data=="object"&&!Array.isArray(T.card_data)?T.card_data:{},At=Array.isArray(tt.files)?tt.files:[],ve=[...At,...j];return await a.patchCard(f,"card_data.files",ve),s({files_added:j.map((Oe,Pe)=>({idx:At.length+Pe,entry:Oe}))})}catch(f){return u(f)}}}}let n=a$4(t.boardAdapter)?j$1(t.baseRef,t.boardAdapter):y(t.baseRef,t.boardAdapter),i=t.nonCoreAdapter??(!a$4(t.boardAdapter)&&w(t.boardAdapter)?t.boardAdapter:null),y$1=t.nonCore??(i?z(t.baseRef,i):null),P,A=a$4(t.boardAdapter)?(()=>{let a=d(c(b$2(t.boardAdapter.kvStorageForRef(t.cardStoreRef)),t.boardAdapter.hashFn),I.warn),s=o(a);return P={get(l){return s.get(l)},set(l){return s.set(l)}},s})():(()=>{let a=t.boardAdapter.kvStorageForRef(t.cardStoreRef),l$1=a$5(l({readIndex:()=>a.read("_index"),writeIndex:u=>a.write("_index",u),readCard:u=>a.read(u),writeCard:(u,m)=>(a.write(u,m),u),removeCard:u=>{a.delete(u);},cardExists:u=>a.read(u)!==null,defaultCardKey:u=>u},I.warn));return P=l$1,r(l$1)})(),F=t.artifactsAdapter||t.boardAdapter,B=t.filesArtifactsStore??null,M=B?{putBytes(a,s,l){B.putBytes(a,s,l);},getBytes(a){return B.getBytes(a)},listKeys(a){return B.list(a).map(s=>s.key)}}:null;if(!M&&!a$4(F)){let a=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files"),s=c$1(a);M={putBytes(l,u,m){s.putBytes(l,u,m);},getBytes(l){return s.getBytes(l)},listKeys(l){return s.list(l).map(u=>u.key)}};}else if(!M&&a$4(F)){let a=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files");M={async putBytes(s,l){if(a.writeBytes){await a.writeBytes(s,l);return}let u=JSON.stringify({__kind:"bytes-array",data:[...l]});await a.write(s,u);},async getBytes(s){if(a.readBytes){let u=await a.readBytes(s);if(u!==null)return u}let l=await a.read(s);if(l===null)return null;try{let u=JSON.parse(l);if(u&&u.__kind==="bytes-array"&&Array.isArray(u.data))return new Uint8Array(u.data)}catch{}return new TextEncoder().encode(l)},async listKeys(s){return await a.listKeys(s)}};}let D={async init(a){return n.init(a)},async status(a){return n.status(a)},async getConfig(a){return n.getConfig(a)},async getAllOutputsDataObjects(a){return n.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return n.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return n.getOutputsFetchedSources(a)},async upsertCard(a){return n.upsertCard(a)},async removeCard(a){return n.removeCard(a)},async cardRefreshedNotify(a){return n.cardRefreshedNotify(a)},async sourceDataFetched(a){return n.sourceDataFetched(a)},async sourceDataFetchFailure(a){return n.sourceDataFetchFailure(a)}};return {label:t.label,board:n,nonCore:y$1,publicCardStore:P,boardOps:D,cardStoreOps:A,get filesArtifacts(){return M},boardAdapter:t.boardAdapter,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,archiveStoreRef:t.archiveStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:a$6(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let d$2=R.boards.map(h$1),O=new Map;function E(t){return O.get(t)??0}function w(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function b$5(t){let e=d$2[E(t)];return {files:e?e.filesArtifacts:null}}function S(){return e()}function g(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function $(t){if(!t||t.notificationTeardown||!V||!t.notifyRef)return;let e=await V.subscribe(t.notifyRef,r=>{c$3(t.notification,r);let o=r.kind==="notification-batch"?r.notifications:[r];p.broadcastNotificationBatch(o);});t.notificationTeardown=e;}async function N(t){if(!t||t.initialized)return;let e={cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef};t.artifactsStoreRef&&(e.artifactsStoreRef=t.artifactsStoreRef),t.chatStoreRef&&(e.chatStoreRef=t.chatStoreRef),t.scratchStoreRef&&(e.scratchStoreRef=t.scratchStoreRef),t.archiveStoreRef&&(e.archiveStoreRef=t.archiveStoreRef);let r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow),t.inferenceAdapterRef&&(r["inference-adapter-ref"]=t.inferenceAdapterRef);let o=await t.boardOps.init({params:e,body:r});if(o.status!=="success")throw Object.assign(new Error(o.error||`init failed for ${t.label}`),{statusCode:500});if(await $(t),!t.chatHandlerFlow&&t.chatHandlerRef&&W.describe)try{let n=await W.describe(t.chatHandlerRef);n&&n.kind!=="chat-handler"?I.warn(`[init] chat-handler describe returned kind="${n.kind}", expected "chat-handler" for ${t.label}`):n&&I.info(`[init] chat-handler validated: ${n.name} (protocol ${n.protocolVersion}) for ${t.label}`);}catch(n){I.warn(`[init] chat-handler describe failed for ${t.label}: ${n?.message||String(n)}`);}t.initialized=true;}async function C(t){if(!t.boardAdapter.publishBoardChangeNotifications)return;let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&b$3(r.data)&&e.push({kind:"status",status:r.data});let o=await t.boardOps.getAllOutputsDataObjects({});if(o.status==="success"&&o.data!=null)for(let[i,y]of Object.entries(o.data))i&&e.push({kind:"data_object",key:i,payload:y});let n=await t.boardOps.getAllOutputsComputedValues({});if(n.status==="success"&&n.data!=null)for(let[i,y]of Object.entries(n.data))i&&e.push({kind:"computed_values",cardId:i,values:y});e.length>0&&t.boardAdapter.publishBoardChangeNotifications(e);}async function J(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),o=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let n of o)typeof n.id=="string"&&(O.set(n.id,e),await t.boardOps.upsertCard({params:{cardId:n.id}}));t.cardsBootstrapped=true;}async function q(){for(let t of d$2)await N(t);}async function it(){await q();for(let t=0;t<d$2.length;t++)await C(d$2[t]),await J(d$2[t],t),await C(d$2[t]);}async function ct(t=false){t||await q();for(let e of d$2){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}async function te(){return await q(),ct(true)}function Y(t){return d$2[E(t)]??null}async function nt(t){let e=Y(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let o=Array.isArray(r.data?.cards)?r.data.cards:[];return o.length>0?o[0]:null}async function ft(){let t=async r=>{if(!r)return [];let o=await r.cardStoreOps.get({});return o.status!=="success"||!Array.isArray(o.data?.cards)?[]:o.data.cards},e=[];for(let r of d$2)e.push(...await t(r));return e}function ee(){return d$2[0]??null}let pt=n({boardContexts:d$2,cardOwnerIndex:O,cardContextForCard:t=>Y(t),readStatusSnapshot:()=>ie(),readDataObjectsByToken:()=>de(),readCardRuntimeArtifacts:()=>ce(),readCardFromStore:t=>nt(t),readCardDefinitions:()=>ft(),processAccumulatedLaneInternal:t=>ct(t),reportSourceFetched:(t,e)=>bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Ct(t,{reason:e}),uploadCardFile:(t,e,r,o,n)=>Rt(t,e,r,o,n),chatStorePublic:G,serverUrl:_,apiBasePath:k$1}),re=pt.mcpCardStoreFacade,z$1=pt.createMcpFacade,ne=h({boardId:H,getMcpFacade:()=>z$1(),getMcpCardStoreFacade:()=>re()});function ae(t){return k(t)}function oe(){return l$1(z$1())}function se(){return m({boardId:H,uploadCardFile:Rt,getMcpFacade:()=>z$1(),controlplane:ne})}let at=i({boardId:H,boardContexts:d$2,readCardDefinitions:()=>ft(),readChatRecords:t=>yt(t),getChatProcessing:t=>z$1().getChatProcessing({cardId:t}).active}),ie=at.readStatusSnapshot,ce=at.readCardRuntimeArtifacts,de=at.readDataObjectsByToken,dt=at.buildPublishedRuntimePayload;async function mt(t,e,r){let o=r?.syncBoard!==false,n=r?.restartOnlyIfChanged===true,i=Y(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let y=await nt(t);if(!y)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let P=n?JSON.stringify(y):null,A=e(y)||y;if(n&&JSON.stringify(A)===P)return;let F=await i.cardStoreOps.set({body:A});if(F.status!=="success")throw Object.assign(new Error(F.error||`Failed to persist card: ${t}`),{statusCode:500});if(o){let B=await i.boardOps.upsertCard({params:{cardId:t,restart:true}});if(B.status!=="success")throw Object.assign(new Error(B.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function ue(t,e){await mt(t,e,{syncBoard:true});}async function gt(t,e){await mt(t,e,{syncBoard:false});}async function le(t){let e=Y(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await nt(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let o=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(o.status!=="success")throw Object.assign(new Error(o.error||`Failed to retrigger card: ${t}`),{statusCode:500})}function fe(t){L.clear(t);try{z$1().setChatProcessing({cardId:t,active:!1});}catch{}}function pe(t,e,r,o,n=""){let i=typeof r=="string"?r.trim():"";return L.append(t,e||"system",i,o,n)}function yt(t){return L.readAll(t)}let Rt=j({safeCardId:t=>g(t),artifactsStores:t=>b$5(t),cardFileMetadataStore:()=>S(),readCardFromStore:t=>nt(t),updateCardLocalOnly:(t,e)=>gt(t,e),writeChatRecord:(t,e,r,o,n)=>pe(t,e,r,o,n)}).uploadCardFile;async function ht(t){let e=Y(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=r.status==="success"?r.data?.value:null,n=e.chatHandlerRef;return o==null&&(!n||typeof n!="object")?null:{ctx:e,handlerFlow:o,handlerRef:n}}async function me(t,e,r=false,o=""){let n=await ht(t);if(!n)return;let{ctx:i,handlerFlow:y,handlerRef:P}=n;if(!r)try{z$1().setChatProcessing({cardId:t,active:!0});}catch{}let A={boardId:H,cardId:String(t),lastChatEntryId:e,...o?{turnId:o}:{},...X,..._?{serverUrl:_}:{}},F=y!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:Xt}}:P;try{a$4(i.boardAdapter)?await i.boardAdapter.chatAgentStore().enqueueRequest({boardId:H,ref:F,args:y!=null?{...A,__chatHandlerFlow:y}:A}):i.boardAdapter.chatAgentStore().enqueueRequest({boardId:H,ref:F,args:y!=null?{...A,__chatHandlerFlow:y}:A}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(B){try{z$1().setChatProcessing({cardId:t,active:!1});}catch{}I.warn(`[chat-handler] queue failed for card "${t}": ${B instanceof Error?B.message:String(B)}`);}}async function ge(t,e,r){if(e.howToRun==="built-in"&&b$4(e)===Xt){let o=U,n=r.__chatHandlerFlow,i={...r};return delete i.__chatHandlerFlow,o?o.run(n,i,{boardId:H,cardId:String(i.cardId||""),label:t.label,logger:I,serverUrl:_,executionExtra:X}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return W.invoke(e,r)}async function ye(t,e=false){e||await q();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",o=r?Y(r):ee();if(!o)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let n=await ge(o,t.ref,t.args);if(!n.dispatched){if(r)try{L.setProcessing(r,!1);}catch{}throw new Error(n.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Re(t,e,r){let o=e==="chat-send"?gt:ue,n;await o(t,i=>{let y=new Date().toISOString(),P=i.card_data&&typeof i.card_data=="object"?i.card_data:{};if(i.card_data=P,e==="chat-send"){let A=r&&typeof r.text=="string"?r.text.trim():"",F=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"",B=[];if(Array.isArray(r?.files)){for(let M of r.files)if(M){if(typeof M=="string"){B.push({name:M});continue}if(typeof M=="object"){let D=M;typeof D.name=="string"&&B.push({name:D.name,size:D.size,mime_type:D.mime_type,uploaded_at:D.uploaded_at,stored_name:D.stored_name,chat:D.chat===true});}}}if(A||B.length>0){let M=G.runBatch({cardId:t,commands:[{command:"append",role:"user",text:A,files:B,turn:F},{command:"set-processing",active:true}]});if(M.status!=="success")throw new Error(M.error);let D=M.data.results[0]?.data?.id;if(typeof D!="string"||!D)throw new Error(`chat-send did not return an append id for card ${t}`);n={cardId:t,lastEntryId:D,processingAlreadySet:true,turnId:F};try{p.broadcastCardChats(t);}catch{}}return i}if(e==="file-upload"){let A=S().normalizeIncoming(r?.files,y);return A.length>0&&S().merge(P,A),i}if(e==="action"){let A=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!A)return i;P.lastAction={buttonId:A,at:y},P.lastActionText=`${A} @ ${y}`;}return i}),n&&me(n.cardId,n.lastEntryId,n.processingAlreadySet,n.turnId??"");}function ot(t,e,r){let o=JSON.stringify(r),n=typeof Buffer<"u"?Buffer.byteLength(o):new TextEncoder().encode(o).length;t.writeHead(e,{...v,"Content-Type":"application/json; charset=utf-8","Content-Length":n}),t.end(o);}async function wt(t,e,r){let o=await nt(t);if(!o)throw Object.assign(new Error("Card not found"),{statusCode:404});let n=S().resolve(o.card_data,e,r);if(!n.ok&&n.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!n.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let i=n.file,y=g(t),P=b$5(t),A=String(i.stored_name||""),F=`${y}/${A}`,B=P.files?await P.files.getBytes(F):null;if(!B)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:i,bytes:B}}async function he(t,e,r,o){let{fileRecord:n,bytes:i}=await wt(e,r,o),y=String(n.name||n.stored_name||"download.bin"),P=String(n.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":P,"Content-Disposition":`attachment; filename="${y}"`,"Content-Length":i.length}),t.end(i);}function we(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 be(t,e,r){let o=t.split(/\r?\n/);return (e==="head"?o.slice(0,r):o.slice(-r)).join(`
|
|
2
|
-
`)}async function st(t){let e=[];for await(let o of t)e.push(o);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(d$1(e)).trim();return r?JSON.parse(r):{}}async function bt(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 o=d$2[0];return o?o.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Ct(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",o=d$2[0];return o?o.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let Ce=b$1({sseHub:p,corsHeaders:v,json:ot,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:Q,onChannelSubscribed:rt,onChannelUnsubscribed:c$2,apiBasePath:k$1,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),bootstrapBoard:()=>it(),boardContexts:d$2,publishPersistedStateSnapshot:t=>C(t),upsertCardsFromSource:(t,e)=>J(t,e)}).handleWatchersRoutes,Ae=a$2({apiBasePath:k$1,json:ot,readJsonBody:t=>st(t),bootstrapBoard:()=>it(),createMcpFacade:()=>z$1(),createMcpToolRegistry:t=>ae(t),resolveCardFileDownloadPayload:(t,e,r)=>wt(t,e,r),isLikelyTextMimeType:t=>we(t),sliceTextByLines:(t,e,r)=>be(t,e,r)}).handleAgentfaceApi,Se=a$3({apiBasePath:k$1,json:ot,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),createMcpWebhookToolRegistry:()=>oe()}).handleWebhooksApi,Be=Zt({apiBasePath:k$1,json:ot,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),bootstrapBoard:()=>it(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>se(),retriggerCard:t=>le(t),applyCardAction:(t,e,r)=>Re(t,e,r),resolveChatHandlerTarget:t=>ht(t),sendCardFileDownloadResponse:(t,e,r,o)=>he(t,e,r,o)}).handleRuntimeApi;async function ke(t,e,r){return !!(await Ae(t,e,r)||await Se(t,e,r)||await Ce(t,e,r)||await Be(t,e,r))}return {get apiBasePath(){return k$1},get corsHeaders(){return v},get queueLaneTuning(){return K},handleRuntimeApi:ke,buildPublishedRuntimePayload:dt,processAccumulatedEvents:te,processAccumulatedLane:ct,handleChatAgentRequest:ye,clearChatRecords:fe,reportSourceFetched(t,e){return bt(t,{ref:e})},reportSourceFetchFailure(t,e){return Ct(t,{reason:e})},get cardStore(){return d$2[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function ar(R){let k=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),v={...Yt,...R.corsHeaders||{}},K=R.serverMetaStore,H=R.boardRuntimeFactory,I=new Map,W="boards-config.json";function U(){let c=K.getText(W);if(!c)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(c)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function L(c){K.putText(W,JSON.stringify(c,null,2));}function G(c){let p=String(c||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return p.length>0&&p.length<=64?p:null}function V(c){if(I.has(c))return I.get(c);let h=U().boards.find(O=>O.id===c)||{},d=H(c,h);return I.set(c,d),d}function _(c,p,h){let d=JSON.stringify(h),O=typeof Buffer<"u"?Buffer.byteLength(d):new TextEncoder().encode(d).length;c.writeHead(p,{...v,"Content-Type":"application/json; charset=utf-8","Content-Length":O}),c.end(d);}async function X(c,p,h){let d=c.method||"GET",O=h.pathname;if(d==="GET"&&O===k)return _(p,200,{ok:true,boards:U().boards}),true;if(d==="POST"&&O===k){let E=[];for await(let C of c)E.push(C);let w=typeof Buffer<"u"?Buffer.concat(E).toString("utf-8").trim():new TextDecoder().decode(d$1(E)).trim(),b={};try{b=w?JSON.parse(w):{};}catch{b={};}let S=G(b.id);if(!S)return _(p,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let g=U();if(g.boards.some(C=>C.id===S))return _(p,409,{error:`Board "${S}" is already registered`}),true;let $=typeof b.label=="string"&&b.label.trim()?b.label.trim():S,N={id:S,label:$};for(let[C,J]of Object.entries(b))C==="id"||C==="label"||J!=null&&(N[C]=J);return g.boards.push(N),L(g),_(p,200,{ok:true,board:N}),true}return false}async function Q(c,p,h){let O=h.pathname.match(new RegExp(`^${c$2(k)}/([^/]+)(/|$)`));if(!O)return false;let E=G(decodeURIComponent(O[1]));return E?U().boards.some(S=>S.id===E)?!!await V(E).handleRuntimeApi(c,p,h):(_(p,404,{error:`Board "${E}" not registered. POST ${k} with {id} to register it first.`}),true):(_(p,400,{error:"Invalid board id"}),true)}async function x(c,p,h){return !!(await X(c,p,h)||await Q(c,p,h))}function rt(c){if(!U().boards.some(h=>h.id===c))throw Object.assign(new Error(`Board "${c}" not registered`),{statusCode:404});return {service:V(c)}}return {get apiBasePath(){return k},get corsHeaders(){return v},handleApi:x,requireBoardService:rt}}export{nr as a,ar as b};//# sourceMappingURL=chunk-76C7N4YT.js.map
|
|
3
|
-
//# sourceMappingURL=chunk-76C7N4YT.js.map
|
package/lib/chunk-76ON3V7R.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
function P(c){function T(n){let r=typeof n=="number"?n:Number(n);return Number.isInteger(r)&&r>0?r:null}function k(n,r){let t=r;for(let e=n.length-1;e>=0;e-=1)if(n[e]?.role==="user"&&(t-=1,t===0))return n.slice(e);return n}function S(n){return n.some(r=>typeof r?.turn=="string"&&r.turn!=="")}function w(n,r){if(r<=0)return [];if(!S(n))return k(n,r);let t=new Map,e=[];for(let s of n){let u=typeof s?.turn=="string"?s.turn:"";t.has(u)||(t.set(u,[]),e.push(u)),t.get(u).push(s);}return e.slice(Math.max(0,e.length-r)).flatMap(s=>t.get(s)??[])}function o(n){return {status:"success",data:n}}function a(n){return {status:"fail",error:n}}function i(n){return {status:"error",error:n instanceof Error?n.message:String(n)}}function R(n,r="command envelope"){let t=typeof n.cardId=="string"?n.cardId:void 0;if(!n.command)return a(`chat-store: ${r} missing "command"`);if(!t)return a(`chat-store: ${r} missing "cardId"`);if(n.command==="append")return d.append({params:{cardId:t},body:{role:n.role,text:n.text,files:n.files,turn:n.turn}});if(n.command==="read-all")return d.readAll({params:{cardId:t},body:{lastUserTurns:n.lastUserTurns,tailTurns:n.tailTurns,turnId:n.turnId,allTurns:n.allTurns,tailTurnsBeforeId:n.tailTurnsBeforeId}});if(n.command==="read-after")return d.readAfter({params:{cardId:t},body:{cursor:n.cursor??null}});if(n.command==="clear")return d.clear({params:{cardId:t}});if(n.command==="set-processing")return d.setProcessing({params:{cardId:t},body:{active:n.active}});if(n.command==="is-processing")return d.isProcessing({params:{cardId:t}});if(n.command==="get-config")return d.getConfig({params:{cardId:t}});if(n.command==="set-config"){let{command:e,cardId:m,...s}=n;return d.setConfig({params:{cardId:t},body:s})}return a(`chat-store: unknown command "${String(n.command)}"`)}function A(n){if(!Array.isArray(n.commands)||n.commands.length===0)return a('chat-store: command envelope must include a non-empty "commands" array');let r=[];for(let t=0;t<n.commands.length;t+=1){let e=n.commands[t];if(!e||typeof e!="object"||Array.isArray(e))return a(`chat-store: command envelope entry ${t} must be an object`);let m={cardId:n.cardId,...e},s=R(m,`command envelope entry ${t}`);if(s.status!=="success")return s;r.push({index:t,command:String(m.command),data:s.data});}return o({results:r})}let d={append(n){try{let r=n.params?.cardId;if(!r)return a("append requires params.cardId");let t=n.body??{},e=typeof t.role=="string"?t.role:"",m=typeof t.text=="string"?t.text:"",s=Array.isArray(t.files)?t.files:[],u=typeof t.turn=="string"?t.turn:"";if(!e)return a("append requires body.role");let l=c.append(r,e,m,s,u);return o({id:l})}catch(r){return i(r)}},readAll(n){try{let r=n.params?.cardId;if(!r)return a("readAll requires params.cardId");let t=n.body??{},e=typeof t.turnId=="string"?t.turnId:"",m=t.allTurns===!0,s=typeof t.tailTurnsBeforeId=="string"?t.tailTurnsBeforeId:"",u=t.tailTurns===void 0?t.lastUserTurns:t.tailTurns,l=u===void 0?m||e?void 0:1:T(u);if(u!==void 0&&l===null)return a("readAll requires body.tailTurns (positive integer)");let b=c.readAll(r),g=b.filter(f=>!e||String(f.turn||"")===e);if(s){let f=l;if(typeof f!="number"||!Number.isInteger(f)||f<=0)return a("readAll requires body.tailTurns (positive integer) when body.tailTurnsBeforeId is provided");let p=new Map,I=[];for(let C of b){let h=String(C.turn||"");p.has(h)||(p.set(h,[]),I.push(h)),p.get(h).push(C);}let y=I.findIndex(C=>C===s),x=Math.max(0,y-f);return g=(y===-1?[]:I.slice(x,y)).flatMap(C=>p.get(C)??[]),o({records:g})}return o(typeof l=="number"?{records:w(g,l)}:{records:g})}catch(r){return i(r)}},readAfter(n){try{let r=n.params?.cardId;if(!r)return a("readAfter requires params.cardId");let e=(n.body??{}).cursor??null;return o(c.readAfter(r,e))}catch(r){return i(r)}},clear(n){try{let r=n.params?.cardId;return r?(c.clear(r),o({ok:!0})):a("clear requires params.cardId")}catch(r){return i(r)}},setProcessing(n){try{let r=n.params?.cardId;if(!r)return a("setProcessing requires params.cardId");let t=n.body??{};return typeof t.active!="boolean"?a("setProcessing requires body.active (boolean)"):(c.setProcessing(r,t.active),o({ok:!0}))}catch(r){return i(r)}},isProcessing(n){try{let r=n.params?.cardId;return r?o({active:c.isProcessing(r)}):a("isProcessing requires params.cardId")}catch(r){return i(r)}},getConfig(n){try{let r=n.params?.cardId;return r?o({config:c.getConfig(r)}):a("getConfig requires params.cardId")}catch(r){return i(r)}},setConfig(n){try{let r=n.params?.cardId;if(!r)return a("setConfig requires params.cardId");let t=n.body??{};return c.setConfig(r,t),o({ok:!0})}catch(r){return i(r)}},run:R,runBatch:A};return d}export{P as a};//# sourceMappingURL=chunk-76ON3V7R.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-76ON3V7R.js.map
|
package/lib/chunk-7ICPAABP.cjs
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
'use strict';var chunkKAWQPLIE_cjs=require('./chunk-KAWQPLIE.cjs');function A(h){let r=new Map,a=new Map,d=new Map,I=0,b=null;function g(e){let t=JSON.stringify(e);return I++,`id: ${I}
|
|
2
|
-
data: ${t}
|
|
3
|
-
|
|
4
|
-
`}function C(e){let t=e;try{t.flushHeaders?.();}catch{}try{t.flush?.();}catch{}try{t.socket?.setNoDelay?.(!0);}catch{}try{t.socket?.uncork?.();}catch{}}function y(e,t){let s=r.get(e);if(s&&!(t&&s.res!==t)){r.delete(e),w();try{h.onSseClientDisconnected?.(e);}catch{}try{s.res.end();}catch{}}}function v(e,t,s){let n=r.get(e);n&&y(e,n.res),r.set(e,{res:t,subscribedChatCardIds:s??new Set});}function f(e,t){let s=r.get(e);if(!s)return;let n=g(t);try{s.res.write(n),C(s.res);}catch{y(e,s.res);}}function c(){let e=new Set;for(let t of r.values())for(let s of t.subscribedChatCardIds)e.add(s);return Array.from(e)}function l(e){let t=a.has(e)?a.get(e):null,{cursor:s}=h.chatStorage.readAfter(e,t),n=h.chatStorage.isProcessing(e),o=n!==(d.get(e)??false),S=s!==t;return S&&a.set(e,s),d.set(e,n),S||o}function u(e,t){let s=h.readChatRecords(e),n=Date.now();return {kind:"card_chats",cardId:e,sentAt:new Date(n).toISOString(),sentAtMs:n,messages:s.map(o=>({role:String(o.role||"system"),text:String(o.text||""),files:Array.isArray(o.files)?o.files:[]})),receiving:t,processing:h.chatStorage.isProcessing(e)}}function i(e,t=true){let s={kind:"notification-batch",notifications:[u(e,t)]};for(let[n,o]of r.entries())o.subscribedChatCardIds.has(e)&&f(n,s);}function w(){c().length>0||(b&&(clearInterval(b),b=null),a.clear(),d.clear());}function p(){if(b)return;let e=()=>{let t=c();if(t.length===0){w();return}let s=new Set(t);for(let n of Array.from(a.keys()))s.has(n)||a.delete(n);for(let n of Array.from(d.keys()))s.has(n)||d.delete(n);for(let n of t)l(n)&&i(n,true);};e(),b=setInterval(e,1e3);}function k(e,t){let s=r.get(e);if(!s)return false;s.subscribedChatCardIds.add(t);let{cursor:n}=h.chatStorage.readAfter(t,null);return a.set(t,n),d.set(t,h.chatStorage.isProcessing(t)),p(),f(e,{kind:"notification-batch",notifications:[u(t,true)]}),true}function m(e,t){let s=r.get(e);return s?(s.subscribedChatCardIds.delete(t),c().includes(t)||(a.delete(t),d.delete(t)),w(),true):false}function R(e){if(!e||typeof e!="object")return false;let t=e.kind;return t==="card_chats"||t==="chat_messages"}function P(e){if(!e||e.length===0)return;let t=[],s=new Set;for(let n of e)R(n)&&typeof n.cardId=="string"?s.add(String(n.cardId)):t.push(n);if(t.length>0){let n={kind:"notification-batch",notifications:t};for(let o of r.keys())f(o,n);}for(let n of s)i(n,true);}return {size:()=>r.size,has:e=>r.has(e),get:e=>r.get(e),buildFrame:g,flushTransport:C,register:v,disconnect:y,writeFrame:f,subscribeChat:k,unsubscribeChat:m,broadcastNotificationBatch:P,broadcastCardChats:i}}function D(h){let{sseHub:r,corsHeaders:a,json:d,buildPublishedRuntimePayload:I,onSseClientConnected:b,onChannelSubscribed:g,onChannelUnsubscribed:C}=h;function y(f,c,l,u,i){if(!r.has(c)){d(f,404,{error:`SSE client not connected: ${c}`});return}i?g?.(c,l,u):C?.(c,l,u),d(f,200,{ok:true,clientId:c,channelName:l,...u.cardId?{cardId:u.cardId}:{},subscribed:i});}async function v(f,c,l){let u=r.get(l),i=u?new Set(u.subscribedChatCardIds):new Set;c.writeHead(200,{...a,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),r.flushTransport(c),r.register(l,c,i);let w=await I(),p=r.buildFrame(w);c.write(p);try{b?.(l,m=>{r.writeFrame(l,m);});}catch{}let k=setInterval(()=>{try{c.write(`: keepalive
|
|
5
|
-
|
|
6
|
-
`);}catch{}},15e3);f.on("close",()=>{clearInterval(k),r.disconnect(l,c);});}return {handleChannelSubscription:y,handleSse:v}}function T(h){let{apiBasePath:r,json:a,readJsonBody:d,initBoardAndSetup:I,bootstrapBoard:b,boardContexts:g,publishPersistedStateSnapshot:C,upsertCardsFromSource:y,sseHub:v}=h,{handleSse:f,handleChannelSubscription:c}=D(h);async function l(u,i,w){let p=u.method||"GET",k=w,m=k.pathname;try{if(p==="GET"&&m===`${r}/sse`){await I();let s=String(k.searchParams.get("clientId")||"").trim();if(!s)return a(i,400,{error:"clientId query param is required for SSE"}),!0;await f(u,i,s);for(let n=0;n<g.length;n++)await C(g[n]),await y(g[n],n),await C(g[n]);return !0}let R=m.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(r)}/cards/([^/]+)/chats/subscribe-sse$`));if(p==="POST"&&R){await b();let s=decodeURIComponent(R[1]),n=await d(u),o=typeof n?.clientId=="string"?n.clientId.trim():"";return o?v.subscribeChat(o,s)?(a(i,200,{ok:!0,clientId:o,cardId:s,subscribed:!0}),!0):(a(i,404,{error:`SSE client not connected: ${o}`}),!0):(a(i,400,{error:"clientId is required"}),!0)}let P=m.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(r)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(p==="POST"&&P){await b();let s=decodeURIComponent(P[1]),n=await d(u),o=typeof n?.clientId=="string"?n.clientId.trim():"";return o?v.unsubscribeChat(o,s)?(a(i,200,{ok:!0,clientId:o,cardId:s,subscribed:!1}),!0):(a(i,404,{error:`SSE client not connected: ${o}`}),!0):(a(i,400,{error:"clientId is required"}),!0)}let e=m.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(r)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&e){await b();let s=decodeURIComponent(e[1]),n=e[2]==="subscribe",o=await d(u),S=typeof o?.clientId=="string"?o.clientId.trim():"";return S?(c(i,S,s,{},n),!0):(a(i,400,{error:"clientId is required"}),!0)}let t=m.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(r)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(p==="POST"&&t){await b();let s=decodeURIComponent(t[1]),n=decodeURIComponent(t[2]),o=t[3]==="subscribe",S=await d(u),H=typeof S?.clientId=="string"?S.clientId.trim():"";return H?(c(i,H,n,{cardId:s},o),!0):(a(i,400,{error:"clientId is required"}),!0)}return !1}catch(R){let P=R?.statusCode||500;return a(i,P,{error:String(R?.message||R)}),true}}return {handleWatchersRoutes:l,handleSse:f,handleChannelSubscription:c}}exports.a=A;exports.b=T;//# sourceMappingURL=chunk-7ICPAABP.cjs.map
|
|
7
|
-
//# sourceMappingURL=chunk-7ICPAABP.cjs.map
|
package/lib/chunk-ASR44K7H.cjs
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
'use strict';var chunkEZENHAVZ_cjs=require('./chunk-EZENHAVZ.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunk7ICPAABP_cjs=require('./chunk-7ICPAABP.cjs'),chunkKAWQPLIE_cjs=require('./chunk-KAWQPLIE.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkNJJ7WEDT_cjs=require('./chunk-NJJ7WEDT.cjs'),chunkJ6EGN6S4_cjs=require('./chunk-J6EGN6S4.cjs'),chunkJJL5VOQZ_cjs=require('./chunk-JJL5VOQZ.cjs'),chunkYMEIPKLW_cjs=require('./chunk-YMEIPKLW.cjs'),chunkGYQXDNNI_cjs=require('./chunk-GYQXDNNI.cjs');function Zt(R){let{apiBasePath:k,json:v,readJsonBody:K,initBoardAndSetup:H,bootstrapBoard:I,buildPublishedRuntimePayload:W,createMcpControlplaneToolRegistry:U,retriggerCard:L,applyCardAction:G,resolveChatHandlerTarget:V,sendCardFileDownloadResponse:_}=R;async function X(Q,x,rt){let c=Q.method||"GET",p=rt,h=p.pathname;try{if(c==="GET"&&h===`${k}/init-board`)return await H(),v(x,200,await W()),!0;if(c==="POST"&&h===`${k}/mcp-controlplane`){await I();let w=await K(Q),b=typeof w.tool=="string"?w.tool.trim():"",S=w.args&&typeof w.args=="object"&&!Array.isArray(w.args)?w.args:{};if(!b)return v(x,400,{error:"tool is required"}),!0;try{let g=await chunk272IYUKT_cjs.a(b,S,U());if(g&&typeof g=="object"&&!Array.isArray(g)){let $=g;if($.status==="fail")return v(x,400,{error:chunk272IYUKT_cjs.b(g,"Request failed")}),!0;if($.status==="error")return v(x,500,{error:chunk272IYUKT_cjs.b(g,"Internal error")}),!0}v(x,200,g);}catch(g){let $=typeof g?.statusCode=="number"?Number(g.statusCode):500,N=g instanceof Error?g.message:String(g);v(x,$,{error:N});}return !0}let d=h.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(k)}/cards/([^/]+)/retrigger$`));if(c==="POST"&&d){await I();let w=decodeURIComponent(d[1]);return await L(w),v(x,200,{ok:!0}),!0}let O=h.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(k)}/cards/([^/]+)/actions$`));if(c==="POST"&&O){await I();let w=decodeURIComponent(O[1]),b=Date.now(),S=new Date(b).toISOString(),g=await K(Q),$=g?.actionType;if($==="chat-send"&&!await V(w)){let C=Date.now();return v(x,409,{error:`chat handler is not configured for card: ${w}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(C).toISOString(),responseSentAtMs:C,responseStatus:409}),!0}if($==="chat-send"){let C=g?.payload??{},J=typeof C["turn-id"]=="string"?C["turn-id"]:typeof C.turnId=="string"?C.turnId:typeof C.turn=="string"?C.turn:"";if(!J||!String(J).trim()){let q=Date.now();return v(x,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${w}`,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(q).toISOString(),responseSentAtMs:q,responseStatus:400}),!0}}await G(w,$,g?.payload);let N=Date.now();return v(x,200,{ok:!0,requestReceivedAt:S,requestReceivedAtMs:b,responseSentAt:new Date(N).toISOString(),responseSentAtMs:N,responseStatus:200}),!0}let E=h.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(k)}/cards/([^/]+)/files/(\\d+)$`));if(c==="GET"&&E){let w=decodeURIComponent(E[1]),b=parseInt(E[2],10),S=p.searchParams.get("sn");return await _(x,w,b,S),!0}return !1}catch(d){let O=d?.statusCode||500;return v(x,O,{error:String(d?.message||d)}),true}}return {handleRuntimeApi:X}}var Yt={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},Xt="chat-handler-flow-queue";function nr(R){let k=String(R.apiBasePath||"/api/board").replace(/\/$/,""),v={...Yt,...R.corsHeaders||{}},K=R.queueLaneTuning??{},H=R.boardId||"",I=R.logger||{info:console.log,warn:console.warn,error:console.error},W=R.invocationAdapter,U=R.chatFlowRunner||null,L=R.chatStorage??chunkNJJ7WEDT_cjs.b(),G=chunkGYQXDNNI_cjs.a(L),V=R.notificationTransport||null,_=R.serverUrl||null,X=R.executionExtra||{},Q=R.onSseClientConnected,x=R.onSseClientDisconnected,rt=R.onChannelSubscribed,c=R.onChannelUnsubscribed,p=chunk7ICPAABP_cjs.a({chatStorage:L,readChatRecords:t=>yt(t),onSseClientDisconnected:x});function h(t){function e(a){if(Array.isArray(a))return a;if(a&&typeof a=="object"){let s=a;return Array.isArray(s.files)?s.files:[a]}return null}function r(a){return {async get(s){return a.get(s)},async set(s){return a.set(s)},async del(s){return a.del(s)},async patch(s){return a.patch(s)},async appendFiles(s){return a.appendFiles(s)}}}function o(a){function s(m){return {status:"success",data:m}}function l(m){return {status:"fail",error:m}}function u(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}return {async get(m){try{let f=m.params?.id;if(f){let T=await a.readCard(f);return T?s({cards:[T]}):l(`card "${f}" not found`)}return s({cards:await a.readAllCards()})}catch(f){return u(f)}},async set(m){try{let f=m.body;if(f==null)return l("set requires a body (card object or array of cards)");let T=Array.isArray(f)?f:[f];for(let j of T){if(typeof j.id!="string")return l("each card must have a string `id` field");await a.writeCard(j.id,j);}return s({count:T.length})}catch(f){return u(f)}},async del(m){try{let f=m.body?.ids??[],T=m.params?.id,j=T?[...f,T]:f;if(j.length===0)return l("del requires body.ids (string[]) or params.id");for(let tt of j)await a.removeCard(tt);return s({count:j.length})}catch(f){return u(f)}},async patch(m){try{let f=m.params?.id,T=m.params?.path;if(!f)return l("patch requires params.id");if(!T)return l("patch requires params.path");let j=m.body,tt=j&&Object.prototype.hasOwnProperty.call(j,"value")?j.value:m.body;return await a.patchCard(f,T,tt),s({count:1})}catch(f){return u(f)}},async appendFiles(m){try{let f=m.params?.id;if(!f)return l("appendFiles requires params.id");let T=await a.readCard(f);if(!T)return l(`card "${f}" not found`);let j=e(m.body);if(!j||j.length===0)return l("appendFiles requires a file metadata object, array, or body.files array");let tt=T.card_data&&typeof T.card_data=="object"&&!Array.isArray(T.card_data)?T.card_data:{},At=Array.isArray(tt.files)?tt.files:[],ve=[...At,...j];return await a.patchCard(f,"card_data.files",ve),s({files_added:j.map((Oe,Pe)=>({idx:At.length+Pe,entry:Oe}))})}catch(f){return u(f)}}}}let n=chunkKAWQPLIE_cjs.a(t.boardAdapter)?chunkJ6EGN6S4_cjs.j(t.baseRef,t.boardAdapter):chunkJJL5VOQZ_cjs.y(t.baseRef,t.boardAdapter),i=t.nonCoreAdapter??(!chunkKAWQPLIE_cjs.a(t.boardAdapter)&&w(t.boardAdapter)?t.boardAdapter:null),y=t.nonCore??(i?chunkJJL5VOQZ_cjs.z(t.baseRef,i):null),P,A=chunkKAWQPLIE_cjs.a(t.boardAdapter)?(()=>{let a=chunkJ6EGN6S4_cjs.d(chunkJ6EGN6S4_cjs.c(chunkJ6EGN6S4_cjs.b(t.boardAdapter.kvStorageForRef(t.cardStoreRef)),t.boardAdapter.hashFn),I.warn),s=o(a);return P={get(l){return s.get(l)},set(l){return s.set(l)}},s})():(()=>{let a=t.boardAdapter.kvStorageForRef(t.cardStoreRef),l=chunkYMEIPKLW_cjs.a(chunkJJL5VOQZ_cjs.l({readIndex:()=>a.read("_index"),writeIndex:u=>a.write("_index",u),readCard:u=>a.read(u),writeCard:(u,m)=>(a.write(u,m),u),removeCard:u=>{a.delete(u);},cardExists:u=>a.read(u)!==null,defaultCardKey:u=>u},I.warn));return P=l,r(l)})(),F=t.artifactsAdapter||t.boardAdapter,B=t.filesArtifactsStore??null,M=B?{putBytes(a,s,l){B.putBytes(a,s,l);},getBytes(a){return B.getBytes(a)},listKeys(a){return B.list(a).map(s=>s.key)}}:null;if(!M&&!chunkKAWQPLIE_cjs.a(F)){let a=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files"),s=chunkNJJ7WEDT_cjs.c(a);M={putBytes(l,u,m){s.putBytes(l,u,m);},getBytes(l){return s.getBytes(l)},listKeys(l){return s.list(l).map(u=>u.key)}};}else if(!M&&chunkKAWQPLIE_cjs.a(F)){let a=t.artifactsAdapter?F.blobStorage(""):F.blobStorage("files");M={async putBytes(s,l){if(a.writeBytes){await a.writeBytes(s,l);return}let u=JSON.stringify({__kind:"bytes-array",data:[...l]});await a.write(s,u);},async getBytes(s){if(a.readBytes){let u=await a.readBytes(s);if(u!==null)return u}let l=await a.read(s);if(l===null)return null;try{let u=JSON.parse(l);if(u&&u.__kind==="bytes-array"&&Array.isArray(u.data))return new Uint8Array(u.data)}catch{}return new TextEncoder().encode(l)},async listKeys(s){return await a.listKeys(s)}};}let D={async init(a){return n.init(a)},async status(a){return n.status(a)},async getConfig(a){return n.getConfig(a)},async getAllOutputsDataObjects(a){return n.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return n.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return n.getOutputsFetchedSources(a)},async upsertCard(a){return n.upsertCard(a)},async removeCard(a){return n.removeCard(a)},async cardRefreshedNotify(a){return n.cardRefreshedNotify(a)},async sourceDataFetched(a){return n.sourceDataFetched(a)},async sourceDataFetchFailure(a){return n.sourceDataFetchFailure(a)}};return {label:t.label,board:n,nonCore:y,publicCardStore:P,boardOps:D,cardStoreOps:A,get filesArtifacts(){return M},boardAdapter:t.boardAdapter,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,archiveStoreRef:t.archiveStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:chunkEZENHAVZ_cjs.a(),notificationTeardown:null,initialized:false,cardsBootstrapped:false}}let d=R.boards.map(h),O=new Map;function E(t){return O.get(t)??0}function w(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function b(t){let e=d[E(t)];return {files:e?e.filesArtifacts:null}}function S(){return chunkNJJ7WEDT_cjs.e()}function g(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}async function $(t){if(!t||t.notificationTeardown||!V||!t.notifyRef)return;let e=await V.subscribe(t.notifyRef,r=>{chunkEZENHAVZ_cjs.c(t.notification,r);let o=r.kind==="notification-batch"?r.notifications:[r];p.broadcastNotificationBatch(o);});t.notificationTeardown=e;}async function N(t){if(!t||t.initialized)return;let e={cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef};t.artifactsStoreRef&&(e.artifactsStoreRef=t.artifactsStoreRef),t.chatStoreRef&&(e.chatStoreRef=t.chatStoreRef),t.scratchStoreRef&&(e.scratchStoreRef=t.scratchStoreRef),t.archiveStoreRef&&(e.archiveStoreRef=t.archiveStoreRef);let r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow),t.inferenceAdapterRef&&(r["inference-adapter-ref"]=t.inferenceAdapterRef);let o=await t.boardOps.init({params:e,body:r});if(o.status!=="success")throw Object.assign(new Error(o.error||`init failed for ${t.label}`),{statusCode:500});if(await $(t),!t.chatHandlerFlow&&t.chatHandlerRef&&W.describe)try{let n=await W.describe(t.chatHandlerRef);n&&n.kind!=="chat-handler"?I.warn(`[init] chat-handler describe returned kind="${n.kind}", expected "chat-handler" for ${t.label}`):n&&I.info(`[init] chat-handler validated: ${n.name} (protocol ${n.protocolVersion}) for ${t.label}`);}catch(n){I.warn(`[init] chat-handler describe failed for ${t.label}: ${n?.message||String(n)}`);}t.initialized=true;}async function C(t){if(!t.boardAdapter.publishBoardChangeNotifications)return;let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&chunkEZENHAVZ_cjs.b(r.data)&&e.push({kind:"status",status:r.data});let o=await t.boardOps.getAllOutputsDataObjects({});if(o.status==="success"&&o.data!=null)for(let[i,y]of Object.entries(o.data))i&&e.push({kind:"data_object",key:i,payload:y});let n=await t.boardOps.getAllOutputsComputedValues({});if(n.status==="success"&&n.data!=null)for(let[i,y]of Object.entries(n.data))i&&e.push({kind:"computed_values",cardId:i,values:y});e.length>0&&t.boardAdapter.publishBoardChangeNotifications(e);}async function J(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),o=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let n of o)typeof n.id=="string"&&(O.set(n.id,e),await t.boardOps.upsertCard({params:{cardId:n.id}}));t.cardsBootstrapped=true;}async function q(){for(let t of d)await N(t);}async function it(){await q();for(let t=0;t<d.length;t++)await C(d[t]),await J(d[t],t),await C(d[t]);}async function ct(t=false){t||await q();for(let e of d){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}async function te(){return await q(),ct(true)}function Y(t){return d[E(t)]??null}async function nt(t){let e=Y(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let o=Array.isArray(r.data?.cards)?r.data.cards:[];return o.length>0?o[0]:null}async function ft(){let t=async r=>{if(!r)return [];let o=await r.cardStoreOps.get({});return o.status!=="success"||!Array.isArray(o.data?.cards)?[]:o.data.cards},e=[];for(let r of d)e.push(...await t(r));return e}function ee(){return d[0]??null}let pt=chunkEZENHAVZ_cjs.n({boardContexts:d,cardOwnerIndex:O,cardContextForCard:t=>Y(t),readStatusSnapshot:()=>ie(),readDataObjectsByToken:()=>de(),readCardRuntimeArtifacts:()=>ce(),readCardFromStore:t=>nt(t),readCardDefinitions:()=>ft(),processAccumulatedLaneInternal:t=>ct(t),reportSourceFetched:(t,e)=>bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>Ct(t,{reason:e}),uploadCardFile:(t,e,r,o,n)=>Rt(t,e,r,o,n),chatStorePublic:G,serverUrl:_,apiBasePath:k}),re=pt.mcpCardStoreFacade,z=pt.createMcpFacade,ne=chunkEZENHAVZ_cjs.h({boardId:H,getMcpFacade:()=>z(),getMcpCardStoreFacade:()=>re()});function ae(t){return chunkEZENHAVZ_cjs.k(t)}function oe(){return chunkEZENHAVZ_cjs.l(z())}function se(){return chunkEZENHAVZ_cjs.m({boardId:H,uploadCardFile:Rt,getMcpFacade:()=>z(),controlplane:ne})}let at=chunkEZENHAVZ_cjs.i({boardId:H,boardContexts:d,readCardDefinitions:()=>ft(),readChatRecords:t=>yt(t),getChatProcessing:t=>z().getChatProcessing({cardId:t}).active}),ie=at.readStatusSnapshot,ce=at.readCardRuntimeArtifacts,de=at.readDataObjectsByToken,dt=at.buildPublishedRuntimePayload;async function mt(t,e,r){let o=r?.syncBoard!==false,n=r?.restartOnlyIfChanged===true,i=Y(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let y=await nt(t);if(!y)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let P=n?JSON.stringify(y):null,A=e(y)||y;if(n&&JSON.stringify(A)===P)return;let F=await i.cardStoreOps.set({body:A});if(F.status!=="success")throw Object.assign(new Error(F.error||`Failed to persist card: ${t}`),{statusCode:500});if(o){let B=await i.boardOps.upsertCard({params:{cardId:t,restart:true}});if(B.status!=="success")throw Object.assign(new Error(B.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function ue(t,e){await mt(t,e,{syncBoard:true});}async function gt(t,e){await mt(t,e,{syncBoard:false});}async function le(t){let e=Y(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await nt(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let o=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(o.status!=="success")throw Object.assign(new Error(o.error||`Failed to retrigger card: ${t}`),{statusCode:500})}function fe(t){L.clear(t);try{z().setChatProcessing({cardId:t,active:!1});}catch{}}function pe(t,e,r,o,n=""){let i=typeof r=="string"?r.trim():"";return L.append(t,e||"system",i,o,n)}function yt(t){return L.readAll(t)}let Rt=chunkEZENHAVZ_cjs.j({safeCardId:t=>g(t),artifactsStores:t=>b(t),cardFileMetadataStore:()=>S(),readCardFromStore:t=>nt(t),updateCardLocalOnly:(t,e)=>gt(t,e),writeChatRecord:(t,e,r,o,n)=>pe(t,e,r,o,n)}).uploadCardFile;async function ht(t){let e=Y(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=r.status==="success"?r.data?.value:null,n=e.chatHandlerRef;return o==null&&(!n||typeof n!="object")?null:{ctx:e,handlerFlow:o,handlerRef:n}}async function me(t,e,r=false,o=""){let n=await ht(t);if(!n)return;let{ctx:i,handlerFlow:y,handlerRef:P}=n;if(!r)try{z().setChatProcessing({cardId:t,active:!0});}catch{}let A={boardId:H,cardId:String(t),lastChatEntryId:e,...o?{turnId:o}:{},...X,..._?{serverUrl:_}:{}},F=y!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:Xt}}:P;try{chunkKAWQPLIE_cjs.a(i.boardAdapter)?await i.boardAdapter.chatAgentStore().enqueueRequest({boardId:H,ref:F,args:y!=null?{...A,__chatHandlerFlow:y}:A}):i.boardAdapter.chatAgentStore().enqueueRequest({boardId:H,ref:F,args:y!=null?{...A,__chatHandlerFlow:y}:A}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(B){try{z().setChatProcessing({cardId:t,active:!1});}catch{}I.warn(`[chat-handler] queue failed for card "${t}": ${B instanceof Error?B.message:String(B)}`);}}async function ge(t,e,r){if(e.howToRun==="built-in"&&chunkKAWQPLIE_cjs.b(e)===Xt){let o=U,n=r.__chatHandlerFlow,i={...r};return delete i.__chatHandlerFlow,o?o.run(n,i,{boardId:H,cardId:String(i.cardId||""),label:t.label,logger:I,serverUrl:_,executionExtra:X}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return W.invoke(e,r)}async function ye(t,e=false){e||await q();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",o=r?Y(r):ee();if(!o)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let n=await ge(o,t.ref,t.args);if(!n.dispatched){if(r)try{L.setProcessing(r,!1);}catch{}throw new Error(n.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Re(t,e,r){let o=e==="chat-send"?gt:ue,n;await o(t,i=>{let y=new Date().toISOString(),P=i.card_data&&typeof i.card_data=="object"?i.card_data:{};if(i.card_data=P,e==="chat-send"){let A=r&&typeof r.text=="string"?r.text.trim():"",F=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"",B=[];if(Array.isArray(r?.files)){for(let M of r.files)if(M){if(typeof M=="string"){B.push({name:M});continue}if(typeof M=="object"){let D=M;typeof D.name=="string"&&B.push({name:D.name,size:D.size,mime_type:D.mime_type,uploaded_at:D.uploaded_at,stored_name:D.stored_name,chat:D.chat===true});}}}if(A||B.length>0){let M=G.runBatch({cardId:t,commands:[{command:"append",role:"user",text:A,files:B,turn:F},{command:"set-processing",active:true}]});if(M.status!=="success")throw new Error(M.error);let D=M.data.results[0]?.data?.id;if(typeof D!="string"||!D)throw new Error(`chat-send did not return an append id for card ${t}`);n={cardId:t,lastEntryId:D,processingAlreadySet:true,turnId:F};try{p.broadcastCardChats(t);}catch{}}return i}if(e==="file-upload"){let A=S().normalizeIncoming(r?.files,y);return A.length>0&&S().merge(P,A),i}if(e==="action"){let A=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!A)return i;P.lastAction={buttonId:A,at:y},P.lastActionText=`${A} @ ${y}`;}return i}),n&&me(n.cardId,n.lastEntryId,n.processingAlreadySet,n.turnId??"");}function ot(t,e,r){let o=JSON.stringify(r),n=typeof Buffer<"u"?Buffer.byteLength(o):new TextEncoder().encode(o).length;t.writeHead(e,{...v,"Content-Type":"application/json; charset=utf-8","Content-Length":n}),t.end(o);}async function wt(t,e,r){let o=await nt(t);if(!o)throw Object.assign(new Error("Card not found"),{statusCode:404});let n=S().resolve(o.card_data,e,r);if(!n.ok&&n.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!n.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let i=n.file,y=g(t),P=b(t),A=String(i.stored_name||""),F=`${y}/${A}`,B=P.files?await P.files.getBytes(F):null;if(!B)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:i,bytes:B}}async function he(t,e,r,o){let{fileRecord:n,bytes:i}=await wt(e,r,o),y=String(n.name||n.stored_name||"download.bin"),P=String(n.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":P,"Content-Disposition":`attachment; filename="${y}"`,"Content-Length":i.length}),t.end(i);}function we(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 be(t,e,r){let o=t.split(/\r?\n/);return (e==="head"?o.slice(0,r):o.slice(-r)).join(`
|
|
2
|
-
`)}async function st(t){let e=[];for await(let o of t)e.push(o);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(chunkKAWQPLIE_cjs.d(e)).trim();return r?JSON.parse(r):{}}async function bt(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 o=d[0];return o?o.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function Ct(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",o=d[0];return o?o.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let Ce=chunk7ICPAABP_cjs.b({sseHub:p,corsHeaders:v,json:ot,buildPublishedRuntimePayload:()=>dt(),onSseClientConnected:Q,onChannelSubscribed:rt,onChannelUnsubscribed:c,apiBasePath:k,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),bootstrapBoard:()=>it(),boardContexts:d,publishPersistedStateSnapshot:t=>C(t),upsertCardsFromSource:(t,e)=>J(t,e)}).handleWatchersRoutes,Ae=chunk7FGPOGRV_cjs.a({apiBasePath:k,json:ot,readJsonBody:t=>st(t),bootstrapBoard:()=>it(),createMcpFacade:()=>z(),createMcpToolRegistry:t=>ae(t),resolveCardFileDownloadPayload:(t,e,r)=>wt(t,e,r),isLikelyTextMimeType:t=>we(t),sliceTextByLines:(t,e,r)=>be(t,e,r)}).handleAgentfaceApi,Se=chunkNM6O35RY_cjs.a({apiBasePath:k,json:ot,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),createMcpWebhookToolRegistry:()=>oe()}).handleWebhooksApi,Be=Zt({apiBasePath:k,json:ot,readJsonBody:t=>st(t),initBoardAndSetup:()=>q(),bootstrapBoard:()=>it(),buildPublishedRuntimePayload:()=>dt(),createMcpControlplaneToolRegistry:()=>se(),retriggerCard:t=>le(t),applyCardAction:(t,e,r)=>Re(t,e,r),resolveChatHandlerTarget:t=>ht(t),sendCardFileDownloadResponse:(t,e,r,o)=>he(t,e,r,o)}).handleRuntimeApi;async function ke(t,e,r){return !!(await Ae(t,e,r)||await Se(t,e,r)||await Ce(t,e,r)||await Be(t,e,r))}return {get apiBasePath(){return k},get corsHeaders(){return v},get queueLaneTuning(){return K},handleRuntimeApi:ke,buildPublishedRuntimePayload:dt,processAccumulatedEvents:te,processAccumulatedLane:ct,handleChatAgentRequest:ye,clearChatRecords:fe,reportSourceFetched(t,e){return bt(t,{ref:e})},reportSourceFetchFailure(t,e){return Ct(t,{reason:e})},get cardStore(){return d[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function ar(R){let k=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),v={...Yt,...R.corsHeaders||{}},K=R.serverMetaStore,H=R.boardRuntimeFactory,I=new Map,W="boards-config.json";function U(){let c=K.getText(W);if(!c)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(c)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function L(c){K.putText(W,JSON.stringify(c,null,2));}function G(c){let p=String(c||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return p.length>0&&p.length<=64?p:null}function V(c){if(I.has(c))return I.get(c);let h=U().boards.find(O=>O.id===c)||{},d=H(c,h);return I.set(c,d),d}function _(c,p,h){let d=JSON.stringify(h),O=typeof Buffer<"u"?Buffer.byteLength(d):new TextEncoder().encode(d).length;c.writeHead(p,{...v,"Content-Type":"application/json; charset=utf-8","Content-Length":O}),c.end(d);}async function X(c,p,h){let d=c.method||"GET",O=h.pathname;if(d==="GET"&&O===k)return _(p,200,{ok:true,boards:U().boards}),true;if(d==="POST"&&O===k){let E=[];for await(let C of c)E.push(C);let w=typeof Buffer<"u"?Buffer.concat(E).toString("utf-8").trim():new TextDecoder().decode(chunkKAWQPLIE_cjs.d(E)).trim(),b={};try{b=w?JSON.parse(w):{};}catch{b={};}let S=G(b.id);if(!S)return _(p,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let g=U();if(g.boards.some(C=>C.id===S))return _(p,409,{error:`Board "${S}" is already registered`}),true;let $=typeof b.label=="string"&&b.label.trim()?b.label.trim():S,N={id:S,label:$};for(let[C,J]of Object.entries(b))C==="id"||C==="label"||J!=null&&(N[C]=J);return g.boards.push(N),L(g),_(p,200,{ok:true,board:N}),true}return false}async function Q(c,p,h){let O=h.pathname.match(new RegExp(`^${chunkKAWQPLIE_cjs.c(k)}/([^/]+)(/|$)`));if(!O)return false;let E=G(decodeURIComponent(O[1]));return E?U().boards.some(S=>S.id===E)?!!await V(E).handleRuntimeApi(c,p,h):(_(p,404,{error:`Board "${E}" not registered. POST ${k} with {id} to register it first.`}),true):(_(p,400,{error:"Invalid board id"}),true)}async function x(c,p,h){return !!(await X(c,p,h)||await Q(c,p,h))}function rt(c){if(!U().boards.some(h=>h.id===c))throw Object.assign(new Error(`Board "${c}" not registered`),{statusCode:404});return {service:V(c)}}return {get apiBasePath(){return k},get corsHeaders(){return v},handleApi:x,requireBoardService:rt}}exports.a=nr;exports.b=ar;//# sourceMappingURL=chunk-ASR44K7H.cjs.map
|
|
3
|
-
//# sourceMappingURL=chunk-ASR44K7H.cjs.map
|
package/lib/chunk-CPAXTVBQ.cjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
'use strict';var chunkGL2OHR2E_cjs=require('./chunk-GL2OHR2E.cjs');function d(a,e){return e?{...a,...e.pollIntervalMs!=null?{pollIntervalMs:e.pollIntervalMs}:{},...e.visibilityMs!=null?{visibilityMs:e.visibilityMs}:{},...e.concurrency!=null?{concurrency:e.concurrency}:{},...e.maxAttempts!=null?{maxAttempts:e.maxAttempts}:{}}:a}function p(a,e,c,s){return {id:a,async lease(o){return (await Promise.resolve(e.leaseRequests(o))).map(r=>({id:r.messageId,attempt:r.attempt,message:r.request,ack:()=>Promise.resolve(e.ackRequest(r.messageId,r.leaseToken)),nack:t=>Promise.resolve(e.nackRequest(r.messageId,r.leaseToken,t))}))},async handle(o){await c(o.args,o);},onError:s?(o,u)=>s(o,u.attempt,u.message):void 0}}function l(a,e,c,s){return {id:a,async lease(o){return (await Promise.resolve(e.lease(o))).map(r=>({id:r.id,attempt:r.attempt,message:r.body,ack:()=>Promise.resolve(e.ack(r.id,r.leaseToken)),nack:t=>Promise.resolve(e.nack(r.id,r.leaseToken,t))}))},async handle(){await c();},onError:s?(o,u)=>s(o,u.attempt):void 0}}function y(a){let e=a.logger??{info(){},warn(){},error(){}},c=a.boardAdapter,s=a.runtime.queueLaneTuning??{},o=c.processAccumulatedStore(),u=c.chatAgentStore(),r=[];if(r.push(d(l("process-accumulated",o,async()=>{let t=await a.runtime.processAccumulatedLane();if(t.status!=="success")throw new Error(t.error||`processAccumulatedLane returned ${t.status}`)},(t,n)=>{e.error(`[board-server] queued process-accumulated failed for ${a.boardId} (attempt ${n}): ${String(t&&t.message||t)}`);}),s.processAccumulated)),r.push(d(p("chat-agent",u,async(t,n)=>{await a.runtime.handleChatAgentRequest(n);},(t,n,i)=>{let m=typeof i.args?.cardId=="string"?i.args.cardId:"";e.error(`[board-server] queued chat-agent failed for ${a.boardId}${m?`/${m}`:""} (attempt ${n}): ${String(t&&t.message||t)}`);}),s.chatAgent)),a.executeTaskExecutorRequest){let t=c.boardWorkerStore();r.push(d(p("task-executor",t,a.executeTaskExecutorRequest,(n,i)=>{e.error(`[board-server] queued board-worker failed for ${a.boardId} (attempt ${i}): ${String(n&&n.message||n)}`);}),s.taskExecutor));}return chunkGL2OHR2E_cjs.a(r)}exports.a=y;//# sourceMappingURL=chunk-CPAXTVBQ.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-CPAXTVBQ.cjs.map
|
package/lib/chunk-EGRHWZRV.js
DELETED
package/lib/chunk-EZENHAVZ.cjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
'use strict';var chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunkKAWQPLIE_cjs=require('./chunk-KAWQPLIE.cjs'),chunkSFVO2LB2_cjs=require('./chunk-SFVO2LB2.cjs'),chunkPBOQ4HYB_cjs=require('./chunk-PBOQ4HYB.cjs');function H(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function V(n){if(!n||typeof n!="object")return false;let e=n.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function z(n,e){if(!e||typeof e!="object")return;let a=e;if(a.kind==="notification-batch"&&Array.isArray(a.notifications)){for(let l of a.notifications)z(n,l);return}a.kind==="status"&&V(a.status)&&(n.status=a.status),a.kind==="computed_values"&&a.cardId&&(n.computedValues[a.cardId]=a.values),a.kind==="data_object"&&a.key&&(n.dataObjects[a.key]=a.payload),a.kind==="card_refreshed"&&a.cardId&&(n.cards[a.cardId]=a.card),a.kind==="card_removed"&&a.cardId&&(delete n.cards[a.cardId],delete n.computedValues[a.cardId]);}function B(n,e){if(n?.status==="success")return Object.prototype.hasOwnProperty.call(n,"data")?n.data:void 0;throw n?.status==="fail"||n?.status==="error"?Object.assign(new Error(n.error||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function j(n,e){return B(await n,e)}function D(n){let e=chunkLPXVVMQT_cjs.a(n,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let a=e.split(".");if(!(a.length>=2&&a[0]==="chat"&&a.every(h=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(h))))throw Object.assign(new Error("MCP tool only supports card private keys under chat.*"),{statusCode:400});return e}function q(n,e){let a=n.__private;for(let l of e.split(".")){if(!a||typeof a!="object"||Array.isArray(a)||!Object.prototype.hasOwnProperty.call(a,l))return {exists:false,value:null};a=a[l];}return {exists:true,value:a}}function Q(n){let{boardId:e,getMcpFacade:a,getMcpCardStoreFacade:l}=n;function h(p){let o=chunkLPXVVMQT_cjs.a(p,"board_id"),c=chunkLPXVVMQT_cjs.a(p,"card_id");if(!o)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(!c)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});if(o!==e)throw Object.assign(new Error(`Unknown board_id: ${o}`),{statusCode:400});return {cardId:c}}function R(p,o){let{cardId:c}=h(p);return a().setChatProcessing({cardId:c,active:o}),{status:"success",data:{boardId:e,cardId:c,active:o}}}function _(p){let{cardId:o}=h(p),c=a().getChatProcessing({cardId:o});return {status:"success",data:{boardId:e,cardId:o,active:c.active}}}async function t(p){let{cardId:o}=h(p),c=D(p);if(!Object.prototype.hasOwnProperty.call(p,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(c.split(".").includes("visible_controlplane_only")){let i=await j(l().get({params:{id:o}}),"cardStore.get"),g=Array.isArray(i.cards)&&i.cards.length>0&&typeof i.cards[0]=="object"&&!Array.isArray(i.cards[0])?i.cards[0]:null,w=g?q(g,"visible_controlplane_only").value:void 0;if(p.value!==w)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:e,cardId:o,key:c}}}return B(await l().patch({params:{id:o,path:`__private.${c}`},body:{value:p.value}}),"cardStore.patch"),{status:"success",data:{boardId:e,cardId:o,key:c}}}async function C(p){let{cardId:o}=h(p),c=D(p),i=await j(l().get({params:{id:o}}),"cardStore.get"),g=Array.isArray(i.cards)&&i.cards.length>0&&i.cards[0]&&typeof i.cards[0]=="object"&&!Array.isArray(i.cards[0])?i.cards[0]:null;if(!g)throw Object.assign(new Error(`Card "${o}" not found`),{statusCode:404});let w=q(g,c);return {status:"success",data:{boardId:e,cardId:o,key:c,exists:w.exists,value:w.value}}}return {requireCardArgs:h,setChatProcessing:R,getChatProcessing:_,setCardMeta:t,getCardMeta:C}}function ee(n){let{boardId:e,boardContexts:a,readCardDefinitions:l,readChatRecords:h,getChatProcessing:R}=n;async function _(){let o=(await Promise.all(a.map(async y=>{try{let u=y.boardAdapter.kvStorageForRef(y.outputsStoreRef),m=await Promise.resolve(u.read("status"));if(m!=null)return m}catch{}return y.notification.status}))).filter(Boolean);if(o.length===0)return null;if(o.length===1)return o[0];let c=[],i=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],g={};for(let y of i)g[y]=0;for(let y of o){let u=y,m=Array.isArray(u.cards)?u.cards:[];c.push(...m);for(let b of i)g[b]+=Number(u?.summary?.[b]||0);}let w=o[0];return {...w,cards:c,summary:{...w.summary||{},card_count:c.length,...g}}}async function t(){let o={},c=async i=>{try{let g=await i.boardOps.getAllOutputsComputedValues({});if(g.status==="success"&&g.data&&typeof g.data=="object"){for(let[w,y]of Object.entries(g.data)){let u=i.notification.cards[w];o[w]={schema_version:"v1",card_id:w,card_data:u?.card_data??{},computed_values:y??{}};}return}}catch{}for(let[g,w]of Object.entries(i.notification.computedValues)){let y=i.notification.cards[g];o[g]={schema_version:"v1",card_id:g,card_data:y?.card_data??{},computed_values:w??{}};}};for(let i of a)await c(i);return o}async function C(){let o={};for(let c of a){try{let i=await c.boardOps.getAllOutputsDataObjects({});if(i.status==="success"&&i.data&&typeof i.data=="object"){Object.assign(o,i.data);continue}}catch{}Object.assign(o,c.notification.dataObjects||{});}return o}async function p(){let o=await l(),c=await t(),i=await C(),g={};for(let y of o){if(!y?.id)continue;let u=y.id,m=c[u]||{},b={...m.card_data&&typeof m.card_data=="object"?m.card_data:y.card_data&&typeof y.card_data=="object"?y.card_data:{}};g[u]={schema_version:m.schema_version||"v1",card_id:m.card_id||u,card_data:b,computed_values:m.computed_values&&typeof m.computed_values=="object"?m.computed_values:{}};}let w={};for(let y of o){if(!y?.id)continue;let u=y.id;try{let m=h(u),b=R(u);(m.length>0||b)&&(w[u]={messages:m.map(v=>({role:String(v.role||"system"),text:String(v.text||""),files:Array.isArray(v.files)?v.files:[]})),receiving:!1,processing:b});}catch{}}return {boardId:e,cardDefinitions:o,statusSnapshot:await _(),dataObjectsByToken:i,cardRuntimeById:g,cardChatsByCardId:w}}return {readStatusSnapshot:_,readCardRuntimeArtifacts:t,readDataObjectsByToken:C,buildPublishedRuntimePayload:p}}function W(n){let e=String(n||"").trim();if(!e)return "upload.bin";let a=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (a>=0?e.slice(a+1):e)||"upload.bin"}function re(n){let{safeCardId:e,artifactsStores:a,cardFileMetadataStore:l,readCardFromStore:h,updateCardLocalOnly:R,writeChatRecord:_}=n;async function t(o){let c=[];try{let i=await h(o);if(!i)return c;let g=l().read(i.card_data&&typeof i.card_data=="object"?i.card_data:null);for(let w of g)c.push(String(w.stored_name??""));}catch{}return c}async function C(o,c,i,g){let w=e(o),y=a(o),u=W(c),m=await t(o),v=`${String(m.length+1).padStart(3,"0")}-${u}`.slice(-36);return y.files&&await y.files.putBytes(`${w}/${v}`,new Uint8Array(g),i||"application/octet-stream"),{name:u,stored_name:v,size:g.length,mime_type:i||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function p(o,c,i,g,w){if(!g.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let y=w?.inChat===true,u=await C(o,c,i,g),m=null;if(await R(o,b=>{let v=new Date().toISOString(),A=b.card_data&&typeof b.card_data=="object"?b.card_data:{};b.card_data=A;let s=l().normalizeIncoming([{name:u.name,stored_name:u.stored_name,size:u.size,mime_type:u.mime_type,uploaded_at:u.uploaded_at||v,chat:y}],v);return m=l().merge(A,s).findIndex(d=>d.stored_name===u.stored_name),b}),y&&w?.suppressChatRecordWrite!==true){let b=typeof m=="number"&&m>=0?` #${m}`:"";_(o,"system",`file uploaded: ${u.name} as ${u.stored_name}${b}`,[],w?.turnId??"");}return {ok:true,file:{...u,...typeof m=="number"&&m>=0?{file_idx:m}:{},chat:y},...typeof m=="number"&&m>=0?{file_idx:m}:{}}}return {uploadCardFile:p,readCardStoredFileNames:t}}function oe(n){return {"discover.source-kinds":()=>n.discoverSourceKinds(),"inspect.board-runtime-status":()=>n.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>n.inspectCardDefinitionAndRuntime({cardId:chunkLPXVVMQT_cjs.a(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let a=chunkLPXVVMQT_cjs.b(e,"tail_turns"),l=chunkLPXVVMQT_cjs.b(e,"tail"),h=chunkLPXVVMQT_cjs.a(e,"turn_id"),R=e.all_turns===true,_=chunkLPXVVMQT_cjs.a(e,"tail_turns_before_id");return n.inspectChatMessagesOnCards({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),...a!==void 0?{lastUserTurns:a}:{},...l!==void 0?{tail:l}:{},...h?{turnId:h}:{},...R?{allTurns:true}:{},..._?{tailTurnsBeforeId:_}:{}})},"inspect.file-contents":e=>n.inspectFileContents({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),fileIdx:Number(chunkLPXVVMQT_cjs.b(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>n.preflightValidateCandidateCardDefinition({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>n.preflightMaterializeCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockRequires:chunkLPXVVMQT_cjs.d(e,"mock_requires","mock_requires"),mockFetchedSources:chunkLPXVVMQT_cjs.d(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e=>n.preflightProbeSingleSourceInCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockProjections:chunkLPXVVMQT_cjs.c(e,"mock_projections"),sourceIdx:chunkLPXVVMQT_cjs.e(e,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e=>n.preflightRunSingleSourceInCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockProjections:chunkLPXVVMQT_cjs.c(e,"mock_projections"),sourceIdx:chunkLPXVVMQT_cjs.e(e,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e=>n.preflightRunSingleSourceInLiveCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),sourceIdx:chunkLPXVVMQT_cjs.e(e,"source_idx","source_idx"),mockRequires:chunkLPXVVMQT_cjs.d(e,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>n.preflightRunOneCycleWithCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockRequires:chunkLPXVVMQT_cjs.c(e,"mock_requires")}),"manage.read-card":e=>n.manageReadCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let a=chunkLPXVVMQT_cjs.a(e,"turn_id");if(!a)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return n.manageAddChatEntryAndAnyAttachments({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...a?{turn:a}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"manage.upsert-card":e=>n.manageUpsertCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),candidateCardContent:chunkLPXVVMQT_cjs.c(e,"candidate_card_content")}),"manage.remove-card":e=>n.manageRemoveCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id")})}}function se(n){return {"webhook.process-accumulated":()=>n.webhookProcessAccumulated(),"webhook.source-fetch-done":e=>n.webhookSourceFetchDone({token:chunkLPXVVMQT_cjs.a(e,"token"),ref:chunkLPXVVMQT_cjs.a(e,"ref")}),"webhook.source-fetch-failed":e=>n.webhookSourceFetchFailed({token:chunkLPXVVMQT_cjs.a(e,"token"),reason:chunkLPXVVMQT_cjs.a(e,"reason")})}}function de(n){let{boardId:e,uploadCardFile:a,getMcpFacade:l,controlplane:h}=n;function R(t,C){let p=chunkLPXVVMQT_cjs.a(t,"board_id");if(!p)throw Object.assign(new Error(`${C} requires board_id`),{statusCode:400});if(p!==e)throw Object.assign(new Error(`Unknown board_id: ${p}`),{statusCode:400})}function _(t,C){let{cardId:p}=h.requireCardArgs(t),o=chunkLPXVVMQT_cjs.a(t,"turn_id");return R(t,C),l().manageAddChatAttachment({cardId:p,role:chunkLPXVVMQT_cjs.a(t,"role")||"user",...o?{turn:o}:{},files:[{file_name:chunkLPXVVMQT_cjs.a(t,"file_name"),content_type:chunkLPXVVMQT_cjs.a(t,"content_type")||"application/octet-stream",...typeof t.text=="string"?{text:t.text}:{},...typeof t.base64=="string"?{base64:t.base64}:{},...Array.isArray(t.bytes)?{bytes:t.bytes}:{}}]})}return {"list-runtime-cards":t=>(R(t,"list-runtime-cards"),l().listRuntimeCards()),"getstate.is-chat-processing":t=>h.getChatProcessing(t),"setstate.chat-processing-started":t=>h.setChatProcessing(t,true),"setstate.chat-processing-done":t=>h.setChatProcessing(t,false),"getstate.card-private":t=>h.getCardMeta(t),"setstate.card-private":t=>h.setCardMeta(t),"manage.upload-card-file":t=>{let C=chunkLPXVVMQT_cjs.a(t,"card_id"),p=chunkLPXVVMQT_cjs.a(t,"file_name"),o=chunkLPXVVMQT_cjs.a(t,"content_type")||"application/octet-stream",c=chunkLPXVVMQT_cjs.f(t);if(R(t,"manage.upload-card-file"),!C)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!p)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!c)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return a(C,p,o,c,{inChat:false})},"manage.add-chat-attachment":t=>_(t,"manage.add-chat-attachment"),"manage.add-chat-attachement":t=>_(t,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":t=>{let{cardId:C}=h.requireCardArgs(t),p=chunkLPXVVMQT_cjs.a(t,"role")||"user",o=chunkLPXVVMQT_cjs.a(t,"turn_id");return R(t,"manage.add-chat-entry-and-any-attachments"),l().manageAddChatEntryAndAnyAttachments({cardId:C,role:p,...typeof t.text=="string"?{text:t.text}:{},...o?{turn:o}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"manage.patch-card":t=>{let{cardId:C}=h.requireCardArgs(t);return R(t,"manage.patch-card"),l().managePatchCard({cardId:C,patch:chunkLPXVVMQT_cjs.c(t,"patch")})},"manage.upsert-card":t=>{let{cardId:C}=h.requireCardArgs(t);return R(t,"manage.upsert-card"),l().manageUpsertCard({cardId:C,candidateCardContent:chunkLPXVVMQT_cjs.c(t,"candidate_card_content")})},"manage.remove-card":t=>{let{cardId:C}=h.requireCardArgs(t);return R(t,"manage.remove-card"),l().manageRemoveCard({cardId:C})},"manage.admin-read-card":async t=>{let{cardId:C}=h.requireCardArgs(t);return {status:"success",data:{cards:await l().adminReadCard({cardId:C})}}},"manage.admin-upsert-card":t=>{let C=chunkLPXVVMQT_cjs.a(t,"board_id"),p=chunkLPXVVMQT_cjs.a(t,"card_id");if(!C)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!p)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(C!==e)throw Object.assign(new Error(`Unknown board_id: ${C}`),{statusCode:400});return l().adminUpsertCard({cardId:p,candidateCardContent:chunkLPXVVMQT_cjs.c(t,"candidate_card_content")})}}}function pe(n){let{boardContexts:e,cardOwnerIndex:a,cardContextForCard:l,readStatusSnapshot:h,readDataObjectsByToken:R,readCardRuntimeArtifacts:_,readCardFromStore:t,readCardDefinitions:C,processAccumulatedLaneInternal:p,reportSourceFetched:o,reportSourceFetchFailure:c,uploadCardFile:i,chatStorePublic:g,serverUrl:w,apiBasePath:y}=n;function u(){return e[0]??null}function m(){return {async status(){let s=await h();return s==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:s}},async getOutputsDataObject(s){let r=s?.params?.key;return r?{status:"success",data:(await R())[r]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(s){let r=s?.params?.key;return r?{status:"success",data:(await _())[r]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(s){let r=s?.params?.key;if(!r)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let d=l(r)??u();return d?d.boardOps.getOutputsFetchedSources({params:{key:r}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(s){let r=s?.params?.id;if(!r)return {status:"fail",error:"removeCard requires params.id"};let d=l(r)??u();return d?d.boardOps.removeCard({params:{id:r}}):{status:"fail",error:"Board context is unavailable"}},async cardRefreshedNotify(s){let r=s?.params?.cardId;if(!r)return {status:"fail",error:"cardRefreshedNotify requires params.cardId"};let d=l(r)??u();return d?d.boardOps.cardRefreshedNotify({params:{cardId:r}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(s){let r=s?.params?.cardId;if(!r)return {status:"fail",error:"upsertCard requires params.cardId"};let d=l(r)??u();if(!d)return {status:"fail",error:"Board context is unavailable"};let k=await d.boardOps.upsertCard({params:{cardId:r,restart:s.params.restart===true}});if(k.status!=="success")return k;if(chunkKAWQPLIE_cjs.a(d.boardAdapter)){let x=await p(true);if(x.status!=="success")return x}return k}}}function b(){let s=()=>{let r=u();if(!r?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return r.nonCore};return {describeTaskExecutorCapabilities(r){return s().describeTaskExecutorCapabilities(r)},validateCardPreflight(r){return s().validateCardPreflight(r)},evalCardCompute(r){return s().evalCardCompute(r)},probeSourcePreflight(r){return s().probeSourcePreflight(r)},runSourcePreflight(r){return s().runSourcePreflight(r)},simulateCardCycle(r){return s().simulateCardCycle(r)}}}function v(){return {async get(s){let r=typeof s.params?.id=="string"?s.params.id:void 0;if(r){let d=await t(r);return d?{status:"success",data:{cards:[d]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await C()}}},async set(s){let r=s.body;if(r==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let d=Array.isArray(r)?r:[r];for(let k of d){let x=k,I=typeof x.id=="string"?x.id:"";if(!I)return {status:"fail",error:"each card must have a string `id` field"};let T=a.get(I)??0,L=e[T]??u();if(!L)return {status:"fail",error:"Board context is unavailable"};let N=await L.cardStoreOps.set({body:x});if(N.status!=="success")return N;a.set(I,T);}return {status:"success",data:{count:d.length}}},async del(s){let r=[s.params?.id,...s.body?.ids??[]].filter(d=>typeof d=="string"&&!!d);if(r.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let d of r){let k=l(d)??u();if(!k)return {status:"fail",error:"Board context is unavailable"};let x=await k.cardStoreOps.del({params:{id:d}});if(x.status!=="success")return x;a.delete(d);}return {status:"success",data:{count:r.length}}},async patch(s){let r=typeof s.params?.id=="string"?s.params.id:void 0,d=typeof s.params?.path=="string"?s.params.path:void 0;if(!r||!d)return {status:"fail",error:"patch requires params.id and params.path"};let k=l(r)??u();return k?k.cardStoreOps.patch(s):{status:"fail",error:"Board context is unavailable"}},async appendFiles(s){let r=typeof s.params?.id=="string"?s.params.id:void 0;if(!r)return {status:"fail",error:"appendFiles requires params.id"};let d=l(r)??u();return d?d.cardStoreOps.appendFiles(s):{status:"fail",error:"Board context is unavailable"}}}}function A(){return chunkPBOQ4HYB_cjs.a({board:m(),nonCore:b(),cardStore:v(),chatStore:g,processAccumulated:()=>p(true),sourceFetchDone:({token:s,ref:r})=>o(s,r),sourceFetchFailed:({token:s,reason:r})=>c(s,r),uploadCardFile({cardId:s,fileName:r,contentType:d,bytes:k,suppressChatRecordWrite:x}){return i(s,r,d,k,{inChat:true,...x===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:s,fileIdx:r,storedName:d}){let k=`${w||""}${y}/cards/${encodeURIComponent(s)}/files/${r}`;return d?`${k}?sn=${encodeURIComponent(d)}`:k},readFetchedSourceJsonByRef({cardId:s,ref:r}){let d=l(s)??u();if(!d||chunkKAWQPLIE_cjs.a(d.boardAdapter))return null;let I=d.boardAdapter.resolveBlob(chunkSFVO2LB2_cjs.b(r)).trim();return I?JSON.parse(I):null}})}return {mcpBoardFacade:m,mcpNonCoreFacade:b,mcpCardStoreFacade:v,createMcpFacade:A}}exports.a=H;exports.b=V;exports.c=z;exports.d=B;exports.e=j;exports.f=D;exports.g=q;exports.h=Q;exports.i=ee;exports.j=re;exports.k=oe;exports.l=se;exports.m=de;exports.n=pe;//# sourceMappingURL=chunk-EZENHAVZ.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-EZENHAVZ.cjs.map
|
package/lib/chunk-GL2OHR2E.cjs
DELETED
package/lib/chunk-GYQXDNNI.cjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
'use strict';function P(c){function T(n){let r=typeof n=="number"?n:Number(n);return Number.isInteger(r)&&r>0?r:null}function k(n,r){let t=r;for(let e=n.length-1;e>=0;e-=1)if(n[e]?.role==="user"&&(t-=1,t===0))return n.slice(e);return n}function S(n){return n.some(r=>typeof r?.turn=="string"&&r.turn!=="")}function w(n,r){if(r<=0)return [];if(!S(n))return k(n,r);let t=new Map,e=[];for(let s of n){let u=typeof s?.turn=="string"?s.turn:"";t.has(u)||(t.set(u,[]),e.push(u)),t.get(u).push(s);}return e.slice(Math.max(0,e.length-r)).flatMap(s=>t.get(s)??[])}function o(n){return {status:"success",data:n}}function a(n){return {status:"fail",error:n}}function i(n){return {status:"error",error:n instanceof Error?n.message:String(n)}}function R(n,r="command envelope"){let t=typeof n.cardId=="string"?n.cardId:void 0;if(!n.command)return a(`chat-store: ${r} missing "command"`);if(!t)return a(`chat-store: ${r} missing "cardId"`);if(n.command==="append")return d.append({params:{cardId:t},body:{role:n.role,text:n.text,files:n.files,turn:n.turn}});if(n.command==="read-all")return d.readAll({params:{cardId:t},body:{lastUserTurns:n.lastUserTurns,tailTurns:n.tailTurns,turnId:n.turnId,allTurns:n.allTurns,tailTurnsBeforeId:n.tailTurnsBeforeId}});if(n.command==="read-after")return d.readAfter({params:{cardId:t},body:{cursor:n.cursor??null}});if(n.command==="clear")return d.clear({params:{cardId:t}});if(n.command==="set-processing")return d.setProcessing({params:{cardId:t},body:{active:n.active}});if(n.command==="is-processing")return d.isProcessing({params:{cardId:t}});if(n.command==="get-config")return d.getConfig({params:{cardId:t}});if(n.command==="set-config"){let{command:e,cardId:m,...s}=n;return d.setConfig({params:{cardId:t},body:s})}return a(`chat-store: unknown command "${String(n.command)}"`)}function A(n){if(!Array.isArray(n.commands)||n.commands.length===0)return a('chat-store: command envelope must include a non-empty "commands" array');let r=[];for(let t=0;t<n.commands.length;t+=1){let e=n.commands[t];if(!e||typeof e!="object"||Array.isArray(e))return a(`chat-store: command envelope entry ${t} must be an object`);let m={cardId:n.cardId,...e},s=R(m,`command envelope entry ${t}`);if(s.status!=="success")return s;r.push({index:t,command:String(m.command),data:s.data});}return o({results:r})}let d={append(n){try{let r=n.params?.cardId;if(!r)return a("append requires params.cardId");let t=n.body??{},e=typeof t.role=="string"?t.role:"",m=typeof t.text=="string"?t.text:"",s=Array.isArray(t.files)?t.files:[],u=typeof t.turn=="string"?t.turn:"";if(!e)return a("append requires body.role");let l=c.append(r,e,m,s,u);return o({id:l})}catch(r){return i(r)}},readAll(n){try{let r=n.params?.cardId;if(!r)return a("readAll requires params.cardId");let t=n.body??{},e=typeof t.turnId=="string"?t.turnId:"",m=t.allTurns===!0,s=typeof t.tailTurnsBeforeId=="string"?t.tailTurnsBeforeId:"",u=t.tailTurns===void 0?t.lastUserTurns:t.tailTurns,l=u===void 0?m||e?void 0:1:T(u);if(u!==void 0&&l===null)return a("readAll requires body.tailTurns (positive integer)");let b=c.readAll(r),g=b.filter(f=>!e||String(f.turn||"")===e);if(s){let f=l;if(typeof f!="number"||!Number.isInteger(f)||f<=0)return a("readAll requires body.tailTurns (positive integer) when body.tailTurnsBeforeId is provided");let p=new Map,I=[];for(let C of b){let h=String(C.turn||"");p.has(h)||(p.set(h,[]),I.push(h)),p.get(h).push(C);}let y=I.findIndex(C=>C===s),x=Math.max(0,y-f);return g=(y===-1?[]:I.slice(x,y)).flatMap(C=>p.get(C)??[]),o({records:g})}return o(typeof l=="number"?{records:w(g,l)}:{records:g})}catch(r){return i(r)}},readAfter(n){try{let r=n.params?.cardId;if(!r)return a("readAfter requires params.cardId");let e=(n.body??{}).cursor??null;return o(c.readAfter(r,e))}catch(r){return i(r)}},clear(n){try{let r=n.params?.cardId;return r?(c.clear(r),o({ok:!0})):a("clear requires params.cardId")}catch(r){return i(r)}},setProcessing(n){try{let r=n.params?.cardId;if(!r)return a("setProcessing requires params.cardId");let t=n.body??{};return typeof t.active!="boolean"?a("setProcessing requires body.active (boolean)"):(c.setProcessing(r,t.active),o({ok:!0}))}catch(r){return i(r)}},isProcessing(n){try{let r=n.params?.cardId;return r?o({active:c.isProcessing(r)}):a("isProcessing requires params.cardId")}catch(r){return i(r)}},getConfig(n){try{let r=n.params?.cardId;return r?o({config:c.getConfig(r)}):a("getConfig requires params.cardId")}catch(r){return i(r)}},setConfig(n){try{let r=n.params?.cardId;if(!r)return a("setConfig requires params.cardId");let t=n.body??{};return c.setConfig(r,t),o({ok:!0})}catch(r){return i(r)}},run:R,runBatch:A};return d}exports.a=P;//# sourceMappingURL=chunk-GYQXDNNI.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-GYQXDNNI.cjs.map
|
package/lib/chunk-IPLSRN6P.cjs
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
'use strict';function k(o){if(o==null||typeof o!="object")return JSON.stringify(o);if(Array.isArray(o))return `[${o.map(k).join(",")}]`;let r=o;return `{${Object.keys(r).sort().map(u=>`${JSON.stringify(u)}:${k(r[u])}`).join(",")}}`}function _(o,r){let S=r>>>0;for(let u=0;u<o.length;u++)S^=o.charCodeAt(u),S=Math.imul(S,16777619)>>>0;return S}function K(o){let r=k(o),S=_(r,2166136261),u=_(r,3735928559),h=_(r,19088743),s=_(r,4277009102);return [S,u,h,s].map(i=>i.toString(16).padStart(8,"0")).join("")}function J(o){function r(s){return `${o}:blob:${s}`}let S=new TextEncoder;function u(s){if(typeof btoa=="function"){let i="";for(let n=0;n<s.length;n++)i+=String.fromCharCode(s[n]);return btoa(i)}return ""}function h(s){if(typeof atob=="function"){let i=atob(s),n=new Uint8Array(i.length);for(let a=0;a<i.length;a++)n[a]=i.charCodeAt(a);return n}return new Uint8Array}return {read(s){return globalThis.localStorage.getItem(r(s))},write(s,i){globalThis.localStorage.setItem(r(s),i);},exists(s){return globalThis.localStorage.getItem(r(s))!==null},remove(s){globalThis.localStorage.removeItem(r(s));},readBytes(s){let i=globalThis.localStorage.getItem(r(s));if(i===null)return null;try{let n=JSON.parse(i);if(n&&n.__kind==="bytes-b64"&&typeof n.data=="string")return h(n.data)}catch{}return S.encode(i)},writeBytes(s,i){let n=JSON.stringify({__kind:"bytes-b64",data:u(i)});globalThis.localStorage.setItem(r(s),n);},listKeys(s){let i=r(s??""),n=[];for(let a=0;a<globalThis.localStorage.length;a++){let l=globalThis.localStorage.key(a);l&&l.startsWith(i)&&n.push(l.slice(r("").length));}return n.sort()},stat(s){let i=globalThis.localStorage.getItem(r(s));if(i===null)return null;let n=S.encode(i).byteLength;try{let a=JSON.parse(i);a&&a.__kind==="bytes-b64"&&typeof a.data=="string"&&(n=h(a.data).byteLength);}catch{}return {key:s,size:n}}}}var N=":scratch-marker",C=":scratch-config",A=":scratch:",L=1440*60*1e3,O=720*60*1e3,B=200;function $(o,r){if(!o)return r;let S=o.replace(/[^A-Za-z0-9._-]/g,"_");return S.length>0?S:r}function W(o){let r=`${o}${N}`,S=`${o}${C}`,u=t=>`${o}${A}${t}`,h=t=>`${o}${A}${t}:__ts`,s=globalThis.localStorage.getItem(r)===null;if(s)try{globalThis.localStorage.setItem(r,`scratch-store
|
|
2
|
-
${new Date().toISOString()}`);}catch{}function i(){let t=globalThis.localStorage.getItem(S);if(t===null)return {};try{let e=JSON.parse(t);return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}catch{return {}}}function n(t){try{globalThis.localStorage.setItem(S,JSON.stringify(t));}catch{}}if(s){let t=i();typeof t["retention.lastSweepAt"]!="number"&&(t["retention.lastSweepAt"]=Date.now(),n(t));}function a(){if(globalThis.localStorage.getItem(r)===null)return;let t=i(),e=typeof t["retention.maxAgeMs"]=="number"?t["retention.maxAgeMs"]:L,c=typeof t["retention.sweepIntervalMs"]=="number"?t["retention.sweepIntervalMs"]:O;if(e<=0||c<=0)return;let g=typeof t["retention.lastSweepAt"]=="number"?t["retention.lastSweepAt"]:0,y=Date.now();if(y-g<c)return;t["retention.lastSweepAt"]=y,n(t);let f=y,m=`${o}${A}`,b=[];for(let p=0;p<globalThis.localStorage.length;p++){let w=globalThis.localStorage.key(p);w&&w.startsWith(m)&&!w.endsWith(":__ts")&&b.push(w);}for(let p of b){if(Date.now()-f>B)break;let w=globalThis.localStorage.getItem(`${p}:__ts`),I=w===null?0:Number(w);if(Number.isFinite(I)&&I>0&&y-I>e){try{globalThis.localStorage.removeItem(p);}catch{}try{globalThis.localStorage.removeItem(`${p}:__ts`);}catch{}}}}function l(t,e){let c=$(t,"scratch"),g=$(e,".json"),y=g.startsWith(".")?g:`.${g}`,f=Math.random().toString(36).slice(2,10);return `${c}-${Date.now()}-${f}${y}`}function d(t,e){globalThis.localStorage.setItem(u(t),e),globalThis.localStorage.setItem(h(t),String(Date.now()));}return {read(t){return globalThis.localStorage.getItem(u(t))},write(t,e){d(t,e);try{a();}catch{}},exists(t){return globalThis.localStorage.getItem(u(t))!==null},remove(t){try{globalThis.localStorage.removeItem(u(t));}catch{}try{globalThis.localStorage.removeItem(h(t));}catch{}},readBytes(t){let e=globalThis.localStorage.getItem(u(t));return e===null?null:new TextEncoder().encode(e)},writeBytes(t,e){let c="";for(let g=0;g<e.length;g++)c+=String.fromCharCode(e[g]);d(t,c);try{a();}catch{}},stat(t){let e=globalThis.localStorage.getItem(u(t));if(e===null)return null;let c=globalThis.localStorage.getItem(h(t)),g=c===null?null:Number(c);return {key:t,size:new TextEncoder().encode(e).byteLength,updatedAt:g!==null&&Number.isFinite(g)?new Date(g).toISOString():void 0}},listKeys(t){let e=`${o}${A}`,c=[];for(let g=0;g<globalThis.localStorage.length;g++){let y=globalThis.localStorage.key(g);if(y&&y.startsWith(e)&&!y.endsWith(":__ts")){let f=y.slice(e.length);(!t||f.startsWith(t))&&c.push(f);}}return c.sort()},getUniqueKey(t,e){return l(t,e)},create(t,e,c){let g=l(e,c);d(g,t);try{a();}catch{}return g},keyRef(t){return {kind:"local-storage-scratch",value:t,extra:{prefix:o}}},config:{get(t){return i()[t]??null},set(t,e){let c=i();e==null?delete c[t]:c[t]=e,n(c);}}}}var M=":archive-marker",R=":archive-config",T=":archive:stream:",v=":archive:blob:";function E(o){let r=o.replace(/[^A-Za-z0-9._-]/g,"_");if(!r)throw new Error("Archive segment name cannot be empty after sanitization");return r}function D(o){let r=`${o}${M}`,S=`${o}${R}`,u=n=>`${o}${T}${n}`;if(globalThis.localStorage.getItem(r)===null)try{globalThis.localStorage.setItem(r,`archive-store
|
|
3
|
-
${new Date().toISOString()}`);}catch{}function h(){let n=globalThis.localStorage.getItem(S);if(n===null)return {};try{let a=JSON.parse(n);return a&&typeof a=="object"&&!Array.isArray(a)?a:{}}catch{return {}}}function s(n){try{globalThis.localStorage.setItem(S,JSON.stringify(n));}catch{}}function i(){if(globalThis.localStorage.getItem(r)===null)return;let n=h(),a=typeof n["retention.maxAgeMs"]=="number"?n["retention.maxAgeMs"]:0,l=typeof n["retention.sweepIntervalMs"]=="number"?n["retention.sweepIntervalMs"]:0;if(a<=0||l<=0)return;let d=typeof n["retention.lastSweepAt"]=="number"?n["retention.lastSweepAt"]:0,t=Date.now();if(t-d<l)return;n["retention.lastSweepAt"]=t,s(n);let e=`${o}${T}`;for(let c=0;c<globalThis.localStorage.length;c++){let g=globalThis.localStorage.key(c);if(!g||!g.startsWith(e))continue;let y=globalThis.localStorage.getItem(g);if(y)try{let f=JSON.parse(y),m=f.filter(b=>typeof b.__ts!="number"||t-b.__ts<=a);m.length!==f.length&&globalThis.localStorage.setItem(g,JSON.stringify(m));}catch{}}}return {stream(n){let a=E(n),l=u(a);function d(){let e=globalThis.localStorage.getItem(l);if(!e)return [];try{return JSON.parse(e)}catch{return []}}function t(e){try{globalThis.localStorage.setItem(l,JSON.stringify(e));}catch{}}return {append(e){let c={id:globalThis.crypto.randomUUID(),payload:e,__ts:Date.now()},g=d();g.push(c),t(g);try{i();}catch{}return {id:c.id,payload:c.payload}},readAll(){return d().map(e=>({id:e.id,payload:e.payload}))},readAfter(e){let c=d();if(!e){let m=c.map(b=>({id:b.id,payload:b.payload}));return {entries:m,newCursor:m.length>0?m[m.length-1].id:null}}let g=c.findIndex(m=>m.id===e),f=(g===-1?c:c.slice(g+1)).map(m=>({id:m.id,payload:m.payload}));return {entries:f,newCursor:f.length>0?f[f.length-1].id:e}},clear(){try{globalThis.localStorage.removeItem(l);}catch{}}}},blob(n){let a=E(n),l=J(`${o}${v}${a}`);return {read:d=>l.read(d),write:(d,t)=>{l.write(d,t);try{i();}catch{}},exists:d=>l.exists(d),remove:d=>l.remove(d),readBytes:l.readBytes?d=>l.readBytes(d):void 0,writeBytes:l.writeBytes?(d,t)=>{l.writeBytes(d,t);try{i();}catch{}}:void 0,listKeys:d=>l.listKeys(d),stat:l.stat?d=>l.stat(d):void 0}},listStreams(n){let a=`${o}${T}`,l=[];for(let d=0;d<globalThis.localStorage.length;d++){let t=globalThis.localStorage.key(d);if(!t||!t.startsWith(a))continue;let e=t.slice(a.length);(!n||e.startsWith(n))&&l.push(e);}return l.sort()},listBlobs(n){let a=`${o}${v}`,l=new Set;for(let d=0;d<globalThis.localStorage.length;d++){let t=globalThis.localStorage.key(d);if(!t||!t.startsWith(a))continue;let e=t.slice(a.length),c=e.indexOf(":"),g=c===-1?e:e.slice(0,c);(!n||g.startsWith(n))&&l.add(g);}return Array.from(l).sort()},config:{get(n){return h()[n]??null},set(n,a){let l=h();a==null?delete l[n]:l[n]=a,s(l);}}}}function j(o){function r(S){return `${o}:kv:${S}`}return {read(S){let u=globalThis.localStorage.getItem(r(S));if(u===null)return null;try{return JSON.parse(u)}catch{return null}},write(S,u){globalThis.localStorage.setItem(r(S),JSON.stringify(u));},delete(S){globalThis.localStorage.removeItem(r(S));},listKeys(S){let u=r(S??""),h=[];for(let s=0;s<globalThis.localStorage.length;s++){let i=globalThis.localStorage.key(s);i!==null&&i.startsWith(u)&&h.push(i.slice(r("").length));}return h}}}function H(o){function r(){let u=globalThis.localStorage.getItem(o);if(!u)return [];try{return JSON.parse(u)}catch{return []}}function S(u){globalThis.localStorage.setItem(o,JSON.stringify(u));}return {readAllEntries(){return r()},appendEntry(u){let h=r();h.push(u),S(h);},generateId(){return globalThis.crypto.randomUUID()}}}exports.a=K;exports.b=J;exports.c=W;exports.d=D;exports.e=j;exports.f=H;//# sourceMappingURL=chunk-IPLSRN6P.cjs.map
|
|
4
|
-
//# sourceMappingURL=chunk-IPLSRN6P.cjs.map
|
package/lib/chunk-J6EGN6S4.cjs
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
'use strict';var chunkPBCDDO4V_cjs=require('./chunk-PBCDDO4V.cjs'),chunkJJL5VOQZ_cjs=require('./chunk-JJL5VOQZ.cjs'),chunkU2N6MCD5_cjs=require('./chunk-U2N6MCD5.cjs'),chunkSFVO2LB2_cjs=require('./chunk-SFVO2LB2.cjs'),chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkIXZG74EW_cjs=require('./chunk-IXZG74EW.cjs');async function $e(e,t,a){let u=await e.tryAcquire();if(!u)return false;try{await t();}finally{await u();}return await a?.(),true}function We(e){return chunkPBCDDO4V_cjs.b(e)}function Le(e,t){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,u){return await e.write(a,u),t(u)},removeCard(a){return e.delete(a)},async cardExists(a){return await e.read(a)!==null},defaultCardKey(a){return a}}}function Je(e,t){async function a(){return await e.readIndex()??{}}return {async readCard(u){let p=(await a())[u];return !p||!await e.cardExists(p.key)?null:await e.readCard(p.key)},async readCardKey(u){return (await a())[u]?.key??null},async readAllCards(){let u=[];for(let[p,S]of Object.entries(await a())){if(!await e.cardExists(S.key))continue;let f=await e.readCard(S.key);f?u.push(f):t?.(`[card-store] could not read card "${p}" at key "${S.key}"`);}return u},async readChecksumIndex(){let u={};for(let[p,S]of Object.entries(await a()))u[p]=S.checksum;return u},async changedSince(u){let p=await a(),S=[];for(let[f,l]of Object.entries(p))u[f]!==l.checksum&&S.push(f);for(let f of Object.keys(u))p[f]||S.push(f);return S},async validateUpsert(u,p){let S=await a(),f=S[u],l=Object.entries(S).find(([,k])=>k.key===p);return f&&f.key!==p?{ok:false,error:`Card id "${u}" is already mapped to key "${f.key}", cannot remap to "${p}"`}:l&&l[0]!==u?{ok:false,error:`Key "${p}" is already mapped to card id "${l[0]}", cannot remap to "${u}"`}:{ok:true}},async writeCard(u,p,S){let f=await a(),l=S??f[u]?.key??e.defaultCardKey(u),k=await e.writeCard(l,p);f[u]={key:l,checksum:k,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async patchCard(u,p,S){let f=await a(),l=f[u];if(!l||!await e.cardExists(l.key))throw new Error(`card "${u}" not found`);let k=await e.readCard(l.key);if(!k||typeof k!="object"||Array.isArray(k))throw new Error(`card "${u}" is not patchable`);let v=String(p||"").split(".").filter(Boolean),q=chunkPBCDDO4V_cjs.a(k,v,S),P=await e.writeCard(l.key,q);f[u]={key:l.key,checksum:P,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async removeCard(u){let p=await a(),S=p[u];S&&(await e.removeCard(S.key),delete p[u],await e.writeIndex(p));},readIndex(){return a()}}}function cr(e,t){return chunkJJL5VOQZ_cjs.a(e,t)}function dr(e,t,a){return {blob:e,kv:t,journal:a}}function Se(e){return {messageId:e.id,enqueuedAt:e.enqueuedAt,attempt:e.attempt,request:e.body}}function Xe(e){return typeof e=="string"?e.startsWith("b64:")?chunkSFVO2LB2_cjs.b(e).value:e:e.value}function ie(e){return {async enqueueRequest(t){return (await e.enqueue(t)).id},async leaseRequests(t){return (await e.lease(t)).map(a=>({...Se(a),leaseToken:a.leaseToken,leaseExpiresAt:a.leaseExpiresAt}))},ackRequest(t,a){return e.ack(t,a)},nackRequest(t,a,u){return e.nack(t,a,u)},async peekActive(){return (await e.peekActive()).map(Se)},async peekDeadLetter(){return (await e.peekDeadLetter()).map(t=>({...Se(t),reason:t.reason}))}}}function Qe(e){async function t(a){let u=await e.read(a);return u==null?null:typeof u=="string"?u:JSON.stringify(u)}return {async readTaskExecutorRef(){let a=await t("task-executor");if(a?.trim())return chunkU2N6MCD5_cjs.c(a.trim())},writeTaskExecutorRef(a){return e.write("task-executor",chunkU2N6MCD5_cjs.b(a))},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(a){return e.write("chat-handler-flow",a)},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(a){return e.write("card-store-ref",a)},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(a){return e.write("outputs-store-ref",a)},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(a){return e.write("scratch-store-ref",a)},readArchiveStoreRef(){return t("archive-store-ref")},writeArchiveStoreRef(a){return e.write("archive-store-ref",a)},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(a){return e.write("chat-store-ref",a)},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(a){return e.write("artifacts-store-ref",a)}}}function gr(e){let t,a,u,p=e.callbackTransport,S=e.resolveBlob??(async l=>{let k=await e.blobStorage("").read(l.value);if(k==null)throw new Error(`Blob not found for ref ${l.kind}:${l.value}`);return k});async function f(l,k){if(l.howToRun==="queue-storage"){let v=e.boardWorkerStore??t??(e.queueStorage?ie(e.queueStorage):void 0);return v?(t||(t=v),await v.enqueueRequest({boardId:typeof l.extra?.boardId=="string"?l.extra.boardId:e.boardId,ref:l,args:k}),{dispatched:true}):{dispatched:false,error:"queue-storage dispatch requires queueStorage or boardWorkerStore"}}if(l.howToRun==="http:post"){let v=e.fetch??globalThis.fetch;if(!v)return {dispatched:false,error:"http:post dispatch requires fetch support"};let q=await v(Xe(l.whatToRun),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...k,...l.extra?{extra:l.extra}:{}})});if(!q.ok){let P=await q.text().catch(()=>"");return {dispatched:false,error:`HTTP ${q.status}: ${P}`}}return {dispatched:true}}return {dispatched:false,error:`Unsupported hosted async transport "${l.howToRun}"`}}return {kvStorage:e.kvStorage,kvStorageForRef:e.kvStorageForRef,blobStorage:e.blobStorage,scratchStorage:e.scratchStorage,scratchStorageForRef:e.scratchStorageForRef,archiveFactory:e.archiveFactory,archiveFactoryForRef:e.archiveFactoryForRef,journalStorage:e.journalStorage,boardWorkerStore:()=>{if(!t)if(e.boardWorkerStore)t=e.boardWorkerStore;else if(e.queueStorage)t=ie(e.queueStorage);else throw new Error("Hosted async board adapter requires queueStorage or boardWorkerStore");return t},chatAgentStore:()=>{if(!a)if(e.chatAgentStore)a=e.chatAgentStore;else if(e.chatAgentQueueStorage)a=ie(e.chatAgentQueueStorage);else if(e.boardWorkerStore)a=e.boardWorkerStore;else if(e.queueStorage)a=ie(e.queueStorage);else throw new Error("Hosted async board adapter requires chatAgentStore, chatAgentQueueStorage, queueStorage, or boardWorkerStore");return a},processAccumulatedStore:()=>{if(u||(u=e.processAccumulatedStore??e.processAccumulatedQueueStorage??e.queueStorage),!u)throw new Error("Hosted async board adapter requires processAccumulatedStore, processAccumulatedQueueStorage, or queueStorage");return u},lock:e.lock,get callbackTransport(){return p},set callbackTransport(l){p=l;},dispatchExecution:(l,k)=>e.dispatchExecution?.(l,k)??f(l,k),supportsDirectSourceOutput:e.supportsDirectSourceOutput,resolveBlob:S,hashFn:e.hashFn,genId:e.genId,requestProcessAccumulated:e.requestProcessAccumulated,publishBoardChangeNotifications:e.publishBoardChangeNotifications,warn:e.onWarn}}function C(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function w(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function I(){return new Date().toISOString()}function Ze(e){let t=new TextEncoder().encode(e),a=Array.from(t,u=>String.fromCharCode(u)).join("");return btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Me(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),a=t+"=".repeat((4-t.length%4)%4),u=atob(a),p=Uint8Array.from(u,S=>S.charCodeAt(0));return new TextDecoder().decode(p)}function ue(e){try{let t=JSON.parse(Me(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function er(e){return Ze(JSON.stringify(e))}function He(e){try{let t=JSON.parse(Me(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function rr(e){return chunkJJL5VOQZ_cjs.j(e,chunkJJL5VOQZ_cjs.o,()=>({_sources:{}}))}function tr(e,t){return chunkJJL5VOQZ_cjs.h(e,t)}function nr(e){return chunkJJL5VOQZ_cjs.k(e)}function ar(e,t){return chunkJJL5VOQZ_cjs.i(e,t)}function or(e,t,a,u,p,S){return async f=>{let l=[],k=await a.cardStore.readCard(f.nodeId);if(!k)return "task-initiate-failure";let v=k.id,q=k.card_data??{},P=k.source_defs??[],N=P.filter(s=>s.optionalForCompletionGating!==true),V=await a.cardRuntimeStore.readRuntime(v),K=false,L=async()=>{K&&(await a.cardRuntimeStore.writeRuntime(v,V),K=false);},j=s=>chunkJJL5VOQZ_cjs.p(V._sources[s]),b=(s,i)=>{V._sources[s]=chunkJJL5VOQZ_cjs.p(i),K=true;},$=f.taskState?.executionCount??0;if(V._lastExecutionCount!==$&&(V._sources={},V._lastExecutionCount=$,K=true),f.update){let s=f.update.outputFile;if(s){let i=j(s);if(f.update.failure){let m=f.update.rqt??i.lastRequestedToken??i.queueRequestedToken;m&&b(s,chunkJJL5VOQZ_cjs.s(i,m));}else {let m=f.update.rqt;if(!i.lastCompletedToken||m>i.lastCompletedToken){let h=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,x=h?await a.fetchedSourcesStore.commitSourceData(v,s,h):false;b(s,x?chunkJJL5VOQZ_cjs.r(i,m):chunkJJL5VOQZ_cjs.s(i,m));}}await L();}}let J={};for(let s of P){if(!s.outputFile)continue;let i=await a.fetchedSourcesStore.readSourceData(v,s.outputFile);i!==null&&(J[s.bindTo]=i);}let Q={};for(let[s,i]of Object.entries(f.state??{}))if(i!==null&&typeof i=="object"&&!Array.isArray(i)){let m=i[s];Q[s]=m!==void 0?m:i;}else Q[s]=i;let H={id:v,card_data:{...q},requires:Q,source_defs:P,compute:k.compute};H._sourcesData=J,k.compute&&chunkIXZG74EW_cjs.a.runSync(H,{sourcesData:J}),(p??(()=>{}))(v,H.computed_values??{});let G=chunkIXZG74EW_cjs.a.enrichSourcesSync(Array.isArray(k.source_defs)?k.source_defs:void 0,{card_data:k.card_data,requires:Q}),z={...k,source_defs:Array.isArray(G)?G.map(s=>({...s,boardDir:typeof s.boardDir=="string"&&s.boardDir?s.boardDir:e.value})):G},_=I(),O=f.update?void 0:_,n=N.filter(s=>{let i=s.outputFile;if(typeof i!="string"||!i)return true;let m=j(i);O&&(m={...m,queueRequestedToken:O},b(i,m));let h=m.queueRequestedToken??m.lastRequestedToken??_;return chunkJJL5VOQZ_cjs.q(m,h)==="dispatch"});if(await L(),n.length>0){let s=false,i=_;for(let m of n){let h=m.outputFile;if(typeof h!="string"||!h)continue;let x=j(h),F=x.queueRequestedToken??_;b(h,{...x,lastRequestedToken:F}),i=F,s=true;}return s&&await L(),s&&(l.push({taskKind:"source-fetch",payload:{boardRef:chunkSFVO2LB2_cjs.a(e),enrichedCard:z,callbackToken:f.callbackToken,rqt:i}}),await a.executionRequestStore.appendEntries(t,l)),"task-initiated"}if(N.some(s=>{let i=s.outputFile;if(typeof i!="string"||!i)return false;let m=j(i),h=m.queueRequestedToken??m.lastRequestedToken??_;return chunkJJL5VOQZ_cjs.q(m,h)==="in-flight"}))return "task-initiated";let d=k.provides??[],o={};for(let{bindTo:s,ref:i}of d)o[s]=chunkIXZG74EW_cjs.a.resolve(H,i);return (S??(()=>{}))(o),P.filter(s=>{if(s.optionalForCompletionGating!==true)return false;let i=j(s.outputFile);return !i.lastRequestedToken||!i.lastCompletedToken?true:i.lastCompletedToken<=i.lastRequestedToken}).length>0&&l.push({taskKind:"source-fetch",payload:{boardRef:chunkSFVO2LB2_cjs.a(e),enrichedCard:z,callbackToken:f.callbackToken,rqt:_}}),u(f.nodeId,o),l.length>0&&await a.executionRequestStore.appendEntries(t,l),"task-initiated"}}function Ir(e,t){chunkJJL5VOQZ_cjs.d(t.callbackTransport,"createAsyncBoardLiveCardsPublic");let a=t.callbackTransport,u=t.warn??(()=>{}),p=chunkSFVO2LB2_cjs.a(e),S=null;function f(n){if(n.length!==0)try{return Promise.resolve(t.publishBoardChangeNotifications?.(n)).catch(r=>{u(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${r instanceof Error?r.message:String(r)}`);})}catch(r){u(`[async-board-live-cards-public] publishBoardChangeNotifications failed: ${r instanceof Error?r.message:String(r)}`);return}}let l=()=>Qe(t.kvStorage("config")),k=()=>t.kvStorage("state-snapshot"),v=e.value,q=()=>chunkJJL5VOQZ_cjs.b(chunkJJL5VOQZ_cjs.a(()=>k(),t.hashFn),"v1"),P=async()=>{let n=await l().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e.value} has no outputs store configured.`);return nr(t.kvStorageForRef(n))},N=async()=>{let n=await l().readCardStoreRef();if(!n)throw new Error(`Board at ${e.value} has no card store configured.`);let r=t.kvStorageForRef(n);return Je(Le(We(r),t.hashFn),u)};async function V(){return !!(await q().readSnapshot(v)).values[chunkJJL5VOQZ_cjs.n]}async function K(){let n=await q().readSnapshot(v);if(!n.values[chunkJJL5VOQZ_cjs.n])throw new Error(`Board not initialized at ${e.value}`);return chunkJJL5VOQZ_cjs.w(n.values)}async function L(n,r){let d=await q().commitSnapshot(v,{schemaVersion:"v1",expectedVersion:r,deleteKeys:[],shallowMerge:chunkJJL5VOQZ_cjs.v(n)});if(!d.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${r??"null"} current=${d.currentVersion??"null"}`)}let j=()=>chunkJJL5VOQZ_cjs.c(t.journalStorage());async function b(n){await j().appendEvent(n);}function $(){return tr(t.blobStorage("sources"),n=>t.resolveBlob(n))}async function J(n){let r=await Promise.resolve(t.blobStorage("sources").keyRef?.(n));return r?chunkSFVO2LB2_cjs.a(r):n}async function Q(){let n=ar(t.kvStorage("execution-requests"),async(c,g)=>{let A=c.payload,T=(A.enrichedCard??{}).id??A.cardId??"unknown";await b({type:"task-failed",taskName:T,error:g,timestamp:I()});}),r=rr(t.kvStorage("card-runtime")),d=$(),o=await N(),y=await P(),s=new Map,i=new Map,m=[],h=[],x=[],F=new Map,W=new Set,M={async readRuntime(c){return s.get(c)??await r.readRuntime(c)},async writeRuntime(c,g){s.set(c,g);}},ce={async readSourceData(c,g){let A=`${c}/${g}`;return i.has(A)?i.get(A):await d.readSourceData(c,g)},ingestSourceDataStaged(c,g,A,B){return d.ingestSourceDataStaged(c,g,A,B)},async commitSourceData(c,g,A){let B=`${c}/.staged/${A}/${g}`,T=t.blobStorage("sources"),D=await T.read(B);if(D==null){let X=await T.keyRef?.(B);X&&(D=await t.resolveBlob(X));}if(D==null)return false;let re=`${c}/${g}`,Y=D.trim();try{i.set(re,JSON.parse(Y));}catch{i.set(re,Y);}return m.push({cardId:c,outputFile:g,deliveryToken:A}),true},async hasSource(c,g){let A=`${c}/${g}`;return i.has(A)||await d.hasSource(c,g)},async listSources(c){let g=await d.listSources(c),A=[...i.keys()].filter(B=>B.startsWith(`${c}/`)).map(B=>B.slice(`${c}/`.length));return [...new Set([...g,...A])]}},ke=await K(),Ue=chunkG4XXRHL2_cjs.q(ke.graph),{events:Ge,newCursor:de}=await j().readEntriesAfterCursor(ke.lastDrainedJournalId),Z=Ge,ee=chunkG4XXRHL2_cjs.u(Ue,{handlers:{"card-handler":or(e,de,{cardStore:o,cardRuntimeStore:M,fetchedSourcesStore:ce,executionRequestStore:n},(c,g)=>{Z.push({type:"task-completed",taskName:c,data:g,timestamp:I()});},(c,g)=>{h.push({cardId:c,values:g});},c=>{x.push(c);})},onNodeRemoved:c=>{F.delete(c),s.delete(c),W.add(c);}});for(;Z.length>0;){let c=Z;Z=[];for(let g of c)if(g.type==="task-restart"){let A=await o.readCard(g.taskName);A&&F.set(g.taskName,A);}ee.pushAll(c),await ee.waitForHandlers();}let Re=ee.getState();await ee.dispose({wait:true}),await L({lastDrainedJournalId:de,graph:chunkG4XXRHL2_cjs.p(Re)},(await q().readSnapshot(v)).version);for(let{cardId:c,values:g}of h)await y.writeComputedValues(c,g);for(let c of x)await y.writeDataObjects(c);for(let[c,g]of s)await r.writeRuntime(c,g);for(let c of m)await d.commitSourceData(c.cardId,c.outputFile,c.deliveryToken);let he=chunkJJL5VOQZ_cjs.t(p,Re);await y.writeStatusSnapshot(he);let U=[];for(let{cardId:c,values:g}of h)U.push({kind:"computed_values",cardId:c,values:g});for(let c of x)for(let[g,A]of Object.entries(c))U.push({kind:"data_object",key:g,payload:A});for(let[c,g]of F)U.push({kind:"card_refreshed",cardId:c,card:g});for(let c of W)U.push({kind:"card_removed",cardId:c});U.push({kind:"status",status:he}),await f(U);let le=await l().readTaskExecutorRef();if(!le)return;let ze=t.supportsDirectSourceOutput?.(le)===true;await n.dispatchEntriesForJournalId(de,async c=>{if(c.taskKind!=="source-fetch"){u(`[async-process-accumulated-events] unknown taskKind "${c.taskKind}" \u2014 skipping`);return}let g=c.payload,A=g.enrichedCard?.id??"unknown",B=g.enrichedCard?.source_defs??[];for(let T of B){if(!T.outputFile)continue;let D;if(ze){let X=t.genId(),Ye=`${A}/.staged/${X}/${T.outputFile}`,Ce=await Promise.resolve(t.blobStorage("sources").keyRef?.(Ye));Ce&&(D={ref:chunkSFVO2LB2_cjs.a(Ce),deliveryToken:X,outputFile:T.outputFile,cardId:A});}let re=er({cbk:g.callbackToken,rg:e.value,br:chunkSFVO2LB2_cjs.a(e),cid:A,b:T.bindTo,d:T.outputFile,cs:void 0,rqt:g.rqt,...D?{dt:D.deliveryToken}:{}}),Y=await t.dispatchExecution(le,{source_def:T,base_ref:chunkSFVO2LB2_cjs.a(e),callback:a.createCallback(re),...D?{output:D}:{}});Y.dispatched||await b({type:"task-failed",taskName:A,error:Y.error??"dispatch failed",timestamp:I()});}});}async function H(){try{let n=async()=>{let d=await K(),{events:o}=await j().readEntriesAfterCursor(d.lastDrainedJournalId);o.length>0&&await z();},r=await $e(t.lock,Q,n);return C({ran:r!==!1})}catch(n){return w(n)}}async function G(){return S||(S=H().finally(()=>{S=null;}),S)}async function z(){let n=t.processAccumulatedStore();n.enqueueIfAbsent?await n.enqueueIfAbsent({boardRef:chunkSFVO2LB2_cjs.a(e)},`process-accumulated:${chunkSFVO2LB2_cjs.a(e)}`):await n.enqueue({boardRef:chunkSFVO2LB2_cjs.a(e)}),await t.requestProcessAccumulated?.();}async function _(){let n=t.processAccumulatedStore();for(;;){let r=await n.lease({max:64,visibilityMs:1e3});if(r.length<=0)return;for(let d of r)await n.ack(d.id,d.leaseToken);if(r.length<64)return}}function O(){z();}return {async init(n){try{let r=n.params?.cardStoreRef;if(!r)return R("init requires params.cardStoreRef");let d=n.params?.outputsStoreRef;if(!d)return R("init requires params.outputsStoreRef");await V()||await L({lastDrainedJournalId:"",graph:chunkG4XXRHL2_cjs.p(chunkG4XXRHL2_cjs.a(chunkJJL5VOQZ_cjs.u))},null);let o=l();await o.writeCardStoreRef(r),await o.writeOutputsStoreRef(d);let y=n.params?.scratchStoreRef,s=n.params?.archiveStoreRef,i=n.params?.chatStoreRef,m=n.params?.artifactsStoreRef;y&&await o.writeScratchStoreRef(y),s&&await o.writeArchiveStoreRef(s),i&&await o.writeChatStoreRef(i),m&&await o.writeArtifactsStoreRef(m);let h=n.body??{};return h["task-executor-ref"]&&await o.writeTaskExecutorRef(h["task-executor-ref"]),Object.prototype.hasOwnProperty.call(h,"chat-handler-flow")&&await o.writeChatHandlerFlow(h["chat-handler-flow"]),await(await P()).writeStatusSnapshot(chunkJJL5VOQZ_cjs.t(p,chunkG4XXRHL2_cjs.q((await K()).graph))),C()}catch(r){return w(r)}},async status(n){try{let r=await P(),d=await r.readStatusSnapshot();return d||(d=chunkJJL5VOQZ_cjs.t(p,chunkG4XXRHL2_cjs.q((await K()).graph)),await r.writeStatusSnapshot(d)),C(d)}catch(r){return w(r)}},async getCardStoreRef(n){try{let r=await l().readCardStoreRef();return r?C({storeRef:r}):R(`Board at ${e.value} has no card store configured`)}catch(r){return w(r)}},async getOutputsStoreRef(n){try{let r=await l().readOutputsStoreRef();return r?C({storeRef:r}):R(`Board at ${e.value} has no outputs store configured`)}catch(r){return w(r)}},async getScratchStoreRef(n){try{return C({storeRef:await l().readScratchStoreRef()})}catch(r){return w(r)}},async getArchiveStoreRef(n){try{return C({storeRef:await l().readArchiveStoreRef()})}catch(r){return w(r)}},async getChatStoreRef(n){try{return C({storeRef:await l().readChatStoreRef()})}catch(r){return w(r)}},async getArtifactsStoreRef(n){try{return C({storeRef:await l().readArtifactsStoreRef()})}catch(r){return w(r)}},async getConfig(n){try{let r=n.params?.key;if(!r)return R("getConfig requires params.key");let d=l(),o;switch(r){case "task-executor":o=await d.readTaskExecutorRef()??null;break;case "chat-handler-flow":o=await d.readChatHandlerFlow()??null;break;case "card-store-ref":o=await d.readCardStoreRef();break;case "outputs-store-ref":o=await d.readOutputsStoreRef();break;case "scratch-store-ref":o=await d.readScratchStoreRef();break;case "archive-store-ref":o=await d.readArchiveStoreRef();break;case "chat-store-ref":o=await d.readChatStoreRef();break;case "artifacts-store-ref":o=await d.readArtifactsStoreRef();break;default:return R(`getConfig: unknown key "${r}"`)}return C({value:o})}catch(r){return w(r)}},async getOutputsDataObject(n){try{let r=n.params?.key;return r?C(await(await P()).readDataObject(r)):R("getOutputsDataObject requires params.key")}catch(r){return w(r)}},async getAllOutputsDataObjects(n){try{return C(await(await P()).readAllDataObjects())}catch(r){return w(r)}},async getOutputsComputedValues(n){try{let r=n.params?.key;return r?C(await(await P()).readComputedValues(r)):R("getOutputsComputedValues requires params.key")}catch(r){return w(r)}},async getAllOutputsComputedValues(n){try{return C(await(await P()).readAllComputedValues())}catch(r){return w(r)}},async getOutputsFetchedSources(n){try{let r=n.params?.key;if(!r)return R("getOutputsFetchedSources requires params.key");let d=await $().listSources(r),o={};for(let y of d)o[y]=await J(`${r}/${y}`);return C(o)}catch(r){return w(r)}},async getAllOutputsFetchedSources(n){try{let r=$(),d=await t.blobStorage("sources").listKeys(),o=new Set;for(let s of d){let i=s.indexOf("/");i>0&&!s.includes("/.staged/")&&o.add(s.slice(0,i));}let y={};for(let s of o){let i=await r.listSources(s);if(i.length!==0){y[s]={};for(let m of i)y[s][m]=await J(`${s}/${m}`);}}return C(y)}catch(r){return w(r)}},async addCardFiles(n){try{let r=n.params?.cardId;if(!r)return R("addCardFiles requires params.cardId");let d=await N(),o=await d.readCard(r);if(!o)return R(`card "${r}" not found`);let y=n.body,s=Array.isArray(y)?y:y&&typeof y=="object"&&Array.isArray(y.files)?y.files:y!=null?[y]:null;if(!s||s.length===0)return R("addCardFiles requires a file metadata object, array, or body.files array");let i=o.card_data&&typeof o.card_data=="object"&&!Array.isArray(o.card_data)?o.card_data:{},m=Array.isArray(i.files)?i.files:[],h=[...m,...s],x=s.map((W,M)=>({idx:m.length+M,entry:W}));await d.writeCard(r,{...o,card_data:{...i,files:h}});let F=await this.cardRefreshedNotify({params:{cardId:r}});return F.status!=="success"?F:C({cardId:r,files_added:x,notified:!0})}catch(r){return w(r)}},async cardRefreshedNotify(n){try{let r=n.params?.cardId;if(!r)return R("cardRefreshedNotify requires params.cardId");let d=await(await N()).readCard(r);return d?(await f([{kind:"card_refreshed",cardId:r,card:d}]),C({cardId:r,notified:!0})):R(`Card "${r}" not found in board at ${e.value}`)}catch(r){return w(r)}},async removeCard(n){try{let r=n.params?.id;if(!r)return R("removeCard requires params.id");try{await t.kvStorage("card-upsert").delete(r);}catch{}return await b({type:"task-removal",taskName:r,timestamp:I()}),O(),C()}catch(r){return w(r)}},async retrigger(n){try{let r=n.params?.id;return r?(await b({type:"task-restart",taskName:r,timestamp:I()}),O(),C()):R("retrigger requires params.id")}catch(r){return w(r)}},async processAccumulatedEvents(n){return await _(),G()},async upsertCard(n){try{let r=n.params?.cardId,d=n.params?.all,o=!!n.params?.restart;if(!r&&!d)return R("upsertCard requires --card-id <id> or --all");let y=await N(),s=d?(await y.readAllCards()).map(m=>m.id):[r];for(let m of s)if(!await y.readCard(m))return R(`Card "${m}" not found in board at ${e.value}`);let i=t.kvStorage("card-upsert");for(let m of s){let h=await y.readCard(m);if(!h)continue;let x=chunkJJL5VOQZ_cjs.x(h),F=t.hashFn(x),W=await i.read(m),M=W?.taskConfigHash!==F;if(!(!M&&!o)){if(M){let ce=W?.blobRef??await y.readCardKey(m)??m;await b({type:"task-upsert",taskName:m,taskConfig:x,timestamp:I()}),await i.write(m,{blobRef:ce,taskConfigHash:F,updatedAt:I()});}o&&await b({type:"task-restart",taskName:m,timestamp:I()});}}return O(),C()}catch(r){return w(r)}},async taskFailed(n){try{let r=n.params?.token;if(!r)return R("taskFailed requires params.token");let d=n.params?.error??"unknown error",o=ue(r);return o?(await b({type:"task-failed",taskName:o.taskName,error:d,timestamp:I()}),O(),C()):R("Invalid callback token")}catch(r){return w(r)}},async taskProgress(n){try{let r=n.params?.token;if(!r)return R("taskProgress requires params.token");let d=(n.body??{}).update??{},o=ue(r);return o?(await b({type:"task-progress",taskName:o.taskName,update:d,timestamp:I()}),O(),C()):R("Invalid callback token")}catch(r){return w(r)}},async sourceDataFetched(n){try{let r=n.params?.token,d=n.params?.ref;if(!r)return R("sourceDataFetched requires params.token");if(!d)return R("sourceDataFetched requires params.ref");let o=He(r);if(!o)return R("Invalid source token");let y=$(),s=o.dt||t.genId();o.dt||await y.ingestSourceDataStaged(o.cid,o.d,chunkSFVO2LB2_cjs.b(d),s);let i=ue(o.cbk);return i?(await b({type:"task-progress",taskName:i.taskName,update:{bindTo:o.b,outputFile:o.d,fetchedAt:I(),deliveryToken:s,sourceChecksum:o.cs,rqt:o.rqt},timestamp:I()}),O(),C()):R("Invalid callback token embedded in source token")}catch(r){return w(r)}},async sourceDataFetchFailure(n){try{let r=n.params?.token,d=n.params?.reason??"unknown";if(!r)return R("sourceDataFetchFailure requires params.token");let o=He(r);if(!o)return R("Invalid source token");let y=ue(o.cbk);return y?(await b({type:"task-progress",taskName:y.taskName,update:{bindTo:o.b,outputFile:o.d,failure:!0,reason:d,sourceChecksum:o.cs,rqt:o.rqt},timestamp:I()}),O(),C()):R("Invalid callback token embedded in source token")}catch(r){return w(r)}}}}
|
|
2
|
-
exports.a=$e;exports.b=We;exports.c=Le;exports.d=Je;exports.e=cr;exports.f=dr;exports.g=ie;exports.h=Qe;exports.i=gr;exports.j=Ir;//# sourceMappingURL=chunk-J6EGN6S4.cjs.map
|
|
3
|
-
//# sourceMappingURL=chunk-J6EGN6S4.cjs.map
|
package/lib/chunk-JH37NJGP.js
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import {b as b$1,c as c$1}from'./chunk-XQRNDX4Q.js';import {a,b,c}from'./chunk-BQS3EIEK.js';import {r,a as a$1,p,q,u}from'./chunk-VGT3TRQG.js';import {a as a$3}from'./chunk-JMDHDY6M.js';import {a as a$2}from'./chunk-KBELAKIY.js';function et(e){return typeof e=="string"&&e.trim().length>0}function tt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.selfRef is required`);if(!et(e.howToRun))throw new Error(`${t}: adapter.selfRef.howToRun is required`);if(!et(e.whatToRun))throw new Error(`${t}: adapter.selfRef.whatToRun is required`)}function rt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.callbackTransport is required`);if(typeof e.createCallback!="function")throw new Error(`${t}: adapter.callbackTransport.createCallback is required`)}function jt(e,t="callbackTransport"){return {createCallback(n){let o=e();return tt(o,t),{token:n,via:o}}}}function Ve(e){return jt(()=>e,"createStaticExecutionRefCallbackTransport")}function Qt(e){return Ve({meta:"board-live-cards",howToRun:"http:post",whatToRun:a({kind:"http-url",value:String(e||"").trim()})})}function Zt(e){return Ve({meta:"board-live-cards",howToRun:"in-process-loop",whatToRun:a({kind:"in-process-loop",value:String(e||"").trim()})})}function er(e){return Ve({meta:"board-live-cards",howToRun:"local-node",whatToRun:a({kind:"yaml-flow-cli",value:"board-live-cards-cli.js"}),...e?{extra:{notifyChannel:e}}:{}})}function we(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function qe(e,t){return we(e)?e.then(t):t(e)}function ot(e,t){let n={...e};for(let o of t.deleteKeys)delete n[o];return {...n,...t.shallowMerge}}function rr(e,t){return {readValues(o){let i=e(o);return qe(i.listKeys(),u=>{let c=[...u].sort();if(c.length===0)return {version:null,values:{}};let f={},S=null;for(let y of c){let P=i.read(y);we(P)?S=(S??Promise.resolve()).then(async()=>{f[y]=await P;}):f[y]=P;}return S?S.then(()=>({version:t(f),values:f})):{version:t(f),values:f}})},writeValues(o,i,u){let c=e(o),f=null;for(let S of u){let y=c.delete(S);we(y)&&(f=(f??Promise.resolve()).then(()=>y).then(()=>{}));}for(let[S,y]of Object.entries(i)){let P=c.write(S,y);we(P)&&(f=(f??Promise.resolve()).then(()=>P).then(()=>{}));}return f?f.then(()=>t(i)):t(i)}}}function st(e,t){return {readSnapshot(n){return e.readValues(n)},commitSnapshot(n,o){if(o.schemaVersion!==t)throw new Error(`Unsupported snapshot schema version: ${o.schemaVersion}`);return qe(e.readValues(n),i=>{if(i.version!==o.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:i.version};let u=ot(i.values,o);return qe(e.writeValues(n,u,o.deleteKeys),c=>({ok:true,newVersion:c}))})}}}function nt(e,t){if(!t)return e;let n=e.findIndex(o=>o.id===t);return n===-1?e:e.slice(n+1)}function at(e){return {readEntriesAfterCursor(t){let n=nt(e.readAllEntries(),t);return n.length===0?{events:[],newCursor:t}:{events:n.map(o=>o.event),newCursor:n[n.length-1].id}},pendingCount(t){return nt(e.readAllEntries(),t).length},appendEvent(t){e.appendEntry({id:e.generateId(),event:t});}}}function nr(e){return {appendEvent(t){return e.append(t).then(()=>{})},async readEntriesAfterCursor(t){let n=await e.readAfter(t||null);return {events:n.entries.map(o=>o.payload),newCursor:n.newCursor??t}}}}function xe(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function G(e,t){return xe(e)?e.then(t):t(e)}function Be(e,t){let n=null;for(let o of e){if(n){n=n.then(()=>t(o)).then(()=>{});continue}let i=t(o);xe(i)&&(n=Promise.resolve(i).then(()=>{}));}return n??void 0}function Kt(e){if(e==null)return null;let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{return t}}function Dt(e,t){let n=e.match(t);return n?n[1]:null}function it(e,t,n){let o={},i=Be(e,u=>{let c=n(u);if(c)return G(t(u),f=>{o[c]=f;})});return xe(i)?i.then(()=>o):o}function ut(e,t){let n=o=>G(e.read(o),i=>i??(e.keyRef?G(e.keyRef(o),u=>u?G(t(u),c=>c??null):null):null));return {readSourceData(o,i){return G(e.read(`${o}/${i}`),Kt)},ingestSourceDataStaged(o,i,u,c){return G(t(u),f=>e.write(`${o}/.staged/${c}/${i}`,f))},commitSourceData(o,i,u){let c=`${o}/.staged/${u}/${i}`;return G(n(c),f=>f==null?false:G(e.write(`${o}/${i}`,f),()=>G(e.remove(c),()=>true)))},hasSource(o,i){return e.exists(`${o}/${i}`)},listSources(o){return G(e.listKeys(`${o}/`),i=>i.filter(u=>!u.includes("/.staged/")).map(u=>u.slice(`${o}/`.length)))}}}function dt(e,t){let n=(o,i)=>{try{let u=i(o);return xe(u)?u.catch(c=>t(o,c instanceof Error?c.message:String(c))):void 0}catch(u){try{return t(o,u instanceof Error?u.message:String(u))}catch{return}}};return {appendEntries(o,i){if(!(!o||i.length===0))return G(e.read(o),u=>e.write(o,[...u??[],...i]))},dispatchEntriesForJournalId(o,i){if(o)return G(e.read(o),u=>{let c=u;if(!(!c||c.length===0))return G(Be(c,f=>n(f,i)),()=>e.delete(o))})}}}function ct(e,t,n){return {readRuntime(o){return G(e.read(t(o)),i=>i??n())},writeRuntime(o,i){return e.write(t(o),i)}}}function lt(e){return {writeComputedValues(t,n){return e.write(`cards/${t}/computed_values`,n)},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){return G(e.listKeys("cards/"),t=>it(t,n=>e.read(n),n=>Dt(n,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(t){return Be(Object.entries(t),([n,o])=>{if(n)return e.write(`data-objects/${n}`,o)})},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){return G(e.listKeys("data-objects/"),t=>it(t,n=>e.read(n),n=>n.slice(13)))},writeStatusSnapshot(t){return e.write("status",t)},readStatusSnapshot(){return e.read("status")}}}function je(e,t){function n(){return e.readIndex()??{}}function o(i,u,c){let f=String(u||"").split(".").filter(Boolean);if(f.length===0)return c&&typeof c=="object"&&!Array.isArray(c)?c:{value:c};let S={...i},y=S;for(let P=0;P<f.length-1;P++){let L=f[P],j=y[L],Y=j&&typeof j=="object"&&!Array.isArray(j)?{...j}:{};y[L]=Y,y=Y;}return y[f[f.length-1]]=c,S}return {readCard(i){let u=n()[i];return !u||!e.cardExists(u.key)?null:e.readCard(u.key)},readCardKey(i){return n()[i]?.key??null},readAllCards(){let i=[];for(let[u,c]of Object.entries(n())){if(!e.cardExists(c.key))continue;let f=e.readCard(c.key);f?i.push(f):t?.(`[card-store] could not read card "${u}" at key "${c.key}"`);}return i},readChecksumIndex(){let i={};for(let[u,c]of Object.entries(n()))i[u]=c.checksum;return i},changedSince(i){let u=n(),c=[];for(let[f,S]of Object.entries(u))i[f]!==S.checksum&&c.push(f);for(let f of Object.keys(i))u[f]||c.push(f);return c},validateUpsert(i,u){let c=n(),f=c[i],S=Object.entries(c).find(([,y])=>y.key===u);return f&&f.key!==u?{ok:false,error:`Card id "${i}" is already mapped to key "${f.key}", cannot remap to "${u}"`}:S&&S[0]!==i?{ok:false,error:`Key "${u}" is already mapped to card id "${S[0]}", cannot remap to "${i}"`}:{ok:true}},writeCard(i,u,c){let f=n(),S=c??f[i]?.key??e.defaultCardKey(i),y=e.writeCard(S,u);f[i]={key:S,checksum:y,updatedAt:new Date().toISOString()},e.writeIndex(f);},patchCard(i,u,c){let f=n(),S=f[i];if(!S||!e.cardExists(S.key))throw new Error(`card "${i}" not found`);let y=e.readCard(S.key);if(!y||typeof y!="object"||Array.isArray(y))throw new Error(`card "${i}" is not patchable`);let P=o(y,u,c),L=e.writeCard(S.key,P);f[i]={key:S.key,checksum:L,updatedAt:new Date().toISOString()},e.writeIndex(f);},removeCard(i){let u=n(),c=u[i];c&&(e.removeCard(c.key),delete u[i],e.writeIndex(u));},readIndex(){return n()}}}function Te(e,t){return ut(e,t)}function gt(e){return at(e)}function kt(e,t){return dt(e,t)}var Ee="v1",le="board/graph",St="board/lastJournalProcessedId";function Lt(e){return `cards/${e}/runtime`}function ht(e){return ct(e,Lt,()=>({_sources:{}}))}function yt(e){return st(e,Ee)}function Ke(e){function t(n){let o=e.read(n);return o==null?null:typeof o=="string"?o:JSON.stringify(o)}return {readTaskExecutorRef(){let n=t("task-executor");if(n?.trim())return c$1(n.trim())},writeTaskExecutorRef(n){e.write("task-executor",b$1(n));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(n){e.write("chat-handler-flow",n);},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(n){e.write("card-store-ref",n);},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(n){e.write("outputs-store-ref",n);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(n){e.write("scratch-store-ref",n);},readArchiveStoreRef(){return t("archive-store-ref")},writeArchiveStoreRef(n){e.write("archive-store-ref",n);},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(n){e.write("chat-store-ref",n);},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(n){e.write("artifacts-store-ref",n);}}}function Ct(e){return lt(e)}function pt(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function Nt(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function ft(e,t){return e?.lastRequestedToken?Nt(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function $t(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function mt(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function Ae(e,t){let n=t.state.tasks,o=t.config.tasks,i=Object.keys(n),u=r(t),c={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},f=new Map;for(let v of u.pending)f.set(v.taskName,v.waitingOn);for(let v of u.unresolved)f.set(v.taskName,v.missingTokens);for(let v of u.blocked)f.set(v.taskName,v.failedTokens);let S=new Map;for(let[v,l]of Object.entries(o))for(let a of l.requires??[]){let d=S.get(a)??[];d.push(v),S.set(a,d);}let y=i.sort().map(v=>{let l=n[v],a=o[v]??{requires:[],provides:[]};l.status==="completed"?c.completed+=1:l.status==="failed"?c.failed+=1:l.status==="in-progress"&&(c.in_progress+=1);let d=a.requires??[],C=a.provides??[],A=Object.keys(l.data??{}).sort(),E=d.filter(M=>t.state.availableOutputs.includes(M)),_=d.filter(M=>!t.state.availableOutputs.includes(M)),F=f.get(v)??_,V=new Set;for(let M of C)for(let $ of S.get(M)??[])$!==v&&V.add($);let N=l.failedAt,D=l.error?{message:l.error,code:"TASK_FAILED",at:N,source:"task-runtime"}:void 0;return {name:v,status:l.status,error:D,requires:d,requires_satisfied:E,requires_missing:_,provides_declared:C,provides_runtime:A,blocked_by:F,unblocks:Array.from(V).sort(),runtime:{attempt_count:l.executionCount??0,restart_count:l.retryCount??0,in_progress_since:l.status==="in-progress"?l.startedAt??null:null,last_transition_at:l.lastUpdated??null,last_completed_at:l.completedAt??null,last_restarted_at:l.startedAt??null,status_age_ms:l.lastUpdated?0:null}}});c.pending=u.pending.length,c.blocked=u.blocked.length,c.unresolved=u.unresolved.length;let P=y.map(v=>({name:v.name,fanOut:v.unblocks.length})).sort((v,l)=>l.fanOut-v.fanOut||v.name.localeCompare(l.name)),L=P.length>0?P[0]:{name:null,fanOut:0},j=new Set;for(let v of Object.values(o))for(let l of v.requires??[])j.add(l);let Y=0;for(let[v,l]of Object.entries(o)){let a=(l.requires??[]).length===0,C=(l.provides??[]).some(A=>(S.get(A)??[]).some(E=>E!==v));a&&!C&&(Y+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:i.length,completed:c.completed,eligible:u.eligible.length,pending:c.pending,blocked:c.blocked,unresolved:c.unresolved,failed:c.failed,in_progress:c.in_progress,orphan_cards:Y,topology:{edge_count:Array.from(j).length,max_fan_out_card:L.name,max_fan_out:L.fanOut}},cards:y}}function Jt(){return new Date().toISOString()}function Rt(e,t,n,o,i,u,c){return async f=>{let S=[],y=n.cardStore.readCard(f.nodeId);if(!y)return "task-initiate-failure";let P=y.id,L=y.card_data??{},j=y.source_defs??[],Y=j.filter(b=>b.optionalForCompletionGating!==true),v=n.cardRuntimeStore.readRuntime(P),l=false,a$1=()=>{l&&(n.cardRuntimeStore.writeRuntime(P,v),l=false);},d=b=>pt(v._sources[b]),C=(b,k)=>{v._sources[b]=pt(k),l=true;},A=f.taskState?.executionCount??0;if(v._lastExecutionCount!==A&&(v._sources={},v._lastExecutionCount=A,l=true),f.update){let b=f.update,k=b.outputFile;if(k){let w=d(k);if(b.failure){let B=b.rqt??w.lastRequestedToken??w.queueRequestedToken;B&&C(k,mt(w,B));}else {let B=b.rqt;if(!w.lastCompletedToken||B>w.lastCompletedToken){let H=typeof b.deliveryToken=="string"?b.deliveryToken:void 0,Z=false;H&&(Z=n.fetchedSourcesStore.commitSourceData(P,k,H)),Z?C(k,$t(w,B)):C(k,mt(w,B));}}a$1();}}let _={};for(let b of j)if(b.outputFile){let k=n.fetchedSourcesStore.readSourceData(P,b.outputFile);k!==null&&(_[b.bindTo]=k);}let F={};for(let[b,k]of Object.entries(f.state??{}))if(k!==null&&typeof k=="object"&&!Array.isArray(k)){let w=k[b];F[b]=w!==void 0?w:k;}else F[b]=k;let V={id:P,card_data:{...L},requires:F,source_defs:j,compute:y.compute};V._sourcesData=_,y.compute&&a$3.runSync(V,{sourcesData:_}),(u??n.outputStore.writeComputedValues.bind(n.outputStore))(P,V.computed_values??{});let N={...y},D=a$3.enrichSourcesSync(Array.isArray(y.source_defs)?y.source_defs:void 0,{card_data:y.card_data,requires:F}),M=e.value;N.source_defs=Array.isArray(D)?D.map(b=>({...b,boardDir:typeof b.boardDir=="string"&&b.boardDir?b.boardDir:M})):D;let $=Jt(),oe=f.update?void 0:$,se=Y.filter(b=>{let k=b.outputFile;if(typeof k!="string"||!k)return true;let w=d(k);oe&&(w={...w,queueRequestedToken:oe},C(k,w));let B=w.queueRequestedToken??w.lastRequestedToken??$,H=ft(w,B);return H==="in-flight"?false:H==="dispatch"});if(a$1(),se.length>0){let b=false,k=$;for(let w of se){let B=w.outputFile;if(typeof B!="string"||!B)continue;let H=d(B),Z=H.queueRequestedToken??$;C(B,{...H,lastRequestedToken:Z}),k=Z,b=true;}return b&&a$1(),b&&(S.push({taskKind:"source-fetch",payload:{boardRef:a(e),enrichedCard:N,callbackToken:f.callbackToken,rqt:k}}),n.executionRequestStore.appendEntries(t,S)),"task-initiated"}if(Y.some(b=>{let k=b.outputFile;if(typeof k!="string"||!k)return false;let w=d(k),B=w.queueRequestedToken??w.lastRequestedToken??$;return ft(w,B)==="in-flight"}))return "task-initiated";let ae=y.provides??[],ie={};for(let{bindTo:b,ref:k}of ae)ie[b]=a$3.resolve(V,k);return (c??n.outputStore.writeDataObjects.bind(n.outputStore))(ie),j.filter(b=>{if(b.optionalForCompletionGating!==true)return false;let k=d(b.outputFile);return !k.lastRequestedToken||!k.lastCompletedToken?true:k.lastCompletedToken<=k.lastRequestedToken}).length>0&&S.push({taskKind:"source-fetch",payload:{boardRef:a(e),enrichedCard:N,callbackToken:f.callbackToken,rqt:$}}),o(f.nodeId,ie),S.length>0&&n.executionRequestStore.appendEntries(t,S),"task-initiated"}}var De={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function bt(e){return {[le]:e.graph,[St]:e.lastDrainedJournalId}}function vt(e){let t=e[le],n=e[St];if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${le}`);return {graph:t,lastDrainedJournalId:typeof n=="string"?n:""}}function wt(e){let t=e.requires;return {provides:e.provides?.map(o=>o.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...t&&t.length>0?{requires:t}:{}}}function T(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function I(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function Mt(e){let t=new TextEncoder().encode(e),n=Array.from(t,o=>String.fromCharCode(o)).join("");return btoa(n).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Tt(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),n=t+"=".repeat((4-t.length%4)%4),o=atob(n),i=Uint8Array.from(o,u=>u.charCodeAt(0));return new TextDecoder().decode(i)}function Ie(e){try{let t=JSON.parse(Tt(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function Ht(e){return Mt(JSON.stringify(e))}function xt(e){try{let t=JSON.parse(Tt(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function U(){return new Date().toISOString()}function Cr(e,t){rt(t.callbackTransport,"createBoardLiveCardsPublic");let n=t.callbackTransport,o=t.onWarn??(()=>{}),i=a(e);function u$1(s){if(s.length!==0)try{let r=t.publishBoardChangeNotifications?.(s);r&&typeof r.catch=="function"&&r.catch(p=>o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${p instanceof Error?p.message:String(p)}`));}catch(r){o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${r instanceof Error?r.message:String(r)}`);}}function c$1(){let s=S().readCardStoreRef();if(!s)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let r=t.kvStorageForRef(s);return {readIndex(){return r.read("_index")},writeIndex(p){r.write("_index",p);},readCard(p){return r.read(p)},writeCard(p,g){return r.write(p,g),t.hashFn(g)},removeCard(p){r.delete(p);},cardExists(p){return r.read(p)!==null},defaultCardKey(p){return p}}}let f={readValues(s){let r=t.kvStorage("state-snapshot"),p=r.listKeys().sort();if(p.length===0)return {version:null,values:{}};let g={};for(let x of p)g[x]=r.read(x);return {version:t.hashFn(g),values:g}},writeValues(s,r,p){let g=t.kvStorage("state-snapshot");for(let x of p)g.delete(x);for(let[x,O]of Object.entries(r))g.write(x,O);return t.hashFn(r)}},S=()=>Ke(t.kvStorage("config")),y=()=>yt(f),P=()=>gt(t.journalAdapter()),L=()=>je(c$1(),o),j=()=>{let s=S().readOutputsStoreRef();if(!s)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return Ct(t.kvStorageForRef(s))},Y=()=>{let s=S().readArchiveStoreRef();return s?t.archiveFactoryForRef(s):t.archiveFactory()};function v(){return !!y().readSnapshot(e.value).values[le]}function l(){let s=y().readSnapshot(e.value);if(!s.values[le])throw new Error(`Board not initialized at ${e.value}`);return vt(s.values)}function a$3(s,r){let p=y().commitSnapshot(e.value,{schemaVersion:Ee,expectedVersion:r,commitId:t.genId(),committedAt:U(),deleteKeys:[],shallowMerge:bt(s)});if(!p.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${r??"null"} current=${p.currentVersion??"null"}`)}function d(s){P().appendEvent(s);}async function C(){let s=(m,h)=>{let q=m.payload,z=(q?.enrichedCard??{}).id??q?.cardId??"unknown";d({type:"task-failed",taskName:z,error:h,timestamp:U()});},r=kt(t.kvStorage("execution-requests"),s),p$1=ht(t.kvStorage("card-runtime")),g=Te(t.blobStorage("sources"),m=>t.resolveBlob(m)),x=new Map,O={readRuntime(m){return x.get(m)??p$1.readRuntime(m)},writeRuntime(m,h){x.set(m,h);}},X=[],K=new Map,Q={readSourceData(m,h){let q=`${m}/${h}`;return K.has(q)?K.get(q):g.readSourceData(m,h)},ingestSourceDataStaged(m,h,q,re){g.ingestSourceDataStaged(m,h,q,re);},commitSourceData(m,h,q){let re=`${m}/.staged/${q}/${h}`,z=t.blobStorage("sources"),ee=z.read(re);if(ee==null){let be=z.keyRef?.(re);be&&(ee=t.resolveBlob(be));}if(ee==null)return false;let Re=`${m}/${h}`,ne=ee.trim();try{K.set(Re,JSON.parse(ne));}catch{K.set(Re,ne);}return X.push({cardId:m,outputFile:h,deliveryToken:q}),true},hasSource(m,h){let q=`${m}/${h}`;return K.has(q)?true:g.hasSource(m,h)},listSources(m){let h=g.listSources(m),q=new Set;for(let z of K.keys())z.startsWith(`${m}/`)&&q.add(z.slice(`${m}/`.length));let re=new Set([...h,...q]);return Array.from(re)}},W={cardStore:L(),cardRuntimeStore:O,fetchedSourcesStore:Q,outputStore:j(),executionRequestStore:r},ue=l(),fe=q(ue.graph),{events:me,newCursor:ge}=P().readEntriesAfterCursor(ue.lastDrainedJournalId),de=[],he=[],_e=[],Fe=new Map,$e=new Set,Vt=(m,h)=>{de.push({type:"task-completed",taskName:m,data:h,timestamp:U()});try{Y().stream("exec-history").append({taskName:m,status:"completed",completedAt:U()});}catch{}},Je=(m,h)=>{d({type:"task-failed",taskName:m,error:h,timestamp:U()});try{Y().stream("exec-history").append({taskName:m,status:"failed",error:h,completedAt:U()});}catch{}},ye=u(fe,{handlers:{"card-handler":Rt(e,ge,W,Vt,Je,(m,h)=>{he.push({cardId:m,values:h});},m=>{_e.push(m);})},onNodeRemoved:m=>{Fe.delete(m),x.delete(m),$e.add(m);}});for(de=me;de.length>0;){let m=de;de=[];for(let h of m)if(h.type==="task-restart"){let q=W.cardStore.readCard(h.taskName);q&&Fe.set(h.taskName,q);}ye.pushAll(m),await ye.waitForHandlers();}let Me=ye.getState();await ye.dispose({wait:true});let qt=y().readSnapshot(e.value).version;a$3({lastDrainedJournalId:ge,graph:p(Me)},qt);for(let{cardId:m,values:h}of he)W.outputStore.writeComputedValues(m,h);for(let m of _e)W.outputStore.writeDataObjects(m);for(let[m,h]of x)p$1.writeRuntime(m,h);for(let{cardId:m,outputFile:h,deliveryToken:q}of X)g.commitSourceData(m,h,q);let Ce;try{Ce=Ae(i,Me),W.outputStore.writeStatusSnapshot(Ce);}catch(m){o(`[board-live-cards-public] status publish failed: ${m instanceof Error?m.message:String(m)}`);}let ke=[];for(let{cardId:m,values:h}of he)ke.push({kind:"computed_values",cardId:m,values:h});for(let m of _e)for(let[h,q]of Object.entries(m))h&&ke.push({kind:"data_object",key:h,payload:q});for(let[m,h]of Fe)ke.push({kind:"card_refreshed",cardId:m,card:h});for(let m of $e)ke.push({kind:"card_removed",cardId:m});Ce!==void 0&&ke.push({kind:"status",status:Ce}),u$1(ke);let He=S().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:a({kind:"built-in",value:"source-cli-task-executor"})},Bt=t.supportsDirectSourceOutput?.(He)===true;r.dispatchEntriesForJournalId(ge,m=>{if(m.taskKind!=="source-fetch"){o(`[process-accumulated-events] unknown taskKind "${m.taskKind}" \u2014 skipping`);return}let h=m.payload,q=h.enrichedCard?.id??"unknown",re=h.enrichedCard?.source_defs??[];for(let z of re){if(!z.outputFile){o(`[dispatch] source "${z.bindTo}" has no outputFile \u2014 skipping`);continue}let ee;if(Bt){let ne=t.genId(),be=`${q}/.staged/${ne}/${z.outputFile}`,Ge=t.blobStorage("sources").keyRef?.(be);Ge?ee={ref:a(Ge),deliveryToken:ne,outputFile:z.outputFile,cardId:q}:o("[dispatch] hosted board-worker requested but sources BlobStorage cannot produce portable refs; falling back to scratch protocol");}let Re=Ht({cbk:h.callbackToken,rg:e.value,br:a(e),cid:q,b:z.bindTo,d:z.outputFile,cs:void 0,rqt:h.rqt,...ee?{dt:ee.deliveryToken}:{}});t.dispatchExecution(He,{source_def:z,base_ref:a(e),callback:n.createCallback(Re),...ee?{output:ee}:{}}).catch(ne=>Je(q,ne instanceof Error?ne.message:String(ne)));}});}function A(){let s=t.processAccumulatedStore();s.enqueueIfAbsent?s.enqueueIfAbsent({boardRef:a(e)},`process-accumulated:${a(e)}`):s.enqueue({boardRef:a(e)}),t.requestProcessAccumulated?.();}function E(){let s=t.processAccumulatedStore();for(;;){let r=s.lease({max:64,visibilityMs:1e3});if(r.length<=0)return;for(let p of r)s.ack(p.id,p.leaseToken);if(r.length<64)return}}async function _(){try{let s=()=>{let p=l(),{events:g}=P().readEntriesAfterCursor(p.lastDrainedJournalId);g.length<=0||A();},r=await c(t.lock,C,s);return T({ran:r!==!1})}catch(s){return I(s)}}function F(){A();}function V(s){try{let r=s.params?.cardStoreRef;if(!r)return R("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!v()){let W=a$1(De);a$3({lastDrainedJournalId:"",graph:p(W)},null);}let p$1=s.params?.outputsStoreRef;if(!p$1)return R("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let g=s.params?.scratchStoreRef,x=s.params?.archiveStoreRef,O=s.params?.chatStoreRef,X=s.params?.artifactsStoreRef,K=S();K.writeCardStoreRef(r),K.writeOutputsStoreRef(p$1),g&&K.writeScratchStoreRef(g),x&&K.writeArchiveStoreRef(x),O&&K.writeChatStoreRef(O),X&&K.writeArtifactsStoreRef(X);let Q=s.body??{};Q["task-executor-ref"]&&K.writeTaskExecutorRef(Q["task-executor-ref"]),Object.prototype.hasOwnProperty.call(Q,"chat-handler-flow")&&K.writeChatHandlerFlow(Q["chat-handler-flow"]);try{j().writeStatusSnapshot(Ae(i,q(l().graph)));}catch{}return T()}catch(r){return I(r)}}function N(s){try{let r=j().readStatusSnapshot();if(!r){r=Ae(i,q(l().graph));try{j().writeStatusSnapshot(r);}catch{}}return T(r)}catch(r){return I(r)}}function D(s){try{let r=s.params?.id;if(!r)return R("removeCard requires params.id");try{t.kvStorage("card-upsert").delete(r);}catch{}return d({type:"task-removal",taskName:r,timestamp:U()}),F(),T()}catch(r){return I(r)}}function M(s){try{let r=s.params?.cardId;if(!r)return R("addCardFiles requires params.cardId");let p=a$2(L()).appendFiles({params:{id:r},body:s.body});if(p.status!=="success")return p;let g=$({params:{cardId:r}});return g.status!=="success"?g:T({cardId:r,files_added:p.data.files_added,notified:!0})}catch(r){return I(r)}}function $(s){try{let r=s.params?.cardId;if(!r)return R("cardRefreshedNotify requires params.cardId");let p=L().readCard(r);return p?(u$1([{kind:"card_refreshed",cardId:r,card:p}]),T({cardId:r,notified:!0})):R(`Card "${r}" not found in board at ${e.value}`)}catch(r){return I(r)}}function oe(s){try{let r=s.params?.id;return r?(d({type:"task-restart",taskName:r,timestamp:U()}),F(),T()):R("retrigger requires params.id")}catch(r){return I(r)}}async function se(s){return E(),_()}function Se(s){try{let r=s.params?.cardId,p=s.params?.all,g=!!s.params?.restart;if(!r&&!p)return R("upsertCard requires --card-id <id> or --all");let x=p?L().readAllCards().map(O=>O.id):[r];for(let O of x)if(!L().readCard(O))return R(`Card "${O}" not found in board at ${e.value}`);for(let O of x){let X=L().readCard(O),K=wt(X),Q=t.hashFn(K),W=t.kvStorage("card-upsert"),ue=W.read(O),fe=ue?.taskConfigHash!==Q;if(!(!fe&&!g)){if(fe){let me=ue?.blobRef??L().readCardKey(O)??O;d({type:"task-upsert",taskName:O,taskConfig:K,timestamp:U()}),W.write(O,{blobRef:me,taskConfigHash:Q,updatedAt:U()});}g&&d({type:"task-restart",taskName:O,timestamp:U()});}}return F(),T()}catch(r){return I(r)}}function ae(s){try{let r=s.params?.token;if(!r)return R("taskFailed requires params.token");let p=s.params?.error??"unknown error",g=Ie(r);if(!g)return R("Invalid callback token");d({type:"task-failed",taskName:g.taskName,error:p,timestamp:U()});try{Y().stream("exec-history").append({taskName:g.taskName,status:"failed",error:p,completedAt:U()});}catch{}return F(),T()}catch(r){return I(r)}}function ie(s){try{let r=s.params?.token;if(!r)return R("taskProgress requires params.token");let g=(s.body??{}).update??{},x=Ie(r);return x?(d({type:"task-progress",taskName:x.taskName,update:g,timestamp:U()}),F(),T()):R("Invalid callback token")}catch(r){return I(r)}}function pe(s){try{let r=s.params?.token,p=s.params?.ref;if(!r)return R("sourceDataFetched requires params.token");if(!p)return R("sourceDataFetched requires params.ref");let g=xt(r);if(!g)return R("Invalid source token");let{cbk:x,cid:O,b:X,d:K,cs:Q,rqt:W,dt:ue}=g,fe=Te(t.blobStorage("sources"),he=>t.resolveBlob(he)),me=ue||t.genId();ue||fe.ingestSourceDataStaged(O,K,b(p),me);let ge=Ie(x);if(!ge)return R("Invalid callback token embedded in source token");let de=U();return d({type:"task-progress",taskName:ge.taskName,update:{bindTo:X,outputFile:K,fetchedAt:de,deliveryToken:me,sourceChecksum:Q,rqt:W},timestamp:de}),F(),T()}catch(r){return I(r)}}function b$1(s){try{let r=s.params?.token,p=s.params?.reason??"unknown";if(!r)return R("sourceDataFetchFailure requires params.token");let g=xt(r);if(!g)return R("Invalid source token");let{cbk:x,b:O,d:X,cs:K,rqt:Q}=g,W=Ie(x);return W?(d({type:"task-progress",taskName:W.taskName,update:{bindTo:O,outputFile:X,failure:!0,reason:p,sourceChecksum:K,rqt:Q},timestamp:U()}),F(),T()):R("Invalid callback token embedded in source token")}catch(r){return I(r)}}function k(s){try{let r=S().readCardStoreRef();return r?T({storeRef:r}):R(`Board at ${e.value} has no card store configured`)}catch(r){return I(r)}}function w(s){try{let r=S().readOutputsStoreRef();return r?T({storeRef:r}):R(`Board at ${e.value} has no outputs store configured`)}catch(r){return I(r)}}function B(s){try{let r=S().readScratchStoreRef();return T({storeRef:r})}catch(r){return I(r)}}function H(s){try{let r=S().readArchiveStoreRef();return T({storeRef:r})}catch(r){return I(r)}}function Z(s){try{let r=S().readChatStoreRef();return T({storeRef:r})}catch(r){return I(r)}}function te(s){try{let r=S().readArtifactsStoreRef();return T({storeRef:r})}catch(r){return I(r)}}function Et(s){try{let r=s.params?.key;if(!r)return R("getConfig requires params.key");let p=S(),g;switch(r){case "task-executor":g=p.readTaskExecutorRef()??null;break;case "chat-handler-flow":g=p.readChatHandlerFlow()??null;break;case "card-store-ref":g=p.readCardStoreRef();break;case "outputs-store-ref":g=p.readOutputsStoreRef();break;case "scratch-store-ref":g=p.readScratchStoreRef();break;case "archive-store-ref":g=p.readArchiveStoreRef();break;case "chat-store-ref":g=p.readChatStoreRef();break;case "artifacts-store-ref":g=p.readArtifactsStoreRef();break;default:return R(`getConfig: unknown key "${r}"`)}return T({value:g})}catch(r){return I(r)}}function At(s){try{let r=s.params?.key;if(!r)return R("getOutputsDataObject requires params.key");let p=j().readDataObject(r);return T(p)}catch(r){return I(r)}}function It(s){try{return T(j().readAllDataObjects())}catch(r){return I(r)}}function _t(s){try{let r=s.params?.key;if(!r)return R("getOutputsComputedValues requires params.key");let p=j().readComputedValues(r);return T(p)}catch(r){return I(r)}}function Ft(s){try{return T(j().readAllComputedValues())}catch(r){return I(r)}}function Le(){return Te(t.blobStorage("sources"),s=>t.resolveBlob(s))}function Ne(s){let r=t.blobStorage("sources").keyRef?.(s);return r?a(r):s}function Ot(s){try{let r=s.params?.key;if(!r)return R("getOutputsFetchedSources requires params.key");let p=Le().listSources(r),g={};for(let x of p)g[x]=Ne(`${r}/${x}`);return T(g)}catch(r){return I(r)}}function Pt(s){try{let r=Le(),p=new Set;for(let x of t.blobStorage("sources").listKeys()){let O=x.indexOf("/");O>0&&!x.includes("/.staged/")&&p.add(x.slice(0,O));}let g={};for(let x of p){let O=r.listSources(x);if(O.length>0){g[x]={};for(let X of O)g[x][X]=Ne(`${x}/${X}`);}}return T(g)}catch(r){return I(r)}}return {init:V,status:N,getCardStoreRef:k,getOutputsStoreRef:w,getScratchStoreRef:B,getArchiveStoreRef:H,getChatStoreRef:Z,getArtifactsStoreRef:te,getConfig:Et,getOutputsDataObject:At,getAllOutputsDataObjects:It,getOutputsComputedValues:_t,getAllOutputsComputedValues:Ft,getOutputsFetchedSources:Ot,getAllOutputsFetchedSources:Pt,removeCard:D,addCardFiles:M,cardRefreshedNotify:$,retrigger:oe,processAccumulatedEvents:se,upsertCard:Se,taskFailed:ae,taskProgress:ie,sourceDataFetched:pe,sourceDataFetchFailure:b$1}}function Rr(e,t){let n=()=>Ke(t.kvStorage("config"));function o(){let l=n().readCardStoreRef();if(!l)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let a=t.kvStorageForRef(l);return {readIndex(){return a.read("_index")},writeIndex(d){a.write("_index",d);},readCard(d){return a.read(d)},writeCard(d,C){return a.write(d,C),t.hashFn(C)},removeCard(d){a.delete(d);},cardExists(d){return a.read(d)!==null},defaultCardKey(d){return d}}}let i=()=>je(o(),t.onWarn??(()=>{}));async function u(l,a){let d=t.validateSchema(a),C=[],A=n().readTaskExecutorRef();if(A&&Array.isArray(a.source_defs))for(let _ of a.source_defs){let F=typeof _.bindTo=="string"?_.bindTo:"(unknown)";try{let V;try{V=await t.invokeExecutor(A,"validate-source-def",{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(_)});}catch(D){let M=D;if(V=typeof M?.stdout=="string"?M.stdout:"",!V.trim()){C.push(`source "${F}": executor validate-source-def failed \u2014 ${D instanceof Error?D.message:String(D)}`);continue}}let N=JSON.parse(V.trim());if(!N.ok&&Array.isArray(N.errors))for(let D of N.errors)C.push(`source "${F}": ${D}`);}catch(V){C.push(`source "${F}": executor validate-source-def failed \u2014 ${V instanceof Error?V.message:String(V)}`);}}let E=[...d.errors,...C];return T({cardId:l,isValid:E.length===0,issues:E})}function c(l,a){let d=l.params?.sourceIdx,C=l.params?.outRef;if(d===void 0)return R(`${a} requires params.sourceIdx`);if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return R(`${a} requires card JSON object in body`);let A=l.body,E=A["card-content"]??A,_=A["mock-projections"]??{},F=E.source_defs??[];if(d<0||d>=F.length)return R(`sourceIdx ${d} out of range (card has ${F.length} source(s))`);let V=F[d],N=typeof V.bindTo=="string"?V.bindTo:"source";return {src:V,bindTo:N,outRef:C,mockProjections:_}}async function f(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return R("validateCardPreflight requires card JSON object in body");let a=l.body,d=a["card-content"]??a,C=typeof d.id=="string"?d.id:"(unknown)";return await u(C,d)}catch(a){return I(a)}}async function S(l){try{let a=c(l,"probeSourcePreflight");if("status"in a)return a;let d=n().readTaskExecutorRef();if(!d)return R("No task-executor registered for this board");try{let C={...a.src,_projections:a.mockProjections},A=await t.invokeExecutor(d,"probe-source-preflight",{timeout:a.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(C)}),E=JSON.parse(A.trim());return E.ok?T({bindTo:a.bindTo,reachable:E.reachable,latencyMs:E.latencyMs,note:E.note}):R(E.error??"Preflight probe failed")}catch{return R("Executor does not support probe-source-preflight")}}catch(a){return I(a)}}async function y(l){try{let a=c(l,"runSourcePreflight");if("status"in a)return a;let d=n().readTaskExecutorRef();if(!d)return R("No task-executor registered for this board");try{let C={...a.src,_projections:a.mockProjections},A=await t.invokeExecutor(d,"run-source-preflight",{timeout:a.src.timeout??t.executorTimeouts?.probeMs??6e4,input:JSON.stringify(C)}),E=JSON.parse(A.trim());if(!E.ok)return T({bindTo:a.bindTo,ok:!1,result:null,issues:[E.error??"Preflight run failed"]});if(a.outRef){let _=b(a.outRef);t.absoluteBlob.write(_.value,JSON.stringify(E.resultValue,null,2));}return T({bindTo:typeof E.bindTo=="string"?E.bindTo:a.bindTo,ok:!0,result:E.resultValue??null,issues:[]})}catch(C){let A=C instanceof Error?C.message:String(C);return T({bindTo:a.bindTo,ok:!1,result:null,issues:[A]})}}catch(a){return I(a)}}async function P(l){try{let a=n().readTaskExecutorRef();if(!a)return R("No task-executor registered for this board");let d=await t.invokeExecutor(a,"describe-capabilities",{timeout:t.executorTimeouts?.describeMs??1e4});return T(JSON.parse(d.trim()))}catch(a){return I(a)}}function L(l){try{let a=l.body;if(!a||!Array.isArray(a.ops))return R("updatesInCardStore requires body.ops array");let d=a.ops,C=i();for(let A of d){let E=A.op,_=A.id;if(!_)return R('op is missing "id"');if(E==="update"){let F=A["card-content"];if(!F)return R(`update op for "${_}" is missing "card-content"`);C.writeCard(_,F);}else return R(`Unknown op type: "${E??"(none)"}"`)}return T()}catch(a){return I(a)}}function j(l){try{let a=l.body;if(!a||!Array.isArray(a.ids))return R("readFromCardStore requires body.ids array");let d=a.ids,C=i(),A=d.map(E=>({id:E,"card-content":C.readCard(E)}));return T({cards:A})}catch(a){return I(a)}}function Y(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return R("evalCardCompute requires a JSON object in body");let a=l.body,d=a["card-content"]??a,C=typeof d.id=="string"?d.id:"(unknown)",A=a["mock-fetched-sources"]??{},E=a["mock-requires"]??{},_=d.compute;if(!_||!Array.isArray(_)||_.length===0)return T({cardId:C,ok:!0,computed_values:{},errors:[]});let F={id:C,card_data:d.card_data??{},requires:E,source_defs:d.source_defs,compute:_},V=a$3.runSync(F,{sourcesData:A}),N=V.node.computed_values??{},D=V.errors??[];return T({cardId:C,ok:D.length===0,computed_values:N,errors:D})}catch(a){return I(a)}}async function v(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return R("simulateCardCycle requires a JSON object in body");let a=l.body,d=a["card-content"]??a,C=typeof d.id=="string"?d.id:"(unknown)",A=a["mock-fetched-sources"]??{},E=a["mock-requires"]??{},_=await u(C,d),F=_.status==="success"?{isValid:_.data.isValid,issues:_.data.issues}:{isValid:!1,issues:[_.status==="fail"?_.error:"internal error"]},V=d.source_defs??[],N=d.card_data??{},D=[],M=[];if(V.length>0){D=a$3.enrichSourcesSync(V,{card_data:N,requires:E});for(let k of D){let w=k.projections,B=k._projections;if(w&&B){for(let H of Object.keys(w))if(B[H]===void 0){let Z=typeof k.bindTo=="string"?k.bindTo:"(unknown)";M.push({bindTo:Z,key:H,error:`Projection "${H}" resolved to undefined`});}}}}let $=[],oe={...A},se=a["task-executor-ref"],Se=(se?.howToRun&&se?.whatToRun?se:void 0)??n().readTaskExecutorRef();for(let k=0;k<D.length;k++){let w=D[k],B=typeof w.bindTo=="string"?w.bindTo:`source_${k}`;if(!Se){$.push({bindTo:B,skipped:!0,error:"No task executor configured"});continue}try{let H={...w},Z=await t.invokeExecutor(Se,"run-source-preflight",{timeout:w.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(H)}),te=JSON.parse(Z.trim());te.ok&&!Object.prototype.hasOwnProperty.call(A,B)&&Object.prototype.hasOwnProperty.call(te,"resultValue")&&(oe[B]=te.resultValue),$.push({bindTo:B,reachable:te.reachable,latencyMs:te.latencyMs,error:te.ok?void 0:te.error});}catch{$.push({bindTo:B,skipped:!0,error:"Executor does not support run-source-preflight"});}}let ae=d.compute,ie={},pe=[];if(ae&&Array.isArray(ae)&&ae.length>0){let k={id:C,card_data:N,requires:E,source_defs:d.source_defs,compute:ae},w=a$3.runSync(k,{sourcesData:oe});ie=w.node.computed_values??{},pe=w.errors??[];}let b=F.isValid&&M.length===0&&pe.length===0&&$.every(k=>k.reachable!==!1);return T({cardId:C,ok:b,validation:F,source_probes:$,projection_errors:M,fetched_sources:oe,computed_values:ie,compute_errors:pe})}catch(a){return I(a)}}return {validateCardPreflight:f,probeSourcePreflight:S,runSourcePreflight:y,evalCardCompute:Y,simulateCardCycle:v,describeTaskExecutorCapabilities:P,updatesInCardStore:L,readFromCardStore:j}}
|
|
2
|
-
export{rr as a,st as b,nr as c,rt as d,Qt as e,Zt as f,er as g,ut as h,dt as i,ct as j,lt as k,je as l,Ee as m,le as n,Lt as o,pt as p,ft as q,$t as r,mt as s,Ae as t,De as u,bt as v,vt as w,wt as x,Cr as y,Rr as z};//# sourceMappingURL=chunk-JH37NJGP.js.map
|
|
3
|
-
//# sourceMappingURL=chunk-JH37NJGP.js.map
|
package/lib/chunk-JJL5VOQZ.cjs
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
'use strict';var chunkU2N6MCD5_cjs=require('./chunk-U2N6MCD5.cjs'),chunkSFVO2LB2_cjs=require('./chunk-SFVO2LB2.cjs'),chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkIXZG74EW_cjs=require('./chunk-IXZG74EW.cjs'),chunkYMEIPKLW_cjs=require('./chunk-YMEIPKLW.cjs');function et(e){return typeof e=="string"&&e.trim().length>0}function tt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.selfRef is required`);if(!et(e.howToRun))throw new Error(`${t}: adapter.selfRef.howToRun is required`);if(!et(e.whatToRun))throw new Error(`${t}: adapter.selfRef.whatToRun is required`)}function rt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.callbackTransport is required`);if(typeof e.createCallback!="function")throw new Error(`${t}: adapter.callbackTransport.createCallback is required`)}function jt(e,t="callbackTransport"){return {createCallback(n){let o=e();return tt(o,t),{token:n,via:o}}}}function Ve(e){return jt(()=>e,"createStaticExecutionRefCallbackTransport")}function Qt(e){return Ve({meta:"board-live-cards",howToRun:"http:post",whatToRun:chunkSFVO2LB2_cjs.a({kind:"http-url",value:String(e||"").trim()})})}function Zt(e){return Ve({meta:"board-live-cards",howToRun:"in-process-loop",whatToRun:chunkSFVO2LB2_cjs.a({kind:"in-process-loop",value:String(e||"").trim()})})}function er(e){return Ve({meta:"board-live-cards",howToRun:"local-node",whatToRun:chunkSFVO2LB2_cjs.a({kind:"yaml-flow-cli",value:"board-live-cards-cli.js"}),...e?{extra:{notifyChannel:e}}:{}})}function we(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function qe(e,t){return we(e)?e.then(t):t(e)}function ot(e,t){let n={...e};for(let o of t.deleteKeys)delete n[o];return {...n,...t.shallowMerge}}function rr(e,t){return {readValues(o){let i=e(o);return qe(i.listKeys(),u=>{let c=[...u].sort();if(c.length===0)return {version:null,values:{}};let f={},S=null;for(let y of c){let P=i.read(y);we(P)?S=(S??Promise.resolve()).then(async()=>{f[y]=await P;}):f[y]=P;}return S?S.then(()=>({version:t(f),values:f})):{version:t(f),values:f}})},writeValues(o,i,u){let c=e(o),f=null;for(let S of u){let y=c.delete(S);we(y)&&(f=(f??Promise.resolve()).then(()=>y).then(()=>{}));}for(let[S,y]of Object.entries(i)){let P=c.write(S,y);we(P)&&(f=(f??Promise.resolve()).then(()=>P).then(()=>{}));}return f?f.then(()=>t(i)):t(i)}}}function st(e,t){return {readSnapshot(n){return e.readValues(n)},commitSnapshot(n,o){if(o.schemaVersion!==t)throw new Error(`Unsupported snapshot schema version: ${o.schemaVersion}`);return qe(e.readValues(n),i=>{if(i.version!==o.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:i.version};let u=ot(i.values,o);return qe(e.writeValues(n,u,o.deleteKeys),c=>({ok:true,newVersion:c}))})}}}function nt(e,t){if(!t)return e;let n=e.findIndex(o=>o.id===t);return n===-1?e:e.slice(n+1)}function at(e){return {readEntriesAfterCursor(t){let n=nt(e.readAllEntries(),t);return n.length===0?{events:[],newCursor:t}:{events:n.map(o=>o.event),newCursor:n[n.length-1].id}},pendingCount(t){return nt(e.readAllEntries(),t).length},appendEvent(t){e.appendEntry({id:e.generateId(),event:t});}}}function nr(e){return {appendEvent(t){return e.append(t).then(()=>{})},async readEntriesAfterCursor(t){let n=await e.readAfter(t||null);return {events:n.entries.map(o=>o.payload),newCursor:n.newCursor??t}}}}function xe(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function G(e,t){return xe(e)?e.then(t):t(e)}function Be(e,t){let n=null;for(let o of e){if(n){n=n.then(()=>t(o)).then(()=>{});continue}let i=t(o);xe(i)&&(n=Promise.resolve(i).then(()=>{}));}return n??void 0}function Kt(e){if(e==null)return null;let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{return t}}function Dt(e,t){let n=e.match(t);return n?n[1]:null}function it(e,t,n){let o={},i=Be(e,u=>{let c=n(u);if(c)return G(t(u),f=>{o[c]=f;})});return xe(i)?i.then(()=>o):o}function ut(e,t){let n=o=>G(e.read(o),i=>i??(e.keyRef?G(e.keyRef(o),u=>u?G(t(u),c=>c??null):null):null));return {readSourceData(o,i){return G(e.read(`${o}/${i}`),Kt)},ingestSourceDataStaged(o,i,u,c){return G(t(u),f=>e.write(`${o}/.staged/${c}/${i}`,f))},commitSourceData(o,i,u){let c=`${o}/.staged/${u}/${i}`;return G(n(c),f=>f==null?false:G(e.write(`${o}/${i}`,f),()=>G(e.remove(c),()=>true)))},hasSource(o,i){return e.exists(`${o}/${i}`)},listSources(o){return G(e.listKeys(`${o}/`),i=>i.filter(u=>!u.includes("/.staged/")).map(u=>u.slice(`${o}/`.length)))}}}function dt(e,t){let n=(o,i)=>{try{let u=i(o);return xe(u)?u.catch(c=>t(o,c instanceof Error?c.message:String(c))):void 0}catch(u){try{return t(o,u instanceof Error?u.message:String(u))}catch{return}}};return {appendEntries(o,i){if(!(!o||i.length===0))return G(e.read(o),u=>e.write(o,[...u??[],...i]))},dispatchEntriesForJournalId(o,i){if(o)return G(e.read(o),u=>{let c=u;if(!(!c||c.length===0))return G(Be(c,f=>n(f,i)),()=>e.delete(o))})}}}function ct(e,t,n){return {readRuntime(o){return G(e.read(t(o)),i=>i??n())},writeRuntime(o,i){return e.write(t(o),i)}}}function lt(e){return {writeComputedValues(t,n){return e.write(`cards/${t}/computed_values`,n)},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){return G(e.listKeys("cards/"),t=>it(t,n=>e.read(n),n=>Dt(n,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(t){return Be(Object.entries(t),([n,o])=>{if(n)return e.write(`data-objects/${n}`,o)})},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){return G(e.listKeys("data-objects/"),t=>it(t,n=>e.read(n),n=>n.slice(13)))},writeStatusSnapshot(t){return e.write("status",t)},readStatusSnapshot(){return e.read("status")}}}function je(e,t){function n(){return e.readIndex()??{}}function o(i,u,c){let f=String(u||"").split(".").filter(Boolean);if(f.length===0)return c&&typeof c=="object"&&!Array.isArray(c)?c:{value:c};let S={...i},y=S;for(let P=0;P<f.length-1;P++){let L=f[P],j=y[L],Y=j&&typeof j=="object"&&!Array.isArray(j)?{...j}:{};y[L]=Y,y=Y;}return y[f[f.length-1]]=c,S}return {readCard(i){let u=n()[i];return !u||!e.cardExists(u.key)?null:e.readCard(u.key)},readCardKey(i){return n()[i]?.key??null},readAllCards(){let i=[];for(let[u,c]of Object.entries(n())){if(!e.cardExists(c.key))continue;let f=e.readCard(c.key);f?i.push(f):t?.(`[card-store] could not read card "${u}" at key "${c.key}"`);}return i},readChecksumIndex(){let i={};for(let[u,c]of Object.entries(n()))i[u]=c.checksum;return i},changedSince(i){let u=n(),c=[];for(let[f,S]of Object.entries(u))i[f]!==S.checksum&&c.push(f);for(let f of Object.keys(i))u[f]||c.push(f);return c},validateUpsert(i,u){let c=n(),f=c[i],S=Object.entries(c).find(([,y])=>y.key===u);return f&&f.key!==u?{ok:false,error:`Card id "${i}" is already mapped to key "${f.key}", cannot remap to "${u}"`}:S&&S[0]!==i?{ok:false,error:`Key "${u}" is already mapped to card id "${S[0]}", cannot remap to "${i}"`}:{ok:true}},writeCard(i,u,c){let f=n(),S=c??f[i]?.key??e.defaultCardKey(i),y=e.writeCard(S,u);f[i]={key:S,checksum:y,updatedAt:new Date().toISOString()},e.writeIndex(f);},patchCard(i,u,c){let f=n(),S=f[i];if(!S||!e.cardExists(S.key))throw new Error(`card "${i}" not found`);let y=e.readCard(S.key);if(!y||typeof y!="object"||Array.isArray(y))throw new Error(`card "${i}" is not patchable`);let P=o(y,u,c),L=e.writeCard(S.key,P);f[i]={key:S.key,checksum:L,updatedAt:new Date().toISOString()},e.writeIndex(f);},removeCard(i){let u=n(),c=u[i];c&&(e.removeCard(c.key),delete u[i],e.writeIndex(u));},readIndex(){return n()}}}function Te(e,t){return ut(e,t)}function gt(e){return at(e)}function kt(e,t){return dt(e,t)}var Ee="v1",le="board/graph",St="board/lastJournalProcessedId";function Lt(e){return `cards/${e}/runtime`}function ht(e){return ct(e,Lt,()=>({_sources:{}}))}function yt(e){return st(e,Ee)}function Ke(e){function t(n){let o=e.read(n);return o==null?null:typeof o=="string"?o:JSON.stringify(o)}return {readTaskExecutorRef(){let n=t("task-executor");if(n?.trim())return chunkU2N6MCD5_cjs.c(n.trim())},writeTaskExecutorRef(n){e.write("task-executor",chunkU2N6MCD5_cjs.b(n));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(n){e.write("chat-handler-flow",n);},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(n){e.write("card-store-ref",n);},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(n){e.write("outputs-store-ref",n);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(n){e.write("scratch-store-ref",n);},readArchiveStoreRef(){return t("archive-store-ref")},writeArchiveStoreRef(n){e.write("archive-store-ref",n);},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(n){e.write("chat-store-ref",n);},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(n){e.write("artifacts-store-ref",n);}}}function Ct(e){return lt(e)}function pt(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function Nt(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function ft(e,t){return e?.lastRequestedToken?Nt(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function $t(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function mt(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function Ae(e,t){let n=t.state.tasks,o=t.config.tasks,i=Object.keys(n),u=chunkG4XXRHL2_cjs.r(t),c={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},f=new Map;for(let v of u.pending)f.set(v.taskName,v.waitingOn);for(let v of u.unresolved)f.set(v.taskName,v.missingTokens);for(let v of u.blocked)f.set(v.taskName,v.failedTokens);let S=new Map;for(let[v,l]of Object.entries(o))for(let a of l.requires??[]){let d=S.get(a)??[];d.push(v),S.set(a,d);}let y=i.sort().map(v=>{let l=n[v],a=o[v]??{requires:[],provides:[]};l.status==="completed"?c.completed+=1:l.status==="failed"?c.failed+=1:l.status==="in-progress"&&(c.in_progress+=1);let d=a.requires??[],C=a.provides??[],A=Object.keys(l.data??{}).sort(),E=d.filter(M=>t.state.availableOutputs.includes(M)),_=d.filter(M=>!t.state.availableOutputs.includes(M)),F=f.get(v)??_,V=new Set;for(let M of C)for(let $ of S.get(M)??[])$!==v&&V.add($);let N=l.failedAt,D=l.error?{message:l.error,code:"TASK_FAILED",at:N,source:"task-runtime"}:void 0;return {name:v,status:l.status,error:D,requires:d,requires_satisfied:E,requires_missing:_,provides_declared:C,provides_runtime:A,blocked_by:F,unblocks:Array.from(V).sort(),runtime:{attempt_count:l.executionCount??0,restart_count:l.retryCount??0,in_progress_since:l.status==="in-progress"?l.startedAt??null:null,last_transition_at:l.lastUpdated??null,last_completed_at:l.completedAt??null,last_restarted_at:l.startedAt??null,status_age_ms:l.lastUpdated?0:null}}});c.pending=u.pending.length,c.blocked=u.blocked.length,c.unresolved=u.unresolved.length;let P=y.map(v=>({name:v.name,fanOut:v.unblocks.length})).sort((v,l)=>l.fanOut-v.fanOut||v.name.localeCompare(l.name)),L=P.length>0?P[0]:{name:null,fanOut:0},j=new Set;for(let v of Object.values(o))for(let l of v.requires??[])j.add(l);let Y=0;for(let[v,l]of Object.entries(o)){let a=(l.requires??[]).length===0,C=(l.provides??[]).some(A=>(S.get(A)??[]).some(E=>E!==v));a&&!C&&(Y+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:i.length,completed:c.completed,eligible:u.eligible.length,pending:c.pending,blocked:c.blocked,unresolved:c.unresolved,failed:c.failed,in_progress:c.in_progress,orphan_cards:Y,topology:{edge_count:Array.from(j).length,max_fan_out_card:L.name,max_fan_out:L.fanOut}},cards:y}}function Jt(){return new Date().toISOString()}function Rt(e,t,n,o,i,u,c){return async f=>{let S=[],y=n.cardStore.readCard(f.nodeId);if(!y)return "task-initiate-failure";let P=y.id,L=y.card_data??{},j=y.source_defs??[],Y=j.filter(b=>b.optionalForCompletionGating!==true),v=n.cardRuntimeStore.readRuntime(P),l=false,a=()=>{l&&(n.cardRuntimeStore.writeRuntime(P,v),l=false);},d=b=>pt(v._sources[b]),C=(b,k)=>{v._sources[b]=pt(k),l=true;},A=f.taskState?.executionCount??0;if(v._lastExecutionCount!==A&&(v._sources={},v._lastExecutionCount=A,l=true),f.update){let b=f.update,k=b.outputFile;if(k){let w=d(k);if(b.failure){let B=b.rqt??w.lastRequestedToken??w.queueRequestedToken;B&&C(k,mt(w,B));}else {let B=b.rqt;if(!w.lastCompletedToken||B>w.lastCompletedToken){let H=typeof b.deliveryToken=="string"?b.deliveryToken:void 0,Z=false;H&&(Z=n.fetchedSourcesStore.commitSourceData(P,k,H)),Z?C(k,$t(w,B)):C(k,mt(w,B));}}a();}}let _={};for(let b of j)if(b.outputFile){let k=n.fetchedSourcesStore.readSourceData(P,b.outputFile);k!==null&&(_[b.bindTo]=k);}let F={};for(let[b,k]of Object.entries(f.state??{}))if(k!==null&&typeof k=="object"&&!Array.isArray(k)){let w=k[b];F[b]=w!==void 0?w:k;}else F[b]=k;let V={id:P,card_data:{...L},requires:F,source_defs:j,compute:y.compute};V._sourcesData=_,y.compute&&chunkIXZG74EW_cjs.a.runSync(V,{sourcesData:_}),(u??n.outputStore.writeComputedValues.bind(n.outputStore))(P,V.computed_values??{});let N={...y},D=chunkIXZG74EW_cjs.a.enrichSourcesSync(Array.isArray(y.source_defs)?y.source_defs:void 0,{card_data:y.card_data,requires:F}),M=e.value;N.source_defs=Array.isArray(D)?D.map(b=>({...b,boardDir:typeof b.boardDir=="string"&&b.boardDir?b.boardDir:M})):D;let $=Jt(),oe=f.update?void 0:$,se=Y.filter(b=>{let k=b.outputFile;if(typeof k!="string"||!k)return true;let w=d(k);oe&&(w={...w,queueRequestedToken:oe},C(k,w));let B=w.queueRequestedToken??w.lastRequestedToken??$,H=ft(w,B);return H==="in-flight"?false:H==="dispatch"});if(a(),se.length>0){let b=false,k=$;for(let w of se){let B=w.outputFile;if(typeof B!="string"||!B)continue;let H=d(B),Z=H.queueRequestedToken??$;C(B,{...H,lastRequestedToken:Z}),k=Z,b=true;}return b&&a(),b&&(S.push({taskKind:"source-fetch",payload:{boardRef:chunkSFVO2LB2_cjs.a(e),enrichedCard:N,callbackToken:f.callbackToken,rqt:k}}),n.executionRequestStore.appendEntries(t,S)),"task-initiated"}if(Y.some(b=>{let k=b.outputFile;if(typeof k!="string"||!k)return false;let w=d(k),B=w.queueRequestedToken??w.lastRequestedToken??$;return ft(w,B)==="in-flight"}))return "task-initiated";let ae=y.provides??[],ie={};for(let{bindTo:b,ref:k}of ae)ie[b]=chunkIXZG74EW_cjs.a.resolve(V,k);return (c??n.outputStore.writeDataObjects.bind(n.outputStore))(ie),j.filter(b=>{if(b.optionalForCompletionGating!==true)return false;let k=d(b.outputFile);return !k.lastRequestedToken||!k.lastCompletedToken?true:k.lastCompletedToken<=k.lastRequestedToken}).length>0&&S.push({taskKind:"source-fetch",payload:{boardRef:chunkSFVO2LB2_cjs.a(e),enrichedCard:N,callbackToken:f.callbackToken,rqt:$}}),o(f.nodeId,ie),S.length>0&&n.executionRequestStore.appendEntries(t,S),"task-initiated"}}var De={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function bt(e){return {[le]:e.graph,[St]:e.lastDrainedJournalId}}function vt(e){let t=e[le],n=e[St];if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${le}`);return {graph:t,lastDrainedJournalId:typeof n=="string"?n:""}}function wt(e){let t=e.requires;return {provides:e.provides?.map(o=>o.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...t&&t.length>0?{requires:t}:{}}}function T(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function I(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function Mt(e){let t=new TextEncoder().encode(e),n=Array.from(t,o=>String.fromCharCode(o)).join("");return btoa(n).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Tt(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),n=t+"=".repeat((4-t.length%4)%4),o=atob(n),i=Uint8Array.from(o,u=>u.charCodeAt(0));return new TextDecoder().decode(i)}function Ie(e){try{let t=JSON.parse(Tt(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function Ht(e){return Mt(JSON.stringify(e))}function xt(e){try{let t=JSON.parse(Tt(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function U(){return new Date().toISOString()}function Cr(e,t){rt(t.callbackTransport,"createBoardLiveCardsPublic");let n=t.callbackTransport,o=t.onWarn??(()=>{}),i=chunkSFVO2LB2_cjs.a(e);function u(s){if(s.length!==0)try{let r=t.publishBoardChangeNotifications?.(s);r&&typeof r.catch=="function"&&r.catch(p=>o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${p instanceof Error?p.message:String(p)}`));}catch(r){o(`[board-live-cards-public] publishBoardChangeNotifications failed: ${r instanceof Error?r.message:String(r)}`);}}function c(){let s=S().readCardStoreRef();if(!s)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let r=t.kvStorageForRef(s);return {readIndex(){return r.read("_index")},writeIndex(p){r.write("_index",p);},readCard(p){return r.read(p)},writeCard(p,g){return r.write(p,g),t.hashFn(g)},removeCard(p){r.delete(p);},cardExists(p){return r.read(p)!==null},defaultCardKey(p){return p}}}let f={readValues(s){let r=t.kvStorage("state-snapshot"),p=r.listKeys().sort();if(p.length===0)return {version:null,values:{}};let g={};for(let x of p)g[x]=r.read(x);return {version:t.hashFn(g),values:g}},writeValues(s,r,p){let g=t.kvStorage("state-snapshot");for(let x of p)g.delete(x);for(let[x,O]of Object.entries(r))g.write(x,O);return t.hashFn(r)}},S=()=>Ke(t.kvStorage("config")),y=()=>yt(f),P=()=>gt(t.journalAdapter()),L=()=>je(c(),o),j=()=>{let s=S().readOutputsStoreRef();if(!s)throw new Error(`Board at ${e.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return Ct(t.kvStorageForRef(s))},Y=()=>{let s=S().readArchiveStoreRef();return s?t.archiveFactoryForRef(s):t.archiveFactory()};function v(){return !!y().readSnapshot(e.value).values[le]}function l(){let s=y().readSnapshot(e.value);if(!s.values[le])throw new Error(`Board not initialized at ${e.value}`);return vt(s.values)}function a(s,r){let p=y().commitSnapshot(e.value,{schemaVersion:Ee,expectedVersion:r,commitId:t.genId(),committedAt:U(),deleteKeys:[],shallowMerge:bt(s)});if(!p.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${r??"null"} current=${p.currentVersion??"null"}`)}function d(s){P().appendEvent(s);}async function C(){let s=(m,h)=>{let q=m.payload,z=(q?.enrichedCard??{}).id??q?.cardId??"unknown";d({type:"task-failed",taskName:z,error:h,timestamp:U()});},r=kt(t.kvStorage("execution-requests"),s),p=ht(t.kvStorage("card-runtime")),g=Te(t.blobStorage("sources"),m=>t.resolveBlob(m)),x=new Map,O={readRuntime(m){return x.get(m)??p.readRuntime(m)},writeRuntime(m,h){x.set(m,h);}},X=[],K=new Map,Q={readSourceData(m,h){let q=`${m}/${h}`;return K.has(q)?K.get(q):g.readSourceData(m,h)},ingestSourceDataStaged(m,h,q,re){g.ingestSourceDataStaged(m,h,q,re);},commitSourceData(m,h,q){let re=`${m}/.staged/${q}/${h}`,z=t.blobStorage("sources"),ee=z.read(re);if(ee==null){let be=z.keyRef?.(re);be&&(ee=t.resolveBlob(be));}if(ee==null)return false;let Re=`${m}/${h}`,ne=ee.trim();try{K.set(Re,JSON.parse(ne));}catch{K.set(Re,ne);}return X.push({cardId:m,outputFile:h,deliveryToken:q}),true},hasSource(m,h){let q=`${m}/${h}`;return K.has(q)?true:g.hasSource(m,h)},listSources(m){let h=g.listSources(m),q=new Set;for(let z of K.keys())z.startsWith(`${m}/`)&&q.add(z.slice(`${m}/`.length));let re=new Set([...h,...q]);return Array.from(re)}},W={cardStore:L(),cardRuntimeStore:O,fetchedSourcesStore:Q,outputStore:j(),executionRequestStore:r},ue=l(),fe=chunkG4XXRHL2_cjs.q(ue.graph),{events:me,newCursor:ge}=P().readEntriesAfterCursor(ue.lastDrainedJournalId),de=[],he=[],_e=[],Fe=new Map,$e=new Set,Vt=(m,h)=>{de.push({type:"task-completed",taskName:m,data:h,timestamp:U()});try{Y().stream("exec-history").append({taskName:m,status:"completed",completedAt:U()});}catch{}},Je=(m,h)=>{d({type:"task-failed",taskName:m,error:h,timestamp:U()});try{Y().stream("exec-history").append({taskName:m,status:"failed",error:h,completedAt:U()});}catch{}},ye=chunkG4XXRHL2_cjs.u(fe,{handlers:{"card-handler":Rt(e,ge,W,Vt,Je,(m,h)=>{he.push({cardId:m,values:h});},m=>{_e.push(m);})},onNodeRemoved:m=>{Fe.delete(m),x.delete(m),$e.add(m);}});for(de=me;de.length>0;){let m=de;de=[];for(let h of m)if(h.type==="task-restart"){let q=W.cardStore.readCard(h.taskName);q&&Fe.set(h.taskName,q);}ye.pushAll(m),await ye.waitForHandlers();}let Me=ye.getState();await ye.dispose({wait:true});let qt=y().readSnapshot(e.value).version;a({lastDrainedJournalId:ge,graph:chunkG4XXRHL2_cjs.p(Me)},qt);for(let{cardId:m,values:h}of he)W.outputStore.writeComputedValues(m,h);for(let m of _e)W.outputStore.writeDataObjects(m);for(let[m,h]of x)p.writeRuntime(m,h);for(let{cardId:m,outputFile:h,deliveryToken:q}of X)g.commitSourceData(m,h,q);let Ce;try{Ce=Ae(i,Me),W.outputStore.writeStatusSnapshot(Ce);}catch(m){o(`[board-live-cards-public] status publish failed: ${m instanceof Error?m.message:String(m)}`);}let ke=[];for(let{cardId:m,values:h}of he)ke.push({kind:"computed_values",cardId:m,values:h});for(let m of _e)for(let[h,q]of Object.entries(m))h&&ke.push({kind:"data_object",key:h,payload:q});for(let[m,h]of Fe)ke.push({kind:"card_refreshed",cardId:m,card:h});for(let m of $e)ke.push({kind:"card_removed",cardId:m});Ce!==void 0&&ke.push({kind:"status",status:Ce}),u(ke);let He=S().readTaskExecutorRef()??{howToRun:"built-in",whatToRun:chunkSFVO2LB2_cjs.a({kind:"built-in",value:"source-cli-task-executor"})},Bt=t.supportsDirectSourceOutput?.(He)===true;r.dispatchEntriesForJournalId(ge,m=>{if(m.taskKind!=="source-fetch"){o(`[process-accumulated-events] unknown taskKind "${m.taskKind}" \u2014 skipping`);return}let h=m.payload,q=h.enrichedCard?.id??"unknown",re=h.enrichedCard?.source_defs??[];for(let z of re){if(!z.outputFile){o(`[dispatch] source "${z.bindTo}" has no outputFile \u2014 skipping`);continue}let ee;if(Bt){let ne=t.genId(),be=`${q}/.staged/${ne}/${z.outputFile}`,Ge=t.blobStorage("sources").keyRef?.(be);Ge?ee={ref:chunkSFVO2LB2_cjs.a(Ge),deliveryToken:ne,outputFile:z.outputFile,cardId:q}:o("[dispatch] hosted board-worker requested but sources BlobStorage cannot produce portable refs; falling back to scratch protocol");}let Re=Ht({cbk:h.callbackToken,rg:e.value,br:chunkSFVO2LB2_cjs.a(e),cid:q,b:z.bindTo,d:z.outputFile,cs:void 0,rqt:h.rqt,...ee?{dt:ee.deliveryToken}:{}});t.dispatchExecution(He,{source_def:z,base_ref:chunkSFVO2LB2_cjs.a(e),callback:n.createCallback(Re),...ee?{output:ee}:{}}).catch(ne=>Je(q,ne instanceof Error?ne.message:String(ne)));}});}function A(){let s=t.processAccumulatedStore();s.enqueueIfAbsent?s.enqueueIfAbsent({boardRef:chunkSFVO2LB2_cjs.a(e)},`process-accumulated:${chunkSFVO2LB2_cjs.a(e)}`):s.enqueue({boardRef:chunkSFVO2LB2_cjs.a(e)}),t.requestProcessAccumulated?.();}function E(){let s=t.processAccumulatedStore();for(;;){let r=s.lease({max:64,visibilityMs:1e3});if(r.length<=0)return;for(let p of r)s.ack(p.id,p.leaseToken);if(r.length<64)return}}async function _(){try{let s=()=>{let p=l(),{events:g}=P().readEntriesAfterCursor(p.lastDrainedJournalId);g.length<=0||A();},r=await chunkSFVO2LB2_cjs.c(t.lock,C,s);return T({ran:r!==!1})}catch(s){return I(s)}}function F(){A();}function V(s){try{let r=s.params?.cardStoreRef;if(!r)return R("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(!v()){let W=chunkG4XXRHL2_cjs.a(De);a({lastDrainedJournalId:"",graph:chunkG4XXRHL2_cjs.p(W)},null);}let p=s.params?.outputsStoreRef;if(!p)return R("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let g=s.params?.scratchStoreRef,x=s.params?.archiveStoreRef,O=s.params?.chatStoreRef,X=s.params?.artifactsStoreRef,K=S();K.writeCardStoreRef(r),K.writeOutputsStoreRef(p),g&&K.writeScratchStoreRef(g),x&&K.writeArchiveStoreRef(x),O&&K.writeChatStoreRef(O),X&&K.writeArtifactsStoreRef(X);let Q=s.body??{};Q["task-executor-ref"]&&K.writeTaskExecutorRef(Q["task-executor-ref"]),Object.prototype.hasOwnProperty.call(Q,"chat-handler-flow")&&K.writeChatHandlerFlow(Q["chat-handler-flow"]);try{j().writeStatusSnapshot(Ae(i,chunkG4XXRHL2_cjs.q(l().graph)));}catch{}return T()}catch(r){return I(r)}}function N(s){try{let r=j().readStatusSnapshot();if(!r){r=Ae(i,chunkG4XXRHL2_cjs.q(l().graph));try{j().writeStatusSnapshot(r);}catch{}}return T(r)}catch(r){return I(r)}}function D(s){try{let r=s.params?.id;if(!r)return R("removeCard requires params.id");try{t.kvStorage("card-upsert").delete(r);}catch{}return d({type:"task-removal",taskName:r,timestamp:U()}),F(),T()}catch(r){return I(r)}}function M(s){try{let r=s.params?.cardId;if(!r)return R("addCardFiles requires params.cardId");let p=chunkYMEIPKLW_cjs.a(L()).appendFiles({params:{id:r},body:s.body});if(p.status!=="success")return p;let g=$({params:{cardId:r}});return g.status!=="success"?g:T({cardId:r,files_added:p.data.files_added,notified:!0})}catch(r){return I(r)}}function $(s){try{let r=s.params?.cardId;if(!r)return R("cardRefreshedNotify requires params.cardId");let p=L().readCard(r);return p?(u([{kind:"card_refreshed",cardId:r,card:p}]),T({cardId:r,notified:!0})):R(`Card "${r}" not found in board at ${e.value}`)}catch(r){return I(r)}}function oe(s){try{let r=s.params?.id;return r?(d({type:"task-restart",taskName:r,timestamp:U()}),F(),T()):R("retrigger requires params.id")}catch(r){return I(r)}}async function se(s){return E(),_()}function Se(s){try{let r=s.params?.cardId,p=s.params?.all,g=!!s.params?.restart;if(!r&&!p)return R("upsertCard requires --card-id <id> or --all");let x=p?L().readAllCards().map(O=>O.id):[r];for(let O of x)if(!L().readCard(O))return R(`Card "${O}" not found in board at ${e.value}`);for(let O of x){let X=L().readCard(O),K=wt(X),Q=t.hashFn(K),W=t.kvStorage("card-upsert"),ue=W.read(O),fe=ue?.taskConfigHash!==Q;if(!(!fe&&!g)){if(fe){let me=ue?.blobRef??L().readCardKey(O)??O;d({type:"task-upsert",taskName:O,taskConfig:K,timestamp:U()}),W.write(O,{blobRef:me,taskConfigHash:Q,updatedAt:U()});}g&&d({type:"task-restart",taskName:O,timestamp:U()});}}return F(),T()}catch(r){return I(r)}}function ae(s){try{let r=s.params?.token;if(!r)return R("taskFailed requires params.token");let p=s.params?.error??"unknown error",g=Ie(r);if(!g)return R("Invalid callback token");d({type:"task-failed",taskName:g.taskName,error:p,timestamp:U()});try{Y().stream("exec-history").append({taskName:g.taskName,status:"failed",error:p,completedAt:U()});}catch{}return F(),T()}catch(r){return I(r)}}function ie(s){try{let r=s.params?.token;if(!r)return R("taskProgress requires params.token");let g=(s.body??{}).update??{},x=Ie(r);return x?(d({type:"task-progress",taskName:x.taskName,update:g,timestamp:U()}),F(),T()):R("Invalid callback token")}catch(r){return I(r)}}function pe(s){try{let r=s.params?.token,p=s.params?.ref;if(!r)return R("sourceDataFetched requires params.token");if(!p)return R("sourceDataFetched requires params.ref");let g=xt(r);if(!g)return R("Invalid source token");let{cbk:x,cid:O,b:X,d:K,cs:Q,rqt:W,dt:ue}=g,fe=Te(t.blobStorage("sources"),he=>t.resolveBlob(he)),me=ue||t.genId();ue||fe.ingestSourceDataStaged(O,K,chunkSFVO2LB2_cjs.b(p),me);let ge=Ie(x);if(!ge)return R("Invalid callback token embedded in source token");let de=U();return d({type:"task-progress",taskName:ge.taskName,update:{bindTo:X,outputFile:K,fetchedAt:de,deliveryToken:me,sourceChecksum:Q,rqt:W},timestamp:de}),F(),T()}catch(r){return I(r)}}function b(s){try{let r=s.params?.token,p=s.params?.reason??"unknown";if(!r)return R("sourceDataFetchFailure requires params.token");let g=xt(r);if(!g)return R("Invalid source token");let{cbk:x,b:O,d:X,cs:K,rqt:Q}=g,W=Ie(x);return W?(d({type:"task-progress",taskName:W.taskName,update:{bindTo:O,outputFile:X,failure:!0,reason:p,sourceChecksum:K,rqt:Q},timestamp:U()}),F(),T()):R("Invalid callback token embedded in source token")}catch(r){return I(r)}}function k(s){try{let r=S().readCardStoreRef();return r?T({storeRef:r}):R(`Board at ${e.value} has no card store configured`)}catch(r){return I(r)}}function w(s){try{let r=S().readOutputsStoreRef();return r?T({storeRef:r}):R(`Board at ${e.value} has no outputs store configured`)}catch(r){return I(r)}}function B(s){try{let r=S().readScratchStoreRef();return T({storeRef:r})}catch(r){return I(r)}}function H(s){try{let r=S().readArchiveStoreRef();return T({storeRef:r})}catch(r){return I(r)}}function Z(s){try{let r=S().readChatStoreRef();return T({storeRef:r})}catch(r){return I(r)}}function te(s){try{let r=S().readArtifactsStoreRef();return T({storeRef:r})}catch(r){return I(r)}}function Et(s){try{let r=s.params?.key;if(!r)return R("getConfig requires params.key");let p=S(),g;switch(r){case "task-executor":g=p.readTaskExecutorRef()??null;break;case "chat-handler-flow":g=p.readChatHandlerFlow()??null;break;case "card-store-ref":g=p.readCardStoreRef();break;case "outputs-store-ref":g=p.readOutputsStoreRef();break;case "scratch-store-ref":g=p.readScratchStoreRef();break;case "archive-store-ref":g=p.readArchiveStoreRef();break;case "chat-store-ref":g=p.readChatStoreRef();break;case "artifacts-store-ref":g=p.readArtifactsStoreRef();break;default:return R(`getConfig: unknown key "${r}"`)}return T({value:g})}catch(r){return I(r)}}function At(s){try{let r=s.params?.key;if(!r)return R("getOutputsDataObject requires params.key");let p=j().readDataObject(r);return T(p)}catch(r){return I(r)}}function It(s){try{return T(j().readAllDataObjects())}catch(r){return I(r)}}function _t(s){try{let r=s.params?.key;if(!r)return R("getOutputsComputedValues requires params.key");let p=j().readComputedValues(r);return T(p)}catch(r){return I(r)}}function Ft(s){try{return T(j().readAllComputedValues())}catch(r){return I(r)}}function Le(){return Te(t.blobStorage("sources"),s=>t.resolveBlob(s))}function Ne(s){let r=t.blobStorage("sources").keyRef?.(s);return r?chunkSFVO2LB2_cjs.a(r):s}function Ot(s){try{let r=s.params?.key;if(!r)return R("getOutputsFetchedSources requires params.key");let p=Le().listSources(r),g={};for(let x of p)g[x]=Ne(`${r}/${x}`);return T(g)}catch(r){return I(r)}}function Pt(s){try{let r=Le(),p=new Set;for(let x of t.blobStorage("sources").listKeys()){let O=x.indexOf("/");O>0&&!x.includes("/.staged/")&&p.add(x.slice(0,O));}let g={};for(let x of p){let O=r.listSources(x);if(O.length>0){g[x]={};for(let X of O)g[x][X]=Ne(`${x}/${X}`);}}return T(g)}catch(r){return I(r)}}return {init:V,status:N,getCardStoreRef:k,getOutputsStoreRef:w,getScratchStoreRef:B,getArchiveStoreRef:H,getChatStoreRef:Z,getArtifactsStoreRef:te,getConfig:Et,getOutputsDataObject:At,getAllOutputsDataObjects:It,getOutputsComputedValues:_t,getAllOutputsComputedValues:Ft,getOutputsFetchedSources:Ot,getAllOutputsFetchedSources:Pt,removeCard:D,addCardFiles:M,cardRefreshedNotify:$,retrigger:oe,processAccumulatedEvents:se,upsertCard:Se,taskFailed:ae,taskProgress:ie,sourceDataFetched:pe,sourceDataFetchFailure:b}}function Rr(e,t){let n=()=>Ke(t.kvStorage("config"));function o(){let l=n().readCardStoreRef();if(!l)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let a=t.kvStorageForRef(l);return {readIndex(){return a.read("_index")},writeIndex(d){a.write("_index",d);},readCard(d){return a.read(d)},writeCard(d,C){return a.write(d,C),t.hashFn(C)},removeCard(d){a.delete(d);},cardExists(d){return a.read(d)!==null},defaultCardKey(d){return d}}}let i=()=>je(o(),t.onWarn??(()=>{}));async function u(l,a){let d=t.validateSchema(a),C=[],A=n().readTaskExecutorRef();if(A&&Array.isArray(a.source_defs))for(let _ of a.source_defs){let F=typeof _.bindTo=="string"?_.bindTo:"(unknown)";try{let V;try{V=await t.invokeExecutor(A,"validate-source-def",{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(_)});}catch(D){let M=D;if(V=typeof M?.stdout=="string"?M.stdout:"",!V.trim()){C.push(`source "${F}": executor validate-source-def failed \u2014 ${D instanceof Error?D.message:String(D)}`);continue}}let N=JSON.parse(V.trim());if(!N.ok&&Array.isArray(N.errors))for(let D of N.errors)C.push(`source "${F}": ${D}`);}catch(V){C.push(`source "${F}": executor validate-source-def failed \u2014 ${V instanceof Error?V.message:String(V)}`);}}let E=[...d.errors,...C];return T({cardId:l,isValid:E.length===0,issues:E})}function c(l,a){let d=l.params?.sourceIdx,C=l.params?.outRef;if(d===void 0)return R(`${a} requires params.sourceIdx`);if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return R(`${a} requires card JSON object in body`);let A=l.body,E=A["card-content"]??A,_=A["mock-projections"]??{},F=E.source_defs??[];if(d<0||d>=F.length)return R(`sourceIdx ${d} out of range (card has ${F.length} source(s))`);let V=F[d],N=typeof V.bindTo=="string"?V.bindTo:"source";return {src:V,bindTo:N,outRef:C,mockProjections:_}}async function f(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return R("validateCardPreflight requires card JSON object in body");let a=l.body,d=a["card-content"]??a,C=typeof d.id=="string"?d.id:"(unknown)";return await u(C,d)}catch(a){return I(a)}}async function S(l){try{let a=c(l,"probeSourcePreflight");if("status"in a)return a;let d=n().readTaskExecutorRef();if(!d)return R("No task-executor registered for this board");try{let C={...a.src,_projections:a.mockProjections},A=await t.invokeExecutor(d,"probe-source-preflight",{timeout:a.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(C)}),E=JSON.parse(A.trim());return E.ok?T({bindTo:a.bindTo,reachable:E.reachable,latencyMs:E.latencyMs,note:E.note}):R(E.error??"Preflight probe failed")}catch{return R("Executor does not support probe-source-preflight")}}catch(a){return I(a)}}async function y(l){try{let a=c(l,"runSourcePreflight");if("status"in a)return a;let d=n().readTaskExecutorRef();if(!d)return R("No task-executor registered for this board");try{let C={...a.src,_projections:a.mockProjections},A=await t.invokeExecutor(d,"run-source-preflight",{timeout:a.src.timeout??t.executorTimeouts?.probeMs??6e4,input:JSON.stringify(C)}),E=JSON.parse(A.trim());if(!E.ok)return T({bindTo:a.bindTo,ok:!1,result:null,issues:[E.error??"Preflight run failed"]});if(a.outRef){let _=chunkSFVO2LB2_cjs.b(a.outRef);t.absoluteBlob.write(_.value,JSON.stringify(E.resultValue,null,2));}return T({bindTo:typeof E.bindTo=="string"?E.bindTo:a.bindTo,ok:!0,result:E.resultValue??null,issues:[]})}catch(C){let A=C instanceof Error?C.message:String(C);return T({bindTo:a.bindTo,ok:!1,result:null,issues:[A]})}}catch(a){return I(a)}}async function P(l){try{let a=n().readTaskExecutorRef();if(!a)return R("No task-executor registered for this board");let d=await t.invokeExecutor(a,"describe-capabilities",{timeout:t.executorTimeouts?.describeMs??1e4});return T(JSON.parse(d.trim()))}catch(a){return I(a)}}function L(l){try{let a=l.body;if(!a||!Array.isArray(a.ops))return R("updatesInCardStore requires body.ops array");let d=a.ops,C=i();for(let A of d){let E=A.op,_=A.id;if(!_)return R('op is missing "id"');if(E==="update"){let F=A["card-content"];if(!F)return R(`update op for "${_}" is missing "card-content"`);C.writeCard(_,F);}else return R(`Unknown op type: "${E??"(none)"}"`)}return T()}catch(a){return I(a)}}function j(l){try{let a=l.body;if(!a||!Array.isArray(a.ids))return R("readFromCardStore requires body.ids array");let d=a.ids,C=i(),A=d.map(E=>({id:E,"card-content":C.readCard(E)}));return T({cards:A})}catch(a){return I(a)}}function Y(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return R("evalCardCompute requires a JSON object in body");let a=l.body,d=a["card-content"]??a,C=typeof d.id=="string"?d.id:"(unknown)",A=a["mock-fetched-sources"]??{},E=a["mock-requires"]??{},_=d.compute;if(!_||!Array.isArray(_)||_.length===0)return T({cardId:C,ok:!0,computed_values:{},errors:[]});let F={id:C,card_data:d.card_data??{},requires:E,source_defs:d.source_defs,compute:_},V=chunkIXZG74EW_cjs.a.runSync(F,{sourcesData:A}),N=V.node.computed_values??{},D=V.errors??[];return T({cardId:C,ok:D.length===0,computed_values:N,errors:D})}catch(a){return I(a)}}async function v(l){try{if(!l.body||typeof l.body!="object"||Array.isArray(l.body))return R("simulateCardCycle requires a JSON object in body");let a=l.body,d=a["card-content"]??a,C=typeof d.id=="string"?d.id:"(unknown)",A=a["mock-fetched-sources"]??{},E=a["mock-requires"]??{},_=await u(C,d),F=_.status==="success"?{isValid:_.data.isValid,issues:_.data.issues}:{isValid:!1,issues:[_.status==="fail"?_.error:"internal error"]},V=d.source_defs??[],N=d.card_data??{},D=[],M=[];if(V.length>0){D=chunkIXZG74EW_cjs.a.enrichSourcesSync(V,{card_data:N,requires:E});for(let k of D){let w=k.projections,B=k._projections;if(w&&B){for(let H of Object.keys(w))if(B[H]===void 0){let Z=typeof k.bindTo=="string"?k.bindTo:"(unknown)";M.push({bindTo:Z,key:H,error:`Projection "${H}" resolved to undefined`});}}}}let $=[],oe={...A},se=a["task-executor-ref"],Se=(se?.howToRun&&se?.whatToRun?se:void 0)??n().readTaskExecutorRef();for(let k=0;k<D.length;k++){let w=D[k],B=typeof w.bindTo=="string"?w.bindTo:`source_${k}`;if(!Se){$.push({bindTo:B,skipped:!0,error:"No task executor configured"});continue}try{let H={...w},Z=await t.invokeExecutor(Se,"run-source-preflight",{timeout:w.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(H)}),te=JSON.parse(Z.trim());te.ok&&!Object.prototype.hasOwnProperty.call(A,B)&&Object.prototype.hasOwnProperty.call(te,"resultValue")&&(oe[B]=te.resultValue),$.push({bindTo:B,reachable:te.reachable,latencyMs:te.latencyMs,error:te.ok?void 0:te.error});}catch{$.push({bindTo:B,skipped:!0,error:"Executor does not support run-source-preflight"});}}let ae=d.compute,ie={},pe=[];if(ae&&Array.isArray(ae)&&ae.length>0){let k={id:C,card_data:N,requires:E,source_defs:d.source_defs,compute:ae},w=chunkIXZG74EW_cjs.a.runSync(k,{sourcesData:oe});ie=w.node.computed_values??{},pe=w.errors??[];}let b=F.isValid&&M.length===0&&pe.length===0&&$.every(k=>k.reachable!==!1);return T({cardId:C,ok:b,validation:F,source_probes:$,projection_errors:M,fetched_sources:oe,computed_values:ie,compute_errors:pe})}catch(a){return I(a)}}return {validateCardPreflight:f,probeSourcePreflight:S,runSourcePreflight:y,evalCardCompute:Y,simulateCardCycle:v,describeTaskExecutorCapabilities:P,updatesInCardStore:L,readFromCardStore:j}}
|
|
2
|
-
exports.a=rr;exports.b=st;exports.c=nr;exports.d=rt;exports.e=Qt;exports.f=Zt;exports.g=er;exports.h=ut;exports.i=dt;exports.j=ct;exports.k=lt;exports.l=je;exports.m=Ee;exports.n=le;exports.o=Lt;exports.p=pt;exports.q=ft;exports.r=$t;exports.s=mt;exports.t=Ae;exports.u=De;exports.v=bt;exports.w=vt;exports.x=wt;exports.y=Cr;exports.z=Rr;//# sourceMappingURL=chunk-JJL5VOQZ.cjs.map
|
|
3
|
-
//# sourceMappingURL=chunk-JJL5VOQZ.cjs.map
|
package/lib/chunk-NJJ7WEDT.cjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
'use strict';function p(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function m(e){let n=e.payload??{};return {id:e.id,role:typeof n.role=="string"?n.role:"system",text:typeof n.text=="string"?n.text:"",files:Array.isArray(n.files)?n.files:[],turn:typeof n.turn=="string"?n.turn:"",updated_at:typeof n.updated_at=="string"?n.updated_at:""}}function R(e,n){let a=t=>`chats/${p(t)}/processing`,r=t=>`chats/${p(t)}/config`;return {append(t,i,o,u=[],s=""){return e(t).append({role:i,text:o,files:u,turn:s,updated_at:new Date().toISOString()}).id},readAll(t){return e(t).readAll().map(m)},readAfter(t,i){let o=e(t).readAfter(i);return {records:o.entries.map(m),cursor:o.newCursor}},clear(t){e(t).clear?.();},setProcessing(t,i){i?n.write(a(t),true):n.delete(a(t));},isProcessing(t){return n.read(a(t))===true},getConfig(t){return n.read(r(t))??{}},setConfig(t,i){let o=n.read(r(t))??{};n.write(r(t),{...o,...i});}}}function S(){let e=globalThis.crypto;return typeof e?.randomUUID=="function"?String(e.randomUUID()):`id-${Date.now()}-${Math.random().toString(36).slice(2)}`}function $(){let e=new Map,n=new Map;function a(r){return e.has(r)||e.set(r,[]),e.get(r)}return {append(r,t,i,o=[],u=""){let s={id:S(),role:t,text:i,files:o,turn:u,updated_at:new Date().toISOString()};return a(r).push(s),s.id},readAll(r){return a(r).slice()},readAfter(r,t){let i=a(r);if(!t)return {records:i.slice(),cursor:i.length>0?i[i.length-1].id:null};let o=i.findIndex(s=>s.id===t),u=o===-1?i.slice():i.slice(o+1);return {records:u,cursor:u.length>0?u[u.length-1].id:t}},clear(r){e.set(r,[]);},setProcessing(r,t){t?n.set(`p:${r}`,true):n.delete(`p:${r}`);},isProcessing(r){return n.get(`p:${r}`)===true},getConfig(r){return n.get(`c:${r}`)??{}},setConfig(r,t){let i=n.get(`c:${r}`)??{};n.set(`c:${r}`,{...i,...t});}}}function y(){return new Date().toISOString()}function x(e){return new TextEncoder().encode(e).byteLength}function A(e){return e?{key:e.key,size:e.size,updatedAt:e.updatedAt,contentType:e.contentType}:null}function w(e){let n=String(e||"").match(/^(\d+)[-_]/);return n?parseInt(n[1],10):0}function I(e){let n=String(e||"").trim();if(!n)return "upload.bin";let a=Math.max(n.lastIndexOf("/"),n.lastIndexOf("\\"));return (a>=0?n.slice(a+1):n)||"upload.bin"}function k(e){return String(e||"").toLowerCase().replace(/\s+/g,"_").replace(/[^a-z0-9_-]/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||"file"}function z(e){if(!e||e===".")return "";let n=String(e).replace(/^\./,"").toLowerCase().replace(/[^a-z0-9]/g,"");return n?`.${n}`:""}function F(e){let n=I(e),a=n.lastIndexOf(".");return a<=0||a===n.length-1?{stem:n,ext:""}:{stem:n.slice(0,a),ext:n.slice(a)}}function M(e){let n=e.lastIndexOf("/");return n>=0?e.slice(n+1):e}function L(e){function n(a){let r=e.stat?A(e.stat(a)):null;if(r)return r;if(!e.exists(a))return null;let t=e.read(a);return t===null?{key:a}:{key:a,size:x(t)}}return {exists(a){return e.exists(a)},putText(a,r,t="text/plain; charset=utf-8"){e.write(a,r);let i=n(a)??{key:a};return i.contentType=t,i.updatedAt=i.updatedAt??y(),i.size=i.size??x(r),i},putBytes(a,r,t="application/octet-stream"){if(e.writeBytes)e.writeBytes(a,r);else {let o=JSON.stringify({__kind:"bytes-array",data:[...r]});e.write(a,o);}let i=n(a)??{key:a};return i.contentType=t,i.updatedAt=i.updatedAt??y(),i.size=i.size??r.byteLength,i},getText(a){let r=e.read(a);if(r===null){if(!e.readBytes)return null;let t=e.readBytes(a);return t===null?null:Buffer.from(t).toString("utf-8")}try{let t=JSON.parse(r);if(t&&t.__kind==="bytes-array"&&Array.isArray(t.data))return new TextDecoder("utf-8").decode(new Uint8Array(t.data))}catch{}return r},getBytes(a){if(e.readBytes){let t=e.readBytes(a);if(t!==null)return t}let r=e.read(a);if(r===null)return null;try{let t=JSON.parse(r);if(t&&t.__kind==="bytes-array"&&Array.isArray(t.data))return new Uint8Array(t.data)}catch{}return new TextEncoder().encode(r)},head:n,list(a=""){return e.listKeys(a).map(r=>n(r)??{key:r}).sort((r,t)=>r.key.localeCompare(t.key))},remove(a){e.remove(a);}}}function b(e){function n(t,i){let o=0,u=[];Array.isArray(i)&&u.push(...i);for(let s of e.list(`${t}/`))u.push(M(s.key));for(let s of u){let l=w(s);Number.isFinite(l)&&l>o&&(o=l);}return o+1}function a(t,i,o){let u=Number(o?.maxLen||32),{stem:s,ext:l}=F(t),h=z(l),C=k(s),d=`${String(i).padStart(3,"0")}-`,g=h,f=u-d.length-g.length;f<1&&(g="",f=u-d.length);let _=C.slice(0,Math.max(1,f)),c=`${d}${_}${g}`;return c.length>u&&(c=c.slice(0,u).replace(/\.$/,"")),c}function r(t,i,o){let u=n(t,o?.seedNames),s=a(i,u,{maxLen:o?.maxLen});for(;e.exists(`${t}/${s}`);)u+=1,s=a(i,u,{maxLen:o?.maxLen});return s}return {nextSerial:n,buildStoredName:a,allocateStoredName:r}}function N(){function e(t,i){if(!Array.isArray(t))return [];let o=[];for(let u of t){if(!u||typeof u!="object")continue;let s=u;typeof s.stored_name=="string"&&o.push({name:typeof s.name=="string"?s.name:s.stored_name,stored_name:s.stored_name,size:typeof s.size=="number"&&Number.isFinite(s.size)?s.size:null,mime_type:typeof s.mime_type=="string"?s.mime_type:null,uploaded_at:typeof s.uploaded_at=="string"?s.uploaded_at:i||null,chat:s.chat===true});}return o}function n(t){return !t||typeof t!="object"?[]:e(t.files,void 0)}function a(t,i){let o=n(t);if(i.length===0)return t.files=o,o;let u=new Set(o.map(s=>s.stored_name));for(let s of i)u.has(s.stored_name)||(o.push(s),u.add(s.stored_name));return t.files=o,o}function r(t,i,o){let u=n(t);if(!Number.isInteger(i)||i<0||i>=u.length)return {ok:false,reason:"index_out_of_range"};let s=u[i];return !s||!s.stored_name?{ok:false,reason:"missing_stored_name"}:o&&o!==s.stored_name?{ok:false,reason:"stale_reference"}:{ok:true,file:s}}return {read:n,normalizeIncoming:e,merge:a,resolve:r}}exports.a=R;exports.b=$;exports.c=L;exports.d=b;exports.e=N;//# sourceMappingURL=chunk-NJJ7WEDT.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-NJJ7WEDT.cjs.map
|
package/lib/chunk-NKIQRCOM.cjs
DELETED