@ax-llm/ax 19.0.22 → 19.0.24

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/index.cjs CHANGED
@@ -1,48 +1,48 @@
1
- "use strict";var vp=Object.create;var ao=Object.defineProperty;var Sp=Object.getOwnPropertyDescriptor;var kp=Object.getOwnPropertyNames;var Op=Object.getPrototypeOf,Ep=Object.prototype.hasOwnProperty;var Mp=(o,e)=>{for(var t in e)ao(o,t,{get:e[t],enumerable:!0})},Ba=(o,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of kp(e))!Ep.call(o,r)&&r!==t&&ao(o,r,{get:()=>e[r],enumerable:!(n=Sp(e,r))||n.enumerable});return o};var ur=(o,e,t)=>(t=o!=null?vp(Op(o)):{},Ba(e||!o||!o.__esModule?ao(t,"default",{value:o,enumerable:!0}):t,o)),Pp=o=>Ba(ao({},"__esModule",{value:!0}),o);var Ef={};Mp(Ef,{AxACE:()=>Vn,AxACEOptimizedProgram:()=>qr,AxAI:()=>Er,AxAIAnthropic:()=>pn,AxAIAnthropicModel:()=>mr,AxAIAnthropicVertexModel:()=>gr,AxAIAzureOpenAI:()=>hn,AxAICohere:()=>xn,AxAICohereEmbedModel:()=>Ar,AxAICohereModel:()=>xr,AxAIDeepSeek:()=>An,AxAIDeepSeekModel:()=>yr,AxAIGoogleGemini:()=>yn,AxAIGoogleGeminiEmbedModel:()=>Ro,AxAIGoogleGeminiEmbedTypes:()=>fi,AxAIGoogleGeminiModel:()=>br,AxAIGoogleGeminiSafetyCategory:()=>vo,AxAIGoogleGeminiSafetyThreshold:()=>So,AxAIGrok:()=>Mn,AxAIGrokEmbedModels:()=>ki,AxAIGrokModel:()=>Or,AxAIGroq:()=>Tn,AxAIGroqModel:()=>Tr,AxAIHuggingFace:()=>Cn,AxAIHuggingFaceModel:()=>Po,AxAIMistral:()=>In,AxAIMistralEmbedModels:()=>bi,AxAIMistralModel:()=>Cr,AxAIOllama:()=>wn,AxAIOpenAI:()=>fn,AxAIOpenAIBase:()=>Ge,AxAIOpenAIEmbedModel:()=>dn,AxAIOpenAIModel:()=>hr,AxAIOpenAIResponses:()=>vn,AxAIOpenAIResponsesBase:()=>Ir,AxAIOpenAIResponsesImpl:()=>Rn,AxAIOpenAIResponsesModel:()=>mn,AxAIOpenRouter:()=>Sn,AxAIRefusalError:()=>Le,AxAIReka:()=>kn,AxAIRekaModel:()=>Rr,AxAIServiceAbortedError:()=>Pe,AxAIServiceAuthenticationError:()=>$t,AxAIServiceError:()=>et,AxAIServiceNetworkError:()=>Je,AxAIServiceResponseError:()=>Lt,AxAIServiceStatusError:()=>rt,AxAIServiceStreamTerminatedError:()=>gt,AxAIServiceTimeoutError:()=>dt,AxAITogether:()=>On,AxAITogetherModel:()=>Sr,AxAIWebLLM:()=>En,AxAIWebLLMModel:()=>kr,AxAgent:()=>ro,AxAgentClarificationError:()=>ct,AxApacheTika:()=>ms,AxAssertionError:()=>Et,AxBalancer:()=>bo,AxBaseAI:()=>Be,AxBaseOptimizer:()=>Tt,AxBootstrapFewShot:()=>Yn,AxContentProcessingError:()=>It,AxDB:()=>Ko,AxDBBase:()=>ht,AxDBCloudflare:()=>Pn,AxDBManager:()=>Wo,AxDBMemory:()=>Gt,AxDBPinecone:()=>Fn,AxDBWeaviate:()=>_n,AxDefaultCostTracker:()=>zr,AxDefaultResultReranker:()=>ds,AxDockerSession:()=>Ss,AxEmbeddingAdapter:()=>ks,AxEvalUtil:()=>nu,AxFlow:()=>Wr,AxFlowDependencyAnalyzer:()=>Xn,AxFlowExecutionPlanner:()=>er,AxFlowSubContextImpl:()=>rr,AxFlowTypedSubContextImpl:()=>Rs,AxFluentFieldType:()=>Ke,AxFunctionError:()=>Lr,AxFunctionProcessor:()=>Dr,AxGEPA:()=>Ht,AxGen:()=>ke,AxGenerateError:()=>Br,AxHFDataLoader:()=>Cs,AxInstanceRegistry:()=>Gn,AxJSRuntime:()=>ln,AxJSRuntimePermission:()=>Ta,AxLLMRequestTypeValues:()=>Xs,AxLearn:()=>Ts,AxMCPClient:()=>Ms,AxMCPHTTPSSETransport:()=>_s,AxMCPStreambleHTTPTransport:()=>Fs,AxMediaNotSupportedError:()=>ft,AxMemory:()=>Nn,AxMiPRO:()=>ws,AxMockAIService:()=>No,AxMultiServiceRouter:()=>Lo,AxOptimizedProgramImpl:()=>bt,AxProgram:()=>qt,AxPromptTemplate:()=>rn,AxProviderRouter:()=>Go,AxRateLimiterTokenUsage:()=>bn,AxSignature:()=>Ne,AxSignatureBuilder:()=>Ur,AxSimpleClassifier:()=>fs,AxSimpleClassifierClass:()=>gs,AxSpanKindValues:()=>Zs,AxStepContextImpl:()=>qn,AxStopFunctionCallException:()=>en,AxStringUtil:()=>ps,AxSynth:()=>Qn,AxTestPrompt:()=>hs,AxTokenLimitError:()=>pr,AxTraceLogger:()=>Wn,agent:()=>bp,ai:()=>Zl,ax:()=>st,axAIAnthropicDefaultConfig:()=>li,axAIAnthropicVertexDefaultConfig:()=>vl,axAIAzureOpenAIBestConfig:()=>El,axAIAzureOpenAICreativeConfig:()=>kl,axAIAzureOpenAIDefaultConfig:()=>ui,axAIAzureOpenAIFastConfig:()=>Ol,axAICohereCreativeConfig:()=>Nl,axAICohereDefaultConfig:()=>mi,axAIDeepSeekCodeConfig:()=>Ll,axAIDeepSeekDefaultConfig:()=>gi,axAIGoogleGeminiDefaultConfig:()=>xi,axAIGoogleGeminiDefaultCreativeConfig:()=>Gl,axAIGrokBestConfig:()=>Xl,axAIGrokDefaultConfig:()=>qo,axAIHuggingFaceCreativeConfig:()=>Bl,axAIHuggingFaceDefaultConfig:()=>yi,axAIMistralBestConfig:()=>jl,axAIMistralDefaultConfig:()=>_o,axAIOllamaDefaultConfig:()=>Ti,axAIOllamaDefaultCreativeConfig:()=>zl,axAIOpenAIBestConfig:()=>xo,axAIOpenAICreativeConfig:()=>Ao,axAIOpenAIDefaultConfig:()=>Yt,axAIOpenAIFastConfig:()=>yo,axAIOpenAIResponsesBestConfig:()=>ql,axAIOpenAIResponsesCreativeConfig:()=>Hl,axAIOpenAIResponsesDefaultConfig:()=>wr,axAIOpenRouterDefaultConfig:()=>Ii,axAIRekaBestConfig:()=>Vl,axAIRekaCreativeConfig:()=>Jl,axAIRekaDefaultConfig:()=>vr,axAIRekaFastConfig:()=>Ql,axAITogetherDefaultConfig:()=>Ri,axAIWebLLMCreativeConfig:()=>Yl,axAIWebLLMDefaultConfig:()=>Si,axAnalyzeChatPromptRequirements:()=>Kl,axAnalyzeRequestRequirements:()=>Xt,axBaseAIDefaultConfig:()=>we,axBaseAIDefaultCreativeConfig:()=>He,axBuildActorDefinition:()=>$s,axBuildResponderDefinition:()=>Ds,axCheckMetricsHealth:()=>ec,axCreateDefaultColorLogger:()=>Ys,axCreateDefaultOptimizerColorLogger:()=>oa,axCreateDefaultOptimizerTextLogger:()=>iu,axCreateDefaultTextLogger:()=>Ja,axCreateFlowColorLogger:()=>Kr,axCreateFlowTextLogger:()=>fu,axCreateJSRuntime:()=>Eu,axDefaultFlowLogger:()=>hu,axDefaultMetricsConfig:()=>Pi,axDefaultOptimizerLogger:()=>jr,axDefaultOptimizerMetricsConfig:()=>sa,axGetCompatibilityReport:()=>Ml,axGetFormatCompatibility:()=>Fl,axGetMetricsConfig:()=>nc,axGetOptimizerMetricsConfig:()=>lu,axGetProvidersWithMediaSupport:()=>Pl,axGlobals:()=>de,axModelInfoAnthropic:()=>fr,axModelInfoCohere:()=>Io,axModelInfoDeepSeek:()=>wo,axModelInfoGoogleGemini:()=>ko,axModelInfoGrok:()=>zo,axModelInfoGroq:()=>Eo,axModelInfoHuggingFace:()=>Mo,axModelInfoMistral:()=>Fo,axModelInfoOpenAI:()=>gn,axModelInfoOpenAIResponses:()=>ho,axModelInfoReka:()=>Uo,axModelInfoTogether:()=>Bo,axModelInfoWebLLM:()=>jo,axProcessContentForProvider:()=>Do,axRAG:()=>wp,axScoreProvidersForRequest:()=>To,axSelectOptimalProvider:()=>Co,axSpanAttributes:()=>he,axSpanEvents:()=>wt,axUpdateMetricsConfig:()=>tc,axUpdateOptimizerMetricsConfig:()=>au,axValidateChatRequestMessage:()=>cn,axValidateChatResponseResult:()=>fo,axValidateProviderCapabilities:()=>pi,axWorkerRuntime:()=>Os,f:()=>ue,flow:()=>vs,fn:()=>Bc,s:()=>ou});module.exports=Pp(Ef);function mt({model:o,modelInfo:e,models:t}){let n=t?.find(c=>c.key===o),r=n&&"model"in n?n.model:o,s=e.find(c=>c.name===o);if(s)return s;let i=e.find(c=>c.name===r);if(i)return i;let a=r.replace(/^(anthropic\.|openai\.)/,"").replace(/-latest$/,"").replace(/-\d{8}$/,"").replace(/-v\d+:\d+$/,"").replace(/@\d{8}$/,"").replace(/-\d{2,}(-[a-zA-Z0-9-]+)?$/,"").replace(/-v\d+@\d{8}$/,"").replace(/-v\d+$/,""),l=e.find(c=>c.name===a);return l||null}var Vs=(()=>{if(globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function")return globalThis.crypto;throw new Error("Web Crypto API with randomUUID support not available. Requires Node.js 16+ or modern browser.")})();function Ze(){return Vs.randomUUID()}async function Fp(o){let e=new TextEncoder,t=typeof o=="string"?e.encode(o):o,n=await Vs.subtle.digest("SHA-256",t);return Array.from(new Uint8Array(n)).map(i=>i.toString(16).padStart(2,"0")).join("")}var Ws=class{data="";update(e){return this.data+=e,this}digest(e){if(e!=="hex")throw new Error("Only hex encoding is supported");let n=new TextEncoder().encode(this.data),r=0;for(let s=0;s<n.length;s++){let i=n[s];r=(r<<5)-r+i,r=r&r}return Math.abs(r).toString(16).padStart(8,"0")}async digestAsync(){return Fp(this.data)}};function pt(o){if(o!=="sha256")throw new Error("Only SHA-256 algorithm is supported");return new Ws}function ja(){return Vs}var lo=class extends TransformStream{buffer="";currentEvent={rawData:""};dataParser;onError;constructor(e={}){super({transform:(t,n)=>this.handleChunk(t,n),flush:t=>this.handleFlush(t)}),this.dataParser=e.dataParser||JSON.parse,this.onError=e.onError||((t,n)=>{console.warn("Failed to parse event data:",t),console.log("Raw data that failed to parse:",n)})}handleChunk(e,t){this.buffer+=e,this.processBuffer(t)}handleFlush(e){this.processBuffer(e),this.currentEvent.rawData&&this.processEvent(e)}processBuffer(e){let n=this.buffer.replace(/\r\n|\r/g,`
1
+ "use strict";var gd=Object.create;var lo=Object.defineProperty;var fd=Object.getOwnPropertyDescriptor;var hd=Object.getOwnPropertyNames;var xd=Object.getPrototypeOf,Ad=Object.prototype.hasOwnProperty;var yd=(o,e)=>{for(var t in e)lo(o,t,{get:e[t],enumerable:!0})},tu=(o,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of hd(e))!Ad.call(o,r)&&r!==t&&lo(o,r,{get:()=>e[r],enumerable:!(n=fd(e,r))||n.enumerable});return o};var dr=(o,e,t)=>(t=o!=null?gd(xd(o)):{},tu(e||!o||!o.__esModule?lo(t,"default",{value:o,enumerable:!0}):t,o)),bd=o=>tu(lo({},"__esModule",{value:!0}),o);var Tf={};yd(Tf,{AxACE:()=>Yn,AxACEOptimizedProgram:()=>Hr,AxAI:()=>Pr,AxAIAnthropic:()=>fn,AxAIAnthropicModel:()=>fr,AxAIAnthropicVertexModel:()=>hr,AxAIAzureOpenAI:()=>bn,AxAICohere:()=>Cn,AxAICohereEmbedModel:()=>br,AxAICohereModel:()=>yr,AxAIDeepSeek:()=>In,AxAIDeepSeekModel:()=>Cr,AxAIGoogleGemini:()=>Tn,AxAIGoogleGeminiEmbedModel:()=>Oo,AxAIGoogleGeminiEmbedTypes:()=>bi,AxAIGoogleGeminiModel:()=>Ir,AxAIGoogleGeminiSafetyCategory:()=>Eo,AxAIGoogleGeminiSafetyThreshold:()=>Mo,AxAIGrok:()=>Nn,AxAIGrokEmbedModels:()=>Fi,AxAIGrokModel:()=>Mr,AxAIGroq:()=>Rn,AxAIGroqModel:()=>Tr,AxAIHuggingFace:()=>vn,AxAIHuggingFaceModel:()=>Lo,AxAIMistral:()=>Sn,AxAIMistralEmbedModels:()=>Ri,AxAIMistralModel:()=>wr,AxAIOllama:()=>kn,AxAIOpenAI:()=>yn,AxAIOpenAIBase:()=>Ge,AxAIOpenAIEmbedModel:()=>hn,AxAIOpenAIModel:()=>Ar,AxAIOpenAIResponses:()=>En,AxAIOpenAIResponsesBase:()=>Rr,AxAIOpenAIResponsesImpl:()=>On,AxAIOpenAIResponsesModel:()=>xn,AxAIOpenRouter:()=>Mn,AxAIRefusalError:()=>Le,AxAIReka:()=>Pn,AxAIRekaModel:()=>Sr,AxAIServiceAbortedError:()=>_e,AxAIServiceAuthenticationError:()=>Lt,AxAIServiceError:()=>et,AxAIServiceNetworkError:()=>Je,AxAIServiceResponseError:()=>Nt,AxAIServiceStatusError:()=>rt,AxAIServiceStreamTerminatedError:()=>gt,AxAIServiceTimeoutError:()=>dt,AxAITogether:()=>Fn,AxAITogetherModel:()=>Or,AxAIWebLLM:()=>_n,AxAIWebLLMModel:()=>Er,AxAgent:()=>ao,AxAgentClarificationError:()=>at,AxAgentProtocolCompletionSignal:()=>Ut,AxApacheTika:()=>xs,AxAssertionError:()=>Et,AxBalancer:()=>wo,AxBaseAI:()=>je,AxBaseOptimizer:()=>Ct,AxBootstrapFewShot:()=>er,AxContentProcessingError:()=>Tt,AxDB:()=>Qo,AxDBBase:()=>ht,AxDBCloudflare:()=>Ln,AxDBManager:()=>Yo,AxDBMemory:()=>jt,AxDBPinecone:()=>$n,AxDBWeaviate:()=>Dn,AxDefaultCostTracker:()=>qr,AxDefaultResultReranker:()=>hs,AxDockerSession:()=>Ms,AxEmbeddingAdapter:()=>Ps,AxEvalUtil:()=>gl,AxFlow:()=>Vr,AxFlowDependencyAnalyzer:()=>tr,AxFlowExecutionPlanner:()=>rr,AxFlowSubContextImpl:()=>ir,AxFlowTypedSubContextImpl:()=>Os,AxFluentFieldType:()=>Ke,AxFunctionError:()=>Dr,AxFunctionProcessor:()=>Gr,AxGEPA:()=>Wt,AxGen:()=>Pe,AxGenerateError:()=>Br,AxHFDataLoader:()=>vs,AxInstanceRegistry:()=>qn,AxJSRuntime:()=>pn,AxJSRuntimePermission:()=>Sa,AxLLMRequestTypeValues:()=>ni,AxLearn:()=>Rs,AxMCPClient:()=>Ns,AxMCPHTTPSSETransport:()=>Ds,AxMCPStreambleHTTPTransport:()=>$s,AxMediaNotSupportedError:()=>ft,AxMemory:()=>Un,AxMiPRO:()=>ks,AxMockAIService:()=>Uo,AxMultiServiceRouter:()=>Go,AxOptimizedProgramImpl:()=>bt,AxProgram:()=>Ht,AxPromptTemplate:()=>Kt,AxProviderRouter:()=>qo,AxRateLimiterTokenUsage:()=>wn,AxSignature:()=>Me,AxSignatureBuilder:()=>jr,AxSimpleClassifier:()=>ys,AxSimpleClassifierClass:()=>As,AxSpanKindValues:()=>ri,AxStepContextImpl:()=>Vn,AxStopFunctionCallException:()=>nn,AxStringUtil:()=>fs,AxSynth:()=>Zn,AxTestPrompt:()=>bs,AxTokenLimitError:()=>mr,AxTraceLogger:()=>Qn,agent:()=>pd,ai:()=>dc,ax:()=>st,axAIAnthropicDefaultConfig:()=>mi,axAIAnthropicVertexDefaultConfig:()=>Uu,axAIAzureOpenAIBestConfig:()=>zu,axAIAzureOpenAICreativeConfig:()=>ju,axAIAzureOpenAIDefaultConfig:()=>fi,axAIAzureOpenAIFastConfig:()=>Bu,axAICohereCreativeConfig:()=>Vu,axAICohereDefaultConfig:()=>Ai,axAIDeepSeekCodeConfig:()=>Ju,axAIDeepSeekDefaultConfig:()=>yi,axAIGoogleGeminiDefaultConfig:()=>Ii,axAIGoogleGeminiDefaultCreativeConfig:()=>Zu,axAIGrokBestConfig:()=>pc,axAIGrokDefaultConfig:()=>Vo,axAIHuggingFaceCreativeConfig:()=>ec,axAIHuggingFaceDefaultConfig:()=>wi,axAIMistralBestConfig:()=>tc,axAIMistralDefaultConfig:()=>Do,axAIOllamaDefaultConfig:()=>vi,axAIOllamaDefaultCreativeConfig:()=>nc,axAIOpenAIBestConfig:()=>Co,axAIOpenAICreativeConfig:()=>Io,axAIOpenAIDefaultConfig:()=>Zt,axAIOpenAIFastConfig:()=>To,axAIOpenAIResponsesBestConfig:()=>rc,axAIOpenAIResponsesCreativeConfig:()=>oc,axAIOpenAIResponsesDefaultConfig:()=>vr,axAIOpenRouterDefaultConfig:()=>ki,axAIRekaBestConfig:()=>ac,axAIRekaCreativeConfig:()=>uc,axAIRekaDefaultConfig:()=>kr,axAIRekaFastConfig:()=>cc,axAITogetherDefaultConfig:()=>Ei,axAIWebLLMCreativeConfig:()=>lc,axAIWebLLMDefaultConfig:()=>Pi,axAnalyzeChatPromptRequirements:()=>sc,axAnalyzeRequestRequirements:()=>en,axBaseAIDefaultConfig:()=>ve,axBaseAIDefaultCreativeConfig:()=>He,axBuildActorDefinition:()=>js,axBuildResponderDefinition:()=>Bs,axCheckMetricsHealth:()=>mc,axCreateDefaultColorLogger:()=>ti,axCreateDefaultOptimizerColorLogger:()=>la,axCreateDefaultOptimizerTextLogger:()=>Al,axCreateDefaultTextLogger:()=>cu,axCreateFlowColorLogger:()=>Wr,axCreateFlowTextLogger:()=>Sl,axCreateJSRuntime:()=>Bl,axDefaultFlowLogger:()=>kl,axDefaultMetricsConfig:()=>$i,axDefaultOptimizerLogger:()=>zr,axDefaultOptimizerMetricsConfig:()=>pa,axGetCompatibilityReport:()=>qu,axGetFormatCompatibility:()=>Ku,axGetMetricsConfig:()=>fc,axGetOptimizerMetricsConfig:()=>bl,axGetProvidersWithMediaSupport:()=>Hu,axGlobals:()=>ge,axModelInfoAnthropic:()=>xr,axModelInfoCohere:()=>So,axModelInfoDeepSeek:()=>ko,axModelInfoGoogleGemini:()=>Po,axModelInfoGrok:()=>Wo,axModelInfoGroq:()=>_o,axModelInfoHuggingFace:()=>No,axModelInfoMistral:()=>$o,axModelInfoOpenAI:()=>An,axModelInfoOpenAIResponses:()=>bo,axModelInfoReka:()=>zo,axModelInfoTogether:()=>Ho,axModelInfoWebLLM:()=>Ko,axProcessContentForProvider:()=>Bo,axRAG:()=>dd,axScoreProvidersForRequest:()=>Ro,axSelectOptimalProvider:()=>vo,axSpanAttributes:()=>ye,axSpanEvents:()=>wt,axUpdateMetricsConfig:()=>gc,axUpdateOptimizerMetricsConfig:()=>yl,axValidateChatRequestMessage:()=>mn,axValidateChatResponseResult:()=>Ao,axValidateProviderCapabilities:()=>hi,axWorkerRuntime:()=>Fs,f:()=>me,flow:()=>Es,fn:()=>el,s:()=>hl});module.exports=bd(Tf);function mt({model:o,modelInfo:e,models:t}){let n=t?.find(c=>c.key===o),r=n&&"model"in n?n.model:o,s=e.find(c=>c.name===o);if(s)return s;let i=e.find(c=>c.name===r);if(i)return i;let a=r.replace(/^(anthropic\.|openai\.)/,"").replace(/-latest$/,"").replace(/-\d{8}$/,"").replace(/-v\d+:\d+$/,"").replace(/@\d{8}$/,"").replace(/-\d{2,}(-[a-zA-Z0-9-]+)?$/,"").replace(/-v\d+@\d{8}$/,"").replace(/-v\d+$/,""),u=e.find(c=>c.name===a);return u||null}var Xs=(()=>{if(globalThis.crypto&&typeof globalThis.crypto.randomUUID=="function")return globalThis.crypto;throw new Error("Web Crypto API with randomUUID support not available. Requires Node.js 16+ or modern browser.")})();function Ze(){return Xs.randomUUID()}async function Cd(o){let e=new TextEncoder,t=typeof o=="string"?e.encode(o):o,n=await Xs.subtle.digest("SHA-256",t);return Array.from(new Uint8Array(n)).map(i=>i.toString(16).padStart(2,"0")).join("")}var Ys=class{data="";update(e){return this.data+=e,this}digest(e){if(e!=="hex")throw new Error("Only hex encoding is supported");let n=new TextEncoder().encode(this.data),r=0;for(let s=0;s<n.length;s++){let i=n[s];r=(r<<5)-r+i,r=r&r}return Math.abs(r).toString(16).padStart(8,"0")}async digestAsync(){return Cd(this.data)}};function pt(o){if(o!=="sha256")throw new Error("Only SHA-256 algorithm is supported");return new Ys}function nu(){return Xs}var po=class extends TransformStream{buffer="";currentEvent={rawData:""};dataParser;onError;constructor(e={}){super({transform:(t,n)=>this.handleChunk(t,n),flush:t=>this.handleFlush(t)}),this.dataParser=e.dataParser||JSON.parse,this.onError=e.onError||((t,n)=>{console.warn("Failed to parse event data:",t),console.log("Raw data that failed to parse:",n)})}handleChunk(e,t){this.buffer+=e,this.processBuffer(t)}handleFlush(e){this.processBuffer(e),this.currentEvent.rawData&&this.processEvent(e)}processBuffer(e){let n=this.buffer.replace(/\r\n|\r/g,`
2
2
  `).split(`
3
3
  `);this.buffer=n.pop()||"";for(let r of n)r===""?this.processEvent(e):this.parseLine(r)}parseLine(e){if(e.startsWith(":"))return;let t=e.indexOf(":");if(t===-1){this.currentEvent.rawData+=(this.currentEvent.rawData&&!this.currentEvent.rawData.endsWith(`
4
4
  `)?`
5
5
  `:"")+e.trim();return}let n=e.slice(0,t).trim(),r=e.slice(t+1).trim();switch(n){case"event":this.currentEvent.event=r;break;case"data":this.currentEvent.rawData+=(this.currentEvent.rawData&&!this.currentEvent.rawData.endsWith(`
6
6
  `)?`
7
- `:"")+r;break;case"id":this.currentEvent.id=r;break;case"retry":{let s=Number.parseInt(r,10);Number.isNaN(s)||(this.currentEvent.retry=s);break}}}processEvent(e){if(this.currentEvent.rawData){if(this.currentEvent.event||(this.currentEvent.event="message"),this.currentEvent.rawData.trim()==="[DONE]"){this.currentEvent={rawData:""};return}try{let t=this.dataParser(this.currentEvent.rawData);e.enqueue(t)}catch(t){this.onError(t,this.currentEvent.rawData)}this.currentEvent={rawData:""}}}};var Js=class{decoder;constructor(){this.decoder=new TextDecoder}transform(e,t){if(!(e instanceof ArrayBuffer||ArrayBuffer.isView(e)))throw new TypeError("Input data must be a BufferSource");let n=this.decoder.decode(e,{stream:!0});n.length!==0&&t.enqueue(n)}flush(e){let t=this.decoder.decode();t.length!==0&&e.enqueue(t)}},co=class extends TransformStream{constructor(){super(new Js)}};var _p={maxRetries:3,initialDelayMs:1e3,maxDelayMs:6e4,backoffFactor:2,retryableStatusCodes:[500,408,429,502,503,504]},Np=globalThis.TextDecoderStream??co,et=class extends Error{constructor(t,n,r,s,i={},a=!0){super(t);this.url=n;this.requestBody=r;this.responseBody=s;this.name="AxAIServiceError",this.timestamp=new Date().toISOString(),this.errorId=Ze(),this.context=i,this.includeRequestBodyInErrors=a,this.stack=this.toString()}timestamp;errorId;context;includeRequestBodyInErrors;toString(){let t=[`${this.name}: ${this.message}`,`URL: ${this.url}`];return this.includeRequestBodyInErrors&&t.push(`Request Body: ${JSON.stringify(this.requestBody,null,2)}`),t.push(`Response Body: ${JSON.stringify(this.responseBody,null,2)}`,`Context: ${JSON.stringify(this.context,null,2)}`,`Timestamp: ${this.timestamp}`,`Error ID: ${this.errorId}`),t.join(`
8
- `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},rt=class extends et{constructor(t,n,r,s,i,a,l,c=!0){let u=l?` (after ${l} retries)`:"";super(`HTTP ${t} - ${n}${u}`,r,s,{httpStatus:t,httpStatusText:n,responseBody:i,...a},{},c);this.status=t;this.statusText=n;this.name="AxAIServiceStatusError"}},Je=class extends et{constructor(t,n,r,s,i,a=!0){super(`Network Error: ${t.message}`,n,r,s,{originalErrorName:t.name,originalErrorStack:t.stack,...i},a);this.originalError=t;this.name="AxAIServiceNetworkError",this.stack=t.stack}},Lt=class extends et{constructor(e,t,n,r,s=!0){super(e,t,n,void 0,r,s),this.name="AxAIServiceResponseError"}},gt=class extends et{constructor(t,n,r,s,i=!0){super("Stream terminated unexpectedly by remote host",t,n,void 0,{lastChunk:r,...s},i);this.lastChunk=r;this.name="AxAIServiceStreamTerminatedError"}},dt=class extends et{constructor(e,t,n,r,s=!0){super(`Request timed out after ${t}ms`,e,n,void 0,{timeoutMs:t,...r},s),this.name="AxAIServiceTimeoutError"}},pr=class extends rt{constructor(e,t,n,r,s,i,a=!0){super(e,t,n,r,s,i,void 0,a),this.name="AxTokenLimitError"}},Pe=class extends et{constructor(e,t,n,r,s=!0){super(`Request aborted${t?`: ${t}`:""}`,e,n,void 0,{abortReason:t,...r},s),this.name="AxAIServiceAbortedError"}},$t=class extends et{constructor(e,t,n,r,s=!0){super("Authentication failed",e,t,n,r,s),this.name="AxAIServiceAuthenticationError"}},Le=class extends Error{constructor(t,n,r){super(`Model refused to fulfill request: ${t}`);this.refusalMessage=t;this.model=n;this.requestId=r;this.name="AxAIRefusalError",this.timestamp=new Date().toISOString(),this.errorId=Ze()}timestamp;errorId;toString(){return[`${this.name}: ${this.message}`,`Refusal: ${this.refusalMessage}`,this.model?`Model: ${this.model}`:"",this.requestId?`Request ID: ${this.requestId}`:"",`Timestamp: ${this.timestamp}`,`Error ID: ${this.errorId}`].filter(Boolean).join(`
7
+ `:"")+r;break;case"id":this.currentEvent.id=r;break;case"retry":{let s=Number.parseInt(r,10);Number.isNaN(s)||(this.currentEvent.retry=s);break}}}processEvent(e){if(this.currentEvent.rawData){if(this.currentEvent.event||(this.currentEvent.event="message"),this.currentEvent.rawData.trim()==="[DONE]"){this.currentEvent={rawData:""};return}try{let t=this.dataParser(this.currentEvent.rawData);e.enqueue(t)}catch(t){this.onError(t,this.currentEvent.rawData)}this.currentEvent={rawData:""}}}};var Zs=class{decoder;constructor(){this.decoder=new TextDecoder}transform(e,t){if(!(e instanceof ArrayBuffer||ArrayBuffer.isView(e)))throw new TypeError("Input data must be a BufferSource");let n=this.decoder.decode(e,{stream:!0});n.length!==0&&t.enqueue(n)}flush(e){let t=this.decoder.decode();t.length!==0&&e.enqueue(t)}},mo=class extends TransformStream{constructor(){super(new Zs)}};var Id={maxRetries:3,initialDelayMs:1e3,maxDelayMs:6e4,backoffFactor:2,retryableStatusCodes:[500,408,429,502,503,504]},Td=globalThis.TextDecoderStream??mo,et=class extends Error{constructor(t,n,r,s,i={},a=!0){super(t);this.url=n;this.requestBody=r;this.responseBody=s;this.name="AxAIServiceError",this.timestamp=new Date().toISOString(),this.errorId=Ze(),this.context=i,this.includeRequestBodyInErrors=a,this.stack=this.toString()}timestamp;errorId;context;includeRequestBodyInErrors;toString(){let t=[`${this.name}: ${this.message}`,`URL: ${this.url}`];return this.includeRequestBodyInErrors&&t.push(`Request Body: ${JSON.stringify(this.requestBody,null,2)}`),t.push(`Response Body: ${JSON.stringify(this.responseBody,null,2)}`,`Context: ${JSON.stringify(this.context,null,2)}`,`Timestamp: ${this.timestamp}`,`Error ID: ${this.errorId}`),t.join(`
8
+ `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},rt=class extends et{constructor(t,n,r,s,i,a,u,c=!0){let l=u?` (after ${u} retries)`:"";super(`HTTP ${t} - ${n}${l}`,r,s,{httpStatus:t,httpStatusText:n,responseBody:i,...a},{},c);this.status=t;this.statusText=n;this.name="AxAIServiceStatusError"}},Je=class extends et{constructor(t,n,r,s,i,a=!0){super(`Network Error: ${t.message}`,n,r,s,{originalErrorName:t.name,originalErrorStack:t.stack,...i},a);this.originalError=t;this.name="AxAIServiceNetworkError",this.stack=t.stack}},Nt=class extends et{constructor(e,t,n,r,s=!0){super(e,t,n,void 0,r,s),this.name="AxAIServiceResponseError"}},gt=class extends et{constructor(t,n,r,s,i=!0){super("Stream terminated unexpectedly by remote host",t,n,void 0,{lastChunk:r,...s},i);this.lastChunk=r;this.name="AxAIServiceStreamTerminatedError"}},dt=class extends et{constructor(e,t,n,r,s=!0){super(`Request timed out after ${t}ms`,e,n,void 0,{timeoutMs:t,...r},s),this.name="AxAIServiceTimeoutError"}},mr=class extends rt{constructor(e,t,n,r,s,i,a=!0){super(e,t,n,r,s,i,void 0,a),this.name="AxTokenLimitError"}},_e=class extends et{constructor(e,t,n,r,s=!0){super(`Request aborted${t?`: ${t}`:""}`,e,n,void 0,{abortReason:t,...r},s),this.name="AxAIServiceAbortedError"}},Lt=class extends et{constructor(e,t,n,r,s=!0){super("Authentication failed",e,t,n,r,s),this.name="AxAIServiceAuthenticationError"}},Le=class extends Error{constructor(t,n,r){super(`Model refused to fulfill request: ${t}`);this.refusalMessage=t;this.model=n;this.requestId=r;this.name="AxAIRefusalError",this.timestamp=new Date().toISOString(),this.errorId=Ze()}timestamp;errorId;toString(){return[`${this.name}: ${this.message}`,`Refusal: ${this.refusalMessage}`,this.model?`Model: ${this.model}`:"",this.requestId?`Request ID: ${this.requestId}`:"",`Timestamp: ${this.timestamp}`,`Error ID: ${this.errorId}`].filter(Boolean).join(`
9
9
  `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},ft=class extends Error{constructor(t,n,r=!1){super(`${t} not supported by ${n}${r?" (fallback available)":""}`);this.mediaType=t;this.provider=n;this.fallbackAvailable=r;this.name="AxMediaNotSupportedError",this.timestamp=new Date().toISOString(),this.errorId=Ze()}timestamp;errorId;toString(){return[`${this.name}: ${this.message}`,`Media Type: ${this.mediaType}`,`Provider: ${this.provider}`,`Fallback Available: ${this.fallbackAvailable}`,`Timestamp: ${this.timestamp}`,`Error ID: ${this.errorId}`].join(`
10
- `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},It=class extends Error{constructor(t,n,r){super(`Failed to process ${n} during ${r}: ${t.message}`);this.originalError=t;this.contentType=n;this.processingStep=r;this.name="AxContentProcessingError",this.timestamp=new Date().toISOString(),this.errorId=Ze()}timestamp;errorId;toString(){return[`${this.name}: ${this.message}`,`Content Type: ${this.contentType}`,`Processing Step: ${this.processingStep}`,`Original Error: ${this.originalError.message}`,`Timestamp: ${this.timestamp}`,`Error ID: ${this.errorId}`].join(`
11
- `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}};async function Qs(o){try{return o.headers.get("content-type")?.includes("application/json")?await o.json():await o.clone().text()}catch(e){return`[ReadableStream - read failed: ${e.message}]`}}function za(o,e){return Math.min(e.maxDelayMs,e.initialDelayMs*e.backoffFactor**o)*(.75+Math.random()*.5)}function Lp(o){if(!o)return;let e=Number(o);if(!Number.isNaN(e))return e*1e3;let t=Date.parse(o);if(!Number.isNaN(t)){let n=t-Date.now();return Math.max(0,n)}}function $p(){return{startTime:Date.now(),retryCount:0}}function qa(o){o.retryCount++,o.lastRetryTime=Date.now()}function Ha(o,e,t,n){return t>=n.maxRetries?!1:e&&n.retryableStatusCodes.includes(e)?!0:o instanceof Je&&!(o instanceof $t)}var tt=async(o,e)=>{if(o.localCall)return await o.localCall(e,o.stream);if(!o.url)throw new Error("API URL is required when localCall is not provided");let t={..._p,...o.retry},n=o.timeout,r=$p(),s=o.verbose??!1,i=o.includeRequestBodyInErrors??!0,a,l=new URL(o.url),c=`${[l.pathname,o.name].filter(Boolean).join("/").replace(/\/+/g,"/")}${l.search}`,u=new URL(c,l);if(o.corsProxy){let m=u.href;u=new URL(`${o.corsProxy}?url=${encodeURIComponent(m)}`)}let p=Ze();if(o.validateRequest&&!await o.validateRequest(e))throw new Lt("Invalid request data",u.href,e,{validation:"request"},i);o.span?.setAttributes({"http.request.method":o.put?"PUT":"POST","url.full":u.href,"request.id":p,"request.startTime":r.startTime});let d=0;for(;;){let m=new AbortController;if(o.abortSignal){if(o.abortSignal.aborted)throw new Pe(u.href,o.abortSignal.reason,e,{metrics:r},i);let g=()=>{m.abort(o.abortSignal.reason||"User aborted request")};o.abortSignal.addEventListener("abort",g,{once:!0});let f=m.abort.bind(m);m.abort=x=>{o.abortSignal.removeEventListener("abort",g),f(x)}}n&&(a=setTimeout(()=>{m.abort("Request timeout")},n));try{s&&console.log(`
10
+ `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},Tt=class extends Error{constructor(t,n,r){super(`Failed to process ${n} during ${r}: ${t.message}`);this.originalError=t;this.contentType=n;this.processingStep=r;this.name="AxContentProcessingError",this.timestamp=new Date().toISOString(),this.errorId=Ze()}timestamp;errorId;toString(){return[`${this.name}: ${this.message}`,`Content Type: ${this.contentType}`,`Processing Step: ${this.processingStep}`,`Original Error: ${this.originalError.message}`,`Timestamp: ${this.timestamp}`,`Error ID: ${this.errorId}`].join(`
11
+ `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}};async function ei(o){try{return o.headers.get("content-type")?.includes("application/json")?await o.json():await o.clone().text()}catch(e){return`[ReadableStream - read failed: ${e.message}]`}}function ru(o,e){return Math.min(e.maxDelayMs,e.initialDelayMs*e.backoffFactor**o)*(.75+Math.random()*.5)}function wd(o){if(!o)return;let e=Number(o);if(!Number.isNaN(e))return e*1e3;let t=Date.parse(o);if(!Number.isNaN(t)){let n=t-Date.now();return Math.max(0,n)}}function Rd(){return{startTime:Date.now(),retryCount:0}}function ou(o){o.retryCount++,o.lastRetryTime=Date.now()}function su(o,e,t,n){return t>=n.maxRetries?!1:e&&n.retryableStatusCodes.includes(e)?!0:o instanceof Je&&!(o instanceof Lt)}var tt=async(o,e)=>{if(o.localCall)return await o.localCall(e,o.stream);if(!o.url)throw new Error("API URL is required when localCall is not provided");let t={...Id,...o.retry},n=o.timeout,r=Rd(),s=o.verbose??!1,i=o.includeRequestBodyInErrors??!0,a,u=new URL(o.url),c=`${[u.pathname,o.name].filter(Boolean).join("/").replace(/\/+/g,"/")}${u.search}`,l=new URL(c,u);if(o.corsProxy){let m=l.href;l=new URL(`${o.corsProxy}?url=${encodeURIComponent(m)}`)}let p=Ze();if(o.validateRequest&&!await o.validateRequest(e))throw new Nt("Invalid request data",l.href,e,{validation:"request"},i);o.span?.setAttributes({"http.request.method":o.put?"PUT":"POST","url.full":l.href,"request.id":p,"request.startTime":r.startTime});let d=0;for(;;){let m=new AbortController;if(o.abortSignal){if(o.abortSignal.aborted)throw new _e(l.href,o.abortSignal.reason,e,{metrics:r},i);let g=()=>{m.abort(o.abortSignal.reason||"User aborted request")};o.abortSignal.addEventListener("abort",g,{once:!0});let f=m.abort.bind(m);m.abort=x=>{o.abortSignal.removeEventListener("abort",g),f(x)}}n&&(a=setTimeout(()=>{m.abort("Request timeout")},n));try{s&&console.log(`
12
12
  --- [AxAI API Request] ---
13
- `,`URL: ${u.href}
13
+ `,`URL: ${l.href}
14
14
  `,`Method: ${o.put?"PUT":"POST"}
15
15
  `,"Headers:",JSON.stringify({"Content-Type":"application/json","X-Request-ID":p,"X-Retry-Count":d.toString(),...o.headers},null,2),`
16
16
  Body:`,JSON.stringify(e,null,2),`
17
17
  ------------------------
18
- `);let g=await(o.fetch??fetch)(u,{method:o.put?"PUT":"POST",headers:{"Content-Type":"application/json","X-Request-ID":p,"X-Retry-Count":d.toString(),...o.headers},body:JSON.stringify(e),signal:m.signal});if(a&&clearTimeout(a),g.status===401||g.status===403){let T=await Qs(g);throw new $t(u.href,e,T,{metrics:r},i)}if(g.status===400){let T=await Qs(g),C=T,v=!1;if(C?.error?.code==="context_length_exceeded")v=!0;else if(C?.type==="invalid_request_error"&&(C?.error?.message?.includes("prompt is too long")||C?.error?.message?.includes("max_tokens")||C?.error?.message?.includes("token limit")))v=!0;else if(C?.error?.code===400&&C?.error?.status==="INVALID_ARGUMENT"&&(C?.error?.message?.includes("token")||C?.error?.message?.includes("limit")))v=!0;else{let k=JSON.stringify(T).toLowerCase();(k.includes("token")&&k.includes("limit")||k.includes("context length")||k.includes("prompt is too long"))&&(v=!0)}if(v)throw new pr(g.status,g.statusText,u.href,e,T,{metrics:r},i)}if(g.status>=400&&Ha(new Error,g.status,d,t)){let T=za(d,t),C=Lp(g.headers.get("Retry-After"));C!==void 0&&C<=t.maxDelayMs&&(T=C,s&&console.log(`[AxAI] Respecting Retry-After header: ${T}ms`)),d++,qa(r),o.span?.addEvent("retry",{attempt:d,delay:T,status:g.status,"metrics.startTime":r.startTime,"metrics.retryCount":r.retryCount,"metrics.lastRetryTime":r.lastRetryTime}),await new Promise(v=>setTimeout(v,T));continue}if(g.status>=400){let T=await Qs(g);throw new rt(g.status,g.statusText,u.href,e,T,{metrics:r},d>0?d:void 0,i)}if(!o.stream){let T=await g.json();if(s&&console.log(`
18
+ `);let g=await(o.fetch??fetch)(l,{method:o.put?"PUT":"POST",headers:{"Content-Type":"application/json","X-Request-ID":p,"X-Retry-Count":d.toString(),...o.headers},body:JSON.stringify(e),signal:m.signal});if(a&&clearTimeout(a),g.status===401||g.status===403){let C=await ei(g);throw new Lt(l.href,e,C,{metrics:r},i)}if(g.status===400){let C=await ei(g),I=C,v=!1;if(I?.error?.code==="context_length_exceeded")v=!0;else if(I?.type==="invalid_request_error"&&(I?.error?.message?.includes("prompt is too long")||I?.error?.message?.includes("max_tokens")||I?.error?.message?.includes("token limit")))v=!0;else if(I?.error?.code===400&&I?.error?.status==="INVALID_ARGUMENT"&&(I?.error?.message?.includes("token")||I?.error?.message?.includes("limit")))v=!0;else{let O=JSON.stringify(C).toLowerCase();(O.includes("token")&&O.includes("limit")||O.includes("context length")||O.includes("prompt is too long"))&&(v=!0)}if(v)throw new mr(g.status,g.statusText,l.href,e,C,{metrics:r},i)}if(g.status>=400&&su(new Error,g.status,d,t)){let C=ru(d,t),I=wd(g.headers.get("Retry-After"));I!==void 0&&I<=t.maxDelayMs&&(C=I,s&&console.log(`[AxAI] Respecting Retry-After header: ${C}ms`)),d++,ou(r),o.span?.addEvent("retry",{attempt:d,delay:C,status:g.status,"metrics.startTime":r.startTime,"metrics.retryCount":r.retryCount,"metrics.lastRetryTime":r.lastRetryTime}),await new Promise(v=>setTimeout(v,C));continue}if(g.status>=400){let C=await ei(g);throw new rt(g.status,g.statusText,l.href,e,C,{metrics:r},d>0?d:void 0,i)}if(!o.stream){let C=await g.json();if(s&&console.log(`
19
19
  --- [AxAI API Response] ---
20
20
  `,`Status: ${g.status} ${g.statusText}
21
- `,"Body:",JSON.stringify(T,null,2),`
21
+ `,"Body:",JSON.stringify(C,null,2),`
22
22
  -------------------------
23
- `),o.validateResponse&&!await o.validateResponse(T))throw new Lt("Invalid response data",u.href,e,{validation:"response"},i);return o.span?.setAttributes({"response.time":Date.now()-r.startTime,"response.retries":r.retryCount}),T}if(s&&console.log(`
23
+ `),o.validateResponse&&!await o.validateResponse(C))throw new Nt("Invalid response data",l.href,e,{validation:"response"},i);return o.span?.setAttributes({"response.time":Date.now()-r.startTime,"response.retries":r.retryCount}),C}if(s&&console.log(`
24
24
  --- [AxAI API Streaming Response Started] ---
25
25
  `,`Status: ${g.status} ${g.statusText}
26
26
  `,`
27
27
  -------------------------------------------
28
- `),!g.body)throw new Lt("Response body is null",u.href,e,{metrics:r},i);let f,x=0;if(typeof window<"u"&&typeof EventSource<"u")return new ReadableStream({start(T){let C=g.body.getReader(),v=new TextDecoder,k="";async function R(){try{for(;;){let{done:E,value:S}=await C.read();if(E){b=!0,T.close();break}k+=v.decode(S,{stream:!0});let _=k.split(`
28
+ `),!g.body)throw new Nt("Response body is null",l.href,e,{metrics:r},i);let f,x=0;if(typeof window<"u"&&typeof EventSource<"u")return new ReadableStream({start(C){let I=g.body.getReader(),v=new TextDecoder,O="";async function R(){try{for(;;){let{done:E,value:S}=await I.read();if(E){y=!0,C.close();break}O+=v.decode(S,{stream:!0});let _=O.split(`
29
29
 
30
- `);k=_.pop()||"";for(let L of _){if(!L.trim())continue;let P=L.split(`
31
- `),F="",N="message";for(let U of P)U.startsWith("data: ")?F=U.slice(6):U.startsWith("event: ")&&(N=U.slice(7));if(F){if(F==="[DONE]"){T.close();return}try{let U=JSON.parse(F);f=U,x++,r.streamChunks=x,r.lastChunkTime=Date.now(),T.enqueue(U),o.span?.addEvent("stream.chunk",{"stream.chunks":x,"stream.duration":Date.now()-r.startTime,"response.retries":r.retryCount,"sse.event.type":N})}catch(U){s&&console.warn("Skipping non-JSON SSE data:",F,U)}}}}}catch(E){let S=E,_={...r,streamDuration:Date.now()-r.startTime};S.name==="AbortError"||S.message?.includes("aborted")?T.error(new gt(u.href,e,f,{streamMetrics:_},i)):T.error(new Je(S,u.href,e,"[ReadableStream - consumed during streaming]",{streamMetrics:_},i))}finally{C.releaseLock()}}R()}});let h=new TransformStream({transform(T,C){f=T,x++,r.streamChunks=x,r.lastChunkTime=Date.now(),C.enqueue(T),o.span?.addEvent("stream.chunk",{"stream.chunks":x,"stream.duration":Date.now()-r.startTime,"response.retries":r.retryCount})}}),b=!1;return new ReadableStream({start(T){let C=g.body.pipeThrough(new Np).pipeThrough(new lo).pipeThrough(h).getReader();async function v(){try{for(;;){let{done:k,value:R}=await C.read();if(k){b||(b=!0,T.close());break}if(b)break;T.enqueue(R)}}catch(k){let R=k,E={...r,streamDuration:Date.now()-r.startTime};throw R.name==="AbortError"||R.message?.includes("aborted")?T.error(new gt(u.href,e,f,{streamMetrics:E},i)):R instanceof TypeError&&R.message.includes("cancelled")?T.error(new gt(u.href,e,f,{streamMetrics:E,cancelReason:"Stream cancelled by client"},i)):T.error(new Je(R,u.href,e,"[ReadableStream - consumed during streaming]",{streamMetrics:E},i)),R}finally{a&&clearTimeout(a),C.releaseLock()}}v()},cancel(){b=!0}})}catch(g){if(g instanceof Error&&g.name==="AbortError")throw o.abortSignal?.aborted?new Pe(u.href,o.abortSignal.reason,e,{metrics:r},i):new dt(u.href,n||0,e,{metrics:r},i);let f=g;if(!(g instanceof et)&&g instanceof Error&&(f=new Je(g,u.href,e,void 0,{metrics:r},i)),o.span?.isRecording()&&(o.span.recordException(f),o.span.setAttributes({"error.time":Date.now()-r.startTime,"error.retries":r.retryCount})),f instanceof Je&&Ha(f,void 0,d,t)){let x=za(d,t);d++,qa(r),o.span?.addEvent("retry",{attempt:d,delay:x,error:f.message,"metrics.startTime":r.startTime,"metrics.retryCount":r.retryCount,"metrics.lastRetryTime":r.lastRetryTime}),await new Promise(A=>setTimeout(A,x));continue}throw f instanceof et&&(f.context.metrics=r),f}finally{a!==void 0&&clearTimeout(a)}}};var un=require("@opentelemetry/api");var de={signatureStrict:!0,useStructuredPrompt:!0,tracer:void 0,meter:void 0,logger:void 0,optimizerLogger:void 0,debug:void 0,abortSignal:void 0,customLabels:void 0,cachingFunction:void 0,functionResultFormatter:o=>typeof o=="string"?o:o==null?"":JSON.stringify(o,null,2)};var ot=class{ANSI_WHITE_BRIGHT="\x1B[97m";ANSI_GREEN_BRIGHT="\x1B[92m";ANSI_BLUE_BRIGHT="\x1B[94m";ANSI_RED_BRIGHT="\x1B[91m";ANSI_YELLOW_BRIGHT="\x1B[93m";ANSI_YELLOW="\x1B[93m";ANSI_RED="\x1B[91m";ANSI_RESET="\x1B[0m";ANSI_ORANGE="\x1B[38;5;208m";ANSI_WHITE="\x1B[37m";ANSI_CYAN_BRIGHT="\x1B[96m";ANSI_MAGENTA_BRIGHT="\x1B[95m";ANSI_GRAY="\x1B[90m";ANSI_GREEN="\x1B[32m";ANSI_CYAN="\x1B[36m";ANSI_MAGENTA="\x1B[35m";ANSI_BLUE="\x1B[34m";ANSI_YELLOW_DIM="\x1B[33m";colorize(e,t){return`${t}${e}${this.ANSI_RESET}`}whiteBright(e){return this.colorize(e,this.ANSI_WHITE_BRIGHT)}greenBright(e){return this.colorize(e,this.ANSI_GREEN_BRIGHT)}blueBright(e){return this.colorize(e,this.ANSI_BLUE_BRIGHT)}redBright(e){return this.colorize(e,this.ANSI_RED_BRIGHT)}white(e){return this.colorize(e,this.ANSI_WHITE)}yellow(e){return this.colorize(e,this.ANSI_YELLOW)}yellowBright(e){return this.colorize(e,this.ANSI_YELLOW_BRIGHT)}red(e){return this.colorize(e,this.ANSI_RED)}orange(e){return this.colorize(e,this.ANSI_ORANGE)}cyanBright(e){return this.colorize(e,this.ANSI_CYAN_BRIGHT)}magentaBright(e){return this.colorize(e,this.ANSI_MAGENTA_BRIGHT)}gray(e){return this.colorize(e,this.ANSI_GRAY)}green(e){return this.colorize(e,this.ANSI_GREEN)}cyan(e){return this.colorize(e,this.ANSI_CYAN)}magenta(e){return this.colorize(e,this.ANSI_MAGENTA)}blue(e){return this.colorize(e,this.ANSI_BLUE)}yellowDim(e){return this.colorize(e,this.ANSI_YELLOW_DIM)}};var zf=new ot,Ka=o=>{console.log(o)},Wa=(o,e,t)=>{let n=(r,s)=>t&&s&&s in t?t[s](r):r;switch(o.role){case"system":return`${n("[ SYSTEM ]","magentaBright")}
30
+ `);O=_.pop()||"";for(let $ of _){if(!$.trim())continue;let M=$.split(`
31
+ `),F="",N="message";for(let G of M)G.startsWith("data: ")?F=G.slice(6):G.startsWith("event: ")&&(N=G.slice(7));if(F){if(F==="[DONE]"){C.close();return}try{let G=JSON.parse(F);f=G,x++,r.streamChunks=x,r.lastChunkTime=Date.now(),C.enqueue(G),o.span?.addEvent("stream.chunk",{"stream.chunks":x,"stream.duration":Date.now()-r.startTime,"response.retries":r.retryCount,"sse.event.type":N})}catch(G){s&&console.warn("Skipping non-JSON SSE data:",F,G)}}}}}catch(E){let S=E,_={...r,streamDuration:Date.now()-r.startTime};S.name==="AbortError"||S.message?.includes("aborted")?C.error(new gt(l.href,e,f,{streamMetrics:_},i)):C.error(new Je(S,l.href,e,"[ReadableStream - consumed during streaming]",{streamMetrics:_},i))}finally{I.releaseLock()}}R()}});let h=new TransformStream({transform(C,I){f=C,x++,r.streamChunks=x,r.lastChunkTime=Date.now(),I.enqueue(C),o.span?.addEvent("stream.chunk",{"stream.chunks":x,"stream.duration":Date.now()-r.startTime,"response.retries":r.retryCount})}}),y=!1;return new ReadableStream({start(C){let I=g.body.pipeThrough(new Td).pipeThrough(new po).pipeThrough(h).getReader();async function v(){try{for(;;){let{done:O,value:R}=await I.read();if(O){y||(y=!0,C.close());break}if(y)break;C.enqueue(R)}}catch(O){let R=O,E={...r,streamDuration:Date.now()-r.startTime};throw R.name==="AbortError"||R.message?.includes("aborted")?C.error(new gt(l.href,e,f,{streamMetrics:E},i)):R instanceof TypeError&&R.message.includes("cancelled")?C.error(new gt(l.href,e,f,{streamMetrics:E,cancelReason:"Stream cancelled by client"},i)):C.error(new Je(R,l.href,e,"[ReadableStream - consumed during streaming]",{streamMetrics:E},i)),R}finally{a&&clearTimeout(a),I.releaseLock()}}v()},cancel(){y=!0}})}catch(g){if(g instanceof Error&&g.name==="AbortError")throw o.abortSignal?.aborted?new _e(l.href,o.abortSignal.reason,e,{metrics:r},i):new dt(l.href,n||0,e,{metrics:r},i);let f=g;if(!(g instanceof et)&&g instanceof Error&&(f=new Je(g,l.href,e,void 0,{metrics:r},i)),o.span?.isRecording()&&(o.span.recordException(f),o.span.setAttributes({"error.time":Date.now()-r.startTime,"error.retries":r.retryCount})),f instanceof Je&&su(f,void 0,d,t)){let x=ru(d,t);d++,ou(r),o.span?.addEvent("retry",{attempt:d,delay:x,error:f.message,"metrics.startTime":r.startTime,"metrics.retryCount":r.retryCount,"metrics.lastRetryTime":r.lastRetryTime}),await new Promise(A=>setTimeout(A,x));continue}throw f instanceof et&&(f.context.metrics=r),f}finally{a!==void 0&&clearTimeout(a)}}};var gn=require("@opentelemetry/api");var ge={signatureStrict:!0,useStructuredPrompt:!0,tracer:void 0,meter:void 0,logger:void 0,optimizerLogger:void 0,debug:void 0,abortSignal:void 0,customLabels:void 0,cachingFunction:void 0,functionResultFormatter:o=>typeof o=="string"?o:o==null?"":JSON.stringify(o,null,2)};var ot=class{ANSI_WHITE_BRIGHT="\x1B[97m";ANSI_GREEN_BRIGHT="\x1B[92m";ANSI_BLUE_BRIGHT="\x1B[94m";ANSI_RED_BRIGHT="\x1B[91m";ANSI_YELLOW_BRIGHT="\x1B[93m";ANSI_YELLOW="\x1B[93m";ANSI_RED="\x1B[91m";ANSI_RESET="\x1B[0m";ANSI_ORANGE="\x1B[38;5;208m";ANSI_WHITE="\x1B[37m";ANSI_CYAN_BRIGHT="\x1B[96m";ANSI_MAGENTA_BRIGHT="\x1B[95m";ANSI_GRAY="\x1B[90m";ANSI_GREEN="\x1B[32m";ANSI_CYAN="\x1B[36m";ANSI_MAGENTA="\x1B[35m";ANSI_BLUE="\x1B[34m";ANSI_YELLOW_DIM="\x1B[33m";colorize(e,t){return`${t}${e}${this.ANSI_RESET}`}whiteBright(e){return this.colorize(e,this.ANSI_WHITE_BRIGHT)}greenBright(e){return this.colorize(e,this.ANSI_GREEN_BRIGHT)}blueBright(e){return this.colorize(e,this.ANSI_BLUE_BRIGHT)}redBright(e){return this.colorize(e,this.ANSI_RED_BRIGHT)}white(e){return this.colorize(e,this.ANSI_WHITE)}yellow(e){return this.colorize(e,this.ANSI_YELLOW)}yellowBright(e){return this.colorize(e,this.ANSI_YELLOW_BRIGHT)}red(e){return this.colorize(e,this.ANSI_RED)}orange(e){return this.colorize(e,this.ANSI_ORANGE)}cyanBright(e){return this.colorize(e,this.ANSI_CYAN_BRIGHT)}magentaBright(e){return this.colorize(e,this.ANSI_MAGENTA_BRIGHT)}gray(e){return this.colorize(e,this.ANSI_GRAY)}green(e){return this.colorize(e,this.ANSI_GREEN)}cyan(e){return this.colorize(e,this.ANSI_CYAN)}magenta(e){return this.colorize(e,this.ANSI_MAGENTA)}blue(e){return this.colorize(e,this.ANSI_BLUE)}yellowDim(e){return this.colorize(e,this.ANSI_YELLOW_DIM)}};var Lf=new ot,iu=o=>{console.log(o)},au=(o,e,t)=>{let n=(r,s)=>t&&s&&s in t?t[s](r):r;switch(o.role){case"system":return`${n("[ SYSTEM ]","magentaBright")}
32
32
  ${n(o.content,"magenta")}`;case"function":return`${n("[ FUNCTION RESULT ]","yellow")}
33
33
  ${n(o.result??"[No result]","yellowDim")}`;case"user":{let r=`${n("[ USER ]","greenBright")}
34
34
  `;if(typeof o.content=="string")return r+n(o.content,"green");let s=o.content.map(i=>{if(i.type==="text")return n(i.text,"green");if(i.type==="image"){let a=e?"[Image]":`[Image: ${i.image}]`;return n(a,"green")}if(i.type==="audio"){let a=e?"[Audio]":`[Audio: ${i.data}]`;return n(a,"green")}return n("[Unknown content type]","gray")});return r+s.join(`
35
35
  `)}case"assistant":{let r=n("[ ASSISTANT","cyanBright");o.name&&(r+=` ${o.name}`),r+=" ]";let s=`${r}
36
36
  `;return o.content&&(s+=`${n(o.content,"cyan")}
37
37
  `),o.functionCalls&&o.functionCalls.length>0&&(s+=`${n("[ FUNCTION CALLS ]","yellow")}
38
- `,o.functionCalls.forEach((i,a)=>{let l=typeof i.function.params=="string"?i.function.params:JSON.stringify(i.function.params,null,2);s+=n(`${a+1}. ${i.function.name}(${l}) [id: ${i.id}]`,"yellowDim"),a<(o.functionCalls?.length??0)-1&&(s+=`
38
+ `,o.functionCalls.forEach((i,a)=>{let u=typeof i.function.params=="string"?i.function.params:JSON.stringify(i.function.params,null,2);s+=n(`${a+1}. ${i.function.name}(${u}) [id: ${i.id}]`,"yellowDim"),a<(o.functionCalls?.length??0)-1&&(s+=`
39
39
  `)}),s+=`
40
40
  `),!o.content&&(!o.functionCalls||o.functionCalls.length===0)&&(s+=n("[No content]","gray")),s}default:return`${n("[ UNKNOWN ]","redBright")}
41
- ${n(JSON.stringify(o),"gray")}`}},Ys=(o=Ka)=>{let e=new ot,t=e.gray(`${"\u2500".repeat(60)}
41
+ ${n(JSON.stringify(o),"gray")}`}},ti=(o=iu)=>{let e=new ot,t=e.gray(`${"\u2500".repeat(60)}
42
42
  `);return n=>{let r=n,s="";switch(r.name){case"ChatRequestChatPrompt":s=`
43
43
  ${e.blueBright(`[ CHAT REQUEST Step ${r.step} ]`)}
44
44
  ${t}
45
- `,r.value.forEach((i,a)=>{s+=Wa(i,void 0,e),a<r.value.length-1&&(s+=`
45
+ `,r.value.forEach((i,a)=>{s+=au(i,void 0,e),a<r.value.length-1&&(s+=`
46
46
  ${t}
47
47
  `)}),s+=`
48
48
  ${t}`;break;case"FunctionResults":s=`
@@ -52,8 +52,8 @@ Result: ${i.result}`),a<r.value.length-1&&(s+=`
52
52
  ${t}
53
53
  `)});break;case"ChatResponseResults":s=`
54
54
  ${e.cyanBright("[ CHAT RESPONSE ]")}
55
- `,r.value.forEach((i,a)=>{let l=[],c=i.thoughtBlocks?.some(u=>u.encrypted);i.thought&&l.push(e.gray(`[THOUGHT${c?" (redacted)":""}]
56
- ${i.thought}`)),i.content&&l.push(e.cyan(i.content)),l.length===0&&l.push(e.gray("[No content]")),s+=l.join(`
55
+ `,r.value.forEach((i,a)=>{let u=[],c=i.thoughtBlocks?.some(l=>l.encrypted);i.thought&&u.push(e.gray(`[THOUGHT${c?" (redacted)":""}]
56
+ ${i.thought}`)),i.content&&u.push(e.cyan(i.content)),u.length===0&&u.push(e.gray("[No content]")),s+=u.join(`
57
57
  `),a<r.value.length-1&&(s+=`
58
58
  ${t}
59
59
  `)});break;case"ChatResponseStreamingResult":{let i=r.value.thought,a=i||r.value.delta||r.value.content||"";s=i?e.gray(`[THOUGHT]
@@ -102,10 +102,10 @@ ${t}
102
102
  [ CHAT RESPONSE CITATIONS ]`)}
103
103
  `,r.value.forEach(i=>{s+=`${e.white("- ")}${e.cyan(i.title||i.url)}
104
104
  `,i.description&&(s+=` ${e.gray(i.description)}
105
- `)}),s+=t;break}default:s=e.gray(JSON.stringify(r,null,2))}o(s)}},Va=Ys(),Ja=(o=Ka)=>{let e="\u2500".repeat(60);return t=>{let n=t,r="";switch(n.name){case"ChatRequestChatPrompt":r=`
105
+ `)}),s+=t;break}default:s=e.gray(JSON.stringify(r,null,2))}o(s)}},uu=ti(),cu=(o=iu)=>{let e="\u2500".repeat(60);return t=>{let n=t,r="";switch(n.name){case"ChatRequestChatPrompt":r=`
106
106
  [ CHAT REQUEST Step ${n.step} ]
107
107
  ${e}
108
- `,n.value.forEach((s,i)=>{r+=Wa(s),i<n.value.length-1&&(r+=`
108
+ `,n.value.forEach((s,i)=>{r+=au(s),i<n.value.length-1&&(r+=`
109
109
  ${e}
110
110
  `)}),r+=`
111
111
  ${e}`;break;case"FunctionResults":r=`
@@ -116,7 +116,7 @@ Result: ${s.result}`,i<n.value.length-1&&(r+=`
116
116
  ${e}
117
117
  `)});break;case"ChatResponseResults":r=`
118
118
  [ CHAT RESPONSE ]
119
- `,n.value.forEach((s,i)=>{let a=[],l=s.thoughtBlocks?.some(c=>c.encrypted);s.thought&&a.push(`[thought${l?" (redacted)":""}] ${s.thought}`),s.content&&a.push(s.content),a.length===0&&a.push("[No content]"),r+=a.join(`
119
+ `,n.value.forEach((s,i)=>{let a=[],u=s.thoughtBlocks?.some(c=>c.encrypted);s.thought&&a.push(`[thought${u?" (redacted)":""}] ${s.thought}`),s.content&&a.push(s.content),a.length===0&&a.push("[No content]"),r+=a.join(`
120
120
  `),i<n.value.length-1&&(r+=`
121
121
  ${e}
122
122
  `)});break;case"ChatResponseStreamingResult":return;case"ChatResponseStreamingDoneResult":{r=`
@@ -164,19 +164,19 @@ ${e}
164
164
  `,n.value.forEach(s=>{r+=`- ${s.title||s.url}
165
165
  `,s.description&&(r+=` ${s.description}
166
166
  `)}),r+=`${e}
167
- `;break}default:r=JSON.stringify(n,null,2)}o(r)}};var he={LLM_SYSTEM:"gen_ai.system",LLM_OPERATION_NAME:"gen_ai.operation.name",LLM_REQUEST_MODEL:"gen_ai.request.model",LLM_REQUEST_MAX_TOKENS:"gen_ai.request.max_tokens",LLM_REQUEST_TEMPERATURE:"gen_ai.request.temperature",LLM_REQUEST_TOP_K:"gen_ai.request.top_k",LLM_REQUEST_FREQUENCY_PENALTY:"gen_ai.request.frequency_penalty",LLM_REQUEST_PRESENCE_PENALTY:"gen_ai.request.presence_penalty",LLM_REQUEST_STOP_SEQUENCES:"gen_ai.request.stop_sequences",LLM_REQUEST_LLM_IS_STREAMING:"gen_ai.request.llm_is_streaming",LLM_REQUEST_TOP_P:"gen_ai.request.top_p",LLM_USAGE_INPUT_TOKENS:"gen_ai.usage.input_tokens",LLM_USAGE_OUTPUT_TOKENS:"gen_ai.usage.output_tokens",LLM_USAGE_TOTAL_TOKENS:"gen_ai.usage.total_tokens",LLM_USAGE_THOUGHTS_TOKENS:"gen_ai.usage.thoughts_tokens",DB_SYSTEM:"db.system",DB_TABLE:"db.table",DB_NAMESPACE:"db.namespace",DB_ID:"db.id",DB_QUERY_TEXT:"db.query.text",DB_VECTOR:"db.vector",DB_OPERATION_NAME:"db.operation.name",DB_VECTOR_QUERY_TOP_K:"db.vector.query.top_k",DB_QUERY_EMBEDDINGS:"db.query.embeddings",DB_QUERY_RESULT:"db.query.result",DB_QUERY_EMBEDDINGS_VECTOR:"db.query.embeddings.vector",DB_QUERY_RESULT_ID:"db.query.result.id",DB_QUERY_RESULT_SCORE:"db.query.result.score",DB_QUERY_RESULT_DISTANCE:"db.query.result.distance",DB_QUERY_RESULT_METADATA:"db.query.result.metadata",DB_QUERY_RESULT_VECTOR:"db.query.result.vector",DB_QUERY_RESULT_DOCUMENT:"db.query.result.document"},wt={GEN_AI_USER_MESSAGE:"gen_ai.user.message",GEN_AI_SYSTEM_MESSAGE:"gen_ai.system.message",GEN_AI_ASSISTANT_MESSAGE:"gen_ai.assistant.message",GEN_AI_TOOL_MESSAGE:"gen_ai.tool.message",GEN_AI_CHOICE:"gen_ai.choice",GEN_AI_USAGE:"gen_ai.usage"},Xs=(r=>(r.COMPLETION="completion",r.CHAT="chat",r.RERANK="rerank",r.UNKNOWN="unknown",r))(Xs||{}),Zs=(s=>(s.WORKFLOW="workflow",s.TASK="task",s.AGENT="agent",s.TOOL="tool",s.UNKNOWN="unknown",s))(Zs||{});var ei=class{buffer;doneCallback;transformFn;constructor(e,t){this.transformFn=e,this.doneCallback=t,this.buffer=t?[]:void 0}async transform(e,t){let n=this.transformFn(e);n&&(t.enqueue(n),this.buffer?.push(n))}async flush(e){await this.doneCallback?.(this.buffer??[]),e.terminate()}},uo=class extends TransformStream{constructor(e,t){super(new ei(e,t))}};function po(o,e){for(let t of e){let n=o.find(r=>r.id===t.id);n?(typeof t.function.name=="string"&&t.function.name.length>0&&(n.function.name+=t.function.name),typeof t.function.params=="string"&&t.function.params.length>0&&(n.function.params+=t.function.params),typeof t.function.params=="object"&&(n.function.params=t.function.params)):o.push(t)}}var Qa=(o,e,t,n)=>{let r=n?o.filter(i=>i.role!=="system"):[...o];t({name:"ChatRequestChatPrompt",step:e,value:r})};var Ya=(o,e)=>{if(!o.results)return;let t={name:"ChatResponseResults",value:o.results};e(t)};function Xa(o,e){let t=new Map;for(let n of o)for(let r of n.results){if(!r)continue;let s=t.get(r.index);s?(r.content&&(s.content=(s.content??"")+r.content),r.thought&&(s.thought=(s.thought??"")+r.thought),r.finishReason&&(s.finishReason=r.finishReason),r.functionCalls&&(s.functionCalls?po(s.functionCalls,structuredClone(r.functionCalls)):s.functionCalls=structuredClone(r.functionCalls))):(s=structuredClone(r),t.set(r.index,s))}for(let n of t.values()){let r={name:"ChatResponseStreamingDoneResult",index:n.index,value:n};e(r)}}var Za=(o,e)=>{e({name:"FunctionResults",value:o})},ti=(o,e,t,n)=>{n({name:"FunctionError",index:e,fixingInstructions:t,error:o})},el=(o,e,t,n)=>{n({name:"ValidationError",index:e,fixingInstructions:t,error:o})},tl=(o,e,t,n)=>{n({name:"AssertionError",index:e,fixingInstructions:t,error:o})},nl=(o,e,t)=>{t({name:"RefusalError",index:e,error:o})};var rl=(o,e,t)=>{t({name:"EmbedRequest",embedModel:e,value:o})},ol=(o,e)=>{let t=o.slice(0,3).map(r=>({length:r.length,sample:r.slice(0,5),truncated:r.length>5})),n={name:"EmbedResponse",totalEmbeddings:o.length,value:t};e(n)},sl=(o,e,t,n)=>{n({name:"ResultPickerUsed",sampleCount:o,selectedIndex:e,latency:t})};var go=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n);e[t]=r.length>100?r.substring(0,100):r}return e},Qt=(...o)=>{let e={};for(let t of o)t&&Object.assign(e,t);return e},mo,il=o=>{if(mo)return mo;if(o)return mo=Dp(o),mo};var Dp=o=>({latencyHistogram:o.createHistogram("ax_llm_request_duration_ms",{description:"Duration of LLM requests in milliseconds",unit:"ms"}),errorCounter:o.createCounter("ax_llm_errors_total",{description:"Total number of LLM request errors"}),requestCounter:o.createCounter("ax_llm_requests_total",{description:"Total number of LLM requests"}),tokenCounter:o.createCounter("ax_llm_tokens_total",{description:"Total number of LLM tokens consumed"}),inputTokenCounter:o.createCounter("ax_llm_input_tokens_total",{description:"Total number of input/prompt tokens consumed"}),outputTokenCounter:o.createCounter("ax_llm_output_tokens_total",{description:"Total number of output/completion tokens generated"}),errorRateGauge:o.createGauge("ax_llm_error_rate",{description:"Current error rate as a percentage (0-100)"}),meanLatencyGauge:o.createGauge("ax_llm_mean_latency_ms",{description:"Mean latency of LLM requests in milliseconds",unit:"ms"}),p95LatencyGauge:o.createGauge("ax_llm_p95_latency_ms",{description:"95th percentile latency of LLM requests in milliseconds",unit:"ms"}),p99LatencyGauge:o.createGauge("ax_llm_p99_latency_ms",{description:"99th percentile latency of LLM requests in milliseconds",unit:"ms"}),streamingRequestsCounter:o.createCounter("ax_llm_streaming_requests_total",{description:"Total number of streaming LLM requests"}),functionCallsCounter:o.createCounter("ax_llm_function_calls_total",{description:"Total number of function/tool calls made"}),functionCallLatencyHistogram:o.createHistogram("ax_llm_function_call_latency_ms",{description:"Latency of function calls in milliseconds",unit:"ms"}),requestSizeHistogram:o.createHistogram("ax_llm_request_size_bytes",{description:"Size of LLM request payloads in bytes",unit:"By"}),responseSizeHistogram:o.createHistogram("ax_llm_response_size_bytes",{description:"Size of LLM response payloads in bytes",unit:"By"}),temperatureGauge:o.createGauge("ax_llm_temperature_gauge",{description:"Temperature setting used for LLM requests"}),maxTokensGauge:o.createGauge("ax_llm_max_tokens_gauge",{description:"Maximum tokens setting used for LLM requests"}),estimatedCostCounter:o.createCounter("ax_llm_estimated_cost_total",{description:"Estimated cost of LLM requests in USD",unit:"$"}),promptLengthHistogram:o.createHistogram("ax_llm_prompt_length_chars",{description:"Length of prompts in characters"}),contextWindowUsageGauge:o.createGauge("ax_llm_context_window_usage_ratio",{description:"Context window utilization ratio (0-1)"}),timeoutsCounter:o.createCounter("ax_llm_timeouts_total",{description:"Total number of timed out LLM requests"}),abortsCounter:o.createCounter("ax_llm_aborts_total",{description:"Total number of aborted LLM requests"}),thinkingBudgetUsageCounter:o.createCounter("ax_llm_thinking_budget_usage_total",{description:"Total thinking budget tokens used"}),multimodalRequestsCounter:o.createCounter("ax_llm_multimodal_requests_total",{description:"Total number of multimodal requests (with images/audio)"}),cacheReadTokensCounter:o.createCounter("ax_llm_cache_read_tokens_total",{description:"Total number of tokens read from cache (prompt caching)"}),cacheWriteTokensCounter:o.createCounter("ax_llm_cache_write_tokens_total",{description:"Total number of tokens written to cache (prompt caching)"})}),al=(o,e,t,n,r,s)=>{try{if(o.latencyHistogram){let i=go({operation:e,ai_service:n,...r?{model:r}:{},...s});o.latencyHistogram.record(t,i)}}catch(i){console.warn("Failed to record latency metric:",i)}},ll=(o,e,t,n,r,s,i,a)=>{let l={operation:e,ai_service:s,...i?{model:i}:{},...a};o.meanLatencyGauge&&o.meanLatencyGauge.record(t,l),o.p95LatencyGauge&&o.p95LatencyGauge.record(n,l),o.p99LatencyGauge&&o.p99LatencyGauge.record(r,l)},cl=(o,e,t,n,r)=>{try{if(o.errorCounter){let s=go({operation:e,ai_service:t,...n?{model:n}:{},...r});o.errorCounter.add(1,s)}}catch(s){console.warn("Failed to record error metric:",s)}},ul=(o,e,t,n,r,s)=>{o.errorRateGauge&&o.errorRateGauge.record(t*100,{operation:e,ai_service:n,...r?{model:r}:{},...s})},pl=(o,e,t,n,r)=>{o.requestCounter&&o.requestCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},dr=(o,e,t,n,r,s)=>{try{let i=go({ai_service:n,...r?{model:r}:{},...s});o.tokenCounter&&o.tokenCounter.add(t,{token_type:e,...i}),e==="input"&&o.inputTokenCounter&&o.inputTokenCounter.add(t,i),e==="output"&&o.outputTokenCounter&&o.outputTokenCounter.add(t,i)}catch(i){console.warn("Failed to record token metric:",i)}},dl=(o,e,t,n,r,s)=>{t&&o.streamingRequestsCounter&&o.streamingRequestsCounter.add(1,{operation:e,ai_service:n,...r?{model:r}:{},...s})},ml=(o,e,t,n,r,s)=>{let i={function_name:e,...n?{ai_service:n}:{},...r?{model:r}:{},...s};o.functionCallsCounter&&o.functionCallsCounter.add(1,i),t&&o.functionCallLatencyHistogram&&o.functionCallLatencyHistogram.record(t,i)},ni=(o,e,t,n,r,s)=>{o.requestSizeHistogram&&o.requestSizeHistogram.record(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},ri=(o,e,t,n,r,s)=>{o.responseSizeHistogram&&o.responseSizeHistogram.record(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},gl=(o,e,t,n,r,s)=>{let i={...n?{ai_service:n}:{},...r?{model:r}:{},...s};e!==void 0&&o.temperatureGauge&&o.temperatureGauge.record(e,i),t!==void 0&&o.maxTokensGauge&&o.maxTokensGauge.record(t,i)},oi=(o,e,t,n,r,s)=>{o.estimatedCostCounter&&o.estimatedCostCounter.add(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},fl=(o,e,t,n,r)=>{o.promptLengthHistogram&&o.promptLengthHistogram.record(e,{ai_service:t,...n?{model:n}:{},...r})},hl=(o,e,t,n,r)=>{o.contextWindowUsageGauge&&o.contextWindowUsageGauge.record(e,{ai_service:t,...n?{model:n}:{},...r})},xl=(o,e,t,n,r)=>{o.timeoutsCounter&&o.timeoutsCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},Al=(o,e,t,n,r)=>{o.abortsCounter&&o.abortsCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},yl=(o,e,t,n,r)=>{o.thinkingBudgetUsageCounter&&o.thinkingBudgetUsageCounter.add(e,{ai_service:t,...n?{model:n}:{},...r})},bl=(o,e,t,n,r,s)=>{(e||t)&&o.multimodalRequestsCounter&&o.multimodalRequestsCounter.add(1,{ai_service:n,has_images:e.toString(),has_audio:t.toString(),...r?{model:r}:{},...s})},si=(o,e,t,n,r,s)=>{try{if(t<=0)return;let i=go({ai_service:n,...r?{model:r}:{},...s});e==="read"&&o.cacheReadTokensCounter&&o.cacheReadTokensCounter.add(t,i),e==="write"&&o.cacheWriteTokensCounter&&o.cacheWriteTokensCounter.add(t,i)}catch(i){console.warn("Failed to record cache token metric:",i)}};function Tl(o){try{return JSON.stringify(o,null,2)}catch{return String(o)}}function Rt(o,e={}){let t=[o];throw e.fieldPath!==void 0&&t.push(`Field: ${e.fieldPath}`),e.value!==void 0&&t.push(`Value: ${Tl(e.value)}`),e.note&&t.push(`Note: ${e.note}`),e.item!==void 0&&t.push(`Chat item: ${Tl(e.item)}`),new Error(t.join(`
168
- `))}function cn(o){let e=n=>JSON.stringify(n,null,2);if(!o)throw new Error(`Chat request message item cannot be null or undefined, received: ${e(o)}`);let t=typeof o=="object"&&o!==null&&"role"in o&&typeof o.role=="string"?o.role:void 0;if(!t)throw new Error(`Chat request message must have a role, received: ${e(t)}`);switch(t){case"system":{let n=typeof o=="object"&&o!==null&&"content"in o&&typeof o.content=="string"?o.content:void 0;if(!n||n.trim()==="")throw new Error(`System message content cannot be empty or whitespace-only, received: ${e(n)}`);break}case"user":{let n=typeof o=="object"&&o!==null&&"content"in o?o.content:void 0;if(n===void 0)throw new Error(`User message content cannot be undefined, received: ${e(n)}`);if(typeof n=="string"){if(n.trim()==="")throw new Error(`User message content cannot be empty or whitespace-only, received: ${e(n)}`)}else if(Array.isArray(n)){if(n.length===0)throw new Error(`User message content array cannot be empty, received: ${e(n)}`);for(let r=0;r<n.length;r++){let s=n[r];if(!s||typeof s!="object")throw new Error(`User message content item at index ${r} must be an object, received: ${e(s)}`);let i=typeof s=="object"&&s!==null&&"type"in s&&typeof s.type=="string"?s.type:void 0;if(!i)throw new Error(`User message content item at index ${r} must have a type, received: ${e(i)}`);switch(i){case"text":{let a="text"in s&&typeof s.text=="string"?s.text:void 0;if(!a||a.trim()==="")throw new Error(`User message text content at index ${r} cannot be empty or whitespace-only, received: ${e(a)}`);break}case"image":{let a="image"in s&&typeof s.image=="string"?s.image:void 0,l="mimeType"in s&&typeof s.mimeType=="string"?s.mimeType:void 0;if(!a||a.trim()==="")throw new Error(`User message image content at index ${r} cannot be empty, received: ${e(a)}`);if(!l||l.trim()==="")throw new Error(`User message image content at index ${r} must have a mimeType, received: ${e(l)}`);break}case"audio":{let a="data"in s&&typeof s.data=="string"?s.data:void 0;if(!a||a.trim()==="")throw new Error(`User message audio content at index ${r} cannot be empty, received: ${e(a)}`);break}case"file":{let a="fileUri"in s&&typeof s.fileUri=="string",l="data"in s&&typeof s.data=="string";if(!a&&!l)throw new Error(`User message file content at index ${r} must have either 'data' or 'fileUri', received: ${e(s)}`);if(a&&l)throw new Error(`User message file content at index ${r} cannot have both 'data' and 'fileUri', received: ${e(s)}`);if(a){let u=s.fileUri;if(!u||u.trim()==="")throw new Error(`User message file content at index ${r} fileUri cannot be empty, received: ${e(u)}`)}if(l){let u=s.data;if(!u||u.trim()==="")throw new Error(`User message file content at index ${r} data cannot be empty, received: ${e(u)}`)}let c="mimeType"in s&&typeof s.mimeType=="string"?s.mimeType:null;if(!c||c.trim()==="")throw new Error(`User message file content at index ${r} must have a mimeType, received: ${e(c)}`);break}case"url":{let a="url"in s&&typeof s.url=="string"?s.url:void 0;if(!a||a.trim()==="")throw new Error(`User message url content at index ${r} cannot be empty, received: ${e(a)}`);break}default:throw new Error(`User message content item at index ${r} has unsupported type: ${e(i)}`)}}}else throw new Error(`User message content must be a string or array of content objects, received: ${e(n)}`);break}case"assistant":{let n=typeof o=="object"&&o!==null&&"content"in o?o.content:void 0,r=typeof o=="object"&&o!==null&&"functionCalls"in o?o.functionCalls:void 0,s=typeof o=="object"&&o!==null&&"thoughtBlocks"in o?o.thoughtBlocks:void 0,i=typeof n=="string"&&n.trim()!=="",a=Array.isArray(r)&&r.length>0,l=Array.isArray(s)&&s.length>0;if(!i&&!a&&!l&&Rt("Assistant message must include non-empty content, at least one function call, or thought blocks",{fieldPath:"content | functionCalls | thoughtBlocks",value:{content:n,functionCalls:r,thoughtBlocks:s},item:o}),n!==void 0&&typeof n!="string"&&Rt("Assistant message content must be a string",{fieldPath:"content",value:n,item:o}),r!==void 0&&!Array.isArray(r)&&Rt("Assistant message functionCalls must be an array when provided",{fieldPath:"functionCalls",value:r,item:o}),Array.isArray(r))for(let c=0;c<r.length;c++){let u=r[c];if((!u||typeof u!="object")&&Rt("functionCalls entry must be an object",{fieldPath:`functionCalls[${c}]`,value:u,item:o}),(!("id"in u)||typeof u.id!="string"||u.id.trim()==="")&&Rt("functionCalls entry must include a non-empty string id",{fieldPath:`functionCalls[${c}].id`,value:u.id,item:o}),(!("type"in u)||u.type!=="function")&&Rt("functionCalls entry must have type 'function'",{fieldPath:`functionCalls[${c}].type`,value:u.type,item:o}),!("function"in u)||!u.function)Rt("functionCalls entry must include a function object",{fieldPath:`functionCalls[${c}].function`,value:u.function,item:o});else{let p=u.function;(!("name"in p)||typeof p.name!="string"||p.name.trim()==="")&&Rt("functionCalls entry must include a non-empty function name",{fieldPath:`functionCalls[${c}].function.name`,value:p?.name,item:o}),p.params!==void 0&&typeof p.params!="string"&&typeof p.params!="object"&&Rt("functionCalls entry params must be a string or object when provided",{fieldPath:`functionCalls[${c}].function.params`,value:p.params,item:o})}}if(o.name!==void 0){let c=o.name;(typeof c!="string"||c.trim()==="")&&Rt("Assistant message name must be a non-empty string when provided",{fieldPath:"name",value:c,item:o})}break}case"function":{let n=typeof o=="object"&&o!==null&&"functionId"in o&&typeof o.functionId=="string"?o.functionId:void 0,r=typeof o=="object"&&o!==null&&"result"in o?o.result:void 0;if(!n||n.trim()==="")throw new Error(`Function message must have a non-empty functionId, received: ${e(n)}`);if(r==null)throw new Error(`Function message must have a result, received: ${e(r)}`);if(typeof r!="string")throw new Error(`Function message result must be a string, received: ${e(r)}`);o.isError!==void 0&&typeof o.isError!="boolean"&&Rt("Function message isError must be a boolean when provided",{fieldPath:"isError",value:o.isError,item:o});break}default:throw new Error(`Unsupported message role: ${e(t)}`)}}function fo(o){let e=n=>JSON.stringify(n,null,2),t=Array.isArray(o)?o:[o];if(t.length===0)throw new Error(`Chat response results cannot be empty, received: ${e(t)}`);for(let n=0;n<t.length;n++){let r=t[n];if(!r)throw new Error(`Chat response result at index ${n} cannot be null or undefined, received: ${e(r)}`);if(typeof r.index!="number")throw new Error(`Chat response result at index ${n} must have a numeric index, received: ${e(r.index)}`);if(r.index<0)throw new Error(`Chat response result at index ${n} must have a non-negative index, received: ${e(r.index)}`);if(!r.content&&!r.thought&&(!r.thoughtBlocks||r.thoughtBlocks.length===0)&&!r.functionCalls&&!r.finishReason)throw new Error(`Chat response result at index ${n} must have at least one of: content, thought, thoughtBlocks, functionCalls, or finishReason, received: ${e({content:r.content,thought:r.thought,thoughtBlocks:r.thoughtBlocks,functionCalls:r.functionCalls,finishReason:r.finishReason})}`);if(r.content!==void 0&&typeof r.content!="string")throw new Error(`Chat response result content at index ${n} must be a string, received: ${e(r.content)}`);if(r.thought!==void 0&&typeof r.thought!="string")throw new Error(`Chat response result thought at index ${n} must be a string, received: ${e(r.thought)}`);if(r.thoughtBlocks!==void 0){if(!Array.isArray(r.thoughtBlocks))throw new Error(`Chat response result thoughtBlocks at index ${n} must be an array, received: ${e(r.thoughtBlocks)}`);for(let s=0;s<r.thoughtBlocks.length;s++){let i=r.thoughtBlocks[s];if(typeof i!="object"||i===null)throw new Error(`Chat response result thoughtBlocks[${s}] at index ${n} must be an object, received: ${e(i)}`);if(typeof i.data!="string")throw new Error(`Chat response result thoughtBlocks[${s}].data at index ${n} must be a string, received: ${e(i.data)}`);if(typeof i.encrypted!="boolean")throw new Error(`Chat response result thoughtBlocks[${s}].encrypted at index ${n} must be a boolean, received: ${e(i.encrypted)}`);if(i.signature!==void 0&&typeof i.signature!="string")throw new Error(`Chat response result thoughtBlocks[${s}].signature at index ${n} must be a string when provided, received: ${e(i.signature)}`)}}if(r.name!==void 0){if(typeof r.name!="string")throw new Error(`Chat response result name at index ${n} must be a string, received: ${e(r.name)}`);if(r.name.trim()==="")throw new Error(`Chat response result name at index ${n} cannot be empty or whitespace-only, received: ${e(r.name)}`)}if(r.annotations!==void 0){if(!Array.isArray(r.annotations))throw new Error(`Chat response result annotations at index ${n} must be an array, received: ${e(r.annotations)}`);for(let s=0;s<r.annotations.length;s++){let i=r.annotations[s];if(!i||typeof i!="object")throw new Error(`Chat response result annotation at index ${n}[${s}] must be an object, received: ${e(i)}`);if(i.type!=="url_citation")throw new Error(`Chat response result annotation at index ${n}[${s}] must have type 'url_citation', received: ${e(i.type)}`);if(!i.url_citation||typeof i.url_citation!="object")throw new Error(`Chat response result annotation at index ${n}[${s}] must have a valid url_citation object, received: ${e(i.url_citation)}`);if(typeof i.url_citation.url!="string")throw new Error(`Chat response result annotation at index ${n}[${s}] url_citation.url must be a string, received: ${e(i.url_citation.url)}`)}}if(r.id!==void 0){if(typeof r.id!="string")throw new Error(`Chat response result id at index ${n} must be a string, received: ${e(r.id)}`);if(r.id.trim()==="")throw new Error(`Chat response result id at index ${n} cannot be empty or whitespace-only, received: ${e(r.id)}`)}if(r.functionCalls!==void 0){if(!Array.isArray(r.functionCalls))throw new Error(`Chat response result functionCalls at index ${n} must be an array, received: ${e(r.functionCalls)}`);for(let s=0;s<r.functionCalls.length;s++){let i=r.functionCalls[s];if(!i)throw new Error(`Function call at index ${s} in result ${n} cannot be null or undefined, received: ${e(i)}`);if(!i.id||typeof i.id!="string"||i.id.trim()==="")throw new Error(`Function call at index ${s} in result ${n} must have a non-empty string id, received: ${e(i.id)}`);if(i.type!=="function")throw new Error(`Function call at index ${s} in result ${n} must have type 'function', received: ${e(i.type)}`);if(!i.function)throw new Error(`Function call at index ${s} in result ${n} must have a function object, received: ${e(i.function)}`);if(!i.function.name||typeof i.function.name!="string"||i.function.name.trim()==="")throw new Error(`Function call at index ${s} in result ${n} must have a non-empty function name, received: ${e(i.function.name)}`);if(i.function.params!==void 0&&typeof i.function.params!="string"&&typeof i.function.params!="object")throw new Error(`Function call params at index ${s} in result ${n} must be a string or object, received: ${e(i.function.params)}`)}}if(r.finishReason!==void 0){let s=["stop","length","function_call","content_filter","error"];if(!s.includes(r.finishReason))throw new Error(`Chat response result finishReason at index ${n} must be one of: ${s.join(", ")}, received: ${e(r.finishReason)}`)}}}var ii=new Map;function Up(o){return`${o.providerName}:${o.contentHash}`}function Gp(o,e){e.type==="text"?o.update(`text:${e.text}`):e.type==="image"?o.update(`image:${e.mimeType}:${e.image.slice(0,100)}`):e.type==="audio"?o.update(`audio:${e.format}:${e.data.slice(0,100)}`):e.type==="file"&&("fileUri"in e?o.update(`file:${e.mimeType}:${e.fileUri}`):o.update(`file:${e.mimeType}:${e.data.slice(0,100)}`))}function Bp(o){let e=pt("sha256"),t=-1;for(let n=o.length-1;n>=0;n--){let r=o[n];if("cache"in r&&r.cache){t=n;break}}for(let n=0;n<o.length;n++){let r=o[n];if(r.role==="system"){e.update(`system:${r.content}`);continue}if(t>=0&&n<=t)if(r.role==="user"){if(typeof r.content=="string")e.update(`user:${r.content}`);else if(Array.isArray(r.content))for(let s of r.content)Gp(e,s)}else r.role==="assistant"&&r.content&&e.update(`assistant:${r.content}`)}return e.digest("hex")}var we=()=>structuredClone({temperature:0}),He=()=>structuredClone({temperature:.4,frequencyPenalty:.2}),Be=class{constructor(e,{name:t,apiURL:n,headers:r,modelInfo:s,defaults:i,options:a={},supportFor:l,models:c}){this.aiImpl=e;this.name=t,this.apiURL=n||"",this.headers=r,this.supportFor=l,this.tracer=a.tracer??de.tracer,this.meter=a.meter??de.meter,this.modelInfo=s,this.models=c,this.id=Ze();let u=this.getModel(i.model)??i.model,p=this.getEmbedModel(i.embedModel)??i.embedModel;if(this.defaults={model:u,embedModel:p},!i.model||typeof i.model!="string"||i.model==="")throw new Error("No model defined");this.setOptions(a),c&&jp(c)}#e=!1;#t=!1;rt;fetch;tracer;meter;timeout;excludeContentFromTrace;models;abortSignal;logger=de.logger??Va;corsProxy;retry;customLabels;modelInfo;modelUsage;embedModelUsage;defaults;lastUsedModelConfig;lastUsedChatModel;lastUsedEmbedModel;apiURL;name;id;headers;supportFor;metrics={latency:{chat:{mean:0,p95:0,p99:0,samples:[]},embed:{mean:0,p95:0,p99:0,samples:[]}},errors:{chat:{count:0,rate:0,total:0},embed:{count:0,rate:0,total:0}}};getMetricsInstruments(){return il(this.meter)}setName(e){this.name=e}getId(){return this.id}setAPIURL(e){this.apiURL=e}setHeaders(e){this.headers=e}get debug(){return this.#e}setOptions(e){this.#e=e.debug??de.debug??!1,this.#t=e.verbose??!1,this.rt=e.rateLimiter,this.fetch=e.fetch,this.timeout=e.timeout,this.tracer=e.tracer??de.tracer,this.meter=e.meter??de.meter,this.excludeContentFromTrace=e.excludeContentFromTrace,this.abortSignal=e.abortSignal,this.logger=e.logger??de.logger??this.logger,this.corsProxy=e.corsProxy,this.retry=e.retry,this.customLabels=e.customLabels}getOptions(){return{debug:this.#e,verbose:this.#t,rateLimiter:this.rt,fetch:this.fetch,tracer:this.tracer,meter:this.meter,timeout:this.timeout,excludeContentFromTrace:this.excludeContentFromTrace,abortSignal:this.abortSignal,logger:this.logger,corsProxy:this.corsProxy,retry:this.retry,customLabels:this.customLabels}}getLogger(){return this.logger}getMergedCustomLabels(e){return Qt(de.customLabels,this.customLabels,e)}getModelList(){let e=[];for(let t of this.models??[])t.isInternal||("model"in t&&t.model&&e.push({key:t.key,description:t.description,model:t.model}),"embedModel"in t&&t.embedModel&&e.push({key:t.key,description:t.description,embedModel:t.embedModel}));return e}getName(){return this.name}getFeatures(e){return typeof this.supportFor=="function"?this.supportFor(e??this.defaults.model):this.supportFor}getLastUsedChatModel(){return this.lastUsedChatModel}getLastUsedEmbedModel(){return this.lastUsedEmbedModel}getLastUsedModelConfig(){return this.lastUsedModelConfig}calculatePercentile(e,t){if(e.length===0)return 0;let n=[...e].sort((s,i)=>s-i),r=Math.ceil(t/100*n.length)-1;return n[r]??0}updateLatencyMetrics(e,t,n){let r=this.metrics.latency[e];r.samples.push(t),r.samples.length>1e3&&r.samples.shift(),r.mean=r.samples.reduce((i,a)=>i+a,0)/r.samples.length,r.p95=this.calculatePercentile(r.samples,95),r.p99=this.calculatePercentile(r.samples,99);let s=this.getMetricsInstruments();if(s){let i=e==="chat"?this.lastUsedChatModel:this.lastUsedEmbedModel,a=this.getMergedCustomLabels(n);al(s,e,t,this.name,i,a),ll(s,e,r.mean,r.p95,r.p99,this.name,i,a)}}updateErrorMetrics(e,t,n){let r=this.metrics.errors[e];r.total++,t&&r.count++,r.rate=r.count/r.total;let s=this.getMetricsInstruments();if(s){let i=e==="chat"?this.lastUsedChatModel:this.lastUsedEmbedModel,a=this.getMergedCustomLabels(n);pl(s,e,this.name,i,a),t&&cl(s,e,this.name,i,a),ul(s,e,r.rate,this.name,i,a)}}recordTokenUsage(e,t){let n=this.getMetricsInstruments();if(n&&e?.tokens){let{promptTokens:r,completionTokens:s,totalTokens:i,thoughtsTokens:a,cacheReadTokens:l,cacheCreationTokens:c}=e.tokens,u=this.getMergedCustomLabels(t);r&&dr(n,"input",r,this.name,e.model,u),s&&dr(n,"output",s,this.name,e.model,u),i&&dr(n,"total",i,this.name,e.model,u),a&&dr(n,"thoughts",a,this.name,e.model,u),l&&si(n,"read",l,this.name,e.model,u),c&&si(n,"write",c,this.name,e.model,u)}}calculateRequestSize(e){try{return new TextEncoder().encode(JSON.stringify(e)).length}catch{return 0}}calculateResponseSize(e){try{return new TextEncoder().encode(JSON.stringify(e)).length}catch{return 0}}detectMultimodalContent(e){let t=!1,n=!1;if(e.chatPrompt&&Array.isArray(e.chatPrompt)){for(let r of e.chatPrompt)if(r.role==="user"&&Array.isArray(r.content))for(let s of r.content)s.type==="image"?t=!0:s.type==="audio"&&(n=!0)}return{hasImages:t,hasAudio:n}}calculatePromptLength(e){let t=0;if(e.chatPrompt&&Array.isArray(e.chatPrompt))for(let n of e.chatPrompt)if(n.role==="system"||n.role==="assistant")n.content&&(t+=n.content.length);else if(n.role==="user"){if(typeof n.content=="string")t+=n.content.length;else if(Array.isArray(n.content))for(let r of n.content)r.type==="text"&&(t+=r.text.length)}else n.role==="function"&&n.result&&(t+=n.result.length);return t}calculateContextWindowUsage(e,t){if(!t?.tokens?.promptTokens)return 0;let n=this.modelInfo.find(r=>r.name===e);return n?.contextWindow?t.tokens.promptTokens/n.contextWindow:0}estimateCost(e,t){if(!t?.tokens)return 0;let n=this.modelInfo.find(l=>l.name===e);if(!n||!n.promptTokenCostPer1M&&!n.completionTokenCostPer1M)return 0;let{promptTokens:r=0,completionTokens:s=0}=t.tokens,i=n.promptTokenCostPer1M||0,a=n.completionTokenCostPer1M||0;return r*i/1e6+s*a/1e6}estimateCostByName(e,t){if(!t?.tokens)return 0;let n=this.modelInfo.find(l=>l.name===e);if(!n||!n.promptTokenCostPer1M&&!n.completionTokenCostPer1M)return 0;let{promptTokens:r=0,completionTokens:s=0}=t.tokens,i=n.promptTokenCostPer1M||0,a=n.completionTokenCostPer1M||0;return r*i/1e6+s*a/1e6}recordFunctionCallMetrics(e,t,n){let r=this.getMetricsInstruments();if(!(!r||!e))for(let s of e)s&&typeof s=="object"&&"function"in s&&s.function&&typeof s.function=="object"&&"name"in s.function&&ml(r,s.function.name,void 0,this.name,t,this.getMergedCustomLabels(n))}recordTimeoutMetric(e,t){let n=this.getMetricsInstruments();if(n){let r=e==="chat"?this.lastUsedChatModel:this.lastUsedEmbedModel;xl(n,e,this.name,r,this.getMergedCustomLabels(t))}}recordAbortMetric(e,t){let n=this.getMetricsInstruments();if(n){let r=e==="chat"?this.lastUsedChatModel:this.lastUsedEmbedModel;Al(n,e,this.name,r,this.getMergedCustomLabels(t))}}recordChatMetrics(e,t,n){let r=this.getMetricsInstruments();if(!r)return;let s=this.lastUsedChatModel,i=this.lastUsedModelConfig,a=this.getMergedCustomLabels(t?.customLabels),l=i?.stream??!1;dl(r,"chat",l,this.name,s,a);let{hasImages:c,hasAudio:u}=this.detectMultimodalContent(e);bl(r,c,u,this.name,s,a);let p=this.calculatePromptLength(e);fl(r,p,this.name,s,a),gl(r,i?.temperature,i?.maxTokens,this.name,s,a),t?.thinkingTokenBudget&&this.modelUsage?.tokens?.thoughtsTokens&&yl(r,this.modelUsage.tokens.thoughtsTokens,this.name,s,a);let d=this.calculateRequestSize(e);if(ni(r,"chat",d,this.name,s,a),n&&!l){let m=n,g=this.calculateResponseSize(m);if(ri(r,"chat",g,this.name,s,a),m.results)for(let A of m.results)A.functionCalls&&this.recordFunctionCallMetrics(A.functionCalls,this.lastUsedChatModel,a);let f=this.calculateContextWindowUsage(this.lastUsedChatModel,m.modelUsage);f>0&&hl(r,f,this.name,s,a);let x=this.estimateCost(this.lastUsedChatModel,m.modelUsage);x>0&&oi(r,"chat",x,this.name,s,a)}}recordEmbedMetrics(e,t,n){let r=this.getMetricsInstruments();if(!r)return;let s=this.lastUsedEmbedModel,i=this.getMergedCustomLabels(n?.customLabels),a=this.calculateRequestSize(e);ni(r,"embed",a,this.name,s,i);let l=this.calculateResponseSize(t);ri(r,"embed",l,this.name,s,i);let c=this.estimateCostByName(s,t.modelUsage);c>0&&oi(r,"embed",c,this.name,s,i)}getMetrics(){return structuredClone(this.metrics)}async chat(e,t){let n=performance.now(),r=!1,s,i=this.getModelByKey(e.model),a=i?i.thinkingTokenBudget:void 0,l={...i?{thinkingTokenBudget:a,showThoughts:i.showThoughts,stream:i.stream,debug:i.debug,useExpensiveModel:i.useExpensiveModel}:void 0,...Object.fromEntries(Object.entries(t??{}).filter(([,c])=>c!==void 0))};try{return s=await this._chat1(e,l),s}catch(c){throw r=!0,c instanceof Error&&(c.message.includes("timeout")||c.name==="TimeoutError"?this.recordTimeoutMetric("chat",l?.customLabels):(c.message.includes("abort")||c.name==="AbortError")&&this.recordAbortMetric("chat",l?.customLabels)),c}finally{let c=performance.now()-n;this.updateLatencyMetrics("chat",c,l?.customLabels),this.updateErrorMetrics("chat",r,l?.customLabels),r||this.recordChatMetrics(e,l,s)}}async _chat1(e,t){let n=this.getModel(e.model)??e.model??this.defaults.model;if(Array.isArray(e.chatPrompt))for(let c of e.chatPrompt)cn(c);let r=this.getModelByKey(e.model),s={...this.aiImpl.getModelConfig(),...r?r.modelConfig:void 0,...e.modelConfig},i=this.modelInfo.find(c=>c.name===n);if(i?.notSupported?.temperature&&"temperature"in s&&delete s.temperature,i?.notSupported?.topP&&"topP"in s&&delete s.topP,t?.thinkingTokenBudget&&!this.getFeatures(n).hasThinkingBudget)throw new Error(`Model ${n} does not support thinkingTokenBudget.`);if(t?.showThoughts&&!this.getFeatures(n).hasShowThoughts)throw new Error(`Model ${n} does not support showThoughts.`);if(this.modelInfo.find(c=>c.name===n)?.isExpensive&&t?.useExpensiveModel!=="yes")throw new Error(`Model ${n} is marked as expensive and requires explicit confirmation. Set useExpensiveModel: "yes" to proceed.`);return s.stream=(t?.stream!==void 0?t.stream:s.stream)??!0,this.getFeatures(n).streaming||(s.stream=!1),this.tracer?await this.tracer.startActiveSpan("AI Chat Request",{kind:un.SpanKind.SERVER,attributes:{[he.LLM_SYSTEM]:this.name,[he.LLM_OPERATION_NAME]:"chat",[he.LLM_REQUEST_MODEL]:n,[he.LLM_REQUEST_MAX_TOKENS]:s.maxTokens??"Not set",[he.LLM_REQUEST_TEMPERATURE]:s.temperature,[he.LLM_REQUEST_TOP_P]:s.topP??"Not set",[he.LLM_REQUEST_TOP_K]:s.topK??"Not set",[he.LLM_REQUEST_FREQUENCY_PENALTY]:s.frequencyPenalty??"Not set",[he.LLM_REQUEST_PRESENCE_PENALTY]:s.presencePenalty??"Not set",[he.LLM_REQUEST_STOP_SEQUENCES]:s.stopSequences?.join(", ")??"Not set",[he.LLM_REQUEST_LLM_IS_STREAMING]:s.stream??"Not set"}},t?.traceContext??un.context.active(),async c=>await this._chat2(n,s,e,t,c)):await this._chat2(n,s,e,t)}cleanupFunctionSchema(e){let t={...e};if(t.parameters){let n={...t.parameters};Array.isArray(n.required)&&n.required.length===0&&delete n.required,n.properties&&Object.keys(n.properties).length===0&&delete n.properties,Object.keys(n).length===0||Object.keys(n).length===1&&n.type==="object"?delete t.parameters:t.parameters=n}return t}async _chat2(e,t,n,r,s){if(!this.aiImpl.createChatReq)throw new Error("createChatReq not implemented");let i=r?.debug??this.#e,a=r?.verbose??this.#t,l;n.functions&&n.functions.length>0&&(l=n.functions.map(b=>this.cleanupFunctionSchema(b)));let c={...n,model:e,functions:l,modelConfig:t};this.lastUsedChatModel=e,this.lastUsedModelConfig=t,i&&Qa(c.chatPrompt,r?.stepIndex??0,r?.logger??this.logger,r?.debugHideSystemPrompt);let u=this.getFeatures(e).functions,p=r?.functionCallMode??"auto",m=p==="prompt"||p==="auto"&&!u?{...c,chatPrompt:c.chatPrompt.map(b=>{if(b.role==="assistant"){let{content:T,name:C,cache:v}=b;return{role:"assistant",content:T,name:C,cache:v}}return b.role==="function"?{role:"user",content:b.result}:b}),functions:[]}:c,g=await this.handleContextCaching(e,m,r,s),f=async()=>{if(g?.preparedRequest){let{apiConfig:v,request:k}=g.preparedRequest;return s?.isRecording()&&Cl(n,s,this.excludeContentFromTrace),await tt({name:v.name,url:this.apiURL,localCall:v.localCall,headers:await this.buildHeaders(v.headers),stream:t.stream,timeout:this.timeout,verbose:a,fetch:this.fetch,span:s,abortSignal:r?.abortSignal??this.abortSignal,corsProxy:this.corsProxy,retry:r?.retry??this.retry},k)}let[b,T]=await this.aiImpl.createChatReq(m,r);return s?.isRecording()&&Cl(n,s,this.excludeContentFromTrace),await tt({name:b.name,url:this.apiURL,localCall:b.localCall,headers:await this.buildHeaders(b.headers),stream:t.stream,timeout:this.timeout,verbose:a,fetch:this.fetch,span:s,abortSignal:r?.abortSignal??this.abortSignal,corsProxy:this.corsProxy,retry:r?.retry??this.retry},T)},x=r?.rateLimiter??this.rt,A=x?await x(f,{modelUsage:this.modelUsage}):await f();if(t.stream){if(!this.aiImpl.createChatStreamResp)throw new Error("createChatStreamResp not implemented");let b=this.aiImpl.createChatStreamResp.bind(this),T=R=>E=>{let S=b(E,R);if(S.sessionId=r?.sessionId,!S.modelUsage){let _=this.aiImpl.getTokenUsage();_&&(S.modelUsage={ai:this.name,model:e,tokens:_})}return this.modelUsage=S.modelUsage,this.recordTokenUsage(S.modelUsage,r?.customLabels),s?.isRecording()&&Il(S,s,this.excludeContentFromTrace),S},C=async R=>{s?.isRecording()&&s.end(),i&&Xa(R,r?.logger??this.logger)};if(typeof window<"u"){let R=A,E={},S=[],_=r?.abortSignal??this.abortSignal;return new ReadableStream({start:L=>{let P=R.getReader(),F=()=>{try{P.cancel().catch(()=>{})}catch{}try{this.recordAbortMetric("chat",r?.customLabels)}catch{}try{s?.isRecording()&&s.end()}catch{}try{L.error(new DOMException("Aborted","AbortError"))}catch{L.error(new Error("Aborted"))}};if(_){if(_.aborted){F();return}_.addEventListener("abort",F,{once:!0})}async function N(){try{for(;;){let{done:U,value:G}=await P.read();if(U){C&&await C(S),L.close();break}let B=T(E)(G);B&&(S.push(B),L.enqueue(B))}}catch(U){if(L.error(U),s?.isRecording())try{s.end()}catch{}}finally{if(P.releaseLock(),_)try{_.removeEventListener("abort",F)}catch{}}}N()}})}return A.pipeThrough(new uo(T({}),C))}if(!this.aiImpl.createChatResp)throw new Error("createChatResp not implemented");let h=this.aiImpl.createChatResp(A);if(h.sessionId=r?.sessionId,!h.modelUsage){let b=this.aiImpl.getTokenUsage();b&&(h.modelUsage={ai:this.name,model:e,tokens:b})}return h.modelUsage&&(this.modelUsage=h.modelUsage,this.recordTokenUsage(h.modelUsage,r?.customLabels)),s?.isRecording()&&(Il(h,s,this.excludeContentFromTrace),s.end()),i&&Ya(h,r?.logger??this.logger),h}async embed(e,t){let n=performance.now(),r=!1,s,i=this.getModelByKey(e.embedModel),a={...i?{thinkingTokenBudget:i.thinkingTokenBudget,showThoughts:i.showThoughts,stream:i.stream,debug:i.debug,useExpensiveModel:i.useExpensiveModel}:void 0,...t};try{return s=await this._embed1(e,a),s}catch(l){throw r=!0,l instanceof Error&&(l.message.includes("timeout")||l.name==="TimeoutError"?this.recordTimeoutMetric("embed",a?.customLabels):(l.message.includes("abort")||l.name==="AbortError")&&this.recordAbortMetric("embed",a?.customLabels)),l}finally{let l=performance.now()-n;this.updateLatencyMetrics("embed",l,a?.customLabels),this.updateErrorMetrics("embed",r,a?.customLabels),!r&&s&&this.recordEmbedMetrics(e,s,a)}}async _embed1(e,t){let n=this.getEmbedModel(e.embedModel)??e.embedModel??this.defaults.embedModel;if(!n)throw new Error("No embed model defined");return this.tracer?await this.tracer.startActiveSpan("AI Embed Request",{kind:un.SpanKind.SERVER,attributes:{[he.LLM_SYSTEM]:this.name,[he.LLM_OPERATION_NAME]:"embeddings",[he.LLM_REQUEST_MODEL]:n}},t?.traceContext??un.context.active(),async r=>await this._embed2(n,e,t,r)):await this._embed2(n,e,t)}async _embed2(e,t,n,r){if(!this.aiImpl.createEmbedReq)throw new Error("createEmbedReq not implemented");if(!this.aiImpl.createEmbedResp)throw new Error("createEmbedResp not implemented");let s=this.aiImpl.createEmbedReq.bind(this.aiImpl),i=n?.debug??this.#e,a=n?.verbose??this.#t,l={...t,embedModel:e};this.lastUsedEmbedModel=e,i&&rl(l.texts??[],e,n?.logger??this.logger);let c=async()=>{let[m,g]=await s(l);return await tt({name:m.name,url:this.apiURL,localCall:m.localCall,headers:await this.buildHeaders(m.headers),verbose:a,fetch:this.fetch,timeout:this.timeout,span:r,abortSignal:n?.abortSignal??this.abortSignal,corsProxy:this.corsProxy,retry:n?.retry??this.retry},g)},u=n?.rateLimiter??this.rt,p=u?await u(c,{modelUsage:this.embedModelUsage}):await c(),d=this.aiImpl.createEmbedResp?.(p);if(d.sessionId=n?.sessionId,!d.modelUsage){let m=this.aiImpl.getTokenUsage();m&&(d.modelUsage={ai:this.name,model:e,tokens:m})}return this.embedModelUsage=d.modelUsage,this.recordTokenUsage(d.modelUsage,n?.customLabels),r?.isRecording()&&d.modelUsage?.tokens&&r.addEvent(wt.GEN_AI_USAGE,{[he.LLM_USAGE_INPUT_TOKENS]:d.modelUsage.tokens.promptTokens,[he.LLM_USAGE_OUTPUT_TOKENS]:d.modelUsage.tokens.completionTokens??0,[he.LLM_USAGE_TOTAL_TOKENS]:d.modelUsage.tokens.totalTokens}),i&&ol(d.embeddings,n?.logger??this.logger),r?.end(),d}async buildHeaders(e={}){return{...e,...await this.headers()}}getModelByKey(e){return e?this.models?.find(n=>n.key===e):void 0}getModel(e){let t=this.getModelByKey(e);return t&&"model"in t?t.model:void 0}getEmbedModel(e){let t=this.getModelByKey(e);return t&&"embedModel"in t?t.embedModel:void 0}async handleContextCaching(e,t,n,r){let s=n?.contextCache;if(!s)return null;let i=this.aiImpl.supportsContextCache?.(e)??!1,a=this.aiImpl.supportsImplicitCaching?.(e)??!1;if(!i&&!a)throw new Error(`Context caching is not supported by this provider/model (${this.getName()}/${e}). Remove the contextCache option or use a provider that supports caching.`);if(!i)return null;let l=s.ttlSeconds??3600,c=s.refreshWindowSeconds??300,u=s.minTokens??2048;if(s.name)return this.useCacheByName(e,t,s.name,n,r);let p=Bp(t.chatPrompt);if(!p||p===pt("sha256").digest("hex"))return null;let d={providerName:this.getName(),contentHash:p},m=Up(d),g=Date.now(),f=s.registry,x=f?await f.get(m):ii.get(m);if(x&&x.expiresAt>g){if(x.expiresAt-g<c*1e3&&this.aiImpl.buildCacheUpdateTTLOp){await this.executeCacheOperation(this.aiImpl.buildCacheUpdateTTLOp(x.cacheName,l),n,r);let T={cacheName:x.cacheName,expiresAt:g+l*1e3,tokenCount:x.tokenCount};f?await f.set(m,T):ii.set(m,{...T,contentHash:p,lastTouchedAt:g})}return this.useCacheByName(e,t,x.cacheName,n,r)}if(this.estimateCacheableTokens(t.chatPrompt)<u)return null;let h=this.aiImpl.buildCacheCreateOp?.(t,n);if(h){let b=await this.executeCacheOperation(h,n,r);if(b){let T={cacheName:b.name,expiresAt:new Date(b.expiresAt).getTime(),tokenCount:b.tokenCount};return f?await f.set(m,T):ii.set(m,{...T,contentHash:p,lastTouchedAt:g}),this.useCacheByName(e,t,b.name,n,r)}}return null}async useCacheByName(e,t,n,r,s){if(this.aiImpl.prepareCachedChatReq){let i=await this.aiImpl.prepareCachedChatReq(t,r??{},n);return{preparedRequest:{apiConfig:i.apiConfig,request:i.request}}}return null}async executeCacheOperation(e,t,n){let r=t?.verbose??this.#t;try{n?.addEvent("context_cache.operation",{type:e.type,endpoint:e.apiConfig.name});let s=await tt({name:e.apiConfig.name,url:this.apiURL,localCall:e.apiConfig.localCall,headers:await this.buildHeaders(e.apiConfig.headers),stream:!1,timeout:this.timeout,verbose:r,fetch:this.fetch,span:n,abortSignal:t?.abortSignal??this.abortSignal,corsProxy:this.corsProxy,retry:t?.retry??this.retry},e.request);return e.parseResponse(s)}catch(s){n?.addEvent("context_cache.error",{type:e.type,error:s instanceof Error?s.message:String(s)});return}}estimateCacheableTokens(e){let t=0;for(let n of e){if(n.role==="system"){t+=n.content.length;continue}if("cache"in n&&n.cache)if(n.role==="user"){if(typeof n.content=="string")t+=n.content.length;else if(Array.isArray(n.content))for(let r of n.content)"cache"in r&&r.cache&&(r.type==="text"?t+=r.text.length:r.type==="image"?t+=1e3:r.type==="audio"?t+=2e3:r.type==="file"&&(t+=500))}else n.role==="assistant"&&n.content&&(t+=n.content.length)}return Math.ceil(t/4)}};function Cl(o,e,t){let n=[];if(o.chatPrompt&&Array.isArray(o.chatPrompt)&&o.chatPrompt.length>0)for(let s of o.chatPrompt)switch(s.role){case"system":if(s.content){let i={};t||(i.content=s.content),e.addEvent(wt.GEN_AI_SYSTEM_MESSAGE,i)}break;case"user":if(typeof s.content=="string")n.push(s.content);else if(Array.isArray(s.content))for(let i of s.content)i.type==="text"&&n.push(i.text);break;case"assistant":{let i=s.functionCalls?.map(a=>({id:a.id,type:a.type,function:a.function.name,arguments:a.function.params}));if(i&&i.length>0){let a={function_calls:JSON.stringify(i,null,2)};!t&&s.content&&(a.content=s.content),e.addEvent(wt.GEN_AI_ASSISTANT_MESSAGE,a)}else if(s.content){let a={};t||(a.content=s.content),e.addEvent(wt.GEN_AI_ASSISTANT_MESSAGE,a)}break}case"function":{let i={id:s.functionId};t||(i.content=s.result),e.addEvent(wt.GEN_AI_TOOL_MESSAGE,i);break}}let r={};t||(r.content=n.join(`
169
- `)),e.addEvent(wt.GEN_AI_USER_MESSAGE,r)}function Il(o,e,t){if(o.modelUsage?.tokens){let n=o.modelUsage.tokens.thoughtsTokens?{[he.LLM_USAGE_THOUGHTS_TOKENS]:o.modelUsage.tokens.thoughtsTokens}:{};e.addEvent(wt.GEN_AI_USAGE,{[he.LLM_USAGE_INPUT_TOKENS]:o.modelUsage.tokens.promptTokens,[he.LLM_USAGE_OUTPUT_TOKENS]:o.modelUsage.tokens.completionTokens??0,[he.LLM_USAGE_TOTAL_TOKENS]:o.modelUsage.tokens.totalTokens,...n})}if(o.results)for(let n=0;n<o.results.length;n++){let r=o.results[n];if(!r||!r.content&&!r.thought&&!r.functionCalls?.length&&!r.finishReason)continue;let s=r.functionCalls?.map(a=>({id:a.id,type:a.type,function:a.function.name,arguments:a.function.params})),i={};s&&s.length>0?(t||(i.content=r.content),i.tool_calls=s):t||(i.content=r.content??""),e.addEvent(wt.GEN_AI_CHOICE,{finish_reason:r.finishReason,index:n,message:JSON.stringify(i,null,2)})}}function wl(o){let e=0;for(let t of o){if(!t||typeof t!="object")throw new Error(`AxMessage array validation failed: Item at index ${e} is not a valid message object`);if(t.role!=="user"&&t.role!=="assistant")throw new Error(`AxMessage array validation failed: Item at index ${e} has invalid role: ${t.role}`);e++}}function jp(o){let e=new Set;for(let t of o){if(e.has(t.key))throw new Error(`Duplicate model key detected: "${t.key}". Each model key must be unique.`);e.add(t.key)}}var mr=(x=>(x.Claude46Opus="claude-opus-4-6",x.Claude46Sonnet="claude-sonnet-4-6",x.Claude45Opus="claude-opus-4-5-20251101",x.Claude41Opus="claude-opus-4-1-20250805",x.Claude4Opus="claude-opus-4-20250514",x.Claude4Sonnet="claude-sonnet-4-20250514",x.Claude45Sonnet="claude-sonnet-4-5-20250929",x.Claude45Haiku="claude-haiku-4-5",x.Claude37Sonnet="claude-3-7-sonnet-latest",x.Claude35Sonnet="claude-3-5-sonnet-latest",x.Claude35Haiku="claude-3-5-haiku-latest",x.Claude3Opus="claude-3-opus-latest",x.Claude3Sonnet="claude-3-sonnet-20240229",x.Claude3Haiku="claude-3-haiku-20240307",x.Claude21="claude-2.1",x.ClaudeInstant12="claude-instant-1.2",x))(mr||{}),gr=(g=>(g.Claude46Opus="claude-opus-4-6",g.Claude46Sonnet="claude-sonnet-4-6",g.Claude45Opus="claude-opus-4-5@20251101",g.Claude41Opus="claude-opus-4-1@20250805",g.Claude4Opus="claude-opus-4@20250514",g.Claude45Sonnet="claude-sonnet-4-5@20250929",g.Claude4Sonnet="claude-sonnet-4@20250514",g.Claude37Sonnet="claude-3-7-sonnet@20250219",g.Claude35SonnetV2="claude-3-5-sonnet-v2@20241022",g.Claude45Haiku="claude-haiku-4-5@20251001",g.Claude35Haiku="claude-3-5-haiku@20241022",g.Claude35Sonnet="claude-3-5-sonnet@20240620",g.Claude3Opus="claude-3-opus@20240229",g.Claude3Haiku="claude-3-haiku@20240307",g))(gr||{});var fr=[{name:"claude-opus-4-6",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:25,maxTokens:128e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-6",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:25,maxTokens:128e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-6",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-6",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-5-20251101",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:25,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-5@20251101",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:25,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-5-20250929",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:2e5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-5@20250929",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:2e5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-haiku-4-5",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:5,maxTokens:2e5,supported:{thinkingBudget:!0,showThoughts:!0}},{name:"claude-haiku-4-5@20251001",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:5,maxTokens:2e5,supported:{thinkingBudget:!0,showThoughts:!0}},{name:"claude-opus-4-1-20250805",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:32e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-1@20250805",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:32e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-20250514",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:32e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4@20250514",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:32e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-20250514",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4@20250514",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-3-7-sonnet-latest",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-3-7-sonnet@20250219",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-3-5-sonnet-latest",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:8192,supported:{structuredOutputs:!0}},{name:"claude-3-5-sonnet@20240620",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:8192,supported:{structuredOutputs:!0}},{name:"claude-3-5-sonnet-v2@20241022",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:8192,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-3-5-haiku-latest",currency:"usd",promptTokenCostPer1M:.8,completionTokenCostPer1M:4,maxTokens:8192},{name:"claude-3-5-haiku@20241022",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:5,maxTokens:8192},{name:"claude-3-opus-latest",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:4096,supported:{structuredOutputs:!0}},{name:"claude-3-opus@20240229",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:4096,supported:{structuredOutputs:!0}},{name:"claude-3-sonnet-20240229",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:4096,supported:{structuredOutputs:!0}},{name:"claude-3-haiku-20240307",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:1.25,maxTokens:4096},{name:"claude-3-haiku@20240307",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:1.25,maxTokens:4096},{name:"claude-2.1",currency:"usd",promptTokenCostPer1M:8,completionTokenCostPer1M:25,maxTokens:4096},{name:"claude-instant-1.2",currency:"usd",promptTokenCostPer1M:.8,completionTokenCostPer1M:2.24,maxTokens:4096}];var Ut=o=>{if(!o||typeof o!="object")return o;let e={...o};if(e.type==="object"||Array.isArray(e.type)&&e.type.includes("object")){if(!e.properties||Object.keys(e.properties).length===0)return e;e.additionalProperties===void 0&&(e.additionalProperties=!1)}return delete e.optional,e.properties&&typeof e.properties=="object"&&(e.properties=Object.fromEntries(Object.entries(e.properties).map(([n,r])=>[n,Ut(r)]))),e.items&&(e.items=Ut(e.items)),Array.isArray(e.anyOf)&&(e.anyOf=e.anyOf.map(n=>Ut(n))),Array.isArray(e.allOf)&&(e.allOf=e.allOf.map(n=>Ut(n))),Array.isArray(e.oneOf)&&(e.oneOf=e.oneOf.map(n=>Ut(n))),e},li=()=>structuredClone({model:"claude-3-7-sonnet-latest",maxTokens:4e4,thinkingTokenBudgetLevels:{minimal:1024,low:5e3,medium:1e4,high:2e4,highest:32e3},effortLevelMapping:{minimal:"low",low:"low",medium:"medium",high:"high",highest:"max"},...we()}),vl=()=>structuredClone({model:"claude-3-7-sonnet@20250219",maxTokens:4e4,thinkingTokenBudgetLevels:{minimal:1024,low:5e3,medium:1e4,high:2e4,highest:32e3},effortLevelMapping:{minimal:"low",low:"low",medium:"medium",high:"high",highest:"max"},...we()}),ai=class{constructor(e,t){this.config=e;this.isVertex=t}tokensUsed;currentPromptConfig;usedStructuredOutput=!1;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens??4096,temperature:e.temperature,topP:e.topP,topK:e.topK,stream:e.stream,stopSequences:e.stopSequences,endSequences:e.endSequences,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,n:e.n}}createChatReq=async(e,t)=>{this.currentPromptConfig=t;let n=e.model,r=e.modelConfig?.stream??this.config.stream,s;this.isVertex?s={name:r?`/models/${n}:streamRawPredict?alt=sse`:`/models/${n}:rawPredict`}:s={name:"/messages"};let i;if(e.functionCall&&e.functions&&e.functions.length>0)if(typeof e.functionCall=="string")switch(e.functionCall){case"auto":i={tool_choice:{type:"auto"}};break;case"required":i={tool_choice:{type:"any"}};break;case"none":throw new Error("functionCall none not supported")}else if("function"in e.functionCall)i={tool_choice:{type:"tool",name:e.functionCall.function.name}};else throw new Error("Invalid function call type, must be string or object");let a=e.chatPrompt.some(N=>"cache"in N&&N.cache)||e.functions?.some(N=>N.cache),l=e.chatPrompt.filter(N=>N.role==="system"),c=l.map((N,U)=>({type:"text",text:N.content,...N.cache||a&&U===l.length-1?{cache_control:{type:"ephemeral"}}:{}})),u=e.chatPrompt.filter(N=>N.role!=="system"),p=e.functions?.map((N,U,G)=>{let B={type:"object",properties:{dummy:{type:"string",description:"An optional dummy parameter, do not use"}},required:[]},te=N.parameters?Ut(N.parameters):void 0;return te===void 0||te&&typeof te=="object"&&Object.keys(te).length===0?te={...B}:te&&typeof te=="object"&&te.type==="object"&&(!("properties"in te)||!te.properties||Object.keys(te.properties).length===0)&&(te={...te,properties:{dummy:{type:"string",description:"An optional dummy parameter, do not use"}},required:[]}),{name:N.name,description:N.description,input_schema:te,...N.cache||a&&U===G.length-1?{cache_control:{type:"ephemeral"}}:{}}}),m=(this.config.tools??[]).map(N=>N&&typeof N=="object"&&"type"in N?N:{name:N.name,description:N.description,input_schema:N.input_schema?Ut(N.input_schema):void 0,...N.cache_control?{cache_control:N.cache_control}:{}}),g=[...p??[],...m];g.length===0&&(g=void 0);let f=e.modelConfig?.maxTokens??this.config.maxTokens,x=e.modelConfig?.stopSequences??this.config.stopSequences,A=e.modelConfig?.temperature,h=e.modelConfig?.topP,b=e.modelConfig?.topK??this.config.topK,T=e.modelConfig?.n??this.config.n;if(T&&T>1)throw new Error("Anthropic does not support sampling (n > 1)");let C=N=>N.includes("claude-opus-4-6"),v=N=>N.includes("claude-opus-4-5"),k,R,E=n;if(t?.thinkingTokenBudget){let N=this.config.thinkingTokenBudgetLevels,U=this.config.effortLevelMapping;if(t.thinkingTokenBudget==="none")k=void 0,R=void 0;else{let G=t.thinkingTokenBudget;if(C(E))k={type:"adaptive"},R={effort:U?.[G]??"medium"};else if(v(E)){k={type:"enabled",budget_tokens:N?.[G]??1e4};let te=U?.[G]??"medium";te==="max"&&(te="high"),R={effort:te}}else k={type:"enabled",budget_tokens:N?.[G]??1e4}}}let _=zp(u,!!k);_.some(N=>N.role==="assistant"&&Array.isArray(N.content)&&N.content.length>0&&N.content[0]?.type==="tool_use")&&(k=void 0,R=void 0);let P;if(this.usedStructuredOutput=!1,e.responseFormat&&e.responseFormat.type==="json_schema"&&e.responseFormat.schema){let N=e.responseFormat.schema.schema||e.responseFormat.schema;P={type:"json_schema",schema:Ut(N)},this.usedStructuredOutput=!0}let F={...this.isVertex?{anthropic_version:"vertex-2023-10-16"}:{model:n},...f?{max_tokens:f}:{},...x&&x.length>0?{stop_sequences:x}:{},...A!==void 0&&!k?{temperature:A}:{},...h!==void 0&&(!k||h>=.95)?{top_p:h}:{},...b&&!k?{top_k:b}:{},...i,...g?{tools:g}:{},...r?{stream:!0}:{},...c?{system:c}:{},...k?{thinking:k}:{},...R?{output_config:R}:{},...P?{output_format:P}:{},messages:_};return[s,F]};createChatResp=e=>{if(e.type==="error")throw new Le(e.error.message,void 0,void 0);let t=Rl(e.stop_reason),n=this.currentPromptConfig?.thinkingTokenBudget!=="none"&&this.currentPromptConfig?.showThoughts!==!1,r="",s=[],i=[],a=[];for(let u of e.content)switch(u.type){case"text":if(r+=u.text??"",Array.isArray(u.citations))for(let p of u.citations)p?.url&&a.push({url:String(p.url),title:typeof p.title=="string"?p.title:void 0,snippet:typeof p.cited_text=="string"?p.cited_text:void 0});break;case"thinking":if(n){let p=u.thinking??"",d=u.signature;i.push({data:p,encrypted:!1,...typeof d=="string"?{signature:d}:{}})}break;case"redacted_thinking":if(n){let p=u.data??"",d=u.signature;i.push({data:p,encrypted:!0,...typeof d=="string"?{signature:d}:{}})}break;case"tool_use":s.push({id:u.id,type:"function",function:{name:u.name,params:u.input}});break}let l={index:0,id:e.id,finishReason:t};r&&(l.content=r),i.length>0&&(l.thoughtBlocks=i,l.thought=i.map(u=>u.data).join("")),s.length>0&&(l.functionCalls=s),a.length>0&&(l.citations=a);let c=[l];return this.tokensUsed={promptTokens:e.usage.input_tokens,completionTokens:e.usage.output_tokens,totalTokens:e.usage.input_tokens+e.usage.output_tokens+(e.usage.cache_creation_input_tokens||0)+(e.usage.cache_read_input_tokens||0),cacheCreationTokens:e.usage.cache_creation_input_tokens,cacheReadTokens:e.usage.cache_read_input_tokens},{results:c,remoteId:e.id}};createChatStreamResp=(e,t)=>{if(!("type"in e))throw new Error("Invalid Anthropic streaming event");let n=t;if(n.indexIdMap||(n.indexIdMap={}),e.type==="error"){let{error:s}=e;throw new Le(s.message,void 0,void 0)}let r=0;if(e.type==="message_start"){let{message:s}=e,i=[{index:r,content:"",id:s.id}];return this.tokensUsed={promptTokens:s.usage?.input_tokens??0,completionTokens:s.usage?.output_tokens??0,totalTokens:(s.usage?.input_tokens??0)+(s.usage?.output_tokens??0)+(s.usage?.cache_creation_input_tokens??0)+(s.usage?.cache_read_input_tokens??0),cacheCreationTokens:s.usage?.cache_creation_input_tokens,cacheReadTokens:s.usage?.cache_read_input_tokens},{results:i}}if(e.type==="content_block_start"){let{content_block:s}=e;if(s.type==="text"){let i=[];if(Array.isArray(s.citations))for(let a of s.citations)a?.url&&i.push({url:String(a.url),title:typeof a.title=="string"?a.title:void 0,snippet:typeof a.cited_text=="string"?a.cited_text:void 0});return{results:[{index:r,content:s.text,...i.length?{citations:i}:{}}]}}if(s.type==="thinking")return this.currentPromptConfig?.thinkingTokenBudget!=="none"&&this.currentPromptConfig?.showThoughts!==!1?{results:[{index:r,thought:s.thinking,thoughtBlocks:[{data:s.thinking,encrypted:!1}]}]}:{results:[{index:r,content:""}]};if(s.type==="tool_use"&&typeof s.id=="string"&&typeof e.index=="number"&&!n.indexIdMap[e.index]){n.indexIdMap[e.index]=s.id;let i=[{id:s.id,type:"function",function:{name:s.name,params:""}}];return{results:[{index:r,functionCalls:i}]}}if(s.type==="web_search_tool_result"||s.type==="server_tool_use")return{results:[{index:r,content:""}]}}if(e.type==="content_block_delta"){let{delta:s}=e;if(s.type==="citations_delta"){let i=s.citation;if(i&&typeof i.url=="string"&&i.url.length>0){let a=[{url:String(i.url),title:typeof i.title=="string"?i.title:void 0,snippet:typeof i.cited_text=="string"?i.cited_text:void 0}];return{results:[{index:r,content:"",citations:a}]}}return{results:[{index:r,content:""}]}}if(s.type==="text_delta"){let i=[];if(Array.isArray(s.citations))for(let a of s.citations)a?.url&&i.push({url:String(a.url),title:typeof a.title=="string"?a.title:void 0,snippet:typeof a.cited_text=="string"?a.cited_text:void 0});return{results:[{index:r,content:s.text,...i.length?{citations:i}:{}}]}}if(s.type==="thinking_delta")return this.currentPromptConfig?.thinkingTokenBudget!=="none"&&this.currentPromptConfig?.showThoughts!==!1?{results:[{index:r,thought:s.thinking,thoughtBlocks:[{data:s.thinking,encrypted:!1}]}]}:{results:[{index:r,content:""}]};if(s.type==="signature_delta")return{results:[{index:r,thoughtBlocks:[{data:"",encrypted:!1,signature:s.signature}]}]};if(s.type==="input_json_delta"){let i=n.indexIdMap[e.index];if(!i)return{results:[{index:r,content:""}]};let a=[{id:i,type:"function",function:{name:"",params:s.partial_json}}];return{results:[{index:r,functionCalls:a}]}}}if(e.type==="message_delta"){let{delta:s,usage:i}=e;return this.tokensUsed={promptTokens:this.tokensUsed?.promptTokens??0,completionTokens:i.output_tokens,totalTokens:(this.tokensUsed?.promptTokens??0)+i.output_tokens+(this.tokensUsed?.cacheCreationTokens??0)+(this.tokensUsed?.cacheReadTokens??0),cacheCreationTokens:this.tokensUsed?.cacheCreationTokens,cacheReadTokens:this.tokensUsed?.cacheReadTokens},{results:[{index:r,content:"",finishReason:Rl(s.stop_reason)}]}}return{results:[{index:r,content:""}]}};supportsImplicitCaching=()=>!0},pn=class o extends Be{static create(e){return new o(e)}constructor({apiKey:e,projectId:t,region:n,config:r,options:s,models:i}){let a=t!==void 0&&n!==void 0,l,c;if(a){if(!e)throw new Error("Anthropic Vertex API key not set");if(typeof e!="function")throw new Error("Anthropic Vertex API key must be a function for token-based authentication");l=`https://${n==="global"?"aiplatform":`${n}-aiplatform`}.googleapis.com/v1/projects/${t}/locations/${n}/publishers/anthropic/`,c=async()=>({Authorization:`Bearer ${await e()}`,"anthropic-beta":"web-search-2025-03-05"})}else{if(!e)throw new Error("Anthropic API key not set");l="https://api.anthropic.com/v1",c=async()=>({"anthropic-version":"2023-06-01","anthropic-beta":"structured-outputs-2025-11-13, web-search-2025-03-05","x-api-key":typeof e=="function"?await e():e})}let u={...li(),...r},p=new ai(u,a),d=g=>{let f=mt({model:g,modelInfo:fr,models:i});return{functions:!0,streaming:!0,hasThinkingBudget:f?.supported?.thinkingBudget??!1,hasShowThoughts:f?.supported?.showThoughts??!1,structuredOutputs:f?.supported?.structuredOutputs??!1,functionCot:!0,media:{images:{supported:!0,formats:["image/jpeg","image/png","image/gif","image/webp"],maxSize:5*1024*1024,detailLevels:["high","low","auto"]},audio:{supported:!1,formats:[],maxDuration:0},files:{supported:!1,formats:[],maxSize:0,uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!0,types:["ephemeral"],cacheBreakpoints:!1},thinking:f?.supported?.thinkingBudget??!1,multiTurn:!0}},m=i?.map(g=>{let f=g,x=f?.config;if(!x)return g;let A={};x.maxTokens!==void 0&&(A.maxTokens=x.maxTokens),x.temperature!==void 0&&(A.temperature=x.temperature),x.topP!==void 0&&(A.topP=x.topP),x.topK!==void 0&&(A.topK=x.topK),x.presencePenalty!==void 0&&(A.presencePenalty=x.presencePenalty),x.frequencyPenalty!==void 0&&(A.frequencyPenalty=x.frequencyPenalty),x.stopSequences!==void 0&&(A.stopSequences=x.stopSequences),x.endSequences!==void 0&&(A.endSequences=x.endSequences),x.stream!==void 0&&(A.stream=x.stream),x.n!==void 0&&(A.n=x.n);let h={...f};Object.keys(A).length>0&&(h.modelConfig={...f.modelConfig??{},...A});let b=x.thinking?.thinkingTokenBudget;if(typeof b=="number"){let T=u.thinkingTokenBudgetLevels,C=[["minimal",T?.minimal??1024],["low",T?.low??5e3],["medium",T?.medium??1e4],["high",T?.high??2e4],["highest",T?.highest??32e3]],v="minimal",k=Number.POSITIVE_INFINITY;for(let[R,E]of C){let S=Math.abs(b-E);S<k&&(k=S,v=R)}h.thinkingTokenBudget=v}return x.thinking?.includeThoughts!==void 0&&(h.showThoughts=!!x.thinking.includeThoughts),h});super(p,{name:"Anthropic",apiURL:l,headers:c,modelInfo:fr,defaults:{model:u.model},options:s,supportFor:d,models:m??i})}};function zp(o,e){let t=o.map(r=>{switch(r.role){case"function":return{role:"user",content:[{type:"tool_result",content:r.result,tool_use_id:r.functionId,...r.isError?{is_error:!0}:{},...r.cache?{cache:{type:"ephemeral"}}:{}}]};case"user":return typeof r.content=="string"?{role:"user",content:r.content,...r.cache?{cache_control:{type:"ephemeral"}}:{}}:{role:"user",content:r.content.map(i=>{switch(i.type){case"text":return{type:"text",text:i.text,...i.cache?{cache_control:{type:"ephemeral"}}:{}};case"image":return{type:"image",source:{type:"base64",media_type:i.mimeType,data:i.image},...i.cache?{cache_control:{type:"ephemeral"}}:{}};default:throw new Error("Invalid content type")}})};case"assistant":{let s="",i=[],a=r.thoughtBlocks;if(Array.isArray(a)&&a.length>0)for(let l of a)l.encrypted?i.push(l.signature?{type:"redacted_thinking",data:l.data,signature:l.signature}:{type:"redacted_thinking",data:l.data}):i.push(l.signature?{type:"thinking",thinking:l.data,signature:l.signature}:{type:"thinking",thinking:l.data});if(typeof r.content=="string"&&(i.length>0?s=[...i,{type:"text",text:r.content}]:s=r.content),typeof r.functionCalls<"u"&&(s=r.functionCalls.map(l=>{let c={};if(typeof l.function.params=="string"){let u=l.function.params;if(u.trim().length===0)c={};else try{c=JSON.parse(u)}catch{throw new Error(`Failed to parse function params JSON: ${u}`)}}else typeof l.function.params=="object"&&(c=l.function.params);return{type:"tool_use",id:l.id,name:l.function.name,input:c,...r.cache?{cache_control:{type:"ephemeral"}}:{}}}),Array.isArray(s)&&i.length>0&&(s=[...i,...s])),r.cache){if(typeof s=="string")s=[{type:"text",text:s,cache_control:{type:"ephemeral"}}];else if(Array.isArray(s)&&s.length>0){let l=s.length-1,c=s[l];c&&c.type==="text"&&(s[l]={...c,cache_control:{type:"ephemeral"}})}}return{role:"assistant",content:s}}default:throw new Error("Invalid role")}}),n=qp(t);return Hp(n)}function qp(o){let e=[];for(let[t,n]of o.entries()){if(n.role!=="assistant"){e.push(n);continue}if(t>0&&o.at(t-1)?.role==="assistant"){let r=e.pop();e.push({...r||{},...n})}else e.push(n)}return e}function Hp(o){return o.map(e=>e.role==="assistant"&&typeof e.content=="string"?{...e,content:e.content.replace(/\s+$/,"")}:e)}function Rl(o){if(o)switch(o){case"stop_sequence":return"stop";case"max_tokens":return"length";case"tool_use":return"function_call";case"end_turn":return"stop";default:return"stop"}}var hr=(B=>(B.GPT4="gpt-4",B.GPT41="gpt-4.1",B.GPT41Mini="gpt-4.1-mini",B.GPT41Nano="gpt-4.1-nano",B.GPT4O="gpt-4o",B.GPT4OMini="gpt-4o-mini",B.GPT4ChatGPT4O="chatgpt-4o-latest",B.GPT4Turbo="gpt-4-turbo",B.GPT35Turbo="gpt-3.5-turbo",B.GPT35TurboInstruct="gpt-3.5-turbo-instruct",B.GPT35TextDavinci002="text-davinci-002",B.GPT3TextBabbage002="text-babbage-002",B.GPT3TextAda001="text-ada-001",B.GPT5="gpt-5",B.GPT5Nano="gpt-5-nano",B.GPT5Mini="gpt-5-mini",B.GPT5Chat="gpt-5-chat",B.GPT5ChatLatest="gpt-5-chat-latest",B.GPT5Codex="gpt-5-codex",B.GPT5Pro="gpt-5-pro",B.GPT51="gpt-5.1",B.GPT51ChatLatest="gpt-5.1-chat-latest",B.GPT51Codex="gpt-5.1-codex",B.GPT51CodexMini="gpt-5.1-codex-mini",B.GPT51CodexMax="gpt-5.1-codex-max",B.GPT52="gpt-5.2",B.GPT52ChatLatest="gpt-5.2-chat-latest",B.GPT52Codex="gpt-5.2-codex",B.GPT52Pro="gpt-5.2-pro",B.O1="o1",B.O1Mini="o1-mini",B.O3="o3",B.O3Mini="o3-mini",B.O4Mini="o4-mini",B))(hr||{}),dn=(n=>(n.TextEmbeddingAda002="text-embedding-ada-002",n.TextEmbedding3Small="text-embedding-3-small",n.TextEmbedding3Large="text-embedding-3-large",n))(dn||{});var mn=(j=>(j.GPT4="gpt-4",j.GPT41="gpt-4.1",j.GPT41Mini="gpt-4.1-mini",j.GPT41Nano="gpt-4.1-nano",j.GPT4O="gpt-4o",j.GPT4OMini="gpt-4o-mini",j.GPT4ChatGPT4O="chatgpt-4o-latest",j.GPT4Turbo="gpt-4-turbo",j.GPT35Turbo="gpt-3.5-turbo",j.GPT35TurboInstruct="gpt-3.5-turbo-instruct",j.GPT35TextDavinci002="text-davinci-002",j.GPT3TextBabbage002="text-babbage-002",j.GPT3TextAda001="text-ada-001",j.GPT5="gpt-5",j.GPT5Nano="gpt-5-nano",j.GPT5Mini="gpt-5-mini",j.GPT5Chat="gpt-5-chat",j.GPT5ChatLatest="gpt-5-chat-latest",j.GPT5Codex="gpt-5-codex",j.GPT5Pro="gpt-5-pro",j.GPT51="gpt-5.1",j.GPT51ChatLatest="gpt-5.1-chat-latest",j.GPT51Codex="gpt-5.1-codex",j.GPT51CodexMini="gpt-5.1-codex-mini",j.GPT51CodexMax="gpt-5.1-codex-max",j.GPT52="gpt-5.2",j.GPT52ChatLatest="gpt-5.2-chat-latest",j.GPT52Codex="gpt-5.2-codex",j.GPT52Pro="gpt-5.2-pro",j.O1Pro="o1-pro",j.O1="o1",j.O1Mini="o1-mini",j.O3Pro="o3-pro",j.O3="o3",j.O3Mini="o3-mini",j.O4Mini="o4-mini",j))(mn||{});var gn=[{name:"gpt-4",currency:"usd",promptTokenCostPer1M:30,completionTokenCostPer1M:60},{name:"gpt-4.1",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,supported:{structuredOutputs:!0}},{name:"gpt-4.1-mini",currency:"usd",promptTokenCostPer1M:.4,completionTokenCostPer1M:1.6,supported:{structuredOutputs:!0}},{name:"gpt-4.1-nano",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.4,supported:{structuredOutputs:!0}},{name:"gpt-4o",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:15,supported:{structuredOutputs:!0}},{name:"gpt-4o-mini",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:.6,supported:{structuredOutputs:!0}},{name:"chatgpt-4o-latest",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:15,supported:{structuredOutputs:!0}},{name:"gpt-4-turbo",currency:"usd",promptTokenCostPer1M:10,completionTokenCostPer1M:30,supported:{structuredOutputs:!0}},{name:"gpt-3.5-turbo",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5},{name:"gpt-5-nano",currency:"usd",promptTokenCostPer1M:.05,completionTokenCostPer1M:.4,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-mini",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:2,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-chat",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-chat-latest",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-pro",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:120,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-codex",currency:"usd",promptTokenCostPer1M:10,completionTokenCostPer1M:40,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1-chat-latest",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1-codex",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1-codex-mini",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:2,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1-codex-max",currency:"usd",promptTokenCostPer1M:2.5,completionTokenCostPer1M:20,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.2",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.2-chat-latest",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.2-codex",currency:"usd",promptTokenCostPer1M:1.5,completionTokenCostPer1M:6,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.2-pro",currency:"usd",promptTokenCostPer1M:20,completionTokenCostPer1M:160,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"o1",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:60,supported:{structuredOutputs:!0}},{name:"o1-mini",currency:"usd",promptTokenCostPer1M:1.1,completionTokenCostPer1M:14.4,supported:{structuredOutputs:!0}},{name:"o3",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:60,supported:{structuredOutputs:!0}},{name:"o4-mini",currency:"usd",promptTokenCostPer1M:1.1,completionTokenCostPer1M:4.4,supported:{structuredOutputs:!0}},{name:"text-embedding-ada-002",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1},{name:"text-embedding-3-small",currency:"usd",promptTokenCostPer1M:.02,completionTokenCostPer1M:.02},{name:"text-embedding-3-large",currency:"usd",promptTokenCostPer1M:.13,completionTokenCostPer1M:.13}],ho=[{name:"gpt-4",currency:"usd",promptTokenCostPer1M:30,completionTokenCostPer1M:60},{name:"gpt-4.1",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,supported:{structuredOutputs:!0}},{name:"gpt-4.1-mini",currency:"usd",promptTokenCostPer1M:.4,completionTokenCostPer1M:1.6,supported:{structuredOutputs:!0}},{name:"gpt-4.1-nano",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.4,supported:{structuredOutputs:!0}},{name:"gpt-4o",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:15,supported:{structuredOutputs:!0}},{name:"gpt-4o-mini",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:.6,supported:{structuredOutputs:!0}},{name:"chatgpt-4o-latest",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:15,supported:{structuredOutputs:!0}},{name:"gpt-4-turbo",currency:"usd",promptTokenCostPer1M:10,completionTokenCostPer1M:30,supported:{structuredOutputs:!0}},{name:"gpt-3.5-turbo",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5},{name:"gpt-5-nano",currency:"usd",promptTokenCostPer1M:.05,completionTokenCostPer1M:.4,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-mini",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:2,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-chat",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-chat-latest",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-pro",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:120,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-codex",currency:"usd",promptTokenCostPer1M:10,completionTokenCostPer1M:40,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1-chat-latest",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1-codex",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1-codex-mini",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:2,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1-codex-max",currency:"usd",promptTokenCostPer1M:2.5,completionTokenCostPer1M:20,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.2",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.2-chat-latest",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.2-codex",currency:"usd",promptTokenCostPer1M:1.5,completionTokenCostPer1M:6,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.2-pro",currency:"usd",promptTokenCostPer1M:20,completionTokenCostPer1M:160,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"o1-pro",currency:"usd",promptTokenCostPer1M:150,completionTokenCostPer1M:600,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0},isExpensive:!0},{name:"o1",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:60,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"o3-pro",currency:"usd",promptTokenCostPer1M:20,completionTokenCostPer1M:80,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0},isExpensive:!0},{name:"o3",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:60,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"o3-mini",currency:"usd",promptTokenCostPer1M:1.1,completionTokenCostPer1M:4.4,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"o4-mini",currency:"usd",promptTokenCostPer1M:1.1,completionTokenCostPer1M:4.4,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}}];var Kp=o=>{let e=["o1","o1-mini","o3","o3-mini","o4-mini","o1-pro","o3-pro"];return e.includes(o)||e.includes(o)},Yt=()=>structuredClone({model:"gpt-5-mini",embedModel:"text-embedding-3-small",...we()}),xo=()=>structuredClone({...Yt(),model:"gpt-5"}),Ao=()=>structuredClone({model:"gpt-5-mini",embedModel:"text-embedding-3-small",...He()}),yo=()=>({...Yt(),model:"gpt-5-nano"}),ci=class{constructor(e,t,n){this.config=e;this.streamingUsage=t;this.chatReqUpdater=n}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,stopSequences:e.stopSequences,endSequences:e.endSequences,topP:e.topP,n:e.n,stream:e.stream}}createChatReq=(e,t)=>{let n=e.model;if(!e.chatPrompt||e.chatPrompt.length===0)throw new Error("Chat prompt is empty");let r={name:"/chat/completions"},s=e.functions?.map(m=>({type:"function",function:{name:m.name,description:m.description,parameters:m.parameters}})),i=!e.functionCall&&e.functions&&e.functions.length>0?"auto":e.functionCall,a=Wp(e),l=e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,c=e.modelConfig?.stream??this.config.stream,u=this.config.store,p=Kp(n),d={model:n,messages:a,...e.responseFormat?{response_format:e.responseFormat.type==="json_schema"?{type:"json_schema",json_schema:e.responseFormat.schema}:e.responseFormat}:this.config?.responseFormat?{response_format:{type:this.config.responseFormat}}:{},...s?{tools:s}:{},...i?{tool_choice:i}:{},...p?{}:{...(e.modelConfig?.maxTokens??this.config.maxTokens)!==void 0?{max_completion_tokens:e.modelConfig?.maxTokens??this.config.maxTokens}:{},...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},...(e.modelConfig?.n??this.config.n)!==void 0?{n:e.modelConfig?.n??this.config.n}:{},...(e.modelConfig?.presencePenalty??this.config.presencePenalty)!==void 0?{presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty}:{},...l!==void 0?{frequency_penalty:l}:{}},...(e.modelConfig?.stopSequences??this.config.stop)&&(e.modelConfig?.stopSequences??this.config.stop).length>0?{stop:e.modelConfig?.stopSequences??this.config.stop}:{},...this.config.logitBias!==void 0?{logit_bias:this.config.logitBias}:{},...c&&this.streamingUsage?{stream:!0,stream_options:{include_usage:!0}}:{},...u?{store:u}:{},...this.config.serviceTier?{service_tier:this.config.serviceTier}:{},...this.config.user?{user:this.config.user}:{}};if(this.config.reasoningEffort&&(d.reasoning_effort=this.config.reasoningEffort),this.config.webSearchOptions&&(d.web_search_options={...this.config.webSearchOptions.searchContextSize&&{search_context_size:this.config.webSearchOptions.searchContextSize},...this.config.webSearchOptions.userLocation&&{user_location:{approximate:{type:"approximate",...this.config.webSearchOptions.userLocation.approximate.city&&{city:this.config.webSearchOptions.userLocation.approximate.city},...this.config.webSearchOptions.userLocation.approximate.country&&{country:this.config.webSearchOptions.userLocation.approximate.country},...this.config.webSearchOptions.userLocation.approximate.region&&{region:this.config.webSearchOptions.userLocation.approximate.region},...this.config.webSearchOptions.userLocation.approximate.timezone&&{timezone:this.config.webSearchOptions.userLocation.approximate.timezone}}}}}),t?.thinkingTokenBudget)switch(t.thinkingTokenBudget){case"none":d.reasoning_effort=void 0;break;case"minimal":d.reasoning_effort="minimal";break;case"low":d.reasoning_effort="medium";break;case"medium":d.reasoning_effort="high";break;case"high":d.reasoning_effort="high";break;case"highest":d.reasoning_effort="high";break}if(!d.reasoning_effort&&t?.thinkingTokenBudget)switch(t.thinkingTokenBudget){case"minimal":d.reasoning_effort="minimal";break;case"low":d.reasoning_effort="medium";break;case"medium":case"high":case"highest":d.reasoning_effort="high";break}return this.chatReqUpdater&&(d=this.chatReqUpdater(d)),[r,d]};createEmbedReq=e=>{let t=e.embedModel;if(!t)throw new Error("Embed model not set");if(!e.texts||e.texts.length===0)throw new Error("Embed texts is empty");let n={name:"/embeddings"},r={model:t,input:e.texts,dimensions:this.config.dimensions};return[n,r]};createChatResp(e){let{id:t,usage:n,choices:r,error:s}=e;if(s)throw s;return this.tokensUsed=n?{promptTokens:n.prompt_tokens,completionTokens:n.completion_tokens,totalTokens:n.total_tokens}:void 0,{results:r.map(a=>{if(a.message.refusal)throw new Le(a.message.refusal,e.model,e.id);let l=Sl(a.finish_reason),c=a.message.tool_calls?.map(({id:u,function:{arguments:p,name:d}})=>({id:u,type:"function",function:{name:d,params:p}}));return{index:a.index,id:`${a.index}`,content:a.message.content??void 0,thought:a.message.reasoning_content,citations:a.message.annotations?.filter(u=>u?.type==="url_citation"&&u.url_citation).map(u=>({url:u.url_citation?.url,title:u.url_citation?.title,description:u.url_citation?.description})),functionCalls:c,finishReason:l}}),remoteId:t}}createChatStreamResp(e,t){let{id:n,usage:r,choices:s}=e;this.tokensUsed=r?{promptTokens:r.prompt_tokens,completionTokens:r.completion_tokens,totalTokens:r.total_tokens}:void 0;let i=t;return i.indexIdMap||(i.indexIdMap={}),{results:s.map(({index:l,delta:{content:c,role:u,refusal:p,tool_calls:d,reasoning_content:m,annotations:g},finish_reason:f})=>{if(p)throw new Le(p,void 0,n);let x=Sl(f),A=d?.map(({id:h,index:b,function:{name:T,arguments:C}})=>{typeof h=="string"&&typeof b=="number"&&!i.indexIdMap[b]&&(i.indexIdMap[b]=h);let v=i.indexIdMap[b];return v?{id:v,type:"function",function:{name:T,params:C}}:null}).filter(h=>h!==null);return{index:l,content:c??void 0,role:u,thought:m,citations:g?.filter(h=>h?.type==="url_citation"&&h.url_citation).map(h=>({url:h.url_citation?.url,title:h.url_citation?.title,description:h.url_citation?.description})),functionCalls:A,finishReason:x,id:n}})}}createEmbedResp(e){let{data:t,usage:n}=e;return this.tokensUsed=n?{promptTokens:n.prompt_tokens,completionTokens:n.completion_tokens,totalTokens:n.total_tokens}:void 0,{embeddings:t.map(r=>r.embedding)}}},Sl=o=>{switch(o){case"stop":return"stop";case"length":return"length";case"content_filter":return"error";case"tool_calls":return"function_call"}};function Wp(o){return o.chatPrompt.map(t=>{switch(t.role){case"system":return{role:"system",content:t.content};case"user":{let n=Array.isArray(t.content)?t.content.map(r=>{switch(r.type){case"text":return{type:"text",text:r.text};case"image":return{type:"image_url",image_url:{url:`data:${r.mimeType};base64,${r.image}`,details:r.details??"auto"}};case"audio":return{type:"input_audio",input_audio:{data:r.data,format:r.format==="wav"?"wav":void 0}};default:throw new Error("Invalid content type")}}):t.content;return{role:"user",...t.name?{name:t.name}:{},content:n}}case"assistant":{let n=t.functionCalls?.map(r=>({id:r.id,type:"function",function:{name:r.function.name,arguments:typeof r.function.params=="object"?JSON.stringify(r.function.params):r.function.params}}));if(n&&n.length>0)return{role:"assistant",...t.content?{content:t.content}:{},name:t.name,tool_calls:n};if(t.content===void 0)throw new Error("Assistant content is required when no tool calls are provided");return{role:"assistant",content:t.content,...t.name?{name:t.name}:{}}}case"function":return{role:"tool",content:t.result,tool_call_id:t.functionId};default:throw new Error("Invalid role")}})}var Ge=class extends Be{constructor({apiKey:e,config:t,options:n,apiURL:r,modelInfo:s,models:i,chatReqUpdater:a,supportFor:l}){if(!e||e==="")throw new Error("OpenAI API key not set");let c=new ci(t,n?.streamingUsage??!0,a);super(c,{name:"OpenAI",apiURL:r||"https://api.openai.com/v1",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:s,defaults:{model:t.model,embedModel:t.embedModel},options:n,supportFor:l,models:i})}},fn=class extends Ge{constructor({apiKey:e,apiURL:t,config:n,options:r,models:s,modelInfo:i}){if(!e||e==="")throw new Error("OpenAI API key not set");i=[...gn,...i??[]];let a=c=>{let u=mt({model:c,modelInfo:i,models:s});return{functions:!0,streaming:!0,hasThinkingBudget:u?.supported?.thinkingBudget??!1,hasShowThoughts:u?.supported?.showThoughts??!1,structuredOutputs:u?.supported?.structuredOutputs??!1,media:{images:{supported:!0,formats:["image/jpeg","image/png","image/gif","image/webp"],maxSize:20*1024*1024,detailLevels:["high","low","auto"]},audio:{supported:!0,formats:["wav","mp3","ogg"],maxDuration:25*60},files:{supported:!0,formats:["text/plain","application/pdf","image/jpeg","image/png"],maxSize:512*1024*1024,uploadMethod:"upload"},urls:{supported:!1,webSearch:!0,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:u?.supported?.thinkingBudget??!1,multiTurn:!0}},l=s?.map(c=>{let u=c,p=u?.config;if(!p)return c;let d={};p.maxTokens!==void 0&&(d.maxTokens=p.maxTokens),p.temperature!==void 0&&(d.temperature=p.temperature),p.topP!==void 0&&(d.topP=p.topP),p.presencePenalty!==void 0&&(d.presencePenalty=p.presencePenalty),p.frequencyPenalty!==void 0&&(d.frequencyPenalty=p.frequencyPenalty);let m=p.stopSequences??p.stop;m!==void 0&&(d.stopSequences=m),p.n!==void 0&&(d.n=p.n),p.stream!==void 0&&(d.stream=p.stream);let g={...u};Object.keys(d).length>0&&(g.modelConfig={...u.modelConfig??{},...d});let f=p?.thinking?.thinkingTokenBudget;if(typeof f=="number"){let x=[["minimal",200],["low",800],["medium",5e3],["high",1e4],["highest",24500]],A="minimal",h=Number.POSITIVE_INFINITY;for(let[b,T]of x){let C=Math.abs(f-T);C<h&&(h=C,A=b)}g.thinkingTokenBudget=A}return p?.thinking?.includeThoughts!==void 0&&(g.showThoughts=!!p.thinking.includeThoughts),g});super({apiKey:e,apiURL:t,config:{...Yt(),...n},options:r,modelInfo:i,models:l??s,supportFor:a}),super.setName("OpenAI")}};var Vp=o=>{let e=o.trim();if(!e)return e;if(e.includes("api-version=")){let t=e.indexOf("api-version="),n=e.slice(t);return new URLSearchParams(n).get("api-version")??e}return e},Jp=o=>{let e=o.match(/^(\d{4}-\d{2}-\d{2})/);return e?e[1]>="2024-08-01":!1},ui=Yt,kl=Ao,Ol=yo,El=xo,hn=class extends Ge{constructor({apiKey:e,resourceName:t,deploymentName:n,version:r="api-version=2024-02-15-preview",config:s,options:i,models:a,modelInfo:l}){if(!e||e==="")throw new Error("Azure OpenAPI API key not set");if(!t||t==="")throw new Error("Azure OpenAPI resource name not set");if(!n||n==="")throw new Error("Azure OpenAPI deployment id not set");let c={...ui(),...s},u=Vp(r),p=Jp(u);l=[...gn,...l??[]];let d=g=>{let f=mt({model:g,modelInfo:l,models:a});return{functions:!0,streaming:!0,hasThinkingBudget:f?.supported?.thinkingBudget??!1,hasShowThoughts:f?.supported?.showThoughts??!1,structuredOutputs:p&&(f?.supported?.structuredOutputs??!1),functionCot:!1,media:{images:{supported:!0,formats:["image/jpeg","image/png","image/gif","image/webp"],maxSize:20*1024*1024,detailLevels:["high","low","auto"]},audio:{supported:!1,formats:[],maxDuration:0},files:{supported:!1,formats:[],maxSize:0,uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:f?.supported?.thinkingBudget??!1,multiTurn:!0}};super({apiKey:e,config:c,options:i,models:a,modelInfo:l,supportFor:d});let m=t.includes("://")?t:`https://${t}.openai.azure.com/`;super.setName("Azure OpenAI"),super.setAPIURL(new URL(`/openai/deployments/${n}?api-version=${u}`,m).href),super.setHeaders(async()=>({"api-key":e}))}};var bo=class o{services;currentServiceIndex=0;currentService;debug;initialBackoffMs;maxBackoffMs;maxRetries;serviceFailures=new Map;constructor(e,t){if(e.length===0)throw new Error("No AI services provided.");Qp(e),this.services=[...e].sort(t?.comparator??o.metricComparator);let n=this.services[this.currentServiceIndex];if(n===void 0)throw new Error("Error initializing the AI services.");this.currentService=n,this.debug=t?.debug??!0,this.initialBackoffMs=t?.initialBackoffMs??1e3,this.maxBackoffMs=t?.maxBackoffMs??32e3,this.maxRetries=t?.maxRetries??3}static create(e,t){return new o(e,t)}getLastUsedChatModel(){return this.currentService.getLastUsedChatModel()}getLastUsedEmbedModel(){return this.currentService.getLastUsedEmbedModel()}getLastUsedModelConfig(){return this.currentService.getLastUsedModelConfig()}static inputOrderComparator=()=>0;static metricComparator=(e,t)=>{let n=e.getMetrics(),r=t.getMetrics();return n.latency.chat.mean-r.latency.chat.mean};getModelList(){for(let e of this.services){let t=e.getModelList();if(t)return t}}getNextService(e,t){let n=t+1,r=e[n];return r===void 0?{service:void 0,index:n}:{service:r,index:n}}reset(){this.currentServiceIndex=0;let e=this.services[this.currentServiceIndex];if(e===void 0)throw new Error("No AI services provided.");this.currentService=e}getName(){return this.currentService.getName()}getId(){return this.currentService.getId()}getFeatures(e){let t={functions:!1,streaming:!1,thinking:!1,multiTurn:!1,structuredOutputs:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]}};for(let n of this.services){let r=n.getFeatures(e);r.functions&&(t.functions=!0),r.streaming&&(t.streaming=!0),r.thinking&&(t.thinking=!0),r.multiTurn&&(t.multiTurn=!0),r.structuredOutputs&&(t.structuredOutputs=!0),r.functionCot&&(t.functionCot=!0),r.hasThinkingBudget&&(t.hasThinkingBudget=!0),r.hasShowThoughts&&(t.hasShowThoughts=!0),r.media.images.supported&&(t.media.images.supported=!0),t.media.images.formats=Array.from(new Set([...t.media.images.formats,...r.media.images.formats])),r.media.audio.supported&&(t.media.audio.supported=!0),t.media.audio.formats=Array.from(new Set([...t.media.audio.formats,...r.media.audio.formats])),r.media.files.supported&&(t.media.files.supported=!0),t.media.files.formats=Array.from(new Set([...t.media.files.formats,...r.media.files.formats])),r.media.files.uploadMethod!=="none"&&(t.media.files.uploadMethod=r.media.files.uploadMethod),r.media.urls.supported&&(t.media.urls.supported=!0),r.media.urls.webSearch&&(t.media.urls.webSearch=!0),r.media.urls.contextFetching&&(t.media.urls.contextFetching=!0),r.caching.supported&&(t.caching.supported=!0),t.caching.types=Array.from(new Set([...t.caching.types,...r.caching.types]))}return t}getMetrics(){let e={latency:{chat:{mean:0,p95:0,p99:0,samples:[]},embed:{mean:0,p95:0,p99:0,samples:[]}},errors:{chat:{count:0,rate:0,total:0},embed:{count:0,rate:0,total:0}}},t=0,n=0,r=0,s=0;for(let i of this.services){let a=i.getMetrics();e.errors.chat.count+=a.errors.chat.count,e.errors.chat.total+=a.errors.chat.total,e.errors.embed.count+=a.errors.embed.count,e.errors.embed.total+=a.errors.embed.total;let l=a.latency.chat.samples.length;l>0&&(t+=a.latency.chat.mean*l,n+=l);let c=a.latency.embed.samples.length;c>0&&(r+=a.latency.embed.mean*c,s+=c)}e.errors.chat.total>0&&(e.errors.chat.rate=e.errors.chat.count/e.errors.chat.total),e.errors.embed.total>0&&(e.errors.embed.rate=e.errors.embed.count/e.errors.embed.total),n>0&&(e.latency.chat.mean=t/n),s>0&&(e.latency.embed.mean=r/s);for(let i of this.services){let a=i.getMetrics();e.latency.chat.p95=Math.max(e.latency.chat.p95,a.latency.chat.p95),e.latency.chat.p99=Math.max(e.latency.chat.p99,a.latency.chat.p99),e.latency.embed.p95=Math.max(e.latency.embed.p95,a.latency.embed.p95),e.latency.embed.p99=Math.max(e.latency.embed.p99,a.latency.embed.p99)}return e}canRetryService(e){let t=this.serviceFailures.get(e.getId());if(!t)return!0;let{retries:n,lastFailureTime:r}=t,s=Date.now()-r,i=Math.min(this.initialBackoffMs*2**n,this.maxBackoffMs);return s>=i}handleFailure(e,t){let r=(this.serviceFailures.get(e.getId())?.retries??0)+1;this.serviceFailures.set(e.getId(),{retries:r,lastFailureTime:Date.now()}),this.debug&&console.warn(`AxBalancer: Service ${e.getName()} failed (retry ${r}/${this.maxRetries})`,t)}handleSuccess(e){this.serviceFailures.delete(e.getId())}async chat(e,t){let n=e.responseFormat?.type==="json_schema",r=e.capabilities,s=r?.requiresImages,i=r?.requiresAudio,a=this.services,l=e.model;if((n||s||i)&&(a=this.services.filter(p=>{let d=p.getFeatures(l);return!(n&&!d.structuredOutputs||s&&!d.media.images.supported||i&&!d.media.audio.supported)}),a.length===0)){let p=[];throw n&&p.push("structured outputs"),s&&p.push("images"),i&&p.push("audio"),new Error(`No services available that support required capabilities: ${p.join(", ")}.`)}let c=0,u=a[c];if(!u)throw new Error("No matching AI services available for request.");for(this.currentService=u;;){if(!this.canRetryService(u)){let p=this.getNextService(a,c);if(!p.service)throw new Error(`All candidate services exhausted (tried ${a.length} service(s))`);u=p.service,c=p.index,this.currentService=u;continue}try{let p=await u.chat(e,t);return this.handleSuccess(u),p}catch(p){if(!(p instanceof et))throw p;switch(p.constructor){case $t:throw p;case rt:{if(![408,429,500,502,503,504].includes(p.status))throw p;break}case Je:break;case Lt:break;case gt:break;case dt:break;default:throw p}if(this.handleFailure(u,p),(this.serviceFailures.get(u.getId())?.retries??0)>=this.maxRetries){let m=this.getNextService(a,c);if(this.debug&&console.warn(`AxBalancer: Switching to service ${m.service?.getName()??"none"}`,p),!m.service)throw p;u=m.service,c=m.index,this.currentService=u}}}}async embed(e,t){this.reset();let n=this.currentServiceIndex;for(;;){if(!this.canRetryService(this.currentService)){let r=this.getNextService(this.services,n);if(!r.service)throw new Error(`All services exhausted (tried ${this.services.length} service(s))`);this.currentService=r.service,n=r.index,this.currentServiceIndex=n;continue}try{let r=await this.currentService.embed(e,t);return this.handleSuccess(this.currentService),r}catch(r){if(!(r instanceof et)||r instanceof rt&&![408,429,500,502,503,504].includes(r.status)||r instanceof $t)throw r;if(this.handleFailure(this.currentService,r),(this.serviceFailures.get(this.currentService.getId())?.retries??0)>=this.maxRetries){let i=this.getNextService(this.services,n);if(!i.service)throw r;this.currentService=i.service,n=i.index,this.currentServiceIndex=n}}}}setOptions(e){for(let t of this.services)t.setOptions(e);this.currentService.setOptions(e),this.debug=e.debug??this.debug}getOptions(){return this.currentService.getOptions()}getLogger(){return this.currentService.getLogger()}};function Qp(o){let e=o.find(r=>r.getModelList()!==void 0);if(!e)return;let t=e.getModelList();if(!t)throw new Error("No model list found in any service.");let n=new Set(t.map(r=>r.key));for(let r=0;r<o.length;r++){let s=o[r];if(!s)throw new Error(`Service at index ${r} is undefined`);let i=s.getModelList();if(!i)throw new Error(`Service at index ${r} (${s.getName()}) has no model list while another service does.`);let a=new Set(i.map(l=>l.key));for(let l of n)if(!a.has(l))throw new Error(`Service at index ${r} (${s.getName()}) is missing model "${l}"`);for(let l of a)if(!n.has(l))throw new Error(`Service at index ${r} (${s.getName()}) has extra model "${l}"`)}}function Xt(o){let e=!1,t=!1,n=!1,r=!1,s=!1,i=!1,a=!1,l=new Set,c=0;if(o.chatPrompt&&Array.isArray(o.chatPrompt))for(let u of o.chatPrompt){if(u.role==="user"&&Array.isArray(u.content))for(let p of u.content)switch(l.add(p.type),p.type){case"image":e=!0,p.cache&&(a=!0),c+=85;break;case"audio":t=!0,p.cache&&(a=!0),c+=p.duration||60;break;case"file":n=!0,p.cache&&(a=!0),c+=Math.ceil((p.extractedText?.length||1e3)/4);break;case"url":r=!0,p.cache&&(a=!0),c+=Math.ceil((p.cachedContent?.length||2e3)/4);break;case"text":p.cache&&(a=!0),c+=Math.ceil(p.text.length/4);break}else"content"in u&&typeof u.content=="string"&&(c+=Math.ceil(u.content.length/4));"cache"in u&&u.cache&&(a=!0)}return o.functions&&o.functions.length>0&&(s=!0),o.modelConfig?.stream===!0&&(i=!0),o.capabilities&&(o.capabilities.requiresImages&&(e=!0),o.capabilities.requiresAudio&&(t=!0),o.capabilities.requiresFiles&&(n=!0),o.capabilities.requiresWebSearch&&(r=!0)),{hasImages:e,hasAudio:t,hasFiles:n,hasUrls:r,requiresFunctions:s,requiresStreaming:i,requiresCaching:a,contentTypes:l,estimatedTokens:c}}function pi(o,e){let t=o.getFeatures(),n=[],r=[],s=[];if(e.hasImages&&!t.media.images.supported&&(n.push("Image support"),s.push("Use altText for images or imageToText service")),e.hasAudio&&!t.media.audio.supported&&(n.push("Audio support"),s.push("Pre-transcribe audio or use transcription field")),e.hasFiles&&!t.media.files.supported&&(n.push("File support"),s.push("Pre-extract text content or use extractedText field")),e.hasUrls&&!t.media.urls.supported&&(n.push("URL/Web search support"),s.push("Pre-fetch content or use cachedContent field")),e.requiresFunctions&&!t.functions&&n.push("Function calling"),e.requiresStreaming&&!t.streaming&&(n.push("Streaming responses"),s.push("Use non-streaming mode")),e.requiresCaching&&!t.caching.supported&&(n.push("Content caching"),s.push("Repeated content will not be cached")),e.hasImages&&t.media.images.supported){let a=t.media.images.maxSize;a&&a<10*1024*1024&&r.push(`Image size limit is ${Math.round(a/(1024*1024))}MB`)}if(e.hasAudio&&t.media.audio.supported){let a=t.media.audio.maxDuration;a&&a<600&&r.push(`Audio duration limit is ${Math.round(a/60)} minutes`)}return{isSupported:n.length===0,missingCapabilities:n,warnings:r,alternatives:s}}function To(o,e){return o.map(t=>{let n=t.getFeatures(),r=pi(t,e),s=0,i=[];return s+=10,e.hasImages&&n.media.images.supported&&(s+=25,i.push("Images"),n.media.images.detailLevels?.includes("high")&&(s+=5),n.media.images.maxSize&&n.media.images.maxSize>10*1024*1024&&(s+=3)),e.hasAudio&&n.media.audio.supported&&(s+=25,i.push("Audio"),n.media.audio.maxDuration&&n.media.audio.maxDuration>600&&(s+=5)),e.hasFiles&&n.media.files.supported&&(s+=25,i.push("Files"),n.media.files.uploadMethod==="cloud"&&(s+=3)),e.hasUrls&&n.media.urls.supported&&(s+=25,i.push("URLs"),n.media.urls.webSearch&&(s+=5)),e.requiresFunctions&&n.functions&&(s+=15,i.push("Functions"),n.functionCot&&(s+=3)),e.requiresStreaming&&n.streaming&&(s+=10,i.push("Streaming")),e.requiresCaching&&n.caching.supported&&(s+=8,i.push("Caching"),n.caching.types.includes("persistent")&&(s+=3)),n.thinking&&(s+=2),n.multiTurn&&(s+=2),n.hasThinkingBudget&&(s+=1),n.hasShowThoughts&&(s+=1),s-=r.missingCapabilities.length*10,{provider:t,score:s,missingCapabilities:r.missingCapabilities,supportedCapabilities:i}}).sort((t,n)=>n.score-t.score)}function Co(o,e,t={}){if(e.length===0)throw new Error("No providers available");let n=Xt(o),r=To(e,n);if(t.requireExactMatch){let s=r.filter(i=>i.missingCapabilities.length===0);if(s.length===0)throw new Error(`No providers fully support the request requirements: ${r[0]?.missingCapabilities.join(", ")||"unknown requirements"}`);return s[0].provider}if(!t.allowDegradation){let s=r[0];if(s.missingCapabilities.length>0)throw new Error(`Best available provider (${s.provider.getName()}) is missing: ${s.missingCapabilities.join(", ")}`)}return r[0].provider}function Ml(o,e){let t=Xt(o),n=To(e,t),r=n[0]?.provider||null,s=[t.hasImages&&"images",t.hasAudio&&"audio",t.hasFiles&&"files",t.hasUrls&&"URLs",t.requiresFunctions&&"functions",t.requiresStreaming&&"streaming",t.requiresCaching&&"caching"].filter(Boolean).length,i=r?n[0].supportedCapabilities.length:0,a=r?`${r.getName()} supports ${i}/${s} requirements (${Math.round(i/Math.max(s,1)*100)}% compatibility)`:"No suitable providers found";return{requirements:t,providerScores:n,recommendedProvider:r,summary:a}}function Pl(o,e){return o.filter(t=>t.getFeatures().media[e].supported)}function Fl(o,e){let t={};for(let n of o){let s=n.getFeatures().media[e];if(s.supported)for(let i of s.formats)t[i]||(t[i]=[]),t[i].push(n)}return t}var xr=(r=>(r.CommandRPlus="command-r-plus",r.CommandR="command-r",r.Command="command",r.CommandLight="command-light",r))(xr||{}),Ar=(r=>(r.EmbedEnglishV30="embed-english-v3.0",r.EmbedEnglishLightV30="embed-english-light-v3.0",r.EmbedMultiLingualV30="embed-multilingual-v3.0",r.EmbedMultiLingualLightV30="embed-multilingual-light-v3.0",r))(Ar||{});var Io=[{name:"command-r-plus",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15},{name:"command-r",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5},{name:"command",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5},{name:"command-light",currency:"usd",promptTokenCostPer1M:.3,completionTokenCostPer1M:.6},{name:"embed-english-light-v3.0",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1},{name:"embed-english-v3.0",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1},{name:"embed-multilingual-v3.0",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1},{name:"embed-multilingual-light-v3.0",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1}];function Yp(o){if(Array.isArray(o)){let t=["string","number","integer","boolean","object","array"].find(n=>o.includes(n));return t||(o.find(n=>n!=="null")??o[0]??"string")}return typeof o=="string"?o:"string"}var mi=()=>structuredClone({model:"command-r-plus",embedModel:"embed-english-v3.0",...we()}),Nl=()=>structuredClone({model:"command-r",embedModel:"embed-english-v3.0",...He()}),di=class{constructor(e){this.config=e}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,topP:e.topP,topK:e.topK,frequencyPenalty:e.frequencyPenalty,presencePenalty:e.presencePenalty,endSequences:e.endSequences,stopSequences:e.stopSequences,stream:e.stream,n:e.n}}createChatReq(e){let t=e.model,n=e.chatPrompt.at(-1),r=e.chatPrompt.slice(0,-1),s;n&&n.role==="user"&&typeof n.content=="string"&&(s=n?.content);let i=Xp(r),a=e.functions?.map(p=>{let d={};if(p.parameters?.properties)for(let[m,g]of Object.entries(p.parameters.properties))d[m]={description:g.description,type:Yp(g.type),required:p.parameters.required?.includes(m)??!1};return{name:p.name,description:p.description,parameter_definitions:d}}),l=e.chatPrompt.filter(p=>p.role==="function").map(p=>{let d=a?.find(m=>m.name===p.functionId);if(!d)throw new Error("Function not found");return{call:{name:d.name,parameters:d.parameter_definitions},outputs:[{result:p.result??""}]}}),c={name:"/chat"},u={message:s,model:t,tools:a,...l&&!s?{tool_results:l}:{},chat_history:i,max_tokens:e.modelConfig?.maxTokens??this.config.maxTokens,...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},k:e.modelConfig?.topK??this.config.topK,...e.modelConfig?.topP!==void 0?{p:e.modelConfig.topP}:{},frequency_penalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty,end_sequences:this.config.endSequences,stop_sequences:e.modelConfig?.stopSequences??this.config.stopSequences};return[c,u]}createEmbedReq=e=>{let t=e.embedModel;if(!t)throw new Error("Embed model not set");if(!e.texts||e.texts.length===0)throw new Error("Embed texts is empty");let n={name:"/embed"},r={model:t,texts:e.texts??[],input_type:"classification",truncate:""};return[n,r]};createChatResp=e=>{this.tokensUsed=e.meta.billed_units?{promptTokens:e.meta.billed_units.input_tokens,completionTokens:e.meta.billed_units.output_tokens,totalTokens:e.meta.billed_units.input_tokens+e.meta.billed_units.output_tokens}:void 0;let t;if("finish_reason"in e)switch(e.finish_reason){case"COMPLETE":t="stop";break;case"MAX_TOKENS":t="length";break;case"ERROR":throw new Error("Finish reason: ERROR");case"ERROR_TOXIC":throw new Error("Finish reason: CONTENT_FILTER");default:t="stop";break}let n;return"tool_calls"in e&&(n=e.tool_calls?.map(s=>({id:s.name,type:"function",function:{name:s.name,params:s.parameters}}))),{results:[{index:0,id:e.generation_id,content:e.text,functionCalls:n,finishReason:t}],remoteId:e.response_id}};createChatStreamResp=(e,t)=>{let n=t;e.event_type==="stream-start"&&(n.generation_id=e.generation_id),this.tokensUsed={promptTokens:0,completionTokens:e.meta.billed_units?.output_tokens??0,totalTokens:e.meta.billed_units?.output_tokens??0};let{results:r}=this.createChatResp(e),s=r[0];if(!s)throw new Error("No result");return s.id=n.generation_id??"",{results:r}};createEmbedResp(e){return{remoteId:e.id,embeddings:e.embeddings}}},xn=class extends Be{constructor({apiKey:e,config:t,options:n,models:r}){if(!e||e==="")throw new Error("Cohere API key not set");let s={...mi(),...t},i=new di(s),a=r?.map(l=>{let c=l,u=c?.config;if(!u)return l;let p={};u.maxTokens!==void 0&&(p.maxTokens=u.maxTokens),u.temperature!==void 0&&(p.temperature=u.temperature),u.topP!==void 0&&(p.topP=u.topP),u.topK!==void 0&&(p.topK=u.topK),u.presencePenalty!==void 0&&(p.presencePenalty=u.presencePenalty),u.frequencyPenalty!==void 0&&(p.frequencyPenalty=u.frequencyPenalty),u.stopSequences!==void 0&&(p.stopSequences=u.stopSequences),u.endSequences!==void 0&&(p.endSequences=u.endSequences),u.stream!==void 0&&(p.stream=u.stream),u.n!==void 0&&(p.n=u.n);let d={...c};return Object.keys(p).length>0&&(d.modelConfig={...c.modelConfig??{},...p}),d});super(i,{name:"Cohere",apiURL:"https://api.cohere.ai/v1",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:Io,defaults:{model:s.model},supportFor:{functions:!0,streaming:!0,media:{images:{supported:!1,formats:[],maxSize:0,detailLevels:[]},audio:{supported:!1,formats:[],maxDuration:0},files:{supported:!1,formats:[],maxSize:0,uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},options:n,models:a??r})}};function Xp(o){return o.map(e=>{let t="";if(e.role==="system"||e.role==="assistant"||e.role==="user")if(typeof e.content=="string")t=e.content;else throw new Error("Multi-modal content not supported");switch(e.role){case"user":return{role:"USER",message:t};case"system":return{role:"SYSTEM",message:t};case"assistant":{let n=_l(e.functionCalls);return{role:"CHATBOT",message:t,tool_calls:n}}case"function":{let n=o.map(i=>{if(i.role==="assistant")return i.functionCalls?.find(a=>a.id===e.functionId)}).filter(i=>i!==void 0),r=_l(n)?.at(0);if(!r)throw new Error("Function call not found");let s=[{result:e.result}];return{role:"TOOL",tool_results:[{call:r,outputs:s}]}}default:throw new Error("Unknown role")}})}function _l(o){return o?.map(e=>{let t;if(typeof e.function.params=="string"){let n=e.function.params;if(n.trim().length===0)t={};else try{t=JSON.parse(n)}catch{throw new Error(`Failed to parse function params JSON: ${n}`)}}else t=e.function.params;return{name:e.function.name,parameters:t}})}var yr=(n=>(n.DeepSeekChat="deepseek-chat",n.DeepSeekCoder="deepseek-coder",n.DeepSeekReasoner="deepseek-reasoner",n))(yr||{});var wo=[{name:"deepseek-chat",currency:"USD",promptTokenCostPer1M:.27,completionTokenCostPer1M:1.1},{name:"deepseek-reasoner",currency:"USD",promptTokenCostPer1M:.55,completionTokenCostPer1M:2.19}];var gi=()=>structuredClone({model:"deepseek-chat",...we()}),Ll=()=>structuredClone({model:"deepseek-coder",...He()}),An=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("DeepSeek API key not set");let i={...gi(),...t};s=[...wo,...s??[]],super({apiKey:e,config:i,options:n,apiURL:"https://api.deepseek.com",modelInfo:s,supportFor:{functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},models:r}),super.setName("DeepSeek")}};var br=(T=>(T.Gemini31Pro="gemini-3.1-pro-preview",T.Gemini3FlashLite="gemini-3.1-flash-lite-preview",T.Gemini3Flash="gemini-3-flash-preview",T.Gemini3Pro="gemini-3.1-pro-preview",T.Gemini3ProImage="gemini-3-pro-image-preview",T.Gemini25Pro="gemini-2.5-pro",T.Gemini25Flash="gemini-2.5-flash",T.Gemini25FlashLite="gemini-2.5-flash-lite",T.Gemini20Flash="gemini-2.0-flash",T.Gemini20FlashLite="gemini-2.0-flash-lite",T.Gemini20ProExp="gemini-2.0-pro-exp-02-05",T.Gemini20FlashThinkingExp="gemini-2.0-flash-thinking-exp-01-21",T.Gemini1Pro="gemini-1.0-pro",T.Gemini15Flash="gemini-1.5-flash",T.Gemini15Flash002="gemini-1.5-flash-002",T.Gemini15Flash8B="gemini-1.5-flash-8b",T.Gemini15Pro="gemini-1.5-pro",T.GeminiFlashLatest="gemini-flash-latest",T.GeminiFlashLiteLatest="gemini-flash-lite-latest",T.GeminiProLatest="gemini-pro-latest",T))(br||{}),Ro=(s=>(s.GeminiEmbedding001="gemini-embedding-001",s.GeminiEmbedding="gemini-embedding-exp",s.TextEmbeddingLarge="text-embedding-large-exp-03-07",s.TextEmbedding004="text-embedding-004",s.TextEmbedding005="text-embedding-005",s))(Ro||{}),vo=(r=>(r.HarmCategoryHarassment="HARM_CATEGORY_HARASSMENT",r.HarmCategoryHateSpeech="HARM_CATEGORY_HATE_SPEECH",r.HarmCategorySexuallyExplicit="HARM_CATEGORY_SEXUALLY_EXPLICIT",r.HarmCategoryDangerousContent="HARM_CATEGORY_DANGEROUS_CONTENT",r))(vo||{}),So=(s=>(s.BlockNone="BLOCK_NONE",s.BlockOnlyHigh="BLOCK_ONLY_HIGH",s.BlockMediumAndAbove="BLOCK_MEDIUM_AND_ABOVE",s.BlockLowAndAbove="BLOCK_LOW_AND_ABOVE",s.BlockDefault="HARM_BLOCK_THRESHOLD_UNSPECIFIED",s))(So||{}),fi=(l=>(l.SemanticSimilarity="SEMANTIC_SIMILARITY",l.Classification="CLASSIFICATION",l.Clustering="CLUSTERING",l.RetrievalDocument="RETRIEVAL_DOCUMENT",l.RetrievalQuery="RETRIEVAL_QUERY",l.QuestionAnswering="QUESTION_ANSWERING",l.FactVerification="FACT_VERIFICATION",l.CodeRetrievalQuery="CODE_RETRIEVAL_QUERY",l))(fi||{}),$l=["gemini-3.1-pro-preview","gemini-3.1-pro-preview-customtools","gemini-3.1-flash-lite-preview","gemini-3-flash-preview","gemini-2.5-pro","gemini-2.5-flash","gemini-2.5-flash-lite","gemini-2.0-flash","gemini-2.0-flash-lite","gemini-flash-latest","gemini-flash-lite-latest"];var ko=[{name:"gemini-3.1-pro-preview",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:2,completionTokenCostPer1M:12,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-3-flash-preview",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.5,completionTokenCostPer1M:3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-3.1-flash-lite-preview",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.25,completionTokenCostPer1M:1.5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-3-pro-image-preview",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:2,completionTokenCostPer1M:.134,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.5-pro",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:2.5,completionTokenCostPer1M:15,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.0-pro-exp-02-05",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:0,completionTokenCostPer1M:0,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.0-flash-thinking-exp-01-21",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:0,completionTokenCostPer1M:0,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.5-flash",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:15,completionTokenCostPer1M:3.5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.5-flash-lite",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.1,completionTokenCostPer1M:.4,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.0-flash",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.01,completionTokenCostPer1M:.4,supported:{structuredOutputs:!0}},{name:"gemini-2.0-flash-lite",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:0,completionTokenCostPer1M:0,supported:{structuredOutputs:!0}},{name:"gemini-1.5-flash",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.075,completionTokenCostPer1M:.3,supported:{structuredOutputs:!0}},{name:"gemini-1.5-flash-8b",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.0375,completionTokenCostPer1M:.15,supported:{structuredOutputs:!0}},{name:"gemini-1.5-pro",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:1.25,completionTokenCostPer1M:5,supported:{structuredOutputs:!0}},{name:"gemini-1.0-pro",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5,supported:{structuredOutputs:!0}},{name:"gemini-flash-latest",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.075,completionTokenCostPer1M:.3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-flash-lite-latest",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:0,completionTokenCostPer1M:0,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-pro-latest",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:1.25,completionTokenCostPer1M:5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}}];var Zt=o=>o.includes("gemini-3"),Dl=o=>o.includes("gemini-3")&&o.includes("pro"),Oo=o=>{if(!o||typeof o!="object")return o;let e={...o};return delete e.additionalProperties,delete e.default,delete e.optional,delete e.maximum,delete e.oneOf,delete e.anyOf,Array.isArray(e.type)&&(e.type=e.type.includes("object")?"object":e.type[0]??"string"),e.properties&&typeof e.properties=="object"&&(e.properties=Object.fromEntries(Object.entries(e.properties).map(([t,n])=>[t,Oo(n)]))),e.items&&(e.items=Oo(e.items)),e},Ul=[{category:"HARM_CATEGORY_HARASSMENT",threshold:"BLOCK_NONE"},{category:"HARM_CATEGORY_HATE_SPEECH",threshold:"BLOCK_NONE"},{category:"HARM_CATEGORY_SEXUALLY_EXPLICIT",threshold:"BLOCK_NONE"},{category:"HARM_CATEGORY_DANGEROUS_CONTENT",threshold:"BLOCK_NONE"}],xi=()=>structuredClone({model:"gemini-2.5-flash",embedModel:"text-embedding-005",safetySettings:Ul,thinkingTokenBudgetLevels:{minimal:200,low:800,medium:5e3,high:1e4,highest:24500},thinkingLevelMapping:{minimal:"minimal",low:"low",medium:"medium",high:"high",highest:"high"},...we()}),Gl=()=>structuredClone({model:"gemini-2.0-flash",embedModel:"text-embedding-005",safetySettings:Ul,thinkingTokenBudgetLevels:{minimal:200,low:800,medium:5e3,high:1e4,highest:24500},thinkingLevelMapping:{minimal:"minimal",low:"low",medium:"medium",high:"high",highest:"high"},...He()}),hi=class{constructor(e,t,n,r,s){this.config=e;this.isVertex=t;this.endpointId=n;this.apiKey=r;this.options=s;if(!this.isVertex&&this.config.autoTruncate)throw new Error("Auto truncate is not supported for GoogleGemini");let i=this.config.model;if(Zt(i)){if(this.config.thinking?.thinkingTokenBudget!==void 0&&typeof this.config.thinking.thinkingTokenBudget=="number")throw new Error(`Gemini 3 models (${i}) do not support numeric thinkingTokenBudget. Use thinkingLevel ('low', 'medium', 'high') instead, or pass thinkingTokenBudget as a string level via options.`);if(Dl(i)&&this.config.thinking?.thinkingLevel){let a=this.config.thinking.thinkingLevel;if(a!=="low"&&a!=="high")throw new Error(`Gemini 3 Pro (${i}) only supports thinkingLevel 'low' or 'high', got '${a}'. Use 'low' for less thinking or 'high' for more thinking.`)}}}tokensUsed;models;setModels(e){this.models=e}getEffectiveMappings(e){let t=this.models?.find(n=>n.model===e);return{thinkingLevelMapping:{...this.config.thinkingLevelMapping,...t?.thinkingLevelMapping??{}},thinkingTokenBudgetLevels:{...this.config.thinkingTokenBudgetLevels,...t?.thinkingTokenBudgetLevels??{}}}}getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,topP:e.topP,topK:e.topK,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,stopSequences:e.stopSequences,endSequences:e.endSequences,stream:e.stream,n:e.n}}createChatReq=async(e,t)=>{let n=e.model,r=e.modelConfig?.stream??this.config.stream;if(!e.chatPrompt||e.chatPrompt.length===0)throw new Error("Chat prompt is empty");let s;if(this.endpointId?s={name:r?`/${this.endpointId}:streamGenerateContent?alt=sse`:`/${this.endpointId}:generateContent`}:s={name:r?`/models/${n}:streamGenerateContent?alt=sse`:`/models/${n}:generateContent`},!this.isVertex){let h=r?"&":"?",b=typeof this.apiKey=="function"?await this.apiKey():this.apiKey;s.name+=`${h}key=${b}`}let i=e.chatPrompt.filter(h=>h.role==="system").map(h=>h.content),a=i.length>0?{role:"user",parts:[{text:i.join(" ")}]}:void 0,l=[],c=e.chatPrompt.filter(h=>h.role!=="system");for(let h=0;h<c.length;h++){let b=c[h];switch(b.role){case"user":{let T=Array.isArray(b.content)?b.content.map((C,v)=>{switch(C.type){case"text":return{text:C.text};case"image":return{inlineData:{mimeType:C.mimeType,data:C.image}};case"audio":return{inlineData:{mimeType:`audio/${C.format??"mp3"}`,data:C.data}};case"file":return"fileUri"in C?{fileData:{mimeType:C.mimeType,fileUri:C.fileUri}}:{inlineData:{mimeType:C.mimeType,data:C.data}};default:throw new Error(`Chat prompt content type not supported (index: ${v})`)}}):[{text:b.content}];l.push({role:"user",parts:T});break}case"assistant":{let T=[],C=b.thoughtBlocks,v=b.functionCalls&&b.functionCalls.length>0,k=C?.[0],R=C?.map(S=>S.data).join("")??"",E=k?.signature;if(R&&T.push({...v?{}:{thought:!0},text:R,...E&&!v?{thought_signature:E}:{}}),b.functionCalls){let S=b.functionCalls.map((_,L)=>{let P;if(typeof _.function.params=="string"){let N=_.function.params;if(N.trim().length===0)P={};else try{P=JSON.parse(N)}catch{throw new Error(`Failed to parse function params JSON: ${N}`)}}else P=_.function.params;let F={functionCall:{name:_.function.name,args:P}};return E&&L===0&&(F.thought_signature=E),F});T.push(...S)}if(b.content&&T.push({text:b.content}),T.length===0)throw new Error("Assistant content is empty");l.push({role:"model",parts:T});break}case"function":{let T=[],C=b,v=h;for(;;){if(!("functionId"in C))throw new Error(`Chat prompt functionId is empty (index: ${v})`);if(T.push({functionResponse:{name:C.functionId,response:{result:C.result}}}),v+1<c.length&&c[v+1].role==="function")v++,C=c[v];else break}h=v,l.push({role:"user",parts:T});break}default:throw new Error(`Invalid role: ${JSON.stringify(b)} (index: ${h})`)}}let u=[];if(e.functions&&e.functions.length>0){let h=e.functions.map(b=>{let T={type:"object",properties:{dummy:{type:"string",description:"An optional dummy parameter, do not use"}},required:[]},C=b.parameters?Oo(b.parameters):void 0;return C===void 0||C&&typeof C=="object"&&Object.keys(C).length===0?C={...T}:C&&typeof C=="object"&&C.type==="object"&&(!("properties"in C)||!C.properties||Object.keys(C.properties).length===0)&&(C={...C,properties:{dummy:{type:"string",description:"An optional dummy parameter, do not use"}},required:[]}),{name:b.name,description:b.description,parameters:C}});u.push({function_declarations:h})}if(this.options?.codeExecution&&u.push({code_execution:{}}),this.options?.googleSearchRetrieval&&u.push({google_search_retrieval:{dynamic_retrieval_config:this.options.googleSearchRetrieval}}),this.options?.googleSearch&&u.push({google_search:{}}),this.options?.googleMaps){let h=this.options.googleMaps,b=h?.enableWidget!==void 0?{enableWidget:h.enableWidget}:{};u.push({google_maps:b})}this.options?.urlContext&&u.push({url_context:{}}),u.length===0&&(u=void 0);let p,d=Array.isArray(u)?u.some(h=>h&&Array.isArray(h.function_declarations)&&h.function_declarations.length>0):!1;if(e.functionCall)if(e.functionCall==="none")p={function_calling_config:{mode:"NONE"}};else if(e.functionCall==="auto")p={function_calling_config:{mode:"AUTO"}};else if(e.functionCall==="required")p={function_calling_config:{mode:"ANY"}};else{let h=e.functionCall.function?.name?{allowedFunctionNames:[e.functionCall.function.name]}:{};p={function_calling_config:{mode:"ANY"},...h}}else d&&(p={function_calling_config:{mode:"AUTO"}});this.options?.retrievalConfig&&(p={...p??{},retrievalConfig:{...this.options.retrievalConfig.latLng?{latLng:this.options.retrievalConfig.latLng}:{}}});let m={};if(this.config.thinking?.includeThoughts&&(m.includeThoughts=!0),this.config.thinking?.thinkingTokenBudget&&(m.thinkingBudget=this.config.thinking.thinkingTokenBudget),this.config.thinking?.thinkingLevel&&Zt(n)&&(m.thinkingLevel=this.config.thinking.thinkingLevel),t?.thinkingTokenBudget){let h=this.getEffectiveMappings(n),b=h.thinkingTokenBudgetLevels;if(Zt(n)){let C=Dl(n),v=h.thinkingLevelMapping;if(t.thinkingTokenBudget==="none")m.thinkingLevel=v?.minimal??"minimal";else{let k=t.thinkingTokenBudget,R=v?.[k];R||(R=k==="highest"?"high":k),m.thinkingLevel=R}if(C&&m.thinkingLevel){let k=m.thinkingLevel;k!=="low"&&k!=="high"&&(m.thinkingLevel=k==="minimal"?"low":"high")}}else switch(t.thinkingTokenBudget){case"none":m.thinkingBudget=0,m.includeThoughts=!1,delete m.thinkingLevel;break;case"minimal":m.thinkingBudget=b?.minimal??200;break;case"low":m.thinkingBudget=b?.low??800;break;case"medium":m.thinkingBudget=b?.medium??5e3;break;case"high":m.thinkingBudget=b?.high??1e4;break;case"highest":m.thinkingBudget=b?.highest??24500;break}}m.thinkingLevel&&delete m.thinkingBudget,Zt(n)||delete m.thinkingLevel,Zt(n)&&delete m.thinkingBudget;let g=e.modelConfig?.maxTokens??this.config.maxTokens;if(m.thinkingLevel&&g!==void 0)throw new Error("Cannot set maxTokens when using thinkingLevel with Gemini models. When thinking is enabled, the model manages output tokens automatically. Remove the maxTokens setting or disable thinking.");t?.showThoughts!==void 0&&t?.thinkingTokenBudget!=="none"&&(m.includeThoughts=t.showThoughts);let f={maxOutputTokens:e.modelConfig?.maxTokens??this.config.maxTokens,temperature:e.modelConfig?.temperature??this.config.temperature,...e.modelConfig?.topP!==void 0?{topP:e.modelConfig.topP}:{},topK:e.modelConfig?.topK??this.config.topK,frequencyPenalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,candidateCount:1,stopSequences:e.modelConfig?.stopSequences??this.config.stopSequences,responseMimeType:"text/plain",...Object.keys(m).length>0?{thinkingConfig:m}:{}};if(Zt(n)&&(f.temperature===void 0||f.temperature<1)&&(f.temperature=1),e.responseFormat){if(f.responseMimeType="application/json",e.responseFormat.type==="json_schema"&&e.responseFormat.schema){let h=e.responseFormat.schema.schema||e.responseFormat.schema;f.responseSchema=Oo(h)}}else this.config.responseFormat&&this.config.responseFormat==="json_object"&&(f.responseMimeType="application/json");let x=this.config.safetySettings;return[s,{contents:l,tools:u,toolConfig:p,systemInstruction:a,generationConfig:f,safetySettings:x}]};createEmbedReq=async e=>{let t=e.embedModel;if(!t)throw new Error("Embed model not set");if(!e.texts||e.texts.length===0)throw new Error("Embed texts is empty");let n,r;if(this.isVertex)this.endpointId?n={name:`/${this.endpointId}:predict`}:n={name:`/models/${t}:predict`},r={instances:e.texts.map(s=>({content:s,...this.config.embedType&&{taskType:this.config.embedType}})),parameters:{autoTruncate:this.config.autoTruncate,outputDimensionality:this.config.dimensions}};else{let s=typeof this.apiKey=="function"?this.apiKey():this.apiKey;n={name:`/models/${t}:batchEmbedContents?key=${s}`},r={requests:e.texts.map(i=>({model:`models/${t}`,content:{parts:[{text:i}]},outputDimensionality:this.config.dimensions,...this.config.embedType&&{taskType:this.config.embedType}}))}}return[n,r]};createChatResp=e=>{let t,n=e.candidates?.map(s=>{let i={index:0};switch(s.finishReason){case"MAX_TOKENS":i.finishReason="length";break;case"STOP":i.finishReason="stop";break;case"SAFETY":throw new Le("Content was blocked due to safety settings",void 0,void 0);case"RECITATION":throw new Le("Content was blocked due to recitation policy",void 0,void 0);case"MALFORMED_FUNCTION_CALL":throw new Le("Function call was malformed and blocked",void 0,void 0);case"UNEXPECTED_TOOL_CALL":throw new Le("Unexpected tool call",void 0,void 0);case"FINISH_REASON_UNSPECIFIED":throw new Le("Finish reason unspecified",void 0,void 0);case"BLOCKLIST":throw new Le("Content was blocked due to blocklist",void 0,void 0);case"PROHIBITED_CONTENT":throw new Le("Content was blocked due to prohibited content",void 0,void 0);case"SPII":throw new Le("Content was blocked due to SPII",void 0,void 0);case"OTHER":throw new Le("Other finish reason",void 0,void 0)}if(!s.content||!s.content.parts)return i;for(let c of s.content.parts){if("text"in c){if("thought"in c&&c.thought||c.thought===!0){i.thought=c.text;let u=c.thoughtSignature||c.thought_signature;i.thoughtBlocks||(i.thoughtBlocks=[]),i.thoughtBlocks.push({data:c.text,encrypted:!1,...u?{signature:u}:{}})}else i.content=c.text;continue}if("functionCall"in c){let u=c.thoughtSignature||c.thought_signature;if(u)if(!i.thoughtBlocks||i.thoughtBlocks.length===0)i.thoughtBlocks=[{data:"",encrypted:!1,signature:u}];else{let p=i.thoughtBlocks[i.thoughtBlocks.length-1];p&&!p.signature&&(p.signature=u)}i.functionCalls=[...i.functionCalls??[],{id:Ze(),type:"function",function:{name:c.functionCall.name,params:c.functionCall.args}}]}}let a=s.citationMetadata?.citations;if(Array.isArray(a)&&a.length){let c=u=>u?`${u.year}-${String(u.month).padStart(2,"0")}-${String(u.day).padStart(2,"0")}`:void 0;i.citations=a.filter(u=>typeof u?.uri=="string").map(u=>({url:u.uri,title:u.title,license:u.license,publicationDate:c(u.publicationDate)}))}let l=s.groundingMetadata;if(l){if(Array.isArray(l.groundingChunks)){let c=l.groundingChunks.map(u=>u?.maps).filter(u=>u&&typeof u.uri=="string").map(u=>({url:u.uri,title:u.title}));c.length&&(i.citations=[...i.citations??[],...c])}typeof l.googleMapsWidgetContextToken=="string"&&(t=l.googleMapsWidgetContextToken)}return i});e.usageMetadata&&(this.tokensUsed={totalTokens:e.usageMetadata.totalTokenCount,promptTokens:e.usageMetadata.promptTokenCount,completionTokens:e.usageMetadata.candidatesTokenCount,thoughtsTokens:e.usageMetadata.thoughtsTokenCount,...e.usageMetadata.cachedContentTokenCount!==void 0?{cacheReadTokens:e.usageMetadata.cachedContentTokenCount}:{}});let r={results:n};return t&&(r.providerMetadata={...r.providerMetadata,google:{...r.providerMetadata?.google??{},mapsWidgetContextToken:t}}),r};createChatStreamResp=e=>this.createChatResp(e);createEmbedResp=e=>{let t;return this.isVertex?t=e.predictions.map(n=>n.embeddings.values):t=e.embeddings.map(n=>n.values),{embeddings:t}};supportsContextCache=e=>{let t=e;return $l.some(n=>t.includes(n)||n.includes(t))};buildCacheCreateOp=(e,t)=>{let n=e.model,r=t.contextCache?.ttlSeconds??3600,{systemInstruction:s,contents:i}=this.extractCacheableContent(e.chatPrompt);if(!s&&(!i||i.length===0))return;let a={model:this.isVertex?n:`models/${n}`,ttl:`${r}s`,displayName:`ax-cache-${Date.now()}`};s&&(a.systemInstruction=s),i&&i.length>0&&(a.contents=i);let l;if(this.isVertex)l="/cachedContents";else{l="/cachedContents";let c=typeof this.apiKey=="function"?"ASYNC_KEY":this.apiKey;l+=`?key=${c}`}return{type:"create",apiConfig:{name:l},request:a,parseResponse:c=>{let u=c;if(u?.name)return{name:u.name,expiresAt:u.expireTime,tokenCount:u.usageMetadata?.totalTokenCount}}}};buildCacheUpdateTTLOp=(e,t)=>{let n={ttl:`${t}s`},r=`/${e}`;if(!this.isVertex&&this.apiKey){let s=typeof this.apiKey=="function"?"ASYNC_KEY":this.apiKey;r+=`?key=${s}`}return{type:"update",apiConfig:{name:r,headers:{"Content-Type":"application/json"}},request:n,parseResponse:s=>{let i=s;if(i?.name)return{name:i.name,expiresAt:i.expireTime,tokenCount:i.usageMetadata?.totalTokenCount}}}};buildCacheDeleteOp=e=>{let t=`/${e}`;if(!this.isVertex&&this.apiKey){let n=typeof this.apiKey=="function"?"ASYNC_KEY":this.apiKey;t+=`?key=${n}`}return{type:"delete",apiConfig:{name:t,headers:{"Content-Type":"application/json"}},request:{},parseResponse:()=>{}}};prepareCachedChatReq=async(e,t,n)=>{let r=e.model,s=e.modelConfig?.stream??this.config.stream,{dynamicContents:i,dynamicSystemInstruction:a}=this.extractDynamicContent(e.chatPrompt),l;if(this.endpointId?l={name:s?`/${this.endpointId}:streamGenerateContent?alt=sse`:`/${this.endpointId}:generateContent`}:l={name:s?`/models/${r}:streamGenerateContent?alt=sse`:`/models/${r}:generateContent`},!this.isVertex){let d=s?"&":"?",m=typeof this.apiKey=="function"?await this.apiKey():this.apiKey;l.name+=`${d}key=${m}`}let c={maxOutputTokens:e.modelConfig?.maxTokens??this.config.maxTokens,temperature:e.modelConfig?.temperature??this.config.temperature,...e.modelConfig?.topP!==void 0?{topP:e.modelConfig.topP}:{},topK:e.modelConfig?.topK??this.config.topK,frequencyPenalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,candidateCount:1,stopSequences:e.modelConfig?.stopSequences??this.config.stopSequences,responseMimeType:"text/plain"};Zt(r)&&(c.temperature===void 0||c.temperature<1)&&(c.temperature=1);let u=this.config.safetySettings,p={contents:i,cachedContent:n,generationConfig:c,safetySettings:u};return a&&(p.systemInstruction=a),{apiConfig:l,request:p}};extractCacheableContent(e){let t,n=[],r=-1;for(let s=e.length-1;s>=0;s--){let i=e[s];if("cache"in i&&i.cache){r=s;break}}for(let s=0;s<e.length;s++){let i=e[s];if(i.role==="system"){t={role:"user",parts:[{text:i.content}]};continue}if(r>=0&&s<=r)if(i.role==="user"){let a=[];if(typeof i.content=="string")a.push({text:i.content});else if(Array.isArray(i.content))for(let l of i.content)switch(l.type){case"text":a.push({text:l.text});break;case"image":a.push({inlineData:{mimeType:l.mimeType,data:l.image}});break;case"audio":a.push({inlineData:{mimeType:`audio/${l.format??"mp3"}`,data:l.data}});break;case"file":"fileUri"in l?a.push({fileData:{mimeType:l.mimeType,fileUri:l.fileUri}}):a.push({inlineData:{mimeType:l.mimeType,data:l.data}});break}a.length>0&&n.push({role:"user",parts:a})}else i.role==="assistant"&&i.content&&n.push({role:"model",parts:[{text:i.content}]})}return{systemInstruction:t,contents:n}}extractDynamicContent(e){let n=[];for(let r of e)if(r.role!=="system"&&!("cache"in r&&r.cache))if(r.role==="user"){let s=[];if(typeof r.content=="string")s.push({text:r.content});else if(Array.isArray(r.content)){for(let i of r.content)if(!("cache"in i&&i.cache))switch(i.type){case"text":s.push({text:i.text});break;case"image":s.push({inlineData:{mimeType:i.mimeType,data:i.image}});break;case"audio":s.push({inlineData:{mimeType:`audio/${i.format??"mp3"}`,data:i.data}});break;case"file":"fileUri"in i?s.push({fileData:{mimeType:i.mimeType,fileUri:i.fileUri}}):s.push({inlineData:{mimeType:i.mimeType,data:i.data}});break}}s.length>0&&n.push({role:"user",parts:s})}else if(r.role==="assistant"){let s=[];if(r.content&&s.push({text:r.content}),r.functionCalls)for(let i of r.functionCalls){let a;if(typeof i.function.params=="string")try{a=JSON.parse(i.function.params)}catch{a={}}else a=i.function.params??{};s.push({functionCall:{name:i.function.name,args:a}})}s.length>0&&n.push({role:"model",parts:s})}else r.role==="function"&&n.push({role:"user",parts:[{functionResponse:{name:r.functionId,response:{result:r.result}}}]});return{dynamicContents:n,dynamicSystemInstruction:void 0}}},yn=class o extends Be{static create(e){return new o(e)}constructor({apiKey:e,projectId:t,region:n,endpointId:r,config:s,options:i,models:a,modelInfo:l}){let c=t!==void 0&&n!==void 0,u,p;if(c){if(!e)throw new Error("GoogleGemini Vertex API key not set");if(typeof e!="function")throw new Error("GoogleGemini Vertex API key must be a function for token-based authentication");let x;r?x="endpoints":x="publishers/google",u=`https://${n==="global"?"aiplatform":`${n}-aiplatform`}.googleapis.com/v1/projects/${t}/locations/${n}/${x}`,p=async()=>({Authorization:`Bearer ${typeof e=="function"?await e():e}`})}else{if(!e)throw new Error("GoogleGemini AI API key not set");u="https://generativelanguage.googleapis.com/v1beta",p=async()=>({})}let d={...xi(),...s},m=new hi(d,c,r,e,i);l=[...ko,...l??[]];let g=x=>{let A=mt({model:x,modelInfo:l,models:a});return{functions:!0,streaming:!0,hasThinkingBudget:A?.supported?.thinkingBudget??!1,hasShowThoughts:A?.supported?.showThoughts??!1,structuredOutputs:A?.supported?.structuredOutputs??!1,media:{images:{supported:!0,formats:["image/jpeg","image/png","image/gif","image/webp"],maxSize:20*1024*1024,detailLevels:["high","low","auto"]},audio:{supported:!0,formats:["wav","mp3","aac","ogg"],maxDuration:9.5*60},files:{supported:!0,formats:["application/pdf","text/plain","text/csv","text/html","text/xml"],maxSize:2*1024*1024*1024,uploadMethod:"cloud"},urls:{supported:!0,webSearch:!0,contextFetching:!0}},caching:{supported:m.supportsContextCache(x),types:["persistent"]},thinking:A?.supported?.thinkingBudget??!1,multiTurn:!0}},f=a?.map(x=>{let A=x,h=A?.config;if(!h)return x;let b={};h.maxTokens!==void 0&&(b.maxTokens=h.maxTokens),h.temperature!==void 0&&(b.temperature=h.temperature),h.topP!==void 0&&(b.topP=h.topP),h.topK!==void 0&&(b.topK=h.topK),h.presencePenalty!==void 0&&(b.presencePenalty=h.presencePenalty),h.frequencyPenalty!==void 0&&(b.frequencyPenalty=h.frequencyPenalty),h.stopSequences!==void 0&&(b.stopSequences=h.stopSequences),h.endSequences!==void 0&&(b.endSequences=h.endSequences),h.stream!==void 0&&(b.stream=h.stream),h.n!==void 0&&(b.n=h.n);let T={...A};Object.keys(b).length>0&&(T.modelConfig={...A.modelConfig??{},...b});let C=h.thinking?.thinkingTokenBudget;if(typeof C=="number"){let v=d.thinkingTokenBudgetLevels,k=[["minimal",v?.minimal??200],["low",v?.low??800],["medium",v?.medium??5e3],["high",v?.high??1e4],["highest",v?.highest??24500]],R="minimal",E=Number.POSITIVE_INFINITY;for(let[S,_]of k){let L=Math.abs(C-_);L<E&&(E=L,R=S)}T.thinkingTokenBudget=R}return h.thinking?.includeThoughts!==void 0&&(T.showThoughts=!!h.thinking.includeThoughts),h.thinkingLevelMapping&&(T.thinkingLevelMapping=h.thinkingLevelMapping),h.thinkingTokenBudgetLevels&&(T.thinkingTokenBudgetLevels=h.thinkingTokenBudgetLevels),T});f?m.setModels(f):a&&m.setModels(a),super(m,{name:"GoogleGeminiAI",apiURL:u,headers:p,modelInfo:l,defaults:{model:d.model,embedModel:d.embedModel},options:i,supportFor:g,models:f??a})}};var Zp=new ot,bn=class{options;maxTokens;refillRate;currentTokens;lastRefillTime;constructor(e,t,n){this.maxTokens=e,this.refillRate=t,this.currentTokens=e,this.lastRefillTime=Date.now(),this.options=n}refillTokens(){let e=Date.now(),n=(e-this.lastRefillTime)/1e3*this.refillRate;this.currentTokens=Math.min(this.maxTokens,this.currentTokens+n),this.lastRefillTime=e}async waitUntilTokensAvailable(e){if(this.refillTokens(),this.currentTokens>=e){this.currentTokens-=e;return}return this.options?.debug&&console.log(Zp.red(`Rate limiter: Waiting for ${e-this.currentTokens} tokens`)),await new Promise(t=>setTimeout(t,100)),this.waitUntilTokensAvailable(e)}async acquire(e){await this.waitUntilTokensAvailable(e)}};var Tr=(r=>(r.Llama3_8B="llama3-8b-8192",r.Llama33_70B="llama-3.3-70b-versatile",r.Mixtral_8x7B="mixtral-8x7b-32768",r.Gemma2_9B="gemma2-9b-it",r))(Tr||{});var Eo=[{name:"gemma2-9b-it",currency:"usd",characterIsToken:!0,promptTokenCostPer1M:.2,completionTokenCostPer1M:.2},{name:"llama-3.3-70b-versatile",currency:"usd",characterIsToken:!0,promptTokenCostPer1M:.59,completionTokenCostPer1M:.79},{name:"llama3-8b-8192",currency:"usd",characterIsToken:!0,promptTokenCostPer1M:.05,completionTokenCostPer1M:.08},{name:"mixtral-8x7b-32768",currency:"usd",characterIsToken:!0,promptTokenCostPer1M:.24,completionTokenCostPer1M:.24}];var ed=()=>structuredClone({model:"llama-3.3-70b-versatile",...we()}),Tn=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("Groq API key not set");let i={...ed(),...t},a={...n,streamingUsage:!1};s=[...Eo,...s??[]];let l={functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0};super({apiKey:e,config:i,options:a,modelInfo:s,apiURL:"https://api.groq.com/openai/v1",models:r,supportFor:l}),super.setName("Groq"),this.setOptions(a)}setOptions=e=>{let t=this.newRateLimiter(e);super.setOptions({...e,rateLimiter:t})};newRateLimiter=e=>{if(e?.rateLimiter)return e.rateLimiter;let t=e?.tokensPerMinute??4800,n=new bn(t,t/60,{debug:e?.debug});return async(s,i)=>{let a=i.modelUsage?.tokens?.totalTokens||0;return await n.acquire(a),await s()}}};var Mo=[];var Po=(e=>(e.MetaLlama270BChatHF="meta-llama/Llama-2-70b-chat-hf",e))(Po||{});var yi=()=>structuredClone({model:"meta-llama/Llama-2-70b-chat-hf",...we()}),Bl=()=>structuredClone({model:"meta-llama/Llama-2-70b-chat-hf",...He()}),Ai=class{constructor(e){this.config=e}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,topP:e.topP,topK:e.topK,n:e.n,presencePenalty:e.presencePenalty}}createChatReq=e=>{let t=e.model,n=e.functions?`Functions:
167
+ `;break}default:r=JSON.stringify(n,null,2)}o(r)}};var ye={LLM_SYSTEM:"gen_ai.system",LLM_OPERATION_NAME:"gen_ai.operation.name",LLM_REQUEST_MODEL:"gen_ai.request.model",LLM_REQUEST_MAX_TOKENS:"gen_ai.request.max_tokens",LLM_REQUEST_TEMPERATURE:"gen_ai.request.temperature",LLM_REQUEST_TOP_K:"gen_ai.request.top_k",LLM_REQUEST_FREQUENCY_PENALTY:"gen_ai.request.frequency_penalty",LLM_REQUEST_PRESENCE_PENALTY:"gen_ai.request.presence_penalty",LLM_REQUEST_STOP_SEQUENCES:"gen_ai.request.stop_sequences",LLM_REQUEST_LLM_IS_STREAMING:"gen_ai.request.llm_is_streaming",LLM_REQUEST_TOP_P:"gen_ai.request.top_p",LLM_USAGE_INPUT_TOKENS:"gen_ai.usage.input_tokens",LLM_USAGE_OUTPUT_TOKENS:"gen_ai.usage.output_tokens",LLM_USAGE_TOTAL_TOKENS:"gen_ai.usage.total_tokens",LLM_USAGE_THOUGHTS_TOKENS:"gen_ai.usage.thoughts_tokens",DB_SYSTEM:"db.system",DB_TABLE:"db.table",DB_NAMESPACE:"db.namespace",DB_ID:"db.id",DB_QUERY_TEXT:"db.query.text",DB_VECTOR:"db.vector",DB_OPERATION_NAME:"db.operation.name",DB_VECTOR_QUERY_TOP_K:"db.vector.query.top_k",DB_QUERY_EMBEDDINGS:"db.query.embeddings",DB_QUERY_RESULT:"db.query.result",DB_QUERY_EMBEDDINGS_VECTOR:"db.query.embeddings.vector",DB_QUERY_RESULT_ID:"db.query.result.id",DB_QUERY_RESULT_SCORE:"db.query.result.score",DB_QUERY_RESULT_DISTANCE:"db.query.result.distance",DB_QUERY_RESULT_METADATA:"db.query.result.metadata",DB_QUERY_RESULT_VECTOR:"db.query.result.vector",DB_QUERY_RESULT_DOCUMENT:"db.query.result.document"},wt={GEN_AI_USER_MESSAGE:"gen_ai.user.message",GEN_AI_SYSTEM_MESSAGE:"gen_ai.system.message",GEN_AI_ASSISTANT_MESSAGE:"gen_ai.assistant.message",GEN_AI_TOOL_MESSAGE:"gen_ai.tool.message",GEN_AI_CHOICE:"gen_ai.choice",GEN_AI_USAGE:"gen_ai.usage"},ni=(r=>(r.COMPLETION="completion",r.CHAT="chat",r.RERANK="rerank",r.UNKNOWN="unknown",r))(ni||{}),ri=(s=>(s.WORKFLOW="workflow",s.TASK="task",s.AGENT="agent",s.TOOL="tool",s.UNKNOWN="unknown",s))(ri||{});var oi=class{buffer;doneCallback;transformFn;constructor(e,t){this.transformFn=e,this.doneCallback=t,this.buffer=t?[]:void 0}async transform(e,t){let n=this.transformFn(e);n&&(t.enqueue(n),this.buffer?.push(n))}async flush(e){await this.doneCallback?.(this.buffer??[]),e.terminate()}},go=class extends TransformStream{constructor(e,t){super(new oi(e,t))}};function fo(o,e){for(let t of e){let n=o.find(r=>r.id===t.id);n?(typeof t.function.name=="string"&&t.function.name.length>0&&(n.function.name+=t.function.name),typeof t.function.params=="string"&&t.function.params.length>0&&(n.function.params+=t.function.params),typeof t.function.params=="object"&&(n.function.params=t.function.params)):o.push(t)}}var lu=(o,e,t,n)=>{let r=n?o.filter(i=>i.role!=="system"):[...o];t({name:"ChatRequestChatPrompt",step:e,value:r})};var pu=(o,e)=>{if(!o.results)return;let t={name:"ChatResponseResults",value:o.results};e(t)};function du(o,e){let t=new Map;for(let n of o)for(let r of n.results){if(!r)continue;let s=t.get(r.index);s?(r.content&&(s.content=(s.content??"")+r.content),r.thought&&(s.thought=(s.thought??"")+r.thought),r.finishReason&&(s.finishReason=r.finishReason),r.functionCalls&&(s.functionCalls?fo(s.functionCalls,structuredClone(r.functionCalls)):s.functionCalls=structuredClone(r.functionCalls))):(s=structuredClone(r),t.set(r.index,s))}for(let n of t.values()){let r={name:"ChatResponseStreamingDoneResult",index:n.index,value:n};e(r)}}var mu=(o,e)=>{e({name:"FunctionResults",value:o})},si=(o,e,t,n)=>{n({name:"FunctionError",index:e,fixingInstructions:t,error:o})},gu=(o,e,t,n)=>{n({name:"ValidationError",index:e,fixingInstructions:t,error:o})},fu=(o,e,t,n)=>{n({name:"AssertionError",index:e,fixingInstructions:t,error:o})},hu=(o,e,t)=>{t({name:"RefusalError",index:e,error:o})};var xu=(o,e,t)=>{t({name:"EmbedRequest",embedModel:e,value:o})},Au=(o,e)=>{let t=o.slice(0,3).map(r=>({length:r.length,sample:r.slice(0,5),truncated:r.length>5})),n={name:"EmbedResponse",totalEmbeddings:o.length,value:t};e(n)},yu=(o,e,t,n)=>{n({name:"ResultPickerUsed",sampleCount:o,selectedIndex:e,latency:t})};var xo=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n);e[t]=r.length>100?r.substring(0,100):r}return e},Xt=(...o)=>{let e={};for(let t of o)t&&Object.assign(e,t);return e},ho,bu=o=>{if(ho)return ho;if(o)return ho=vd(o),ho};var vd=o=>({latencyHistogram:o.createHistogram("ax_llm_request_duration_ms",{description:"Duration of LLM requests in milliseconds",unit:"ms"}),errorCounter:o.createCounter("ax_llm_errors_total",{description:"Total number of LLM request errors"}),requestCounter:o.createCounter("ax_llm_requests_total",{description:"Total number of LLM requests"}),tokenCounter:o.createCounter("ax_llm_tokens_total",{description:"Total number of LLM tokens consumed"}),inputTokenCounter:o.createCounter("ax_llm_input_tokens_total",{description:"Total number of input/prompt tokens consumed"}),outputTokenCounter:o.createCounter("ax_llm_output_tokens_total",{description:"Total number of output/completion tokens generated"}),errorRateGauge:o.createGauge("ax_llm_error_rate",{description:"Current error rate as a percentage (0-100)"}),meanLatencyGauge:o.createGauge("ax_llm_mean_latency_ms",{description:"Mean latency of LLM requests in milliseconds",unit:"ms"}),p95LatencyGauge:o.createGauge("ax_llm_p95_latency_ms",{description:"95th percentile latency of LLM requests in milliseconds",unit:"ms"}),p99LatencyGauge:o.createGauge("ax_llm_p99_latency_ms",{description:"99th percentile latency of LLM requests in milliseconds",unit:"ms"}),streamingRequestsCounter:o.createCounter("ax_llm_streaming_requests_total",{description:"Total number of streaming LLM requests"}),functionCallsCounter:o.createCounter("ax_llm_function_calls_total",{description:"Total number of function/tool calls made"}),functionCallLatencyHistogram:o.createHistogram("ax_llm_function_call_latency_ms",{description:"Latency of function calls in milliseconds",unit:"ms"}),requestSizeHistogram:o.createHistogram("ax_llm_request_size_bytes",{description:"Size of LLM request payloads in bytes",unit:"By"}),responseSizeHistogram:o.createHistogram("ax_llm_response_size_bytes",{description:"Size of LLM response payloads in bytes",unit:"By"}),temperatureGauge:o.createGauge("ax_llm_temperature_gauge",{description:"Temperature setting used for LLM requests"}),maxTokensGauge:o.createGauge("ax_llm_max_tokens_gauge",{description:"Maximum tokens setting used for LLM requests"}),estimatedCostCounter:o.createCounter("ax_llm_estimated_cost_total",{description:"Estimated cost of LLM requests in USD",unit:"$"}),promptLengthHistogram:o.createHistogram("ax_llm_prompt_length_chars",{description:"Length of prompts in characters"}),contextWindowUsageGauge:o.createGauge("ax_llm_context_window_usage_ratio",{description:"Context window utilization ratio (0-1)"}),timeoutsCounter:o.createCounter("ax_llm_timeouts_total",{description:"Total number of timed out LLM requests"}),abortsCounter:o.createCounter("ax_llm_aborts_total",{description:"Total number of aborted LLM requests"}),thinkingBudgetUsageCounter:o.createCounter("ax_llm_thinking_budget_usage_total",{description:"Total thinking budget tokens used"}),multimodalRequestsCounter:o.createCounter("ax_llm_multimodal_requests_total",{description:"Total number of multimodal requests (with images/audio)"}),cacheReadTokensCounter:o.createCounter("ax_llm_cache_read_tokens_total",{description:"Total number of tokens read from cache (prompt caching)"}),cacheWriteTokensCounter:o.createCounter("ax_llm_cache_write_tokens_total",{description:"Total number of tokens written to cache (prompt caching)"})}),Cu=(o,e,t,n,r,s)=>{try{if(o.latencyHistogram){let i=xo({operation:e,ai_service:n,...r?{model:r}:{},...s});o.latencyHistogram.record(t,i)}}catch(i){console.warn("Failed to record latency metric:",i)}},Iu=(o,e,t,n,r,s,i,a)=>{let u={operation:e,ai_service:s,...i?{model:i}:{},...a};o.meanLatencyGauge&&o.meanLatencyGauge.record(t,u),o.p95LatencyGauge&&o.p95LatencyGauge.record(n,u),o.p99LatencyGauge&&o.p99LatencyGauge.record(r,u)},Tu=(o,e,t,n,r)=>{try{if(o.errorCounter){let s=xo({operation:e,ai_service:t,...n?{model:n}:{},...r});o.errorCounter.add(1,s)}}catch(s){console.warn("Failed to record error metric:",s)}},wu=(o,e,t,n,r,s)=>{o.errorRateGauge&&o.errorRateGauge.record(t*100,{operation:e,ai_service:n,...r?{model:r}:{},...s})},Ru=(o,e,t,n,r)=>{o.requestCounter&&o.requestCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},gr=(o,e,t,n,r,s)=>{try{let i=xo({ai_service:n,...r?{model:r}:{},...s});o.tokenCounter&&o.tokenCounter.add(t,{token_type:e,...i}),e==="input"&&o.inputTokenCounter&&o.inputTokenCounter.add(t,i),e==="output"&&o.outputTokenCounter&&o.outputTokenCounter.add(t,i)}catch(i){console.warn("Failed to record token metric:",i)}},vu=(o,e,t,n,r,s)=>{t&&o.streamingRequestsCounter&&o.streamingRequestsCounter.add(1,{operation:e,ai_service:n,...r?{model:r}:{},...s})},Su=(o,e,t,n,r,s)=>{let i={function_name:e,...n?{ai_service:n}:{},...r?{model:r}:{},...s};o.functionCallsCounter&&o.functionCallsCounter.add(1,i),t&&o.functionCallLatencyHistogram&&o.functionCallLatencyHistogram.record(t,i)},ii=(o,e,t,n,r,s)=>{o.requestSizeHistogram&&o.requestSizeHistogram.record(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},ai=(o,e,t,n,r,s)=>{o.responseSizeHistogram&&o.responseSizeHistogram.record(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},ku=(o,e,t,n,r,s)=>{let i={...n?{ai_service:n}:{},...r?{model:r}:{},...s};e!==void 0&&o.temperatureGauge&&o.temperatureGauge.record(e,i),t!==void 0&&o.maxTokensGauge&&o.maxTokensGauge.record(t,i)},ui=(o,e,t,n,r,s)=>{o.estimatedCostCounter&&o.estimatedCostCounter.add(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},Ou=(o,e,t,n,r)=>{o.promptLengthHistogram&&o.promptLengthHistogram.record(e,{ai_service:t,...n?{model:n}:{},...r})},Eu=(o,e,t,n,r)=>{o.contextWindowUsageGauge&&o.contextWindowUsageGauge.record(e,{ai_service:t,...n?{model:n}:{},...r})},Mu=(o,e,t,n,r)=>{o.timeoutsCounter&&o.timeoutsCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},Pu=(o,e,t,n,r)=>{o.abortsCounter&&o.abortsCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},Fu=(o,e,t,n,r)=>{o.thinkingBudgetUsageCounter&&o.thinkingBudgetUsageCounter.add(e,{ai_service:t,...n?{model:n}:{},...r})},_u=(o,e,t,n,r,s)=>{(e||t)&&o.multimodalRequestsCounter&&o.multimodalRequestsCounter.add(1,{ai_service:n,has_images:e.toString(),has_audio:t.toString(),...r?{model:r}:{},...s})},ci=(o,e,t,n,r,s)=>{try{if(t<=0)return;let i=xo({ai_service:n,...r?{model:r}:{},...s});e==="read"&&o.cacheReadTokensCounter&&o.cacheReadTokensCounter.add(t,i),e==="write"&&o.cacheWriteTokensCounter&&o.cacheWriteTokensCounter.add(t,i)}catch(i){console.warn("Failed to record cache token metric:",i)}};function Nu(o){try{return JSON.stringify(o,null,2)}catch{return String(o)}}function Rt(o,e={}){let t=[o];throw e.fieldPath!==void 0&&t.push(`Field: ${e.fieldPath}`),e.value!==void 0&&t.push(`Value: ${Nu(e.value)}`),e.note&&t.push(`Note: ${e.note}`),e.item!==void 0&&t.push(`Chat item: ${Nu(e.item)}`),new Error(t.join(`
168
+ `))}function mn(o){let e=n=>JSON.stringify(n,null,2);if(!o)throw new Error(`Chat request message item cannot be null or undefined, received: ${e(o)}`);let t=typeof o=="object"&&o!==null&&"role"in o&&typeof o.role=="string"?o.role:void 0;if(!t)throw new Error(`Chat request message must have a role, received: ${e(t)}`);switch(t){case"system":{let n=typeof o=="object"&&o!==null&&"content"in o&&typeof o.content=="string"?o.content:void 0;if(!n||n.trim()==="")throw new Error(`System message content cannot be empty or whitespace-only, received: ${e(n)}`);break}case"user":{let n=typeof o=="object"&&o!==null&&"content"in o?o.content:void 0;if(n===void 0)throw new Error(`User message content cannot be undefined, received: ${e(n)}`);if(typeof n=="string"){if(n.trim()==="")throw new Error(`User message content cannot be empty or whitespace-only, received: ${e(n)}`)}else if(Array.isArray(n)){if(n.length===0)throw new Error(`User message content array cannot be empty, received: ${e(n)}`);for(let r=0;r<n.length;r++){let s=n[r];if(!s||typeof s!="object")throw new Error(`User message content item at index ${r} must be an object, received: ${e(s)}`);let i=typeof s=="object"&&s!==null&&"type"in s&&typeof s.type=="string"?s.type:void 0;if(!i)throw new Error(`User message content item at index ${r} must have a type, received: ${e(i)}`);switch(i){case"text":{let a="text"in s&&typeof s.text=="string"?s.text:void 0;if(!a||a.trim()==="")throw new Error(`User message text content at index ${r} cannot be empty or whitespace-only, received: ${e(a)}`);break}case"image":{let a="image"in s&&typeof s.image=="string"?s.image:void 0,u="mimeType"in s&&typeof s.mimeType=="string"?s.mimeType:void 0;if(!a||a.trim()==="")throw new Error(`User message image content at index ${r} cannot be empty, received: ${e(a)}`);if(!u||u.trim()==="")throw new Error(`User message image content at index ${r} must have a mimeType, received: ${e(u)}`);break}case"audio":{let a="data"in s&&typeof s.data=="string"?s.data:void 0;if(!a||a.trim()==="")throw new Error(`User message audio content at index ${r} cannot be empty, received: ${e(a)}`);break}case"file":{let a="fileUri"in s&&typeof s.fileUri=="string",u="data"in s&&typeof s.data=="string";if(!a&&!u)throw new Error(`User message file content at index ${r} must have either 'data' or 'fileUri', received: ${e(s)}`);if(a&&u)throw new Error(`User message file content at index ${r} cannot have both 'data' and 'fileUri', received: ${e(s)}`);if(a){let l=s.fileUri;if(!l||l.trim()==="")throw new Error(`User message file content at index ${r} fileUri cannot be empty, received: ${e(l)}`)}if(u){let l=s.data;if(!l||l.trim()==="")throw new Error(`User message file content at index ${r} data cannot be empty, received: ${e(l)}`)}let c="mimeType"in s&&typeof s.mimeType=="string"?s.mimeType:null;if(!c||c.trim()==="")throw new Error(`User message file content at index ${r} must have a mimeType, received: ${e(c)}`);break}case"url":{let a="url"in s&&typeof s.url=="string"?s.url:void 0;if(!a||a.trim()==="")throw new Error(`User message url content at index ${r} cannot be empty, received: ${e(a)}`);break}default:throw new Error(`User message content item at index ${r} has unsupported type: ${e(i)}`)}}}else throw new Error(`User message content must be a string or array of content objects, received: ${e(n)}`);break}case"assistant":{let n=typeof o=="object"&&o!==null&&"content"in o?o.content:void 0,r=typeof o=="object"&&o!==null&&"functionCalls"in o?o.functionCalls:void 0,s=typeof o=="object"&&o!==null&&"thoughtBlocks"in o?o.thoughtBlocks:void 0,i=typeof n=="string"&&n.trim()!=="",a=Array.isArray(r)&&r.length>0,u=Array.isArray(s)&&s.length>0;if(!i&&!a&&!u&&Rt("Assistant message must include non-empty content, at least one function call, or thought blocks",{fieldPath:"content | functionCalls | thoughtBlocks",value:{content:n,functionCalls:r,thoughtBlocks:s},item:o}),n!==void 0&&typeof n!="string"&&Rt("Assistant message content must be a string",{fieldPath:"content",value:n,item:o}),r!==void 0&&!Array.isArray(r)&&Rt("Assistant message functionCalls must be an array when provided",{fieldPath:"functionCalls",value:r,item:o}),Array.isArray(r))for(let c=0;c<r.length;c++){let l=r[c];if((!l||typeof l!="object")&&Rt("functionCalls entry must be an object",{fieldPath:`functionCalls[${c}]`,value:l,item:o}),(!("id"in l)||typeof l.id!="string"||l.id.trim()==="")&&Rt("functionCalls entry must include a non-empty string id",{fieldPath:`functionCalls[${c}].id`,value:l.id,item:o}),(!("type"in l)||l.type!=="function")&&Rt("functionCalls entry must have type 'function'",{fieldPath:`functionCalls[${c}].type`,value:l.type,item:o}),!("function"in l)||!l.function)Rt("functionCalls entry must include a function object",{fieldPath:`functionCalls[${c}].function`,value:l.function,item:o});else{let p=l.function;(!("name"in p)||typeof p.name!="string"||p.name.trim()==="")&&Rt("functionCalls entry must include a non-empty function name",{fieldPath:`functionCalls[${c}].function.name`,value:p?.name,item:o}),p.params!==void 0&&typeof p.params!="string"&&typeof p.params!="object"&&Rt("functionCalls entry params must be a string or object when provided",{fieldPath:`functionCalls[${c}].function.params`,value:p.params,item:o})}}if(o.name!==void 0){let c=o.name;(typeof c!="string"||c.trim()==="")&&Rt("Assistant message name must be a non-empty string when provided",{fieldPath:"name",value:c,item:o})}break}case"function":{let n=typeof o=="object"&&o!==null&&"functionId"in o&&typeof o.functionId=="string"?o.functionId:void 0,r=typeof o=="object"&&o!==null&&"result"in o?o.result:void 0;if(!n||n.trim()==="")throw new Error(`Function message must have a non-empty functionId, received: ${e(n)}`);if(r==null)throw new Error(`Function message must have a result, received: ${e(r)}`);if(typeof r!="string")throw new Error(`Function message result must be a string, received: ${e(r)}`);o.isError!==void 0&&typeof o.isError!="boolean"&&Rt("Function message isError must be a boolean when provided",{fieldPath:"isError",value:o.isError,item:o});break}default:throw new Error(`Unsupported message role: ${e(t)}`)}}function Ao(o){let e=n=>JSON.stringify(n,null,2),t=Array.isArray(o)?o:[o];if(t.length===0)throw new Error(`Chat response results cannot be empty, received: ${e(t)}`);for(let n=0;n<t.length;n++){let r=t[n];if(!r)throw new Error(`Chat response result at index ${n} cannot be null or undefined, received: ${e(r)}`);if(typeof r.index!="number")throw new Error(`Chat response result at index ${n} must have a numeric index, received: ${e(r.index)}`);if(r.index<0)throw new Error(`Chat response result at index ${n} must have a non-negative index, received: ${e(r.index)}`);if(!r.content&&!r.thought&&(!r.thoughtBlocks||r.thoughtBlocks.length===0)&&!r.functionCalls&&!r.finishReason)throw new Error(`Chat response result at index ${n} must have at least one of: content, thought, thoughtBlocks, functionCalls, or finishReason, received: ${e({content:r.content,thought:r.thought,thoughtBlocks:r.thoughtBlocks,functionCalls:r.functionCalls,finishReason:r.finishReason})}`);if(r.content!==void 0&&typeof r.content!="string")throw new Error(`Chat response result content at index ${n} must be a string, received: ${e(r.content)}`);if(r.thought!==void 0&&typeof r.thought!="string")throw new Error(`Chat response result thought at index ${n} must be a string, received: ${e(r.thought)}`);if(r.thoughtBlocks!==void 0){if(!Array.isArray(r.thoughtBlocks))throw new Error(`Chat response result thoughtBlocks at index ${n} must be an array, received: ${e(r.thoughtBlocks)}`);for(let s=0;s<r.thoughtBlocks.length;s++){let i=r.thoughtBlocks[s];if(typeof i!="object"||i===null)throw new Error(`Chat response result thoughtBlocks[${s}] at index ${n} must be an object, received: ${e(i)}`);if(typeof i.data!="string")throw new Error(`Chat response result thoughtBlocks[${s}].data at index ${n} must be a string, received: ${e(i.data)}`);if(typeof i.encrypted!="boolean")throw new Error(`Chat response result thoughtBlocks[${s}].encrypted at index ${n} must be a boolean, received: ${e(i.encrypted)}`);if(i.signature!==void 0&&typeof i.signature!="string")throw new Error(`Chat response result thoughtBlocks[${s}].signature at index ${n} must be a string when provided, received: ${e(i.signature)}`)}}if(r.name!==void 0){if(typeof r.name!="string")throw new Error(`Chat response result name at index ${n} must be a string, received: ${e(r.name)}`);if(r.name.trim()==="")throw new Error(`Chat response result name at index ${n} cannot be empty or whitespace-only, received: ${e(r.name)}`)}if(r.annotations!==void 0){if(!Array.isArray(r.annotations))throw new Error(`Chat response result annotations at index ${n} must be an array, received: ${e(r.annotations)}`);for(let s=0;s<r.annotations.length;s++){let i=r.annotations[s];if(!i||typeof i!="object")throw new Error(`Chat response result annotation at index ${n}[${s}] must be an object, received: ${e(i)}`);if(i.type!=="url_citation")throw new Error(`Chat response result annotation at index ${n}[${s}] must have type 'url_citation', received: ${e(i.type)}`);if(!i.url_citation||typeof i.url_citation!="object")throw new Error(`Chat response result annotation at index ${n}[${s}] must have a valid url_citation object, received: ${e(i.url_citation)}`);if(typeof i.url_citation.url!="string")throw new Error(`Chat response result annotation at index ${n}[${s}] url_citation.url must be a string, received: ${e(i.url_citation.url)}`)}}if(r.id!==void 0){if(typeof r.id!="string")throw new Error(`Chat response result id at index ${n} must be a string, received: ${e(r.id)}`);if(r.id.trim()==="")throw new Error(`Chat response result id at index ${n} cannot be empty or whitespace-only, received: ${e(r.id)}`)}if(r.functionCalls!==void 0){if(!Array.isArray(r.functionCalls))throw new Error(`Chat response result functionCalls at index ${n} must be an array, received: ${e(r.functionCalls)}`);for(let s=0;s<r.functionCalls.length;s++){let i=r.functionCalls[s];if(!i)throw new Error(`Function call at index ${s} in result ${n} cannot be null or undefined, received: ${e(i)}`);if(!i.id||typeof i.id!="string"||i.id.trim()==="")throw new Error(`Function call at index ${s} in result ${n} must have a non-empty string id, received: ${e(i.id)}`);if(i.type!=="function")throw new Error(`Function call at index ${s} in result ${n} must have type 'function', received: ${e(i.type)}`);if(!i.function)throw new Error(`Function call at index ${s} in result ${n} must have a function object, received: ${e(i.function)}`);if(!i.function.name||typeof i.function.name!="string"||i.function.name.trim()==="")throw new Error(`Function call at index ${s} in result ${n} must have a non-empty function name, received: ${e(i.function.name)}`);if(i.function.params!==void 0&&typeof i.function.params!="string"&&typeof i.function.params!="object")throw new Error(`Function call params at index ${s} in result ${n} must be a string or object, received: ${e(i.function.params)}`)}}if(r.finishReason!==void 0){let s=["stop","length","function_call","content_filter","error"];if(!s.includes(r.finishReason))throw new Error(`Chat response result finishReason at index ${n} must be one of: ${s.join(", ")}, received: ${e(r.finishReason)}`)}}}function yo(o){if(!o||!Array.isArray(o))return 0;let e=0;for(let t of o)switch(t.role){case"system":case"assistant":typeof t.content=="string"&&(e+=t.content.length);break;case"user":if(typeof t.content=="string"){e+=t.content.length;break}if(Array.isArray(t.content))for(let n of t.content)n.type==="text"&&(e+=n.text.length);break;case"function":typeof t.result=="string"&&(e+=t.result.length);break}return e}var li=new Map;function Sd(o){return`${o.providerName}:${o.contentHash}`}function kd(o,e){e.type==="text"?o.update(`text:${e.text}`):e.type==="image"?o.update(`image:${e.mimeType}:${e.image.slice(0,100)}`):e.type==="audio"?o.update(`audio:${e.format}:${e.data.slice(0,100)}`):e.type==="file"&&("fileUri"in e?o.update(`file:${e.mimeType}:${e.fileUri}`):o.update(`file:${e.mimeType}:${e.data.slice(0,100)}`))}function Od(o){let e=pt("sha256"),t=-1;for(let n=o.length-1;n>=0;n--){let r=o[n];if("cache"in r&&r.cache){t=n;break}}for(let n=0;n<o.length;n++){let r=o[n];if(r.role==="system"){e.update(`system:${r.content}`);continue}if(t>=0&&n<=t)if(r.role==="user"){if(typeof r.content=="string")e.update(`user:${r.content}`);else if(Array.isArray(r.content))for(let s of r.content)kd(e,s)}else r.role==="assistant"&&r.content&&e.update(`assistant:${r.content}`)}return e.digest("hex")}var ve=()=>structuredClone({temperature:0}),He=()=>structuredClone({temperature:.4,frequencyPenalty:.2}),je=class{constructor(e,{name:t,apiURL:n,headers:r,modelInfo:s,defaults:i,options:a={},supportFor:u,models:c}){this.aiImpl=e;this.name=t,this.apiURL=n||"",this.headers=r,this.supportFor=u,this.tracer=a.tracer??ge.tracer,this.meter=a.meter??ge.meter,this.modelInfo=s,this.models=c,this.id=Ze();let l=this.getModel(i.model)??i.model,p=this.getEmbedModel(i.embedModel)??i.embedModel;if(this.defaults={model:l,embedModel:p},!i.model||typeof i.model!="string"||i.model==="")throw new Error("No model defined");this.setOptions(a),c&&Ed(c)}#e=!1;#t=!1;rt;fetch;tracer;meter;timeout;excludeContentFromTrace;models;abortSignal;logger=ge.logger??uu;corsProxy;retry;customLabels;modelInfo;modelUsage;embedModelUsage;defaults;lastUsedModelConfig;lastUsedChatModel;lastUsedEmbedModel;apiURL;name;id;headers;supportFor;metrics={latency:{chat:{mean:0,p95:0,p99:0,samples:[]},embed:{mean:0,p95:0,p99:0,samples:[]}},errors:{chat:{count:0,rate:0,total:0},embed:{count:0,rate:0,total:0}}};getMetricsInstruments(){return bu(this.meter)}setName(e){this.name=e}getId(){return this.id}setAPIURL(e){this.apiURL=e}setHeaders(e){this.headers=e}get debug(){return this.#e}setOptions(e){this.#e=e.debug??ge.debug??!1,this.#t=e.verbose??!1,this.rt=e.rateLimiter,this.fetch=e.fetch,this.timeout=e.timeout,this.tracer=e.tracer??ge.tracer,this.meter=e.meter??ge.meter,this.excludeContentFromTrace=e.excludeContentFromTrace,this.abortSignal=e.abortSignal,this.logger=e.logger??ge.logger??this.logger,this.corsProxy=e.corsProxy,this.retry=e.retry,this.customLabels=e.customLabels}getOptions(){return{debug:this.#e,verbose:this.#t,rateLimiter:this.rt,fetch:this.fetch,tracer:this.tracer,meter:this.meter,timeout:this.timeout,excludeContentFromTrace:this.excludeContentFromTrace,abortSignal:this.abortSignal,logger:this.logger,corsProxy:this.corsProxy,retry:this.retry,customLabels:this.customLabels}}getLogger(){return this.logger}getMergedCustomLabels(e){return Xt(ge.customLabels,this.customLabels,e)}getModelList(){let e=[];for(let t of this.models??[])t.isInternal||("model"in t&&t.model&&e.push({key:t.key,description:t.description,model:t.model}),"embedModel"in t&&t.embedModel&&e.push({key:t.key,description:t.description,embedModel:t.embedModel}));return e}getName(){return this.name}getFeatures(e){return typeof this.supportFor=="function"?this.supportFor(e??this.defaults.model):this.supportFor}getLastUsedChatModel(){return this.lastUsedChatModel}getLastUsedEmbedModel(){return this.lastUsedEmbedModel}getLastUsedModelConfig(){return this.lastUsedModelConfig}calculatePercentile(e,t){if(e.length===0)return 0;let n=[...e].sort((s,i)=>s-i),r=Math.ceil(t/100*n.length)-1;return n[r]??0}updateLatencyMetrics(e,t,n){let r=this.metrics.latency[e];r.samples.push(t),r.samples.length>1e3&&r.samples.shift(),r.mean=r.samples.reduce((i,a)=>i+a,0)/r.samples.length,r.p95=this.calculatePercentile(r.samples,95),r.p99=this.calculatePercentile(r.samples,99);let s=this.getMetricsInstruments();if(s){let i=e==="chat"?this.lastUsedChatModel:this.lastUsedEmbedModel,a=this.getMergedCustomLabels(n);Cu(s,e,t,this.name,i,a),Iu(s,e,r.mean,r.p95,r.p99,this.name,i,a)}}updateErrorMetrics(e,t,n){let r=this.metrics.errors[e];r.total++,t&&r.count++,r.rate=r.count/r.total;let s=this.getMetricsInstruments();if(s){let i=e==="chat"?this.lastUsedChatModel:this.lastUsedEmbedModel,a=this.getMergedCustomLabels(n);Ru(s,e,this.name,i,a),t&&Tu(s,e,this.name,i,a),wu(s,e,r.rate,this.name,i,a)}}recordTokenUsage(e,t){let n=this.getMetricsInstruments();if(n&&e?.tokens){let{promptTokens:r,completionTokens:s,totalTokens:i,thoughtsTokens:a,cacheReadTokens:u,cacheCreationTokens:c}=e.tokens,l=this.getMergedCustomLabels(t);r&&gr(n,"input",r,this.name,e.model,l),s&&gr(n,"output",s,this.name,e.model,l),i&&gr(n,"total",i,this.name,e.model,l),a&&gr(n,"thoughts",a,this.name,e.model,l),u&&ci(n,"read",u,this.name,e.model,l),c&&ci(n,"write",c,this.name,e.model,l)}}calculateRequestSize(e){try{return new TextEncoder().encode(JSON.stringify(e)).length}catch{return 0}}calculateResponseSize(e){try{return new TextEncoder().encode(JSON.stringify(e)).length}catch{return 0}}detectMultimodalContent(e){let t=!1,n=!1;if(e.chatPrompt&&Array.isArray(e.chatPrompt)){for(let r of e.chatPrompt)if(r.role==="user"&&Array.isArray(r.content))for(let s of r.content)s.type==="image"?t=!0:s.type==="audio"&&(n=!0)}return{hasImages:t,hasAudio:n}}calculateContextWindowUsage(e,t){if(!t?.tokens?.promptTokens)return 0;let n=this.modelInfo.find(r=>r.name===e);return n?.contextWindow?t.tokens.promptTokens/n.contextWindow:0}estimateCost(e,t){if(!t?.tokens)return 0;let n=this.modelInfo.find(u=>u.name===e);if(!n||!n.promptTokenCostPer1M&&!n.completionTokenCostPer1M)return 0;let{promptTokens:r=0,completionTokens:s=0}=t.tokens,i=n.promptTokenCostPer1M||0,a=n.completionTokenCostPer1M||0;return r*i/1e6+s*a/1e6}estimateCostByName(e,t){if(!t?.tokens)return 0;let n=this.modelInfo.find(u=>u.name===e);if(!n||!n.promptTokenCostPer1M&&!n.completionTokenCostPer1M)return 0;let{promptTokens:r=0,completionTokens:s=0}=t.tokens,i=n.promptTokenCostPer1M||0,a=n.completionTokenCostPer1M||0;return r*i/1e6+s*a/1e6}recordFunctionCallMetrics(e,t,n){let r=this.getMetricsInstruments();if(!(!r||!e))for(let s of e)s&&typeof s=="object"&&"function"in s&&s.function&&typeof s.function=="object"&&"name"in s.function&&Su(r,s.function.name,void 0,this.name,t,this.getMergedCustomLabels(n))}recordTimeoutMetric(e,t){let n=this.getMetricsInstruments();if(n){let r=e==="chat"?this.lastUsedChatModel:this.lastUsedEmbedModel;Mu(n,e,this.name,r,this.getMergedCustomLabels(t))}}recordAbortMetric(e,t){let n=this.getMetricsInstruments();if(n){let r=e==="chat"?this.lastUsedChatModel:this.lastUsedEmbedModel;Pu(n,e,this.name,r,this.getMergedCustomLabels(t))}}recordChatMetrics(e,t,n){let r=this.getMetricsInstruments();if(!r)return;let s=this.lastUsedChatModel,i=this.lastUsedModelConfig,a=this.getMergedCustomLabels(t?.customLabels),u=i?.stream??!1;vu(r,"chat",u,this.name,s,a);let{hasImages:c,hasAudio:l}=this.detectMultimodalContent(e);_u(r,c,l,this.name,s,a);let p=yo(e.chatPrompt);Ou(r,p,this.name,s,a),ku(r,i?.temperature,i?.maxTokens,this.name,s,a),t?.thinkingTokenBudget&&this.modelUsage?.tokens?.thoughtsTokens&&Fu(r,this.modelUsage.tokens.thoughtsTokens,this.name,s,a);let d=this.calculateRequestSize(e);if(ii(r,"chat",d,this.name,s,a),n&&!u){let m=n,g=this.calculateResponseSize(m);if(ai(r,"chat",g,this.name,s,a),m.results)for(let A of m.results)A.functionCalls&&this.recordFunctionCallMetrics(A.functionCalls,this.lastUsedChatModel,a);let f=this.calculateContextWindowUsage(this.lastUsedChatModel,m.modelUsage);f>0&&Eu(r,f,this.name,s,a);let x=this.estimateCost(this.lastUsedChatModel,m.modelUsage);x>0&&ui(r,"chat",x,this.name,s,a)}}recordEmbedMetrics(e,t,n){let r=this.getMetricsInstruments();if(!r)return;let s=this.lastUsedEmbedModel,i=this.getMergedCustomLabels(n?.customLabels),a=this.calculateRequestSize(e);ii(r,"embed",a,this.name,s,i);let u=this.calculateResponseSize(t);ai(r,"embed",u,this.name,s,i);let c=this.estimateCostByName(s,t.modelUsage);c>0&&ui(r,"embed",c,this.name,s,i)}getMetrics(){return structuredClone(this.metrics)}async chat(e,t){let n=performance.now(),r=!1,s,i=this.getModelByKey(e.model),a=i?i.thinkingTokenBudget:void 0,u={...i?{thinkingTokenBudget:a,showThoughts:i.showThoughts,stream:i.stream,debug:i.debug,useExpensiveModel:i.useExpensiveModel}:void 0,...Object.fromEntries(Object.entries(t??{}).filter(([,c])=>c!==void 0))};try{return s=await this._chat1(e,u),s}catch(c){throw r=!0,c instanceof Error&&(c.message.includes("timeout")||c.name==="TimeoutError"?this.recordTimeoutMetric("chat",u?.customLabels):(c.message.includes("abort")||c.name==="AbortError")&&this.recordAbortMetric("chat",u?.customLabels)),c}finally{let c=performance.now()-n;this.updateLatencyMetrics("chat",c,u?.customLabels),this.updateErrorMetrics("chat",r,u?.customLabels),r||this.recordChatMetrics(e,u,s)}}async _chat1(e,t){let n=this.getModel(e.model)??e.model??this.defaults.model;if(Array.isArray(e.chatPrompt))for(let c of e.chatPrompt)mn(c);let r=this.getModelByKey(e.model),s={...this.aiImpl.getModelConfig(),...r?r.modelConfig:void 0,...e.modelConfig},i=this.modelInfo.find(c=>c.name===n);if(i?.notSupported?.temperature&&"temperature"in s&&delete s.temperature,i?.notSupported?.topP&&"topP"in s&&delete s.topP,t?.thinkingTokenBudget&&!this.getFeatures(n).hasThinkingBudget)throw new Error(`Model ${n} does not support thinkingTokenBudget.`);if(t?.showThoughts&&!this.getFeatures(n).hasShowThoughts)throw new Error(`Model ${n} does not support showThoughts.`);if(this.modelInfo.find(c=>c.name===n)?.isExpensive&&t?.useExpensiveModel!=="yes")throw new Error(`Model ${n} is marked as expensive and requires explicit confirmation. Set useExpensiveModel: "yes" to proceed.`);return s.stream=(t?.stream!==void 0?t.stream:s.stream)??!0,this.getFeatures(n).streaming||(s.stream=!1),this.tracer?await this.tracer.startActiveSpan("AI Chat Request",{kind:gn.SpanKind.SERVER,attributes:{[ye.LLM_SYSTEM]:this.name,[ye.LLM_OPERATION_NAME]:"chat",[ye.LLM_REQUEST_MODEL]:n,[ye.LLM_REQUEST_MAX_TOKENS]:s.maxTokens??"Not set",[ye.LLM_REQUEST_TEMPERATURE]:s.temperature,[ye.LLM_REQUEST_TOP_P]:s.topP??"Not set",[ye.LLM_REQUEST_TOP_K]:s.topK??"Not set",[ye.LLM_REQUEST_FREQUENCY_PENALTY]:s.frequencyPenalty??"Not set",[ye.LLM_REQUEST_PRESENCE_PENALTY]:s.presencePenalty??"Not set",[ye.LLM_REQUEST_STOP_SEQUENCES]:s.stopSequences?.join(", ")??"Not set",[ye.LLM_REQUEST_LLM_IS_STREAMING]:s.stream??"Not set"}},t?.traceContext??gn.context.active(),async c=>await this._chat2(n,s,e,t,c)):await this._chat2(n,s,e,t)}cleanupFunctionSchema(e){let t={...e};if(t.parameters){let n={...t.parameters};Array.isArray(n.required)&&n.required.length===0&&delete n.required,n.properties&&Object.keys(n.properties).length===0&&delete n.properties,Object.keys(n).length===0||Object.keys(n).length===1&&n.type==="object"?delete t.parameters:t.parameters=n}return t}async _chat2(e,t,n,r,s){if(!this.aiImpl.createChatReq)throw new Error("createChatReq not implemented");let i=r?.debug??this.#e,a=r?.verbose??this.#t,u;n.functions&&n.functions.length>0&&(u=n.functions.map(y=>this.cleanupFunctionSchema(y)));let c={...n,model:e,functions:u,modelConfig:t};this.lastUsedChatModel=e,this.lastUsedModelConfig=t,i&&lu(c.chatPrompt,r?.stepIndex??0,r?.logger??this.logger,r?.debugHideSystemPrompt);let l=this.getFeatures(e).functions,p=r?.functionCallMode??"auto",m=p==="prompt"||p==="auto"&&!l?{...c,chatPrompt:c.chatPrompt.map(y=>{if(y.role==="assistant"){let{content:C,name:I,cache:v}=y;return{role:"assistant",content:C,name:I,cache:v}}return y.role==="function"?{role:"user",content:y.result}:y}),functions:[]}:c,g=await this.handleContextCaching(e,m,r,s),f=async()=>{if(g?.preparedRequest){let{apiConfig:v,request:O}=g.preparedRequest;return s?.isRecording()&&Lu(n,s,this.excludeContentFromTrace),await tt({name:v.name,url:this.apiURL,localCall:v.localCall,headers:await this.buildHeaders(v.headers),stream:t.stream,timeout:this.timeout,verbose:a,fetch:this.fetch,span:s,abortSignal:r?.abortSignal??this.abortSignal,corsProxy:this.corsProxy,retry:r?.retry??this.retry},O)}let[y,C]=await this.aiImpl.createChatReq(m,r);return s?.isRecording()&&Lu(n,s,this.excludeContentFromTrace),await tt({name:y.name,url:this.apiURL,localCall:y.localCall,headers:await this.buildHeaders(y.headers),stream:t.stream,timeout:this.timeout,verbose:a,fetch:this.fetch,span:s,abortSignal:r?.abortSignal??this.abortSignal,corsProxy:this.corsProxy,retry:r?.retry??this.retry},C)},x=r?.rateLimiter??this.rt,A=x?await x(f,{modelUsage:this.modelUsage}):await f();if(t.stream){if(!this.aiImpl.createChatStreamResp)throw new Error("createChatStreamResp not implemented");let y=this.aiImpl.createChatStreamResp.bind(this),C=R=>E=>{let S=y(E,R);if(S.sessionId=r?.sessionId,!S.modelUsage){let _=this.aiImpl.getTokenUsage();_&&(S.modelUsage={ai:this.name,model:e,tokens:_})}return this.modelUsage=S.modelUsage,this.recordTokenUsage(S.modelUsage,r?.customLabels),s?.isRecording()&&$u(S,s,this.excludeContentFromTrace),S},I=async R=>{s?.isRecording()&&s.end(),i&&du(R,r?.logger??this.logger)};if(typeof window<"u"){let R=A,E={},S=[],_=r?.abortSignal??this.abortSignal;return new ReadableStream({start:$=>{let M=R.getReader(),F=()=>{try{M.cancel().catch(()=>{})}catch{}try{this.recordAbortMetric("chat",r?.customLabels)}catch{}try{s?.isRecording()&&s.end()}catch{}try{$.error(new DOMException("Aborted","AbortError"))}catch{$.error(new Error("Aborted"))}};if(_){if(_.aborted){F();return}_.addEventListener("abort",F,{once:!0})}async function N(){try{for(;;){let{done:G,value:W}=await M.read();if(G){I&&await I(S),$.close();break}let U=C(E)(W);U&&(S.push(U),$.enqueue(U))}}catch(G){if($.error(G),s?.isRecording())try{s.end()}catch{}}finally{if(M.releaseLock(),_)try{_.removeEventListener("abort",F)}catch{}}}N()}})}return A.pipeThrough(new go(C({}),I))}if(!this.aiImpl.createChatResp)throw new Error("createChatResp not implemented");let h=this.aiImpl.createChatResp(A);if(h.sessionId=r?.sessionId,!h.modelUsage){let y=this.aiImpl.getTokenUsage();y&&(h.modelUsage={ai:this.name,model:e,tokens:y})}return h.modelUsage&&(this.modelUsage=h.modelUsage,this.recordTokenUsage(h.modelUsage,r?.customLabels)),s?.isRecording()&&($u(h,s,this.excludeContentFromTrace),s.end()),i&&pu(h,r?.logger??this.logger),h}async embed(e,t){let n=performance.now(),r=!1,s,i=this.getModelByKey(e.embedModel),a={...i?{thinkingTokenBudget:i.thinkingTokenBudget,showThoughts:i.showThoughts,stream:i.stream,debug:i.debug,useExpensiveModel:i.useExpensiveModel}:void 0,...t};try{return s=await this._embed1(e,a),s}catch(u){throw r=!0,u instanceof Error&&(u.message.includes("timeout")||u.name==="TimeoutError"?this.recordTimeoutMetric("embed",a?.customLabels):(u.message.includes("abort")||u.name==="AbortError")&&this.recordAbortMetric("embed",a?.customLabels)),u}finally{let u=performance.now()-n;this.updateLatencyMetrics("embed",u,a?.customLabels),this.updateErrorMetrics("embed",r,a?.customLabels),!r&&s&&this.recordEmbedMetrics(e,s,a)}}async _embed1(e,t){let n=this.getEmbedModel(e.embedModel)??e.embedModel??this.defaults.embedModel;if(!n)throw new Error("No embed model defined");return this.tracer?await this.tracer.startActiveSpan("AI Embed Request",{kind:gn.SpanKind.SERVER,attributes:{[ye.LLM_SYSTEM]:this.name,[ye.LLM_OPERATION_NAME]:"embeddings",[ye.LLM_REQUEST_MODEL]:n}},t?.traceContext??gn.context.active(),async r=>await this._embed2(n,e,t,r)):await this._embed2(n,e,t)}async _embed2(e,t,n,r){if(!this.aiImpl.createEmbedReq)throw new Error("createEmbedReq not implemented");if(!this.aiImpl.createEmbedResp)throw new Error("createEmbedResp not implemented");let s=this.aiImpl.createEmbedReq.bind(this.aiImpl),i=n?.debug??this.#e,a=n?.verbose??this.#t,u={...t,embedModel:e};this.lastUsedEmbedModel=e,i&&xu(u.texts??[],e,n?.logger??this.logger);let c=async()=>{let[m,g]=await s(u);return await tt({name:m.name,url:this.apiURL,localCall:m.localCall,headers:await this.buildHeaders(m.headers),verbose:a,fetch:this.fetch,timeout:this.timeout,span:r,abortSignal:n?.abortSignal??this.abortSignal,corsProxy:this.corsProxy,retry:n?.retry??this.retry},g)},l=n?.rateLimiter??this.rt,p=l?await l(c,{modelUsage:this.embedModelUsage}):await c(),d=this.aiImpl.createEmbedResp?.(p);if(d.sessionId=n?.sessionId,!d.modelUsage){let m=this.aiImpl.getTokenUsage();m&&(d.modelUsage={ai:this.name,model:e,tokens:m})}return this.embedModelUsage=d.modelUsage,this.recordTokenUsage(d.modelUsage,n?.customLabels),r?.isRecording()&&d.modelUsage?.tokens&&r.addEvent(wt.GEN_AI_USAGE,{[ye.LLM_USAGE_INPUT_TOKENS]:d.modelUsage.tokens.promptTokens,[ye.LLM_USAGE_OUTPUT_TOKENS]:d.modelUsage.tokens.completionTokens??0,[ye.LLM_USAGE_TOTAL_TOKENS]:d.modelUsage.tokens.totalTokens}),i&&Au(d.embeddings,n?.logger??this.logger),r?.end(),d}async buildHeaders(e={}){return{...e,...await this.headers()}}getModelByKey(e){return e?this.models?.find(n=>n.key===e):void 0}getModel(e){let t=this.getModelByKey(e);return t&&"model"in t?t.model:void 0}getEmbedModel(e){let t=this.getModelByKey(e);return t&&"embedModel"in t?t.embedModel:void 0}async handleContextCaching(e,t,n,r){let s=n?.contextCache;if(!s)return null;let i=this.aiImpl.supportsContextCache?.(e)??!1,a=this.aiImpl.supportsImplicitCaching?.(e)??!1;if(!i&&!a)throw new Error(`Context caching is not supported by this provider/model (${this.getName()}/${e}). Remove the contextCache option or use a provider that supports caching.`);if(!i)return null;let u=s.ttlSeconds??3600,c=s.refreshWindowSeconds??300,l=s.minTokens??2048;if(s.name)return this.useCacheByName(e,t,s.name,n,r);let p=Od(t.chatPrompt);if(!p||p===pt("sha256").digest("hex"))return null;let d={providerName:this.getName(),contentHash:p},m=Sd(d),g=Date.now(),f=s.registry,x=f?await f.get(m):li.get(m);if(x&&x.expiresAt>g){if(x.expiresAt-g<c*1e3&&this.aiImpl.buildCacheUpdateTTLOp){await this.executeCacheOperation(this.aiImpl.buildCacheUpdateTTLOp(x.cacheName,u),n,r);let C={cacheName:x.cacheName,expiresAt:g+u*1e3,tokenCount:x.tokenCount};f?await f.set(m,C):li.set(m,{...C,contentHash:p,lastTouchedAt:g})}return this.useCacheByName(e,t,x.cacheName,n,r)}if(this.estimateCacheableTokens(t.chatPrompt)<l)return null;let h=this.aiImpl.buildCacheCreateOp?.(t,n);if(h){let y=await this.executeCacheOperation(h,n,r);if(y){let C={cacheName:y.name,expiresAt:new Date(y.expiresAt).getTime(),tokenCount:y.tokenCount};return f?await f.set(m,C):li.set(m,{...C,contentHash:p,lastTouchedAt:g}),this.useCacheByName(e,t,y.name,n,r)}}return null}async useCacheByName(e,t,n,r,s){if(this.aiImpl.prepareCachedChatReq){let i=await this.aiImpl.prepareCachedChatReq(t,r??{},n);return{preparedRequest:{apiConfig:i.apiConfig,request:i.request}}}return null}async executeCacheOperation(e,t,n){let r=t?.verbose??this.#t;try{n?.addEvent("context_cache.operation",{type:e.type,endpoint:e.apiConfig.name});let s=await tt({name:e.apiConfig.name,url:this.apiURL,localCall:e.apiConfig.localCall,headers:await this.buildHeaders(e.apiConfig.headers),stream:!1,timeout:this.timeout,verbose:r,fetch:this.fetch,span:n,abortSignal:t?.abortSignal??this.abortSignal,corsProxy:this.corsProxy,retry:t?.retry??this.retry},e.request);return e.parseResponse(s)}catch(s){n?.addEvent("context_cache.error",{type:e.type,error:s instanceof Error?s.message:String(s)});return}}estimateCacheableTokens(e){let t=0;for(let n of e){if(n.role==="system"){t+=n.content.length;continue}if("cache"in n&&n.cache)if(n.role==="user"){if(typeof n.content=="string")t+=n.content.length;else if(Array.isArray(n.content))for(let r of n.content)"cache"in r&&r.cache&&(r.type==="text"?t+=r.text.length:r.type==="image"?t+=1e3:r.type==="audio"?t+=2e3:r.type==="file"&&(t+=500))}else n.role==="assistant"&&n.content&&(t+=n.content.length)}return Math.ceil(t/4)}};function Lu(o,e,t){let n=[];if(o.chatPrompt&&Array.isArray(o.chatPrompt)&&o.chatPrompt.length>0)for(let s of o.chatPrompt)switch(s.role){case"system":if(s.content){let i={};t||(i.content=s.content),e.addEvent(wt.GEN_AI_SYSTEM_MESSAGE,i)}break;case"user":if(typeof s.content=="string")n.push(s.content);else if(Array.isArray(s.content))for(let i of s.content)i.type==="text"&&n.push(i.text);break;case"assistant":{let i=s.functionCalls?.map(a=>({id:a.id,type:a.type,function:a.function.name,arguments:a.function.params}));if(i&&i.length>0){let a={function_calls:JSON.stringify(i,null,2)};!t&&s.content&&(a.content=s.content),e.addEvent(wt.GEN_AI_ASSISTANT_MESSAGE,a)}else if(s.content){let a={};t||(a.content=s.content),e.addEvent(wt.GEN_AI_ASSISTANT_MESSAGE,a)}break}case"function":{let i={id:s.functionId};t||(i.content=s.result),e.addEvent(wt.GEN_AI_TOOL_MESSAGE,i);break}}let r={};t||(r.content=n.join(`
169
+ `)),e.addEvent(wt.GEN_AI_USER_MESSAGE,r)}function $u(o,e,t){if(o.modelUsage?.tokens){let n=o.modelUsage.tokens.thoughtsTokens?{[ye.LLM_USAGE_THOUGHTS_TOKENS]:o.modelUsage.tokens.thoughtsTokens}:{};e.addEvent(wt.GEN_AI_USAGE,{[ye.LLM_USAGE_INPUT_TOKENS]:o.modelUsage.tokens.promptTokens,[ye.LLM_USAGE_OUTPUT_TOKENS]:o.modelUsage.tokens.completionTokens??0,[ye.LLM_USAGE_TOTAL_TOKENS]:o.modelUsage.tokens.totalTokens,...n})}if(o.results)for(let n=0;n<o.results.length;n++){let r=o.results[n];if(!r||!r.content&&!r.thought&&!r.functionCalls?.length&&!r.finishReason)continue;let s=r.functionCalls?.map(a=>({id:a.id,type:a.type,function:a.function.name,arguments:a.function.params})),i={};s&&s.length>0?(t||(i.content=r.content),i.tool_calls=s):t||(i.content=r.content??""),e.addEvent(wt.GEN_AI_CHOICE,{finish_reason:r.finishReason,index:n,message:JSON.stringify(i,null,2)})}}function pi(o){let e=0;for(let t of o){if(!t||typeof t!="object")throw new Error(`AxMessage array validation failed: Item at index ${e} is not a valid message object`);if(t.role!=="user"&&t.role!=="assistant")throw new Error(`AxMessage array validation failed: Item at index ${e} has invalid role: ${t.role}`);e++}}function Ed(o){let e=new Set;for(let t of o){if(e.has(t.key))throw new Error(`Duplicate model key detected: "${t.key}". Each model key must be unique.`);e.add(t.key)}}var fr=(x=>(x.Claude46Opus="claude-opus-4-6",x.Claude46Sonnet="claude-sonnet-4-6",x.Claude45Opus="claude-opus-4-5-20251101",x.Claude41Opus="claude-opus-4-1-20250805",x.Claude4Opus="claude-opus-4-20250514",x.Claude4Sonnet="claude-sonnet-4-20250514",x.Claude45Sonnet="claude-sonnet-4-5-20250929",x.Claude45Haiku="claude-haiku-4-5",x.Claude37Sonnet="claude-3-7-sonnet-latest",x.Claude35Sonnet="claude-3-5-sonnet-latest",x.Claude35Haiku="claude-3-5-haiku-latest",x.Claude3Opus="claude-3-opus-latest",x.Claude3Sonnet="claude-3-sonnet-20240229",x.Claude3Haiku="claude-3-haiku-20240307",x.Claude21="claude-2.1",x.ClaudeInstant12="claude-instant-1.2",x))(fr||{}),hr=(g=>(g.Claude46Opus="claude-opus-4-6",g.Claude46Sonnet="claude-sonnet-4-6",g.Claude45Opus="claude-opus-4-5@20251101",g.Claude41Opus="claude-opus-4-1@20250805",g.Claude4Opus="claude-opus-4@20250514",g.Claude45Sonnet="claude-sonnet-4-5@20250929",g.Claude4Sonnet="claude-sonnet-4@20250514",g.Claude37Sonnet="claude-3-7-sonnet@20250219",g.Claude35SonnetV2="claude-3-5-sonnet-v2@20241022",g.Claude45Haiku="claude-haiku-4-5@20251001",g.Claude35Haiku="claude-3-5-haiku@20241022",g.Claude35Sonnet="claude-3-5-sonnet@20240620",g.Claude3Opus="claude-3-opus@20240229",g.Claude3Haiku="claude-3-haiku@20240307",g))(hr||{});var xr=[{name:"claude-opus-4-6",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:25,maxTokens:128e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-6",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:25,maxTokens:128e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-6",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-6",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-5-20251101",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:25,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-5@20251101",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:25,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-5-20250929",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:2e5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-5@20250929",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:2e5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-haiku-4-5",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:5,maxTokens:2e5,supported:{thinkingBudget:!0,showThoughts:!0}},{name:"claude-haiku-4-5@20251001",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:5,maxTokens:2e5,supported:{thinkingBudget:!0,showThoughts:!0}},{name:"claude-opus-4-1-20250805",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:32e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-1@20250805",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:32e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4-20250514",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:32e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-opus-4@20250514",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:32e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4-20250514",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-sonnet-4@20250514",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-3-7-sonnet-latest",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-3-7-sonnet@20250219",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:64e3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-3-5-sonnet-latest",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:8192,supported:{structuredOutputs:!0}},{name:"claude-3-5-sonnet@20240620",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:8192,supported:{structuredOutputs:!0}},{name:"claude-3-5-sonnet-v2@20241022",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:8192,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"claude-3-5-haiku-latest",currency:"usd",promptTokenCostPer1M:.8,completionTokenCostPer1M:4,maxTokens:8192},{name:"claude-3-5-haiku@20241022",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:5,maxTokens:8192},{name:"claude-3-opus-latest",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:4096,supported:{structuredOutputs:!0}},{name:"claude-3-opus@20240229",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:75,maxTokens:4096,supported:{structuredOutputs:!0}},{name:"claude-3-sonnet-20240229",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15,maxTokens:4096,supported:{structuredOutputs:!0}},{name:"claude-3-haiku-20240307",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:1.25,maxTokens:4096},{name:"claude-3-haiku@20240307",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:1.25,maxTokens:4096},{name:"claude-2.1",currency:"usd",promptTokenCostPer1M:8,completionTokenCostPer1M:25,maxTokens:4096},{name:"claude-instant-1.2",currency:"usd",promptTokenCostPer1M:.8,completionTokenCostPer1M:2.24,maxTokens:4096}];var Gt=o=>{if(!o||typeof o!="object")return o;let e={...o};if(e.type==="object"||Array.isArray(e.type)&&e.type.includes("object")){if(!e.properties||Object.keys(e.properties).length===0)return e;e.additionalProperties===void 0&&(e.additionalProperties=!1)}return delete e.optional,e.properties&&typeof e.properties=="object"&&(e.properties=Object.fromEntries(Object.entries(e.properties).map(([n,r])=>[n,Gt(r)]))),e.items&&(e.items=Gt(e.items)),Array.isArray(e.anyOf)&&(e.anyOf=e.anyOf.map(n=>Gt(n))),Array.isArray(e.allOf)&&(e.allOf=e.allOf.map(n=>Gt(n))),Array.isArray(e.oneOf)&&(e.oneOf=e.oneOf.map(n=>Gt(n))),e},mi=()=>structuredClone({model:"claude-3-7-sonnet-latest",maxTokens:4e4,thinkingTokenBudgetLevels:{minimal:1024,low:5e3,medium:1e4,high:2e4,highest:32e3},effortLevelMapping:{minimal:"low",low:"low",medium:"medium",high:"high",highest:"max"},...ve()}),Uu=()=>structuredClone({model:"claude-3-7-sonnet@20250219",maxTokens:4e4,thinkingTokenBudgetLevels:{minimal:1024,low:5e3,medium:1e4,high:2e4,highest:32e3},effortLevelMapping:{minimal:"low",low:"low",medium:"medium",high:"high",highest:"max"},...ve()}),di=class{constructor(e,t){this.config=e;this.isVertex=t}tokensUsed;currentPromptConfig;usedStructuredOutput=!1;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens??4096,temperature:e.temperature,topP:e.topP,topK:e.topK,stream:e.stream,stopSequences:e.stopSequences,endSequences:e.endSequences,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,n:e.n}}createChatReq=async(e,t)=>{this.currentPromptConfig=t;let n=e.model,r=e.modelConfig?.stream??this.config.stream,s;this.isVertex?s={name:r?`/models/${n}:streamRawPredict?alt=sse`:`/models/${n}:rawPredict`}:s={name:"/messages"};let i;if(e.functionCall&&e.functions&&e.functions.length>0)if(typeof e.functionCall=="string")switch(e.functionCall){case"auto":i={tool_choice:{type:"auto"}};break;case"required":i={tool_choice:{type:"any"}};break;case"none":throw new Error("functionCall none not supported")}else if("function"in e.functionCall)i={tool_choice:{type:"tool",name:e.functionCall.function.name}};else throw new Error("Invalid function call type, must be string or object");let a=e.chatPrompt.some(N=>"cache"in N&&N.cache)||e.functions?.some(N=>N.cache),u=e.chatPrompt.filter(N=>N.role==="system"),c=u.map((N,G)=>({type:"text",text:N.content,...N.cache||a&&G===u.length-1?{cache_control:{type:"ephemeral"}}:{}})),l=e.chatPrompt.filter(N=>N.role!=="system"),p=e.functions?.map((N,G,W)=>{let U={type:"object",properties:{dummy:{type:"string",description:"An optional dummy parameter, do not use"}},required:[]},ae=N.parameters?Gt(N.parameters):void 0;return ae===void 0||ae&&typeof ae=="object"&&Object.keys(ae).length===0?ae={...U}:ae&&typeof ae=="object"&&ae.type==="object"&&(!("properties"in ae)||!ae.properties||Object.keys(ae.properties).length===0)&&(ae={...ae,properties:{dummy:{type:"string",description:"An optional dummy parameter, do not use"}},required:[]}),{name:N.name,description:N.description,input_schema:ae,...N.cache||a&&G===W.length-1?{cache_control:{type:"ephemeral"}}:{}}}),m=(this.config.tools??[]).map(N=>N&&typeof N=="object"&&"type"in N?N:{name:N.name,description:N.description,input_schema:N.input_schema?Gt(N.input_schema):void 0,...N.cache_control?{cache_control:N.cache_control}:{}}),g=[...p??[],...m];g.length===0&&(g=void 0);let f=e.modelConfig?.maxTokens??this.config.maxTokens,x=e.modelConfig?.stopSequences??this.config.stopSequences,A=e.modelConfig?.temperature,h=e.modelConfig?.topP,y=e.modelConfig?.topK??this.config.topK,C=e.modelConfig?.n??this.config.n;if(C&&C>1)throw new Error("Anthropic does not support sampling (n > 1)");let I=N=>N.includes("claude-opus-4-6"),v=N=>N.includes("claude-opus-4-5"),O,R,E=n;if(t?.thinkingTokenBudget){let N=this.config.thinkingTokenBudgetLevels,G=this.config.effortLevelMapping;if(t.thinkingTokenBudget==="none")O=void 0,R=void 0;else{let W=t.thinkingTokenBudget;if(I(E))O={type:"adaptive"},R={effort:G?.[W]??"medium"};else if(v(E)){O={type:"enabled",budget_tokens:N?.[W]??1e4};let ae=G?.[W]??"medium";ae==="max"&&(ae="high"),R={effort:ae}}else O={type:"enabled",budget_tokens:N?.[W]??1e4}}}let _=Md(l,!!O);_.some(N=>N.role==="assistant"&&Array.isArray(N.content)&&N.content.length>0&&N.content[0]?.type==="tool_use")&&(O=void 0,R=void 0);let M;if(this.usedStructuredOutput=!1,e.responseFormat&&e.responseFormat.type==="json_schema"&&e.responseFormat.schema){let N=e.responseFormat.schema.schema||e.responseFormat.schema;M={type:"json_schema",schema:Gt(N)},this.usedStructuredOutput=!0}let F={...this.isVertex?{anthropic_version:"vertex-2023-10-16"}:{model:n},...f?{max_tokens:f}:{},...x&&x.length>0?{stop_sequences:x}:{},...A!==void 0&&!O?{temperature:A}:{},...h!==void 0&&(!O||h>=.95)?{top_p:h}:{},...y&&!O?{top_k:y}:{},...i,...g?{tools:g}:{},...r?{stream:!0}:{},...c?{system:c}:{},...O?{thinking:O}:{},...R?{output_config:R}:{},...M?{output_format:M}:{},messages:_};return[s,F]};createChatResp=e=>{if(e.type==="error")throw new Le(e.error.message,void 0,void 0);let t=Du(e.stop_reason),n=this.currentPromptConfig?.thinkingTokenBudget!=="none"&&this.currentPromptConfig?.showThoughts!==!1,r="",s=[],i=[],a=[];for(let l of e.content)switch(l.type){case"text":if(r+=l.text??"",Array.isArray(l.citations))for(let p of l.citations)p?.url&&a.push({url:String(p.url),title:typeof p.title=="string"?p.title:void 0,snippet:typeof p.cited_text=="string"?p.cited_text:void 0});break;case"thinking":if(n){let p=l.thinking??"",d=l.signature;i.push({data:p,encrypted:!1,...typeof d=="string"?{signature:d}:{}})}break;case"redacted_thinking":if(n){let p=l.data??"",d=l.signature;i.push({data:p,encrypted:!0,...typeof d=="string"?{signature:d}:{}})}break;case"tool_use":s.push({id:l.id,type:"function",function:{name:l.name,params:l.input}});break}let u={index:0,id:e.id,finishReason:t};r&&(u.content=r),i.length>0&&(u.thoughtBlocks=i,u.thought=i.map(l=>l.data).join("")),s.length>0&&(u.functionCalls=s),a.length>0&&(u.citations=a);let c=[u];return this.tokensUsed={promptTokens:e.usage.input_tokens,completionTokens:e.usage.output_tokens,totalTokens:e.usage.input_tokens+e.usage.output_tokens+(e.usage.cache_creation_input_tokens||0)+(e.usage.cache_read_input_tokens||0),cacheCreationTokens:e.usage.cache_creation_input_tokens,cacheReadTokens:e.usage.cache_read_input_tokens},{results:c,remoteId:e.id}};createChatStreamResp=(e,t)=>{if(!("type"in e))throw new Error("Invalid Anthropic streaming event");let n=t;if(n.indexIdMap||(n.indexIdMap={}),e.type==="error"){let{error:s}=e;throw new Le(s.message,void 0,void 0)}let r=0;if(e.type==="message_start"){let{message:s}=e,i=[{index:r,content:"",id:s.id}];return this.tokensUsed={promptTokens:s.usage?.input_tokens??0,completionTokens:s.usage?.output_tokens??0,totalTokens:(s.usage?.input_tokens??0)+(s.usage?.output_tokens??0)+(s.usage?.cache_creation_input_tokens??0)+(s.usage?.cache_read_input_tokens??0),cacheCreationTokens:s.usage?.cache_creation_input_tokens,cacheReadTokens:s.usage?.cache_read_input_tokens},{results:i}}if(e.type==="content_block_start"){let{content_block:s}=e;if(s.type==="text"){let i=[];if(Array.isArray(s.citations))for(let a of s.citations)a?.url&&i.push({url:String(a.url),title:typeof a.title=="string"?a.title:void 0,snippet:typeof a.cited_text=="string"?a.cited_text:void 0});return{results:[{index:r,content:s.text,...i.length?{citations:i}:{}}]}}if(s.type==="thinking")return this.currentPromptConfig?.thinkingTokenBudget!=="none"&&this.currentPromptConfig?.showThoughts!==!1?{results:[{index:r,thought:s.thinking,thoughtBlocks:[{data:s.thinking,encrypted:!1}]}]}:{results:[{index:r,content:""}]};if(s.type==="tool_use"&&typeof s.id=="string"&&typeof e.index=="number"&&!n.indexIdMap[e.index]){n.indexIdMap[e.index]=s.id;let i=[{id:s.id,type:"function",function:{name:s.name,params:""}}];return{results:[{index:r,functionCalls:i}]}}if(s.type==="web_search_tool_result"||s.type==="server_tool_use")return{results:[{index:r,content:""}]}}if(e.type==="content_block_delta"){let{delta:s}=e;if(s.type==="citations_delta"){let i=s.citation;if(i&&typeof i.url=="string"&&i.url.length>0){let a=[{url:String(i.url),title:typeof i.title=="string"?i.title:void 0,snippet:typeof i.cited_text=="string"?i.cited_text:void 0}];return{results:[{index:r,content:"",citations:a}]}}return{results:[{index:r,content:""}]}}if(s.type==="text_delta"){let i=[];if(Array.isArray(s.citations))for(let a of s.citations)a?.url&&i.push({url:String(a.url),title:typeof a.title=="string"?a.title:void 0,snippet:typeof a.cited_text=="string"?a.cited_text:void 0});return{results:[{index:r,content:s.text,...i.length?{citations:i}:{}}]}}if(s.type==="thinking_delta")return this.currentPromptConfig?.thinkingTokenBudget!=="none"&&this.currentPromptConfig?.showThoughts!==!1?{results:[{index:r,thought:s.thinking,thoughtBlocks:[{data:s.thinking,encrypted:!1}]}]}:{results:[{index:r,content:""}]};if(s.type==="signature_delta")return{results:[{index:r,thoughtBlocks:[{data:"",encrypted:!1,signature:s.signature}]}]};if(s.type==="input_json_delta"){let i=n.indexIdMap[e.index];if(!i)return{results:[{index:r,content:""}]};let a=[{id:i,type:"function",function:{name:"",params:s.partial_json}}];return{results:[{index:r,functionCalls:a}]}}}if(e.type==="message_delta"){let{delta:s,usage:i}=e;return this.tokensUsed={promptTokens:this.tokensUsed?.promptTokens??0,completionTokens:i.output_tokens,totalTokens:(this.tokensUsed?.promptTokens??0)+i.output_tokens+(this.tokensUsed?.cacheCreationTokens??0)+(this.tokensUsed?.cacheReadTokens??0),cacheCreationTokens:this.tokensUsed?.cacheCreationTokens,cacheReadTokens:this.tokensUsed?.cacheReadTokens},{results:[{index:r,content:"",finishReason:Du(s.stop_reason)}]}}return{results:[{index:r,content:""}]}};supportsImplicitCaching=()=>!0},fn=class o extends je{static create(e){return new o(e)}constructor({apiKey:e,projectId:t,region:n,config:r,options:s,models:i}){let a=t!==void 0&&n!==void 0,u,c;if(a){if(!e)throw new Error("Anthropic Vertex API key not set");if(typeof e!="function")throw new Error("Anthropic Vertex API key must be a function for token-based authentication");u=`https://${n==="global"?"aiplatform":`${n}-aiplatform`}.googleapis.com/v1/projects/${t}/locations/${n}/publishers/anthropic/`,c=async()=>({Authorization:`Bearer ${await e()}`,"anthropic-beta":"web-search-2025-03-05"})}else{if(!e)throw new Error("Anthropic API key not set");u="https://api.anthropic.com/v1",c=async()=>({"anthropic-version":"2023-06-01","anthropic-beta":"structured-outputs-2025-11-13, web-search-2025-03-05","x-api-key":typeof e=="function"?await e():e})}let l={...mi(),...r},p=new di(l,a),d=g=>{let f=mt({model:g,modelInfo:xr,models:i});return{functions:!0,streaming:!0,hasThinkingBudget:f?.supported?.thinkingBudget??!1,hasShowThoughts:f?.supported?.showThoughts??!1,structuredOutputs:f?.supported?.structuredOutputs??!1,functionCot:!0,media:{images:{supported:!0,formats:["image/jpeg","image/png","image/gif","image/webp"],maxSize:5*1024*1024,detailLevels:["high","low","auto"]},audio:{supported:!1,formats:[],maxDuration:0},files:{supported:!1,formats:[],maxSize:0,uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!0,types:["ephemeral"],cacheBreakpoints:!1},thinking:f?.supported?.thinkingBudget??!1,multiTurn:!0}},m=i?.map(g=>{let f=g,x=f?.config;if(!x)return g;let A={};x.maxTokens!==void 0&&(A.maxTokens=x.maxTokens),x.temperature!==void 0&&(A.temperature=x.temperature),x.topP!==void 0&&(A.topP=x.topP),x.topK!==void 0&&(A.topK=x.topK),x.presencePenalty!==void 0&&(A.presencePenalty=x.presencePenalty),x.frequencyPenalty!==void 0&&(A.frequencyPenalty=x.frequencyPenalty),x.stopSequences!==void 0&&(A.stopSequences=x.stopSequences),x.endSequences!==void 0&&(A.endSequences=x.endSequences),x.stream!==void 0&&(A.stream=x.stream),x.n!==void 0&&(A.n=x.n);let h={...f};Object.keys(A).length>0&&(h.modelConfig={...f.modelConfig??{},...A});let y=x.thinking?.thinkingTokenBudget;if(typeof y=="number"){let C=l.thinkingTokenBudgetLevels,I=[["minimal",C?.minimal??1024],["low",C?.low??5e3],["medium",C?.medium??1e4],["high",C?.high??2e4],["highest",C?.highest??32e3]],v="minimal",O=Number.POSITIVE_INFINITY;for(let[R,E]of I){let S=Math.abs(y-E);S<O&&(O=S,v=R)}h.thinkingTokenBudget=v}return x.thinking?.includeThoughts!==void 0&&(h.showThoughts=!!x.thinking.includeThoughts),h});super(p,{name:"Anthropic",apiURL:u,headers:c,modelInfo:xr,defaults:{model:l.model},options:s,supportFor:d,models:m??i})}};function Md(o,e){let t=o.map(r=>{switch(r.role){case"function":return{role:"user",content:[{type:"tool_result",content:r.result,tool_use_id:r.functionId,...r.isError?{is_error:!0}:{},...r.cache?{cache:{type:"ephemeral"}}:{}}]};case"user":return typeof r.content=="string"?{role:"user",content:r.content,...r.cache?{cache_control:{type:"ephemeral"}}:{}}:{role:"user",content:r.content.map(i=>{switch(i.type){case"text":return{type:"text",text:i.text,...i.cache?{cache_control:{type:"ephemeral"}}:{}};case"image":return{type:"image",source:{type:"base64",media_type:i.mimeType,data:i.image},...i.cache?{cache_control:{type:"ephemeral"}}:{}};default:throw new Error("Invalid content type")}})};case"assistant":{let s="",i=[],a=r.thoughtBlocks;if(Array.isArray(a)&&a.length>0)for(let u of a)u.encrypted?i.push(u.signature?{type:"redacted_thinking",data:u.data,signature:u.signature}:{type:"redacted_thinking",data:u.data}):i.push(u.signature?{type:"thinking",thinking:u.data,signature:u.signature}:{type:"thinking",thinking:u.data});if(typeof r.content=="string"&&(i.length>0?s=[...i,{type:"text",text:r.content}]:s=r.content),typeof r.functionCalls<"u"&&(s=r.functionCalls.map(u=>{let c={};if(typeof u.function.params=="string"){let l=u.function.params;if(l.trim().length===0)c={};else try{c=JSON.parse(l)}catch{throw new Error(`Failed to parse function params JSON: ${l}`)}}else typeof u.function.params=="object"&&(c=u.function.params);return{type:"tool_use",id:u.id,name:u.function.name,input:c,...r.cache?{cache_control:{type:"ephemeral"}}:{}}}),Array.isArray(s)&&i.length>0&&(s=[...i,...s])),r.cache){if(typeof s=="string")s=[{type:"text",text:s,cache_control:{type:"ephemeral"}}];else if(Array.isArray(s)&&s.length>0){let u=s.length-1,c=s[u];c&&c.type==="text"&&(s[u]={...c,cache_control:{type:"ephemeral"}})}}return{role:"assistant",content:s}}default:throw new Error("Invalid role")}}),n=Pd(t);return Fd(n)}function Pd(o){let e=[];for(let[t,n]of o.entries()){if(n.role!=="assistant"){e.push(n);continue}if(t>0&&o.at(t-1)?.role==="assistant"){let r=e.pop();e.push({...r||{},...n})}else e.push(n)}return e}function Fd(o){return o.map(e=>e.role==="assistant"&&typeof e.content=="string"?{...e,content:e.content.replace(/\s+$/,"")}:e)}function Du(o){if(o)switch(o){case"stop_sequence":return"stop";case"max_tokens":return"length";case"tool_use":return"function_call";case"end_turn":return"stop";default:return"stop"}}var Ar=(U=>(U.GPT4="gpt-4",U.GPT41="gpt-4.1",U.GPT41Mini="gpt-4.1-mini",U.GPT41Nano="gpt-4.1-nano",U.GPT4O="gpt-4o",U.GPT4OMini="gpt-4o-mini",U.GPT4ChatGPT4O="chatgpt-4o-latest",U.GPT4Turbo="gpt-4-turbo",U.GPT35Turbo="gpt-3.5-turbo",U.GPT35TurboInstruct="gpt-3.5-turbo-instruct",U.GPT35TextDavinci002="text-davinci-002",U.GPT3TextBabbage002="text-babbage-002",U.GPT3TextAda001="text-ada-001",U.GPT5="gpt-5",U.GPT5Nano="gpt-5-nano",U.GPT5Mini="gpt-5-mini",U.GPT5Chat="gpt-5-chat",U.GPT5ChatLatest="gpt-5-chat-latest",U.GPT5Codex="gpt-5-codex",U.GPT5Pro="gpt-5-pro",U.GPT51="gpt-5.1",U.GPT51ChatLatest="gpt-5.1-chat-latest",U.GPT51Codex="gpt-5.1-codex",U.GPT51CodexMini="gpt-5.1-codex-mini",U.GPT51CodexMax="gpt-5.1-codex-max",U.GPT52="gpt-5.2",U.GPT52ChatLatest="gpt-5.2-chat-latest",U.GPT52Codex="gpt-5.2-codex",U.GPT52Pro="gpt-5.2-pro",U.O1="o1",U.O1Mini="o1-mini",U.O3="o3",U.O3Mini="o3-mini",U.O4Mini="o4-mini",U))(Ar||{}),hn=(n=>(n.TextEmbeddingAda002="text-embedding-ada-002",n.TextEmbedding3Small="text-embedding-3-small",n.TextEmbedding3Large="text-embedding-3-large",n))(hn||{});var xn=(j=>(j.GPT4="gpt-4",j.GPT41="gpt-4.1",j.GPT41Mini="gpt-4.1-mini",j.GPT41Nano="gpt-4.1-nano",j.GPT4O="gpt-4o",j.GPT4OMini="gpt-4o-mini",j.GPT4ChatGPT4O="chatgpt-4o-latest",j.GPT4Turbo="gpt-4-turbo",j.GPT35Turbo="gpt-3.5-turbo",j.GPT35TurboInstruct="gpt-3.5-turbo-instruct",j.GPT35TextDavinci002="text-davinci-002",j.GPT3TextBabbage002="text-babbage-002",j.GPT3TextAda001="text-ada-001",j.GPT5="gpt-5",j.GPT5Nano="gpt-5-nano",j.GPT5Mini="gpt-5-mini",j.GPT5Chat="gpt-5-chat",j.GPT5ChatLatest="gpt-5-chat-latest",j.GPT5Codex="gpt-5-codex",j.GPT5Pro="gpt-5-pro",j.GPT51="gpt-5.1",j.GPT51ChatLatest="gpt-5.1-chat-latest",j.GPT51Codex="gpt-5.1-codex",j.GPT51CodexMini="gpt-5.1-codex-mini",j.GPT51CodexMax="gpt-5.1-codex-max",j.GPT52="gpt-5.2",j.GPT52ChatLatest="gpt-5.2-chat-latest",j.GPT52Codex="gpt-5.2-codex",j.GPT52Pro="gpt-5.2-pro",j.O1Pro="o1-pro",j.O1="o1",j.O1Mini="o1-mini",j.O3Pro="o3-pro",j.O3="o3",j.O3Mini="o3-mini",j.O4Mini="o4-mini",j))(xn||{});var An=[{name:"gpt-4",currency:"usd",promptTokenCostPer1M:30,completionTokenCostPer1M:60},{name:"gpt-4.1",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,supported:{structuredOutputs:!0}},{name:"gpt-4.1-mini",currency:"usd",promptTokenCostPer1M:.4,completionTokenCostPer1M:1.6,supported:{structuredOutputs:!0}},{name:"gpt-4.1-nano",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.4,supported:{structuredOutputs:!0}},{name:"gpt-4o",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:15,supported:{structuredOutputs:!0}},{name:"gpt-4o-mini",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:.6,supported:{structuredOutputs:!0}},{name:"chatgpt-4o-latest",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:15,supported:{structuredOutputs:!0}},{name:"gpt-4-turbo",currency:"usd",promptTokenCostPer1M:10,completionTokenCostPer1M:30,supported:{structuredOutputs:!0}},{name:"gpt-3.5-turbo",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5},{name:"gpt-5-nano",currency:"usd",promptTokenCostPer1M:.05,completionTokenCostPer1M:.4,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-mini",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:2,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-chat",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-chat-latest",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-pro",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:120,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5-codex",currency:"usd",promptTokenCostPer1M:10,completionTokenCostPer1M:40,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1-chat-latest",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1-codex",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1-codex-mini",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:2,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.1-codex-max",currency:"usd",promptTokenCostPer1M:2.5,completionTokenCostPer1M:20,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.2",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.2-chat-latest",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.2-codex",currency:"usd",promptTokenCostPer1M:1.5,completionTokenCostPer1M:6,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"gpt-5.2-pro",currency:"usd",promptTokenCostPer1M:20,completionTokenCostPer1M:160,notSupported:{temperature:!0,topP:!0},supported:{structuredOutputs:!0}},{name:"o1",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:60,supported:{structuredOutputs:!0}},{name:"o1-mini",currency:"usd",promptTokenCostPer1M:1.1,completionTokenCostPer1M:14.4,supported:{structuredOutputs:!0}},{name:"o3",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:60,supported:{structuredOutputs:!0}},{name:"o4-mini",currency:"usd",promptTokenCostPer1M:1.1,completionTokenCostPer1M:4.4,supported:{structuredOutputs:!0}},{name:"text-embedding-ada-002",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1},{name:"text-embedding-3-small",currency:"usd",promptTokenCostPer1M:.02,completionTokenCostPer1M:.02},{name:"text-embedding-3-large",currency:"usd",promptTokenCostPer1M:.13,completionTokenCostPer1M:.13}],bo=[{name:"gpt-4",currency:"usd",promptTokenCostPer1M:30,completionTokenCostPer1M:60},{name:"gpt-4.1",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,supported:{structuredOutputs:!0}},{name:"gpt-4.1-mini",currency:"usd",promptTokenCostPer1M:.4,completionTokenCostPer1M:1.6,supported:{structuredOutputs:!0}},{name:"gpt-4.1-nano",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.4,supported:{structuredOutputs:!0}},{name:"gpt-4o",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:15,supported:{structuredOutputs:!0}},{name:"gpt-4o-mini",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:.6,supported:{structuredOutputs:!0}},{name:"chatgpt-4o-latest",currency:"usd",promptTokenCostPer1M:5,completionTokenCostPer1M:15,supported:{structuredOutputs:!0}},{name:"gpt-4-turbo",currency:"usd",promptTokenCostPer1M:10,completionTokenCostPer1M:30,supported:{structuredOutputs:!0}},{name:"gpt-3.5-turbo",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5},{name:"gpt-5-nano",currency:"usd",promptTokenCostPer1M:.05,completionTokenCostPer1M:.4,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-mini",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:2,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-chat",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-chat-latest",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-pro",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:120,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5-codex",currency:"usd",promptTokenCostPer1M:10,completionTokenCostPer1M:40,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1-chat-latest",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1-codex",currency:"usd",promptTokenCostPer1M:1.25,completionTokenCostPer1M:10,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1-codex-mini",currency:"usd",promptTokenCostPer1M:.25,completionTokenCostPer1M:2,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.1-codex-max",currency:"usd",promptTokenCostPer1M:2.5,completionTokenCostPer1M:20,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.2",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.2-chat-latest",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:8,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.2-codex",currency:"usd",promptTokenCostPer1M:1.5,completionTokenCostPer1M:6,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gpt-5.2-pro",currency:"usd",promptTokenCostPer1M:20,completionTokenCostPer1M:160,notSupported:{temperature:!0,topP:!0},supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"o1-pro",currency:"usd",promptTokenCostPer1M:150,completionTokenCostPer1M:600,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0},isExpensive:!0},{name:"o1",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:60,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"o3-pro",currency:"usd",promptTokenCostPer1M:20,completionTokenCostPer1M:80,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0},isExpensive:!0},{name:"o3",currency:"usd",promptTokenCostPer1M:15,completionTokenCostPer1M:60,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"o3-mini",currency:"usd",promptTokenCostPer1M:1.1,completionTokenCostPer1M:4.4,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"o4-mini",currency:"usd",promptTokenCostPer1M:1.1,completionTokenCostPer1M:4.4,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}}];var _d=o=>{let e=["o1","o1-mini","o3","o3-mini","o4-mini","o1-pro","o3-pro"];return e.includes(o)||e.includes(o)},Zt=()=>structuredClone({model:"gpt-5-mini",embedModel:"text-embedding-3-small",...ve()}),Co=()=>structuredClone({...Zt(),model:"gpt-5"}),Io=()=>structuredClone({model:"gpt-5-mini",embedModel:"text-embedding-3-small",...He()}),To=()=>({...Zt(),model:"gpt-5-nano"}),gi=class{constructor(e,t,n){this.config=e;this.streamingUsage=t;this.chatReqUpdater=n}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,stopSequences:e.stopSequences,endSequences:e.endSequences,topP:e.topP,n:e.n,stream:e.stream}}createChatReq=(e,t)=>{let n=e.model;if(!e.chatPrompt||e.chatPrompt.length===0)throw new Error("Chat prompt is empty");let r={name:"/chat/completions"},s=e.functions?.map(m=>({type:"function",function:{name:m.name,description:m.description,parameters:m.parameters}})),i=!e.functionCall&&e.functions&&e.functions.length>0?"auto":e.functionCall,a=Nd(e),u=e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,c=e.modelConfig?.stream??this.config.stream,l=this.config.store,p=_d(n),d={model:n,messages:a,...e.responseFormat?{response_format:e.responseFormat.type==="json_schema"?{type:"json_schema",json_schema:e.responseFormat.schema}:e.responseFormat}:this.config?.responseFormat?{response_format:{type:this.config.responseFormat}}:{},...s?{tools:s}:{},...i?{tool_choice:i}:{},...p?{}:{...(e.modelConfig?.maxTokens??this.config.maxTokens)!==void 0?{max_completion_tokens:e.modelConfig?.maxTokens??this.config.maxTokens}:{},...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},...(e.modelConfig?.n??this.config.n)!==void 0?{n:e.modelConfig?.n??this.config.n}:{},...(e.modelConfig?.presencePenalty??this.config.presencePenalty)!==void 0?{presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty}:{},...u!==void 0?{frequency_penalty:u}:{}},...(e.modelConfig?.stopSequences??this.config.stop)&&(e.modelConfig?.stopSequences??this.config.stop).length>0?{stop:e.modelConfig?.stopSequences??this.config.stop}:{},...this.config.logitBias!==void 0?{logit_bias:this.config.logitBias}:{},...c&&this.streamingUsage?{stream:!0,stream_options:{include_usage:!0}}:{},...l?{store:l}:{},...this.config.serviceTier?{service_tier:this.config.serviceTier}:{},...this.config.user?{user:this.config.user}:{}};if(this.config.reasoningEffort&&(d.reasoning_effort=this.config.reasoningEffort),this.config.webSearchOptions&&(d.web_search_options={...this.config.webSearchOptions.searchContextSize&&{search_context_size:this.config.webSearchOptions.searchContextSize},...this.config.webSearchOptions.userLocation&&{user_location:{approximate:{type:"approximate",...this.config.webSearchOptions.userLocation.approximate.city&&{city:this.config.webSearchOptions.userLocation.approximate.city},...this.config.webSearchOptions.userLocation.approximate.country&&{country:this.config.webSearchOptions.userLocation.approximate.country},...this.config.webSearchOptions.userLocation.approximate.region&&{region:this.config.webSearchOptions.userLocation.approximate.region},...this.config.webSearchOptions.userLocation.approximate.timezone&&{timezone:this.config.webSearchOptions.userLocation.approximate.timezone}}}}}),t?.thinkingTokenBudget)switch(t.thinkingTokenBudget){case"none":d.reasoning_effort=void 0;break;case"minimal":d.reasoning_effort="minimal";break;case"low":d.reasoning_effort="medium";break;case"medium":d.reasoning_effort="high";break;case"high":d.reasoning_effort="high";break;case"highest":d.reasoning_effort="high";break}if(!d.reasoning_effort&&t?.thinkingTokenBudget)switch(t.thinkingTokenBudget){case"minimal":d.reasoning_effort="minimal";break;case"low":d.reasoning_effort="medium";break;case"medium":case"high":case"highest":d.reasoning_effort="high";break}return this.chatReqUpdater&&(d=this.chatReqUpdater(d)),[r,d]};createEmbedReq=e=>{let t=e.embedModel;if(!t)throw new Error("Embed model not set");if(!e.texts||e.texts.length===0)throw new Error("Embed texts is empty");let n={name:"/embeddings"},r={model:t,input:e.texts,dimensions:this.config.dimensions};return[n,r]};createChatResp(e){let{id:t,usage:n,choices:r,error:s}=e;if(s)throw s;return this.tokensUsed=n?{promptTokens:n.prompt_tokens,completionTokens:n.completion_tokens,totalTokens:n.total_tokens}:void 0,{results:r.map(a=>{if(a.message.refusal)throw new Le(a.message.refusal,e.model,e.id);let u=Gu(a.finish_reason),c=a.message.tool_calls?.map(({id:l,function:{arguments:p,name:d}})=>({id:l,type:"function",function:{name:d,params:p}}));return{index:a.index,id:`${a.index}`,content:a.message.content??void 0,thought:a.message.reasoning_content,citations:a.message.annotations?.filter(l=>l?.type==="url_citation"&&l.url_citation).map(l=>({url:l.url_citation?.url,title:l.url_citation?.title,description:l.url_citation?.description})),functionCalls:c,finishReason:u}}),remoteId:t}}createChatStreamResp(e,t){let{id:n,usage:r,choices:s}=e;this.tokensUsed=r?{promptTokens:r.prompt_tokens,completionTokens:r.completion_tokens,totalTokens:r.total_tokens}:void 0;let i=t;return i.indexIdMap||(i.indexIdMap={}),{results:s.map(({index:u,delta:{content:c,role:l,refusal:p,tool_calls:d,reasoning_content:m,annotations:g},finish_reason:f})=>{if(p)throw new Le(p,void 0,n);let x=Gu(f),A=d?.map(({id:h,index:y,function:{name:C,arguments:I}})=>{typeof h=="string"&&typeof y=="number"&&!i.indexIdMap[y]&&(i.indexIdMap[y]=h);let v=i.indexIdMap[y];return v?{id:v,type:"function",function:{name:C,params:I}}:null}).filter(h=>h!==null);return{index:u,content:c??void 0,role:l,thought:m,citations:g?.filter(h=>h?.type==="url_citation"&&h.url_citation).map(h=>({url:h.url_citation?.url,title:h.url_citation?.title,description:h.url_citation?.description})),functionCalls:A,finishReason:x,id:n}})}}createEmbedResp(e){let{data:t,usage:n}=e;return this.tokensUsed=n?{promptTokens:n.prompt_tokens,completionTokens:n.completion_tokens,totalTokens:n.total_tokens}:void 0,{embeddings:t.map(r=>r.embedding)}}},Gu=o=>{switch(o){case"stop":return"stop";case"length":return"length";case"content_filter":return"error";case"tool_calls":return"function_call"}};function Nd(o){return o.chatPrompt.map(t=>{switch(t.role){case"system":return{role:"system",content:t.content};case"user":{let n=Array.isArray(t.content)?t.content.map(r=>{switch(r.type){case"text":return{type:"text",text:r.text};case"image":return{type:"image_url",image_url:{url:`data:${r.mimeType};base64,${r.image}`,details:r.details??"auto"}};case"audio":return{type:"input_audio",input_audio:{data:r.data,format:r.format==="wav"?"wav":void 0}};default:throw new Error("Invalid content type")}}):t.content;return{role:"user",...t.name?{name:t.name}:{},content:n}}case"assistant":{let n=t.functionCalls?.map(r=>({id:r.id,type:"function",function:{name:r.function.name,arguments:typeof r.function.params=="object"?JSON.stringify(r.function.params):r.function.params}}));if(n&&n.length>0)return{role:"assistant",...t.content?{content:t.content}:{},name:t.name,tool_calls:n};if(t.content===void 0)throw new Error("Assistant content is required when no tool calls are provided");return{role:"assistant",content:t.content,...t.name?{name:t.name}:{}}}case"function":return{role:"tool",content:t.result,tool_call_id:t.functionId};default:throw new Error("Invalid role")}})}var Ge=class extends je{constructor({apiKey:e,config:t,options:n,apiURL:r,modelInfo:s,models:i,chatReqUpdater:a,supportFor:u}){if(!e||e==="")throw new Error("OpenAI API key not set");let c=new gi(t,n?.streamingUsage??!0,a);super(c,{name:"OpenAI",apiURL:r||"https://api.openai.com/v1",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:s,defaults:{model:t.model,embedModel:t.embedModel},options:n,supportFor:u,models:i})}},yn=class extends Ge{constructor({apiKey:e,apiURL:t,config:n,options:r,models:s,modelInfo:i}){if(!e||e==="")throw new Error("OpenAI API key not set");i=[...An,...i??[]];let a=c=>{let l=mt({model:c,modelInfo:i,models:s});return{functions:!0,streaming:!0,hasThinkingBudget:l?.supported?.thinkingBudget??!1,hasShowThoughts:l?.supported?.showThoughts??!1,structuredOutputs:l?.supported?.structuredOutputs??!1,media:{images:{supported:!0,formats:["image/jpeg","image/png","image/gif","image/webp"],maxSize:20*1024*1024,detailLevels:["high","low","auto"]},audio:{supported:!0,formats:["wav","mp3","ogg"],maxDuration:25*60},files:{supported:!0,formats:["text/plain","application/pdf","image/jpeg","image/png"],maxSize:512*1024*1024,uploadMethod:"upload"},urls:{supported:!1,webSearch:!0,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:l?.supported?.thinkingBudget??!1,multiTurn:!0}},u=s?.map(c=>{let l=c,p=l?.config;if(!p)return c;let d={};p.maxTokens!==void 0&&(d.maxTokens=p.maxTokens),p.temperature!==void 0&&(d.temperature=p.temperature),p.topP!==void 0&&(d.topP=p.topP),p.presencePenalty!==void 0&&(d.presencePenalty=p.presencePenalty),p.frequencyPenalty!==void 0&&(d.frequencyPenalty=p.frequencyPenalty);let m=p.stopSequences??p.stop;m!==void 0&&(d.stopSequences=m),p.n!==void 0&&(d.n=p.n),p.stream!==void 0&&(d.stream=p.stream);let g={...l};Object.keys(d).length>0&&(g.modelConfig={...l.modelConfig??{},...d});let f=p?.thinking?.thinkingTokenBudget;if(typeof f=="number"){let x=[["minimal",200],["low",800],["medium",5e3],["high",1e4],["highest",24500]],A="minimal",h=Number.POSITIVE_INFINITY;for(let[y,C]of x){let I=Math.abs(f-C);I<h&&(h=I,A=y)}g.thinkingTokenBudget=A}return p?.thinking?.includeThoughts!==void 0&&(g.showThoughts=!!p.thinking.includeThoughts),g});super({apiKey:e,apiURL:t,config:{...Zt(),...n},options:r,modelInfo:i,models:u??s,supportFor:a}),super.setName("OpenAI")}};var Ld=o=>{let e=o.trim();if(!e)return e;if(e.includes("api-version=")){let t=e.indexOf("api-version="),n=e.slice(t);return new URLSearchParams(n).get("api-version")??e}return e},$d=o=>{let e=o.match(/^(\d{4}-\d{2}-\d{2})/);return e?e[1]>="2024-08-01":!1},fi=Zt,ju=Io,Bu=To,zu=Co,bn=class extends Ge{constructor({apiKey:e,resourceName:t,deploymentName:n,version:r="api-version=2024-02-15-preview",config:s,options:i,models:a,modelInfo:u}){if(!e||e==="")throw new Error("Azure OpenAPI API key not set");if(!t||t==="")throw new Error("Azure OpenAPI resource name not set");if(!n||n==="")throw new Error("Azure OpenAPI deployment id not set");let c={...fi(),...s},l=Ld(r),p=$d(l);u=[...An,...u??[]];let d=g=>{let f=mt({model:g,modelInfo:u,models:a});return{functions:!0,streaming:!0,hasThinkingBudget:f?.supported?.thinkingBudget??!1,hasShowThoughts:f?.supported?.showThoughts??!1,structuredOutputs:p&&(f?.supported?.structuredOutputs??!1),functionCot:!1,media:{images:{supported:!0,formats:["image/jpeg","image/png","image/gif","image/webp"],maxSize:20*1024*1024,detailLevels:["high","low","auto"]},audio:{supported:!1,formats:[],maxDuration:0},files:{supported:!1,formats:[],maxSize:0,uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:f?.supported?.thinkingBudget??!1,multiTurn:!0}};super({apiKey:e,config:c,options:i,models:a,modelInfo:u,supportFor:d});let m=t.includes("://")?t:`https://${t}.openai.azure.com/`;super.setName("Azure OpenAI"),super.setAPIURL(new URL(`/openai/deployments/${n}?api-version=${l}`,m).href),super.setHeaders(async()=>({"api-key":e}))}};var wo=class o{services;currentServiceIndex=0;currentService;debug;initialBackoffMs;maxBackoffMs;maxRetries;serviceFailures=new Map;constructor(e,t){if(e.length===0)throw new Error("No AI services provided.");Dd(e),this.services=[...e].sort(t?.comparator??o.metricComparator);let n=this.services[this.currentServiceIndex];if(n===void 0)throw new Error("Error initializing the AI services.");this.currentService=n,this.debug=t?.debug??!0,this.initialBackoffMs=t?.initialBackoffMs??1e3,this.maxBackoffMs=t?.maxBackoffMs??32e3,this.maxRetries=t?.maxRetries??3}static create(e,t){return new o(e,t)}getLastUsedChatModel(){return this.currentService.getLastUsedChatModel()}getLastUsedEmbedModel(){return this.currentService.getLastUsedEmbedModel()}getLastUsedModelConfig(){return this.currentService.getLastUsedModelConfig()}static inputOrderComparator=()=>0;static metricComparator=(e,t)=>{let n=e.getMetrics(),r=t.getMetrics();return n.latency.chat.mean-r.latency.chat.mean};getModelList(){for(let e of this.services){let t=e.getModelList();if(t)return t}}getNextService(e,t){let n=t+1,r=e[n];return r===void 0?{service:void 0,index:n}:{service:r,index:n}}reset(){this.currentServiceIndex=0;let e=this.services[this.currentServiceIndex];if(e===void 0)throw new Error("No AI services provided.");this.currentService=e}getName(){return this.currentService.getName()}getId(){return this.currentService.getId()}getFeatures(e){let t={functions:!1,streaming:!1,thinking:!1,multiTurn:!1,structuredOutputs:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]}};for(let n of this.services){let r=n.getFeatures(e);r.functions&&(t.functions=!0),r.streaming&&(t.streaming=!0),r.thinking&&(t.thinking=!0),r.multiTurn&&(t.multiTurn=!0),r.structuredOutputs&&(t.structuredOutputs=!0),r.functionCot&&(t.functionCot=!0),r.hasThinkingBudget&&(t.hasThinkingBudget=!0),r.hasShowThoughts&&(t.hasShowThoughts=!0),r.media.images.supported&&(t.media.images.supported=!0),t.media.images.formats=Array.from(new Set([...t.media.images.formats,...r.media.images.formats])),r.media.audio.supported&&(t.media.audio.supported=!0),t.media.audio.formats=Array.from(new Set([...t.media.audio.formats,...r.media.audio.formats])),r.media.files.supported&&(t.media.files.supported=!0),t.media.files.formats=Array.from(new Set([...t.media.files.formats,...r.media.files.formats])),r.media.files.uploadMethod!=="none"&&(t.media.files.uploadMethod=r.media.files.uploadMethod),r.media.urls.supported&&(t.media.urls.supported=!0),r.media.urls.webSearch&&(t.media.urls.webSearch=!0),r.media.urls.contextFetching&&(t.media.urls.contextFetching=!0),r.caching.supported&&(t.caching.supported=!0),t.caching.types=Array.from(new Set([...t.caching.types,...r.caching.types]))}return t}getMetrics(){let e={latency:{chat:{mean:0,p95:0,p99:0,samples:[]},embed:{mean:0,p95:0,p99:0,samples:[]}},errors:{chat:{count:0,rate:0,total:0},embed:{count:0,rate:0,total:0}}},t=0,n=0,r=0,s=0;for(let i of this.services){let a=i.getMetrics();e.errors.chat.count+=a.errors.chat.count,e.errors.chat.total+=a.errors.chat.total,e.errors.embed.count+=a.errors.embed.count,e.errors.embed.total+=a.errors.embed.total;let u=a.latency.chat.samples.length;u>0&&(t+=a.latency.chat.mean*u,n+=u);let c=a.latency.embed.samples.length;c>0&&(r+=a.latency.embed.mean*c,s+=c)}e.errors.chat.total>0&&(e.errors.chat.rate=e.errors.chat.count/e.errors.chat.total),e.errors.embed.total>0&&(e.errors.embed.rate=e.errors.embed.count/e.errors.embed.total),n>0&&(e.latency.chat.mean=t/n),s>0&&(e.latency.embed.mean=r/s);for(let i of this.services){let a=i.getMetrics();e.latency.chat.p95=Math.max(e.latency.chat.p95,a.latency.chat.p95),e.latency.chat.p99=Math.max(e.latency.chat.p99,a.latency.chat.p99),e.latency.embed.p95=Math.max(e.latency.embed.p95,a.latency.embed.p95),e.latency.embed.p99=Math.max(e.latency.embed.p99,a.latency.embed.p99)}return e}canRetryService(e){let t=this.serviceFailures.get(e.getId());if(!t)return!0;let{retries:n,lastFailureTime:r}=t,s=Date.now()-r,i=Math.min(this.initialBackoffMs*2**n,this.maxBackoffMs);return s>=i}handleFailure(e,t){let r=(this.serviceFailures.get(e.getId())?.retries??0)+1;this.serviceFailures.set(e.getId(),{retries:r,lastFailureTime:Date.now()}),this.debug&&console.warn(`AxBalancer: Service ${e.getName()} failed (retry ${r}/${this.maxRetries})`,t)}handleSuccess(e){this.serviceFailures.delete(e.getId())}async chat(e,t){let n=e.responseFormat?.type==="json_schema",r=e.capabilities,s=r?.requiresImages,i=r?.requiresAudio,a=this.services,u=e.model;if((n||s||i)&&(a=this.services.filter(p=>{let d=p.getFeatures(u);return!(n&&!d.structuredOutputs||s&&!d.media.images.supported||i&&!d.media.audio.supported)}),a.length===0)){let p=[];throw n&&p.push("structured outputs"),s&&p.push("images"),i&&p.push("audio"),new Error(`No services available that support required capabilities: ${p.join(", ")}.`)}let c=0,l=a[c];if(!l)throw new Error("No matching AI services available for request.");for(this.currentService=l;;){if(!this.canRetryService(l)){let p=this.getNextService(a,c);if(!p.service)throw new Error(`All candidate services exhausted (tried ${a.length} service(s))`);l=p.service,c=p.index,this.currentService=l;continue}try{let p=await l.chat(e,t);return this.handleSuccess(l),p}catch(p){if(!(p instanceof et))throw p;switch(p.constructor){case Lt:throw p;case rt:{if(![408,429,500,502,503,504].includes(p.status))throw p;break}case Je:break;case Nt:break;case gt:break;case dt:break;default:throw p}if(this.handleFailure(l,p),(this.serviceFailures.get(l.getId())?.retries??0)>=this.maxRetries){let m=this.getNextService(a,c);if(this.debug&&console.warn(`AxBalancer: Switching to service ${m.service?.getName()??"none"}`,p),!m.service)throw p;l=m.service,c=m.index,this.currentService=l}}}}async embed(e,t){this.reset();let n=this.currentServiceIndex;for(;;){if(!this.canRetryService(this.currentService)){let r=this.getNextService(this.services,n);if(!r.service)throw new Error(`All services exhausted (tried ${this.services.length} service(s))`);this.currentService=r.service,n=r.index,this.currentServiceIndex=n;continue}try{let r=await this.currentService.embed(e,t);return this.handleSuccess(this.currentService),r}catch(r){if(!(r instanceof et)||r instanceof rt&&![408,429,500,502,503,504].includes(r.status)||r instanceof Lt)throw r;if(this.handleFailure(this.currentService,r),(this.serviceFailures.get(this.currentService.getId())?.retries??0)>=this.maxRetries){let i=this.getNextService(this.services,n);if(!i.service)throw r;this.currentService=i.service,n=i.index,this.currentServiceIndex=n}}}}setOptions(e){for(let t of this.services)t.setOptions(e);this.currentService.setOptions(e),this.debug=e.debug??this.debug}getOptions(){return this.currentService.getOptions()}getLogger(){return this.currentService.getLogger()}};function Dd(o){let e=o.find(r=>r.getModelList()!==void 0);if(!e)return;let t=e.getModelList();if(!t)throw new Error("No model list found in any service.");let n=new Set(t.map(r=>r.key));for(let r=0;r<o.length;r++){let s=o[r];if(!s)throw new Error(`Service at index ${r} is undefined`);let i=s.getModelList();if(!i)throw new Error(`Service at index ${r} (${s.getName()}) has no model list while another service does.`);let a=new Set(i.map(u=>u.key));for(let u of n)if(!a.has(u))throw new Error(`Service at index ${r} (${s.getName()}) is missing model "${u}"`);for(let u of a)if(!n.has(u))throw new Error(`Service at index ${r} (${s.getName()}) has extra model "${u}"`)}}function en(o){let e=!1,t=!1,n=!1,r=!1,s=!1,i=!1,a=!1,u=new Set,c=0;if(o.chatPrompt&&Array.isArray(o.chatPrompt))for(let l of o.chatPrompt){if(l.role==="user"&&Array.isArray(l.content))for(let p of l.content)switch(u.add(p.type),p.type){case"image":e=!0,p.cache&&(a=!0),c+=85;break;case"audio":t=!0,p.cache&&(a=!0),c+=p.duration||60;break;case"file":n=!0,p.cache&&(a=!0),c+=Math.ceil((p.extractedText?.length||1e3)/4);break;case"url":r=!0,p.cache&&(a=!0),c+=Math.ceil((p.cachedContent?.length||2e3)/4);break;case"text":p.cache&&(a=!0),c+=Math.ceil(p.text.length/4);break}else"content"in l&&typeof l.content=="string"&&(c+=Math.ceil(l.content.length/4));"cache"in l&&l.cache&&(a=!0)}return o.functions&&o.functions.length>0&&(s=!0),o.modelConfig?.stream===!0&&(i=!0),o.capabilities&&(o.capabilities.requiresImages&&(e=!0),o.capabilities.requiresAudio&&(t=!0),o.capabilities.requiresFiles&&(n=!0),o.capabilities.requiresWebSearch&&(r=!0)),{hasImages:e,hasAudio:t,hasFiles:n,hasUrls:r,requiresFunctions:s,requiresStreaming:i,requiresCaching:a,contentTypes:u,estimatedTokens:c}}function hi(o,e){let t=o.getFeatures(),n=[],r=[],s=[];if(e.hasImages&&!t.media.images.supported&&(n.push("Image support"),s.push("Use altText for images or imageToText service")),e.hasAudio&&!t.media.audio.supported&&(n.push("Audio support"),s.push("Pre-transcribe audio or use transcription field")),e.hasFiles&&!t.media.files.supported&&(n.push("File support"),s.push("Pre-extract text content or use extractedText field")),e.hasUrls&&!t.media.urls.supported&&(n.push("URL/Web search support"),s.push("Pre-fetch content or use cachedContent field")),e.requiresFunctions&&!t.functions&&n.push("Function calling"),e.requiresStreaming&&!t.streaming&&(n.push("Streaming responses"),s.push("Use non-streaming mode")),e.requiresCaching&&!t.caching.supported&&(n.push("Content caching"),s.push("Repeated content will not be cached")),e.hasImages&&t.media.images.supported){let a=t.media.images.maxSize;a&&a<10*1024*1024&&r.push(`Image size limit is ${Math.round(a/(1024*1024))}MB`)}if(e.hasAudio&&t.media.audio.supported){let a=t.media.audio.maxDuration;a&&a<600&&r.push(`Audio duration limit is ${Math.round(a/60)} minutes`)}return{isSupported:n.length===0,missingCapabilities:n,warnings:r,alternatives:s}}function Ro(o,e){return o.map(t=>{let n=t.getFeatures(),r=hi(t,e),s=0,i=[];return s+=10,e.hasImages&&n.media.images.supported&&(s+=25,i.push("Images"),n.media.images.detailLevels?.includes("high")&&(s+=5),n.media.images.maxSize&&n.media.images.maxSize>10*1024*1024&&(s+=3)),e.hasAudio&&n.media.audio.supported&&(s+=25,i.push("Audio"),n.media.audio.maxDuration&&n.media.audio.maxDuration>600&&(s+=5)),e.hasFiles&&n.media.files.supported&&(s+=25,i.push("Files"),n.media.files.uploadMethod==="cloud"&&(s+=3)),e.hasUrls&&n.media.urls.supported&&(s+=25,i.push("URLs"),n.media.urls.webSearch&&(s+=5)),e.requiresFunctions&&n.functions&&(s+=15,i.push("Functions"),n.functionCot&&(s+=3)),e.requiresStreaming&&n.streaming&&(s+=10,i.push("Streaming")),e.requiresCaching&&n.caching.supported&&(s+=8,i.push("Caching"),n.caching.types.includes("persistent")&&(s+=3)),n.thinking&&(s+=2),n.multiTurn&&(s+=2),n.hasThinkingBudget&&(s+=1),n.hasShowThoughts&&(s+=1),s-=r.missingCapabilities.length*10,{provider:t,score:s,missingCapabilities:r.missingCapabilities,supportedCapabilities:i}}).sort((t,n)=>n.score-t.score)}function vo(o,e,t={}){if(e.length===0)throw new Error("No providers available");let n=en(o),r=Ro(e,n);if(t.requireExactMatch){let s=r.filter(i=>i.missingCapabilities.length===0);if(s.length===0)throw new Error(`No providers fully support the request requirements: ${r[0]?.missingCapabilities.join(", ")||"unknown requirements"}`);return s[0].provider}if(!t.allowDegradation){let s=r[0];if(s.missingCapabilities.length>0)throw new Error(`Best available provider (${s.provider.getName()}) is missing: ${s.missingCapabilities.join(", ")}`)}return r[0].provider}function qu(o,e){let t=en(o),n=Ro(e,t),r=n[0]?.provider||null,s=[t.hasImages&&"images",t.hasAudio&&"audio",t.hasFiles&&"files",t.hasUrls&&"URLs",t.requiresFunctions&&"functions",t.requiresStreaming&&"streaming",t.requiresCaching&&"caching"].filter(Boolean).length,i=r?n[0].supportedCapabilities.length:0,a=r?`${r.getName()} supports ${i}/${s} requirements (${Math.round(i/Math.max(s,1)*100)}% compatibility)`:"No suitable providers found";return{requirements:t,providerScores:n,recommendedProvider:r,summary:a}}function Hu(o,e){return o.filter(t=>t.getFeatures().media[e].supported)}function Ku(o,e){let t={};for(let n of o){let s=n.getFeatures().media[e];if(s.supported)for(let i of s.formats)t[i]||(t[i]=[]),t[i].push(n)}return t}var yr=(r=>(r.CommandRPlus="command-r-plus",r.CommandR="command-r",r.Command="command",r.CommandLight="command-light",r))(yr||{}),br=(r=>(r.EmbedEnglishV30="embed-english-v3.0",r.EmbedEnglishLightV30="embed-english-light-v3.0",r.EmbedMultiLingualV30="embed-multilingual-v3.0",r.EmbedMultiLingualLightV30="embed-multilingual-light-v3.0",r))(br||{});var So=[{name:"command-r-plus",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15},{name:"command-r",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5},{name:"command",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5},{name:"command-light",currency:"usd",promptTokenCostPer1M:.3,completionTokenCostPer1M:.6},{name:"embed-english-light-v3.0",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1},{name:"embed-english-v3.0",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1},{name:"embed-multilingual-v3.0",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1},{name:"embed-multilingual-light-v3.0",currency:"usd",promptTokenCostPer1M:.1,completionTokenCostPer1M:.1}];function Ud(o){if(Array.isArray(o)){let t=["string","number","integer","boolean","object","array"].find(n=>o.includes(n));return t||(o.find(n=>n!=="null")??o[0]??"string")}return typeof o=="string"?o:"string"}var Ai=()=>structuredClone({model:"command-r-plus",embedModel:"embed-english-v3.0",...ve()}),Vu=()=>structuredClone({model:"command-r",embedModel:"embed-english-v3.0",...He()}),xi=class{constructor(e){this.config=e}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,topP:e.topP,topK:e.topK,frequencyPenalty:e.frequencyPenalty,presencePenalty:e.presencePenalty,endSequences:e.endSequences,stopSequences:e.stopSequences,stream:e.stream,n:e.n}}createChatReq(e){let t=e.model,n=e.chatPrompt.at(-1),r=e.chatPrompt.slice(0,-1),s;n&&n.role==="user"&&typeof n.content=="string"&&(s=n?.content);let i=Gd(r),a=e.functions?.map(p=>{let d={};if(p.parameters?.properties)for(let[m,g]of Object.entries(p.parameters.properties))d[m]={description:g.description,type:Ud(g.type),required:p.parameters.required?.includes(m)??!1};return{name:p.name,description:p.description,parameter_definitions:d}}),u=e.chatPrompt.filter(p=>p.role==="function").map(p=>{let d=a?.find(m=>m.name===p.functionId);if(!d)throw new Error("Function not found");return{call:{name:d.name,parameters:d.parameter_definitions},outputs:[{result:p.result??""}]}}),c={name:"/chat"},l={message:s,model:t,tools:a,...u&&!s?{tool_results:u}:{},chat_history:i,max_tokens:e.modelConfig?.maxTokens??this.config.maxTokens,...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},k:e.modelConfig?.topK??this.config.topK,...e.modelConfig?.topP!==void 0?{p:e.modelConfig.topP}:{},frequency_penalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty,end_sequences:this.config.endSequences,stop_sequences:e.modelConfig?.stopSequences??this.config.stopSequences};return[c,l]}createEmbedReq=e=>{let t=e.embedModel;if(!t)throw new Error("Embed model not set");if(!e.texts||e.texts.length===0)throw new Error("Embed texts is empty");let n={name:"/embed"},r={model:t,texts:e.texts??[],input_type:"classification",truncate:""};return[n,r]};createChatResp=e=>{this.tokensUsed=e.meta.billed_units?{promptTokens:e.meta.billed_units.input_tokens,completionTokens:e.meta.billed_units.output_tokens,totalTokens:e.meta.billed_units.input_tokens+e.meta.billed_units.output_tokens}:void 0;let t;if("finish_reason"in e)switch(e.finish_reason){case"COMPLETE":t="stop";break;case"MAX_TOKENS":t="length";break;case"ERROR":throw new Error("Finish reason: ERROR");case"ERROR_TOXIC":throw new Error("Finish reason: CONTENT_FILTER");default:t="stop";break}let n;return"tool_calls"in e&&(n=e.tool_calls?.map(s=>({id:s.name,type:"function",function:{name:s.name,params:s.parameters}}))),{results:[{index:0,id:e.generation_id,content:e.text,functionCalls:n,finishReason:t}],remoteId:e.response_id}};createChatStreamResp=(e,t)=>{let n=t;e.event_type==="stream-start"&&(n.generation_id=e.generation_id),this.tokensUsed={promptTokens:0,completionTokens:e.meta.billed_units?.output_tokens??0,totalTokens:e.meta.billed_units?.output_tokens??0};let{results:r}=this.createChatResp(e),s=r[0];if(!s)throw new Error("No result");return s.id=n.generation_id??"",{results:r}};createEmbedResp(e){return{remoteId:e.id,embeddings:e.embeddings}}},Cn=class extends je{constructor({apiKey:e,config:t,options:n,models:r}){if(!e||e==="")throw new Error("Cohere API key not set");let s={...Ai(),...t},i=new xi(s),a=r?.map(u=>{let c=u,l=c?.config;if(!l)return u;let p={};l.maxTokens!==void 0&&(p.maxTokens=l.maxTokens),l.temperature!==void 0&&(p.temperature=l.temperature),l.topP!==void 0&&(p.topP=l.topP),l.topK!==void 0&&(p.topK=l.topK),l.presencePenalty!==void 0&&(p.presencePenalty=l.presencePenalty),l.frequencyPenalty!==void 0&&(p.frequencyPenalty=l.frequencyPenalty),l.stopSequences!==void 0&&(p.stopSequences=l.stopSequences),l.endSequences!==void 0&&(p.endSequences=l.endSequences),l.stream!==void 0&&(p.stream=l.stream),l.n!==void 0&&(p.n=l.n);let d={...c};return Object.keys(p).length>0&&(d.modelConfig={...c.modelConfig??{},...p}),d});super(i,{name:"Cohere",apiURL:"https://api.cohere.ai/v1",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:So,defaults:{model:s.model},supportFor:{functions:!0,streaming:!0,media:{images:{supported:!1,formats:[],maxSize:0,detailLevels:[]},audio:{supported:!1,formats:[],maxDuration:0},files:{supported:!1,formats:[],maxSize:0,uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},options:n,models:a??r})}};function Gd(o){return o.map(e=>{let t="";if(e.role==="system"||e.role==="assistant"||e.role==="user")if(typeof e.content=="string")t=e.content;else throw new Error("Multi-modal content not supported");switch(e.role){case"user":return{role:"USER",message:t};case"system":return{role:"SYSTEM",message:t};case"assistant":{let n=Wu(e.functionCalls);return{role:"CHATBOT",message:t,tool_calls:n}}case"function":{let n=o.map(i=>{if(i.role==="assistant")return i.functionCalls?.find(a=>a.id===e.functionId)}).filter(i=>i!==void 0),r=Wu(n)?.at(0);if(!r)throw new Error("Function call not found");let s=[{result:e.result}];return{role:"TOOL",tool_results:[{call:r,outputs:s}]}}default:throw new Error("Unknown role")}})}function Wu(o){return o?.map(e=>{let t;if(typeof e.function.params=="string"){let n=e.function.params;if(n.trim().length===0)t={};else try{t=JSON.parse(n)}catch{throw new Error(`Failed to parse function params JSON: ${n}`)}}else t=e.function.params;return{name:e.function.name,parameters:t}})}var Cr=(n=>(n.DeepSeekChat="deepseek-chat",n.DeepSeekCoder="deepseek-coder",n.DeepSeekReasoner="deepseek-reasoner",n))(Cr||{});var ko=[{name:"deepseek-chat",currency:"USD",promptTokenCostPer1M:.27,completionTokenCostPer1M:1.1},{name:"deepseek-reasoner",currency:"USD",promptTokenCostPer1M:.55,completionTokenCostPer1M:2.19}];var yi=()=>structuredClone({model:"deepseek-chat",...ve()}),Ju=()=>structuredClone({model:"deepseek-coder",...He()}),In=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("DeepSeek API key not set");let i={...yi(),...t};s=[...ko,...s??[]],super({apiKey:e,config:i,options:n,apiURL:"https://api.deepseek.com",modelInfo:s,supportFor:{functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},models:r}),super.setName("DeepSeek")}};var Ir=(C=>(C.Gemini31Pro="gemini-3.1-pro-preview",C.Gemini3FlashLite="gemini-3.1-flash-lite-preview",C.Gemini3Flash="gemini-3-flash-preview",C.Gemini3Pro="gemini-3.1-pro-preview",C.Gemini3ProImage="gemini-3-pro-image-preview",C.Gemini25Pro="gemini-2.5-pro",C.Gemini25Flash="gemini-2.5-flash",C.Gemini25FlashLite="gemini-2.5-flash-lite",C.Gemini20Flash="gemini-2.0-flash",C.Gemini20FlashLite="gemini-2.0-flash-lite",C.Gemini20ProExp="gemini-2.0-pro-exp-02-05",C.Gemini20FlashThinkingExp="gemini-2.0-flash-thinking-exp-01-21",C.Gemini1Pro="gemini-1.0-pro",C.Gemini15Flash="gemini-1.5-flash",C.Gemini15Flash002="gemini-1.5-flash-002",C.Gemini15Flash8B="gemini-1.5-flash-8b",C.Gemini15Pro="gemini-1.5-pro",C.GeminiFlashLatest="gemini-flash-latest",C.GeminiFlashLiteLatest="gemini-flash-lite-latest",C.GeminiProLatest="gemini-pro-latest",C))(Ir||{}),Oo=(s=>(s.GeminiEmbedding001="gemini-embedding-001",s.GeminiEmbedding="gemini-embedding-exp",s.TextEmbeddingLarge="text-embedding-large-exp-03-07",s.TextEmbedding004="text-embedding-004",s.TextEmbedding005="text-embedding-005",s))(Oo||{}),Eo=(r=>(r.HarmCategoryHarassment="HARM_CATEGORY_HARASSMENT",r.HarmCategoryHateSpeech="HARM_CATEGORY_HATE_SPEECH",r.HarmCategorySexuallyExplicit="HARM_CATEGORY_SEXUALLY_EXPLICIT",r.HarmCategoryDangerousContent="HARM_CATEGORY_DANGEROUS_CONTENT",r))(Eo||{}),Mo=(s=>(s.BlockNone="BLOCK_NONE",s.BlockOnlyHigh="BLOCK_ONLY_HIGH",s.BlockMediumAndAbove="BLOCK_MEDIUM_AND_ABOVE",s.BlockLowAndAbove="BLOCK_LOW_AND_ABOVE",s.BlockDefault="HARM_BLOCK_THRESHOLD_UNSPECIFIED",s))(Mo||{}),bi=(u=>(u.SemanticSimilarity="SEMANTIC_SIMILARITY",u.Classification="CLASSIFICATION",u.Clustering="CLUSTERING",u.RetrievalDocument="RETRIEVAL_DOCUMENT",u.RetrievalQuery="RETRIEVAL_QUERY",u.QuestionAnswering="QUESTION_ANSWERING",u.FactVerification="FACT_VERIFICATION",u.CodeRetrievalQuery="CODE_RETRIEVAL_QUERY",u))(bi||{}),Qu=["gemini-3.1-pro-preview","gemini-3.1-pro-preview-customtools","gemini-3.1-flash-lite-preview","gemini-3-flash-preview","gemini-2.5-pro","gemini-2.5-flash","gemini-2.5-flash-lite","gemini-2.0-flash","gemini-2.0-flash-lite","gemini-flash-latest","gemini-flash-lite-latest"];var Po=[{name:"gemini-3.1-pro-preview",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:2,completionTokenCostPer1M:12,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-3-flash-preview",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.5,completionTokenCostPer1M:3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-3.1-flash-lite-preview",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.25,completionTokenCostPer1M:1.5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-3-pro-image-preview",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:2,completionTokenCostPer1M:.134,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.5-pro",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:2.5,completionTokenCostPer1M:15,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.0-pro-exp-02-05",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:0,completionTokenCostPer1M:0,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.0-flash-thinking-exp-01-21",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:0,completionTokenCostPer1M:0,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.5-flash",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:15,completionTokenCostPer1M:3.5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.5-flash-lite",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.1,completionTokenCostPer1M:.4,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-2.0-flash",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.01,completionTokenCostPer1M:.4,supported:{structuredOutputs:!0}},{name:"gemini-2.0-flash-lite",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:0,completionTokenCostPer1M:0,supported:{structuredOutputs:!0}},{name:"gemini-1.5-flash",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.075,completionTokenCostPer1M:.3,supported:{structuredOutputs:!0}},{name:"gemini-1.5-flash-8b",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.0375,completionTokenCostPer1M:.15,supported:{structuredOutputs:!0}},{name:"gemini-1.5-pro",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:1.25,completionTokenCostPer1M:5,supported:{structuredOutputs:!0}},{name:"gemini-1.0-pro",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.5,completionTokenCostPer1M:1.5,supported:{structuredOutputs:!0}},{name:"gemini-flash-latest",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:.075,completionTokenCostPer1M:.3,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-flash-lite-latest",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:0,completionTokenCostPer1M:0,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}},{name:"gemini-pro-latest",currency:"usd",characterIsToken:!1,promptTokenCostPer1M:1.25,completionTokenCostPer1M:5,supported:{thinkingBudget:!0,showThoughts:!0,structuredOutputs:!0}}];var tn=o=>o.includes("gemini-3"),Yu=o=>o.includes("gemini-3")&&o.includes("pro"),Fo=o=>{if(!o||typeof o!="object")return o;let e={...o};return delete e.additionalProperties,delete e.default,delete e.optional,delete e.maximum,delete e.oneOf,delete e.anyOf,Array.isArray(e.type)&&(e.type=e.type.includes("object")?"object":e.type[0]??"string"),e.properties&&typeof e.properties=="object"&&(e.properties=Object.fromEntries(Object.entries(e.properties).map(([t,n])=>[t,Fo(n)]))),e.items&&(e.items=Fo(e.items)),e},Xu=[{category:"HARM_CATEGORY_HARASSMENT",threshold:"BLOCK_NONE"},{category:"HARM_CATEGORY_HATE_SPEECH",threshold:"BLOCK_NONE"},{category:"HARM_CATEGORY_SEXUALLY_EXPLICIT",threshold:"BLOCK_NONE"},{category:"HARM_CATEGORY_DANGEROUS_CONTENT",threshold:"BLOCK_NONE"}],Ii=()=>structuredClone({model:"gemini-2.5-flash",embedModel:"text-embedding-005",safetySettings:Xu,thinkingTokenBudgetLevels:{minimal:200,low:800,medium:5e3,high:1e4,highest:24500},thinkingLevelMapping:{minimal:"minimal",low:"low",medium:"medium",high:"high",highest:"high"},...ve()}),Zu=()=>structuredClone({model:"gemini-2.0-flash",embedModel:"text-embedding-005",safetySettings:Xu,thinkingTokenBudgetLevels:{minimal:200,low:800,medium:5e3,high:1e4,highest:24500},thinkingLevelMapping:{minimal:"minimal",low:"low",medium:"medium",high:"high",highest:"high"},...He()}),Ci=class{constructor(e,t,n,r,s){this.config=e;this.isVertex=t;this.endpointId=n;this.apiKey=r;this.options=s;if(!this.isVertex&&this.config.autoTruncate)throw new Error("Auto truncate is not supported for GoogleGemini");let i=this.config.model;if(tn(i)){if(this.config.thinking?.thinkingTokenBudget!==void 0&&typeof this.config.thinking.thinkingTokenBudget=="number")throw new Error(`Gemini 3 models (${i}) do not support numeric thinkingTokenBudget. Use thinkingLevel ('low', 'medium', 'high') instead, or pass thinkingTokenBudget as a string level via options.`);if(Yu(i)&&this.config.thinking?.thinkingLevel){let a=this.config.thinking.thinkingLevel;if(a!=="low"&&a!=="high")throw new Error(`Gemini 3 Pro (${i}) only supports thinkingLevel 'low' or 'high', got '${a}'. Use 'low' for less thinking or 'high' for more thinking.`)}}}tokensUsed;models;setModels(e){this.models=e}getEffectiveMappings(e){let t=this.models?.find(n=>n.model===e);return{thinkingLevelMapping:{...this.config.thinkingLevelMapping,...t?.thinkingLevelMapping??{}},thinkingTokenBudgetLevels:{...this.config.thinkingTokenBudgetLevels,...t?.thinkingTokenBudgetLevels??{}}}}getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,topP:e.topP,topK:e.topK,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,stopSequences:e.stopSequences,endSequences:e.endSequences,stream:e.stream,n:e.n}}createChatReq=async(e,t)=>{let n=e.model,r=e.modelConfig?.stream??this.config.stream;if(!e.chatPrompt||e.chatPrompt.length===0)throw new Error("Chat prompt is empty");let s;if(this.endpointId?s={name:r?`/${this.endpointId}:streamGenerateContent?alt=sse`:`/${this.endpointId}:generateContent`}:s={name:r?`/models/${n}:streamGenerateContent?alt=sse`:`/models/${n}:generateContent`},!this.isVertex){let h=r?"&":"?",y=typeof this.apiKey=="function"?await this.apiKey():this.apiKey;s.name+=`${h}key=${y}`}let i=e.chatPrompt.filter(h=>h.role==="system").map(h=>h.content),a=i.length>0?{role:"user",parts:[{text:i.join(" ")}]}:void 0,u=[],c=e.chatPrompt.filter(h=>h.role!=="system");for(let h=0;h<c.length;h++){let y=c[h];switch(y.role){case"user":{let C=Array.isArray(y.content)?y.content.map((I,v)=>{switch(I.type){case"text":return{text:I.text};case"image":return{inlineData:{mimeType:I.mimeType,data:I.image}};case"audio":return{inlineData:{mimeType:`audio/${I.format??"mp3"}`,data:I.data}};case"file":return"fileUri"in I?{fileData:{mimeType:I.mimeType,fileUri:I.fileUri}}:{inlineData:{mimeType:I.mimeType,data:I.data}};default:throw new Error(`Chat prompt content type not supported (index: ${v})`)}}):[{text:y.content}];u.push({role:"user",parts:C});break}case"assistant":{let C=[],I=y.thoughtBlocks,v=y.functionCalls&&y.functionCalls.length>0,O=I?.[0],R=I?.map(S=>S.data).join("")??"",E=O?.signature;if(R&&C.push({...v?{}:{thought:!0},text:R,...E&&!v?{thought_signature:E}:{}}),y.functionCalls){let S=y.functionCalls.map((_,$)=>{let M;if(typeof _.function.params=="string"){let N=_.function.params;if(N.trim().length===0)M={};else try{M=JSON.parse(N)}catch{throw new Error(`Failed to parse function params JSON: ${N}`)}}else M=_.function.params;let F={functionCall:{name:_.function.name,args:M}};return E&&$===0&&(F.thought_signature=E),F});C.push(...S)}if(y.content&&C.push({text:y.content}),C.length===0)throw new Error("Assistant content is empty");u.push({role:"model",parts:C});break}case"function":{let C=[],I=y,v=h;for(;;){if(!("functionId"in I))throw new Error(`Chat prompt functionId is empty (index: ${v})`);if(C.push({functionResponse:{name:I.functionId,response:{result:I.result}}}),v+1<c.length&&c[v+1].role==="function")v++,I=c[v];else break}h=v,u.push({role:"user",parts:C});break}default:throw new Error(`Invalid role: ${JSON.stringify(y)} (index: ${h})`)}}let l=[];if(e.functions&&e.functions.length>0){let h=e.functions.map(y=>{let C={type:"object",properties:{dummy:{type:"string",description:"An optional dummy parameter, do not use"}},required:[]},I=y.parameters?Fo(y.parameters):void 0;return I===void 0||I&&typeof I=="object"&&Object.keys(I).length===0?I={...C}:I&&typeof I=="object"&&I.type==="object"&&(!("properties"in I)||!I.properties||Object.keys(I.properties).length===0)&&(I={...I,properties:{dummy:{type:"string",description:"An optional dummy parameter, do not use"}},required:[]}),{name:y.name,description:y.description,parameters:I}});l.push({function_declarations:h})}if(this.options?.codeExecution&&l.push({code_execution:{}}),this.options?.googleSearchRetrieval&&l.push({google_search_retrieval:{dynamic_retrieval_config:this.options.googleSearchRetrieval}}),this.options?.googleSearch&&l.push({google_search:{}}),this.options?.googleMaps){let h=this.options.googleMaps,y=h?.enableWidget!==void 0?{enableWidget:h.enableWidget}:{};l.push({google_maps:y})}this.options?.urlContext&&l.push({url_context:{}}),l.length===0&&(l=void 0);let p,d=Array.isArray(l)?l.some(h=>h&&Array.isArray(h.function_declarations)&&h.function_declarations.length>0):!1;if(e.functionCall)if(e.functionCall==="none")p={function_calling_config:{mode:"NONE"}};else if(e.functionCall==="auto")p={function_calling_config:{mode:"AUTO"}};else if(e.functionCall==="required")p={function_calling_config:{mode:"ANY"}};else{let h=e.functionCall.function?.name?{allowedFunctionNames:[e.functionCall.function.name]}:{};p={function_calling_config:{mode:"ANY"},...h}}else d&&(p={function_calling_config:{mode:"AUTO"}});this.options?.retrievalConfig&&(p={...p??{},retrievalConfig:{...this.options.retrievalConfig.latLng?{latLng:this.options.retrievalConfig.latLng}:{}}});let m={};if(this.config.thinking?.includeThoughts&&(m.includeThoughts=!0),this.config.thinking?.thinkingTokenBudget&&(m.thinkingBudget=this.config.thinking.thinkingTokenBudget),this.config.thinking?.thinkingLevel&&tn(n)&&(m.thinkingLevel=this.config.thinking.thinkingLevel),t?.thinkingTokenBudget){let h=this.getEffectiveMappings(n),y=h.thinkingTokenBudgetLevels;if(tn(n)){let I=Yu(n),v=h.thinkingLevelMapping;if(t.thinkingTokenBudget==="none")m.thinkingLevel=v?.minimal??"minimal";else{let O=t.thinkingTokenBudget,R=v?.[O];R||(R=O==="highest"?"high":O),m.thinkingLevel=R}if(I&&m.thinkingLevel){let O=m.thinkingLevel;O!=="low"&&O!=="high"&&(m.thinkingLevel=O==="minimal"?"low":"high")}}else switch(t.thinkingTokenBudget){case"none":m.thinkingBudget=0,m.includeThoughts=!1,delete m.thinkingLevel;break;case"minimal":m.thinkingBudget=y?.minimal??200;break;case"low":m.thinkingBudget=y?.low??800;break;case"medium":m.thinkingBudget=y?.medium??5e3;break;case"high":m.thinkingBudget=y?.high??1e4;break;case"highest":m.thinkingBudget=y?.highest??24500;break}}m.thinkingLevel&&delete m.thinkingBudget,tn(n)||delete m.thinkingLevel,tn(n)&&delete m.thinkingBudget;let g=e.modelConfig?.maxTokens??this.config.maxTokens;if(m.thinkingLevel&&g!==void 0)throw new Error("Cannot set maxTokens when using thinkingLevel with Gemini models. When thinking is enabled, the model manages output tokens automatically. Remove the maxTokens setting or disable thinking.");t?.showThoughts!==void 0&&t?.thinkingTokenBudget!=="none"&&(m.includeThoughts=t.showThoughts);let f={maxOutputTokens:e.modelConfig?.maxTokens??this.config.maxTokens,temperature:e.modelConfig?.temperature??this.config.temperature,...e.modelConfig?.topP!==void 0?{topP:e.modelConfig.topP}:{},topK:e.modelConfig?.topK??this.config.topK,frequencyPenalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,candidateCount:1,stopSequences:e.modelConfig?.stopSequences??this.config.stopSequences,responseMimeType:"text/plain",...Object.keys(m).length>0?{thinkingConfig:m}:{}};if(tn(n)&&(f.temperature===void 0||f.temperature<1)&&(f.temperature=1),e.responseFormat){if(f.responseMimeType="application/json",e.responseFormat.type==="json_schema"&&e.responseFormat.schema){let h=e.responseFormat.schema.schema||e.responseFormat.schema;f.responseSchema=Fo(h)}}else this.config.responseFormat&&this.config.responseFormat==="json_object"&&(f.responseMimeType="application/json");let x=this.config.safetySettings;return[s,{contents:u,tools:l,toolConfig:p,systemInstruction:a,generationConfig:f,safetySettings:x}]};createEmbedReq=async e=>{let t=e.embedModel;if(!t)throw new Error("Embed model not set");if(!e.texts||e.texts.length===0)throw new Error("Embed texts is empty");let n,r;if(this.isVertex)this.endpointId?n={name:`/${this.endpointId}:predict`}:n={name:`/models/${t}:predict`},r={instances:e.texts.map(s=>({content:s,...this.config.embedType&&{taskType:this.config.embedType}})),parameters:{autoTruncate:this.config.autoTruncate,outputDimensionality:this.config.dimensions}};else{let s=typeof this.apiKey=="function"?this.apiKey():this.apiKey;n={name:`/models/${t}:batchEmbedContents?key=${s}`},r={requests:e.texts.map(i=>({model:`models/${t}`,content:{parts:[{text:i}]},outputDimensionality:this.config.dimensions,...this.config.embedType&&{taskType:this.config.embedType}}))}}return[n,r]};createChatResp=e=>{let t,n=e.candidates?.map(s=>{let i={index:0};switch(s.finishReason){case"MAX_TOKENS":i.finishReason="length";break;case"STOP":i.finishReason="stop";break;case"SAFETY":throw new Le("Content was blocked due to safety settings",void 0,void 0);case"RECITATION":throw new Le("Content was blocked due to recitation policy",void 0,void 0);case"MALFORMED_FUNCTION_CALL":throw new Le("Function call was malformed and blocked",void 0,void 0);case"UNEXPECTED_TOOL_CALL":throw new Le("Unexpected tool call",void 0,void 0);case"FINISH_REASON_UNSPECIFIED":throw new Le("Finish reason unspecified",void 0,void 0);case"BLOCKLIST":throw new Le("Content was blocked due to blocklist",void 0,void 0);case"PROHIBITED_CONTENT":throw new Le("Content was blocked due to prohibited content",void 0,void 0);case"SPII":throw new Le("Content was blocked due to SPII",void 0,void 0);case"OTHER":throw new Le("Other finish reason",void 0,void 0)}if(!s.content||!s.content.parts)return i;for(let c of s.content.parts){if("text"in c){if("thought"in c&&c.thought||c.thought===!0){i.thought=c.text;let l=c.thoughtSignature||c.thought_signature;i.thoughtBlocks||(i.thoughtBlocks=[]),i.thoughtBlocks.push({data:c.text,encrypted:!1,...l?{signature:l}:{}})}else i.content=c.text;continue}if("functionCall"in c){let l=c.thoughtSignature||c.thought_signature;if(l)if(!i.thoughtBlocks||i.thoughtBlocks.length===0)i.thoughtBlocks=[{data:"",encrypted:!1,signature:l}];else{let p=i.thoughtBlocks[i.thoughtBlocks.length-1];p&&!p.signature&&(p.signature=l)}i.functionCalls=[...i.functionCalls??[],{id:Ze(),type:"function",function:{name:c.functionCall.name,params:c.functionCall.args}}]}}let a=s.citationMetadata?.citations;if(Array.isArray(a)&&a.length){let c=l=>l?`${l.year}-${String(l.month).padStart(2,"0")}-${String(l.day).padStart(2,"0")}`:void 0;i.citations=a.filter(l=>typeof l?.uri=="string").map(l=>({url:l.uri,title:l.title,license:l.license,publicationDate:c(l.publicationDate)}))}let u=s.groundingMetadata;if(u){if(Array.isArray(u.groundingChunks)){let c=u.groundingChunks.map(l=>l?.maps).filter(l=>l&&typeof l.uri=="string").map(l=>({url:l.uri,title:l.title}));c.length&&(i.citations=[...i.citations??[],...c])}typeof u.googleMapsWidgetContextToken=="string"&&(t=u.googleMapsWidgetContextToken)}return i});e.usageMetadata&&(this.tokensUsed={totalTokens:e.usageMetadata.totalTokenCount,promptTokens:e.usageMetadata.promptTokenCount,completionTokens:e.usageMetadata.candidatesTokenCount,thoughtsTokens:e.usageMetadata.thoughtsTokenCount,...e.usageMetadata.cachedContentTokenCount!==void 0?{cacheReadTokens:e.usageMetadata.cachedContentTokenCount}:{}});let r={results:n};return t&&(r.providerMetadata={...r.providerMetadata,google:{...r.providerMetadata?.google??{},mapsWidgetContextToken:t}}),r};createChatStreamResp=e=>this.createChatResp(e);createEmbedResp=e=>{let t;return this.isVertex?t=e.predictions.map(n=>n.embeddings.values):t=e.embeddings.map(n=>n.values),{embeddings:t}};supportsContextCache=e=>{let t=e;return Qu.some(n=>t.includes(n)||n.includes(t))};buildCacheCreateOp=(e,t)=>{let n=e.model,r=t.contextCache?.ttlSeconds??3600,{systemInstruction:s,contents:i}=this.extractCacheableContent(e.chatPrompt);if(!s&&(!i||i.length===0))return;let a={model:this.isVertex?n:`models/${n}`,ttl:`${r}s`,displayName:`ax-cache-${Date.now()}`};s&&(a.systemInstruction=s),i&&i.length>0&&(a.contents=i);let u;if(this.isVertex)u="/cachedContents";else{u="/cachedContents";let c=typeof this.apiKey=="function"?"ASYNC_KEY":this.apiKey;u+=`?key=${c}`}return{type:"create",apiConfig:{name:u},request:a,parseResponse:c=>{let l=c;if(l?.name)return{name:l.name,expiresAt:l.expireTime,tokenCount:l.usageMetadata?.totalTokenCount}}}};buildCacheUpdateTTLOp=(e,t)=>{let n={ttl:`${t}s`},r=`/${e}`;if(!this.isVertex&&this.apiKey){let s=typeof this.apiKey=="function"?"ASYNC_KEY":this.apiKey;r+=`?key=${s}`}return{type:"update",apiConfig:{name:r,headers:{"Content-Type":"application/json"}},request:n,parseResponse:s=>{let i=s;if(i?.name)return{name:i.name,expiresAt:i.expireTime,tokenCount:i.usageMetadata?.totalTokenCount}}}};buildCacheDeleteOp=e=>{let t=`/${e}`;if(!this.isVertex&&this.apiKey){let n=typeof this.apiKey=="function"?"ASYNC_KEY":this.apiKey;t+=`?key=${n}`}return{type:"delete",apiConfig:{name:t,headers:{"Content-Type":"application/json"}},request:{},parseResponse:()=>{}}};prepareCachedChatReq=async(e,t,n)=>{let r=e.model,s=e.modelConfig?.stream??this.config.stream,{dynamicContents:i,dynamicSystemInstruction:a}=this.extractDynamicContent(e.chatPrompt),u;if(this.endpointId?u={name:s?`/${this.endpointId}:streamGenerateContent?alt=sse`:`/${this.endpointId}:generateContent`}:u={name:s?`/models/${r}:streamGenerateContent?alt=sse`:`/models/${r}:generateContent`},!this.isVertex){let d=s?"&":"?",m=typeof this.apiKey=="function"?await this.apiKey():this.apiKey;u.name+=`${d}key=${m}`}let c={maxOutputTokens:e.modelConfig?.maxTokens??this.config.maxTokens,temperature:e.modelConfig?.temperature??this.config.temperature,...e.modelConfig?.topP!==void 0?{topP:e.modelConfig.topP}:{},topK:e.modelConfig?.topK??this.config.topK,frequencyPenalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,candidateCount:1,stopSequences:e.modelConfig?.stopSequences??this.config.stopSequences,responseMimeType:"text/plain"};tn(r)&&(c.temperature===void 0||c.temperature<1)&&(c.temperature=1);let l=this.config.safetySettings,p={contents:i,cachedContent:n,generationConfig:c,safetySettings:l};return a&&(p.systemInstruction=a),{apiConfig:u,request:p}};extractCacheableContent(e){let t,n=[],r=-1;for(let s=e.length-1;s>=0;s--){let i=e[s];if("cache"in i&&i.cache){r=s;break}}for(let s=0;s<e.length;s++){let i=e[s];if(i.role==="system"){t={role:"user",parts:[{text:i.content}]};continue}if(r>=0&&s<=r)if(i.role==="user"){let a=[];if(typeof i.content=="string")a.push({text:i.content});else if(Array.isArray(i.content))for(let u of i.content)switch(u.type){case"text":a.push({text:u.text});break;case"image":a.push({inlineData:{mimeType:u.mimeType,data:u.image}});break;case"audio":a.push({inlineData:{mimeType:`audio/${u.format??"mp3"}`,data:u.data}});break;case"file":"fileUri"in u?a.push({fileData:{mimeType:u.mimeType,fileUri:u.fileUri}}):a.push({inlineData:{mimeType:u.mimeType,data:u.data}});break}a.length>0&&n.push({role:"user",parts:a})}else i.role==="assistant"&&i.content&&n.push({role:"model",parts:[{text:i.content}]})}return{systemInstruction:t,contents:n}}extractDynamicContent(e){let n=[];for(let r of e)if(r.role!=="system"&&!("cache"in r&&r.cache))if(r.role==="user"){let s=[];if(typeof r.content=="string")s.push({text:r.content});else if(Array.isArray(r.content)){for(let i of r.content)if(!("cache"in i&&i.cache))switch(i.type){case"text":s.push({text:i.text});break;case"image":s.push({inlineData:{mimeType:i.mimeType,data:i.image}});break;case"audio":s.push({inlineData:{mimeType:`audio/${i.format??"mp3"}`,data:i.data}});break;case"file":"fileUri"in i?s.push({fileData:{mimeType:i.mimeType,fileUri:i.fileUri}}):s.push({inlineData:{mimeType:i.mimeType,data:i.data}});break}}s.length>0&&n.push({role:"user",parts:s})}else if(r.role==="assistant"){let s=[];if(r.content&&s.push({text:r.content}),r.functionCalls)for(let i of r.functionCalls){let a;if(typeof i.function.params=="string")try{a=JSON.parse(i.function.params)}catch{a={}}else a=i.function.params??{};s.push({functionCall:{name:i.function.name,args:a}})}s.length>0&&n.push({role:"model",parts:s})}else r.role==="function"&&n.push({role:"user",parts:[{functionResponse:{name:r.functionId,response:{result:r.result}}}]});return{dynamicContents:n,dynamicSystemInstruction:void 0}}},Tn=class o extends je{static create(e){return new o(e)}constructor({apiKey:e,projectId:t,region:n,endpointId:r,config:s,options:i,models:a,modelInfo:u}){let c=t!==void 0&&n!==void 0,l,p;if(c){if(!e)throw new Error("GoogleGemini Vertex API key not set");if(typeof e!="function")throw new Error("GoogleGemini Vertex API key must be a function for token-based authentication");let x;r?x="endpoints":x="publishers/google",l=`https://${n==="global"?"aiplatform":`${n}-aiplatform`}.googleapis.com/v1/projects/${t}/locations/${n}/${x}`,p=async()=>({Authorization:`Bearer ${typeof e=="function"?await e():e}`})}else{if(!e)throw new Error("GoogleGemini AI API key not set");l="https://generativelanguage.googleapis.com/v1beta",p=async()=>({})}let d={...Ii(),...s},m=new Ci(d,c,r,e,i);u=[...Po,...u??[]];let g=x=>{let A=mt({model:x,modelInfo:u,models:a});return{functions:!0,streaming:!0,hasThinkingBudget:A?.supported?.thinkingBudget??!1,hasShowThoughts:A?.supported?.showThoughts??!1,structuredOutputs:A?.supported?.structuredOutputs??!1,media:{images:{supported:!0,formats:["image/jpeg","image/png","image/gif","image/webp"],maxSize:20*1024*1024,detailLevels:["high","low","auto"]},audio:{supported:!0,formats:["wav","mp3","aac","ogg"],maxDuration:9.5*60},files:{supported:!0,formats:["application/pdf","text/plain","text/csv","text/html","text/xml"],maxSize:2*1024*1024*1024,uploadMethod:"cloud"},urls:{supported:!0,webSearch:!0,contextFetching:!0}},caching:{supported:m.supportsContextCache(x),types:["persistent"]},thinking:A?.supported?.thinkingBudget??!1,multiTurn:!0}},f=a?.map(x=>{let A=x,h=A?.config;if(!h)return x;let y={};h.maxTokens!==void 0&&(y.maxTokens=h.maxTokens),h.temperature!==void 0&&(y.temperature=h.temperature),h.topP!==void 0&&(y.topP=h.topP),h.topK!==void 0&&(y.topK=h.topK),h.presencePenalty!==void 0&&(y.presencePenalty=h.presencePenalty),h.frequencyPenalty!==void 0&&(y.frequencyPenalty=h.frequencyPenalty),h.stopSequences!==void 0&&(y.stopSequences=h.stopSequences),h.endSequences!==void 0&&(y.endSequences=h.endSequences),h.stream!==void 0&&(y.stream=h.stream),h.n!==void 0&&(y.n=h.n);let C={...A};Object.keys(y).length>0&&(C.modelConfig={...A.modelConfig??{},...y});let I=h.thinking?.thinkingTokenBudget;if(typeof I=="number"){let v=d.thinkingTokenBudgetLevels,O=[["minimal",v?.minimal??200],["low",v?.low??800],["medium",v?.medium??5e3],["high",v?.high??1e4],["highest",v?.highest??24500]],R="minimal",E=Number.POSITIVE_INFINITY;for(let[S,_]of O){let $=Math.abs(I-_);$<E&&(E=$,R=S)}C.thinkingTokenBudget=R}return h.thinking?.includeThoughts!==void 0&&(C.showThoughts=!!h.thinking.includeThoughts),h.thinkingLevelMapping&&(C.thinkingLevelMapping=h.thinkingLevelMapping),h.thinkingTokenBudgetLevels&&(C.thinkingTokenBudgetLevels=h.thinkingTokenBudgetLevels),C});f?m.setModels(f):a&&m.setModels(a),super(m,{name:"GoogleGeminiAI",apiURL:l,headers:p,modelInfo:u,defaults:{model:d.model,embedModel:d.embedModel},options:i,supportFor:g,models:f??a})}};var jd=new ot,wn=class{options;maxTokens;refillRate;currentTokens;lastRefillTime;constructor(e,t,n){this.maxTokens=e,this.refillRate=t,this.currentTokens=e,this.lastRefillTime=Date.now(),this.options=n}refillTokens(){let e=Date.now(),n=(e-this.lastRefillTime)/1e3*this.refillRate;this.currentTokens=Math.min(this.maxTokens,this.currentTokens+n),this.lastRefillTime=e}async waitUntilTokensAvailable(e){if(this.refillTokens(),this.currentTokens>=e){this.currentTokens-=e;return}return this.options?.debug&&console.log(jd.red(`Rate limiter: Waiting for ${e-this.currentTokens} tokens`)),await new Promise(t=>setTimeout(t,100)),this.waitUntilTokensAvailable(e)}async acquire(e){await this.waitUntilTokensAvailable(e)}};var Tr=(r=>(r.Llama3_8B="llama3-8b-8192",r.Llama33_70B="llama-3.3-70b-versatile",r.Mixtral_8x7B="mixtral-8x7b-32768",r.Gemma2_9B="gemma2-9b-it",r))(Tr||{});var _o=[{name:"gemma2-9b-it",currency:"usd",characterIsToken:!0,promptTokenCostPer1M:.2,completionTokenCostPer1M:.2},{name:"llama-3.3-70b-versatile",currency:"usd",characterIsToken:!0,promptTokenCostPer1M:.59,completionTokenCostPer1M:.79},{name:"llama3-8b-8192",currency:"usd",characterIsToken:!0,promptTokenCostPer1M:.05,completionTokenCostPer1M:.08},{name:"mixtral-8x7b-32768",currency:"usd",characterIsToken:!0,promptTokenCostPer1M:.24,completionTokenCostPer1M:.24}];var Bd=()=>structuredClone({model:"llama-3.3-70b-versatile",...ve()}),Rn=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("Groq API key not set");let i={...Bd(),...t},a={...n,streamingUsage:!1};s=[..._o,...s??[]];let u={functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0};super({apiKey:e,config:i,options:a,modelInfo:s,apiURL:"https://api.groq.com/openai/v1",models:r,supportFor:u}),super.setName("Groq"),this.setOptions(a)}setOptions=e=>{let t=this.newRateLimiter(e);super.setOptions({...e,rateLimiter:t})};newRateLimiter=e=>{if(e?.rateLimiter)return e.rateLimiter;let t=e?.tokensPerMinute??4800,n=new wn(t,t/60,{debug:e?.debug});return async(s,i)=>{let a=i.modelUsage?.tokens?.totalTokens||0;return await n.acquire(a),await s()}}};var No=[];var Lo=(e=>(e.MetaLlama270BChatHF="meta-llama/Llama-2-70b-chat-hf",e))(Lo||{});var wi=()=>structuredClone({model:"meta-llama/Llama-2-70b-chat-hf",...ve()}),ec=()=>structuredClone({model:"meta-llama/Llama-2-70b-chat-hf",...He()}),Ti=class{constructor(e){this.config=e}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,topP:e.topP,topK:e.topK,n:e.n,presencePenalty:e.presencePenalty}}createChatReq=e=>{let t=e.model,n=e.functions?`Functions:
170
170
  ${JSON.stringify(e.functions,null,2)}
171
- `:"",r=e.chatPrompt?.map(l=>{switch(l.role){case"user":return`User: ${l.content}`;case"system":return`System: ${l.content}`;case"function":return`Function Result: ${l.result}`;case"assistant":{let c=l.functionCalls?.map(u=>{let p=typeof u.function.params=="string"?u.function.params:JSON.stringify(u.function.params);return`${u.function.name}(${p})`}).join(`
172
- `);return c?`Assistant: ${l.content}
171
+ `:"",r=e.chatPrompt?.map(u=>{switch(u.role){case"user":return`User: ${u.content}`;case"system":return`System: ${u.content}`;case"function":return`Function Result: ${u.result}`;case"assistant":{let c=u.functionCalls?.map(l=>{let p=typeof l.function.params=="string"?l.function.params:JSON.stringify(l.function.params);return`${l.function.name}(${p})`}).join(`
172
+ `);return c?`Assistant: ${u.content}
173
173
  Functions:
174
- ${c}`:`Assistant: ${l.content}`}default:throw new Error("Unknown role")}}).join(`
175
- `),s=`${n} ${r}`.trim(),i={name:"/models"},a={model:t,inputs:s,parameters:{max_new_tokens:e.modelConfig?.maxTokens??this.config.maxTokens,repetition_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty,...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},top_k:e.modelConfig?.topK??this.config.topK,return_full_text:this.config.returnFullText,num_return_sequences:this.config.n,do_sample:this.config.doSample,max_time:this.config.maxTime},options:{use_cache:this.config.useCache,wait_for_model:this.config.waitForModel}};return[i,a]};createChatResp=e=>({results:[{index:0,content:e.generated_text}]})},Cn=class extends Be{constructor({apiKey:e,config:t,options:n,models:r}){if(!e||e==="")throw new Error("HuggingFace API key not set");let s={...yi(),...t},i=new Ai(s);super(i,{name:"HuggingFace",apiURL:"https://api-inference.huggingface.co",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:Mo,defaults:{model:s.model},options:n,supportFor:{functions:!1,streaming:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},models:r})}};var Cr=(l=>(l.Mistral7B="open-mistral-7b",l.Mistral8x7B="open-mixtral-8x7b",l.MistralSmall="mistral-small-latest",l.MistralNemo="mistral-nemo-latest",l.MistralLarge="mistral-large-latest",l.Codestral="codestral-latest",l.OpenCodestralMamba="open-codestral-mamba",l.OpenMistralNemo="open-mistral-nemo-latest",l))(Cr||{}),bi=(e=>(e.MistralEmbed="mistral-embed",e))(bi||{});var Fo=[{name:"open-mistral-7b",currency:"USD",promptTokenCostPer1M:.25,completionTokenCostPer1M:.25},{name:"open-mixtral-8x7b",currency:"USD",promptTokenCostPer1M:.7,completionTokenCostPer1M:.7},{name:"mistral-nemo-latest",currency:"USD",promptTokenCostPer1M:.15,completionTokenCostPer1M:.15},{name:"mistral-small-latest",currency:"USD",promptTokenCostPer1M:.2,completionTokenCostPer1M:.6},{name:"mistral-large-latest",currency:"USD",promptTokenCostPer1M:2,completionTokenCostPer1M:6},{name:"codestral-latest",currency:"USD",promptTokenCostPer1M:.2,completionTokenCostPer1M:.6},{name:"open-codestral-mamba",currency:"USD",promptTokenCostPer1M:.25,completionTokenCostPer1M:.25},{name:"open-mistral-nemo-latest",currency:"USD",promptTokenCostPer1M:.3,completionTokenCostPer1M:.3}];var _o=()=>structuredClone({model:"mistral-small-latest",...we(),topP:1}),jl=()=>structuredClone({..._o(),model:"mistral-large-latest"}),In=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("Mistral API key not set");let i={..._o(),...t};s=[...Fo,...s??[]];let a={functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},l=c=>{let{max_completion_tokens:u,messages:p,...d}=c;return{...d,messages:this.updateMessages(p),max_tokens:u}};super({apiKey:e,config:i,options:n,apiURL:"https://api.mistral.ai/v1",modelInfo:s,models:r,supportFor:a,chatReqUpdater:l}),super.setName("Mistral")}updateMessages(e){let t=[];if(!Array.isArray(e))return e;for(let n of e)if(n.role==="user"&&Array.isArray(n.content)){let r=n.content.map(s=>typeof s=="object"&&s!==null&&"image_url"in s?{type:"image_url",image_url:{url:s.image_url?.url}}:s);t.push({...n,content:r})}else t.push(n);return t}};var No=class{constructor(e={}){this.config=e;this.config.id=this.config.id??Ze()}metrics={latency:{chat:{mean:0,p95:0,p99:0,samples:[]},embed:{mean:0,p95:0,p99:0,samples:[]}},errors:{chat:{count:0,rate:0,total:0},embed:{count:0,rate:0,total:0}}};getLastUsedChatModel(){return this.config.modelInfo?.name??"mock-model"}getLastUsedEmbedModel(){return this.config.embedModelInfo?.name??"mock-embed-model"}getLastUsedModelConfig(){return this.config.modelInfo?{maxTokens:this.config.modelInfo.maxTokens,temperature:.7,stream:this.config.features?.streaming??!1}:void 0}getName(){return this.config.name??"mock-ai-service"}getId(){return this.config.id??"mock-ai-service-id"}getFeatures(e){let t=this.config.features?.media;return{functions:this.config.features?.functions??!1,streaming:this.config.features?.streaming??!1,structuredOutputs:this.config.features?.structuredOutputs??!1,media:{images:{supported:t?.images?.supported??!1,formats:t?.images?.formats??[]},audio:{supported:t?.audio?.supported??!1,formats:t?.audio?.formats??[]},files:{supported:t?.files?.supported??!1,formats:t?.files?.formats??[],uploadMethod:t?.files?.uploadMethod??"none"},urls:{supported:t?.urls?.supported??!1,webSearch:t?.urls?.webSearch??!1,contextFetching:t?.urls?.contextFetching??!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}}getModelList(){return this.config.models}getMetrics(){return this.metrics}async chat(e,t){if(this.config.latencyMs&&await new Promise(n=>setTimeout(n,this.config.latencyMs)),this.config.shouldError)throw new Error(this.config.errorMessage??"Mock chat error");return this.updateMetrics("chat"),typeof this.config.chatResponse=="function"?await this.config.chatResponse(e):this.config.chatResponse??{results:[{index:0,content:"Mock response",finishReason:"stop"}],modelUsage:{ai:this.getName(),model:"mock-model",tokens:{promptTokens:10,completionTokens:5,totalTokens:15}}}}async embed(e,t){if(this.config.latencyMs&&await new Promise(n=>setTimeout(n,this.config.latencyMs)),this.config.shouldError)throw new Error(this.config.errorMessage??"Mock embed error");return this.updateMetrics("embed"),typeof this.config.embedResponse=="function"?this.config.embedResponse(e):this.config.embedResponse??{embeddings:[[.1,.2,.3]],modelUsage:{ai:this.getName(),model:"mock-model",tokens:{promptTokens:5,completionTokens:0,totalTokens:5}}}}setOptions(e){this.config.options=e}getOptions(){return this.config.options??{}}getLogger(){return this.config.options?.logger??(e=>{console.log(e)})}updateMetrics(e){let t=this.config.latencyMs??0;this.metrics.latency[e].samples.push(t);let n=this.metrics.latency[e].samples;if(this.metrics.latency[e].mean=n.reduce((r,s)=>r+s,0)/n.length,n.length>0){let r=[...n].sort((a,l)=>a-l),s=Math.max(0,Math.floor(r.length*.95)-1);this.metrics.latency[e].p95=r[s]??t;let i=Math.max(0,Math.floor(r.length*.99)-1);this.metrics.latency[e].p99=r[i]??t}if(this.config.shouldError){this.metrics.errors[e].count++,this.metrics.errors[e].total++;let r=this.metrics.latency[e].samples.length;this.metrics.errors[e].rate=r>0?this.metrics.errors[e].count/r:0}}};var Lo=class o{options;lastUsedService;services=new Map;constructor(e){if(e.length===0)throw new Error("No AI services provided.");for(let[t,n]of e.entries())if("key"in n){if(this.services.has(n.key))throw new Error(`Duplicate model key: ${n.key}`);let{service:s,description:i,isInternal:a}=n;this.services.set(n.key,{service:s,description:i,isInternal:a})}else{let s=n.getModelList();if(!s)throw new Error(`Service ${t} \`${n.getName()}\` has no model list.`);for(let i of s){if(this.services.has(i.key)){let a=this.services.get(i.key)?.service;throw new Error(`Service ${t} \`${n.getName()}\` has duplicate model key: ${i.key} as service ${a?.getName()}`)}if("model"in i&&typeof i.model)this.services.set(i.key,{description:i.description,service:n,model:i.model});else if("embedModel"in i&&i.embedModel)this.services.set(i.key,{description:i.description,service:n,embedModel:i.embedModel});else throw new Error(`Key ${i.key} in model list for service ${t} \`${n.getName()}\` is missing a model or embedModel property.`)}}}static create(e){return new o(e)}getLastUsedChatModel(){return this.lastUsedService?.getLastUsedChatModel()}getLastUsedEmbedModel(){return this.lastUsedService?.getLastUsedEmbedModel()}getLastUsedModelConfig(){return this.lastUsedService?.getLastUsedModelConfig()}async chat(e,t){let n=e.model;if(!n)throw new Error("Model key must be specified for multi-service");let r=this.services.get(n);if(!r)throw new Error(`No service found for model key: ${n}`);if(this.lastUsedService=r.service,!r.model){let{model:s,...i}=e;return await r.service.chat(i,t)}return await r.service.chat({model:n,...e},t)}async embed(e,t){let n=e.embedModel;if(!n)throw new Error("Embed model key must be specified for multi-service");let r=this.services.get(n);if(!r)throw new Error(`No service found for embed model key: ${n}`);if(this.lastUsedService=r.service,!r.model){let{embedModel:s,...i}=e;return await r.service.embed(i,t)}return await r.service.embed({embedModel:n,...e},t)}getId(){return`MultiServiceRouter:${Array.from(this.services.values()).map(e=>e.service.getId()).join(",")}`}getName(){return"MultiServiceRouter"}getModelList(){return Array.from(this.services).filter(([,e])=>!e.isInternal).map(([e,t])=>{if(t.model)return{key:e,description:t.description,model:t.model};if(t.embedModel)return{key:e,description:t.description,embedModel:t.embedModel};throw new Error(`Service ${e} has no model or embedModel`)})}getFeatures(e){if(e){let t=this.services.get(e);if(t)return t.service.getFeatures(e)}return{functions:!1,streaming:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}}getMetrics(){let e=this.lastUsedService;if(!e){let t=this.services.values().next().value;t&&(e="service"in t?t.service:t)}if(!e)throw new Error("No service available to get metrics.");return e.getMetrics()}setOptions(e){for(let t of this.services.values())t.service.setOptions(e);this.options=e}getOptions(){return this.options??{}}getLogger(){let e=this.lastUsedService;if(!e){let t=this.services.values().next().value;t&&(e=t.service)}if(!e)throw new Error("No service available to get logger.");return e.getLogger()}setServiceEntry(e,t){this.services.set(e,t)}};var Ti=()=>structuredClone({...we(),model:"nous-hermes2",embedModel:"all-minilm"}),zl=()=>structuredClone({...He(),model:"nous-hermes2",embedModel:"all-minilm"}),wn=class extends Ge{constructor({apiKey:e="not-set",url:t="http://localhost:11434/v1",config:n,options:r,models:s}){let i={...Ti(),...n};super({apiKey:e,options:r,config:i,apiURL:t,models:s,modelInfo:[],supportFor:{functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}}),super.setName("Ollama")}};var td=o=>["o1","o1-mini","o1-pro","o3","o3-mini","o3-pro","o4-mini"].includes(o),Rn=class{constructor(e,t,n){this.config=e;this.streamingUsage=t;this.responsesReqUpdater=n}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,stopSequences:e.stopSequences,topP:e.topP,stream:e.stream}}mapInternalContentToResponsesInput(e,t){let n=[];for(let r of e){if(r.type==="text"){t==="assistant"?n.push({type:"output_text",text:r.text}):n.push({type:"input_text",text:r.text});continue}if(t==="assistant")continue;if(r.type==="image"){let i=`data:${r.mimeType};base64,${r.image}`;n.push({type:"input_image",image_url:{url:i,details:r.details??"auto"}});continue}if(r.type==="audio"){n.push({type:"input_audio",input_audio:{data:r.data,format:r.format==="wav"?"wav":void 0}});continue}let s=r;throw new Error(`Unsupported content part: ${JSON.stringify(s)}`)}return n}createResponsesReqInternalInput(e,t=!1){let n=[];for(let r of e){if(t&&r.role==="system")continue;let s;if(r.role==="system"||r.role==="user"||r.role==="assistant"&&r.content)if(typeof r.content=="string")r.role==="system"?s=r.content:r.role==="assistant"?s=[{type:"output_text",text:r.content}]:s=[{type:"input_text",text:r.content}];else if(Array.isArray(r.content))s=this.mapInternalContentToResponsesInput(r.content,r.role==="assistant"?"assistant":"user");else{if(!(r.role==="assistant"&&!r.content&&r.functionCalls))throw new Error(`Invalid content type for role ${r.role}`);s=""}else r.role,s="";switch(r.role){case"system":n.push({type:"message",role:"system",content:s});break;case"user":n.push({type:"message",role:"user",content:s,name:r.name});break;case"assistant":if(r.content||r.functionCalls){let i={type:"message",role:"assistant",content:""};if(r.content&&(i.content=s),r.name&&(i.name=r.name),r.content&&n.push(i),r.functionCalls)for(let a of r.functionCalls)n.push({type:"function_call",call_id:a.id,name:a.function.name,arguments:typeof a.function.params=="object"?JSON.stringify(a.function.params):a.function.params||""})}break;case"function":n.push({type:"function_call_output",call_id:r.functionId,output:r.result});break;default:{let i=r.role;throw new Error(`Invalid role in chat prompt: ${i}`)}}}return n}createChatReq(e,t){let n=e.model,r={name:"/responses"},s=null,i=!1;if(e.chatPrompt){for(let A of e.chatPrompt)if(A.role==="system"&&typeof A.content=="string"){s=A.content,i=!0;break}}let a=s??this.config.systemPrompt??null,l=e.functions?.map(A=>({type:"function",name:A.name,description:A.description,parameters:A.parameters??{}})),c=[],u=td(n),p=this.config.reasoningSummary;t?.showThoughts?p||(p="auto"):p=void 0;let d=this.config.reasoningEffort;if(t?.thinkingTokenBudget)switch(t.thinkingTokenBudget){case"none":d=void 0;break;case"minimal":d="minimal";break;case"low":d="medium";break;case"medium":case"high":case"highest":d="high";break}let m={model:n,input:"",instructions:a,tools:l?.length?l:void 0,tool_choice:e.functionCall==="none"||e.functionCall==="auto"||e.functionCall==="required"?e.functionCall:typeof e.functionCall=="object"&&e.functionCall.function?{type:"function",name:e.functionCall.function.name}:void 0,...u?{max_output_tokens:e.modelConfig?.maxTokens??this.config.maxTokens??void 0}:{...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty??void 0,frequency_penalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty??void 0,max_output_tokens:e.modelConfig?.maxTokens??this.config.maxTokens??void 0},stream:e.modelConfig?.stream??this.config.stream??!1,background:void 0,include:c.length>0?c:void 0,metadata:void 0,parallel_tool_calls:this.config.parallelToolCalls,previous_response_id:void 0,...d?{reasoning:{effort:d,summary:p}}:{},service_tier:this.config.serviceTier,store:this.config.store,text:void 0,truncation:void 0,user:this.config.user,seed:this.config.seed};this.config.user&&(m.user=this.config.user),this.config.parallelToolCalls!==void 0&&(m.parallel_tool_calls=this.config.parallelToolCalls),e.responseFormat?m.text={format:e.responseFormat.type==="json_schema"?{type:"json_schema",json_schema:e.responseFormat.schema}:{type:e.responseFormat.type}}:this.config.responseFormat&&(m.text={format:{type:this.config.responseFormat}}),this.config.seed&&(m.seed=this.config.seed);let g=e.chatPrompt?this.createResponsesReqInternalInput(e.chatPrompt,i):[];if(g.length>0)m.input=g;else if(e.chatPrompt&&e.chatPrompt.length===1&&e.chatPrompt[0]?.role==="user"&&e.chatPrompt[0]?.content&&typeof e.chatPrompt[0].content=="string"&&!a)m.input=e.chatPrompt[0].content;else if(g.length===0&&!a)throw new Error("Responses API request must have input or instructions.");let f=m.reasoning??{};if(this.config.reasoningEffort&&(f={...f,effort:this.config.reasoningEffort}),t?.thinkingTokenBudget)switch(t.thinkingTokenBudget){case"none":f={};break;case"minimal":f={...f,effort:"minimal"};break;case"low":f={...f,effort:"medium"};break;case"medium":case"high":case"highest":f={...f,effort:"high"};break}Object.keys(f).length>0&&f.effort?m.reasoning=f:m.reasoning=void 0;let x=m;return this.responsesReqUpdater&&(x=this.responsesReqUpdater(x)),[r,x]}createChatResp(e){let{id:t,output:n,usage:r}=e;r&&(this.tokensUsed={promptTokens:r.prompt_tokens,completionTokens:r.completion_tokens??r.output_tokens??0,totalTokens:r.total_tokens});let s={};for(let i of n??[])switch(i.type){case"message":s.id=i.id,s.content=Ci(i.content,t),s.finishReason=i.status==="completed"?"stop":"content_filter",s.citations=$o(i.content);break;case"reasoning":s.id=i.id,i.encrypted_content?s.thought=i.encrypted_content:s.thought=i.summary.map(a=>typeof a=="object"?JSON.stringify(a):a).join(`
176
- `);break;case"file_search_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"file_search",params:{queries:i.queries,results:i.results}}}],s.finishReason="function_call";break;case"web_search_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"web_search",params:{queries:i.queries}}}],s.finishReason="function_call";break;case"computer_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"computer_use",params:{action:i.action}}}],s.finishReason="function_call";break;case"code_interpreter_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"code_interpreter",params:{code:i.code,results:i.results}}}],s.finishReason="function_call";break;case"image_generation_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"image_generation",params:{result:i.result}}}],s.finishReason="function_call";break;case"local_shell_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"local_shell",params:{action:i.action}}}],s.finishReason="function_call";break;case"mcp_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"mcp",params:{name:i.name,args:i.args,serverLabel:i.server_label,output:i.output,error:i.error}}}],s.finishReason="function_call";break;case"function_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:i.name,params:i.arguments}}],s.finishReason="function_call";break}return{results:[{...s,index:0}],remoteId:t}}createChatStreamResp(e){let t=e,n={index:0,id:"",content:"",finishReason:"stop"},r;switch(t.type){case"response.created":case"response.in_progress":case"response.queued":r=t.response.id,n.id=`${t.response.id}_res_0`;break;case"response.output_item.added":switch(t.item.type){case"message":n.id=t.item.id,n.content=Ci(t.item.content,t.item.id),n.citations=$o(t.item.content);break;case"function_call":n.id=t.item.id,n.functionCalls=[{id:t.item.id,type:"function",function:{name:t.item.name,params:t.item.arguments}}];break;case"file_search_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"file_search",params:{queries:s.queries||[],results:s.results?.map(i=>({fileId:i.file_id,filename:i.filename,score:i.score,text:i.text,attributes:i.attributes}))}}}]}break;case"web_search_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"web_search",params:{queries:s.queries||[]}}}]}break;case"computer_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"computer_use",params:{action:s.action||{}}}}]}break;case"code_interpreter_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"code_interpreter",params:{code:s.code||"",results:s.results}}}]}break;case"image_generation_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"image_generation",params:{result:s.result}}}]}break;case"local_shell_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"local_shell",params:{action:s.action||{}}}}]}break;case"mcp_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"mcp",params:{name:s.name||"",args:s.args||"",serverLabel:s.server_label||"",output:s.output,error:s.error}}}]}break}break;case"response.content_part.added":n.id=t.item_id,n.content=Ci([t.part],t.item_id),n.citations=$o([t.part]);break;case"response.output_text.delta":n.id=t.item_id,n.content=t.delta;break;case"response.output_text.done":break;case"response.function_call_arguments.delta":n.id=t.item_id,n.functionCalls=[{id:t.item_id,type:"function",function:{name:"",params:t.delta}}];break;case"response.reasoning_summary_text.delta":n.id=t.item_id,n.thought=t.delta;break;case"response.file_search_call.in_progress":case"response.file_search_call.searching":n.id=t.item_id,n.finishReason="function_call";break;case"response.file_search_call.completed":n.id=t.item_id,n.finishReason="function_call";break;case"response.web_search_call.in_progress":case"response.web_search_call.searching":n.id=t.item_id,n.finishReason="function_call";break;case"response.web_search_call.completed":n.id=t.item_id,n.finishReason="function_call";break;case"response.image_generation_call.in_progress":case"response.image_generation_call.generating":n.id=t.item_id,n.finishReason="function_call";break;case"response.image_generation_call.completed":n.id=t.item_id,n.finishReason="function_call";break;case"response.image_generation_call.partial_image":n.id=t.item_id,n.finishReason="function_call";break;case"response.mcp_call.in_progress":n.id=t.item_id,n.finishReason="function_call";break;case"response.mcp_call.arguments.delta":n.id=t.item_id,n.functionCalls=[{id:t.item_id,type:"function",function:{name:"",params:t.delta}}];break;case"response.mcp_call.arguments.done":n.id=t.item_id,n.functionCalls=[{id:t.item_id,type:"function",function:{name:"",params:t.arguments}}];break;case"response.mcp_call.completed":case"response.mcp_call.failed":n.id="mcp_call_event",n.finishReason="function_call";break;case"response.mcp_list_tools.in_progress":case"response.mcp_list_tools.completed":case"response.mcp_list_tools.failed":n.id="mcp_list_tools_event",n.finishReason="function_call";break;case"response.output_item.done":switch(t.item.type){case"message":if(n.id=t.item.id,n.finishReason=t.item.status==="completed"?"stop":"error",!n.citations||n.citations.length===0){let s=$o(t.item.content||[]);s&&(n.citations=s)}break;case"function_call":case"file_search_call":case"web_search_call":case"computer_call":case"code_interpreter_call":case"image_generation_call":case"local_shell_call":case"mcp_call":n.id=t.item.id,n.finishReason="function_call";break}break;case"response.completed":t.response.usage&&(this.tokensUsed={promptTokens:t.response.usage.prompt_tokens,completionTokens:t.response.usage.completion_tokens??t.response.usage.output_tokens??0,totalTokens:t.response.usage.total_tokens}),r=t.response.id,n.id=`${t.response.id}_completed`,n.finishReason="stop";break;case"response.failed":r=t.response.id,n.id=`${t.response.id}_failed`,n.finishReason="error";break;case"response.incomplete":r=t.response.id,n.id=`${t.response.id}_incomplete`,n.finishReason="length";break;case"error":n.id="error",n.content=`Error: ${t.message}`,n.finishReason="error";break;default:n.id="unknown";break}return{results:[n],remoteId:r}}createEmbedReq(e){let t=e.embedModel;if(!t)throw new Error("Embed model not set");if(!e.texts||e.texts.length===0)throw new Error("Embed texts is empty");let n={name:"/embeddings"},r={model:t,input:e.texts,dimensions:this.config.dimensions};return[n,r]}},Ci=(o,e)=>{let t=o.filter(n=>n.type==="refusal");if(t.length>0){let n=t.map(r=>r.refusal).join(`
174
+ ${c}`:`Assistant: ${u.content}`}default:throw new Error("Unknown role")}}).join(`
175
+ `),s=`${n} ${r}`.trim(),i={name:"/models"},a={model:t,inputs:s,parameters:{max_new_tokens:e.modelConfig?.maxTokens??this.config.maxTokens,repetition_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty,...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},top_k:e.modelConfig?.topK??this.config.topK,return_full_text:this.config.returnFullText,num_return_sequences:this.config.n,do_sample:this.config.doSample,max_time:this.config.maxTime},options:{use_cache:this.config.useCache,wait_for_model:this.config.waitForModel}};return[i,a]};createChatResp=e=>({results:[{index:0,content:e.generated_text}]})},vn=class extends je{constructor({apiKey:e,config:t,options:n,models:r}){if(!e||e==="")throw new Error("HuggingFace API key not set");let s={...wi(),...t},i=new Ti(s);super(i,{name:"HuggingFace",apiURL:"https://api-inference.huggingface.co",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:No,defaults:{model:s.model},options:n,supportFor:{functions:!1,streaming:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},models:r})}};var wr=(u=>(u.Mistral7B="open-mistral-7b",u.Mistral8x7B="open-mixtral-8x7b",u.MistralSmall="mistral-small-latest",u.MistralNemo="mistral-nemo-latest",u.MistralLarge="mistral-large-latest",u.Codestral="codestral-latest",u.OpenCodestralMamba="open-codestral-mamba",u.OpenMistralNemo="open-mistral-nemo-latest",u))(wr||{}),Ri=(e=>(e.MistralEmbed="mistral-embed",e))(Ri||{});var $o=[{name:"open-mistral-7b",currency:"USD",promptTokenCostPer1M:.25,completionTokenCostPer1M:.25},{name:"open-mixtral-8x7b",currency:"USD",promptTokenCostPer1M:.7,completionTokenCostPer1M:.7},{name:"mistral-nemo-latest",currency:"USD",promptTokenCostPer1M:.15,completionTokenCostPer1M:.15},{name:"mistral-small-latest",currency:"USD",promptTokenCostPer1M:.2,completionTokenCostPer1M:.6},{name:"mistral-large-latest",currency:"USD",promptTokenCostPer1M:2,completionTokenCostPer1M:6},{name:"codestral-latest",currency:"USD",promptTokenCostPer1M:.2,completionTokenCostPer1M:.6},{name:"open-codestral-mamba",currency:"USD",promptTokenCostPer1M:.25,completionTokenCostPer1M:.25},{name:"open-mistral-nemo-latest",currency:"USD",promptTokenCostPer1M:.3,completionTokenCostPer1M:.3}];var Do=()=>structuredClone({model:"mistral-small-latest",...ve(),topP:1}),tc=()=>structuredClone({...Do(),model:"mistral-large-latest"}),Sn=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("Mistral API key not set");let i={...Do(),...t};s=[...$o,...s??[]];let a={functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},u=c=>{let{max_completion_tokens:l,messages:p,...d}=c;return{...d,messages:this.updateMessages(p),max_tokens:l}};super({apiKey:e,config:i,options:n,apiURL:"https://api.mistral.ai/v1",modelInfo:s,models:r,supportFor:a,chatReqUpdater:u}),super.setName("Mistral")}updateMessages(e){let t=[];if(!Array.isArray(e))return e;for(let n of e)if(n.role==="user"&&Array.isArray(n.content)){let r=n.content.map(s=>typeof s=="object"&&s!==null&&"image_url"in s?{type:"image_url",image_url:{url:s.image_url?.url}}:s);t.push({...n,content:r})}else t.push(n);return t}};var Uo=class{constructor(e={}){this.config=e;this.config.id=this.config.id??Ze()}metrics={latency:{chat:{mean:0,p95:0,p99:0,samples:[]},embed:{mean:0,p95:0,p99:0,samples:[]}},errors:{chat:{count:0,rate:0,total:0},embed:{count:0,rate:0,total:0}}};getLastUsedChatModel(){return this.config.modelInfo?.name??"mock-model"}getLastUsedEmbedModel(){return this.config.embedModelInfo?.name??"mock-embed-model"}getLastUsedModelConfig(){return this.config.modelInfo?{maxTokens:this.config.modelInfo.maxTokens,temperature:.7,stream:this.config.features?.streaming??!1}:void 0}getName(){return this.config.name??"mock-ai-service"}getId(){return this.config.id??"mock-ai-service-id"}getFeatures(e){let t=this.config.features?.media;return{functions:this.config.features?.functions??!1,streaming:this.config.features?.streaming??!1,structuredOutputs:this.config.features?.structuredOutputs??!1,media:{images:{supported:t?.images?.supported??!1,formats:t?.images?.formats??[]},audio:{supported:t?.audio?.supported??!1,formats:t?.audio?.formats??[]},files:{supported:t?.files?.supported??!1,formats:t?.files?.formats??[],uploadMethod:t?.files?.uploadMethod??"none"},urls:{supported:t?.urls?.supported??!1,webSearch:t?.urls?.webSearch??!1,contextFetching:t?.urls?.contextFetching??!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}}getModelList(){return this.config.models}getMetrics(){return this.metrics}async chat(e,t){if(this.config.latencyMs&&await new Promise(n=>setTimeout(n,this.config.latencyMs)),this.config.shouldError)throw new Error(this.config.errorMessage??"Mock chat error");return this.updateMetrics("chat"),typeof this.config.chatResponse=="function"?await this.config.chatResponse(e):this.config.chatResponse??{results:[{index:0,content:"Mock response",finishReason:"stop"}],modelUsage:{ai:this.getName(),model:"mock-model",tokens:{promptTokens:10,completionTokens:5,totalTokens:15}}}}async embed(e,t){if(this.config.latencyMs&&await new Promise(n=>setTimeout(n,this.config.latencyMs)),this.config.shouldError)throw new Error(this.config.errorMessage??"Mock embed error");return this.updateMetrics("embed"),typeof this.config.embedResponse=="function"?this.config.embedResponse(e):this.config.embedResponse??{embeddings:[[.1,.2,.3]],modelUsage:{ai:this.getName(),model:"mock-model",tokens:{promptTokens:5,completionTokens:0,totalTokens:5}}}}setOptions(e){this.config.options=e}getOptions(){return this.config.options??{}}getLogger(){return this.config.options?.logger??(e=>{console.log(e)})}updateMetrics(e){let t=this.config.latencyMs??0;this.metrics.latency[e].samples.push(t);let n=this.metrics.latency[e].samples;if(this.metrics.latency[e].mean=n.reduce((r,s)=>r+s,0)/n.length,n.length>0){let r=[...n].sort((a,u)=>a-u),s=Math.max(0,Math.floor(r.length*.95)-1);this.metrics.latency[e].p95=r[s]??t;let i=Math.max(0,Math.floor(r.length*.99)-1);this.metrics.latency[e].p99=r[i]??t}if(this.config.shouldError){this.metrics.errors[e].count++,this.metrics.errors[e].total++;let r=this.metrics.latency[e].samples.length;this.metrics.errors[e].rate=r>0?this.metrics.errors[e].count/r:0}}};var Go=class o{options;lastUsedService;services=new Map;constructor(e){if(e.length===0)throw new Error("No AI services provided.");for(let[t,n]of e.entries())if("key"in n){if(this.services.has(n.key))throw new Error(`Duplicate model key: ${n.key}`);let{service:s,description:i,isInternal:a}=n;this.services.set(n.key,{service:s,description:i,isInternal:a})}else{let s=n.getModelList();if(!s)throw new Error(`Service ${t} \`${n.getName()}\` has no model list.`);for(let i of s){if(this.services.has(i.key)){let a=this.services.get(i.key)?.service;throw new Error(`Service ${t} \`${n.getName()}\` has duplicate model key: ${i.key} as service ${a?.getName()}`)}if("model"in i&&typeof i.model)this.services.set(i.key,{description:i.description,service:n,model:i.model});else if("embedModel"in i&&i.embedModel)this.services.set(i.key,{description:i.description,service:n,embedModel:i.embedModel});else throw new Error(`Key ${i.key} in model list for service ${t} \`${n.getName()}\` is missing a model or embedModel property.`)}}}static create(e){return new o(e)}getLastUsedChatModel(){return this.lastUsedService?.getLastUsedChatModel()}getLastUsedEmbedModel(){return this.lastUsedService?.getLastUsedEmbedModel()}getLastUsedModelConfig(){return this.lastUsedService?.getLastUsedModelConfig()}async chat(e,t){let n=e.model;if(!n)throw new Error("Model key must be specified for multi-service");let r=this.services.get(n);if(!r)throw new Error(`No service found for model key: ${n}`);if(this.lastUsedService=r.service,!r.model){let{model:s,...i}=e;return await r.service.chat(i,t)}return await r.service.chat({model:n,...e},t)}async embed(e,t){let n=e.embedModel;if(!n)throw new Error("Embed model key must be specified for multi-service");let r=this.services.get(n);if(!r)throw new Error(`No service found for embed model key: ${n}`);if(this.lastUsedService=r.service,!r.model){let{embedModel:s,...i}=e;return await r.service.embed(i,t)}return await r.service.embed({embedModel:n,...e},t)}getId(){return`MultiServiceRouter:${Array.from(this.services.values()).map(e=>e.service.getId()).join(",")}`}getName(){return"MultiServiceRouter"}getModelList(){return Array.from(this.services).filter(([,e])=>!e.isInternal).map(([e,t])=>{if(t.model)return{key:e,description:t.description,model:t.model};if(t.embedModel)return{key:e,description:t.description,embedModel:t.embedModel};throw new Error(`Service ${e} has no model or embedModel`)})}getFeatures(e){if(e){let t=this.services.get(e);if(t)return t.service.getFeatures(e)}return{functions:!1,streaming:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}}getMetrics(){let e=this.lastUsedService;if(!e){let t=this.services.values().next().value;t&&(e="service"in t?t.service:t)}if(!e)throw new Error("No service available to get metrics.");return e.getMetrics()}setOptions(e){for(let t of this.services.values())t.service.setOptions(e);this.options=e}getOptions(){return this.options??{}}getLogger(){let e=this.lastUsedService;if(!e){let t=this.services.values().next().value;t&&(e=t.service)}if(!e)throw new Error("No service available to get logger.");return e.getLogger()}setServiceEntry(e,t){this.services.set(e,t)}};var vi=()=>structuredClone({...ve(),model:"nous-hermes2",embedModel:"all-minilm"}),nc=()=>structuredClone({...He(),model:"nous-hermes2",embedModel:"all-minilm"}),kn=class extends Ge{constructor({apiKey:e="not-set",url:t="http://localhost:11434/v1",config:n,options:r,models:s}){let i={...vi(),...n};super({apiKey:e,options:r,config:i,apiURL:t,models:s,modelInfo:[],supportFor:{functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}}),super.setName("Ollama")}};var zd=o=>["o1","o1-mini","o1-pro","o3","o3-mini","o3-pro","o4-mini"].includes(o),On=class{constructor(e,t,n){this.config=e;this.streamingUsage=t;this.responsesReqUpdater=n}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,stopSequences:e.stopSequences,topP:e.topP,stream:e.stream}}mapInternalContentToResponsesInput(e,t){let n=[];for(let r of e){if(r.type==="text"){t==="assistant"?n.push({type:"output_text",text:r.text}):n.push({type:"input_text",text:r.text});continue}if(t==="assistant")continue;if(r.type==="image"){let i=`data:${r.mimeType};base64,${r.image}`;n.push({type:"input_image",image_url:{url:i,details:r.details??"auto"}});continue}if(r.type==="audio"){n.push({type:"input_audio",input_audio:{data:r.data,format:r.format==="wav"?"wav":void 0}});continue}let s=r;throw new Error(`Unsupported content part: ${JSON.stringify(s)}`)}return n}createResponsesReqInternalInput(e,t=!1){let n=[];for(let r of e){if(t&&r.role==="system")continue;let s;if(r.role==="system"||r.role==="user"||r.role==="assistant"&&r.content)if(typeof r.content=="string")r.role==="system"?s=r.content:r.role==="assistant"?s=[{type:"output_text",text:r.content}]:s=[{type:"input_text",text:r.content}];else if(Array.isArray(r.content))s=this.mapInternalContentToResponsesInput(r.content,r.role==="assistant"?"assistant":"user");else{if(!(r.role==="assistant"&&!r.content&&r.functionCalls))throw new Error(`Invalid content type for role ${r.role}`);s=""}else r.role,s="";switch(r.role){case"system":n.push({type:"message",role:"system",content:s});break;case"user":n.push({type:"message",role:"user",content:s,name:r.name});break;case"assistant":if(r.content||r.functionCalls){let i={type:"message",role:"assistant",content:""};if(r.content&&(i.content=s),r.name&&(i.name=r.name),r.content&&n.push(i),r.functionCalls)for(let a of r.functionCalls)n.push({type:"function_call",call_id:a.id,name:a.function.name,arguments:typeof a.function.params=="object"?JSON.stringify(a.function.params):a.function.params||""})}break;case"function":n.push({type:"function_call_output",call_id:r.functionId,output:r.result});break;default:{let i=r.role;throw new Error(`Invalid role in chat prompt: ${i}`)}}}return n}createChatReq(e,t){let n=e.model,r={name:"/responses"},s=null,i=!1;if(e.chatPrompt){for(let A of e.chatPrompt)if(A.role==="system"&&typeof A.content=="string"){s=A.content,i=!0;break}}let a=s??this.config.systemPrompt??null,u=e.functions?.map(A=>({type:"function",name:A.name,description:A.description,parameters:A.parameters??{}})),c=[],l=zd(n),p=this.config.reasoningSummary;t?.showThoughts?p||(p="auto"):p=void 0;let d=this.config.reasoningEffort;if(t?.thinkingTokenBudget)switch(t.thinkingTokenBudget){case"none":d=void 0;break;case"minimal":d="minimal";break;case"low":d="medium";break;case"medium":case"high":case"highest":d="high";break}let m={model:n,input:"",instructions:a,tools:u?.length?u:void 0,tool_choice:e.functionCall==="none"||e.functionCall==="auto"||e.functionCall==="required"?e.functionCall:typeof e.functionCall=="object"&&e.functionCall.function?{type:"function",name:e.functionCall.function.name}:void 0,...l?{max_output_tokens:e.modelConfig?.maxTokens??this.config.maxTokens??void 0}:{...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty??void 0,frequency_penalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty??void 0,max_output_tokens:e.modelConfig?.maxTokens??this.config.maxTokens??void 0},stream:e.modelConfig?.stream??this.config.stream??!1,background:void 0,include:c.length>0?c:void 0,metadata:void 0,parallel_tool_calls:this.config.parallelToolCalls,previous_response_id:void 0,...d?{reasoning:{effort:d,summary:p}}:{},service_tier:this.config.serviceTier,store:this.config.store,text:void 0,truncation:void 0,user:this.config.user,seed:this.config.seed};this.config.user&&(m.user=this.config.user),this.config.parallelToolCalls!==void 0&&(m.parallel_tool_calls=this.config.parallelToolCalls),e.responseFormat?m.text={format:e.responseFormat.type==="json_schema"?{type:"json_schema",json_schema:e.responseFormat.schema}:{type:e.responseFormat.type}}:this.config.responseFormat&&(m.text={format:{type:this.config.responseFormat}}),this.config.seed&&(m.seed=this.config.seed);let g=e.chatPrompt?this.createResponsesReqInternalInput(e.chatPrompt,i):[];if(g.length>0)m.input=g;else if(e.chatPrompt&&e.chatPrompt.length===1&&e.chatPrompt[0]?.role==="user"&&e.chatPrompt[0]?.content&&typeof e.chatPrompt[0].content=="string"&&!a)m.input=e.chatPrompt[0].content;else if(g.length===0&&!a)throw new Error("Responses API request must have input or instructions.");let f=m.reasoning??{};if(this.config.reasoningEffort&&(f={...f,effort:this.config.reasoningEffort}),t?.thinkingTokenBudget)switch(t.thinkingTokenBudget){case"none":f={};break;case"minimal":f={...f,effort:"minimal"};break;case"low":f={...f,effort:"medium"};break;case"medium":case"high":case"highest":f={...f,effort:"high"};break}Object.keys(f).length>0&&f.effort?m.reasoning=f:m.reasoning=void 0;let x=m;return this.responsesReqUpdater&&(x=this.responsesReqUpdater(x)),[r,x]}createChatResp(e){let{id:t,output:n,usage:r}=e;r&&(this.tokensUsed={promptTokens:r.prompt_tokens,completionTokens:r.completion_tokens??r.output_tokens??0,totalTokens:r.total_tokens});let s={};for(let i of n??[])switch(i.type){case"message":s.id=i.id,s.content=Si(i.content,t),s.finishReason=i.status==="completed"?"stop":"content_filter",s.citations=jo(i.content);break;case"reasoning":s.id=i.id,i.encrypted_content?s.thought=i.encrypted_content:s.thought=i.summary.map(a=>typeof a=="object"?JSON.stringify(a):a).join(`
176
+ `);break;case"file_search_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"file_search",params:{queries:i.queries,results:i.results}}}],s.finishReason="function_call";break;case"web_search_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"web_search",params:{queries:i.queries}}}],s.finishReason="function_call";break;case"computer_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"computer_use",params:{action:i.action}}}],s.finishReason="function_call";break;case"code_interpreter_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"code_interpreter",params:{code:i.code,results:i.results}}}],s.finishReason="function_call";break;case"image_generation_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"image_generation",params:{result:i.result}}}],s.finishReason="function_call";break;case"local_shell_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"local_shell",params:{action:i.action}}}],s.finishReason="function_call";break;case"mcp_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:"mcp",params:{name:i.name,args:i.args,serverLabel:i.server_label,output:i.output,error:i.error}}}],s.finishReason="function_call";break;case"function_call":s.id=i.id,s.functionCalls=[{id:i.id,type:"function",function:{name:i.name,params:i.arguments}}],s.finishReason="function_call";break}return{results:[{...s,index:0}],remoteId:t}}createChatStreamResp(e){let t=e,n={index:0,id:"",content:"",finishReason:"stop"},r;switch(t.type){case"response.created":case"response.in_progress":case"response.queued":r=t.response.id,n.id=`${t.response.id}_res_0`;break;case"response.output_item.added":switch(t.item.type){case"message":n.id=t.item.id,n.content=Si(t.item.content,t.item.id),n.citations=jo(t.item.content);break;case"function_call":n.id=t.item.id,n.functionCalls=[{id:t.item.id,type:"function",function:{name:t.item.name,params:t.item.arguments}}];break;case"file_search_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"file_search",params:{queries:s.queries||[],results:s.results?.map(i=>({fileId:i.file_id,filename:i.filename,score:i.score,text:i.text,attributes:i.attributes}))}}}]}break;case"web_search_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"web_search",params:{queries:s.queries||[]}}}]}break;case"computer_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"computer_use",params:{action:s.action||{}}}}]}break;case"code_interpreter_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"code_interpreter",params:{code:s.code||"",results:s.results}}}]}break;case"image_generation_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"image_generation",params:{result:s.result}}}]}break;case"local_shell_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"local_shell",params:{action:s.action||{}}}}]}break;case"mcp_call":{let s=t.item;n.id=t.item.id,n.functionCalls=[{id:s.id,type:"function",function:{name:"mcp",params:{name:s.name||"",args:s.args||"",serverLabel:s.server_label||"",output:s.output,error:s.error}}}]}break}break;case"response.content_part.added":n.id=t.item_id,n.content=Si([t.part],t.item_id),n.citations=jo([t.part]);break;case"response.output_text.delta":n.id=t.item_id,n.content=t.delta;break;case"response.output_text.done":break;case"response.function_call_arguments.delta":n.id=t.item_id,n.functionCalls=[{id:t.item_id,type:"function",function:{name:"",params:t.delta}}];break;case"response.reasoning_summary_text.delta":n.id=t.item_id,n.thought=t.delta;break;case"response.file_search_call.in_progress":case"response.file_search_call.searching":n.id=t.item_id,n.finishReason="function_call";break;case"response.file_search_call.completed":n.id=t.item_id,n.finishReason="function_call";break;case"response.web_search_call.in_progress":case"response.web_search_call.searching":n.id=t.item_id,n.finishReason="function_call";break;case"response.web_search_call.completed":n.id=t.item_id,n.finishReason="function_call";break;case"response.image_generation_call.in_progress":case"response.image_generation_call.generating":n.id=t.item_id,n.finishReason="function_call";break;case"response.image_generation_call.completed":n.id=t.item_id,n.finishReason="function_call";break;case"response.image_generation_call.partial_image":n.id=t.item_id,n.finishReason="function_call";break;case"response.mcp_call.in_progress":n.id=t.item_id,n.finishReason="function_call";break;case"response.mcp_call.arguments.delta":n.id=t.item_id,n.functionCalls=[{id:t.item_id,type:"function",function:{name:"",params:t.delta}}];break;case"response.mcp_call.arguments.done":n.id=t.item_id,n.functionCalls=[{id:t.item_id,type:"function",function:{name:"",params:t.arguments}}];break;case"response.mcp_call.completed":case"response.mcp_call.failed":n.id="mcp_call_event",n.finishReason="function_call";break;case"response.mcp_list_tools.in_progress":case"response.mcp_list_tools.completed":case"response.mcp_list_tools.failed":n.id="mcp_list_tools_event",n.finishReason="function_call";break;case"response.output_item.done":switch(t.item.type){case"message":if(n.id=t.item.id,n.finishReason=t.item.status==="completed"?"stop":"error",!n.citations||n.citations.length===0){let s=jo(t.item.content||[]);s&&(n.citations=s)}break;case"function_call":case"file_search_call":case"web_search_call":case"computer_call":case"code_interpreter_call":case"image_generation_call":case"local_shell_call":case"mcp_call":n.id=t.item.id,n.finishReason="function_call";break}break;case"response.completed":t.response.usage&&(this.tokensUsed={promptTokens:t.response.usage.prompt_tokens,completionTokens:t.response.usage.completion_tokens??t.response.usage.output_tokens??0,totalTokens:t.response.usage.total_tokens}),r=t.response.id,n.id=`${t.response.id}_completed`,n.finishReason="stop";break;case"response.failed":r=t.response.id,n.id=`${t.response.id}_failed`,n.finishReason="error";break;case"response.incomplete":r=t.response.id,n.id=`${t.response.id}_incomplete`,n.finishReason="length";break;case"error":n.id="error",n.content=`Error: ${t.message}`,n.finishReason="error";break;default:n.id="unknown";break}return{results:[n],remoteId:r}}createEmbedReq(e){let t=e.embedModel;if(!t)throw new Error("Embed model not set");if(!e.texts||e.texts.length===0)throw new Error("Embed texts is empty");let n={name:"/embeddings"},r={model:t,input:e.texts,dimensions:this.config.dimensions};return[n,r]}},Si=(o,e)=>{let t=o.filter(n=>n.type==="refusal");if(t.length>0){let n=t.map(r=>r.refusal).join(`
177
177
  `);throw new Le(n,void 0,e)}return o.filter(n=>n.type==="output_text").map(n=>n.text).join(`
178
- `)};function $o(o){let e=[];for(let t of o??[])if(t?.type==="output_text"&&Array.isArray(t.annotations))for(let n of t.annotations)n&&n.type==="url_citation"&&typeof n.url=="string"&&e.push({url:n.url,title:n.title,description:n.description});return e.length?e:void 0}var wr=()=>({model:"gpt-4o",embedModel:"text-embedding-ada-002",temperature:.7,topP:1,stream:!0}),ql=()=>({...wr(),model:"gpt-4o",temperature:.5}),Hl=()=>({...wr(),model:"gpt-4o",temperature:.9}),Ir=class extends Be{constructor({apiKey:e,config:t,options:n,apiURL:r,modelInfo:s=[],models:i,responsesReqUpdater:a,supportFor:l={functions:!0,streaming:!0,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}}){if(!e||e==="")throw new Error("OpenAI API key not set");let c=new Rn(t,n?.streamingUsage??!0,a),u=i?.map(p=>{let d=p,m=d?.config;if(!m)return p;let g={};m.maxTokens!==void 0&&(g.maxTokens=m.maxTokens),m.temperature!==void 0&&(g.temperature=m.temperature),m.topP!==void 0&&(g.topP=m.topP),m.presencePenalty!==void 0&&(g.presencePenalty=m.presencePenalty),m.frequencyPenalty!==void 0&&(g.frequencyPenalty=m.frequencyPenalty);let f=m.stopSequences??m.stop;f!==void 0&&(g.stopSequences=f),m.n!==void 0&&(g.n=m.n),m.stream!==void 0&&(g.stream=m.stream);let x={...d};Object.keys(g).length>0&&(x.modelConfig={...d.modelConfig??{},...g});let A=m?.thinking?.thinkingTokenBudget;if(typeof A=="number"){let h=[["minimal",200],["low",800],["medium",5e3],["high",1e4],["highest",24500]],b="minimal",T=Number.POSITIVE_INFINITY;for(let[C,v]of h){let k=Math.abs(A-v);k<T&&(T=k,b=C)}x.thinkingTokenBudget=b}return m?.thinking?.includeThoughts!==void 0&&(x.showThoughts=!!m.thinking.includeThoughts),x});super(c,{name:"OpenAI",apiURL:r||"https://api.openai.com/v1",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:s,defaults:{model:t.model??"gpt-4o",embedModel:t.embedModel??"text-embedding-ada-002"},options:n,supportFor:l,models:u??i})}},vn=class extends Ir{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("OpenAI API key not set");s=[...ho,...s??[]];let i=a=>{let l=mt({model:a,modelInfo:s,models:r});return{functions:!0,streaming:!0,hasThinkingBudget:l?.supported?.thinkingBudget??!1,hasShowThoughts:l?.supported?.showThoughts??!1,structuredOutputs:l?.supported?.structuredOutputs??!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}};super({apiKey:e,config:{...wr(),...t},options:n,modelInfo:s,models:r,supportFor:i})}};var Ii=()=>structuredClone({model:"openrouter/auto",...we()}),Sn=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s,referer:i,title:a}){if(!e||e==="")throw new Error("OpenRouter API key not set");let l={...Ii(),...t},c={functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},u=s??[];super({apiKey:e,config:l,options:n,apiURL:"https://openrouter.ai/api/v1",modelInfo:u,models:r,supportFor:c}),super.setName("OpenRouter"),super.setHeaders(async()=>{let p={Authorization:`Bearer ${e}`};return i&&(p["HTTP-Referer"]=i),a&&(p["X-Title"]=a),p})}};async function Do(o,e,t={}){if(typeof o=="string")return[{type:"text",text:o}];if(!Array.isArray(o))return[{type:"text",text:String(o)}];let n=e.getFeatures(),r=[];for(let s of o)try{switch(s.type){case"text":r.push({type:"text",text:s.text});break;case"image":if(n.media.images.supported)s.altText?r.push({type:"text",text:`[Image: ${s.altText}]`}):r.push({type:"text",text:"[Image content]"});else if(s.altText)r.push({type:"text",text:s.altText});else if(t.imageToText)try{let i=await t.imageToText(s.image);r.push({type:"text",text:i})}catch(i){throw new It(i,"image","vision analysis")}else switch(t.fallbackBehavior){case"error":throw new ft("Images",e.getName(),!1);case"skip":continue;default:r.push({type:"text",text:"[Image content not supported by this provider]"})}break;case"audio":if(n.media.audio.supported)s.transcription?r.push({type:"text",text:s.transcription}):r.push({type:"text",text:"[Audio content]"});else if(s.transcription)r.push({type:"text",text:s.transcription});else if(t.audioToText)try{let i=await t.audioToText(s.data,s.format);r.push({type:"text",text:i})}catch(i){throw new It(i,"audio","transcription")}else switch(t.fallbackBehavior){case"error":throw new ft("Audio",e.getName(),!1);case"skip":continue;case"degrade":r.push({type:"text",text:"[Audio content not supported by this provider]"})}break;case"file":if(n.media.files.supported)s.extractedText?r.push({type:"text",text:s.extractedText}):r.push({type:"text",text:`[File: ${s.filename}]`});else if(s.extractedText)r.push({type:"text",text:s.extractedText});else if(t.fileToText)try{let i=await t.fileToText(s.data,s.mimeType);r.push({type:"text",text:i})}catch(i){throw new It(i,"file","text extraction")}else switch(t.fallbackBehavior){case"error":throw new ft("Files",e.getName(),!1);case"skip":continue;default:r.push({type:"text",text:`[File: ${s.filename} - content not accessible by this provider]`})}break;case"url":if(n.media.urls.supported)s.cachedContent?r.push({type:"text",text:s.cachedContent}):r.push({type:"text",text:`[Link: ${s.url}${s.title?` - ${s.title}`:""}]`});else if(s.cachedContent)r.push({type:"text",text:s.cachedContent});else if(t.urlToText)try{let i=await t.urlToText(s.url);r.push({type:"text",text:i})}catch(i){throw new It(i,"url","content fetching")}else switch(t.fallbackBehavior){case"error":throw new ft("URLs",e.getName(),!1);case"skip":continue;case"degrade":r.push({type:"text",text:`[Link: ${s.url}${s.title?` - ${s.title}`:""}]`})}break;default:typeof s=="object"&&s.text?r.push({type:"text",text:s.text}):r.push({type:"text",text:String(s)})}}catch(i){throw i instanceof ft||i instanceof It?i:new It(i,s.type||"unknown","content processing")}return r}function Kl(o){let e=!1,t=!1,n=!1,r=!1;for(let s of o)if(s.role==="user"&&Array.isArray(s.content))for(let i of s.content)switch(i.type){case"image":e=!0;break;case"audio":t=!0;break;case"file":n=!0;break;case"url":r=!0;break}return{hasImages:e,hasAudio:t,hasFiles:n,hasUrls:r}}var Rr=(n=>(n.RekaCore="reka-core",n.RekaFlash="reka-flash",n.RekaEdge="reka-edge",n))(Rr||{});var Uo=[{name:"reka-core",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15},{name:"reka-flash",currency:"usd",promptTokenCostPer1M:.8,completionTokenCostPer1M:2},{name:"reka-edge",currency:"usd",promptTokenCostPer1M:.4,completionTokenCostPer1M:1}];var vr=()=>structuredClone({model:"reka-core",...we()}),Vl=()=>structuredClone({...vr(),model:"reka-core"}),Jl=()=>structuredClone({model:"reka-core",...He()}),Ql=()=>({...vr(),model:"reka-flash"}),wi=class{constructor(e){this.config=e}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,stopSequences:e.stopSequences,topP:e.topP,n:e.n,stream:e.stream}}createChatReq=e=>{let t=e.model;if(!e.chatPrompt||e.chatPrompt.length===0)throw new Error("Chat prompt is empty");let n={name:"/chat/completions"},r=nd(e),s=e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,i=e.modelConfig?.stream??this.config.stream,a={model:t,messages:r,max_tokens:e.modelConfig?.maxTokens??this.config.maxTokens,...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},top_k:e.modelConfig?.n??this.config.n,...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},stop:e.modelConfig?.stopSequences??this.config.stop,presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty,...s?{frequency_penalty:s}:{},...i?{stream:!0}:{}};return[n,a]};createChatResp=e=>{let{id:t,usage:n,responses:r}=e;return this.tokensUsed=n?{promptTokens:n.input_tokens,completionTokens:n.output_tokens,totalTokens:n.input_tokens+n.output_tokens}:void 0,{results:r.map((i,a)=>{let l=Wl(i.finish_reason),c;return typeof i.message.content=="string"?c=i.message.content:c=i.message.content.text,{index:a,id:`${t}`,content:c,finishReason:l}}),remoteId:t}};createChatStreamResp=e=>{let{id:t,usage:n,responses:r}=e;return this.tokensUsed=n?{promptTokens:n.input_tokens,completionTokens:n.output_tokens,totalTokens:n.input_tokens+n.output_tokens}:void 0,{results:r.map((i,a)=>{let l=Wl(i.finish_reason),c;return typeof i.chunk.content=="string"?c=i.chunk.content:c=i.chunk.content.text,{index:a,id:`${t}`,content:c,finishReason:l}})}}},Wl=o=>{switch(o){case"stop":return"stop";case"context":return"length";case"length":return"length"}};function nd(o){return o.chatPrompt.map(e=>{switch(e.role){case"system":return{role:"user",content:e.content};case"user":return Array.isArray(e.content)?{role:"user",content:e.content.map(t=>{switch(t.type){case"text":return{type:"text",text:t.text};case"image":throw new Error("Image type not supported");default:throw new Error("Invalid content type")}})}:{role:"user",content:e.content};case"assistant":if(Array.isArray(e.content))return{role:"assistant",content:e.content.map(t=>{switch(t.type){case"text":return{type:"text",text:t.text};case"image":throw new Error("Image type not supported");default:throw new Error("Invalid content type")}})};if(!e.content)throw new Error("Assistant content is empty");return{role:"user",content:e.content};default:throw new Error("Invalid role")}})}var kn=class extends Be{constructor({apiKey:e,config:t,options:n,apiURL:r,modelInfo:s=Uo,models:i}){if(!e||e==="")throw new Error("Reka API key not set");let a={...vr(),...t},l=new wi(a);super(l,{name:"Reka",apiURL:r||"https://api.reka.ai/v1/chat",headers:async()=>({"X-Api-Key":e}),modelInfo:s,defaults:{model:a.model},options:n,supportFor:{functions:!0,streaming:!0,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},models:i})}};var Go=class{providers;processingServices;config;constructor(e){this.providers=[e.providers.primary,...e.providers.alternatives],this.processingServices=e.processing,this.config=e.routing}async chat(e,t={}){let n=await this.selectProviderWithDegradation(e,t.routingOptions||{}),r=await this.preprocessRequest(e,n.provider,t.processingOptions);try{return{response:await n.provider.chat(r,t),routing:n}}catch(s){if(s instanceof ft&&t.fallbackProviders?.length)return await this.tryFallbackProviders(e,t.fallbackProviders,t);throw s}}async preprocessRequest(e,t,n){let r={...n,fallbackBehavior:n?.fallbackBehavior||"degrade",imageToText:n?.imageToText||this.processingServices.imageToText,audioToText:n?.audioToText||this.processingServices.audioToText,fileToText:n?.fileToText||this.processingServices.fileToText,urlToText:n?.urlToText||this.processingServices.urlToText},s=[];for(let i of e.chatPrompt)if(i.role==="user"&&Array.isArray(i.content)){let a=await Do(i.content,t,r);a.every(c=>c.type==="text")&&a.length===1?s.push({...i,content:a[0].text}):s.push({...i,content:a.map(c=>({type:"text",text:c.text}))})}else s.push(i);return{...e,chatPrompt:s}}async selectProviderWithDegradation(e,t){let n=Xt(e),r=[],s=[],i=[];try{let a=Co(e,this.providers,{requireExactMatch:t.requireExactMatch??this.config.capability.requireExactMatch,allowDegradation:t.allowDegradation??this.config.capability.allowDegradation}),l=a.getFeatures();return n.hasImages&&!l.media.images.supported&&(s.push("Images will be converted to text descriptions"),r.push("Image-to-text conversion")),n.hasAudio&&!l.media.audio.supported&&(s.push("Audio will be transcribed to text"),r.push("Audio-to-text transcription")),n.hasFiles&&!l.media.files.supported&&(s.push("File content will be extracted to text"),r.push("File-to-text extraction")),n.hasUrls&&!l.media.urls.supported&&(s.push("URL content will be pre-fetched"),r.push("URL content fetching")),n.requiresStreaming&&!l.streaming&&i.push("Streaming not supported - will use non-streaming mode"),n.requiresCaching&&!l.caching.supported&&i.push("Content caching not supported"),{provider:a,processingApplied:r,degradations:s,warnings:i}}catch(a){throw new Error(`Provider selection failed: ${a instanceof Error?a.message:"Unknown error"}`)}}async tryFallbackProviders(e,t,n){for(let r of t)try{let s={provider:r,processingApplied:["Fallback provider selection"],degradations:["Using fallback provider due to primary provider failure"],warnings:[]},i=await this.preprocessRequest(e,r,{fallbackBehavior:"degrade"});return{response:await r.chat(i,n),routing:s}}catch{}throw new Error("All fallback providers failed")}async getRoutingRecommendation(e){return await this.selectProviderWithDegradation(e,{})}async validateRequest(e){let t=Xt(e),n=[],r=[];try{let s=await this.selectProviderWithDegradation(e,{});return s.degradations.length>0&&(n.push(...s.degradations),r.push("Consider using a provider that natively supports all media types")),s.warnings.length>0&&n.push(...s.warnings),t.hasImages&&this.processingServices.imageToText===void 0&&(this.providers.some(a=>a.getFeatures().media.images.supported)||(n.push("No image processing service available and no providers support images"),r.push("Add imageToText processing service or use image-capable provider"))),t.hasAudio&&this.processingServices.audioToText===void 0&&(this.providers.some(a=>a.getFeatures().media.audio.supported)||(n.push("No audio processing service available and no providers support audio"),r.push("Add audioToText processing service or use audio-capable provider"))),{canHandle:n.length===0||s.degradations.length>0,issues:n,recommendations:r}}catch(s){return{canHandle:!1,issues:[`Cannot route request: ${s instanceof Error?s.message:"Unknown error"}`],recommendations:["Add more providers or processing services to handle this request"]}}}getRoutingStats(){let e={};for(let t of this.providers){let n=t.getFeatures(),r=t.getName();n.functions&&(e.Functions=e.Functions||[],e.Functions.push(r)),n.streaming&&(e.Streaming=e.Streaming||[],e.Streaming.push(r)),n.media.images.supported&&(e.Images=e.Images||[],e.Images.push(r)),n.media.audio.supported&&(e.Audio=e.Audio||[],e.Audio.push(r)),n.media.files.supported&&(e.Files=e.Files||[],e.Files.push(r)),n.media.urls.supported&&(e.URLs=e.URLs||[],e.URLs.push(r)),n.caching.supported&&(e.Caching=e.Caching||[],e.Caching.push(r))}return{totalProviders:this.providers.length,capabilityMatrix:e,recommendedProvider:this.providers[0]?.getName()||"None"}}};var Sr=(h=>(h.KimiK25="moonshotai/Kimi-K2.5",h.KimiK2Instruct0905="moonshotai/Kimi-K2-Instruct-0905",h.KimiK2Thinking="moonshotai/Kimi-K2-Thinking",h.DeepSeekV31="deepseek-ai/DeepSeek-V3.1",h.DeepSeekR1="deepseek-ai/DeepSeek-R1",h.GPTOSS120B="openai/gpt-oss-120b",h.GPTOSS20B="openai/gpt-oss-20b",h.Qwen35_397B="Qwen/Qwen3.5-397B-A17B",h.Qwen3CoderNext="Qwen/Qwen3-Coder-Next-FP8",h.Qwen3Coder480B="Qwen/Qwen3-Coder-480B-A35B-Instruct-FP8",h.Qwen3_235BInstruct2507="Qwen/Qwen3-235B-A22B-Instruct-2507-tput",h.Qwen3_235BThinking2507="Qwen/Qwen3-235B-A22B-Thinking-2507",h.Qwen3Next80BInstruct="Qwen/Qwen3-Next-80B-A3B-Instruct",h.Qwen3Next80BThinking="Qwen/Qwen3-Next-80B-A3B-Thinking",h.GLM5="zai-org/GLM-5",h.GLM47="zai-org/GLM-4.7",h.Llama4Maverick="meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8",h.Llama33_70B="meta-llama/Llama-3.3-70B-Instruct-Turbo",h))(Sr||{});var Bo=[{name:"moonshotai/Kimi-K2.5",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:2.8},{name:"moonshotai/Kimi-K2-Instruct-0905",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:3},{name:"moonshotai/Kimi-K2-Thinking",currency:"usd",promptTokenCostPer1M:1.2,completionTokenCostPer1M:4},{name:"deepseek-ai/DeepSeek-V3.1",currency:"usd",promptTokenCostPer1M:.6,completionTokenCostPer1M:1.7},{name:"deepseek-ai/DeepSeek-R1",currency:"usd",promptTokenCostPer1M:1.4,completionTokenCostPer1M:2.2},{name:"openai/gpt-oss-120b",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:.6},{name:"openai/gpt-oss-20b",currency:"usd",promptTokenCostPer1M:.05,completionTokenCostPer1M:.2},{name:"Qwen/Qwen3.5-397B-A17B",currency:"usd",promptTokenCostPer1M:.6,completionTokenCostPer1M:3.6},{name:"Qwen/Qwen3-Coder-Next-FP8",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.2},{name:"Qwen/Qwen3-Coder-480B-A35B-Instruct-FP8",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:2},{name:"Qwen/Qwen3-235B-A22B-Instruct-2507-tput",currency:"usd",promptTokenCostPer1M:.2,completionTokenCostPer1M:.6},{name:"Qwen/Qwen3-235B-A22B-Thinking-2507",currency:"usd",promptTokenCostPer1M:.65,completionTokenCostPer1M:3},{name:"Qwen/Qwen3-Next-80B-A3B-Instruct",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:1.5},{name:"Qwen/Qwen3-Next-80B-A3B-Thinking",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:1.5},{name:"zai-org/GLM-5",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:3.2},{name:"zai-org/GLM-4.7",currency:"usd",promptTokenCostPer1M:.45,completionTokenCostPer1M:2},{name:"meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8",currency:"usd",promptTokenCostPer1M:.27,completionTokenCostPer1M:.85},{name:"meta-llama/Llama-3.3-70B-Instruct-Turbo",currency:"usd",promptTokenCostPer1M:.88,completionTokenCostPer1M:.88}];var Ri=()=>structuredClone({model:"meta-llama/Llama-3.3-70B-Instruct-Turbo",...we()}),On=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("Together API key not set");let i={...Ri(),...t};s=[...Bo,...s??[]];let a={functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0};super({apiKey:e,config:i,options:n,apiURL:"https://api.together.xyz/v1",modelInfo:s,models:r,supportFor:a}),super.setName("Together")}};var kr=(d=>(d.Llama31_8B_Instruct="Llama-3.1-8B-Instruct-q4f32_1-MLC",d.Llama31_70B_Instruct="Llama-3.1-70B-Instruct-q4f16_1-MLC",d.Llama32_1B_Instruct="Llama-3.2-1B-Instruct-q4f32_1-MLC",d.Llama32_3B_Instruct="Llama-3.2-3B-Instruct-q4f32_1-MLC",d.Mistral7B_Instruct="Mistral-7B-Instruct-v0.3-q4f32_1-MLC",d.Phi35_Mini_Instruct="Phi-3.5-mini-instruct-q4f32_1-MLC",d.Gemma2_2B_Instruct="gemma-2-2b-it-q4f32_1-MLC",d.Gemma2_9B_Instruct="gemma-2-9b-it-q4f32_1-MLC",d.Qwen2_5_0_5B_Instruct="Qwen2.5-0.5B-Instruct-q4f32_1-MLC",d.Qwen2_5_1_5B_Instruct="Qwen2.5-1.5B-Instruct-q4f32_1-MLC",d.Qwen2_5_3B_Instruct="Qwen2.5-3B-Instruct-q4f32_1-MLC",d.Qwen2_5_7B_Instruct="Qwen2.5-7B-Instruct-q4f32_1-MLC",d))(kr||{});var jo=[{name:"Llama-3.1-8B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:4096},{name:"Llama-3.1-70B-Instruct-q4f16_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:4096,isExpensive:!0},{name:"Llama-3.2-1B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:2048},{name:"Llama-3.2-3B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:2048},{name:"Mistral-7B-Instruct-v0.3-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:4096},{name:"Phi-3.5-mini-instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:4096},{name:"gemma-2-2b-it-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:8192,maxTokens:2048},{name:"gemma-2-9b-it-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:8192,maxTokens:2048},{name:"Qwen2.5-0.5B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:2048},{name:"Qwen2.5-1.5B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:2048},{name:"Qwen2.5-3B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:2048},{name:"Qwen2.5-7B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:4096}];var Si=()=>structuredClone({model:"Llama-3.2-3B-Instruct-q4f32_1-MLC",...we()}),Yl=()=>structuredClone({model:"Llama-3.2-3B-Instruct-q4f32_1-MLC",...He()}),vi=class{constructor(e,t){this.config=e;this.engine=t}tokensUsed;engine;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,topP:e.topP,topK:e.topK,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,stopSequences:e.stopSequences,endSequences:e.endSequences,stream:e.stream,n:e.n}}createChatReq(e){let t=e.model,n=e.chatPrompt.map(a=>{if(a.role==="function")return{role:"function",name:a.functionId,content:typeof a.result=="string"?a.result:JSON.stringify(a.result)};let l="";typeof a.content=="string"?l=a.content:Array.isArray(a.content)&&(l=a.content.filter(u=>u.type==="text").map(u=>u.text).join(`
179
- `));let c={role:a.role,content:l};return a.role==="assistant"&&a.functionCalls?.length?{...c,tool_calls:a.functionCalls.map(u=>({id:u.id,type:"function",function:{name:u.function.name,arguments:typeof u.function.params=="string"?u.function.params:JSON.stringify(u.function.params||{})}}))}:c}),r=e.functions?.map(a=>({type:"function",function:{name:a.name,description:a.description,parameters:a.parameters||{type:"object",properties:{}}}})),s={name:"/chat/completions",localCall:async(a,l)=>{try{let c=await this.engine.chat.completions.create({...a,stream:l||!1});return l?new ReadableStream({async start(u){try{for await(let p of c)u.enqueue(p);u.close()}catch(p){u.error(p)}}}):c}catch(c){throw new Error(`WebLLM API error: ${c}`)}}},i={model:t,messages:n,...r?.length?{tools:r}:{},max_tokens:e.modelConfig?.maxTokens??this.config.maxTokens,...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty,frequency_penalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,stop:e.modelConfig?.stopSequences??this.config.stopSequences,stream:e.modelConfig?.stream??this.config.stream,n:e.modelConfig?.n??this.config.n};return[s,i]}createEmbedReq=e=>{throw new Error("WebLLM does not support embeddings")};createChatResp=e=>(this.tokensUsed={promptTokens:e.usage?.prompt_tokens??0,completionTokens:e.usage?.completion_tokens??0,totalTokens:e.usage?.total_tokens??0},{results:e.choices.map((n,r)=>{let s="stop";switch(n.finish_reason){case"stop":s="stop";break;case"length":s="length";break;case"tool_calls":s="function_call";break;case"content_filter":s="content_filter";break;default:s="stop";break}let i=n.message.tool_calls?.map(a=>({id:a.id,type:"function",function:{name:a.function.name,params:a.function.arguments}}));return{index:r,id:e.id,content:n.message.content||"",functionCalls:i,finishReason:s}}),remoteId:e.id});createChatStreamResp=(e,t)=>{let n=t,r=e.choices[0];if(!r)throw new Error("No choice in WebLLM stream response");if(r.delta.content&&(n.content=(n.content||"")+r.delta.content),r.delta.tool_calls){n.toolCalls||(n.toolCalls=[]);for(let l of r.delta.tool_calls){let c=n.toolCalls[l.index];c?l.function?.arguments&&(c.function.arguments=(c.function?.arguments||"")+l.function.arguments):n.toolCalls[l.index]={id:l.id,type:l.type,function:{name:l.function?.name,arguments:l.function?.arguments||""}}}}e.usage&&(this.tokensUsed={promptTokens:e.usage.prompt_tokens,completionTokens:e.usage.completion_tokens,totalTokens:e.usage.total_tokens});let s;if(r.finish_reason)switch(r.finish_reason){case"stop":s="stop";break;case"length":s="length";break;case"tool_calls":s="function_call";break;case"content_filter":s="content_filter";break;default:s="stop";break}let i=n.toolCalls?.map(l=>({id:l.id||"",type:"function",function:{name:l.function?.name||"",params:l.function?.arguments||""}}));return{results:[{index:0,id:e.id,content:n.content||"",functionCalls:i,finishReason:s}],remoteId:e.id}};createEmbedResp(e){throw new Error("WebLLM does not support embeddings")}},En=class extends Be{constructor({engine:e,config:t,options:n,models:r}){if(!e)throw new Error("WebLLM engine instance is required");let s={...Si(),...t},i=new vi(s,e);super(i,{name:"WebLLM",apiURL:void 0,headers:async()=>({}),modelInfo:jo,defaults:{model:s.model},supportFor:a=>({functions:!0,streaming:!0,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}),options:n,models:r})}};var Or=(r=>(r.Grok3="grok-3",r.Grok3Mini="grok-3-mini",r.Grok3Fast="grok-3-fast",r.Grok3MiniFast="grok-3-mini-fast",r))(Or||{}),ki=(e=>(e.GrokEmbedSmall="grok-embed-small",e))(ki||{});var zo=[{name:"grok-3",currency:"USD",promptTokenCostPer1M:3,completionTokenCostPer1M:15},{name:"grok-3-mini",currency:"USD",promptTokenCostPer1M:.3,completionTokenCostPer1M:.5,supported:{thinkingBudget:!0}},{name:"grok-3-fast",currency:"USD",promptTokenCostPer1M:5,completionTokenCostPer1M:25},{name:"grok-3-mini-fast",currency:"USD",promptTokenCostPer1M:.6,completionTokenCostPer1M:4,supported:{thinkingBudget:!0}}];var qo=()=>structuredClone({model:"grok-3-mini",...we()}),Xl=()=>structuredClone({...qo(),model:"grok-3"}),Mn=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("Grok API key not set");let i={...qo(),...t};s=[...zo,...s??[]];let a=c=>{let u=mt({model:c,modelInfo:s,models:r});return{functions:!0,streaming:!0,hasThinkingBudget:u?.supported?.thinkingBudget??!1,hasShowThoughts:u?.supported?.showThoughts??!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}},l=c=>{if(n?.searchParameters){let u=n.searchParameters;return{...c,search_parameters:{mode:u.mode,return_citations:u.returnCitations,from_date:u.fromDate,to_date:u.toDate,max_search_results:u.maxSearchResults,sources:u.sources?.map(p=>({type:p.type,country:p.country,excluded_websites:p.excludedWebsites,allowed_websites:p.allowedWebsites,safe_search:p.safeSearch,x_handles:p.xHandles,links:p.links}))}}}return c};super({apiKey:e,config:i,options:n,apiURL:"https://api.x.ai/v1",modelInfo:s,models:r,supportFor:a,chatReqUpdater:l}),super.setName("Grok")}};function Zl(o){return Er.create(o)}var Er=class o{ai;static create(e){return new o(e)}constructor(e){switch(e.name){case"openai":this.ai=new fn(e);break;case"openai-responses":this.ai=new vn(e);break;case"azure-openai":this.ai=new hn(e);break;case"grok":this.ai=new Mn(e);break;case"huggingface":this.ai=new Cn(e);break;case"groq":this.ai=new Tn(e);break;case"together":this.ai=new On(e);break;case"openrouter":this.ai=new Sn(e);break;case"cohere":this.ai=new xn(e);break;case"google-gemini":this.ai=new yn(e);break;case"anthropic":this.ai=new pn(e);break;case"mistral":this.ai=new In(e);break;case"deepseek":this.ai=new An(e);break;case"ollama":this.ai=new wn(e);break;case"reka":this.ai=new kn(e);break;case"webllm":this.ai=new En(e);break;default:throw new Error("Unknown AI")}}getName(){return this.ai.getName()}getId(){return this.ai.getId()}getFeatures(e){return this.ai.getFeatures(e)}getModelList(){return this.ai.getModelList()}getLastUsedChatModel(){return this.ai.getLastUsedChatModel()}getLastUsedEmbedModel(){return this.ai.getLastUsedEmbedModel()}getLastUsedModelConfig(){return this.ai.getLastUsedModelConfig()}getMetrics(){return this.ai.getMetrics()}async chat(e,t){return await this.ai.chat(e,t)}async embed(e,t){return await this.ai.embed(e,t)}setOptions(e){this.ai.setOptions(e)}getOptions(){return this.ai.getOptions()}getLogger(){return this.ai.getLogger()}};var Ho=require("@opentelemetry/api");var ht=class{name;fetch;tracer;_upsert;_batchUpsert;_query;constructor({name:e,fetch:t,tracer:n}){this.name=e,this.fetch=t,this.tracer=n}async upsert(e,t){if(!this._upsert)throw new Error("upsert() not implemented");return this.tracer?await this.tracer.startActiveSpan("DB Upsert Request",{kind:Ho.SpanKind.SERVER,attributes:{[he.DB_SYSTEM]:this.name,[he.DB_OPERATION_NAME]:"upsert",[he.DB_TABLE]:e.table,[he.DB_NAMESPACE]:e.namespace,[he.DB_OPERATION_NAME]:t?"update":"insert"}},async n=>{try{return await this._upsert(e,t,{span:n})}finally{n.end()}}):await this._upsert(e,t)}async batchUpsert(e,t){if(!this._batchUpsert)throw new Error("batchUpsert() not implemented");if(e.length===0)throw new Error("Batch request is empty");if(!e[0])throw new Error("Batch request is invalid first element is undefined");return this.tracer?await this.tracer.startActiveSpan("DB Batch Upsert Request",{kind:Ho.SpanKind.SERVER,attributes:{[he.DB_SYSTEM]:this.name,[he.DB_OPERATION_NAME]:"upsert",[he.DB_TABLE]:e[0].table,[he.DB_NAMESPACE]:e[0].namespace,[he.DB_OPERATION_NAME]:t?"update":"insert"}},async n=>{try{return await this._batchUpsert(e,t,{span:n})}finally{n.end()}}):await this._batchUpsert(e,t)}async query(e){if(!this._query)throw new Error("query() not implemented");return this.tracer?await this.tracer.startActiveSpan("DB Query Request",{kind:Ho.SpanKind.SERVER,attributes:{[he.DB_SYSTEM]:this.name,[he.DB_OPERATION_NAME]:"upsert",[he.DB_TABLE]:e.table,[he.DB_NAMESPACE]:e.namespace,[he.DB_OPERATION_NAME]:"query"}},async t=>{try{return await this._query(e,{span:t})}finally{t.end()}}):await this._query(e)}};var Oi="https://api.cloudflare.com/client/v4/accounts/",Pn=class extends ht{apiKey;accountId;constructor({apiKey:e,accountId:t,fetch:n,tracer:r}){if(!e||!t)throw new Error("Cloudflare credentials not set");super({name:"Cloudflare",fetch:n,tracer:r}),this.apiKey=e,this.accountId=t}_upsert=async(e,t,n)=>{let r=await tt({url:new URL(`${this.accountId}/vectorize/indexes/${e.table}/upsert`,Oi),headers:{"X-Auth-Key":this.apiKey},fetch:this.fetch,span:n?.span},{id:e.id,values:e.values,namespace:e.namespace,metadata:e.metadata});if(r.errors)throw new Error(`Cloudflare upsert failed: ${r.errors.map(({message:s})=>s).join(", ")}`);return{ids:r.result.ids}};batchUpsert=async(e,t,n)=>{if(t)throw new Error("Weaviate does not support batch update");if(e.length<1)throw new Error("Batch request is empty");if(!e[0]||!e[0].table)throw new Error("Table name is empty");let r=e[0].table,s=await tt({url:new URL(`${this.accountId}/vectorize/indexes/${r}/upsert`,Oi),headers:{"X-Auth-Key":this.apiKey},fetch:this.fetch,span:n?.span},e.map(i=>({id:i.id,values:i.values,namespace:i.namespace,metadata:i.metadata})));if(s.errors)throw new Error(`Cloudflare batch upsert failed: ${s.errors.map(({message:i})=>i).join(", ")}`);return{ids:s.result.ids}};query=async(e,t)=>{let n=await tt({url:new URL(`${this.accountId}/vectorize/indexes/${e.table}/query`,Oi),headers:{"X-Auth-Key":this.apiKey},fetch:this.fetch,span:t?.span},{vector:e.values,topK:e.limit||10,returnValues:!0});if(n.errors)throw new Error(`Cloudflare query failed: ${n.errors.map(({message:s})=>s).join(", ")}`);return{matches:n.result.matches.map(({id:s,score:i,values:a,metadata:l})=>({id:s,score:i,values:a,metadata:l}))}}};var Gt=class extends ht{state;constructor({tracer:e}={}){super({name:"Memory",tracer:e}),this.state={}}_upsert=async(e,t,n)=>{if(!this.state[e.table])this.state[e.table]={[e.id]:e};else{let r=this.state[e.table];if(!r)throw new Error(`Table not found: ${e.table}`);r[e.id]=e}return{ids:[e.id]}};_batchUpsert=async(e,t,n)=>{let r=[];for(let s of e){let i=await this.upsert(s,t);r.push(...i.ids)}return{ids:r}};_query=async(e,t)=>{let n=this.state[e.table];if(!n)return{matches:[]};let r=[];return Object.entries(n).forEach(([s,i])=>{if(e.values&&i.values){let a=rd(e.values,i.values);r.push({id:s,score:a,metadata:i.metadata})}}),r.sort((s,i)=>s.score-i.score),e.limit&&(r.length=e.limit),{matches:r}};getDB=()=>structuredClone(this.state);setDB=e=>{this.state=structuredClone(e)};clearDB=()=>{this.state={}}},rd=(o,e)=>{if(o.length!==e.length)throw new Error("Vectors must be of the same length.");let t=0,n=0,r=0,s=!0,i=!0,a=new Float64Array(o),l=new Float64Array(e);for(let d=0;d<a.length;d++)t+=a[d]*l[d],n+=a[d]*a[d],r+=l[d]*l[d],a[d]!==0&&(s=!1),l[d]!==0&&(i=!1);if(s||i)return 1;let c=Math.sqrt(n),u=Math.sqrt(r);return 1-t/(c*u)};var od=o=>({namespace:o.namespace,topK:o.limit||10,filter:{},includeValues:!0,includeMetadata:!0,vector:o.values??[],id:o.id}),Fn=class extends ht{apiKey;apiURL;constructor({apiKey:e,host:t,fetch:n,tracer:r}){if(!e||e==="")throw new Error("Pinecone API key not set");super({name:"Pinecone",fetch:n,tracer:r}),this.apiKey=e,this.apiURL=t}_upsert=async(e,t,n)=>(await this._batchUpsert([e],t,n),{ids:[e.id]});_batchUpsert=async(e,t,n)=>{if(e.length===0)throw new Error("Batch request is empty");return await tt({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:"/vectors/upsert",fetch:this.fetch,span:n?.span},e.map(({id:r,values:s=[],metadata:i})=>({id:r,values:s,metadata:i}))),{ids:e.map(({id:r})=>r)}};query=async(e,t)=>{if(e.text)throw new Error("Pinecone does not support text");return{matches:(await tt({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:"/query",fetch:this.fetch,span:t?.span},od(e))).matches.map(({id:s,score:i,values:a,metadata:l})=>({id:s,score:i,metadata:l,values:a}))}}};var _n=class extends ht{apiKey;apiURL;constructor({apiKey:e,host:t,fetch:n,tracer:r}){if(!e||e==="")throw new Error("Weaviate API key not set");super({name:"Weaviate",fetch:n,tracer:r}),this.apiKey=e,this.apiURL=t}_upsert=async(e,t,n)=>{let r=await tt({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:`/v1/objects/${e.table}/${e.id}`,put:!!t,fetch:this.fetch,span:n?.span},{id:e.id,class:e.table,tenant:e.namespace,vector:e.values,properties:e.metadata??{}});if(r?.result?.errors)throw new Error(`Weaviate upsert failed: ${r.result.errors.error.map(({message:s})=>s).join(", ")}`);return{ids:[r.id]}};_batchUpsert=async(e,t,n)=>{if(t)throw new Error("Weaviate does not support batch update");if(e.length===0)throw new Error("Batch request is empty");let r=e.map(i=>({id:i.id,class:i.table,tenant:i.namespace,vector:i.values,properties:i.metadata??{}})),s=await tt({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:"/v1/batch/objects",fetch:this.fetch,span:n?.span},{objects:r});if(s?.some(({result:i})=>i?.errors))throw new Error(`Weaviate batch upsert failed: ${s.map(({result:i})=>i?.errors?.error.map(({message:a})=>a).join(", ")).join(", ")}`);return{ids:s.map(({id:i})=>i)}};_query=async(e,t)=>{let n="";if(e.columns&&e.columns.length===0)throw new Error("Weaviate requires at least one column");if(e.values)n=`nearVector: {
178
+ `)};function jo(o){let e=[];for(let t of o??[])if(t?.type==="output_text"&&Array.isArray(t.annotations))for(let n of t.annotations)n&&n.type==="url_citation"&&typeof n.url=="string"&&e.push({url:n.url,title:n.title,description:n.description});return e.length?e:void 0}var vr=()=>({model:"gpt-4o",embedModel:"text-embedding-ada-002",temperature:.7,topP:1,stream:!0}),rc=()=>({...vr(),model:"gpt-4o",temperature:.5}),oc=()=>({...vr(),model:"gpt-4o",temperature:.9}),Rr=class extends je{constructor({apiKey:e,config:t,options:n,apiURL:r,modelInfo:s=[],models:i,responsesReqUpdater:a,supportFor:u={functions:!0,streaming:!0,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}}){if(!e||e==="")throw new Error("OpenAI API key not set");let c=new On(t,n?.streamingUsage??!0,a),l=i?.map(p=>{let d=p,m=d?.config;if(!m)return p;let g={};m.maxTokens!==void 0&&(g.maxTokens=m.maxTokens),m.temperature!==void 0&&(g.temperature=m.temperature),m.topP!==void 0&&(g.topP=m.topP),m.presencePenalty!==void 0&&(g.presencePenalty=m.presencePenalty),m.frequencyPenalty!==void 0&&(g.frequencyPenalty=m.frequencyPenalty);let f=m.stopSequences??m.stop;f!==void 0&&(g.stopSequences=f),m.n!==void 0&&(g.n=m.n),m.stream!==void 0&&(g.stream=m.stream);let x={...d};Object.keys(g).length>0&&(x.modelConfig={...d.modelConfig??{},...g});let A=m?.thinking?.thinkingTokenBudget;if(typeof A=="number"){let h=[["minimal",200],["low",800],["medium",5e3],["high",1e4],["highest",24500]],y="minimal",C=Number.POSITIVE_INFINITY;for(let[I,v]of h){let O=Math.abs(A-v);O<C&&(C=O,y=I)}x.thinkingTokenBudget=y}return m?.thinking?.includeThoughts!==void 0&&(x.showThoughts=!!m.thinking.includeThoughts),x});super(c,{name:"OpenAI",apiURL:r||"https://api.openai.com/v1",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:s,defaults:{model:t.model??"gpt-4o",embedModel:t.embedModel??"text-embedding-ada-002"},options:n,supportFor:u,models:l??i})}},En=class extends Rr{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("OpenAI API key not set");s=[...bo,...s??[]];let i=a=>{let u=mt({model:a,modelInfo:s,models:r});return{functions:!0,streaming:!0,hasThinkingBudget:u?.supported?.thinkingBudget??!1,hasShowThoughts:u?.supported?.showThoughts??!1,structuredOutputs:u?.supported?.structuredOutputs??!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}};super({apiKey:e,config:{...vr(),...t},options:n,modelInfo:s,models:r,supportFor:i})}};var ki=()=>structuredClone({model:"openrouter/auto",...ve()}),Mn=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s,referer:i,title:a}){if(!e||e==="")throw new Error("OpenRouter API key not set");let u={...ki(),...t},c={functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},l=s??[];super({apiKey:e,config:u,options:n,apiURL:"https://openrouter.ai/api/v1",modelInfo:l,models:r,supportFor:c}),super.setName("OpenRouter"),super.setHeaders(async()=>{let p={Authorization:`Bearer ${e}`};return i&&(p["HTTP-Referer"]=i),a&&(p["X-Title"]=a),p})}};async function Bo(o,e,t={}){if(typeof o=="string")return[{type:"text",text:o}];if(!Array.isArray(o))return[{type:"text",text:String(o)}];let n=e.getFeatures(),r=[];for(let s of o)try{switch(s.type){case"text":r.push({type:"text",text:s.text});break;case"image":if(n.media.images.supported)s.altText?r.push({type:"text",text:`[Image: ${s.altText}]`}):r.push({type:"text",text:"[Image content]"});else if(s.altText)r.push({type:"text",text:s.altText});else if(t.imageToText)try{let i=await t.imageToText(s.image);r.push({type:"text",text:i})}catch(i){throw new Tt(i,"image","vision analysis")}else switch(t.fallbackBehavior){case"error":throw new ft("Images",e.getName(),!1);case"skip":continue;default:r.push({type:"text",text:"[Image content not supported by this provider]"})}break;case"audio":if(n.media.audio.supported)s.transcription?r.push({type:"text",text:s.transcription}):r.push({type:"text",text:"[Audio content]"});else if(s.transcription)r.push({type:"text",text:s.transcription});else if(t.audioToText)try{let i=await t.audioToText(s.data,s.format);r.push({type:"text",text:i})}catch(i){throw new Tt(i,"audio","transcription")}else switch(t.fallbackBehavior){case"error":throw new ft("Audio",e.getName(),!1);case"skip":continue;case"degrade":r.push({type:"text",text:"[Audio content not supported by this provider]"})}break;case"file":if(n.media.files.supported)s.extractedText?r.push({type:"text",text:s.extractedText}):r.push({type:"text",text:`[File: ${s.filename}]`});else if(s.extractedText)r.push({type:"text",text:s.extractedText});else if(t.fileToText)try{let i=await t.fileToText(s.data,s.mimeType);r.push({type:"text",text:i})}catch(i){throw new Tt(i,"file","text extraction")}else switch(t.fallbackBehavior){case"error":throw new ft("Files",e.getName(),!1);case"skip":continue;default:r.push({type:"text",text:`[File: ${s.filename} - content not accessible by this provider]`})}break;case"url":if(n.media.urls.supported)s.cachedContent?r.push({type:"text",text:s.cachedContent}):r.push({type:"text",text:`[Link: ${s.url}${s.title?` - ${s.title}`:""}]`});else if(s.cachedContent)r.push({type:"text",text:s.cachedContent});else if(t.urlToText)try{let i=await t.urlToText(s.url);r.push({type:"text",text:i})}catch(i){throw new Tt(i,"url","content fetching")}else switch(t.fallbackBehavior){case"error":throw new ft("URLs",e.getName(),!1);case"skip":continue;case"degrade":r.push({type:"text",text:`[Link: ${s.url}${s.title?` - ${s.title}`:""}]`})}break;default:typeof s=="object"&&s.text?r.push({type:"text",text:s.text}):r.push({type:"text",text:String(s)})}}catch(i){throw i instanceof ft||i instanceof Tt?i:new Tt(i,s.type||"unknown","content processing")}return r}function sc(o){let e=!1,t=!1,n=!1,r=!1;for(let s of o)if(s.role==="user"&&Array.isArray(s.content))for(let i of s.content)switch(i.type){case"image":e=!0;break;case"audio":t=!0;break;case"file":n=!0;break;case"url":r=!0;break}return{hasImages:e,hasAudio:t,hasFiles:n,hasUrls:r}}var Sr=(n=>(n.RekaCore="reka-core",n.RekaFlash="reka-flash",n.RekaEdge="reka-edge",n))(Sr||{});var zo=[{name:"reka-core",currency:"usd",promptTokenCostPer1M:3,completionTokenCostPer1M:15},{name:"reka-flash",currency:"usd",promptTokenCostPer1M:.8,completionTokenCostPer1M:2},{name:"reka-edge",currency:"usd",promptTokenCostPer1M:.4,completionTokenCostPer1M:1}];var kr=()=>structuredClone({model:"reka-core",...ve()}),ac=()=>structuredClone({...kr(),model:"reka-core"}),uc=()=>structuredClone({model:"reka-core",...He()}),cc=()=>({...kr(),model:"reka-flash"}),Oi=class{constructor(e){this.config=e}tokensUsed;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,stopSequences:e.stopSequences,topP:e.topP,n:e.n,stream:e.stream}}createChatReq=e=>{let t=e.model;if(!e.chatPrompt||e.chatPrompt.length===0)throw new Error("Chat prompt is empty");let n={name:"/chat/completions"},r=qd(e),s=e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,i=e.modelConfig?.stream??this.config.stream,a={model:t,messages:r,max_tokens:e.modelConfig?.maxTokens??this.config.maxTokens,...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},top_k:e.modelConfig?.n??this.config.n,...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},stop:e.modelConfig?.stopSequences??this.config.stop,presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty,...s?{frequency_penalty:s}:{},...i?{stream:!0}:{}};return[n,a]};createChatResp=e=>{let{id:t,usage:n,responses:r}=e;return this.tokensUsed=n?{promptTokens:n.input_tokens,completionTokens:n.output_tokens,totalTokens:n.input_tokens+n.output_tokens}:void 0,{results:r.map((i,a)=>{let u=ic(i.finish_reason),c;return typeof i.message.content=="string"?c=i.message.content:c=i.message.content.text,{index:a,id:`${t}`,content:c,finishReason:u}}),remoteId:t}};createChatStreamResp=e=>{let{id:t,usage:n,responses:r}=e;return this.tokensUsed=n?{promptTokens:n.input_tokens,completionTokens:n.output_tokens,totalTokens:n.input_tokens+n.output_tokens}:void 0,{results:r.map((i,a)=>{let u=ic(i.finish_reason),c;return typeof i.chunk.content=="string"?c=i.chunk.content:c=i.chunk.content.text,{index:a,id:`${t}`,content:c,finishReason:u}})}}},ic=o=>{switch(o){case"stop":return"stop";case"context":return"length";case"length":return"length"}};function qd(o){return o.chatPrompt.map(e=>{switch(e.role){case"system":return{role:"user",content:e.content};case"user":return Array.isArray(e.content)?{role:"user",content:e.content.map(t=>{switch(t.type){case"text":return{type:"text",text:t.text};case"image":throw new Error("Image type not supported");default:throw new Error("Invalid content type")}})}:{role:"user",content:e.content};case"assistant":if(Array.isArray(e.content))return{role:"assistant",content:e.content.map(t=>{switch(t.type){case"text":return{type:"text",text:t.text};case"image":throw new Error("Image type not supported");default:throw new Error("Invalid content type")}})};if(!e.content)throw new Error("Assistant content is empty");return{role:"user",content:e.content};default:throw new Error("Invalid role")}})}var Pn=class extends je{constructor({apiKey:e,config:t,options:n,apiURL:r,modelInfo:s=zo,models:i}){if(!e||e==="")throw new Error("Reka API key not set");let a={...kr(),...t},u=new Oi(a);super(u,{name:"Reka",apiURL:r||"https://api.reka.ai/v1/chat",headers:async()=>({"X-Api-Key":e}),modelInfo:s,defaults:{model:a.model},options:n,supportFor:{functions:!0,streaming:!0,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0},models:i})}};var qo=class{providers;processingServices;config;constructor(e){this.providers=[e.providers.primary,...e.providers.alternatives],this.processingServices=e.processing,this.config=e.routing}async chat(e,t={}){let n=await this.selectProviderWithDegradation(e,t.routingOptions||{}),r=await this.preprocessRequest(e,n.provider,t.processingOptions);try{return{response:await n.provider.chat(r,t),routing:n}}catch(s){if(s instanceof ft&&t.fallbackProviders?.length)return await this.tryFallbackProviders(e,t.fallbackProviders,t);throw s}}async preprocessRequest(e,t,n){let r={...n,fallbackBehavior:n?.fallbackBehavior||"degrade",imageToText:n?.imageToText||this.processingServices.imageToText,audioToText:n?.audioToText||this.processingServices.audioToText,fileToText:n?.fileToText||this.processingServices.fileToText,urlToText:n?.urlToText||this.processingServices.urlToText},s=[];for(let i of e.chatPrompt)if(i.role==="user"&&Array.isArray(i.content)){let a=await Bo(i.content,t,r);a.every(c=>c.type==="text")&&a.length===1?s.push({...i,content:a[0].text}):s.push({...i,content:a.map(c=>({type:"text",text:c.text}))})}else s.push(i);return{...e,chatPrompt:s}}async selectProviderWithDegradation(e,t){let n=en(e),r=[],s=[],i=[];try{let a=vo(e,this.providers,{requireExactMatch:t.requireExactMatch??this.config.capability.requireExactMatch,allowDegradation:t.allowDegradation??this.config.capability.allowDegradation}),u=a.getFeatures();return n.hasImages&&!u.media.images.supported&&(s.push("Images will be converted to text descriptions"),r.push("Image-to-text conversion")),n.hasAudio&&!u.media.audio.supported&&(s.push("Audio will be transcribed to text"),r.push("Audio-to-text transcription")),n.hasFiles&&!u.media.files.supported&&(s.push("File content will be extracted to text"),r.push("File-to-text extraction")),n.hasUrls&&!u.media.urls.supported&&(s.push("URL content will be pre-fetched"),r.push("URL content fetching")),n.requiresStreaming&&!u.streaming&&i.push("Streaming not supported - will use non-streaming mode"),n.requiresCaching&&!u.caching.supported&&i.push("Content caching not supported"),{provider:a,processingApplied:r,degradations:s,warnings:i}}catch(a){throw new Error(`Provider selection failed: ${a instanceof Error?a.message:"Unknown error"}`)}}async tryFallbackProviders(e,t,n){for(let r of t)try{let s={provider:r,processingApplied:["Fallback provider selection"],degradations:["Using fallback provider due to primary provider failure"],warnings:[]},i=await this.preprocessRequest(e,r,{fallbackBehavior:"degrade"});return{response:await r.chat(i,n),routing:s}}catch{}throw new Error("All fallback providers failed")}async getRoutingRecommendation(e){return await this.selectProviderWithDegradation(e,{})}async validateRequest(e){let t=en(e),n=[],r=[];try{let s=await this.selectProviderWithDegradation(e,{});return s.degradations.length>0&&(n.push(...s.degradations),r.push("Consider using a provider that natively supports all media types")),s.warnings.length>0&&n.push(...s.warnings),t.hasImages&&this.processingServices.imageToText===void 0&&(this.providers.some(a=>a.getFeatures().media.images.supported)||(n.push("No image processing service available and no providers support images"),r.push("Add imageToText processing service or use image-capable provider"))),t.hasAudio&&this.processingServices.audioToText===void 0&&(this.providers.some(a=>a.getFeatures().media.audio.supported)||(n.push("No audio processing service available and no providers support audio"),r.push("Add audioToText processing service or use audio-capable provider"))),{canHandle:n.length===0||s.degradations.length>0,issues:n,recommendations:r}}catch(s){return{canHandle:!1,issues:[`Cannot route request: ${s instanceof Error?s.message:"Unknown error"}`],recommendations:["Add more providers or processing services to handle this request"]}}}getRoutingStats(){let e={};for(let t of this.providers){let n=t.getFeatures(),r=t.getName();n.functions&&(e.Functions=e.Functions||[],e.Functions.push(r)),n.streaming&&(e.Streaming=e.Streaming||[],e.Streaming.push(r)),n.media.images.supported&&(e.Images=e.Images||[],e.Images.push(r)),n.media.audio.supported&&(e.Audio=e.Audio||[],e.Audio.push(r)),n.media.files.supported&&(e.Files=e.Files||[],e.Files.push(r)),n.media.urls.supported&&(e.URLs=e.URLs||[],e.URLs.push(r)),n.caching.supported&&(e.Caching=e.Caching||[],e.Caching.push(r))}return{totalProviders:this.providers.length,capabilityMatrix:e,recommendedProvider:this.providers[0]?.getName()||"None"}}};var Or=(h=>(h.KimiK25="moonshotai/Kimi-K2.5",h.KimiK2Instruct0905="moonshotai/Kimi-K2-Instruct-0905",h.KimiK2Thinking="moonshotai/Kimi-K2-Thinking",h.DeepSeekV31="deepseek-ai/DeepSeek-V3.1",h.DeepSeekR1="deepseek-ai/DeepSeek-R1",h.GPTOSS120B="openai/gpt-oss-120b",h.GPTOSS20B="openai/gpt-oss-20b",h.Qwen35_397B="Qwen/Qwen3.5-397B-A17B",h.Qwen3CoderNext="Qwen/Qwen3-Coder-Next-FP8",h.Qwen3Coder480B="Qwen/Qwen3-Coder-480B-A35B-Instruct-FP8",h.Qwen3_235BInstruct2507="Qwen/Qwen3-235B-A22B-Instruct-2507-tput",h.Qwen3_235BThinking2507="Qwen/Qwen3-235B-A22B-Thinking-2507",h.Qwen3Next80BInstruct="Qwen/Qwen3-Next-80B-A3B-Instruct",h.Qwen3Next80BThinking="Qwen/Qwen3-Next-80B-A3B-Thinking",h.GLM5="zai-org/GLM-5",h.GLM47="zai-org/GLM-4.7",h.Llama4Maverick="meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8",h.Llama33_70B="meta-llama/Llama-3.3-70B-Instruct-Turbo",h))(Or||{});var Ho=[{name:"moonshotai/Kimi-K2.5",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:2.8},{name:"moonshotai/Kimi-K2-Instruct-0905",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:3},{name:"moonshotai/Kimi-K2-Thinking",currency:"usd",promptTokenCostPer1M:1.2,completionTokenCostPer1M:4},{name:"deepseek-ai/DeepSeek-V3.1",currency:"usd",promptTokenCostPer1M:.6,completionTokenCostPer1M:1.7},{name:"deepseek-ai/DeepSeek-R1",currency:"usd",promptTokenCostPer1M:1.4,completionTokenCostPer1M:2.2},{name:"openai/gpt-oss-120b",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:.6},{name:"openai/gpt-oss-20b",currency:"usd",promptTokenCostPer1M:.05,completionTokenCostPer1M:.2},{name:"Qwen/Qwen3.5-397B-A17B",currency:"usd",promptTokenCostPer1M:.6,completionTokenCostPer1M:3.6},{name:"Qwen/Qwen3-Coder-Next-FP8",currency:"usd",promptTokenCostPer1M:.5,completionTokenCostPer1M:1.2},{name:"Qwen/Qwen3-Coder-480B-A35B-Instruct-FP8",currency:"usd",promptTokenCostPer1M:2,completionTokenCostPer1M:2},{name:"Qwen/Qwen3-235B-A22B-Instruct-2507-tput",currency:"usd",promptTokenCostPer1M:.2,completionTokenCostPer1M:.6},{name:"Qwen/Qwen3-235B-A22B-Thinking-2507",currency:"usd",promptTokenCostPer1M:.65,completionTokenCostPer1M:3},{name:"Qwen/Qwen3-Next-80B-A3B-Instruct",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:1.5},{name:"Qwen/Qwen3-Next-80B-A3B-Thinking",currency:"usd",promptTokenCostPer1M:.15,completionTokenCostPer1M:1.5},{name:"zai-org/GLM-5",currency:"usd",promptTokenCostPer1M:1,completionTokenCostPer1M:3.2},{name:"zai-org/GLM-4.7",currency:"usd",promptTokenCostPer1M:.45,completionTokenCostPer1M:2},{name:"meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8",currency:"usd",promptTokenCostPer1M:.27,completionTokenCostPer1M:.85},{name:"meta-llama/Llama-3.3-70B-Instruct-Turbo",currency:"usd",promptTokenCostPer1M:.88,completionTokenCostPer1M:.88}];var Ei=()=>structuredClone({model:"meta-llama/Llama-3.3-70B-Instruct-Turbo",...ve()}),Fn=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("Together API key not set");let i={...Ei(),...t};s=[...Ho,...s??[]];let a={functions:!0,streaming:!0,hasThinkingBudget:!1,hasShowThoughts:!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0};super({apiKey:e,config:i,options:n,apiURL:"https://api.together.xyz/v1",modelInfo:s,models:r,supportFor:a}),super.setName("Together")}};var Er=(d=>(d.Llama31_8B_Instruct="Llama-3.1-8B-Instruct-q4f32_1-MLC",d.Llama31_70B_Instruct="Llama-3.1-70B-Instruct-q4f16_1-MLC",d.Llama32_1B_Instruct="Llama-3.2-1B-Instruct-q4f32_1-MLC",d.Llama32_3B_Instruct="Llama-3.2-3B-Instruct-q4f32_1-MLC",d.Mistral7B_Instruct="Mistral-7B-Instruct-v0.3-q4f32_1-MLC",d.Phi35_Mini_Instruct="Phi-3.5-mini-instruct-q4f32_1-MLC",d.Gemma2_2B_Instruct="gemma-2-2b-it-q4f32_1-MLC",d.Gemma2_9B_Instruct="gemma-2-9b-it-q4f32_1-MLC",d.Qwen2_5_0_5B_Instruct="Qwen2.5-0.5B-Instruct-q4f32_1-MLC",d.Qwen2_5_1_5B_Instruct="Qwen2.5-1.5B-Instruct-q4f32_1-MLC",d.Qwen2_5_3B_Instruct="Qwen2.5-3B-Instruct-q4f32_1-MLC",d.Qwen2_5_7B_Instruct="Qwen2.5-7B-Instruct-q4f32_1-MLC",d))(Er||{});var Ko=[{name:"Llama-3.1-8B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:4096},{name:"Llama-3.1-70B-Instruct-q4f16_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:4096,isExpensive:!0},{name:"Llama-3.2-1B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:2048},{name:"Llama-3.2-3B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:2048},{name:"Mistral-7B-Instruct-v0.3-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:4096},{name:"Phi-3.5-mini-instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:128e3,maxTokens:4096},{name:"gemma-2-2b-it-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:8192,maxTokens:2048},{name:"gemma-2-9b-it-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:8192,maxTokens:2048},{name:"Qwen2.5-0.5B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:2048},{name:"Qwen2.5-1.5B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:2048},{name:"Qwen2.5-3B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:2048},{name:"Qwen2.5-7B-Instruct-q4f32_1-MLC",currency:"usd",promptTokenCostPer1M:0,completionTokenCostPer1M:0,contextWindow:32768,maxTokens:4096}];var Pi=()=>structuredClone({model:"Llama-3.2-3B-Instruct-q4f32_1-MLC",...ve()}),lc=()=>structuredClone({model:"Llama-3.2-3B-Instruct-q4f32_1-MLC",...He()}),Mi=class{constructor(e,t){this.config=e;this.engine=t}tokensUsed;engine;getTokenUsage(){return this.tokensUsed}getModelConfig(){let{config:e}=this;return{maxTokens:e.maxTokens,temperature:e.temperature,topP:e.topP,topK:e.topK,presencePenalty:e.presencePenalty,frequencyPenalty:e.frequencyPenalty,stopSequences:e.stopSequences,endSequences:e.endSequences,stream:e.stream,n:e.n}}createChatReq(e){let t=e.model,n=e.chatPrompt.map(a=>{if(a.role==="function")return{role:"function",name:a.functionId,content:typeof a.result=="string"?a.result:JSON.stringify(a.result)};let u="";typeof a.content=="string"?u=a.content:Array.isArray(a.content)&&(u=a.content.filter(l=>l.type==="text").map(l=>l.text).join(`
179
+ `));let c={role:a.role,content:u};return a.role==="assistant"&&a.functionCalls?.length?{...c,tool_calls:a.functionCalls.map(l=>({id:l.id,type:"function",function:{name:l.function.name,arguments:typeof l.function.params=="string"?l.function.params:JSON.stringify(l.function.params||{})}}))}:c}),r=e.functions?.map(a=>({type:"function",function:{name:a.name,description:a.description,parameters:a.parameters||{type:"object",properties:{}}}})),s={name:"/chat/completions",localCall:async(a,u)=>{try{let c=await this.engine.chat.completions.create({...a,stream:u||!1});return u?new ReadableStream({async start(l){try{for await(let p of c)l.enqueue(p);l.close()}catch(p){l.error(p)}}}):c}catch(c){throw new Error(`WebLLM API error: ${c}`)}}},i={model:t,messages:n,...r?.length?{tools:r}:{},max_tokens:e.modelConfig?.maxTokens??this.config.maxTokens,...e.modelConfig?.temperature!==void 0?{temperature:e.modelConfig.temperature}:{},...e.modelConfig?.topP!==void 0?{top_p:e.modelConfig.topP}:{},presence_penalty:e.modelConfig?.presencePenalty??this.config.presencePenalty,frequency_penalty:e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,stop:e.modelConfig?.stopSequences??this.config.stopSequences,stream:e.modelConfig?.stream??this.config.stream,n:e.modelConfig?.n??this.config.n};return[s,i]}createEmbedReq=e=>{throw new Error("WebLLM does not support embeddings")};createChatResp=e=>(this.tokensUsed={promptTokens:e.usage?.prompt_tokens??0,completionTokens:e.usage?.completion_tokens??0,totalTokens:e.usage?.total_tokens??0},{results:e.choices.map((n,r)=>{let s="stop";switch(n.finish_reason){case"stop":s="stop";break;case"length":s="length";break;case"tool_calls":s="function_call";break;case"content_filter":s="content_filter";break;default:s="stop";break}let i=n.message.tool_calls?.map(a=>({id:a.id,type:"function",function:{name:a.function.name,params:a.function.arguments}}));return{index:r,id:e.id,content:n.message.content||"",functionCalls:i,finishReason:s}}),remoteId:e.id});createChatStreamResp=(e,t)=>{let n=t,r=e.choices[0];if(!r)throw new Error("No choice in WebLLM stream response");if(r.delta.content&&(n.content=(n.content||"")+r.delta.content),r.delta.tool_calls){n.toolCalls||(n.toolCalls=[]);for(let u of r.delta.tool_calls){let c=n.toolCalls[u.index];c?u.function?.arguments&&(c.function.arguments=(c.function?.arguments||"")+u.function.arguments):n.toolCalls[u.index]={id:u.id,type:u.type,function:{name:u.function?.name,arguments:u.function?.arguments||""}}}}e.usage&&(this.tokensUsed={promptTokens:e.usage.prompt_tokens,completionTokens:e.usage.completion_tokens,totalTokens:e.usage.total_tokens});let s;if(r.finish_reason)switch(r.finish_reason){case"stop":s="stop";break;case"length":s="length";break;case"tool_calls":s="function_call";break;case"content_filter":s="content_filter";break;default:s="stop";break}let i=n.toolCalls?.map(u=>({id:u.id||"",type:"function",function:{name:u.function?.name||"",params:u.function?.arguments||""}}));return{results:[{index:0,id:e.id,content:n.content||"",functionCalls:i,finishReason:s}],remoteId:e.id}};createEmbedResp(e){throw new Error("WebLLM does not support embeddings")}},_n=class extends je{constructor({engine:e,config:t,options:n,models:r}){if(!e)throw new Error("WebLLM engine instance is required");let s={...Pi(),...t},i=new Mi(s,e);super(i,{name:"WebLLM",apiURL:void 0,headers:async()=>({}),modelInfo:Ko,defaults:{model:s.model},supportFor:a=>({functions:!0,streaming:!0,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}),options:n,models:r})}};var Mr=(r=>(r.Grok3="grok-3",r.Grok3Mini="grok-3-mini",r.Grok3Fast="grok-3-fast",r.Grok3MiniFast="grok-3-mini-fast",r))(Mr||{}),Fi=(e=>(e.GrokEmbedSmall="grok-embed-small",e))(Fi||{});var Wo=[{name:"grok-3",currency:"USD",promptTokenCostPer1M:3,completionTokenCostPer1M:15},{name:"grok-3-mini",currency:"USD",promptTokenCostPer1M:.3,completionTokenCostPer1M:.5,supported:{thinkingBudget:!0}},{name:"grok-3-fast",currency:"USD",promptTokenCostPer1M:5,completionTokenCostPer1M:25},{name:"grok-3-mini-fast",currency:"USD",promptTokenCostPer1M:.6,completionTokenCostPer1M:4,supported:{thinkingBudget:!0}}];var Vo=()=>structuredClone({model:"grok-3-mini",...ve()}),pc=()=>structuredClone({...Vo(),model:"grok-3"}),Nn=class extends Ge{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("Grok API key not set");let i={...Vo(),...t};s=[...Wo,...s??[]];let a=c=>{let l=mt({model:c,modelInfo:s,models:r});return{functions:!0,streaming:!0,hasThinkingBudget:l?.supported?.thinkingBudget??!1,hasShowThoughts:l?.supported?.showThoughts??!1,media:{images:{supported:!1,formats:[]},audio:{supported:!1,formats:[]},files:{supported:!1,formats:[],uploadMethod:"none"},urls:{supported:!1,webSearch:!1,contextFetching:!1}},caching:{supported:!1,types:[]},thinking:!1,multiTurn:!0}},u=c=>{if(n?.searchParameters){let l=n.searchParameters;return{...c,search_parameters:{mode:l.mode,return_citations:l.returnCitations,from_date:l.fromDate,to_date:l.toDate,max_search_results:l.maxSearchResults,sources:l.sources?.map(p=>({type:p.type,country:p.country,excluded_websites:p.excludedWebsites,allowed_websites:p.allowedWebsites,safe_search:p.safeSearch,x_handles:p.xHandles,links:p.links}))}}}return c};super({apiKey:e,config:i,options:n,apiURL:"https://api.x.ai/v1",modelInfo:s,models:r,supportFor:a,chatReqUpdater:u}),super.setName("Grok")}};function dc(o){return Pr.create(o)}var Pr=class o{ai;static create(e){return new o(e)}constructor(e){switch(e.name){case"openai":this.ai=new yn(e);break;case"openai-responses":this.ai=new En(e);break;case"azure-openai":this.ai=new bn(e);break;case"grok":this.ai=new Nn(e);break;case"huggingface":this.ai=new vn(e);break;case"groq":this.ai=new Rn(e);break;case"together":this.ai=new Fn(e);break;case"openrouter":this.ai=new Mn(e);break;case"cohere":this.ai=new Cn(e);break;case"google-gemini":this.ai=new Tn(e);break;case"anthropic":this.ai=new fn(e);break;case"mistral":this.ai=new Sn(e);break;case"deepseek":this.ai=new In(e);break;case"ollama":this.ai=new kn(e);break;case"reka":this.ai=new Pn(e);break;case"webllm":this.ai=new _n(e);break;default:throw new Error("Unknown AI")}}getName(){return this.ai.getName()}getId(){return this.ai.getId()}getFeatures(e){return this.ai.getFeatures(e)}getModelList(){return this.ai.getModelList()}getLastUsedChatModel(){return this.ai.getLastUsedChatModel()}getLastUsedEmbedModel(){return this.ai.getLastUsedEmbedModel()}getLastUsedModelConfig(){return this.ai.getLastUsedModelConfig()}getMetrics(){return this.ai.getMetrics()}async chat(e,t){return await this.ai.chat(e,t)}async embed(e,t){return await this.ai.embed(e,t)}setOptions(e){this.ai.setOptions(e)}getOptions(){return this.ai.getOptions()}getLogger(){return this.ai.getLogger()}};var Jo=require("@opentelemetry/api");var ht=class{name;fetch;tracer;_upsert;_batchUpsert;_query;constructor({name:e,fetch:t,tracer:n}){this.name=e,this.fetch=t,this.tracer=n}async upsert(e,t){if(!this._upsert)throw new Error("upsert() not implemented");return this.tracer?await this.tracer.startActiveSpan("DB Upsert Request",{kind:Jo.SpanKind.SERVER,attributes:{[ye.DB_SYSTEM]:this.name,[ye.DB_OPERATION_NAME]:"upsert",[ye.DB_TABLE]:e.table,[ye.DB_NAMESPACE]:e.namespace,[ye.DB_OPERATION_NAME]:t?"update":"insert"}},async n=>{try{return await this._upsert(e,t,{span:n})}finally{n.end()}}):await this._upsert(e,t)}async batchUpsert(e,t){if(!this._batchUpsert)throw new Error("batchUpsert() not implemented");if(e.length===0)throw new Error("Batch request is empty");if(!e[0])throw new Error("Batch request is invalid first element is undefined");return this.tracer?await this.tracer.startActiveSpan("DB Batch Upsert Request",{kind:Jo.SpanKind.SERVER,attributes:{[ye.DB_SYSTEM]:this.name,[ye.DB_OPERATION_NAME]:"upsert",[ye.DB_TABLE]:e[0].table,[ye.DB_NAMESPACE]:e[0].namespace,[ye.DB_OPERATION_NAME]:t?"update":"insert"}},async n=>{try{return await this._batchUpsert(e,t,{span:n})}finally{n.end()}}):await this._batchUpsert(e,t)}async query(e){if(!this._query)throw new Error("query() not implemented");return this.tracer?await this.tracer.startActiveSpan("DB Query Request",{kind:Jo.SpanKind.SERVER,attributes:{[ye.DB_SYSTEM]:this.name,[ye.DB_OPERATION_NAME]:"upsert",[ye.DB_TABLE]:e.table,[ye.DB_NAMESPACE]:e.namespace,[ye.DB_OPERATION_NAME]:"query"}},async t=>{try{return await this._query(e,{span:t})}finally{t.end()}}):await this._query(e)}};var _i="https://api.cloudflare.com/client/v4/accounts/",Ln=class extends ht{apiKey;accountId;constructor({apiKey:e,accountId:t,fetch:n,tracer:r}){if(!e||!t)throw new Error("Cloudflare credentials not set");super({name:"Cloudflare",fetch:n,tracer:r}),this.apiKey=e,this.accountId=t}_upsert=async(e,t,n)=>{let r=await tt({url:new URL(`${this.accountId}/vectorize/indexes/${e.table}/upsert`,_i),headers:{"X-Auth-Key":this.apiKey},fetch:this.fetch,span:n?.span},{id:e.id,values:e.values,namespace:e.namespace,metadata:e.metadata});if(r.errors)throw new Error(`Cloudflare upsert failed: ${r.errors.map(({message:s})=>s).join(", ")}`);return{ids:r.result.ids}};batchUpsert=async(e,t,n)=>{if(t)throw new Error("Weaviate does not support batch update");if(e.length<1)throw new Error("Batch request is empty");if(!e[0]||!e[0].table)throw new Error("Table name is empty");let r=e[0].table,s=await tt({url:new URL(`${this.accountId}/vectorize/indexes/${r}/upsert`,_i),headers:{"X-Auth-Key":this.apiKey},fetch:this.fetch,span:n?.span},e.map(i=>({id:i.id,values:i.values,namespace:i.namespace,metadata:i.metadata})));if(s.errors)throw new Error(`Cloudflare batch upsert failed: ${s.errors.map(({message:i})=>i).join(", ")}`);return{ids:s.result.ids}};query=async(e,t)=>{let n=await tt({url:new URL(`${this.accountId}/vectorize/indexes/${e.table}/query`,_i),headers:{"X-Auth-Key":this.apiKey},fetch:this.fetch,span:t?.span},{vector:e.values,topK:e.limit||10,returnValues:!0});if(n.errors)throw new Error(`Cloudflare query failed: ${n.errors.map(({message:s})=>s).join(", ")}`);return{matches:n.result.matches.map(({id:s,score:i,values:a,metadata:u})=>({id:s,score:i,values:a,metadata:u}))}}};var jt=class extends ht{state;constructor({tracer:e}={}){super({name:"Memory",tracer:e}),this.state={}}_upsert=async(e,t,n)=>{if(!this.state[e.table])this.state[e.table]={[e.id]:e};else{let r=this.state[e.table];if(!r)throw new Error(`Table not found: ${e.table}`);r[e.id]=e}return{ids:[e.id]}};_batchUpsert=async(e,t,n)=>{let r=[];for(let s of e){let i=await this.upsert(s,t);r.push(...i.ids)}return{ids:r}};_query=async(e,t)=>{let n=this.state[e.table];if(!n)return{matches:[]};let r=[];return Object.entries(n).forEach(([s,i])=>{if(e.values&&i.values){let a=Hd(e.values,i.values);r.push({id:s,score:a,metadata:i.metadata})}}),r.sort((s,i)=>s.score-i.score),e.limit&&(r.length=e.limit),{matches:r}};getDB=()=>structuredClone(this.state);setDB=e=>{this.state=structuredClone(e)};clearDB=()=>{this.state={}}},Hd=(o,e)=>{if(o.length!==e.length)throw new Error("Vectors must be of the same length.");let t=0,n=0,r=0,s=!0,i=!0,a=new Float64Array(o),u=new Float64Array(e);for(let d=0;d<a.length;d++)t+=a[d]*u[d],n+=a[d]*a[d],r+=u[d]*u[d],a[d]!==0&&(s=!1),u[d]!==0&&(i=!1);if(s||i)return 1;let c=Math.sqrt(n),l=Math.sqrt(r);return 1-t/(c*l)};var Kd=o=>({namespace:o.namespace,topK:o.limit||10,filter:{},includeValues:!0,includeMetadata:!0,vector:o.values??[],id:o.id}),$n=class extends ht{apiKey;apiURL;constructor({apiKey:e,host:t,fetch:n,tracer:r}){if(!e||e==="")throw new Error("Pinecone API key not set");super({name:"Pinecone",fetch:n,tracer:r}),this.apiKey=e,this.apiURL=t}_upsert=async(e,t,n)=>(await this._batchUpsert([e],t,n),{ids:[e.id]});_batchUpsert=async(e,t,n)=>{if(e.length===0)throw new Error("Batch request is empty");return await tt({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:"/vectors/upsert",fetch:this.fetch,span:n?.span},e.map(({id:r,values:s=[],metadata:i})=>({id:r,values:s,metadata:i}))),{ids:e.map(({id:r})=>r)}};query=async(e,t)=>{if(e.text)throw new Error("Pinecone does not support text");return{matches:(await tt({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:"/query",fetch:this.fetch,span:t?.span},Kd(e))).matches.map(({id:s,score:i,values:a,metadata:u})=>({id:s,score:i,metadata:u,values:a}))}}};var Dn=class extends ht{apiKey;apiURL;constructor({apiKey:e,host:t,fetch:n,tracer:r}){if(!e||e==="")throw new Error("Weaviate API key not set");super({name:"Weaviate",fetch:n,tracer:r}),this.apiKey=e,this.apiURL=t}_upsert=async(e,t,n)=>{let r=await tt({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:`/v1/objects/${e.table}/${e.id}`,put:!!t,fetch:this.fetch,span:n?.span},{id:e.id,class:e.table,tenant:e.namespace,vector:e.values,properties:e.metadata??{}});if(r?.result?.errors)throw new Error(`Weaviate upsert failed: ${r.result.errors.error.map(({message:s})=>s).join(", ")}`);return{ids:[r.id]}};_batchUpsert=async(e,t,n)=>{if(t)throw new Error("Weaviate does not support batch update");if(e.length===0)throw new Error("Batch request is empty");let r=e.map(i=>({id:i.id,class:i.table,tenant:i.namespace,vector:i.values,properties:i.metadata??{}})),s=await tt({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:"/v1/batch/objects",fetch:this.fetch,span:n?.span},{objects:r});if(s?.some(({result:i})=>i?.errors))throw new Error(`Weaviate batch upsert failed: ${s.map(({result:i})=>i?.errors?.error.map(({message:a})=>a).join(", ")).join(", ")}`);return{ids:s.map(({id:i})=>i)}};_query=async(e,t)=>{let n="";if(e.columns&&e.columns.length===0)throw new Error("Weaviate requires at least one column");if(e.values)n=`nearVector: {
180
180
  vector: [${e.values.join(",")}],
181
181
  }`;else if(e.text)n=`nearText: {
182
182
  concepts: ['${e.text}'],
@@ -190,31 +190,31 @@ ${c}`:`Assistant: ${l.content}`}default:throw new Error("Unknown role")}}).join(
190
190
  `)}
191
191
  }
192
192
  }
193
- }`});if(r.errors)throw new Error(`Weaviate query failed: ${r.errors.map(({message:a})=>a).join(", ")}`);let s=r.data.Get[e.table];return s?{matches:s.map(a=>({id:a.id,score:1,metadata:a}))}:{matches:[]}}};var Ko=class{db;constructor(e){switch(e.name){case"weaviate":this.db=new _n(e);break;case"pinecone":this.db=new Fn(e);break;case"cloudflare":this.db=new Pn(e);break;case"memory":this.db=new Gt(e);break;default:throw new Error("Unknown DB")}}async upsert(e,t){return await this.db.upsert(e,t)}async batchUpsert(e,t){return await this.db.batchUpsert(e,t)}async query(e){return await this.db.query(e)}};var Ei="_internal",Wo=class{ai;db;chunker;rewriter;reranker;constructor({ai:e,db:t,config:n}){this.ai=e,this.db=t,this.chunker=n?.chunker??this.defaultChunker,this.reranker=n?.reranker,this.rewriter=n?.rewriter}defaultChunker=e=>e.split(/\n\n+/);insert=async(e,t)=>{try{let n=Array.isArray(e)?e.join(`
193
+ }`});if(r.errors)throw new Error(`Weaviate query failed: ${r.errors.map(({message:a})=>a).join(", ")}`);let s=r.data.Get[e.table];return s?{matches:s.map(a=>({id:a.id,score:1,metadata:a}))}:{matches:[]}}};var Qo=class{db;constructor(e){switch(e.name){case"weaviate":this.db=new Dn(e);break;case"pinecone":this.db=new $n(e);break;case"cloudflare":this.db=new Ln(e);break;case"memory":this.db=new jt(e);break;default:throw new Error("Unknown DB")}}async upsert(e,t){return await this.db.upsert(e,t)}async batchUpsert(e,t){return await this.db.batchUpsert(e,t)}async query(e){return await this.db.query(e)}};var Ni="_internal",Yo=class{ai;db;chunker;rewriter;reranker;constructor({ai:e,db:t,config:n}){this.ai=e,this.db=t,this.chunker=n?.chunker??this.defaultChunker,this.reranker=n?.reranker,this.rewriter=n?.rewriter}defaultChunker=e=>e.split(/\n\n+/);insert=async(e,t)=>{try{let n=Array.isArray(e)?e.join(`
194
194
 
195
- `):e,r=this.chunker(n).filter(c=>c.length>0),s=t?.maxWordsPerChunk,i=t?.minWordsPerChunk,a=sd({initialChunks:r,minWordsPerChunk:i,maxWordsPerChunk:s}),l=t?.batchSize??10;for(let c=0;c<a.length;c+=l){let u=a.slice(c,c+l),d=(await this.ai.embed({texts:u},{abortSignal:t?.abortSignal})).embeddings.map((m,g)=>({id:`chunk_${Date.now()+g}`,table:Ei,values:m,metadata:{text:u[g]??""}})).filter(m=>m.metadata?.text&&m.metadata?.text.length>0);await this.db.batchUpsert(d)}}catch(n){throw new Error(`Error processing text: ${n}`)}};query=async(e,{topPercent:t,abortSignal:n}={})=>{let r=Array.isArray(e)?e:[e];if(typeof r[0]=="string"&&this.rewriter)for(let[l,c]of r.entries()){let{rewrittenQuery:u}=await this.rewriter.forward(this.ai,{query:c});r[l]=u}let s;typeof r[0]=="string"?s=(await this.ai.embed({texts:r},{abortSignal:n})).embeddings.map(c=>this.db.query({table:Ei,values:c})):s=r.map(l=>this.db.query({table:Ei,values:l}));let i=await Promise.all(s),a=[];for(let{matches:l}of i){let c=l.filter(d=>d.metadata?.text&&d.metadata?.text.length>0).map(({score:d,metadata:m})=>({score:d,text:m?.text??""})),u=t&&t>1?t/100:t,p=u?id(c,u):c;if(this.reranker){let{rankedItems:d}=await this.reranker.forward(this.ai,{query:r[0],items:p.map(g=>g.text)}),m=d.map(g=>p.find(f=>f.text===g)).filter(g=>g!==void 0);a.push(m)}else a.push(p)}return a}},sd=({initialChunks:o,maxWordsPerChunk:e=350,minWordsPerChunk:t=250})=>{let n=[],r="",s=0;return o.forEach(i=>{let a=i.split(/\s+/),l=a.length;if(s+l<=e)r+=`${i}
195
+ `):e,r=this.chunker(n).filter(c=>c.length>0),s=t?.maxWordsPerChunk,i=t?.minWordsPerChunk,a=Wd({initialChunks:r,minWordsPerChunk:i,maxWordsPerChunk:s}),u=t?.batchSize??10;for(let c=0;c<a.length;c+=u){let l=a.slice(c,c+u),d=(await this.ai.embed({texts:l},{abortSignal:t?.abortSignal})).embeddings.map((m,g)=>({id:`chunk_${Date.now()+g}`,table:Ni,values:m,metadata:{text:l[g]??""}})).filter(m=>m.metadata?.text&&m.metadata?.text.length>0);await this.db.batchUpsert(d)}}catch(n){throw new Error(`Error processing text: ${n}`)}};query=async(e,{topPercent:t,abortSignal:n}={})=>{let r=Array.isArray(e)?e:[e];if(typeof r[0]=="string"&&this.rewriter)for(let[u,c]of r.entries()){let{rewrittenQuery:l}=await this.rewriter.forward(this.ai,{query:c});r[u]=l}let s;typeof r[0]=="string"?s=(await this.ai.embed({texts:r},{abortSignal:n})).embeddings.map(c=>this.db.query({table:Ni,values:c})):s=r.map(u=>this.db.query({table:Ni,values:u}));let i=await Promise.all(s),a=[];for(let{matches:u}of i){let c=u.filter(d=>d.metadata?.text&&d.metadata?.text.length>0).map(({score:d,metadata:m})=>({score:d,text:m?.text??""})),l=t&&t>1?t/100:t,p=l?Vd(c,l):c;if(this.reranker){let{rankedItems:d}=await this.reranker.forward(this.ai,{query:r[0],items:p.map(g=>g.text)}),m=d.map(g=>p.find(f=>f.text===g)).filter(g=>g!==void 0);a.push(m)}else a.push(p)}return a}},Wd=({initialChunks:o,maxWordsPerChunk:e=350,minWordsPerChunk:t=250})=>{let n=[],r="",s=0;return o.forEach(i=>{let a=i.split(/\s+/),u=a.length;if(s+u<=e)r+=`${i}
196
196
 
197
- `,s+=l;else if(s>0&&s+l<=e*1.5)r+=`${i}
197
+ `,s+=u;else if(s>0&&s+u<=e*1.5)r+=`${i}
198
198
 
199
- `,s+=l;else if(s>t&&(n.push(r.trim()),r="",s=0),l>e){let c=a;for(;c.length>e*1.5;){let u=c.splice(0,e);n.push(u.join(" "))}c.length>0&&(r+=`${c.join(" ")}
199
+ `,s+=u;else if(s>t&&(n.push(r.trim()),r="",s=0),u>e){let c=a;for(;c.length>e*1.5;){let l=c.splice(0,e);n.push(l.join(" "))}c.length>0&&(r+=`${c.join(" ")}
200
200
 
201
201
  `,s+=c.length)}else r=`${i}
202
202
 
203
- `,s=l}),(s>t||n.length===0)&&n.push(r.trim()),n},id=(o,e=.1)=>{let t=[...o].sort((r,s)=>r.score-s.score),n=Math.ceil(t.length*e);return t.slice(0,n)};var Kn=require("@opentelemetry/api");var Mr=class{data=[];seenTags=new Set;addRequest(e,t){this.data.push(...e.map(n=>{let r=structuredClone(n);return{role:n.role,chat:[{index:t,value:r}]}}))}addFunctionResults(e){let t=e.map(({index:r,...s})=>({index:r,value:structuredClone(s)})),n=this.getLast();n?.role==="function"?n.chat.push(...t):this.data.push({role:"function",chat:t})}addResponse(e){let t=e.map(({index:n,...r})=>({index:n,value:structuredClone(r)}));this.data.push({role:"assistant",chat:t})}updateResult({content:e,name:t,functionCalls:n,thought:r,thoughtBlocks:s,index:i}){let a=this.data.at(-1);if(!a||a.role!=="assistant"||a.role==="assistant"&&!a.updatable){this.data.push({role:"assistant",updatable:!0,chat:[{index:i,value:structuredClone({content:e,name:t,functionCalls:n,thought:r,thoughtBlocks:s})}]});return}let l=a.chat.find(c=>c.index===i);if(!l){a.chat.push({index:i,value:structuredClone({content:e,name:t,functionCalls:n,thought:r,thoughtBlocks:s})});return}if(typeof e=="string"&&e.trim()!==""&&(l.value.content=e),typeof t=="string"&&t.trim()!==""&&(l.value.name=t),Array.isArray(n)&&n.length>0&&(l.value.functionCalls=n),typeof r=="string"&&r.trim()!==""){let c=l.value.thought;l.value.thought=typeof c=="string"?c+r:r}if(Array.isArray(s)&&s.length>0){let c=l.value.thoughtBlocks??[];for(let u of s){let p=c.length>0?c[c.length-1]:void 0;!u.signature&&u.data?p&&!p.signature?(p.data=(p.data??"")+u.data,u.encrypted&&(p.encrypted=!0)):c.push(structuredClone(u)):u.signature?p&&!p.signature?(p.data=(p.data??"")+u.data,p.signature=u.signature,u.encrypted&&(p.encrypted=!0)):c.push(structuredClone(u)):c.length===0&&c.push(structuredClone(u))}l.value.thoughtBlocks=c,c.length>0&&(l.value.thought=c.map(u=>u.data).join(""))}}addTag(e){let t=this.data.at(-1);t&&(t.tags||(t.tags=[]),t.tags.includes(e)||t.tags.push(e),this.seenTags.add(e))}rewindToTag(e){let t=this.data.findIndex(n=>n.tags?.includes(e));if(t===-1){if(!this.seenTags.has(e))throw new Error(`Tag "${e}" not found`);return[]}return this.data.splice(t)}removeByTag(e){let t=this.data.reduce((n,r,s)=>(r.tags?.includes(e)&&n.push(s),n),[]);return t.length===0?[]:t.reverse().map(n=>this.data.splice(n,1).at(0)).filter(n=>n!==void 0).reverse()}history(e){let t=[];for(let{role:n,chat:r}of this.data){let s;n==="function"?s=r.filter(i=>i.index===e).map(i=>i.value):s=r.find(i=>i.index===e)?.value,Array.isArray(s)&&s.length>0?t.push(...s.map(i=>({...i,role:n}))):typeof s=="object"&&s!==null&&t.push({...s,role:n})}return t}getLast(){return this.data.at(-1)}reset(){this.data=[],this.seenTags=new Set}},Nn=class{memories=new Map;defaultMemory;constructor(){this.defaultMemory=new Mr}getMemory(e){return e?(this.memories.has(e)||this.memories.set(e,new Mr),this.memories.get(e)):this.defaultMemory}addRequest(e,t){for(let n of e)cn(n);this.getMemory(t).addRequest(e,0)}addResponse(e,t){fo(e),this.getMemory(t).addResponse(e)}addFunctionResults(e,t){this.getMemory(t).addFunctionResults(e)}updateResult(e,t){this.getMemory(t).updateResult(e)}addTag(e,t){this.getMemory(t).addTag(e)}rewindToTag(e,t){return this.getMemory(t).rewindToTag(e)}removeByTag(e,t){return this.getMemory(t).removeByTag(e)}history(e,t){return this.getMemory(t).history(e)}getLast(e){return this.getMemory(e).getLast()}reset(e){e?this.memories.set(e,new Mr):this.defaultMemory.reset()}};function vt(o,e){if(!o&&!e)return;if(!o)return e;if(!e||o===e||o.aborted)return o;if(e.aborted)return e;if(typeof AbortSignal.any=="function")return AbortSignal.any([o,e]);let t=new AbortController,n=()=>{t.abort(o.aborted?o.reason:e.reason),r()},r=()=>{o.removeEventListener("abort",n),e.removeEventListener("abort",n)};return o.addEventListener("abort",n,{once:!0}),e.addEventListener("abort",n,{once:!0}),t.signal}var Et=class extends Error{constructor({message:e}){super(e),this.name="AxAssertionError"}getFixingInstructions=()=>{let e=[],t=this.message.trim();return e.push({name:"error",title:"Follow these instructions",description:t+(t.endsWith(".")?"":".")}),e};toString(){return`${this.name}: ${this.message}`}[Symbol.for("nodejs.util.inspect.custom")](e,t){return this.toString()}},Ln=async(o,e)=>{for(let t of o){let{fn:n,message:r}=t,s=await n(e);if(s!==void 0){if(typeof s=="string")throw new Et({message:s});if(!s)throw r?new Et({message:r}):new Error("Assertion Failed: No message provided for assertion")}}},Mi=async(o,e,t,n=!1)=>{if(!e.currField||e.s===-1||!o||o.length===0)return;let r=o.filter(i=>i.fieldName===e.currField?.name);if(r.length===0)return;let s=t.substring(e.s);for(let i of r){let{message:a,fn:l}=i,c=await l(s,n);if(c!==void 0){if(typeof c=="string")throw new Et({message:c});if(!c&&a)throw new Et({message:a})}}};var Pi={enabled:!0,enabledCategories:["generation","streaming","functions","errors","performance"],maxLabelLength:100,samplingRate:1},Pr,Fi=o=>{if(Pr)return Pr;let e=o??de.meter;if(e)return Pr=ad(e),Pr};var ec=()=>{let o=[];return de.meter||o.push("Global meter not initialized"),!Pr&&de.meter&&o.push("Metrics instruments not created despite available meter"),{healthy:o.length===0,issues:o}},ad=o=>({generationLatencyHistogram:o.createHistogram("ax_gen_generation_duration_ms",{description:"End-to-end duration of AxGen generation requests",unit:"ms"}),generationRequestsCounter:o.createCounter("ax_gen_generation_requests_total",{description:"Total number of AxGen generation requests"}),generationErrorsCounter:o.createCounter("ax_gen_generation_errors_total",{description:"Total number of failed AxGen generations"}),multiStepGenerationsCounter:o.createCounter("ax_gen_multistep_generations_total",{description:"Total number of generations that required multiple steps"}),stepsPerGenerationHistogram:o.createHistogram("ax_gen_steps_per_generation",{description:"Number of steps taken per generation"}),maxStepsReachedCounter:o.createCounter("ax_gen_max_steps_reached_total",{description:"Total number of generations that hit max steps limit"}),validationErrorsCounter:o.createCounter("ax_gen_validation_errors_total",{description:"Total number of validation errors encountered"}),assertionErrorsCounter:o.createCounter("ax_gen_assertion_errors_total",{description:"Total number of assertion errors encountered"}),errorCorrectionAttemptsHistogram:o.createHistogram("ax_gen_error_correction_attempts",{description:"Number of error correction attempts per generation"}),errorCorrectionSuccessCounter:o.createCounter("ax_gen_error_correction_success_total",{description:"Total number of successful error corrections"}),errorCorrectionFailureCounter:o.createCounter("ax_gen_error_correction_failure_total",{description:"Total number of failed error corrections"}),maxRetriesReachedCounter:o.createCounter("ax_gen_max_retries_reached_total",{description:"Total number of generations that hit max retries limit"}),functionsEnabledGenerationsCounter:o.createCounter("ax_gen_functions_enabled_generations_total",{description:"Total number of generations with functions enabled"}),functionCallStepsCounter:o.createCounter("ax_gen_function_call_steps_total",{description:"Total number of steps that included function calls"}),functionsExecutedPerGenerationHistogram:o.createHistogram("ax_gen_functions_executed_per_generation",{description:"Number of unique functions executed per generation"}),functionErrorCorrectionCounter:o.createCounter("ax_gen_function_error_correction_total",{description:"Total number of function-related error corrections"}),fieldProcessorsExecutedCounter:o.createCounter("ax_gen_field_processors_executed_total",{description:"Total number of field processors executed"}),streamingFieldProcessorsExecutedCounter:o.createCounter("ax_gen_streaming_field_processors_executed_total",{description:"Total number of streaming field processors executed"}),streamingGenerationsCounter:o.createCounter("ax_gen_streaming_generations_total",{description:"Total number of streaming generations"}),streamingDeltasEmittedCounter:o.createCounter("ax_gen_streaming_deltas_emitted_total",{description:"Total number of streaming deltas emitted"}),streamingFinalizationLatencyHistogram:o.createHistogram("ax_gen_streaming_finalization_duration_ms",{description:"Duration of streaming response finalization",unit:"ms"}),samplesGeneratedHistogram:o.createHistogram("ax_gen_samples_generated",{description:"Number of samples generated per request"}),resultPickerUsageCounter:o.createCounter("ax_gen_result_picker_usage_total",{description:"Total number of times result picker was used"}),resultPickerLatencyHistogram:o.createHistogram("ax_gen_result_picker_duration_ms",{description:"Duration of result picker execution",unit:"ms"}),inputFieldsGauge:o.createGauge("ax_gen_input_fields",{description:"Number of input fields in signature"}),outputFieldsGauge:o.createGauge("ax_gen_output_fields",{description:"Number of output fields in signature"}),examplesUsedGauge:o.createGauge("ax_gen_examples_used",{description:"Number of examples used in generation"}),demosUsedGauge:o.createGauge("ax_gen_demos_used",{description:"Number of demos used in generation"}),promptRenderLatencyHistogram:o.createHistogram("ax_gen_prompt_render_duration_ms",{description:"Duration of prompt template rendering",unit:"ms"}),extractionLatencyHistogram:o.createHistogram("ax_gen_extraction_duration_ms",{description:"Duration of value extraction from responses",unit:"ms"}),assertionLatencyHistogram:o.createHistogram("ax_gen_assertion_duration_ms",{description:"Duration of assertion checking",unit:"ms"}),stateCreationLatencyHistogram:o.createHistogram("ax_gen_state_creation_duration_ms",{description:"Duration of state creation for multiple samples",unit:"ms"}),memoryUpdateLatencyHistogram:o.createHistogram("ax_gen_memory_update_duration_ms",{description:"Duration of memory updates during generation",unit:"ms"})}),Vo=Pi,tc=o=>{Vo={...Vo,...o}},nc=()=>({...Vo}),St=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n),s=Vo.maxLabelLength;e[t]=r.length>s?r.substring(0,s):r}return e};var rc=(o,e,t,n,r,s,i)=>{try{let a=St({success:t.toString(),...n?{signature:n}:{},...r?{ai_service:r}:{},...s?{model:s}:{},...i});o.generationLatencyHistogram&&o.generationLatencyHistogram.record(e,a),o.generationRequestsCounter&&o.generationRequestsCounter.add(1,a),!t&&o.generationErrorsCounter&&o.generationErrorsCounter.add(1,a)}catch(a){console.warn("Failed to record generation metric:",a)}},Jo=(o,e,t,n,r)=>{try{let s=St({...n?{signature:n}:{},...r});e>1&&o.multiStepGenerationsCounter&&o.multiStepGenerationsCounter.add(1,s),o.stepsPerGenerationHistogram&&o.stepsPerGenerationHistogram.record(e,s),e>=t&&o.maxStepsReachedCounter&&o.maxStepsReachedCounter.add(1,s)}catch(s){console.warn("Failed to record multi-step metric:",s)}},_i=(o,e,t,n)=>{try{let r=St({error_type:e,...t?{signature:t}:{},...n});e==="validation"&&o.validationErrorsCounter&&o.validationErrorsCounter.add(1,r),e==="assertion"&&o.assertionErrorsCounter&&o.assertionErrorsCounter.add(1,r)}catch(r){console.warn("Failed to record validation error metric:",r)}},oc=(o,e,t)=>{try{let n=St({error_type:"refusal",...e?{signature:e}:{},...t});o.validationErrorsCounter&&o.validationErrorsCounter.add(1,n)}catch(n){console.warn("Failed to record refusal error metric:",n)}},Ni=(o,e,t,n,r,s)=>{try{let i=St({success:t.toString(),...r?{signature:r}:{},...s});o.errorCorrectionAttemptsHistogram&&o.errorCorrectionAttemptsHistogram.record(e,i),t&&o.errorCorrectionSuccessCounter&&o.errorCorrectionSuccessCounter.add(1,i),t||(o.errorCorrectionFailureCounter&&o.errorCorrectionFailureCounter.add(1,i),e>=n&&o.maxRetriesReachedCounter&&o.maxRetriesReachedCounter.add(1,i))}catch(i){console.warn("Failed to record error correction metric:",i)}},sc=(o,e,t,n,r=!1,s,i)=>{try{let a=St({functions_enabled:e.toString(),had_function_calls:n.toString(),...s?{signature:s}:{},...i});e&&o.functionsEnabledGenerationsCounter&&o.functionsEnabledGenerationsCounter.add(1,a),n&&o.functionCallStepsCounter&&o.functionCallStepsCounter.add(1,a),t>0&&o.functionsExecutedPerGenerationHistogram&&o.functionsExecutedPerGenerationHistogram.record(t,a),r&&o.functionErrorCorrectionCounter&&o.functionErrorCorrectionCounter.add(1,a)}catch(a){console.warn("Failed to record function calling metric:",a)}},ic=(o,e,t,n,r)=>{try{let s=St({...n?{signature:n}:{},...r});e>0&&o.fieldProcessorsExecutedCounter&&o.fieldProcessorsExecutedCounter.add(e,s),t>0&&o.streamingFieldProcessorsExecutedCounter&&o.streamingFieldProcessorsExecutedCounter.add(t,s)}catch(s){console.warn("Failed to record field processing metric:",s)}},ac=(o,e,t,n,r,s)=>{try{let i=St({is_streaming:e.toString(),...r?{signature:r}:{},...s});e&&o.streamingGenerationsCounter&&o.streamingGenerationsCounter.add(1,i),t>0&&o.streamingDeltasEmittedCounter&&o.streamingDeltasEmittedCounter.add(t,i),n&&o.streamingFinalizationLatencyHistogram&&o.streamingFinalizationLatencyHistogram.record(n,i)}catch(i){console.warn("Failed to record streaming metric:",i)}},lc=(o,e,t,n,r,s)=>{try{let i=St({result_picker_used:t.toString(),...r?{signature:r}:{},...s});o.samplesGeneratedHistogram&&o.samplesGeneratedHistogram.record(e,i),t&&o.resultPickerUsageCounter&&o.resultPickerUsageCounter.add(1,i),n&&o.resultPickerLatencyHistogram&&o.resultPickerLatencyHistogram.record(n,i)}catch(i){console.warn("Failed to record samples metric:",i)}},cc=(o,e,t,n,r,s,i)=>{try{let a=St({...s?{signature:s}:{},...i});o.inputFieldsGauge&&o.inputFieldsGauge.record(e,a),o.outputFieldsGauge&&o.outputFieldsGauge.record(t,a),o.examplesUsedGauge&&o.examplesUsedGauge.record(n,a),o.demosUsedGauge&&o.demosUsedGauge.record(r,a)}catch(a){console.warn("Failed to record signature complexity metrics:",a)}},Qo=(o,e,t,n,r)=>{try{let s=St({metric_type:e,...n?{signature:n}:{},...r});switch(e){case"prompt_render":o.promptRenderLatencyHistogram&&o.promptRenderLatencyHistogram.record(t,s);break;case"extraction":o.extractionLatencyHistogram&&o.extractionLatencyHistogram.record(t,s);break;case"assertion":o.assertionLatencyHistogram&&o.assertionLatencyHistogram.record(t,s);break;case"state_creation":o.stateCreationLatencyHistogram&&o.stateCreationLatencyHistogram.record(t,s);break;case"memory_update":o.memoryUpdateLatencyHistogram&&o.memoryUpdateLatencyHistogram.record(t,s);break}}catch(s){console.warn("Failed to record performance metric:",s)}};var $n=o=>{let e=(()=>{switch(o?.name){case"string":return"string";case"number":return"number";case"boolean":return"boolean";case"date":return'date ("YYYY-MM-DD" format)';case"datetime":return'date time ("YYYY-MM-DD HH:mm Timezone" format)';case"json":return"JSON object";case"class":return"classification class";case"code":return"code";case"object":return"object";default:return"string"}})();return o?.isArray?`array of ${e}s`:e},Qe=class extends Error{constructor(e){super(e),this.name="ValidationError"}getFixingInstructions=()=>[{name:"outputError",title:"Invalid Field",description:this.message}];toString(){return`${this.name}: ${this.message}`}[Symbol.for("nodejs.util.inspect.custom")](e,t){return this.toString()}},uc=o=>{let t=o.map(n=>`'${n.title}' (${$n(n.type)})`).join(", ");return new Qe(`Required field not found: ${t}. Add a line starting with the exact label followed by a colon (e.g., "${o[0]?.title}:") and then provide a valid ${$n(o[0]?.type)} value. Keep the output concise and avoid unrelated text.`)},Yo=o=>new Qe(`Expected (Required) field not found: '${o.title}'. Begin a new section with "${o.title}:" and then provide a valid ${$n(o.type)} value directly after.`);var Xo=o=>new Qe(`Required field is missing: '${o.title}'. After the "${o.title}:" label, provide a non-empty ${$n(o.type)}. Do not use null, undefined, or leave it blank.`),pc=(o,e)=>new Qe(`Invalid JSON: ${e} in field '${o.title}'. Return only valid JSON. Prefer a fenced code block containing a single JSON object or array with no trailing text.`),dc=(o,e)=>new Qe(`Invalid Array: ${e} for '${o.title}'. Provide a JSON array of ${$n(o.type)} items (e.g., [ ... ]). Markdown lists are also accepted if each item is on its own line starting with a hyphen.`),mc=(o,e,t)=>new Qe(`Field '${o.title}' has an invalid value '${e}': ${t}. Provide a ${$n(o.type)}. Ensure formatting exactly matches the expected type.`),gc=(o,e,t)=>new Qe(`Invalid date for '${o.title}': ${t}. Use the exact format YYYY-MM-DD (e.g., 2024-05-09). You provided: ${e}.`),fc=(o,e,t)=>new Qe(`Invalid date/time for '${o.title}': ${t}. Use the format YYYY-MM-DD HH:mm or YYYY-MM-DD HH:mm:ss followed by a valid timezone (e.g., America/New_York). You provided: ${e}.`),Li=(o,e,t)=>new Qe(`Invalid URL for '${o.title}': ${t}. Use a valid URL format (e.g., https://example.com). You provided: ${e}.`),Dn=(o,e,t,n)=>{let r=`Field '${o.title}' failed validation: `;return t==="minLength"?r+=`String must be at least ${n} characters long. You provided: "${e}" (${e.length} characters).`:t==="maxLength"?r+=`String must be at most ${n} characters long. You provided: "${e}" (${e.length} characters).`:t==="pattern"?r+=`String must match pattern /${n}/. You provided: "${e}".`:t==="format"&&(r+=`String must be a ${n}. You provided: "${e}".`),new Qe(r)},$i=(o,e,t,n)=>{let r=`Field '${o.title}' failed validation: `;return t==="minimum"?r+=`Number must be at least ${n}. You provided: ${e}.`:t==="maximum"&&(r+=`Number must be at most ${n}. You provided: ${e}.`),new Qe(r)};var hc=({error:o,errCount:e,debug:t,logger:n,metricsInstruments:r,signatureName:s,span:i,customLabels:a})=>{let l=o.getFixingInstructions();if(t&&n){let c=l?.map(u=>u.title).join(", ")??"";el(o,e,c,n)}return r&&_i(r,"validation",s,a),i&&i.addEvent("validation.error",{message:o.toString(),fixing_instructions:l?.map(c=>c.title).join(", ")??""}),l},xc=({error:o,errCount:e,debug:t,logger:n,metricsInstruments:r,signatureName:s,span:i,customLabels:a})=>{let l=o.getFixingInstructions();if(t&&n){let c=l?.map(u=>u.title).join(", ")??"";tl(o,e,c,n)}return r&&_i(r,"assertion",s,a),i&&i.addEvent("assertion.error",{message:o.toString(),fixing_instructions:l?.map(c=>c.title).join(", ")??""}),l},Ac=({error:o,errCount:e,debug:t,logger:n,metricsInstruments:r,signatureName:s,span:i,customLabels:a})=>{t&&n&&nl(o,e,n),r&&oc(r,s,a),i&&i.addEvent("refusal.error",{message:o.toString()})};var Bt=ur(require("dayjs"),1),yc=ur(require("dayjs/plugin/customParseFormat.js"),1),bc=ur(require("dayjs/plugin/timezone.js"),1),Tc=ur(require("dayjs/plugin/utc.js"),1);Bt.default.extend(Tc.default);Bt.default.extend(bc.default);Bt.default.extend(yc.default);function Cc(o,e,t=!1){try{return ld(e)}catch(n){if(o.isOptional&&!t)return;let r=n.message;throw gc(o,e,r)}}function ld(o){if(!(0,Bt.default)(o,"YYYY-MM-DD",!0).isValid())throw new Error('Invalid date format. Please provide the date in "YYYY-MM-DD" format.');return Bt.default.utc(o,"YYYY-MM-DD").startOf("day").toDate()}function Ic(o,e,t=!1){try{return cd(e)}catch(n){if(o.isOptional&&!t)return;let r=n.message;throw fc(o,e,r)}}function cd(o){let e=/^(\d{4}-\d{2}-\d{2} \d{2}:\d{2}(?::\d{2})?) (.+)$/,t=o.match(e);if(!t)throw new Error('Invalid date and time format. Please provide the date and time in "YYYY-MM-DD HH:mm" or "YYYY-MM-DD HH:mm:ss" format, followed by the timezone.');let[,n,r]=t;if(!n||!r)throw new Error('Invalid date and time format. Please provide the date and time in "YYYY-MM-DD HH:mm" or "YYYY-MM-DD HH:mm:ss" format, followed by the timezone.');try{let s=n.includes(":")&&n.split(":").length===3?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD HH:mm",i=Bt.default.tz(n,s,r);if(!i.isValid())throw new Error("Invalid date and time values. Please ensure all components are correct.");return i.utc().toDate()}catch{throw new Error(`Unrecognized time zone ${r}. Please provide a valid time zone name, abbreviation, or offset. For example, "America/New_York", or "EST".`)}}var wc=o=>(0,Bt.default)(o).utc().format("YYYY-MM-DD HH:mm:ss [UTC]");var Oy=new ot,Fr=(o,e)=>{let t=o.type??{name:"string",isArray:!1},n=(c,u)=>{switch(c){case"class":return typeof u=="string";case"code":return typeof u=="string";case"string":return typeof u=="string";case"number":return typeof u=="number";case"boolean":return typeof u=="boolean";case"date":return u instanceof Date||typeof u=="string";case"datetime":return u instanceof Date||typeof u=="string";case"json":return typeof u=="object"||typeof u=="string";case"object":return typeof u=="object";default:return!1}},r=c=>!(!c||typeof c!="object"||!("mimeType"in c)||!("data"in c));if(o.type?.name==="image"){let c;if(Array.isArray(e)){for(let u of e)if(!r(u)){c="object ({ mimeType: string; data: string })";break}}else r(e)||(c="object ({ mimeType: string; data: string })");if(c)throw new Error(`Validation failed: Expected '${o.name}' to be type '${c}' instead got '${e}'`);return}let s=c=>!(!c||typeof c!="object"||!("data"in c));if(o.type?.name==="audio"){let c;if(Array.isArray(e)){for(let u of e)if(!s(u)){c="object ({ data: string; format?: string })";break}}else s(e)||(c="object ({ data: string; format?: string })");if(c)throw new Error(`Validation failed: Expected '${o.name}' to be type '${c}' instead got '${e}'`);return}let i=c=>{if(!c||typeof c!="object"||!("mimeType"in c))return!1;let u="data"in c,p="fileUri"in c;return!(!u&&!p||u&&p)};if(o.type?.name==="file"){let c;if(Array.isArray(e)){for(let u of e)if(!i(u)){c="object ({ mimeType: string; data: string } | { mimeType: string; fileUri: string })";break}}else i(e)||(c="object ({ mimeType: string; data: string } | { mimeType: string; fileUri: string })");if(c)throw new Error(`Validation failed: Expected '${o.name}' to be type '${c}' instead got '${e}'`);return}let a=c=>typeof c=="string"?!0:!(!c||typeof c!="object"||!("url"in c));if(o.type?.name==="url"){let c;if(Array.isArray(e)){for(let u of e)if(!a(u)){c="string or object ({ url: string; title?: string; description?: string })";break}}else a(e)||(c="string or object ({ url: string; title?: string; description?: string })");if(c)throw new Error(`Validation failed: Expected '${o.name}' to be type '${c}' instead got '${e}'`);return}let l=!0;if(t.isArray){if(!Array.isArray(e))l=!1;else for(let c of e)if(!n(t.name,c)){l=!1;break}}else l=n(t.name,e);if(!l){let c=Array.isArray(e)?"array":typeof e;throw new Error(`Validation failed: Expected '${o.name}' to be a ${o.type?.isArray?"an array of ":""}${t.name} instead got '${c}' (${JSON.stringify(e)})`)}};function _r(o){let e={};for(let t of o){let n=`${t.ai}:${t.model}`;if(!e[n]){e[n]={...t};continue}let r=e[n];if(r){let s=r.tokens??{promptTokens:0,completionTokens:0,totalTokens:0};s.promptTokens+=t?.tokens?.promptTokens??0,s.completionTokens+=t?.tokens?.completionTokens??0,s.totalTokens+=t?.tokens?.totalTokens??0,r.tokens=s;let i=r.citations??[],a=t.citations??[];if(a.length){let l=new Set(i.map(c=>c.url));for(let c of a)c?.url&&!l.has(c.url)&&(i.push(c),l.add(c.url));r.citations=i}}}return Object.values(e)}var Rc=o=>{if(!o.trim())return[];let e=new Set(["-","*","+"]),t=/^\d+[\s]*[.)\]]\s*/,n=o.split(`
204
- `),r=[];for(let s of n){let i=s.trim();if(i){if(i[0]&&e.has(i[0]))r.push(i.slice(1).trim());else if(t.test(i))r.push(i.replace(t,"").trim());else if(r.length!==0)throw new Error("Could not parse markdown list: mixed content detected")}}if(r.length===0)throw new Error("Could not parse markdown list: no valid list items found");return r};function Ui(o,e){let{index:t,delta:n,version:r}=e,s=o.find(a=>a.index===t)?.delta;if(!s)return o.push({index:t,delta:n,version:r}),o;for(let a of Object.keys(n)){let l=s[a],c=n[a];l===void 0&&Array.isArray(c)?s[a]=[...c]:Array.isArray(l)&&Array.isArray(c)?s[a]=[...l,...c]:(l===void 0||typeof l=="string")&&typeof c=="string"?s[a]=`${l??""}${c}`:s[a]=c}let i=o.find(a=>a.index===t);return i&&(i.version=r),o}var Di=class{cache=new Map;maxSize;constructor(e){this.maxSize=e}get(e){let t=this.cache.get(e);return t&&(this.cache.delete(e),this.cache.set(e,t)),t}set(e,t){if(this.cache.has(e))this.cache.delete(e);else if(this.cache.size>=this.maxSize){let n=this.cache.keys().next().value;n&&this.cache.delete(n)}this.cache.set(e,t)}},ud=new Di(500);function vc(o,e,t=0,n=ud){if(/^```[a-zA-Z]*\s*$/.test(o))return-4;if(/^[\s`]*$/.test(o))return-3;let r=o.indexOf(e,t);if(r!==-1)return r;let s=n.get(e)??Array.from({length:e.length},(a,l)=>e.slice(0,l+1));n.get(e)||n.set(e,s);let i=-1;for(let a=s.length-1;a>=0;a--){let l=s[a];if(o.endsWith(l)){i=a;break}}return i>=0?-2:-1}function jt(o,e){if(typeof o!="string")throw Li(e,String(o),"URL must be a string");try{new URL(o)}catch{throw Li(e,o,"Invalid URL format. Expected a valid URL like https://example.com")}}function xt(o,e){if(typeof o!="string")return;let t=e.type;if(t){if(t.minLength!==void 0&&o.length<t.minLength)throw Dn(e,o,"minLength",t.minLength);if(t.maxLength!==void 0&&o.length>t.maxLength)throw Dn(e,o,"maxLength",t.maxLength);if(t.pattern!==void 0&&!new RegExp(t.pattern).test(o))throw Dn(e,o,"pattern",t.pattern);if(t.format==="email"&&!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(o))throw Dn(e,o,"format","valid email address");if(t.format==="uri"||t.format==="url")try{new URL(o)}catch{throw Dn(e,o,"format","valid URL")}}}function At(o,e){if(typeof o!="number")return;let t=e.type;if(t){if(t.minimum!==void 0&&o<t.minimum)throw $i(e,o,"minimum",t.minimum);if(t.maximum!==void 0&&o>t.maximum)throw $i(e,o,"maximum",t.maximum)}}var ts=(o,e,t,n)=>{let r=n?.strictMode??!1,s=n?.treatAllFieldsOptional??!1,i=n?.treatAllFieldsOptional??!1,a={extractedFields:[],streamedIndex:{},s:-1};ji(o,e,a,t,{strictMode:r,skipEarlyFail:i,treatAllFieldsOptional:s}),zi(o,e,a,t,{strictMode:r,treatAllFieldsOptional:s,forceFinalize:!0});for(let l of o.getOutputFields())l.isInternal&&delete e[l.name]},Gi=(o,e,t)=>{let n=[];for(let r of t)r&&!r.isOptional&&e[r.name]===void 0&&n.push(r);if(n.length>0)throw uc(n)},ji=(o,e,t,n,{strictMode:r,skipEarlyFail:s}={})=>{let i=o.getOutputFields(),a;for(;;){let l=new Set;t.currFieldIndex!==void 0&&!t.inAssumedField&&l.add(t.currFieldIndex);let c=i.map((g,f)=>({field:g,index:f})).filter(({index:g})=>!l.has(g)),u,p,d=-1,m=0;for(let{index:g,field:f}of c){let A=`${(t.extractedFields.length===0?"":`
205
- `)+f.title}:`,h=vc(n,A,t.s);if(h===-2||h===-3)return!0;if(h===-4)return t.inBlock=!0,!0;h>=0&&(d===-1||h<d)&&(d=h,m=A.length,u=g,p=f)}if(d===-1){if(s)return;if(!r&&t.currField===void 0&&t.extractedFields.length===0&&i.length===1){t.inAssumedField=!0,t.currField=i[0],t.currFieldIndex=0,t.s=0,t.extractedFields.includes(i[0])||t.extractedFields.push(i[0]),t.streamedIndex[i[0].name]===void 0&&(t.streamedIndex[i[0].name]=0);return}if(r&&t.currField===void 0&&t.extractedFields.length===0){let g=i.find(f=>!f.isOptional);if(g)throw Yo(g)}break}if(a&&p&&a.name!==p.name)throw Yo(a);if(t.currField!==void 0&&t.inAssumedField&&(t.inAssumedField=!1,t.streamedIndex[t.currField.name]=0,t.currField=void 0),t.currField){let g=n.substring(t.s,d).trim(),f=Zo(t.currField,g);f!==void 0&&(e[t.currField.name]=f),t.prevFields?t.prevFields?.push({field:t.currField,s:t.s,e:d}):t.prevFields=[{field:t.currField,s:t.s,e:d}]}t.s=d+m,p!==void 0&&u!==void 0&&(t.currField=p,t.currFieldIndex=u),p&&!t.extractedFields.includes(p)&&t.extractedFields.push(p),p&&t.streamedIndex[p.name]===void 0&&(t.streamedIndex[p.name]=0)}},zi=(o,e,t,n,r)=>{let s=r?.strictMode??!1,i=r?.treatAllFieldsOptional??!1,a=r?.deferRequiredCheckForStreaming??!1,l=r?.forceFinalize??!1;if(t.currField){let c=n.length,u=o.getOutputFields();for(let m of u){if(m.name===t.currField.name)continue;let g=`
206
- ${m.title}:`,f=n.indexOf(g,t.s);f!==-1&&f<c&&(c=f)}let p=n.substring(t.s,c).trim(),d=Zo(t.currField,p);d!==void 0&&(e[t.currField.name]=d)}if(s&&!t.currField&&t.extractedFields.length===0&&n.trim()){let p=o.getOutputFields().find(d=>!d.isOptional);if(p)throw Yo(p)}if(pd(o,e,n,t),!i){let c=t.currField!==void 0||(t.extractedFields?.length??0)>0;s||l?Gi(t,e,o.getOutputFields()):c||Gi(t,e,o.getOutputFields())}},pd=(o,e,t,n)=>{let r=o.getOutputFields();if(r.length===1){let i=r[0];if(i){let a=`${i.title}:`,l=t.indexOf(a);if(l!==-1){let c=l+a.length,u=`
207
- ${i.title}:`,p=t.indexOf(u,c),d=t.substring(c,p===-1?t.length:p).trim();if(d)try{let m=Zo(i,d);if(m!==void 0){e[i.name]=m;return}}catch{}}}}let s=t.split(`
208
- `);for(let i of r){if(i.name in e)continue;let a=`${i.title}:`;for(let l of s){let c=l.trim();if(c.startsWith(a)){let u=c.substring(a.length).trim();if(u)try{let p=Zo(i,u);if(p!==void 0){e[i.name]=p;break}}catch(p){if(!i.isOptional)throw p}break}}}},Sc=(o,e,t=!1)=>{switch(o.type?.name){case"code":return Bi(e);case"string":return e;case"number":{let n=Number(e);if(Number.isNaN(n)){if(o.isOptional&&!t)return;throw new Error("Invalid number")}return n}case"boolean":{if(typeof e=="boolean")return e;let n=e.toLowerCase();if(n==="true")return!0;if(n==="false")return!1;if(o.isOptional&&!t)return;throw new Error("Invalid boolean")}case"date":return Cc(o,e,t);case"datetime":return Ic(o,e,t);case"class":{let n=e;if(o.type.options&&!o.type.options.includes(n)){if(o.isOptional)return;throw new Error(`Invalid class '${e}', expected one of the following: ${o.type.options.join(", ")}`)}return n}default:return e}};function*kc(o,e,t,n,r,s){let{name:i,isInternal:a}=e,{isArray:l,name:c}=e.type??{};if(a||l||c&&c!=="string"&&c!=="code")return;let u=r.streamedIndex[i]??0,p=u===0,d=(t<0?0:t)+u,m=o.substring(d,n);if(m.length===0)return;let g=m.replace(/\s+$/,"");r.currField?.type?.name==="code"&&(g=g.replace(/\s*```\s*$/,""));let f=p?g.trimStart():g;r.currField?.type?.name==="code"&&(f=f.replace(/^[ ]*```[a-zA-Z0-9]*\n\s*/,"")),f.length>0&&(yield{index:s,delta:{[i]:f}},r.streamedIndex[i]=u+g.length)}function*qi(o,e,t,n,r){for(let i of n.prevFields??[]){let{field:a,s:l,e:c}=i;yield*kc(e,a,l,c,n,r)}if(n.prevFields=void 0,n.inAssumedField&&!(o.getOutputFields().filter(l=>!l.isInternal).length===1)||!n.currField||n.currField.isInternal)return;yield*kc(e,n.currField,n.s,e.length,n,r);let s=o.getOutputFields();for(let i of Object.keys(t)){let a=s.find(u=>u.name===i);if(!a||a.isInternal)continue;let l=t[i];if(Array.isArray(l)){let u=n.streamedIndex?.[i]??0,p=l.slice(u);p&&p.length>0&&(yield{index:r,delta:{[i]:p}},n.streamedIndex[i]=u+p.length);continue}let c=typeof l=="string"?l:void 0;if(!n.streamedIndex[i])yield{index:r,delta:{[i]:l}},n.streamedIndex[i]=c?c.length:1;else if(c){let u=n.streamedIndex[i];if(c.length>u){let p=c.substring(u);yield{index:r,delta:{[i]:p}},n.streamedIndex[i]=c.length}}}}function Zo(o,e){if(!e||e===""||/^(null|undefined)\s*$/i.test(e)){if(o.isOptional)return;throw Xo(o)}let t;if(o.type?.name==="json"&&!o.type?.isArray)try{let r=Bi(e);return t=JSON.parse(r),t}catch(r){throw pc(o,r.message)}if(o.type?.isArray)try{try{t=JSON.parse(e)}catch{t=Rc(e)}if(!Array.isArray(t))throw new Error("Expected an array")}catch(r){let s=r.message;if(s.includes("no valid list items found")||s==="Expected an array")t=[e];else throw dc(o,s)}try{if(Array.isArray(t)){for(let[r,s]of t.entries())if(s!==void 0){let i=typeof s=="string"?s.trim():s;if(typeof i=="string"&&(o.type?.name==="object"||o.type?.name==="json"))try{let a=Bi(i);i=JSON.parse(a)}catch{}t[r]=Sc(o,i,!0)}}else t=Sc(o,e)}catch(r){throw mc(o,e,r.message)}if(typeof t=="string"&&t==="")return;let n=o.type;if(n&&t!==void 0&&(n.name==="url"&&jt(t,o),(n.name==="string"||n.name==="code")&&xt(t,o),n.name==="number"&&At(t,o),n.isArray&&Array.isArray(t)))for(let r of t)r!==void 0&&(n.name==="string"||n.name==="code"?xt(r,o):n.name==="number"&&At(r,o));return t}function Un(o,e,t){let n=o.getOutputFields();for(let r of n){let s=e[r.name];if(s==null){if(!r.isOptional&&!t?.allowMissingRequired)throw Xo(r);continue}let i=r.type;if(i){if(i.name==="url"&&jt(s,r),(i.name==="string"||i.name==="code")&&xt(s,r),i.name==="number"&&At(s,r),i.isArray&&Array.isArray(s))for(let a of s)a!=null&&(i.name==="url"?jt(a,r):i.name==="string"||i.name==="code"?xt(a,r):i.name==="number"&&At(a,r));if(i.name==="object"&&i.fields&&typeof s=="object"&&!Array.isArray(s)&&es(r,s,t),i.isArray&&i.fields&&Array.isArray(s)&&i.name==="object")for(let a of s)a&&typeof a=="object"&&es(r,a,t)}}}function es(o,e,t){let n=o.type?.fields;if(!(!n||typeof n!="object"))for(let[r,s]of Object.entries(n)){let i={name:r,title:r,description:s.description,type:{name:s.type,isArray:s.isArray,options:s.options,fields:s.fields,minLength:s.minLength,maxLength:s.maxLength,minimum:s.minimum,maximum:s.maximum,pattern:s.pattern,patternDescription:s.patternDescription,format:s.format},isOptional:s.isOptional??!1,isInternal:s.isInternal??!1},a=e[i.name];if(a==null){if(!i.isOptional&&!t?.allowMissingRequired)throw Xo(i);continue}let l=i.type;if(l){if(l.name==="url"&&jt(a,i),(l.name==="string"||l.name==="code")&&xt(a,i),l.name==="number"&&At(a,i),l.isArray&&Array.isArray(a))for(let c of a)c!=null&&(l.name==="url"?jt(c,i):l.name==="string"||l.name==="code"?xt(c,i):l.name==="number"&&At(c,i));if(l.name==="object"&&l.fields&&typeof a=="object"&&!Array.isArray(a)&&es(i,a,t),l.isArray&&l.fields&&Array.isArray(a)&&l.name==="object")for(let c of a)c&&typeof c=="object"&&es(i,c,t)}}}var Bi=o=>{let t=/```([A-Za-z]*)\s*([\s\S]*?)\s*```/g.exec(o);return t?t.length===3?t[2]:t.length===2?t[1]:o:o};async function Nr(o,e,t,n){for(let r of o){if(e[r.field.name]===void 0)continue;let s=r.process,i=await s(e[r.field.name],{sessionId:n,values:e,done:!0});Oc(r.field,t,i,n)}}async function Hi(o,e,t,n,r,s,i=!1){for(let a of o){if(t.currField?.name!==a.field.name)continue;let l=e.substring(t.s);t.currField?.type?.name==="code"&&(l=l.replace(/^[ ]*```[a-zA-Z0-9]*\n\s*/,""),l=l.replace(/\s*```\s*$/,""));let c=a.process,u=await c(l,{sessionId:s,values:r,done:i});Oc(t.currField,n,u,s)}}var Oc=(o,e,t,n)=>{if(t===void 0||typeof t=="string"&&(t===""||/^(null|undefined)\s*$/i.test(t)))return;let r=String(t),s=r;e.addRequest([{role:"user",content:[{type:"text",text:s}]}],n),e.addTag("processor",n)};function Ec(o,e){if(!e)return o;let t=[];if(e.format==="email"&&t.push("Must be a valid email address format"),(e.format==="uri"||e.format==="url"||e.name==="url")&&t.push("Must be a valid URL format"),(e.name==="string"||e.name==="code"||e.name==="url"||e.name==="date"||e.name==="datetime")&&(e.minLength!==void 0&&e.maxLength!==void 0?t.push(`Minimum length: ${e.minLength} characters, maximum length: ${e.maxLength} characters`):e.minLength!==void 0?t.push(`Minimum length: ${e.minLength} characters`):e.maxLength!==void 0&&t.push(`Maximum length: ${e.maxLength} characters`)),e.name==="number"&&(e.minimum!==void 0&&e.maximum!==void 0?t.push(`Minimum value: ${e.minimum}, maximum value: ${e.maximum}`):e.minimum!==void 0?t.push(`Minimum value: ${e.minimum}`):e.maximum!==void 0&&t.push(`Maximum value: ${e.maximum}`)),e.pattern!==void 0){if(!e.patternDescription)throw new Error(`Field with pattern '${e.pattern}' must include a patternDescription to explain the pattern to the LLM`);t.push(e.patternDescription)}if(e.name==="date"&&t.push("Format: YYYY-MM-DD"),e.name==="datetime"&&t.push("Format: ISO 8601 date-time"),t.length===0)return o;let n=t.join(". ");return!o||o.trim().length===0?n:`${o.trim().endsWith(".")?o.trim():`${o.trim()}.`} ${n}`}function zt(o,e="Schema"){if("name"in o&&"type"in o)return ns(o);let t={},n=[];for(let r of o){if(r.isInternal)continue;let s=ns(r);t[r.name]=s,r.isOptional||n.push(r.name)}return{type:"object",title:e,properties:t,required:n,additionalProperties:!1}}function ns(o,e=!1){let t=o.type,n=Ec(o.description,t);if(e&&t?.name&&(t.name==="image"||t.name==="audio"||t.name==="file"))throw new Error(`Media type '${t.name}' is not allowed in nested object fields. Media types (image, audio, file) can only be used as top-level input fields. Field: ${o.name}`);let r={};if(n&&(r.description=n),t?.isArray)if(r.type="array",t.fields){r.items={type:"object",properties:{},required:[],additionalProperties:!1},t.description&&(r.items.description=t.description);for(let[s,i]of Object.entries(t.fields)){let a={name:s,description:i.description,type:{name:i.type,isArray:i.isArray,options:i.options?[...i.options]:void 0,fields:i.fields,minLength:i.minLength,maxLength:i.maxLength,minimum:i.minimum,maximum:i.maximum,pattern:i.pattern,patternDescription:i.patternDescription,format:i.format},isOptional:i.isOptional,isInternal:i.isInternal};r.items.properties[s]=ns(a,!0),i.isOptional||r.items.required.push(s)}}else if(t.name==="class"&&t.options)r.items={type:"string",enum:t.options};else{let s=Ec(t.description||o.description,t);r.items={type:Mc(t.name)},s&&(r.items.description=s),t.name==="string"||t.name==="code"||t.name==="url"||t.name==="date"||t.name==="datetime"?(t.minLength!==void 0&&(r.items.minLength=t.minLength),t.maxLength!==void 0&&(r.items.maxLength=t.maxLength),t.pattern!==void 0&&(r.items.pattern=t.pattern),t.format!==void 0&&(r.items.format=t.format)):t.name==="number"&&(t.minimum!==void 0&&(r.items.minimum=t.minimum),t.maximum!==void 0&&(r.items.maximum=t.maximum))}else if(t?.name==="object"&&t.fields){r.type="object",r.properties={},r.required=[],r.additionalProperties=!1;for(let[s,i]of Object.entries(t.fields)){let a={name:s,description:i.description,type:{name:i.type,isArray:i.isArray,options:i.options?[...i.options]:void 0,fields:i.fields,minLength:i.minLength,maxLength:i.maxLength,minimum:i.minimum,maximum:i.maximum,pattern:i.pattern,patternDescription:i.patternDescription,format:i.format},isOptional:i.isOptional,isInternal:i.isInternal};r.properties[s]=ns(a,!0),i.isOptional||r.required.push(s)}}else t?.name==="class"&&t.options?(r.type="string",r.enum=t.options):(r.type=Mc(t?.name??"string"),t?.name==="string"||t?.name==="code"||t?.name==="url"||t?.name==="date"||t?.name==="datetime"?(t.minLength!==void 0&&(r.minLength=t.minLength),t.maxLength!==void 0&&(r.maxLength=t.maxLength),t.pattern!==void 0&&(r.pattern=t.pattern),t.format!==void 0&&(r.format=t.format),t.name==="url"&&!t.format&&(r.format="uri"),t.name==="date"&&!t.format&&(r.format="date"),t.name==="datetime"&&!t.format&&(r.format="date-time")):t?.name==="number"&&(t.minimum!==void 0&&(r.minimum=t.minimum),t.maximum!==void 0&&(r.maximum=t.maximum)));return r}function Mc(o){switch(o){case"string":case"code":case"url":case"date":case"datetime":case"image":case"audio":case"file":return"string";case"number":return"number";case"boolean":return"boolean";case"json":case"object":return["object","array","string","number","boolean","null"];default:return"string"}}function rs(o){if(!o||typeof o!="object")throw new Error("Schema must be an object");if(o.type==="array"){if(!o.items)throw new Error('Array schema is missing an "items" definition (required by JSON Schema and all LLM providers for function tools)');rs(o.items)}else if(o.type==="object"&&o.properties)for(let e of Object.values(o.properties))rs(e)}var en=class extends Error{calls;constructor(e){super(`Stop function executed: ${e.map(t=>t.func.name).join(", ")}`),this.name="AxStopFunctionCallException",this.calls=e}},Lr=class extends Error{constructor(t){super();this.fields=t;this.name="AxFunctionError"}getFields=()=>this.fields;toString(){return[`${this.name}: Function validation error`,...this.fields.map(t=>` - ${t.field}: ${t.message}`)].join(`
209
- `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},$r=class extends Error{constructor(t,n,r){super();this.fields=t;this.func=n;this.funcId=r}getFunctionId=()=>this.funcId;getFieldDescription(t){if(!this.func.parameters?.properties?.[t])return"";let n=this.func.parameters.properties[t],r=n.description;return n.enum?.length&&(r+=` Allowed values are: ${n.enum.join(", ")}`),r}getFixingInstructions=()=>{let t=this.fields.map(n=>{let r=this.getFieldDescription(n.field)||"";return`- \`${n.field}\` - ${n.message} (${r}).`});return`Errors In Function Arguments: Fix the following invalid arguments to '${this.func.name}'
203
+ `,s=u}),(s>t||n.length===0)&&n.push(r.trim()),n},Vd=(o,e=.1)=>{let t=[...o].sort((r,s)=>r.score-s.score),n=Math.ceil(t.length*e);return t.slice(0,n)};var Jn=require("@opentelemetry/api");var Fr=class{data=[];seenTags=new Set;addRequest(e,t){this.data.push(...e.map(n=>{let r=structuredClone(n);return{role:n.role,chat:[{index:t,value:r}]}}))}addFunctionResults(e){let t=e.map(({index:r,...s})=>({index:r,value:structuredClone(s)})),n=this.getLast();n?.role==="function"?n.chat.push(...t):this.data.push({role:"function",chat:t})}addResponse(e){let t=e.map(({index:n,...r})=>({index:n,value:structuredClone(r)}));this.data.push({role:"assistant",chat:t})}updateResult({content:e,name:t,functionCalls:n,thought:r,thoughtBlocks:s,index:i}){let a=this.data.at(-1);if(!a||a.role!=="assistant"||a.role==="assistant"&&!a.updatable){this.data.push({role:"assistant",updatable:!0,chat:[{index:i,value:structuredClone({content:e,name:t,functionCalls:n,thought:r,thoughtBlocks:s})}]});return}let u=a.chat.find(c=>c.index===i);if(!u){a.chat.push({index:i,value:structuredClone({content:e,name:t,functionCalls:n,thought:r,thoughtBlocks:s})});return}if(typeof e=="string"&&e.trim()!==""&&(u.value.content=e),typeof t=="string"&&t.trim()!==""&&(u.value.name=t),Array.isArray(n)&&n.length>0&&(u.value.functionCalls=n),typeof r=="string"&&r.trim()!==""){let c=u.value.thought;u.value.thought=typeof c=="string"?c+r:r}if(Array.isArray(s)&&s.length>0){let c=u.value.thoughtBlocks??[];for(let l of s){let p=c.length>0?c[c.length-1]:void 0;!l.signature&&l.data?p&&!p.signature?(p.data=(p.data??"")+l.data,l.encrypted&&(p.encrypted=!0)):c.push(structuredClone(l)):l.signature?p&&!p.signature?(p.data=(p.data??"")+l.data,p.signature=l.signature,l.encrypted&&(p.encrypted=!0)):c.push(structuredClone(l)):c.length===0&&c.push(structuredClone(l))}u.value.thoughtBlocks=c,c.length>0&&(u.value.thought=c.map(l=>l.data).join(""))}}addTag(e){let t=this.data.at(-1);t&&(t.tags||(t.tags=[]),t.tags.includes(e)||t.tags.push(e),this.seenTags.add(e))}rewindToTag(e){let t=this.data.findIndex(n=>n.tags?.includes(e));if(t===-1){if(!this.seenTags.has(e))throw new Error(`Tag "${e}" not found`);return[]}return this.data.splice(t)}removeByTag(e){let t=this.data.reduce((n,r,s)=>(r.tags?.includes(e)&&n.push(s),n),[]);return t.length===0?[]:t.reverse().map(n=>this.data.splice(n,1).at(0)).filter(n=>n!==void 0).reverse()}history(e){let t=[];for(let{role:n,chat:r}of this.data){let s;n==="function"?s=r.filter(i=>i.index===e).map(i=>i.value):s=r.find(i=>i.index===e)?.value,Array.isArray(s)&&s.length>0?t.push(...s.map(i=>({...i,role:n}))):typeof s=="object"&&s!==null&&t.push({...s,role:n})}return t}getLast(){return this.data.at(-1)}reset(){this.data=[],this.seenTags=new Set}},Un=class{memories=new Map;defaultMemory;constructor(){this.defaultMemory=new Fr}getMemory(e){return e?(this.memories.has(e)||this.memories.set(e,new Fr),this.memories.get(e)):this.defaultMemory}addRequest(e,t){for(let n of e)mn(n);this.getMemory(t).addRequest(e,0)}addResponse(e,t){Ao(e),this.getMemory(t).addResponse(e)}addFunctionResults(e,t){this.getMemory(t).addFunctionResults(e)}updateResult(e,t){this.getMemory(t).updateResult(e)}addTag(e,t){this.getMemory(t).addTag(e)}rewindToTag(e,t){return this.getMemory(t).rewindToTag(e)}removeByTag(e,t){return this.getMemory(t).removeByTag(e)}history(e,t){return this.getMemory(t).history(e)}getLast(e){return this.getMemory(e).getLast()}reset(e){e?this.memories.set(e,new Fr):this.defaultMemory.reset()}};function vt(o,e){if(!o&&!e)return;if(!o)return e;if(!e||o===e||o.aborted)return o;if(e.aborted)return e;if(typeof AbortSignal.any=="function")return AbortSignal.any([o,e]);let t=new AbortController,n=()=>{t.abort(o.aborted?o.reason:e.reason),r()},r=()=>{o.removeEventListener("abort",n),e.removeEventListener("abort",n)};return o.addEventListener("abort",n,{once:!0}),e.addEventListener("abort",n,{once:!0}),t.signal}var Et=class extends Error{constructor({message:e}){super(e),this.name="AxAssertionError"}getFixingInstructions=()=>{let e=[],t=this.message.trim();return e.push({name:"error",title:"Follow these instructions",description:t+(t.endsWith(".")?"":".")}),e};toString(){return`${this.name}: ${this.message}`}[Symbol.for("nodejs.util.inspect.custom")](e,t){return this.toString()}},Gn=async(o,e)=>{for(let t of o){let{fn:n,message:r}=t,s=await n(e);if(s!==void 0){if(typeof s=="string")throw new Et({message:s});if(!s)throw r?new Et({message:r}):new Error("Assertion Failed: No message provided for assertion")}}},Li=async(o,e,t,n=!1)=>{if(!e.currField||e.s===-1||!o||o.length===0)return;let r=o.filter(i=>i.fieldName===e.currField?.name);if(r.length===0)return;let s=t.substring(e.s);for(let i of r){let{message:a,fn:u}=i,c=await u(s,n);if(c!==void 0){if(typeof c=="string")throw new Et({message:c});if(!c&&a)throw new Et({message:a})}}};var $i={enabled:!0,enabledCategories:["generation","streaming","functions","errors","performance"],maxLabelLength:100,samplingRate:1},_r,Di=o=>{if(_r)return _r;let e=o??ge.meter;if(e)return _r=Jd(e),_r};var mc=()=>{let o=[];return ge.meter||o.push("Global meter not initialized"),!_r&&ge.meter&&o.push("Metrics instruments not created despite available meter"),{healthy:o.length===0,issues:o}},Jd=o=>({generationLatencyHistogram:o.createHistogram("ax_gen_generation_duration_ms",{description:"End-to-end duration of AxGen generation requests",unit:"ms"}),generationRequestsCounter:o.createCounter("ax_gen_generation_requests_total",{description:"Total number of AxGen generation requests"}),generationErrorsCounter:o.createCounter("ax_gen_generation_errors_total",{description:"Total number of failed AxGen generations"}),multiStepGenerationsCounter:o.createCounter("ax_gen_multistep_generations_total",{description:"Total number of generations that required multiple steps"}),stepsPerGenerationHistogram:o.createHistogram("ax_gen_steps_per_generation",{description:"Number of steps taken per generation"}),maxStepsReachedCounter:o.createCounter("ax_gen_max_steps_reached_total",{description:"Total number of generations that hit max steps limit"}),validationErrorsCounter:o.createCounter("ax_gen_validation_errors_total",{description:"Total number of validation errors encountered"}),assertionErrorsCounter:o.createCounter("ax_gen_assertion_errors_total",{description:"Total number of assertion errors encountered"}),errorCorrectionAttemptsHistogram:o.createHistogram("ax_gen_error_correction_attempts",{description:"Number of error correction attempts per generation"}),errorCorrectionSuccessCounter:o.createCounter("ax_gen_error_correction_success_total",{description:"Total number of successful error corrections"}),errorCorrectionFailureCounter:o.createCounter("ax_gen_error_correction_failure_total",{description:"Total number of failed error corrections"}),maxRetriesReachedCounter:o.createCounter("ax_gen_max_retries_reached_total",{description:"Total number of generations that hit max retries limit"}),functionsEnabledGenerationsCounter:o.createCounter("ax_gen_functions_enabled_generations_total",{description:"Total number of generations with functions enabled"}),functionCallStepsCounter:o.createCounter("ax_gen_function_call_steps_total",{description:"Total number of steps that included function calls"}),functionsExecutedPerGenerationHistogram:o.createHistogram("ax_gen_functions_executed_per_generation",{description:"Number of unique functions executed per generation"}),functionErrorCorrectionCounter:o.createCounter("ax_gen_function_error_correction_total",{description:"Total number of function-related error corrections"}),fieldProcessorsExecutedCounter:o.createCounter("ax_gen_field_processors_executed_total",{description:"Total number of field processors executed"}),streamingFieldProcessorsExecutedCounter:o.createCounter("ax_gen_streaming_field_processors_executed_total",{description:"Total number of streaming field processors executed"}),streamingGenerationsCounter:o.createCounter("ax_gen_streaming_generations_total",{description:"Total number of streaming generations"}),streamingDeltasEmittedCounter:o.createCounter("ax_gen_streaming_deltas_emitted_total",{description:"Total number of streaming deltas emitted"}),streamingFinalizationLatencyHistogram:o.createHistogram("ax_gen_streaming_finalization_duration_ms",{description:"Duration of streaming response finalization",unit:"ms"}),samplesGeneratedHistogram:o.createHistogram("ax_gen_samples_generated",{description:"Number of samples generated per request"}),resultPickerUsageCounter:o.createCounter("ax_gen_result_picker_usage_total",{description:"Total number of times result picker was used"}),resultPickerLatencyHistogram:o.createHistogram("ax_gen_result_picker_duration_ms",{description:"Duration of result picker execution",unit:"ms"}),inputFieldsGauge:o.createGauge("ax_gen_input_fields",{description:"Number of input fields in signature"}),outputFieldsGauge:o.createGauge("ax_gen_output_fields",{description:"Number of output fields in signature"}),examplesUsedGauge:o.createGauge("ax_gen_examples_used",{description:"Number of examples used in generation"}),demosUsedGauge:o.createGauge("ax_gen_demos_used",{description:"Number of demos used in generation"}),promptRenderLatencyHistogram:o.createHistogram("ax_gen_prompt_render_duration_ms",{description:"Duration of prompt template rendering",unit:"ms"}),extractionLatencyHistogram:o.createHistogram("ax_gen_extraction_duration_ms",{description:"Duration of value extraction from responses",unit:"ms"}),assertionLatencyHistogram:o.createHistogram("ax_gen_assertion_duration_ms",{description:"Duration of assertion checking",unit:"ms"}),stateCreationLatencyHistogram:o.createHistogram("ax_gen_state_creation_duration_ms",{description:"Duration of state creation for multiple samples",unit:"ms"}),memoryUpdateLatencyHistogram:o.createHistogram("ax_gen_memory_update_duration_ms",{description:"Duration of memory updates during generation",unit:"ms"})}),Xo=$i,gc=o=>{Xo={...Xo,...o}},fc=()=>({...Xo}),St=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n),s=Xo.maxLabelLength;e[t]=r.length>s?r.substring(0,s):r}return e};var hc=(o,e,t,n,r,s,i)=>{try{let a=St({success:t.toString(),...n?{signature:n}:{},...r?{ai_service:r}:{},...s?{model:s}:{},...i});o.generationLatencyHistogram&&o.generationLatencyHistogram.record(e,a),o.generationRequestsCounter&&o.generationRequestsCounter.add(1,a),!t&&o.generationErrorsCounter&&o.generationErrorsCounter.add(1,a)}catch(a){console.warn("Failed to record generation metric:",a)}},Zo=(o,e,t,n,r)=>{try{let s=St({...n?{signature:n}:{},...r});e>1&&o.multiStepGenerationsCounter&&o.multiStepGenerationsCounter.add(1,s),o.stepsPerGenerationHistogram&&o.stepsPerGenerationHistogram.record(e,s),e>=t&&o.maxStepsReachedCounter&&o.maxStepsReachedCounter.add(1,s)}catch(s){console.warn("Failed to record multi-step metric:",s)}},Ui=(o,e,t,n)=>{try{let r=St({error_type:e,...t?{signature:t}:{},...n});e==="validation"&&o.validationErrorsCounter&&o.validationErrorsCounter.add(1,r),e==="assertion"&&o.assertionErrorsCounter&&o.assertionErrorsCounter.add(1,r)}catch(r){console.warn("Failed to record validation error metric:",r)}},xc=(o,e,t)=>{try{let n=St({error_type:"refusal",...e?{signature:e}:{},...t});o.validationErrorsCounter&&o.validationErrorsCounter.add(1,n)}catch(n){console.warn("Failed to record refusal error metric:",n)}},Gi=(o,e,t,n,r,s)=>{try{let i=St({success:t.toString(),...r?{signature:r}:{},...s});o.errorCorrectionAttemptsHistogram&&o.errorCorrectionAttemptsHistogram.record(e,i),t&&o.errorCorrectionSuccessCounter&&o.errorCorrectionSuccessCounter.add(1,i),t||(o.errorCorrectionFailureCounter&&o.errorCorrectionFailureCounter.add(1,i),e>=n&&o.maxRetriesReachedCounter&&o.maxRetriesReachedCounter.add(1,i))}catch(i){console.warn("Failed to record error correction metric:",i)}},Ac=(o,e,t,n,r=!1,s,i)=>{try{let a=St({functions_enabled:e.toString(),had_function_calls:n.toString(),...s?{signature:s}:{},...i});e&&o.functionsEnabledGenerationsCounter&&o.functionsEnabledGenerationsCounter.add(1,a),n&&o.functionCallStepsCounter&&o.functionCallStepsCounter.add(1,a),t>0&&o.functionsExecutedPerGenerationHistogram&&o.functionsExecutedPerGenerationHistogram.record(t,a),r&&o.functionErrorCorrectionCounter&&o.functionErrorCorrectionCounter.add(1,a)}catch(a){console.warn("Failed to record function calling metric:",a)}},yc=(o,e,t,n,r)=>{try{let s=St({...n?{signature:n}:{},...r});e>0&&o.fieldProcessorsExecutedCounter&&o.fieldProcessorsExecutedCounter.add(e,s),t>0&&o.streamingFieldProcessorsExecutedCounter&&o.streamingFieldProcessorsExecutedCounter.add(t,s)}catch(s){console.warn("Failed to record field processing metric:",s)}},bc=(o,e,t,n,r,s)=>{try{let i=St({is_streaming:e.toString(),...r?{signature:r}:{},...s});e&&o.streamingGenerationsCounter&&o.streamingGenerationsCounter.add(1,i),t>0&&o.streamingDeltasEmittedCounter&&o.streamingDeltasEmittedCounter.add(t,i),n&&o.streamingFinalizationLatencyHistogram&&o.streamingFinalizationLatencyHistogram.record(n,i)}catch(i){console.warn("Failed to record streaming metric:",i)}},Cc=(o,e,t,n,r,s)=>{try{let i=St({result_picker_used:t.toString(),...r?{signature:r}:{},...s});o.samplesGeneratedHistogram&&o.samplesGeneratedHistogram.record(e,i),t&&o.resultPickerUsageCounter&&o.resultPickerUsageCounter.add(1,i),n&&o.resultPickerLatencyHistogram&&o.resultPickerLatencyHistogram.record(n,i)}catch(i){console.warn("Failed to record samples metric:",i)}},Ic=(o,e,t,n,r,s,i)=>{try{let a=St({...s?{signature:s}:{},...i});o.inputFieldsGauge&&o.inputFieldsGauge.record(e,a),o.outputFieldsGauge&&o.outputFieldsGauge.record(t,a),o.examplesUsedGauge&&o.examplesUsedGauge.record(n,a),o.demosUsedGauge&&o.demosUsedGauge.record(r,a)}catch(a){console.warn("Failed to record signature complexity metrics:",a)}},es=(o,e,t,n,r)=>{try{let s=St({metric_type:e,...n?{signature:n}:{},...r});switch(e){case"prompt_render":o.promptRenderLatencyHistogram&&o.promptRenderLatencyHistogram.record(t,s);break;case"extraction":o.extractionLatencyHistogram&&o.extractionLatencyHistogram.record(t,s);break;case"assertion":o.assertionLatencyHistogram&&o.assertionLatencyHistogram.record(t,s);break;case"state_creation":o.stateCreationLatencyHistogram&&o.stateCreationLatencyHistogram.record(t,s);break;case"memory_update":o.memoryUpdateLatencyHistogram&&o.memoryUpdateLatencyHistogram.record(t,s);break}}catch(s){console.warn("Failed to record performance metric:",s)}};var jn=o=>{let e=(()=>{switch(o?.name){case"string":return"string";case"number":return"number";case"boolean":return"boolean";case"date":return'date ("YYYY-MM-DD" format)';case"datetime":return'date time ("YYYY-MM-DD HH:mm Timezone" format)';case"json":return"JSON object";case"class":return"classification class";case"code":return"code";case"object":return"object";default:return"string"}})();return o?.isArray?`array of ${e}s`:e},Qe=class extends Error{constructor(e){super(e),this.name="ValidationError"}getFixingInstructions=()=>[{name:"outputError",title:"Invalid Field",description:this.message}];toString(){return`${this.name}: ${this.message}`}[Symbol.for("nodejs.util.inspect.custom")](e,t){return this.toString()}},Tc=o=>{let t=o.map(n=>`'${n.title}' (${jn(n.type)})`).join(", ");return new Qe(`Required field not found: ${t}. Add a line starting with the exact label followed by a colon (e.g., "${o[0]?.title}:") and then provide a valid ${jn(o[0]?.type)} value. Keep the output concise and avoid unrelated text.`)},ts=o=>new Qe(`Expected (Required) field not found: '${o.title}'. Begin a new section with "${o.title}:" and then provide a valid ${jn(o.type)} value directly after.`);var ns=o=>new Qe(`Required field is missing: '${o.title}'. After the "${o.title}:" label, provide a non-empty ${jn(o.type)}. Do not use null, undefined, or leave it blank.`),wc=(o,e)=>new Qe(`Invalid JSON: ${e} in field '${o.title}'. Return only valid JSON. Prefer a fenced code block containing a single JSON object or array with no trailing text.`),Rc=(o,e)=>new Qe(`Invalid Array: ${e} for '${o.title}'. Provide a JSON array of ${jn(o.type)} items (e.g., [ ... ]). Markdown lists are also accepted if each item is on its own line starting with a hyphen.`),vc=(o,e,t)=>new Qe(`Field '${o.title}' has an invalid value '${e}': ${t}. Provide a ${jn(o.type)}. Ensure formatting exactly matches the expected type.`),Sc=(o,e,t)=>new Qe(`Invalid date for '${o.title}': ${t}. Use the exact format YYYY-MM-DD (e.g., 2024-05-09). You provided: ${e}.`),kc=(o,e,t)=>new Qe(`Invalid date/time for '${o.title}': ${t}. Use the format YYYY-MM-DD HH:mm or YYYY-MM-DD HH:mm:ss followed by a valid timezone (e.g., America/New_York). You provided: ${e}.`),ji=(o,e,t)=>new Qe(`Invalid URL for '${o.title}': ${t}. Use a valid URL format (e.g., https://example.com). You provided: ${e}.`),Bn=(o,e,t,n)=>{let r=`Field '${o.title}' failed validation: `;return t==="minLength"?r+=`String must be at least ${n} characters long. You provided: "${e}" (${e.length} characters).`:t==="maxLength"?r+=`String must be at most ${n} characters long. You provided: "${e}" (${e.length} characters).`:t==="pattern"?r+=`String must match pattern /${n}/. You provided: "${e}".`:t==="format"&&(r+=`String must be a ${n}. You provided: "${e}".`),new Qe(r)},Bi=(o,e,t,n)=>{let r=`Field '${o.title}' failed validation: `;return t==="minimum"?r+=`Number must be at least ${n}. You provided: ${e}.`:t==="maximum"&&(r+=`Number must be at most ${n}. You provided: ${e}.`),new Qe(r)};var Oc=({error:o,errCount:e,debug:t,logger:n,metricsInstruments:r,signatureName:s,span:i,customLabels:a})=>{let u=o.getFixingInstructions();if(t&&n){let c=u?.map(l=>l.title).join(", ")??"";gu(o,e,c,n)}return r&&Ui(r,"validation",s,a),i&&i.addEvent("validation.error",{message:o.toString(),fixing_instructions:u?.map(c=>c.title).join(", ")??""}),u},Ec=({error:o,errCount:e,debug:t,logger:n,metricsInstruments:r,signatureName:s,span:i,customLabels:a})=>{let u=o.getFixingInstructions();if(t&&n){let c=u?.map(l=>l.title).join(", ")??"";fu(o,e,c,n)}return r&&Ui(r,"assertion",s,a),i&&i.addEvent("assertion.error",{message:o.toString(),fixing_instructions:u?.map(c=>c.title).join(", ")??""}),u},Mc=({error:o,errCount:e,debug:t,logger:n,metricsInstruments:r,signatureName:s,span:i,customLabels:a})=>{t&&n&&hu(o,e,n),r&&xc(r,s,a),i&&i.addEvent("refusal.error",{message:o.toString()})};var Bt=dr(require("dayjs"),1),Pc=dr(require("dayjs/plugin/customParseFormat.js"),1),Fc=dr(require("dayjs/plugin/timezone.js"),1),_c=dr(require("dayjs/plugin/utc.js"),1);Bt.default.extend(_c.default);Bt.default.extend(Fc.default);Bt.default.extend(Pc.default);function Nc(o,e,t=!1){try{return Qd(e)}catch(n){if(o.isOptional&&!t)return;let r=n.message;throw Sc(o,e,r)}}function Qd(o){if(!(0,Bt.default)(o,"YYYY-MM-DD",!0).isValid())throw new Error('Invalid date format. Please provide the date in "YYYY-MM-DD" format.');return Bt.default.utc(o,"YYYY-MM-DD").startOf("day").toDate()}function Lc(o,e,t=!1){try{return Yd(e)}catch(n){if(o.isOptional&&!t)return;let r=n.message;throw kc(o,e,r)}}function Yd(o){let e=/^(\d{4}-\d{2}-\d{2} \d{2}:\d{2}(?::\d{2})?) (.+)$/,t=o.match(e);if(!t)throw new Error('Invalid date and time format. Please provide the date and time in "YYYY-MM-DD HH:mm" or "YYYY-MM-DD HH:mm:ss" format, followed by the timezone.');let[,n,r]=t;if(!n||!r)throw new Error('Invalid date and time format. Please provide the date and time in "YYYY-MM-DD HH:mm" or "YYYY-MM-DD HH:mm:ss" format, followed by the timezone.');try{let s=n.includes(":")&&n.split(":").length===3?"YYYY-MM-DD HH:mm:ss":"YYYY-MM-DD HH:mm",i=Bt.default.tz(n,s,r);if(!i.isValid())throw new Error("Invalid date and time values. Please ensure all components are correct.");return i.utc().toDate()}catch{throw new Error(`Unrecognized time zone ${r}. Please provide a valid time zone name, abbreviation, or offset. For example, "America/New_York", or "EST".`)}}var $c=o=>(0,Bt.default)(o).utc().format("YYYY-MM-DD HH:mm:ss [UTC]");var wy=new ot,Nr=(o,e)=>{let t=o.type??{name:"string",isArray:!1},n=(c,l)=>{switch(c){case"class":return typeof l=="string";case"code":return typeof l=="string";case"string":return typeof l=="string";case"number":return typeof l=="number";case"boolean":return typeof l=="boolean";case"date":return l instanceof Date||typeof l=="string";case"datetime":return l instanceof Date||typeof l=="string";case"json":return typeof l=="object"||typeof l=="string";case"object":return typeof l=="object";default:return!1}},r=c=>!(!c||typeof c!="object"||!("mimeType"in c)||!("data"in c));if(o.type?.name==="image"){let c;if(Array.isArray(e)){for(let l of e)if(!r(l)){c="object ({ mimeType: string; data: string })";break}}else r(e)||(c="object ({ mimeType: string; data: string })");if(c)throw new Error(`Validation failed: Expected '${o.name}' to be type '${c}' instead got '${e}'`);return}let s=c=>!(!c||typeof c!="object"||!("data"in c));if(o.type?.name==="audio"){let c;if(Array.isArray(e)){for(let l of e)if(!s(l)){c="object ({ data: string; format?: string })";break}}else s(e)||(c="object ({ data: string; format?: string })");if(c)throw new Error(`Validation failed: Expected '${o.name}' to be type '${c}' instead got '${e}'`);return}let i=c=>{if(!c||typeof c!="object"||!("mimeType"in c))return!1;let l="data"in c,p="fileUri"in c;return!(!l&&!p||l&&p)};if(o.type?.name==="file"){let c;if(Array.isArray(e)){for(let l of e)if(!i(l)){c="object ({ mimeType: string; data: string } | { mimeType: string; fileUri: string })";break}}else i(e)||(c="object ({ mimeType: string; data: string } | { mimeType: string; fileUri: string })");if(c)throw new Error(`Validation failed: Expected '${o.name}' to be type '${c}' instead got '${e}'`);return}let a=c=>typeof c=="string"?!0:!(!c||typeof c!="object"||!("url"in c));if(o.type?.name==="url"){let c;if(Array.isArray(e)){for(let l of e)if(!a(l)){c="string or object ({ url: string; title?: string; description?: string })";break}}else a(e)||(c="string or object ({ url: string; title?: string; description?: string })");if(c)throw new Error(`Validation failed: Expected '${o.name}' to be type '${c}' instead got '${e}'`);return}let u=!0;if(t.isArray){if(!Array.isArray(e))u=!1;else for(let c of e)if(!n(t.name,c)){u=!1;break}}else u=n(t.name,e);if(!u){let c=Array.isArray(e)?"array":typeof e;throw new Error(`Validation failed: Expected '${o.name}' to be a ${o.type?.isArray?"an array of ":""}${t.name} instead got '${c}' (${JSON.stringify(e)})`)}};function Lr(o){let e={};for(let t of o){let n=`${t.ai}:${t.model}`;if(!e[n]){e[n]={...t};continue}let r=e[n];if(r){let s=r.tokens??{promptTokens:0,completionTokens:0,totalTokens:0};s.promptTokens+=t?.tokens?.promptTokens??0,s.completionTokens+=t?.tokens?.completionTokens??0,s.totalTokens+=t?.tokens?.totalTokens??0,r.tokens=s;let i=r.citations??[],a=t.citations??[];if(a.length){let u=new Set(i.map(c=>c.url));for(let c of a)c?.url&&!u.has(c.url)&&(i.push(c),u.add(c.url));r.citations=i}}}return Object.values(e)}var Dc=o=>{if(!o.trim())return[];let e=new Set(["-","*","+"]),t=/^\d+[\s]*[.)\]]\s*/,n=o.split(`
204
+ `),r=[];for(let s of n){let i=s.trim();if(i){if(i[0]&&e.has(i[0]))r.push(i.slice(1).trim());else if(t.test(i))r.push(i.replace(t,"").trim());else if(r.length!==0)throw new Error("Could not parse markdown list: mixed content detected")}}if(r.length===0)throw new Error("Could not parse markdown list: no valid list items found");return r};function qi(o,e){let{index:t,delta:n,version:r}=e,s=o.find(a=>a.index===t)?.delta;if(!s)return o.push({index:t,delta:n,version:r}),o;for(let a of Object.keys(n)){let u=s[a],c=n[a];u===void 0&&Array.isArray(c)?s[a]=[...c]:Array.isArray(u)&&Array.isArray(c)?s[a]=[...u,...c]:(u===void 0||typeof u=="string")&&typeof c=="string"?s[a]=`${u??""}${c}`:s[a]=c}let i=o.find(a=>a.index===t);return i&&(i.version=r),o}var zi=class{cache=new Map;maxSize;constructor(e){this.maxSize=e}get(e){let t=this.cache.get(e);return t&&(this.cache.delete(e),this.cache.set(e,t)),t}set(e,t){if(this.cache.has(e))this.cache.delete(e);else if(this.cache.size>=this.maxSize){let n=this.cache.keys().next().value;n&&this.cache.delete(n)}this.cache.set(e,t)}},Xd=new zi(500);function Uc(o,e,t=0,n=Xd){if(/^```[a-zA-Z]*\s*$/.test(o))return-4;if(/^[\s`]*$/.test(o))return-3;let r=o.indexOf(e,t);if(r!==-1)return r;let s=n.get(e)??Array.from({length:e.length},(a,u)=>e.slice(0,u+1));n.get(e)||n.set(e,s);let i=-1;for(let a=s.length-1;a>=0;a--){let u=s[a];if(o.endsWith(u)){i=a;break}}return i>=0?-2:-1}function zt(o,e){if(typeof o!="string")throw ji(e,String(o),"URL must be a string");try{new URL(o)}catch{throw ji(e,o,"Invalid URL format. Expected a valid URL like https://example.com")}}function xt(o,e){if(typeof o!="string")return;let t=e.type;if(t){if(t.minLength!==void 0&&o.length<t.minLength)throw Bn(e,o,"minLength",t.minLength);if(t.maxLength!==void 0&&o.length>t.maxLength)throw Bn(e,o,"maxLength",t.maxLength);if(t.pattern!==void 0&&!new RegExp(t.pattern).test(o))throw Bn(e,o,"pattern",t.pattern);if(t.format==="email"&&!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(o))throw Bn(e,o,"format","valid email address");if(t.format==="uri"||t.format==="url")try{new URL(o)}catch{throw Bn(e,o,"format","valid URL")}}}function At(o,e){if(typeof o!="number")return;let t=e.type;if(t){if(t.minimum!==void 0&&o<t.minimum)throw Bi(e,o,"minimum",t.minimum);if(t.maximum!==void 0&&o>t.maximum)throw Bi(e,o,"maximum",t.maximum)}}var ss=(o,e,t,n)=>{let r=n?.strictMode??!1,s=n?.treatAllFieldsOptional??!1,i=n?.treatAllFieldsOptional??!1,a={extractedFields:[],streamedIndex:{},s:-1};Wi(o,e,a,t,{strictMode:r,skipEarlyFail:i,treatAllFieldsOptional:s}),Vi(o,e,a,t,{strictMode:r,treatAllFieldsOptional:s,forceFinalize:!0});for(let u of o.getOutputFields())u.isInternal&&delete e[u.name]},Hi=(o,e,t)=>{let n=[];for(let r of t)r&&!r.isOptional&&e[r.name]===void 0&&n.push(r);if(n.length>0)throw Tc(n)},Wi=(o,e,t,n,{strictMode:r,skipEarlyFail:s}={})=>{let i=o.getOutputFields(),a;for(;;){let u=new Set;t.currFieldIndex!==void 0&&!t.inAssumedField&&u.add(t.currFieldIndex);let c=i.map((g,f)=>({field:g,index:f})).filter(({index:g})=>!u.has(g)),l,p,d=-1,m=0;for(let{index:g,field:f}of c){let A=`${(t.extractedFields.length===0?"":`
205
+ `)+f.title}:`,h=Uc(n,A,t.s);if(h===-2||h===-3)return!0;if(h===-4)return t.inBlock=!0,!0;h>=0&&(d===-1||h<d)&&(d=h,m=A.length,l=g,p=f)}if(d===-1){if(s)return;if(!r&&t.currField===void 0&&t.extractedFields.length===0&&i.length===1){t.inAssumedField=!0,t.currField=i[0],t.currFieldIndex=0,t.s=0,t.extractedFields.includes(i[0])||t.extractedFields.push(i[0]),t.streamedIndex[i[0].name]===void 0&&(t.streamedIndex[i[0].name]=0);return}if(r&&t.currField===void 0&&t.extractedFields.length===0){let g=i.find(f=>!f.isOptional);if(g)throw ts(g)}break}if(a&&p&&a.name!==p.name)throw ts(a);if(t.currField!==void 0&&t.inAssumedField&&(t.inAssumedField=!1,t.streamedIndex[t.currField.name]=0,t.currField=void 0),t.currField){let g=n.substring(t.s,d).trim(),f=rs(t.currField,g);f!==void 0&&(e[t.currField.name]=f),t.prevFields?t.prevFields?.push({field:t.currField,s:t.s,e:d}):t.prevFields=[{field:t.currField,s:t.s,e:d}]}t.s=d+m,p!==void 0&&l!==void 0&&(t.currField=p,t.currFieldIndex=l),p&&!t.extractedFields.includes(p)&&t.extractedFields.push(p),p&&t.streamedIndex[p.name]===void 0&&(t.streamedIndex[p.name]=0)}},Vi=(o,e,t,n,r)=>{let s=r?.strictMode??!1,i=r?.treatAllFieldsOptional??!1,a=r?.deferRequiredCheckForStreaming??!1,u=r?.forceFinalize??!1;if(t.currField){let c=n.length,l=o.getOutputFields();for(let m of l){if(m.name===t.currField.name)continue;let g=`
206
+ ${m.title}:`,f=n.indexOf(g,t.s);f!==-1&&f<c&&(c=f)}let p=n.substring(t.s,c).trim(),d=rs(t.currField,p);d!==void 0&&(e[t.currField.name]=d)}if(s&&!t.currField&&t.extractedFields.length===0&&n.trim()){let p=o.getOutputFields().find(d=>!d.isOptional);if(p)throw ts(p)}if(Zd(o,e,n,t),!i){let c=t.currField!==void 0||(t.extractedFields?.length??0)>0;s||u?Hi(t,e,o.getOutputFields()):c||Hi(t,e,o.getOutputFields())}},Zd=(o,e,t,n)=>{let r=o.getOutputFields();if(r.length===1){let i=r[0];if(i){let a=`${i.title}:`,u=t.indexOf(a);if(u!==-1){let c=u+a.length,l=`
207
+ ${i.title}:`,p=t.indexOf(l,c),d=t.substring(c,p===-1?t.length:p).trim();if(d)try{let m=rs(i,d);if(m!==void 0){e[i.name]=m;return}}catch{}}}}let s=t.split(`
208
+ `);for(let i of r){if(i.name in e)continue;let a=`${i.title}:`;for(let u of s){let c=u.trim();if(c.startsWith(a)){let l=c.substring(a.length).trim();if(l)try{let p=rs(i,l);if(p!==void 0){e[i.name]=p;break}}catch(p){if(!i.isOptional)throw p}break}}}},Gc=(o,e,t=!1)=>{switch(o.type?.name){case"code":return Ki(e);case"string":return e;case"number":{let n=Number(e);if(Number.isNaN(n)){if(o.isOptional&&!t)return;throw new Error("Invalid number")}return n}case"boolean":{if(typeof e=="boolean")return e;let n=e.toLowerCase();if(n==="true")return!0;if(n==="false")return!1;if(o.isOptional&&!t)return;throw new Error("Invalid boolean")}case"date":return Nc(o,e,t);case"datetime":return Lc(o,e,t);case"class":{let n=e;if(o.type.options&&!o.type.options.includes(n)){if(o.isOptional)return;throw new Error(`Invalid class '${e}', expected one of the following: ${o.type.options.join(", ")}`)}return n}default:return e}};function*jc(o,e,t,n,r,s){let{name:i,isInternal:a}=e,{isArray:u,name:c}=e.type??{};if(a||u||c&&c!=="string"&&c!=="code")return;let l=r.streamedIndex[i]??0,p=l===0,d=(t<0?0:t)+l,m=o.substring(d,n);if(m.length===0)return;let g=m.replace(/\s+$/,"");r.currField?.type?.name==="code"&&(g=g.replace(/\s*```\s*$/,""));let f=p?g.trimStart():g;r.currField?.type?.name==="code"&&(f=f.replace(/^[ ]*```[a-zA-Z0-9]*\n\s*/,"")),f.length>0&&(yield{index:s,delta:{[i]:f}},r.streamedIndex[i]=l+g.length)}function*Ji(o,e,t,n,r){for(let i of n.prevFields??[]){let{field:a,s:u,e:c}=i;yield*jc(e,a,u,c,n,r)}if(n.prevFields=void 0,n.inAssumedField&&!(o.getOutputFields().filter(u=>!u.isInternal).length===1)||!n.currField||n.currField.isInternal)return;yield*jc(e,n.currField,n.s,e.length,n,r);let s=o.getOutputFields();for(let i of Object.keys(t)){let a=s.find(l=>l.name===i);if(!a||a.isInternal)continue;let u=t[i];if(Array.isArray(u)){let l=n.streamedIndex?.[i]??0,p=u.slice(l);p&&p.length>0&&(yield{index:r,delta:{[i]:p}},n.streamedIndex[i]=l+p.length);continue}let c=typeof u=="string"?u:void 0;if(!n.streamedIndex[i])yield{index:r,delta:{[i]:u}},n.streamedIndex[i]=c?c.length:1;else if(c){let l=n.streamedIndex[i];if(c.length>l){let p=c.substring(l);yield{index:r,delta:{[i]:p}},n.streamedIndex[i]=c.length}}}}function rs(o,e){if(!e||e===""||/^(null|undefined)\s*$/i.test(e)){if(o.isOptional)return;throw ns(o)}let t;if(o.type?.name==="json"&&!o.type?.isArray)try{let r=Ki(e);return t=JSON.parse(r),t}catch(r){throw wc(o,r.message)}if(o.type?.isArray)try{try{t=JSON.parse(e)}catch{t=Dc(e)}if(!Array.isArray(t))throw new Error("Expected an array")}catch(r){let s=r.message;if(s.includes("no valid list items found")||s==="Expected an array")t=[e];else throw Rc(o,s)}try{if(Array.isArray(t)){for(let[r,s]of t.entries())if(s!==void 0){let i=typeof s=="string"?s.trim():s;if(typeof i=="string"&&(o.type?.name==="object"||o.type?.name==="json"))try{let a=Ki(i);i=JSON.parse(a)}catch{}t[r]=Gc(o,i,!0)}}else t=Gc(o,e)}catch(r){throw vc(o,e,r.message)}if(typeof t=="string"&&t==="")return;let n=o.type;if(n&&t!==void 0&&(n.name==="url"&&zt(t,o),(n.name==="string"||n.name==="code")&&xt(t,o),n.name==="number"&&At(t,o),n.isArray&&Array.isArray(t)))for(let r of t)r!==void 0&&(n.name==="string"||n.name==="code"?xt(r,o):n.name==="number"&&At(r,o));return t}function zn(o,e,t){let n=o.getOutputFields();for(let r of n){let s=e[r.name];if(s==null){if(!r.isOptional&&!t?.allowMissingRequired)throw ns(r);continue}let i=r.type;if(i){if(i.name==="url"&&zt(s,r),(i.name==="string"||i.name==="code")&&xt(s,r),i.name==="number"&&At(s,r),i.isArray&&Array.isArray(s))for(let a of s)a!=null&&(i.name==="url"?zt(a,r):i.name==="string"||i.name==="code"?xt(a,r):i.name==="number"&&At(a,r));if(i.name==="object"&&i.fields&&typeof s=="object"&&!Array.isArray(s)&&os(r,s,t),i.isArray&&i.fields&&Array.isArray(s)&&i.name==="object")for(let a of s)a&&typeof a=="object"&&os(r,a,t)}}}function os(o,e,t){let n=o.type?.fields;if(!(!n||typeof n!="object"))for(let[r,s]of Object.entries(n)){let i={name:r,title:r,description:s.description,type:{name:s.type,isArray:s.isArray,options:s.options,fields:s.fields,minLength:s.minLength,maxLength:s.maxLength,minimum:s.minimum,maximum:s.maximum,pattern:s.pattern,patternDescription:s.patternDescription,format:s.format},isOptional:s.isOptional??!1,isInternal:s.isInternal??!1},a=e[i.name];if(a==null){if(!i.isOptional&&!t?.allowMissingRequired)throw ns(i);continue}let u=i.type;if(u){if(u.name==="url"&&zt(a,i),(u.name==="string"||u.name==="code")&&xt(a,i),u.name==="number"&&At(a,i),u.isArray&&Array.isArray(a))for(let c of a)c!=null&&(u.name==="url"?zt(c,i):u.name==="string"||u.name==="code"?xt(c,i):u.name==="number"&&At(c,i));if(u.name==="object"&&u.fields&&typeof a=="object"&&!Array.isArray(a)&&os(i,a,t),u.isArray&&u.fields&&Array.isArray(a)&&u.name==="object")for(let c of a)c&&typeof c=="object"&&os(i,c,t)}}}var Ki=o=>{let t=/```([A-Za-z]*)\s*([\s\S]*?)\s*```/g.exec(o);return t?t.length===3?t[2]:t.length===2?t[1]:o:o};async function $r(o,e,t,n){for(let r of o){if(e[r.field.name]===void 0)continue;let s=r.process,i=await s(e[r.field.name],{sessionId:n,values:e,done:!0});Bc(r.field,t,i,n)}}async function Qi(o,e,t,n,r,s,i=!1){for(let a of o){if(t.currField?.name!==a.field.name)continue;let u=e.substring(t.s);t.currField?.type?.name==="code"&&(u=u.replace(/^[ ]*```[a-zA-Z0-9]*\n\s*/,""),u=u.replace(/\s*```\s*$/,""));let c=a.process,l=await c(u,{sessionId:s,values:r,done:i});Bc(t.currField,n,l,s)}}var Bc=(o,e,t,n)=>{if(t===void 0||typeof t=="string"&&(t===""||/^(null|undefined)\s*$/i.test(t)))return;let r=String(t),s=r;e.addRequest([{role:"user",content:[{type:"text",text:s}]}],n),e.addTag("processor",n)};function zc(o,e){if(!e)return o;let t=[];if(e.format==="email"&&t.push("Must be a valid email address format"),(e.format==="uri"||e.format==="url"||e.name==="url")&&t.push("Must be a valid URL format"),(e.name==="string"||e.name==="code"||e.name==="url"||e.name==="date"||e.name==="datetime")&&(e.minLength!==void 0&&e.maxLength!==void 0?t.push(`Minimum length: ${e.minLength} characters, maximum length: ${e.maxLength} characters`):e.minLength!==void 0?t.push(`Minimum length: ${e.minLength} characters`):e.maxLength!==void 0&&t.push(`Maximum length: ${e.maxLength} characters`)),e.name==="number"&&(e.minimum!==void 0&&e.maximum!==void 0?t.push(`Minimum value: ${e.minimum}, maximum value: ${e.maximum}`):e.minimum!==void 0?t.push(`Minimum value: ${e.minimum}`):e.maximum!==void 0&&t.push(`Maximum value: ${e.maximum}`)),e.pattern!==void 0){if(!e.patternDescription)throw new Error(`Field with pattern '${e.pattern}' must include a patternDescription to explain the pattern to the LLM`);t.push(e.patternDescription)}if(e.name==="date"&&t.push("Format: YYYY-MM-DD"),e.name==="datetime"&&t.push("Format: ISO 8601 date-time"),t.length===0)return o;let n=t.join(". ");return!o||o.trim().length===0?n:`${o.trim().endsWith(".")?o.trim():`${o.trim()}.`} ${n}`}function qt(o,e="Schema"){if("name"in o&&"type"in o)return is(o);let t={},n=[];for(let r of o){if(r.isInternal)continue;let s=is(r);t[r.name]=s,r.isOptional||n.push(r.name)}return{type:"object",title:e,properties:t,required:n,additionalProperties:!1}}function is(o,e=!1){let t=o.type,n=zc(o.description,t);if(e&&t?.name&&(t.name==="image"||t.name==="audio"||t.name==="file"))throw new Error(`Media type '${t.name}' is not allowed in nested object fields. Media types (image, audio, file) can only be used as top-level input fields. Field: ${o.name}`);let r={};if(n&&(r.description=n),t?.isArray)if(r.type="array",t.fields){r.items={type:"object",properties:{},required:[],additionalProperties:!1},t.description&&(r.items.description=t.description);for(let[s,i]of Object.entries(t.fields)){let a={name:s,description:i.description,type:{name:i.type,isArray:i.isArray,options:i.options?[...i.options]:void 0,fields:i.fields,minLength:i.minLength,maxLength:i.maxLength,minimum:i.minimum,maximum:i.maximum,pattern:i.pattern,patternDescription:i.patternDescription,format:i.format},isOptional:i.isOptional,isInternal:i.isInternal};r.items.properties[s]=is(a,!0),i.isOptional||r.items.required.push(s)}}else if(t.name==="class"&&t.options)r.items={type:"string",enum:t.options};else{let s=zc(t.description||o.description,t);r.items={type:qc(t.name)},s&&(r.items.description=s),t.name==="string"||t.name==="code"||t.name==="url"||t.name==="date"||t.name==="datetime"?(t.minLength!==void 0&&(r.items.minLength=t.minLength),t.maxLength!==void 0&&(r.items.maxLength=t.maxLength),t.pattern!==void 0&&(r.items.pattern=t.pattern),t.format!==void 0&&(r.items.format=t.format)):t.name==="number"&&(t.minimum!==void 0&&(r.items.minimum=t.minimum),t.maximum!==void 0&&(r.items.maximum=t.maximum))}else if(t?.name==="object"&&t.fields){r.type="object",r.properties={},r.required=[],r.additionalProperties=!1;for(let[s,i]of Object.entries(t.fields)){let a={name:s,description:i.description,type:{name:i.type,isArray:i.isArray,options:i.options?[...i.options]:void 0,fields:i.fields,minLength:i.minLength,maxLength:i.maxLength,minimum:i.minimum,maximum:i.maximum,pattern:i.pattern,patternDescription:i.patternDescription,format:i.format},isOptional:i.isOptional,isInternal:i.isInternal};r.properties[s]=is(a,!0),i.isOptional||r.required.push(s)}}else t?.name==="class"&&t.options?(r.type="string",r.enum=t.options):(r.type=qc(t?.name??"string"),t?.name==="string"||t?.name==="code"||t?.name==="url"||t?.name==="date"||t?.name==="datetime"?(t.minLength!==void 0&&(r.minLength=t.minLength),t.maxLength!==void 0&&(r.maxLength=t.maxLength),t.pattern!==void 0&&(r.pattern=t.pattern),t.format!==void 0&&(r.format=t.format),t.name==="url"&&!t.format&&(r.format="uri"),t.name==="date"&&!t.format&&(r.format="date"),t.name==="datetime"&&!t.format&&(r.format="date-time")):t?.name==="number"&&(t.minimum!==void 0&&(r.minimum=t.minimum),t.maximum!==void 0&&(r.maximum=t.maximum)));return r}function qc(o){switch(o){case"string":case"code":case"url":case"date":case"datetime":case"image":case"audio":case"file":return"string";case"number":return"number";case"boolean":return"boolean";case"json":case"object":return["object","array","string","number","boolean","null"];default:return"string"}}function as(o){if(!o||typeof o!="object")throw new Error("Schema must be an object");if(o.type==="array"){if(!o.items)throw new Error('Array schema is missing an "items" definition (required by JSON Schema and all LLM providers for function tools)');as(o.items)}else if(o.type==="object"&&o.properties)for(let e of Object.values(o.properties))as(e)}var nn=class extends Error{calls;constructor(e){super(`Stop function executed: ${e.map(t=>t.func.name).join(", ")}`),this.name="AxStopFunctionCallException",this.calls=e}},Dr=class extends Error{constructor(t){super();this.fields=t;this.name="AxFunctionError"}getFields=()=>this.fields;toString(){return[`${this.name}: Function validation error`,...this.fields.map(t=>` - ${t.field}: ${t.message}`)].join(`
209
+ `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},Ur=class extends Error{constructor(t,n,r){super();this.fields=t;this.func=n;this.funcId=r}getFunctionId=()=>this.funcId;getFieldDescription(t){if(!this.func.parameters?.properties?.[t])return"";let n=this.func.parameters.properties[t],r=n.description;return n.enum?.length&&(r+=` Allowed values are: ${n.enum.join(", ")}`),r}getFixingInstructions=()=>{let t=this.fields.map(n=>{let r=this.getFieldDescription(n.field)||"";return`- \`${n.field}\` - ${n.message} (${r}).`});return`Errors In Function Arguments: Fix the following invalid arguments to '${this.func.name}'
210
210
  ${t.join(`
211
211
  `)}`};toString(){return[`${this.name}: Function execution error in '${this.func.name}'`,...this.fields.map(t=>{let n=this.getFieldDescription(t.field);return` - ${t.field}: ${t.message}${n?` (${n})`:""}`}),this.funcId?` Function ID: ${this.funcId}`:""].join(`
212
- `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},Dr=class{funcList=[];constructor(e){this.funcList=e}executeFunction=async(e,t,n)=>{let r;if(typeof t.args=="string"&&t.args.length>0)try{r=JSON.parse(t.args)}catch(c){throw new Error(`Invalid function arguments: ${t.args}`,{cause:c})}else r=t.args;let s=n?{sessionId:n.sessionId,traceId:n.traceId,ai:n.ai,step:n.step,abortSignal:n.abortSignal}:void 0,i;e.parameters?i=e.func.length===2?await e.func(r,s):await e.func(r):i=e.func.length===1?await e.func(s):await e.func();let l=(n?.functionResultFormatter??de.functionResultFormatter)(i);return{formatted:String(l),rawResult:i,parsedArgs:r}};executeWithDetails=async(e,t)=>{let n=i=>i.replace(/[^a-zA-Z0-9]/g,"").toLowerCase(),r=n(e.name),s=this.funcList.find(i=>i.name===e.name);if(s||(s=this.funcList.find(i=>n(i.name)===r)),!s)throw new Error(`Function not found: ${e.name}`);if(!s.func)throw new Error(`No handler for function: ${e.name}`);try{return await this.executeFunction(s,e,t)}catch(i){throw i instanceof Lr?new $r(i.getFields(),s,e.id):i}};execute=async(e,t)=>(await this.executeWithDetails(e,t)).formatted},tn=(o,e)=>{if(o.length===0)return[...e??[]];let t=o.map(n=>"toFunction"in n?n.toFunction():n).flat();for(let n of t.filter(r=>r.parameters))if(n.parameters)try{rs(n.parameters)}catch(r){throw r instanceof Error?new Error(`Function '${n.name}' parameters schema is invalid.
212
+ `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},Gr=class{funcList=[];constructor(e){this.funcList=e}executeFunction=async(e,t,n)=>{let r;if(typeof t.args=="string"&&t.args.length>0)try{r=JSON.parse(t.args)}catch(c){throw new Error(`Invalid function arguments: ${t.args}`,{cause:c})}else r=t.args;let s=n?{sessionId:n.sessionId,traceId:n.traceId,ai:n.ai,step:n.step,abortSignal:n.abortSignal}:void 0,i;e.parameters?i=e.func.length===2?await e.func(r,s):await e.func(r):i=e.func.length===1?await e.func(s):await e.func();let u=(n?.functionResultFormatter??ge.functionResultFormatter)(i);return{formatted:String(u),rawResult:i,parsedArgs:r}};executeWithDetails=async(e,t)=>{let n=i=>i.replace(/[^a-zA-Z0-9]/g,"").toLowerCase(),r=n(e.name),s=this.funcList.find(i=>i.name===e.name);if(s||(s=this.funcList.find(i=>n(i.name)===r)),!s)throw new Error(`Function not found: ${e.name}`);if(!s.func)throw new Error(`No handler for function: ${e.name}`);try{return await this.executeFunction(s,e,t)}catch(i){throw i instanceof Dr?new Ur(i.getFields(),s,e.id):i}};execute=async(e,t)=>(await this.executeWithDetails(e,t)).formatted},rn=(o,e)=>{if(o.length===0)return[...e??[]];let t=o.map(n=>"toFunction"in n?n.toFunction():n).flat();for(let n of t.filter(r=>r.parameters))if(n.parameters)try{as(n.parameters)}catch(r){throw r instanceof Error?new Error(`Function '${n.name}' parameters schema is invalid.
213
213
  ${r.message}
214
- Tip: Arrays must include an "items" schema (e.g., { items: { type: "string" } } or items: { type: "object", properties: { ... } }).`,{cause:r}):r}return[...e??[],...t]},os=async({ai:o,functionList:e,functionCalls:t,mem:n,sessionId:r,traceId:s,span:i,excludeContentFromTrace:a,index:l,functionResultFormatter:c,logger:u,debug:p,stopFunctionNames:d,step:m,abortSignal:g})=>{let f=new Dr(e),x=new Set,A=[],h=v=>{let k=S=>S.replace(/[^a-zA-Z0-9]/g,"").toLowerCase(),R=k(v),E=e.find(S=>S.name===v);return E||(E=e.find(S=>k(S.name)===R)),E},b=t.map(v=>{if(!v.id)throw new Error(`Function ${v.name} did not return an ID`);let k=o.getOptions().tracer??de.tracer;return k?k.startActiveSpan(`Tool: ${v.name}`,async R=>{try{R?.setAttributes?.({"tool.name":v.name,"tool.mode":"native","function.id":v.id,"session.id":r??""});let{formatted:E,rawResult:S,parsedArgs:_}=await f.executeWithDetails(v,{sessionId:r,ai:o,functionResultFormatter:c,traceId:R?.spanContext?.().traceId??s,stopFunctionNames:d,step:m,abortSignal:g});if(x.add(v.name.toLowerCase()),m?._recordFunctionCall(v.name,_,S),d?.includes(v.name.toLowerCase())){let L=h(v.name);L&&A.push({func:L,args:_,result:S})}if(a?R.addEvent("gen_ai.tool.message",{name:v.name}):R.addEvent("gen_ai.tool.message",{name:v.name,args:v.args,result:E??""}),i){let L={name:v.name};a||(L.args=v.args,L.result=E??""),i.addEvent("function.call",L)}return{result:E??"",role:"function",functionId:v.id,index:l}}catch(E){if(R?.recordException?.(E),E instanceof $r){let S=E.getFixingInstructions(),_={name:v.name,message:E.toString()};return a||(_.args=v.args,_.fixing_instructions=S),R?.addEvent?.("function.error",_),p&&ti(E,l,S,u),{functionId:v.id,isError:!0,index:l,result:S,role:"function"}}throw E}finally{R?.end?.()}}):f.executeWithDetails(v,{sessionId:r,ai:o,functionResultFormatter:c,traceId:s,stopFunctionNames:d,step:m,abortSignal:g}).then(({formatted:R,rawResult:E,parsedArgs:S})=>{if(x.add(v.name.toLowerCase()),m?._recordFunctionCall(v.name,S,E),d?.includes(v.name.toLowerCase())){let _=h(v.name);_&&A.push({func:_,args:S,result:E})}if(i){let _={name:v.name};a||(_.args=v.args,_.result=R??""),i.addEvent("function.call",_)}return{result:R??"",role:"function",functionId:v.id,index:l}}).catch(R=>{if(!(R instanceof $r))throw R;let E=R.getFixingInstructions();if(i){let S={name:v.name,message:R.toString()};a||(S.args=v.args,S.fixing_instructions=E),i.addEvent("function.error",S)}return p&&ti(R,l,E,u),{functionId:v.id,isError:!0,index:l,result:E,role:"function"}})}),C=(await Promise.all(b)).map(v=>v.result===void 0||v.result===""?{...v,result:"done"}:v);if(n.addFunctionResults(C,r),p){let v=C.filter(k=>!k.isError);v.length>0&&Za(v,u)}if(A.length>0)throw new en(A);return x};function Ki(o,e,t,n){if(!e||e.length===0)return;if(!o.getFeatures(n).functions)throw new Error("Functions are not supported by the AI service");return e.map(s=>({id:s.id,name:s.function.name,args:s.function.params}))}function Pc(o,e,t,n){let r=e;return!t&&(r==="required"||typeof r=="function")?{functions:[],functionCall:void 0}:o?{functions:o.map(i=>"toFunction"in i?i.toFunction():i).flat(),functionCall:r}:{functions:[],functionCall:r}}function dd(o){let e=0,t=!1,n=!1,r=!1,s=!1,i=[];for(let a=0;a<o.length;a++){let l=o[a];if(n){n=!1;continue}if(l==="\\"){n=!0;continue}if(l==='"'){t=!t;continue}t||(l==="{"?(i.push("{"),e++):l==="["?(i.push("["),e++):l==="}"?i.length>0&&i[i.length-1]==="{"&&(i.pop(),e--):l==="]"&&i.length>0&&i[i.length-1]==="["&&(i.pop(),e--))}if(i.length>0){let a=i[i.length-1];r=a==="[",s=a==="{"}return{nestingLevel:e,inString:t,inArray:r,inObject:s}}function Fc(o){if(!o.trim())return{parsed:null,partialMarker:null};try{return{parsed:JSON.parse(o),partialMarker:null}}catch{}let e=dd(o),t=md(o);try{return{parsed:JSON.parse(t),partialMarker:e}}catch{return{parsed:null,partialMarker:e}}}function md(o){let e=o.trim();for(e.endsWith(",")&&(e=e.slice(0,-1)),e.match(/,\s*"[^"]*"\s*:\s*$/)?e=e.replace(/,\s*"[^"]*"\s*:\s*$/,""):e.match(/\{\s*"[^"]*"\s*:\s*$/)&&(e=e.replace(/"[^"]*"\s*:\s*$/,""));e.match(/[0-9][eE.+-]$/)||e.match(/[eE][+-]$/);)e=e.slice(0,-1);e=e.replace(/,(\s*[}\]])/g,"$1"),e.match(/t(r(u(e)?)?)?$/)&&!e.endsWith('"')&&!e.endsWith("true")&&e.match(/[:[,]\s*t(r(u(e)?)?)?$/)&&(e=e.replace(/t(r(u(e)?)?)?$/,"true")),e.match(/f(a(l(s(e)?)?)?)?$/)&&!e.endsWith('"')&&!e.endsWith("false")&&e.match(/[:[,]\s*f(a(l(s(e)?)?)?)?$/)&&(e=e.replace(/f(a(l(s(e)?)?)?)?$/,"false")),e.match(/n(u(l(l)?)?)?$/)&&!e.endsWith('"')&&!e.endsWith("null")&&e.match(/[:[,]\s*n(u(l(l)?)?)?$/)&&(e=e.replace(/n(u(l(l)?)?)?$/,"null"));let t=[],n=!1,r=!1;for(let s=0;s<e.length;s++){let i=e[s];if(r){r=!1;continue}if(i==="\\"){r=!0;continue}if(i==='"'){n=!n;continue}n||(i==="{"?t.push("}"):i==="["?t.push("]"):i==="}"?t.length>0&&t[t.length-1]==="}"&&t.pop():i==="]"&&t.length>0&&t[t.length-1]==="]"&&t.pop())}for(r&&(e=e.slice(0,-1)),n&&(e+='"'),t.length>0&&t[t.length-1]==="}"&&e.match(/,\s*"[^"]*"\s*$/)&&(e=e.replace(/,\s*"[^"]*"\s*$/,""));t.length>0;)e+=t.pop();return e}async function*_c({res:o,usage:e,states:t,debug:n,stepContext:r,...s}){let i=(s.ai.getFeatures().functionCot??!1)&&s.functions!==void 0&&s.functions.length>0,a,l=[],c=o.getReader();try{for(;;){let{done:u,value:p}=await c.read();if(u)break;let d=p;d.modelUsage&&(a=d.modelUsage);for(let m of d.results){if(Array.isArray(m.citations))for(let f of m.citations)f?.url&&l.push({url:f.url,title:f.title,description:f.description,license:f.license,publicationDate:f.publicationDate,snippet:f.snippet});if((!m.content||m.content==="")&&(!m.thought||m.thought==="")&&(!m.thoughtBlocks||m.thoughtBlocks.length===0)&&(!m.functionCalls||m.functionCalls.length===0))continue;let g=t.find(f=>f.index===m.index);if(!g)throw new Error(`No state found for result (index: ${m.index})`);yield*gd({...s,result:m,skipEarlyFail:i,state:g,debug:n})}}}finally{c.releaseLock()}for(let u of t)yield*fd({...s,state:u,debug:n,stepContext:r});if(a){if(l.length){let u=Array.from(new Map(l.filter(p=>p.url).map(p=>[p.url,p])).values());a.citations=u}if(e.push(a),n&&s.logger){let u=structuredClone(a);delete u.citations,s.logger({name:"ChatResponseUsage",value:u}),a.citations&&a.citations.length>0&&s.logger({name:"ChatResponseCitations",value:a.citations})}}}async function*gd({result:o,mem:e,sessionId:t,strictMode:n,skipEarlyFail:r,treatAllFieldsOptional:s,state:i,signature:a,streamingFieldProcessors:l,thoughtFieldName:c,streamingAsserts:u,asserts:p}){if(o.functionCalls&&o.functionCalls.length>0)po(i.functionCalls,o.functionCalls),e.updateResult({name:o.name,content:o.content,functionCalls:i.functionCalls,thoughtBlocks:o.thoughtBlocks,delta:o.functionCalls?.[0]?.function?.params,index:o.index},t);else if(o.content&&o.content.length>0){o.thought&&o.thought.length>0&&(yield{index:o.index,delta:{[c]:o.thought}}),i.content+=o.content,e.updateResult({name:o.name,content:i.content,thoughtBlocks:o.thoughtBlocks,delta:o.content,index:o.index},t);let d=a.getOutputFields();if(a.hasComplexFields()){let{parsed:f,partialMarker:x}=Fc(i.content);if(f&&typeof f=="object"){let A={},h={};for(let b of Object.keys(f))if(d.some(T=>T.name===b)){let T=f[b],C=i.values[b];if(Array.isArray(T)&&T.length>0&&hd(T,x)&&(T=T.slice(0,-1)),h[b]=T,typeof T=="string"&&typeof C=="string"&&T.startsWith(C)){let v=T.slice(C.length);v&&(A[b]=v)}else Array.isArray(T)&&Array.isArray(C)?T.length>C.length&&(A[b]=T.slice(C.length)):JSON.stringify(T)!==JSON.stringify(C)&&(Array.isArray(T)||(A[b]=T))}try{Un(a,h,{allowMissingRequired:!0})}catch{}Object.assign(i.values,h),Object.keys(A).length>0&&(yield{index:o.index,delta:A});return}}if(ji(a,i.values,i.xstate,i.content,{strictMode:n,skipEarlyFail:r,treatAllFieldsOptional:s}))return;u.length!==0&&await Mi(u,i.xstate,i.content),l.length!==0&&await Hi(l,i.content,i.xstate,e,i.values,t),yield*qi(a,i.content,i.values,i.xstate,o.index),await Ln(p,i.values)}else o.thought&&o.thought.length>0?(i.values[c]=(i.values[c]??"")+o.thought,yield{index:o.index,delta:{[c]:o.thought}},e.updateResult({name:o.name,content:i.content,delta:"",index:o.index,thought:o.thought,thoughtBlocks:o.thoughtBlocks},t)):o.thoughtBlocks&&o.thoughtBlocks.length>0&&e.updateResult({name:o.name,content:i.content,delta:"",index:o.index,thoughtBlocks:o.thoughtBlocks},t);if(o.finishReason==="length")throw new Error(`Max tokens reached before completion
215
- Content: ${i.content}`)}async function*fd({state:o,signature:e,ai:t,model:n,functions:r,mem:s,sessionId:i,traceId:a,span:l,strictMode:c,excludeContentFromTrace:u,streamingAsserts:p,asserts:d,fieldProcessors:m,streamingFieldProcessors:g,functionResultFormatter:f,signatureToolCallingManager:x,logger:A,debug:h,stopFunctionNames:b,stepContext:T,abortSignal:C}){let v=x?void 0:Ki(t,o.functionCalls,o.values,n);if(v){if(!r)throw new Error("Functions are not defined");let k=await os({ai:t,functionList:r,functionCalls:v,mem:s,sessionId:i,traceId:a,span:l,index:o.index,excludeContentFromTrace:u,functionResultFormatter:f,logger:A,debug:h,stopFunctionNames:b,step:T,abortSignal:C});o.functionsExecuted=new Set([...o.functionsExecuted,...k]),o.functionCalls=[]}else{let k=e.getOutputFields(),R=e.hasComplexFields(),E=!1;if(R)try{let S=JSON.parse(o.content),_={};for(let L of Object.keys(S))if(k.some(P=>P.name===L)){let P=S[L],F=o.values[L];if(typeof P=="string"&&typeof F=="string"&&P.startsWith(F)){let N=P.slice(F.length);N&&(_[L]=N)}else Array.isArray(P)&&Array.isArray(F)?P.length>F.length&&(_[L]=P.slice(F.length)):JSON.stringify(P)!==JSON.stringify(F)&&(Array.isArray(P)||(_[L]=P))}try{Un(e,_,{allowMissingRequired:!0})}catch(L){let P=(L.message||"").toLowerCase();if(P.includes("at least")||P.includes("at most")||P.includes("must match pattern")||P.includes("invalid url")||P.includes("required")||P.includes("missing")||P.includes("valid email")||P.includes("number must be"))throw L}for(let L of Object.keys(S))k.some(P=>P.name===L)&&(o.values[L]=S[L]);yield{index:o.index,delta:_},E=!0}catch(S){let _=(S.message||"").toLowerCase();if(_.includes("at least")||_.includes("at most")||_.includes("must match pattern")||_.includes("invalid url")||_.includes("required")||_.includes("missing")||_.includes("valid email")||_.includes("number must be"))throw S}if(!E){let S=x!==void 0;zi(e,o.values,o.xstate,o.content,{strictMode:c,treatAllFieldsOptional:S,deferRequiredCheckForStreaming:!0,forceFinalize:!0})}if(x){let S=await x.processResults(o.values);if(S&&S.length>0){if(!r)throw new Error("Functions are not defined");let _=await os({ai:t,functionList:r,functionCalls:S,mem:s,sessionId:i,traceId:a,span:l,index:o.index,excludeContentFromTrace:u,functionResultFormatter:f,logger:A,debug:h,stopFunctionNames:b,step:T,abortSignal:C});o.functionsExecuted=new Set([...o.functionsExecuted,..._]),s.updateResult({name:void 0,content:o.content,functionCalls:S.map(L=>({id:L.id,type:"function",function:{name:L.name,params:L.args}})),index:o.index},i);return}}await Mi(p,o.xstate,o.content,!0),await Ln(d,o.values),m.length&&await Nr(m,o.values,s,i),g.length!==0&&await Hi(g,o.content,o.xstate,s,o.values,i,!0),yield*qi(e,o.content,o.values,o.xstate,o.index)}}async function*Nc({ai:o,res:e,mem:t,sessionId:n,traceId:r,functions:s,span:i,strictMode:a,states:l,usage:c,excludeContentFromTrace:u,asserts:p,fieldProcessors:d,thoughtFieldName:m,signature:g,functionResultFormatter:f,logger:x,debug:A,signatureToolCallingManager:h,stopFunctionNames:b,disableMemoryCleanup:T,stepContext:C,abortSignal:v}){let k=e.results??[],R=h!==void 0;t.addResponse(k,n);let E=[];for(let P of k)if(Array.isArray(P?.citations))for(let F of P.citations)F?.url&&E.push({url:F.url,title:F.title,description:F.description,license:F.license,publicationDate:F.publicationDate,snippet:F.snippet});for(let P of k){let F=l[P.index];if(!F)throw new Error(`No state found for result (index: ${P.index})`);if(e.modelUsage){let N=Array.from(new Map(E.filter(G=>G.url).map(G=>[G.url,G])).values()),U={...e.modelUsage,...N.length?{citations:N}:{}};if(c.push(U),A&&x){let G=structuredClone(U);delete G.citations,x({name:"ChatResponseUsage",value:G}),U.citations&&U.citations.length>0&&x({name:"ChatResponseCitations",value:U.citations})}}if(h&&P.content){P.thought&&P.thought.length>0&&(F.values[m]=P.thought),ts(g,F.values,P.content,{strictMode:a,treatAllFieldsOptional:R});let U=(await h.processResults(F.values))?.map(G=>({id:G.id,type:"function",function:{name:G.name,params:G.args}}));U&&U.length>0&&t.updateResult({name:P.name,content:P.content,functionCalls:U,index:P.index},n)}if(P.functionCalls?.length){let N=Ki(o,P.functionCalls,F.values);if(N&&N.length>0){if(!s)throw new Error("Functions are not defined");let U;try{U=await os({ai:o,functionList:s,functionCalls:N,mem:t,sessionId:n,traceId:r,span:i,excludeContentFromTrace:u,index:P.index,functionResultFormatter:f,logger:x,debug:A,stopFunctionNames:b,step:C,abortSignal:v})}catch(G){throw t.addRequest([{role:"user",content:"The previous tool call failed. Fix arguments and try again, ensuring required fields match schema."}],n),t.addTag("correction",n),G}F.functionsExecuted=new Set([...F.functionsExecuted,...U])}}else if(P.content){P.thought&&P.thought.length>0&&(F.values[m]=P.thought);let N=g.getOutputFields();if(g.hasComplexFields())try{let G=JSON.parse(P.content),B={};for(let te of Object.keys(G))N.some(j=>j.name===te)&&(B[te]=G[te]);Un(g,B),Object.assign(F.values,B)}catch(G){let B=G instanceof SyntaxError;if((G.name?.includes("ValidationError")||G.name?.includes("Error"))&&!B){let j=(G.message||"").toLowerCase();if(j.includes("at least")||j.includes("at most")||j.includes("must match pattern")||j.includes("invalid url")||j.includes("required")||j.includes("missing")||j.includes("valid email")||j.includes("number must be"))throw G}if(B)ts(g,F.values,P.content,{strictMode:a,treatAllFieldsOptional:R});else throw G}else ts(g,F.values,P.content,{strictMode:a,treatAllFieldsOptional:R})}if(await Ln(p,F.values),T||(t.removeByTag("correction",n),t.removeByTag("error",n)),d.length&&await Nr(d,F.values,t,n),P.finishReason==="length")throw new Error(`Max tokens reached before completion
216
- Content: ${P.content}`)}let S=l.map(P=>P.values);for(let P of S)for(let F of g.getOutputFields())F.isInternal&&delete P[F.name];let _=g.getOutputFields(),L=S.map((P,F)=>{let N={};for(let U of _)U.isInternal||(N[U.name]=P[U.name]);return P[m]!==void 0&&(N[m]=P[m]),{index:F,delta:N}});for(let P of L)yield P}function hd(o,e){return e?!!(e.nestingLevel>0||e.inArray||e.inObject):!1}function Lc(o,e,t,n){let r=o.getLast(n);if(!r)return!0;for(let[s,i]of t.entries()){let a=e?Array.from(e).some(p=>i.functionsExecuted.has(p)):!1;if(!r.chat[s])throw new Error(`No chat message found for result (index: ${s})`);let c=r.role==="function",u=r.tags?r.tags.some(p=>p==="processor"):!1;if(c&&e&&a||!(c||u))return!1}return!0}var xd=["none","minimal","low","medium","high","highest"];function Wi(o,e,t){let n={};if(e.model!==!1){let a=o.getModelList();if(a&&a.length>0){let l=a.filter(c=>"model"in c);if(l.length>0){let c=l.map(p=>p.key),u=l.map(p=>`${p.key} (${p.description})`);n.model={type:"string",enum:c,description:`${t&&c.includes(t)?`Currently using model: ${t}. `:""}Switch model for the next step. Prefer faster/cheaper models for simple tasks; use more capable models for complex reasoning, math, or multi-step analysis. Available: ${u.join(", ")}`}}}}e.thinkingBudget!==!1&&(n.thinkingBudget={type:"string",enum:[...xd],description:"Reasoning depth for the next step. none/minimal: simple lookups or reformatting. low/medium: moderate analysis, summarization. high/highest: math, logic, code analysis, or multi-step reasoning. Higher budgets use more tokens."}),e.temperature&&(n.temperature={type:"number",description:"Sampling temperature for the next step. Lower values (0\u20130.3) for deterministic tasks like math or code; higher values (0.7\u20131.0) for creative or exploratory tasks."});let r;if(e.functions&&e.functions.length>0){r=tn(e.functions);let a=r.map(c=>c.name),l=r.map(c=>`${c.name} (${c.description})`);n.addFunctions={type:"array",items:{type:"string",enum:a},description:`Activate tools you need for the current sub-task. Only add what you will use immediately \u2014 fewer active tools means less noise. Available: ${l.join(", ")}`},n.removeFunctions={type:"array",items:{type:"string",enum:a},description:"Remove tools you are done with to reduce context size and maintain focus on remaining work."}}let s=r;return{name:"adjustGeneration",description:"Adjust model, reasoning depth, or active tools for the next step. Call when task complexity changes \u2014 upgrade for hard reasoning or analysis, downgrade for simple follow-ups. Only call when there is a clear reason to change.",parameters:Object.keys(n).length>0?{type:"object",properties:n}:void 0,func:(a,l)=>{let c=l?.step;if(!c)return"Generation parameters adjusted for next response.";if(a?.model&&c.setModel(a.model),a?.thinkingBudget&&c.setThinkingBudget(a.thinkingBudget),a?.temperature!==void 0&&c.setTemperature(a.temperature),a?.addFunctions?.length&&s){let u=s.filter(p=>a.addFunctions.includes(p.name));u.length>0&&c.addFunctions(u)}return a?.removeFunctions?.length&&c.removeFunctions(...a.removeFunctions),"Generation parameters adjusted for next response."}}}var Gn=class{reg;constructor(){this.reg=new Set}register(e){this.reg.add(e)}*[Symbol.iterator](){let e=Array.from(this.reg);for(let t=0;t<e.length;t++)yield e[t]}};var me=class extends Error{constructor(t,n,r,s){super(t);this.position=n;this.context=r;this.suggestion=s;this.name="SignatureValidationError"}},Vi=class{input;position;currentFieldName=null;currentSection="description";constructor(e){if(this.input=e.trim(),this.position=0,!this.input)throw new me("Empty signature provided",0,"",'A signature must contain at least input and output fields separated by "->". Example: "userQuery:string -> aiResponse:string"')}parse(){try{this.skipWhitespace();let e=this.parseParsedString();this.skipWhitespace(),this.currentSection="inputs";let t=this.parseFieldList(this.parseInputField.bind(this),"input");if(this.skipWhitespace(),this.position>=this.input.length)throw new me("Incomplete signature: Missing output section",this.position,this.getErrorContext(),'Add "->" followed by output fields. Example: "-> responseText:string"');if(this.expectArrow(),this.skipWhitespace(),this.position>=this.input.length)throw new me('Incomplete signature: No output fields specified after "->"',this.position,this.getErrorContext(),'Add at least one output field. Example: "-> responseText:string"');this.currentSection="outputs";let n=this.parseFieldList(this.parseOutputField.bind(this),"output");if(this.skipWhitespace(),this.position<this.input.length){let r=this.input.slice(this.position);throw new me(`Unexpected content after signature: "${r}"`,this.position,this.getErrorContext(),"Remove any extra content after the output fields")}return this.validateParsedSignature({desc:e?.trim(),inputs:t,outputs:n}),{desc:e?.trim(),inputs:t,outputs:n}}catch(e){if(e instanceof me)throw e;let t=e instanceof Error?e.message:"Unknown error";throw new me(t,this.position,this.getErrorContext())}}validateParsedSignature(e){let t=new Set;for(let r of e.inputs){if(t.has(r.name))throw new me(`Duplicate input field name: "${r.name}"`,0,"","Each field name must be unique within the signature");t.add(r.name)}let n=new Set;for(let r of e.outputs){if(n.has(r.name))throw new me(`Duplicate output field name: "${r.name}"`,0,"","Each field name must be unique within the signature");n.add(r.name)}for(let r of e.outputs)if(t.has(r.name))throw new me(`Field name "${r.name}" appears in both inputs and outputs`,0,"","Use different names for input and output fields to avoid confusion");if(e.inputs.length===0)throw new me("Signature must have at least one input field",0,"",'Add an input field before "->". Example: "userInput:string -> ..."');if(e.outputs.length===0)throw new me("Signature must have at least one output field",0,"",'Add an output field after "->". Example: "... -> responseText:string"')}getErrorContext(){let e=Math.max(0,this.position-25),t=Math.min(this.input.length,this.position+25),n=this.input.slice(e,this.position),r=this.input.slice(this.position,t),s=`${" ".repeat(n.length)}^`;return[`Position ${this.position} in signature:`,`"${n}${r}"`,` ${s}`].join(`
217
- `)}parseFieldList(e,t){let n=[];if(this.skipWhitespace(),this.position>=this.input.length)throw new me(`Empty ${t} section: Expected at least one field`,this.position,this.getErrorContext(),`Add a ${t} field. Example: ${t==="input"?"userInput:string":"responseText:string"}`);try{n.push(e())}catch(r){throw r instanceof me?r:new me(`Invalid first ${t} field: ${r instanceof Error?r.message:"Unknown error"}`,this.position,this.getErrorContext())}for(this.skipWhitespace();this.position<this.input.length&&!(this.input[this.position]==="-"&&this.position+1<this.input.length&&this.input[this.position+1]===">");)if(this.match(",")){if(this.skipWhitespace(),this.position>=this.input.length)throw new me(`Unexpected end of input after comma in ${t} section`,this.position,this.getErrorContext(),`Add another ${t} field after the comma`);try{n.push(e())}catch(r){throw r instanceof me?r:new me(`Invalid ${t} field after comma: ${r instanceof Error?r.message:"Unknown error"}`,this.position,this.getErrorContext())}this.skipWhitespace()}else break;return n}parseInputField(){this.skipWhitespace();let e=this.parseParsedIdentifier();this.currentFieldName=e,this.validateFieldName(e,"input");let t;for(;;){if(this.match("?")){t=!0;continue}if(this.match("!"))throw new me(`Input field "${e}" cannot use the internal marker "!"`,this.position-1,this.getErrorContext(),"Internal markers (!) are only allowed on output fields");break}let n;if(this.skipWhitespace(),this.match(":")){if(this.skipWhitespace(),/^class\b/.test(this.input.slice(this.position)))throw new me(`Input field "${e}" cannot use the "class" type`,this.position,this.getErrorContext(),'Class types are only allowed on output fields. Use "string" type for input classifications');try{let s=this.parseTypeNotClass(),i=this.match("[]");n={name:s,isArray:i}}catch(s){throw s instanceof me?s:new me(`Input field "${e}": ${s instanceof Error?s.message:"Unknown error"}`,this.position,this.getErrorContext())}}this.skipWhitespace();let r=this.parseParsedString();return{name:e,desc:r?.trim(),type:n,isOptional:t}}parseOutputField(){this.skipWhitespace();let e=this.parseParsedIdentifier();this.currentFieldName=e,this.validateFieldName(e,"output");let t=!1,n=!1;for(;;){if(this.match("?")){t=!0;continue}if(this.match("!")){n=!0;continue}break}let r;if(this.skipWhitespace(),this.match(":"))if(this.skipWhitespace(),this.match("class")){let i=this.match("[]");this.skipWhitespace();let a=this.parseParsedString();if(!a)throw new me(`Output field "${e}": Missing class options after "class" type`,this.position,this.getErrorContext(),'Add class names in quotes. Example: class "positive, negative, neutral"');let l=a.split(/[,|]/).map(c=>c.trim()).filter(c=>c.length>0);if(l.length===0)throw new me(`Output field "${e}": Empty class list provided`,this.position,this.getErrorContext(),'Provide at least one class option. Example: "positive, negative"');r={name:"class",isArray:i,options:l}}else try{let i=this.parseTypeNotClass(),a=this.match("[]");if(r={name:i,isArray:a},i==="image"&&a)throw new me(`Output field "${e}": Arrays of images are not supported`,this.position,this.getErrorContext(),'Use a single image type instead: "image"');if(i==="audio"&&a)throw new me(`Output field "${e}": Arrays of audio are not supported`,this.position,this.getErrorContext(),'Use a single audio type instead: "audio"');if(i==="image")throw new me(`Output field "${e}": Image type is not supported in output fields`,this.position,this.getErrorContext(),"Image types can only be used in input fields");if(i==="audio")throw new me(`Output field "${e}": Audio type is not supported in output fields`,this.position,this.getErrorContext(),"Audio types can only be used in input fields")}catch(i){throw i instanceof me?i:new me(`Output field "${e}": ${i instanceof Error?i.message:"Unknown error"}`,this.position,this.getErrorContext())}this.skipWhitespace();let s=this.parseParsedString();return{name:e,desc:s?.trim(),type:r,isOptional:t,isInternal:n}}validateFieldName(e,t){if(de.signatureStrict&&["text","object","image","string","number","boolean","json","array","datetime","date","time","type","class","input","output","data","value","result","response","request","item","element"].includes(e.toLowerCase())){let i=t==="input"?["userInput","questionText","documentContent","messageText"]:["responseText","analysisResult","categoryType","summaryText"];throw new me(`Field name "${e}" is too generic`,this.position,this.getErrorContext(),`Use a more descriptive name. Examples: ${i.join(", ")}`)}let n=/^[a-z][a-zA-Z0-9]*$/,r=/^[a-z]+(_[a-z0-9]+)*$/;if(!n.test(e)&&!r.test(e))throw new me(`Invalid field name "${e}"`,this.position,this.getErrorContext(),'Field names must be in camelCase (e.g., "userInput") or snake_case (e.g., "user_input")');if(e.length<2)throw new me(`Field name "${e}" is too short`,this.position,this.getErrorContext(),"Field names must be at least 2 characters long");if(e.length>50)throw new me(`Field name "${e}" is too long (${e.length} characters)`,this.position,this.getErrorContext(),"Field names should be 50 characters or less")}parseTypeNotClass(){let e=["string","number","boolean","json","image","audio","file","url","datetime","date","code","object"],t=e.find(n=>this.match(n));if(!t){let n=this.input.slice(this.position).match(/^\w+/)?.[0]||"",r=this.suggestType(n),s=`Invalid type "${n||"empty"}"`,i=r?`. Did you mean "${r}"?`:"",a=`${s}${i}`;throw new me(a,this.position,this.getErrorContext(),`Expected one of: ${e.join(", ")}`)}return t}suggestType(e){return{str:"string",text:"string",int:"number",integer:"number",float:"number",double:"number",bool:"boolean",object:"json",dict:"json",timestamp:"datetime",time:"datetime",img:"image",picture:"image",sound:"audio",voice:"audio",classification:"class",category:"class"}[e.toLowerCase()]||null}parseParsedIdentifier(){this.skipWhitespace();let e=/^[a-zA-Z_][a-zA-Z_0-9]*/.exec(this.input.slice(this.position));if(e)return this.position+=e[0].length,e[0];let t=/^\S+/.exec(this.input.slice(this.position)),n=t?t[0]:"";throw n===""?new me("Expected field name but found end of input",this.position,this.getErrorContext(),"Add a field name. Field names must start with a letter or underscore"):/^\d/.test(n)?new me(`Invalid field name "${n}" - cannot start with a number`,this.position,this.getErrorContext(),'Field names must start with a letter or underscore. Example: "userInput" or "_internal"'):new me(`Invalid field name "${n}"`,this.position,this.getErrorContext(),"Field names must start with a letter or underscore and contain only letters, numbers, or underscores")}parseParsedString(){let e=["'",'"'];for(let t of e)if(this.match(t)){let n="",r=!1,s=this.position-1;for(;this.position<this.input.length;){let a=this.input[this.position];if(this.position++,r)n+=a,r=!1;else if(a==="\\")r=!0;else{if(a===t)return n;n+=a}}let i=this.input.slice(s,Math.min(this.position,s+20));throw new me(`Unterminated string starting at position ${s}`,s,this.getErrorContext(),`Add closing ${t} to complete the string: ${i}${t}`)}}skipWhitespace(){let e=/^[\s\t\r\n]+/.exec(this.input.slice(this.position));e&&(this.position+=e[0].length)}match(e){let t;if(typeof e=="string"){if(this.input.startsWith(e,this.position))return this.position+=e.length,!0}else if(t=e.exec(this.input.slice(this.position)),t)return this.position+=t[0].length,!0;return!1}expectArrow(){if(!this.match("->")){let e=this.input.slice(this.position,this.position+10),t=e.includes(">")?'Use "->" (dash followed by greater-than)':e.includes("-")?'Add ">" after the dash':'Add "->" to separate input and output fields';throw new me(`Expected "->" but found "${e}..."`,this.position,this.getErrorContext(),t)}}};function $c(o){return new Vi(o).parse()}var Ur=class{inputFields=[];outputFields=[];desc;input(e,t,n=!1){let r={name:e,type:{name:t.type,isArray:t.isArray||void 0,options:t.options?[...t.options]:void 0,minLength:t.minLength,maxLength:t.maxLength,minimum:t.minimum,maximum:t.maximum,pattern:t.pattern,patternDescription:t.patternDescription,format:t.format,description:t.itemDescription,fields:t.fields?Object.fromEntries(Object.entries(t.fields).map(([s,i])=>[s,is(i)])):void 0},description:t.description,isOptional:t.isOptional||void 0,isInternal:t.isInternal||void 0,isCached:t.isCached||void 0};return n?this.inputFields.unshift(r):this.inputFields.push(r),this}output(e,t,n=!1){let r={name:e,type:{name:t.type,isArray:t.isArray||void 0,options:t.options?[...t.options]:void 0,minLength:t.minLength,maxLength:t.maxLength,minimum:t.minimum,maximum:t.maximum,pattern:t.pattern,patternDescription:t.patternDescription,format:t.format,description:t.itemDescription,fields:t.fields?Object.fromEntries(Object.entries(t.fields).map(([s,i])=>[s,is(i)])):void 0},description:t.description,isOptional:t.isOptional||void 0,isInternal:t.isInternal||void 0};return n?this.outputFields.unshift(r):this.outputFields.push(r),this}addInputFields(e){for(let t of e)this.inputFields.push(t);return this}addOutputFields(e){for(let t of e)this.outputFields.push(t);return this}description(e){return this.desc=e,this}useStructured(){return this._useStructuredOutputs=!0,this}build(){let e={description:this.desc,inputs:this.inputFields,outputs:this.outputFields},t=new Ne(e);return this._useStructuredOutputs&&(t._forceComplexFields=!0,t._hasComplexFields=void 0),t}},Ke=class o{type;isArray;options;description;isOptional;isInternal;isCached;fields;minLength;maxLength;minimum;maximum;pattern;patternDescription;format;itemDescription;constructor(e){this.type=e.type,this.isArray=e.isArray,this.options=e.options,this.description=e.description,this.itemDescription=e.itemDescription,this.isOptional=e.isOptional,this.isInternal=e.isInternal,this.isCached=e.isCached,this.fields=e.fields,this.minLength=e.minLength,this.maxLength=e.maxLength,this.minimum=e.minimum,this.maximum=e.maximum,this.pattern=e.pattern,this.patternDescription=e.patternDescription,this.format=e.format}optional(){return new o({...this,isOptional:!0})}array(e){return new o({...this,isArray:!0,description:e||this.description,itemDescription:e?this.description:void 0})}internal(){return new o({...this,isInternal:!0})}cache(){return new o({...this,isCached:!0})}min(e){return this.type==="string"?new o({...this,minLength:e}):this.type==="number"?new o({...this,minimum:e}):this}max(e){return this.type==="string"?new o({...this,maxLength:e}):this.type==="number"?new o({...this,maximum:e}):this}email(){return this.type==="string"?new o({...this,format:"email"}):this}url(){return this.type==="string"?new o({...this,format:"uri"}):this}regex(e,t){return this.type==="string"?new o({...this,pattern:e,patternDescription:t}):this}date(){return this.type==="string"?new o({...this,format:"date"}):this}datetime(){return this.type==="string"?new o({...this,format:"date-time"}):this}},ue=Object.assign(()=>new Ur,{string:o=>new Ke({type:"string",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),number:o=>new Ke({type:"number",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),boolean:o=>new Ke({type:"boolean",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),json:o=>new Ke({type:"json",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),datetime:o=>new Ke({type:"datetime",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),date:o=>new Ke({type:"date",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),class:(o,e)=>new Ke({type:"class",isArray:!1,options:o,description:e,isOptional:!1,isInternal:!1,isCached:!1}),image:o=>new Ke({type:"image",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),audio:o=>new Ke({type:"audio",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),file:o=>new Ke({type:"file",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),url:o=>new Ke({type:"url",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),email:o=>new Ke({type:"string",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1,format:"email"}),code:(o,e)=>new Ke({type:"code",isArray:!1,description:e||o,isOptional:!1,isInternal:!1,isCached:!1}),object:(o,e)=>new Ke({type:"object",isArray:!1,fields:o,description:e,isOptional:!1,isInternal:!1,isCached:!1})});function is(o){return{type:o.type,isArray:o.isArray,options:o.options,description:o.description,isOptional:o.isOptional,isInternal:o.isInternal,minLength:o.minLength,maxLength:o.maxLength,minimum:o.minimum,maximum:o.maximum,pattern:o.pattern,patternDescription:o.patternDescription,format:o.format,fields:o.fields?Object.fromEntries(Object.entries(o.fields).map(([e,t])=>[e,is(t)])):void 0}}function ss(o){return{type:{name:o.type,isArray:o.isArray,options:o.options?[...o.options]:void 0,fields:o.fields},description:o.description,isOptional:o.isOptional,isInternal:o.isInternal}}function Ji(o,e){return{name:o,type:{name:e.type,isArray:e.isArray||void 0,options:e.options?[...e.options]:void 0,minLength:e.minLength,maxLength:e.maxLength,minimum:e.minimum,maximum:e.maximum,pattern:e.pattern,patternDescription:e.patternDescription,format:e.format,description:e.itemDescription,fields:e.fields?Object.fromEntries(Object.entries(e.fields).map(([t,n])=>[t,is(n)])):void 0},description:e.description,isOptional:e.isOptional||void 0,isInternal:e.isInternal||void 0,isCached:e.isCached||void 0}}function Dc(o){return o.length===0?{type:"object",properties:{}}:zt(o,"Schema")}function Ad(o){let e=Ji("__value",o);return zt([e],"Schema").properties?.__value??{type:"json"}}var Qi=class{name;desc;ns;argFields=[];returnFields=[];returnFieldType;returnMode;fnHandler;fnExamples=[];constructor(e){this.name=e}description(e){return this.desc=e,this}namespace(e){return this.ns=e,this}arg(e,t){return this.argFields.push(Ji(e,t)),this}args(e,t){return this.arg(e,t)}returns(e){if(this.returnMode==="fields")throw new Error("Cannot use fn().returns(...) after fn().returnsField(...); choose exactly one return schema style");return this.returnMode="single",this.returnFieldType=e,this}returnsField(e,t){if(this.returnMode==="single")throw new Error("Cannot use fn().returnsField(...) after fn().returns(...); choose exactly one return schema style");return this.returnMode="fields",this.returnFields.push(Ji(e,t)),this}example(e){return this.fnExamples.push(e),this}examples(e){return this.fnExamples.push(...e),this}handler(e){return this.fnHandler=e,this}build(){let e=this.name.trim(),t=this.desc?.trim(),n=this.ns?.trim();if(!e)throw new Error("fn() requires a non-empty function name");if(!t)throw new Error(`Function "${e}" must define a non-empty description`);if(!this.fnHandler)throw new Error(`Function "${e}" must define a handler`);if(this.fnExamples.some(s=>!s.code.trim()))throw new Error(`Function "${e}" examples must define non-empty code`);return{name:e,description:t,...n?{namespace:n}:{},parameters:Dc(this.argFields),...this.returnMode==="single"&&this.returnFieldType?{returns:Ad(this.returnFieldType)}:this.returnMode==="fields"?{returns:Dc(this.returnFields)}:{},...this.fnExamples.length>0?{examples:this.fnExamples.map(s=>({...s}))}:{},func:this.fnHandler}}},Bc=o=>new Qi(o),re=class extends Error{constructor(t,n,r){super(t);this.fieldName=n;this.suggestion=r;this.name="AxSignatureValidationError"}},Ne=class o{description;inputFields;outputFields;sigHash;sigString;validatedAtHash;constructor(e){if(!e){this.inputFields=[],this.outputFields=[],this.sigHash="",this.sigString="";return}if(typeof e=="string"){let t;try{t=$c(e)}catch(n){if(n instanceof Error){let r="suggestion"in n&&typeof n.suggestion=="string"?n.suggestion:'Please check the signature format. Example: "userInput:string -> responseText:string"';throw new re(`Invalid Signature: ${n.message}`,void 0,r)}throw new re(`Invalid Signature: ${e}`,void 0,'Please check the signature format. Example: "userInput:string -> responseText:string"')}this.description=t.desc,this.inputFields=t.inputs.map(n=>this.parseParsedField(n)),this.outputFields=t.outputs.map(n=>this.parseParsedField(n)),[this.sigHash,this.sigString]=this.updateHash()}else if(e instanceof o)this.description=e.getDescription(),this.inputFields=structuredClone(e.getInputFields()),this.outputFields=structuredClone(e.getOutputFields()),this.sigHash=e.hash(),this.sigString=e.toString(),e.validatedAtHash===this.sigHash&&(this.validatedAtHash=this.sigHash),this._forceComplexFields=e._forceComplexFields,this._hasComplexFields=e._hasComplexFields;else if(typeof e=="object"&&e!==null){if(!("inputs"in e)||!("outputs"in e))throw new re("Invalid signature object: missing inputs or outputs",void 0,'Signature object must have "inputs" and "outputs" arrays. Example: { inputs: [...], outputs: [...] }');if(!Array.isArray(e.inputs)||!Array.isArray(e.outputs))throw new re("Invalid signature object: inputs and outputs must be arrays",void 0,'Both "inputs" and "outputs" must be arrays of AxField objects');try{this.description=e.description,this.inputFields=e.inputs.map(t=>this.parseField(t)),this.outputFields=e.outputs.map(t=>this.parseField(t)),[this.sigHash,this.sigString]=this.updateHash()}catch(t){throw t instanceof re?t:new re(`Failed to create signature from object: ${t instanceof Error?t.message:"Unknown error"}`,void 0,"Check that all fields in inputs and outputs arrays are valid AxField objects")}}else throw new re("Invalid signature argument type",void 0,"Signature must be a string, another AxSignature instance, or an object with inputs and outputs arrays")}static create(e){return new o(e)}parseParsedField=e=>{if(!e.name||e.name.length===0)throw new re("Field name is required",e.name,'Every field must have a descriptive name. Example: "userInput", "responseText"');let t=this.toTitle(e.name);return{name:e.name,title:t,description:"desc"in e?e.desc:void 0,type:e.type??{name:"string",isArray:!1},..."isInternal"in e?{isInternal:e.isInternal}:{},..."isOptional"in e?{isOptional:e.isOptional}:{}}};parseField=e=>{let t=!e.title||e.title.length===0?this.toTitle(e.name):e.title;if(e.type&&(!e.type.name||e.type.name.length===0))throw new re("Field type name is required",e.name,"Specify a valid type. Available types: string, number, boolean, json, image, audio, file, url, date, datetime, class, code");return{...e,title:t}};setDescription=e=>{if(typeof e!="string")throw new re("Description must be a string",void 0,"Provide a string description for the signature");this.description=e,this.invalidateValidationCache(),this.updateHashLight()};addInputField=e=>{try{let t=this.parseField(e);Mt(t,"input");for(let n of this.inputFields)if(n.name===t.name)throw new re(`Duplicate input field name: "${t.name}"`,t.name,"Each field name must be unique within the signature");for(let n of this.outputFields)if(n.name===t.name)throw new re(`Field name "${t.name}" appears in both inputs and outputs`,t.name,"Use different names for input and output fields to avoid confusion");this.inputFields.push(t),this.invalidateValidationCache(),this.updateHashLight()}catch(t){throw t instanceof re?t:new re(`Failed to add input field "${e.name}": ${t instanceof Error?t.message:"Unknown error"}`,e.name)}};addOutputField=e=>{try{let t=this.parseField(e);Mt(t,"output");for(let n of this.outputFields)if(n.name===t.name)throw new re(`Duplicate output field name: "${t.name}"`,t.name,"Each field name must be unique within the signature");for(let n of this.inputFields)if(n.name===t.name)throw new re(`Field name "${t.name}" appears in both inputs and outputs`,t.name,"Use different names for input and output fields to avoid confusion");this.outputFields.push(t),this.invalidateValidationCache(),this.updateHashLight()}catch(t){throw t instanceof re?t:new re(`Failed to add output field "${e.name}": ${t instanceof Error?t.message:"Unknown error"}`,e.name)}};setInputFields=e=>{if(!Array.isArray(e))throw new re("Input fields must be an array",void 0,"Provide an array of field objects");try{let t=e.map(n=>{let r=this.parseField(n);return Mt(r,"input"),r});this.inputFields=t,this.invalidateValidationCache(),this.updateHashLight()}catch(t){throw t instanceof re?t:new re(`Failed to set input fields: ${t instanceof Error?t.message:"Unknown error"}`)}};setOutputFields=e=>{if(!Array.isArray(e))throw new re("Output fields must be an array",void 0,"Provide an array of field objects");try{let t=e.map(n=>{let r=this.parseField(n);return Mt(r,"output"),r});this.outputFields=t,this.invalidateValidationCache(),this.updateHashLight()}catch(t){throw t instanceof re?t:new re(`Failed to set output fields: ${t instanceof Error?t.message:"Unknown error"}`)}};getInputFields=()=>this.inputFields;getOutputFields=()=>this.outputFields;getDescription=()=>this.description;appendInputField=(e,t)=>{let n=new o(this);return n.addInputField({name:e,...ss(t)}),n};prependInputField=(e,t)=>{let n=new o(this),r={name:e,...ss(t)},s=n.parseField(r);Mt(s,"input");for(let i of n.inputFields)if(i.name===s.name)throw new re(`Duplicate input field name: "${s.name}"`,s.name,"Each field name must be unique within the signature");for(let i of n.outputFields)if(i.name===s.name)throw new re(`Field name "${s.name}" appears in both inputs and outputs`,s.name,"Use different names for input and output fields to avoid confusion");return n.inputFields.unshift(s),n.invalidateValidationCache(),n.updateHashLight(),n};appendOutputField=(e,t)=>{let n=new o(this);return n.addOutputField({name:e,...ss(t)}),n};prependOutputField=(e,t)=>{let n=new o(this),r={name:e,...ss(t)},s=n.parseField(r);Mt(s,"output");for(let i of n.outputFields)if(i.name===s.name)throw new re(`Duplicate output field name: "${s.name}"`,s.name,"Each field name must be unique within the signature");for(let i of n.inputFields)if(i.name===s.name)throw new re(`Field name "${s.name}" appears in both inputs and outputs`,s.name,"Use different names for input and output fields to avoid confusion");return n.outputFields.unshift(s),n.invalidateValidationCache(),n.updateHashLight(),n};invalidateValidationCache=()=>{this.validatedAtHash=void 0,this._hasComplexFields=void 0};toTitle=e=>{let t=e.replace(/_/g," ");return t=t.replace(/([A-Z]|[0-9]+)/g," $1").trim(),t.charAt(0).toUpperCase()+t.slice(1)};updateHashLight=()=>{try{return this.getInputFields().forEach(e=>{Mt(e,"input")}),this.getOutputFields().forEach(e=>{Mt(e,"output")}),this.sigHash=pt("sha256").update(JSON.stringify(this.inputFields)).update(JSON.stringify(this.outputFields)).digest("hex"),this.sigString=Gc(this.description,this.inputFields,this.outputFields),this._hasComplexFields=this.computeHasComplexFields(),[this.sigHash,this.sigString]}catch(e){throw e instanceof re?e:new re(`Signature validation failed: ${e instanceof Error?e.message:"Unknown error"}`)}};updateHash=()=>{try{return this.getInputFields().forEach(e=>{Mt(e,"input")}),this.getOutputFields().forEach(e=>{Mt(e,"output")}),this.validateSignatureConsistency(),this.sigHash=pt("sha256").update(this.description??"").update(JSON.stringify(this.inputFields)).update(JSON.stringify(this.outputFields)).digest("hex"),this.sigString=Gc(this.description,this.inputFields,this.outputFields),this._hasComplexFields=this.computeHasComplexFields(),[this.sigHash,this.sigString]}catch(e){throw e instanceof re?e:new re(`Signature validation failed: ${e instanceof Error?e.message:"Unknown error"}`)}};validateSignatureConsistency(){let e=new Set;for(let n of this.inputFields){if(e.has(n.name))throw new re(`Duplicate input field name: "${n.name}"`,n.name,"Each field name must be unique within the signature");e.add(n.name)}let t=new Set;for(let n of this.outputFields){if(t.has(n.name))throw new re(`Duplicate output field name: "${n.name}"`,n.name,"Each field name must be unique within the signature");t.add(n.name)}for(let n of this.outputFields)if(e.has(n.name))throw new re(`Field name "${n.name}" appears in both inputs and outputs`,n.name,"Use different names for input and output fields to avoid confusion");if(this.inputFields.length===0)throw new re("Signature must have at least one input field",void 0,'Add an input field. Example: "userInput:string -> ..."');if(this.outputFields.length===0)throw new re("Signature must have at least one output field",void 0,'Add an output field. Example: "... -> responseText:string"')}_forceComplexFields=!1;_hasComplexFields;hasComplexFields=()=>this._hasComplexFields!==void 0?this._hasComplexFields:(this._hasComplexFields=this.computeHasComplexFields(),this._hasComplexFields);computeHasComplexFields=()=>this._forceComplexFields?!0:this.outputFields.some(e=>e.type?.name==="object"||e.type?.isArray&&e.type.fields!==void 0);validate=()=>{if(this.validatedAtHash===this.sigHash)return!0;try{return this.updateHash(),this.validatedAtHash=this.sigHash,!0}catch(e){throw this.validatedAtHash=void 0,e}};hash=()=>this.sigHash;toString=()=>this.sigString;toJSON=()=>({id:this.hash(),description:this.description,inputFields:this.inputFields,outputFields:this.outputFields});toJSONSchema=()=>{let e=[...this.inputFields,...this.outputFields];return zt(e,this.description??"Schema")};toInputJSONSchema=()=>zt(this.inputFields,this.description??"Schema")};function Uc(o){let e=o.name;return o.isOptional&&(e+="?"),o.isInternal&&(e+="!"),o.type&&(e+=`:${o.type.name}`,o.type.isArray&&(e+="[]"),o.type.name==="class"&&o.type.options&&(e+=` "${o.type.options.join(" | ")}"`)),o.description&&o.type?.name!=="class"&&(e+=` "${o.description}"`),e}function Gc(o,e,t){let n=o?`"${o}" `:"",r=e.map(Uc).join(", "),s=t.map(Uc).join(", ");return`${n}${r} -> ${s}`}function yd(o){let e=/^[a-z][a-zA-Z0-9]*$/,t=/^[a-z]+(_[a-z0-9]+)*$/;return e.test(o)||t.test(o)}function Mt(o,e){if(!o.name||o.name.length===0)throw new re("Field name cannot be blank",o.name,"Every field must have a descriptive name");if(!yd(o.name))throw new re(`Invalid field name '${o.name}' - must be camelCase or snake_case`,o.name,'Use camelCase (e.g., "userInput") or snake_case (e.g., "user_input")');if(de.signatureStrict&&["text","object","image","string","number","boolean","json","array","datetime","date","time","type","class","input","output","data","value","result","response","request","item","element"].includes(o.name.toLowerCase())){let n=e==="input"?["userInput","questionText","documentContent","messageText","queryString"]:["responseText","analysisResult","categoryType","summaryText","outputData"];throw new re(`Field name '${o.name}' is too generic`,o.name,`Use a more descriptive name. Examples for ${e} fields: ${n.join(", ")}`)}if(o.name.length<2)throw new re(`Field name '${o.name}' is too short`,o.name,"Field names must be at least 2 characters long");if(o.name.length>50)throw new re(`Field name '${o.name}' is too long (${o.name.length} characters)`,o.name,"Field names should be 50 characters or less");o.type&&bd(o,e)}function bd(o,e){if(!o.type)return;let{type:t}=o;if((t.name==="image"||t.name==="audio"||t.name==="file")&&e==="output")throw new re(`${t.name} type is not supported in output fields`,o.name,`${t.name} types can only be used in input fields`);if(t.name==="class"){if(e==="input")throw new re("Class type is not supported in input fields",o.name,'Class types are only allowed on output fields. Use "string" type for input classifications');if(!t.options||t.options.length===0)throw new re("Class type requires options",o.name,'Provide class options. Example: class "positive, negative, neutral"');for(let r of t.options){if(!r||r.trim().length===0)throw new re("Empty class option found",o.name,"All class options must be non-empty strings");let s=r.trim();if(s.includes(",")||s.includes("|"))throw new re(`Invalid class option "${s}"`,o.name,"Class options cannot contain commas (,) or pipes (|) as they are used to separate options")}if(new Set(t.options.map(r=>r.trim().toLowerCase())).size!==t.options.length)throw new re("Duplicate class options found",o.name,"Each class option must be unique (case-insensitive)")}if(t.name==="code"&&t.isArray)throw new re("Arrays of code are not commonly supported",o.name,"Consider using a single code field or an array of strings instead");if(o.isInternal&&e==="input")throw new re("Internal marker (!) is not allowed on input fields",o.name,"Internal markers are only allowed on output fields");t.name==="object"&&t.fields&&Yi(t.fields,o.name,e)}function Yi(o,e,t,n=1){for(let[r,s]of Object.entries(o)){let i=`${e}.${r}`;if(s.type==="image"||s.type==="audio"||s.type==="file")throw new re(`${s.type} type is not allowed in nested object fields`,i,`Media types (image, audio, file) can only be used as top-level input fields, not within objects. Found at depth ${n}.`);s.type==="object"&&s.fields&&Yi(s.fields,i,t,n+1),s.isArray&&s.fields&&Yi(s.fields,`${i}[]`,t,n+1)}}var qt=class o{signature;sigHash;examples;examplesOptions;demos;trace;usage=[];traceLabel;key;children;childNames=new Map;childCount=0;constructor(e,t){this.signature=new Ne(e),t?.description&&this.signature.setDescription(t.description),t?.traceLabel&&(this.traceLabel=t.traceLabel),e&&this.signature.validate(),this.sigHash=this.signature?.hash(),this.children=new Gn,this.key={id:"root"}}getSignature(){return new Ne(this.signature)}setSignature(e){this.signature=new Ne(e),e&&this.signature.validate(),this.updateSignatureHash()}setDescription(e){this.signature.setDescription(e),this.updateSignatureHash()}updateSignatureHash(){this.sigHash=this.signature.hash()}getId(){return this.key.id}register(e,t){let n=t??`p${this.childCount}`;this.childCount++,e.setId([this.key.id,n].join(".")),this.childNames.set(e,n),this.children.register(e)}setId(e){this.key={id:e,custom:!0};for(let[t,n]of this.childNames)t.setId([e,n].join("."))}setExamples(e,t){let n=[];if("programId"in e&&e.programId===this.key.id&&(n=e.traces),Array.isArray(e)&&(n=e),n){this.examplesOptions=t;let r=this.signature,s=[...r.getInputFields(),...r.getOutputFields()];this.examples=n.map(i=>{let a={};for(let l of s){let c=i[l.name];c!==void 0&&(Fr(l,c),a[l.name]=c)}return a})}}getTraces(){let e=[];this.trace&&e.push({trace:this.trace,programId:this.key.id});for(let t of Array.from(this.children)){let n=t?.getTraces();e=[...e,...n??[]]}return e}getUsage(){let e=[...this.usage??[]];for(let t of Array.from(this.children)){let n=t?.getUsage();e=[...e,...n??[]]}return _r(e)}resetUsage(){this.usage=[];for(let e of Array.from(this.children))e?.resetUsage()}static _propagating=!1;setDemos(e,t){if(!o._propagating&&e.length>0){let c=new Set(this.namedPrograms().map(p=>p.id)),u=[...new Set(e.map(p=>p.programId))].filter(p=>!c.has(p));if(u.length>0){let p=[...c].join(", ");throw new Error(`Unknown program ID(s) in demos: ${u.join(", ")}. Valid IDs: ${p}. Use namedPrograms() to discover available IDs.`)}}let n=e.filter(c=>c.programId===this.key.id).map(c=>c.traces).flat(),r=this.signature,s=[...r.getInputFields(),...r.getOutputFields()],i=new Set(r.getInputFields().map(c=>c.name)),a=new Set(r.getOutputFields().map(c=>c.name));this.demos=n.map((c,u)=>{let p={};for(let g of s){let f=c[g.name];f!==void 0&&(Fr(g,f),p[g.name]=f)}let d=Object.keys(p).some(g=>i.has(g));if(!Object.keys(p).some(g=>a.has(g)))throw new Error(`Demo trace[${u}] for '${this.key.id}' has no output field values. Expected at least one of: ${[...a].join(", ")}`);if(!d)throw new Error(`Demo trace[${u}] for '${this.key.id}' has no input field values. Expected at least one of: ${[...i].join(", ")}. Provide input context so the demo renders as a complete few-shot example.`);return p}),t?.modelConfig&&(this._optimizedModelConfig=t.modelConfig);let l=o._propagating;o._propagating=!0;try{for(let c of Array.from(this.children))c?.setDemos(e,t)}finally{o._propagating=l}}namedPrograms(){let e=[];[...this.signature.getInputFields(),...this.signature.getOutputFields()].length>0&&e.push({id:this.key.id,signature:this.signature.toString()});for(let n of Array.from(this.children))n&&"namedPrograms"in n&&typeof n.namedPrograms=="function"?e.push(...n.namedPrograms()):n&&e.push({id:n.getId()});return e}namedProgramInstances(){let e=[];[...this.signature.getInputFields(),...this.signature.getOutputFields()].length>0&&e.push({id:this.key.id,program:this,signature:this.signature.toString()});for(let n of Array.from(this.children))n&&"namedProgramInstances"in n&&typeof n.namedProgramInstances=="function"?e.push(...n.namedProgramInstances()):n&&e.push({id:n.getId(),program:n});return e}applyOptimization(e){let t=e.demos!==void 0,n=e.modelConfig!==void 0;(t||n)&&this.setDemos(e.demos??[],{modelConfig:e.modelConfig});let r=this;if(typeof r.setInstruction=="function"){let i=e.instructionMap?.[this.key.id],a=typeof i=="string"?i:e.instruction;typeof a=="string"&&a.length>0&&r.setInstruction(a)}let s={...e,...t?{demos:void 0}:{},...n?{modelConfig:void 0}:{}};for(let i of Array.from(this.children))i?.applyOptimization(s)}};var jc={"dsp/example-disclaimer.md":`## Example Demonstrations
214
+ Tip: Arrays must include an "items" schema (e.g., { items: { type: "string" } } or items: { type: "object", properties: { ... } }).`,{cause:r}):r}return[...e??[],...t]},us=async({ai:o,functionList:e,functionCalls:t,mem:n,sessionId:r,traceId:s,span:i,excludeContentFromTrace:a,index:u,functionResultFormatter:c,logger:l,debug:p,stopFunctionNames:d,step:m,abortSignal:g})=>{let f=new Gr(e),x=new Set,A=[],h=v=>{let O=S=>S.replace(/[^a-zA-Z0-9]/g,"").toLowerCase(),R=O(v),E=e.find(S=>S.name===v);return E||(E=e.find(S=>O(S.name)===R)),E},y=t.map(v=>{if(!v.id)throw new Error(`Function ${v.name} did not return an ID`);let O=o.getOptions().tracer??ge.tracer;return O?O.startActiveSpan(`Tool: ${v.name}`,async R=>{try{R?.setAttributes?.({"tool.name":v.name,"tool.mode":"native","function.id":v.id,"session.id":r??""});let{formatted:E,rawResult:S,parsedArgs:_}=await f.executeWithDetails(v,{sessionId:r,ai:o,functionResultFormatter:c,traceId:R?.spanContext?.().traceId??s,stopFunctionNames:d,step:m,abortSignal:g});if(x.add(v.name.toLowerCase()),m?._recordFunctionCall(v.name,_,S),d?.includes(v.name.toLowerCase())){let $=h(v.name);$&&A.push({func:$,args:_,result:S})}if(a?R.addEvent("gen_ai.tool.message",{name:v.name}):R.addEvent("gen_ai.tool.message",{name:v.name,args:v.args,result:E??""}),i){let $={name:v.name};a||($.args=v.args,$.result=E??""),i.addEvent("function.call",$)}return{result:E??"",role:"function",functionId:v.id,index:u}}catch(E){if(R?.recordException?.(E),E instanceof Ur){let S=E.getFixingInstructions(),_={name:v.name,message:E.toString()};return a||(_.args=v.args,_.fixing_instructions=S),R?.addEvent?.("function.error",_),p&&si(E,u,S,l),{functionId:v.id,isError:!0,index:u,result:S,role:"function"}}throw E}finally{R?.end?.()}}):f.executeWithDetails(v,{sessionId:r,ai:o,functionResultFormatter:c,traceId:s,stopFunctionNames:d,step:m,abortSignal:g}).then(({formatted:R,rawResult:E,parsedArgs:S})=>{if(x.add(v.name.toLowerCase()),m?._recordFunctionCall(v.name,S,E),d?.includes(v.name.toLowerCase())){let _=h(v.name);_&&A.push({func:_,args:S,result:E})}if(i){let _={name:v.name};a||(_.args=v.args,_.result=R??""),i.addEvent("function.call",_)}return{result:R??"",role:"function",functionId:v.id,index:u}}).catch(R=>{if(!(R instanceof Ur))throw R;let E=R.getFixingInstructions();if(i){let S={name:v.name,message:R.toString()};a||(S.args=v.args,S.fixing_instructions=E),i.addEvent("function.error",S)}return p&&si(R,u,E,l),{functionId:v.id,isError:!0,index:u,result:E,role:"function"}})}),I=(await Promise.all(y)).map(v=>v.result===void 0||v.result===""?{...v,result:"done"}:v);if(n.addFunctionResults(I,r),p){let v=I.filter(O=>!O.isError);v.length>0&&mu(v,l)}if(A.length>0)throw new nn(A);return x};function Yi(o,e,t,n){if(!e||e.length===0)return;if(!o.getFeatures(n).functions)throw new Error("Functions are not supported by the AI service");return e.map(s=>({id:s.id,name:s.function.name,args:s.function.params}))}function Hc(o,e,t,n){let r=e;return!t&&(r==="required"||typeof r=="function")?{functions:[],functionCall:void 0}:o?{functions:o.map(i=>"toFunction"in i?i.toFunction():i).flat(),functionCall:r}:{functions:[],functionCall:r}}function em(o){let e=0,t=!1,n=!1,r=!1,s=!1,i=[];for(let a=0;a<o.length;a++){let u=o[a];if(n){n=!1;continue}if(u==="\\"){n=!0;continue}if(u==='"'){t=!t;continue}t||(u==="{"?(i.push("{"),e++):u==="["?(i.push("["),e++):u==="}"?i.length>0&&i[i.length-1]==="{"&&(i.pop(),e--):u==="]"&&i.length>0&&i[i.length-1]==="["&&(i.pop(),e--))}if(i.length>0){let a=i[i.length-1];r=a==="[",s=a==="{"}return{nestingLevel:e,inString:t,inArray:r,inObject:s}}function Kc(o){if(!o.trim())return{parsed:null,partialMarker:null};try{return{parsed:JSON.parse(o),partialMarker:null}}catch{}let e=em(o),t=tm(o);try{return{parsed:JSON.parse(t),partialMarker:e}}catch{return{parsed:null,partialMarker:e}}}function tm(o){let e=o.trim();for(e.endsWith(",")&&(e=e.slice(0,-1)),e.match(/,\s*"[^"]*"\s*:\s*$/)?e=e.replace(/,\s*"[^"]*"\s*:\s*$/,""):e.match(/\{\s*"[^"]*"\s*:\s*$/)&&(e=e.replace(/"[^"]*"\s*:\s*$/,""));e.match(/[0-9][eE.+-]$/)||e.match(/[eE][+-]$/);)e=e.slice(0,-1);e=e.replace(/,(\s*[}\]])/g,"$1"),e.match(/t(r(u(e)?)?)?$/)&&!e.endsWith('"')&&!e.endsWith("true")&&e.match(/[:[,]\s*t(r(u(e)?)?)?$/)&&(e=e.replace(/t(r(u(e)?)?)?$/,"true")),e.match(/f(a(l(s(e)?)?)?)?$/)&&!e.endsWith('"')&&!e.endsWith("false")&&e.match(/[:[,]\s*f(a(l(s(e)?)?)?)?$/)&&(e=e.replace(/f(a(l(s(e)?)?)?)?$/,"false")),e.match(/n(u(l(l)?)?)?$/)&&!e.endsWith('"')&&!e.endsWith("null")&&e.match(/[:[,]\s*n(u(l(l)?)?)?$/)&&(e=e.replace(/n(u(l(l)?)?)?$/,"null"));let t=[],n=!1,r=!1;for(let s=0;s<e.length;s++){let i=e[s];if(r){r=!1;continue}if(i==="\\"){r=!0;continue}if(i==='"'){n=!n;continue}n||(i==="{"?t.push("}"):i==="["?t.push("]"):i==="}"?t.length>0&&t[t.length-1]==="}"&&t.pop():i==="]"&&t.length>0&&t[t.length-1]==="]"&&t.pop())}for(r&&(e=e.slice(0,-1)),n&&(e+='"'),t.length>0&&t[t.length-1]==="}"&&e.match(/,\s*"[^"]*"\s*$/)&&(e=e.replace(/,\s*"[^"]*"\s*$/,""));t.length>0;)e+=t.pop();return e}async function*Wc({res:o,usage:e,states:t,debug:n,stepContext:r,...s}){let i=(s.ai.getFeatures().functionCot??!1)&&s.functions!==void 0&&s.functions.length>0,a,u=[],c=o.getReader();try{for(;;){let{done:l,value:p}=await c.read();if(l)break;let d=p;d.modelUsage&&(a=d.modelUsage);for(let m of d.results){if(Array.isArray(m.citations))for(let f of m.citations)f?.url&&u.push({url:f.url,title:f.title,description:f.description,license:f.license,publicationDate:f.publicationDate,snippet:f.snippet});if((!m.content||m.content==="")&&(!m.thought||m.thought==="")&&(!m.thoughtBlocks||m.thoughtBlocks.length===0)&&(!m.functionCalls||m.functionCalls.length===0))continue;let g=t.find(f=>f.index===m.index);if(!g)throw new Error(`No state found for result (index: ${m.index})`);yield*nm({...s,result:m,skipEarlyFail:i,state:g,debug:n})}}}finally{c.releaseLock()}for(let l of t)yield*rm({...s,state:l,debug:n,stepContext:r});if(a){if(u.length){let l=Array.from(new Map(u.filter(p=>p.url).map(p=>[p.url,p])).values());a.citations=l}if(e.push(a),n&&s.logger){let l=structuredClone(a);delete l.citations,s.logger({name:"ChatResponseUsage",value:l}),a.citations&&a.citations.length>0&&s.logger({name:"ChatResponseCitations",value:a.citations})}}}async function*nm({result:o,mem:e,sessionId:t,strictMode:n,skipEarlyFail:r,treatAllFieldsOptional:s,state:i,signature:a,streamingFieldProcessors:u,thoughtFieldName:c,streamingAsserts:l,asserts:p}){if(o.functionCalls&&o.functionCalls.length>0)fo(i.functionCalls,o.functionCalls),e.updateResult({name:o.name,content:o.content,functionCalls:i.functionCalls,thoughtBlocks:o.thoughtBlocks,delta:o.functionCalls?.[0]?.function?.params,index:o.index},t);else if(o.content&&o.content.length>0){o.thought&&o.thought.length>0&&(yield{index:o.index,delta:{[c]:o.thought}}),i.content+=o.content,e.updateResult({name:o.name,content:i.content,thoughtBlocks:o.thoughtBlocks,delta:o.content,index:o.index},t);let d=a.getOutputFields();if(a.hasComplexFields()){let{parsed:f,partialMarker:x}=Kc(i.content);if(f&&typeof f=="object"){let A={},h={};for(let y of Object.keys(f))if(d.some(C=>C.name===y)){let C=f[y],I=i.values[y];if(Array.isArray(C)&&C.length>0&&om(C,x)&&(C=C.slice(0,-1)),h[y]=C,typeof C=="string"&&typeof I=="string"&&C.startsWith(I)){let v=C.slice(I.length);v&&(A[y]=v)}else Array.isArray(C)&&Array.isArray(I)?C.length>I.length&&(A[y]=C.slice(I.length)):JSON.stringify(C)!==JSON.stringify(I)&&(Array.isArray(C)||(A[y]=C))}try{zn(a,h,{allowMissingRequired:!0})}catch{}Object.assign(i.values,h),Object.keys(A).length>0&&(yield{index:o.index,delta:A});return}}if(Wi(a,i.values,i.xstate,i.content,{strictMode:n,skipEarlyFail:r,treatAllFieldsOptional:s}))return;l.length!==0&&await Li(l,i.xstate,i.content),u.length!==0&&await Qi(u,i.content,i.xstate,e,i.values,t),yield*Ji(a,i.content,i.values,i.xstate,o.index),await Gn(p,i.values)}else o.thought&&o.thought.length>0?(i.values[c]=(i.values[c]??"")+o.thought,yield{index:o.index,delta:{[c]:o.thought}},e.updateResult({name:o.name,content:i.content,delta:"",index:o.index,thought:o.thought,thoughtBlocks:o.thoughtBlocks},t)):o.thoughtBlocks&&o.thoughtBlocks.length>0&&e.updateResult({name:o.name,content:i.content,delta:"",index:o.index,thoughtBlocks:o.thoughtBlocks},t);if(o.finishReason==="length")throw new Error(`Max tokens reached before completion
215
+ Content: ${i.content}`)}async function*rm({state:o,signature:e,ai:t,model:n,functions:r,mem:s,sessionId:i,traceId:a,span:u,strictMode:c,excludeContentFromTrace:l,streamingAsserts:p,asserts:d,fieldProcessors:m,streamingFieldProcessors:g,functionResultFormatter:f,signatureToolCallingManager:x,logger:A,debug:h,stopFunctionNames:y,stepContext:C,abortSignal:I}){let v=x?void 0:Yi(t,o.functionCalls,o.values,n);if(v){if(!r)throw new Error("Functions are not defined");let O=await us({ai:t,functionList:r,functionCalls:v,mem:s,sessionId:i,traceId:a,span:u,index:o.index,excludeContentFromTrace:l,functionResultFormatter:f,logger:A,debug:h,stopFunctionNames:y,step:C,abortSignal:I});o.functionsExecuted=new Set([...o.functionsExecuted,...O]),o.functionCalls=[]}else{let O=e.getOutputFields(),R=e.hasComplexFields(),E=!1;if(R)try{let S=JSON.parse(o.content),_={};for(let $ of Object.keys(S))if(O.some(M=>M.name===$)){let M=S[$],F=o.values[$];if(typeof M=="string"&&typeof F=="string"&&M.startsWith(F)){let N=M.slice(F.length);N&&(_[$]=N)}else Array.isArray(M)&&Array.isArray(F)?M.length>F.length&&(_[$]=M.slice(F.length)):JSON.stringify(M)!==JSON.stringify(F)&&(Array.isArray(M)||(_[$]=M))}try{zn(e,_,{allowMissingRequired:!0})}catch($){let M=($.message||"").toLowerCase();if(M.includes("at least")||M.includes("at most")||M.includes("must match pattern")||M.includes("invalid url")||M.includes("required")||M.includes("missing")||M.includes("valid email")||M.includes("number must be"))throw $}for(let $ of Object.keys(S))O.some(M=>M.name===$)&&(o.values[$]=S[$]);yield{index:o.index,delta:_},E=!0}catch(S){let _=(S.message||"").toLowerCase();if(_.includes("at least")||_.includes("at most")||_.includes("must match pattern")||_.includes("invalid url")||_.includes("required")||_.includes("missing")||_.includes("valid email")||_.includes("number must be"))throw S}if(!E){let S=x!==void 0;Vi(e,o.values,o.xstate,o.content,{strictMode:c,treatAllFieldsOptional:S,deferRequiredCheckForStreaming:!0,forceFinalize:!0})}if(x){let S=await x.processResults(o.values);if(S&&S.length>0){if(!r)throw new Error("Functions are not defined");let _=await us({ai:t,functionList:r,functionCalls:S,mem:s,sessionId:i,traceId:a,span:u,index:o.index,excludeContentFromTrace:l,functionResultFormatter:f,logger:A,debug:h,stopFunctionNames:y,step:C,abortSignal:I});o.functionsExecuted=new Set([...o.functionsExecuted,..._]),s.updateResult({name:void 0,content:o.content,functionCalls:S.map($=>({id:$.id,type:"function",function:{name:$.name,params:$.args}})),index:o.index},i);return}}await Li(p,o.xstate,o.content,!0),await Gn(d,o.values),m.length&&await $r(m,o.values,s,i),g.length!==0&&await Qi(g,o.content,o.xstate,s,o.values,i,!0),yield*Ji(e,o.content,o.values,o.xstate,o.index)}}async function*Vc({ai:o,res:e,mem:t,sessionId:n,traceId:r,functions:s,span:i,strictMode:a,states:u,usage:c,excludeContentFromTrace:l,asserts:p,fieldProcessors:d,thoughtFieldName:m,signature:g,functionResultFormatter:f,logger:x,debug:A,signatureToolCallingManager:h,stopFunctionNames:y,disableMemoryCleanup:C,stepContext:I,abortSignal:v}){let O=e.results??[],R=h!==void 0;t.addResponse(O,n);let E=[];for(let M of O)if(Array.isArray(M?.citations))for(let F of M.citations)F?.url&&E.push({url:F.url,title:F.title,description:F.description,license:F.license,publicationDate:F.publicationDate,snippet:F.snippet});for(let M of O){let F=u[M.index];if(!F)throw new Error(`No state found for result (index: ${M.index})`);if(e.modelUsage){let N=Array.from(new Map(E.filter(W=>W.url).map(W=>[W.url,W])).values()),G={...e.modelUsage,...N.length?{citations:N}:{}};if(c.push(G),A&&x){let W=structuredClone(G);delete W.citations,x({name:"ChatResponseUsage",value:W}),G.citations&&G.citations.length>0&&x({name:"ChatResponseCitations",value:G.citations})}}if(h&&M.content){M.thought&&M.thought.length>0&&(F.values[m]=M.thought),ss(g,F.values,M.content,{strictMode:a,treatAllFieldsOptional:R});let G=(await h.processResults(F.values))?.map(W=>({id:W.id,type:"function",function:{name:W.name,params:W.args}}));G&&G.length>0&&t.updateResult({name:M.name,content:M.content,functionCalls:G,index:M.index},n)}if(M.functionCalls?.length){let N=Yi(o,M.functionCalls,F.values);if(N&&N.length>0){if(!s)throw new Error("Functions are not defined");let G;try{G=await us({ai:o,functionList:s,functionCalls:N,mem:t,sessionId:n,traceId:r,span:i,excludeContentFromTrace:l,index:M.index,functionResultFormatter:f,logger:x,debug:A,stopFunctionNames:y,step:I,abortSignal:v})}catch(W){throw t.addRequest([{role:"user",content:"The previous tool call failed. Fix arguments and try again, ensuring required fields match schema."}],n),t.addTag("correction",n),W}F.functionsExecuted=new Set([...F.functionsExecuted,...G])}}else if(M.content){M.thought&&M.thought.length>0&&(F.values[m]=M.thought);let N=g.getOutputFields();if(g.hasComplexFields())try{let W=JSON.parse(M.content),U={};for(let ae of Object.keys(W))N.some(j=>j.name===ae)&&(U[ae]=W[ae]);zn(g,U),Object.assign(F.values,U)}catch(W){let U=W instanceof SyntaxError;if((W.name?.includes("ValidationError")||W.name?.includes("Error"))&&!U){let j=(W.message||"").toLowerCase();if(j.includes("at least")||j.includes("at most")||j.includes("must match pattern")||j.includes("invalid url")||j.includes("required")||j.includes("missing")||j.includes("valid email")||j.includes("number must be"))throw W}if(U)ss(g,F.values,M.content,{strictMode:a,treatAllFieldsOptional:R});else throw W}else ss(g,F.values,M.content,{strictMode:a,treatAllFieldsOptional:R})}if(await Gn(p,F.values),C||(t.removeByTag("correction",n),t.removeByTag("error",n)),d.length&&await $r(d,F.values,t,n),M.finishReason==="length")throw new Error(`Max tokens reached before completion
216
+ Content: ${M.content}`)}let S=u.map(M=>M.values);for(let M of S)for(let F of g.getOutputFields())F.isInternal&&delete M[F.name];let _=g.getOutputFields(),$=S.map((M,F)=>{let N={};for(let G of _)G.isInternal||(N[G.name]=M[G.name]);return M[m]!==void 0&&(N[m]=M[m]),{index:F,delta:N}});for(let M of $)yield M}function om(o,e){return e?!!(e.nestingLevel>0||e.inArray||e.inObject):!1}function Jc(o,e,t,n){let r=o.getLast(n);if(!r)return!0;for(let[s,i]of t.entries()){let a=e?Array.from(e).some(p=>i.functionsExecuted.has(p)):!1;if(!r.chat[s])throw new Error(`No chat message found for result (index: ${s})`);let c=r.role==="function",l=r.tags?r.tags.some(p=>p==="processor"):!1;if(c&&e&&a||!(c||l))return!1}return!0}var sm=["none","minimal","low","medium","high","highest"];function Xi(o,e,t){let n={};if(e.model!==!1){let a=o.getModelList();if(a&&a.length>0){let u=a.filter(c=>"model"in c);if(u.length>0){let c=u.map(p=>p.key),l=u.map(p=>`${p.key} (${p.description})`);n.model={type:"string",enum:c,description:`${t&&c.includes(t)?`Currently using model: ${t}. `:""}Switch model for the next step. Prefer faster/cheaper models for simple tasks; use more capable models for complex reasoning, math, or multi-step analysis. Available: ${l.join(", ")}`}}}}e.thinkingBudget!==!1&&(n.thinkingBudget={type:"string",enum:[...sm],description:"Reasoning depth for the next step. none/minimal: simple lookups or reformatting. low/medium: moderate analysis, summarization. high/highest: math, logic, code analysis, or multi-step reasoning. Higher budgets use more tokens."}),e.temperature&&(n.temperature={type:"number",description:"Sampling temperature for the next step. Lower values (0\u20130.3) for deterministic tasks like math or code; higher values (0.7\u20131.0) for creative or exploratory tasks."});let r;if(e.functions&&e.functions.length>0){r=rn(e.functions);let a=r.map(c=>c.name),u=r.map(c=>`${c.name} (${c.description})`);n.addFunctions={type:"array",items:{type:"string",enum:a},description:`Activate tools you need for the current sub-task. Only add what you will use immediately \u2014 fewer active tools means less noise. Available: ${u.join(", ")}`},n.removeFunctions={type:"array",items:{type:"string",enum:a},description:"Remove tools you are done with to reduce context size and maintain focus on remaining work."}}let s=r;return{name:"adjustGeneration",description:"Adjust model, reasoning depth, or active tools for the next step. Call when task complexity changes \u2014 upgrade for hard reasoning or analysis, downgrade for simple follow-ups. Only call when there is a clear reason to change.",parameters:Object.keys(n).length>0?{type:"object",properties:n}:void 0,func:(a,u)=>{let c=u?.step;if(!c)return"Generation parameters adjusted for next response.";if(a?.model&&c.setModel(a.model),a?.thinkingBudget&&c.setThinkingBudget(a.thinkingBudget),a?.temperature!==void 0&&c.setTemperature(a.temperature),a?.addFunctions?.length&&s){let l=s.filter(p=>a.addFunctions.includes(p.name));l.length>0&&c.addFunctions(l)}return a?.removeFunctions?.length&&c.removeFunctions(...a.removeFunctions),"Generation parameters adjusted for next response."}}}var qn=class{reg;constructor(){this.reg=new Set}register(e){this.reg.add(e)}*[Symbol.iterator](){let e=Array.from(this.reg);for(let t=0;t<e.length;t++)yield e[t]}};var fe=class extends Error{constructor(t,n,r,s){super(t);this.position=n;this.context=r;this.suggestion=s;this.name="SignatureValidationError"}},Zi=class{input;position;currentFieldName=null;currentSection="description";constructor(e){if(this.input=e.trim(),this.position=0,!this.input)throw new fe("Empty signature provided",0,"",'A signature must contain at least input and output fields separated by "->". Example: "userQuery:string -> aiResponse:string"')}parse(){try{this.skipWhitespace();let e=this.parseParsedString();this.skipWhitespace(),this.currentSection="inputs";let t=this.parseFieldList(this.parseInputField.bind(this),"input");if(this.skipWhitespace(),this.position>=this.input.length)throw new fe("Incomplete signature: Missing output section",this.position,this.getErrorContext(),'Add "->" followed by output fields. Example: "-> responseText:string"');if(this.expectArrow(),this.skipWhitespace(),this.position>=this.input.length)throw new fe('Incomplete signature: No output fields specified after "->"',this.position,this.getErrorContext(),'Add at least one output field. Example: "-> responseText:string"');this.currentSection="outputs";let n=this.parseFieldList(this.parseOutputField.bind(this),"output");if(this.skipWhitespace(),this.position<this.input.length){let r=this.input.slice(this.position);throw new fe(`Unexpected content after signature: "${r}"`,this.position,this.getErrorContext(),"Remove any extra content after the output fields")}return this.validateParsedSignature({desc:e?.trim(),inputs:t,outputs:n}),{desc:e?.trim(),inputs:t,outputs:n}}catch(e){if(e instanceof fe)throw e;let t=e instanceof Error?e.message:"Unknown error";throw new fe(t,this.position,this.getErrorContext())}}validateParsedSignature(e){let t=new Set;for(let r of e.inputs){if(t.has(r.name))throw new fe(`Duplicate input field name: "${r.name}"`,0,"","Each field name must be unique within the signature");t.add(r.name)}let n=new Set;for(let r of e.outputs){if(n.has(r.name))throw new fe(`Duplicate output field name: "${r.name}"`,0,"","Each field name must be unique within the signature");n.add(r.name)}for(let r of e.outputs)if(t.has(r.name))throw new fe(`Field name "${r.name}" appears in both inputs and outputs`,0,"","Use different names for input and output fields to avoid confusion");if(e.inputs.length===0)throw new fe("Signature must have at least one input field",0,"",'Add an input field before "->". Example: "userInput:string -> ..."');if(e.outputs.length===0)throw new fe("Signature must have at least one output field",0,"",'Add an output field after "->". Example: "... -> responseText:string"')}getErrorContext(){let e=Math.max(0,this.position-25),t=Math.min(this.input.length,this.position+25),n=this.input.slice(e,this.position),r=this.input.slice(this.position,t),s=`${" ".repeat(n.length)}^`;return[`Position ${this.position} in signature:`,`"${n}${r}"`,` ${s}`].join(`
217
+ `)}parseFieldList(e,t){let n=[];if(this.skipWhitespace(),this.position>=this.input.length)throw new fe(`Empty ${t} section: Expected at least one field`,this.position,this.getErrorContext(),`Add a ${t} field. Example: ${t==="input"?"userInput:string":"responseText:string"}`);try{n.push(e())}catch(r){throw r instanceof fe?r:new fe(`Invalid first ${t} field: ${r instanceof Error?r.message:"Unknown error"}`,this.position,this.getErrorContext())}for(this.skipWhitespace();this.position<this.input.length&&!(this.input[this.position]==="-"&&this.position+1<this.input.length&&this.input[this.position+1]===">");)if(this.match(",")){if(this.skipWhitespace(),this.position>=this.input.length)throw new fe(`Unexpected end of input after comma in ${t} section`,this.position,this.getErrorContext(),`Add another ${t} field after the comma`);try{n.push(e())}catch(r){throw r instanceof fe?r:new fe(`Invalid ${t} field after comma: ${r instanceof Error?r.message:"Unknown error"}`,this.position,this.getErrorContext())}this.skipWhitespace()}else break;return n}parseInputField(){this.skipWhitespace();let e=this.parseParsedIdentifier();this.currentFieldName=e,this.validateFieldName(e,"input");let t;for(;;){if(this.match("?")){t=!0;continue}if(this.match("!"))throw new fe(`Input field "${e}" cannot use the internal marker "!"`,this.position-1,this.getErrorContext(),"Internal markers (!) are only allowed on output fields");break}let n;if(this.skipWhitespace(),this.match(":")){if(this.skipWhitespace(),/^class\b/.test(this.input.slice(this.position)))throw new fe(`Input field "${e}" cannot use the "class" type`,this.position,this.getErrorContext(),'Class types are only allowed on output fields. Use "string" type for input classifications');try{let s=this.parseTypeNotClass(),i=this.match("[]");n={name:s,isArray:i}}catch(s){throw s instanceof fe?s:new fe(`Input field "${e}": ${s instanceof Error?s.message:"Unknown error"}`,this.position,this.getErrorContext())}}this.skipWhitespace();let r=this.parseParsedString();return{name:e,desc:r?.trim(),type:n,isOptional:t}}parseOutputField(){this.skipWhitespace();let e=this.parseParsedIdentifier();this.currentFieldName=e,this.validateFieldName(e,"output");let t=!1,n=!1;for(;;){if(this.match("?")){t=!0;continue}if(this.match("!")){n=!0;continue}break}let r;if(this.skipWhitespace(),this.match(":"))if(this.skipWhitespace(),this.match("class")){let i=this.match("[]");this.skipWhitespace();let a=this.parseParsedString();if(!a)throw new fe(`Output field "${e}": Missing class options after "class" type`,this.position,this.getErrorContext(),'Add class names in quotes. Example: class "positive, negative, neutral"');let u=a.split(/[,|]/).map(c=>c.trim()).filter(c=>c.length>0);if(u.length===0)throw new fe(`Output field "${e}": Empty class list provided`,this.position,this.getErrorContext(),'Provide at least one class option. Example: "positive, negative"');r={name:"class",isArray:i,options:u}}else try{let i=this.parseTypeNotClass(),a=this.match("[]");if(r={name:i,isArray:a},i==="image"&&a)throw new fe(`Output field "${e}": Arrays of images are not supported`,this.position,this.getErrorContext(),'Use a single image type instead: "image"');if(i==="audio"&&a)throw new fe(`Output field "${e}": Arrays of audio are not supported`,this.position,this.getErrorContext(),'Use a single audio type instead: "audio"');if(i==="image")throw new fe(`Output field "${e}": Image type is not supported in output fields`,this.position,this.getErrorContext(),"Image types can only be used in input fields");if(i==="audio")throw new fe(`Output field "${e}": Audio type is not supported in output fields`,this.position,this.getErrorContext(),"Audio types can only be used in input fields")}catch(i){throw i instanceof fe?i:new fe(`Output field "${e}": ${i instanceof Error?i.message:"Unknown error"}`,this.position,this.getErrorContext())}this.skipWhitespace();let s=this.parseParsedString();return{name:e,desc:s?.trim(),type:r,isOptional:t,isInternal:n}}validateFieldName(e,t){if(ge.signatureStrict&&["text","object","image","string","number","boolean","json","array","datetime","date","time","type","class","input","output","data","value","result","response","request","item","element"].includes(e.toLowerCase())){let i=t==="input"?["userInput","questionText","documentContent","messageText"]:["responseText","analysisResult","categoryType","summaryText"];throw new fe(`Field name "${e}" is too generic`,this.position,this.getErrorContext(),`Use a more descriptive name. Examples: ${i.join(", ")}`)}let n=/^[a-z][a-zA-Z0-9]*$/,r=/^[a-z]+(_[a-z0-9]+)*$/;if(!n.test(e)&&!r.test(e))throw new fe(`Invalid field name "${e}"`,this.position,this.getErrorContext(),'Field names must be in camelCase (e.g., "userInput") or snake_case (e.g., "user_input")');if(e.length<2)throw new fe(`Field name "${e}" is too short`,this.position,this.getErrorContext(),"Field names must be at least 2 characters long");if(e.length>50)throw new fe(`Field name "${e}" is too long (${e.length} characters)`,this.position,this.getErrorContext(),"Field names should be 50 characters or less")}parseTypeNotClass(){let e=["string","number","boolean","json","image","audio","file","url","datetime","date","code","object"],t=e.find(n=>this.match(n));if(!t){let n=this.input.slice(this.position).match(/^\w+/)?.[0]||"",r=this.suggestType(n),s=`Invalid type "${n||"empty"}"`,i=r?`. Did you mean "${r}"?`:"",a=`${s}${i}`;throw new fe(a,this.position,this.getErrorContext(),`Expected one of: ${e.join(", ")}`)}return t}suggestType(e){return{str:"string",text:"string",int:"number",integer:"number",float:"number",double:"number",bool:"boolean",object:"json",dict:"json",timestamp:"datetime",time:"datetime",img:"image",picture:"image",sound:"audio",voice:"audio",classification:"class",category:"class"}[e.toLowerCase()]||null}parseParsedIdentifier(){this.skipWhitespace();let e=/^[a-zA-Z_][a-zA-Z_0-9]*/.exec(this.input.slice(this.position));if(e)return this.position+=e[0].length,e[0];let t=/^\S+/.exec(this.input.slice(this.position)),n=t?t[0]:"";throw n===""?new fe("Expected field name but found end of input",this.position,this.getErrorContext(),"Add a field name. Field names must start with a letter or underscore"):/^\d/.test(n)?new fe(`Invalid field name "${n}" - cannot start with a number`,this.position,this.getErrorContext(),'Field names must start with a letter or underscore. Example: "userInput" or "_internal"'):new fe(`Invalid field name "${n}"`,this.position,this.getErrorContext(),"Field names must start with a letter or underscore and contain only letters, numbers, or underscores")}parseParsedString(){let e=["'",'"'];for(let t of e)if(this.match(t)){let n="",r=!1,s=this.position-1;for(;this.position<this.input.length;){let a=this.input[this.position];if(this.position++,r)n+=a,r=!1;else if(a==="\\")r=!0;else{if(a===t)return n;n+=a}}let i=this.input.slice(s,Math.min(this.position,s+20));throw new fe(`Unterminated string starting at position ${s}`,s,this.getErrorContext(),`Add closing ${t} to complete the string: ${i}${t}`)}}skipWhitespace(){let e=/^[\s\t\r\n]+/.exec(this.input.slice(this.position));e&&(this.position+=e[0].length)}match(e){let t;if(typeof e=="string"){if(this.input.startsWith(e,this.position))return this.position+=e.length,!0}else if(t=e.exec(this.input.slice(this.position)),t)return this.position+=t[0].length,!0;return!1}expectArrow(){if(!this.match("->")){let e=this.input.slice(this.position,this.position+10),t=e.includes(">")?'Use "->" (dash followed by greater-than)':e.includes("-")?'Add ">" after the dash':'Add "->" to separate input and output fields';throw new fe(`Expected "->" but found "${e}..."`,this.position,this.getErrorContext(),t)}}};function Qc(o){return new Zi(o).parse()}var jr=class{inputFields=[];outputFields=[];desc;input(e,t,n=!1){let r={name:e,type:{name:t.type,isArray:t.isArray||void 0,options:t.options?[...t.options]:void 0,minLength:t.minLength,maxLength:t.maxLength,minimum:t.minimum,maximum:t.maximum,pattern:t.pattern,patternDescription:t.patternDescription,format:t.format,description:t.itemDescription,fields:t.fields?Object.fromEntries(Object.entries(t.fields).map(([s,i])=>[s,ls(i)])):void 0},description:t.description,isOptional:t.isOptional||void 0,isInternal:t.isInternal||void 0,isCached:t.isCached||void 0};return n?this.inputFields.unshift(r):this.inputFields.push(r),this}output(e,t,n=!1){let r={name:e,type:{name:t.type,isArray:t.isArray||void 0,options:t.options?[...t.options]:void 0,minLength:t.minLength,maxLength:t.maxLength,minimum:t.minimum,maximum:t.maximum,pattern:t.pattern,patternDescription:t.patternDescription,format:t.format,description:t.itemDescription,fields:t.fields?Object.fromEntries(Object.entries(t.fields).map(([s,i])=>[s,ls(i)])):void 0},description:t.description,isOptional:t.isOptional||void 0,isInternal:t.isInternal||void 0};return n?this.outputFields.unshift(r):this.outputFields.push(r),this}addInputFields(e){for(let t of e)this.inputFields.push(t);return this}addOutputFields(e){for(let t of e)this.outputFields.push(t);return this}description(e){return this.desc=e,this}useStructured(){return this._useStructuredOutputs=!0,this}build(){let e={description:this.desc,inputs:this.inputFields,outputs:this.outputFields},t=new Me(e);return this._useStructuredOutputs&&(t._forceComplexFields=!0,t._hasComplexFields=void 0),t}},Ke=class o{type;isArray;options;description;isOptional;isInternal;isCached;fields;minLength;maxLength;minimum;maximum;pattern;patternDescription;format;itemDescription;constructor(e){this.type=e.type,this.isArray=e.isArray,this.options=e.options,this.description=e.description,this.itemDescription=e.itemDescription,this.isOptional=e.isOptional,this.isInternal=e.isInternal,this.isCached=e.isCached,this.fields=e.fields,this.minLength=e.minLength,this.maxLength=e.maxLength,this.minimum=e.minimum,this.maximum=e.maximum,this.pattern=e.pattern,this.patternDescription=e.patternDescription,this.format=e.format}optional(){return new o({...this,isOptional:!0})}array(e){return new o({...this,isArray:!0,description:e||this.description,itemDescription:e?this.description:void 0})}internal(){return new o({...this,isInternal:!0})}cache(){return new o({...this,isCached:!0})}min(e){return this.type==="string"?new o({...this,minLength:e}):this.type==="number"?new o({...this,minimum:e}):this}max(e){return this.type==="string"?new o({...this,maxLength:e}):this.type==="number"?new o({...this,maximum:e}):this}email(){return this.type==="string"?new o({...this,format:"email"}):this}url(){return this.type==="string"?new o({...this,format:"uri"}):this}regex(e,t){return this.type==="string"?new o({...this,pattern:e,patternDescription:t}):this}date(){return this.type==="string"?new o({...this,format:"date"}):this}datetime(){return this.type==="string"?new o({...this,format:"date-time"}):this}},me=Object.assign(()=>new jr,{string:o=>new Ke({type:"string",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),number:o=>new Ke({type:"number",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),boolean:o=>new Ke({type:"boolean",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),json:o=>new Ke({type:"json",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),datetime:o=>new Ke({type:"datetime",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),date:o=>new Ke({type:"date",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),class:(o,e)=>new Ke({type:"class",isArray:!1,options:o,description:e,isOptional:!1,isInternal:!1,isCached:!1}),image:o=>new Ke({type:"image",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),audio:o=>new Ke({type:"audio",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),file:o=>new Ke({type:"file",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),url:o=>new Ke({type:"url",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),email:o=>new Ke({type:"string",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1,format:"email"}),code:(o,e)=>new Ke({type:"code",isArray:!1,description:e||o,isOptional:!1,isInternal:!1,isCached:!1}),object:(o,e)=>new Ke({type:"object",isArray:!1,fields:o,description:e,isOptional:!1,isInternal:!1,isCached:!1})});function ls(o){return{type:o.type,isArray:o.isArray,options:o.options,description:o.description,isOptional:o.isOptional,isInternal:o.isInternal,minLength:o.minLength,maxLength:o.maxLength,minimum:o.minimum,maximum:o.maximum,pattern:o.pattern,patternDescription:o.patternDescription,format:o.format,fields:o.fields?Object.fromEntries(Object.entries(o.fields).map(([e,t])=>[e,ls(t)])):void 0}}function cs(o){return{type:{name:o.type,isArray:o.isArray,options:o.options?[...o.options]:void 0,fields:o.fields},description:o.description,isOptional:o.isOptional,isInternal:o.isInternal}}function ea(o,e){return{name:o,type:{name:e.type,isArray:e.isArray||void 0,options:e.options?[...e.options]:void 0,minLength:e.minLength,maxLength:e.maxLength,minimum:e.minimum,maximum:e.maximum,pattern:e.pattern,patternDescription:e.patternDescription,format:e.format,description:e.itemDescription,fields:e.fields?Object.fromEntries(Object.entries(e.fields).map(([t,n])=>[t,ls(n)])):void 0},description:e.description,isOptional:e.isOptional||void 0,isInternal:e.isInternal||void 0,isCached:e.isCached||void 0}}function Yc(o){return o.length===0?{type:"object",properties:{}}:qt(o,"Schema")}function im(o){let e=ea("__value",o);return qt([e],"Schema").properties?.__value??{type:"json"}}var ta=class{name;desc;ns;argFields=[];returnFields=[];returnFieldType;returnMode;fnHandler;fnExamples=[];constructor(e){this.name=e}description(e){return this.desc=e,this}namespace(e){return this.ns=e,this}arg(e,t){return this.argFields.push(ea(e,t)),this}args(e,t){return this.arg(e,t)}returns(e){if(this.returnMode==="fields")throw new Error("Cannot use fn().returns(...) after fn().returnsField(...); choose exactly one return schema style");return this.returnMode="single",this.returnFieldType=e,this}returnsField(e,t){if(this.returnMode==="single")throw new Error("Cannot use fn().returnsField(...) after fn().returns(...); choose exactly one return schema style");return this.returnMode="fields",this.returnFields.push(ea(e,t)),this}example(e){return this.fnExamples.push(e),this}examples(e){return this.fnExamples.push(...e),this}handler(e){return this.fnHandler=e,this}build(){let e=this.name.trim(),t=this.desc?.trim(),n=this.ns?.trim();if(!e)throw new Error("fn() requires a non-empty function name");if(!t)throw new Error(`Function "${e}" must define a non-empty description`);if(!this.fnHandler)throw new Error(`Function "${e}" must define a handler`);if(this.fnExamples.some(s=>!s.code.trim()))throw new Error(`Function "${e}" examples must define non-empty code`);return{name:e,description:t,...n?{namespace:n}:{},parameters:Yc(this.argFields),...this.returnMode==="single"&&this.returnFieldType?{returns:im(this.returnFieldType)}:this.returnMode==="fields"?{returns:Yc(this.returnFields)}:{},...this.fnExamples.length>0?{examples:this.fnExamples.map(s=>({...s}))}:{},func:this.fnHandler}}},el=o=>new ta(o),ie=class extends Error{constructor(t,n,r){super(t);this.fieldName=n;this.suggestion=r;this.name="AxSignatureValidationError"}},Me=class o{description;inputFields;outputFields;sigHash;sigString;validatedAtHash;constructor(e){if(!e){this.inputFields=[],this.outputFields=[],this.sigHash="",this.sigString="";return}if(typeof e=="string"){let t;try{t=Qc(e)}catch(n){if(n instanceof Error){let r="suggestion"in n&&typeof n.suggestion=="string"?n.suggestion:'Please check the signature format. Example: "userInput:string -> responseText:string"';throw new ie(`Invalid Signature: ${n.message}`,void 0,r)}throw new ie(`Invalid Signature: ${e}`,void 0,'Please check the signature format. Example: "userInput:string -> responseText:string"')}this.description=t.desc,this.inputFields=t.inputs.map(n=>this.parseParsedField(n)),this.outputFields=t.outputs.map(n=>this.parseParsedField(n)),[this.sigHash,this.sigString]=this.updateHash()}else if(e instanceof o)this.description=e.getDescription(),this.inputFields=structuredClone(e.getInputFields()),this.outputFields=structuredClone(e.getOutputFields()),this.sigHash=e.hash(),this.sigString=e.toString(),e.validatedAtHash===this.sigHash&&(this.validatedAtHash=this.sigHash),this._forceComplexFields=e._forceComplexFields,this._hasComplexFields=e._hasComplexFields;else if(typeof e=="object"&&e!==null){if(!("inputs"in e)||!("outputs"in e))throw new ie("Invalid signature object: missing inputs or outputs",void 0,'Signature object must have "inputs" and "outputs" arrays. Example: { inputs: [...], outputs: [...] }');if(!Array.isArray(e.inputs)||!Array.isArray(e.outputs))throw new ie("Invalid signature object: inputs and outputs must be arrays",void 0,'Both "inputs" and "outputs" must be arrays of AxField objects');try{this.description=e.description,this.inputFields=e.inputs.map(t=>this.parseField(t)),this.outputFields=e.outputs.map(t=>this.parseField(t)),[this.sigHash,this.sigString]=this.updateHash()}catch(t){throw t instanceof ie?t:new ie(`Failed to create signature from object: ${t instanceof Error?t.message:"Unknown error"}`,void 0,"Check that all fields in inputs and outputs arrays are valid AxField objects")}}else throw new ie("Invalid signature argument type",void 0,"Signature must be a string, another AxSignature instance, or an object with inputs and outputs arrays")}static create(e){return new o(e)}parseParsedField=e=>{if(!e.name||e.name.length===0)throw new ie("Field name is required",e.name,'Every field must have a descriptive name. Example: "userInput", "responseText"');let t=this.toTitle(e.name);return{name:e.name,title:t,description:"desc"in e?e.desc:void 0,type:e.type??{name:"string",isArray:!1},..."isInternal"in e?{isInternal:e.isInternal}:{},..."isOptional"in e?{isOptional:e.isOptional}:{}}};parseField=e=>{let t=!e.title||e.title.length===0?this.toTitle(e.name):e.title;if(e.type&&(!e.type.name||e.type.name.length===0))throw new ie("Field type name is required",e.name,"Specify a valid type. Available types: string, number, boolean, json, image, audio, file, url, date, datetime, class, code");return{...e,title:t}};setDescription=e=>{if(typeof e!="string")throw new ie("Description must be a string",void 0,"Provide a string description for the signature");this.description=e,this.invalidateValidationCache(),this.updateHashLight()};addInputField=e=>{try{let t=this.parseField(e);Mt(t,"input");for(let n of this.inputFields)if(n.name===t.name)throw new ie(`Duplicate input field name: "${t.name}"`,t.name,"Each field name must be unique within the signature");for(let n of this.outputFields)if(n.name===t.name)throw new ie(`Field name "${t.name}" appears in both inputs and outputs`,t.name,"Use different names for input and output fields to avoid confusion");this.inputFields.push(t),this.invalidateValidationCache(),this.updateHashLight()}catch(t){throw t instanceof ie?t:new ie(`Failed to add input field "${e.name}": ${t instanceof Error?t.message:"Unknown error"}`,e.name)}};addOutputField=e=>{try{let t=this.parseField(e);Mt(t,"output");for(let n of this.outputFields)if(n.name===t.name)throw new ie(`Duplicate output field name: "${t.name}"`,t.name,"Each field name must be unique within the signature");for(let n of this.inputFields)if(n.name===t.name)throw new ie(`Field name "${t.name}" appears in both inputs and outputs`,t.name,"Use different names for input and output fields to avoid confusion");this.outputFields.push(t),this.invalidateValidationCache(),this.updateHashLight()}catch(t){throw t instanceof ie?t:new ie(`Failed to add output field "${e.name}": ${t instanceof Error?t.message:"Unknown error"}`,e.name)}};setInputFields=e=>{if(!Array.isArray(e))throw new ie("Input fields must be an array",void 0,"Provide an array of field objects");try{let t=e.map(n=>{let r=this.parseField(n);return Mt(r,"input"),r});this.inputFields=t,this.invalidateValidationCache(),this.updateHashLight()}catch(t){throw t instanceof ie?t:new ie(`Failed to set input fields: ${t instanceof Error?t.message:"Unknown error"}`)}};setOutputFields=e=>{if(!Array.isArray(e))throw new ie("Output fields must be an array",void 0,"Provide an array of field objects");try{let t=e.map(n=>{let r=this.parseField(n);return Mt(r,"output"),r});this.outputFields=t,this.invalidateValidationCache(),this.updateHashLight()}catch(t){throw t instanceof ie?t:new ie(`Failed to set output fields: ${t instanceof Error?t.message:"Unknown error"}`)}};getInputFields=()=>this.inputFields;getOutputFields=()=>this.outputFields;getDescription=()=>this.description;appendInputField=(e,t)=>{let n=new o(this);return n.addInputField({name:e,...cs(t)}),n};prependInputField=(e,t)=>{let n=new o(this),r={name:e,...cs(t)},s=n.parseField(r);Mt(s,"input");for(let i of n.inputFields)if(i.name===s.name)throw new ie(`Duplicate input field name: "${s.name}"`,s.name,"Each field name must be unique within the signature");for(let i of n.outputFields)if(i.name===s.name)throw new ie(`Field name "${s.name}" appears in both inputs and outputs`,s.name,"Use different names for input and output fields to avoid confusion");return n.inputFields.unshift(s),n.invalidateValidationCache(),n.updateHashLight(),n};appendOutputField=(e,t)=>{let n=new o(this);return n.addOutputField({name:e,...cs(t)}),n};prependOutputField=(e,t)=>{let n=new o(this),r={name:e,...cs(t)},s=n.parseField(r);Mt(s,"output");for(let i of n.outputFields)if(i.name===s.name)throw new ie(`Duplicate output field name: "${s.name}"`,s.name,"Each field name must be unique within the signature");for(let i of n.inputFields)if(i.name===s.name)throw new ie(`Field name "${s.name}" appears in both inputs and outputs`,s.name,"Use different names for input and output fields to avoid confusion");return n.outputFields.unshift(s),n.invalidateValidationCache(),n.updateHashLight(),n};invalidateValidationCache=()=>{this.validatedAtHash=void 0,this._hasComplexFields=void 0};toTitle=e=>{let t=e.replace(/_/g," ");return t=t.replace(/([A-Z]|[0-9]+)/g," $1").trim(),t.charAt(0).toUpperCase()+t.slice(1)};updateHashLight=()=>{try{return this.getInputFields().forEach(e=>{Mt(e,"input")}),this.getOutputFields().forEach(e=>{Mt(e,"output")}),this.sigHash=pt("sha256").update(JSON.stringify(this.inputFields)).update(JSON.stringify(this.outputFields)).digest("hex"),this.sigString=Zc(this.description,this.inputFields,this.outputFields),this._hasComplexFields=this.computeHasComplexFields(),[this.sigHash,this.sigString]}catch(e){throw e instanceof ie?e:new ie(`Signature validation failed: ${e instanceof Error?e.message:"Unknown error"}`)}};updateHash=()=>{try{return this.getInputFields().forEach(e=>{Mt(e,"input")}),this.getOutputFields().forEach(e=>{Mt(e,"output")}),this.validateSignatureConsistency(),this.sigHash=pt("sha256").update(this.description??"").update(JSON.stringify(this.inputFields)).update(JSON.stringify(this.outputFields)).digest("hex"),this.sigString=Zc(this.description,this.inputFields,this.outputFields),this._hasComplexFields=this.computeHasComplexFields(),[this.sigHash,this.sigString]}catch(e){throw e instanceof ie?e:new ie(`Signature validation failed: ${e instanceof Error?e.message:"Unknown error"}`)}};validateSignatureConsistency(){let e=new Set;for(let n of this.inputFields){if(e.has(n.name))throw new ie(`Duplicate input field name: "${n.name}"`,n.name,"Each field name must be unique within the signature");e.add(n.name)}let t=new Set;for(let n of this.outputFields){if(t.has(n.name))throw new ie(`Duplicate output field name: "${n.name}"`,n.name,"Each field name must be unique within the signature");t.add(n.name)}for(let n of this.outputFields)if(e.has(n.name))throw new ie(`Field name "${n.name}" appears in both inputs and outputs`,n.name,"Use different names for input and output fields to avoid confusion");if(this.inputFields.length===0)throw new ie("Signature must have at least one input field",void 0,'Add an input field. Example: "userInput:string -> ..."');if(this.outputFields.length===0)throw new ie("Signature must have at least one output field",void 0,'Add an output field. Example: "... -> responseText:string"')}_forceComplexFields=!1;_hasComplexFields;hasComplexFields=()=>this._hasComplexFields!==void 0?this._hasComplexFields:(this._hasComplexFields=this.computeHasComplexFields(),this._hasComplexFields);computeHasComplexFields=()=>this._forceComplexFields?!0:this.outputFields.some(e=>e.type?.name==="object"||e.type?.isArray&&e.type.fields!==void 0);validate=()=>{if(this.validatedAtHash===this.sigHash)return!0;try{return this.updateHash(),this.validatedAtHash=this.sigHash,!0}catch(e){throw this.validatedAtHash=void 0,e}};hash=()=>this.sigHash;toString=()=>this.sigString;toJSON=()=>({id:this.hash(),description:this.description,inputFields:this.inputFields,outputFields:this.outputFields});toJSONSchema=()=>{let e=[...this.inputFields,...this.outputFields];return qt(e,this.description??"Schema")};toInputJSONSchema=()=>qt(this.inputFields,this.description??"Schema")};function Xc(o){let e=o.name;return o.isOptional&&(e+="?"),o.isInternal&&(e+="!"),o.type&&(e+=`:${o.type.name}`,o.type.isArray&&(e+="[]"),o.type.name==="class"&&o.type.options&&(e+=` "${o.type.options.join(" | ")}"`)),o.description&&o.type?.name!=="class"&&(e+=` "${o.description}"`),e}function Zc(o,e,t){let n=o?`"${o}" `:"",r=e.map(Xc).join(", "),s=t.map(Xc).join(", ");return`${n}${r} -> ${s}`}function am(o){let e=/^[a-z][a-zA-Z0-9]*$/,t=/^[a-z]+(_[a-z0-9]+)*$/;return e.test(o)||t.test(o)}function Mt(o,e){if(!o.name||o.name.length===0)throw new ie("Field name cannot be blank",o.name,"Every field must have a descriptive name");if(!am(o.name))throw new ie(`Invalid field name '${o.name}' - must be camelCase or snake_case`,o.name,'Use camelCase (e.g., "userInput") or snake_case (e.g., "user_input")');if(ge.signatureStrict&&["text","object","image","string","number","boolean","json","array","datetime","date","time","type","class","input","output","data","value","result","response","request","item","element"].includes(o.name.toLowerCase())){let n=e==="input"?["userInput","questionText","documentContent","messageText","queryString"]:["responseText","analysisResult","categoryType","summaryText","outputData"];throw new ie(`Field name '${o.name}' is too generic`,o.name,`Use a more descriptive name. Examples for ${e} fields: ${n.join(", ")}`)}if(o.name.length<2)throw new ie(`Field name '${o.name}' is too short`,o.name,"Field names must be at least 2 characters long");if(o.name.length>50)throw new ie(`Field name '${o.name}' is too long (${o.name.length} characters)`,o.name,"Field names should be 50 characters or less");o.type&&um(o,e)}function um(o,e){if(!o.type)return;let{type:t}=o;if((t.name==="image"||t.name==="audio"||t.name==="file")&&e==="output")throw new ie(`${t.name} type is not supported in output fields`,o.name,`${t.name} types can only be used in input fields`);if(t.name==="class"){if(e==="input")throw new ie("Class type is not supported in input fields",o.name,'Class types are only allowed on output fields. Use "string" type for input classifications');if(!t.options||t.options.length===0)throw new ie("Class type requires options",o.name,'Provide class options. Example: class "positive, negative, neutral"');for(let r of t.options){if(!r||r.trim().length===0)throw new ie("Empty class option found",o.name,"All class options must be non-empty strings");let s=r.trim();if(s.includes(",")||s.includes("|"))throw new ie(`Invalid class option "${s}"`,o.name,"Class options cannot contain commas (,) or pipes (|) as they are used to separate options")}if(new Set(t.options.map(r=>r.trim().toLowerCase())).size!==t.options.length)throw new ie("Duplicate class options found",o.name,"Each class option must be unique (case-insensitive)")}if(t.name==="code"&&t.isArray)throw new ie("Arrays of code are not commonly supported",o.name,"Consider using a single code field or an array of strings instead");if(o.isInternal&&e==="input")throw new ie("Internal marker (!) is not allowed on input fields",o.name,"Internal markers are only allowed on output fields");t.name==="object"&&t.fields&&na(t.fields,o.name,e)}function na(o,e,t,n=1){for(let[r,s]of Object.entries(o)){let i=`${e}.${r}`;if(s.type==="image"||s.type==="audio"||s.type==="file")throw new ie(`${s.type} type is not allowed in nested object fields`,i,`Media types (image, audio, file) can only be used as top-level input fields, not within objects. Found at depth ${n}.`);s.type==="object"&&s.fields&&na(s.fields,i,t,n+1),s.isArray&&s.fields&&na(s.fields,`${i}[]`,t,n+1)}}var Ht=class o{signature;sigHash;examples;examplesOptions;demos;trace;usage=[];traceLabel;key;children;childNames=new Map;childCount=0;constructor(e,t){this.signature=new Me(e),t?.description&&this.signature.setDescription(t.description),t?.traceLabel&&(this.traceLabel=t.traceLabel),e&&this.signature.validate(),this.sigHash=this.signature?.hash(),this.children=new qn,this.key={id:"root"}}getSignature(){return new Me(this.signature)}setSignature(e){this.signature=new Me(e),e&&this.signature.validate(),this.updateSignatureHash()}setDescription(e){this.signature.setDescription(e),this.updateSignatureHash()}updateSignatureHash(){this.sigHash=this.signature.hash()}getId(){return this.key.id}register(e,t){let n=t??`p${this.childCount}`;this.childCount++,e.setId([this.key.id,n].join(".")),this.childNames.set(e,n),this.children.register(e)}setId(e){this.key={id:e,custom:!0};for(let[t,n]of this.childNames)t.setId([e,n].join("."))}setExamples(e,t){let n=[];if("programId"in e&&e.programId===this.key.id&&(n=e.traces),Array.isArray(e)&&(n=e),n){this.examplesOptions=t;let r=this.signature,s=[...r.getInputFields(),...r.getOutputFields()];this.examples=n.map(i=>{let a={};for(let u of s){let c=i[u.name];c!==void 0&&(Nr(u,c),a[u.name]=c)}return a})}}getTraces(){let e=[];this.trace&&e.push({trace:this.trace,programId:this.key.id});for(let t of Array.from(this.children)){let n=t?.getTraces();e=[...e,...n??[]]}return e}getUsage(){let e=[...this.usage??[]];for(let t of Array.from(this.children)){let n=t?.getUsage();e=[...e,...n??[]]}return Lr(e)}resetUsage(){this.usage=[];for(let e of Array.from(this.children))e?.resetUsage()}static _propagating=!1;setDemos(e,t){if(!o._propagating&&e.length>0){let c=new Set(this.namedPrograms().map(p=>p.id)),l=[...new Set(e.map(p=>p.programId))].filter(p=>!c.has(p));if(l.length>0){let p=[...c].join(", ");throw new Error(`Unknown program ID(s) in demos: ${l.join(", ")}. Valid IDs: ${p}. Use namedPrograms() to discover available IDs.`)}}let n=e.filter(c=>c.programId===this.key.id).map(c=>c.traces).flat(),r=this.signature,s=[...r.getInputFields(),...r.getOutputFields()],i=new Set(r.getInputFields().map(c=>c.name)),a=new Set(r.getOutputFields().map(c=>c.name));this.demos=n.map((c,l)=>{let p={};for(let g of s){let f=c[g.name];f!==void 0&&(Nr(g,f),p[g.name]=f)}let d=Object.keys(p).some(g=>i.has(g));if(!Object.keys(p).some(g=>a.has(g)))throw new Error(`Demo trace[${l}] for '${this.key.id}' has no output field values. Expected at least one of: ${[...a].join(", ")}`);if(!d)throw new Error(`Demo trace[${l}] for '${this.key.id}' has no input field values. Expected at least one of: ${[...i].join(", ")}. Provide input context so the demo renders as a complete few-shot example.`);return p}),t?.modelConfig&&(this._optimizedModelConfig=t.modelConfig);let u=o._propagating;o._propagating=!0;try{for(let c of Array.from(this.children))c?.setDemos(e,t)}finally{o._propagating=u}}namedPrograms(){let e=[];[...this.signature.getInputFields(),...this.signature.getOutputFields()].length>0&&e.push({id:this.key.id,signature:this.signature.toString()});for(let n of Array.from(this.children))n&&"namedPrograms"in n&&typeof n.namedPrograms=="function"?e.push(...n.namedPrograms()):n&&e.push({id:n.getId()});return e}namedProgramInstances(){let e=[];[...this.signature.getInputFields(),...this.signature.getOutputFields()].length>0&&e.push({id:this.key.id,program:this,signature:this.signature.toString()});for(let n of Array.from(this.children))n&&"namedProgramInstances"in n&&typeof n.namedProgramInstances=="function"?e.push(...n.namedProgramInstances()):n&&e.push({id:n.getId(),program:n});return e}applyOptimization(e){let t=e.demos!==void 0,n=e.modelConfig!==void 0;(t||n)&&this.setDemos(e.demos??[],{modelConfig:e.modelConfig});let r=this;if(typeof r.setInstruction=="function"){let i=e.instructionMap?.[this.key.id],a=typeof i=="string"?i:e.instruction;typeof a=="string"&&a.length>0&&r.setInstruction(a)}let s={...e,...t?{demos:void 0}:{},...n?{modelConfig:void 0}:{}};for(let i of Array.from(this.children))i?.applyOptimization(s)}};var tl={"dsp/example-disclaimer.md":`## Example Demonstrations
218
218
  The conversation history preceding the final user query consists of **few-shot examples** (demonstrations).
219
219
  - These alternating User/Assistant messages are provided **solely** to illustrate the correct reasoning steps, function usage, and output format.
220
220
  - **Do not** treat the specific data, entities, or facts in these examples as valid context for the current task.
@@ -711,12 +711,12 @@ You synthesize a final answer from the provided actorResult payload. In normal \
711
711
  1. Base your answer ONLY on evidence from actorResult payload arguments.
712
712
  2. If actorResult lacks sufficient information, provide the best possible answer from available evidence.
713
713
  3. If an internal or evaluation workflow provides \`actorResult.type = ask_clarification\`, ask for the missing information clearly in your output fields.
714
- `};var Xi=/{{\s*([^}]+?)\s*}}/g,zc=/^[A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)*$/,Hc=/^([A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)*)\s*===\s*(?:'([^']*)'|"([^"]*)")$/,qc=new Map;function Pt(o,e,t,n){let s=e.slice(0,t).split(`
715
- `),i=s.length,a=(s.at(-1)?.length??0)+1;return`${o}:${i}:${a} ${n}`}function Td(o){let e=[],t=0;Xi.lastIndex=0;let n=Xi.exec(o);for(;n;){let[r,s]=n,i=n.index;i>t&&e.push({type:"text",value:o.slice(t,i)}),e.push({type:"tag",value:s.trim(),index:i}),t=i+r.length,n=Xi.exec(o)}return t<o.length&&e.push({type:"text",value:o.slice(t)}),e}function ea(o,e,t,n=0,r=new Set){let s=[],i=n;for(;i<o.length;){let a=o[i];if(a.type==="text"){s.push({type:"text",value:a.value}),i++;continue}let l=a.value;if(r.has(l))return{nodes:s,nextIndex:i,terminator:l};if(l.startsWith("if ")){let c=l.slice(3).trim();if(!zc.test(c)&&!Hc.test(c))throw new Error(Pt(t,e,a.index,`Invalid if condition '${c}'`));let u=ea(o,e,t,i+1,new Set(["else","/if"]));if(!u.terminator)throw new Error(Pt(t,e,a.index,"Unclosed 'if' block"));let p=[],d=u.nextIndex+1;if(u.terminator==="else"){let m=ea(o,e,t,u.nextIndex+1,new Set(["/if"]));if(m.terminator!=="/if")throw new Error(Pt(t,e,a.index,"Unclosed 'if' block"));p=m.nodes,d=m.nextIndex+1}s.push({type:"if",condition:c,thenNodes:u.nodes,elseNodes:p,index:a.index}),i=d;continue}if(l==="else")throw new Error(Pt(t,e,a.index,"Unexpected 'else'"));if(l==="/if")throw new Error(Pt(t,e,a.index,"Unexpected '/if'"));if(l.startsWith("include "))throw new Error(Pt(t,e,a.index,"Unexpected 'include' directive at runtime (includes must be compiled)"));if(!zc.test(l))throw new Error(Pt(t,e,a.index,`Invalid tag '${l}'`));s.push({type:"var",name:l,index:a.index}),i++}return{nodes:s,nextIndex:i}}function Zi(o,e,t,n,r){let s=e.split("."),i=o;for(let a of s){if(i===null||typeof i!="object"||!(a in i))throw new Error(Pt(n,t,r,`Missing template variable '${e}'`));i=i[a]}return i}function ta(o,e,t,n){let r="";for(let s of o){if(s.type==="text"){r+=s.value;continue}if(s.type==="var"){let l=Zi(e,s.name,t,n,s.index);if(typeof l!="string"&&typeof l!="number"&&typeof l!="boolean")throw new Error(Pt(n,t,s.index,`Variable '${s.name}' must be string, number, or boolean`));r+=String(l);continue}let i,a=Hc.exec(s.condition);if(a){let[,l,c,u]=a,p=c??u??"";i=Zi(e,l,t,n,s.index)===p}else{let l=Zi(e,s.condition,t,n,s.index);if(typeof l!="boolean")throw new Error(Pt(n,t,s.index,`Condition '${s.condition}' must be boolean`));i=l}i?r+=ta(s.thenNodes,e,t,n):r+=ta(s.elseNodes,e,t,n)}return r}function Cd(o,e){let t=Td(o),n=ea(t,o,e);if(n.terminator)throw new Error(`Unexpected template terminator '${n.terminator}' in ${e}`);return n.nodes}function yt(o,e={}){let t=jc[o],n=`template:${o}`;if(!t)throw new Error(`Unknown template id: ${String(o)}`);let r=qc.get(o);return r||(r=Cd(t,n),qc.set(o,r)),ta(r,e,t,n)}var Kc=yt("dsp/function-call-instructions.md"),Id=yt("dsp/strict-output-formatting-rules.md"),wd=yt("dsp/example-disclaimer.md"),Bn=yt("dsp/example-separator.md"),rn=class{sig;fieldTemplates;task;customInstruction;setInstruction(e){this.customInstruction=e,this.task={type:"text",text:e}}getInstruction(){return this.customInstruction}thoughtFieldName;functions;contextCache;examplesInSystem;ignoreBreakpoints;structuredOutputFunctionName;constructor(e,t,n){this.sig=e,this.fieldTemplates=n,this.thoughtFieldName=t?.thoughtFieldName??"thought",this.functions=t?.functions,this.contextCache=t?.contextCache,this.examplesInSystem=t?.examplesInSystem??!1,this.ignoreBreakpoints=t?.ignoreBreakpoints??!1,this.structuredOutputFunctionName=t?.structuredOutputFunctionName,de.useStructuredPrompt?this.task=this.buildStructuredPrompt():this.task=this.buildLegacyPrompt()}getFieldNameToTitleMap=()=>{let e=new Map;for(let t of this.sig.getInputFields())e.set(t.name,t.title);for(let t of this.sig.getOutputFields())e.set(t.name,t.title);return e};sortFieldsCachedFirst=e=>[...e].sort((t,n)=>t.isCached&&!n.isCached?-1:!t.isCached&&n.isCached?1:0);buildLegacyPrompt(){let e=[],t=this.sig.hasComplexFields(),n=as(this.sig.getInputFields()),r=as(this.sig.getOutputFields());e.push(`You will be provided with the following fields: ${n}. Your task is to generate new fields: ${r}.`);let i=this.functions?.map(u=>"toFunction"in u?u.toFunction():u)?.flat()?.map(u=>`- \`${u.name}\`: ${jn(u.description)}`).join(`
714
+ `};var ra=/{{\s*([^}]+?)\s*}}/g,nl=/^[A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)*$/,ol=/^([A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)*)\s*===\s*(?:'([^']*)'|"([^"]*)")$/,rl=new Map;function Pt(o,e,t,n){let s=e.slice(0,t).split(`
715
+ `),i=s.length,a=(s.at(-1)?.length??0)+1;return`${o}:${i}:${a} ${n}`}function cm(o){let e=[],t=0;ra.lastIndex=0;let n=ra.exec(o);for(;n;){let[r,s]=n,i=n.index;i>t&&e.push({type:"text",value:o.slice(t,i)}),e.push({type:"tag",value:s.trim(),index:i}),t=i+r.length,n=ra.exec(o)}return t<o.length&&e.push({type:"text",value:o.slice(t)}),e}function sa(o,e,t,n=0,r=new Set){let s=[],i=n;for(;i<o.length;){let a=o[i];if(a.type==="text"){s.push({type:"text",value:a.value}),i++;continue}let u=a.value;if(r.has(u))return{nodes:s,nextIndex:i,terminator:u};if(u.startsWith("if ")){let c=u.slice(3).trim();if(!nl.test(c)&&!ol.test(c))throw new Error(Pt(t,e,a.index,`Invalid if condition '${c}'`));let l=sa(o,e,t,i+1,new Set(["else","/if"]));if(!l.terminator)throw new Error(Pt(t,e,a.index,"Unclosed 'if' block"));let p=[],d=l.nextIndex+1;if(l.terminator==="else"){let m=sa(o,e,t,l.nextIndex+1,new Set(["/if"]));if(m.terminator!=="/if")throw new Error(Pt(t,e,a.index,"Unclosed 'if' block"));p=m.nodes,d=m.nextIndex+1}s.push({type:"if",condition:c,thenNodes:l.nodes,elseNodes:p,index:a.index}),i=d;continue}if(u==="else")throw new Error(Pt(t,e,a.index,"Unexpected 'else'"));if(u==="/if")throw new Error(Pt(t,e,a.index,"Unexpected '/if'"));if(u.startsWith("include "))throw new Error(Pt(t,e,a.index,"Unexpected 'include' directive at runtime (includes must be compiled)"));if(!nl.test(u))throw new Error(Pt(t,e,a.index,`Invalid tag '${u}'`));s.push({type:"var",name:u,index:a.index}),i++}return{nodes:s,nextIndex:i}}function oa(o,e,t,n,r){let s=e.split("."),i=o;for(let a of s){if(i===null||typeof i!="object"||!(a in i))throw new Error(Pt(n,t,r,`Missing template variable '${e}'`));i=i[a]}return i}function ia(o,e,t,n){let r="";for(let s of o){if(s.type==="text"){r+=s.value;continue}if(s.type==="var"){let u=oa(e,s.name,t,n,s.index);if(typeof u!="string"&&typeof u!="number"&&typeof u!="boolean")throw new Error(Pt(n,t,s.index,`Variable '${s.name}' must be string, number, or boolean`));r+=String(u);continue}let i,a=ol.exec(s.condition);if(a){let[,u,c,l]=a,p=c??l??"";i=oa(e,u,t,n,s.index)===p}else{let u=oa(e,s.condition,t,n,s.index);if(typeof u!="boolean")throw new Error(Pt(n,t,s.index,`Condition '${s.condition}' must be boolean`));i=u}i?r+=ia(s.thenNodes,e,t,n):r+=ia(s.elseNodes,e,t,n)}return r}function lm(o,e){let t=cm(o),n=sa(t,o,e);if(n.terminator)throw new Error(`Unexpected template terminator '${n.terminator}' in ${e}`);return n.nodes}function yt(o,e={}){let t=tl[o],n=`template:${o}`;if(!t)throw new Error(`Unknown template id: ${String(o)}`);let r=rl.get(o);return r||(r=lm(t,n),rl.set(o,r)),ia(r,e,t,n)}var sl=yt("dsp/function-call-instructions.md"),pm=yt("dsp/strict-output-formatting-rules.md"),dm=yt("dsp/example-disclaimer.md"),Hn=yt("dsp/example-separator.md"),Kt=class{sig;fieldTemplates;task;customInstruction;setInstruction(e){this.customInstruction=e,this.task={type:"text",text:e}}getInstruction(){return this.customInstruction}thoughtFieldName;functions;contextCache;examplesInSystem;ignoreBreakpoints;structuredOutputFunctionName;constructor(e,t,n){this.sig=e,this.fieldTemplates=n,this.thoughtFieldName=t?.thoughtFieldName??"thought",this.functions=t?.functions,this.contextCache=t?.contextCache,this.examplesInSystem=t?.examplesInSystem??!1,this.ignoreBreakpoints=t?.ignoreBreakpoints??!1,this.structuredOutputFunctionName=t?.structuredOutputFunctionName,ge.useStructuredPrompt?this.task=this.buildStructuredPrompt():this.task=this.buildLegacyPrompt()}getFieldNameToTitleMap=()=>{let e=new Map;for(let t of this.sig.getInputFields())e.set(t.name,t.title);for(let t of this.sig.getOutputFields())e.set(t.name,t.title);return e};sortFieldsCachedFirst=e=>[...e].sort((t,n)=>t.isCached&&!n.isCached?-1:!t.isCached&&n.isCached?1:0);buildLegacyPrompt(){let e=[],t=this.sig.hasComplexFields(),n=ps(this.sig.getInputFields()),r=ps(this.sig.getOutputFields());e.push(`You will be provided with the following fields: ${n}. Your task is to generate new fields: ${r}.`);let i=this.functions?.map(l=>"toFunction"in l?l.toFunction():l)?.flat()?.map(l=>`- \`${l.name}\`: ${Kn(l.description)}`).join(`
716
716
  `);i&&i.length>0&&e.push(`## Available Functions
717
- ${i}`);let a=this.getFieldNameToTitleMap(),l=Wc(this.sig.getInputFields(),a);if(e.push(`## Input Fields
718
- ${l}`),!t){let u=Vc(this.sig.getOutputFields(),a);e.push(`## Output Fields
719
- ${u}`)}i&&i.length>0&&e.push(Kc.trim()),t&&this.structuredOutputFunctionName?e.push(yt("dsp/legacy-formatting-rules-structured-function.md",{structuredOutputFunctionName:this.structuredOutputFunctionName}).trim()):t||e.push(Id.trim());let c=this.sig.getDescription();if(c){let u=jn(c);u=ls(u,a),e.push(u)}return{type:"text",text:e.join(`
717
+ ${i}`);let a=this.getFieldNameToTitleMap(),u=il(this.sig.getInputFields(),a);if(e.push(`## Input Fields
718
+ ${u}`),!t){let l=al(this.sig.getOutputFields(),a);e.push(`## Output Fields
719
+ ${l}`)}i&&i.length>0&&e.push(sl.trim()),t&&this.structuredOutputFunctionName?e.push(yt("dsp/legacy-formatting-rules-structured-function.md",{structuredOutputFunctionName:this.structuredOutputFunctionName}).trim()):t||e.push(pm.trim());let c=this.sig.getDescription();if(c){let l=Kn(c);l=ds(l,a),e.push(l)}return{type:"text",text:e.join(`
720
720
 
721
721
  `)}}buildStructuredPrompt(){let e=[],t=this.sig.hasComplexFields();e.push("<identity>"),e.push(this.buildIdentitySection()),e.push("</identity>");let n=this.buildTaskDefinitionSection();n&&(e.push(`
722
722
  <task_definition>`),e.push(n),e.push("</task_definition>"));let r=this.functions?.flatMap(s=>"toFunction"in s?s.toFunction():s);return r&&r.length>0&&(e.push(`
@@ -724,71 +724,71 @@ ${u}`)}i&&i.length>0&&e.push(Kc.trim()),t&&this.structuredOutputFunctionName?e.p
724
724
  <input_fields>`),e.push(this.buildInputFieldsSection()),e.push("</input_fields>"),t||(e.push(`
725
725
  <output_fields>`),e.push(this.buildOutputFieldsSection()),e.push("</output_fields>")),e.push(`
726
726
  <formatting_rules>`),e.push(this.buildFormattingRulesSection()),e.push("</formatting_rules>"),{type:"text",text:e.join(`
727
- `)}}buildIdentitySection(){let e=as(this.sig.getInputFields()),t=as(this.sig.getOutputFields());return`You will be provided with the following fields: ${e}. Your task is to generate new fields: ${t}.`}buildTaskDefinitionSection(){let e=this.sig.getDescription();if(!e)return"";let t=this.getFieldNameToTitleMap(),n=jn(e);return n=ls(n,t),n}buildFunctionsSection(e){let t=[];t.push(`**Available Functions**: You can call the following functions to complete the task:
728
- `);let n=e.map(r=>`- \`${r.name}\`: ${jn(r.description??"")}`).join(`
727
+ `)}}buildIdentitySection(){let e=ps(this.sig.getInputFields()),t=ps(this.sig.getOutputFields());return`You will be provided with the following fields: ${e}. Your task is to generate new fields: ${t}.`}buildTaskDefinitionSection(){let e=this.sig.getDescription();if(!e)return"";let t=this.getFieldNameToTitleMap(),n=Kn(e);return n=ds(n,t),n}buildFunctionsSection(e){let t=[];t.push(`**Available Functions**: You can call the following functions to complete the task:
728
+ `);let n=e.map(r=>`- \`${r.name}\`: ${Kn(r.description??"")}`).join(`
729
729
  `);return t.push(n),t.push(`
730
- ${Kc.trim()}`),t.join(`
730
+ ${sl.trim()}`),t.join(`
731
731
  `)}buildInputFieldsSection(){let e=this.getFieldNameToTitleMap();return`**Input Fields**: The following fields will be provided to you:
732
732
 
733
- ${Wc(this.sig.getInputFields(),e)}`}buildOutputFieldsSection(){let e=this.getFieldNameToTitleMap();return`**Output Fields**: You must generate the following fields:
733
+ ${il(this.sig.getInputFields(),e)}`}buildOutputFieldsSection(){let e=this.getFieldNameToTitleMap();return`**Output Fields**: You must generate the following fields:
734
734
 
735
- ${Vc(this.sig.getOutputFields(),e)}`}buildFormattingRulesSection(){let e=this.sig.hasComplexFields();return e&&this.structuredOutputFunctionName?yt("dsp/formatting-rules-structured-function.md",{structuredOutputFunctionName:this.structuredOutputFunctionName}).trim():e?yt("dsp/formatting-rules-structured-json.md").trim():yt("dsp/formatting-rules-plain-text.md").trim()}renderSingleValueUserContent=(e,t,n,r)=>{let s=this.renderInputFields(e),i;if(r)i=s;else{let l=[...t,...n];if(this.contextCache&&l.length>0){let c=l.length-1,u=l[c];u&&(l[c]={...u,cache:!0})}i=[...l,...s]}let a=i.filter(l=>l!==void 0);return a.every(l=>l.type==="text")?a.map(l=>l.text).join(`
736
- `):a.reduce(nn(`
735
+ ${al(this.sig.getOutputFields(),e)}`}buildFormattingRulesSection(){let e=this.sig.hasComplexFields();return e&&this.structuredOutputFunctionName?yt("dsp/formatting-rules-structured-function.md",{structuredOutputFunctionName:this.structuredOutputFunctionName}).trim():e?yt("dsp/formatting-rules-structured-json.md").trim():yt("dsp/formatting-rules-plain-text.md").trim()}renderSingleValueUserContent=(e,t,n,r)=>{let s=this.renderInputFields(e),i;if(r)i=s;else{let u=[...t,...n];if(this.contextCache&&u.length>0){let c=u.length-1,l=u[c];l&&(u[c]={...l,cache:!0})}i=[...u,...s]}let a=i.filter(u=>u!==void 0);return a.every(u=>u.type==="text")?a.map(u=>u.text).join(`
736
+ `):a.reduce(on(`
737
737
  `),[])};render=(e,{examples:t,demos:n})=>{if(!this.examplesInSystem)return this.renderWithMessagePairs(e,{examples:t,demos:n});let r=t?[{type:"text",text:`
738
738
 
739
739
  ## Examples
740
- `},...this.renderExamples(t)]:[],s=n?this.renderDemos(n):[],i=r.every(d=>d.type==="text"),a=s.every(d=>d.type==="text"),l=i&&a,c=this.task.text;if(l){let d=[{type:"text",text:c},...r,...s];d.reduce(nn(""),[]),d?.[0]&&(c=d[0].text)}let u={role:"system",content:c,cache:!!this.contextCache};if(Array.isArray(e)){let d=[],m=e,g=!0;for(let f of m){let x;if(g?(x=this.renderSingleValueUserContent(f.values,r,s,l),g=!1):x=this.renderSingleValueUserContent(f.values,[],[],!1),f.role==="user"){d.push({role:"user",content:x});continue}if(f.role!=="assistant")throw new Error("Invalid message role");if(typeof x!="string")throw new Error("Assistant message cannot contain non-text content like images, files,etc");d.push({role:"assistant",content:x})}return[u,...d]}let p=this.renderSingleValueUserContent(e,r,s,l);return[u,{role:"user",content:p}]};renderWithMessagePairs=(e,{examples:t,demos:n})=>{let r=t&&t.length>0||n&&n.length>0,i={role:"system",content:r?`${this.task.text}
741
- ${wd}`:this.task.text,cache:!!this.contextCache},a=t?this.renderExamplesAsMessages(t):[],l=n?this.renderDemosAsMessages(n):[],c=[];for(let C of[...a,...l])c.push(C.userMessage),c.push(C.assistantMessage),C.functionResultMessage&&c.push(C.functionResultMessage);let u=this.contextCache?.cacheBreakpoint??"after-examples",p=this.ignoreBreakpoints||u==="after-examples";if(this.contextCache&&c.length>0&&p){let C=c.length-1,v=c[C];v?.role==="assistant"&&(c[C]={...v,cache:!0})}if(Array.isArray(e)){let C=[],v=e,k=!0;for(let R of v){let E=this.renderInputFields(R.values),S=E.every(_=>_.type==="text")?E.map(_=>_.text).join(`
742
- `):E.reduce(nn(`
743
- `),[]);if(R.role==="user"){k&&r&&(typeof S=="string"?S=Bn+S:S=[{type:"text",text:Bn},...S],k=!1),C.push({role:"user",content:S});continue}if(R.role!=="assistant")throw new Error("Invalid message role");if(typeof S!="string")throw new Error("Assistant message cannot contain non-text content like images, files, etc");C.push({role:"assistant",content:S})}return[i,...c,...C]}let d=this.sig.getInputFields(),m=d.filter(C=>C.isCached),g=d.filter(C=>!C.isCached),f=m.length>0;if(this.contextCache&&f&&(this.ignoreBreakpoints||u!=="system"&&u!=="after-functions")&&g.length>0){let C=m.map(E=>this.renderInField(E,e,void 0)).filter(E=>E!==void 0).flat();C.filter(E=>E.type==="text").forEach(E=>{E.text=`${E.text}
744
- `});let v=C.every(E=>E.type==="text")?C.map(E=>E.text).join(`
745
- `):C.reduce(nn(`
746
- `),[]);r&&(typeof v=="string"?v=Bn+v:v=[{type:"text",text:Bn},...v]);let k=g.map(E=>this.renderInField(E,e,void 0)).filter(E=>E!==void 0).flat();k.filter(E=>E.type==="text").forEach(E=>{E.text=`${E.text}
747
- `});let R=k.every(E=>E.type==="text")?k.map(E=>E.text).join(`
748
- `):k.reduce(nn(`
749
- `),[]);return[i,...c,{role:"user",content:v,cache:!0},{role:"user",content:R}]}let h=this.sortFieldsCachedFirst(d).map(C=>this.renderInField(C,e,void 0)).filter(C=>C!==void 0).flat();h.filter(C=>C.type==="text").forEach(C=>{C.text=`${C.text}
750
- `});let b=h.every(C=>C.type==="text")?h.map(C=>C.text).join(`
751
- `):h.reduce(nn(`
752
- `),[]);r&&(typeof b=="string"?b=Bn+b:b=[{type:"text",text:Bn},...b]);let T=f&&g.length===0&&this.contextCache;return[i,...c,{role:"user",content:b,...T?{cache:!0}:{}}]};renderExtraFields=e=>{let t=[];if(!e||e.length===0)return t;let n=e.reduce((i,a)=>{let l=a.title;return i[l]||(i[l]=[]),i[l].push(a),i},{}),r=this.sig.hasComplexFields();return Object.entries(n).map(([i,a])=>{if(a.length===1){let l=a[0];return l.type?.name==="object"||l.type?.isArray&&l.type.fields?{title:i,name:l.name,description:`${l.description}
753
- IMPORTANT: Provide the FULL JSON object for this field, matching the schema exactly.`}:{title:i,name:l.name,description:l.description}}if(a.length>1){let l=a.map(c=>`- ${c.description}`).join(`
754
- `);return{title:i,name:a[0].name,description:l}}}).filter(Boolean).forEach(i=>{let a=this.fieldTemplates?.[i.name]??this.defaultRenderInField;t.push(...a(i,i.description))}),t};renderExamples=e=>{let t=[],n={isExample:!0},r=this.sig.hasComplexFields();for(let[s,i]of e.entries()){if(r){let u=this.sig.getInputFields().map(f=>this.renderInField(f,i,{...n,isInputField:!0})).filter(f=>f!==void 0).flat(),p=this.sig.getOutputFields(),d={};for(let f of p)f.name in i&&(d[f.name]=i[f.name]);let m=JSON.stringify(d,null,2),g=[...u,{type:"text",text:`\`\`\`json
740
+ `},...this.renderExamples(t)]:[],s=n?this.renderDemos(n):[],i=r.every(d=>d.type==="text"),a=s.every(d=>d.type==="text"),u=i&&a,c=this.task.text;if(u){let d=[{type:"text",text:c},...r,...s];d.reduce(on(""),[]),d?.[0]&&(c=d[0].text)}let l={role:"system",content:c,cache:!!this.contextCache};if(Array.isArray(e)){let d=[],m=e,g=!0;for(let f of m){let x;if(g?(x=this.renderSingleValueUserContent(f.values,r,s,u),g=!1):x=this.renderSingleValueUserContent(f.values,[],[],!1),f.role==="user"){d.push({role:"user",content:x});continue}if(f.role!=="assistant")throw new Error("Invalid message role");if(typeof x!="string")throw new Error("Assistant message cannot contain non-text content like images, files,etc");d.push({role:"assistant",content:x})}return[l,...d]}let p=this.renderSingleValueUserContent(e,r,s,u);return[l,{role:"user",content:p}]};renderWithMessagePairs=(e,{examples:t,demos:n})=>{let r=t&&t.length>0||n&&n.length>0,i={role:"system",content:r?`${this.task.text}
741
+ ${dm}`:this.task.text,cache:!!this.contextCache},a=t?this.renderExamplesAsMessages(t):[],u=n?this.renderDemosAsMessages(n):[],c=[];for(let I of[...a,...u])c.push(I.userMessage),c.push(I.assistantMessage),I.functionResultMessage&&c.push(I.functionResultMessage);let l=this.contextCache?.cacheBreakpoint??"after-examples",p=this.ignoreBreakpoints||l==="after-examples";if(this.contextCache&&c.length>0&&p){let I=c.length-1,v=c[I];v?.role==="assistant"&&(c[I]={...v,cache:!0})}if(Array.isArray(e)){let I=[],v=e,O=!0;for(let R of v){let E=this.renderInputFields(R.values),S=E.every(_=>_.type==="text")?E.map(_=>_.text).join(`
742
+ `):E.reduce(on(`
743
+ `),[]);if(R.role==="user"){O&&r&&(typeof S=="string"?S=Hn+S:S=[{type:"text",text:Hn},...S],O=!1),I.push({role:"user",content:S});continue}if(R.role!=="assistant")throw new Error("Invalid message role");if(typeof S!="string")throw new Error("Assistant message cannot contain non-text content like images, files, etc");I.push({role:"assistant",content:S})}return[i,...c,...I]}let d=this.sig.getInputFields(),m=d.filter(I=>I.isCached),g=d.filter(I=>!I.isCached),f=m.length>0;if(this.contextCache&&f&&(this.ignoreBreakpoints||l!=="system"&&l!=="after-functions")&&g.length>0){let I=m.map(E=>this.renderInField(E,e,void 0)).filter(E=>E!==void 0).flat();I.filter(E=>E.type==="text").forEach(E=>{E.text=`${E.text}
744
+ `});let v=I.every(E=>E.type==="text")?I.map(E=>E.text).join(`
745
+ `):I.reduce(on(`
746
+ `),[]);r&&(typeof v=="string"?v=Hn+v:v=[{type:"text",text:Hn},...v]);let O=g.map(E=>this.renderInField(E,e,void 0)).filter(E=>E!==void 0).flat();O.filter(E=>E.type==="text").forEach(E=>{E.text=`${E.text}
747
+ `});let R=O.every(E=>E.type==="text")?O.map(E=>E.text).join(`
748
+ `):O.reduce(on(`
749
+ `),[]);return[i,...c,{role:"user",content:v,cache:!0},{role:"user",content:R}]}let h=this.sortFieldsCachedFirst(d).map(I=>this.renderInField(I,e,void 0)).filter(I=>I!==void 0).flat();h.filter(I=>I.type==="text").forEach(I=>{I.text=`${I.text}
750
+ `});let y=h.every(I=>I.type==="text")?h.map(I=>I.text).join(`
751
+ `):h.reduce(on(`
752
+ `),[]);r&&(typeof y=="string"?y=Hn+y:y=[{type:"text",text:Hn},...y]);let C=f&&g.length===0&&this.contextCache;return[i,...c,{role:"user",content:y,...C?{cache:!0}:{}}]};renderExtraFields=e=>{let t=[];if(!e||e.length===0)return t;let n=e.reduce((i,a)=>{let u=a.title;return i[u]||(i[u]=[]),i[u].push(a),i},{}),r=this.sig.hasComplexFields();return Object.entries(n).map(([i,a])=>{if(a.length===1){let u=a[0];return u.type?.name==="object"||u.type?.isArray&&u.type.fields?{title:i,name:u.name,description:`${u.description}
753
+ IMPORTANT: Provide the FULL JSON object for this field, matching the schema exactly.`}:{title:i,name:u.name,description:u.description}}if(a.length>1){let u=a.map(c=>`- ${c.description}`).join(`
754
+ `);return{title:i,name:a[0].name,description:u}}}).filter(Boolean).forEach(i=>{let a=this.fieldTemplates?.[i.name]??this.defaultRenderInField;t.push(...a(i,i.description))}),t};renderExamples=e=>{let t=[],n={isExample:!0},r=this.sig.hasComplexFields();for(let[s,i]of e.entries()){if(r){let l=this.sig.getInputFields().map(f=>this.renderInField(f,i,{...n,isInputField:!0})).filter(f=>f!==void 0).flat(),p=this.sig.getOutputFields(),d={};for(let f of p)f.name in i&&(d[f.name]=i[f.name]);let m=JSON.stringify(d,null,2),g=[...l,{type:"text",text:`\`\`\`json
755
755
  ${m}
756
756
  \`\`\`
757
757
  `}];s>0&&g.length>0&&g[0]?.type==="text"&&t.push({type:"text",text:`---
758
758
 
759
759
  `}),g.forEach(f=>{f&&("text"in f&&(f.text=`${f.text}
760
- `),t.push(f))});continue}let a=this.sig.getInputFields().map(u=>this.renderInField(u,i,{...n,isInputField:!0})).filter(u=>u!==void 0).flat(),l=this.sig.getOutputFields().map(u=>this.renderInField(u,i,{...n,isInputField:!1})).filter(u=>u!==void 0).flat(),c=[...a,...l];s>0&&c.length>0&&c[0]?.type==="text"&&t.push({type:"text",text:`---
760
+ `),t.push(f))});continue}let a=this.sig.getInputFields().map(l=>this.renderInField(l,i,{...n,isInputField:!0})).filter(l=>l!==void 0).flat(),u=this.sig.getOutputFields().map(l=>this.renderInField(l,i,{...n,isInputField:!1})).filter(l=>l!==void 0).flat(),c=[...a,...u];s>0&&c.length>0&&c[0]?.type==="text"&&t.push({type:"text",text:`---
761
761
 
762
- `}),c.forEach(u=>{"text"in u&&(u.text=`${u.text}
763
- `),t.push(u)})}return t};renderDemos=e=>{let t=[],n=this.sig.getInputFields(),r=this.sig.getOutputFields(),s={isExample:!0},i=this.sig.hasComplexFields();for(let a of e){if(i){let p=n.map(f=>this.renderInField(f,a,{...s,isInputField:!0})).filter(f=>f!==void 0).flat(),d={};for(let f of r)f.name in a&&(d[f.name]=a[f.name]);let m=JSON.stringify(d,null,2);[...p,{type:"text",text:`\`\`\`json
762
+ `}),c.forEach(l=>{"text"in l&&(l.text=`${l.text}
763
+ `),t.push(l)})}return t};renderDemos=e=>{let t=[],n=this.sig.getInputFields(),r=this.sig.getOutputFields(),s={isExample:!0},i=this.sig.hasComplexFields();for(let a of e){if(i){let p=n.map(f=>this.renderInField(f,a,{...s,isInputField:!0})).filter(f=>f!==void 0).flat(),d={};for(let f of r)f.name in a&&(d[f.name]=a[f.name]);let m=JSON.stringify(d,null,2);[...p,{type:"text",text:`\`\`\`json
764
764
  ${m}
765
765
  \`\`\`
766
766
  `}].slice(0,-1).forEach(f=>{"text"in f&&(f.text=`${f.text}
767
- `),t.push(f)});continue}let l=n.map(p=>this.renderInField(p,a,{...s,isInputField:!0})).filter(p=>p!==void 0).flat(),c=r.map(p=>this.renderInField(p,a,{...s,isInputField:!1})).filter(p=>p!==void 0).flat();[...l,...c].slice(0,-1).forEach(p=>{"text"in p&&(p.text=`${p.text}
768
- `),t.push(p)})}return t};renderExamplesAsMessages=e=>{let t=[],n={isExample:!0},r=this.sig.hasComplexFields();for(let s of e){let a=this.sortFieldsCachedFirst(this.sig.getInputFields()).map(d=>this.renderInField(d,s,{...n,isInputField:!0})).filter(d=>d!==void 0).flat(),l=a.every(d=>d.type==="text")?a.map(d=>d.text).join(`
769
- `):a.reduce(nn(`
770
- `),[]);if(r&&this.structuredOutputFunctionName){let d={};for(let f of this.sig.getOutputFields())f.name in s&&(d[f.name]=s[f.name]);if(typeof l=="string"&&l.trim()===""||Array.isArray(l)&&l.length===0||Object.keys(d).length===0)continue;let g=`example-${t.length}`;t.push({userMessage:{role:"user",content:l},assistantMessage:{role:"assistant",functionCalls:[{id:g,type:"function",function:{name:this.structuredOutputFunctionName,params:d}}]},functionResultMessage:{role:"function",result:"done",functionId:g}});continue}let c;if(r){let d={};for(let m of this.sig.getOutputFields())m.name in s&&(d[m.name]=s[m.name]);c=JSON.stringify(d,null,2)}else c=this.sig.getOutputFields().map(m=>this.renderInField(m,s,{...n,isInputField:!1})).filter(m=>m!==void 0).flat().filter(m=>m.type==="text").map(m=>m.text).join(`
771
- `);let u=c.trim()==="";typeof l=="string"&&l.trim()===""||Array.isArray(l)&&l.length===0||u||t.push({userMessage:{role:"user",content:l},assistantMessage:{role:"assistant",content:c}})}return t};renderDemosAsMessages=e=>this.renderExamplesAsMessages(e);renderInputFields=e=>{let n=this.sortFieldsCachedFirst(this.sig.getInputFields()).map(r=>this.renderInField(r,e,void 0)).filter(r=>r!==void 0).flat();return n.filter(r=>r.type==="text").forEach(r=>{r.text=`${r.text}
772
- `}),n};renderInField=(e,t,n)=>{let r=t[e.name];if(Sd(e,r,n))return;e.type&&Fr(e,r);let s=Rd(e,r);return(this.fieldTemplates?.[e.name]??this.defaultRenderInField)(e,s)};defaultRenderInField=(e,t)=>{if(e.type?.name==="image"){let r=i=>{if(!i)throw new Error("Image field value is required.");if(typeof i!="object")throw new Error("Image field value must be an object.");if(!("mimeType"in i))throw new Error("Image field must have mimeType");if(!("data"in i))throw new Error("Image field must have data");return i},s=[{type:"text",text:`${e.title}: `}];if(e.type.isArray){if(!Array.isArray(t))throw new Error("Image field value must be an array.");s=s.concat(t.map(i=>{let a=r(i);return{type:"image",mimeType:a.mimeType,image:a.data}}))}else{let i=r(t);s.push({type:"image",mimeType:i.mimeType,image:i.data})}return s}if(e.type?.name==="audio"){let r=i=>{if(!i)throw new Error("Audio field value is required.");if(typeof i!="object")throw new Error("Audio field value must be an object.");if(!("data"in i))throw new Error("Audio field must have data");return i},s=[{type:"text",text:`${e.title}: `}];if(e.type.isArray){if(!Array.isArray(t))throw new Error("Audio field value must be an array.");s=s.concat(t.map(i=>{let a=r(i);return{type:"audio",format:a.format??"wav",data:a.data}}))}else{let i=r(t);s.push({type:"audio",format:i.format??"wav",data:i.data})}return s}if(e.type?.name==="file"){let r=i=>{if(!i)throw new Error("File field value is required.");if(typeof i!="object")throw new Error("File field value must be an object.");if(!("mimeType"in i))throw new Error("File field must have mimeType");let a="data"in i,l="fileUri"in i;if(!a&&!l)throw new Error("File field must have either data or fileUri");if(a&&l)throw new Error("File field cannot have both data and fileUri");return i},s=[{type:"text",text:`${e.title}: `}];if(e.type.isArray){if(!Array.isArray(t))throw new Error("File field value must be an array.");s=s.concat(t.map(i=>{let a=r(i);return"fileUri"in a?{type:"file",mimeType:a.mimeType,fileUri:a.fileUri}:{type:"file",mimeType:a.mimeType,data:a.data}}))}else{let i=r(t);s.push("fileUri"in i?{type:"file",mimeType:i.mimeType,fileUri:i.fileUri}:{type:"file",mimeType:i.mimeType,data:i.data})}return s}if(e.type?.name==="url"){let r=i=>{if(!i)throw new Error("URL field value is required.");if(typeof i=="string")return{url:i};if(typeof i!="object")throw new Error("URL field value must be a string or object.");if(!("url"in i))throw new Error("URL field must have url property");return i},s=[{type:"text",text:`${e.title}: `}];if(e.type.isArray){if(!Array.isArray(t))throw new Error("URL field value must be an array.");s=s.concat(t.map(i=>{let a=r(i);return{type:"url",url:a.url,...a.title?{title:a.title}:{},...a.description?{description:a.description}:{}}}))}else{let i=r(t);s.push({type:"url",url:i.url,...i.title?{title:i.title}:{},...i.description?{description:i.description}:{}})}return s}let n=[e.title,": "];return Array.isArray(t)?(n.push(`
767
+ `),t.push(f)});continue}let u=n.map(p=>this.renderInField(p,a,{...s,isInputField:!0})).filter(p=>p!==void 0).flat(),c=r.map(p=>this.renderInField(p,a,{...s,isInputField:!1})).filter(p=>p!==void 0).flat();[...u,...c].slice(0,-1).forEach(p=>{"text"in p&&(p.text=`${p.text}
768
+ `),t.push(p)})}return t};renderExamplesAsMessages=e=>{let t=[],n={isExample:!0},r=this.sig.hasComplexFields();for(let s of e){let a=this.sortFieldsCachedFirst(this.sig.getInputFields()).map(d=>this.renderInField(d,s,{...n,isInputField:!0})).filter(d=>d!==void 0).flat(),u=a.every(d=>d.type==="text")?a.map(d=>d.text).join(`
769
+ `):a.reduce(on(`
770
+ `),[]);if(r&&this.structuredOutputFunctionName){let d={};for(let f of this.sig.getOutputFields())f.name in s&&(d[f.name]=s[f.name]);if(typeof u=="string"&&u.trim()===""||Array.isArray(u)&&u.length===0||Object.keys(d).length===0)continue;let g=`example-${t.length}`;t.push({userMessage:{role:"user",content:u},assistantMessage:{role:"assistant",functionCalls:[{id:g,type:"function",function:{name:this.structuredOutputFunctionName,params:d}}]},functionResultMessage:{role:"function",result:"done",functionId:g}});continue}let c;if(r){let d={};for(let m of this.sig.getOutputFields())m.name in s&&(d[m.name]=s[m.name]);c=JSON.stringify(d,null,2)}else c=this.sig.getOutputFields().map(m=>this.renderInField(m,s,{...n,isInputField:!1})).filter(m=>m!==void 0).flat().filter(m=>m.type==="text").map(m=>m.text).join(`
771
+ `);let l=c.trim()==="";typeof u=="string"&&u.trim()===""||Array.isArray(u)&&u.length===0||l||t.push({userMessage:{role:"user",content:u},assistantMessage:{role:"assistant",content:c}})}return t};renderDemosAsMessages=e=>this.renderExamplesAsMessages(e);renderInputFields=e=>{let n=this.sortFieldsCachedFirst(this.sig.getInputFields()).map(r=>this.renderInField(r,e,void 0)).filter(r=>r!==void 0).flat();return n.filter(r=>r.type==="text").forEach(r=>{r.text=`${r.text}
772
+ `}),n};renderInField=(e,t,n)=>{let r=t[e.name];if(fm(e,r,n))return;e.type&&Nr(e,r);let s=mm(e,r);return(this.fieldTemplates?.[e.name]??this.defaultRenderInField)(e,s)};defaultRenderInField=(e,t)=>{if(e.type?.name==="image"){let r=i=>{if(!i)throw new Error("Image field value is required.");if(typeof i!="object")throw new Error("Image field value must be an object.");if(!("mimeType"in i))throw new Error("Image field must have mimeType");if(!("data"in i))throw new Error("Image field must have data");return i},s=[{type:"text",text:`${e.title}: `}];if(e.type.isArray){if(!Array.isArray(t))throw new Error("Image field value must be an array.");s=s.concat(t.map(i=>{let a=r(i);return{type:"image",mimeType:a.mimeType,image:a.data}}))}else{let i=r(t);s.push({type:"image",mimeType:i.mimeType,image:i.data})}return s}if(e.type?.name==="audio"){let r=i=>{if(!i)throw new Error("Audio field value is required.");if(typeof i!="object")throw new Error("Audio field value must be an object.");if(!("data"in i))throw new Error("Audio field must have data");return i},s=[{type:"text",text:`${e.title}: `}];if(e.type.isArray){if(!Array.isArray(t))throw new Error("Audio field value must be an array.");s=s.concat(t.map(i=>{let a=r(i);return{type:"audio",format:a.format??"wav",data:a.data}}))}else{let i=r(t);s.push({type:"audio",format:i.format??"wav",data:i.data})}return s}if(e.type?.name==="file"){let r=i=>{if(!i)throw new Error("File field value is required.");if(typeof i!="object")throw new Error("File field value must be an object.");if(!("mimeType"in i))throw new Error("File field must have mimeType");let a="data"in i,u="fileUri"in i;if(!a&&!u)throw new Error("File field must have either data or fileUri");if(a&&u)throw new Error("File field cannot have both data and fileUri");return i},s=[{type:"text",text:`${e.title}: `}];if(e.type.isArray){if(!Array.isArray(t))throw new Error("File field value must be an array.");s=s.concat(t.map(i=>{let a=r(i);return"fileUri"in a?{type:"file",mimeType:a.mimeType,fileUri:a.fileUri}:{type:"file",mimeType:a.mimeType,data:a.data}}))}else{let i=r(t);s.push("fileUri"in i?{type:"file",mimeType:i.mimeType,fileUri:i.fileUri}:{type:"file",mimeType:i.mimeType,data:i.data})}return s}if(e.type?.name==="url"){let r=i=>{if(!i)throw new Error("URL field value is required.");if(typeof i=="string")return{url:i};if(typeof i!="object")throw new Error("URL field value must be a string or object.");if(!("url"in i))throw new Error("URL field must have url property");return i},s=[{type:"text",text:`${e.title}: `}];if(e.type.isArray){if(!Array.isArray(t))throw new Error("URL field value must be an array.");s=s.concat(t.map(i=>{let a=r(i);return{type:"url",url:a.url,...a.title?{title:a.title}:{},...a.description?{description:a.description}:{}}}))}else{let i=r(t);s.push({type:"url",url:i.url,...i.title?{title:i.title}:{},...i.description?{description:i.description}:{}})}return s}let n=[e.title,": "];return Array.isArray(t)?(n.push(`
773
773
  `),n.push(t.map(r=>`- ${r}`).join(`
774
- `))):n.push(t),[{type:"text",text:n.join("")}]}},as=o=>o.map(e=>`\`${e.title}\``).join(", "),Wc=(o,e)=>o.map(n=>{let r=n.title,s=n.type?.name?zn(n.type):"string",i=n.isOptional?`This optional ${s} field may be omitted`:`${/^[aeiou]/i.test(s)?"An":"A"} ${s} field`,a="";if(n.description){let l=jn(n.description);e&&(l=ls(l,e)),a=` ${l}`}return`${r}: (${i})${a}`.trim()}).join(`
775
- `),Vc=(o,e)=>o.map(n=>{let r=n.title,s=n.type?.name?zn(n.type):"string",i=n.isOptional?`Only include this ${s} field if its value is available`:`This ${s} field must be included`,a="";if(n.description&&n.description.length>0){let l=n.type?.name==="class"?n.description:jn(n.description);e&&(l=ls(l,e)),a=` ${l}`}return n.type?.options&&n.type.options.length>0&&(a.length>0&&(a+=". "),a+=`Allowed values: ${n.type.options.join(", ")}`),`${r}: (${i})${a}`.trim()}).join(`
776
- `),Rd=(o,e)=>{if(o.type?.name==="date"&&e instanceof Date){let t=e.toISOString();return t.slice(0,t.indexOf("T"))}return o.type?.name==="datetime"&&e instanceof Date?wc(e):o.type?.name==="image"&&typeof e=="object"||o.type?.name==="audio"&&typeof e=="object"||o.type?.name==="file"&&typeof e=="object"||o.type?.name==="url"&&(typeof e=="string"||typeof e=="object")||typeof e=="string"?e:JSON.stringify(e,null,2)};function vd(o){return`{ ${Object.entries(o).map(([t,n])=>{let r=n.isOptional?"?":"",s=zn({name:n.type,isArray:n.isArray,fields:n.fields,options:n.options});return`${t}${r}: ${s}`}).join(", ")} }`}var zn=o=>{let e=(()=>{switch(o?.name){case"string":return"string";case"number":return"number";case"boolean":return"boolean (true or false)";case"date":return'date ("YYYY-MM-DD" format)';case"datetime":return'date time ("YYYY-MM-DD HH:mm Timezone" format)';case"json":return"JSON object";case"class":return"classification class";case"code":return"code";case"file":return"file (with filename, mimeType, and data)";case"url":return"URL (string or object with url, title, description)";case"object":return o?.fields?`object ${vd(o.fields)}`:"object";default:return"string"}})();return o?.isArray?`json array of ${e} items`:e};function nn(o){return(e,t)=>{if(t.type==="text"){let n=e.length>0?e[e.length-1]:null;n&&n.type==="text"?n.text+=o+t.text:e.push(t)}else e.push(t);return e}}var Sd=(o,e,t)=>{if(typeof e=="boolean"||o?.type?.name==="number"&&typeof e=="number")return!1;if(!e||(Array.isArray(e)||typeof e=="string")&&e.length===0){if(t?.isExample||o.isOptional||o.isInternal)return!0;let n=t?.isInputField!==!1?"input":"output";throw new Error(`Value for ${n} field '${o.name}' is required.`)}return!1};function jn(o){let e=o.trim();return e.length>0?`${e.charAt(0).toUpperCase()}${e.slice(1)}${e.endsWith(".")?"":"."}`:""}function ls(o,e){if(e.size===0)return o;let t=o,n=Array.from(e.keys()).sort((r,s)=>s.length-r.length);for(let r of n){let s=e.get(r),i=new RegExp(`\`${r}\``,"g");t=t.replace(i,`\`${s}\``);let a=new RegExp(`"${r}"`,"g");t=t.replace(a,`"${s}"`);let l=new RegExp(`'${r}'`,"g");t=t.replace(l,`'${s}'`);let c=new RegExp(`\\[${r}\\]`,"g");t=t.replace(c,`[${s}]`);let u=new RegExp(`\\(${r}\\)`,"g");t=t.replace(u,`(${s})`);let p=new RegExp(`\\$${r}\\b`,"g");t=t.replace(p,`\`${s}\``)}return t}function kd(o,e){let t=o.history(0,e),n=t.some(s=>s.role==="function");return t.some(s=>s.role==="assistant"&&"functionCalls"in s&&Array.isArray(s.functionCalls)&&s.functionCalls.length>0)&&n}function Od(o,e){let t=o.history(0,e),n=[],r=t.filter(i=>i.role==="assistant"&&"functionCalls"in i&&Array.isArray(i.functionCalls)&&i.functionCalls.length>0),s=t.filter(i=>i.role==="function");for(let i of r)if("functionCalls"in i&&i.functionCalls)for(let a of i.functionCalls){let l=s.find(c=>"functionId"in c&&c.functionId===a.id);l&&"result"in l&&"functionId"in l&&n.push({index:n.length,functionName:a.function.name,functionId:a.id,args:a.function.params||"",result:String(l.result),isError:"isError"in l?!!l.isError:!1})}return n}async function cs(o,e,t,n){if(!e?.resultPicker||o.length<=1)return 0;let r=e.resultPicker;if((t?kd(t,n):!1)&&t){let l=Od(t,n),c=await r({type:"function",results:l});if(c<0||c>=l.length)throw new Error(`Result picker returned invalid index: ${c}. Must be between 0 and ${l.length-1}`);return c}let i=o.map((l,c)=>({index:c,sample:l.delta})),a=await r({type:"fields",results:i});if(a<0||a>=o.length)throw new Error(`Result picker returned invalid index: ${a}. Must be between 0 and ${o.length-1}`);return a}async function Jc(o,e,t){let n=o?.getLast(e);if(!n||n.role!=="assistant"||n.chat.length<=1)return 0;let r=n.chat.map(i=>({version:0,index:i.index,delta:i.value}));return await cs(r,t,o,e)}var qn=class{_stepIndex=0;maxSteps;_functionsExecuted=new Set;_lastFunctionCalls=[];_usage={promptTokens:0,completionTokens:0,totalTokens:0};state=new Map;_pendingOptions={};_functionsToAdd=[];_functionsToRemove=[];_stopRequested=!1;_stopResultValues;constructor(e){this.maxSteps=e}get stepIndex(){return this._stepIndex}get isFirstStep(){return this._stepIndex===0}get functionsExecuted(){return this._functionsExecuted}get lastFunctionCalls(){return this._lastFunctionCalls}get usage(){return this._usage}setModel(e){this._pendingOptions.model=e}setThinkingBudget(e){this._pendingOptions.thinkingTokenBudget=e}setTemperature(e){this._pendingOptions.modelConfig||(this._pendingOptions.modelConfig={}),this._pendingOptions.modelConfig.temperature=e}setMaxTokens(e){this._pendingOptions.modelConfig||(this._pendingOptions.modelConfig={}),this._pendingOptions.modelConfig.maxTokens=e}setOptions(e){Object.assign(this._pendingOptions,e)}addFunctions(e){this._functionsToAdd.push(...e)}removeFunctions(...e){this._functionsToRemove.push(...e)}stop(e){this._stopRequested=!0,this._stopResultValues=e}_beginStep(e){this._stepIndex=e,this._functionsExecuted=new Set,this._lastFunctionCalls=[]}_recordFunctionCall(e,t,n){this._functionsExecuted.add(e.toLowerCase()),this._lastFunctionCalls.push({name:e,args:t,result:n})}_addUsage(e,t,n){this._usage.promptTokens+=e,this._usage.completionTokens+=t,this._usage.totalTokens+=n}_consumePendingOptions(){if(Object.keys(this._pendingOptions).length===0)return;let e=this._pendingOptions;return this._pendingOptions={},e}_consumeFunctionsToAdd(){if(this._functionsToAdd.length===0)return;let e=this._functionsToAdd;return this._functionsToAdd=[],e}_consumeFunctionsToRemove(){if(this._functionsToRemove.length===0)return;let e=this._functionsToRemove;return this._functionsToRemove=[],e}get _isStopRequested(){return this._stopRequested}get _stopValues(){return this._stopResultValues}};var us=class{tools;logger;constructor(e,t){this.tools=new Map(e.map(n=>[n.name,n])),this.logger=t}getToolParamFieldMap(){let e=new Map;for(let[,t]of this.tools.entries())if(t.parameters?.properties&&Object.keys(t.parameters.properties).length>0){let{paramFieldMap:n}=Ed(t);e.set(t.name,n)}else e.set(t.name,new Map);return e}async route(e,t){let n=[],r={},s=new Map,i=new Map;for(let[a,l]of this.tools.entries())i.set(a,this.buildSanitizedFieldMap(l));for(let[a,l]of Object.entries(e)){let c=this.tools.get(this.normalizeToolName(a));if(c){l!=null&&typeof l=="object"&&s.set(c.name,l);continue}r[a]=l}for(let[a,l]of Object.entries(e))for(let[c,u]of this.tools.entries()){let p=i.get(c);if(!p)continue;let d=p.get(a);if(!d)continue;let m=s.get(u.name)??{};this.setNested(m,d,l),s.set(u.name,m)}for(let[a,l]of this.tools.entries()){let c=s.get(l.name);if(!(!c||Object.keys(c).length===0)){if(l.parameters&&l.parameters.type==="object"){let p=(l.parameters.required||[]).filter(d=>c[d]===void 0);if(p.length>0)throw new Qe(`Missing required arguments for tool '${l.name}': ${p.join(", ")}`)}n.push({id:l.name,name:l.name,args:JSON.stringify(c)})}}return{functionCalls:n,remainingFields:r}}normalizeToolName(e){return e.replace(/_([a-z])/g,(t,n)=>n.toUpperCase())}sanitizeFieldName(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}buildSanitizedFieldMap(e){let t=new Map;if(!e.parameters||!("properties"in e.parameters))return t;let n=(r,s)=>{for(let[i,a]of Object.entries(r)){let l=[...s,i];if(a&&a.type==="object"&&a.properties)n(a.properties,l);else{let c=`${e.name}.${l.join(".")}`,u=this.sanitizeFieldName(c);t.set(u,l)}}};return n(e.parameters.properties??{},[]),t}setNested(e,t,n){let r=e;for(let s=0;s<t.length-1;s++){let i=t[s],a=r[i];(typeof a!="object"||a===null)&&(r[i]={}),r=r[i]}r[t[t.length-1]]=n}isToolField(e){return this.tools.has(this.normalizeToolName(e))}getToolFieldNames(){return Array.from(this.tools.keys()).map(e=>e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,""))}};function Ed(o){let e=[],t=new Map;if(!o.parameters||!o.parameters.properties)return{fields:e,paramFieldMap:t};let n=o.parameters.properties,r=o.parameters.required||[],s=(i,a,l)=>{for(let[c,u]of Object.entries(i)){let p=a?`${a}.${c}`:c,d=`${o.name}.${p}`;if(u.type==="object"&&u.properties)s(u.properties,p,u.required||[]);else{let m=Md(u);e.push({name:Fd(d),title:Pd(o.name,p),type:m,description:u.description||`${c} parameter for ${o.name}`,isOptional:!0}),t.set(d,e[e.length-1])}}};return s(n,"",r),{fields:e,paramFieldMap:t}}function Md(o){switch(o.type){case"string":return{name:"string",isArray:!1};case"number":case"integer":return{name:"number",isArray:!1};case"boolean":return{name:"boolean",isArray:!1};case"array":{let e=o.items;if(e?.type)switch(e.type){case"string":return{name:"string",isArray:!0};case"number":case"integer":return{name:"number",isArray:!0};case"boolean":return{name:"boolean",isArray:!0};default:return{name:"json",isArray:!0}}return{name:"json",isArray:!0}}case"object":return{name:"json",isArray:!1};default:return{name:"string",isArray:!1}}}function Pd(o,e){return`${o} ${e.replace(/\./g," ")}`}function Fd(o){return o.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}function Xc(o,e,t){let n=new Ne(e);if(t){let r=t.getToolParamFieldMap();for(let s of o){let i=r.get(s.name);if(i&&i.size>0)for(let a of i.values())n.getOutputFields().some(c=>c.name===a.name)||n.addOutputField(a);else{let a=na(s.name),l=Yc(s.parameters);n.getOutputFields().some(u=>u.name===a)||n.addOutputField({name:a,title:Qc(s.name),type:l,description:s.description||`Parameters for ${s.name}`,isOptional:!0})}}return{signature:n,toolParamFieldMap:r}}else{let r=new Map;for(let s of o)if(s.parameters?.properties&&Object.keys(s.parameters.properties).length>0){let{fields:i,paramFieldMap:a}=_d(s);r.set(s.name,a);for(let l of i)n.getOutputFields().some(u=>u.name===l.name)||n.addOutputField(l)}else{let i=na(s.name),a=Yc(s.parameters);n.getOutputFields().some(c=>c.name===i)||n.addOutputField({name:i,title:Qc(s.name),type:a,description:s.description||`Parameters for ${s.name}`,isOptional:!0})}return{signature:n,toolParamFieldMap:r}}}function _d(o){let e=[],t=new Map;if(!o.parameters||!o.parameters.properties)return{fields:e,paramFieldMap:t};let n=o.parameters.properties,r=o.parameters.required||[],s=(i,a,l)=>{for(let[c,u]of Object.entries(i)){let p=a?`${a}.${c}`:c,d=`${o.name}.${p}`;if(u.type==="object"&&u.properties)s(u.properties,p,u.required||[]);else{let m=Nd(u),g={name:na(d),title:Ld(o.name,p),type:m,description:u.description||`${c} parameter for ${o.name}`,isOptional:!0};e.push(g),t.set(d,g)}}};return s(n,"",r),{fields:e,paramFieldMap:t}}function Nd(o){switch(o.type){case"string":return{name:"string",isArray:!1};case"number":case"integer":return{name:"number",isArray:!1};case"boolean":return{name:"boolean",isArray:!1};case"array":{let e=o.items;if(e?.type)switch(e.type){case"string":return{name:"string",isArray:!0};case"number":case"integer":return{name:"number",isArray:!0};case"boolean":return{name:"boolean",isArray:!0};default:return{name:"json",isArray:!0}}return{name:"json",isArray:!0}}case"object":return{name:"json",isArray:!1};default:return{name:"string",isArray:!1}}}function Ld(o,e){return`${o} ${e.replace(/\./g," ")}`}function na(o){return o.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}function Qc(o){return o.replace(/([A-Z])/g," $1").replace(/^./,e=>e.toUpperCase()).trim()}function Yc(o){return!o||!o.properties||Object.keys(o.properties).length===0?{name:"string",isArray:!1}:{name:"json",isArray:!1}}var Gr=class{tools;router;injectedToolFieldNames=new Set;constructor(e){this.tools=e,this.router=new us(e)}processSignature(e){let{signature:t}=Xc(this.tools,e),n=new Set(t.getOutputFields().map(s=>s.name)),r=new Set(e.getOutputFields().map(s=>s.name));return this.injectedToolFieldNames=new Set([...n].filter(s=>!r.has(s))),t}async processResults(e,t){let{functionCalls:n}=await this.router.route(e,t);return n.length>0?n:void 0}getInjectedToolFieldNames(){return Array.from(this.injectedToolFieldNames)}getRouter(){return this.router}};var Hn="__finalResult",ke=class o extends qt{clone=()=>new o(this.signature,this.options);promptTemplate;asserts;streamingAsserts;options;functions;fieldProcessors=[];streamingFieldProcessors=[];excludeContentFromTrace=!1;thoughtFieldName;signatureToolCallingManager;structuredOutputFunctionFallback=!1;activeAbortControllers=new Set;_stopRequested=!1;constructor(e,t){super(e,{description:t?.description,traceLabel:t?.traceLabel}),this.options=t,this.thoughtFieldName=t?.thoughtFieldName??"thought";let n={functions:t?.functions,thoughtFieldName:this.thoughtFieldName};this.promptTemplate=new(t?.promptTemplate??rn)(this.signature,n),this.asserts=this.options?.asserts??[],this.streamingAsserts=this.options?.streamingAsserts??[],this.excludeContentFromTrace=t?.excludeContentFromTrace??!1,this.functions=t?.functions?tn(t.functions):[],this.usage=[]}stop(){this._stopRequested=!0;for(let e of this.activeAbortControllers)e.abort("Stopped by user")}setInstruction(e){this.promptTemplate.setInstruction(e)}getInstruction(){return this.promptTemplate.getInstruction()}getSignatureName(){return this.signature.getDescription()||"unknown_signature"}getMetricsInstruments(){return Fi()}getMergedCustomLabels(e,t){return Qt(de.customLabels,e?.getOptions?.()?.customLabels,t?.customLabels)}updateMeter(e){Fi(e)}createStates(e){return Array.from({length:e},(t,n)=>({index:n,functionCalls:[],values:{},content:"",functionsExecuted:new Set,xstate:{extractedFields:[],streamedIndex:{},s:-1}}))}addAssert(e,t){this.asserts.push({fn:e,message:t})}addStreamingAssert(e,t,n){let r=this.signature.getOutputFields().find(a=>a.name===e);if(!r)throw new Error(`addStreamingAssert: field ${String(e)} not found in output signature`);let s=r.type?.name;if(!(!s||s==="string"||s==="code"))throw new Error(`addStreamingAssert: field ${String(e)} must be a string field for streaming assertions`);this.streamingAsserts.push({fieldName:String(e),fn:t,message:n})}addFieldProcessorInternal(e,t,n=!1){let r=this.signature.getOutputFields().find(s=>s.name===e);if(!r)throw new Error(`addFieldProcessor: field ${e} not found`);if(n){let s=r.type?.name;if(!(!s||s==="string"||s==="code"))throw new Error(`addFieldProcessor: field ${e} must be a text field`);this.streamingFieldProcessors.push({field:r,process:t})}else this.fieldProcessors.push({field:r,process:t})}addStreamingFieldProcessor(e,t){this.addFieldProcessorInternal(String(e),t,!0)}addFieldProcessor(e,t){this.addFieldProcessorInternal(String(e),t,!1)}async forwardSendRequest({ai:e,mem:t,options:n,traceContext:r,functions:s,functionCall:i,stepIndex:a}){let{sessionId:l,model:c,rateLimiter:u,stream:p,thinkingTokenBudget:d,showThoughts:m}=n??{},g=await Jc(t,l,{resultPicker:n?.resultPicker}),f=t?.history(g,l)??[];if(f.length===0)throw new Error("No chat prompt found");let x={...n?.modelConfig,...n?.sampleCount?{n:n.sampleCount}:{},...n?.sampleCount&&n?.modelConfig?.temperature===1?{temperature:.8}:{}},A=this.isDebug(e,n),h=a===0,b=this.getLogger(e,n);s=this.signatureToolCallingManager?[]:s;let T,C=this.signature.getOutputFields();if(this.signature.hasComplexFields()&&!this.structuredOutputFunctionFallback){if(!e.getFeatures(c)?.structuredOutputs)throw new Error(`Complex structured outputs (object/array types) require a provider that supports structured outputs. Current provider/model (${c}) does not support this feature. Supported providers: OpenAI (GPT-4o, GPT-4.1+), Google Gemini, Anthropic (Sonnet/Opus).`);T={type:"json_schema",schema:{name:"output",strict:!0,schema:zt(C)}}}let k=n?.contextCache?.cacheBreakpoint??"after-examples",R=e.getFeatures?.(c)?.caching?.cacheBreakpoints===!1,E=n?.contextCache&&(R||k==="after-functions"||k==="after-examples"),S=s?.length&&E?s.map((L,P)=>({...L,cache:P===s.length-1})):s;return await e.chat({chatPrompt:f,functions:S,functionCall:i,modelConfig:x,model:c,responseFormat:T},{sessionId:l,rateLimiter:u,stream:p,debug:A,debugHideSystemPrompt:n?.debugHideSystemPrompt??this.options?.debugHideSystemPrompt??!h,thinkingTokenBudget:d,showThoughts:m,traceContext:r,abortSignal:n?.abortSignal??de.abortSignal,stepIndex:a,logger:b,functionCallMode:n?.functionCallMode??this.options?.functionCallMode??"auto",retry:n?.retry??this.options?.retry,customLabels:n?.customLabels})}async*forwardCore({ai:e,mem:t,options:n,stepIndex:r,span:s,traceContext:i,states:a,stopFunctionNames:l,stepContext:c}){let{sessionId:u,functions:p}=n??{},d=n?.functionResultFormatter??this.options?.functionResultFormatter,m=n?.functionCall??this.options?.functionCall,g=this.signatureToolCallingManager,f=n?.strictMode??!1,x=n.model,A=this.usage,h=r===0,b=this.isDebug(e,n),T=this.getLogger(e,n),{functions:C,functionCall:v}=Pc(p,m,h,n);this.structuredOutputFunctionFallback&&C.filter(E=>E.name!==Hn).length===0&&(v={type:"function",function:{name:Hn}});let k=await this.forwardSendRequest({ai:e,mem:t,options:n,traceContext:i,functions:C,functionCall:v,stepIndex:r});k instanceof ReadableStream?yield*_c({ai:e,model:x,res:k,mem:t,sessionId:u,traceId:s?s.spanContext?.().traceId:void 0,functions:C,strictMode:f,span:s,states:a,usage:A,asserts:this.asserts,streamingAsserts:this.streamingAsserts,fieldProcessors:this.fieldProcessors,streamingFieldProcessors:this.streamingFieldProcessors,thoughtFieldName:this.thoughtFieldName,excludeContentFromTrace:this.excludeContentFromTrace,signature:this.signature,logger:T,debug:b,functionResultFormatter:d,signatureToolCallingManager:g,stopFunctionNames:l,disableMemoryCleanup:n.disableMemoryCleanup,stepContext:c,abortSignal:n.abortSignal}):yield*Nc({ai:e,model:x,res:k,mem:t,sessionId:u,traceId:s?s.spanContext?.().traceId:void 0,functions:C,span:s,strictMode:f,states:a,usage:A,asserts:this.asserts,fieldProcessors:this.fieldProcessors,thoughtFieldName:this.thoughtFieldName,excludeContentFromTrace:this.excludeContentFromTrace,signature:this.signature,logger:T,debug:b,functionResultFormatter:d,signatureToolCallingManager:g,stopFunctionNames:l,disableMemoryCleanup:n.disableMemoryCleanup,stepContext:c,abortSignal:n.abortSignal})}async*_forward2(e,t,n,r,s,i){this.signatureToolCallingManager=void 0;let a=r?.stopFunction??this.options?.stopFunction,l=Array.isArray(a)?a.map(V=>V.toLowerCase()):a?[a.toLowerCase()]:void 0,c=r.maxRetries??this.options?.maxRetries??3,u=r.maxSteps??this.options?.maxSteps??25,p=r.mem??this.options?.mem??new Nn,d=r.functions?tn(r.functions):[...this.functions],m=new qn(u),g;if(r.selfTuning){if(g=r.selfTuning===!0?{model:!0,thinkingBudget:!0}:r.selfTuning,g.model!==!1){let ve=e.getModelList()?.filter($=>"model"in $);if(!ve||ve.length<2)throw new Error("Self-tuning with model selection requires the AI service to have a `models` list with at least 2 chat models. Either configure models on your AI service or disable model selection with `selfTuning: { model: false }`.")}let V=Wi(e,g,r.model?String(r.model):void 0);d.push(V)}let f={...r},x=r.stepHooks,A=d&&d.length>0,h=r.functionCallMode??this.options?.functionCallMode??"auto";A&&h==="prompt"&&(this.signatureToolCallingManager=new Gr(d)),A&&h==="auto"&&!e.getFeatures(r.model).functions&&(this.signatureToolCallingManager=new Gr(d));let b,T,C=this.options?.promptTemplate??rn;this.signatureToolCallingManager&&(this.signature=this.signatureToolCallingManager.processSignature(this.signature),this.setSignature(this.signature));let v=this.signature.hasComplexFields(),k=e.getFeatures?.(r.model),R=r.structuredOutputMode??this.options?.structuredOutputMode??"auto";if(this.structuredOutputFunctionFallback=v&&(R==="function"||R==="auto"&&!k?.structuredOutputs),this.structuredOutputFunctionFallback){let V={name:Hn,description:"Return the final result. Call this function with the complete output data.",parameters:zt(this.signature.getOutputFields()),func:async()=>"done"};d.push(V),l=[...l??[],Hn.toLowerCase()]}let E=e.getFeatures?.(r.model)?.caching?.cacheBreakpoints===!1,S={functions:this.signatureToolCallingManager?[]:d,thoughtFieldName:this.thoughtFieldName,contextCache:r.contextCache,examplesInSystem:r.examplesInSystem,ignoreBreakpoints:E,structuredOutputFunctionName:this.structuredOutputFunctionFallback?Hn:void 0};this.promptTemplate=new C(this.signature,S);let _,L=performance.now();Array.isArray(t)?(wl(t),_=this.promptTemplate.render(t,{examples:this.examples,demos:this.demos})):_=this.promptTemplate.render(t,{examples:this.examples,demos:this.demos});let P=performance.now()-L,F=this.getMetricsInstruments(),N=this.getMergedCustomLabels(e,r);F&&Qo(F,"prompt_render",P,this.getSignatureName(),N);let U=performance.now();p.addRequest(_,r.sessionId);let G=performance.now()-U;F&&Qo(F,"memory_update",G,this.getSignatureName(),N);let B=new Map;n.forEach(V=>{B.set(V.index,{})});let te=()=>{let V=m._consumePendingOptions();if(V){let{modelConfig:$,...K}=V;f={...f,...K},$&&(f.modelConfig={...f.modelConfig,...$})}let xe=m._consumeFunctionsToAdd();if(xe){let $=tn(xe);for(let K of $)d.some(ne=>ne.name===K.name)||d.push(K)}let ve=m._consumeFunctionsToRemove();if(ve){let $=new Set(ve.map(K=>K.toLowerCase()));for(let K=d.length-1;K>=0;K--)$.has(d[K].name.toLowerCase())&&d.splice(K,1)}},j=r?.abortSignal??de.abortSignal;e:for(let V=0;V<u;V++){if(m._beginStep(V),te(),g&&g.model!==!1){let ve=d.findIndex($=>$.name==="adjustGeneration");if(ve!==-1){let $=f.model?String(f.model):void 0;d[ve]=Wi(e,g,$)}}if(m._isStopRequested)break;if(j?.aborted)throw new Pe("between-steps",j.reason??"Aborted between steps");if(x?.beforeStep&&(await x.beforeStep(m),te(),m._isStopRequested))break;let xe=c;for(let ve=0;ve<=xe;ve++)try{let $=c+1;for(let ne=0;ne<$;ne++){n.forEach(X=>{X.content="",X.values={},X.functionCalls=[],X.functionsExecuted=new Set,X.xstate={extractedFields:[],streamedIndex:{},s:-1}}),ne>0&&B.forEach((X,z)=>{B.set(z,{})});let pe=new Map;n.forEach(X=>{pe.set(X.index,{})});try{let X=this.forwardCore({options:{...f,functions:d},ai:e,mem:p,stepIndex:V,span:s,traceContext:i,states:n,stopFunctionNames:l,stepContext:m}),z=!1;try{for await(let se of X)if(se!==void 0){let Fe=se.index,ae=se.delta,Ae=pe.get(Fe)??{},be=B.get(Fe)??{},oe={},ge=!1;for(let Ie of Object.keys(ae)){let je=ae[Ie],$e=Ae[Ie],it;typeof je=="string"&&(typeof $e=="string"||$e===void 0)?it=($e??"")+je:Array.isArray(je)&&(Array.isArray($e)||$e===void 0)?it=[...$e??[],...je]:it=je,Ae[Ie]=it;let Se=it,ze=be[Ie];if(typeof Se=="string"&&typeof ze=="string")if(Se.startsWith(ze)){let le=Se.slice(ze.length);le&&(oe[Ie]=le,ge=!0,be[Ie]=Se)}else ze.startsWith(Se)||Se!==ze&&(oe[Ie]=Se,ge=!0,be[Ie]=Se);else if(Array.isArray(Se)&&Array.isArray(ze)){if(Se.length>ze.length){let le=Se.slice(ze.length);oe[Ie]=le,ge=!0,be[Ie]=Se}}else JSON.stringify(Se)!==JSON.stringify(ze)&&(oe[Ie]=Se,ge=!0,be[Ie]=Se)}ge&&(yield{version:ne,index:se.index,delta:oe})}}catch(se){if(se instanceof en){if(z=!0,this.structuredOutputFunctionFallback){let Fe=se.calls.find(ae=>ae.func.name===Hn);if(Fe?.args){let ae=Fe.args;Un(this.signature,ae);let Ae=this.signature.getOutputFields();for(let be of n){let oe={};for(let ge of Ae)ge.name in ae&&!ge.isInternal&&(oe[ge.name]=ae[ge.name],be.values[ge.name]=ae[ge.name]);yield{version:ne,index:be.index,delta:oe}}for(let be of n)await Ln(this.asserts,be.values);if(this.fieldProcessors.length>0)for(let be of n)await Nr(this.fieldProcessors,be.values,p,r.sessionId)}}}else throw se}if(this.usage.length>0){let se=this.usage[this.usage.length-1];se?.tokens&&m._addUsage(se.tokens.promptTokens??0,se.tokens.completionTokens??0,se.tokens.totalTokens??0)}n.some(se=>se.functionsExecuted.size>0)&&x?.afterFunctionExecution&&(await x.afterFunctionExecution(m),te());let Oe=z||m._isStopRequested?!1:Lc(p,l,n,f?.sessionId);if(x?.afterStep&&(await x.afterStep(m),te()),Oe&&!m._isStopRequested&&!j?.aborted){let se=this.getMetricsInstruments();se&&Jo(se,V+1,u,this.getSignatureName(),N);continue e}if(j?.aborted)throw new Pe("mid-step",j.reason??"Aborted");r?.disableMemoryCleanup||(p.removeByTag("invalid-assistant",r.sessionId),p.removeByTag("correction",r.sessionId),p.removeByTag("error",r.sessionId));let Ee=this.getMetricsInstruments();if(Ee){Jo(Ee,V+1,u,this.getSignatureName(),N);let se=new Set;n.forEach(Fe=>{Fe.functionsExecuted.forEach(ae=>se.add(ae))}),se.size>0&&sc(Ee,!0,se.size,!0,!1,this.getSignatureName(),N),ic(Ee,this.fieldProcessors.length,this.streamingFieldProcessors.length,this.getSignatureName(),N)}return}catch(X){if(X instanceof Pe)throw X;T=X;let z,ie=this.isDebug(e,r),Oe=this.getLogger(e,r),Ee=this.getMetricsInstruments(),se=this.getSignatureName(),Fe={error:X,errCount:ne,logger:Oe,metricsInstruments:Ee,signatureName:se,span:s,debug:ie,customLabels:N};if(s?.recordException(X),X instanceof Qe)z=hc(Fe),b=X;else if(X instanceof Et)z=xc(Fe),b=X;else if(X instanceof Le)Ac(Fe);else{if(X instanceof gt)throw X;{let ae=X,Ae=ae instanceof rt&&ae.status>=500&&ae.status<600,be=ae instanceof Je,oe=ae instanceof dt;throw Ae||be||oe?X:ra(X,e,this.signature)}}if(z&&(p.addTag("error",r.sessionId),p.addRequest([{role:"user",content:this.promptTemplate.renderExtraFields(z)}],r.sessionId),p.addTag("correction",r.sessionId),this.signature.hasComplexFields()))for(let Ae of n)Ae.content="",Ae.values={},Ae.xstate={extractedFields:[],streamedIndex:{},s:-1}}}let K=this.getMetricsInstruments();throw K&&Ni(K,c,!1,c,this.getSignatureName(),N),ra(new Error(`Unable to fix validation error: ${(b??T)?.message??(b??T)?.toString()??"unknown error"}
774
+ `))):n.push(t),[{type:"text",text:n.join("")}]}},ps=o=>o.map(e=>`\`${e.title}\``).join(", "),il=(o,e)=>o.map(n=>{let r=n.title,s=n.type?.name?Wn(n.type):"string",i=n.isOptional?`This optional ${s} field may be omitted`:`${/^[aeiou]/i.test(s)?"An":"A"} ${s} field`,a="";if(n.description){let u=Kn(n.description);e&&(u=ds(u,e)),a=` ${u}`}return`${r}: (${i})${a}`.trim()}).join(`
775
+ `),al=(o,e)=>o.map(n=>{let r=n.title,s=n.type?.name?Wn(n.type):"string",i=n.isOptional?`Only include this ${s} field if its value is available`:`This ${s} field must be included`,a="";if(n.description&&n.description.length>0){let u=n.type?.name==="class"?n.description:Kn(n.description);e&&(u=ds(u,e)),a=` ${u}`}return n.type?.options&&n.type.options.length>0&&(a.length>0&&(a+=". "),a+=`Allowed values: ${n.type.options.join(", ")}`),`${r}: (${i})${a}`.trim()}).join(`
776
+ `),mm=(o,e)=>{if(o.type?.name==="date"&&e instanceof Date){let t=e.toISOString();return t.slice(0,t.indexOf("T"))}return o.type?.name==="datetime"&&e instanceof Date?$c(e):o.type?.name==="image"&&typeof e=="object"||o.type?.name==="audio"&&typeof e=="object"||o.type?.name==="file"&&typeof e=="object"||o.type?.name==="url"&&(typeof e=="string"||typeof e=="object")||typeof e=="string"?e:JSON.stringify(e,null,2)};function gm(o){return`{ ${Object.entries(o).map(([t,n])=>{let r=n.isOptional?"?":"",s=Wn({name:n.type,isArray:n.isArray,fields:n.fields,options:n.options});return`${t}${r}: ${s}`}).join(", ")} }`}var Wn=o=>{let e=(()=>{switch(o?.name){case"string":return"string";case"number":return"number";case"boolean":return"boolean (true or false)";case"date":return'date ("YYYY-MM-DD" format)';case"datetime":return'date time ("YYYY-MM-DD HH:mm Timezone" format)';case"json":return"JSON object";case"class":return"classification class";case"code":return"code";case"file":return"file (with filename, mimeType, and data)";case"url":return"URL (string or object with url, title, description)";case"object":return o?.fields?`object ${gm(o.fields)}`:"object";default:return"string"}})();return o?.isArray?`json array of ${e} items`:e};function on(o){return(e,t)=>{if(t.type==="text"){let n=e.length>0?e[e.length-1]:null;n&&n.type==="text"?n.text+=o+t.text:e.push(t)}else e.push(t);return e}}var fm=(o,e,t)=>{if(typeof e=="boolean"||o?.type?.name==="number"&&typeof e=="number")return!1;if(!e||(Array.isArray(e)||typeof e=="string")&&e.length===0){if(t?.isExample||o.isOptional||o.isInternal)return!0;let n=t?.isInputField!==!1?"input":"output";throw new Error(`Value for ${n} field '${o.name}' is required.`)}return!1};function Kn(o){let e=o.trim();return e.length>0?`${e.charAt(0).toUpperCase()}${e.slice(1)}${e.endsWith(".")?"":"."}`:""}function ds(o,e){if(e.size===0)return o;let t=o,n=Array.from(e.keys()).sort((r,s)=>s.length-r.length);for(let r of n){let s=e.get(r),i=new RegExp(`\`${r}\``,"g");t=t.replace(i,`\`${s}\``);let a=new RegExp(`"${r}"`,"g");t=t.replace(a,`"${s}"`);let u=new RegExp(`'${r}'`,"g");t=t.replace(u,`'${s}'`);let c=new RegExp(`\\[${r}\\]`,"g");t=t.replace(c,`[${s}]`);let l=new RegExp(`\\(${r}\\)`,"g");t=t.replace(l,`(${s})`);let p=new RegExp(`\\$${r}\\b`,"g");t=t.replace(p,`\`${s}\``)}return t}function hm(o,e){let t=o.history(0,e),n=t.some(s=>s.role==="function");return t.some(s=>s.role==="assistant"&&"functionCalls"in s&&Array.isArray(s.functionCalls)&&s.functionCalls.length>0)&&n}function xm(o,e){let t=o.history(0,e),n=[],r=t.filter(i=>i.role==="assistant"&&"functionCalls"in i&&Array.isArray(i.functionCalls)&&i.functionCalls.length>0),s=t.filter(i=>i.role==="function");for(let i of r)if("functionCalls"in i&&i.functionCalls)for(let a of i.functionCalls){let u=s.find(c=>"functionId"in c&&c.functionId===a.id);u&&"result"in u&&"functionId"in u&&n.push({index:n.length,functionName:a.function.name,functionId:a.id,args:a.function.params||"",result:String(u.result),isError:"isError"in u?!!u.isError:!1})}return n}async function ms(o,e,t,n){if(!e?.resultPicker||o.length<=1)return 0;let r=e.resultPicker;if((t?hm(t,n):!1)&&t){let u=xm(t,n),c=await r({type:"function",results:u});if(c<0||c>=u.length)throw new Error(`Result picker returned invalid index: ${c}. Must be between 0 and ${u.length-1}`);return c}let i=o.map((u,c)=>({index:c,sample:u.delta})),a=await r({type:"fields",results:i});if(a<0||a>=o.length)throw new Error(`Result picker returned invalid index: ${a}. Must be between 0 and ${o.length-1}`);return a}async function aa(o,e,t){let n=o?.getLast(e);if(!n||n.role!=="assistant"||n.chat.length<=1)return 0;let r=n.chat.map(i=>({version:0,index:i.index,delta:i.value}));return await ms(r,t,o,e)}var Vn=class{_stepIndex=0;maxSteps;_functionsExecuted=new Set;_lastFunctionCalls=[];_usage={promptTokens:0,completionTokens:0,totalTokens:0};state=new Map;_pendingOptions={};_functionsToAdd=[];_functionsToRemove=[];_stopRequested=!1;_stopResultValues;constructor(e){this.maxSteps=e}get stepIndex(){return this._stepIndex}get isFirstStep(){return this._stepIndex===0}get functionsExecuted(){return this._functionsExecuted}get lastFunctionCalls(){return this._lastFunctionCalls}get usage(){return this._usage}setModel(e){this._pendingOptions.model=e}setThinkingBudget(e){this._pendingOptions.thinkingTokenBudget=e}setTemperature(e){this._pendingOptions.modelConfig||(this._pendingOptions.modelConfig={}),this._pendingOptions.modelConfig.temperature=e}setMaxTokens(e){this._pendingOptions.modelConfig||(this._pendingOptions.modelConfig={}),this._pendingOptions.modelConfig.maxTokens=e}setOptions(e){Object.assign(this._pendingOptions,e)}addFunctions(e){this._functionsToAdd.push(...e)}removeFunctions(...e){this._functionsToRemove.push(...e)}stop(e){this._stopRequested=!0,this._stopResultValues=e}_beginStep(e){this._stepIndex=e,this._functionsExecuted=new Set,this._lastFunctionCalls=[]}_recordFunctionCall(e,t,n){this._functionsExecuted.add(e.toLowerCase()),this._lastFunctionCalls.push({name:e,args:t,result:n})}_addUsage(e,t,n){this._usage.promptTokens+=e,this._usage.completionTokens+=t,this._usage.totalTokens+=n}_consumePendingOptions(){if(Object.keys(this._pendingOptions).length===0)return;let e=this._pendingOptions;return this._pendingOptions={},e}_consumeFunctionsToAdd(){if(this._functionsToAdd.length===0)return;let e=this._functionsToAdd;return this._functionsToAdd=[],e}_consumeFunctionsToRemove(){if(this._functionsToRemove.length===0)return;let e=this._functionsToRemove;return this._functionsToRemove=[],e}get _isStopRequested(){return this._stopRequested}get _stopValues(){return this._stopResultValues}};var gs=class{tools;logger;constructor(e,t){this.tools=new Map(e.map(n=>[n.name,n])),this.logger=t}getToolParamFieldMap(){let e=new Map;for(let[,t]of this.tools.entries())if(t.parameters?.properties&&Object.keys(t.parameters.properties).length>0){let{paramFieldMap:n}=Am(t);e.set(t.name,n)}else e.set(t.name,new Map);return e}async route(e,t){let n=[],r={},s=new Map,i=new Map;for(let[a,u]of this.tools.entries())i.set(a,this.buildSanitizedFieldMap(u));for(let[a,u]of Object.entries(e)){let c=this.tools.get(this.normalizeToolName(a));if(c){u!=null&&typeof u=="object"&&s.set(c.name,u);continue}r[a]=u}for(let[a,u]of Object.entries(e))for(let[c,l]of this.tools.entries()){let p=i.get(c);if(!p)continue;let d=p.get(a);if(!d)continue;let m=s.get(l.name)??{};this.setNested(m,d,u),s.set(l.name,m)}for(let[a,u]of this.tools.entries()){let c=s.get(u.name);if(!(!c||Object.keys(c).length===0)){if(u.parameters&&u.parameters.type==="object"){let p=(u.parameters.required||[]).filter(d=>c[d]===void 0);if(p.length>0)throw new Qe(`Missing required arguments for tool '${u.name}': ${p.join(", ")}`)}n.push({id:u.name,name:u.name,args:JSON.stringify(c)})}}return{functionCalls:n,remainingFields:r}}normalizeToolName(e){return e.replace(/_([a-z])/g,(t,n)=>n.toUpperCase())}sanitizeFieldName(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}buildSanitizedFieldMap(e){let t=new Map;if(!e.parameters||!("properties"in e.parameters))return t;let n=(r,s)=>{for(let[i,a]of Object.entries(r)){let u=[...s,i];if(a&&a.type==="object"&&a.properties)n(a.properties,u);else{let c=`${e.name}.${u.join(".")}`,l=this.sanitizeFieldName(c);t.set(l,u)}}};return n(e.parameters.properties??{},[]),t}setNested(e,t,n){let r=e;for(let s=0;s<t.length-1;s++){let i=t[s],a=r[i];(typeof a!="object"||a===null)&&(r[i]={}),r=r[i]}r[t[t.length-1]]=n}isToolField(e){return this.tools.has(this.normalizeToolName(e))}getToolFieldNames(){return Array.from(this.tools.keys()).map(e=>e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,""))}};function Am(o){let e=[],t=new Map;if(!o.parameters||!o.parameters.properties)return{fields:e,paramFieldMap:t};let n=o.parameters.properties,r=o.parameters.required||[],s=(i,a,u)=>{for(let[c,l]of Object.entries(i)){let p=a?`${a}.${c}`:c,d=`${o.name}.${p}`;if(l.type==="object"&&l.properties)s(l.properties,p,l.required||[]);else{let m=ym(l);e.push({name:Cm(d),title:bm(o.name,p),type:m,description:l.description||`${c} parameter for ${o.name}`,isOptional:!0}),t.set(d,e[e.length-1])}}};return s(n,"",r),{fields:e,paramFieldMap:t}}function ym(o){switch(o.type){case"string":return{name:"string",isArray:!1};case"number":case"integer":return{name:"number",isArray:!1};case"boolean":return{name:"boolean",isArray:!1};case"array":{let e=o.items;if(e?.type)switch(e.type){case"string":return{name:"string",isArray:!0};case"number":case"integer":return{name:"number",isArray:!0};case"boolean":return{name:"boolean",isArray:!0};default:return{name:"json",isArray:!0}}return{name:"json",isArray:!0}}case"object":return{name:"json",isArray:!1};default:return{name:"string",isArray:!1}}}function bm(o,e){return`${o} ${e.replace(/\./g," ")}`}function Cm(o){return o.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}function ll(o,e,t){let n=new Me(e);if(t){let r=t.getToolParamFieldMap();for(let s of o){let i=r.get(s.name);if(i&&i.size>0)for(let a of i.values())n.getOutputFields().some(c=>c.name===a.name)||n.addOutputField(a);else{let a=ua(s.name),u=cl(s.parameters);n.getOutputFields().some(l=>l.name===a)||n.addOutputField({name:a,title:ul(s.name),type:u,description:s.description||`Parameters for ${s.name}`,isOptional:!0})}}return{signature:n,toolParamFieldMap:r}}else{let r=new Map;for(let s of o)if(s.parameters?.properties&&Object.keys(s.parameters.properties).length>0){let{fields:i,paramFieldMap:a}=Im(s);r.set(s.name,a);for(let u of i)n.getOutputFields().some(l=>l.name===u.name)||n.addOutputField(u)}else{let i=ua(s.name),a=cl(s.parameters);n.getOutputFields().some(c=>c.name===i)||n.addOutputField({name:i,title:ul(s.name),type:a,description:s.description||`Parameters for ${s.name}`,isOptional:!0})}return{signature:n,toolParamFieldMap:r}}}function Im(o){let e=[],t=new Map;if(!o.parameters||!o.parameters.properties)return{fields:e,paramFieldMap:t};let n=o.parameters.properties,r=o.parameters.required||[],s=(i,a,u)=>{for(let[c,l]of Object.entries(i)){let p=a?`${a}.${c}`:c,d=`${o.name}.${p}`;if(l.type==="object"&&l.properties)s(l.properties,p,l.required||[]);else{let m=Tm(l),g={name:ua(d),title:wm(o.name,p),type:m,description:l.description||`${c} parameter for ${o.name}`,isOptional:!0};e.push(g),t.set(d,g)}}};return s(n,"",r),{fields:e,paramFieldMap:t}}function Tm(o){switch(o.type){case"string":return{name:"string",isArray:!1};case"number":case"integer":return{name:"number",isArray:!1};case"boolean":return{name:"boolean",isArray:!1};case"array":{let e=o.items;if(e?.type)switch(e.type){case"string":return{name:"string",isArray:!0};case"number":case"integer":return{name:"number",isArray:!0};case"boolean":return{name:"boolean",isArray:!0};default:return{name:"json",isArray:!0}}return{name:"json",isArray:!0}}case"object":return{name:"json",isArray:!1};default:return{name:"string",isArray:!1}}}function wm(o,e){return`${o} ${e.replace(/\./g," ")}`}function ua(o){return o.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}function ul(o){return o.replace(/([A-Z])/g," $1").replace(/^./,e=>e.toUpperCase()).trim()}function cl(o){return!o||!o.properties||Object.keys(o.properties).length===0?{name:"string",isArray:!1}:{name:"json",isArray:!1}}var sn=class{tools;router;injectedToolFieldNames=new Set;constructor(e){this.tools=e,this.router=new gs(e)}processSignature(e){let{signature:t}=ll(this.tools,e),n=new Set(t.getOutputFields().map(s=>s.name)),r=new Set(e.getOutputFields().map(s=>s.name));return this.injectedToolFieldNames=new Set([...n].filter(s=>!r.has(s))),t}async processResults(e,t){let{functionCalls:n}=await this.router.route(e,t);return n.length>0?n:void 0}getInjectedToolFieldNames(){return Array.from(this.injectedToolFieldNames)}getRouter(){return this.router}};var an="__finalResult",Pe=class o extends Ht{clone=()=>new o(this.signature,this.options);promptTemplate;asserts;streamingAsserts;options;functions;fieldProcessors=[];streamingFieldProcessors=[];excludeContentFromTrace=!1;thoughtFieldName;signatureToolCallingManager;structuredOutputFunctionFallback=!1;activeAbortControllers=new Set;_stopRequested=!1;constructor(e,t){super(e,{description:t?.description,traceLabel:t?.traceLabel}),this.options=t,this.thoughtFieldName=t?.thoughtFieldName??"thought";let n={functions:t?.functions,thoughtFieldName:this.thoughtFieldName};this.promptTemplate=new(t?.promptTemplate??Kt)(this.signature,n),this.asserts=this.options?.asserts??[],this.streamingAsserts=this.options?.streamingAsserts??[],this.excludeContentFromTrace=t?.excludeContentFromTrace??!1,this.functions=t?.functions?rn(t.functions):[],this.usage=[]}stop(){this._stopRequested=!0;for(let e of this.activeAbortControllers)e.abort("Stopped by user")}setInstruction(e){this.promptTemplate.setInstruction(e)}getInstruction(){return this.promptTemplate.getInstruction()}async renderPromptForInternalUse(e,t,n){let r=n?.promptTemplate??this.options?.promptTemplate??Kt,s=[...this.functions],i=n?.functionCallMode??this.options?.functionCallMode??"auto",a=s.length>0,u;a&&i==="prompt"&&(u=new sn(s)),a&&i==="auto"&&!e.getFeatures(n?.model).functions&&(u=new sn(s));let c=new Me(this.signature);u&&(c=u.processSignature(c));let l=c.hasComplexFields(),p=e.getFeatures?.(n?.model),d=n?.structuredOutputMode??this.options?.structuredOutputMode??"auto",m=l&&(d==="function"||d==="auto"&&!p?.structuredOutputs),g=e.getFeatures?.(n?.model)?.caching?.cacheBreakpoints===!1,f=new r(c,{functions:u?[]:s,thoughtFieldName:this.thoughtFieldName,contextCache:n?.contextCache,examplesInSystem:n?.examplesInSystem,ignoreBreakpoints:g,structuredOutputFunctionName:m?an:void 0}),x=this.getInstruction();x!==void 0&&f.setInstruction(x),Array.isArray(t)&&pi(t);let A=f.render(t,{examples:this.examples,demos:this.demos}),h=n?.mem??this.options?.mem;if(!h)return A;let y=await aa(h,n?.sessionId,{resultPicker:n?.resultPicker});return[...h.history(y,n?.sessionId),...A]}async _measurePromptCharsForInternalUse(e,t,n){return yo(await this.renderPromptForInternalUse(e,t,n))}getSignatureName(){return this.signature.getDescription()||"unknown_signature"}getMetricsInstruments(){return Di()}getMergedCustomLabels(e,t){return Xt(ge.customLabels,e?.getOptions?.()?.customLabels,t?.customLabels)}updateMeter(e){Di(e)}createStates(e){return Array.from({length:e},(t,n)=>({index:n,functionCalls:[],values:{},content:"",functionsExecuted:new Set,xstate:{extractedFields:[],streamedIndex:{},s:-1}}))}addAssert(e,t){this.asserts.push({fn:e,message:t})}addStreamingAssert(e,t,n){let r=this.signature.getOutputFields().find(a=>a.name===e);if(!r)throw new Error(`addStreamingAssert: field ${String(e)} not found in output signature`);let s=r.type?.name;if(!(!s||s==="string"||s==="code"))throw new Error(`addStreamingAssert: field ${String(e)} must be a string field for streaming assertions`);this.streamingAsserts.push({fieldName:String(e),fn:t,message:n})}addFieldProcessorInternal(e,t,n=!1){let r=this.signature.getOutputFields().find(s=>s.name===e);if(!r)throw new Error(`addFieldProcessor: field ${e} not found`);if(n){let s=r.type?.name;if(!(!s||s==="string"||s==="code"))throw new Error(`addFieldProcessor: field ${e} must be a text field`);this.streamingFieldProcessors.push({field:r,process:t})}else this.fieldProcessors.push({field:r,process:t})}addStreamingFieldProcessor(e,t){this.addFieldProcessorInternal(String(e),t,!0)}addFieldProcessor(e,t){this.addFieldProcessorInternal(String(e),t,!1)}async forwardSendRequest({ai:e,mem:t,options:n,traceContext:r,functions:s,functionCall:i,stepIndex:a}){let{sessionId:u,model:c,rateLimiter:l,stream:p,thinkingTokenBudget:d,showThoughts:m}=n??{},g=await aa(t,u,{resultPicker:n?.resultPicker}),f=t?.history(g,u)??[];if(f.length===0)throw new Error("No chat prompt found");let x={...n?.modelConfig,...n?.sampleCount?{n:n.sampleCount}:{},...n?.sampleCount&&n?.modelConfig?.temperature===1?{temperature:.8}:{}},A=this.isDebug(e,n),h=a===0,y=this.getLogger(e,n);s=this.signatureToolCallingManager?[]:s;let C,I=this.signature.getOutputFields();if(this.signature.hasComplexFields()&&!this.structuredOutputFunctionFallback){if(!e.getFeatures(c)?.structuredOutputs)throw new Error(`Complex structured outputs (object/array types) require a provider that supports structured outputs. Current provider/model (${c}) does not support this feature. Supported providers: OpenAI (GPT-4o, GPT-4.1+), Google Gemini, Anthropic (Sonnet/Opus).`);C={type:"json_schema",schema:{name:"output",strict:!0,schema:qt(I)}}}let O=n?.contextCache?.cacheBreakpoint??"after-examples",R=e.getFeatures?.(c)?.caching?.cacheBreakpoints===!1,E=n?.contextCache&&(R||O==="after-functions"||O==="after-examples"),S=s?.length&&E?s.map(($,M)=>({...$,cache:M===s.length-1})):s;return await e.chat({chatPrompt:f,functions:S,functionCall:i,modelConfig:x,model:c,responseFormat:C},{sessionId:u,rateLimiter:l,stream:p,debug:A,debugHideSystemPrompt:n?.debugHideSystemPrompt??this.options?.debugHideSystemPrompt??!h,thinkingTokenBudget:d,showThoughts:m,traceContext:r,abortSignal:n?.abortSignal??ge.abortSignal,stepIndex:a,logger:y,functionCallMode:n?.functionCallMode??this.options?.functionCallMode??"auto",retry:n?.retry??this.options?.retry,customLabels:n?.customLabels})}async*forwardCore({ai:e,mem:t,options:n,stepIndex:r,span:s,traceContext:i,states:a,stopFunctionNames:u,stepContext:c}){let{sessionId:l,functions:p}=n??{},d=n?.functionResultFormatter??this.options?.functionResultFormatter,m=n?.functionCall??this.options?.functionCall,g=this.signatureToolCallingManager,f=n?.strictMode??!1,x=n.model,A=this.usage,h=r===0,y=this.isDebug(e,n),C=this.getLogger(e,n),{functions:I,functionCall:v}=Hc(p,m,h,n);this.structuredOutputFunctionFallback&&I.filter(E=>E.name!==an).length===0&&(v={type:"function",function:{name:an}});let O=await this.forwardSendRequest({ai:e,mem:t,options:n,traceContext:i,functions:I,functionCall:v,stepIndex:r});O instanceof ReadableStream?yield*Wc({ai:e,model:x,res:O,mem:t,sessionId:l,traceId:s?s.spanContext?.().traceId:void 0,functions:I,strictMode:f,span:s,states:a,usage:A,asserts:this.asserts,streamingAsserts:this.streamingAsserts,fieldProcessors:this.fieldProcessors,streamingFieldProcessors:this.streamingFieldProcessors,thoughtFieldName:this.thoughtFieldName,excludeContentFromTrace:this.excludeContentFromTrace,signature:this.signature,logger:C,debug:y,functionResultFormatter:d,signatureToolCallingManager:g,stopFunctionNames:u,disableMemoryCleanup:n.disableMemoryCleanup,stepContext:c,abortSignal:n.abortSignal}):yield*Vc({ai:e,model:x,res:O,mem:t,sessionId:l,traceId:s?s.spanContext?.().traceId:void 0,functions:I,span:s,strictMode:f,states:a,usage:A,asserts:this.asserts,fieldProcessors:this.fieldProcessors,thoughtFieldName:this.thoughtFieldName,excludeContentFromTrace:this.excludeContentFromTrace,signature:this.signature,logger:C,debug:y,functionResultFormatter:d,signatureToolCallingManager:g,stopFunctionNames:u,disableMemoryCleanup:n.disableMemoryCleanup,stepContext:c,abortSignal:n.abortSignal})}async*_forward2(e,t,n,r,s,i){this.signatureToolCallingManager=void 0;let a=r?.stopFunction??this.options?.stopFunction,u=Array.isArray(a)?a.map(re=>re.toLowerCase()):a?[a.toLowerCase()]:void 0,c=r.maxRetries??this.options?.maxRetries??3,l=r.maxSteps??this.options?.maxSteps??25,p=r.mem??this.options?.mem??new Un,d=r.functions?rn(r.functions):[...this.functions],m=new Vn(l),g;if(r.selfTuning){if(g=r.selfTuning===!0?{model:!0,thinkingBudget:!0}:r.selfTuning,g.model!==!1){let Ce=e.getModelList()?.filter(L=>"model"in L);if(!Ce||Ce.length<2)throw new Error("Self-tuning with model selection requires the AI service to have a `models` list with at least 2 chat models. Either configure models on your AI service or disable model selection with `selfTuning: { model: false }`.")}let re=Xi(e,g,r.model?String(r.model):void 0);d.push(re)}let f={...r},x=r.stepHooks,A=d&&d.length>0,h=r.functionCallMode??this.options?.functionCallMode??"auto";A&&h==="prompt"&&(this.signatureToolCallingManager=new sn(d)),A&&h==="auto"&&!e.getFeatures(r.model).functions&&(this.signatureToolCallingManager=new sn(d));let y,C,I=this.options?.promptTemplate??Kt;this.signatureToolCallingManager&&(this.signature=this.signatureToolCallingManager.processSignature(this.signature),this.setSignature(this.signature));let v=this.signature.hasComplexFields(),O=e.getFeatures?.(r.model),R=r.structuredOutputMode??this.options?.structuredOutputMode??"auto";if(this.structuredOutputFunctionFallback=v&&(R==="function"||R==="auto"&&!O?.structuredOutputs),this.structuredOutputFunctionFallback){let re={name:an,description:"Return the final result. Call this function with the complete output data.",parameters:qt(this.signature.getOutputFields()),func:async()=>"done"};d.push(re),u=[...u??[],an.toLowerCase()]}let E=e.getFeatures?.(r.model)?.caching?.cacheBreakpoints===!1,S={functions:this.signatureToolCallingManager?[]:d,thoughtFieldName:this.thoughtFieldName,contextCache:r.contextCache,examplesInSystem:r.examplesInSystem,ignoreBreakpoints:E,structuredOutputFunctionName:this.structuredOutputFunctionFallback?an:void 0};this.promptTemplate=new I(this.signature,S);let _,$=performance.now();Array.isArray(t)?(pi(t),_=this.promptTemplate.render(t,{examples:this.examples,demos:this.demos})):_=this.promptTemplate.render(t,{examples:this.examples,demos:this.demos});let M=performance.now()-$,F=this.getMetricsInstruments(),N=this.getMergedCustomLabels(e,r);F&&es(F,"prompt_render",M,this.getSignatureName(),N);let G=performance.now();p.addRequest(_,r.sessionId);let W=performance.now()-G;F&&es(F,"memory_update",W,this.getSignatureName(),N);let U=new Map;n.forEach(re=>{U.set(re.index,{})});let ae=()=>{let re=m._consumePendingOptions();if(re){let{modelConfig:L,...K}=re;f={...f,...K},L&&(f.modelConfig={...f.modelConfig,...L})}let oe=m._consumeFunctionsToAdd();if(oe){let L=rn(oe);for(let K of L)d.some(ee=>ee.name===K.name)||d.push(K)}let Ce=m._consumeFunctionsToRemove();if(Ce){let L=new Set(Ce.map(K=>K.toLowerCase()));for(let K=d.length-1;K>=0;K--)L.has(d[K].name.toLowerCase())&&d.splice(K,1)}},j=r?.abortSignal??ge.abortSignal;e:for(let re=0;re<l;re++){if(m._beginStep(re),ae(),g&&g.model!==!1){let Ce=d.findIndex(L=>L.name==="adjustGeneration");if(Ce!==-1){let L=f.model?String(f.model):void 0;d[Ce]=Xi(e,g,L)}}if(m._isStopRequested)break;if(j?.aborted)throw new _e("between-steps",j.reason??"Aborted between steps");if(x?.beforeStep&&(await x.beforeStep(m),ae(),m._isStopRequested))break;let oe=c;for(let Ce=0;Ce<=oe;Ce++)try{let L=c+1;for(let ee=0;ee<L;ee++){n.forEach(q=>{q.content="",q.values={},q.functionCalls=[],q.functionsExecuted=new Set,q.xstate={extractedFields:[],streamedIndex:{},s:-1}}),ee>0&&U.forEach((q,B)=>{U.set(B,{})});let he=new Map;n.forEach(q=>{he.set(q.index,{})});try{let q=this.forwardCore({options:{...f,functions:d},ai:e,mem:p,stepIndex:re,span:s,traceContext:i,states:n,stopFunctionNames:u,stepContext:m}),B=!1;try{for await(let ce of q)if(ce!==void 0){let Re=ce.index,se=ce.delta,de=he.get(Re)??{},J=U.get(Re)??{},X={},xe=!1;for(let we of Object.keys(se)){let Be=se[we],$e=de[we],ut;typeof Be=="string"&&(typeof $e=="string"||$e===void 0)?ut=($e??"")+Be:Array.isArray(Be)&&(Array.isArray($e)||$e===void 0)?ut=[...$e??[],...Be]:ut=Be,de[we]=ut;let Ee=ut,ze=J[we];if(typeof Ee=="string"&&typeof ze=="string")if(Ee.startsWith(ze)){let pe=Ee.slice(ze.length);pe&&(X[we]=pe,xe=!0,J[we]=Ee)}else ze.startsWith(Ee)||Ee!==ze&&(X[we]=Ee,xe=!0,J[we]=Ee);else if(Array.isArray(Ee)&&Array.isArray(ze)){if(Ee.length>ze.length){let pe=Ee.slice(ze.length);X[we]=pe,xe=!0,J[we]=Ee}}else JSON.stringify(Ee)!==JSON.stringify(ze)&&(X[we]=Ee,xe=!0,J[we]=Ee)}xe&&(yield{version:ee,index:ce.index,delta:X})}}catch(ce){if(ce instanceof nn){if(B=!0,this.structuredOutputFunctionFallback){let Re=ce.calls.find(se=>se.func.name===an);if(Re?.args){let se=Re.args;zn(this.signature,se);let de=this.signature.getOutputFields();for(let J of n){let X={};for(let xe of de)xe.name in se&&!xe.isInternal&&(X[xe.name]=se[xe.name],J.values[xe.name]=se[xe.name]);yield{version:ee,index:J.index,delta:X}}for(let J of n)await Gn(this.asserts,J.values);if(this.fieldProcessors.length>0)for(let J of n)await $r(this.fieldProcessors,J.values,p,r.sessionId)}}}else throw ce}if(this.usage.length>0){let ce=this.usage[this.usage.length-1];ce?.tokens&&m._addUsage(ce.tokens.promptTokens??0,ce.tokens.completionTokens??0,ce.tokens.totalTokens??0)}n.some(ce=>ce.functionsExecuted.size>0)&&x?.afterFunctionExecution&&(await x.afterFunctionExecution(m),ae());let ke=B||m._isStopRequested?!1:Jc(p,u,n,f?.sessionId);if(x?.afterStep&&(await x.afterStep(m),ae()),ke&&!m._isStopRequested&&!j?.aborted){let ce=this.getMetricsInstruments();ce&&Zo(ce,re+1,l,this.getSignatureName(),N);continue e}if(j?.aborted)throw new _e("mid-step",j.reason??"Aborted");r?.disableMemoryCleanup||(p.removeByTag("invalid-assistant",r.sessionId),p.removeByTag("correction",r.sessionId),p.removeByTag("error",r.sessionId));let Oe=this.getMetricsInstruments();if(Oe){Zo(Oe,re+1,l,this.getSignatureName(),N);let ce=new Set;n.forEach(Re=>{Re.functionsExecuted.forEach(se=>ce.add(se))}),ce.size>0&&Ac(Oe,!0,ce.size,!0,!1,this.getSignatureName(),N),yc(Oe,this.fieldProcessors.length,this.streamingFieldProcessors.length,this.getSignatureName(),N)}return}catch(q){if(q instanceof _e)throw q;C=q;let B,ue=this.isDebug(e,r),ke=this.getLogger(e,r),Oe=this.getMetricsInstruments(),ce=this.getSignatureName(),Re={error:q,errCount:ee,logger:ke,metricsInstruments:Oe,signatureName:ce,span:s,debug:ue,customLabels:N};if(s?.recordException(q),q instanceof Qe)B=Oc(Re),y=q;else if(q instanceof Et)B=Ec(Re),y=q;else if(q instanceof Le)Mc(Re);else{if(q instanceof gt)throw q;{let se=q,de=se instanceof rt&&se.status>=500&&se.status<600,J=se instanceof Je,X=se instanceof dt;throw de||J||X?q:ca(q,e,this.signature)}}if(B&&(p.addTag("error",r.sessionId),p.addRequest([{role:"user",content:this.promptTemplate.renderExtraFields(B)}],r.sessionId),p.addTag("correction",r.sessionId),this.signature.hasComplexFields()))for(let de of n)de.content="",de.values={},de.xstate={extractedFields:[],streamedIndex:{},s:-1}}}let K=this.getMetricsInstruments();throw K&&Gi(K,c,!1,c,this.getSignatureName(),N),ca(new Error(`Unable to fix validation error: ${(y??C)?.message??(y??C)?.toString()??"unknown error"}
777
777
 
778
778
  LLM Output:
779
- ${n.map(ne=>ne.content).join(`
779
+ ${n.map(ee=>ee.content).join(`
780
780
  ---
781
- `)}`),e,this.signature)}catch($){let K=$,ne=K instanceof rt&&K.status>=500&&K.status<600,pe=K instanceof Je,X=K instanceof dt,z=K instanceof gt;if((ne||pe||X||z)&&ve<xe){let Oe=this.isDebug(e,r),Ee=this.getLogger(e,r),ae=Math.min(6e4,1e3*Math.pow(2,ve));Oe&&Ee&&Ee({name:"Notification",id:"infrastructure-retry",value:`Infrastructure error (attempt ${ve+1}/${xe+1}): ${K.message}. Retrying in ${ae}ms...`}),s?.addEvent("infrastructure.retry",{attempt:ve+1,maxRetries:xe,delay:ae,errorType:K instanceof rt?"status_error":K instanceof Je?"network_error":K instanceof dt?"timeout_error":"stream_terminated",errorMessage:K.message}),await new Promise((Ae,be)=>{let oe=!1,ge,Ie=()=>{j&&ge&&j.removeEventListener("abort",ge)},$e=setTimeout(()=>{oe||(oe=!0,Ie(),Ae())},ae);if(j){if(ge=()=>{oe||(oe=!0,clearTimeout($e),Ie(),be(new Pe("infrastructure-retry-backoff",j.reason?String(j.reason):"Aborted during retry backoff")))},j.aborted){ge();return}j.addEventListener("abort",ge,{once:!0})}});continue}throw $}}throw F&&Jo(F,u,u,this.getSignatureName(),N),ra(new Error(`Max steps reached: ${u}`),e,this.signature)}validateInputs(e){let t=this.signature.getInputFields();for(let n of t){if(n.isInternal)continue;let r=e[n.name];if(n.isOptional&&r===void 0)continue;let s=n.type;if(s&&(s.name==="url"&&jt(r,n),s.name,s.name,(s.name==="string"||s.name==="code")&&xt(r,n),s.name==="number"&&At(r,n),s.name==="object"&&s.fields&&typeof r=="object"&&r!==null&&this.validateObjectFields(r,s.fields,n.name),s.isArray&&Array.isArray(r)))for(let i=0;i<r.length;i++){let a=r[i];s.name==="string"||s.name==="code"?xt(a,n):s.name==="number"?At(a,n):s.fields&&typeof a=="object"&&a!==null&&this.validateObjectFields(a,s.fields,`${n.name}[${i}]`)}}}validateObjectFields(e,t,n){for(let[r,s]of Object.entries(t)){let i=e[r];if(s.isOptional&&i===void 0)continue;let a={name:`${n}.${r}`,type:{name:s.type,isArray:s.isArray,options:s.options?[...s.options]:void 0,fields:s.fields,minLength:s.minLength,maxLength:s.maxLength,minimum:s.minimum,maximum:s.maximum,pattern:s.pattern,format:s.format},description:s.description,isOptional:s.isOptional};if(s.type==="string"||s.type==="code"?xt(i,a):s.type==="number"?At(i,a):s.type==="object"&&s.fields&&typeof i=="object"&&i!==null&&this.validateObjectFields(i,s.fields,a.name),s.isArray&&Array.isArray(i))for(let l=0;l<i.length;l++){let c=i[l];s.type==="string"||s.type==="code"?xt(c,a):s.type==="number"?At(c,a):s.fields&&typeof c=="object"&&c!==null&&this.validateObjectFields(c,s.fields,`${a.name}[${l}]`)}}}async*_forward1(e,t,n){(!Array.isArray(t)||!t.every(a=>"role"in a))&&this.validateInputs(t);let r=new AbortController;this.activeAbortControllers.add(r),this._stopRequested&&r.abort("Stopped by user (pre-forward)");let s=vt(r.signal,n?.abortSignal??de.abortSignal),i=s?{...n,abortSignal:s}:n;try{let a=performance.now(),l=this.createStates(n.sampleCount??1),c=performance.now()-a,u=this.getMetricsInstruments(),p=this.getMergedCustomLabels(e,n);u&&Qo(u,"state_creation",c,this.getSignatureName(),p);let d=n?.tracer??this.options?.tracer??e.getOptions().tracer,m=this.functions;if(n?.functions&&(m=tn(n.functions,this.functions)),!d){yield*this._forward2(e,t,l,{...i,functions:m});return}let g=m?.map(C=>C.name).join(","),f={signature:JSON.stringify(this.signature.toJSON(),null,2),...this.examples?{examples:JSON.stringify(this.examples,null,2)}:{},...g?{provided_functions:g}:{},...n?.model?{model:n.model}:{},...n?.thinkingTokenBudget?{thinking_token_budget:n.thinkingTokenBudget}:{},...n?.showThoughts?{show_thoughts:n.showThoughts}:{},...n?.maxSteps?{max_steps:n.maxSteps}:{},...n?.maxRetries?{max_retries:n.maxRetries}:{}},x=this.traceLabel&&n.traceLabel?`${this.traceLabel} > ${n.traceLabel}`:n.traceLabel??this.traceLabel,A=x?`AxGen > ${x}`:"AxGen",h=d.startSpan(A,{kind:Kn.SpanKind.SERVER,attributes:f}),b=Kn.context.active(),T=Kn.trace.setSpan(b,h);try{if(this.excludeContentFromTrace||h.addEvent("input",{content:JSON.stringify(t,null,2)}),yield*this._forward2(e,t,l,{...i,functions:m},h,T),!this.excludeContentFromTrace){let C=l.map(k=>k.values),v=C.length===1?C[0]:C;h.addEvent("output",{content:JSON.stringify(v,null,2)})}}finally{h.end()}}finally{this.activeAbortControllers.delete(r),this._stopRequested=!1}}async forward(e,t,n){let r=n?.cachingFunction??this.options?.cachingFunction??de.cachingFunction,s=(()=>{if(!r)return;let d=this.signature.getInputFields().map(m=>m.name);return this.computeCacheKey(t,d)})();if(r&&s){let d=await r(s);if(d!==void 0)return d}let i=performance.now(),a=this.getSignatureName(),l=n?.stream??!1,c=!1,u=0,p=!1;try{let d=this.getMetricsInstruments(),m=this.getMergedCustomLabels(e,n);d&&cc(d,this.signature.getInputFields().length,this.signature.getOutputFields().length,this.examples?.length??0,this.demos?.length??0,a,m);let g=this._forward1(e,t,n??{}),f=[],x=0,A=0;for await(let R of g)R.version!==x&&(f=[]),x=R.version,f=Ui(f,R),A++;u=x;let h=performance.now();p=!!n?.resultPicker;let b=await cs(f,{resultPicker:n?.resultPicker},n?.mem,n?.sessionId),T=performance.now()-h,v=f[b]?.delta??{},k=Array.isArray(t)?{}:t??{};if(this.trace={...k,...v},p&&this.isDebug(e,n)){let R=this.getLogger(e,n);sl(f.length,b,T,R)}if(c=!0,d&&(lc(d,f.length,p,p?T:void 0,a,m),ac(d,l,A,void 0,a,m)),r&&s)try{await r(s,v)}catch{}return v}catch(d){throw c=!1,d}finally{let d=performance.now()-i,m=this.getMetricsInstruments(),g=this.getMergedCustomLabels(e,n);m&&(rc(m,d,c,a,e.getName(),n?.model?String(n.model):void 0,g),u>0&&Ni(m,u,c,n?.maxRetries??this.options?.maxRetries??3,a,g))}}async*streamingForward(e,t,n){let r=n?.cachingFunction??this.options?.cachingFunction??de.cachingFunction,s=(()=>{if(!r)return;let p=this.signature.getInputFields().map(d=>d.name);return this.computeCacheKey(t,p)})();if(r&&s){let p;try{p=await r(s)}catch{}if(p!==void 0){yield{version:0,index:0,delta:p};return}}if(!n?.resultPicker){yield*this._forward1(e,t,{...n,stream:!0});return}let i=this._forward1(e,t,{...n,stream:!0}),a=[],l=0;for await(let p of i)p.version!==l&&(a=[]),l=p.version,a=Ui(a,p);let c=await cs(a,{resultPicker:n?.resultPicker},n?.mem,n?.sessionId),u=a[c];if(u){if(r&&s)try{await r(s,u.delta)}catch{}yield{version:l,index:c,delta:u.delta}}}setExamples(e,t){super.setExamples(e,t)}isDebug(e,t){return t?.debug??this.options?.debug??de.debug??e.getOptions().debug??!1}getLogger(e,t){return t?.logger??this.options?.logger??de.logger??e.getLogger()}computeCacheKey(e,t){let n=pt("sha256");n.update(this.signature.hash()??"");let r=s=>{let i=typeof s;if(n.update(`|${i}|`),s==null){n.update("null");return}if(i==="string"||i==="number"||i==="boolean"){n.update(String(s));return}if(Array.isArray(s)){n.update("[");for(let a of s)r(a);n.update("]");return}if(typeof s=="object"&&s!==null&&"mimeType"in s&&"data"in s){let a=s;n.update(a.mimeType??"");let l=pt("sha256").update(a.data??"").digest("hex");n.update(l);return}if(typeof s=="object"){let a=s,l=Object.keys(a).sort();for(let c of l)n.update(`{${c}}`),r(a[c]);return}n.update(String(s))};if(Array.isArray(e))for(let s of e){n.update(`role:${s.role}`);let i=t.map(a=>s.values?.[a]);for(let a of i)r(a)}else{let s=t.map(i=>e?.[i]);for(let i of s)r(i)}return n.digest("hex")}},Br=class extends Error{details;constructor(e,t,n){super(e),this.name="AxGenerateError",this.details=t,n?.cause&&(this.cause=n.cause)}toJSON(){let e=this.cause;return{name:this.name,message:this.message,details:this.details,cause:e?{name:e.name,message:e.message,stack:e.stack}:void 0,stack:this.stack}}};function ra(o,e,t){let n=o instanceof Error?o:new Error(String(o));if(n instanceof Pe)return n;let r=(n.message||"").toLowerCase();if(r.includes("at least")||r.includes("at most")||r.includes("must match pattern")||r.includes("invalid url")||r.includes("required")||r.includes("missing")||r.includes("valid email")||r.includes("number must be")||n.name==="ValidationError"||n.name==="AssertionError"||n.name==="AxAssertionError"||n.stack?.includes("asserts.ts"))return n;let i=e.getLastUsedChatModel(),a=e.getLastUsedModelConfig(),l={model:i,maxTokens:a?.maxTokens,streaming:a?.stream??!1,signature:{input:t.getInputFields(),output:t.getOutputFields(),description:t.getDescription()}};return new Br(`Generate failed: ${n.message}`,l,{cause:n})}var $d=o=>o.replace(/^\W+|\W+$/g,""),Dd=(o,e)=>{let t=o.search(e);if(t===-1)return[o];let n=o.match(e);if(!n)throw new Error("Match failed unexpectedly.");let r=o.substring(0,t),s=o.substring(t+n[0].length);return[r,s]},Ud=o=>{let e=new Set,t=[];for(let n of o)e.has(n)||(e.add(n),t.push(n));return t},Gd=o=>{let e=o.match(/^(\d+)[.,\s]+(.*)$/);if(!e||e.length<3)throw new Error('line must start with a number, a dot and then text. e.g. "1. hello"');let t=Number.parseInt(e[1],10),n=e[2].trim();return{id:t,text:n}},Bd=o=>{let e=o.match(/^(\d+)[.,\s]+(.*)$/);return e&&e[2]!==void 0?e[2].trim():o},jd=(o,e)=>{let t=[];for(let n=0;n<o.length;n+=e)t.push(o.slice(n,n+e));return t},ps={trimNonAlphaNum:$d,splitIntoTwo:Dd,dedup:Ud,extractIdAndText:Gd,extractIndexPrefixedText:Bd,batchArray:jd};var ds=class extends ke{constructor(e){super(`"You are a re-ranker assistant tasked with evaluating a set of content items in relation to a specific question. Your role involves critically analyzing each content item to determine its relevance to the question and re-ranking them accordingly. This process includes assigning a relevance score from 0 to 10 to each content item based on how well it answers the question, its coverage of the topic, and the reliability of its information. This re-ranked list should start with the content item that is most relevant to the question and end with the least relevant. Output only the list."
782
- query: string, items: string[] -> rankedItems: string[] "list of id, 5-words Rationale, relevance score"`,e)}forward=async(e,t,n)=>{let{rankedItems:r}=await super.forward(e,t,n),s=r.map(a=>{let{id:l}=ps.extractIdAndText(a);return l});return{rankedItems:t.items.map((a,l)=>{let c=s[l];return c!==void 0?t.items[c]:void 0}).filter(a=>a!==void 0)}}};var ms=class{tikaUrl;fetch;constructor(e){let t=e??{url:"http://localhost:9998/"};this.tikaUrl=new URL("/tika",t.url),this.fetch=t.fetch}async _convert(e,t){if(!e)throw new Error("Failed to read file data");let n=t?.format==="html"?"text/html":"text/plain";try{let r={body:e,headers:{Accept:n},method:"PUT"};typeof window>"u"&&typeof process<"u"&&(r.duplex="half");let s=await(this.fetch??fetch)(this.tikaUrl,r);if(!s.ok)throw new Error(`Failed to upload file: ${s.statusText}`);return await s.text()}catch(r){throw new Error(`Error converting file: ${r}`)}}async convert(e,t){let n=[],r=t?.batchSize??10;for(let s=0;s<e.length;s+=r){let a=e.slice(s,s+r).map(c=>this._convert(c,{format:t?.format})),l=await Promise.all(a);n.push(...l)}return n}};var iT=new ot,gs=class{name;context;constructor(e,t){this.name=e,this.context=t}getName(){return this.name}getContext(){return this.context}},fs=class{ai;db;debug;constructor(e){this.db=new Gt,this.ai=e}getState(){return this.db.getDB()}setState(e){this.db.setDB(e)}setClasses=async(e,t)=>{for(let n of e){let r=await this.ai.embed({texts:n.getContext()},{abortSignal:t?.abortSignal});await this.db.upsert({id:n.getName(),table:"classes",values:r.embeddings[0]})}};async forward(e,t){let{embeddings:n}=await this.ai.embed({texts:[e]},{abortSignal:t?.abortSignal}),s=(await this.db.query({table:"classes",values:n[0]})).matches;if(typeof t?.cutoff=="number"){let{cutoff:a}=t;s=s.filter(l=>l.score<=a)}let i=s.at(0);return i?i.id:""}setOptions(e){typeof e.debug=="boolean"&&(this.debug=e.debug)}};var Zc=new Set(["0o","0s","3a","3b","3d","6b","6o","a","a1","a2","a3","a4","ab","able","about","above","abst","ac","accordance","according","accordingly","across","act","actually","ad","added","adj","ae","af","affected","affecting","affects","after","afterwards","ag","again","against","ah","ain","ain't","aj","al","all","allow","allows","almost","alone","along","already","also","although","always","am","among","amongst","amoungst","amount","an","and","announce","another","any","anybody","anyhow","anymore","anyone","anything","anyway","anyways","anywhere","ao","ap","apart","apparently","appear","appreciate","appropriate","approximately","ar","are","aren","arent","aren't","arise","around","as","a's","aside","ask","asking","associated","at","au","auth","av","available","aw","away","awfully","ax","ay","az","b","b1","b2","b3","ba","back","bc","bd","be","became","because","become","becomes","becoming","been","before","beforehand","begin","beginning","beginnings","begins","behind","being","believe","below","beside","besides","best","better","between","beyond","bi","bill","biol","bj","bk","bl","bn","both","bottom","bp","br","brief","briefly","bs","bt","bu","but","bx","by","c","c1","c2","c3","ca","call","came","can","cannot","cant","can't","cause","causes","cc","cd","ce","certain","certainly","cf","cg","ch","changes","ci","cit","cj","cl","clearly","cm","c'mon","cn","co","com","come","comes","con","concerning","consequently","consider","considering","contain","containing","contains","corresponding","could","couldn","couldnt","couldn't","course","cp","cq","cr","cry","cs","c's","ct","cu","currently","cv","cx","cy","cz","d","d2","da","date","dc","dd","de","definitely","describe","described","despite","detail","df","di","did","didn","didn't","different","dj","dk","dl","do","does","doesn","doesn't","doing","don","done","don't","down","downwards","dp","dr","ds","dt","du","due","during","dx","dy","e","e2","e3","ea","each","ec","ed","edu","ee","ef","effect","eg","ei","eight","eighty","either","ej","el","eleven","else","elsewhere","em","empty","en","end","ending","enough","entirely","eo","ep","eq","er","es","especially","est","et","et-al","etc","eu","ev","even","ever","every","everybody","everyone","everything","everywhere","ex","exactly","example","except","ey","f","f2","fa","far","fc","few","ff","fi","fifteen","fifth","fify","fill","find","fire","first","five","fix","fj","fl","fn","fo","followed","following","follows","for","former","formerly","forth","forty","found","four","fr","from","front","ft","fu","full","further","furthermore","fy","g","ga","gave","ge","get","gets","getting","gi","give","given","gives","giving","gj","gl","go","goes","going","gone","got","gotten","gr","greetings","gs","gy","h","h2","h3","had","hadn","hadn't","happens","hardly","has","hasn","hasnt","hasn't","have","haven","haven't","having","he","hed","he'd","he'll","hello","help","hence","her","here","hereafter","hereby","herein","heres","here's","hereupon","hers","herself","hes","he's","hh","hi","hid","him","himself","his","hither","hj","ho","home","hopefully","how","howbeit","however","how's","hr","hs","http","hu","hundred","hy","i","i2","i3","i4","i6","i7","i8","ia","ib","ibid","ic","id","i'd","ie","if","ig","ignored","ih","ii","ij","il","i'll","im","i'm","immediate","immediately","importance","important","in","inasmuch","inc","indeed","index","indicate","indicated","indicates","information","inner","insofar","instead","interest","into","invention","inward","io","ip","iq","ir","is","isn","isn't","it","itd","it'd","it'll","its","it's","itself","iv","i've","ix","iy","iz","j","jj","jr","js","jt","ju","just","k","ke","keep","keeps","kept","kg","kj","km","know","known","knows","ko","l","l2","la","largely","last","lately","later","latter","latterly","lb","lc","le","least","les","less","lest","let","lets","let's","lf","like","liked","likely","line","little","lj","ll","ll","ln","lo","look","looking","looks","los","lr","ls","lt","ltd","m","m2","ma","made","mainly","make","makes","many","may","maybe","me","mean","means","meantime","meanwhile","merely","mg","might","mightn","mightn't","mill","million","mine","miss","ml","mn","mo","more","moreover","most","mostly","move","mr","mrs","ms","mt","mu","much","mug","must","mustn","mustn't","my","myself","model","n","n2","na","name","namely","nay","nc","nd","ne","near","nearly","necessarily","necessary","need","needn","needn't","needs","neither","never","nevertheless","new","next","ng","ni","nine","ninety","nj","nl","nn","no","nobody","non","none","nonetheless","noone","nor","normally","nos","not","noted","nothing","novel","now","nowhere","nr","ns","nt","ny","o","oa","ob","obtain","obtained","obviously","oc","od","of","off","often","og","oh","oi","oj","ok","okay","ol","old","om","omitted","on","once","one","ones","only","onto","oo","op","oq","or","ord","os","ot","other","others","otherwise","ou","ought","our","ours","ourselves","out","outside","over","overall","ow","owing","own","ox","oz","p","p1","p2","p3","page","pagecount","pages","par","part","particular","particularly","pas","past","pc","pd","pe","per","perhaps","pf","ph","pi","pj","pk","pl","placed","please","plus","pm","pn","po","poorly","possible","possibly","potentially","pp","pq","pr","predominantly","present","presumably","previously","primarily","probably","promptly","proud","provides","ps","pt","pu","put","py","q","qj","qu","que","quickly","quite","qv","r","r2","ra","ran","rather","rc","rd","re","readily","really","reasonably","recent","recently","ref","refs","regarding","regardless","regards","related","relatively","research","research-articl","respectively","resulted","resulting","results","rf","rh","ri","right","rj","rl","rm","rn","ro","rq","rr","rs","rt","ru","run","rv","ry","s","s2","sa","said","same","saw","say","saying","says","sc","sd","se","sec","second","secondly","section","see","seeing","seem","seemed","seeming","seems","seen","self","selves","sensible","sent","serious","seriously","seven","several","sf","shall","shan","shan't","she","shed","she'd","she'll","shes","she's","should","shouldn","shouldn't","should've","show","showed","shown","showns","shows","si","side","significant","significantly","similar","similarly","since","sincere","six","sixty","sj","sl","slightly","sm","sn","so","some","somebody","somehow","someone","somethan","something","sometime","sometimes","somewhat","somewhere","soon","sorry","sp","specifically","specified","specify","specifying","sq","sr","ss","st","still","stop","strongly","sub","substantially","successfully","such","sufficiently","suggest","sup","sure","sy","system","sz","t","t1","t2","t3","take","taken","taking","tb","tc","td","te","tell","ten","tends","tf","th","than","thank","thanks","thanx","that","that'll","thats","that's","that've","the","their","theirs","them","themselves","then","thence","there","thereafter","thereby","thered","therefore","therein","there'll","thereof","therere","theres","there's","thereto","thereupon","there've","these","they","theyd","they'd","they'll","theyre","they're","they've","thickv","thin","think","third","this","thorough","thoroughly","those","thou","though","thoughh","thousand","three","throug","through","throughout","thru","thus","ti","til","tip","tj","tl","tm","tn","to","together","too","took","top","toward","towards","tp","tq","tr","tried","tries","truly","try","trying","ts","t's","tt","tv","twelve","twenty","twice","two","tx","u","u201d","ue","ui","uj","uk","um","un","under","unfortunately","unless","unlike","unlikely","until","unto","uo","up","upon","ups","ur","us","use","used","useful","usefully","usefulness","uses","using","usually","ut","v","va","value","various","vd","ve","ve","very","via","viz","vj","vo","vol","vols","volumtype","vq","vs","vt","vu","w","wa","want","wants","was","wasn","wasnt","wasn't","way","we","wed","we'd","welcome","well","we'll","well-b","went","were","we're","weren","werent","weren't","we've","what","whatever","what'll","whats","what's","when","whence","whenever","when's","where","whereafter","whereas","whereby","wherein","wheres","where's","whereupon","wherever","whether","which","while","whim","whither","who","whod","whoever","whole","who'll","whom","whomever","whos","who's","whose","why","why's","wi","widely","will","willing","wish","with","within","without","wo","won","wonder","wont","won't","words","world","would","wouldn","wouldnt","wouldn't","www","x","x1","x2","x3","xf","xi","xj","xk","xl","xn","xo","xs","xt","xv","xx","y","y2","yes","yet","yj","yl","you","youd","you'd","you'll","your","youre","you're","yours","yourself","yourselves","you've","yr","ys","yt","z","zero","zi","zz","task"]);function eu(o,e){return o.filter(t=>!e.has(t))}function tu(o){let e={};for(let t of o)e[t]=(e[t]||0)+1;return e}function on(o){let e=o.normalize("NFD");return e=e.replace(/\b(a|an|the)\b/g," "),e=e.split(/\s+/).join(" "),e=e.replace(/[!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~]/g,""),e.toLowerCase()}function zd(o,e){return on(o)===on(e)?1:0}function qd(o,e){let t=on(o).split(" "),n=on(e).split(" "),r=tu(t),s=tu(n),i=0;for(let c in r){let u=r[c]??0,p=s[c]??0;i+=Math.min(u,p)}if(i===0)return 0;let a=i/t.length,l=i/n.length;return 2*a*l/(a+l)}function Hd(o,e,t,n=!1){let r=on(o).split(" "),s=on(e).split(" "),i=on(t).split(" "),a=new Set([...Zc,...r]);s=eu(s,a),i=eu(i,a);let l=0,c=l/s.length,u=l/i.length,p=2*c*u/(c+u);return n?u:p}var nu={emScore:zd,f1Score:qd,novelF1ScoreOptimized:Hd};var hs=class{ai;program;examples;constructor({ai:e,program:t,examples:n=[]}){if(n.length===0)throw new Error("No examples found");this.ai=e,this.program=t,this.examples=n}async run(e){let t=Date.now(),n=this.examples.length,r=0;for(let i=0;i<n;i++){let a=this.examples[i];if(!a)throw new Error("Invalid example");try{let l=await this.program.forward(this.ai,a,{maxRetries:1}),c=await e({prediction:l,example:a});r+=c}catch(l){console.warn(`Program evaluation failed for example ${i}: ${l instanceof Error?l.message:"Unknown error"}`)}}let s=n>0?r/n:0;this.ai.getOptions().debug&&console.log(`
781
+ `)}`),e,this.signature)}catch(L){let K=L,ee=K instanceof rt&&K.status>=500&&K.status<600,he=K instanceof Je,q=K instanceof dt,B=K instanceof gt;if((ee||he||q||B)&&Ce<oe){let ke=this.isDebug(e,r),Oe=this.getLogger(e,r),se=Math.min(6e4,1e3*Math.pow(2,Ce));ke&&Oe&&Oe({name:"Notification",id:"infrastructure-retry",value:`Infrastructure error (attempt ${Ce+1}/${oe+1}): ${K.message}. Retrying in ${se}ms...`}),s?.addEvent("infrastructure.retry",{attempt:Ce+1,maxRetries:oe,delay:se,errorType:K instanceof rt?"status_error":K instanceof Je?"network_error":K instanceof dt?"timeout_error":"stream_terminated",errorMessage:K.message}),await new Promise((de,J)=>{let X=!1,xe,we=()=>{j&&xe&&j.removeEventListener("abort",xe)},$e=setTimeout(()=>{X||(X=!0,we(),de())},se);if(j){if(xe=()=>{X||(X=!0,clearTimeout($e),we(),J(new _e("infrastructure-retry-backoff",j.reason?String(j.reason):"Aborted during retry backoff")))},j.aborted){xe();return}j.addEventListener("abort",xe,{once:!0})}});continue}throw L}}throw F&&Zo(F,l,l,this.getSignatureName(),N),ca(new Error(`Max steps reached: ${l}`),e,this.signature)}validateInputs(e){let t=this.signature.getInputFields();for(let n of t){if(n.isInternal)continue;let r=e[n.name];if(n.isOptional&&r===void 0)continue;let s=n.type;if(s&&(s.name==="url"&&zt(r,n),s.name,s.name,(s.name==="string"||s.name==="code")&&xt(r,n),s.name==="number"&&At(r,n),s.name==="object"&&s.fields&&typeof r=="object"&&r!==null&&this.validateObjectFields(r,s.fields,n.name),s.isArray&&Array.isArray(r)))for(let i=0;i<r.length;i++){let a=r[i];s.name==="string"||s.name==="code"?xt(a,n):s.name==="number"?At(a,n):s.fields&&typeof a=="object"&&a!==null&&this.validateObjectFields(a,s.fields,`${n.name}[${i}]`)}}}validateObjectFields(e,t,n){for(let[r,s]of Object.entries(t)){let i=e[r];if(s.isOptional&&i===void 0)continue;let a={name:`${n}.${r}`,type:{name:s.type,isArray:s.isArray,options:s.options?[...s.options]:void 0,fields:s.fields,minLength:s.minLength,maxLength:s.maxLength,minimum:s.minimum,maximum:s.maximum,pattern:s.pattern,format:s.format},description:s.description,isOptional:s.isOptional};if(s.type==="string"||s.type==="code"?xt(i,a):s.type==="number"?At(i,a):s.type==="object"&&s.fields&&typeof i=="object"&&i!==null&&this.validateObjectFields(i,s.fields,a.name),s.isArray&&Array.isArray(i))for(let u=0;u<i.length;u++){let c=i[u];s.type==="string"||s.type==="code"?xt(c,a):s.type==="number"?At(c,a):s.fields&&typeof c=="object"&&c!==null&&this.validateObjectFields(c,s.fields,`${a.name}[${u}]`)}}}async*_forward1(e,t,n){(!Array.isArray(t)||!t.every(a=>"role"in a))&&this.validateInputs(t);let r=new AbortController;this.activeAbortControllers.add(r),this._stopRequested&&r.abort("Stopped by user (pre-forward)");let s=vt(r.signal,n?.abortSignal??ge.abortSignal),i=s?{...n,abortSignal:s}:n;try{let a=performance.now(),u=this.createStates(n.sampleCount??1),c=performance.now()-a,l=this.getMetricsInstruments(),p=this.getMergedCustomLabels(e,n);l&&es(l,"state_creation",c,this.getSignatureName(),p);let d=n?.tracer??this.options?.tracer??e.getOptions().tracer,m=this.functions;if(n?.functions&&(m=rn(n.functions,this.functions)),!d){yield*this._forward2(e,t,u,{...i,functions:m});return}let g=m?.map(I=>I.name).join(","),f={signature:JSON.stringify(this.signature.toJSON(),null,2),...this.examples?{examples:JSON.stringify(this.examples,null,2)}:{},...g?{provided_functions:g}:{},...n?.model?{model:n.model}:{},...n?.thinkingTokenBudget?{thinking_token_budget:n.thinkingTokenBudget}:{},...n?.showThoughts?{show_thoughts:n.showThoughts}:{},...n?.maxSteps?{max_steps:n.maxSteps}:{},...n?.maxRetries?{max_retries:n.maxRetries}:{}},x=this.traceLabel&&n.traceLabel?`${this.traceLabel} > ${n.traceLabel}`:n.traceLabel??this.traceLabel,A=x?`AxGen > ${x}`:"AxGen",h=d.startSpan(A,{kind:Jn.SpanKind.SERVER,attributes:f}),y=Jn.context.active(),C=Jn.trace.setSpan(y,h);try{if(this.excludeContentFromTrace||h.addEvent("input",{content:JSON.stringify(t,null,2)}),yield*this._forward2(e,t,u,{...i,functions:m},h,C),!this.excludeContentFromTrace){let I=u.map(O=>O.values),v=I.length===1?I[0]:I;h.addEvent("output",{content:JSON.stringify(v,null,2)})}}finally{h.end()}}finally{this.activeAbortControllers.delete(r),this._stopRequested=!1}}async forward(e,t,n){let r=n?.cachingFunction??this.options?.cachingFunction??ge.cachingFunction,s=(()=>{if(!r)return;let d=this.signature.getInputFields().map(m=>m.name);return this.computeCacheKey(t,d)})();if(r&&s){let d=await r(s);if(d!==void 0)return d}let i=performance.now(),a=this.getSignatureName(),u=n?.stream??!1,c=!1,l=0,p=!1;try{let d=this.getMetricsInstruments(),m=this.getMergedCustomLabels(e,n);d&&Ic(d,this.signature.getInputFields().length,this.signature.getOutputFields().length,this.examples?.length??0,this.demos?.length??0,a,m);let g=this._forward1(e,t,n??{}),f=[],x=0,A=0;for await(let R of g)R.version!==x&&(f=[]),x=R.version,f=qi(f,R),A++;l=x;let h=performance.now();p=!!n?.resultPicker;let y=await ms(f,{resultPicker:n?.resultPicker},n?.mem,n?.sessionId),C=performance.now()-h,v=f[y]?.delta??{},O=Array.isArray(t)?{}:t??{};if(this.trace={...O,...v},p&&this.isDebug(e,n)){let R=this.getLogger(e,n);yu(f.length,y,C,R)}if(c=!0,d&&(Cc(d,f.length,p,p?C:void 0,a,m),bc(d,u,A,void 0,a,m)),r&&s)try{await r(s,v)}catch{}return v}catch(d){throw c=!1,d}finally{let d=performance.now()-i,m=this.getMetricsInstruments(),g=this.getMergedCustomLabels(e,n);m&&(hc(m,d,c,a,e.getName(),n?.model?String(n.model):void 0,g),l>0&&Gi(m,l,c,n?.maxRetries??this.options?.maxRetries??3,a,g))}}async*streamingForward(e,t,n){let r=n?.cachingFunction??this.options?.cachingFunction??ge.cachingFunction,s=(()=>{if(!r)return;let p=this.signature.getInputFields().map(d=>d.name);return this.computeCacheKey(t,p)})();if(r&&s){let p;try{p=await r(s)}catch{}if(p!==void 0){yield{version:0,index:0,delta:p};return}}if(!n?.resultPicker){yield*this._forward1(e,t,{...n,stream:!0});return}let i=this._forward1(e,t,{...n,stream:!0}),a=[],u=0;for await(let p of i)p.version!==u&&(a=[]),u=p.version,a=qi(a,p);let c=await ms(a,{resultPicker:n?.resultPicker},n?.mem,n?.sessionId),l=a[c];if(l){if(r&&s)try{await r(s,l.delta)}catch{}yield{version:u,index:c,delta:l.delta}}}setExamples(e,t){super.setExamples(e,t)}isDebug(e,t){return t?.debug??this.options?.debug??ge.debug??e.getOptions().debug??!1}getLogger(e,t){return t?.logger??this.options?.logger??ge.logger??e.getLogger()}computeCacheKey(e,t){let n=pt("sha256");n.update(this.signature.hash()??"");let r=s=>{let i=typeof s;if(n.update(`|${i}|`),s==null){n.update("null");return}if(i==="string"||i==="number"||i==="boolean"){n.update(String(s));return}if(Array.isArray(s)){n.update("[");for(let a of s)r(a);n.update("]");return}if(typeof s=="object"&&s!==null&&"mimeType"in s&&"data"in s){let a=s;n.update(a.mimeType??"");let u=pt("sha256").update(a.data??"").digest("hex");n.update(u);return}if(typeof s=="object"){let a=s,u=Object.keys(a).sort();for(let c of u)n.update(`{${c}}`),r(a[c]);return}n.update(String(s))};if(Array.isArray(e))for(let s of e){n.update(`role:${s.role}`);let i=t.map(a=>s.values?.[a]);for(let a of i)r(a)}else{let s=t.map(i=>e?.[i]);for(let i of s)r(i)}return n.digest("hex")}},Br=class extends Error{details;constructor(e,t,n){super(e),this.name="AxGenerateError",this.details=t,n?.cause&&(this.cause=n.cause)}toJSON(){let e=this.cause;return{name:this.name,message:this.message,details:this.details,cause:e?{name:e.name,message:e.message,stack:e.stack}:void 0,stack:this.stack}}};function ca(o,e,t){let n=o instanceof Error?o:new Error(String(o));if(n instanceof _e)return n;let r=(n.message||"").toLowerCase();if(r.includes("at least")||r.includes("at most")||r.includes("must match pattern")||r.includes("invalid url")||r.includes("required")||r.includes("missing")||r.includes("valid email")||r.includes("number must be")||n.name==="ValidationError"||n.name==="AssertionError"||n.name==="AxAssertionError"||n.stack?.includes("asserts.ts"))return n;let i=e.getLastUsedChatModel(),a=e.getLastUsedModelConfig(),u={model:i,maxTokens:a?.maxTokens,streaming:a?.stream??!1,signature:{input:t.getInputFields(),output:t.getOutputFields(),description:t.getDescription()}};return new Br(`Generate failed: ${n.message}`,u,{cause:n})}var Rm=o=>o.replace(/^\W+|\W+$/g,""),vm=(o,e)=>{let t=o.search(e);if(t===-1)return[o];let n=o.match(e);if(!n)throw new Error("Match failed unexpectedly.");let r=o.substring(0,t),s=o.substring(t+n[0].length);return[r,s]},Sm=o=>{let e=new Set,t=[];for(let n of o)e.has(n)||(e.add(n),t.push(n));return t},km=o=>{let e=o.match(/^(\d+)[.,\s]+(.*)$/);if(!e||e.length<3)throw new Error('line must start with a number, a dot and then text. e.g. "1. hello"');let t=Number.parseInt(e[1],10),n=e[2].trim();return{id:t,text:n}},Om=o=>{let e=o.match(/^(\d+)[.,\s]+(.*)$/);return e&&e[2]!==void 0?e[2].trim():o},Em=(o,e)=>{let t=[];for(let n=0;n<o.length;n+=e)t.push(o.slice(n,n+e));return t},fs={trimNonAlphaNum:Rm,splitIntoTwo:vm,dedup:Sm,extractIdAndText:km,extractIndexPrefixedText:Om,batchArray:Em};var hs=class extends Pe{constructor(e){super(`"You are a re-ranker assistant tasked with evaluating a set of content items in relation to a specific question. Your role involves critically analyzing each content item to determine its relevance to the question and re-ranking them accordingly. This process includes assigning a relevance score from 0 to 10 to each content item based on how well it answers the question, its coverage of the topic, and the reliability of its information. This re-ranked list should start with the content item that is most relevant to the question and end with the least relevant. Output only the list."
782
+ query: string, items: string[] -> rankedItems: string[] "list of id, 5-words Rationale, relevance score"`,e)}forward=async(e,t,n)=>{let{rankedItems:r}=await super.forward(e,t,n),s=r.map(a=>{let{id:u}=fs.extractIdAndText(a);return u});return{rankedItems:t.items.map((a,u)=>{let c=s[u];return c!==void 0?t.items[c]:void 0}).filter(a=>a!==void 0)}}};var xs=class{tikaUrl;fetch;constructor(e){let t=e??{url:"http://localhost:9998/"};this.tikaUrl=new URL("/tika",t.url),this.fetch=t.fetch}async _convert(e,t){if(!e)throw new Error("Failed to read file data");let n=t?.format==="html"?"text/html":"text/plain";try{let r={body:e,headers:{Accept:n},method:"PUT"};typeof window>"u"&&typeof process<"u"&&(r.duplex="half");let s=await(this.fetch??fetch)(this.tikaUrl,r);if(!s.ok)throw new Error(`Failed to upload file: ${s.statusText}`);return await s.text()}catch(r){throw new Error(`Error converting file: ${r}`)}}async convert(e,t){let n=[],r=t?.batchSize??10;for(let s=0;s<e.length;s+=r){let a=e.slice(s,s+r).map(c=>this._convert(c,{format:t?.format})),u=await Promise.all(a);n.push(...u)}return n}};var rC=new ot,As=class{name;context;constructor(e,t){this.name=e,this.context=t}getName(){return this.name}getContext(){return this.context}},ys=class{ai;db;debug;constructor(e){this.db=new jt,this.ai=e}getState(){return this.db.getDB()}setState(e){this.db.setDB(e)}setClasses=async(e,t)=>{for(let n of e){let r=await this.ai.embed({texts:n.getContext()},{abortSignal:t?.abortSignal});await this.db.upsert({id:n.getName(),table:"classes",values:r.embeddings[0]})}};async forward(e,t){let{embeddings:n}=await this.ai.embed({texts:[e]},{abortSignal:t?.abortSignal}),s=(await this.db.query({table:"classes",values:n[0]})).matches;if(typeof t?.cutoff=="number"){let{cutoff:a}=t;s=s.filter(u=>u.score<=a)}let i=s.at(0);return i?i.id:""}setOptions(e){typeof e.debug=="boolean"&&(this.debug=e.debug)}};var pl=new Set(["0o","0s","3a","3b","3d","6b","6o","a","a1","a2","a3","a4","ab","able","about","above","abst","ac","accordance","according","accordingly","across","act","actually","ad","added","adj","ae","af","affected","affecting","affects","after","afterwards","ag","again","against","ah","ain","ain't","aj","al","all","allow","allows","almost","alone","along","already","also","although","always","am","among","amongst","amoungst","amount","an","and","announce","another","any","anybody","anyhow","anymore","anyone","anything","anyway","anyways","anywhere","ao","ap","apart","apparently","appear","appreciate","appropriate","approximately","ar","are","aren","arent","aren't","arise","around","as","a's","aside","ask","asking","associated","at","au","auth","av","available","aw","away","awfully","ax","ay","az","b","b1","b2","b3","ba","back","bc","bd","be","became","because","become","becomes","becoming","been","before","beforehand","begin","beginning","beginnings","begins","behind","being","believe","below","beside","besides","best","better","between","beyond","bi","bill","biol","bj","bk","bl","bn","both","bottom","bp","br","brief","briefly","bs","bt","bu","but","bx","by","c","c1","c2","c3","ca","call","came","can","cannot","cant","can't","cause","causes","cc","cd","ce","certain","certainly","cf","cg","ch","changes","ci","cit","cj","cl","clearly","cm","c'mon","cn","co","com","come","comes","con","concerning","consequently","consider","considering","contain","containing","contains","corresponding","could","couldn","couldnt","couldn't","course","cp","cq","cr","cry","cs","c's","ct","cu","currently","cv","cx","cy","cz","d","d2","da","date","dc","dd","de","definitely","describe","described","despite","detail","df","di","did","didn","didn't","different","dj","dk","dl","do","does","doesn","doesn't","doing","don","done","don't","down","downwards","dp","dr","ds","dt","du","due","during","dx","dy","e","e2","e3","ea","each","ec","ed","edu","ee","ef","effect","eg","ei","eight","eighty","either","ej","el","eleven","else","elsewhere","em","empty","en","end","ending","enough","entirely","eo","ep","eq","er","es","especially","est","et","et-al","etc","eu","ev","even","ever","every","everybody","everyone","everything","everywhere","ex","exactly","example","except","ey","f","f2","fa","far","fc","few","ff","fi","fifteen","fifth","fify","fill","find","fire","first","five","fix","fj","fl","fn","fo","followed","following","follows","for","former","formerly","forth","forty","found","four","fr","from","front","ft","fu","full","further","furthermore","fy","g","ga","gave","ge","get","gets","getting","gi","give","given","gives","giving","gj","gl","go","goes","going","gone","got","gotten","gr","greetings","gs","gy","h","h2","h3","had","hadn","hadn't","happens","hardly","has","hasn","hasnt","hasn't","have","haven","haven't","having","he","hed","he'd","he'll","hello","help","hence","her","here","hereafter","hereby","herein","heres","here's","hereupon","hers","herself","hes","he's","hh","hi","hid","him","himself","his","hither","hj","ho","home","hopefully","how","howbeit","however","how's","hr","hs","http","hu","hundred","hy","i","i2","i3","i4","i6","i7","i8","ia","ib","ibid","ic","id","i'd","ie","if","ig","ignored","ih","ii","ij","il","i'll","im","i'm","immediate","immediately","importance","important","in","inasmuch","inc","indeed","index","indicate","indicated","indicates","information","inner","insofar","instead","interest","into","invention","inward","io","ip","iq","ir","is","isn","isn't","it","itd","it'd","it'll","its","it's","itself","iv","i've","ix","iy","iz","j","jj","jr","js","jt","ju","just","k","ke","keep","keeps","kept","kg","kj","km","know","known","knows","ko","l","l2","la","largely","last","lately","later","latter","latterly","lb","lc","le","least","les","less","lest","let","lets","let's","lf","like","liked","likely","line","little","lj","ll","ll","ln","lo","look","looking","looks","los","lr","ls","lt","ltd","m","m2","ma","made","mainly","make","makes","many","may","maybe","me","mean","means","meantime","meanwhile","merely","mg","might","mightn","mightn't","mill","million","mine","miss","ml","mn","mo","more","moreover","most","mostly","move","mr","mrs","ms","mt","mu","much","mug","must","mustn","mustn't","my","myself","model","n","n2","na","name","namely","nay","nc","nd","ne","near","nearly","necessarily","necessary","need","needn","needn't","needs","neither","never","nevertheless","new","next","ng","ni","nine","ninety","nj","nl","nn","no","nobody","non","none","nonetheless","noone","nor","normally","nos","not","noted","nothing","novel","now","nowhere","nr","ns","nt","ny","o","oa","ob","obtain","obtained","obviously","oc","od","of","off","often","og","oh","oi","oj","ok","okay","ol","old","om","omitted","on","once","one","ones","only","onto","oo","op","oq","or","ord","os","ot","other","others","otherwise","ou","ought","our","ours","ourselves","out","outside","over","overall","ow","owing","own","ox","oz","p","p1","p2","p3","page","pagecount","pages","par","part","particular","particularly","pas","past","pc","pd","pe","per","perhaps","pf","ph","pi","pj","pk","pl","placed","please","plus","pm","pn","po","poorly","possible","possibly","potentially","pp","pq","pr","predominantly","present","presumably","previously","primarily","probably","promptly","proud","provides","ps","pt","pu","put","py","q","qj","qu","que","quickly","quite","qv","r","r2","ra","ran","rather","rc","rd","re","readily","really","reasonably","recent","recently","ref","refs","regarding","regardless","regards","related","relatively","research","research-articl","respectively","resulted","resulting","results","rf","rh","ri","right","rj","rl","rm","rn","ro","rq","rr","rs","rt","ru","run","rv","ry","s","s2","sa","said","same","saw","say","saying","says","sc","sd","se","sec","second","secondly","section","see","seeing","seem","seemed","seeming","seems","seen","self","selves","sensible","sent","serious","seriously","seven","several","sf","shall","shan","shan't","she","shed","she'd","she'll","shes","she's","should","shouldn","shouldn't","should've","show","showed","shown","showns","shows","si","side","significant","significantly","similar","similarly","since","sincere","six","sixty","sj","sl","slightly","sm","sn","so","some","somebody","somehow","someone","somethan","something","sometime","sometimes","somewhat","somewhere","soon","sorry","sp","specifically","specified","specify","specifying","sq","sr","ss","st","still","stop","strongly","sub","substantially","successfully","such","sufficiently","suggest","sup","sure","sy","system","sz","t","t1","t2","t3","take","taken","taking","tb","tc","td","te","tell","ten","tends","tf","th","than","thank","thanks","thanx","that","that'll","thats","that's","that've","the","their","theirs","them","themselves","then","thence","there","thereafter","thereby","thered","therefore","therein","there'll","thereof","therere","theres","there's","thereto","thereupon","there've","these","they","theyd","they'd","they'll","theyre","they're","they've","thickv","thin","think","third","this","thorough","thoroughly","those","thou","though","thoughh","thousand","three","throug","through","throughout","thru","thus","ti","til","tip","tj","tl","tm","tn","to","together","too","took","top","toward","towards","tp","tq","tr","tried","tries","truly","try","trying","ts","t's","tt","tv","twelve","twenty","twice","two","tx","u","u201d","ue","ui","uj","uk","um","un","under","unfortunately","unless","unlike","unlikely","until","unto","uo","up","upon","ups","ur","us","use","used","useful","usefully","usefulness","uses","using","usually","ut","v","va","value","various","vd","ve","ve","very","via","viz","vj","vo","vol","vols","volumtype","vq","vs","vt","vu","w","wa","want","wants","was","wasn","wasnt","wasn't","way","we","wed","we'd","welcome","well","we'll","well-b","went","were","we're","weren","werent","weren't","we've","what","whatever","what'll","whats","what's","when","whence","whenever","when's","where","whereafter","whereas","whereby","wherein","wheres","where's","whereupon","wherever","whether","which","while","whim","whither","who","whod","whoever","whole","who'll","whom","whomever","whos","who's","whose","why","why's","wi","widely","will","willing","wish","with","within","without","wo","won","wonder","wont","won't","words","world","would","wouldn","wouldnt","wouldn't","www","x","x1","x2","x3","xf","xi","xj","xk","xl","xn","xo","xs","xt","xv","xx","y","y2","yes","yet","yj","yl","you","youd","you'd","you'll","your","youre","you're","yours","yourself","yourselves","you've","yr","ys","yt","z","zero","zi","zz","task"]);function dl(o,e){return o.filter(t=>!e.has(t))}function ml(o){let e={};for(let t of o)e[t]=(e[t]||0)+1;return e}function un(o){let e=o.normalize("NFD");return e=e.replace(/\b(a|an|the)\b/g," "),e=e.split(/\s+/).join(" "),e=e.replace(/[!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~]/g,""),e.toLowerCase()}function Mm(o,e){return un(o)===un(e)?1:0}function Pm(o,e){let t=un(o).split(" "),n=un(e).split(" "),r=ml(t),s=ml(n),i=0;for(let c in r){let l=r[c]??0,p=s[c]??0;i+=Math.min(l,p)}if(i===0)return 0;let a=i/t.length,u=i/n.length;return 2*a*u/(a+u)}function Fm(o,e,t,n=!1){let r=un(o).split(" "),s=un(e).split(" "),i=un(t).split(" "),a=new Set([...pl,...r]);s=dl(s,a),i=dl(i,a);let u=0,c=u/s.length,l=u/i.length,p=2*c*l/(c+l);return n?l:p}var gl={emScore:Mm,f1Score:Pm,novelF1ScoreOptimized:Fm};var bs=class{ai;program;examples;constructor({ai:e,program:t,examples:n=[]}){if(n.length===0)throw new Error("No examples found");this.ai=e,this.program=t,this.examples=n}async run(e){let t=Date.now(),n=this.examples.length,r=0;for(let i=0;i<n;i++){let a=this.examples[i];if(!a)throw new Error("Invalid example");try{let u=await this.program.forward(this.ai,a,{maxRetries:1}),c=await e({prediction:u,example:a});r+=c}catch(u){console.warn(`Program evaluation failed for example ${i}: ${u instanceof Error?u.message:"Unknown error"}`)}}let s=n>0?r/n:0;this.ai.getOptions().debug&&console.log(`
783
783
  Performance: `,r,"/",n,"Average Score: ",s,`
784
- `)}};function ru(){let o=Date.now().toString(36),e=Math.random().toString(36).substring(2,8);return`trace-${o}-${e}`}var Wn=class o{gen;options;constructor(e,t){this.gen=e,this.options={name:t.name,storage:t.storage,logInputs:t.logInputs??!0,logOutputs:t.logOutputs??!0,metadata:t.metadata,onTrace:t.onTrace,throwOnError:t.throwOnError??!1}}async*streamingForward(e,t,n){let r=ru(),s=new Date,i,a;try{let l=this.gen.streamingForward(e,t,n);for await(let c of l)c.partial?i=c.partial:c.delta,yield c}catch(l){throw a=l instanceof Error?l.message:String(l),l}finally{let l=new Date,c=l.getTime()-s.getTime(),u={type:"trace",id:r,name:this.options.name,input:this.options.logInputs?t:{},output:this.options.logOutputs&&i?i:{},startTime:s,endTime:l,durationMs:c,model:n?.model??void 0,metadata:this.options.metadata,error:a};this.saveTrace(u)}}async forward(e,t,n){let r=ru(),s=new Date,i,a;try{return i=await this.gen.forward(e,t,n),i}catch(l){throw a=l instanceof Error?l.message:String(l),l}finally{let l=new Date,c=l.getTime()-s.getTime(),u={type:"trace",id:r,name:this.options.name,input:this.options.logInputs?t:{},output:this.options.logOutputs&&i?i:{},startTime:s,endTime:l,durationMs:c,model:n?.model??void 0,metadata:this.options.metadata,error:a};this.saveTrace(u)}}async saveTrace(e){try{await this.options.storage.save(this.options.name,e),this.options.onTrace&&this.options.onTrace(e)}catch(t){if(this.options.throwOnError)throw t;console.warn("AxTraceLogger: Failed to save trace:",t)}}getGen(){return this.gen}getName(){return this.options.name}getStorage(){return this.options.storage}setMetadata(e){this.options.metadata=e}clone(e){return new o(e??this.gen.clone(),{name:this.options.name,storage:this.options.storage,logInputs:this.options.logInputs,logOutputs:this.options.logOutputs,metadata:this.options.metadata,onTrace:this.options.onTrace,throwOnError:this.options.throwOnError})}};function ou(o){return Ne.create(o)}function st(o,e){let t=typeof o=="string"?Ne.create(o):o;return new ke(t,e)}var su=o=>{console.log(o)},oa=(o=su)=>{let e=new ot,t=e.gray("\u2500".repeat(50)),n=e.gray("\u2501".repeat(50));return r=>{let s="";switch(r.name){case"OptimizationStart":s=`
784
+ `)}};function fl(){let o=Date.now().toString(36),e=Math.random().toString(36).substring(2,8);return`trace-${o}-${e}`}var Qn=class o{gen;options;constructor(e,t){this.gen=e,this.options={name:t.name,storage:t.storage,logInputs:t.logInputs??!0,logOutputs:t.logOutputs??!0,metadata:t.metadata,onTrace:t.onTrace,throwOnError:t.throwOnError??!1}}async*streamingForward(e,t,n){let r=fl(),s=new Date,i,a;try{let u=this.gen.streamingForward(e,t,n);for await(let c of u)c.partial?i=c.partial:c.delta,yield c}catch(u){throw a=u instanceof Error?u.message:String(u),u}finally{let u=new Date,c=u.getTime()-s.getTime(),l={type:"trace",id:r,name:this.options.name,input:this.options.logInputs?t:{},output:this.options.logOutputs&&i?i:{},startTime:s,endTime:u,durationMs:c,model:n?.model??void 0,metadata:this.options.metadata,error:a};this.saveTrace(l)}}async forward(e,t,n){let r=fl(),s=new Date,i,a;try{return i=await this.gen.forward(e,t,n),i}catch(u){throw a=u instanceof Error?u.message:String(u),u}finally{let u=new Date,c=u.getTime()-s.getTime(),l={type:"trace",id:r,name:this.options.name,input:this.options.logInputs?t:{},output:this.options.logOutputs&&i?i:{},startTime:s,endTime:u,durationMs:c,model:n?.model??void 0,metadata:this.options.metadata,error:a};this.saveTrace(l)}}async saveTrace(e){try{await this.options.storage.save(this.options.name,e),this.options.onTrace&&this.options.onTrace(e)}catch(t){if(this.options.throwOnError)throw t;console.warn("AxTraceLogger: Failed to save trace:",t)}}getGen(){return this.gen}getName(){return this.options.name}getStorage(){return this.options.storage}setMetadata(e){this.options.metadata=e}clone(e){return new o(e??this.gen.clone(),{name:this.options.name,storage:this.options.storage,logInputs:this.options.logInputs,logOutputs:this.options.logOutputs,metadata:this.options.metadata,onTrace:this.options.onTrace,throwOnError:this.options.throwOnError})}};function hl(o){return Me.create(o)}function st(o,e){let t=typeof o=="string"?Me.create(o):o;return new Pe(t,e)}var xl=o=>{console.log(o)},la=(o=xl)=>{let e=new ot,t=e.gray("\u2500".repeat(50)),n=e.gray("\u2501".repeat(50));return r=>{let s="";switch(r.name){case"OptimizationStart":s=`
785
785
  ${e.blueBright("\u25CF ")}${e.whiteBright("Optimization Started")}
786
786
  ${t}
787
787
  ${e.white("Optimizer:")} ${e.cyan(r.value.optimizerType)}
788
788
  ${e.white("Examples:")} ${e.green(r.value.exampleCount.toString())} training, ${e.green(r.value.validationCount.toString())} validation
789
789
  ${e.white("Config:")} ${e.white(JSON.stringify(r.value.config).slice(0,80))}${JSON.stringify(r.value.config).length>80?"...":""}
790
790
  ${n}
791
- `;break;case"RoundProgress":{let i=r.value.configuration||{},a=[];i.temperature!==void 0&&typeof i.temperature=="number"&&a.push(`T=${i.temperature.toFixed(2)}`),i.bootstrappedDemos!==void 0&&a.push(`demos=${i.bootstrappedDemos}`),Object.entries(i).forEach(([p,d])=>{p!=="temperature"&&p!=="bootstrappedDemos"&&p!=="trialNumber"&&typeof d=="number"&&a.push(`${p}=${d.toFixed(2)}`)});let l=r.value.currentScore-r.value.bestScore,c=l>0?e.greenBright(` \u2191${l.toFixed(3)}`):l<0?e.red(` \u2193${Math.abs(l).toFixed(3)}`):"",u=typeof r.value.totalRounds=="number"&&r.value.totalRounds>0?r.value.totalRounds:typeof i.totalRounds=="number"&&i.totalRounds>0?i.totalRounds:0;s=`${e.yellow("\u25CF ")}${e.whiteBright(`Round ${r.value.round}/${u}`)}`+(i.trialNumber!==void 0?e.gray(` [Trial #${i.trialNumber}]`):"")+`
791
+ `;break;case"RoundProgress":{let i=r.value.configuration||{},a=[];i.temperature!==void 0&&typeof i.temperature=="number"&&a.push(`T=${i.temperature.toFixed(2)}`),i.bootstrappedDemos!==void 0&&a.push(`demos=${i.bootstrappedDemos}`),Object.entries(i).forEach(([p,d])=>{p!=="temperature"&&p!=="bootstrappedDemos"&&p!=="trialNumber"&&typeof d=="number"&&a.push(`${p}=${d.toFixed(2)}`)});let u=r.value.currentScore-r.value.bestScore,c=u>0?e.greenBright(` \u2191${u.toFixed(3)}`):u<0?e.red(` \u2193${Math.abs(u).toFixed(3)}`):"",l=typeof r.value.totalRounds=="number"&&r.value.totalRounds>0?r.value.totalRounds:typeof i.totalRounds=="number"&&i.totalRounds>0?i.totalRounds:0;s=`${e.yellow("\u25CF ")}${e.whiteBright(`Round ${r.value.round}/${l}`)}`+(i.trialNumber!==void 0?e.gray(` [Trial #${i.trialNumber}]`):"")+`
792
792
  ${e.white("Score:")} ${e.green(r.value.currentScore.toFixed(3))} ${e.white("(best:")} ${e.greenBright(r.value.bestScore.toFixed(3))}${e.white(")")}${c}
793
793
  `+(a.length>0?` ${e.white("Config:")} ${e.cyan(a.join(", "))}
794
794
  `:"")}break;case"EarlyStopping":s=`
@@ -806,7 +806,7 @@ ${e.yellowBright("\u26A1 Performance:")}
806
806
  ${e.white(r.value.performanceAssessment)}
807
807
  `),r.value.recommendations&&r.value.recommendations.length>0&&(i+=`
808
808
  ${e.greenBright("\u{1F4A1} Recommendations:")}
809
- `,r.value.recommendations.forEach((a,l)=>{i+=` ${e.white(`${l+1}.`)} ${e.white(a)}
809
+ `,r.value.recommendations.forEach((a,u)=>{i+=` ${e.white(`${u+1}.`)} ${e.white(a)}
810
810
  `})),s=`
811
811
  ${e.green("\u25CF ")}${e.whiteBright("Optimization Complete")}
812
812
  ${t}
@@ -824,7 +824,7 @@ ${t}
824
824
  ${e.white("Config:")} ${e.cyan(JSON.stringify(r.value.config).slice(0,80))}${JSON.stringify(r.value.config).length>80?"...":""}
825
825
  `;break;default:s=`${e.red("\u25CF ")}${e.whiteBright("Unknown Event")}
826
826
  ${e.white(JSON.stringify(r).slice(0,100))}${JSON.stringify(r).length>100?"...":""}
827
- `}o(s)}},iu=(o=su)=>{let e="\u2500".repeat(60);return t=>{let n="";switch(t.name){case"OptimizationStart":n=`[ OPTIMIZATION START: ${t.value.optimizerType} ]
827
+ `}o(s)}},Al=(o=xl)=>{let e="\u2500".repeat(60);return t=>{let n="";switch(t.name){case"OptimizationStart":n=`[ OPTIMIZATION START: ${t.value.optimizerType} ]
828
828
  ${e}
829
829
  Config: ${JSON.stringify(t.value.config,null,2)}
830
830
  Examples: ${t.value.exampleCount}, Validation: ${t.value.validationCount}
@@ -850,7 +850,7 @@ Score: ${t.value.score.toFixed(3)}
850
850
  Config: ${JSON.stringify(t.value.config)}
851
851
  ${e}`;break;default:n=`[ UNKNOWN OPTIMIZER EVENT ]
852
852
  ${JSON.stringify(t)}
853
- ${e}`}o(n)}},jr=oa();var sa={enabled:!0,enabledCategories:["optimization","convergence","resource_usage","teacher_student","checkpointing","pareto"],maxLabelLength:100,samplingRate:1},xs,Kd=o=>{if(xs)return xs;if(o)return xs=Wd(o),xs};var As=sa,au=o=>{As={...As,...o}},lu=()=>({...As}),Wd=o=>({optimizationLatencyHistogram:o.createHistogram("ax_optimizer_optimization_duration_ms",{description:"End-to-end duration of optimization runs",unit:"ms"}),optimizationRequestsCounter:o.createCounter("ax_optimizer_optimization_requests_total",{description:"Total number of optimization requests"}),optimizationErrorsCounter:o.createCounter("ax_optimizer_optimization_errors_total",{description:"Total number of failed optimizations"}),convergenceRoundsHistogram:o.createHistogram("ax_optimizer_convergence_rounds",{description:"Number of rounds until convergence"}),convergenceScoreGauge:o.createGauge("ax_optimizer_convergence_score",{description:"Current best score during optimization"}),convergenceImprovementGauge:o.createGauge("ax_optimizer_convergence_improvement",{description:"Improvement in score from baseline"}),stagnationRoundsGauge:o.createGauge("ax_optimizer_stagnation_rounds",{description:"Number of rounds without improvement"}),earlyStoppingCounter:o.createCounter("ax_optimizer_early_stopping_total",{description:"Total number of early stopping events"}),tokenUsageCounter:o.createCounter("ax_optimizer_token_usage_total",{description:"Total tokens used during optimization"}),costUsageCounter:o.createCounter("ax_optimizer_cost_usage_total",{description:"Total cost incurred during optimization",unit:"$"}),memoryUsageGauge:o.createGauge("ax_optimizer_memory_usage_bytes",{description:"Peak memory usage during optimization",unit:"By"}),optimizationDurationHistogram:o.createHistogram("ax_optimizer_duration_ms",{description:"Duration of optimization runs",unit:"ms"}),teacherStudentUsageCounter:o.createCounter("ax_optimizer_teacher_student_usage_total",{description:"Total number of teacher-student interactions"}),teacherStudentLatencyHistogram:o.createHistogram("ax_optimizer_teacher_student_latency_ms",{description:"Latency of teacher-student interactions",unit:"ms"}),teacherStudentScoreImprovementGauge:o.createGauge("ax_optimizer_teacher_student_score_improvement",{description:"Score improvement from teacher-student interactions"}),checkpointSaveCounter:o.createCounter("ax_optimizer_checkpoint_save_total",{description:"Total number of checkpoint saves"}),checkpointLoadCounter:o.createCounter("ax_optimizer_checkpoint_load_total",{description:"Total number of checkpoint loads"}),checkpointSaveLatencyHistogram:o.createHistogram("ax_optimizer_checkpoint_save_latency_ms",{description:"Latency of checkpoint save operations",unit:"ms"}),checkpointLoadLatencyHistogram:o.createHistogram("ax_optimizer_checkpoint_load_latency_ms",{description:"Latency of checkpoint load operations",unit:"ms"}),paretoOptimizationsCounter:o.createCounter("ax_optimizer_pareto_optimizations_total",{description:"Total number of Pareto optimizations"}),paretoFrontSizeHistogram:o.createHistogram("ax_optimizer_pareto_front_size",{description:"Size of Pareto frontier"}),paretoHypervolumeGauge:o.createGauge("ax_optimizer_pareto_hypervolume",{description:"Hypervolume of Pareto frontier"}),paretoSolutionsGeneratedHistogram:o.createHistogram("ax_optimizer_pareto_solutions_generated",{description:"Number of solutions generated for Pareto optimization"}),programInputFieldsGauge:o.createGauge("ax_optimizer_program_input_fields",{description:"Number of input fields in optimized program"}),programOutputFieldsGauge:o.createGauge("ax_optimizer_program_output_fields",{description:"Number of output fields in optimized program"}),examplesCountGauge:o.createGauge("ax_optimizer_examples_count",{description:"Number of training examples used"}),validationSetSizeGauge:o.createGauge("ax_optimizer_validation_set_size",{description:"Size of validation set used"}),evaluationLatencyHistogram:o.createHistogram("ax_optimizer_evaluation_latency_ms",{description:"Latency of program evaluations",unit:"ms"}),demoGenerationLatencyHistogram:o.createHistogram("ax_optimizer_demo_generation_latency_ms",{description:"Latency of demo generation",unit:"ms"}),metricComputationLatencyHistogram:o.createHistogram("ax_optimizer_metric_computation_latency_ms",{description:"Latency of metric computation",unit:"ms"}),optimizerTypeGauge:o.createGauge("ax_optimizer_type",{description:"Type of optimizer being used"}),targetScoreGauge:o.createGauge("ax_optimizer_target_score",{description:"Target score for optimization"}),maxRoundsGauge:o.createGauge("ax_optimizer_max_rounds",{description:"Maximum rounds for optimization"})}),kt=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n),s=As.maxLabelLength;e[t]=r.length>s?r.substring(0,s):r}return e},Vd=(o,e,t,n,r,s)=>{try{let i=kt({success:t.toString(),optimizer_type:n,...r?{program_signature:r}:{},...s});o.optimizationLatencyHistogram&&o.optimizationLatencyHistogram.record(e,i),o.optimizationRequestsCounter&&o.optimizationRequestsCounter.add(1,i),!t&&o.optimizationErrorsCounter&&o.optimizationErrorsCounter.add(1,i)}catch(i){console.warn("Failed to record optimization metric:",i)}},Jd=(o,e,t,n,r,s,i)=>{try{let a=kt({optimizer_type:s,...i});o.convergenceRoundsHistogram&&o.convergenceRoundsHistogram.record(e,a),o.convergenceScoreGauge&&o.convergenceScoreGauge.record(t,a),o.convergenceImprovementGauge&&o.convergenceImprovementGauge.record(n,a),o.stagnationRoundsGauge&&o.stagnationRoundsGauge.record(r,a)}catch(a){console.warn("Failed to record convergence metric:",a)}},Qd=(o,e,t,n)=>{try{let r=kt({reason:e,optimizer_type:t,...n});o.earlyStoppingCounter&&o.earlyStoppingCounter.add(1,r)}catch(r){console.warn("Failed to record early stopping metric:",r)}},Yd=(o,e,t,n,r,s)=>{try{let i=kt({optimizer_type:n,...s});o.tokenUsageCounter&&o.tokenUsageCounter.add(e,i),o.costUsageCounter&&o.costUsageCounter.add(t,i),r!==void 0&&o.memoryUsageGauge&&o.memoryUsageGauge.record(r,i)}catch(i){console.warn("Failed to record resource usage metric:",i)}},Xd=(o,e,t,n)=>{try{let r=kt({optimizer_type:t,...n});o.optimizationDurationHistogram&&o.optimizationDurationHistogram.record(e,r)}catch(r){console.warn("Failed to record optimization duration metric:",r)}},Zd=(o,e,t,n,r)=>{try{let s=kt({optimizer_type:n,...r});o.teacherStudentUsageCounter&&o.teacherStudentUsageCounter.add(1,s),o.teacherStudentLatencyHistogram&&o.teacherStudentLatencyHistogram.record(e,s),o.teacherStudentScoreImprovementGauge&&o.teacherStudentScoreImprovementGauge.record(t,s)}catch(s){console.warn("Failed to record teacher-student metric:",s)}},em=(o,e,t,n,r,s)=>{try{let i=kt({operation:e,success:n.toString(),optimizer_type:r,...s});e==="save"?(o.checkpointSaveCounter&&o.checkpointSaveCounter.add(1,i),o.checkpointSaveLatencyHistogram&&o.checkpointSaveLatencyHistogram.record(t,i)):(o.checkpointLoadCounter&&o.checkpointLoadCounter.add(1,i),o.checkpointLoadLatencyHistogram&&o.checkpointLoadLatencyHistogram.record(t,i))}catch(i){console.warn("Failed to record checkpoint metric:",i)}},tm=(o,e,t,n,r,s)=>{try{let i=kt({optimizer_type:n,...s});o.paretoOptimizationsCounter&&o.paretoOptimizationsCounter.add(1,i),o.paretoFrontSizeHistogram&&o.paretoFrontSizeHistogram.record(e,i),r!==void 0&&o.paretoHypervolumeGauge&&o.paretoHypervolumeGauge.record(r,i),o.paretoSolutionsGeneratedHistogram&&o.paretoSolutionsGeneratedHistogram.record(t,i)}catch(i){console.warn("Failed to record Pareto metric:",i)}},nm=(o,e,t,n,r,s,i)=>{try{let a=kt({optimizer_type:s,...i});o.programInputFieldsGauge&&o.programInputFieldsGauge.record(e,a),o.programOutputFieldsGauge&&o.programOutputFieldsGauge.record(t,a),o.examplesCountGauge&&o.examplesCountGauge.record(n,a),o.validationSetSizeGauge&&o.validationSetSizeGauge.record(r,a)}catch(a){console.warn("Failed to record program complexity metric:",a)}},rm=(o,e,t,n,r)=>{try{let s=kt({metric_type:e,optimizer_type:n,...r});switch(e){case"evaluation":o.evaluationLatencyHistogram&&o.evaluationLatencyHistogram.record(t,s);break;case"demo_generation":o.demoGenerationLatencyHistogram&&o.demoGenerationLatencyHistogram.record(t,s);break;case"metric_computation":o.metricComputationLatencyHistogram&&o.metricComputationLatencyHistogram.record(t,s);break}}catch(s){console.warn("Failed to record optimizer performance metric:",s)}},om=(o,e,t,n,r)=>{try{let s=kt({optimizer_type:e,...r});o.optimizerTypeGauge&&o.optimizerTypeGauge.record(1,s),t!==void 0&&o.targetScoreGauge&&o.targetScoreGauge.record(t,s),n!==void 0&&o.maxRoundsGauge&&o.maxRoundsGauge.record(n,s)}catch(s){console.warn("Failed to record optimizer configuration metric:",s)}},bt=class{bestScore;stats;instruction;instructionMap;demos;examples;modelConfig;optimizerType;optimizationTime;totalRounds;converged;scoreHistory;configurationHistory;artifactFormatVersion;instructionSchema;constructor(e){this.bestScore=e.bestScore,this.stats=e.stats,this.instruction=e.instruction,this.instructionMap=e.instructionMap,this.demos=e.demos,this.examples=e.examples,this.modelConfig=e.modelConfig,this.optimizerType=e.optimizerType,this.optimizationTime=e.optimizationTime,this.totalRounds=e.totalRounds,this.converged=e.converged,this.scoreHistory=e.scoreHistory,this.configurationHistory=e.configurationHistory,this.artifactFormatVersion=e.artifactFormatVersion,this.instructionSchema=e.instructionSchema}applyTo(e){e.applyOptimization?.(this)}},zr=class{tokenUsage={};totalTokens=0;costPerModel;maxCost;maxTokens;constructor(e){this.costPerModel=e?.costPerModel??{},this.maxCost=e?.maxCost,this.maxTokens=e?.maxTokens}trackTokens(e,t){this.tokenUsage[t]=(this.tokenUsage[t]||0)+e,this.totalTokens+=e}getCurrentCost(){let e=0;for(let[t,n]of Object.entries(this.tokenUsage)){let r=this.costPerModel[t]||.001;e+=n/1e3*r}return e}getTokenUsage(){return{...this.tokenUsage}}getTotalTokens(){return this.totalTokens}isLimitReached(){return this.maxTokens!==void 0&&this.totalTokens>=this.maxTokens||this.maxCost!==void 0&&this.getCurrentCost()>=this.maxCost}reset(){this.tokenUsage={},this.totalTokens=0}},Tt=class{studentAI;teacherAI;targetScore;minSuccessRate;onProgress;onEarlyStop;costTracker;seed;checkpointSave;checkpointLoad;checkpointInterval;resumeFromCheckpoint;logger;verbose;debugOptimizer;optimizerLogger;currentRound=0;scoreHistory=[];configurationHistory=[];stats;metricsInstruments;resultExplainer;constructor(e){this.studentAI=e.studentAI,this.teacherAI=e.teacherAI,this.targetScore=e.targetScore,this.minSuccessRate=e.minSuccessRate,this.onProgress=e.onProgress,this.onEarlyStop=e.onEarlyStop,this.seed=e.seed,this.checkpointSave=e.checkpointSave,this.checkpointLoad=e.checkpointLoad,this.checkpointInterval=e.checkpointInterval??10,this.resumeFromCheckpoint=e.resumeFromCheckpoint,this.logger=e.logger,this.verbose=e.verbose;let t=new zr({maxTokens:1e6});this.costTracker=e.costTracker??t,this.metricsInstruments=Kd(de.meter),this.stats=this.initializeStats(),this.debugOptimizer=e.debugOptimizer??!1,this.optimizerLogger=e.optimizerLogger??(this.verbose?jr:void 0),this.initializeResultExplainer()}getMergedCustomLabels(e){return Qt(de.customLabels,this.studentAI?.getOptions?.()?.customLabels,this.teacherAI?.getOptions?.()?.customLabels,e?.customLabels)}initializeResultExplainer(){this.resultExplainer=void 0}initializeStats(){return{totalCalls:0,successfulDemos:0,estimatedTokenUsage:0,earlyStopped:!1,resourceUsage:{totalTokens:0,totalTime:0,avgLatencyPerEval:0,costByModel:{}},convergenceInfo:{converged:!1,finalImprovement:0,stagnationRounds:0,convergenceThreshold:.01},bestScore:0,bestConfiguration:{}}}setupRandomSeed(){this.seed!==void 0&&(Math.random=(()=>{let e=this.seed;return()=>(e=(e*9301+49297)%233280,e/233280)})())}checkCostLimits(){return this.costTracker?.isLimitReached()??!1}checkTargetScore(e){return this.targetScore!==void 0&&e>=this.targetScore}updateResourceUsage(e,t=0){this.stats.resourceUsage.totalTime=Date.now()-e,this.stats.resourceUsage.totalTokens+=t,this.stats.totalCalls>0&&(this.stats.resourceUsage.avgLatencyPerEval=this.stats.resourceUsage.totalTime/this.stats.totalCalls)}triggerEarlyStopping(e,t,n){this.stats.earlyStopped=!0,this.stats.earlyStopping={bestScoreRound:t,patienceExhausted:e.includes("improvement"),reason:e},this.recordEarlyStoppingMetrics(e,"unknown",n),this.onEarlyStop&&this.onEarlyStop(e,this.stats),this.getOptimizerLogger()?.({name:"EarlyStopping",value:{reason:e,finalScore:this.stats.bestScore??0,round:t}})}validateExamples(e,t=!0){if(!e||e.length===0)throw new Error("At least 1 example is required for optimization");if(t&&e.length<2)throw new Error("At least 2 examples are required for optimization with auto-splitting. Provide more examples to enable proper train/validation split.");let n=t?10:5;e.length<n&&this.verbose&&console.warn(`[Ax Optimizer] Warning: Only ${e.length} examples provided. Consider providing more examples (${n}+ recommended) for better optimization results.`)}getAIService(e=!1,t){return e&&t?.overrideTeacherAI?t.overrideTeacherAI:e&&this.teacherAI?this.teacherAI:this.studentAI}hasTeacherAI(e){return e?.overrideTeacherAI!==void 0||this.teacherAI!==void 0}getTeacherOrStudentAI(e){return e?.overrideTeacherAI||this.teacherAI||this.studentAI}async executeWithTeacher(e,t=!0,n){let r=this.getAIService(t,n);return await e(r)}async*compileStream(e,t,n,r){let s=Date.now(),i=this.constructor.name,a=e.getSignature().toString();this.recordOptimizationStart(i,a,r);let l,c=(g,f,x,A,h,b,T,C={},v)=>{this.getOptimizerLogger(v)?.({name:"RoundProgress",value:{round:g,totalRounds:v?.maxIterations??0,currentScore:f,bestScore:b,configuration:x}}),this.updateOptimizationProgress(g,f,x,A,h,b,T,C,v)},u=(g,f)=>{l=g,this.triggerEarlyStopping(g,this.currentRound,r)},p=g=>{this.onProgress?.(g),c(g.round,g.currentScore,g.currentConfiguration||{},i,{},g.bestScore,g.bestConfiguration,g.convergenceInfo,r)},d=await this.compile(e,t,n,{...r,overrideOnProgress:p,overrideOnEarlyStop:u}),m=Date.now()-s;return this.recordOptimizationComplete(m,!0,i,a,r),l&&this.getLogger(r)?.({name:"Notification",id:"optimization_early_stop",value:`Optimization stopped early due to ${l}`}),{demos:d.demos,stats:d.stats,bestScore:d.bestScore,finalConfiguration:d.finalConfiguration,scoreHistory:d.scoreHistory,configurationHistory:d.configurationHistory}}async compilePareto(e,t,n,r){let s=this.constructor.name,i=Date.now(),a=await this.generateWeightedSolutions(e,t,n,r),l=await this.generateConstraintSolutions(e,t,n,r),c=[...a,...l],u=this.findParetoFrontier(c),p=this.calculateHypervolume(u);this.updateResourceUsage(i),this.stats.convergenceInfo.converged=!0,this.recordParetoMetrics(u.length,c.length,"base_optimizer",p,r);let d=u.length>0?Math.max(...u.map(m=>Math.max(...Object.values(m.scores)))):0;return{demos:u.length>0?[...u[0].demos]:void 0,stats:this.stats,bestScore:d,paretoFront:u,hypervolume:p,paretoFrontSize:u.length,finalConfiguration:{paretoFrontSize:u.length,hypervolume:p,strategy:"weighted_combinations_and_constraints",numSolutions:c.length}}}async generateWeightedSolutions(e,t,n,r){let s=[];if(!t||t.length===0)throw new Error("No examples provided for Pareto optimization");let i=t[0],a=await e.forward(this.getAIService(!1,r),i),l=await n({prediction:a,example:i}),c=Object.keys(l),u=this.generateWeightCombinations(c);for(let p=0;p<u.length;p++){let d=u[p],m=async({prediction:g,example:f})=>{let x=await n({prediction:g,example:f}),A=0;for(let[h,b]of Object.entries(x))A+=b*(d[h]||0);return A};try{let g=await this.compile(e,t,m,{...r,verbose:!1}),f=await this.evaluateWithMultiObjective(e,g,n,t);s.push({scores:f,demos:g.demos,configuration:{...g.finalConfiguration,weights:d,strategy:"weighted_combination"}})}catch{}}return s}async generateConstraintSolutions(e,t,n,r){let s=[];if(!t||t.length===0)throw new Error("No examples provided for multi-objective optimization");let i=t[0],a=await e.forward(this.getAIService(!1,r),i),l=await n({prediction:a,example:i}),c=Object.keys(l);for(let u of c){let p=async({prediction:d,example:m})=>{let g=await n({prediction:d,example:m}),f=g[u]||0,x=0;for(let[A,h]of Object.entries(g))A!==u&&h<.3&&(x+=(.3-h)*2);return f-x};try{let d=await this.compile(e,t,p,{...r,verbose:!1}),m=await this.evaluateWithMultiObjective(e,d,n,t);s.push({scores:m,demos:d.demos,configuration:{...d.finalConfiguration,primaryObjective:u,strategy:"constraint_based"}})}catch{}}return s}generateWeightCombinations(e){let t=[];for(let r of e){let s={};for(let i of e)s[i]=i===r?1:0;t.push(s)}let n={};for(let r of e)n[r]=1/e.length;if(t.push(n),e.length===2){let[r,s]=e;for(let i=.1;i<=.9;i+=.2){let a=1-i;t.push({[r]:i,[s]:a})}}if(e.length===3){let[r,s,i]=e;t.push({[r]:.5,[s]:.3,[i]:.2},{[r]:.3,[s]:.5,[i]:.2},{[r]:.2,[s]:.3,[i]:.5})}return t}async evaluateWithMultiObjective(e,t,n,r){let s=new ke(e.getSignature());t.demos&&s.setDemos(t.demos);let i=[],a=Math.max(1,Math.min(5,Math.floor(r.length*.2))),l=r.slice(-a),c={},u=l;for(let d of u)try{let m=await s.forward(this.studentAI,d),g=await n({prediction:m,example:d});for(let[f,x]of Object.entries(g))c[f]||(c[f]=[]),c[f].push(x)}catch{}let p={};for(let[d,m]of Object.entries(c))p[d]=m.length>0?m.reduce((g,f)=>g+f,0)/m.length:0;return p}findParetoFrontier(e){let t=[];for(let n=0;n<e.length;n++){let r=e[n],s=!1,i=0;for(let a=0;a<e.length;a++){if(n===a)continue;let l=e[a];if(this.dominates(l.scores,r.scores)){s=!0;break}this.dominates(r.scores,l.scores)&&i++}s||t.push({demos:r.demos||[],scores:r.scores,configuration:r.configuration,dominatedSolutions:i})}return t}dominates(e,t){let n=Object.keys(e),r=!0,s=!1;for(let i of n){let a=e[i]||0,l=t[i]||0;if(a<l){r=!1;break}a>l&&(s=!0)}return r&&s}calculateHypervolume(e){if(e.length===0)return;let t=e[0],n=Object.keys(t.scores);if(n.length===2){let[r,s]=n,i=0,a=[...e].sort((c,u)=>(u.scores[r]||0)-(c.scores[r]||0)),l=0;for(let c of a){let u=c.scores[r]||0,p=c.scores[s]||0;i+=u*(p-l),l=Math.max(l,p)}return i}}async saveCheckpoint(e,t,n,r,s={},i){let a=i?.overrideCheckpointSave||this.checkpointSave;if(!a)return;let l=Date.now(),c=!1,u;try{let p={version:"1.0.0",timestamp:Date.now(),optimizerType:e,optimizerConfig:t,currentRound:this.currentRound,totalRounds:this.stats.resourceUsage.totalTime>0?this.currentRound:0,bestScore:n,bestConfiguration:r,scoreHistory:[...this.scoreHistory],configurationHistory:[...this.configurationHistory],stats:{...this.stats},optimizerState:s,examples:[]};u=await a(p),c=!0}catch(p){throw c=!1,p}finally{let p=Date.now()-l;this.recordCheckpointMetrics("save",p,c,e,i)}return u}async loadCheckpoint(e,t){let n=t?.overrideCheckpointLoad||this.checkpointLoad;if(!n)return null;let r=Date.now(),s=!1,i=null;try{i=await n(e),s=i!==null}catch(a){throw s=!1,a}finally{let a=Date.now()-r;this.recordCheckpointMetrics("load",a,s,"unknown",t)}return i}restoreFromCheckpoint(e){this.currentRound=e.currentRound,this.scoreHistory=[...e.scoreHistory],this.configurationHistory=[...e.configurationHistory],this.stats={...e.stats}}shouldSaveCheckpoint(e,t){let n=t?.overrideCheckpointInterval||this.checkpointInterval;return n!==void 0&&e%n===0}async updateOptimizationProgress(e,t,n,r,s,i,a,l={},c){this.currentRound=e,this.scoreHistory.push(t),this.configurationHistory.push(n),this.shouldSaveCheckpoint(e,c)&&await this.saveCheckpoint(r,s,i,a,l,c),this.getOptimizerLogger(c)?.({name:"RoundProgress",value:{round:e,totalRounds:c?.maxIterations??0,currentScore:t,bestScore:i,configuration:n}})}async saveFinalCheckpoint(e,t,n,r,s={},i){i?.saveCheckpointOnComplete!==!1&&await this.saveCheckpoint(e,t,n,r,{...s,final:!0},i)}getLogger(e){if(this.isLoggingEnabled(e))return this.logger?this.logger:this.studentAI.getLogger()}isLoggingEnabled(e){return e?.verbose!==void 0?e.verbose:this.verbose??!0}recordOptimizationStart(e,t,n){if(!this.metricsInstruments)return;let r=this.getMergedCustomLabels(n);if(t){let s=(t.match(/input:/g)||[]).length,i=(t.match(/output:/g)||[]).length;nm(this.metricsInstruments,s,i,0,0,e,r)}om(this.metricsInstruments,e,this.targetScore,void 0,r)}recordOptimizationComplete(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);Vd(this.metricsInstruments,e,t,n,r,i),Xd(this.metricsInstruments,e,n,i);let a=this.costTracker?.getCurrentCost()??0,l=this.costTracker?.getTotalTokens()??0;Yd(this.metricsInstruments,l,a,n,void 0,i)}recordConvergenceMetrics(e,t,n,r,s,i){if(!this.metricsInstruments)return;let a=this.getMergedCustomLabels(i);Jd(this.metricsInstruments,e,t,n,r,s,a)}recordEarlyStoppingMetrics(e,t,n){if(!this.metricsInstruments)return;let r=this.getMergedCustomLabels(n);Qd(this.metricsInstruments,e,t,r)}recordTeacherStudentMetrics(e,t,n,r){if(!this.metricsInstruments)return;let s=this.getMergedCustomLabels(r);Zd(this.metricsInstruments,e,t,n,s)}recordCheckpointMetrics(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);em(this.metricsInstruments,e,t,n,r,i)}recordParetoMetrics(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);tm(this.metricsInstruments,e,t,n,r,i)}recordPerformanceMetrics(e,t,n,r){if(!this.metricsInstruments)return;let s=this.getMergedCustomLabels(r);rm(this.metricsInstruments,e,t,n,s)}isOptimizerLoggingEnabled(e){return this.debugOptimizer||(e?.verbose??this.verbose??!1)}getOptimizerLogger(e){if(this.isOptimizerLoggingEnabled(e))return this.optimizerLogger??de.optimizerLogger??jr}getStats(){return{...this.stats}}async explainOptimizationResults(e,t,n){let r=this.stats.convergenceInfo.converged,s=this.stats.totalCalls,i=s>0?this.stats.successfulDemos/s*100:0,a=`Optimization finished with best score ${e.toFixed(3)}${t?` using configuration ${JSON.stringify(t)}`:""}. Convergence: ${r?"yes":"no"}. Success rate: ${i.toFixed(1)}%.`,l=[];if(r||l.push("Increase numTrials or relax earlyStoppingTrials to allow further improvement."),typeof this.targetScore=="number"&&e<this.targetScore&&l.push("Tighten the metric or supply more/better-labeled examples to reach targetScore."),t&&"bootstrappedDemos"in t){let u=t.bootstrappedDemos;typeof u=="number"&&u===0&&l.push("Consider allowing a small number of bootstrapped demos to boost performance.")}l.length===0&&l.push("Re-run with more trials or different acquisition settings to explore more of the space.");let c=`Tokens used: ${this.stats.resourceUsage.totalTokens}, rounds: ${this.currentRound}, stagnationRounds: ${this.stats.convergenceInfo.stagnationRounds}.`;return{humanExplanation:a,recommendations:l,performanceAssessment:c}}async logOptimizationComplete(e,t,n,r,s){let i=this.getOptimizerLogger(r);i&&i(s?{name:"OptimizationComplete",value:{optimizerType:e,bestScore:t,bestConfiguration:n||{},totalCalls:this.stats.totalCalls,successRate:this.stats.totalCalls>0?`${(this.stats.successfulDemos/this.stats.totalCalls*100).toFixed(1)}%`:"N/A",explanation:s.humanExplanation,recommendations:s.recommendations,performanceAssessment:s.performanceAssessment,stats:this.stats}}:{name:"OptimizationComplete",value:{optimizerType:e,bestScore:t,bestConfiguration:n||{},totalCalls:this.stats.totalCalls,successRate:this.stats.totalCalls>0?`${(this.stats.successfulDemos/this.stats.totalCalls*100).toFixed(1)}%`:"N/A",stats:this.stats}})}reset(){this.stats=this.initializeStats(),this.costTracker?.reset(),this.currentRound=0,this.scoreHistory=[],this.configurationHistory=[]}};var cu=ur(require("crypto"),1);function ys(o){let e=new Date().toISOString();return{version:1,sections:{},stats:{bulletCount:0,helpfulCount:0,harmfulCount:0,tokenEstimate:0},updatedAt:e,description:o}}function Ot(o){return JSON.parse(JSON.stringify(o))}function sm(o){return Math.ceil(o.length/4)}function ia(o,e,t){let n=[],r=[],{maxSectionSize:s=Number.POSITIVE_INFINITY,allowDynamicSections:i=!0,enableAutoPrune:a=!1,protectedBulletIds:l}=t??{},c=new Date().toISOString(),u=l??new Set;for(let p of e){if(!p.section)continue;if(!o.sections[p.section]){if(!i)continue;o.sections[p.section]=[]}let d=o.sections[p.section];switch(p.type){case"ADD":{if(d.length>=s){if(!a)continue;let f=am(d,u);if(!f)continue;n.push(f.id),r.push({type:"REMOVE",section:p.section,bulletId:f.id,metadata:{...f.metadata??{},autoPruned:!0,removedAt:c}})}let m=p.bulletId??im(p.section),g={id:m,section:p.section,content:p.content??"",helpfulCount:0,harmfulCount:0,createdAt:c,updatedAt:c,metadata:p.metadata?{...p.metadata}:void 0};d.push(g),n.push(m);break}case"UPDATE":{let m=d.find(g=>g.id===p.bulletId);if(!m)continue;typeof p.content=="string"&&(m.content=p.content),m.updatedAt=c,p.metadata&&(m.metadata={...m.metadata??{},...p.metadata}),n.push(m.id);break}case"REMOVE":{let m=d.findIndex(g=>g.id===p.bulletId);if(m>=0){let[g]=d.splice(m,1);g&&n.push(g.id)}break}}}return ca(o),o.updatedAt=c,{updatedBulletIds:n,autoRemoved:r}}function aa(o,e,t){for(let n of Object.values(o.sections)){let r=n.find(s=>s.id===e);if(r){t==="helpful"?r.helpfulCount+=1:t==="harmful"&&(r.harmfulCount+=1),r.updatedAt=new Date().toISOString(),ca(o);return}}}function sn(o){let e=o.description?`## Context Playbook
853
+ ${e}`}o(n)}},zr=la();var pa={enabled:!0,enabledCategories:["optimization","convergence","resource_usage","teacher_student","checkpointing","pareto"],maxLabelLength:100,samplingRate:1},Cs,_m=o=>{if(Cs)return Cs;if(o)return Cs=Nm(o),Cs};var Is=pa,yl=o=>{Is={...Is,...o}},bl=()=>({...Is}),Nm=o=>({optimizationLatencyHistogram:o.createHistogram("ax_optimizer_optimization_duration_ms",{description:"End-to-end duration of optimization runs",unit:"ms"}),optimizationRequestsCounter:o.createCounter("ax_optimizer_optimization_requests_total",{description:"Total number of optimization requests"}),optimizationErrorsCounter:o.createCounter("ax_optimizer_optimization_errors_total",{description:"Total number of failed optimizations"}),convergenceRoundsHistogram:o.createHistogram("ax_optimizer_convergence_rounds",{description:"Number of rounds until convergence"}),convergenceScoreGauge:o.createGauge("ax_optimizer_convergence_score",{description:"Current best score during optimization"}),convergenceImprovementGauge:o.createGauge("ax_optimizer_convergence_improvement",{description:"Improvement in score from baseline"}),stagnationRoundsGauge:o.createGauge("ax_optimizer_stagnation_rounds",{description:"Number of rounds without improvement"}),earlyStoppingCounter:o.createCounter("ax_optimizer_early_stopping_total",{description:"Total number of early stopping events"}),tokenUsageCounter:o.createCounter("ax_optimizer_token_usage_total",{description:"Total tokens used during optimization"}),costUsageCounter:o.createCounter("ax_optimizer_cost_usage_total",{description:"Total cost incurred during optimization",unit:"$"}),memoryUsageGauge:o.createGauge("ax_optimizer_memory_usage_bytes",{description:"Peak memory usage during optimization",unit:"By"}),optimizationDurationHistogram:o.createHistogram("ax_optimizer_duration_ms",{description:"Duration of optimization runs",unit:"ms"}),teacherStudentUsageCounter:o.createCounter("ax_optimizer_teacher_student_usage_total",{description:"Total number of teacher-student interactions"}),teacherStudentLatencyHistogram:o.createHistogram("ax_optimizer_teacher_student_latency_ms",{description:"Latency of teacher-student interactions",unit:"ms"}),teacherStudentScoreImprovementGauge:o.createGauge("ax_optimizer_teacher_student_score_improvement",{description:"Score improvement from teacher-student interactions"}),checkpointSaveCounter:o.createCounter("ax_optimizer_checkpoint_save_total",{description:"Total number of checkpoint saves"}),checkpointLoadCounter:o.createCounter("ax_optimizer_checkpoint_load_total",{description:"Total number of checkpoint loads"}),checkpointSaveLatencyHistogram:o.createHistogram("ax_optimizer_checkpoint_save_latency_ms",{description:"Latency of checkpoint save operations",unit:"ms"}),checkpointLoadLatencyHistogram:o.createHistogram("ax_optimizer_checkpoint_load_latency_ms",{description:"Latency of checkpoint load operations",unit:"ms"}),paretoOptimizationsCounter:o.createCounter("ax_optimizer_pareto_optimizations_total",{description:"Total number of Pareto optimizations"}),paretoFrontSizeHistogram:o.createHistogram("ax_optimizer_pareto_front_size",{description:"Size of Pareto frontier"}),paretoHypervolumeGauge:o.createGauge("ax_optimizer_pareto_hypervolume",{description:"Hypervolume of Pareto frontier"}),paretoSolutionsGeneratedHistogram:o.createHistogram("ax_optimizer_pareto_solutions_generated",{description:"Number of solutions generated for Pareto optimization"}),programInputFieldsGauge:o.createGauge("ax_optimizer_program_input_fields",{description:"Number of input fields in optimized program"}),programOutputFieldsGauge:o.createGauge("ax_optimizer_program_output_fields",{description:"Number of output fields in optimized program"}),examplesCountGauge:o.createGauge("ax_optimizer_examples_count",{description:"Number of training examples used"}),validationSetSizeGauge:o.createGauge("ax_optimizer_validation_set_size",{description:"Size of validation set used"}),evaluationLatencyHistogram:o.createHistogram("ax_optimizer_evaluation_latency_ms",{description:"Latency of program evaluations",unit:"ms"}),demoGenerationLatencyHistogram:o.createHistogram("ax_optimizer_demo_generation_latency_ms",{description:"Latency of demo generation",unit:"ms"}),metricComputationLatencyHistogram:o.createHistogram("ax_optimizer_metric_computation_latency_ms",{description:"Latency of metric computation",unit:"ms"}),optimizerTypeGauge:o.createGauge("ax_optimizer_type",{description:"Type of optimizer being used"}),targetScoreGauge:o.createGauge("ax_optimizer_target_score",{description:"Target score for optimization"}),maxRoundsGauge:o.createGauge("ax_optimizer_max_rounds",{description:"Maximum rounds for optimization"})}),kt=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n),s=Is.maxLabelLength;e[t]=r.length>s?r.substring(0,s):r}return e},Lm=(o,e,t,n,r,s)=>{try{let i=kt({success:t.toString(),optimizer_type:n,...r?{program_signature:r}:{},...s});o.optimizationLatencyHistogram&&o.optimizationLatencyHistogram.record(e,i),o.optimizationRequestsCounter&&o.optimizationRequestsCounter.add(1,i),!t&&o.optimizationErrorsCounter&&o.optimizationErrorsCounter.add(1,i)}catch(i){console.warn("Failed to record optimization metric:",i)}},$m=(o,e,t,n,r,s,i)=>{try{let a=kt({optimizer_type:s,...i});o.convergenceRoundsHistogram&&o.convergenceRoundsHistogram.record(e,a),o.convergenceScoreGauge&&o.convergenceScoreGauge.record(t,a),o.convergenceImprovementGauge&&o.convergenceImprovementGauge.record(n,a),o.stagnationRoundsGauge&&o.stagnationRoundsGauge.record(r,a)}catch(a){console.warn("Failed to record convergence metric:",a)}},Dm=(o,e,t,n)=>{try{let r=kt({reason:e,optimizer_type:t,...n});o.earlyStoppingCounter&&o.earlyStoppingCounter.add(1,r)}catch(r){console.warn("Failed to record early stopping metric:",r)}},Um=(o,e,t,n,r,s)=>{try{let i=kt({optimizer_type:n,...s});o.tokenUsageCounter&&o.tokenUsageCounter.add(e,i),o.costUsageCounter&&o.costUsageCounter.add(t,i),r!==void 0&&o.memoryUsageGauge&&o.memoryUsageGauge.record(r,i)}catch(i){console.warn("Failed to record resource usage metric:",i)}},Gm=(o,e,t,n)=>{try{let r=kt({optimizer_type:t,...n});o.optimizationDurationHistogram&&o.optimizationDurationHistogram.record(e,r)}catch(r){console.warn("Failed to record optimization duration metric:",r)}},jm=(o,e,t,n,r)=>{try{let s=kt({optimizer_type:n,...r});o.teacherStudentUsageCounter&&o.teacherStudentUsageCounter.add(1,s),o.teacherStudentLatencyHistogram&&o.teacherStudentLatencyHistogram.record(e,s),o.teacherStudentScoreImprovementGauge&&o.teacherStudentScoreImprovementGauge.record(t,s)}catch(s){console.warn("Failed to record teacher-student metric:",s)}},Bm=(o,e,t,n,r,s)=>{try{let i=kt({operation:e,success:n.toString(),optimizer_type:r,...s});e==="save"?(o.checkpointSaveCounter&&o.checkpointSaveCounter.add(1,i),o.checkpointSaveLatencyHistogram&&o.checkpointSaveLatencyHistogram.record(t,i)):(o.checkpointLoadCounter&&o.checkpointLoadCounter.add(1,i),o.checkpointLoadLatencyHistogram&&o.checkpointLoadLatencyHistogram.record(t,i))}catch(i){console.warn("Failed to record checkpoint metric:",i)}},zm=(o,e,t,n,r,s)=>{try{let i=kt({optimizer_type:n,...s});o.paretoOptimizationsCounter&&o.paretoOptimizationsCounter.add(1,i),o.paretoFrontSizeHistogram&&o.paretoFrontSizeHistogram.record(e,i),r!==void 0&&o.paretoHypervolumeGauge&&o.paretoHypervolumeGauge.record(r,i),o.paretoSolutionsGeneratedHistogram&&o.paretoSolutionsGeneratedHistogram.record(t,i)}catch(i){console.warn("Failed to record Pareto metric:",i)}},qm=(o,e,t,n,r,s,i)=>{try{let a=kt({optimizer_type:s,...i});o.programInputFieldsGauge&&o.programInputFieldsGauge.record(e,a),o.programOutputFieldsGauge&&o.programOutputFieldsGauge.record(t,a),o.examplesCountGauge&&o.examplesCountGauge.record(n,a),o.validationSetSizeGauge&&o.validationSetSizeGauge.record(r,a)}catch(a){console.warn("Failed to record program complexity metric:",a)}},Hm=(o,e,t,n,r)=>{try{let s=kt({metric_type:e,optimizer_type:n,...r});switch(e){case"evaluation":o.evaluationLatencyHistogram&&o.evaluationLatencyHistogram.record(t,s);break;case"demo_generation":o.demoGenerationLatencyHistogram&&o.demoGenerationLatencyHistogram.record(t,s);break;case"metric_computation":o.metricComputationLatencyHistogram&&o.metricComputationLatencyHistogram.record(t,s);break}}catch(s){console.warn("Failed to record optimizer performance metric:",s)}},Km=(o,e,t,n,r)=>{try{let s=kt({optimizer_type:e,...r});o.optimizerTypeGauge&&o.optimizerTypeGauge.record(1,s),t!==void 0&&o.targetScoreGauge&&o.targetScoreGauge.record(t,s),n!==void 0&&o.maxRoundsGauge&&o.maxRoundsGauge.record(n,s)}catch(s){console.warn("Failed to record optimizer configuration metric:",s)}},bt=class{bestScore;stats;instruction;instructionMap;demos;examples;modelConfig;optimizerType;optimizationTime;totalRounds;converged;scoreHistory;configurationHistory;artifactFormatVersion;instructionSchema;constructor(e){this.bestScore=e.bestScore,this.stats=e.stats,this.instruction=e.instruction,this.instructionMap=e.instructionMap,this.demos=e.demos,this.examples=e.examples,this.modelConfig=e.modelConfig,this.optimizerType=e.optimizerType,this.optimizationTime=e.optimizationTime,this.totalRounds=e.totalRounds,this.converged=e.converged,this.scoreHistory=e.scoreHistory,this.configurationHistory=e.configurationHistory,this.artifactFormatVersion=e.artifactFormatVersion,this.instructionSchema=e.instructionSchema}applyTo(e){e.applyOptimization?.(this)}},qr=class{tokenUsage={};totalTokens=0;costPerModel;maxCost;maxTokens;constructor(e){this.costPerModel=e?.costPerModel??{},this.maxCost=e?.maxCost,this.maxTokens=e?.maxTokens}trackTokens(e,t){this.tokenUsage[t]=(this.tokenUsage[t]||0)+e,this.totalTokens+=e}getCurrentCost(){let e=0;for(let[t,n]of Object.entries(this.tokenUsage)){let r=this.costPerModel[t]||.001;e+=n/1e3*r}return e}getTokenUsage(){return{...this.tokenUsage}}getTotalTokens(){return this.totalTokens}isLimitReached(){return this.maxTokens!==void 0&&this.totalTokens>=this.maxTokens||this.maxCost!==void 0&&this.getCurrentCost()>=this.maxCost}reset(){this.tokenUsage={},this.totalTokens=0}},Ct=class{studentAI;teacherAI;targetScore;minSuccessRate;onProgress;onEarlyStop;costTracker;seed;checkpointSave;checkpointLoad;checkpointInterval;resumeFromCheckpoint;logger;verbose;debugOptimizer;optimizerLogger;currentRound=0;scoreHistory=[];configurationHistory=[];stats;metricsInstruments;resultExplainer;constructor(e){this.studentAI=e.studentAI,this.teacherAI=e.teacherAI,this.targetScore=e.targetScore,this.minSuccessRate=e.minSuccessRate,this.onProgress=e.onProgress,this.onEarlyStop=e.onEarlyStop,this.seed=e.seed,this.checkpointSave=e.checkpointSave,this.checkpointLoad=e.checkpointLoad,this.checkpointInterval=e.checkpointInterval??10,this.resumeFromCheckpoint=e.resumeFromCheckpoint,this.logger=e.logger,this.verbose=e.verbose;let t=new qr({maxTokens:1e6});this.costTracker=e.costTracker??t,this.metricsInstruments=_m(ge.meter),this.stats=this.initializeStats(),this.debugOptimizer=e.debugOptimizer??!1,this.optimizerLogger=e.optimizerLogger??(this.verbose?zr:void 0),this.initializeResultExplainer()}getMergedCustomLabels(e){return Xt(ge.customLabels,this.studentAI?.getOptions?.()?.customLabels,this.teacherAI?.getOptions?.()?.customLabels,e?.customLabels)}initializeResultExplainer(){this.resultExplainer=void 0}initializeStats(){return{totalCalls:0,successfulDemos:0,estimatedTokenUsage:0,earlyStopped:!1,resourceUsage:{totalTokens:0,totalTime:0,avgLatencyPerEval:0,costByModel:{}},convergenceInfo:{converged:!1,finalImprovement:0,stagnationRounds:0,convergenceThreshold:.01},bestScore:0,bestConfiguration:{}}}setupRandomSeed(){this.seed!==void 0&&(Math.random=(()=>{let e=this.seed;return()=>(e=(e*9301+49297)%233280,e/233280)})())}checkCostLimits(){return this.costTracker?.isLimitReached()??!1}checkTargetScore(e){return this.targetScore!==void 0&&e>=this.targetScore}updateResourceUsage(e,t=0){this.stats.resourceUsage.totalTime=Date.now()-e,this.stats.resourceUsage.totalTokens+=t,this.stats.totalCalls>0&&(this.stats.resourceUsage.avgLatencyPerEval=this.stats.resourceUsage.totalTime/this.stats.totalCalls)}triggerEarlyStopping(e,t,n){this.stats.earlyStopped=!0,this.stats.earlyStopping={bestScoreRound:t,patienceExhausted:e.includes("improvement"),reason:e},this.recordEarlyStoppingMetrics(e,"unknown",n),this.onEarlyStop&&this.onEarlyStop(e,this.stats),this.getOptimizerLogger()?.({name:"EarlyStopping",value:{reason:e,finalScore:this.stats.bestScore??0,round:t}})}validateExamples(e,t=!0){if(!e||e.length===0)throw new Error("At least 1 example is required for optimization");if(t&&e.length<2)throw new Error("At least 2 examples are required for optimization with auto-splitting. Provide more examples to enable proper train/validation split.");let n=t?10:5;e.length<n&&this.verbose&&console.warn(`[Ax Optimizer] Warning: Only ${e.length} examples provided. Consider providing more examples (${n}+ recommended) for better optimization results.`)}getAIService(e=!1,t){return e&&t?.overrideTeacherAI?t.overrideTeacherAI:e&&this.teacherAI?this.teacherAI:this.studentAI}hasTeacherAI(e){return e?.overrideTeacherAI!==void 0||this.teacherAI!==void 0}getTeacherOrStudentAI(e){return e?.overrideTeacherAI||this.teacherAI||this.studentAI}async executeWithTeacher(e,t=!0,n){let r=this.getAIService(t,n);return await e(r)}async*compileStream(e,t,n,r){let s=Date.now(),i=this.constructor.name,a=e.getSignature().toString();this.recordOptimizationStart(i,a,r);let u,c=(g,f,x,A,h,y,C,I={},v)=>{this.getOptimizerLogger(v)?.({name:"RoundProgress",value:{round:g,totalRounds:v?.maxIterations??0,currentScore:f,bestScore:y,configuration:x}}),this.updateOptimizationProgress(g,f,x,A,h,y,C,I,v)},l=(g,f)=>{u=g,this.triggerEarlyStopping(g,this.currentRound,r)},p=g=>{this.onProgress?.(g),c(g.round,g.currentScore,g.currentConfiguration||{},i,{},g.bestScore,g.bestConfiguration,g.convergenceInfo,r)},d=await this.compile(e,t,n,{...r,overrideOnProgress:p,overrideOnEarlyStop:l}),m=Date.now()-s;return this.recordOptimizationComplete(m,!0,i,a,r),u&&this.getLogger(r)?.({name:"Notification",id:"optimization_early_stop",value:`Optimization stopped early due to ${u}`}),{demos:d.demos,stats:d.stats,bestScore:d.bestScore,finalConfiguration:d.finalConfiguration,scoreHistory:d.scoreHistory,configurationHistory:d.configurationHistory}}async compilePareto(e,t,n,r){let s=this.constructor.name,i=Date.now(),a=await this.generateWeightedSolutions(e,t,n,r),u=await this.generateConstraintSolutions(e,t,n,r),c=[...a,...u],l=this.findParetoFrontier(c),p=this.calculateHypervolume(l);this.updateResourceUsage(i),this.stats.convergenceInfo.converged=!0,this.recordParetoMetrics(l.length,c.length,"base_optimizer",p,r);let d=l.length>0?Math.max(...l.map(m=>Math.max(...Object.values(m.scores)))):0;return{demos:l.length>0?[...l[0].demos]:void 0,stats:this.stats,bestScore:d,paretoFront:l,hypervolume:p,paretoFrontSize:l.length,finalConfiguration:{paretoFrontSize:l.length,hypervolume:p,strategy:"weighted_combinations_and_constraints",numSolutions:c.length}}}async generateWeightedSolutions(e,t,n,r){let s=[];if(!t||t.length===0)throw new Error("No examples provided for Pareto optimization");let i=t[0],a=await e.forward(this.getAIService(!1,r),i),u=await n({prediction:a,example:i}),c=Object.keys(u),l=this.generateWeightCombinations(c);for(let p=0;p<l.length;p++){let d=l[p],m=async({prediction:g,example:f})=>{let x=await n({prediction:g,example:f}),A=0;for(let[h,y]of Object.entries(x))A+=y*(d[h]||0);return A};try{let g=await this.compile(e,t,m,{...r,verbose:!1}),f=await this.evaluateWithMultiObjective(e,g,n,t);s.push({scores:f,demos:g.demos,configuration:{...g.finalConfiguration,weights:d,strategy:"weighted_combination"}})}catch{}}return s}async generateConstraintSolutions(e,t,n,r){let s=[];if(!t||t.length===0)throw new Error("No examples provided for multi-objective optimization");let i=t[0],a=await e.forward(this.getAIService(!1,r),i),u=await n({prediction:a,example:i}),c=Object.keys(u);for(let l of c){let p=async({prediction:d,example:m})=>{let g=await n({prediction:d,example:m}),f=g[l]||0,x=0;for(let[A,h]of Object.entries(g))A!==l&&h<.3&&(x+=(.3-h)*2);return f-x};try{let d=await this.compile(e,t,p,{...r,verbose:!1}),m=await this.evaluateWithMultiObjective(e,d,n,t);s.push({scores:m,demos:d.demos,configuration:{...d.finalConfiguration,primaryObjective:l,strategy:"constraint_based"}})}catch{}}return s}generateWeightCombinations(e){let t=[];for(let r of e){let s={};for(let i of e)s[i]=i===r?1:0;t.push(s)}let n={};for(let r of e)n[r]=1/e.length;if(t.push(n),e.length===2){let[r,s]=e;for(let i=.1;i<=.9;i+=.2){let a=1-i;t.push({[r]:i,[s]:a})}}if(e.length===3){let[r,s,i]=e;t.push({[r]:.5,[s]:.3,[i]:.2},{[r]:.3,[s]:.5,[i]:.2},{[r]:.2,[s]:.3,[i]:.5})}return t}async evaluateWithMultiObjective(e,t,n,r){let s=new Pe(e.getSignature());t.demos&&s.setDemos(t.demos);let i=[],a=Math.max(1,Math.min(5,Math.floor(r.length*.2))),u=r.slice(-a),c={},l=u;for(let d of l)try{let m=await s.forward(this.studentAI,d),g=await n({prediction:m,example:d});for(let[f,x]of Object.entries(g))c[f]||(c[f]=[]),c[f].push(x)}catch{}let p={};for(let[d,m]of Object.entries(c))p[d]=m.length>0?m.reduce((g,f)=>g+f,0)/m.length:0;return p}findParetoFrontier(e){let t=[];for(let n=0;n<e.length;n++){let r=e[n],s=!1,i=0;for(let a=0;a<e.length;a++){if(n===a)continue;let u=e[a];if(this.dominates(u.scores,r.scores)){s=!0;break}this.dominates(r.scores,u.scores)&&i++}s||t.push({demos:r.demos||[],scores:r.scores,configuration:r.configuration,dominatedSolutions:i})}return t}dominates(e,t){let n=Object.keys(e),r=!0,s=!1;for(let i of n){let a=e[i]||0,u=t[i]||0;if(a<u){r=!1;break}a>u&&(s=!0)}return r&&s}calculateHypervolume(e){if(e.length===0)return;let t=e[0],n=Object.keys(t.scores);if(n.length===2){let[r,s]=n,i=0,a=[...e].sort((c,l)=>(l.scores[r]||0)-(c.scores[r]||0)),u=0;for(let c of a){let l=c.scores[r]||0,p=c.scores[s]||0;i+=l*(p-u),u=Math.max(u,p)}return i}}async saveCheckpoint(e,t,n,r,s={},i){let a=i?.overrideCheckpointSave||this.checkpointSave;if(!a)return;let u=Date.now(),c=!1,l;try{let p={version:"1.0.0",timestamp:Date.now(),optimizerType:e,optimizerConfig:t,currentRound:this.currentRound,totalRounds:this.stats.resourceUsage.totalTime>0?this.currentRound:0,bestScore:n,bestConfiguration:r,scoreHistory:[...this.scoreHistory],configurationHistory:[...this.configurationHistory],stats:{...this.stats},optimizerState:s,examples:[]};l=await a(p),c=!0}catch(p){throw c=!1,p}finally{let p=Date.now()-u;this.recordCheckpointMetrics("save",p,c,e,i)}return l}async loadCheckpoint(e,t){let n=t?.overrideCheckpointLoad||this.checkpointLoad;if(!n)return null;let r=Date.now(),s=!1,i=null;try{i=await n(e),s=i!==null}catch(a){throw s=!1,a}finally{let a=Date.now()-r;this.recordCheckpointMetrics("load",a,s,"unknown",t)}return i}restoreFromCheckpoint(e){this.currentRound=e.currentRound,this.scoreHistory=[...e.scoreHistory],this.configurationHistory=[...e.configurationHistory],this.stats={...e.stats}}shouldSaveCheckpoint(e,t){let n=t?.overrideCheckpointInterval||this.checkpointInterval;return n!==void 0&&e%n===0}async updateOptimizationProgress(e,t,n,r,s,i,a,u={},c){this.currentRound=e,this.scoreHistory.push(t),this.configurationHistory.push(n),this.shouldSaveCheckpoint(e,c)&&await this.saveCheckpoint(r,s,i,a,u,c),this.getOptimizerLogger(c)?.({name:"RoundProgress",value:{round:e,totalRounds:c?.maxIterations??0,currentScore:t,bestScore:i,configuration:n}})}async saveFinalCheckpoint(e,t,n,r,s={},i){i?.saveCheckpointOnComplete!==!1&&await this.saveCheckpoint(e,t,n,r,{...s,final:!0},i)}getLogger(e){if(this.isLoggingEnabled(e))return this.logger?this.logger:this.studentAI.getLogger()}isLoggingEnabled(e){return e?.verbose!==void 0?e.verbose:this.verbose??!0}recordOptimizationStart(e,t,n){if(!this.metricsInstruments)return;let r=this.getMergedCustomLabels(n);if(t){let s=(t.match(/input:/g)||[]).length,i=(t.match(/output:/g)||[]).length;qm(this.metricsInstruments,s,i,0,0,e,r)}Km(this.metricsInstruments,e,this.targetScore,void 0,r)}recordOptimizationComplete(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);Lm(this.metricsInstruments,e,t,n,r,i),Gm(this.metricsInstruments,e,n,i);let a=this.costTracker?.getCurrentCost()??0,u=this.costTracker?.getTotalTokens()??0;Um(this.metricsInstruments,u,a,n,void 0,i)}recordConvergenceMetrics(e,t,n,r,s,i){if(!this.metricsInstruments)return;let a=this.getMergedCustomLabels(i);$m(this.metricsInstruments,e,t,n,r,s,a)}recordEarlyStoppingMetrics(e,t,n){if(!this.metricsInstruments)return;let r=this.getMergedCustomLabels(n);Dm(this.metricsInstruments,e,t,r)}recordTeacherStudentMetrics(e,t,n,r){if(!this.metricsInstruments)return;let s=this.getMergedCustomLabels(r);jm(this.metricsInstruments,e,t,n,s)}recordCheckpointMetrics(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);Bm(this.metricsInstruments,e,t,n,r,i)}recordParetoMetrics(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);zm(this.metricsInstruments,e,t,n,r,i)}recordPerformanceMetrics(e,t,n,r){if(!this.metricsInstruments)return;let s=this.getMergedCustomLabels(r);Hm(this.metricsInstruments,e,t,n,s)}isOptimizerLoggingEnabled(e){return this.debugOptimizer||(e?.verbose??this.verbose??!1)}getOptimizerLogger(e){if(this.isOptimizerLoggingEnabled(e))return this.optimizerLogger??ge.optimizerLogger??zr}getStats(){return{...this.stats}}async explainOptimizationResults(e,t,n){let r=this.stats.convergenceInfo.converged,s=this.stats.totalCalls,i=s>0?this.stats.successfulDemos/s*100:0,a=`Optimization finished with best score ${e.toFixed(3)}${t?` using configuration ${JSON.stringify(t)}`:""}. Convergence: ${r?"yes":"no"}. Success rate: ${i.toFixed(1)}%.`,u=[];if(r||u.push("Increase numTrials or relax earlyStoppingTrials to allow further improvement."),typeof this.targetScore=="number"&&e<this.targetScore&&u.push("Tighten the metric or supply more/better-labeled examples to reach targetScore."),t&&"bootstrappedDemos"in t){let l=t.bootstrappedDemos;typeof l=="number"&&l===0&&u.push("Consider allowing a small number of bootstrapped demos to boost performance.")}u.length===0&&u.push("Re-run with more trials or different acquisition settings to explore more of the space.");let c=`Tokens used: ${this.stats.resourceUsage.totalTokens}, rounds: ${this.currentRound}, stagnationRounds: ${this.stats.convergenceInfo.stagnationRounds}.`;return{humanExplanation:a,recommendations:u,performanceAssessment:c}}async logOptimizationComplete(e,t,n,r,s){let i=this.getOptimizerLogger(r);i&&i(s?{name:"OptimizationComplete",value:{optimizerType:e,bestScore:t,bestConfiguration:n||{},totalCalls:this.stats.totalCalls,successRate:this.stats.totalCalls>0?`${(this.stats.successfulDemos/this.stats.totalCalls*100).toFixed(1)}%`:"N/A",explanation:s.humanExplanation,recommendations:s.recommendations,performanceAssessment:s.performanceAssessment,stats:this.stats}}:{name:"OptimizationComplete",value:{optimizerType:e,bestScore:t,bestConfiguration:n||{},totalCalls:this.stats.totalCalls,successRate:this.stats.totalCalls>0?`${(this.stats.successfulDemos/this.stats.totalCalls*100).toFixed(1)}%`:"N/A",stats:this.stats}})}reset(){this.stats=this.initializeStats(),this.costTracker?.reset(),this.currentRound=0,this.scoreHistory=[],this.configurationHistory=[]}};var Cl=dr(require("crypto"),1);function Ts(o){let e=new Date().toISOString();return{version:1,sections:{},stats:{bulletCount:0,helpfulCount:0,harmfulCount:0,tokenEstimate:0},updatedAt:e,description:o}}function Ot(o){return JSON.parse(JSON.stringify(o))}function Wm(o){return Math.ceil(o.length/4)}function da(o,e,t){let n=[],r=[],{maxSectionSize:s=Number.POSITIVE_INFINITY,allowDynamicSections:i=!0,enableAutoPrune:a=!1,protectedBulletIds:u}=t??{},c=new Date().toISOString(),l=u??new Set;for(let p of e){if(!p.section)continue;if(!o.sections[p.section]){if(!i)continue;o.sections[p.section]=[]}let d=o.sections[p.section];switch(p.type){case"ADD":{if(d.length>=s){if(!a)continue;let f=Jm(d,l);if(!f)continue;n.push(f.id),r.push({type:"REMOVE",section:p.section,bulletId:f.id,metadata:{...f.metadata??{},autoPruned:!0,removedAt:c}})}let m=p.bulletId??Vm(p.section),g={id:m,section:p.section,content:p.content??"",helpfulCount:0,harmfulCount:0,createdAt:c,updatedAt:c,metadata:p.metadata?{...p.metadata}:void 0};d.push(g),n.push(m);break}case"UPDATE":{let m=d.find(g=>g.id===p.bulletId);if(!m)continue;typeof p.content=="string"&&(m.content=p.content),m.updatedAt=c,p.metadata&&(m.metadata={...m.metadata??{},...p.metadata}),n.push(m.id);break}case"REMOVE":{let m=d.findIndex(g=>g.id===p.bulletId);if(m>=0){let[g]=d.splice(m,1);g&&n.push(g.id)}break}}}return fa(o),o.updatedAt=c,{updatedBulletIds:n,autoRemoved:r}}function ma(o,e,t){for(let n of Object.values(o.sections)){let r=n.find(s=>s.id===e);if(r){t==="helpful"?r.helpfulCount+=1:t==="harmful"&&(r.harmfulCount+=1),r.updatedAt=new Date().toISOString(),fa(o);return}}}function cn(o){let e=o.description?`## Context Playbook
854
854
  ${o.description.trim()}
855
855
  `:`## Context Playbook
856
856
  `,t=Object.entries(o.sections).map(([n,r])=>{let s=r.map(i=>`- [${i.id}] ${i.content}`).join(`
@@ -859,56 +859,56 @@ ${s}`:`### ${n}
859
859
  _(empty)_`}).join(`
860
860
 
861
861
  `);return`${e}
862
- ${t}`.trim()}function im(o){let e=o.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"").slice(0,6),t=cu.default.randomBytes(4).toString("hex");return`${e||"ctx"}-${t}`}function am(o,e){let t=-1,n;for(let s=0;s<o.length;s+=1){let i=o[s];if(e.has(i.id))continue;let a=i.helpfulCount??0,l=i.harmfulCount??0,c=a-l*2,u=Date.parse(i.updatedAt??i.createdAt),p=[c,a,Number.isFinite(u)?u:Number.POSITIVE_INFINITY];if(!n){t=s,n=p;continue}let d=o[t],m=d.helpfulCount??0,g=d.harmfulCount??0,f=m-g*2,x=Date.parse(d.updatedAt??d.createdAt),A=[f,m,Number.isFinite(x)?x:Number.POSITIVE_INFINITY];(p[0]<A[0]||p[0]===A[0]&&p[1]<A[1]||p[0]===A[0]&&p[1]===A[1]&&p[2]<A[2])&&(t=s,n=p)}if(t===-1)return;let[r]=o.splice(t,1);return r}function la(o,e=.95){for(let[t,n]of Object.entries(o.sections)){let r=new Map,s=[];for(let i of n){let a=i.content.trim().toLowerCase(),l=r.get(a);l?(l.helpfulCount+=i.helpfulCount,l.harmfulCount+=i.harmfulCount,l.updatedAt=i.updatedAt):(r.set(a,i),s.push(i))}o.sections[t]=s}ca(o)}function ca(o){let e=0,t=0,n=0,r=0;for(let s of Object.values(o.sections))for(let i of s)e+=1,t+=i.helpfulCount,n+=i.harmfulCount,r+=sm(i.content);o.stats={bulletCount:e,helpfulCount:t,harmfulCount:n,tokenEstimate:r}}var lm={maxEpochs:1,maxReflectorRounds:2,maxSectionSize:25,similarityThreshold:.95,allowDynamicSections:!0},qr=class extends bt{playbook;artifact;baseInstruction;constructor(e){super({bestScore:e.bestScore,stats:e.stats,instruction:e.instruction,demos:e.demos,examples:e.examples,modelConfig:e.modelConfig,optimizerType:e.optimizerType,optimizationTime:e.optimizationTime,totalRounds:e.totalRounds,converged:e.converged,scoreHistory:e.scoreHistory,configurationHistory:e.configurationHistory}),this.playbook=Ot(e.playbook),this.artifact=e.artifact,this.baseInstruction=e.baseInstruction}applyTo(e){super.applyTo(e);let t=e.getSignature(),r=[(this.baseInstruction??t.getDescription()??"").trim(),"",sn(this.playbook)].filter(s=>s&&s.trim().length>0).join(`
862
+ ${t}`.trim()}function Vm(o){let e=o.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"").slice(0,6),t=Cl.default.randomBytes(4).toString("hex");return`${e||"ctx"}-${t}`}function Jm(o,e){let t=-1,n;for(let s=0;s<o.length;s+=1){let i=o[s];if(e.has(i.id))continue;let a=i.helpfulCount??0,u=i.harmfulCount??0,c=a-u*2,l=Date.parse(i.updatedAt??i.createdAt),p=[c,a,Number.isFinite(l)?l:Number.POSITIVE_INFINITY];if(!n){t=s,n=p;continue}let d=o[t],m=d.helpfulCount??0,g=d.harmfulCount??0,f=m-g*2,x=Date.parse(d.updatedAt??d.createdAt),A=[f,m,Number.isFinite(x)?x:Number.POSITIVE_INFINITY];(p[0]<A[0]||p[0]===A[0]&&p[1]<A[1]||p[0]===A[0]&&p[1]===A[1]&&p[2]<A[2])&&(t=s,n=p)}if(t===-1)return;let[r]=o.splice(t,1);return r}function ga(o,e=.95){for(let[t,n]of Object.entries(o.sections)){let r=new Map,s=[];for(let i of n){let a=i.content.trim().toLowerCase(),u=r.get(a);u?(u.helpfulCount+=i.helpfulCount,u.harmfulCount+=i.harmfulCount,u.updatedAt=i.updatedAt):(r.set(a,i),s.push(i))}o.sections[t]=s}fa(o)}function fa(o){let e=0,t=0,n=0,r=0;for(let s of Object.values(o.sections))for(let i of s)e+=1,t+=i.helpfulCount,n+=i.harmfulCount,r+=Wm(i.content);o.stats={bulletCount:e,helpfulCount:t,harmfulCount:n,tokenEstimate:r}}var Qm={maxEpochs:1,maxReflectorRounds:2,maxSectionSize:25,similarityThreshold:.95,allowDynamicSections:!0},Hr=class extends bt{playbook;artifact;baseInstruction;constructor(e){super({bestScore:e.bestScore,stats:e.stats,instruction:e.instruction,demos:e.demos,examples:e.examples,modelConfig:e.modelConfig,optimizerType:e.optimizerType,optimizationTime:e.optimizationTime,totalRounds:e.totalRounds,converged:e.converged,scoreHistory:e.scoreHistory,configurationHistory:e.configurationHistory}),this.playbook=Ot(e.playbook),this.artifact=e.artifact,this.baseInstruction=e.baseInstruction}applyTo(e){super.applyTo(e);let t=e.getSignature(),r=[(this.baseInstruction??t.getDescription()??"").trim(),"",cn(this.playbook)].filter(s=>s&&s.trim().length>0).join(`
863
863
 
864
- `);e.setDescription(r)}},Vn=class extends Tt{aceConfig;playbook;baseInstruction;generatorHistory=[];deltaHistory=[];reflectorProgram;curatorProgram;program;constructor(e,t){super(e),this.aceConfig={...lm,...t},this.playbook=t?.initialPlaybook!==void 0?Ot(t.initialPlaybook):ys()}reset(){super.reset(),this.playbook=this.aceConfig.initialPlaybook!==void 0?Ot(this.aceConfig.initialPlaybook):ys(),this.baseInstruction=void 0,this.generatorHistory=[],this.deltaHistory=[]}hydrate(e,t){this.program=e,this.baseInstruction=t?.baseInstruction??e.getSignature().getDescription()??void 0,this.playbook=t?.playbook!==void 0?Ot(t.playbook):this.aceConfig.initialPlaybook!==void 0?Ot(this.aceConfig.initialPlaybook):ys(),this.generatorHistory=[...t?.artifact?.feedback??[]],this.deltaHistory=[...t?.artifact?.history??[]]}getPlaybook(){return Ot(this.playbook)}getBaseInstruction(){return this.baseInstruction}getArtifact(){return{playbook:Ot(this.playbook),feedback:[...this.generatorHistory],history:[...this.deltaHistory]}}applyCurrentState(e){let t=e??this.program;if(!t)throw new Error("AxACE: no program available to apply playbook state");let n=this.baseInstruction??t.getSignature().getDescription()??"";t.setDescription?.(this.composeInstruction(n,this.playbook))}configureAuto(e){switch(e){case"light":this.aceConfig.maxEpochs=1,this.aceConfig.maxReflectorRounds=1;break;case"medium":this.aceConfig.maxEpochs=2,this.aceConfig.maxReflectorRounds=2;break;case"heavy":this.aceConfig.maxEpochs=3,this.aceConfig.maxReflectorRounds=3;break}}async compile(e,t,n,r){let s=r?.aceOptions;s&&(Object.assign(this.aceConfig,{maxEpochs:s.maxEpochs??this.aceConfig.maxEpochs,maxReflectorRounds:s.maxReflectorRounds??this.aceConfig.maxReflectorRounds,maxSectionSize:s.maxSectionSize??this.aceConfig.maxSectionSize,similarityThreshold:s.similarityThreshold??this.aceConfig.similarityThreshold,allowDynamicSections:s.allowDynamicSections??this.aceConfig.allowDynamicSections}),s.initialPlaybook&&(this.playbook=Ot(s.initialPlaybook)));let i=Date.now();this.validateExamples(t),this.program=e;let a=await this.extractProgramInstruction(e),l=e.getSignature().getDescription()??"";this.baseInstruction=a??l,this.generatorHistory=[],this.deltaHistory=[];let c=Number.NEGATIVE_INFINITY,u=0,p=Math.max(this.aceConfig.maxEpochs,1),d=p*t.length;try{for(let A=0;A<p;A++)for(let h=0;h<t.length;h++){let b=t[h],T=this.composeInstruction(a??l,this.playbook);e.setDescription?.(T);let C=await e.forward(this.studentAI,b);this.stats.totalCalls+=1;let v=await n({prediction:C,example:b});typeof v=="number"&&(this.stats.bestScore=Math.max(this.stats.bestScore,v),c=Math.max(c,v));let k=C?.severity,R=b?.severity,E=this.createGeneratorOutput(C,b),S=R&&k&&R!==k,_=await this.runReflectionRounds({example:b,generatorOutput:E,feedback:R&&k&&R!==k?`Expected severity "${R}" but model predicted "${k}".`:void 0}),L=await this.runCurator({program:e,example:b,reflection:_,playbook:this.playbook}),P=this.normalizeCuratorOperations(L?.operations);P.length===0&&S&&(P=this.inferOperationsFromReflection(_)),P=this.resolveCuratorOperationTargets(P,this.playbook,_,E);let F=L||P.length>0?{...L??{},operations:P}:void 0,N=[];if(P.length>0){let j=this.collectProtectedBulletIds(P),V=ia(this.playbook,P,{maxSectionSize:this.aceConfig.maxSectionSize,allowDynamicSections:this.aceConfig.allowDynamicSections,enableAutoPrune:!0,protectedBulletIds:j});N=V.updatedBulletIds,V.autoRemoved.length>0&&(P.push(...V.autoRemoved),F&&(F.operations=P))}if(_?.bulletTags)for(let j of _.bulletTags)aa(this.playbook,j.id,j.tag);P.length>0&&N.length>0&&la(this.playbook,this.aceConfig.similarityThreshold);let U={example:b,prediction:C,score:typeof v=="number"?v:0,generatorOutput:E,reflection:_,curator:F,timestamp:new Date().toISOString()};this.generatorHistory.push(U),N.length>0&&F?.operations?.length&&this.deltaHistory.push({epoch:A,exampleIndex:h,operations:F.operations}),u+=1,this.currentRound=u;let G=typeof v=="number"&&Number.isFinite(v)?v:0,B=Number.isFinite(c)?c:G,te={...r??{},maxIterations:d};await this.updateOptimizationProgress(u,G,{epoch:A,exampleIndex:h,playbookBullets:this.playbook.stats.bulletCount},"ACE",{epochs:p,totalRounds:d},B,{playbookBullets:this.playbook.stats.bulletCount},void 0,te),this.stats.convergenceInfo.finalImprovement=Math.max(this.stats.convergenceInfo.finalImprovement,G)}}finally{e.setDescription?.(l)}let m=Date.now()-i;this.stats.resourceUsage.totalTime=m,this.stats.convergenceInfo.converged=!0,this.stats.bestScore=Number.isFinite(c)?c:0;let g={playbook:Ot(this.playbook),feedback:[...this.generatorHistory],history:[...this.deltaHistory]},f=new qr({baseInstruction:a??l,playbook:this.playbook,artifact:g,bestScore:Number.isFinite(c)?c:0,stats:this.stats,optimizerType:"ACE",optimizationTime:m,totalRounds:u,converged:this.stats.convergenceInfo.converged});return{stats:this.stats,bestScore:Number.isFinite(c)?c:0,finalConfiguration:{strategy:"ace",epochs:p},optimizedProgram:f,playbook:Ot(this.playbook),artifact:g}}async applyOnlineUpdate(e){if(!this.program)throw new Error("AxACE: `compile` must be run before `applyOnlineUpdate`");let t=this.createGeneratorOutput(e.prediction,e.example),n=e.prediction?.severity,r=e.example?.severity,s=await this.runReflectionRounds({example:e.example,generatorOutput:t,feedback:e.feedback??(r&&n&&r!==n?`Expected severity "${r}" but model predicted "${n}".`:void 0)}),i=await this.runCurator({program:this.program,example:e.example,reflection:s,playbook:this.playbook}),a=this.normalizeCuratorOperations(i?.operations),l=r&&n&&r!==n;a.length===0&&l&&(a=this.inferOperationsFromReflection(s)),a=this.resolveCuratorOperationTargets(a,this.playbook,s,t);let c=i||a.length>0?{...i??{},operations:a}:void 0;if(s?.bulletTags)for(let p of s.bulletTags)aa(this.playbook,p.id,p.tag);if(a.length>0){let p=this.collectProtectedBulletIds(a),d=ia(this.playbook,a,{maxSectionSize:this.aceConfig.maxSectionSize,allowDynamicSections:this.aceConfig.allowDynamicSections,enableAutoPrune:!0,protectedBulletIds:p});d.autoRemoved.length>0&&(a.push(...d.autoRemoved),c&&(c.operations=a)),la(this.playbook,this.aceConfig.similarityThreshold)}let u={example:e.example,prediction:e.prediction,score:0,generatorOutput:t,reflection:s,curator:c,timestamp:new Date().toISOString()};return this.generatorHistory.push(u),c}composeInstruction(e,t){return[e.trim(),"",sn(t)].filter(r=>r.trim().length>0).join(`
864
+ `);e.setDescription(r)}},Yn=class extends Ct{aceConfig;playbook;baseInstruction;generatorHistory=[];deltaHistory=[];reflectorProgram;curatorProgram;program;constructor(e,t){super(e),this.aceConfig={...Qm,...t},this.playbook=t?.initialPlaybook!==void 0?Ot(t.initialPlaybook):Ts()}reset(){super.reset(),this.playbook=this.aceConfig.initialPlaybook!==void 0?Ot(this.aceConfig.initialPlaybook):Ts(),this.baseInstruction=void 0,this.generatorHistory=[],this.deltaHistory=[]}hydrate(e,t){this.program=e,this.baseInstruction=t?.baseInstruction??e.getSignature().getDescription()??void 0,this.playbook=t?.playbook!==void 0?Ot(t.playbook):this.aceConfig.initialPlaybook!==void 0?Ot(this.aceConfig.initialPlaybook):Ts(),this.generatorHistory=[...t?.artifact?.feedback??[]],this.deltaHistory=[...t?.artifact?.history??[]]}getPlaybook(){return Ot(this.playbook)}getBaseInstruction(){return this.baseInstruction}getArtifact(){return{playbook:Ot(this.playbook),feedback:[...this.generatorHistory],history:[...this.deltaHistory]}}applyCurrentState(e){let t=e??this.program;if(!t)throw new Error("AxACE: no program available to apply playbook state");let n=this.baseInstruction??t.getSignature().getDescription()??"";t.setDescription?.(this.composeInstruction(n,this.playbook))}configureAuto(e){switch(e){case"light":this.aceConfig.maxEpochs=1,this.aceConfig.maxReflectorRounds=1;break;case"medium":this.aceConfig.maxEpochs=2,this.aceConfig.maxReflectorRounds=2;break;case"heavy":this.aceConfig.maxEpochs=3,this.aceConfig.maxReflectorRounds=3;break}}async compile(e,t,n,r){let s=r?.aceOptions;s&&(Object.assign(this.aceConfig,{maxEpochs:s.maxEpochs??this.aceConfig.maxEpochs,maxReflectorRounds:s.maxReflectorRounds??this.aceConfig.maxReflectorRounds,maxSectionSize:s.maxSectionSize??this.aceConfig.maxSectionSize,similarityThreshold:s.similarityThreshold??this.aceConfig.similarityThreshold,allowDynamicSections:s.allowDynamicSections??this.aceConfig.allowDynamicSections}),s.initialPlaybook&&(this.playbook=Ot(s.initialPlaybook)));let i=Date.now();this.validateExamples(t),this.program=e;let a=await this.extractProgramInstruction(e),u=e.getSignature().getDescription()??"";this.baseInstruction=a??u,this.generatorHistory=[],this.deltaHistory=[];let c=Number.NEGATIVE_INFINITY,l=0,p=Math.max(this.aceConfig.maxEpochs,1),d=p*t.length;try{for(let A=0;A<p;A++)for(let h=0;h<t.length;h++){let y=t[h],C=this.composeInstruction(a??u,this.playbook);e.setDescription?.(C);let I=await e.forward(this.studentAI,y);this.stats.totalCalls+=1;let v=await n({prediction:I,example:y});typeof v=="number"&&(this.stats.bestScore=Math.max(this.stats.bestScore,v),c=Math.max(c,v));let O=I?.severity,R=y?.severity,E=this.createGeneratorOutput(I,y),S=R&&O&&R!==O,_=await this.runReflectionRounds({example:y,generatorOutput:E,feedback:R&&O&&R!==O?`Expected severity "${R}" but model predicted "${O}".`:void 0}),$=await this.runCurator({program:e,example:y,reflection:_,playbook:this.playbook}),M=this.normalizeCuratorOperations($?.operations);M.length===0&&S&&(M=this.inferOperationsFromReflection(_)),M=this.resolveCuratorOperationTargets(M,this.playbook,_,E);let F=$||M.length>0?{...$??{},operations:M}:void 0,N=[];if(M.length>0){let j=this.collectProtectedBulletIds(M),re=da(this.playbook,M,{maxSectionSize:this.aceConfig.maxSectionSize,allowDynamicSections:this.aceConfig.allowDynamicSections,enableAutoPrune:!0,protectedBulletIds:j});N=re.updatedBulletIds,re.autoRemoved.length>0&&(M.push(...re.autoRemoved),F&&(F.operations=M))}if(_?.bulletTags)for(let j of _.bulletTags)ma(this.playbook,j.id,j.tag);M.length>0&&N.length>0&&ga(this.playbook,this.aceConfig.similarityThreshold);let G={example:y,prediction:I,score:typeof v=="number"?v:0,generatorOutput:E,reflection:_,curator:F,timestamp:new Date().toISOString()};this.generatorHistory.push(G),N.length>0&&F?.operations?.length&&this.deltaHistory.push({epoch:A,exampleIndex:h,operations:F.operations}),l+=1,this.currentRound=l;let W=typeof v=="number"&&Number.isFinite(v)?v:0,U=Number.isFinite(c)?c:W,ae={...r??{},maxIterations:d};await this.updateOptimizationProgress(l,W,{epoch:A,exampleIndex:h,playbookBullets:this.playbook.stats.bulletCount},"ACE",{epochs:p,totalRounds:d},U,{playbookBullets:this.playbook.stats.bulletCount},void 0,ae),this.stats.convergenceInfo.finalImprovement=Math.max(this.stats.convergenceInfo.finalImprovement,W)}}finally{e.setDescription?.(u)}let m=Date.now()-i;this.stats.resourceUsage.totalTime=m,this.stats.convergenceInfo.converged=!0,this.stats.bestScore=Number.isFinite(c)?c:0;let g={playbook:Ot(this.playbook),feedback:[...this.generatorHistory],history:[...this.deltaHistory]},f=new Hr({baseInstruction:a??u,playbook:this.playbook,artifact:g,bestScore:Number.isFinite(c)?c:0,stats:this.stats,optimizerType:"ACE",optimizationTime:m,totalRounds:l,converged:this.stats.convergenceInfo.converged});return{stats:this.stats,bestScore:Number.isFinite(c)?c:0,finalConfiguration:{strategy:"ace",epochs:p},optimizedProgram:f,playbook:Ot(this.playbook),artifact:g}}async applyOnlineUpdate(e){if(!this.program)throw new Error("AxACE: `compile` must be run before `applyOnlineUpdate`");let t=this.createGeneratorOutput(e.prediction,e.example),n=e.prediction?.severity,r=e.example?.severity,s=await this.runReflectionRounds({example:e.example,generatorOutput:t,feedback:e.feedback??(r&&n&&r!==n?`Expected severity "${r}" but model predicted "${n}".`:void 0)}),i=await this.runCurator({program:this.program,example:e.example,reflection:s,playbook:this.playbook}),a=this.normalizeCuratorOperations(i?.operations),u=r&&n&&r!==n;a.length===0&&u&&(a=this.inferOperationsFromReflection(s)),a=this.resolveCuratorOperationTargets(a,this.playbook,s,t);let c=i||a.length>0?{...i??{},operations:a}:void 0;if(s?.bulletTags)for(let p of s.bulletTags)ma(this.playbook,p.id,p.tag);if(a.length>0){let p=this.collectProtectedBulletIds(a),d=da(this.playbook,a,{maxSectionSize:this.aceConfig.maxSectionSize,allowDynamicSections:this.aceConfig.allowDynamicSections,enableAutoPrune:!0,protectedBulletIds:p});d.autoRemoved.length>0&&(a.push(...d.autoRemoved),c&&(c.operations=a)),ga(this.playbook,this.aceConfig.similarityThreshold)}let l={example:e.example,prediction:e.prediction,score:0,generatorOutput:t,reflection:s,curator:c,timestamp:new Date().toISOString()};return this.generatorHistory.push(l),c}composeInstruction(e,t){return[e.trim(),"",cn(t)].filter(r=>r.trim().length>0).join(`
865
865
 
866
- `)}async extractProgramInstruction(e){try{return e.getSignature().getDescription()??void 0}catch{return}}createGeneratorOutput(e,t){let n=e?.thought?.toString()??"",r=Array.isArray(e?.bullet_ids)?e?.bullet_ids:[];return{reasoning:n,answer:e,bulletIds:r,trajectory:JSON.stringify({example:t,prediction:e}),metadata:{predictedSeverity:e?.severity,expectedSeverity:t?.severity}}}resolveCuratorOperationTargets(e,t,n,r){if(!e.length)return e;let s=[],i=new Set(e.map(u=>u.bulletId).filter(u=>typeof u=="string")),a=new Map,l=(u,p)=>{if(i.has(u))return;let d=this.locateBullet(t,u);if(!d)return;let m=a.get(d.section)??{harmful:[],primary:[],generator:[]};m[p].push(d.id),a.set(d.section,m)};for(let u of n?.bulletTags??[]){let p=u.tag==="harmful"?"harmful":"primary";l(u.id,p)}if(r?.bulletIds)for(let u of r.bulletIds)l(u,"generator");let c=u=>{let p=a.get(u);if(!p)return this.locateFallbackBullet(t,u,i);let d=g=>{for(;g.length>0;){let f=g.shift();if(!i.has(f))return f}},m=d(p.harmful)??d(p.primary)??d(p.generator);return m||this.locateFallbackBullet(t,u,i)};for(let u of e){if((u.type==="UPDATE"||u.type==="REMOVE")&&!u.bulletId){let p=c(u.section);p&&(u.bulletId=p,i.add(p))}(u.type==="UPDATE"||u.type==="REMOVE")&&!u.bulletId||s.push(u)}return s}locateBullet(e,t){for(let n of Object.values(e.sections)){let r=n.find(s=>s.id===t);if(r)return r}}locateFallbackBullet(e,t,n){let r=e.sections[t]??[];for(let s of r)if(!n.has(s.id))return s.id}collectProtectedBulletIds(e){let t=new Set;for(let n of e)n.type==="UPDATE"&&n.bulletId&&t.add(n.bulletId);return t}normalizeCuratorOperations(e){if(!e)return[];if(Array.isArray(e)){let t=[],n=new Set;for(let r of e){if(!r||typeof r!="object")continue;let s=r.type??"ADD",i=typeof s=="string"?s.toUpperCase():"ADD",a=i==="UPDATE"?"UPDATE":i==="REMOVE"?"REMOVE":"ADD",l=r.section??"Guidelines",c=typeof l=="string"&&l.trim().length>0?l.trim():"Guidelines",u=r.content??"",p=typeof u=="string"?u.trim():"";if(a!=="REMOVE"&&p.length===0)continue;let d=r.bulletId??r.id,m=typeof d=="string"&&d.trim().length>0?d.trim():void 0,f=[a,c,p,m??""].join(":");if(n.has(f))continue;n.add(f);let x={type:a,section:c};a!=="REMOVE"&&(x.content=p),m&&(x.bulletId=m);let A=r.metadata;A&&typeof A=="object"&&(x.metadata={...A}),t.push(x)}return t}if(typeof e=="string")try{let t=JSON.parse(e);return this.normalizeCuratorOperations(t)}catch{return[]}if(typeof e=="object"){let t=e;if(t&&Array.isArray(t.operations))return this.normalizeCuratorOperations(t.operations);if(t&&typeof t.operations=="string")try{let n=JSON.parse(t.operations);return this.normalizeCuratorOperations(n)}catch{return[]}return[]}return[]}inferOperationsFromReflection(e){if(!e)return[];let t=[],n=new Set,r=(s,i)=>{if(!i)return;let a=i.trim();if(!a||a.toLowerCase().startsWith("no error"))return;let c=`${s}:${a}`;n.has(c)||(n.add(c),t.push({type:"ADD",section:s,content:a}))};return r("Guidelines",e.keyInsight),r("Response Strategies",e.correctApproach),r("Common Pitfalls",e.errorIdentification),r("Root Cause Notes",e.rootCauseAnalysis),t}async runReflectionRounds({example:e,generatorOutput:t,feedback:n}){let r=Math.max(this.aceConfig.maxReflectorRounds,1),s;for(let i=0;i<r;i++){let a=await this.runReflector({example:e,generatorOutput:t,feedback:n,previousReflection:s});if(!a)break;s=a;let l=a.errorIdentification?.toLowerCase().trim()??"";if(a.metadata?.resolved===!0||l.length===0||l.startsWith("no error")||l.startsWith("resolved"))break}return s}async runReflector({example:e,generatorOutput:t,feedback:n,previousReflection:r}){let s=this.getOrCreateReflectorProgram(),i=this.teacherAI??this.studentAI;try{let a={severity:e?.severity,policyHint:e?.policyHint},u=(this.program?.getSignature()?.getInputFields()??[]).reduce((d,m)=>(m.name in e&&(d[m.name]=e[m.name]),d),{});return await s.forward(i,{question:JSON.stringify(u),generator_answer:JSON.stringify(t.answer),generator_reasoning:t.reasoning,playbook:JSON.stringify({markdown:sn(this.playbook),structured:this.playbook}),expected_answer:a.severity||a.policyHint?JSON.stringify(a):void 0,feedback:n,previous_reflection:r?JSON.stringify(r):void 0})}catch(a){this.verbose&&console.warn("[AxACE] Reflector error:",a instanceof Error?a.message:a);return}}async runCurator({program:e,example:t,reflection:n,playbook:r}){if(!n)return;let s=this.getOrCreateCuratorProgram(),i=this.teacherAI??this.studentAI,c=e.getSignature().getInputFields().reduce((u,p)=>(p.name in t&&(u[p.name]=t[p.name]),u),{});try{return await s.forward(i,{playbook:JSON.stringify({markdown:sn(r),structured:r}),reflection:JSON.stringify(n),question_context:JSON.stringify(c),token_budget:1024})}catch(u){this.verbose&&console.warn("[AxACE] Curator error:",u instanceof Error?u.message:u);return}}getOrCreateReflectorProgram(){if(!this.reflectorProgram){let e=ue().input("question",ue.string("Original task input serialized as JSON")).input("generator_answer",ue.string("Generator output serialized as JSON")).input("generator_reasoning",ue.string("Generator reasoning trace").optional()).input("playbook",ue.string("Current context playbook rendered as markdown")).input("expected_answer",ue.string("Expected output when ground truth is available").optional()).input("feedback",ue.string("External feedback or reward signal").optional()).input("previous_reflection",ue.string("Most recent reflection JSON when running multi-round refinement").optional()).output("reasoning",ue.string("Step-by-step analysis of generator performance")).output("errorIdentification",ue.string("Specific mistakes detected")).output("rootCauseAnalysis",ue.string("Underlying cause of the error")).output("correctApproach",ue.string("What the generator should do differently")).output("keyInsight",ue.string("Reusable insight to remember")).output("bulletTags",ue.json("Array of {id, tag} entries referencing playbook bullets")).build();this.reflectorProgram=st(e)}return this.reflectorProgram}getOrCreateCuratorProgram(){if(!this.curatorProgram){let e=ue().input("playbook",ue.string("Current playbook serialized as JSON")).input("reflection",ue.string("Latest reflection output serialized as JSON")).input("question_context",ue.string("Original task input serialized as JSON")).input("token_budget",ue.number("Approximate token budget for curator response").optional()).output("reasoning",ue.string("Justification for the proposed updates")).output("operations",ue.json("List of operations with type/section/content fields")).build();this.curatorProgram=st(e)}return this.curatorProgram}};function uu(o,e,t=0){let n=new Set([...Object.keys(o),...Object.keys(e)]),r=!0,s=!1;for(let i of n){let a=o[i]??0,l=e[i]??0;if(a+t<l){r=!1;break}a>l+t&&(s=!0)}return r&&s}function Hr(o,e=0){let t=[];for(let n=0;n<o.length;n++){let r=0,s=!1;for(let i=0;i<o.length;i++)if(n!==i){if(uu(o[i].scores,o[n].scores,e)){s=!0;break}uu(o[n].scores,o[i].scores,e)&&r++}s||t.push({idx:o[n].idx,scores:o[n].scores,dominated:r})}return t}function Jn(o){if(o.length===0)return;let e=Object.keys(o[0]??{});if(e.length!==2)return;let[t,n]=e,r=[...o].sort((a,l)=>(l[t]??0)-(a[t]??0)),s=0,i=0;for(let a of r){let l=a[t]??0,c=a[n]??0,u=Math.max(c-i,0);s+=l*u,i=Math.max(i,c)}return s}function ua(o){if(o.length===0)return 0;let e=0;for(let t of o)e+=t;return e/o.length}function pu(o){let e={},t={};for(let r of o)for(let[s,i]of Object.entries(r))e[s]=(e[s]||0)+(typeof i=="number"?i:0),t[s]=(t[s]||0)+1;let n={};for(let[r,s]of Object.entries(e))n[r]=s/Math.max(t[r]||1,1);return n}function pa(o,e){let t=new Set;for(let u of o)for(let p of u)t.add(p);let r=[...Array.from(t)].sort((u,p)=>(e[u]??0)-(e[p]??0)),s=new Set,i=(u,p)=>{for(let d of o){if(!d.has(u))continue;let m=!1;for(let g of p)if(d.has(g)){m=!0;break}if(!m)return!1}return!0},a=!0;for(;a;){a=!1;for(let u of r){if(s.has(u))continue;let p=new Set(r.filter(d=>d!==u&&!s.has(d)));if(i(u,p)){s.add(u),a=!0;break}}}let l=r.filter(u=>!s.has(u)),c=new Set(l);return o.map(u=>{let p=new Set;for(let d of u)c.has(d)&&p.add(d);return p})}function du(o,e,t){let n=pa(o,e),r={};for(let l of n)for(let c of l)r[c]=(r[c]||0)+1;let s=[];for(let[l,c]of Object.entries(r)){let u=Number(l);for(let p=0;p<c;p++)s.push(u)}if(s.length===0)return 0;let i=typeof t=="function"?t():Math.random(),a=Math.floor(i*s.length);return s[a]}function cm(o){return o.size===0?{score:0}:Object.fromEntries([...o].map(e=>[e,0]))}function bs(o,e=800){if(typeof o=="string"){let t=o.trim();return t.length<=e?t:`${t.slice(0,Math.max(0,e-3))}...`}try{let t=JSON.stringify(o,null,2).trim();return t.length<=e?t:`${t.slice(0,Math.max(0,e-3))}...`}catch{let t=String(o).trim();return t.length<=e?t:`${t.slice(0,Math.max(0,e-3))}...`}}var Ht=class o extends Tt{numTrials;minibatch;minibatchSize;earlyStoppingTrials;minImprovementThreshold;sampleCount;paretoSetSize;crossoverEvery;tieEpsilon;feedbackMemorySize;feedbackMemory=[];mergeMax;mergesUsed=0;mergesDue=0;totalMergesTested=0;lastIterFoundNewProgram=!1;mergeAttemptKeys=new Set;mergeCompositionKeys=new Set;static REFLECTION_PROMPT_TEMPLATE="I provided an assistant with the following instructions to perform a task for me:\n```\n<curr_instructions>\n```\n\nThe following are examples of different task inputs provided to the assistant along with the assistant's response for each of them, and some feedback on how the assistant's response could be better:\n```\n<inputs_outputs_feedback>\n```\n\nYour task is to write a new instruction for the assistant. Read the inputs carefully and identify the input format and infer detailed task description about the task I wish to solve with the assistant. Read all the assistant responses and the corresponding feedback. Identify all niche and domain specific factual information about the task and include it in the instruction, as a lot of it may not be available to the assistant in the future. The assistant may have utilized a generalizable strategy to solve the task, if so, include that in the instruction as well. Provide the new instructions within ``` blocks.";rngState=123456789;samplerState={epoch:-1,shuffled:[],freq:new Map};localScoreHistory=[];localConfigurationHistory=[];constructor(e){super(e);let t=e?.seed,n=Number.isFinite(t)?Math.floor(Number(t)):0;this.rngState=n&&n!==0?n:123456789,this.numTrials=e.numTrials??30,this.minibatch=e.minibatch??!0,this.minibatchSize=e.minibatchSize??20,this.earlyStoppingTrials=e.earlyStoppingTrials??5,this.minImprovementThreshold=e.minImprovementThreshold??0,this.sampleCount=e.sampleCount??1;let r=e?.paretoSetSize;this.paretoSetSize=r&&r>0?Math.min(1e3,Math.max(5,Math.floor(r))):Math.max(10,Math.min(200,this.minibatchSize*3));let s=e?.crossoverEvery;this.crossoverEvery=Math.max(0,Math.floor(s??Math.max(3,Math.floor(this.numTrials/4))));let i=e?.tieEpsilon;this.tieEpsilon=Number.isFinite(i)?i:0;let a=e?.feedbackMemorySize;this.feedbackMemorySize=Math.max(0,Math.floor(a??4));let l=e?.mergeMax;this.mergeMax=Math.max(0,Math.floor(l??5)),this.mergesUsed=0,this.stats.convergenceInfo.convergenceThreshold=this.minImprovementThreshold}reset(){super.reset(),this.stats.convergenceInfo.convergenceThreshold=this.minImprovementThreshold,this.localScoreHistory=[],this.localConfigurationHistory=[],this.feedbackMemory=[],this.mergesUsed=0,this.mergesDue=0,this.totalMergesTested=0,this.lastIterFoundNewProgram=!1,this.mergeAttemptKeys.clear(),this.mergeCompositionKeys.clear(),this.samplerState.epoch=-1,this.samplerState.shuffled=[],this.samplerState.freq.clear()}async compile(e,t,n,r){let s=Date.now();this.validateExamples(t),r?.auto&&this.configureAuto(r.auto);let i=r?.maxMetricCalls;if(!Number.isFinite(i)||i<=0)throw new Error("AxGEPA: options.maxMetricCalls must be set to a positive integer");let a=Math.floor(i),l=r?.validationExamples,c=r?.feedbackExamples,u=(l&&l.length>0?l:t).slice(0,this.paretoSetSize),p=$=>{let K=Object.keys($).sort().reduce((ne,pe)=>(ne[pe]=$[pe],ne),{});return JSON.stringify(K)},d=new Set(t.map($=>p($))),m=c&&c.length>0?c.filter($=>d.has(p($))):t,g=m.length>0?m:t,f=this.getInstructionTargets(e);if(f.length===0)throw new Error("AxGEPA: program has no instruction-bearing nodes to optimize");let x=f.map($=>$.id),A=$=>{for(let K of f){let ne=$[K.id];typeof ne=="string"&&K.program.setInstruction?.(ne)}},h=async($,K)=>{let ne=await n({prediction:$,example:K});if(typeof ne=="number")return Number.isFinite(ne)?{score:ne}:{};if(!ne||typeof ne!="object")return{};let pe={};for(let[X,z]of Object.entries(ne))typeof z=="number"&&Number.isFinite(z)&&(pe[X]=z);return pe},b=$=>{let K=r?.paretoMetricKey,ne=r?.paretoScalarize;if(typeof ne=="function")return ne($);if(K)return Number.isFinite($[K])?$[K]:0;let pe=Object.values($);return pe.length?pe.reduce((X,z)=>X+z,0)/pe.length:0},T=this.getOptimizerLogger(r),C=r?.verbose??this.verbose?$=>console.log(`[GEPA] ${$}`):$=>{},v=new Set,k=async($,K,ne,pe=!1)=>{let X=K.length;if(this.stats.totalCalls+X>a){if(pe)throw new Error(`AxGEPA: options.maxMetricCalls=${a} is too small to evaluate the initial Pareto set; need at least ${X} metric calls`);return}let z=[];C(`${ne}: evaluating ${K.length} example${K.length===1?"":"s"}`);for(let[ie,Oe]of K.entries()){A($);let Ee,se;try{Ee=await e.forward(this.studentAI,Oe,{sampleCount:this.sampleCount}),se=await h(Ee,Oe);for(let ae of Object.keys(se))v.add(ae)}catch(ae){let Ae=ae instanceof Error?ae.message:String(ae);Ee={error:Ae},se=cm(v),C(`Evaluation failed during ${ne}; scoring this example as zero. Error: ${Ae}`)}this.stats.totalCalls+=1;let Fe=b(se);z.push({input:Oe,prediction:Ee,scores:se,scalar:Fe}),C(`${ne}: completed ${ie+1}/${K.length} (score=${Fe.toFixed(3)})`)}return{rows:z,avg:pu(z.map(ie=>ie.scores)),scalars:z.map(ie=>ie.scalar),sum:z.reduce((ie,Oe)=>ie+Oe.scalar,0)}},R={};for(let $ of f)R[$.id]=await this.getBaseInstruction($.program);let E=await k(R,u,"initial Pareto evaluation",!0),S=[{cfg:{...R},parent:void 0,scores:E.avg}],_=[E.scalars];T?.({name:"OptimizationStart",value:{optimizerType:"GEPA",exampleCount:t.length,validationCount:u.length,config:{numTrials:this.numTrials,minibatch:this.minibatch,mergeMax:this.mergeMax,tunableCount:f.length}}}),C(`Starting GEPA optimization: ${t.length} train, ${u.length} validation, maxCalls=${a}`);let L=0,P=new Set,F=Hr(S.map(($,K)=>({idx:K,scores:$.scores})),this.tieEpsilon).map($=>$.idx),N;for(let $=0;$<this.numTrials&&!(a!==void 0&&this.stats.totalCalls>=Math.max(1,Math.floor(a)));$++){let K=_[0]?.length??0,ne=[];for(let le=0;le<K;le++){let De=Number.NEGATIVE_INFINITY,We=new Set;for(let Ye=0;Ye<_.length;Ye++){let at=_[Ye][le];at>De+this.tieEpsilon?(De=at,We.clear(),We.add(Ye)):Math.abs(at-De)<=this.tieEpsilon&&We.add(Ye)}ne.push(We)}let pe=_.map(le=>ua(le));if(this.mergeMax>0&&this.mergesDue>0&&this.lastIterFoundNewProgram){let le=w=>{let O=[],I=w;for(;I!==void 0;)O.push(I),I=S[I]?.parent;return O},De=w=>w.length?w[Math.floor(this.rand()*w.length)]:void 0,We=pa(ne,pe),Ye=new Set;for(let w of We)for(let O of w)Ye.add(O);let at=Array.from(Ye),y;for(let w=0;w<10&&!y&&!(at.length<2);w++){let O=De(at),I=De(at);if(O===I)continue;I<O&&([O,I]=[I,O]);let D=new Set(le(O)),H=new Set(le(I));if(D.has(I)||H.has(O))continue;let Q=[...D].filter(Z=>H.has(Z));if(Q.length===0)continue;let W=[];for(let Z of Q){let Te=S[Z].cfg,Ue=S[O].cfg,ye=S[I].cfg,qe=!1,_e=new Set([...Object.keys(Te),...Object.keys(Ue),...Object.keys(ye)]);for(let nt of _e){let Y=Te[nt],J=Ue[nt],fe=ye[nt];if(J===Y&&fe!==J||fe===Y&&J!==fe){qe=!0;break}}qe&&W.push(Z)}if(W.length===0)continue;let M=W.map(Z=>Math.max(1e-9,pe[Z])),q=this.rand()*M.reduce((Z,Te)=>Z+Te,0),ee=W[W.length-1];for(let Z=0;Z<W.length;Z++){if(q<M[Z]){ee=W[Z];break}q-=M[Z]}y={i:O,j:I,a:ee}}if(this.lastIterFoundNewProgram=!1,y){let w=!1,{i:O,j:I,a:D}=y,H=pe[D],Q=pe[O],W=pe[I];if(H>Math.min(Q,W))continue;let M=`${O}|${I}|${D}`;if(this.mergeAttemptKeys.has(M)||(this.mergeAttemptKeys.add(M),P.has(M)))continue;let{cfg:q,descSig:ee}=this.systemAwareMergeWithSig(S,O,I,(Ce,Xe)=>pe[Ce]>=pe[Xe]?Ce:Xe),Z=`${Math.min(O,I)}|${Math.max(O,I)}|${ee}`;if(this.mergeCompositionKeys.has(Z))continue;this.mergeCompositionKeys.add(Z);let Te=_[O],Ue=_[I],ye=Array.from({length:Te.length},(Ce,Xe)=>Xe),qe=ye.filter(Ce=>(Te[Ce]??0)>(Ue[Ce]??0)),_e=ye.filter(Ce=>(Ue[Ce]??0)>(Te[Ce]??0)),nt=ye.filter(Ce=>!(qe.includes(Ce)||_e.includes(Ce))),Y=5,J=Math.ceil(Y/3),fe=(Ce,Xe)=>{if(Xe<=0||Ce.length===0)return[];if(Ce.length<=Xe)return[...Ce];let cr=[],io=new Set;for(;cr.length<Xe;){let Ct=Math.floor(this.rand()*Ce.length);io.has(Ct)||(io.add(Ct),cr.push(Ce[Ct]))}return cr},Re=[];Re.push(...fe(qe,Math.min(J,qe.length))),Re.push(...fe(_e,Math.min(J,_e.length)));let Me=Y-Re.length;Re.push(...fe(nt,Math.max(0,Me)));let Ve=Y-Re.length;if(Ve>0){let Ce=ye.filter(Xe=>!Re.includes(Xe));Re.push(...fe(Ce,Math.min(Ve,Ce.length)))}let Wt=Re.slice(0,Math.min(Y,ye.length)),Ks=Wt.map(Ce=>u[Ce]),Vt=await k(q,Ks,"merge subsample");if(!Vt)break;let Jt=Vt.sum,so=Wt.reduce((Ce,Xe)=>Ce+(Te[Xe]??0),0),Ga=Wt.reduce((Ce,Xe)=>Ce+(Ue[Xe]??0),0);if(Jt>=Math.max(so,Ga)+this.minImprovementThreshold){C(`Iteration ${$+1}: Merge accepted (programs ${O} + ${I} via ancestor ${D})`);let Ce=await k(q,u,"merge validation");if(!Ce)break;S.push({cfg:{...q},parent:D,scores:Ce.avg}),_.push(Ce.scalars);let Xe=F.length,cr=Jn(F.map(Ct=>S[Ct].scores))??0;F=Hr(S.map((Ct,Rp)=>({idx:Rp,scores:Ct.scores})),this.tieEpsilon).map(Ct=>Ct.idx);let io=Jn(F.map(Ct=>S[Ct].scores))??0;(F.length>Xe||io>cr+1e-6)&&(L=0),this.mergesDue-=1,this.totalMergesTested+=1,P.add(M),w=!0}if(w)continue}}let X=du(ne,pe,()=>this.rand());this.lastIterFoundNewProgram=!1;let z=this.minibatch?this.nextMinibatchIndices(g.length,$).map(le=>g[le]):g,ie=await k(S[X].cfg,z,"parent minibatch");if(!ie)break;if(r?.skipPerfectScore??!0){let le=Number(r?.perfectScore??1);if(ie.scalars.length>0&&ie.scalars.every(De=>De>=le))continue}let Oe={...S[X].cfg},Ee="reflective_mutation",se,Fe,ae=f[$%f.length],Ae=S[X].cfg[ae.id],be=r?.gepaAdapter,oe,ge=ie.rows.map(le=>({input:le.input,prediction:le.prediction,score:le.scalar}));if(be)try{let le=await be.evaluate(z,{...S[X].cfg},!0);se=Array.isArray(le?.scores)?le.scores.reduce((at,y)=>at+(Number(y)||0),0):void 0;let De=be.make_reflective_dataset({...S[X].cfg},le,[ae.id]),We=await be.propose_new_texts?.({...S[X].cfg},De,[ae.id]),Ye=We?.[ae.id]??(We?Object.values(We)[0]:void 0);typeof Ye=="string"&&Ye.length>0&&(oe=Ye)}catch{}if(oe||(oe=await this.reflectTargetInstruction(ae.id,Ae,e,A,{...S[X].cfg},z,async({prediction:le,example:De})=>b(await h(le,De)),r,ge)),Oe[ae.id]=oe,be&&se!==void 0)try{let le=await be.evaluate(z,Oe,!1);Fe=Array.isArray(le?.scores)?le.scores.reduce((De,We)=>De+(Number(We)||0),0):void 0}catch{}let Ie=await k(Oe,z,"child minibatch");if(!Ie)break;if(this.currentRound=$+1,await this.updateOptimizationProgress(this.currentRound,Ie.sum,{instructionLen:oe.length,target:ae.id,parent:X,totalRounds:this.numTrials},"GEPA",{strategy:Ee,paretoSetSize:u.length,tunableCount:f.length},Ie.sum,{instructionLen:Ae.length,idx:X},{...r??{},maxIterations:this.numTrials}),!(Ie.sum>ie.sum+this.minImprovementThreshold&&(se===void 0||Fe===void 0||Fe>se+this.minImprovementThreshold))){if(C(`Iteration ${$+1}: Rejected (child=${Ie.sum.toFixed(3)} <= parent=${ie.sum.toFixed(3)})`),++L>=this.earlyStoppingTrials){C(`Early stopping: ${L} iterations without improvement`);break}continue}C(`Iteration ${$+1}: Accepted (child=${Ie.sum.toFixed(3)} > parent=${ie.sum.toFixed(3)})`);let $e=await k(Oe,u,"validation evaluation");if(!$e)break;S.push({cfg:{...Oe},parent:X,scores:$e.avg}),_.push($e.scalars);let it=F.length,Se=Jn(F.map(le=>S[le].scores))??0;F=Hr(S.map((le,De)=>({idx:De,scores:le.scores})),this.tieEpsilon).map(le=>le.idx);let ze=Jn(F.map(le=>S[le].scores))??0;if(F.length>it||ze>Se+1e-6)L=0,C(`Iteration ${$+1}: Archive improved (size=${F.length}, hv=${ze.toFixed(4)})`);else if(L++,C(`Iteration ${$+1}: Archive unchanged (stagnation=${L}/${this.earlyStoppingTrials})`),L>=this.earlyStoppingTrials){C(`Early stopping: ${L} iterations without archive improvement`);break}this.lastIterFoundNewProgram=!0,this.mergeMax>0&&this.totalMergesTested<this.mergeMax&&(this.mergesDue+=1)}let U=Hr(S.map(($,K)=>({idx:K,scores:$.scores})),this.tieEpsilon),G=U.length>0?Math.max(...U.map($=>b($.scores))):0,B;if(U.length>0){let $=Number.NEGATIVE_INFINITY;for(let K of U){let ne=b(K.scores);ne>$&&($=ne,B=K.idx)}}let te=Jn(U.map($=>$.scores));this.stats.convergenceInfo.converged=!0;let j=this.getMergedCustomLabels(r);this.recordParetoMetrics(U.length,S.length,"GEPA",te,j);let V=Date.now()-s,xe=typeof B=="number"?new bt({bestScore:G,stats:this.stats,instruction:f.length===1?S[B].cfg[x[0]]:void 0,instructionMap:{...S[B].cfg},demos:[],examples:t,modelConfig:void 0,optimizerType:"GEPA",optimizationTime:V,totalRounds:this.numTrials,converged:this.stats.convergenceInfo.converged}):void 0,ve=this.generateOptimizationReport(U,te,G,S.length);return{demos:[],stats:this.stats,bestScore:G,paretoFront:U.map($=>({demos:[],scores:$.scores,configuration:{candidate:$.idx,instructionMap:{...S[$.idx].cfg},...f.length===1?{instruction:S[$.idx].cfg[x[0]]}:{}},dominatedSolutions:$.dominated})),paretoFrontSize:U.length,hypervolume:te,finalConfiguration:{strategy:"gepa",candidates:S.length,tunables:f.length},optimizedProgram:xe,report:ve}}configureAuto(e){switch(e){case"light":this.numTrials=10,this.minibatch=!0,this.minibatchSize=15;break;case"medium":this.numTrials=20,this.minibatch=!0,this.minibatchSize=25;break;case"heavy":this.numTrials=35,this.minibatch=!0,this.minibatchSize=35;break}}async getBaseInstruction(e){let t=e.getInstruction?.();if(t&&t.length>0)return t;let r=e.getSignature?.()?.getDescription?.();return r&&r.length>0?r:"Follow the task precisely. Be concise, correct, and consistent."}getInstructionTargets(e){let t=new Set,n=[],r=(s,i)=>{let a=i;!s||t.has(s)||typeof a?.setInstruction!="function"||(t.add(s),n.push({id:s,program:a,signature:a.getSignature?.()?.toString?.()}))};if("namedProgramInstances"in e&&typeof e.namedProgramInstances=="function"){let s=e.namedProgramInstances()??[];for(let i of s)r(i?.id,i?.program)}return r(e.getId?.(),e),n}async evaluateOnSet(e,t,n,r){let s=[];for(let i of n){let a=await this.evaluateOne(e,t,i,r);s.push(a)}return s}async evaluateAvg(e,t,n,r){let s=await this.evaluateOnSet(e,t,n,r);return s.length>0?ua(s):0}async evaluateOne(e,t,n,r){try{e.setInstruction?.(t);let s=await e.forward(this.studentAI,n,{sampleCount:this.sampleCount});this.stats.totalCalls+=1;let i=await r({prediction:s,example:n});if(typeof i=="number"&&!Number.isNaN(i)){let a=typeof this.targetScore=="number"?this.targetScore:.5;return i>=a&&(this.stats.successfulDemos+=1),i}return 0}catch(s){return this.getLogger()?.({name:"Notification",id:"gepa_eval",value:String(s)}),0}}async reflectTargetInstruction(e,t,n,r,s,i,a,l,c){let u=c?[...c]:[];if(u.length===0)for(let h of i)try{s[e]=t,r(s);let b=await n.forward(this.studentAI,h,{sampleCount:this.sampleCount});this.stats.totalCalls+=1;let T=await a({prediction:b,example:h});u.push({input:h,prediction:b,score:typeof T=="number"?T:0})}catch{u.push({input:h,prediction:{},score:0})}let p=l?.overrideTeacherAI??this.teacherAI??this.studentAI,d=st('targetId:string "Target program ID", minibatch:json "Array of {input,prediction,score}", evalFeedback?:string[] "Evaluator feedback when available" -> feedbackSummary:string "Concise program-focused feedback"'),g=[...(l?.feedbackNotes??[]).filter(h=>typeof h=="string"&&h.trim().length>0)],f=l?.feedbackFn;if(typeof f=="function")for(let h of u){let b=f({prediction:h.prediction,example:h.input,componentId:e});b&&(Array.isArray(b)?g.push(...b):g.push(b))}let x="";try{x=(await d.forward(p,{targetId:e,minibatch:u,evalFeedback:g}))?.feedbackSummary?.trim()||""}catch{}let A=st('targetId:string "Target program ID", currentInstruction:string "Current instruction", feedbackSummary?:string "Summarized feedback", minibatch:json "Array of {input,prediction,score}" -> newInstruction:string "Improved instruction (1-6 sentences) for the target program"');try{let b=(await A.forward(p,{targetId:e,currentInstruction:t,feedbackSummary:x,minibatch:u}))?.newInstruction?.trim();if(b&&b.length>16)return b}catch{}return`${t.trim()} Focus on step-by-step, target-specific reasoning and factual grounding.`.slice(0,2e3)}async reflectInstruction(e,t,n,r,s,i){let a=i??[];if(a.length===0)for(let f of n)try{t.setInstruction?.(e);let x=await t.forward(this.studentAI,f,{sampleCount:this.sampleCount});this.stats.totalCalls+=1;let A=await r({prediction:x,example:f});a.push({input:f,prediction:x,score:typeof A=="number"?A:0})}catch{a.push({input:f,prediction:{},score:0})}let l=s?.overrideTeacherAI??this.teacherAI??this.studentAI,c=typeof t?.getId=="function"?t.getId():void 0,u=s?.feedbackFn,p=(s?.feedbackNotes??[]).filter(f=>typeof f=="string"&&f.trim().length>0),d=()=>{let f=[];for(let A=0;A<a.length;A++){let h=a[A],b=`# Example ${A+1}
867
- `;if(b+=`## Inputs
868
- `,typeof h.input=="object"&&h.input!==null)for(let[C,v]of Object.entries(h.input))b+=`### ${C}
869
- ${bs(v)}
866
+ `)}async extractProgramInstruction(e){try{return e.getSignature().getDescription()??void 0}catch{return}}createGeneratorOutput(e,t){let n=e?.thought?.toString()??"",r=Array.isArray(e?.bullet_ids)?e?.bullet_ids:[];return{reasoning:n,answer:e,bulletIds:r,trajectory:JSON.stringify({example:t,prediction:e}),metadata:{predictedSeverity:e?.severity,expectedSeverity:t?.severity}}}resolveCuratorOperationTargets(e,t,n,r){if(!e.length)return e;let s=[],i=new Set(e.map(l=>l.bulletId).filter(l=>typeof l=="string")),a=new Map,u=(l,p)=>{if(i.has(l))return;let d=this.locateBullet(t,l);if(!d)return;let m=a.get(d.section)??{harmful:[],primary:[],generator:[]};m[p].push(d.id),a.set(d.section,m)};for(let l of n?.bulletTags??[]){let p=l.tag==="harmful"?"harmful":"primary";u(l.id,p)}if(r?.bulletIds)for(let l of r.bulletIds)u(l,"generator");let c=l=>{let p=a.get(l);if(!p)return this.locateFallbackBullet(t,l,i);let d=g=>{for(;g.length>0;){let f=g.shift();if(!i.has(f))return f}},m=d(p.harmful)??d(p.primary)??d(p.generator);return m||this.locateFallbackBullet(t,l,i)};for(let l of e){if((l.type==="UPDATE"||l.type==="REMOVE")&&!l.bulletId){let p=c(l.section);p&&(l.bulletId=p,i.add(p))}(l.type==="UPDATE"||l.type==="REMOVE")&&!l.bulletId||s.push(l)}return s}locateBullet(e,t){for(let n of Object.values(e.sections)){let r=n.find(s=>s.id===t);if(r)return r}}locateFallbackBullet(e,t,n){let r=e.sections[t]??[];for(let s of r)if(!n.has(s.id))return s.id}collectProtectedBulletIds(e){let t=new Set;for(let n of e)n.type==="UPDATE"&&n.bulletId&&t.add(n.bulletId);return t}normalizeCuratorOperations(e){if(!e)return[];if(Array.isArray(e)){let t=[],n=new Set;for(let r of e){if(!r||typeof r!="object")continue;let s=r.type??"ADD",i=typeof s=="string"?s.toUpperCase():"ADD",a=i==="UPDATE"?"UPDATE":i==="REMOVE"?"REMOVE":"ADD",u=r.section??"Guidelines",c=typeof u=="string"&&u.trim().length>0?u.trim():"Guidelines",l=r.content??"",p=typeof l=="string"?l.trim():"";if(a!=="REMOVE"&&p.length===0)continue;let d=r.bulletId??r.id,m=typeof d=="string"&&d.trim().length>0?d.trim():void 0,f=[a,c,p,m??""].join(":");if(n.has(f))continue;n.add(f);let x={type:a,section:c};a!=="REMOVE"&&(x.content=p),m&&(x.bulletId=m);let A=r.metadata;A&&typeof A=="object"&&(x.metadata={...A}),t.push(x)}return t}if(typeof e=="string")try{let t=JSON.parse(e);return this.normalizeCuratorOperations(t)}catch{return[]}if(typeof e=="object"){let t=e;if(t&&Array.isArray(t.operations))return this.normalizeCuratorOperations(t.operations);if(t&&typeof t.operations=="string")try{let n=JSON.parse(t.operations);return this.normalizeCuratorOperations(n)}catch{return[]}return[]}return[]}inferOperationsFromReflection(e){if(!e)return[];let t=[],n=new Set,r=(s,i)=>{if(!i)return;let a=i.trim();if(!a||a.toLowerCase().startsWith("no error"))return;let c=`${s}:${a}`;n.has(c)||(n.add(c),t.push({type:"ADD",section:s,content:a}))};return r("Guidelines",e.keyInsight),r("Response Strategies",e.correctApproach),r("Common Pitfalls",e.errorIdentification),r("Root Cause Notes",e.rootCauseAnalysis),t}async runReflectionRounds({example:e,generatorOutput:t,feedback:n}){let r=Math.max(this.aceConfig.maxReflectorRounds,1),s;for(let i=0;i<r;i++){let a=await this.runReflector({example:e,generatorOutput:t,feedback:n,previousReflection:s});if(!a)break;s=a;let u=a.errorIdentification?.toLowerCase().trim()??"";if(a.metadata?.resolved===!0||u.length===0||u.startsWith("no error")||u.startsWith("resolved"))break}return s}async runReflector({example:e,generatorOutput:t,feedback:n,previousReflection:r}){let s=this.getOrCreateReflectorProgram(),i=this.teacherAI??this.studentAI;try{let a={severity:e?.severity,policyHint:e?.policyHint},l=(this.program?.getSignature()?.getInputFields()??[]).reduce((d,m)=>(m.name in e&&(d[m.name]=e[m.name]),d),{});return await s.forward(i,{question:JSON.stringify(l),generator_answer:JSON.stringify(t.answer),generator_reasoning:t.reasoning,playbook:JSON.stringify({markdown:cn(this.playbook),structured:this.playbook}),expected_answer:a.severity||a.policyHint?JSON.stringify(a):void 0,feedback:n,previous_reflection:r?JSON.stringify(r):void 0})}catch(a){this.verbose&&console.warn("[AxACE] Reflector error:",a instanceof Error?a.message:a);return}}async runCurator({program:e,example:t,reflection:n,playbook:r}){if(!n)return;let s=this.getOrCreateCuratorProgram(),i=this.teacherAI??this.studentAI,c=e.getSignature().getInputFields().reduce((l,p)=>(p.name in t&&(l[p.name]=t[p.name]),l),{});try{return await s.forward(i,{playbook:JSON.stringify({markdown:cn(r),structured:r}),reflection:JSON.stringify(n),question_context:JSON.stringify(c),token_budget:1024})}catch(l){this.verbose&&console.warn("[AxACE] Curator error:",l instanceof Error?l.message:l);return}}getOrCreateReflectorProgram(){if(!this.reflectorProgram){let e=me().input("question",me.string("Original task input serialized as JSON")).input("generator_answer",me.string("Generator output serialized as JSON")).input("generator_reasoning",me.string("Generator reasoning trace").optional()).input("playbook",me.string("Current context playbook rendered as markdown")).input("expected_answer",me.string("Expected output when ground truth is available").optional()).input("feedback",me.string("External feedback or reward signal").optional()).input("previous_reflection",me.string("Most recent reflection JSON when running multi-round refinement").optional()).output("reasoning",me.string("Step-by-step analysis of generator performance")).output("errorIdentification",me.string("Specific mistakes detected")).output("rootCauseAnalysis",me.string("Underlying cause of the error")).output("correctApproach",me.string("What the generator should do differently")).output("keyInsight",me.string("Reusable insight to remember")).output("bulletTags",me.json("Array of {id, tag} entries referencing playbook bullets")).build();this.reflectorProgram=st(e)}return this.reflectorProgram}getOrCreateCuratorProgram(){if(!this.curatorProgram){let e=me().input("playbook",me.string("Current playbook serialized as JSON")).input("reflection",me.string("Latest reflection output serialized as JSON")).input("question_context",me.string("Original task input serialized as JSON")).input("token_budget",me.number("Approximate token budget for curator response").optional()).output("reasoning",me.string("Justification for the proposed updates")).output("operations",me.json("List of operations with type/section/content fields")).build();this.curatorProgram=st(e)}return this.curatorProgram}};function Il(o,e,t=0){let n=new Set([...Object.keys(o),...Object.keys(e)]),r=!0,s=!1;for(let i of n){let a=o[i]??0,u=e[i]??0;if(a+t<u){r=!1;break}a>u+t&&(s=!0)}return r&&s}function Kr(o,e=0){let t=[];for(let n=0;n<o.length;n++){let r=0,s=!1;for(let i=0;i<o.length;i++)if(n!==i){if(Il(o[i].scores,o[n].scores,e)){s=!0;break}Il(o[n].scores,o[i].scores,e)&&r++}s||t.push({idx:o[n].idx,scores:o[n].scores,dominated:r})}return t}function Xn(o){if(o.length===0)return;let e=Object.keys(o[0]??{});if(e.length!==2)return;let[t,n]=e,r=[...o].sort((a,u)=>(u[t]??0)-(a[t]??0)),s=0,i=0;for(let a of r){let u=a[t]??0,c=a[n]??0,l=Math.max(c-i,0);s+=u*l,i=Math.max(i,c)}return s}function ha(o){if(o.length===0)return 0;let e=0;for(let t of o)e+=t;return e/o.length}function Tl(o){let e={},t={};for(let r of o)for(let[s,i]of Object.entries(r))e[s]=(e[s]||0)+(typeof i=="number"?i:0),t[s]=(t[s]||0)+1;let n={};for(let[r,s]of Object.entries(e))n[r]=s/Math.max(t[r]||1,1);return n}function xa(o,e){let t=new Set;for(let l of o)for(let p of l)t.add(p);let r=[...Array.from(t)].sort((l,p)=>(e[l]??0)-(e[p]??0)),s=new Set,i=(l,p)=>{for(let d of o){if(!d.has(l))continue;let m=!1;for(let g of p)if(d.has(g)){m=!0;break}if(!m)return!1}return!0},a=!0;for(;a;){a=!1;for(let l of r){if(s.has(l))continue;let p=new Set(r.filter(d=>d!==l&&!s.has(d)));if(i(l,p)){s.add(l),a=!0;break}}}let u=r.filter(l=>!s.has(l)),c=new Set(u);return o.map(l=>{let p=new Set;for(let d of l)c.has(d)&&p.add(d);return p})}function wl(o,e,t){let n=xa(o,e),r={};for(let u of n)for(let c of u)r[c]=(r[c]||0)+1;let s=[];for(let[u,c]of Object.entries(r)){let l=Number(u);for(let p=0;p<c;p++)s.push(l)}if(s.length===0)return 0;let i=typeof t=="function"?t():Math.random(),a=Math.floor(i*s.length);return s[a]}function Ym(o){return o.size===0?{score:0}:Object.fromEntries([...o].map(e=>[e,0]))}function ws(o,e=800){if(typeof o=="string"){let t=o.trim();return t.length<=e?t:`${t.slice(0,Math.max(0,e-3))}...`}try{let t=JSON.stringify(o,null,2).trim();return t.length<=e?t:`${t.slice(0,Math.max(0,e-3))}...`}catch{let t=String(o).trim();return t.length<=e?t:`${t.slice(0,Math.max(0,e-3))}...`}}var Wt=class o extends Ct{numTrials;minibatch;minibatchSize;earlyStoppingTrials;minImprovementThreshold;sampleCount;paretoSetSize;crossoverEvery;tieEpsilon;feedbackMemorySize;feedbackMemory=[];mergeMax;mergesUsed=0;mergesDue=0;totalMergesTested=0;lastIterFoundNewProgram=!1;mergeAttemptKeys=new Set;mergeCompositionKeys=new Set;static REFLECTION_PROMPT_TEMPLATE="I provided an assistant with the following instructions to perform a task for me:\n```\n<curr_instructions>\n```\n\nThe following are examples of different task inputs provided to the assistant along with the assistant's response for each of them, and some feedback on how the assistant's response could be better:\n```\n<inputs_outputs_feedback>\n```\n\nYour task is to write a new instruction for the assistant. Read the inputs carefully and identify the input format and infer detailed task description about the task I wish to solve with the assistant. Read all the assistant responses and the corresponding feedback. Identify all niche and domain specific factual information about the task and include it in the instruction, as a lot of it may not be available to the assistant in the future. The assistant may have utilized a generalizable strategy to solve the task, if so, include that in the instruction as well. Provide the new instructions within ``` blocks.";rngState=123456789;samplerState={epoch:-1,shuffled:[],freq:new Map};localScoreHistory=[];localConfigurationHistory=[];constructor(e){super(e);let t=e?.seed,n=Number.isFinite(t)?Math.floor(Number(t)):0;this.rngState=n&&n!==0?n:123456789,this.numTrials=e.numTrials??30,this.minibatch=e.minibatch??!0,this.minibatchSize=e.minibatchSize??20,this.earlyStoppingTrials=e.earlyStoppingTrials??5,this.minImprovementThreshold=e.minImprovementThreshold??0,this.sampleCount=e.sampleCount??1;let r=e?.paretoSetSize;this.paretoSetSize=r&&r>0?Math.min(1e3,Math.max(5,Math.floor(r))):Math.max(10,Math.min(200,this.minibatchSize*3));let s=e?.crossoverEvery;this.crossoverEvery=Math.max(0,Math.floor(s??Math.max(3,Math.floor(this.numTrials/4))));let i=e?.tieEpsilon;this.tieEpsilon=Number.isFinite(i)?i:0;let a=e?.feedbackMemorySize;this.feedbackMemorySize=Math.max(0,Math.floor(a??4));let u=e?.mergeMax;this.mergeMax=Math.max(0,Math.floor(u??5)),this.mergesUsed=0,this.stats.convergenceInfo.convergenceThreshold=this.minImprovementThreshold}reset(){super.reset(),this.stats.convergenceInfo.convergenceThreshold=this.minImprovementThreshold,this.localScoreHistory=[],this.localConfigurationHistory=[],this.feedbackMemory=[],this.mergesUsed=0,this.mergesDue=0,this.totalMergesTested=0,this.lastIterFoundNewProgram=!1,this.mergeAttemptKeys.clear(),this.mergeCompositionKeys.clear(),this.samplerState.epoch=-1,this.samplerState.shuffled=[],this.samplerState.freq.clear()}async compile(e,t,n,r){let s=Date.now();this.validateExamples(t),r?.auto&&this.configureAuto(r.auto);let i=r?.maxMetricCalls;if(!Number.isFinite(i)||i<=0)throw new Error("AxGEPA: options.maxMetricCalls must be set to a positive integer");let a=Math.floor(i),u=r?.validationExamples,c=r?.feedbackExamples,l=(u&&u.length>0?u:t).slice(0,this.paretoSetSize),p=L=>{let K=Object.keys(L).sort().reduce((ee,he)=>(ee[he]=L[he],ee),{});return JSON.stringify(K)},d=new Set(t.map(L=>p(L))),m=c&&c.length>0?c.filter(L=>d.has(p(L))):t,g=m.length>0?m:t,f=this.getInstructionTargets(e);if(f.length===0)throw new Error("AxGEPA: program has no instruction-bearing nodes to optimize");let x=f.map(L=>L.id),A=L=>{for(let K of f){let ee=L[K.id];typeof ee=="string"&&K.program.setInstruction?.(ee)}},h=async(L,K)=>{let ee=await n({prediction:L,example:K});if(typeof ee=="number")return Number.isFinite(ee)?{score:ee}:{};if(!ee||typeof ee!="object")return{};let he={};for(let[q,B]of Object.entries(ee))typeof B=="number"&&Number.isFinite(B)&&(he[q]=B);return he},y=L=>{let K=r?.paretoMetricKey,ee=r?.paretoScalarize;if(typeof ee=="function")return ee(L);if(K)return Number.isFinite(L[K])?L[K]:0;let he=Object.values(L);return he.length?he.reduce((q,B)=>q+B,0)/he.length:0},C=this.getOptimizerLogger(r),I=r?.verbose??this.verbose?L=>console.log(`[GEPA] ${L}`):L=>{},v=new Set,O=async(L,K,ee,he=!1)=>{let q=K.length;if(this.stats.totalCalls+q>a){if(he)throw new Error(`AxGEPA: options.maxMetricCalls=${a} is too small to evaluate the initial Pareto set; need at least ${q} metric calls`);return}let B=[];I(`${ee}: evaluating ${K.length} example${K.length===1?"":"s"}`);for(let[ue,ke]of K.entries()){A(L);let Oe,ce;try{Oe=await e.forward(this.studentAI,ke,{sampleCount:this.sampleCount}),ce=await h(Oe,ke);for(let se of Object.keys(ce))v.add(se)}catch(se){let de=se instanceof Error?se.message:String(se);Oe={error:de},ce=Ym(v),I(`Evaluation failed during ${ee}; scoring this example as zero. Error: ${de}`)}this.stats.totalCalls+=1;let Re=y(ce);B.push({input:ke,prediction:Oe,scores:ce,scalar:Re}),I(`${ee}: completed ${ue+1}/${K.length} (score=${Re.toFixed(3)})`)}return{rows:B,avg:Tl(B.map(ue=>ue.scores)),scalars:B.map(ue=>ue.scalar),sum:B.reduce((ue,ke)=>ue+ke.scalar,0)}},R={};for(let L of f)R[L.id]=await this.getBaseInstruction(L.program);let E=await O(R,l,"initial Pareto evaluation",!0),S=[{cfg:{...R},parent:void 0,scores:E.avg}],_=[E.scalars];C?.({name:"OptimizationStart",value:{optimizerType:"GEPA",exampleCount:t.length,validationCount:l.length,config:{numTrials:this.numTrials,minibatch:this.minibatch,mergeMax:this.mergeMax,tunableCount:f.length}}}),I(`Starting GEPA optimization: ${t.length} train, ${l.length} validation, maxCalls=${a}`);let $=0,M=new Set,F=Kr(S.map((L,K)=>({idx:K,scores:L.scores})),this.tieEpsilon).map(L=>L.idx),N;for(let L=0;L<this.numTrials&&!(a!==void 0&&this.stats.totalCalls>=Math.max(1,Math.floor(a)));L++){let K=_[0]?.length??0,ee=[];for(let pe=0;pe<K;pe++){let De=Number.NEGATIVE_INFINITY,We=new Set;for(let Ye=0;Ye<_.length;Ye++){let ct=_[Ye][pe];ct>De+this.tieEpsilon?(De=ct,We.clear(),We.add(Ye)):Math.abs(ct-De)<=this.tieEpsilon&&We.add(Ye)}ee.push(We)}let he=_.map(pe=>ha(pe));if(this.mergeMax>0&&this.mergesDue>0&&this.lastIterFoundNewProgram){let pe=w=>{let k=[],T=w;for(;T!==void 0;)k.push(T),T=S[T]?.parent;return k},De=w=>w.length?w[Math.floor(this.rand()*w.length)]:void 0,We=xa(ee,he),Ye=new Set;for(let w of We)for(let k of w)Ye.add(k);let ct=Array.from(Ye),b;for(let w=0;w<10&&!b&&!(ct.length<2);w++){let k=De(ct),T=De(ct);if(k===T)continue;T<k&&([k,T]=[T,k]);let D=new Set(pe(k)),H=new Set(pe(T));if(D.has(T)||H.has(k))continue;let Y=[...D].filter(te=>H.has(te));if(Y.length===0)continue;let V=[];for(let te of Y){let Ie=S[te].cfg,Ue=S[k].cfg,be=S[T].cfg,qe=!1,Ne=new Set([...Object.keys(Ie),...Object.keys(Ue),...Object.keys(be)]);for(let nt of Ne){let Z=Ie[nt],Q=Ue[nt],Ae=be[nt];if(Q===Z&&Ae!==Q||Ae===Z&&Q!==Ae){qe=!0;break}}qe&&V.push(te)}if(V.length===0)continue;let P=V.map(te=>Math.max(1e-9,he[te])),z=this.rand()*P.reduce((te,Ie)=>te+Ie,0),ne=V[V.length-1];for(let te=0;te<V.length;te++){if(z<P[te]){ne=V[te];break}z-=P[te]}b={i:k,j:T,a:ne}}if(this.lastIterFoundNewProgram=!1,b){let w=!1,{i:k,j:T,a:D}=b,H=he[D],Y=he[k],V=he[T];if(H>Math.min(Y,V))continue;let P=`${k}|${T}|${D}`;if(this.mergeAttemptKeys.has(P)||(this.mergeAttemptKeys.add(P),M.has(P)))continue;let{cfg:z,descSig:ne}=this.systemAwareMergeWithSig(S,k,T,(Te,Xe)=>he[Te]>=he[Xe]?Te:Xe),te=`${Math.min(k,T)}|${Math.max(k,T)}|${ne}`;if(this.mergeCompositionKeys.has(te))continue;this.mergeCompositionKeys.add(te);let Ie=_[k],Ue=_[T],be=Array.from({length:Ie.length},(Te,Xe)=>Xe),qe=be.filter(Te=>(Ie[Te]??0)>(Ue[Te]??0)),Ne=be.filter(Te=>(Ue[Te]??0)>(Ie[Te]??0)),nt=be.filter(Te=>!(qe.includes(Te)||Ne.includes(Te))),Z=5,Q=Math.ceil(Z/3),Ae=(Te,Xe)=>{if(Xe<=0||Te.length===0)return[];if(Te.length<=Xe)return[...Te];let pr=[],co=new Set;for(;pr.length<Xe;){let It=Math.floor(this.rand()*Te.length);co.has(It)||(co.add(It),pr.push(Te[It]))}return pr},Se=[];Se.push(...Ae(qe,Math.min(Q,qe.length))),Se.push(...Ae(Ne,Math.min(Q,Ne.length)));let Fe=Z-Se.length;Se.push(...Ae(nt,Math.max(0,Fe)));let Ve=Z-Se.length;if(Ve>0){let Te=be.filter(Xe=>!Se.includes(Xe));Se.push(...Ae(Te,Math.min(Ve,Te.length)))}let Jt=Se.slice(0,Math.min(Z,be.length)),Qs=Jt.map(Te=>l[Te]),Qt=await O(z,Qs,"merge subsample");if(!Qt)break;let Yt=Qt.sum,uo=Jt.reduce((Te,Xe)=>Te+(Ie[Xe]??0),0),eu=Jt.reduce((Te,Xe)=>Te+(Ue[Xe]??0),0);if(Yt>=Math.max(uo,eu)+this.minImprovementThreshold){I(`Iteration ${L+1}: Merge accepted (programs ${k} + ${T} via ancestor ${D})`);let Te=await O(z,l,"merge validation");if(!Te)break;S.push({cfg:{...z},parent:D,scores:Te.avg}),_.push(Te.scalars);let Xe=F.length,pr=Xn(F.map(It=>S[It].scores))??0;F=Kr(S.map((It,md)=>({idx:md,scores:It.scores})),this.tieEpsilon).map(It=>It.idx);let co=Xn(F.map(It=>S[It].scores))??0;(F.length>Xe||co>pr+1e-6)&&($=0),this.mergesDue-=1,this.totalMergesTested+=1,M.add(P),w=!0}if(w)continue}}let q=wl(ee,he,()=>this.rand());this.lastIterFoundNewProgram=!1;let B=this.minibatch?this.nextMinibatchIndices(g.length,L).map(pe=>g[pe]):g,ue=await O(S[q].cfg,B,"parent minibatch");if(!ue)break;if(r?.skipPerfectScore??!0){let pe=Number(r?.perfectScore??1);if(ue.scalars.length>0&&ue.scalars.every(De=>De>=pe))continue}let ke={...S[q].cfg},Oe="reflective_mutation",ce,Re,se=f[L%f.length],de=S[q].cfg[se.id],J=r?.gepaAdapter,X,xe=ue.rows.map(pe=>({input:pe.input,prediction:pe.prediction,score:pe.scalar}));if(J)try{let pe=await J.evaluate(B,{...S[q].cfg},!0);ce=Array.isArray(pe?.scores)?pe.scores.reduce((ct,b)=>ct+(Number(b)||0),0):void 0;let De=J.make_reflective_dataset({...S[q].cfg},pe,[se.id]),We=await J.propose_new_texts?.({...S[q].cfg},De,[se.id]),Ye=We?.[se.id]??(We?Object.values(We)[0]:void 0);typeof Ye=="string"&&Ye.length>0&&(X=Ye)}catch{}if(X||(X=await this.reflectTargetInstruction(se.id,de,e,A,{...S[q].cfg},B,async({prediction:pe,example:De})=>y(await h(pe,De)),r,xe)),ke[se.id]=X,J&&ce!==void 0)try{let pe=await J.evaluate(B,ke,!1);Re=Array.isArray(pe?.scores)?pe.scores.reduce((De,We)=>De+(Number(We)||0),0):void 0}catch{}let we=await O(ke,B,"child minibatch");if(!we)break;if(this.currentRound=L+1,await this.updateOptimizationProgress(this.currentRound,we.sum,{instructionLen:X.length,target:se.id,parent:q,totalRounds:this.numTrials},"GEPA",{strategy:Oe,paretoSetSize:l.length,tunableCount:f.length},we.sum,{instructionLen:de.length,idx:q},{...r??{},maxIterations:this.numTrials}),!(we.sum>ue.sum+this.minImprovementThreshold&&(ce===void 0||Re===void 0||Re>ce+this.minImprovementThreshold))){if(I(`Iteration ${L+1}: Rejected (child=${we.sum.toFixed(3)} <= parent=${ue.sum.toFixed(3)})`),++$>=this.earlyStoppingTrials){I(`Early stopping: ${$} iterations without improvement`);break}continue}I(`Iteration ${L+1}: Accepted (child=${we.sum.toFixed(3)} > parent=${ue.sum.toFixed(3)})`);let $e=await O(ke,l,"validation evaluation");if(!$e)break;S.push({cfg:{...ke},parent:q,scores:$e.avg}),_.push($e.scalars);let ut=F.length,Ee=Xn(F.map(pe=>S[pe].scores))??0;F=Kr(S.map((pe,De)=>({idx:De,scores:pe.scores})),this.tieEpsilon).map(pe=>pe.idx);let ze=Xn(F.map(pe=>S[pe].scores))??0;if(F.length>ut||ze>Ee+1e-6)$=0,I(`Iteration ${L+1}: Archive improved (size=${F.length}, hv=${ze.toFixed(4)})`);else if($++,I(`Iteration ${L+1}: Archive unchanged (stagnation=${$}/${this.earlyStoppingTrials})`),$>=this.earlyStoppingTrials){I(`Early stopping: ${$} iterations without archive improvement`);break}this.lastIterFoundNewProgram=!0,this.mergeMax>0&&this.totalMergesTested<this.mergeMax&&(this.mergesDue+=1)}let G=Kr(S.map((L,K)=>({idx:K,scores:L.scores})),this.tieEpsilon),W=G.length>0?Math.max(...G.map(L=>y(L.scores))):0,U;if(G.length>0){let L=Number.NEGATIVE_INFINITY;for(let K of G){let ee=y(K.scores);ee>L&&(L=ee,U=K.idx)}}let ae=Xn(G.map(L=>L.scores));this.stats.convergenceInfo.converged=!0;let j=this.getMergedCustomLabels(r);this.recordParetoMetrics(G.length,S.length,"GEPA",ae,j);let re=Date.now()-s,oe=typeof U=="number"?new bt({bestScore:W,stats:this.stats,instruction:f.length===1?S[U].cfg[x[0]]:void 0,instructionMap:{...S[U].cfg},demos:[],examples:t,modelConfig:void 0,optimizerType:"GEPA",optimizationTime:re,totalRounds:this.numTrials,converged:this.stats.convergenceInfo.converged}):void 0,Ce=this.generateOptimizationReport(G,ae,W,S.length);return{demos:[],stats:this.stats,bestScore:W,paretoFront:G.map(L=>({demos:[],scores:L.scores,configuration:{candidate:L.idx,instructionMap:{...S[L.idx].cfg},...f.length===1?{instruction:S[L.idx].cfg[x[0]]}:{}},dominatedSolutions:L.dominated})),paretoFrontSize:G.length,hypervolume:ae,finalConfiguration:{strategy:"gepa",candidates:S.length,tunables:f.length},optimizedProgram:oe,report:Ce}}configureAuto(e){switch(e){case"light":this.numTrials=10,this.minibatch=!0,this.minibatchSize=15;break;case"medium":this.numTrials=20,this.minibatch=!0,this.minibatchSize=25;break;case"heavy":this.numTrials=35,this.minibatch=!0,this.minibatchSize=35;break}}async getBaseInstruction(e){let t=e.getInstruction?.();if(t&&t.length>0)return t;let r=e.getSignature?.()?.getDescription?.();return r&&r.length>0?r:"Follow the task precisely. Be concise, correct, and consistent."}getInstructionTargets(e){let t=new Set,n=[],r=(s,i)=>{let a=i;!s||t.has(s)||typeof a?.setInstruction!="function"||(t.add(s),n.push({id:s,program:a,signature:a.getSignature?.()?.toString?.()}))};if("namedProgramInstances"in e&&typeof e.namedProgramInstances=="function"){let s=e.namedProgramInstances()??[];for(let i of s)r(i?.id,i?.program)}return r(e.getId?.(),e),n}async evaluateOnSet(e,t,n,r){let s=[];for(let i of n){let a=await this.evaluateOne(e,t,i,r);s.push(a)}return s}async evaluateAvg(e,t,n,r){let s=await this.evaluateOnSet(e,t,n,r);return s.length>0?ha(s):0}async evaluateOne(e,t,n,r){try{e.setInstruction?.(t);let s=await e.forward(this.studentAI,n,{sampleCount:this.sampleCount});this.stats.totalCalls+=1;let i=await r({prediction:s,example:n});if(typeof i=="number"&&!Number.isNaN(i)){let a=typeof this.targetScore=="number"?this.targetScore:.5;return i>=a&&(this.stats.successfulDemos+=1),i}return 0}catch(s){return this.getLogger()?.({name:"Notification",id:"gepa_eval",value:String(s)}),0}}async reflectTargetInstruction(e,t,n,r,s,i,a,u,c){let l=c?[...c]:[];if(l.length===0)for(let h of i)try{s[e]=t,r(s);let y=await n.forward(this.studentAI,h,{sampleCount:this.sampleCount});this.stats.totalCalls+=1;let C=await a({prediction:y,example:h});l.push({input:h,prediction:y,score:typeof C=="number"?C:0})}catch{l.push({input:h,prediction:{},score:0})}let p=u?.overrideTeacherAI??this.teacherAI??this.studentAI,d=st('targetId:string "Target program ID", minibatch:json "Array of {input,prediction,score}", evalFeedback?:string[] "Evaluator feedback when available" -> feedbackSummary:string "Concise program-focused feedback"'),g=[...(u?.feedbackNotes??[]).filter(h=>typeof h=="string"&&h.trim().length>0)],f=u?.feedbackFn;if(typeof f=="function")for(let h of l){let y=f({prediction:h.prediction,example:h.input,componentId:e});y&&(Array.isArray(y)?g.push(...y):g.push(y))}let x="";try{x=(await d.forward(p,{targetId:e,minibatch:l,evalFeedback:g}))?.feedbackSummary?.trim()||""}catch{}let A=st('targetId:string "Target program ID", currentInstruction:string "Current instruction", feedbackSummary?:string "Summarized feedback", minibatch:json "Array of {input,prediction,score}" -> newInstruction:string "Improved instruction (1-6 sentences) for the target program"');try{let y=(await A.forward(p,{targetId:e,currentInstruction:t,feedbackSummary:x,minibatch:l}))?.newInstruction?.trim();if(y&&y.length>16)return y}catch{}return`${t.trim()} Focus on step-by-step, target-specific reasoning and factual grounding.`.slice(0,2e3)}async reflectInstruction(e,t,n,r,s,i){let a=i??[];if(a.length===0)for(let f of n)try{t.setInstruction?.(e);let x=await t.forward(this.studentAI,f,{sampleCount:this.sampleCount});this.stats.totalCalls+=1;let A=await r({prediction:x,example:f});a.push({input:f,prediction:x,score:typeof A=="number"?A:0})}catch{a.push({input:f,prediction:{},score:0})}let u=s?.overrideTeacherAI??this.teacherAI??this.studentAI,c=typeof t?.getId=="function"?t.getId():void 0,l=s?.feedbackFn,p=(s?.feedbackNotes??[]).filter(f=>typeof f=="string"&&f.trim().length>0),d=()=>{let f=[];for(let A=0;A<a.length;A++){let h=a[A],y=`# Example ${A+1}
867
+ `;if(y+=`## Inputs
868
+ `,typeof h.input=="object"&&h.input!==null)for(let[I,v]of Object.entries(h.input))y+=`### ${I}
869
+ ${ws(v)}
870
870
 
871
- `;else b+=`${bs(h.input)}
871
+ `;else y+=`${ws(h.input)}
872
872
 
873
- `;if(b+=`## Generated Outputs
874
- `,typeof h.prediction=="object"&&h.prediction!==null)for(let[C,v]of Object.entries(h.prediction))b+=`### ${C}
875
- ${bs(v)}
873
+ `;if(y+=`## Generated Outputs
874
+ `,typeof h.prediction=="object"&&h.prediction!==null)for(let[I,v]of Object.entries(h.prediction))y+=`### ${I}
875
+ ${ws(v)}
876
876
 
877
- `;else b+=`${bs(h.prediction)}
877
+ `;else y+=`${ws(h.prediction)}
878
878
 
879
- `;b+=`## Feedback
880
- `;let T=`This trajectory got a score of ${h.score.toFixed(3)}.`;if(typeof u=="function")try{let C=u({prediction:h.prediction,example:h.input,componentId:c});C&&(T=Array.isArray(C)?C.join(`
881
- `):C)}catch{}b+=`${T}
882
- `,f.push(b)}return[...p.map((A,h)=>`# Additional Feedback ${h+1}
879
+ `;y+=`## Feedback
880
+ `;let C=`This trajectory got a score of ${h.score.toFixed(3)}.`;if(typeof l=="function")try{let I=l({prediction:h.prediction,example:h.input,componentId:c});I&&(C=Array.isArray(I)?I.join(`
881
+ `):I)}catch{}y+=`${C}
882
+ `,f.push(y)}return[...p.map((A,h)=>`# Additional Feedback ${h+1}
883
883
  ${A}`),...f].join(`
884
884
 
885
- `)},m=o.REFLECTION_PROMPT_TEMPLATE.replace("<curr_instructions>",e).replace("<inputs_outputs_feedback>",d());try{let f=await l.chat({chatPrompt:[{role:"user",content:m}],model:s?.reflectionModel},{stream:!1});if(typeof f.getReader=="function")throw new Error("Streaming response not expected for reflection");let A=f.results?.[0]?.content;if(typeof A=="string"){let h=this.extractInstructionFromBackticks(A);if(h&&h.length>16){let b=`Iteration feedback: ${a.map(T=>`score=${T.score.toFixed(2)}`).join(", ")}`;return this.feedbackMemory.unshift(b),this.feedbackMemory.length>this.feedbackMemorySize&&this.feedbackMemory.pop(),h}}}catch{}let g=st('currentInstruction:string "Current instruction", feedbackSummary?:string "Summarized feedback", recentFeedback?:string[] "Past feedback memory", minibatch:json "Array of {input,prediction,score}" -> newInstruction:string "Improved instruction within 1-6 sentences."');try{let x=(await g.forward(l,{currentInstruction:e,feedbackSummary:this.feedbackMemory[0]||"",recentFeedback:this.feedbackMemory,minibatch:a}))?.newInstruction?.trim();if(x&&x.length>16)return x}catch{}return`${e.trim()} Focus on step-by-step evidence-based reasoning. Avoid hallucinations.`.slice(0,2e3)}extractInstructionFromBackticks(e){let t=e.indexOf("```")+3,n=e.lastIndexOf("```");if(t>=n){let i=e.trim();if(i.startsWith("```")){let a=i.match(/^```\S*\n?/);if(a)return i.slice(a[0].length).trim()}else if(i.endsWith("```"))return i.slice(0,-3).trim();return i}let r=e.slice(t,n),s=r.match(/^\S*\n/);return s&&(r=r.slice(s[0].length)),r.trim()}updateSamplerShuffled(e){let t=Array.from({length:e},(l,c)=>c);for(let l=t.length-1;l>0;l--){let c=Math.floor(this.rand()*(l+1));[t[l],t[c]]=[t[c],t[l]]}for(let l of t)this.samplerState.freq.set(l,(this.samplerState.freq.get(l)??0)+1);let n=this.minibatchSize,r=e%n,s=r===0?0:n-r,i=Array.from({length:e},(l,c)=>c).sort((l,c)=>(this.samplerState.freq.get(l)??0)-(this.samplerState.freq.get(c)??0)),a=[...t];for(let l=0;l<s;l++){let c=i[l%i.length];a.push(c),this.samplerState.freq.set(c,(this.samplerState.freq.get(c)??0)+1)}this.samplerState.shuffled=a,this.samplerState.epoch+=1}nextMinibatchIndices(e,t){this.samplerState.epoch===-1&&(this.samplerState.epoch=0,this.updateSamplerShuffled(e));let n=this.minibatchSize,r=Math.max(1,Math.floor(this.samplerState.shuffled.length/n)),s=Math.floor(t/r);for(;s>=this.samplerState.epoch;)this.updateSamplerShuffled(e);let i=t*n%this.samplerState.shuffled.length;return this.samplerState.shuffled.slice(i,i+n)}rand(){return this.rngState^=this.rngState<<13,this.rngState^=this.rngState>>>17,this.rngState^=this.rngState<<5,(this.rngState>>>0)/4294967296}systemAwareMergeWithSig(e,t,n,r){let s=x=>{let A=[],h=x;for(;h!==void 0;)A.push(h),h=e[h]?.parent;return A},i=s(t),a=s(n),c=i.find(x=>a.includes(x))??t,u=e[c].cfg,p=e[t].cfg,d=e[n].cfg,m={},g=[],f=Array.from(new Set([...Object.keys(u),...Object.keys(p),...Object.keys(d)])).sort();for(let x of f){let A=u[x],h=p[x],b=d[x];if(h===A&&b!==h)m[x]=b,g.push("j");else if(b===A&&h!==b)m[x]=h,g.push("i");else if(h!==b&&h!==A&&b!==A){let T=r(t,n);m[x]=T===t?h:b,g.push(T===t?"i":"j")}else m[x]=h??b??A,g.push("i")}return{cfg:m,descSig:g.join("|")}}generateOptimizationReport(e,t,n,r){let s=e.length>0?e.reduce((u,p)=>{let d=Object.values(u.scores).reduce((g,f)=>g+f,0);return Object.values(p.scores).reduce((g,f)=>g+f,0)>d?p:u}):void 0,i={};if(s)for(let[u,p]of Object.entries(s.scores))i[u]={value:p,percentage:p*100};let a=[];if(e.length>1){let u=[...e].sort((p,d)=>d.dominated-p.dominated).slice(0,3);for(let p of u)a.push({...p.scores})}let l="good",c=[];if(e.length===1)l="single",c.push("Increase numTrials (current seems low)"),c.push("Add more training examples"),c.push("Adjust earlyStoppingTrials");else if(e.length<3)l="limited",c.push("More optimization trials"),c.push("Larger validation set");else{l="good";let u=Object.keys(e[0]?.scores||{});for(let p of u)c.push(`High ${p}: Choose solution with best ${p} score`);c.push("Balanced: Use provided bestScore (average)")}return this.stats.totalCalls<50&&(c.push("Quick run detected - use numTrials: 30+ for production"),c.push("Provide 50+ training examples"),c.push("Use 20+ validation examples")),{summary:"GEPA Multi-Objective Optimization Complete",bestSolution:{overallScore:n??0,objectives:i},paretoFrontier:{solutionCount:e.length,objectiveSpaceCoverage:(t??0)*100,hypervolume:t??0,tradeoffs:a.length>0?a:void 0},statistics:{totalEvaluations:this.stats.totalCalls,candidatesExplored:r,converged:this.stats.convergenceInfo?.converged??!1},recommendations:{status:l,suggestions:c}}}async mergeInstructions(e,t,n){let r=n?.overrideTeacherAI??this.teacherAI??this.studentAI,s=st(`instructionA:string "Parent A instruction",
885
+ `)},m=o.REFLECTION_PROMPT_TEMPLATE.replace("<curr_instructions>",e).replace("<inputs_outputs_feedback>",d());try{let f=await u.chat({chatPrompt:[{role:"user",content:m}],model:s?.reflectionModel},{stream:!1});if(typeof f.getReader=="function")throw new Error("Streaming response not expected for reflection");let A=f.results?.[0]?.content;if(typeof A=="string"){let h=this.extractInstructionFromBackticks(A);if(h&&h.length>16){let y=`Iteration feedback: ${a.map(C=>`score=${C.score.toFixed(2)}`).join(", ")}`;return this.feedbackMemory.unshift(y),this.feedbackMemory.length>this.feedbackMemorySize&&this.feedbackMemory.pop(),h}}}catch{}let g=st('currentInstruction:string "Current instruction", feedbackSummary?:string "Summarized feedback", recentFeedback?:string[] "Past feedback memory", minibatch:json "Array of {input,prediction,score}" -> newInstruction:string "Improved instruction within 1-6 sentences."');try{let x=(await g.forward(u,{currentInstruction:e,feedbackSummary:this.feedbackMemory[0]||"",recentFeedback:this.feedbackMemory,minibatch:a}))?.newInstruction?.trim();if(x&&x.length>16)return x}catch{}return`${e.trim()} Focus on step-by-step evidence-based reasoning. Avoid hallucinations.`.slice(0,2e3)}extractInstructionFromBackticks(e){let t=e.indexOf("```")+3,n=e.lastIndexOf("```");if(t>=n){let i=e.trim();if(i.startsWith("```")){let a=i.match(/^```\S*\n?/);if(a)return i.slice(a[0].length).trim()}else if(i.endsWith("```"))return i.slice(0,-3).trim();return i}let r=e.slice(t,n),s=r.match(/^\S*\n/);return s&&(r=r.slice(s[0].length)),r.trim()}updateSamplerShuffled(e){let t=Array.from({length:e},(u,c)=>c);for(let u=t.length-1;u>0;u--){let c=Math.floor(this.rand()*(u+1));[t[u],t[c]]=[t[c],t[u]]}for(let u of t)this.samplerState.freq.set(u,(this.samplerState.freq.get(u)??0)+1);let n=this.minibatchSize,r=e%n,s=r===0?0:n-r,i=Array.from({length:e},(u,c)=>c).sort((u,c)=>(this.samplerState.freq.get(u)??0)-(this.samplerState.freq.get(c)??0)),a=[...t];for(let u=0;u<s;u++){let c=i[u%i.length];a.push(c),this.samplerState.freq.set(c,(this.samplerState.freq.get(c)??0)+1)}this.samplerState.shuffled=a,this.samplerState.epoch+=1}nextMinibatchIndices(e,t){this.samplerState.epoch===-1&&(this.samplerState.epoch=0,this.updateSamplerShuffled(e));let n=this.minibatchSize,r=Math.max(1,Math.floor(this.samplerState.shuffled.length/n)),s=Math.floor(t/r);for(;s>=this.samplerState.epoch;)this.updateSamplerShuffled(e);let i=t*n%this.samplerState.shuffled.length;return this.samplerState.shuffled.slice(i,i+n)}rand(){return this.rngState^=this.rngState<<13,this.rngState^=this.rngState>>>17,this.rngState^=this.rngState<<5,(this.rngState>>>0)/4294967296}systemAwareMergeWithSig(e,t,n,r){let s=x=>{let A=[],h=x;for(;h!==void 0;)A.push(h),h=e[h]?.parent;return A},i=s(t),a=s(n),c=i.find(x=>a.includes(x))??t,l=e[c].cfg,p=e[t].cfg,d=e[n].cfg,m={},g=[],f=Array.from(new Set([...Object.keys(l),...Object.keys(p),...Object.keys(d)])).sort();for(let x of f){let A=l[x],h=p[x],y=d[x];if(h===A&&y!==h)m[x]=y,g.push("j");else if(y===A&&h!==y)m[x]=h,g.push("i");else if(h!==y&&h!==A&&y!==A){let C=r(t,n);m[x]=C===t?h:y,g.push(C===t?"i":"j")}else m[x]=h??y??A,g.push("i")}return{cfg:m,descSig:g.join("|")}}generateOptimizationReport(e,t,n,r){let s=e.length>0?e.reduce((l,p)=>{let d=Object.values(l.scores).reduce((g,f)=>g+f,0);return Object.values(p.scores).reduce((g,f)=>g+f,0)>d?p:l}):void 0,i={};if(s)for(let[l,p]of Object.entries(s.scores))i[l]={value:p,percentage:p*100};let a=[];if(e.length>1){let l=[...e].sort((p,d)=>d.dominated-p.dominated).slice(0,3);for(let p of l)a.push({...p.scores})}let u="good",c=[];if(e.length===1)u="single",c.push("Increase numTrials (current seems low)"),c.push("Add more training examples"),c.push("Adjust earlyStoppingTrials");else if(e.length<3)u="limited",c.push("More optimization trials"),c.push("Larger validation set");else{u="good";let l=Object.keys(e[0]?.scores||{});for(let p of l)c.push(`High ${p}: Choose solution with best ${p} score`);c.push("Balanced: Use provided bestScore (average)")}return this.stats.totalCalls<50&&(c.push("Quick run detected - use numTrials: 30+ for production"),c.push("Provide 50+ training examples"),c.push("Use 20+ validation examples")),{summary:"GEPA Multi-Objective Optimization Complete",bestSolution:{overallScore:n??0,objectives:i},paretoFrontier:{solutionCount:e.length,objectiveSpaceCoverage:(t??0)*100,hypervolume:t??0,tradeoffs:a.length>0?a:void 0},statistics:{totalEvaluations:this.stats.totalCalls,candidatesExplored:r,converged:this.stats.convergenceInfo?.converged??!1},recommendations:{status:u,suggestions:c}}}async mergeInstructions(e,t,n){let r=n?.overrideTeacherAI??this.teacherAI??this.studentAI,s=st(`instructionA:string "Parent A instruction",
886
886
  instructionB:string "Parent B instruction",
887
887
  recentFeedback?:string[] "Past feedback memory"
888
- -> mergedInstruction:string "Merged instruction (1-6 sentences) combining strengths, fixing weaknesses"`);try{let a=(await s.forward(r,{instructionA:e,instructionB:t,recentFeedback:this.feedbackMemory}))?.mergedInstruction?.trim();if(a&&a.length>16)return a}catch{}return(e.length>=t.length?e:t).slice(0,2e3)}};function mu(o){return o.map(e=>{let t=e.type?.name??"string",n=e.type?.isArray?"[]":"",r=e.isOptional?" (optional)":"",s=e.description?`: ${e.description}`:"";return`- ${e.name}: ${t}${n}${r}${s}`}).join(`
889
- `)}function um(o){return o.map(e=>{let t=e.type?.name??"string",n=e.type?.isArray?"[]":"",r=e.type?.options?` (options: ${e.type.options.join(", ")})`:"",s=e.description?`: ${e.description}`:"";return`- ${e.name}: ${t}${n}${r}${s}`}).join(`
890
- `)}var Qn=class{signature;options;constructor(e,t){this.signature=e,this.options={teacher:t.teacher,diversity:t.diversity??"none",temperature:t.temperature??.8,domain:t.domain,edgeCases:t.edgeCases,model:t.model}}async generate(e,t){let n=Date.now(),r=t?.batchSize??Math.min(e,10),s=[],i=0,a=0;for(let l=0;l<e;l+=r){let c=Math.min(r,e-l),u=await this.generateInputs(c);for(let p of u){a++;try{let d=await this.labelInput(p);s.push({input:p,expected:d,category:"normal"}),i++}catch(d){console.warn("AxSynth: Failed to label input:",d)}}}if(this.options.edgeCases&&this.options.edgeCases.length>0){let l=await this.generateEdgeCaseInputs(Math.ceil(e*.2));for(let c of l){a++;try{let u=await this.labelInput(c);s.push({input:c,expected:u,category:"edge_case"}),i++}catch(u){console.warn("AxSynth: Failed to label edge case input:",u)}}}return{examples:s,stats:{requested:e,generated:s.length,labelingSuccessRate:a>0?i/a:0,durationMs:Date.now()-n}}}async generateInputs(e){let t=this.signature.getInputFields(),n=this.signature.getOutputFields(),r=this.signature.getDescription(),s=`
888
+ -> mergedInstruction:string "Merged instruction (1-6 sentences) combining strengths, fixing weaknesses"`);try{let a=(await s.forward(r,{instructionA:e,instructionB:t,recentFeedback:this.feedbackMemory}))?.mergedInstruction?.trim();if(a&&a.length>16)return a}catch{}return(e.length>=t.length?e:t).slice(0,2e3)}};function Rl(o){return o.map(e=>{let t=e.type?.name??"string",n=e.type?.isArray?"[]":"",r=e.isOptional?" (optional)":"",s=e.description?`: ${e.description}`:"";return`- ${e.name}: ${t}${n}${r}${s}`}).join(`
889
+ `)}function Xm(o){return o.map(e=>{let t=e.type?.name??"string",n=e.type?.isArray?"[]":"",r=e.type?.options?` (options: ${e.type.options.join(", ")})`:"",s=e.description?`: ${e.description}`:"";return`- ${e.name}: ${t}${n}${r}${s}`}).join(`
890
+ `)}var Zn=class{signature;options;constructor(e,t){this.signature=e,this.options={teacher:t.teacher,diversity:t.diversity??"none",temperature:t.temperature??.8,domain:t.domain,edgeCases:t.edgeCases,model:t.model}}async generate(e,t){let n=Date.now(),r=t?.batchSize??Math.min(e,10),s=[],i=0,a=0;for(let u=0;u<e;u+=r){let c=Math.min(r,e-u),l=await this.generateInputs(c);for(let p of l){a++;try{let d=await this.labelInput(p);s.push({input:p,expected:d,category:"normal"}),i++}catch(d){console.warn("AxSynth: Failed to label input:",d)}}}if(this.options.edgeCases&&this.options.edgeCases.length>0){let u=await this.generateEdgeCaseInputs(Math.ceil(e*.2));for(let c of u){a++;try{let l=await this.labelInput(c);s.push({input:c,expected:l,category:"edge_case"}),i++}catch(l){console.warn("AxSynth: Failed to label edge case input:",l)}}}return{examples:s,stats:{requested:e,generated:s.length,labelingSuccessRate:a>0?i/a:0,durationMs:Date.now()-n}}}async generateInputs(e){let t=this.signature.getInputFields(),n=this.signature.getOutputFields(),r=this.signature.getDescription(),s=`
891
891
  You are generating realistic input data for an AI system.
892
892
 
893
893
  ${r?`Task description: ${r}`:""}
894
894
  ${this.options.domain?`Domain: ${this.options.domain}`:""}
895
895
 
896
896
  The system expects these INPUT fields:
897
- ${mu(t)}
897
+ ${Rl(t)}
898
898
 
899
899
  The system produces these OUTPUT fields:
900
- ${um(n)}
900
+ ${Xm(n)}
901
901
 
902
902
  Generate ${e} diverse, realistic input examples as a JSON array.
903
903
  Each example should be an object with the input fields defined above.
904
904
  Make the examples varied and realistic for the domain.
905
905
 
906
906
  Output ONLY the JSON array, no explanation.
907
- `.trim(),i=new ke("count:number -> examples:json");i.setInstruction(s);try{let a=await i.forward(this.options.teacher,{count:e},{model:this.options.model});return Array.isArray(a.examples)?a.examples.slice(0,e):[]}catch(a){return console.warn("AxSynth: Input generation failed:",a),[]}}async generateEdgeCaseInputs(e){let t=this.signature.getInputFields(),n=this.options.edgeCases??[],r=`
907
+ `.trim(),i=new Pe("count:number -> examples:json");i.setInstruction(s);try{let a=await i.forward(this.options.teacher,{count:e},{model:this.options.model});return Array.isArray(a.examples)?a.examples.slice(0,e):[]}catch(a){return console.warn("AxSynth: Input generation failed:",a),[]}}async generateEdgeCaseInputs(e){let t=this.signature.getInputFields(),n=this.options.edgeCases??[],r=`
908
908
  You are generating challenging edge case input data to test an AI system's robustness.
909
909
 
910
910
  The system expects these INPUT fields:
911
- ${mu(t)}
911
+ ${Rl(t)}
912
912
 
913
913
  Generate ${e} edge case examples as a JSON array.
914
914
  Focus on these types of edge cases:
@@ -916,7 +916,7 @@ ${n.map(i=>`- ${i}`).join(`
916
916
  `)}
917
917
 
918
918
  Output ONLY the JSON array, no explanation.
919
- `.trim(),s=new ke("count:number -> examples:json");s.setInstruction(r);try{let i=await s.forward(this.options.teacher,{count:e},{model:this.options.model});return Array.isArray(i.examples)?i.examples.slice(0,e):[]}catch(i){return console.warn("AxSynth: Edge case generation failed:",i),[]}}async labelInput(e){return await new ke(this.signature).forward(this.options.teacher,e,{model:this.options.model})}getSignature(){return this.signature}getTeacher(){return this.options.teacher}};var pm={excellent:1,good:.8,acceptable:.5,poor:.2,unacceptable:0};function dm(o){let{ai:e,criteria:t,description:n,randomizeOrder:r,...s}=o;return{...s,maxSteps:1}}function mm(o){if(o==null)return!1;if(typeof o=="string"||typeof o=="number"||typeof o=="boolean"||Array.isArray(o)&&o.every(e=>typeof e!="object"))return!0;if(typeof o=="object"){let e=Object.values(o);return e.length>0&&e.every(t=>t==null?!1:typeof t=="string"||typeof t=="number"||typeof t=="boolean"?!0:Array.isArray(t)?t.every(n=>typeof n!="object"):!1)}return!1}function gm(o,e){return o===e?!0:typeof o!=typeof e?!1:typeof o=="object"&&o!==null&&e!==null?JSON.stringify(o)===JSON.stringify(e):!1}function fm(o,e,t){let n=o.getOutputFields(),r=0,s=0;for(let i of n){let a=e[i.name],l=t[i.name];l!==void 0&&(s+=1,gm(a,l)&&(r+=1))}return s>0?r/s:0}function hm(o,e){let t=new ke(`
919
+ `.trim(),s=new Pe("count:number -> examples:json");s.setInstruction(r);try{let i=await s.forward(this.options.teacher,{count:e},{model:this.options.model});return Array.isArray(i.examples)?i.examples.slice(0,e):[]}catch(i){return console.warn("AxSynth: Edge case generation failed:",i),[]}}async labelInput(e){return await new Pe(this.signature).forward(this.options.teacher,e,{model:this.options.model})}getSignature(){return this.signature}getTeacher(){return this.options.teacher}};var Zm={excellent:1,good:.8,acceptable:.5,poor:.2,unacceptable:0};function eg(o){let{ai:e,criteria:t,description:n,randomizeOrder:r,...s}=o;return{...s,maxSteps:1}}function tg(o){if(o==null)return!1;if(typeof o=="string"||typeof o=="number"||typeof o=="boolean"||Array.isArray(o)&&o.every(e=>typeof e!="object"))return!0;if(typeof o=="object"){let e=Object.values(o);return e.length>0&&e.every(t=>t==null?!1:typeof t=="string"||typeof t=="number"||typeof t=="boolean"?!0:Array.isArray(t)?t.every(n=>typeof n!="object"):!1)}return!1}function ng(o,e){return o===e?!0:typeof o!=typeof e?!1:typeof o=="object"&&o!==null&&e!==null?JSON.stringify(o)===JSON.stringify(e):!1}function rg(o,e,t){let n=o.getOutputFields(),r=0,s=0;for(let i of n){let a=e[i.name],u=t[i.name];u!==void 0&&(s+=1,ng(a,u)&&(r+=1))}return s>0?r/s:0}function og(o,e){let t=new Pe(`
920
920
  task_input:string "The original task input encoded as JSON",
921
921
  task_description?:string "Optional task description from the program signature",
922
922
  criteria?:string "Optional evaluation guidance",
@@ -924,7 +924,7 @@ Output ONLY the JSON array, no explanation.
924
924
  ->
925
925
  reasoning:string "Short explanation of the quality assessment",
926
926
  quality:class "excellent, good, acceptable, poor, unacceptable" "Overall quality tier"
927
- `),n=new ke(`
927
+ `),n=new Pe(`
928
928
  task_input:string "The original task input encoded as JSON",
929
929
  task_description?:string "Optional task description from the program signature",
930
930
  criteria?:string "Optional evaluation guidance",
@@ -933,11 +933,11 @@ Output ONLY the JSON array, no explanation.
933
933
  ->
934
934
  reasoning:string "Short explanation of which output is better",
935
935
  winner:class "A, B, Tie" "Which output is better overall"
936
- `),r=e.description?.trim();r&&(t.setInstruction(r),n.setInstruction(r));let s=dm(e),i=o.getDescription();return async({example:a,prediction:l})=>{let c={};for(let g of o.getInputFields())g.name in a&&(c[g.name]=a[g.name]);let u={},p=!1;for(let g of o.getOutputFields())g.name in a&&(u[g.name]=a[g.name],p=!0);let d=l;if(p&&mm(u))return fm(o,d,u);if(p){let f=e.randomizeOrder??!0?Math.random()>.5:!0,A=(await n.forward(e.ai,{task_input:JSON.stringify(c),task_description:i,criteria:e.criteria,system_output_a:JSON.stringify(f?d:u),system_output_b:JSON.stringify(f?u:d)},s)).winner.toUpperCase();return A==="TIE"?.5:A==="A"?f?1:0:A==="B"?f?0:1:.5}let m=await t.forward(e.ai,{task_input:JSON.stringify(c),task_description:i,criteria:e.criteria,system_output:JSON.stringify(d)},s);return pm[m.quality.toLowerCase()]??.5}}var xm="batch",da={feedbackWindowSize:25,maxRecentTraces:100,updateBudget:4},Ts=class o{gen;options;tracer;currentScore;currentState;readyPromise;playbookOptimizer;constructor(e,t){this.gen=e,this.options={...t,enableTracing:t.enableTracing??!0,mode:t.mode??xm,continuousOptions:{feedbackWindowSize:t.continuousOptions?.feedbackWindowSize??da.feedbackWindowSize,maxRecentTraces:t.continuousOptions?.maxRecentTraces??da.maxRecentTraces,updateBudget:t.continuousOptions?.updateBudget??da.updateBudget}},this.tracer=new Wn(e,{name:this.options.name,storage:this.options.storage,metadata:this.options.metadata,onTrace:this.options.onTrace}),this.readyPromise=this.loadLatestCheckpoint()}async ready(){await this.readyPromise}async forward(e,t,n){return await this.ready(),this.options.enableTracing?this.tracer.forward(e,t,n):this.gen.forward(e,t,n)}async*streamingForward(e,t,n){await this.ready(),this.options.enableTracing?yield*this.tracer.streamingForward(e,t,n):yield*this.gen.streamingForward(e,t,n)}getUsage(){return this.gen.getUsage()}resetUsage(){this.gen.resetUsage()}getSignature(){return this.gen.getSignature()}setInstruction(e){this.gen.setInstruction(e)}getInstruction(){return this.currentState?.mode==="playbook"||this.options.mode==="playbook"?this.currentState?.instruction??this.gen.getSignature().getDescription()??this.gen.getInstruction():this.gen.getInstruction()}updateMeter(e){this.gen.updateMeter(e)}addAssert(e,t){this.gen.addAssert(e,t)}addStreamingAssert(e,t,n){this.gen.addStreamingAssert(e,t,n)}addFieldProcessor(e,t){this.gen.addFieldProcessor(e,t)}addStreamingFieldProcessor(e,t){this.gen.addStreamingFieldProcessor(e,t)}clone(){return new o(this.gen.clone(),this.options)}async optimize(e={}){await this.ready();let t=this.mergeConfig(e);return t.mode==="playbook"?this.optimizePlaybook(t):(await this.runPromptOptimization(t)).result}async applyUpdate(e,t={}){await this.ready();let n=this.mergeConfig(t),r=n.mode==="continuous"?{...n,budget:t.budget??n.continuousOptions.updateBudget}:n;if(r.mode==="batch")throw new Error("AxLearn: applyUpdate() is only available in continuous or playbook modes");return r.mode==="playbook"?this.applyPlaybookUpdate(r,e):(await this.runPromptOptimization(r,e)).result}getGen(){return this.gen}getStorage(){return this.options.storage}async getTraces(e){return await this.ready(),this.options.storage.load(this.options.name,{type:"trace",...e})}async addFeedback(e,t){await this.ready();let r=(await this.options.storage.load(this.options.name,{type:"trace"})).find(s=>s.id===e);r&&(r.feedback={...r.feedback,...t},await this.options.storage.save(this.options.name,r))}createPromptOptimizer(e,t){return new Ht({studentAI:this.requireRuntimeAI(e.runtimeAI),teacherAI:e.teacher,numTrials:e.budget,minibatch:!0,minibatchSize:10,onProgress:this.createOptimizerProgressHandler(t,e.onProgress)})}createPlaybookOptimizer(e,t){return new Vn({studentAI:this.requireRuntimeAI(e.runtimeAI),teacherAI:e.teacher,onProgress:this.createOptimizerProgressHandler(t,e.onProgress)},e.playbookOptions)}mergeConfig(e){return{runtimeAI:e.runtimeAI??this.options.runtimeAI,mode:this.options.mode,teacher:this.options.teacher,budget:e.budget??this.options.budget??20,metric:e.metric??this.options.metric,judgeOptions:e.judgeOptions??this.options.judgeOptions,criteria:e.criteria??this.options.criteria,examples:e.examples??this.options.examples,useTraces:e.useTraces??this.options.useTraces??!0,generateExamples:e.generateExamples??this.options.generateExamples??!1,synthCount:e.synthCount??this.options.synthCount,synthOptions:e.synthOptions??this.options.synthOptions,validationSplit:e.validationSplit??this.options.validationSplit??.2,continuousOptions:{feedbackWindowSize:e.continuousOptions?.feedbackWindowSize??this.options.continuousOptions.feedbackWindowSize,maxRecentTraces:e.continuousOptions?.maxRecentTraces??this.options.continuousOptions.maxRecentTraces,updateBudget:e.continuousOptions?.updateBudget??this.options.continuousOptions.updateBudget},playbookOptions:e.playbookOptions??this.options.playbookOptions,onProgress:e.onProgress??this.options.onProgress}}requireRuntimeAI(e){if(e)return e;throw new Error("AxLearn: runtimeAI is required for optimize()/applyUpdate(). Provide it in the constructor or per-call overrides.")}createOptimizerProgressHandler(e,t){if(t)return n=>{t({round:n.round,totalRounds:n.totalRounds,score:n.bestScore,improvement:n.bestScore-e})}}async resolveMetric(e){if(e.metric)return e.metric;let t={ai:e.teacher,criteria:e.criteria,...e.judgeOptions};return hm(this.gen.getSignature(),t)}async runPromptOptimization(e,t){let n=Date.now(),r=this.currentScore??0,s=e.budget,i=await this.resolveMetric(e),a=await this.prepareDataset(e,t);if(a.examples.length<2)throw new Error("AxLearn: at least 2 usable examples are required after filtering traces/examples.");if(t!==void 0&&e.mode==="continuous"&&a.feedbackExamples.length===0)throw new Error("AxLearn: continuous updates require explicit feedback or stored feedback-bearing traces.");let{trainingExamples:l,validationExamples:c}=this.splitExamples(a.examples,a.feedbackScoredExamples,e.validationSplit,e.mode),p=await this.createPromptOptimizer({...e,budget:s},r).compile(this.gen,l,i,{validationExamples:c,feedbackExamples:a.feedbackExamples.length>0?a.feedbackExamples:void 0,feedbackFn:a.feedbackTextByKey.size>0?({example:A})=>a.feedbackTextByKey.get(this.exampleKey(A)):void 0,feedbackNotes:a.feedbackNotes.length>0?a.feedbackNotes:void 0,maxMetricCalls:this.computeMetricBudget(s,c.length)});if(!p.optimizedProgram)throw new Error("AxLearn: prompt optimization failed with no result");this.gen.applyOptimization?.(p.optimizedProgram),this.currentScore=p.optimizedProgram.bestScore,this.tracer=this.tracer.clone(this.gen);let d=this.createPromptState(e.mode,this.currentScore,a.feedbackExamples.length),m={feedbackExamples:a.feedbackExamples.length,lastUpdateAt:d.continuous?.lastUpdateAt},g={trainingExamples:l.length,validationExamples:c.length,feedbackExamples:a.feedbackExamples.length,durationMs:Date.now()-n},f=await this.saveCheckpoint({mode:e.mode,score:this.currentScore,state:d,stats:g,budget:s});return{result:{mode:e.mode,score:this.currentScore,improvement:this.currentScore-r,checkpointVersion:f,stats:{...g,mode:e.mode},state:d,artifact:m},optimizedProgram:p.optimizedProgram}}async optimizePlaybook(e){let t=Date.now();this.requireRuntimeAI(e.runtimeAI);let n=this.currentScore??0,r=await this.resolveMetric(e),s=await this.prepareDataset(e);if(s.examples.length<2)throw new Error("AxLearn: at least 2 usable examples are required for playbook mode.");let{trainingExamples:i,validationExamples:a}=this.splitExamples(s.examples,s.feedbackExamples,e.validationSplit,e.mode),l=this.createPlaybookOptimizer(e,n),c=await l.compile(this.gen,i,r,{aceOptions:e.playbookOptions});c.optimizedProgram?.applyTo(this.gen),this.playbookOptimizer=l,this.currentScore=c.bestScore,this.tracer=this.tracer.clone(this.gen);let u=c.playbook,p=c.artifact,d=this.summarizePlaybookArtifact(p),m=this.createPlaybookState(u,d,l.getBaseInstruction()),g={trainingExamples:i.length,validationExamples:a.length,feedbackExamples:s.feedbackExamples.length,durationMs:Date.now()-t},f=await this.saveCheckpoint({mode:"playbook",score:this.currentScore,state:m,stats:g,budget:e.budget});return{mode:"playbook",score:this.currentScore,improvement:this.currentScore-n,checkpointVersion:f,stats:{...g,mode:"playbook"},state:m,artifact:{playbook:u,playbookSummary:d,feedbackExamples:s.feedbackExamples.length}}}async applyPlaybookUpdate(e,t){let n=Date.now();this.requireRuntimeAI(e.runtimeAI);let r=this.currentScore??0,s=this.getOrCreatePlaybookOptimizer(e,r);await s.applyOnlineUpdate({example:t.example,prediction:t.prediction,feedback:this.feedbackToText(t.feedback)}),s.applyCurrentState(this.gen),this.tracer=this.tracer.clone(this.gen);let i=s.getArtifact(),a=s.getPlaybook(),l=this.summarizePlaybookArtifact(i),c=this.createPlaybookState(a,l,s.getBaseInstruction()),u=this.currentScore??r,p={trainingExamples:1,validationExamples:1,feedbackExamples:1,durationMs:Date.now()-n},d=await this.saveCheckpoint({mode:"playbook",score:u,state:c,stats:p,budget:e.playbookOptions?.maxEpochs});return e.onProgress?.({round:1,totalRounds:1,score:u,improvement:u-r}),{mode:"playbook",score:u,improvement:u-r,checkpointVersion:d,stats:{...p,mode:"playbook"},state:c,artifact:{playbook:a,playbookSummary:l,feedbackExamples:1}}}getOrCreatePlaybookOptimizer(e,t){return this.playbookOptimizer||(this.playbookOptimizer=this.createPlaybookOptimizer(e,t),this.playbookOptimizer.hydrate(this.gen,{baseInstruction:this.currentState?.baseInstruction??this.gen.getSignature().getDescription()??void 0,playbook:this.currentState?.playbook})),this.playbookOptimizer}async prepareDataset(e,t){let n=[],r=[],s=[],i=new Map,a=[],l=new Set,c=new Set,u=new Set,p=(d,m)=>{let g=this.normalizeExample(d);if(!g)return;let f=this.hasInputFields(g),x=this.hasOutputFields(g);if(!f||m?.requireOutput&&!x)return;let A=this.exampleKey(g);m?.includeInExamples!==!1&&!l.has(A)&&(l.add(A),n.push(g));let b=m?.feedback?.trim();if(b){let T=i.get(A);T?T!==b&&i.set(A,`${T}
937
- ${b}`):i.set(A,b),m?.includeInFeedbackSet!==!1&&!c.has(A)&&(r.push(g),c.add(A)),m?.feedbackEligibleForScoring&&!u.has(A)&&(s.push(g),u.add(A))}return g};for(let d of e.examples??[])p(d);if(e.useTraces){let d=await this.loadRelevantTraces(e);for(let m of d)p(m.example,{feedback:m.feedback,requireOutput:!0,feedbackEligibleForScoring:!0})}if(t){let d=this.feedbackToText(t.feedback),m=t.example,g=this.hasOutputFields(m),f=this.buildObservedUpdateExample(m,t.prediction);if(d&&f){p(f,{feedback:d,requireOutput:!0,includeInExamples:!1,feedbackEligibleForScoring:!1});let x=this.formatObservedUpdateFeedback(m,t.prediction,d);x&&a.push(x)}g&&p(m,{feedback:d,feedbackEligibleForScoring:!0})}if(e.generateExamples||n.length===0){let d=e.synthCount??20,g=await new Qn(this.gen.getSignature(),{teacher:e.teacher,...e.synthOptions}).generate(d);for(let f of g.examples)p({...f.input,...f.expected})}return e.mode==="continuous"&&s.length>0?{examples:[...s,...n.filter(m=>!s.some(g=>this.exampleKey(g)===this.exampleKey(m)))],feedbackExamples:r.slice(0,e.continuousOptions.feedbackWindowSize),feedbackScoredExamples:s.slice(0,e.continuousOptions.feedbackWindowSize),feedbackTextByKey:i,feedbackNotes:a}:{examples:n,feedbackExamples:r.slice(0,e.continuousOptions.feedbackWindowSize),feedbackScoredExamples:s.slice(0,e.continuousOptions.feedbackWindowSize),feedbackTextByKey:i,feedbackNotes:a}}async loadRelevantTraces(e){let n=[...await this.options.storage.load(this.options.name,{type:"trace"})].sort((i,a)=>{let l=new Date(i.endTime??i.startTime).getTime();return new Date(a.endTime??a.startTime).getTime()-l}),r=e.mode==="continuous"?n.slice(0,e.continuousOptions.maxRecentTraces):n,s=new Map;for(let i of r){if(i.error)continue;let a=this.normalizeExample({...i.input??{},...i.output??{}});if(!a||!this.hasOutputFields(a))continue;let l=this.exampleKey(a),c=this.feedbackToText(i.feedback),u=s.get(l);if(!u){s.set(l,{example:a,feedback:c});continue}!u.feedback&&c&&(u.feedback=c)}return[...s.values()]}normalizeExample(e){let t={},n=this.gen.getSignature(),r=[...n.getInputFields(),...n.getOutputFields()];for(let s of r)s.name in e&&e[s.name]!==void 0&&(t[s.name]=e[s.name]);if(Object.keys(t).length!==0)return t}buildObservedUpdateExample(e,t){return this.normalizeExample({...this.pickInputFields(e),...this.pickOutputFields(t)})}pickInputFields(e){let t={};for(let n of this.gen.getSignature().getInputFields())e[n.name]!==void 0&&(t[n.name]=e[n.name]);return t}pickOutputFields(e){let t={};for(let n of this.gen.getSignature().getOutputFields())e[n.name]!==void 0&&(t[n.name]=e[n.name]);return t}hasInputFields(e){return this.gen.getSignature().getInputFields().some(t=>e[t.name]!==void 0)}hasOutputFields(e){return this.gen.getSignature().getOutputFields().some(t=>e[t.name]!==void 0)}exampleKey(e){let t=this.gen.getSignature(),r=[...t.getInputFields(),...t.getOutputFields()].map(s=>s.name).reduce((s,i)=>(e[i]!==void 0&&(s[i]=e[i]),s),{});return JSON.stringify(r)}feedbackToText(e){if(!e)return;if(typeof e=="string")return e.trim()||void 0;let t=[];return typeof e.score=="number"&&t.push(`User score: ${e.score}.`),e.label&&t.push(`User label: ${e.label}.`),e.comment&&t.push(e.comment.trim()),t.join(" ").trim()||void 0}formatObservedUpdateFeedback(e,t,n){let r=this.pickInputFields(e),s=this.pickOutputFields(t);return["Observed continuous update event.",`Inputs: ${JSON.stringify(r)}`,`Observed output: ${JSON.stringify(s)}`,`User feedback: ${n}`].join(`
938
- `)}splitExamples(e,t,n,r){let s=this.shuffleExamples(e),i=Number.isFinite(n)?Math.min(Math.max(n,.05),.5):.2,a=Math.min(s.length-1,Math.max(1,Math.round(s.length*i)));if(r==="continuous"&&t.length>0){let l=new Set(t.map(p=>this.exampleKey(p))),c=[];for(let p of s)!l.has(this.exampleKey(p))&&c.length<a&&c.push(p);for(let p of s){if(c.length>=a)break;c.some(d=>this.exampleKey(d)===this.exampleKey(p))||c.push(p)}let u=new Set(c.map(p=>this.exampleKey(p)));return{trainingExamples:s.filter(p=>!u.has(this.exampleKey(p))),validationExamples:c}}return{trainingExamples:s.slice(0,s.length-a),validationExamples:s.slice(s.length-a)}}shuffleExamples(e){let t=[...e];for(let n=t.length-1;n>0;n-=1){let r=Math.floor(Math.random()*(n+1));[t[n],t[r]]=[t[r],t[n]]}return t}computeMetricBudget(e,t){let n=Math.max(e,1),r=Math.max(t,1);return Math.max(r*(n+2),20)}createPromptState(e,t,n){let r=this.gen.getInstruction(),s={mode:e,instruction:r,baseInstruction:r,score:t};return e==="continuous"&&(s.continuous={feedbackTraceCount:n,lastUpdateAt:new Date().toISOString()}),this.currentState=s,s}createPlaybookState(e,t,n){let r=this.gen.getSignature().getDescription()??this.gen.getInstruction(),s={mode:"playbook",instruction:r,baseInstruction:n??this.currentState?.baseInstruction??r,score:this.currentScore,playbook:e,artifactSummary:t};return this.currentState=s,s}summarizePlaybookArtifact(e){return{feedbackEvents:e.feedback.length,historyBatches:e.history.length,bulletCount:e.playbook.stats.bulletCount,updatedAt:e.playbook.updatedAt}}async saveCheckpoint(e){let r=(await this.options.storage.load(this.options.name,{type:"checkpoint"})).reduce((i,a)=>Math.max(i,a.version??0),0)+1,s={type:"checkpoint",name:this.options.name,version:r,createdAt:new Date,instruction:e.state.instruction??this.gen.getInstruction(),score:e.score,optimizerType:"learn",learnState:e.state,metadata:{mode:e.mode,budget:e.budget,trainingExamples:e.stats.trainingExamples,validationExamples:e.stats.validationExamples,feedbackExamples:e.stats.feedbackExamples,durationMs:e.stats.durationMs}};return await this.options.storage.save(this.options.name,s),this.currentScore=e.score,this.currentState=e.state,r}async loadLatestCheckpoint(){try{let e=await this.options.storage.load(this.options.name,{type:"checkpoint"});if(e.length===0)return;let t=[...e].sort((r,s)=>{let i=(s.version??0)-(r.version??0);return i!==0?i:new Date(s.createdAt).getTime()-new Date(r.createdAt).getTime()})[0];if(!t)return;let n=t.learnState?.instruction??t.instruction??void 0;t.learnState?.mode==="playbook"&&t.learnState.playbook?this.applyRestoredPlaybook(t.learnState.playbook,t.learnState.baseInstruction,n):n&&this.gen.setInstruction(n),this.currentScore=t.learnState?.score??t.score,this.currentState=t.learnState,t.learnState?.mode==="playbook"&&(this.playbookOptimizer=void 0),this.tracer=this.tracer.clone(this.gen)}catch{}}applyRestoredPlaybook(e,t,n){let s=[(t??this.gen.getSignature().getDescription()??n??"").trim(),"",sn(e)].filter(i=>i&&i.trim().length>0).join(`
936
+ `),r=e.description?.trim();r&&(t.setInstruction(r),n.setInstruction(r));let s=eg(e),i=o.getDescription();return async({example:a,prediction:u})=>{let c={};for(let g of o.getInputFields())g.name in a&&(c[g.name]=a[g.name]);let l={},p=!1;for(let g of o.getOutputFields())g.name in a&&(l[g.name]=a[g.name],p=!0);let d=u;if(p&&tg(l))return rg(o,d,l);if(p){let f=e.randomizeOrder??!0?Math.random()>.5:!0,A=(await n.forward(e.ai,{task_input:JSON.stringify(c),task_description:i,criteria:e.criteria,system_output_a:JSON.stringify(f?d:l),system_output_b:JSON.stringify(f?l:d)},s)).winner.toUpperCase();return A==="TIE"?.5:A==="A"?f?1:0:A==="B"?f?0:1:.5}let m=await t.forward(e.ai,{task_input:JSON.stringify(c),task_description:i,criteria:e.criteria,system_output:JSON.stringify(d)},s);return Zm[m.quality.toLowerCase()]??.5}}var sg="batch",Aa={feedbackWindowSize:25,maxRecentTraces:100,updateBudget:4},Rs=class o{gen;options;tracer;currentScore;currentState;readyPromise;playbookOptimizer;constructor(e,t){this.gen=e,this.options={...t,enableTracing:t.enableTracing??!0,mode:t.mode??sg,continuousOptions:{feedbackWindowSize:t.continuousOptions?.feedbackWindowSize??Aa.feedbackWindowSize,maxRecentTraces:t.continuousOptions?.maxRecentTraces??Aa.maxRecentTraces,updateBudget:t.continuousOptions?.updateBudget??Aa.updateBudget}},this.tracer=new Qn(e,{name:this.options.name,storage:this.options.storage,metadata:this.options.metadata,onTrace:this.options.onTrace}),this.readyPromise=this.loadLatestCheckpoint()}async ready(){await this.readyPromise}async forward(e,t,n){return await this.ready(),this.options.enableTracing?this.tracer.forward(e,t,n):this.gen.forward(e,t,n)}async*streamingForward(e,t,n){await this.ready(),this.options.enableTracing?yield*this.tracer.streamingForward(e,t,n):yield*this.gen.streamingForward(e,t,n)}getUsage(){return this.gen.getUsage()}resetUsage(){this.gen.resetUsage()}getSignature(){return this.gen.getSignature()}setInstruction(e){this.gen.setInstruction(e)}getInstruction(){return this.currentState?.mode==="playbook"||this.options.mode==="playbook"?this.currentState?.instruction??this.gen.getSignature().getDescription()??this.gen.getInstruction():this.gen.getInstruction()}updateMeter(e){this.gen.updateMeter(e)}addAssert(e,t){this.gen.addAssert(e,t)}addStreamingAssert(e,t,n){this.gen.addStreamingAssert(e,t,n)}addFieldProcessor(e,t){this.gen.addFieldProcessor(e,t)}addStreamingFieldProcessor(e,t){this.gen.addStreamingFieldProcessor(e,t)}clone(){return new o(this.gen.clone(),this.options)}async optimize(e={}){await this.ready();let t=this.mergeConfig(e);return t.mode==="playbook"?this.optimizePlaybook(t):(await this.runPromptOptimization(t)).result}async applyUpdate(e,t={}){await this.ready();let n=this.mergeConfig(t),r=n.mode==="continuous"?{...n,budget:t.budget??n.continuousOptions.updateBudget}:n;if(r.mode==="batch")throw new Error("AxLearn: applyUpdate() is only available in continuous or playbook modes");return r.mode==="playbook"?this.applyPlaybookUpdate(r,e):(await this.runPromptOptimization(r,e)).result}getGen(){return this.gen}getStorage(){return this.options.storage}async getTraces(e){return await this.ready(),this.options.storage.load(this.options.name,{type:"trace",...e})}async addFeedback(e,t){await this.ready();let r=(await this.options.storage.load(this.options.name,{type:"trace"})).find(s=>s.id===e);r&&(r.feedback={...r.feedback,...t},await this.options.storage.save(this.options.name,r))}createPromptOptimizer(e,t){return new Wt({studentAI:this.requireRuntimeAI(e.runtimeAI),teacherAI:e.teacher,numTrials:e.budget,minibatch:!0,minibatchSize:10,onProgress:this.createOptimizerProgressHandler(t,e.onProgress)})}createPlaybookOptimizer(e,t){return new Yn({studentAI:this.requireRuntimeAI(e.runtimeAI),teacherAI:e.teacher,onProgress:this.createOptimizerProgressHandler(t,e.onProgress)},e.playbookOptions)}mergeConfig(e){return{runtimeAI:e.runtimeAI??this.options.runtimeAI,mode:this.options.mode,teacher:this.options.teacher,budget:e.budget??this.options.budget??20,metric:e.metric??this.options.metric,judgeOptions:e.judgeOptions??this.options.judgeOptions,criteria:e.criteria??this.options.criteria,examples:e.examples??this.options.examples,useTraces:e.useTraces??this.options.useTraces??!0,generateExamples:e.generateExamples??this.options.generateExamples??!1,synthCount:e.synthCount??this.options.synthCount,synthOptions:e.synthOptions??this.options.synthOptions,validationSplit:e.validationSplit??this.options.validationSplit??.2,continuousOptions:{feedbackWindowSize:e.continuousOptions?.feedbackWindowSize??this.options.continuousOptions.feedbackWindowSize,maxRecentTraces:e.continuousOptions?.maxRecentTraces??this.options.continuousOptions.maxRecentTraces,updateBudget:e.continuousOptions?.updateBudget??this.options.continuousOptions.updateBudget},playbookOptions:e.playbookOptions??this.options.playbookOptions,onProgress:e.onProgress??this.options.onProgress}}requireRuntimeAI(e){if(e)return e;throw new Error("AxLearn: runtimeAI is required for optimize()/applyUpdate(). Provide it in the constructor or per-call overrides.")}createOptimizerProgressHandler(e,t){if(t)return n=>{t({round:n.round,totalRounds:n.totalRounds,score:n.bestScore,improvement:n.bestScore-e})}}async resolveMetric(e){if(e.metric)return e.metric;let t={ai:e.teacher,criteria:e.criteria,...e.judgeOptions};return og(this.gen.getSignature(),t)}async runPromptOptimization(e,t){let n=Date.now(),r=this.currentScore??0,s=e.budget,i=await this.resolveMetric(e),a=await this.prepareDataset(e,t);if(a.examples.length<2)throw new Error("AxLearn: at least 2 usable examples are required after filtering traces/examples.");if(t!==void 0&&e.mode==="continuous"&&a.feedbackExamples.length===0)throw new Error("AxLearn: continuous updates require explicit feedback or stored feedback-bearing traces.");let{trainingExamples:u,validationExamples:c}=this.splitExamples(a.examples,a.feedbackScoredExamples,e.validationSplit,e.mode),p=await this.createPromptOptimizer({...e,budget:s},r).compile(this.gen,u,i,{validationExamples:c,feedbackExamples:a.feedbackExamples.length>0?a.feedbackExamples:void 0,feedbackFn:a.feedbackTextByKey.size>0?({example:A})=>a.feedbackTextByKey.get(this.exampleKey(A)):void 0,feedbackNotes:a.feedbackNotes.length>0?a.feedbackNotes:void 0,maxMetricCalls:this.computeMetricBudget(s,c.length)});if(!p.optimizedProgram)throw new Error("AxLearn: prompt optimization failed with no result");this.gen.applyOptimization?.(p.optimizedProgram),this.currentScore=p.optimizedProgram.bestScore,this.tracer=this.tracer.clone(this.gen);let d=this.createPromptState(e.mode,this.currentScore,a.feedbackExamples.length),m={feedbackExamples:a.feedbackExamples.length,lastUpdateAt:d.continuous?.lastUpdateAt},g={trainingExamples:u.length,validationExamples:c.length,feedbackExamples:a.feedbackExamples.length,durationMs:Date.now()-n},f=await this.saveCheckpoint({mode:e.mode,score:this.currentScore,state:d,stats:g,budget:s});return{result:{mode:e.mode,score:this.currentScore,improvement:this.currentScore-r,checkpointVersion:f,stats:{...g,mode:e.mode},state:d,artifact:m},optimizedProgram:p.optimizedProgram}}async optimizePlaybook(e){let t=Date.now();this.requireRuntimeAI(e.runtimeAI);let n=this.currentScore??0,r=await this.resolveMetric(e),s=await this.prepareDataset(e);if(s.examples.length<2)throw new Error("AxLearn: at least 2 usable examples are required for playbook mode.");let{trainingExamples:i,validationExamples:a}=this.splitExamples(s.examples,s.feedbackExamples,e.validationSplit,e.mode),u=this.createPlaybookOptimizer(e,n),c=await u.compile(this.gen,i,r,{aceOptions:e.playbookOptions});c.optimizedProgram?.applyTo(this.gen),this.playbookOptimizer=u,this.currentScore=c.bestScore,this.tracer=this.tracer.clone(this.gen);let l=c.playbook,p=c.artifact,d=this.summarizePlaybookArtifact(p),m=this.createPlaybookState(l,d,u.getBaseInstruction()),g={trainingExamples:i.length,validationExamples:a.length,feedbackExamples:s.feedbackExamples.length,durationMs:Date.now()-t},f=await this.saveCheckpoint({mode:"playbook",score:this.currentScore,state:m,stats:g,budget:e.budget});return{mode:"playbook",score:this.currentScore,improvement:this.currentScore-n,checkpointVersion:f,stats:{...g,mode:"playbook"},state:m,artifact:{playbook:l,playbookSummary:d,feedbackExamples:s.feedbackExamples.length}}}async applyPlaybookUpdate(e,t){let n=Date.now();this.requireRuntimeAI(e.runtimeAI);let r=this.currentScore??0,s=this.getOrCreatePlaybookOptimizer(e,r);await s.applyOnlineUpdate({example:t.example,prediction:t.prediction,feedback:this.feedbackToText(t.feedback)}),s.applyCurrentState(this.gen),this.tracer=this.tracer.clone(this.gen);let i=s.getArtifact(),a=s.getPlaybook(),u=this.summarizePlaybookArtifact(i),c=this.createPlaybookState(a,u,s.getBaseInstruction()),l=this.currentScore??r,p={trainingExamples:1,validationExamples:1,feedbackExamples:1,durationMs:Date.now()-n},d=await this.saveCheckpoint({mode:"playbook",score:l,state:c,stats:p,budget:e.playbookOptions?.maxEpochs});return e.onProgress?.({round:1,totalRounds:1,score:l,improvement:l-r}),{mode:"playbook",score:l,improvement:l-r,checkpointVersion:d,stats:{...p,mode:"playbook"},state:c,artifact:{playbook:a,playbookSummary:u,feedbackExamples:1}}}getOrCreatePlaybookOptimizer(e,t){return this.playbookOptimizer||(this.playbookOptimizer=this.createPlaybookOptimizer(e,t),this.playbookOptimizer.hydrate(this.gen,{baseInstruction:this.currentState?.baseInstruction??this.gen.getSignature().getDescription()??void 0,playbook:this.currentState?.playbook})),this.playbookOptimizer}async prepareDataset(e,t){let n=[],r=[],s=[],i=new Map,a=[],u=new Set,c=new Set,l=new Set,p=(d,m)=>{let g=this.normalizeExample(d);if(!g)return;let f=this.hasInputFields(g),x=this.hasOutputFields(g);if(!f||m?.requireOutput&&!x)return;let A=this.exampleKey(g);m?.includeInExamples!==!1&&!u.has(A)&&(u.add(A),n.push(g));let y=m?.feedback?.trim();if(y){let C=i.get(A);C?C!==y&&i.set(A,`${C}
937
+ ${y}`):i.set(A,y),m?.includeInFeedbackSet!==!1&&!c.has(A)&&(r.push(g),c.add(A)),m?.feedbackEligibleForScoring&&!l.has(A)&&(s.push(g),l.add(A))}return g};for(let d of e.examples??[])p(d);if(e.useTraces){let d=await this.loadRelevantTraces(e);for(let m of d)p(m.example,{feedback:m.feedback,requireOutput:!0,feedbackEligibleForScoring:!0})}if(t){let d=this.feedbackToText(t.feedback),m=t.example,g=this.hasOutputFields(m),f=this.buildObservedUpdateExample(m,t.prediction);if(d&&f){p(f,{feedback:d,requireOutput:!0,includeInExamples:!1,feedbackEligibleForScoring:!1});let x=this.formatObservedUpdateFeedback(m,t.prediction,d);x&&a.push(x)}g&&p(m,{feedback:d,feedbackEligibleForScoring:!0})}if(e.generateExamples||n.length===0){let d=e.synthCount??20,g=await new Zn(this.gen.getSignature(),{teacher:e.teacher,...e.synthOptions}).generate(d);for(let f of g.examples)p({...f.input,...f.expected})}return e.mode==="continuous"&&s.length>0?{examples:[...s,...n.filter(m=>!s.some(g=>this.exampleKey(g)===this.exampleKey(m)))],feedbackExamples:r.slice(0,e.continuousOptions.feedbackWindowSize),feedbackScoredExamples:s.slice(0,e.continuousOptions.feedbackWindowSize),feedbackTextByKey:i,feedbackNotes:a}:{examples:n,feedbackExamples:r.slice(0,e.continuousOptions.feedbackWindowSize),feedbackScoredExamples:s.slice(0,e.continuousOptions.feedbackWindowSize),feedbackTextByKey:i,feedbackNotes:a}}async loadRelevantTraces(e){let n=[...await this.options.storage.load(this.options.name,{type:"trace"})].sort((i,a)=>{let u=new Date(i.endTime??i.startTime).getTime();return new Date(a.endTime??a.startTime).getTime()-u}),r=e.mode==="continuous"?n.slice(0,e.continuousOptions.maxRecentTraces):n,s=new Map;for(let i of r){if(i.error)continue;let a=this.normalizeExample({...i.input??{},...i.output??{}});if(!a||!this.hasOutputFields(a))continue;let u=this.exampleKey(a),c=this.feedbackToText(i.feedback),l=s.get(u);if(!l){s.set(u,{example:a,feedback:c});continue}!l.feedback&&c&&(l.feedback=c)}return[...s.values()]}normalizeExample(e){let t={},n=this.gen.getSignature(),r=[...n.getInputFields(),...n.getOutputFields()];for(let s of r)s.name in e&&e[s.name]!==void 0&&(t[s.name]=e[s.name]);if(Object.keys(t).length!==0)return t}buildObservedUpdateExample(e,t){return this.normalizeExample({...this.pickInputFields(e),...this.pickOutputFields(t)})}pickInputFields(e){let t={};for(let n of this.gen.getSignature().getInputFields())e[n.name]!==void 0&&(t[n.name]=e[n.name]);return t}pickOutputFields(e){let t={};for(let n of this.gen.getSignature().getOutputFields())e[n.name]!==void 0&&(t[n.name]=e[n.name]);return t}hasInputFields(e){return this.gen.getSignature().getInputFields().some(t=>e[t.name]!==void 0)}hasOutputFields(e){return this.gen.getSignature().getOutputFields().some(t=>e[t.name]!==void 0)}exampleKey(e){let t=this.gen.getSignature(),r=[...t.getInputFields(),...t.getOutputFields()].map(s=>s.name).reduce((s,i)=>(e[i]!==void 0&&(s[i]=e[i]),s),{});return JSON.stringify(r)}feedbackToText(e){if(!e)return;if(typeof e=="string")return e.trim()||void 0;let t=[];return typeof e.score=="number"&&t.push(`User score: ${e.score}.`),e.label&&t.push(`User label: ${e.label}.`),e.comment&&t.push(e.comment.trim()),t.join(" ").trim()||void 0}formatObservedUpdateFeedback(e,t,n){let r=this.pickInputFields(e),s=this.pickOutputFields(t);return["Observed continuous update event.",`Inputs: ${JSON.stringify(r)}`,`Observed output: ${JSON.stringify(s)}`,`User feedback: ${n}`].join(`
938
+ `)}splitExamples(e,t,n,r){let s=this.shuffleExamples(e),i=Number.isFinite(n)?Math.min(Math.max(n,.05),.5):.2,a=Math.min(s.length-1,Math.max(1,Math.round(s.length*i)));if(r==="continuous"&&t.length>0){let u=new Set(t.map(p=>this.exampleKey(p))),c=[];for(let p of s)!u.has(this.exampleKey(p))&&c.length<a&&c.push(p);for(let p of s){if(c.length>=a)break;c.some(d=>this.exampleKey(d)===this.exampleKey(p))||c.push(p)}let l=new Set(c.map(p=>this.exampleKey(p)));return{trainingExamples:s.filter(p=>!l.has(this.exampleKey(p))),validationExamples:c}}return{trainingExamples:s.slice(0,s.length-a),validationExamples:s.slice(s.length-a)}}shuffleExamples(e){let t=[...e];for(let n=t.length-1;n>0;n-=1){let r=Math.floor(Math.random()*(n+1));[t[n],t[r]]=[t[r],t[n]]}return t}computeMetricBudget(e,t){let n=Math.max(e,1),r=Math.max(t,1);return Math.max(r*(n+2),20)}createPromptState(e,t,n){let r=this.gen.getInstruction(),s={mode:e,instruction:r,baseInstruction:r,score:t};return e==="continuous"&&(s.continuous={feedbackTraceCount:n,lastUpdateAt:new Date().toISOString()}),this.currentState=s,s}createPlaybookState(e,t,n){let r=this.gen.getSignature().getDescription()??this.gen.getInstruction(),s={mode:"playbook",instruction:r,baseInstruction:n??this.currentState?.baseInstruction??r,score:this.currentScore,playbook:e,artifactSummary:t};return this.currentState=s,s}summarizePlaybookArtifact(e){return{feedbackEvents:e.feedback.length,historyBatches:e.history.length,bulletCount:e.playbook.stats.bulletCount,updatedAt:e.playbook.updatedAt}}async saveCheckpoint(e){let r=(await this.options.storage.load(this.options.name,{type:"checkpoint"})).reduce((i,a)=>Math.max(i,a.version??0),0)+1,s={type:"checkpoint",name:this.options.name,version:r,createdAt:new Date,instruction:e.state.instruction??this.gen.getInstruction(),score:e.score,optimizerType:"learn",learnState:e.state,metadata:{mode:e.mode,budget:e.budget,trainingExamples:e.stats.trainingExamples,validationExamples:e.stats.validationExamples,feedbackExamples:e.stats.feedbackExamples,durationMs:e.stats.durationMs}};return await this.options.storage.save(this.options.name,s),this.currentScore=e.score,this.currentState=e.state,r}async loadLatestCheckpoint(){try{let e=await this.options.storage.load(this.options.name,{type:"checkpoint"});if(e.length===0)return;let t=[...e].sort((r,s)=>{let i=(s.version??0)-(r.version??0);return i!==0?i:new Date(s.createdAt).getTime()-new Date(r.createdAt).getTime()})[0];if(!t)return;let n=t.learnState?.instruction??t.instruction??void 0;t.learnState?.mode==="playbook"&&t.learnState.playbook?this.applyRestoredPlaybook(t.learnState.playbook,t.learnState.baseInstruction,n):n&&this.gen.setInstruction(n),this.currentScore=t.learnState?.score??t.score,this.currentState=t.learnState,t.learnState?.mode==="playbook"&&(this.playbookOptimizer=void 0),this.tracer=this.tracer.clone(this.gen)}catch{}}applyRestoredPlaybook(e,t,n){let s=[(t??this.gen.getSignature().getDescription()??n??"").trim(),"",cn(e)].filter(i=>i&&i.trim().length>0).join(`
939
939
 
940
- `);if(typeof this.gen.setDescription=="function"){this.gen.setDescription(s);return}s&&this.gen.setInstruction(s)}};var Cs=class{rows=[];baseUrl;dataset;split;config;options;constructor({dataset:e,split:t,config:n,options:r}){this.baseUrl="https://datasets-server.huggingface.co/rows",this.dataset=e,this.split=t,this.config=n,this.options=r}async fetchDataFromAPI(e){try{let t=await fetch(e);if(!t.ok)throw new Error(`Error fetching data: ${t.statusText}`);let n=await t.json();if(!n?.rows)throw new Error("Invalid data format");return n.rows}catch(t){throw console.error("Error fetching data from API:",t),t}}async loadData(){let e=this.options?.offset??0,t=this.options?.length??100,n=encodeURIComponent(this.dataset),r=`${this.baseUrl}?dataset=${n}&config=${this.config}&split=${this.split}&offset=${e}&length=${t}`;return this.rows=await this.fetchDataFromAPI(r),this.rows}setData(e){this.rows=e}getData(){return this.rows}async getRows({count:e,fields:t,renameMap:n}){if(this.rows.length===0)throw new Error("No data loaded, call loadData or setData first.");return this.rows.slice(0,e).map(s=>{let i={};return t.forEach(a=>{let l=a.split("."),c=s.row;for(let p of l)Object.hasOwn(c,p)&&(c=c[p]);if(!c)return;let u=n&&a in n?n[a]:a;if(!u)throw new Error(`Invalid field name: ${a}`);i[u]=c}),i}).filter(s=>Object.keys(s).length!==0)}};var Yn=class extends Tt{maxRounds;maxDemos;maxExamples;batchSize;earlyStoppingPatience;costMonitoring;maxTokensPerGeneration;verboseMode;debugMode;traces=[];constructor(e){super(e);let t=e.options||{};this.maxRounds=t.maxRounds??3,this.maxDemos=t.maxDemos??4,this.maxExamples=t.maxExamples??16,this.batchSize=t.batchSize??1,this.earlyStoppingPatience=t.earlyStoppingPatience??0,this.costMonitoring=t.costMonitoring??!1,this.maxTokensPerGeneration=t.maxTokensPerGeneration??0,this.verboseMode=t.verboseMode??!0,this.debugMode=t.debugMode??!1}async compileRound(e,t,n,r,s){let i=Date.now(),a=s?.maxDemos??this.maxDemos,l={modelConfig:{temperature:.7}};this.maxTokensPerGeneration>0&&(l.modelConfig.max_tokens=this.maxTokensPerGeneration);let c=ym([...t],this.maxExamples),u=this.traces.length,p=e.getId();for(let d=0;d<c.length;d+=this.batchSize){d>0&&(l.modelConfig.temperature=.7+.001*d);let m=c.slice(d,d+this.batchSize);for(let g of m){if(!g||typeof g!="object")continue;let f=t.filter(h=>h!==g);e.setDemos([{traces:f,programId:p}]);let x=this.getTeacherOrStudentAI();this.stats.totalCalls++;let A;try{let h={...l,maxRetries:1};A=await e.forward(x,g,h),this.costMonitoring&&(this.stats.estimatedTokenUsage+=JSON.stringify(g).length/4+JSON.stringify(A).length/4),await r({prediction:A,example:g})>=.5&&(this.traces=[...this.traces,...e.getTraces()],this.stats.successfulDemos++)}catch(h){(this.verboseMode||this.debugMode)&&console.warn(`Student model failed during bootstrap: ${h instanceof Error?h.message:"Unknown error"}`),A={}}if(this.traces.length>=a)return}}if(this.earlyStoppingPatience>0){let m=this.traces.length-u;if(!this.stats.earlyStopping)this.stats.earlyStopping={bestScoreRound:m>0?n:0,patienceExhausted:!1,reason:"No improvement detected"};else if(m>0)this.stats.earlyStopping.bestScoreRound=n;else if(n-this.stats.earlyStopping.bestScoreRound>=this.earlyStoppingPatience){this.stats.earlyStopping.patienceExhausted=!0,this.stats.earlyStopped=!0,this.stats.earlyStopping.reason=`No improvement for ${this.earlyStoppingPatience} rounds`;return}}}async compile(e,t,n,r){this.validateExamples(t,!1);let s=r?.maxIterations??this.maxRounds;this.traces=[],this.reset();for(let l=0;l<s&&(await this.compileRound(e,t,l,n,r),!this.stats.earlyStopped);l++);if(this.traces.length===0)throw new Error("No demonstrations found. Either provide more examples or improve the existing ones.");let i=Am(this.traces),a=0;return this.traces.length>0&&(a=this.stats.successfulDemos/Math.max(1,this.stats.totalCalls)),await this.logOptimizationComplete("BootstrapFewShot",a,{maxRounds:this.maxRounds,maxDemos:this.maxDemos,batchSize:this.batchSize,successRate:a,demosGenerated:i.length,tracesCollected:this.traces.length},r),{demos:i,stats:this.stats,bestScore:a,finalConfiguration:{maxRounds:this.maxRounds,maxDemos:this.maxDemos,batchSize:this.batchSize,successRate:a}}}};function Am(o){let e=new Map;for(let n of o)if(e.has(n.programId)){let r=e.get(n.programId);r&&r.push(n.trace)}else e.set(n.programId,[n.trace]);let t=[];return e.forEach((n,r)=>{t.push({traces:n,programId:r})}),t}var ym=(o,e)=>{let t=[...o];for(let n=t.length-1;n>0;n--){let r=Math.floor(Math.random()*(n+1)),s=t[n],i=t[r];if(!s||!i)throw new Error("Invalid array elements");[t[n],t[r]]=[i,s]}return t.slice(0,e)};var Is=class{endpoint;timeout;retryAttempts;retryDelay;logger;constructor(e){this.endpoint=e.endpoint.replace(/\/$/,""),this.timeout=e.timeout??3e4,this.retryAttempts=e.retryAttempts??3,this.retryDelay=e.retryDelay??1e3,this.logger=e.logger}async healthCheck(){try{return(await this.fetchWithRetry("/health",{method:"GET"})).ok}catch(e){return this.logger?.({name:"Notification",id:"health_check_failed",value:`Health check failed: ${e}`}),!1}}async createOptimizationJob(e){let t=await this.fetchWithRetry("/optimize",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)});if(!t.ok){let n=await t.text();throw new Error(`Failed to create optimization job: ${n}`)}return t.json()}async getJobStatus(e){let t=await this.fetchWithRetry(`/jobs/${e}`,{method:"GET"});if(!t.ok){let n=await t.text();throw new Error(`Failed to get job status: ${n}`)}return t.json()}async cancelJob(e){let t=await this.fetchWithRetry(`/jobs/${e}`,{method:"DELETE"});if(!t.ok){let n=await t.text();throw new Error(`Failed to cancel job: ${n}`)}}async suggestParameters(e){let t=await this.fetchWithRetry(`/studies/${e}/suggest`,{method:"POST",headers:{"Content-Type":"application/json"}});if(!t.ok){let n=await t.text();throw new Error(`Failed to suggest parameters: ${n}`)}return t.json()}async evaluateTrial(e){let t=await this.fetchWithRetry(`/studies/${e.study_name}/evaluate`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)});if(!t.ok){let n=await t.text();throw new Error(`Failed to evaluate trial: ${n}`)}}async getStudyResults(e){let t=await this.fetchWithRetry(`/studies/${e}/results`,{method:"GET"});if(!t.ok){let n=await t.text();throw new Error(`Failed to get study results: ${n}`)}return t.json()}async deleteStudy(e){let t=await this.fetchWithRetry(`/studies/${e}`,{method:"DELETE"});if(!t.ok){let n=await t.text();throw new Error(`Failed to delete study: ${n}`)}}async listStudies(){let e=await this.fetchWithRetry("/studies",{method:"GET"});if(!e.ok){let t=await e.text();throw new Error(`Failed to list studies: ${t}`)}return e.json()}async waitForJobCompletion(e,t=2e3,n=3e5){let r=Date.now();for(;Date.now()-r<n;){let s=await this.getJobStatus(e);if(["completed","failed","cancelled"].includes(s.status))return s;this.logger?.({name:"Notification",id:"job_status",value:`Job ${e} status: ${s.status}, waiting...`}),await this.sleep(t)}throw new Error(`Job ${e} did not complete within ${n}ms`)}async fetchWithRetry(e,t){let n=`${this.endpoint}${e}`,r=null;for(let s=0;s<this.retryAttempts;s++)try{let i=new AbortController,a=setTimeout(()=>i.abort(),this.timeout),l=await fetch(n,{...t,signal:i.signal});return clearTimeout(a),l}catch(i){r=i,this.logger?.({name:"Notification",id:"retry_attempt",value:`Attempt ${s+1} failed: ${i}`}),s<this.retryAttempts-1&&await this.sleep(this.retryDelay*Math.pow(2,s))}throw new Error(`Request failed after ${this.retryAttempts} attempts: ${r?.message}`)}sleep(e){return new Promise(t=>setTimeout(t,e))}};var ws=class extends Tt{maxBootstrappedDemos;maxLabeledDemos;numCandidates;initTemperature;numTrials;minibatch;minibatchSize;minibatchFullEvalSteps;programAwareProposer;dataAwareProposer;viewDataBatchSize;tipAwareProposer;fewshotAwareProposer;earlyStoppingTrials;minImprovementThreshold;bayesianOptimization;acquisitionFunction;explorationWeight;optimizeTopP;sampleCount;pythonClient;localScoreHistory=[];localConfigurationHistory=[];customResultPicker;constructor(e){if(super(e),this.numCandidates=e.numCandidates??5,this.initTemperature=e.initTemperature??.7,this.maxBootstrappedDemos=e.maxBootstrappedDemos??3,this.maxLabeledDemos=e.maxLabeledDemos??4,this.numTrials=e.numTrials??30,this.minibatch=e.minibatch??!0,this.minibatchSize=e.minibatchSize??25,this.minibatchFullEvalSteps=e.minibatchFullEvalSteps??10,this.programAwareProposer=e.programAwareProposer??!0,this.dataAwareProposer=e.dataAwareProposer??!0,this.viewDataBatchSize=e.viewDataBatchSize??10,this.tipAwareProposer=e.tipAwareProposer??!0,this.fewshotAwareProposer=e.fewshotAwareProposer??!0,this.earlyStoppingTrials=e.earlyStoppingTrials??5,this.minImprovementThreshold=e.minImprovementThreshold??.01,this.bayesianOptimization=e.bayesianOptimization??!0,this.acquisitionFunction=e.acquisitionFunction??"expected_improvement",this.explorationWeight=e.explorationWeight??.1,this.optimizeTopP=e.optimizeTopP??!1,this.sampleCount=e.sampleCount??1,this.customResultPicker=e.resultPicker,e.optimizerEndpoint){let t={endpoint:e.optimizerEndpoint,timeout:e.optimizerTimeout??3e4,retryAttempts:e.optimizerRetries??3,logger:n=>{this.logger?.({name:"Notification",id:"python_client",value:typeof n=="string"?n:JSON.stringify(n)})}};this.pythonClient=new Is(t)}this.stats.convergenceInfo.convergenceThreshold=this.minImprovementThreshold}defaultResultPicker=async e=>{if(e.type==="function"){let s=e.results.findIndex(i=>!i.isError);return s>=0?s:0}let t=new Map;for(let s of e.results){let i=JSON.stringify(s.sample??{}),a=t.get(i);a?a.count+=1:t.set(i,{count:1,firstIndex:s.index})}let n="",r={count:-1,firstIndex:0};for(let[s,i]of t.entries())i.count>r.count&&(r=i,n=s);return t.get(n)?.firstIndex??0};configureAuto(e){switch(e){case"light":this.numCandidates=3,this.numTrials=10,this.minibatch=!0,this.minibatchSize=20;break;case"medium":this.numCandidates=5,this.numTrials=20,this.minibatch=!0,this.minibatchSize=25;break;case"heavy":this.numCandidates=7,this.numTrials=30,this.minibatch=!0,this.minibatchSize=30;break}}generateTips(){return["Be very specific and detailed in your instructions.","Focus on step-by-step reasoning in your instructions.","Provide clear constraints and guidelines in your instructions.","Keep your instructions concise and to the point.","Emphasize accuracy and precision in your instructions.","Include examples of good outputs in your instructions.","Focus on handling edge cases in your instructions.","Explicitly outline the reasoning process in your instructions."]}async generateProgramSummary(e,t){let r=`
940
+ `);if(typeof this.gen.setDescription=="function"){this.gen.setDescription(s);return}s&&this.gen.setInstruction(s)}};var vs=class{rows=[];baseUrl;dataset;split;config;options;constructor({dataset:e,split:t,config:n,options:r}){this.baseUrl="https://datasets-server.huggingface.co/rows",this.dataset=e,this.split=t,this.config=n,this.options=r}async fetchDataFromAPI(e){try{let t=await fetch(e);if(!t.ok)throw new Error(`Error fetching data: ${t.statusText}`);let n=await t.json();if(!n?.rows)throw new Error("Invalid data format");return n.rows}catch(t){throw console.error("Error fetching data from API:",t),t}}async loadData(){let e=this.options?.offset??0,t=this.options?.length??100,n=encodeURIComponent(this.dataset),r=`${this.baseUrl}?dataset=${n}&config=${this.config}&split=${this.split}&offset=${e}&length=${t}`;return this.rows=await this.fetchDataFromAPI(r),this.rows}setData(e){this.rows=e}getData(){return this.rows}async getRows({count:e,fields:t,renameMap:n}){if(this.rows.length===0)throw new Error("No data loaded, call loadData or setData first.");return this.rows.slice(0,e).map(s=>{let i={};return t.forEach(a=>{let u=a.split("."),c=s.row;for(let p of u)Object.hasOwn(c,p)&&(c=c[p]);if(!c)return;let l=n&&a in n?n[a]:a;if(!l)throw new Error(`Invalid field name: ${a}`);i[l]=c}),i}).filter(s=>Object.keys(s).length!==0)}};var er=class extends Ct{maxRounds;maxDemos;maxExamples;batchSize;earlyStoppingPatience;costMonitoring;maxTokensPerGeneration;verboseMode;debugMode;traces=[];constructor(e){super(e);let t=e.options||{};this.maxRounds=t.maxRounds??3,this.maxDemos=t.maxDemos??4,this.maxExamples=t.maxExamples??16,this.batchSize=t.batchSize??1,this.earlyStoppingPatience=t.earlyStoppingPatience??0,this.costMonitoring=t.costMonitoring??!1,this.maxTokensPerGeneration=t.maxTokensPerGeneration??0,this.verboseMode=t.verboseMode??!0,this.debugMode=t.debugMode??!1}async compileRound(e,t,n,r,s){let i=Date.now(),a=s?.maxDemos??this.maxDemos,u={modelConfig:{temperature:.7}};this.maxTokensPerGeneration>0&&(u.modelConfig.max_tokens=this.maxTokensPerGeneration);let c=ag([...t],this.maxExamples),l=this.traces.length,p=e.getId();for(let d=0;d<c.length;d+=this.batchSize){d>0&&(u.modelConfig.temperature=.7+.001*d);let m=c.slice(d,d+this.batchSize);for(let g of m){if(!g||typeof g!="object")continue;let f=t.filter(h=>h!==g);e.setDemos([{traces:f,programId:p}]);let x=this.getTeacherOrStudentAI();this.stats.totalCalls++;let A;try{let h={...u,maxRetries:1};A=await e.forward(x,g,h),this.costMonitoring&&(this.stats.estimatedTokenUsage+=JSON.stringify(g).length/4+JSON.stringify(A).length/4),await r({prediction:A,example:g})>=.5&&(this.traces=[...this.traces,...e.getTraces()],this.stats.successfulDemos++)}catch(h){(this.verboseMode||this.debugMode)&&console.warn(`Student model failed during bootstrap: ${h instanceof Error?h.message:"Unknown error"}`),A={}}if(this.traces.length>=a)return}}if(this.earlyStoppingPatience>0){let m=this.traces.length-l;if(!this.stats.earlyStopping)this.stats.earlyStopping={bestScoreRound:m>0?n:0,patienceExhausted:!1,reason:"No improvement detected"};else if(m>0)this.stats.earlyStopping.bestScoreRound=n;else if(n-this.stats.earlyStopping.bestScoreRound>=this.earlyStoppingPatience){this.stats.earlyStopping.patienceExhausted=!0,this.stats.earlyStopped=!0,this.stats.earlyStopping.reason=`No improvement for ${this.earlyStoppingPatience} rounds`;return}}}async compile(e,t,n,r){this.validateExamples(t,!1);let s=r?.maxIterations??this.maxRounds;this.traces=[],this.reset();for(let u=0;u<s&&(await this.compileRound(e,t,u,n,r),!this.stats.earlyStopped);u++);if(this.traces.length===0)throw new Error("No demonstrations found. Either provide more examples or improve the existing ones.");let i=ig(this.traces),a=0;return this.traces.length>0&&(a=this.stats.successfulDemos/Math.max(1,this.stats.totalCalls)),await this.logOptimizationComplete("BootstrapFewShot",a,{maxRounds:this.maxRounds,maxDemos:this.maxDemos,batchSize:this.batchSize,successRate:a,demosGenerated:i.length,tracesCollected:this.traces.length},r),{demos:i,stats:this.stats,bestScore:a,finalConfiguration:{maxRounds:this.maxRounds,maxDemos:this.maxDemos,batchSize:this.batchSize,successRate:a}}}};function ig(o){let e=new Map;for(let n of o)if(e.has(n.programId)){let r=e.get(n.programId);r&&r.push(n.trace)}else e.set(n.programId,[n.trace]);let t=[];return e.forEach((n,r)=>{t.push({traces:n,programId:r})}),t}var ag=(o,e)=>{let t=[...o];for(let n=t.length-1;n>0;n--){let r=Math.floor(Math.random()*(n+1)),s=t[n],i=t[r];if(!s||!i)throw new Error("Invalid array elements");[t[n],t[r]]=[i,s]}return t.slice(0,e)};var Ss=class{endpoint;timeout;retryAttempts;retryDelay;logger;constructor(e){this.endpoint=e.endpoint.replace(/\/$/,""),this.timeout=e.timeout??3e4,this.retryAttempts=e.retryAttempts??3,this.retryDelay=e.retryDelay??1e3,this.logger=e.logger}async healthCheck(){try{return(await this.fetchWithRetry("/health",{method:"GET"})).ok}catch(e){return this.logger?.({name:"Notification",id:"health_check_failed",value:`Health check failed: ${e}`}),!1}}async createOptimizationJob(e){let t=await this.fetchWithRetry("/optimize",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)});if(!t.ok){let n=await t.text();throw new Error(`Failed to create optimization job: ${n}`)}return t.json()}async getJobStatus(e){let t=await this.fetchWithRetry(`/jobs/${e}`,{method:"GET"});if(!t.ok){let n=await t.text();throw new Error(`Failed to get job status: ${n}`)}return t.json()}async cancelJob(e){let t=await this.fetchWithRetry(`/jobs/${e}`,{method:"DELETE"});if(!t.ok){let n=await t.text();throw new Error(`Failed to cancel job: ${n}`)}}async suggestParameters(e){let t=await this.fetchWithRetry(`/studies/${e}/suggest`,{method:"POST",headers:{"Content-Type":"application/json"}});if(!t.ok){let n=await t.text();throw new Error(`Failed to suggest parameters: ${n}`)}return t.json()}async evaluateTrial(e){let t=await this.fetchWithRetry(`/studies/${e.study_name}/evaluate`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)});if(!t.ok){let n=await t.text();throw new Error(`Failed to evaluate trial: ${n}`)}}async getStudyResults(e){let t=await this.fetchWithRetry(`/studies/${e}/results`,{method:"GET"});if(!t.ok){let n=await t.text();throw new Error(`Failed to get study results: ${n}`)}return t.json()}async deleteStudy(e){let t=await this.fetchWithRetry(`/studies/${e}`,{method:"DELETE"});if(!t.ok){let n=await t.text();throw new Error(`Failed to delete study: ${n}`)}}async listStudies(){let e=await this.fetchWithRetry("/studies",{method:"GET"});if(!e.ok){let t=await e.text();throw new Error(`Failed to list studies: ${t}`)}return e.json()}async waitForJobCompletion(e,t=2e3,n=3e5){let r=Date.now();for(;Date.now()-r<n;){let s=await this.getJobStatus(e);if(["completed","failed","cancelled"].includes(s.status))return s;this.logger?.({name:"Notification",id:"job_status",value:`Job ${e} status: ${s.status}, waiting...`}),await this.sleep(t)}throw new Error(`Job ${e} did not complete within ${n}ms`)}async fetchWithRetry(e,t){let n=`${this.endpoint}${e}`,r=null;for(let s=0;s<this.retryAttempts;s++)try{let i=new AbortController,a=setTimeout(()=>i.abort(),this.timeout),u=await fetch(n,{...t,signal:i.signal});return clearTimeout(a),u}catch(i){r=i,this.logger?.({name:"Notification",id:"retry_attempt",value:`Attempt ${s+1} failed: ${i}`}),s<this.retryAttempts-1&&await this.sleep(this.retryDelay*Math.pow(2,s))}throw new Error(`Request failed after ${this.retryAttempts} attempts: ${r?.message}`)}sleep(e){return new Promise(t=>setTimeout(t,e))}};var ks=class extends Ct{maxBootstrappedDemos;maxLabeledDemos;numCandidates;initTemperature;numTrials;minibatch;minibatchSize;minibatchFullEvalSteps;programAwareProposer;dataAwareProposer;viewDataBatchSize;tipAwareProposer;fewshotAwareProposer;earlyStoppingTrials;minImprovementThreshold;bayesianOptimization;acquisitionFunction;explorationWeight;optimizeTopP;sampleCount;pythonClient;localScoreHistory=[];localConfigurationHistory=[];customResultPicker;constructor(e){if(super(e),this.numCandidates=e.numCandidates??5,this.initTemperature=e.initTemperature??.7,this.maxBootstrappedDemos=e.maxBootstrappedDemos??3,this.maxLabeledDemos=e.maxLabeledDemos??4,this.numTrials=e.numTrials??30,this.minibatch=e.minibatch??!0,this.minibatchSize=e.minibatchSize??25,this.minibatchFullEvalSteps=e.minibatchFullEvalSteps??10,this.programAwareProposer=e.programAwareProposer??!0,this.dataAwareProposer=e.dataAwareProposer??!0,this.viewDataBatchSize=e.viewDataBatchSize??10,this.tipAwareProposer=e.tipAwareProposer??!0,this.fewshotAwareProposer=e.fewshotAwareProposer??!0,this.earlyStoppingTrials=e.earlyStoppingTrials??5,this.minImprovementThreshold=e.minImprovementThreshold??.01,this.bayesianOptimization=e.bayesianOptimization??!0,this.acquisitionFunction=e.acquisitionFunction??"expected_improvement",this.explorationWeight=e.explorationWeight??.1,this.optimizeTopP=e.optimizeTopP??!1,this.sampleCount=e.sampleCount??1,this.customResultPicker=e.resultPicker,e.optimizerEndpoint){let t={endpoint:e.optimizerEndpoint,timeout:e.optimizerTimeout??3e4,retryAttempts:e.optimizerRetries??3,logger:n=>{this.logger?.({name:"Notification",id:"python_client",value:typeof n=="string"?n:JSON.stringify(n)})}};this.pythonClient=new Ss(t)}this.stats.convergenceInfo.convergenceThreshold=this.minImprovementThreshold}defaultResultPicker=async e=>{if(e.type==="function"){let s=e.results.findIndex(i=>!i.isError);return s>=0?s:0}let t=new Map;for(let s of e.results){let i=JSON.stringify(s.sample??{}),a=t.get(i);a?a.count+=1:t.set(i,{count:1,firstIndex:s.index})}let n="",r={count:-1,firstIndex:0};for(let[s,i]of t.entries())i.count>r.count&&(r=i,n=s);return t.get(n)?.firstIndex??0};configureAuto(e){switch(e){case"light":this.numCandidates=3,this.numTrials=10,this.minibatch=!0,this.minibatchSize=20;break;case"medium":this.numCandidates=5,this.numTrials=20,this.minibatch=!0,this.minibatchSize=25;break;case"heavy":this.numCandidates=7,this.numTrials=30,this.minibatch=!0,this.minibatchSize=30;break}}generateTips(){return["Be very specific and detailed in your instructions.","Focus on step-by-step reasoning in your instructions.","Provide clear constraints and guidelines in your instructions.","Keep your instructions concise and to the point.","Emphasize accuracy and precision in your instructions.","Include examples of good outputs in your instructions.","Focus on handling edge cases in your instructions.","Explicitly outline the reasoning process in your instructions."]}async generateProgramSummary(e,t){let r=`
941
941
  Analyze this language model program and provide a concise summary of its purpose and structure.
942
942
 
943
943
  Program Signature: ${e.getSignature()}
@@ -951,7 +951,7 @@ Summary:`;try{let s=await t.chat({chatPrompt:[{role:"user",content:r}]});return"
951
951
  Analyze this dataset and provide a concise summary of its characteristics.
952
952
 
953
953
  Sample Examples:
954
- ${e.slice(0,n).map((a,l)=>`Example ${l+1}: ${JSON.stringify(a)}`).join(`
954
+ ${e.slice(0,n).map((a,u)=>`Example ${u+1}: ${JSON.stringify(a)}`).join(`
955
955
  `)}
956
956
 
957
957
  Provide a 2-3 sentence summary focusing on:
@@ -962,7 +962,7 @@ Provide a 2-3 sentence summary focusing on:
962
962
  Dataset Summary:`;try{let a=await t.chat({chatPrompt:[{role:"user",content:i}]});return"results"in a&&a.results[0]?.content?.trim()||"General dataset"}catch{return"General dataset"}}async generateInstruction({tip:e,candidateIndex:t,ai:n,programSummary:r,datasetSummary:s,previousInstructions:i=[]}){let a="";this.programAwareProposer&&r&&(a+=`
963
963
  Program Context: ${r}`),this.dataAwareProposer&&s&&(a+=`
964
964
  Dataset Context: ${s}`),this.fewshotAwareProposer&&i.length>0&&(a+=`
965
- Previous Instructions (avoid repeating): ${i.slice(-3).join("; ")}`);let l=`
965
+ Previous Instructions (avoid repeating): ${i.slice(-3).join("; ")}`);let u=`
966
966
  Generate a high-quality instruction for a language model program.
967
967
 
968
968
  ${a}
@@ -977,12 +977,12 @@ Requirements:
977
977
  5. Keep it concise but comprehensive
978
978
 
979
979
  Generate a single, well-crafted instruction:
980
- Instruction:`;try{let m=(await st('programSummary?:string "Program context" , datasetSummary?:string "Dataset context" , tip?:string "Generation tip" -> instructionText:string "Well-crafted instruction for the program"').forward(n,{programSummary:r??"",datasetSummary:s??"",tip:e??""})).instructionText;if(m&&m.trim().length>10)return m.trim()}catch{}let c=["Analyze the input systematically and provide a precise, well-reasoned response.","Think through this step-by-step, considering all relevant factors before responding.","Examine the input carefully and generate an accurate, detailed answer.","Process the information methodically and deliver a clear, comprehensive response.","Consider the context thoroughly and provide a thoughtful, accurate answer."],u=c[t%c.length]||c[0];return e&&(u=`${u} ${e}`),u}async proposeInstructionCandidates(e,t,n=[]){let r=[],s=this.getTeacherOrStudentAI(t),i,a;this.programAwareProposer&&(i=await this.generateProgramSummary(e,s)),this.dataAwareProposer&&(a=await this.generateDatasetSummary([...n],s));let l=this.tipAwareProposer?this.generateTips():[];for(let c=0;c<this.numCandidates;c++){let u=l.length>0?c%l.length:-1,p=u>=0?l[u]:void 0,d=await this.generateInstruction({tip:p,candidateIndex:c,ai:s,programSummary:i,datasetSummary:a,previousInstructions:r});r.push(d)}return r}async bootstrapFewShotExamples(e,t,n){return(await new Yn({studentAI:this.studentAI,options:{maxDemos:this.maxBootstrappedDemos,maxRounds:3,verboseMode:this.verbose??!1}}).compile(e,n,t,{maxDemos:this.maxBootstrappedDemos})).demos||[]}selectLabeledExamples(e){let t=[],n=new Set;for(;n.size<this.maxLabeledDemos&&n.size<e.length;){let r=Math.floor(Math.random()*e.length);if(!n.has(r)){n.add(r);let s=e[r];s&&t.push(s)}}return t}applyConfigToProgram(e,t,n,r){if(e.setInstruction&&e.setInstruction(t.instruction),e.setDemos){let s=[...n.slice(0,t.bootstrappedDemos)];if(t.labeledExamples>0&&e.getId){let i=e.getId();s.push({traces:r.slice(0,t.labeledExamples),programId:i})}s.length>0&&e.setDemos(s)}}async compile(e,t,n,r){let s=Date.now();if(this.validateExamples(t),this.setupRandomSeed(),r?.auto&&this.configureAuto(r.auto),!this.pythonClient)throw new Error("AxMiPRO v2 requires the Python optimizer service. Please configure optimizerEndpoint.");if(!await this.pythonClient.healthCheck())throw new Error("Python optimizer service is not available or unhealthy");return await this.compilePython(e,t,n,r)}applyConfigToAxGen(e,t,n,r){"setInstruction"in e&&typeof e.setInstruction=="function"&&e.setInstruction(t.instruction);let s=[...n.slice(0,t.bootstrappedDemos)];if(t.labeledExamples>0){let i=e.getId();s.push({traces:r.slice(0,t.labeledExamples),programId:i})}s.length>0&&e.setDemos(s)}getConfiguration(){return{numCandidates:this.numCandidates,initTemperature:this.initTemperature,maxBootstrappedDemos:this.maxBootstrappedDemos,maxLabeledDemos:this.maxLabeledDemos,numTrials:this.numTrials,minibatch:this.minibatch,minibatchSize:this.minibatchSize,minibatchFullEvalSteps:this.minibatchFullEvalSteps,programAwareProposer:this.programAwareProposer,dataAwareProposer:this.dataAwareProposer,tipAwareProposer:this.tipAwareProposer,fewshotAwareProposer:this.fewshotAwareProposer,earlyStoppingTrials:this.earlyStoppingTrials,minImprovementThreshold:this.minImprovementThreshold,bayesianOptimization:this.bayesianOptimization,acquisitionFunction:this.acquisitionFunction,explorationWeight:this.explorationWeight,sampleCount:this.sampleCount}}updateConfiguration(e){e.numCandidates!==void 0&&(this.numCandidates=e.numCandidates),e.initTemperature!==void 0&&(this.initTemperature=e.initTemperature),e.maxBootstrappedDemos!==void 0&&(this.maxBootstrappedDemos=e.maxBootstrappedDemos),e.maxLabeledDemos!==void 0&&(this.maxLabeledDemos=e.maxLabeledDemos),e.numTrials!==void 0&&(this.numTrials=e.numTrials),e.minibatch!==void 0&&(this.minibatch=e.minibatch),e.minibatchSize!==void 0&&(this.minibatchSize=e.minibatchSize),e.earlyStoppingTrials!==void 0&&(this.earlyStoppingTrials=e.earlyStoppingTrials),e.minImprovementThreshold!==void 0&&(this.minImprovementThreshold=e.minImprovementThreshold),e.sampleCount!==void 0&&(this.sampleCount=e.sampleCount)}reset(){super.reset(),this.stats.convergenceInfo.convergenceThreshold=this.minImprovementThreshold}validateProgram(e){let t=[],n=[];return{isValid:t.length===0,issues:t,suggestions:n}}async compilePython(e,t,n,r){if(!this.pythonClient)throw new Error("Python client not initialized");let s=Date.now();this.localScoreHistory=[],this.localConfigurationHistory=[];let i=await this.proposeInstructionCandidates(e,r,t),a=`mipro_${Date.now()}_${Math.random().toString(36).substr(2,9)}`,l={study_name:a,parameters:[{name:"temperature",type:"float",low:.1,high:2},{name:"bootstrappedDemos",type:"int",low:0,high:this.maxBootstrappedDemos},{name:"instruction",type:"categorical",choices:i},{name:"labeledExamples",type:"int",low:0,high:this.maxLabeledDemos},...this.optimizeTopP?[{name:"topP",type:"float",low:.7,high:1}]:[]],objective:{name:"score",direction:"maximize"},n_trials:this.numTrials,sampler:"TPESampler",pruner:this.minibatch?"MedianPruner":void 0},c=await this.pythonClient.createOptimizationJob(l);this.getOptimizerLogger()?.({name:"OptimizationStart",value:{optimizerType:"MiPRO (Python)",exampleCount:t.length,validationCount:0,config:{jobId:c.job_id,numTrials:this.numTrials}}});let p=Number.NEGATIVE_INFINITY,d,m=0,g=0;for(let v=0;v<this.numTrials;v++)try{let k=await this.pythonClient.suggestParameters(a),R=k.params.temperature,E=k.params.bootstrappedDemos,S=k.params.instruction,_=k.params.labeledExamples,L=this.optimizeTopP?k.params.topP:void 0;if(R===void 0)throw new Error(`Missing temperature parameter in suggestion: ${JSON.stringify(k)}`);if(E===void 0)throw new Error(`Missing bootstrappedDemos parameter in suggestion: ${JSON.stringify(k)}`);if(S===void 0)throw new Error(`Missing instruction parameter in suggestion: ${JSON.stringify(k)}`);if(_===void 0)throw new Error(`Missing labeledExamples parameter in suggestion: ${JSON.stringify(k)}`);let P=e.clone();P.setInstruction(S);let F=P.getId();P.setDemos([{traces:this.selectLabeledExamples(t).slice(0,_),programId:F}]);let U=!this.minibatch||this.minibatchFullEvalSteps>0&&v%this.minibatchFullEvalSteps===this.minibatchFullEvalSteps-1?[...t]:(()=>{let te=Math.min(this.minibatchSize,t.length),j=new Set;for(;j.size<te;)j.add(Math.floor(Math.random()*t.length));return Array.from(j).map(V=>t[V])})(),G=await this.evaluateConfiguration(P,n,{temperature:R,bootstrappedDemos:E,topP:L},U);m++,await this.pythonClient.evaluateTrial({study_name:a,trial_number:k.trial_number,value:G}),G>p+this.minImprovementThreshold?(p=G,d={temperature:R,bootstrappedDemos:E,...L!==void 0?{topP:L}:{},trialNumber:k.trial_number},g=0):g+=1,this.currentRound=v+1;let B={temperature:R,bootstrappedDemos:E,...L!==void 0?{topP:L}:{},trialNumber:k.trial_number};if(this.localScoreHistory.push(G),this.localConfigurationHistory.push(B),await this.updateOptimizationProgress(this.currentRound,G,B,"MiPRO (Python)",{sampler:"TPESampler"},p,d),this.onProgress?.({round:v+1,totalRounds:this.numTrials,currentScore:G,bestScore:p,tokensUsed:this.stats.estimatedTokenUsage,timeElapsed:Date.now()-s,successfulExamples:m,totalExamples:t.length}),this.earlyStoppingTrials>0&&g>=this.earlyStoppingTrials){this.getOptimizerLogger()?.({name:"EarlyStopping",value:{reason:`No improvement \u2265 ${this.minImprovementThreshold} for ${this.earlyStoppingTrials} trials`,finalScore:p,round:this.currentRound}}),this.onEarlyStop?.(`No improvement for ${this.earlyStoppingTrials} trials`,this.stats);break}}catch{}let f=p,x={},A=[];try{let v=await this.pythonClient.getStudyResults(a);if(f=v.best_value||p,x=v.best_params||{},x&&Object.keys(x).length>0){let k=x.bootstrappedDemos||0;k>0&&(A=await this.bootstrapFewShotExamples(e,n,t.slice(0,Math.floor(t.length*.8))),A=A.slice(0,k))}}catch{}let h;try{let k=await st('optimizerType:string "Optimizer name" , bestScore:number "Final best score" , totalCalls:number "Total eval calls" , successfulDemos:number "Successful evals" , bestConfig:json "Best configuration" -> humanExplanation:string "Readable summary", recommendations:string[] "Next steps", performanceAssessment:string "Performance notes"').forward(this.studentAI,{optimizerType:"MiPRO (Python)",bestScore:f,totalCalls:this.stats.totalCalls,successfulDemos:this.stats.successfulDemos,bestConfig:x||{}});h={humanExplanation:k.humanExplanation??"",recommendations:k.recommendations??[],performanceAssessment:k.performanceAssessment??""}}catch{}await this.logOptimizationComplete("MiPRO (Python)",f,x,r,h);try{await this.pythonClient.deleteStudy(a)}catch{}this.stats.bestScore=f;let b=new ke(e.getSignature());x.instruction&&b.setInstruction(x.instruction);let T=x.temperature?{temperature:x.temperature}:void 0;b.setDemos(A,{modelConfig:T});let C=new bt({bestScore:f,stats:this.stats,instruction:x.instruction,demos:A,examples:[],modelConfig:{temperature:x.temperature},optimizerType:"MiPRO (Python)",optimizationTime:Date.now()-s,totalRounds:this.numTrials,converged:this.stats.convergenceInfo.converged,scoreHistory:[...this.localScoreHistory],configurationHistory:[...this.localConfigurationHistory]});return this.generateOptimizationReport(f,A.length),{bestScore:f,demos:A,stats:this.stats,optimizedGen:b,optimizedProgram:C,finalConfiguration:{temperature:x.temperature,bootstrappedDemos:x.bootstrappedDemos||0,...x}}}generateOptimizationReport(e,t){console.log(`
980
+ Instruction:`;try{let m=(await st('programSummary?:string "Program context" , datasetSummary?:string "Dataset context" , tip?:string "Generation tip" -> instructionText:string "Well-crafted instruction for the program"').forward(n,{programSummary:r??"",datasetSummary:s??"",tip:e??""})).instructionText;if(m&&m.trim().length>10)return m.trim()}catch{}let c=["Analyze the input systematically and provide a precise, well-reasoned response.","Think through this step-by-step, considering all relevant factors before responding.","Examine the input carefully and generate an accurate, detailed answer.","Process the information methodically and deliver a clear, comprehensive response.","Consider the context thoroughly and provide a thoughtful, accurate answer."],l=c[t%c.length]||c[0];return e&&(l=`${l} ${e}`),l}async proposeInstructionCandidates(e,t,n=[]){let r=[],s=this.getTeacherOrStudentAI(t),i,a;this.programAwareProposer&&(i=await this.generateProgramSummary(e,s)),this.dataAwareProposer&&(a=await this.generateDatasetSummary([...n],s));let u=this.tipAwareProposer?this.generateTips():[];for(let c=0;c<this.numCandidates;c++){let l=u.length>0?c%u.length:-1,p=l>=0?u[l]:void 0,d=await this.generateInstruction({tip:p,candidateIndex:c,ai:s,programSummary:i,datasetSummary:a,previousInstructions:r});r.push(d)}return r}async bootstrapFewShotExamples(e,t,n){return(await new er({studentAI:this.studentAI,options:{maxDemos:this.maxBootstrappedDemos,maxRounds:3,verboseMode:this.verbose??!1}}).compile(e,n,t,{maxDemos:this.maxBootstrappedDemos})).demos||[]}selectLabeledExamples(e){let t=[],n=new Set;for(;n.size<this.maxLabeledDemos&&n.size<e.length;){let r=Math.floor(Math.random()*e.length);if(!n.has(r)){n.add(r);let s=e[r];s&&t.push(s)}}return t}applyConfigToProgram(e,t,n,r){if(e.setInstruction&&e.setInstruction(t.instruction),e.setDemos){let s=[...n.slice(0,t.bootstrappedDemos)];if(t.labeledExamples>0&&e.getId){let i=e.getId();s.push({traces:r.slice(0,t.labeledExamples),programId:i})}s.length>0&&e.setDemos(s)}}async compile(e,t,n,r){let s=Date.now();if(this.validateExamples(t),this.setupRandomSeed(),r?.auto&&this.configureAuto(r.auto),!this.pythonClient)throw new Error("AxMiPRO v2 requires the Python optimizer service. Please configure optimizerEndpoint.");if(!await this.pythonClient.healthCheck())throw new Error("Python optimizer service is not available or unhealthy");return await this.compilePython(e,t,n,r)}applyConfigToAxGen(e,t,n,r){"setInstruction"in e&&typeof e.setInstruction=="function"&&e.setInstruction(t.instruction);let s=[...n.slice(0,t.bootstrappedDemos)];if(t.labeledExamples>0){let i=e.getId();s.push({traces:r.slice(0,t.labeledExamples),programId:i})}s.length>0&&e.setDemos(s)}getConfiguration(){return{numCandidates:this.numCandidates,initTemperature:this.initTemperature,maxBootstrappedDemos:this.maxBootstrappedDemos,maxLabeledDemos:this.maxLabeledDemos,numTrials:this.numTrials,minibatch:this.minibatch,minibatchSize:this.minibatchSize,minibatchFullEvalSteps:this.minibatchFullEvalSteps,programAwareProposer:this.programAwareProposer,dataAwareProposer:this.dataAwareProposer,tipAwareProposer:this.tipAwareProposer,fewshotAwareProposer:this.fewshotAwareProposer,earlyStoppingTrials:this.earlyStoppingTrials,minImprovementThreshold:this.minImprovementThreshold,bayesianOptimization:this.bayesianOptimization,acquisitionFunction:this.acquisitionFunction,explorationWeight:this.explorationWeight,sampleCount:this.sampleCount}}updateConfiguration(e){e.numCandidates!==void 0&&(this.numCandidates=e.numCandidates),e.initTemperature!==void 0&&(this.initTemperature=e.initTemperature),e.maxBootstrappedDemos!==void 0&&(this.maxBootstrappedDemos=e.maxBootstrappedDemos),e.maxLabeledDemos!==void 0&&(this.maxLabeledDemos=e.maxLabeledDemos),e.numTrials!==void 0&&(this.numTrials=e.numTrials),e.minibatch!==void 0&&(this.minibatch=e.minibatch),e.minibatchSize!==void 0&&(this.minibatchSize=e.minibatchSize),e.earlyStoppingTrials!==void 0&&(this.earlyStoppingTrials=e.earlyStoppingTrials),e.minImprovementThreshold!==void 0&&(this.minImprovementThreshold=e.minImprovementThreshold),e.sampleCount!==void 0&&(this.sampleCount=e.sampleCount)}reset(){super.reset(),this.stats.convergenceInfo.convergenceThreshold=this.minImprovementThreshold}validateProgram(e){let t=[],n=[];return{isValid:t.length===0,issues:t,suggestions:n}}async compilePython(e,t,n,r){if(!this.pythonClient)throw new Error("Python client not initialized");let s=Date.now();this.localScoreHistory=[],this.localConfigurationHistory=[];let i=await this.proposeInstructionCandidates(e,r,t),a=`mipro_${Date.now()}_${Math.random().toString(36).substr(2,9)}`,u={study_name:a,parameters:[{name:"temperature",type:"float",low:.1,high:2},{name:"bootstrappedDemos",type:"int",low:0,high:this.maxBootstrappedDemos},{name:"instruction",type:"categorical",choices:i},{name:"labeledExamples",type:"int",low:0,high:this.maxLabeledDemos},...this.optimizeTopP?[{name:"topP",type:"float",low:.7,high:1}]:[]],objective:{name:"score",direction:"maximize"},n_trials:this.numTrials,sampler:"TPESampler",pruner:this.minibatch?"MedianPruner":void 0},c=await this.pythonClient.createOptimizationJob(u);this.getOptimizerLogger()?.({name:"OptimizationStart",value:{optimizerType:"MiPRO (Python)",exampleCount:t.length,validationCount:0,config:{jobId:c.job_id,numTrials:this.numTrials}}});let p=Number.NEGATIVE_INFINITY,d,m=0,g=0;for(let v=0;v<this.numTrials;v++)try{let O=await this.pythonClient.suggestParameters(a),R=O.params.temperature,E=O.params.bootstrappedDemos,S=O.params.instruction,_=O.params.labeledExamples,$=this.optimizeTopP?O.params.topP:void 0;if(R===void 0)throw new Error(`Missing temperature parameter in suggestion: ${JSON.stringify(O)}`);if(E===void 0)throw new Error(`Missing bootstrappedDemos parameter in suggestion: ${JSON.stringify(O)}`);if(S===void 0)throw new Error(`Missing instruction parameter in suggestion: ${JSON.stringify(O)}`);if(_===void 0)throw new Error(`Missing labeledExamples parameter in suggestion: ${JSON.stringify(O)}`);let M=e.clone();M.setInstruction(S);let F=M.getId();M.setDemos([{traces:this.selectLabeledExamples(t).slice(0,_),programId:F}]);let G=!this.minibatch||this.minibatchFullEvalSteps>0&&v%this.minibatchFullEvalSteps===this.minibatchFullEvalSteps-1?[...t]:(()=>{let ae=Math.min(this.minibatchSize,t.length),j=new Set;for(;j.size<ae;)j.add(Math.floor(Math.random()*t.length));return Array.from(j).map(re=>t[re])})(),W=await this.evaluateConfiguration(M,n,{temperature:R,bootstrappedDemos:E,topP:$},G);m++,await this.pythonClient.evaluateTrial({study_name:a,trial_number:O.trial_number,value:W}),W>p+this.minImprovementThreshold?(p=W,d={temperature:R,bootstrappedDemos:E,...$!==void 0?{topP:$}:{},trialNumber:O.trial_number},g=0):g+=1,this.currentRound=v+1;let U={temperature:R,bootstrappedDemos:E,...$!==void 0?{topP:$}:{},trialNumber:O.trial_number};if(this.localScoreHistory.push(W),this.localConfigurationHistory.push(U),await this.updateOptimizationProgress(this.currentRound,W,U,"MiPRO (Python)",{sampler:"TPESampler"},p,d),this.onProgress?.({round:v+1,totalRounds:this.numTrials,currentScore:W,bestScore:p,tokensUsed:this.stats.estimatedTokenUsage,timeElapsed:Date.now()-s,successfulExamples:m,totalExamples:t.length}),this.earlyStoppingTrials>0&&g>=this.earlyStoppingTrials){this.getOptimizerLogger()?.({name:"EarlyStopping",value:{reason:`No improvement \u2265 ${this.minImprovementThreshold} for ${this.earlyStoppingTrials} trials`,finalScore:p,round:this.currentRound}}),this.onEarlyStop?.(`No improvement for ${this.earlyStoppingTrials} trials`,this.stats);break}}catch{}let f=p,x={},A=[];try{let v=await this.pythonClient.getStudyResults(a);if(f=v.best_value||p,x=v.best_params||{},x&&Object.keys(x).length>0){let O=x.bootstrappedDemos||0;O>0&&(A=await this.bootstrapFewShotExamples(e,n,t.slice(0,Math.floor(t.length*.8))),A=A.slice(0,O))}}catch{}let h;try{let O=await st('optimizerType:string "Optimizer name" , bestScore:number "Final best score" , totalCalls:number "Total eval calls" , successfulDemos:number "Successful evals" , bestConfig:json "Best configuration" -> humanExplanation:string "Readable summary", recommendations:string[] "Next steps", performanceAssessment:string "Performance notes"').forward(this.studentAI,{optimizerType:"MiPRO (Python)",bestScore:f,totalCalls:this.stats.totalCalls,successfulDemos:this.stats.successfulDemos,bestConfig:x||{}});h={humanExplanation:O.humanExplanation??"",recommendations:O.recommendations??[],performanceAssessment:O.performanceAssessment??""}}catch{}await this.logOptimizationComplete("MiPRO (Python)",f,x,r,h);try{await this.pythonClient.deleteStudy(a)}catch{}this.stats.bestScore=f;let y=new Pe(e.getSignature());x.instruction&&y.setInstruction(x.instruction);let C=x.temperature?{temperature:x.temperature}:void 0;y.setDemos(A,{modelConfig:C});let I=new bt({bestScore:f,stats:this.stats,instruction:x.instruction,demos:A,examples:[],modelConfig:{temperature:x.temperature},optimizerType:"MiPRO (Python)",optimizationTime:Date.now()-s,totalRounds:this.numTrials,converged:this.stats.convergenceInfo.converged,scoreHistory:[...this.localScoreHistory],configurationHistory:[...this.localConfigurationHistory]});return this.generateOptimizationReport(f,A.length),{bestScore:f,demos:A,stats:this.stats,optimizedGen:y,optimizedProgram:I,finalConfiguration:{temperature:x.temperature,bootstrappedDemos:x.bootstrappedDemos||0,...x}}}generateOptimizationReport(e,t){console.log(`
981
981
  \u{1F389} MiPRO Optimization Complete!
982
982
  `),console.log("\u2705 Improvements:"),e!==void 0&&e>0&&console.log(`\u2022 Best score achieved: ${e.toFixed(3)}`),t>0&&console.log(`\u2022 Generated ${t} optimized demonstrations`),console.log("\u2022 Systematic prompt and example optimization"),console.log(`\u2022 Automated instruction refinement process
983
983
  `),console.log("\u26A0\uFE0F Limitations:"),this.stats.totalCalls<50&&console.log("\u2022 Relatively few optimization trials performed"),t<5&&console.log("\u2022 Limited number of demonstrations generated"),console.log("\u2022 Results depend on teacher model quality"),console.log(`\u2022 Optimization time increases with example complexity
984
984
  `),console.log("\u{1F50D} Key Issues:"),e!==void 0&&e<.7&&console.log("\u2022 Final performance may still have room for improvement"),this.stats.convergenceInfo?.converged===!1&&console.log("\u2022 Optimization may not have fully converged"),console.log("\u2022 Evaluation metrics may need domain-specific tuning"),console.log(`\u2022 Bootstrap quality depends on initial examples
985
- `),console.log("\u{1F4A1} What This Means:"),console.log("\u2022 MiPRO successfully automated prompt engineering"),console.log("\u2022 Optimized instructions and examples improve model performance"),console.log("\u2022 Framework reduces manual prompt engineering effort"),console.log("\u2022 More training data and iterations would likely improve results")}async evaluateConfiguration(e,t,n,r){let s=0,i=0,a=0,l=r;for(let c of l)try{let u=await e.forward(this.studentAI,c,{modelConfig:{temperature:n.temperature,...n.topP!==void 0?{topP:n.topP}:{}},sampleCount:this.sampleCount,resultPicker:this.sampleCount>1?this.customResultPicker??this.defaultResultPicker:void 0});this.stats.totalCalls+=1;let p=await t({prediction:u,example:c});if(typeof p=="number"&&!Number.isNaN(p)){s+=p,i++;let d=typeof this.targetScore=="number"?this.targetScore:.5;p>=d&&a++}}catch(u){this.getLogger()?.({name:"Notification",id:"mipro_evaluate",value:typeof u=="string"?u:String(u)})}return this.stats.successfulDemos+=a,i>0?s/i:0}};var Xn=class{analyzeMappingDependencies(e,t){if(!e||typeof e!="function")return[];let n=[];try{let r=e.toString(),s=Array.from(r.matchAll(/state\.(\w+)/g));for(let i of s)i[1]&&!n.includes(i[1])&&n.push(i[1]);if(n.length===0)try{let i=this.createDependencyTracker(n);e(i)}catch{}}catch(r){console.debug("Dependency analysis failed:",r)}return n}createTrackingProxy(e,t){let n=this;return new Proxy(e,{get(r,s){typeof s=="string"&&!t.includes(s)&&t.push(s);let i=r[s];return i&&typeof i=="object"?n.createTrackingProxy(i,t):i},has(r,s){return typeof s=="string"&&!t.includes(s)&&t.push(s),s in r}})}parseStaticDependencies(e){let t=[];try{let n=Array.from(e.matchAll(/state\.(\w+)/g));for(let i of n)i[1]&&!t.includes(i[1])&&t.push(i[1]);let r=Array.from(e.matchAll(/\$\{state\.(\w+)\}/g));for(let i of r)i[1]&&!t.includes(i[1])&&t.push(i[1]);let s=Array.from(e.matchAll(/\{\s*(\w+)(?:\s*,\s*(\w+))*\s*\}\s*=\s*state/g));for(let i of s)for(let a=1;a<i.length;a++)i[a]&&!t.includes(i[a])&&t.push(i[a])}catch(n){console.debug("Static dependency parsing failed:",n)}return t}createDependencyTracker(e){return new Proxy({},{get(t,n){return typeof n=="string"&&!e.includes(n)&&e.push(n),new Proxy({},{get:()=>{}})}})}};async function Zn(o,e,t){if(!t||t<=0||t>=o.length){let r=o.map((s,i)=>e(s,i));return Promise.all(r)}let n=new Array(o.length);for(let r=0;r<o.length;r+=t){let i=o.slice(r,r+t).map((l,c)=>{let u=r+c;return e(l,u).then(p=>({result:p,originalIndex:u}))}),a=await Promise.all(i);for(let{result:l,originalIndex:c}of a)n[c]=l}return n}var er=class{steps=[];parallelGroups=[];analyzer=new Xn;initialFields=new Set;addExecutionStep(e,t,n,r,s,i,a){let l=[],c=[],u=r||"map";if(t&&n)u="execute",l=this.analyzer.analyzeMappingDependencies(n,t),c=[`${t}Result`];else if(u==="map"&&s)c=this.analyzeMapTransformation(s),l=this.getAllProducedFields();else if(u==="parallel-map"){if(Array.isArray(s)){let d=new Set;for(let m of s)this.analyzeMapTransformation(m).forEach(f=>d.add(f));c=Array.from(d)}else s?c=this.analyzeMapTransformation(s):c=["_parallelMapResult"];l=this.getAllProducedFields()}else if(u==="merge"){if(i?.resultKey)c=[i.resultKey];else{let m=this.analyzeBranchMergeFields();c=m.length>0?m:["_mergedResult"]}e.toString().includes("_parallelResults")?l=["_parallelResults"]:l=this.getAllProducedFields()}else if(u==="parallel")c=["_parallelResults"],l=this.getAllProducedFields();else if(u==="derive")if(a?.outputFieldName&&a?.inputFieldName){c=[a.outputFieldName];let d=s?this.analyzer.analyzeMappingDependencies(s,"derive"):[];l=[a.inputFieldName,...d].filter((m,g,f)=>f.indexOf(m)===g)}else c=["_deriveResult"],l=this.getAllProducedFields();else e.toString().includes("transform(")?(u="map",l=this.getAllProducedFields(),c=["_mapResult"]):e.toString().includes("_parallelResults")&&(c=["_parallelResults"],l=this.getAllProducedFields());for(let d of l)this.getAllProducedFields().includes(d)||this.initialFields.add(d);let p={type:u,nodeName:t,dependencies:l,produces:c,stepFunction:e,stepIndex:this.steps.length};this.steps.push(p)}analyzeStepFunctionProduction(e){try{let t=this.analyzeStepFunctionSource(e);if(t.length>0&&!t.includes("_stepResult"))return t}catch(t){console.debug("Step function source analysis failed:",t)}try{let t=this.createMockState(),n=Object.keys(t),s=e(t,{mainAi:{getOptions:()=>({trace:!1}),forward:()=>Promise.resolve({text:"mock"})},mainOptions:void 0});if(s&&typeof s=="object"&&"then"in s)return this.analyzeStepFunctionSource(e);if(s&&typeof s=="object"&&!Array.isArray(s)){let a=Object.keys(s).filter(l=>!n.includes(l));if(a.length>0)return a}}catch(t){console.debug("Step function dynamic analysis failed:",t)}return this.analyzeStepFunctionSource(e)}analyzeStepFunctionSource(e){try{let t=e.toString(),n=t.match(/\{\s*\.\.\.state\s*,\s*(\w+)\s*:/g);if(n){let s=n.map(i=>{let a=i.match(/(\w+)\s*:/);return a?a[1]:null}).filter(Boolean);if(s.length>0)return s}let r=t.match(/state\.(\w+)\s*=/g);if(r){let s=r.map(i=>{let a=i.match(/state\.(\w+)\s*=/);return a?a[1]:null}).filter(Boolean);if(s.length>0)return s}}catch(t){console.debug("Step function source analysis failed:",t)}return["_stepResult"]}analyzeMapTransformation(e){try{let n=e.toString().split(/\{[\s\S]*?\}/).flatMap(()=>[])}catch{}return["_mapResult"]}createMockState(){let e={};for(let t of this.initialFields)e[t]=this.createMockValue(t);for(let t of this.steps)for(let n of t.produces)n.endsWith("Result")?e[n]={text:"mockText",value:"mockValue",result:"mockResult",data:"mockData",processedText:"mockProcessedText",sentimentValue:"mockSentiment",confidenceScore:.8,isComplex:!1,mockValue:"mockValue",responseText:"mockResponseText",inputText:"mockInputText"}:e[n]=this.createMockValue(n);return e}createMockValue(e){return e.includes("List")||e.includes("Array")||e.endsWith("s")?["mockItem1","mockItem2"]:e.includes("count")||e.includes("Count")||e.includes("index")||e.includes("Index")?0:e.includes("is")||e.includes("has")||e.includes("can")?!1:"mockValue"}analyzeBranchMergeFields(){let e=this.steps.slice(-5).filter(t=>t.type==="execute"&&t.nodeName).flatMap(t=>t.produces);return e.length>0?e:this.steps.filter(t=>t.type==="execute"&&t.nodeName).flatMap(t=>t.produces)}setInitialFields(e){this.initialFields=new Set(e),this.rebuildParallelGroups()}rebuildParallelGroups(){this.parallelGroups=[];let e=new Set,t=new Set(this.initialFields),n=0;for(;e.size<this.steps.length;){let r=[];for(let s of this.steps){if(e.has(s.stepIndex))continue;if(s.dependencies.length===0||s.dependencies.every(a=>t.has(a))){if(s.type==="merge"&&r.length>0)continue;if(r.push(s),e.add(s.stepIndex),s.type==="merge")break}}if(r.length>0){for(let s of r)s.produces.forEach(i=>t.add(i));this.parallelGroups.push({level:n,steps:r}),n++}else{let s=this.steps.filter(i=>!e.has(i.stepIndex));if(s.length>0){let i=s[0];e.add(i.stepIndex),i.produces.forEach(a=>t.add(a)),this.parallelGroups.push({level:n,steps:[i]}),n++}else break}}}getAllProducedFields(){let e=[];for(let t of this.steps)e.push(...t.produces);return e}createOptimizedExecution(e){let t=[];for(let n of this.parallelGroups)if(n.steps.length===1){let r=n.steps[0];r&&t.push(r.stepFunction)}else if(n.steps.length>1){let r=async(s,i)=>{let a=await Zn(n.steps,async u=>await u.stepFunction(s,i),e);if(a.some(u=>u&&typeof u=="object"&&"_parallelResults"in u)){let u=a.find(p=>p&&typeof p=="object"&&"_parallelResults"in p);return u||s}let c=s;for(let u of a)c={...c,...u};return c};t.push(r)}return t}getOptimizedExecutionSteps(){return this.parallelGroups.length===0&&this.steps.length>0&&this.rebuildParallelGroups(),this.createOptimizedExecution()}getExecutionPlan(){return this.parallelGroups.length===0&&this.steps.length>0&&this.rebuildParallelGroups(),{totalSteps:this.steps.length,parallelGroups:this.parallelGroups.length,maxParallelism:this.steps.length===0?1:Math.max(...this.parallelGroups.map(e=>e.steps.length),0),steps:this.steps,groups:this.parallelGroups}}};var or=require("@opentelemetry/api");var gu=o=>{console.log(o)},tr=(o,e=!1)=>{if(e)return"[State hidden]";let t={};for(let[n,r]of Object.entries(o))if(typeof r=="string"&&r.length>100)t[n]=`${r.substring(0,100)}...`;else if(Array.isArray(r)&&r.length>3)t[n]=[...r.slice(0,3),`... (${r.length-3} more)`];else if(typeof r=="object"&&r!==null){let s=JSON.stringify(r);s.length>200?t[n]=`${s.substring(0,200)}...`:t[n]=r}else t[n]=r;return JSON.stringify(t,null,2)},nr=o=>o<1e3?`${o.toFixed(1)}ms`:o<6e4?`${(o/1e3).toFixed(2)}s`:`${(o/6e4).toFixed(2)}min`,Kr=(o=gu)=>{let e=new ot,t=e.gray(`${"\u2501".repeat(80)}
985
+ `),console.log("\u{1F4A1} What This Means:"),console.log("\u2022 MiPRO successfully automated prompt engineering"),console.log("\u2022 Optimized instructions and examples improve model performance"),console.log("\u2022 Framework reduces manual prompt engineering effort"),console.log("\u2022 More training data and iterations would likely improve results")}async evaluateConfiguration(e,t,n,r){let s=0,i=0,a=0,u=r;for(let c of u)try{let l=await e.forward(this.studentAI,c,{modelConfig:{temperature:n.temperature,...n.topP!==void 0?{topP:n.topP}:{}},sampleCount:this.sampleCount,resultPicker:this.sampleCount>1?this.customResultPicker??this.defaultResultPicker:void 0});this.stats.totalCalls+=1;let p=await t({prediction:l,example:c});if(typeof p=="number"&&!Number.isNaN(p)){s+=p,i++;let d=typeof this.targetScore=="number"?this.targetScore:.5;p>=d&&a++}}catch(l){this.getLogger()?.({name:"Notification",id:"mipro_evaluate",value:typeof l=="string"?l:String(l)})}return this.stats.successfulDemos+=a,i>0?s/i:0}};var tr=class{analyzeMappingDependencies(e,t){if(!e||typeof e!="function")return[];let n=[];try{let r=e.toString(),s=Array.from(r.matchAll(/state\.(\w+)/g));for(let i of s)i[1]&&!n.includes(i[1])&&n.push(i[1]);if(n.length===0)try{let i=this.createDependencyTracker(n);e(i)}catch{}}catch(r){console.debug("Dependency analysis failed:",r)}return n}createTrackingProxy(e,t){let n=this;return new Proxy(e,{get(r,s){typeof s=="string"&&!t.includes(s)&&t.push(s);let i=r[s];return i&&typeof i=="object"?n.createTrackingProxy(i,t):i},has(r,s){return typeof s=="string"&&!t.includes(s)&&t.push(s),s in r}})}parseStaticDependencies(e){let t=[];try{let n=Array.from(e.matchAll(/state\.(\w+)/g));for(let i of n)i[1]&&!t.includes(i[1])&&t.push(i[1]);let r=Array.from(e.matchAll(/\$\{state\.(\w+)\}/g));for(let i of r)i[1]&&!t.includes(i[1])&&t.push(i[1]);let s=Array.from(e.matchAll(/\{\s*(\w+)(?:\s*,\s*(\w+))*\s*\}\s*=\s*state/g));for(let i of s)for(let a=1;a<i.length;a++)i[a]&&!t.includes(i[a])&&t.push(i[a])}catch(n){console.debug("Static dependency parsing failed:",n)}return t}createDependencyTracker(e){return new Proxy({},{get(t,n){return typeof n=="string"&&!e.includes(n)&&e.push(n),new Proxy({},{get:()=>{}})}})}};async function nr(o,e,t){if(!t||t<=0||t>=o.length){let r=o.map((s,i)=>e(s,i));return Promise.all(r)}let n=new Array(o.length);for(let r=0;r<o.length;r+=t){let i=o.slice(r,r+t).map((u,c)=>{let l=r+c;return e(u,l).then(p=>({result:p,originalIndex:l}))}),a=await Promise.all(i);for(let{result:u,originalIndex:c}of a)n[c]=u}return n}var rr=class{steps=[];parallelGroups=[];analyzer=new tr;initialFields=new Set;addExecutionStep(e,t,n,r,s,i,a){let u=[],c=[],l=r||"map";if(t&&n)l="execute",u=this.analyzer.analyzeMappingDependencies(n,t),c=[`${t}Result`];else if(l==="map"&&s)c=this.analyzeMapTransformation(s),u=this.getAllProducedFields();else if(l==="parallel-map"){if(Array.isArray(s)){let d=new Set;for(let m of s)this.analyzeMapTransformation(m).forEach(f=>d.add(f));c=Array.from(d)}else s?c=this.analyzeMapTransformation(s):c=["_parallelMapResult"];u=this.getAllProducedFields()}else if(l==="merge"){if(i?.resultKey)c=[i.resultKey];else{let m=this.analyzeBranchMergeFields();c=m.length>0?m:["_mergedResult"]}e.toString().includes("_parallelResults")?u=["_parallelResults"]:u=this.getAllProducedFields()}else if(l==="parallel")c=["_parallelResults"],u=this.getAllProducedFields();else if(l==="derive")if(a?.outputFieldName&&a?.inputFieldName){c=[a.outputFieldName];let d=s?this.analyzer.analyzeMappingDependencies(s,"derive"):[];u=[a.inputFieldName,...d].filter((m,g,f)=>f.indexOf(m)===g)}else c=["_deriveResult"],u=this.getAllProducedFields();else e.toString().includes("transform(")?(l="map",u=this.getAllProducedFields(),c=["_mapResult"]):e.toString().includes("_parallelResults")&&(c=["_parallelResults"],u=this.getAllProducedFields());for(let d of u)this.getAllProducedFields().includes(d)||this.initialFields.add(d);let p={type:l,nodeName:t,dependencies:u,produces:c,stepFunction:e,stepIndex:this.steps.length};this.steps.push(p)}analyzeStepFunctionProduction(e){try{let t=this.analyzeStepFunctionSource(e);if(t.length>0&&!t.includes("_stepResult"))return t}catch(t){console.debug("Step function source analysis failed:",t)}try{let t=this.createMockState(),n=Object.keys(t),s=e(t,{mainAi:{getOptions:()=>({trace:!1}),forward:()=>Promise.resolve({text:"mock"})},mainOptions:void 0});if(s&&typeof s=="object"&&"then"in s)return this.analyzeStepFunctionSource(e);if(s&&typeof s=="object"&&!Array.isArray(s)){let a=Object.keys(s).filter(u=>!n.includes(u));if(a.length>0)return a}}catch(t){console.debug("Step function dynamic analysis failed:",t)}return this.analyzeStepFunctionSource(e)}analyzeStepFunctionSource(e){try{let t=e.toString(),n=t.match(/\{\s*\.\.\.state\s*,\s*(\w+)\s*:/g);if(n){let s=n.map(i=>{let a=i.match(/(\w+)\s*:/);return a?a[1]:null}).filter(Boolean);if(s.length>0)return s}let r=t.match(/state\.(\w+)\s*=/g);if(r){let s=r.map(i=>{let a=i.match(/state\.(\w+)\s*=/);return a?a[1]:null}).filter(Boolean);if(s.length>0)return s}}catch(t){console.debug("Step function source analysis failed:",t)}return["_stepResult"]}analyzeMapTransformation(e){try{let n=e.toString().split(/\{[\s\S]*?\}/).flatMap(()=>[])}catch{}return["_mapResult"]}createMockState(){let e={};for(let t of this.initialFields)e[t]=this.createMockValue(t);for(let t of this.steps)for(let n of t.produces)n.endsWith("Result")?e[n]={text:"mockText",value:"mockValue",result:"mockResult",data:"mockData",processedText:"mockProcessedText",sentimentValue:"mockSentiment",confidenceScore:.8,isComplex:!1,mockValue:"mockValue",responseText:"mockResponseText",inputText:"mockInputText"}:e[n]=this.createMockValue(n);return e}createMockValue(e){return e.includes("List")||e.includes("Array")||e.endsWith("s")?["mockItem1","mockItem2"]:e.includes("count")||e.includes("Count")||e.includes("index")||e.includes("Index")?0:e.includes("is")||e.includes("has")||e.includes("can")?!1:"mockValue"}analyzeBranchMergeFields(){let e=this.steps.slice(-5).filter(t=>t.type==="execute"&&t.nodeName).flatMap(t=>t.produces);return e.length>0?e:this.steps.filter(t=>t.type==="execute"&&t.nodeName).flatMap(t=>t.produces)}setInitialFields(e){this.initialFields=new Set(e),this.rebuildParallelGroups()}rebuildParallelGroups(){this.parallelGroups=[];let e=new Set,t=new Set(this.initialFields),n=0;for(;e.size<this.steps.length;){let r=[];for(let s of this.steps){if(e.has(s.stepIndex))continue;if(s.dependencies.length===0||s.dependencies.every(a=>t.has(a))){if(s.type==="merge"&&r.length>0)continue;if(r.push(s),e.add(s.stepIndex),s.type==="merge")break}}if(r.length>0){for(let s of r)s.produces.forEach(i=>t.add(i));this.parallelGroups.push({level:n,steps:r}),n++}else{let s=this.steps.filter(i=>!e.has(i.stepIndex));if(s.length>0){let i=s[0];e.add(i.stepIndex),i.produces.forEach(a=>t.add(a)),this.parallelGroups.push({level:n,steps:[i]}),n++}else break}}}getAllProducedFields(){let e=[];for(let t of this.steps)e.push(...t.produces);return e}createOptimizedExecution(e){let t=[];for(let n of this.parallelGroups)if(n.steps.length===1){let r=n.steps[0];r&&t.push(r.stepFunction)}else if(n.steps.length>1){let r=async(s,i)=>{let a=await nr(n.steps,async l=>await l.stepFunction(s,i),e);if(a.some(l=>l&&typeof l=="object"&&"_parallelResults"in l)){let l=a.find(p=>p&&typeof p=="object"&&"_parallelResults"in p);return l||s}let c=s;for(let l of a)c={...c,...l};return c};t.push(r)}return t}getOptimizedExecutionSteps(){return this.parallelGroups.length===0&&this.steps.length>0&&this.rebuildParallelGroups(),this.createOptimizedExecution()}getExecutionPlan(){return this.parallelGroups.length===0&&this.steps.length>0&&this.rebuildParallelGroups(),{totalSteps:this.steps.length,parallelGroups:this.parallelGroups.length,maxParallelism:this.steps.length===0?1:Math.max(...this.parallelGroups.map(e=>e.steps.length),0),steps:this.steps,groups:this.parallelGroups}}};var ar=require("@opentelemetry/api");var vl=o=>{console.log(o)},or=(o,e=!1)=>{if(e)return"[State hidden]";let t={};for(let[n,r]of Object.entries(o))if(typeof r=="string"&&r.length>100)t[n]=`${r.substring(0,100)}...`;else if(Array.isArray(r)&&r.length>3)t[n]=[...r.slice(0,3),`... (${r.length-3} more)`];else if(typeof r=="object"&&r!==null){let s=JSON.stringify(r);s.length>200?t[n]=`${s.substring(0,200)}...`:t[n]=r}else t[n]=r;return JSON.stringify(t,null,2)},sr=o=>o<1e3?`${o.toFixed(1)}ms`:o<6e4?`${(o/1e3).toFixed(2)}s`:`${(o/6e4).toFixed(2)}min`,Wr=(o=vl)=>{let e=new ot,t=e.gray(`${"\u2501".repeat(80)}
986
986
  `),n=e.gray(`${"\u2500".repeat(40)}
987
987
  `);return r=>{let s="";switch(r.name){case"FlowStart":s=`
988
988
  ${e.blueBright("\u{1F504} [ AXFLOW START ]")}
@@ -994,13 +994,13 @@ ${t}`,s+=`${e.white("Input Fields:")} ${e.cyan(r.inputFields.join(", "))}
994
994
  `,s+=t;break;case"StepStart":{let i=r.stepType==="execute"?"\u26A1":r.stepType==="map"?"\u{1F504}":r.stepType==="merge"?"\u{1F500}":r.stepType==="parallel"?"\u2696\uFE0F":"\u{1F4CB}";s=`${e.greenBright(`${i} [ STEP ${r.stepIndex} START ]`)} ${e.white(`(${r.stepType})`)}`,r.nodeName&&(s+=` ${e.cyanBright(`Node: ${r.nodeName}`)}`),s+=`
995
995
  `,r.dependencies.length>0&&(s+=`${e.white("Dependencies:")} ${e.gray(r.dependencies.join(", "))}
996
996
  `),r.produces.length>0&&(s+=`${e.white("Produces:")} ${e.cyan(r.produces.join(", "))}
997
- `),s+=`${e.white("State:")} ${e.gray(tr(r.state,!0))}
998
- `,s+=n;break}case"StepComplete":{let i=(r.stepType==="execute"||r.stepType==="map"||r.stepType==="merge"||r.stepType==="parallel","\u2705");s=`${e.greenBright(`${i} [ STEP ${r.stepIndex} COMPLETE ]`)} ${e.white(`(${r.stepType})`)}`,r.nodeName&&(s+=` ${e.cyanBright(`Node: ${r.nodeName}`)}`),s+=` ${e.magenta(`in ${nr(r.executionTime)}`)}
997
+ `),s+=`${e.white("State:")} ${e.gray(or(r.state,!0))}
998
+ `,s+=n;break}case"StepComplete":{let i=(r.stepType==="execute"||r.stepType==="map"||r.stepType==="merge"||r.stepType==="parallel","\u2705");s=`${e.greenBright(`${i} [ STEP ${r.stepIndex} COMPLETE ]`)} ${e.white(`(${r.stepType})`)}`,r.nodeName&&(s+=` ${e.cyanBright(`Node: ${r.nodeName}`)}`),s+=` ${e.magenta(`in ${sr(r.executionTime)}`)}
999
999
  `,r.newFields&&r.newFields.length>0&&(s+=`${e.white("New Fields:")} ${e.green(r.newFields.join(", "))}
1000
1000
  `),r.result&&r.nodeName&&(s+=`${e.white("Result:")} ${e.yellow(JSON.stringify(r.result,null,2))}
1001
1001
  `),s+=n;break}case"ParallelGroupStart":s=`${e.blueBright("\u2696\uFE0F [ PARALLEL GROUP START ]")} ${e.white(`Level ${r.groupLevel}`)}
1002
1002
  `,s+=`${e.white("Steps:")} ${e.yellow(r.stepsCount.toString())} ${e.gray(`(${r.stepTypes.join(", ")})`)}
1003
- `,s+=n;break;case"ParallelGroupComplete":s=`${e.blueBright("\u2705 [ PARALLEL GROUP COMPLETE ]")} ${e.white(`Level ${r.groupLevel}`)}`,s+=` ${e.magenta(`in ${nr(r.executionTime)}`)}
1003
+ `,s+=n;break;case"ParallelGroupComplete":s=`${e.blueBright("\u2705 [ PARALLEL GROUP COMPLETE ]")} ${e.white(`Level ${r.groupLevel}`)}`,s+=` ${e.magenta(`in ${sr(r.executionTime)}`)}
1004
1004
  `,s+=`${e.white("Steps Executed:")} ${e.yellow(r.stepsCount.toString())}
1005
1005
  `,s+=n;break;case"BranchEvaluation":s=`${e.yellow("\u{1F500} [ BRANCH EVALUATION ]")}
1006
1006
  `,s+=`${e.white("Branch Value:")} ${e.cyan(JSON.stringify(r.branchValue))}
@@ -1008,16 +1008,16 @@ ${t}`,s+=`${e.white("Input Fields:")} ${e.cyan(r.inputFields.join(", "))}
1008
1008
  `,r.hasMatchingBranch&&(s+=`${e.white("Branch Steps:")} ${e.yellow(r.branchStepsCount.toString())}
1009
1009
  `),s+=n;break;case"FlowComplete":s=`
1010
1010
  ${e.greenBright("\u2705 [ AXFLOW COMPLETE ]")}
1011
- ${t}`,s+=`${e.white("Total Time:")} ${e.magenta(nr(r.totalExecutionTime))}
1011
+ ${t}`,s+=`${e.white("Total Time:")} ${e.magenta(sr(r.totalExecutionTime))}
1012
1012
  `,s+=`${e.white("Steps Executed:")} ${e.yellow(r.stepsExecuted.toString())}
1013
1013
  `,s+=`${e.white("Output Fields:")} ${e.green(r.outputFields.join(", "))}
1014
- `,s+=`${e.white("Final State:")} ${e.gray(tr(r.finalState,!0))}
1014
+ `,s+=`${e.white("Final State:")} ${e.gray(or(r.finalState,!0))}
1015
1015
  `,s+=t;break;case"FlowError":s=`
1016
1016
  ${e.redBright("\u274C [ AXFLOW ERROR ]")}
1017
1017
  ${t}`,r.stepIndex!==void 0&&(s+=`${e.white("Step:")} ${e.yellow(r.stepIndex.toString())}`,r.stepType&&(s+=` ${e.gray(`(${r.stepType})`)}`),r.nodeName&&(s+=` ${e.cyan(`Node: ${r.nodeName}`)}`),s+=`
1018
1018
  `),s+=`${e.white("Error:")} ${e.red(r.error)}
1019
- `,r.state&&(s+=`${e.white("State:")} ${e.gray(tr(r.state,!0))}
1020
- `),s+=t;break;default:s=e.gray(JSON.stringify(r,null,2))}o(s)}},fu=(o=gu)=>{let e="=".repeat(80),t="-".repeat(40);return n=>{let r="";switch(n.name){case"FlowStart":r=`
1019
+ `,r.state&&(s+=`${e.white("State:")} ${e.gray(or(r.state,!0))}
1020
+ `),s+=t;break;default:s=e.gray(JSON.stringify(r,null,2))}o(s)}},Sl=(o=vl)=>{let e="=".repeat(80),t="-".repeat(40);return n=>{let r="";switch(n.name){case"FlowStart":r=`
1021
1021
  [ AXFLOW START ]
1022
1022
  ${e}
1023
1023
  `,r+=`Input Fields: ${n.inputFields.join(", ")}
@@ -1029,16 +1029,16 @@ ${e}
1029
1029
  `;break;case"StepStart":r=`[ STEP ${n.stepIndex} START ] (${n.stepType})`,n.nodeName&&(r+=` Node: ${n.nodeName}`),r+=`
1030
1030
  `,n.dependencies.length>0&&(r+=`Dependencies: ${n.dependencies.join(", ")}
1031
1031
  `),n.produces.length>0&&(r+=`Produces: ${n.produces.join(", ")}
1032
- `),r+=`State: ${tr(n.state,!0)}
1032
+ `),r+=`State: ${or(n.state,!0)}
1033
1033
  `,r+=`${t}
1034
- `;break;case"StepComplete":r=`[ STEP ${n.stepIndex} COMPLETE ] (${n.stepType})`,n.nodeName&&(r+=` Node: ${n.nodeName}`),r+=` in ${nr(n.executionTime)}
1034
+ `;break;case"StepComplete":r=`[ STEP ${n.stepIndex} COMPLETE ] (${n.stepType})`,n.nodeName&&(r+=` Node: ${n.nodeName}`),r+=` in ${sr(n.executionTime)}
1035
1035
  `,n.newFields&&n.newFields.length>0&&(r+=`New Fields: ${n.newFields.join(", ")}
1036
1036
  `),n.result&&n.nodeName&&(r+=`Result: ${JSON.stringify(n.result,null,2)}
1037
1037
  `),r+=`${t}
1038
1038
  `;break;case"ParallelGroupStart":r=`[ PARALLEL GROUP START ] Level ${n.groupLevel}
1039
1039
  `,r+=`Steps: ${n.stepsCount} (${n.stepTypes.join(", ")})
1040
1040
  `,r+=`${t}
1041
- `;break;case"ParallelGroupComplete":r=`[ PARALLEL GROUP COMPLETE ] Level ${n.groupLevel} in ${nr(n.executionTime)}
1041
+ `;break;case"ParallelGroupComplete":r=`[ PARALLEL GROUP COMPLETE ] Level ${n.groupLevel} in ${sr(n.executionTime)}
1042
1042
  `,r+=`Steps Executed: ${n.stepsCount}
1043
1043
  `,r+=`${t}
1044
1044
  `;break;case"BranchEvaluation":r=`[ BRANCH EVALUATION ]
@@ -1049,21 +1049,21 @@ ${e}
1049
1049
  `;break;case"FlowComplete":r=`
1050
1050
  [ AXFLOW COMPLETE ]
1051
1051
  ${e}
1052
- `,r+=`Total Time: ${nr(n.totalExecutionTime)}
1052
+ `,r+=`Total Time: ${sr(n.totalExecutionTime)}
1053
1053
  `,r+=`Steps Executed: ${n.stepsExecuted}
1054
1054
  `,r+=`Output Fields: ${n.outputFields.join(", ")}
1055
- `,r+=`Final State: ${tr(n.finalState,!0)}
1055
+ `,r+=`Final State: ${or(n.finalState,!0)}
1056
1056
  `,r+=`${e}
1057
1057
  `;break;case"FlowError":r=`
1058
1058
  [ AXFLOW ERROR ]
1059
1059
  ${e}
1060
1060
  `,n.stepIndex!==void 0&&(r+=`Step: ${n.stepIndex}`,n.stepType&&(r+=` (${n.stepType})`),n.nodeName&&(r+=` Node: ${n.nodeName}`),r+=`
1061
1061
  `),r+=`Error: ${n.error}
1062
- `,n.state&&(r+=`State: ${tr(n.state,!0)}
1062
+ `,n.state&&(r+=`State: ${or(n.state,!0)}
1063
1063
  `),r+=`${e}
1064
- `;break;default:r=JSON.stringify(n,null,2)}o(r)}},hu=Kr(),xu=o=>{let e=new Map;return{logger:o,startTiming:t=>{e.set(t,Date.now())},endTiming:t=>{let n=e.get(t);if(!n)return 0;let r=Date.now()-n;return e.delete(t),r},getCurrentTime:()=>Date.now()}};var rr=class{constructor(e){this.nodeGenerators=e}steps=[];execute(e,t,n){let r=this.nodeGenerators.get(e);if(!r)throw new Error(`Node program for '${e}' not found.`);return this.steps.push(async(s,i)=>{let a=n?.ai??i.mainAi,l=n?.options??i.mainOptions,c=t(s),u=l?.traceLabel?`Node:${e} (${l.traceLabel})`:`Node:${e}`,p;if("forward"in r&&typeof r.forward=="function")p=await r.forward(a,c,{...l,traceLabel:u});else throw new Error(`Node program for '${e}' does not have a forward method`);return{...s,[`${e}Result`]:p}}),this}map(e){return this.steps.push(t=>e(t)),this}async executeSteps(e,t){let n=e;for(let r of this.steps)n=await r(n,t);return n}},Rs=class{constructor(e){this.nodeGenerators=e}steps=[];execute(e,t,n){let r=this.nodeGenerators.get(e);if(!r)throw new Error(`Node program for '${e}' not found.`);return this.steps.push(async(s,i)=>{let a=n?.ai??i.mainAi,l=n?.options??i.mainOptions,c=t(s),u=l?.traceLabel?`Node:${e} (${l.traceLabel})`:`Node:${e}`,p;if("forward"in r&&typeof r.forward=="function")p=await r.forward(a,c,{...l,traceLabel:u});else throw new Error(`Node program for '${e}' does not have a forward method`);return{...s,[`${e}Result`]:p}}),this}map(e){return this.steps.push(t=>e(t)),this}async executeSteps(e,t){let n=e;for(let r of this.steps)n=await r(n,t);return n}};var Wr=class o{static _ctorWarned=!1;nodes=new Map;flowDefinition=[];nodeGenerators=new Map;loopStack=[];stepLabels=new Map;branchContext=null;autoParallelConfig;executionPlanner=new er;program;flowName;nodeUsage=new Map;nodeTraces=new Map;flowLogger;timingLogger;defaultAIOptions;activeAbortControllers=new Set;_stopRequested=!1;toCamelCase(e){return e.replace(/_([a-z])/g,(t,n)=>n.toUpperCase())}stop(){this._stopRequested=!0;for(let e of this.activeAbortControllers)e.abort("Stopped by user")}extractInputValues(e){if(!Array.isArray(e))return e;let t=e.filter(n=>n.role==="user").pop();if(!t)throw new Error("No user message found in values array");return t.values}getCacheKey(e,t){if(!t)return;this.ensureProgram();let n=this.program.getSignature(),r=n.getInputFields().map(l=>l.name),s=this.extractInputValues(e),i=pt("sha256");i.update(n.hash()??"");let a=l=>{let c=typeof l;if(i.update(`|${c}|`),l==null){i.update("null");return}if(c==="string"||c==="number"||c==="boolean"){i.update(String(l));return}if(Array.isArray(l)){i.update("[");for(let u of l)a(u);i.update("]");return}if(typeof l=="object"&&l!==null&&"mimeType"in l&&"data"in l){let u=l;i.update(u.mimeType??"");let p=pt("sha256").update(u.data??"").digest("hex");i.update(p);return}if(typeof l=="object"){let u=l,p=Object.keys(u).sort();for(let d of p)i.update(`{${d}}`),a(u[d]);return}i.update(String(l))};for(let l of r)a(s?.[l]);return i.digest("hex")}async executeStepsWithLogging(e,t,n,r){let s={...t},i=0;for(let a=0;a<e.length;a++){let l=e[a];if(!l)continue;let c=n.mainOptions?.abortSignal;if(c?.aborted)throw new Pe("flow-between-steps",c.reason??"Flow aborted between steps");let u=this.getStepType(l,a),p=this.getStepMetadata(l,a),d=Object.keys(s);this.flowLogger&&this.flowLogger({name:"StepStart",timestamp:Date.now(),stepIndex:a,stepType:u,nodeName:p.nodeName,dependencies:p.dependencies,produces:p.produces,state:{...s}});let m=Date.now();this.timingLogger?.startTiming(`step-${a}`);try{s=await l(s,n),i++;let f=this.timingLogger?.endTiming(`step-${a}`)??Date.now()-m,A=Object.keys(s).filter(b=>!d.includes(b)),h;if(u==="execute"&&p.nodeName&&A.length>0){let b=`${p.nodeName}Result`;h=s[b]}this.flowLogger&&this.flowLogger({name:"StepComplete",timestamp:Date.now(),stepIndex:a,stepType:u,nodeName:p.nodeName,executionTime:f,state:{...s},newFields:A,result:h})}catch(g){throw this.flowLogger&&this.flowLogger({name:"FlowError",timestamp:Date.now(),error:g instanceof Error?g.message:String(g),stepIndex:a,stepType:u,nodeName:p.nodeName,state:{...s}}),g}}return{finalState:s,stepsExecuted:i}}getStepType(e,t){let n=this.executionPlanner.getExecutionPlan().steps.find(s=>s.stepIndex===t);if(n)return n.type;let r=e.toString();return r.includes("nodeName")||r.includes("nodeProgram")?"execute":r.includes("_parallelResults")||r.includes("processBatches")?"parallel":r.includes("branchValue")||r.includes("branches.get")||r.includes("mergeFunction")?"merge":r.includes("transform(")||r.includes("...state,")?"map":r.includes("inputValue")&&r.includes("transformFn")?"derive":r.includes("condition(")&&r.includes("iterations")?r.includes("while")?"while":"feedback":r.includes("branchSteps")||r.includes("currentState")?"branch":"other"}getStepMetadata(e,t){let r=this.executionPlanner.getExecutionPlan().steps.find(a=>a.stepIndex===t);if(r)return{nodeName:r.nodeName,dependencies:r.dependencies,produces:r.produces};let s=e.toString();return{nodeName:this.extractNodeNameFromSource(s),dependencies:[],produces:[]}}extractNodeNameFromSource(e){let t=e.match(/nodeName['"]?\s*[=:]\s*['"](\w+)['"]/);if(t)return t[1];let n=e.match(/nodeProgram\.get\(['"](\w+)['"]\)/);if(n)return n[1]}inferSignatureFromFlow(){let e=this.executionPlanner.getExecutionPlan();if(this.nodeGenerators.size===0&&e.steps.length===0)return ue().input("userInput",ue.string("User input to the flow")).output("flowOutput",ue.string("Output from the flow")).build();let t=new Set,n=new Set;for(let u of e.steps)u.produces.forEach(p=>t.add(p)),u.dependencies.forEach(p=>n.add(p));let r=new Set;for(let u of Array.from(n))t.has(u)||r.add(u);let s=new Set,i=e.steps[e.steps.length-1];if(i&&(i.type==="map"||i.type==="merge")){if(i.produces.forEach(u=>{u.startsWith("_")||s.add(u)}),i.type==="merge"&&i.produces.includes("_mergedResult"))for(let u of e.steps)u.type==="execute"&&u.produces.length>0&&u.produces.forEach(p=>s.add(p))}else for(let u of Array.from(t)){let p=!1;for(let d of e.steps)if(d.dependencies.includes(u)){p=!0;break}if(!p)if(u.endsWith("Result")){let d=u.replace("Result",""),m=this.nodeGenerators.get(d);if(m){let f=m.getSignature().getOutputFields();for(let x of f)s.add(x.name)}else s.add(u)}else s.add(u)}if(r.size===0&&s.size===0){let u=[],p=[];for(let[m,g]of Array.from(this.nodeGenerators)){let f=g.getSignature();for(let x of f.getInputFields()){let A=this.toCamelCase(`${m}_${x.name}`);u.push({name:A,type:x.type,description:x.description,isOptional:x.isOptional,isInternal:x.isInternal})}for(let x of f.getOutputFields()){let A=this.toCamelCase(`${m}_${x.name}`);p.push({name:A,type:x.type,description:x.description,isOptional:x.isOptional,isInternal:x.isInternal})}}let d=new Ne;return u.length>0?d.setInputFields(u):d.addInputField({name:"userInput",type:{name:"string"},description:"User input to the flow"}),p.length>0?d.setOutputFields(p):d.addOutputField({name:"flowOutput",type:{name:"string"},description:"Output from the flow"}),d}let a=new Ne,l=[];for(let u of Array.from(r))l.push({name:u,type:{name:"string"},description:`Input field: ${u}`});l.length===0&&l.push({name:"userInput",type:{name:"string"},description:"User input to the flow"});let c=[];for(let u of Array.from(s))u.startsWith("_")||c.push({name:u,type:{name:"string"},description:`Output field: ${u}`});return c.length===0&&c.push({name:"flowOutput",type:{name:"string"},description:"Output from the flow"}),a.setInputFields(l),a.setOutputFields(c),a}constructor(e){o._ctorWarned||(console.warn("[AxFlow] new AxFlow() is deprecated. Use flow() factory instead."),o._ctorWarned=!0),this.autoParallelConfig={enabled:e?.autoParallel!==!1,batchSize:e?.batchSize||10},e?.logger?this.flowLogger=e.logger:e?.debug===!0?this.flowLogger=Kr():this.flowLogger=void 0,this.timingLogger=this.flowLogger?xu(this.flowLogger):void 0,(e?.tracer||e?.meter)&&(this.defaultAIOptions={tracer:e.tracer,meter:e.meter})}static create(e){return new o(e)}ensureProgram(){let e=this.inferSignatureFromFlow();if(!this.program){this.program=new qt(e);for(let[t,n]of Array.from(this.nodeGenerators))this.program.register(n,t);return}this.program.setSignature(e)}getId(){return this.ensureProgram(),this.program.getId()}setId(e){this.ensureProgram(),this.program.setId(e)}namedPrograms(){return this.ensureProgram(),this.program.namedPrograms()}namedProgramInstances(){return this.ensureProgram(),this.program.namedProgramInstances()}getTraces(){let e=[];for(let[t,n]of Array.from(this.nodeTraces))e.push(...n);return e}setDemos(e,t){this.ensureProgram(),this.program.setDemos(e,t)}description(e,t){return this.ensureProgram(),this.flowName=e,this.program.setDescription(t),this}toFunction(){this.ensureProgram();let e=this.program.getSignature(),n=(this.flowName??(e.getDescription()?.trim().split(`
1065
- `)[0]||"axFlow")).replace(/\s+/g,"_"),r=this.toCamelCase(n),s=async(i,a)=>{let l=a?.ai;if(!l)throw new Error("AI service is required to run the flow");let c=await this.forward(l,i??{}),u=e.getOutputFields(),p=c??{};return Object.keys(p).map(d=>{let m=u.find(g=>g.name===d);return m&&m.title?`${m.title}: ${p[d]}`:`${d}: ${p[d]}`}).join(`
1066
- `)};return{name:r,description:e.getDescription()??"Execute this AxFlow",parameters:e.toJSONSchema(),func:s}}getUsage(){let e=[];for(let[t,n]of Array.from(this.nodeUsage))e.push(...n);return _r(e)}resetUsage(){this.nodeUsage.clear();for(let[e,t]of Array.from(this.nodeGenerators))t&&"resetUsage"in t&&t.resetUsage()}resetTraces(){this.nodeTraces.clear()}getUsageReport(){let e={};for(let[t,n]of Array.from(this.nodeUsage))e[t]=_r(n);return e}getNodePrograms(){return Array.from(this.nodeGenerators).map(([e,t])=>({name:e,program:t}))}setNodeInstruction(e,t){let n=this.nodeGenerators.get(e);if(!n)return!1;let r=n;if(typeof r.setInstruction=="function")try{return r.setInstruction(t),!0}catch{return!1}return!1}setAllNodeInstructions(e){for(let[t,n]of Object.entries(e))this.setNodeInstruction(t,n)}getTracesReport(){let e={};for(let[t,n]of Array.from(this.nodeTraces))e[t]=n;return e}async*streamingForward(e,t,n){let r=n?.cachingFunction??de.cachingFunction,s=this.getCacheKey(t,r);if(r&&s){let a;try{a=await r(s)}catch{}if(a!==void 0){yield{version:0,index:0,delta:a};return}}let i=await this.forward(e,t,n);if(r&&s)try{await r(s,i)}catch{}yield{version:1,index:0,delta:i}}async forward(e,t,n){let r=n?.cachingFunction??de.cachingFunction,s=this.getCacheKey(t,r);if(r&&s){let u;try{u=await r(s)}catch{}if(u!==void 0)return u}let i=Date.now();this.timingLogger?.startTiming("flow-execution");let a={},l,c;try{this.resetUsage(),this.resetTraces();let u=this.extractInputValues(t);if(this.nodeGenerators.size>0&&this.ensureProgram(),a={...u},this.flowLogger){let b=this.getExecutionPlan();this.flowLogger({name:"FlowStart",timestamp:i,inputFields:Object.keys(u),totalSteps:b.totalSteps,parallelGroups:b.parallelGroups,maxParallelism:b.maxParallelism,autoParallelEnabled:b.autoParallelEnabled})}let p=n?.tracer??this.defaultAIOptions?.tracer,d=n?.traceContext,m=d;if(p){let b=this.getExecutionPlan(),T=n?.traceLabel?`AxFlow > ${n.traceLabel}`:"AxFlow";l=p.startSpan(T,{kind:or.SpanKind.INTERNAL,attributes:{total_steps:b.totalSteps,parallel_groups:b.parallelGroups,max_parallelism:b.maxParallelism,auto_parallel_enabled:b.autoParallelEnabled}});let C=d??or.context.active();m=or.trace.setSpan(C,l)}c=new AbortController,this.activeAbortControllers.add(c),this._stopRequested&&c.abort("Stopped by user (pre-forward)");let g=vt(n?.abortSignal,n?.abortController?.signal),f=vt(c.signal,vt(g,de.abortSignal)),x={mainAi:e,mainOptions:(()=>{let b={...this.defaultAIOptions??{},...n};return n?.model&&(b.model=String(n.model)),p&&(b.tracer=p),m&&(b.traceContext=m),f&&(b.abortSignal=f),Object.keys(b).length>0?b:void 0})()},A=n?.autoParallel!==!1&&this.autoParallelConfig.enabled,h=0;if(A){this.executionPlanner.setInitialFields(Object.keys(u));let b=this.executionPlanner.createOptimizedExecution(this.autoParallelConfig.batchSize),T=await this.executeStepsWithLogging(b,a,x,!0);a=T.finalState,h=T.stepsExecuted}else{let b=await this.executeStepsWithLogging(this.flowDefinition,a,x,!1);a=b.finalState,h=b.stepsExecuted}if(this.flowLogger){let b=this.timingLogger?.endTiming("flow-execution")??Date.now()-i;this.flowLogger({name:"FlowComplete",timestamp:Date.now(),totalExecutionTime:b,finalState:a,outputFields:Object.keys(a),stepsExecuted:h})}if(r&&s)try{await r(s,a)}catch{}return a}catch(u){throw this.flowLogger&&this.flowLogger({name:"FlowError",timestamp:Date.now(),error:u instanceof Error?u.message:String(u),state:a}),u}finally{l&&l.end(),c&&this.activeAbortControllers.delete(c),this._stopRequested=!1}}node(e,t){if(this.nodes.has(e)||this.nodeGenerators.has(e))throw new Error(`Node '${e}' is already defined. Use a unique node name in this flow.`);if(typeof t=="string"||t instanceof Ne){let n=t;if(!n)throw new Error(`Invalid signature for node '${e}': signature cannot be empty`);this.nodes.set(e,{inputs:{},outputs:{}});let r=st(n);this.nodeGenerators.set(e,r),this.ensureProgram(),this.program.register(r,e)}else if(typeof t=="function"){this.nodes.set(e,{inputs:{},outputs:{}});let n=new t;this.nodeGenerators.set(e,n),this.ensureProgram(),this.program.register(n,e)}else if(t&&typeof t=="object"&&"forward"in t){this.nodes.set(e,{inputs:{},outputs:{}});let n=t;this.nodeGenerators.set(e,n),this.ensureProgram(),this.program.register(n,e)}else throw new Error(`Invalid second argument for node '${e}': expected string, AxSignature, AxProgrammable instance, or constructor function`);return this}n(e,t){return this.node(e,t)}map(e,t){if(t?.parallel){let n=Array.isArray(e)?e:[e],r=async s=>(await Zn(n,async(l,c)=>{let u=l(s);return Promise.resolve(u)},this.autoParallelConfig.batchSize)).reduce((l,c)=>({...l,...c}),s);if(this.branchContext?.currentBranchValue!==void 0){let s=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];s.push(r),this.branchContext.branches.set(this.branchContext.currentBranchValue,s)}else this.flowDefinition.push(r),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(r,void 0,void 0,"parallel-map",n)}else{let n=async r=>{if(Array.isArray(e))throw new Error("Array of transforms requires parallel: true option");let s=e(r);return Promise.resolve(s)};if(this.branchContext?.currentBranchValue!==void 0){let r=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];r.push(n),this.branchContext.branches.set(this.branchContext.currentBranchValue,r)}else this.flowDefinition.push(n),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(n,void 0,void 0,"map",e)}return this.nodeGenerators.size>0&&this.ensureProgram(),this}m(e,t){return this.map(e,t)}returns(e){let t=async n=>{let r=e(n);return Promise.resolve(r)};if(this.branchContext?.currentBranchValue!==void 0){let n=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];n.push(t),this.branchContext.branches.set(this.branchContext.currentBranchValue,n)}else this.flowDefinition.push(t),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(t,void 0,void 0,"map",e);return this.nodeGenerators.size>0&&this.ensureProgram(),this}r(e){return this.returns(e)}label(e){if(this.branchContext?.currentBranchValue!==void 0)throw new Error("Cannot create labels inside branch blocks");return this.stepLabels.set(e,this.flowDefinition.length),this}l(e){return this.label(e)}execute(e,t,n){if(!this.nodes.has(e))throw new Error(`Node '${e}' not found. Make sure to define it with .node() first.`);let r=this.nodeGenerators.get(e);if(!r)throw new Error(`Node program for '${e}' not found.`);let s=async(i,a)=>{let l=n?.ai??a.mainAi,c={...a.mainOptions??{},...n?.options??{}},u=t(i),p=c?.traceLabel?`Node:${e} (${c.traceLabel})`:`Node:${e}`,d;if("forward"in r&&typeof r.forward=="function"){if(d=await r.forward(l,u,{...c,traceLabel:p}),"getUsage"in r&&typeof r.getUsage=="function"){let m=r.getUsage();if(m&&m.length>0){let g=this.nodeUsage.get(e)||[];this.nodeUsage.set(e,[...g,...m])}}if("getTraces"in r&&typeof r.getTraces=="function"){let m=r.getTraces();if(m&&m.length>0){let g=this.nodeTraces.get(e)||[];this.nodeTraces.set(e,[...g,...m])}}}else throw new Error(`Node program for '${e}' does not have a forward method`);return{...i,[`${e}Result`]:d}};if(this.branchContext?.currentBranchValue!==void 0){let i=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];i.push(s),this.branchContext.branches.set(this.branchContext.currentBranchValue,i)}else this.flowDefinition.push(s),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(s,e,t);return this.ensureProgram(),this}applyOptimization(e){this.program&&"applyOptimization"in this.program&&this.program.applyOptimization(e)}e(e,t,n){return this.execute(e,t,n)}branch(e){if(this.branchContext)throw new Error("Nested branches are not supported");return this.branchContext={predicate:t=>e(t),branches:new Map,currentBranchValue:void 0},this}b(e){return this.branch(e)}when(e){if(!this.branchContext)throw new Error("when() called without matching branch()");return this.branchContext.currentBranchValue=e,this.branchContext.branches.set(e,[]),this}w(e){return this.when(e)}merge(){if(!this.branchContext)throw new Error("merge() called without matching branch()");let e=this.branchContext;this.branchContext=null;let t=async(n,r)=>{let s=e.predicate(n),i=e.branches.get(s);if(this.flowLogger&&this.flowLogger({name:"BranchEvaluation",timestamp:Date.now(),branchValue:s,hasMatchingBranch:!!i,branchStepsCount:i?.length??0}),!i)return n;let a=n;for(let l of i)a=await l(a,r);return a};return this.flowDefinition.push(t),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(t,void 0,void 0,"merge"),this.ensureProgram(),this}mg(){return this.merge()}parallel(e){let t=async(n,r)=>{let s=await Zn(e,async(i,a)=>{let l=new rr(this.nodeGenerators);return await i(l).executeSteps(n,r)},this.autoParallelConfig.batchSize);return{...n,_parallelResults:s}};return this.flowDefinition.push(t),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(t,void 0,void 0,"parallel",void 0,void 0),this.ensureProgram(),{merge:(n,r)=>{let s=i=>{let a=i._parallelResults;if(!Array.isArray(a))throw new Error("No parallel results found for merge");let l=r(...a),c={...i};return delete c._parallelResults,c[n]=l,c};return this.flowDefinition.push(s),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(s,void 0,void 0,"merge",void 0,{resultKey:n,mergeFunction:r}),this.ensureProgram(),this}}}p(e){return this.parallel(e)}feedback(e,t,n=10){if(!this.stepLabels.has(t))throw new Error(`Label '${t}' not found. Make sure to define it with .label() before the feedback point.`);let r=this.stepLabels.get(t),s=this.flowDefinition.length;return this.flowDefinition.push(async(i,a)=>{let l=i,c=1,u=`_feedback_${t}_iterations`;for(typeof l[u]!="number"&&(l={...l,[u]:1});e(l)&&c<n;){c++,l={...l,[u]:c};for(let p=r;p<s;p++){let d=this.flowDefinition[p];d&&(l=await d(l,a))}}return l}),this.nodeGenerators.size>0&&this.ensureProgram(),this}fb(e,t,n=10){return this.feedback(e,t,n)}while(e,t=100){let n=this.flowDefinition.length;this.loopStack.push(n);let r=Object.assign(s=>s,{_condition:e,_maxIterations:t,_isLoopStart:!0});return this.flowDefinition.push(r),this.nodeGenerators.size>0&&this.ensureProgram(),this}wh(e,t=100){return this.while(e,t)}endWhile(){if(this.loopStack.length===0)throw new Error("endWhile() called without matching while()");let e=this.loopStack.pop(),t=this.flowDefinition[e];if(!t||!("_isLoopStart"in t))throw new Error("Loop start step not found or invalid");let n=t._condition,r=t._maxIterations,s=this.flowDefinition.splice(e+1);return this.flowDefinition[e]=async(i,a)=>{let l=i,c=0;for(;n(l)&&c<r;){c++;for(let u of s)l=await u(l,a)}if(c>=r&&n(l))throw new Error(`While loop exceeded maximum iterations (${r}). Consider increasing maxIterations or ensuring the loop condition eventually becomes false.`);return l},this.nodeGenerators.size>0&&this.ensureProgram(),this}end(){return this.endWhile()}derive(e,t,n,r){let s=async i=>{let a=i[t];if(a===void 0)throw new Error(`Input field '${t}' not found in state`);let l;if(Array.isArray(a))if(this.autoParallelConfig.enabled){let c=r?.batchSize||this.autoParallelConfig.batchSize;l=await Zn(a,async(u,p)=>n(u,p,i),c)}else l=a.map((c,u)=>n(c,u,i));else l=n(a,void 0,i);return{...i,[e]:l}};if(this.branchContext?.currentBranchValue!==void 0){let i=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];i.push(s),this.branchContext.branches.set(this.branchContext.currentBranchValue,i)}else this.flowDefinition.push(s),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(s,void 0,void 0,"derive",n,void 0,{inputFieldName:t,outputFieldName:e,batchSize:r?.batchSize});return this.ensureProgram(),this}getExecutionPlan(){let e=this.executionPlanner.getExecutionPlan();return{totalSteps:e.totalSteps,parallelGroups:e.parallelGroups,maxParallelism:e.maxParallelism,autoParallelEnabled:this.autoParallelConfig.enabled,steps:e.steps,groups:e.groups}}getSignature(){return this.ensureProgram(),this.program.getSignature()}nodeExtended(e,t,n){let s=typeof t=="string"?Ne.create(t):t;if(n.prependInputs)for(let i of n.prependInputs)s=s.prependInputField(i.name,i.type);if(n.appendInputs)for(let i of n.appendInputs)s=s.appendInputField(i.name,i.type);if(n.prependOutputs)for(let i of n.prependOutputs)s=s.prependOutputField(i.name,i.type);if(n.appendOutputs)for(let i of n.appendOutputs)s=s.appendOutputField(i.name,i.type);return this.node(e,s)}nx(e,t,n){return this.nodeExtended(e,t,n)}mapOutput(e){let t=async n=>{let r=e(n);return{...n,...r}};if(this.branchContext?.currentBranchValue!==void 0){let n=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];n.push(t),this.branchContext.branches.set(this.branchContext.currentBranchValue,n)}else this.flowDefinition.push(t),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(t,void 0,void 0,"map",e);return this.nodeGenerators.size>0&&this.ensureProgram(),this}mo(e){return this.mapOutput(e)}};function vs(o){return Wr.create(o)}var Ss=class{apiUrl;containerId=null;constructor(e="http://localhost:2375"){this.apiUrl=e}async pullImage(e){let t=await this.fetchDockerAPI(`/images/create?fromImage=${encodeURIComponent(e)}`,{method:"POST"});if(!t.ok)throw new Error(`Failed to pull image: ${t.statusText}`);await t.text()}async createContainer({imageName:e,volumes:t=[],doNotPullImage:n,tag:r}){let s=t.map(c=>`${c.hostPath}:${c.containerPath}`);n||await this.pullImage(e);let i={Image:e,Tty:!0,OpenStdin:!1,AttachStdin:!1,AttachStdout:!1,AttachStderr:!1,HostConfig:{Binds:s},Labels:{}};r&&(i.Labels["com.example.tag"]=r);let a=await this.fetchDockerAPI("/containers/create",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(i)});if(!a.ok)throw new Error(`Failed to create container: ${a.statusText}`);let l=await a.json();return this.containerId=l.Id,l}async findOrCreateContainer({imageName:e,volumes:t=[],doNotPullImage:n,tag:r}){let i=(await this.listContainers(!0)).filter(l=>l.Labels&&l.Labels["com.example.tag"]===r);if(i&&i.length>0){let l=Math.floor(Math.random()*i.length),c=i[l];if(c)return await this.connectToContainer(c.Id),{Id:c.Id,isNew:!1}}return{Id:(await this.createContainer({imageName:e,volumes:t,doNotPullImage:n,tag:r})).Id,isNew:!0}}async startContainer(){if(!this.containerId)throw new Error("No container created or connected");let e=await this.fetchDockerAPI(`/containers/${this.containerId}/start`,{method:"POST"});if(!e.ok)throw new Error(`Failed to start container: ${e.statusText}`)}async connectToContainer(e){let t=await this.fetchDockerAPI(`/containers/${e}/json`);if(!t.ok)throw new Error(`Failed to connect to container: ${t.statusText}`);this.containerId=e}async stopContainers({tag:e,remove:t,timeout:n=10}){let r=[],s=await this.listContainers(!0),i=e?s.filter(a=>a.Labels["com.example.tag"]===e):s;for(let a of i){if(a.State.Status==="running"){let l=await this.fetchDockerAPI(`/containers/${a.Id}/stop?t=${n}`,{method:"POST"});if(!l.ok){console.warn(`Failed to stop container ${a.Id}: ${l.statusText}`);continue}r.push({Id:a.Id,Action:"stopped"})}if(t){let l=await this.fetchDockerAPI(`/containers/${a.Id}`,{method:"DELETE"});if(!l.ok){console.warn(`Failed to remove container ${a.Id}: ${l.statusText}`);continue}r.push({Id:a.Id,Action:"removed"})}}return r}async listContainers(e=!1){return(await this.fetchDockerAPI(`/containers/json?all=${e}`,{method:"GET"})).json()}async getContainerLogs(){if(!this.containerId)throw new Error("No container created or connected");return(await this.fetchDockerAPI(`/containers/${this.containerId}/logs?stdout=true&stderr=true`,{method:"GET"})).text()}async executeCommand(e){if(!this.containerId)throw new Error("No container created or connected");(await this.getContainerInfo(this.containerId)).State.Status!=="running"&&(await this.startContainer(),await this.waitForContainerToBeRunning(this.containerId));let n=await this.fetchDockerAPI(`/containers/${this.containerId}/exec`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({Cmd:["sh","-c",e],AttachStdout:!0,AttachStderr:!0})});if(!n.ok)throw new Error(`Failed to create exec instance: ${n.statusText}`);let r=await n.json(),s=await this.fetchDockerAPI(`/exec/${r.Id}/start`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({Detach:!1,Tty:!1})});if(!s.ok)throw new Error(`Failed to start exec instance: ${s.statusText}`);return await s.text()}async getContainerInfo(e){let t=await this.fetchDockerAPI(`/containers/${e}/json`);if(!t.ok)throw new Error(`Failed to get container info: ${t.statusText}`);return t.json()}async waitForContainerToBeRunning(e,t=3e4){let n=Date.now();for(;Date.now()-n<t;){if((await this.getContainerInfo(e)).State.Status==="running")return;await new Promise(s=>setTimeout(s,1e3))}throw new Error("Timeout waiting for container to start")}async fetchDockerAPI(e,t){let n=new URL(e,this.apiUrl).toString();return await fetch(n,t)}toFunction(){return{name:"commandExecution",description:"Use this function to execute shell commands, scripts, and programs. This function enables interaction with the file system, running system utilities, and performing tasks that require a shell interface.",parameters:{type:"object",properties:{command:{type:"string",description:'Shell command to execute. eg. `ls -l` or `echo "Hello, World!"`.'}},required:["command"]},func:async({command:e})=>await this.executeCommand(e)}}};var ks=class{aiService;info;func;constructor({ai:e,info:t,func:n}){this.aiService=e,this.info=t,this.func=n}async embedAdapter(e,t){let r=(await this.aiService.embed({texts:[e]},{sessionId:t?.sessionId,abortSignal:t?.abortSignal})).embeddings.at(0);if(!r)throw new Error("Failed to embed text");return this.func.length===2?this.func(r,t):this.func(r)}toFunction(){return{name:this.info.name,description:this.info.description,parameters:{type:"object",properties:{text:{type:"string",description:this.info.argumentDescription}},required:["text"]},func:({text:e},t)=>this.embedAdapter(e,t)}}};function an(o){return!!o&&/[A-Za-z0-9_$]/.test(o)}function Au(o){return!!o&&/[A-Za-z_$]/.test(o)}function Ft(o){let e="",t=0,n="normal",r=!1;for(;t<o.length;){let s=o[t]??"",i=o[t+1]??"";if(n==="lineComment"){s===`
1064
+ `;break;default:r=JSON.stringify(n,null,2)}o(r)}},kl=Wr(),Ol=o=>{let e=new Map;return{logger:o,startTiming:t=>{e.set(t,Date.now())},endTiming:t=>{let n=e.get(t);if(!n)return 0;let r=Date.now()-n;return e.delete(t),r},getCurrentTime:()=>Date.now()}};var ir=class{constructor(e){this.nodeGenerators=e}steps=[];execute(e,t,n){let r=this.nodeGenerators.get(e);if(!r)throw new Error(`Node program for '${e}' not found.`);return this.steps.push(async(s,i)=>{let a=n?.ai??i.mainAi,u=n?.options??i.mainOptions,c=t(s),l=u?.traceLabel?`Node:${e} (${u.traceLabel})`:`Node:${e}`,p;if("forward"in r&&typeof r.forward=="function")p=await r.forward(a,c,{...u,traceLabel:l});else throw new Error(`Node program for '${e}' does not have a forward method`);return{...s,[`${e}Result`]:p}}),this}map(e){return this.steps.push(t=>e(t)),this}async executeSteps(e,t){let n=e;for(let r of this.steps)n=await r(n,t);return n}},Os=class{constructor(e){this.nodeGenerators=e}steps=[];execute(e,t,n){let r=this.nodeGenerators.get(e);if(!r)throw new Error(`Node program for '${e}' not found.`);return this.steps.push(async(s,i)=>{let a=n?.ai??i.mainAi,u=n?.options??i.mainOptions,c=t(s),l=u?.traceLabel?`Node:${e} (${u.traceLabel})`:`Node:${e}`,p;if("forward"in r&&typeof r.forward=="function")p=await r.forward(a,c,{...u,traceLabel:l});else throw new Error(`Node program for '${e}' does not have a forward method`);return{...s,[`${e}Result`]:p}}),this}map(e){return this.steps.push(t=>e(t)),this}async executeSteps(e,t){let n=e;for(let r of this.steps)n=await r(n,t);return n}};var Vr=class o{static _ctorWarned=!1;nodes=new Map;flowDefinition=[];nodeGenerators=new Map;loopStack=[];stepLabels=new Map;branchContext=null;autoParallelConfig;executionPlanner=new rr;program;flowName;nodeUsage=new Map;nodeTraces=new Map;flowLogger;timingLogger;defaultAIOptions;activeAbortControllers=new Set;_stopRequested=!1;toCamelCase(e){return e.replace(/_([a-z])/g,(t,n)=>n.toUpperCase())}stop(){this._stopRequested=!0;for(let e of this.activeAbortControllers)e.abort("Stopped by user")}extractInputValues(e){if(!Array.isArray(e))return e;let t=e.filter(n=>n.role==="user").pop();if(!t)throw new Error("No user message found in values array");return t.values}getCacheKey(e,t){if(!t)return;this.ensureProgram();let n=this.program.getSignature(),r=n.getInputFields().map(u=>u.name),s=this.extractInputValues(e),i=pt("sha256");i.update(n.hash()??"");let a=u=>{let c=typeof u;if(i.update(`|${c}|`),u==null){i.update("null");return}if(c==="string"||c==="number"||c==="boolean"){i.update(String(u));return}if(Array.isArray(u)){i.update("[");for(let l of u)a(l);i.update("]");return}if(typeof u=="object"&&u!==null&&"mimeType"in u&&"data"in u){let l=u;i.update(l.mimeType??"");let p=pt("sha256").update(l.data??"").digest("hex");i.update(p);return}if(typeof u=="object"){let l=u,p=Object.keys(l).sort();for(let d of p)i.update(`{${d}}`),a(l[d]);return}i.update(String(u))};for(let u of r)a(s?.[u]);return i.digest("hex")}async executeStepsWithLogging(e,t,n,r){let s={...t},i=0;for(let a=0;a<e.length;a++){let u=e[a];if(!u)continue;let c=n.mainOptions?.abortSignal;if(c?.aborted)throw new _e("flow-between-steps",c.reason??"Flow aborted between steps");let l=this.getStepType(u,a),p=this.getStepMetadata(u,a),d=Object.keys(s);this.flowLogger&&this.flowLogger({name:"StepStart",timestamp:Date.now(),stepIndex:a,stepType:l,nodeName:p.nodeName,dependencies:p.dependencies,produces:p.produces,state:{...s}});let m=Date.now();this.timingLogger?.startTiming(`step-${a}`);try{s=await u(s,n),i++;let f=this.timingLogger?.endTiming(`step-${a}`)??Date.now()-m,A=Object.keys(s).filter(y=>!d.includes(y)),h;if(l==="execute"&&p.nodeName&&A.length>0){let y=`${p.nodeName}Result`;h=s[y]}this.flowLogger&&this.flowLogger({name:"StepComplete",timestamp:Date.now(),stepIndex:a,stepType:l,nodeName:p.nodeName,executionTime:f,state:{...s},newFields:A,result:h})}catch(g){throw this.flowLogger&&this.flowLogger({name:"FlowError",timestamp:Date.now(),error:g instanceof Error?g.message:String(g),stepIndex:a,stepType:l,nodeName:p.nodeName,state:{...s}}),g}}return{finalState:s,stepsExecuted:i}}getStepType(e,t){let n=this.executionPlanner.getExecutionPlan().steps.find(s=>s.stepIndex===t);if(n)return n.type;let r=e.toString();return r.includes("nodeName")||r.includes("nodeProgram")?"execute":r.includes("_parallelResults")||r.includes("processBatches")?"parallel":r.includes("branchValue")||r.includes("branches.get")||r.includes("mergeFunction")?"merge":r.includes("transform(")||r.includes("...state,")?"map":r.includes("inputValue")&&r.includes("transformFn")?"derive":r.includes("condition(")&&r.includes("iterations")?r.includes("while")?"while":"feedback":r.includes("branchSteps")||r.includes("currentState")?"branch":"other"}getStepMetadata(e,t){let r=this.executionPlanner.getExecutionPlan().steps.find(a=>a.stepIndex===t);if(r)return{nodeName:r.nodeName,dependencies:r.dependencies,produces:r.produces};let s=e.toString();return{nodeName:this.extractNodeNameFromSource(s),dependencies:[],produces:[]}}extractNodeNameFromSource(e){let t=e.match(/nodeName['"]?\s*[=:]\s*['"](\w+)['"]/);if(t)return t[1];let n=e.match(/nodeProgram\.get\(['"](\w+)['"]\)/);if(n)return n[1]}inferSignatureFromFlow(){let e=this.executionPlanner.getExecutionPlan();if(this.nodeGenerators.size===0&&e.steps.length===0)return me().input("userInput",me.string("User input to the flow")).output("flowOutput",me.string("Output from the flow")).build();let t=new Set,n=new Set;for(let l of e.steps)l.produces.forEach(p=>t.add(p)),l.dependencies.forEach(p=>n.add(p));let r=new Set;for(let l of Array.from(n))t.has(l)||r.add(l);let s=new Set,i=e.steps[e.steps.length-1];if(i&&(i.type==="map"||i.type==="merge")){if(i.produces.forEach(l=>{l.startsWith("_")||s.add(l)}),i.type==="merge"&&i.produces.includes("_mergedResult"))for(let l of e.steps)l.type==="execute"&&l.produces.length>0&&l.produces.forEach(p=>s.add(p))}else for(let l of Array.from(t)){let p=!1;for(let d of e.steps)if(d.dependencies.includes(l)){p=!0;break}if(!p)if(l.endsWith("Result")){let d=l.replace("Result",""),m=this.nodeGenerators.get(d);if(m){let f=m.getSignature().getOutputFields();for(let x of f)s.add(x.name)}else s.add(l)}else s.add(l)}if(r.size===0&&s.size===0){let l=[],p=[];for(let[m,g]of Array.from(this.nodeGenerators)){let f=g.getSignature();for(let x of f.getInputFields()){let A=this.toCamelCase(`${m}_${x.name}`);l.push({name:A,type:x.type,description:x.description,isOptional:x.isOptional,isInternal:x.isInternal})}for(let x of f.getOutputFields()){let A=this.toCamelCase(`${m}_${x.name}`);p.push({name:A,type:x.type,description:x.description,isOptional:x.isOptional,isInternal:x.isInternal})}}let d=new Me;return l.length>0?d.setInputFields(l):d.addInputField({name:"userInput",type:{name:"string"},description:"User input to the flow"}),p.length>0?d.setOutputFields(p):d.addOutputField({name:"flowOutput",type:{name:"string"},description:"Output from the flow"}),d}let a=new Me,u=[];for(let l of Array.from(r))u.push({name:l,type:{name:"string"},description:`Input field: ${l}`});u.length===0&&u.push({name:"userInput",type:{name:"string"},description:"User input to the flow"});let c=[];for(let l of Array.from(s))l.startsWith("_")||c.push({name:l,type:{name:"string"},description:`Output field: ${l}`});return c.length===0&&c.push({name:"flowOutput",type:{name:"string"},description:"Output from the flow"}),a.setInputFields(u),a.setOutputFields(c),a}constructor(e){o._ctorWarned||(console.warn("[AxFlow] new AxFlow() is deprecated. Use flow() factory instead."),o._ctorWarned=!0),this.autoParallelConfig={enabled:e?.autoParallel!==!1,batchSize:e?.batchSize||10},e?.logger?this.flowLogger=e.logger:e?.debug===!0?this.flowLogger=Wr():this.flowLogger=void 0,this.timingLogger=this.flowLogger?Ol(this.flowLogger):void 0,(e?.tracer||e?.meter)&&(this.defaultAIOptions={tracer:e.tracer,meter:e.meter})}static create(e){return new o(e)}ensureProgram(){let e=this.inferSignatureFromFlow();if(!this.program){this.program=new Ht(e);for(let[t,n]of Array.from(this.nodeGenerators))this.program.register(n,t);return}this.program.setSignature(e)}getId(){return this.ensureProgram(),this.program.getId()}setId(e){this.ensureProgram(),this.program.setId(e)}namedPrograms(){return this.ensureProgram(),this.program.namedPrograms()}namedProgramInstances(){return this.ensureProgram(),this.program.namedProgramInstances()}getTraces(){let e=[];for(let[t,n]of Array.from(this.nodeTraces))e.push(...n);return e}setDemos(e,t){this.ensureProgram(),this.program.setDemos(e,t)}description(e,t){return this.ensureProgram(),this.flowName=e,this.program.setDescription(t),this}toFunction(){this.ensureProgram();let e=this.program.getSignature(),n=(this.flowName??(e.getDescription()?.trim().split(`
1065
+ `)[0]||"axFlow")).replace(/\s+/g,"_"),r=this.toCamelCase(n),s=async(i,a)=>{let u=a?.ai;if(!u)throw new Error("AI service is required to run the flow");let c=await this.forward(u,i??{}),l=e.getOutputFields(),p=c??{};return Object.keys(p).map(d=>{let m=l.find(g=>g.name===d);return m&&m.title?`${m.title}: ${p[d]}`:`${d}: ${p[d]}`}).join(`
1066
+ `)};return{name:r,description:e.getDescription()??"Execute this AxFlow",parameters:e.toJSONSchema(),func:s}}getUsage(){let e=[];for(let[t,n]of Array.from(this.nodeUsage))e.push(...n);return Lr(e)}resetUsage(){this.nodeUsage.clear();for(let[e,t]of Array.from(this.nodeGenerators))t&&"resetUsage"in t&&t.resetUsage()}resetTraces(){this.nodeTraces.clear()}getUsageReport(){let e={};for(let[t,n]of Array.from(this.nodeUsage))e[t]=Lr(n);return e}getNodePrograms(){return Array.from(this.nodeGenerators).map(([e,t])=>({name:e,program:t}))}setNodeInstruction(e,t){let n=this.nodeGenerators.get(e);if(!n)return!1;let r=n;if(typeof r.setInstruction=="function")try{return r.setInstruction(t),!0}catch{return!1}return!1}setAllNodeInstructions(e){for(let[t,n]of Object.entries(e))this.setNodeInstruction(t,n)}getTracesReport(){let e={};for(let[t,n]of Array.from(this.nodeTraces))e[t]=n;return e}async*streamingForward(e,t,n){let r=n?.cachingFunction??ge.cachingFunction,s=this.getCacheKey(t,r);if(r&&s){let a;try{a=await r(s)}catch{}if(a!==void 0){yield{version:0,index:0,delta:a};return}}let i=await this.forward(e,t,n);if(r&&s)try{await r(s,i)}catch{}yield{version:1,index:0,delta:i}}async forward(e,t,n){let r=n?.cachingFunction??ge.cachingFunction,s=this.getCacheKey(t,r);if(r&&s){let l;try{l=await r(s)}catch{}if(l!==void 0)return l}let i=Date.now();this.timingLogger?.startTiming("flow-execution");let a={},u,c;try{this.resetUsage(),this.resetTraces();let l=this.extractInputValues(t);if(this.nodeGenerators.size>0&&this.ensureProgram(),a={...l},this.flowLogger){let y=this.getExecutionPlan();this.flowLogger({name:"FlowStart",timestamp:i,inputFields:Object.keys(l),totalSteps:y.totalSteps,parallelGroups:y.parallelGroups,maxParallelism:y.maxParallelism,autoParallelEnabled:y.autoParallelEnabled})}let p=n?.tracer??this.defaultAIOptions?.tracer,d=n?.traceContext,m=d;if(p){let y=this.getExecutionPlan(),C=n?.traceLabel?`AxFlow > ${n.traceLabel}`:"AxFlow";u=p.startSpan(C,{kind:ar.SpanKind.INTERNAL,attributes:{total_steps:y.totalSteps,parallel_groups:y.parallelGroups,max_parallelism:y.maxParallelism,auto_parallel_enabled:y.autoParallelEnabled}});let I=d??ar.context.active();m=ar.trace.setSpan(I,u)}c=new AbortController,this.activeAbortControllers.add(c),this._stopRequested&&c.abort("Stopped by user (pre-forward)");let g=vt(n?.abortSignal,n?.abortController?.signal),f=vt(c.signal,vt(g,ge.abortSignal)),x={mainAi:e,mainOptions:(()=>{let y={...this.defaultAIOptions??{},...n};return n?.model&&(y.model=String(n.model)),p&&(y.tracer=p),m&&(y.traceContext=m),f&&(y.abortSignal=f),Object.keys(y).length>0?y:void 0})()},A=n?.autoParallel!==!1&&this.autoParallelConfig.enabled,h=0;if(A){this.executionPlanner.setInitialFields(Object.keys(l));let y=this.executionPlanner.createOptimizedExecution(this.autoParallelConfig.batchSize),C=await this.executeStepsWithLogging(y,a,x,!0);a=C.finalState,h=C.stepsExecuted}else{let y=await this.executeStepsWithLogging(this.flowDefinition,a,x,!1);a=y.finalState,h=y.stepsExecuted}if(this.flowLogger){let y=this.timingLogger?.endTiming("flow-execution")??Date.now()-i;this.flowLogger({name:"FlowComplete",timestamp:Date.now(),totalExecutionTime:y,finalState:a,outputFields:Object.keys(a),stepsExecuted:h})}if(r&&s)try{await r(s,a)}catch{}return a}catch(l){throw this.flowLogger&&this.flowLogger({name:"FlowError",timestamp:Date.now(),error:l instanceof Error?l.message:String(l),state:a}),l}finally{u&&u.end(),c&&this.activeAbortControllers.delete(c),this._stopRequested=!1}}node(e,t){if(this.nodes.has(e)||this.nodeGenerators.has(e))throw new Error(`Node '${e}' is already defined. Use a unique node name in this flow.`);if(typeof t=="string"||t instanceof Me){let n=t;if(!n)throw new Error(`Invalid signature for node '${e}': signature cannot be empty`);this.nodes.set(e,{inputs:{},outputs:{}});let r=st(n);this.nodeGenerators.set(e,r),this.ensureProgram(),this.program.register(r,e)}else if(typeof t=="function"){this.nodes.set(e,{inputs:{},outputs:{}});let n=new t;this.nodeGenerators.set(e,n),this.ensureProgram(),this.program.register(n,e)}else if(t&&typeof t=="object"&&"forward"in t){this.nodes.set(e,{inputs:{},outputs:{}});let n=t;this.nodeGenerators.set(e,n),this.ensureProgram(),this.program.register(n,e)}else throw new Error(`Invalid second argument for node '${e}': expected string, AxSignature, AxProgrammable instance, or constructor function`);return this}n(e,t){return this.node(e,t)}map(e,t){if(t?.parallel){let n=Array.isArray(e)?e:[e],r=async s=>(await nr(n,async(u,c)=>{let l=u(s);return Promise.resolve(l)},this.autoParallelConfig.batchSize)).reduce((u,c)=>({...u,...c}),s);if(this.branchContext?.currentBranchValue!==void 0){let s=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];s.push(r),this.branchContext.branches.set(this.branchContext.currentBranchValue,s)}else this.flowDefinition.push(r),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(r,void 0,void 0,"parallel-map",n)}else{let n=async r=>{if(Array.isArray(e))throw new Error("Array of transforms requires parallel: true option");let s=e(r);return Promise.resolve(s)};if(this.branchContext?.currentBranchValue!==void 0){let r=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];r.push(n),this.branchContext.branches.set(this.branchContext.currentBranchValue,r)}else this.flowDefinition.push(n),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(n,void 0,void 0,"map",e)}return this.nodeGenerators.size>0&&this.ensureProgram(),this}m(e,t){return this.map(e,t)}returns(e){let t=async n=>{let r=e(n);return Promise.resolve(r)};if(this.branchContext?.currentBranchValue!==void 0){let n=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];n.push(t),this.branchContext.branches.set(this.branchContext.currentBranchValue,n)}else this.flowDefinition.push(t),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(t,void 0,void 0,"map",e);return this.nodeGenerators.size>0&&this.ensureProgram(),this}r(e){return this.returns(e)}label(e){if(this.branchContext?.currentBranchValue!==void 0)throw new Error("Cannot create labels inside branch blocks");return this.stepLabels.set(e,this.flowDefinition.length),this}l(e){return this.label(e)}execute(e,t,n){if(!this.nodes.has(e))throw new Error(`Node '${e}' not found. Make sure to define it with .node() first.`);let r=this.nodeGenerators.get(e);if(!r)throw new Error(`Node program for '${e}' not found.`);let s=async(i,a)=>{let u=n?.ai??a.mainAi,c={...a.mainOptions??{},...n?.options??{}},l=t(i),p=c?.traceLabel?`Node:${e} (${c.traceLabel})`:`Node:${e}`,d;if("forward"in r&&typeof r.forward=="function"){if(d=await r.forward(u,l,{...c,traceLabel:p}),"getUsage"in r&&typeof r.getUsage=="function"){let m=r.getUsage();if(m&&m.length>0){let g=this.nodeUsage.get(e)||[];this.nodeUsage.set(e,[...g,...m])}}if("getTraces"in r&&typeof r.getTraces=="function"){let m=r.getTraces();if(m&&m.length>0){let g=this.nodeTraces.get(e)||[];this.nodeTraces.set(e,[...g,...m])}}}else throw new Error(`Node program for '${e}' does not have a forward method`);return{...i,[`${e}Result`]:d}};if(this.branchContext?.currentBranchValue!==void 0){let i=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];i.push(s),this.branchContext.branches.set(this.branchContext.currentBranchValue,i)}else this.flowDefinition.push(s),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(s,e,t);return this.ensureProgram(),this}applyOptimization(e){this.program&&"applyOptimization"in this.program&&this.program.applyOptimization(e)}e(e,t,n){return this.execute(e,t,n)}branch(e){if(this.branchContext)throw new Error("Nested branches are not supported");return this.branchContext={predicate:t=>e(t),branches:new Map,currentBranchValue:void 0},this}b(e){return this.branch(e)}when(e){if(!this.branchContext)throw new Error("when() called without matching branch()");return this.branchContext.currentBranchValue=e,this.branchContext.branches.set(e,[]),this}w(e){return this.when(e)}merge(){if(!this.branchContext)throw new Error("merge() called without matching branch()");let e=this.branchContext;this.branchContext=null;let t=async(n,r)=>{let s=e.predicate(n),i=e.branches.get(s);if(this.flowLogger&&this.flowLogger({name:"BranchEvaluation",timestamp:Date.now(),branchValue:s,hasMatchingBranch:!!i,branchStepsCount:i?.length??0}),!i)return n;let a=n;for(let u of i)a=await u(a,r);return a};return this.flowDefinition.push(t),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(t,void 0,void 0,"merge"),this.ensureProgram(),this}mg(){return this.merge()}parallel(e){let t=async(n,r)=>{let s=await nr(e,async(i,a)=>{let u=new ir(this.nodeGenerators);return await i(u).executeSteps(n,r)},this.autoParallelConfig.batchSize);return{...n,_parallelResults:s}};return this.flowDefinition.push(t),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(t,void 0,void 0,"parallel",void 0,void 0),this.ensureProgram(),{merge:(n,r)=>{let s=i=>{let a=i._parallelResults;if(!Array.isArray(a))throw new Error("No parallel results found for merge");let u=r(...a),c={...i};return delete c._parallelResults,c[n]=u,c};return this.flowDefinition.push(s),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(s,void 0,void 0,"merge",void 0,{resultKey:n,mergeFunction:r}),this.ensureProgram(),this}}}p(e){return this.parallel(e)}feedback(e,t,n=10){if(!this.stepLabels.has(t))throw new Error(`Label '${t}' not found. Make sure to define it with .label() before the feedback point.`);let r=this.stepLabels.get(t),s=this.flowDefinition.length;return this.flowDefinition.push(async(i,a)=>{let u=i,c=1,l=`_feedback_${t}_iterations`;for(typeof u[l]!="number"&&(u={...u,[l]:1});e(u)&&c<n;){c++,u={...u,[l]:c};for(let p=r;p<s;p++){let d=this.flowDefinition[p];d&&(u=await d(u,a))}}return u}),this.nodeGenerators.size>0&&this.ensureProgram(),this}fb(e,t,n=10){return this.feedback(e,t,n)}while(e,t=100){let n=this.flowDefinition.length;this.loopStack.push(n);let r=Object.assign(s=>s,{_condition:e,_maxIterations:t,_isLoopStart:!0});return this.flowDefinition.push(r),this.nodeGenerators.size>0&&this.ensureProgram(),this}wh(e,t=100){return this.while(e,t)}endWhile(){if(this.loopStack.length===0)throw new Error("endWhile() called without matching while()");let e=this.loopStack.pop(),t=this.flowDefinition[e];if(!t||!("_isLoopStart"in t))throw new Error("Loop start step not found or invalid");let n=t._condition,r=t._maxIterations,s=this.flowDefinition.splice(e+1);return this.flowDefinition[e]=async(i,a)=>{let u=i,c=0;for(;n(u)&&c<r;){c++;for(let l of s)u=await l(u,a)}if(c>=r&&n(u))throw new Error(`While loop exceeded maximum iterations (${r}). Consider increasing maxIterations or ensuring the loop condition eventually becomes false.`);return u},this.nodeGenerators.size>0&&this.ensureProgram(),this}end(){return this.endWhile()}derive(e,t,n,r){let s=async i=>{let a=i[t];if(a===void 0)throw new Error(`Input field '${t}' not found in state`);let u;if(Array.isArray(a))if(this.autoParallelConfig.enabled){let c=r?.batchSize||this.autoParallelConfig.batchSize;u=await nr(a,async(l,p)=>n(l,p,i),c)}else u=a.map((c,l)=>n(c,l,i));else u=n(a,void 0,i);return{...i,[e]:u}};if(this.branchContext?.currentBranchValue!==void 0){let i=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];i.push(s),this.branchContext.branches.set(this.branchContext.currentBranchValue,i)}else this.flowDefinition.push(s),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(s,void 0,void 0,"derive",n,void 0,{inputFieldName:t,outputFieldName:e,batchSize:r?.batchSize});return this.ensureProgram(),this}getExecutionPlan(){let e=this.executionPlanner.getExecutionPlan();return{totalSteps:e.totalSteps,parallelGroups:e.parallelGroups,maxParallelism:e.maxParallelism,autoParallelEnabled:this.autoParallelConfig.enabled,steps:e.steps,groups:e.groups}}getSignature(){return this.ensureProgram(),this.program.getSignature()}nodeExtended(e,t,n){let s=typeof t=="string"?Me.create(t):t;if(n.prependInputs)for(let i of n.prependInputs)s=s.prependInputField(i.name,i.type);if(n.appendInputs)for(let i of n.appendInputs)s=s.appendInputField(i.name,i.type);if(n.prependOutputs)for(let i of n.prependOutputs)s=s.prependOutputField(i.name,i.type);if(n.appendOutputs)for(let i of n.appendOutputs)s=s.appendOutputField(i.name,i.type);return this.node(e,s)}nx(e,t,n){return this.nodeExtended(e,t,n)}mapOutput(e){let t=async n=>{let r=e(n);return{...n,...r}};if(this.branchContext?.currentBranchValue!==void 0){let n=this.branchContext.branches.get(this.branchContext.currentBranchValue)||[];n.push(t),this.branchContext.branches.set(this.branchContext.currentBranchValue,n)}else this.flowDefinition.push(t),this.autoParallelConfig.enabled&&this.executionPlanner.addExecutionStep(t,void 0,void 0,"map",e);return this.nodeGenerators.size>0&&this.ensureProgram(),this}mo(e){return this.mapOutput(e)}};function Es(o){return Vr.create(o)}var Ms=class{apiUrl;containerId=null;constructor(e="http://localhost:2375"){this.apiUrl=e}async pullImage(e){let t=await this.fetchDockerAPI(`/images/create?fromImage=${encodeURIComponent(e)}`,{method:"POST"});if(!t.ok)throw new Error(`Failed to pull image: ${t.statusText}`);await t.text()}async createContainer({imageName:e,volumes:t=[],doNotPullImage:n,tag:r}){let s=t.map(c=>`${c.hostPath}:${c.containerPath}`);n||await this.pullImage(e);let i={Image:e,Tty:!0,OpenStdin:!1,AttachStdin:!1,AttachStdout:!1,AttachStderr:!1,HostConfig:{Binds:s},Labels:{}};r&&(i.Labels["com.example.tag"]=r);let a=await this.fetchDockerAPI("/containers/create",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(i)});if(!a.ok)throw new Error(`Failed to create container: ${a.statusText}`);let u=await a.json();return this.containerId=u.Id,u}async findOrCreateContainer({imageName:e,volumes:t=[],doNotPullImage:n,tag:r}){let i=(await this.listContainers(!0)).filter(u=>u.Labels&&u.Labels["com.example.tag"]===r);if(i&&i.length>0){let u=Math.floor(Math.random()*i.length),c=i[u];if(c)return await this.connectToContainer(c.Id),{Id:c.Id,isNew:!1}}return{Id:(await this.createContainer({imageName:e,volumes:t,doNotPullImage:n,tag:r})).Id,isNew:!0}}async startContainer(){if(!this.containerId)throw new Error("No container created or connected");let e=await this.fetchDockerAPI(`/containers/${this.containerId}/start`,{method:"POST"});if(!e.ok)throw new Error(`Failed to start container: ${e.statusText}`)}async connectToContainer(e){let t=await this.fetchDockerAPI(`/containers/${e}/json`);if(!t.ok)throw new Error(`Failed to connect to container: ${t.statusText}`);this.containerId=e}async stopContainers({tag:e,remove:t,timeout:n=10}){let r=[],s=await this.listContainers(!0),i=e?s.filter(a=>a.Labels["com.example.tag"]===e):s;for(let a of i){if(a.State.Status==="running"){let u=await this.fetchDockerAPI(`/containers/${a.Id}/stop?t=${n}`,{method:"POST"});if(!u.ok){console.warn(`Failed to stop container ${a.Id}: ${u.statusText}`);continue}r.push({Id:a.Id,Action:"stopped"})}if(t){let u=await this.fetchDockerAPI(`/containers/${a.Id}`,{method:"DELETE"});if(!u.ok){console.warn(`Failed to remove container ${a.Id}: ${u.statusText}`);continue}r.push({Id:a.Id,Action:"removed"})}}return r}async listContainers(e=!1){return(await this.fetchDockerAPI(`/containers/json?all=${e}`,{method:"GET"})).json()}async getContainerLogs(){if(!this.containerId)throw new Error("No container created or connected");return(await this.fetchDockerAPI(`/containers/${this.containerId}/logs?stdout=true&stderr=true`,{method:"GET"})).text()}async executeCommand(e){if(!this.containerId)throw new Error("No container created or connected");(await this.getContainerInfo(this.containerId)).State.Status!=="running"&&(await this.startContainer(),await this.waitForContainerToBeRunning(this.containerId));let n=await this.fetchDockerAPI(`/containers/${this.containerId}/exec`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({Cmd:["sh","-c",e],AttachStdout:!0,AttachStderr:!0})});if(!n.ok)throw new Error(`Failed to create exec instance: ${n.statusText}`);let r=await n.json(),s=await this.fetchDockerAPI(`/exec/${r.Id}/start`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({Detach:!1,Tty:!1})});if(!s.ok)throw new Error(`Failed to start exec instance: ${s.statusText}`);return await s.text()}async getContainerInfo(e){let t=await this.fetchDockerAPI(`/containers/${e}/json`);if(!t.ok)throw new Error(`Failed to get container info: ${t.statusText}`);return t.json()}async waitForContainerToBeRunning(e,t=3e4){let n=Date.now();for(;Date.now()-n<t;){if((await this.getContainerInfo(e)).State.Status==="running")return;await new Promise(s=>setTimeout(s,1e3))}throw new Error("Timeout waiting for container to start")}async fetchDockerAPI(e,t){let n=new URL(e,this.apiUrl).toString();return await fetch(n,t)}toFunction(){return{name:"commandExecution",description:"Use this function to execute shell commands, scripts, and programs. This function enables interaction with the file system, running system utilities, and performing tasks that require a shell interface.",parameters:{type:"object",properties:{command:{type:"string",description:'Shell command to execute. eg. `ls -l` or `echo "Hello, World!"`.'}},required:["command"]},func:async({command:e})=>await this.executeCommand(e)}}};var Ps=class{aiService;info;func;constructor({ai:e,info:t,func:n}){this.aiService=e,this.info=t,this.func=n}async embedAdapter(e,t){let r=(await this.aiService.embed({texts:[e]},{sessionId:t?.sessionId,abortSignal:t?.abortSignal})).embeddings.at(0);if(!r)throw new Error("Failed to embed text");return this.func.length===2?this.func(r,t):this.func(r)}toFunction(){return{name:this.info.name,description:this.info.description,parameters:{type:"object",properties:{text:{type:"string",description:this.info.argumentDescription}},required:["text"]},func:({text:e},t)=>this.embedAdapter(e,t)}}};function ln(o){return!!o&&/[A-Za-z0-9_$]/.test(o)}function El(o){return!!o&&/[A-Za-z_$]/.test(o)}function $t(o){let e="",t=0,n="normal",r=!1;for(;t<o.length;){let s=o[t]??"",i=o[t+1]??"";if(n==="lineComment"){s===`
1067
1067
  `?(e+=`
1068
1068
  `,n="normal"):e+=" ",t++;continue}if(n==="blockComment"){s==="*"&&i==="/"?(e+=" ",t+=2,n="normal"):(e+=s===`
1069
1069
  `?`
@@ -1071,66 +1071,66 @@ ${e}
1071
1071
  `?`
1072
1072
  `:" ",r=!1,t++;continue}if(s==="\\"){e+=" ",r=!0,t++;continue}if(s===a){e+=" ",n="normal",t++;continue}e+=s===`
1073
1073
  `?`
1074
- `:" ",t++;continue}if(s==="/"&&i==="/"){e+=" ",t+=2,n="lineComment";continue}if(s==="/"&&i==="*"){e+=" ",t+=2,n="blockComment";continue}if(s==="'"){e+=" ",t++,n="single";continue}if(s==='"'){e+=" ",t++,n="double";continue}if(s==="`"){e+=" ",t++,n="template";continue}e+=s,t++}return e}function Vr(o){let e=[],t=o.length,n=0,r=0,s=0,i=A=>{if(n++,A==="`"){let h=0;for(;n<t;){let b=o[n];if(b==="\\"){n+=2;continue}if(h>0){b==="{"?h++:b==="}"&&h--,n++;continue}if(b==="$"&&n+1<t&&o[n+1]==="{"){h++,n+=2;continue}if(b==="`"){n++;return}n++}return}for(;n<t;){let h=o[n];if(h==="\\"){n+=2;continue}if(h===A){n++;return}n++}},a=()=>{for(n+=2;n<t&&o[n]!==`
1075
- `;)n++},l=()=>{for(n+=2;n<t;){if(o[n]==="*"&&n+1<t&&o[n+1]==="/"){n+=2;return}n++}},c=()=>{let A=n;for(;n<t&&an(o[n]);)n++;return o.slice(A,n)},u=()=>{let A=n;for(;n<t;){let h=o[n];if(h===" "||h===" "||h===`
1076
- `||h==="\r"){n++;continue}if(h==="/"&&n+1<t){if(o[n+1]==="/"){a();continue}if(o[n+1]==="*"){l();continue}}break}return n>A},p=A=>{let h=1;for(;n<t&&h>0;){if(u(),n>=t)return;let b=o[n];if(b===A){h--,n++;continue}if(b==="{"||b==="["){let T=b==="{"?"}":"]";n++,p(T);continue}if(b==="."&&n+2<t&&o[n+1]==="."&&o[n+2]==="."){if(n+=3,u(),n<t&&an(o[n])){let T=c();T&&e.push(T)}continue}if(b===","){n++;continue}if(b==="="){n++;let T=0;for(;n<t;){let C=o[n];if(C==="'"||C==='"'||C==="`"){i(C);continue}if(C==="("||C==="["||C==="{"){T++,n++;continue}if(C===")"||C==="]"||C==="}"){if(T>0){T--,n++;continue}break}if(C===","&&T===0)break;n++}continue}if(an(b)){let T=c();if(u(),n<t&&o[n]===":"){if(n++,u(),n<t){let C=o[n];if(C==="{"||C==="["){let v=C==="{"?"}":"]";n++,p(v)}else if(an(C)){let v=c();v&&e.push(v)}}}else T&&e.push(T);continue}n++}},d=()=>{let A=0;for(;n<t;){let h=o[n];if(h==="'"||h==='"'||h==="`"){i(h);continue}if(h==="/"&&n+1<t){if(o[n+1]==="/"){a();continue}if(o[n+1]==="*"){l();continue}}if(h==="("||h==="["||h==="{"){A++,n++;continue}if(h===")"||h==="]"||h==="}"){if(A>0){A--,n++;continue}return!1}if(h===","&&A===0)return n++,!0;if(h===";"&&A===0)return n++,!1;if(h===`
1077
- `&&A===0){let b=n;return n++,u(),n<t&&o[n]===","?(n++,!0):(n=b,!1)}n++}return!1},m=()=>{for(;n<t;){if(u(),n>=t)return;let A=o[n];if(A==="{"){if(n++,p("}"),!d())return;continue}if(A==="["){if(n++,p("]"),!d())return;continue}if(an(A)){let h=c();if(h&&e.push(h),!d())return;continue}return}},g=A=>{if(A===0)return!0;let h=A-1;for(;h>=0;){let b=o[h];if(b===" "||b===" "||b==="\r"){h--;continue}return b===`
1078
- `||b===";"||b==="{"||b==="}"}return!0};for(;n<t;){let A=o[n];if(A==="'"||A==='"'||A==="`"){i(A);continue}if(A==="/"&&n+1<t){if(o[n+1]==="/"){a();continue}if(o[n+1]==="*"){l();continue}}if(A==="{"){r++,n++;continue}if(A==="}"){r--,n++;continue}if(A==="("){s++,n++;continue}if(A===")"){s--,n++;continue}if(r===0&&s===0&&an(A)){let h=n,b=c();(b==="var"||b==="let"||b==="const")&&n<t&&(o[n]===" "||o[n]===" "||o[n]===`
1079
- `)&&g(h)&&m();continue}n++}let f=new Set,x=[];for(let A of e)f.has(A)||(f.add(A),x.push(A));return x}function yu(o){let e=new Set(Vr(o)),t=Ft(o),n=t.length,r=0,s=0,i=0,a=m=>{let g=m;for(;g<n&&/\s/.test(t[g]??"");)g++;return g},l=m=>{let g=m;for(;g>=0&&/\s/.test(t[g]??"");)g--;return g},c=m=>{let g=t.slice(m,m+3),f=t.slice(m,m+2);return g==="==="||f==="=="||f==="=>"?!1:t[m]==="="||["+=","-=","*=","/=","%=","&=","|=","^=","&&=","||=","??=","**=","<<=",">>=",">>>="].some(x=>t.startsWith(x,m))},u=m=>{let g=m;for(;g<n&&an(t[g]);)g++;return{word:t.slice(m,g),nextIndex:g}},p=(m,g,f)=>{let x=l(g-1),A=x>=0?t[x]:void 0,h=a(f);if(A==="."||A==="?")return;let T=t.slice(Math.max(0,g-2),g)==="++"||t.slice(Math.max(0,g-2),g)==="--",C=t.startsWith("++",h)||t.startsWith("--",h);(T||C||c(h))&&e.add(m)},d=(m,g)=>{let f=a(g);if(t[f]!==".")return;let x=a(f+1);if(!Au(t[x]))return;let{word:A,nextIndex:h}=u(x),b=a(h),T=t.slice(Math.max(0,m-2),m)==="++"||t.slice(Math.max(0,m-2),m)==="--",C=t.startsWith("++",b)||t.startsWith("--",b);A&&(T||C||c(b))&&e.add(A)};for(;r<n;){let m=t[r];if(m==="{"){s++,r++;continue}if(m==="}"){s--,r++;continue}if(m==="("){i++,r++;continue}if(m===")"){i--,r++;continue}if(s===0&&i===0&&Au(m)){let g=r,{word:f,nextIndex:x}=u(r);if(r=x,!f)continue;if(f==="globalThis"){d(g,x);continue}p(f,g,x);continue}r++}return[...e]}function Os(o){let e=typeof self<"u"?self:globalThis,t=[],n=Object.getPrototypeOf(async()=>{}).constructor,r=o.functionRefKey,s="return",i="stdout",a=/^(if|for|while|switch|try|catch|finally|function|class|import|export|throw|return|var|let|const|break|continue|debugger)\b/,l=/^\s*return\s+([^\n;]+?)\s*;?\s*$/,c={network:["fetch","XMLHttpRequest","WebSocket","EventSource"],storage:["indexedDB","caches"],"code-loading":["importScripts"],communication:["BroadcastChannel"],timing:["performance"],workers:["Worker","SharedWorker"]},u=()=>{let y;if(typeof process<"u"&&typeof process.getBuiltinModule=="function"&&(y=process.getBuiltinModule.bind(process)),!y)try{y=new Function('return typeof require==="function"?require:undefined')()}catch{y=void 0}if(!(typeof y=="function"&&typeof process<"u"&&!!process.versions?.node))return{isNodeWorker:!1,parentPort:null};try{return{isNodeWorker:!0,parentPort:y("node:worker_threads").parentPort??null}}catch{return{isNodeWorker:!0,parentPort:null}}},{isNodeWorker:p,parentPort:d}=u(),m=()=>{if(!d&&typeof e.postMessage!="function")throw new Error("Worker transport unavailable: no postMessage channel");return{send:O=>{if(d){d.postMessage(O);return}e.postMessage(O)},setOnMessage:O=>{if(d){d.on("message",I=>O({data:I}));return}e.onmessage=O}}},{send:g,setOnMessage:f}=m(),x=y=>y&&(/\r?\n$/.test(y)?y:`${y}
1080
- `),A=y=>{let w=y.trim();return w.startsWith("//")||w.startsWith("/*")||w.startsWith("*")},h=y=>{let w=y.length-1;for(;w>=0;){let O=y[w].trim();if(O&&!A(O))break;w-=1}return w},b=y=>{if(!y)return!0;let w=y.split(`
1081
- `).find(O=>O.trim().length>0)?.trim();return!w||a.test(w)?!0:w.startsWith("{")&&!w.startsWith("({")||w==="}"||w==="};"||A(w)},T=(y,w)=>{let O=y,I=w.trim().replace(/;\s*$/,"");if(!I)return null;let D=I.lastIndexOf(";");if(D!==-1){let H=I.slice(D+1).trim(),Q=I.slice(0,D).trim();H&&(H.startsWith("//")||H.startsWith("/*")?Q&&(I=Q):(Q&&(O=O?`${O}
1082
- ${Q};`:`${Q};`),I=H))}return b(I)?null:{head:O,expression:I}},C=(y,w,O)=>{let I=y.slice(0,w).join(`
1083
- `),D=y.slice(w,O+1).join(`
1074
+ `:" ",t++;continue}if(s==="/"&&i==="/"){e+=" ",t+=2,n="lineComment";continue}if(s==="/"&&i==="*"){e+=" ",t+=2,n="blockComment";continue}if(s==="'"){e+=" ",t++,n="single";continue}if(s==='"'){e+=" ",t++,n="double";continue}if(s==="`"){e+=" ",t++,n="template";continue}e+=s,t++}return e}function Jr(o){let e=[],t=o.length,n=0,r=0,s=0,i=A=>{if(n++,A==="`"){let h=0;for(;n<t;){let y=o[n];if(y==="\\"){n+=2;continue}if(h>0){y==="{"?h++:y==="}"&&h--,n++;continue}if(y==="$"&&n+1<t&&o[n+1]==="{"){h++,n+=2;continue}if(y==="`"){n++;return}n++}return}for(;n<t;){let h=o[n];if(h==="\\"){n+=2;continue}if(h===A){n++;return}n++}},a=()=>{for(n+=2;n<t&&o[n]!==`
1075
+ `;)n++},u=()=>{for(n+=2;n<t;){if(o[n]==="*"&&n+1<t&&o[n+1]==="/"){n+=2;return}n++}},c=()=>{let A=n;for(;n<t&&ln(o[n]);)n++;return o.slice(A,n)},l=()=>{let A=n;for(;n<t;){let h=o[n];if(h===" "||h===" "||h===`
1076
+ `||h==="\r"){n++;continue}if(h==="/"&&n+1<t){if(o[n+1]==="/"){a();continue}if(o[n+1]==="*"){u();continue}}break}return n>A},p=A=>{let h=1;for(;n<t&&h>0;){if(l(),n>=t)return;let y=o[n];if(y===A){h--,n++;continue}if(y==="{"||y==="["){let C=y==="{"?"}":"]";n++,p(C);continue}if(y==="."&&n+2<t&&o[n+1]==="."&&o[n+2]==="."){if(n+=3,l(),n<t&&ln(o[n])){let C=c();C&&e.push(C)}continue}if(y===","){n++;continue}if(y==="="){n++;let C=0;for(;n<t;){let I=o[n];if(I==="'"||I==='"'||I==="`"){i(I);continue}if(I==="("||I==="["||I==="{"){C++,n++;continue}if(I===")"||I==="]"||I==="}"){if(C>0){C--,n++;continue}break}if(I===","&&C===0)break;n++}continue}if(ln(y)){let C=c();if(l(),n<t&&o[n]===":"){if(n++,l(),n<t){let I=o[n];if(I==="{"||I==="["){let v=I==="{"?"}":"]";n++,p(v)}else if(ln(I)){let v=c();v&&e.push(v)}}}else C&&e.push(C);continue}n++}},d=()=>{let A=0;for(;n<t;){let h=o[n];if(h==="'"||h==='"'||h==="`"){i(h);continue}if(h==="/"&&n+1<t){if(o[n+1]==="/"){a();continue}if(o[n+1]==="*"){u();continue}}if(h==="("||h==="["||h==="{"){A++,n++;continue}if(h===")"||h==="]"||h==="}"){if(A>0){A--,n++;continue}return!1}if(h===","&&A===0)return n++,!0;if(h===";"&&A===0)return n++,!1;if(h===`
1077
+ `&&A===0){let y=n;return n++,l(),n<t&&o[n]===","?(n++,!0):(n=y,!1)}n++}return!1},m=()=>{for(;n<t;){if(l(),n>=t)return;let A=o[n];if(A==="{"){if(n++,p("}"),!d())return;continue}if(A==="["){if(n++,p("]"),!d())return;continue}if(ln(A)){let h=c();if(h&&e.push(h),!d())return;continue}return}},g=A=>{if(A===0)return!0;let h=A-1;for(;h>=0;){let y=o[h];if(y===" "||y===" "||y==="\r"){h--;continue}return y===`
1078
+ `||y===";"||y==="{"||y==="}"}return!0};for(;n<t;){let A=o[n];if(A==="'"||A==='"'||A==="`"){i(A);continue}if(A==="/"&&n+1<t){if(o[n+1]==="/"){a();continue}if(o[n+1]==="*"){u();continue}}if(A==="{"){r++,n++;continue}if(A==="}"){r--,n++;continue}if(A==="("){s++,n++;continue}if(A===")"){s--,n++;continue}if(r===0&&s===0&&ln(A)){let h=n,y=c();(y==="var"||y==="let"||y==="const")&&n<t&&(o[n]===" "||o[n]===" "||o[n]===`
1079
+ `)&&g(h)&&m();continue}n++}let f=new Set,x=[];for(let A of e)f.has(A)||(f.add(A),x.push(A));return x}function Ml(o){let e=new Set(Jr(o)),t=$t(o),n=t.length,r=0,s=0,i=0,a=m=>{let g=m;for(;g<n&&/\s/.test(t[g]??"");)g++;return g},u=m=>{let g=m;for(;g>=0&&/\s/.test(t[g]??"");)g--;return g},c=m=>{let g=t.slice(m,m+3),f=t.slice(m,m+2);return g==="==="||f==="=="||f==="=>"?!1:t[m]==="="||["+=","-=","*=","/=","%=","&=","|=","^=","&&=","||=","??=","**=","<<=",">>=",">>>="].some(x=>t.startsWith(x,m))},l=m=>{let g=m;for(;g<n&&ln(t[g]);)g++;return{word:t.slice(m,g),nextIndex:g}},p=(m,g,f)=>{let x=u(g-1),A=x>=0?t[x]:void 0,h=a(f);if(A==="."||A==="?")return;let C=t.slice(Math.max(0,g-2),g)==="++"||t.slice(Math.max(0,g-2),g)==="--",I=t.startsWith("++",h)||t.startsWith("--",h);(C||I||c(h))&&e.add(m)},d=(m,g)=>{let f=a(g);if(t[f]!==".")return;let x=a(f+1);if(!El(t[x]))return;let{word:A,nextIndex:h}=l(x),y=a(h),C=t.slice(Math.max(0,m-2),m)==="++"||t.slice(Math.max(0,m-2),m)==="--",I=t.startsWith("++",y)||t.startsWith("--",y);A&&(C||I||c(y))&&e.add(A)};for(;r<n;){let m=t[r];if(m==="{"){s++,r++;continue}if(m==="}"){s--,r++;continue}if(m==="("){i++,r++;continue}if(m===")"){i--,r++;continue}if(s===0&&i===0&&El(m)){let g=r,{word:f,nextIndex:x}=l(r);if(r=x,!f)continue;if(f==="globalThis"){d(g,x);continue}p(f,g,x);continue}r++}return[...e]}function Fs(o){let e=typeof self<"u"?self:globalThis,t=[],n=Object.getPrototypeOf(async()=>{}).constructor,r=o.functionRefKey,s="return",i="stdout",a=/^(if|for|while|switch|try|catch|finally|function|class|import|export|throw|return|var|let|const|break|continue|debugger)\b/,u=/^\s*return\s+([^\n;]+?)\s*;?\s*$/,c={network:["fetch","XMLHttpRequest","WebSocket","EventSource"],storage:["indexedDB","caches"],"code-loading":["importScripts"],communication:["BroadcastChannel"],timing:["performance"],workers:["Worker","SharedWorker"]},l=()=>{let b;if(typeof process<"u"&&typeof process.getBuiltinModule=="function"&&(b=process.getBuiltinModule.bind(process)),!b)try{b=new Function('return typeof require==="function"?require:undefined')()}catch{b=void 0}if(!(typeof b=="function"&&typeof process<"u"&&!!process.versions?.node))return{isNodeWorker:!1,parentPort:null};try{return{isNodeWorker:!0,parentPort:b("node:worker_threads").parentPort??null}}catch{return{isNodeWorker:!0,parentPort:null}}},{isNodeWorker:p,parentPort:d}=l(),m=()=>{if(!d&&typeof e.postMessage!="function")throw new Error("Worker transport unavailable: no postMessage channel");return{send:k=>{if(d){d.postMessage(k);return}e.postMessage(k)},setOnMessage:k=>{if(d){d.on("message",T=>k({data:T}));return}e.onmessage=k}}},{send:g,setOnMessage:f}=m(),x=b=>b&&(/\r?\n$/.test(b)?b:`${b}
1080
+ `),A=b=>{let w=b.trim();return w.startsWith("//")||w.startsWith("/*")||w.startsWith("*")},h=b=>{let w=b.length-1;for(;w>=0;){let k=b[w].trim();if(k&&!A(k))break;w-=1}return w},y=b=>{if(!b)return!0;let w=b.split(`
1081
+ `).find(k=>k.trim().length>0)?.trim();return!w||a.test(w)?!0:w.startsWith("{")&&!w.startsWith("({")||w==="}"||w==="};"||A(w)},C=(b,w)=>{let k=b,T=w.trim().replace(/;\s*$/,"");if(!T)return null;let D=T.lastIndexOf(";");if(D!==-1){let H=T.slice(D+1).trim(),Y=T.slice(0,D).trim();H&&(H.startsWith("//")||H.startsWith("/*")?Y&&(T=Y):(Y&&(k=k?`${k}
1082
+ ${Y};`:`${Y};`),T=H))}return y(T)?null:{head:k,expression:T}},I=(b,w,k)=>{let T=b.slice(0,w).join(`
1083
+ `),D=b.slice(w,k+1).join(`
1084
1084
  `).trim();if(!D)return null;if(!D.includes(`
1085
- `)){let H=T(I,D);return H?H.head?`${H.head}
1085
+ `)){let H=C(T,D);return H?H.head?`${H.head}
1086
1086
  return (
1087
1087
  ${H.expression}
1088
1088
  );`:`return (
1089
1089
  ${H.expression}
1090
- );`:null}return b(D)?null:I?`${I}
1090
+ );`:null}return y(D)?null:T?`${T}
1091
1091
  return (
1092
1092
  ${D}
1093
1093
  );`:`return (
1094
1094
  ${D}
1095
- );`},v=y=>{try{return new n(y),!0}catch{return!1}},k=y=>{let w=y.split(`
1096
- `),O=h(w);if(O<0)return y;let I=new Set;for(let D=O;D>=0;D-=1){let H=w[D]??"";if(!H.trim()||A(H))continue;let Q=C(w,D,O);if(Q&&!I.has(Q)&&(I.add(Q),v(Q)))return Q}return y},R=y=>{let w=l.exec(y);return w&&(w[1]||"").trim()||y},E=y=>{let w=[],O=y.length,I=0,D=0,H=0,Q=Y=>Y>="a"&&Y<="z"||Y>="A"&&Y<="Z"||Y>="0"&&Y<="9"||Y==="_"||Y==="$",W=Y=>{if(I++,Y==="`"){let J=0;for(;I<O;){let fe=y[I];if(fe==="\\"){I+=2;continue}if(J>0){fe==="{"?J++:fe==="}"&&J--,I++;continue}if(fe==="$"&&I+1<O&&y[I+1]==="{"){J++,I+=2;continue}if(fe==="`"){I++;return}I++}}else for(;I<O;){let J=y[I];if(J==="\\"){I+=2;continue}if(J===Y){I++;return}I++}},M=()=>{for(I+=2;I<O&&y[I]!==`
1097
- `;)I++},q=()=>{for(I+=2;I<O;){if(y[I]==="*"&&I+1<O&&y[I+1]==="/"){I+=2;return}I++}},ee=()=>{let Y=I;for(;I<O&&Q(y[I]);)I++;return y.slice(Y,I)},Z=()=>{let Y=I;for(;I<O;){let J=y[I];if(J===" "||J===" "||J===`
1098
- `||J==="\r"){I++;continue}if(J==="/"&&I+1<O){if(y[I+1]==="/"){M();continue}if(y[I+1]==="*"){q();continue}}break}return I>Y},Te=Y=>{let J=1;for(;I<O&&J>0;){if(Z(),I>=O)return;let fe=y[I];if(fe===Y){J--,I++;continue}if(fe==="{"||fe==="["){let Re=fe==="{"?"}":"]";I++,J++,I--,J--,I++,Te(Re);continue}if(fe==="."&&I+2<O&&y[I+1]==="."&&y[I+2]==="."){if(I+=3,Z(),I<O&&Q(y[I])){let Re=ee();Re&&w.push(Re)}continue}if(fe===","){I++;continue}if(fe==="="){I++;let Re=0;for(;I<O;){let Me=y[I];if(Me==="'"||Me==='"'||Me==="`"){W(Me);continue}if(Me==="("||Me==="["||Me==="{"){Re++,I++;continue}if(Me===")"||Me==="]"||Me==="}"){if(Re>0){Re--,I++;continue}break}if(Me===","&&Re===0)break;I++}continue}if(Q(fe)){let Re=ee();if(Z(),I<O&&y[I]===":"){if(I++,Z(),I<O){let Me=y[I];if(Me==="{"||Me==="["){let Ve=Me==="{"?"}":"]";I++,Te(Ve)}else if(Q(Me)){let Ve=ee();Ve&&w.push(Ve)}}}else Re&&w.push(Re);continue}I++}},Ue=()=>{let Y=0;for(;I<O;){let J=y[I];if(J==="'"||J==='"'||J==="`"){W(J);continue}if(J==="/"&&I+1<O){if(y[I+1]==="/"){M();continue}if(y[I+1]==="*"){q();continue}}if(J==="("||J==="["||J==="{"){Y++,I++;continue}if(J===")"||J==="]"||J==="}"){if(Y>0){Y--,I++;continue}return!1}if(J===","&&Y===0)return I++,!0;if(J===";"&&Y===0)return I++,!1;if(J===`
1099
- `&&Y===0){let fe=I;return I++,Z(),I<O&&y[I]===","?(I++,!0):(I=fe,!1)}I++}return!1},ye=()=>{for(;I<O;){if(Z(),I>=O)return;let Y=y[I];if(Y==="{"){if(I++,Te("}"),!Ue())return;continue}if(Y==="["){if(I++,Te("]"),!Ue())return;continue}if(Q(Y)){let J=ee();if(J&&w.push(J),!Ue())return;continue}return}},qe=Y=>{if(Y===0)return!0;let J=Y-1;for(;J>=0;){let fe=y[J];if(fe===" "||fe===" "||fe==="\r"){J--;continue}return fe===`
1100
- `||fe===";"||fe==="{"||fe==="}"}return!0};for(;I<O;){let Y=y[I];if(Y==="'"||Y==='"'||Y==="`"){W(Y);continue}if(Y==="/"&&I+1<O){if(y[I+1]==="/"){M();continue}if(y[I+1]==="*"){q();continue}}if(Y==="{"){D++,I++;continue}if(Y==="}"){D--,I++;continue}if(Y==="("){H++,I++;continue}if(Y===")"){H--,I++;continue}if(D===0&&H===0&&Q(Y)){let J=I,fe=ee();if((fe==="var"||fe==="let"||fe==="const")&&I<O&&(y[I]===" "||y[I]===" "||y[I]===`
1101
- `)&&qe(J)){ye();continue}continue}I++}let _e=new Set,nt=[];for(let Y of w)_e.has(Y)||(_e.add(Y),nt.push(Y));return nt},S=y=>y.length===0?"":`
1102
- try { ${y.map(O=>`globalThis[${JSON.stringify(O)}] = ${O};`).join(" ")} } catch (_ax_e) {} void 0;`,_=y=>{if(typeof y=="string")return y;try{return JSON.stringify(y,null,2)}catch{return String(y)}},L=(y,w)=>{let O=e.console&&typeof e.console=="object"?e.console:null,I=O?.[y],D=typeof I=="function"?(...Q)=>I.apply(O,Q):null,H=(...Q)=>{w.push(Q.map(_).join(" "))};return(!e.console||typeof e.console!="object")&&(e.console={}),e.console[y]=H,()=>{if(!(!e.console||typeof e.console!="object")){if(D){e.console[y]=D;return}try{delete e.console[y]}catch{e.console[y]=void 0}}}},P=y=>{let w=[];return pe&&(w.push(L("log",y)),w.push(L("info",y)),w.push(L("warn",y)),w.push(L("error",y))),w},F=()=>{let y=[],w=P(y),O=e.print;return ne===i&&(e.print=(...D)=>{y.push(D.map(_).join(" "))}),{output:y,cleanup:()=>{for(let D of w)try{D()}catch{}if(ne===i)if(O===void 0)try{delete e.print}catch{e.print=void 0}else e.print=O}}},N=y=>{for(let w of y)try{Object.defineProperty(e,w,{value:void 0,writable:!1,configurable:!1})}catch{}},U=y=>{let w=new Set(Array.isArray(y)?y:[]);for(let[O,I]of Object.entries(c))w.has(O)||N(I)},G=y=>{p&&!y&&N(["process","require"])},B=o.maxErrorCauseDepth,te=(y,w=0,O=new Set)=>{if(w>B)return{name:"Error",message:"[cause chain truncated]"};if(y&&typeof y=="object"){if(O.has(y))return{name:"Error",message:"[circular]"};O.add(y)}let I=y,D=I?.name!=null?String(I.name):"Error",H=I?.message!=null?String(I.message):xe(y),Q=typeof I?.stack=="string"?I.stack:void 0,W;if(typeof I?.cause<"u"&&w<B)try{let q=I.cause;q instanceof Error||q&&typeof q=="object"&&("message"in q||"name"in q)?W=te(q,w+1,O):W={name:"Error",message:xe(q)}}catch{W={name:"Error",message:xe(I.cause)}}let M={name:D,message:H};if(Q!==void 0&&(M.stack=Q),W!==void 0&&(M.cause=W),typeof I?.data<"u")try{M.data=typeof structuredClone=="function"?structuredClone(I.data):I.data}catch{}return M},j=y=>{if(typeof y=="string")return new Error(y);if(!y||typeof y!="object")return new Error(String(y));let w=y,O=new Error(w.message!=null?String(w.message):"");return O.name=w.name!=null?String(w.name):"Error",typeof w.stack=="string"&&(O.stack=w.stack),w.cause!==void 0&&(O.cause=j(w.cause)),w.data!==void 0&&(O.data=w.data),O},V=y=>{let w=globalThis.AggregateError,O=typeof w=="function"&&y instanceof w;return y instanceof SyntaxError||y instanceof TypeError||y instanceof RangeError||y instanceof ReferenceError||O||y instanceof EvalError||y instanceof URIError},xe=y=>{if(y==null||typeof y!="object")return String(y);try{return JSON.stringify(y,null,2)}catch{return String(y)}},ve=(y,w,O=0)=>{let I=y,D=I?.name!=null?String(I.name):"Error",H=I?.message!=null?String(I.message):xe(y),Q=[`${D}: ${H}`],W;if(typeof I?.stack=="string"){let M=I.stack.match(/<anonymous>:(\d+):(\d+)/);M&&(W=Math.max(1,Number(M[1])-O),Q.push(` at line ${W}, column ${M[2]}`))}if(w&&W!==void 0&&W>=1&&W<=w.split(`
1103
- `).length){let M=w.split(`
1104
- `),q=Math.max(0,W-2),ee=Math.min(M.length,W+1),Te=M.slice(q,ee).map((Ue,ye)=>` ${String(q+ye+1).padStart(3)}| ${Ue}`).join(`
1105
- `);Q.push(`Source:
1106
- ${Te}`)}if(I?.data!==void 0&&Q.push(`Data: ${xe(I.data)}`),I?.cause!==void 0){let M=(q,ee)=>{if(ee>4)return"[cause chain truncated]";let Z=q,Te=Z?.name!=null?String(Z.name):"Error",Ue=Z?.message!=null?String(Z.message):xe(q),ye=[`${Te}: ${Ue}`];return Z?.data!==void 0&&ye.push(`Data: ${xe(Z.data)}`),Z?.cause!==void 0&&ye.push(`Caused by: ${M(Z.cause,ee+1)}`),ye.join(`
1107
- `)};Q.push(`Caused by: ${M(I.cause,1)}`)}return Q.join(`
1108
- `)},$=new Map,K=0,ne=s,pe=!1,X=[],z=y=>{if(!y||typeof y!="object"||Array.isArray(y))return!1;let w=Object.getPrototypeOf(y);return w===Object.prototype||w===null},ie=y=>typeof y=="string"&&y.trim().length>0,Oe=y=>{if(!ie(y)){if(!z(y))throw new Error("ask_clarification() choice entries must be non-empty strings or objects with a non-empty label");if(!ie(y.label))throw new Error("ask_clarification() choice objects require a non-empty label");if(y.value!==void 0&&!ie(y.value))throw new Error("ask_clarification() choice object values must be non-empty strings")}},Ee=y=>{if(ie(y))return;if(!z(y))throw new Error("ask_clarification() requires a non-empty string or an object payload");if(!ie(y.question))throw new Error("ask_clarification() object payload requires a non-empty question");let w=new Set(["text","number","date","single_choice","multiple_choice"]),O;if(y.type===void 0)O=Array.isArray(y.choices)&&y.choices.length>0?"single_choice":void 0;else{if(typeof y.type!="string"||!w.has(y.type))throw new Error("ask_clarification() object payload type must be one of: text, number, date, single_choice, multiple_choice");O=y.type}let I=O==="single_choice"||O==="multiple_choice",D=y.choices;if(D!==void 0){if(!Array.isArray(D)||D.length===0)throw new Error("ask_clarification() choices must be a non-empty array when provided");for(let H of D)Oe(H)}else if(I)throw new Error("ask_clarification() choice payloads require a non-empty choices array")},se=(y,w)=>{if(y==="final"){if(w.length===0)throw new Error("final() requires at least one argument");return}if(y==="ask_clarification"){if(w.length!==1)throw new Error("ask_clarification() requires exactly one argument");Ee(w[0])}},Fe=y=>{if(y==="final"||y==="ask_clarification")return y;let O=/^fn_\d+_(.+)$/.exec(y)?.[1];if(O==="final"||O==="ask_clarification")return O},ae=y=>(...w)=>{let O=Fe(y);O&&se(O,w);let I=++K,D=!1,H=new Promise((Z,Te)=>{$.set(I,{resolve:Z,reject:Te}),g({type:"fn-call",id:I,name:y,args:w})}),Q=H.then.bind(H),W=H.catch.bind(H),M=H.finally.bind(H),q=()=>{D=!0},ee=new Proxy(H,{get(Z,Te,Ue){return Te==="then"?(...ye)=>(q(),Q(...ye)):Te==="catch"?(...ye)=>(q(),W(...ye)):Te==="finally"?(...ye)=>(q(),M(...ye)):Reflect.get(Z,Te,Ue)}});return H.catch(Z=>{D||X.push(Z)}),ee},Ae=async()=>{for(let y=0;y<50&&$.size>0;y+=1)await new Promise(w=>{setTimeout(w,0)})},be=y=>{if(!y||typeof y!="object")return y;if(Array.isArray(y)){for(let O=0;O<y.length;O+=1)y[O]=be(y[O]);return y}let w=y;if(r in w){let O=w[r];return typeof O=="string"?ae(O):void 0}for(let[O,I]of Object.entries(w))w[O]=be(I);return y},oe=y=>{for(let[w,O]of Object.entries(y)){let I=be(O),D=e[w];if(z(D)&&z(I)){for(let H of Object.keys(D))Object.hasOwn(I,H)||delete D[H];for(let[H,Q]of Object.entries(I))D[H]=Q;continue}e[w]=I}},ge=y=>{if(y.globals&&typeof y.globals=="object"&&oe(y.globals),Array.isArray(y.fnNames))for(let w of y.fnNames)typeof w=="string"&&(e[w]=ae(w))},Ie=async y=>{let w=x(y),O=[];try{O=E(y)}catch{O=[]}let I=S(O),D=w;try{D=k(w)}catch{D=w}let H=D;if(I){let M=D.lastIndexOf(`
1109
- return (`);M!==-1?H=D.slice(0,M)+I+D.slice(M):H=D+I}let Q=v(H)?H:v(D)?D:w;return await new n(Q)()},je=y=>{let w=R(y),O=[];try{O=E(y)}catch{O=[]}let I=S(O),D=I?w+I:w;return(0,eval)(D)},$e=(y,w)=>{if(ne!==i)return y;let O=w.join(`
1110
- `).trim();return O||y},it=(y,w)=>y.length<=w?y:`${y.slice(0,w-3)}...`,Se=y=>{if(y===null)return"null";if(y===void 0)return"undefined";let w=typeof y;if(typeof y=="string")return JSON.stringify(it(y,40));if(w==="number"||w==="boolean"||w==="bigint"||w==="symbol")return String(y);if(w==="function")return`[function ${(y.name&&typeof y.name=="string"?y.name??"":"")||"anonymous"}]`;if(Array.isArray(y))return`[array(${y.length})]`;if(y instanceof Date)return Number.isFinite(y.getTime())?y.toISOString():String(y);if(y instanceof Error)return`${y.name||"Error"}: ${y.message||""}`;if(y instanceof Map)return`[map(${y.size})]`;if(y instanceof Set)return`[set(${y.size})]`;let O=y&&typeof y=="object"&&"constructor"in y&&y.constructor&&typeof y.constructor.name=="string"?y.constructor.name??"":"";return O&&O!=="Object"?`[${O}]`:"[object]"},ze=y=>{if(y===null)return{type:"null"};if(Array.isArray(y))return{type:"array",ctor:"Array"};if(y instanceof Map)return{type:"map",ctor:"Map"};if(y instanceof Set)return{type:"set",ctor:"Set"};if(y instanceof Date)return{type:"date",ctor:"Date"};if(y instanceof Error)return{type:"error",ctor:typeof y.name=="string"&&y.name.trim()?y.name:"Error"};let w=typeof y;return w!=="object"?{type:w}:{type:"object",ctor:y&&typeof y=="object"&&"constructor"in y&&y.constructor&&typeof y.constructor.name=="string"?y.constructor.name??void 0:void 0}},le=(y,w)=>{if(w==="string")return`${y.length} chars`;if(w==="array")return`${y.length} items`;if(w==="map"||w==="set")return`${y.size} items`;if(w==="object"&&y&&typeof y=="object")return`${Object.keys(y).length} keys`},De=(y,w,O)=>{if(w==="array")return"["+y.slice(0,3).map(D=>Se(D)).join(", ")+(y.length>3?", ...":"")+"]";if(w==="map"){let I=y,D=Array.from(I.entries()).slice(0,3).map(([H,Q])=>`${Se(H)} => ${Se(Q)}`);return"Map("+I.size+") {"+D.join(", ")+(I.size>3?", ...":"")+"}"}if(w==="set"){let I=y,D=Array.from(I.values()).slice(0,5).map(H=>Se(H));return"Set("+I.size+") {"+D.join(", ")+(I.size>5?", ...":"")+"}"}if(w==="date"||w==="error"||w==="function")return Se(y);if(w==="object"&&y&&typeof y=="object"){let I=Object.keys(y),D=I.slice(0,4);return(O&&O!=="Object"?`${O} `:"")+"{"+D.join(", ")+(I.length>D.length?", ...":"")+"}"}return Se(y)},We=y=>{let w=new Set([...t,...y??[]]),O=Object.getOwnPropertyNames(e).filter(I=>!w.has(I)&&!I.startsWith("_")).sort().flatMap(I=>{try{let D=Object.getOwnPropertyDescriptor(e,I);if(!D)return[];if("get"in D&&typeof D.get=="function"&&!("value"in D))return[{name:I,type:"accessor",preview:"[getter omitted]"}];let H="value"in D?D.value:e[I],Q=ze(H),W=le(H,Q.type),M=De(H,Q.type,Q.ctor);return[{name:I,type:Q.type,...Q.ctor?{ctor:Q.ctor}:{},...W?{size:W}:{},...M?{preview:it(M,96)}:{}}]}catch{return[{name:I,type:"unknown",preview:"[unavailable]"}]}});return JSON.stringify({version:1,entries:O})},Ye=y=>{if(typeof structuredClone=="function")try{return structuredClone(y),!0}catch{return!1}try{return JSON.stringify(y),!0}catch{return!1}},at=y=>{let w=new Set([...t,...y??[]]),O={};return{version:1,entries:Object.getOwnPropertyNames(e).filter(D=>!w.has(D)&&!D.startsWith("_")).sort().flatMap(D=>{try{let H=Object.getOwnPropertyDescriptor(e,D);if(!H)return[];if("get"in H&&typeof H.get=="function"&&!("value"in H))return[{name:D,type:"accessor",preview:"[getter omitted]",restorable:!1}];let Q="value"in H?H.value:e[D],W=ze(Q),M=le(Q,W.type),q=De(Q,W.type,W.ctor),ee=Ye(Q);return ee&&(O[D]=typeof structuredClone=="function"?structuredClone(Q):Q),[{name:D,type:W.type,...W.ctor?{ctor:W.ctor}:{},...M?{size:M}:{},...q?{preview:it(q,96)}:{},restorable:ee}]}catch{return[{name:D,type:"unknown",preview:"[unavailable]",restorable:!1}]}}),bindings:O}};f(async y=>{let w=y.data;if(!w||typeof w!="object"||typeof w.type!="string")return;if(w.type==="init"){ne=w.outputMode===i?i:s,pe=w.captureConsole!==void 0?!!w.captureConsole:ne===i;let W=w.allowUnsafeNodeHostAccess===!0;ge(w),U(w.permissions),G(W),t=Object.getOwnPropertyNames(e).sort();return}if(w.type==="fn-result"){if(typeof w.id!="number")return;let W=$.get(w.id);W&&($.delete(w.id),w.error!==void 0?W.reject(j(w.error)):W.resolve(w.value));return}if(w.type==="update-globals"){if(typeof w.id!="number")return;try{w.globals&&typeof w.globals=="object"&&oe(w.globals),g({type:"result",id:w.id,value:void 0})}catch(W){g({type:"result",id:w.id,error:te(W)})}return}if(w.type==="inspect-globals"){if(typeof w.id!="number")return;try{let W=Array.isArray(w.reservedNames)?w.reservedNames.filter(M=>typeof M=="string"):void 0;g({type:"result",id:w.id,value:We(W)})}catch(W){g({type:"result",id:w.id,error:te(W)})}return}if(w.type==="snapshot-globals"){if(typeof w.id!="number")return;try{let W=Array.isArray(w.reservedNames)?w.reservedNames.filter(M=>typeof M=="string"):void 0;g({type:"result",id:w.id,value:at(W)})}catch(W){g({type:"result",id:w.id,error:te(W)})}return}if(w.type!=="execute"||typeof w.id!="number"||typeof w.code!="string")return;let O=w.id,I=w.code,D=/\bawait\b/.test(I),{output:H,cleanup:Q}=F();try{X.length=0;let W=D?await Ie(I):je(I);if($.size>0&&await Ae(),await Promise.resolve(),X.length>0)throw X[0];let M=$e(W,H);try{g({type:"result",id:O,value:M})}catch{g({type:"result",id:O,value:String(M)})}}catch(W){V(W)?g({type:"result",id:O,value:ve(W,I,D?2:0)}):g({type:"result",id:O,error:te(W)})}finally{Q()}})}var ma=4,bu=16,ga="__ax_rlm_fn_ref__",fa=16;function Tu(){let o={functionRefKey:ga,maxErrorCauseDepth:fa},e=`(${Os.toString()})(${JSON.stringify(o)});
1095
+ );`},v=b=>{try{return new n(b),!0}catch{return!1}},O=b=>{let w=b.split(`
1096
+ `),k=h(w);if(k<0)return b;let T=new Set;for(let D=k;D>=0;D-=1){let H=w[D]??"";if(!H.trim()||A(H))continue;let Y=I(w,D,k);if(Y&&!T.has(Y)&&(T.add(Y),v(Y)))return Y}return b},R=b=>{let w=u.exec(b);return w&&(w[1]||"").trim()||b},E=b=>{let w=[],k=b.length,T=0,D=0,H=0,Y=Z=>Z>="a"&&Z<="z"||Z>="A"&&Z<="Z"||Z>="0"&&Z<="9"||Z==="_"||Z==="$",V=Z=>{if(T++,Z==="`"){let Q=0;for(;T<k;){let Ae=b[T];if(Ae==="\\"){T+=2;continue}if(Q>0){Ae==="{"?Q++:Ae==="}"&&Q--,T++;continue}if(Ae==="$"&&T+1<k&&b[T+1]==="{"){Q++,T+=2;continue}if(Ae==="`"){T++;return}T++}}else for(;T<k;){let Q=b[T];if(Q==="\\"){T+=2;continue}if(Q===Z){T++;return}T++}},P=()=>{for(T+=2;T<k&&b[T]!==`
1097
+ `;)T++},z=()=>{for(T+=2;T<k;){if(b[T]==="*"&&T+1<k&&b[T+1]==="/"){T+=2;return}T++}},ne=()=>{let Z=T;for(;T<k&&Y(b[T]);)T++;return b.slice(Z,T)},te=()=>{let Z=T;for(;T<k;){let Q=b[T];if(Q===" "||Q===" "||Q===`
1098
+ `||Q==="\r"){T++;continue}if(Q==="/"&&T+1<k){if(b[T+1]==="/"){P();continue}if(b[T+1]==="*"){z();continue}}break}return T>Z},Ie=Z=>{let Q=1;for(;T<k&&Q>0;){if(te(),T>=k)return;let Ae=b[T];if(Ae===Z){Q--,T++;continue}if(Ae==="{"||Ae==="["){let Se=Ae==="{"?"}":"]";T++,Q++,T--,Q--,T++,Ie(Se);continue}if(Ae==="."&&T+2<k&&b[T+1]==="."&&b[T+2]==="."){if(T+=3,te(),T<k&&Y(b[T])){let Se=ne();Se&&w.push(Se)}continue}if(Ae===","){T++;continue}if(Ae==="="){T++;let Se=0;for(;T<k;){let Fe=b[T];if(Fe==="'"||Fe==='"'||Fe==="`"){V(Fe);continue}if(Fe==="("||Fe==="["||Fe==="{"){Se++,T++;continue}if(Fe===")"||Fe==="]"||Fe==="}"){if(Se>0){Se--,T++;continue}break}if(Fe===","&&Se===0)break;T++}continue}if(Y(Ae)){let Se=ne();if(te(),T<k&&b[T]===":"){if(T++,te(),T<k){let Fe=b[T];if(Fe==="{"||Fe==="["){let Ve=Fe==="{"?"}":"]";T++,Ie(Ve)}else if(Y(Fe)){let Ve=ne();Ve&&w.push(Ve)}}}else Se&&w.push(Se);continue}T++}},Ue=()=>{let Z=0;for(;T<k;){let Q=b[T];if(Q==="'"||Q==='"'||Q==="`"){V(Q);continue}if(Q==="/"&&T+1<k){if(b[T+1]==="/"){P();continue}if(b[T+1]==="*"){z();continue}}if(Q==="("||Q==="["||Q==="{"){Z++,T++;continue}if(Q===")"||Q==="]"||Q==="}"){if(Z>0){Z--,T++;continue}return!1}if(Q===","&&Z===0)return T++,!0;if(Q===";"&&Z===0)return T++,!1;if(Q===`
1099
+ `&&Z===0){let Ae=T;return T++,te(),T<k&&b[T]===","?(T++,!0):(T=Ae,!1)}T++}return!1},be=()=>{for(;T<k;){if(te(),T>=k)return;let Z=b[T];if(Z==="{"){if(T++,Ie("}"),!Ue())return;continue}if(Z==="["){if(T++,Ie("]"),!Ue())return;continue}if(Y(Z)){let Q=ne();if(Q&&w.push(Q),!Ue())return;continue}return}},qe=Z=>{if(Z===0)return!0;let Q=Z-1;for(;Q>=0;){let Ae=b[Q];if(Ae===" "||Ae===" "||Ae==="\r"){Q--;continue}return Ae===`
1100
+ `||Ae===";"||Ae==="{"||Ae==="}"}return!0};for(;T<k;){let Z=b[T];if(Z==="'"||Z==='"'||Z==="`"){V(Z);continue}if(Z==="/"&&T+1<k){if(b[T+1]==="/"){P();continue}if(b[T+1]==="*"){z();continue}}if(Z==="{"){D++,T++;continue}if(Z==="}"){D--,T++;continue}if(Z==="("){H++,T++;continue}if(Z===")"){H--,T++;continue}if(D===0&&H===0&&Y(Z)){let Q=T,Ae=ne();if((Ae==="var"||Ae==="let"||Ae==="const")&&T<k&&(b[T]===" "||b[T]===" "||b[T]===`
1101
+ `)&&qe(Q)){be();continue}continue}T++}let Ne=new Set,nt=[];for(let Z of w)Ne.has(Z)||(Ne.add(Z),nt.push(Z));return nt},S=b=>b.length===0?"":`
1102
+ try { ${b.map(k=>`globalThis[${JSON.stringify(k)}] = ${k};`).join(" ")} } catch (_ax_e) {} void 0;`,_=b=>{if(typeof b=="string")return b;try{return JSON.stringify(b,null,2)}catch{return String(b)}},$=(b,w)=>{let k=e.console&&typeof e.console=="object"?e.console:null,T=k?.[b],D=typeof T=="function"?(...Y)=>T.apply(k,Y):null,H=(...Y)=>{w.push(Y.map(_).join(" "))};return(!e.console||typeof e.console!="object")&&(e.console={}),e.console[b]=H,()=>{if(!(!e.console||typeof e.console!="object")){if(D){e.console[b]=D;return}try{delete e.console[b]}catch{e.console[b]=void 0}}}},M=b=>{let w=[];return he&&(w.push($("log",b)),w.push($("info",b)),w.push($("warn",b)),w.push($("error",b))),w},F=()=>{let b=[],w=M(b),k=e.print;return ee===i&&(e.print=(...D)=>{b.push(D.map(_).join(" "))}),{output:b,cleanup:()=>{for(let D of w)try{D()}catch{}if(ee===i)if(k===void 0)try{delete e.print}catch{e.print=void 0}else e.print=k}}},N=b=>{for(let w of b)try{Object.defineProperty(e,w,{value:void 0,writable:!1,configurable:!1})}catch{}},G=b=>{let w=new Set(Array.isArray(b)?b:[]);for(let[k,T]of Object.entries(c))w.has(k)||N(T)},W=b=>{p&&!b&&N(["process","require"])},U=o.maxErrorCauseDepth,ae=(b,w=0,k=new Set)=>{if(w>U)return{name:"Error",message:"[cause chain truncated]"};if(b&&typeof b=="object"){if(k.has(b))return{name:"Error",message:"[circular]"};k.add(b)}let T=b,D=T?.name!=null?String(T.name):"Error",H=T?.message!=null?String(T.message):oe(b),Y=typeof T?.stack=="string"?T.stack:void 0,V;if(typeof T?.cause<"u"&&w<U)try{let z=T.cause;z instanceof Error||z&&typeof z=="object"&&("message"in z||"name"in z)?V=ae(z,w+1,k):V={name:"Error",message:oe(z)}}catch{V={name:"Error",message:oe(T.cause)}}let P={name:D,message:H};if(Y!==void 0&&(P.stack=Y),V!==void 0&&(P.cause=V),typeof T?.data<"u")try{P.data=typeof structuredClone=="function"?structuredClone(T.data):T.data}catch{}return P},j=b=>{if(typeof b=="string")return new Error(b);if(!b||typeof b!="object")return new Error(String(b));let w=b,k=new Error(w.message!=null?String(w.message):"");return k.name=w.name!=null?String(w.name):"Error",typeof w.stack=="string"&&(k.stack=w.stack),w.cause!==void 0&&(k.cause=j(w.cause)),w.data!==void 0&&(k.data=w.data),k},re=b=>{let w=globalThis.AggregateError,k=typeof w=="function"&&b instanceof w;return b instanceof SyntaxError||b instanceof TypeError||b instanceof RangeError||b instanceof ReferenceError||k||b instanceof EvalError||b instanceof URIError},oe=b=>{if(b==null||typeof b!="object")return String(b);try{return JSON.stringify(b,null,2)}catch{return String(b)}},Ce=(b,w,k=0)=>{let T=b,D=T?.name!=null?String(T.name):"Error",H=T?.message!=null?String(T.message):oe(b),Y=[`${D}: ${H}`],V;if(typeof T?.stack=="string"){let P=T.stack.match(/<anonymous>:(\d+):(\d+)/);P&&(V=Math.max(1,Number(P[1])-k),Y.push(` at line ${V}, column ${P[2]}`))}if(w&&V!==void 0&&V>=1&&V<=w.split(`
1103
+ `).length){let P=w.split(`
1104
+ `),z=Math.max(0,V-2),ne=Math.min(P.length,V+1),Ie=P.slice(z,ne).map((Ue,be)=>` ${String(z+be+1).padStart(3)}| ${Ue}`).join(`
1105
+ `);Y.push(`Source:
1106
+ ${Ie}`)}if(T?.data!==void 0&&Y.push(`Data: ${oe(T.data)}`),T?.cause!==void 0){let P=(z,ne)=>{if(ne>4)return"[cause chain truncated]";let te=z,Ie=te?.name!=null?String(te.name):"Error",Ue=te?.message!=null?String(te.message):oe(z),be=[`${Ie}: ${Ue}`];return te?.data!==void 0&&be.push(`Data: ${oe(te.data)}`),te?.cause!==void 0&&be.push(`Caused by: ${P(te.cause,ne+1)}`),be.join(`
1107
+ `)};Y.push(`Caused by: ${P(T.cause,1)}`)}return Y.join(`
1108
+ `)},L=new Map,K=0,ee=s,he=!1,q=[],B=b=>{if(!b||typeof b!="object"||Array.isArray(b))return!1;let w=Object.getPrototypeOf(b);return w===Object.prototype||w===null},ue=b=>typeof b=="string"&&b.trim().length>0,ke=b=>{if(!ue(b)){if(!B(b))throw new Error("ask_clarification() choice entries must be non-empty strings or objects with a non-empty label");if(!ue(b.label))throw new Error("ask_clarification() choice objects require a non-empty label");if(b.value!==void 0&&!ue(b.value))throw new Error("ask_clarification() choice object values must be non-empty strings")}},Oe=b=>{if(ue(b))return;if(!B(b))throw new Error("ask_clarification() requires a non-empty string or an object payload");if(!ue(b.question))throw new Error("ask_clarification() object payload requires a non-empty question");let w=new Set(["text","number","date","single_choice","multiple_choice"]),k;if(b.type===void 0)k=Array.isArray(b.choices)&&b.choices.length>0?"single_choice":void 0;else{if(typeof b.type!="string"||!w.has(b.type))throw new Error("ask_clarification() object payload type must be one of: text, number, date, single_choice, multiple_choice");k=b.type}let T=k==="single_choice"||k==="multiple_choice",D=b.choices;if(D!==void 0){if(!Array.isArray(D)||D.length===0)throw new Error("ask_clarification() choices must be a non-empty array when provided");for(let H of D)ke(H)}else if(T)throw new Error("ask_clarification() choice payloads require a non-empty choices array")},ce=(b,w)=>{if(b==="final"){if(w.length===0)throw new Error("final() requires at least one argument");return}if(b==="ask_clarification"){if(w.length!==1)throw new Error("ask_clarification() requires exactly one argument");Oe(w[0])}},Re=b=>{if(b==="final"||b==="ask_clarification")return b;let k=/^fn_\d+_(.+)$/.exec(b)?.[1];if(k==="final"||k==="ask_clarification")return k},se=b=>(...w)=>{let k=Re(b);k&&ce(k,w);let T=++K,D=!1,H=new Promise((te,Ie)=>{L.set(T,{resolve:te,reject:Ie}),g({type:"fn-call",id:T,name:b,args:w})}),Y=H.then.bind(H),V=H.catch.bind(H),P=H.finally.bind(H),z=()=>{D=!0},ne=new Proxy(H,{get(te,Ie,Ue){return Ie==="then"?(...be)=>(z(),Y(...be)):Ie==="catch"?(...be)=>(z(),V(...be)):Ie==="finally"?(...be)=>(z(),P(...be)):Reflect.get(te,Ie,Ue)}});return H.catch(te=>{D||q.push(te)}),ne},de=async()=>{for(let b=0;b<50&&L.size>0;b+=1)await new Promise(w=>{setTimeout(w,0)})},J=b=>{if(!b||typeof b!="object")return b;if(Array.isArray(b)){for(let k=0;k<b.length;k+=1)b[k]=J(b[k]);return b}let w=b;if(r in w){let k=w[r];return typeof k=="string"?se(k):void 0}for(let[k,T]of Object.entries(w))w[k]=J(T);return b},X=b=>{for(let[w,k]of Object.entries(b)){let T=J(k),D=e[w];if(B(D)&&B(T)){for(let H of Object.keys(D))Object.hasOwn(T,H)||delete D[H];for(let[H,Y]of Object.entries(T))D[H]=Y;continue}e[w]=T}},xe=b=>{if(b.globals&&typeof b.globals=="object"&&X(b.globals),Array.isArray(b.fnNames))for(let w of b.fnNames)typeof w=="string"&&(e[w]=se(w))},we=async b=>{let w=x(b),k=[];try{k=E(b)}catch{k=[]}let T=S(k),D=w;try{D=O(w)}catch{D=w}let H=D;if(T){let P=D.lastIndexOf(`
1109
+ return (`);P!==-1?H=D.slice(0,P)+T+D.slice(P):H=D+T}let Y=v(H)?H:v(D)?D:w;return await new n(Y)()},Be=b=>{let w=R(b),k=[];try{k=E(b)}catch{k=[]}let T=S(k),D=T?w+T:w;return(0,eval)(D)},$e=(b,w)=>{if(ee!==i)return b;let k=w.join(`
1110
+ `).trim();return k||b},ut=(b,w)=>b.length<=w?b:`${b.slice(0,w-3)}...`,Ee=b=>{if(b===null)return"null";if(b===void 0)return"undefined";let w=typeof b;if(typeof b=="string")return JSON.stringify(ut(b,40));if(w==="number"||w==="boolean"||w==="bigint"||w==="symbol")return String(b);if(w==="function")return`[function ${(b.name&&typeof b.name=="string"?b.name??"":"")||"anonymous"}]`;if(Array.isArray(b))return`[array(${b.length})]`;if(b instanceof Date)return Number.isFinite(b.getTime())?b.toISOString():String(b);if(b instanceof Error)return`${b.name||"Error"}: ${b.message||""}`;if(b instanceof Map)return`[map(${b.size})]`;if(b instanceof Set)return`[set(${b.size})]`;let k=b&&typeof b=="object"&&"constructor"in b&&b.constructor&&typeof b.constructor.name=="string"?b.constructor.name??"":"";return k&&k!=="Object"?`[${k}]`:"[object]"},ze=b=>{if(b===null)return{type:"null"};if(Array.isArray(b))return{type:"array",ctor:"Array"};if(b instanceof Map)return{type:"map",ctor:"Map"};if(b instanceof Set)return{type:"set",ctor:"Set"};if(b instanceof Date)return{type:"date",ctor:"Date"};if(b instanceof Error)return{type:"error",ctor:typeof b.name=="string"&&b.name.trim()?b.name:"Error"};let w=typeof b;return w!=="object"?{type:w}:{type:"object",ctor:b&&typeof b=="object"&&"constructor"in b&&b.constructor&&typeof b.constructor.name=="string"?b.constructor.name??void 0:void 0}},pe=(b,w)=>{if(w==="string")return`${b.length} chars`;if(w==="array")return`${b.length} items`;if(w==="map"||w==="set")return`${b.size} items`;if(w==="object"&&b&&typeof b=="object")return`${Object.keys(b).length} keys`},De=(b,w,k)=>{if(w==="array")return"["+b.slice(0,3).map(D=>Ee(D)).join(", ")+(b.length>3?", ...":"")+"]";if(w==="map"){let T=b,D=Array.from(T.entries()).slice(0,3).map(([H,Y])=>`${Ee(H)} => ${Ee(Y)}`);return"Map("+T.size+") {"+D.join(", ")+(T.size>3?", ...":"")+"}"}if(w==="set"){let T=b,D=Array.from(T.values()).slice(0,5).map(H=>Ee(H));return"Set("+T.size+") {"+D.join(", ")+(T.size>5?", ...":"")+"}"}if(w==="date"||w==="error"||w==="function")return Ee(b);if(w==="object"&&b&&typeof b=="object"){let T=Object.keys(b),D=T.slice(0,4);return(k&&k!=="Object"?`${k} `:"")+"{"+D.join(", ")+(T.length>D.length?", ...":"")+"}"}return Ee(b)},We=b=>{let w=new Set([...t,...b??[]]),k=Object.getOwnPropertyNames(e).filter(T=>!w.has(T)&&!T.startsWith("_")).sort().flatMap(T=>{try{let D=Object.getOwnPropertyDescriptor(e,T);if(!D)return[];if("get"in D&&typeof D.get=="function"&&!("value"in D))return[{name:T,type:"accessor",preview:"[getter omitted]"}];let H="value"in D?D.value:e[T],Y=ze(H),V=pe(H,Y.type),P=De(H,Y.type,Y.ctor);return[{name:T,type:Y.type,...Y.ctor?{ctor:Y.ctor}:{},...V?{size:V}:{},...P?{preview:ut(P,96)}:{}}]}catch{return[{name:T,type:"unknown",preview:"[unavailable]"}]}});return JSON.stringify({version:1,entries:k})},Ye=b=>{if(typeof structuredClone=="function")try{return structuredClone(b),!0}catch{return!1}try{return JSON.stringify(b),!0}catch{return!1}},ct=b=>{let w=new Set([...t,...b??[]]),k={};return{version:1,entries:Object.getOwnPropertyNames(e).filter(D=>!w.has(D)&&!D.startsWith("_")).sort().flatMap(D=>{try{let H=Object.getOwnPropertyDescriptor(e,D);if(!H)return[];if("get"in H&&typeof H.get=="function"&&!("value"in H))return[{name:D,type:"accessor",preview:"[getter omitted]",restorable:!1}];let Y="value"in H?H.value:e[D],V=ze(Y),P=pe(Y,V.type),z=De(Y,V.type,V.ctor),ne=Ye(Y);return ne&&(k[D]=typeof structuredClone=="function"?structuredClone(Y):Y),[{name:D,type:V.type,...V.ctor?{ctor:V.ctor}:{},...P?{size:P}:{},...z?{preview:ut(z,96)}:{},restorable:ne}]}catch{return[{name:D,type:"unknown",preview:"[unavailable]",restorable:!1}]}}),bindings:k}};f(async b=>{let w=b.data;if(!w||typeof w!="object"||typeof w.type!="string")return;if(w.type==="init"){ee=w.outputMode===i?i:s,he=w.captureConsole!==void 0?!!w.captureConsole:ee===i;let V=w.allowUnsafeNodeHostAccess===!0;xe(w),G(w.permissions),W(V),t=Object.getOwnPropertyNames(e).sort();return}if(w.type==="fn-result"){if(typeof w.id!="number")return;let V=L.get(w.id);V&&(L.delete(w.id),w.error!==void 0?V.reject(j(w.error)):V.resolve(w.value));return}if(w.type==="update-globals"){if(typeof w.id!="number")return;try{w.globals&&typeof w.globals=="object"&&X(w.globals),g({type:"result",id:w.id,value:void 0})}catch(V){g({type:"result",id:w.id,error:ae(V)})}return}if(w.type==="inspect-globals"){if(typeof w.id!="number")return;try{let V=Array.isArray(w.reservedNames)?w.reservedNames.filter(P=>typeof P=="string"):void 0;g({type:"result",id:w.id,value:We(V)})}catch(V){g({type:"result",id:w.id,error:ae(V)})}return}if(w.type==="snapshot-globals"){if(typeof w.id!="number")return;try{let V=Array.isArray(w.reservedNames)?w.reservedNames.filter(P=>typeof P=="string"):void 0;g({type:"result",id:w.id,value:ct(V)})}catch(V){g({type:"result",id:w.id,error:ae(V)})}return}if(w.type!=="execute"||typeof w.id!="number"||typeof w.code!="string")return;let k=w.id,T=w.code,D=/\bawait\b/.test(T),{output:H,cleanup:Y}=F();try{q.length=0;let V=D?await we(T):Be(T);if(L.size>0&&await de(),await Promise.resolve(),q.length>0)throw q[0];let P=$e(V,H);try{g({type:"result",id:k,value:P})}catch{g({type:"result",id:k,value:String(P)})}}catch(V){re(V)?g({type:"result",id:k,value:Ce(V,T,D?2:0)}):g({type:"result",id:k,error:ae(V)})}finally{Y()}})}var ya=4,Pl=16,ba="__ax_rlm_fn_ref__",Ca=16;function Fl(){let o={functionRefKey:ba,maxErrorCauseDepth:Ca},e=`(${Fs.toString()})(${JSON.stringify(o)});
1111
1111
  `,t="";return e.includes("__name")&&(t+=`var __name=(fn,_n)=>fn;
1112
- `),t?`${t}${e}`:e}var Cu=()=>typeof Worker<"u"&&typeof Blob<"u"&&typeof URL<"u"&&typeof URL.createObjectURL=="function",Es=()=>typeof process<"u"&&!!process.versions?.node,bm=()=>!!globalThis.Deno?.version?.deno,Tm=()=>globalThis.Deno?.version?.deno??null,Cm=o=>{let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(o.trim());return e?{major:Number(e[1]),minor:Number(e[2]),patch:Number(e[3])}:null},Iu=o=>Number.isFinite(o)?Math.max(1,Math.min(bu,Math.floor(o))):ma,Im=()=>{if(!Es())return null;let e=globalThis.process?.getBuiltinModule;if(typeof e!="function")return null;let n=e("node:os")?.availableParallelism;if(typeof n!="function")return null;let r=n();return Number.isFinite(r)&&r>0?r:null},wm=o=>{if(o!==void 0)return Iu(o);let e=Im();return e?Iu(Math.ceil(e/2)):ma},Rm=o=>o?.debugNodeWorkerPool?!0:(globalThis.process?.env??{}).AX_RLM_DEBUG_NODE_POOL==="1",vm=o=>{let e=new Set(o),t={};return e.has("network")&&(t.net=!0),Object.keys(t).length>0?t:"none"},Sm=(o,e)=>{let t=Tm(),n=t?Cm(t):null;if(n?n.major>=1:!0)try{return new Worker(o,{type:"module",deno:{permissions:vm(e)}})}catch{}return new Worker(o,{type:"module"})},wu=(o,e)=>{let t=new Blob([o],{type:"application/javascript"}),n=URL.createObjectURL(t),r=bm()?Sm(n,e):new Worker(n),s=!1,i=()=>{s||(URL.revokeObjectURL(n),s=!0)},a={postMessage:l=>r.postMessage(l),terminate:()=>{r.terminate(),i()},onmessage:null,onerror:null};return r.onmessage=l=>{a.onmessage?.({data:l.data})},r.onerror=l=>{a.onerror?.(new Error(l.message||"Worker error"))},a},ya=async o=>{let e="node:worker_threads",{Worker:t}=await import(e),n=new t(o,{eval:!0}),r=null,s=null,i=!1;n.on("error",l=>{s?s(l):r=l}),n.on("exit",l=>{if(i=!0,l!==0&&!r){let c=new Error(`Worker exited with code ${l}`);s?s(c):r=c}}),n.on("message",l=>{a.onmessage?.({data:l})});let a={postMessage:l=>n.postMessage(l),terminate:()=>{n.terminate()},onmessage:null,get onerror(){return s},set onerror(l){if(s=l,l&&r){let c=r;r=null,l(c)}},get exited(){return i}};return a},ba=class{source;maxSize;idle=[];pendingCreates=0;constructor(e,t){this.source=e,this.maxSize=t}warm(){if(Es())for(;this.idle.length+this.pendingCreates<this.maxSize;)this.pendingCreates+=1,ya(this.source).then(e=>{e.onmessage=null,e.onerror=null,this.idle.push(e)}).catch(()=>{}).finally(()=>{this.pendingCreates-=1})}async acquire(){for(;this.idle.length>0;){let e=this.idle.pop();if(!e.exited)return this.warm(),e}return this.warm(),ya(this.source)}release(e){e.onmessage=null,e.onerror=null,e.terminate(),this.warm()}},Ru=new Map,km=(o,e)=>`${e}:${o}`,Om=(o,e)=>{let t=km(o,e),n=Ru.get(t);if(n)return n;let r=new ba(o,e);return Ru.set(t,r),r},vu=(o,e)=>{let t={},n=new Map,r=0,s=new WeakMap,i=(a,l)=>{if(typeof a=="function"){let g=`fn_${e?.nextFnId?e.nextFnId():++r}_${l||"root"}`;return n.set(g,a),{[ga]:g}}if(!a||typeof a!="object")return a;if(s.has(a))return s.get(a);if(Array.isArray(a)){let m=[];s.set(a,m);for(let g=0;g<a.length;g+=1)m[g]=i(a[g],`${l}[${g}]`);return m}let c=Object.getPrototypeOf(a);if(!(c===Object.prototype||c===null))return a;let p=a,d={};s.set(a,d);for(let[m,g]of Object.entries(p))d[m]=i(g,l?`${l}.${m}`:m);return d};if(o)for(let[a,l]of Object.entries(o))t[a]=i(l,a);return{serializableGlobals:t,fnMap:n}},Su=o=>{if(typeof structuredClone=="function")try{structuredClone(o)}catch(e){let t=e instanceof Error?e.message:String(e);throw new Error(`RLM globals must be structured-cloneable: ${t}`)}},ha=o=>!!o&&/[A-Za-z0-9_$]/.test(o),xa=o=>!!o&&/[A-Za-z_$]/.test(o),Em=(o,e)=>{let t=new Set(e);for(let m of Vr(o))if(t.has(m))return m;let n=Ft(o),r=n.length,s=0,i=0,a=0,l=m=>{let g=m;for(;g<r&&/\s/.test(n[g]??"");)g++;return g},c=m=>{let g=m;for(;g>=0&&/\s/.test(n[g]??"");)g--;return g},u=m=>{let g=c(m-1);if(g<0)return!0;let f=n[g];return f===`
1113
- `||f===";"||f==="{"||f==="}"},p=()=>{let m=s;for(;s<r&&ha(n[s]);)s++;return n.slice(m,s)},d=m=>{let g=n.slice(m,m+2);return n.slice(m,m+3)==="==="||g==="=="||g==="=>"?!1:n[m]==="="||["+=","-=","*=","/=","%=","&=","|=","^=","&&=","||=","??=","**=","<<=",">>=",">>>="].some(x=>n.startsWith(x,m))};for(;s<r;){let m=n[s];if(m==="{"){i++,s++;continue}if(m==="}"){i--,s++;continue}if(m==="("){a++,s++;continue}if(m===")"){a--,s++;continue}if(i===0&&a===0&&xa(m)){let g=s,f=p();if((f==="function"||f==="class")&&u(g)){let x=l(s);if(xa(n[x])){let A=x+1;for(;A<r&&ha(n[A]);)A++;let h=n.slice(x,A);if(t.has(h))return h}continue}if(f==="async"&&u(g)){let x=l(s);if(n.startsWith("function",x)){let A=l(x+8);if(xa(n[A])){let h=A+1;for(;h<r&&ha(n[h]);)h++;let b=n.slice(A,h);if(t.has(b))return b}}continue}if(t.has(f)){let x=c(g-1),A=x>=0?n[x]:void 0,h=l(s),b=A==="."||A==="?"||A==="["&&n[h]==="]",T=n.startsWith("++",h)||n.startsWith("--",h)||x>0&&(n.slice(x-1,x+1)==="++"||n.slice(x-1,x+1)==="--");if(!b&&(T||d(h)))return f}continue}s++}};function Aa(o){if(o==null||typeof o!="object")return String(o);try{return JSON.stringify(o,null,2)}catch{return String(o)}}function ku(o,e=fa,t=0,n=new Set){if(t>e)return{name:"Error",message:"[cause chain truncated]"};if(o!==null&&typeof o=="object"){if(n.has(o))return{name:"Error",message:"[circular]"};n.add(o)}let r=o!==null&&typeof o=="object"&&o.name!=null?String(o.name):"Error",s=o!==null&&typeof o=="object"&&o.message!=null?String(o.message):Aa(o),i=o!==null&&typeof o=="object"&&typeof o.stack=="string"?o.stack:void 0,a,l=o;if(l&&typeof l=="object"&&l.cause!==void 0&&t<e)try{let p=l.cause;p instanceof Error||p!==null&&typeof p=="object"&&("message"in p||"name"in p)?a=ku(p,e,t+1,n):a={name:"Error",message:Aa(p)}}catch{a={name:"Error",message:Aa(l.cause)}}let c={name:r,message:s};i!==void 0&&(c.stack=i),a!==void 0&&(c.cause=a);let u=o;if(u&&typeof u=="object"&&"data"in u&&u.data!==void 0)try{typeof structuredClone=="function"?c.data=structuredClone(u.data):c.data=u.data}catch{}return c}function Ou(o){if(typeof o=="string")return new Error(o);if(!o||typeof o!="object")return new Error(String(o));let e=o.message!=null?String(o.message):"Unknown error",t=new Error(e);return t.name=o.name!=null?String(o.name):"Error",typeof o.stack=="string"&&(t.stack=o.stack),o.cause!==void 0&&(t.cause=Ou(o.cause)),o.data!==void 0&&(t.data=o.data),t}function Mm(o){if(!o||typeof o!="object")return!1;let e=o;return typeof e.name=="string"&&typeof e.type=="string"&&(e.ctor===void 0||typeof e.ctor=="string")&&(e.size===void 0||typeof e.size=="string")&&(e.preview===void 0||typeof e.preview=="string")&&(e.restorable===void 0||typeof e.restorable=="boolean")}function Pm(o){if(!o||typeof o!="object")return{version:1,entries:[],bindings:{}};let e=o,t=Array.isArray(e.entries)?e.entries:[],n=e.bindings&&typeof e.bindings=="object"?e.bindings:{};return{version:1,entries:t.filter(Mm),bindings:n}}var Ta=(i=>(i.NETWORK="network",i.STORAGE="storage",i.CODE_LOADING="code-loading",i.COMMUNICATION="communication",i.TIMING="timing",i.WORKERS="workers",i))(Ta||{}),ln=class{language="JavaScript";timeout;permissions;allowUnsafeNodeHostAccess;nodeWorkerPoolSize;debugNodeWorkerPool;outputMode;captureConsole;constructor(e){this.timeout=e?.timeout??3e4,this.permissions=e?.permissions??[],this.allowUnsafeNodeHostAccess=e?.allowUnsafeNodeHostAccess??!1,this.outputMode=e?.outputMode??"stdout",this.captureConsole=e?.captureConsole??this.outputMode==="stdout",this.nodeWorkerPoolSize=wm(e?.nodeWorkerPoolSize),this.debugNodeWorkerPool=Rm(e)}getUsageInstructions(){return["Don't wrap async code in (async()=>{ ... })() \u2014 the runtime automatically handles async execution.","State is session-scoped: all top-level declarations (`var`, `let`, `const`) persist across calls.","Bare assignment (e.g. `x = 1`) also persists via `globalThis`.",...this.outputMode==="stdout"?["Use `console.log(...)` output is captured as the execution result so use it to inspect intermediate values between steps instead of `return`."]:["Use `return` or a trailing expression to produce the execution result."]].map(t=>`- ${t}`).join(`
1114
- `)}createSession(e){let t=Tu(),n=Es()?Om(t,this.nodeWorkerPoolSize):null;n&&this.debugNodeWorkerPool&&console.debug(`[AxJSRuntime] Node worker pool size: ${this.nodeWorkerPoolSize}`),n?.warm();let r=null,s=null,i=null,a=!1,l=this.timeout,c=0,{serializableGlobals:u,fnMap:p}=vu(e,{nextFnId:()=>++c});Su(u);let d=new Map,m=0,g=[],f=null,x=R=>{let E=R.data;if(!E||typeof E!="object"||!("type"in E)||E.type===void 0)return;let S=E;if(S.type==="result"){if(typeof S.id!="number")return;let _=d.get(S.id);_&&(d.delete(S.id),S.error!==void 0?_.reject(Ou(S.error)):_.resolve(S.value));return}if(S.type==="fn-call"){if(typeof S.id!="number"||typeof S.name!="string")return;let _=p.get(S.name);if(!_){r?.postMessage({type:"fn-result",id:S.id,error:`Function "${S.name}" not found`});return}Promise.resolve().then(()=>_(...S.args??[])).then(L=>{r?.postMessage({type:"fn-result",id:S.id,value:L})}).catch(L=>{r?.postMessage({type:"fn-result",id:S.id,error:ku(L)})})}},A=()=>{r&&(s==="node"&&n?n.release(r):r.terminate(),r=null,s=null),i=null},h=()=>{a=!0,A();for(let R of g)!R.started&&!R.settled&&(R.settled=!0,R.signal&&R.onAbort&&R.signal.removeEventListener("abort",R.onAbort),R.reject(new Error("Worker terminated")));g.length=0;for(let R of d.values())R.reject(new Error("Worker terminated"));d.clear()},b=R=>{A();for(let E of d.values())E.reject(R);d.clear()},T=R=>{R.postMessage({type:"init",globals:u,fnNames:[...p.keys()],permissions:[...this.permissions],allowUnsafeNodeHostAccess:this.allowUnsafeNodeHostAccess,outputMode:this.outputMode,captureConsole:this.captureConsole})};if(Cu()){r=wu(t,this.permissions),s="browser",r.onmessage=x,r.onerror=b;try{T(r)}catch(R){throw h(),R}}let C=async()=>{if(!r){if(a)throw new Error("Session is closed");if(Cu()){r=wu(t,this.permissions),s="browser",r.onmessage=x,r.onerror=b;try{T(r)}catch(R){throw h(),R}return}if(!Es())throw new Error("No worker runtime available: Web Worker is unavailable in this environment");i||(i=(n?n.acquire():ya(t)).then(R=>{if(a)throw n?n.release(R):R.terminate(),new Error("Session is closed");r=R,s="node",r.onmessage=x,r.onerror=b;try{T(r)}catch(E){throw n?n.release(R):R.terminate(),r=null,s=null,E}})),await i}},v=(R,E)=>{if(a)return Promise.reject(new Error("Session is closed"));let S=E.signal;if(S?.aborted)return Promise.reject(new Error(`Aborted: ${S.reason??"execution aborted"}`));let _=++m;return new Promise((L,P)=>{let F=L,N=P,U,G=()=>{};if(d.set(_,{resolve:B=>{U&&clearTimeout(U),G(),F(B)},reject:B=>{U&&clearTimeout(U),G(),N(B)}}),S){let B=()=>{clearTimeout(U),d.delete(_),h(),N(new Error(`Aborted: ${S.reason??"execution aborted"}`))};S.addEventListener("abort",B,{once:!0}),G=()=>{S.removeEventListener("abort",B)}}C().then(()=>{if(!r)throw new Error("Worker unavailable");U=setTimeout(()=>{d.delete(_),A();for(let B of d.values())B.reject(new Error("Worker terminated"));d.clear(),P(new Error(E.timeoutMessage))},l),r.postMessage({...R,id:_})}).catch(B=>{d.get(_)&&(d.delete(_),clearTimeout(U),G(),N(B))})})},k=(R,E)=>a?Promise.reject(new Error("Session is closed")):R?.aborted?Promise.reject(new Error(`Aborted: ${R.reason??"execution aborted"}`)):new Promise((S,_)=>{let L={started:!1,settled:!1,signal:R,resolve:S,reject:_,operation:E};if(R){let F=()=>{if(L.settled)return;L.settled=!0;let N=g.indexOf(L);N!==-1&&g.splice(N,1),R.removeEventListener("abort",F),_(new Error(`Aborted: ${R.reason??"execution aborted"}`))};L.onAbort=F,R.addEventListener("abort",F,{once:!0})}g.push(L);let P=()=>{if(f)return;let F=g.find(U=>!U.started&&!U.settled);if(!F)return;let N=()=>{f=null,P()};f=(async()=>{if(!F.settled){if(a){F.settled=!0,F.signal&&F.onAbort&&F.signal.removeEventListener("abort",F.onAbort),F.reject(new Error("Worker terminated"));return}if(F.signal?.aborted){F.settled=!0,F.onAbort&&F.signal.removeEventListener("abort",F.onAbort),F.reject(new Error(`Aborted: ${F.signal.reason??"execution aborted"}`));return}F.started=!0;try{let U=await F.operation();if(F.settled)return;F.settled=!0,F.signal&&F.onAbort&&F.signal.removeEventListener("abort",F.onAbort),F.resolve(U)}catch(U){if(F.settled)return;F.settled=!0,F.signal&&F.onAbort&&F.signal.removeEventListener("abort",F.onAbort),F.reject(U)}finally{let U=g.indexOf(F);U!==-1&&g.splice(U,1),N()}}})().catch(()=>{N()})};P()});return{execute(R,E){if(a)return Promise.reject(new Error("Session is closed"));if(/['"]use strict['"]/.test(R))return Promise.resolve('[ERROR] "use strict" is not allowed in the runtime session. Remove it and try again.');let S=E?.reservedNames;if(S){let _=Em(R,S);if(_)return Promise.resolve(`[ERROR] Cannot assign to, redeclare, or shadow reserved runtime variable '${_}'. Use a different local variable name (for example: \`ctx\`) or access the original via \`inputs.${_}\`.`)}return k(E?.signal,()=>v({type:"execute",code:R},{signal:E?.signal,timeoutMessage:"Execution timed out"}))},inspectGlobals(R){return a?Promise.reject(new Error("Session is closed")):k(R?.signal,()=>v({type:"inspect-globals",reservedNames:R?.reservedNames},{signal:R?.signal,timeoutMessage:"Global inspection timed out"}).then(E=>typeof E=="string"?E:E===void 0?"":JSON.stringify(E)))},snapshotGlobals(R){return a?Promise.reject(new Error("Session is closed")):k(R?.signal,()=>v({type:"snapshot-globals",reservedNames:R?.reservedNames},{signal:R?.signal,timeoutMessage:"Global snapshot timed out"}).then(Pm))},async patchGlobals(R,E){if(!R||typeof R!="object"||Array.isArray(R))throw new Error("patchGlobals expects an object");let{serializableGlobals:S,fnMap:_}=vu(R,{nextFnId:()=>++c});if(Su(S),Object.keys(S).length!==0){await k(E?.signal,()=>v({type:"update-globals",globals:S},{signal:E?.signal,timeoutMessage:"Global patch timed out"}));for(let[L,P]of Object.entries(S))u[L]=P;for(let[L,P]of _.entries())p.set(L,P)}},close(){h()}}}toFunction(){return{name:"javascriptInterpreter",description:"Execute JavaScript code in a persistent session and return output.",parameters:{type:"object",properties:{code:{type:"string",description:"JavaScript code to execute."}},required:["code"]},func:async({code:e},t)=>{let n=this.createSession();try{return await n.execute(e,{signal:t?.abortSignal})}finally{n.close()}}}}};function Eu(o){return new ln(o)}var Ms=class{constructor(e,t={}){this.transport=e;this.options=t;this.logger=t.logger??(n=>{console.log(typeof n=="string"?n:JSON.stringify(n,null,2))})}functions=[];promptFunctions=[];resourceFunctions=[];activeRequests=new Map;capabilities={};logger;async init(){"connect"in this.transport&&await this.transport.connect?.();let{result:e}=await this.sendRequest("initialize",{protocolVersion:"2024-11-05",capabilities:{roots:{listChanged:!0},sampling:{}},clientInfo:{name:"AxMCPClient",version:"1.0.0"}}),t="2024-11-05";if(e.protocolVersion!==t)throw new Error(`Protocol version mismatch. Expected ${t} but got ${e.protocolVersion}`);e.capabilities.tools&&(this.capabilities.tools=!0),e.capabilities.resources&&(this.capabilities.resources=!0),e.capabilities.prompts&&(this.capabilities.prompts=!0),await this.sendNotification("notifications/initialized"),this.capabilities.tools&&await this.discoverFunctions(),this.capabilities.prompts&&await this.discoverPromptFunctions(),this.capabilities.resources&&await this.discoverResourceFunctions()}async discoverFunctions(){let{result:e}=await this.sendRequest("tools/list");this.functions=e.tools.map(t=>{let n=this.options.functionOverrides?.find(s=>s.name===t.name),r=t.inputSchema.properties?{properties:t.inputSchema.properties,required:t.inputSchema.required??[],type:t.inputSchema.type}:void 0;return{name:n?.updates.name??t.name,description:n?.updates.description??t.description,parameters:r,func:async s=>{let{result:i}=await this.sendRequest("tools/call",{name:t.name,arguments:s});return i}}})}async discoverPromptFunctions(){let e;do{let t=await this.listPrompts(e);for(let n of t.prompts??[])this.promptFunctions.push(this.promptToFunction(n));e=t.nextCursor}while(e)}async discoverResourceFunctions(){let e;do{let t=await this.listResources(e);for(let n of t.resources??[])this.resourceFunctions.push(this.resourceToFunction(n));e=t.nextCursor}while(e);e=void 0;do{let t=await this.listResourceTemplates(e);for(let n of t.resourceTemplates??[])this.resourceFunctions.push(this.resourceTemplateToFunction(n));e=t.nextCursor}while(e)}promptToFunction(e){let t=`prompt_${e.name}`,n=this.options.functionOverrides?.find(s=>s.name===t),r=e.arguments?.length?{type:"object",properties:Object.fromEntries(e.arguments.map(s=>[s.name,{type:"string",description:s.description??""}])),required:e.arguments.filter(s=>s.required).map(s=>s.name)}:void 0;return{name:n?.updates.name??t,description:n?.updates.description??e.description??`Get the ${e.name} prompt`,parameters:r,func:async s=>{let i=await this.getPrompt(e.name,s);return this.formatPromptMessages(i.messages)}}}resourceToFunction(e){let t=`resource_${this.sanitizeName(e.name)}`,n=this.options.functionOverrides?.find(r=>r.name===t);return{name:n?.updates.name??t,description:n?.updates.description??e.description??`Read ${e.name}`,parameters:void 0,func:async()=>{let r=await this.readResource(e.uri);return this.formatResourceContents(r.contents)}}}resourceTemplateToFunction(e){let t=`resource_${this.sanitizeName(e.name)}`,n=this.options.functionOverrides?.find(s=>s.name===t),r=this.parseUriTemplate(e.uriTemplate);return{name:n?.updates.name??t,description:n?.updates.description??e.description??`Read ${e.name}`,parameters:r.length?{type:"object",properties:Object.fromEntries(r.map(s=>[s,{type:"string",description:`Value for ${s}`}])),required:r}:void 0,func:async s=>{let i=this.expandUriTemplate(e.uriTemplate,s??{}),a=await this.readResource(i);return this.formatResourceContents(a.contents)}}}formatPromptMessages(e){return e.map(t=>{let n=t.role==="user"?"User":"Assistant",r=this.extractContent(t.content);return`${n}: ${r}`}).join(`
1112
+ `),t?`${t}${e}`:e}var _l=()=>typeof Worker<"u"&&typeof Blob<"u"&&typeof URL<"u"&&typeof URL.createObjectURL=="function",_s=()=>typeof process<"u"&&!!process.versions?.node,ug=()=>!!globalThis.Deno?.version?.deno,cg=()=>globalThis.Deno?.version?.deno??null,lg=o=>{let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(o.trim());return e?{major:Number(e[1]),minor:Number(e[2]),patch:Number(e[3])}:null},Nl=o=>Number.isFinite(o)?Math.max(1,Math.min(Pl,Math.floor(o))):ya,pg=()=>{if(!_s())return null;let e=globalThis.process?.getBuiltinModule;if(typeof e!="function")return null;let n=e("node:os")?.availableParallelism;if(typeof n!="function")return null;let r=n();return Number.isFinite(r)&&r>0?r:null},dg=o=>{if(o!==void 0)return Nl(o);let e=pg();return e?Nl(Math.ceil(e/2)):ya},mg=o=>o?.debugNodeWorkerPool?!0:(globalThis.process?.env??{}).AX_RLM_DEBUG_NODE_POOL==="1",gg=o=>{let e=new Set(o),t={};return e.has("network")&&(t.net=!0),Object.keys(t).length>0?t:"none"},fg=(o,e)=>{let t=cg(),n=t?lg(t):null;if(n?n.major>=1:!0)try{return new Worker(o,{type:"module",deno:{permissions:gg(e)}})}catch{}return new Worker(o,{type:"module"})},Ll=(o,e)=>{let t=new Blob([o],{type:"application/javascript"}),n=URL.createObjectURL(t),r=ug()?fg(n,e):new Worker(n),s=!1,i=()=>{s||(URL.revokeObjectURL(n),s=!0)},a={postMessage:u=>r.postMessage(u),terminate:()=>{r.terminate(),i()},onmessage:null,onerror:null};return r.onmessage=u=>{a.onmessage?.({data:u.data})},r.onerror=u=>{a.onerror?.(new Error(u.message||"Worker error"))},a},Ra=async o=>{let e="node:worker_threads",{Worker:t}=await import(e),n=new t(o,{eval:!0}),r=null,s=null,i=!1;n.on("error",u=>{s?s(u):r=u}),n.on("exit",u=>{if(i=!0,u!==0&&!r){let c=new Error(`Worker exited with code ${u}`);s?s(c):r=c}}),n.on("message",u=>{a.onmessage?.({data:u})});let a={postMessage:u=>n.postMessage(u),terminate:()=>{n.terminate()},onmessage:null,get onerror(){return s},set onerror(u){if(s=u,u&&r){let c=r;r=null,u(c)}},get exited(){return i}};return a},va=class{source;maxSize;idle=[];pendingCreates=0;constructor(e,t){this.source=e,this.maxSize=t}warm(){if(_s())for(;this.idle.length+this.pendingCreates<this.maxSize;)this.pendingCreates+=1,Ra(this.source).then(e=>{e.onmessage=null,e.onerror=null,this.idle.push(e)}).catch(()=>{}).finally(()=>{this.pendingCreates-=1})}async acquire(){for(;this.idle.length>0;){let e=this.idle.pop();if(!e.exited)return this.warm(),e}return this.warm(),Ra(this.source)}release(e){e.onmessage=null,e.onerror=null,e.terminate(),this.warm()}},$l=new Map,hg=(o,e)=>`${e}:${o}`,xg=(o,e)=>{let t=hg(o,e),n=$l.get(t);if(n)return n;let r=new va(o,e);return $l.set(t,r),r},Dl=(o,e)=>{let t={},n=new Map,r=0,s=new WeakMap,i=(a,u)=>{if(typeof a=="function"){let g=`fn_${e?.nextFnId?e.nextFnId():++r}_${u||"root"}`;return n.set(g,a),{[ba]:g}}if(!a||typeof a!="object")return a;if(s.has(a))return s.get(a);if(Array.isArray(a)){let m=[];s.set(a,m);for(let g=0;g<a.length;g+=1)m[g]=i(a[g],`${u}[${g}]`);return m}let c=Object.getPrototypeOf(a);if(!(c===Object.prototype||c===null))return a;let p=a,d={};s.set(a,d);for(let[m,g]of Object.entries(p))d[m]=i(g,u?`${u}.${m}`:m);return d};if(o)for(let[a,u]of Object.entries(o))t[a]=i(u,a);return{serializableGlobals:t,fnMap:n}},Ul=o=>{if(typeof structuredClone=="function")try{structuredClone(o)}catch(e){let t=e instanceof Error?e.message:String(e);throw new Error(`RLM globals must be structured-cloneable: ${t}`)}},Ia=o=>!!o&&/[A-Za-z0-9_$]/.test(o),Ta=o=>!!o&&/[A-Za-z_$]/.test(o),Ag=(o,e)=>{let t=new Set(e);for(let m of Jr(o))if(t.has(m))return m;let n=$t(o),r=n.length,s=0,i=0,a=0,u=m=>{let g=m;for(;g<r&&/\s/.test(n[g]??"");)g++;return g},c=m=>{let g=m;for(;g>=0&&/\s/.test(n[g]??"");)g--;return g},l=m=>{let g=c(m-1);if(g<0)return!0;let f=n[g];return f===`
1113
+ `||f===";"||f==="{"||f==="}"},p=()=>{let m=s;for(;s<r&&Ia(n[s]);)s++;return n.slice(m,s)},d=m=>{let g=n.slice(m,m+2);return n.slice(m,m+3)==="==="||g==="=="||g==="=>"?!1:n[m]==="="||["+=","-=","*=","/=","%=","&=","|=","^=","&&=","||=","??=","**=","<<=",">>=",">>>="].some(x=>n.startsWith(x,m))};for(;s<r;){let m=n[s];if(m==="{"){i++,s++;continue}if(m==="}"){i--,s++;continue}if(m==="("){a++,s++;continue}if(m===")"){a--,s++;continue}if(i===0&&a===0&&Ta(m)){let g=s,f=p();if((f==="function"||f==="class")&&l(g)){let x=u(s);if(Ta(n[x])){let A=x+1;for(;A<r&&Ia(n[A]);)A++;let h=n.slice(x,A);if(t.has(h))return h}continue}if(f==="async"&&l(g)){let x=u(s);if(n.startsWith("function",x)){let A=u(x+8);if(Ta(n[A])){let h=A+1;for(;h<r&&Ia(n[h]);)h++;let y=n.slice(A,h);if(t.has(y))return y}}continue}if(t.has(f)){let x=c(g-1),A=x>=0?n[x]:void 0,h=u(s),y=A==="."||A==="?"||A==="["&&n[h]==="]",C=n.startsWith("++",h)||n.startsWith("--",h)||x>0&&(n.slice(x-1,x+1)==="++"||n.slice(x-1,x+1)==="--");if(!y&&(C||d(h)))return f}continue}s++}};function wa(o){if(o==null||typeof o!="object")return String(o);try{return JSON.stringify(o,null,2)}catch{return String(o)}}function Gl(o,e=Ca,t=0,n=new Set){if(t>e)return{name:"Error",message:"[cause chain truncated]"};if(o!==null&&typeof o=="object"){if(n.has(o))return{name:"Error",message:"[circular]"};n.add(o)}let r=o!==null&&typeof o=="object"&&o.name!=null?String(o.name):"Error",s=o!==null&&typeof o=="object"&&o.message!=null?String(o.message):wa(o),i=o!==null&&typeof o=="object"&&typeof o.stack=="string"?o.stack:void 0,a,u=o;if(u&&typeof u=="object"&&u.cause!==void 0&&t<e)try{let p=u.cause;p instanceof Error||p!==null&&typeof p=="object"&&("message"in p||"name"in p)?a=Gl(p,e,t+1,n):a={name:"Error",message:wa(p)}}catch{a={name:"Error",message:wa(u.cause)}}let c={name:r,message:s};i!==void 0&&(c.stack=i),a!==void 0&&(c.cause=a);let l=o;if(l&&typeof l=="object"&&"data"in l&&l.data!==void 0)try{typeof structuredClone=="function"?c.data=structuredClone(l.data):c.data=l.data}catch{}return c}function jl(o){if(typeof o=="string")return new Error(o);if(!o||typeof o!="object")return new Error(String(o));let e=o.message!=null?String(o.message):"Unknown error",t=new Error(e);return t.name=o.name!=null?String(o.name):"Error",typeof o.stack=="string"&&(t.stack=o.stack),o.cause!==void 0&&(t.cause=jl(o.cause)),o.data!==void 0&&(t.data=o.data),t}function yg(o){if(!o||typeof o!="object")return!1;let e=o;return typeof e.name=="string"&&typeof e.type=="string"&&(e.ctor===void 0||typeof e.ctor=="string")&&(e.size===void 0||typeof e.size=="string")&&(e.preview===void 0||typeof e.preview=="string")&&(e.restorable===void 0||typeof e.restorable=="boolean")}function bg(o){if(!o||typeof o!="object")return{version:1,entries:[],bindings:{}};let e=o,t=Array.isArray(e.entries)?e.entries:[],n=e.bindings&&typeof e.bindings=="object"?e.bindings:{};return{version:1,entries:t.filter(yg),bindings:n}}var Sa=(i=>(i.NETWORK="network",i.STORAGE="storage",i.CODE_LOADING="code-loading",i.COMMUNICATION="communication",i.TIMING="timing",i.WORKERS="workers",i))(Sa||{}),pn=class{language="JavaScript";timeout;permissions;allowUnsafeNodeHostAccess;nodeWorkerPoolSize;debugNodeWorkerPool;outputMode;captureConsole;constructor(e){this.timeout=e?.timeout??3e4,this.permissions=e?.permissions??[],this.allowUnsafeNodeHostAccess=e?.allowUnsafeNodeHostAccess??!1,this.outputMode=e?.outputMode??"stdout",this.captureConsole=e?.captureConsole??this.outputMode==="stdout",this.nodeWorkerPoolSize=dg(e?.nodeWorkerPoolSize),this.debugNodeWorkerPool=mg(e)}getUsageInstructions(){return["Don't wrap async code in (async()=>{ ... })() \u2014 the runtime automatically handles async execution.","State is session-scoped: all top-level declarations (`var`, `let`, `const`) persist across calls.","Bare assignment (e.g. `x = 1`) also persists via `globalThis`.",...this.outputMode==="stdout"?["Use `console.log(...)` output is captured as the execution result so use it to inspect intermediate values between steps instead of `return`."]:["Use `return` or a trailing expression to produce the execution result."]].map(t=>`- ${t}`).join(`
1114
+ `)}createSession(e){let t=Fl(),n=_s()?xg(t,this.nodeWorkerPoolSize):null;n&&this.debugNodeWorkerPool&&console.debug(`[AxJSRuntime] Node worker pool size: ${this.nodeWorkerPoolSize}`),n?.warm();let r=null,s=null,i=null,a=!1,u=this.timeout,c=0,{serializableGlobals:l,fnMap:p}=Dl(e,{nextFnId:()=>++c});Ul(l);let d=new Map,m=0,g=[],f=null,x=R=>{let E=R.data;if(!E||typeof E!="object"||!("type"in E)||E.type===void 0)return;let S=E;if(S.type==="result"){if(typeof S.id!="number")return;let _=d.get(S.id);_&&(d.delete(S.id),S.error!==void 0?_.reject(jl(S.error)):_.resolve(S.value));return}if(S.type==="fn-call"){if(typeof S.id!="number"||typeof S.name!="string")return;let _=p.get(S.name);if(!_){r?.postMessage({type:"fn-result",id:S.id,error:`Function "${S.name}" not found`});return}Promise.resolve().then(()=>_(...S.args??[])).then($=>{r?.postMessage({type:"fn-result",id:S.id,value:$})}).catch($=>{r?.postMessage({type:"fn-result",id:S.id,error:Gl($)})})}},A=()=>{r&&(s==="node"&&n?n.release(r):r.terminate(),r=null,s=null),i=null},h=()=>{a=!0,A();for(let R of g)!R.started&&!R.settled&&(R.settled=!0,R.signal&&R.onAbort&&R.signal.removeEventListener("abort",R.onAbort),R.reject(new Error("Worker terminated")));g.length=0;for(let R of d.values())R.reject(new Error("Worker terminated"));d.clear()},y=R=>{A();for(let E of d.values())E.reject(R);d.clear()},C=R=>{R.postMessage({type:"init",globals:l,fnNames:[...p.keys()],permissions:[...this.permissions],allowUnsafeNodeHostAccess:this.allowUnsafeNodeHostAccess,outputMode:this.outputMode,captureConsole:this.captureConsole})};if(_l()){r=Ll(t,this.permissions),s="browser",r.onmessage=x,r.onerror=y;try{C(r)}catch(R){throw h(),R}}let I=async()=>{if(!r){if(a)throw new Error("Session is closed");if(_l()){r=Ll(t,this.permissions),s="browser",r.onmessage=x,r.onerror=y;try{C(r)}catch(R){throw h(),R}return}if(!_s())throw new Error("No worker runtime available: Web Worker is unavailable in this environment");i||(i=(n?n.acquire():Ra(t)).then(R=>{if(a)throw n?n.release(R):R.terminate(),new Error("Session is closed");r=R,s="node",r.onmessage=x,r.onerror=y;try{C(r)}catch(E){throw n?n.release(R):R.terminate(),r=null,s=null,E}})),await i}},v=(R,E)=>{if(a)return Promise.reject(new Error("Session is closed"));let S=E.signal;if(S?.aborted)return Promise.reject(new Error(`Aborted: ${S.reason??"execution aborted"}`));let _=++m;return new Promise(($,M)=>{let F=$,N=M,G,W=()=>{};if(d.set(_,{resolve:U=>{G&&clearTimeout(G),W(),F(U)},reject:U=>{G&&clearTimeout(G),W(),N(U)}}),S){let U=()=>{clearTimeout(G),d.delete(_),h(),N(new Error(`Aborted: ${S.reason??"execution aborted"}`))};S.addEventListener("abort",U,{once:!0}),W=()=>{S.removeEventListener("abort",U)}}I().then(()=>{if(!r)throw new Error("Worker unavailable");G=setTimeout(()=>{d.delete(_),A();for(let U of d.values())U.reject(new Error("Worker terminated"));d.clear(),M(new Error(E.timeoutMessage))},u),r.postMessage({...R,id:_})}).catch(U=>{d.get(_)&&(d.delete(_),clearTimeout(G),W(),N(U))})})},O=(R,E)=>a?Promise.reject(new Error("Session is closed")):R?.aborted?Promise.reject(new Error(`Aborted: ${R.reason??"execution aborted"}`)):new Promise((S,_)=>{let $={started:!1,settled:!1,signal:R,resolve:S,reject:_,operation:E};if(R){let F=()=>{if($.settled)return;$.settled=!0;let N=g.indexOf($);N!==-1&&g.splice(N,1),R.removeEventListener("abort",F),_(new Error(`Aborted: ${R.reason??"execution aborted"}`))};$.onAbort=F,R.addEventListener("abort",F,{once:!0})}g.push($);let M=()=>{if(f)return;let F=g.find(G=>!G.started&&!G.settled);if(!F)return;let N=()=>{f=null,M()};f=(async()=>{if(!F.settled){if(a){F.settled=!0,F.signal&&F.onAbort&&F.signal.removeEventListener("abort",F.onAbort),F.reject(new Error("Worker terminated"));return}if(F.signal?.aborted){F.settled=!0,F.onAbort&&F.signal.removeEventListener("abort",F.onAbort),F.reject(new Error(`Aborted: ${F.signal.reason??"execution aborted"}`));return}F.started=!0;try{let G=await F.operation();if(F.settled)return;F.settled=!0,F.signal&&F.onAbort&&F.signal.removeEventListener("abort",F.onAbort),F.resolve(G)}catch(G){if(F.settled)return;F.settled=!0,F.signal&&F.onAbort&&F.signal.removeEventListener("abort",F.onAbort),F.reject(G)}finally{let G=g.indexOf(F);G!==-1&&g.splice(G,1),N()}}})().catch(()=>{N()})};M()});return{execute(R,E){if(a)return Promise.reject(new Error("Session is closed"));if(/['"]use strict['"]/.test(R))return Promise.resolve('[ERROR] "use strict" is not allowed in the runtime session. Remove it and try again.');let S=E?.reservedNames;if(S){let _=Ag(R,S);if(_)return Promise.resolve(`[ERROR] Cannot assign to, redeclare, or shadow reserved runtime variable '${_}'. Use a different local variable name (for example: \`ctx\`) or access the original via \`inputs.${_}\`.`)}return O(E?.signal,()=>v({type:"execute",code:R},{signal:E?.signal,timeoutMessage:"Execution timed out"}))},inspectGlobals(R){return a?Promise.reject(new Error("Session is closed")):O(R?.signal,()=>v({type:"inspect-globals",reservedNames:R?.reservedNames},{signal:R?.signal,timeoutMessage:"Global inspection timed out"}).then(E=>typeof E=="string"?E:E===void 0?"":JSON.stringify(E)))},snapshotGlobals(R){return a?Promise.reject(new Error("Session is closed")):O(R?.signal,()=>v({type:"snapshot-globals",reservedNames:R?.reservedNames},{signal:R?.signal,timeoutMessage:"Global snapshot timed out"}).then(bg))},async patchGlobals(R,E){if(!R||typeof R!="object"||Array.isArray(R))throw new Error("patchGlobals expects an object");let{serializableGlobals:S,fnMap:_}=Dl(R,{nextFnId:()=>++c});if(Ul(S),Object.keys(S).length!==0){await O(E?.signal,()=>v({type:"update-globals",globals:S},{signal:E?.signal,timeoutMessage:"Global patch timed out"}));for(let[$,M]of Object.entries(S))l[$]=M;for(let[$,M]of _.entries())p.set($,M)}},close(){h()}}}toFunction(){return{name:"javascriptInterpreter",description:"Execute JavaScript code in a persistent session and return output.",parameters:{type:"object",properties:{code:{type:"string",description:"JavaScript code to execute."}},required:["code"]},func:async({code:e},t)=>{let n=this.createSession();try{return await n.execute(e,{signal:t?.abortSignal})}finally{n.close()}}}}};function Bl(o){return new pn(o)}var Ns=class{constructor(e,t={}){this.transport=e;this.options=t;this.logger=t.logger??(n=>{console.log(typeof n=="string"?n:JSON.stringify(n,null,2))})}functions=[];promptFunctions=[];resourceFunctions=[];activeRequests=new Map;capabilities={};logger;async init(){"connect"in this.transport&&await this.transport.connect?.();let{result:e}=await this.sendRequest("initialize",{protocolVersion:"2024-11-05",capabilities:{roots:{listChanged:!0},sampling:{}},clientInfo:{name:"AxMCPClient",version:"1.0.0"}}),t="2024-11-05";if(e.protocolVersion!==t)throw new Error(`Protocol version mismatch. Expected ${t} but got ${e.protocolVersion}`);e.capabilities.tools&&(this.capabilities.tools=!0),e.capabilities.resources&&(this.capabilities.resources=!0),e.capabilities.prompts&&(this.capabilities.prompts=!0),await this.sendNotification("notifications/initialized"),this.capabilities.tools&&await this.discoverFunctions(),this.capabilities.prompts&&await this.discoverPromptFunctions(),this.capabilities.resources&&await this.discoverResourceFunctions()}async discoverFunctions(){let{result:e}=await this.sendRequest("tools/list");this.functions=e.tools.map(t=>{let n=this.options.functionOverrides?.find(s=>s.name===t.name),r=t.inputSchema.properties?{properties:t.inputSchema.properties,required:t.inputSchema.required??[],type:t.inputSchema.type}:void 0;return{name:n?.updates.name??t.name,description:n?.updates.description??t.description,parameters:r,func:async s=>{let{result:i}=await this.sendRequest("tools/call",{name:t.name,arguments:s});return i}}})}async discoverPromptFunctions(){let e;do{let t=await this.listPrompts(e);for(let n of t.prompts??[])this.promptFunctions.push(this.promptToFunction(n));e=t.nextCursor}while(e)}async discoverResourceFunctions(){let e;do{let t=await this.listResources(e);for(let n of t.resources??[])this.resourceFunctions.push(this.resourceToFunction(n));e=t.nextCursor}while(e);e=void 0;do{let t=await this.listResourceTemplates(e);for(let n of t.resourceTemplates??[])this.resourceFunctions.push(this.resourceTemplateToFunction(n));e=t.nextCursor}while(e)}promptToFunction(e){let t=`prompt_${e.name}`,n=this.options.functionOverrides?.find(s=>s.name===t),r=e.arguments?.length?{type:"object",properties:Object.fromEntries(e.arguments.map(s=>[s.name,{type:"string",description:s.description??""}])),required:e.arguments.filter(s=>s.required).map(s=>s.name)}:void 0;return{name:n?.updates.name??t,description:n?.updates.description??e.description??`Get the ${e.name} prompt`,parameters:r,func:async s=>{let i=await this.getPrompt(e.name,s);return this.formatPromptMessages(i.messages)}}}resourceToFunction(e){let t=`resource_${this.sanitizeName(e.name)}`,n=this.options.functionOverrides?.find(r=>r.name===t);return{name:n?.updates.name??t,description:n?.updates.description??e.description??`Read ${e.name}`,parameters:void 0,func:async()=>{let r=await this.readResource(e.uri);return this.formatResourceContents(r.contents)}}}resourceTemplateToFunction(e){let t=`resource_${this.sanitizeName(e.name)}`,n=this.options.functionOverrides?.find(s=>s.name===t),r=this.parseUriTemplate(e.uriTemplate);return{name:n?.updates.name??t,description:n?.updates.description??e.description??`Read ${e.name}`,parameters:r.length?{type:"object",properties:Object.fromEntries(r.map(s=>[s,{type:"string",description:`Value for ${s}`}])),required:r}:void 0,func:async s=>{let i=this.expandUriTemplate(e.uriTemplate,s??{}),a=await this.readResource(i);return this.formatResourceContents(a.contents)}}}formatPromptMessages(e){return e.map(t=>{let n=t.role==="user"?"User":"Assistant",r=this.extractContent(t.content);return`${n}: ${r}`}).join(`
1115
1115
 
1116
1116
  `)}extractContent(e){if(e.type==="text")return e.text;if(e.type==="image")return`[Image: ${e.mimeType}]`;if(e.type==="resource"){let t=e.resource;return"text"in t?t.text:`[Binary: ${t.uri}]`}return""}formatResourceContents(e){return e.map(t=>"text"in t?t.text:`[Binary: ${t.uri}]`).join(`
1117
- `)}sanitizeName(e){return e.replace(/[^a-zA-Z0-9_]/g,"_")}parseUriTemplate(e){return(e.match(/\{([^}]+)\}/g)??[]).map(n=>n.slice(1,-1))}expandUriTemplate(e,t){return e.replace(/\{([^}]+)\}/g,(n,r)=>t[r]??"")}async ping(e=3e3){let t=this.sendRequest("ping"),n=new Promise((i,a)=>setTimeout(()=>a(new Error("Ping response timeout exceeded")),e)),r=await Promise.race([t,n]),{result:s}=r;if(typeof s!="object"||s===null||Object.keys(s).length!==0)throw new Error(`Unexpected ping response: ${JSON.stringify(s)}`)}toFunction(){return[...this.functions,...this.promptFunctions,...this.resourceFunctions]}getCapabilities(){return{tools:this.capabilities.tools??!1,resources:this.capabilities.resources??!1,prompts:this.capabilities.prompts??!1}}hasToolsCapability(){return this.capabilities.tools??!1}hasPromptsCapability(){return this.capabilities.prompts??!1}hasResourcesCapability(){return this.capabilities.resources??!1}async listPrompts(e){if(!this.capabilities.prompts)throw new Error("Prompts are not supported");let t=e?{cursor:e}:void 0,{result:n}=await this.sendRequest("prompts/list",t);return n}async getPrompt(e,t){if(!this.capabilities.prompts)throw new Error("Prompts are not supported");let{result:n}=await this.sendRequest("prompts/get",{name:e,arguments:t});return n}async listResources(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");let t=e?{cursor:e}:void 0,{result:n}=await this.sendRequest("resources/list",t);return n}async listResourceTemplates(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");let t=e?{cursor:e}:void 0,{result:n}=await this.sendRequest("resources/templates/list",t);return n}async readResource(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");let{result:t}=await this.sendRequest("resources/read",{uri:e});return t}async subscribeResource(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");await this.sendRequest("resources/subscribe",{uri:e})}async unsubscribeResource(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");await this.sendRequest("resources/unsubscribe",{uri:e})}cancelRequest(e){if(this.activeRequests.has(e)){this.sendNotification("notifications/cancelled",{requestId:e,reason:"Client cancelled request"});let t=this.activeRequests.get(e);t&&t.reject(new Error(`Request ${e} cancelled`)),this.activeRequests.delete(e)}}async sendRequest(e,t={}){let n=Ze(),r={jsonrpc:"2.0",id:n,method:e,params:t},s=new Promise((a,l)=>{this.activeRequests.set(n,{reject:l}),this.transport.send(r).then(c=>{if(this.activeRequests.delete(n),c!==null&&typeof c=="object"&&"error"in c){let u=c;l(new Error(`RPC Error ${u.error.code}: ${u.error.message}`))}else c!==null&&typeof c=="object"&&"result"in c?a({result:c.result}):l(new Error("Invalid response no result or error"))}).catch(c=>{this.activeRequests.delete(n),l(c)})}),{result:i}=await s;return{id:n,result:i}}async sendNotification(e,t={}){let n={jsonrpc:"2.0",method:e,params:t},{debug:r}=this.options;if(r){let s={name:"Notification",id:"mcp_notification",value:`Sending notification: ${JSON.stringify(n,null,2)}`};this.logger(s)}await this.transport.sendNotification(n)}};function Mu(o){if(typeof Buffer<"u")return Buffer.from(o).toString("base64").replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"");let e="";for(let n=0;n<o.length;n++)e+=String.fromCharCode(o[n]);return(typeof btoa=="function"?btoa(e):"").replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}async function Pu(o){let t=new TextEncoder().encode(o),n=await ja().subtle.digest("SHA-256",t);return new Uint8Array(n)}async function Ca(){return Mu(await Pu(Ze()+Math.random().toString(36)))}async function Fu(o){return Mu(await Pu(o))}async function Ps(o,e){let t=await fetch(o,{headers:e});if(!t.ok)throw new Error(`HTTP ${t.status} fetching ${o}: ${t.statusText}`);return await t.json()}function _u(o){let e=new URLSearchParams;for(let[t,n]of Object.entries(o))n!==void 0&&e.set(t,n);return e.toString()}function Jr(o){return o.endsWith("/")?o.slice(0,-1):o}function Fm(o){if(!o)return null;let e=o.match(/resource_metadata\s*=\s*"([^"]+)"/i)||o.match(/resource_metadata\s*=\s*([^,\s]+)/i);return e?e[1]:null}async function Nu(o,e){let t=Fm(e);if(t){let a=await Ps(t),l=Jr(new URL(o).toString().split("?")[0]),c=Jr(a.resource??"");if(!c||c!==l)throw new Error(`Protected resource metadata 'resource' mismatch. Expected ${l} but got ${c}`);let u=Array.isArray(a.authorization_servers)?a.authorization_servers:[];if(u.length===0)throw new Error("No authorization_servers advertised by protected resource");return{resource:l,issuers:u}}let n=new URL(o),r=n.pathname.replace(/\/+$/,""),s=[];r&&r!=="/"&&s.push({url:`${n.origin}/.well-known/oauth-protected-resource${r}`,expected:`${n.origin}${r}`}),s.push({url:`${n.origin}/.well-known/oauth-protected-resource`,expected:`${n.origin}`});let i;for(let a of s)try{let l=await Ps(a.url),c=Jr(l.resource??""),u=Jr(a.expected);if(!c||c!==u)throw new Error(`Protected resource metadata 'resource' mismatch. Expected ${u} but got ${c}`);let p=Array.isArray(l.authorization_servers)?l.authorization_servers:[];if(p.length===0)throw new Error("No authorization_servers advertised by protected resource");return{resource:u,issuers:p}}catch(l){i=l}throw new Error(`Failed to resolve protected resource metadata via well-known endpoints. Last error: ${String(i)}`)}async function Lu(o){let e=new URL(o),t=e.pathname.replace(/^\/+/,""),n=[];t?(n.push(`${e.origin}/.well-known/oauth-authorization-server/${t}`),n.push(`${e.origin}/.well-known/openid-configuration/${t}`),n.push(`${e.origin}/${t.replace(/\/+$/,"")}/.well-known/openid-configuration`)):(n.push(`${e.origin}/.well-known/oauth-authorization-server`),n.push(`${e.origin}/.well-known/openid-configuration`));let r;for(let s of n)try{let i=await Ps(s);if(!i.authorization_endpoint||!i.token_endpoint)throw new Error("AS metadata missing endpoints");let a=i.code_challenge_methods_supported;if(!a||!a.includes("S256"))throw new Error("Authorization server does not advertise PKCE S256 support");return i}catch(i){r=i}throw new Error(`Failed to discover AS metadata for ${o}: ${String(r)}`)}var sr=class{constructor(e){this.oauth=e}tokenCache=new Map;asMetaCache=new Map;key(e,t){return`${e}::${t}`}async getStoredToken(e,t){let n=this.key(e,t);if(this.tokenCache.has(n))return this.tokenCache.get(n);let r=await this.oauth?.tokenStore?.getToken?.(n);return r&&this.tokenCache.set(n,r),r??null}async setStoredToken(e,t,n){let r=this.key(e,t);this.tokenCache.set(r,n),await this.oauth?.tokenStore?.setToken?.(r,n)}async clearStoredToken(e,t){let n=this.key(e,t);this.tokenCache.delete(n),await this.oauth?.tokenStore?.clearToken?.(n)}isExpired(e){return e?Date.now()>e-6e4:!1}async getASMeta(e){if(this.asMetaCache.has(e))return this.asMetaCache.get(e);let t=await Lu(e);return this.asMetaCache.set(e,t),t}async ensureAccessToken(e){if(!this.oauth)return null;let{resource:t,issuers:n}=await Nu(e.requestedUrl,e.wwwAuthenticate),r=this.oauth.selectAuthorizationServer?await this.oauth.selectAuthorizationServer(n,{}):n[0],s=await this.getASMeta(r),i=e.currentToken??await this.getStoredToken(t,r);if(i?.accessToken&&!this.isExpired(i.expiresAt))return{token:i,issuer:r,asMeta:s,resource:t};if(i?.refreshToken)try{let h=await this.refreshToken(i.refreshToken,t,r,s);return await this.setStoredToken(t,r,h),{token:h,issuer:r,asMeta:s,resource:t}}catch{await this.clearStoredToken(t,r)}let a=this.oauth.redirectUri??"http://localhost:8787/callback",l=this.oauth.clientId?{client_id:this.oauth.clientId,client_secret:this.oauth.clientSecret}:await this.dynamicClientRegistration(s,a),c=await Ca(),u=await Fu(c),p=await Ca(),d=this.oauth.scopes?.join(" "),m=`${s.authorization_endpoint}?${_u({response_type:"code",client_id:l.client_id,redirect_uri:a,scope:d,state:p,code_challenge:u,code_challenge_method:"S256",resource:t})}`;if(!this.oauth.onAuthCode)throw new Error(`Authorization required. Provide oauth.onAuthCode to complete the flow. Navigate to: ${m}`);let{code:g,redirectUri:f}=await this.oauth.onAuthCode(m),x=f??a,A=await this.exchangeCodeForToken({asMeta:s,code:g,codeVerifier:c,client:l,redirectUri:x,resource:t});return await this.setStoredToken(t,r,A),{token:A,issuer:r,asMeta:s,resource:t}}async dynamicClientRegistration(e,t){if(!e.registration_endpoint)throw new Error("Authorization server does not support dynamic client registration and no clientId was provided.");let r={application_type:t.startsWith("http://localhost")?"native":"web",client_name:"Ax MCP Client",redirect_uris:[t],grant_types:["authorization_code","refresh_token"],response_types:["code"],token_endpoint_auth_method:"none"},s=await fetch(e.registration_endpoint,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)});if(!s.ok)throw new Error(`Dynamic client registration failed: ${s.status} ${s.statusText}`);let i=await s.json();if(!i.client_id)throw new Error("Dynamic client registration did not return client_id");return i}async exchangeCodeForToken(e){let t=new URLSearchParams;t.set("grant_type","authorization_code"),t.set("code",e.code),t.set("redirect_uri",e.redirectUri),t.set("client_id",e.client.client_id),t.set("code_verifier",e.codeVerifier),t.set("resource",e.resource),e.client.client_secret&&t.set("client_secret",e.client.client_secret);let n=await fetch(e.asMeta.token_endpoint,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:t.toString()});if(!n.ok)throw new Error(`Token exchange failed: ${n.status} ${n.statusText}`);let r=await n.json();if(!r.access_token)throw new Error("No access_token in token response");let s=r.expires_in?Date.now()+r.expires_in*1e3:void 0;return{accessToken:r.access_token,refreshToken:r.refresh_token,expiresAt:s}}async refreshToken(e,t,n,r){let s=new URLSearchParams;s.set("grant_type","refresh_token"),s.set("refresh_token",e),s.set("resource",t),this.oauth?.clientId&&s.set("client_id",this.oauth.clientId),this.oauth?.clientSecret&&s.set("client_secret",this.oauth.clientSecret);let i=await fetch(r.token_endpoint,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:s.toString()});if(!i.ok)throw new Error(`Token refresh failed: ${i.status} ${i.statusText}`);let a=await i.json();if(!a.access_token)throw new Error("No access_token in refresh response");let l=a.expires_in?Date.now()+a.expires_in*1e3:void 0;return{accessToken:a.access_token,refreshToken:a.refresh_token??e,expiresAt:l}}};var Fs=class{mcpEndpoint;sessionId;eventSource;pendingRequests=new Map;messageHandler;customHeaders;oauthHelper;currentToken;currentIssuer;constructor(e,t){this.mcpEndpoint=e,this.customHeaders={...t?.headers??{}},t?.authorization&&(this.customHeaders.Authorization=t.authorization),this.oauthHelper=new sr(t?.oauth)}setHeaders(e){this.customHeaders={...e}}setAuthorization(e){this.customHeaders.Authorization=e}getHeaders(){return{...this.customHeaders}}buildHeaders(e){let t={...this.customHeaders,...e};return this.sessionId&&(t["Mcp-Session-Id"]=this.sessionId),t}setMessageHandler(e){this.messageHandler=e}async connect(){return Promise.resolve()}async openListeningStream(){return new Promise((e,t)=>{let n=this.buildHeaders({Accept:"text/event-stream"}),r=new URL(this.mcpEndpoint);if(Object.keys(this.customHeaders).length>0){this.openListeningStreamWithFetch(n).then(e).catch(t);return}this.eventSource=new EventSource(r.toString()),this.eventSource.onopen=()=>e(),this.eventSource.onmessage=s=>{try{let i=JSON.parse(s.data);this.messageHandler&&this.messageHandler(i)}catch(i){console.error("Failed to parse SSE message:",i)}},this.eventSource.onerror=()=>t(new Error("Failed to establish SSE connection"))})}async openListeningStreamWithFetch(e){let t=await fetch(this.mcpEndpoint,{method:"GET",headers:e});if(t.status===401){let a=t.headers.get("WWW-Authenticate"),l=await this.oauthHelper.ensureAccessToken({requestedUrl:this.mcpEndpoint,wwwAuthenticate:a,currentToken:null});if(!l)throw new Error("HTTP 401: Unauthorized");return this.customHeaders.Authorization=`Bearer ${l.token.accessToken}`,this.openListeningStreamWithFetch(this.buildHeaders({Accept:"text/event-stream"}))}if(!t.ok)throw new Error(`Failed to open SSE stream: ${t.status} ${t.statusText}`);if(!t.body)throw new Error("No response body available for SSE stream");let n=t.body.getReader(),r=new TextDecoder,s="",i=async()=>{try{let{done:a,value:l}=await n.read();if(a){n.releaseLock();return}s+=r.decode(l,{stream:!0});let c=s.split(`
1118
- `);s=c.pop()||"";for(let u of c)if(u.startsWith("data: ")){let p=u.slice(6);if(p==="[DONE]")return;try{let d=JSON.parse(p);this.messageHandler&&this.messageHandler(d)}catch(d){console.error("Failed to parse SSE data:",d)}}await i()}catch(a){throw n.releaseLock(),a}};await i()}async send(e){let t=this.buildHeaders({"Content-Type":"application/json",Accept:"application/json, text/event-stream"}),n=JSON.stringify(e),r=await fetch(this.mcpEndpoint,{method:"POST",headers:t,body:n});if(r.status===401){let a=r.headers.get("WWW-Authenticate"),l=await this.oauthHelper.ensureAccessToken({requestedUrl:this.mcpEndpoint,wwwAuthenticate:a,currentToken:null});if(!l)throw new Error("HTTP 401: Unauthorized");this.customHeaders.Authorization=`Bearer ${l.token.accessToken}`,r=await fetch(this.mcpEndpoint,{method:"POST",headers:this.buildHeaders({"Content-Type":"application/json",Accept:"application/json, text/event-stream"}),body:n})}if(!r.ok)throw r.status===404&&this.sessionId?(this.sessionId=void 0,new Error("Session expired. Please reinitialize.")):new Error(`HTTP error ${r.status}: ${r.statusText}`);let s=r.headers.get("Mcp-Session-Id");s&&(this.sessionId=s);let i=r.headers.get("Content-Type");if(i?.includes("text/event-stream"))return this.handleSSEResponse(r,e.id);if(i?.includes("application/json"))return r.json();throw new Error(`Unexpected content type: ${i}`)}async handleSSEResponse(e,t){return new Promise((n,r)=>{let s=e.body?.getReader();if(!s){r(new Error("No response body reader available"));return}let i=new TextDecoder,a="",l=async()=>{try{let{done:c,value:u}=await s.read();if(c){s.releaseLock();return}a+=i.decode(u,{stream:!0});let p=a.split(`
1119
- `);a=p.pop()||"";for(let d of p)if(d.startsWith("data: ")){let m=d.slice(6);if(m==="[DONE]")return;try{let g=JSON.parse(m);if("id"in g&&g.id===t){n(g);return}this.messageHandler&&this.messageHandler(g)}catch(g){console.error("Failed to parse SSE data:",g)}}await l()}catch(c){s.releaseLock(),r(c)}};l().catch(r)})}async sendNotification(e){let t=this.buildHeaders({"Content-Type":"application/json",Accept:"application/json, text/event-stream"}),n=JSON.stringify(e),r=await fetch(this.mcpEndpoint,{method:"POST",headers:t,body:n});if(r.status===401){let s=r.headers.get("WWW-Authenticate"),i=await this.oauthHelper.ensureAccessToken({requestedUrl:this.mcpEndpoint,wwwAuthenticate:s,currentToken:null});if(!i)throw new Error("HTTP 401: Unauthorized");this.customHeaders.Authorization=`Bearer ${i.token.accessToken}`,r=await fetch(this.mcpEndpoint,{method:"POST",headers:this.buildHeaders({"Content-Type":"application/json",Accept:"application/json, text/event-stream"}),body:n})}if(!r.ok)throw r.status===404&&this.sessionId?(this.sessionId=void 0,new Error("Session expired. Please reinitialize.")):new Error(`HTTP error ${r.status}: ${r.statusText}`);r.status!==202&&console.warn(`Unexpected status for notification: ${r.status}`)}async terminateSession(){if(this.sessionId)try{let e=this.buildHeaders({});(await fetch(this.mcpEndpoint,{method:"DELETE",headers:e})).status===405&&console.info("Server does not support explicit session termination")}catch(e){console.error("Failed to terminate session:",e)}finally{this.sessionId=void 0}}close(){this.eventSource&&(this.eventSource.close(),this.eventSource=void 0)}};var _s=class{endpoint=null;sseUrl;eventSource;customHeaders={};oauthHelper;currentToken;currentIssuer;sseAbort;pendingRequests=new Map;messageHandler;endpointReady;constructor(e,t){this.sseUrl=e,this.customHeaders={...t?.headers??{}},t?.authorization&&(this.customHeaders.Authorization=t.authorization),this.oauthHelper=new sr(t?.oauth)}buildHeaders(e){return{...this.customHeaders,...e}}async openSSEWithFetch(e){let t=new AbortController;this.sseAbort=t;let n=await fetch(this.sseUrl,{method:"GET",headers:e,signal:t.signal});if(n.status===401){let s=n.headers.get("WWW-Authenticate"),i=await this.oauthHelper.ensureAccessToken({requestedUrl:this.sseUrl,wwwAuthenticate:s,currentToken:null});if(!i)throw new Error("HTTP 401: Unauthorized");return this.customHeaders.Authorization=`Bearer ${i.token.accessToken}`,this.openSSEWithFetch(this.buildHeaders({Accept:"text/event-stream"}))}if(!n.ok)throw new Error("Failed to establish SSE connection");let r=this.createEndpointReady();this.consumeSSEStream(n),await r}createEndpointReady(){if(!this.endpointReady){let e,t=new Promise(n=>{e=n});this.endpointReady={resolve:e,promise:t}}return this.endpointReady.promise}async consumeSSEStream(e){if(!e.body)throw new Error("No response body available for SSE stream");let t=e.body.getReader(),n=new TextDecoder,r="",s=null;for(;;){let{done:i,value:a}=await t.read();if(i)break;r+=n.decode(a,{stream:!0});let l=r.split(`
1120
- `);r=l.pop()||"";for(let c of l)if(c.startsWith("event: "))s=c.slice(7).trim();else if(c.startsWith("data: ")){let u=c.slice(6);if(s==="endpoint"){let p=u.trim(),d;try{let m=JSON.parse(p);typeof m=="string"?d=m:m&&typeof m=="object"&&"uri"in m&&(d=m.uri)}catch{d=p}if(!d)throw new Error("Endpoint URI missing in SSE event data");/^https?:\/\//i.test(d)||(d=new URL(this.sseUrl).origin+(d.startsWith("/")?d:`/${d}`)),this.endpoint=d,this.endpointReady&&(this.endpointReady.resolve(),this.endpointReady=void 0)}else{let p=u.trim();try{let d=JSON.parse(p);if(d&&typeof d=="object"&&"id"in d){let m=d.id,g=this.pendingRequests.get(m);g?(g.resolve(d),this.pendingRequests.delete(m)):this.messageHandler&&this.messageHandler(d)}else this.messageHandler&&this.messageHandler(d)}catch{}}}else c.trim()===""&&(s=null)}}async connect(){let e=this.buildHeaders({Accept:"text/event-stream"});await this.openSSEWithFetch(e)}async send(e){if(!this.endpoint)throw new Error("HTTPTransport endpoint is not initialized. Call connect() first.");let t=this.buildHeaders({"Content-Type":"application/json"}),n=JSON.stringify(e),r=new Promise((a,l)=>{this.pendingRequests.set(e.id,{resolve:a,reject:l})}),s=await fetch(this.endpoint,{method:"POST",headers:t,body:n});if(s.status===401){let a=s.headers.get("WWW-Authenticate"),l=await this.oauthHelper.ensureAccessToken({requestedUrl:this.sseUrl,wwwAuthenticate:a,currentToken:null});if(!l)throw new Error("HTTP 401: Unauthorized");this.customHeaders.Authorization=`Bearer ${l.token.accessToken}`,s=await fetch(this.endpoint,{method:"POST",headers:this.buildHeaders({"Content-Type":"application/json"}),body:n})}if(!s.ok)throw this.pendingRequests.delete(e.id),new Error(`HTTP error ${s.status}: ${s.statusText}`);if(s.headers.get("Content-Type")?.includes("application/json")){let a=await s.json();return this.pendingRequests.delete(e.id),a}return r}async sendNotification(e){if(!this.endpoint)throw new Error("HTTPTransport endpoint is not initialized. Call connect() first.");let t=this.buildHeaders({"Content-Type":"application/json"}),n=JSON.stringify(e),r=await fetch(this.endpoint,{method:"POST",headers:t,body:n});if(r.status===401){let s=r.headers.get("WWW-Authenticate"),i=await this.oauthHelper.ensureAccessToken({requestedUrl:this.sseUrl,wwwAuthenticate:s,currentToken:null});if(!i)throw new Error("HTTP 401: Unauthorized");this.customHeaders.Authorization=`Bearer ${i.token.accessToken}`,r=await fetch(this.endpoint,{method:"POST",headers:this.buildHeaders({"Content-Type":"application/json"}),body:n})}if(!r.ok)throw new Error(`HTTP error ${r.status}: ${r.statusText}`);r.status!==202&&console.warn(`Unexpected status for notification: ${r.status}`)}close(){this.eventSource&&(this.eventSource.close(),this.eventSource=void 0),this.sseAbort&&(this.sseAbort.abort(),this.sseAbort=void 0)}};function Ia(o){return o.match(/^(\w+Error:\s*.{0,60})/m)?.[1]??o.slice(0,80)}function Du(o){return Vr(o)}function _m(o){return yu(o)}var Nm=new Set(["var","let","const","function","return","if","else","for","while","do","switch","case","break","continue","try","catch","finally","throw","new","delete","typeof","void","in","of","instanceof","this","class","extends","super","import","export","default","from","as","async","await","yield","true","false","null","undefined","console","log"]);function Uu(o){let e=Ft(o),t=/\b([a-zA-Z_$][a-zA-Z0-9_$]*)\b/g,n=new Set,r=t.exec(e);for(;r!==null;)r[1]&&!Nm.has(r[1])&&n.add(r[1]),r=t.exec(e);return n}function Gu(o){let e=Uu(o);for(let t of Du(o))e.delete(t);return e}var Lm=new Set(["dead-end","foundational","pivot","superseded"]);function _t(o,e=120){let t=o.replace(/\s+/g," ").trim();return t.length<=e?t:`${t.slice(0,e-3)}...`}function $m(o){return/\b(final|ask_clarification)\s*\(/.test(o)}function Dm(o){return o.tags.includes("error")?"error":$m(o.code)?"finalize":/\b(llmQuery|listModuleFunctions|getFunctionDefinitions)\s*\(/.test(o.code)?"query":(o.producedVars?.length??0)>0?"transform":"explore"}function Um(o){let e=o.producedVars??[];if(e.length>0)return`Updated live runtime values: ${e.join(", ")}`;switch(o.stepKind){case"query":return"Gathered external or semantic evidence without creating durable runtime values";case"finalize":return"Prepared completion payload for the responder";case"error":return"Did not produce a durable runtime state update";default:return"Inspected runtime state without creating durable runtime values"}}function Ra(o){if(o.tombstone)return o.tombstone;let e=o.stepKind==="error"?"Error step":o.stepKind==="query"?"Query step":o.stepKind==="transform"?"Transform step":o.stepKind==="finalize"?"Finalize step":"Explore step",t=_t(o.output||"(no output)"),n=_t(o.actorFieldsOutput.replace(/^Actor fields:\s*/i,""),80),r=o.stateDelta??"No durable runtime state update",s=n?` Actor fields: ${n}.`:"";return`[SUMMARY]: ${e}. ${r}. Result: ${t}.${s}`}function Gm(o){o.rank=void 0,o.tags=o.tags.filter(e=>!Lm.has(e))}function Dt(o){o.producedVars||(o.producedVars=_m(o.code)),o.referencedVars||(o.referencedVars=[...Uu(o.code)]),o.stepKind||(o.stepKind=Dm(o)),o.stateDelta||(o.stateDelta=Um(o)),o.summary||(o.summary=Ra(o))}function Bu(o,e){let t=[...o.matchAll(e)];return t.length===0?[]:t.map((n,r)=>{let s=n[1]?.trim(),i=n.index??0,a=t[r+1]?.index??o.length;if(s)return{key:s,text:o.slice(i,a).trim()}}).filter(n=>!!n)}function Bm(o){return/\blistModuleFunctions\s*\(/.test(o.code)?Bu(o.output,/^### Module `([^`]+)`/gm).map(e=>({module:e.key,text:e.text})):[]}function jm(o){return/\bgetFunctionDefinitions\s*\(/.test(o.code)?Bu(o.output,/^### `([^`]+)`/gm).map(e=>({qualifiedName:e.key,text:e.text})):[]}function zm(o){let e=Ft(o),t=new Set,n=/\b([a-zA-Z_$][a-zA-Z0-9_$]*)\.([a-zA-Z_$][a-zA-Z0-9_$]*)\s*\(/g,r=n.exec(e);for(;r;){let s=r[1],i=r[2];s&&i&&t.add(`${s}.${i}`),r=n.exec(e)}return[...t]}function Yr(o){o._discoveryModuleSections||(o._discoveryModuleSections=Bm(o)),o._discoveryFunctionSections||(o._discoveryFunctionSections=jm(o)),o._directQualifiedCalls||(o._directQualifiedCalls=zm(o.code))}function qm(o){return Yr(o),o._directQualifiedCalls?.find(Boolean)}function Ns(o){let e=new Map;for(let t of o){let n=t;Dt(n);let r=qm(n);for(let i of n.producedVars??[])e.set(i,{createdTurn:n.turn,stepKind:n.stepKind,source:r,code:n.code});let s=Gu(n.code);for(let i of s){let a=e.get(i);a&&(a.lastReadTurn=Math.max(a.lastReadTurn??a.createdTurn,n.turn))}}return e}function Hm(o){let e=Array.from({length:o.length},()=>new Set),t=new Set;for(let n=o.length-1;n>=0;n--){e[n]=new Set(t);let r=o[n];if(!(!r||r.tags.includes("error"))){Yr(r);for(let s of r._directQualifiedCalls??[])t.add(s)}}return e}function Km(o,e){let t=o;Yr(t);let n=t._discoveryFunctionSections??[];if(n.length>0){let s=n.filter(i=>!e.has(i.qualifiedName));return s.length===n.length?t:s.length===0?void 0:{...t,output:s.map(i=>i.text).join(`
1117
+ `)}sanitizeName(e){return e.replace(/[^a-zA-Z0-9_]/g,"_")}parseUriTemplate(e){return(e.match(/\{([^}]+)\}/g)??[]).map(n=>n.slice(1,-1))}expandUriTemplate(e,t){return e.replace(/\{([^}]+)\}/g,(n,r)=>t[r]??"")}async ping(e=3e3){let t=this.sendRequest("ping"),n=new Promise((i,a)=>setTimeout(()=>a(new Error("Ping response timeout exceeded")),e)),r=await Promise.race([t,n]),{result:s}=r;if(typeof s!="object"||s===null||Object.keys(s).length!==0)throw new Error(`Unexpected ping response: ${JSON.stringify(s)}`)}toFunction(){return[...this.functions,...this.promptFunctions,...this.resourceFunctions]}getCapabilities(){return{tools:this.capabilities.tools??!1,resources:this.capabilities.resources??!1,prompts:this.capabilities.prompts??!1}}hasToolsCapability(){return this.capabilities.tools??!1}hasPromptsCapability(){return this.capabilities.prompts??!1}hasResourcesCapability(){return this.capabilities.resources??!1}async listPrompts(e){if(!this.capabilities.prompts)throw new Error("Prompts are not supported");let t=e?{cursor:e}:void 0,{result:n}=await this.sendRequest("prompts/list",t);return n}async getPrompt(e,t){if(!this.capabilities.prompts)throw new Error("Prompts are not supported");let{result:n}=await this.sendRequest("prompts/get",{name:e,arguments:t});return n}async listResources(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");let t=e?{cursor:e}:void 0,{result:n}=await this.sendRequest("resources/list",t);return n}async listResourceTemplates(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");let t=e?{cursor:e}:void 0,{result:n}=await this.sendRequest("resources/templates/list",t);return n}async readResource(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");let{result:t}=await this.sendRequest("resources/read",{uri:e});return t}async subscribeResource(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");await this.sendRequest("resources/subscribe",{uri:e})}async unsubscribeResource(e){if(!this.capabilities.resources)throw new Error("Resources are not supported");await this.sendRequest("resources/unsubscribe",{uri:e})}cancelRequest(e){if(this.activeRequests.has(e)){this.sendNotification("notifications/cancelled",{requestId:e,reason:"Client cancelled request"});let t=this.activeRequests.get(e);t&&t.reject(new Error(`Request ${e} cancelled`)),this.activeRequests.delete(e)}}async sendRequest(e,t={}){let n=Ze(),r={jsonrpc:"2.0",id:n,method:e,params:t},s=new Promise((a,u)=>{this.activeRequests.set(n,{reject:u}),this.transport.send(r).then(c=>{if(this.activeRequests.delete(n),c!==null&&typeof c=="object"&&"error"in c){let l=c;u(new Error(`RPC Error ${l.error.code}: ${l.error.message}`))}else c!==null&&typeof c=="object"&&"result"in c?a({result:c.result}):u(new Error("Invalid response no result or error"))}).catch(c=>{this.activeRequests.delete(n),u(c)})}),{result:i}=await s;return{id:n,result:i}}async sendNotification(e,t={}){let n={jsonrpc:"2.0",method:e,params:t},{debug:r}=this.options;if(r){let s={name:"Notification",id:"mcp_notification",value:`Sending notification: ${JSON.stringify(n,null,2)}`};this.logger(s)}await this.transport.sendNotification(n)}};function zl(o){if(typeof Buffer<"u")return Buffer.from(o).toString("base64").replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"");let e="";for(let n=0;n<o.length;n++)e+=String.fromCharCode(o[n]);return(typeof btoa=="function"?btoa(e):"").replace(/\+/g,"-").replace(/\//g,"_").replace(/=+$/g,"")}async function ql(o){let t=new TextEncoder().encode(o),n=await nu().subtle.digest("SHA-256",t);return new Uint8Array(n)}async function ka(){return zl(await ql(Ze()+Math.random().toString(36)))}async function Hl(o){return zl(await ql(o))}async function Ls(o,e){let t=await fetch(o,{headers:e});if(!t.ok)throw new Error(`HTTP ${t.status} fetching ${o}: ${t.statusText}`);return await t.json()}function Kl(o){let e=new URLSearchParams;for(let[t,n]of Object.entries(o))n!==void 0&&e.set(t,n);return e.toString()}function Qr(o){return o.endsWith("/")?o.slice(0,-1):o}function Cg(o){if(!o)return null;let e=o.match(/resource_metadata\s*=\s*"([^"]+)"/i)||o.match(/resource_metadata\s*=\s*([^,\s]+)/i);return e?e[1]:null}async function Wl(o,e){let t=Cg(e);if(t){let a=await Ls(t),u=Qr(new URL(o).toString().split("?")[0]),c=Qr(a.resource??"");if(!c||c!==u)throw new Error(`Protected resource metadata 'resource' mismatch. Expected ${u} but got ${c}`);let l=Array.isArray(a.authorization_servers)?a.authorization_servers:[];if(l.length===0)throw new Error("No authorization_servers advertised by protected resource");return{resource:u,issuers:l}}let n=new URL(o),r=n.pathname.replace(/\/+$/,""),s=[];r&&r!=="/"&&s.push({url:`${n.origin}/.well-known/oauth-protected-resource${r}`,expected:`${n.origin}${r}`}),s.push({url:`${n.origin}/.well-known/oauth-protected-resource`,expected:`${n.origin}`});let i;for(let a of s)try{let u=await Ls(a.url),c=Qr(u.resource??""),l=Qr(a.expected);if(!c||c!==l)throw new Error(`Protected resource metadata 'resource' mismatch. Expected ${l} but got ${c}`);let p=Array.isArray(u.authorization_servers)?u.authorization_servers:[];if(p.length===0)throw new Error("No authorization_servers advertised by protected resource");return{resource:l,issuers:p}}catch(u){i=u}throw new Error(`Failed to resolve protected resource metadata via well-known endpoints. Last error: ${String(i)}`)}async function Vl(o){let e=new URL(o),t=e.pathname.replace(/^\/+/,""),n=[];t?(n.push(`${e.origin}/.well-known/oauth-authorization-server/${t}`),n.push(`${e.origin}/.well-known/openid-configuration/${t}`),n.push(`${e.origin}/${t.replace(/\/+$/,"")}/.well-known/openid-configuration`)):(n.push(`${e.origin}/.well-known/oauth-authorization-server`),n.push(`${e.origin}/.well-known/openid-configuration`));let r;for(let s of n)try{let i=await Ls(s);if(!i.authorization_endpoint||!i.token_endpoint)throw new Error("AS metadata missing endpoints");let a=i.code_challenge_methods_supported;if(!a||!a.includes("S256"))throw new Error("Authorization server does not advertise PKCE S256 support");return i}catch(i){r=i}throw new Error(`Failed to discover AS metadata for ${o}: ${String(r)}`)}var ur=class{constructor(e){this.oauth=e}tokenCache=new Map;asMetaCache=new Map;key(e,t){return`${e}::${t}`}async getStoredToken(e,t){let n=this.key(e,t);if(this.tokenCache.has(n))return this.tokenCache.get(n);let r=await this.oauth?.tokenStore?.getToken?.(n);return r&&this.tokenCache.set(n,r),r??null}async setStoredToken(e,t,n){let r=this.key(e,t);this.tokenCache.set(r,n),await this.oauth?.tokenStore?.setToken?.(r,n)}async clearStoredToken(e,t){let n=this.key(e,t);this.tokenCache.delete(n),await this.oauth?.tokenStore?.clearToken?.(n)}isExpired(e){return e?Date.now()>e-6e4:!1}async getASMeta(e){if(this.asMetaCache.has(e))return this.asMetaCache.get(e);let t=await Vl(e);return this.asMetaCache.set(e,t),t}async ensureAccessToken(e){if(!this.oauth)return null;let{resource:t,issuers:n}=await Wl(e.requestedUrl,e.wwwAuthenticate),r=this.oauth.selectAuthorizationServer?await this.oauth.selectAuthorizationServer(n,{}):n[0],s=await this.getASMeta(r),i=e.currentToken??await this.getStoredToken(t,r);if(i?.accessToken&&!this.isExpired(i.expiresAt))return{token:i,issuer:r,asMeta:s,resource:t};if(i?.refreshToken)try{let h=await this.refreshToken(i.refreshToken,t,r,s);return await this.setStoredToken(t,r,h),{token:h,issuer:r,asMeta:s,resource:t}}catch{await this.clearStoredToken(t,r)}let a=this.oauth.redirectUri??"http://localhost:8787/callback",u=this.oauth.clientId?{client_id:this.oauth.clientId,client_secret:this.oauth.clientSecret}:await this.dynamicClientRegistration(s,a),c=await ka(),l=await Hl(c),p=await ka(),d=this.oauth.scopes?.join(" "),m=`${s.authorization_endpoint}?${Kl({response_type:"code",client_id:u.client_id,redirect_uri:a,scope:d,state:p,code_challenge:l,code_challenge_method:"S256",resource:t})}`;if(!this.oauth.onAuthCode)throw new Error(`Authorization required. Provide oauth.onAuthCode to complete the flow. Navigate to: ${m}`);let{code:g,redirectUri:f}=await this.oauth.onAuthCode(m),x=f??a,A=await this.exchangeCodeForToken({asMeta:s,code:g,codeVerifier:c,client:u,redirectUri:x,resource:t});return await this.setStoredToken(t,r,A),{token:A,issuer:r,asMeta:s,resource:t}}async dynamicClientRegistration(e,t){if(!e.registration_endpoint)throw new Error("Authorization server does not support dynamic client registration and no clientId was provided.");let r={application_type:t.startsWith("http://localhost")?"native":"web",client_name:"Ax MCP Client",redirect_uris:[t],grant_types:["authorization_code","refresh_token"],response_types:["code"],token_endpoint_auth_method:"none"},s=await fetch(e.registration_endpoint,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)});if(!s.ok)throw new Error(`Dynamic client registration failed: ${s.status} ${s.statusText}`);let i=await s.json();if(!i.client_id)throw new Error("Dynamic client registration did not return client_id");return i}async exchangeCodeForToken(e){let t=new URLSearchParams;t.set("grant_type","authorization_code"),t.set("code",e.code),t.set("redirect_uri",e.redirectUri),t.set("client_id",e.client.client_id),t.set("code_verifier",e.codeVerifier),t.set("resource",e.resource),e.client.client_secret&&t.set("client_secret",e.client.client_secret);let n=await fetch(e.asMeta.token_endpoint,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:t.toString()});if(!n.ok)throw new Error(`Token exchange failed: ${n.status} ${n.statusText}`);let r=await n.json();if(!r.access_token)throw new Error("No access_token in token response");let s=r.expires_in?Date.now()+r.expires_in*1e3:void 0;return{accessToken:r.access_token,refreshToken:r.refresh_token,expiresAt:s}}async refreshToken(e,t,n,r){let s=new URLSearchParams;s.set("grant_type","refresh_token"),s.set("refresh_token",e),s.set("resource",t),this.oauth?.clientId&&s.set("client_id",this.oauth.clientId),this.oauth?.clientSecret&&s.set("client_secret",this.oauth.clientSecret);let i=await fetch(r.token_endpoint,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:s.toString()});if(!i.ok)throw new Error(`Token refresh failed: ${i.status} ${i.statusText}`);let a=await i.json();if(!a.access_token)throw new Error("No access_token in refresh response");let u=a.expires_in?Date.now()+a.expires_in*1e3:void 0;return{accessToken:a.access_token,refreshToken:a.refresh_token??e,expiresAt:u}}};var $s=class{mcpEndpoint;sessionId;eventSource;pendingRequests=new Map;messageHandler;customHeaders;oauthHelper;currentToken;currentIssuer;constructor(e,t){this.mcpEndpoint=e,this.customHeaders={...t?.headers??{}},t?.authorization&&(this.customHeaders.Authorization=t.authorization),this.oauthHelper=new ur(t?.oauth)}setHeaders(e){this.customHeaders={...e}}setAuthorization(e){this.customHeaders.Authorization=e}getHeaders(){return{...this.customHeaders}}buildHeaders(e){let t={...this.customHeaders,...e};return this.sessionId&&(t["Mcp-Session-Id"]=this.sessionId),t}setMessageHandler(e){this.messageHandler=e}async connect(){return Promise.resolve()}async openListeningStream(){return new Promise((e,t)=>{let n=this.buildHeaders({Accept:"text/event-stream"}),r=new URL(this.mcpEndpoint);if(Object.keys(this.customHeaders).length>0){this.openListeningStreamWithFetch(n).then(e).catch(t);return}this.eventSource=new EventSource(r.toString()),this.eventSource.onopen=()=>e(),this.eventSource.onmessage=s=>{try{let i=JSON.parse(s.data);this.messageHandler&&this.messageHandler(i)}catch(i){console.error("Failed to parse SSE message:",i)}},this.eventSource.onerror=()=>t(new Error("Failed to establish SSE connection"))})}async openListeningStreamWithFetch(e){let t=await fetch(this.mcpEndpoint,{method:"GET",headers:e});if(t.status===401){let a=t.headers.get("WWW-Authenticate"),u=await this.oauthHelper.ensureAccessToken({requestedUrl:this.mcpEndpoint,wwwAuthenticate:a,currentToken:null});if(!u)throw new Error("HTTP 401: Unauthorized");return this.customHeaders.Authorization=`Bearer ${u.token.accessToken}`,this.openListeningStreamWithFetch(this.buildHeaders({Accept:"text/event-stream"}))}if(!t.ok)throw new Error(`Failed to open SSE stream: ${t.status} ${t.statusText}`);if(!t.body)throw new Error("No response body available for SSE stream");let n=t.body.getReader(),r=new TextDecoder,s="",i=async()=>{try{let{done:a,value:u}=await n.read();if(a){n.releaseLock();return}s+=r.decode(u,{stream:!0});let c=s.split(`
1118
+ `);s=c.pop()||"";for(let l of c)if(l.startsWith("data: ")){let p=l.slice(6);if(p==="[DONE]")return;try{let d=JSON.parse(p);this.messageHandler&&this.messageHandler(d)}catch(d){console.error("Failed to parse SSE data:",d)}}await i()}catch(a){throw n.releaseLock(),a}};await i()}async send(e){let t=this.buildHeaders({"Content-Type":"application/json",Accept:"application/json, text/event-stream"}),n=JSON.stringify(e),r=await fetch(this.mcpEndpoint,{method:"POST",headers:t,body:n});if(r.status===401){let a=r.headers.get("WWW-Authenticate"),u=await this.oauthHelper.ensureAccessToken({requestedUrl:this.mcpEndpoint,wwwAuthenticate:a,currentToken:null});if(!u)throw new Error("HTTP 401: Unauthorized");this.customHeaders.Authorization=`Bearer ${u.token.accessToken}`,r=await fetch(this.mcpEndpoint,{method:"POST",headers:this.buildHeaders({"Content-Type":"application/json",Accept:"application/json, text/event-stream"}),body:n})}if(!r.ok)throw r.status===404&&this.sessionId?(this.sessionId=void 0,new Error("Session expired. Please reinitialize.")):new Error(`HTTP error ${r.status}: ${r.statusText}`);let s=r.headers.get("Mcp-Session-Id");s&&(this.sessionId=s);let i=r.headers.get("Content-Type");if(i?.includes("text/event-stream"))return this.handleSSEResponse(r,e.id);if(i?.includes("application/json"))return r.json();throw new Error(`Unexpected content type: ${i}`)}async handleSSEResponse(e,t){return new Promise((n,r)=>{let s=e.body?.getReader();if(!s){r(new Error("No response body reader available"));return}let i=new TextDecoder,a="",u=async()=>{try{let{done:c,value:l}=await s.read();if(c){s.releaseLock();return}a+=i.decode(l,{stream:!0});let p=a.split(`
1119
+ `);a=p.pop()||"";for(let d of p)if(d.startsWith("data: ")){let m=d.slice(6);if(m==="[DONE]")return;try{let g=JSON.parse(m);if("id"in g&&g.id===t){n(g);return}this.messageHandler&&this.messageHandler(g)}catch(g){console.error("Failed to parse SSE data:",g)}}await u()}catch(c){s.releaseLock(),r(c)}};u().catch(r)})}async sendNotification(e){let t=this.buildHeaders({"Content-Type":"application/json",Accept:"application/json, text/event-stream"}),n=JSON.stringify(e),r=await fetch(this.mcpEndpoint,{method:"POST",headers:t,body:n});if(r.status===401){let s=r.headers.get("WWW-Authenticate"),i=await this.oauthHelper.ensureAccessToken({requestedUrl:this.mcpEndpoint,wwwAuthenticate:s,currentToken:null});if(!i)throw new Error("HTTP 401: Unauthorized");this.customHeaders.Authorization=`Bearer ${i.token.accessToken}`,r=await fetch(this.mcpEndpoint,{method:"POST",headers:this.buildHeaders({"Content-Type":"application/json",Accept:"application/json, text/event-stream"}),body:n})}if(!r.ok)throw r.status===404&&this.sessionId?(this.sessionId=void 0,new Error("Session expired. Please reinitialize.")):new Error(`HTTP error ${r.status}: ${r.statusText}`);r.status!==202&&console.warn(`Unexpected status for notification: ${r.status}`)}async terminateSession(){if(this.sessionId)try{let e=this.buildHeaders({});(await fetch(this.mcpEndpoint,{method:"DELETE",headers:e})).status===405&&console.info("Server does not support explicit session termination")}catch(e){console.error("Failed to terminate session:",e)}finally{this.sessionId=void 0}}close(){this.eventSource&&(this.eventSource.close(),this.eventSource=void 0)}};var Ds=class{endpoint=null;sseUrl;eventSource;customHeaders={};oauthHelper;currentToken;currentIssuer;sseAbort;pendingRequests=new Map;messageHandler;endpointReady;constructor(e,t){this.sseUrl=e,this.customHeaders={...t?.headers??{}},t?.authorization&&(this.customHeaders.Authorization=t.authorization),this.oauthHelper=new ur(t?.oauth)}buildHeaders(e){return{...this.customHeaders,...e}}async openSSEWithFetch(e){let t=new AbortController;this.sseAbort=t;let n=await fetch(this.sseUrl,{method:"GET",headers:e,signal:t.signal});if(n.status===401){let s=n.headers.get("WWW-Authenticate"),i=await this.oauthHelper.ensureAccessToken({requestedUrl:this.sseUrl,wwwAuthenticate:s,currentToken:null});if(!i)throw new Error("HTTP 401: Unauthorized");return this.customHeaders.Authorization=`Bearer ${i.token.accessToken}`,this.openSSEWithFetch(this.buildHeaders({Accept:"text/event-stream"}))}if(!n.ok)throw new Error("Failed to establish SSE connection");let r=this.createEndpointReady();this.consumeSSEStream(n),await r}createEndpointReady(){if(!this.endpointReady){let e,t=new Promise(n=>{e=n});this.endpointReady={resolve:e,promise:t}}return this.endpointReady.promise}async consumeSSEStream(e){if(!e.body)throw new Error("No response body available for SSE stream");let t=e.body.getReader(),n=new TextDecoder,r="",s=null;for(;;){let{done:i,value:a}=await t.read();if(i)break;r+=n.decode(a,{stream:!0});let u=r.split(`
1120
+ `);r=u.pop()||"";for(let c of u)if(c.startsWith("event: "))s=c.slice(7).trim();else if(c.startsWith("data: ")){let l=c.slice(6);if(s==="endpoint"){let p=l.trim(),d;try{let m=JSON.parse(p);typeof m=="string"?d=m:m&&typeof m=="object"&&"uri"in m&&(d=m.uri)}catch{d=p}if(!d)throw new Error("Endpoint URI missing in SSE event data");/^https?:\/\//i.test(d)||(d=new URL(this.sseUrl).origin+(d.startsWith("/")?d:`/${d}`)),this.endpoint=d,this.endpointReady&&(this.endpointReady.resolve(),this.endpointReady=void 0)}else{let p=l.trim();try{let d=JSON.parse(p);if(d&&typeof d=="object"&&"id"in d){let m=d.id,g=this.pendingRequests.get(m);g?(g.resolve(d),this.pendingRequests.delete(m)):this.messageHandler&&this.messageHandler(d)}else this.messageHandler&&this.messageHandler(d)}catch{}}}else c.trim()===""&&(s=null)}}async connect(){let e=this.buildHeaders({Accept:"text/event-stream"});await this.openSSEWithFetch(e)}async send(e){if(!this.endpoint)throw new Error("HTTPTransport endpoint is not initialized. Call connect() first.");let t=this.buildHeaders({"Content-Type":"application/json"}),n=JSON.stringify(e),r=new Promise((a,u)=>{this.pendingRequests.set(e.id,{resolve:a,reject:u})}),s=await fetch(this.endpoint,{method:"POST",headers:t,body:n});if(s.status===401){let a=s.headers.get("WWW-Authenticate"),u=await this.oauthHelper.ensureAccessToken({requestedUrl:this.sseUrl,wwwAuthenticate:a,currentToken:null});if(!u)throw new Error("HTTP 401: Unauthorized");this.customHeaders.Authorization=`Bearer ${u.token.accessToken}`,s=await fetch(this.endpoint,{method:"POST",headers:this.buildHeaders({"Content-Type":"application/json"}),body:n})}if(!s.ok)throw this.pendingRequests.delete(e.id),new Error(`HTTP error ${s.status}: ${s.statusText}`);if(s.headers.get("Content-Type")?.includes("application/json")){let a=await s.json();return this.pendingRequests.delete(e.id),a}return r}async sendNotification(e){if(!this.endpoint)throw new Error("HTTPTransport endpoint is not initialized. Call connect() first.");let t=this.buildHeaders({"Content-Type":"application/json"}),n=JSON.stringify(e),r=await fetch(this.endpoint,{method:"POST",headers:t,body:n});if(r.status===401){let s=r.headers.get("WWW-Authenticate"),i=await this.oauthHelper.ensureAccessToken({requestedUrl:this.sseUrl,wwwAuthenticate:s,currentToken:null});if(!i)throw new Error("HTTP 401: Unauthorized");this.customHeaders.Authorization=`Bearer ${i.token.accessToken}`,r=await fetch(this.endpoint,{method:"POST",headers:this.buildHeaders({"Content-Type":"application/json"}),body:n})}if(!r.ok)throw new Error(`HTTP error ${r.status}: ${r.statusText}`);r.status!==202&&console.warn(`Unexpected status for notification: ${r.status}`)}close(){this.eventSource&&(this.eventSource.close(),this.eventSource=void 0),this.sseAbort&&(this.sseAbort.abort(),this.sseAbort=void 0)}};function Oa(o){return o.match(/^(\w+Error:\s*.{0,60})/m)?.[1]??o.slice(0,80)}function Ql(o){return Jr(o)}function Ig(o){return Ml(o)}var Tg=new Set(["var","let","const","function","return","if","else","for","while","do","switch","case","break","continue","try","catch","finally","throw","new","delete","typeof","void","in","of","instanceof","this","class","extends","super","import","export","default","from","as","async","await","yield","true","false","null","undefined","console","log"]);function Yl(o){let e=$t(o),t=/\b([a-zA-Z_$][a-zA-Z0-9_$]*)\b/g,n=new Set,r=t.exec(e);for(;r!==null;)r[1]&&!Tg.has(r[1])&&n.add(r[1]),r=t.exec(e);return n}function Xl(o){let e=Yl(o);for(let t of Ql(o))e.delete(t);return e}var wg=new Set(["dead-end","foundational","pivot","superseded"]);function Ft(o,e=120){let t=o.replace(/\s+/g," ").trim();return t.length<=e?t:`${t.slice(0,e-3)}...`}function Rg(o){return/\b(final|ask_clarification)\s*\(/.test(o)}function vg(o){return o.tags.includes("error")?"error":Rg(o.code)?"finalize":/\b(llmQuery|listModuleFunctions|getFunctionDefinitions)\s*\(/.test(o.code)?"query":(o.producedVars?.length??0)>0?"transform":"explore"}function Sg(o){let e=o.producedVars??[];if(e.length>0)return`Updated live runtime values: ${e.join(", ")}`;switch(o.stepKind){case"query":return"Gathered external or semantic evidence without creating durable runtime values";case"finalize":return"Prepared completion payload for the responder";case"error":return"Did not produce a durable runtime state update";default:return"Inspected runtime state without creating durable runtime values"}}function Ma(o){if(o.tombstone)return o.tombstone;let e=o.stepKind==="error"?"Error step":o.stepKind==="query"?"Query step":o.stepKind==="transform"?"Transform step":o.stepKind==="finalize"?"Finalize step":"Explore step",t=Ft(o.output||"(no output)"),n=Ft(o.actorFieldsOutput.replace(/^Actor fields:\s*/i,""),80),r=o.stateDelta??"No durable runtime state update",s=n?` Actor fields: ${n}.`:"";return`[SUMMARY]: ${e}. ${r}. Result: ${t}.${s}`}function kg(o){o.rank=void 0,o.tags=o.tags.filter(e=>!wg.has(e))}function Dt(o){o.producedVars||(o.producedVars=Ig(o.code)),o.referencedVars||(o.referencedVars=[...Yl(o.code)]),o.stepKind||(o.stepKind=vg(o)),o.stateDelta||(o.stateDelta=Sg(o)),o.summary||(o.summary=Ma(o))}function Zl(o,e){let t=[...o.matchAll(e)];return t.length===0?[]:t.map((n,r)=>{let s=n[1]?.trim(),i=n.index??0,a=t[r+1]?.index??o.length;if(s)return{key:s,text:o.slice(i,a).trim()}}).filter(n=>!!n)}function Og(o){return/\blistModuleFunctions\s*\(/.test(o.code)?Zl(o.output,/^### Module `([^`]+)`/gm).map(e=>({module:e.key,text:e.text})):[]}function Eg(o){return/\bgetFunctionDefinitions\s*\(/.test(o.code)?Zl(o.output,/^### `([^`]+)`/gm).map(e=>({qualifiedName:e.key,text:e.text})):[]}function Mg(o){let e=$t(o),t=new Set,n=/\b([a-zA-Z_$][a-zA-Z0-9_$]*)\.([a-zA-Z_$][a-zA-Z0-9_$]*)\s*\(/g,r=n.exec(e);for(;r;){let s=r[1],i=r[2];s&&i&&t.add(`${s}.${i}`),r=n.exec(e)}return[...t]}function Xr(o){o._discoveryModuleSections||(o._discoveryModuleSections=Og(o)),o._discoveryFunctionSections||(o._discoveryFunctionSections=Eg(o)),o._directQualifiedCalls||(o._directQualifiedCalls=Mg(o.code))}function Pg(o){return Xr(o),o._directQualifiedCalls?.find(Boolean)}function Us(o){let e=new Map;for(let t of o){let n=t;Dt(n);let r=Pg(n);for(let i of n.producedVars??[])e.set(i,{createdTurn:n.turn,stepKind:n.stepKind,source:r,code:n.code});let s=Xl(n.code);for(let i of s){let a=e.get(i);a&&(a.lastReadTurn=Math.max(a.lastReadTurn??a.createdTurn,n.turn))}}return e}function Fg(o){let e=Array.from({length:o.length},()=>new Set),t=new Set;for(let n=o.length-1;n>=0;n--){e[n]=new Set(t);let r=o[n];if(!(!r||r.tags.includes("error"))){Xr(r);for(let s of r._directQualifiedCalls??[])t.add(s)}}return e}function _g(o,e){let t=o;Xr(t);let n=t._discoveryFunctionSections??[];if(n.length>0){let s=n.filter(i=>!e.has(i.qualifiedName));return s.length===n.length?t:s.length===0?void 0:{...t,output:s.map(i=>i.text).join(`
1121
1121
 
1122
1122
  `),summary:void 0,_discoveryFunctionSections:s}}let r=t._discoveryModuleSections??[];if(r.length>0){let s=new Set([...e].map(a=>a.split(".")[0])),i=r.filter(a=>!s.has(a.module));return i.length===r.length?t:i.length===0?void 0:{...t,output:i.map(a=>a.text).join(`
1123
1123
 
1124
- `),summary:void 0,_discoveryModuleSections:i}}return t}function Ls(o,e){if(!e?.pruneUsedDocs||o.length===0)return[...o];let t=Hm(o);return o.flatMap((n,r)=>{let s=Km(n,t[r]??new Set);return s?[s]:[]})}function Wm(o){let e=Array.from({length:o.length},()=>new Set),t=new Set;for(let n=o.length-1;n>=0;n--){e[n]=new Set(t);for(let r of o[n]?.referencedVars??[])t.add(r)}return e}function Vm(o,e){let t=e.actionReplay??"full",n=Math.max(e.recentFullActions??1,0),r=t==="checkpointed"&&((e.checkpointTurns?.length??0)>0||!!e.checkpointSummary);for(let a of o)Dt(a);let s=Wm(o),i=Math.max(o.length-n,0);o.forEach((a,l)=>{if(a.tombstone){a.replayMode="full";return}if(t==="full"){a.replayMode="full";return}if(t==="checkpointed"&&!r){a.replayMode="full";return}let c=l>=i,u=a.tags.includes("error"),p=a.output.startsWith("[POLICY]"),d=s[l]??new Set,g=(a.producedVars??[]).some(f=>d.has(f));if(c||u||p){a.replayMode="full";return}if(t==="adaptive"&&g){a.replayMode="full";return}a.replayMode="omit"})}function Jm(o,e){Dt(o),Dt(e),Gm(o);let t=o.tags.includes("error"),n=e.tags.includes("error");if(t&&!n){o.rank=0,Qr(o,"dead-end");return}if(t&&n){let r=Ia(o.output),s=Ia(e.output);r!==s?(o.rank=3,Qr(o,"pivot")):(o.rank=0,Qr(o,"dead-end"));return}if(!t&&!n){let r=o.producedVars??Du(o.code);if(r.length===0||o.stepKind==="explore"||o.stepKind==="query")return;let s=Gu(e.code);if(r.filter(a=>s.has(a)).length>0){o.rank=5,Qr(o,"foundational");return}o.stepKind==="transform"&&(o.rank=1,Qr(o,"superseded"));return}}function Qr(o,e){o.tags.includes(e)||o.tags.push(e)}function wa(o,e){let t=o.output.split(`
1124
+ `),summary:void 0,_discoveryModuleSections:i}}return t}function Gs(o,e){if(!e?.pruneUsedDocs||o.length===0)return[...o];let t=Fg(o);return o.flatMap((n,r)=>{let s=_g(n,t[r]??new Set);return s?[s]:[]})}function Ng(o){let e=Array.from({length:o.length},()=>new Set),t=new Set;for(let n=o.length-1;n>=0;n--){e[n]=new Set(t);for(let r of o[n]?.referencedVars??[])t.add(r)}return e}function Lg(o,e){let t=e.actionReplay??"full",n=Math.max(e.recentFullActions??1,0),r=t==="checkpointed"&&((e.checkpointTurns?.length??0)>0||!!e.checkpointSummary);for(let a of o)Dt(a);let s=Ng(o),i=Math.max(o.length-n,0);o.forEach((a,u)=>{if(a.tombstone){a.replayMode="full";return}if(t==="full"){a.replayMode="full";return}if(t==="checkpointed"&&!r){a.replayMode="full";return}let c=u>=i,l=a.tags.includes("error"),p=a.output.startsWith("[POLICY]"),d=s[u]??new Set,g=(a.producedVars??[]).some(f=>d.has(f));if(c||l||p){a.replayMode="full";return}if(t==="adaptive"&&g){a.replayMode="full";return}a.replayMode="omit"})}function $g(o,e){Dt(o),Dt(e),kg(o);let t=o.tags.includes("error"),n=e.tags.includes("error");if(t&&!n){o.rank=0,Yr(o,"dead-end");return}if(t&&n){let r=Oa(o.output),s=Oa(e.output);r!==s?(o.rank=3,Yr(o,"pivot")):(o.rank=0,Yr(o,"dead-end"));return}if(!t&&!n){let r=o.producedVars??Ql(o.code);if(r.length===0||o.stepKind==="explore"||o.stepKind==="query")return;let s=Xl(e.code);if(r.filter(a=>s.has(a)).length>0){o.rank=5,Yr(o,"foundational");return}o.stepKind==="transform"&&(o.rank=1,Yr(o,"superseded"));return}}function Yr(o,e){o.tags.includes(e)||o.tags.push(e)}function Ea(o,e){let t=o.output.split(`
1125
1125
  `).map(r=>r.trim()).filter(Boolean).find(r=>/\b\w+Error:/.test(r)&&!r.startsWith("["))??o.output.split(`
1126
- `).map(r=>r.trim()).filter(r=>!!r&&!r.startsWith("[")&&!r.startsWith("...")).at(-1)??Ia(o.output);return`[TOMBSTONE]: Resolved ${_t(t,96)} in turn ${e.turn}.`}function Qm(o){return o.startsWith("[TOMBSTONE]: Resolved ")}var Ym=`You are an internal AxAgent tombstone summarizer.
1126
+ `).map(r=>r.trim()).filter(r=>!!r&&!r.startsWith("[")&&!r.startsWith("...")).at(-1)??Oa(o.output);return`[TOMBSTONE]: Resolved ${Ft(t,96)} in turn ${e.turn}.`}function Dg(o){return o.startsWith("[TOMBSTONE]: Resolved ")}var Ug=`You are an internal AxAgent tombstone summarizer.
1127
1127
 
1128
1128
  Write the output field \`tombstone\` as exactly one concise line.
1129
1129
  - Start with \`[TOMBSTONE]:\`
1130
1130
  - Summarize the resolved error and the successful fix.
1131
1131
  - Mention one failed approach to avoid when possible.
1132
1132
  - Do not include code fences, bullet points, or extra prose.
1133
- - Keep it roughly 20-40 tokens.`,Xm=`You are an internal AxAgent checkpoint summarizer.
1133
+ - Keep it roughly 20-40 tokens.`,Gg=`You are an internal AxAgent checkpoint summarizer.
1134
1134
 
1135
1135
  Write the output field \`checkpointSummary\` as plain text with exactly these labels in this order:
1136
1136
  Objective:
@@ -1151,29 +1151,29 @@ Rules:
1151
1151
  - Use \`Failures to avoid:\` for exact retry hazards. Use \`none\` if there are no important failure patterns in the provided turns.
1152
1152
  - Do not restate raw code or quote large outputs.
1153
1153
  - Use "none" when a section has nothing worth preserving.
1154
- - Be concise and factual, but prefer slightly more detail over losing task-critical specifics.`;function ju(o){let{mem:e,description:t,maxSteps:n,...r}=o??{};return r}function zu(o,e,t){let n=ju(t);return{...n,description:o,traceLabel:n.traceLabel??e,maxSteps:1}}function qu(o){return{...ju(o),maxSteps:1}}async function Zm(o,e,t,n,r){let s=new ke("errorCode:string, errorOutput:string, resolutionCode:string -> tombstone:string",{...zu(Ym,"ax-agent-tombstone-summary",e)});try{let i=await s.forward(o,{errorCode:n.code.slice(0,500),errorOutput:n.output.slice(0,300),resolutionCode:r.code.slice(0,500)},qu(t));return(typeof i.tombstone=="string"?i.tombstone.trim():String(i.tombstone).trim())||wa(n,r)}catch{return wa(n,r)}}function eg(o){return o.map(e=>{Dt(e),Yr(e);let t=e.actorFieldsOutput.replace(/^Actor fields:\s*/i,"").trim(),n=(e._directQualifiedCalls??[]).join(", ")||"none",r=e.tags.includes("error")?_t(e.output||"(no output)",200):"none";return[`Turn: ${e.turn}`,`Step kind: ${e.stepKind??"explore"}`,`Referenced inputs: ${(e.referencedVars??[]).join(", ")||"none"}`,`Durable values written: ${(e.producedVars??[]).join(", ")||"none"}`,`Direct callables: ${n}`,`State delta: ${e.stateDelta??"none"}`,`Observed result: ${_t(e.output||"(no output)",360)}`,`Actor fields: ${t||"none"}`,`Failure cues: ${r}`,`Code excerpt: ${_t(e.code||"(no code)",360)}`].join(`
1154
+ - Be concise and factual, but prefer slightly more detail over losing task-critical specifics.`;function ep(o){let{mem:e,description:t,maxSteps:n,...r}=o??{};return r}function tp(o,e,t){let n=ep(t);return{...n,description:o,traceLabel:n.traceLabel??e,maxSteps:1}}function np(o){return{...ep(o),maxSteps:1}}async function jg(o,e,t,n,r){let s=new Pe("errorCode:string, errorOutput:string, resolutionCode:string -> tombstone:string",{...tp(Ug,"ax-agent-tombstone-summary",e)});try{let i=await s.forward(o,{errorCode:n.code.slice(0,500),errorOutput:n.output.slice(0,300),resolutionCode:r.code.slice(0,500)},np(t));return(typeof i.tombstone=="string"?i.tombstone.trim():String(i.tombstone).trim())||Ea(n,r)}catch{return Ea(n,r)}}function Bg(o){return o.map(e=>{Dt(e),Xr(e);let t=e.actorFieldsOutput.replace(/^Actor fields:\s*/i,"").trim(),n=(e._directQualifiedCalls??[]).join(", ")||"none",r=e.tags.includes("error")?Ft(e.output||"(no output)",200):"none";return[`Turn: ${e.turn}`,`Step kind: ${e.stepKind??"explore"}`,`Referenced inputs: ${(e.referencedVars??[]).join(", ")||"none"}`,`Durable values written: ${(e.producedVars??[]).join(", ")||"none"}`,`Direct callables: ${n}`,`State delta: ${e.stateDelta??"none"}`,`Observed result: ${Ft(e.output||"(no output)",360)}`,`Actor fields: ${t||"none"}`,`Failure cues: ${r}`,`Code excerpt: ${Ft(e.code||"(no code)",360)}`].join(`
1155
1155
  `)}).join(`
1156
1156
 
1157
- `)}function $u(o){let e=new Set,t=new Set,n=[],r=[],s=[],i=[],a="Continue from the latest live runtime state.";for(let l of o){Dt(l),Yr(l),e.add(l.stepKind??"explore");for(let d of l.producedVars??[])t.add(d);let c=l._directQualifiedCalls??[];c.length>0?n.push(`Turn ${l.turn}: ${c.join(", ")} via ${_t(l.code||"(no code)",140)}`):/\b(listModuleFunctions|getFunctionDefinitions)\s*\(/.test(l.code)&&n.push(`Turn ${l.turn}: ${_t(l.code||"(no code)",140)}`);let u=_t(l.output||"(no output)",200);r.push(`Turn ${l.turn}: ${u}`);let p=l.actorFieldsOutput.replace(/^Actor fields:\s*/i,"").trim();p&&s.push(`Turn ${l.turn}: ${p}`),l.tags.includes("error")&&i.push(`Turn ${l.turn}: ${_t(l.output||"(no output)",160)}`),a=l.stepKind==="finalize"?"Complete the responder handoff.":"Continue from the latest live runtime state."}return[`Objective: ${[...e].join(", ")||"none"}`,`Durable state: ${[...t].join(", ")||"none"}`,`Exact callables and formats: ${n.join(" | ")||"none"}`,`Evidence: ${r.join(" | ")||"none"}`,"Conclusions: Preserve the durable state, exact callable usage, and evidence above. Confirmed execution facts should override inference.",`Actor fields: ${s.join(" | ")||"none"}`,`Failures to avoid: ${i.join(" | ")||"none"}`,`Next step: ${a}`].join(`
1158
- `)}async function Hu(o,e,t,n){let r=new ke("turns:string -> checkpointSummary:string",{...zu(Xm,"ax-agent-checkpoint-summary",e)});try{let s=await r.forward(o,{turns:eg(n)},qu(t));return(typeof s.checkpointSummary=="string"?s.checkpointSummary.trim():String(s.checkpointSummary).trim())||$u(n)}catch{return $u(n)}}async function va(o,e,t,n,r){let s=o[e];if(!s)return;Dt(s);let i=s.tags.includes("error");if(t.hindsightEvaluation&&o.length>=2){let a=o[o.length-2];Jm(a,s)}if(t.errorPruning||t.tombstoning)for(let a of o){if(!a.tags.includes("error"))continue;let l=o.indexOf(a),c=o[l+1];if(!c||c.tags.includes("error")||(t.errorPruning&&!a.tombstone&&(a.tombstone=wa(a,c)),!(!!t.tombstoning&&!!n&&!a._tombstonePromise&&(!a.tombstone||Qm(a.tombstone)))||!n))continue;let p=typeof t.tombstoning=="object"?t.tombstoning:void 0;a._tombstonePromise=Zm(n,p,r,a,c),a._tombstonePromise.then(d=>{a.tombstone=d}).catch(()=>{}).finally(()=>{a._tombstonePromise=void 0})}if(t.errorPruning&&!i){let a=o.filter(l=>!l.tags.includes("error")||l.tombstone!=null||l._tombstonePromise!=null);o.length=0,o.push(...a)}if(t.hindsightEvaluation){let a=o[o.length-1]?.turn??s.turn,l=o.filter((c,u)=>u===o.length-1||c.rank===void 0||!c.tags.includes("error")&&a-c.turn<t.rankPruneGraceTurns||c.rank>=t.pruneRank||c.tombstone!=null||c._tombstonePromise!=null);o.length=0,o.push(...l)}}function tg(o,e){if(e.has(o.turn)&&!o.tags.includes("error")&&o.replayMode!=="full")return"";if(o.tombstone)return`Action ${o.turn}:
1157
+ `)}function Jl(o){let e=new Set,t=new Set,n=[],r=[],s=[],i=[],a="Continue from the latest live runtime state.";for(let u of o){Dt(u),Xr(u),e.add(u.stepKind??"explore");for(let d of u.producedVars??[])t.add(d);let c=u._directQualifiedCalls??[];c.length>0?n.push(`Turn ${u.turn}: ${c.join(", ")} via ${Ft(u.code||"(no code)",140)}`):/\b(listModuleFunctions|getFunctionDefinitions)\s*\(/.test(u.code)&&n.push(`Turn ${u.turn}: ${Ft(u.code||"(no code)",140)}`);let l=Ft(u.output||"(no output)",200);r.push(`Turn ${u.turn}: ${l}`);let p=u.actorFieldsOutput.replace(/^Actor fields:\s*/i,"").trim();p&&s.push(`Turn ${u.turn}: ${p}`),u.tags.includes("error")&&i.push(`Turn ${u.turn}: ${Ft(u.output||"(no output)",160)}`),a=u.stepKind==="finalize"?"Complete the responder handoff.":"Continue from the latest live runtime state."}return[`Objective: ${[...e].join(", ")||"none"}`,`Durable state: ${[...t].join(", ")||"none"}`,`Exact callables and formats: ${n.join(" | ")||"none"}`,`Evidence: ${r.join(" | ")||"none"}`,"Conclusions: Preserve the durable state, exact callable usage, and evidence above. Confirmed execution facts should override inference.",`Actor fields: ${s.join(" | ")||"none"}`,`Failures to avoid: ${i.join(" | ")||"none"}`,`Next step: ${a}`].join(`
1158
+ `)}async function rp(o,e,t,n){let r=new Pe("turns:string -> checkpointSummary:string",{...tp(Gg,"ax-agent-checkpoint-summary",e)});try{let s=await r.forward(o,{turns:Bg(n)},np(t));return(typeof s.checkpointSummary=="string"?s.checkpointSummary.trim():String(s.checkpointSummary).trim())||Jl(n)}catch{return Jl(n)}}async function Pa(o,e,t,n,r){let s=o[e];if(!s)return;Dt(s);let i=s.tags.includes("error");if(t.hindsightEvaluation&&o.length>=2){let a=o[o.length-2];$g(a,s)}if(t.errorPruning||t.tombstoning)for(let a of o){if(!a.tags.includes("error"))continue;let u=o.indexOf(a),c=o[u+1];if(!c||c.tags.includes("error")||(t.errorPruning&&!a.tombstone&&(a.tombstone=Ea(a,c)),!(!!t.tombstoning&&!!n&&!a._tombstonePromise&&(!a.tombstone||Dg(a.tombstone)))||!n))continue;let p=typeof t.tombstoning=="object"?t.tombstoning:void 0;a._tombstonePromise=jg(n,p,r,a,c),a._tombstonePromise.then(d=>{a.tombstone=d}).catch(()=>{}).finally(()=>{a._tombstonePromise=void 0})}if(t.errorPruning&&!i){let a=o.filter(u=>!u.tags.includes("error")||u.tombstone!=null||u._tombstonePromise!=null);o.length=0,o.push(...a)}if(t.hindsightEvaluation){let a=o[o.length-1]?.turn??s.turn,u=o.filter((c,l)=>l===o.length-1||c.rank===void 0||!c.tags.includes("error")&&a-c.turn<t.rankPruneGraceTurns||c.rank>=t.pruneRank||c.tombstone!=null||c._tombstonePromise!=null);o.length=0,o.push(...u)}}function zg(o,e){if(e.has(o.turn)&&!o.tags.includes("error")&&o.replayMode!=="full")return"";if(o.tombstone)return`Action ${o.turn}:
1159
1159
  ${o.tombstone}`;switch(o.replayMode){case"omit":return Dt(o),`Action ${o.turn}:
1160
- ${o.summary??Ra(o)}`;default:return`Action ${o.turn}:
1160
+ ${o.summary??Ma(o)}`;default:return`Action ${o.turn}:
1161
1161
  \`\`\`javascript
1162
1162
  ${o.code}
1163
1163
  \`\`\`
1164
1164
  Result:
1165
- ${o.output}${o.actorFieldsOutput}`}}function Xr(o,e){let t=Ls(o,{pruneUsedDocs:e.pruneUsedDocs});if(t.length===0)return{promptFacingEntries:t,checkpointEntries:[],historyText:"",historyChars:0};Vm(t,e);let n=t.filter(i=>!i.tags.includes("error")&&i.replayMode!=="full"),r=new Set(e.checkpointTurns??[]),s=t.map(i=>tg(i,r)).filter(Boolean).join(`
1165
+ ${o.output}${o.actorFieldsOutput}`}}function Fa(o,e){let t=Gs(o,{pruneUsedDocs:e.pruneUsedDocs});if(t.length===0)return{promptFacingEntries:t,checkpointEntries:[],historyText:"",historyChars:0};Lg(t,e);let n=t.filter(i=>!i.tags.includes("error")&&i.replayMode!=="full"),r=new Set(e.checkpointTurns??[]),s=t.map(i=>zg(i,r)).filter(Boolean).join(`
1166
1166
 
1167
- `);return{promptFacingEntries:t,checkpointEntries:n,historyText:s,historyChars:s.length}}function Ku(o,e){let t=Xr(o,e);if(t.promptFacingEntries.length===0&&!e.delegatedContextSummary&&!e.stateSummary&&!e.checkpointSummary)return"";let n=[];return e.restoreNotice&&n.push(e.restoreNotice),e.delegatedContextSummary&&n.push(`Delegated Context (runtime-only \u2014 explore with code):
1167
+ `);return{promptFacingEntries:t,checkpointEntries:n,historyText:s,historyChars:s.length}}function op(o,e){let t=Fa(o,e);if(t.promptFacingEntries.length===0&&!e.delegatedContextSummary&&!e.stateSummary&&!e.checkpointSummary)return"";let n=[];return e.restoreNotice&&n.push(e.restoreNotice),e.delegatedContextSummary&&n.push(`Delegated Context (runtime-only \u2014 explore with code):
1168
1168
  ${e.delegatedContextSummary}`),e.stateSummary&&n.push(`Live Runtime State:
1169
1169
  ${e.stateSummary}`),t.historyText&&n.push(t.historyText),e.checkpointSummary&&n.push(`Checkpoint Summary:
1170
1170
  ${e.checkpointSummary}`),n.join(`
1171
1171
 
1172
- `)}function Wu(o,e){let t=Ls(o,{pruneUsedDocs:e?.pruneUsedDocs}),n=new Set(e?.checkpointTurns??[]),r=t.map(i=>{if(n.has(i.turn)&&!i.tags.includes("error"))return"";Dt(i);let a=i.tombstone??i.summary??Ra(i);return`- Action ${i.turn}: ${a}`}).filter(Boolean).join(`
1172
+ `)}function sp(o,e){let t=Gs(o,{pruneUsedDocs:e?.pruneUsedDocs}),n=new Set(e?.checkpointTurns??[]),r=t.map(i=>{if(n.has(i.turn)&&!i.tags.includes("error"))return"";Dt(i);let a=i.tombstone??i.summary??Ma(i);return`- Action ${i.turn}: ${a}`}).filter(Boolean).join(`
1173
1173
  `),s=["Actor stopped without calling final(...). Evidence summary:"];return e?.checkpointSummary&&s.push(`Checkpoint summary:
1174
1174
  ${e.checkpointSummary}`),r?s.push(r):e?.checkpointSummary||s.push("- No actions were taken."),e?.stateSummary&&s.push(`Current runtime state:
1175
1175
  ${e.stateSummary}`),s.join(`
1176
- `)}function Vu(o,e=[]){return`(() => {
1176
+ `)}function ip(o,e=[]){return`(() => {
1177
1177
  const skip = new Set([${[...o,...e].map(n=>`'${n}'`).join(",")}]);
1178
1178
  const truncate = (text, maxChars) =>
1179
1179
  text.length <= maxChars ? text : text.slice(0, maxChars - 3) + '...';
@@ -1294,21 +1294,21 @@ ${e.stateSummary}`),s.join(`
1294
1294
  }
1295
1295
  });
1296
1296
  return JSON.stringify({ version: 1, entries });
1297
- })()`}function Ju(){return"(() => JSON.stringify(Object.getOwnPropertyNames(globalThis).sort()))()"}function ng(o){let e=o.type;return Array.isArray(e)?e.filter(t=>typeof t=="string"):typeof e=="string"?e.includes(",")?e.split(",").map(t=>t.trim()).filter(Boolean):[e]:[]}function rg(o){let e=new Set(o);return e.has("object")&&e.has("array")&&e.has("string")&&e.has("number")&&e.has("boolean")&&e.has("null")}function Sa(o){if(o.enum)return o.enum.map(n=>`"${n}"`).join(" | ");let e=ng(o);if(e.length===0)return"unknown";if(rg(e))return"any";let t=[...new Set(e)].map(n=>{if(n==="array"){let r=o.items?Sa(o.items):"unknown";return r.includes(" | ")?`(${r})[]`:`${r}[]`}return n==="object"?o.properties&&Object.keys(o.properties).length>0?Yu(o):"object":n});return t.length>1?t.join(" | "):t[0]??"unknown"}function Yu(o,e){if(!o)return"{}";let t=!!o.properties&&Object.keys(o.properties).length>0,n=o.additionalProperties===!0;if(!t)return n?"{ [key: string]: unknown }":"{}";let r=new Set(o.required??[]),s=e?.respectRequired??!1,i=Object.entries(o.properties).map(([a,l])=>{let c=Sa(l),u=s&&!r.has(a)?"?":"";return`${a}${u}: ${c}`});return o?.additionalProperties===!0&&i.push("[key: string]: unknown"),`{ ${i.join(", ")} }`}function og(o){return o?Sa(o):"unknown"}function Qu(o){let e=Yu(o.parameters,{respectRequired:!0}),t=o.returns?`: Promise<${og(o.returns)}>`:"";return`- \`${o.qualifiedName}(args: ${e})${t}\``}function $s(o,e,t,n){let r=n.promptLevel??"detailed",s=e.length>0?e.map(m=>{let g=zn(m.type),f=m.isOptional?"optional":"required",x=m.description?`: ${m.description}`:"";return`- \`${m.name}\` -> \`inputs.${m.name}\` (${g}, ${f})${x}`}).join(`
1298
- `):"(none)",i=t.map(m=>`\`${m.name}\``).join(", "),a=[...n.agents??[]].sort((m,g)=>m.name.localeCompare(g.name)),l=[...n.agentFunctions??[]].sort((m,g)=>m.namespace!==g.namespace?m.namespace.localeCompare(g.namespace):m.name.localeCompare(g.name)),c=n.agentModuleNamespace??"agents",u=!!n.discoveryMode,p=n.availableModules?[...n.availableModules].sort((m,g)=>m.namespace.localeCompare(g.namespace)):[...new Set([...l.map(m=>m.namespace),...a.length>0?[c]:[]])].sort((m,g)=>m.localeCompare(g)).map(m=>({namespace:m})),d=yt("rlm/actor.md",{contextVarList:s,responderOutputFieldTitles:i,promptLevel:r,llmQueryPromptMode:n.llmQueryPromptMode??"simple",discoveryMode:u,hasInspectRuntime:!!n.hasInspectRuntime,hasAgentFunctions:!u&&a.length>0,agentModuleNamespace:c,agentFunctionsList:a.map(m=>Qu({qualifiedName:`${c}.${m.name}`,parameters:m.parameters})).join(`
1299
- `),hasFunctions:!u&&l.length>0,functionsList:l.map(m=>Qu({qualifiedName:`${m.namespace}.${m.name}`,parameters:m.parameters,returns:m.returns})).join(`
1300
- `),hasModules:u&&p.length>0,modulesList:p.map(m=>m.selectionCriteria?.trim()?`- \`${m.namespace}\` - ${m.selectionCriteria.trim()}`:`- \`${m.namespace}\``).join(`
1297
+ })()`}function ap(){return"(() => JSON.stringify(Object.getOwnPropertyNames(globalThis).sort()))()"}function qg(o){let e=o.type;return Array.isArray(e)?e.filter(t=>typeof t=="string"):typeof e=="string"?e.includes(",")?e.split(",").map(t=>t.trim()).filter(Boolean):[e]:[]}function Hg(o){let e=new Set(o);return e.has("object")&&e.has("array")&&e.has("string")&&e.has("number")&&e.has("boolean")&&e.has("null")}function _a(o){if(o.enum)return o.enum.map(n=>`"${n}"`).join(" | ");let e=qg(o);if(e.length===0)return"unknown";if(Hg(e))return"any";let t=[...new Set(e)].map(n=>{if(n==="array"){let r=o.items?_a(o.items):"unknown";return r.includes(" | ")?`(${r})[]`:`${r}[]`}return n==="object"?o.properties&&Object.keys(o.properties).length>0?cp(o):"object":n});return t.length>1?t.join(" | "):t[0]??"unknown"}function cp(o,e){if(!o)return"{}";let t=!!o.properties&&Object.keys(o.properties).length>0,n=o.additionalProperties===!0;if(!t)return n?"{ [key: string]: unknown }":"{}";let r=new Set(o.required??[]),s=e?.respectRequired??!1,i=Object.entries(o.properties).map(([a,u])=>{let c=_a(u),l=s&&!r.has(a)?"?":"";return`${a}${l}: ${c}`});return o?.additionalProperties===!0&&i.push("[key: string]: unknown"),`{ ${i.join(", ")} }`}function Kg(o){return o?_a(o):"unknown"}function up(o){let e=cp(o.parameters,{respectRequired:!0}),t=o.returns?`: Promise<${Kg(o.returns)}>`:"";return`- \`${o.qualifiedName}(args: ${e})${t}\``}function js(o,e,t,n){let r=n.promptLevel??"detailed",s=e.length>0?e.map(m=>{let g=Wn(m.type),f=m.isOptional?"optional":"required",x=m.description?`: ${m.description}`:"";return`- \`${m.name}\` -> \`inputs.${m.name}\` (${g}, ${f})${x}`}).join(`
1298
+ `):"(none)",i=t.map(m=>`\`${m.name}\``).join(", "),a=[...n.agents??[]].sort((m,g)=>m.name.localeCompare(g.name)),u=[...n.agentFunctions??[]].sort((m,g)=>m.namespace!==g.namespace?m.namespace.localeCompare(g.namespace):m.name.localeCompare(g.name)),c=n.agentModuleNamespace??"agents",l=!!n.discoveryMode,p=n.availableModules?[...n.availableModules].sort((m,g)=>m.namespace.localeCompare(g.namespace)):[...new Set([...u.map(m=>m.namespace),...a.length>0?[c]:[]])].sort((m,g)=>m.localeCompare(g)).map(m=>({namespace:m})),d=yt("rlm/actor.md",{contextVarList:s,responderOutputFieldTitles:i,promptLevel:r,llmQueryPromptMode:n.llmQueryPromptMode??"simple",discoveryMode:l,hasInspectRuntime:!!n.hasInspectRuntime,hasAgentFunctions:!l&&a.length>0,agentModuleNamespace:c,agentFunctionsList:a.map(m=>up({qualifiedName:`${c}.${m.name}`,parameters:m.parameters})).join(`
1299
+ `),hasFunctions:!l&&u.length>0,functionsList:u.map(m=>up({qualifiedName:`${m.namespace}.${m.name}`,parameters:m.parameters,returns:m.returns})).join(`
1300
+ `),hasModules:l&&p.length>0,modulesList:p.map(m=>m.selectionCriteria?.trim()?`- \`${m.namespace}\` - ${m.selectionCriteria.trim()}`:`- \`${m.namespace}\``).join(`
1301
1301
  `),runtimeUsageInstructions:String(n.runtimeUsageInstructions),enforceIncrementalConsoleTurns:!!n.enforceIncrementalConsoleTurns,hasLiveRuntimeState:!!n.hasLiveRuntimeState,hasCompressedActionReplay:!!n.hasCompressedActionReplay}).replace(/\n{3,}/g,`
1302
1302
 
1303
1303
  `).trim();return o?`${d}
1304
1304
 
1305
- ${o}`:d}function Ds(o,e){let t=e.length>0?e.map(r=>{let s=zn(r.type),i=r.isOptional?"optional":"required";return`- \`${r.name}\` (${s}, ${i})`}).join(`
1305
+ ${o}`:d}function Bs(o,e){let t=e.length>0?e.map(r=>{let s=Wn(r.type),i=r.isOptional?"optional":"required";return`- \`${r.name}\` (${s}, ${i})`}).join(`
1306
1306
  `):"(none)",n=yt("rlm/responder.md",{contextVarSummary:t}).trim();return o?`${n}
1307
1307
 
1308
- ${o}`:n}var Zr="ax-agent-recursive-slots-v1",ce={shared:"root.actor.shared",root:"root.actor.root",recursive:"root.actor.recursive",terminal:"root.actor.terminal",responder:"root.responder"},sg=()=>({promptTokens:0,completionTokens:0,totalTokens:0}),Kt=o=>{let e=Math.max(0,Math.floor(o?.promptTokens??0)),t=Math.max(0,Math.floor(o?.completionTokens??0)),n=Math.max(0,Math.floor(o?.totalTokens??0)),r=Math.max(n,e+t);return{promptTokens:e,completionTokens:t,totalTokens:r}},eo=(o,e)=>{let t=Kt(o),n=Kt(e);return{promptTokens:t.promptTokens+n.promptTokens,completionTokens:t.completionTokens+n.completionTokens,totalTokens:t.totalTokens+n.totalTokens}},Xu=(o,e)=>{let t=Kt(o),n=Kt(e);return Kt({promptTokens:Math.max(0,t.promptTokens-n.promptTokens),completionTokens:Math.max(0,t.completionTokens-n.completionTokens),totalTokens:Math.max(0,t.totalTokens-n.totalTokens)})},Us=o=>(o??[]).reduce((e,t)=>eo(e,{promptTokens:t.tokens?.promptTokens??0,completionTokens:t.tokens?.completionTokens??0,totalTokens:t.tokens?.totalTokens??0}),sg()),Nt=(o,e=240)=>{if(o===void 0)return;let t;if(typeof o=="string")t=o;else try{t=JSON.stringify(o)}catch{t=String(o)}let n=t.replace(/\s+/g," ").trim();if(n)return n.length<=e?n:`${n.slice(0,Math.max(0,e-3))}...`};var Gs=(o,e)=>{let t=e?.maxCodeChars??220,n=e?.maxOutputChars??220,r=e?.maxTaskChars??220,s=e?.maxContextChars??220,i=e?.maxToolErrors??12,a=e?.maxFunctionCalls??12,l=e?.maxChildren??Number.POSITIVE_INFINITY,c=o.children.slice(0,l).map(d=>Gs(d,e)),u=Kt(o.localUsage),p=c.reduce((d,m)=>eo(d,m.cumulativeUsage),u);return{nodeId:o.nodeId,parentId:o.parentId,depth:o.depth,role:o.role,taskDigest:Nt(o.taskDigest,r),contextDigest:Nt(o.contextDigest,s),completionType:o.completionType,turnCount:o.turnCount,childCount:c.length,actorTurns:o.actorTurns.map(d=>({turn:d.turn,code:Nt(d.code,t)??"",output:Nt(d.output,n)??"",isError:d.isError,thought:Nt(d.thought,n)})),functionCalls:o.functionCalls.slice(0,a).map(d=>({qualifiedName:d.qualifiedName,name:d.name,error:Nt(d.error,n)})),toolErrors:o.toolErrors.slice(0,i).map(d=>Nt(d,n)??""),localUsage:u,cumulativeUsage:p,children:c}},ka=o=>{let e=0,t=0,n=0,r=0,s=0,i=0,a=0,l=0,c=0,u=[],p=d=>{e++,n=Math.max(n,d.depth),d.depth>0&&r++,d.children.length===0&&t++,d.children.length>1&&s++,d.completionType==="ask_clarification"&&i++,(d.toolErrors.length>0||d.functionCalls.some(g=>!!g.error)||d.actorTurns.some(g=>g.isError))&&a++,d.completionType==="final"&&(d.children.length>0?c++:l++),u.push({nodeId:d.nodeId,role:d.role,depth:d.depth,taskDigest:d.taskDigest,totalTokens:d.cumulativeUsage.totalTokens});for(let g of d.children)p(g)};return p(o),{nodeCount:e,leafCount:t,maxDepth:n,recursiveCallCount:r,batchedFanOutCount:s,clarificationCount:i,errorCount:a,directAnswerCount:l,delegatedAnswerCount:c,rootLocalUsage:Kt(o.localUsage),rootCumulativeUsage:Kt(o.cumulativeUsage),topExpensiveNodes:u.sort((d,m)=>m.totalTokens-d.totalTokens).slice(0,5)}},Oa=(o,e)=>{let t=[`Trace nodes=${e.nodeCount}, leaves=${e.leafCount}, maxDepth=${e.maxDepth}, recursiveCalls=${e.recursiveCallCount}, batchedFanOuts=${e.batchedFanOutCount}.`,`Final answers direct=${e.directAnswerCount}, delegated=${e.delegatedAnswerCount}, clarifications=${e.clarificationCount}, errorNodes=${e.errorCount}.`,`Root role=${o.role}, root local tokens=${e.rootLocalUsage.totalTokens}, root cumulative tokens=${e.rootCumulativeUsage.totalTokens}.`];if(e.topExpensiveNodes.length>0){let n=e.topExpensiveNodes.map(r=>{let s=r.taskDigest&&r.taskDigest.length>0?` (${r.taskDigest})`:"";return`${r.nodeId}:${r.totalTokens}${s}`}).join("; ");t.push(`Most expensive nodes: ${n}.`)}return t.join(`
1309
- `)},Zu=(o,e)=>{let t=new Map;for(let n of o.children){let r=n.taskDigest?.trim();r&&t.set(r,(t.get(r)??0)+1)}for(let[n,r]of t)r>1&&e.push(n);for(let n of o.children)Zu(n,e)},ig=o=>{let e=[],t=n=>{e.push(n);for(let r of n.children)t(r)};return t(o),e},ep=o=>{let e=o.prediction.recursiveTrace,t=o.prediction.recursiveStats;if(!e||!t)return;let n=[],r=[];Zu(e,r);let s=ig(e),i=s.filter(c=>c.role==="recursive"),a=s.filter(c=>c.role==="terminal"),l=t.rootLocalUsage.totalTokens>0?t.rootCumulativeUsage.totalTokens/t.rootLocalUsage.totalTokens:t.rootCumulativeUsage.totalTokens>0?Number.POSITIVE_INFINITY:1;switch(o.componentId){case ce.root:{e.childCount>=4&&n.push(`Root decomposition fanned out into ${e.childCount} subtasks. Delegate fewer, higher-leverage branches.`),e.childCount>0&&t.rootCumulativeUsage.totalTokens>=8e3&&l>=3&&n.push(`Root decomposition consumed ${t.rootCumulativeUsage.totalTokens} total tokens versus ${t.rootLocalUsage.totalTokens} local tokens. Prefer solving directly when a shallow answer is viable.`),r.length>0&&n.push(`Sibling subtasks overlap in scope (${[...new Set(r)].slice(0,2).join("; ")}). Make delegated tasks more distinct.`);break}case ce.recursive:{let c=i.filter(p=>p.childCount===1&&p.cumulativeUsage.totalTokens>=2e3);c.length>0&&n.push(`Mid-tree branches repeatedly delegated one child at a time (${c.length} such nodes). Collapse serial delegation when the current branch can finish locally.`);let u=i.filter(p=>p.cumulativeUsage.totalTokens>=3e3).sort((p,d)=>d.cumulativeUsage.totalTokens-p.cumulativeUsage.totalTokens);u.length>0&&n.push(`Recursive branches are expensive (${u[0].cumulativeUsage.totalTokens} tokens on ${u[0].nodeId}). Narrow context and avoid redundant child work.`);break}case ce.terminal:{let c=a.filter(p=>p.toolErrors.length>0||p.functionCalls.some(d=>!!d.error)||p.actorTurns.some(d=>d.isError));c.length>0&&n.push(`Terminal-depth nodes still hit avoidable errors (${c.length} nodes). Terminal instructions should prefer direct, minimal answers from already available context.`);let u=a.filter(p=>p.localUsage.totalTokens>=2e3||p.turnCount>=3);u.length>0&&n.push(`Terminal-depth nodes spent too much effort before answering (${u.length} nodes over budget). Encourage concise direct answers at max depth.`);break}case ce.shared:{t.errorCount>0&&n.push(`The trace contains ${t.errorCount} error-producing nodes. Reinforce careful tool use, argument validation, and earlier stopping when the answer is already sufficient.`),t.rootCumulativeUsage.totalTokens>=1e4&&t.recursiveCallCount>=3&&n.push(`Tree-wide behavior is expensive (${t.rootCumulativeUsage.totalTokens} cumulative tokens across ${t.recursiveCallCount} recursive calls). Add stronger cost-awareness before delegating.`),t.delegatedAnswerCount>0&&t.directAnswerCount===0&&t.recursiveCallCount>=2&&n.push("The agent delegated every successful branch. Add a general rule to answer directly whenever the task can be completed without further recursion.");break}default:{t.errorCount>0&&n.push(`The recursive trace contains ${t.errorCount} error-producing nodes.`);break}}return n.length>0?n:void 0};var ir=o=>({[ce.shared]:o?.trim()??"",[ce.root]:"At the root, decide whether to solve directly or decompose. Delegate only when it clearly improves accuracy or reduces risk.",[ce.recursive]:"Within recursive branches, avoid redundant delegation. Narrow context, keep sibling tasks distinct, and finish locally when further fan-out is unnecessary.",[ce.terminal]:"At terminal depth, answer directly from the available context. Do not spend extra turns or imitate deeper delegation.",[ce.responder]:""}),tp=(o,e)=>{let t=[e[ce.shared]?.trim(),o==="root"?e[ce.root]?.trim():o==="recursive"?e[ce.recursive]?.trim():e[ce.terminal]?.trim()].filter(n=>!!n);if(t.length!==0)return t.join(`
1308
+ ${o}`:n}var Zr="ax-agent-recursive-slots-v1",le={shared:"root.actor.shared",root:"root.actor.root",recursive:"root.actor.recursive",terminal:"root.actor.terminal",responder:"root.responder"},Wg=()=>({promptTokens:0,completionTokens:0,totalTokens:0}),Vt=o=>{let e=Math.max(0,Math.floor(o?.promptTokens??0)),t=Math.max(0,Math.floor(o?.completionTokens??0)),n=Math.max(0,Math.floor(o?.totalTokens??0)),r=Math.max(n,e+t);return{promptTokens:e,completionTokens:t,totalTokens:r}},eo=(o,e)=>{let t=Vt(o),n=Vt(e);return{promptTokens:t.promptTokens+n.promptTokens,completionTokens:t.completionTokens+n.completionTokens,totalTokens:t.totalTokens+n.totalTokens}},lp=(o,e)=>{let t=Vt(o),n=Vt(e);return Vt({promptTokens:Math.max(0,t.promptTokens-n.promptTokens),completionTokens:Math.max(0,t.completionTokens-n.completionTokens),totalTokens:Math.max(0,t.totalTokens-n.totalTokens)})},zs=o=>(o??[]).reduce((e,t)=>eo(e,{promptTokens:t.tokens?.promptTokens??0,completionTokens:t.tokens?.completionTokens??0,totalTokens:t.tokens?.totalTokens??0}),Wg()),_t=(o,e=240)=>{if(o===void 0)return;let t;if(typeof o=="string")t=o;else try{t=JSON.stringify(o)}catch{t=String(o)}let n=t.replace(/\s+/g," ").trim();if(n)return n.length<=e?n:`${n.slice(0,Math.max(0,e-3))}...`};var qs=(o,e)=>{let t=e?.maxCodeChars??220,n=e?.maxOutputChars??220,r=e?.maxTaskChars??220,s=e?.maxContextChars??220,i=e?.maxToolErrors??12,a=e?.maxFunctionCalls??12,u=e?.maxChildren??Number.POSITIVE_INFINITY,c=o.children.slice(0,u).map(d=>qs(d,e)),l=Vt(o.localUsage),p=c.reduce((d,m)=>eo(d,m.cumulativeUsage),l);return{nodeId:o.nodeId,parentId:o.parentId,depth:o.depth,role:o.role,taskDigest:_t(o.taskDigest,r),contextDigest:_t(o.contextDigest,s),completionType:o.completionType,turnCount:o.turnCount,childCount:c.length,actorTurns:o.actorTurns.map(d=>({turn:d.turn,code:_t(d.code,t)??"",output:_t(d.output,n)??"",isError:d.isError,thought:_t(d.thought,n)})),functionCalls:o.functionCalls.slice(0,a).map(d=>({qualifiedName:d.qualifiedName,name:d.name,error:_t(d.error,n)})),toolErrors:o.toolErrors.slice(0,i).map(d=>_t(d,n)??""),localUsage:l,cumulativeUsage:p,children:c}},Na=o=>{let e=0,t=0,n=0,r=0,s=0,i=0,a=0,u=0,c=0,l=[],p=d=>{e++,n=Math.max(n,d.depth),d.depth>0&&r++,d.children.length===0&&t++,d.children.length>1&&s++,d.completionType==="ask_clarification"&&i++,(d.toolErrors.length>0||d.functionCalls.some(g=>!!g.error)||d.actorTurns.some(g=>g.isError))&&a++,d.completionType==="final"&&(d.children.length>0?c++:u++),l.push({nodeId:d.nodeId,role:d.role,depth:d.depth,taskDigest:d.taskDigest,totalTokens:d.cumulativeUsage.totalTokens});for(let g of d.children)p(g)};return p(o),{nodeCount:e,leafCount:t,maxDepth:n,recursiveCallCount:r,batchedFanOutCount:s,clarificationCount:i,errorCount:a,directAnswerCount:u,delegatedAnswerCount:c,rootLocalUsage:Vt(o.localUsage),rootCumulativeUsage:Vt(o.cumulativeUsage),topExpensiveNodes:l.sort((d,m)=>m.totalTokens-d.totalTokens).slice(0,5)}},La=(o,e)=>{let t=[`Trace nodes=${e.nodeCount}, leaves=${e.leafCount}, maxDepth=${e.maxDepth}, recursiveCalls=${e.recursiveCallCount}, batchedFanOuts=${e.batchedFanOutCount}.`,`Final answers direct=${e.directAnswerCount}, delegated=${e.delegatedAnswerCount}, clarifications=${e.clarificationCount}, errorNodes=${e.errorCount}.`,`Root role=${o.role}, root local tokens=${e.rootLocalUsage.totalTokens}, root cumulative tokens=${e.rootCumulativeUsage.totalTokens}.`];if(e.topExpensiveNodes.length>0){let n=e.topExpensiveNodes.map(r=>{let s=r.taskDigest&&r.taskDigest.length>0?` (${r.taskDigest})`:"";return`${r.nodeId}:${r.totalTokens}${s}`}).join("; ");t.push(`Most expensive nodes: ${n}.`)}return t.join(`
1309
+ `)},pp=(o,e)=>{let t=new Map;for(let n of o.children){let r=n.taskDigest?.trim();r&&t.set(r,(t.get(r)??0)+1)}for(let[n,r]of t)r>1&&e.push(n);for(let n of o.children)pp(n,e)},Vg=o=>{let e=[],t=n=>{e.push(n);for(let r of n.children)t(r)};return t(o),e},dp=o=>{let e=o.prediction.recursiveTrace,t=o.prediction.recursiveStats;if(!e||!t)return;let n=[],r=[];pp(e,r);let s=Vg(e),i=s.filter(c=>c.role==="recursive"),a=s.filter(c=>c.role==="terminal"),u=t.rootLocalUsage.totalTokens>0?t.rootCumulativeUsage.totalTokens/t.rootLocalUsage.totalTokens:t.rootCumulativeUsage.totalTokens>0?Number.POSITIVE_INFINITY:1;switch(o.componentId){case le.root:{e.childCount>=4&&n.push(`Root decomposition fanned out into ${e.childCount} subtasks. Delegate fewer, higher-leverage branches.`),e.childCount>0&&t.rootCumulativeUsage.totalTokens>=8e3&&u>=3&&n.push(`Root decomposition consumed ${t.rootCumulativeUsage.totalTokens} total tokens versus ${t.rootLocalUsage.totalTokens} local tokens. Prefer solving directly when a shallow answer is viable.`),r.length>0&&n.push(`Sibling subtasks overlap in scope (${[...new Set(r)].slice(0,2).join("; ")}). Make delegated tasks more distinct.`);break}case le.recursive:{let c=i.filter(p=>p.childCount===1&&p.cumulativeUsage.totalTokens>=2e3);c.length>0&&n.push(`Mid-tree branches repeatedly delegated one child at a time (${c.length} such nodes). Collapse serial delegation when the current branch can finish locally.`);let l=i.filter(p=>p.cumulativeUsage.totalTokens>=3e3).sort((p,d)=>d.cumulativeUsage.totalTokens-p.cumulativeUsage.totalTokens);l.length>0&&n.push(`Recursive branches are expensive (${l[0].cumulativeUsage.totalTokens} tokens on ${l[0].nodeId}). Narrow context and avoid redundant child work.`);break}case le.terminal:{let c=a.filter(p=>p.toolErrors.length>0||p.functionCalls.some(d=>!!d.error)||p.actorTurns.some(d=>d.isError));c.length>0&&n.push(`Terminal-depth nodes still hit avoidable errors (${c.length} nodes). Terminal instructions should prefer direct, minimal answers from already available context.`);let l=a.filter(p=>p.localUsage.totalTokens>=2e3||p.turnCount>=3);l.length>0&&n.push(`Terminal-depth nodes spent too much effort before answering (${l.length} nodes over budget). Encourage concise direct answers at max depth.`);break}case le.shared:{t.errorCount>0&&n.push(`The trace contains ${t.errorCount} error-producing nodes. Reinforce careful tool use, argument validation, and earlier stopping when the answer is already sufficient.`),t.rootCumulativeUsage.totalTokens>=1e4&&t.recursiveCallCount>=3&&n.push(`Tree-wide behavior is expensive (${t.rootCumulativeUsage.totalTokens} cumulative tokens across ${t.recursiveCallCount} recursive calls). Add stronger cost-awareness before delegating.`),t.delegatedAnswerCount>0&&t.directAnswerCount===0&&t.recursiveCallCount>=2&&n.push("The agent delegated every successful branch. Add a general rule to answer directly whenever the task can be completed without further recursion.");break}default:{t.errorCount>0&&n.push(`The recursive trace contains ${t.errorCount} error-producing nodes.`);break}}return n.length>0?n:void 0};var cr=o=>({[le.shared]:o?.trim()??"",[le.root]:"At the root, decide whether to solve directly or decompose. Delegate only when it clearly improves accuracy or reduces risk.",[le.recursive]:"Within recursive branches, avoid redundant delegation. Narrow context, keep sibling tasks distinct, and finish locally when further fan-out is unnecessary.",[le.terminal]:"At terminal depth, answer directly from the available context. Do not spend extra turns or imitate deeper delegation.",[le.responder]:""}),mp=(o,e)=>{let t=[e[le.shared]?.trim(),o==="root"?e[le.root]?.trim():o==="recursive"?e[le.recursive]?.trim():e[le.terminal]?.trim()].filter(n=>!!n);if(t.length!==0)return t.join(`
1310
1310
 
1311
- `)};var ct=class extends Error{question;clarification;stateSnapshot;stateErrorMessage;constructor(e,t){let n=yp(e);super(n.question),this.name="AxAgentClarificationError",this.question=n.question,this.clarification=n,this.stateSnapshot=t?.state?ar(t.state):void 0,this.stateErrorMessage=t?.stateError}getState(){if(this.stateErrorMessage)throw new Error(this.stateErrorMessage);return this.stateSnapshot?ar(this.stateSnapshot):void 0}},rp=8,Ea=5e3,ag=8,op=8,Bs=2,lg=1200,js="agents",cg=2,ug=14e3,pg=1e4,dg=4,mg=2,gg=3,fg=8e3,hg=3,xg=3,Ag=100,yg=new Set(["console","Math","JSON","Object","Array","String","Number","Boolean","Date","Promise","Reflect","Map","Set","WeakMap","WeakSet","Symbol","Intl","URL","URLSearchParams"]),bg=/^[$A-Z_a-z][$0-9A-Z_a-z]*$/,Tg=new Set(["context","__proto__","prototype","constructor","globalThis","global","self","window","console","JSON","Math","Reflect","Atomics","Array","Object","String","Number","Boolean","BigInt","Symbol","Date","RegExp","Error","EvalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError","AggregateError","Map","Set","WeakMap","WeakSet","Promise","Proxy","Function","Intl","URL","URLSearchParams","TextEncoder","TextDecoder","AbortController","AbortSignal","parseInt","parseFloat","isNaN","isFinite","eval","undefined","Infinity","NaN","await","break","case","catch","class","const","continue","debugger","default","delete","do","else","enum","export","extends","false","finally","for","function","if","import","in","instanceof","new","null","return","super","switch","this","throw","true","try","typeof","var","void","while","with","yield","let","static","implements","interface","package","private","protected","public"]),Ma="listModuleFunctions",Pa="getFunctionDefinitions",Cg="AI service is required to use llmQuery(...) in AxAgent.test(). Pass options.ai or configure ai on the agent.",Hs="[The JavaScript runtime was restarted; all global state was lost and must be recreated if needed.]",lI=new Ne(`
1311
+ `)};var to="agents";var gp='actorModelPolicy now expects an ordered array of { model, abovePromptChars?, aboveErrorTurns? } entries. Example: actorModelPolicy: [{ model: "gpt-5.4-mini", abovePromptChars: 16000 }, { model: "gpt-5.4", aboveErrorTurns: 2 }]';function Jg(o,e){if(typeof o!="string"||o.trim().length===0)throw new Error(`${e} must be a non-empty string`);return o.trim()}function fp(o,e){if(o!==void 0){if(typeof o!="number"||!Number.isFinite(o)||o<0)throw new Error(`${e} must be a finite number >= 0`);return o}}function hp(o){if(o!==void 0){if(!Array.isArray(o))throw new Error(gp);if(o.length===0)throw new Error("actorModelPolicy must contain at least one entry");return o.map((e,t)=>{if(!e||typeof e!="object"||Array.isArray(e))throw new Error(`actorModelPolicy[${t}] must be an object`);let n=e;if("escalatedModel"in n||"baseModel"in n||"escalateAtPromptChars"in n||"escalateAtPromptCharsWhenCheckpointed"in n||"recentErrorWindowTurns"in n||"recentErrorThreshold"in n||"discoveryStallTurns"in n||"deescalateBelowPromptChars"in n||"stableTurnsBeforeDeescalate"in n||"minEscalatedTurns"in n)throw new Error(gp);let r=fp(n.abovePromptChars,`actorModelPolicy[${t}].abovePromptChars`),s=fp(n.aboveErrorTurns,`actorModelPolicy[${t}].aboveErrorTurns`);if(s!==void 0&&!Number.isInteger(s))throw new Error(`actorModelPolicy[${t}].aboveErrorTurns must be an integer >= 0`);if(r===void 0&&s===void 0)throw new Error(`actorModelPolicy[${t}] must define at least one of abovePromptChars or aboveErrorTurns`);return{model:Jg(n.model,`actorModelPolicy[${t}].model`),...r!==void 0?{abovePromptChars:r}:{},...s!==void 0?{aboveErrorTurns:s}:{}}})}}function $a(o){let e=o?.preset??"full",t=Qg(e),n=o?.expert?.rankPruning,r=n?.enabled??(n?.minRank!==void 0?!0:t.hindsight),s=o?.state?.summary??t.stateSummary,i=o?.state?.inspect??t.inspect,a=o?.checkpoints?.enabled??t.checkpointsEnabled;if(a&&!s&&!i)throw new Error("contextPolicy.checkpoints requires either state.summary or state.inspect to be enabled");return{preset:e,summarizerOptions:o?.summarizerOptions,pruneUsedDocs:o?.pruneUsedDocs??t.pruneUsedDocs,actionReplay:o?.expert?.replay??t.actionReplay,recentFullActions:Math.max(o?.expert?.recentFullActions??t.recentFullActions,0),errorPruning:o?.pruneErrors??t.errorPruning,hindsightEvaluation:r,pruneRank:n?.minRank??t.pruneRank,rankPruneGraceTurns:2,tombstoning:o?.expert?.tombstones,stateSummary:{enabled:s,maxEntries:o?.state?.maxEntries??t.maxEntries,maxChars:o?.state?.maxChars??t.maxStateChars},stateInspection:{enabled:i,contextThreshold:o?.state?.inspectThresholdChars??t.inspectThreshold},checkpoints:{enabled:a,triggerChars:o?.checkpoints?.triggerChars??t.checkpointTriggerChars}}}function Qg(o){switch(o){case"adaptive":return{actionReplay:"adaptive",recentFullActions:3,errorPruning:!0,hindsight:!1,pruneRank:2,pruneUsedDocs:!1,stateSummary:!0,inspect:!0,inspectThreshold:16e3,maxEntries:8,maxStateChars:1600,checkpointsEnabled:!0,checkpointTriggerChars:22e3};case"lean":return{actionReplay:"minimal",recentFullActions:1,errorPruning:!0,hindsight:!1,pruneRank:2,pruneUsedDocs:!0,stateSummary:!0,inspect:!0,inspectThreshold:12e3,maxEntries:4,maxStateChars:800,checkpointsEnabled:!0,checkpointTriggerChars:15e3};case"checkpointed":return{actionReplay:"checkpointed",recentFullActions:3,errorPruning:!1,hindsight:!1,pruneRank:2,pruneUsedDocs:!1,stateSummary:!0,inspect:!0,inspectThreshold:16e3,maxEntries:8,maxStateChars:1600,checkpointsEnabled:!0,checkpointTriggerChars:18e3};default:return{actionReplay:"full",recentFullActions:1,errorPruning:!1,hindsight:!1,pruneRank:2,pruneUsedDocs:!1,stateSummary:!1,inspect:!1,inspectThreshold:void 0,maxEntries:void 0,maxStateChars:void 0,checkpointsEnabled:!1,checkpointTriggerChars:void 0}}}function Da(o){return o?.consecutiveErrorTurns??0}function Ua(){return{consecutiveErrorTurns:0}}function xp(o){if(!o||typeof o!="object"||Array.isArray(o))return;let e=o,t=e.consecutiveErrorTurns;if(typeof t=="number"&&Number.isFinite(t)&&t>=0)return{consecutiveErrorTurns:Math.floor(t)};if("escalated"in e||"escalatedTurns"in e||"stableBelowThresholdTurns"in e)return Ua()}function Ap(o,e){return{consecutiveErrorTurns:e?Da(o)+1:0}}function yp(o,e,t){let n;for(let r of o){let s=r.abovePromptChars!==void 0&&e>=r.abovePromptChars,i=r.aboveErrorTurns!==void 0&&t>=r.aboveErrorTurns;(s||i)&&(n=r.model)}return n}var Ut=class extends Error{constructor(t){super(`AxAgent protocol completion: ${t}`);this.type=t;this.name="AxAgentProtocolCompletionSignal"}};function Ga(o){return{finalFunction:(...r)=>{o("final",r)},askClarificationFunction:(...r)=>{o("ask_clarification",r)},protocol:{final:(...r)=>{throw o("final",r),new Ut("final")},askClarification:(...r)=>{throw o("ask_clarification",r),new Ut("ask_clarification")}}}}function ja(o,e){if(e.length===0)throw new Error(`${o}() requires at least one argument`);if(o==="ask_clarification"){if(e.length!==1)throw new Error("ask_clarification() requires exactly one argument");return{type:o,args:[Cp(e[0])]}}return{type:o,args:e}}function bp(o){return!!o&&typeof o=="object"&&!Array.isArray(o)&&Object.getPrototypeOf(o)===Object.prototype}function no(o){return typeof o=="string"&&o.trim().length>0}function Yg(o){if(no(o))return o;if(!bp(o))throw new Error("ask_clarification() choice entries must be non-empty strings or objects with a non-empty label");if(!no(o.label))throw new Error("ask_clarification() choice objects require a non-empty label");if(o.value!==void 0&&!no(o.value))throw new Error("ask_clarification() choice object values must be non-empty strings");return{label:o.label,...o.value!==void 0?{value:o.value}:{}}}function Cp(o){if(no(o))return o;if(!bp(o))throw new Error("ask_clarification() requires a non-empty string or an object payload");if(!no(o.question))throw new Error("ask_clarification() object payload requires a non-empty question");let e=new Set(["text","number","date","single_choice","multiple_choice"]),t;if(o.type===void 0)t=Array.isArray(o.choices)&&o.choices.length>0?"single_choice":void 0;else{if(typeof o.type!="string"||!e.has(o.type))throw new Error("ask_clarification() object payload type must be one of: text, number, date, single_choice, multiple_choice");t=o.type}let n=t==="single_choice"||t==="multiple_choice",r=o.choices;if(r!==void 0){if(!Array.isArray(r)||r.length===0)throw new Error("ask_clarification() choices must be a non-empty array when provided")}else if(n)throw new Error("ask_clarification() choice payloads require a non-empty choices array");return{...o,question:o.question,...t?{type:t}:{},...r?{choices:r.map(Yg)}:{}}}function Ba(o){let e=Cp(o);return typeof e=="string"?{question:e}:e}var Tp=100,XI=new Me(`
1312
1312
  taskInput:json "The structured task input passed to the agent",
1313
1313
  criteria:string "Task-specific success criteria",
1314
1314
  expectedOutput?:json "Optional expected final output",
@@ -1326,7 +1326,7 @@ ${o}`:n}var Zr="ax-agent-recursive-slots-v1",ce={shared:"root.actor.shared",root
1326
1326
  usage?:json "Optional usage summary for the run",
1327
1327
  recursiveTrace?:json "Optional structured recursive trace projection for advanced recursive llmQuery runs",
1328
1328
  recursiveStats?:json "Optional deterministic recursive trace statistics for advanced recursive llmQuery runs"
1329
- `),Ig=new Ne(`
1329
+ `),wp=new Me(`
1330
1330
  taskInput:json "The structured task input passed to the agent",
1331
1331
  criteria:string "Task-specific success criteria",
1332
1332
  expectedOutput?:json "Optional expected final output",
@@ -1346,11 +1346,11 @@ ${o}`:n}var Zr="ax-agent-recursive-slots-v1",ce={shared:"root.actor.shared",root
1346
1346
  ->
1347
1347
  reasoning:string "Short explanation of the run quality",
1348
1348
  quality:class "excellent, good, acceptable, poor, unacceptable" "Overall run quality tier"
1349
- `),wg=new Ne(`
1349
+ `),Rp=new Me(`
1350
1350
  taskRecord:json "Full optimization task record, including the agent input and evaluation criteria"
1351
1351
  ->
1352
1352
  agentRunReport:json "Agent run report containing completion type, clarification or final output, action log, function calls, errors, and turn count"
1353
- `);function Rg(o){return"train"in o?{train:o.train,validation:o.validation}:{train:o}}function lt(o){if(o!==void 0){if(o===null)return null;if(typeof o=="string"||typeof o=="number"||typeof o=="boolean")return o;if(Array.isArray(o))try{return JSON.parse(JSON.stringify(o))}catch{return o.map(e=>lt(e))}if(typeof o=="object")try{return JSON.parse(JSON.stringify(o))}catch{return String(o)}return String(o)}}function vg(o){let e=o.trim();for(;;){let t=e;if(e=e.replace(/^```(?:[A-Za-z0-9_-]+)?[ \t]*\r?\n/,""),e=e.replace(/\r?\n?```[ \t]*$/,""),e=e.trim(),e===t)return e}}function Sg(o){let e=`
1353
+ `);function vp(o){return"train"in o?{train:o.train,validation:o.validation}:{train:o}}function it(o){if(o!==void 0){if(o===null)return null;if(typeof o=="string"||typeof o=="number"||typeof o=="boolean")return o;if(Array.isArray(o))try{return JSON.parse(JSON.stringify(o))}catch{return o.map(e=>it(e))}if(typeof o=="object")try{return JSON.parse(JSON.stringify(o))}catch{return String(o)}return String(o)}}function Sp(o){let e=o.trim();for(;;){let t=e;if(e=e.replace(/^```(?:[A-Za-z0-9_-]+)?[ \t]*\r?\n/,""),e=e.replace(/\r?\n?```[ \t]*$/,""),e=e.trim(),e===t)return e}}function kp(o){let e=`
1354
1354
  Use the input field named "criteria" as the task-specific rubric for success.
1355
1355
  - Reward actual task completion over polished wording.
1356
1356
  - Reward correct tool choice and correct arguments.
@@ -1365,42 +1365,42 @@ Use the input field named "criteria" as the task-specific rubric for success.
1365
1365
  `.trim(),t=o?.trim();return t?`${e}
1366
1366
 
1367
1367
  Additional Evaluation Guidance:
1368
- ${t}`:e}function kg(o){let{criteria:e,description:t,randomizeOrder:n,...r}=o;return{...r,maxSteps:1}}function Og(o){let e=o.toLowerCase();return e==="excellent"?1:e==="good"?.8:e==="acceptable"?.5:e==="poor"?.2:e==="unacceptable"?0:.5}function sp(o,e){return e.qualifiedName===o||e.name===o||e.qualifiedName.endsWith(`.${o}`)}function Eg(o,e,t){let n=Math.max(0,Math.min(1,o)),r=e.expectedActions??[];if(r.length>0){let i=r.filter(a=>t.functionCalls.some(l=>sp(a,l))).length;n*=.5+.5*(i/r.length)}return(e.forbiddenActions??[]).some(i=>t.functionCalls.some(a=>sp(i,a)))&&(n*=.2),Math.max(0,Math.min(1,n))}function Mg(o,e){let t=new Set(o.map(i=>i.id)),n=t.has(ce.shared),r=[ce.shared,ce.root,ce.recursive,ce.terminal].filter(i=>t.has(i));if(e==="actor"){if(n){if(r.length===0)throw new Error("AxAgent.optimize(): recursive actor targets are not available");return r}if(!t.has("root.actor"))throw new Error("AxAgent.optimize(): root.actor is not available");return["root.actor"]}if(e==="responder"){if(!t.has("root.responder"))throw new Error("AxAgent.optimize(): root.responder is not available");return["root.responder"]}if(e==="all")return n?[...r,...t.has(ce.responder)?[ce.responder]:[]]:[...t];let s=[...e];for(let i of s)if(!t.has(i))throw new Error(`AxAgent.optimize(): unknown target program ID "${i}"`);return s}var lr=class extends Error{constructor(t){super(`AxAgent protocol completion: ${t}`);this.type=t;this.name="AxAgentProtocolCompletionSignal"}};function ip(o){return{finalFunction:(...r)=>{o("final",r)},askClarificationFunction:(...r)=>{o("ask_clarification",r)},protocol:{final:(...r)=>{throw o("final",r),new lr("final")},askClarification:(...r)=>{throw o("ask_clarification",r),new lr("ask_clarification")}}}}function Pg(o,e,t){return{model:o?.model,modelConfig:o?.modelConfig,debug:e,verbose:o?.verbose,rateLimiter:o?.rateLimiter,fetch:o?.fetch,tracer:o?.tracer,meter:o?.meter,timeout:o?.timeout,excludeContentFromTrace:o?.excludeContentFromTrace,abortSignal:t,logger:o?.logger,sessionId:o?.sessionId,debugHideSystemPrompt:o?.debugHideSystemPrompt,traceContext:o?.traceContext,thinkingTokenBudget:o?.thinkingTokenBudget,showThoughts:o?.showThoughts,useExpensiveModel:o?.useExpensiveModel,corsProxy:o?.corsProxy,retry:o?.retry,contextCache:o?.contextCache,examplesInSystem:o?.examplesInSystem,customLabels:o?.customLabels}}function ap(o,e){if(typeof o!="string"||o.trim().length===0)throw new Error(`${e} must be a non-empty string`);return o.trim()}function Fg(o){if(o)return{escalatedModel:ap(o.escalatedModel,"actorModelPolicy.escalatedModel"),...o.baseModel!==void 0?{baseModel:ap(o.baseModel,"actorModelPolicy.baseModel")}:{},escalateAtPromptChars:Math.max(1,o.escalateAtPromptChars??ug),escalateAtPromptCharsWhenCheckpointed:Math.max(1,o.escalateAtPromptCharsWhenCheckpointed??pg),recentErrorWindowTurns:Math.max(1,o.recentErrorWindowTurns??dg),recentErrorThreshold:Math.max(1,o.recentErrorThreshold??mg),discoveryStallTurns:Math.max(1,o.discoveryStallTurns??gg),deescalateBelowPromptChars:Math.max(0,o.deescalateBelowPromptChars??fg),stableTurnsBeforeDeescalate:Math.max(1,o.stableTurnsBeforeDeescalate??hg),minEscalatedTurns:Math.max(0,o.minEscalatedTurns??xg)}}function lp(o){let e=o?.preset??"full",t=_g(e),n=o?.expert?.rankPruning,r=n?.enabled??(n?.minRank!==void 0?!0:t.hindsight),s=o?.state?.summary??t.stateSummary,i=o?.state?.inspect??t.inspect,a=o?.checkpoints?.enabled??t.checkpointsEnabled;if(a&&!s&&!i)throw new Error("contextPolicy.checkpoints requires either state.summary or state.inspect to be enabled");return{preset:e,summarizerOptions:o?.summarizerOptions,pruneUsedDocs:o?.pruneUsedDocs??t.pruneUsedDocs,actionReplay:o?.expert?.replay??t.actionReplay,recentFullActions:Math.max(o?.expert?.recentFullActions??t.recentFullActions,0),errorPruning:o?.pruneErrors??t.errorPruning,hindsightEvaluation:r,pruneRank:n?.minRank??t.pruneRank,rankPruneGraceTurns:cg,tombstoning:o?.expert?.tombstones,stateSummary:{enabled:s,maxEntries:o?.state?.maxEntries??t.maxEntries,maxChars:o?.state?.maxChars??t.maxStateChars},stateInspection:{enabled:i,contextThreshold:o?.state?.inspectThresholdChars??t.inspectThreshold},checkpoints:{enabled:a,triggerChars:o?.checkpoints?.triggerChars??t.checkpointTriggerChars}}}function _g(o){switch(o){case"adaptive":return{actionReplay:"adaptive",recentFullActions:3,errorPruning:!0,hindsight:!1,pruneRank:2,pruneUsedDocs:!1,stateSummary:!0,inspect:!0,inspectThreshold:1e4,maxEntries:8,maxStateChars:1600,checkpointsEnabled:!0,checkpointTriggerChars:16e3};case"lean":return{actionReplay:"minimal",recentFullActions:1,errorPruning:!0,hindsight:!1,pruneRank:2,pruneUsedDocs:!0,stateSummary:!0,inspect:!0,inspectThreshold:6e3,maxEntries:4,maxStateChars:800,checkpointsEnabled:!0,checkpointTriggerChars:9e3};case"checkpointed":return{actionReplay:"checkpointed",recentFullActions:3,errorPruning:!1,hindsight:!1,pruneRank:2,pruneUsedDocs:!1,stateSummary:!0,inspect:!0,inspectThreshold:1e4,maxEntries:8,maxStateChars:1600,checkpointsEnabled:!0,checkpointTriggerChars:12e3};default:return{actionReplay:"full",recentFullActions:1,errorPruning:!1,hindsight:!1,pruneRank:2,pruneUsedDocs:!1,stateSummary:!1,inspect:!1,inspectThreshold:void 0,maxEntries:void 0,maxStateChars:void 0,checkpointsEnabled:!1,checkpointTriggerChars:void 0}}}function xp(o){let e=Ft(o),t=new Set,n=/\b([a-zA-Z_$][a-zA-Z0-9_$]*)\.([a-zA-Z_$][a-zA-Z0-9_$]*)\s*\(/g,r=n.exec(e);for(;r;){let s=r[1],i=r[2];s&&i&&!yg.has(s)&&t.add(`${s}.${i}`),r=n.exec(e)}return[...t]}function Ng(o){return o.tags.includes("error")||!/\b(listModuleFunctions|getFunctionDefinitions)\s*\(/.test(o.code)?!1:xp(o.code).length===0}function Lg(o,e){return o.slice(-e.recentErrorWindowTurns).filter(r=>r.tags.includes("error")).length>=e.recentErrorThreshold}function $g(o,e){if(o.length<e.discoveryStallTurns)return!1;let t=0;for(let n=o.length-1;n>=0;n--){let r=o[n];if(!r||r.tags.includes("error")||xp(r.code).length>0||!Ng(r))break;if(t+=1,t>=e.discoveryStallTurns)return!0}return!1}function Dg(o,e,t,n){return{promptFacingChars:t,checkpointActive:n,recentErrorTrigger:Lg(e,o),discoveryStallTrigger:$g(e,o)}}function Ug(o,e,t){let n=t.checkpointActive?e.escalateAtPromptCharsWhenCheckpointed:e.escalateAtPromptChars,s=t.promptFacingChars>=n||t.recentErrorTrigger||t.discoveryStallTrigger,i=o?{...o}:{escalated:!1,escalatedTurns:0,stableBelowThresholdTurns:0};if(!i.escalated)return s?{escalated:!0,escalatedTurns:1,stableBelowThresholdTurns:0}:(i.escalatedTurns=0,i.stableBelowThresholdTurns=0,i);if(s)return{escalated:!0,escalatedTurns:i.escalatedTurns+1,stableBelowThresholdTurns:0};if(!(t.promptFacingChars<e.deescalateBelowPromptChars&&!t.recentErrorTrigger&&!t.discoveryStallTrigger&&i.escalatedTurns>=e.minEscalatedTurns))return{escalated:!0,escalatedTurns:i.escalatedTurns+1,stableBelowThresholdTurns:0};let l=i.stableBelowThresholdTurns+1;return l>=e.stableTurnsBeforeDeescalate?{escalated:!1,escalatedTurns:0,stableBelowThresholdTurns:0}:{escalated:!0,escalatedTurns:i.escalatedTurns+1,stableBelowThresholdTurns:l}}function Gg(){let o=new Map,e={nextNodeOrdinal:1,nodesById:o,rootNode:void 0,createNode:({parentId:t,depth:n,role:r,taskDigest:s,contextDigest:i})=>{let a=`trace_${e.nextNodeOrdinal++}`,l={nodeId:a,parentId:t,depth:n,role:r,taskDigest:s,contextDigest:i,completionType:void 0,turnCount:0,actorTurns:[],functionCalls:[],toolErrors:[],localUsage:{promptTokens:0,completionTokens:0,totalTokens:0},children:[]};return o.set(a,l),t?o.get(t)?.children.push(l):e.rootNode=l,l}};return e}function _a(o){let e=o.children.map(r=>_a(r)),t=o.localUsage,n=e.reduce((r,s)=>({promptTokens:r.promptTokens+s.cumulativeUsage.promptTokens,completionTokens:r.completionTokens+s.cumulativeUsage.completionTokens,totalTokens:r.totalTokens+s.cumulativeUsage.totalTokens}),{...t});return{nodeId:o.nodeId,parentId:o.parentId,depth:o.depth,role:o.role,taskDigest:o.taskDigest,contextDigest:o.contextDigest,completionType:o.completionType,turnCount:o.turnCount,childCount:e.length,actorTurns:[...o.actorTurns],functionCalls:[...o.functionCalls],toolErrors:[...o.toolErrors],localUsage:{...t},cumulativeUsage:n,children:e}}var ro=class o{ai;judgeAI;program;actorProgram;responderProgram;agents;agentFunctions;agentFunctionModuleMetadata=new Map;debug;options;rlmConfig;runtime;actorFieldNames;localFieldNames;sharedFieldNames;globalSharedFieldNames;excludedSharedFields;excludedAgents;excludedAgentFunctions;actorDescription;actorPromptLevel;actorModelPolicy;responderDescription;judgeOptions;recursionForwardOptions;actorForwardOptions;responderForwardOptions;inputUpdateCallback;contextPromptConfigByField=new Map;agentModuleNamespace=js;functionDiscoveryEnabled=!1;runtimeUsageInstructions="";enforceIncrementalConsoleTurns=!1;activeAbortControllers=new Set;_stopRequested=!1;state;stateError;runtimeBootstrapContext=void 0;llmQueryBudgetState;recursiveInstructionSlots=ir();baseActorDefinition="";recursiveEvalContext;currentRecursiveTraceNodeId;recursiveInstructionRoleOverride;func;_parentSharedFields=new Set;_parentSharedAgents=new Set;_parentSharedAgentFunctions=new Set;_reservedAgentFunctionNamespaces(){return new Set(["inputs","llmQuery","final","ask_clarification","inspect_runtime",js,this.agentModuleNamespace,...this.functionDiscoveryEnabled?[Ma,Pa]:[]])}_mergeAgentFunctionModuleMetadata(e){let t=!1;for(let n of e){let r=this.agentFunctionModuleMetadata.get(n.namespace);if(!r){this.agentFunctionModuleMetadata.set(n.namespace,n),t=!0;continue}if(r.title!==n.title||r.selectionCriteria!==n.selectionCriteria||r.description!==n.description)throw new Error(`Conflicting agent function group metadata for namespace "${n.namespace}"`)}return t}_validateConfiguredSignature(e){if(e.getDescription())throw new Error("AxAgent does not support signature-level descriptions. Use setActorDescription() and/or setResponderDescription() to customize the actor and responder prompts independently.");let t=new Set(e.getInputFields().map(r=>r.name)),n=new Set(e.getOutputFields().map(r=>r.name));for(let r of this.rlmConfig.contextFields)if(!t.has(r))throw new Error(`RLM contextField "${r}" not found in signature`);for(let r of this.sharedFieldNames)if(!t.has(r))throw new Error(`sharedField "${r}" not found in signature input fields`);for(let r of this.globalSharedFieldNames)if(!t.has(r))throw new Error(`globalSharedField "${r}" not found in signature input fields`);for(let r of this.actorFieldNames)if(!n.has(r))throw new Error(`RLM actorField "${r}" not found in output signature`)}_validateAgentFunctionNamespaces(e){let t=this._reservedAgentFunctionNamespaces();for(let n of e){let r=n.namespace??"utils";if(t.has(r))throw new Error(`Agent function namespace "${r}" conflicts with an AxAgent runtime global and is reserved`)}}_supportsRecursiveActorSlotOptimization(){if((this.rlmConfig.mode??"simple")!=="advanced")return!1;let e=this.recursionForwardOptions?.maxDepth??Bs;return!!this.recursiveInstructionRoleOverride||Math.max(0,e)>0}_getRecursiveActorRole(){if((this.rlmConfig.mode??"simple")!=="advanced")return;if(this.recursiveInstructionRoleOverride)return this.recursiveInstructionRoleOverride;let e=this.recursionForwardOptions?.maxDepth??Bs;return Math.max(0,e)>0?"root":void 0}_applyRecursiveActorInstruction(){let e=this._getRecursiveActorRole();if(!e||!this.actorProgram)return;let t=tp(e,this.recursiveInstructionSlots),n=[this.baseActorDefinition.trim(),t?.trim()].filter(r=>!!r).join(`
1369
-
1370
- `);this.actorProgram.setDescription(n),this.actorProgram.setInstruction(n)}_setRecursiveInstructionSlot(e,t){if(e===ce.responder){this.responderProgram.setInstruction(t??"");return}this.recursiveInstructionSlots[e]=t??"",this._applyRecursiveActorInstruction()}_copyRecursiveOptimizationStateTo(e){e.recursiveInstructionSlots={...this.recursiveInstructionSlots},e.recursiveInstructionRoleOverride=e._supportsRecursiveActorSlotOptimization()?e.recursiveInstructionRoleOverride:void 0,e._applyRecursiveActorInstruction()}constructor({ai:e,judgeAI:t,agentIdentity:n,agentModuleNamespace:r,signature:s},i){let{debug:a,contextFields:l,runtime:c,maxSubAgentCalls:u,maxRuntimeChars:p,maxBatchedLlmQueryConcurrency:d,maxTurns:m,contextPolicy:g,actorFields:f,actorTurnCallback:x,mode:A,promptLevel:h,actorModelPolicy:b,recursionOptions:T,actorOptions:C,responderOptions:v,judgeOptions:k,inputUpdateCallback:R}=i;this.ai=e,this.judgeAI=t,this.agents=i.agents?.local,this.functionDiscoveryEnabled=i.functions?.discovery??!1,this.debug=a,this.options=i,this.runtime=c??new ln,this.runtimeUsageInstructions=this.runtime.getUsageInstructions(),this.enforceIncrementalConsoleTurns=Af(this.runtimeUsageInstructions);let E=r??n?.namespace??js;if(this.agentModuleNamespace=If(E,{normalize:r===void 0}),new Set(["inputs","llmQuery","final","ask_clarification","inspect_runtime",Ma,Pa]).has(this.agentModuleNamespace))throw new Error(`Agent module namespace "${this.agentModuleNamespace}" is reserved`);let _=this._reservedAgentFunctionNamespaces(),L=Fa(i.functions?.local,_),P=Fa(i.functions?.shared,_),F=Fa(i.functions?.globallyShared,_);this.agentFunctions=L.functions,this._mergeAgentFunctionModuleMetadata(L.moduleMetadata);let{agents:N,fields:U,functions:G,judgeOptions:B,inputUpdateCallback:te,promptLevel:j,actorModelPolicy:V,...xe}=i;this.program=new ke(s,xe);let ve=this.program.getSignature().getInputFields(),$=ff(l,ve,lg);this.contextPromptConfigByField=$.promptConfigByField,this.rlmConfig={contextFields:$.contextFieldNames,sharedFields:i.fields?.shared,runtime:this.runtime,maxSubAgentCalls:u,maxRuntimeChars:p,maxBatchedLlmQueryConcurrency:d,maxTurns:m,contextPolicy:g,actorFields:f,actorTurnCallback:x,mode:A},this.recursionForwardOptions=T;let{description:K,...ne}=C??{},{description:pe,...X}=v??{};this.actorDescription=K,this.actorPromptLevel=h??"detailed",this.actorModelPolicy=Fg(b),this.actorForwardOptions=ne,this.recursiveInstructionSlots=ir(K),this.responderDescription=pe,this.responderForwardOptions=X,this.judgeOptions=k?{...k}:void 0,this.inputUpdateCallback=R;let z=this.agents;for(let oe of z??[]){let ge=oe.getFunction().name;this.program.register(oe,ge)}n&&(this.func={name:Ip(n.name),description:n.description,parameters:this._buildFuncParameters(),func:async()=>{throw new Error("Use getFunction() to get a callable wrapper")}});let ie=f??[];this.actorFieldNames=ie;let Oe=i.fields?.shared??[];this.sharedFieldNames=Oe,this.excludedSharedFields=i.fields?.excluded??[];let Ee=i.fields?.globallyShared??[];this.globalSharedFieldNames=Ee,this.localFieldNames=i.fields?.local??[];let se=i.agents?.shared??[],Fe=i.agents?.globallyShared??[];this.excludedAgents=i.agents?.excluded??[];let ae=P.functions,Ae=F.functions;this.excludedAgentFunctions=i.functions?.excluded??[];let be=[...this.agentFunctions,...ae,...Ae];for(let oe of be){if(!oe.parameters)throw new Error(`Agent function "${oe.name}" must define parameters schema for agent runtime usage.`);if(oe.examples){for(let[ge,Ie]of oe.examples.entries())if(!Ie.code.trim())throw new Error(`Agent function "${oe.name}" example at index ${ge} must define non-empty code`)}}if(this._validateConfiguredSignature(this.program.getSignature()),this._validateAgentFunctionNamespaces(be),Oe.length>0&&z){let oe=ve.filter(ge=>Oe.includes(ge.name));for(let ge of z){if(!(ge instanceof o))continue;let Ie=new Set(ge.getExcludedSharedFields()),je=oe.filter($e=>!Ie.has($e.name));je.length!==0&&ge._extendForSharedFields(je,this.rlmConfig.contextFields)}}if(se.length>0&&z)for(let oe of z)oe instanceof o&&oe._extendForSharedAgents(se);if(Ee.length>0&&z){let oe=ve.filter(ge=>Ee.includes(ge.name));for(let ge of z){if(!(ge instanceof o))continue;let Ie=new Set(ge.getExcludedSharedFields()),je=oe.filter($e=>!Ie.has($e.name));je.length!==0&&ge._extendForGlobalSharedFields(je,this.rlmConfig.contextFields)}}if(Fe.length>0&&z)for(let oe of z)oe instanceof o&&oe._extendForGlobalSharedAgents(Fe);if(ae.length>0&&z)for(let oe of z)oe instanceof o&&oe._extendForSharedAgentFunctions(P);if(Ae.length>0&&z)for(let oe of z)oe instanceof o&&oe._extendForGlobalSharedAgentFunctions(F);this._buildSplitPrograms(),this.program.register(this.actorProgram,"actor"),this.program.register(this.responderProgram,"responder")}_buildSplitPrograms(){let e=this.program.getSignature().getInputFields(),t=this.rlmConfig.contextFields,n=this._getBypassedSharedFieldNames(),r=e.filter(R=>t.includes(R.name)),s=r.filter(R=>this.contextPromptConfigByField.has(R.name)&&!n.has(R.name)).map(R=>({...R,isOptional:!0})),i=e.filter(R=>!t.includes(R.name)&&!n.has(R.name)),a=this.program.getSignature().getOutputFields(),l=a.filter(R=>this.actorFieldNames.includes(R.name)),c=a.filter(R=>!this.actorFieldNames.includes(R.name)),u=ue().addInputFields(i).addInputFields(s).input("contextMetadata",ue.string("Metadata about pre-loaded context variables (type and size)")).input("actionLog",ue.string("Chronological trace of code executions or actions and their outputs so far")).output("javascriptCode",ue.code("JavaScript code to execute in runtime session"));l.length>0&&(u=u.addOutputFields(l));let p=u.build(),d=ue().addInputFields(i).input("contextData",ue.json("Context data to help synthesize the final answer.")).addOutputFields(c).build(),m=this.rlmConfig.maxSubAgentCalls??rp,g=this.rlmConfig.maxTurns??op,f=this.recursionForwardOptions?.maxDepth??Bs,x=(this.rlmConfig.mode??"simple")==="advanced"?Math.max(0,f)>0?"advanced-recursive":"simple-at-terminal-depth":"simple",A=this.agents?.map(R=>{let E=R.getFunction();return{name:E.name,description:E.description,parameters:E.parameters}})??[],h=this.agentFunctions.map(R=>({name:R.name,description:R.description,parameters:R.parameters,returns:R.returns,namespace:R.namespace??"utils"})),b=new Set(h.map(R=>R.namespace??"utils"));A.length>0&&b.add(this.agentModuleNamespace);let T=[...b].sort((R,E)=>R.localeCompare(E)).map(R=>({namespace:R,selectionCriteria:this.agentFunctionModuleMetadata.get(R)?.selectionCriteria})),C=lp(this.rlmConfig.contextPolicy),v=$s(this._supportsRecursiveActorSlotOptimization()?void 0:this.actorDescription,r,c,{runtimeUsageInstructions:this.runtimeUsageInstructions,promptLevel:this.actorPromptLevel,maxSubAgentCalls:m,maxTurns:g,hasInspectRuntime:C.stateInspection.enabled,hasLiveRuntimeState:C.stateSummary.enabled,hasCompressedActionReplay:C.actionReplay!=="full"||C.checkpoints.enabled||C.errorPruning||!!C.tombstoning||this.functionDiscoveryEnabled&&C.pruneUsedDocs,llmQueryPromptMode:x,enforceIncrementalConsoleTurns:this.enforceIncrementalConsoleTurns,agentModuleNamespace:this.agentModuleNamespace,discoveryMode:this.functionDiscoveryEnabled,availableModules:T,agents:A,agentFunctions:h});this.baseActorDefinition=v;let k=Ds(this.responderDescription,r);this.actorProgram?(this.actorProgram.setSignature(p),this.actorProgram.setDescription(v)):this.actorProgram=new ke(p,{...this._genOptions,description:v}),this.responderProgram?(this.responderProgram.setSignature(d),this.responderProgram.setDescription(k)):this.responderProgram=new ke(d,{...this._genOptions,description:k}),this._applyRecursiveActorInstruction()}_extendForSharedFields(e,t){let n=this.program.getSignature(),r=n.getInputFields(),s=!1;for(let i of e){if(r.some(a=>a.name===i.name)){if(this._parentSharedFields.has(i.name))throw new Error(`Duplicate shared field "${i.name}" \u2014 already propagated from a parent`);continue}this._parentSharedFields.add(i.name),n.addInputField(i),s=!0}s&&this.program.setSignature(n);for(let i of e)t.includes(i.name)&&!this.rlmConfig.contextFields.includes(i.name)&&this.rlmConfig.contextFields.push(i.name);this._buildSplitPrograms(),this.func&&(this.func.parameters=this._buildFuncParameters())}_extendForSharedAgents(e){if(e.length===0)return;let t=new Set((this.agents??[]).map(s=>s.getFunction().name)),n=new Set(this.excludedAgents),r=[];for(let s of e){if(s===this)continue;let i=s.getFunction().name;if(!n.has(i)){if(t.has(i)){if(this._parentSharedAgents.has(i))throw new Error(`Duplicate shared agent "${i}" \u2014 already propagated from a parent`);continue}this._parentSharedAgents.add(i),t.add(i),r.push(s)}}if(r.length!==0){this.agents=[...this.agents??[],...r];for(let s of r){let i=s.getFunction().name;this.program.register(s,i)}this._buildSplitPrograms()}}_extendForGlobalSharedFields(e,t){let n=this.program.getSignature(),r=n.getInputFields(),s=!1;for(let i of e){if(r.some(a=>a.name===i.name)){if(this._parentSharedFields.has(i.name))throw new Error(`Duplicate shared field "${i.name}" \u2014 already propagated from a parent`);continue}this._parentSharedFields.add(i.name),n.addInputField(i),s=!0}s&&this.program.setSignature(n);for(let i of e)t.includes(i.name)&&!this.rlmConfig.contextFields.includes(i.name)&&this.rlmConfig.contextFields.push(i.name);for(let i of e)this.sharedFieldNames.includes(i.name)||this.sharedFieldNames.push(i.name);if(this._buildSplitPrograms(),this.func&&(this.func.parameters=this._buildFuncParameters()),this.agents)for(let i of this.agents){if(!(i instanceof o))continue;let a=new Set(i.getExcludedSharedFields()),l=e.filter(c=>!a.has(c.name));l.length!==0&&i._extendForGlobalSharedFields(l,t)}}_extendForGlobalSharedAgents(e){let t=this.agents?this.agents.filter(n=>n instanceof o):[];this._extendForSharedAgents(e);for(let n of t)n._extendForGlobalSharedAgents(e)}_extendForSharedAgentFunctions(e){if(e.functions.length===0&&e.moduleMetadata.length===0)return;let t=new Set(this.agentFunctions.map(i=>`${i.namespace??"utils"}.${i.name}`)),n=new Set(this.excludedAgentFunctions),r=[],s=this._mergeAgentFunctionModuleMetadata(e.moduleMetadata);for(let i of e.functions){if(n.has(i.name))continue;let a=`${i.namespace??"utils"}.${i.name}`;if(t.has(a)){if(this._parentSharedAgentFunctions.has(a))throw new Error(`Duplicate shared agent function "${a}" \u2014 already propagated from a parent`);continue}this._parentSharedAgentFunctions.add(a),t.add(a),r.push(i)}r.length===0&&!s||(r.length>0&&(this.agentFunctions=[...this.agentFunctions,...r]),this._buildSplitPrograms())}_extendForGlobalSharedAgentFunctions(e){let t=this.agents?this.agents.filter(n=>n instanceof o):[];this._extendForSharedAgentFunctions(e);for(let n of t)n._extendForGlobalSharedAgentFunctions(e)}stop(){this._stopRequested=!0;for(let e of this.activeAbortControllers)e.abort("Stopped by user");this.program.stop(),this.actorProgram.stop(),this.responderProgram.stop()}getId(){return this.program.getId()}setId(e){this.program.setId(e)}namedPrograms(){return this.program.namedPrograms()}namedProgramInstances(){return this.program.namedProgramInstances()}getTraces(){return this.program.getTraces()}setDemos(e,t){this.program.setDemos(e,t)}getUsage(){return this.program.getUsage()}resetUsage(){this.program.resetUsage()}getState(){if(this.stateError)throw new Error(this.stateError);return this.state?ar(this.state):void 0}setState(e){if(e&&e.version!==1)throw new Error(`Unsupported AxAgentState version "${String(e.version)}"`);if(e){let t=this.runtime.createSession();try{if(typeof t.patchGlobals!="function")throw new Error("AxCodeSession.patchGlobals() is required to restore AxAgent state")}finally{try{t.close()}catch{}}}this.state=e?ar(e):void 0,this.stateError=void 0}_createRecursiveOptimizationProxy(e,t){return{id:e,signature:t,program:{getId:()=>e,setId:()=>{},getTraces:()=>[],setDemos:()=>{},applyOptimization:n=>{this.applyOptimization(n)},getInstruction:()=>e===ce.responder?this.responderProgram.getInstruction():this.recursiveInstructionSlots[e],setInstruction:n=>{this._setRecursiveInstructionSlot(e,n)},getSignature:()=>({getDescription:()=>t})}}}_listOptimizationTargetDescriptors(){return this._supportsRecursiveActorSlotOptimization()?[this._createRecursiveOptimizationProxy(ce.shared,"Shared recursive-actor guidance applied to every advanced recursive AxAgent actor invocation."),this._createRecursiveOptimizationProxy(ce.root,"Root-only recursive-actor guidance for deciding whether to answer directly or decompose into subtasks."),this._createRecursiveOptimizationProxy(ce.recursive,"Mid-tree recursive-actor guidance for branch orchestration, selective delegation, and efficient synthesis."),this._createRecursiveOptimizationProxy(ce.terminal,"Terminal-depth recursive-actor guidance for direct answers when deeper recursion is no longer available."),{id:ce.responder,signature:this.responderProgram.getSignature().toString(),program:this.responderProgram}]:this.namedProgramInstances().map(e=>({id:e.id,signature:e.signature,program:e.program}))}_beginRecursiveTraceCapture(e){let t=Us(this.getUsage()),n=this._getRecursiveActorRole();if(!this.recursiveEvalContext||!n)return{node:void 0,usageBefore:t};let r=this.recursiveEvalContext.collector.createNode({parentId:this.recursiveEvalContext.parentNodeId,depth:this.recursiveEvalContext.depth,role:n,taskDigest:Nt(Array.isArray(e)?e.filter(s=>s.role==="user").map(s=>s.values):e),contextDigest:Nt(this.runtimeBootstrapContext)});return this.currentRecursiveTraceNodeId=r.nodeId,{node:r,usageBefore:t}}_finalizeRecursiveTraceCapture(e,t,n,r,s){if(!e){this.currentRecursiveTraceNodeId=void 0;return}let i=Us(this.getUsage());e.localUsage=eo(e.localUsage,Xu(i,t)),e.turnCount=n.length,e.completionType=s.type,e.actorTurns=[...n],e.functionCalls=r.map(a=>({qualifiedName:a.qualifiedName,name:a.name,error:a.error})),e.toolErrors=r.filter(a=>!!a.error).map(a=>`${a.qualifiedName}: ${a.error??"unknown error"}`),this.currentRecursiveTraceNodeId=void 0}_recordEphemeralRecursiveUsage(e){if(!this.recursiveEvalContext||!this.currentRecursiveTraceNodeId||e.totalTokens<=0)return;let t=this.recursiveEvalContext.collector.nodesById.get(this.currentRecursiveTraceNodeId);t&&(t.localUsage=eo(t.localUsage,e))}async optimize(e,t){let n=Rg(e);if(n.train.length===0)throw new Error("AxAgent.optimize(): at least one training task is required.");let r=t?.studentAI??this.ai;if(!r)throw new Error("AxAgent.optimize(): studentAI is required when the agent has no default ai.");let s=t?.judgeAI??this.judgeAI??t?.teacherAI??this.ai??r,i={...this.judgeOptions??{},...t?.judgeOptions??{}},a=this._listOptimizationTargetDescriptors(),l=Mg(a,t?.target??"actor"),c=t?.metric??this._createAgentOptimizeMetric(s,i),u=this._createOptimizationProgram(l,a),p=Math.max(1,Math.floor(t?.maxMetricCalls??Math.max(Ag,n.train.length*4))),m=await new Ht({studentAI:r,teacherAI:t?.teacherAI??s,numTrials:t?.numTrials,minibatch:t?.minibatch,minibatchSize:t?.minibatchSize,earlyStoppingTrials:t?.earlyStoppingTrials,minImprovementThreshold:t?.minImprovementThreshold,sampleCount:t?.sampleCount,seed:t?.seed,verbose:t?.verbose,debugOptimizer:t?.debugOptimizer,optimizerLogger:t?.optimizerLogger,onProgress:t?.onProgress,onEarlyStop:t?.onEarlyStop}).compile(u,n.train,c,{validationExamples:n.validation,maxMetricCalls:p,verbose:t?.verbose,feedbackFn:t?.metric?void 0:({prediction:f,example:x,componentId:A})=>ep({componentId:A,prediction:f,example:x})}),g=m.optimizedProgram;return m.optimizedProgram&&this._supportsRecursiveActorSlotOptimization()&&(g=new bt({...m.optimizedProgram,artifactFormatVersion:1,instructionSchema:Zr}),m.optimizedProgram=g),t?.apply!==!1&&g&&this.applyOptimization(g),m}_createOptimizationProgram(e,t){return{getId:()=>this.getId(),setId:n=>this.setId(n),getSignature:()=>wg,forward:async(n,r,s)=>this._forwardForEvaluation(n,r,s),streamingForward:async function*(n,r,s){yield{version:1,index:0,delta:await this.forward(n,r,s)}},getTraces:()=>this.getTraces(),namedProgramInstances:()=>t.filter(n=>e.includes(n.id)),setDemos:(n,r)=>this.setDemos(n,r),applyOptimization:n=>this.applyOptimization(n),getUsage:()=>this.getUsage(),resetUsage:()=>this.resetUsage()}}_createAgentOptimizeMetric(e,t){let n=Sg(t.criteria),r=new ke(Ig),s=t.description?.trim();r.setInstruction(s?`${n}
1371
-
1372
- Additional Judge Guidance:
1373
- ${s}`:n);let i=kg(t);return async({example:a,prediction:l})=>{let c=a,u=l,p={taskInput:lt(c.input),criteria:c.criteria,expectedOutput:c.expectedOutput,expectedActions:c.expectedActions,forbiddenActions:c.forbiddenActions,metadata:c.metadata},d={completionType:u.completionType,clarification:lt(u.clarification),finalOutput:lt(u.output),actionLog:u.actionLog,functionCalls:lt(u.functionCalls),toolErrors:u.toolErrors,turnCount:u.turnCount,usage:lt(u.usage??[]),recursiveTrace:lt(u.recursiveTrace),recursiveStats:lt(u.recursiveStats)},m=await r.forward(e,{...p,...d},i);return Eg(Og(m.quality),c,u)}}async _forwardForEvaluation(e,t,n){let r=this.state?ar(this.state):void 0,s=this.stateError;this.state=void 0,this.stateError=void 0;let i=new AbortController;this._stopRequested&&i.abort("Stopped by user (pre-forward)");let a=vt(i.signal,n?.abortSignal);this.activeAbortControllers.add(i);let l=this._ensureLlmQueryBudgetState(),c=this.recursiveEvalContext,u=this.currentRecursiveTraceNodeId,p=this._supportsRecursiveActorSlotOptimization()?Gg():void 0;this.recursiveEvalContext=p?{collector:p,depth:0}:void 0,this.currentRecursiveTraceNodeId=void 0;try{let d=this.ai??e,m=n?.debug??this.debug??d?.getOptions()?.debug??!1,g=[],f=[],{node:x,usageBefore:A}=this._beginRecursiveTraceCapture(t.input),{nonContextValues:h,actorResult:b,actorFieldValues:T,actionLog:C,turnCount:v}=await this._runActorLoop(d,t.input,n,a,g,f),k=g.filter(P=>!!P.error).map(P=>`${P.qualifiedName}: ${P.error??"unknown error"}`);if(b.type==="ask_clarification"){this._finalizeRecursiveTraceCapture(x,A,f,g,b);let P=p?.rootNode?Gs(_a(p.rootNode)):void 0,F=P?ka(P):void 0,N=P&&F?Oa(P,F):void 0;return{completionType:"ask_clarification",clarification:yp(b.args[0]),actionLog:C,functionCalls:g,toolErrors:k,turnCount:v,recursiveTrace:P,recursiveStats:F,recursiveSummary:N}}let R={...this._genOptions,...this.responderForwardOptions,...n,debug:m,abortSignal:a,maxSteps:1},E=await this.responderProgram.forward(d,{...h,contextData:b},R);this._finalizeRecursiveTraceCapture(x,A,f,g,b);let S=p?.rootNode?Gs(_a(p.rootNode)):void 0,_=S?ka(S):void 0,L=S&&_?Oa(S,_):void 0;return{completionType:"final",output:{...E,...T},actionLog:C,functionCalls:g,toolErrors:k,turnCount:v,recursiveTrace:S,recursiveStats:_,recursiveSummary:L}}finally{this.state=r?ar(r):void 0,this.stateError=s,this.recursiveEvalContext=c,this.currentRecursiveTraceNodeId=u,l&&(this.llmQueryBudgetState=void 0),this.activeAbortControllers.delete(i),this._stopRequested=!1}}getFunction(){if(!this.func)throw new Error("getFunction() requires agentIdentity to be set in the constructor");let e=this.forward.bind(this);return{...this.func,func:async(r,s)=>{let i=this.ai??s?.ai;if(!i)throw new Error("AI service is required to run the agent");let a=await e(i,r,s),c=this.program.getSignature().getOutputFields();return Object.keys(a).map(p=>{let d=c.find(m=>m.name===p);return d?`${d.title}: ${a[p]}`:`${p}: ${a[p]}`}).join(`
1374
- `)}}}getExcludedSharedFields(){return this.excludedSharedFields}_getBypassedSharedFieldNames(){let e=new Set([...this.sharedFieldNames,...this.globalSharedFieldNames]);for(let t of this.localFieldNames)e.delete(t);return e}_createRuntimeInputState(e,t){let n;Array.isArray(e)?n=e.filter(x=>x.role==="user").reduce((x,A)=>({...x,...A.values}),{}):n=e;let r=t?.allowedFieldNames?new Set(t.allowedFieldNames):void 0;if(r&&t?.validateInputKeys){for(let x of Object.keys(n))if(!r.has(x))throw new Error(`AxAgent.test() only accepts context field values. "${x}" is not configured in contextFields.`)}let s={...n},i=r?new Set(r):new Set(this.program.getSignature().getInputFields().map(x=>x.name)),a=[...this.sharedFieldNames,...this.globalSharedFieldNames],l=this._getBypassedSharedFieldNames(),c={},u={},p={},d={},m="(none)",g=new Set(this.program.getSignature().getInputFields().filter(x=>this.rlmConfig.contextFields.includes(x.name)&&x.isOptional).map(x=>x.name));return{currentInputs:s,signatureInputFieldNames:i,sharedFieldValues:c,recomputeTurnInputs:x=>{let A={},h={};for(let[T,C]of Object.entries(s))this.rlmConfig.contextFields.includes(T)?A[T]=C:l.has(T)||(h[T]=C);if(x){for(let T of this.rlmConfig.contextFields)if(!g.has(T)&&(!(T in A)||A[T]===void 0))throw new Error(`RLM contextField "${T}" is missing from input values`)}let b={};for(let[T,C]of this.contextPromptConfigByField){if(l.has(T)||!(T in A))continue;let v=df(A[T],C);v!==void 0&&(b[T]=v)}u=A,p=h,d=b;for(let T of Object.keys(c))delete c[T];for(let T of a)T in s&&(c[T]=s[T]),T in u&&(c[T]=u[T]);m=hf(u,{promptConfigByField:this.contextPromptConfigByField,inlinedFields:new Set(Object.keys(d))})||"(none)"},getNonContextValues:()=>p,getActorInlineContextValues:()=>d,getContextMetadata:()=>m}}_ensureLlmQueryBudgetState(){return this.llmQueryBudgetState?!1:(this.llmQueryBudgetState={used:0},!0)}_createRuntimeExecutionContext({ai:e,inputState:t,options:n,effectiveAbortSignal:r,debug:s,completionState:i,completionBindings:a,actionLogEntries:l,functionCallRecorder:c}){let u=this.rlmConfig,p=this.runtime,d=u.maxSubAgentCalls??rp,m=u.maxRuntimeChars??Ea,g=Math.max(1,u.maxBatchedLlmQueryConcurrency??ag),f=this.recursionForwardOptions?.maxDepth??Bs,x=Math.max(0,f),A=lp(u.contextPolicy),h=this.llmQueryBudgetState??{used:0},b=new Set,T=Math.floor(d*.8),{maxDepth:C,...v}=this.recursionForwardOptions??{},{description:k,mem:R,sessionId:E,...S}=n??{},_={...this.recursionForwardOptions??{},maxDepth:Math.max(0,x-1)},L=ue().input("task",ue.string("Task for recursive analysis")).output("answer",ue.string("Answer from recursive analysis")).build(),P=ue().input("task",ue.string("Task for recursive analysis")).input("context",ue.json("Optional context for the recursive task")).output("answer",ue.string("Answer from recursive analysis")).build(),N=(u.mode??"simple")==="advanced"&&x>0,U=this.recursionForwardOptions?.promptLevel??this.actorPromptLevel,G=()=>(()=>{let M=new o({agentModuleNamespace:this.agentModuleNamespace,signature:L},{debug:s,...u,agents:{local:this.agents},functions:{local:this.agentFunctions,discovery:this.functionDiscoveryEnabled},contextFields:[],actorFields:void 0,promptLevel:U,actorModelPolicy:this.options?.actorModelPolicy,recursionOptions:_,actorOptions:{...this.actorForwardOptions},responderOptions:this.responderForwardOptions});return M.recursiveInstructionRoleOverride=_.maxDepth&&_.maxDepth>0?"recursive":"terminal",this._copyRecursiveOptimizationStateTo(M),M})(),B=M=>(M.llmQueryBudgetState=h,this.recursiveEvalContext&&(M.recursiveEvalContext={collector:this.recursiveEvalContext.collector,parentNodeId:this.currentRecursiveTraceNodeId,depth:this.recursiveEvalContext.depth+1}),M),te=()=>{for(let M of[...b])M.stop()},j=()=>new ke(P,_),V=async(M,q)=>{if(!Array.isArray(M)&&typeof M=="object"&&M!==null&&"query"in M)return V(M.query,M.context??q);if(r?.aborted)throw new Pe("rlm-llm-query",r.reason?String(r.reason):"Aborted");if(!e)throw new Error(Cg);let ee=M,Z=ye=>{if(ye==null)return"";if(typeof ye=="string")return ut(ye,m);try{return ut(JSON.stringify(ye),m)}catch{return ut(String(ye),m)}},Te=async(ye,qe,_e=r)=>{if(_e?.aborted)throw new Pe("rlm-llm-query",_e.reason?String(_e.reason):"Aborted");let nt=qe===void 0?void 0:typeof qe=="string"?ut(qe,m):qe;if(h.used>=d)return`[ERROR] Sub-query budget exhausted (${d}/${d}). Complete the task using data already gathered or handle remaining work directly in JS.`;h.used++;let Y=3,J,fe=Re=>`[ERROR] ${Re instanceof Error?Re.message:String(Re)}. Retry with a simpler query, handle in JS, or proceed with data already gathered.`;for(let Re=0;Re<Y;Re++)try{if(!N){let Ve=j(),Wt=await Ve.forward(e,{task:ye,...nt!==void 0?{context:nt}:{}},{...S,...v,abortSignal:_e,debug:s});return this._recordEphemeralRecursiveUsage(Us(Ve.getUsage())),Z(Wt.answer)}let Me=await(()=>{let Ve=B(G());return b.add(Ve),Ve.runtimeBootstrapContext=nt,Ve.forward(e,{task:ye},{...S,...v,abortSignal:_e,debug:s}).finally(()=>{b.delete(Ve)})})();return Z(Me.answer)}catch(Me){if(Me instanceof Pe||Me instanceof ct)throw Me;if(J=Me,!rf(Me)||Re>=Y-1)return fe(Me);let Ve=Math.min(6e4,1e3*Math.pow(2,Re));await new Promise((Wt,Ks)=>{let Vt=!1,Jt,so=()=>{_e&&Jt&&_e.removeEventListener("abort",Jt)},Ce=setTimeout(()=>{Vt||(Vt=!0,so(),Wt())},Ve);if(_e){if(Jt=()=>{Vt||(Vt=!0,clearTimeout(Ce),so(),Ks(new Pe("rlm-llm-query-retry-backoff",_e.reason?String(_e.reason):"Aborted during retry backoff")))},_e.aborted){Jt();return}_e.addEventListener("abort",Jt,{once:!0})}})}return fe(J)};if(Array.isArray(M)){let ye=new AbortController,qe=vt(r,ye.signal)??ye.signal,_e,nt=()=>{te()};qe.addEventListener("abort",nt,{once:!0});try{return await xf(M,g,async Y=>{try{return await Te(Y.query,Y.context,qe)}catch(J){if(J instanceof Pe||J instanceof ct)throw(J instanceof ct||!_e)&&(_e=J),ye.signal.aborted||ye.abort(J instanceof ct?"Child clarification":J.message),_e;return`[ERROR] ${J instanceof Error?J.message:String(J)}`}},qe)}finally{qe.removeEventListener("abort",nt)}}let Ue=await Te(ee,q);return h.used===T?`${Ue}
1375
- [WARNING] ${h.used}/${d} sub-queries used (${d-h.used} remaining). Consolidate remaining work.`:Ue},xe=this.buildRuntimeGlobals(r,t.sharedFieldValues,e,a.protocol,c),ve=[...new Set(this.agentFunctions.map(M=>M.namespace??"utils"))],$={...t.currentInputs},K=new Set(["inputs","llmQuery",js,this.agentModuleNamespace,"final","ask_clarification",...ve,...A.stateInspection.enabled?["inspect_runtime"]:[],...Object.keys(xe)]),ne=[...new Set([...Object.keys($),...t.signatureInputFieldNames])].filter(M=>!K.has(M)),pe={};for(let M of ne)pe[M]=$[M];let X=()=>{for(let M of Object.keys($))delete $[M];for(let[M,q]of Object.entries(t.currentInputs))$[M]=q;for(let M of ne)pe[M]=t.currentInputs[M]},z=[...K],ie=[...K,...ne],Oe=new Set(ie),Ee=this.runtimeBootstrapContext;this.runtimeBootstrapContext=void 0;let se=qg(Ee,Oe),Fe=new Set(Object.keys(se)),ae=l??[],Ae,be,oe=M=>typeof M.inspectGlobals=="function"?M:void 0,ge=async()=>{try{let M=await Ae.execute(Ju(),{signal:r,reservedNames:ie});if(typeof M!="string")return[];let q=JSON.parse(M);return Array.isArray(q)?q.filter(ee=>typeof ee=="string"&&!Fe.has(ee)):[]}catch{return[]}},Ie=async()=>(be||(be=await ge()),be),je=async()=>{try{let M=oe(Ae);if(M?.inspectGlobals)return await M.inspectGlobals({signal:r,reservedNames:ie});let q=await Ie(),ee=Vu(ie,q),Z=await Ae.execute(ee,{signal:r,reservedNames:ie});return typeof Z=="string"?Z:String(Z)}catch(M){return`[inspect_runtime error: ${M instanceof Error?M.message:String(M)}]`}},$e=(M,q)=>{let ee=sf(M);if(!ee)return af(M,q);let Z=Ns(ae);return Na(ee,Z,q)},it=A.stateInspection.enabled?async()=>$e(await je()):void 0,Se=()=>(be=void 0,p.createSession({...pe,inputs:$,...se,llmQuery:V,final:a.finalFunction,ask_clarification:a.askClarificationFunction,...it?{inspect_runtime:it}:{},...xe}));Ae=Se();let ze=()=>({maxEntries:A.stateSummary.maxEntries&&A.stateSummary.maxEntries>0?A.stateSummary.maxEntries:8,maxChars:A.stateSummary.maxChars&&A.stateSummary.maxChars>0?A.stateSummary.maxChars:void 0}),le=()=>({maxEntries:A.stateSummary.maxEntries&&A.stateSummary.maxEntries>0?A.stateSummary.maxEntries:6,maxChars:A.stateSummary.maxChars&&A.stateSummary.maxChars>0?A.stateSummary.maxChars:Math.min(m,1200)}),De=Object.keys(se).length>0?Qg(se,{...le(),budgetRemaining:Math.max(0,d-h.used),budgetTotal:d}):void 0,We=async()=>{if(!i.payload)for(let M=0;M<3&&!i.payload;M++)await new Promise(q=>{setTimeout(q,0)})},Ye=async()=>{if(!A.stateSummary.enabled)return;let M=await je();return $e(M,ze())||"(no user variables)"},at=M=>{if(typeof M.patchGlobals!="function")throw new Error("AxCodeSession.patchGlobals() is required when restoring AxAgent state or using inputUpdateCallback");return M},y=M=>{if(typeof M.snapshotGlobals!="function")throw new Error("AxCodeSession.snapshotGlobals() is required to export AxAgent state");return M},w=M=>{let q=new Set(ie),ee={};for(let[Te,Ue]of Object.entries(M.runtimeBindings??{}))q.has(Te)||(ee[Te]=Ue);let Z=(M.runtimeEntries??[]).filter(Te=>!q.has(Te.name));return{runtimeBindings:ee,runtimeEntries:Z,actionLogEntries:Xg(M.actionLogEntries),checkpointState:M.checkpointState,provenance:{...M.provenance??{}},actorModelState:M.actorModelState?{escalated:M.actorModelState.escalated,escalatedTurns:M.actorModelState.escalatedTurns,stableBelowThresholdTurns:M.actorModelState.stableBelowThresholdTurns}:void 0}};return{effectiveContextConfig:A,bootstrapContextSummary:De,applyBootstrapRuntimeContext:async()=>{if(Object.keys(se).length===0||!A.stateSummary.enabled)return;let M=await je();return $e(M,ze())||"(no user variables)"},captureRuntimeStateSummary:Ye,exportRuntimeState:async()=>{let q=await y(Ae).snapshotGlobals({signal:r,reservedNames:ie}),ee=Ns(ae);return{version:1,runtimeBindings:q.bindings,runtimeEntries:q.entries,actionLogEntries:Yg(ae),provenance:Zg(ee)}},restoreRuntimeState:async M=>{let q=w(M);return await at(Ae).patchGlobals(q.runtimeBindings,{signal:r}),q},syncRuntimeInputsToSession:async()=>{X();let M=async q=>{await at(q).patchGlobals({inputs:{...$},...pe},{signal:r})};try{await M(Ae)}catch(q){if(r?.aborted)throw new Pe("rlm-session",r.reason??"Aborted");if(q instanceof Error&&(q.name==="AbortError"||q.message.startsWith("Aborted")))throw q;if(gp(q)){Ae=Se(),await M(Ae);return}throw new Error(`Failed to sync runtime inputs: ${qs(q,m)}`)}},executeActorCode:async M=>{let q={result:void 0,output:zs(void 0,m),isError:!1};try{let ee=await Ae.execute(M,{signal:r,reservedNames:z});return i.payload||dp(M)&&mp(ee)&&(await We(),i.payload)?q:{result:ee,output:zs(ee,m),isError:!1}}catch(ee){if(ee instanceof lr||i.payload)return q;if(ee instanceof ct||ee instanceof Pe)throw ee;if(r?.aborted)throw new Pe("rlm-session",r.reason??"Aborted");if(ee instanceof Error&&(ee.name==="AbortError"||ee.message.startsWith("Aborted")))throw ee;if(uf(ee))return{result:void 0,output:ut(`${Hs}
1376
- ${qs(ee,m)}`,m),isError:!0};if(gp(ee))try{Ae=Se(),i.payload=void 0;let Z=await Ae.execute(M,{signal:r,reservedNames:z});return{result:Z,output:ut(`${Hs}
1377
- ${zs(Z,m)}`,m),isError:!1}}catch(Z){if(Z instanceof ct||Z instanceof Pe)throw Z;return{result:void 0,output:ut(`${Hs}
1378
- ${qs(Z,m)}`,m),isError:!0}}return{result:void 0,output:ut(qs(ee,m),m),isError:!0}}},executeTestCode:async M=>{try{let q=await Ae.execute(M,{signal:r,reservedNames:z});if(dp(M)&&mp(q)&&await We(),i.payload)return i.payload;let ee=zs(q,m);if(pf(ee))throw new Error(ee);return ee}catch(q){if((q instanceof lr||i.payload)&&i.payload)return i.payload;throw q}},close:()=>{Ae.close()}}}getExcludedAgents(){return this.excludedAgents}getExcludedAgentFunctions(){return this.excludedAgentFunctions}getSignature(){return this.program.getSignature()}async test(e,t,n){let r=this.ai??n?.ai,s=n?.debug??this.debug??r?.getOptions()?.debug??!1,i=this._createRuntimeInputState(t??{},{allowedFieldNames:this.rlmConfig.contextFields,validateInputKeys:!0});i.recomputeTurnInputs(!1);let a={payload:void 0},l=ip((p,d)=>{a.payload=cp(p,d)}),c=this._ensureLlmQueryBudgetState(),u=this._createRuntimeExecutionContext({ai:r,inputState:i,options:void 0,effectiveAbortSignal:n?.abortSignal,debug:s,completionState:a,completionBindings:l,actionLogEntries:[]});try{return await u.executeTestCode(e)}finally{this.currentRecursiveTraceNodeId=void 0,c&&(this.llmQueryBudgetState=void 0),u.close()}}setSignature(e){let t=new Ne(e);this._validateConfiguredSignature(t);let n=this.program.getSignature();try{this.program.setSignature(t),this._buildSplitPrograms(),this.func&&(this.func.parameters=this._buildFuncParameters())}catch(r){throw this.program.setSignature(n),this._buildSplitPrograms(),this.func&&(this.func.parameters=this._buildFuncParameters()),r}}applyOptimization(e){let t=e?.instructionSchema,n=e?.artifactFormatVersion;if(t&&t!==Zr)throw new Error(`AxAgent.applyOptimization(): unsupported instruction schema "${t}".`);if(t===Zr&&n!==void 0&&n!==1)throw new Error(`AxAgent.applyOptimization(): unsupported recursive artifact format version "${String(n)}".`);let r=e?.instructionMap??{},s=[ce.shared,ce.root,ce.recursive,ce.terminal].some(i=>typeof r[i]=="string");if(t===Zr){if(!this._supportsRecursiveActorSlotOptimization())throw new Error('AxAgent.applyOptimization(): recursive-slot artifacts require mode "advanced" with recursion enabled.');(e?.demos||e?.modelConfig)&&this.program.setDemos(e.demos??[],{modelConfig:e.modelConfig}),this.recursiveInstructionSlots=ir(this.actorDescription);for(let a of[ce.shared,ce.root,ce.recursive,ce.terminal])typeof r[a]=="string"&&(this.recursiveInstructionSlots[a]=r[a]??"");this._applyRecursiveActorInstruction();let i=r[ce.responder];typeof i=="string"&&this.responderProgram.setInstruction(i);return}if(this._supportsRecursiveActorSlotOptimization()&&!s){(e?.demos||e?.modelConfig)&&this.program.setDemos(e.demos??[],{modelConfig:e.modelConfig}),this.recursiveInstructionSlots=ir(this.actorDescription);let i=r["root.actor"]??e?.instruction;typeof i=="string"&&(this.recursiveInstructionSlots[ce.shared]=i),this._applyRecursiveActorInstruction();let a=r["root.responder"];typeof a=="string"?this.responderProgram.setInstruction(a):typeof e?.instruction=="string"&&this.responderProgram.setInstruction(e.instruction);return}if(s){if(!this._supportsRecursiveActorSlotOptimization())throw new Error('AxAgent.applyOptimization(): recursive-slot instruction maps require mode "advanced" with recursion enabled.');this.recursiveInstructionSlots=ir(this.actorDescription);for(let a of[ce.shared,ce.root,ce.recursive,ce.terminal])typeof r[a]=="string"&&(this.recursiveInstructionSlots[a]=r[a]??"");this._applyRecursiveActorInstruction();let i=r[ce.responder];typeof i=="string"&&this.responderProgram.setInstruction(i),(e?.demos||e?.modelConfig)&&this.program.setDemos(e.demos??[],{modelConfig:e.modelConfig});return}this.program.applyOptimization?.(e)}async _runActorLoop(e,t,n,r,s,i){let a=this.rlmConfig,l=n?.debug??this.debug??e?.getOptions()?.debug??!1,c=a.maxTurns??op,u=this._createRuntimeInputState(t);u.recomputeTurnInputs(!1);let p={payload:void 0},d=ip((U,G)=>{p.payload=cp(U,G)}),m=[],g,f=this._createRuntimeExecutionContext({ai:e,inputState:u,options:n,effectiveAbortSignal:r,debug:l,completionState:p,completionBindings:d,actionLogEntries:m,functionCallRecorder:s?U=>{s.push(U)}:void 0}),x=f.effectiveContextConfig.stateSummary.enabled?void 0:f.bootstrapContextSummary,A=async()=>{if(!this.inputUpdateCallback)return;let U=await this.inputUpdateCallback({...u.currentInputs});if(U!==void 0){if(!U||typeof U!="object"||Array.isArray(U))throw new Error("inputUpdateCallback must return an object patch or undefined");for(let[G,B]of Object.entries(U))u.signatureInputFieldNames.has(G)&&(u.currentInputs[G]=B)}},h={...this._genOptions,...this.actorForwardOptions,...n,debug:l,abortSignal:r},b={},T=f.effectiveContextConfig.stateInspection.enabled?f.effectiveContextConfig.stateInspection.contextThreshold:void 0,C=Pg(n,l,r),v=this.functionDiscoveryEnabled&&f.effectiveContextConfig.pruneUsedDocs,k,R,E,S=f.effectiveContextConfig.actionReplay==="checkpointed"?"minimal":f.effectiveContextConfig.actionReplay,_=f.effectiveContextConfig.actionReplay==="checkpointed"?"full":f.effectiveContextConfig.actionReplay,L=()=>Ls(m,{pruneUsedDocs:v}),P=()=>Ku(L(),{actionReplay:f.effectiveContextConfig.actionReplay,recentFullActions:f.effectiveContextConfig.recentFullActions,restoreNotice:E,delegatedContextSummary:x,stateSummary:g,checkpointSummary:k?.summary,checkpointTurns:k?.turns})||"(no actions yet)",F=async()=>{if(!f.effectiveContextConfig.checkpoints.enabled){k=void 0;return}let U=Xr(m,{actionReplay:_,recentFullActions:f.effectiveContextConfig.recentFullActions,pruneUsedDocs:v}),G=f.effectiveContextConfig.checkpoints.triggerChars;if(!G||U.historyChars<=G){k=void 0;return}let te=Xr(m,{actionReplay:S,recentFullActions:f.effectiveContextConfig.recentFullActions,pruneUsedDocs:v}).checkpointEntries;if(te.length===0){k=void 0;return}let j=JSON.stringify(te.map(V=>({turn:V.turn,code:V.code,output:V.output,actorFieldsOutput:V.actorFieldsOutput,tags:V.tags,tombstone:V.tombstone})));k?.fingerprint!==j&&(k={fingerprint:j,turns:te.map(V=>V.turn),summary:await Hu(e,f.effectiveContextConfig.summarizerOptions,C,te)})};try{if(this.state){let G=await f.restoreRuntimeState(this.state),B=f.effectiveContextConfig.stateSummary.enabled;m.push(...G.actionLogEntries),k=G.checkpointState?{fingerprint:G.checkpointState.fingerprint,turns:[...G.checkpointState.turns],summary:G.checkpointState.summary}:void 0,R=G.actorModelState?{escalated:G.actorModelState.escalated,escalatedTurns:G.actorModelState.escalatedTurns,stableBelowThresholdTurns:G.actorModelState.stableBelowThresholdTurns}:void 0;let te=nf(Ns(m),tf(G.provenance));g=B?Na(G.runtimeEntries,te,{maxEntries:f.effectiveContextConfig.stateSummary.maxEntries&&f.effectiveContextConfig.stateSummary.maxEntries>0?f.effectiveContextConfig.stateSummary.maxEntries:8,maxChars:f.effectiveContextConfig.stateSummary.maxChars&&f.effectiveContextConfig.stateSummary.maxChars>0?f.effectiveContextConfig.stateSummary.maxChars:1200})||"(no user variables)":void 0,E=ef(G.runtimeEntries,{includeLiveRuntimeState:B})}let U=await f.applyBootstrapRuntimeContext();U!==void 0&&(g=U);for(let G=0;G<c;G++){await A(),u.recomputeTurnInputs(!0),await F();let B=P(),te=Xr(m,{actionReplay:f.effectiveContextConfig.actionReplay,recentFullActions:f.effectiveContextConfig.recentFullActions,pruneUsedDocs:v,checkpointTurns:k?.turns});T&&te.historyChars>T&&(B+="\n\n[HINT: Action log is large. Call `const state = await inspect_runtime()` for a compact snapshot of current variables instead of re-reading old outputs.]");let j=h;if(this.actorModelPolicy){let ie=(this.actorProgram.getSignature().getDescription()?.length??0)+u.getContextMetadata().length+B.length,Oe=Dg(this.actorModelPolicy,m,ie,!!k?.summary);R=Ug(R,this.actorModelPolicy,Oe);let Ee=R.escalated?this.actorModelPolicy.escalatedModel:this.actorModelPolicy.baseModel??h.model;j=Ee!==void 0?{...h,model:Ee}:{...h}}let V=await this.actorProgram.forward(e,{...u.getNonContextValues(),...u.getActorInlineContextValues(),contextMetadata:u.getContextMetadata(),actionLog:B},j);G===0&&(h.debugHideSystemPrompt=!0,E=void 0);let xe=V.javascriptCode,ve=xe?.trim();if(!xe||!ve)break;xe=vg(ve),V.javascriptCode=xe;for(let z of this.actorFieldNames)z in V&&(b[z]=V[z]);let $="";if(this.actorFieldNames.length>0){let z=this.actorFieldNames.filter(ie=>ie in V).map(ie=>`${ie}: ${V[ie]}`).join(`
1379
- `);z&&($=`
1380
- Actor fields:
1381
- ${z}`)}if(p.payload=void 0,this.enforceIncrementalConsoleTurns){let z=yf(xe);if(z){let ie=m.length+1;m.push({turn:ie,code:xe,output:z,actorFieldsOutput:$,tags:["error"]}),i?.push({turn:ie,code:xe,output:z,isError:!0,thought:typeof V.thought=="string"?V.thought:void 0}),a.actorTurnCallback&&await a.actorTurnCallback({turn:ie,actorResult:V,code:xe,result:void 0,output:z,isError:!0,thought:typeof V.thought=="string"?V.thought:void 0}),await va(m,m.length-1,f.effectiveContextConfig,e,C),await F();continue}}this.inputUpdateCallback&&await f.syncRuntimeInputsToSession();let K,ne,pe;try{let z=await f.executeActorCode(xe);K=z.result,ne=z.output,pe=z.isError}catch(z){throw(z instanceof ct||z instanceof Pe)&&(i?.push({turn:m.length+1,code:xe,output:up(z,a.maxRuntimeChars??Ea),isError:z instanceof Pe,thought:typeof V.thought=="string"?V.thought:void 0}),a.actorTurnCallback&&await a.actorTurnCallback({turn:m.length+1,actorResult:V,code:xe,result:void 0,output:up(z,a.maxRuntimeChars??Ea),isError:z instanceof Pe,thought:typeof V.thought=="string"?V.thought:void 0})),z}let X=m.length+1;if(m.push({turn:X,code:xe,output:ne,actorFieldsOutput:$,tags:pe?["error"]:[]}),i?.push({turn:X,code:xe,output:ne,isError:pe,thought:typeof V.thought=="string"?V.thought:void 0}),a.actorTurnCallback&&await a.actorTurnCallback({turn:X,actorResult:V,code:xe,result:K,output:ne,isError:pe,thought:typeof V.thought=="string"?V.thought:void 0}),await va(m,m.length-1,f.effectiveContextConfig,e,C),pe||(g=await f.captureRuntimeStateSummary()),await F(),p.payload)break}await F();try{let G=await f.exportRuntimeState();G.checkpointState=k?{fingerprint:k.fingerprint,turns:[...k.turns],summary:k.summary}:void 0,G.actorModelState=R?{escalated:R.escalated,escalatedTurns:R.escalatedTurns,stableBelowThresholdTurns:R.stableBelowThresholdTurns}:void 0,this.state=G,this.stateError=void 0}catch(G){this.state=void 0,this.stateError=G instanceof Error?G.message:`Failed to export AxAgent state: ${String(G)}`}}finally{try{f.close()}catch{}}let N=p.payload??{type:"final",args:[Wu(m,{stateSummary:g,checkpointSummary:k?.summary,checkpointTurns:k?.turns,pruneUsedDocs:v})]};return{nonContextValues:u.getNonContextValues(),contextMetadata:u.getContextMetadata(),actionLog:P(),actorResult:N,actorFieldValues:b,turnCount:m.length}}async forward(e,t,n){let r=new AbortController;this._stopRequested&&r.abort("Stopped by user (pre-forward)");let s=vt(r.signal,n?.abortSignal);this.activeAbortControllers.add(r);let i=this._ensureLlmQueryBudgetState();try{let a=this.ai??e,l=n?.debug??this.debug??a?.getOptions()?.debug??!1,c=[],u=[],{node:p,usageBefore:d}=this._beginRecursiveTraceCapture(t),{nonContextValues:m,actorResult:g,actorFieldValues:f}=await this._runActorLoop(a,t,n,s,c,u);if(g.type==="ask_clarification")throw this._finalizeRecursiveTraceCapture(p,d,u,c,g),new ct(g.args[0],{state:this.state,stateError:this.stateError});let x={...this._genOptions,...this.responderForwardOptions,...n,debug:l,abortSignal:s,maxSteps:1},A=await this.responderProgram.forward(a,{...m,contextData:g},x);return this._finalizeRecursiveTraceCapture(p,d,u,c,g),{...A,...f}}finally{i&&(this.llmQueryBudgetState=void 0),this.activeAbortControllers.delete(r),this._stopRequested=!1}}async*streamingForward(e,t,n){let r=new AbortController;this._stopRequested&&r.abort("Stopped by user (pre-forward)");let s=vt(r.signal,n?.abortSignal);this.activeAbortControllers.add(r);let i=this._ensureLlmQueryBudgetState();try{let a=this.ai??e,l=n?.debug??this.debug??a?.getOptions()?.debug??!1,{nonContextValues:c,actorResult:u,actorFieldValues:p}=await this._runActorLoop(a,t,n,s);if(u.type==="ask_clarification")throw new ct(u.args[0],{state:this.state,stateError:this.stateError});let d={...this._genOptions,...this.responderForwardOptions,...n,debug:l,abortSignal:s,maxSteps:1};for await(let m of this.responderProgram.streamingForward(a,{...c,contextData:u},d))yield m;Object.keys(p).length>0&&(yield{version:1,index:0,delta:p})}finally{i&&(this.llmQueryBudgetState=void 0),this.activeAbortControllers.delete(r),this._stopRequested=!1}}static wrapFunction(e,t,n,r,s,i){return async(...a)=>{let l;if(a.length===1&&typeof a[0]=="object"&&a[0]!==null&&!Array.isArray(a[0]))l=a[0];else{let c=e.parameters?.properties?Object.keys(e.parameters.properties):[];l={},c.forEach((u,p)=>{p<a.length&&(l[u]=a[p])})}try{let c=await e.func(l,{abortSignal:t,ai:n,protocol:r});return i?.({qualifiedName:s??e.name,name:e.name,arguments:lt(l),result:lt(c)}),c}catch(c){throw i?.({qualifiedName:s??e.name,name:e.name,arguments:lt(l),error:c instanceof Error?c.message:String(c)}),c}}}static wrapFunctionWithSharedFields(e,t,n,r,s,i,a){return typeof n!="function"&&(!n||Object.keys(n).length===0)?o.wrapFunction(e,t,r,s,i,a):async(...l)=>{let c;if(l.length===1&&typeof l[0]=="object"&&l[0]!==null&&!Array.isArray(l[0]))c=l[0];else{let d=e.parameters?.properties?Object.keys(e.parameters.properties):[];c={},d.forEach((m,g)=>{g<l.length&&(c[m]=l[g])})}let u=typeof n=="function"?n():n,p=u?{...u,...c}:c;try{let d=await e.func(p,{abortSignal:t,ai:r,protocol:s});return a?.({qualifiedName:i??e.name,name:e.name,arguments:lt(p),result:lt(d)}),d}catch(d){throw a?.({qualifiedName:i??e.name,name:e.name,arguments:lt(p),error:d instanceof Error?d.message:String(d)}),d}}}buildRuntimeGlobals(e,t,n,r,s){let i={},a=new Map,l=new Map,c=new Map;for(let[p,d]of this.agentFunctionModuleMetadata)c.set(p,d);let u=(p,d)=>{a.set(d,p),l.has(p.module)||l.set(p.module,[]),l.get(p.module)?.push(d)};for(let p of this.agentFunctions){let d=p.namespace??"utils";(!i[d]||typeof i[d]!="object")&&(i[d]={});let m=`${d}.${p.name}`;i[d][p.name]=o.wrapFunction(p,e,n,r,m,s),u({module:d,name:p.name,description:p.description,parameters:p.parameters,returns:p.returns,examples:p.examples},m)}if(this.agents&&this.agents.length>0){let p={};for(let d of this.agents){let m=d.getFunction(),g=new Set(d.getExcludedSharedFields?.()??[]),f=()=>{let A={};if(t)for(let[h,b]of Object.entries(t))g.has(h)||(A[h]=b);return A},x=`${this.agentModuleNamespace}.${m.name}`;p[m.name]=o.wrapFunctionWithSharedFields(m,e,f,n,r,x,s),u({module:this.agentModuleNamespace,name:m.name,description:m.description,parameters:m.parameters},x)}i[this.agentModuleNamespace]=p}return this.functionDiscoveryEnabled&&(i[Ma]=async p=>{let d=hp(p,"modules");return kf(d,l,c)},i[Pa]=async p=>{let d=hp(p,"functions");return Of(d,a)}),i}get _genOptions(){if(!this.options)return{};let{agents:e,fields:t,functions:n,judgeOptions:r,inputUpdateCallback:s,...i}=this.options;return i}_buildFuncParameters(){let e=this.program.getSignature().toInputJSONSchema();return this._parentSharedFields.size>0?Cf(e,this._parentSharedFields):e}};function cp(o,e){if(e.length===0)throw new Error(`${o}() requires at least one argument`);if(o==="ask_clarification"){if(e.length!==1)throw new Error("ask_clarification() requires exactly one argument");return{type:o,args:[Ap(e[0])]}}return{type:o,args:e}}function Da(o){return!!o&&typeof o=="object"&&!Array.isArray(o)&&Object.getPrototypeOf(o)===Object.prototype}function no(o){return typeof o=="string"&&o.trim().length>0}function Bg(o){if(no(o))return o;if(!Da(o))throw new Error("ask_clarification() choice entries must be non-empty strings or objects with a non-empty label");if(!no(o.label))throw new Error("ask_clarification() choice objects require a non-empty label");if(o.value!==void 0&&!no(o.value))throw new Error("ask_clarification() choice object values must be non-empty strings");return{label:o.label,...o.value!==void 0?{value:o.value}:{}}}function Ap(o){if(no(o))return o;if(!Da(o))throw new Error("ask_clarification() requires a non-empty string or an object payload");if(!no(o.question))throw new Error("ask_clarification() object payload requires a non-empty question");let e=new Set(["text","number","date","single_choice","multiple_choice"]),t;if(o.type===void 0)t=Array.isArray(o.choices)&&o.choices.length>0?"single_choice":void 0;else{if(typeof o.type!="string"||!e.has(o.type))throw new Error("ask_clarification() object payload type must be one of: text, number, date, single_choice, multiple_choice");t=o.type}let n=t==="single_choice"||t==="multiple_choice",r=o.choices;if(r!==void 0){if(!Array.isArray(r)||r.length===0)throw new Error("ask_clarification() choices must be a non-empty array when provided")}else if(n)throw new Error("ask_clarification() choice payloads require a non-empty choices array");return{...o,question:o.question,...t?{type:t}:{},...r?{choices:r.map(Bg)}:{}}}function yp(o){let e=Ap(o);return typeof e=="string"?{question:e,type:"text"}:{...e,type:e.type??(e.choices&&e.choices.length>0?"single_choice":"text")}}function jg(o){return typeof structuredClone=="function"?structuredClone(o):JSON.parse(JSON.stringify(o))}function zg(o,e){return!e.has(o)&&!Tg.has(o)&&bg.test(o)}function qg(o,e){if(o===void 0)return{};let t={context:o};if(!Da(o))return t;for(let[n,r]of Object.entries(o))zg(n,e)&&(t[n]=r);return t}function Hg(o){if(o===null)return{type:"null"};if(Array.isArray(o))return{type:"array",ctor:"Array"};if(o instanceof Map)return{type:"map",ctor:"Map"};if(o instanceof Set)return{type:"set",ctor:"Set"};if(o instanceof Date)return{type:"date",ctor:"Date"};if(o instanceof Error)return{type:"error",ctor:typeof o.name=="string"&&o.name.trim()?o.name:"Error"};let e=typeof o;return e!=="object"?{type:e}:{type:"object",ctor:o&&o.constructor&&typeof o.constructor?.name=="string"?o.constructor?.name:void 0}}function to(o){if(o===null)return"null";if(o===void 0)return"undefined";let e=typeof o;if(e==="string")return JSON.stringify(Ua(o,40));if(e==="number"||e==="boolean"||e==="bigint"||e==="symbol")return String(o);if(e==="function")return`[function ${o.name||"anonymous"}]`;if(Array.isArray(o))return`[array(${o.length})]`;if(o instanceof Date)return Number.isFinite(o.getTime())?o.toISOString():String(o);if(o instanceof Error)return`${o.name||"Error"}: ${o.message||""}`;if(o instanceof Map)return`[map(${o.size})]`;if(o instanceof Set)return`[set(${o.size})]`;let t=o&&o.constructor&&typeof o.constructor?.name=="string"?o.constructor?.name:"";return t&&t!=="Object"?`[${t}]`:"[object]"}function Kg(o,e,t){if(e==="array"&&Array.isArray(o))return`[${o.slice(0,3).map(r=>to(r)).join(", ")}${o.length>3?", ...":""}]`;if(e==="map"&&o instanceof Map){let n=[...o.entries()].slice(0,3).map(([r,s])=>`${to(r)} => ${to(s)}`);return`Map(${o.size}) {${n.join(", ")}${o.size>3?", ...":""}}`}if(e==="set"&&o instanceof Set){let n=[...o.values()].slice(0,5).map(r=>to(r));return`Set(${o.size}) {${n.join(", ")}${o.size>5?", ...":""}}`}if(e==="object"&&o&&typeof o=="object"){let n=Object.keys(o),r=n.slice(0,4);return`${t&&t!=="Object"?`${t} `:""}{${r.join(", ")}${n.length>r.length?", ...":""}}`}return to(o)}function Wg(o,e){if(e==="string"&&typeof o=="string")return`${o.length} chars`;if(e==="array"&&Array.isArray(o))return`${o.length} items`;if((e==="map"||e==="set")&&o instanceof Map)return`${o.size} items`;if((e==="map"||e==="set")&&o instanceof Set)return`${o.size} items`;if(e==="object"&&o&&typeof o=="object")return`${Object.keys(o).length} keys`}function Vg(o){if(o.length===0)return;let e=o[0];if(e&&typeof e=="object"&&!Array.isArray(e)){let t=Object.keys(e).slice(0,8);if(t.length>0)return t.join(", ")}}function Jg(o){return Object.entries(o).map(([e,t])=>{try{let n=Hg(t),r=Wg(t,n.type),s=Kg(t,n.type,n.ctor),i;n.type==="array"&&Array.isArray(t)&&(i=Vg(t));let a=s?Ua(s,40):void 0,l=i?a?`${a} \u2014 element keys: ${i}`:`element keys: ${i}`:a;return{name:e,type:n.type,...n.ctor?{ctor:n.ctor}:{},...r?{size:r}:{},...l?{preview:l}:{}}}catch{return{name:e,type:"unknown",preview:"[unavailable]"}}})}function Qg(o,e){let t=Jg(o),n=Na(t,new Map,e),r=e?.budgetRemaining!==void 0&&e?.budgetTotal!==void 0?`
1368
+ ${t}`:e}function Op(o){let{criteria:e,description:t,randomizeOrder:n,...r}=o;return{...r,maxSteps:1}}function Ep(o){let e=o.toLowerCase();return e==="excellent"?1:e==="good"?.8:e==="acceptable"?.5:e==="poor"?.2:e==="unacceptable"?0:.5}function Ip(o,e){return e.qualifiedName===o||e.name===o||e.qualifiedName.endsWith(`.${o}`)}function Mp(o,e,t){let n=Math.max(0,Math.min(1,o)),r=e.expectedActions??[];if(r.length>0){let i=r.filter(a=>t.functionCalls.some(u=>Ip(a,u))).length;n*=.5+.5*(i/r.length)}return(e.forbiddenActions??[]).some(i=>t.functionCalls.some(a=>Ip(i,a)))&&(n*=.2),Math.max(0,Math.min(1,n))}function Pp(o,e){let t=new Set(o.map(i=>i.id)),n=t.has(le.shared),r=[le.shared,le.root,le.recursive,le.terminal].filter(i=>t.has(i));if(e==="actor"){if(n){if(r.length===0)throw new Error("AxAgent.optimize(): recursive actor targets are not available");return r}if(!t.has("root.actor"))throw new Error("AxAgent.optimize(): root.actor is not available");return["root.actor"]}if(e==="responder"){if(!t.has("root.responder"))throw new Error("AxAgent.optimize(): root.responder is not available");return["root.responder"]}if(e==="all")return n?[...r,...t.has(le.responder)?[le.responder]:[]]:[...t];let s=[...e];for(let i of s)if(!t.has(i))throw new Error(`AxAgent.optimize(): unknown target program ID "${i}"`);return s}var Xg=/^[$A-Z_a-z][$0-9A-Z_a-z]*$/,Zg=new Set(["context","__proto__","prototype","constructor","globalThis","global","self","window","console","JSON","Math","Reflect","Atomics","Array","Object","String","Number","Boolean","BigInt","Symbol","Date","RegExp","Error","EvalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError","AggregateError","Map","Set","WeakMap","WeakSet","Promise","Proxy","Function","Intl","URL","URLSearchParams","TextEncoder","TextDecoder","AbortController","AbortSignal","parseInt","parseFloat","isNaN","isFinite","eval","undefined","Infinity","NaN","await","break","case","catch","class","const","continue","debugger","default","delete","do","else","enum","export","extends","false","finally","for","function","if","import","in","instanceof","new","null","return","super","switch","this","throw","true","try","typeof","var","void","while","with","yield","let","static","implements","interface","package","private","protected","public"]),Hs="listModuleFunctions",Ks="getFunctionDefinitions",Np="AI service is required to use llmQuery(...) in AxAgent.test(). Pass options.ai or configure ai on the agent.",so="[The JavaScript runtime was restarted; all global state was lost and must be recreated if needed.]";function Lp(o,e,t){return{model:o?.model,modelConfig:o?.modelConfig,debug:e,verbose:o?.verbose,rateLimiter:o?.rateLimiter,fetch:o?.fetch,tracer:o?.tracer,meter:o?.meter,timeout:o?.timeout,excludeContentFromTrace:o?.excludeContentFromTrace,abortSignal:t,logger:o?.logger,sessionId:o?.sessionId,debugHideSystemPrompt:o?.debugHideSystemPrompt,traceContext:o?.traceContext,thinkingTokenBudget:o?.thinkingTokenBudget,showThoughts:o?.showThoughts,useExpensiveModel:o?.useExpensiveModel,corsProxy:o?.corsProxy,retry:o?.retry,contextCache:o?.contextCache,examplesInSystem:o?.examplesInSystem,customLabels:o?.customLabels}}function ef(o){return!!o&&typeof o=="object"&&!Array.isArray(o)&&Object.getPrototypeOf(o)===Object.prototype}function tf(o,e){return!e.has(o)&&!Zg.has(o)&&Xg.test(o)}function $p(o,e){if(o===void 0)return{};let t={context:o};if(!ef(o))return t;for(let[n,r]of Object.entries(o))tf(n,e)&&(t[n]=r);return t}function nf(o){if(o===null)return{type:"null"};if(Array.isArray(o))return{type:"array",ctor:"Array"};if(o instanceof Map)return{type:"map",ctor:"Map"};if(o instanceof Set)return{type:"set",ctor:"Set"};if(o instanceof Date)return{type:"date",ctor:"Date"};if(o instanceof Error)return{type:"error",ctor:typeof o.name=="string"&&o.name.trim()?o.name:"Error"};let e=typeof o;return e!=="object"?{type:e}:{type:"object",ctor:o&&o.constructor&&typeof o.constructor?.name=="string"?o.constructor?.name:void 0}}function ro(o){if(o===null)return"null";if(o===void 0)return"undefined";let e=typeof o;if(e==="string")return JSON.stringify(Ka(o,40));if(e==="number"||e==="boolean"||e==="bigint"||e==="symbol")return String(o);if(e==="function")return`[function ${o.name||"anonymous"}]`;if(Array.isArray(o))return`[array(${o.length})]`;if(o instanceof Date)return Number.isFinite(o.getTime())?o.toISOString():String(o);if(o instanceof Error)return`${o.name||"Error"}: ${o.message||""}`;if(o instanceof Map)return`[map(${o.size})]`;if(o instanceof Set)return`[set(${o.size})]`;let t=o&&o.constructor&&typeof o.constructor?.name=="string"?o.constructor?.name:"";return t&&t!=="Object"?`[${t}]`:"[object]"}function rf(o,e,t){if(e==="array"&&Array.isArray(o))return`[${o.slice(0,3).map(r=>ro(r)).join(", ")}${o.length>3?", ...":""}]`;if(e==="map"&&o instanceof Map){let n=[...o.entries()].slice(0,3).map(([r,s])=>`${ro(r)} => ${ro(s)}`);return`Map(${o.size}) {${n.join(", ")}${o.size>3?", ...":""}}`}if(e==="set"&&o instanceof Set){let n=[...o.values()].slice(0,5).map(r=>ro(r));return`Set(${o.size}) {${n.join(", ")}${o.size>5?", ...":""}}`}if(e==="object"&&o&&typeof o=="object"){let n=Object.keys(o),r=n.slice(0,4);return`${t&&t!=="Object"?`${t} `:""}{${r.join(", ")}${n.length>r.length?", ...":""}}`}return ro(o)}function of(o,e){if(e==="string"&&typeof o=="string")return`${o.length} chars`;if(e==="array"&&Array.isArray(o))return`${o.length} items`;if((e==="map"||e==="set")&&o instanceof Map)return`${o.size} items`;if((e==="map"||e==="set")&&o instanceof Set)return`${o.size} items`;if(e==="object"&&o&&typeof o=="object")return`${Object.keys(o).length} keys`}function sf(o){if(o.length===0)return;let e=o[0];if(e&&typeof e=="object"&&!Array.isArray(e)){let t=Object.keys(e).slice(0,8);if(t.length>0)return t.join(", ")}}function af(o){return Object.entries(o).map(([e,t])=>{try{let n=nf(t),r=of(t,n.type),s=rf(t,n.type,n.ctor),i;n.type==="array"&&Array.isArray(t)&&(i=sf(t));let a=s?Ka(s,40):void 0,u=i?a?`${a} \u2014 element keys: ${i}`:`element keys: ${i}`:a;return{name:e,type:n.type,...n.ctor?{ctor:n.ctor}:{},...r?{size:r}:{},...u?{preview:u}:{}}}catch{return{name:e,type:"unknown",preview:"[unavailable]"}}})}function Dp(o,e){let t=af(o),n=Ws(t,new Map,e),r=e?.budgetRemaining!==void 0&&e?.budgetTotal!==void 0?`
1382
1369
  Sub-query budget: ${e.budgetRemaining}/${e.budgetTotal} remaining`:"";return`Explore with code \u2014 do not assume values from these previews.
1383
- ${n}${r}`}function up(o,e){return o instanceof ct?ut(`[CLARIFICATION] ${o.question}`,e):ut(`[ABORTED] ${o.message}`,e)}function ar(o){return jg(o)}function Yg(o){return o.map(e=>({turn:e.turn,code:e.code,output:e.output,actorFieldsOutput:e.actorFieldsOutput,tags:[...e.tags],...e.summary?{summary:e.summary}:{},...e.producedVars?{producedVars:[...e.producedVars]}:{},...e.referencedVars?{referencedVars:[...e.referencedVars]}:{},...e.stateDelta?{stateDelta:e.stateDelta}:{},...e.stepKind?{stepKind:e.stepKind}:{},...e.replayMode?{replayMode:e.replayMode}:{},...e.rank!==void 0?{rank:e.rank}:{},...e.tombstone?{tombstone:e.tombstone}:{}}))}function Xg(o){return(o??[]).map(e=>({turn:e.turn,code:e.code,output:e.output,actorFieldsOutput:e.actorFieldsOutput,tags:[...e.tags],...e.summary?{summary:e.summary}:{},...e.producedVars?{producedVars:[...e.producedVars]}:{},...e.referencedVars?{referencedVars:[...e.referencedVars]}:{},...e.stateDelta?{stateDelta:e.stateDelta}:{},...e.stepKind?{stepKind:e.stepKind}:{},...e.replayMode?{replayMode:e.replayMode}:{},...e.rank!==void 0?{rank:e.rank}:{},...e.tombstone?{tombstone:e.tombstone}:{}}))}function Zg(o){return Object.fromEntries([...o.entries()].map(([e,t])=>[e,{...t}]))}function ef(o,e){let t=o.filter(r=>r.restorable===!1).length,n=["Runtime Restore:","- Runtime state was restored from a previous call.","- Continue from restored values unless recomputation is actually needed."];return e?.includeLiveRuntimeState!==!1?n.splice(2,0,"- Live Runtime State below reflects the restored bindings."):n.splice(2,0,"- Live Runtime State rendering is disabled for this run, but the restored bindings are available in the runtime session."),t>0&&n.push(`- ${t} prior value${t===1?" was":"s were"} snapshot-only and could not be restored.`),n.join(`
1384
- `)}function tf(o){return new Map(Object.entries(o??{}).map(([e,t])=>[e,{...t}]))}function nf(o,e){let t=new Map;for(let[n,r]of e.entries())t.set(n,{...r});for(let[n,r]of o.entries())t.set(n,{...r});return t}function bp(o,e){let t=typeof o=="string"?Ne.create(o):o,{ai:n,judgeAI:r,agentIdentity:s,...i}=e;return new ro({ai:n,judgeAI:r,agentIdentity:s,signature:t},i)}function rf(o){return o instanceof rt&&o.status>=500&&o.status<600?!0:o instanceof Je||o instanceof dt}function ut(o,e){return o.length<=e?o:`${o.slice(0,e)}
1385
- ...[truncated ${o.length-e} chars]`}function Ua(o,e){return e<=0?"":o.length<=e?o:e<=3?o.slice(0,e):`${o.slice(0,e-3)}...`}function of(o){if(!o||typeof o!="object")return!1;let e=o;return typeof e.name=="string"&&typeof e.type=="string"&&(e.ctor===void 0||typeof e.ctor=="string")&&(e.size===void 0||typeof e.size=="string")&&(e.preview===void 0||typeof e.preview=="string")&&(e.restorable===void 0||typeof e.restorable=="boolean")}function sf(o){let e=o.trim();if(!(!e||e[0]!=="{"&&e[0]!=="["))try{let t=JSON.parse(e),n=Array.isArray(t)?t:t&&typeof t=="object"&&Array.isArray(t.entries)?t.entries:void 0;return n?n.filter(of):void 0}catch{return}}function Tp(o,e){let t=e?.maxEntries&&e.maxEntries>0?e.maxEntries:void 0,n=e?.maxChars&&e.maxChars>0?e.maxChars:void 0,r=t?o.slice(0,t):[...o];if(!n)return r.join(`
1386
- `);let s=[],i=0;for(let a of r){let l=s.length>0?1:0,c=n-i-l;if(c<=0)break;if(a.length<=c){s.push(a),i+=l+a.length;continue}s.push(Ua(a,c)),i=n;break}return s.join(`
1387
- `)}function af(o,e){let t=o.split(`
1388
- `).map(n=>n.trim()).filter(Boolean);return Tp(t,e)}function pp(o,e){let t=0;return e&&(t+=1e6,t+=e.createdTurn*100,t+=(e.lastReadTurn??e.createdTurn)*1e4,e.source&&(t+=25)),o.type==="accessor"?t-=100:o.type==="function"&&(t-=10),t}function lf(o){let e=o.type;return o.type==="object"&&o.ctor&&o.ctor!=="Object"?e=`object<${o.ctor}>`:o.type==="error"&&o.ctor&&o.ctor!=="Error"&&(e=`error<${o.ctor}>`),o.size&&(e+=` (${o.size})`),e}function cf(o){if(!o)return"";let e=[`from t${o.createdTurn}${o.source?` via ${o.source}`:""}`];return o.lastReadTurn!==void 0&&o.lastReadTurn>o.createdTurn&&e.push(`read t${o.lastReadTurn}`),` [${e.join("; ")}]`}function Na(o,e,t){let n=[...o].sort((r,s)=>{let i=pp(r,e.get(r.name));return pp(s,e.get(s.name))-i||r.name.localeCompare(s.name)}).map(r=>{let s=r.preview?` = ${r.preview}`:"",i=cf(e.get(r.name)),a="restorable"in r&&r.restorable===!1?" [snapshot only]":"";return`${r.name}: ${lf(r)}${s}${i}${a}`});return n.length===0?"(no user variables)":Tp(n,t)}function zs(o,e){if(o===void 0)return"(no output)";if(typeof o=="string")return ut(o||"(no output)",e);try{return ut(JSON.stringify(o,null,2),e)}catch{return ut(String(o),e)}}function qs(o,e){let t=o,n=t?.name??"Error",r=t?.message??String(o),s=[`${n}: ${r}`];if(t?.data!==void 0)try{s.push(`Data: ${JSON.stringify(t.data,null,2)}`)}catch{s.push(`Data: ${String(t.data)}`)}if(t?.cause!==void 0){let i=(a,l)=>{if(l>4)return"[cause chain truncated]";let c=a,u=c?.name??"Error",p=c?.message??String(a),d=[`${u}: ${p}`];if(c?.data!==void 0)try{d.push(`Data: ${JSON.stringify(c.data,null,2)}`)}catch{d.push(`Data: ${String(c.data)}`)}return c?.cause!==void 0&&d.push(`Caused by: ${i(c.cause,l+1)}`),d.join(`
1389
- `)};s.push(`Caused by: ${i(t.cause,1)}`)}return ut(s.join(`
1390
- `),e)}function dp(o){let e=Ft(o);return/\bfinal\s*\(/.test(e)||/\bask_clarification\s*\(/.test(e)}function mp(o){return o&&(typeof o=="object"||typeof o=="function")&&"then"in o&&typeof o.then=="function"?!0:typeof o=="string"&&o.trim()==="[object Promise]"}function gp(o){return o instanceof Error&&o.message==="Session is closed"}function uf(o){return o instanceof Error&&o.message==="Execution timed out"}function pf(o){return o.startsWith("[ERROR]")||o.startsWith(Hs)?!0:/^(AggregateError|Error|EvalError|RangeError|ReferenceError|SyntaxError|TypeError|URIError): /.test(o)}function df(o,e){if(e.kind==="threshold")return gf(o)<=e.promptMaxChars?o:void 0;if(typeof o!="string")return;let t=e.keepInPromptChars;if(o.length<=t)return o;let n=o.length-t;if(e.reverseTruncate){let s=t>0?o.slice(-t):"";return`[truncated ${n} chars]...${s}`}return`${t>0?o.slice(0,t):""}...[truncated ${n} chars]`}function mf(o,e,t){return e.kind==="threshold"?t?`inline (<=${e.promptMaxChars} chars)`:`runtime-only (>${e.promptMaxChars} chars)`:typeof o!="string"?"runtime-only (keepInPromptChars requires string)":t?o.length<=e.keepInPromptChars?`inline (<=${e.keepInPromptChars} chars)`:e.reverseTruncate?`inline-truncated(last ${e.keepInPromptChars} chars of ${o.length})`:`inline-truncated(first ${e.keepInPromptChars} chars of ${o.length})`:"runtime-only"}function gf(o){if(typeof o=="string")return o.length;try{return JSON.stringify(o).length}catch{return String(o).length}}function ff(o,e,t){let n=new Set(e.map(a=>a.name)),r=new Set,s=[],i=new Map;for(let a of o){let l=typeof a=="string"?a:a.field;if(!n.has(l))throw new Error(`RLM contextField "${l}" not found in signature`);if(r.has(l))throw new Error(`Duplicate contextField "${l}"`);if(r.add(l),s.push(l),typeof a!="string"){let c=a.keepInPromptChars!==void 0,u=a.promptMaxChars!==void 0;if(c&&u)throw new Error(`contextField "${l}" cannot set both promptMaxChars and keepInPromptChars`);if("reverseTruncate"in a&&!c)throw new Error(`contextField "${l}" reverseTruncate requires keepInPromptChars`);if(c){let d=a.keepInPromptChars;if(!Number.isFinite(d)||d===void 0||d<0)throw new Error(`contextField "${l}" keepInPromptChars must be a finite number >= 0`);i.set(l,{kind:"truncate",keepInPromptChars:d,reverseTruncate:a.reverseTruncate===!0});continue}let p=a.promptMaxChars??t;if(!Number.isFinite(p)||p<0)throw new Error(`contextField "${l}" promptMaxChars must be a finite number >= 0`);i.set(l,{kind:"threshold",promptMaxChars:p})}}return{contextFieldNames:s,promptConfigByField:i}}function hf(o,e){let t=[];for(let[n,r]of Object.entries(o)){let s=Array.isArray(r)?"array":typeof r,i=typeof r=="string"?`${r.length} chars`:Array.isArray(r)?`${r.length} items`:r&&typeof r=="object"?`${Object.keys(r).length} keys`:"n/a",a=e?.promptConfigByField?.get(n),l=a===void 0?"runtime-only":mf(r,a,e?.inlinedFields?.has(n)===!0);t.push(`- ${n}: type=${s}, size=${i}, prompt=${l}`)}return t.join(`
1391
- `)}async function xf(o,e,t,n){if(o.length===0)return[];let r=new Array(o.length),s=0,i=Math.max(1,Math.min(e,o.length)),a=Array.from({length:i},async()=>{for(;;){if(n?.aborted)return;let l=s++;if(l>=o.length)return;let c=o[l];if(c===void 0)return;r[l]=await t(c,l)}});return await Promise.all(a),r}function Af(o){return o.includes("console.log")}function yf(o){let e=Ft(o),t=/\bfinal\s*\(/.test(e),n=/\bask_clarification\s*\(/.test(e),r=Number(t)+Number(n),s=bf(e);if(r>1)return"[POLICY] Use exactly one completion signal per turn: either final(...) or ask_clarification(...), not both.";if(r===1)return s.length>0?"[POLICY] Do not combine console.log(...) with final(...)/ask_clarification(...) in the same turn. Inspect in one turn, then complete in the next turn.":void 0;if(s.length===0)return"[POLICY] Non-final turns must include exactly one console.log(...) so the next turn can reason from its output.";if(s.length>1)return"[POLICY] Use exactly one console.log(...) per non-final turn, then stop.";let i=s[0];if(i===void 0)return"[POLICY] Unable to verify console.log(...) usage. Emit exactly one console.log(...) per non-final turn.";if(i.closeParenIndex===void 0)return"[POLICY] Could not parse console.log(...). Keep a single valid console.log(...) call as the last statement in non-final turns.";if(e.slice(i.closeParenIndex+1).replace(/^[\s;]+/,"").length>0)return"[POLICY] End non-final turns immediately after console.log(...). Do not execute additional statements after logging."}function bf(o){let e=o.matchAll(/\bconsole\s*\.\s*log\s*\(/g),t=[];for(let n of e){let r=n[0];if(r===void 0)continue;let s=n.index??-1;if(s<0)continue;let i=r.lastIndexOf("("),a=s+i,l=Tf(o,a);t.push({closeParenIndex:l})}return t}function Tf(o,e){if(e<0||o[e]!=="(")return;let t=0;for(let n=e;n<o.length;n++){let r=o[n];if(r==="(")t++;else if(r===")"&&(t--,t===0))return n}}function Cf(o,e){if(!o.properties||e.size===0)return o;let t=Object.fromEntries(Object.entries(o.properties).filter(([r])=>!e.has(r))),n=o.required?.filter(r=>!e.has(r));return{...o,properties:t,...n!==void 0?{required:n}:{}}}function If(o,e){let t=o.trim(),r=e?.normalize??!0?Ip(t):t;if(!r)throw new Error("Agent module namespace must contain letters or numbers");return r}function fp(o){return Array.isArray(o.functions)}function Fa(o,e){if(!o||o.length===0)return{functions:[],moduleMetadata:[]};let t=o.every(a=>fp(a)),n=o.every(a=>!fp(a));if(!t&&!n)throw new Error("Agent functions collections must contain either flat functions or grouped function modules, not both");if(n)return{functions:[...o],moduleMetadata:[]};let r=new Set,s=[],i=[];for(let a of o){let l=a.namespace.trim(),c=a.title.trim(),u=a.selectionCriteria?.trim()||void 0,p=a.description?.trim()||void 0;if(!l)throw new Error("Agent function group namespace must be a non-empty string");if(!c)throw new Error(`Agent function group "${l}" must define a non-empty title`);if(e.has(l))throw new Error(`Agent function namespace "${l}" conflicts with an AxAgent runtime global and is reserved`);if(r.has(l))throw new Error(`Duplicate agent function group namespace "${l}"`);if(a.functions.length===0)throw new Error(`Agent function group "${l}" must contain at least one function`);r.add(l),s.push({namespace:l,title:c,selectionCriteria:u,description:p});for(let d of a.functions){if("namespace"in d&&d.namespace!==void 0)throw new Error(`Grouped agent function "${l}.${d.name}" must not define namespace; use the parent group namespace instead`);i.push({...d,namespace:l})}}return{functions:i,moduleMetadata:s}}function hp(o,e){if(typeof o=="string"){let n=o.trim();if(n.length===0)throw new Error(`${e} must be a non-empty string`);return[n]}if(!Array.isArray(o))throw new Error(`${e} must be a string or string[]`);if(!o.every(n=>typeof n=="string"))throw new Error(`${e} must contain only strings`);let t=o.map(n=>n).map(n=>n.trim()).filter(n=>n.length>0);if(t.length===0)throw new Error(`${e} must contain at least one non-empty string`);return[...new Set(t)]}function La(o){let e=o.type;return Array.isArray(e)?e.filter(t=>typeof t=="string"):typeof e=="string"?e.includes(",")?e.split(",").map(t=>t.trim()).filter(Boolean):[e]:[]}function wf(o){let e=new Set(o);return e.has("object")&&e.has("array")&&e.has("string")&&e.has("number")&&e.has("boolean")&&e.has("null")}function oo(o){if(o.enum)return o.enum.map(n=>`"${n}"`).join(" | ");let e=La(o);if(e.length===0)return"unknown";if(wf(e))return"any";let t=[...new Set(e)].map(n=>{if(n==="array"){let r=o.items?oo(o.items):"unknown";return r.includes(" | ")?`(${r})[]`:`${r}[]`}return n==="object"?o.properties&&Object.keys(o.properties).length>0?Cp(o):"object":n});return t.length>1?t.join(" | "):t[0]??"unknown"}function Cp(o,e){if(!o)return"{}";let t=!!o.properties&&Object.keys(o.properties).length>0,n=o.additionalProperties===!0;if(!t)return n?"{ [key: string]: unknown }":"{}";let r=new Set(o.required??[]),s=e?.respectRequired??!1,i=Object.entries(o.properties).map(([a,l])=>{let c=oo(l),u=s&&!r.has(a)?"?":"";return`${a}${u}: ${c}`});return o.additionalProperties===!0&&i.push("[key: string]: unknown"),`{ ${i.join(", ")} }`}function Rf(o){let e=Cp(o.parameters,{respectRequired:!0}),t=o.returns?`: Promise<${oo(o.returns)}>`:"";return`- \`${o.qualifiedName}(args: ${e})${t}\``}function $a(o,e="",t=!0){if(!o?.properties)return[];let n=new Set(o.required??[]),r=[];for(let[s,i]of Object.entries(o.properties)){let a=e?`${e}.${s}`:s,l=i.description?.trim();l&&r.push({name:a,type:oo(i),required:t?n.has(s):void 0,description:l});let c=La(i);if(c.includes("object")&&i.properties&&r.push(...$a(i,a,!1)),c.includes("array")&&i.items){let u=i.items.description?.trim(),p=`${a}[]`;u&&r.push({name:p,type:oo(i.items),description:u}),La(i.items).includes("object")&&i.items.properties&&r.push(...$a(i.items,p,!1))}}return r}function vf(o){let e=$a(o);if(e.length!==0)return["#### Arguments",...e.map(t=>{let n=t.required===void 0?`\`${t.type}\``:`\`${t.type}\`, ${t.required?"required":"optional"}`;return`- \`${t.name}\` (${n}): ${t.description}`})].join(`
1392
- `)}function Sf(o){return!o||o.length===0?void 0:["#### Examples",o.map(t=>{let n=[];return t.title?.trim()&&n.push(`##### ${t.title.trim()}`),t.description?.trim()&&n.push(t.description.trim()),n.push(`\`\`\`${t.language?.trim()||"typescript"}`),n.push(t.code),n.push("```"),n.join(`
1370
+ ${n}${r}`}function Ha(o,e){return o instanceof at?lt(`[CLARIFICATION] ${o.question}`,e):lr(o,e)}function Up(o){return o instanceof rt&&o.status>=500&&o.status<600?!0:o instanceof Je||o instanceof dt}function lt(o,e){return o.length<=e?o:`${o.slice(0,e)}
1371
+ ...[truncated ${o.length-e} chars]`}function Ka(o,e){return e<=0?"":o.length<=e?o:e<=3?o.slice(0,e):`${o.slice(0,e-3)}...`}function uf(o){if(!o||typeof o!="object")return!1;let e=o;return typeof e.name=="string"&&typeof e.type=="string"&&(e.ctor===void 0||typeof e.ctor=="string")&&(e.size===void 0||typeof e.size=="string")&&(e.preview===void 0||typeof e.preview=="string")&&(e.restorable===void 0||typeof e.restorable=="boolean")}function Gp(o){let e=o.trim();if(!(!e||e[0]!=="{"&&e[0]!=="["))try{let t=JSON.parse(e),n=Array.isArray(t)?t:t&&typeof t=="object"&&Array.isArray(t.entries)?t.entries:void 0;return n?n.filter(uf):void 0}catch{return}}function jp(o,e){let t=e?.maxEntries&&e.maxEntries>0?e.maxEntries:void 0,n=e?.maxChars&&e.maxChars>0?e.maxChars:void 0,r=t?o.slice(0,t):[...o];if(!n)return r.join(`
1372
+ `);let s=[],i=0;for(let a of r){let u=s.length>0?1:0,c=n-i-u;if(c<=0)break;if(a.length<=c){s.push(a),i+=u+a.length;continue}s.push(Ka(a,c)),i=n;break}return s.join(`
1373
+ `)}function Bp(o,e){let t=o.split(`
1374
+ `).map(n=>n.trim()).filter(Boolean);return jp(t,e)}function Fp(o,e){let t=0;return e&&(t+=1e6,t+=e.createdTurn*100,t+=(e.lastReadTurn??e.createdTurn)*1e4,e.source&&(t+=25)),o.type==="accessor"?t-=100:o.type==="function"&&(t-=10),t}function cf(o){let e=o.type;return o.type==="object"&&o.ctor&&o.ctor!=="Object"?e=`object<${o.ctor}>`:o.type==="error"&&o.ctor&&o.ctor!=="Error"&&(e=`error<${o.ctor}>`),o.size&&(e+=` (${o.size})`),e}function lf(o){if(!o)return"";let e=[`from t${o.createdTurn}${o.source?` via ${o.source}`:""}`];return o.lastReadTurn!==void 0&&o.lastReadTurn>o.createdTurn&&e.push(`read t${o.lastReadTurn}`),` [${e.join("; ")}]`}function Ws(o,e,t){let n=[...o].sort((r,s)=>{let i=Fp(r,e.get(r.name));return Fp(s,e.get(s.name))-i||r.name.localeCompare(s.name)}).map(r=>{let s=r.preview?` = ${r.preview}`:"",i=lf(e.get(r.name)),a="restorable"in r&&r.restorable===!1?" [snapshot only]":"";return`${r.name}: ${cf(r)}${s}${i}${a}`});return n.length===0?"(no user variables)":jp(n,t)}function io(o,e){if(o===void 0)return"(no output)";if(typeof o=="string")return lt(o||"(no output)",e);try{return lt(JSON.stringify(o,null,2),e)}catch{return lt(String(o),e)}}function lr(o,e){let t=o,n=t?.name??"Error",r=t?.message??String(o),s=[`${n}: ${r}`];if(t?.data!==void 0)try{s.push(`Data: ${JSON.stringify(t.data,null,2)}`)}catch{s.push(`Data: ${String(t.data)}`)}if(t?.cause!==void 0){let i=(a,u)=>{if(u>4)return"[cause chain truncated]";let c=a,l=c?.name??"Error",p=c?.message??String(a),d=[`${l}: ${p}`];if(c?.data!==void 0)try{d.push(`Data: ${JSON.stringify(c.data,null,2)}`)}catch{d.push(`Data: ${String(c.data)}`)}return c?.cause!==void 0&&d.push(`Caused by: ${i(c.cause,u+1)}`),d.join(`
1375
+ `)};s.push(`Caused by: ${i(t.cause,1)}`)}return lt(s.join(`
1376
+ `),e)}function Wa(o){let e=$t(o);return/\bfinal\s*\(/.test(e)||/\bask_clarification\s*\(/.test(e)}function Va(o){return o&&(typeof o=="object"||typeof o=="function")&&"then"in o&&typeof o.then=="function"?!0:typeof o=="string"&&o.trim()==="[object Promise]"}function Ja(o){return o instanceof Error&&o.message==="Session is closed"}function zp(o){return o instanceof Error&&o.message==="Execution timed out"}function qp(o){return o.startsWith("[ERROR]")||o.startsWith(so)?!0:/^(AggregateError|Error|EvalError|RangeError|ReferenceError|SyntaxError|TypeError|URIError): /.test(o)}function Hp(o,e){if(e.kind==="threshold")return df(o)<=e.promptMaxChars?o:void 0;if(typeof o!="string")return;let t=e.keepInPromptChars;if(o.length<=t)return o;let n=o.length-t;if(e.reverseTruncate){let s=t>0?o.slice(-t):"";return`[truncated ${n} chars]...${s}`}return`${t>0?o.slice(0,t):""}...[truncated ${n} chars]`}function pf(o,e,t){return e.kind==="threshold"?t?`inline (<=${e.promptMaxChars} chars)`:`runtime-only (>${e.promptMaxChars} chars)`:typeof o!="string"?"runtime-only (keepInPromptChars requires string)":t?o.length<=e.keepInPromptChars?`inline (<=${e.keepInPromptChars} chars)`:e.reverseTruncate?`inline-truncated(last ${e.keepInPromptChars} chars of ${o.length})`:`inline-truncated(first ${e.keepInPromptChars} chars of ${o.length})`:"runtime-only"}function df(o){if(typeof o=="string")return o.length;try{return JSON.stringify(o).length}catch{return String(o).length}}function Kp(o,e,t){let n=new Set(e.map(a=>a.name)),r=new Set,s=[],i=new Map;for(let a of o){let u=typeof a=="string"?a:a.field;if(!n.has(u))throw new Error(`RLM contextField "${u}" not found in signature`);if(r.has(u))throw new Error(`Duplicate contextField "${u}"`);if(r.add(u),s.push(u),typeof a!="string"){let c=a.keepInPromptChars!==void 0,l=a.promptMaxChars!==void 0;if(c&&l)throw new Error(`contextField "${u}" cannot set both promptMaxChars and keepInPromptChars`);if("reverseTruncate"in a&&!c)throw new Error(`contextField "${u}" reverseTruncate requires keepInPromptChars`);if(c){let d=a.keepInPromptChars;if(!Number.isFinite(d)||d===void 0||d<0)throw new Error(`contextField "${u}" keepInPromptChars must be a finite number >= 0`);i.set(u,{kind:"truncate",keepInPromptChars:d,reverseTruncate:a.reverseTruncate===!0});continue}let p=a.promptMaxChars??t;if(!Number.isFinite(p)||p<0)throw new Error(`contextField "${u}" promptMaxChars must be a finite number >= 0`);i.set(u,{kind:"threshold",promptMaxChars:p})}}return{contextFieldNames:s,promptConfigByField:i}}function Wp(o,e){let t=[];for(let[n,r]of Object.entries(o)){let s=Array.isArray(r)?"array":typeof r,i=typeof r=="string"?`${r.length} chars`:Array.isArray(r)?`${r.length} items`:r&&typeof r=="object"?`${Object.keys(r).length} keys`:"n/a",a=e?.promptConfigByField?.get(n),u=a===void 0?"runtime-only":pf(r,a,e?.inlinedFields?.has(n)===!0);t.push(`- ${n}: type=${s}, size=${i}, prompt=${u}`)}return t.join(`
1377
+ `)}async function Vp(o,e,t,n){if(o.length===0)return[];let r=new Array(o.length),s=0,i=Math.max(1,Math.min(e,o.length)),a=Array.from({length:i},async()=>{for(;;){if(n?.aborted)return;let u=s++;if(u>=o.length)return;let c=o[u];if(c===void 0)return;r[u]=await t(c,u)}});return await Promise.all(a),r}function Jp(o){return o.includes("console.log")}function Qp(o){let e=$t(o),t=/\bfinal\s*\(/.test(e),n=/\bask_clarification\s*\(/.test(e),r=Number(t)+Number(n),s=mf(e);if(r>1)return"[POLICY] Use exactly one completion signal per turn: either final(...) or ask_clarification(...), not both.";if(r===1)return s.length>0?"[POLICY] Do not combine console.log(...) with final(...)/ask_clarification(...) in the same turn. Inspect in one turn, then complete in the next turn.":void 0;if(s.length===0)return"[POLICY] Non-final turns must include exactly one console.log(...) so the next turn can reason from its output.";if(s.length>1)return"[POLICY] Use exactly one console.log(...) per non-final turn, then stop.";let i=s[0];if(i===void 0)return"[POLICY] Unable to verify console.log(...) usage. Emit exactly one console.log(...) per non-final turn.";if(i.closeParenIndex===void 0)return"[POLICY] Could not parse console.log(...). Keep a single valid console.log(...) call as the last statement in non-final turns.";if(e.slice(i.closeParenIndex+1).replace(/^[\s;]+/,"").length>0)return"[POLICY] End non-final turns immediately after console.log(...). Do not execute additional statements after logging."}function mf(o){let e=o.matchAll(/\bconsole\s*\.\s*log\s*\(/g),t=[];for(let n of e){let r=n[0];if(r===void 0)continue;let s=n.index??-1;if(s<0)continue;let i=r.lastIndexOf("("),a=s+i,u=gf(o,a);t.push({closeParenIndex:u})}return t}function gf(o,e){if(e<0||o[e]!=="(")return;let t=0;for(let n=e;n<o.length;n++){let r=o[n];if(r==="(")t++;else if(r===")"&&(t--,t===0))return n}}function Yp(o,e){if(!o.properties||e.size===0)return o;let t=Object.fromEntries(Object.entries(o.properties).filter(([r])=>!e.has(r))),n=o.required?.filter(r=>!e.has(r));return{...o,properties:t,...n!==void 0?{required:n}:{}}}function Xp(o,e){let t=o.trim(),r=e?.normalize??!0?Ya(t):t;if(!r)throw new Error("Agent module namespace must contain letters or numbers");return r}function _p(o){return Array.isArray(o.functions)}function Vs(o,e){if(!o||o.length===0)return{functions:[],moduleMetadata:[]};let t=o.every(a=>_p(a)),n=o.every(a=>!_p(a));if(!t&&!n)throw new Error("Agent functions collections must contain either flat functions or grouped function modules, not both");if(n)return{functions:[...o],moduleMetadata:[]};let r=new Set,s=[],i=[];for(let a of o){let u=a.namespace.trim(),c=a.title.trim(),l=a.selectionCriteria?.trim()||void 0,p=a.description?.trim()||void 0;if(!u)throw new Error("Agent function group namespace must be a non-empty string");if(!c)throw new Error(`Agent function group "${u}" must define a non-empty title`);if(e.has(u))throw new Error(`Agent function namespace "${u}" conflicts with an AxAgent runtime global and is reserved`);if(r.has(u))throw new Error(`Duplicate agent function group namespace "${u}"`);if(a.functions.length===0)throw new Error(`Agent function group "${u}" must contain at least one function`);r.add(u),s.push({namespace:u,title:c,selectionCriteria:l,description:p});for(let d of a.functions){if("namespace"in d&&d.namespace!==void 0)throw new Error(`Grouped agent function "${u}.${d.name}" must not define namespace; use the parent group namespace instead`);i.push({...d,namespace:u})}}return{functions:i,moduleMetadata:s}}function Qa(o,e){if(typeof o=="string"){let n=o.trim();if(n.length===0)throw new Error(`${e} must be a non-empty string`);return[n]}if(!Array.isArray(o))throw new Error(`${e} must be a string or string[]`);if(!o.every(n=>typeof n=="string"))throw new Error(`${e} must contain only strings`);let t=o.map(n=>n).map(n=>n.trim()).filter(n=>n.length>0);if(t.length===0)throw new Error(`${e} must contain at least one non-empty string`);return[...new Set(t)]}function za(o){let e=o.type;return Array.isArray(e)?e.filter(t=>typeof t=="string"):typeof e=="string"?e.includes(",")?e.split(",").map(t=>t.trim()).filter(Boolean):[e]:[]}function ff(o){let e=new Set(o);return e.has("object")&&e.has("array")&&e.has("string")&&e.has("number")&&e.has("boolean")&&e.has("null")}function oo(o){if(o.enum)return o.enum.map(n=>`"${n}"`).join(" | ");let e=za(o);if(e.length===0)return"unknown";if(ff(e))return"any";let t=[...new Set(e)].map(n=>{if(n==="array"){let r=o.items?oo(o.items):"unknown";return r.includes(" | ")?`(${r})[]`:`${r}[]`}return n==="object"?o.properties&&Object.keys(o.properties).length>0?Zp(o):"object":n});return t.length>1?t.join(" | "):t[0]??"unknown"}function Zp(o,e){if(!o)return"{}";let t=!!o.properties&&Object.keys(o.properties).length>0,n=o.additionalProperties===!0;if(!t)return n?"{ [key: string]: unknown }":"{}";let r=new Set(o.required??[]),s=e?.respectRequired??!1,i=Object.entries(o.properties).map(([a,u])=>{let c=oo(u),l=s&&!r.has(a)?"?":"";return`${a}${l}: ${c}`});return o.additionalProperties===!0&&i.push("[key: string]: unknown"),`{ ${i.join(", ")} }`}function hf(o){let e=Zp(o.parameters,{respectRequired:!0}),t=o.returns?`: Promise<${oo(o.returns)}>`:"";return`- \`${o.qualifiedName}(args: ${e})${t}\``}function qa(o,e="",t=!0){if(!o?.properties)return[];let n=new Set(o.required??[]),r=[];for(let[s,i]of Object.entries(o.properties)){let a=e?`${e}.${s}`:s,u=i.description?.trim();u&&r.push({name:a,type:oo(i),required:t?n.has(s):void 0,description:u});let c=za(i);if(c.includes("object")&&i.properties&&r.push(...qa(i,a,!1)),c.includes("array")&&i.items){let l=i.items.description?.trim(),p=`${a}[]`;l&&r.push({name:p,type:oo(i.items),description:l}),za(i.items).includes("object")&&i.items.properties&&r.push(...qa(i.items,p,!1))}}return r}function xf(o){let e=qa(o);if(e.length!==0)return["#### Arguments",...e.map(t=>{let n=t.required===void 0?`\`${t.type}\``:`\`${t.type}\`, ${t.required?"required":"optional"}`;return`- \`${t.name}\` (${n}): ${t.description}`})].join(`
1378
+ `)}function Af(o){return!o||o.length===0?void 0:["#### Examples",o.map(t=>{let n=[];return t.title?.trim()&&n.push(`##### ${t.title.trim()}`),t.description?.trim()&&n.push(t.description.trim()),n.push(`\`\`\`${t.language?.trim()||"typescript"}`),n.push(t.code),n.push("```"),n.join(`
1393
1379
  `)}).join(`
1394
1380
 
1395
1381
  `)].join(`
1396
- `)}function kf(o,e,t){return o.map(n=>{let r=[...e.get(n)??[]].map(c=>c.split(".").pop()??c).sort((c,u)=>c.localeCompare(u)),s=r.length>0,i=s?t.get(n):void 0,a=s?r.map(c=>`- \`${c}\``).join(`
1397
- `):`- Error: module \`${n}\` does not exist.`,l=[`### Module \`${n}\``];return i&&(l.push(`**${i.title}**`),i.description&&l.push(i.description)),l.push(a),l.join(`
1382
+ `)}function ed(o,e,t){return o.map(n=>{let r=[...e.get(n)??[]].map(c=>c.split(".").pop()??c).sort((c,l)=>c.localeCompare(l)),s=r.length>0,i=s?t.get(n):void 0,a=s?r.map(c=>`- \`${c}\``).join(`
1383
+ `):`- Error: module \`${n}\` does not exist.`,u=[`### Module \`${n}\``];return i&&u.push(`**${i.title}**`),u.push(a),i?.description&&u.push(i.description),u.join(`
1398
1384
  `)}).join(`
1399
1385
 
1400
- `)}function Of(o,e){return o.map(t=>{let n=t.includes(".")?t:`utils.${t}`,r=e.get(n);return r?[`### \`${n}\``,r.description,Rf({qualifiedName:n,parameters:r.parameters,returns:r.returns}),vf(r.parameters),Sf(r.examples)].filter(s=>!!s).join(`
1386
+ `)}function td(o,e){return o.map(t=>{let n=t.includes(".")?t:`utils.${t}`,r=e.get(n);return r?[`### \`${n}\``,r.description,hf({qualifiedName:n,parameters:r.parameters,returns:r.returns}),xf(r.parameters),Af(r.examples)].filter(s=>!!s).join(`
1401
1387
  `):`### \`${n}\`
1402
1388
  - Not found.`}).join(`
1403
1389
 
1404
- `)}function Ip(o){return o.split(/[^a-zA-Z0-9]/).map((n,r)=>{let s=n.toLowerCase();return r>0&&s&&s[0]?s[0].toUpperCase()+s.slice(1):s}).join("")}var wp=(o,e)=>{let t=e?.maxHops??3,n=e?.qualityThreshold??.8,r=e?.maxIterations??2,s=e?.qualityTarget??.85,i=e?.disableQualityHealing??!1;return vs({logger:e?.logger,debug:e?.debug}).node("queryGenerator","originalQuestion:string, previousContext?:string -> searchQuery:string, queryReasoning:string").node("contextualizer","retrievedDocument:string, accumulatedContext?:string -> enhancedContext:string").node("qualityAssessor","currentContext:string, originalQuestion:string -> completenessScore:number, missingAspects:string[]").node("questionDecomposer","complexQuestion:string -> subQuestions:string[], decompositionReason:string").node("evidenceSynthesizer","collectedEvidence:string[], originalQuestion:string -> synthesizedEvidence:string, evidenceGaps:string[]").node("gapAnalyzer","synthesizedEvidence:string, evidenceGaps:string[], originalQuestion:string -> needsMoreInfo:boolean, focusedQueries:string[]").node("answerGenerator","finalContext:string, originalQuestion:string -> comprehensiveAnswer:string, confidenceLevel:number").node("queryRefiner","originalQuestion:string, currentContext:string, missingAspects:string[] -> refinedQuery:string").node("qualityValidator","generatedAnswer:string, userQuery:string -> qualityScore:number, issues:string[]").node("answerHealer","originalAnswer:string, healingDocument:string, issues?:string[] -> healedAnswer:string").map(a=>({...a,maxHops:t,qualityThreshold:n,maxIterations:r,qualityTarget:s,disableQualityHealing:i,currentHop:0,accumulatedContext:"",retrievedContexts:[],completenessScore:0,searchQuery:a.originalQuestion,shouldContinue:!0,iteration:0,allEvidence:[],evidenceSources:[],needsMoreInfo:!0,healingAttempts:0,currentQuality:0,shouldContinueHealing:!0,currentAnswer:"",currentIssues:[]})).while(a=>a.currentHop<a.maxHops&&a.completenessScore<a.qualityThreshold&&a.shouldContinue).map(a=>({...a,currentHop:a.currentHop+1})).execute("queryGenerator",a=>({originalQuestion:a.originalQuestion,previousContext:a.accumulatedContext||void 0})).map(async a=>{let l=a.queryGeneratorResult?.searchQuery||a.searchQuery||a.originalQuestion,c=await o(l);return{...a,retrievalResult:{retrievedDocument:c,retrievalConfidence:.9}}}).execute("contextualizer",a=>({retrievedDocument:a.retrievalResult.retrievedDocument,accumulatedContext:a.accumulatedContext||void 0})).execute("qualityAssessor",a=>({currentContext:a.contextualizerResult.enhancedContext,originalQuestion:a.originalQuestion})).map(a=>({...a,accumulatedContext:a.contextualizerResult.enhancedContext,retrievedContexts:[...a.retrievedContexts,a.retrievalResult.retrievedDocument],completenessScore:a.qualityAssessorResult.completenessScore,searchQuery:a.queryGeneratorResult.searchQuery,shouldContinue:a.qualityAssessorResult.completenessScore<a.qualityThreshold})).branch(a=>a.shouldContinue&&a.currentHop<a.maxHops).when(!0).execute("queryRefiner",a=>({originalQuestion:a.originalQuestion,currentContext:a.accumulatedContext,missingAspects:a.qualityAssessorResult.missingAspects})).map(a=>({...a,searchQuery:a.queryRefinerResult?.refinedQuery||a.searchQuery})).when(!1).map(a=>a).merge().endWhile().map(a=>({...a,allEvidence:a.retrievedContexts.length>0?a.retrievedContexts:[]})).while(a=>a.iteration<a.maxIterations&&a.needsMoreInfo).map(a=>({...a,iteration:a.iteration+1})).branch(a=>a.iteration===1).when(!0).execute("questionDecomposer",a=>({complexQuestion:a.originalQuestion})).map(a=>({...a,currentQueries:a.questionDecomposerResult.subQuestions})).when(!1).map(a=>({...a,currentQueries:a.gapAnalyzerResult?.focusedQueries||[]})).merge().map(async a=>{let l=a.currentQueries||[],c=l.length>0?await Promise.all(l.filter(Boolean).map(u=>o(u))):[];return{...a,retrievalResults:c}}).execute("evidenceSynthesizer",a=>{let l=Array.isArray(a.allEvidence)?a.allEvidence:[],c=Array.isArray(a.retrievalResults)?a.retrievalResults:[],u=[...l,...c].filter(Boolean);return{collectedEvidence:u.length>0?u:["No evidence collected yet"],originalQuestion:a.originalQuestion}}).execute("gapAnalyzer",a=>({synthesizedEvidence:a.evidenceSynthesizerResult.synthesizedEvidence,evidenceGaps:a.evidenceSynthesizerResult.evidenceGaps,originalQuestion:a.originalQuestion})).map(a=>({...a,allEvidence:[...Array.isArray(a.allEvidence)?a.allEvidence:[],...Array.isArray(a.retrievalResults)?a.retrievalResults:[]],evidenceSources:[...Array.isArray(a.evidenceSources)?a.evidenceSources:[],`Iteration ${a.iteration} sources`],needsMoreInfo:a.gapAnalyzerResult.needsMoreInfo,synthesizedEvidence:a.evidenceSynthesizerResult.synthesizedEvidence})).endWhile().execute("answerGenerator",a=>({finalContext:(()=>{let l=(a.accumulatedContext||"").toString().trim();if(l.length>0)return l;let c=(a.synthesizedEvidence||"").toString().trim();if(c.length>0)return c;let p=(Array.isArray(a.allEvidence)?a.allEvidence.filter(Boolean).join(`
1405
- `):"").toString().trim();return p.length>0?p:"No context available."})(),originalQuestion:a.originalQuestion})).branch(a=>!a.disableQualityHealing).when(!0).execute("qualityValidator",a=>({generatedAnswer:a.answerGeneratorResult.comprehensiveAnswer,userQuery:a.originalQuestion})).map(a=>({...a,currentAnswer:a.answerGeneratorResult.comprehensiveAnswer,currentQuality:a.qualityValidatorResult.qualityScore,currentIssues:a.qualityValidatorResult.issues,shouldContinueHealing:a.qualityValidatorResult.qualityScore<a.qualityTarget})).while(a=>a.healingAttempts<3&&a.shouldContinueHealing).map(a=>({...a,healingAttempts:a.healingAttempts+1})).map(async a=>{let l=a.currentIssues||[],c=l.length>0?`${a.originalQuestion} addressing issues: ${l.join(", ")}`:`${a.originalQuestion} quality improvement`,u=await o(c);return{...a,healingResult:{healingDocument:u}}}).execute("answerHealer",a=>({originalAnswer:a.currentAnswer,healingDocument:a.healingResult.healingDocument,issues:a.currentIssues})).execute("qualityValidator",a=>({generatedAnswer:a.answerHealerResult.healedAnswer,userQuery:a.originalQuestion})).map(a=>({...a,currentAnswer:a.answerHealerResult.healedAnswer,currentQuality:a.qualityValidatorResult.qualityScore,currentIssues:a.qualityValidatorResult.issues,shouldContinueHealing:a.qualityValidatorResult.qualityScore<a.qualityTarget})).endWhile().when(!1).map(a=>({...a,currentAnswer:a.answerGeneratorResult.comprehensiveAnswer,currentQuality:1,currentIssues:[],shouldContinueHealing:!1})).merge().returns(a=>({finalAnswer:a.currentAnswer,totalHops:a.currentHop,retrievedContexts:a.retrievedContexts,iterationCount:a.iteration,healingAttempts:a.healingAttempts,qualityAchieved:a.currentQuality}))};
1390
+ `)}function Ya(o){let e=o.trim().split(/[^A-Za-z0-9_$]+/).map(t=>t.trim()).filter(Boolean);return e.length===0?"":e.map((t,n)=>{let r=t.toLowerCase();return n===0?r:r.charAt(0).toUpperCase()+r.slice(1)}).join("")}function yf(o){return typeof structuredClone=="function"?structuredClone(o):JSON.parse(JSON.stringify(o))}function dn(o){return yf(o)}function nd(o){return o.map(e=>({turn:e.turn,code:e.code,output:e.output,actorFieldsOutput:e.actorFieldsOutput,tags:[...e.tags],...e.summary?{summary:e.summary}:{},...e.producedVars?{producedVars:[...e.producedVars]}:{},...e.referencedVars?{referencedVars:[...e.referencedVars]}:{},...e.stateDelta?{stateDelta:e.stateDelta}:{},...e.stepKind?{stepKind:e.stepKind}:{},...e.replayMode?{replayMode:e.replayMode}:{},...e.rank!==void 0?{rank:e.rank}:{},...e.tombstone?{tombstone:e.tombstone}:{}}))}function rd(o){return(o??[]).map(e=>({turn:e.turn,code:e.code,output:e.output,actorFieldsOutput:e.actorFieldsOutput,tags:[...e.tags],...e.summary?{summary:e.summary}:{},...e.producedVars?{producedVars:[...e.producedVars]}:{},...e.referencedVars?{referencedVars:[...e.referencedVars]}:{},...e.stateDelta?{stateDelta:e.stateDelta}:{},...e.stepKind?{stepKind:e.stepKind}:{},...e.replayMode?{replayMode:e.replayMode}:{},...e.rank!==void 0?{rank:e.rank}:{},...e.tombstone?{tombstone:e.tombstone}:{}}))}function od(o){return Object.fromEntries([...o.entries()].map(([e,t])=>[e,{...t}]))}function sd(o,e){let t=o.filter(r=>r.restorable===!1).length,n=["Runtime Restore:","- Runtime state was restored from a previous call.","- Continue from restored values unless recomputation is actually needed."];return e?.includeLiveRuntimeState!==!1?n.splice(2,0,"- Live Runtime State below reflects the restored bindings."):n.splice(2,0,"- Live Runtime State rendering is disabled for this run, but the restored bindings are available in the runtime session."),t>0&&n.push(`- ${t} prior value${t===1?" was":"s were"} snapshot-only and could not be restored.`),n.join(`
1391
+ `)}function id(o){return new Map(Object.entries(o??{}).map(([e,t])=>[e,{...t}]))}function ad(o,e){let t=new Map;for(let[n,r]of o.entries())t.set(n,{...r});for(let[n,r]of e.entries())t.set(n,{...r});return t}var at=class extends Error{question;clarification;stateSnapshot;stateErrorMessage;constructor(e,t){let n=Ba(e);super(n.question),this.name="AxAgentClarificationError",this.question=n.question,this.clarification=n,this.stateSnapshot=t?.state?dn(t.state):void 0,this.stateErrorMessage=t?.stateError}getState(){if(this.stateErrorMessage)throw new Error(this.stateErrorMessage);return this.stateSnapshot?dn(this.stateSnapshot):void 0}};function If(){let o=new Map,e={nextNodeOrdinal:1,nodesById:o,rootNode:void 0,createNode:({parentId:t,depth:n,role:r,taskDigest:s,contextDigest:i})=>{let a=`trace_${e.nextNodeOrdinal++}`,u={nodeId:a,parentId:t,depth:n,role:r,taskDigest:s,contextDigest:i,completionType:void 0,turnCount:0,actorTurns:[],functionCalls:[],toolErrors:[],localUsage:{promptTokens:0,completionTokens:0,totalTokens:0},children:[]};return o.set(a,u),t?o.get(t)?.children.push(u):e.rootNode=u,u}};return e}function Za(o){let e=o.children.map(r=>Za(r)),t=o.localUsage,n=e.reduce((r,s)=>({promptTokens:r.promptTokens+s.cumulativeUsage.promptTokens,completionTokens:r.completionTokens+s.cumulativeUsage.completionTokens,totalTokens:r.totalTokens+s.cumulativeUsage.totalTokens}),{...t});return{nodeId:o.nodeId,parentId:o.parentId,depth:o.depth,role:o.role,taskDigest:o.taskDigest,contextDigest:o.contextDigest,completionType:o.completionType,turnCount:o.turnCount,childCount:e.length,actorTurns:[...o.actorTurns],functionCalls:[...o.functionCalls],toolErrors:[...o.toolErrors],localUsage:{...t},cumulativeUsage:n,children:e}}var ao=class o{ai;judgeAI;program;actorProgram;responderProgram;agents;agentFunctions;agentFunctionModuleMetadata=new Map;debug;options;rlmConfig;runtime;actorFieldNames;localFieldNames;sharedFieldNames;globalSharedFieldNames;excludedSharedFields;excludedAgents;excludedAgentFunctions;actorDescription;actorPromptLevel;actorModelPolicy;responderDescription;judgeOptions;recursionForwardOptions;actorForwardOptions;responderForwardOptions;inputUpdateCallback;contextPromptConfigByField=new Map;agentModuleNamespace=to;functionDiscoveryEnabled=!1;runtimeUsageInstructions="";enforceIncrementalConsoleTurns=!1;activeAbortControllers=new Set;_stopRequested=!1;state;stateError;runtimeBootstrapContext=void 0;llmQueryBudgetState;recursiveInstructionSlots=cr();baseActorDefinition="";recursiveEvalContext;currentRecursiveTraceNodeId;recursiveInstructionRoleOverride;func;_parentSharedFields=new Set;_parentSharedAgents=new Set;_parentSharedAgentFunctions=new Set;_reservedAgentFunctionNamespaces(){return new Set(["inputs","llmQuery","final","ask_clarification","inspect_runtime",to,this.agentModuleNamespace,...this.functionDiscoveryEnabled?[Hs,Ks]:[]])}_mergeAgentFunctionModuleMetadata(e){let t=!1;for(let n of e){let r=this.agentFunctionModuleMetadata.get(n.namespace);if(!r){this.agentFunctionModuleMetadata.set(n.namespace,n),t=!0;continue}if(r.title!==n.title||r.selectionCriteria!==n.selectionCriteria||r.description!==n.description)throw new Error(`Conflicting agent function group metadata for namespace "${n.namespace}"`)}return t}_validateConfiguredSignature(e){if(e.getDescription())throw new Error("AxAgent does not support signature-level descriptions. Use setActorDescription() and/or setResponderDescription() to customize the actor and responder prompts independently.");let t=new Set(e.getInputFields().map(r=>r.name)),n=new Set(e.getOutputFields().map(r=>r.name));for(let r of this.rlmConfig.contextFields)if(!t.has(r))throw new Error(`RLM contextField "${r}" not found in signature`);for(let r of this.sharedFieldNames)if(!t.has(r))throw new Error(`sharedField "${r}" not found in signature input fields`);for(let r of this.globalSharedFieldNames)if(!t.has(r))throw new Error(`globalSharedField "${r}" not found in signature input fields`);for(let r of this.actorFieldNames)if(!n.has(r))throw new Error(`RLM actorField "${r}" not found in output signature`)}_validateAgentFunctionNamespaces(e){let t=this._reservedAgentFunctionNamespaces();for(let n of e){let r=n.namespace??"utils";if(t.has(r))throw new Error(`Agent function namespace "${r}" conflicts with an AxAgent runtime global and is reserved`)}}_supportsRecursiveActorSlotOptimization(){if((this.rlmConfig.mode??"simple")!=="advanced")return!1;let e=this.recursionForwardOptions?.maxDepth??2;return!!this.recursiveInstructionRoleOverride||Math.max(0,e)>0}_getRecursiveActorRole(){if((this.rlmConfig.mode??"simple")!=="advanced")return;if(this.recursiveInstructionRoleOverride)return this.recursiveInstructionRoleOverride;let e=this.recursionForwardOptions?.maxDepth??2;return Math.max(0,e)>0?"root":void 0}_applyRecursiveActorInstruction(){let e=this._getRecursiveActorRole();if(!e||!this.actorProgram)return;let t=mp(e,this.recursiveInstructionSlots),n=[this.baseActorDefinition.trim(),t?.trim()].filter(r=>!!r).join(`
1392
+
1393
+ `);this.actorProgram.setDescription(n),this.actorProgram.setInstruction(n)}_setRecursiveInstructionSlot(e,t){if(e===le.responder){this.responderProgram.setInstruction(t??"");return}this.recursiveInstructionSlots[e]=t??"",this._applyRecursiveActorInstruction()}_copyRecursiveOptimizationStateTo(e){e.recursiveInstructionSlots={...this.recursiveInstructionSlots},e.recursiveInstructionRoleOverride=e._supportsRecursiveActorSlotOptimization()?e.recursiveInstructionRoleOverride:void 0,e._applyRecursiveActorInstruction()}constructor({ai:e,judgeAI:t,agentIdentity:n,agentModuleNamespace:r,signature:s},i){let{debug:a,contextFields:u=[],runtime:c,maxSubAgentCalls:l,maxRuntimeChars:p,maxBatchedLlmQueryConcurrency:d,maxTurns:m,contextPolicy:g,actorFields:f,actorTurnCallback:x,mode:A,promptLevel:h,actorModelPolicy:y,recursionOptions:C,actorOptions:I,responderOptions:v,judgeOptions:O,inputUpdateCallback:R}=i;this.ai=e,this.judgeAI=t,this.agents=i.agents?.local,this.functionDiscoveryEnabled=i.functions?.discovery??!1,this.debug=a,this.options=i,this.runtime=c??new pn,this.runtimeUsageInstructions=this.runtime.getUsageInstructions(),this.enforceIncrementalConsoleTurns=Jp(this.runtimeUsageInstructions);let E=r??n?.namespace??to;if(this.agentModuleNamespace=Xp(E,{normalize:r===void 0}),new Set(["inputs","llmQuery","final","ask_clarification","inspect_runtime",Hs,Ks]).has(this.agentModuleNamespace))throw new Error(`Agent module namespace "${this.agentModuleNamespace}" is reserved`);let _=this._reservedAgentFunctionNamespaces(),$=Vs(i.functions?.local,_),M=Vs(i.functions?.shared,_),F=Vs(i.functions?.globallyShared,_);this.agentFunctions=$.functions,this._mergeAgentFunctionModuleMetadata($.moduleMetadata);let{agents:N,fields:G,functions:W,judgeOptions:U,inputUpdateCallback:ae,promptLevel:j,actorModelPolicy:re,...oe}=i;this.program=new Pe(s,oe);let Ce=this.program.getSignature().getInputFields(),L=Kp(u,Ce,1200);this.contextPromptConfigByField=L.promptConfigByField,this.rlmConfig={contextFields:L.contextFieldNames,sharedFields:i.fields?.shared,runtime:this.runtime,maxSubAgentCalls:l,maxRuntimeChars:p,maxBatchedLlmQueryConcurrency:d,maxTurns:m,contextPolicy:g,actorFields:f,actorTurnCallback:x,mode:A},this.recursionForwardOptions=C;let{description:K,...ee}=I??{},{description:he,...q}=v??{};this.actorDescription=K,this.actorPromptLevel=h??"detailed",this.actorModelPolicy=hp(y),this.actorForwardOptions=ee,this.recursiveInstructionSlots=cr(K),this.responderDescription=he,this.responderForwardOptions=q,this.judgeOptions=O?{...O}:void 0,this.inputUpdateCallback=R;let B=this.agents;for(let X of B??[]){let xe=X.getFunction().name;this.program.register(X,xe)}n&&(this.func={name:Ya(n.name),description:n.description,parameters:this._buildFuncParameters(),func:async()=>{throw new Error("Use getFunction() to get a callable wrapper")}});let ue=f??[];this.actorFieldNames=ue;let ke=i.fields?.shared??[];this.sharedFieldNames=ke,this.excludedSharedFields=i.fields?.excluded??[];let Oe=i.fields?.globallyShared??[];this.globalSharedFieldNames=Oe,this.localFieldNames=i.fields?.local??[];let ce=i.agents?.shared??[],Re=i.agents?.globallyShared??[];this.excludedAgents=i.agents?.excluded??[];let se=M.functions,de=F.functions;this.excludedAgentFunctions=i.functions?.excluded??[];let J=[...this.agentFunctions,...se,...de];for(let X of J){if(!X.parameters)throw new Error(`Agent function "${X.name}" must define parameters schema for agent runtime usage.`);if(X.examples){for(let[xe,we]of X.examples.entries())if(!we.code.trim())throw new Error(`Agent function "${X.name}" example at index ${xe} must define non-empty code`)}}if(this._validateConfiguredSignature(this.program.getSignature()),this._validateAgentFunctionNamespaces(J),ke.length>0&&B){let X=Ce.filter(xe=>ke.includes(xe.name));for(let xe of B){if(!(xe instanceof o))continue;let we=new Set(xe.getExcludedSharedFields()),Be=X.filter($e=>!we.has($e.name));Be.length!==0&&xe._extendForSharedFields(Be,this.rlmConfig.contextFields)}}if(ce.length>0&&B)for(let X of B)X instanceof o&&X._extendForSharedAgents(ce);if(Oe.length>0&&B){let X=Ce.filter(xe=>Oe.includes(xe.name));for(let xe of B){if(!(xe instanceof o))continue;let we=new Set(xe.getExcludedSharedFields()),Be=X.filter($e=>!we.has($e.name));Be.length!==0&&xe._extendForGlobalSharedFields(Be,this.rlmConfig.contextFields)}}if(Re.length>0&&B)for(let X of B)X instanceof o&&X._extendForGlobalSharedAgents(Re);if(se.length>0&&B)for(let X of B)X instanceof o&&X._extendForSharedAgentFunctions(M);if(de.length>0&&B)for(let X of B)X instanceof o&&X._extendForGlobalSharedAgentFunctions(F);this._buildSplitPrograms(),this.program.register(this.actorProgram,"actor"),this.program.register(this.responderProgram,"responder")}_buildSplitPrograms(){let e=this.program.getSignature().getInputFields(),t=this.rlmConfig.contextFields,n=this._getBypassedSharedFieldNames(),r=e.filter(R=>t.includes(R.name)),s=r.filter(R=>this.contextPromptConfigByField.has(R.name)&&!n.has(R.name)).map(R=>({...R,isOptional:!0})),i=e.filter(R=>!t.includes(R.name)&&!n.has(R.name)),a=this.program.getSignature().getOutputFields(),u=a.filter(R=>this.actorFieldNames.includes(R.name)),c=a.filter(R=>!this.actorFieldNames.includes(R.name)),l=me().addInputFields(i).addInputFields(s).input("contextMetadata",me.string("Metadata about pre-loaded context variables (type and size)")).input("actionLog",me.string("Chronological trace of code executions or actions and their outputs so far")).output("javascriptCode",me.code("JavaScript code to execute in runtime session"));u.length>0&&(l=l.addOutputFields(u));let p=l.build(),d=me().addInputFields(i).input("contextData",me.json("Context data to help synthesize the final answer.")).addOutputFields(c).build(),m=this.rlmConfig.maxSubAgentCalls??8,g=this.rlmConfig.maxTurns??8,f=this.recursionForwardOptions?.maxDepth??2,x=(this.rlmConfig.mode??"simple")==="advanced"?Math.max(0,f)>0?"advanced-recursive":"simple-at-terminal-depth":"simple",A=this.agents?.map(R=>{let E=R.getFunction();return{name:E.name,description:E.description,parameters:E.parameters}})??[],h=this.agentFunctions.map(R=>({name:R.name,description:R.description,parameters:R.parameters,returns:R.returns,namespace:R.namespace??"utils"})),y=new Set(h.map(R=>R.namespace??"utils"));A.length>0&&y.add(this.agentModuleNamespace);let C=[...y].sort((R,E)=>R.localeCompare(E)).map(R=>({namespace:R,selectionCriteria:this.agentFunctionModuleMetadata.get(R)?.selectionCriteria})),I=$a(this.rlmConfig.contextPolicy),v=js(this._supportsRecursiveActorSlotOptimization()?void 0:this.actorDescription,r,c,{runtimeUsageInstructions:this.runtimeUsageInstructions,promptLevel:this.actorPromptLevel,maxSubAgentCalls:m,maxTurns:g,hasInspectRuntime:I.stateInspection.enabled,hasLiveRuntimeState:I.stateSummary.enabled,hasCompressedActionReplay:I.actionReplay!=="full"||I.checkpoints.enabled||I.errorPruning||!!I.tombstoning||this.functionDiscoveryEnabled&&I.pruneUsedDocs,llmQueryPromptMode:x,enforceIncrementalConsoleTurns:this.enforceIncrementalConsoleTurns,agentModuleNamespace:this.agentModuleNamespace,discoveryMode:this.functionDiscoveryEnabled,availableModules:C,agents:A,agentFunctions:h});this.baseActorDefinition=v;let O=Bs(this.responderDescription,r);this.actorProgram?(this.actorProgram.setSignature(p),this.actorProgram.setDescription(v)):this.actorProgram=new Pe(p,{...this._genOptions,description:v}),this.responderProgram?(this.responderProgram.setSignature(d),this.responderProgram.setDescription(O)):this.responderProgram=new Pe(d,{...this._genOptions,description:O}),this._applyRecursiveActorInstruction()}_extendForSharedFields(e,t){let n=this.program.getSignature(),r=n.getInputFields(),s=!1;for(let i of e){if(r.some(a=>a.name===i.name)){if(this._parentSharedFields.has(i.name))throw new Error(`Duplicate shared field "${i.name}" \u2014 already propagated from a parent`);continue}this._parentSharedFields.add(i.name),n.addInputField(i),s=!0}s&&this.program.setSignature(n);for(let i of e)t.includes(i.name)&&!this.rlmConfig.contextFields.includes(i.name)&&this.rlmConfig.contextFields.push(i.name);this._buildSplitPrograms(),this.func&&(this.func.parameters=this._buildFuncParameters())}_extendForSharedAgents(e){if(e.length===0)return;let t=new Set((this.agents??[]).map(s=>s.getFunction().name)),n=new Set(this.excludedAgents),r=[];for(let s of e){if(s===this)continue;let i=s.getFunction().name;if(!n.has(i)){if(t.has(i)){if(this._parentSharedAgents.has(i))throw new Error(`Duplicate shared agent "${i}" \u2014 already propagated from a parent`);continue}this._parentSharedAgents.add(i),t.add(i),r.push(s)}}if(r.length!==0){this.agents=[...this.agents??[],...r];for(let s of r){let i=s.getFunction().name;this.program.register(s,i)}this._buildSplitPrograms()}}_extendForGlobalSharedFields(e,t){let n=this.program.getSignature(),r=n.getInputFields(),s=!1;for(let i of e){if(r.some(a=>a.name===i.name)){if(this._parentSharedFields.has(i.name))throw new Error(`Duplicate shared field "${i.name}" \u2014 already propagated from a parent`);continue}this._parentSharedFields.add(i.name),n.addInputField(i),s=!0}s&&this.program.setSignature(n);for(let i of e)t.includes(i.name)&&!this.rlmConfig.contextFields.includes(i.name)&&this.rlmConfig.contextFields.push(i.name);for(let i of e)this.sharedFieldNames.includes(i.name)||this.sharedFieldNames.push(i.name);if(this._buildSplitPrograms(),this.func&&(this.func.parameters=this._buildFuncParameters()),this.agents)for(let i of this.agents){if(!(i instanceof o))continue;let a=new Set(i.getExcludedSharedFields()),u=e.filter(c=>!a.has(c.name));u.length!==0&&i._extendForGlobalSharedFields(u,t)}}_extendForGlobalSharedAgents(e){let t=this.agents?this.agents.filter(n=>n instanceof o):[];this._extendForSharedAgents(e);for(let n of t)n._extendForGlobalSharedAgents(e)}_extendForSharedAgentFunctions(e){if(e.functions.length===0&&e.moduleMetadata.length===0)return;let t=new Set(this.agentFunctions.map(i=>`${i.namespace??"utils"}.${i.name}`)),n=new Set(this.excludedAgentFunctions),r=[],s=this._mergeAgentFunctionModuleMetadata(e.moduleMetadata);for(let i of e.functions){if(n.has(i.name))continue;let a=`${i.namespace??"utils"}.${i.name}`;if(t.has(a)){if(this._parentSharedAgentFunctions.has(a))throw new Error(`Duplicate shared agent function "${a}" \u2014 already propagated from a parent`);continue}this._parentSharedAgentFunctions.add(a),t.add(a),r.push(i)}r.length===0&&!s||(r.length>0&&(this.agentFunctions=[...this.agentFunctions,...r]),this._buildSplitPrograms())}_extendForGlobalSharedAgentFunctions(e){let t=this.agents?this.agents.filter(n=>n instanceof o):[];this._extendForSharedAgentFunctions(e);for(let n of t)n._extendForGlobalSharedAgentFunctions(e)}stop(){this._stopRequested=!0;for(let e of this.activeAbortControllers)e.abort("Stopped by user");this.program.stop(),this.actorProgram.stop(),this.responderProgram.stop()}getId(){return this.program.getId()}setId(e){this.program.setId(e)}namedPrograms(){return this.program.namedPrograms()}namedProgramInstances(){return this.program.namedProgramInstances()}getTraces(){return this.program.getTraces()}setDemos(e,t){this.program.setDemos(e,t)}getUsage(){return this.program.getUsage()}resetUsage(){this.program.resetUsage()}getState(){if(this.stateError)throw new Error(this.stateError);return this.state?dn(this.state):void 0}setState(e){if(e&&e.version!==1)throw new Error(`Unsupported AxAgentState version "${String(e.version)}"`);if(e){let t=this.runtime.createSession();try{if(typeof t.patchGlobals!="function")throw new Error("AxCodeSession.patchGlobals() is required to restore AxAgent state")}finally{try{t.close()}catch{}}}this.state=e?dn(e):void 0,this.stateError=void 0}_createRecursiveOptimizationProxy(e,t){return{id:e,signature:t,program:{getId:()=>e,setId:()=>{},getTraces:()=>[],setDemos:()=>{},applyOptimization:n=>{this.applyOptimization(n)},getInstruction:()=>e===le.responder?this.responderProgram.getInstruction():this.recursiveInstructionSlots[e],setInstruction:n=>{this._setRecursiveInstructionSlot(e,n)},getSignature:()=>({getDescription:()=>t})}}}_listOptimizationTargetDescriptors(){return this._supportsRecursiveActorSlotOptimization()?[this._createRecursiveOptimizationProxy(le.shared,"Shared recursive-actor guidance applied to every advanced recursive AxAgent actor invocation."),this._createRecursiveOptimizationProxy(le.root,"Root-only recursive-actor guidance for deciding whether to answer directly or decompose into subtasks."),this._createRecursiveOptimizationProxy(le.recursive,"Mid-tree recursive-actor guidance for branch orchestration, selective delegation, and efficient synthesis."),this._createRecursiveOptimizationProxy(le.terminal,"Terminal-depth recursive-actor guidance for direct answers when deeper recursion is no longer available."),{id:le.responder,signature:this.responderProgram.getSignature().toString(),program:this.responderProgram}]:this.namedProgramInstances().map(e=>({id:e.id,signature:e.signature,program:e.program}))}_beginRecursiveTraceCapture(e){let t=zs(this.getUsage()),n=this._getRecursiveActorRole();if(!this.recursiveEvalContext||!n)return{node:void 0,usageBefore:t};let r=this.recursiveEvalContext.collector.createNode({parentId:this.recursiveEvalContext.parentNodeId,depth:this.recursiveEvalContext.depth,role:n,taskDigest:_t(Array.isArray(e)?e.filter(s=>s.role==="user").map(s=>s.values):e),contextDigest:_t(this.runtimeBootstrapContext)});return this.currentRecursiveTraceNodeId=r.nodeId,{node:r,usageBefore:t}}_finalizeRecursiveTraceCapture(e,t,n,r,s){if(!e){this.currentRecursiveTraceNodeId=void 0;return}let i=zs(this.getUsage());e.localUsage=eo(e.localUsage,lp(i,t)),e.turnCount=n.length,e.completionType=s.type,e.actorTurns=[...n],e.functionCalls=r.map(a=>({qualifiedName:a.qualifiedName,name:a.name,error:a.error})),e.toolErrors=r.filter(a=>!!a.error).map(a=>`${a.qualifiedName}: ${a.error??"unknown error"}`),this.currentRecursiveTraceNodeId=void 0}_recordEphemeralRecursiveUsage(e){if(!this.recursiveEvalContext||!this.currentRecursiveTraceNodeId||e.totalTokens<=0)return;let t=this.recursiveEvalContext.collector.nodesById.get(this.currentRecursiveTraceNodeId);t&&(t.localUsage=eo(t.localUsage,e))}async optimize(e,t){let n=vp(e);if(n.train.length===0)throw new Error("AxAgent.optimize(): at least one training task is required.");let r=t?.studentAI??this.ai;if(!r)throw new Error("AxAgent.optimize(): studentAI is required when the agent has no default ai.");let s=t?.judgeAI??this.judgeAI??t?.teacherAI??this.ai??r,i={...this.judgeOptions??{},...t?.judgeOptions??{}},a=this._listOptimizationTargetDescriptors(),u=Pp(a,t?.target??"actor"),c=t?.metric??this._createAgentOptimizeMetric(s,i),l=this._createOptimizationProgram(u,a),p=Math.max(1,Math.floor(t?.maxMetricCalls??Math.max(Tp,n.train.length*4))),m=await new Wt({studentAI:r,teacherAI:t?.teacherAI??s,numTrials:t?.numTrials,minibatch:t?.minibatch,minibatchSize:t?.minibatchSize,earlyStoppingTrials:t?.earlyStoppingTrials,minImprovementThreshold:t?.minImprovementThreshold,sampleCount:t?.sampleCount,seed:t?.seed,verbose:t?.verbose,debugOptimizer:t?.debugOptimizer,optimizerLogger:t?.optimizerLogger,onProgress:t?.onProgress,onEarlyStop:t?.onEarlyStop}).compile(l,n.train,c,{validationExamples:n.validation,maxMetricCalls:p,verbose:t?.verbose,feedbackFn:t?.metric?void 0:({prediction:f,example:x,componentId:A})=>dp({componentId:A,prediction:f,example:x})}),g=m.optimizedProgram;return m.optimizedProgram&&this._supportsRecursiveActorSlotOptimization()&&(g=new bt({...m.optimizedProgram,artifactFormatVersion:1,instructionSchema:Zr}),m.optimizedProgram=g),t?.apply!==!1&&g&&this.applyOptimization(g),m}_createOptimizationProgram(e,t){return{getId:()=>this.getId(),setId:n=>this.setId(n),getSignature:()=>Rp,forward:async(n,r,s)=>this._forwardForEvaluation(n,r,s),streamingForward:async function*(n,r,s){yield{version:1,index:0,delta:await this.forward(n,r,s)}},getTraces:()=>this.getTraces(),namedProgramInstances:()=>t.filter(n=>e.includes(n.id)),setDemos:(n,r)=>this.setDemos(n,r),applyOptimization:n=>this.applyOptimization(n),getUsage:()=>this.getUsage(),resetUsage:()=>this.resetUsage()}}_createAgentOptimizeMetric(e,t){let n=kp(t.criteria),r=new Pe(wp),s=t.description?.trim();r.setInstruction(s?`${n}
1394
+
1395
+ Additional Judge Guidance:
1396
+ ${s}`:n);let i=Op(t);return async({example:a,prediction:u})=>{let c=a,l=u,p={taskInput:it(c.input),criteria:c.criteria,expectedOutput:c.expectedOutput,expectedActions:c.expectedActions,forbiddenActions:c.forbiddenActions,metadata:c.metadata},d={completionType:l.completionType,clarification:it(l.clarification),finalOutput:it(l.output),actionLog:l.actionLog,functionCalls:it(l.functionCalls),toolErrors:l.toolErrors,turnCount:l.turnCount,usage:it(l.usage??[]),recursiveTrace:it(l.recursiveTrace),recursiveStats:it(l.recursiveStats)},m=await r.forward(e,{...p,...d},i);return Mp(Ep(m.quality),c,l)}}async _forwardForEvaluation(e,t,n){let r=this.state?dn(this.state):void 0,s=this.stateError;this.state=void 0,this.stateError=void 0;let i=new AbortController;this._stopRequested&&i.abort("Stopped by user (pre-forward)");let a=vt(i.signal,n?.abortSignal);this.activeAbortControllers.add(i);let u=this._ensureLlmQueryBudgetState(),c=this.recursiveEvalContext,l=this.currentRecursiveTraceNodeId,p=this._supportsRecursiveActorSlotOptimization()?If():void 0;this.recursiveEvalContext=p?{collector:p,depth:0}:void 0,this.currentRecursiveTraceNodeId=void 0;try{let d=this.ai??e,m=n?.debug??this.debug??d?.getOptions()?.debug??!1,g=[],f=[],{node:x,usageBefore:A}=this._beginRecursiveTraceCapture(t.input),{nonContextValues:h,actorResult:y,actorFieldValues:C,actionLog:I,turnCount:v}=await this._runActorLoop(d,t.input,n,a,g,f),O=g.filter(M=>!!M.error).map(M=>`${M.qualifiedName}: ${M.error??"unknown error"}`);if(y.type==="ask_clarification"){this._finalizeRecursiveTraceCapture(x,A,f,g,y);let M=p?.rootNode?qs(Za(p.rootNode)):void 0,F=M?Na(M):void 0,N=M&&F?La(M,F):void 0;return{completionType:"ask_clarification",clarification:Ba(y.args[0]),actionLog:I,functionCalls:g,toolErrors:O,turnCount:v,recursiveTrace:M,recursiveStats:F,recursiveSummary:N}}let R={...this._genOptions,...this.responderForwardOptions,...n,debug:m,abortSignal:a,maxSteps:1},E=await this.responderProgram.forward(d,{...h,contextData:y},R);this._finalizeRecursiveTraceCapture(x,A,f,g,y);let S=p?.rootNode?qs(Za(p.rootNode)):void 0,_=S?Na(S):void 0,$=S&&_?La(S,_):void 0;return{completionType:"final",output:{...E,...C},actionLog:I,functionCalls:g,toolErrors:O,turnCount:v,recursiveTrace:S,recursiveStats:_,recursiveSummary:$}}finally{this.state=r?dn(r):void 0,this.stateError=s,this.recursiveEvalContext=c,this.currentRecursiveTraceNodeId=l,u&&(this.llmQueryBudgetState=void 0),this.activeAbortControllers.delete(i),this._stopRequested=!1}}getFunction(){if(!this.func)throw new Error("getFunction() requires agentIdentity to be set in the constructor");let e=this.forward.bind(this);return{...this.func,func:async(r,s)=>{let i=this.ai??s?.ai;if(!i)throw new Error("AI service is required to run the agent");let a=await e(i,r,s),c=this.program.getSignature().getOutputFields();return Object.keys(a).map(p=>{let d=c.find(m=>m.name===p);return d?`${d.title}: ${a[p]}`:`${p}: ${a[p]}`}).join(`
1397
+ `)}}}getExcludedSharedFields(){return this.excludedSharedFields}_getBypassedSharedFieldNames(){let e=new Set([...this.sharedFieldNames,...this.globalSharedFieldNames]);for(let t of this.localFieldNames)e.delete(t);return e}_createRuntimeInputState(e,t){let n;Array.isArray(e)?n=e.filter(x=>x.role==="user").reduce((x,A)=>({...x,...A.values}),{}):n=e;let r=t?.allowedFieldNames?new Set(t.allowedFieldNames):void 0;if(r&&t?.validateInputKeys){for(let x of Object.keys(n))if(!r.has(x))throw new Error(`AxAgent.test() only accepts context field values. "${x}" is not configured in contextFields.`)}let s={...n},i=r?new Set(r):new Set(this.program.getSignature().getInputFields().map(x=>x.name)),a=[...this.sharedFieldNames,...this.globalSharedFieldNames],u=this._getBypassedSharedFieldNames(),c={},l={},p={},d={},m="(none)",g=new Set(this.program.getSignature().getInputFields().filter(x=>this.rlmConfig.contextFields.includes(x.name)&&x.isOptional).map(x=>x.name));return{currentInputs:s,signatureInputFieldNames:i,sharedFieldValues:c,recomputeTurnInputs:x=>{let A={},h={};for(let[C,I]of Object.entries(s))this.rlmConfig.contextFields.includes(C)?A[C]=I:u.has(C)||(h[C]=I);if(x){for(let C of this.rlmConfig.contextFields)if(!g.has(C)&&(!(C in A)||A[C]===void 0))throw new Error(`RLM contextField "${C}" is missing from input values`)}let y={};for(let[C,I]of this.contextPromptConfigByField){if(u.has(C)||!(C in A))continue;let v=Hp(A[C],I);v!==void 0&&(y[C]=v)}l=A,p=h,d=y;for(let C of Object.keys(c))delete c[C];for(let C of a)C in s&&(c[C]=s[C]),C in l&&(c[C]=l[C]);m=Wp(l,{promptConfigByField:this.contextPromptConfigByField,inlinedFields:new Set(Object.keys(d))})||"(none)"},getNonContextValues:()=>p,getActorInlineContextValues:()=>d,getContextMetadata:()=>m}}_ensureLlmQueryBudgetState(){return this.llmQueryBudgetState?!1:(this.llmQueryBudgetState={used:0},!0)}_createRuntimeExecutionContext({ai:e,inputState:t,options:n,effectiveAbortSignal:r,debug:s,completionState:i,completionBindings:a,actionLogEntries:u,functionCallRecorder:c}){let l=this.rlmConfig,p=this.runtime,d=l.maxSubAgentCalls??8,m=l.maxRuntimeChars??5e3,g=Math.max(1,l.maxBatchedLlmQueryConcurrency??8),f=this.recursionForwardOptions?.maxDepth??2,x=Math.max(0,f),A=$a(l.contextPolicy),h=this.llmQueryBudgetState??{used:0},y=new Set,C=Math.floor(d*.8),{maxDepth:I,...v}=this.recursionForwardOptions??{},{description:O,mem:R,sessionId:E,...S}=n??{},_={...this.recursionForwardOptions??{},maxDepth:Math.max(0,x-1)},$=me().input("task",me.string("Task for recursive analysis")).output("answer",me.string("Answer from recursive analysis")).build(),M=me().input("task",me.string("Task for recursive analysis")).input("context",me.json("Optional context for the recursive task")).output("answer",me.string("Answer from recursive analysis")).build(),N=(l.mode??"simple")==="advanced"&&x>0,G=this.recursionForwardOptions?.promptLevel??this.actorPromptLevel,W=()=>(()=>{let P=new o({agentModuleNamespace:this.agentModuleNamespace,signature:$},{debug:s,...l,agents:{local:this.agents},functions:{local:this.agentFunctions,discovery:this.functionDiscoveryEnabled},contextFields:[],actorFields:void 0,promptLevel:G,actorModelPolicy:this.options?.actorModelPolicy,recursionOptions:_,actorOptions:{...this.actorForwardOptions},responderOptions:this.responderForwardOptions});return P.recursiveInstructionRoleOverride=_.maxDepth&&_.maxDepth>0?"recursive":"terminal",this._copyRecursiveOptimizationStateTo(P),P})(),U=P=>(P.llmQueryBudgetState=h,this.recursiveEvalContext&&(P.recursiveEvalContext={collector:this.recursiveEvalContext.collector,parentNodeId:this.currentRecursiveTraceNodeId,depth:this.recursiveEvalContext.depth+1}),P),ae=()=>{for(let P of[...y])P.stop()},j=()=>new Pe(M,_),re=async(P,z)=>{if(!Array.isArray(P)&&typeof P=="object"&&P!==null&&"query"in P)return re(P.query,P.context??z);if(r?.aborted)throw new _e("rlm-llm-query",r.reason?String(r.reason):"Aborted");if(!e)throw new Error(Np);let ne=P,te=be=>{if(be==null)return"";if(typeof be=="string")return lt(be,m);try{return lt(JSON.stringify(be),m)}catch{return lt(String(be),m)}},Ie=async(be,qe,Ne=r)=>{if(Ne?.aborted)throw new _e("rlm-llm-query",Ne.reason?String(Ne.reason):"Aborted");let nt=qe===void 0?void 0:typeof qe=="string"?lt(qe,m):qe;if(h.used>=d)return`[ERROR] Sub-query budget exhausted (${d}/${d}). Complete the task using data already gathered or handle remaining work directly in JS.`;h.used++;let Z=3,Q,Ae=Se=>`[ERROR] ${Se instanceof Error?Se.message:String(Se)}. Retry with a simpler query, handle in JS, or proceed with data already gathered.`;for(let Se=0;Se<Z;Se++)try{if(!N){let Ve=j(),Jt=await Ve.forward(e,{task:be,...nt!==void 0?{context:nt}:{}},{...S,...v,abortSignal:Ne,debug:s});return this._recordEphemeralRecursiveUsage(zs(Ve.getUsage())),te(Jt.answer)}let Fe=await(()=>{let Ve=U(W());return y.add(Ve),Ve.runtimeBootstrapContext=nt,Ve.forward(e,{task:be},{...S,...v,abortSignal:Ne,debug:s}).finally(()=>{y.delete(Ve)})})();return te(Fe.answer)}catch(Fe){if(Fe instanceof _e||Fe instanceof at)throw Fe;if(Q=Fe,!Up(Fe)||Se>=Z-1)return Ae(Fe);let Ve=Math.min(6e4,1e3*Math.pow(2,Se));await new Promise((Jt,Qs)=>{let Qt=!1,Yt,uo=()=>{Ne&&Yt&&Ne.removeEventListener("abort",Yt)},Te=setTimeout(()=>{Qt||(Qt=!0,uo(),Jt())},Ve);if(Ne){if(Yt=()=>{Qt||(Qt=!0,clearTimeout(Te),uo(),Qs(new _e("rlm-llm-query-retry-backoff",Ne.reason?String(Ne.reason):"Aborted during retry backoff")))},Ne.aborted){Yt();return}Ne.addEventListener("abort",Yt,{once:!0})}})}return Ae(Q)};if(Array.isArray(P)){let be=new AbortController,qe=vt(r,be.signal)??be.signal,Ne,nt=()=>{ae()};qe.addEventListener("abort",nt,{once:!0});try{return await Vp(P,g,async Z=>{try{return await Ie(Z.query,Z.context,qe)}catch(Q){if(Q instanceof _e||Q instanceof at)throw(Q instanceof at||!Ne)&&(Ne=Q),be.signal.aborted||be.abort(Q instanceof at?"Child clarification":Q.message),Ne;return`[ERROR] ${Q instanceof Error?Q.message:String(Q)}`}},qe)}finally{qe.removeEventListener("abort",nt)}}let Ue=await Ie(ne,z);return h.used===C?`${Ue}
1398
+ [WARNING] ${h.used}/${d} sub-queries used (${d-h.used} remaining). Consolidate remaining work.`:Ue},oe=this.buildRuntimeGlobals(r,t.sharedFieldValues,e,a.protocol,c),Ce=[...new Set(this.agentFunctions.map(P=>P.namespace??"utils"))],L={...t.currentInputs},K=new Set(["inputs","llmQuery",to,this.agentModuleNamespace,"final","ask_clarification",...Ce,...A.stateInspection.enabled?["inspect_runtime"]:[],...Object.keys(oe)]),ee=[...new Set([...Object.keys(L),...t.signatureInputFieldNames])].filter(P=>!K.has(P)),he={};for(let P of ee)he[P]=L[P];let q=()=>{for(let P of Object.keys(L))delete L[P];for(let[P,z]of Object.entries(t.currentInputs))L[P]=z;for(let P of ee)he[P]=t.currentInputs[P]},B=[...K],ue=[...K,...ee],ke=new Set(ue),Oe=this.runtimeBootstrapContext;this.runtimeBootstrapContext=void 0;let ce=$p(Oe,ke),Re=new Set(Object.keys(ce)),se=u??[],de,J,X=P=>typeof P.inspectGlobals=="function"?P:void 0,xe=async()=>{try{let P=await de.execute(ap(),{signal:r,reservedNames:ue});if(typeof P!="string")return[];let z=JSON.parse(P);return Array.isArray(z)?z.filter(ne=>typeof ne=="string"&&!Re.has(ne)):[]}catch{return[]}},we=async()=>(J||(J=await xe()),J),Be=async()=>{try{let P=X(de);if(P?.inspectGlobals)return await P.inspectGlobals({signal:r,reservedNames:ue});let z=await we(),ne=ip(ue,z),te=await de.execute(ne,{signal:r,reservedNames:ue});return typeof te=="string"?te:String(te)}catch(P){return`[inspect_runtime error: ${P instanceof Error?P.message:String(P)}]`}},$e=(P,z)=>{let ne=Gp(P);if(!ne)return Bp(P,z);let te=Us(se);return Ws(ne,te,z)},ut=A.stateInspection.enabled?async()=>$e(await Be()):void 0,Ee=()=>(J=void 0,p.createSession({...he,inputs:L,...ce,llmQuery:re,final:a.finalFunction,ask_clarification:a.askClarificationFunction,...ut?{inspect_runtime:ut}:{},...oe}));de=Ee();let ze=()=>({maxEntries:A.stateSummary.maxEntries&&A.stateSummary.maxEntries>0?A.stateSummary.maxEntries:8,maxChars:A.stateSummary.maxChars&&A.stateSummary.maxChars>0?A.stateSummary.maxChars:void 0}),pe=()=>({maxEntries:A.stateSummary.maxEntries&&A.stateSummary.maxEntries>0?A.stateSummary.maxEntries:6,maxChars:A.stateSummary.maxChars&&A.stateSummary.maxChars>0?A.stateSummary.maxChars:Math.min(m,1200)}),De=Object.keys(ce).length>0?Dp(ce,{...pe(),budgetRemaining:Math.max(0,d-h.used),budgetTotal:d}):void 0,We=async()=>{if(!i.payload)for(let P=0;P<3&&!i.payload;P++)await new Promise(z=>{setTimeout(z,0)})},Ye=async()=>{if(!A.stateSummary.enabled)return;let P=await Be();return $e(P,ze())||"(no user variables)"},ct=P=>{if(typeof P.patchGlobals!="function")throw new Error("AxCodeSession.patchGlobals() is required when restoring AxAgent state or using inputUpdateCallback");return P},b=P=>{if(typeof P.snapshotGlobals!="function")throw new Error("AxCodeSession.snapshotGlobals() is required to export AxAgent state");return P},w=P=>{let z=new Set(ue),ne={};for(let[Ie,Ue]of Object.entries(P.runtimeBindings??{}))z.has(Ie)||(ne[Ie]=Ue);let te=(P.runtimeEntries??[]).filter(Ie=>!z.has(Ie.name));return{runtimeBindings:ne,runtimeEntries:te,actionLogEntries:rd(P.actionLogEntries),checkpointState:P.checkpointState,provenance:{...P.provenance??{}},actorModelState:xp(P.actorModelState)}};return{effectiveContextConfig:A,bootstrapContextSummary:De,applyBootstrapRuntimeContext:async()=>{if(Object.keys(ce).length===0||!A.stateSummary.enabled)return;let P=await Be();return $e(P,ze())||"(no user variables)"},captureRuntimeStateSummary:Ye,exportRuntimeState:async()=>{let z=await b(de).snapshotGlobals({signal:r,reservedNames:ue}),ne=Us(se);return{version:1,runtimeBindings:z.bindings,runtimeEntries:z.entries,actionLogEntries:nd(se),provenance:od(ne)}},restoreRuntimeState:async P=>{let z=w(P);return await ct(de).patchGlobals(z.runtimeBindings,{signal:r}),z},syncRuntimeInputsToSession:async()=>{q();let P=async z=>{await ct(z).patchGlobals({inputs:{...L},...he},{signal:r})};try{await P(de)}catch(z){if(r?.aborted)throw new _e("rlm-session",r.reason??"Aborted");if(z instanceof Error&&(z.name==="AbortError"||z.message.startsWith("Aborted")))throw z;if(Ja(z)){de=Ee(),await P(de);return}throw new Error(`Failed to sync runtime inputs: ${lr(z,m)}`)}},executeActorCode:async P=>{let z={result:void 0,output:io(void 0,m),isError:!1};try{let ne=await de.execute(P,{signal:r,reservedNames:B});return i.payload||Wa(P)&&Va(ne)&&(await We(),i.payload)?z:{result:ne,output:io(ne,m),isError:!1}}catch(ne){if(ne instanceof Ut||i.payload)return z;if(ne instanceof at||ne instanceof _e)throw ne;if(r?.aborted)throw new _e("rlm-session",r.reason??"Aborted");if(ne instanceof Error&&(ne.name==="AbortError"||ne.message.startsWith("Aborted")))throw ne;if(zp(ne))return{result:void 0,output:lt(`${so}
1399
+ ${lr(ne,m)}`,m),isError:!0};if(Ja(ne))try{de=Ee(),i.payload=void 0;let te=await de.execute(P,{signal:r,reservedNames:B});return{result:te,output:lt(`${so}
1400
+ ${io(te,m)}`,m),isError:!1}}catch(te){if(te instanceof at||te instanceof _e)throw te;return{result:void 0,output:lt(`${so}
1401
+ ${lr(te,m)}`,m),isError:!0}}return{result:void 0,output:lt(lr(ne,m),m),isError:!0}}},executeTestCode:async P=>{try{let z=await de.execute(P,{signal:r,reservedNames:B});if(Wa(P)&&Va(z)&&await We(),i.payload)return i.payload;let ne=io(z,m);if(qp(ne))throw new Error(ne);return ne}catch(z){if((z instanceof Ut||i.payload)&&i.payload)return i.payload;throw z}},close:()=>{de.close()}}}getExcludedAgents(){return this.excludedAgents}getExcludedAgentFunctions(){return this.excludedAgentFunctions}getSignature(){return this.program.getSignature()}async test(e,t,n){let r=this.ai??n?.ai,s=n?.debug??this.debug??r?.getOptions()?.debug??!1,i=this._createRuntimeInputState(t??{},{allowedFieldNames:this.rlmConfig.contextFields,validateInputKeys:!0});i.recomputeTurnInputs(!1);let a={payload:void 0},u=Ga((p,d)=>{a.payload=ja(p,d)}),c=this._ensureLlmQueryBudgetState(),l=this._createRuntimeExecutionContext({ai:r,inputState:i,options:void 0,effectiveAbortSignal:n?.abortSignal,debug:s,completionState:a,completionBindings:u,actionLogEntries:[]});try{return await l.executeTestCode(e)}finally{this.currentRecursiveTraceNodeId=void 0,c&&(this.llmQueryBudgetState=void 0),l.close()}}setSignature(e){let t=new Me(e);this._validateConfiguredSignature(t);let n=this.program.getSignature();try{this.program.setSignature(t),this._buildSplitPrograms(),this.func&&(this.func.parameters=this._buildFuncParameters())}catch(r){throw this.program.setSignature(n),this._buildSplitPrograms(),this.func&&(this.func.parameters=this._buildFuncParameters()),r}}applyOptimization(e){let t=e?.instructionSchema,n=e?.artifactFormatVersion;if(t&&t!==Zr)throw new Error(`AxAgent.applyOptimization(): unsupported instruction schema "${t}".`);if(t===Zr&&n!==void 0&&n!==1)throw new Error(`AxAgent.applyOptimization(): unsupported recursive artifact format version "${String(n)}".`);let r=e?.instructionMap??{},s=[le.shared,le.root,le.recursive,le.terminal].some(i=>typeof r[i]=="string");if(t===Zr){if(!this._supportsRecursiveActorSlotOptimization())throw new Error('AxAgent.applyOptimization(): recursive-slot artifacts require mode "advanced" with recursion enabled.');(e?.demos||e?.modelConfig)&&this.program.setDemos(e.demos??[],{modelConfig:e.modelConfig}),this.recursiveInstructionSlots=cr(this.actorDescription);for(let a of[le.shared,le.root,le.recursive,le.terminal])typeof r[a]=="string"&&(this.recursiveInstructionSlots[a]=r[a]??"");this._applyRecursiveActorInstruction();let i=r[le.responder];typeof i=="string"&&this.responderProgram.setInstruction(i);return}if(this._supportsRecursiveActorSlotOptimization()&&!s){(e?.demos||e?.modelConfig)&&this.program.setDemos(e.demos??[],{modelConfig:e.modelConfig}),this.recursiveInstructionSlots=cr(this.actorDescription);let i=r["root.actor"]??e?.instruction;typeof i=="string"&&(this.recursiveInstructionSlots[le.shared]=i),this._applyRecursiveActorInstruction();let a=r["root.responder"];typeof a=="string"?this.responderProgram.setInstruction(a):typeof e?.instruction=="string"&&this.responderProgram.setInstruction(e.instruction);return}if(s){if(!this._supportsRecursiveActorSlotOptimization())throw new Error('AxAgent.applyOptimization(): recursive-slot instruction maps require mode "advanced" with recursion enabled.');this.recursiveInstructionSlots=cr(this.actorDescription);for(let a of[le.shared,le.root,le.recursive,le.terminal])typeof r[a]=="string"&&(this.recursiveInstructionSlots[a]=r[a]??"");this._applyRecursiveActorInstruction();let i=r[le.responder];typeof i=="string"&&this.responderProgram.setInstruction(i),(e?.demos||e?.modelConfig)&&this.program.setDemos(e.demos??[],{modelConfig:e.modelConfig});return}this.program.applyOptimization?.(e)}async _runActorLoop(e,t,n,r,s,i){let a=this.rlmConfig,u=n?.debug??this.debug??e?.getOptions()?.debug??!1,c=a.maxTurns??8,l=this._createRuntimeInputState(t);l.recomputeTurnInputs(!1);let p={payload:void 0},d=Ga((re,oe)=>{p.payload=ja(re,oe)}),m=[],g,f=this._createRuntimeExecutionContext({ai:e,inputState:l,options:n,effectiveAbortSignal:r,debug:u,completionState:p,completionBindings:d,actionLogEntries:m,functionCallRecorder:s?re=>{s.push(re)}:void 0}),x=f.effectiveContextConfig.stateSummary.enabled?void 0:f.bootstrapContextSummary,A=async()=>{if(!this.inputUpdateCallback)return;let re=await this.inputUpdateCallback({...l.currentInputs});if(re!==void 0){if(!re||typeof re!="object"||Array.isArray(re))throw new Error("inputUpdateCallback must return an object patch or undefined");for(let[oe,Ce]of Object.entries(re))l.signatureInputFieldNames.has(oe)&&(l.currentInputs[oe]=Ce)}},h={...this._genOptions,...this.actorForwardOptions,...n,debug:u,abortSignal:r},y={},C=f.effectiveContextConfig.stateInspection.enabled?f.effectiveContextConfig.stateInspection.contextThreshold:void 0,I=Lp(n,u,r),v=this.functionDiscoveryEnabled&&f.effectiveContextConfig.pruneUsedDocs,O,R,E,S=f.effectiveContextConfig.actionReplay==="checkpointed"?"minimal":f.effectiveContextConfig.actionReplay,_=f.effectiveContextConfig.actionReplay==="checkpointed"?"full":f.effectiveContextConfig.actionReplay,$=()=>Gs(m,{pruneUsedDocs:v}),M=re=>({...l.getNonContextValues(),...l.getActorInlineContextValues(),contextMetadata:l.getContextMetadata(),actionLog:re}),F=re=>this.actorProgram._measurePromptCharsForInternalUse(e,M(re),h),N=(re,oe,Ce)=>op($(),{actionReplay:re,recentFullActions:f.effectiveContextConfig.recentFullActions,restoreNotice:E,delegatedContextSummary:x,stateSummary:g,checkpointSummary:oe,checkpointTurns:Ce})||"(no actions yet)",G=()=>N(f.effectiveContextConfig.actionReplay,O?.summary,O?.turns),W=()=>{!this.actorModelPolicy&&!R||(R=Ua())},U=re=>{!this.actorModelPolicy&&!R||(R=Ap(R,re))},ae=async()=>{let re=q=>{let B=(O?.fingerprint??null)!==(q?.fingerprint??null);return O=q,B};if(!f.effectiveContextConfig.checkpoints.enabled)return re(void 0);let oe=f.effectiveContextConfig.checkpoints.triggerChars,Ce=N(_),L=await F(Ce);if(!oe||L<=oe)return re(void 0);let ee=Fa(m,{actionReplay:S,recentFullActions:f.effectiveContextConfig.recentFullActions,pruneUsedDocs:v}).checkpointEntries;if(ee.length===0)return re(void 0);let he=JSON.stringify(ee.map(q=>({turn:q.turn,code:q.code,output:q.output,actorFieldsOutput:q.actorFieldsOutput,tags:q.tags,tombstone:q.tombstone})));return O?.fingerprint===he?!1:re({fingerprint:he,turns:ee.map(q=>q.turn),summary:await rp(e,f.effectiveContextConfig.summarizerOptions,I,ee)})};try{if(this.state){let oe=await f.restoreRuntimeState(this.state),Ce=f.effectiveContextConfig.stateSummary.enabled;m.push(...oe.actionLogEntries),O=oe.checkpointState?{fingerprint:oe.checkpointState.fingerprint,turns:[...oe.checkpointState.turns],summary:oe.checkpointState.summary}:void 0,R=oe.actorModelState?{consecutiveErrorTurns:oe.actorModelState.consecutiveErrorTurns}:void 0;let L=ad(Us(m),id(oe.provenance));g=Ce?Ws(oe.runtimeEntries,L,{maxEntries:f.effectiveContextConfig.stateSummary.maxEntries&&f.effectiveContextConfig.stateSummary.maxEntries>0?f.effectiveContextConfig.stateSummary.maxEntries:8,maxChars:f.effectiveContextConfig.stateSummary.maxChars&&f.effectiveContextConfig.stateSummary.maxChars>0?f.effectiveContextConfig.stateSummary.maxChars:1200})||"(no user variables)":void 0,E=sd(oe.runtimeEntries,{includeLiveRuntimeState:Ce})}let re=await f.applyBootstrapRuntimeContext();re!==void 0&&(g=re);for(let oe=0;oe<c;oe++){await A(),l.recomputeTurnInputs(!0),await ae()&&W();let L=G(),K=await F(L),ee=!1;C&&K>C&&(ee=!0,L+="\n\n[HINT: Actor prompt is large. Call `const state = await inspect_runtime()` for a compact snapshot of current variables instead of re-reading old outputs.]");let he=ee?await F(L):K,q=h;if(this.actorModelPolicy){let J=yp(this.actorModelPolicy,he,Da(R));q=J!==void 0?{...h,model:J}:h}let B=await this.actorProgram.forward(e,M(L),q);oe===0&&(h.debugHideSystemPrompt=!0,E=void 0);let ue=B.javascriptCode,ke=ue?.trim();if(!ue||!ke)break;ue=Sp(ke),B.javascriptCode=ue;for(let J of this.actorFieldNames)J in B&&(y[J]=B[J]);let Oe="";if(this.actorFieldNames.length>0){let J=this.actorFieldNames.filter(X=>X in B).map(X=>`${X}: ${B[X]}`).join(`
1402
+ `);J&&(Oe=`
1403
+ Actor fields:
1404
+ ${J}`)}if(p.payload=void 0,this.enforceIncrementalConsoleTurns){let J=Qp(ue);if(J){let X=m.length+1;m.push({turn:X,code:ue,output:J,actorFieldsOutput:Oe,tags:["error"]}),i?.push({turn:X,code:ue,output:J,isError:!0,thought:typeof B.thought=="string"?B.thought:void 0}),a.actorTurnCallback&&await a.actorTurnCallback({turn:X,actorResult:B,code:ue,result:void 0,output:J,isError:!0,thought:typeof B.thought=="string"?B.thought:void 0}),await Pa(m,m.length-1,f.effectiveContextConfig,e,I),U(!0),await ae()&&W();continue}}this.inputUpdateCallback&&await f.syncRuntimeInputsToSession();let ce,Re,se;try{let J=await f.executeActorCode(ue);ce=J.result,Re=J.output,se=J.isError}catch(J){throw(J instanceof at||J instanceof _e)&&(i?.push({turn:m.length+1,code:ue,output:Ha(J,a.maxRuntimeChars??5e3),isError:J instanceof _e,thought:typeof B.thought=="string"?B.thought:void 0}),a.actorTurnCallback&&await a.actorTurnCallback({turn:m.length+1,actorResult:B,code:ue,result:void 0,output:Ha(J,a.maxRuntimeChars??5e3),isError:J instanceof _e,thought:typeof B.thought=="string"?B.thought:void 0})),J}let de=m.length+1;if(m.push({turn:de,code:ue,output:Re,actorFieldsOutput:Oe,tags:se?["error"]:[]}),i?.push({turn:de,code:ue,output:Re,isError:se,thought:typeof B.thought=="string"?B.thought:void 0}),a.actorTurnCallback&&await a.actorTurnCallback({turn:de,actorResult:B,code:ue,result:ce,output:Re,isError:se,thought:typeof B.thought=="string"?B.thought:void 0}),await Pa(m,m.length-1,f.effectiveContextConfig,e,I),se||(g=await f.captureRuntimeStateSummary()),U(se),await ae()&&W(),p.payload)break}await ae()&&W();try{let oe=await f.exportRuntimeState();oe.checkpointState=O?{fingerprint:O.fingerprint,turns:[...O.turns],summary:O.summary}:void 0,oe.actorModelState=R?{consecutiveErrorTurns:R.consecutiveErrorTurns}:void 0,this.state=oe,this.stateError=void 0}catch(oe){this.state=void 0,this.stateError=oe instanceof Error?oe.message:`Failed to export AxAgent state: ${String(oe)}`}}finally{try{f.close()}catch{}}let j=p.payload??{type:"final",args:[sp(m,{stateSummary:g,checkpointSummary:O?.summary,checkpointTurns:O?.turns,pruneUsedDocs:v})]};return{nonContextValues:l.getNonContextValues(),contextMetadata:l.getContextMetadata(),actionLog:G(),actorResult:j,actorFieldValues:y,turnCount:m.length}}async forward(e,t,n){let r=new AbortController;this._stopRequested&&r.abort("Stopped by user (pre-forward)");let s=vt(r.signal,n?.abortSignal);this.activeAbortControllers.add(r);let i=this._ensureLlmQueryBudgetState();try{let a=this.ai??e,u=n?.debug??this.debug??a?.getOptions()?.debug??!1,c=[],l=[],{node:p,usageBefore:d}=this._beginRecursiveTraceCapture(t),{nonContextValues:m,actorResult:g,actorFieldValues:f}=await this._runActorLoop(a,t,n,s,c,l);if(g.type==="ask_clarification")throw this._finalizeRecursiveTraceCapture(p,d,l,c,g),new at(g.args[0],{state:this.state,stateError:this.stateError});let x={...this._genOptions,...this.responderForwardOptions,...n,debug:u,abortSignal:s,maxSteps:1},A=await this.responderProgram.forward(a,{...m,contextData:g},x);return this._finalizeRecursiveTraceCapture(p,d,l,c,g),{...A,...f}}finally{i&&(this.llmQueryBudgetState=void 0),this.activeAbortControllers.delete(r),this._stopRequested=!1}}async*streamingForward(e,t,n){let r=new AbortController;this._stopRequested&&r.abort("Stopped by user (pre-forward)");let s=vt(r.signal,n?.abortSignal);this.activeAbortControllers.add(r);let i=this._ensureLlmQueryBudgetState();try{let a=this.ai??e,u=n?.debug??this.debug??a?.getOptions()?.debug??!1,{nonContextValues:c,actorResult:l,actorFieldValues:p}=await this._runActorLoop(a,t,n,s);if(l.type==="ask_clarification")throw new at(l.args[0],{state:this.state,stateError:this.stateError});let d={...this._genOptions,...this.responderForwardOptions,...n,debug:u,abortSignal:s,maxSteps:1};for await(let m of this.responderProgram.streamingForward(a,{...c,contextData:l},d))yield m;Object.keys(p).length>0&&(yield{version:1,index:0,delta:p})}finally{i&&(this.llmQueryBudgetState=void 0),this.activeAbortControllers.delete(r),this._stopRequested=!1}}static wrapFunction(e,t,n,r,s,i){return async(...a)=>{let u;if(a.length===1&&typeof a[0]=="object"&&a[0]!==null&&!Array.isArray(a[0]))u=a[0];else{let c=e.parameters?.properties?Object.keys(e.parameters.properties):[];u={},c.forEach((l,p)=>{p<a.length&&(u[l]=a[p])})}try{let c=await e.func(u,{abortSignal:t,ai:n,protocol:r});return i?.({qualifiedName:s??e.name,name:e.name,arguments:it(u),result:it(c)}),c}catch(c){throw i?.({qualifiedName:s??e.name,name:e.name,arguments:it(u),error:c instanceof Error?c.message:String(c)}),c}}}static wrapFunctionWithSharedFields(e,t,n,r,s,i,a){return typeof n!="function"&&(!n||Object.keys(n).length===0)?o.wrapFunction(e,t,r,s,i,a):async(...u)=>{let c;if(u.length===1&&typeof u[0]=="object"&&u[0]!==null&&!Array.isArray(u[0]))c=u[0];else{let d=e.parameters?.properties?Object.keys(e.parameters.properties):[];c={},d.forEach((m,g)=>{g<u.length&&(c[m]=u[g])})}let l=typeof n=="function"?n():n,p=l?{...l,...c}:c;try{let d=await e.func(p,{abortSignal:t,ai:r,protocol:s});return a?.({qualifiedName:i??e.name,name:e.name,arguments:it(p),result:it(d)}),d}catch(d){throw a?.({qualifiedName:i??e.name,name:e.name,arguments:it(p),error:d instanceof Error?d.message:String(d)}),d}}}buildRuntimeGlobals(e,t,n,r,s){let i={},a=new Map,u=new Map,c=new Map;for(let[p,d]of this.agentFunctionModuleMetadata)c.set(p,d);let l=(p,d)=>{a.set(d,p),u.has(p.module)||u.set(p.module,[]),u.get(p.module)?.push(d)};for(let p of this.agentFunctions){let d=p.namespace??"utils";(!i[d]||typeof i[d]!="object")&&(i[d]={});let m=`${d}.${p.name}`;i[d][p.name]=o.wrapFunction(p,e,n,r,m,s),l({module:d,name:p.name,description:p.description,parameters:p.parameters,returns:p.returns,examples:p.examples},m)}if(this.agents&&this.agents.length>0){let p={};for(let d of this.agents){let m=d.getFunction(),g=new Set(d.getExcludedSharedFields?.()??[]),f=()=>{let A={};if(t)for(let[h,y]of Object.entries(t))g.has(h)||(A[h]=y);return A},x=`${this.agentModuleNamespace}.${m.name}`;p[m.name]=o.wrapFunctionWithSharedFields(m,e,f,n,r,x,s),l({module:this.agentModuleNamespace,name:m.name,description:m.description,parameters:m.parameters},x)}i[this.agentModuleNamespace]=p}return this.functionDiscoveryEnabled&&(i[Hs]=async p=>{let d=Qa(p,"modules");return ed(d,u,c)},i[Ks]=async p=>{let d=Qa(p,"functions");return td(d,a)}),i}get _genOptions(){if(!this.options)return{};let{agents:e,fields:t,functions:n,judgeOptions:r,inputUpdateCallback:s,...i}=this.options;return i}_buildFuncParameters(){let e=this.program.getSignature().toInputJSONSchema();return this._parentSharedFields.size>0?Yp(e,this._parentSharedFields):e}};function pd(o,e){let t=typeof o=="string"?Me.create(o):o,{ai:n,judgeAI:r,agentIdentity:s,...i}=e;return new ao({ai:n,judgeAI:r,agentIdentity:s,signature:t},{contextFields:[],...i})}var dd=(o,e)=>{let t=e?.maxHops??3,n=e?.qualityThreshold??.8,r=e?.maxIterations??2,s=e?.qualityTarget??.85,i=e?.disableQualityHealing??!1;return Es({logger:e?.logger,debug:e?.debug}).node("queryGenerator","originalQuestion:string, previousContext?:string -> searchQuery:string, queryReasoning:string").node("contextualizer","retrievedDocument:string, accumulatedContext?:string -> enhancedContext:string").node("qualityAssessor","currentContext:string, originalQuestion:string -> completenessScore:number, missingAspects:string[]").node("questionDecomposer","complexQuestion:string -> subQuestions:string[], decompositionReason:string").node("evidenceSynthesizer","collectedEvidence:string[], originalQuestion:string -> synthesizedEvidence:string, evidenceGaps:string[]").node("gapAnalyzer","synthesizedEvidence:string, evidenceGaps:string[], originalQuestion:string -> needsMoreInfo:boolean, focusedQueries:string[]").node("answerGenerator","finalContext:string, originalQuestion:string -> comprehensiveAnswer:string, confidenceLevel:number").node("queryRefiner","originalQuestion:string, currentContext:string, missingAspects:string[] -> refinedQuery:string").node("qualityValidator","generatedAnswer:string, userQuery:string -> qualityScore:number, issues:string[]").node("answerHealer","originalAnswer:string, healingDocument:string, issues?:string[] -> healedAnswer:string").map(a=>({...a,maxHops:t,qualityThreshold:n,maxIterations:r,qualityTarget:s,disableQualityHealing:i,currentHop:0,accumulatedContext:"",retrievedContexts:[],completenessScore:0,searchQuery:a.originalQuestion,shouldContinue:!0,iteration:0,allEvidence:[],evidenceSources:[],needsMoreInfo:!0,healingAttempts:0,currentQuality:0,shouldContinueHealing:!0,currentAnswer:"",currentIssues:[]})).while(a=>a.currentHop<a.maxHops&&a.completenessScore<a.qualityThreshold&&a.shouldContinue).map(a=>({...a,currentHop:a.currentHop+1})).execute("queryGenerator",a=>({originalQuestion:a.originalQuestion,previousContext:a.accumulatedContext||void 0})).map(async a=>{let u=a.queryGeneratorResult?.searchQuery||a.searchQuery||a.originalQuestion,c=await o(u);return{...a,retrievalResult:{retrievedDocument:c,retrievalConfidence:.9}}}).execute("contextualizer",a=>({retrievedDocument:a.retrievalResult.retrievedDocument,accumulatedContext:a.accumulatedContext||void 0})).execute("qualityAssessor",a=>({currentContext:a.contextualizerResult.enhancedContext,originalQuestion:a.originalQuestion})).map(a=>({...a,accumulatedContext:a.contextualizerResult.enhancedContext,retrievedContexts:[...a.retrievedContexts,a.retrievalResult.retrievedDocument],completenessScore:a.qualityAssessorResult.completenessScore,searchQuery:a.queryGeneratorResult.searchQuery,shouldContinue:a.qualityAssessorResult.completenessScore<a.qualityThreshold})).branch(a=>a.shouldContinue&&a.currentHop<a.maxHops).when(!0).execute("queryRefiner",a=>({originalQuestion:a.originalQuestion,currentContext:a.accumulatedContext,missingAspects:a.qualityAssessorResult.missingAspects})).map(a=>({...a,searchQuery:a.queryRefinerResult?.refinedQuery||a.searchQuery})).when(!1).map(a=>a).merge().endWhile().map(a=>({...a,allEvidence:a.retrievedContexts.length>0?a.retrievedContexts:[]})).while(a=>a.iteration<a.maxIterations&&a.needsMoreInfo).map(a=>({...a,iteration:a.iteration+1})).branch(a=>a.iteration===1).when(!0).execute("questionDecomposer",a=>({complexQuestion:a.originalQuestion})).map(a=>({...a,currentQueries:a.questionDecomposerResult.subQuestions})).when(!1).map(a=>({...a,currentQueries:a.gapAnalyzerResult?.focusedQueries||[]})).merge().map(async a=>{let u=a.currentQueries||[],c=u.length>0?await Promise.all(u.filter(Boolean).map(l=>o(l))):[];return{...a,retrievalResults:c}}).execute("evidenceSynthesizer",a=>{let u=Array.isArray(a.allEvidence)?a.allEvidence:[],c=Array.isArray(a.retrievalResults)?a.retrievalResults:[],l=[...u,...c].filter(Boolean);return{collectedEvidence:l.length>0?l:["No evidence collected yet"],originalQuestion:a.originalQuestion}}).execute("gapAnalyzer",a=>({synthesizedEvidence:a.evidenceSynthesizerResult.synthesizedEvidence,evidenceGaps:a.evidenceSynthesizerResult.evidenceGaps,originalQuestion:a.originalQuestion})).map(a=>({...a,allEvidence:[...Array.isArray(a.allEvidence)?a.allEvidence:[],...Array.isArray(a.retrievalResults)?a.retrievalResults:[]],evidenceSources:[...Array.isArray(a.evidenceSources)?a.evidenceSources:[],`Iteration ${a.iteration} sources`],needsMoreInfo:a.gapAnalyzerResult.needsMoreInfo,synthesizedEvidence:a.evidenceSynthesizerResult.synthesizedEvidence})).endWhile().execute("answerGenerator",a=>({finalContext:(()=>{let u=(a.accumulatedContext||"").toString().trim();if(u.length>0)return u;let c=(a.synthesizedEvidence||"").toString().trim();if(c.length>0)return c;let p=(Array.isArray(a.allEvidence)?a.allEvidence.filter(Boolean).join(`
1405
+ `):"").toString().trim();return p.length>0?p:"No context available."})(),originalQuestion:a.originalQuestion})).branch(a=>!a.disableQualityHealing).when(!0).execute("qualityValidator",a=>({generatedAnswer:a.answerGeneratorResult.comprehensiveAnswer,userQuery:a.originalQuestion})).map(a=>({...a,currentAnswer:a.answerGeneratorResult.comprehensiveAnswer,currentQuality:a.qualityValidatorResult.qualityScore,currentIssues:a.qualityValidatorResult.issues,shouldContinueHealing:a.qualityValidatorResult.qualityScore<a.qualityTarget})).while(a=>a.healingAttempts<3&&a.shouldContinueHealing).map(a=>({...a,healingAttempts:a.healingAttempts+1})).map(async a=>{let u=a.currentIssues||[],c=u.length>0?`${a.originalQuestion} addressing issues: ${u.join(", ")}`:`${a.originalQuestion} quality improvement`,l=await o(c);return{...a,healingResult:{healingDocument:l}}}).execute("answerHealer",a=>({originalAnswer:a.currentAnswer,healingDocument:a.healingResult.healingDocument,issues:a.currentIssues})).execute("qualityValidator",a=>({generatedAnswer:a.answerHealerResult.healedAnswer,userQuery:a.originalQuestion})).map(a=>({...a,currentAnswer:a.answerHealerResult.healedAnswer,currentQuality:a.qualityValidatorResult.qualityScore,currentIssues:a.qualityValidatorResult.issues,shouldContinueHealing:a.qualityValidatorResult.qualityScore<a.qualityTarget})).endWhile().when(!1).map(a=>({...a,currentAnswer:a.answerGeneratorResult.comprehensiveAnswer,currentQuality:1,currentIssues:[],shouldContinueHealing:!1})).merge().returns(a=>({finalAnswer:a.currentAnswer,totalHops:a.currentHop,retrievedContexts:a.retrievedContexts,iterationCount:a.iteration,healingAttempts:a.healingAttempts,qualityAchieved:a.currentQuality}))};
1406
1406
  //# sourceMappingURL=index.cjs.map