yaml-flow 8.11.7 → 8.11.8

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 (74) hide show
  1. package/browser/asset-integrity.json +5 -5
  2. package/browser/live-cards.schema.json +4 -0
  3. package/browser/server-runtime-controlface.js +4 -4
  4. package/examples/board/cards/card-rebalance-sim.json +4 -1
  5. package/lib/board-live-cards-mcp.cjs +1 -1
  6. package/lib/board-live-cards-mcp.js +1 -1
  7. package/lib/board-live-cards-node.cjs +6 -6
  8. package/lib/board-live-cards-node.js +6 -6
  9. package/lib/board-live-cards-public.cjs +1 -1
  10. package/lib/board-live-cards-public.js +1 -1
  11. package/lib/board-live-cards-server-runtime.cjs +1 -1
  12. package/lib/board-live-cards-server-runtime.js +1 -1
  13. package/lib/board-livegraph-runtime/index.cjs +1 -1
  14. package/lib/board-livegraph-runtime/index.js +1 -1
  15. package/lib/card-compute/index.cjs +1 -1
  16. package/lib/card-compute/index.d.cts +6 -0
  17. package/lib/card-compute/index.d.ts +6 -0
  18. package/lib/card-compute/index.js +1 -1
  19. package/lib/card-store-public.cjs +1 -1
  20. package/lib/card-store-public.js +1 -1
  21. package/lib/card-validation.cjs +1 -1
  22. package/lib/card-validation.js +1 -1
  23. package/lib/{chunk-NOAERAOE.cjs → chunk-36KKCQVE.cjs} +2 -2
  24. package/lib/chunk-3DWVFRQD.cjs +3 -0
  25. package/lib/chunk-3SLSRX6Q.js +3 -0
  26. package/lib/{chunk-EHREWADE.js → chunk-4NWVZ7AW.js} +2 -2
  27. package/lib/chunk-543ZEGP7.cjs +2 -0
  28. package/lib/{chunk-YAPTL2MP.cjs → chunk-6SPWFJRG.cjs} +2 -2
  29. package/lib/{chunk-HKPVF5UI.js → chunk-BA25VGJP.js} +3 -3
  30. package/lib/chunk-BRYV6CDD.js +3 -0
  31. package/lib/chunk-EGZPROOH.cjs +3 -0
  32. package/lib/{chunk-GHUW6P4G.cjs → chunk-ESTFYRHF.cjs} +2 -2
  33. package/lib/{chunk-52XPRCZC.cjs → chunk-HOS2ZUFZ.cjs} +2 -2
  34. package/lib/chunk-JOQWJ3VR.cjs +2 -0
  35. package/lib/chunk-MRESV3MD.js +2 -0
  36. package/lib/chunk-MRIFSG7L.cjs +3 -0
  37. package/lib/{chunk-6M3RIGUH.js → chunk-NN52BT3Q.js} +2 -2
  38. package/lib/{chunk-TUQ6JBER.cjs → chunk-OR6B2H2Y.cjs} +3 -3
  39. package/lib/{chunk-I3ZOFU3F.js → chunk-PIPXFUEA.js} +2 -2
  40. package/lib/chunk-REZO2QJD.js +3 -0
  41. package/lib/{chunk-23PEDGFN.js → chunk-ROIYEFSE.js} +2 -2
  42. package/lib/chunk-UJQ7IML5.js +2 -0
  43. package/lib/chunk-YOY2JM5N.js +2 -0
  44. package/lib/chunk-ZV35WD6K.cjs +2 -0
  45. package/lib/cloud-storage.cjs +1 -1
  46. package/lib/cloud-storage.js +1 -1
  47. package/lib/continuous-event-graph/index.cjs +1 -1
  48. package/lib/continuous-event-graph/index.js +1 -1
  49. package/lib/firestore-storage/index.cjs +1 -1
  50. package/lib/firestore-storage/index.js +1 -1
  51. package/lib/index.cjs +2 -2
  52. package/lib/index.js +1 -1
  53. package/lib/localstorage-storage/index.cjs +1 -1
  54. package/lib/localstorage-storage/index.js +1 -1
  55. package/lib/server-runtime/index.cjs +1 -1
  56. package/lib/server-runtime/index.js +1 -1
  57. package/lib/server-runtime-controlface/index.cjs +1 -1
  58. package/lib/server-runtime-controlface/index.js +1 -1
  59. package/lib/server-runtime-core/index.cjs +1 -1
  60. package/lib/server-runtime-core/index.js +1 -1
  61. package/package.json +1 -1
  62. package/schema/live-cards.schema.json +4 -0
  63. package/lib/chunk-2LGCYN35.js +0 -2
  64. package/lib/chunk-3XPY7CCM.cjs +0 -3
  65. package/lib/chunk-ATOQP3BD.js +0 -2
  66. package/lib/chunk-CPJXGK2T.cjs +0 -2
  67. package/lib/chunk-J7KE7SPA.cjs +0 -2
  68. package/lib/chunk-K5TEZRZK.cjs +0 -3
  69. package/lib/chunk-QBEQL4TL.cjs +0 -2
  70. package/lib/chunk-QEHKMLHA.cjs +0 -3
  71. package/lib/chunk-RKLEBQUG.js +0 -3
  72. package/lib/chunk-WGYS2L4V.js +0 -2
  73. package/lib/chunk-X32SJDLT.js +0 -3
  74. package/lib/chunk-YT76JNKE.js +0 -3
@@ -1,2 +1,2 @@
1
- import {a as a$1}from'./chunk-FOFGEABN.js';import {a,c,d,e,b,f}from'./chunk-O7NOHKVR.js';import {a as a$2}from'./chunk-6M3RIGUH.js';import {b as b$1}from'./chunk-44L64VQ2.js';function M(a){if(!a||typeof a!="object")return false;let t=a;return typeof t.kind=="string"&&t.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let t=a;return t.kind==="notification-batch"?Array.isArray(t.notifications)?t.notifications.filter(M):[]:M(a)?[a]:[]}function X(a,t,i){let c=0;return {accepted:a.filter(_=>{if(!M(_))return c++,false;let S=_;return typeof S.sentAtMs=="number"&&t-S.sentAtMs>i?(c++,false):true}),rejected:c}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let t=a.summary;return !t||typeof t!="object"?false:Number(t.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let t=a;return t.kind==="notification-batch"&&Array.isArray(t.notifications)}function V(a,t){if(t.kind==="status"){z(t.status)&&(a.status=t.status);return}if(t.kind==="computed_values"){a.computedValues[t.cardId]=t.values;return}if(t.kind==="data_object"){a.dataObjects[t.key]=t.payload;return}if(t.kind==="card_refreshed"){a.cards[t.cardId]=t.card;return}t.kind==="card_removed"&&(delete a.cards[t.cardId],delete a.computedValues[t.cardId]);}function Y(a,t){if(W(t)){for(let i of t.notifications)M(i)&&V(a,i);return}M(t)&&V(a,t);}function j(a,t){if(a?.status==="success")return Object.prototype.hasOwnProperty.call(a,"data")?a.data:void 0;throw a?.status==="fail"||a?.status==="error"?Object.assign(new Error(a.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function N(a,t){return j(await a,t)}function T(a$1){let t=a(a$1,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=t.split(".");if(!(i.length>=2&&i.every(g=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(g))))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 q(a,t){let i=a.__private;for(let c of t.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,c))return {exists:false,value:null};i=i[c];}return {exists:true,value:i}}function ot(a$1){let{boardId:t,bootstrapBoard:i,sseHub:c,onChannelSubscribed:g,onChannelUnsubscribed:_,getMcpFacade:S,getMcpCardStoreFacade:n}=a$1;function f(s){let d=a(s,"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 h(s){let d=a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function w(s){f(s);let d=h(s),e=a(s,"channel_name"),r=a(s,"card_id")||void 0;if(!e)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:e,...r?{cardId:r}:{}}}function R(s){f(s);let d=a(s,"card_id");if(!d)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:d}}async function I(s){await i();let{cardId:d}=R(s),e=h(s);if(!await c.subscribeChat(e,d))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:e,subscribed:true}}}async function u(s){await i();let{cardId:d}=R(s),e=h(s);if(!c.unsubscribeChat(e,d))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:e,subscribed:false}}}async function b(s,d){await i();let{clientId:e,channelName:r,cardId:o}=w(s);if(!c.has(e))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return d?(c.subscribeChannel(e,r,o),g?.(e,r,o?{cardId:o}:{})):(c.unsubscribeChannel(e,r,o),_?.(e,r,o?{cardId:o}:{})),{status:"success",data:{boardId:t,clientId:e,channelName:r,subscribed:d,...o?{cardId:o}:{}}}}async function m(s,d){let{cardId:e}=R(s);return await S().setChatProcessing({cardId:e,active:d}),{status:"success",data:{boardId:t,cardId:e,active:d}}}async function p(s){let{cardId:d}=R(s),e=await S().getChatProcessing({cardId:d});return {status:"success",data:{boardId:t,cardId:d,active:e.active}}}async function y(s){let{cardId:d}=R(s),e=T(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(e.split(".").includes("visible_controlplane_only")){let r=await N(n().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(r.cards)&&r.cards.length>0&&typeof r.cards[0]=="object"&&!Array.isArray(r.cards[0])?r.cards[0]:null,k=o?q(o,"visible_controlplane_only").value:void 0;if(s.value!==k)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:d,key:e}}}return j(await n().patch({params:{id:d,path:`__private.${e}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:d,key:e}}}async function C(s){let{cardId:d}=R(s),e=T(s),r=await N(n().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(r.cards)&&r.cards.length>0&&r.cards[0]&&typeof r.cards[0]=="object"&&!Array.isArray(r.cards[0])?r.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=q(o,e);return {status:"success",data:{boardId:t,cardId:d,key:e,exists:k.exists,value:k.value}}}return {requireCardArgs:R,subscribeChat:I,unsubscribeChat:u,watchChannel:b,setChatProcessing:m,getChatProcessing:p,setCardMeta:y,getCardMeta:C}}function it(a){let{boardId:t,boardContexts:i,readChatRecords:c,getChatProcessing:g}=a,_=Number.isInteger(a.chatBootstrapTailTurns)&&a.chatBootstrapTailTurns>0?a.chatBootstrapTailTurns:1;function S(u){return {role:String(u.role||"system"),text:String(u.text||""),files:Array.isArray(u.files)?u.files:[],...typeof u.turn=="string"&&u.turn?{turn:u.turn}:{}}}function n(u){if(u.length===0)return null;if(u.length===1)return u[0];let b=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],p={};for(let C of m)p[C]=0;for(let C of u){let s=C,d=Array.isArray(s.cards)?s.cards:[];b.push(...d);for(let e of m)p[e]+=Number(s?.summary?.[e]||0);}let y=u[0];return {...y,cards:b,summary:{...y.summary||{},card_count:b.length,...p}}}async function f(){let u=[];for(let b of i)try{let m=await b.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&u.push(m.data);}catch{}return u}async function h(){let b=(await f()).map(m=>m.statusSnapshot).filter(Boolean);if(b.length===0){let m=i.map(p=>p.notification.status).filter(Boolean);return n(m)}return n(b)}async function w(){let u={},b=await f();for(let m of b)Object.assign(u,m.cardRuntimeById||{});if(Object.keys(u).length>0)return u;for(let m of i)for(let[p,y]of Object.entries(m.notification.computedValues)){let C=m.notification.cards[p];u[p]={schema_version:"v1",card_id:p,card_data:C?.card_data??{},computed_values:y??{}};}return u}async function R(){let u={},b=await f();for(let m of b)Object.assign(u,m.dataObjectsByToken||{});if(Object.keys(u).length===0)for(let m of i)Object.assign(u,m.notification.dataObjects||{});return u}async function I(){let u=await f(),b=u.flatMap(C=>Array.isArray(C.cardDefinitions)?C.cardDefinitions:[]),m={},p={};for(let C of u)Object.assign(m,C.dataObjectsByToken||{}),Object.assign(p,C.cardRuntimeById||{});let y={};for(let C of b){if(!C?.id)continue;let s=C.id;try{let d=await c(s,{tailTurns:_}),e=await g(s);(d.length>0||e)&&(y[s]={messages:d.map(r=>S(r)),receiving:!1,processing:e});}catch{}}return {boardId:t,cardDefinitions:b,statusSnapshot:await h(),dataObjectsByToken:m,cardRuntimeById:p,cardChatsByCardId:y}}return {readStatusSnapshot:h,readCardRuntimeArtifacts:w,readDataObjectsByToken:R,buildPublishedRuntimePayload:I}}function K(a){let t=String(a||"").trim();if(!t)return "upload.bin";let i=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (i>=0?t.slice(i+1):t)||"upload.bin"}function ct(a){let{safeCardId:t,artifactsStores:i,cardFileMetadataStore:c,readCardFromStore:g,updateCardLocalOnly:_,writeChatRecord:S}=a;async function n(w){let R=[];try{let I=await g(w);if(!I)return R;let u=c().read(I.card_data&&typeof I.card_data=="object"?I.card_data:null);for(let b of u)R.push(String(b.stored_name??""));}catch{}return R}async function f(w,R,I,u){let b=t(w),m=i(w),p=K(R),y=await n(w),s=`${String(y.length+1).padStart(3,"0")}-${p}`.slice(-36);if(!m.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${w}`),{statusCode:500});return await m.files.putBytes(`${b}/${s}`,new Uint8Array(u),I||"application/octet-stream"),{name:p,stored_name:s,size:u.length,mime_type:I||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function h(w,R,I,u,b){if(!u.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let m=b?.inChat===true,p=await f(w,R,I,u),y=null;if(await _(w,C=>{let s=new Date().toISOString(),d=C.card_data&&typeof C.card_data=="object"?C.card_data:{};C.card_data=d;let e=c().normalizeIncoming([{name:p.name,stored_name:p.stored_name,size:p.size,mime_type:p.mime_type,uploaded_at:p.uploaded_at||s,chat:m}],s);return y=c().merge(d,e).findIndex(o=>o.stored_name===p.stored_name),C}),m&&b?.suppressChatRecordWrite!==true){let C=typeof y=="number"&&y>=0?` #${y}`:"";await S(w,"system",`file uploaded: ${p.name} as ${p.stored_name}${C}`,[],b?.turnId??"");}return {ok:true,file:{...p,...typeof y=="number"&&y>=0?{file_idx:y}:{},chat:m},...typeof y=="number"&&y>=0?{file_idx:y}:{}}}return {uploadCardFile:h,readCardStoredFileNames:n}}function pt(a$1){return {"discover.source-kinds":()=>a$1.discoverSourceKinds(),"inspect.board-runtime-status":()=>a$1.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>a$1.inspectCardDefinitionAndRuntime({cardId:a(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let i=b(t,"tail_turns"),c=b(t,"tail"),g=a(t,"turn_id"),_=t.all_turns===true,S=a(t,"tail_turns_before_id");return a$1.inspectChatMessagesOnCards({cardId:a(t,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...c!==void 0?{tail:c}:{},...g?{turnId:g}:{},..._?{allTurns:true}:{},...S?{tailTurnsBeforeId:S}:{}})},"inspect.file-contents":t=>a$1.inspectFileContents({cardId:a(t,"card_id"),fileIdx:Number(b(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>a$1.preflightValidateCandidateCardDefinition({candidateCardContent:d(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>a$1.preflightMaterializeCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockRequires:d(t,"mock_requires","mock_requires"),mockFetchedSources:d(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>a$1.preflightProbeSingleSourceInCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockProjections:c(t,"mock_projections"),sourceIdx:e(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>a$1.preflightRunSingleSourceInCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockProjections:c(t,"mock_projections"),sourceIdx:e(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>a$1.preflightRunSingleSourceInLiveCard({cardId:a(t,"card_id"),sourceIdx:e(t,"source_idx","source_idx"),mockRequires:d(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>a$1.preflightRunOneCycleWithCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockRequires:c(t,"mock_requires")}),"manage.read-card":t=>a$1.manageReadCard({cardId:a(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let i=a(t,"turn_id");if(!i)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...i?{turn:i}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"stage-ai-failure-message":t=>{let i=a(t,"turn_id"),c=a(t,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!c)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(t,"card_id"),role:"system",text:c,turn:i})},"manage.upsert-card":t=>a$1.manageUpsertCard({cardId:a(t,"card_id"),candidateCardContent:c(t,"candidate_card_content")}),"manage.remove-card":t=>a$1.manageRemoveCard({cardId:a(t,"card_id")})}}function mt(a$1){return {"webhook.process-accumulated":()=>a$1.webhookProcessAccumulated(),"webhook.source-fetch-done":t=>a$1.webhookSourceFetchDone({token:a(t,"token"),ref:a(t,"ref")}),"webhook.source-fetch-failed":t=>a$1.webhookSourceFetchFailed({token:a(t,"token"),reason:a(t,"reason")})}}function ft(a$1){let{boardId:t,uploadCardFile:i,getMcpFacade:c$1,controlplane:g}=a$1;function _(n,f){let h=a(n,"board_id");if(!h)throw Object.assign(new Error(`${f} requires board_id`),{statusCode:400});if(h!==t)throw Object.assign(new Error(`Unknown board_id: ${h}`),{statusCode:400})}function S(n,f){let{cardId:h}=g.requireCardArgs(n),w=a(n,"turn_id");return _(n,f),c$1().manageAddChatAttachment({cardId:h,role:a(n,"role")||"user",...w?{turn:w}:{},files:[{file_name:a(n,"file_name"),content_type:a(n,"content_type")||"application/octet-stream",...typeof n.text=="string"?{text:n.text}:{},...typeof n.base64=="string"?{base64:n.base64}:{},...Array.isArray(n.bytes)?{bytes:n.bytes}:{}}]})}return {"list-runtime-cards":n=>(_(n,"list-runtime-cards"),c$1().listRuntimeCards()),"sse.subscribe-chat":n=>g.subscribeChat(n),"sse.unsubscribe-chat":n=>g.unsubscribeChat(n),"sse.watch-channel":n=>g.watchChannel(n,true),"sse.unwatch-channel":n=>g.watchChannel(n,false),"getstate.is-chat-processing":n=>g.getChatProcessing(n),"setstate.chat-processing-started":n=>g.setChatProcessing(n,true),"setstate.chat-processing-done":n=>g.setChatProcessing(n,false),"getstate.card-private":n=>g.getCardMeta(n),"setstate.card-private":n=>g.setCardMeta(n),"manage.upload-card-file":n=>{let f$1=a(n,"card_id"),h=a(n,"file_name"),w=a(n,"content_type")||"application/octet-stream",R=f(n);if(_(n,"manage.upload-card-file"),!f$1)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!h)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!R)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(f$1,h,w,R,{inChat:false})},"manage.add-chat-attachment":n=>S(n,"manage.add-chat-attachment"),"manage.add-chat-attachement":n=>S(n,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":n=>{let{cardId:f}=g.requireCardArgs(n),h=a(n,"role")||"user",w=a(n,"turn_id");return _(n,"manage.add-chat-entry-and-any-attachments"),c$1().manageAddChatEntryAndAnyAttachments({cardId:f,role:h,...typeof n.text=="string"?{text:n.text}:{},...w?{turn:w}:{},...Array.isArray(n.files)?{files:n.files}:{}})},"manage.patch-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.patch-card"),c$1().managePatchCard({cardId:f,patch:c(n,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.upsert-card"),c$1().manageUpsertCard({cardId:f,candidateCardContent:c(n,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.remove-card"),c$1().manageRemoveCard({cardId:f},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async n=>{let{cardId:f}=g.requireCardArgs(n);return {status:"success",data:{cards:await c$1().adminReadCard({cardId:f})}}},"manage.admin-upsert-card":n=>{let f=a(n,"board_id"),h=a(n,"card_id");if(!f)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!h)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 c$1().adminUpsertCard({cardId:h,candidateCardContent:c(n,"candidate_card_content")})}}}function yt(a){let{boardContexts:t,cardOwnerIndex:i,cardContextForCard:c,readStatusSnapshot:g,readDataObjectsByToken:_,readCardRuntimeArtifacts:S,readCardFromStore:n,readCardDefinitions:f,processAccumulatedLaneInternal:h,reportSourceFetched:w,reportSourceFetchFailure:R,uploadCardFile:I,chatStorePublic:u,serverUrl:b,apiBasePath:m}=a;function p(){return t[0]??null}function y(){return {async status(){let e=await g();return e==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:e}},async getOutputsDataObject(e){let r=e?.params?.key;return r?{status:"success",data:(await _())[r]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(e){let r=e?.params?.key;return r?{status:"success",data:(await S())[r]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(e){let r=e?.params?.key;if(!r)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=c(r)??p();return o?o.boardOps.getOutputsFetchedSources({params:{key:r}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(e){let r=e?.params?.id;if(!r)return {status:"fail",error:"removeCard requires params.id"};let o=c(r)??p();return o?o.boardOps.removeCard({params:{id:r}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(e){let r=e?.params?.cardId;if(!r)return {status:"fail",error:"upsertCard requires params.cardId"};let o=c(r)??p();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:r,restart:e.params.restart===true}});if(k.status!=="success")return k;if(a$1(o.boardAdapter)){let P=await h(true);if(P.status!=="success")return P}return k}}}function C(){let e=()=>{let r=p();if(!r?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return r.nonCore};return {describeTaskExecutorCapabilities(r){return e().describeTaskExecutorCapabilities(r)},validateCardPreflight(r){return e().validateCardPreflight(r)},evalCardCompute(r){return e().evalCardCompute(r)},probeSourcePreflight(r){return e().probeSourcePreflight(r)},runSourcePreflight(r){return e().runSourcePreflight(r)},simulateCardCycle(r){return e().simulateCardCycle(r)}}}function s(){return {async get(e){let r=typeof e.params?.id=="string"?e.params.id:void 0;if(r){let o=await n(r);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await f()}}},async set(e){let r=e.body;if(r==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(r)?r:[r];for(let k of o){let P=k,A=typeof P.id=="string"?P.id:"";if(!A)return {status:"fail",error:"each card must have a string `id` field"};let E=i.get(A)??0,D=t[E]??p();if(!D)return {status:"fail",error:"Board context is unavailable"};let L=await D.cardStoreOps.set({body:P});if(L.status!=="success")return L;i.set(A,E);}return {status:"success",data:{count:o.length}}},async del(e){let r=[e.params?.id,...e.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(r.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of r){let k=c(o)??p();if(!k)return {status:"fail",error:"Board context is unavailable"};let P=await k.cardStoreOps.del({params:{id:o}});if(P.status!=="success")return P;i.delete(o);}return {status:"success",data:{count:r.length}}},async patch(e){let r=typeof e.params?.id=="string"?e.params.id:void 0,o=typeof e.params?.path=="string"?e.params.path:void 0;if(!r||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=c(r)??p();return k?k.cardStoreOps.patch(e):{status:"fail",error:"Board context is unavailable"}},async appendFiles(e){let r=typeof e.params?.id=="string"?e.params.id:void 0;if(!r)return {status:"fail",error:"appendFiles requires params.id"};let o=c(r)??p();return o?o.cardStoreOps.appendFiles(e):{status:"fail",error:"Board context is unavailable"}}}}function d(){return a$2({board:y(),nonCore:C(),cardStore:s(),chatStore:u,processAccumulated:()=>h(true),sourceFetchDone:({token:e,ref:r})=>w(e,r),sourceFetchFailed:({token:e,reason:r})=>R(e,r),uploadCardFile({cardId:e,fileName:r,contentType:o,bytes:k,suppressChatRecordWrite:P}){return I(e,r,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:e,fileIdx:r,storedName:o}){let k=`${b||""}${m}/cards/${encodeURIComponent(e)}/files/${r}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:e,ref:r}){let o=c(e)??p();if(!o||a$1(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(b$1(r)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:y,mcpNonCoreFacade:C,mcpCardStoreFacade:s,createMcpFacade:d}}export{J as a,X as b,Q as c,z as d,Y as e,j as f,N as g,T as h,q as i,ot as j,it as k,ct as l,pt as m,mt as n,ft as o,yt as p};//# sourceMappingURL=chunk-I3ZOFU3F.js.map
2
- //# sourceMappingURL=chunk-I3ZOFU3F.js.map
1
+ import {a as a$1}from'./chunk-FOFGEABN.js';import {a,c,d,e,b,f}from'./chunk-O7NOHKVR.js';import {a as a$2}from'./chunk-NN52BT3Q.js';import {b as b$1}from'./chunk-44L64VQ2.js';function M(a){if(!a||typeof a!="object")return false;let t=a;return typeof t.kind=="string"&&t.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let t=a;return t.kind==="notification-batch"?Array.isArray(t.notifications)?t.notifications.filter(M):[]:M(a)?[a]:[]}function X(a,t,i){let c=0;return {accepted:a.filter(_=>{if(!M(_))return c++,false;let S=_;return typeof S.sentAtMs=="number"&&t-S.sentAtMs>i?(c++,false):true}),rejected:c}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let t=a.summary;return !t||typeof t!="object"?false:Number(t.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let t=a;return t.kind==="notification-batch"&&Array.isArray(t.notifications)}function V(a,t){if(t.kind==="status"){z(t.status)&&(a.status=t.status);return}if(t.kind==="computed_values"){a.computedValues[t.cardId]=t.values;return}if(t.kind==="data_object"){a.dataObjects[t.key]=t.payload;return}if(t.kind==="card_refreshed"){a.cards[t.cardId]=t.card;return}t.kind==="card_removed"&&(delete a.cards[t.cardId],delete a.computedValues[t.cardId]);}function Y(a,t){if(W(t)){for(let i of t.notifications)M(i)&&V(a,i);return}M(t)&&V(a,t);}function j(a,t){if(a?.status==="success")return Object.prototype.hasOwnProperty.call(a,"data")?a.data:void 0;throw a?.status==="fail"||a?.status==="error"?Object.assign(new Error(a.error||`${t} failed`),{statusCode:400}):Object.assign(new Error(`${t} returned an unexpected response`),{statusCode:500})}async function N(a,t){return j(await a,t)}function T(a$1){let t=a(a$1,"key");if(!t)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=t.split(".");if(!(i.length>=2&&i.every(g=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(g))))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 q(a,t){let i=a.__private;for(let c of t.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,c))return {exists:false,value:null};i=i[c];}return {exists:true,value:i}}function ot(a$1){let{boardId:t,bootstrapBoard:i,sseHub:c,onChannelSubscribed:g,onChannelUnsubscribed:_,getMcpFacade:S,getMcpCardStoreFacade:n}=a$1;function f(s){let d=a(s,"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 h(s){let d=a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function w(s){f(s);let d=h(s),e=a(s,"channel_name"),r=a(s,"card_id")||void 0;if(!e)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:e,...r?{cardId:r}:{}}}function R(s){f(s);let d=a(s,"card_id");if(!d)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:d}}async function I(s){await i();let{cardId:d}=R(s),e=h(s);if(!await c.subscribeChat(e,d))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:e,subscribed:true}}}async function u(s){await i();let{cardId:d}=R(s),e=h(s);if(!c.unsubscribeChat(e,d))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return {status:"success",data:{boardId:t,cardId:d,clientId:e,subscribed:false}}}async function b(s,d){await i();let{clientId:e,channelName:r,cardId:o}=w(s);if(!c.has(e))throw Object.assign(new Error(`SSE client not connected: ${e}`),{statusCode:404});return d?(c.subscribeChannel(e,r,o),g?.(e,r,o?{cardId:o}:{})):(c.unsubscribeChannel(e,r,o),_?.(e,r,o?{cardId:o}:{})),{status:"success",data:{boardId:t,clientId:e,channelName:r,subscribed:d,...o?{cardId:o}:{}}}}async function m(s,d){let{cardId:e}=R(s);return await S().setChatProcessing({cardId:e,active:d}),{status:"success",data:{boardId:t,cardId:e,active:d}}}async function p(s){let{cardId:d}=R(s),e=await S().getChatProcessing({cardId:d});return {status:"success",data:{boardId:t,cardId:d,active:e.active}}}async function y(s){let{cardId:d}=R(s),e=T(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(e.split(".").includes("visible_controlplane_only")){let r=await N(n().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(r.cards)&&r.cards.length>0&&typeof r.cards[0]=="object"&&!Array.isArray(r.cards[0])?r.cards[0]:null,k=o?q(o,"visible_controlplane_only").value:void 0;if(s.value!==k)throw Object.assign(new Error("MCP tool cannot change the reserved private flag visible_controlplane_only"),{statusCode:403});return {status:"success",data:{boardId:t,cardId:d,key:e}}}return j(await n().patch({params:{id:d,path:`__private.${e}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:t,cardId:d,key:e}}}async function C(s){let{cardId:d}=R(s),e=T(s),r=await N(n().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(r.cards)&&r.cards.length>0&&r.cards[0]&&typeof r.cards[0]=="object"&&!Array.isArray(r.cards[0])?r.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=q(o,e);return {status:"success",data:{boardId:t,cardId:d,key:e,exists:k.exists,value:k.value}}}return {requireCardArgs:R,subscribeChat:I,unsubscribeChat:u,watchChannel:b,setChatProcessing:m,getChatProcessing:p,setCardMeta:y,getCardMeta:C}}function it(a){let{boardId:t,boardContexts:i,readChatRecords:c,getChatProcessing:g}=a,_=Number.isInteger(a.chatBootstrapTailTurns)&&a.chatBootstrapTailTurns>0?a.chatBootstrapTailTurns:1;function S(u){return {role:String(u.role||"system"),text:String(u.text||""),files:Array.isArray(u.files)?u.files:[],...typeof u.turn=="string"&&u.turn?{turn:u.turn}:{}}}function n(u){if(u.length===0)return null;if(u.length===1)return u[0];let b=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],p={};for(let C of m)p[C]=0;for(let C of u){let s=C,d=Array.isArray(s.cards)?s.cards:[];b.push(...d);for(let e of m)p[e]+=Number(s?.summary?.[e]||0);}let y=u[0];return {...y,cards:b,summary:{...y.summary||{},card_count:b.length,...p}}}async function f(){let u=[];for(let b of i)try{let m=await b.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&u.push(m.data);}catch{}return u}async function h(){let b=(await f()).map(m=>m.statusSnapshot).filter(Boolean);if(b.length===0){let m=i.map(p=>p.notification.status).filter(Boolean);return n(m)}return n(b)}async function w(){let u={},b=await f();for(let m of b)Object.assign(u,m.cardRuntimeById||{});if(Object.keys(u).length>0)return u;for(let m of i)for(let[p,y]of Object.entries(m.notification.computedValues)){let C=m.notification.cards[p];u[p]={schema_version:"v1",card_id:p,card_data:C?.card_data??{},computed_values:y??{}};}return u}async function R(){let u={},b=await f();for(let m of b)Object.assign(u,m.dataObjectsByToken||{});if(Object.keys(u).length===0)for(let m of i)Object.assign(u,m.notification.dataObjects||{});return u}async function I(){let u=await f(),b=u.flatMap(C=>Array.isArray(C.cardDefinitions)?C.cardDefinitions:[]),m={},p={};for(let C of u)Object.assign(m,C.dataObjectsByToken||{}),Object.assign(p,C.cardRuntimeById||{});let y={};for(let C of b){if(!C?.id)continue;let s=C.id;try{let d=await c(s,{tailTurns:_}),e=await g(s);(d.length>0||e)&&(y[s]={messages:d.map(r=>S(r)),receiving:!1,processing:e});}catch{}}return {boardId:t,cardDefinitions:b,statusSnapshot:await h(),dataObjectsByToken:m,cardRuntimeById:p,cardChatsByCardId:y}}return {readStatusSnapshot:h,readCardRuntimeArtifacts:w,readDataObjectsByToken:R,buildPublishedRuntimePayload:I}}function K(a){let t=String(a||"").trim();if(!t)return "upload.bin";let i=Math.max(t.lastIndexOf("/"),t.lastIndexOf("\\"));return (i>=0?t.slice(i+1):t)||"upload.bin"}function ct(a){let{safeCardId:t,artifactsStores:i,cardFileMetadataStore:c,readCardFromStore:g,updateCardLocalOnly:_,writeChatRecord:S}=a;async function n(w){let R=[];try{let I=await g(w);if(!I)return R;let u=c().read(I.card_data&&typeof I.card_data=="object"?I.card_data:null);for(let b of u)R.push(String(b.stored_name??""));}catch{}return R}async function f(w,R,I,u){let b=t(w),m=i(w),p=K(R),y=await n(w),s=`${String(y.length+1).padStart(3,"0")}-${p}`.slice(-36);if(!m.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${w}`),{statusCode:500});return await m.files.putBytes(`${b}/${s}`,new Uint8Array(u),I||"application/octet-stream"),{name:p,stored_name:s,size:u.length,mime_type:I||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function h(w,R,I,u,b){if(!u.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let m=b?.inChat===true,p=await f(w,R,I,u),y=null;if(await _(w,C=>{let s=new Date().toISOString(),d=C.card_data&&typeof C.card_data=="object"?C.card_data:{};C.card_data=d;let e=c().normalizeIncoming([{name:p.name,stored_name:p.stored_name,size:p.size,mime_type:p.mime_type,uploaded_at:p.uploaded_at||s,chat:m}],s);return y=c().merge(d,e).findIndex(o=>o.stored_name===p.stored_name),C}),m&&b?.suppressChatRecordWrite!==true){let C=typeof y=="number"&&y>=0?` #${y}`:"";await S(w,"system",`file uploaded: ${p.name} as ${p.stored_name}${C}`,[],b?.turnId??"");}return {ok:true,file:{...p,...typeof y=="number"&&y>=0?{file_idx:y}:{},chat:m},...typeof y=="number"&&y>=0?{file_idx:y}:{}}}return {uploadCardFile:h,readCardStoredFileNames:n}}function pt(a$1){return {"discover.source-kinds":()=>a$1.discoverSourceKinds(),"inspect.board-runtime-status":()=>a$1.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":t=>a$1.inspectCardDefinitionAndRuntime({cardId:a(t,"card_id")}),"inspect.chat-messages-on-cards":t=>{let i=b(t,"tail_turns"),c=b(t,"tail"),g=a(t,"turn_id"),_=t.all_turns===true,S=a(t,"tail_turns_before_id");return a$1.inspectChatMessagesOnCards({cardId:a(t,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...c!==void 0?{tail:c}:{},...g?{turnId:g}:{},..._?{allTurns:true}:{},...S?{tailTurnsBeforeId:S}:{}})},"inspect.file-contents":t=>a$1.inspectFileContents({cardId:a(t,"card_id"),fileIdx:Number(b(t,"file_idx"))}),"preflight.validate-candidate-card-definition":t=>a$1.preflightValidateCandidateCardDefinition({candidateCardContent:d(t,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":t=>a$1.preflightMaterializeCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockRequires:d(t,"mock_requires","mock_requires"),mockFetchedSources:d(t,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":t=>a$1.preflightProbeSingleSourceInCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockProjections:c(t,"mock_projections"),sourceIdx:e(t,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":t=>a$1.preflightRunSingleSourceInCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockProjections:c(t,"mock_projections"),sourceIdx:e(t,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":t=>a$1.preflightRunSingleSourceInLiveCard({cardId:a(t,"card_id"),sourceIdx:e(t,"source_idx","source_idx"),mockRequires:d(t,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":t=>a$1.preflightRunOneCycleWithCandidateCard({candidateCardContent:d(t,"candidate_card_content","candidate_card_content"),mockRequires:c(t,"mock_requires")}),"manage.read-card":t=>a$1.manageReadCard({cardId:a(t,"card_id")}),"stage-ai-response-and-any-attachments":t=>{let i=a(t,"turn_id");if(!i)throw Object.assign(new Error("stage-ai-response-and-any-attachments requires a non-empty turn_id"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(t,"card_id"),role:"assistant",...typeof t.text=="string"?{text:t.text}:{},...i?{turn:i}:{},...Array.isArray(t.files)?{files:t.files}:{}})},"stage-ai-failure-message":t=>{let i=a(t,"turn_id"),c=a(t,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!c)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(t,"card_id"),role:"system",text:c,turn:i})},"manage.upsert-card":t=>a$1.manageUpsertCard({cardId:a(t,"card_id"),candidateCardContent:c(t,"candidate_card_content")}),"manage.remove-card":t=>a$1.manageRemoveCard({cardId:a(t,"card_id")})}}function mt(a$1){return {"webhook.process-accumulated":()=>a$1.webhookProcessAccumulated(),"webhook.source-fetch-done":t=>a$1.webhookSourceFetchDone({token:a(t,"token"),ref:a(t,"ref")}),"webhook.source-fetch-failed":t=>a$1.webhookSourceFetchFailed({token:a(t,"token"),reason:a(t,"reason")})}}function ft(a$1){let{boardId:t,uploadCardFile:i,getMcpFacade:c$1,controlplane:g}=a$1;function _(n,f){let h=a(n,"board_id");if(!h)throw Object.assign(new Error(`${f} requires board_id`),{statusCode:400});if(h!==t)throw Object.assign(new Error(`Unknown board_id: ${h}`),{statusCode:400})}function S(n,f){let{cardId:h}=g.requireCardArgs(n),w=a(n,"turn_id");return _(n,f),c$1().manageAddChatAttachment({cardId:h,role:a(n,"role")||"user",...w?{turn:w}:{},files:[{file_name:a(n,"file_name"),content_type:a(n,"content_type")||"application/octet-stream",...typeof n.text=="string"?{text:n.text}:{},...typeof n.base64=="string"?{base64:n.base64}:{},...Array.isArray(n.bytes)?{bytes:n.bytes}:{}}]})}return {"list-runtime-cards":n=>(_(n,"list-runtime-cards"),c$1().listRuntimeCards()),"sse.subscribe-chat":n=>g.subscribeChat(n),"sse.unsubscribe-chat":n=>g.unsubscribeChat(n),"sse.watch-channel":n=>g.watchChannel(n,true),"sse.unwatch-channel":n=>g.watchChannel(n,false),"getstate.is-chat-processing":n=>g.getChatProcessing(n),"setstate.chat-processing-started":n=>g.setChatProcessing(n,true),"setstate.chat-processing-done":n=>g.setChatProcessing(n,false),"getstate.card-private":n=>g.getCardMeta(n),"setstate.card-private":n=>g.setCardMeta(n),"manage.upload-card-file":n=>{let f$1=a(n,"card_id"),h=a(n,"file_name"),w=a(n,"content_type")||"application/octet-stream",R=f(n);if(_(n,"manage.upload-card-file"),!f$1)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!h)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!R)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(f$1,h,w,R,{inChat:false})},"manage.add-chat-attachment":n=>S(n,"manage.add-chat-attachment"),"manage.add-chat-attachement":n=>S(n,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":n=>{let{cardId:f}=g.requireCardArgs(n),h=a(n,"role")||"user",w=a(n,"turn_id");return _(n,"manage.add-chat-entry-and-any-attachments"),c$1().manageAddChatEntryAndAnyAttachments({cardId:f,role:h,...typeof n.text=="string"?{text:n.text}:{},...w?{turn:w}:{},...Array.isArray(n.files)?{files:n.files}:{}})},"manage.patch-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.patch-card"),c$1().managePatchCard({cardId:f,patch:c(n,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.upsert-card"),c$1().manageUpsertCard({cardId:f,candidateCardContent:c(n,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":n=>{let{cardId:f}=g.requireCardArgs(n);return _(n,"manage.remove-card"),c$1().manageRemoveCard({cardId:f},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async n=>{let{cardId:f}=g.requireCardArgs(n);return {status:"success",data:{cards:await c$1().adminReadCard({cardId:f})}}},"manage.admin-upsert-card":n=>{let f=a(n,"board_id"),h=a(n,"card_id");if(!f)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!h)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 c$1().adminUpsertCard({cardId:h,candidateCardContent:c(n,"candidate_card_content")})}}}function yt(a){let{boardContexts:t,cardOwnerIndex:i,cardContextForCard:c,readStatusSnapshot:g,readDataObjectsByToken:_,readCardRuntimeArtifacts:S,readCardFromStore:n,readCardDefinitions:f,processAccumulatedLaneInternal:h,reportSourceFetched:w,reportSourceFetchFailure:R,uploadCardFile:I,chatStorePublic:u,serverUrl:b,apiBasePath:m}=a;function p(){return t[0]??null}function y(){return {async status(){let e=await g();return e==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:e}},async getOutputsDataObject(e){let r=e?.params?.key;return r?{status:"success",data:(await _())[r]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(e){let r=e?.params?.key;return r?{status:"success",data:(await S())[r]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(e){let r=e?.params?.key;if(!r)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=c(r)??p();return o?o.boardOps.getOutputsFetchedSources({params:{key:r}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(e){let r=e?.params?.id;if(!r)return {status:"fail",error:"removeCard requires params.id"};let o=c(r)??p();return o?o.boardOps.removeCard({params:{id:r}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(e){let r=e?.params?.cardId;if(!r)return {status:"fail",error:"upsertCard requires params.cardId"};let o=c(r)??p();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:r,restart:e.params.restart===true}});if(k.status!=="success")return k;if(a$1(o.boardAdapter)){let P=await h(true);if(P.status!=="success")return P}return k}}}function C(){let e=()=>{let r=p();if(!r?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return r.nonCore};return {describeTaskExecutorCapabilities(r){return e().describeTaskExecutorCapabilities(r)},validateCardPreflight(r){return e().validateCardPreflight(r)},evalCardCompute(r){return e().evalCardCompute(r)},probeSourcePreflight(r){return e().probeSourcePreflight(r)},runSourcePreflight(r){return e().runSourcePreflight(r)},simulateCardCycle(r){return e().simulateCardCycle(r)}}}function s(){return {async get(e){let r=typeof e.params?.id=="string"?e.params.id:void 0;if(r){let o=await n(r);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await f()}}},async set(e){let r=e.body;if(r==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(r)?r:[r];for(let k of o){let P=k,A=typeof P.id=="string"?P.id:"";if(!A)return {status:"fail",error:"each card must have a string `id` field"};let E=i.get(A)??0,D=t[E]??p();if(!D)return {status:"fail",error:"Board context is unavailable"};let L=await D.cardStoreOps.set({body:P});if(L.status!=="success")return L;i.set(A,E);}return {status:"success",data:{count:o.length}}},async del(e){let r=[e.params?.id,...e.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(r.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of r){let k=c(o)??p();if(!k)return {status:"fail",error:"Board context is unavailable"};let P=await k.cardStoreOps.del({params:{id:o}});if(P.status!=="success")return P;i.delete(o);}return {status:"success",data:{count:r.length}}},async patch(e){let r=typeof e.params?.id=="string"?e.params.id:void 0,o=typeof e.params?.path=="string"?e.params.path:void 0;if(!r||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=c(r)??p();return k?k.cardStoreOps.patch(e):{status:"fail",error:"Board context is unavailable"}},async appendFiles(e){let r=typeof e.params?.id=="string"?e.params.id:void 0;if(!r)return {status:"fail",error:"appendFiles requires params.id"};let o=c(r)??p();return o?o.cardStoreOps.appendFiles(e):{status:"fail",error:"Board context is unavailable"}}}}function d(){return a$2({board:y(),nonCore:C(),cardStore:s(),chatStore:u,processAccumulated:()=>h(true),sourceFetchDone:({token:e,ref:r})=>w(e,r),sourceFetchFailed:({token:e,reason:r})=>R(e,r),uploadCardFile({cardId:e,fileName:r,contentType:o,bytes:k,suppressChatRecordWrite:P}){return I(e,r,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:e,fileIdx:r,storedName:o}){let k=`${b||""}${m}/cards/${encodeURIComponent(e)}/files/${r}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:e,ref:r}){let o=c(e)??p();if(!o||a$1(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(b$1(r)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:y,mcpNonCoreFacade:C,mcpCardStoreFacade:s,createMcpFacade:d}}export{J as a,X as b,Q as c,z as d,Y as e,j as f,N as g,T as h,q as i,ot as j,it as k,ct as l,pt as m,mt as n,ft as o,yt as p};//# sourceMappingURL=chunk-PIPXFUEA.js.map
2
+ //# sourceMappingURL=chunk-PIPXFUEA.js.map
@@ -0,0 +1,3 @@
1
+ import {b as b$2}from'./chunk-PEJRTZU3.js';import {a as a$1}from'./chunk-BRYV6CDD.js';import {q,p,a as a$3,t}from'./chunk-FULAMLUU.js';import {a,G,i,h,z,B,D,l,q as q$1,F,E as E$1,A,g,b as b$3,c,d,e as e$1,f as f$1,r,k,j,y,x,w,v}from'./chunk-MRESV3MD.js';import {a as a$2,b as b$1}from'./chunk-44L64VQ2.js';import {a as a$4}from'./chunk-YOY2JM5N.js';import {e,f}from'./chunk-UGB7PC4P.js';async function mt(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function Pt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function ve(e,o){return Pt(e)?e.then(o):o(e)}function lt(e,o){let a={...e};for(let[r,s]of Object.entries(o))s!==null&&typeof s=="object"&&!Array.isArray(s)&&a[r]!==null&&typeof a[r]=="object"&&!Array.isArray(a[r])?a[r]=lt(a[r],s):a[r]=s;return a}function be(e,o,a){if(o.length===0)return e;let[r,...s]=o;if(s.length===0)return {...e,[r]:a};let d=e[r]!==null&&typeof e[r]=="object"&&!Array.isArray(e[r])?e[r]:{};return {...e,[r]:be(d,s,a)}}function ft(e){return {read:a=>e.read(a),get(a,r){return ve(e.read(a),s=>{if(s===null)return null;let d=s;for(let f of r.split(".").filter(Boolean)){if(d===null||typeof d!="object"||Array.isArray(d))return null;d=d[f]??null;}return d??null})},write:(a,r)=>e.write(a,r),delete:a=>e.delete(a),listKeys:a=>e.listKeys(a),shallowMerge(a,r){return ve(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return ve(e.read(a),s=>e.write(a,lt(s??{},r)))},patch(a,r,s){return ve(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,be(d??{},f,s))})}}}function gt(e){return ft(e)}function pt(e,o){return {async readIndex(){return await e.read("_index")},writeIndex(a){return e.write("_index",a)},async readCard(a){return await e.read(a)},async writeCard(a,r){return await e.write(a,r),o(r)},removeCard(a){return e.delete(a)},async cardExists(a){return await e.read(a)!==null},defaultCardKey(a){return a}}}function yt(e,o){async function a(){return await e.readIndex()??{}}return {async readCard(r){let s=(await a())[r];return !s||!await e.cardExists(s.key)?null:await e.readCard(s.key)},async readCardKey(r){return (await a())[r]?.key??null},async readAllCards(){let r=[];for(let[s,d]of Object.entries(await a())){if(!await e.cardExists(d.key))continue;let f=await e.readCard(d.key);f?r.push(f):o?.(`[card-store] could not read card "${s}" at key "${d.key}"`);}return r},async readChecksumIndex(){let r={};for(let[s,d]of Object.entries(await a()))r[s]=d.checksum;return r},async changedSince(r){let s=await a(),d=[];for(let[f,v]of Object.entries(s))r[f]!==v.checksum&&d.push(f);for(let f of Object.keys(r))s[f]||d.push(f);return d},async validateUpsert(r,s){let d=await a(),f=d[r],v=Object.entries(d).find(([,w])=>w.key===s);return f&&f.key!==s?{ok:false,error:`Card id "${r}" is already mapped to key "${f.key}", cannot remap to "${s}"`}:v&&v[0]!==r?{ok:false,error:`Key "${s}" is already mapped to card id "${v[0]}", cannot remap to "${r}"`}:{ok:true}},async writeCard(r,s,d){let f=await a(),v=d??f[r]?.key??e.defaultCardKey(r),w=await e.writeCard(v,s);f[r]={key:v,checksum:w,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async patchCard(r,s,d){let f=await a(),v=f[r];if(!v||!await e.cardExists(v.key))throw new Error(`card "${r}" not found`);let w=await e.readCard(v.key);if(!w||typeof w!="object"||Array.isArray(w))throw new Error(`card "${r}" is not patchable`);let m=String(s||"").split(".").filter(Boolean),l=be(w,m,d),h=await e.writeCard(v.key,l);f[r]={key:v.key,checksum:h,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async removeCard(r){let s=await a(),d=s[r];d&&(await e.removeCard(d.key),delete s[r],await e.writeIndex(s));},readIndex(){return a()}}}function Nt(e,o){return a(e,o)}function _t(e,o,a){return {blob:e,kv:o,journal:a}}function St(e$1,o={}){function a(m){return {status:"success",data:m}}function r(m){return {status:"fail",error:m}}function s(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}async function d(m){let l=o.emitNotification;if(!l||m.length===0)return;let h=e(m);if(h.length===1){await l(h[0]);return}await l(f({kind:"notification-batch",notifications:h}));}async function f$1(m){let l=m.params?.id;if(l){let h=await e$1.readCard(l);if(!h)throw new Error(`card "${l}" not found`);return [h]}return await e$1.readAllCards()}function v(m){return f({kind:"notification-batch",notifications:e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function w(m){if(Array.isArray(m))return m;if(m&&typeof m=="object"){let l=m;return Array.isArray(l.files)?l.files:[m]}return null}return {async get(m){try{return a({cards:await f$1(m)})}catch(l){return s(l)}},async buildNotificationBatch(m){try{return a(v(await f$1(m)))}catch(l){return s(l)}},async set(m){try{let l=m.body;if(l==null)return r("set requires a body (card object or array of cards)");let h=Array.isArray(l)?l:[l];for(let S of h){if(typeof S.id!="string")return r("each card must have a string `id` field");await e$1.writeCard(S.id,S);}return await d(h.map(S=>({kind:"card_refreshed",cardId:S.id,card:S}))),a({count:h.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],h=m.params?.id,S=h?[...l,h]:l;if(S.length===0)return r("del requires body.ids (string[]) or params.id");for(let _ of S)await e$1.removeCard(_);return await d(S.map(_=>({kind:"card_removed",cardId:_}))),a({count:S.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,h=m.params?.path;if(!l)return r("patch requires params.id");if(!h)return r("patch requires params.path");let S=m.body,_=S&&Object.prototype.hasOwnProperty.call(S,"value")?S.value:m.body;await e$1.patchCard(l,h,_);let O=await e$1.readCard(l);return O?(await d([{kind:"card_refreshed",cardId:l,card:O}]),a({count:1})):r(`card "${l}" not found`)}catch(l){return s(l)}},async appendFiles(m){try{let l=m.params?.id;if(!l)return r("appendFiles requires params.id");let h=await e$1.readCard(l);if(!h)return r(`card "${l}" not found`);let S=w(m.body);if(!S||S.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let _=h.card_data&&typeof h.card_data=="object"&&!Array.isArray(h.card_data)?h.card_data:{},O=Array.isArray(_.files)?_.files:[],L=[...O,...S],J=S.map((j,Y)=>({idx:O.length+Y,entry:j})),V=await this.patch({params:{id:l,path:"card_data.files"},body:{value:L}});return V.status!=="success"?V:a({files_added:J})}catch(l){return s(l)}}}}async function vt(e,o){return (await e.peekActive()).find(a=>a.id===o)}function $t(e$1,o={}){async function a(r){let s=o.emitNotification;if(!s||r.length===0)return;let d=e(r);if(d.length===1){await s(d[0]);return}await s(f({kind:"notification-batch",notifications:d}));}return {async enqueue(r){let s=await e$1.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await e$1.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:e$1.enqueueIfAbsent?async(r,s)=>{let d=await e$1.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return e$1.lease(r)},ack(r,s){return e$1.ack(r,s)},nack(r,s,d){return e$1.nack(r,s,d)},peekActive(r){return e$1.peekActive(r)},peekDeadLetter(r){return e$1.peekDeadLetter(r)},async stage(r,s){return e$1.stage(r,s)},async commitStaged(r){let s=await e$1.commitStaged(r);if(s){let d=await vt(e$1,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return e$1.discardStaged(r,s)},peekStaged(r){return e$1.peekStaged(r)}}}function b(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function T(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function E(){return new Date().toISOString()}function bt(e){let o=new TextEncoder().encode(e),a=Array.from(o,r=>String.fromCharCode(r)).join("");return btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Rt(e){let o=e.replace(/-/g,"+").replace(/_/g,"/"),a=o+"=".repeat((4-o.length%4)%4),r=atob(a),s=Uint8Array.from(r,d=>d.charCodeAt(0));return new TextDecoder().decode(s)}function Ae(e){try{let o=JSON.parse(Rt(e));return typeof o?.t=="string"?{taskName:o.t}:null}catch{return null}}function kt(e){return bt(JSON.stringify(e))}function Ct(e){try{let o=JSON.parse(Rt(e));return typeof o?.cbk=="string"&&typeof o?.cid=="string"&&typeof o?.b=="string"&&typeof o?.d=="string"?o:null}catch{return null}}function At(e){return f$1(e,r,()=>({_sources:{}}))}function It(e,o){return d(e,o)}function xt(e){return g(e)}function Tt(e,o){return e$1(e,o)}function Ot(e,o,a,r,s,d){return async f=>{let v$1=[],w$1=await a.cardStore.readCard(f.nodeId);if(!w$1)return "task-initiate-failure";let m=w$1.id;if(m===i){let p=a.activeTaskConfigs?.(),y={[h]:p?k((await Promise.all(Object.keys(p).filter(k=>k!==i).map(k=>a.cardStore.readCard(k)))).filter(k=>!!k),p):await j(await a.cardStore.readAllCards())};return (d??(()=>{}))(y),r(f.nodeId,y),"task-initiated"}let l=w$1.card_data??{},h$1=w$1.source_defs??[],S=await a.cardRuntimeStore.readRuntime(m),_=false,O=async()=>{_&&(await a.cardRuntimeStore.writeRuntime(m,S),_=false);},L=p=>v(S._sources[p]),J=(p,y)=>{S._sources[p]=v(y),_=true;},V=f.taskState?.executionCount??0;if(S._lastExecutionCount!==V&&(S._sources={},S._lastExecutionCount=V,_=true),f.update){let p=f.update.outputFile;if(p){let y$1=L(p);if(f.update.failure){let k=f.update.rqt??y$1.lastRequestedToken??y$1.queueRequestedToken;k&&J(p,y(y$1,k));}else {let k=f.update.rqt;if(!y$1.lastCompletedToken||k>y$1.lastCompletedToken){let D=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,K=D?await a.fetchedSourcesStore.commitSourceData(m,p,D):false;J(p,K?x(y$1,k):y(y$1,k));}}await O();}}let j$1={};for(let[p,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let k=y[p];j$1[p]=k!==void 0?k:y;}else j$1[p]=y;let Y={id:m,card_data:{...l},requires:j$1,source_defs:h$1,compute:w$1.compute},W=a$4.enrichSourcesSync(Array.isArray(w$1.source_defs)?w$1.source_defs:void 0,{card_data:l,requires:j$1}).filter(p=>p._skip!==true),ae=W,de={};for(let p of W){if(!p.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,p.outputFile);y!==null&&(de[p.bindTo]=y);}Y._sourcesData=de,w$1.compute&&a$4.runSync(Y,{sourcesData:de}),(s??(()=>{}))(m,Y.computed_values??{});let fe={...w$1,source_defs:Array.isArray(W)?W.map(p=>({...p,boardDir:typeof p.boardDir=="string"&&p.boardDir?p.boardDir:e.value})):W},B=E(),ge=f.update?void 0:B,Z=ae.filter(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return true;let k=L(y);ge&&(k={...k,queueRequestedToken:ge},J(y,k));let D=k.queueRequestedToken??k.lastRequestedToken??B;return w(k,D)==="dispatch"});if(await O(),Z.length>0){let p=false,y=B;for(let k of Z){let D=k.outputFile;if(typeof D!="string"||!D)continue;let K=L(D),n=K.queueRequestedToken??B;J(D,{...K,lastRequestedToken:n}),y=n,p=true;}return p&&await O(),p&&(v$1.push({taskKind:"source-fetch",payload:{boardRef:a$2(e),enrichedCard:fe,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,v$1)),"task-initiated"}if(ae.some(p=>{let y=p.outputFile;if(typeof y!="string"||!y)return false;let k=L(y),D=k.queueRequestedToken??k.lastRequestedToken??B;return w(k,D)==="in-flight"}))return "task-initiated";let pe=w$1.provides??[],me={};for(let{bindTo:p,ref:y}of pe)me[p]=a$4.resolve(Y,y);return (d??(()=>{}))(me),r(f.nodeId,me),v$1.length>0&&await a.executionRequestStore.appendEntries(o,v$1),"task-initiated"}}function nr(e$1,o,a$4={}){a$1(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=a$2(e$1),f$1=a$4.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),v=null,w=a$4.boardRuntimeStoreRef,m=a$4.scratchStoreRef,l$1=a$4.taskExecutorRef,h$1=a$4.chatHandlerFlow;function S(){if(!w)throw new Error(`Board at ${e$1.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return w}function _(n){if(n.length!==0)try{let t=e(n),c=f({kind:"notification-batch",notifications:t});return Promise.resolve(f$1(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(t){s(`[async-board-live-cards-public] emitNotification failed: ${t instanceof Error?t.message:String(t)}`);return}}let O=()=>b$2(o.kvStorageForRef(S())),L=e$1.value,J=()=>b$3(a(()=>o.kvStorageForRef(S()),o.hashFn),"v1"),V=async()=>{let n=await O().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no outputs store configured.`);return xt(o.kvStorageForRef(n))},j=async()=>{let n=await O().readCardStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no card store configured.`);let t=o.kvStorageForRef(n);return yt(pt(gt(t),o.hashFn),s)};async function Y(){return !!(await J().readSnapshot(L)).values[q$1]}async function ue(){let n=await J().readSnapshot(L);if(!n.values[q$1])throw new Error(`Board not initialized at ${e$1.value}`);return F(n.values)}async function W(n,t){let c=await J().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:E$1(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let ae=()=>c(o.journalStorageForRef(S()));async function de(){return l$1??await O().readTaskExecutorRef()}async function fe(){return A(await(await V()).readAllDataObjects())}async function B$1(n){await ae().appendEvent(n);}async function ge(){let n=await O().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function Z(){return o.blobStorageForRef(await ge())}async function ce(){return It(await Z(),n=>o.resolveBlob(n))}async function pe(n){let t=(await Z()).keyRef?.(n);if(!t)throw new Error("configured fetched-sources store does not support keyRef");let c=await Promise.resolve(t);return a$2(c)}async function me(){let n=Tt(o.kvStorageForRef(S()),async(u,g)=>{let P=u.payload,q=(P.enrichedCard??{}).id??P.cardId??"unknown";await B$1({type:"task-failed",taskName:q,error:g,timestamp:E()});}),t$1=At(o.kvStorageForRef(S())),c=await Z(),i$1=await ce(),A=await j(),I=await V(),F=new Map,C=new Map,x=[],Q=[],H=[],X=new Map,oe=new Set,se={async readRuntime(u){return F.get(u)??await t$1.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),Te[u]=g;}},Ie={async readSourceData(u,g){let P=`${u}/${g}`;return C.has(P)?C.get(P):await i$1.readSourceData(u,g)},ingestSourceDataStaged(u,g,P,$){return i$1.ingestSourceDataStaged(u,g,P,$)},async commitSourceData(u,g,P){let $=`${u}/.staged/${P}/${g}`,q=await c.read($);if(q==null){let G=await Promise.resolve(c.keyRef?.($));G&&(q=await o.resolveBlob(G));}if(q==null)return false;let U=`${u}/${g}`,te=q.trim();try{C.set(U,JSON.parse(te));}catch{C.set(U,te);}return x.push({cardId:u,outputFile:g,deliveryToken:P}),true},async hasSource(u,g){let P=`${u}/${g}`;return C.has(P)||await i$1.hasSource(u,g)},async listSources(u){let g=await i$1.listSources(u),P=[...C.keys()].filter($=>$.startsWith(`${u}/`)).map($=>$.slice(`${u}/`.length));return [...new Set([...g,...P])]}},xe=await ue(),De=q(xe.graph),Te={...xe.runtimeByCardId},{events:wt,newCursor:Oe}=await ae().readEntriesAfterCursor(xe.lastDrainedJournalId),ye=wt,Ve=()=>De.config.tasks,le=t(De,{handlers:{"card-handler":Ot(e$1,Oe,{cardStore:A,cardRuntimeStore:se,fetchedSourcesStore:Ie,outputStore:I,executionRequestStore:n,activeTaskConfigs:()=>Ve()},(u,g)=>{ye.push({type:"task-completed",taskName:u,data:g,timestamp:E()});},(u,g)=>{Q.push({cardId:u,values:g});},u=>{H.push(u);})},onNodeRemoved:u=>{X.delete(u),F.delete(u),delete Te[u],oe.add(u);}});for(Ve=()=>le.getState().config.tasks;ye.length>0;){let u=ye;ye=[];for(let g of u)if(g.type==="task-restart"){let P=await A.readCard(g.taskName);P&&X.set(g.taskName,P);}le.pushAll(u),await le.waitForHandlers();}let $e=le.getState();await le.dispose({wait:true}),await W({lastDrainedJournalId:Oe,graph:p($e),runtimeByCardId:Te},(await J().readSnapshot(L)).version);for(let{cardId:u,values:g}of Q)await I.writeComputedValues(u,g);for(let u of H)await I.writeDataObjects(u);for(let[u,g]of F)await t$1.writeRuntime(u,g);for(let u of x)await i$1.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let Le=z(B(d,$e));await I.writeStatusSnapshot(Le);let ie=[];for(let{cardId:u,values:g}of Q)ie.push({kind:"computed_values",cardId:u,values:g});for(let u of H)for(let[g,P]of Object.entries(u))ie.push({kind:"data_object",key:g,payload:P});for(let[u,g]of X)u!==i&&ie.push({kind:"card_refreshed",cardId:u,card:g});for(let u of oe)ie.push({kind:"card_removed",cardId:u});ie.push({kind:"status",status:Le}),await _(ie);let ee=await de();if(!ee)return;let Je=o.supportsDirectSourceOutput?.(ee)===true;await n.dispatchEntriesForJournalId(Oe,async u=>{if(u.taskKind!=="source-fetch"){s(`[async-process-accumulated-events] unknown taskKind "${u.taskKind}" \u2014 skipping`);return}let g=u.payload,P=g.enrichedCard?.id??"unknown",$=g.enrichedCard?.source_defs??[];if(ee.howToRun==="queue-storage"&&Je){try{let q=await O().readQueueStoreRef();if(!q)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let U=o.queueStorageForRef(q,"task-executor"),te=typeof ee.extra?.boardId=="string"?ee.extra.boardId:void 0,G=[];for(let z of $){if(!z.outputFile)continue;let Se=o.genId(),ke=`${P}/.staged/${Se}/${z.outputFile}`,Me=await Promise.resolve(c.keyRef?.(ke));if(!Me)continue;let Qe={ref:a$2(Me),deliveryToken:Se,outputFile:z.outputFile,cardId:P},ht=kt({cbk:g.callbackToken,rg:e$1.value,br:a$2(e$1),cid:P,b:z.bindTo,d:z.outputFile,cs:void 0,rqt:g.rqt,dt:Qe.deliveryToken});G.push({...te?{boardId:te}:{},ref:ee,args:{source_def:z,base_ref:a$2(e$1),callback:r.createCallback(ht),output:Qe}});}G.length>0&&await U.enqueueMany(G);}catch(q){await B$1({type:"task-failed",taskName:P,error:q instanceof Error?q.message:String(q),timestamp:E()});}return}for(let q of $){if(!q.outputFile)continue;let U;if(Je){let z=o.genId(),Se=`${P}/.staged/${z}/${q.outputFile}`,ke=await Promise.resolve(c.keyRef?.(Se));ke&&(U={ref:a$2(ke),deliveryToken:z,outputFile:q.outputFile,cardId:P});}let te=kt({cbk:g.callbackToken,rg:e$1.value,br:a$2(e$1),cid:P,b:q.bindTo,d:q.outputFile,cs:void 0,rqt:g.rqt,...U?{dt:U.deliveryToken}:{}}),G=await o.dispatchExecution(ee,{source_def:q,base_ref:a$2(e$1),callback:r.createCallback(te),...U?{output:U}:{}});G.dispatched||await B$1({type:"task-failed",taskName:P,error:G.error??"dispatch failed",timestamp:E()});}});}async function p$1(){try{let n=async()=>{let c=await ue(),{events:i}=await ae().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await k();},t=await mt(o.lock,me,n);return b({ran:t!==!1})}catch(n){return T(n)}}async function y(){return v||(v=p$1().finally(()=>{v=null;}),v)}async function k(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);await o.queueStorageForRef(n,"process-accumulated").enqueue({boardRef:a$2(e$1)}),await o.requestProcessAccumulated?.();}async function D$1(){let n=await O().readQueueStoreRef();if(!n)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await t.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await t.ack(i.id,i.leaseToken);if(c.length<64)return}}function K(){k();}return {async init(n){try{let t=n.params?.cardStoreRef;if(!t)return R("init requires params.cardStoreRef");if(w=n.params?.boardRuntimeStoreRef,!w)return R("init requires params.boardRuntimeStoreRef");let c=n.params?.outputsStoreRef;if(!c)return R("init requires params.outputsStoreRef");let i$1=n.params?.queueStoreRef;if(!i$1)return R("init requires params.queueStoreRef");let A=n.params?.fetchedSourcesStoreRef;if(!A)return R("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let I=n.params?.chatStoreRef;if(!I)return R("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return R("init requires params.artifactsStoreRef");await Y()||await W({lastDrainedJournalId:"",graph:p(a$3(D)),runtimeByCardId:{}},null);let C=O();await C.writeBoardRuntimeStoreRef(w),await C.writeCardStoreRef(t),await C.writeOutputsStoreRef(c),await C.writeQueueStoreRef(i$1),await C.writeFetchedSourcesStoreRef(A),await C.writeChatStoreRef(I),await C.writeArtifactsStoreRef(F),await(await j()).writeCard(i,l());let x=o.kvStorage("card-upsert"),Q=l(),H=G(Q),X=o.hashFn(H),se=(await x.read(i))?.blobRef??await(await j()).readCardKey(i)??i;return await B$1({type:"task-upsert",taskName:i,taskConfig:H,timestamp:E()}),await x.write(i,{blobRef:se,taskConfigHash:X,updatedAt:E()}),await B$1({type:"task-restart",taskName:i,timestamp:E()}),K(),await(await V()).writeStatusSnapshot(z(B(d,q((await ue()).graph)))),b()}catch(t){return T(t)}},async status(n){try{let t=await V(),c=await t.readStatusSnapshot();return c||(c=z(B(d,q((await ue()).graph))),await t.writeStatusSnapshot(c)),b(c)}catch(t){return T(t)}},async getCardStoreRef(n){try{let t=await O().readCardStoreRef();return t?b({storeRef:t}):R(`Board at ${e$1.value} has no card store configured`)}catch(t){return T(t)}},async getBoardRuntimeStoreRef(n){try{return b({storeRef:w??null})}catch(t){return T(t)}},async getOutputsStoreRef(n){try{let t=await O().readOutputsStoreRef();return t?b({storeRef:t}):R(`Board at ${e$1.value} has no outputs store configured`)}catch(t){return T(t)}},async getScratchStoreRef(n){try{return b({storeRef:m??null})}catch(t){return T(t)}},async getChatStoreRef(n){try{return b({storeRef:await O().readChatStoreRef()})}catch(t){return T(t)}},async getArtifactsStoreRef(n){try{return b({storeRef:await O().readArtifactsStoreRef()})}catch(t){return T(t)}},async getFetchedSourcesStoreRef(n){try{return b({storeRef:await O().readFetchedSourcesStoreRef()})}catch(t){return T(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return R("getConfig requires params.key");let c=O(),i;switch(t){case "task-executor":i=l$1??null;break;case "chat-handler-flow":i=h$1??null;break;case "board-runtime-store-ref":i=await c.readBoardRuntimeStoreRef();break;case "card-store-ref":i=await c.readCardStoreRef();break;case "outputs-store-ref":i=await c.readOutputsStoreRef();break;case "scratch-store-ref":i=m??null;break;case "chat-store-ref":i=await c.readChatStoreRef();break;case "artifacts-store-ref":i=await c.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=await c.readFetchedSourcesStoreRef();break;default:return R(`getConfig: unknown key "${t}"`)}return b({value:i})}catch(t){return T(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;if(!t)return R("getOutputsDataObject requires params.key");if(t===h)return b(null);let c=await fe();return b(c[t]??null)}catch(t){return T(t)}},async getAllOutputsDataObjects(n){try{return b(await fe())}catch(t){return T(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?b(await(await V()).readComputedValues(t)):R("getOutputsComputedValues requires params.key")}catch(t){return T(t)}},async getAllOutputsComputedValues(n){try{return b(await(await V()).readAllComputedValues())}catch(t){return T(t)}},async getOutputsFetchedSources(n){try{let t=n.params?.key;if(!t)return R("getOutputsFetchedSources requires params.key");let c=await(await ce()).listSources(t),i={};for(let A of c)i[A]=await pe(`${t}/${A}`);return b(i)}catch(t){return T(t)}},async getAllOutputsFetchedSources(n){try{let t=await ce(),c=await(await Z()).listKeys(),i=new Set;for(let I of c){let F=I.indexOf("/");F>0&&!I.includes("/.staged/")&&i.add(I.slice(0,F));}let A={};for(let I of i){let F=await t.listSources(I);if(F.length!==0){A[I]={};for(let C of F)A[I][C]=await pe(`${I}/${C}`);}}return b(A)}catch(t){return T(t)}},async buildSseOneShotPayload(n){try{let t=(await(await j()).readAllCards()).filter(C=>C.id!==i),c=await this.status({});if(c.status!=="success")return c;let i$1=await this.getAllOutputsDataObjects({});if(i$1.status!=="success")return i$1;let A=await this.getAllOutputsComputedValues({});if(A.status!=="success")return A;let I=A.data,F={};for(let C of t){let x=typeof C?.id=="string"?C.id:null;if(!x)continue;let Q=C.card_data&&typeof C.card_data=="object"&&!Array.isArray(C.card_data)?C.card_data:{};F[x]={schema_version:"v1",card_id:x,card_data:{...Q},computed_values:I[x]&&typeof I[x]=="object"?I[x]:{}};}return b({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i$1.data,cardRuntimeById:F})}catch(t){return T(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return R("addCardFiles requires params.cardId");let i=await St(await j(),{emitNotification:f$1}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:b({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return T(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return R("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await B$1({type:"task-removal",taskName:t,timestamp:E()}),t!==i&&await B$1({type:"task-restart",taskName:i,timestamp:E()}),K(),b()}catch(t){return T(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await B$1({type:"task-restart",taskName:t,timestamp:E()}),K(),b()):R("retrigger requires params.id")}catch(t){return T(t)}},async processAccumulatedEvents(n){return await D$1(),y()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i$1=!!n.params?.restart;if(!t&&!c)return R("upsertCard requires --card-id <id> or --all");let A=await j(),I=c?(await A.readAllCards()).map(x=>x.id):[t];for(let x of I)if(!await A.readCard(x))return R(`Card "${x}" not found in board at ${e$1.value}`);let F=o.kvStorage("card-upsert"),C=!1;for(let x of I){let Q=await A.readCard(x);if(!Q)continue;let H=G(Q),X=o.hashFn(H),oe=await F.read(x),se=oe?.taskConfigHash!==X;if(!(!se&&!i$1)){if(se){let Ie=oe?.blobRef??await A.readCardKey(x)??x;await B$1({type:"task-upsert",taskName:x,taskConfig:H,timestamp:E()}),await F.write(x,{blobRef:Ie,taskConfigHash:X,updatedAt:E()}),C=C||x!==i;}i$1&&await B$1({type:"task-restart",taskName:x,timestamp:E()});}}return C&&await B$1({type:"task-restart",taskName:i,timestamp:E()}),K(),b()}catch(t){return T(t)}},async taskFailed(n){try{let t=n.params?.token;if(!t)return R("taskFailed requires params.token");let c=n.params?.error??"unknown error",i=Ae(t);return i?(await B$1({type:"task-failed",taskName:i.taskName,error:c,timestamp:E()}),K(),b()):R("Invalid callback token")}catch(t){return T(t)}},async taskProgress(n){try{let t=n.params?.token;if(!t)return R("taskProgress requires params.token");let c=(n.body??{}).update??{},i=Ae(t);return i?(await B$1({type:"task-progress",taskName:i.taskName,update:c,timestamp:E()}),K(),b()):R("Invalid callback token")}catch(t){return T(t)}},async sourceDataFetched(n){try{let t=n.params?.token,c=n.params?.ref;if(!t)return R("sourceDataFetched requires params.token");if(!c)return R("sourceDataFetched requires params.ref");let i=Ct(t);if(!i)return R("Invalid source token");let A=await ce(),I=i.dt||o.genId();i.dt||await A.ingestSourceDataStaged(i.cid,i.d,b$1(c),I);let F=Ae(i.cbk);return F?(await B$1({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:E(),deliveryToken:I,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}},async sourceDataFetchFailure(n){try{let t=n.params?.token,c=n.params?.reason??"unknown";if(!t)return R("sourceDataFetchFailure requires params.token");let i=Ct(t);if(!i)return R("Invalid source token");let A=Ae(i.cbk);return A?(await B$1({type:"task-progress",taskName:A.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:E()}),K(),b()):R("Invalid callback token embedded in source token")}catch(t){return T(t)}}}}
2
+ export{mt as a,gt as b,pt as c,yt as d,Nt as e,_t as f,St as g,$t as h,nr as i};//# sourceMappingURL=chunk-REZO2QJD.js.map
3
+ //# sourceMappingURL=chunk-REZO2QJD.js.map
@@ -1,2 +1,2 @@
1
- import {c,n,m,l as l$1,k,j,i as i$1,h as h$1,g as g$1,f,e,d,t}from'./chunk-FULAMLUU.js';import {i,a,g,h,l}from'./chunk-R7SQQSDX.js';import {a as a$1}from'./chunk-ATOQP3BD.js';import {exec,execFile}from'child_process';function z(s){let{config:e,state:o}=s,a$1=i(e),i$1=Object.keys(a$1),d=0,c=0,l=0,f=0,t=0,r=0;for(let h of i$1){let T=o.tasks[h];if(!T||T.status===a.NOT_STARTED)t++;else switch(T.status){case a.RUNNING:d++;break;case a.COMPLETED:c++;break;case a.FAILED:l++;break;case "inactivated":r++;break;default:f++;}}let n={};for(let[h,T]of Object.entries(a$1)){for(let R of g(T))n[R]||(n[R]=[]),n[R].push(h);if(T.on)for(let R of Object.values(T.on))for(let g of R)n[g]||(n[g]=[]),n[g].includes(h)||n[g].push(h);if(T.on_failure)for(let R of T.on_failure)n[R]||(n[R]=[]),n[R].includes(h)||n[R].push(h);}let u=new Set,p=0,k=0;for(let[h$1,T]of Object.entries(a$1)){let R=o.tasks[h$1];if(R?.status===a.COMPLETED||R?.status===a.RUNNING)continue;let g=false,H=false;for(let x of h(T)){let q=n[x]||[];q.length===0?(u.add(x),g=true):q.every(Y=>{let W=o.tasks[Y];return W?.status===a.FAILED||W?.status==="inactivated"})&&(H=true);}g&&p++,H&&!g&&k++;}let m=[];for(let[h,T]of Object.entries(n))T.length>1&&m.push(h);let v=Q(a$1,n),b=Z(i$1,v);return {totalNodes:i$1.length,running:d,completed:c,failed:l,waiting:f,notStarted:t,disabled:r,unresolvedCount:p,blockedCount:k,openDependencies:[...u],cycles:b,conflictTokens:m}}function Q(s,e){let o={};for(let[a,i]of Object.entries(s)){o[a]=new Set;for(let d of h(i))for(let c of e[d]||[])c!==a&&o[a].add(c);}return o}function Z(s,e){let d={},c={},l=[];for(let t of s)d[t]=0,c[t]=null;function f(t){d[t]=1;for(let r of e[t]||[])if(d[r]===1){let n=[r],u=t;for(;u!==r;)n.push(u),u=c[u];n.push(r),n.reverse(),l.push(n);}else d[r]===0&&(c[r]=t,f(r));d[t]=2;}for(let t of s)d[t]===0&&f(t);return l}function B(s){let e={};for(let[o,a]of Object.entries(s)){for(let i of g(a))e[i]||(e[i]=[]),e[i].push(o);if(a.on)for(let i of Object.values(a.on))for(let d of i)e[d]||(e[d]=[]),e[d].includes(o)||e[d].push(o);if(a.on_failure)for(let i of a.on_failure)e[i]||(e[i]=[]),e[i].includes(o)||e[i].push(o);}return e}function V(s){let{config:e,state:o}=s,a=i(e),i$1=B(a),d=new Set([...o.availableOutputs]);for(let[n,u]of Object.entries(o.tasks))if(u.status==="completed"){let p=a[n];p&&g(p).forEach(k=>d.add(k));}let c=new Set;for(let n of Object.values(a))for(let u of h(n))c.add(u);let l$1=new Set,f=new Set;for(let n of c){if(d.has(n))continue;(i$1[n]||[]).length===0&&l$1.add(n);}let t=true;for(;t;){t=false;for(let[n,u]of Object.entries(a)){if(f.has(n))continue;let p=o.tasks[n];if(p?.status==="completed")continue;let k=l(p),v=h(u).some(b=>l$1.has(b));(k||v)&&(f.has(n)||(f.add(n),t=true));}for(let n of c){if(l$1.has(n)||d.has(n))continue;let u=i$1[n]||[],p=u.length>0&&u.every(k=>f.has(k)||l(o.tasks[k]));(u.length===0||p)&&(l$1.has(n)||(l$1.add(n),t=true));}}let r=[];for(let n of l$1){let u=i$1[n]||[],p;u.length===0?p="no-producer":p=u.every(m=>l(o.tasks[m]))?"all-producers-failed":"transitive",r.push({token:n,reason:p,producers:u});}return {tokens:r}}function ee(s){let{config:e,state:o}=s,a=i(e),{tokens:i$1}=V(s),d=new Set(i$1.map(l=>l.token)),c=[];for(let[l$1,f]of Object.entries(a)){let t=o.tasks[l$1];if(t?.status==="completed")continue;let n=h(f).filter(u=>d.has(u));n.length>0?c.push({nodeName:l$1,missingTokens:n}):l(t)&&c.push({nodeName:l$1,missingTokens:[]});}return {nodes:c}}function te(s,e){let o=i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a=B(o),i$1=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of h(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i$1.has(p)||(i$1.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,providesTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function ne(s,e){let o=i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a={};for(let[t,r]of Object.entries(o))for(let n of h(r))a[n]||(a[n]=[]),a[n].push(t);let i$1=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of g(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i$1.has(p)||(i$1.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,requiresTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function K(s){let e=[],{config:o,state:a$1}=s,i$1=i(o),d=Object.keys(i$1);for(let t of d)a$1.tasks[t]||e.push({severity:"error",code:"MISSING_STATE",message:`Task "${t}" exists in config but has no state entry`,tasks:[t]});for(let t of Object.keys(a$1.tasks))i$1[t]||e.push({severity:"warning",code:"ORPHAN_STATE",message:`State entry "${t}" has no corresponding task config`,tasks:[t]});for(let t of d){let r=a$1.tasks[t];r&&(r.status===a.RUNNING&&!r.startedAt&&e.push({severity:"warning",code:"RUNNING_WITHOUT_START",message:`Task "${t}" is running but has no startedAt timestamp`,tasks:[t]}),r.status===a.COMPLETED&&!r.completedAt&&e.push({severity:"warning",code:"COMPLETED_WITHOUT_TIMESTAMP",message:`Task "${t}" is completed but has no completedAt timestamp`,tasks:[t]}),r.status===a.FAILED&&(r.failedAt||e.push({severity:"warning",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no failedAt timestamp`,tasks:[t]}),r.error||e.push({severity:"info",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no error message`,tasks:[t]})));}let c=new Set;for(let t of d)if(a$1.tasks[t]?.status===a.COMPLETED)for(let n of g(i$1[t]))c.add(n);let l=new Set(a$1.availableOutputs),f=new Set;for(let t of Object.values(i$1)){for(let r of g(t))f.add(r);if(t.on)for(let r of Object.values(t.on))for(let n of r)f.add(n);if(t.on_failure)for(let r of t.on_failure)f.add(r);}for(let t of l)!c.has(t)&&!f.has(t)&&e.push({severity:"info",code:"INJECTED_TOKEN",message:`Token "${t}" is available but no task in the graph can produce it (likely injected)`,tokens:[t]});for(let t of c)l.has(t)||e.push({severity:"warning",code:"MISSING_OUTPUT",message:`Token "${t}" should be available (its producer completed) but is not in availableOutputs`,tokens:[t]});for(let t of d){let r=a$1.tasks[t];if(!r)continue;r.executionCount<0&&e.push({severity:"error",code:"INVALID_EXECUTION_COUNT",message:`Task "${t}" has negative execution count: ${r.executionCount}`,tasks:[t]});let n=i$1[t].maxExecutions;n!==void 0&&r.executionCount>n&&e.push({severity:"error",code:"EXCEEDED_MAX_EXECUTIONS",message:`Task "${t}" executed ${r.executionCount} times, exceeding maxExecutions of ${n}`,tasks:[t]});}return J(e)}function se(s){let{graph:e,handlers:o}=s,a=e.getState(),i$1=[],d=i(a.config),c=Object.keys(d),l=new Set(Object.keys(o)),f=new Set;for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)f.add(u);}for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)o[u]||i$1.push({severity:"error",code:"MISSING_HANDLER",message:`Task "${r}" references handler "${u}" but it is not in the registry`,tasks:[r]});}for(let r of l)f.has(r)||i$1.push({severity:"warning",code:"ORPHAN_HANDLER",message:`Handler "${r}" is registered but not referenced by any task's taskHandlers`,tasks:[r]});let t=K(a);return i$1.push(...t.issues),J(i$1)}function J(s){let e=s.filter(a=>a.severity==="error"),o=s.filter(a=>a.severity==="warning");return {valid:e.length===0,issues:s,errors:e,warnings:o}}function re(s,e){let o=s;for(let a of e)o=oe(o,a);return o}function oe(s,e$1){switch(e$1.type){case "add-node":return d(s,e$1.name,e$1.config);case "remove-node":return e(s,e$1.name);case "add-requires":return f(s,e$1.taskName,e$1.tokens);case "remove-requires":return g$1(s,e$1.taskName,e$1.tokens);case "add-provides":return h$1(s,e$1.taskName,e$1.tokens);case "remove-provides":return i$1(s,e$1.taskName,e$1.tokens);case "inject-tokens":return j(s,e$1.tokens);case "drain-tokens":return k(s,e$1.tokens);case "reset-node":return l$1(s,e$1.name);case "disable-node":return m(s,e$1.name);case "enable-node":return n(s,e$1.name);case "apply-events":return c(s,e$1.events);default:throw new Error(`Unknown mutation type: ${e$1.type}`)}}function ce(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(i=>e()(a,i)).catch(i=>e()(a,{},[i instanceof Error?i.message:String(i)])),"task-initiated"}}function de(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(()=>e()(a,{})).catch(()=>e()(a,{})),"task-initiated"}}function ue(s){let{command:e,cwd:o,env:a,timeoutMs:i=3e4,exitCodeMap:d,captureOutput:c=false,getResolve:l}=s;return async f=>{let{callbackToken:t,nodeId:r}=f,n=e.replace(/\$\{taskName\}/g,r);return exec(n,{cwd:o,env:a?{...process.env,...a}:void 0,timeout:i,maxBuffer:10*1024*1024},(u,p,k)=>{let m=u?.code??(u?1:0);if(m!==0&&!d?.[m]){l()(t,{},[`Command exited with code ${m}: ${k||u?.message}`]);return}let v={};c&&(v.stdout=p,v.stderr=k,v.exitCode=m),l()(t,v);}),"task-initiated"}}function X(s){let{command:e,args:o=[],cwd:a,env:i,timeoutMs:d=3e4,exitCodeMap:c,captureOutput:l=false,getResolve:f}=s;return async t=>{let{callbackToken:r,nodeId:n}=t,u=e.replace(/\$\{taskName\}/g,n),p=o.map(k=>k.replace(/\$\{taskName\}/g,n));return execFile(u,p,{cwd:a,env:i?{...process.env,...i}:void 0,timeout:d,maxBuffer:10*1024*1024,encoding:"utf8",windowsHide:true},(k,m,v)=>{let b=k?.code??(k?1:0);if(b!==0&&!c?.[b]){f()(r,{},[`Process exited with code ${b}: ${v||k?.message}`]);return}let h={};l&&(h.stdout=m,h.stderr=v,h.exitCode=b),f()(r,h);}),"task-initiated"}}function le(s){return s.endsWith(".js")||s.endsWith(".mjs")||s.endsWith(".ts")?"node":s.endsWith(".py")?"python3":(s.endsWith(".sh"),"bash")}function pe(s){let{scriptPath:e,runtime:o,args:a=[],cwd:i,timeoutMs:d=6e4,captureOutput:c=false,getResolve:l}=s,f=o??le(e),t=f==="node"?process.execPath:f;return X({command:t,args:[e,"${taskName}",...a],cwd:i,timeoutMs:d,captureOutput:c,getResolve:l})}function fe(s){let{url:e,method:o="POST",headers:a={},timeoutMs:i=3e4,failOnNon2xx:d=true,getResolve:c}=s;return async l=>{let{callbackToken:f,nodeId:t,config:r}=l,n=e.replace(/\$\{taskName\}/g,t),u=JSON.stringify({taskName:t,callbackToken:f,config:r}),p=new AbortController,k=setTimeout(()=>p.abort(),i);return fetch(n,{method:o,headers:{"Content-Type":"application/json",...a},body:u,signal:p.signal}).then(async m=>{if(clearTimeout(k),d&&!m.ok){let b=await m.text().catch(()=>"");c()(f,{},[`HTTP ${m.status}: ${b}`]);return}let v=await m.json().catch(()=>({}));c()(f,v);}).catch(m=>{clearTimeout(k),c()(f,{},[m instanceof Error?m.message:String(m)]);}),"task-initiated"}}function ge(s,e){return async o=>(s()(o.callbackToken,e??{}),"task-initiated")}function ke(s,e={}){let o,a={},i;if(!Array.isArray(s)&&"nodes"in s){let g=s;o=g.nodes,i=g.id,a=g.settings??{};}else o=s;let{sourceHandlers:d={},defaultSourceHandler:c,cardHandlers:l={},reactiveOptions:f={},graphSettings:t$1={},executionId:r}=e,n=new Map;for(let g of o){if(n.has(g.id))throw new Error(`Duplicate card ID: "${g.id}"`);n.set(g.id,g);}let u=e.sharedState??new Map,p={},k=new Set,m=new Map;for(let g of o)for(let H of g.provides??[{bindTo:g.id,ref:"card_data"}])k.add(H.bindTo),m.set(H.bindTo,g.id);for(let g of o){let H=g.requires??[];for(let x of H)if(!k.has(x))throw new Error(`Card "${g.id}" requires "${x}" but no card provides that token`);p[g.id]={requires:H.length>0?H:void 0,provides:(g.provides??[{bindTo:g.id,ref:"card_data"}]).map(x=>x.bindTo),taskHandlers:[g.id],description:g.meta?.title??g.id};}let v={id:i??`live-cards-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...a,...t$1},tasks:p},b={},h=null,T=()=>(g,H,x)=>{h.resolveCallback(g,H,x);};for(let g of o)g.source_defs&&g.source_defs.length>0?b[g.id]=me(g,d,c,u,T):b[g.id]=he(g,l,u,n,m,T);let R=t(v,{...f,handlers:b},r);return h=R,{graph:R,config:v,handlers:b,cards:n,sharedState:u}}function me(s,e,o,a,i){if(e[s.id]){let d=e[s.id];return async c=>d(c)}if(o){let d=o(s);return async c=>d(c)}return async d=>{let c={...s.card_data};return a.set(s.id,c),i()(d.callbackToken,c),"task-initiated"}}function he(s,e,o,a,i,d){if(e[s.id]){let c=e[s.id];return async l=>c(l)}return async c=>{let l={},f=s.requires??[];for(let u of f){let p=i.get(u)??u,k=o.get(p);k&&(l[u]=k[u]??k);}let t={id:s.id,card_data:{...s.card_data},requires:l,compute:s.compute};await a$1.run(t);let r;if(s.provides&&s.provides.length>0){r={};for(let{bindTo:u,ref:p}of s.provides)r[u]=a$1.resolve(t,p);}else r={...t.card_data,...t.computed_values};let n={...t.card_data,...t.computed_values};return o.set(s.id,n),d()(c.callbackToken,r),"task-initiated"}}export{z as a,V as b,ee as c,te as d,ne as e,K as f,se as g,re as h,ce as i,de as j,ue as k,X as l,pe as m,fe as n,ge as o,ke as p};//# sourceMappingURL=chunk-23PEDGFN.js.map
2
- //# sourceMappingURL=chunk-23PEDGFN.js.map
1
+ import {c,n,m,l as l$1,k,j,i as i$1,h as h$1,g as g$1,f,e,d,t}from'./chunk-FULAMLUU.js';import {i,a,g,h,l}from'./chunk-R7SQQSDX.js';import {a as a$1}from'./chunk-YOY2JM5N.js';import {exec,execFile}from'child_process';function z(s){let{config:e,state:o}=s,a$1=i(e),i$1=Object.keys(a$1),d=0,c=0,l=0,f=0,t=0,r=0;for(let h of i$1){let T=o.tasks[h];if(!T||T.status===a.NOT_STARTED)t++;else switch(T.status){case a.RUNNING:d++;break;case a.COMPLETED:c++;break;case a.FAILED:l++;break;case "inactivated":r++;break;default:f++;}}let n={};for(let[h,T]of Object.entries(a$1)){for(let R of g(T))n[R]||(n[R]=[]),n[R].push(h);if(T.on)for(let R of Object.values(T.on))for(let g of R)n[g]||(n[g]=[]),n[g].includes(h)||n[g].push(h);if(T.on_failure)for(let R of T.on_failure)n[R]||(n[R]=[]),n[R].includes(h)||n[R].push(h);}let u=new Set,p=0,k=0;for(let[h$1,T]of Object.entries(a$1)){let R=o.tasks[h$1];if(R?.status===a.COMPLETED||R?.status===a.RUNNING)continue;let g=false,H=false;for(let x of h(T)){let q=n[x]||[];q.length===0?(u.add(x),g=true):q.every(Y=>{let W=o.tasks[Y];return W?.status===a.FAILED||W?.status==="inactivated"})&&(H=true);}g&&p++,H&&!g&&k++;}let m=[];for(let[h,T]of Object.entries(n))T.length>1&&m.push(h);let v=Q(a$1,n),b=Z(i$1,v);return {totalNodes:i$1.length,running:d,completed:c,failed:l,waiting:f,notStarted:t,disabled:r,unresolvedCount:p,blockedCount:k,openDependencies:[...u],cycles:b,conflictTokens:m}}function Q(s,e){let o={};for(let[a,i]of Object.entries(s)){o[a]=new Set;for(let d of h(i))for(let c of e[d]||[])c!==a&&o[a].add(c);}return o}function Z(s,e){let d={},c={},l=[];for(let t of s)d[t]=0,c[t]=null;function f(t){d[t]=1;for(let r of e[t]||[])if(d[r]===1){let n=[r],u=t;for(;u!==r;)n.push(u),u=c[u];n.push(r),n.reverse(),l.push(n);}else d[r]===0&&(c[r]=t,f(r));d[t]=2;}for(let t of s)d[t]===0&&f(t);return l}function B(s){let e={};for(let[o,a]of Object.entries(s)){for(let i of g(a))e[i]||(e[i]=[]),e[i].push(o);if(a.on)for(let i of Object.values(a.on))for(let d of i)e[d]||(e[d]=[]),e[d].includes(o)||e[d].push(o);if(a.on_failure)for(let i of a.on_failure)e[i]||(e[i]=[]),e[i].includes(o)||e[i].push(o);}return e}function V(s){let{config:e,state:o}=s,a=i(e),i$1=B(a),d=new Set([...o.availableOutputs]);for(let[n,u]of Object.entries(o.tasks))if(u.status==="completed"){let p=a[n];p&&g(p).forEach(k=>d.add(k));}let c=new Set;for(let n of Object.values(a))for(let u of h(n))c.add(u);let l$1=new Set,f=new Set;for(let n of c){if(d.has(n))continue;(i$1[n]||[]).length===0&&l$1.add(n);}let t=true;for(;t;){t=false;for(let[n,u]of Object.entries(a)){if(f.has(n))continue;let p=o.tasks[n];if(p?.status==="completed")continue;let k=l(p),v=h(u).some(b=>l$1.has(b));(k||v)&&(f.has(n)||(f.add(n),t=true));}for(let n of c){if(l$1.has(n)||d.has(n))continue;let u=i$1[n]||[],p=u.length>0&&u.every(k=>f.has(k)||l(o.tasks[k]));(u.length===0||p)&&(l$1.has(n)||(l$1.add(n),t=true));}}let r=[];for(let n of l$1){let u=i$1[n]||[],p;u.length===0?p="no-producer":p=u.every(m=>l(o.tasks[m]))?"all-producers-failed":"transitive",r.push({token:n,reason:p,producers:u});}return {tokens:r}}function ee(s){let{config:e,state:o}=s,a=i(e),{tokens:i$1}=V(s),d=new Set(i$1.map(l=>l.token)),c=[];for(let[l$1,f]of Object.entries(a)){let t=o.tasks[l$1];if(t?.status==="completed")continue;let n=h(f).filter(u=>d.has(u));n.length>0?c.push({nodeName:l$1,missingTokens:n}):l(t)&&c.push({nodeName:l$1,missingTokens:[]});}return {nodes:c}}function te(s,e){let o=i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a=B(o),i$1=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of h(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i$1.has(p)||(i$1.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,providesTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function ne(s,e){let o=i(s.config);if(!o[e])return {nodeName:e,nodes:[],tokens:[]};let a={};for(let[t,r]of Object.entries(o))for(let n of h(r))a[n]||(a[n]=[]),a[n].push(t);let i$1=new Set,d=new Set,c=new Map;function l(t){let r=o[t];if(r)for(let n of g(r)){let u=a[n]||[];for(let p of u)p!==e&&(d.add(n),c.has(p)||c.set(p,new Set),c.get(p).add(n),i$1.has(p)||(i$1.add(p),l(p)));}}l(e);let f=[...c.entries()].map(([t,r])=>({nodeName:t,requiresTokens:[...r]}));return {nodeName:e,nodes:f,tokens:[...d]}}function K(s){let e=[],{config:o,state:a$1}=s,i$1=i(o),d=Object.keys(i$1);for(let t of d)a$1.tasks[t]||e.push({severity:"error",code:"MISSING_STATE",message:`Task "${t}" exists in config but has no state entry`,tasks:[t]});for(let t of Object.keys(a$1.tasks))i$1[t]||e.push({severity:"warning",code:"ORPHAN_STATE",message:`State entry "${t}" has no corresponding task config`,tasks:[t]});for(let t of d){let r=a$1.tasks[t];r&&(r.status===a.RUNNING&&!r.startedAt&&e.push({severity:"warning",code:"RUNNING_WITHOUT_START",message:`Task "${t}" is running but has no startedAt timestamp`,tasks:[t]}),r.status===a.COMPLETED&&!r.completedAt&&e.push({severity:"warning",code:"COMPLETED_WITHOUT_TIMESTAMP",message:`Task "${t}" is completed but has no completedAt timestamp`,tasks:[t]}),r.status===a.FAILED&&(r.failedAt||e.push({severity:"warning",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no failedAt timestamp`,tasks:[t]}),r.error||e.push({severity:"info",code:"FAILED_WITHOUT_INFO",message:`Task "${t}" is failed but has no error message`,tasks:[t]})));}let c=new Set;for(let t of d)if(a$1.tasks[t]?.status===a.COMPLETED)for(let n of g(i$1[t]))c.add(n);let l=new Set(a$1.availableOutputs),f=new Set;for(let t of Object.values(i$1)){for(let r of g(t))f.add(r);if(t.on)for(let r of Object.values(t.on))for(let n of r)f.add(n);if(t.on_failure)for(let r of t.on_failure)f.add(r);}for(let t of l)!c.has(t)&&!f.has(t)&&e.push({severity:"info",code:"INJECTED_TOKEN",message:`Token "${t}" is available but no task in the graph can produce it (likely injected)`,tokens:[t]});for(let t of c)l.has(t)||e.push({severity:"warning",code:"MISSING_OUTPUT",message:`Token "${t}" should be available (its producer completed) but is not in availableOutputs`,tokens:[t]});for(let t of d){let r=a$1.tasks[t];if(!r)continue;r.executionCount<0&&e.push({severity:"error",code:"INVALID_EXECUTION_COUNT",message:`Task "${t}" has negative execution count: ${r.executionCount}`,tasks:[t]});let n=i$1[t].maxExecutions;n!==void 0&&r.executionCount>n&&e.push({severity:"error",code:"EXCEEDED_MAX_EXECUTIONS",message:`Task "${t}" executed ${r.executionCount} times, exceeding maxExecutions of ${n}`,tasks:[t]});}return J(e)}function se(s){let{graph:e,handlers:o}=s,a=e.getState(),i$1=[],d=i(a.config),c=Object.keys(d),l=new Set(Object.keys(o)),f=new Set;for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)f.add(u);}for(let r of c){let n=d[r].taskHandlers;if(n)for(let u of n)o[u]||i$1.push({severity:"error",code:"MISSING_HANDLER",message:`Task "${r}" references handler "${u}" but it is not in the registry`,tasks:[r]});}for(let r of l)f.has(r)||i$1.push({severity:"warning",code:"ORPHAN_HANDLER",message:`Handler "${r}" is registered but not referenced by any task's taskHandlers`,tasks:[r]});let t=K(a);return i$1.push(...t.issues),J(i$1)}function J(s){let e=s.filter(a=>a.severity==="error"),o=s.filter(a=>a.severity==="warning");return {valid:e.length===0,issues:s,errors:e,warnings:o}}function re(s,e){let o=s;for(let a of e)o=oe(o,a);return o}function oe(s,e$1){switch(e$1.type){case "add-node":return d(s,e$1.name,e$1.config);case "remove-node":return e(s,e$1.name);case "add-requires":return f(s,e$1.taskName,e$1.tokens);case "remove-requires":return g$1(s,e$1.taskName,e$1.tokens);case "add-provides":return h$1(s,e$1.taskName,e$1.tokens);case "remove-provides":return i$1(s,e$1.taskName,e$1.tokens);case "inject-tokens":return j(s,e$1.tokens);case "drain-tokens":return k(s,e$1.tokens);case "reset-node":return l$1(s,e$1.name);case "disable-node":return m(s,e$1.name);case "enable-node":return n(s,e$1.name);case "apply-events":return c(s,e$1.events);default:throw new Error(`Unknown mutation type: ${e$1.type}`)}}function ce(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(i=>e()(a,i)).catch(i=>e()(a,{},[i instanceof Error?i.message:String(i)])),"task-initiated"}}function de(s,e){return async o=>{let{callbackToken:a}=o;return Promise.resolve(s(o)).then(()=>e()(a,{})).catch(()=>e()(a,{})),"task-initiated"}}function ue(s){let{command:e,cwd:o,env:a,timeoutMs:i=3e4,exitCodeMap:d,captureOutput:c=false,getResolve:l}=s;return async f=>{let{callbackToken:t,nodeId:r}=f,n=e.replace(/\$\{taskName\}/g,r);return exec(n,{cwd:o,env:a?{...process.env,...a}:void 0,timeout:i,maxBuffer:10*1024*1024},(u,p,k)=>{let m=u?.code??(u?1:0);if(m!==0&&!d?.[m]){l()(t,{},[`Command exited with code ${m}: ${k||u?.message}`]);return}let v={};c&&(v.stdout=p,v.stderr=k,v.exitCode=m),l()(t,v);}),"task-initiated"}}function X(s){let{command:e,args:o=[],cwd:a,env:i,timeoutMs:d=3e4,exitCodeMap:c,captureOutput:l=false,getResolve:f}=s;return async t=>{let{callbackToken:r,nodeId:n}=t,u=e.replace(/\$\{taskName\}/g,n),p=o.map(k=>k.replace(/\$\{taskName\}/g,n));return execFile(u,p,{cwd:a,env:i?{...process.env,...i}:void 0,timeout:d,maxBuffer:10*1024*1024,encoding:"utf8",windowsHide:true},(k,m,v)=>{let b=k?.code??(k?1:0);if(b!==0&&!c?.[b]){f()(r,{},[`Process exited with code ${b}: ${v||k?.message}`]);return}let h={};l&&(h.stdout=m,h.stderr=v,h.exitCode=b),f()(r,h);}),"task-initiated"}}function le(s){return s.endsWith(".js")||s.endsWith(".mjs")||s.endsWith(".ts")?"node":s.endsWith(".py")?"python3":(s.endsWith(".sh"),"bash")}function pe(s){let{scriptPath:e,runtime:o,args:a=[],cwd:i,timeoutMs:d=6e4,captureOutput:c=false,getResolve:l}=s,f=o??le(e),t=f==="node"?process.execPath:f;return X({command:t,args:[e,"${taskName}",...a],cwd:i,timeoutMs:d,captureOutput:c,getResolve:l})}function fe(s){let{url:e,method:o="POST",headers:a={},timeoutMs:i=3e4,failOnNon2xx:d=true,getResolve:c}=s;return async l=>{let{callbackToken:f,nodeId:t,config:r}=l,n=e.replace(/\$\{taskName\}/g,t),u=JSON.stringify({taskName:t,callbackToken:f,config:r}),p=new AbortController,k=setTimeout(()=>p.abort(),i);return fetch(n,{method:o,headers:{"Content-Type":"application/json",...a},body:u,signal:p.signal}).then(async m=>{if(clearTimeout(k),d&&!m.ok){let b=await m.text().catch(()=>"");c()(f,{},[`HTTP ${m.status}: ${b}`]);return}let v=await m.json().catch(()=>({}));c()(f,v);}).catch(m=>{clearTimeout(k),c()(f,{},[m instanceof Error?m.message:String(m)]);}),"task-initiated"}}function ge(s,e){return async o=>(s()(o.callbackToken,e??{}),"task-initiated")}function ke(s,e={}){let o,a={},i;if(!Array.isArray(s)&&"nodes"in s){let g=s;o=g.nodes,i=g.id,a=g.settings??{};}else o=s;let{sourceHandlers:d={},defaultSourceHandler:c,cardHandlers:l={},reactiveOptions:f={},graphSettings:t$1={},executionId:r}=e,n=new Map;for(let g of o){if(n.has(g.id))throw new Error(`Duplicate card ID: "${g.id}"`);n.set(g.id,g);}let u=e.sharedState??new Map,p={},k=new Set,m=new Map;for(let g of o)for(let H of g.provides??[{bindTo:g.id,ref:"card_data"}])k.add(H.bindTo),m.set(H.bindTo,g.id);for(let g of o){let H=g.requires??[];for(let x of H)if(!k.has(x))throw new Error(`Card "${g.id}" requires "${x}" but no card provides that token`);p[g.id]={requires:H.length>0?H:void 0,provides:(g.provides??[{bindTo:g.id,ref:"card_data"}]).map(x=>x.bindTo),taskHandlers:[g.id],description:g.meta?.title??g.id};}let v={id:i??`live-cards-${Date.now()}`,settings:{completion:"manual",execution_mode:"eligibility-mode",...a,...t$1},tasks:p},b={},h=null,T=()=>(g,H,x)=>{h.resolveCallback(g,H,x);};for(let g of o)g.source_defs&&g.source_defs.length>0?b[g.id]=me(g,d,c,u,T):b[g.id]=he(g,l,u,n,m,T);let R=t(v,{...f,handlers:b},r);return h=R,{graph:R,config:v,handlers:b,cards:n,sharedState:u}}function me(s,e,o,a,i){if(e[s.id]){let d=e[s.id];return async c=>d(c)}if(o){let d=o(s);return async c=>d(c)}return async d=>{let c={...s.card_data};return a.set(s.id,c),i()(d.callbackToken,c),"task-initiated"}}function he(s,e,o,a,i,d){if(e[s.id]){let c=e[s.id];return async l=>c(l)}return async c=>{let l={},f=s.requires??[];for(let u of f){let p=i.get(u)??u,k=o.get(p);k&&(l[u]=k[u]??k);}let t={id:s.id,card_data:{...s.card_data},requires:l,compute:s.compute};await a$1.run(t);let r;if(s.provides&&s.provides.length>0){r={};for(let{bindTo:u,ref:p}of s.provides)r[u]=a$1.resolve(t,p);}else r={...t.card_data,...t.computed_values};let n={...t.card_data,...t.computed_values};return o.set(s.id,n),d()(c.callbackToken,r),"task-initiated"}}export{z as a,V as b,ee as c,te as d,ne as e,K as f,se as g,re as h,ce as i,de as j,ue as k,X as l,pe as m,fe as n,ge as o,ke as p};//# sourceMappingURL=chunk-ROIYEFSE.js.map
2
+ //# sourceMappingURL=chunk-ROIYEFSE.js.map
@@ -0,0 +1,2 @@
1
+ import {d}from'./chunk-3SLSRX6Q.js';function s(r){let e=d(r);return {isValid:e.ok,issues:e.errors}}export{s as a};//# sourceMappingURL=chunk-UJQ7IML5.js.map
2
+ //# sourceMappingURL=chunk-UJQ7IML5.js.map
@@ -0,0 +1,2 @@
1
+ import {createRequire}from'module';var g=createRequire(import.meta.url),u=g("./jsonata-sync.cjs"),c=u;function d(t,r){if(!r||!t)return;let s=r.split("."),e=t;for(let n=0;n<s.length;n++){if(e==null)return;e=e[s[n]];}return e}function f(t,r,s){let e=r.split("."),n=t;for(let o=0;o<e.length-1;o++)(n[e[o]]==null||typeof n[e[o]]!="object")&&(n[e[o]]={}),n=n[e[o]];n[e[e.length-1]]=s;}async function m(t,r){if(!t?.compute?.length)return t;t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=r?.sourcesData??{};let s=t.requires??{},e={card_data:t.card_data,requires:s,expects_data:s,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values};for(let n of t.compute)try{let o=await u(n.expr).evaluate(e);f(t.computed_values,n.bindTo,o),e.computed_values=t.computed_values;}catch{}return t}function y(t,r){if(!t?.compute?.length)return {ok:true,node:t};t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=r?.sourcesData??{};let s=t.requires??{},e={card_data:t.card_data,requires:s,expects_data:s,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values},n=[];for(let o of t.compute)try{let a=c(o.expr).evaluate(e);f(t.computed_values,o.bindTo,a),e.computed_values=t.computed_values;}catch(a){let i=a instanceof Error?a.message:String(a);n.push({bindTo:o.bindTo,error:i});}return n.length>0?{ok:true,node:t,errors:n}:{ok:true,node:t}}async function _(t,r,s){let e={...s??{},card_data:r.card_data??{},requires:r.requires??{},fetched_sources:r._sourcesData??{},computed_values:r.computed_values??{}};return u(t).evaluate(e)}function b(t,r){return r.startsWith("fetched_sources.")?d(t._sourcesData??{},r.slice(16)):d(t,r)}var p=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),h=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function k(t){let r=[];if(!t||typeof t!="object"||Array.isArray(t))return {ok:false,errors:["Node must be a non-null object"]};let s=t;(typeof s.id!="string"||!s.id)&&r.push("id: required, must be a non-empty string");for(let e of Object.keys(s))h.has(e)||r.push(`Unknown top-level key: "${e}"`);if((s.card_data==null||typeof s.card_data!="object"||Array.isArray(s.card_data))&&r.push("card_data: required, must be an object"),s.meta!=null)if(typeof s.meta!="object"||Array.isArray(s.meta))r.push("meta: must be an object");else {let e=s.meta;e.title!=null&&typeof e.title!="string"&&r.push("meta.title: must be a string"),e.tags!=null&&!Array.isArray(e.tags)&&r.push("meta.tags: must be an array");}if(s.requires!=null&&!Array.isArray(s.requires)&&r.push("requires: must be an array of strings"),s.provides!=null&&(Array.isArray(s.provides)?s.provides.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))r.push(`provides[${n}]: must be an object with bindTo and ref`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&r.push(`provides[${n}]: missing required "bindTo" string`),(typeof o.ref!="string"||!o.ref)&&r.push(`provides[${n}]: missing required "ref" string`);}}):r.push("provides: must be an array of { bindTo, ref } bindings")),s.compute!=null&&(Array.isArray(s.compute)?s.compute.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))r.push(`compute[${n}]: must be a compute step object`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&r.push(`compute[${n}]: missing required "bindTo" property`),(typeof o.expr!="string"||!o.expr)&&r.push(`compute[${n}]: missing required "expr" string (JSONata expression)`);}}):r.push("compute: must be an array of compute steps")),s.source_defs!=null)if(!Array.isArray(s.source_defs))r.push("source_defs: must be an array");else {let e=new Set,n=new Set;s.source_defs.forEach((o,a)=>{if(!o||typeof o!="object"||Array.isArray(o))r.push(`source_defs[${a}]: must be an object`);else {let i=o;typeof i.bindTo!="string"||!i.bindTo?r.push(`source_defs[${a}]: missing required "bindTo" property`):(e.has(i.bindTo)&&r.push(`source_defs[${a}]: bindTo "${i.bindTo}" is not unique across source_defs`),e.add(i.bindTo)),typeof i.outputFile!="string"||!i.outputFile?r.push(`source_defs[${a}]: missing required "outputFile" property`):(n.has(i.outputFile)&&r.push(`source_defs[${a}]: outputFile "${i.outputFile}" is not unique across source_defs`),n.add(i.outputFile));}});}if(s.view!=null)if(typeof s.view!="object"||Array.isArray(s.view))r.push("view: must be an object");else {let e=s.view;!Array.isArray(e.elements)||e.elements.length===0?r.push("view.elements: required, must be a non-empty array"):e.elements.forEach((n,o)=>{if(!n||typeof n!="object"){r.push(`view.elements[${o}]: must be an object`);return}!n.kind||typeof n.kind!="string"?r.push(`view.elements[${o}].kind: required, must be a string`):p.has(n.kind)||r.push(`view.elements[${o}].kind: unknown kind "${n.kind}". Valid: ${[...p].join(", ")}`),n.data!=null&&(typeof n.data!="object"||Array.isArray(n.data))&&r.push(`view.elements[${o}].data: must be an object`);});}return {ok:r.length===0,errors:r}}async function w(t,r){if(!t||t.length===0)return [];let s={card_data:r.card_data??{},requires:r.requires??{}};return Promise.all(t.map(async e=>{let n=false;if(typeof e.skip_when=="string"&&e.skip_when.trim().length>0)try{n=!!await u(e.skip_when).evaluate(s);}catch{n=false;}let o={};if(!n&&e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[a,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{o[a]=await u(i).evaluate(s);}catch{o[a]=void 0;}}return {...e,_projections:o,_skip:n}}))}function v(t,r){if(!t||t.length===0)return [];let s={card_data:r.card_data??{},requires:r.requires??{}};return t.map(e=>{let n=false;if(typeof e.skip_when=="string"&&e.skip_when.trim().length>0)try{n=!!c(e.skip_when).evaluate(s);}catch{n=false;}let o={};if(!n&&e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[a,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{o[a]=c(i).evaluate(s);}catch{o[a]=void 0;}}return {...e,_projections:o,_skip:n}})}var j={run:m,runSync:y,eval:_,resolve:b,validate:k,enrichSources:w,enrichSourcesSync:v},$=j;export{j as a,$ as b};//# sourceMappingURL=chunk-YOY2JM5N.js.map
2
+ //# sourceMappingURL=chunk-YOY2JM5N.js.map
@@ -0,0 +1,2 @@
1
+ 'use strict';var module$1=require('module');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var g=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-ZV35WD6K.cjs', document.baseURI).href))),u=g("./jsonata-sync.cjs"),c=u;function d(t,r){if(!r||!t)return;let s=r.split("."),e=t;for(let n=0;n<s.length;n++){if(e==null)return;e=e[s[n]];}return e}function f(t,r,s){let e=r.split("."),n=t;for(let o=0;o<e.length-1;o++)(n[e[o]]==null||typeof n[e[o]]!="object")&&(n[e[o]]={}),n=n[e[o]];n[e[e.length-1]]=s;}async function m(t,r){if(!t?.compute?.length)return t;t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=r?.sourcesData??{};let s=t.requires??{},e={card_data:t.card_data,requires:s,expects_data:s,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values};for(let n of t.compute)try{let o=await u(n.expr).evaluate(e);f(t.computed_values,n.bindTo,o),e.computed_values=t.computed_values;}catch{}return t}function y(t,r){if(!t?.compute?.length)return {ok:true,node:t};t.card_data||(t.card_data={}),t.computed_values={},t._sourcesData=r?.sourcesData??{};let s=t.requires??{},e={card_data:t.card_data,requires:s,expects_data:s,fetched_sources:t._sourcesData,data:t.computed_values,computed_values:t.computed_values},n=[];for(let o of t.compute)try{let a=c(o.expr).evaluate(e);f(t.computed_values,o.bindTo,a),e.computed_values=t.computed_values;}catch(a){let i=a instanceof Error?a.message:String(a);n.push({bindTo:o.bindTo,error:i});}return n.length>0?{ok:true,node:t,errors:n}:{ok:true,node:t}}async function _(t,r,s){let e={...s??{},card_data:r.card_data??{},requires:r.requires??{},fetched_sources:r._sourcesData??{},computed_values:r.computed_values??{}};return u(t).evaluate(e)}function b(t,r){return r.startsWith("fetched_sources.")?d(t._sourcesData??{},r.slice(16)):d(t,r)}var p=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),h=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function k(t){let r=[];if(!t||typeof t!="object"||Array.isArray(t))return {ok:false,errors:["Node must be a non-null object"]};let s=t;(typeof s.id!="string"||!s.id)&&r.push("id: required, must be a non-empty string");for(let e of Object.keys(s))h.has(e)||r.push(`Unknown top-level key: "${e}"`);if((s.card_data==null||typeof s.card_data!="object"||Array.isArray(s.card_data))&&r.push("card_data: required, must be an object"),s.meta!=null)if(typeof s.meta!="object"||Array.isArray(s.meta))r.push("meta: must be an object");else {let e=s.meta;e.title!=null&&typeof e.title!="string"&&r.push("meta.title: must be a string"),e.tags!=null&&!Array.isArray(e.tags)&&r.push("meta.tags: must be an array");}if(s.requires!=null&&!Array.isArray(s.requires)&&r.push("requires: must be an array of strings"),s.provides!=null&&(Array.isArray(s.provides)?s.provides.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))r.push(`provides[${n}]: must be an object with bindTo and ref`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&r.push(`provides[${n}]: missing required "bindTo" string`),(typeof o.ref!="string"||!o.ref)&&r.push(`provides[${n}]: missing required "ref" string`);}}):r.push("provides: must be an array of { bindTo, ref } bindings")),s.compute!=null&&(Array.isArray(s.compute)?s.compute.forEach((e,n)=>{if(!e||typeof e!="object"||Array.isArray(e))r.push(`compute[${n}]: must be a compute step object`);else {let o=e;(typeof o.bindTo!="string"||!o.bindTo)&&r.push(`compute[${n}]: missing required "bindTo" property`),(typeof o.expr!="string"||!o.expr)&&r.push(`compute[${n}]: missing required "expr" string (JSONata expression)`);}}):r.push("compute: must be an array of compute steps")),s.source_defs!=null)if(!Array.isArray(s.source_defs))r.push("source_defs: must be an array");else {let e=new Set,n=new Set;s.source_defs.forEach((o,a)=>{if(!o||typeof o!="object"||Array.isArray(o))r.push(`source_defs[${a}]: must be an object`);else {let i=o;typeof i.bindTo!="string"||!i.bindTo?r.push(`source_defs[${a}]: missing required "bindTo" property`):(e.has(i.bindTo)&&r.push(`source_defs[${a}]: bindTo "${i.bindTo}" is not unique across source_defs`),e.add(i.bindTo)),typeof i.outputFile!="string"||!i.outputFile?r.push(`source_defs[${a}]: missing required "outputFile" property`):(n.has(i.outputFile)&&r.push(`source_defs[${a}]: outputFile "${i.outputFile}" is not unique across source_defs`),n.add(i.outputFile));}});}if(s.view!=null)if(typeof s.view!="object"||Array.isArray(s.view))r.push("view: must be an object");else {let e=s.view;!Array.isArray(e.elements)||e.elements.length===0?r.push("view.elements: required, must be a non-empty array"):e.elements.forEach((n,o)=>{if(!n||typeof n!="object"){r.push(`view.elements[${o}]: must be an object`);return}!n.kind||typeof n.kind!="string"?r.push(`view.elements[${o}].kind: required, must be a string`):p.has(n.kind)||r.push(`view.elements[${o}].kind: unknown kind "${n.kind}". Valid: ${[...p].join(", ")}`),n.data!=null&&(typeof n.data!="object"||Array.isArray(n.data))&&r.push(`view.elements[${o}].data: must be an object`);});}return {ok:r.length===0,errors:r}}async function w(t,r){if(!t||t.length===0)return [];let s={card_data:r.card_data??{},requires:r.requires??{}};return Promise.all(t.map(async e=>{let n=false;if(typeof e.skip_when=="string"&&e.skip_when.trim().length>0)try{n=!!await u(e.skip_when).evaluate(s);}catch{n=false;}let o={};if(!n&&e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[a,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{o[a]=await u(i).evaluate(s);}catch{o[a]=void 0;}}return {...e,_projections:o,_skip:n}}))}function v(t,r){if(!t||t.length===0)return [];let s={card_data:r.card_data??{},requires:r.requires??{}};return t.map(e=>{let n=false;if(typeof e.skip_when=="string"&&e.skip_when.trim().length>0)try{n=!!c(e.skip_when).evaluate(s);}catch{n=false;}let o={};if(!n&&e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[a,i]of Object.entries(e.projections))if(typeof i=="string"&&i.trim().length>0)try{o[a]=c(i).evaluate(s);}catch{o[a]=void 0;}}return {...e,_projections:o,_skip:n}})}var j={run:m,runSync:y,eval:_,resolve:b,validate:k,enrichSources:w,enrichSourcesSync:v},$=j;exports.a=j;exports.b=$;//# sourceMappingURL=chunk-ZV35WD6K.cjs.map
2
+ //# sourceMappingURL=chunk-ZV35WD6K.cjs.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunk6EJRZHFP_cjs=require('./chunk-6EJRZHFP.cjs'),chunkK5TEZRZK_cjs=require('./chunk-K5TEZRZK.cjs'),chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs');require('./chunk-3XPY7CCM.cjs'),require('./chunk-AW3COGCI.cjs'),require('./chunk-SIPLKLWU.cjs'),require('./chunk-J7KE7SPA.cjs'),require('./chunk-7JVHYHT2.cjs'),require('./chunk-VQCIOKJV.cjs'),require('./chunk-VI36DRWG.cjs'),require('./chunk-7Y47QXMX.cjs'),require('./chunk-QBEQL4TL.cjs'),require('./chunk-QEHKMLHA.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-2RIHC5TZ.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createAzureBlobStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.d}});Object.defineProperty(exports,"createAzureQueueStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.e}});Object.defineProperty(exports,"createCosmosAtomicRelayLock",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.c}});Object.defineProperty(exports,"createCosmosJournalStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.b}});Object.defineProperty(exports,"createCosmosKvStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.a}});Object.defineProperty(exports,"createAsyncBoardLiveCardsPublic",{enumerable:true,get:function(){return chunkK5TEZRZK_cjs.i}});Object.defineProperty(exports,"createAsyncCardStorageAdapter",{enumerable:true,get:function(){return chunkK5TEZRZK_cjs.c}});Object.defineProperty(exports,"createAsyncCardStore",{enumerable:true,get:function(){return chunkK5TEZRZK_cjs.d}});Object.defineProperty(exports,"createAsyncCardStorePublic",{enumerable:true,get:function(){return chunkK5TEZRZK_cjs.g}});Object.defineProperty(exports,"createAsyncJsonStorage",{enumerable:true,get:function(){return chunkK5TEZRZK_cjs.b}});Object.defineProperty(exports,"createAsyncQueueStoragePublic",{enumerable:true,get:function(){return chunkK5TEZRZK_cjs.h}});Object.defineProperty(exports,"createAsyncStateSnapshotAdapter",{enumerable:true,get:function(){return chunkK5TEZRZK_cjs.e}});Object.defineProperty(exports,"createAsyncStorageProvider",{enumerable:true,get:function(){return chunkK5TEZRZK_cjs.f}});Object.defineProperty(exports,"withAsyncRelayLock",{enumerable:true,get:function(){return chunkK5TEZRZK_cjs.a}});Object.defineProperty(exports,"createAsyncBoardConfigStore",{enumerable:true,get:function(){return chunkCSHNTZW4_cjs.b}});Object.defineProperty(exports,"createAsyncBoardWorkerStore",{enumerable:true,get:function(){return chunkCSHNTZW4_cjs.a}});Object.defineProperty(exports,"createHostedAsyncBoardPlatformAdapter",{enumerable:true,get:function(){return chunkCSHNTZW4_cjs.c}});//# sourceMappingURL=cloud-storage.cjs.map
1
+ 'use strict';var chunk6EJRZHFP_cjs=require('./chunk-6EJRZHFP.cjs'),chunkMRIFSG7L_cjs=require('./chunk-MRIFSG7L.cjs'),chunkCSHNTZW4_cjs=require('./chunk-CSHNTZW4.cjs');require('./chunk-EGZPROOH.cjs'),require('./chunk-AW3COGCI.cjs'),require('./chunk-SIPLKLWU.cjs'),require('./chunk-JOQWJ3VR.cjs'),require('./chunk-7JVHYHT2.cjs'),require('./chunk-VQCIOKJV.cjs'),require('./chunk-VI36DRWG.cjs'),require('./chunk-7Y47QXMX.cjs'),require('./chunk-ZV35WD6K.cjs'),require('./chunk-3DWVFRQD.cjs'),require('./chunk-UJ7ZTV4J.cjs'),require('./chunk-2RIHC5TZ.cjs'),require('./chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createAzureBlobStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.d}});Object.defineProperty(exports,"createAzureQueueStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.e}});Object.defineProperty(exports,"createCosmosAtomicRelayLock",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.c}});Object.defineProperty(exports,"createCosmosJournalStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.b}});Object.defineProperty(exports,"createCosmosKvStorage",{enumerable:true,get:function(){return chunk6EJRZHFP_cjs.a}});Object.defineProperty(exports,"createAsyncBoardLiveCardsPublic",{enumerable:true,get:function(){return chunkMRIFSG7L_cjs.i}});Object.defineProperty(exports,"createAsyncCardStorageAdapter",{enumerable:true,get:function(){return chunkMRIFSG7L_cjs.c}});Object.defineProperty(exports,"createAsyncCardStore",{enumerable:true,get:function(){return chunkMRIFSG7L_cjs.d}});Object.defineProperty(exports,"createAsyncCardStorePublic",{enumerable:true,get:function(){return chunkMRIFSG7L_cjs.g}});Object.defineProperty(exports,"createAsyncJsonStorage",{enumerable:true,get:function(){return chunkMRIFSG7L_cjs.b}});Object.defineProperty(exports,"createAsyncQueueStoragePublic",{enumerable:true,get:function(){return chunkMRIFSG7L_cjs.h}});Object.defineProperty(exports,"createAsyncStateSnapshotAdapter",{enumerable:true,get:function(){return chunkMRIFSG7L_cjs.e}});Object.defineProperty(exports,"createAsyncStorageProvider",{enumerable:true,get:function(){return chunkMRIFSG7L_cjs.f}});Object.defineProperty(exports,"withAsyncRelayLock",{enumerable:true,get:function(){return chunkMRIFSG7L_cjs.a}});Object.defineProperty(exports,"createAsyncBoardConfigStore",{enumerable:true,get:function(){return chunkCSHNTZW4_cjs.b}});Object.defineProperty(exports,"createAsyncBoardWorkerStore",{enumerable:true,get:function(){return chunkCSHNTZW4_cjs.a}});Object.defineProperty(exports,"createHostedAsyncBoardPlatformAdapter",{enumerable:true,get:function(){return chunkCSHNTZW4_cjs.c}});//# sourceMappingURL=cloud-storage.cjs.map
2
2
  //# sourceMappingURL=cloud-storage.cjs.map
@@ -1,2 +1,2 @@
1
- export{d as createAzureBlobStorage,e as createAzureQueueStorage,c as createCosmosAtomicRelayLock,b as createCosmosJournalStorage,a as createCosmosKvStorage}from'./chunk-QLB6PKOT.js';export{i as createAsyncBoardLiveCardsPublic,c as createAsyncCardStorageAdapter,d as createAsyncCardStore,g as createAsyncCardStorePublic,b as createAsyncJsonStorage,h as createAsyncQueueStoragePublic,e as createAsyncStateSnapshotAdapter,f as createAsyncStorageProvider,a as withAsyncRelayLock}from'./chunk-RKLEBQUG.js';export{b as createAsyncBoardConfigStore,a as createAsyncBoardWorkerStore,c as createHostedAsyncBoardPlatformAdapter}from'./chunk-PEJRTZU3.js';import'./chunk-X32SJDLT.js';import'./chunk-FULAMLUU.js';import'./chunk-EOVTMJYZ.js';import'./chunk-WGYS2L4V.js';import'./chunk-ANKA7HEJ.js';import'./chunk-44L64VQ2.js';import'./chunk-Q444D72R.js';import'./chunk-R7SQQSDX.js';import'./chunk-ATOQP3BD.js';import'./chunk-YT76JNKE.js';import'./chunk-MNEOJWPS.js';import'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=cloud-storage.js.map
1
+ export{d as createAzureBlobStorage,e as createAzureQueueStorage,c as createCosmosAtomicRelayLock,b as createCosmosJournalStorage,a as createCosmosKvStorage}from'./chunk-QLB6PKOT.js';export{i as createAsyncBoardLiveCardsPublic,c as createAsyncCardStorageAdapter,d as createAsyncCardStore,g as createAsyncCardStorePublic,b as createAsyncJsonStorage,h as createAsyncQueueStoragePublic,e as createAsyncStateSnapshotAdapter,f as createAsyncStorageProvider,a as withAsyncRelayLock}from'./chunk-REZO2QJD.js';export{b as createAsyncBoardConfigStore,a as createAsyncBoardWorkerStore,c as createHostedAsyncBoardPlatformAdapter}from'./chunk-PEJRTZU3.js';import'./chunk-BRYV6CDD.js';import'./chunk-FULAMLUU.js';import'./chunk-EOVTMJYZ.js';import'./chunk-MRESV3MD.js';import'./chunk-ANKA7HEJ.js';import'./chunk-44L64VQ2.js';import'./chunk-Q444D72R.js';import'./chunk-R7SQQSDX.js';import'./chunk-YOY2JM5N.js';import'./chunk-3SLSRX6Q.js';import'./chunk-MNEOJWPS.js';import'./chunk-UGB7PC4P.js';import'./chunk-FW4363Y4.js';//# sourceMappingURL=cloud-storage.js.map
2
2
  //# sourceMappingURL=cloud-storage.js.map
@@ -1,2 +1,2 @@
1
- 'use strict';var chunk52XPRCZC_cjs=require('../chunk-52XPRCZC.cjs'),chunkAW3COGCI_cjs=require('../chunk-AW3COGCI.cjs');require('../chunk-SIPLKLWU.cjs');var chunkVI36DRWG_cjs=require('../chunk-VI36DRWG.cjs');require('../chunk-7Y47QXMX.cjs'),require('../chunk-QBEQL4TL.cjs'),require('../chunk-QEHKMLHA.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createCallbackHandler",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.i}});Object.defineProperty(exports,"createFireAndForgetHandler",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.j}});Object.defineProperty(exports,"createNoopHandler",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.o}});Object.defineProperty(exports,"createProcessHandler",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.l}});Object.defineProperty(exports,"createScriptHandler",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.m}});Object.defineProperty(exports,"createShellHandler",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.k}});Object.defineProperty(exports,"createWebhookHandler",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.n}});Object.defineProperty(exports,"getDownstream",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.e}});Object.defineProperty(exports,"getUnreachableNodes",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.c}});Object.defineProperty(exports,"getUnreachableTokens",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.b}});Object.defineProperty(exports,"getUpstream",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.d}});Object.defineProperty(exports,"inspect",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.a}});Object.defineProperty(exports,"liveCardsToReactiveGraph",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.p}});Object.defineProperty(exports,"mutateGraph",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.h}});Object.defineProperty(exports,"validateLiveGraph",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.f}});Object.defineProperty(exports,"validateReactiveGraph",{enumerable:true,get:function(){return chunk52XPRCZC_cjs.g}});Object.defineProperty(exports,"MemoryJournal",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.r}});Object.defineProperty(exports,"addNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.d}});Object.defineProperty(exports,"addProvides",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.h}});Object.defineProperty(exports,"addRequires",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.f}});Object.defineProperty(exports,"applyEvent",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.b}});Object.defineProperty(exports,"applyEvents",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.c}});Object.defineProperty(exports,"computeDataHash",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.s}});Object.defineProperty(exports,"createLiveGraph",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.a}});Object.defineProperty(exports,"createReactiveGraph",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.t}});Object.defineProperty(exports,"disableNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.m}});Object.defineProperty(exports,"drainTokens",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.k}});Object.defineProperty(exports,"enableNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.n}});Object.defineProperty(exports,"getNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.o}});Object.defineProperty(exports,"injectTokens",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.j}});Object.defineProperty(exports,"removeNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.e}});Object.defineProperty(exports,"removeProvides",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.i}});Object.defineProperty(exports,"removeRequires",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.g}});Object.defineProperty(exports,"resetNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.l}});Object.defineProperty(exports,"restore",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.q}});Object.defineProperty(exports,"snapshot",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.p}});Object.defineProperty(exports,"schedule",{enumerable:true,get:function(){return chunkVI36DRWG_cjs.a}});//# sourceMappingURL=index.cjs.map
1
+ 'use strict';var chunkHOS2ZUFZ_cjs=require('../chunk-HOS2ZUFZ.cjs'),chunkAW3COGCI_cjs=require('../chunk-AW3COGCI.cjs');require('../chunk-SIPLKLWU.cjs');var chunkVI36DRWG_cjs=require('../chunk-VI36DRWG.cjs');require('../chunk-7Y47QXMX.cjs'),require('../chunk-ZV35WD6K.cjs'),require('../chunk-3DWVFRQD.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-GNFE24S7.cjs');Object.defineProperty(exports,"createCallbackHandler",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.i}});Object.defineProperty(exports,"createFireAndForgetHandler",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.j}});Object.defineProperty(exports,"createNoopHandler",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.o}});Object.defineProperty(exports,"createProcessHandler",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.l}});Object.defineProperty(exports,"createScriptHandler",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.m}});Object.defineProperty(exports,"createShellHandler",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.k}});Object.defineProperty(exports,"createWebhookHandler",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.n}});Object.defineProperty(exports,"getDownstream",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.e}});Object.defineProperty(exports,"getUnreachableNodes",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.c}});Object.defineProperty(exports,"getUnreachableTokens",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.b}});Object.defineProperty(exports,"getUpstream",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.d}});Object.defineProperty(exports,"inspect",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.a}});Object.defineProperty(exports,"liveCardsToReactiveGraph",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.p}});Object.defineProperty(exports,"mutateGraph",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.h}});Object.defineProperty(exports,"validateLiveGraph",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.f}});Object.defineProperty(exports,"validateReactiveGraph",{enumerable:true,get:function(){return chunkHOS2ZUFZ_cjs.g}});Object.defineProperty(exports,"MemoryJournal",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.r}});Object.defineProperty(exports,"addNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.d}});Object.defineProperty(exports,"addProvides",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.h}});Object.defineProperty(exports,"addRequires",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.f}});Object.defineProperty(exports,"applyEvent",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.b}});Object.defineProperty(exports,"applyEvents",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.c}});Object.defineProperty(exports,"computeDataHash",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.s}});Object.defineProperty(exports,"createLiveGraph",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.a}});Object.defineProperty(exports,"createReactiveGraph",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.t}});Object.defineProperty(exports,"disableNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.m}});Object.defineProperty(exports,"drainTokens",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.k}});Object.defineProperty(exports,"enableNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.n}});Object.defineProperty(exports,"getNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.o}});Object.defineProperty(exports,"injectTokens",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.j}});Object.defineProperty(exports,"removeNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.e}});Object.defineProperty(exports,"removeProvides",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.i}});Object.defineProperty(exports,"removeRequires",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.g}});Object.defineProperty(exports,"resetNode",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.l}});Object.defineProperty(exports,"restore",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.q}});Object.defineProperty(exports,"snapshot",{enumerable:true,get:function(){return chunkAW3COGCI_cjs.p}});Object.defineProperty(exports,"schedule",{enumerable:true,get:function(){return chunkVI36DRWG_cjs.a}});//# sourceMappingURL=index.cjs.map
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1,2 +1,2 @@
1
- export{i as createCallbackHandler,j as createFireAndForgetHandler,o as createNoopHandler,l as createProcessHandler,m as createScriptHandler,k as createShellHandler,n as createWebhookHandler,e as getDownstream,c as getUnreachableNodes,b as getUnreachableTokens,d as getUpstream,a as inspect,p as liveCardsToReactiveGraph,h as mutateGraph,f as validateLiveGraph,g as validateReactiveGraph}from'../chunk-23PEDGFN.js';export{r as MemoryJournal,d as addNode,h as addProvides,f as addRequires,b as applyEvent,c as applyEvents,s as computeDataHash,a as createLiveGraph,t as createReactiveGraph,m as disableNode,k as drainTokens,n as enableNode,o as getNode,j as injectTokens,e as removeNode,i as removeProvides,g as removeRequires,l as resetNode,q as restore,p as snapshot}from'../chunk-FULAMLUU.js';import'../chunk-EOVTMJYZ.js';export{a as schedule}from'../chunk-Q444D72R.js';import'../chunk-R7SQQSDX.js';import'../chunk-ATOQP3BD.js';import'../chunk-YT76JNKE.js';import'../chunk-MNEOJWPS.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
1
+ export{i as createCallbackHandler,j as createFireAndForgetHandler,o as createNoopHandler,l as createProcessHandler,m as createScriptHandler,k as createShellHandler,n as createWebhookHandler,e as getDownstream,c as getUnreachableNodes,b as getUnreachableTokens,d as getUpstream,a as inspect,p as liveCardsToReactiveGraph,h as mutateGraph,f as validateLiveGraph,g as validateReactiveGraph}from'../chunk-ROIYEFSE.js';export{r as MemoryJournal,d as addNode,h as addProvides,f as addRequires,b as applyEvent,c as applyEvents,s as computeDataHash,a as createLiveGraph,t as createReactiveGraph,m as disableNode,k as drainTokens,n as enableNode,o as getNode,j as injectTokens,e as removeNode,i as removeProvides,g as removeRequires,l as resetNode,q as restore,p as snapshot}from'../chunk-FULAMLUU.js';import'../chunk-EOVTMJYZ.js';export{a as schedule}from'../chunk-Q444D72R.js';import'../chunk-R7SQQSDX.js';import'../chunk-YOY2JM5N.js';import'../chunk-3SLSRX6Q.js';import'../chunk-MNEOJWPS.js';import'../chunk-FW4363Y4.js';//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,3 +1,3 @@
1
- 'use strict';var chunkHFW7E2Z7_cjs=require('../chunk-HFW7E2Z7.cjs'),chunkMCPADH33_cjs=require('../chunk-MCPADH33.cjs');require('../chunk-6EJRZHFP.cjs'),require('../chunk-K5TEZRZK.cjs');var chunkCSHNTZW4_cjs=require('../chunk-CSHNTZW4.cjs');require('../chunk-3XPY7CCM.cjs'),require('../chunk-AW3COGCI.cjs'),require('../chunk-SIPLKLWU.cjs'),require('../chunk-J7KE7SPA.cjs'),require('../chunk-7JVHYHT2.cjs');var chunkVQCIOKJV_cjs=require('../chunk-VQCIOKJV.cjs');require('../chunk-VI36DRWG.cjs'),require('../chunk-7Y47QXMX.cjs'),require('../chunk-QBEQL4TL.cjs'),require('../chunk-QEHKMLHA.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return chunkHFW7E2Z7_cjs.a(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return chunkVQCIOKJV_cjs.b(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return chunkVQCIOKJV_cjs.a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return chunkCSHNTZW4_cjs.c({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return chunkMCPADH33_cjs.b(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
1
+ 'use strict';var chunkHFW7E2Z7_cjs=require('../chunk-HFW7E2Z7.cjs'),chunkMCPADH33_cjs=require('../chunk-MCPADH33.cjs');require('../chunk-6EJRZHFP.cjs'),require('../chunk-MRIFSG7L.cjs');var chunkCSHNTZW4_cjs=require('../chunk-CSHNTZW4.cjs');require('../chunk-EGZPROOH.cjs'),require('../chunk-AW3COGCI.cjs'),require('../chunk-SIPLKLWU.cjs'),require('../chunk-JOQWJ3VR.cjs'),require('../chunk-7JVHYHT2.cjs');var chunkVQCIOKJV_cjs=require('../chunk-VQCIOKJV.cjs');require('../chunk-VI36DRWG.cjs'),require('../chunk-7Y47QXMX.cjs'),require('../chunk-ZV35WD6K.cjs'),require('../chunk-3DWVFRQD.cjs'),require('../chunk-UJ7ZTV4J.cjs'),require('../chunk-2RIHC5TZ.cjs'),require('../chunk-GNFE24S7.cjs');function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return chunkHFW7E2Z7_cjs.a(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return chunkVQCIOKJV_cjs.b(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return chunkVQCIOKJV_cjs.a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return chunkCSHNTZW4_cjs.c({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return chunkMCPADH33_cjs.b(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
2
2
  exports.createFirestoreArchiveFactory=P;exports.createFirestoreBlobStorage=w;exports.createFirestoreBoardAdapter=z;exports.createFirestoreBoardRefs=N;exports.createFirestoreBoardRuntimeBundle=Y;exports.createFirestoreJournalStorage=m;exports.createFirestoreKvStorage=A;exports.createFirestoreLock=J;exports.createFirestoreQueueStorage=W;exports.createFirestoreScratchStorage=O;exports.makeFirestoreRef=b;exports.serializeFirestoreRef=l;//# sourceMappingURL=index.cjs.map
3
3
  //# sourceMappingURL=index.cjs.map
@@ -1,3 +1,3 @@
1
- import {a as a$1}from'../chunk-VS3BXEYK.js';import {b as b$1}from'../chunk-Y4WK7HE4.js';import'../chunk-QLB6PKOT.js';import'../chunk-RKLEBQUG.js';import {c as c$1}from'../chunk-PEJRTZU3.js';import'../chunk-X32SJDLT.js';import'../chunk-FULAMLUU.js';import'../chunk-EOVTMJYZ.js';import'../chunk-WGYS2L4V.js';import'../chunk-ANKA7HEJ.js';import {a,b as b$2}from'../chunk-44L64VQ2.js';import'../chunk-Q444D72R.js';import'../chunk-R7SQQSDX.js';import'../chunk-ATOQP3BD.js';import'../chunk-YT76JNKE.js';import'../chunk-MNEOJWPS.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return a$1(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return b$2(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return c$1({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return b$1(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
1
+ import {a as a$1}from'../chunk-VS3BXEYK.js';import {b as b$1}from'../chunk-Y4WK7HE4.js';import'../chunk-QLB6PKOT.js';import'../chunk-REZO2QJD.js';import {c as c$1}from'../chunk-PEJRTZU3.js';import'../chunk-BRYV6CDD.js';import'../chunk-FULAMLUU.js';import'../chunk-EOVTMJYZ.js';import'../chunk-MRESV3MD.js';import'../chunk-ANKA7HEJ.js';import {a,b as b$2}from'../chunk-44L64VQ2.js';import'../chunk-Q444D72R.js';import'../chunk-R7SQQSDX.js';import'../chunk-YOY2JM5N.js';import'../chunk-3SLSRX6Q.js';import'../chunk-MNEOJWPS.js';import'../chunk-UGB7PC4P.js';import'../chunk-FW4363Y4.js';function j(e){return String(e).replace(/[^a-zA-Z0-9_-]/g,"_")}function M(e){let r="";for(let n=0;n<e.length;n++)r+=String.fromCharCode(e[n]);return btoa(r)}function U(e){let r=atob(e),n=new Uint8Array(r.length);for(let t=0;t<r.length;t++)n[t]=r.charCodeAt(t);return n}function I(e){let r=new TextEncoder().encode(e);return M(r).replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}function V(e){return a$1(e).slice(0,16)}function K(){return globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function"?globalThis.crypto.randomUUID():`${Date.now().toString(16)}-${Math.random().toString(16).slice(2,10)}`}function c(e){return I(String(e))}function f(){let e=String(Date.now()).padStart(13,"0"),r=Math.random().toString(36).slice(2,10).padEnd(8,"0");return `${e}-${r}`}function Q(e){try{return b$2(e)}catch{return null}}function p(e,r){let n=Q(e);return n?.kind==="firestore"&&n.value?n.value:r}function g(e){if(e===void 0)return null;if(Array.isArray(e))return e.map(r=>g(r===void 0?null:r));if(e&&typeof e=="object"){let r=Object.entries(e).filter(([,n])=>n!==void 0).map(([n,t])=>[n,g(t)]);return Object.fromEntries(r)}return e}function _(e,r){return e.collection("boards").doc(r)}function y(e,r,n){return _(e,r).collection(n)}function b(e){return {kind:"firestore",value:String(e)}}function l(e){return a(b(e))}function N(e){return {baseRef:b(`boards/${e}`),boardRuntimeStoreRef:l(`boards/${e}/runtime-board`),cardStoreRef:l(`boards/${e}/cards`),outputsStoreRef:l(`boards/${e}/runtime-out`),queueStoreRef:l(`boards/${e}/runtime`),scratchStoreRef:l(`boards/${e}/scratch`),chatStoreRef:l(`boards/${e}/chat`),artifactsStoreRef:l(`boards/${e}/files`),fetchedSourcesStoreRef:l(`boards/${e}/sources`)}}function A(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.value??null:null},async write(r,n){await e.doc(c(r)).set(g({k:r,value:n}));},async delete(r){await e.doc(c(r)).delete();},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)}}}function m(e){return {async append(r){let n=f();return await e.doc(n).set(g({id:n,createdAt:new Date().toISOString(),payload:r})),{id:n,payload:r}},async readAll(){return (await e.orderBy("id").get()).docs.map(n=>{let t=n.data()??{};return {id:String(t.id??n.id),payload:t.payload}})},async readAfter(r){let s=(await(r?e.where("id",">",r).orderBy("id"):e.orderBy("id")).get()).docs.map(a=>{let i=a.data()??{};return {id:String(i.id??a.id),payload:i.payload}});return {entries:s,newCursor:s.length>0?s[s.length-1].id:r}},async clear(){let r=await e.get();if(typeof e.firestore.batch=="function"){let n=e.firestore.batch();for(let t of r.docs)n.delete(e.doc(t.id));await n.commit();return}await Promise.all(r.docs.map(n=>e.doc(n.id).delete()));}}}function w(e){return {async read(r){let n=await e.doc(c(r)).get();return n.exists?n.data()?.content??null:null},async write(r,n){await e.doc(c(r)).set({k:r,content:n});},async exists(r){return (await e.doc(c(r)).get()).exists},async remove(r){await e.doc(c(r)).delete();},async readBytes(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{};return typeof t.bytesBase64=="string"?U(t.bytesBase64):typeof t.content=="string"?new TextEncoder().encode(t.content):null},async writeBytes(r,n){await e.doc(c(r)).set({k:r,bytesBase64:M(n)});},async listKeys(r=""){return (await(r?e.where("k",">=",r).where("k","<",`${r}\uF8FF`).orderBy("k"):e.orderBy("k")).get()).docs.map(s=>s.data()?.k??s.id)},async stat(r){let n=await e.doc(c(r)).get();if(!n.exists)return null;let t=n.data()??{},s=typeof t.bytesBase64=="string"?Math.floor(t.bytesBase64.length*3/4):typeof t.content=="string"?t.content.length:0;return {key:r,size:s,contentType:String(t.contentType??"application/octet-stream")}},async renameKey(r,n){let t=await e.doc(c(r)).get();if(!t.exists)return false;let s=t.data()??{};return await e.doc(c(n)).set({...s,k:n}),await e.doc(c(r)).delete(),true}}}function O(e){let r=w(e);return {...r,async getUniqueKey(n="scratch-",t=""){return `${n}${f()}${t}`},async create(n,t="scratch-",s=""){let a=`${t}${f()}${s}`;return await r.write(a,n),a},keyRef(n){return b(`${e.path}/${c(n)}`)},config:{async get(n){let t=await r.read(`__config__/${n}`);if(t==null)return null;try{return JSON.parse(t)}catch{return t}},async set(n,t){await r.write(`__config__/${n}`,JSON.stringify(t));}}}}function P(e,r){let n=_(e,r);return {stream(t){return m(n.collection(`archive-stream-${t}`))},blob(t){return w(n.collection(`archive-blob-${t}`))},async listStreams(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-stream-${t}`)).map(a=>a.slice(15))},async listBlobs(t=""){return typeof n.listCollections!="function"?[]:(await n.listCollections()).map(a=>a.path.split("/").at(-1)??"").filter(a=>a.startsWith(`archive-blob-${t}`)).map(a=>a.slice(13))},config:{async get(t){let s=await n.collection("archive-config").doc("main").get();return s.exists?s.data()?.[t]??null:null},async set(t,s){await n.collection("archive-config").doc("main").set(g({[t]:s}),{merge:true});}}}}function J(e,r={}){let n=r.holderId??K(),t=r.ttlMs??3e4;return {async tryAcquire(){try{await e.firestore.runTransaction(async s=>{let a=await s.get(e),i=new Date().toISOString();if(a.exists){let o=a.data()??{};if(o.held===!0&&typeof o.expiresAt=="string"&&o.expiresAt>i)throw Object.assign(new Error("locked"),{code:"locked"})}s.set(e,{held:!0,holderId:n,acquiredAt:i,expiresAt:new Date(Date.now()+t).toISOString()});});}catch(s){if(s?.code==="locked")return null;throw s}return async()=>{try{await e.firestore.runTransaction(async s=>{let a=await s.get(e);if(!a.exists)return;(a.data()??{}).holderId===n&&s.update(e,{held:!1,holderId:null});});}catch{}}}}}function W(e,r={}){let n=r.defaultVisibilityMs??3e4;return {async enqueue(t){let s=f(),a=new Date().toISOString();return await e.doc(s).set(g({id:s,body:t,enqueuedAt:a,attempt:0,staged:false,visibleAfter:a,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:s,body:t,enqueuedAt:a,attempt:0}},async enqueueMany(t){let s=[];for(let a of t)s.push(await this.enqueue(a));return s},async enqueueIfAbsent(t,s){if((await e.where("dedupKey","==",s).where("dead","==",false).limit(1).get()).docs.length>0)return null;let i=f(),o=new Date().toISOString();return await e.doc(i).set(g({id:i,body:t,dedupKey:s,enqueuedAt:o,attempt:0,staged:false,visibleAfter:o,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:i,body:t,enqueuedAt:o,attempt:0}},async stage(t,s={}){if(s.dedupKey&&(await e.where("dedupKey","==",s.dedupKey).where("dead","==",false).limit(1).get()).docs.length>0)return null;let a=f(),i=new Date().toISOString();return await e.doc(a).set(g({id:a,body:t,dedupKey:s.dedupKey,enqueuedAt:i,attempt:0,staged:true,visibleAfter:null,leaseToken:null,leaseExpiresAt:null,dead:false,deadReason:null})),{id:a,body:t,enqueuedAt:i,attempt:0}},async commitStaged(t){try{return await e.firestore.runTransaction(async s=>{let a=e.doc(t),i=await s.get(a);if(!i.exists)throw new Error("missing");let o=i.data()??{};if(o.dead===!0||o.staged!==!0)throw new Error("not-staged");s.update(a,{staged:!1,enqueuedAt:new Date().toISOString(),attempt:0,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async discardStaged(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)throw new Error("missing");let d=o.data()??{};if(d.dead===!0||d.staged!==!0)throw new Error("not-staged");a.update(i,{staged:!1,dead:!0,deadReason:s??"discarded"});}),!0}catch{return false}},async peekStaged(t=""){return (await e.where("dead","==",false).where("staged","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async lease(t={}){let s=Math.max(1,Number(t.max??1)),a=Math.max(1,Number(t.visibilityMs??n)),i=new Date().toISOString(),o=Math.max(s*32,128),d=await e.where("dead","==",false).where("staged","==",false).where("visibleAfter","<=",i).orderBy("visibleAfter").limit(o).get(),h=[];for(let F of d.docs){if(h.length>=s)break;let R=e.doc(F.id);try{let S=null;await e.firestore.runTransaction(async x=>{let T=await x.get(R);if(!T.exists)throw new Error("gone");let u=T.data()??{},k=new Date().toISOString();if(u.dead===!0)throw new Error("dead");if(u.staged===!0)throw new Error("staged");if(typeof u.visibleAfter=="string"&&u.visibleAfter>k)throw new Error("hidden");if(u.leaseToken&&typeof u.leaseExpiresAt=="string"&&u.leaseExpiresAt>k)throw new Error("leased");let L=K(),$=new Date(Date.now()+a).toISOString(),v=Number(u.attempt??0)+1;x.update(R,{leaseToken:L,leaseExpiresAt:$,attempt:v}),S={id:String(u.id??F.id),body:u.body,enqueuedAt:String(u.enqueuedAt??k),attempt:v,leaseToken:L,leaseExpiresAt:$};}),S&&h.push(S);}catch{}}return h},async ack(t,s){try{return await e.firestore.runTransaction(async a=>{let i=e.doc(t),o=await a.get(i);if(!o.exists)return;if((o.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.delete(i);}),!0}catch{return false}},async nack(t,s,a={}){try{return await e.firestore.runTransaction(async i=>{let o=e.doc(t),d=await i.get(o);if(!d.exists)return;if((d.data()??{}).leaseToken!==s)throw new Error("token mismatch");a.dead===!0?i.update(o,{dead:!0,deadReason:a.reason??"nacked",leaseToken:null,leaseExpiresAt:null}):i.update(o,{leaseToken:null,leaseExpiresAt:null,visibleAfter:new Date().toISOString()});}),!0}catch{return false}},async peekActive(t=""){return (await e.where("dead","==",false).where("staged","==",false).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0)}))},async peekDeadLetter(t=""){return (await e.where("dead","==",true).orderBy("enqueuedAt").get()).docs.map(a=>a.data()??{}).filter(a=>!t||String(a.id??"").startsWith(t)).map(a=>({id:String(a.id??""),body:a.body,enqueuedAt:String(a.enqueuedAt??""),attempt:Number(a.attempt??0),reason:a.deadReason}))}}}function z(e,r,n={}){return c$1({boardId:r,kvStorage(t){return A(y(e,r,`kv-${t||"root"}`))},kvStorageForRef(t){return A(e.collection(p(t,`boards/${r}/kv-root`)))},blobStorage(t){return w(y(e,r,`blobs-${t||"root"}`))},blobStorageForRef(t){return w(e.collection(p(t,`boards/${r}/blobs-root`)))},chatStorageForRef(t){let s=p(t,`boards/${r}/chat`);return b$1(a=>m(e.collection(`${s}-journal-${j(a)}`)),A(e.collection(`${s}-kv`)))},queueStoreRef:N(r).queueStoreRef,queueStorageForRef(t,s){let a=p(t,`boards/${r}/runtime`);return W(e.collection(`${a}-${s}`))},scratchStorage(){return O(y(e,r,"scratch"))},scratchStorageForRef(t){return O(e.collection(p(t,`boards/${r}/scratch`)))},archiveFactory(){return P(e,r)},archiveFactoryForRef(t){let s=Q(t),a=s?.kind==="firestore-board"?s.value:r;return P(e,a)},journalStorage(){return m(y(e,r,"journal"))},journalStorageForRef(t){let s=p(t,`boards/${r}/runtime-board`);return m(e.collection(`${s}-journal`))},lock:J(y(e,r,"locks").doc("board-lock"),{holderId:n.holderId}),hashFn(t){return V(t)},genId(){return f()},supportsDirectSourceOutput(t){return t.howToRun==="queue-storage"||t.howToRun==="http:post"},requestProcessAccumulated:n.requestProcessAccumulated,publishBoardChangeNotifications:n.publishBoardChangeNotifications,onWarn:t=>console.warn(`[firestore-board-adapter:${r}] ${t}`)})}function Y(e,r,n={}){let t={...N(r),...n.refs??{}},s=z(e,r,n);return {refs:t,boardAdapter:s}}
2
2
  export{P as createFirestoreArchiveFactory,w as createFirestoreBlobStorage,z as createFirestoreBoardAdapter,N as createFirestoreBoardRefs,Y as createFirestoreBoardRuntimeBundle,m as createFirestoreJournalStorage,A as createFirestoreKvStorage,J as createFirestoreLock,W as createFirestoreQueueStorage,O as createFirestoreScratchStorage,b as makeFirestoreRef,l as serializeFirestoreRef};//# sourceMappingURL=index.js.map
3
3
  //# sourceMappingURL=index.js.map