yaml-flow 8.9.1 → 8.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/browser/asset-integrity.json +5 -5
- package/browser/live-cards.js +15 -15
- package/browser/live-cards.schema.json +36 -59
- package/browser/server-runtime-controlface.js +4 -4
- package/examples/board/cards/card-concentration.json +64 -16
- package/examples/board/cards/card-my-identity.json +1 -4
- package/examples/board/cards/card-portfolio-intelligence.json +1 -5
- package/examples/board/cards/card-rebalance-sim.json +1 -4
- package/examples/board/cards/cardT-market-prices.json +1 -4
- package/examples/board/cards/cardT-portfolio-value.json +35 -10
- package/examples/board/cards/cardT-portfolio.json +1 -4
- package/lib/board-live-cards-mcp.cjs +1 -1
- package/lib/board-live-cards-mcp.d.cts +0 -2
- package/lib/board-live-cards-mcp.d.ts +0 -2
- 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-2LGCYN35.js +2 -0
- package/lib/chunk-5U5NMYGT.js +3 -0
- package/lib/chunk-6M3RIGUH.js +2 -0
- package/lib/chunk-ATOQP3BD.js +2 -0
- package/lib/{chunk-INRLKWC2.cjs → chunk-BDT43KYE.cjs} +3 -3
- package/lib/chunk-CPJXGK2T.cjs +2 -0
- package/lib/{chunk-7KSENEPK.js → chunk-CZ6ZFWFT.js} +2 -2
- package/lib/{chunk-XQAHHUZO.cjs → chunk-FFHG3CFU.cjs} +2 -2
- package/lib/chunk-GHUW6P4G.cjs +2 -0
- package/lib/chunk-H5FKNSCO.js +3 -0
- package/lib/{chunk-OPNGCSXJ.js → chunk-MEL5LKF7.js} +2 -2
- package/lib/{chunk-HDGEWOC2.cjs → chunk-NMOUBZXX.cjs} +2 -2
- package/lib/{chunk-JAL25FGA.cjs → chunk-O65MSWUE.cjs} +2 -2
- package/lib/{chunk-IXZG74EW.cjs → chunk-QBEQL4TL.cjs} +2 -2
- package/lib/chunk-QEHKMLHA.cjs +3 -0
- package/lib/chunk-VNLMJEIX.cjs +3 -0
- package/lib/{chunk-32GZ4ODA.js → chunk-WQANIJAQ.js} +3 -3
- package/lib/chunk-X5CZE2L7.cjs +3 -0
- package/lib/chunk-YT76JNKE.js +3 -0
- package/lib/{chunk-4HIEOBJC.js → chunk-ZCU5O2LR.js} +2 -2
- 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 +36 -59
- package/lib/chunk-3KC6LBOG.js +0 -3
- package/lib/chunk-FO4KNVU7.cjs +0 -2
- package/lib/chunk-HWYMZK3N.cjs +0 -3
- package/lib/chunk-JMDHDY6M.js +0 -2
- package/lib/chunk-ORBKEBNX.cjs +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-XLHMUPBW.js +0 -2
- package/lib/chunk-YBYXCFAI.js +0 -2
package/lib/chunk-VS4E7QFN.js
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import {b as b$1,c as c$1}from'./chunk-ANKA7HEJ.js';import {a,b,c}from'./chunk-44L64VQ2.js';import {r,a as a$1,p,q,u}from'./chunk-VGT3TRQG.js';import {a as a$3}from'./chunk-JMDHDY6M.js';import {a as a$2}from'./chunk-7QNEV5S3.js';import {e,f}from'./chunk-UGB7PC4P.js';function lt(e){return typeof e=="string"&&e.trim().length>0}function ft(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.selfRef is required`);if(!lt(e.howToRun))throw new Error(`${t}: adapter.selfRef.howToRun is required`);if(!lt(e.whatToRun))throw new Error(`${t}: adapter.selfRef.whatToRun is required`)}function mt(e,t){if(!e||typeof e!="object")throw new Error(`${t}: adapter.callbackTransport is required`);if(typeof e.createCallback!="function")throw new Error(`${t}: adapter.callbackTransport.createCallback is required`)}function Xt(e,t="callbackTransport"){return {createCallback(n){let a=e();return ft(a,t),{token:n,via:a}}}}function $e(e){return Xt(()=>e,"createStaticExecutionRefCallbackTransport")}function mr(e){return $e({meta:"board-live-cards",howToRun:"http:post",whatToRun:a({kind:"http-url",value:String(e||"").trim()})})}function pr(e){return $e({meta:"board-live-cards",howToRun:"in-process-loop",whatToRun:a({kind:"in-process-loop",value:String(e||"").trim()})})}function gr(e){let t=typeof e=="string"?{notifyChannel:e}:e??{},n={};return t.notifyChannel&&(n.notifyChannel=t.notifyChannel),t.boardRuntimeStoreRef&&(n.boardRuntimeStoreRef=t.boardRuntimeStoreRef),t.queueStoreRef&&(n.queueStoreRef=t.queueStoreRef),$e({meta:"board-live-cards",howToRun:"built-in",whatToRun:a({kind:"built-in",value:"board-live-cards"}),...Object.keys(n).length>0?{extra:n}:{}})}function Ie(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function Je(e,t){return Ie(e)?e.then(t):t(e)}function gt(e,t){let n={...e};for(let a of t.deleteKeys)delete n[a];return {...n,...t.shallowMerge}}function kr(e,t){return {readValues(a){let s=e(a);return Je(s.listKeys(),d=>{let u=[...d].sort();if(u.length===0)return {version:null,values:{}};let c={},y=null;for(let C of u){let j=s.read(C);Ie(j)?y=(y??Promise.resolve()).then(async()=>{c[C]=await j;}):c[C]=j;}return y?y.then(()=>({version:t(c),values:c})):{version:t(c),values:c}})},writeValues(a,s,d){let u=e(a),c=null;for(let y of d){let C=u.delete(y);Ie(C)&&(c=(c??Promise.resolve()).then(()=>C).then(()=>{}));}for(let[y,C]of Object.entries(s)){let j=u.write(y,C);Ie(j)&&(c=(c??Promise.resolve()).then(()=>j).then(()=>{}));}return c?c.then(()=>t(s)):t(s)}}}function St(e,t){return {readSnapshot(n){return e.readValues(n)},commitSnapshot(n,a){if(a.schemaVersion!==t)throw new Error(`Unsupported snapshot schema version: ${a.schemaVersion}`);return Je(e.readValues(n),s=>{if(s.version!==a.expectedVersion)return {ok:false,reason:"version-mismatch",currentVersion:s.version};let d=gt(s.values,a);return Je(e.writeValues(n,d,a.deleteKeys),u=>({ok:true,newVersion:u}))})}}}function pt(e,t){if(!t)return e;let n=e.findIndex(a=>a.id===t);return n===-1?e:e.slice(n+1)}function kt(e){return {readEntriesAfterCursor(t){let n=pt(e.readAllEntries(),t);return n.length===0?{events:[],newCursor:t}:{events:n.map(a=>a.event),newCursor:n[n.length-1].id}},pendingCount(t){return pt(e.readAllEntries(),t).length},appendEvent(t){e.appendEntry({id:e.generateId(),event:t});}}}function Rr(e){return {appendEvent(t){return e.append(t).then(()=>{})},async readEntriesAfterCursor(t){let n=await e.readAfter(t||null);return {events:n.entries.map(a=>a.payload),newCursor:n.newCursor??t}}}}function Fe(e){return typeof e=="object"&&e!==null&&"then"in e&&typeof e.then=="function"}function ue(e,t){return Fe(e)?e.then(t):t(e)}function Me(e,t){let n=null;for(let a of e){if(n){n=n.then(()=>t(a)).then(()=>{});continue}let s=t(a);Fe(s)&&(n=Promise.resolve(s).then(()=>{}));}return n??void 0}function Wt(e){if(e==null)return null;let t=e.trim();if(!t)return null;try{return JSON.parse(t)}catch{return t}}function Zt(e,t){let n=e.match(t);return n?n[1]:null}function Rt(e,t,n){let a={},s=Me(e,d=>{let u=n(d);if(u)return ue(t(d),c=>{a[u]=c;})});return Fe(s)?s.then(()=>a):a}function ht(e,t){return {readSourceData(n,a){return ue(e.read(`${n}/${a}`),Wt)},ingestSourceDataStaged(n,a,s,d){return ue(t(s),u=>e.write(`${n}/.staged/${d}/${a}`,u))},commitSourceData(n,a,s){let d=`${n}/.staged/${s}/${a}`,u=`${n}/${a}`;return e.renameKey(d,u)},hasSource(n,a){return e.exists(`${n}/${a}`)},listSources(n){return ue(e.listKeys(`${n}/`),a=>a.filter(s=>!s.includes("/.staged/")).map(s=>s.slice(`${n}/`.length)))}}}function er(e,t){let n=(a,s)=>{try{let d=s(a);return Fe(d)?d.catch(u=>t(a,u instanceof Error?u.message:String(u))):void 0}catch(d){try{return t(a,d instanceof Error?d.message:String(d))}catch{return}}};return {appendEntries(a,s){if(!(!a||s.length===0))return ue(e.read(a),d=>e.write(a,[...d??[],...s]))},dispatchEntriesForJournalId(a,s){if(a)return ue(e.read(a),d=>{let u=d;if(!(!u||u.length===0))return ue(Me(u,c=>n(c,s)),()=>e.delete(a))})}}}function tr(e,t,n){return {readRuntime(a){return ue(e.read(t(a)),s=>s??n())},writeRuntime(a,s){return e.write(t(a),s)}}}function yt(e){return {writeComputedValues(t,n){return e.write(`cards/${t}/computed_values`,n)},readComputedValues(t){return e.read(`cards/${t}/computed_values`)},readAllComputedValues(){return ue(e.listKeys("cards/"),t=>Rt(t,n=>e.read(n),n=>Zt(n,/^cards\/([^/]+)\/computed_values$/)))},writeDataObjects(t){return Me(Object.entries(t),([n,a])=>{if(n)return a===void 0?e.delete(`data-objects/${n}`):e.write(`data-objects/${n}`,a)})},readDataObject(t){return e.read(`data-objects/${t}`)},readAllDataObjects(){return ue(e.listKeys("data-objects/"),t=>Rt(t,n=>e.read(n),n=>n.slice(13)))},writeStatusSnapshot(t){return e.write("status",t)},readStatusSnapshot(){return e.read("status")}}}function He(e,t){function n(){return e.readIndex()??{}}function a(s,d,u){let c=String(d||"").split(".").filter(Boolean);if(c.length===0)return u&&typeof u=="object"&&!Array.isArray(u)?u:{value:u};let y={...s},C=y;for(let j=0;j<c.length-1;j++){let Y=c[j],X=C[Y],te=X&&typeof X=="object"&&!Array.isArray(X)?{...X}:{};C[Y]=te,C=te;}return C[c[c.length-1]]=u,y}return {readCard(s){let d=n()[s];return !d||!e.cardExists(d.key)?null:e.readCard(d.key)},readCardKey(s){return n()[s]?.key??null},readAllCards(){let s=[];for(let[d,u]of Object.entries(n())){if(!e.cardExists(u.key))continue;let c=e.readCard(u.key);c?s.push(c):t?.(`[card-store] could not read card "${d}" at key "${u.key}"`);}return s},readChecksumIndex(){let s={};for(let[d,u]of Object.entries(n()))s[d]=u.checksum;return s},changedSince(s){let d=n(),u=[];for(let[c,y]of Object.entries(d))s[c]!==y.checksum&&u.push(c);for(let c of Object.keys(s))d[c]||u.push(c);return u},validateUpsert(s,d){let u=n(),c=u[s],y=Object.entries(u).find(([,C])=>C.key===d);return c&&c.key!==d?{ok:false,error:`Card id "${s}" is already mapped to key "${c.key}", cannot remap to "${d}"`}:y&&y[0]!==s?{ok:false,error:`Key "${d}" is already mapped to card id "${y[0]}", cannot remap to "${s}"`}:{ok:true}},writeCard(s,d,u){let c=n(),y=u??c[s]?.key??e.defaultCardKey(s),C=e.writeCard(y,d);c[s]={key:y,checksum:C,updatedAt:new Date().toISOString()},e.writeIndex(c);},patchCard(s,d,u){let c=n(),y=c[s];if(!y||!e.cardExists(y.key))throw new Error(`card "${s}" not found`);let C=e.readCard(y.key);if(!C||typeof C!="object"||Array.isArray(C))throw new Error(`card "${s}" is not patchable`);let j=a(C,d,u),Y=e.writeCard(y.key,j);c[s]={key:y.key,checksum:Y,updatedAt:new Date().toISOString()},e.writeIndex(c);},removeCard(s){let d=n(),u=d[s];u&&(e.removeCard(u.key),delete d[s],e.writeIndex(d));},readIndex(){return n()}}}function _e(e,t){return ht(e,t)}function vt(e){return kt(e)}var Oe="v1",Re="board/graph",xt="board/lastJournalProcessedId";function Tr(e){return `cards/${e}/runtime`}function Et(e){return St(e,Oe)}function Pe(e){function t(n){let a=e.read(n);return a==null?null:typeof a=="string"?a:JSON.stringify(a)}return {readTaskExecutorRef(){let n=t("task-executor");if(n?.trim())return c$1(n.trim())},writeTaskExecutorRef(n){e.write("task-executor",b$1(n));},readChatHandlerFlow(){return e.read("chat-handler-flow")},writeChatHandlerFlow(n){e.write("chat-handler-flow",n);},readBoardRuntimeStoreRef(){return t("board-runtime-store-ref")},writeBoardRuntimeStoreRef(n){e.write("board-runtime-store-ref",n);},readCardStoreRef(){return t("card-store-ref")},writeCardStoreRef(n){e.write("card-store-ref",n);},readOutputsStoreRef(){return t("outputs-store-ref")},writeOutputsStoreRef(n){e.write("outputs-store-ref",n);},readQueueStoreRef(){return t("queue-store-ref")},writeQueueStoreRef(n){e.write("queue-store-ref",n);},readScratchStoreRef(){return t("scratch-store-ref")},writeScratchStoreRef(n){e.write("scratch-store-ref",n);},readChatStoreRef(){return t("chat-store-ref")},writeChatStoreRef(n){e.write("chat-store-ref",n);},readArtifactsStoreRef(){return t("artifacts-store-ref")},writeArtifactsStoreRef(n){e.write("artifacts-store-ref",n);},readFetchedSourcesStoreRef(){return t("fetched-sources-store-ref")},writeFetchedSourcesStoreRef(n){e.write("fetched-sources-store-ref",n);}}}function Tt(e){return yt(e)}function Ct(e){return e?{lastRequestedToken:e.lastRequestedToken,lastCompletedToken:e.lastCompletedToken,lastCompletionStatus:e.lastCompletionStatus??(e.lastCompletedToken?"success":"not-started"),queueRequestedToken:e.queueRequestedToken}:{lastCompletionStatus:"not-started"}}function rr(e){return e?.lastRequestedToken?e.lastCompletedToken!==e.lastRequestedToken:false}function bt(e,t){return e?.lastRequestedToken?rr(e)?"in-flight":!e.lastCompletedToken||e.lastCompletedToken<t?"dispatch":"idle":"dispatch"}function nr(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"success"}}function wt(e,t){return {...e,lastCompletedToken:t,lastCompletionStatus:"failure"}}function Be(e,t){let n=t.state.tasks,a=t.config.tasks,s=Object.keys(n),d=r(t),u={completed:0,failed:0,in_progress:0,pending:0,blocked:0,unresolved:0},c=new Map;for(let T of d.pending)c.set(T.taskName,T.waitingOn);for(let T of d.unresolved)c.set(T.taskName,T.missingTokens);for(let T of d.blocked)c.set(T.taskName,T.failedTokens);let y=new Map;for(let[T,S]of Object.entries(a))for(let U of S.requires??[]){let M=y.get(U)??[];M.push(T),y.set(U,M);}let C=s.sort().map(T=>{let S=n[T],U=a[T]??{requires:[],provides:[]};S.status==="completed"?u.completed+=1:S.status==="failed"?u.failed+=1:S.status==="in-progress"&&(u.in_progress+=1);let M=U.requires??[],g=U.provides??[],i=Object.keys(S.data??{}).sort(),m=M.filter(P=>t.state.availableOutputs.includes(P)),v=M.filter(P=>!t.state.availableOutputs.includes(P)),I=c.get(T)??v,x=new Set;for(let P of g)for(let N of y.get(P)??[])N!==T&&x.add(N);let E=S.failedAt,K=S.error?{message:S.error,code:"TASK_FAILED",at:E,source:"task-runtime"}:void 0;return {name:T,status:S.status,error:K,requires:M,requires_satisfied:m,requires_missing:v,provides_declared:g,provides_runtime:i,blocked_by:I,unblocks:Array.from(x).sort(),runtime:{attempt_count:S.executionCount??0,restart_count:S.retryCount??0,in_progress_since:S.status==="in-progress"?S.startedAt??null:null,last_transition_at:S.lastUpdated??null,last_completed_at:S.completedAt??null,last_restarted_at:S.startedAt??null,status_age_ms:S.lastUpdated?0:null}}});u.pending=d.pending.length,u.blocked=d.blocked.length,u.unresolved=d.unresolved.length;let j=C.map(T=>({name:T.name,fanOut:T.unblocks.length})).sort((T,S)=>S.fanOut-T.fanOut||T.name.localeCompare(S.name)),Y=j.length>0?j[0]:{name:null,fanOut:0},X=new Set;for(let T of Object.values(a))for(let S of T.requires??[])X.add(S);let te=0;for(let[T,S]of Object.entries(a)){let U=(S.requires??[]).length===0,g=(S.provides??[]).some(i=>(y.get(i)??[]).some(m=>m!==T));U&&!g&&(te+=1);}return {schema_version:"v1",meta:{board:{path:e}},summary:{card_count:s.length,completed:u.completed,eligible:d.eligible.length,pending:u.pending,blocked:u.blocked,unresolved:u.unresolved,failed:u.failed,in_progress:u.in_progress,orphan_cards:te,topology:{edge_count:Array.from(X).length,max_fan_out_card:Y.name,max_fan_out:Y.fanOut}},cards:C}}function or(){return new Date().toISOString()}function At(e,t,n,a$1,s,d,u){return async c=>{let y=[],C=n.cardStore.readCard(c.nodeId);if(!C)return "task-initiate-failure";let j=C.id,Y=C.card_data??{},X=C.source_defs??[],te=X.filter(h=>h.optionalForCompletionGating!==true),T=n.cardRuntimeStore.readRuntime(j),S=false,U=()=>{S&&(n.cardRuntimeStore.writeRuntime(j,T),S=false);},M=h=>Ct(T._sources[h]),g=(h,b)=>{T._sources[h]=Ct(b),S=true;},i=c.taskState?.executionCount??0;if(T._lastExecutionCount!==i&&(T._sources={},T._lastExecutionCount=i,S=true),c.update){let h=c.update,b=h.outputFile;if(b){let B=M(b);if(h.failure){let G=h.rqt??B.lastRequestedToken??B.queueRequestedToken;G&&g(b,wt(B,G));}else {let G=h.rqt;if(!B.lastCompletedToken||G>B.lastCompletedToken){let q=typeof h.deliveryToken=="string"?h.deliveryToken:void 0,Q=false;q&&(Q=n.fetchedSourcesStore.commitSourceData(j,b,q)),Q?g(b,nr(B,G)):g(b,wt(B,G));}}U();}}let v={};for(let h of X)if(h.outputFile){let b=n.fetchedSourcesStore.readSourceData(j,h.outputFile);b!==null&&(v[h.bindTo]=b);}let I={};for(let[h,b]of Object.entries(c.state??{}))if(b!==null&&typeof b=="object"&&!Array.isArray(b)){let B=b[h];I[h]=B!==void 0?B:b;}else I[h]=b;let x={id:j,card_data:{...Y},requires:I,source_defs:X,compute:C.compute};x._sourcesData=v,C.compute&&a$3.runSync(x,{sourcesData:v}),(d??n.outputStore.writeComputedValues.bind(n.outputStore))(j,x.computed_values??{});let E={...C},K=a$3.enrichSourcesSync(Array.isArray(C.source_defs)?C.source_defs:void 0,{card_data:C.card_data,requires:I}),P=e.value;E.source_defs=Array.isArray(K)?K.map(h=>({...h,boardDir:typeof h.boardDir=="string"&&h.boardDir?h.boardDir:P})):K;let N=or(),H=c.update?void 0:N,re=te.filter(h=>{let b=h.outputFile;if(typeof b!="string"||!b)return true;let B=M(b);H&&(B={...B,queueRequestedToken:H},g(b,B));let G=B.queueRequestedToken??B.lastRequestedToken??N,q=bt(B,G);return q==="in-flight"?false:q==="dispatch"});if(U(),re.length>0){let h=false,b=N;for(let B of re){let G=B.outputFile;if(typeof G!="string"||!G)continue;let q=M(G),Q=q.queueRequestedToken??N;g(G,{...q,lastRequestedToken:Q}),b=Q,h=true;}return h&&U(),h&&(y.push({taskKind:"source-fetch",payload:{boardRef:a(e),enrichedCard:E,callbackToken:c.callbackToken,rqt:b}}),n.executionRequestStore.appendEntries(t,y)),"task-initiated"}if(te.some(h=>{let b=h.outputFile;if(typeof b!="string"||!b)return false;let B=M(b),G=B.queueRequestedToken??B.lastRequestedToken??N;return bt(B,G)==="in-flight"}))return "task-initiated";let me=C.provides??[],se={};for(let{bindTo:h,ref:b}of me)se[h]=a$3.resolve(x,b);return (u??n.outputStore.writeDataObjects.bind(n.outputStore))(se),X.filter(h=>{if(h.optionalForCompletionGating!==true)return false;let b=M(h.outputFile);return !b.lastRequestedToken||!b.lastCompletedToken?true:b.lastCompletedToken<=b.lastRequestedToken}).length>0&&y.push({taskKind:"source-fetch",payload:{boardRef:a(e),enrichedCard:E,callbackToken:c.callbackToken,rqt:N}}),a$1(c.nodeId,se),y.length>0&&n.executionRequestStore.appendEntries(t,y),"task-initiated"}}var Ge={settings:{completion:"manual",refreshStrategy:"data-changed"},tasks:{}};function It(e){return {[Re]:e.graph,[xt]:e.lastDrainedJournalId,board:{runtimeByCardId:e.runtimeByCardId}}}function Ft(e){let t=e[Re],n=e[xt],s=e.board?.runtimeByCardId;if(!t||typeof t!="object")throw new Error(`State snapshot is missing required key: ${Re}`);return {graph:t,lastDrainedJournalId:typeof n=="string"?n:"",runtimeByCardId:s&&typeof s=="object"?s:{}}}function _t(e){let t=e.requires;return {provides:e.provides?.map(a=>a.bindTo)??[],taskHandlers:["card-handler"],description:e.meta?.title??e.id,...t&&t.length>0?{requires:t}:{}}}function A(e){return e!==void 0?{status:"success",data:e}:{status:"success"}}function R(e){return {status:"fail",error:e}}function _(e){return {status:"error",error:e instanceof Error?e.message:String(e)}}function sr(e){let t=new TextEncoder().encode(e),n=Array.from(t,a=>String.fromCharCode(a)).join("");return btoa(n).replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Bt(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),n=t+"=".repeat((4-t.length%4)%4),a=atob(n),s=Uint8Array.from(a,d=>d.charCodeAt(0));return new TextDecoder().decode(s)}function qe(e){try{let t=JSON.parse(Bt(e));return typeof t?.t=="string"?{taskName:t.t}:null}catch{return null}}function Ot(e){return sr(JSON.stringify(e))}function Pt(e){try{let t=JSON.parse(Bt(e));return typeof t?.cbk=="string"&&typeof t?.cid=="string"&&typeof t?.b=="string"&&typeof t?.d=="string"?t:null}catch{return null}}function ee(){return new Date().toISOString()}function ar(e){let t=new Map;return {appendEntries(n,a){if(!n||a.length===0)return;let s=t.get(n)??[];t.set(n,[...s,...a]);},dispatchEntriesForJournalId(n,a){if(!n)return;let s=t.get(n);if(!(!s||s.length===0)){for(let d of s)try{a(d);}catch(u){try{e(d,u instanceof Error?u.message:String(u));}catch{}}t.delete(n);}}}}function jr(e$1,t,n={}){mt(t.callbackTransport,"createBoardLiveCardsPublic");let a$3=t.callbackTransport,s=t.onWarn??(()=>{}),d=a(e$1),u$1=n.boardRuntimeStoreRef,c$1=n.scratchStoreRef,y=n.taskExecutorRef,C=n.chatHandlerFlow,j=n.emitNotification??(o=>{if(!t.publishBoardChangeNotifications)return;let r=o.kind==="notification-batch"?o.notifications:[o];return t.publishBoardChangeNotifications(r)});function Y(){if(!u$1)throw new Error(`Board at ${e$1.value} has no board runtime store configured. Pass boardRuntimeStoreRef at construction or init.`);return u$1}function X(o){if(o.length!==0)try{let r=e(o),l=f({kind:"notification-batch",notifications:r}),p=j(l);p&&typeof p.catch=="function"&&p.catch(w=>s(`[board-live-cards-public] emitNotification failed: ${w instanceof Error?w.message:String(w)}`));}catch(r){s(`[board-live-cards-public] emitNotification failed: ${r instanceof Error?r.message:String(r)}`);}}function te(){let o=S().readCardStoreRef();if(!o)throw new Error(`Board at ${e$1.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let r=t.kvStorageForRef(o);return {readIndex(){return r.read("_index")},writeIndex(l){r.write("_index",l);},readCard(l){return r.read(l)},writeCard(l,p){return r.write(l,p),t.hashFn(p)},removeCard(l){r.delete(l);},cardExists(l){return r.read(l)!==null},defaultCardKey(l){return l}}}let T={readValues(o){let r=t.kvStorageForRef(Y()),l=r.listKeys().sort();if(l.length===0)return {version:null,values:{}};let p={};for(let w of l)p[w]=r.read(w);return {version:t.hashFn(p),values:p}},writeValues(o,r,l){let p=t.kvStorageForRef(Y());for(let w of l)p.delete(w);for(let[w,F]of Object.entries(r))p.write(w,F);return t.hashFn(r)}},S=()=>Pe(t.kvStorageForRef(Y())),U=()=>Et(T),M=()=>vt(t.journalAdapterForRef(Y())),g=()=>He(te(),s),i=()=>{let o=S().readOutputsStoreRef();if(!o)throw new Error(`Board at ${e$1.value} has no outputs store configured. Run: init --outputs-store-ref <b64-ref>`);return Tt(t.kvStorageForRef(o))};function m(){return y??S().readTaskExecutorRef()}function v(){return !!U().readSnapshot(e$1.value).values[Re]}function I(){let o=U().readSnapshot(e$1.value);if(!o.values[Re])throw new Error(`Board not initialized at ${e$1.value}`);return Ft(o.values)}function x(o,r){let l=U().commitSnapshot(e$1.value,{schemaVersion:Oe,expectedVersion:r,commitId:t.genId(),committedAt:ee(),deleteKeys:[],shallowMerge:It(o)});if(!l.ok)throw new Error(`Snapshot commit failed (version mismatch): expected=${r??"null"} current=${l.currentVersion??"null"}`)}function E(o){M().appendEvent(o);}async function K(){let r=ar((f,k)=>{let O=f.payload,D=(O?.enrichedCard??{}).id??O?.cardId??"unknown";E({type:"task-failed",taskName:D,error:k,timestamp:ee()});}),l=I(),p$1=q(l.graph),{events:w,newCursor:F}=M().readEntriesAfterCursor(l.lastDrainedJournalId),$=q$1(),V=_e($,f=>t.resolveBlob(f)),J={...l.runtimeByCardId},Z=new Map,ge={readRuntime(f){return Z.get(f)??J[f]??{_sources:{}}},writeRuntime(f,k){Z.set(f,k),J[f]=k;}},Se=[],ne=new Map,we={readSourceData(f,k){let O=`${f}/${k}`;return ne.has(O)?ne.get(O):V.readSourceData(f,k)},ingestSourceDataStaged(f,k,O,ie){V.ingestSourceDataStaged(f,k,O,ie);},commitSourceData(f,k,O){let ie=`${f}/.staged/${O}/${k}`,D=$.read(ie);if(D==null){let z=$.keyRef?.(ie);z&&(D=t.resolveBlob(z));}if(D==null)return false;let oe=`${f}/${k}`,le=D.trim();try{ne.set(oe,JSON.parse(le));}catch{ne.set(oe,le);}return Se.push({cardId:f,outputFile:k,deliveryToken:O}),true},hasSource(f,k){let O=`${f}/${k}`;return ne.has(O)?true:V.hasSource(f,k)},listSources(f){let k=V.listSources(f),O=new Set;for(let D of ne.keys())D.startsWith(`${f}/`)&&O.add(D.slice(`${f}/`.length));let ie=new Set([...k,...O]);return Array.from(ie)}},ce={cardStore:g(),cardRuntimeStore:ge,fetchedSourcesStore:we,outputStore:i(),executionRequestStore:r},ke=[],Ve=[],je=[],Ke=new Map,Xe=new Set,Qt=(f,k)=>{ke.push({type:"task-completed",taskName:f,data:k,timestamp:ee()});},Ne=(f,k)=>{E({type:"task-failed",taskName:f,error:k,timestamp:ee()});},ve=u(p$1,{handlers:{"card-handler":At(e$1,F,ce,Qt,Ne,(f,k)=>{Ve.push({cardId:f,values:k});},f=>{je.push(f);})},onNodeRemoved:f=>{Ke.delete(f),Z.delete(f),delete J[f],Xe.add(f);}});for(ke=w;ke.length>0;){let f=ke;ke=[];for(let k of f)if(k.type==="task-restart"){let O=ce.cardStore.readCard(k.taskName);O&&Ke.set(k.taskName,O);}ve.pushAll(f),await ve.waitForHandlers();}let We=ve.getState();await ve.dispose({wait:true});let zt=U().readSnapshot(e$1.value).version;x({lastDrainedJournalId:F,graph:p(We),runtimeByCardId:J},zt);for(let{cardId:f,values:k}of Ve)ce.outputStore.writeComputedValues(f,k);for(let f of je)ce.outputStore.writeDataObjects(f);for(let{cardId:f,outputFile:k,deliveryToken:O}of Se)V.commitSourceData(f,k,O);let xe;try{xe=Be(d,We),ce.outputStore.writeStatusSnapshot(xe);}catch(f){s(`[board-live-cards-public] status publish failed: ${f instanceof Error?f.message:String(f)}`);}let he=[];for(let{cardId:f,values:k}of Ve)he.push({kind:"computed_values",cardId:f,values:k});for(let f of je)for(let[k,O]of Object.entries(f))k&&he.push({kind:"data_object",key:k,payload:O});for(let[f,k]of Ke)he.push({kind:"card_refreshed",cardId:f,card:k});for(let f of Xe)he.push({kind:"card_removed",cardId:f});xe!==void 0&&he.push({kind:"status",status:xe}),X(he);let ye=m()??{howToRun:"built-in",whatToRun:a({kind:"built-in",value:"source-cli-task-executor"})},Ze=t.supportsDirectSourceOutput?.(ye)===true;r.dispatchEntriesForJournalId(F,f=>{if(f.taskKind!=="source-fetch"){s(`[process-accumulated-events] unknown taskKind "${f.taskKind}" \u2014 skipping`);return}let k=f.payload,O=k.enrichedCard?.id??"unknown",ie=k.enrichedCard?.source_defs??[];if(ye.howToRun==="queue-storage"&&Ze){try{let D=t.queueStorageForRef(P(),"task-executor"),oe=typeof ye.extra?.boardId=="string"?ye.extra.boardId:void 0,le=[];for(let z of ie){if(!z.outputFile){s(`[dispatch] source "${z.bindTo}" has no outputFile \u2014 skipping`);continue}let Ee=t.genId(),Te=`${O}/.staged/${Ee}/${z.outputFile}`,et=$.keyRef?.(Te);if(!et)continue;let tt={ref:a(et),deliveryToken:Ee,outputFile:z.outputFile,cardId:O},Yt=Ot({cbk:k.callbackToken,rg:e$1.value,br:a(e$1),cid:O,b:z.bindTo,d:z.outputFile,cs:void 0,rqt:k.rqt,dt:tt.deliveryToken});le.push({...oe?{boardId:oe}:{},ref:ye,args:{source_def:z,base_ref:a(e$1),callback:a$3.createCallback(Yt),output:tt}});}le.length>0&&D.enqueueMany(le);}catch(D){Ne(O,D instanceof Error?D.message:String(D));}return}for(let D of ie){if(!D.outputFile){s(`[dispatch] source "${D.bindTo}" has no outputFile \u2014 skipping`);continue}let oe;if(Ze){let z=t.genId(),Ee=`${O}/.staged/${z}/${D.outputFile}`,Te=$.keyRef?.(Ee);Te&&(oe={ref:a(Te),deliveryToken:z,outputFile:D.outputFile,cardId:O});}let le=Ot({cbk:k.callbackToken,rg:e$1.value,br:a(e$1),cid:O,b:D.bindTo,d:D.outputFile,cs:void 0,rqt:k.rqt,...oe?{dt:oe.deliveryToken}:{}});t.dispatchExecution(ye,{source_def:D,base_ref:a(e$1),callback:a$3.createCallback(le),...oe?{output:oe}:{}}).catch(z=>Ne(O,z instanceof Error?z.message:String(z)));}});}function P(){let o=S().readQueueStoreRef();if(!o)throw new Error(`Board at ${e$1.value} has no queue store configured. Run: init --queue-store-ref <b64-ref>`);return o}function N(){let o=t.queueStorageForRef(P(),"process-accumulated");o.enqueueIfAbsent?o.enqueueIfAbsent({boardRef:a(e$1)},`process-accumulated:${a(e$1)}`):o.enqueue({boardRef:a(e$1)}),t.requestProcessAccumulated?.();}function H(){let o=t.queueStorageForRef(P(),"process-accumulated");for(;;){let r=o.lease({max:64,visibilityMs:1e3});if(r.length<=0)return;for(let l of r)o.ack(l.id,l.leaseToken);if(r.length<64)return}}async function re(){try{let o=()=>{let l=I(),{events:p}=M().readEntriesAfterCursor(l.lastDrainedJournalId);p.length<=0||N();},r=await c(t.lock,K,o);return A({ran:r!==!1})}catch(o){return _(o)}}function W(){N();}function me(o){try{let r=o.params?.cardStoreRef;if(!r)return R("init requires params.cardStoreRef \u2014 create a card store with card-store-cli and pass its ref here");if(u$1=o.params?.boardRuntimeStoreRef,!u$1)return R("init requires params.boardRuntimeStoreRef \u2014 pass the board runtime store ref here");if(!v()){let J=a$1(Ge);x({lastDrainedJournalId:"",graph:p(J),runtimeByCardId:{}},null);}let l=o.params?.outputsStoreRef;if(!l)return R("init requires params.outputsStoreRef \u2014 pass the outputs store ref here");let p$1=o.params?.queueStoreRef;if(!p$1)return R("init requires params.queueStoreRef \u2014 pass the queue store ref here");let w=o.params?.fetchedSourcesStoreRef;if(!w)return R("init requires params.fetchedSourcesStoreRef \u2014 pass the fetched sources store ref here");c$1=o.params?.scratchStoreRef;let F=o.params?.chatStoreRef;if(!F)return R("init requires params.chatStoreRef \u2014 pass the chat store ref here");let $=o.params?.artifactsStoreRef;if(!$)return R("init requires params.artifactsStoreRef \u2014 pass the artifacts store ref here");let V=S();V.writeBoardRuntimeStoreRef(u$1),V.writeCardStoreRef(r),V.writeOutputsStoreRef(l),V.writeQueueStoreRef(p$1),V.writeFetchedSourcesStoreRef(w),V.writeChatStoreRef(F),V.writeArtifactsStoreRef($);try{i().writeStatusSnapshot(Be(d,q(I().graph)));}catch{}return A()}catch(r){return _(r)}}function se(o){try{let r=i().readStatusSnapshot();if(!r){r=Be(d,q(I().graph));try{i().writeStatusSnapshot(r);}catch{}}return A(r)}catch(r){return _(r)}}function Ce(o){try{let r=o.params?.id;if(!r)return R("removeCard requires params.id");try{t.kvStorage("card-upsert").delete(r);}catch{}return E({type:"task-removal",taskName:r,timestamp:ee()}),W(),A()}catch(r){return _(r)}}function h(o){try{let r=o.params?.cardId;if(!r)return R("addCardFiles requires params.cardId");let l=a$2(g(),{emitNotification:j}).appendFiles({params:{id:r},body:o.body});return l.status!=="success"?l:A({cardId:r,files_added:l.data.files_added,notified:!0})}catch(r){return _(r)}}function b$1(o){try{let r=o.params?.id;return r?(E({type:"task-restart",taskName:r,timestamp:ee()}),W(),A()):R("retrigger requires params.id")}catch(r){return _(r)}}async function B(o){return H(),re()}function G(){let o=S().readFetchedSourcesStoreRef();if(!o)throw new Error(`Board at ${e$1.value} has no fetched sources store configured. Run: init --fetched-sources-store-ref <b64-ref>`);return o}function q$1(){return t.blobStorageForRef(G())}function Q(o){try{let r=o.params?.cardId,l=o.params?.all,p=!!o.params?.restart;if(!r&&!l)return R("upsertCard requires --card-id <id> or --all");let w=l?g().readAllCards().map(F=>F.id):[r];for(let F of w)if(!g().readCard(F))return R(`Card "${F}" not found in board at ${e$1.value}`);for(let F of w){let $=g().readCard(F),V=_t($),J=t.hashFn(V),Z=t.kvStorage("card-upsert"),ge=Z.read(F),Se=ge?.taskConfigHash!==J;if(!(!Se&&!p)){if(Se){let ne=ge?.blobRef??g().readCardKey(F)??F;E({type:"task-upsert",taskName:F,taskConfig:V,timestamp:ee()}),Z.write(F,{blobRef:ne,taskConfigHash:J,updatedAt:ee()});}p&&E({type:"task-restart",taskName:F,timestamp:ee()});}}return W(),A()}catch(r){return _(r)}}function ae(o){try{let r=o.params?.token;if(!r)return R("taskFailed requires params.token");let l=o.params?.error??"unknown error",p=qe(r);return p?(E({type:"task-failed",taskName:p.taskName,error:l,timestamp:ee()}),W(),A()):R("Invalid callback token")}catch(r){return _(r)}}function pe(o){try{let r=o.params?.token;if(!r)return R("taskProgress requires params.token");let p=(o.body??{}).update??{},w=qe(r);return w?(E({type:"task-progress",taskName:w.taskName,update:p,timestamp:ee()}),W(),A()):R("Invalid callback token")}catch(r){return _(r)}}function be(o){try{let r=o.params?.token,l=o.params?.ref;if(!r)return R("sourceDataFetched requires params.token");if(!l)return R("sourceDataFetched requires params.ref");let p=Pt(r);if(!p)return R("Invalid source token");let{cbk:w,cid:F,b:$,d:V,cs:J,rqt:Z,dt:ge}=p,Se=_e(q$1(),ke=>t.resolveBlob(ke)),ne=ge||t.genId();ge||Se.ingestSourceDataStaged(F,V,b(l),ne);let we=qe(w);if(!we)return R("Invalid callback token embedded in source token");let ce=ee();return E({type:"task-progress",taskName:we.taskName,update:{bindTo:$,outputFile:V,fetchedAt:ce,deliveryToken:ne,sourceChecksum:J,rqt:Z},timestamp:ce}),W(),A()}catch(r){return _(r)}}function de(o){try{let r=o.params?.token,l=o.params?.reason??"unknown";if(!r)return R("sourceDataFetchFailure requires params.token");let p=Pt(r);if(!p)return R("Invalid source token");let{cbk:w,b:F,d:$,cs:V,rqt:J}=p,Z=qe(w);return Z?(E({type:"task-progress",taskName:Z.taskName,update:{bindTo:F,outputFile:$,failure:!0,reason:l,sourceChecksum:V,rqt:J},timestamp:ee()}),W(),A()):R("Invalid callback token embedded in source token")}catch(r){return _(r)}}function qt(o){try{let r=S().readCardStoreRef();return r?A({storeRef:r}):R(`Board at ${e$1.value} has no card store configured`)}catch(r){return _(r)}}function Vt(o){try{return A({storeRef:u$1??null})}catch(r){return _(r)}}function jt(o){try{let r=S().readOutputsStoreRef();return r?A({storeRef:r}):R(`Board at ${e$1.value} has no outputs store configured`)}catch(r){return _(r)}}function Kt(o){try{return A({storeRef:c$1??null})}catch(r){return _(r)}}function Nt(o){try{let r=S().readChatStoreRef();return A({storeRef:r})}catch(r){return _(r)}}function Dt(o){try{let r=S().readArtifactsStoreRef();return A({storeRef:r})}catch(r){return _(r)}}function Lt(o){try{let r=S().readFetchedSourcesStoreRef();return A({storeRef:r})}catch(r){return _(r)}}function $t(o){try{let r=o.params?.key;if(!r)return R("getConfig requires params.key");let l=S(),p;switch(r){case "task-executor":p=y??null;break;case "chat-handler-flow":p=C??null;break;case "board-runtime-store-ref":p=l.readBoardRuntimeStoreRef();break;case "card-store-ref":p=l.readCardStoreRef();break;case "outputs-store-ref":p=l.readOutputsStoreRef();break;case "scratch-store-ref":p=c$1??null;break;case "chat-store-ref":p=l.readChatStoreRef();break;case "artifacts-store-ref":p=l.readArtifactsStoreRef();break;case "fetched-sources-store-ref":p=l.readFetchedSourcesStoreRef();break;default:return R(`getConfig: unknown key "${r}"`)}return A({value:p})}catch(r){return _(r)}}function Jt(o){try{let r=o.params?.key;if(!r)return R("getOutputsDataObject requires params.key");let l=i().readDataObject(r);return A(l)}catch(r){return _(r)}}function Ue(o){try{return A(i().readAllDataObjects())}catch(r){return _(r)}}function Mt(o){try{let r=o.params?.key;if(!r)return R("getOutputsComputedValues requires params.key");let l=i().readComputedValues(r);return A(l)}catch(r){return _(r)}}function Qe(o){try{return A(i().readAllComputedValues())}catch(r){return _(r)}}function ze(){return _e(q$1(),o=>t.resolveBlob(o))}function Ye(o){let r=q$1().keyRef?.(o);if(!r)throw new Error("configured fetched-sources store does not support keyRef");return a(r)}function Ht(o){try{let r=o.params?.key;if(!r)return R("getOutputsFetchedSources requires params.key");let l=ze().listSources(r),p={};for(let w of l)p[w]=Ye(`${r}/${w}`);return A(p)}catch(r){return _(r)}}function Gt(o){try{let r=ze(),l=new Set;for(let w of q$1().listKeys()){let F=w.indexOf("/");F>0&&!w.includes("/.staged/")&&l.add(w.slice(0,F));}let p={};for(let w of l){let F=r.listSources(w);if(F.length>0){p[w]={};for(let $ of F)p[w][$]=Ye(`${w}/${$}`);}}return A(p)}catch(r){return _(r)}}function Ut(o){try{let r=g().readAllCards(),l=se({});if(l.status!=="success")return l;let p=Ue({});if(p.status!=="success")return p;let w=Qe({});if(w.status!=="success")return w;let F=w.data,$={};for(let V of r){let J=typeof V?.id=="string"?V.id:null;if(!J)continue;let Z=V.card_data&&typeof V.card_data=="object"&&!Array.isArray(V.card_data)?V.card_data:{};$[J]={schema_version:"v1",card_id:J,card_data:{...Z},computed_values:F[J]&&typeof F[J]=="object"?F[J]:{}};}return A({cardDefinitions:r,statusSnapshot:l.data,dataObjectsByToken:p.data,cardRuntimeById:$})}catch(r){return _(r)}}return {init:me,status:se,getBoardRuntimeStoreRef:Vt,getCardStoreRef:qt,getOutputsStoreRef:jt,getScratchStoreRef:Kt,getChatStoreRef:Nt,getArtifactsStoreRef:Dt,getFetchedSourcesStoreRef:Lt,getConfig:$t,getOutputsDataObject:Jt,getAllOutputsDataObjects:Ue,getOutputsComputedValues:Mt,getAllOutputsComputedValues:Qe,getOutputsFetchedSources:Ht,getAllOutputsFetchedSources:Gt,buildSseOneShotPayload:Ut,removeCard:Ce,addCardFiles:h,retrigger:b$1,processAccumulatedEvents:B,upsertCard:Q,taskFailed:ae,taskProgress:pe,sourceDataFetched:be,sourceDataFetchFailure:de}}function Kr(e,t,n){let a=n?.taskExecutorRef,s=()=>{if(n){if(!n.boardRuntimeStoreRef)throw new Error(`Board at ${e.value} requires boardRuntimeStoreRef for non-core runtime operations.`);return Pe(t.kvStorageForRef(n.boardRuntimeStoreRef))}return Pe(t.kvStorage("config"))};function d(){let g=s().readCardStoreRef();if(!g)throw new Error(`Board at ${e.value} has no card store configured. Run: init --base-ref <ref> --store-ref <b64-ref>`);let i=t.kvStorageForRef(g);return {readIndex(){return i.read("_index")},writeIndex(m){i.write("_index",m);},readCard(m){return i.read(m)},writeCard(m,v){return i.write(m,v),t.hashFn(v)},removeCard(m){i.delete(m);},cardExists(m){return i.read(m)!==null},defaultCardKey(m){return m}}}let u=()=>He(d(),t.onWarn??(()=>{}));function c(){return a??s().readTaskExecutorRef()}async function y(g,i){let m=t.validateSchema(i),v=[],I=c();if(I&&Array.isArray(i.source_defs))for(let E of i.source_defs){let K=typeof E.bindTo=="string"?E.bindTo:"(unknown)";try{let P;try{P=await t.invokeExecutor(I,"validate-source-def",{timeout:t.executorTimeouts?.validationMs??1e4,input:JSON.stringify(E)});}catch(H){let re=H;if(P=typeof re?.stdout=="string"?re.stdout:"",!P.trim()){v.push(`source "${K}": executor validate-source-def failed \u2014 ${H instanceof Error?H.message:String(H)}`);continue}}let N=JSON.parse(P.trim());if(!N.ok&&Array.isArray(N.errors))for(let H of N.errors)v.push(`source "${K}": ${H}`);}catch(P){v.push(`source "${K}": executor validate-source-def failed \u2014 ${P instanceof Error?P.message:String(P)}`);}}let x=[...m.errors,...v];return A({cardId:g,isValid:x.length===0,issues:x})}function C(g,i){let m=g.params?.sourceIdx,v=g.params?.outRef;if(m===void 0)return R(`${i} requires params.sourceIdx`);if(!g.body||typeof g.body!="object"||Array.isArray(g.body))return R(`${i} requires card JSON object in body`);let I=g.body,x=I["card-content"]??I,E=I["mock-projections"]??{},K=x.source_defs??[];if(m<0||m>=K.length)return R(`sourceIdx ${m} out of range (card has ${K.length} source(s))`);let P=K[m],N=typeof P.bindTo=="string"?P.bindTo:"source";return {src:P,bindTo:N,outRef:v,mockProjections:E}}async function j(g){try{if(!g.body||typeof g.body!="object"||Array.isArray(g.body))return R("validateCardPreflight requires card JSON object in body");let i=g.body,m=i["card-content"]??i,v=typeof m.id=="string"?m.id:"(unknown)";return await y(v,m)}catch(i){return _(i)}}async function Y(g){try{let i=C(g,"probeSourcePreflight");if("status"in i)return i;let m=c();if(!m)return R("No task-executor registered for this board");try{let v={...i.src,_projections:i.mockProjections},I=await t.invokeExecutor(m,"probe-source-preflight",{timeout:i.src.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(v)}),x=JSON.parse(I.trim());return x.ok?A({bindTo:i.bindTo,reachable:x.reachable,latencyMs:x.latencyMs,note:x.note}):R(x.error??"Preflight probe failed")}catch{return R("Executor does not support probe-source-preflight")}}catch(i){return _(i)}}async function X(g){try{let i=C(g,"runSourcePreflight");if("status"in i)return i;let m=c();if(!m)return R("No task-executor registered for this board");try{let v={...i.src,_projections:i.mockProjections},I=await t.invokeExecutor(m,"run-source-preflight",{timeout:i.src.timeout??t.executorTimeouts?.probeMs??6e4,input:JSON.stringify(v)}),x=JSON.parse(I.trim());if(!x.ok)return A({bindTo:i.bindTo,ok:!1,result:null,issues:[x.error??"Preflight run failed"]});if(i.outRef){let E=b(i.outRef);t.absoluteBlob.write(E.value,JSON.stringify(x.resultValue,null,2));}return A({bindTo:typeof x.bindTo=="string"?x.bindTo:i.bindTo,ok:!0,result:x.resultValue??null,issues:[]})}catch(v){let I=v instanceof Error?v.message:String(v);return A({bindTo:i.bindTo,ok:!1,result:null,issues:[I]})}}catch(i){return _(i)}}async function te(g){try{let i=c();if(!i)return R("No task-executor registered for this board");let m=await t.invokeExecutor(i,"describe-capabilities",{timeout:t.executorTimeouts?.describeMs??1e4});return A(JSON.parse(m.trim()))}catch(i){return _(i)}}function T(g){try{let i=g.body;if(!i||!Array.isArray(i.ops))return R("updatesInCardStore requires body.ops array");let m=i.ops,v=u();for(let I of m){let x=I.op,E=I.id;if(!E)return R('op is missing "id"');if(x==="update"){let K=I["card-content"];if(!K)return R(`update op for "${E}" is missing "card-content"`);v.writeCard(E,K);}else return R(`Unknown op type: "${x??"(none)"}"`)}return A()}catch(i){return _(i)}}function S(g){try{let i=g.body;if(!i||!Array.isArray(i.ids))return R("readFromCardStore requires body.ids array");let m=i.ids,v=u(),I=m.map(x=>({id:x,"card-content":v.readCard(x)}));return A({cards:I})}catch(i){return _(i)}}function U(g){try{if(!g.body||typeof g.body!="object"||Array.isArray(g.body))return R("evalCardCompute requires a JSON object in body");let i=g.body,m=i["card-content"]??i,v=typeof m.id=="string"?m.id:"(unknown)",I=i["mock-fetched-sources"]??{},x=i["mock-requires"]??{},E=m.compute;if(!E||!Array.isArray(E)||E.length===0)return A({cardId:v,ok:!0,computed_values:{},errors:[]});let K={id:v,card_data:m.card_data??{},requires:x,source_defs:m.source_defs,compute:E},P=a$3.runSync(K,{sourcesData:I}),N=P.node.computed_values??{},H=P.errors??[];return A({cardId:v,ok:H.length===0,computed_values:N,errors:H})}catch(i){return _(i)}}async function M(g){try{if(!g.body||typeof g.body!="object"||Array.isArray(g.body))return R("simulateCardCycle requires a JSON object in body");let i=g.body,m=i["card-content"]??i,v=typeof m.id=="string"?m.id:"(unknown)",I=i["mock-fetched-sources"]??{},x=i["mock-requires"]??{},E=await y(v,m),K=E.status==="success"?{isValid:E.data.isValid,issues:E.data.issues}:{isValid:!1,issues:[E.status==="fail"?E.error:"internal error"]},P=m.source_defs??[],N=m.card_data??{},H=[],re=[];if(P.length>0){H=a$3.enrichSourcesSync(P,{card_data:N,requires:x});for(let q of H){let Q=q.projections,ae=q._projections;if(Q&&ae){for(let pe of Object.keys(Q))if(ae[pe]===void 0){let be=typeof q.bindTo=="string"?q.bindTo:"(unknown)";re.push({bindTo:be,key:pe,error:`Projection "${pe}" resolved to undefined`});}}}}let W=[],me={...I},se=i["task-executor-ref"],Ce=(se?.howToRun&&se?.whatToRun?se:void 0)??c();for(let q=0;q<H.length;q++){let Q=H[q],ae=typeof Q.bindTo=="string"?Q.bindTo:`source_${q}`;if(!Ce){W.push({bindTo:ae,skipped:!0,error:"No task executor configured"});continue}try{let pe={...Q},be=await t.invokeExecutor(Ce,"run-source-preflight",{timeout:Q.timeout??t.executorTimeouts?.preflightMs??6e4,input:JSON.stringify(pe)}),de=JSON.parse(be.trim());de.ok&&!Object.prototype.hasOwnProperty.call(I,ae)&&Object.prototype.hasOwnProperty.call(de,"resultValue")&&(me[ae]=de.resultValue),W.push({bindTo:ae,reachable:de.reachable,latencyMs:de.latencyMs,error:de.ok?void 0:de.error});}catch{W.push({bindTo:ae,skipped:!0,error:"Executor does not support run-source-preflight"});}}let h=m.compute,b={},B=[];if(h&&Array.isArray(h)&&h.length>0){let q={id:v,card_data:N,requires:x,source_defs:m.source_defs,compute:h},Q=a$3.runSync(q,{sourcesData:me});b=Q.node.computed_values??{},B=Q.errors??[];}let G=K.isValid&&re.length===0&&B.length===0&&W.every(q=>q.reachable!==!1);return A({cardId:v,ok:G,validation:K,source_probes:W,projection_errors:re,fetched_sources:me,computed_values:b,compute_errors:B})}catch(i){return _(i)}}return {validateCardPreflight:j,probeSourcePreflight:Y,runSourcePreflight:X,evalCardCompute:U,simulateCardCycle:M,describeTaskExecutorCapabilities:te,updatesInCardStore:T,readFromCardStore:S}}
|
|
2
|
-
export{kr as a,St as b,Rr as c,mt as d,mr as e,pr as f,gr as g,ht as h,er as i,tr as j,yt as k,He as l,Oe as m,Re as n,Tr as o,Ct as p,bt as q,nr as r,wt as s,Be as t,Ge as u,It as v,Ft as w,_t as x,jr as y,Kr as z};//# sourceMappingURL=chunk-VS4E7QFN.js.map
|
|
3
|
-
//# sourceMappingURL=chunk-VS4E7QFN.js.map
|
package/lib/chunk-XLHMUPBW.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
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-XLHMUPBW.js.map
|
package/lib/chunk-YBYXCFAI.js
DELETED