yaml-flow 8.11.5 → 8.11.7

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.
Files changed (90) hide show
  1. package/browser/adapters/localstorage-storage.js +1 -1
  2. package/browser/asset-integrity.json +4 -4
  3. package/browser/board-sse-state.js +2 -0
  4. package/browser/server-runtime-controlface.js +1 -1
  5. package/examples/board-container/board-container-lifecycle-example.js +67 -0
  6. package/lib/board-container-lifecycle-D5gz6kB1.d.cts +57 -0
  7. package/lib/board-container-lifecycle-D5gz6kB1.d.ts +57 -0
  8. package/lib/board-live-cards-node.cjs +8 -8
  9. package/lib/board-live-cards-node.d.cts +24 -9
  10. package/lib/board-live-cards-node.d.ts +24 -9
  11. package/lib/board-live-cards-node.js +8 -8
  12. package/lib/{board-live-cards-public-async-U98IXUBx.d.ts → board-live-cards-public-async-D72v-MTi.d.ts} +1 -1
  13. package/lib/{board-live-cards-public-async-Cl0M3j5P.d.cts → board-live-cards-public-async-DtgoCVRv.d.cts} +1 -1
  14. package/lib/board-live-cards-public.cjs +1 -1
  15. package/lib/board-live-cards-public.d.cts +4 -4
  16. package/lib/board-live-cards-public.d.ts +4 -4
  17. package/lib/board-live-cards-public.js +1 -1
  18. package/lib/board-live-cards-server-runtime.cjs +1 -1
  19. package/lib/board-live-cards-server-runtime.d.cts +3 -3
  20. package/lib/board-live-cards-server-runtime.d.ts +3 -3
  21. package/lib/board-live-cards-server-runtime.js +1 -1
  22. package/lib/{board-platform-adapter-async-ByBRFn1G.d.ts → board-platform-adapter-async-CVvZYqNy.d.ts} +2 -2
  23. package/lib/{board-platform-adapter-async-DjBwE0m9.d.cts → board-platform-adapter-async-O7EUvJ3W.d.cts} +2 -2
  24. package/lib/board-sse-state.cjs +2 -0
  25. package/lib/board-sse-state.d.cts +19 -0
  26. package/lib/board-sse-state.d.ts +19 -0
  27. package/lib/board-sse-state.js +2 -0
  28. package/lib/board-state-reducer.cjs +1 -1
  29. package/lib/board-state-reducer.js +1 -1
  30. package/lib/{chunk-WE7JOO4T.cjs → chunk-3XPY7CCM.cjs} +2 -2
  31. package/lib/chunk-73LKIKD3.cjs +2 -0
  32. package/lib/chunk-7SBE7A6E.cjs +2 -0
  33. package/lib/{chunk-7UJQMFVS.js → chunk-AN7MLI7X.js} +2 -2
  34. package/lib/chunk-CAQHA4GK.js +2 -0
  35. package/lib/chunk-CJQEM63S.cjs +2 -0
  36. package/lib/{chunk-WRMOGPRG.cjs → chunk-CSHNTZW4.cjs} +2 -2
  37. package/lib/chunk-F3A3ZNF6.js +2 -0
  38. package/lib/{chunk-CODPG5MY.js → chunk-HKPVF5UI.js} +3 -3
  39. package/lib/chunk-IXZV5BS5.js +2 -0
  40. package/lib/{chunk-5RUSICUC.cjs → chunk-K5TEZRZK.cjs} +3 -3
  41. package/lib/{chunk-6MD6FVE3.js → chunk-PEJRTZU3.js} +2 -2
  42. package/lib/{chunk-QKWQ4HRE.js → chunk-RKLEBQUG.js} +3 -3
  43. package/lib/{chunk-ZWXZ5DBX.cjs → chunk-TUQ6JBER.cjs} +3 -3
  44. package/lib/{chunk-BQJVCCFU.cjs → chunk-U5BGE52X.cjs} +2 -2
  45. package/lib/{chunk-HOSD6UHA.js → chunk-X32SJDLT.js} +2 -2
  46. package/lib/cloud-storage.cjs +1 -1
  47. package/lib/cloud-storage.d.cts +2 -2
  48. package/lib/cloud-storage.d.ts +2 -2
  49. package/lib/cloud-storage.js +1 -1
  50. package/lib/firestore-storage/index.cjs +1 -1
  51. package/lib/firestore-storage/index.d.cts +1 -1
  52. package/lib/firestore-storage/index.d.ts +1 -1
  53. package/lib/firestore-storage/index.js +1 -1
  54. package/lib/index.cjs +2 -2
  55. package/lib/index.d.cts +1 -0
  56. package/lib/index.d.ts +1 -0
  57. package/lib/index.js +1 -1
  58. package/lib/localstorage-storage/index.cjs +1 -1
  59. package/lib/localstorage-storage/index.d.cts +1 -1
  60. package/lib/localstorage-storage/index.d.ts +1 -1
  61. package/lib/localstorage-storage/index.js +1 -1
  62. package/lib/notification-consumer/index.cjs +1 -1
  63. package/lib/notification-consumer/index.js +1 -1
  64. package/lib/server-jobs-queue-runner/index.cjs +1 -1
  65. package/lib/server-jobs-queue-runner/index.d.cts +3 -3
  66. package/lib/server-jobs-queue-runner/index.d.ts +3 -3
  67. package/lib/server-jobs-queue-runner/index.js +1 -1
  68. package/lib/server-runtime/index.cjs +1 -1
  69. package/lib/server-runtime/index.d.cts +4 -4
  70. package/lib/server-runtime/index.d.ts +4 -4
  71. package/lib/server-runtime/index.js +1 -1
  72. package/lib/server-runtime-agentface/index.d.cts +3 -3
  73. package/lib/server-runtime-agentface/index.d.ts +3 -3
  74. package/lib/server-runtime-controlface/index.cjs +1 -1
  75. package/lib/server-runtime-controlface/index.d.cts +3 -3
  76. package/lib/server-runtime-controlface/index.d.ts +3 -3
  77. package/lib/server-runtime-controlface/index.js +1 -1
  78. package/lib/server-runtime-core/index.cjs +1 -1
  79. package/lib/server-runtime-core/index.d.cts +5 -5
  80. package/lib/server-runtime-core/index.d.ts +5 -5
  81. package/lib/server-runtime-core/index.js +1 -1
  82. package/lib/server-runtime-watchers/index.d.cts +5 -5
  83. package/lib/server-runtime-watchers/index.d.ts +5 -5
  84. package/lib/server-runtime-webhooks/index.d.cts +3 -3
  85. package/lib/server-runtime-webhooks/index.d.ts +3 -3
  86. package/lib/{sse-hub-D_QHswxL.d.ts → sse-hub-BGQWPQJP.d.ts} +1 -1
  87. package/lib/{sse-hub-XO6crN9o.d.cts → sse-hub-DViWG1m-.d.cts} +1 -1
  88. package/lib/{types-B8Yieskx.d.ts → types-D5rknZ9j.d.ts} +2 -2
  89. package/lib/{types-gTf9pAyC.d.cts → types-VIrQZ8CW.d.cts} +2 -2
  90. package/package.json +6 -1
@@ -1,4 +1,4 @@
1
1
  var LocalStorageStorage=(function(exports){'use strict';var A="b64:";function fe(r){let t=new TextEncoder().encode(r),n=globalThis.Buffer,o;if(n)o=n.from(t).toString("base64");else if(typeof btoa=="function"){let e="";for(let s of t)e+=String.fromCharCode(s);o=btoa(e);}else throw new Error("No base64 encoder available in this runtime");return o.replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function ge(r){let t=r.replace(/-/g,"+").replace(/_/g,"/")+"=".repeat((4-r.length%4)%4),n=globalThis.Buffer;if(n)return n.from(t,"base64").toString("utf8");if(typeof atob=="function"){let o=atob(t),e=new Uint8Array(o.length);for(let s=0;s<o.length;s+=1)e[s]=o.charCodeAt(s);return new TextDecoder().decode(e)}throw new Error("No base64 decoder available in this runtime")}function h(r){return `${A}${fe(JSON.stringify(r))}`}function v(r){if(!r.startsWith(A))throw new Error(`Invalid ref format (expected ${A}<base64url(json)>): ${r}`);let t;try{t=JSON.parse(ge(r.slice(A.length)));}catch{throw new Error(`Invalid ref format (malformed base64url/json): ${r}`)}if(!t||typeof t!="object")throw new Error(`Invalid ref format (expected object payload): ${r}`);let n=t;if(typeof n.kind!="string"||typeof n.value!="string")throw new Error(`Invalid ref format (payload must contain string kind/value): ${r}`);return {kind:n.kind,value:n.value}}function B(r){return {messageId:r.id,enqueuedAt:r.enqueuedAt,attempt:r.attempt,request:r.body}}function Se(r){return typeof r=="string"?r.startsWith("b64:")?v(r).value:r:r.value}function K(r){return {async enqueueRequest(t){return (await r.enqueue(t)).id},async leaseRequests(t){return (await r.lease(t)).map(n=>({...B(n),leaseToken:n.leaseToken,leaseExpiresAt:n.leaseExpiresAt}))},ackRequest(t,n){return r.ack(t,n)},nackRequest(t,n,o){return r.nack(t,n,o)},async peekActive(){return (await r.peekActive()).map(B)},async peekDeadLetter(){return (await r.peekDeadLetter()).map(t=>({...B(t),reason:t.reason}))}}}function q(r){let t=r.callbackTransport,n=r.resolveBlob??(async e=>{let s=await r.blobStorage("").read(e.value);if(s==null)throw new Error(`Blob not found for ref ${e.kind}:${e.value}`);return s});async function o(e,s){if(e.howToRun==="queue-storage")return r.queueStoreRef?(await K(r.queueStorageForRef(r.queueStoreRef,"task-executor")).enqueueRequest({boardId:typeof e.extra?.boardId=="string"?e.extra.boardId:r.boardId,ref:e,args:s}),{dispatched:true}):{dispatched:false,error:"queue-storage dispatch requires queueStoreRef"};if(e.howToRun==="http:post"){let u=r.fetch??globalThis.fetch;if(!u)return {dispatched:false,error:"http:post dispatch requires fetch support"};let a=await u(Se(e.whatToRun),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...s,...e.extra?{extra:e.extra}:{}})});if(!a.ok){let c=await a.text().catch(()=>"");return {dispatched:false,error:`HTTP ${a.status}: ${c}`}}return {dispatched:true}}return {dispatched:false,error:`Unsupported hosted async transport "${e.howToRun}"`}}return {kvStorage:r.kvStorage,kvStorageForRef:r.kvStorageForRef,blobStorage:r.blobStorage,blobStorageForRef:r.blobStorageForRef,chatStorageForRef:r.chatStorageForRef,queueStorageForRef:r.queueStorageForRef,scratchStorage:r.scratchStorage,scratchStorageForRef:r.scratchStorageForRef,archiveFactory:r.archiveFactory,archiveFactoryForRef:r.archiveFactoryForRef,journalStorage:r.journalStorage,journalStorageForRef:r.journalStorageForRef,lock:r.lock,get callbackTransport(){return t},set callbackTransport(e){t=e;},dispatchExecution:(e,s)=>r.dispatchExecution?.(e,s)??o(e,s),supportsDirectSourceOutput:r.supportsDirectSourceOutput,resolveBlob:n,hashFn:r.hashFn,genId:r.genId,requestProcessAccumulated:r.requestProcessAccumulated,publishBoardChangeNotifications:r.publishBoardChangeNotifications,warn:r.onWarn}}function N(r){if(r==null||typeof r!="object")return JSON.stringify(r);if(Array.isArray(r))return `[${r.map(N).join(",")}]`;let t=r;return `{${Object.keys(t).sort().map(o=>`${JSON.stringify(o)}:${N(t[o])}`).join(",")}}`}function I(r,t){let n=t>>>0;for(let o=0;o<r.length;o++)n^=r.charCodeAt(o),n=Math.imul(n,16777619)>>>0;return n}function X(r){let t=N(r),n=I(t,2166136261),o=I(t,3735928559),e=I(t,19088743),s=I(t,4277009102);return [n,o,e,s].map(u=>u.toString(16).padStart(8,"0")).join("")}function _(r){function t(s){return `${r}:blob:${s}`}let n=new TextEncoder;function o(s){if(typeof btoa=="function"){let u="";for(let a=0;a<s.length;a++)u+=String.fromCharCode(s[a]);return btoa(u)}return ""}function e(s){if(typeof atob=="function"){let u=atob(s),a=new Uint8Array(u.length);for(let c=0;c<u.length;c++)a[c]=u.charCodeAt(c);return a}return new Uint8Array}return {read(s){return globalThis.localStorage.getItem(t(s))},write(s,u){globalThis.localStorage.setItem(t(s),u);},exists(s){return globalThis.localStorage.getItem(t(s))!==null},remove(s){globalThis.localStorage.removeItem(t(s));},readBytes(s){let u=globalThis.localStorage.getItem(t(s));if(u===null)return null;try{let a=JSON.parse(u);if(a&&a.__kind==="bytes-b64"&&typeof a.data=="string")return e(a.data)}catch{}return n.encode(u)},writeBytes(s,u){let a=JSON.stringify({__kind:"bytes-b64",data:o(u)});globalThis.localStorage.setItem(t(s),a);},listKeys(s){let u=t(s??""),a=[];for(let c=0;c<globalThis.localStorage.length;c++){let l=globalThis.localStorage.key(c);l&&l.startsWith(u)&&a.push(l.slice(t("").length));}return a.sort()},stat(s){let u=globalThis.localStorage.getItem(t(s));if(u===null)return null;let a=n.encode(u).byteLength;try{let c=JSON.parse(u);c&&c.__kind==="bytes-b64"&&typeof c.data=="string"&&(a=e(c.data).byteLength);}catch{}return {key:s,size:a}},renameKey(s,u){let a=globalThis.localStorage.getItem(t(s));return a===null?false:(globalThis.localStorage.setItem(t(u),a),globalThis.localStorage.removeItem(t(s)),true)}}}var Ge=":scratch-marker",Ue=":scratch-config",P=":scratch:",He=1440*60*1e3,Qe=720*60*1e3,ze=200;function z(r,t){if(!r)return t;let n=r.replace(/[^A-Za-z0-9._-]/g,"_");return n.length>0?n:t}function Z(r){let t=`${r}${Ge}`,n=`${r}${Ue}`,o=i=>`${r}${P}${i}`,e=i=>`${r}${P}${i}:__ts`,s=globalThis.localStorage.getItem(t)===null;if(s)try{globalThis.localStorage.setItem(t,`scratch-store
2
- ${new Date().toISOString()}`);}catch{}function u(){let i=globalThis.localStorage.getItem(n);if(i===null)return {};try{let d=JSON.parse(i);return d&&typeof d=="object"&&!Array.isArray(d)?d:{}}catch{return {}}}function a(i){try{globalThis.localStorage.setItem(n,JSON.stringify(i));}catch{}}if(s){let i=u();typeof i["retention.lastSweepAt"]!="number"&&(i["retention.lastSweepAt"]=Date.now(),a(i));}function c(){if(globalThis.localStorage.getItem(t)===null)return;let i=u(),d=typeof i["retention.maxAgeMs"]=="number"?i["retention.maxAgeMs"]:He,f=typeof i["retention.sweepIntervalMs"]=="number"?i["retention.sweepIntervalMs"]:Qe;if(d<=0||f<=0)return;let m=typeof i["retention.lastSweepAt"]=="number"?i["retention.lastSweepAt"]:0,p=Date.now();if(p-m<f)return;i["retention.lastSweepAt"]=p,a(i);let y=p,S=`${r}${P}`,k=[];for(let C=0;C<globalThis.localStorage.length;C++){let b=globalThis.localStorage.key(C);b&&b.startsWith(S)&&!b.endsWith(":__ts")&&k.push(b);}for(let C of k){if(Date.now()-y>ze)break;let b=globalThis.localStorage.getItem(`${C}:__ts`),O=b===null?0:Number(b);if(Number.isFinite(O)&&O>0&&p-O>d){try{globalThis.localStorage.removeItem(C);}catch{}try{globalThis.localStorage.removeItem(`${C}:__ts`);}catch{}}}}function l(i,d){let f=z(i,"scratch"),m=z(d,".json"),p=m.startsWith(".")?m:`.${m}`,y=Math.random().toString(36).slice(2,10);return `${f}-${Date.now()}-${y}${p}`}function g(i,d){globalThis.localStorage.setItem(o(i),d),globalThis.localStorage.setItem(e(i),String(Date.now()));}return {read(i){return globalThis.localStorage.getItem(o(i))},write(i,d){g(i,d);try{c();}catch{}},exists(i){return globalThis.localStorage.getItem(o(i))!==null},remove(i){try{globalThis.localStorage.removeItem(o(i));}catch{}try{globalThis.localStorage.removeItem(e(i));}catch{}},readBytes(i){let d=globalThis.localStorage.getItem(o(i));return d===null?null:new TextEncoder().encode(d)},writeBytes(i,d){let f="";for(let m=0;m<d.length;m++)f+=String.fromCharCode(d[m]);g(i,f);try{c();}catch{}},stat(i){let d=globalThis.localStorage.getItem(o(i));if(d===null)return null;let f=globalThis.localStorage.getItem(e(i)),m=f===null?null:Number(f);return {key:i,size:new TextEncoder().encode(d).byteLength,updatedAt:m!==null&&Number.isFinite(m)?new Date(m).toISOString():void 0}},listKeys(i){let d=`${r}${P}`,f=[];for(let m=0;m<globalThis.localStorage.length;m++){let p=globalThis.localStorage.key(m);if(p&&p.startsWith(d)&&!p.endsWith(":__ts")){let y=p.slice(d.length);(!i||y.startsWith(i))&&f.push(y);}}return f.sort()},getUniqueKey(i,d){return l(i,d)},create(i,d,f){let m=l(d,f);g(m,i);try{c();}catch{}return m},keyRef(i){return {kind:"local-storage-scratch",value:i,extra:{prefix:r}}},renameKey(i,d){let f=globalThis.localStorage.getItem(o(i));if(f===null)return false;g(d,f);try{globalThis.localStorage.removeItem(o(i));}catch{}try{globalThis.localStorage.removeItem(e(i));}catch{}return true},config:{get(i){return u()[i]??null},set(i,d){let f=u();d==null?delete f[i]:f[i]=d,a(f);}}}}var We=":archive-marker",Ye=":archive-config",F=":archive:stream:",W=":archive:blob:";function Y(r){let t=r.replace(/[^A-Za-z0-9._-]/g,"_");if(!t)throw new Error("Archive segment name cannot be empty after sanitization");return t}function ee(r){let t=`${r}${We}`,n=`${r}${Ye}`,o=a=>`${r}${F}${a}`;if(globalThis.localStorage.getItem(t)===null)try{globalThis.localStorage.setItem(t,`archive-store
2
+ ${new Date().toISOString()}`);}catch{}function u(){let i=globalThis.localStorage.getItem(n);if(i===null)return {};try{let d=JSON.parse(i);return d&&typeof d=="object"&&!Array.isArray(d)?d:{}}catch{return {}}}function a(i){try{globalThis.localStorage.setItem(n,JSON.stringify(i));}catch{}}if(s){let i=u();typeof i["retention.lastSweepAt"]!="number"&&(i["retention.lastSweepAt"]=Date.now(),a(i));}function c(){if(globalThis.localStorage.getItem(t)===null)return;let i=u(),d=typeof i["retention.maxAgeMs"]=="number"?i["retention.maxAgeMs"]:He,f=typeof i["retention.sweepIntervalMs"]=="number"?i["retention.sweepIntervalMs"]:Qe;if(d<=0||f<=0)return;let m=typeof i["retention.lastSweepAt"]=="number"?i["retention.lastSweepAt"]:0,p=Date.now();if(p-m<f)return;i["retention.lastSweepAt"]=p,a(i);let y=p,S=`${r}${P}`,k=[];for(let b=0;b<globalThis.localStorage.length;b++){let C=globalThis.localStorage.key(b);C&&C.startsWith(S)&&!C.endsWith(":__ts")&&k.push(C);}for(let b of k){if(Date.now()-y>ze)break;let C=globalThis.localStorage.getItem(`${b}:__ts`),O=C===null?0:Number(C);if(Number.isFinite(O)&&O>0&&p-O>d){try{globalThis.localStorage.removeItem(b);}catch{}try{globalThis.localStorage.removeItem(`${b}:__ts`);}catch{}}}}function l(i,d){let f=z(i,"scratch"),m=z(d,".json"),p=m.startsWith(".")?m:`.${m}`,y=Math.random().toString(36).slice(2,10);return `${f}-${Date.now()}-${y}${p}`}function g(i,d){globalThis.localStorage.setItem(o(i),d),globalThis.localStorage.setItem(e(i),String(Date.now()));}return {read(i){return globalThis.localStorage.getItem(o(i))},write(i,d){g(i,d);try{c();}catch{}},exists(i){return globalThis.localStorage.getItem(o(i))!==null},remove(i){try{globalThis.localStorage.removeItem(o(i));}catch{}try{globalThis.localStorage.removeItem(e(i));}catch{}},readBytes(i){let d=globalThis.localStorage.getItem(o(i));return d===null?null:new TextEncoder().encode(d)},writeBytes(i,d){let f="";for(let m=0;m<d.length;m++)f+=String.fromCharCode(d[m]);g(i,f);try{c();}catch{}},stat(i){let d=globalThis.localStorage.getItem(o(i));if(d===null)return null;let f=globalThis.localStorage.getItem(e(i)),m=f===null?null:Number(f);return {key:i,size:new TextEncoder().encode(d).byteLength,updatedAt:m!==null&&Number.isFinite(m)?new Date(m).toISOString():void 0}},listKeys(i){let d=`${r}${P}`,f=[];for(let m=0;m<globalThis.localStorage.length;m++){let p=globalThis.localStorage.key(m);if(p&&p.startsWith(d)&&!p.endsWith(":__ts")){let y=p.slice(d.length);(!i||y.startsWith(i))&&f.push(y);}}return f.sort()},getUniqueKey(i,d){return l(i,d)},create(i,d,f){let m=l(d,f);g(m,i);try{c();}catch{}return m},keyRef(i){return {kind:"local-storage-scratch",value:i,extra:{prefix:r}}},renameKey(i,d){let f=globalThis.localStorage.getItem(o(i));if(f===null)return false;g(d,f);try{globalThis.localStorage.removeItem(o(i));}catch{}try{globalThis.localStorage.removeItem(e(i));}catch{}return true},config:{get(i){return u()[i]??null},set(i,d){let f=u();d==null?delete f[i]:f[i]=d,a(f);}}}}var We=":archive-marker",Ye=":archive-config",F=":archive:stream:",W=":archive:blob:";function Y(r){let t=r.replace(/[^A-Za-z0-9._-]/g,"_");if(!t)throw new Error("Archive segment name cannot be empty after sanitization");return t}function ee(r){let t=`${r}${We}`,n=`${r}${Ye}`,o=a=>`${r}${F}${a}`;if(globalThis.localStorage.getItem(t)===null)try{globalThis.localStorage.setItem(t,`archive-store
3
3
  ${new Date().toISOString()}`);}catch{}function e(){let a=globalThis.localStorage.getItem(n);if(a===null)return {};try{let c=JSON.parse(a);return c&&typeof c=="object"&&!Array.isArray(c)?c:{}}catch{return {}}}function s(a){try{globalThis.localStorage.setItem(n,JSON.stringify(a));}catch{}}function u(){if(globalThis.localStorage.getItem(t)===null)return;let a=e(),c=typeof a["retention.maxAgeMs"]=="number"?a["retention.maxAgeMs"]:0,l=typeof a["retention.sweepIntervalMs"]=="number"?a["retention.sweepIntervalMs"]:0;if(c<=0||l<=0)return;let g=typeof a["retention.lastSweepAt"]=="number"?a["retention.lastSweepAt"]:0,i=Date.now();if(i-g<l)return;a["retention.lastSweepAt"]=i,s(a);let d=`${r}${F}`;for(let f=0;f<globalThis.localStorage.length;f++){let m=globalThis.localStorage.key(f);if(!m||!m.startsWith(d))continue;let p=globalThis.localStorage.getItem(m);if(p)try{let y=JSON.parse(p),S=y.filter(k=>typeof k.__ts!="number"||i-k.__ts<=c);S.length!==y.length&&globalThis.localStorage.setItem(m,JSON.stringify(S));}catch{}}}return {stream(a){let c=Y(a),l=o(c);function g(){let d=globalThis.localStorage.getItem(l);if(!d)return [];try{return JSON.parse(d)}catch{return []}}function i(d){try{globalThis.localStorage.setItem(l,JSON.stringify(d));}catch{}}return {append(d){let f={id:globalThis.crypto.randomUUID(),payload:d,__ts:Date.now()},m=g();m.push(f),i(m);try{u();}catch{}return {id:f.id,payload:f.payload}},readAll(){return g().map(d=>({id:d.id,payload:d.payload}))},readAfter(d){let f=g();if(!d){let S=f.map(k=>({id:k.id,payload:k.payload}));return {entries:S,newCursor:S.length>0?S[S.length-1].id:null}}let m=f.findIndex(S=>S.id===d),y=(m===-1?f:f.slice(m+1)).map(S=>({id:S.id,payload:S.payload}));return {entries:y,newCursor:y.length>0?y[y.length-1].id:d}},clear(){try{globalThis.localStorage.removeItem(l);}catch{}}}},blob(a){let c=Y(a),l=_(`${r}${W}${c}`);return {read:g=>l.read(g),write:(g,i)=>{l.write(g,i);try{u();}catch{}},exists:g=>l.exists(g),remove:g=>l.remove(g),readBytes:l.readBytes?g=>l.readBytes(g):void 0,writeBytes:l.writeBytes?(g,i)=>{l.writeBytes(g,i);try{u();}catch{}}:void 0,listKeys:g=>l.listKeys(g),stat:l.stat?g=>l.stat(g):void 0,renameKey:(g,i)=>l.renameKey(g,i)}},listStreams(a){let c=`${r}${F}`,l=[];for(let g=0;g<globalThis.localStorage.length;g++){let i=globalThis.localStorage.key(g);if(!i||!i.startsWith(c))continue;let d=i.slice(c.length);(!a||d.startsWith(a))&&l.push(d);}return l.sort()},listBlobs(a){let c=`${r}${W}`,l=new Set;for(let g=0;g<globalThis.localStorage.length;g++){let i=globalThis.localStorage.key(g);if(!i||!i.startsWith(c))continue;let d=i.slice(c.length),f=d.indexOf(":"),m=f===-1?d:d.slice(0,f);(!a||m.startsWith(a))&&l.add(m);}return Array.from(l).sort()},config:{get(a){return e()[a]??null},set(a,c){let l=e();c==null?delete l[a]:l[a]=c,s(l);}}}}function te(r){function t(n){return `${r}:kv:${n}`}return {read(n){let o=globalThis.localStorage.getItem(t(n));if(o===null)return null;try{return JSON.parse(o)}catch{return null}},write(n,o){globalThis.localStorage.setItem(t(n),JSON.stringify(o));},delete(n){globalThis.localStorage.removeItem(t(n));},listKeys(n){let o=t(n??""),e=[];for(let s=0;s<globalThis.localStorage.length;s++){let u=globalThis.localStorage.key(s);u!==null&&u.startsWith(o)&&e.push(u.slice(t("").length));}return e}}}function re(r){function t(){let o=globalThis.localStorage.getItem(r);if(!o)return [];try{return JSON.parse(o)}catch{return []}}function n(o){globalThis.localStorage.setItem(r,JSON.stringify(o));}return {readAllEntries(){return t()},appendEntry(o){let e=t();e.push(o),n(e);},generateId(){return globalThis.crypto.randomUUID()}}}function ne(r){return String(r).replace(/[^a-zA-Z0-9_-]/g,"_")}function oe(r){let t=r.payload??{};return {id:r.id,role:typeof t.role=="string"?t.role:"system",text:typeof t.text=="string"?t.text:"",files:Array.isArray(t.files)?t.files:[],turn:typeof t.turn=="string"?t.turn:"",updated_at:typeof t.updated_at=="string"?t.updated_at:""}}function se(r,t){let n=e=>`chats/${ne(e)}/processing`,o=e=>`chats/${ne(e)}/config`;return {async append(e,s,u,a=[],c=""){return (await r(e).append({role:s,text:u,files:a,turn:c,updated_at:new Date().toISOString()})).id},async readAll(e){return (await r(e).readAll()).map(oe)},async readAfter(e,s){let u=await r(e).readAfter(s);return {records:u.entries.map(oe),cursor:u.newCursor}},async clear(e){await r(e).clear?.();},async setProcessing(e,s){s?await t.write(n(e),true):await t.delete(n(e));},async isProcessing(e){return await t.read(n(e))===true},async getConfig(e){return await t.read(o(e))??{}},async setConfig(e,s){let u=await t.read(o(e))??{};await t.write(o(e),{...u,...s});}}}function Xe(){let r=false;return {async tryAcquire(){return r?null:(r=true,()=>{r=false;})}}}function Ze(){let r=new Map,t=new Map,n=new Map;return {async enqueue(o){let e={id:globalThis.crypto?.randomUUID?.()??`${Date.now()}-${Math.random().toString(36).slice(2,10)}`,body:o,enqueuedAt:new Date().toISOString(),attempt:0};return r.set(e.id,e),e},async enqueueMany(o){let e=[];for(let s of o)e.push(await this.enqueue(s));return e},async enqueueIfAbsent(o,e){for(let u of r.values())if(u.dedupKey===e)return null;for(let u of t.values())if(u.dedupKey===e)return null;let s={id:globalThis.crypto?.randomUUID?.()??`${Date.now()}-${Math.random().toString(36).slice(2,10)}`,body:o,enqueuedAt:new Date().toISOString(),attempt:0,dedupKey:e};return r.set(s.id,s),s},async stage(o,e){let s=e?.dedupKey;if(s){for(let a of r.values())if(a.dedupKey===s)return null;for(let a of t.values())if(a.dedupKey===s)return null}let u={id:globalThis.crypto?.randomUUID?.()??`${Date.now()}-${Math.random().toString(36).slice(2,10)}`,body:o,enqueuedAt:new Date().toISOString(),attempt:0,...s?{dedupKey:s}:{}};return t.set(u.id,u),u},async commitStaged(o){let e=t.get(o);return e?(t.delete(o),r.set(o,{...e,enqueuedAt:new Date().toISOString(),attempt:0}),true):false},async discardStaged(o,e){let s=t.get(o);return s?(t.delete(o),n.set(o,{...s,reason:e}),true):false},async peekStaged(o=""){return Array.from(t.values()).filter(e=>!o||e.id.startsWith(o)).map(e=>({id:e.id,body:e.body,enqueuedAt:e.enqueuedAt,attempt:e.attempt}))},async lease(o){let e=Math.max(1,Math.floor(o?.max??1)),s=Math.max(1,Math.floor(o?.visibilityMs??6e4)),u=Date.now();for(let c of r.values())c.leaseExpiresAt&&Date.parse(c.leaseExpiresAt)<=u&&(delete c.leaseToken,delete c.leaseExpiresAt);let a=[];for(let c of r.values()){if(a.length>=e)break;c.leaseToken||(c.attempt+=1,c.leaseToken=globalThis.crypto?.randomUUID?.()??`${Date.now()}-${Math.random().toString(36).slice(2,10)}`,c.leaseExpiresAt=new Date(Date.now()+s).toISOString(),a.push({id:c.id,body:c.body,enqueuedAt:c.enqueuedAt,attempt:c.attempt,leaseToken:c.leaseToken,leaseExpiresAt:c.leaseExpiresAt}));}return a},async ack(o,e){let s=r.get(o);return !s||s.leaseToken!==e?false:(r.delete(o),true)},async nack(o,e,s){let u=r.get(o);return !u||u.leaseToken!==e?false:(delete u.leaseToken,delete u.leaseExpiresAt,s?.dead&&(r.delete(o),n.set(o,{...u,reason:s.reason})),true)},async peekActive(o=""){return Array.from(r.values()).filter(e=>!e.leaseToken).filter(e=>!o||e.id.startsWith(o)).map(e=>({id:e.id,body:e.body,enqueuedAt:e.enqueuedAt,attempt:e.attempt}))},async peekDeadLetter(o=""){return Array.from(n.values()).filter(e=>!o||e.id.startsWith(o)).map(e=>({id:e.id,body:e.body,enqueuedAt:e.enqueuedAt,attempt:e.attempt,reason:e.reason}))}}}function D(r){let t=te(r);return {async read(n){return t.read(n)},async write(n,o){t.write(n,o);},async delete(n){t.delete(n);},async listKeys(n){return t.listKeys(n)}}}function ae(r){let t=_(r);return {async read(n){return t.read(n)},async write(n,o){t.write(n,o);},async exists(n){return t.exists(n)},async remove(n){t.remove(n);},async readBytes(n){return t.readBytes?.(n)??null},async writeBytes(n,o){await t.writeBytes?.(n,o);},async listKeys(n){return t.listKeys(n)},async stat(n){return t.stat?.(n)??null},async renameKey(n,o){let e=await t.read(n);return e==null?false:(t.write(o,e),t.remove(n),true)}}}function ie(r){let t=Z(r);return {async read(n){return t.read(n)},async write(n,o){t.write(n,o);},async exists(n){return t.exists(n)},async remove(n){t.remove(n);},async readBytes(n){return t.readBytes?.(n)??null},async writeBytes(n,o){await t.writeBytes?.(n,o);},async listKeys(n){return t.listKeys(n)},async stat(n){return t.stat?.(n)??null},async getUniqueKey(n,o){return t.getUniqueKey(n,o)},async create(n,o,e){return t.create(n,o,e)},keyRef(n){return t.keyRef(n)},async renameKey(n,o){let e=t.read(n);return e==null?false:(t.write(o,e),t.remove(n),true)},config:{async get(n){return t.config.get(n)},async set(n,o){t.config.set(n,o);}}}}function L(r){let t=re(r);function n(o){return {id:o.id,payload:o.event}}return {async append(o){let e={id:t.generateId(),event:o};return t.appendEntry(e),n(e)},async readAll(){return t.readAllEntries().map(n)},async readAfter(o){let e=t.readAllEntries().map(n);if(!o)return {entries:e,newCursor:e.length>0?e[e.length-1].id:null};let s=e.findIndex(a=>a.id===o),u=s===-1?e:e.slice(s+1);return {entries:u,newCursor:u.length>0?u[u.length-1].id:o}}}}function ue(r){let t=ee(r);return {stream(n){let o=t.stream(n);return {async append(e){return o.append(e)},async readAll(){return o.readAll()},async readAfter(e){return o.readAfter(e)},async clear(){o.clear?.();}}},blob(n){let o=t.blob(n);return {async read(e){return o.read(e)},async write(e,s){o.write(e,s);},async exists(e){return o.exists(e)},async remove(e){o.remove(e);},async readBytes(e){return o.readBytes?.(e)??null},async writeBytes(e,s){await o.writeBytes?.(e,s);},async listKeys(e){return o.listKeys(e)},async stat(e){return o.stat?.(e)??null},async renameKey(e,s){let u=o.read(e);return u==null?false:(o.write(s,u),o.remove(e),true)}}},async listStreams(n){return t.listStreams(n)},async listBlobs(n){return t.listBlobs(n)},config:{async get(n){return t.config.get(n)},async set(n,o){t.config.set(n,o);}}}}function ce(r){return String(r||"").trim()}function et(r){return String(r).replace(/[^a-zA-Z0-9_-]/g,"_")}function de(r){return {kind:"local-storage",value:ce(r)}}function R(r){return h(de(r))}function le(r){let t=`boards:${r}`;return {baseRef:de(t),boardRuntimeStoreRef:R(`${t}:runtime-board`),cardStoreRef:R(`${t}:cards`),outputsStoreRef:R(`${t}:runtime-out`),queueStoreRef:R(`${t}:runtime`),scratchStoreRef:R(`${t}:scratch`),chatStoreRef:R(`${t}:chat`),artifactsStoreRef:R(`${t}:files`),fetchedSourcesStoreRef:R(`${t}:sources`)}}function w(r,t){try{let n=v(r);if(n?.kind==="local-storage"&&n.value)return ce(n.value)}catch{}return t}function tt(r,t={}){let n=le(r),o=new Map;return q({boardId:r,kvStorage(e){return D(`${n.baseRef.value}:${e||"root"}`)},kvStorageForRef(e){return D(w(e,`${n.baseRef.value}:root`))},blobStorage(e){return ae(e?`${n.baseRef.value}:${e}`:n.baseRef.value)},blobStorageForRef(e){return ae(w(e,n.baseRef.value))},chatStorageForRef(e){let s=w(e,`${n.baseRef.value}:chat`);return se(u=>L(`${s}:journal:${et(u)}`),D(s))},queueStoreRef:n.queueStoreRef,queueStorageForRef(e,s){let u=`${w(e,`${n.baseRef.value}:runtime`)}:queue:${s}`,a=o.get(u);return a||(a=Ze(),o.set(u,a)),a},scratchStorage(){return ie(`${n.baseRef.value}:scratch`)},scratchStorageForRef(e){return ie(w(e,`${n.baseRef.value}:scratch`))},archiveFactory(){return ue(`${n.baseRef.value}:archive`)},archiveFactoryForRef(e){return ue(w(e,`${n.baseRef.value}:archive`))},journalStorage(){return L(`${n.baseRef.value}:journal`)},journalStorageForRef(e){return L(`${w(e,`${n.baseRef.value}:runtime-board`)}:journal`)},lock:Xe(),resolveBlob:async e=>{let s=e?.kind==="local-storage"?e:null;if(!s?.value)throw new Error(`Unsupported localStorage ref: ${h(e)}`);let u=_(s.value),a=await Promise.resolve(u.read(""));if(a===null)throw new Error(`Blob not found: ${h(e)}`);try{let c=JSON.parse(a);if(c?.__kind==="bytes-b64"&&typeof c.data=="string"){let l=await Promise.resolve(u.readBytes?.(""));if(l)return new TextDecoder().decode(l)}}catch{}return a},hashFn:X,genId:()=>(globalThis.crypto?.randomUUID?.()??`${Date.now()}-${Math.random().toString(36).slice(2,10)}`).replace(/-/g,""),requestProcessAccumulated:t.requestProcessAccumulated,publishBoardChangeNotifications:t.publishBoardChangeNotifications,onWarn:e=>console.warn(`[localstorage-board-adapter:${r}] ${e}`)})}function oo(r,t={}){return {refs:{...le(r),...t.refs??{}},boardAdapter:tt(r,t)}}exports.createLocalStorageBoardAdapter=tt;exports.createLocalStorageBoardRefs=le;exports.createLocalStorageBoardRuntimeBundle=oo;exports.makeLocalStorageRef=de;exports.serializeLocalStorageRef=R;return exports;})({});//# sourceMappingURL=localstorage-storage.js.map
4
4
  //# sourceMappingURL=localstorage-storage.js.map
@@ -1,17 +1,17 @@
1
1
  {
2
- "generatedAt": "2026-06-15T12:30:29.788Z",
2
+ "generatedAt": "2026-06-21T06:09:42.985Z",
3
3
  "algorithm": "sha256",
4
4
  "files": {
5
5
  "browser/server-runtime-controlface.js": {
6
- "sha256": "sha256-xcsZzlY8TF2GnpeAKqVBb2lsF0yI6pZMf/jHuV+kobk=",
7
- "bytes": 190913
6
+ "sha256": "sha256-xZ1UFI31nbFKqIsaEUuprg4QO1tcCj37f08UkcTnt44=",
7
+ "bytes": 190971
8
8
  },
9
9
  "browser/adapters/firestore-storage.js": {
10
10
  "sha256": "sha256-dAP2RFjTHpzcEpvcixRvM139mcUc9Lg1W6T9/CwaRvA=",
11
11
  "bytes": 17562
12
12
  },
13
13
  "browser/adapters/localstorage-storage.js": {
14
- "sha256": "sha256-xqP10b03lw9LGMihnUzirEtECdT5TANdosLs/Mtha24=",
14
+ "sha256": "sha256-ieCOIqBFozOLd2evr2mOe3yRE9w5m4mDYDxwBDFPxow=",
15
15
  "bytes": 22195
16
16
  },
17
17
  "browser/adapters/firebase-storage.js": {
@@ -0,0 +1,2 @@
1
+ var BoardSseState=(function(exports){'use strict';function A(t){if(!t||typeof t!="object")return false;let r=t;return r.kind==="notification-batch"&&Array.isArray(r.notifications)}function w(t){let r=t.category??x(t.kind);return r==="board-output"||r==="card-store"}function B(t){let r=t.category??x(t.kind);return r==="chat-store"||r==="hosted-runtime"}function x(t){switch(t){case "computed_values":case "data_object":case "status":return "board-output";case "card_refreshed":case "card_removed":return "card-store";case "card_chats":case "chat_messages":return "chat-store";case "chat_processing":case "card_watchparty":return "hosted-runtime";case "message_enqueued":return "queue-storage"}}function W(t){if(!t||typeof t!="object")return false;let r=t;return typeof r.kind=="string"&&r.kind.length>0&&r.kind!=="notification-batch"}function D(t){return A(t)?t.notifications:W(t)?[t]:[]}function R(t){return JSON.parse(JSON.stringify(t))}function C(t,r){if(t===r)return true;try{return JSON.stringify(t)===JSON.stringify(r)}catch{return false}}function E(t){return t==="running"||t==="in-progress"?"loading":t==="failed"?"error":"fresh"}function j(t,r,u,s){if(!t||!Array.isArray(r)||r.length===0)return t;let n=t.modelsById,g=t.cardIds,h=t.cardWatchParties||{},m=t.pendingComputedValues||{},_=false,l=false,b={};for(let a of g){let i=n[a],e=i&&i.requires;if(e&&typeof e=="object")for(let o of Object.keys(e))(b[o]=b[o]||[]).push(a);}function y(){_||(n={...n},_=true);}function k(a){if(a.kind!=="card_watchparty"||!a.cardId||!a.channel)return;let i=h[a.cardId]||{},e=Array.isArray(i[a.channel])?i[a.channel]:[],o=e;if(a.clear){if(e.length===0)return;o=[];}else if(a.replace){let c=Number.isFinite(Number(a.sentAtMs))?Number(a.sentAtMs):0,p={payload:a.payload,ts:c};if(e.length===1&&e[0]?.ts===p.ts&&C(e[0]?.payload,p.payload))return;o=[p];}else {let c={payload:a.payload,ts:Number.isFinite(Number(a.sentAtMs))?Number(a.sentAtMs):0};o=[...e,c];}h={...h,[a.cardId]:{...i,[a.channel]:o}},l=true;}for(let a of r)if(!(!a||!a.kind)){if(a.kind==="card_watchparty"){k(a);continue}if(B(a)){if(a.kind==="card_chats"){let i=a.cardId,e=n[i];if(!e)continue;let o=Array.isArray(a.messages)?a.messages:e.card_chats?.messages??[],c=typeof a.receiving=="boolean"?a.receiving:e.card_chats?.receiving??false,p=typeof a.processing=="boolean"?a.processing:e.card_chats?.processing??false,d={messages:o,receiving:c,processing:p};if(C(e.card_chats,d))continue;y(),n[i]={...e,card_chats:d},l=true;}else if(a.kind==="chat_messages"){let i=a.cardId,e=n[i];if(!e)continue;let o=Array.isArray(a.messages)?a.messages:[],c=e.card_chats||{receiving:false,processing:false},p={messages:o,receiving:c.receiving,processing:!!c.processing};if(C(e.card_chats,p))continue;y(),n[i]={...e,card_chats:p},l=true;}else if(a.kind==="chat_processing"){let i=a.cardId,e=n[i];if(!e)continue;let o=e.card_chats||{messages:[],receiving:false},c={messages:o.messages,receiving:o.receiving,processing:a.active===true};if(C(e.card_chats,c))continue;y(),n[i]={...e,card_chats:c},l=true;}continue}if(w(a)){if(a.kind==="computed_values"){let i=a.cardId,e=n[i],o=a.values||{};if(!e){let c=m[i];if(C(c,o))continue;m={...m,[i]:R(o)},l=true;continue}if(C(e.computed_values,o))continue;y(),n[i]={...e,computed_values:o},l=true;}else if(a.kind==="data_object"){let i=a.key,e=a.payload,o=b[i]||[];for(let c of o){let p=n[c];if(!p)continue;let d=p.requires||{};C(d[i],e)||(y(),n[c]={...p,requires:{...d,[i]:e}},l=true);}}else if(a.kind==="card_refreshed"){let i=a.cardId,e=null,o=n[i],c=a.card;if(o&&c&&typeof c=="object"&&!Array.isArray(c)){let d=c,v=d.card_data&&typeof d.card_data=="object"&&!Array.isArray(d.card_data)?d.card_data:o.card_data,P=d.requires&&typeof d.requires=="object"&&!Array.isArray(d.requires)?d.requires:o.requires,q=d.computed_values&&typeof d.computed_values=="object"&&!Array.isArray(d.computed_values)?d.computed_values:o.computed_values,V=d.runtime_state&&typeof d.runtime_state=="object"&&!Array.isArray(d.runtime_state)?d.runtime_state:o.runtime_state;e={...o,card:c,card_data:v,requires:P,computed_values:q,runtime_state:V};}if(!e)try{let d=s();d&&(e=u(d,i));}catch{}if(!e)continue;let p=m[i];if(p!==void 0&&!C(e.computed_values,p)&&(e={...e,computed_values:R(p)}),o&&C(o.card,e.card)&&C(o.card_data,e.card_data)&&C(o.requires,e.requires)&&C(o.computed_values,e.computed_values)&&C(o.runtime_state,e.runtime_state))continue;y(),n[i]=e,g.includes(i)||(g=[...g,i]),Object.prototype.hasOwnProperty.call(m,i)&&(m={...m},delete m[i]),l=true;}else if(a.kind==="card_removed"){let i=a.cardId;if(!n[i])continue;if(y(),delete n[i],g=g.filter(e=>e!==i),Object.prototype.hasOwnProperty.call(h,i)){let e={...h};delete e[i],h=e;}Object.prototype.hasOwnProperty.call(m,i)&&(m={...m},delete m[i]),l=true;}else if(a.kind==="status"){let i=a.status?.cards??[];for(let e of i){let o=e?.name;if(!o||!n[o])continue;let c=n[o],p=E(e.status),d={...c.card_data||{},status:p,lastRun:e.runtime?.last_transition_at??null,...e.error?.message?{error:e.error.message}:{}};e.error?.message||delete d.error;let v={task_status:e.status??null,card_status:p,runtime:e.runtime?R(e.runtime):{},error:e.error?R(e.error):null,blocked_by:Array.isArray(e.blocked_by)?R(e.blocked_by):[],requires_missing:Array.isArray(e.requires_missing)?R(e.requires_missing):[]};C(c.card_data,d)&&C(c.runtime_state,v)||(y(),n[o]={...c,card_data:d,runtime_state:v},l=true);}}}}return l?{payload:t.payload,cardIds:g,modelsById:n,cardWatchParties:h,pendingComputedValues:m}:t}var f=Object.freeze({}),N=Object.freeze([]);function T(t=null){return {boardInfo:{boardId:t,boardInfo:null},boardStatus:{summary:null,cardRuntimesById:f},boardDataObjects:f,boardCardComputedValues:f,cardDefinitionsAndData:f,cardChatViews:f,cardWatchParties:f}}function I(t=null){return t?{messages:t?.messages??N,processing:!!t?.processing,receiving:!!t?.receiving}:{messages:N,processing:false,receiving:false}}function O({chatState:t=null}={}){return {chatState:t??I()}}function S(t){return Array.isArray(t)?t.filter(Boolean).map(String):N}function F(t,r){let u=new Map;for(let s of t?.cards??[]){let n=typeof s?.name=="string"?s.name.trim():"";!n||u.has(n)||u.set(n,{id:n,meta:{title:n},requires:S(s?.requires),provides:S(s?.provides_declared??s?.provides_runtime),source_defs:N,card_data:f});}for(let s of Object.keys(r??f)){let n=typeof s=="string"?s.trim():"";!n||u.has(n)||u.set(n,{id:n,meta:{title:n},requires:N,provides:N,source_defs:N,card_data:f});}return [...u.values()]}function J(t,r){let u={};for(let n of r?.cards??[])u[n.name]=n;let s={};for(let n of t){let g=u[n.id]??{};s[n.id]={status:g.status??"",runtime:g.runtime??f};}return {summary:r?.summary??null,cardRuntimesById:s}}function L(t,r){return Object.fromEntries(t.map(u=>[u.id,r?.[u.id]?.computed_values??f]))}function z(t){return Object.fromEntries(t.map(r=>[r.id,{cardContent:r,cardData:r?.card_data??f}]))}function H(t,r){let u={},s=new Set([...Object.keys(r??f),...Object.keys(t??f)]);for(let n of s){let g=t?.[n]??null;u[n]=O({chatState:I(g)});}return u}function Q(t,r=null){let u=Array.isArray(t.cardDefinitions)&&t.cardDefinitions.length>0?t.cardDefinitions:F(t.statusSnapshot,t.cardRuntimeById),s=z(u);return {boardInfo:{boardId:t.boardId??null,boardInfo:t.boardInfo??null},boardStatus:J(u,t.statusSnapshot),boardDataObjects:t.dataObjectsByToken??f,boardCardComputedValues:L(u,t.cardRuntimeById),cardDefinitionsAndData:s,cardChatViews:H(t.cardChatsByCardId,s),cardWatchParties:r?.cardWatchParties??f}}function M(t,r){let u=t?.cardDefinitionsAndData?.[r]??null,s=t?.boardStatus?.cardRuntimesById?.[r]??null,n=t?.boardCardComputedValues?.[r]??f,g=u?.cardContent??null,h={};for(let m of S(g?.requires))h[m]=Object.prototype.hasOwnProperty.call(t?.boardDataObjects??f,m)?t.boardDataObjects[m]:null;return {id:r,card:g,card_data:u?.cardData??f,requires:h,computed_values:n,runtime_state:{task_status:s?.status??null,runtime:s?.runtime??f},card_chats:t?.cardChatViews?.[r]?.chatState??null}}function Y(t){let r=Object.keys(t?.cardDefinitionsAndData??f),u=Object.fromEntries(r.map(s=>[s,M(t,s)]));return {payload:t,cardIds:r,modelsById:u,cardWatchParties:t?.cardWatchParties??f}}function K(t,r,u,s){let n={},g={},h={},m={};for(let _ of r.cardIds){let l=r.modelsById[_];if(!l)continue;let b=t?.cardDefinitionsAndData?.[_]??null,y=l.card??b?.cardContent??null,k=l.card_data??f;n[_]=b&&b.cardContent===y&&b.cardData===k?b:{cardContent:y,cardData:k};let a=t?.boardCardComputedValues?.[_]??f,i=l.computed_values??f;g[_]=a===i?a:i;let e=t?.cardChatViews?.[_]??null,o=l.card_chats??I();h[_]=e&&e.chatState===o?e:O({chatState:o});let c=t?.boardStatus?.cardRuntimesById?.[_]??{status:"",runtime:f},p=l.runtime_state?.runtime??c.runtime,d=l.runtime_state?.task_status??c.status;m[_]=c.status===d&&c.runtime===p?c:{status:d,runtime:p};}return {...t,boardStatus:{summary:s,cardRuntimesById:m},boardDataObjects:u,boardCardComputedValues:g,cardDefinitionsAndData:n,cardChatViews:h,cardWatchParties:r.cardWatchParties??f}}function rt(t,r){if(Array.isArray(r?.cardDefinitions))return Q(r,t);let u=D(r);if(u.length===0)return t;let s=t??T(),n=s.boardDataObjects??f,g=s.boardStatus?.summary??null,h=[];for(let y of u)y.kind==="data_object"&&y.key?(n===(t?.boardDataObjects??f)&&(n={...n}),n[y.key]=y.payload):y.kind==="status"&&y.status&&"summary"in y.status&&(g=y.status.summary??null),h.push(y);let m=Y(s),_=h.length>0?j(m,h,(y,k)=>M(y,k),()=>s):m,l=K(s,_,n,g);return !(l.boardStatus!==s.boardStatus||l.boardDataObjects!==s.boardDataObjects||l.boardCardComputedValues!==s.boardCardComputedValues||l.cardDefinitionsAndData!==s.cardDefinitionsAndData||l.cardChatViews!==s.cardChatViews||l.cardWatchParties!==s.cardWatchParties)&&t?t:l}exports.EMPTY_ARRAY=N;exports.EMPTY_OBJECT=f;exports.applyBoardSseFrame=rt;exports.createEmptyBoardSnapshot=T;return exports;})({});//# sourceMappingURL=board-sse-state.js.map
2
+ //# sourceMappingURL=board-sse-state.js.map
@@ -3,6 +3,6 @@ data: ${i}
3
3
 
4
4
  `}function o(l){let i=l;try{i.flushHeaders?.();}catch{}try{i.flush?.();}catch{}try{i.socket?.setNoDelay?.(!0);}catch{}try{i.socket?.uncork?.();}catch{}}function a(l,i){let d=t.get(l);if(d&&!(i&&d.res!==i)){t.delete(l);try{e.onSseClientDisconnected?.(l);}catch{}try{d.res.end();}catch{}}}function c(l,i,d){let m=t.get(l);m&&a(l,m.res),t.set(l,{res:i,subscribedChatCardIds:d?.subscribedChatCardIds??new Set,subscribedChannelNames:d?.subscribedChannelNames??new Set,subscribedCardChannels:d?.subscribedCardChannels??new Map});}function u(l,i){let d=t.get(l);if(!d)return;let m=n(i);try{d.res.write(m),o(d.res);}catch{a(l,d.res);}}function f(l){return $e({kind:"notification-batch",notifications:l})}async function k(l,i){let d=await e.buildChatOneShotBatch(l,i);return d.status==="success"?d.data:f([])}async function R(l,i){let d=t.get(l);return d?(d.subscribedChatCardIds.add(i),u(l,await k(i,true)),true):false}function b(l,i){let d=t.get(l);return d?(d.subscribedChatCardIds.delete(i),true):false}function S(l,i,d){let m=t.get(l);if(!m)return false;if(d){let p=m.subscribedCardChannels.get(d)??new Set;return p.add(i),m.subscribedCardChannels.set(d,p),true}return m.subscribedChannelNames.add(i),true}function _(l,i,d){let m=t.get(l);if(!m)return false;if(d){let p=m.subscribedCardChannels.get(d);return p&&(p.delete(i),p.size===0&&m.subscribedCardChannels.delete(d)),true}return m.subscribedChannelNames.delete(i),true}function T(l){return l.kind==="card_chats"||l.kind==="chat_messages"||l.kind==="chat_processing"}function I(l){return l.kind==="card_watchparty"}function A(l,i,d){return l.subscribedChannelNames.has(i)?true:!!l.subscribedCardChannels.get(d)?.has(i)}function g(l){if(!l||l.length===0)return;let i=[],d=new Map,m=new Map;for(let p of l)if(I(p)){let h=`${p.cardId}\0${p.channel}`,w=m.get(h)??[];w.push(p),m.set(h,w);}else if(T(p)){let h=d.get(p.cardId)??[];h.push(p),d.set(p.cardId,h);}else i.push(p);if(i.length>0){let p=f(i);for(let h of t.keys())u(h,p);}for(let[p,h]of d.entries()){let w=f(h);for(let[O,N]of t.entries())N.subscribedChatCardIds.has(p)&&u(O,w);}for(let[p,h]of m.entries()){let w=p.indexOf("\0"),O=w>=0?p.slice(0,w):"",N=w>=0?p.slice(w+1):p,U=f(h);for(let[J,ae]of t.entries())!O||!N||A(ae,N,O)&&u(J,U);}}return {size:()=>t.size,has:l=>t.has(l),get:l=>t.get(l),buildFrame:n,flushTransport:o,register:c,disconnect:a,writeFrame:u,subscribeChat:R,unsubscribeChat:b,subscribeChannel:S,unsubscribeChannel:_,broadcastNotificationBatch:g}}function Gr(e,t){if(e?.status==="success")return Object.prototype.hasOwnProperty.call(e,"data")?e.data:void 0;throw e?.status==="fail"||e?.status==="error"?Object.assign(new Error(e.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function Wr(e,t){return Gr(await e,t)}function zr(e){let t=me(e,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let r=t.split(".");if(!(r.length>=2&&r.every(o=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(o))))throw Object.assign(new Error("MCP tool requires a card private key with at least two identifier segments (e.g. chat.foundry_thread_id)"),{statusCode:400});return t}function Yr(e,t){let r=e.__private;for(let n of t.split(".")){if(!r||typeof r!="object"||Array.isArray(r)||!Object.prototype.hasOwnProperty.call(r,n))return {exists:false,value:null};r=r[n];}return {exists:true,value:r}}function io(e){let{boardId:t,bootstrapBoard:r,sseHub:n,onChannelSubscribed:o,onChannelUnsubscribed:a,getMcpFacade:c,getMcpCardStoreFacade:u}=e;function f(i){let d=me(i,"board_id");if(!d)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(d!==t)throw Object.assign(new Error(`Unknown board_id: ${d}`),{statusCode:400})}function k(i){let d=me(i,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function R(i){f(i);let d=k(i),m=me(i,"channel_name"),p=me(i,"card_id")||void 0;if(!m)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:m,...p?{cardId:p}:{}}}function b(i){f(i);let d=me(i,"card_id");if(!d)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:d}}async function S(i){await r();let{cardId:d}=b(i),m=k(i);if(!await n.subscribeChat(m,d))throw Object.assign(new Error(`SSE client not connected: ${m}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:m,subscribed:true}}}async function _(i){await r();let{cardId:d}=b(i),m=k(i);if(!n.unsubscribeChat(m,d))throw Object.assign(new Error(`SSE client not connected: ${m}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:m,subscribed:false}}}async function T(i,d){await r();let{clientId:m,channelName:p,cardId:h}=R(i);if(!n.has(m))throw Object.assign(new Error(`SSE client not connected: ${m}`),{statusCode:404});return d?(n.subscribeChannel(m,p,h),o?.(m,p,h?{cardId:h}:{})):(n.unsubscribeChannel(m,p,h),a?.(m,p,h?{cardId:h}:{})),{status:"success",data:{boardId:t,clientId:m,channelName:p,subscribed:d,...h?{cardId:h}:{}}}}async function I(i,d){let{cardId:m}=b(i);return await c().setChatProcessing({cardId:m,active:d}),{status:"success",data:{boardId:t,cardId:m,active:d}}}async function A(i){let{cardId:d}=b(i),m=await c().getChatProcessing({cardId:d});return {status:"success",data:{boardId:t,cardId:d,active:m.active}}}async function g(i){let{cardId:d}=b(i),m=zr(i);if(!Object.prototype.hasOwnProperty.call(i,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(m.split(".").includes("visible_controlplane_only")){let p=await Wr(u().get({params:{id:d}}),"cardStore.get"),h=Array.isArray(p.cards)&&p.cards.length>0&&typeof p.cards[0]=="object"&&!Array.isArray(p.cards[0])?p.cards[0]:null,w=h?Yr(h,"visible_controlplane_only").value:void 0;if(i.value!==w)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:d,key:m}}}return Gr(await u().patch({params:{id:d,path:`__private.${m}`},body:{value:i.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:d,key:m}}}async function l(i){let{cardId:d}=b(i),m=zr(i),p=await Wr(u().get({params:{id:d}}),"cardStore.get"),h=Array.isArray(p.cards)&&p.cards.length>0&&p.cards[0]&&typeof p.cards[0]=="object"&&!Array.isArray(p.cards[0])?p.cards[0]:null;if(!h)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let w=Yr(h,m);return {status:"success",data:{boardId:t,cardId:d,key:m,exists:w.exists,value:w.value}}}return {requireCardArgs:b,subscribeChat:S,unsubscribeChat:_,watchChannel:T,setChatProcessing:I,getChatProcessing:A,setCardMeta:g,getCardMeta:l}}function uo(e){let{boardId:t,boardContexts:r,readChatRecords:n,getChatProcessing:o}=e,a=Number.isInteger(e.chatBootstrapTailTurns)&&e.chatBootstrapTailTurns>0?e.chatBootstrapTailTurns:1;function c(_){return {role:String(_.role||"system"),text:String(_.text||""),files:Array.isArray(_.files)?_.files:[],...typeof _.turn=="string"&&_.turn?{turn:_.turn}:{}}}function u(_){if(_.length===0)return null;if(_.length===1)return _[0];let T=[],I=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],A={};for(let l of I)A[l]=0;for(let l of _){let i=l,d=Array.isArray(i.cards)?i.cards:[];T.push(...d);for(let m of I)A[m]+=Number(i?.summary?.[m]||0);}let g=_[0];return {...g,cards:T,summary:{...g.summary||{},card_count:T.length,...A}}}async function f(){let _=[];for(let T of r)try{let I=await T.boardOps.buildSseOneShotPayload({});I.status==="success"&&I.data&&_.push(I.data);}catch{}return _}async function k(){let T=(await f()).map(I=>I.statusSnapshot).filter(Boolean);if(T.length===0){let I=r.map(A=>A.notification.status).filter(Boolean);return u(I)}return u(T)}async function R(){let _={},T=await f();for(let I of T)Object.assign(_,I.cardRuntimeById||{});if(Object.keys(_).length>0)return _;for(let I of r)for(let[A,g]of Object.entries(I.notification.computedValues)){let l=I.notification.cards[A];_[A]={schema_version:"v1",card_id:A,card_data:l?.card_data??{},computed_values:g??{}};}return _}async function b(){let _={},T=await f();for(let I of T)Object.assign(_,I.dataObjectsByToken||{});if(Object.keys(_).length===0)for(let I of r)Object.assign(_,I.notification.dataObjects||{});return _}async function S(){let _=await f(),T=_.flatMap(l=>Array.isArray(l.cardDefinitions)?l.cardDefinitions:[]),I={},A={};for(let l of _)Object.assign(I,l.dataObjectsByToken||{}),Object.assign(A,l.cardRuntimeById||{});let g={};for(let l of T){if(!l?.id)continue;let i=l.id;try{let d=await n(i,{tailTurns:a}),m=await o(i);(d.length>0||m)&&(g[i]={messages:d.map(p=>c(p)),receiving:!1,processing:m});}catch{}}return {boardId:t,cardDefinitions:T,statusSnapshot:await k(),dataObjectsByToken:I,cardRuntimeById:A,cardChatsByCardId:g}}return {readStatusSnapshot:k,readCardRuntimeArtifacts:R,readDataObjectsByToken:b,buildPublishedRuntimePayload:S}}function ba(e){let t=String(e||"").trim();if(!t)return "upload.bin";let r=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (r>=0?t.slice(r+1):t)||"upload.bin"}function co(e){let{safeCardId:t,artifactsStores:r,cardFileMetadataStore:n,readCardFromStore:o,updateCardLocalOnly:a,writeChatRecord:c}=e;async function u(R){let b=[];try{let S=await o(R);if(!S)return b;let _=n().read(S.card_data&&typeof S.card_data=="object"?S.card_data:null);for(let T of _)b.push(String(T.stored_name??""));}catch{}return b}async function f(R,b,S,_){let T=t(R),I=r(R),A=ba(b),g=await u(R),i=`${String(g.length+1).padStart(3,"0")}-${A}`.slice(-36);if(!I.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${R}`),{statusCode:500});return await I.files.putBytes(`${T}/${i}`,new Uint8Array(_),S||"application/octet-stream"),{name:A,stored_name:i,size:_.length,mime_type:S||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function k(R,b,S,_,T){if(!_.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let I=T?.inChat===true,A=await f(R,b,S,_),g=null;if(await a(R,l=>{let i=new Date().toISOString(),d=l.card_data&&typeof l.card_data=="object"?l.card_data:{};l.card_data=d;let m=n().normalizeIncoming([{name:A.name,stored_name:A.stored_name,size:A.size,mime_type:A.mime_type,uploaded_at:A.uploaded_at||i,chat:I}],i);return g=n().merge(d,m).findIndex(h=>h.stored_name===A.stored_name),l}),I&&T?.suppressChatRecordWrite!==true){let l=typeof g=="number"&&g>=0?` #${g}`:"";await c(R,"system",`file uploaded: ${A.name} as ${A.stored_name}${l}`,[],T?.turnId??"");}return {ok:true,file:{...A,...typeof g=="number"&&g>=0?{file_idx:g}:{},chat:I},...typeof g=="number"&&g>=0?{file_idx:g}:{}}}return {uploadCardFile:k,readCardStoredFileNames:u}}function lo(e){return {"discover.source-kinds":()=>e.discoverSourceKinds(),"inspect.board-runtime-status":()=>e.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>e.inspectCardDefinitionAndRuntime({cardId:me(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let r=ut(t,"tail_turns"),n=ut(t,"tail"),o=me(t,"turn_id"),a=t.all_turns===true,c=me(t,"tail_turns_before_id");return e.inspectChatMessagesOnCards({cardId:me(t,"card_id"),...r!==void 0?{lastUserTurns:r}:{},...n!==void 0?{tail:n}:{},...o?{turnId:o}:{},...a?{allTurns:true}:{},...c?{tailTurnsBeforeId:c}:{}})},"inspect.file-contents":t=>e.inspectFileContents({cardId:me(t,"card_id"),fileIdx:Number(ut(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>e.preflightValidateCandidateCardDefinition({candidateCardContent:pt(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>e.preflightMaterializeCandidateCard({candidateCardContent:pt(t,"candidate_card_content","candidate_card_content"),mockRequires:pt(t,"mock_requires","mock_requires"),mockFetchedSources:pt(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>e.preflightProbeSingleSourceInCandidateCard({candidateCardContent:pt(t,"candidate_card_content","candidate_card_content"),mockProjections:ct(t,"mock_projections"),sourceIdx:Qt(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>e.preflightRunSingleSourceInCandidateCard({candidateCardContent:pt(t,"candidate_card_content","candidate_card_content"),mockProjections:ct(t,"mock_projections"),sourceIdx:Qt(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>e.preflightRunSingleSourceInLiveCard({cardId:me(t,"card_id"),sourceIdx:Qt(t,"source_idx","source_idx"),mockRequires:pt(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>e.preflightRunOneCycleWithCandidateCard({candidateCardContent:pt(t,"candidate_card_content","candidate_card_content"),mockRequires:ct(t,"mock_requires")}),"manage.read-card":t=>e.manageReadCard({cardId:me(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let r=me(t,"turn_id");if(!r)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return e.manageAddChatEntryAndAnyAttachments({cardId:me(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...r?{turn:r}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"stage-ai-failure-message":t=>{let r=me(t,"turn_id"),n=me(t,"failure");if(!r)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!n)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return e.manageAddChatEntryAndAnyAttachments({cardId:me(t,"card_id"),role:"system",text:n,turn:r})},"manage.upsert-card":t=>e.manageUpsertCard({cardId:me(t,"card_id"),candidateCardContent:ct(t,"candidate_card_content")}),"manage.remove-card":t=>e.manageRemoveCard({cardId:me(t,"card_id")})}}function fo(e){return {"webhook.process-accumulated":()=>e.webhookProcessAccumulated(),"webhook.source-fetch-done":t=>e.webhookSourceFetchDone({token:me(t,"token"),ref:me(t,"ref")}),"webhook.source-fetch-failed":t=>e.webhookSourceFetchFailed({token:me(t,"token"),reason:me(t,"reason")})}}function mo(e){let{boardId:t,uploadCardFile:r,getMcpFacade:n,controlplane:o}=e;function a(u,f){let k=me(u,"board_id");if(!k)throw Object.assign(new Error(`${f} requires board_id`),{statusCode:400});if(k!==t)throw Object.assign(new Error(`Unknown board_id: ${k}`),{statusCode:400})}function c(u,f){let{cardId:k}=o.requireCardArgs(u),R=me(u,"turn_id");return a(u,f),n().manageAddChatAttachment({cardId:k,role:me(u,"role")||"user",...R?{turn:R}:{},files:[{file_name:me(u,"file_name"),content_type:me(u,"content_type")||"application/octet-stream",...typeof u.text=="string"?{text:u.text}:{},...typeof u.base64=="string"?{base64:u.base64}:{},...Array.isArray(u.bytes)?{bytes:u.bytes}:{}}]})}return {"list-runtime-cards":u=>(a(u,"list-runtime-cards"),n().listRuntimeCards()),"sse.subscribe-chat":u=>o.subscribeChat(u),"sse.unsubscribe-chat":u=>o.unsubscribeChat(u),"sse.watch-channel":u=>o.watchChannel(u,true),"sse.unwatch-channel":u=>o.watchChannel(u,false),"getstate.is-chat-processing":u=>o.getChatProcessing(u),"setstate.chat-processing-started":u=>o.setChatProcessing(u,true),"setstate.chat-processing-done":u=>o.setChatProcessing(u,false),"getstate.card-private":u=>o.getCardMeta(u),"setstate.card-private":u=>o.setCardMeta(u),"manage.upload-card-file":u=>{let f=me(u,"card_id"),k=me(u,"file_name"),R=me(u,"content_type")||"application/octet-stream",b=an(u);if(a(u,"manage.upload-card-file"),!f)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!k)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return r(f,k,R,b,{inChat:false})},"manage.add-chat-attachment":u=>c(u,"manage.add-chat-attachment"),"manage.add-chat-attachement":u=>c(u,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":u=>{let{cardId:f}=o.requireCardArgs(u),k=me(u,"role")||"user",R=me(u,"turn_id");return a(u,"manage.add-chat-entry-and-any-attachments"),n().manageAddChatEntryAndAnyAttachments({cardId:f,role:k,...typeof u.text=="string"?{text:u.text}:{},...R?{turn:R}:{},...Array.isArray(u.files)?{files:u.files}:{}})},"manage.patch-card":u=>{let{cardId:f}=o.requireCardArgs(u);return a(u,"manage.patch-card"),n().managePatchCard({cardId:f,patch:ct(u,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":u=>{let{cardId:f}=o.requireCardArgs(u);return a(u,"manage.upsert-card"),n().manageUpsertCard({cardId:f,candidateCardContent:ct(u,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":u=>{let{cardId:f}=o.requireCardArgs(u);return a(u,"manage.remove-card"),n().manageRemoveCard({cardId:f},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async u=>{let{cardId:f}=o.requireCardArgs(u);return {status:"success",data:{cards:await n().adminReadCard({cardId:f})}}},"manage.admin-upsert-card":u=>{let f=me(u,"board_id"),k=me(u,"card_id");if(!f)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!k)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(f!==t)throw Object.assign(new Error(`Unknown board_id: ${f}`),{statusCode:400});return n().adminUpsertCard({cardId:k,candidateCardContent:ct(u,"candidate_card_content")})}}}function at(e,t){if(e?.status==="success")return Object.prototype.hasOwnProperty.call(e,"data")?e.data:void 0;throw e?.status==="fail"||e?.status==="error"?new Error(e.error||`${t} failed`):new Error(`${t} returned an unexpected response`)}function po(e,t){if(e?.status==="success"&&Object.prototype.hasOwnProperty.call(e,"data"))return e.data;throw e?.status==="success"?new Error(`${t} returned success without data`):e?.status==="fail"||e?.status==="error"?new Error(e.error||`${t} failed`):new Error(`${t} returned an unexpected response`)}function z(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:{}}function Fe(e){return Array.isArray(e)?e:[]}function Zr(e,t){if(typeof t!="string"||t.length===0)return;let r=e,n=t;n.startsWith("fetched_sources.")&&(r=z(e).fetched_sources,n=n.slice(16));for(let o of n.split(".")){if(r==null||typeof r!="object")return;r=r[o];}return r}function Xr(e,t){let r=z(e.view);return {elements:Fe(r.elements).map((o,a)=>{let c=z(o),u=z(c.data),f=typeof c.visible=="string"?!!Zr(t,c.visible):true,k=typeof u.bind=="string"?u.bind:void 0,R=typeof u.maxRows=="number"?u.maxRows:void 0,b=k?Zr(t,k):void 0,S={id:typeof c.id=="string"&&c.id?c.id:`element-${a}`,kind:c.kind,label:c.label,visible:f};return b!==void 0&&(S.resolved=Array.isArray(b)&&typeof R=="number"?b.slice(0,R):b),S})}}function go(e,t){let r=typeof e.id=="string"&&e.id?e.id:"card",n=Fe(e.provides),o=n.length>0?n:[{bindTo:r,ref:"card_data"}],a={};for(let c of o){let u=z(c),f=typeof u.bindTo=="string"?u.bindTo:"",k=typeof u.ref=="string"?u.ref:"";if(!f||!k)continue;let R=Zr(t,k);R!==void 0&&(a[f]=R);}return a}function Sa(e){if(typeof e!="string"||!e.trim())return null;let t=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(e.trim());if(!t)return null;let r=Number.parseInt(t[2],10);return !Number.isInteger(r)||r<0?null:r}function wa(e){return {"card-content":e}}function br(e){let t={...e};return delete t.__private,t}function va(e,t){return Object.prototype.hasOwnProperty.call(e,t)}function Aa(e){return typeof structuredClone=="function"?structuredClone(e):JSON.parse(JSON.stringify(e))}function xa(e,t){let r=Aa(e);if(!t||Object.keys(t).length===0)return r;function n(o,a,c){let u=String(a||"").split(".").filter(Boolean);if(!u.length)return;let f=o;for(let k=0;k<u.length-1;k+=1){let R=u[k];(!f[R]||typeof f[R]!="object")&&(f[R]={}),f=f[R];}f[u[u.length-1]]=c;}if(t.fieldValues!==void 0&&t.fieldValues!==null){let o=null,a=z(r.view),c=Fe(a.elements);for(let u of c){let f=z(z(u).data);if(typeof f.writeTo=="string"&&f.writeTo){o=f.writeTo;break}}return o?n(r,o,t.fieldValues):typeof t.fieldValues=="object"&&!Array.isArray(t.fieldValues)&&(r.card_data={...z(r.card_data),...t.fieldValues}),r}if(Array.isArray(t._stagedFiles)&&t._stagedFiles.length>0)return r;for(let[o,a]of Object.entries(t))o!=="_stagedFiles"&&(a!==null&&typeof a=="object"&&!Array.isArray(a)&&r[o]!==null&&typeof r[o]=="object"&&!Array.isArray(r[o])?r[o]={...r[o],...a}:r[o]=a);return r}function Sr(e){return z(e.__private).visible_controlplane_only===true}async function Pt(e,t){let r=await ze(e.get({params:{id:t}}),"cardStore.get"),n=Array.isArray(r?.cards)?r.cards:[];if(n.length===0)throw new Error(`Card "${t}" not found`);return n[0]}function yo(e){let{board:t,nonCore:r,cardStore:n,chatStore:o,processAccumulated:a,sourceFetchDone:c,sourceFetchFailed:u,uploadCardFile:f,buildFileDownloadUrl:k,readFetchedSourceJsonByRef:R}=e;function b(y,P){if(typeof y=="function")return y;throw new Error(`${P} is not configured for this MCP facade`)}async function S(){let y=await ze(n.get({}),"cardStore.get");return Array.isArray(y.cards)?y.cards.map(P=>z(P)).filter(P=>!Sr(P)):[]}function _(y){if(Array.isArray(y.bytes))return new Uint8Array(y.bytes.map(P=>Math.max(0,Math.min(255,Number(P)||0))));if(typeof y.text=="string")return new TextEncoder().encode(y.text);if(typeof y.base64=="string"){let P=String(y.base64).replace(/-/g,"+").replace(/_/g,"/"),q=P+"=".repeat((4-P.length%4)%4),D=atob(q);return Uint8Array.from(D,M=>M.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function T(){let y=z(await ze(r.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:y.version,commonSourceFields:z(y.commonSourceDefFields),sourceKinds:z(y.sourceKinds)}}async function I(){let y=z(await ze(t.status({}),"status")),P=z(y.summary),q=Fe(y.cards),D=await ze(n.get({}),"cardStore.get"),M=new Set((Array.isArray(D.cards)?D.cards.map(z):[]).filter(Sr).map(se=>typeof se.id=="string"?se.id:"").filter(Boolean)),$=q.filter(se=>!M.has(String(z(se).name??"")));return {meta:z(y.meta),summary:{card_count:typeof P.card_count=="number"?P.card_count:0,completed:typeof P.completed=="number"?P.completed:0,eligible:typeof P.eligible=="number"?P.eligible:0,pending:typeof P.pending=="number"?P.pending:0,blocked:typeof P.blocked=="number"?P.blocked:0,in_progress:typeof P.in_progress=="number"?P.in_progress:0,failed:typeof P.failed=="number"?P.failed:0,unresolved:typeof P.unresolved=="number"?P.unresolved:0},cards:$.map(se=>{let ce=z(se);return {"card-id":typeof ce.name=="string"?ce.name:null,status:ce.status??null,error:ce.error??null,requires:Fe(ce.requires),requires_satisfied:Fe(ce.requires_satisfied),requires_missing:Fe(ce.requires_missing),provides_declared:Fe(ce.provides_declared),provides_runtime:Fe(ce.provides_runtime)}})}}async function A(y){let P=String(y.cardId||"").trim();if(!P)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let q=z(await ze(t.status({}),"status")),M=Fe(q.cards).map(z).find(he=>he.name===P);if(!M)throw new Error(`card "${P}" not found in board status`);let $=z(await Pt(n,P)),se=br($),ce=Fe(M.requires_satisfied).filter(he=>typeof he=="string"&&!!he),be=Fe(M.provides_runtime).filter(he=>typeof he=="string"&&!!he),Te=Object.fromEntries(await Promise.all(ce.map(async he=>[he,await ze(t.getOutputsDataObject({params:{key:he}}),`getOutputsDataObject(${he})`)]))),_e=Object.fromEntries(await Promise.all(be.map(async he=>[he,await ze(t.getOutputsDataObject({params:{key:he}}),`getOutputsDataObject(${he})`)]))),pe=z(await ze(t.getOutputsComputedValues({params:{key:P}}),"getOutputsComputedValues")),ke=await ze(t.getOutputsFetchedSources({params:{key:P}}),"getOutputsFetchedSources"),Ve=Fe($.source_defs).map(z),Se={};for(let he of Ve)typeof he.bindTo=="string"&&typeof he.outputFile=="string"&&(Se[he.outputFile]=he.bindTo);let Ke={};for(let[he,et]of Object.entries(ke)){let Je=Se[he]??he;if(!R||typeof et!="string"){Ke[Je]=null;continue}try{Ke[Je]=R({cardId:P,ref:et});}catch{Ke[Je]=null;}}let qe={card_data:z($.card_data),requires:Te,fetched_sources:Ke,computed_values:pe};return {cardId:P,card_status_in_board:M,card_definition_and_static_data:se,refs_for_fetched_source_files:ke,runtime_data:{requires:Te,provides:_e,computed_values:pe,rendered_view:Xr($,qe)}}}async function g(y){let P=String(y.cardId||"").trim();if(!P)throw new Error("inspectChatMessagesOnCards requires cardId");let q=typeof y.turnId=="string"?y.turnId:"",D=y.allTurns===true,M=typeof y.tailTurnsBeforeId=="string"?y.tailTurnsBeforeId:"",$=D?void 0:y.lastUserTurns??(q?void 0:1),se=y.tail,ce={...$===void 0?{}:{tailTurns:$},...q?{turnId:q}:{},...D?{allTurns:true}:{},...M?{tailTurnsBeforeId:M}:{}},be=Object.keys(ce).length>0?{params:{cardId:P},body:ce}:{params:{cardId:P}},Te=at(await o.readAll(be),"chatStore.readAll"),_e=z(await Pt(n,P)),pe=Fe(z(_e.card_data).files).map((Se,Ke)=>({idx:Ke,stored_name:z(Se).stored_name})).filter(Se=>typeof Se.stored_name=="string"&&Se.stored_name.length>0),Ve=(Array.isArray(Te.records)?Te.records:[]).map(Se=>{let qe=z(Se.payload),he={...Se},et=typeof Se?.role=="string"?Se.role:typeof qe.role=="string"?String(qe.role):"",Je=typeof Se?.text=="string"?Se.text:typeof qe.text=="string"?String(qe.text):"";if(et==="system"){let tt=Sa(Je);if(tt!==null&&pe.some(j=>j.idx===tt)){let j=`Retrieve using inspect-file-contents --card-id ${P} --file-idx ${tt}`;he.retrieval_hint=j,Object.keys(qe).length>0&&typeof Se.role!="string"&&(he.payload={...qe,retrieval_hint:j});}}return he});return {cardId:P,messages:typeof se=="number"&&se>=0?Ve.slice(-se):Ve}}async function l(y){let P=String(y.cardId||"").trim(),q=Number(y.fileIdx);if(!P)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(q)||q<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let D=z(await Pt(n,P)),M=Fe(z(D.card_data).files).map(z);if(q>=M.length)throw new Error(`attachment index ${q} is out of range for card "${P}"`);let $=M[q],se=typeof $.stored_name=="string"?$.stored_name:null;return {cardId:P,fileIdx:q,downloadUrl:k({cardId:P,fileIdx:q,storedName:se}),...typeof $.name=="string"?{name:$.name}:{},...typeof $.stored_name=="string"?{stored_name:$.stored_name}:{},...typeof $.mime_type=="string"?{mime_type:$.mime_type}:{},...typeof $.size=="number"?{size:$.size}:{},...typeof $.uploaded_at=="string"?{uploaded_at:$.uploaded_at}:{}}}async function i(y){return await r.validateCardPreflight({body:wa(y.candidateCardContent)})}function d(y){if(!y.mockRequires||typeof y.mockRequires!="object"||Array.isArray(y.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!y.mockFetchedSources||typeof y.mockFetchedSources!="object"||Array.isArray(y.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let P=r.evalCardCompute({body:{"card-content":y.candidateCardContent,"mock-requires":y.mockRequires,"mock-fetched-sources":y.mockFetchedSources}});if(P.status!=="success")return P;let q=z(po(P,"evalCardCompute")),D=z(y.candidateCardContent),M={card_data:z(D.card_data),requires:z(y.mockRequires),fetched_sources:z(y.mockFetchedSources),computed_values:z(q.computed_values)};return {status:"success",data:{cardId:typeof q.cardId=="string"?q.cardId:typeof D.id=="string"?D.id:"(unknown)",ok:q.ok===true,computed_values:z(q.computed_values),errors:Fe(q.errors).map($=>{let se=z($);return {bindTo:typeof se.bindTo=="string"?se.bindTo:"",error:typeof se.error=="string"?se.error:""}}),provides_outputs:go(D,M),rendered_view:Xr(D,M)}}}async function m(y){return await r.probeSourcePreflight({params:{sourceIdx:y.sourceIdx},body:{"card-content":y.candidateCardContent,"mock-projections":y.mockProjections}})}async function p(y){return await r.runSourcePreflight({params:{sourceIdx:y.sourceIdx},body:{"card-content":y.candidateCardContent,"mock-projections":y.mockProjections}})}async function h(y){let P=String(y.cardId||"").trim();if(!P)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!y.mockRequires||typeof y.mockRequires!="object"||Array.isArray(y.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let q=z(await Pt(n,P)),D=Fe(q.source_defs).filter($=>!!$&&typeof $=="object"&&!Array.isArray($)),M={};if(y.sourceIdx>=0&&y.sourceIdx<D.length){let $=D[y.sourceIdx],se=We.enrichSourcesSync([$],{card_data:z(q.card_data),requires:y.mockRequires});Array.isArray(se)&&se.length>0&&(M=z(se[0]._projections));}return await r.runSourcePreflight({params:{sourceIdx:y.sourceIdx},body:{"card-content":q,"mock-requires":y.mockRequires,"mock-projections":M}})}async function w(y){let P=z(await ze(r.simulateCardCycle({body:{"card-content":y.candidateCardContent,"mock-requires":y.mockRequires}}),"simulateCardCycle")),q=z(y.candidateCardContent),D=z(P.validation),M=Fe(P.source_probes),$=Fe(P.projection_errors),se=z(P.fetched_sources),ce=Fe(P.compute_errors),be=z(P.computed_values),Te={card_data:z(q.card_data),requires:y.mockRequires,fetched_sources:se,computed_values:be},_e=[];for(let pe of Fe(D.issues))typeof pe=="string"&&pe&&_e.push(pe);for(let pe of M){let ke=z(pe),Ve=typeof ke.bindTo=="string"?ke.bindTo:"source",Se=typeof ke.error=="string"?ke.error:"";Se&&_e.push(`${Ve}: ${Se}`);}for(let pe of $){let ke=z(pe),Ve=typeof ke.bindTo=="string"?ke.bindTo:"source",Se=typeof ke.key=="string"?ke.key:"projection",Ke=typeof ke.error=="string"?ke.error:"projection failed";_e.push(`${Ve}.${Se}: ${Ke}`);}for(let pe of ce){let ke=z(pe),Ve=typeof ke.bindTo=="string"?ke.bindTo:"compute",Se=typeof ke.error=="string"?ke.error:"compute failed";_e.push(`${Ve}: ${Se}`);}return {status:"success",data:{cardId:typeof P.cardId=="string"?P.cardId:"(unknown)",ok:P.ok===true,issues:_e,provides_outputs:go(q,Te),rendered_view:Xr(q,Te)}}}async function O(y){let P=String(y.cardId||"").trim();if(!P)throw new Error("manageReadCard requires cardId");let q=await ze(n.get({params:{id:P}}),"cardStore.get");return (Array.isArray(q.cards)?q.cards.map(z):[]).map(M=>br(M))}async function N(y){let P=await Promise.all(Fe(y.files).map(async q=>{let D=z(q),M=String(D.file_name??D.fileName??D.name??"").trim(),$=String(D.content_type??D.contentType??"application/octet-stream");if(!M)throw new Error("file entry requires file_name");return await f({cardId:y.cardId,fileName:M,contentType:$,bytes:_(D),suppressChatRecordWrite:true})}));for(let[q,D]of P.entries()){let M=z(D.file),$=typeof D.file_idx=="number"&&Number.isInteger(D.file_idx)&&D.file_idx>=0?D.file_idx:q,se=y.role==="assistant"?`AI generated: ${String(M.name||"")} as ${String(M.stored_name||"")} #${$}`:`file uploaded: ${String(M.name||"")} as ${String(M.stored_name||"")} #${$}`;at(await o.append({params:{cardId:y.cardId},body:{role:"system",text:se,files:[],turn:y.turn}}),"chatStore.append(system attachment message)");}return P.map(q=>q.file)}async function U(y){let P=String(y.cardId||"").trim(),q=String(y.role||"user").trim()||"user",D=typeof y.turn=="string"?y.turn:"";if(!P)throw new Error("manageAddChatAttachment requires cardId");let M=await N({cardId:P,role:q,turn:D,files:y.files});return {status:"success",data:{cardId:P,turn:D,files:M}}}async function J(y){let P=String(y.cardId||"").trim(),q=String(y.role||"").trim(),D=typeof y.text=="string"?y.text:"",M=typeof y.turn=="string"?y.turn:"";if(!P)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!q)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(q==="assistant"&&M){let ce=at(await o.readAll({params:{cardId:P},body:{turnId:M}}),"chatStore.readAll(existing turn messages)"),be=Array.isArray(ce.records)?ce.records.find(Te=>Te.role==="assistant"&&String(Te.turn||"")===M):void 0;if(be)return {status:"success",data:{cardId:P,id:String(be.id),role:q,turn:M,files:Array.isArray(be.files)?be.files:[]}}}let $=await N({cardId:P,role:q,turn:M,files:y.files}),se=at(await o.append({params:{cardId:P},body:{role:q,text:D,files:$,turn:M}}),"chatStore.append");return {status:"success",data:{cardId:P,id:String(se.id),role:q,turn:M,files:$}}}async function ae(y,P={}){let q=String(y.cardId||"").trim(),D=z(y.patch);if(!q)throw new Error("managePatchCard requires cardId");let M=await O({cardId:q}),$=z(M[0]),se=xa($,D);return Q({cardId:q,candidateCardContent:se},P)}async function Q(y,P={}){let q=String(y.cardId||"").trim(),D=z(y.candidateCardContent),M=br(D);if(!q)throw new Error("manageUpsertCard requires cardId");if(typeof M.id!="string"||!M.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(M.id!==q)throw new Error(`candidateCardContent.id must match cardId (${q})`);let $=null;try{$=await i({candidateCardContent:M});}catch(pe){let ke=pe instanceof Error?pe.message:String(pe);if(!/non-core adapter is not configured/i.test(ke))throw pe;$=null;}if($!==null){let pe=z($),ke=z(pe.data);if(pe.status!=="success"||ke.isValid!==true)return {status:"fail",step:"validate",validation:$}}let se=null;try{se=await Pt(n,q);}catch{se=null;}let ce=se?z(se):null;if(ce&&Sr(ce)&&!P.allowControlplaneOnlyCards)throw Object.assign(new Error(`Card "${q}" not found`),{statusCode:404});let be={...M,...ce&&va(ce,"__private")?{__private:ce.__private}:{}},Te=await n.set({body:be});at(Te,"cardStore.set");let _e;try{_e=await t.upsertCard({params:{cardId:q,restart:!0}}),at(_e,"upsertCard");}catch(pe){try{se&&await n.set({body:se});}catch{}throw pe}return {status:"success",data:{validation:$,card_saved:null,board_result:_e}}}async function te(y,P={}){let q=String(y.cardId||"").trim();if(!q)throw new Error("manageRemoveCard requires cardId");if(!P.allowControlplaneOnlyCards){let $=await ze(n.get({params:{id:q}}),"cardStore.get");if((Array.isArray($.cards)?$.cards.map(z):[]).some(Sr))throw Object.assign(new Error(`Card "${q}" not found`),{statusCode:404})}let D=await t.removeCard({params:{id:q}});at(D,"removeCard");let M=await n.del({params:{id:q}});return at(M,"cardStore.del"),{status:"success",data:{board_result:D,store_result:M}}}async function ue(y){let P=String(y.cardId||"").trim();if(!P)throw new Error("adminReadCard requires cardId");let q=await ze(n.get({params:{id:P}}),"cardStore.get");return Array.isArray(q.cards)?q.cards.map(D=>z(D)):[]}async function G(y){let P=String(y.cardId||"").trim(),q=z(y.candidateCardContent),D=br(q);if(!P)throw new Error("adminUpsertCard requires cardId");if(typeof D.id!="string"||!D.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(D.id!==P)throw new Error(`candidateCardContent.id must match cardId (${P})`);let M=await i({candidateCardContent:D}),$=z(M),se=z($.data);if($.status!=="success"||se.isValid!==true)return {status:"fail",step:"validate",validation:M};let ce=null;try{ce=await Pt(n,P);}catch{ce=null;}let be=ce?z(z(ce).__private):{},Te={...D,__private:{...be,visible_controlplane_only:true}},_e=await n.set({body:Te});at(_e,"cardStore.set");let pe;try{pe=await t.upsertCard({params:{cardId:P,restart:!0}}),at(pe,"upsertCard");}catch(ke){try{ce&&await n.set({body:ce});}catch{}throw ke}return {status:"success",data:{validation:M,card_saved:null,board_result:pe}}}async function Z(y){let P=String(y.cardId||"").trim();if(!P)throw new Error("getChatProcessing requires cardId");let q=po(await o.isProcessing({params:{cardId:P}}),"chatStore.isProcessing");return {cardId:P,active:!!q.active}}async function re(y){let P=String(y.cardId||"").trim();if(!P)throw new Error("setChatProcessing requires cardId");if(typeof y.active!="boolean")throw new Error("setChatProcessing requires boolean active");return at(await o.setProcessing({params:{cardId:P},body:{active:y.active}}),"chatStore.setProcessing"),{cardId:P,active:y.active}}async function B(){let y=await b(a,"webhook.process-accumulated")();return y?.status==="fail"||y?.status==="error"?y:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(y??{},"data")?y.data??null:null}}}async function x(y){let P=String(y.token||"").trim(),q=String(y.ref||"").trim();if(!P)throw new Error("webhookSourceFetchDone requires token");if(!q)throw new Error("webhookSourceFetchDone requires ref");let D=await b(c,"webhook.source-fetch-done")({token:P,ref:q});return D?.status==="fail"||D?.status==="error"?D:{status:"success",data:{token:P,ref:q,runtime_result:Object.prototype.hasOwnProperty.call(D??{},"data")?D.data??null:null}}}async function K(y){let P=String(y.token||"").trim(),q=String(y.reason||"").trim();if(!P)throw new Error("webhookSourceFetchFailed requires token");if(!q)throw new Error("webhookSourceFetchFailed requires reason");let D=await b(u,"webhook.source-fetch-failed")({token:P,reason:q});return D?.status==="fail"||D?.status==="error"?D:{status:"success",data:{token:P,reason:q,runtime_result:Object.prototype.hasOwnProperty.call(D??{},"data")?D.data??null:null}}}return {listRuntimeCards:S,discoverSourceKinds:T,inspectBoardRuntimeStatus:I,inspectCardDefinitionAndRuntime:A,inspectChatMessagesOnCards:g,inspectFileContents:l,preflightValidateCandidateCardDefinition:i,preflightMaterializeCandidateCard:d,preflightProbeSingleSourceInCandidateCard:m,preflightRunSingleSourceInCandidateCard:p,preflightRunSingleSourceInLiveCard:h,preflightRunOneCycleWithCandidateCard:w,manageReadCard:O,manageAddChatAttachment:U,manageAddChatEntryAndAnyAttachments:J,managePatchCard:ae,manageUpsertCard:Q,manageRemoveCard:te,adminReadCard:ue,adminUpsertCard:G,getChatProcessing:Z,setChatProcessing:re,webhookProcessAccumulated:B,webhookSourceFetchDone:x,webhookSourceFetchFailed:K}}async function ze(e,t){return at(await e,t)}function ho(e){let{boardContexts:t,cardOwnerIndex:r,cardContextForCard:n,readStatusSnapshot:o,readDataObjectsByToken:a,readCardRuntimeArtifacts:c,readCardFromStore:u,readCardDefinitions:f,processAccumulatedLaneInternal:k,reportSourceFetched:R,reportSourceFetchFailure:b,uploadCardFile:S,chatStorePublic:_,serverUrl:T,apiBasePath:I}=e;function A(){return t[0]??null}function g(){return {async status(){let m=await o();return m==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:m}},async getOutputsDataObject(m){let p=m?.params?.key;return p?{status:"success",data:(await a())[p]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(m){let p=m?.params?.key;return p?{status:"success",data:(await c())[p]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(m){let p=m?.params?.key;if(!p)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let h=n(p)??A();return h?h.boardOps.getOutputsFetchedSources({params:{key:p}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(m){let p=m?.params?.id;if(!p)return {status:"fail",error:"removeCard requires params.id"};let h=n(p)??A();return h?h.boardOps.removeCard({params:{id:p}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(m){let p=m?.params?.cardId;if(!p)return {status:"fail",error:"upsertCard requires params.cardId"};let h=n(p)??A();if(!h)return {status:"fail",error:"Board context is unavailable"};let w=await h.boardOps.upsertCard({params:{cardId:p,restart:m.params.restart===true}});if(w.status!=="success")return w;if(rt(h.boardAdapter)){let O=await k(true);if(O.status!=="success")return O}return w}}}function l(){let m=()=>{let p=A();if(!p?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return p.nonCore};return {describeTaskExecutorCapabilities(p){return m().describeTaskExecutorCapabilities(p)},validateCardPreflight(p){return m().validateCardPreflight(p)},evalCardCompute(p){return m().evalCardCompute(p)},probeSourcePreflight(p){return m().probeSourcePreflight(p)},runSourcePreflight(p){return m().runSourcePreflight(p)},simulateCardCycle(p){return m().simulateCardCycle(p)}}}function i(){return {async get(m){let p=typeof m.params?.id=="string"?m.params.id:void 0;if(p){let h=await u(p);return h?{status:"success",data:{cards:[h]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await f()}}},async set(m){let p=m.body;if(p==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let h=Array.isArray(p)?p:[p];for(let w of h){let O=w,N=typeof O.id=="string"?O.id:"";if(!N)return {status:"fail",error:"each card must have a string `id` field"};let U=r.get(N)??0,J=t[U]??A();if(!J)return {status:"fail",error:"Board context is unavailable"};let ae=await J.cardStoreOps.set({body:O});if(ae.status!=="success")return ae;r.set(N,U);}return {status:"success",data:{count:h.length}}},async del(m){let p=[m.params?.id,...m.body?.ids??[]].filter(h=>typeof h=="string"&&!!h);if(p.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let h of p){let w=n(h)??A();if(!w)return {status:"fail",error:"Board context is unavailable"};let O=await w.cardStoreOps.del({params:{id:h}});if(O.status!=="success")return O;r.delete(h);}return {status:"success",data:{count:p.length}}},async patch(m){let p=typeof m.params?.id=="string"?m.params.id:void 0,h=typeof m.params?.path=="string"?m.params.path:void 0;if(!p||!h)return {status:"fail",error:"patch requires params.id and params.path"};let w=n(p)??A();return w?w.cardStoreOps.patch(m):{status:"fail",error:"Board context is unavailable"}},async appendFiles(m){let p=typeof m.params?.id=="string"?m.params.id:void 0;if(!p)return {status:"fail",error:"appendFiles requires params.id"};let h=n(p)??A();return h?h.cardStoreOps.appendFiles(m):{status:"fail",error:"Board context is unavailable"}}}}function d(){return yo({board:g(),nonCore:l(),cardStore:i(),chatStore:_,processAccumulated:()=>k(true),sourceFetchDone:({token:m,ref:p})=>R(m,p),sourceFetchFailed:({token:m,reason:p})=>b(m,p),uploadCardFile({cardId:m,fileName:p,contentType:h,bytes:w,suppressChatRecordWrite:O}){return S(m,p,h,w,{inChat:true,...O===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:m,fileIdx:p,storedName:h}){let w=`${T||""}${I}/cards/${encodeURIComponent(m)}/files/${p}`;return h?`${w}?sn=${encodeURIComponent(h)}`:w},readFetchedSourceJsonByRef({cardId:m,ref:p}){let h=n(m)??A();if(!h||rt(h.boardAdapter))return null;let N=h.boardAdapter.resolveBlob(it(p)).trim();return N?JSON.parse(N):null}})}return {mcpBoardFacade:g,mcpNonCoreFacade:l,mcpCardStoreFacade:i,createMcpFacade:d}}function Ro(e){let{apiBasePath:t,json:r,readJsonBody:n,bootstrapBoard:o,createMcpFacade:a,createMcpToolRegistry:c,resolveCardFileDownloadPayload:u,isLikelyTextMimeType:f,sliceTextByLines:k}=e;async function R(b,S,_){let T=b.method||"GET",I=_,A=I.pathname;try{if(T==="POST"&&A===`${t}/mcp`){await o();let g=await n(b),l=typeof g.tool=="string"?g.tool.trim():"",i=g.args&&typeof g.args=="object"&&!Array.isArray(g.args)?g.args:{};if(!l)return r(S,400,{error:"tool is required"}),!0;if(l==="inspect.file-contents")return r(S,400,{error:"inspect.file-contents is only available on /mcp-raw"}),!0;try{let d=await gt(l,i,c(a()));if(d&&typeof d=="object"&&!Array.isArray(d)){let m=d;if(m.status==="fail")return r(S,400,{error:nt(d,"Request failed")}),!0;if(m.status==="error")return r(S,500,{error:nt(d,"Internal error")}),!0}r(S,200,d);}catch(d){let m=typeof d?.statusCode=="number"?Number(d.statusCode):500,p=d instanceof Error?d.message:String(d);r(S,m,{error:p});}return !0}if(T==="POST"&&A===`${t}/mcp-raw`){await o();let g=await n(b),l=typeof g.tool=="string"?g.tool.trim():"",i=g.args&&typeof g.args=="object"&&!Array.isArray(g.args)?g.args:{};if(!l)return r(S,400,{error:"tool is required"}),!0;if(l!=="inspect.file-contents")return r(S,400,{error:`Tool does not support raw response: ${l}`}),!0;let d=me(i,"card_id","cardId"),m=ut(i,"file_idx","fileIdx"),p=ut(i,"head-lines","headLines"),h=ut(i,"tail-lines","tailLines"),w=ut(i,"head-bytes","headBytes"),O=ut(i,"tail-bytes","tailBytes");if(!d)return r(S,400,{error:"inspect.file-contents requires card_id"}),!0;if(m===void 0||!Number.isInteger(m)||m<0)return r(S,400,{error:"inspect.file-contents requires file_idx to be a non-negative integer"}),!0;if([p,h,w,O].filter(B=>B!==void 0).length>1)return r(S,400,{error:"inspect.file-contents accepts at most one of head-lines, tail-lines, head-bytes, tail-bytes"}),!0;for(let[B,x]of [["head-lines",p],["tail-lines",h],["head-bytes",w],["tail-bytes",O]])if(x!==void 0&&(!Number.isInteger(x)||x<0))return r(S,400,{error:`inspect.file-contents requires ${B} to be a non-negative integer`}),!0;let U=await a().inspectFileContents({cardId:d,fileIdx:m}),J=typeof U?.stored_name=="string"?U.stored_name:null,{fileRecord:ae,bytes:Q}=await u(d,m,J),te=String(ae.name||ae.stored_name||"download.bin"),ue=String(ae.mime_type||"application/octet-stream"),G=(I.searchParams.get("resp")||"").trim().toLowerCase();if(G&&G!=="json-b64")return r(S,400,{error:`unsupported resp mode: ${G}`}),!0;let Z=G==="json-b64",re;if(p!==void 0||h!==void 0){if(!f(ue))return r(S,400,{error:"head-lines/tail-lines are only supported for text-like files; use head-bytes/tail-bytes for binary content"}),!0;let B=new TextDecoder().decode(Q),x=p!==void 0?k(B,"head",p):k(B,"tail",h);re=typeof Buffer<"u"?Buffer.from(x,"utf8"):new TextEncoder().encode(x);}else if(w!==void 0||O!==void 0){let B=w??O;re=w!==void 0?Q.slice(0,B):Q.slice(Math.max(0,Q.length-B));}else re=Q;if(Z){let B=typeof Buffer<"u"?Buffer.from(re).toString("base64"):btoa(String.fromCharCode(...re));return r(S,200,{bodyBase64:B,mimeType:ue,filename:te,byteLength:re.length}),!0}return S.writeHead(200,{"Content-Type":ue,"Content-Disposition":`attachment; filename="${te}"`,"Content-Length":re.length}),S.end(re),!0}return !1}catch(g){let l=g?.statusCode||500;return r(S,l,{error:String(g?.message||g)}),true}}return {handleAgentfaceApi:R}}function ko(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,createMcpWebhookToolRegistry:a}=e;async function c(u,f,k){let R=u.method||"GET",b=k.pathname;try{if(R==="POST"&&b===`${t}/mcp-webhooks`){await o();let S=await n(u),_=typeof S.tool=="string"?S.tool.trim():"",T=S.args&&typeof S.args=="object"&&!Array.isArray(S.args)?S.args:{};if(!_)return r(f,400,{error:"tool is required"}),!0;try{let I=await gt(_,T,a());if(I&&typeof I=="object"&&!Array.isArray(I)){let A=I;if(A.status==="fail")return r(f,400,{error:nt(I,"Request failed")}),!0;if(A.status==="error")return r(f,500,{error:nt(I,"Internal error")}),!0}r(f,200,I);}catch(I){let A=typeof I?.statusCode=="number"?Number(I.statusCode):500,g=I instanceof Error?I.message:String(I);r(f,A,{error:g});}return !0}return !1}catch(S){let _=S?.statusCode||500;return r(f,_,{error:String(S?.message||S)}),true}}return {handleWebhooksApi:c}}function en(e){let{sseHub:t,corsHeaders:r,json:n,buildPublishedRuntimePayload:o,onSseClientConnected:a,onChannelSubscribed:c,onChannelUnsubscribed:u}=e;function f(R,b,S,_,T){if(!t.has(b)){n(R,404,{error:`SSE client not connected: ${b}`});return}T?(t.subscribeChannel(b,S,_.cardId),c?.(b,S,_)):(t.unsubscribeChannel(b,S,_.cardId),u?.(b,S,_)),n(R,200,{ok:true,clientId:b,channelName:S,..._.cardId?{cardId:_.cardId}:{},subscribed:T});}async function k(R,b,S,_){let T=_?.oneShot===true,I=_?.bootstrapPayload!==false,A=!T&&S?t.get(S):null,g=A?new Set(A.subscribedChatCardIds):new Set,l=A?new Set(A.subscribedChannelNames):new Set,i=A?new Map(Array.from(A.subscribedCardChannels.entries(),([m,p])=>[m,new Set(p)])):new Map;if(b.writeHead(200,{...r,"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}),t.flushTransport(b),I){let m=await o(),p=t.buildFrame(m);b.write(p);}if(T){b.end();return}if(!S)throw new Error("clientId is required for streaming SSE");t.register(S,b,{subscribedChatCardIds:g,subscribedChannelNames:l,subscribedCardChannels:i});try{a?.(S,m=>{t.writeFrame(S,m);});}catch{}let d=setInterval(()=>{try{b.write(`: keepalive
5
5
 
6
- `);}catch{}},15e3);R.on("close",()=>{clearInterval(d),t.disconnect(S,b);});}return {handleChannelSubscription:f,handleSse:k}}function Co(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,bootstrapBoard:a,boardContexts:c,publishPersistedStateSnapshot:u,upsertCardsFromSource:f,sseHub:k,queueSseHub:R}=e,{handleSse:b,handleChannelSubscription:S}=en(e),{handleSse:_}=en({...e,sseHub:R,buildPublishedRuntimePayload:async()=>null});async function T(I,A,g){let l=I.method||"GET",i=g,d=i.pathname;try{if(l==="GET"&&d===`${t}/sse`){let O=i.searchParams.has("one-shot");await o();let N=String(i.searchParams.get("clientId")||"").trim();if(!O&&!N)return r(A,400,{error:"clientId query param is required for SSE"}),!0;if(await b(I,A,N||void 0,{oneShot:O}),O)return !0;for(let U=0;U<c.length;U++)await u(c[U]),await f(c[U],U),await u(c[U]);return !0}if(l==="GET"&&d===`${t}/sse-q`){let O=String(i.searchParams.get("clientId")||"").trim();return O?(await _(I,A,O,{bootstrapPayload:!1}),!0):(r(A,400,{error:"clientId query param is required for SSE"}),!0)}let m=d.match(new RegExp(`^${st(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(l==="POST"&&m){await a();let O=decodeURIComponent(m[1]),N=await n(I),U=typeof N?.clientId=="string"?N.clientId.trim():"";return U?await k.subscribeChat(U,O)?(r(A,200,{ok:!0,clientId:U,cardId:O,subscribed:!0}),!0):(r(A,404,{error:`SSE client not connected: ${U}`}),!0):(r(A,400,{error:"clientId is required"}),!0)}let p=d.match(new RegExp(`^${st(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(l==="POST"&&p){await a();let O=decodeURIComponent(p[1]),N=await n(I),U=typeof N?.clientId=="string"?N.clientId.trim():"";return U?k.unsubscribeChat(U,O)?(r(A,200,{ok:!0,clientId:U,cardId:O,subscribed:!1}),!0):(r(A,404,{error:`SSE client not connected: ${U}`}),!0):(r(A,400,{error:"clientId is required"}),!0)}let h=d.match(new RegExp(`^${st(t)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(l==="POST"&&h){await a();let O=decodeURIComponent(h[1]),N=h[2]==="subscribe",U=await n(I),J=typeof U?.clientId=="string"?U.clientId.trim():"";return J?(S(A,J,O,{},N),!0):(r(A,400,{error:"clientId is required"}),!0)}let w=d.match(new RegExp(`^${st(t)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(l==="POST"&&w){await a();let O=decodeURIComponent(w[1]),N=decodeURIComponent(w[2]),U=w[3]==="subscribe",J=await n(I),ae=typeof J?.clientId=="string"?J.clientId.trim():"";return ae?(S(A,ae,N,{cardId:O},U),!0):(r(A,400,{error:"clientId is required"}),!0)}return !1}catch(m){let p=m?.statusCode||500;return r(A,p,{error:String(m?.message||m)}),true}}return {handleWatchersRoutes:T,handleSse:b,handleChannelSubscription:S}}var Ta=3e4;function Ia(e){let t=e.socket?.remoteAddress??"";return t==="127.0.0.1"||t==="::1"||t==="::ffff:127.0.0.1"}function bo(e){let{apiBasePath:t,emitNotifications:r,readJsonBody:n,json:o}=e,a=`${t}/notify-q`;async function c(u,f,k){if(k.pathname!==a)return false;if((u.method??"").toUpperCase()!=="POST")return o(f,405,{status:"error",error:"Method not allowed"}),true;if(!Ia(u))return o(f,403,{status:"error",error:"Forbidden"}),true;let R;try{R=await n(u);}catch{return o(f,400,{status:"error",error:"Invalid JSON body"}),true}if(!R||typeof R!="object"||!Array.isArray(R.notifications))return o(f,400,{status:"error",error:"body.notifications must be an array"}),true;let b=R.notifications,{accepted:S,rejected:_}=no(b,Date.now(),Ta);return S.length>0&&r(S),o(f,200,{status:"success",data:{accepted:S.length,rejected:_}}),true}return {handleNotifyRoute:c}}var wo={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},So="chat-handler-flow-queue",Ut="__probe__echo__probe__";function Pa(e){let t=String(e.apiBasePath||"/api/board").replace(/\/$/,""),r={...wo,...e.corsHeaders||{}},n=e.queueLaneTuning??{},o=e.boardId||"",a=Number.isInteger(e.chatBootstrapTailTurns)&&e.chatBootstrapTailTurns>0?e.chatBootstrapTailTurns:1,c=e.logger||{info:console.log,warn:console.warn,error:console.error},u=e.invocationAdapter,f=e.chatFlowRunner||null,k=e.notificationTransport||null,R=e.serverUrl||null,b=e.executionExtra||{},S=e.onSseClientConnected,_=e.onSseClientDisconnected,T=e.onChannelSubscribed,I=e.onChannelUnsubscribed,A=Qr({buildChatOneShotBatch:async(s,C)=>await be.buildSseOneShotBatch({params:{cardId:s},body:{receiving:C}}),onSseClientDisconnected:_}),g=Qr({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function l(s){function C(ee){return {...ee,queueStorageForRef(ge,Oe){return zn(ee.queueStorageForRef(ge,Oe),{lane:Oe,emitNotification:X})}}}function E(ee){return {...ee,queueStorageForRef(ge,Oe){return Wn(ee.queueStorageForRef(ge,Oe),{lane:Oe,emitNotification:X})}}}function L(ee){return {async get(ge){return ee.get(ge)},async set(ge){return ee.set(ge)},async del(ge){return ee.del(ge)},async patch(ge){return ee.patch(ge)},async appendFiles(ge){return ee.appendFiles(ge)}}}function H(ee){return {async get(ge){return await ee.get(ge)},async set(ge){return await ee.set(ge)},async del(ge){return await ee.del(ge)},async patch(ge){return await ee.patch(ge)},async appendFiles(ge){return await ee.appendFiles(ge)}}}let ne=null;function X(ee){if(ee.kind==="notification-batch"){te(ee.notifications,ne??void 0);return}te([ee],ne??void 0);}let le=rt(s.boardAdapter)?E(s.boardAdapter):C(s.boardAdapter),Ue=s.nonCoreAdapter??(!rt(le)&&w(le)?le:null),xe=rt(le)?Gn(s.baseRef,le,{boardRuntimeStoreRef:s.boardRuntimeStoreRef,scratchStoreRef:s.scratchStoreRef,taskExecutorRef:s.taskExecutorRef,chatHandlerFlow:s.chatHandlerFlow,emitNotification:X}):Mn(s.baseRef,le,{boardRuntimeStoreRef:s.boardRuntimeStoreRef,scratchStoreRef:s.scratchStoreRef,taskExecutorRef:s.taskExecutorRef,chatHandlerFlow:s.chatHandlerFlow,emitNotification:X}),He=s.nonCore??(Ue?Dn(s.baseRef,Ue,{boardRuntimeStoreRef:s.boardRuntimeStoreRef,taskExecutorRef:s.taskExecutorRef}):null),Ar=le.chatStorageForRef(s.chatStoreRef),xr,Ao=rt(le)?(()=>{let ee=kr(Rr(hr(le.kvStorageForRef(s.cardStoreRef)),le.hashFn),c.warn),ge=pr(ee,{emitNotification:X}),Oe=H(ge);return xr={get(we){return Oe.get(we)},set(we){return Oe.set(we)}},Oe})():(()=>{let ee=le.kvStorageForRef(s.cardStoreRef),Oe=fr(Mt({readIndex:()=>ee.read("_index"),writeIndex:we=>ee.write("_index",we),readCard:we=>ee.read(we),writeCard:(we,Ir)=>(ee.write(we,Ir),we),removeCard:we=>{ee.delete(we);},cardExists:we=>ee.read(we)!==null,defaultCardKey:we=>we},c.warn),{emitNotification:X});return xr=Oe,L(Oe)})(),Tr;if(rt(le)){let ee=le.blobStorageForRef(s.artifactsStoreRef);Tr={async putBytes(ge,Oe){if(ee.writeBytes){await ee.writeBytes(ge,Oe);return}let we=JSON.stringify({__kind:"bytes-array",data:[...Oe]});await ee.write(ge,we);},async getBytes(ge){if(ee.readBytes){let we=await ee.readBytes(ge);if(we!==null)return we}let Oe=await ee.read(ge);if(Oe===null)return null;try{let we=JSON.parse(Oe);if(we&&we.__kind==="bytes-array"&&Array.isArray(we.data))return new Uint8Array(we.data)}catch{}return new TextEncoder().encode(Oe)},async listKeys(ge){return await ee.listKeys(ge)}};}else {let ee=le.blobStorageForRef(s.artifactsStoreRef),ge=Zn(ee);Tr={putBytes(Oe,we,Ir){ge.putBytes(Oe,we,Ir);},getBytes(Oe){return ge.getBytes(Oe)},listKeys(Oe){return ge.list(Oe).map(we=>we.key)}};}let xo={async init(ee){return xe.init(ee)},async status(ee){return xe.status(ee)},async getConfig(ee){return xe.getConfig(ee)},async getAllOutputsDataObjects(ee){return xe.getAllOutputsDataObjects(ee)},async getAllOutputsComputedValues(ee){return xe.getAllOutputsComputedValues(ee)},async getOutputsFetchedSources(ee){return xe.getOutputsFetchedSources(ee)},async buildSseOneShotPayload(ee){return xe.buildSseOneShotPayload(ee)},async upsertCard(ee){return xe.upsertCard(ee)},async removeCard(ee){return xe.removeCard(ee)},async sourceDataFetched(ee){return xe.sourceDataFetched(ee)},async sourceDataFetchFailure(ee){return xe.sourceDataFetchFailure(ee)}};return ne={label:s.label,board:xe,nonCore:He,publicCardStore:xr,boardOps:xo,cardStoreOps:Ao,get filesArtifacts(){return Tr},get chatStorage(){return Ar},boardAdapter:le,boardRuntimeStoreRef:s.boardRuntimeStoreRef,cardStoreRef:s.cardStoreRef,outputsStoreRef:s.outputsStoreRef,artifactsStoreRef:s.artifactsStoreRef,fetchedSourcesStoreRef:s.fetchedSourcesStoreRef,queueStoreRef:s.queueStoreRef,chatStoreRef:s.chatStoreRef,scratchStoreRef:s.scratchStoreRef,notifyRef:s.notifyRef,taskExecutorRef:s.taskExecutorRef,chatHandlerRef:s.chatHandlerRef,chatHandlerFlow:s.chatHandlerFlow,inferenceAdapterRef:s.inferenceAdapterRef,notification:ao(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},ne}let i=e.boards.map(l),d=new Map;function m(s){return d.get(s)??0}function p(s){return s.queueStoreRef}function h(s,C){if(rt(s.boardAdapter)){let L=s.boardAdapter.queueStorageForRef(p(s),C);return Vr(L)}let E=s.boardAdapter.queueStorageForRef(p(s),C);return Hr(E)}function w(s){let C=s;return typeof C.invokeExecutor=="function"&&typeof C.validateSchema=="function"}function O(s){let C=i[m(s)];return {files:C?C.filesArtifacts:null}}function N(){return eo()}function U(s){return String(s||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function J(s){return "cardId"in s&&typeof s.cardId=="string"?y(s.cardId)??void 0:i[0]??void 0}function ae(s){for(let C of s){let E=J(C);if(E)return E}return i[0]??void 0}function Q(s,C={}){if(!s||s.length===0)return;let E=De(s),L={kind:"notification-batch",notifications:E},H=C.ctx??ae(E);if(C.appendState!==false&&H&&so(H.notification,L),C.broadcastSse!==false){let ne=E.filter(le=>le.kind==="message_enqueued"),X=E.filter(le=>le.kind!=="message_enqueued");X.length>0&&A.broadcastNotificationBatch(X),ne.length>0&&g.broadcastNotificationBatch(ne);}if(!(C.mirrorExternal===false||!H?.boardAdapter.publishBoardChangeNotifications))try{let ne=E.filter(X=>X.category==="board-output"||X.category==="card-store");ne.length>0&&H.boardAdapter.publishBoardChangeNotifications(ne);}catch{}}function te(s,C){Q(s,{ctx:C,appendState:true,broadcastSse:true,mirrorExternal:true});}async function ue(s){if(!s||s.notificationTeardown||!k||!s.notifyRef)return;let C=await k.subscribe(s.notifyRef,E=>{let L=ro(E);Q(L,{ctx:s,appendState:true,broadcastSse:true,mirrorExternal:false});});s.notificationTeardown=C;}async function G(s){if(!s||s.initialized)return;let C={boardRuntimeStoreRef:s.boardRuntimeStoreRef,cardStoreRef:s.cardStoreRef,outputsStoreRef:s.outputsStoreRef,fetchedSourcesStoreRef:s.fetchedSourcesStoreRef,artifactsStoreRef:s.artifactsStoreRef,queueStoreRef:s.queueStoreRef,chatStoreRef:s.chatStoreRef,scratchStoreRef:s.scratchStoreRef},E={};s.taskExecutorRef&&(E["task-executor-ref"]=s.taskExecutorRef),s.chatHandlerFlow!==void 0&&(E["chat-handler-flow"]=s.chatHandlerFlow);let L=await s.boardOps.init({params:C,body:E});if(L.status!=="success")throw Object.assign(new Error(L.error||`init failed for ${s.label}`),{statusCode:500});if(await ue(s),!s.chatHandlerFlow&&s.chatHandlerRef&&u.describe)try{let H=await u.describe(s.chatHandlerRef);H&&H.kind!=="chat-handler"?c.warn(`[init] chat-handler describe returned kind="${H.kind}", expected "chat-handler" for ${s.label}`):H&&c.info(`[init] chat-handler validated: ${H.name} (protocol ${H.protocolVersion}) for ${s.label}`);}catch(H){c.warn(`[init] chat-handler describe failed for ${s.label}: ${H?.message||String(H)}`);}s.initialized=true;}async function Z(s){let C=[],E=await s.boardOps.status({});E.status==="success"&&E.data!=null&&Jr(E.data)&&C.push({kind:"status",status:E.data});let L=await s.boardOps.getAllOutputsDataObjects({});if(L.status==="success"&&L.data!=null)for(let[ne,X]of Object.entries(L.data))ne&&C.push({kind:"data_object",key:ne,payload:X});let H=await s.boardOps.getAllOutputsComputedValues({});if(H.status==="success"&&H.data!=null)for(let[ne,X]of Object.entries(H.data))ne&&X&&typeof X=="object"&&!Array.isArray(X)&&C.push({kind:"computed_values",cardId:ne,values:X});C.length>0&&Q(C,{ctx:s,appendState:true,broadcastSse:true,mirrorExternal:false});}async function re(s,C){if(!s||s.cardsBootstrapped)return;let E=await s.cardStoreOps.get({}),L=E.status==="success"&&Array.isArray(E.data?.cards)?E.data.cards:[];for(let H of L)typeof H.id=="string"&&(d.set(H.id,C),await s.boardOps.upsertCard({params:{cardId:H.id}}));s.cardsBootstrapped=true;}async function B(){for(let s of i)await G(s);}async function x(){await B();for(let s=0;s<i.length;s++)await Z(i[s]),await re(i[s],s),await Z(i[s]);}async function K(s=false){s||await B();for(let C of i){let E=await C.board.processAccumulatedEvents({});if(E.status!=="success")return E}return {status:"success"}}function y(s){return i[m(s)]??null}async function P(s){let C=y(s);if(!C)return null;let E=await C.cardStoreOps.get({params:{id:s}});if(E.status!=="success")return null;let L=Array.isArray(E.data?.cards)?E.data.cards:[];return L.length>0?L[0]:null}async function q(){let s=async E=>{if(!E)return [];let L=await E.cardStoreOps.get({});return L.status!=="success"||!Array.isArray(L.data?.cards)?[]:L.data.cards},C=[];for(let E of i)C.push(...await s(E));return C}function D(){return i[0]??null}function M(s){return y(s)??D()}function $(s){let C=M(s);if(!C)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${s}`),{statusCode:404});return C.chatStorage}async function se(s){return await $(s).isProcessing(s)}async function ce(s,C){let E=await be.setProcessing({params:{cardId:s},body:{active:C}});if(E.status!=="success")throw Object.assign(new Error(E.error||`Failed to set chat processing for card: ${s}`),{statusCode:500})}let be=to({append(s,C,E,L,H){return $(s).append(s,C,E,L,H)},readAll(s){return $(s).readAll(s)},readAfter(s,C){return $(s).readAfter(s,C)},clear(s){return $(s).clear(s)},setProcessing(s,C){return $(s).setProcessing(s,C)},isProcessing(s){return $(s).isProcessing(s)},getConfig(s){return $(s).getConfig(s)},setConfig(s,C){return $(s).setConfig(s,C)}},{emitNotification(s){if(s.kind==="notification-batch"){te(s.notifications);return}te([s]);}}),Te=ho({boardContexts:i,cardOwnerIndex:d,cardContextForCard:s=>y(s),readStatusSnapshot:()=>he(),readDataObjectsByToken:()=>Je(),readCardRuntimeArtifacts:()=>et(),readCardFromStore:s=>P(s),readCardDefinitions:()=>q(),processAccumulatedLaneInternal:s=>K(s),reportSourceFetched:(s,C)=>Bt(s,{ref:C}),reportSourceFetchFailure:(s,C)=>Vt(s,{reason:C}),uploadCardFile:(s,C,E,L,H)=>ie(s,C,E,L,H),chatStorePublic:be,serverUrl:R,apiBasePath:t}),_e=Te.mcpCardStoreFacade,pe=Te.createMcpFacade,ke=io({boardId:o,bootstrapBoard:()=>x(),sseHub:A,onChannelSubscribed:T,onChannelUnsubscribed:I,getMcpFacade:()=>pe(),getMcpCardStoreFacade:()=>_e()});function Ve(s){return lo(s)}function Se(){return fo(pe())}function Ke(){return mo({boardId:o,uploadCardFile:ie,getMcpFacade:()=>pe(),controlplane:ke})}let qe=uo({boardId:o,boardContexts:i,readChatRecords:(s,C)=>oe(s,C),getChatProcessing:s=>se(s),chatBootstrapTailTurns:a}),he=qe.readStatusSnapshot,et=qe.readCardRuntimeArtifacts,Je=qe.readDataObjectsByToken,tt=qe.buildPublishedRuntimePayload;async function yt(s,C,E){let L=E?.syncBoard!==false,H=E?.restartOnlyIfChanged===true,ne=y(s);if(!ne)throw Object.assign(new Error(`Card not found: ${s}`),{statusCode:404});let X=await P(s);if(!X)throw Object.assign(new Error(`Card not found: ${s}`),{statusCode:404});let le=H?JSON.stringify(X):null,Ue=C(X)||X;if(H&&JSON.stringify(Ue)===le)return;let xe=await ne.cardStoreOps.set({body:Ue});if(xe.status!=="success")throw Object.assign(new Error(xe.error||`Failed to persist card: ${s}`),{statusCode:500});if(L){let He=await ne.boardOps.upsertCard({params:{cardId:s,restart:true}});if(He.status!=="success")throw Object.assign(new Error(He.error||`Failed to upsert card: ${s}`),{statusCode:500})}}async function j(s,C){await yt(s,C,{syncBoard:true});}async function v(s,C){await yt(s,C,{syncBoard:false});}async function W(s){let C=y(s);if(!C)throw Object.assign(new Error(`Card not found: ${s}`),{statusCode:404});if(!await P(s))throw Object.assign(new Error(`Card not found: ${s}`),{statusCode:404});let L=await C.boardOps.upsertCard({params:{cardId:s,restart:true}});if(L.status!=="success")throw Object.assign(new Error(L.error||`Failed to retrigger card: ${s}`),{statusCode:500})}async function F(s){let C=await be.clear({params:{cardId:s}});if(C.status!=="success")throw Object.assign(new Error(C.error||`Failed to clear chat records for card: ${s}`),{statusCode:500});try{await ce(s,!1);}catch{}}async function V(s,C,E,L,H=""){let ne=typeof E=="string"?E.trim():"",X=await be.append({params:{cardId:s},body:{role:C||"system",text:ne,files:L,turn:H}});if(X.status!=="success")throw Object.assign(new Error(X.error||`Failed to append chat record for card: ${s}`),{statusCode:500});return String(X.data?.id||"")}async function oe(s,C){let E=Number.isInteger(C?.tailTurns)&&C?.tailTurns>0?C?.tailTurns:void 0,L=await be.readAll({params:{cardId:s},...E===void 0?{}:{body:{tailTurns:E}}});if(L.status!=="success")throw Object.assign(new Error(L.error||`Failed to read chat records for card: ${s}`),{statusCode:500});return Array.isArray(L.data?.records)?L.data.records:[]}let ie=co({safeCardId:s=>U(s),artifactsStores:s=>O(s),cardFileMetadataStore:()=>N(),readCardFromStore:s=>P(s),updateCardLocalOnly:(s,C)=>v(s,C),writeChatRecord:(s,C,E,L,H)=>V(s,C,E,L,H)}).uploadCardFile;async function Re(s){let C=y(s);if(!C)return null;let E=await C.boardOps.getConfig({params:{key:"chat-handler-flow"}}),H=(E.status==="success"?E.data?.value:null)??C.chatHandlerFlow??null,ne=C.chatHandlerRef;return H==null&&(!ne||typeof ne!="object")?null:{ctx:C,handlerFlow:H,handlerRef:ne}}function Be(s){let C=typeof s=="string"?s.trim():"";if(C.length<Ut.length*2||!C.startsWith(Ut)||!C.endsWith(Ut))return null;let E=C.slice(Ut.length,C.length-Ut.length).trim(),L=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(E);return L?{assistant:L[1].trim().toLowerCase(),text:L[2].trim()}:{assistant:"echo",text:E}}async function je(s,C,E=false,L="",H=""){try{let ne=await Re(s);if(!ne){try{await ce(s,!1);}catch{}return}let{ctx:X,handlerFlow:le,handlerRef:Ue}=ne;if(!E)try{await ce(s,!0);}catch{}let xe={boardId:o,cardId:String(s),lastChatEntryId:C,...L?{turnId:L}:{},...typeof H=="string"&&H.trim()?{probe:H.trim()}:{},...b,...R?{serverUrl:R}:{}},He=le!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:So}}:Ue;rt(X.boardAdapter)?await h(X,"chat-agent").enqueueRequest({boardId:o,ref:He,args:le!=null?{...xe,__chatHandlerFlow:le}:xe}):h(X,"chat-agent").enqueueRequest({boardId:o,ref:He,args:le!=null?{...xe,__chatHandlerFlow:le}:xe}),await Promise.resolve(X.boardAdapter.requestProcessAccumulated?.());}catch(ne){try{await ce(s,!1);}catch{}c.warn(`[chat-handler] queue failed for card "${s}": ${ne instanceof Error?ne.message:String(ne)}`);}}async function Le(s,C,E){if(C.howToRun==="built-in"&&on(C)===So){let L=f,H=E.__chatHandlerFlow,ne={...E};return delete ne.__chatHandlerFlow,L?L.run(H,ne,{boardId:o,cardId:String(ne.cardId||""),label:s.label,logger:c,serverUrl:R,executionExtra:b}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return u.invoke(C,E)}async function Me(s,C=false){C||await B();let E=typeof s.args?.cardId=="string"?s.args.cardId:"",L=E?y(E):D();if(!L)throw new Error(E?`Board context is unavailable for chat-agent request: ${E}`:"Board context is unavailable for chat-agent request");let H=await Le(L,s.ref,s.args);if(!H.dispatched){if(E)try{await ce(E,!1);}catch{}throw new Error(H.error||`chat-agent dispatch failed for card "${E||"unknown"}"`)}}async function Ye(s,C,E){if(C==="chat-send"){let H=E&&typeof E["turn-id"]=="string"?E["turn-id"]:E&&typeof E.turnId=="string"?E.turnId:E&&typeof E.turn=="string"?E.turn:"";if(E&&"files"in E&&E.files!==void 0&&E.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 ne=Ke(),X=Be(E?.text),le=X?X.text:E?.text,Ue=await gt("manage.add-chat-entry-and-any-attachments",{board_id:o,card_id:s,role:"user",text:le,turn_id:H,files:[]},ne);if(Ue?.status!=="success")throw new Error(nt(Ue,`chat-send append failed for card ${s}`));let xe=Ue?.data?.id;if(typeof xe!="string"||!xe)throw new Error(`chat-send did not return an append id for card ${s}`);let He=await gt("setstate.chat-processing-started",{board_id:o,card_id:s},ne);if(He?.status!=="success")throw new Error(nt(He,`chat-send processing update failed for card ${s}`));je(s,xe,true,H,X?.assistant||"");return}await j(s,H=>{let ne=new Date().toISOString(),X=H.card_data&&typeof H.card_data=="object"?H.card_data:{};if(H.card_data=X,C==="file-upload"){let le=N().normalizeIncoming(E?.files,ne);return le.length>0&&N().merge(X,le),H}if(C==="action"){let le=E&&typeof E.buttonId=="string"?E.buttonId:"";if(!le)return H;X.lastAction={buttonId:le,at:ne},X.lastActionText=`${le} @ ${ne}`;}return H});}function Ge(s,C,E){let L=JSON.stringify(E),H=typeof Buffer<"u"?Buffer.byteLength(L):new TextEncoder().encode(L).length;s.writeHead(C,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":H}),s.end(L);}async function Xe(s,C,E){let L=await P(s);if(!L)throw Object.assign(new Error("Card not found"),{statusCode:404});let H=N().resolve(L.card_data,C,E);if(!H.ok&&H.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!H.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let ne=H.file,X=U(s),le=O(s),Ue=String(ne.stored_name||""),xe=`${X}/${Ue}`,He=le.files?await le.files.getBytes(xe):null;if(!He)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:ne,bytes:He}}async function ft(s,C,E,L){let{fileRecord:H,bytes:ne}=await Xe(C,E,L),X=String(H.name||H.stored_name||"download.bin"),le=String(H.mime_type||"application/octet-stream");s.writeHead(200,{"Content-Type":le,"Content-Disposition":`attachment; filename="${X}"`,"Content-Length":ne.length}),s.end(ne);}function _t(s){let C=String(s||"").toLowerCase();return C.startsWith("text/")||C.includes("json")||C.includes("xml")||C.includes("javascript")||C.includes("typescript")||C.includes("yaml")||C.includes("csv")}function Et(s,C,E){let L=s.split(/\r?\n/);return (C==="head"?L.slice(0,E):L.slice(-E)).join(`
6
+ `);}catch{}},15e3);R.on("close",()=>{clearInterval(d),t.disconnect(S,b);});}return {handleChannelSubscription:f,handleSse:k}}function Co(e){let{apiBasePath:t,json:r,readJsonBody:n,initBoardAndSetup:o,bootstrapBoard:a,boardContexts:c,publishPersistedStateSnapshot:u,upsertCardsFromSource:f,sseHub:k,queueSseHub:R}=e,{handleSse:b,handleChannelSubscription:S}=en(e),{handleSse:_}=en({...e,sseHub:R,buildPublishedRuntimePayload:async()=>null});async function T(I,A,g){let l=I.method||"GET",i=g,d=i.pathname;try{if(l==="GET"&&d===`${t}/sse`){let O=i.searchParams.has("one-shot");await o();let N=String(i.searchParams.get("clientId")||"").trim();if(!O&&!N)return r(A,400,{error:"clientId query param is required for SSE"}),!0;if(await b(I,A,N||void 0,{oneShot:O}),O)return !0;for(let U=0;U<c.length;U++)await u(c[U]),await f(c[U],U),await u(c[U]);return !0}if(l==="GET"&&d===`${t}/sse-q`){let O=String(i.searchParams.get("clientId")||"").trim();return O?(await _(I,A,O,{bootstrapPayload:!1}),!0):(r(A,400,{error:"clientId query param is required for SSE"}),!0)}let m=d.match(new RegExp(`^${st(t)}/cards/([^/]+)/chats/subscribe-sse$`));if(l==="POST"&&m){await a();let O=decodeURIComponent(m[1]),N=await n(I),U=typeof N?.clientId=="string"?N.clientId.trim():"";return U?await k.subscribeChat(U,O)?(r(A,200,{ok:!0,clientId:U,cardId:O,subscribed:!0}),!0):(r(A,404,{error:`SSE client not connected: ${U}`}),!0):(r(A,400,{error:"clientId is required"}),!0)}let p=d.match(new RegExp(`^${st(t)}/cards/([^/]+)/chats/unsubscribe-sse$`));if(l==="POST"&&p){await a();let O=decodeURIComponent(p[1]),N=await n(I),U=typeof N?.clientId=="string"?N.clientId.trim():"";return U?k.unsubscribeChat(U,O)?(r(A,200,{ok:!0,clientId:U,cardId:O,subscribed:!1}),!0):(r(A,404,{error:`SSE client not connected: ${U}`}),!0):(r(A,400,{error:"clientId is required"}),!0)}let h=d.match(new RegExp(`^${st(t)}/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(l==="POST"&&h){await a();let O=decodeURIComponent(h[1]),N=h[2]==="subscribe",U=await n(I),J=typeof U?.clientId=="string"?U.clientId.trim():"";return J?(S(A,J,O,{},N),!0):(r(A,400,{error:"clientId is required"}),!0)}let w=d.match(new RegExp(`^${st(t)}/cards/([^/]+)/watch-channel/([^/]+)/(subscribe|unsubscribe)-sse$`));if(l==="POST"&&w){await a();let O=decodeURIComponent(w[1]),N=decodeURIComponent(w[2]),U=w[3]==="subscribe",J=await n(I),ae=typeof J?.clientId=="string"?J.clientId.trim():"";return ae?(S(A,ae,N,{cardId:O},U),!0):(r(A,400,{error:"clientId is required"}),!0)}return !1}catch(m){let p=m?.statusCode||500;return r(A,p,{error:String(m?.message||m)}),true}}return {handleWatchersRoutes:T,handleSse:b,handleChannelSubscription:S}}var Ta=3e4;function Ia(e){let t=e.socket?.remoteAddress??"";return t==="127.0.0.1"||t==="::1"||t==="::ffff:127.0.0.1"}function bo(e){let{apiBasePath:t,emitNotifications:r,readJsonBody:n,json:o}=e,a=`${t}/notify-q`;async function c(u,f,k){if(k.pathname!==a)return false;if((u.method??"").toUpperCase()!=="POST")return o(f,405,{status:"error",error:"Method not allowed"}),true;if(!Ia(u))return o(f,403,{status:"error",error:"Forbidden"}),true;let R;try{R=await n(u);}catch{return o(f,400,{status:"error",error:"Invalid JSON body"}),true}if(!R||typeof R!="object"||!Array.isArray(R.notifications))return o(f,400,{status:"error",error:"body.notifications must be an array"}),true;let b=R.notifications,{accepted:S,rejected:_}=no(b,Date.now(),Ta);return S.length>0&&r(S),o(f,200,{status:"success",data:{accepted:S.length,rejected:_}}),true}return {handleNotifyRoute:c}}var wo={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"content-type,x-file-name","Access-Control-Allow-Methods":"GET,POST,PATCH,OPTIONS"},So="chat-handler-flow-queue",Ut="__probe__echo__probe__";function Pa(e){let t=String(e.apiBasePath||"/api/board").replace(/\/$/,""),r={...wo,...e.corsHeaders||{}},n=e.queueLaneTuning??{},o=e.boardId||"",a=Number.isInteger(e.chatBootstrapTailTurns)&&e.chatBootstrapTailTurns>0?e.chatBootstrapTailTurns:1,c=e.logger||{info:console.log,warn:console.warn,error:console.error},u=e.invocationAdapter,f=e.chatFlowRunner||null,k=e.notificationTransport||null,R=e.serverUrl||null,b=e.executionExtra||{},S=e.onSseClientConnected,_=e.onSseClientDisconnected,T=e.onChannelSubscribed,I=e.onChannelUnsubscribed,A=Qr({buildChatOneShotBatch:async(s,C)=>await be.buildSseOneShotBatch({params:{cardId:s},body:{receiving:C}}),onSseClientDisconnected:_}),g=Qr({buildChatOneShotBatch:async()=>({status:"success",data:{kind:"notification-batch",category:"batch",notifications:[]}})});function l(s){function C(ee){return {...ee,queueStorageForRef(ge,Oe){return zn(ee.queueStorageForRef(ge,Oe),{lane:Oe,emitNotification:X})}}}function E(ee){return {...ee,queueStorageForRef(ge,Oe){return Wn(ee.queueStorageForRef(ge,Oe),{lane:Oe,emitNotification:X})}}}function L(ee){return {async get(ge){return ee.get(ge)},async set(ge){return ee.set(ge)},async del(ge){return ee.del(ge)},async patch(ge){return ee.patch(ge)},async appendFiles(ge){return ee.appendFiles(ge)}}}function H(ee){return {async get(ge){return await ee.get(ge)},async set(ge){return await ee.set(ge)},async del(ge){return await ee.del(ge)},async patch(ge){return await ee.patch(ge)},async appendFiles(ge){return await ee.appendFiles(ge)}}}let ne=null;function X(ee){if(ee.kind==="notification-batch"){te(ee.notifications,ne??void 0);return}te([ee],ne??void 0);}let le=rt(s.boardAdapter)?E(s.boardAdapter):C(s.boardAdapter),Ue=s.nonCoreAdapter??(!rt(le)&&w(le)?le:null),xe=rt(le)?Gn(s.baseRef,le,{boardRuntimeStoreRef:s.boardRuntimeStoreRef,scratchStoreRef:s.scratchStoreRef,taskExecutorRef:s.taskExecutorRef,chatHandlerFlow:s.chatHandlerFlow,emitNotification:X}):Mn(s.baseRef,le,{boardRuntimeStoreRef:s.boardRuntimeStoreRef,scratchStoreRef:s.scratchStoreRef,taskExecutorRef:s.taskExecutorRef,chatHandlerFlow:s.chatHandlerFlow,emitNotification:X}),He=s.nonCore??(Ue?Dn(s.baseRef,Ue,{boardRuntimeStoreRef:s.boardRuntimeStoreRef,taskExecutorRef:s.taskExecutorRef}):null),Ar=le.chatStorageForRef(s.chatStoreRef),xr,Ao=rt(le)?(()=>{let ee=kr(Rr(hr(le.kvStorageForRef(s.cardStoreRef)),le.hashFn),c.warn),ge=pr(ee,{emitNotification:X}),Oe=H(ge);return xr={get(we){return Oe.get(we)},set(we){return Oe.set(we)}},Oe})():(()=>{let ee=le.kvStorageForRef(s.cardStoreRef),Oe=fr(Mt({readIndex:()=>ee.read("_index"),writeIndex:we=>ee.write("_index",we),readCard:we=>ee.read(we),writeCard:(we,Ir)=>(ee.write(we,Ir),we),removeCard:we=>{ee.delete(we);},cardExists:we=>ee.read(we)!==null,defaultCardKey:we=>we},c.warn),{emitNotification:X});return xr=Oe,L(Oe)})(),Tr;if(rt(le)){let ee=le.blobStorageForRef(s.artifactsStoreRef);Tr={async putBytes(ge,Oe){if(ee.writeBytes){await ee.writeBytes(ge,Oe);return}let we=JSON.stringify({__kind:"bytes-array",data:[...Oe]});await ee.write(ge,we);},async getBytes(ge){if(ee.readBytes){let we=await ee.readBytes(ge);if(we!==null)return we}let Oe=await ee.read(ge);if(Oe===null)return null;try{let we=JSON.parse(Oe);if(we&&we.__kind==="bytes-array"&&Array.isArray(we.data))return new Uint8Array(we.data)}catch{}return new TextEncoder().encode(Oe)},async listKeys(ge){return await ee.listKeys(ge)}};}else {let ee=le.blobStorageForRef(s.artifactsStoreRef),ge=Zn(ee);Tr={putBytes(Oe,we,Ir){ge.putBytes(Oe,we,Ir);},getBytes(Oe){return ge.getBytes(Oe)},listKeys(Oe){return ge.list(Oe).map(we=>we.key)}};}let xo={async init(ee){return xe.init(ee)},async status(ee){return xe.status(ee)},async getConfig(ee){return xe.getConfig(ee)},async getAllOutputsDataObjects(ee){return xe.getAllOutputsDataObjects(ee)},async getAllOutputsComputedValues(ee){return xe.getAllOutputsComputedValues(ee)},async getOutputsFetchedSources(ee){return xe.getOutputsFetchedSources(ee)},async buildSseOneShotPayload(ee){return xe.buildSseOneShotPayload(ee)},async upsertCard(ee){return xe.upsertCard(ee)},async removeCard(ee){return xe.removeCard(ee)},async sourceDataFetched(ee){return xe.sourceDataFetched(ee)},async sourceDataFetchFailure(ee){return xe.sourceDataFetchFailure(ee)}};return ne={label:s.label,board:xe,nonCore:He,publicCardStore:xr,boardOps:xo,cardStoreOps:Ao,get filesArtifacts(){return Tr},get chatStorage(){return Ar},boardAdapter:le,boardRuntimeStoreRef:s.boardRuntimeStoreRef,cardStoreRef:s.cardStoreRef,outputsStoreRef:s.outputsStoreRef,artifactsStoreRef:s.artifactsStoreRef,fetchedSourcesStoreRef:s.fetchedSourcesStoreRef,queueStoreRef:s.queueStoreRef,chatStoreRef:s.chatStoreRef,scratchStoreRef:s.scratchStoreRef,notifyRef:s.notifyRef,taskExecutorRef:s.taskExecutorRef,chatHandlerRef:s.chatHandlerRef,chatHandlerFlow:s.chatHandlerFlow,inferenceAdapterRef:s.inferenceAdapterRef,notification:ao(),notificationTeardown:null,initialized:false,cardsBootstrapped:false},ne}let i=e.boards.map(l),d=new Map;function m(s){return d.get(s)??0}function p(s){return s.queueStoreRef}function h(s,C){if(rt(s.boardAdapter)){let L=s.boardAdapter.queueStorageForRef(p(s),C);return Vr(L)}let E=s.boardAdapter.queueStorageForRef(p(s),C);return Hr(E)}function w(s){let C=s;return typeof C.invokeExecutor=="function"&&typeof C.validateSchema=="function"}function O(s){let C=i[m(s)];return {files:C?C.filesArtifacts:null}}function N(){return eo()}function U(s){return String(s||"").replace(/[^a-zA-Z0-9_-]/g,"_")||"unknown-card"}function J(s){return "cardId"in s&&typeof s.cardId=="string"?y(s.cardId)??void 0:i[0]??void 0}function ae(s){for(let C of s){let E=J(C);if(E)return E}return i[0]??void 0}function Q(s,C={}){if(!s||s.length===0)return;let E=De(s),L={kind:"notification-batch",notifications:E},H=C.ctx??ae(E);if(C.appendState!==false&&H&&so(H.notification,L),C.broadcastSse!==false){let ne=E.filter(le=>le.kind==="message_enqueued"),X=E.filter(le=>le.kind!=="message_enqueued");X.length>0&&A.broadcastNotificationBatch(X),ne.length>0&&g.broadcastNotificationBatch(ne);}if(!(C.mirrorExternal===false||!H?.boardAdapter.publishBoardChangeNotifications))try{let ne=E.filter(X=>X.category==="board-output"||X.category==="card-store"||X.category==="chat-store"||X.category==="hosted-runtime");ne.length>0&&H.boardAdapter.publishBoardChangeNotifications(ne);}catch{}}function te(s,C){Q(s,{ctx:C,appendState:true,broadcastSse:true,mirrorExternal:true});}async function ue(s){if(!s||s.notificationTeardown||!k||!s.notifyRef)return;let C=await k.subscribe(s.notifyRef,E=>{let L=ro(E);Q(L,{ctx:s,appendState:true,broadcastSse:true,mirrorExternal:false});});s.notificationTeardown=C;}async function G(s){if(!s||s.initialized)return;let C={boardRuntimeStoreRef:s.boardRuntimeStoreRef,cardStoreRef:s.cardStoreRef,outputsStoreRef:s.outputsStoreRef,fetchedSourcesStoreRef:s.fetchedSourcesStoreRef,artifactsStoreRef:s.artifactsStoreRef,queueStoreRef:s.queueStoreRef,chatStoreRef:s.chatStoreRef,scratchStoreRef:s.scratchStoreRef},E={};s.taskExecutorRef&&(E["task-executor-ref"]=s.taskExecutorRef),s.chatHandlerFlow!==void 0&&(E["chat-handler-flow"]=s.chatHandlerFlow);let L=await s.boardOps.init({params:C,body:E});if(L.status!=="success")throw Object.assign(new Error(L.error||`init failed for ${s.label}`),{statusCode:500});if(await ue(s),!s.chatHandlerFlow&&s.chatHandlerRef&&u.describe)try{let H=await u.describe(s.chatHandlerRef);H&&H.kind!=="chat-handler"?c.warn(`[init] chat-handler describe returned kind="${H.kind}", expected "chat-handler" for ${s.label}`):H&&c.info(`[init] chat-handler validated: ${H.name} (protocol ${H.protocolVersion}) for ${s.label}`);}catch(H){c.warn(`[init] chat-handler describe failed for ${s.label}: ${H?.message||String(H)}`);}s.initialized=true;}async function Z(s){let C=[],E=await s.boardOps.status({});E.status==="success"&&E.data!=null&&Jr(E.data)&&C.push({kind:"status",status:E.data});let L=await s.boardOps.getAllOutputsDataObjects({});if(L.status==="success"&&L.data!=null)for(let[ne,X]of Object.entries(L.data))ne&&C.push({kind:"data_object",key:ne,payload:X});let H=await s.boardOps.getAllOutputsComputedValues({});if(H.status==="success"&&H.data!=null)for(let[ne,X]of Object.entries(H.data))ne&&X&&typeof X=="object"&&!Array.isArray(X)&&C.push({kind:"computed_values",cardId:ne,values:X});C.length>0&&Q(C,{ctx:s,appendState:true,broadcastSse:true,mirrorExternal:false});}async function re(s,C){if(!s||s.cardsBootstrapped)return;let E=await s.cardStoreOps.get({}),L=E.status==="success"&&Array.isArray(E.data?.cards)?E.data.cards:[];for(let H of L)typeof H.id=="string"&&(d.set(H.id,C),await s.boardOps.upsertCard({params:{cardId:H.id}}));s.cardsBootstrapped=true;}async function B(){for(let s of i)await G(s);}async function x(){await B();for(let s=0;s<i.length;s++)await Z(i[s]),await re(i[s],s),await Z(i[s]);}async function K(s=false){s||await B();for(let C of i){let E=await C.board.processAccumulatedEvents({});if(E.status!=="success")return E}return {status:"success"}}function y(s){return i[m(s)]??null}async function P(s){let C=y(s);if(!C)return null;let E=await C.cardStoreOps.get({params:{id:s}});if(E.status!=="success")return null;let L=Array.isArray(E.data?.cards)?E.data.cards:[];return L.length>0?L[0]:null}async function q(){let s=async E=>{if(!E)return [];let L=await E.cardStoreOps.get({});return L.status!=="success"||!Array.isArray(L.data?.cards)?[]:L.data.cards},C=[];for(let E of i)C.push(...await s(E));return C}function D(){return i[0]??null}function M(s){return y(s)??D()}function $(s){let C=M(s);if(!C)throw Object.assign(new Error(`Board context is unavailable for chat operations: ${s}`),{statusCode:404});return C.chatStorage}async function se(s){return await $(s).isProcessing(s)}async function ce(s,C){let E=await be.setProcessing({params:{cardId:s},body:{active:C}});if(E.status!=="success")throw Object.assign(new Error(E.error||`Failed to set chat processing for card: ${s}`),{statusCode:500})}let be=to({append(s,C,E,L,H){return $(s).append(s,C,E,L,H)},readAll(s){return $(s).readAll(s)},readAfter(s,C){return $(s).readAfter(s,C)},clear(s){return $(s).clear(s)},setProcessing(s,C){return $(s).setProcessing(s,C)},isProcessing(s){return $(s).isProcessing(s)},getConfig(s){return $(s).getConfig(s)},setConfig(s,C){return $(s).setConfig(s,C)}},{emitNotification(s){if(s.kind==="notification-batch"){te(s.notifications);return}te([s]);}}),Te=ho({boardContexts:i,cardOwnerIndex:d,cardContextForCard:s=>y(s),readStatusSnapshot:()=>he(),readDataObjectsByToken:()=>Je(),readCardRuntimeArtifacts:()=>et(),readCardFromStore:s=>P(s),readCardDefinitions:()=>q(),processAccumulatedLaneInternal:s=>K(s),reportSourceFetched:(s,C)=>Bt(s,{ref:C}),reportSourceFetchFailure:(s,C)=>Vt(s,{reason:C}),uploadCardFile:(s,C,E,L,H)=>ie(s,C,E,L,H),chatStorePublic:be,serverUrl:R,apiBasePath:t}),_e=Te.mcpCardStoreFacade,pe=Te.createMcpFacade,ke=io({boardId:o,bootstrapBoard:()=>x(),sseHub:A,onChannelSubscribed:T,onChannelUnsubscribed:I,getMcpFacade:()=>pe(),getMcpCardStoreFacade:()=>_e()});function Ve(s){return lo(s)}function Se(){return fo(pe())}function Ke(){return mo({boardId:o,uploadCardFile:ie,getMcpFacade:()=>pe(),controlplane:ke})}let qe=uo({boardId:o,boardContexts:i,readChatRecords:(s,C)=>oe(s,C),getChatProcessing:s=>se(s),chatBootstrapTailTurns:a}),he=qe.readStatusSnapshot,et=qe.readCardRuntimeArtifacts,Je=qe.readDataObjectsByToken,tt=qe.buildPublishedRuntimePayload;async function yt(s,C,E){let L=E?.syncBoard!==false,H=E?.restartOnlyIfChanged===true,ne=y(s);if(!ne)throw Object.assign(new Error(`Card not found: ${s}`),{statusCode:404});let X=await P(s);if(!X)throw Object.assign(new Error(`Card not found: ${s}`),{statusCode:404});let le=H?JSON.stringify(X):null,Ue=C(X)||X;if(H&&JSON.stringify(Ue)===le)return;let xe=await ne.cardStoreOps.set({body:Ue});if(xe.status!=="success")throw Object.assign(new Error(xe.error||`Failed to persist card: ${s}`),{statusCode:500});if(L){let He=await ne.boardOps.upsertCard({params:{cardId:s,restart:true}});if(He.status!=="success")throw Object.assign(new Error(He.error||`Failed to upsert card: ${s}`),{statusCode:500})}}async function j(s,C){await yt(s,C,{syncBoard:true});}async function v(s,C){await yt(s,C,{syncBoard:false});}async function W(s){let C=y(s);if(!C)throw Object.assign(new Error(`Card not found: ${s}`),{statusCode:404});if(!await P(s))throw Object.assign(new Error(`Card not found: ${s}`),{statusCode:404});let L=await C.boardOps.upsertCard({params:{cardId:s,restart:true}});if(L.status!=="success")throw Object.assign(new Error(L.error||`Failed to retrigger card: ${s}`),{statusCode:500})}async function F(s){let C=await be.clear({params:{cardId:s}});if(C.status!=="success")throw Object.assign(new Error(C.error||`Failed to clear chat records for card: ${s}`),{statusCode:500});try{await ce(s,!1);}catch{}}async function V(s,C,E,L,H=""){let ne=typeof E=="string"?E.trim():"",X=await be.append({params:{cardId:s},body:{role:C||"system",text:ne,files:L,turn:H}});if(X.status!=="success")throw Object.assign(new Error(X.error||`Failed to append chat record for card: ${s}`),{statusCode:500});return String(X.data?.id||"")}async function oe(s,C){let E=Number.isInteger(C?.tailTurns)&&C?.tailTurns>0?C?.tailTurns:void 0,L=await be.readAll({params:{cardId:s},...E===void 0?{}:{body:{tailTurns:E}}});if(L.status!=="success")throw Object.assign(new Error(L.error||`Failed to read chat records for card: ${s}`),{statusCode:500});return Array.isArray(L.data?.records)?L.data.records:[]}let ie=co({safeCardId:s=>U(s),artifactsStores:s=>O(s),cardFileMetadataStore:()=>N(),readCardFromStore:s=>P(s),updateCardLocalOnly:(s,C)=>v(s,C),writeChatRecord:(s,C,E,L,H)=>V(s,C,E,L,H)}).uploadCardFile;async function Re(s){let C=y(s);if(!C)return null;let E=await C.boardOps.getConfig({params:{key:"chat-handler-flow"}}),H=(E.status==="success"?E.data?.value:null)??C.chatHandlerFlow??null,ne=C.chatHandlerRef;return H==null&&(!ne||typeof ne!="object")?null:{ctx:C,handlerFlow:H,handlerRef:ne}}function Be(s){let C=typeof s=="string"?s.trim():"";if(C.length<Ut.length*2||!C.startsWith(Ut)||!C.endsWith(Ut))return null;let E=C.slice(Ut.length,C.length-Ut.length).trim(),L=/^([A-Za-z0-9_-]+)__(.*)$/s.exec(E);return L?{assistant:L[1].trim().toLowerCase(),text:L[2].trim()}:{assistant:"echo",text:E}}async function je(s,C,E=false,L="",H=""){try{let ne=await Re(s);if(!ne){try{await ce(s,!1);}catch{}return}let{ctx:X,handlerFlow:le,handlerRef:Ue}=ne;if(!E)try{await ce(s,!0);}catch{}let xe={boardId:o,cardId:String(s),lastChatEntryId:C,...L?{turnId:L}:{},...typeof H=="string"&&H.trim()?{probe:H.trim()}:{},...b,...R?{serverUrl:R}:{}},He=le!=null?{meta:"chat-handler-flow",howToRun:"built-in",whatToRun:{kind:"built-in",value:So}}:Ue;rt(X.boardAdapter)?await h(X,"chat-agent").enqueueRequest({boardId:o,ref:He,args:le!=null?{...xe,__chatHandlerFlow:le}:xe}):h(X,"chat-agent").enqueueRequest({boardId:o,ref:He,args:le!=null?{...xe,__chatHandlerFlow:le}:xe}),await Promise.resolve(X.boardAdapter.requestProcessAccumulated?.());}catch(ne){try{await ce(s,!1);}catch{}c.warn(`[chat-handler] queue failed for card "${s}": ${ne instanceof Error?ne.message:String(ne)}`);}}async function Le(s,C,E){if(C.howToRun==="built-in"&&on(C)===So){let L=f,H=E.__chatHandlerFlow,ne={...E};return delete ne.__chatHandlerFlow,L?L.run(H,ne,{boardId:o,cardId:String(ne.cardId||""),label:s.label,logger:c,serverUrl:R,executionExtra:b}):{dispatched:false,error:"chat-handler-flow configured but no chatFlowRunner was provided"}}return u.invoke(C,E)}async function Me(s,C=false){C||await B();let E=typeof s.args?.cardId=="string"?s.args.cardId:"",L=E?y(E):D();if(!L)throw new Error(E?`Board context is unavailable for chat-agent request: ${E}`:"Board context is unavailable for chat-agent request");let H=await Le(L,s.ref,s.args);if(!H.dispatched){if(E)try{await ce(E,!1);}catch{}throw new Error(H.error||`chat-agent dispatch failed for card "${E||"unknown"}"`)}}async function Ye(s,C,E){if(C==="chat-send"){let H=E&&typeof E["turn-id"]=="string"?E["turn-id"]:E&&typeof E.turnId=="string"?E.turnId:E&&typeof E.turn=="string"?E.turn:"";if(E&&"files"in E&&E.files!==void 0&&E.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 ne=Ke(),X=Be(E?.text),le=X?X.text:E?.text,Ue=await gt("manage.add-chat-entry-and-any-attachments",{board_id:o,card_id:s,role:"user",text:le,turn_id:H,files:[]},ne);if(Ue?.status!=="success")throw new Error(nt(Ue,`chat-send append failed for card ${s}`));let xe=Ue?.data?.id;if(typeof xe!="string"||!xe)throw new Error(`chat-send did not return an append id for card ${s}`);let He=await gt("setstate.chat-processing-started",{board_id:o,card_id:s},ne);if(He?.status!=="success")throw new Error(nt(He,`chat-send processing update failed for card ${s}`));je(s,xe,true,H,X?.assistant||"");return}await j(s,H=>{let ne=new Date().toISOString(),X=H.card_data&&typeof H.card_data=="object"?H.card_data:{};if(H.card_data=X,C==="file-upload"){let le=N().normalizeIncoming(E?.files,ne);return le.length>0&&N().merge(X,le),H}if(C==="action"){let le=E&&typeof E.buttonId=="string"?E.buttonId:"";if(!le)return H;X.lastAction={buttonId:le,at:ne},X.lastActionText=`${le} @ ${ne}`;}return H});}function Ge(s,C,E){let L=JSON.stringify(E),H=typeof Buffer<"u"?Buffer.byteLength(L):new TextEncoder().encode(L).length;s.writeHead(C,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":H}),s.end(L);}async function Xe(s,C,E){let L=await P(s);if(!L)throw Object.assign(new Error("Card not found"),{statusCode:404});let H=N().resolve(L.card_data,C,E);if(!H.ok&&H.reason==="stale_reference")throw Object.assign(new Error("File reference is stale. Refresh and try again."),{statusCode:409});if(!H.ok)throw Object.assign(new Error("File not found"),{statusCode:404});let ne=H.file,X=U(s),le=O(s),Ue=String(ne.stored_name||""),xe=`${X}/${Ue}`,He=le.files?await le.files.getBytes(xe):null;if(!He)throw Object.assign(new Error("File not found"),{statusCode:404});return {fileRecord:ne,bytes:He}}async function ft(s,C,E,L){let{fileRecord:H,bytes:ne}=await Xe(C,E,L),X=String(H.name||H.stored_name||"download.bin"),le=String(H.mime_type||"application/octet-stream");s.writeHead(200,{"Content-Type":le,"Content-Disposition":`attachment; filename="${X}"`,"Content-Length":ne.length}),s.end(ne);}function _t(s){let C=String(s||"").toLowerCase();return C.startsWith("text/")||C.includes("json")||C.includes("xml")||C.includes("javascript")||C.includes("typescript")||C.includes("yaml")||C.includes("csv")}function Et(s,C,E){let L=s.split(/\r?\n/);return (C==="head"?L.slice(0,E):L.slice(-E)).join(`
7
7
  `)}async function mt(s){let C=[];for await(let L of s)C.push(L);let E=typeof Buffer<"u"?Buffer.concat(C).toString("utf-8").trim():new TextDecoder().decode(Pr(C)).trim();return E?JSON.parse(E):{}}async function Bt(s,C){let E=typeof C.ref=="string"?C.ref.trim():"";if(!E)return {status:"fail",error:"board-worker success callback requires body.ref"};let L=i[0];return L?L.boardOps.sourceDataFetched({params:{token:s,ref:E}}):{status:"fail",error:"no board context"}}async function Vt(s,C){let E=typeof C.reason=="string"&&C.reason.trim()?C.reason:"unknown",L=i[0];return L?L.boardOps.sourceDataFetchFailure({params:{token:s,reason:E}}):{status:"fail",error:"no board context"}}let tn=Co({sseHub:A,queueSseHub:g,corsHeaders:r,json:Ge,buildPublishedRuntimePayload:()=>tt(),onSseClientConnected:S,onChannelSubscribed:T,onChannelUnsubscribed:I,apiBasePath:t,readJsonBody:s=>mt(s),initBoardAndSetup:()=>B(),bootstrapBoard:()=>x(),boardContexts:i,publishPersistedStateSnapshot:s=>Z(s),upsertCardsFromSource:(s,C)=>re(s,C)}).handleWatchersRoutes,vt=Ro({apiBasePath:t,json:Ge,readJsonBody:s=>mt(s),bootstrapBoard:()=>x(),createMcpFacade:()=>pe(),createMcpToolRegistry:s=>Ve(s),resolveCardFileDownloadPayload:(s,C,E)=>Xe(s,C,E),isLikelyTextMimeType:s=>_t(s),sliceTextByLines:(s,C,E)=>Et(s,C,E)}).handleAgentfaceApi,vr=ko({apiBasePath:t,json:Ge,readJsonBody:s=>mt(s),initBoardAndSetup:()=>B(),createMcpWebhookToolRegistry:()=>Se()}).handleWebhooksApi,ht=_r({apiBasePath:t,json:Ge,readJsonBody:s=>mt(s),bootstrapBoard:()=>x(),createMcpControlplaneToolRegistry:()=>Ke(),retriggerCard:s=>W(s),applyCardAction:(s,C,E)=>Ye(s,C,E),resolveChatHandlerTarget:s=>Re(s),sendCardFileDownloadResponse:(s,C,E,L)=>ft(s,C,E,L)}).handleRuntimeApi,Ht=bo({apiBasePath:t,emitNotifications:s=>te(s),readJsonBody:s=>mt(s),json:(s,C,E)=>Ge(s,C,E)}).handleNotifyRoute;async function Y(s,C,E){return !!(await vt(s,C,E)||await vr(s,C,E)||await tn(s,C,E)||await Ht(s,C,E)||await ht(s,C,E))}return {get apiBasePath(){return t},get corsHeaders(){return r},get queueLaneTuning(){return n},handleRuntimeApi:Y,emitNotification(s){if(s.kind==="notification-batch"){te(s.notifications);return}te([s]);},buildPublishedRuntimePayload:tt,__drainProcessAccumulatedLane:K,handleChatAgentRequest:Me,clearChatRecords:F,reportSourceFetched(s,C){return Bt(s,{ref:C})},reportSourceFetchFailure(s,C){return Vt(s,{reason:C})},get cardStore(){return i[0]?.publicCardStore??{get(){return Promise.resolve({status:"fail",error:"no board context"})},set(){return Promise.resolve({status:"fail",error:"no board context"})}}}}}function _a(e){let t=String(e.apiBasePath||"/api/boards").replace(/\/$/,""),r={...wo,...e.corsHeaders||{}},n=e.serverMetaStore,o=e.boardRuntimeFactory,a=new Map,c="boards-config.json";function u(){let A=n.getText(c);if(!A)return {boards:[{id:"default",label:"Default Board"}]};try{return JSON.parse(A)}catch{return {boards:[{id:"default",label:"Default Board"}]}}}function f(A){n.putText(c,JSON.stringify(A,null,2));}function k(A){let g=String(A||"").replace(/[^a-zA-Z0-9_-]/g,"_").replace(/^_+|_+$/g,"");return g.length>0&&g.length<=64?g:null}function R(A){if(a.has(A))return a.get(A);let l=u().boards.find(d=>d.id===A)||{},i=o(A,l);return a.set(A,i),i}function b(A,g,l){let i=JSON.stringify(l),d=typeof Buffer<"u"?Buffer.byteLength(i):new TextEncoder().encode(i).length;A.writeHead(g,{...r,"Content-Type":"application/json; charset=utf-8","Content-Length":d}),A.end(i);}async function S(A,g,l){let i=A.method||"GET",d=l.pathname;if(i==="GET"&&d===t)return b(g,200,{ok:true,boards:u().boards}),true;if(i==="POST"&&d===t){let m=[];for await(let J of A)m.push(J);let p=typeof Buffer<"u"?Buffer.concat(m).toString("utf-8").trim():new TextDecoder().decode(Pr(m)).trim(),h={};try{h=p?JSON.parse(p):{};}catch{h={};}let w=k(h.id);if(!w)return b(g,400,{error:"board id must be 1-64 alphanumeric/dash/underscore characters"}),true;let O=u();if(O.boards.some(J=>J.id===w))return b(g,409,{error:`Board "${w}" is already registered`}),true;let N=typeof h.label=="string"&&h.label.trim()?h.label.trim():w,U={id:w,label:N};for(let[J,ae]of Object.entries(h))J==="id"||J==="label"||ae!=null&&(U[J]=ae);return O.boards.push(U),f(O),b(g,200,{ok:true,board:U}),true}return false}async function _(A,g,l){let d=l.pathname.match(new RegExp(`^${st(t)}/([^/]+)(/|$)`));if(!d)return false;let m=k(decodeURIComponent(d[1]));return m?u().boards.some(w=>w.id===m)?!!await R(m).handleRuntimeApi(A,g,l):(b(g,404,{error:`Board "${m}" not registered. POST ${t} with {id} to register it first.`}),true):(b(g,400,{error:"Invalid board id"}),true)}async function T(A,g,l){return !!(await S(A,g,l)||await _(A,g,l))}function I(A){if(!u().boards.some(l=>l.id===A))throw Object.assign(new Error(`Board "${A}" not registered`),{statusCode:404});return {service:R(A)}}return {get apiBasePath(){return t},get corsHeaders(){return r},handleApi:T,requireBoardService:I}}exports.createMultiBoardServerRuntime=_a;exports.createRoutesRuntimeApi=_r;exports.createSingleBoardServerRuntime=Pa;return exports;})({});//# sourceMappingURL=server-runtime-controlface.js.map
8
8
  //# sourceMappingURL=server-runtime-controlface.js.map
@@ -0,0 +1,67 @@
1
+ #!/usr/bin/env node
2
+
3
+ import fs from 'node:fs';
4
+ import os from 'node:os';
5
+ import path from 'node:path';
6
+
7
+ import {
8
+ createBoardContainerLifecycle,
9
+ createFsBoardContainerStorage,
10
+ } from 'yaml-flow/board-live-cards-node';
11
+
12
+ function main() {
13
+ const rootDir = fs.mkdtempSync(path.join(os.tmpdir(), 'yaml-flow-board-container-example-'));
14
+ const boardsDir = path.join(rootDir, 'boards');
15
+ const layoutsDir = path.join(rootDir, 'layouts');
16
+ const deprecatedDir = path.join(rootDir, 'deprecated');
17
+ const workspaceDir = path.join(rootDir, 'workspace-demo');
18
+ fs.mkdirSync(workspaceDir, { recursive: true });
19
+
20
+ const storage = createFsBoardContainerStorage({
21
+ registry: {
22
+ boardsIndexRef: { kind: 'fs-path', value: boardsDir },
23
+ boardsLayoutRef: { kind: 'fs-path', value: layoutsDir },
24
+ deprecatedContainerRef: { kind: 'fs-path', value: deprecatedDir },
25
+ },
26
+ });
27
+
28
+ const lifecycle = createBoardContainerLifecycle({
29
+ storage,
30
+ hydrate(boardId, record) {
31
+ return { id: boardId, ...record };
32
+ },
33
+ resolveWorkspaceDir(_board, record) {
34
+ return record?.refs?.baseRef?.kind === 'fs-path' ? String(record.refs.baseRef.value || '') : '';
35
+ },
36
+ });
37
+
38
+ const boardRecord = {
39
+ id: 'demo-board',
40
+ label: 'Demo Board',
41
+ metadata: { pageTitle: 'Lifecycle Demo' },
42
+ refs: {
43
+ baseRef: { kind: 'fs-path', value: workspaceDir },
44
+ },
45
+ };
46
+
47
+ return lifecycle.provision('demo-board', boardRecord, {
48
+ layout: { canvas: { zoom: 1, panX: 0, panY: 0 } },
49
+ })
50
+ .then(async () => {
51
+ console.log('provisioned:', await lifecycle.get('demo-board'));
52
+ await lifecycle.saveMeta('demo-board', { pageSubtitle: 'Example Subtitle' });
53
+ await lifecycle.saveLayout('demo-board', { canvas: { zoom: 1.25, panX: 24, panY: 12 } });
54
+ console.log('updated record:', await lifecycle.get('demo-board'));
55
+ console.log('updated layout:', await lifecycle.getLayout('demo-board'));
56
+ const archived = await lifecycle.deprecate('demo-board');
57
+ console.log('archived:', archived);
58
+ })
59
+ .finally(() => {
60
+ fs.rmSync(rootDir, { recursive: true, force: true });
61
+ });
62
+ }
63
+
64
+ main().catch((error) => {
65
+ console.error(error instanceof Error ? error.message : String(error));
66
+ process.exit(1);
67
+ });
@@ -0,0 +1,57 @@
1
+ type BoardContainerArchiveResult = {
2
+ archiveId: string;
3
+ archiveRecordPath: string;
4
+ archiveWorkspaceDir: string;
5
+ [key: string]: unknown;
6
+ };
7
+ type BoardContainerProvisionOptions<TLayout> = {
8
+ layout?: TLayout | null;
9
+ };
10
+ interface BoardContainerStorage<TRecord, TLayout = unknown> {
11
+ kind?: string;
12
+ list(): Promise<Array<{
13
+ id: string;
14
+ record: TRecord;
15
+ }>>;
16
+ get(id: string): Promise<TRecord | null>;
17
+ has(id: string): Promise<boolean>;
18
+ put(id: string, record: TRecord): Promise<void>;
19
+ set(id: string, record: TRecord): Promise<void>;
20
+ getLayout?(id: string): Promise<TLayout | null>;
21
+ setLayout?(id: string, layout: TLayout): Promise<void>;
22
+ removeLayout?(id: string): Promise<void>;
23
+ provision?(id: string, record: TRecord, options?: BoardContainerProvisionOptions<TLayout>): Promise<void>;
24
+ archive?(id: string, options?: {
25
+ workspaceDir?: string;
26
+ }): Promise<BoardContainerArchiveResult | null>;
27
+ deprecate?(id: string, options?: {
28
+ workspaceDir?: string;
29
+ }): Promise<BoardContainerArchiveResult | null>;
30
+ }
31
+ type CreateBoardContainerLifecycleOptions<TRecord, THydrated, TLayout = unknown> = {
32
+ storage: BoardContainerStorage<TRecord, TLayout>;
33
+ hydrate: (boardId: string, record: TRecord) => THydrated;
34
+ resolveWorkspaceDir?: (board: THydrated, record: TRecord) => string;
35
+ };
36
+ declare function createBoardContainerLifecycle<TRecord, THydrated, TLayout = unknown>(options: CreateBoardContainerLifecycleOptions<TRecord, THydrated, TLayout>): {
37
+ kind: string;
38
+ storage: BoardContainerStorage<TRecord, TLayout>;
39
+ list: () => Promise<THydrated[]>;
40
+ get: (boardId: string) => Promise<THydrated | null>;
41
+ has: (boardId: string) => Promise<boolean>;
42
+ provision: (boardId: string, record: TRecord, provisionOptions?: BoardContainerProvisionOptions<TLayout>) => Promise<THydrated>;
43
+ add: (boardId: string, record: TRecord) => Promise<THydrated>;
44
+ saveMeta: (boardId: string, metadata: Record<string, unknown>) => Promise<THydrated | null>;
45
+ saveRecord: (boardId: string, patch: TRecord) => Promise<THydrated | null>;
46
+ getLayout: (boardId: string) => Promise<TLayout | null>;
47
+ saveLayout: (boardId: string, layout: TLayout) => Promise<TLayout>;
48
+ removeLayout: (boardId: string) => Promise<void>;
49
+ deprecate: (boardId: string) => Promise<{
50
+ archiveId: string;
51
+ archiveRecordPath: string;
52
+ archiveWorkspaceDir: string;
53
+ board: THydrated;
54
+ } | null>;
55
+ };
56
+
57
+ export { type BoardContainerArchiveResult as B, type CreateBoardContainerLifecycleOptions as C, type BoardContainerProvisionOptions as a, type BoardContainerStorage as b, createBoardContainerLifecycle as c };
@@ -0,0 +1,57 @@
1
+ type BoardContainerArchiveResult = {
2
+ archiveId: string;
3
+ archiveRecordPath: string;
4
+ archiveWorkspaceDir: string;
5
+ [key: string]: unknown;
6
+ };
7
+ type BoardContainerProvisionOptions<TLayout> = {
8
+ layout?: TLayout | null;
9
+ };
10
+ interface BoardContainerStorage<TRecord, TLayout = unknown> {
11
+ kind?: string;
12
+ list(): Promise<Array<{
13
+ id: string;
14
+ record: TRecord;
15
+ }>>;
16
+ get(id: string): Promise<TRecord | null>;
17
+ has(id: string): Promise<boolean>;
18
+ put(id: string, record: TRecord): Promise<void>;
19
+ set(id: string, record: TRecord): Promise<void>;
20
+ getLayout?(id: string): Promise<TLayout | null>;
21
+ setLayout?(id: string, layout: TLayout): Promise<void>;
22
+ removeLayout?(id: string): Promise<void>;
23
+ provision?(id: string, record: TRecord, options?: BoardContainerProvisionOptions<TLayout>): Promise<void>;
24
+ archive?(id: string, options?: {
25
+ workspaceDir?: string;
26
+ }): Promise<BoardContainerArchiveResult | null>;
27
+ deprecate?(id: string, options?: {
28
+ workspaceDir?: string;
29
+ }): Promise<BoardContainerArchiveResult | null>;
30
+ }
31
+ type CreateBoardContainerLifecycleOptions<TRecord, THydrated, TLayout = unknown> = {
32
+ storage: BoardContainerStorage<TRecord, TLayout>;
33
+ hydrate: (boardId: string, record: TRecord) => THydrated;
34
+ resolveWorkspaceDir?: (board: THydrated, record: TRecord) => string;
35
+ };
36
+ declare function createBoardContainerLifecycle<TRecord, THydrated, TLayout = unknown>(options: CreateBoardContainerLifecycleOptions<TRecord, THydrated, TLayout>): {
37
+ kind: string;
38
+ storage: BoardContainerStorage<TRecord, TLayout>;
39
+ list: () => Promise<THydrated[]>;
40
+ get: (boardId: string) => Promise<THydrated | null>;
41
+ has: (boardId: string) => Promise<boolean>;
42
+ provision: (boardId: string, record: TRecord, provisionOptions?: BoardContainerProvisionOptions<TLayout>) => Promise<THydrated>;
43
+ add: (boardId: string, record: TRecord) => Promise<THydrated>;
44
+ saveMeta: (boardId: string, metadata: Record<string, unknown>) => Promise<THydrated | null>;
45
+ saveRecord: (boardId: string, patch: TRecord) => Promise<THydrated | null>;
46
+ getLayout: (boardId: string) => Promise<TLayout | null>;
47
+ saveLayout: (boardId: string, layout: TLayout) => Promise<TLayout>;
48
+ removeLayout: (boardId: string) => Promise<void>;
49
+ deprecate: (boardId: string) => Promise<{
50
+ archiveId: string;
51
+ archiveRecordPath: string;
52
+ archiveWorkspaceDir: string;
53
+ board: THydrated;
54
+ } | null>;
55
+ };
56
+
57
+ export { type BoardContainerArchiveResult as B, type CreateBoardContainerLifecycleOptions as C, type BoardContainerProvisionOptions as a, type BoardContainerStorage as b, createBoardContainerLifecycle as c };