@graphrefly/graphrefly 0.33.0 → 0.34.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/dist/chunk-3Y4BXFFR.js +1 -0
- package/dist/chunk-65WWQ5CB.js +43 -0
- package/dist/chunk-A3GDELMY.js +61 -0
- package/dist/chunk-KN2UMFT6.js +5 -0
- package/dist/{index--BTb6HUO.d.ts → index-3L3RC3VJ.d.ts} +250 -4
- package/dist/{index-C_cXlbu0.d.cts → index-CQtnGFrZ.d.cts} +250 -4
- package/dist/{index-DDf8PoPO.d.ts → index-CbCNoogR.d.ts} +71 -16
- package/dist/{index-Dgcd59CJ.d.cts → index-IxinNgAH.d.cts} +71 -16
- package/dist/index.cjs +57 -57
- package/dist/index.d.cts +2 -2
- package/dist/index.d.ts +2 -2
- package/dist/index.js +1 -1
- package/dist/patterns/ai/browser.cjs +5 -5
- package/dist/patterns/ai/browser.js +1 -1
- package/dist/patterns/ai/index.cjs +19 -19
- package/dist/patterns/ai/index.d.cts +1 -1
- package/dist/patterns/ai/index.d.ts +1 -1
- package/dist/patterns/ai/index.js +1 -1
- package/dist/patterns/harness/index.cjs +10 -10
- package/dist/patterns/harness/index.d.cts +3 -3
- package/dist/patterns/harness/index.d.ts +3 -3
- package/dist/patterns/harness/index.js +1 -1
- package/dist/patterns/orchestration/index.cjs +7 -7
- package/dist/patterns/orchestration/index.js +1 -1
- package/package.json +1 -1
- package/dist/chunk-DUK7LTJO.js +0 -43
- package/dist/chunk-HIJ2RKVP.js +0 -1
- package/dist/chunk-O2WY22L7.js +0 -5
- package/dist/chunk-Z4GXBOWO.js +0 -61
package/dist/chunk-DUK7LTJO.js
DELETED
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import{a as we}from"./chunk-SFIM774L.js";import{c as Oe}from"./chunk-6HQ6HVTF.js";import{u as Y}from"./chunk-Z4GXBOWO.js";import{a as Ae}from"./chunk-GCUYSIM4.js";import{e as Se}from"./chunk-HIJ2RKVP.js";import{f as Ne,h as se}from"./chunk-T2TB37TW.js";import{b as oe,d as D}from"./chunk-L3KUKDZC.js";import{b as ke}from"./chunk-TZQPPQEQ.js";import{f as be,j as ne}from"./chunk-2JO6LXFT.js";import{b as P,s as H,t as Re,x as $}from"./chunk-4F564IPP.js";import{m as Ie}from"./chunk-T7EQPKOP.js";import{D as he,E as S,G as R,H as _,o as F}from"./chunk-LYCLF26R.js";import{b as Je}from"./chunk-QYADASLV.js";var yt={};Je(yt,{DEFAULT_DECAY_RATE:()=>L,DEFAULT_EXECUTE_PROMPT:()=>ie,DEFAULT_QUEUE_CONFIGS:()=>J,DEFAULT_SEVERITY_WEIGHTS:()=>M,DEFAULT_TRIAGE_PROMPT:()=>ae,DEFAULT_VERIFY_PROMPT:()=>ue,HarnessGraph:()=>W,QUEUE_NAMES:()=>b,affectedTaskFilter:()=>Ze,beforeAfterCompare:()=>Xe,codeChangeBridge:()=>et,createIntakeBridge:()=>Ke,defaultErrorClassifier:()=>K,defaultLlmExecutor:()=>Me,defaultLlmVerifier:()=>Le,evalIntakeBridge:()=>We,evalSource:()=>ze,evalVerifier:()=>Ce,harnessEvalPair:()=>it,harnessLoop:()=>ct,harnessProfile:()=>ft,harnessTrace:()=>mt,notifyEffect:()=>tt,priorityScore:()=>ut,refineExecutor:()=>le,resolvePromptFn:()=>Q,strategyKey:()=>V,strategyModel:()=>ce});function Ke(e,t,n,r){return _([e],([o])=>{if(o==null)return;let c=n(o);for(let a of c)t.publish(a)},{name:r?.name??"intake-bridge"})}function We(e,t,n){let r=n?.defaultSeverity??"medium";return _([e],([o])=>{if(o==null)return;let c=Array.isArray(o)?o:[o];for(let a of c)for(let i of a.tasks)if(!(i.valid&&i.judge_scores?.every(l=>l.pass))){if(!i.valid&&(!i.judge_scores||i.judge_scores.length===0)){t.publish({source:"eval",summary:`Task ${i.task_id} invalid (model: ${a.model})`,evidence:`Run ${a.run_id}: task produced invalid output`,affectsAreas:["graphspec"],affectsEvalTasks:[i.task_id],severity:r});continue}if(i.judge_scores)for(let l of i.judge_scores)l.pass||t.publish({source:"eval",summary:`${i.task_id}: ${l.claim} (model: ${a.model})`,evidence:l.reasoning,affectsAreas:["graphspec"],affectsEvalTasks:[i.task_id],severity:r})}},{name:n?.name??"eval-intake-bridge"})}function ze(e,t){return $(e,()=>Ie(t()))}function Xe(e,t){return R([e,t],([n,r])=>{let o=n,c=r,a=new Map(o.tasks.map(f=>[f.task_id,f])),i=new Map(c.tasks.map(f=>[f.task_id,f])),l=new Set([...a.keys(),...i.keys()]),d=[],m=[],p=[];for(let f of l){let g=a.get(f),T=i.get(f),k=g?.valid??!1,x=T?.valid??!1,I=g?.judge_scores?g.judge_scores.filter(w=>w.pass).length:void 0,N=T?.judge_scores?T.judge_scores.filter(w=>w.pass).length:void 0,A=I!==void 0&&N!==void 0?N-I:void 0;d.push({taskId:f,before:k,after:x,scoreDiff:A}),k&&!x&&m.push(f),!k&&x&&p.push(f)}return{newFailures:m,resolved:p,taskDeltas:d,overallImproved:p.length>m.length}},{name:"eval-delta"})}function Ze(e,t){let n=t==null?null:Array.isArray(t)?S(t):t,r=[e];return n&&r.push(n),R(r,o=>{let c=o[0],a=n?new Set(o[1]):null,i=new Set;for(let l of c)for(let d of l.affectsEvalTasks??[])(a==null||a.has(d))&&i.add(d);return[...i].sort()},{name:"affected-task-filter"})}function et(e,t,n,r){let o=r?.defaultSeverity??"high";function c(i){let l=[];for(let d of i.lintErrors??[])l.push({source:"code-change",summary:`Lint: ${d.rule} in ${d.file}:${d.line}`,evidence:d.message,affectsAreas:[d.file],severity:o});for(let d of i.testFailures??[])l.push({source:"test",summary:`Test failure: ${d.testId}`,evidence:d.message,affectsAreas:[d.file],affectsEvalTasks:[d.testId],severity:o});return l}let a=n??c;return _([e],([i])=>{if(i!=null)for(let l of a(i))t.publish(l)},{name:r?.name??"code-change-bridge"})}function tt(e,t,n){return _([e.latest],([r])=>{r!=null&&t(r)},{name:n?.name??"notify-effect"})}var b=["auto-fix","needs-decision","investigation","backlog"],J={"auto-fix":{gated:!1},"needs-decision":{gated:!0},investigation:{gated:!0},backlog:{gated:!1}},M={critical:100,high:70,medium:40,low:10},L=Math.LN2/(168*3600);function V(e,t){return`${e}\u2192${t}`}var rt=/\b(parse|json|config|validation|syntax)\b/i,K=e=>rt.test(e.detail)?"self-correctable":"structural",ae=`You are a triage classifier for a reactive collaboration harness.
|
|
2
|
-
|
|
3
|
-
Given an intake item, classify it and output JSON:
|
|
4
|
-
{
|
|
5
|
-
"rootCause": "composition" | "missing-fn" | "bad-docs" | "schema-gap" | "regression" | "unknown",
|
|
6
|
-
"intervention": "template" | "catalog-fn" | "docs" | "wrapper" | "schema-change" | "investigate",
|
|
7
|
-
"route": "auto-fix" | "needs-decision" | "investigation" | "backlog",
|
|
8
|
-
"priority": <number 0-100>,
|
|
9
|
-
"triageReasoning": "<one sentence>"
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
Strategy model (past effectiveness):
|
|
13
|
-
{{strategy}}
|
|
14
|
-
|
|
15
|
-
Intake item:
|
|
16
|
-
{{item}}`,ie=`You are an implementation agent.
|
|
17
|
-
|
|
18
|
-
Given a triaged issue with root cause and intervention type, produce a fix.
|
|
19
|
-
|
|
20
|
-
Issue:
|
|
21
|
-
{{item}}
|
|
22
|
-
|
|
23
|
-
Output JSON:
|
|
24
|
-
{
|
|
25
|
-
"outcome": "success" | "failure" | "partial",
|
|
26
|
-
"detail": "<description of what was done or what failed>"
|
|
27
|
-
}`,ue=`You are a QA reviewer.
|
|
28
|
-
|
|
29
|
-
Given an execution result, verify whether the fix is correct.
|
|
30
|
-
|
|
31
|
-
Execution:
|
|
32
|
-
{{execution}}
|
|
33
|
-
|
|
34
|
-
Original issue:
|
|
35
|
-
{{item}}
|
|
36
|
-
|
|
37
|
-
Output JSON:
|
|
38
|
-
{
|
|
39
|
-
"verified": true/false,
|
|
40
|
-
"findings": ["<finding1>", ...],
|
|
41
|
-
"errorClass": "self-correctable" | "structural" // only if verified=false
|
|
42
|
-
}`;function Q(e,t,n){if(typeof e=="function")return e;let r=e??t;return o=>n(r,o)}function nt(e){let{best:t,score:n,status:r}=e,o=Number.isFinite(n)?n.toFixed(3):String(n),c=t??void 0;return r==="converged"?{outcome:"success",detail:`refineLoop converged at score ${o}`,artifact:c}:r==="budget"?{outcome:"partial",detail:`refineLoop hit budget at score ${o}`,artifact:c}:{outcome:"failure",detail:`refineLoop errored (status=${r})`,artifact:c}}function le(e){let t=e.name??"refine-executor",n=e.toOutput??nt;return r=>{let o=P(r,a=>a!=null,{name:`${t}/gate-in`}),c=$(o,a=>{let i=we(e.seedFrom(a),e.evaluator,e.strategy,{...e.refine,dataset:e.datasetFor(a),name:`${t}/inner`});return R([i.status,i.best,i.score],([l,d,m])=>{let p=l;return p!=="converged"&&p!=="budget"&&p!=="errored"?null:n({best:d,score:m,status:p})},{name:`${t}/output`})},{name:t});return P(c,a=>a!=null,{name:`${t}/gate-out`})}}function ot(e){if(e.length===0)return Number.NEGATIVE_INFINITY;let t=0;for(let n of e)t+=n.score;return t/e.length}function st(e){let{passCount:t,total:n,meanScore:r,threshold:o,missingArtifact:c}=e,a=Number.isFinite(r)?r.toFixed(3):String(r),i=!c&&n>0&&r>=o,l=c?["EXECUTE stage did not emit an artifact; cannot verify reactively"]:i?[`${t}/${n} eval tasks passed; mean score ${a} \u2265 ${o}`]:n===0?["No eval tasks were selected for this item \u2014 cannot verify"]:[`${t}/${n} eval tasks passed; mean score ${a} < threshold ${o}`];return i?{verified:!0,findings:l}:{verified:!1,findings:l,errorClass:"structural"}}function at(e){return e.artifact??null}function Ce(e){let t=e.name??"eval-verifier",n=e.threshold??.5,r=e.toOutput??st,o=e.extractArtifact??at;return c=>{let a=P(c,l=>l!=null&&l[0]!=null&&l[1]!=null,{name:`${t}/gate-in`}),i=$(a,l=>{let[d,m]=l,p=o(d,m);if(p==null)return S(r({scores:[],meanScore:Number.NEGATIVE_INFINITY,passCount:0,total:0,threshold:n,missingArtifact:!0}));let f=S([p],{name:`${t}/candidates`}),g=S(e.datasetFor(m),{name:`${t}/dataset`}),T=e.evaluator(f,g);return R([T],([k])=>{let x=k;if(x==null)return null;let I=ot(x),N=x.filter(A=>A.score>=n).length;return r({scores:x,meanScore:I,passCount:N,total:x.length,threshold:n})},{name:`${t}/output`})},{name:t});return P(i,l=>l!=null,{name:`${t}/gate-out`})}}function it(e){let t=e.name??"harness-pair",n=le({name:`${t}-exec`,seedFrom:e.seedFrom,evaluator:e.evaluator,strategy:e.strategy,datasetFor:e.datasetFor,refine:e.refine}),r=Ce({name:`${t}-verify`,evaluator:e.evaluator,datasetFor:e.datasetFor,threshold:e.threshold});return{executor:n,verifier:r}}function ce(){let e=ke({name:"strategy-entries"}),t=R([e.entries],([a])=>{let i=a;return new Map(i)},{name:"strategy-model",equals:(a,i)=>{let l=a,d=i;if(l.size!==d.size)return!1;for(let[m,p]of l){let f=d.get(m);if(!f||p.attempts!==f.attempts||p.successes!==f.successes)return!1}return!0}});function n(a,i,l){let d=V(a,i),m=e.get(d),p=(m?.attempts??0)+1,f=(m?.successes??0)+(l?1:0);e.set(d,{rootCause:a,intervention:i,attempts:p,successes:f,successRate:f/p})}function r(a,i){return e.get(V(a,i))}let o=t.subscribe(()=>{});function c(){o()}return{node:t,record:n,lookup:r,dispose:c}}function ut(e,t,n,r,o){let c={...M,...o?.severityWeights},a=o?.decayRate??L,i=o?.effectivenessThreshold??.7,l=o?.effectivenessBoost??15,d=[e,t,n];return r&&d.push(r),R(d,m=>{let p=m[0],f=m[1],g=m[2],T=r?m[3]:0,k=c[p.severity??"medium"],x=(F()-g)/1e9,I=Ae(k,x,a,0),N=V(p.rootCause,p.intervention),A=f.get(N);return A&&A.successRate>=i&&(I+=l),I+=T*20,I},{name:"priority-score"})}var _e="intake",lt="triage-output",Fe="retry",Pe="verify-results",$e="__unrouted";function Me(e,t){let n=Q(t,ie,(r,o)=>r.replace("{{item}}",JSON.stringify(o)));return r=>Y(e,[r],n,{name:"execute",format:"json"})}function Le(e,t){let n=Q(t,ue,(r,o)=>{let[c,a]=o;return r.replace("{{execution}}",JSON.stringify(c)).replace("{{item}}",JSON.stringify(a))});return r=>Y(e,[r],o=>o==null?"":n(o),{name:"verify",format:"json"})}var W=class extends ne{queues;jobs;gates;strategy;totalRetries;totalReingestions;priorityScores;constructor(t,n,r,o,c,a,i,l){super(t),this.queues=n,this.jobs=r,this.gates=o,this.strategy=c,this.totalRetries=a,this.totalReingestions=i,this.priorityScores=l}get intake(){return this.queues.topic(_e)}get verifyResults(){return this.queues.topic(Pe)}get retry(){return this.queues.topic(Fe)}get unrouted(){return this.queues.topic($e)}stageNodes(){let t=this.queues,n=a=>t.has(a)?`queues::${a}::latest`:null,r=a=>a==null?[]:[a],o=b.flatMap(a=>r(n(a))),c=[];for(let[a]of this.gates)c.push(`gates::${a}/gate`);return[{label:"INTAKE",paths:r(n("intake"))},{label:"TRIAGE",paths:["triage"]},{label:"QUEUE",paths:o},{label:"GATE",paths:c},{label:"EXECUTE",paths:["execute"]},{label:"VERIFY",paths:r(n("verify-results"))},{label:"REFLECT",paths:["reflect"]},{label:"STRATEGY",paths:["strategy"]}]}};function ct(e,t){let n=t.adapter,r=t.maxRetries??2,o=t.retainedLimit??1e3,c=t.errorClassifier??K,a=new Map;for(let s of b)a.set(s,{...J[s],...t.queues?.[s]});let i=Ne(`${e}/queues`,{defaultTopicOptions:{retainedLimit:o}}),l=i.topic(_e),d=i.topic(lt),m=i.topic(Fe),p=i.topic(Pe),f=new Map;for(let s of b)f.set(s,i.topic(s));let g=i.topic($e),T=ce(),k=H(l.latest,T.node),x=Q(t.triagePrompt,ae,(s,u)=>{let[y,v]=u;return s.replace("{{strategy}}",JSON.stringify(Array.from(v.entries()))).replace("{{item}}",JSON.stringify(y))}),I=Y(n,[k],s=>{let u=s;return!u||!u[0]?"":x(u)},{name:"triage",format:"json"}),N=H(I,k),w=_([N],([s])=>{if(s==null)return;let[u,y]=s;if(!u?.route)return;let v=y?.[0],O={...u,...v};d.publish(O)}).subscribe(()=>{}),je=new Set(b);for(let s of b)se(`bridge/${s}`,d,f.get(s),{map:u=>u.route===s?u:void 0});se("bridge/__unrouted",d,g,{map:s=>je.has(s.route)?void 0:s});let j=new Map,z=new Map;for(let s of b)j.set(s,Oe(`jobs/${s}`));let de=[];for(let s of b){let u=f.get(s),y=j.get(s),v=new WeakSet,O=_([u.events],([re])=>{let G=re??[];for(let h of G){if(v.has(h))continue;v.add(h);let C=y.enqueue(h);z.set(D(h),{route:s,id:C})}},{name:`jobs/${s}-mirror`});de.push(O.subscribe(()=>{}))}function fe(s){let u=D(s),y=z.get(u);y&&(j.get(y.route)?.removeById(y.id),z.delete(u))}let X=new ne("gates"),U=new Map;for(let s of b){let u=a.get(s);if(!u.gated)continue;let y=f.get(s);X.add(y.latest,{name:`${s}/source`});let v=Se(X,`${s}/gate`,`${s}/source`,{maxPending:u.maxPending,startOpen:u.startOpen});U.set(s,v)}let q=[];for(let s of b)a.get(s).gated&&U.has(s)?q.push(U.get(s).node):q.push(f.get(s).latest);q.push(m.latest);let Z=Re(...q),pe=(t.executor??Me(n,t.executePrompt))(Z),ee=H(pe,Z),me=(t.verifier??Le(n,t.verifyPrompt))(ee),ge=H(me,ee),ye=t.maxReingestions??1,Ge=Math.min(t.maxTotalRetries??r*10,100),De=Math.min(t.maxTotalReingestions??ye*10,100),Te=S(0),Ee=S(0);function He(s,u,y){let v={item:y,outcome:u?.outcome??"failure",detail:u?.detail??"unknown",artifact:u?.artifact};return{item:y,execution:v,verified:s.verified,findings:s.findings??[],errorClass:s.errorClass}}function Qe(s,u){T.record(u.rootCause,u.intervention,!0),p.publish(s),fe(u)}function Ue(s,u){let y=D(u),v=u.$retries??0,O={...u,$retries:v+1,summary:`[RETRY ${v+1}/${r}] ${y} \u2014 Previous attempt failed: ${s.findings.join("; ")}`,relatedTo:[y]};m.publish(O)}function ve(s,u){T.record(u.rootCause,u.intervention,!1),p.publish(s),fe(u);let y=D(u),v=u.$reingestions??0;v<ye&&oe(Ee,De)&&l.publish({source:u.source,summary:`Verification failed for: ${y}`,evidence:s.findings.join(`
|
|
43
|
-
`),affectsAreas:u.affectsAreas,affectsEvalTasks:u.affectsEvalTasks,severity:u.severity??"high",relatedTo:[y],$reingestions:v+1})}let te=he([ge],(s,u)=>{let y=s[0];if(y==null||y.length===0)return;let v=y[y.length-1];if(v==null)return;let[O,re]=v,[G,h]=re??[null,null];if(!O||!h)return;if(G==null){ve({item:h,execution:{item:h,outcome:"failure",detail:"executor returned null"},verified:!1,findings:["executor returned null"],errorClass:"structural"},h);return}let C=He(O,G,h);if(C.verified){Qe(C,h);return}let Be=C.errorClass??c({item:h,outcome:G.outcome,detail:C.findings.join("; ")}),Ye=h.$retries??0;Be==="self-correctable"&&Ye<r&&oe(Te,Ge)?Ue(C,h):ve(C,h)}),qe=te.subscribe(()=>{}),xe=R([te],()=>null,{name:"reflect",equals:()=>!1}),B;t.priority&&(B=dt(f,T,t));let E=new W(e,i,j,U,T,Te,Ee,B);E.addDisposer(w),E.addDisposer(qe),E.addDisposer(T.dispose);for(let s of de)E.addDisposer(s);if(E.add(I,{name:"triage"}),E.add(Z,{name:"execute-input"}),E.add(pe,{name:"execute"}),E.add(ee,{name:"execute-context"}),E.add(me,{name:"verify"}),E.add(ge,{name:"verify-context"}),E.add(te,{name:"verify-dispatch"}),E.add(xe,{name:"reflect"}),E.add(T.node,{name:"strategy"}),E.addDisposer(xe.subscribe(()=>{})),B)for(let[s,u]of B)E.add(u,{name:`priority/${s}`}),E.addDisposer(u.subscribe(()=>{}));E.mount("queues",i),E.mount("gates",X);for(let[s,u]of j)E.mount(`jobs/${s}`,u);return E}function dt(e,t,n){if(!n.lastInteractionNs)throw new Error("harnessLoop: `opts.priority` requires `opts.lastInteractionNs` \u2014 pass a Node<number> (e.g. `fromTimer(60_000)` or a `state(monotonicNs())` you bump on human interaction). Priority scores only decay when this node settles; an internal default would freeze age at construction time.");let r=n.lastInteractionNs,o=n.priority??{},c={...M,...o.severityWeights},a=o.decayRate??L,i=o.effectivenessThreshold??.7,l=o.effectivenessBoost??15,d=new Map;for(let[m,p]of e){let f=R([p.latest,t.node,r],g=>{let T=g[0];if(T==null)return 0;let k=c[T.severity??"medium"]??40,x=(F()-g[2])/1e9,I=k*Math.exp(-a*Math.max(0,x)),N=`${T.rootCause}\u2192${T.intervention}`,w=g[1]?.get(N);return w&&w.successRate>=i&&(I+=l),I},{name:`priority/${m}`});d.set(m,f)}return d}function ft(e,t){let n=be(e,t),r={};for(let o of b){let c=e.queues.has(o)?e.queues.topic(o):null;r[o]=c?.retained().length??0}return{...n,queueDepths:r,strategyEntries:e.strategy.node.cache?.size??0,totalRetries:e.totalRetries.cache??0,totalReingestions:e.totalReingestions.cache??0}}function pt(e){let t={};for(let{label:n,paths:r}of e.stageNodes())for(let o of r)t[o]=n;return t}function mt(e,t){let n=t?.logger===null?null:t?.logger??console.log,r=t?.detail??"summary",o=F(),c=[],a=[],i=pt(e);function l(){return(F()-o)/1e9}function d(m,p,f){let g={elapsed:l(),stage:m,type:p};r!=="summary"&&(g.summary=gt(f)),r==="full"&&(g.data=f),a.push(g)}for(let[m,p]of Object.entries(i))try{let f=e.observe(m,{format:"stage-log",stageLabels:i,logger:n?g=>n(g):()=>{},includeTypes:["data","error","complete"]});f.onEvent(g=>{g.type==="data"?d(p,"data",g.data):g.type==="error"?d(p,"error",g.data):g.type==="complete"&&d(p,"complete",void 0)}),c.push(f)}catch(f){let g=f instanceof Error?f.message:String(f);d(p,"error",`observe-unavailable: ${m} \u2014 ${g}`),n&&n(`[${l().toFixed(3)}s] ${p.padEnd(9)} \u2717 observe-unavailable: ${g}`)}return{get events(){return a},dispose(){for(let m of c)m.dispose();c.length=0}}}function gt(e){if(e==null)return"null";if(typeof e=="string")return Ve(e,80);if(typeof e=="number"||typeof e=="boolean"||typeof e=="bigint")return String(e);try{let t=JSON.stringify(e);return Ve(t,120)}catch{return String(e)}}function Ve(e,t){return e.length>t?`${e.slice(0,t-1)}\u2026`:e}export{Ke as a,We as b,ze as c,Xe as d,Ze as e,et as f,tt as g,b as h,J as i,M as j,L as k,V as l,K as m,ae as n,ie as o,ue as p,Q as q,le as r,Ce as s,it as t,ce as u,ut as v,Me as w,Le as x,W as y,ct as z,ft as A,mt as B,yt as C};
|
package/dist/chunk-HIJ2RKVP.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{c as I}from"./chunk-L3KUKDZC.js";import{g as q,j as P}from"./chunk-2JO6LXFT.js";import{D as G,E as j,G as E,m as C}from"./chunk-LYCLF26R.js";import{b as _,d as D,i as A,j as M}from"./chunk-CK2E7BTU.js";import{b as $}from"./chunk-QYADASLV.js";var ne={};$(ne,{approval:()=>z,branch:()=>V,gate:()=>J,join:()=>Q,loop:()=>X,onFailure:()=>ee,pipeline:()=>L,sensor:()=>Z,subPipeline:()=>Y,task:()=>U});function v(e,n){if(typeof n=="string")return{node:e.resolve(n),path:n};let o=W(e,n);if(!o)throw new Error("orchestration dep node must already be registered in the graph so explicit edges can be recorded; pass a string path or register the node first");return{node:n,path:o}}function W(e,n){let o=e.describe(),r=`::${q}::`;for(let t of Object.keys(o.nodes).sort())if(!t.includes(r))try{if(e.resolve(t)===n)return t}catch{}}function k(e,n,o,r){e.add(o,{name:n})}function y(e,n){return I("orchestration",e,n)}function H(e){let n=r=>{let t=r.trim();return t.length===0?0:Number(t)},o;return typeof e=="string"?o=n(e):e===null?o=0:o=Number(e),Number.isFinite(o)?Math.max(0,Math.trunc(o)):1}function L(e,n){return new P(e,n)}function U(e,n,o,r){let i=(r?.deps??[]).map(a=>v(e,a)),{deps:s,...u}=r??{},h=(a,c,f)=>{let m=a.map((T,b)=>T!=null&&T.length>0?T.at(-1):f.prevData[b]);c.emit(o(m,f))},d=G(i.map(a=>a.node),h,{...u,name:n,describeKind:"derived",meta:y("task",r?.meta)});return k(e,n,d,i.flatMap(a=>a.path?[a.path]:[])),d}function V(e,n,o,r,t){let i=v(e,o),s=E([i.node],([u])=>({branch:r(u)?"then":"else",value:u}),{...t,name:n,meta:y("branch",t?.meta)});return k(e,n,s,i.path?[i.path]:[]),s}function z(e,n,o,r,t){let i=v(e,o),s=v(e,r),u=t?.isApproved??(d=>!!d),h=G([i.node,s.node],(d,a,c)=>{let f=d[0],m=d[1],T=m!=null&&m.length>0?m.at(-1):c.prevData[1];if(T===void 0||!u(T)){a.down([[D]]);return}if(f==null||f.length===0){m!=null&&m.length>0&&c.prevData[0]!==void 0?a.emit(c.prevData[0]):a.down([[D]]);return}for(let b of f)a.emit(b)},{...t,name:n,describeKind:"derived",meta:y("approval",t?.meta)});return k(e,n,h,[i.path,s.path].filter(d=>typeof d=="string")),h}function J(e,n,o,r){let t=r?.maxPending??1/0;if(t<1&&t!==1/0)throw new RangeError("gate: maxPending must be >= 1");let i=r?.startOpen??!1,s=v(e,o),u=j([],{name:"pending",equals:()=>!1}),h=j(i,{name:"isOpen"}),d=E([u],([p])=>p.length,{name:"count"}),a=j(null,{name:"lastRejected",equals:()=>!1}),c=[],f=!1,m=i,T=h.subscribe(p=>{for(let l of p)l[0]===_&&(m=l[1])});function b(){u.emit([...c])}function K(p){c.push(p),c.length>t&&c.shift(),b()}function R(p){let l=c.splice(0,p);return b(),l}function O(p){if(f)throw new Error(`gate: ${p}() called after gate was torn down`)}let S=G([s.node],(p,l,w)=>{let g=w.terminalDeps[0];if(g!==void 0){f=!0,c=[],b(),l.down(g===!0?[[A]]:[[M,g]]);return}let N=p[0];if(N==null||N.length===0){l.down([[D]]);return}for(let F of N)m?l.emit(F):(K(F),l.down([[D]]))},{name:n,describeKind:"derived",meta:y("gate",r?.meta)}),B={node:S,pending:u,count:d,isOpen:h,lastRejected:a,approve(p=1){O("approve");let l=R(p);for(let w of l){if(f)break;S.emit(w)}},reject(p=1){O("reject");let l=[...c],w=Math.min(p,l.length);if(w===0){R(p);return}C(()=>{for(let g=0;g<w;g++)a.emit(l[g]);R(p)})},modify(p,l=1){O("modify");let w=[...c],g=R(l);for(let N=0;N<g.length&&!f;N++)S.emit(p(g[N],N,w))},open(){O("open"),C(()=>{h.emit(!0);let p=R(c.length);for(let l of p){if(f)break;S.emit(l)}})},close(){O("close"),h.emit(!1)}};e.addDisposer(d.subscribe(()=>{})),e.addDisposer(T),k(e,n,S,s.path?[s.path]:[]);let x=new P(`${n}_state`);return x.add(u,{name:"pending"}),x.add(h,{name:"isOpen"}),x.add(d,{name:"count"}),x.add(a,{name:"lastRejected"}),e.mount(`${n}_state`,x),e.addDisposer(a.subscribe(()=>{})),B}function Q(e,n,o,r){let t=o.map(s=>v(e,s)),i=E(t.map(s=>s.node),s=>s,{...r,name:n,meta:y("join",r?.meta)});return k(e,n,i,t.flatMap(s=>s.path?[s.path]:[])),i}function X(e,n,o,r,t){let i=v(e,o),s=t?.iterations,u=typeof s=="number"||s===void 0?void 0:v(e,s),h=typeof s=="number"?s:void 0,d=G(u?[i.node,u.node]:[i.node],(a,c,f)=>{let m=a[0],T=m!=null&&m.length>0?m.at(-1):f.prevData[0],b=u?a[1]:void 0,K=h??(u?b!=null&&b.length>0?b.at(-1):f.prevData[1]:1),R=H(K);for(let O=0;O<R;O+=1)T=r(T,O,c);c.emit(T)},{...t,name:n,describeKind:"derived",meta:y("loop",t?.meta)});return k(e,n,d,[i.path,u?.path].filter(a=>typeof a=="string")),d}function Y(e,n,o,r){let t=o instanceof P?o:L(n,r);return typeof o=="function"&&o(t),e.mount(n,t),t}function Z(e,n,o,r){let t=G([],()=>{},{...r,name:n,initial:o,describeKind:"producer",meta:y("sensor",r?.meta)});return k(e,n,t,[]),{node:t,push(i){t.emit(i)},error(i){t.down([[M,i]])},complete(){t.down([[A]])}}}function ee(e,n,o,r,t){let i=v(e,o),s=!1,u=G([],(h,d)=>{let a=i.node.subscribe(c=>{for(let f of c){if(s)return;if(f[0]===M)try{d.emit(r(f[1],d))}catch(m){s=!0,d.down([[M,m]])}else d.down([f]),f[0]===A&&(s=!0)}});return()=>a()},{...t,name:n,describeKind:"derived",completeWhenDepsComplete:!1,errorWhenDepsError:!1,meta:y("onFailure",t?.meta)});return k(e,n,u,i.path?[i.path]:[]),u}export{L as a,U as b,V as c,z as d,J as e,Q as f,X as g,Y as h,Z as i,ee as j,ne as k};
|
package/dist/chunk-O2WY22L7.js
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import{a as O,f as v,k as P}from"./chunk-2LZ6DL45.js";import{ba as _,k as A}from"./chunk-LOF5HSD3.js";import{d as U}from"./chunk-FKRPIRE6.js";import{m as S,w as T}from"./chunk-T7EQPKOP.js";import{o as y}from"./chunk-LYCLF26R.js";function G(e={}){return e.sdk?H(e):Y(e)}function b(e,t,o,a){let i=t?.model??o;if(!i)throw new Error("anthropicAdapter: model must be set via options.model or invokeOpts.model");let{system:n,chat:s}=q(e,t?.systemPrompt),r={model:i,messages:s.map(J),max_tokens:t?.maxTokens??4096};return n&&(r.system=n),t?.temperature!=null&&(r.temperature=t.temperature),t?.tools&&t.tools.length>0&&(r.tools=t.tools.map(F)),t?.maxReasoningTokens!=null&&(r.thinking={type:"enabled",budget_tokens:t.maxReasoningTokens}),t?.cacheHint,a&&(r.stream=!0),t?.providerExtras&&Object.assign(r,t.providerExtras),r}function q(e,t){let o=[];t&&o.push(t);let a=[];for(let i of e)i.role==="system"?o.push(i.content):a.push(i);return{system:o.length>0?o.join(`
|
|
2
|
-
|
|
3
|
-
`):void 0,chat:a}}function J(e){if(e.role==="tool")return{role:"user",content:[{type:"tool_result",tool_use_id:e.toolCallId,content:e.content}]};if(e.role==="assistant"&&e.toolCalls&&e.toolCalls.length>0){let t=[];e.content&&t.push({type:"text",text:e.content});for(let o of e.toolCalls)t.push({type:"tool_use",id:o.id,name:o.name,input:o.arguments});return{role:"assistant",content:t}}return{role:e.role,content:e.content}}function F(e){return{name:e.name,description:e.description,input_schema:e.parameters}}function R(e,t){if(!e)return{...t};let o={...e};return t.input_tokens!=null&&(o.input_tokens=t.input_tokens),t.output_tokens!=null&&(o.output_tokens=t.output_tokens),t.cache_read_input_tokens!=null&&(o.cache_read_input_tokens=t.cache_read_input_tokens),t.cache_creation_input_tokens!=null&&(o.cache_creation_input_tokens=t.cache_creation_input_tokens),t.cache_creation&&(o.cache_creation={...e.cache_creation??{},...t.cache_creation}),t.server_tool_use&&(o.server_tool_use={...e.server_tool_use??{},...t.server_tool_use}),o}function x(e){let t={input:{regular:e?.input_tokens??0},output:{regular:e?.output_tokens??0},raw:e};return e?.cache_read_input_tokens&&(t.input.cacheRead=e.cache_read_input_tokens),e?.cache_creation?(e.cache_creation.ephemeral_5m_input_tokens&&(t.input.cacheWrite5m=e.cache_creation.ephemeral_5m_input_tokens),e.cache_creation.ephemeral_1h_input_tokens&&(t.input.cacheWrite1h=e.cache_creation.ephemeral_1h_input_tokens)):e?.cache_creation_input_tokens&&(t.input.cacheWrite5m=e.cache_creation_input_tokens),e?.server_tool_use?.web_search_requests&&(t.auxiliary={webSearchRequests:e.server_tool_use.web_search_requests}),t}function K(e,t){let o=[],a=[];for(let i of e.content)if(i.type==="text"&&typeof i.text=="string")o.push(i.text);else if(i.type==="tool_use"){let n=i;a.push({id:n.id,name:n.name,arguments:n.input??{}})}return{content:o.join(""),toolCalls:a.length>0?a:void 0,usage:x(e.usage),finishReason:e.stop_reason,latencyMs:t,model:e.model,provider:"anthropic"}}function Y(e){let t=e.apiKey??globalThis.process?.env?.ANTHROPIC_API_KEY,o=e.baseURL??"https://api.anthropic.com",a=e.anthropicVersion??"2023-06-01",i=e.fetchImpl??fetch,n=()=>{if(!t)throw new Error("anthropicAdapter: apiKey required for invoke/stream (or provide opts.sdk)");return{"x-api-key":t,"anthropic-version":a,"content-type":"application/json",...e.headers??{}}};return{provider:"anthropic",model:e.model,async invoke(s,r){let c=b(s,r,e.model,!1),g=y(),l=await i(`${o}/v1/messages`,{method:"POST",headers:n(),body:JSON.stringify(c),signal:r?.signal});if(!l.ok)throw await _(l,"Anthropic");let d=await l.json(),p=Math.max(0,(y()-g)/1e6);return K(d,p)},async*stream(s,r){let c=b(s,r,e.model,!0),g=await i(`${o}/v1/messages`,{method:"POST",headers:{...n(),accept:"text/event-stream"},body:JSON.stringify(c),signal:r?.signal});if(!g.ok)throw await _(g,"Anthropic");if(!g.body)throw new Error("anthropicAdapter: streaming response has no body");let l,d,p=new Map;for await(let m of A(g.body,{signal:r?.signal})){let h=m.data;if(!h)continue;let k;try{k=JSON.parse(h)}catch{continue}switch(k.type){case"message_start":{l=R(l,k.message.usage);break}case"content_block_start":{let u=k,f=u.content_block;f.type==="tool_use"&&(p.set(u.index,{id:String(f.id??""),name:String(f.name??""),argBuf:""}),yield{type:"tool-call-delta",delta:{id:String(f.id??""),name:String(f.name??"")}});break}case"content_block_delta":{let u=k,f=u.delta;if(f.type==="text_delta"&&typeof f.text=="string")yield{type:"token",delta:f.text};else if(f.type==="input_json_delta"&&typeof f.partial_json=="string"){let E=p.get(u.index);E&&(E.argBuf+=f.partial_json),yield{type:"tool-call-delta",delta:{argumentsDelta:f.partial_json}}}else f.type==="thinking_delta"&&typeof f.thinking=="string"&&(yield{type:"thinking",delta:f.thinking});break}case"message_delta":{let u=k;u.delta.stop_reason&&(d=u.delta.stop_reason),u.delta.usage&&(l=R(l,u.delta.usage));break}case"message_stop":break}}l&&(yield{type:"usage",usage:x(l)}),yield{type:"finish",reason:d??"stop"}}}}function H(e){let t=e.sdk;if(!t)throw new Error("sdkBackedAnthropic: sdk instance required");return{provider:"anthropic",model:e.model,async invoke(o,a){let i=b(o,a,e.model,!1),n=y(),s=await t.messages.create(i,{signal:a?.signal}),r=Math.max(0,(y()-n)/1e6);return K(s,r)},async*stream(o,a){if(!t.messages.stream)throw new Error("sdkBackedAnthropic: SDK instance does not expose .messages.stream");let i=b(o,a,e.model,!0),n,s;for await(let r of t.messages.stream(i,{signal:a?.signal}))switch(r.type){case"message_start":n=R(n,r.message.usage);break;case"content_block_delta":{let c=r.delta;c?.type==="text_delta"&&typeof c.text=="string"?yield{type:"token",delta:c.text}:c?.type==="input_json_delta"&&typeof c.partial_json=="string"?yield{type:"tool-call-delta",delta:{argumentsDelta:c.partial_json}}:c?.type==="thinking_delta"&&typeof c.thinking=="string"&&(yield{type:"thinking",delta:c.thinking});break}case"message_delta":{let c=r;c.delta.stop_reason&&(s=c.delta.stop_reason),c.delta.usage&&(n=R(n,c.delta.usage));break}}n&&(yield{type:"usage",usage:x(n)}),yield{type:"finish",reason:s??"stop"}}}}function j(e={}){return e.sdk?Q(e):z(e)}function w(e,t){let o=[],a=[];t?.systemPrompt&&o.push(t.systemPrompt);for(let s of e){if(s.role==="system"){o.push(s.content);continue}if(s.role==="tool"){a.push({role:"user",parts:[{functionResponse:{name:s.name??s.toolCallId??"tool",response:{result:s.content}}}]});continue}if(s.role==="assistant"&&s.toolCalls&&s.toolCalls.length>0){let r=[];s.content&&r.push({text:s.content});for(let c of s.toolCalls)r.push({functionCall:{name:c.name,args:c.arguments}});a.push({role:"model",parts:r});continue}a.push({role:s.role==="assistant"?"model":"user",parts:[{text:s.content}]})}let i={contents:a};o.length>0&&(i.systemInstruction={role:"system",parts:[{text:o.join(`
|
|
4
|
-
|
|
5
|
-
`)}]});let n={};return t?.maxTokens!=null&&(n.maxOutputTokens=t.maxTokens),t?.temperature!=null&&(n.temperature=t.temperature),t?.maxReasoningTokens!=null&&(n.thinkingConfig={thinkingBudget:t.maxReasoningTokens}),Object.keys(n).length>0&&(i.generationConfig=n),t?.tools&&t.tools.length>0&&(i.tools=[{functionDeclarations:t.tools.map(V)}]),t?.providerExtras&&Object.assign(i,t.providerExtras),i}function V(e){return{name:e.name,description:e.description,parameters:e.parameters}}function M(e){let t={input:{regular:0},output:{regular:0},raw:e};if(!e)return t;let o=e.promptTokenCount??0,a=e.cachedContentTokenCount??0;if(t.input.regular=Math.max(0,o-a),a>0&&(t.input.cacheRead=a),e.toolUsePromptTokenCount&&(t.input.toolUse=e.toolUsePromptTokenCount),e.promptTokensDetails)for(let i of e.promptTokensDetails){let n=i.modality?.toLowerCase();n==="image"?t.input.image=(t.input.image??0)+i.tokenCount:n==="audio"?t.input.audio=(t.input.audio??0)+i.tokenCount:n==="video"&&(t.input.video=(t.input.video??0)+i.tokenCount)}return t.output.regular=e.candidatesTokenCount??0,e.thoughtsTokenCount&&(t.output.reasoning=e.thoughtsTokenCount),t}function D(e,t){let o=e.candidates?.[0],a=o?.content?.parts??[],i=[],n=[],s=0;for(let r of a)typeof r.text=="string"&&i.push(r.text),r.functionCall&&n.push({id:`${r.functionCall.name}-${s++}`,name:r.functionCall.name,arguments:r.functionCall.args??{}});return{content:i.join(""),toolCalls:n.length>0?n:void 0,usage:M(e.usageMetadata),finishReason:o?.finishReason,latencyMs:t,model:e.modelVersion,provider:"google"}}function W(e){if(e.apiKey)return e.apiKey;let t=globalThis.process?.env;return t?.GOOGLE_API_KEY??t?.GEMINI_API_KEY}function z(e){let t=e.baseURL??"https://generativelanguage.googleapis.com/v1beta",o=e.fetchImpl??fetch,a=n=>{let s=n?.model??e.model;if(!s)throw new Error("googleAdapter: model must be set via options.model or invokeOpts.model");return s},i=()=>{let n=W(e);if(!n)throw new Error("googleAdapter: apiKey required for invoke/stream");return`key=${encodeURIComponent(n)}`};return{provider:"google",model:e.model,async invoke(n,s){let r=a(s),c=w(n,s),g=y(),l=`${t}/models/${encodeURIComponent(r)}:generateContent?${i()}`,d=await o(l,{method:"POST",headers:{"content-type":"application/json",...e.headers??{}},body:JSON.stringify(c),signal:s?.signal});if(!d.ok)throw await _(d,"Google");let p=await d.json(),m=Math.max(0,(y()-g)/1e6);return D(p,m)},async*stream(n,s){let r=a(s),c=w(n,s),g=`${t}/models/${encodeURIComponent(r)}:streamGenerateContent?alt=sse&${i()}`,l=await o(g,{method:"POST",headers:{"content-type":"application/json",accept:"text/event-stream",...e.headers??{}},body:JSON.stringify(c),signal:s?.signal});if(!l.ok)throw await _(l,"Google");if(!l.body)throw new Error("googleAdapter: streaming response has no body");let d,p;for await(let m of A(l.body,{signal:s?.signal})){if(!m.data)continue;let h;try{h=JSON.parse(m.data)}catch{continue}let k=h.candidates?.[0];for(let u of k?.content?.parts??[])typeof u.text=="string"&&(u.thought?yield{type:"thinking",delta:u.text}:yield{type:"token",delta:u.text}),u.functionCall&&(yield{type:"tool-call-delta",delta:{name:u.functionCall.name,argumentsDelta:JSON.stringify(u.functionCall.args??{})}});k?.finishReason&&(p=k.finishReason),h.usageMetadata&&(d=h.usageMetadata)}d&&(yield{type:"usage",usage:M(d)}),yield{type:"finish",reason:p??"stop"}}}}function Q(e){let t=e.sdk;if(!t)throw new Error("sdkBackedGoogle: sdk instance required");return{provider:"google",model:e.model,async invoke(o,a){let i=w(o,a),n=a?.model??e.model;if(!n)throw new Error("googleAdapter: model required");let s=y(),r=await t.models.generateContent({...i,model:n},{signal:a?.signal}),c=Math.max(0,(y()-s)/1e6);return D(r,c)},async*stream(o,a){if(!t.models.generateContentStream)throw new Error("sdkBackedGoogle: SDK instance does not expose generateContentStream");let i=w(o,a),n=a?.model??e.model;if(!n)throw new Error("googleAdapter: model required");let s,r;for await(let c of t.models.generateContentStream({...i,model:n},{signal:a?.signal})){let g=c.candidates?.[0];for(let l of g?.content?.parts??[])typeof l.text=="string"&&(l.thought?yield{type:"thinking",delta:l.text}:yield{type:"token",delta:l.text}),l.functionCall&&(yield{type:"tool-call-delta",delta:{name:l.functionCall.name,argumentsDelta:JSON.stringify(l.functionCall.args??{})}});g?.finishReason&&(r=g.finishReason),c.usageMetadata&&(s=c.usageMetadata)}s&&(yield{type:"usage",usage:M(s)}),yield{type:"finish",reason:r??"stop"}}}}var X={openai:{baseURL:"https://api.openai.com/v1",apiKeyEnv:"OPENAI_API_KEY",provider:"openai"},openrouter:{baseURL:"https://openrouter.ai/api/v1",apiKeyEnv:"OPENROUTER_API_KEY",provider:"openrouter"},groq:{baseURL:"https://api.groq.com/openai/v1",apiKeyEnv:"GROQ_API_KEY",provider:"groq"},ollama:{baseURL:"http://localhost:11434/v1",provider:"ollama"},deepseek:{baseURL:"https://api.deepseek.com/v1",apiKeyEnv:"DEEPSEEK_API_KEY",provider:"deepseek"},xai:{baseURL:"https://api.x.ai/v1",apiKeyEnv:"XAI_API_KEY",provider:"xai"}};function B(e={}){return e.sdk?oe(e):ne(e)}function L(e,t,o,a,i){let n=t?.model??o;if(!n)throw new Error("openAICompatAdapter: model must be set via options.model or invokeOpts.model");let s=e.map(Z);t?.systemPrompt&&!e.some(c=>c.role==="system")&&s.unshift({role:"system",content:t.systemPrompt});let r={model:n,messages:s};return t?.maxTokens!=null&&(r.max_tokens=t.maxTokens),t?.temperature!=null&&(r.temperature=t.temperature),t?.tools&&t.tools.length>0&&(r.tools=t.tools.map(ee)),t?.maxReasoningTokens!=null&&(r.reasoning={max_tokens:t.maxReasoningTokens}),a&&(r.stream=!0,r.stream_options={include_usage:!0}),i&&Object.assign(r,i),t?.providerExtras&&Object.assign(r,t.providerExtras),r}function Z(e){return e.role==="tool"?{role:"tool",tool_call_id:e.toolCallId,content:e.content}:e.role==="assistant"&&e.toolCalls&&e.toolCalls.length>0?{role:"assistant",content:e.content||null,tool_calls:e.toolCalls.map(t=>({id:t.id,type:"function",function:{name:t.name,arguments:JSON.stringify(t.arguments)}}))}:{role:e.role,content:e.content}}function ee(e){return{type:"function",function:{name:e.name,description:e.description,parameters:e.parameters}}}function I(e){let t={input:{regular:0},output:{regular:0},raw:e};if(!e)return t;let o=e.prompt_tokens??0,a=e.prompt_tokens_details?.cached_tokens??0;e.prompt_cache_hit_tokens!=null?(a=e.prompt_cache_hit_tokens,t.input.regular=e.prompt_cache_miss_tokens??Math.max(0,o-a)):t.input.regular=Math.max(0,o-a),a>0&&(t.input.cacheRead=a),e.prompt_tokens_details?.audio_tokens&&(t.input.audio=e.prompt_tokens_details.audio_tokens);let i=e.completion_tokens??0,n=e.completion_tokens_details?.reasoning_tokens??0;return t.output.regular=Math.max(0,i-n),n>0&&(t.output.reasoning=n),e.completion_tokens_details?.audio_tokens&&(t.output.audio=e.completion_tokens_details.audio_tokens),e.completion_tokens_details?.accepted_prediction_tokens&&(t.output.predictionAccepted=e.completion_tokens_details.accepted_prediction_tokens),e.completion_tokens_details?.rejected_prediction_tokens&&(t.output.predictionRejected=e.completion_tokens_details.rejected_prediction_tokens),t}function $(e,t,o){let a=e.choices[0],i=a?.message,n=i?.content??"",s=(i?.tool_calls??[]).map(r=>({id:r.id,name:r.function.name,arguments:te(r.function.arguments)}));return{content:n,toolCalls:s.length>0?s:void 0,usage:I(e.usage),finishReason:a?.finish_reason,latencyMs:t,model:e.model,provider:o}}function te(e){try{let t=JSON.parse(e);return typeof t=="object"&&t!=null?t:{_raw:e}}catch{return{_raw:e}}}function N(e){let t=e.preset??"openai",o=X[t],a=e.baseURL??o.baseURL,i=e.provider??o.provider,n=o.apiKeyEnv,s=e.apiKey??(n?globalThis.process?.env?.[n]:void 0);return{provider:i,baseURL:a,apiKey:s}}function ne(e){let{provider:t,baseURL:o,apiKey:a}=N(e),i=e.fetchImpl??fetch,n=t!=="ollama",s=()=>{let r={"content-type":"application/json",...e.headers??{}};if(n){if(!a)throw new Error(`openAICompatAdapter[${t}]: apiKey required for invoke/stream`);r.authorization=`Bearer ${a}`}return r};return{provider:t,model:e.model,async invoke(r,c){let g=L(r,c,e.model,!1,e.bodyExtras),l=y(),d=await i(`${o}/chat/completions`,{method:"POST",headers:s(),body:JSON.stringify(g),signal:c?.signal});if(!d.ok)throw await _(d,t);let p=await d.json(),m=Math.max(0,(y()-l)/1e6);return $(p,m,t)},async*stream(r,c){let g=L(r,c,e.model,!0,e.bodyExtras),l=await i(`${o}/chat/completions`,{method:"POST",headers:{...s(),accept:"text/event-stream"},body:JSON.stringify(g),signal:c?.signal});if(!l.ok)throw await _(l,t);if(!l.body)throw new Error(`openAICompatAdapter[${t}]: streaming response has no body`);let d,p;for await(let m of A(l.body,{signal:c?.signal})){if(!m.data||m.data==="[DONE]")continue;let h;try{h=JSON.parse(m.data)}catch{continue}let k=h.choices;if(k){let u=k[0];if(u?.delta?.content&&(yield{type:"token",delta:u.delta.content}),u?.delta?.reasoning_content&&(yield{type:"thinking",delta:u.delta.reasoning_content}),u?.delta?.tool_calls)for(let f of u.delta.tool_calls)yield{type:"tool-call-delta",delta:{id:f.id,name:f.function?.name,argumentsDelta:f.function?.arguments}};u?.finish_reason&&(p=u.finish_reason)}h.usage&&(d=h.usage,yield{type:"usage",usage:I(d)})}yield{type:"finish",reason:p??"stop"}}}}function oe(e){let t=e.sdk;if(!t)throw new Error("sdkBackedOpenAI: sdk instance required");let{provider:o}=N(e);return{provider:o,model:e.model,async invoke(a,i){let n=L(a,i,e.model,!1,e.bodyExtras),s=y(),r=await t.chat.completions.create(n,{signal:i?.signal}),c=Math.max(0,(y()-s)/1e6);return $(r,c,o)},async*stream(a,i){let n=L(a,i,e.model,!0,e.bodyExtras),s=await t.chat.completions.create(n,{signal:i?.signal}),r,c;for await(let g of s){let l=g.choices;if(l){let p=l[0];if(p?.delta?.content&&(yield{type:"token",delta:p.delta.content}),p?.delta?.reasoning_content&&(yield{type:"thinking",delta:p.delta.reasoning_content}),p?.delta?.tool_calls)for(let m of p.delta.tool_calls)yield{type:"tool-call-delta",delta:{id:m.id,name:m.function?.name,argumentsDelta:m.function?.arguments}};p?.finish_reason&&(c=p.finish_reason)}let d=g.usage;d&&(r=d,yield{type:"usage",usage:I(d)})}yield{type:"finish",reason:c??"stop"}}}}function be(e){switch(e.provider){case"anthropic":{let t={apiKey:e.apiKey,model:e.model,baseURL:e.baseURL,headers:e.headers,sdk:e.sdk,fetchImpl:e.fetchImpl,...e.extras};return G(t)}case"google":{let t={apiKey:e.apiKey,model:e.model,baseURL:e.baseURL,headers:e.headers,sdk:e.sdk,fetchImpl:e.fetchImpl,...e.extras};return j(t)}case"dry-run":{let t={model:e.model,...e.extras};return O(t)}case"fallback":{let t={provider:e.provider,model:e.model,...e.extras};return P(t)}case"openai":case"openrouter":case"groq":case"ollama":case"deepseek":case"xai":{let t={preset:e.provider,apiKey:e.apiKey,model:e.model,baseURL:e.baseURL,headers:e.headers,bodyExtras:e.bodyExtras,sdk:e.sdk,fetchImpl:e.fetchImpl,...e.extras};return B(t)}default:{let t=e.provider;throw new Error(`createAdapter: unknown provider: ${String(t)}`)}}}var C=class extends Error{name="AllTiersExhaustedError";skipped;failed;constructor(t){let o=[];t.failed.size>0&&o.push(`failed=[${[...t.failed.keys()].join(",")}]`),t.skipped.length>0&&o.push(`skipped=[${t.skipped.map(a=>`${a.name}(${a.reason})`).join(",")}]`),super(`All LLM adapter tiers exhausted: ${o.join(" ")}`),this.skipped=t.skipped,this.failed=t.failed}};function xe(e,t={}){if(e.length===0)throw new RangeError("cascadingLlmAdapter: tiers must be non-empty");let o=e.map(n=>({name:n.name,adapter:n.adapter,filter:n.filter,breaker:n.breaker?"canExecute"in n.breaker?n.breaker:U(n.breaker):void 0})),a=t.streamRetryBeforeFirstChunk??!0,i={provider:"cascading",model:void 0,async invoke(n,s){let r=[],c=new Map;for(let l=0;l<o.length;l++){let d=o[l];if(d.filter&&!d.filter(n,s)){r.push({name:d.name,reason:"filter"});continue}if(d.breaker&&!d.breaker.canExecute()){r.push({name:d.name,reason:"breaker"});continue}try{let p=await T(S(d.adapter.invoke(n,s)));return d.breaker?.recordSuccess(),{...p,metadata:{...p.metadata??{},tier:d.name}}}catch(p){c.set(d.name,p),d.breaker?.recordFailure(p);let m=o[l+1];m&&t.onFallback?.(d.name,m.name,p)}}let g={skipped:r,failed:c};throw t.onExhausted?.(g),new C(g)},async*stream(n,s){let r=[],c=new Map;for(let l=0;l<o.length;l++){let d=o[l];if(d.filter&&!d.filter(n,s)){r.push({name:d.name,reason:"filter"});continue}if(d.breaker&&!d.breaker.canExecute()){r.push({name:d.name,reason:"breaker"});continue}let p=!1;try{for await(let m of d.adapter.stream(n,s))p=!0,yield m;d.breaker?.recordSuccess();return}catch(m){if(c.set(d.name,m),d.breaker?.recordFailure(m),p||!a)throw m;let h=o[l+1];h&&t.onFallback?.(d.name,h.name,m)}}let g={skipped:r,failed:c};throw t.onExhausted?.(g),new C(g)}};return v(i,`cascade[${o.map(n=>n.name).join(",")}]`),i}function Me(e,t,o){let a={name:e,adapter:t};return o?.breaker&&(a.breaker=o.breaker),o?.filter&&(a.filter=o.filter),a}export{G as a,j as b,B as c,be as d,C as e,xe as f,Me as g};
|
package/dist/chunk-Z4GXBOWO.js
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import{a as _e,b as je,d as Fe,e as Ge}from"./chunk-GCUYSIM4.js";import{e as St}from"./chunk-HIJ2RKVP.js";import{h as Et}from"./chunk-U2T2XWDA.js";import{e as et}from"./chunk-T2TB37TW.js";import{a as Xt,b as nr,c as or,d as ar,e as sr,f as Ze,g as ir}from"./chunk-O2WY22L7.js";import{a as Qe,b as ee,c as Pe,d as ge,e as ie,f as te,g as Zt,h as Xe,i as er,j as tr,k as rr}from"./chunk-2LZ6DL45.js";import{c as wt}from"./chunk-L3KUKDZC.js";import{b as Ct}from"./chunk-WBWBY6LI.js";import{b as Tt,c as Oe,d as vt,f as Ye}from"./chunk-FKRPIRE6.js";import{b as De}from"./chunk-TZQPPQEQ.js";import{b as Te}from"./chunk-HTBOCKVD.js";import{j as me}from"./chunk-2JO6LXFT.js";import{a as se}from"./chunk-ESMPEKEV.js";import{R as At,b as Lt,s as Nt,x as Y}from"./chunk-4F564IPP.js";import{B as U,f as Mt,k as Je,l as kt,m as w,w as ce,y as Rt,z as xt}from"./chunk-T7EQPKOP.js";import{D as fe,E as k,F as ue,G as M,H as ne,m as Z,o as re,p as Le}from"./chunk-LYCLF26R.js";import{b as Q,d as be,i as le,j as X}from"./chunk-CK2E7BTU.js";import{b as Qt}from"./chunk-QYADASLV.js";var un={};Qt(un,{AgentLoopGraph:()=>ze,AllTiersExhaustedError:()=>sr,BudgetExhaustedError:()=>We,ChatStreamGraph:()=>He,CircuitOpenError:()=>Oe,DEFAULT_DECAY_RATE:()=>Se,FallbackMissError:()=>tr,LLMTimeoutError:()=>Me,ReplayCacheMissError:()=>Zt,ToolRegistryGraph:()=>qe,admissionFilter3D:()=>Yr,admissionScored:()=>Ut,agentLoop:()=>Hr,agentMemory:()=>Jr,anthropicAdapter:()=>Xt,canonicalJson:()=>er,cascadingLlmAdapter:()=>Ze,chatStream:()=>mt,composePricing:()=>pr,computePrice:()=>tt,contentGate:()=>Wr,costMeterExtractor:()=>_r,createAdapter:()=>ar,createCapabilitiesRegistry:()=>lr,createPricingRegistry:()=>cr,dryRunAdapter:()=>Qe,fallbackAdapter:()=>rr,fromLLM:()=>Lr,frozenContext:()=>Sr,gatedStream:()=>Or,gaugesAsContext:()=>rn,googleAdapter:()=>nr,graphFromSpec:()=>qt,graphFromSpecReactive:()=>nn,handoff:()=>qr,keywordFlagExtractor:()=>Fr,knobsAsTools:()=>an,llmConsolidator:()=>yt,llmExtractor:()=>gt,memoryRetrieval:()=>tn,memoryWithKG:()=>Xr,memoryWithTiers:()=>Zr,memoryWithVectors:()=>Qr,observableAdapter:()=>dr,openAICompatAdapter:()=>or,parseRateLimitFromError:()=>at,pricingFor:()=>fr,promptNode:()=>ct,redactor:()=>Kr,registryPricing:()=>mr,resilientAdapter:()=>wr,streamExtractor:()=>Gr,streamingPromptNode:()=>Ir,suggestStrategy:()=>zt,suggestStrategyReactive:()=>ln,systemPromptBuilder:()=>Dr,tier:()=>ir,toolCallExtractor:()=>$r,toolExecution:()=>pt,toolRegistry:()=>ft,toolSelector:()=>zr,validateGraphDef:()=>dn,withBreaker:()=>rt,withBudgetGate:()=>ot,withDryRun:()=>yr,withRateLimiter:()=>it,withReplayCache:()=>Xe,withRetry:()=>lt,withTimeout:()=>dt,zeroPrice:()=>$e});function Ne(t,e){return`${t}::${e}`}function lr(t){let e=De({name:"capabilitiesRegistry"}),r=i=>{e.set(Ne(i.provider,i.id),i)};if(t)for(let i of t)r(i);let n=(i,u)=>{let c=e.get(Ne(i,u));if(c)return c;let m=e.entries.cache;if(!m)return;let p;for(let[,y]of m){if(y.provider!==i)continue;let g=y.id;u.startsWith(g)&&(!p||g.length>p.id.length)&&(p=y)}return p},o=128,a=new Map,s=new Map,l=(i,u,c,m)=>{for(i.has(u)&&i.delete(u),i.set(u,c);i.size>m;){let p=i.keys().next().value;if(p===void 0)break;i.delete(p)}},d=M([e.entries],([i])=>Array.from(i.values()),{name:"capabilitiesRegistry/entries",initial:[]});return{register:r,lookup:n,remove(i,u){let c=e.has(Ne(i,u));return c&&e.delete(Ne(i,u)),c},entries(){let i=e.entries.cache;return(function*(){if(i)for(let u of i.values())yield u})()},lookupNode(i,u){let c=Ne(i,u),m=a.get(c);if(m)return a.delete(c),a.set(c,m),m;let p=M([e.entries],()=>n(i,u),{name:`capabilitiesRegistry/lookup/${i}::${u}`,initial:void 0});return l(a,c,p,o),p},entriesNode:d,byProvider(i){let u=s.get(i);if(u)return s.delete(i),s.set(i,u),u;let c=M([d],([m])=>m.filter(p=>p.provider===i),{name:`capabilitiesRegistry/byProvider/${i}`,initial:[]});return l(s,i,c,o),c}}}function ae(t){let e=t.input,r=e.regular+(e.cacheRead??0)+(e.cacheWrite5m??0)+(e.cacheWrite1h??0)+(e.cacheWriteOther??0)+(e.audio??0)+(e.image??0)+(e.video??0)+(e.toolUse??0);if(!e.extensions)return r;let n=0;for(let o of Object.values(e.extensions))n+=o;return r+n}function de(t){let e=t.output,r=e.regular+(e.reasoning??0)+(e.audio??0)+(e.predictionAccepted??0)+(e.predictionRejected??0);if(!e.extensions)return r;let n=0;for(let o of Object.values(e.extensions))n+=o;return r+n}function It(){return{input:{regular:0},output:{regular:0}}}function dr(t,e){let r=e?.logMax??1e3,n=Te(void 0,{name:e?.name?`${e.name}/stats`:"adapterStats",maxSize:r}),o=k(null,{name:"adapterStats/lastCall"}),a=M([n.entries],([g])=>g.length,{name:"adapterStats/totalCalls",initial:0}),s=M([n.entries],([g])=>g.reduce((f,h)=>f+ae(h.usage),0),{name:"adapterStats/totalInputTokens",initial:0}),l=M([n.entries],([g])=>g.reduce((f,h)=>f+de(h.usage),0),{name:"adapterStats/totalOutputTokens",initial:0}),d=[U(a),U(s),U(l)],i=g=>{n.append(g),o.emit(g)},u=()=>{n.clear(),o.emit(null)},c=ee(t,{invoke(g,f){let h=re(),v=Le(),b=t.model??f?.model??"",R=A=>(i(ge({provider:t.provider,model:t.model??f?.model??A.model??"",tier:f?.tier??A.tier,usage:A.usage??ie(),startNs:h,startWallClockNs:v,method:"invoke"})),A),E=A=>{let F=A;i(ge({provider:t.provider,model:b,tier:f?.tier,usage:ie(),startNs:h,startWallClockNs:v,method:"invoke",error:{type:F?.name??"Error",message:F?.message??String(A)}}))};return Pe(t.invoke(g,f),{onResp:R,onError:E,name:"adapterStats/invokeTap"})},async*stream(g,f){let h=re(),v=Le(),b=t.model??f?.model??"",R;try{for await(let E of t.stream(g,f))E.type==="usage"&&(R=E.usage),yield E;i(ge({provider:t.provider,model:b,tier:f?.tier,usage:R??ie(),startNs:h,startWallClockNs:v,method:"stream"}))}catch(E){let A=E;throw i(ge({provider:t.provider,model:b,tier:f?.tier,usage:R??ie(),startNs:h,startWallClockNs:v,method:"stream",error:{type:A?.name??"Error",message:A?.message??String(E)}})),E}}});te(c,"observableAdapter",t);let m=!1;return{adapter:c,stats:{lastCall:o,allCalls:n,totalCalls:a,totalInputTokens:s,totalOutputTokens:l,reset:u,dispose:()=>{if(!m){m=!0;for(let g of d)g();d.length=0}}}}}function ur(t,e){return t==null?0:typeof t=="number"?t:t.thresholdTokens!=null&&t.pricePerMillionAbove!=null&&e>t.thresholdTokens?t.pricePerMillionAbove:t.pricePerMillion}function $e(t="USD"){return{total:0,currency:t}}function tt(t,e,r){let n=ae(t),o=e.currency??"USD",a=r?.withBreakdown===!0,s=a?{}:null,l=0,d=(f,h,v)=>{if(!h||v==null)return;let b=ur(v,n),R=h*b/1e6;l+=R,a&&(s[f]=(s[f]??0)+R)},i=t.input,u=e.input;if(u&&(d("input.regular",i.regular,u.regular),d("input.cacheRead",i.cacheRead??0,u.cacheRead),d("input.cacheWrite5m",i.cacheWrite5m??0,u.cacheWrite5m),d("input.cacheWrite1h",i.cacheWrite1h??0,u.cacheWrite1h),d("input.cacheWriteOther",i.cacheWriteOther??0,u.cacheWriteOther),d("input.audio",i.audio??0,u.audio),d("input.image",i.image??0,u.image),d("input.video",i.video??0,u.video),d("input.toolUse",i.toolUse??0,u.toolUse),i.extensions&&u.extensions))for(let[f,h]of Object.entries(i.extensions))d(`input.ext.${f}`,h,u.extensions[f]);let c=t.output,m=e.output;if(m&&(d("output.regular",c.regular,m.regular),d("output.reasoning",c.reasoning??0,m.reasoning),d("output.audio",c.audio??0,m.audio),d("output.predictionAccepted",c.predictionAccepted??0,m.predictionAccepted),d("output.predictionRejected",c.predictionRejected??0,m.predictionRejected),c.extensions&&m.extensions))for(let[f,h]of Object.entries(c.extensions))d(`output.ext.${f}`,h,m.extensions[f]);let p=r?.tier;if(p&&e.tierMultipliers){let f=e.tierMultipliers[p];if(f!=null&&(l*=f,a))for(let h of Object.keys(s))s[h]*=f}let y=t.auxiliary,g=e.auxiliary;if(y&&g)for(let[f,h]of Object.entries(y)){let v=g[f];if(v==null||!h)continue;let b=h*v;l+=b,a&&(s[`auxiliary.${f}`]=b)}return a?{total:l,currency:o,breakdown:s}:{total:l,currency:o}}function Be(t,e){return`${t}::${e}`}function cr(t){let e=new Map,r=new Map,n=(o,a,s)=>{e.set(Be(o,a),{provider:o,model:a,pricing:s});let l=r.get(o);l||(l=new Set,r.set(o,l)),l.add(a)};if(t)for(let[o,a,s]of t)n(o,a,s);return{register:n,lookup(o,a){let s=e.get(Be(o,a));if(s)return s.pricing;let l=r.get(o);if(!l)return;let d;for(let i of l)if(a.startsWith(i)&&(!d||i.length>d.key.length)){let u=e.get(Be(o,i));u&&(d={key:i,pricing:u.pricing})}return d?.pricing},remove(o,a){let s=e.delete(Be(o,a));if(s){let l=r.get(o);l?.delete(a),l&&l.size===0&&r.delete(o)}return s},entries(){let o=e.values();return(function*(){for(let{provider:a,model:s,pricing:l}of o)yield[a,s,l]})()}}}function mr(t,e="USD"){return(r,n)=>{let o=t.lookup(n.provider,n.model);return o?tt(r,o,{tier:n.tier,withBreakdown:n.withBreakdown}):$e(e)}}function pr(...t){return(e,r)=>{for(let n of t){let o=n(e,r);if(o.total!==0)return o}return t.length>0?t[0](e,r):$e()}}function fr(t,e,r){return t?.pricing?tt(e,t.pricing,r):$e()}function rt(t,e={}){let r=e.breaker??vt(e),n=ee(t,{async invoke(o,a){if(!r.canExecute())throw new Oe;try{let s=await ce(w(t.invoke(o,a)));return r.recordSuccess(),s}catch(s){throw r.recordFailure(s),s}},async*stream(o,a){if(!r.canExecute())throw new Oe;try{for await(let s of t.stream(o,a))yield s;r.recordSuccess()}catch(s){throw r.recordFailure(s),s}}});return te(n,"withBreaker",t),{adapter:n,breaker:r}}var We=class extends Error{constructor(r,n,o){super(`Budget exhausted: ${r} (limit=${n}, observed=${o})`);this.which=r;this.limit=n;this.observed=o}name="BudgetExhaustedError"},nt=Object.freeze({calls:0,inputTokens:0,outputTokens:0,usd:0}),Ot=()=>({calls:0,inputTokens:0,outputTokens:0,usd:0});function ot(t,e){let r=Te(void 0,{name:e.name?`${e.name}/log`:"budgetGate/log",maxSize:e.logMax??1e3}),n=k(Ot(),{name:e.name?`${e.name}/totals`:"budgetGate/totals"}),o=M([n],([i])=>{let u=i;return!(e.caps.calls!=null&&u.calls>=e.caps.calls||e.caps.inputTokens!=null&&u.inputTokens>=e.caps.inputTokens||e.caps.outputTokens!=null&&u.outputTokens>=e.caps.outputTokens||e.caps.usd!=null&&u.usd>=e.caps.usd)},{name:e.name?`${e.name}/isOpen`:"budgetGate/isOpen",initial:!0});if(U(o),e.onExhausted!=null){let i=e.onExhausted,u=!1,c=!0;o.subscribe(m=>{for(let p of m)if(p[0]===Q){let y=p[1];if(u&&c&&y===!1){let g=Dt(n.cache??nt,e.caps);g&&i(g)}c=y,u=!0}})}let a=()=>{if(o.cache===!1){let i=n.cache??nt,u=Dt(i,e.caps);return new We(u??"budget",e.caps[u??"calls"]??0,gr(i,u??"calls"))}},s=(i,u)=>{let c=t.provider,m=ge({provider:c,model:u.model,tier:u.tier,usage:i,startNs:u.startNs,method:u.method,...u.error?{error:u.error}:{}});r.append(m);let p=n.cache??nt,y=e.pricingFn?p.usd+e.pricingFn(i,{model:u.model,provider:c,tier:u.tier}).total:p.usd;n.emit({calls:p.calls+1,inputTokens:p.inputTokens+ae(i),outputTokens:p.outputTokens+de(i),usd:y})},l=()=>{r.clear(),n.emit(Ot())},d=ee(t,{invoke(i,u){let c=a();if(c)return Promise.reject(c);let m=re(),p=t.model??u?.model??"",y=f=>(s(f.usage??ie(),{model:t.model??u?.model??f.model??"",tier:u?.tier??f.tier,startNs:m,method:"invoke"}),f),g=f=>{let h=f;s(ie(),{model:p,tier:u?.tier,startNs:m,method:"invoke",error:{type:h?.name??"Error",message:h?.message??String(f)}})};return Pe(t.invoke(i,u),{onResp:y,onError:g,name:"budgetGate/invokeTap"})},async*stream(i,u){let c=a();if(c)throw c;let m=re(),p;try{for await(let y of t.stream(i,u))y.type==="usage"&&(p=y.usage),yield y;s(p??ie(),{model:t.model??u?.model??"",tier:u?.tier,startNs:m,method:"stream"})}catch(y){let g=y;throw s(p??ie(),{model:t.model??u?.model??"",tier:u?.tier,startNs:m,method:"stream",error:{type:g?.name??"Error",message:g?.message??String(y)}}),y}}});return te(d,"withBudgetGate",t),{adapter:d,budget:{totals:n,isOpen:o,log:r,reset:l}}}function Dt(t,e){if(e.calls!=null&&t.calls>=e.calls)return"calls";if(e.inputTokens!=null&&t.inputTokens>=e.inputTokens)return"inputTokens";if(e.outputTokens!=null&&t.outputTokens>=e.outputTokens)return"outputTokens";if(e.usd!=null&&t.usd>=e.usd)return"usd"}function gr(t,e){switch(e){case"calls":return t.calls;case"inputTokens":return t.inputTokens;case"outputTokens":return t.outputTokens;case"usd":return t.usd}}function yr(t,e){let r=e.mock??Qe({provider:t.provider,model:t.model}),n=typeof e.enabled=="boolean"?e.enabled:void 0,o=n===void 0?w(e.enabled):void 0,a;o&&(a=U(o));let s=()=>n!==void 0?n:!!o?.cache,l=ee(t,{invoke(i,u){return s()?r.invoke(i,u):t.invoke(i,u)},stream(i,u){return s()?r.stream(i,u):t.stream(i,u)}});return te(l,"withDryRun",t),{adapter:l,dispose:()=>{a&&(a(),a=void 0)}}}function at(t){if(t==null||typeof t!="object")return;let e=t,r=e.status,n=hr(e.headers);if(r!==429&&r!==503&&!Rr(e.message))return;let o={},a=n("retry-after"),s=Tr(a);s!=null&&(o.retryAfterMs=s);let l=n("anthropic-ratelimit-requests-reset");if(l){let p=Pt(l);p!=null&&(o.retryAfterMs=Math.max(o.retryAfterMs??0,p))}let d=n("anthropic-ratelimit-tokens-reset");if(d){let p=Pt(d);p!=null&&(o.retryAfterMs=Math.max(o.retryAfterMs??0,p))}let i=Ke(n,"x-ratelimit-limit-requests");i!=null&&(o.rpmCap=i);let u=Ke(n,"x-ratelimit-limit-tokens");u!=null&&(o.tpmCap=u);let c=Ke(n,"x-ratelimit-remaining-requests"),m=Ke(n,"x-ratelimit-remaining-tokens");if(c!=null&&i!=null&&i>0&&(o.usageHint??={},o.usageHint.rpm=1-c/i),m!=null&&u!=null&&u>0&&(o.usageHint??={},o.usageHint.tpm=1-m/u),o.retryAfterMs==null&&e.message){let p=Mr(e.message);p!=null&&(o.retryAfterMs=p)}return e.headers&&(o.metadata={headers:br(e.headers)}),o.retryAfterMs==null&&o.rpmCap==null&&o.tpmCap==null&&o.usageHint==null?o.metadata?o:void 0:o}function hr(t){if(!t)return()=>{};if(typeof t.get=="function"){let n=t;return o=>n.get(o)??n.get(o.toLowerCase())??void 0}let e=t,r={};for(let[n,o]of Object.entries(e)){let a=Array.isArray(o)?o.join(", "):o;a!=null&&(r[n.toLowerCase()]=a)}return n=>r[n.toLowerCase()]}function br(t){let e={};if(typeof t.forEach=="function")return t.forEach((r,n)=>{e[n]=r}),e;for(let[r,n]of Object.entries(t))n!=null&&(e[r]=Array.isArray(n)?n.join(", "):n);return e}function Ke(t,e){let r=t(e);if(r==null)return;let n=Number(r);return Number.isFinite(n)?n:void 0}function Tr(t){if(!t)return;let e=t.trim(),r=Number(e);if(Number.isFinite(r)&&r>=0)return r*1e3;let n=Date.parse(e);if(Number.isFinite(n)){let o=n-Date.now();if(o>0)return o}}function Pt(t){if(!t)return;let e=Date.parse(t);if(Number.isFinite(e))return Math.max(0,e-Date.now())}var vr=/retry\s+(?:in|after)\s+(\d+(?:\.\d+)?)\s*(ms|s|sec|seconds?|m|min|minutes?)/i;function Mr(t){let e=vr.exec(t);if(!e)return;let r=Number(e[1]);if(!Number.isFinite(r))return;let n=(e[2]??"s").toLowerCase();if(n==="ms")return r;if(n.startsWith("s"))return r*1e3;if(n.startsWith("m"))return r*6e4}var kr=/rate\s*limit|too\s*many\s*requests|quota|429/i;function Rr(t){return!!t&&kr.test(t)}function st(t){let e=new Error(t);return e.name="AbortError",e}function jt(t={}){let e=Math.max(1,t.burstMultiplier??1),r=t.clampCooldownMs??6e4,n=t.rpm!=null?w(t.rpm):k(Number.POSITIVE_INFINITY),o=t.tpm!=null?w(t.tpm):k(Number.POSITIVE_INFINITY),a=k(Number.POSITIVE_INFINITY,{name:"adaptiveRateLimiter/signalRpmCap"}),s=k(Number.POSITIVE_INFINITY,{name:"adaptiveRateLimiter/signalTpmCap"}),l=k({},{name:"adaptiveRateLimiter/lastSignal"}),d=M([n,a],([x,D])=>Math.min(Number(x??1/0),Number(D??1/0)),{name:"adaptiveRateLimiter/effectiveRpm"}),i=M([o,s],([x,D])=>Math.min(Number(x??1/0),Number(D??1/0)),{name:"adaptiveRateLimiter/effectiveTpm"}),u=ve(Number(n.cache??Number.POSITIVE_INFINITY),e),c=ve(Number(o.cache??Number.POSITIVE_INFINITY),e),m=!1,p=!1,y=d.subscribe(x=>{for(let D of x)if(D[0]===Q){let _=Number(D[1]);Number.isFinite(_)&&_>0?(u=ve(_,e),m=!1):_===1/0?(u=ve(1/0,e),m=!1):_<=0&&(m=!0)}}),g=i.subscribe(x=>{for(let D of x)if(D[0]===Q){let _=Number(D[1]);Number.isFinite(_)&&_>0?(c=ve(_,e),p=!1):_===1/0?(c=ve(1/0,e),p=!1):_<=0&&(p=!0)}}),f=0,h=new se,v=new se,b;t.adaptation!=null&&(b=w(t.adaptation).subscribe(D=>{for(let _ of D)_[0]===Q&&R(_[1])}));function R(x){if(l.emit(x),x.rpmCap!=null&&Number.isFinite(x.rpmCap)&&x.rpmCap>=0&&(a.emit(x.rpmCap),Number.isFinite(r)&&r>0&&h.start(r,()=>a.emit(Number.POSITIVE_INFINITY))),x.tpmCap!=null&&Number.isFinite(x.tpmCap)&&x.tpmCap>=0&&(s.emit(x.tpmCap),Number.isFinite(r)&&r>0&&v.start(r,()=>s.emit(Number.POSITIVE_INFINITY))),x.retryAfterMs!=null&&x.retryAfterMs>0){let D=re()+x.retryAfterMs*1e6;D>f&&(f=D)}}let E=k(0,{name:"adaptiveRateLimiter/pending"}),A=k(Number.POSITIVE_INFINITY,{name:"adaptiveRateLimiter/rpmAvailable"}),F=k(Number.POSITIVE_INFINITY,{name:"adaptiveRateLimiter/tpmAvailable"}),B=x=>{E.emit((E.cache??0)+x)},C=()=>{A.emit(u.available()),F.emit(c.available())};async function I(x={}){let D=x.requestCost??1,_=x.tokenCost??0,J=x.signal;B(1);try{for(;;){if(J?.aborted)throw st("AdaptiveRateLimiter.acquire aborted");let P=re();if(f>P){let T=Math.ceil((f-P)/1e6);await Ue(T,J);continue}if(D>0&&m||_>0&&p){await Ue(250,J);continue}let $=u,G=c;if(!$.tryConsume(D)){await Ue(_t($,D),J);continue}if(!(_>0?G.tryConsume(_):!0)){$.putBack(D),await Ue(_t(G,_),J);continue}C();return}}finally{B(-1)}}function L(x){x>0?c.tryConsume(x):x<0&&c.putBack(-x),C()}function O(){y(),g(),b?.(),h.cancel(),v.cancel()}return{effectiveRpm:d,effectiveTpm:i,lastSignal:l,pending:E,rpmAvailable:A,tpmAvailable:F,acquire:I,recordUsage:L,recordSignal:R,dispose:O}}function ve(t,e){if(!Number.isFinite(t)||t===1/0)return Ye(Number.MAX_SAFE_INTEGER,Number.MAX_SAFE_INTEGER);let r=Math.max(1,t*e),n=t/60;return Ye(r,n)}function _t(t,e){let r=t.available(),n=Math.max(0,e-r);return n<=0?25:Math.min(5e3,Math.max(50,n*100))}function Ue(t,e){return t<=0?Promise.resolve():e?.aborted?Promise.reject(st("AdaptiveRateLimiter.acquire aborted")):new Promise((r,n)=>{let o=new se,a,s=()=>{o.cancel(),e&&a&&e.removeEventListener("abort",a)};o.start(t,()=>{s(),r()}),e&&(a=()=>{s(),n(st("AdaptiveRateLimiter.acquire aborted"))},e.addEventListener("abort",a,{once:!0}))})}function it(t,e={}){let r=e.limiter??jt({name:e.name??"rateLimiter",rpm:e.rpm,tpm:e.tpm,adaptation:e.adaptation,burstMultiplier:e.burstMultiplier}),n=(s,l)=>e.costFn?e.costFn(s,l):0,o=s=>{let l=at(s);l&&r.recordSignal(l)},a=ee(t,{async invoke(s,l){let d=n(s,l);await r.acquire({requestCost:1,tokenCost:d,signal:l?.signal});try{let i=await ce(w(t.invoke(s,l))),u=i.usage??It(),m=ae(u)+de(u)-d;return m>0&&r.recordUsage(m),i}catch(i){throw o(i),i}},async*stream(s,l){let d=n(s,l);await r.acquire({requestCost:1,tokenCost:d,signal:l?.signal});try{let i=0;for await(let c of t.stream(s,l))c.type==="usage"&&(i=ae(c.usage)+de(c.usage)),yield c;let u=i-d;u>0&&r.recordUsage(u)}catch(i){throw o(i),i}}});return te(a,"withRateLimiter",t),{adapter:a,limiter:r}}function Ve(t="aborted"){let e=new Error(t);return e.name="AbortError",e}function Ft(t,e){return t<=0?Promise.resolve():e?.aborted?Promise.reject(Ve()):new Promise((r,n)=>{let o=new se,a,s=()=>{o.cancel(),e&&a&&e.removeEventListener("abort",a)};o.start(t,()=>{s(),r()}),e&&(a=()=>{s(),n(Ve())},e.addEventListener("abort",a,{once:!0}))})}function lt(t,e={}){let r=e.attempts??3,n=e.baseDelayMs??500,o=e.maxDelayMs??1e4,a=e.strategy??"decorrelated",s=e.jitter??!0,l=e.shouldRetry??xr,d=e.retryStreaming??!0,i=(c,m)=>{if(a==="decorrelated"){let f=Math.min(o,Math.max(n,m*3));return n+Math.random()*(f-n)}let p=a==="exp"?n*2**(c-1):n*c,y=Math.min(o,p);if(!s)return y;let g=y*(.5+Math.random());return Math.min(o,g)},u=ee(t,{async invoke(c,m){if(m?.signal?.aborted)throw Ve();let p,y=n;for(let g=1;g<=r;g++)try{return await ce(w(t.invoke(c,m)))}catch(f){if(p=f,g>=r||!l(f,g))throw f;let h=i(g,y);y=h,await Ft(h,m?.signal)}throw p},async*stream(c,m){if(m?.signal?.aborted)throw Ve();if(!d){for await(let g of t.stream(c,m))yield g;return}let p,y=n;for(let g=1;g<=r;g++){let f=!1;try{for await(let h of t.stream(c,m))f=!0,yield h;return}catch(h){if(p=h,f||g>=r||!l(h,g))throw h;let v=i(g,y);y=v,await Ft(v,m?.signal)}}throw p}});return te(u,"withRetry",t),u}function xr(t,e){if(t==null)return!1;let r=t;return r.name==="LLMTimeoutError"?!0:r.name==="AbortError"||r.message==="aborted"||r.name==="DOMException"&&r.code!=null&&Number(r.code)===20||r.name==="BudgetExhaustedError"||r.name==="CircuitOpenError"?!1:r.status!=null?r.status===429||r.status>=500&&r.status<600:r.code&&typeof r.code=="string"&&/^E[A-Z]+$/.test(r.code)?!0:r.message?/network|timeout|socket|fetch|econn|eai_/i.test(r.message):!1}var Me=class extends Error{constructor(r){super(`LLM call timed out after ${r}ms`);this.ms=r}name="LLMTimeoutError"};function dt(t,e){if(e<=0)throw new RangeError("withTimeout: ms must be > 0");let r=a=>{let s=new AbortController,l=!1,d,i=new se;return a&&(a.aborted?s.abort(a.reason):(d=()=>{i.cancel(),s.abort(a.reason)},a.addEventListener("abort",d,{once:!0}))),i.start(e,()=>{l=!0,s.abort(new Me(e))}),{signal:s.signal,cancel:()=>{i.cancel(),a&&d&&a.removeEventListener("abort",d)},timedOut:()=>l}},n=(a,s)=>{if(!s||a instanceof Me)throw a;let l=a;if(l?.name==="AbortError"||l?.name==="DOMException"&&Number(l.code)===20||a?.message==="aborted"){let i=new Me(e);throw i.cause=a,i}throw a},o=ee(t,{async invoke(a,s){let{signal:l,cancel:d,timedOut:i}=r(s?.signal);try{return await ce(w(t.invoke(a,{...s,signal:l})))}catch(u){return n(u,i())}finally{d()}},async*stream(a,s){let{signal:l,cancel:d,timedOut:i}=r(s?.signal);try{for await(let u of t.stream(a,{...s,signal:l}))yield u}catch(u){n(u,i())}finally{d()}}});return te(o,"withTimeout",t),o}function wr(t,e={}){let r={adapter:t},n=t;if(e.rateLimit){let o=it(n,e.rateLimit);n=o.adapter,r.rateLimiter=o.limiter}if(e.budget){let o=ot(n,e.budget);n=o.adapter,r.budget=o.budget}if(e.breaker){let o=rt(n,e.breaker);n=o.adapter,r.breaker=o.breaker}if(e.timeoutMs!=null&&(n=dt(n,e.timeoutMs)),e.retry&&(n=lt(n,e.retry)),e.fallback){if(e.name==="fallback")throw new RangeError('resilientAdapter: `name` cannot be "fallback" \u2014 collides with the secondary tier label.');let o={};e.onFallback&&(o.onFallback=e.onFallback),e.onExhausted&&(o.onExhausted=e.onExhausted),n=Ze([{name:e.name??"primary",adapter:n},{name:"fallback",adapter:e.fallback}],o)}return e.cache&&(n=Xe(n,e.cache)),r.adapter=n,r}function Lr(t,e,r){let n=w(e);return Y(n,a=>{if(!a||a.length===0)return k(null);let s=r?.tools;return t.invoke(a,{model:r?.model,temperature:r?.temperature,maxTokens:r?.maxTokens,tools:s,systemPrompt:r?.systemPrompt})})}function N(t,e){return wt("ai",t,e)}function Nr(t){return t!=null&&typeof t.then=="function"}function ut(t){return typeof t=="object"&&t!==null&&"subscribe"in t&&typeof t.subscribe=="function"&&"cache"in t}function Ar(t){return t!=null&&typeof t=="object"&&Symbol.asyncIterator in t&&typeof t[Symbol.asyncIterator]=="function"}var Cr=3e4;function Gt(t,e){if(t.status==="settled"){let n=t.cache;if(n!==void 0)return Promise.resolve(n)}let r=e?.timeoutMs??Cr;return new Promise((n,o)=>{let a=new se,s=t.subscribe(l=>{for(let d of l){if(d[0]===Q){a.cancel(),s(),n(d[1]);return}if(d[0]===X){a.cancel(),s(),o(d[1]);return}if(d[0]===le){a.cancel(),s(),o(new Error("firstDataFromNode: completed without producing a value"));return}}});a.start(r,()=>{s(),o(new Error(`firstDataFromNode: timed out after ${r}ms`))})})}async function Ae(t){return Nr(t)?Ae(await t):ut(t)?Gt(t):Ar(t)?Gt(w(t)):t}function ke(t){let e=t.match(/^```(?:json)?\s*([\s\S]*?)\s*```[\s\S]*$/);return e?e[1]:t}function Sr(t,e){let r=w(t),n=e?.refreshTrigger!=null?w(e.refreshTrigger):null;return n==null?fe([r],(o,a,s)=>{if(s.store.emitted===!0)return;let d=o[0],i=d!=null&&d.length>0?d.at(-1):s.prevData[0];if(i!==void 0)return s.store.emitted=!0,a.emit(i),{invalidate:()=>{s.store.emitted=!1}}},{name:e?.name??"frozenContext",describeKind:"derived",initial:null,meta:N("frozen_context")}):fe([r,n],(o,a,s)=>{let l=o[1];if(!(l!=null&&l.length>0))return;let i=o[0],u=i!=null&&i.length>0?i.at(-1):s.prevData[0];a.emit(u)},{name:e?.name??"frozenContext",describeKind:"derived",initial:null,meta:N("frozen_context")})}function Bt(t){return t!=null&&typeof t=="object"&&"content"in t?String(t.content):typeof t=="string"?t:String(t)}function Er(t,e=200){return t.length<=e?t:`${t.slice(0,e)}\u2026`}function ct(t,e,r,n){let o=n?.format??"text",a=n?.name??"prompt_node",s=M(e,d=>{if(d.some(u=>u==null))return[];let i=typeof r=="string"?r:r(...d);return i?[{role:"user",content:i}]:[]},{name:`${a}::messages`,meta:N("prompt_node")});return Y(s,d=>!d||d.length===0?k(null):ue(i=>{let u=!1,c=!1,m,p={model:n?.model,temperature:n?.temperature,maxTokens:n?.maxTokens,systemPrompt:n?.systemPrompt};if(n?.abort){let h=xt(n.abort);p.signal=h.signal,m=h.dispose}let y;try{y=t.invoke(d,p)}catch(h){return u=!0,i.down([[X,h]]),()=>{m?.()}}let f=w(y).subscribe(h=>{if(!(c||u))for(let v of h){if(u)return;if(v[0]===Q){let b=v[1];try{let R=Bt(b),E=o==="json"?JSON.parse(ke(R)):R;i.emit(E)}catch(R){let E=Bt(b),A=new Error(`promptNode: failed to parse LLM response as JSON: ${R.message}
|
|
2
|
-
Raw content (first 200 chars): ${Er(E)}`);u=!0,i.down([[X,A]]);return}}else if(v[0]===X){u=!0,i.down([[X,v[1]]]);return}else if(v[0]===le){u=!0,i.down([[le]]);return}else i.down([v])}});return()=>{c=!0,f(),m?.()}},{name:`${a}::call`,meta:N("prompt_node::call")}),{name:`${a}::output`,meta:n?.meta?{...N("prompt_node::output"),...n.meta}:N("prompt_node::output")})}async function $t(t,e,r,n){let o="",a=0;for await(let s of t.stream(e,r))n.publish({...s,seq:a++,ts:Le()}),s.type==="token"&&(o+=s.delta);return o}function Wt(t,e){if(e==="json")try{return JSON.parse(ke(t))}catch(r){let n=t.slice(0,160);throw new Error(`streamingPromptNode: format:"json" \u2014 failed to parse accumulated text as JSON: ${r.message}; content preview: ${n}`)}return t}function Kt(t,e){return M([t.latest],([r],n)=>{let o=n.store;if(r==null)return o.acc??"";let a=r;return a.seq===0&&(o.acc=""),a.type==="token"&&(o.acc=(o.acc??"")+a.delta),o.acc??""},{name:e,meta:N("accumulated_text"),initial:""})}function Ir(t,e,r,n){let o=n?.name??"llm",a=n?.format??"text",s=et(`${o}/stream`,{...n?.retainedLimit!=null?{retainedLimit:n.retainedLimit}:{}}),l=M(e,c=>{if(c.some(p=>p==null))return[];let m=typeof r=="string"?r:r(...c);return m?[{role:"user",content:m}]:[]},{name:`${o}::messages`,meta:N("prompt_node::messages"),initial:[]}),d=Y(l,c=>{let m=c;if(!m||m.length===0)return k(null);let p=new AbortController;async function*y(){try{let g=await $t(t,m,{model:n?.model,temperature:n?.temperature,maxTokens:n?.maxTokens,systemPrompt:n?.systemPrompt,signal:p.signal},s);yield Wt(g,a)}finally{p.abort()}}return w(y())}),i=Kt(s,`${o}::accumulatedText`),u=U(d);return{output:d,deltaTopic:s,accumulatedText:i,dispose:()=>{u(),s.destroy()}}}function Or(t,e,r,n,o,a){let s=k(0,{name:`${e}/cancel`}),l=0,d=[...n,s],i=a?.name??e,u=a?.format??"text",c=et(`${i}/stream`,{...a?.retainedLimit!=null?{retainedLimit:a.retainedLimit}:{}}),m=M(d,A=>{let F=A.slice(0,-1);if(F.some(C=>C==null))return[];let B=typeof o=="string"?o:o(...F);return B?[{role:"user",content:B}]:[]},{name:`${i}::messages`,meta:N("prompt_node::messages"),initial:[]}),p=Y(m,A=>{let F=A;if(!F||F.length===0)return k(null);let B=new AbortController;async function*C(){try{let I=await $t(r,F,{model:a?.model,temperature:a?.temperature,maxTokens:a?.maxTokens,systemPrompt:a?.systemPrompt,signal:B.signal},c);yield Wt(I,u)}finally{B.abort()}}return w(C())}),y=Kt(c,`${i}::accumulatedText`),g=Lt(p,A=>A!=null);t.add(g,{name:`${e}/raw`});let f=St(t,`${e}/gate`,`${e}/raw`,a?.gate),h=U(p),v=U(f.node),b=U(y);t.addDisposer(h),t.addDisposer(v),t.addDisposer(b);let R=f.reject.bind(f),E={...f,reject(A=1){Z(()=>{R(A),s.emit(++l)})}};return{output:f.node,deltaTopic:c,accumulatedText:y,gate:E,dispose:()=>{h(),v(),b(),c.destroy()}}}function Dr(t,e){let r=e?.separator??`
|
|
3
|
-
|
|
4
|
-
`,n=t.map(s=>typeof s=="string"?k(s):w(s)),o=M(n,s=>s.filter(l=>l!=null&&l!=="").join(r),{name:e?.name??"systemPrompt",describeKind:"derived",meta:N("system_prompt"),initial:""}),a=U(o);return Object.assign(o,{dispose:a})}var Pr=(t,e)=>t===e?!0:t.chunkCount===e.chunkCount&&t.charCount===e.charCount&&t.estimatedTokens===e.estimatedTokens&&t.estimated===e.estimated;function _r(t,e){let r=e?.charsPerToken??4,n={chunkCount:0,charCount:0,estimatedTokens:0,estimated:!0};return M([t.latest],([o],a)=>{if(o==null)return n;let s=o;"chunkCount"in a.store||(a.store.chunkCount=0,a.store.charCount=0,a.store.usageTokens=0,a.store.sawUsage=!1);let l=a.store;s.type==="token"?(l.chunkCount+=1,l.charCount+=s.delta.length):s.type==="usage"&&(l.sawUsage=!0,l.usageTokens=ae(s.usage)+de(s.usage));let d=l.sawUsage?l.usageTokens:Math.ceil(l.charCount/r);return{chunkCount:l.chunkCount,charCount:l.charCount,estimatedTokens:d,estimated:!l.sawUsage}},{name:e?.name??"cost-meter",describeKind:"derived",initial:n,meta:N("cost_meter_extractor"),equals:Pr})}var jr=(t,e)=>{if(t===e)return!0;if(t==null||e==null)return t===e;if(t.length!==e.length)return!1;for(let r=0;r<t.length;r++){let n=t[r],o=e[r];if(n.label!==o.label||n.pattern!==o.pattern||n.match!==o.match||n.position!==o.position)return!1}return!0};function Fr(t,e){let r=e.maxPatternLength??128;for(let o of e.patterns)if(o.pattern.source.length>r)throw new Error(`keywordFlagExtractor: pattern "${o.label}" literal exceeds maxPatternLength (${o.pattern.source.length} > ${r}); raise the option or shorten the pattern.`);let n=e.patterns.map(o=>({label:o.label,pattern:o.pattern,compiled:new RegExp(o.pattern.source,`${o.pattern.flags.replace("g","")}g`)}));return M([t],([o],a)=>{if(o==null)return[];let s=o;"flags"in a.store||(a.store.flags=[],a.store.scannedTo=0);let l=a.store.flags,d=a.store.scannedTo,i=Math.max(0,d-r),u=s.slice(i),c=!1;for(let{pattern:m,label:p,compiled:y}of n){y.lastIndex=0;for(let g of u.matchAll(y)){let f=i+(g.index??0);f+g[0].length<=d||(l.push({label:p,pattern:m,match:g[0],position:f}),c=!0)}}return a.store.scannedTo=s.length,c?[...l]:l.slice()},{name:e.name??"keyword-flag-extractor",describeKind:"derived",initial:[],meta:N("keyword_flag_extractor"),equals:jr})}function Gr(t,e,r){return M([t],([n])=>n==null?null:e(n),{name:r?.name??"extractor",describeKind:"derived",initial:null,meta:N("stream_extractor"),...r?.equals?{equals:r.equals}:{}})}var Br=(t,e)=>{if(t===e)return!0;if(t==null||e==null)return t===e;if(t.length!==e.length)return!1;for(let r=0;r<t.length;r++){let n=t[r],o=e[r];if(n.startIndex!==o.startIndex||n.name!==o.name||n.raw!==o.raw)return!1}return!0};function $r(t,e){return M([t],([r],n)=>{if(r==null)return[];let o=r;"calls"in n.store||(n.store.calls=[],n.store.scanFrom=0);let a=n.store.calls,s=n.store.scanFrom,l=!1;for(;s<o.length;){let d=o.indexOf("{",s);if(d===-1){n.store.scanFrom=o.length;break}let i=0,u=-1,c=!1;for(let p=d;p<o.length;p++){let y=o[p];if(c)y==="\\"&&p+1<o.length?p++:y==='"'&&(c=!1);else if(y==='"')c=!0;else if(y==="{")i++;else if(y==="}"&&(i--,i===0)){u=p;break}}if(u===-1){n.store.scanFrom=d;break}let m=o.slice(d,u+1);try{let p=JSON.parse(m);typeof p.name=="string"&&p.arguments!=null&&typeof p.arguments=="object"&&(a.push({name:p.name,arguments:p.arguments,raw:m,startIndex:d}),l=!0)}catch{}s=u+1,n.store.scanFrom=s}return l?[...a]:a.slice()},{name:e?.name??"tool-call-extractor",describeKind:"derived",initial:[],meta:N("tool_call_extractor"),equals:Br})}function Wr(t,e,r,n){let o=r*(n?.hardMultiplier??1.5),a=typeof e!="function",s=[t];return a&&s.push(e),M(s,l=>{let d=l[0]??"";if(d.length===0)return"allow";let i=a?l[1]??0:e(d);return i>=o?"block":i>=r?"review":"allow"},{name:n?.name??"content-gate",initial:"allow"})}function Kr(t,e,r,n){let o=r??(()=>"[REDACTED]");function a(s){let l=s;for(let d of e){let i=d.global?d:new RegExp(d.source,`${d.flags}g`);l=l.replace(i,u=>o(u,d))}return l}return M([t],([s])=>a(s??""),{name:n?.name??"redactor",initial:""})}var He=class extends me{_log;messages;latest;messageCount;constructor(e,r={}){super(e,r.graph),this._log=Te([],{name:"messages",maxSize:r.maxMessages}),this.messages=this._log.entries,this.add(this.messages,{name:"messages"}),this.latest=M([this.messages],([n])=>{let o=n;return o.length===0?null:o[o.length-1]},{name:"latest",describeKind:"derived",meta:N("chat_latest")}),this.add(this.latest,{name:"latest"}),this.addDisposer(U(this.latest)),this.messageCount=M([this.messages],([n])=>n.length,{name:"messageCount",describeKind:"derived",meta:N("chat_message_count"),initial:0}),this.add(this.messageCount,{name:"messageCount"}),this.addDisposer(U(this.messageCount))}append(e,r,n){this._log.append({role:e,content:r,...n})}appendToolResult(e,r){this._log.append({role:"tool",content:r,toolCallId:e})}clear(){this._log.clear()}allMessages(){return this.messages.cache}};function mt(t,e){return new He(t,e)}function pt(t){let{toolCalls:e,tools:r}=t,n=t.retryCount??1,o=t.onError??"rescue",a=(s,l)=>{if(s===l)return!0;if(s.length!==l.length)return!1;for(let d=0;d<s.length;d++){let i=s[d],u=l[d];if(i?.id!==u?.id||i?.content!==u?.content)return!1}return!0};return Y(e,s=>{if(s==null||s.length===0)throw new Error("toolExecution: received an empty tool-call batch as DATA \u2014 callers must upstream-filter empty batches (emit RESOLVED) so switchMap is only dispatched for non-empty batches.");let l=s.map(d=>Ur(d,r,n,o));return M(l,d=>d,{name:"toolExecution::batch",equals:a})})}function Ur(t,e,r,n){let o=Tt(()=>e.executeReactive(t.name,t.arguments),{count:r}),a=M([o],([s])=>({id:t.id,content:typeof s=="string"?s:JSON.stringify(s)}));return n==="propagate"?a:At(a,s=>({id:t.id,content:JSON.stringify({error:String(s)})}))}var qe=class extends me{definitions;schemas;_bundle;constructor(e,r={}){super(e,r.graph),this._bundle=De({name:"definitions"}),this.definitions=this._bundle.entries,this.add(this.definitions,{name:"definitions"}),this.schemas=M([this.definitions],([n])=>[...(n??new Map).values()],{name:"schemas",describeKind:"derived",meta:N("tool_schemas"),initial:[]}),this.add(this.schemas,{name:"schemas"}),this.addDisposer(U(this.schemas))}register(e){this._bundle.set(e.name,e)}unregister(e){this._bundle.delete(e)}executeReactive(e,r){let n=this._bundle.get(e);if(!n)throw new Error(`toolRegistry: unknown tool "${e}"`);return ue(o=>{let a=new AbortController,s;try{let d=n.handler(r,{signal:a.signal});s=Vr(d,a.signal)}catch(d){return o.down([[X,d]]),()=>{a.abort()}}let l=s.subscribe(d=>{o.down(d)});return()=>{a.abort(),l()}},{name:`executeReactive::${e}`,meta:N("tool_execute_reactive")})}getDefinition(e){return this._bundle.entries.cache?.get(e)}};function ft(t,e){return new qe(t,e)}function Vr(t,e){return ut(t)?t:t!=null&&typeof t.then=="function"?Je(t,{signal:e}):t!=null&&typeof t=="object"&&Symbol.asyncIterator in t?kt(t,{signal:e}):Je(Promise.resolve(t),{signal:e})}var ze=class extends me{chat;tools;status;turn;aborted;lastResponse;toolCalls;toolResults;_terminalResult;_disposeRunWiring;_running=!1;_currentAbortController=null;constructor(e,r){if(super(e,r.graph),this.chat=mt(`${e}-chat`,{maxMessages:r.maxMessages}),this.mount("chat",this.chat),this.tools=ft(`${e}-tools`),this.mount("tools",this.tools),r.tools)for(let S of r.tools)this.tools.register(S);this.status=k("idle",{name:"status",describeKind:"state",meta:N("agent_status")}),this.add(this.status,{name:"status"}),this.turn=k(0,{name:"turn",describeKind:"state",meta:N("agent_turn_count")}),this.add(this.turn,{name:"turn"}),this.aborted=k(!1,{name:"aborted",describeKind:"state",meta:N("agent_aborted")}),this.add(this.aborted,{name:"aborted"});let n=0,o=this.turn.subscribe(S=>{for(let T of S)T[0]===Q&&(n=T[1])}),a=!1,s=this.aborted.subscribe(S=>{for(let T of S)T[0]===Q&&(a=T[1])}),l=this.chat.messages.cache??[],d=this.chat.messages.subscribe(S=>{for(let T of S)T[0]===Q&&(l=T[1])}),i=this.tools.schemas.cache??[],u=this.tools.schemas.subscribe(S=>{for(let T of S)T[0]===Q&&(i=T[1])}),c=r.adapter,m=r.systemPrompt,p=r.model,y=r.temperature,g=r.maxTokens,f=r.maxTurns??10,h=r.stopWhen,v=this.chat,b=this.tools,R=this.status,E=this.turn,A=this.aborted,F=fe([R],(S,T,V)=>{if(Ce(S,V.prevData,0,"idle")!=="thinking"||a||n>=f){T.down([[be]]);return}if(l.length===0){T.down([[be]]);return}T.emit({messages:l,tools:i})},{name:"promptInput",describeKind:"derived",meta:N("agent_prompt_input")}),B=Y(F,S=>{let T=new AbortController;return this._currentAbortController=T,a&&T.abort(new Error("agentLoop: aborted")),w(c.invoke(S.messages,{tools:S.tools.length>0?S.tools:void 0,systemPrompt:m,model:p,temperature:y,maxTokens:g,signal:T.signal}),{signal:T.signal})},{equals:()=>!1}),C=k(null,{name:"lastResponse",describeKind:"state",meta:N("agent_last_response")});this.lastResponse=C;let I=fe([C,R],(S,T,V)=>{let j=Ce(S,V.prevData,0,null);if(Ce(S,V.prevData,1,"idle")!=="acting"){T.down([[be]]);return}let W=j?.toolCalls;if(W==null||W.length===0){T.down([[be]]);return}T.emit(W)},{name:"toolCallsRaw",describeKind:"derived",meta:N("agent_tool_calls_raw")}),L=r.interceptToolCalls?r.interceptToolCalls(I):I;this.toolCalls=L;let O=pt({toolCalls:L,tools:b,retryCount:1});this.toolResults=O;let x=ne([B],([S])=>{if(a)return;let T=S,V=n+1,j=T.toolCalls!=null&&T.toolCalls.length>0,H=T.finishReason==="end_turn"&&(!T.toolCalls||T.toolCalls.length===0),W=h?.(T)===!0,oe=V>=f,q=W||H||!j||oe?"done":"acting";Z(()=>{C.emit(T),R.emit(q),E.emit(V),v.append("assistant",T.content,{toolCalls:T.toolCalls})})}),D=ne([O],([S])=>{if(a)return;let T=S;if(T.length===0)return;let V=n>=f?"done":"thinking";Z(()=>{R.emit(V);for(let j of T)v.appendToolResult(j.id,j.content)})}),_=R.cache??"idle",J=R.subscribe(S=>{for(let T of S)T[0]===Q&&(_=T[1])}),P=ne([A],([S])=>{S===!0&&(this._currentAbortController?.abort(new Error("agentLoop: aborted")),_!=="done"&&R.emit("done"))}),$=U(x),G=U(D),K=U(P);this._terminalResult=fe([R,C],(S,T,V)=>{let j=Ce(S,V.prevData,0,"idle"),H=Ce(S,V.prevData,1,null);if(j==="done"){if(H!=null){T.emit(H);return}let W=new Error("agentLoop: aborted");W.name="AbortError",T.down([[X,W]]);return}if(j==="error"){T.down([[X,new Error("agentLoop: errored")]]);return}T.down([[be]])},{name:"terminalResult",describeKind:"derived",meta:N("agent_terminal_result")}),this.add(F,{name:"promptInput"}),this.add(B,{name:"llmResponse"}),this.add(this.lastResponse,{name:"lastResponse"}),this.toolCalls===I?this.add(this.toolCalls,{name:"toolCalls"}):(this.add(I,{name:"toolCallsRaw"}),this.add(this.toolCalls,{name:"toolCalls"})),this.add(O,{name:"toolResults"}),this.add(this._terminalResult,{name:"terminalResult"}),this.addDisposer(o),this.addDisposer(s),this.addDisposer(J),this.addDisposer(d),this.addDisposer(u),this.addDisposer($),this.addDisposer(G),this.addDisposer(K),this._disposeRunWiring=()=>{}}async run(e,r){if(this._running)throw new RangeError(`agentLoop "${this.name}": run() called while a previous run() is still pending \u2014 await the previous run before starting another, or call abort() first`);this._running=!0;let n;try{Z(()=>{this.turn.emit(0),this.aborted.emit(!1),this.status.emit("idle"),this.lastResponse.emit(null)}),e!=null&&this.chat.append("user",e);let o=Rt(this._terminalResult,{skipCurrent:!0});if(r!=null)if(r.aborted)this.aborted.emit(!0);else{let a=()=>this.aborted.emit(!0);r.addEventListener("abort",a,{once:!0}),n=()=>r.removeEventListener("abort",a)}return r?.aborted!==!0&&this.status.emit("thinking"),await o}finally{n?.(),this._running=!1,this._currentAbortController=null}}abort(){this.aborted.emit(!0)}destroy(){try{this._disposeRunWiring()}catch{}super.destroy()}};function Ce(t,e,r,n){let o=t[r];if(o!=null&&o.length>0)return o[o.length-1];let a=e[r];return a!==void 0?a:n}function Hr(t,e){return new ze(t,e)}function qr(t,e,r){let n=w(t),o=r?.condition!=null?w(r.condition):null,a=k(null,{name:r?.name?`${r.name}::null`:"handoff::null"});if(o==null)return Y(n,l=>{if(l==null)return a;let d=k(l);return e(d)});let s=M([n,o],([l,d])=>({v:l,open:d===!0}),{name:r?.name?`${r.name}::router`:"handoff::router",describeKind:"derived"});return Y(s,({v:l,open:d})=>{if(l==null)return a;if(!d)return k(l);let i=k(l);return e(i)})}function zr(t,e,r){let n=w(t),o=e.map(s=>w(s)),a=[n,...o];return M(a,s=>{let l=s[0]??[],d=s.slice(1);return l.filter(i=>{for(let u of d)if(u!=null&&!u(i))return!1;return!0})},{name:r?.name??"tool-selector",describeKind:"derived",meta:N("tool_selector"),equals:(s,l)=>{let d=s,i=l;if(d.length!==i.length)return!1;for(let u=0;u<d.length;u++)if(d[u]!==i[u])return!1;return!0}})}function Ut(t){let e=t.thresholds??{};return r=>{let n=t.scoreFn(r);for(let o of Object.keys(e)){let a=e[o];if(a===void 0)continue;let s=n[o];if((Number.isFinite(s)?s:Number.NEGATIVE_INFINITY)<a)return!1}return!0}}function Yr(t){let e={persistence:t.persistenceThreshold??.3,personalValue:t.personalValueThreshold??.3},r=Ut({scoreFn:t.scoreFn,thresholds:e});return t.requireStructured?n=>{if(!r(n))return!1;let o=t.scoreFn(n).structure;return Number.isFinite(o)&&o>0}:r}function Vt(t,e,r,n){let o=r.name??n;return a=>{let s=k(a);return ct(r.adapter,[s],l=>e(l),{name:o,format:"json",systemPrompt:t,model:r.model,temperature:r.temperature??0,maxTokens:r.maxTokens})}}function gt(t,e){let r=e.maxExistingKeys??100,n=Vt(t,o=>JSON.stringify({input:o.raw,existingKeys:o.existingKeys}),e,"llmExtractor");return(o,a)=>{let s=r===Number.POSITIVE_INFINITY?[...a.keys()]:[...a.keys()].slice(0,r);return n({raw:o,existingKeys:s})}}function yt(t,e){let r=Vt(t,n=>JSON.stringify({memories:n}),e,"llmConsolidator");return n=>{let o=[...n.entries()].map(([a,s])=>({key:a,value:s}));return r(o)}}var Se=Math.LN2/604800;function Ee(t){return t instanceof Map?t:new Map}function Jr(t,e,r){let n=new me(t,r.graph),o=[],a;if(r.extractFn)a=r.extractFn;else if(r.adapter&&r.extractPrompt)a=gt(r.extractPrompt,{adapter:r.adapter});else throw new Error("agentMemory: provide either extractFn or adapter + extractPrompt");let s=(b,R)=>b==null?{upsert:[]}:a(b,R),l=e;if(r.admissionFilter){let b=w(e),R=r.admissionFilter;l=M([b],([E])=>{if(R(E))return E},{name:"admissionFilter",describeKind:"derived"})}let d;r.consolidateFn?d=r.consolidateFn:r.adapter&&r.consolidatePrompt&&(d=yt(r.consolidatePrompt,{adapter:r.adapter}));let i=r.consolidateTrigger;if(!i&&d&&r.reflection?.enabled!==!1){let b=r.reflection?.interval??3e5;i=Mt(b,{period:b})}let u={score:r.score,cost:r.cost,budget:r.budget??2e3,context:r.context,consolidate:d,consolidateTrigger:i},c=Ct(l,s,u);n.add(c.store.entries,{name:"store"}),n.add(c.compact,{name:"compact"}),n.add(c.size,{name:"size"});let m=null;r.vectorDimensions&&r.vectorDimensions>0&&r.embedFn&&(m=Fe({dimension:r.vectorDimensions}),n.add(m.entries,{name:"vectorIndex"}));let p=null;r.enableKnowledgeGraph&&(p=Ge(`${t}-kg`),n.mount("kg",p));let y=null;if(r.tiers){let b=r.tiers,R=b.decayRate??Se,E=b.maxActive??1e3,A=b.archiveThreshold??.1,F=b.permanentFilter??(()=>!1),B=je({name:"permanent"});n.add(B.entries,{name:"permanent"});let C=new Set,I=P=>C.has(P)?"permanent":Ee(c.store.entries.cache).has(P)?"active":"archived",L=(P,$)=>{C.add(P),B.upsert(P,$)},O=new Map,x=c.store.entries,D=r.context?w(r.context):k(null),_=ne([x,D],([P,$])=>{let G=Ee(P),K=re(),S=[],T=[];for(let[j,H]of G){if(O.has(j)||O.set(j,K),F(j,H)){T.push({key:j,value:H});continue}let W=r.score(H,$),oe=O.get(j)??K,q=Number(K-oe)/1e9;_e(W,q,R)<A&&S.push(j)}for(let j of O.keys())G.has(j)||O.delete(j);for(let{key:j,value:H}of T)C.has(j)||L(j,H);let V=G.size-C.size;if(V>E){let j=[...G.entries()].filter(([W])=>!C.has(W)).map(([W,oe])=>({key:W,score:r.score(oe,$)})).sort((W,oe)=>W.score-oe.score),H=V-E;for(let W=0;W<H&&W<j.length;W++){let oe=j[W].key;S.includes(oe)||S.push(oe)}}S.length>0&&Z(()=>{for(let j of S)c.store.delete(j)})});o.push(_.subscribe(()=>{}));let J=null;b.archiveTier&&(J=n.attachStorage([b.archiveTier],b.archiveStorageOptions??{})),y={permanent:B,activeEntries:x,archiveHandle:J,tierOf:I,markPermanent:L}}if(m||p){let b=r.embedFn,R=r.entityFn,E=c.store.entries,A=ne([E],([F])=>{let B=Ee(F);for(let[C,I]of B){if(m&&b){let L=b(I);L&&m.upsert(C,L,I)}if(p&&R){let L=R(C,I);if(L){for(let O of L.entities??[])p.upsertEntity(O.id,O.value);for(let O of L.relations??[])p.link(O.from,O.to,O.relation,O.weight)}}}});o.push(A.subscribe(()=>{}))}let g=null,f=null,h=null,v=null;if(m||p){let b=r.retrieval?.topK??20,R=r.retrieval?.graphDepth??1,E=r.budget??2e3,A=r.cost,F=r.score,B=r.contextOf,C=r.contextWeight??0,I=r.context?w(r.context):k(null),L=(P,$)=>{if(!P||!$)return 0;let G=Math.min(P.length,$.length),K=0;for(;K<G&&P[K]===$[K];)K++;return K},O=(P,$,G)=>{let K=new Map,S=[];if(m&&G.vector){S=m.search(G.vector,b);for(let q of S){let z=P.get(q.id);z&&K.set(q.id,{value:z,sources:new Set(["vector"])})}}let T=[];if(p){let q=[...G.entityIds??[],...K.keys()],z=new Set,xe=q;for(let ye=0;ye<R;ye++){let pe=[];for(let we of xe){if(z.has(we))continue;z.add(we);let Ie=p.related(we);for(let Jt of Ie){let he=Jt.to;if(!z.has(he)){pe.push(he);let ht=P.get(he);if(ht){let bt=K.get(he);bt?bt.sources.add("graph"):K.set(he,{value:ht,sources:new Set(["graph"])}),T.push(he)}}}}xe=pe}}for(let[q,z]of P)K.has(q)||K.set(q,{value:z,sources:new Set(["store"])});let V=G.context?.length??0,j=[];for(let[q,{value:z,sources:xe}]of K){let ye=B?B(z):void 0,pe=F(z,$);if(C>0&&V>0){let Ie=L(G.context,ye);Ie>0&&(pe=pe*(1+C*Ie/V))}let we=ye?{key:q,value:z,score:pe,sources:[...xe],context:ye}:{key:q,value:z,score:pe,sources:[...xe]};j.push(we)}j.sort((q,z)=>z.score-q.score);let H=[],W=0;for(let q of j){let z=A(q.value);if(W+z>E&&H.length>0)break;H.push(q),W+=z}return{packed:H,trace:{vectorCandidates:S,graphExpanded:T,ranked:j,packed:H}}},x=(P,$)=>{if(P===$)return!0;if(P.length!==$.length)return!1;for(let G=0;G<P.length;G++)if(P[G]!==$[G])return!1;return!0},D=k([],{name:"retrieval",describeKind:"state",meta:N("retrieval_pipeline"),equals:x});n.add(D,{name:"retrieval"}),g=D;let _=k(null,{name:"retrievalTrace",describeKind:"state",meta:N("retrieval_trace")});n.add(_,{name:"retrievalTrace"}),f=_,h=P=>{let $=Ee(c.store.entries.cache),{packed:G,trace:K}=O($,I.cache,P);return Z(()=>{D.emit(G),_.emit(K)}),G},v=P=>{let $=w(P),G=M([c.store.entries,I,$],([S,T,V])=>{if(V==null)return{packed:[],trace:null};let j=Ee(S),{packed:H,trace:W}=O(j,T,V);return{packed:H,trace:W}},{name:"retrievalReactive::result",describeKind:"derived",meta:N("retrieval_reactive_result"),initial:{packed:[],trace:null}}),K=ne([G],([S])=>{let T=S;Z(()=>{D.emit(T.packed),T.trace&&_.emit(T.trace)})});return o.push(K.subscribe(()=>{})),M([G],([S])=>S.packed,{name:"retrievalReactive",describeKind:"derived",meta:N("retrieval_reactive"),initial:[],equals:x})}}return n.addDisposer(()=>{for(let b of o)b();o.length=0}),Object.assign(n,{distillBundle:c,compact:c.compact,size:c.size,vectors:m,kg:p,memoryTiers:y,retrieval:g,retrievalTrace:f,retrieve:h,retrieveReactive:v})}function Re(t){return t instanceof Map?t:new Map}function Qr(t,e,r){let n=Fe({dimension:r.dimension});t.add(n.entries,{name:"vectorIndex"});let a=ne([e.store.entries],([s])=>{let l=Re(s);for(let[d,i]of l){let u=r.embedFn(i);u&&n.upsert(d,u,i)}}).subscribe(()=>{});return t.addDisposer(a),{vectors:n,dispose:()=>a()}}function Xr(t,e,r,n){let o=Ge(`${r}-kg`);t.mount(r,o);let s=ne([e.store.entries],([l])=>{let d=Re(l);for(let[i,u]of d){let c=n.entityFn(i,u);if(c){for(let m of c.entities??[])o.upsertEntity(m.id,m.value);for(let m of c.relations??[])o.link(m.from,m.to,m.relation,m.weight)}}}).subscribe(()=>{});return t.addDisposer(s),{kg:o,dispose:()=>s()}}function Zr(t,e,r){let n=r.decayRate??Se,o=r.maxActive??1e3,a=r.archiveThreshold??.1,s=r.permanentFilter??(()=>!1),l=je({name:"permanent"});t.add(l.entries,{name:"permanent"});let d=new Set,i=v=>d.has(v)?"permanent":Re(e.store.entries.cache).has(v)?"active":"archived",u=(v,b)=>{d.add(v),l.upsert(v,b)},c=new Map,m=e.store.entries,p=r.context?w(r.context):k(null),g=ne([m,p],([v,b])=>{let R=Re(v),E=re(),A=[],F=[];for(let[C,I]of R){if(c.has(C)||c.set(C,E),s(C,I)){F.push({key:C,value:I});continue}let L=r.score(I,b),O=c.get(C)??E,x=Number(E-O)/1e9;_e(L,x,n)<a&&A.push(C)}for(let C of c.keys())R.has(C)||c.delete(C);for(let{key:C,value:I}of F)d.has(C)||u(C,I);let B=R.size-d.size;if(B>o){let C=[...R.entries()].filter(([L])=>!d.has(L)).map(([L,O])=>({key:L,score:r.score(O,b)})).sort((L,O)=>L.score-O.score),I=B-o;for(let L=0;L<I&&L<C.length;L++){let O=C[L].key;A.includes(O)||A.push(O)}}A.length>0&&Z(()=>{for(let C of A)e.store.delete(C)})}).subscribe(()=>{}),f=null;r.archiveTier&&(f=t.attachStorage([r.archiveTier],r.archiveStorageOptions??{}));let h=()=>{g(),f?.dispose()};return t.addDisposer(h),{tiers:{permanent:l,activeEntries:m,archiveHandle:f,tierOf:i,markPermanent:u},dispose:h}}function en(t,e){if(!t||!e)return 0;let r=Math.min(t.length,e.length),n=0;for(;n<r&&t[n]===e[n];)n++;return n}function tn(t,e,r,n,o){let a=o.topK??20,s=o.graphDepth??1,l=o.budget??2e3,d=o.contextWeight??0,i=o.context?w(o.context):k(null),u=(f,h,v)=>{let b=new Map,R=[];if(r&&v.vector){R=r.search(v.vector,a);for(let I of R){let L=f.get(I.id);L&&b.set(I.id,{value:L,sources:new Set(["vector"])})}}let E=[];if(n){let I=[...v.entityIds??[],...b.keys()],L=new Set,O=I;for(let x=0;x<s;x++){let D=[];for(let _ of O)if(!L.has(_)){L.add(_);for(let J of n.related(_)){let P=J.to;if(!L.has(P)){D.push(P);let $=f.get(P);if($){let G=b.get(P);G?G.sources.add("graph"):b.set(P,{value:$,sources:new Set(["graph"])}),E.push(P)}}}}O=D}}for(let[I,L]of f)b.has(I)||b.set(I,{value:L,sources:new Set(["store"])});let A=v.context?.length??0,F=[];for(let[I,{value:L,sources:O}]of b){let x=o.contextOf?o.contextOf(L):void 0,D=o.score(L,h);if(d>0&&A>0){let J=en(v.context,x);J>0&&(D=D*(1+d*J/A))}let _=x?{key:I,value:L,score:D,sources:[...O],context:x}:{key:I,value:L,score:D,sources:[...O]};F.push(_)}F.sort((I,L)=>L.score-I.score);let B=[],C=0;for(let I of F){let L=o.cost(I.value);if(C+L>l&&B.length>0)break;B.push(I),C+=L}return{packed:B,trace:{vectorCandidates:R,graphExpanded:E,ranked:F,packed:B}}},c=(f,h)=>{if(f===h)return!0;if(f.length!==h.length)return!1;for(let v=0;v<f.length;v++)if(f[v]!==h[v])return!1;return!0},m=k([],{name:"retrieval",describeKind:"state",meta:N("retrieval_pipeline"),equals:c});t.add(m,{name:"retrieval"});let p=k(null,{name:"retrievalTrace",describeKind:"state",meta:N("retrieval_trace")});return t.add(p,{name:"retrievalTrace"}),{retrieval:m,retrievalTrace:p,retrieve:f=>{let h=Re(e.store.entries.cache),{packed:v,trace:b}=u(h,i.cache,f);return Z(()=>{m.emit(v),p.emit(b)}),v},retrieveReactive:f=>{let h=w(f),v=M([e.store.entries,i,h],([E,A,F])=>{if(F==null)return{packed:[],trace:null};let B=Re(E),{packed:C,trace:I}=u(B,A,F);return{packed:C,trace:I}},{name:"retrievalReactive::result",describeKind:"derived",meta:N("retrieval_reactive_result"),initial:{packed:[],trace:null}}),R=ne([v],([E])=>{let A=E;Z(()=>{m.emit(A.packed),A.trace&&p.emit(A.trace)})}).subscribe(()=>{});return t.addDisposer(R),M([v],([E])=>E.packed,{name:"retrievalReactive",describeKind:"derived",meta:N("retrieval_reactive"),initial:[],equals:c})}}}function rn(t,e,r){let n=t.describe({actor:e,detail:"full"}),o=r?.groupByTags??!0,a=r?.separator??`
|
|
5
|
-
`,s=[],l=r?.sinceVersion;for(let[d,i]of Object.entries(n.nodes)){let u=i.meta??{},c=u.description,m=u.format;if(!c&&!m)continue;if(l!=null&&i.v!=null){let h=l.get(d);if(h!=null&&h.id===i.v.id&&i.v.version<=h.version)continue}let p=c??d,y=i.value,g=u.unit,f;m==="currency"&&typeof y=="number"?f=`$${y.toFixed(2)}`:m==="percentage"&&typeof y=="number"?f=`${(y*100).toFixed(1)}%`:y==null?f="(no value)":f=String(y),g&&m!=="currency"&&m!=="percentage"&&(f=`${f} ${g}`),s.push({path:d,description:p,formatted:f})}if(s.length===0)return"";if(o){let d=new Map,i=[];for(let c of s){let p=n.nodes[c.path].meta?.tags;if(p&&p.length>0){let y=p[0],g=d.get(y);g||(g=[],d.set(y,g)),g.push(c)}else i.push(c)}if(d.size===0)return s.map(c=>`- ${c.description}: ${c.formatted}`).join(a);let u=[];for(let[c,m]of[...d.entries()].sort((p,y)=>p[0].localeCompare(y[0])))u.push(`[${c}]${a}${m.map(p=>`- ${p.description}: ${p.formatted}`).join(a)}`);return i.length>0&&u.push(i.map(c=>`- ${c.description}: ${c.formatted}`).join(a)),u.join(a+a)}return s.map(d=>`- ${d.description}: ${d.formatted}`).join(a)}var Ht=`You are a graph architect for GraphReFly, a reactive graph protocol.
|
|
6
|
-
|
|
7
|
-
Given a natural-language description, produce a JSON graph specification with this structure:
|
|
8
|
-
|
|
9
|
-
{
|
|
10
|
-
"name": "<graph_name>",
|
|
11
|
-
"nodes": {
|
|
12
|
-
"<node_name>": {
|
|
13
|
-
"type": "state" | "derived" | "producer" | "effect" | "operator",
|
|
14
|
-
"initial": <initial_value_for_state_nodes>,
|
|
15
|
-
"deps": ["<dep_node_name>", ...],
|
|
16
|
-
"meta": {
|
|
17
|
-
"description": "<human-readable purpose>",
|
|
18
|
-
"type": "string" | "number" | "boolean" | "integer" | "enum",
|
|
19
|
-
"range": [min, max],
|
|
20
|
-
"values": ["a", "b"],
|
|
21
|
-
"format": "currency" | "percentage" | "status",
|
|
22
|
-
"access": "human" | "llm" | "both" | "system",
|
|
23
|
-
"unit": "<unit>",
|
|
24
|
-
"tags": ["<tag>"]
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
Rules:
|
|
31
|
-
- "state" nodes have no deps and hold user/LLM-writable values (knobs). Use "initial" for the starting value.
|
|
32
|
-
- "derived" nodes have deps and compute from them (pure, no side effects).
|
|
33
|
-
- "effect" nodes have deps but produce side effects (no return value).
|
|
34
|
-
- "producer" nodes have no deps but generate values asynchronously.
|
|
35
|
-
- "operator" nodes are parameterized transformations with deps.
|
|
36
|
-
- Use "deps" inside each node to declare dependencies \u2014 no separate "edges" array.
|
|
37
|
-
- meta.description is required for every node.
|
|
38
|
-
- Return ONLY valid JSON, no markdown fences or commentary.`;async function qt(t,e,r){let o=[{role:"system",content:r?.systemPromptExtra?`${Ht}
|
|
39
|
-
|
|
40
|
-
${r.systemPromptExtra}`:Ht},{role:"user",content:t}],a=e.invoke(o,{model:r?.model,temperature:r?.temperature??0,maxTokens:r?.maxTokens,signal:r?.signal}),l=(await Ae(a)).content.trim();l.startsWith("```")&&(l=ke(l));let d;try{d=JSON.parse(l)}catch{throw new Error(`graphFromSpec: LLM response is not valid JSON: ${l.slice(0,200)}`)}return Et(d,{catalog:r?.catalog})}function nn(t,e,r){let n=w(t);return Y(n,o=>!o||typeof o!="string"||o.trim().length===0?k(null):ue(a=>{let s=new AbortController,l=!1;return qt(o,e,{...r,signal:s.signal}).then(d=>{if(l){d.destroy();return}a.emit(d),a.down([[le]])}).catch(d=>{l||a.down([[X,d]])}),()=>{l=!0,s.abort()}},{name:"graphFromSpec::call"}))}function on(t){let e={},r=t.type;return r==="enum"&&Array.isArray(t.values)?(e.type="string",e.enum=t.values):r==="integer"?e.type="integer":r==="number"?e.type="number":r==="boolean"?e.type="boolean":r==="string"?e.type="string":e.type=["string","number","boolean"],Array.isArray(t.range)&&t.range.length===2&&(e.minimum=t.range[0],e.maximum=t.range[1]),typeof t.format=="string"&&(e.description=`Format: ${t.format}`),typeof t.unit=="string"&&(e.description?e.description+=` (${t.unit})`:e.description=`Unit: ${t.unit}`),e}function an(t,e){let r=t.describe({actor:e,detail:"full"}),n=[],o=[],a=[];for(let[s,l]of Object.entries(r.nodes)){if(l.type!=="state"||s.includes("::__meta__::")||l.status==="completed"||l.status==="errored")continue;let d=l.meta??{},i=d.access;if(i==="human"||i==="system")continue;let u=d.description??`Set the value of ${s}`,c=on(d),m={type:"object",required:["value"],properties:{value:c},additionalProperties:!1},p=s.replace(/::/g,"__");n.push({type:"function",function:{name:p,description:u,parameters:m}}),o.push({name:s,description:u,inputSchema:m});let y=t,g=e,f=l.v;a.push({name:s,description:u,parameters:m,handler(h){return y.set(s,h.value,g?{actor:g}:void 0),h.value},...f!=null?{version:{id:f.id,version:f.version}}:{}})}return{openai:n,mcp:o,definitions:a}}var sn=`You are a reactive graph optimizer for GraphReFly.
|
|
41
|
-
|
|
42
|
-
Given a graph's current structure (from describe()) and a problem statement, suggest topology and parameter changes to solve the problem.
|
|
43
|
-
|
|
44
|
-
Return ONLY valid JSON with this structure:
|
|
45
|
-
{
|
|
46
|
-
"summary": "<one-line summary of the strategy>",
|
|
47
|
-
"reasoning": "<explanation of why these changes help>",
|
|
48
|
-
"operations": [
|
|
49
|
-
{ "type": "add_node", "name": "<name>", "nodeType": "state|derived|effect|producer|operator", "meta": {...}, "initial": <value> },
|
|
50
|
-
{ "type": "remove_node", "name": "<name>" },
|
|
51
|
-
{ "type": "connect", "from": "<source>", "to": "<target>" },
|
|
52
|
-
{ "type": "disconnect", "from": "<source>", "to": "<target>" },
|
|
53
|
-
{ "type": "set_value", "name": "<name>", "value": <new_value> },
|
|
54
|
-
{ "type": "update_meta", "name": "<name>", "key": "<meta_key>", "value": <new_value> }
|
|
55
|
-
]
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
Rules:
|
|
59
|
-
- Only suggest operations that reference existing nodes (for remove/disconnect/set_value/update_meta) or new nodes you define (for add_node).
|
|
60
|
-
- Keep changes minimal \u2014 prefer the smallest set of operations that solves the problem.
|
|
61
|
-
- Return ONLY valid JSON, no markdown fences or commentary.`;async function zt(t,e,r,n){let{expand:o,...a}=t.describe({actor:n?.actor,detail:"standard"}),s=[{role:"system",content:sn},{role:"user",content:JSON.stringify({graph:a,problem:e})}],l=r.invoke(s,{model:n?.model,temperature:n?.temperature??0,maxTokens:n?.maxTokens,signal:n?.signal}),i=(await Ae(l)).content.trim();i.startsWith("```")&&(i=i.replace(/^```(?:json)?\s*/,"").replace(/\s*```$/,""));let u;try{u=JSON.parse(i)}catch{throw new Error(`suggestStrategy: LLM response is not valid JSON: ${i.slice(0,200)}`)}let c=u;if(typeof c.summary!="string")throw new Error("suggestStrategy: missing 'summary' in response");if(typeof c.reasoning!="string")throw new Error("suggestStrategy: missing 'reasoning' in response");if(!Array.isArray(c.operations))throw new Error("suggestStrategy: missing 'operations' array in response");return{summary:c.summary,reasoning:c.reasoning,operations:c.operations}}function ln(t,e,r,n){let o=w(e),a=Nt(o,t);return Y(a,s=>{if(s==null)return k(null);let[l,d]=s;return!d||!l||typeof l!="string"||l.trim().length===0?k(null):d.destroyed?k(null):ue(i=>{let u=new AbortController,c=!1;return zt(d,l,r,{...n,signal:u.signal}).then(m=>{c||(i.emit(m),i.down([[le]]))}).catch(m=>{c||i.down([[X,m]])}),()=>{c=!0,u.abort()}},{name:"suggestStrategy::call"})})}var Yt=new Set(["state","derived","producer","operator","effect"]);function dn(t){let e=[];if(t==null||typeof t!="object")return{valid:!1,errors:["Definition must be a non-null object"]};let r=t;if((typeof r.name!="string"||r.name.length===0)&&e.push("Missing or empty 'name' field"),r.nodes==null||typeof r.nodes!="object"||Array.isArray(r.nodes))return e.push("Missing or invalid 'nodes' field (must be an object)"),{valid:!1,errors:e};let n=new Set(Object.keys(r.nodes));for(let[o,a]of Object.entries(r.nodes)){if(a==null||typeof a!="object"){e.push(`Node "${o}": must be an object`);continue}let s=a;if((typeof s.type!="string"||!Yt.has(s.type))&&e.push(`Node "${o}": invalid type "${String(s.type)}" (expected: ${[...Yt].join(", ")})`),Array.isArray(s.deps))for(let l of s.deps)typeof l=="string"&&!n.has(l)&&e.push(`Node "${o}": dep "${l}" does not reference an existing node`)}if(!Array.isArray(r.edges))r.edges!==void 0&&e.push("'edges' must be an array");else{let o=new Set;for(let a=0;a<r.edges.length;a++){let s=r.edges[a];if(s==null||typeof s!="object"){e.push(`Edge [${a}]: must be an object`);continue}let l=s;(typeof l.from!="string"||!n.has(l.from))&&e.push(`Edge [${a}]: 'from' "${String(l.from)}" does not reference an existing node`),(typeof l.to!="string"||!n.has(l.to))&&e.push(`Edge [${a}]: 'to' "${String(l.to)}" does not reference an existing node`);let d=`${l.from}->${l.to}`;o.has(d)&&e.push(`Edge [${a}]: duplicate edge ${d}`),o.add(d)}}return{valid:e.length===0,errors:e}}export{lr as a,dr as b,$e as c,tt as d,cr as e,mr as f,pr as g,fr as h,rt as i,We as j,ot as k,yr as l,at as m,it as n,lt as o,Me as p,dt as q,wr as r,Lr as s,Sr as t,ct as u,Ir as v,Or as w,Dr as x,_r as y,Fr as z,Gr as A,$r as B,Wr as C,Kr as D,He as E,mt as F,pt as G,qe as H,ft as I,ze as J,Hr as K,qr as L,zr as M,Ut as N,Yr as O,gt as P,yt as Q,Se as R,Jr as S,Qr as T,Xr as U,Zr as V,tn as W,rn as X,qt as Y,nn as Z,an as _,zt as $,ln as aa,dn as ba,un as ca};
|