yaml-flow 8.11.1 → 8.11.2
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/firestore-storage.js +1 -1
- package/browser/adapters/localstorage-storage.js +1 -1
- package/browser/asset-integrity.json +5 -5
- package/browser/server-runtime-controlface.js +5 -5
- package/examples/board/test/server-http-test.js +9 -0
- package/lib/board-live-cards-node.cjs +2 -2
- package/lib/board-live-cards-node.js +1 -1
- package/lib/board-live-cards-public.cjs +1 -1
- package/lib/board-live-cards-public.js +1 -1
- package/lib/board-live-cards-server-runtime.cjs +1 -1
- package/lib/board-live-cards-server-runtime.js +1 -1
- package/lib/{chunk-U6JMXOER.cjs → chunk-42ZOYXEV.cjs} +3 -3
- package/lib/chunk-AHW6EMUO.js +3 -0
- package/lib/chunk-EYBDAEVO.cjs +3 -0
- package/lib/chunk-HFI2NAZJ.js +3 -0
- package/lib/{chunk-4LHFO56U.js → chunk-LDVJPFIW.js} +3 -3
- package/lib/chunk-ZOZ7ZDGA.cjs +3 -0
- package/lib/cloud-storage.cjs +1 -1
- package/lib/cloud-storage.js +1 -1
- package/lib/firestore-storage/index.cjs +1 -1
- package/lib/firestore-storage/index.js +1 -1
- package/lib/localstorage-storage/index.cjs +1 -1
- package/lib/localstorage-storage/index.js +1 -1
- package/lib/server-runtime/index.cjs +1 -1
- package/lib/server-runtime/index.js +1 -1
- package/lib/server-runtime-controlface/index.cjs +1 -1
- package/lib/server-runtime-controlface/index.js +1 -1
- package/package.json +1 -1
- package/lib/chunk-5U5NMYGT.js +0 -3
- package/lib/chunk-H5FKNSCO.js +0 -3
- package/lib/chunk-VNLMJEIX.cjs +0 -3
- package/lib/chunk-X5CZE2L7.cjs +0 -3
|
@@ -877,6 +877,15 @@ try {
|
|
|
877
877
|
assert(mcpSummary.completed === mcpSummary.card_count, `not all complete: ${JSON.stringify(mcpSummary)}`);
|
|
878
878
|
console.log(`[T0.4] board-status: ${JSON.stringify(mcpSummary)}`);
|
|
879
879
|
|
|
880
|
+
const t0OneShotPayload = await waitForFirstSsePayload(`${BASE}/sse?one-shot`);
|
|
881
|
+
const t0SysKeysBoardState = t0OneShotPayload?.dataObjectsByToken?.sys_keys_board_state;
|
|
882
|
+
assert(t0SysKeysBoardState && typeof t0SysKeysBoardState === 'object',
|
|
883
|
+
`T0 sys_keys_board_state missing from one-shot payload: ${JSON.stringify(t0OneShotPayload?.dataObjectsByToken)}`);
|
|
884
|
+
assert(JSON.stringify(t0SysKeysBoardState) === JSON.stringify({
|
|
885
|
+
card_ids: T0_EXPECTED_CARD_IDS,
|
|
886
|
+
data_object_keys: ['holdings', 'positions', 'quotes'],
|
|
887
|
+
}), `T0 sys_keys_board_state mismatch: ${JSON.stringify(t0SysKeysBoardState)}`);
|
|
888
|
+
|
|
880
889
|
// Verify computed_values arrived for portfolio-value card
|
|
881
890
|
const t0Positions = NS.computedValues['card-portfolio-value']?.positions;
|
|
882
891
|
assert(Array.isArray(t0Positions) && t0Positions.length > 0, 'T0 positions missing from computed_values');
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
'use strict';var chunkMCPADH33_cjs=require('./chunk-MCPADH33.cjs'),chunkCPJXGK2T_cjs=require('./chunk-CPJXGK2T.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunkH4TYOSMD_cjs=require('./chunk-H4TYOSMD.cjs'),chunk3CZCGNY4_cjs=require('./chunk-3CZCGNY4.cjs');require('./chunk-6EJRZHFP.cjs'),require('./chunk-
|
|
1
|
+
'use strict';var chunkMCPADH33_cjs=require('./chunk-MCPADH33.cjs'),chunkCPJXGK2T_cjs=require('./chunk-CPJXGK2T.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunkH4TYOSMD_cjs=require('./chunk-H4TYOSMD.cjs'),chunk3CZCGNY4_cjs=require('./chunk-3CZCGNY4.cjs');require('./chunk-6EJRZHFP.cjs'),require('./chunk-ZOZ7ZDGA.cjs');var chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkEYBDAEVO_cjs=require('./chunk-EYBDAEVO.cjs'),chunk7JVHYHT2_cjs=require('./chunk-7JVHYHT2.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs');require('./chunk-G4XXRHL2.cjs'),require('./chunk-LODXIALE.cjs');var chunkGHUW6P4G_cjs=require('./chunk-GHUW6P4G.cjs'),chunkQBEQL4TL_cjs=require('./chunk-QBEQL4TL.cjs'),chunkQEHKMLHA_cjs=require('./chunk-QEHKMLHA.cjs');require('./chunk-UJ7ZTV4J.cjs');var chunk5XLFPPTY_cjs=require('./chunk-5XLFPPTY.cjs'),chunkSDJ3747Q_cjs=require('./chunk-SDJ3747Q.cjs'),chunkP7ZCDICS_cjs=require('./chunk-P7ZCDICS.cjs');require('./chunk-2RIHC5TZ.cjs'),require('./chunk-GNFE24S7.cjs');var child_process=require('child_process'),i=require('fs'),qe=require('os'),w=require('path'),Le=require('net'),url=require('url'),crypto=require('crypto'),module$1=require('module'),properLockfile=require('proper-lockfile');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;function _interopNamespace(e){if(e&&e.__esModule)return e;var n=Object.create(null);if(e){Object.keys(e).forEach(function(k){if(k!=='default'){var d=Object.getOwnPropertyDescriptor(e,k);Object.defineProperty(n,k,d.get?d:{enumerable:true,get:function(){return e[k]}});}})}n.default=e;return Object.freeze(n)}var i__namespace=/*#__PURE__*/_interopNamespace(i);var qe__namespace=/*#__PURE__*/_interopNamespace(qe);var w__namespace=/*#__PURE__*/_interopNamespace(w);var Le__namespace=/*#__PURE__*/_interopNamespace(Le);function C(...e){return w__namespace.join(...e)}function Ne(e){return w__namespace.isAbsolute(e)}function ue(){return crypto.randomUUID()}function Qe(e){return crypto.createHash("sha256").update(e).digest("hex")}function Je(e){return w__namespace.dirname(url.fileURLToPath(e))}function Ft(e){if(typeof e=="object"&&e!==null){let{command:r,args:o=[],...n}=e,s=Oe(r,o);return {...n,command:s.command,args:s.args}}let t=De(e);if(t.length===0)throw new Error(`Empty command spec: ${JSON.stringify(e)}`);return Oe(t[0],t.slice(1))}function Oe(e,t){return /^(node|node\.exe)$/i.test(e)?{command:process.execPath,args:t}:/\.m?js$/i.test(e)?{command:process.execPath,args:[e,...t]}:{command:e,args:t}}function De(e){let t=[],r="",o=null;for(let n of e.trim()){if(o){n===o?o=null:r+=n;continue}if(n==='"'||n==="'"){o=n;continue}if(/\s/.test(n)){r&&(t.push(r),r="");continue}r+=n;}if(o)throw new Error(`Unterminated quote in command: ${e}`);return r&&t.push(r),t}function Ke(e){return process.platform==="win32"&&/\.(cmd|bat)$/i.test(e)}function We(e,t){let{command:r,args:o=[],cwd:n,env:s,timeoutMs:u}=e;return child_process.execFileSync(r,o,{shell:Ke(r),timeout:u,encoding:t?.encoding??"utf-8",cwd:n,windowsHide:true,env:s?{...process.env,...s}:void 0,input:t?.input})}function $t(e,t){let{command:r,args:o=[],cwd:n,env:s,timeoutMs:u=3e4}=e;child_process.execFile(r,o,{shell:Ke(r),encoding:"utf8",windowsHide:true,timeout:u,maxBuffer:10*1024*1024,cwd:n,env:s?{...process.env,...s}:void 0},(p,x,c)=>t(p??null,x,c));}function He(e,t,r){let o=w__namespace.join(e,"board-live-cards-cli.js");if(i__namespace.existsSync(o))return {cmd:process.execPath,args:[o,t,...r]};let n=w__namespace.join(e,"board-live-cards-cli.ts"),u=[w__namespace.join(e,"..","..","..","node_modules","tsx","dist","cli.mjs"),w__namespace.join(e,"..","..","node_modules","tsx","dist","cli.mjs"),w__namespace.join(e,"..","..","..","node_modules",".bin","tsx"),w__namespace.join(e,"..","..","node_modules",".bin","tsx")].find(x=>i__namespace.existsSync(x));return i__namespace.existsSync(n)&&u?{cmd:process.execPath,args:[u,n,t,...r]}:{cmd:process.platform==="win32"?"npx.cmd":"npx",args:["tsx",n,t,...r]}}function Ve(e){let t=w__namespace.join(e,"board-live-cards-cli.mjs");if(i__namespace.existsSync(t))return t;let r=w__namespace.join(e,"..","..","..","dev","board-live-cards-cli.js");if(i__namespace.existsSync(r))return r;let o=w__namespace.join(e,"..","..","dev","board-live-cards-cli.js");if(i__namespace.existsSync(o))return o;let n=w__namespace.join(e,"board-live-cards-cli.js");if(i__namespace.existsSync(n))return n;throw new Error(`resolveBoardCliCallbackTarget: cannot find callback target in ${e} (expected dev/board-live-cards-cli.js wrapper, ${n}, or ${t})`)}function Mt(e){return process.platform==="win32"?`\\\\.\\pipe\\${e}`:w__namespace.join(qe__namespace.tmpdir(),`${e}.sock`)}var ce=new Map;function Ue(e,t,r){if(t.length===0)return;let o=t.map(p=>JSON.stringify(p)).join(`
|
|
2
2
|
`)+`
|
|
3
3
|
`,n=ce.get(e);if(n&&!n.socket.destroyed){n.ready?n.socket.write(o):n.queue.push(o);return}let s=Mt(e),u=Le__namespace.createConnection(s);n={socket:u,ready:false,queue:[o]},ce.set(e,n),u.on("connect",()=>{n.ready=true;for(let p of n.queue)u.write(p);n.queue.length=0;}),u.on("error",p=>{r?.(`[named-pipe publish] ${s}: ${p instanceof Error?p.message:String(p)}`),ce.delete(e);}),u.on("close",()=>{ce.delete(e);});}function ze(){return {executeSync(e,t,r){return We({command:e,args:t,cwd:r?.cwd,timeoutMs:r?.timeout,env:r?.env},{encoding:r?.encoding,input:r?.input})},executeAsync(e,t,r){$t({command:e,args:t},r);},resolveInvocation(e,t){let r=Ft({command:e,args:t});return {cmd:r.command,args:r.args??[]}},splitCommand:De}}function xe(e){return {id:e.id??"board-worker",pollIntervalMs:e.pollIntervalMs,visibilityMs:e.visibilityMs,concurrency:e.concurrency,maxAttempts:e.maxAttempts,async lease(t){return e.workerStore.leaseRequests(t).map(r=>({id:r.messageId,attempt:r.attempt,message:r.request,ack:()=>e.workerStore.ackRequest(r.messageId,r.leaseToken),nack:o=>e.workerStore.nackRequest(r.messageId,r.leaseToken,o)}))},async handle(t){await e.handleRequest(t.args,t);},onError:e.onError}}function we(e){return {id:e.id,pollIntervalMs:e.pollIntervalMs,visibilityMs:e.visibilityMs,concurrency:e.concurrency,maxAttempts:e.maxAttempts,async lease(t){return e.queueStorage.lease(t).map(r=>({id:r.id,attempt:r.attempt,message:r.body,ack:()=>e.queueStorage.ack(r.id,r.leaseToken),nack:o=>e.queueStorage.nack(r.id,r.leaseToken,o)}))},handle:e.handleMessage,onError:e.onError}}async function Ge(e,t){try{await e.handle(t.message,t),await t.ack();}catch(r){let o=t.attempt>=Math.max(1,Math.floor(e.maxAttempts??5));await t.nack({dead:o,reason:r instanceof Error?r.message:String(r)}),e.onError?.(r,t);}}function Ye(e){let t=Math.max(1,Math.floor(e.pollIntervalMs??250)),r=Math.max(1,Math.floor(e.visibilityMs??6e4)),o=Math.max(1,Math.floor(e.concurrency??1)),n=false,s=false;async function u(){if(!(n||s)){s=true;try{let x=await e.lease({max:o,visibilityMs:r});for(let c of x)await Ge(e,c);}finally{s=false;}}}let p=setInterval(()=>{u();},t);return typeof p.unref=="function"&&p.unref(),u(),()=>{n=true,clearInterval(p);}}async function _t(e){let t=Math.max(1,Math.floor(e.visibilityMs??6e4)),r=Math.max(1,Math.floor(e.concurrency??1)),o=await e.lease({max:r,visibilityMs:t});for(let n of o)await Ge(e,n);return o.length}async function de(e,t){let r=Math.max(1,Math.floor(t?.maxPasses??256)),o=0;for(let n=0;n<r;n+=1){let s=await _t(e);if(o+=s,s<=0)return o}throw new Error(`drainQueueLaneToIdle exceeded ${r} passes for lane "${e.id}"`)}function Ot(e){let r=(Array.isArray(e)?e:e.lanes).map(o=>Ye(o));return ()=>{for(let o of r)o();}}var Lt=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('board-live-cards-node.cjs', document.baseURI).href)));function Nt(e){return typeof e=="object"?e:chunkVQCIOKJV_cjs.b(e)}function Xe(e){let t=w__namespace.basename(String(e||"").trim());if(!t)throw new Error(`resolveYamlFlowCliPath: expected non-empty cli file name, got ${JSON.stringify(e)}`);let r=w__namespace.dirname(Lt.resolve("yaml-flow/package.json")),o=t.replace(/\.[^.]+$/,""),n=w__namespace.join(r,"cli","bundled",`${o}.mjs`);if(i__namespace.existsSync(n))return n;let s=w__namespace.join(r,"cli","node",t);if(i__namespace.existsSync(s))return s;throw new Error(`resolveYamlFlowCliPath: could not find ${t} under cli/bundled or cli/node in ${r}`)}function L(e){let t=Nt(e);return t.kind==="yaml-flow-cli"?Xe(t.value):t.value}function Qt(e,t){let r=L(e);switch(r){case "source-cli-task-executor":{let o=w__namespace.join(t,"source-cli-task-executor.js");if(i__namespace.existsSync(o))return {command:process.execPath,args:[o]};let n=w__namespace.join(t,"source-cli-task-executor.ts"),s=w__namespace.join(t,"..","..","node_modules","tsx","dist","cli.mjs"),u=w__namespace.join(t,"..","..","node_modules",".bin","tsx"),p=i__namespace.existsSync(s)?s:u;return i__namespace.existsSync(n)&&i__namespace.existsSync(p)?{command:process.execPath,args:[p,n]}:{command:process.execPath,args:[o]}}case "board-live-cards":{let{cmd:o,args:n}=He(t,"_",[]);return {command:o,args:n}}default:throw new Error(`resolveBuiltIn: unknown built-in name "${r}". Supported: source-cli-task-executor, board-live-cards`)}}function Jt(e,t){if(e.howToRun==="built-in"){let{command:o,args:n}=Qt(e.whatToRun,t);return {command:o,baseArgs:n}}let r=(typeof e.whatToRun=="object",L(e.whatToRun));switch(e.howToRun){case "local-node":return {command:process.execPath,baseArgs:[r]};case "local-python":return {command:process.platform==="win32"?"python":"python3",baseArgs:[r]};case "local-process":return {command:r,baseArgs:[]};default:throw new Error(`resolveBaseInvocation: howToRun "${e.howToRun}" is not a local transport`)}}function le(e,t){return Jt(e,t)}var be=new Map;function Dt(e,t){let r=String(e||"").trim();if(!r)throw new Error("registerInProcessExecutionHandler: key is required");be.set(r,t);}function Kt(e){let t=String(e||"").trim();t&&be.delete(t);}function et(e){let t=e.trim();if(!t)throw new Error("empty stdout");try{return JSON.parse(t)}catch{let r=t.split(/\r?\n/).filter(Boolean),o=r[r.length-1];return JSON.parse(o)}}function tt(e,t){return {...t,whatToRun:L(e.whatToRun),...e.extra?{extra:e.extra}:{}}}function ke(e,t,r="invokeExecutionRef"){return chunk3CZCGNY4_cjs.a(e,t,r)}function rt(e,t){if(e&&typeof e=="object"&&!Array.isArray(e)&&typeof e.result=="string"&&e.data&&typeof e.data=="object"&&!Array.isArray(e.data))return {...e,...t||{}};if(e&&typeof e=="object"&&!Array.isArray(e)&&typeof e.status=="string"){let o=e,n=o.status==="success"?"success":o.status==="fail"?"failure":o.status,s=o.data&&typeof o.data=="object"&&!Array.isArray(o.data)?o.data:o.data===void 0?{}:{stdout:o.data};return {result:n,data:s,...typeof o.error=="string"?{error:o.error}:{},...t||{}}}return {result:"success",data:e&&typeof e=="object"&&!Array.isArray(e)?e:{stdout:e},...t||{}}}function q(e){return {result:"failure",data:{error:e}}}function V(e,t,r){let o=r?.label??"invokeExecutionRefSync",n=r?.cliDir??r?.cwd??process.cwd(),s;try{s=ke(e.argsMassaging,tt(e,t),o);}catch(h){let R=h instanceof Error?h.message:String(h);return q(R)}let u;try{u=le(e,n);}catch(h){let R=h instanceof Error?h.message:String(h);return q(`[${o}] ref resolution failed: ${R}`)}let p=[...u.baseArgs,...s.cmdArgs??[]],x=JSON.stringify(s.stdin??t),c=ze(),l;try{l=c.executeSync(u.command,p,{timeout:r?.timeoutMs??3e4,encoding:"utf-8",cwd:r?.cwd,input:x});}catch(h){let R=h,y=(R.stderr?String(R.stderr):"").trim(),d=typeof R.status=="number"?R.status:"unknown",f=y||R.message;return q(`[${o}] ref exited with status ${d}${f?`: ${f}`:""}`)}try{return rt(et(l))}catch{return {result:"success",data:{stdout:l.trim()}}}}async function Ze(e,t,r){let o=r?.label??"invokeExecutionRef",n;try{n=ke(e.argsMassaging,tt(e,t),o);}catch(h){let R=h instanceof Error?h.message:String(h);return q(R)}let s=L(e.whatToRun),u=n.headers?{"Content-Type":"application/json",...n.headers}:{"Content-Type":"application/json"},p=n.url??s,x;if(e.howToRun==="http:get"){let h=n.body&&typeof n.body=="object"&&!Array.isArray(n.body)?n.body:t,R=new URLSearchParams(Object.entries(h).filter(([,y])=>y!=null).map(([y,d])=>[y,String(d)]));R.size>0&&(p=`${p}${p.includes("?")?"&":"?"}${R.toString()}`);}else x=JSON.stringify(n.body??t);let c={method:e.howToRun==="http:get"?"GET":"POST",headers:u,body:x},l=0;for(;;)try{let h=await fetch(p,c);if(!h.ok){let f=await h.text().catch(()=>"");return q(`[${o}] HTTP ${h.status}${f?`: ${f}`:""}`)}let R={};h.headers.forEach((f,m)=>{R[m]=f;});let y=new Uint8Array(await h.arrayBuffer());if(y.byteLength===0)return {result:"success",data:{},headers:R};let d=new TextDecoder().decode(y);try{return rt(et(d),{headers:R})}catch{return {result:"success",data:{stdout:d},headers:R}}}catch(h){let R=h?.cause,y=R&&typeof R=="object"&&"code"in R?String(R.code||""):"";if((y==="ECONNRESET"||y==="UND_ERR_SOCKET")&&l===0){l+=1;continue}let f=h instanceof Error?h.message:String(h),m=R instanceof Error?`${R.name}: ${R.message}${y?` [${y}]`:""}`:R?String(R):"",S=n.url??s??"",a=`${f}${m?` (cause: ${m})`:""}${S?` url=${S}`:""}`;return q(`[${o}] ${a}`)}}async function Wt(e,t,r){let o=r?.label??"invokeExecutionRef",n=L(e.whatToRun).trim();if(!n)return q(`[${o}] in-process-loop requires a non-empty handler key`);let s=be.get(n);if(!s)return q(`[${o}] no in-process handler registered for: ${n}`);try{return await s(e,t,r)}catch(u){let p=u instanceof Error?u.message:String(u);return q(`[${o}] ${p}`)}}var Ht={"local-node":async(e,t,r)=>V(e,t,r),"local-python":async(e,t,r)=>V(e,t,r),"local-process":async(e,t,r)=>V(e,t,r),"built-in":async(e,t,r)=>V(e,t,r),"http:post":Ze,"http:get":Ze,"in-process-loop":Wt},Vt={"local-node":V,"local-python":V,"local-process":V,"built-in":V};async function Z(e,t,r){let o=r?.transports?.[e.howToRun]??Ht[e.howToRun];return o?o(e,t,r):q(`[${r?.label??"invokeExecutionRef"}] unsupported howToRun: ${e.howToRun}`)}function ve(e,t,r){let o=r?.syncTransports?.[e.howToRun]??Vt[e.howToRun];return o?o(e,t,r):q(`[${r?.label??"invokeExecutionRefSync"}] unsupported sync howToRun: ${e.howToRun}`)}function Ut(e){return {invoke(t,r){return Z(t,r,e)},invokeSync(t,r){return ve(t,r,e)}}}function zt(e,t,r){return ve(e,t,r)}function Ae(e={}){let t=e.resolveRef??(r=>r);return {...e.executorTimeouts?{executorTimeouts:e.executorTimeouts}:{},async invokeExecutor(r,o,n){let s=t(r);if(s.howToRun==="queue-storage")throw new Error("queue-storage does not support inline executor request/response");if(s.howToRun==="http:post"||s.howToRun==="in-process-loop"){let l=await chunkH4TYOSMD_cjs.h(s,{subcommand:o,...n?.input!==void 0?{input:n.input}:{}});return typeof l=="string"?l:l&&typeof l=="object"&&!Array.isArray(l)&&typeof l.stdout=="string"?String(l.stdout):JSON.stringify(l??{})}if(s.howToRun==="http:get"){let l=await Z(s,{subcommand:o,...n?.input!==void 0?{input:n.input}:{},...s.extra?{extra:s.extra}:{}},{cwd:process.cwd(),timeoutMs:n?.timeout??3e4,label:`invokeExecutor:${o}`});if(l.result!=="success"){let h=typeof l.data?.error=="string"?l.data.error:l.error;throw new Error(h||`executor request failed: ${l.result}`)}return typeof l.data?.stdout=="string"?l.data.stdout:JSON.stringify(l.data??{})}if(!e.resolveCliDir)throw new Error(`createNonCoreExecutorDispatcher: ref.howToRun="${s.howToRun}" requires opts.resolveCliDir`);let{command:u,baseArgs:p}=le(s,e.resolveCliDir()),x=s.extra?["--extra",Buffer.from(JSON.stringify(s.extra)).toString("base64")]:[],c=[...p,o,...x];return await new Promise((l,h)=>{let R=child_process.spawn(u,c,{cwd:process.cwd(),stdio:"pipe",windowsHide:true,shell:process.platform==="win32"&&/\.(cmd|bat)$/i.test(u)}),y=[],d=[],f=false,m=null,S=g=>{f||(f=true,m&&clearTimeout(m),h(g));},a=g=>{f||(f=true,m&&clearTimeout(m),l(g));};R.stdout.on("data",g=>{y.push(Buffer.from(g));}),R.stderr.on("data",g=>{d.push(Buffer.from(g));}),R.on("error",g=>{let v=g;v.stdout=Buffer.concat(y).toString("utf-8"),v.stderr=Buffer.concat(d).toString("utf-8"),S(v);}),R.on("close",g=>{let v=Buffer.concat(y).toString("utf-8"),b=Buffer.concat(d).toString("utf-8");if(g===0){a(v);return}let k=new Error(b.trim()||`executor exited with status ${g}`);k.stdout=v,k.stderr=b,S(k);}),n?.timeout&&n.timeout>0&&(m=setTimeout(()=>{R.kill();let g=new Error(`executor timed out after ${n.timeout}ms`);g.stdout=Buffer.concat(y).toString("utf-8"),g.stderr=Buffer.concat(d).toString("utf-8"),S(g);},n.timeout)),n?.input!==void 0?R.stdin.end(n.input):R.stdin.end();})}}}function B(e,t){if(process.platform!=="win32"){i__namespace.renameSync(e,t);return}let r=[10,20,40,80,160];for(let o=0;o<=r.length;o++)try{i__namespace.renameSync(e,t);return}catch(n){let s=n.code;if((s==="EPERM"||s==="EBUSY")&&o<r.length){Atomics.wait(new Int32Array(new SharedArrayBuffer(4)),0,0,r[o]);continue}throw n}}function U(e){function t(n){return w__namespace.join(e,...n.split("/"))}function r(n){return w__namespace.relative(e,n).replace(/\\/g,"/")}function o(n,s){if(i__namespace.existsSync(n))for(let u of i__namespace.readdirSync(n,{withFileTypes:true})){let p=w__namespace.join(n,u.name);if(u.isDirectory()){o(p,s);continue}u.isFile()&&s.push(r(p));}}return {read(n){let s=t(n);if(!i__namespace.existsSync(s))return null;try{return i__namespace.readFileSync(s,"utf-8")}catch{return null}},write(n,s){let u=t(n),p=`${u}.${process.pid}.${crypto.randomUUID()}.tmp`;i__namespace.mkdirSync(w__namespace.dirname(u),{recursive:true}),i__namespace.writeFileSync(p,s,"utf-8"),B(p,u);},exists(n){return i__namespace.existsSync(t(n))},remove(n){let s=t(n);try{i__namespace.existsSync(s)&&i__namespace.unlinkSync(s);}catch{}},readBytes(n){let s=t(n);if(!i__namespace.existsSync(s))return null;try{return new Uint8Array(i__namespace.readFileSync(s))}catch{return null}},writeBytes(n,s){let u=t(n),p=`${u}.${process.pid}.${crypto.randomUUID()}.tmp`;i__namespace.mkdirSync(w__namespace.dirname(u),{recursive:true}),i__namespace.writeFileSync(p,Buffer.from(s)),B(p,u);},listKeys(n){let s=[];o(e,s);let u=s.sort();return n?u.filter(p=>p.startsWith(n)):u},stat(n){let s=t(n);if(!i__namespace.existsSync(s))return null;try{let u=i__namespace.statSync(s);return {key:n,size:Number(u.size||0),updatedAt:new Date(u.mtimeMs).toISOString()}}catch{return null}},keyRef(n){return {kind:"fs-path",value:t(n)}},renameKey(n,s){let u=t(n);if(!i__namespace.existsSync(u))return false;let p=t(s);return i__namespace.mkdirSync(w__namespace.dirname(p),{recursive:true}),B(u,p),true}}}function Ie(){return {read(e){if(!i__namespace.existsSync(e))return null;try{return i__namespace.readFileSync(e,"utf-8")}catch{return null}},write(e,t){let r=`${e}.${process.pid}.${crypto.randomUUID()}.tmp`;i__namespace.mkdirSync(w__namespace.dirname(e),{recursive:true}),i__namespace.writeFileSync(r,t,"utf-8"),B(r,e);},exists(e){return i__namespace.existsSync(e)},remove(e){try{i__namespace.existsSync(e)&&i__namespace.unlinkSync(e);}catch{}},readBytes(e){if(!i__namespace.existsSync(e))return null;try{return new Uint8Array(i__namespace.readFileSync(e))}catch{return null}},writeBytes(e,t){let r=`${e}.${process.pid}.${crypto.randomUUID()}.tmp`;i__namespace.mkdirSync(w__namespace.dirname(e),{recursive:true}),i__namespace.writeFileSync(r,Buffer.from(t)),B(r,e);},stat(e){if(!i__namespace.existsSync(e))return null;try{let t=i__namespace.statSync(e);return {key:e,size:Number(t.size||0),updatedAt:new Date(t.mtimeMs).toISOString()}}catch{return null}},listKeys(e){return []},renameKey(e,t){return i__namespace.existsSync(e)?(i__namespace.mkdirSync(w__namespace.dirname(t),{recursive:true}),B(e,t),true):false}}}function D(e,t){let r=`${e}.${process.pid}.${crypto.randomUUID()}.tmp`;i__namespace.mkdirSync(w__namespace.dirname(e),{recursive:true}),i__namespace.writeFileSync(r,JSON.stringify(t,null,2),"utf-8"),B(r,e);}function N(e){if(!i__namespace.existsSync(e))return null;try{return JSON.parse(i__namespace.readFileSync(e,"utf-8"))}catch{return null}}function X(e){return i__namespace.existsSync(e)?i__namespace.readdirSync(e).filter(t=>t.endsWith(".json")).sort().map(t=>w__namespace.join(e,t)):[]}function ee(e){return {id:e.id,body:e.body,enqueuedAt:e.enqueuedAt,attempt:e.attempt}}function Xt(e){return {...ee(e),leaseToken:String(e.leaseToken||""),leaseExpiresAt:String(e.leaseExpiresAt||"")}}function er(e){return {...ee(e),reason:e.reason}}function je(e){let t=w__namespace.join(e,"active"),r=w__namespace.join(e,"leased"),o=w__namespace.join(e,"done"),n=w__namespace.join(e,"dead"),s=w__namespace.join(e,"staged");for(let d of [t,r,o,n,s])i__namespace.mkdirSync(d,{recursive:true});let u=0;function p(d){let f=d.replace(/[:.]/g,"-"),m=String(u++).padStart(6,"0");return `${f}-${m}`}function x(d){let f=d.activeOrderKey||p(String(d.enqueuedAt||new Date().toISOString()));return w__namespace.join(t,`${f}-${d.id}.json`)}function c(d){return w__namespace.join(r,`${d}.json`)}function l(d){return w__namespace.join(o,`${d}.json`)}function h(d){return w__namespace.join(n,`${d}.json`)}function R(d){return w__namespace.join(s,`${d}.json`)}function y(){let d=Date.now();for(let f of X(r)){let m=N(f);if(!m?.leaseExpiresAt)continue;let S=Date.parse(m.leaseExpiresAt);if(Number.isNaN(S)||S>d)continue;let a={id:m.id,body:m.body,enqueuedAt:m.enqueuedAt,attempt:m.attempt,activeOrderKey:m.activeOrderKey};D(x(a),a);try{i__namespace.unlinkSync(f);}catch{}}}return {enqueue(d){let f={id:crypto.randomUUID(),body:d,enqueuedAt:new Date().toISOString(),attempt:0};return f.activeOrderKey=p(f.enqueuedAt),D(x(f),f),ee(f)},enqueueMany(d){return d.map(f=>this.enqueue(f))},enqueueIfAbsent(d,f){y();for(let S of [t,r,s])for(let a of X(S))if(N(a)?.dedupKey===f)return null;let m={id:crypto.randomUUID(),body:d,enqueuedAt:new Date().toISOString(),attempt:0,dedupKey:f};return m.activeOrderKey=p(m.enqueuedAt),D(x(m),m),ee(m)},lease(d){y();let f=Math.max(1,Math.floor(d?.max??1)),m=Math.max(1,Math.floor(d?.visibilityMs??6e4)),S=[];for(let a of X(t)){if(S.length>=f)break;let g=N(a);if(!g)continue;let v=c(g.id);try{B(a,v);}catch{continue}let b={...g,attempt:(Number(g.attempt)||0)+1,leaseToken:crypto.randomUUID(),leaseExpiresAt:new Date(Date.now()+m).toISOString()};D(v,b),S.push(Xt(b));}return S},ack(d,f){let m=c(d),S=N(m);if(!S||S.leaseToken!==f)return false;try{B(m,l(d));}catch{return false}return true},nack(d,f,m){let S=c(d),a=N(S);if(!a||a.leaseToken!==f)return false;let g={id:a.id,body:a.body,enqueuedAt:a.enqueuedAt,attempt:a.attempt,activeOrderKey:a.activeOrderKey};m?.dead?(g.reason=m.reason,D(h(d),g)):D(x(g),g);try{i__namespace.unlinkSync(S);}catch{}return true},peekActive(d){return y(),X(t).map(f=>N(f)).filter(f=>!!f).map(ee)},peekDeadLetter(d){return X(n).map(f=>N(f)).filter(f=>!!f).map(er)},stage(d,f){let m=f?.dedupKey;if(m){y();for(let a of [t,r,s])for(let g of X(a))if(N(g)?.dedupKey===m)return null}let S={id:crypto.randomUUID(),body:d,enqueuedAt:new Date().toISOString(),attempt:0,...m?{dedupKey:m}:{}};return D(R(S.id),S),ee(S)},commitStaged(d){let f=R(d),m=N(f);if(!m)return false;let S=new Date().toISOString(),a={...m,attempt:0,enqueuedAt:S,activeOrderKey:p(S)};D(x(a),a);try{i__namespace.unlinkSync(f);}catch{}return true},discardStaged(d,f){let m=R(d),S=N(m);if(!S)return false;let a={id:S.id,body:S.body,enqueuedAt:S.enqueuedAt,attempt:S.attempt,reason:f};D(h(d),a);try{i__namespace.unlinkSync(m);}catch{}return true},peekStaged(d){return X(s).map(f=>N(f)).filter(f=>!!f).map(ee)}}}var Ee="__scratch-marker",Te="__scratch-config.json",tr=1440*60*1e3,rr=720*60*1e3,nr=500;function nt(e,t){if(!e)return t;let r=e.replace(/[^A-Za-z0-9._-]/g,"_");return r.length>0?r:t}function oe(e){i__namespace.mkdirSync(e,{recursive:true});let t=w__namespace.join(e,Ee),r=w__namespace.join(e,Te),o=!i__namespace.existsSync(t);if(o)try{i__namespace.writeFileSync(t,`scratch-store
|
|
4
4
|
${new Date().toISOString()}
|
|
@@ -8,5 +8,5 @@ ${new Date().toISOString()}
|
|
|
8
8
|
`).filter(Boolean).map(o=>JSON.parse(o)):[]}return {append(r){let o={id:crypto.randomUUID(),payload:r};return i__namespace.mkdirSync(w__namespace.dirname(e),{recursive:true}),i__namespace.appendFileSync(e,JSON.stringify(o)+`
|
|
9
9
|
`,"utf-8"),o},readAll(){return t()},readAfter(r){let o=t();if(!r)return {entries:o,newCursor:o.length>0?o[o.length-1].id:null};let n=o.findIndex(u=>u.id===r),s=n===-1?o:o.slice(n+1);return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},clear(){i__namespace.existsSync(e)&&i__namespace.truncateSync(e,0);}}}function Ce(e){if(e==null||typeof e!="object")return JSON.stringify(e);if(Array.isArray(e))return `[${e.map(Ce).join(",")}]`;let t=e;return `{${Object.keys(t).sort().map(o=>`${JSON.stringify(o)}:${Ce(t[o])}`).join(",")}}`}function st(e){return crypto.createHash("sha256").update(Ce(e)).digest("hex")}function Be(e){let t=w__namespace.join(e,"board-journal.jsonl");return {readAllEntries(){if(!i__namespace.existsSync(t))return [];let r=i__namespace.readFileSync(t,"utf-8").trim();return r?r.split(`
|
|
10
10
|
`).filter(Boolean).map(o=>JSON.parse(o)):[]},appendEntry(r){i__namespace.appendFileSync(t,JSON.stringify(r)+`
|
|
11
|
-
`,"utf-8");},generateId(){return crypto.randomUUID()}}}function it(e){return {tryAcquire(){try{if(!i__namespace.existsSync(e)){i__namespace.mkdirSync(w__namespace.dirname(e),{recursive:!0});try{i__namespace.writeFileSync(e,"{}",{flag:"wx"});}catch{}}return properLockfile.lockSync(e,{retries:0})}catch{return null}}}}function z(e){return {status:"success",data:e}}function Q(e){return {status:"fail",error:e}}function re(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function ne(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}function ar(e,t={}){let r=()=>chunkWRMOGPRG_cjs.b(e.kvStorage("config")),o=t.unsupportedLabel??"hosted async runtime";async function n(){return t.taskExecutorRef?t.taskExecutorRef:await r().readTaskExecutorRef().catch(()=>{})}async function s(y,d,f){let m=await n();if(!m||!t.invokeExecutor)throw new Error(`${y} is not supported on the ${o} yet`);let a=(await t.invokeExecutor(m,y,{...d!==void 0?{input:typeof d=="string"?d:JSON.stringify(d)}:{},...f!==void 0?{timeout:f}:{}})).trim();return a?ne(JSON.parse(a)):{}}async function u(y){try{if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("validateCardPreflight requires card JSON object in body");let d=y.body,f=d["card-content"]??d,m=typeof f.id=="string"?f.id:"(unknown)",S=chunkCPJXGK2T_cjs.a(f),a=Array.isArray(f.source_defs)&&f.source_defs.length>0,g=[...S.issues];if(a)if(t.invokeExecutor&&await n())for(let v of f.source_defs){let b=typeof v.bindTo=="string"?v.bindTo:"(unknown)";try{let k=await s("validate-source-def",v,1e4);if(k.ok!==!0&&Array.isArray(k.errors))for(let A of k.errors)typeof A=="string"&&A&&g.push(`source "${b}": ${A}`);}catch(k){g.push(`source "${b}": executor validate-source-def failed \u2014 ${k instanceof Error?k.message:String(k)}`);}}else await n()&&g.push(`executor-backed source_def preflight is not supported on the ${o} yet`);return z({cardId:m,isValid:g.length===0,issues:g})}catch(d){return re(d)}}function p(y){try{if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("evalCardCompute requires a JSON object in body");let d=y.body,f=d["card-content"]??d,m=typeof f.id=="string"?f.id:"(unknown)",S=d["mock-fetched-sources"]??{},a=d["mock-requires"]??{},g=f.compute;if(!g||!Array.isArray(g)||g.length===0)return z({cardId:m,ok:!0,computed_values:{},errors:[]});let v={id:m,card_data:f.card_data??{},requires:a,source_defs:f.source_defs,compute:g},b=chunkQBEQL4TL_cjs.a.runSync(v,{sourcesData:S});return z({cardId:m,ok:(b.errors??[]).length===0,computed_values:b.node.computed_values??{},errors:b.errors??[]})}catch(d){return re(d)}}async function x(y){return Q(`${y} is not supported on the ${o} yet`)}async function c(){try{return t.invokeExecutor&&await n()?z(await s("describe-capabilities",void 0,1e4)):await x("describeTaskExecutorCapabilities")}catch(y){return re(y)}}async function l(y){try{if(!t.invokeExecutor||!await n())return await x("probeSourcePreflight");if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("probeSourcePreflight requires card JSON object in body");let d=y.body,f=d["card-content"]??d,m=ne(d["mock-projections"]??{}),S=y.params?.sourceIdx,a=Array.isArray(f.source_defs)?f.source_defs:[];if(S===void 0)return Q("probeSourcePreflight requires params.sourceIdx");if(S<0||S>=a.length)return Q(`sourceIdx ${S} out of range (card has ${a.length} source(s))`);let g=a[S],v=typeof g.bindTo=="string"?g.bindTo:"source",b=await s("probe-source-preflight",{...g,_projections:m},g.timeout??6e4);return b.ok!==!0?Q(typeof b.error=="string"?b.error:"Preflight probe failed"):z({bindTo:v,reachable:b.reachable,latencyMs:b.latencyMs,...typeof b.note=="string"?{note:b.note}:{}})}catch(d){return re(d)}}async function h(y){try{if(!t.invokeExecutor||!await n())return await x("runSourcePreflight");if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("runSourcePreflight requires card JSON object in body");let d=y.body,f=d["card-content"]??d,m=ne(d["mock-projections"]??{}),S=y.params?.sourceIdx,a=Array.isArray(f.source_defs)?f.source_defs:[];if(S===void 0)return Q("runSourcePreflight requires params.sourceIdx");if(S<0||S>=a.length)return Q(`sourceIdx ${S} out of range (card has ${a.length} source(s))`);let g=a[S],v=typeof g.bindTo=="string"?g.bindTo:"source",b=await s("run-source-preflight",{...g,_projections:m},g.timeout??6e4);return b.ok!==!0?z({bindTo:v,ok:!1,result:null,issues:[typeof b.error=="string"?b.error:"Preflight run failed"]}):z({bindTo:v,ok:!0,result:Object.prototype.hasOwnProperty.call(b,"resultValue")?b.resultValue:null,issues:[]})}catch(d){return re(d)}}async function R(y){try{if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("simulateCardCycle requires a JSON object in body");let d=y.body,f=d["card-content"]??d,m=typeof f.id=="string"?f.id:"(unknown)",S=ne(d["mock-fetched-sources"]??{}),a=ne(d["mock-requires"]??{}),g=await u({body:{"card-content":f}}),v=g.status==="success"?{isValid:g.data.isValid,issues:g.data.issues}:{isValid:!1,issues:[g.status==="fail"?g.error:"internal error"]},b=Array.isArray(f.source_defs)?f.source_defs:[],k=ne(f.card_data??{}),A=[],F=[];if(b.length>0){A=chunkQBEQL4TL_cjs.a.enrichSourcesSync(b,{card_data:k,requires:a});for(let I of A){let P=I.projections,W=I._projections;if(P&&W){for(let $ of Object.keys(P))if(W[$]===void 0){let ut=typeof I.bindTo=="string"?I.bindTo:"(unknown)";F.push({bindTo:ut,key:$,error:`Projection "${$}" resolved to undefined`});}}}}let E=[],M={...S};for(let I=0;I<A.length;I+=1){let P=A[I],W=typeof P.bindTo=="string"?P.bindTo:`source_${I}`;if(!t.invokeExecutor||!await n()){E.push({bindTo:W,skipped:!0,error:"No task executor configured"});continue}try{let $=await s("run-source-preflight",P,P.timeout??6e4);$.ok===!0&&!Object.prototype.hasOwnProperty.call(S,W)&&Object.prototype.hasOwnProperty.call($,"resultValue")&&(M[W]=$.resultValue),E.push({bindTo:W,reachable:$.reachable,latencyMs:$.latencyMs,...$.ok===!0?{}:{error:typeof $.error=="string"?$.error:"Preflight run failed"}});}catch{E.push({bindTo:W,skipped:!0,error:"Executor does not support run-source-preflight"});}}let K=f.compute,te={},G=[];if(K&&Array.isArray(K)&&K.length>0){let I={id:m,card_data:k,requires:a,source_defs:f.source_defs,compute:K},P=chunkQBEQL4TL_cjs.a.runSync(I,{sourcesData:M});te=P.node.computed_values??{},G=P.errors??[];}return z({cardId:m,ok:v.isValid&&F.length===0&&G.length===0&&E.every(I=>!I.error),validation:v,source_probes:E,projection_errors:F,fetched_sources:M,computed_values:te,compute_errors:G})}catch(d){return re(d)}}return {describeTaskExecutorCapabilities:c,validateCardPreflight:u,evalCardCompute:p,probeSourcePreflight:l,runSourcePreflight:h,simulateCardCycle:R}}function sn(){return {async invoke(e,t){if(e.howToRun!=="local-node")return {dispatched:false,error:`createNodeSpawnInvocationAdapter: unsupported howToRun "${e.howToRun}"`};let r="";try{let s=e.whatToRun;r=L(s);}catch{r="";}if(!r)return {dispatched:false,error:"createNodeSpawnInvocationAdapter: could not resolve executable path from whatToRun"};let o={...t},n=Buffer.from(JSON.stringify(o)).toString("base64");try{return child_process.spawn(process.execPath,[r,"--boardId",String(t.boardId??""),"--cardId",String(t.cardId??""),"--extraEncJson",n],{stdio:"ignore",windowsHide:!0}).unref(),{dispatched:!0}}catch(s){return {dispatched:false,error:s instanceof Error?s.message:String(s)}}},async describe(e){if(e.howToRun!=="local-node")return null;let t="";try{let r=e.whatToRun;t=L(r);}catch{t="";}if(!t)return null;try{let r=child_process.spawnSync(process.execPath,[t,"describe"],{timeout:5e3,encoding:"utf-8",windowsHide:!0});return r.status!==0?null:JSON.parse(String(r.stdout).trim())}catch{return null}}}}var dr=".board.lock";function at(e,t){if(!e||!t)return false;let r=String(e).replace(/[\\/]+$/,"").split(/[\\/]+/).filter(Boolean);return r.length>0&&r[r.length-1]===t}function lr(e,t){return typeof e=="string"?{cliDir:e,opts:t}:{cliDir:void 0,opts:e}}function fr(e,t){return typeof e=="string"?{cliDir:e,opts:t}:{cliDir:void 0,opts:e}}function ct(e){if(e)return e;let t=Je((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('board-live-cards-node.cjs', document.baseURI).href))),r=[t,C(t,"..","cli","node"),C(t,"..","..","cli","node")];for(let o of r)try{return Ve(o),o}catch{}throw new Error(`createFsBoardPlatformAdapter: could not resolve a public CLI directory from module dir ${t}`)}function pr(e,t,r){let{cliDir:o,opts:n}=lr(t,r),s=e.value,u=null,p,x=null,c;function l(){return c||(c=ct(o)),c}function h(a){let g=n?.queueStoreRef;if(!g)throw new Error(`createFsBoardPlatformAdapter: ${a} requires opts.queueStoreRef`);return g}function R(a){let g=n?.boardRuntimeStoreRef;if(!g)throw new Error(`createFsBoardPlatformAdapter: ${a} requires opts.boardRuntimeStoreRef`);return g}let y=n?.callbackTransport??chunkVNLMJEIX_cjs.g({notifyChannel:n?.notifyChannel,boardRuntimeStoreRef:n?.boardRuntimeStoreRef,queueStoreRef:n?.queueStoreRef}),d;function f(a){return d.queueStorageForRef(h(`internal lane "${a}"`),a)}function m(a){return chunkGPCMBPLK_cjs.a(f(a))}function S(){if(n?.suppressSpawn||u)return;let a=xe({id:"task-executor",workerStore:m("task-executor"),handleRequest:async(g,v)=>{let b=await Z(v.ref,v.args,{cliDir:l(),cwd:process.cwd(),label:"fsBoardAdapter.boardWorker"});if(b.result!=="success"){let k=typeof b.data?.error=="string"?b.data.error:b.error;throw new Error(k||b.result)}}});u=de(a).catch(g=>{n?.onWarn?.(`[board-worker] in-process queue drain failed: ${g instanceof Error?g.message:String(g)}`);}).finally(()=>{u=null,f("task-executor").peekActive().length>0&&S();});}return d={kvStorage:a=>se(C(s,`.${a}`)),blobStorage:a=>a?U(C(s,a)):U(s),blobStorageForRef:a=>U(chunkVQCIOKJV_cjs.b(a).value),chatStorageForRef:a=>gr(chunkVQCIOKJV_cjs.b(a).value),queueStorageForRef:(a,g)=>je(C(chunkVQCIOKJV_cjs.b(a).value,g)),scratchStorage:()=>oe(C(s,".tmp")),scratchStorageForRef:a=>oe(chunkVQCIOKJV_cjs.b(a).value),archiveFactory:()=>ge(C(s,"archive")),archiveFactoryForRef:a=>ge(chunkVQCIOKJV_cjs.b(a).value),journalAdapter:()=>Be(s),journalAdapterForRef:a=>Be(chunkVQCIOKJV_cjs.b(a).value),lock:it(C(s,dr)),callbackTransport:y,async dispatchExecution(a,g){let v=!!g.output?.ref;if(a.howToRun==="queue-storage")try{let k=m("task-executor"),A=typeof a.extra?.boardId=="string"?a.extra.boardId:void 0;if(v)return k.enqueueRequest({boardId:A,ref:a,args:g}),{dispatched:!0};let F=g.source_def?.bindTo??ue().slice(0,8),E=oe(C(s,".tmp")),M=E.create(JSON.stringify(g,null,2),`exec-in-${F}`,".json"),K=E.getUniqueKey(`exec-out-${F}`,".json"),te=E.getUniqueKey(`exec-err-${F}`,".txt"),G=chunkVQCIOKJV_cjs.a(E.keyRef(M)),I=chunkVQCIOKJV_cjs.a(E.keyRef(K)),P=chunkVQCIOKJV_cjs.a(E.keyRef(te));return k.enqueueRequest({boardId:A,ref:a,args:{subcommand:"run-source-fetch",inRef:G,outRef:I,errRef:P}}),{dispatched:!0}}catch(k){return {dispatched:false,error:k instanceof Error?k.message:String(k)}}if(v&&(a.howToRun==="http:post"||a.howToRun==="in-process-loop"))try{if(a.howToRun==="http:post"){let F=L(a.whatToRun),E=await fetch(F,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...g,...a.extra?{extra:a.extra}:{}})});if(!E.ok){let M=await E.text().catch(()=>"");return {dispatched:!1,error:`HTTP ${E.status}: ${M}`}}return {dispatched:!0}}let k=await Z(a,g,{cwd:process.cwd(),label:"dispatchExecution.directHostedWorker"});return k.result==="success"?{dispatched:!0}:{dispatched:!1,error:(typeof k.data?.error=="string"?k.data.error:k.error)||k.result}}catch(k){return {dispatched:false,error:k instanceof Error?k.message:String(k)}}let b=a.howToRun==="local-node"||a.howToRun==="local-process"||a.howToRun==="local-python"||a.howToRun==="built-in";if(n?.suppressSpawn&&b)return {dispatched:false};try{let k=g.source_def?.bindTo??ue().slice(0,8),A=oe(C(s,".tmp")),F=A.create(JSON.stringify(g,null,2),`exec-in-${k}`,".json"),E=A.getUniqueKey(`exec-out-${k}`,".json"),M=A.getUniqueKey(`exec-err-${k}`,".txt"),K=chunkVQCIOKJV_cjs.a(A.keyRef(F)),te=chunkVQCIOKJV_cjs.a(A.keyRef(E)),G=chunkVQCIOKJV_cjs.a(A.keyRef(M)),I=m("task-executor"),P=typeof a.extra?.boardId=="string"?a.extra.boardId:void 0;return I.enqueueRequest({boardId:P,ref:a,args:{subcommand:"run-source-fetch",inRef:K,outRef:te,errRef:G}}),S(),{dispatched:!0}}catch(k){let A=k instanceof Error?k.message:String(k);try{let F=ge(C(s,"archive")),E=new Date().toISOString().replace(/[:.]/g,"-"),M=g.source_def?.bindTo??"unknown";F.blob("exec-failures").write(`${E}-${M}.json`,JSON.stringify({error:A,args:g,ref:a,at:new Date().toISOString()},null,2));}catch{}return {dispatched:false,error:A}}},supportsDirectSourceOutput(a){return a.howToRun==="queue-storage"||a.howToRun==="http:post"||a.howToRun==="in-process-loop"},resolveBlob(a){let g=Ne(a.value)?Ie().read(a.value):U(s).read(a.value);if(g===null)throw new Error(`resolveBlob: blob not found: ::${a.kind}::${a.value}`);return g},hashFn:st,genId:()=>Qe(`${Date.now()}-${Math.random()}`).slice(0,32),kvStorageForRef:a=>se(chunkVQCIOKJV_cjs.b(a).value),requestProcessAccumulated(){if(n?.suppressSpawn||x)return;let a=this,g=p??=chunkVNLMJEIX_cjs.y(e,a,{boardRuntimeStoreRef:R("requestProcessAccumulated")}),v=we({id:"process-accumulated",queueStorage:f("process-accumulated"),handleMessage:async()=>{let b=await g.processAccumulatedEvents({});if(b.status!=="success")throw new Error(b.error||`processAccumulatedEvents returned ${b.status}`)}});x=de(v).catch(b=>{n?.onWarn?.(`[process-accumulated] in-process queue drain failed: ${b instanceof Error?b.message:String(b)}`);}).finally(()=>{x=null,f("process-accumulated").peekActive().length>0&&a.requestProcessAccumulated?.();});},publishBoardChangeNotifications(a){if(!n?.notifyChannel||a.length===0)return;let g=a.map(v=>({id:ue(),ts:new Date().toISOString(),boardRef:chunkVQCIOKJV_cjs.a(e),notification:v}));Ue(n.notifyChannel,g,n.onWarn);},onWarn:n?.onWarn},d}function an(e,t,r){let{cliDir:o,opts:n}=fr(t,r),s,u=()=>(s||(s=ct(o)),s),p=pr(e,o,n),x=Ae({resolveCliDir:u,...n?.resolveRef?{resolveRef:n.resolveRef}:{}});return {...p,invokeExecutor:x.invokeExecutor,validateSchema(c){let l=chunkQEHKMLHA_cjs.d(c);return {ok:l.errors.length===0,errors:l.errors}},absoluteBlob:Ie()}}function cn(e,t={}){let r=t.chatsSubdir??"chats",o=t.kvSubdir??".kv",n=o?[o,"chat"]:["chat"],s=r&&!at(e,r)?C(e,r):e,u=se(C(e,...n));return chunkMCPADH33_cjs.a(p=>{let c=`${String(p).replace(/[^a-zA-Z0-9_-]/g,"_")}.jsonl`,l=C(s,c);return me(l)},u)}function gr(e){return chunkMCPADH33_cjs.a(t=>{let o=`${String(t).replace(/[^a-zA-Z0-9_-]/g,"_")}.jsonl`;return me(C(e,"journal",o))},se(C(e,"kv")))}function un(e,t={}){let r=t.filesSubdir??"files",o=r&&!at(e,r)?C(e,r):e;return chunkNBJTYAYN_cjs.a(U(o))}function dn(e){try{let t=JSON.parse(Buffer.from(e,"base64url").toString());return typeof t.br=="string"?t.br:null}catch{return null}}Object.defineProperty(exports,"createChatStorage",{enumerable:true,get:function(){return chunkMCPADH33_cjs.a}});Object.defineProperty(exports,"createInMemoryChatStorage",{enumerable:true,get:function(){return chunkMCPADH33_cjs.c}});Object.defineProperty(exports,"createArtifactsStore",{enumerable:true,get:function(){return chunkNBJTYAYN_cjs.a}});Object.defineProperty(exports,"createCardFileMetadataStore",{enumerable:true,get:function(){return chunkNBJTYAYN_cjs.c}});Object.defineProperty(exports,"createFileArtifactsStore",{enumerable:true,get:function(){return chunkNBJTYAYN_cjs.b}});Object.defineProperty(exports,"createBoardWorkerStore",{enumerable:true,get:function(){return chunkGPCMBPLK_cjs.a}});Object.defineProperty(exports,"createQueueLaneRegistry",{enumerable:true,get:function(){return chunkGPCMBPLK_cjs.b}});Object.defineProperty(exports,"BOARD_GRAPH_KEY",{enumerable:true,get:function(){return chunkVNLMJEIX_cjs.n}});Object.defineProperty(exports,"EMPTY_CONFIG",{enumerable:true,get:function(){return chunkVNLMJEIX_cjs.u}});Object.defineProperty(exports,"SNAPSHOT_SCHEMA_VERSION_V1",{enumerable:true,get:function(){return chunkVNLMJEIX_cjs.m}});Object.defineProperty(exports,"createBoardLiveCardsNonCorePublic",{enumerable:true,get:function(){return chunkVNLMJEIX_cjs.z}});Object.defineProperty(exports,"createBoardLiveCardsPublic",{enumerable:true,get:function(){return chunkVNLMJEIX_cjs.y}});Object.defineProperty(exports,"createCardStore",{enumerable:true,get:function(){return chunkVNLMJEIX_cjs.l}});Object.defineProperty(exports,"createHttpBoardCallbackTransport",{enumerable:true,get:function(){return chunkVNLMJEIX_cjs.e}});Object.defineProperty(exports,"createInProcessBoardCallbackTransport",{enumerable:true,get:function(){return chunkVNLMJEIX_cjs.f}});Object.defineProperty(exports,"createLocalNodeBoardCallbackTransport",{enumerable:true,get:function(){return chunkVNLMJEIX_cjs.g}});Object.defineProperty(exports,"executionRefFromScriptPath",{enumerable:true,get:function(){return chunk7JVHYHT2_cjs.a}});Object.defineProperty(exports,"parseExecutionRef",{enumerable:true,get:function(){return chunk7JVHYHT2_cjs.c}});Object.defineProperty(exports,"serializeExecutionRef",{enumerable:true,get:function(){return chunk7JVHYHT2_cjs.b}});Object.defineProperty(exports,"parseRef",{enumerable:true,get:function(){return chunkVQCIOKJV_cjs.b}});Object.defineProperty(exports,"serializeRef",{enumerable:true,get:function(){return chunkVQCIOKJV_cjs.a}});Object.defineProperty(exports,"createBoardLiveCardsMcp",{enumerable:true,get:function(){return chunkGHUW6P4G_cjs.a}});Object.defineProperty(exports,"createCardStorePublic",{enumerable:true,get:function(){return chunk5XLFPPTY_cjs.a}});Object.defineProperty(exports,"createQueueStoragePublic",{enumerable:true,get:function(){return chunkSDJ3747Q_cjs.a}});Object.defineProperty(exports,"createArtifactsStorePublic",{enumerable:true,get:function(){return chunkP7ZCDICS_cjs.a}});exports.buildLocalBaseSpec=le;exports.createBoardWorkerQueueLane=xe;exports.createExecutionRefInvoker=Ut;exports.createFsBlobStorage=U;exports.createFsBoardChatStorage=cn;exports.createFsBoardFileArtifactsStore=un;exports.createFsBoardNonCorePlatformAdapter=an;exports.createFsBoardPlatformAdapter=pr;exports.createFsChatStorageForRefRoot=gr;exports.createFsQueueStorage=je;exports.createHostedAsyncBoardNonCorePublic=ar;exports.createNodeSpawnInvocationAdapter=sn;exports.createNonCoreExecutorDispatcher=Ae;exports.createQueueStorageLane=we;exports.decodeBoardRefFromToken=dn;exports.drainQueueLaneToIdle=de;exports.evaluateArgsMassaging=ke;exports.invokeExecutionRef=Z;exports.invokeExecutionRefSync=ve;exports.invokeRefSync=zt;exports.registerInProcessExecutionHandler=Dt;exports.resolveWhatToRunValue=L;exports.resolveYamlFlowCliPath=Xe;exports.startQueueLaneRunner=Ye;exports.startQueueLaneRunners=Ot;exports.unregisterInProcessExecutionHandler=Kt;//# sourceMappingURL=board-live-cards-node.cjs.map
|
|
11
|
+
`,"utf-8");},generateId(){return crypto.randomUUID()}}}function it(e){return {tryAcquire(){try{if(!i__namespace.existsSync(e)){i__namespace.mkdirSync(w__namespace.dirname(e),{recursive:!0});try{i__namespace.writeFileSync(e,"{}",{flag:"wx"});}catch{}}return properLockfile.lockSync(e,{retries:0})}catch{return null}}}}function z(e){return {status:"success",data:e}}function Q(e){return {status:"fail",error:e}}function re(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function ne(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}function ar(e,t={}){let r=()=>chunkWRMOGPRG_cjs.b(e.kvStorage("config")),o=t.unsupportedLabel??"hosted async runtime";async function n(){return t.taskExecutorRef?t.taskExecutorRef:await r().readTaskExecutorRef().catch(()=>{})}async function s(y,d,f){let m=await n();if(!m||!t.invokeExecutor)throw new Error(`${y} is not supported on the ${o} yet`);let a=(await t.invokeExecutor(m,y,{...d!==void 0?{input:typeof d=="string"?d:JSON.stringify(d)}:{},...f!==void 0?{timeout:f}:{}})).trim();return a?ne(JSON.parse(a)):{}}async function u(y){try{if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("validateCardPreflight requires card JSON object in body");let d=y.body,f=d["card-content"]??d,m=typeof f.id=="string"?f.id:"(unknown)",S=chunkCPJXGK2T_cjs.a(f),a=Array.isArray(f.source_defs)&&f.source_defs.length>0,g=[...S.issues];if(a)if(t.invokeExecutor&&await n())for(let v of f.source_defs){let b=typeof v.bindTo=="string"?v.bindTo:"(unknown)";try{let k=await s("validate-source-def",v,1e4);if(k.ok!==!0&&Array.isArray(k.errors))for(let A of k.errors)typeof A=="string"&&A&&g.push(`source "${b}": ${A}`);}catch(k){g.push(`source "${b}": executor validate-source-def failed \u2014 ${k instanceof Error?k.message:String(k)}`);}}else await n()&&g.push(`executor-backed source_def preflight is not supported on the ${o} yet`);return z({cardId:m,isValid:g.length===0,issues:g})}catch(d){return re(d)}}function p(y){try{if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("evalCardCompute requires a JSON object in body");let d=y.body,f=d["card-content"]??d,m=typeof f.id=="string"?f.id:"(unknown)",S=d["mock-fetched-sources"]??{},a=d["mock-requires"]??{},g=f.compute;if(!g||!Array.isArray(g)||g.length===0)return z({cardId:m,ok:!0,computed_values:{},errors:[]});let v={id:m,card_data:f.card_data??{},requires:a,source_defs:f.source_defs,compute:g},b=chunkQBEQL4TL_cjs.a.runSync(v,{sourcesData:S});return z({cardId:m,ok:(b.errors??[]).length===0,computed_values:b.node.computed_values??{},errors:b.errors??[]})}catch(d){return re(d)}}async function x(y){return Q(`${y} is not supported on the ${o} yet`)}async function c(){try{return t.invokeExecutor&&await n()?z(await s("describe-capabilities",void 0,1e4)):await x("describeTaskExecutorCapabilities")}catch(y){return re(y)}}async function l(y){try{if(!t.invokeExecutor||!await n())return await x("probeSourcePreflight");if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("probeSourcePreflight requires card JSON object in body");let d=y.body,f=d["card-content"]??d,m=ne(d["mock-projections"]??{}),S=y.params?.sourceIdx,a=Array.isArray(f.source_defs)?f.source_defs:[];if(S===void 0)return Q("probeSourcePreflight requires params.sourceIdx");if(S<0||S>=a.length)return Q(`sourceIdx ${S} out of range (card has ${a.length} source(s))`);let g=a[S],v=typeof g.bindTo=="string"?g.bindTo:"source",b=await s("probe-source-preflight",{...g,_projections:m},g.timeout??6e4);return b.ok!==!0?Q(typeof b.error=="string"?b.error:"Preflight probe failed"):z({bindTo:v,reachable:b.reachable,latencyMs:b.latencyMs,...typeof b.note=="string"?{note:b.note}:{}})}catch(d){return re(d)}}async function h(y){try{if(!t.invokeExecutor||!await n())return await x("runSourcePreflight");if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("runSourcePreflight requires card JSON object in body");let d=y.body,f=d["card-content"]??d,m=ne(d["mock-projections"]??{}),S=y.params?.sourceIdx,a=Array.isArray(f.source_defs)?f.source_defs:[];if(S===void 0)return Q("runSourcePreflight requires params.sourceIdx");if(S<0||S>=a.length)return Q(`sourceIdx ${S} out of range (card has ${a.length} source(s))`);let g=a[S],v=typeof g.bindTo=="string"?g.bindTo:"source",b=await s("run-source-preflight",{...g,_projections:m},g.timeout??6e4);return b.ok!==!0?z({bindTo:v,ok:!1,result:null,issues:[typeof b.error=="string"?b.error:"Preflight run failed"]}):z({bindTo:v,ok:!0,result:Object.prototype.hasOwnProperty.call(b,"resultValue")?b.resultValue:null,issues:[]})}catch(d){return re(d)}}async function R(y){try{if(!y.body||typeof y.body!="object"||Array.isArray(y.body))return Q("simulateCardCycle requires a JSON object in body");let d=y.body,f=d["card-content"]??d,m=typeof f.id=="string"?f.id:"(unknown)",S=ne(d["mock-fetched-sources"]??{}),a=ne(d["mock-requires"]??{}),g=await u({body:{"card-content":f}}),v=g.status==="success"?{isValid:g.data.isValid,issues:g.data.issues}:{isValid:!1,issues:[g.status==="fail"?g.error:"internal error"]},b=Array.isArray(f.source_defs)?f.source_defs:[],k=ne(f.card_data??{}),A=[],F=[];if(b.length>0){A=chunkQBEQL4TL_cjs.a.enrichSourcesSync(b,{card_data:k,requires:a});for(let I of A){let P=I.projections,W=I._projections;if(P&&W){for(let $ of Object.keys(P))if(W[$]===void 0){let ut=typeof I.bindTo=="string"?I.bindTo:"(unknown)";F.push({bindTo:ut,key:$,error:`Projection "${$}" resolved to undefined`});}}}}let E=[],M={...S};for(let I=0;I<A.length;I+=1){let P=A[I],W=typeof P.bindTo=="string"?P.bindTo:`source_${I}`;if(!t.invokeExecutor||!await n()){E.push({bindTo:W,skipped:!0,error:"No task executor configured"});continue}try{let $=await s("run-source-preflight",P,P.timeout??6e4);$.ok===!0&&!Object.prototype.hasOwnProperty.call(S,W)&&Object.prototype.hasOwnProperty.call($,"resultValue")&&(M[W]=$.resultValue),E.push({bindTo:W,reachable:$.reachable,latencyMs:$.latencyMs,...$.ok===!0?{}:{error:typeof $.error=="string"?$.error:"Preflight run failed"}});}catch{E.push({bindTo:W,skipped:!0,error:"Executor does not support run-source-preflight"});}}let K=f.compute,te={},G=[];if(K&&Array.isArray(K)&&K.length>0){let I={id:m,card_data:k,requires:a,source_defs:f.source_defs,compute:K},P=chunkQBEQL4TL_cjs.a.runSync(I,{sourcesData:M});te=P.node.computed_values??{},G=P.errors??[];}return z({cardId:m,ok:v.isValid&&F.length===0&&G.length===0&&E.every(I=>!I.error),validation:v,source_probes:E,projection_errors:F,fetched_sources:M,computed_values:te,compute_errors:G})}catch(d){return re(d)}}return {describeTaskExecutorCapabilities:c,validateCardPreflight:u,evalCardCompute:p,probeSourcePreflight:l,runSourcePreflight:h,simulateCardCycle:R}}function sn(){return {async invoke(e,t){if(e.howToRun!=="local-node")return {dispatched:false,error:`createNodeSpawnInvocationAdapter: unsupported howToRun "${e.howToRun}"`};let r="";try{let s=e.whatToRun;r=L(s);}catch{r="";}if(!r)return {dispatched:false,error:"createNodeSpawnInvocationAdapter: could not resolve executable path from whatToRun"};let o={...t},n=Buffer.from(JSON.stringify(o)).toString("base64");try{return child_process.spawn(process.execPath,[r,"--boardId",String(t.boardId??""),"--cardId",String(t.cardId??""),"--extraEncJson",n],{stdio:"ignore",windowsHide:!0}).unref(),{dispatched:!0}}catch(s){return {dispatched:false,error:s instanceof Error?s.message:String(s)}}},async describe(e){if(e.howToRun!=="local-node")return null;let t="";try{let r=e.whatToRun;t=L(r);}catch{t="";}if(!t)return null;try{let r=child_process.spawnSync(process.execPath,[t,"describe"],{timeout:5e3,encoding:"utf-8",windowsHide:!0});return r.status!==0?null:JSON.parse(String(r.stdout).trim())}catch{return null}}}}var dr=".board.lock";function at(e,t){if(!e||!t)return false;let r=String(e).replace(/[\\/]+$/,"").split(/[\\/]+/).filter(Boolean);return r.length>0&&r[r.length-1]===t}function lr(e,t){return typeof e=="string"?{cliDir:e,opts:t}:{cliDir:void 0,opts:e}}function fr(e,t){return typeof e=="string"?{cliDir:e,opts:t}:{cliDir:void 0,opts:e}}function ct(e){if(e)return e;let t=Je((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('board-live-cards-node.cjs', document.baseURI).href))),r=[t,C(t,"..","cli","node"),C(t,"..","..","cli","node")];for(let o of r)try{return Ve(o),o}catch{}throw new Error(`createFsBoardPlatformAdapter: could not resolve a public CLI directory from module dir ${t}`)}function pr(e,t,r){let{cliDir:o,opts:n}=lr(t,r),s=e.value,u=null,p,x=null,c;function l(){return c||(c=ct(o)),c}function h(a){let g=n?.queueStoreRef;if(!g)throw new Error(`createFsBoardPlatformAdapter: ${a} requires opts.queueStoreRef`);return g}function R(a){let g=n?.boardRuntimeStoreRef;if(!g)throw new Error(`createFsBoardPlatformAdapter: ${a} requires opts.boardRuntimeStoreRef`);return g}let y=n?.callbackTransport??chunkEYBDAEVO_cjs.g({notifyChannel:n?.notifyChannel,boardRuntimeStoreRef:n?.boardRuntimeStoreRef,queueStoreRef:n?.queueStoreRef}),d;function f(a){return d.queueStorageForRef(h(`internal lane "${a}"`),a)}function m(a){return chunkGPCMBPLK_cjs.a(f(a))}function S(){if(n?.suppressSpawn||u)return;let a=xe({id:"task-executor",workerStore:m("task-executor"),handleRequest:async(g,v)=>{let b=await Z(v.ref,v.args,{cliDir:l(),cwd:process.cwd(),label:"fsBoardAdapter.boardWorker"});if(b.result!=="success"){let k=typeof b.data?.error=="string"?b.data.error:b.error;throw new Error(k||b.result)}}});u=de(a).catch(g=>{n?.onWarn?.(`[board-worker] in-process queue drain failed: ${g instanceof Error?g.message:String(g)}`);}).finally(()=>{u=null,f("task-executor").peekActive().length>0&&S();});}return d={kvStorage:a=>se(C(s,`.${a}`)),blobStorage:a=>a?U(C(s,a)):U(s),blobStorageForRef:a=>U(chunkVQCIOKJV_cjs.b(a).value),chatStorageForRef:a=>gr(chunkVQCIOKJV_cjs.b(a).value),queueStorageForRef:(a,g)=>je(C(chunkVQCIOKJV_cjs.b(a).value,g)),scratchStorage:()=>oe(C(s,".tmp")),scratchStorageForRef:a=>oe(chunkVQCIOKJV_cjs.b(a).value),archiveFactory:()=>ge(C(s,"archive")),archiveFactoryForRef:a=>ge(chunkVQCIOKJV_cjs.b(a).value),journalAdapter:()=>Be(s),journalAdapterForRef:a=>Be(chunkVQCIOKJV_cjs.b(a).value),lock:it(C(s,dr)),callbackTransport:y,async dispatchExecution(a,g){let v=!!g.output?.ref;if(a.howToRun==="queue-storage")try{let k=m("task-executor"),A=typeof a.extra?.boardId=="string"?a.extra.boardId:void 0;if(v)return k.enqueueRequest({boardId:A,ref:a,args:g}),{dispatched:!0};let F=g.source_def?.bindTo??ue().slice(0,8),E=oe(C(s,".tmp")),M=E.create(JSON.stringify(g,null,2),`exec-in-${F}`,".json"),K=E.getUniqueKey(`exec-out-${F}`,".json"),te=E.getUniqueKey(`exec-err-${F}`,".txt"),G=chunkVQCIOKJV_cjs.a(E.keyRef(M)),I=chunkVQCIOKJV_cjs.a(E.keyRef(K)),P=chunkVQCIOKJV_cjs.a(E.keyRef(te));return k.enqueueRequest({boardId:A,ref:a,args:{subcommand:"run-source-fetch",inRef:G,outRef:I,errRef:P}}),{dispatched:!0}}catch(k){return {dispatched:false,error:k instanceof Error?k.message:String(k)}}if(v&&(a.howToRun==="http:post"||a.howToRun==="in-process-loop"))try{if(a.howToRun==="http:post"){let F=L(a.whatToRun),E=await fetch(F,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...g,...a.extra?{extra:a.extra}:{}})});if(!E.ok){let M=await E.text().catch(()=>"");return {dispatched:!1,error:`HTTP ${E.status}: ${M}`}}return {dispatched:!0}}let k=await Z(a,g,{cwd:process.cwd(),label:"dispatchExecution.directHostedWorker"});return k.result==="success"?{dispatched:!0}:{dispatched:!1,error:(typeof k.data?.error=="string"?k.data.error:k.error)||k.result}}catch(k){return {dispatched:false,error:k instanceof Error?k.message:String(k)}}let b=a.howToRun==="local-node"||a.howToRun==="local-process"||a.howToRun==="local-python"||a.howToRun==="built-in";if(n?.suppressSpawn&&b)return {dispatched:false};try{let k=g.source_def?.bindTo??ue().slice(0,8),A=oe(C(s,".tmp")),F=A.create(JSON.stringify(g,null,2),`exec-in-${k}`,".json"),E=A.getUniqueKey(`exec-out-${k}`,".json"),M=A.getUniqueKey(`exec-err-${k}`,".txt"),K=chunkVQCIOKJV_cjs.a(A.keyRef(F)),te=chunkVQCIOKJV_cjs.a(A.keyRef(E)),G=chunkVQCIOKJV_cjs.a(A.keyRef(M)),I=m("task-executor"),P=typeof a.extra?.boardId=="string"?a.extra.boardId:void 0;return I.enqueueRequest({boardId:P,ref:a,args:{subcommand:"run-source-fetch",inRef:K,outRef:te,errRef:G}}),S(),{dispatched:!0}}catch(k){let A=k instanceof Error?k.message:String(k);try{let F=ge(C(s,"archive")),E=new Date().toISOString().replace(/[:.]/g,"-"),M=g.source_def?.bindTo??"unknown";F.blob("exec-failures").write(`${E}-${M}.json`,JSON.stringify({error:A,args:g,ref:a,at:new Date().toISOString()},null,2));}catch{}return {dispatched:false,error:A}}},supportsDirectSourceOutput(a){return a.howToRun==="queue-storage"||a.howToRun==="http:post"||a.howToRun==="in-process-loop"},resolveBlob(a){let g=Ne(a.value)?Ie().read(a.value):U(s).read(a.value);if(g===null)throw new Error(`resolveBlob: blob not found: ::${a.kind}::${a.value}`);return g},hashFn:st,genId:()=>Qe(`${Date.now()}-${Math.random()}`).slice(0,32),kvStorageForRef:a=>se(chunkVQCIOKJV_cjs.b(a).value),requestProcessAccumulated(){if(n?.suppressSpawn||x)return;let a=this,g=p??=chunkEYBDAEVO_cjs.y(e,a,{boardRuntimeStoreRef:R("requestProcessAccumulated")}),v=we({id:"process-accumulated",queueStorage:f("process-accumulated"),handleMessage:async()=>{let b=await g.processAccumulatedEvents({});if(b.status!=="success")throw new Error(b.error||`processAccumulatedEvents returned ${b.status}`)}});x=de(v).catch(b=>{n?.onWarn?.(`[process-accumulated] in-process queue drain failed: ${b instanceof Error?b.message:String(b)}`);}).finally(()=>{x=null,f("process-accumulated").peekActive().length>0&&a.requestProcessAccumulated?.();});},publishBoardChangeNotifications(a){if(!n?.notifyChannel||a.length===0)return;let g=a.map(v=>({id:ue(),ts:new Date().toISOString(),boardRef:chunkVQCIOKJV_cjs.a(e),notification:v}));Ue(n.notifyChannel,g,n.onWarn);},onWarn:n?.onWarn},d}function an(e,t,r){let{cliDir:o,opts:n}=fr(t,r),s,u=()=>(s||(s=ct(o)),s),p=pr(e,o,n),x=Ae({resolveCliDir:u,...n?.resolveRef?{resolveRef:n.resolveRef}:{}});return {...p,invokeExecutor:x.invokeExecutor,validateSchema(c){let l=chunkQEHKMLHA_cjs.d(c);return {ok:l.errors.length===0,errors:l.errors}},absoluteBlob:Ie()}}function cn(e,t={}){let r=t.chatsSubdir??"chats",o=t.kvSubdir??".kv",n=o?[o,"chat"]:["chat"],s=r&&!at(e,r)?C(e,r):e,u=se(C(e,...n));return chunkMCPADH33_cjs.a(p=>{let c=`${String(p).replace(/[^a-zA-Z0-9_-]/g,"_")}.jsonl`,l=C(s,c);return me(l)},u)}function gr(e){return chunkMCPADH33_cjs.a(t=>{let o=`${String(t).replace(/[^a-zA-Z0-9_-]/g,"_")}.jsonl`;return me(C(e,"journal",o))},se(C(e,"kv")))}function un(e,t={}){let r=t.filesSubdir??"files",o=r&&!at(e,r)?C(e,r):e;return chunkNBJTYAYN_cjs.a(U(o))}function dn(e){try{let t=JSON.parse(Buffer.from(e,"base64url").toString());return typeof t.br=="string"?t.br:null}catch{return null}}Object.defineProperty(exports,"createChatStorage",{enumerable:true,get:function(){return chunkMCPADH33_cjs.a}});Object.defineProperty(exports,"createInMemoryChatStorage",{enumerable:true,get:function(){return chunkMCPADH33_cjs.c}});Object.defineProperty(exports,"createArtifactsStore",{enumerable:true,get:function(){return chunkNBJTYAYN_cjs.a}});Object.defineProperty(exports,"createCardFileMetadataStore",{enumerable:true,get:function(){return chunkNBJTYAYN_cjs.c}});Object.defineProperty(exports,"createFileArtifactsStore",{enumerable:true,get:function(){return chunkNBJTYAYN_cjs.b}});Object.defineProperty(exports,"createBoardWorkerStore",{enumerable:true,get:function(){return chunkGPCMBPLK_cjs.a}});Object.defineProperty(exports,"createQueueLaneRegistry",{enumerable:true,get:function(){return chunkGPCMBPLK_cjs.b}});Object.defineProperty(exports,"BOARD_GRAPH_KEY",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.n}});Object.defineProperty(exports,"EMPTY_CONFIG",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.u}});Object.defineProperty(exports,"SNAPSHOT_SCHEMA_VERSION_V1",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.m}});Object.defineProperty(exports,"createBoardLiveCardsNonCorePublic",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.z}});Object.defineProperty(exports,"createBoardLiveCardsPublic",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.y}});Object.defineProperty(exports,"createCardStore",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.l}});Object.defineProperty(exports,"createHttpBoardCallbackTransport",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.e}});Object.defineProperty(exports,"createInProcessBoardCallbackTransport",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.f}});Object.defineProperty(exports,"createLocalNodeBoardCallbackTransport",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.g}});Object.defineProperty(exports,"executionRefFromScriptPath",{enumerable:true,get:function(){return chunk7JVHYHT2_cjs.a}});Object.defineProperty(exports,"parseExecutionRef",{enumerable:true,get:function(){return chunk7JVHYHT2_cjs.c}});Object.defineProperty(exports,"serializeExecutionRef",{enumerable:true,get:function(){return chunk7JVHYHT2_cjs.b}});Object.defineProperty(exports,"parseRef",{enumerable:true,get:function(){return chunkVQCIOKJV_cjs.b}});Object.defineProperty(exports,"serializeRef",{enumerable:true,get:function(){return chunkVQCIOKJV_cjs.a}});Object.defineProperty(exports,"createBoardLiveCardsMcp",{enumerable:true,get:function(){return chunkGHUW6P4G_cjs.a}});Object.defineProperty(exports,"createCardStorePublic",{enumerable:true,get:function(){return chunk5XLFPPTY_cjs.a}});Object.defineProperty(exports,"createQueueStoragePublic",{enumerable:true,get:function(){return chunkSDJ3747Q_cjs.a}});Object.defineProperty(exports,"createArtifactsStorePublic",{enumerable:true,get:function(){return chunkP7ZCDICS_cjs.a}});exports.buildLocalBaseSpec=le;exports.createBoardWorkerQueueLane=xe;exports.createExecutionRefInvoker=Ut;exports.createFsBlobStorage=U;exports.createFsBoardChatStorage=cn;exports.createFsBoardFileArtifactsStore=un;exports.createFsBoardNonCorePlatformAdapter=an;exports.createFsBoardPlatformAdapter=pr;exports.createFsChatStorageForRefRoot=gr;exports.createFsQueueStorage=je;exports.createHostedAsyncBoardNonCorePublic=ar;exports.createNodeSpawnInvocationAdapter=sn;exports.createNonCoreExecutorDispatcher=Ae;exports.createQueueStorageLane=we;exports.decodeBoardRefFromToken=dn;exports.drainQueueLaneToIdle=de;exports.evaluateArgsMassaging=ke;exports.invokeExecutionRef=Z;exports.invokeExecutionRefSync=ve;exports.invokeRefSync=zt;exports.registerInProcessExecutionHandler=Dt;exports.resolveWhatToRunValue=L;exports.resolveYamlFlowCliPath=Xe;exports.startQueueLaneRunner=Ye;exports.startQueueLaneRunners=Ot;exports.unregisterInProcessExecutionHandler=Kt;//# sourceMappingURL=board-live-cards-node.cjs.map
|
|
12
12
|
//# sourceMappingURL=board-live-cards-node.cjs.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {a as a$2}from'./chunk-Y4WK7HE4.js';export{a as createChatStorage,c as createInMemoryChatStorage}from'./chunk-Y4WK7HE4.js';import {a as a$5}from'./chunk-2LGCYN35.js';import {a as a$3}from'./chunk-O5UYCGIN.js';export{a as createArtifactsStore,c as createCardFileMetadataStore,b as createFileArtifactsStore}from'./chunk-O5UYCGIN.js';import {a as a$4}from'./chunk-RKKSVOP2.js';export{a as createBoardWorkerStore,b as createQueueLaneRegistry}from'./chunk-RKKSVOP2.js';import {h}from'./chunk-J4MHQ7JF.js';import {a}from'./chunk-VGDLSS2H.js';import'./chunk-QLB6PKOT.js';import'./chunk-
|
|
1
|
+
import {a as a$2}from'./chunk-Y4WK7HE4.js';export{a as createChatStorage,c as createInMemoryChatStorage}from'./chunk-Y4WK7HE4.js';import {a as a$5}from'./chunk-2LGCYN35.js';import {a as a$3}from'./chunk-O5UYCGIN.js';export{a as createArtifactsStore,c as createCardFileMetadataStore,b as createFileArtifactsStore}from'./chunk-O5UYCGIN.js';import {a as a$4}from'./chunk-RKKSVOP2.js';export{a as createBoardWorkerStore,b as createQueueLaneRegistry}from'./chunk-RKKSVOP2.js';import {h}from'./chunk-J4MHQ7JF.js';import {a}from'./chunk-VGDLSS2H.js';import'./chunk-QLB6PKOT.js';import'./chunk-HFI2NAZJ.js';import {b as b$1}from'./chunk-6MD6FVE3.js';import {g,y}from'./chunk-AHW6EMUO.js';export{n as BOARD_GRAPH_KEY,u as EMPTY_CONFIG,m as SNAPSHOT_SCHEMA_VERSION_V1,z as createBoardLiveCardsNonCorePublic,y as createBoardLiveCardsPublic,l as createCardStore,e as createHttpBoardCallbackTransport,f as createInProcessBoardCallbackTransport,g as createLocalNodeBoardCallbackTransport}from'./chunk-AHW6EMUO.js';export{a as executionRefFromScriptPath,c as parseExecutionRef,b as serializeExecutionRef}from'./chunk-ANKA7HEJ.js';import {a as a$1,b}from'./chunk-44L64VQ2.js';export{b as parseRef,a as serializeRef}from'./chunk-44L64VQ2.js';import'./chunk-VGT3TRQG.js';import'./chunk-WDPOGXTY.js';export{a as createBoardLiveCardsMcp}from'./chunk-6M3RIGUH.js';import {a as a$6}from'./chunk-ATOQP3BD.js';import {d}from'./chunk-YT76JNKE.js';import'./chunk-MNEOJWPS.js';export{a as createCardStorePublic}from'./chunk-7QNEV5S3.js';export{a as createQueueStoragePublic}from'./chunk-BJGK5FNL.js';export{a as createArtifactsStorePublic}from'./chunk-X3LC4LII.js';import'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';import {spawn,spawnSync,execFile,execFileSync}from'child_process';import*as i from'fs';import*as qe from'os';import*as w from'path';import*as Le from'net';import {fileURLToPath}from'url';import {randomUUID,createHash}from'crypto';import {createRequire}from'module';import {lockSync}from'proper-lockfile';function C(...e){return w.join(...e)}function Ne(e){return w.isAbsolute(e)}function ue(){return randomUUID()}function Qe(e){return createHash("sha256").update(e).digest("hex")}function Je(e){return w.dirname(fileURLToPath(e))}function Ft(e){if(typeof e=="object"&&e!==null){let{command:r,args:o=[],...n}=e,s=Oe(r,o);return {...n,command:s.command,args:s.args}}let t=De(e);if(t.length===0)throw new Error(`Empty command spec: ${JSON.stringify(e)}`);return Oe(t[0],t.slice(1))}function Oe(e,t){return /^(node|node\.exe)$/i.test(e)?{command:process.execPath,args:t}:/\.m?js$/i.test(e)?{command:process.execPath,args:[e,...t]}:{command:e,args:t}}function De(e){let t=[],r="",o=null;for(let n of e.trim()){if(o){n===o?o=null:r+=n;continue}if(n==='"'||n==="'"){o=n;continue}if(/\s/.test(n)){r&&(t.push(r),r="");continue}r+=n;}if(o)throw new Error(`Unterminated quote in command: ${e}`);return r&&t.push(r),t}function Ke(e){return process.platform==="win32"&&/\.(cmd|bat)$/i.test(e)}function We(e,t){let{command:r,args:o=[],cwd:n,env:s,timeoutMs:u}=e;return execFileSync(r,o,{shell:Ke(r),timeout:u,encoding:t?.encoding??"utf-8",cwd:n,windowsHide:true,env:s?{...process.env,...s}:void 0,input:t?.input})}function $t(e,t){let{command:r,args:o=[],cwd:n,env:s,timeoutMs:u=3e4}=e;execFile(r,o,{shell:Ke(r),encoding:"utf8",windowsHide:true,timeout:u,maxBuffer:10*1024*1024,cwd:n,env:s?{...process.env,...s}:void 0},(p,x,c)=>t(p??null,x,c));}function He(e,t,r){let o=w.join(e,"board-live-cards-cli.js");if(i.existsSync(o))return {cmd:process.execPath,args:[o,t,...r]};let n=w.join(e,"board-live-cards-cli.ts"),u=[w.join(e,"..","..","..","node_modules","tsx","dist","cli.mjs"),w.join(e,"..","..","node_modules","tsx","dist","cli.mjs"),w.join(e,"..","..","..","node_modules",".bin","tsx"),w.join(e,"..","..","node_modules",".bin","tsx")].find(x=>i.existsSync(x));return i.existsSync(n)&&u?{cmd:process.execPath,args:[u,n,t,...r]}:{cmd:process.platform==="win32"?"npx.cmd":"npx",args:["tsx",n,t,...r]}}function Ve(e){let t=w.join(e,"board-live-cards-cli.mjs");if(i.existsSync(t))return t;let r=w.join(e,"..","..","..","dev","board-live-cards-cli.js");if(i.existsSync(r))return r;let o=w.join(e,"..","..","dev","board-live-cards-cli.js");if(i.existsSync(o))return o;let n=w.join(e,"board-live-cards-cli.js");if(i.existsSync(n))return n;throw new Error(`resolveBoardCliCallbackTarget: cannot find callback target in ${e} (expected dev/board-live-cards-cli.js wrapper, ${n}, or ${t})`)}function Mt(e){return process.platform==="win32"?`\\\\.\\pipe\\${e}`:w.join(qe.tmpdir(),`${e}.sock`)}var ce=new Map;function Ue(e,t,r){if(t.length===0)return;let o=t.map(p=>JSON.stringify(p)).join(`
|
|
2
2
|
`)+`
|
|
3
3
|
`,n=ce.get(e);if(n&&!n.socket.destroyed){n.ready?n.socket.write(o):n.queue.push(o);return}let s=Mt(e),u=Le.createConnection(s);n={socket:u,ready:false,queue:[o]},ce.set(e,n),u.on("connect",()=>{n.ready=true;for(let p of n.queue)u.write(p);n.queue.length=0;}),u.on("error",p=>{r?.(`[named-pipe publish] ${s}: ${p instanceof Error?p.message:String(p)}`),ce.delete(e);}),u.on("close",()=>{ce.delete(e);});}function ze(){return {executeSync(e,t,r){return We({command:e,args:t,cwd:r?.cwd,timeoutMs:r?.timeout,env:r?.env},{encoding:r?.encoding,input:r?.input})},executeAsync(e,t,r){$t({command:e,args:t},r);},resolveInvocation(e,t){let r=Ft({command:e,args:t});return {cmd:r.command,args:r.args??[]}},splitCommand:De}}function xe(e){return {id:e.id??"board-worker",pollIntervalMs:e.pollIntervalMs,visibilityMs:e.visibilityMs,concurrency:e.concurrency,maxAttempts:e.maxAttempts,async lease(t){return e.workerStore.leaseRequests(t).map(r=>({id:r.messageId,attempt:r.attempt,message:r.request,ack:()=>e.workerStore.ackRequest(r.messageId,r.leaseToken),nack:o=>e.workerStore.nackRequest(r.messageId,r.leaseToken,o)}))},async handle(t){await e.handleRequest(t.args,t);},onError:e.onError}}function we(e){return {id:e.id,pollIntervalMs:e.pollIntervalMs,visibilityMs:e.visibilityMs,concurrency:e.concurrency,maxAttempts:e.maxAttempts,async lease(t){return e.queueStorage.lease(t).map(r=>({id:r.id,attempt:r.attempt,message:r.body,ack:()=>e.queueStorage.ack(r.id,r.leaseToken),nack:o=>e.queueStorage.nack(r.id,r.leaseToken,o)}))},handle:e.handleMessage,onError:e.onError}}async function Ge(e,t){try{await e.handle(t.message,t),await t.ack();}catch(r){let o=t.attempt>=Math.max(1,Math.floor(e.maxAttempts??5));await t.nack({dead:o,reason:r instanceof Error?r.message:String(r)}),e.onError?.(r,t);}}function Ye(e){let t=Math.max(1,Math.floor(e.pollIntervalMs??250)),r=Math.max(1,Math.floor(e.visibilityMs??6e4)),o=Math.max(1,Math.floor(e.concurrency??1)),n=false,s=false;async function u(){if(!(n||s)){s=true;try{let x=await e.lease({max:o,visibilityMs:r});for(let c of x)await Ge(e,c);}finally{s=false;}}}let p=setInterval(()=>{u();},t);return typeof p.unref=="function"&&p.unref(),u(),()=>{n=true,clearInterval(p);}}async function _t(e){let t=Math.max(1,Math.floor(e.visibilityMs??6e4)),r=Math.max(1,Math.floor(e.concurrency??1)),o=await e.lease({max:r,visibilityMs:t});for(let n of o)await Ge(e,n);return o.length}async function de(e,t){let r=Math.max(1,Math.floor(t?.maxPasses??256)),o=0;for(let n=0;n<r;n+=1){let s=await _t(e);if(o+=s,s<=0)return o}throw new Error(`drainQueueLaneToIdle exceeded ${r} passes for lane "${e.id}"`)}function Ot(e){let r=(Array.isArray(e)?e:e.lanes).map(o=>Ye(o));return ()=>{for(let o of r)o();}}var Lt=createRequire(import.meta.url);function Nt(e){return typeof e=="object"?e:b(e)}function Xe(e){let t=w.basename(String(e||"").trim());if(!t)throw new Error(`resolveYamlFlowCliPath: expected non-empty cli file name, got ${JSON.stringify(e)}`);let r=w.dirname(Lt.resolve("yaml-flow/package.json")),o=t.replace(/\.[^.]+$/,""),n=w.join(r,"cli","bundled",`${o}.mjs`);if(i.existsSync(n))return n;let s=w.join(r,"cli","node",t);if(i.existsSync(s))return s;throw new Error(`resolveYamlFlowCliPath: could not find ${t} under cli/bundled or cli/node in ${r}`)}function L(e){let t=Nt(e);return t.kind==="yaml-flow-cli"?Xe(t.value):t.value}function Qt(e,t){let r=L(e);switch(r){case "source-cli-task-executor":{let o=w.join(t,"source-cli-task-executor.js");if(i.existsSync(o))return {command:process.execPath,args:[o]};let n=w.join(t,"source-cli-task-executor.ts"),s=w.join(t,"..","..","node_modules","tsx","dist","cli.mjs"),u=w.join(t,"..","..","node_modules",".bin","tsx"),p=i.existsSync(s)?s:u;return i.existsSync(n)&&i.existsSync(p)?{command:process.execPath,args:[p,n]}:{command:process.execPath,args:[o]}}case "board-live-cards":{let{cmd:o,args:n}=He(t,"_",[]);return {command:o,args:n}}default:throw new Error(`resolveBuiltIn: unknown built-in name "${r}". Supported: source-cli-task-executor, board-live-cards`)}}function Jt(e,t){if(e.howToRun==="built-in"){let{command:o,args:n}=Qt(e.whatToRun,t);return {command:o,baseArgs:n}}let r=(typeof e.whatToRun=="object",L(e.whatToRun));switch(e.howToRun){case "local-node":return {command:process.execPath,baseArgs:[r]};case "local-python":return {command:process.platform==="win32"?"python":"python3",baseArgs:[r]};case "local-process":return {command:r,baseArgs:[]};default:throw new Error(`resolveBaseInvocation: howToRun "${e.howToRun}" is not a local transport`)}}function le(e,t){return Jt(e,t)}var be=new Map;function Dt(e,t){let r=String(e||"").trim();if(!r)throw new Error("registerInProcessExecutionHandler: key is required");be.set(r,t);}function Kt(e){let t=String(e||"").trim();t&&be.delete(t);}function et(e){let t=e.trim();if(!t)throw new Error("empty stdout");try{return JSON.parse(t)}catch{let r=t.split(/\r?\n/).filter(Boolean),o=r[r.length-1];return JSON.parse(o)}}function tt(e,t){return {...t,whatToRun:L(e.whatToRun),...e.extra?{extra:e.extra}:{}}}function ke(e,t,r="invokeExecutionRef"){return a(e,t,r)}function rt(e,t){if(e&&typeof e=="object"&&!Array.isArray(e)&&typeof e.result=="string"&&e.data&&typeof e.data=="object"&&!Array.isArray(e.data))return {...e,...t||{}};if(e&&typeof e=="object"&&!Array.isArray(e)&&typeof e.status=="string"){let o=e,n=o.status==="success"?"success":o.status==="fail"?"failure":o.status,s=o.data&&typeof o.data=="object"&&!Array.isArray(o.data)?o.data:o.data===void 0?{}:{stdout:o.data};return {result:n,data:s,...typeof o.error=="string"?{error:o.error}:{},...t||{}}}return {result:"success",data:e&&typeof e=="object"&&!Array.isArray(e)?e:{stdout:e},...t||{}}}function q(e){return {result:"failure",data:{error:e}}}function V(e,t,r){let o=r?.label??"invokeExecutionRefSync",n=r?.cliDir??r?.cwd??process.cwd(),s;try{s=ke(e.argsMassaging,tt(e,t),o);}catch(h){let R=h instanceof Error?h.message:String(h);return q(R)}let u;try{u=le(e,n);}catch(h){let R=h instanceof Error?h.message:String(h);return q(`[${o}] ref resolution failed: ${R}`)}let p=[...u.baseArgs,...s.cmdArgs??[]],x=JSON.stringify(s.stdin??t),c=ze(),l;try{l=c.executeSync(u.command,p,{timeout:r?.timeoutMs??3e4,encoding:"utf-8",cwd:r?.cwd,input:x});}catch(h){let R=h,y=(R.stderr?String(R.stderr):"").trim(),d=typeof R.status=="number"?R.status:"unknown",f=y||R.message;return q(`[${o}] ref exited with status ${d}${f?`: ${f}`:""}`)}try{return rt(et(l))}catch{return {result:"success",data:{stdout:l.trim()}}}}async function Ze(e,t,r){let o=r?.label??"invokeExecutionRef",n;try{n=ke(e.argsMassaging,tt(e,t),o);}catch(h){let R=h instanceof Error?h.message:String(h);return q(R)}let s=L(e.whatToRun),u=n.headers?{"Content-Type":"application/json",...n.headers}:{"Content-Type":"application/json"},p=n.url??s,x;if(e.howToRun==="http:get"){let h=n.body&&typeof n.body=="object"&&!Array.isArray(n.body)?n.body:t,R=new URLSearchParams(Object.entries(h).filter(([,y])=>y!=null).map(([y,d])=>[y,String(d)]));R.size>0&&(p=`${p}${p.includes("?")?"&":"?"}${R.toString()}`);}else x=JSON.stringify(n.body??t);let c={method:e.howToRun==="http:get"?"GET":"POST",headers:u,body:x},l=0;for(;;)try{let h=await fetch(p,c);if(!h.ok){let f=await h.text().catch(()=>"");return q(`[${o}] HTTP ${h.status}${f?`: ${f}`:""}`)}let R={};h.headers.forEach((f,m)=>{R[m]=f;});let y=new Uint8Array(await h.arrayBuffer());if(y.byteLength===0)return {result:"success",data:{},headers:R};let d=new TextDecoder().decode(y);try{return rt(et(d),{headers:R})}catch{return {result:"success",data:{stdout:d},headers:R}}}catch(h){let R=h?.cause,y=R&&typeof R=="object"&&"code"in R?String(R.code||""):"";if((y==="ECONNRESET"||y==="UND_ERR_SOCKET")&&l===0){l+=1;continue}let f=h instanceof Error?h.message:String(h),m=R instanceof Error?`${R.name}: ${R.message}${y?` [${y}]`:""}`:R?String(R):"",S=n.url??s??"",a=`${f}${m?` (cause: ${m})`:""}${S?` url=${S}`:""}`;return q(`[${o}] ${a}`)}}async function Wt(e,t,r){let o=r?.label??"invokeExecutionRef",n=L(e.whatToRun).trim();if(!n)return q(`[${o}] in-process-loop requires a non-empty handler key`);let s=be.get(n);if(!s)return q(`[${o}] no in-process handler registered for: ${n}`);try{return await s(e,t,r)}catch(u){let p=u instanceof Error?u.message:String(u);return q(`[${o}] ${p}`)}}var Ht={"local-node":async(e,t,r)=>V(e,t,r),"local-python":async(e,t,r)=>V(e,t,r),"local-process":async(e,t,r)=>V(e,t,r),"built-in":async(e,t,r)=>V(e,t,r),"http:post":Ze,"http:get":Ze,"in-process-loop":Wt},Vt={"local-node":V,"local-python":V,"local-process":V,"built-in":V};async function Z(e,t,r){let o=r?.transports?.[e.howToRun]??Ht[e.howToRun];return o?o(e,t,r):q(`[${r?.label??"invokeExecutionRef"}] unsupported howToRun: ${e.howToRun}`)}function ve(e,t,r){let o=r?.syncTransports?.[e.howToRun]??Vt[e.howToRun];return o?o(e,t,r):q(`[${r?.label??"invokeExecutionRefSync"}] unsupported sync howToRun: ${e.howToRun}`)}function Ut(e){return {invoke(t,r){return Z(t,r,e)},invokeSync(t,r){return ve(t,r,e)}}}function zt(e,t,r){return ve(e,t,r)}function Ae(e={}){let t=e.resolveRef??(r=>r);return {...e.executorTimeouts?{executorTimeouts:e.executorTimeouts}:{},async invokeExecutor(r,o,n){let s=t(r);if(s.howToRun==="queue-storage")throw new Error("queue-storage does not support inline executor request/response");if(s.howToRun==="http:post"||s.howToRun==="in-process-loop"){let l=await h(s,{subcommand:o,...n?.input!==void 0?{input:n.input}:{}});return typeof l=="string"?l:l&&typeof l=="object"&&!Array.isArray(l)&&typeof l.stdout=="string"?String(l.stdout):JSON.stringify(l??{})}if(s.howToRun==="http:get"){let l=await Z(s,{subcommand:o,...n?.input!==void 0?{input:n.input}:{},...s.extra?{extra:s.extra}:{}},{cwd:process.cwd(),timeoutMs:n?.timeout??3e4,label:`invokeExecutor:${o}`});if(l.result!=="success"){let h=typeof l.data?.error=="string"?l.data.error:l.error;throw new Error(h||`executor request failed: ${l.result}`)}return typeof l.data?.stdout=="string"?l.data.stdout:JSON.stringify(l.data??{})}if(!e.resolveCliDir)throw new Error(`createNonCoreExecutorDispatcher: ref.howToRun="${s.howToRun}" requires opts.resolveCliDir`);let{command:u,baseArgs:p}=le(s,e.resolveCliDir()),x=s.extra?["--extra",Buffer.from(JSON.stringify(s.extra)).toString("base64")]:[],c=[...p,o,...x];return await new Promise((l,h)=>{let R=spawn(u,c,{cwd:process.cwd(),stdio:"pipe",windowsHide:true,shell:process.platform==="win32"&&/\.(cmd|bat)$/i.test(u)}),y=[],d=[],f=false,m=null,S=g=>{f||(f=true,m&&clearTimeout(m),h(g));},a=g=>{f||(f=true,m&&clearTimeout(m),l(g));};R.stdout.on("data",g=>{y.push(Buffer.from(g));}),R.stderr.on("data",g=>{d.push(Buffer.from(g));}),R.on("error",g=>{let v=g;v.stdout=Buffer.concat(y).toString("utf-8"),v.stderr=Buffer.concat(d).toString("utf-8"),S(v);}),R.on("close",g=>{let v=Buffer.concat(y).toString("utf-8"),b=Buffer.concat(d).toString("utf-8");if(g===0){a(v);return}let k=new Error(b.trim()||`executor exited with status ${g}`);k.stdout=v,k.stderr=b,S(k);}),n?.timeout&&n.timeout>0&&(m=setTimeout(()=>{R.kill();let g=new Error(`executor timed out after ${n.timeout}ms`);g.stdout=Buffer.concat(y).toString("utf-8"),g.stderr=Buffer.concat(d).toString("utf-8"),S(g);},n.timeout)),n?.input!==void 0?R.stdin.end(n.input):R.stdin.end();})}}}function B(e,t){if(process.platform!=="win32"){i.renameSync(e,t);return}let r=[10,20,40,80,160];for(let o=0;o<=r.length;o++)try{i.renameSync(e,t);return}catch(n){let s=n.code;if((s==="EPERM"||s==="EBUSY")&&o<r.length){Atomics.wait(new Int32Array(new SharedArrayBuffer(4)),0,0,r[o]);continue}throw n}}function U(e){function t(n){return w.join(e,...n.split("/"))}function r(n){return w.relative(e,n).replace(/\\/g,"/")}function o(n,s){if(i.existsSync(n))for(let u of i.readdirSync(n,{withFileTypes:true})){let p=w.join(n,u.name);if(u.isDirectory()){o(p,s);continue}u.isFile()&&s.push(r(p));}}return {read(n){let s=t(n);if(!i.existsSync(s))return null;try{return i.readFileSync(s,"utf-8")}catch{return null}},write(n,s){let u=t(n),p=`${u}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(w.dirname(u),{recursive:true}),i.writeFileSync(p,s,"utf-8"),B(p,u);},exists(n){return i.existsSync(t(n))},remove(n){let s=t(n);try{i.existsSync(s)&&i.unlinkSync(s);}catch{}},readBytes(n){let s=t(n);if(!i.existsSync(s))return null;try{return new Uint8Array(i.readFileSync(s))}catch{return null}},writeBytes(n,s){let u=t(n),p=`${u}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(w.dirname(u),{recursive:true}),i.writeFileSync(p,Buffer.from(s)),B(p,u);},listKeys(n){let s=[];o(e,s);let u=s.sort();return n?u.filter(p=>p.startsWith(n)):u},stat(n){let s=t(n);if(!i.existsSync(s))return null;try{let u=i.statSync(s);return {key:n,size:Number(u.size||0),updatedAt:new Date(u.mtimeMs).toISOString()}}catch{return null}},keyRef(n){return {kind:"fs-path",value:t(n)}},renameKey(n,s){let u=t(n);if(!i.existsSync(u))return false;let p=t(s);return i.mkdirSync(w.dirname(p),{recursive:true}),B(u,p),true}}}function Ie(){return {read(e){if(!i.existsSync(e))return null;try{return i.readFileSync(e,"utf-8")}catch{return null}},write(e,t){let r=`${e}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(w.dirname(e),{recursive:true}),i.writeFileSync(r,t,"utf-8"),B(r,e);},exists(e){return i.existsSync(e)},remove(e){try{i.existsSync(e)&&i.unlinkSync(e);}catch{}},readBytes(e){if(!i.existsSync(e))return null;try{return new Uint8Array(i.readFileSync(e))}catch{return null}},writeBytes(e,t){let r=`${e}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(w.dirname(e),{recursive:true}),i.writeFileSync(r,Buffer.from(t)),B(r,e);},stat(e){if(!i.existsSync(e))return null;try{let t=i.statSync(e);return {key:e,size:Number(t.size||0),updatedAt:new Date(t.mtimeMs).toISOString()}}catch{return null}},listKeys(e){return []},renameKey(e,t){return i.existsSync(e)?(i.mkdirSync(w.dirname(t),{recursive:true}),B(e,t),true):false}}}function D(e,t){let r=`${e}.${process.pid}.${randomUUID()}.tmp`;i.mkdirSync(w.dirname(e),{recursive:true}),i.writeFileSync(r,JSON.stringify(t,null,2),"utf-8"),B(r,e);}function N(e){if(!i.existsSync(e))return null;try{return JSON.parse(i.readFileSync(e,"utf-8"))}catch{return null}}function X(e){return i.existsSync(e)?i.readdirSync(e).filter(t=>t.endsWith(".json")).sort().map(t=>w.join(e,t)):[]}function ee(e){return {id:e.id,body:e.body,enqueuedAt:e.enqueuedAt,attempt:e.attempt}}function Xt(e){return {...ee(e),leaseToken:String(e.leaseToken||""),leaseExpiresAt:String(e.leaseExpiresAt||"")}}function er(e){return {...ee(e),reason:e.reason}}function je(e){let t=w.join(e,"active"),r=w.join(e,"leased"),o=w.join(e,"done"),n=w.join(e,"dead"),s=w.join(e,"staged");for(let d of [t,r,o,n,s])i.mkdirSync(d,{recursive:true});let u=0;function p(d){let f=d.replace(/[:.]/g,"-"),m=String(u++).padStart(6,"0");return `${f}-${m}`}function x(d){let f=d.activeOrderKey||p(String(d.enqueuedAt||new Date().toISOString()));return w.join(t,`${f}-${d.id}.json`)}function c(d){return w.join(r,`${d}.json`)}function l(d){return w.join(o,`${d}.json`)}function h(d){return w.join(n,`${d}.json`)}function R(d){return w.join(s,`${d}.json`)}function y(){let d=Date.now();for(let f of X(r)){let m=N(f);if(!m?.leaseExpiresAt)continue;let S=Date.parse(m.leaseExpiresAt);if(Number.isNaN(S)||S>d)continue;let a={id:m.id,body:m.body,enqueuedAt:m.enqueuedAt,attempt:m.attempt,activeOrderKey:m.activeOrderKey};D(x(a),a);try{i.unlinkSync(f);}catch{}}}return {enqueue(d){let f={id:randomUUID(),body:d,enqueuedAt:new Date().toISOString(),attempt:0};return f.activeOrderKey=p(f.enqueuedAt),D(x(f),f),ee(f)},enqueueMany(d){return d.map(f=>this.enqueue(f))},enqueueIfAbsent(d,f){y();for(let S of [t,r,s])for(let a of X(S))if(N(a)?.dedupKey===f)return null;let m={id:randomUUID(),body:d,enqueuedAt:new Date().toISOString(),attempt:0,dedupKey:f};return m.activeOrderKey=p(m.enqueuedAt),D(x(m),m),ee(m)},lease(d){y();let f=Math.max(1,Math.floor(d?.max??1)),m=Math.max(1,Math.floor(d?.visibilityMs??6e4)),S=[];for(let a of X(t)){if(S.length>=f)break;let g=N(a);if(!g)continue;let v=c(g.id);try{B(a,v);}catch{continue}let b={...g,attempt:(Number(g.attempt)||0)+1,leaseToken:randomUUID(),leaseExpiresAt:new Date(Date.now()+m).toISOString()};D(v,b),S.push(Xt(b));}return S},ack(d,f){let m=c(d),S=N(m);if(!S||S.leaseToken!==f)return false;try{B(m,l(d));}catch{return false}return true},nack(d,f,m){let S=c(d),a=N(S);if(!a||a.leaseToken!==f)return false;let g={id:a.id,body:a.body,enqueuedAt:a.enqueuedAt,attempt:a.attempt,activeOrderKey:a.activeOrderKey};m?.dead?(g.reason=m.reason,D(h(d),g)):D(x(g),g);try{i.unlinkSync(S);}catch{}return true},peekActive(d){return y(),X(t).map(f=>N(f)).filter(f=>!!f).map(ee)},peekDeadLetter(d){return X(n).map(f=>N(f)).filter(f=>!!f).map(er)},stage(d,f){let m=f?.dedupKey;if(m){y();for(let a of [t,r,s])for(let g of X(a))if(N(g)?.dedupKey===m)return null}let S={id:randomUUID(),body:d,enqueuedAt:new Date().toISOString(),attempt:0,...m?{dedupKey:m}:{}};return D(R(S.id),S),ee(S)},commitStaged(d){let f=R(d),m=N(f);if(!m)return false;let S=new Date().toISOString(),a={...m,attempt:0,enqueuedAt:S,activeOrderKey:p(S)};D(x(a),a);try{i.unlinkSync(f);}catch{}return true},discardStaged(d,f){let m=R(d),S=N(m);if(!S)return false;let a={id:S.id,body:S.body,enqueuedAt:S.enqueuedAt,attempt:S.attempt,reason:f};D(h(d),a);try{i.unlinkSync(m);}catch{}return true},peekStaged(d){return X(s).map(f=>N(f)).filter(f=>!!f).map(ee)}}}var Ee="__scratch-marker",Te="__scratch-config.json",tr=1440*60*1e3,rr=720*60*1e3,nr=500;function nt(e,t){if(!e)return t;let r=e.replace(/[^A-Za-z0-9._-]/g,"_");return r.length>0?r:t}function oe(e){i.mkdirSync(e,{recursive:true});let t=w.join(e,Ee),r=w.join(e,Te),o=!i.existsSync(t);if(o)try{i.writeFileSync(t,`scratch-store
|
|
4
4
|
${new Date().toISOString()}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkEYBDAEVO_cjs=require('./chunk-EYBDAEVO.cjs');require('./chunk-7JVHYHT2.cjs'),require('./chunk-VQCIOKJV.cjs'),require('./chunk-G4XXRHL2.cjs'),require('./chunk-LODXIALE.cjs'),require('./chunk-QBEQL4TL.cjs'),require('./chunk-QEHKMLHA.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-5XLFPPTY.cjs'),require('./chunk-2RIHC5TZ.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"BOARD_GRAPH_KEY",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.n}});Object.defineProperty(exports,"EMPTY_CONFIG",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.u}});Object.defineProperty(exports,"SNAPSHOT_SCHEMA_VERSION_V1",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.m}});Object.defineProperty(exports,"createBoardLiveCardsNonCorePublic",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.z}});Object.defineProperty(exports,"createBoardLiveCardsPublic",{enumerable:true,get:function(){return chunkEYBDAEVO_cjs.y}});//# sourceMappingURL=board-live-cards-public.cjs.map
|
|
2
2
|
//# sourceMappingURL=board-live-cards-public.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{n as BOARD_GRAPH_KEY,u as EMPTY_CONFIG,m as SNAPSHOT_SCHEMA_VERSION_V1,z as createBoardLiveCardsNonCorePublic,y as createBoardLiveCardsPublic}from'./chunk-
|
|
1
|
+
export{n as BOARD_GRAPH_KEY,u as EMPTY_CONFIG,m as SNAPSHOT_SCHEMA_VERSION_V1,z as createBoardLiveCardsNonCorePublic,y as createBoardLiveCardsPublic}from'./chunk-AHW6EMUO.js';import'./chunk-ANKA7HEJ.js';import'./chunk-44L64VQ2.js';import'./chunk-VGT3TRQG.js';import'./chunk-WDPOGXTY.js';import'./chunk-ATOQP3BD.js';import'./chunk-YT76JNKE.js';import'./chunk-MNEOJWPS.js';import'./chunk-7QNEV5S3.js';import'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=board-live-cards-public.js.map
|
|
2
2
|
//# sourceMappingURL=board-live-cards-public.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunk42ZOYXEV_cjs=require('./chunk-42ZOYXEV.cjs');require('./chunk-LFVMX23W.cjs'),require('./chunk-NM6O35RY.cjs'),require('./chunk-NBJTYAYN.cjs'),require('./chunk-NMOUBZXX.cjs');var chunkBQJVCCFU_cjs=require('./chunk-BQJVCCFU.cjs');require('./chunk-BQUQTOPB.cjs'),require('./chunk-GPCMBPLK.cjs'),require('./chunk-7FGPOGRV.cjs'),require('./chunk-LPXVVMQT.cjs'),require('./chunk-272IYUKT.cjs'),require('./chunk-ZOZ7ZDGA.cjs'),require('./chunk-WRMOGPRG.cjs'),require('./chunk-EYBDAEVO.cjs'),require('./chunk-7JVHYHT2.cjs'),require('./chunk-VQCIOKJV.cjs'),require('./chunk-G4XXRHL2.cjs'),require('./chunk-LODXIALE.cjs'),require('./chunk-GHUW6P4G.cjs'),require('./chunk-QBEQL4TL.cjs'),require('./chunk-QEHKMLHA.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-5XLFPPTY.cjs'),require('./chunk-SDJ3747Q.cjs'),require('./chunk-OF4FPYNI.cjs'),require('./chunk-2RIHC5TZ.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createMultiBoardServerRuntime",{enumerable:true,get:function(){return chunk42ZOYXEV_cjs.b}});Object.defineProperty(exports,"createSingleBoardServerRuntime",{enumerable:true,get:function(){return chunk42ZOYXEV_cjs.a}});Object.defineProperty(exports,"createHostedBoardQueueLaneRegistry",{enumerable:true,get:function(){return chunkBQJVCCFU_cjs.a}});//# sourceMappingURL=board-live-cards-server-runtime.cjs.map
|
|
2
2
|
//# sourceMappingURL=board-live-cards-server-runtime.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{b as createMultiBoardServerRuntime,a as createSingleBoardServerRuntime}from'./chunk-
|
|
1
|
+
export{b as createMultiBoardServerRuntime,a as createSingleBoardServerRuntime}from'./chunk-LDVJPFIW.js';import'./chunk-JB4Q2W7I.js';import'./chunk-XYN5D3GL.js';import'./chunk-O5UYCGIN.js';import'./chunk-CZ6ZFWFT.js';export{a as createHostedBoardQueueLaneRegistry}from'./chunk-7UJQMFVS.js';import'./chunk-FOFGEABN.js';import'./chunk-RKKSVOP2.js';import'./chunk-NTICU4OK.js';import'./chunk-O7NOHKVR.js';import'./chunk-ZJ5M5COT.js';import'./chunk-HFI2NAZJ.js';import'./chunk-6MD6FVE3.js';import'./chunk-AHW6EMUO.js';import'./chunk-ANKA7HEJ.js';import'./chunk-44L64VQ2.js';import'./chunk-VGT3TRQG.js';import'./chunk-WDPOGXTY.js';import'./chunk-6M3RIGUH.js';import'./chunk-ATOQP3BD.js';import'./chunk-YT76JNKE.js';import'./chunk-MNEOJWPS.js';import'./chunk-7QNEV5S3.js';import'./chunk-BJGK5FNL.js';import'./chunk-NIBLKYXN.js';import'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=board-live-cards-server-runtime.js.map
|
|
2
2
|
//# sourceMappingURL=board-live-cards-server-runtime.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';var chunkLFVMX23W_cjs=require('./chunk-LFVMX23W.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunkNMOUBZXX_cjs=require('./chunk-NMOUBZXX.cjs'),chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkX5CZE2L7_cjs=require('./chunk-X5CZE2L7.cjs'),chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkVNLMJEIX_cjs=require('./chunk-VNLMJEIX.cjs'),chunk5XLFPPTY_cjs=require('./chunk-5XLFPPTY.cjs'),chunkSDJ3747Q_cjs=require('./chunk-SDJ3747Q.cjs'),chunkOF4FPYNI_cjs=require('./chunk-OF4FPYNI.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function ie(R){let{apiBasePath:w,json:b,readJsonBody:$,bootstrapBoard:A,createMcpControlplaneToolRegistry:x,retriggerCard:D,applyCardAction:N,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:q}=R;async function j(T,S,W){let H=T.method||"GET",J=W,f=J.pathname;try{if(H==="POST"&&f===`${w}/mcp-actions`){await A();let p=Date.now(),y=new Date(p).toISOString(),O=await $(T),l=typeof O.tool=="string"?O.tool.trim():"",B=O.args&&typeof O.args=="object"&&!Array.isArray(O.args)?O.args:{};if(!l)return b(S,400,{error:"tool is required"}),!0;let k=chunkLPXVVMQT_cjs.a(B,"card_id");if(!k)return b(S,400,{error:"MCP action requires card_id"}),!0;if(l==="retrigger-card"||l==="retrigger"){await D(k);let F=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:200}}),!0}let P=chunkLPXVVMQT_cjs.c(B,"payload");if(l==="chat-send"&&!await E(k)){let F=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:409}),!0}if(l==="chat-send"){let F=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!F||!String(F).trim()){let L=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(L).toISOString(),responseSentAtMs:L,responseStatus:400}),!0}}await N(k,l,P);let I=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(I).toISOString(),responseSentAtMs:I,responseStatus:200}}),!0}if(H==="POST"&&f===`${w}/mcp-controlplane`){await A();let p=await $(T),y=typeof p.tool=="string"?p.tool.trim():"",O=p.args&&typeof p.args=="object"&&!Array.isArray(p.args)?p.args:{};if(!y)return b(S,400,{error:"tool is required"}),!0;try{let l=await chunk272IYUKT_cjs.a(y,O,x());if(l&&typeof l=="object"&&!Array.isArray(l)){let B=l;if(B.status==="fail")return b(S,400,{error:chunk272IYUKT_cjs.b(l,"Request failed")}),!0;if(B.status==="error")return b(S,500,{error:chunk272IYUKT_cjs.b(l,"Internal error")}),!0}b(S,200,l);}catch(l){let B=typeof l?.statusCode=="number"?Number(l.statusCode):500,k=l instanceof Error?l.message:String(l);b(S,B,{error:k});}return !0}let g=f.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/cards/([^/]+)/retrigger$`));if(H==="POST"&&g){await A();let p=decodeURIComponent(g[1]);return await D(p),b(S,200,{ok:!0}),!0}let d=f.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/cards/([^/]+)/actions$`));if(H==="POST"&&d){await A();let p=decodeURIComponent(d[1]),y=Date.now(),O=new Date(y).toISOString(),l=await $(T),B=l?.actionType;if(B==="chat-send"&&!await E(p)){let P=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:409}),!0}if(B==="chat-send"){let P=l?.payload??{},I=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!I||!String(I).trim()){let F=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:400}),!0}}await N(p,B,l?.payload);let k=Date.now();return b(S,200,{ok:!0,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(k).toISOString(),responseSentAtMs:k,responseStatus:200}),!0}let v=f.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/cards/([^/]+)/files/(\\d+)$`));if(H==="GET"&&v){let p=decodeURIComponent(v[1]),y=parseInt(v[2],10),O=J.searchParams.get("sn");return await q(S,p,y,O),!0}return !1}catch(g){let d=g?.statusCode||500;return b(S,d,{error:String(g?.message||g)}),true}}return {handleRuntimeApi:j}}var ze=3e4;function Ke(R){let w=R.socket?.remoteAddress??"";return w==="127.0.0.1"||w==="::1"||w==="::ffff:127.0.0.1"}function ce(R){let{apiBasePath:w,emitNotifications:b,readJsonBody:$,json:A}=R,x=`${w}/notify-q`;async function D(N,E,q){if(q.pathname!==x)return false;if((N.method??"").toUpperCase()!=="POST")return A(E,405,{status:"error",error:"Method not allowed"}),true;if(!Ke(N))return A(E,403,{status:"error",error:"Forbidden"}),true;let j;try{j=await $(N);}catch{return A(E,400,{status:"error",error:"Invalid JSON body"}),true}if(!j||typeof j!="object"||!Array.isArray(j.notifications))return A(E,400,{status:"error",error:"body.notifications must be an array"}),true;let T=j.notifications,{accepted:S,rejected:W}=chunkNMOUBZXX_cjs.b(T,Date.now(),ze);return S.length>0&&b(S),A(E,200,{status:"success",data:{accepted:S.length,rejected:W}}),true}return {handleNotifyRoute:D}}var de={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},ue="chat-handler-flow-queue",ot="__probe__echo__probe__";function jr(R){let w=String(R.apiBasePath||"/api/board").replace(/\/$/,""),b={...de,...R.corsHeaders||{}},$=R.queueLaneTuning??{},A=R.boardId||"",x=R.logger||{info:console.log,warn:console.warn,error:console.error},D=R.invocationAdapter,N=R.chatFlowRunner||null,E=R.notificationTransport||null,q=R.serverUrl||null,j=R.executionExtra||{},T=R.onSseClientConnected,S=R.onSseClientDisconnected,W=R.onChannelSubscribed,H=R.onChannelUnsubscribed,J=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:S}),f=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function g(t){function e(a){return {...a,queueStorageForRef(u,C){return chunkSDJ3747Q_cjs.a(a.queueStorageForRef(u,C),{lane:C,emitNotification:i})}}}function r(a){return {...a,queueStorageForRef(u,C){return chunkX5CZE2L7_cjs.h(a.queueStorageForRef(u,C),{lane:C,emitNotification:i})}}}function n(a){return {async get(u){return a.get(u)},async set(u){return a.set(u)},async del(u){return a.del(u)},async patch(u){return a.patch(u)},async appendFiles(u){return a.appendFiles(u)}}}function o(a){return {async get(u){return await a.get(u)},async set(u){return await a.set(u)},async del(u){return await a.del(u)},async patch(u){return await a.patch(u)},async appendFiles(u){return await a.appendFiles(u)}}}let s=null;function i(a){if(a.kind==="notification-batch"){V(a.notifications,s??void 0);return}V([a],s??void 0);}let c=chunkBQUQTOPB_cjs.a(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),M=t.nonCoreAdapter??(!chunkBQUQTOPB_cjs.a(c)&&l(c)?c:null),h=chunkBQUQTOPB_cjs.a(c)?chunkX5CZE2L7_cjs.i(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}):chunkVNLMJEIX_cjs.y(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}),_=t.nonCore??(M?chunkVNLMJEIX_cjs.z(t.baseRef,M,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c.chatStorageForRef(t.chatStoreRef),dt,We=chunkBQUQTOPB_cjs.a(c)?(()=>{let a=chunkX5CZE2L7_cjs.d(chunkX5CZE2L7_cjs.c(chunkX5CZE2L7_cjs.b(c.kvStorageForRef(t.cardStoreRef)),c.hashFn),x.warn),u=chunkX5CZE2L7_cjs.g(a,{emitNotification:i}),C=o(u);return dt={get(m){return C.get(m)},set(m){return C.set(m)}},C})():(()=>{let a=c.kvStorageForRef(t.cardStoreRef),C=chunk5XLFPPTY_cjs.a(chunkVNLMJEIX_cjs.l({readIndex:()=>a.read("_index"),writeIndex:m=>a.write("_index",m),readCard:m=>a.read(m),writeCard:(m,ft)=>(a.write(m,ft),m),removeCard:m=>{a.delete(m);},cardExists:m=>a.read(m)!==null,defaultCardKey:m=>m},x.warn),{emitNotification:i});return dt=C,n(C)})(),lt;if(chunkBQUQTOPB_cjs.a(c)){let a=c.blobStorageForRef(t.artifactsStoreRef);lt={async putBytes(u,C){if(a.writeBytes){await a.writeBytes(u,C);return}let m=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(u,m);},async getBytes(u){if(a.readBytes){let m=await a.readBytes(u);if(m!==null)return m}let C=await a.read(u);if(C===null)return null;try{let m=JSON.parse(C);if(m&&m.__kind==="bytes-array"&&Array.isArray(m.data))return new Uint8Array(m.data)}catch{}return new TextEncoder().encode(C)},async listKeys(u){return await a.listKeys(u)}};}else {let a=c.blobStorageForRef(t.artifactsStoreRef),u=chunkNBJTYAYN_cjs.a(a);lt={putBytes(C,m,ft){u.putBytes(C,m,ft);},getBytes(C){return u.getBytes(C)},listKeys(C){return u.list(C).map(m=>m.key)}};}let Je={async init(a){return h.init(a)},async status(a){return h.status(a)},async getConfig(a){return h.getConfig(a)},async getAllOutputsDataObjects(a){return h.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return h.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return h.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return h.buildSseOneShotPayload(a)},async upsertCard(a){return h.upsertCard(a)},async removeCard(a){return h.removeCard(a)},async sourceDataFetched(a){return h.sourceDataFetched(a)},async sourceDataFetchFailure(a){return h.sourceDataFetchFailure(a)}};return s={label:t.label,board:h,nonCore:_,publicCardStore:dt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return lt},get chatStorage(){return Ue},boardAdapter:c,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:chunkNMOUBZXX_cjs.c(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let d=R.boards.map(g),v=new Map;function p(t){return v.get(t)??0}function y(t){return t.queueStoreRef}function O(t,e){if(chunkBQUQTOPB_cjs.a(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(y(t),e);return chunkWRMOGPRG_cjs.a(n)}let r=t.boardAdapter.queueStorageForRef(y(t),e);return chunkGPCMBPLK_cjs.a(r)}function l(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function B(t){let e=d[p(t)];return {files:e?e.filesArtifacts:null}}function k(){return chunkNBJTYAYN_cjs.c()}function P(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function I(t){return "cardId"in t&&typeof t.cardId=="string"?z(t.cardId)??void 0:d[0]??void 0}function F(t){for(let e of t){let r=I(e);if(r)return r}return d[0]??void 0}function L(t,e={}){if(!t||t.length===0)return;let r=chunk2RIHC5TZ_cjs.e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??F(r);if(e.appendState!==false&&o&&chunkNMOUBZXX_cjs.e(o.notification,n),e.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&J.broadcastNotificationBatch(i),s.length>0&&f.broadcastNotificationBatch(s);}if(!(e.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function V(t,e){L(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function le(t){if(!t||t.notificationTeardown||!E||!t.notifyRef)return;let e=await E.subscribe(t.notifyRef,r=>{let n=chunkNMOUBZXX_cjs.a(r);L(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function fe(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let n=await t.boardOps.init({params:e,body:r});if(n.status!=="success")throw Object.assign(new Error(n.error||`init failed for ${t.label}`),{statusCode:500});if(await le(t),!t.chatHandlerFlow&&t.chatHandlerRef&&D.describe)try{let o=await D.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?x.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&x.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){x.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ct(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&chunkNMOUBZXX_cjs.d(r.data)&&e.push({kind:"status",status:r.data});let n=await t.boardOps.getAllOutputsDataObjects({});if(n.status==="success"&&n.data!=null)for(let[s,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&L(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function gt(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),n=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let o of n)typeof o.id=="string"&&(v.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of d)await fe(t);}async function at(){await G();for(let t=0;t<d.length;t++)await ct(d[t]),await gt(d[t],t),await ct(d[t]);}async function Rt(t=false){t||await G();for(let e of d){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function z(t){return d[p(t)]??null}async function X(t){let e=z(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function pe(){let t=async r=>{if(!r)return [];let n=await r.cardStoreOps.get({});return n.status!=="success"||!Array.isArray(n.data?.cards)?[]:n.data.cards},e=[];for(let r of d)e.push(...await t(r));return e}function yt(){return d[0]??null}function me(t){return z(t)??yt()}function U(t){let e=me(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ge(t){return await U(t).isProcessing(t)}async function Y(t,e){let r=await tt.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let tt=chunkOF4FPYNI_cjs.a({append(t,e,r,n,o){return U(t).append(t,e,r,n,o)},readAll(t){return U(t).readAll(t)},readAfter(t,e){return U(t).readAfter(t,e)},clear(t){return U(t).clear(t)},setProcessing(t,e){return U(t).setProcessing(t,e)},isProcessing(t){return U(t).isProcessing(t)},getConfig(t){return U(t).getConfig(t)},setConfig(t,e){return U(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);}}),ht=chunkNMOUBZXX_cjs.p({boardContexts:d,cardOwnerIndex:v,cardContextForCard:t=>z(t),readStatusSnapshot:()=>be(),readDataObjectsByToken:()=>Ce(),readCardRuntimeArtifacts:()=>Se(),readCardFromStore:t=>X(t),readCardDefinitions:()=>pe(),processAccumulatedLaneInternal:t=>Rt(t),reportSourceFetched:(t,e)=>Bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>kt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>St(t,e,r,n,o),chatStorePublic:tt,serverUrl:q,apiBasePath:w}),Re=ht.mcpCardStoreFacade,st=ht.createMcpFacade,ye=chunkNMOUBZXX_cjs.j({boardId:A,bootstrapBoard:()=>at(),sseHub:J,onChannelSubscribed:W,onChannelUnsubscribed:H,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>Re()});function he(t){return chunkNMOUBZXX_cjs.m(t)}function we(){return chunkNMOUBZXX_cjs.n(st())}function wt(){return chunkNMOUBZXX_cjs.o({boardId:A,uploadCardFile:St,getMcpFacade:()=>st(),controlplane:ye})}let it=chunkNMOUBZXX_cjs.k({boardId:A,boardContexts:d,readChatRecords:t=>Fe(t),getChatProcessing:t=>ge(t)}),be=it.readStatusSnapshot,Se=it.readCardRuntimeArtifacts,Ce=it.readDataObjectsByToken,ut=it.buildPublishedRuntimePayload;async function bt(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=z(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await X(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,M=e(i)||i;if(o&&JSON.stringify(M)===c)return;let h=await s.cardStoreOps.set({body:M});if(h.status!=="success")throw Object.assign(new Error(h.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let _=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(_.status!=="success")throw Object.assign(new Error(_.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Ae(t,e){await bt(t,e,{syncBoard:true});}async function Be(t,e){await bt(t,e,{syncBoard:false});}async function ke(t){let e=z(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await X(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let n=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function Pe(t){let e=await tt.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await Y(t,!1);}catch{}}async function Oe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await tt.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function Fe(t){return await U(t).readAll(t)}let St=chunkNMOUBZXX_cjs.l({safeCardId:t=>P(t),artifactsStores:t=>B(t),cardFileMetadataStore:()=>k(),readCardFromStore:t=>X(t),updateCardLocalOnly:(t,e)=>Be(t,e),writeChatRecord:(t,e,r,n,o)=>Oe(t,e,r,n,o)}).uploadCardFile;async function Ct(t){let e=z(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function ve(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function xe(t,e,r=false,n="",o=""){try{let s=await Ct(t);if(!s){try{await Y(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:M}=s;if(!r)try{await Y(t,!0);}catch{}let h={boardId:A,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...j,...q?{serverUrl:q}:{}},_=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:ue}}:M;chunkBQUQTOPB_cjs.a(i.boardAdapter)?await O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}):O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await Y(t,!1);}catch{}x.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Te(t,e,r){if(e.howToRun==="built-in"&&chunkBQUQTOPB_cjs.b(e)===ue){let n=N,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:A,cardId:String(s.cardId||""),label:t.label,logger:x,serverUrl:q,executionExtra:j}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return D.invoke(e,r)}async function Ne(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?z(r):yt();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Te(n,t.ref,t.args);if(!o.dispatched){if(r)try{await Y(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Ee(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=wt(),i=ve(r?.text),c=i?i.text:r?.text,M=await chunk272IYUKT_cjs.a("manage.add-chat-entry-and-any-attachments",{board_id:A,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(M?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(M,`chat-send append failed for card ${t}`));let h=M?.data?.id;if(typeof h!="string"||!h)throw new Error(`chat-send did not return an append id for card ${t}`);let _=await chunk272IYUKT_cjs.a("setstate.chat-processing-started",{board_id:A,card_id:t},s);if(_?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(_,`chat-send processing update failed for card ${t}`));xe(t,h,true,o,i?.assistant||"");return}await Ae(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=k().normalizeIncoming(r?.files,s);return c.length>0&&k().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function At(t,e,r){let n=await X(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=k().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=P(t),c=B(t),M=String(s.stored_name||""),h=`${i}/${M}`,_=c.files?await c.files.getBytes(h):null;if(!_)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:_}}async function je(t,e,r,n){let{fileRecord:o,bytes:s}=await At(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function Me(t){let e=String(t||"").toLowerCase();return e.startsWith("text/")||e.includes("json")||e.includes("xml")||e.includes("javascript")||e.includes("typescript")||e.includes("yaml")||e.includes("csv")}function _e(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
|
|
2
|
-
`)}async function rt(t){let e=[];for await(let n of t)e.push(n);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(e)).trim();return r?JSON.parse(r):{}}async function 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 n=d[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function kt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=d[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let De=chunkLFVMX23W_cjs.b({sseHub:J,queueSseHub:f,corsHeaders:b,json:et,buildPublishedRuntimePayload:()=>ut(),onSseClientConnected:T,onChannelSubscribed:W,onChannelUnsubscribed:H,apiBasePath:w,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>at(),boardContexts:d,publishPersistedStateSnapshot:t=>ct(t),upsertCardsFromSource:(t,e)=>gt(t,e)}).handleWatchersRoutes,qe=chunk7FGPOGRV_cjs.a({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpFacade:()=>st(),createMcpToolRegistry:t=>he(t),resolveCardFileDownloadPayload:(t,e,r)=>At(t,e,r),isLikelyTextMimeType:t=>Me(t),sliceTextByLines:(t,e,r)=>_e(t,e,r)}).handleAgentfaceApi,Ie=chunkNM6O35RY_cjs.a({apiBasePath:w,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ie({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpControlplaneToolRegistry:()=>wt(),retriggerCard:t=>ke(t),applyCardAction:(t,e,r)=>Ee(t,e,r),resolveChatHandlerTarget:t=>Ct(t),sendCardFileDownloadResponse:(t,e,r,n)=>je(t,e,r,n)}).handleRuntimeApi,He=ce({apiBasePath:w,emitNotifications:t=>V(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Le(t,e,r){return !!(await qe(t,e,r)||await Ie(t,e,r)||await De(t,e,r)||await He(t,e,r)||await $e(t,e,r))}return {get apiBasePath(){return w},get corsHeaders(){return b},get queueLaneTuning(){return $},handleRuntimeApi:Le,emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);},buildPublishedRuntimePayload:ut,__drainProcessAccumulatedLane:Rt,handleChatAgentRequest:Ne,clearChatRecords:Pe,reportSourceFetched(t,e){return Bt(t,{ref:e})},reportSourceFetchFailure(t,e){return kt(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 Mr(R){let w=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),b={...de,...R.corsHeaders||{}},$=R.serverMetaStore,A=R.boardRuntimeFactory,x=new Map,D="boards-config.json";function N(){let f=$.getText(D);if(!f)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(f)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function E(f){$.putText(D,JSON.stringify(f,null,2));}function q(f){let g=String(f||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return g.length>0&&g.length<=64?g:null}function j(f){if(x.has(f))return x.get(f);let d=N().boards.find(p=>p.id===f)||{},v=A(f,d);return x.set(f,v),v}function T(f,g,d){let v=JSON.stringify(d),p=typeof Buffer<"u"?Buffer.byteLength(v):new TextEncoder().encode(v).length;f.writeHead(g,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":p}),f.end(v);}async function S(f,g,d){let v=f.method||"GET",p=d.pathname;if(v==="GET"&&p===w)return T(g,200,{ok:true,boards:N().boards}),true;if(v==="POST"&&p===w){let y=[];for await(let F of f)y.push(F);let O=typeof Buffer<"u"?Buffer.concat(y).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(y)).trim(),l={};try{l=O?JSON.parse(O):{};}catch{l={};}let B=q(l.id);if(!B)return T(g,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let k=N();if(k.boards.some(F=>F.id===B))return T(g,409,{error:`Board "${B}" is already registered`}),true;let P=typeof l.label=="string"&&l.label.trim()?l.label.trim():B,I={id:B,label:P};for(let[F,L]of Object.entries(l))F==="id"||F==="label"||L!=null&&(I[F]=L);return k.boards.push(I),E(k),T(g,200,{ok:true,board:I}),true}return false}async function W(f,g,d){let p=d.pathname.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/([^/]+)(/|$)`));if(!p)return false;let y=q(decodeURIComponent(p[1]));return y?N().boards.some(B=>B.id===y)?!!await j(y).handleRuntimeApi(f,g,d):(T(g,404,{error:`Board "${y}" not registered. POST ${w} with {id} to register it first.`}),true):(T(g,400,{error:"Invalid board id"}),true)}async function H(f,g,d){return !!(await S(f,g,d)||await W(f,g,d))}function J(f){if(!N().boards.some(d=>d.id===f))throw Object.assign(new Error(`Board "${f}" not registered`),{statusCode:404});return {service:j(f)}}return {get apiBasePath(){return w},get corsHeaders(){return b},handleApi:H,requireBoardService:J}}exports.a=jr;exports.b=Mr;//# sourceMappingURL=chunk-
|
|
3
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkLFVMX23W_cjs=require('./chunk-LFVMX23W.cjs'),chunkNM6O35RY_cjs=require('./chunk-NM6O35RY.cjs'),chunkNBJTYAYN_cjs=require('./chunk-NBJTYAYN.cjs'),chunkNMOUBZXX_cjs=require('./chunk-NMOUBZXX.cjs'),chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkGPCMBPLK_cjs=require('./chunk-GPCMBPLK.cjs'),chunk7FGPOGRV_cjs=require('./chunk-7FGPOGRV.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunk272IYUKT_cjs=require('./chunk-272IYUKT.cjs'),chunkZOZ7ZDGA_cjs=require('./chunk-ZOZ7ZDGA.cjs'),chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkEYBDAEVO_cjs=require('./chunk-EYBDAEVO.cjs'),chunk5XLFPPTY_cjs=require('./chunk-5XLFPPTY.cjs'),chunkSDJ3747Q_cjs=require('./chunk-SDJ3747Q.cjs'),chunkOF4FPYNI_cjs=require('./chunk-OF4FPYNI.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');function ie(R){let{apiBasePath:w,json:b,readJsonBody:$,bootstrapBoard:A,createMcpControlplaneToolRegistry:x,retriggerCard:D,applyCardAction:N,resolveChatHandlerTarget:E,sendCardFileDownloadResponse:q}=R;async function j(T,S,W){let H=T.method||"GET",J=W,f=J.pathname;try{if(H==="POST"&&f===`${w}/mcp-actions`){await A();let p=Date.now(),y=new Date(p).toISOString(),O=await $(T),l=typeof O.tool=="string"?O.tool.trim():"",B=O.args&&typeof O.args=="object"&&!Array.isArray(O.args)?O.args:{};if(!l)return b(S,400,{error:"tool is required"}),!0;let k=chunkLPXVVMQT_cjs.a(B,"card_id");if(!k)return b(S,400,{error:"MCP action requires card_id"}),!0;if(l==="retrigger-card"||l==="retrigger"){await D(k);let F=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:200}}),!0}let P=chunkLPXVVMQT_cjs.c(B,"payload");if(l==="chat-send"&&!await E(k)){let F=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:409}),!0}if(l==="chat-send"){let F=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!F||!String(F).trim()){let L=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${k}`,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(L).toISOString(),responseSentAtMs:L,responseStatus:400}),!0}}await N(k,l,P);let I=Date.now();return b(S,200,{status:"success",data:{ok:!0,cardId:k,actionType:l,requestReceivedAt:y,requestReceivedAtMs:p,responseSentAt:new Date(I).toISOString(),responseSentAtMs:I,responseStatus:200}}),!0}if(H==="POST"&&f===`${w}/mcp-controlplane`){await A();let p=await $(T),y=typeof p.tool=="string"?p.tool.trim():"",O=p.args&&typeof p.args=="object"&&!Array.isArray(p.args)?p.args:{};if(!y)return b(S,400,{error:"tool is required"}),!0;try{let l=await chunk272IYUKT_cjs.a(y,O,x());if(l&&typeof l=="object"&&!Array.isArray(l)){let B=l;if(B.status==="fail")return b(S,400,{error:chunk272IYUKT_cjs.b(l,"Request failed")}),!0;if(B.status==="error")return b(S,500,{error:chunk272IYUKT_cjs.b(l,"Internal error")}),!0}b(S,200,l);}catch(l){let B=typeof l?.statusCode=="number"?Number(l.statusCode):500,k=l instanceof Error?l.message:String(l);b(S,B,{error:k});}return !0}let g=f.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/cards/([^/]+)/retrigger$`));if(H==="POST"&&g){await A();let p=decodeURIComponent(g[1]);return await D(p),b(S,200,{ok:!0}),!0}let d=f.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/cards/([^/]+)/actions$`));if(H==="POST"&&d){await A();let p=decodeURIComponent(d[1]),y=Date.now(),O=new Date(y).toISOString(),l=await $(T),B=l?.actionType;if(B==="chat-send"&&!await E(p)){let P=Date.now();return b(S,409,{error:`chat handler is not configured for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(P).toISOString(),responseSentAtMs:P,responseStatus:409}),!0}if(B==="chat-send"){let P=l?.payload??{},I=typeof P["turn-id"]=="string"?P["turn-id"]:typeof P.turnId=="string"?P.turnId:typeof P.turn=="string"?P.turn:"";if(!I||!String(I).trim()){let F=Date.now();return b(S,400,{error:`chat-send requires a non-empty 'turn-id' (or 'turnId'/'turn') in payload for card: ${p}`,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(F).toISOString(),responseSentAtMs:F,responseStatus:400}),!0}}await N(p,B,l?.payload);let k=Date.now();return b(S,200,{ok:!0,requestReceivedAt:O,requestReceivedAtMs:y,responseSentAt:new Date(k).toISOString(),responseSentAtMs:k,responseStatus:200}),!0}let v=f.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/cards/([^/]+)/files/(\\d+)$`));if(H==="GET"&&v){let p=decodeURIComponent(v[1]),y=parseInt(v[2],10),O=J.searchParams.get("sn");return await q(S,p,y,O),!0}return !1}catch(g){let d=g?.statusCode||500;return b(S,d,{error:String(g?.message||g)}),true}}return {handleRuntimeApi:j}}var ze=3e4;function Ke(R){let w=R.socket?.remoteAddress??"";return w==="127.0.0.1"||w==="::1"||w==="::ffff:127.0.0.1"}function ce(R){let{apiBasePath:w,emitNotifications:b,readJsonBody:$,json:A}=R,x=`${w}/notify-q`;async function D(N,E,q){if(q.pathname!==x)return false;if((N.method??"").toUpperCase()!=="POST")return A(E,405,{status:"error",error:"Method not allowed"}),true;if(!Ke(N))return A(E,403,{status:"error",error:"Forbidden"}),true;let j;try{j=await $(N);}catch{return A(E,400,{status:"error",error:"Invalid JSON body"}),true}if(!j||typeof j!="object"||!Array.isArray(j.notifications))return A(E,400,{status:"error",error:"body.notifications must be an array"}),true;let T=j.notifications,{accepted:S,rejected:W}=chunkNMOUBZXX_cjs.b(T,Date.now(),ze);return S.length>0&&b(S),A(E,200,{status:"success",data:{accepted:S.length,rejected:W}}),true}return {handleNotifyRoute:D}}var de={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},ue="chat-handler-flow-queue",ot="__probe__echo__probe__";function jr(R){let w=String(R.apiBasePath||"/api/board").replace(/\/$/,""),b={...de,...R.corsHeaders||{}},$=R.queueLaneTuning??{},A=R.boardId||"",x=R.logger||{info:console.log,warn:console.warn,error:console.error},D=R.invocationAdapter,N=R.chatFlowRunner||null,E=R.notificationTransport||null,q=R.serverUrl||null,j=R.executionExtra||{},T=R.onSseClientConnected,S=R.onSseClientDisconnected,W=R.onChannelSubscribed,H=R.onChannelUnsubscribed,J=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async(t,e)=>await tt.buildSseOneShotBatch({params:{cardId:t},body:{receiving:e}}),onSseClientDisconnected:S}),f=chunkLFVMX23W_cjs.a({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function g(t){function e(a){return {...a,queueStorageForRef(u,C){return chunkSDJ3747Q_cjs.a(a.queueStorageForRef(u,C),{lane:C,emitNotification:i})}}}function r(a){return {...a,queueStorageForRef(u,C){return chunkZOZ7ZDGA_cjs.h(a.queueStorageForRef(u,C),{lane:C,emitNotification:i})}}}function n(a){return {async get(u){return a.get(u)},async set(u){return a.set(u)},async del(u){return a.del(u)},async patch(u){return a.patch(u)},async appendFiles(u){return a.appendFiles(u)}}}function o(a){return {async get(u){return await a.get(u)},async set(u){return await a.set(u)},async del(u){return await a.del(u)},async patch(u){return await a.patch(u)},async appendFiles(u){return await a.appendFiles(u)}}}let s=null;function i(a){if(a.kind==="notification-batch"){V(a.notifications,s??void 0);return}V([a],s??void 0);}let c=chunkBQUQTOPB_cjs.a(t.boardAdapter)?r(t.boardAdapter):e(t.boardAdapter),M=t.nonCoreAdapter??(!chunkBQUQTOPB_cjs.a(c)&&l(c)?c:null),h=chunkBQUQTOPB_cjs.a(c)?chunkZOZ7ZDGA_cjs.i(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}):chunkEYBDAEVO_cjs.y(t.baseRef,c,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,scratchStoreRef:t.scratchStoreRef,taskExecutorRef:t.taskExecutorRef,chatHandlerFlow:t.chatHandlerFlow,emitNotification:i}),_=t.nonCore??(M?chunkEYBDAEVO_cjs.z(t.baseRef,M,{boardRuntimeStoreRef:t.boardRuntimeStoreRef,taskExecutorRef:t.taskExecutorRef}):null),Ue=c.chatStorageForRef(t.chatStoreRef),dt,We=chunkBQUQTOPB_cjs.a(c)?(()=>{let a=chunkZOZ7ZDGA_cjs.d(chunkZOZ7ZDGA_cjs.c(chunkZOZ7ZDGA_cjs.b(c.kvStorageForRef(t.cardStoreRef)),c.hashFn),x.warn),u=chunkZOZ7ZDGA_cjs.g(a,{emitNotification:i}),C=o(u);return dt={get(m){return C.get(m)},set(m){return C.set(m)}},C})():(()=>{let a=c.kvStorageForRef(t.cardStoreRef),C=chunk5XLFPPTY_cjs.a(chunkEYBDAEVO_cjs.l({readIndex:()=>a.read("_index"),writeIndex:m=>a.write("_index",m),readCard:m=>a.read(m),writeCard:(m,ft)=>(a.write(m,ft),m),removeCard:m=>{a.delete(m);},cardExists:m=>a.read(m)!==null,defaultCardKey:m=>m},x.warn),{emitNotification:i});return dt=C,n(C)})(),lt;if(chunkBQUQTOPB_cjs.a(c)){let a=c.blobStorageForRef(t.artifactsStoreRef);lt={async putBytes(u,C){if(a.writeBytes){await a.writeBytes(u,C);return}let m=JSON.stringify({__kind:"bytes-array",data:[...C]});await a.write(u,m);},async getBytes(u){if(a.readBytes){let m=await a.readBytes(u);if(m!==null)return m}let C=await a.read(u);if(C===null)return null;try{let m=JSON.parse(C);if(m&&m.__kind==="bytes-array"&&Array.isArray(m.data))return new Uint8Array(m.data)}catch{}return new TextEncoder().encode(C)},async listKeys(u){return await a.listKeys(u)}};}else {let a=c.blobStorageForRef(t.artifactsStoreRef),u=chunkNBJTYAYN_cjs.a(a);lt={putBytes(C,m,ft){u.putBytes(C,m,ft);},getBytes(C){return u.getBytes(C)},listKeys(C){return u.list(C).map(m=>m.key)}};}let Je={async init(a){return h.init(a)},async status(a){return h.status(a)},async getConfig(a){return h.getConfig(a)},async getAllOutputsDataObjects(a){return h.getAllOutputsDataObjects(a)},async getAllOutputsComputedValues(a){return h.getAllOutputsComputedValues(a)},async getOutputsFetchedSources(a){return h.getOutputsFetchedSources(a)},async buildSseOneShotPayload(a){return h.buildSseOneShotPayload(a)},async upsertCard(a){return h.upsertCard(a)},async removeCard(a){return h.removeCard(a)},async sourceDataFetched(a){return h.sourceDataFetched(a)},async sourceDataFetchFailure(a){return h.sourceDataFetchFailure(a)}};return s={label:t.label,board:h,nonCore:_,publicCardStore:dt,boardOps:Je,cardStoreOps:We,get filesArtifacts(){return lt},get chatStorage(){return Ue},boardAdapter:c,boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,artifactsStoreRef:t.artifactsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef,notifyRef:t.notifyRef,taskExecutorRef:t.taskExecutorRef,chatHandlerRef:t.chatHandlerRef,chatHandlerFlow:t.chatHandlerFlow,inferenceAdapterRef:t.inferenceAdapterRef,notification:chunkNMOUBZXX_cjs.c(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},s}let d=R.boards.map(g),v=new Map;function p(t){return v.get(t)??0}function y(t){return t.queueStoreRef}function O(t,e){if(chunkBQUQTOPB_cjs.a(t.boardAdapter)){let n=t.boardAdapter.queueStorageForRef(y(t),e);return chunkWRMOGPRG_cjs.a(n)}let r=t.boardAdapter.queueStorageForRef(y(t),e);return chunkGPCMBPLK_cjs.a(r)}function l(t){let e=t;return typeof e.invokeExecutor=="function"&&typeof e.validateSchema=="function"}function B(t){let e=d[p(t)];return {files:e?e.filesArtifacts:null}}function k(){return chunkNBJTYAYN_cjs.c()}function P(t){return String(t||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function I(t){return "cardId"in t&&typeof t.cardId=="string"?z(t.cardId)??void 0:d[0]??void 0}function F(t){for(let e of t){let r=I(e);if(r)return r}return d[0]??void 0}function L(t,e={}){if(!t||t.length===0)return;let r=chunk2RIHC5TZ_cjs.e(t),n={kind:"notification-batch",category:"batch",notifications:r},o=e.ctx??F(r);if(e.appendState!==false&&o&&chunkNMOUBZXX_cjs.e(o.notification,n),e.broadcastSse!==false){let s=r.filter(c=>c.kind==="message_enqueued"),i=r.filter(c=>c.kind!=="message_enqueued");i.length>0&&J.broadcastNotificationBatch(i),s.length>0&&f.broadcastNotificationBatch(s);}if(!(e.mirrorExternal===false||!o?.boardAdapter.publishBoardChangeNotifications))try{let s=r.filter(i=>i.category==="board-output"||i.category==="card-store");s.length>0&&o.boardAdapter.publishBoardChangeNotifications(s);}catch{}}function V(t,e){L(t,{ctx:e,appendState:true,broadcastSse:true,mirrorExternal:true});}async function le(t){if(!t||t.notificationTeardown||!E||!t.notifyRef)return;let e=await E.subscribe(t.notifyRef,r=>{let n=chunkNMOUBZXX_cjs.a(r);L(n,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});});t.notificationTeardown=e;}async function fe(t){if(!t||t.initialized)return;let e={boardRuntimeStoreRef:t.boardRuntimeStoreRef,cardStoreRef:t.cardStoreRef,outputsStoreRef:t.outputsStoreRef,fetchedSourcesStoreRef:t.fetchedSourcesStoreRef,artifactsStoreRef:t.artifactsStoreRef,queueStoreRef:t.queueStoreRef,chatStoreRef:t.chatStoreRef,scratchStoreRef:t.scratchStoreRef},r={};t.taskExecutorRef&&(r["task-executor-ref"]=t.taskExecutorRef),t.chatHandlerFlow!==void 0&&(r["chat-handler-flow"]=t.chatHandlerFlow);let n=await t.boardOps.init({params:e,body:r});if(n.status!=="success")throw Object.assign(new Error(n.error||`init failed for ${t.label}`),{statusCode:500});if(await le(t),!t.chatHandlerFlow&&t.chatHandlerRef&&D.describe)try{let o=await D.describe(t.chatHandlerRef);o&&o.kind!=="chat-handler"?x.warn(`[init] chat-handler describe returned kind="${o.kind}", expected "chat-handler" for ${t.label}`):o&&x.info(`[init] chat-handler validated: ${o.name} (protocol ${o.protocolVersion}) for ${t.label}`);}catch(o){x.warn(`[init] chat-handler describe failed for ${t.label}: ${o?.message||String(o)}`);}t.initialized=true;}async function ct(t){let e=[],r=await t.boardOps.status({});r.status==="success"&&r.data!=null&&chunkNMOUBZXX_cjs.d(r.data)&&e.push({kind:"status",status:r.data});let n=await t.boardOps.getAllOutputsDataObjects({});if(n.status==="success"&&n.data!=null)for(let[s,i]of Object.entries(n.data))s&&e.push({kind:"data_object",key:s,payload:i});let o=await t.boardOps.getAllOutputsComputedValues({});if(o.status==="success"&&o.data!=null)for(let[s,i]of Object.entries(o.data))s&&i&&typeof i=="object"&&!Array.isArray(i)&&e.push({kind:"computed_values",cardId:s,values:i});e.length>0&&L(e,{ctx:t,appendState:true,broadcastSse:true,mirrorExternal:false});}async function gt(t,e){if(!t||t.cardsBootstrapped)return;let r=await t.cardStoreOps.get({}),n=r.status==="success"&&Array.isArray(r.data?.cards)?r.data.cards:[];for(let o of n)typeof o.id=="string"&&(v.set(o.id,e),await t.boardOps.upsertCard({params:{cardId:o.id}}));t.cardsBootstrapped=true;}async function G(){for(let t of d)await fe(t);}async function at(){await G();for(let t=0;t<d.length;t++)await ct(d[t]),await gt(d[t],t),await ct(d[t]);}async function Rt(t=false){t||await G();for(let e of d){let r=await e.board.processAccumulatedEvents({});if(r.status!=="success")return r}return {status:"success"}}function z(t){return d[p(t)]??null}async function X(t){let e=z(t);if(!e)return null;let r=await e.cardStoreOps.get({params:{id:t}});if(r.status!=="success")return null;let n=Array.isArray(r.data?.cards)?r.data.cards:[];return n.length>0?n[0]:null}async function pe(){let t=async r=>{if(!r)return [];let n=await r.cardStoreOps.get({});return n.status!=="success"||!Array.isArray(n.data?.cards)?[]:n.data.cards},e=[];for(let r of d)e.push(...await t(r));return e}function yt(){return d[0]??null}function me(t){return z(t)??yt()}function U(t){let e=me(t);if(!e)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${t}`),{statusCode:404});return e.chatStorage}async function ge(t){return await U(t).isProcessing(t)}async function Y(t,e){let r=await tt.setProcessing({params:{cardId:t},body:{active:e}});if(r.status!=="success")throw Object.assign(new Error(r.error||`Failed to set chat processing for card: ${t}`),{statusCode:500})}let tt=chunkOF4FPYNI_cjs.a({append(t,e,r,n,o){return U(t).append(t,e,r,n,o)},readAll(t){return U(t).readAll(t)},readAfter(t,e){return U(t).readAfter(t,e)},clear(t){return U(t).clear(t)},setProcessing(t,e){return U(t).setProcessing(t,e)},isProcessing(t){return U(t).isProcessing(t)},getConfig(t){return U(t).getConfig(t)},setConfig(t,e){return U(t).setConfig(t,e)}},{emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);}}),ht=chunkNMOUBZXX_cjs.p({boardContexts:d,cardOwnerIndex:v,cardContextForCard:t=>z(t),readStatusSnapshot:()=>be(),readDataObjectsByToken:()=>Ce(),readCardRuntimeArtifacts:()=>Se(),readCardFromStore:t=>X(t),readCardDefinitions:()=>pe(),processAccumulatedLaneInternal:t=>Rt(t),reportSourceFetched:(t,e)=>Bt(t,{ref:e}),reportSourceFetchFailure:(t,e)=>kt(t,{reason:e}),uploadCardFile:(t,e,r,n,o)=>St(t,e,r,n,o),chatStorePublic:tt,serverUrl:q,apiBasePath:w}),Re=ht.mcpCardStoreFacade,st=ht.createMcpFacade,ye=chunkNMOUBZXX_cjs.j({boardId:A,bootstrapBoard:()=>at(),sseHub:J,onChannelSubscribed:W,onChannelUnsubscribed:H,getMcpFacade:()=>st(),getMcpCardStoreFacade:()=>Re()});function he(t){return chunkNMOUBZXX_cjs.m(t)}function we(){return chunkNMOUBZXX_cjs.n(st())}function wt(){return chunkNMOUBZXX_cjs.o({boardId:A,uploadCardFile:St,getMcpFacade:()=>st(),controlplane:ye})}let it=chunkNMOUBZXX_cjs.k({boardId:A,boardContexts:d,readChatRecords:t=>Fe(t),getChatProcessing:t=>ge(t)}),be=it.readStatusSnapshot,Se=it.readCardRuntimeArtifacts,Ce=it.readDataObjectsByToken,ut=it.buildPublishedRuntimePayload;async function bt(t,e,r){let n=r?.syncBoard!==false,o=r?.restartOnlyIfChanged===true,s=z(t);if(!s)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let i=await X(t);if(!i)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let c=o?JSON.stringify(i):null,M=e(i)||i;if(o&&JSON.stringify(M)===c)return;let h=await s.cardStoreOps.set({body:M});if(h.status!=="success")throw Object.assign(new Error(h.error||`Failed to persist card: ${t}`),{statusCode:500});if(n){let _=await s.boardOps.upsertCard({params:{cardId:t,restart:true}});if(_.status!=="success")throw Object.assign(new Error(_.error||`Failed to upsert card: ${t}`),{statusCode:500})}}async function Ae(t,e){await bt(t,e,{syncBoard:true});}async function Be(t,e){await bt(t,e,{syncBoard:false});}async function ke(t){let e=z(t);if(!e)throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});if(!await X(t))throw Object.assign(new Error(`Card not found: ${t}`),{statusCode:404});let n=await e.boardOps.upsertCard({params:{cardId:t,restart:true}});if(n.status!=="success")throw Object.assign(new Error(n.error||`Failed to retrigger card: ${t}`),{statusCode:500})}async function Pe(t){let e=await tt.clear({params:{cardId:t}});if(e.status!=="success")throw Object.assign(new Error(e.error||`Failed to clear chat records for card: ${t}`),{statusCode:500});try{await Y(t,!1);}catch{}}async function Oe(t,e,r,n,o=""){let s=typeof r=="string"?r.trim():"",i=await tt.append({params:{cardId:t},body:{role:e||"system",text:s,files:n,turn:o}});if(i.status!=="success")throw Object.assign(new Error(i.error||`Failed to append chat record for card: ${t}`),{statusCode:500});return String(i.data?.id||"")}async function Fe(t){return await U(t).readAll(t)}let St=chunkNMOUBZXX_cjs.l({safeCardId:t=>P(t),artifactsStores:t=>B(t),cardFileMetadataStore:()=>k(),readCardFromStore:t=>X(t),updateCardLocalOnly:(t,e)=>Be(t,e),writeChatRecord:(t,e,r,n,o)=>Oe(t,e,r,n,o)}).uploadCardFile;async function Ct(t){let e=z(t);if(!e)return null;let r=await e.boardOps.getConfig({params:{key:"chat-handler-flow"}}),o=(r.status==="success"?r.data?.value:null)??e.chatHandlerFlow??null,s=e.chatHandlerRef;return o==null&&(!s||typeof s!="object")?null:{ctx:e,handlerFlow:o,handlerRef:s}}function ve(t){let e=typeof t=="string"?t.trim():"";if(e.length<ot.length*2||!e.startsWith(ot)||!e.endsWith(ot))return null;let r=e.slice(ot.length,e.length-ot.length).trim(),n=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(r);return n?{assistant:n[1].trim().toLowerCase(),text:n[2].trim()}:{assistant:"echo",text:r}}async function xe(t,e,r=false,n="",o=""){try{let s=await Ct(t);if(!s){try{await Y(t,!1);}catch{}return}let{ctx:i,handlerFlow:c,handlerRef:M}=s;if(!r)try{await Y(t,!0);}catch{}let h={boardId:A,cardId:String(t),lastChatEntryId:e,...n?{turnId:n}:{},...typeof o=="string"&&o.trim()?{probe:o.trim()}:{},...j,...q?{serverUrl:q}:{}},_=c!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:ue}}:M;chunkBQUQTOPB_cjs.a(i.boardAdapter)?await O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}):O(i,"chat-agent").enqueueRequest({boardId:A,ref:_,args:c!=null?{...h,__chatHandlerFlow:c}:h}),await Promise.resolve(i.boardAdapter.requestProcessAccumulated?.());}catch(s){try{await Y(t,!1);}catch{}x.warn(`[chat-handler] queue failed for card "${t}": ${s instanceof Error?s.message:String(s)}`);}}async function Te(t,e,r){if(e.howToRun==="built-in"&&chunkBQUQTOPB_cjs.b(e)===ue){let n=N,o=r.__chatHandlerFlow,s={...r};return delete s.__chatHandlerFlow,n?n.run(o,s,{boardId:A,cardId:String(s.cardId||""),label:t.label,logger:x,serverUrl:q,executionExtra:j}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return D.invoke(e,r)}async function Ne(t,e=false){e||await G();let r=typeof t.args?.cardId=="string"?t.args.cardId:"",n=r?z(r):yt();if(!n)throw new Error(r?`Board context is unavailable for chat-agent request: ${r}`:"Board context is unavailable for chat-agent request");let o=await Te(n,t.ref,t.args);if(!o.dispatched){if(r)try{await Y(r,!1);}catch{}throw new Error(o.error||`chat-agent dispatch failed for card "${r||"unknown"}"`)}}async function Ee(t,e,r){if(e==="chat-send"){let o=r&&typeof r["turn-id"]=="string"?r["turn-id"]:r&&typeof r.turnId=="string"?r.turnId:r&&typeof r.turn=="string"?r.turn:"";if(r&&"files"in r&&r.files!==void 0&&r.files!==null)throw Object.assign(new Error('chat-send does not accept a "files" parameter; upload attachments via manage.add-chat-attachment first'),{statusCode:400});let s=wt(),i=ve(r?.text),c=i?i.text:r?.text,M=await chunk272IYUKT_cjs.a("manage.add-chat-entry-and-any-attachments",{board_id:A,card_id:t,role:"user",text:c,turn_id:o,files:[]},s);if(M?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(M,`chat-send append failed for card ${t}`));let h=M?.data?.id;if(typeof h!="string"||!h)throw new Error(`chat-send did not return an append id for card ${t}`);let _=await chunk272IYUKT_cjs.a("setstate.chat-processing-started",{board_id:A,card_id:t},s);if(_?.status!=="success")throw new Error(chunk272IYUKT_cjs.b(_,`chat-send processing update failed for card ${t}`));xe(t,h,true,o,i?.assistant||"");return}await Ae(t,o=>{let s=new Date().toISOString(),i=o.card_data&&typeof o.card_data=="object"?o.card_data:{};if(o.card_data=i,e==="file-upload"){let c=k().normalizeIncoming(r?.files,s);return c.length>0&&k().merge(i,c),o}if(e==="action"){let c=r&&typeof r.buttonId=="string"?r.buttonId:"";if(!c)return o;i.lastAction={buttonId:c,at:s},i.lastActionText=`${c} @ ${s}`;}return o});}function et(t,e,r){let n=JSON.stringify(r),o=typeof Buffer<"u"?Buffer.byteLength(n):new TextEncoder().encode(n).length;t.writeHead(e,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":o}),t.end(n);}async function At(t,e,r){let n=await X(t);if(!n)throw Object.assign(new Error("Card not found"),{statusCode:404});let o=k().resolve(n.card_data,e,r);if(!o.ok&&o.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!o.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let s=o.file,i=P(t),c=B(t),M=String(s.stored_name||""),h=`${i}/${M}`,_=c.files?await c.files.getBytes(h):null;if(!_)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:s,bytes:_}}async function je(t,e,r,n){let{fileRecord:o,bytes:s}=await At(e,r,n),i=String(o.name||o.stored_name||"download.bin"),c=String(o.mime_type||"application/octet-stream");t.writeHead(200,{"Content-Type":c,"Content-Disposition":`attachment; filename="${i}"`,"Content-Length":s.length}),t.end(s);}function Me(t){let e=String(t||"").toLowerCase();return e.startsWith("text/")||e.includes("json")||e.includes("xml")||e.includes("javascript")||e.includes("typescript")||e.includes("yaml")||e.includes("csv")}function _e(t,e,r){let n=t.split(/\r?\n/);return (e==="head"?n.slice(0,r):n.slice(-r)).join(`
|
|
2
|
+
`)}async function rt(t){let e=[];for await(let n of t)e.push(n);let r=typeof Buffer<"u"?Buffer.concat(e).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(e)).trim();return r?JSON.parse(r):{}}async function 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 n=d[0];return n?n.boardOps.sourceDataFetched({params:{token:t,ref:r}}):{status:"fail",error:"no board context"}}async function kt(t,e){let r=typeof e.reason=="string"&&e.reason.trim()?e.reason:"unknown",n=d[0];return n?n.boardOps.sourceDataFetchFailure({params:{token:t,reason:r}}):{status:"fail",error:"no board context"}}let De=chunkLFVMX23W_cjs.b({sseHub:J,queueSseHub:f,corsHeaders:b,json:et,buildPublishedRuntimePayload:()=>ut(),onSseClientConnected:T,onChannelSubscribed:W,onChannelUnsubscribed:H,apiBasePath:w,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),bootstrapBoard:()=>at(),boardContexts:d,publishPersistedStateSnapshot:t=>ct(t),upsertCardsFromSource:(t,e)=>gt(t,e)}).handleWatchersRoutes,qe=chunk7FGPOGRV_cjs.a({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpFacade:()=>st(),createMcpToolRegistry:t=>he(t),resolveCardFileDownloadPayload:(t,e,r)=>At(t,e,r),isLikelyTextMimeType:t=>Me(t),sliceTextByLines:(t,e,r)=>_e(t,e,r)}).handleAgentfaceApi,Ie=chunkNM6O35RY_cjs.a({apiBasePath:w,json:et,readJsonBody:t=>rt(t),initBoardAndSetup:()=>G(),createMcpWebhookToolRegistry:()=>we()}).handleWebhooksApi,$e=ie({apiBasePath:w,json:et,readJsonBody:t=>rt(t),bootstrapBoard:()=>at(),createMcpControlplaneToolRegistry:()=>wt(),retriggerCard:t=>ke(t),applyCardAction:(t,e,r)=>Ee(t,e,r),resolveChatHandlerTarget:t=>Ct(t),sendCardFileDownloadResponse:(t,e,r,n)=>je(t,e,r,n)}).handleRuntimeApi,He=ce({apiBasePath:w,emitNotifications:t=>V(t),readJsonBody:t=>rt(t),json:(t,e,r)=>et(t,e,r)}).handleNotifyRoute;async function Le(t,e,r){return !!(await qe(t,e,r)||await Ie(t,e,r)||await De(t,e,r)||await He(t,e,r)||await $e(t,e,r))}return {get apiBasePath(){return w},get corsHeaders(){return b},get queueLaneTuning(){return $},handleRuntimeApi:Le,emitNotification(t){if(t.kind==="notification-batch"){V(t.notifications);return}V([t]);},buildPublishedRuntimePayload:ut,__drainProcessAccumulatedLane:Rt,handleChatAgentRequest:Ne,clearChatRecords:Pe,reportSourceFetched(t,e){return Bt(t,{ref:e})},reportSourceFetchFailure(t,e){return kt(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 Mr(R){let w=String(R.apiBasePath||"/api/boards").replace(/\/$/,""),b={...de,...R.corsHeaders||{}},$=R.serverMetaStore,A=R.boardRuntimeFactory,x=new Map,D="boards-config.json";function N(){let f=$.getText(D);if(!f)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(f)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function E(f){$.putText(D,JSON.stringify(f,null,2));}function q(f){let g=String(f||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return g.length>0&&g.length<=64?g:null}function j(f){if(x.has(f))return x.get(f);let d=N().boards.find(p=>p.id===f)||{},v=A(f,d);return x.set(f,v),v}function T(f,g,d){let v=JSON.stringify(d),p=typeof Buffer<"u"?Buffer.byteLength(v):new TextEncoder().encode(v).length;f.writeHead(g,{...b,"Content-Type":"application/json; charset=utf-8","Content-Length":p}),f.end(v);}async function S(f,g,d){let v=f.method||"GET",p=d.pathname;if(v==="GET"&&p===w)return T(g,200,{ok:true,boards:N().boards}),true;if(v==="POST"&&p===w){let y=[];for await(let F of f)y.push(F);let O=typeof Buffer<"u"?Buffer.concat(y).toString("utf-8").trim():new TextDecoder().decode(chunkBQUQTOPB_cjs.d(y)).trim(),l={};try{l=O?JSON.parse(O):{};}catch{l={};}let B=q(l.id);if(!B)return T(g,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let k=N();if(k.boards.some(F=>F.id===B))return T(g,409,{error:`Board "${B}" is already registered`}),true;let P=typeof l.label=="string"&&l.label.trim()?l.label.trim():B,I={id:B,label:P};for(let[F,L]of Object.entries(l))F==="id"||F==="label"||L!=null&&(I[F]=L);return k.boards.push(I),E(k),T(g,200,{ok:true,board:I}),true}return false}async function W(f,g,d){let p=d.pathname.match(new RegExp(`^${chunkBQUQTOPB_cjs.c(w)}/([^/]+)(/|$)`));if(!p)return false;let y=q(decodeURIComponent(p[1]));return y?N().boards.some(B=>B.id===y)?!!await j(y).handleRuntimeApi(f,g,d):(T(g,404,{error:`Board "${y}" not registered. POST ${w} with {id} to register it first.`}),true):(T(g,400,{error:"Invalid board id"}),true)}async function H(f,g,d){return !!(await S(f,g,d)||await W(f,g,d))}function J(f){if(!N().boards.some(d=>d.id===f))throw Object.assign(new Error(`Board "${f}" not registered`),{statusCode:404});return {service:j(f)}}return {get apiBasePath(){return w},get corsHeaders(){return b},handleApi:H,requireBoardService:J}}exports.a=jr;exports.b=Mr;//# sourceMappingURL=chunk-42ZOYXEV.cjs.map
|
|
3
|
+
//# sourceMappingURL=chunk-42ZOYXEV.cjs.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {b as b$1,c as c$1}from'./chunk-ANKA7HEJ.js';import {a,b,c}from'./chunk-44L64VQ2.js';import {r,a as a$1,p,q,u}from'./chunk-VGT3TRQG.js';import {a as a$3}from'./chunk-ATOQP3BD.js';import {a as a$2}from'./chunk-7QNEV5S3.js';import {e,f}from'./chunk-UGB7PC4P.js';function ft(e){return typeof e=="string"&&e.trim().length>0}function mt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.selfRef is required`);if(!ft(e.howToRun))throw new Error(`${t}: adapter.selfRef.howToRun is required`);if(!ft(e.whatToRun))throw new Error(`${t}: adapter.selfRef.whatToRun is required`)}function pt(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 tr(e,t="callbackTransport"){return {createCallback(n){let a=e();return mt(a,t),{token:n,via:a}}}}function $e(e){return tr(()=>e,"createStaticExecutionRefCallbackTransport")}function kr(e){return $e({meta:"board-live-cards",howToRun:"http:post",whatToRun:a({kind:"http-url",value:String(e||"").trim()})})}function Rr(e){return $e({meta:"board-live-cards",howToRun:"in-process-loop",whatToRun:a({kind:"in-process-loop",value:String(e||"").trim()})})}function hr(e){let t=typeof e=="string"?{notifyChannel:e}:e??{},n={};return t.notifyChannel&&(n.notifyChannel=t.notifyChannel),t.boardRuntimeStoreRef&&(n.boardRuntimeStoreRef=t.boardRuntimeStoreRef),t.queueStoreRef&&(n.queueStoreRef=t.queueStoreRef),$e({meta:"board-live-cards",howToRun:"built-in",whatToRun:a({kind:"built-in",value:"board-live-cards"}),...Object.keys(n).length>0?{extra:n}:{}})}function Ie(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Je(e,t){return Ie(e)?e.then(t):t(e)}function St(e,t){let n={...e};for(let a of t.deleteKeys)delete n[a];return {...n,...t.shallowMerge}}function Cr(e,t){return {readValues(a){let s=e(a);return Je(s.listKeys(),d=>{let u=[...d].sort();if(u.length===0)return {version:null,values:{}};let l={},h=null;for(let y of u){let V=s.read(y);Ie(V)?h=(h??Promise.resolve()).then(async()=>{l[y]=await V;}):l[y]=V;}return h?h.then(()=>({version:t(l),values:l})):{version:t(l),values:l}})},writeValues(a,s,d){let u=e(a),l=null;for(let h of d){let y=u.delete(h);Ie(y)&&(l=(l??Promise.resolve()).then(()=>y).then(()=>{}));}for(let[h,y]of Object.entries(s)){let V=u.write(h,y);Ie(V)&&(l=(l??Promise.resolve()).then(()=>V).then(()=>{}));}return l?l.then(()=>t(s)):t(s)}}}function kt(e,t){return {readSnapshot(n){return e.readValues(n)},commitSnapshot(n,a){if(a.schemaVersion!==t)throw new Error(`Unsupported snapshot schema version: ${a.schemaVersion}`);return Je(e.readValues(n),s=>{if(s.version!==a.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:s.version};let d=St(s.values,a);return Je(e.writeValues(n,d,a.deleteKeys),u=>({ok:true,newVersion:u}))})}}}function gt(e,t){if(!t)return e;let n=e.findIndex(a=>a.id===t);return n===-1?e:e.slice(n+1)}function Rt(e){return {readEntriesAfterCursor(t){let n=gt(e.readAllEntries(),t);return n.length===0?{events:[],newCursor:t}:{events:n.map(a=>a.event),newCursor:n[n.length-1].id}},pendingCount(t){return gt(e.readAllEntries(),t).length},appendEvent(t){e.appendEntry({id:e.generateId(),event:t});}}}function br(e){return {appendEvent(t){return e.append(t).then(()=>{})},async readEntriesAfterCursor(t){let n=await e.readAfter(t||null);return {events:n.entries.map(a=>a.payload),newCursor:n.newCursor??t}}}}function _e(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function de(e,t){return _e(e)?e.then(t):t(e)}function Me(e,t){let n=null;for(let a of e){if(n){n=n.then(()=>t(a)).then(()=>{});continue}let s=t(a);_e(s)&&(n=Promise.resolve(s).then(()=>{}));}return n??void 0}function rr(e){if(e==null)return null;let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{return t}}function nr(e,t){let n=e.match(t);return n?n[1]:null}function ht(e,t,n){let a={},s=Me(e,d=>{let u=n(d);if(u)return de(t(d),l=>{a[u]=l;})});return _e(s)?s.then(()=>a):a}function yt(e,t){return {readSourceData(n,a){return de(e.read(`${n}/${a}`),rr)},ingestSourceDataStaged(n,a,s,d){return de(t(s),u=>e.write(`${n}/.staged/${d}/${a}`,u))},commitSourceData(n,a,s){let d=`${n}/.staged/${s}/${a}`,u=`${n}/${a}`;return e.renameKey(d,u)},hasSource(n,a){return e.exists(`${n}/${a}`)},listSources(n){return de(e.listKeys(`${n}/`),a=>a.filter(s=>!s.includes("/.staged/")).map(s=>s.slice(`${n}/`.length)))}}}function or(e,t){let n=(a,s)=>{try{let d=s(a);return _e(d)?d.catch(u=>t(a,u instanceof Error?u.message:String(u))):void 0}catch(d){try{return t(a,d instanceof Error?d.message:String(d))}catch{return}}};return {appendEntries(a,s){if(!(!a||s.length===0))return de(e.read(a),d=>e.write(a,[...d??[],...s]))},dispatchEntriesForJournalId(a,s){if(a)return de(e.read(a),d=>{let u=d;if(!(!u||u.length===0))return de(Me(u,l=>n(l,s)),()=>e.delete(a))})}}}function sr(e,t,n){return {readRuntime(a){return de(e.read(t(a)),s=>s??n())},writeRuntime(a,s){return e.write(t(a),s)}}}function Ct(e){return {writeComputedValues(t,n){return e.write(`cards/${t}/computed_values`,n)},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){return de(e.listKeys("cards/"),t=>ht(t,n=>e.read(n),n=>nr(n,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(t){return Me(Object.entries(t),([n,a])=>{if(n)return a===void 0?e.delete(`data-objects/${n}`):e.write(`data-objects/${n}`,a)})},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){return de(e.listKeys("data-objects/"),t=>ht(t,n=>e.read(n),n=>n.slice(13)))},writeStatusSnapshot(t){return e.write("status",t)},readStatusSnapshot(){return e.read("status")}}}function He(e,t){function n(){return e.readIndex()??{}}function a(s,d,u){let l=String(d||"").split(".").filter(Boolean);if(l.length===0)return u&&typeof u=="object"&&!Array.isArray(u)?u:{value:u};let h={...s},y=h;for(let V=0;V<l.length-1;V++){let z=l[V],Y=y[z],ee=Y&&typeof Y=="object"&&!Array.isArray(Y)?{...Y}:{};y[z]=ee,y=ee;}return y[l[l.length-1]]=u,h}return {readCard(s){let d=n()[s];return !d||!e.cardExists(d.key)?null:e.readCard(d.key)},readCardKey(s){return n()[s]?.key??null},readAllCards(){let s=[];for(let[d,u]of Object.entries(n())){if(!e.cardExists(u.key))continue;let l=e.readCard(u.key);l?s.push(l):t?.(`[card-store] could not read card "${d}" at key "${u.key}"`);}return s},readChecksumIndex(){let s={};for(let[d,u]of Object.entries(n()))s[d]=u.checksum;return s},changedSince(s){let d=n(),u=[];for(let[l,h]of Object.entries(d))s[l]!==h.checksum&&u.push(l);for(let l of Object.keys(s))d[l]||u.push(l);return u},validateUpsert(s,d){let u=n(),l=u[s],h=Object.entries(u).find(([,y])=>y.key===d);return l&&l.key!==d?{ok:false,error:`Card id "${s}" is already mapped to key "${l.key}", cannot remap to "${d}"`}:h&&h[0]!==s?{ok:false,error:`Key "${d}" is already mapped to card id "${h[0]}", cannot remap to "${s}"`}:{ok:true}},writeCard(s,d,u){let l=n(),h=u??l[s]?.key??e.defaultCardKey(s),y=e.writeCard(h,d);l[s]={key:h,checksum:y,updatedAt:new Date().toISOString()},e.writeIndex(l);},patchCard(s,d,u){let l=n(),h=l[s];if(!h||!e.cardExists(h.key))throw new Error(`card "${s}" not found`);let y=e.readCard(h.key);if(!y||typeof y!="object"||Array.isArray(y))throw new Error(`card "${s}" is not patchable`);let V=a(y,d,u),z=e.writeCard(h.key,V);l[s]={key:h.key,checksum:z,updatedAt:new Date().toISOString()},e.writeIndex(l);},removeCard(s){let d=n(),u=d[s];u&&(e.removeCard(u.key),delete d[s],e.writeIndex(d));},readIndex(){return n()}}}function Fe(e,t){return yt(e,t)}function xt(e){return Rt(e)}var Oe="v1",he="board/graph",Et="board/lastJournalProcessedId";function Fr(e){return `cards/${e}/runtime`}function Tt(e){return kt(e,Oe)}function Be(e){function t(n){let a=e.read(n);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}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);},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(n){e.write("board-runtime-store-ref",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);},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(n){e.write("queue-store-ref",n);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(n){e.write("scratch-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);},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(n){e.write("fetched-sources-store-ref",n);}}}function At(e){return Ct(e)}function bt(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function ar(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function wt(e,t){return e?.lastRequestedToken?ar(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function ir(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function vt(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function Pe(e,t){let n=t.state.tasks,a=t.config.tasks,s=Object.keys(n),d=r(t),u={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},l=new Map;for(let T of d.pending)l.set(T.taskName,T.waitingOn);for(let T of d.unresolved)l.set(T.taskName,T.missingTokens);for(let T of d.blocked)l.set(T.taskName,T.failedTokens);let h=new Map;for(let[T,S]of Object.entries(a))for(let G of S.requires??[]){let U=h.get(G)??[];U.push(T),h.set(G,U);}let y=s.sort().map(T=>{let S=n[T],G=a[T]??{requires:[],provides:[]};S.status==="completed"?u.completed+=1:S.status==="failed"?u.failed+=1:S.status==="in-progress"&&(u.in_progress+=1);let U=G.requires??[],g=G.provides??[],i=Object.keys(S.data??{}).sort(),p=U.filter(B=>t.state.availableOutputs.includes(B)),b=U.filter(B=>!t.state.availableOutputs.includes(B)),I=l.get(T)??b,w=new Set;for(let B of g)for(let D of h.get(B)??[])D!==T&&w.add(D);let x=S.failedAt,K=S.error?{message:S.error,code:"TASK_FAILED",at:x,source:"task-runtime"}:void 0;return {name:T,status:S.status,error:K,requires:U,requires_satisfied:p,requires_missing:b,provides_declared:g,provides_runtime:i,blocked_by:I,unblocks:Array.from(w).sort(),runtime:{attempt_count:S.executionCount??0,restart_count:S.retryCount??0,in_progress_since:S.status==="in-progress"?S.startedAt??null:null,last_transition_at:S.lastUpdated??null,last_completed_at:S.completedAt??null,last_restarted_at:S.startedAt??null,status_age_ms:S.lastUpdated?0:null}}});u.pending=d.pending.length,u.blocked=d.blocked.length,u.unresolved=d.unresolved.length;let V=y.map(T=>({name:T.name,fanOut:T.unblocks.length})).sort((T,S)=>S.fanOut-T.fanOut||T.name.localeCompare(S.name)),z=V.length>0?V[0]:{name:null,fanOut:0},Y=new Set;for(let T of Object.values(a))for(let S of T.requires??[])Y.add(S);let ee=0;for(let[T,S]of Object.entries(a)){let G=(S.requires??[]).length===0,g=(S.provides??[]).some(i=>(h.get(i)??[]).some(p=>p!==T));G&&!g&&(ee+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:s.length,completed:u.completed,eligible:d.eligible.length,pending:u.pending,blocked:u.blocked,unresolved:u.unresolved,failed:u.failed,in_progress:u.in_progress,orphan_cards:ee,topology:{edge_count:Array.from(Y).length,max_fan_out_card:z.name,max_fan_out:z.fanOut}},cards:y}}function ur(){return new Date().toISOString()}function It(e,t,n,a$1,s,d,u){return async l=>{let h=[],y=n.cardStore.readCard(l.nodeId);if(!y)return "task-initiate-failure";let V=y.id,z=y.card_data??{},Y=y.source_defs??[],ee=Y,T=n.cardRuntimeStore.readRuntime(V),S=false,G=()=>{S&&(n.cardRuntimeStore.writeRuntime(V,T),S=false);},U=E=>bt(T._sources[E]),g=(E,v)=>{T._sources[E]=bt(v),S=true;},i=l.taskState?.executionCount??0;if(T._lastExecutionCount!==i&&(T._sources={},T._lastExecutionCount=i,S=true),l.update){let E=l.update,v=E.outputFile;if(v){let P=U(v);if(E.failure){let L=E.rqt??P.lastRequestedToken??P.queueRequestedToken;L&&g(v,vt(P,L));}else {let L=E.rqt;if(!P.lastCompletedToken||L>P.lastCompletedToken){let te=typeof E.deliveryToken=="string"?E.deliveryToken:void 0,j=false;te&&(j=n.fetchedSourcesStore.commitSourceData(V,v,te)),j?g(v,ir(P,L)):g(v,vt(P,L));}}G();}}let b={};for(let E of Y)if(E.outputFile){let v=n.fetchedSourcesStore.readSourceData(V,E.outputFile);v!==null&&(b[E.bindTo]=v);}let I={};for(let[E,v]of Object.entries(l.state??{}))if(v!==null&&typeof v=="object"&&!Array.isArray(v)){let P=v[E];I[E]=P!==void 0?P:v;}else I[E]=v;let w={id:V,card_data:{...z},requires:I,source_defs:Y,compute:y.compute};w._sourcesData=b,y.compute&&a$3.runSync(w,{sourcesData:b}),(d??n.outputStore.writeComputedValues.bind(n.outputStore))(V,w.computed_values??{});let x={...y},K=a$3.enrichSourcesSync(Array.isArray(y.source_defs)?y.source_defs:void 0,{card_data:y.card_data,requires:I}),B=e.value;x.source_defs=Array.isArray(K)?K.map(E=>({...E,boardDir:typeof E.boardDir=="string"&&E.boardDir?E.boardDir:B})):K;let D=ur(),H=l.update?void 0:D,ne=ee.filter(E=>{let v=E.outputFile;if(typeof v!="string"||!v)return true;let P=U(v);H&&(P={...P,queueRequestedToken:H},g(v,P));let L=P.queueRequestedToken??P.lastRequestedToken??D,te=wt(P,L);return te==="in-flight"?false:te==="dispatch"});if(G(),ne.length>0){let E=false,v=D;for(let P of ne){let L=P.outputFile;if(typeof L!="string"||!L)continue;let te=U(L),j=te.queueRequestedToken??D;g(L,{...te,lastRequestedToken:j}),v=j,E=true;}return E&&G(),E&&(h.push({taskKind:"source-fetch",payload:{boardRef:a(e),enrichedCard:x,callbackToken:l.callbackToken,rqt:v}}),n.executionRequestStore.appendEntries(t,h)),"task-initiated"}if(ee.some(E=>{let v=E.outputFile;if(typeof v!="string"||!v)return false;let P=U(v),L=P.queueRequestedToken??P.lastRequestedToken??D;return wt(P,L)==="in-flight"}))return "task-initiated";let pe=y.provides??[],ae={};for(let{bindTo:E,ref:v}of pe)ae[E]=a$3.resolve(w,v);return (u??n.outputStore.writeDataObjects.bind(n.outputStore))(ae),a$1(l.nodeId,ae),h.length>0&&n.executionRequestStore.appendEntries(t,h),"task-initiated"}}var Ge={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function _t(e){return {[he]:e.graph,[Et]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function Ft(e){let t=e[he],n=e[Et],s=e.board?.runtimeByCardId;if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${he}`);return {graph:t,lastDrainedJournalId:typeof n=="string"?n:"",runtimeByCardId:s&&typeof s=="object"?s:{}}}function Ot(e){let t=e.requires;return {provides:e.provides?.map(a=>a.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...t&&t.length>0?{requires:t}:{}}}function A(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function F(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}var Bt="sys_keys_board_state";function dr(e){let t=new TextEncoder().encode(e),n=Array.from(t,a=>String.fromCharCode(a)).join("");return btoa(n).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Vt(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),n=t+"=".repeat((4-t.length%4)%4),a=atob(n),s=Uint8Array.from(a,d=>d.charCodeAt(0));return new TextDecoder().decode(s)}function qe(e){try{let t=JSON.parse(Vt(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function Pt(e){return dr(JSON.stringify(e))}function qt(e){try{let t=JSON.parse(Vt(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function Z(){return new Date().toISOString()}function cr(e){let t=new Map;return {appendEntries(n,a){if(!n||a.length===0)return;let s=t.get(n)??[];t.set(n,[...s,...a]);},dispatchEntriesForJournalId(n,a){if(!n)return;let s=t.get(n);if(!(!s||s.length===0)){for(let d of s)try{a(d);}catch(u){try{e(d,u instanceof Error?u.message:String(u));}catch{}}t.delete(n);}}}}function Lr(e$1,t,n={}){pt(t.callbackTransport,"createBoardLiveCardsPublic");let a$3=t.callbackTransport,s=t.onWarn??(()=>{}),d=a(e$1),u$1=n.boardRuntimeStoreRef,l=n.scratchStoreRef,h=n.taskExecutorRef,y=n.chatHandlerFlow,V=n.emitNotification??(o=>{if(!t.publishBoardChangeNotifications)return;let r=o.kind==="notification-batch"?o.notifications:[o];return t.publishBoardChangeNotifications(r)});function z(){if(!u$1)throw new Error(`Board at ${e$1.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return u$1}function Y(o){if(o.length!==0)try{let r=e(o),c=f({kind:"notification-batch",notifications:r}),f$1=V(c);f$1&&typeof f$1.catch=="function"&&f$1.catch(C=>s(`[board-live-cards-public] emitNotification failed: ${C instanceof Error?C.message:String(C)}`));}catch(r){s(`[board-live-cards-public] emitNotification failed: ${r instanceof Error?r.message:String(r)}`);}}function ee(){let o=S().readCardStoreRef();if(!o)throw new Error(`Board at ${e$1.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let r=t.kvStorageForRef(o);return {readIndex(){return r.read("_index")},writeIndex(c){r.write("_index",c);},readCard(c){return r.read(c)},writeCard(c,f){return r.write(c,f),t.hashFn(f)},removeCard(c){r.delete(c);},cardExists(c){return r.read(c)!==null},defaultCardKey(c){return c}}}let T={readValues(o){let r=t.kvStorageForRef(z()),c=r.listKeys().sort();if(c.length===0)return {version:null,values:{}};let f={};for(let C of c)f[C]=r.read(C);return {version:t.hashFn(f),values:f}},writeValues(o,r,c){let f=t.kvStorageForRef(z());for(let C of c)f.delete(C);for(let[C,_]of Object.entries(r))f.write(C,_);return t.hashFn(r)}},S=()=>Be(t.kvStorageForRef(z())),G=()=>Tt(T),U=()=>xt(t.journalAdapterForRef(z())),g=()=>He(ee(),s),i=()=>{let o=S().readOutputsStoreRef();if(!o)throw new Error(`Board at ${e$1.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return At(t.kvStorageForRef(o))};function p$1(){return h??S().readTaskExecutorRef()}function b$1(){return !!G().readSnapshot(e$1.value).values[he]}function I(){let o=G().readSnapshot(e$1.value);if(!o.values[he])throw new Error(`Board not initialized at ${e$1.value}`);return Ft(o.values)}function w(o,r){let c=G().commitSnapshot(e$1.value,{schemaVersion:Oe,expectedVersion:r,commitId:t.genId(),committedAt:Z(),deleteKeys:[],shallowMerge:_t(o)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${r??"null"} current=${c.currentVersion??"null"}`)}function x(o){U().appendEvent(o);}async function K(){let r=cr((m,k)=>{let O=m.payload,N=(O?.enrichedCard??{}).id??O?.cardId??"unknown";x({type:"task-failed",taskName:N,error:k,timestamp:Z()});}),c=I(),f=q(c.graph),{events:C,newCursor:_}=U().readEntriesAfterCursor(c.lastDrainedJournalId),$=j(),q$1=Fe($,m=>t.resolveBlob(m)),J={...c.runtimeByCardId},W=new Map,Se={readRuntime(m){return W.get(m)??J[m]??{_sources:{}}},writeRuntime(m,k){W.set(m,k),J[m]=k;}},ke=[],oe=new Map,we={readSourceData(m,k){let O=`${m}/${k}`;return oe.has(O)?oe.get(O):q$1.readSourceData(m,k)},ingestSourceDataStaged(m,k,O,ue){q$1.ingestSourceDataStaged(m,k,O,ue);},commitSourceData(m,k,O){let ue=`${m}/.staged/${O}/${k}`,N=$.read(ue);if(N==null){let Q=$.keyRef?.(ue);Q&&(N=t.resolveBlob(Q));}if(N==null)return false;let se=`${m}/${k}`,fe=N.trim();try{oe.set(se,JSON.parse(fe));}catch{oe.set(se,fe);}return ke.push({cardId:m,outputFile:k,deliveryToken:O}),true},hasSource(m,k){let O=`${m}/${k}`;return oe.has(O)?true:q$1.hasSource(m,k)},listSources(m){let k=q$1.listSources(m),O=new Set;for(let N of oe.keys())N.startsWith(`${m}/`)&&O.add(N.slice(`${m}/`.length));let ue=new Set([...k,...O]);return Array.from(ue)}},le={cardStore:g(),cardRuntimeStore:Se,fetchedSourcesStore:we,outputStore:i(),executionRequestStore:r},Re=[],Ve=[],je=[],Ke=new Map,We=new Set,Wt=(m,k)=>{Re.push({type:"task-completed",taskName:m,data:k,timestamp:Z()});},Ne=(m,k)=>{x({type:"task-failed",taskName:m,error:k,timestamp:Z()});},ve=u(f,{handlers:{"card-handler":It(e$1,_,le,Wt,Ne,(m,k)=>{Ve.push({cardId:m,values:k});},m=>{je.push(m);})},onNodeRemoved:m=>{Ke.delete(m),W.delete(m),delete J[m],We.add(m);}});for(Re=C;Re.length>0;){let m=Re;Re=[];for(let k of m)if(k.type==="task-restart"){let O=le.cardStore.readCard(k.taskName);O&&Ke.set(k.taskName,O);}ve.pushAll(m),await ve.waitForHandlers();}let Ze=ve.getState();await ve.dispose({wait:true});let Zt=G().readSnapshot(e$1.value).version;w({lastDrainedJournalId:_,graph:p(Ze),runtimeByCardId:J},Zt);for(let{cardId:m,values:k}of Ve)le.outputStore.writeComputedValues(m,k);for(let m of je)le.outputStore.writeDataObjects(m);for(let{cardId:m,outputFile:k,deliveryToken:O}of ke)q$1.commitSourceData(m,k,O);let xe;try{xe=Pe(d,Ze),le.outputStore.writeStatusSnapshot(xe);}catch(m){s(`[board-live-cards-public] status publish failed: ${m instanceof Error?m.message:String(m)}`);}let ye=[];for(let{cardId:m,values:k}of Ve)ye.push({kind:"computed_values",cardId:m,values:k});for(let m of je)for(let[k,O]of Object.entries(m))k&&ye.push({kind:"data_object",key:k,payload:O});for(let[m,k]of Ke)ye.push({kind:"card_refreshed",cardId:m,card:k});for(let m of We)ye.push({kind:"card_removed",cardId:m});xe!==void 0&&ye.push({kind:"status",status:xe}),Y(ye);let Ce=p$1()??{howToRun:"built-in",whatToRun:a({kind:"built-in",value:"source-cli-task-executor"})},et=t.supportsDirectSourceOutput?.(Ce)===true;r.dispatchEntriesForJournalId(_,m=>{if(m.taskKind!=="source-fetch"){s(`[process-accumulated-events] unknown taskKind "${m.taskKind}" \u2014 skipping`);return}let k=m.payload,O=k.enrichedCard?.id??"unknown",ue=k.enrichedCard?.source_defs??[];if(Ce.howToRun==="queue-storage"&&et){try{let N=t.queueStorageForRef(B(),"task-executor"),se=typeof Ce.extra?.boardId=="string"?Ce.extra.boardId:void 0,fe=[];for(let Q of ue){if(!Q.outputFile){s(`[dispatch] source "${Q.bindTo}" has no outputFile \u2014 skipping`);continue}let Ee=t.genId(),Te=`${O}/.staged/${Ee}/${Q.outputFile}`,tt=$.keyRef?.(Te);if(!tt)continue;let rt={ref:a(tt),deliveryToken:Ee,outputFile:Q.outputFile,cardId:O},er=Pt({cbk:k.callbackToken,rg:e$1.value,br:a(e$1),cid:O,b:Q.bindTo,d:Q.outputFile,cs:void 0,rqt:k.rqt,dt:rt.deliveryToken});fe.push({...se?{boardId:se}:{},ref:Ce,args:{source_def:Q,base_ref:a(e$1),callback:a$3.createCallback(er),output:rt}});}fe.length>0&&N.enqueueMany(fe);}catch(N){Ne(O,N instanceof Error?N.message:String(N));}return}for(let N of ue){if(!N.outputFile){s(`[dispatch] source "${N.bindTo}" has no outputFile \u2014 skipping`);continue}let se;if(et){let Q=t.genId(),Ee=`${O}/.staged/${Q}/${N.outputFile}`,Te=$.keyRef?.(Ee);Te&&(se={ref:a(Te),deliveryToken:Q,outputFile:N.outputFile,cardId:O});}let fe=Pt({cbk:k.callbackToken,rg:e$1.value,br:a(e$1),cid:O,b:N.bindTo,d:N.outputFile,cs:void 0,rqt:k.rqt,...se?{dt:se.deliveryToken}:{}});t.dispatchExecution(Ce,{source_def:N,base_ref:a(e$1),callback:a$3.createCallback(fe),...se?{output:se}:{}}).catch(Q=>Ne(O,Q instanceof Error?Q.message:String(Q)));}});}function B(){let o=S().readQueueStoreRef();if(!o)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);return o}function D(){let o=t.queueStorageForRef(B(),"process-accumulated");o.enqueueIfAbsent?o.enqueueIfAbsent({boardRef:a(e$1)},`process-accumulated:${a(e$1)}`):o.enqueue({boardRef:a(e$1)}),t.requestProcessAccumulated?.();}function H(){let o=t.queueStorageForRef(B(),"process-accumulated");for(;;){let r=o.lease({max:64,visibilityMs:1e3});if(r.length<=0)return;for(let c of r)o.ack(c.id,c.leaseToken);if(r.length<64)return}}async function ne(){try{let o=()=>{let c=I(),{events:f}=U().readEntriesAfterCursor(c.lastDrainedJournalId);f.length<=0||D();},r=await c(t.lock,K,o);return A({ran:r!==!1})}catch(o){return F(o)}}function X(){D();}function pe(o){try{let r=o.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(u$1=o.params?.boardRuntimeStoreRef,!u$1)return R("init requires params.boardRuntimeStoreRef \u2014 pass the board runtime store ref here");if(!b$1()){let J=a$1(Ge);w({lastDrainedJournalId:"",graph:p(J),runtimeByCardId:{}},null);}let c=o.params?.outputsStoreRef;if(!c)return R("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let f=o.params?.queueStoreRef;if(!f)return R("init requires params.queueStoreRef \u2014 pass the queue store ref here");let C=o.params?.fetchedSourcesStoreRef;if(!C)return R("init requires params.fetchedSourcesStoreRef \u2014 pass the fetched sources store ref here");l=o.params?.scratchStoreRef;let _=o.params?.chatStoreRef;if(!_)return R("init requires params.chatStoreRef \u2014 pass the chat store ref here");let $=o.params?.artifactsStoreRef;if(!$)return R("init requires params.artifactsStoreRef \u2014 pass the artifacts store ref here");let q$1=S();q$1.writeBoardRuntimeStoreRef(u$1),q$1.writeCardStoreRef(r),q$1.writeOutputsStoreRef(c),q$1.writeQueueStoreRef(f),q$1.writeFetchedSourcesStoreRef(C),q$1.writeChatStoreRef(_),q$1.writeArtifactsStoreRef($);try{i().writeStatusSnapshot(Pe(d,q(I().graph)));}catch{}return A()}catch(r){return F(r)}}function ae(o){try{let r=i().readStatusSnapshot();if(!r){r=Pe(d,q(I().graph));try{i().writeStatusSnapshot(r);}catch{}}return A(r)}catch(r){return F(r)}}function E(o){try{let r=o.params?.id;if(!r)return R("removeCard requires params.id");try{t.kvStorage("card-upsert").delete(r);}catch{}return x({type:"task-removal",taskName:r,timestamp:Z()}),X(),A()}catch(r){return F(r)}}function v(o){try{let r=o.params?.cardId;if(!r)return R("addCardFiles requires params.cardId");let c=a$2(g(),{emitNotification:V}).appendFiles({params:{id:r},body:o.body});return c.status!=="success"?c:A({cardId:r,files_added:c.data.files_added,notified:!0})}catch(r){return F(r)}}function P(o){try{let r=o.params?.id;return r?(x({type:"task-restart",taskName:r,timestamp:Z()}),X(),A()):R("retrigger requires params.id")}catch(r){return F(r)}}async function L(o){return H(),ne()}function te(){let o=S().readFetchedSourcesStoreRef();if(!o)throw new Error(`Board at ${e$1.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return o}function j(){return t.blobStorageForRef(te())}function re(o){try{let r=o.params?.cardId,c=o.params?.all,f=!!o.params?.restart;if(!r&&!c)return R("upsertCard requires --card-id <id> or --all");let C=c?g().readAllCards().map(_=>_.id):[r];for(let _ of C)if(!g().readCard(_))return R(`Card "${_}" not found in board at ${e$1.value}`);for(let _ of C){let $=g().readCard(_),q=Ot($),J=t.hashFn(q),W=t.kvStorage("card-upsert"),Se=W.read(_),ke=Se?.taskConfigHash!==J;if(!(!ke&&!f)){if(ke){let oe=Se?.blobRef??g().readCardKey(_)??_;x({type:"task-upsert",taskName:_,taskConfig:q,timestamp:Z()}),W.write(_,{blobRef:oe,taskConfigHash:J,updatedAt:Z()});}f&&x({type:"task-restart",taskName:_,timestamp:Z()});}}return X(),A()}catch(r){return F(r)}}function ie(o){try{let r=o.params?.token;if(!r)return R("taskFailed requires params.token");let c=o.params?.error??"unknown error",f=qe(r);return f?(x({type:"task-failed",taskName:f.taskName,error:c,timestamp:Z()}),X(),A()):R("Invalid callback token")}catch(r){return F(r)}}function ge(o){try{let r=o.params?.token;if(!r)return R("taskProgress requires params.token");let f=(o.body??{}).update??{},C=qe(r);return C?(x({type:"task-progress",taskName:C.taskName,update:f,timestamp:Z()}),X(),A()):R("Invalid callback token")}catch(r){return F(r)}}function be(o){try{let r=o.params?.token,c=o.params?.ref;if(!r)return R("sourceDataFetched requires params.token");if(!c)return R("sourceDataFetched requires params.ref");let f=qt(r);if(!f)return R("Invalid source token");let{cbk:C,cid:_,b:$,d:q,cs:J,rqt:W,dt:Se}=f,ke=Fe(j(),Re=>t.resolveBlob(Re)),oe=Se||t.genId();Se||ke.ingestSourceDataStaged(_,q,b(c),oe);let we=qe(C);if(!we)return R("Invalid callback token embedded in source token");let le=Z();return x({type:"task-progress",taskName:we.taskName,update:{bindTo:$,outputFile:q,fetchedAt:le,deliveryToken:oe,sourceChecksum:J,rqt:W},timestamp:le}),X(),A()}catch(r){return F(r)}}function ce(o){try{let r=o.params?.token,c=o.params?.reason??"unknown";if(!r)return R("sourceDataFetchFailure requires params.token");let f=qt(r);if(!f)return R("Invalid source token");let{cbk:C,b:_,d:$,cs:q,rqt:J}=f,W=qe(C);return W?(x({type:"task-progress",taskName:W.taskName,update:{bindTo:_,outputFile:$,failure:!0,reason:c,sourceChecksum:q,rqt:J},timestamp:Z()}),X(),A()):R("Invalid callback token embedded in source token")}catch(r){return F(r)}}function jt(o){try{let r=S().readCardStoreRef();return r?A({storeRef:r}):R(`Board at ${e$1.value} has no card store configured`)}catch(r){return F(r)}}function Kt(o){try{return A({storeRef:u$1??null})}catch(r){return F(r)}}function Nt(o){try{let r=S().readOutputsStoreRef();return r?A({storeRef:r}):R(`Board at ${e$1.value} has no outputs store configured`)}catch(r){return F(r)}}function Dt(o){try{return A({storeRef:l??null})}catch(r){return F(r)}}function Lt(o){try{let r=S().readChatStoreRef();return A({storeRef:r})}catch(r){return F(r)}}function $t(o){try{let r=S().readArtifactsStoreRef();return A({storeRef:r})}catch(r){return F(r)}}function Jt(o){try{let r=S().readFetchedSourcesStoreRef();return A({storeRef:r})}catch(r){return F(r)}}function Mt(o){try{let r=o.params?.key;if(!r)return R("getConfig requires params.key");let c=S(),f;switch(r){case "task-executor":f=h??null;break;case "chat-handler-flow":f=y??null;break;case "board-runtime-store-ref":f=c.readBoardRuntimeStoreRef();break;case "card-store-ref":f=c.readCardStoreRef();break;case "outputs-store-ref":f=c.readOutputsStoreRef();break;case "scratch-store-ref":f=l??null;break;case "chat-store-ref":f=c.readChatStoreRef();break;case "artifacts-store-ref":f=c.readArtifactsStoreRef();break;case "fetched-sources-store-ref":f=c.readFetchedSourcesStoreRef();break;default:return R(`getConfig: unknown key "${r}"`)}return A({value:f})}catch(r){return F(r)}}function Ht(o){try{let r=o.params?.key;if(!r)return R("getOutputsDataObject requires params.key");let c=Ue()[r]??null;return A(c)}catch(r){return F(r)}}function Gt(o){if(!o||typeof o!="object"||Array.isArray(o))return false;let r=o.__private;return !!r&&typeof r=="object"&&!Array.isArray(r)&&r.visible_controlplane_only===true}function Ut(o){let r=[...new Set(g().readAllCards().filter(f=>!Gt(f)).map(f=>f.id).filter(f=>typeof f=="string"&&f.length>0))].sort(),c=[...new Set(Object.keys(o).filter(f=>f&&f!==Bt))].sort();return {card_ids:r,data_object_keys:c}}function Ue(){let o=i().readAllDataObjects();return {...o,[Bt]:Ut(o)}}function Qe(o){try{return A(Ue())}catch(r){return F(r)}}function Qt(o){try{let r=o.params?.key;if(!r)return R("getOutputsComputedValues requires params.key");let c=i().readComputedValues(r);return A(c)}catch(r){return F(r)}}function ze(o){try{return A(i().readAllComputedValues())}catch(r){return F(r)}}function Ye(){return Fe(j(),o=>t.resolveBlob(o))}function Xe(o){let r=j().keyRef?.(o);if(!r)throw new Error("configured fetched-sources store does not support keyRef");return a(r)}function zt(o){try{let r=o.params?.key;if(!r)return R("getOutputsFetchedSources requires params.key");let c=Ye().listSources(r),f={};for(let C of c)f[C]=Xe(`${r}/${C}`);return A(f)}catch(r){return F(r)}}function Yt(o){try{let r=Ye(),c=new Set;for(let C of j().listKeys()){let _=C.indexOf("/");_>0&&!C.includes("/.staged/")&&c.add(C.slice(0,_));}let f={};for(let C of c){let _=r.listSources(C);if(_.length>0){f[C]={};for(let $ of _)f[C][$]=Xe(`${C}/${$}`);}}return A(f)}catch(r){return F(r)}}function Xt(o){try{let r=g().readAllCards(),c=ae({});if(c.status!=="success")return c;let f=Qe({});if(f.status!=="success")return f;let C=ze({});if(C.status!=="success")return C;let _=C.data,$={};for(let q of r){let J=typeof q?.id=="string"?q.id:null;if(!J)continue;let W=q.card_data&&typeof q.card_data=="object"&&!Array.isArray(q.card_data)?q.card_data:{};$[J]={schema_version:"v1",card_id:J,card_data:{...W},computed_values:_[J]&&typeof _[J]=="object"?_[J]:{}};}return A({cardDefinitions:r,statusSnapshot:c.data,dataObjectsByToken:f.data,cardRuntimeById:$})}catch(r){return F(r)}}return {init:pe,status:ae,getBoardRuntimeStoreRef:Kt,getCardStoreRef:jt,getOutputsStoreRef:Nt,getScratchStoreRef:Dt,getChatStoreRef:Lt,getArtifactsStoreRef:$t,getFetchedSourcesStoreRef:Jt,getConfig:Mt,getOutputsDataObject:Ht,getAllOutputsDataObjects:Qe,getOutputsComputedValues:Qt,getAllOutputsComputedValues:ze,getOutputsFetchedSources:zt,getAllOutputsFetchedSources:Yt,buildSseOneShotPayload:Xt,removeCard:E,addCardFiles:v,retrigger:P,processAccumulatedEvents:L,upsertCard:re,taskFailed:ie,taskProgress:ge,sourceDataFetched:be,sourceDataFetchFailure:ce}}function $r(e,t,n){let a=n?.taskExecutorRef,s=()=>{if(n){if(!n.boardRuntimeStoreRef)throw new Error(`Board at ${e.value} requires boardRuntimeStoreRef for non-core runtime operations.`);return Be(t.kvStorageForRef(n.boardRuntimeStoreRef))}return Be(t.kvStorage("config"))};function d(){let g=s().readCardStoreRef();if(!g)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let i=t.kvStorageForRef(g);return {readIndex(){return i.read("_index")},writeIndex(p){i.write("_index",p);},readCard(p){return i.read(p)},writeCard(p,b){return i.write(p,b),t.hashFn(b)},removeCard(p){i.delete(p);},cardExists(p){return i.read(p)!==null},defaultCardKey(p){return p}}}let u=()=>He(d(),t.onWarn??(()=>{}));function l(){return a??s().readTaskExecutorRef()}async function h(g,i){let p=t.validateSchema(i),b=[],I=l();if(I&&Array.isArray(i.source_defs))for(let x of i.source_defs){let K=typeof x.bindTo=="string"?x.bindTo:"(unknown)";try{let B;try{B=await t.invokeExecutor(I,"validate-source-def",{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(x)});}catch(H){let ne=H;if(B=typeof ne?.stdout=="string"?ne.stdout:"",!B.trim()){b.push(`source "${K}": executor validate-source-def failed \u2014 ${H instanceof Error?H.message:String(H)}`);continue}}let D=JSON.parse(B.trim());if(!D.ok&&Array.isArray(D.errors))for(let H of D.errors)b.push(`source "${K}": ${H}`);}catch(B){b.push(`source "${K}": executor validate-source-def failed \u2014 ${B instanceof Error?B.message:String(B)}`);}}let w=[...p.errors,...b];return A({cardId:g,isValid:w.length===0,issues:w})}function y(g,i){let p=g.params?.sourceIdx,b=g.params?.outRef;if(p===void 0)return R(`${i} requires params.sourceIdx`);if(!g.body||typeof g.body!="object"||Array.isArray(g.body))return R(`${i} requires card JSON object in body`);let I=g.body,w=I["card-content"]??I,x=I["mock-projections"]??{},K=w.source_defs??[];if(p<0||p>=K.length)return R(`sourceIdx ${p} out of range (card has ${K.length} source(s))`);let B=K[p],D=typeof B.bindTo=="string"?B.bindTo:"source";return {src:B,bindTo:D,outRef:b,mockProjections:x}}async function V(g){try{if(!g.body||typeof g.body!="object"||Array.isArray(g.body))return R("validateCardPreflight requires card JSON object in body");let i=g.body,p=i["card-content"]??i,b=typeof p.id=="string"?p.id:"(unknown)";return await h(b,p)}catch(i){return F(i)}}async function z(g){try{let i=y(g,"probeSourcePreflight");if("status"in i)return i;let p=l();if(!p)return R("No task-executor registered for this board");try{let b={...i.src,_projections:i.mockProjections},I=await t.invokeExecutor(p,"probe-source-preflight",{timeout:i.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(b)}),w=JSON.parse(I.trim());return w.ok?A({bindTo:i.bindTo,reachable:w.reachable,latencyMs:w.latencyMs,note:w.note}):R(w.error??"Preflight probe failed")}catch{return R("Executor does not support probe-source-preflight")}}catch(i){return F(i)}}async function Y(g){try{let i=y(g,"runSourcePreflight");if("status"in i)return i;let p=l();if(!p)return R("No task-executor registered for this board");try{let b$1={...i.src,_projections:i.mockProjections},I=await t.invokeExecutor(p,"run-source-preflight",{timeout:i.src.timeout??t.executorTimeouts?.probeMs??6e4,input:JSON.stringify(b$1)}),w=JSON.parse(I.trim());if(!w.ok)return A({bindTo:i.bindTo,ok:!1,result:null,issues:[w.error??"Preflight run failed"]});if(i.outRef){let x=b(i.outRef);t.absoluteBlob.write(x.value,JSON.stringify(w.resultValue,null,2));}return A({bindTo:typeof w.bindTo=="string"?w.bindTo:i.bindTo,ok:!0,result:w.resultValue??null,issues:[]})}catch(b){let I=b instanceof Error?b.message:String(b);return A({bindTo:i.bindTo,ok:!1,result:null,issues:[I]})}}catch(i){return F(i)}}async function ee(g){try{let i=l();if(!i)return R("No task-executor registered for this board");let p=await t.invokeExecutor(i,"describe-capabilities",{timeout:t.executorTimeouts?.describeMs??1e4});return A(JSON.parse(p.trim()))}catch(i){return F(i)}}function T(g){try{let i=g.body;if(!i||!Array.isArray(i.ops))return R("updatesInCardStore requires body.ops array");let p=i.ops,b=u();for(let I of p){let w=I.op,x=I.id;if(!x)return R('op is missing "id"');if(w==="update"){let K=I["card-content"];if(!K)return R(`update op for "${x}" is missing "card-content"`);b.writeCard(x,K);}else return R(`Unknown op type: "${w??"(none)"}"`)}return A()}catch(i){return F(i)}}function S(g){try{let i=g.body;if(!i||!Array.isArray(i.ids))return R("readFromCardStore requires body.ids array");let p=i.ids,b=u(),I=p.map(w=>({id:w,"card-content":b.readCard(w)}));return A({cards:I})}catch(i){return F(i)}}function G(g){try{if(!g.body||typeof g.body!="object"||Array.isArray(g.body))return R("evalCardCompute requires a JSON object in body");let i=g.body,p=i["card-content"]??i,b=typeof p.id=="string"?p.id:"(unknown)",I=i["mock-fetched-sources"]??{},w=i["mock-requires"]??{},x=p.compute;if(!x||!Array.isArray(x)||x.length===0)return A({cardId:b,ok:!0,computed_values:{},errors:[]});let K={id:b,card_data:p.card_data??{},requires:w,source_defs:p.source_defs,compute:x},B=a$3.runSync(K,{sourcesData:I}),D=B.node.computed_values??{},H=B.errors??[];return A({cardId:b,ok:H.length===0,computed_values:D,errors:H})}catch(i){return F(i)}}async function U(g){try{if(!g.body||typeof g.body!="object"||Array.isArray(g.body))return R("simulateCardCycle requires a JSON object in body");let i=g.body,p=i["card-content"]??i,b=typeof p.id=="string"?p.id:"(unknown)",I=i["mock-fetched-sources"]??{},w=i["mock-requires"]??{},x=await h(b,p),K=x.status==="success"?{isValid:x.data.isValid,issues:x.data.issues}:{isValid:!1,issues:[x.status==="fail"?x.error:"internal error"]},B=p.source_defs??[],D=p.card_data??{},H=[],ne=[];if(B.length>0){H=a$3.enrichSourcesSync(B,{card_data:D,requires:w});for(let j of H){let re=j.projections,ie=j._projections;if(re&&ie){for(let ge of Object.keys(re))if(ie[ge]===void 0){let be=typeof j.bindTo=="string"?j.bindTo:"(unknown)";ne.push({bindTo:be,key:ge,error:`Projection "${ge}" resolved to undefined`});}}}}let X=[],pe={...I},ae=i["task-executor-ref"],E=(ae?.howToRun&&ae?.whatToRun?ae:void 0)??l();for(let j=0;j<H.length;j++){let re=H[j],ie=typeof re.bindTo=="string"?re.bindTo:`source_${j}`;if(!E){X.push({bindTo:ie,skipped:!0,error:"No task executor configured"});continue}try{let ge={...re},be=await t.invokeExecutor(E,"run-source-preflight",{timeout:re.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(ge)}),ce=JSON.parse(be.trim());ce.ok&&!Object.prototype.hasOwnProperty.call(I,ie)&&Object.prototype.hasOwnProperty.call(ce,"resultValue")&&(pe[ie]=ce.resultValue),X.push({bindTo:ie,reachable:ce.reachable,latencyMs:ce.latencyMs,error:ce.ok?void 0:ce.error});}catch{X.push({bindTo:ie,skipped:!0,error:"Executor does not support run-source-preflight"});}}let v=p.compute,P={},L=[];if(v&&Array.isArray(v)&&v.length>0){let j={id:b,card_data:D,requires:w,source_defs:p.source_defs,compute:v},re=a$3.runSync(j,{sourcesData:pe});P=re.node.computed_values??{},L=re.errors??[];}let te=K.isValid&&ne.length===0&&L.length===0&&X.every(j=>j.reachable!==!1);return A({cardId:b,ok:te,validation:K,source_probes:X,projection_errors:ne,fetched_sources:pe,computed_values:P,compute_errors:L})}catch(i){return F(i)}}return {validateCardPreflight:V,probeSourcePreflight:z,runSourcePreflight:Y,evalCardCompute:G,simulateCardCycle:U,describeTaskExecutorCapabilities:ee,updatesInCardStore:T,readFromCardStore:S}}
|
|
2
|
+
export{Cr as a,kt as b,br as c,pt as d,kr as e,Rr as f,hr as g,yt as h,or as i,sr as j,Ct as k,He as l,Oe as m,he as n,Fr as o,bt as p,wt as q,ir as r,vt as s,Pe as t,Ge as u,_t as v,Ft as w,Ot as x,Lr as y,$r as z};//# sourceMappingURL=chunk-AHW6EMUO.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-AHW6EMUO.js.map
|