yaml-flow 8.9.1 → 8.9.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/browser/asset-integrity.json +5 -5
- package/browser/live-cards.schema.json +1 -6
- package/browser/server-runtime-controlface.js +4 -4
- package/lib/board-live-cards-mcp.cjs +1 -1
- package/lib/board-live-cards-mcp.js +1 -1
- package/lib/board-live-cards-node.cjs +2 -2
- package/lib/board-live-cards-node.js +1 -1
- package/lib/board-live-cards-public.cjs +1 -1
- package/lib/board-live-cards-public.js +1 -1
- package/lib/board-live-cards-server-runtime.cjs +1 -1
- package/lib/board-live-cards-server-runtime.js +1 -1
- package/lib/board-livegraph-runtime/index.cjs +1 -1
- package/lib/board-livegraph-runtime/index.js +1 -1
- package/lib/card-compute/index.cjs +1 -1
- package/lib/card-compute/index.d.cts +0 -1
- package/lib/card-compute/index.d.ts +0 -1
- package/lib/card-compute/index.js +1 -1
- package/lib/card-validation.cjs +1 -1
- package/lib/card-validation.js +1 -1
- package/lib/{chunk-32GZ4ODA.js → chunk-4VZL3GWU.js} +3 -3
- package/lib/{chunk-4HIEOBJC.js → chunk-7E5NKZIO.js} +2 -2
- package/lib/{chunk-XQAHHUZO.cjs → chunk-7W4QQX7S.cjs} +2 -2
- package/lib/chunk-BVQISI6G.js +3 -0
- package/lib/chunk-CBRVINMT.js +2 -0
- package/lib/chunk-E46UCDYN.js +2 -0
- package/lib/{chunk-OPNGCSXJ.js → chunk-GLKWEPX6.js} +2 -2
- package/lib/{chunk-JAL25FGA.cjs → chunk-GTHQJXYW.cjs} +2 -2
- package/lib/{chunk-ORBKEBNX.cjs → chunk-IRGTOCEU.cjs} +2 -2
- package/lib/chunk-JHXRGPL7.cjs +3 -0
- package/lib/{chunk-HDGEWOC2.cjs → chunk-KSKPS6OO.cjs} +2 -2
- package/lib/chunk-M53MX233.js +3 -0
- package/lib/chunk-N5RUH4NG.cjs +3 -0
- package/lib/chunk-NLC4FN7V.cjs +2 -0
- package/lib/{chunk-7KSENEPK.js → chunk-OEL5P7XE.js} +2 -2
- package/lib/{chunk-XLHMUPBW.js → chunk-RWAEV253.js} +2 -2
- package/lib/chunk-UG55PF75.cjs +2 -0
- package/lib/{chunk-INRLKWC2.cjs → chunk-WYKCHXBZ.cjs} +3 -3
- package/lib/chunk-YXKWIPQM.cjs +3 -0
- package/lib/chunk-ZA4FS27N.js +3 -0
- package/lib/cloud-storage.cjs +1 -1
- package/lib/cloud-storage.js +1 -1
- package/lib/continuous-event-graph/index.cjs +1 -1
- package/lib/continuous-event-graph/index.js +1 -1
- package/lib/firestore-storage/index.cjs +1 -1
- package/lib/firestore-storage/index.js +1 -1
- package/lib/index.cjs +2 -2
- package/lib/index.js +1 -1
- package/lib/localstorage-storage/index.cjs +1 -1
- package/lib/localstorage-storage/index.js +1 -1
- package/lib/server-runtime/index.cjs +1 -1
- package/lib/server-runtime/index.js +1 -1
- package/lib/server-runtime-controlface/index.cjs +1 -1
- package/lib/server-runtime-controlface/index.js +1 -1
- package/lib/server-runtime-core/index.cjs +1 -1
- package/lib/server-runtime-core/index.js +1 -1
- package/package.json +1 -1
- package/schema/live-cards.schema.json +1 -6
- package/lib/chunk-3KC6LBOG.js +0 -3
- package/lib/chunk-FO4KNVU7.cjs +0 -2
- package/lib/chunk-HWYMZK3N.cjs +0 -3
- package/lib/chunk-IXZG74EW.cjs +0 -2
- package/lib/chunk-JMDHDY6M.js +0 -2
- package/lib/chunk-RP2I3OLA.cjs +0 -3
- package/lib/chunk-TMS7KDKH.js +0 -3
- package/lib/chunk-UIUCNV3X.cjs +0 -3
- package/lib/chunk-VS4E7QFN.js +0 -3
- package/lib/chunk-YBYXCFAI.js +0 -2
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkORBKEBNX_cjs=require('./chunk-ORBKEBNX.cjs');function v(a){if(!a||typeof a!="object")return false;let e=a;return typeof e.kind=="string"&&e.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let e=a;return e.kind==="notification-batch"?Array.isArray(e.notifications)?e.notifications.filter(v):[]:v(a)?[a]:[]}function X(a,e,i){let u=0;return {accepted:a.filter(R=>{if(!v(R))return u++,false;let _=R;return typeof _.sentAtMs=="number"&&e-_.sentAtMs>i?(u++,false):true}),rejected:u}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let e=a.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let e=a;return e.kind==="notification-batch"&&Array.isArray(e.notifications)}function V(a,e){if(e.kind==="status"){z(e.status)&&(a.status=e.status);return}if(e.kind==="computed_values"){a.computedValues[e.cardId]=e.values;return}if(e.kind==="data_object"){a.dataObjects[e.key]=e.payload;return}if(e.kind==="card_refreshed"){a.cards[e.cardId]=e.card;return}e.kind==="card_removed"&&(delete a.cards[e.cardId],delete a.computedValues[e.cardId]);}function Y(a,e){if(W(e)){for(let i of e.notifications)v(i)&&V(a,i);return}v(e)&&V(a,e);}function j(a,e){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||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function N(a,e){return j(await a,e)}function q(a){let e=chunkLPXVVMQT_cjs.a(a,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=e.split(".");if(!(i.length>=2&&i.every(f=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(f))))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 e}function E(a,e){let i=a.__private;for(let u of e.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,u))return {exists:false,value:null};i=i[u];}return {exists:true,value:i}}function oe(a){let{boardId:e,bootstrapBoard:i,sseHub:u,onChannelSubscribed:f,onChannelUnsubscribed:R,getMcpFacade:_,getMcpCardStoreFacade:r}=a;function g(s){let d=chunkLPXVVMQT_cjs.a(s,"board_id");if(!d)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(d!==e)throw Object.assign(new Error(`Unknown board_id: ${d}`),{statusCode:400})}function b(s){let d=chunkLPXVVMQT_cjs.a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function y(s){g(s);let d=b(s),n=chunkLPXVVMQT_cjs.a(s,"channel_name"),t=chunkLPXVVMQT_cjs.a(s,"card_id")||void 0;if(!n)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:n,...t?{cardId:t}:{}}}function c(s){g(s);let d=chunkLPXVVMQT_cjs.a(s,"card_id");if(!d)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:d}}async function C(s){await i();let{cardId:d}=c(s),n=b(s);if(!await u.subscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:true}}}async function m(s){await i();let{cardId:d}=c(s),n=b(s);if(!u.unsubscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:false}}}async function w(s,d){await i();let{clientId:n,channelName:t,cardId:o}=y(s);if(!u.has(n))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return d?(u.subscribeChannel(n,t,o),f?.(n,t,o?{cardId:o}:{})):(u.unsubscribeChannel(n,t,o),R?.(n,t,o?{cardId:o}:{})),{status:"success",data:{boardId:e,clientId:n,channelName:t,subscribed:d,...o?{cardId:o}:{}}}}async function S(s,d){let{cardId:n}=c(s);return await _().setChatProcessing({cardId:n,active:d}),{status:"success",data:{boardId:e,cardId:n,active:d}}}async function l(s){let{cardId:d}=c(s),n=await _().getChatProcessing({cardId:d});return {status:"success",data:{boardId:e,cardId:d,active:n.active}}}async function h(s){let{cardId:d}=c(s),n=q(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(n.split(".").includes("visible_controlplane_only")){let t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null,k=o?E(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:e,cardId:d,key:n}}}return j(await r().patch({params:{id:d,path:`__private.${n}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:e,cardId:d,key:n}}}async function I(s){let{cardId:d}=c(s),n=q(s),t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&t.cards[0]&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=E(o,n);return {status:"success",data:{boardId:e,cardId:d,key:n,exists:k.exists,value:k.value}}}return {requireCardArgs:c,subscribeChat:C,unsubscribeChat:m,watchChannel:w,setChatProcessing:S,getChatProcessing:l,setCardMeta:h,getCardMeta:I}}function ie(a){let{boardId:e,boardContexts:i,readChatRecords:u,getChatProcessing:f}=a;function R(c){if(c.length===0)return null;if(c.length===1)return c[0];let C=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],w={};for(let l of m)w[l]=0;for(let l of c){let h=l,I=Array.isArray(h.cards)?h.cards:[];C.push(...I);for(let s of m)w[s]+=Number(h?.summary?.[s]||0);}let S=c[0];return {...S,cards:C,summary:{...S.summary||{},card_count:C.length,...w}}}async function _(){let c=[];for(let C of i)try{let m=await C.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&c.push(m.data);}catch{}return c}async function r(){let C=(await _()).map(m=>m.statusSnapshot).filter(Boolean);if(C.length===0){let m=i.map(w=>w.notification.status).filter(Boolean);return R(m)}return R(C)}async function g(){let c={},C=await _();for(let m of C)Object.assign(c,m.cardRuntimeById||{});if(Object.keys(c).length>0)return c;for(let m of i)for(let[w,S]of Object.entries(m.notification.computedValues)){let l=m.notification.cards[w];c[w]={schema_version:"v1",card_id:w,card_data:l?.card_data??{},computed_values:S??{}};}return c}async function b(){let c={},C=await _();for(let m of C)Object.assign(c,m.dataObjectsByToken||{});if(Object.keys(c).length===0)for(let m of i)Object.assign(c,m.notification.dataObjects||{});return c}async function y(){let c=await _(),C=c.flatMap(l=>Array.isArray(l.cardDefinitions)?l.cardDefinitions:[]),m={},w={};for(let l of c)Object.assign(m,l.dataObjectsByToken||{}),Object.assign(w,l.cardRuntimeById||{});let S={};for(let l of C){if(!l?.id)continue;let h=l.id;try{let I=await u(h),s=await f(h);(I.length>0||s)&&(S[h]={messages:I.map(d=>({role:String(d.role||"system"),text:String(d.text||""),files:Array.isArray(d.files)?d.files:[]})),receiving:!1,processing:s});}catch{}}return {boardId:e,cardDefinitions:C,statusSnapshot:await r(),dataObjectsByToken:m,cardRuntimeById:w,cardChatsByCardId:S}}return {readStatusSnapshot:r,readCardRuntimeArtifacts:g,readDataObjectsByToken:b,buildPublishedRuntimePayload:y}}function K(a){let e=String(a||"").trim();if(!e)return "upload.bin";let i=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (i>=0?e.slice(i+1):e)||"upload.bin"}function ce(a){let{safeCardId:e,artifactsStores:i,cardFileMetadataStore:u,readCardFromStore:f,updateCardLocalOnly:R,writeChatRecord:_}=a;async function r(y){let c=[];try{let C=await f(y);if(!C)return c;let m=u().read(C.card_data&&typeof C.card_data=="object"?C.card_data:null);for(let w of m)c.push(String(w.stored_name??""));}catch{}return c}async function g(y,c,C,m){let w=e(y),S=i(y),l=K(c),h=await r(y),s=`${String(h.length+1).padStart(3,"0")}-${l}`.slice(-36);if(!S.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${y}`),{statusCode:500});return await S.files.putBytes(`${w}/${s}`,new Uint8Array(m),C||"application/octet-stream"),{name:l,stored_name:s,size:m.length,mime_type:C||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function b(y,c,C,m,w){if(!m.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let S=w?.inChat===true,l=await g(y,c,C,m),h=null;if(await R(y,I=>{let s=new Date().toISOString(),d=I.card_data&&typeof I.card_data=="object"?I.card_data:{};I.card_data=d;let n=u().normalizeIncoming([{name:l.name,stored_name:l.stored_name,size:l.size,mime_type:l.mime_type,uploaded_at:l.uploaded_at||s,chat:S}],s);return h=u().merge(d,n).findIndex(o=>o.stored_name===l.stored_name),I}),S&&w?.suppressChatRecordWrite!==true){let I=typeof h=="number"&&h>=0?` #${h}`:"";await _(y,"system",`file uploaded: ${l.name} as ${l.stored_name}${I}`,[],w?.turnId??"");}return {ok:true,file:{...l,...typeof h=="number"&&h>=0?{file_idx:h}:{},chat:S},...typeof h=="number"&&h>=0?{file_idx:h}:{}}}return {uploadCardFile:b,readCardStoredFileNames:r}}function pe(a){return {"discover.source-kinds":()=>a.discoverSourceKinds(),"inspect.board-runtime-status":()=>a.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>a.inspectCardDefinitionAndRuntime({cardId:chunkLPXVVMQT_cjs.a(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let i=chunkLPXVVMQT_cjs.b(e,"tail_turns"),u=chunkLPXVVMQT_cjs.b(e,"tail"),f=chunkLPXVVMQT_cjs.a(e,"turn_id"),R=e.all_turns===true,_=chunkLPXVVMQT_cjs.a(e,"tail_turns_before_id");return a.inspectChatMessagesOnCards({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...u!==void 0?{tail:u}:{},...f?{turnId:f}:{},...R?{allTurns:true}:{},..._?{tailTurnsBeforeId:_}:{}})},"inspect.file-contents":e=>a.inspectFileContents({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),fileIdx:Number(chunkLPXVVMQT_cjs.b(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>a.preflightValidateCandidateCardDefinition({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>a.preflightMaterializeCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockRequires:chunkLPXVVMQT_cjs.d(e,"mock_requires","mock_requires"),mockFetchedSources:chunkLPXVVMQT_cjs.d(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e=>a.preflightProbeSingleSourceInCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockProjections:chunkLPXVVMQT_cjs.c(e,"mock_projections"),sourceIdx:chunkLPXVVMQT_cjs.e(e,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e=>a.preflightRunSingleSourceInCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockProjections:chunkLPXVVMQT_cjs.c(e,"mock_projections"),sourceIdx:chunkLPXVVMQT_cjs.e(e,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e=>a.preflightRunSingleSourceInLiveCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),sourceIdx:chunkLPXVVMQT_cjs.e(e,"source_idx","source_idx"),mockRequires:chunkLPXVVMQT_cjs.d(e,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>a.preflightRunOneCycleWithCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockRequires:chunkLPXVVMQT_cjs.c(e,"mock_requires")}),"manage.read-card":e=>a.manageReadCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let i=chunkLPXVVMQT_cjs.a(e,"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.manageAddChatEntryAndAnyAttachments({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...i?{turn:i}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"stage-ai-failure-message":e=>{let i=chunkLPXVVMQT_cjs.a(e,"turn_id"),u=chunkLPXVVMQT_cjs.a(e,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!u)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a.manageAddChatEntryAndAnyAttachments({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),role:"system",text:u,turn:i})},"manage.upsert-card":e=>a.manageUpsertCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),candidateCardContent:chunkLPXVVMQT_cjs.c(e,"candidate_card_content")}),"manage.remove-card":e=>a.manageRemoveCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id")})}}function me(a){return {"webhook.process-accumulated":()=>a.webhookProcessAccumulated(),"webhook.source-fetch-done":e=>a.webhookSourceFetchDone({token:chunkLPXVVMQT_cjs.a(e,"token"),ref:chunkLPXVVMQT_cjs.a(e,"ref")}),"webhook.source-fetch-failed":e=>a.webhookSourceFetchFailed({token:chunkLPXVVMQT_cjs.a(e,"token"),reason:chunkLPXVVMQT_cjs.a(e,"reason")})}}function fe(a){let{boardId:e,uploadCardFile:i,getMcpFacade:u,controlplane:f}=a;function R(r,g){let b=chunkLPXVVMQT_cjs.a(r,"board_id");if(!b)throw Object.assign(new Error(`${g} requires board_id`),{statusCode:400});if(b!==e)throw Object.assign(new Error(`Unknown board_id: ${b}`),{statusCode:400})}function _(r,g){let{cardId:b}=f.requireCardArgs(r),y=chunkLPXVVMQT_cjs.a(r,"turn_id");return R(r,g),u().manageAddChatAttachment({cardId:b,role:chunkLPXVVMQT_cjs.a(r,"role")||"user",...y?{turn:y}:{},files:[{file_name:chunkLPXVVMQT_cjs.a(r,"file_name"),content_type:chunkLPXVVMQT_cjs.a(r,"content_type")||"application/octet-stream",...typeof r.text=="string"?{text:r.text}:{},...typeof r.base64=="string"?{base64:r.base64}:{},...Array.isArray(r.bytes)?{bytes:r.bytes}:{}}]})}return {"list-runtime-cards":r=>(R(r,"list-runtime-cards"),u().listRuntimeCards()),"sse.subscribe-chat":r=>f.subscribeChat(r),"sse.unsubscribe-chat":r=>f.unsubscribeChat(r),"sse.watch-channel":r=>f.watchChannel(r,true),"sse.unwatch-channel":r=>f.watchChannel(r,false),"getstate.is-chat-processing":r=>f.getChatProcessing(r),"setstate.chat-processing-started":r=>f.setChatProcessing(r,true),"setstate.chat-processing-done":r=>f.setChatProcessing(r,false),"getstate.card-private":r=>f.getCardMeta(r),"setstate.card-private":r=>f.setCardMeta(r),"manage.upload-card-file":r=>{let g=chunkLPXVVMQT_cjs.a(r,"card_id"),b=chunkLPXVVMQT_cjs.a(r,"file_name"),y=chunkLPXVVMQT_cjs.a(r,"content_type")||"application/octet-stream",c=chunkLPXVVMQT_cjs.f(r);if(R(r,"manage.upload-card-file"),!g)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!c)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(g,b,y,c,{inChat:false})},"manage.add-chat-attachment":r=>_(r,"manage.add-chat-attachment"),"manage.add-chat-attachement":r=>_(r,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":r=>{let{cardId:g}=f.requireCardArgs(r),b=chunkLPXVVMQT_cjs.a(r,"role")||"user",y=chunkLPXVVMQT_cjs.a(r,"turn_id");return R(r,"manage.add-chat-entry-and-any-attachments"),u().manageAddChatEntryAndAnyAttachments({cardId:g,role:b,...typeof r.text=="string"?{text:r.text}:{},...y?{turn:y}:{},...Array.isArray(r.files)?{files:r.files}:{}})},"manage.patch-card":r=>{let{cardId:g}=f.requireCardArgs(r);return R(r,"manage.patch-card"),u().managePatchCard({cardId:g,patch:chunkLPXVVMQT_cjs.c(r,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":r=>{let{cardId:g}=f.requireCardArgs(r);return R(r,"manage.upsert-card"),u().manageUpsertCard({cardId:g,candidateCardContent:chunkLPXVVMQT_cjs.c(r,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":r=>{let{cardId:g}=f.requireCardArgs(r);return R(r,"manage.remove-card"),u().manageRemoveCard({cardId:g},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async r=>{let{cardId:g}=f.requireCardArgs(r);return {status:"success",data:{cards:await u().adminReadCard({cardId:g})}}},"manage.admin-upsert-card":r=>{let g=chunkLPXVVMQT_cjs.a(r,"board_id"),b=chunkLPXVVMQT_cjs.a(r,"card_id");if(!g)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(g!==e)throw Object.assign(new Error(`Unknown board_id: ${g}`),{statusCode:400});return u().adminUpsertCard({cardId:b,candidateCardContent:chunkLPXVVMQT_cjs.c(r,"candidate_card_content")})}}}function ye(a){let{boardContexts:e,cardOwnerIndex:i,cardContextForCard:u,readStatusSnapshot:f,readDataObjectsByToken:R,readCardRuntimeArtifacts:_,readCardFromStore:r,readCardDefinitions:g,processAccumulatedLaneInternal:b,reportSourceFetched:y,reportSourceFetchFailure:c,uploadCardFile:C,chatStorePublic:m,serverUrl:w,apiBasePath:S}=a;function l(){return e[0]??null}function h(){return {async status(){let n=await f();return n==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:n}},async getOutputsDataObject(n){let t=n?.params?.key;return t?{status:"success",data:(await R())[t]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(n){let t=n?.params?.key;return t?{status:"success",data:(await _())[t]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(n){let t=n?.params?.key;if(!t)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=u(t)??l();return o?o.boardOps.getOutputsFetchedSources({params:{key:t}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(n){let t=n?.params?.id;if(!t)return {status:"fail",error:"removeCard requires params.id"};let o=u(t)??l();return o?o.boardOps.removeCard({params:{id:t}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(n){let t=n?.params?.cardId;if(!t)return {status:"fail",error:"upsertCard requires params.cardId"};let o=u(t)??l();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:t,restart:n.params.restart===true}});if(k.status!=="success")return k;if(chunkBQUQTOPB_cjs.a(o.boardAdapter)){let P=await b(true);if(P.status!=="success")return P}return k}}}function I(){let n=()=>{let t=l();if(!t?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return t.nonCore};return {describeTaskExecutorCapabilities(t){return n().describeTaskExecutorCapabilities(t)},validateCardPreflight(t){return n().validateCardPreflight(t)},evalCardCompute(t){return n().evalCardCompute(t)},probeSourcePreflight(t){return n().probeSourcePreflight(t)},runSourcePreflight(t){return n().runSourcePreflight(t)},simulateCardCycle(t){return n().simulateCardCycle(t)}}}function s(){return {async get(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(t){let o=await r(t);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await g()}}},async set(n){let t=n.body;if(t==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(t)?t:[t];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 D=i.get(A)??0,L=e[D]??l();if(!L)return {status:"fail",error:"Board context is unavailable"};let T=await L.cardStoreOps.set({body:P});if(T.status!=="success")return T;i.set(A,D);}return {status:"success",data:{count:o.length}}},async del(n){let t=[n.params?.id,...n.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(t.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of t){let k=u(o)??l();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:t.length}}},async patch(n){let t=typeof n.params?.id=="string"?n.params.id:void 0,o=typeof n.params?.path=="string"?n.params.path:void 0;if(!t||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=u(t)??l();return k?k.cardStoreOps.patch(n):{status:"fail",error:"Board context is unavailable"}},async appendFiles(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(!t)return {status:"fail",error:"appendFiles requires params.id"};let o=u(t)??l();return o?o.cardStoreOps.appendFiles(n):{status:"fail",error:"Board context is unavailable"}}}}function d(){return chunkORBKEBNX_cjs.a({board:h(),nonCore:I(),cardStore:s(),chatStore:m,processAccumulated:()=>b(true),sourceFetchDone:({token:n,ref:t})=>y(n,t),sourceFetchFailed:({token:n,reason:t})=>c(n,t),uploadCardFile({cardId:n,fileName:t,contentType:o,bytes:k,suppressChatRecordWrite:P}){return C(n,t,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:n,fileIdx:t,storedName:o}){let k=`${w||""}${S}/cards/${encodeURIComponent(n)}/files/${t}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:n,ref:t}){let o=u(n)??l();if(!o||chunkBQUQTOPB_cjs.a(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(chunkVQCIOKJV_cjs.b(t)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:h,mcpNonCoreFacade:I,mcpCardStoreFacade:s,createMcpFacade:d}}exports.a=J;exports.b=X;exports.c=Q;exports.d=z;exports.e=Y;exports.f=j;exports.g=N;exports.h=q;exports.i=E;exports.j=oe;exports.k=ie;exports.l=ce;exports.m=pe;exports.n=me;exports.o=fe;exports.p=ye;//# sourceMappingURL=chunk-HDGEWOC2.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
'use strict';var chunkBQUQTOPB_cjs=require('./chunk-BQUQTOPB.cjs'),chunkLPXVVMQT_cjs=require('./chunk-LPXVVMQT.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkIRGTOCEU_cjs=require('./chunk-IRGTOCEU.cjs');function v(a){if(!a||typeof a!="object")return false;let e=a;return typeof e.kind=="string"&&e.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let e=a;return e.kind==="notification-batch"?Array.isArray(e.notifications)?e.notifications.filter(v):[]:v(a)?[a]:[]}function X(a,e,i){let u=0;return {accepted:a.filter(R=>{if(!v(R))return u++,false;let _=R;return typeof _.sentAtMs=="number"&&e-_.sentAtMs>i?(u++,false):true}),rejected:u}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let e=a.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let e=a;return e.kind==="notification-batch"&&Array.isArray(e.notifications)}function V(a,e){if(e.kind==="status"){z(e.status)&&(a.status=e.status);return}if(e.kind==="computed_values"){a.computedValues[e.cardId]=e.values;return}if(e.kind==="data_object"){a.dataObjects[e.key]=e.payload;return}if(e.kind==="card_refreshed"){a.cards[e.cardId]=e.card;return}e.kind==="card_removed"&&(delete a.cards[e.cardId],delete a.computedValues[e.cardId]);}function Y(a,e){if(W(e)){for(let i of e.notifications)v(i)&&V(a,i);return}v(e)&&V(a,e);}function j(a,e){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||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function N(a,e){return j(await a,e)}function q(a){let e=chunkLPXVVMQT_cjs.a(a,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=e.split(".");if(!(i.length>=2&&i.every(f=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(f))))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 e}function E(a,e){let i=a.__private;for(let u of e.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,u))return {exists:false,value:null};i=i[u];}return {exists:true,value:i}}function oe(a){let{boardId:e,bootstrapBoard:i,sseHub:u,onChannelSubscribed:f,onChannelUnsubscribed:R,getMcpFacade:_,getMcpCardStoreFacade:r}=a;function g(s){let d=chunkLPXVVMQT_cjs.a(s,"board_id");if(!d)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(d!==e)throw Object.assign(new Error(`Unknown board_id: ${d}`),{statusCode:400})}function b(s){let d=chunkLPXVVMQT_cjs.a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function y(s){g(s);let d=b(s),n=chunkLPXVVMQT_cjs.a(s,"channel_name"),t=chunkLPXVVMQT_cjs.a(s,"card_id")||void 0;if(!n)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:n,...t?{cardId:t}:{}}}function c(s){g(s);let d=chunkLPXVVMQT_cjs.a(s,"card_id");if(!d)throw Object.assign(new Error("MCP tool requires card_id"),{statusCode:400});return {cardId:d}}async function C(s){await i();let{cardId:d}=c(s),n=b(s);if(!await u.subscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:true}}}async function m(s){await i();let{cardId:d}=c(s),n=b(s);if(!u.unsubscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:false}}}async function w(s,d){await i();let{clientId:n,channelName:t,cardId:o}=y(s);if(!u.has(n))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return d?(u.subscribeChannel(n,t,o),f?.(n,t,o?{cardId:o}:{})):(u.unsubscribeChannel(n,t,o),R?.(n,t,o?{cardId:o}:{})),{status:"success",data:{boardId:e,clientId:n,channelName:t,subscribed:d,...o?{cardId:o}:{}}}}async function S(s,d){let{cardId:n}=c(s);return await _().setChatProcessing({cardId:n,active:d}),{status:"success",data:{boardId:e,cardId:n,active:d}}}async function l(s){let{cardId:d}=c(s),n=await _().getChatProcessing({cardId:d});return {status:"success",data:{boardId:e,cardId:d,active:n.active}}}async function h(s){let{cardId:d}=c(s),n=q(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(n.split(".").includes("visible_controlplane_only")){let t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null,k=o?E(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:e,cardId:d,key:n}}}return j(await r().patch({params:{id:d,path:`__private.${n}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:e,cardId:d,key:n}}}async function I(s){let{cardId:d}=c(s),n=q(s),t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&t.cards[0]&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=E(o,n);return {status:"success",data:{boardId:e,cardId:d,key:n,exists:k.exists,value:k.value}}}return {requireCardArgs:c,subscribeChat:C,unsubscribeChat:m,watchChannel:w,setChatProcessing:S,getChatProcessing:l,setCardMeta:h,getCardMeta:I}}function ie(a){let{boardId:e,boardContexts:i,readChatRecords:u,getChatProcessing:f}=a;function R(c){if(c.length===0)return null;if(c.length===1)return c[0];let C=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],w={};for(let l of m)w[l]=0;for(let l of c){let h=l,I=Array.isArray(h.cards)?h.cards:[];C.push(...I);for(let s of m)w[s]+=Number(h?.summary?.[s]||0);}let S=c[0];return {...S,cards:C,summary:{...S.summary||{},card_count:C.length,...w}}}async function _(){let c=[];for(let C of i)try{let m=await C.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&c.push(m.data);}catch{}return c}async function r(){let C=(await _()).map(m=>m.statusSnapshot).filter(Boolean);if(C.length===0){let m=i.map(w=>w.notification.status).filter(Boolean);return R(m)}return R(C)}async function g(){let c={},C=await _();for(let m of C)Object.assign(c,m.cardRuntimeById||{});if(Object.keys(c).length>0)return c;for(let m of i)for(let[w,S]of Object.entries(m.notification.computedValues)){let l=m.notification.cards[w];c[w]={schema_version:"v1",card_id:w,card_data:l?.card_data??{},computed_values:S??{}};}return c}async function b(){let c={},C=await _();for(let m of C)Object.assign(c,m.dataObjectsByToken||{});if(Object.keys(c).length===0)for(let m of i)Object.assign(c,m.notification.dataObjects||{});return c}async function y(){let c=await _(),C=c.flatMap(l=>Array.isArray(l.cardDefinitions)?l.cardDefinitions:[]),m={},w={};for(let l of c)Object.assign(m,l.dataObjectsByToken||{}),Object.assign(w,l.cardRuntimeById||{});let S={};for(let l of C){if(!l?.id)continue;let h=l.id;try{let I=await u(h),s=await f(h);(I.length>0||s)&&(S[h]={messages:I.map(d=>({role:String(d.role||"system"),text:String(d.text||""),files:Array.isArray(d.files)?d.files:[]})),receiving:!1,processing:s});}catch{}}return {boardId:e,cardDefinitions:C,statusSnapshot:await r(),dataObjectsByToken:m,cardRuntimeById:w,cardChatsByCardId:S}}return {readStatusSnapshot:r,readCardRuntimeArtifacts:g,readDataObjectsByToken:b,buildPublishedRuntimePayload:y}}function K(a){let e=String(a||"").trim();if(!e)return "upload.bin";let i=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (i>=0?e.slice(i+1):e)||"upload.bin"}function ce(a){let{safeCardId:e,artifactsStores:i,cardFileMetadataStore:u,readCardFromStore:f,updateCardLocalOnly:R,writeChatRecord:_}=a;async function r(y){let c=[];try{let C=await f(y);if(!C)return c;let m=u().read(C.card_data&&typeof C.card_data=="object"?C.card_data:null);for(let w of m)c.push(String(w.stored_name??""));}catch{}return c}async function g(y,c,C,m){let w=e(y),S=i(y),l=K(c),h=await r(y),s=`${String(h.length+1).padStart(3,"0")}-${l}`.slice(-36);if(!S.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${y}`),{statusCode:500});return await S.files.putBytes(`${w}/${s}`,new Uint8Array(m),C||"application/octet-stream"),{name:l,stored_name:s,size:m.length,mime_type:C||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function b(y,c,C,m,w){if(!m.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let S=w?.inChat===true,l=await g(y,c,C,m),h=null;if(await R(y,I=>{let s=new Date().toISOString(),d=I.card_data&&typeof I.card_data=="object"?I.card_data:{};I.card_data=d;let n=u().normalizeIncoming([{name:l.name,stored_name:l.stored_name,size:l.size,mime_type:l.mime_type,uploaded_at:l.uploaded_at||s,chat:S}],s);return h=u().merge(d,n).findIndex(o=>o.stored_name===l.stored_name),I}),S&&w?.suppressChatRecordWrite!==true){let I=typeof h=="number"&&h>=0?` #${h}`:"";await _(y,"system",`file uploaded: ${l.name} as ${l.stored_name}${I}`,[],w?.turnId??"");}return {ok:true,file:{...l,...typeof h=="number"&&h>=0?{file_idx:h}:{},chat:S},...typeof h=="number"&&h>=0?{file_idx:h}:{}}}return {uploadCardFile:b,readCardStoredFileNames:r}}function pe(a){return {"discover.source-kinds":()=>a.discoverSourceKinds(),"inspect.board-runtime-status":()=>a.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>a.inspectCardDefinitionAndRuntime({cardId:chunkLPXVVMQT_cjs.a(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let i=chunkLPXVVMQT_cjs.b(e,"tail_turns"),u=chunkLPXVVMQT_cjs.b(e,"tail"),f=chunkLPXVVMQT_cjs.a(e,"turn_id"),R=e.all_turns===true,_=chunkLPXVVMQT_cjs.a(e,"tail_turns_before_id");return a.inspectChatMessagesOnCards({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...u!==void 0?{tail:u}:{},...f?{turnId:f}:{},...R?{allTurns:true}:{},..._?{tailTurnsBeforeId:_}:{}})},"inspect.file-contents":e=>a.inspectFileContents({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),fileIdx:Number(chunkLPXVVMQT_cjs.b(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>a.preflightValidateCandidateCardDefinition({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>a.preflightMaterializeCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockRequires:chunkLPXVVMQT_cjs.d(e,"mock_requires","mock_requires"),mockFetchedSources:chunkLPXVVMQT_cjs.d(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e=>a.preflightProbeSingleSourceInCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockProjections:chunkLPXVVMQT_cjs.c(e,"mock_projections"),sourceIdx:chunkLPXVVMQT_cjs.e(e,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e=>a.preflightRunSingleSourceInCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockProjections:chunkLPXVVMQT_cjs.c(e,"mock_projections"),sourceIdx:chunkLPXVVMQT_cjs.e(e,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e=>a.preflightRunSingleSourceInLiveCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),sourceIdx:chunkLPXVVMQT_cjs.e(e,"source_idx","source_idx"),mockRequires:chunkLPXVVMQT_cjs.d(e,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>a.preflightRunOneCycleWithCandidateCard({candidateCardContent:chunkLPXVVMQT_cjs.d(e,"candidate_card_content","candidate_card_content"),mockRequires:chunkLPXVVMQT_cjs.c(e,"mock_requires")}),"manage.read-card":e=>a.manageReadCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let i=chunkLPXVVMQT_cjs.a(e,"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.manageAddChatEntryAndAnyAttachments({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...i?{turn:i}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"stage-ai-failure-message":e=>{let i=chunkLPXVVMQT_cjs.a(e,"turn_id"),u=chunkLPXVVMQT_cjs.a(e,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!u)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a.manageAddChatEntryAndAnyAttachments({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),role:"system",text:u,turn:i})},"manage.upsert-card":e=>a.manageUpsertCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id"),candidateCardContent:chunkLPXVVMQT_cjs.c(e,"candidate_card_content")}),"manage.remove-card":e=>a.manageRemoveCard({cardId:chunkLPXVVMQT_cjs.a(e,"card_id")})}}function me(a){return {"webhook.process-accumulated":()=>a.webhookProcessAccumulated(),"webhook.source-fetch-done":e=>a.webhookSourceFetchDone({token:chunkLPXVVMQT_cjs.a(e,"token"),ref:chunkLPXVVMQT_cjs.a(e,"ref")}),"webhook.source-fetch-failed":e=>a.webhookSourceFetchFailed({token:chunkLPXVVMQT_cjs.a(e,"token"),reason:chunkLPXVVMQT_cjs.a(e,"reason")})}}function fe(a){let{boardId:e,uploadCardFile:i,getMcpFacade:u,controlplane:f}=a;function R(r,g){let b=chunkLPXVVMQT_cjs.a(r,"board_id");if(!b)throw Object.assign(new Error(`${g} requires board_id`),{statusCode:400});if(b!==e)throw Object.assign(new Error(`Unknown board_id: ${b}`),{statusCode:400})}function _(r,g){let{cardId:b}=f.requireCardArgs(r),y=chunkLPXVVMQT_cjs.a(r,"turn_id");return R(r,g),u().manageAddChatAttachment({cardId:b,role:chunkLPXVVMQT_cjs.a(r,"role")||"user",...y?{turn:y}:{},files:[{file_name:chunkLPXVVMQT_cjs.a(r,"file_name"),content_type:chunkLPXVVMQT_cjs.a(r,"content_type")||"application/octet-stream",...typeof r.text=="string"?{text:r.text}:{},...typeof r.base64=="string"?{base64:r.base64}:{},...Array.isArray(r.bytes)?{bytes:r.bytes}:{}}]})}return {"list-runtime-cards":r=>(R(r,"list-runtime-cards"),u().listRuntimeCards()),"sse.subscribe-chat":r=>f.subscribeChat(r),"sse.unsubscribe-chat":r=>f.unsubscribeChat(r),"sse.watch-channel":r=>f.watchChannel(r,true),"sse.unwatch-channel":r=>f.watchChannel(r,false),"getstate.is-chat-processing":r=>f.getChatProcessing(r),"setstate.chat-processing-started":r=>f.setChatProcessing(r,true),"setstate.chat-processing-done":r=>f.setChatProcessing(r,false),"getstate.card-private":r=>f.getCardMeta(r),"setstate.card-private":r=>f.setCardMeta(r),"manage.upload-card-file":r=>{let g=chunkLPXVVMQT_cjs.a(r,"card_id"),b=chunkLPXVVMQT_cjs.a(r,"file_name"),y=chunkLPXVVMQT_cjs.a(r,"content_type")||"application/octet-stream",c=chunkLPXVVMQT_cjs.f(r);if(R(r,"manage.upload-card-file"),!g)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!c)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(g,b,y,c,{inChat:false})},"manage.add-chat-attachment":r=>_(r,"manage.add-chat-attachment"),"manage.add-chat-attachement":r=>_(r,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":r=>{let{cardId:g}=f.requireCardArgs(r),b=chunkLPXVVMQT_cjs.a(r,"role")||"user",y=chunkLPXVVMQT_cjs.a(r,"turn_id");return R(r,"manage.add-chat-entry-and-any-attachments"),u().manageAddChatEntryAndAnyAttachments({cardId:g,role:b,...typeof r.text=="string"?{text:r.text}:{},...y?{turn:y}:{},...Array.isArray(r.files)?{files:r.files}:{}})},"manage.patch-card":r=>{let{cardId:g}=f.requireCardArgs(r);return R(r,"manage.patch-card"),u().managePatchCard({cardId:g,patch:chunkLPXVVMQT_cjs.c(r,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":r=>{let{cardId:g}=f.requireCardArgs(r);return R(r,"manage.upsert-card"),u().manageUpsertCard({cardId:g,candidateCardContent:chunkLPXVVMQT_cjs.c(r,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":r=>{let{cardId:g}=f.requireCardArgs(r);return R(r,"manage.remove-card"),u().manageRemoveCard({cardId:g},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async r=>{let{cardId:g}=f.requireCardArgs(r);return {status:"success",data:{cards:await u().adminReadCard({cardId:g})}}},"manage.admin-upsert-card":r=>{let g=chunkLPXVVMQT_cjs.a(r,"board_id"),b=chunkLPXVVMQT_cjs.a(r,"card_id");if(!g)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(g!==e)throw Object.assign(new Error(`Unknown board_id: ${g}`),{statusCode:400});return u().adminUpsertCard({cardId:b,candidateCardContent:chunkLPXVVMQT_cjs.c(r,"candidate_card_content")})}}}function ye(a){let{boardContexts:e,cardOwnerIndex:i,cardContextForCard:u,readStatusSnapshot:f,readDataObjectsByToken:R,readCardRuntimeArtifacts:_,readCardFromStore:r,readCardDefinitions:g,processAccumulatedLaneInternal:b,reportSourceFetched:y,reportSourceFetchFailure:c,uploadCardFile:C,chatStorePublic:m,serverUrl:w,apiBasePath:S}=a;function l(){return e[0]??null}function h(){return {async status(){let n=await f();return n==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:n}},async getOutputsDataObject(n){let t=n?.params?.key;return t?{status:"success",data:(await R())[t]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(n){let t=n?.params?.key;return t?{status:"success",data:(await _())[t]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(n){let t=n?.params?.key;if(!t)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=u(t)??l();return o?o.boardOps.getOutputsFetchedSources({params:{key:t}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(n){let t=n?.params?.id;if(!t)return {status:"fail",error:"removeCard requires params.id"};let o=u(t)??l();return o?o.boardOps.removeCard({params:{id:t}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(n){let t=n?.params?.cardId;if(!t)return {status:"fail",error:"upsertCard requires params.cardId"};let o=u(t)??l();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:t,restart:n.params.restart===true}});if(k.status!=="success")return k;if(chunkBQUQTOPB_cjs.a(o.boardAdapter)){let P=await b(true);if(P.status!=="success")return P}return k}}}function I(){let n=()=>{let t=l();if(!t?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return t.nonCore};return {describeTaskExecutorCapabilities(t){return n().describeTaskExecutorCapabilities(t)},validateCardPreflight(t){return n().validateCardPreflight(t)},evalCardCompute(t){return n().evalCardCompute(t)},probeSourcePreflight(t){return n().probeSourcePreflight(t)},runSourcePreflight(t){return n().runSourcePreflight(t)},simulateCardCycle(t){return n().simulateCardCycle(t)}}}function s(){return {async get(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(t){let o=await r(t);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await g()}}},async set(n){let t=n.body;if(t==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(t)?t:[t];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 D=i.get(A)??0,L=e[D]??l();if(!L)return {status:"fail",error:"Board context is unavailable"};let T=await L.cardStoreOps.set({body:P});if(T.status!=="success")return T;i.set(A,D);}return {status:"success",data:{count:o.length}}},async del(n){let t=[n.params?.id,...n.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(t.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of t){let k=u(o)??l();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:t.length}}},async patch(n){let t=typeof n.params?.id=="string"?n.params.id:void 0,o=typeof n.params?.path=="string"?n.params.path:void 0;if(!t||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=u(t)??l();return k?k.cardStoreOps.patch(n):{status:"fail",error:"Board context is unavailable"}},async appendFiles(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(!t)return {status:"fail",error:"appendFiles requires params.id"};let o=u(t)??l();return o?o.cardStoreOps.appendFiles(n):{status:"fail",error:"Board context is unavailable"}}}}function d(){return chunkIRGTOCEU_cjs.a({board:h(),nonCore:I(),cardStore:s(),chatStore:m,processAccumulated:()=>b(true),sourceFetchDone:({token:n,ref:t})=>y(n,t),sourceFetchFailed:({token:n,reason:t})=>c(n,t),uploadCardFile({cardId:n,fileName:t,contentType:o,bytes:k,suppressChatRecordWrite:P}){return C(n,t,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:n,fileIdx:t,storedName:o}){let k=`${w||""}${S}/cards/${encodeURIComponent(n)}/files/${t}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:n,ref:t}){let o=u(n)??l();if(!o||chunkBQUQTOPB_cjs.a(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(chunkVQCIOKJV_cjs.b(t)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:h,mcpNonCoreFacade:I,mcpCardStoreFacade:s,createMcpFacade:d}}exports.a=J;exports.b=X;exports.c=Q;exports.d=z;exports.e=Y;exports.f=j;exports.g=N;exports.h=q;exports.i=E;exports.j=oe;exports.k=ie;exports.l=ce;exports.m=pe;exports.n=me;exports.o=fe;exports.p=ye;//# sourceMappingURL=chunk-KSKPS6OO.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-KSKPS6OO.cjs.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {q as q$1}from'./chunk-MNEOJWPS.js';import {b as b$1}from'./chunk-FW4363Y4.js';import A from'ajv-formats';import {createRequire}from'module';var h={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://nsreehari.github.io/boards/live-cards.schema.json",definitions:{bind_ref:{description:"A card data path reference, e.g. 'card_data.raw_quotes' or 'requires.upstream'",type:"string",pattern:"^(card_data|requires|fetched_sources|computed_values)(\\.|$)"},bind_or_literal:{description:"A literal value or a bind reference object",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref"}},required:["bind"]}]},compute_expr:{description:"A declarative JSON compute expression",type:"object",required:["fn"],properties:{fn:{type:"string",description:"Function name from the built-in vocabulary",enum:["sum","avg","min","max","count","first","last","add","sub","mul","div","round","abs","mod","gt","gte","lt","lte","eq","neq","if","and","or","not","concat","upper","lower","template","filter","pluck","map","sort","slice","flat","unique","group","get","default","now","diff_days","format_date"]},input:{description:"card_data.path, literal, array of inputs, or nested compute_expr",oneOf:[{type:"string"},{type:"number"},{type:"boolean"},{type:"array"},{$ref:"#/definitions/compute_expr"}]},field:{type:"string",description:"For pluck/sum/group \u2014 the object key to extract"},where:{$ref:"#/definitions/compute_expr",description:"For filter \u2014 predicate expression ($ = current item)"},cond:{$ref:"#/definitions/compute_expr",description:"For if \u2014 condition expression"},then:{description:"For if \u2014 value when cond is truthy"},else:{description:"For if \u2014 value when cond is falsy"},format:{type:"string",description:"For format_date \u2014 date format string"}}},meta:{type:"object",properties:{title:{type:"string"},tags:{type:"array",items:{type:"string"}}},additionalProperties:true},__private:{description:"Control-plane-owned private state. Stripped entirely from all regular /mcp read responses. Writable only via 'setstate.card-private' and 'manage.admin-upsert-card'. Agents must never author this field. Keys inside use plain names (no leading underscores).",type:"object",additionalProperties:true},requires:{type:"array",items:{type:"string"},description:"IDs of upstream nodes this node depends on"},provides:{type:"array",items:{type:"object",required:["bindTo","ref"],properties:{bindTo:{type:"string",description:"Token name published downstream"},ref:{type:"string",description:"Path to read value from (card_data.*, requires.*, fetched_sources.*, computed_values.*)"}}},description:"Explicit bindings exposing computed or card_data values downstream as named tokens"},compute_step:{description:"A single ordered compute step: reads card_data.*/requires.*/computed_values.*, writes to computed_values[bindTo]",type:"object",required:["bindTo","expr"],properties:{bindTo:{type:"string",description:"Key in computed_values to write result"},expr:{type:"string",description:"JSONata expression evaluated against { card_data, requires, fetched_sources, computed_values }"}}},source_def:{description:"One source entry. The engine requires 'bindTo' (compute namespace key) and 'outputFile' (delivery signal path). bindTo and outputFile must be unique across all source_defs in a card. Every other property is yours \u2014 add whatever your task-executor needs: kind, url, headers, mailbox, channel, model, query, etc. The full object is passed verbatim as the --in JSON to the executor.",type:"object",required:["bindTo","outputFile"],additionalProperties:true,properties:{bindTo:{type:"string",description:"Key under fetched_sources.* available in compute expressions"},outputFile:{type:"string",description:"Board-relative path the executor writes its JSON result to. Presence of this file signals delivery."},projections:{type:"object",description:"Named data projections from card_data or requires, evaluated before the executor is called. Each key is a ref name; each value is a JSONata expression rooted at card_data or requires. The resolved values are passed to the executor as _projections. fetched_sources, computed_values, and source_defs are not accessible here \u2014 sources run before those exist.",additionalProperties:{type:"string"}},timeout:{type:"integer",minimum:0,default:12e4,description:"Executor/script timeout in ms. Default: 120 000 (2 min)."},script:{type:"string",description:"Legacy direct-run: shell command executed when no .task-executor is registered. stdout is captured as the result."}}},render_element:{type:"object",required:["kind"],properties:{id:{type:"string",description:"Optional element ID for targeted updates"},kind:{enum:["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]},label:{type:"string",description:"Heading above this element"},className:{type:"string",description:"Bootstrap grid class, e.g. 'col-12 col-md-6'"},visible:{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 element shown only if truthy"},data:{type:"object",properties:{bind:{$ref:"#/definitions/bind_ref",description:"card_data/requires/fetched_sources/computed_values path to read data from"},writeTo:{$ref:"#/definitions/bind_ref",description:"card_data path for user input (form, filter, todo, notes)"},columns:{type:"array",items:{type:"string"},description:"table: visible columns"},maxRows:{type:"integer",description:"table/list: max rows to display"},sortable:{type:"boolean",default:true,description:"table: enable click-to-sort"},placeholder:{type:"string",description:"Empty-state message"},chartType:{enum:["bar","line","pie","doughnut"]},chartOptions:{type:"object",description:"Chart.js options passthrough"},fields:{type:"object",description:"JSON Schema for form/filter fields"},thresholds:{type:"object",properties:{green:{type:"string"},amber:{type:"string"}}},colorMap:{type:"object",description:"badge: value \u2192 Bootstrap color"},style:{enum:["heading","muted","default"],description:"text: display style"},upload:{type:"boolean",default:true,description:"file-upload: show drop zone (false = read-only file list)"},accept:{type:"array",items:{type:"string"},description:"file-upload: allowed extensions"},multiple:{type:"boolean",default:true,description:"file-upload: allow multiple files"},fileAttach:{type:"boolean",default:false,description:"chat: enable inline file attachments"},fileAccept:{type:"array",items:{type:"string"},description:"chat: allowed attachment extensions"},buttons:{type:"array",description:"actions: button definitions",items:{type:"object",required:["id","label"],properties:{id:{type:"string"},label:{type:"string"},style:{type:"string",description:"Bootstrap button variant, e.g. 'success', 'outline-danger'"},size:{type:"string",default:"sm"},disabled:{oneOf:[{type:"boolean"},{type:"string",description:"card_data/requires/fetched_sources/computed_values path \u2014 truthy = disabled"}]}}}}}}}},view:{type:"object",required:["elements"],properties:{elements:{type:"array",minItems:1,items:{$ref:"#/definitions/render_element"}},layout:{type:"object",properties:{board:{type:"object",properties:{col:{type:"integer",minimum:1,maximum:12},order:{type:"integer"}}},canvas:{type:"object",properties:{x:{type:"number"},y:{type:"number"},w:{type:"number"},h:{type:"number"}}}}},features:{type:"object",properties:{chat:{type:"boolean",default:false},notes:{type:"boolean",default:false},refresh:{type:"boolean",default:true}}}}}},title:"LiveCard",description:"A unified card node. Behavior depends on which sections are present (source_defs, compute, view, etc.)",type:"object",required:["id"],additionalProperties:false,properties:{id:{type:"string"},requires:{$ref:"#/definitions/requires"},provides:{$ref:"#/definitions/provides"},meta:{$ref:"#/definitions/meta"},__private:{$ref:"#/definitions/__private"},view:{$ref:"#/definitions/view"},card_data:{type:"object",description:"Authored card data and runtime metadata. Includes uploaded-file metadata maintained by host handlers and inference evaluation results.",properties:{files:{type:"array",description:"Optional uploaded-file metadata maintained by host handlers. Stored name is normalized and serial-prefixed (for example 001-my_file.pdf).",items:{type:"object",required:["name","stored_name"],properties:{name:{type:"string",minLength:1},stored_name:{type:"string",minLength:5,maxLength:32,pattern:"^[0-9]{3,}-[a-z0-9._-]+$"},size:{oneOf:[{type:"integer",minimum:0},{type:"null"}]},mime_type:{type:"string"},path:{type:"string",pattern:"^[^\\s]+/files/[0-9]{3,}-[a-z0-9._-]+$"},uploaded_at:{type:"string",format:"date-time"},chat:{type:"boolean",description:"Whether this file entry is associated with a chat interaction"}},additionalProperties:false}}},additionalProperties:true},source_defs:{type:"array",description:"Source entries. Each entry is passed verbatim to the board's .task-executor (registered via init --task-executor) as the --in JSON file. The executor fetches/generates the data and writes JSON to --out. If no executor is registered, the built-in executor runs the entry's 'cli' command directly. Sources gate completion.",items:{$ref:"#/definitions/source_def"}},compute:{type:"array",description:"Ordered array of compute steps. Each reads card_data.*/requires.*/fetched_sources.*/computed_values.* and writes to ephemeral computed_values[bindTo].",items:{$ref:"#/definitions/compute_step"}}}};var _=b$1(q$1(),1);var k=createRequire(import.meta.url),q=k("./jsonata-sync.cjs"),f=null;var b=/\b(card_data|requires|fetched_sources|computed_values|source_defs)\b/g,N=/^\s*(card_data|requires|fetched_sources|computed_values|source_defs)(\.|$)/;function E(e){let t=new Set,s;for(b.lastIndex=0;(s=b.exec(e))!==null;)t.add(s[1]);return t}function v(e){let t=N.exec(e);return t?t[1]:null}function g(e,t,s,n){try{q(e);}catch(o){let d=o instanceof Error?o.message:String(o);n.push(`${t}: invalid JSONata expression (${d})`);return}let i=E(e);for(let o of i)s.has(o)||n.push(`${t}: disallowed namespace "${o}" in expression`);}function y(e,t,s){if(Array.isArray(e)){e.forEach((i,o)=>{y(i,`${t}/${o}`,s);});return}if(typeof e=="string"){let i=v(e);if(!i)return;new Set(["card_data","requires","computed_values"]).has(i)||s.push(`${t}: disallowed namespace "${i}" in view reference`);return}if(!e||typeof e!="object")return;let n=e;for(let[i,o]of Object.entries(n))y(o,`${t}/${i}`,s);}function S(){if(f)return f;let e=new _.default({allErrors:true});return A(e),f=e.compile(h),f}function R(e){let t=S(),s=t(e),n=(t.errors??[]).map(i=>`${i.instancePath||"/"}: ${i.message??"unknown error"}`);if(e&&typeof e=="object"&&!Array.isArray(e)){let i=e.source_defs;if(Array.isArray(i)){let o=new Set,d=new Set;i.forEach((p,u)=>{if(!p||typeof p!="object"||Array.isArray(p))return;let r=p;typeof r.bindTo=="string"&&r.bindTo&&(o.has(r.bindTo)&&n.push(`/source_defs/${u}/bindTo: bindTo "${r.bindTo}" must be unique across all source_defs`),o.add(r.bindTo)),typeof r.outputFile=="string"&&r.outputFile&&(d.has(r.outputFile)&&n.push(`/source_defs/${u}/outputFile: outputFile "${r.outputFile}" must be unique across all source_defs`),d.add(r.outputFile));});}}return !s||n.length>0?{ok:false,errors:n}:{ok:true,errors:[]}}function T(e){let t=[];if(!e||typeof e!="object"||Array.isArray(e))return {ok:true,errors:[]};let s=e,n=s.compute;Array.isArray(n)&&n.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.expr;typeof a!="string"||a.trim().length===0||g(a,`/compute/${c}/expr`,new Set(["card_data","requires","fetched_sources","computed_values"]),t);});let i=new Set(["card_data","requires","fetched_sources","computed_values"]),o=s.provides;Array.isArray(o)&&o.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.ref;if(typeof a!="string"||a.trim().length===0)return;let l=v(a);l===null?t.push(`/provides/${c}/ref: path "${a}" must start with a valid namespace (${[...i].join(", ")})`):i.has(l)||t.push(`/provides/${c}/ref: disallowed namespace "${l}" in path "${a}" (valid: ${[...i].join(", ")})`);});let d=s.view;d&&typeof d=="object"&&!Array.isArray(d)&&y(d,"/view",t);let p=new Set(["card_data","requires"]),u=s.source_defs;return Array.isArray(u)&&u.forEach((r,c)=>{if(!r||typeof r!="object"||Array.isArray(r))return;let a=r.projections;if(!(!a||typeof a!="object"||Array.isArray(a)))for(let[l,m]of Object.entries(a))typeof m!="string"||m.trim().length===0||g(m,`/source_defs/${c}/projections/${l}`,p,t);}),{ok:t.length===0,errors:t}}function V(e){return O(e)}function O(e){let t=R(e);if(!t.ok)return t;let s=T(e);return s.ok?{ok:true,errors:[]}:{ok:false,errors:s.errors}}
|
|
2
|
+
export{R as a,T as b,V as c,O as d};//# sourceMappingURL=chunk-M53MX233.js.map
|
|
3
|
+
//# sourceMappingURL=chunk-M53MX233.js.map
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
'use strict';var chunkWRMOGPRG_cjs=require('./chunk-WRMOGPRG.cjs'),chunkYXKWIPQM_cjs=require('./chunk-YXKWIPQM.cjs'),chunkVQCIOKJV_cjs=require('./chunk-VQCIOKJV.cjs'),chunkG4XXRHL2_cjs=require('./chunk-G4XXRHL2.cjs'),chunkUG55PF75_cjs=require('./chunk-UG55PF75.cjs'),chunk2RIHC5TZ_cjs=require('./chunk-2RIHC5TZ.cjs');async function et(e,o,a){let r=await e.tryAcquire();if(!r)return false;try{await o();}finally{await r();}return await a?.(),true}function gt(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Ce(e,o){return gt(e)?e.then(o):o(e)}function tt(e,o){let a={...e};for(let[r,s]of Object.entries(o))s!==null&&typeof s=="object"&&!Array.isArray(s)&&a[r]!==null&&typeof a[r]=="object"&&!Array.isArray(a[r])?a[r]=tt(a[r],s):a[r]=s;return a}function ke(e,o,a){if(o.length===0)return e;let[r,...s]=o;if(s.length===0)return {...e,[r]:a};let d=e[r]!==null&&typeof e[r]=="object"&&!Array.isArray(e[r])?e[r]:{};return {...e,[r]:ke(d,s,a)}}function rt(e){return {read:a=>e.read(a),get(a,r){return Ce(e.read(a),s=>{if(s===null)return null;let d=s;for(let f of r.split(".").filter(Boolean)){if(d===null||typeof d!="object"||Array.isArray(d))return null;d=d[f]??null;}return d??null})},write:(a,r)=>e.write(a,r),delete:a=>e.delete(a),listKeys:a=>e.listKeys(a),shallowMerge(a,r){return Ce(e.read(a),s=>e.write(a,{...s??{},...r}))},deepMerge(a,r){return Ce(e.read(a),s=>e.write(a,tt(s??{},r)))},patch(a,r,s){return Ce(e.read(a),d=>{let f=r.split(".").filter(Boolean);return e.write(a,ke(d??{},f,s))})}}}function nt(e){return rt(e)}function at(e,o){return {async readIndex(){return await e.read("_index")},writeIndex(a){return e.write("_index",a)},async readCard(a){return await e.read(a)},async writeCard(a,r){return await e.write(a,r),o(r)},removeCard(a){return e.delete(a)},async cardExists(a){return await e.read(a)!==null},defaultCardKey(a){return a}}}function ot(e,o){async function a(){return await e.readIndex()??{}}return {async readCard(r){let s=(await a())[r];return !s||!await e.cardExists(s.key)?null:await e.readCard(s.key)},async readCardKey(r){return (await a())[r]?.key??null},async readAllCards(){let r=[];for(let[s,d]of Object.entries(await a())){if(!await e.cardExists(d.key))continue;let f=await e.readCard(d.key);f?r.push(f):o?.(`[card-store] could not read card "${s}" at key "${d.key}"`);}return r},async readChecksumIndex(){let r={};for(let[s,d]of Object.entries(await a()))r[s]=d.checksum;return r},async changedSince(r){let s=await a(),d=[];for(let[f,P]of Object.entries(s))r[f]!==P.checksum&&d.push(f);for(let f of Object.keys(r))s[f]||d.push(f);return d},async validateUpsert(r,s){let d=await a(),f=d[r],P=Object.entries(d).find(([,k])=>k.key===s);return f&&f.key!==s?{ok:false,error:`Card id "${r}" is already mapped to key "${f.key}", cannot remap to "${s}"`}:P&&P[0]!==r?{ok:false,error:`Key "${s}" is already mapped to card id "${P[0]}", cannot remap to "${r}"`}:{ok:true}},async writeCard(r,s,d){let f=await a(),P=d??f[r]?.key??e.defaultCardKey(r),k=await e.writeCard(P,s);f[r]={key:P,checksum:k,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async patchCard(r,s,d){let f=await a(),P=f[r];if(!P||!await e.cardExists(P.key))throw new Error(`card "${r}" not found`);let k=await e.readCard(P.key);if(!k||typeof k!="object"||Array.isArray(k))throw new Error(`card "${r}" is not patchable`);let m=String(s||"").split(".").filter(Boolean),l=ke(k,m,d),R=await e.writeCard(P.key,l);f[r]={key:P.key,checksum:R,updatedAt:new Date().toISOString()},await e.writeIndex(f);},async removeCard(r){let s=await a(),d=s[r];d&&(await e.removeCard(d.key),delete s[r],await e.writeIndex(s));},readIndex(){return a()}}}function At(e,o){return chunkYXKWIPQM_cjs.a(e,o)}function It(e,o,a){return {blob:e,kv:o,journal:a}}function st(e,o={}){function a(m){return {status:"success",data:m}}function r(m){return {status:"fail",error:m}}function s(m){return {status:"error",error:m instanceof Error?m.message:String(m)}}async function d(m){let l=o.emitNotification;if(!l||m.length===0)return;let R=chunk2RIHC5TZ_cjs.e(m);if(R.length===1){await l(R[0]);return}await l(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:R}));}async function f(m){let l=m.params?.id;if(l){let R=await e.readCard(l);if(!R)throw new Error(`card "${l}" not found`);return [R]}return await e.readAllCards()}function P(m){return chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:chunk2RIHC5TZ_cjs.e(m.map(l=>({kind:"card_refreshed",cardId:l.id,card:l})))})}function k(m){if(Array.isArray(m))return m;if(m&&typeof m=="object"){let l=m;return Array.isArray(l.files)?l.files:[m]}return null}return {async get(m){try{return a({cards:await f(m)})}catch(l){return s(l)}},async buildNotificationBatch(m){try{return a(P(await f(m)))}catch(l){return s(l)}},async set(m){try{let l=m.body;if(l==null)return r("set requires a body (card object or array of cards)");let R=Array.isArray(l)?l:[l];for(let w of R){if(typeof w.id!="string")return r("each card must have a string `id` field");await e.writeCard(w.id,w);}return await d(R.map(w=>({kind:"card_refreshed",cardId:w.id,card:w}))),a({count:R.length})}catch(l){return s(l)}},async del(m){try{let l=m.body?.ids??[],R=m.params?.id,w=R?[...l,R]:l;if(w.length===0)return r("del requires body.ids (string[]) or params.id");for(let B of w)await e.removeCard(B);return await d(w.map(B=>({kind:"card_removed",cardId:B}))),a({count:w.length})}catch(l){return s(l)}},async patch(m){try{let l=m.params?.id,R=m.params?.path;if(!l)return r("patch requires params.id");if(!R)return r("patch requires params.path");let w=m.body,B=w&&Object.prototype.hasOwnProperty.call(w,"value")?w.value:m.body;await e.patchCard(l,R,B);let x=await e.readCard(l);return x?(await d([{kind:"card_refreshed",cardId:l,card:x}]),a({count:1})):r(`card "${l}" not found`)}catch(l){return s(l)}},async appendFiles(m){try{let l=m.params?.id;if(!l)return r("appendFiles requires params.id");let R=await e.readCard(l);if(!R)return r(`card "${l}" not found`);let w=k(m.body);if(!w||w.length===0)return r("appendFiles requires a file metadata object, array, or body.files array");let B=R.card_data&&typeof R.card_data=="object"&&!Array.isArray(R.card_data)?R.card_data:{},x=Array.isArray(B.files)?B.files:[],L=[...x,...w],$=w.map((M,z)=>({idx:x.length+z,entry:M})),E=await this.patch({params:{id:l,path:"card_data.files"},body:{value:L}});return E.status!=="success"?E:a({files_added:$})}catch(l){return s(l)}}}}async function pt(e,o){return (await e.peekActive()).find(a=>a.id===o)}function Bt(e,o={}){async function a(r){let s=o.emitNotification;if(!s||r.length===0)return;let d=chunk2RIHC5TZ_cjs.e(r);if(d.length===1){await s(d[0]);return}await s(chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:d}));}return {async enqueue(r){let s=await e.enqueue(r);return await a([{kind:"message_enqueued",lane:o.lane,message:s}]),s},async enqueueMany(r){let s=await e.enqueueMany(r);return await a(s.map(d=>({kind:"message_enqueued",lane:o.lane,message:d}))),s},enqueueIfAbsent:e.enqueueIfAbsent?async(r,s)=>{let d=await e.enqueueIfAbsent(r,s);return d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]),d}:void 0,lease(r){return e.lease(r)},ack(r,s){return e.ack(r,s)},nack(r,s,d){return e.nack(r,s,d)},peekActive(r){return e.peekActive(r)},peekDeadLetter(r){return e.peekDeadLetter(r)},async stage(r,s){return e.stage(r,s)},async commitStaged(r){let s=await e.commitStaged(r);if(s){let d=await pt(e,r);d&&await a([{kind:"message_enqueued",lane:o.lane,message:d}]);}return s},async discardStaged(r,s){return e.discardStaged(r,s)},peekStaged(r){return e.peekStaged(r)}}}function A(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function C(e){return {status:"fail",error:e}}function I(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function N(){return new Date().toISOString()}function yt(e){let o=new TextEncoder().encode(e),a=Array.from(o,r=>String.fromCharCode(r)).join("");return btoa(a).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function dt(e){let o=e.replace(/-/g,"+").replace(/_/g,"/"),a=o+"=".repeat((4-o.length%4)%4),r=atob(a),s=Uint8Array.from(r,d=>d.charCodeAt(0));return new TextDecoder().decode(s)}function we(e){try{let o=JSON.parse(dt(e));return typeof o?.t=="string"?{taskName:o.t}:null}catch{return null}}function it(e){return yt(JSON.stringify(e))}function ut(e){try{let o=JSON.parse(dt(e));return typeof o?.cbk=="string"&&typeof o?.cid=="string"&&typeof o?.b=="string"&&typeof o?.d=="string"?o:null}catch{return null}}function St(e){return chunkYXKWIPQM_cjs.j(e,chunkYXKWIPQM_cjs.o,()=>({_sources:{}}))}function Rt(e,o){return chunkYXKWIPQM_cjs.h(e,o)}function Ct(e){return chunkYXKWIPQM_cjs.k(e)}function kt(e,o){return chunkYXKWIPQM_cjs.i(e,o)}function wt(e,o,a,r,s,d){return async f=>{let P=[],k=await a.cardStore.readCard(f.nodeId);if(!k)return "task-initiate-failure";let m=k.id,l=k.card_data??{},R=k.source_defs??[],w=R,B=await a.cardRuntimeStore.readRuntime(m),x=false,L=async()=>{x&&(await a.cardRuntimeStore.writeRuntime(m,B),x=false);},$=S=>chunkYXKWIPQM_cjs.p(B._sources[S]),E=(S,y)=>{B._sources[S]=chunkYXKWIPQM_cjs.p(y),x=true;},M=f.taskState?.executionCount??0;if(B._lastExecutionCount!==M&&(B._sources={},B._lastExecutionCount=M,x=true),f.update){let S=f.update.outputFile;if(S){let y=$(S);if(f.update.failure){let T=f.update.rqt??y.lastRequestedToken??y.queueRequestedToken;T&&E(S,chunkYXKWIPQM_cjs.s(y,T));}else {let T=f.update.rqt;if(!y.lastCompletedToken||T>y.lastCompletedToken){let _=typeof f.update.deliveryToken=="string"?f.update.deliveryToken:void 0,j=_?await a.fetchedSourcesStore.commitSourceData(m,S,_):false;E(S,j?chunkYXKWIPQM_cjs.r(y,T):chunkYXKWIPQM_cjs.s(y,T));}}await L();}}let z={};for(let S of R){if(!S.outputFile)continue;let y=await a.fetchedSourcesStore.readSourceData(m,S.outputFile);y!==null&&(z[S.bindTo]=y);}let Q={};for(let[S,y]of Object.entries(f.state??{}))if(y!==null&&typeof y=="object"&&!Array.isArray(y)){let T=y[S];Q[S]=T!==void 0?T:y;}else Q[S]=y;let W={id:m,card_data:{...l},requires:Q,source_defs:R,compute:k.compute};W._sourcesData=z,k.compute&&chunkUG55PF75_cjs.a.runSync(W,{sourcesData:z}),(s??(()=>{}))(m,W.computed_values??{});let Y=chunkUG55PF75_cjs.a.enrichSourcesSync(Array.isArray(k.source_defs)?k.source_defs:void 0,{card_data:k.card_data,requires:Q}),he={...k,source_defs:Array.isArray(Y)?Y.map(S=>({...S,boardDir:typeof S.boardDir=="string"&&S.boardDir?S.boardDir:e.value})):Y},q=N(),de=f.update?void 0:q,X=w.filter(S=>{let y=S.outputFile;if(typeof y!="string"||!y)return true;let T=$(y);de&&(T={...T,queueRequestedToken:de},E(y,T));let _=T.queueRequestedToken??T.lastRequestedToken??q;return chunkYXKWIPQM_cjs.q(T,_)==="dispatch"});if(await L(),X.length>0){let S=false,y=q;for(let T of X){let _=T.outputFile;if(typeof _!="string"||!_)continue;let j=$(_),n=j.queueRequestedToken??q;E(_,{...j,lastRequestedToken:n}),y=n,S=true;}return S&&await L(),S&&(P.push({taskKind:"source-fetch",payload:{boardRef:chunkVQCIOKJV_cjs.a(e),enrichedCard:he,callbackToken:f.callbackToken,rqt:y}}),await a.executionRequestStore.appendEntries(o,P)),"task-initiated"}if(w.some(S=>{let y=S.outputFile;if(typeof y!="string"||!y)return false;let T=$(y),_=T.queueRequestedToken??T.lastRequestedToken??q;return chunkYXKWIPQM_cjs.q(T,_)==="in-flight"}))return "task-initiated";let ce=k.provides??[],ie={};for(let{bindTo:S,ref:y}of ce)ie[S]=chunkUG55PF75_cjs.a.resolve(W,y);return (d??(()=>{}))(ie),r(f.nodeId,ie),P.length>0&&await a.executionRequestStore.appendEntries(o,P),"task-initiated"}}function Gt(e,o,a={}){chunkYXKWIPQM_cjs.d(o.callbackTransport,"createAsyncBoardLiveCardsPublic");let r=o.callbackTransport,s=o.warn??(()=>{}),d=chunkVQCIOKJV_cjs.a(e),f=a.emitNotification??(n=>{if(!o.publishBoardChangeNotifications)return;let t=n.kind==="notification-batch"?n.notifications:[n];return o.publishBoardChangeNotifications(t)}),P=null,k=a.boardRuntimeStoreRef,m=a.scratchStoreRef,l=a.taskExecutorRef,R=a.chatHandlerFlow;function w(){if(!k)throw new Error(`Board at ${e.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return k}function B(n){if(n.length!==0)try{let t=chunk2RIHC5TZ_cjs.e(n),c=chunk2RIHC5TZ_cjs.f({kind:"notification-batch",notifications:t});return Promise.resolve(f(c)).catch(i=>{s(`[async-board-live-cards-public] emitNotification failed: ${i instanceof Error?i.message:String(i)}`);})}catch(t){s(`[async-board-live-cards-public] emitNotification failed: ${t instanceof Error?t.message:String(t)}`);return}}let x=()=>chunkWRMOGPRG_cjs.b(o.kvStorageForRef(w())),L=e.value,$=()=>chunkYXKWIPQM_cjs.b(chunkYXKWIPQM_cjs.a(()=>o.kvStorageForRef(w()),o.hashFn),"v1"),E=async()=>{let n=await x().readOutputsStoreRef();if(!n)throw new Error(`Board at ${e.value} has no outputs store configured.`);return Ct(o.kvStorageForRef(n))},M=async()=>{let n=await x().readCardStoreRef();if(!n)throw new Error(`Board at ${e.value} has no card store configured.`);let t=o.kvStorageForRef(n);return ot(at(nt(t),o.hashFn),s)};async function z(){return !!(await $().readSnapshot(L)).values[chunkYXKWIPQM_cjs.n]}async function Q(){let n=await $().readSnapshot(L);if(!n.values[chunkYXKWIPQM_cjs.n])throw new Error(`Board not initialized at ${e.value}`);return chunkYXKWIPQM_cjs.w(n.values)}async function W(n,t){let c=await $().commitSnapshot(L,{schemaVersion:"v1",expectedVersion:t,deleteKeys:[],shallowMerge:chunkYXKWIPQM_cjs.v(n)});if(!c.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${t??"null"} current=${c.currentVersion??"null"}`)}let Y=()=>chunkYXKWIPQM_cjs.c(o.journalStorageForRef(w()));async function he(){return l??await x().readTaskExecutorRef()}async function q(n){await Y().appendEvent(n);}async function de(){let n=await x().readFetchedSourcesStoreRef();if(!n)throw new Error(`Board at ${e.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return n}async function X(){return o.blobStorageForRef(await de())}async function se(){return Rt(await X(),n=>o.resolveBlob(n))}async function ce(n){let t=(await X()).keyRef?.(n);if(!t)throw new Error("configured fetched-sources store does not support keyRef");let c=await Promise.resolve(t);return chunkVQCIOKJV_cjs.a(c)}async function ie(){let n=kt(o.kvStorageForRef(w()),async(u,g)=>{let h=u.payload,O=(h.enrichedCard??{}).id??h.cardId??"unknown";await q({type:"task-failed",taskName:O,error:g,timestamp:N()});}),t=St(o.kvStorageForRef(w())),c=await X(),i=await se(),v=await M(),b=await E(),F=new Map,p=new Map,D=[],G=[],ne=[],ae=new Map,ue=new Set,Pe={async readRuntime(u){return F.get(u)??await t.readRuntime(u)},async writeRuntime(u,g){F.set(u,g),be[u]=g;}},ct={async readSourceData(u,g){let h=`${u}/${g}`;return p.has(h)?p.get(h):await i.readSourceData(u,g)},ingestSourceDataStaged(u,g,h,V){return i.ingestSourceDataStaged(u,g,h,V)},async commitSourceData(u,g,h){let V=`${u}/.staged/${h}/${g}`,O=await c.read(V);if(O==null){let U=await Promise.resolve(c.keyRef?.(V));U&&(O=await o.resolveBlob(U));}if(O==null)return false;let J=`${u}/${g}`,ee=O.trim();try{p.set(J,JSON.parse(ee));}catch{p.set(J,ee);}return D.push({cardId:u,outputFile:g,deliveryToken:h}),true},async hasSource(u,g){let h=`${u}/${g}`;return p.has(h)||await i.hasSource(u,g)},async listSources(u){let g=await i.listSources(u),h=[...p.keys()].filter(V=>V.startsWith(`${u}/`)).map(V=>V.slice(`${u}/`.length));return [...new Set([...g,...h])]}},ve=await Q(),mt=chunkG4XXRHL2_cjs.q(ve.graph),be={...ve.runtimeByCardId},{events:lt,newCursor:Ae}=await Y().readEntriesAfterCursor(ve.lastDrainedJournalId),me=lt,le=chunkG4XXRHL2_cjs.u(mt,{handlers:{"card-handler":wt(e,Ae,{cardStore:v,cardRuntimeStore:Pe,fetchedSourcesStore:ct,executionRequestStore:n},(u,g)=>{me.push({type:"task-completed",taskName:u,data:g,timestamp:N()});},(u,g)=>{G.push({cardId:u,values:g});},u=>{ne.push(u);})},onNodeRemoved:u=>{ae.delete(u),F.delete(u),delete be[u],ue.add(u);}});for(;me.length>0;){let u=me;me=[];for(let g of u)if(g.type==="task-restart"){let h=await v.readCard(g.taskName);h&&ae.set(g.taskName,h);}le.pushAll(u),await le.waitForHandlers();}let Be=le.getState();await le.dispose({wait:true}),await W({lastDrainedJournalId:Ae,graph:chunkG4XXRHL2_cjs.p(Be),runtimeByCardId:be},(await $().readSnapshot(L)).version);for(let{cardId:u,values:g}of G)await b.writeComputedValues(u,g);for(let u of ne)await b.writeDataObjects(u);for(let[u,g]of F)await t.writeRuntime(u,g);for(let u of D)await i.commitSourceData(u.cardId,u.outputFile,u.deliveryToken);let qe=chunkYXKWIPQM_cjs.t(d,Be);await b.writeStatusSnapshot(qe);let oe=[];for(let{cardId:u,values:g}of G)oe.push({kind:"computed_values",cardId:u,values:g});for(let u of ne)for(let[g,h]of Object.entries(u))oe.push({kind:"data_object",key:g,payload:h});for(let[u,g]of ae)oe.push({kind:"card_refreshed",cardId:u,card:g});for(let u of ue)oe.push({kind:"card_removed",cardId:u});oe.push({kind:"status",status:qe}),await B(oe);let Z=await he();if(!Z)return;let Ee=o.supportsDirectSourceOutput?.(Z)===true;await n.dispatchEntriesForJournalId(Ae,async u=>{if(u.taskKind!=="source-fetch"){s(`[async-process-accumulated-events] unknown taskKind "${u.taskKind}" \u2014 skipping`);return}let g=u.payload,h=g.enrichedCard?.id??"unknown",V=g.enrichedCard?.source_defs??[];if(Z.howToRun==="queue-storage"&&Ee){try{let O=await x().readQueueStoreRef();if(!O)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let J=o.queueStorageForRef(O,"task-executor"),ee=typeof Z.extra?.boardId=="string"?Z.extra.boardId:void 0,U=[];for(let H of V){if(!H.outputFile)continue;let fe=o.genId(),ge=`${h}/.staged/${fe}/${H.outputFile}`,Ne=await Promise.resolve(c.keyRef?.(ge));if(!Ne)continue;let _e={ref:chunkVQCIOKJV_cjs.a(Ne),deliveryToken:fe,outputFile:H.outputFile,cardId:h},ft=it({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:h,b:H.bindTo,d:H.outputFile,cs:void 0,rqt:g.rqt,dt:_e.deliveryToken});U.push({...ee?{boardId:ee}:{},ref:Z,args:{source_def:H,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ft),output:_e}});}U.length>0&&await J.enqueueMany(U);}catch(O){await q({type:"task-failed",taskName:h,error:O instanceof Error?O.message:String(O),timestamp:N()});}return}for(let O of V){if(!O.outputFile)continue;let J;if(Ee){let H=o.genId(),fe=`${h}/.staged/${H}/${O.outputFile}`,ge=await Promise.resolve(c.keyRef?.(fe));ge&&(J={ref:chunkVQCIOKJV_cjs.a(ge),deliveryToken:H,outputFile:O.outputFile,cardId:h});}let ee=it({cbk:g.callbackToken,rg:e.value,br:chunkVQCIOKJV_cjs.a(e),cid:h,b:O.bindTo,d:O.outputFile,cs:void 0,rqt:g.rqt,...J?{dt:J.deliveryToken}:{}}),U=await o.dispatchExecution(Z,{source_def:O,base_ref:chunkVQCIOKJV_cjs.a(e),callback:r.createCallback(ee),...J?{output:J}:{}});U.dispatched||await q({type:"task-failed",taskName:h,error:U.error??"dispatch failed",timestamp:N()});}});}async function S(){try{let n=async()=>{let c=await Q(),{events:i}=await Y().readEntriesAfterCursor(c.lastDrainedJournalId);i.length>0&&await T();},t=await et(o.lock,ie,n);return A({ran:t!==!1})}catch(n){return I(n)}}async function y(){return P||(P=S().finally(()=>{P=null;}),P)}async function T(){let n=await x().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");t.enqueueIfAbsent?await t.enqueueIfAbsent({boardRef:chunkVQCIOKJV_cjs.a(e)},`process-accumulated:${chunkVQCIOKJV_cjs.a(e)}`):await t.enqueue({boardRef:chunkVQCIOKJV_cjs.a(e)}),await o.requestProcessAccumulated?.();}async function _(){let n=await x().readQueueStoreRef();if(!n)throw new Error(`Board at ${e.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);let t=o.queueStorageForRef(n,"process-accumulated");for(;;){let c=await t.lease({max:64,visibilityMs:1e3});if(c.length<=0)return;for(let i of c)await t.ack(i.id,i.leaseToken);if(c.length<64)return}}function j(){T();}return {async init(n){try{let t=n.params?.cardStoreRef;if(!t)return C("init requires params.cardStoreRef");if(k=n.params?.boardRuntimeStoreRef,!k)return C("init requires params.boardRuntimeStoreRef");let c=n.params?.outputsStoreRef;if(!c)return C("init requires params.outputsStoreRef");let i=n.params?.queueStoreRef;if(!i)return C("init requires params.queueStoreRef");let v=n.params?.fetchedSourcesStoreRef;if(!v)return C("init requires params.fetchedSourcesStoreRef");m=n.params?.scratchStoreRef;let b=n.params?.chatStoreRef;if(!b)return C("init requires params.chatStoreRef");let F=n.params?.artifactsStoreRef;if(!F)return C("init requires params.artifactsStoreRef");await z()||await W({lastDrainedJournalId:"",graph:chunkG4XXRHL2_cjs.p(chunkG4XXRHL2_cjs.a(chunkYXKWIPQM_cjs.u)),runtimeByCardId:{}},null);let p=x();return await p.writeBoardRuntimeStoreRef(k),await p.writeCardStoreRef(t),await p.writeOutputsStoreRef(c),await p.writeQueueStoreRef(i),await p.writeFetchedSourcesStoreRef(v),await p.writeChatStoreRef(b),await p.writeArtifactsStoreRef(F),await(await E()).writeStatusSnapshot(chunkYXKWIPQM_cjs.t(d,chunkG4XXRHL2_cjs.q((await Q()).graph))),A()}catch(t){return I(t)}},async status(n){try{let t=await E(),c=await t.readStatusSnapshot();return c||(c=chunkYXKWIPQM_cjs.t(d,chunkG4XXRHL2_cjs.q((await Q()).graph)),await t.writeStatusSnapshot(c)),A(c)}catch(t){return I(t)}},async getCardStoreRef(n){try{let t=await x().readCardStoreRef();return t?A({storeRef:t}):C(`Board at ${e.value} has no card store configured`)}catch(t){return I(t)}},async getBoardRuntimeStoreRef(n){try{return A({storeRef:k??null})}catch(t){return I(t)}},async getOutputsStoreRef(n){try{let t=await x().readOutputsStoreRef();return t?A({storeRef:t}):C(`Board at ${e.value} has no outputs store configured`)}catch(t){return I(t)}},async getScratchStoreRef(n){try{return A({storeRef:m??null})}catch(t){return I(t)}},async getChatStoreRef(n){try{return A({storeRef:await x().readChatStoreRef()})}catch(t){return I(t)}},async getArtifactsStoreRef(n){try{return A({storeRef:await x().readArtifactsStoreRef()})}catch(t){return I(t)}},async getFetchedSourcesStoreRef(n){try{return A({storeRef:await x().readFetchedSourcesStoreRef()})}catch(t){return I(t)}},async getConfig(n){try{let t=n.params?.key;if(!t)return C("getConfig requires params.key");let c=x(),i;switch(t){case "task-executor":i=l??null;break;case "chat-handler-flow":i=R??null;break;case "board-runtime-store-ref":i=await c.readBoardRuntimeStoreRef();break;case "card-store-ref":i=await c.readCardStoreRef();break;case "outputs-store-ref":i=await c.readOutputsStoreRef();break;case "scratch-store-ref":i=m??null;break;case "chat-store-ref":i=await c.readChatStoreRef();break;case "artifacts-store-ref":i=await c.readArtifactsStoreRef();break;case "fetched-sources-store-ref":i=await c.readFetchedSourcesStoreRef();break;default:return C(`getConfig: unknown key "${t}"`)}return A({value:i})}catch(t){return I(t)}},async getOutputsDataObject(n){try{let t=n.params?.key;return t?A(await(await E()).readDataObject(t)):C("getOutputsDataObject requires params.key")}catch(t){return I(t)}},async getAllOutputsDataObjects(n){try{return A(await(await E()).readAllDataObjects())}catch(t){return I(t)}},async getOutputsComputedValues(n){try{let t=n.params?.key;return t?A(await(await E()).readComputedValues(t)):C("getOutputsComputedValues requires params.key")}catch(t){return I(t)}},async getAllOutputsComputedValues(n){try{return A(await(await E()).readAllComputedValues())}catch(t){return I(t)}},async getOutputsFetchedSources(n){try{let t=n.params?.key;if(!t)return C("getOutputsFetchedSources requires params.key");let c=await(await se()).listSources(t),i={};for(let v of c)i[v]=await ce(`${t}/${v}`);return A(i)}catch(t){return I(t)}},async getAllOutputsFetchedSources(n){try{let t=await se(),c=await(await X()).listKeys(),i=new Set;for(let b of c){let F=b.indexOf("/");F>0&&!b.includes("/.staged/")&&i.add(b.slice(0,F));}let v={};for(let b of i){let F=await t.listSources(b);if(F.length!==0){v[b]={};for(let p of F)v[b][p]=await ce(`${b}/${p}`);}}return A(v)}catch(t){return I(t)}},async buildSseOneShotPayload(n){try{let t=await(await M()).readAllCards(),c=await this.status({});if(c.status!=="success")return c;let i=await this.getAllOutputsDataObjects({});if(i.status!=="success")return i;let v=await this.getAllOutputsComputedValues({});if(v.status!=="success")return v;let b=v.data,F={};for(let p of t){let D=typeof p?.id=="string"?p.id:null;if(!D)continue;let G=p.card_data&&typeof p.card_data=="object"&&!Array.isArray(p.card_data)?p.card_data:{};F[D]={schema_version:"v1",card_id:D,card_data:{...G},computed_values:b[D]&&typeof b[D]=="object"?b[D]:{}};}return A({cardDefinitions:t,statusSnapshot:c.data,dataObjectsByToken:i.data,cardRuntimeById:F})}catch(t){return I(t)}},async addCardFiles(n){try{let t=n.params?.cardId;if(!t)return C("addCardFiles requires params.cardId");let i=await st(await M(),{emitNotification:f}).appendFiles({params:{id:t},body:n.body});return i.status!=="success"?i:A({cardId:t,files_added:i.data.files_added,notified:!0})}catch(t){return I(t)}},async removeCard(n){try{let t=n.params?.id;if(!t)return C("removeCard requires params.id");try{await o.kvStorage("card-upsert").delete(t);}catch{}return await q({type:"task-removal",taskName:t,timestamp:N()}),j(),A()}catch(t){return I(t)}},async retrigger(n){try{let t=n.params?.id;return t?(await q({type:"task-restart",taskName:t,timestamp:N()}),j(),A()):C("retrigger requires params.id")}catch(t){return I(t)}},async processAccumulatedEvents(n){return await _(),y()},async upsertCard(n){try{let t=n.params?.cardId,c=n.params?.all,i=!!n.params?.restart;if(!t&&!c)return C("upsertCard requires --card-id <id> or --all");let v=await M(),b=c?(await v.readAllCards()).map(p=>p.id):[t];for(let p of b)if(!await v.readCard(p))return C(`Card "${p}" not found in board at ${e.value}`);let F=o.kvStorage("card-upsert");for(let p of b){let D=await v.readCard(p);if(!D)continue;let G=chunkYXKWIPQM_cjs.x(D),ne=o.hashFn(G),ae=await F.read(p),ue=ae?.taskConfigHash!==ne;if(!(!ue&&!i)){if(ue){let Pe=ae?.blobRef??await v.readCardKey(p)??p;await q({type:"task-upsert",taskName:p,taskConfig:G,timestamp:N()}),await F.write(p,{blobRef:Pe,taskConfigHash:ne,updatedAt:N()});}i&&await q({type:"task-restart",taskName:p,timestamp:N()});}}return j(),A()}catch(t){return I(t)}},async taskFailed(n){try{let t=n.params?.token;if(!t)return C("taskFailed requires params.token");let c=n.params?.error??"unknown error",i=we(t);return i?(await q({type:"task-failed",taskName:i.taskName,error:c,timestamp:N()}),j(),A()):C("Invalid callback token")}catch(t){return I(t)}},async taskProgress(n){try{let t=n.params?.token;if(!t)return C("taskProgress requires params.token");let c=(n.body??{}).update??{},i=we(t);return i?(await q({type:"task-progress",taskName:i.taskName,update:c,timestamp:N()}),j(),A()):C("Invalid callback token")}catch(t){return I(t)}},async sourceDataFetched(n){try{let t=n.params?.token,c=n.params?.ref;if(!t)return C("sourceDataFetched requires params.token");if(!c)return C("sourceDataFetched requires params.ref");let i=ut(t);if(!i)return C("Invalid source token");let v=await se(),b=i.dt||o.genId();i.dt||await v.ingestSourceDataStaged(i.cid,i.d,chunkVQCIOKJV_cjs.b(c),b);let F=we(i.cbk);return F?(await q({type:"task-progress",taskName:F.taskName,update:{bindTo:i.b,outputFile:i.d,fetchedAt:N(),deliveryToken:b,sourceChecksum:i.cs,rqt:i.rqt},timestamp:N()}),j(),A()):C("Invalid callback token embedded in source token")}catch(t){return I(t)}},async sourceDataFetchFailure(n){try{let t=n.params?.token,c=n.params?.reason??"unknown";if(!t)return C("sourceDataFetchFailure requires params.token");let i=ut(t);if(!i)return C("Invalid source token");let v=we(i.cbk);return v?(await q({type:"task-progress",taskName:v.taskName,update:{bindTo:i.b,outputFile:i.d,failure:!0,reason:c,sourceChecksum:i.cs,rqt:i.rqt},timestamp:N()}),j(),A()):C("Invalid callback token embedded in source token")}catch(t){return I(t)}}}}
|
|
2
|
+
exports.a=et;exports.b=nt;exports.c=at;exports.d=ot;exports.e=At;exports.f=It;exports.g=st;exports.h=Bt;exports.i=Gt;//# sourceMappingURL=chunk-N5RUH4NG.cjs.map
|
|
3
|
+
//# sourceMappingURL=chunk-N5RUH4NG.cjs.map
|
|
@@ -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 {b as b$1}from'./chunk-44L64VQ2.js';import {a as a$2}from'./chunk-XLHMUPBW.js';function v(a){if(!a||typeof a!="object")return false;let e=a;return typeof e.kind=="string"&&e.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let e=a;return e.kind==="notification-batch"?Array.isArray(e.notifications)?e.notifications.filter(v):[]:v(a)?[a]:[]}function X(a,e,i){let u=0;return {accepted:a.filter(R=>{if(!v(R))return u++,false;let _=R;return typeof _.sentAtMs=="number"&&e-_.sentAtMs>i?(u++,false):true}),rejected:u}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let e=a.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let e=a;return e.kind==="notification-batch"&&Array.isArray(e.notifications)}function V(a,e){if(e.kind==="status"){z(e.status)&&(a.status=e.status);return}if(e.kind==="computed_values"){a.computedValues[e.cardId]=e.values;return}if(e.kind==="data_object"){a.dataObjects[e.key]=e.payload;return}if(e.kind==="card_refreshed"){a.cards[e.cardId]=e.card;return}e.kind==="card_removed"&&(delete a.cards[e.cardId],delete a.computedValues[e.cardId]);}function Y(a,e){if(W(e)){for(let i of e.notifications)v(i)&&V(a,i);return}v(e)&&V(a,e);}function j(a,e){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||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function N(a,e){return j(await a,e)}function q(a$1){let e=a(a$1,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=e.split(".");if(!(i.length>=2&&i.every(f=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(f))))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 e}function E(a,e){let i=a.__private;for(let u of e.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,u))return {exists:false,value:null};i=i[u];}return {exists:true,value:i}}function oe(a$1){let{boardId:e,bootstrapBoard:i,sseHub:u,onChannelSubscribed:f,onChannelUnsubscribed:R,getMcpFacade:_,getMcpCardStoreFacade:r}=a$1;function g(s){let d=a(s,"board_id");if(!d)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(d!==e)throw Object.assign(new Error(`Unknown board_id: ${d}`),{statusCode:400})}function b(s){let d=a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function y(s){g(s);let d=b(s),n=a(s,"channel_name"),t=a(s,"card_id")||void 0;if(!n)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:n,...t?{cardId:t}:{}}}function c(s){g(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 C(s){await i();let{cardId:d}=c(s),n=b(s);if(!await u.subscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:true}}}async function m(s){await i();let{cardId:d}=c(s),n=b(s);if(!u.unsubscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:false}}}async function w(s,d){await i();let{clientId:n,channelName:t,cardId:o}=y(s);if(!u.has(n))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return d?(u.subscribeChannel(n,t,o),f?.(n,t,o?{cardId:o}:{})):(u.unsubscribeChannel(n,t,o),R?.(n,t,o?{cardId:o}:{})),{status:"success",data:{boardId:e,clientId:n,channelName:t,subscribed:d,...o?{cardId:o}:{}}}}async function S(s,d){let{cardId:n}=c(s);return await _().setChatProcessing({cardId:n,active:d}),{status:"success",data:{boardId:e,cardId:n,active:d}}}async function l(s){let{cardId:d}=c(s),n=await _().getChatProcessing({cardId:d});return {status:"success",data:{boardId:e,cardId:d,active:n.active}}}async function h(s){let{cardId:d}=c(s),n=q(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(n.split(".").includes("visible_controlplane_only")){let t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null,k=o?E(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:e,cardId:d,key:n}}}return j(await r().patch({params:{id:d,path:`__private.${n}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:e,cardId:d,key:n}}}async function I(s){let{cardId:d}=c(s),n=q(s),t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&t.cards[0]&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=E(o,n);return {status:"success",data:{boardId:e,cardId:d,key:n,exists:k.exists,value:k.value}}}return {requireCardArgs:c,subscribeChat:C,unsubscribeChat:m,watchChannel:w,setChatProcessing:S,getChatProcessing:l,setCardMeta:h,getCardMeta:I}}function ie(a){let{boardId:e,boardContexts:i,readChatRecords:u,getChatProcessing:f}=a;function R(c){if(c.length===0)return null;if(c.length===1)return c[0];let C=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],w={};for(let l of m)w[l]=0;for(let l of c){let h=l,I=Array.isArray(h.cards)?h.cards:[];C.push(...I);for(let s of m)w[s]+=Number(h?.summary?.[s]||0);}let S=c[0];return {...S,cards:C,summary:{...S.summary||{},card_count:C.length,...w}}}async function _(){let c=[];for(let C of i)try{let m=await C.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&c.push(m.data);}catch{}return c}async function r(){let C=(await _()).map(m=>m.statusSnapshot).filter(Boolean);if(C.length===0){let m=i.map(w=>w.notification.status).filter(Boolean);return R(m)}return R(C)}async function g(){let c={},C=await _();for(let m of C)Object.assign(c,m.cardRuntimeById||{});if(Object.keys(c).length>0)return c;for(let m of i)for(let[w,S]of Object.entries(m.notification.computedValues)){let l=m.notification.cards[w];c[w]={schema_version:"v1",card_id:w,card_data:l?.card_data??{},computed_values:S??{}};}return c}async function b(){let c={},C=await _();for(let m of C)Object.assign(c,m.dataObjectsByToken||{});if(Object.keys(c).length===0)for(let m of i)Object.assign(c,m.notification.dataObjects||{});return c}async function y(){let c=await _(),C=c.flatMap(l=>Array.isArray(l.cardDefinitions)?l.cardDefinitions:[]),m={},w={};for(let l of c)Object.assign(m,l.dataObjectsByToken||{}),Object.assign(w,l.cardRuntimeById||{});let S={};for(let l of C){if(!l?.id)continue;let h=l.id;try{let I=await u(h),s=await f(h);(I.length>0||s)&&(S[h]={messages:I.map(d=>({role:String(d.role||"system"),text:String(d.text||""),files:Array.isArray(d.files)?d.files:[]})),receiving:!1,processing:s});}catch{}}return {boardId:e,cardDefinitions:C,statusSnapshot:await r(),dataObjectsByToken:m,cardRuntimeById:w,cardChatsByCardId:S}}return {readStatusSnapshot:r,readCardRuntimeArtifacts:g,readDataObjectsByToken:b,buildPublishedRuntimePayload:y}}function K(a){let e=String(a||"").trim();if(!e)return "upload.bin";let i=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (i>=0?e.slice(i+1):e)||"upload.bin"}function ce(a){let{safeCardId:e,artifactsStores:i,cardFileMetadataStore:u,readCardFromStore:f,updateCardLocalOnly:R,writeChatRecord:_}=a;async function r(y){let c=[];try{let C=await f(y);if(!C)return c;let m=u().read(C.card_data&&typeof C.card_data=="object"?C.card_data:null);for(let w of m)c.push(String(w.stored_name??""));}catch{}return c}async function g(y,c,C,m){let w=e(y),S=i(y),l=K(c),h=await r(y),s=`${String(h.length+1).padStart(3,"0")}-${l}`.slice(-36);if(!S.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${y}`),{statusCode:500});return await S.files.putBytes(`${w}/${s}`,new Uint8Array(m),C||"application/octet-stream"),{name:l,stored_name:s,size:m.length,mime_type:C||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function b(y,c,C,m,w){if(!m.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let S=w?.inChat===true,l=await g(y,c,C,m),h=null;if(await R(y,I=>{let s=new Date().toISOString(),d=I.card_data&&typeof I.card_data=="object"?I.card_data:{};I.card_data=d;let n=u().normalizeIncoming([{name:l.name,stored_name:l.stored_name,size:l.size,mime_type:l.mime_type,uploaded_at:l.uploaded_at||s,chat:S}],s);return h=u().merge(d,n).findIndex(o=>o.stored_name===l.stored_name),I}),S&&w?.suppressChatRecordWrite!==true){let I=typeof h=="number"&&h>=0?` #${h}`:"";await _(y,"system",`file uploaded: ${l.name} as ${l.stored_name}${I}`,[],w?.turnId??"");}return {ok:true,file:{...l,...typeof h=="number"&&h>=0?{file_idx:h}:{},chat:S},...typeof h=="number"&&h>=0?{file_idx:h}:{}}}return {uploadCardFile:b,readCardStoredFileNames:r}}function pe(a$1){return {"discover.source-kinds":()=>a$1.discoverSourceKinds(),"inspect.board-runtime-status":()=>a$1.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>a$1.inspectCardDefinitionAndRuntime({cardId:a(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let i=b(e,"tail_turns"),u=b(e,"tail"),f=a(e,"turn_id"),R=e.all_turns===true,_=a(e,"tail_turns_before_id");return a$1.inspectChatMessagesOnCards({cardId:a(e,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...u!==void 0?{tail:u}:{},...f?{turnId:f}:{},...R?{allTurns:true}:{},..._?{tailTurnsBeforeId:_}:{}})},"inspect.file-contents":e=>a$1.inspectFileContents({cardId:a(e,"card_id"),fileIdx:Number(b(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>a$1.preflightValidateCandidateCardDefinition({candidateCardContent:d(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>a$1.preflightMaterializeCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:d(e,"mock_requires","mock_requires"),mockFetchedSources:d(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e$1=>a$1.preflightProbeSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e$1=>a$1.preflightRunSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e$1=>a$1.preflightRunSingleSourceInLiveCard({cardId:a(e$1,"card_id"),sourceIdx:e(e$1,"source_idx","source_idx"),mockRequires:d(e$1,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>a$1.preflightRunOneCycleWithCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:c(e,"mock_requires")}),"manage.read-card":e=>a$1.manageReadCard({cardId:a(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let i=a(e,"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(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...i?{turn:i}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"stage-ai-failure-message":e=>{let i=a(e,"turn_id"),u=a(e,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!u)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(e,"card_id"),role:"system",text:u,turn:i})},"manage.upsert-card":e=>a$1.manageUpsertCard({cardId:a(e,"card_id"),candidateCardContent:c(e,"candidate_card_content")}),"manage.remove-card":e=>a$1.manageRemoveCard({cardId:a(e,"card_id")})}}function me(a$1){return {"webhook.process-accumulated":()=>a$1.webhookProcessAccumulated(),"webhook.source-fetch-done":e=>a$1.webhookSourceFetchDone({token:a(e,"token"),ref:a(e,"ref")}),"webhook.source-fetch-failed":e=>a$1.webhookSourceFetchFailed({token:a(e,"token"),reason:a(e,"reason")})}}function fe(a$1){let{boardId:e,uploadCardFile:i,getMcpFacade:u,controlplane:f$1}=a$1;function R(r,g){let b=a(r,"board_id");if(!b)throw Object.assign(new Error(`${g} requires board_id`),{statusCode:400});if(b!==e)throw Object.assign(new Error(`Unknown board_id: ${b}`),{statusCode:400})}function _(r,g){let{cardId:b}=f$1.requireCardArgs(r),y=a(r,"turn_id");return R(r,g),u().manageAddChatAttachment({cardId:b,role:a(r,"role")||"user",...y?{turn:y}:{},files:[{file_name:a(r,"file_name"),content_type:a(r,"content_type")||"application/octet-stream",...typeof r.text=="string"?{text:r.text}:{},...typeof r.base64=="string"?{base64:r.base64}:{},...Array.isArray(r.bytes)?{bytes:r.bytes}:{}}]})}return {"list-runtime-cards":r=>(R(r,"list-runtime-cards"),u().listRuntimeCards()),"sse.subscribe-chat":r=>f$1.subscribeChat(r),"sse.unsubscribe-chat":r=>f$1.unsubscribeChat(r),"sse.watch-channel":r=>f$1.watchChannel(r,true),"sse.unwatch-channel":r=>f$1.watchChannel(r,false),"getstate.is-chat-processing":r=>f$1.getChatProcessing(r),"setstate.chat-processing-started":r=>f$1.setChatProcessing(r,true),"setstate.chat-processing-done":r=>f$1.setChatProcessing(r,false),"getstate.card-private":r=>f$1.getCardMeta(r),"setstate.card-private":r=>f$1.setCardMeta(r),"manage.upload-card-file":r=>{let g=a(r,"card_id"),b=a(r,"file_name"),y=a(r,"content_type")||"application/octet-stream",c=f(r);if(R(r,"manage.upload-card-file"),!g)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!c)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(g,b,y,c,{inChat:false})},"manage.add-chat-attachment":r=>_(r,"manage.add-chat-attachment"),"manage.add-chat-attachement":r=>_(r,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":r=>{let{cardId:g}=f$1.requireCardArgs(r),b=a(r,"role")||"user",y=a(r,"turn_id");return R(r,"manage.add-chat-entry-and-any-attachments"),u().manageAddChatEntryAndAnyAttachments({cardId:g,role:b,...typeof r.text=="string"?{text:r.text}:{},...y?{turn:y}:{},...Array.isArray(r.files)?{files:r.files}:{}})},"manage.patch-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.patch-card"),u().managePatchCard({cardId:g,patch:c(r,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.upsert-card"),u().manageUpsertCard({cardId:g,candidateCardContent:c(r,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.remove-card"),u().manageRemoveCard({cardId:g},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async r=>{let{cardId:g}=f$1.requireCardArgs(r);return {status:"success",data:{cards:await u().adminReadCard({cardId:g})}}},"manage.admin-upsert-card":r=>{let g=a(r,"board_id"),b=a(r,"card_id");if(!g)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(g!==e)throw Object.assign(new Error(`Unknown board_id: ${g}`),{statusCode:400});return u().adminUpsertCard({cardId:b,candidateCardContent:c(r,"candidate_card_content")})}}}function ye(a){let{boardContexts:e,cardOwnerIndex:i,cardContextForCard:u,readStatusSnapshot:f,readDataObjectsByToken:R,readCardRuntimeArtifacts:_,readCardFromStore:r,readCardDefinitions:g,processAccumulatedLaneInternal:b,reportSourceFetched:y,reportSourceFetchFailure:c,uploadCardFile:C,chatStorePublic:m,serverUrl:w,apiBasePath:S}=a;function l(){return e[0]??null}function h(){return {async status(){let n=await f();return n==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:n}},async getOutputsDataObject(n){let t=n?.params?.key;return t?{status:"success",data:(await R())[t]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(n){let t=n?.params?.key;return t?{status:"success",data:(await _())[t]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(n){let t=n?.params?.key;if(!t)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=u(t)??l();return o?o.boardOps.getOutputsFetchedSources({params:{key:t}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(n){let t=n?.params?.id;if(!t)return {status:"fail",error:"removeCard requires params.id"};let o=u(t)??l();return o?o.boardOps.removeCard({params:{id:t}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(n){let t=n?.params?.cardId;if(!t)return {status:"fail",error:"upsertCard requires params.cardId"};let o=u(t)??l();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:t,restart:n.params.restart===true}});if(k.status!=="success")return k;if(a$1(o.boardAdapter)){let P=await b(true);if(P.status!=="success")return P}return k}}}function I(){let n=()=>{let t=l();if(!t?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return t.nonCore};return {describeTaskExecutorCapabilities(t){return n().describeTaskExecutorCapabilities(t)},validateCardPreflight(t){return n().validateCardPreflight(t)},evalCardCompute(t){return n().evalCardCompute(t)},probeSourcePreflight(t){return n().probeSourcePreflight(t)},runSourcePreflight(t){return n().runSourcePreflight(t)},simulateCardCycle(t){return n().simulateCardCycle(t)}}}function s(){return {async get(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(t){let o=await r(t);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await g()}}},async set(n){let t=n.body;if(t==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(t)?t:[t];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 D=i.get(A)??0,L=e[D]??l();if(!L)return {status:"fail",error:"Board context is unavailable"};let T=await L.cardStoreOps.set({body:P});if(T.status!=="success")return T;i.set(A,D);}return {status:"success",data:{count:o.length}}},async del(n){let t=[n.params?.id,...n.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(t.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of t){let k=u(o)??l();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:t.length}}},async patch(n){let t=typeof n.params?.id=="string"?n.params.id:void 0,o=typeof n.params?.path=="string"?n.params.path:void 0;if(!t||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=u(t)??l();return k?k.cardStoreOps.patch(n):{status:"fail",error:"Board context is unavailable"}},async appendFiles(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(!t)return {status:"fail",error:"appendFiles requires params.id"};let o=u(t)??l();return o?o.cardStoreOps.appendFiles(n):{status:"fail",error:"Board context is unavailable"}}}}function d(){return a$2({board:h(),nonCore:I(),cardStore:s(),chatStore:m,processAccumulated:()=>b(true),sourceFetchDone:({token:n,ref:t})=>y(n,t),sourceFetchFailed:({token:n,reason:t})=>c(n,t),uploadCardFile({cardId:n,fileName:t,contentType:o,bytes:k,suppressChatRecordWrite:P}){return C(n,t,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:n,fileIdx:t,storedName:o}){let k=`${w||""}${S}/cards/${encodeURIComponent(n)}/files/${t}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:n,ref:t}){let o=u(n)??l();if(!o||a$1(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(b$1(t)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:h,mcpNonCoreFacade:I,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,q as h,E as i,oe as j,ie as k,ce as l,pe as m,me as n,fe as o,ye as p};//# sourceMappingURL=chunk-7KSENEPK.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {a as a$1}from'./chunk-FOFGEABN.js';import {a,c,d,e,b,f}from'./chunk-O7NOHKVR.js';import {b as b$1}from'./chunk-44L64VQ2.js';import {a as a$2}from'./chunk-RWAEV253.js';function v(a){if(!a||typeof a!="object")return false;let e=a;return typeof e.kind=="string"&&e.kind.length>0}function J(a){if(!a||typeof a!="object")return [];let e=a;return e.kind==="notification-batch"?Array.isArray(e.notifications)?e.notifications.filter(v):[]:v(a)?[a]:[]}function X(a,e,i){let u=0;return {accepted:a.filter(R=>{if(!v(R))return u++,false;let _=R;return typeof _.sentAtMs=="number"&&e-_.sentAtMs>i?(u++,false):true}),rejected:u}}function Q(){return {status:null,computedValues:{},dataObjects:{},cards:{}}}function z(a){if(!a||typeof a!="object")return false;let e=a.summary;return !e||typeof e!="object"?false:Number(e.card_count||0)>0}function W(a){if(!a||typeof a!="object")return false;let e=a;return e.kind==="notification-batch"&&Array.isArray(e.notifications)}function V(a,e){if(e.kind==="status"){z(e.status)&&(a.status=e.status);return}if(e.kind==="computed_values"){a.computedValues[e.cardId]=e.values;return}if(e.kind==="data_object"){a.dataObjects[e.key]=e.payload;return}if(e.kind==="card_refreshed"){a.cards[e.cardId]=e.card;return}e.kind==="card_removed"&&(delete a.cards[e.cardId],delete a.computedValues[e.cardId]);}function Y(a,e){if(W(e)){for(let i of e.notifications)v(i)&&V(a,i);return}v(e)&&V(a,e);}function j(a,e){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||`${e} failed`),{statusCode:400}):Object.assign(new Error(`${e} returned an unexpected response`),{statusCode:500})}async function N(a,e){return j(await a,e)}function q(a$1){let e=a(a$1,"key");if(!e)throw Object.assign(new Error("MCP tool requires key"),{statusCode:400});let i=e.split(".");if(!(i.length>=2&&i.every(f=>/^[A-Za-z_][A-Za-z0-9_]*$/.test(f))))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 e}function E(a,e){let i=a.__private;for(let u of e.split(".")){if(!i||typeof i!="object"||Array.isArray(i)||!Object.prototype.hasOwnProperty.call(i,u))return {exists:false,value:null};i=i[u];}return {exists:true,value:i}}function oe(a$1){let{boardId:e,bootstrapBoard:i,sseHub:u,onChannelSubscribed:f,onChannelUnsubscribed:R,getMcpFacade:_,getMcpCardStoreFacade:r}=a$1;function g(s){let d=a(s,"board_id");if(!d)throw Object.assign(new Error("MCP tool requires board_id"),{statusCode:400});if(d!==e)throw Object.assign(new Error(`Unknown board_id: ${d}`),{statusCode:400})}function b(s){let d=a(s,"client_id");if(!d)throw Object.assign(new Error("MCP tool requires client_id"),{statusCode:400});return d}function y(s){g(s);let d=b(s),n=a(s,"channel_name"),t=a(s,"card_id")||void 0;if(!n)throw Object.assign(new Error("MCP tool requires channel_name"),{statusCode:400});return {clientId:d,channelName:n,...t?{cardId:t}:{}}}function c(s){g(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 C(s){await i();let{cardId:d}=c(s),n=b(s);if(!await u.subscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:true}}}async function m(s){await i();let{cardId:d}=c(s),n=b(s);if(!u.unsubscribeChat(n,d))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return {status:"success",data:{boardId:e,cardId:d,clientId:n,subscribed:false}}}async function w(s,d){await i();let{clientId:n,channelName:t,cardId:o}=y(s);if(!u.has(n))throw Object.assign(new Error(`SSE client not connected: ${n}`),{statusCode:404});return d?(u.subscribeChannel(n,t,o),f?.(n,t,o?{cardId:o}:{})):(u.unsubscribeChannel(n,t,o),R?.(n,t,o?{cardId:o}:{})),{status:"success",data:{boardId:e,clientId:n,channelName:t,subscribed:d,...o?{cardId:o}:{}}}}async function S(s,d){let{cardId:n}=c(s);return await _().setChatProcessing({cardId:n,active:d}),{status:"success",data:{boardId:e,cardId:n,active:d}}}async function l(s){let{cardId:d}=c(s),n=await _().getChatProcessing({cardId:d});return {status:"success",data:{boardId:e,cardId:d,active:n.active}}}async function h(s){let{cardId:d}=c(s),n=q(s);if(!Object.prototype.hasOwnProperty.call(s,"value"))throw Object.assign(new Error("MCP tool requires value"),{statusCode:400});if(n.split(".").includes("visible_controlplane_only")){let t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null,k=o?E(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:e,cardId:d,key:n}}}return j(await r().patch({params:{id:d,path:`__private.${n}`},body:{value:s.value}}),"cardStore.patch"),{status:"success",data:{boardId:e,cardId:d,key:n}}}async function I(s){let{cardId:d}=c(s),n=q(s),t=await N(r().get({params:{id:d}}),"cardStore.get"),o=Array.isArray(t.cards)&&t.cards.length>0&&t.cards[0]&&typeof t.cards[0]=="object"&&!Array.isArray(t.cards[0])?t.cards[0]:null;if(!o)throw Object.assign(new Error(`Card "${d}" not found`),{statusCode:404});let k=E(o,n);return {status:"success",data:{boardId:e,cardId:d,key:n,exists:k.exists,value:k.value}}}return {requireCardArgs:c,subscribeChat:C,unsubscribeChat:m,watchChannel:w,setChatProcessing:S,getChatProcessing:l,setCardMeta:h,getCardMeta:I}}function ie(a){let{boardId:e,boardContexts:i,readChatRecords:u,getChatProcessing:f}=a;function R(c){if(c.length===0)return null;if(c.length===1)return c[0];let C=[],m=["completed","eligible","pending","blocked","unresolved","failed","in_progress","orphan_cards"],w={};for(let l of m)w[l]=0;for(let l of c){let h=l,I=Array.isArray(h.cards)?h.cards:[];C.push(...I);for(let s of m)w[s]+=Number(h?.summary?.[s]||0);}let S=c[0];return {...S,cards:C,summary:{...S.summary||{},card_count:C.length,...w}}}async function _(){let c=[];for(let C of i)try{let m=await C.boardOps.buildSseOneShotPayload({});m.status==="success"&&m.data&&c.push(m.data);}catch{}return c}async function r(){let C=(await _()).map(m=>m.statusSnapshot).filter(Boolean);if(C.length===0){let m=i.map(w=>w.notification.status).filter(Boolean);return R(m)}return R(C)}async function g(){let c={},C=await _();for(let m of C)Object.assign(c,m.cardRuntimeById||{});if(Object.keys(c).length>0)return c;for(let m of i)for(let[w,S]of Object.entries(m.notification.computedValues)){let l=m.notification.cards[w];c[w]={schema_version:"v1",card_id:w,card_data:l?.card_data??{},computed_values:S??{}};}return c}async function b(){let c={},C=await _();for(let m of C)Object.assign(c,m.dataObjectsByToken||{});if(Object.keys(c).length===0)for(let m of i)Object.assign(c,m.notification.dataObjects||{});return c}async function y(){let c=await _(),C=c.flatMap(l=>Array.isArray(l.cardDefinitions)?l.cardDefinitions:[]),m={},w={};for(let l of c)Object.assign(m,l.dataObjectsByToken||{}),Object.assign(w,l.cardRuntimeById||{});let S={};for(let l of C){if(!l?.id)continue;let h=l.id;try{let I=await u(h),s=await f(h);(I.length>0||s)&&(S[h]={messages:I.map(d=>({role:String(d.role||"system"),text:String(d.text||""),files:Array.isArray(d.files)?d.files:[]})),receiving:!1,processing:s});}catch{}}return {boardId:e,cardDefinitions:C,statusSnapshot:await r(),dataObjectsByToken:m,cardRuntimeById:w,cardChatsByCardId:S}}return {readStatusSnapshot:r,readCardRuntimeArtifacts:g,readDataObjectsByToken:b,buildPublishedRuntimePayload:y}}function K(a){let e=String(a||"").trim();if(!e)return "upload.bin";let i=Math.max(e.lastIndexOf("/"),e.lastIndexOf("\\"));return (i>=0?e.slice(i+1):e)||"upload.bin"}function ce(a){let{safeCardId:e,artifactsStores:i,cardFileMetadataStore:u,readCardFromStore:f,updateCardLocalOnly:R,writeChatRecord:_}=a;async function r(y){let c=[];try{let C=await f(y);if(!C)return c;let m=u().read(C.card_data&&typeof C.card_data=="object"?C.card_data:null);for(let w of m)c.push(String(w.stored_name??""));}catch{}return c}async function g(y,c,C,m){let w=e(y),S=i(y),l=K(c),h=await r(y),s=`${String(h.length+1).padStart(3,"0")}-${l}`.slice(-36);if(!S.files)throw Object.assign(new Error(`artifactsStoreRef is not configured for card uploads: ${y}`),{statusCode:500});return await S.files.putBytes(`${w}/${s}`,new Uint8Array(m),C||"application/octet-stream"),{name:l,stored_name:s,size:m.length,mime_type:C||"application/octet-stream",uploaded_at:new Date().toISOString()}}async function b(y,c,C,m,w){if(!m.length)throw Object.assign(new Error("Empty upload body"),{statusCode:400});let S=w?.inChat===true,l=await g(y,c,C,m),h=null;if(await R(y,I=>{let s=new Date().toISOString(),d=I.card_data&&typeof I.card_data=="object"?I.card_data:{};I.card_data=d;let n=u().normalizeIncoming([{name:l.name,stored_name:l.stored_name,size:l.size,mime_type:l.mime_type,uploaded_at:l.uploaded_at||s,chat:S}],s);return h=u().merge(d,n).findIndex(o=>o.stored_name===l.stored_name),I}),S&&w?.suppressChatRecordWrite!==true){let I=typeof h=="number"&&h>=0?` #${h}`:"";await _(y,"system",`file uploaded: ${l.name} as ${l.stored_name}${I}`,[],w?.turnId??"");}return {ok:true,file:{...l,...typeof h=="number"&&h>=0?{file_idx:h}:{},chat:S},...typeof h=="number"&&h>=0?{file_idx:h}:{}}}return {uploadCardFile:b,readCardStoredFileNames:r}}function pe(a$1){return {"discover.source-kinds":()=>a$1.discoverSourceKinds(),"inspect.board-runtime-status":()=>a$1.inspectBoardRuntimeStatus(),"inspect.card-definition-and-runtime":e=>a$1.inspectCardDefinitionAndRuntime({cardId:a(e,"card_id")}),"inspect.chat-messages-on-cards":e=>{let i=b(e,"tail_turns"),u=b(e,"tail"),f=a(e,"turn_id"),R=e.all_turns===true,_=a(e,"tail_turns_before_id");return a$1.inspectChatMessagesOnCards({cardId:a(e,"card_id"),...i!==void 0?{lastUserTurns:i}:{},...u!==void 0?{tail:u}:{},...f?{turnId:f}:{},...R?{allTurns:true}:{},..._?{tailTurnsBeforeId:_}:{}})},"inspect.file-contents":e=>a$1.inspectFileContents({cardId:a(e,"card_id"),fileIdx:Number(b(e,"file_idx"))}),"preflight.validate-candidate-card-definition":e=>a$1.preflightValidateCandidateCardDefinition({candidateCardContent:d(e,"candidate_card_content","candidate_card_content")}),"preflight.materialize-candidate-card":e=>a$1.preflightMaterializeCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:d(e,"mock_requires","mock_requires"),mockFetchedSources:d(e,"mock_fetched_sources","mock_fetched_sources")}),"preflight.probe-single-source-in-candidate-card":e$1=>a$1.preflightProbeSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-candidate-card":e$1=>a$1.preflightRunSingleSourceInCandidateCard({candidateCardContent:d(e$1,"candidate_card_content","candidate_card_content"),mockProjections:c(e$1,"mock_projections"),sourceIdx:e(e$1,"source_idx","source_idx")}),"preflight.run-single-source-in-live-card":e$1=>a$1.preflightRunSingleSourceInLiveCard({cardId:a(e$1,"card_id"),sourceIdx:e(e$1,"source_idx","source_idx"),mockRequires:d(e$1,"mock_requires","mock_requires")}),"preflight.run-one-cycle-with-candidate-card":e=>a$1.preflightRunOneCycleWithCandidateCard({candidateCardContent:d(e,"candidate_card_content","candidate_card_content"),mockRequires:c(e,"mock_requires")}),"manage.read-card":e=>a$1.manageReadCard({cardId:a(e,"card_id")}),"stage-ai-response-and-any-attachments":e=>{let i=a(e,"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(e,"card_id"),role:"assistant",...typeof e.text=="string"?{text:e.text}:{},...i?{turn:i}:{},...Array.isArray(e.files)?{files:e.files}:{}})},"stage-ai-failure-message":e=>{let i=a(e,"turn_id"),u=a(e,"failure");if(!i)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty turn_id"),{statusCode:400});if(!u)throw Object.assign(new Error("stage-ai-failure-message requires a non-empty failure"),{statusCode:400});return a$1.manageAddChatEntryAndAnyAttachments({cardId:a(e,"card_id"),role:"system",text:u,turn:i})},"manage.upsert-card":e=>a$1.manageUpsertCard({cardId:a(e,"card_id"),candidateCardContent:c(e,"candidate_card_content")}),"manage.remove-card":e=>a$1.manageRemoveCard({cardId:a(e,"card_id")})}}function me(a$1){return {"webhook.process-accumulated":()=>a$1.webhookProcessAccumulated(),"webhook.source-fetch-done":e=>a$1.webhookSourceFetchDone({token:a(e,"token"),ref:a(e,"ref")}),"webhook.source-fetch-failed":e=>a$1.webhookSourceFetchFailed({token:a(e,"token"),reason:a(e,"reason")})}}function fe(a$1){let{boardId:e,uploadCardFile:i,getMcpFacade:u,controlplane:f$1}=a$1;function R(r,g){let b=a(r,"board_id");if(!b)throw Object.assign(new Error(`${g} requires board_id`),{statusCode:400});if(b!==e)throw Object.assign(new Error(`Unknown board_id: ${b}`),{statusCode:400})}function _(r,g){let{cardId:b}=f$1.requireCardArgs(r),y=a(r,"turn_id");return R(r,g),u().manageAddChatAttachment({cardId:b,role:a(r,"role")||"user",...y?{turn:y}:{},files:[{file_name:a(r,"file_name"),content_type:a(r,"content_type")||"application/octet-stream",...typeof r.text=="string"?{text:r.text}:{},...typeof r.base64=="string"?{base64:r.base64}:{},...Array.isArray(r.bytes)?{bytes:r.bytes}:{}}]})}return {"list-runtime-cards":r=>(R(r,"list-runtime-cards"),u().listRuntimeCards()),"sse.subscribe-chat":r=>f$1.subscribeChat(r),"sse.unsubscribe-chat":r=>f$1.unsubscribeChat(r),"sse.watch-channel":r=>f$1.watchChannel(r,true),"sse.unwatch-channel":r=>f$1.watchChannel(r,false),"getstate.is-chat-processing":r=>f$1.getChatProcessing(r),"setstate.chat-processing-started":r=>f$1.setChatProcessing(r,true),"setstate.chat-processing-done":r=>f$1.setChatProcessing(r,false),"getstate.card-private":r=>f$1.getCardMeta(r),"setstate.card-private":r=>f$1.setCardMeta(r),"manage.upload-card-file":r=>{let g=a(r,"card_id"),b=a(r,"file_name"),y=a(r,"content_type")||"application/octet-stream",c=f(r);if(R(r,"manage.upload-card-file"),!g)throw Object.assign(new Error("manage.upload-card-file requires card_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.upload-card-file requires file_name"),{statusCode:400});if(!c)throw Object.assign(new Error("manage.upload-card-file requires args.bytes, args.text, or args.base64"),{statusCode:400});return i(g,b,y,c,{inChat:false})},"manage.add-chat-attachment":r=>_(r,"manage.add-chat-attachment"),"manage.add-chat-attachement":r=>_(r,"manage.add-chat-attachement"),"manage.add-chat-entry-and-any-attachments":r=>{let{cardId:g}=f$1.requireCardArgs(r),b=a(r,"role")||"user",y=a(r,"turn_id");return R(r,"manage.add-chat-entry-and-any-attachments"),u().manageAddChatEntryAndAnyAttachments({cardId:g,role:b,...typeof r.text=="string"?{text:r.text}:{},...y?{turn:y}:{},...Array.isArray(r.files)?{files:r.files}:{}})},"manage.patch-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.patch-card"),u().managePatchCard({cardId:g,patch:c(r,"patch")},{allowControlplaneOnlyCards:true})},"manage.upsert-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.upsert-card"),u().manageUpsertCard({cardId:g,candidateCardContent:c(r,"candidate_card_content")},{allowControlplaneOnlyCards:true})},"manage.remove-card":r=>{let{cardId:g}=f$1.requireCardArgs(r);return R(r,"manage.remove-card"),u().manageRemoveCard({cardId:g},{allowControlplaneOnlyCards:true})},"manage.admin-read-card":async r=>{let{cardId:g}=f$1.requireCardArgs(r);return {status:"success",data:{cards:await u().adminReadCard({cardId:g})}}},"manage.admin-upsert-card":r=>{let g=a(r,"board_id"),b=a(r,"card_id");if(!g)throw Object.assign(new Error("manage.admin-upsert-card requires board_id"),{statusCode:400});if(!b)throw Object.assign(new Error("manage.admin-upsert-card requires card_id"),{statusCode:400});if(g!==e)throw Object.assign(new Error(`Unknown board_id: ${g}`),{statusCode:400});return u().adminUpsertCard({cardId:b,candidateCardContent:c(r,"candidate_card_content")})}}}function ye(a){let{boardContexts:e,cardOwnerIndex:i,cardContextForCard:u,readStatusSnapshot:f,readDataObjectsByToken:R,readCardRuntimeArtifacts:_,readCardFromStore:r,readCardDefinitions:g,processAccumulatedLaneInternal:b,reportSourceFetched:y,reportSourceFetchFailure:c,uploadCardFile:C,chatStorePublic:m,serverUrl:w,apiBasePath:S}=a;function l(){return e[0]??null}function h(){return {async status(){let n=await f();return n==null?{status:"fail",error:"Board status is unavailable"}:{status:"success",data:n}},async getOutputsDataObject(n){let t=n?.params?.key;return t?{status:"success",data:(await R())[t]}:{status:"fail",error:"getOutputsDataObject requires params.key"}},async getOutputsComputedValues(n){let t=n?.params?.key;return t?{status:"success",data:(await _())[t]?.computed_values}:{status:"fail",error:"getOutputsComputedValues requires params.key"}},async getOutputsFetchedSources(n){let t=n?.params?.key;if(!t)return {status:"fail",error:"getOutputsFetchedSources requires params.key"};let o=u(t)??l();return o?o.boardOps.getOutputsFetchedSources({params:{key:t}}):{status:"fail",error:"Board context is unavailable"}},async removeCard(n){let t=n?.params?.id;if(!t)return {status:"fail",error:"removeCard requires params.id"};let o=u(t)??l();return o?o.boardOps.removeCard({params:{id:t}}):{status:"fail",error:"Board context is unavailable"}},async upsertCard(n){let t=n?.params?.cardId;if(!t)return {status:"fail",error:"upsertCard requires params.cardId"};let o=u(t)??l();if(!o)return {status:"fail",error:"Board context is unavailable"};let k=await o.boardOps.upsertCard({params:{cardId:t,restart:n.params.restart===true}});if(k.status!=="success")return k;if(a$1(o.boardAdapter)){let P=await b(true);if(P.status!=="success")return P}return k}}}function I(){let n=()=>{let t=l();if(!t?.nonCore)throw new Error("Board non-core adapter is not configured for MCP preflight/discovery tools");return t.nonCore};return {describeTaskExecutorCapabilities(t){return n().describeTaskExecutorCapabilities(t)},validateCardPreflight(t){return n().validateCardPreflight(t)},evalCardCompute(t){return n().evalCardCompute(t)},probeSourcePreflight(t){return n().probeSourcePreflight(t)},runSourcePreflight(t){return n().runSourcePreflight(t)},simulateCardCycle(t){return n().simulateCardCycle(t)}}}function s(){return {async get(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(t){let o=await r(t);return o?{status:"success",data:{cards:[o]}}:{status:"success",data:{cards:[]}}}return {status:"success",data:{cards:await g()}}},async set(n){let t=n.body;if(t==null)return {status:"fail",error:"set requires a body (card object or array of cards)"};let o=Array.isArray(t)?t:[t];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 D=i.get(A)??0,L=e[D]??l();if(!L)return {status:"fail",error:"Board context is unavailable"};let T=await L.cardStoreOps.set({body:P});if(T.status!=="success")return T;i.set(A,D);}return {status:"success",data:{count:o.length}}},async del(n){let t=[n.params?.id,...n.body?.ids??[]].filter(o=>typeof o=="string"&&!!o);if(t.length===0)return {status:"fail",error:"del requires body.ids (string[]) or params.id"};for(let o of t){let k=u(o)??l();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:t.length}}},async patch(n){let t=typeof n.params?.id=="string"?n.params.id:void 0,o=typeof n.params?.path=="string"?n.params.path:void 0;if(!t||!o)return {status:"fail",error:"patch requires params.id and params.path"};let k=u(t)??l();return k?k.cardStoreOps.patch(n):{status:"fail",error:"Board context is unavailable"}},async appendFiles(n){let t=typeof n.params?.id=="string"?n.params.id:void 0;if(!t)return {status:"fail",error:"appendFiles requires params.id"};let o=u(t)??l();return o?o.cardStoreOps.appendFiles(n):{status:"fail",error:"Board context is unavailable"}}}}function d(){return a$2({board:h(),nonCore:I(),cardStore:s(),chatStore:m,processAccumulated:()=>b(true),sourceFetchDone:({token:n,ref:t})=>y(n,t),sourceFetchFailed:({token:n,reason:t})=>c(n,t),uploadCardFile({cardId:n,fileName:t,contentType:o,bytes:k,suppressChatRecordWrite:P}){return C(n,t,o,k,{inChat:true,...P===true?{suppressChatRecordWrite:true}:{}})},buildFileDownloadUrl({cardId:n,fileIdx:t,storedName:o}){let k=`${w||""}${S}/cards/${encodeURIComponent(n)}/files/${t}`;return o?`${k}?sn=${encodeURIComponent(o)}`:k},readFetchedSourceJsonByRef({cardId:n,ref:t}){let o=u(n)??l();if(!o||a$1(o.boardAdapter))return null;let A=o.boardAdapter.resolveBlob(b$1(t)).trim();return A?JSON.parse(A):null}})}return {mcpBoardFacade:h,mcpNonCoreFacade:I,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,q as h,E as i,oe as j,ie as k,ce as l,pe as m,me as n,fe as o,ye as p};//# sourceMappingURL=chunk-OEL5P7XE.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-OEL5P7XE.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {a}from'./chunk-JMDHDY6M.js';function P(s,d){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function G(s,d){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${d} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function n(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function y(s){return Array.isArray(s)?s:[]}function N(s,d){if(typeof d!="string"||d.length===0)return;let c=s,p=d;p.startsWith("fetched_sources.")&&(c=n(s).fetched_sources,p=p.slice(16));for(let g of p.split(".")){if(c==null||typeof c!="object")return;c=c[g];}return c}function z(s,d){let c=n(s.view),p=y(c.elements);return {layout:c.layout,features:c.features,elements:p.map((g,h)=>{let R=n(g),b=n(R.data),k=typeof R.visible=="string"?!!N(d,R.visible):true,x=typeof b.bind=="string"?b.bind:void 0,S=typeof b.maxRows=="number"?b.maxRows:void 0,B=x?N(d,x):void 0,q={id:typeof R.id=="string"&&R.id?R.id:`element-${h}`,kind:R.kind,label:R.label,visible:k};return B!==void 0&&(q.resolved=Array.isArray(B)&&typeof S=="number"?B.slice(0,S):B),q})}}function Q(s,d){let c=typeof s.id=="string"&&s.id?s.id:"card",p=y(s.provides),g=p.length>0?p:[{bindTo:c,ref:"card_data"}],h={};for(let R of g){let b=n(R),k=typeof b.bindTo=="string"?b.bindTo:"",x=typeof b.ref=="string"?b.ref:"";if(!k||!x)continue;let S=N(d,x);S!==void 0&&(h[k]=S);}return h}function be(s){if(typeof s!="string"||!s.trim())return null;let d=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!d)return null;let c=Number.parseInt(d[2],10);return !Number.isInteger(c)||c<0?null:c}function ke(s){return {"card-content":s}}function j(s){let d={...s};return delete d.__private,d}function he(s,d){return Object.prototype.hasOwnProperty.call(s,d)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,d){let c=Re(s);if(!d||Object.keys(d).length===0)return c;function p(g,h,R){let b=String(h||"").split(".").filter(Boolean);if(!b.length)return;let k=g;for(let x=0;x<b.length-1;x+=1){let S=b[x];(!k[S]||typeof k[S]!="object")&&(k[S]={}),k=k[S];}k[b[b.length-1]]=R;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let g=null,h=n(c.view),R=y(h.elements);for(let b of R){let k=n(n(b).data);if(typeof k.writeTo=="string"&&k.writeTo){g=k.writeTo;break}}return g?p(c,g,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(c.card_data={...n(c.card_data),...d.fieldValues}),c}if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return c;for(let[g,h]of Object.entries(d))g!=="_stagedFiles"&&(h!==null&&typeof h=="object"&&!Array.isArray(h)&&c[g]!==null&&typeof c[g]=="object"&&!Array.isArray(c[g])?c[g]={...c[g],...h}:c[g]=h);return c}function D(s){return n(s.__private).visible_controlplane_only===true}async function T(s,d){let c=await A(s.get({params:{id:d}}),"cardStore.get"),p=Array.isArray(c?.cards)?c.cards:[];if(p.length===0)throw new Error(`Card "${d}" not found`);return p[0]}function Ae(s){let{board:d,nonCore:c,cardStore:p,chatStore:g,processAccumulated:h,sourceFetchDone:R,sourceFetchFailed:b,uploadCardFile:k,buildFileDownloadUrl:x,readFetchedSourceJsonByRef:S}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function q(){let e=await A(p.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>n(r)).filter(r=>!D(r)):[]}function X(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),a=atob(t);return Uint8Array.from(a,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=n(await A(c.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:n(e.commonSourceDefFields),sourceKinds:n(e.sourceKinds)}}async function Z(){let e=n(await A(d.status({}),"status")),r=n(e.summary),t=y(e.cards),a=await A(p.get({}),"cardStore.get"),o=new Set((Array.isArray(a.cards)?a.cards.map(n):[]).filter(D).map(u=>typeof u.id=="string"?u.id:"").filter(Boolean)),i=t.filter(u=>!o.has(String(n(u).name??"")));return {meta:n(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:i.map(u=>{let l=n(u);return {"card-id":typeof l.name=="string"?l.name:null,status:l.status??null,error:l.error??null,requires:y(l.requires),requires_satisfied:y(l.requires_satisfied),requires_missing:y(l.requires_missing),provides_declared:y(l.provides_declared),provides_runtime:y(l.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=n(await A(d.status({}),"status")),o=y(t.cards).map(n).find(f=>f.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let i=n(await T(p,r)),u=j(i),l=y(o.requires_satisfied).filter(f=>typeof f=="string"&&!!f),I=y(o.provides_runtime).filter(f=>typeof f=="string"&&!!f),v=Object.fromEntries(await Promise.all(l.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),_=Object.fromEntries(await Promise.all(I.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),m=n(await A(d.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),C=await A(d.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),M=y(i.source_defs).map(n),w={};for(let f of M)typeof f.bindTo=="string"&&typeof f.outputFile=="string"&&(w[f.outputFile]=f.bindTo);let U={};for(let[f,F]of Object.entries(C)){let O=w[f]??f;if(!S||typeof F!="string"){U[O]=null;continue}try{U[O]=S({cardId:r,ref:F});}catch{U[O]=null;}}let L={card_data:n(i.card_data),requires:v,fetched_sources:U,computed_values:m};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:u,refs_for_fetched_source_files:C,runtime_data:{requires:v,provides:_,computed_values:m,rendered_view:z(i,L)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",a=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",i=a?void 0:e.lastUserTurns??(t?void 0:1),u=e.tail,l={...i===void 0?{}:{tailTurns:i},...t?{turnId:t}:{},...a?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},I=Object.keys(l).length>0?{params:{cardId:r},body:l}:{params:{cardId:r}},v=P(await g.readAll(I),"chatStore.readAll"),_=n(await T(p,r)),m=y(n(_.card_data).files).map((w,U)=>({idx:U,stored_name:n(w).stored_name})).filter(w=>typeof w.stored_name=="string"&&w.stored_name.length>0),M=(Array.isArray(v.records)?v.records:[]).map(w=>{let L=n(w.payload),f={...w},F=typeof w?.role=="string"?w.role:typeof L.role=="string"?String(L.role):"",O=typeof w?.text=="string"?w.text:typeof L.text=="string"?String(L.text):"";if(F==="system"){let V=be(O);if(V!==null&&m.some(E=>E.idx===V)){let E=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${V}`;f.retrieval_hint=E,Object.keys(L).length>0&&typeof w.role!="string"&&(f.payload={...L,retrieval_hint:E});}}return f});return {cardId:r,messages:typeof u=="number"&&u>=0?M.slice(-u):M}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let a=n(await T(p,r)),o=y(n(a.card_data).files).map(n);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let i=o[t],u=typeof i.stored_name=="string"?i.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:x({cardId:r,fileIdx:t,storedName:u}),...typeof i.name=="string"?{name:i.name}:{},...typeof i.stored_name=="string"?{stored_name:i.stored_name}:{},...typeof i.mime_type=="string"?{mime_type:i.mime_type}:{},...typeof i.size=="number"?{size:i.size}:{},...typeof i.uploaded_at=="string"?{uploaded_at:i.uploaded_at}:{}}}async function $(e){return await c.validateCardPreflight({body:ke(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=c.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=n(G(r,"evalCardCompute")),a=n(e.candidateCardContent),o={card_data:n(a.card_data),requires:n(e.mockRequires),fetched_sources:n(e.mockFetchedSources),computed_values:n(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof a.id=="string"?a.id:"(unknown)",ok:t.ok===true,computed_values:n(t.computed_values),errors:y(t.errors).map(i=>{let u=n(i);return {bindTo:typeof u.bindTo=="string"?u.bindTo:"",error:typeof u.error=="string"?u.error:""}}),provides_outputs:Q(a,o),rendered_view:z(a,o)}}}async function ae(e){return await c.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=n(await T(p,r)),a$1=y(t.source_defs).filter(i=>!!i&&typeof i=="object"&&!Array.isArray(i)),o={};if(e.sourceIdx>=0&&e.sourceIdx<a$1.length){let i=a$1[e.sourceIdx],u=a.enrichSourcesSync([i],{card_data:n(t.card_data),requires:e.mockRequires});Array.isArray(u)&&u.length>0&&(o=n(u[0]._projections));}return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=n(await A(c.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=n(e.candidateCardContent),a=n(r.validation),o=y(r.source_probes),i=y(r.projection_errors),u=n(r.fetched_sources),l=y(r.compute_errors),I=n(r.computed_values),v={card_data:n(t.card_data),requires:e.mockRequires,fetched_sources:u,computed_values:I},_=[];for(let m of y(a.issues))typeof m=="string"&&m&&_.push(m);for(let m of o){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.error=="string"?C.error:"";w&&_.push(`${M}: ${w}`);}for(let m of i){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.key=="string"?C.key:"projection",U=typeof C.error=="string"?C.error:"projection failed";_.push(`${M}.${w}: ${U}`);}for(let m of l){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"compute",w=typeof C.error=="string"?C.error:"compute failed";_.push(`${M}: ${w}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:_,provides_outputs:Q(t,v),rendered_view:z(t,v)}}}async function K(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await A(p.get({params:{id:r}}),"cardStore.get");return (Array.isArray(t.cards)?t.cards.map(n):[]).map(o=>j(o))}async function W(e){let r=await Promise.all(y(e.files).map(async t=>{let a=n(t),o=String(a.file_name??a.fileName??a.name??"").trim(),i=String(a.content_type??a.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await k({cardId:e.cardId,fileName:o,contentType:i,bytes:X(a),suppressChatRecordWrite:true})}));for(let[t,a]of r.entries()){let o=n(a.file),i=typeof a.file_idx=="number"&&Number.isInteger(a.file_idx)&&a.file_idx>=0?a.file_idx:t,u=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`;P(await g.append({params:{cardId:e.cardId},body:{role:"system",text:u,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}return r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",a=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await W({cardId:r,role:t,turn:a,files:e.files});return {status:"success",data:{cardId:r,turn:a,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),a=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let l=P(await g.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),I=Array.isArray(l.records)?l.records.find(v=>v.role==="assistant"&&String(v.turn||"")===o):void 0;if(I)return {status:"success",data:{cardId:r,id:String(I.id),role:t,turn:o,files:Array.isArray(I.files)?I.files:[]}}}let i=await W({cardId:r,role:t,turn:o,files:e.files}),u=P(await g.append({params:{cardId:r},body:{role:t,text:a,files:i,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(u.id),role:t,turn:o,files:i}}}async function ue(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.patch);if(!t)throw new Error("managePatchCard requires cardId");let o=await K({cardId:t}),i=n(o[0]),u=ve(i,a);return J({cardId:t,candidateCardContent:u},r)}async function J(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.candidateCardContent),o=j(a);if(!t)throw new Error("manageUpsertCard requires cardId");if(typeof o.id!="string"||!o.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(o.id!==t)throw new Error(`candidateCardContent.id must match cardId (${t})`);let i=null;try{i=await $({candidateCardContent:o});}catch(m){let C=m instanceof Error?m.message:String(m);if(!/non-core adapter is not configured/i.test(C))throw m;i=null;}if(i!==null){let m=n(i),C=n(m.data);if(m.status!=="success"||C.isValid!==true)return {status:"fail",step:"validate",validation:i}}let u=null;try{u=await T(p,t);}catch{u=null;}let l=u?n(u):null;if(l&&D(l)&&!r.allowControlplaneOnlyCards)throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404});let I={...o,...l&&he(l,"__private")?{__private:l.__private}:{}},v=await p.set({body:I});P(v,"cardStore.set");let _;try{_=await d.upsertCard({params:{cardId:t,restart:!0}}),P(_,"upsertCard");}catch(m){try{u&&await p.set({body:u});}catch{}throw m}return {status:"success",data:{validation:i,card_saved:null,board_result:_}}}async function le(e,r={}){let t=String(e.cardId||"").trim();if(!t)throw new Error("manageRemoveCard requires cardId");if(!r.allowControlplaneOnlyCards){let i=await A(p.get({params:{id:t}}),"cardStore.get");if((Array.isArray(i.cards)?i.cards.map(n):[]).some(D))throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404})}let a=await d.removeCard({params:{id:t}});P(a,"removeCard");let o=await p.del({params:{id:t}});return P(o,"cardStore.del"),{status:"success",data:{board_result:a,store_result:o}}}async function pe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await A(p.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(a=>n(a)):[]}async function me(e){let r=String(e.cardId||"").trim(),t=n(e.candidateCardContent),a=j(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof a.id!="string"||!a.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(a.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:a}),i=n(o),u=n(i.data);if(i.status!=="success"||u.isValid!==true)return {status:"fail",step:"validate",validation:o};let l=null;try{l=await T(p,r);}catch{l=null;}let I=l?n(n(l).__private):{},v={...a,__private:{...I,visible_controlplane_only:true}},_=await p.set({body:v});P(_,"cardStore.set");let m;try{m=await d.upsertCard({params:{cardId:r,restart:!0}}),P(m,"upsertCard");}catch(C){try{l&&await p.set({body:l});}catch{}throw C}return {status:"success",data:{validation:o,card_saved:null,board_result:m}}}async function fe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=G(await g.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}async function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return P(await g.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function Ce(){let e=await B(h,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function we(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let a=await B(R,"webhook.source-fetch-done")({token:r,ref:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let a=await B(b,"webhook.source-fetch-failed")({token:r,reason:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}return {listRuntimeCards:q,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:$,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:K,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:J,manageRemoveCard:le,adminReadCard:pe,adminUpsertCard:me,getChatProcessing:fe,setChatProcessing:ge,webhookProcessAccumulated:Ce,webhookSourceFetchDone:we,webhookSourceFetchFailed:ye}}async function A(s,d){return P(await s,d)}export{Ae as a};//# sourceMappingURL=chunk-XLHMUPBW.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-
|
|
1
|
+
import {a}from'./chunk-E46UCDYN.js';function P(s,d){if(s?.status==="success")return Object.prototype.hasOwnProperty.call(s,"data")?s.data:void 0;throw s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function G(s,d){if(s?.status==="success"&&Object.prototype.hasOwnProperty.call(s,"data"))return s.data;throw s?.status==="success"?new Error(`${d} returned success without data`):s?.status==="fail"||s?.status==="error"?new Error(s.error||`${d} failed`):new Error(`${d} returned an unexpected response`)}function n(s){return s&&typeof s=="object"&&!Array.isArray(s)?s:{}}function y(s){return Array.isArray(s)?s:[]}function N(s,d){if(typeof d!="string"||d.length===0)return;let c=s,p=d;p.startsWith("fetched_sources.")&&(c=n(s).fetched_sources,p=p.slice(16));for(let g of p.split(".")){if(c==null||typeof c!="object")return;c=c[g];}return c}function z(s,d){let c=n(s.view),p=y(c.elements);return {layout:c.layout,features:c.features,elements:p.map((g,h)=>{let R=n(g),b=n(R.data),k=typeof R.visible=="string"?!!N(d,R.visible):true,x=typeof b.bind=="string"?b.bind:void 0,S=typeof b.maxRows=="number"?b.maxRows:void 0,B=x?N(d,x):void 0,q={id:typeof R.id=="string"&&R.id?R.id:`element-${h}`,kind:R.kind,label:R.label,visible:k};return B!==void 0&&(q.resolved=Array.isArray(B)&&typeof S=="number"?B.slice(0,S):B),q})}}function Q(s,d){let c=typeof s.id=="string"&&s.id?s.id:"card",p=y(s.provides),g=p.length>0?p:[{bindTo:c,ref:"card_data"}],h={};for(let R of g){let b=n(R),k=typeof b.bindTo=="string"?b.bindTo:"",x=typeof b.ref=="string"?b.ref:"";if(!k||!x)continue;let S=N(d,x);S!==void 0&&(h[k]=S);}return h}function be(s){if(typeof s!="string"||!s.trim())return null;let d=/^(file uploaded|AI generated|AI geneterated):\s*.*?#(\d+)\s*$/i.exec(s.trim());if(!d)return null;let c=Number.parseInt(d[2],10);return !Number.isInteger(c)||c<0?null:c}function ke(s){return {"card-content":s}}function j(s){let d={...s};return delete d.__private,d}function he(s,d){return Object.prototype.hasOwnProperty.call(s,d)}function Re(s){return typeof structuredClone=="function"?structuredClone(s):JSON.parse(JSON.stringify(s))}function ve(s,d){let c=Re(s);if(!d||Object.keys(d).length===0)return c;function p(g,h,R){let b=String(h||"").split(".").filter(Boolean);if(!b.length)return;let k=g;for(let x=0;x<b.length-1;x+=1){let S=b[x];(!k[S]||typeof k[S]!="object")&&(k[S]={}),k=k[S];}k[b[b.length-1]]=R;}if(d.fieldValues!==void 0&&d.fieldValues!==null){let g=null,h=n(c.view),R=y(h.elements);for(let b of R){let k=n(n(b).data);if(typeof k.writeTo=="string"&&k.writeTo){g=k.writeTo;break}}return g?p(c,g,d.fieldValues):typeof d.fieldValues=="object"&&!Array.isArray(d.fieldValues)&&(c.card_data={...n(c.card_data),...d.fieldValues}),c}if(Array.isArray(d._stagedFiles)&&d._stagedFiles.length>0)return c;for(let[g,h]of Object.entries(d))g!=="_stagedFiles"&&(h!==null&&typeof h=="object"&&!Array.isArray(h)&&c[g]!==null&&typeof c[g]=="object"&&!Array.isArray(c[g])?c[g]={...c[g],...h}:c[g]=h);return c}function D(s){return n(s.__private).visible_controlplane_only===true}async function T(s,d){let c=await A(s.get({params:{id:d}}),"cardStore.get"),p=Array.isArray(c?.cards)?c.cards:[];if(p.length===0)throw new Error(`Card "${d}" not found`);return p[0]}function Ae(s){let{board:d,nonCore:c,cardStore:p,chatStore:g,processAccumulated:h,sourceFetchDone:R,sourceFetchFailed:b,uploadCardFile:k,buildFileDownloadUrl:x,readFetchedSourceJsonByRef:S}=s;function B(e,r){if(typeof e=="function")return e;throw new Error(`${r} is not configured for this MCP facade`)}async function q(){let e=await A(p.get({}),"cardStore.get");return Array.isArray(e.cards)?e.cards.map(r=>n(r)).filter(r=>!D(r)):[]}function X(e){if(Array.isArray(e.bytes))return new Uint8Array(e.bytes.map(r=>Math.max(0,Math.min(255,Number(r)||0))));if(typeof e.text=="string")return new TextEncoder().encode(e.text);if(typeof e.base64=="string"){let r=String(e.base64).replace(/-/g,"+").replace(/_/g,"/"),t=r+"=".repeat((4-r.length%4)%4),a=atob(t);return Uint8Array.from(a,o=>o.charCodeAt(0))}throw new Error("file entry requires bytes, text, or base64")}async function Y(){let e=n(await A(c.describeTaskExecutorCapabilities({}),"describeTaskExecutorCapabilities"));return {version:e.version,commonSourceFields:n(e.commonSourceDefFields),sourceKinds:n(e.sourceKinds)}}async function Z(){let e=n(await A(d.status({}),"status")),r=n(e.summary),t=y(e.cards),a=await A(p.get({}),"cardStore.get"),o=new Set((Array.isArray(a.cards)?a.cards.map(n):[]).filter(D).map(u=>typeof u.id=="string"?u.id:"").filter(Boolean)),i=t.filter(u=>!o.has(String(n(u).name??"")));return {meta:n(e.meta),summary:{card_count:typeof r.card_count=="number"?r.card_count:0,completed:typeof r.completed=="number"?r.completed:0,eligible:typeof r.eligible=="number"?r.eligible:0,pending:typeof r.pending=="number"?r.pending:0,blocked:typeof r.blocked=="number"?r.blocked:0,in_progress:typeof r.in_progress=="number"?r.in_progress:0,failed:typeof r.failed=="number"?r.failed:0,unresolved:typeof r.unresolved=="number"?r.unresolved:0},cards:i.map(u=>{let l=n(u);return {"card-id":typeof l.name=="string"?l.name:null,status:l.status??null,error:l.error??null,requires:y(l.requires),requires_satisfied:y(l.requires_satisfied),requires_missing:y(l.requires_missing),provides_declared:y(l.provides_declared),provides_runtime:y(l.provides_runtime)}})}}async function ee(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectCardDefinitionAndRuntime requires cardId");let t=n(await A(d.status({}),"status")),o=y(t.cards).map(n).find(f=>f.name===r);if(!o)throw new Error(`card "${r}" not found in board status`);let i=n(await T(p,r)),u=j(i),l=y(o.requires_satisfied).filter(f=>typeof f=="string"&&!!f),I=y(o.provides_runtime).filter(f=>typeof f=="string"&&!!f),v=Object.fromEntries(await Promise.all(l.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),_=Object.fromEntries(await Promise.all(I.map(async f=>[f,await A(d.getOutputsDataObject({params:{key:f}}),`getOutputsDataObject(${f})`)]))),m=n(await A(d.getOutputsComputedValues({params:{key:r}}),"getOutputsComputedValues")),C=await A(d.getOutputsFetchedSources({params:{key:r}}),"getOutputsFetchedSources"),M=y(i.source_defs).map(n),w={};for(let f of M)typeof f.bindTo=="string"&&typeof f.outputFile=="string"&&(w[f.outputFile]=f.bindTo);let U={};for(let[f,F]of Object.entries(C)){let O=w[f]??f;if(!S||typeof F!="string"){U[O]=null;continue}try{U[O]=S({cardId:r,ref:F});}catch{U[O]=null;}}let L={card_data:n(i.card_data),requires:v,fetched_sources:U,computed_values:m};return {cardId:r,card_status_in_board:o,card_definition_and_static_data:u,refs_for_fetched_source_files:C,runtime_data:{requires:v,provides:_,computed_values:m,rendered_view:z(i,L)}}}async function re(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("inspectChatMessagesOnCards requires cardId");let t=typeof e.turnId=="string"?e.turnId:"",a=e.allTurns===true,o=typeof e.tailTurnsBeforeId=="string"?e.tailTurnsBeforeId:"",i=a?void 0:e.lastUserTurns??(t?void 0:1),u=e.tail,l={...i===void 0?{}:{tailTurns:i},...t?{turnId:t}:{},...a?{allTurns:true}:{},...o?{tailTurnsBeforeId:o}:{}},I=Object.keys(l).length>0?{params:{cardId:r},body:l}:{params:{cardId:r}},v=P(await g.readAll(I),"chatStore.readAll"),_=n(await T(p,r)),m=y(n(_.card_data).files).map((w,U)=>({idx:U,stored_name:n(w).stored_name})).filter(w=>typeof w.stored_name=="string"&&w.stored_name.length>0),M=(Array.isArray(v.records)?v.records:[]).map(w=>{let L=n(w.payload),f={...w},F=typeof w?.role=="string"?w.role:typeof L.role=="string"?String(L.role):"",O=typeof w?.text=="string"?w.text:typeof L.text=="string"?String(L.text):"";if(F==="system"){let V=be(O);if(V!==null&&m.some(E=>E.idx===V)){let E=`Retrieve using inspect-file-contents --card-id ${r} --file-idx ${V}`;f.retrieval_hint=E,Object.keys(L).length>0&&typeof w.role!="string"&&(f.payload={...L,retrieval_hint:E});}}return f});return {cardId:r,messages:typeof u=="number"&&u>=0?M.slice(-u):M}}async function te(e){let r=String(e.cardId||"").trim(),t=Number(e.fileIdx);if(!r)throw new Error("inspectFileContents requires cardId");if(!Number.isInteger(t)||t<0)throw new Error("inspectFileContents requires fileIdx to be a non-negative integer");let a=n(await T(p,r)),o=y(n(a.card_data).files).map(n);if(t>=o.length)throw new Error(`attachment index ${t} is out of range for card "${r}"`);let i=o[t],u=typeof i.stored_name=="string"?i.stored_name:null;return {cardId:r,fileIdx:t,downloadUrl:x({cardId:r,fileIdx:t,storedName:u}),...typeof i.name=="string"?{name:i.name}:{},...typeof i.stored_name=="string"?{stored_name:i.stored_name}:{},...typeof i.mime_type=="string"?{mime_type:i.mime_type}:{},...typeof i.size=="number"?{size:i.size}:{},...typeof i.uploaded_at=="string"?{uploaded_at:i.uploaded_at}:{}}}async function $(e){return await c.validateCardPreflight({body:ke(e.candidateCardContent)})}function ne(e){if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightMaterializeCandidateCard requires mockRequires");if(!e.mockFetchedSources||typeof e.mockFetchedSources!="object"||Array.isArray(e.mockFetchedSources))throw new Error("preflightMaterializeCandidateCard requires mockFetchedSources");let r=c.evalCardCompute({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires,"mock-fetched-sources":e.mockFetchedSources}});if(r.status!=="success")return r;let t=n(G(r,"evalCardCompute")),a=n(e.candidateCardContent),o={card_data:n(a.card_data),requires:n(e.mockRequires),fetched_sources:n(e.mockFetchedSources),computed_values:n(t.computed_values)};return {status:"success",data:{cardId:typeof t.cardId=="string"?t.cardId:typeof a.id=="string"?a.id:"(unknown)",ok:t.ok===true,computed_values:n(t.computed_values),errors:y(t.errors).map(i=>{let u=n(i);return {bindTo:typeof u.bindTo=="string"?u.bindTo:"",error:typeof u.error=="string"?u.error:""}}),provides_outputs:Q(a,o),rendered_view:z(a,o)}}}async function ae(e){return await c.probeSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function oe(e){return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":e.candidateCardContent,"mock-projections":e.mockProjections}})}async function se(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("preflightRunSingleSourceInLiveCard requires cardId");if(!e.mockRequires||typeof e.mockRequires!="object"||Array.isArray(e.mockRequires))throw new Error("preflightRunSingleSourceInLiveCard requires mockRequires");let t=n(await T(p,r)),a$1=y(t.source_defs).filter(i=>!!i&&typeof i=="object"&&!Array.isArray(i)),o={};if(e.sourceIdx>=0&&e.sourceIdx<a$1.length){let i=a$1[e.sourceIdx],u=a.enrichSourcesSync([i],{card_data:n(t.card_data),requires:e.mockRequires});Array.isArray(u)&&u.length>0&&(o=n(u[0]._projections));}return await c.runSourcePreflight({params:{sourceIdx:e.sourceIdx},body:{"card-content":t,"mock-requires":e.mockRequires,"mock-projections":o}})}async function ie(e){let r=n(await A(c.simulateCardCycle({body:{"card-content":e.candidateCardContent,"mock-requires":e.mockRequires}}),"simulateCardCycle")),t=n(e.candidateCardContent),a=n(r.validation),o=y(r.source_probes),i=y(r.projection_errors),u=n(r.fetched_sources),l=y(r.compute_errors),I=n(r.computed_values),v={card_data:n(t.card_data),requires:e.mockRequires,fetched_sources:u,computed_values:I},_=[];for(let m of y(a.issues))typeof m=="string"&&m&&_.push(m);for(let m of o){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.error=="string"?C.error:"";w&&_.push(`${M}: ${w}`);}for(let m of i){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"source",w=typeof C.key=="string"?C.key:"projection",U=typeof C.error=="string"?C.error:"projection failed";_.push(`${M}.${w}: ${U}`);}for(let m of l){let C=n(m),M=typeof C.bindTo=="string"?C.bindTo:"compute",w=typeof C.error=="string"?C.error:"compute failed";_.push(`${M}: ${w}`);}return {status:"success",data:{cardId:typeof r.cardId=="string"?r.cardId:"(unknown)",ok:r.ok===true,issues:_,provides_outputs:Q(t,v),rendered_view:z(t,v)}}}async function K(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("manageReadCard requires cardId");let t=await A(p.get({params:{id:r}}),"cardStore.get");return (Array.isArray(t.cards)?t.cards.map(n):[]).map(o=>j(o))}async function W(e){let r=await Promise.all(y(e.files).map(async t=>{let a=n(t),o=String(a.file_name??a.fileName??a.name??"").trim(),i=String(a.content_type??a.contentType??"application/octet-stream");if(!o)throw new Error("file entry requires file_name");return await k({cardId:e.cardId,fileName:o,contentType:i,bytes:X(a),suppressChatRecordWrite:true})}));for(let[t,a]of r.entries()){let o=n(a.file),i=typeof a.file_idx=="number"&&Number.isInteger(a.file_idx)&&a.file_idx>=0?a.file_idx:t,u=e.role==="assistant"?`AI generated: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`:`file uploaded: ${String(o.name||"")} as ${String(o.stored_name||"")} #${i}`;P(await g.append({params:{cardId:e.cardId},body:{role:"system",text:u,files:[],turn:e.turn}}),"chatStore.append(system attachment message)");}return r.map(t=>t.file)}async function de(e){let r=String(e.cardId||"").trim(),t=String(e.role||"user").trim()||"user",a=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatAttachment requires cardId");let o=await W({cardId:r,role:t,turn:a,files:e.files});return {status:"success",data:{cardId:r,turn:a,files:o}}}async function ce(e){let r=String(e.cardId||"").trim(),t=String(e.role||"").trim(),a=typeof e.text=="string"?e.text:"",o=typeof e.turn=="string"?e.turn:"";if(!r)throw new Error("manageAddChatEntryAndAnyAttachments requires cardId");if(!t)throw new Error("manageAddChatEntryAndAnyAttachments requires role");if(t==="assistant"&&o){let l=P(await g.readAll({params:{cardId:r},body:{turnId:o}}),"chatStore.readAll(existing turn messages)"),I=Array.isArray(l.records)?l.records.find(v=>v.role==="assistant"&&String(v.turn||"")===o):void 0;if(I)return {status:"success",data:{cardId:r,id:String(I.id),role:t,turn:o,files:Array.isArray(I.files)?I.files:[]}}}let i=await W({cardId:r,role:t,turn:o,files:e.files}),u=P(await g.append({params:{cardId:r},body:{role:t,text:a,files:i,turn:o}}),"chatStore.append");return {status:"success",data:{cardId:r,id:String(u.id),role:t,turn:o,files:i}}}async function ue(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.patch);if(!t)throw new Error("managePatchCard requires cardId");let o=await K({cardId:t}),i=n(o[0]),u=ve(i,a);return J({cardId:t,candidateCardContent:u},r)}async function J(e,r={}){let t=String(e.cardId||"").trim(),a=n(e.candidateCardContent),o=j(a);if(!t)throw new Error("manageUpsertCard requires cardId");if(typeof o.id!="string"||!o.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(o.id!==t)throw new Error(`candidateCardContent.id must match cardId (${t})`);let i=null;try{i=await $({candidateCardContent:o});}catch(m){let C=m instanceof Error?m.message:String(m);if(!/non-core adapter is not configured/i.test(C))throw m;i=null;}if(i!==null){let m=n(i),C=n(m.data);if(m.status!=="success"||C.isValid!==true)return {status:"fail",step:"validate",validation:i}}let u=null;try{u=await T(p,t);}catch{u=null;}let l=u?n(u):null;if(l&&D(l)&&!r.allowControlplaneOnlyCards)throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404});let I={...o,...l&&he(l,"__private")?{__private:l.__private}:{}},v=await p.set({body:I});P(v,"cardStore.set");let _;try{_=await d.upsertCard({params:{cardId:t,restart:!0}}),P(_,"upsertCard");}catch(m){try{u&&await p.set({body:u});}catch{}throw m}return {status:"success",data:{validation:i,card_saved:null,board_result:_}}}async function le(e,r={}){let t=String(e.cardId||"").trim();if(!t)throw new Error("manageRemoveCard requires cardId");if(!r.allowControlplaneOnlyCards){let i=await A(p.get({params:{id:t}}),"cardStore.get");if((Array.isArray(i.cards)?i.cards.map(n):[]).some(D))throw Object.assign(new Error(`Card "${t}" not found`),{statusCode:404})}let a=await d.removeCard({params:{id:t}});P(a,"removeCard");let o=await p.del({params:{id:t}});return P(o,"cardStore.del"),{status:"success",data:{board_result:a,store_result:o}}}async function pe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("adminReadCard requires cardId");let t=await A(p.get({params:{id:r}}),"cardStore.get");return Array.isArray(t.cards)?t.cards.map(a=>n(a)):[]}async function me(e){let r=String(e.cardId||"").trim(),t=n(e.candidateCardContent),a=j(t);if(!r)throw new Error("adminUpsertCard requires cardId");if(typeof a.id!="string"||!a.id.trim())throw new Error("candidateCardContent.id must be a non-empty string");if(a.id!==r)throw new Error(`candidateCardContent.id must match cardId (${r})`);let o=await $({candidateCardContent:a}),i=n(o),u=n(i.data);if(i.status!=="success"||u.isValid!==true)return {status:"fail",step:"validate",validation:o};let l=null;try{l=await T(p,r);}catch{l=null;}let I=l?n(n(l).__private):{},v={...a,__private:{...I,visible_controlplane_only:true}},_=await p.set({body:v});P(_,"cardStore.set");let m;try{m=await d.upsertCard({params:{cardId:r,restart:!0}}),P(m,"upsertCard");}catch(C){try{l&&await p.set({body:l});}catch{}throw C}return {status:"success",data:{validation:o,card_saved:null,board_result:m}}}async function fe(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("getChatProcessing requires cardId");let t=G(await g.isProcessing({params:{cardId:r}}),"chatStore.isProcessing");return {cardId:r,active:!!t.active}}async function ge(e){let r=String(e.cardId||"").trim();if(!r)throw new Error("setChatProcessing requires cardId");if(typeof e.active!="boolean")throw new Error("setChatProcessing requires boolean active");return P(await g.setProcessing({params:{cardId:r},body:{active:e.active}}),"chatStore.setProcessing"),{cardId:r,active:e.active}}async function Ce(){let e=await B(h,"webhook.process-accumulated")();return e?.status==="fail"||e?.status==="error"?e:{status:"success",data:{runtime_result:Object.prototype.hasOwnProperty.call(e??{},"data")?e.data??null:null}}}async function we(e){let r=String(e.token||"").trim(),t=String(e.ref||"").trim();if(!r)throw new Error("webhookSourceFetchDone requires token");if(!t)throw new Error("webhookSourceFetchDone requires ref");let a=await B(R,"webhook.source-fetch-done")({token:r,ref:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,ref:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}async function ye(e){let r=String(e.token||"").trim(),t=String(e.reason||"").trim();if(!r)throw new Error("webhookSourceFetchFailed requires token");if(!t)throw new Error("webhookSourceFetchFailed requires reason");let a=await B(b,"webhook.source-fetch-failed")({token:r,reason:t});return a?.status==="fail"||a?.status==="error"?a:{status:"success",data:{token:r,reason:t,runtime_result:Object.prototype.hasOwnProperty.call(a??{},"data")?a.data??null:null}}}return {listRuntimeCards:q,discoverSourceKinds:Y,inspectBoardRuntimeStatus:Z,inspectCardDefinitionAndRuntime:ee,inspectChatMessagesOnCards:re,inspectFileContents:te,preflightValidateCandidateCardDefinition:$,preflightMaterializeCandidateCard:ne,preflightProbeSingleSourceInCandidateCard:ae,preflightRunSingleSourceInCandidateCard:oe,preflightRunSingleSourceInLiveCard:se,preflightRunOneCycleWithCandidateCard:ie,manageReadCard:K,manageAddChatAttachment:de,manageAddChatEntryAndAnyAttachments:ce,managePatchCard:ue,manageUpsertCard:J,manageRemoveCard:le,adminReadCard:pe,adminUpsertCard:me,getChatProcessing:fe,setChatProcessing:ge,webhookProcessAccumulated:Ce,webhookSourceFetchDone:we,webhookSourceFetchFailed:ye}}async function A(s,d){return P(await s,d)}export{Ae as a};//# sourceMappingURL=chunk-RWAEV253.js.map
|
|
2
|
+
//# sourceMappingURL=chunk-RWAEV253.js.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
'use strict';var module$1=require('module');var _documentCurrentScript=typeof document!=='undefined'?document.currentScript:null;var y=module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('chunk-UG55PF75.cjs', document.baseURI).href))),u=y("./jsonata-sync.cjs"),p=u;function c(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 g(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=p(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 b(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 _(t,r){return r.startsWith("fetched_sources.")?c(t._sourcesData??{},r.slice(16)):c(t,r)}var d=new Set(["metric","table","editable-table","chart","form","filter","list","notes","todo","alert","narrative","badge","text","markdown","ref","custom","actions"]),v=new Set(["id","meta","requires","provides","view","card_data","compute","source_defs"]);function h(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))v.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`):d.has(n.kind)||r.push(`view.elements[${o}].kind: unknown kind "${n.kind}". Valid: ${[...d].join(", ")}`),n.data!=null&&(typeof n.data!="object"||Array.isArray(n.data))&&r.push(`view.elements[${o}].data: must be an object`);}),e.layout!=null&&(typeof e.layout!="object"||Array.isArray(e.layout))&&r.push("view.layout: must be an object"),e.features!=null&&(typeof e.features!="object"||Array.isArray(e.features))&&r.push("view.features: must be an object");}return {ok:r.length===0,errors:r}}async function k(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={};if(e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[o,a]of Object.entries(e.projections))if(typeof a=="string"&&a.trim().length>0)try{n[o]=await u(a).evaluate(s);}catch{n[o]=void 0;}}return {...e,_projections:n}}))}function w(t,r){if(!t||t.length===0)return [];let s={card_data:r.card_data??{},requires:r.requires??{}};return t.map(e=>{let n={};if(e.projections&&typeof e.projections=="object"&&!Array.isArray(e.projections)){for(let[o,a]of Object.entries(e.projections))if(typeof a=="string"&&a.trim().length>0)try{n[o]=p(a).evaluate(s);}catch{n[o]=void 0;}}return {...e,_projections:n}})}var j={run:m,runSync:g,eval:b,resolve:_,validate:h,enrichSources:k,enrichSourcesSync:w},$=j;exports.a=j;exports.b=$;//# sourceMappingURL=chunk-UG55PF75.cjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-UG55PF75.cjs.map
|