@ax-llm/ax 19.0.22 → 19.0.23

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.js CHANGED
@@ -1,48 +1,48 @@
1
- function dt({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 Wo=(()=>{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 Xe(){return Wo.randomUUID()}async function Nu(o){let e=new TextEncoder,t=typeof o=="string"?e.encode(o):o,n=await Wo.subtle.digest("SHA-256",t);return Array.from(new Uint8Array(n)).map(i=>i.toString(16).padStart(2,"0")).join("")}var Ko=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 Nu(this.data)}};function ut(o){if(o!=="sha256")throw new Error("Only SHA-256 algorithm is supported");return new Ko}function fa(){return Wo}var kr=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
+ function dt({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 Wo=(()=>{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 Xe(){return Wo.randomUUID()}async function Dl(o){let e=new TextEncoder,t=typeof o=="string"?e.encode(o):o,n=await Wo.subtle.digest("SHA-256",t);return Array.from(new Uint8Array(n)).map(i=>i.toString(16).padStart(2,"0")).join("")}var Ko=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 Dl(this.data)}};function lt(o){if(o!=="sha256")throw new Error("Only SHA-256 algorithm is supported");return new Ko}function Aa(){return Wo}var Sr=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 Vo=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)}},Or=class extends TransformStream{constructor(){super(new Vo)}};var Lu={maxRetries:3,initialDelayMs:1e3,maxDelayMs:6e4,backoffFactor:2,retryableStatusCodes:[500,408,429,502,503,504]},$u=globalThis.TextDecoderStream??Or,nt=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=Xe(),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()}},it=class extends nt{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"}},Ze=class extends nt{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}},$t=class extends nt{constructor(e,t,n,r,s=!0){super(e,t,n,void 0,r,s),this.name="AxAIServiceResponseError"}},At=class extends nt{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"}},mt=class extends nt{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"}},Er=class extends it{constructor(e,t,n,r,s,i,a=!0){super(e,t,n,r,s,i,void 0,a),this.name="AxTokenLimitError"}},Fe=class extends nt{constructor(e,t,n,r,s=!0){super(`Request aborted${t?`: ${t}`:""}`,e,n,void 0,{abortReason:t,...r},s),this.name="AxAIServiceAbortedError"}},Dt=class extends nt{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=Xe()}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 Vo=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)}},kr=class extends TransformStream{constructor(){super(new Vo)}};var Ul={maxRetries:3,initialDelayMs:1e3,maxDelayMs:6e4,backoffFactor:2,retryableStatusCodes:[500,408,429,502,503,504]},Gl=globalThis.TextDecoderStream??kr,nt=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=Xe(),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()}},it=class extends nt{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"}},Ze=class extends nt{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}},$t=class extends nt{constructor(e,t,n,r,s=!0){super(e,t,n,void 0,r,s),this.name="AxAIServiceResponseError"}},At=class extends nt{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"}},mt=class extends nt{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"}},Or=class extends it{constructor(e,t,n,r,s,i,a=!0){super(e,t,n,r,s,i,void 0,a),this.name="AxTokenLimitError"}},Fe=class extends nt{constructor(e,t,n,r,s=!0){super(`Request aborted${t?`: ${t}`:""}`,e,n,void 0,{abortReason:t,...r},s),this.name="AxAIServiceAbortedError"}},Dt=class extends nt{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=Xe()}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()}},yt=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=Xe()}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
10
  `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}},kt=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=Xe()}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 Jo(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 ha(o,e){return Math.min(e.maxDelayMs,e.initialDelayMs*e.backoffFactor**o)*(.75+Math.random()*.5)}function Du(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 Uu(){return{startTime:Date.now(),retryCount:0}}function xa(o){o.retryCount++,o.lastRetryTime=Date.now()}function Aa(o,e,t,n){return t>=n.maxRetries?!1:e&&n.retryableStatusCodes.includes(e)?!0:o instanceof Ze&&!(o instanceof Dt)}var et=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={...Lu,...o.retry},n=o.timeout,r=Uu(),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=Xe();if(o.validateRequest&&!await o.validateRequest(e))throw new $t("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 Fe(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(`
11
+ `)}[Symbol.for("nodejs.util.inspect.custom")](t,n){return this.toString()}};async function Jo(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 ya(o,e){return Math.min(e.maxDelayMs,e.initialDelayMs*e.backoffFactor**o)*(.75+Math.random()*.5)}function jl(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 Bl(){return{startTime:Date.now(),retryCount:0}}function ba(o){o.retryCount++,o.lastRetryTime=Date.now()}function Ia(o,e,t,n){return t>=n.maxRetries?!1:e&&n.retryableStatusCodes.includes(e)?!0:o instanceof Ze&&!(o instanceof Dt)}var et=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={...Ul,...o.retry},n=o.timeout,r=Bl(),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=Xe();if(o.validateRequest&&!await o.validateRequest(e))throw new $t("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 Fe(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 Jo(g);throw new Dt(u.href,e,T,{metrics:r},i)}if(g.status===400){let T=await Jo(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 Er(g.status,g.statusText,u.href,e,T,{metrics:r},i)}if(g.status>=400&&Aa(new Error,g.status,d,t)){let T=ha(d,t),C=Du(g.headers.get("Retry-After"));C!==void 0&&C<=t.maxDelayMs&&(T=C,s&&console.log(`[AxAI] Respecting Retry-After header: ${T}ms`)),d++,xa(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 Jo(g);throw new it(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 I=await Jo(g);throw new Dt(l.href,e,I,{metrics:r},i)}if(g.status===400){let I=await Jo(g),C=I,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 O=JSON.stringify(I).toLowerCase();(O.includes("token")&&O.includes("limit")||O.includes("context length")||O.includes("prompt is too long"))&&(v=!0)}if(v)throw new Or(g.status,g.statusText,l.href,e,I,{metrics:r},i)}if(g.status>=400&&Ia(new Error,g.status,d,t)){let I=ya(d,t),C=jl(g.headers.get("Retry-After"));C!==void 0&&C<=t.maxDelayMs&&(I=C,s&&console.log(`[AxAI] Respecting Retry-After header: ${I}ms`)),d++,ba(r),o.span?.addEvent("retry",{attempt:d,delay:I,status:g.status,"metrics.startTime":r.startTime,"metrics.retryCount":r.retryCount,"metrics.lastRetryTime":r.lastRetryTime}),await new Promise(v=>setTimeout(v,I));continue}if(g.status>=400){let I=await Jo(g);throw new it(g.status,g.statusText,l.href,e,I,{metrics:r},d>0?d:void 0,i)}if(!o.stream){let I=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(I,null,2),`
22
22
  -------------------------
23
- `),o.validateResponse&&!await o.validateResponse(T))throw new $t("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(I))throw new $t("Invalid response data",l.href,e,{validation:"response"},i);return o.span?.setAttributes({"response.time":Date.now()-r.startTime,"response.retries":r.retryCount}),I}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 $t("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 $t("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(I){let C=g.body.getReader(),v=new TextDecoder,O="";async function R(){try{for(;;){let{done:E,value:S}=await C.read();if(E){y=!0,I.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 At(u.href,e,f,{streamMetrics:_},i)):T.error(new Ze(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 $u).pipeThrough(new kr).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 At(u.href,e,f,{streamMetrics:E},i)):R instanceof TypeError&&R.message.includes("cancelled")?T.error(new At(u.href,e,f,{streamMetrics:E,cancelReason:"Stream cancelled by client"},i)):T.error(new Ze(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 Fe(u.href,o.abortSignal.reason,e,{metrics:r},i):new mt(u.href,n||0,e,{metrics:r},i);let f=g;if(!(g instanceof nt)&&g instanceof Error&&(f=new Ze(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 Ze&&Aa(f,void 0,d,t)){let x=ha(d,t);d++,xa(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 nt&&(f.context.metrics=r),f}finally{a!==void 0&&clearTimeout(a)}}};import{context as Ya,SpanKind as Xa}from"@opentelemetry/api";var fe={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 rt=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 rt,ya=o=>{console.log(o)},ba=(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]"){I.close();return}try{let G=JSON.parse(F);f=G,x++,r.streamChunks=x,r.lastChunkTime=Date.now(),I.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")?I.error(new At(l.href,e,f,{streamMetrics:_},i)):I.error(new Ze(S,l.href,e,"[ReadableStream - consumed during streaming]",{streamMetrics:_},i))}finally{C.releaseLock()}}R()}});let h=new TransformStream({transform(I,C){f=I,x++,r.streamChunks=x,r.lastChunkTime=Date.now(),C.enqueue(I),o.span?.addEvent("stream.chunk",{"stream.chunks":x,"stream.duration":Date.now()-r.startTime,"response.retries":r.retryCount})}}),y=!1;return new ReadableStream({start(I){let C=g.body.pipeThrough(new Gl).pipeThrough(new Sr).pipeThrough(h).getReader();async function v(){try{for(;;){let{done:O,value:R}=await C.read();if(O){y||(y=!0,I.close());break}if(y)break;I.enqueue(R)}}catch(O){let R=O,E={...r,streamDuration:Date.now()-r.startTime};throw R.name==="AbortError"||R.message?.includes("aborted")?I.error(new At(l.href,e,f,{streamMetrics:E},i)):R instanceof TypeError&&R.message.includes("cancelled")?I.error(new At(l.href,e,f,{streamMetrics:E,cancelReason:"Stream cancelled by client"},i)):I.error(new Ze(R,l.href,e,"[ReadableStream - consumed during streaming]",{streamMetrics:E},i)),R}finally{a&&clearTimeout(a),C.releaseLock()}}v()},cancel(){y=!0}})}catch(g){if(g instanceof Error&&g.name==="AbortError")throw o.abortSignal?.aborted?new Fe(l.href,o.abortSignal.reason,e,{metrics:r},i):new mt(l.href,n||0,e,{metrics:r},i);let f=g;if(!(g instanceof nt)&&g instanceof Error&&(f=new Ze(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 Ze&&Ia(f,void 0,d,t)){let x=ya(d,t);d++,ba(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 nt&&(f.context.metrics=r),f}finally{a!==void 0&&clearTimeout(a)}}};import{context as eu,SpanKind as tu}from"@opentelemetry/api";var Ae={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 rt=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 Of=new rt,Ca=o=>{console.log(o)},Ta=(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")}`}},Ta=(o=ya)=>{let e=new rt,t=e.gray(`${"\u2500".repeat(60)}
41
+ ${n(JSON.stringify(o),"gray")}`}},wa=(o=Ca)=>{let e=new rt,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+=ba(i,void 0,e),a<r.value.length-1&&(s+=`
45
+ `,r.value.forEach((i,a)=>{s+=Ta(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)}},Ca=Ta(),Gu=(o=ya)=>{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)}},Ra=wa(),zl=(o=Ca)=>{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+=ba(s),i<n.value.length-1&&(r+=`
108
+ `,n.value.forEach((s,i)=>{r+=Ta(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"},Ot={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"},Ia=(r=>(r.COMPLETION="completion",r.CHAT="chat",r.RERANK="rerank",r.UNKNOWN="unknown",r))(Ia||{}),wa=(s=>(s.WORKFLOW="workflow",s.TASK="task",s.AGENT="agent",s.TOOL="tool",s.UNKNOWN="unknown",s))(wa||{});var Qo=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()}},Mr=class extends TransformStream{constructor(e,t){super(new Qo(e,t))}};function Pr(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 Ra=(o,e,t,n)=>{let r=n?o.filter(i=>i.role!=="system"):[...o];t({name:"ChatRequestChatPrompt",step:e,value:r})};var va=(o,e)=>{if(!o.results)return;let t={name:"ChatResponseResults",value:o.results};e(t)};function Sa(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?Pr(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 ka=(o,e)=>{e({name:"FunctionResults",value:o})},Yo=(o,e,t,n)=>{n({name:"FunctionError",index:e,fixingInstructions:t,error:o})},Oa=(o,e,t,n)=>{n({name:"ValidationError",index:e,fixingInstructions:t,error:o})},Ea=(o,e,t,n)=>{n({name:"AssertionError",index:e,fixingInstructions:t,error:o})},Ma=(o,e,t)=>{t({name:"RefusalError",index:e,error:o})};var Pa=(o,e,t)=>{t({name:"EmbedRequest",embedModel:e,value:o})},Fa=(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)},_a=(o,e,t,n)=>{n({name:"ResultPickerUsed",sampleCount:o,selectedIndex:e,latency:t})};var _r=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},Kt=(...o)=>{let e={};for(let t of o)t&&Object.assign(e,t);return e},Fr,Na=o=>{if(Fr)return Fr;if(o)return Fr=Bu(o),Fr};var Bu=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)"})}),La=(o,e,t,n,r,s)=>{try{if(o.latencyHistogram){let i=_r({operation:e,ai_service:n,...r?{model:r}:{},...s});o.latencyHistogram.record(t,i)}}catch(i){console.warn("Failed to record latency metric:",i)}},$a=(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)},Da=(o,e,t,n,r)=>{try{if(o.errorCounter){let s=_r({operation:e,ai_service:t,...n?{model:n}:{},...r});o.errorCounter.add(1,s)}}catch(s){console.warn("Failed to record error metric:",s)}},Ua=(o,e,t,n,r,s)=>{o.errorRateGauge&&o.errorRateGauge.record(t*100,{operation:e,ai_service:n,...r?{model:r}:{},...s})},Ga=(o,e,t,n,r)=>{o.requestCounter&&o.requestCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},vn=(o,e,t,n,r,s)=>{try{let i=_r({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)}},Ba=(o,e,t,n,r,s)=>{t&&o.streamingRequestsCounter&&o.streamingRequestsCounter.add(1,{operation:e,ai_service:n,...r?{model:r}:{},...s})},ja=(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)},Xo=(o,e,t,n,r,s)=>{o.requestSizeHistogram&&o.requestSizeHistogram.record(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},Zo=(o,e,t,n,r,s)=>{o.responseSizeHistogram&&o.responseSizeHistogram.record(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},za=(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)},es=(o,e,t,n,r,s)=>{o.estimatedCostCounter&&o.estimatedCostCounter.add(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},qa=(o,e,t,n,r)=>{o.promptLengthHistogram&&o.promptLengthHistogram.record(e,{ai_service:t,...n?{model:n}:{},...r})},Ha=(o,e,t,n,r)=>{o.contextWindowUsageGauge&&o.contextWindowUsageGauge.record(e,{ai_service:t,...n?{model:n}:{},...r})},Ka=(o,e,t,n,r)=>{o.timeoutsCounter&&o.timeoutsCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},Wa=(o,e,t,n,r)=>{o.abortsCounter&&o.abortsCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},Va=(o,e,t,n,r)=>{o.thinkingBudgetUsageCounter&&o.thinkingBudgetUsageCounter.add(e,{ai_service:t,...n?{model:n}:{},...r})},Ja=(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})},ts=(o,e,t,n,r,s)=>{try{if(t<=0)return;let i=_r({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 Qa(o){try{return JSON.stringify(o,null,2)}catch{return String(o)}}function bt(o,e={}){let t=[o];throw e.fieldPath!==void 0&&t.push(`Field: ${e.fieldPath}`),e.value!==void 0&&t.push(`Value: ${Qa(e.value)}`),e.note&&t.push(`Note: ${e.note}`),e.item!==void 0&&t.push(`Chat item: ${Qa(e.item)}`),new Error(t.join(`
168
- `))}function Sn(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&&bt("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"&&bt("Assistant message content must be a string",{fieldPath:"content",value:n,item:o}),r!==void 0&&!Array.isArray(r)&&bt("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")&&bt("functionCalls entry must be an object",{fieldPath:`functionCalls[${c}]`,value:u,item:o}),(!("id"in u)||typeof u.id!="string"||u.id.trim()==="")&&bt("functionCalls entry must include a non-empty string id",{fieldPath:`functionCalls[${c}].id`,value:u.id,item:o}),(!("type"in u)||u.type!=="function")&&bt("functionCalls entry must have type 'function'",{fieldPath:`functionCalls[${c}].type`,value:u.type,item:o}),!("function"in u)||!u.function)bt("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()==="")&&bt("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"&&bt("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()==="")&&bt("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"&&bt("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 ns(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 rs=new Map;function ju(o){return`${o.providerName}:${o.contentHash}`}function zu(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 qu(o){let e=ut("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)zu(e,s)}else r.role==="assistant"&&r.content&&e.update(`assistant:${r.content}`)}return e.digest("hex")}var Re=()=>structuredClone({temperature:0}),We=()=>structuredClone({temperature:.4,frequencyPenalty:.2}),je=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??fe.tracer,this.meter=a.meter??fe.meter,this.modelInfo=s,this.models=c,this.id=Xe();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&&Hu(c)}#e=!1;#t=!1;rt;fetch;tracer;meter;timeout;excludeContentFromTrace;models;abortSignal;logger=fe.logger??Ca;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 Na(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??fe.debug??!1,this.#t=e.verbose??!1,this.rt=e.rateLimiter,this.fetch=e.fetch,this.timeout=e.timeout,this.tracer=e.tracer??fe.tracer,this.meter=e.meter??fe.meter,this.excludeContentFromTrace=e.excludeContentFromTrace,this.abortSignal=e.abortSignal,this.logger=e.logger??fe.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 Kt(fe.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);La(s,e,t,this.name,i,a),$a(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);Ga(s,e,this.name,i,a),t&&Da(s,e,this.name,i,a),Ua(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&&vn(n,"input",r,this.name,e.model,u),s&&vn(n,"output",s,this.name,e.model,u),i&&vn(n,"total",i,this.name,e.model,u),a&&vn(n,"thoughts",a,this.name,e.model,u),l&&ts(n,"read",l,this.name,e.model,u),c&&ts(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&&ja(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;Ka(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;Wa(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;Ba(r,"chat",l,this.name,s,a);let{hasImages:c,hasAudio:u}=this.detectMultimodalContent(e);Ja(r,c,u,this.name,s,a);let p=this.calculatePromptLength(e);qa(r,p,this.name,s,a),za(r,i?.temperature,i?.maxTokens,this.name,s,a),t?.thinkingTokenBudget&&this.modelUsage?.tokens?.thoughtsTokens&&Va(r,this.modelUsage.tokens.thoughtsTokens,this.name,s,a);let d=this.calculateRequestSize(e);if(Xo(r,"chat",d,this.name,s,a),n&&!l){let m=n,g=this.calculateResponseSize(m);if(Zo(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&&Ha(r,f,this.name,s,a);let x=this.estimateCost(this.lastUsedChatModel,m.modelUsage);x>0&&es(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);Xo(r,"embed",a,this.name,s,i);let l=this.calculateResponseSize(t);Zo(r,"embed",l,this.name,s,i);let c=this.estimateCostByName(s,t.modelUsage);c>0&&es(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)Sn(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:Xa.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??Ya.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&&Ra(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()&&Za(n,s,this.excludeContentFromTrace),await et({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()&&Za(n,s,this.excludeContentFromTrace),await et({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()&&el(S,s,this.excludeContentFromTrace),S},C=async R=>{s?.isRecording()&&s.end(),i&&Sa(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 Mr(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()&&(el(h,s,this.excludeContentFromTrace),s.end()),i&&va(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:Xa.SERVER,attributes:{[he.LLM_SYSTEM]:this.name,[he.LLM_OPERATION_NAME]:"embeddings",[he.LLM_REQUEST_MODEL]:n}},t?.traceContext??Ya.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&&Pa(l.texts??[],e,n?.logger??this.logger);let c=async()=>{let[m,g]=await s(l);return await et({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(Ot.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&&Fa(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=qu(t.chatPrompt);if(!p||p===ut("sha256").digest("hex"))return null;let d={providerName:this.getName(),contentHash:p},m=ju(d),g=Date.now(),f=s.registry,x=f?await f.get(m):rs.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):rs.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):rs.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 et({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 Za(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(Ot.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(Ot.GEN_AI_ASSISTANT_MESSAGE,a)}else if(s.content){let a={};t||(a.content=s.content),e.addEvent(Ot.GEN_AI_ASSISTANT_MESSAGE,a)}break}case"function":{let i={id:s.functionId};t||(i.content=s.result),e.addEvent(Ot.GEN_AI_TOOL_MESSAGE,i);break}}let r={};t||(r.content=n.join(`
169
- `)),e.addEvent(Ot.GEN_AI_USER_MESSAGE,r)}function el(o,e,t){if(o.modelUsage?.tokens){let n=o.modelUsage.tokens.thoughtsTokens?{[he.LLM_USAGE_THOUGHTS_TOKENS]:o.modelUsage.tokens.thoughtsTokens}:{};e.addEvent(Ot.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(Ot.GEN_AI_CHOICE,{finish_reason:r.finishReason,index:n,message:JSON.stringify(i,null,2)})}}function tl(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 Hu(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 Nr=(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))(Nr||{}),Lr=(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))(Lr||{});var $r=[{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},rl=()=>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"},...Re()}),Ku=()=>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"},...Re()}),os=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 _=Wu(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=nl(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:nl(s.stop_reason)}]}}return{results:[{index:r,content:""}]}};supportsImplicitCaching=()=>!0},kn=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,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={...rl(),...r},p=new os(u,a),d=g=>{let f=dt({model:g,modelInfo:$r,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:$r,defaults:{model:u.model},options:s,supportFor:d,models:m??i})}};function Wu(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=Vu(t);return Ju(n)}function Vu(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 Ju(o){return o.map(e=>e.role==="assistant"&&typeof e.content=="string"?{...e,content:e.content.replace(/\s+$/,"")}:e)}function nl(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 Dr=(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))(Dr||{}),On=(n=>(n.TextEmbeddingAda002="text-embedding-ada-002",n.TextEmbedding3Small="text-embedding-3-small",n.TextEmbedding3Large="text-embedding-3-large",n))(On||{});var En=(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))(En||{});var Mn=[{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}],ss=[{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 Qu=o=>{let e=["o1","o1-mini","o3","o3-mini","o4-mini","o1-pro","o3-pro"];return e.includes(o)||e.includes(o)},rn=()=>structuredClone({model:"gpt-5-mini",embedModel:"text-embedding-3-small",...Re()}),as=()=>structuredClone({...rn(),model:"gpt-5"}),ls=()=>structuredClone({model:"gpt-5-mini",embedModel:"text-embedding-3-small",...We()}),cs=()=>({...rn(),model:"gpt-5-nano"}),is=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=Yu(e),l=e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,c=e.modelConfig?.stream??this.config.stream,u=this.config.store,p=Qu(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=ol(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=ol(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)}}},ol=o=>{switch(o){case"stop":return"stop";case"length":return"length";case"content_filter":return"error";case"tool_calls":return"function_call"}};function Yu(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:l}){if(!e||e==="")throw new Error("OpenAI API key not set");let c=new is(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})}},Pn=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=[...Mn,...i??[]];let a=c=>{let u=dt({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:{...rn(),...n},options:r,modelInfo:i,models:l??s,supportFor:a}),super.setName("OpenAI")}};var Xu=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},Zu=o=>{let e=o.match(/^(\d{4}-\d{2}-\d{2})/);return e?e[1]>="2024-08-01":!1},sl=rn,ep=ls,tp=cs,np=as,Fn=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={...sl(),...s},u=Xu(r),p=Zu(u);l=[...Mn,...l??[]];let d=g=>{let f=dt({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 us=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.");rp(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 nt))throw p;switch(p.constructor){case Dt:throw p;case it:{if(![408,429,500,502,503,504].includes(p.status))throw p;break}case Ze:break;case $t:break;case At:break;case mt: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 nt)||r instanceof it&&![408,429,500,502,503,504].includes(r.status)||r instanceof Dt)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 rp(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 on(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 il(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 ps(o,e){return o.map(t=>{let n=t.getFeatures(),r=il(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 ds(o,e,t={}){if(e.length===0)throw new Error("No providers available");let n=on(o),r=ps(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 op(o,e){let t=on(o),n=ps(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 sp(o,e){return o.filter(t=>t.getFeatures().media[e].supported)}function ip(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 Ur=(r=>(r.CommandRPlus="command-r-plus",r.CommandR="command-r",r.Command="command",r.CommandLight="command-light",r))(Ur||{}),Gr=(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))(Gr||{});var ms=[{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 ap(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 ll=()=>structuredClone({model:"command-r-plus",embedModel:"embed-english-v3.0",...Re()}),lp=()=>structuredClone({model:"command-r",embedModel:"embed-english-v3.0",...We()}),gs=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=cp(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:ap(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}}},_n=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={...ll(),...t},i=new gs(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:ms,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 cp(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=al(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=al(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 al(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 Br=(n=>(n.DeepSeekChat="deepseek-chat",n.DeepSeekCoder="deepseek-coder",n.DeepSeekReasoner="deepseek-reasoner",n))(Br||{});var fs=[{name:"deepseek-chat",currency:"USD",promptTokenCostPer1M:.27,completionTokenCostPer1M:1.1},{name:"deepseek-reasoner",currency:"USD",promptTokenCostPer1M:.55,completionTokenCostPer1M:2.19}];var cl=()=>structuredClone({model:"deepseek-chat",...Re()}),up=()=>structuredClone({model:"deepseek-coder",...We()}),Nn=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={...cl(),...t};s=[...fs,...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 jr=(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))(jr||{}),hs=(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))(hs||{}),xs=(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))(xs||{}),As=(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))(As||{}),ul=(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))(ul||{}),pl=["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 ys=[{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 Wt=o=>o.includes("gemini-3"),dl=o=>o.includes("gemini-3")&&o.includes("pro"),zr=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,zr(n)]))),e.items&&(e.items=zr(e.items)),e},ml=[{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"}],gl=()=>structuredClone({model:"gemini-2.5-flash",embedModel:"text-embedding-005",safetySettings:ml,thinkingTokenBudgetLevels:{minimal:200,low:800,medium:5e3,high:1e4,highest:24500},thinkingLevelMapping:{minimal:"minimal",low:"low",medium:"medium",high:"high",highest:"high"},...Re()}),pp=()=>structuredClone({model:"gemini-2.0-flash",embedModel:"text-embedding-005",safetySettings:ml,thinkingTokenBudgetLevels:{minimal:200,low:800,medium:5e3,high:1e4,highest:24500},thinkingLevelMapping:{minimal:"minimal",low:"low",medium:"medium",high:"high",highest:"high"},...We()}),bs=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(Wt(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?zr(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&&Wt(n)&&(m.thinkingLevel=this.config.thinking.thinkingLevel),t?.thinkingTokenBudget){let h=this.getEffectiveMappings(n),b=h.thinkingTokenBudgetLevels;if(Wt(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,Wt(n)||delete m.thinkingLevel,Wt(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(Wt(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=zr(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:Xe(),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 pl.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"};Wt(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}}},Ln=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: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={...gl(),...s},m=new bs(d,c,r,e,i);l=[...ys,...l??[]];let g=x=>{let A=dt({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 dp=new rt,$n=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(dp.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 qr=(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))(qr||{});var Ts=[{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 mp=()=>structuredClone({model:"llama-3.3-70b-versatile",...Re()}),Dn=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={...mp(),...t},a={...n,streamingUsage:!1};s=[...Ts,...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 $n(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 Cs=[];var Is=(e=>(e.MetaLlama270BChatHF="meta-llama/Llama-2-70b-chat-hf",e))(Is||{});var fl=()=>structuredClone({model:"meta-llama/Llama-2-70b-chat-hf",...Re()}),gp=()=>structuredClone({model:"meta-llama/Llama-2-70b-chat-hf",...We()}),ws=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"},Ot={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"},va=(r=>(r.COMPLETION="completion",r.CHAT="chat",r.RERANK="rerank",r.UNKNOWN="unknown",r))(va||{}),Sa=(s=>(s.WORKFLOW="workflow",s.TASK="task",s.AGENT="agent",s.TOOL="tool",s.UNKNOWN="unknown",s))(Sa||{});var Qo=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()}},Er=class extends TransformStream{constructor(e,t){super(new Qo(e,t))}};function Mr(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 ka=(o,e,t,n)=>{let r=n?o.filter(i=>i.role!=="system"):[...o];t({name:"ChatRequestChatPrompt",step:e,value:r})};var Oa=(o,e)=>{if(!o.results)return;let t={name:"ChatResponseResults",value:o.results};e(t)};function Ea(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?Mr(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 Ma=(o,e)=>{e({name:"FunctionResults",value:o})},Yo=(o,e,t,n)=>{n({name:"FunctionError",index:e,fixingInstructions:t,error:o})},Pa=(o,e,t,n)=>{n({name:"ValidationError",index:e,fixingInstructions:t,error:o})},Fa=(o,e,t,n)=>{n({name:"AssertionError",index:e,fixingInstructions:t,error:o})},_a=(o,e,t)=>{t({name:"RefusalError",index:e,error:o})};var Na=(o,e,t)=>{t({name:"EmbedRequest",embedModel:e,value:o})},La=(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)},$a=(o,e,t,n)=>{n({name:"ResultPickerUsed",sampleCount:o,selectedIndex:e,latency:t})};var Fr=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},Kt=(...o)=>{let e={};for(let t of o)t&&Object.assign(e,t);return e},Pr,Da=o=>{if(Pr)return Pr;if(o)return Pr=ql(o),Pr};var ql=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)"})}),Ua=(o,e,t,n,r,s)=>{try{if(o.latencyHistogram){let i=Fr({operation:e,ai_service:n,...r?{model:r}:{},...s});o.latencyHistogram.record(t,i)}}catch(i){console.warn("Failed to record latency metric:",i)}},Ga=(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)},ja=(o,e,t,n,r)=>{try{if(o.errorCounter){let s=Fr({operation:e,ai_service:t,...n?{model:n}:{},...r});o.errorCounter.add(1,s)}}catch(s){console.warn("Failed to record error metric:",s)}},Ba=(o,e,t,n,r,s)=>{o.errorRateGauge&&o.errorRateGauge.record(t*100,{operation:e,ai_service:n,...r?{model:r}:{},...s})},za=(o,e,t,n,r)=>{o.requestCounter&&o.requestCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},Sn=(o,e,t,n,r,s)=>{try{let i=Fr({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)}},qa=(o,e,t,n,r,s)=>{t&&o.streamingRequestsCounter&&o.streamingRequestsCounter.add(1,{operation:e,ai_service:n,...r?{model:r}:{},...s})},Ha=(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)},Xo=(o,e,t,n,r,s)=>{o.requestSizeHistogram&&o.requestSizeHistogram.record(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},Zo=(o,e,t,n,r,s)=>{o.responseSizeHistogram&&o.responseSizeHistogram.record(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},Ka=(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)},es=(o,e,t,n,r,s)=>{o.estimatedCostCounter&&o.estimatedCostCounter.add(t,{operation:e,ai_service:n,...r?{model:r}:{},...s})},Wa=(o,e,t,n,r)=>{o.promptLengthHistogram&&o.promptLengthHistogram.record(e,{ai_service:t,...n?{model:n}:{},...r})},Va=(o,e,t,n,r)=>{o.contextWindowUsageGauge&&o.contextWindowUsageGauge.record(e,{ai_service:t,...n?{model:n}:{},...r})},Ja=(o,e,t,n,r)=>{o.timeoutsCounter&&o.timeoutsCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},Qa=(o,e,t,n,r)=>{o.abortsCounter&&o.abortsCounter.add(1,{operation:e,ai_service:t,...n?{model:n}:{},...r})},Ya=(o,e,t,n,r)=>{o.thinkingBudgetUsageCounter&&o.thinkingBudgetUsageCounter.add(e,{ai_service:t,...n?{model:n}:{},...r})},Xa=(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})},ts=(o,e,t,n,r,s)=>{try{if(t<=0)return;let i=Fr({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 Za(o){try{return JSON.stringify(o,null,2)}catch{return String(o)}}function bt(o,e={}){let t=[o];throw e.fieldPath!==void 0&&t.push(`Field: ${e.fieldPath}`),e.value!==void 0&&t.push(`Value: ${Za(e.value)}`),e.note&&t.push(`Note: ${e.note}`),e.item!==void 0&&t.push(`Chat item: ${Za(e.item)}`),new Error(t.join(`
168
+ `))}function kn(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&&bt("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"&&bt("Assistant message content must be a string",{fieldPath:"content",value:n,item:o}),r!==void 0&&!Array.isArray(r)&&bt("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")&&bt("functionCalls entry must be an object",{fieldPath:`functionCalls[${c}]`,value:l,item:o}),(!("id"in l)||typeof l.id!="string"||l.id.trim()==="")&&bt("functionCalls entry must include a non-empty string id",{fieldPath:`functionCalls[${c}].id`,value:l.id,item:o}),(!("type"in l)||l.type!=="function")&&bt("functionCalls entry must have type 'function'",{fieldPath:`functionCalls[${c}].type`,value:l.type,item:o}),!("function"in l)||!l.function)bt("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()==="")&&bt("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"&&bt("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()==="")&&bt("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"&&bt("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 ns(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 _r(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 rs=new Map;function Hl(o){return`${o.providerName}:${o.contentHash}`}function Kl(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 Wl(o){let e=lt("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)Kl(e,s)}else r.role==="assistant"&&r.content&&e.update(`assistant:${r.content}`)}return e.digest("hex")}var Se=()=>structuredClone({temperature:0}),We=()=>structuredClone({temperature:.4,frequencyPenalty:.2}),Be=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??Ae.tracer,this.meter=a.meter??Ae.meter,this.modelInfo=s,this.models=c,this.id=Xe();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&&Vl(c)}#e=!1;#t=!1;rt;fetch;tracer;meter;timeout;excludeContentFromTrace;models;abortSignal;logger=Ae.logger??Ra;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 Da(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??Ae.debug??!1,this.#t=e.verbose??!1,this.rt=e.rateLimiter,this.fetch=e.fetch,this.timeout=e.timeout,this.tracer=e.tracer??Ae.tracer,this.meter=e.meter??Ae.meter,this.excludeContentFromTrace=e.excludeContentFromTrace,this.abortSignal=e.abortSignal,this.logger=e.logger??Ae.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 Kt(Ae.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);Ua(s,e,t,this.name,i,a),Ga(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);za(s,e,this.name,i,a),t&&ja(s,e,this.name,i,a),Ba(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&&Sn(n,"input",r,this.name,e.model,l),s&&Sn(n,"output",s,this.name,e.model,l),i&&Sn(n,"total",i,this.name,e.model,l),a&&Sn(n,"thoughts",a,this.name,e.model,l),u&&ts(n,"read",u,this.name,e.model,l),c&&ts(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&&Ha(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;Ja(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;Qa(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;qa(r,"chat",u,this.name,s,a);let{hasImages:c,hasAudio:l}=this.detectMultimodalContent(e);Xa(r,c,l,this.name,s,a);let p=_r(e.chatPrompt);Wa(r,p,this.name,s,a),Ka(r,i?.temperature,i?.maxTokens,this.name,s,a),t?.thinkingTokenBudget&&this.modelUsage?.tokens?.thoughtsTokens&&Ya(r,this.modelUsage.tokens.thoughtsTokens,this.name,s,a);let d=this.calculateRequestSize(e);if(Xo(r,"chat",d,this.name,s,a),n&&!u){let m=n,g=this.calculateResponseSize(m);if(Zo(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&&Va(r,f,this.name,s,a);let x=this.estimateCost(this.lastUsedChatModel,m.modelUsage);x>0&&es(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);Xo(r,"embed",a,this.name,s,i);let u=this.calculateResponseSize(t);Zo(r,"embed",u,this.name,s,i);let c=this.estimateCostByName(s,t.modelUsage);c>0&&es(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)kn(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:tu.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??eu.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&&ka(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:I,name:C,cache:v}=y;return{role:"assistant",content:I,name:C,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()&&nu(n,s,this.excludeContentFromTrace),await et({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,I]=await this.aiImpl.createChatReq(m,r);return s?.isRecording()&&nu(n,s,this.excludeContentFromTrace),await et({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},I)},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),I=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()&&ru(S,s,this.excludeContentFromTrace),S},C=async R=>{s?.isRecording()&&s.end(),i&&Ea(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){C&&await C(S),$.close();break}let U=I(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 Er(I({}),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 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()&&(ru(h,s,this.excludeContentFromTrace),s.end()),i&&Oa(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:tu.SERVER,attributes:{[ye.LLM_SYSTEM]:this.name,[ye.LLM_OPERATION_NAME]:"embeddings",[ye.LLM_REQUEST_MODEL]:n}},t?.traceContext??eu.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&&Na(u.texts??[],e,n?.logger??this.logger);let c=async()=>{let[m,g]=await s(u);return await et({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(Ot.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&&La(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=Wl(t.chatPrompt);if(!p||p===lt("sha256").digest("hex"))return null;let d={providerName:this.getName(),contentHash:p},m=Hl(d),g=Date.now(),f=s.registry,x=f?await f.get(m):rs.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 I={cacheName:x.cacheName,expiresAt:g+u*1e3,tokenCount:x.tokenCount};f?await f.set(m,I):rs.set(m,{...I,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 I={cacheName:y.name,expiresAt:new Date(y.expiresAt).getTime(),tokenCount:y.tokenCount};return f?await f.set(m,I):rs.set(m,{...I,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 et({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 nu(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(Ot.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(Ot.GEN_AI_ASSISTANT_MESSAGE,a)}else if(s.content){let a={};t||(a.content=s.content),e.addEvent(Ot.GEN_AI_ASSISTANT_MESSAGE,a)}break}case"function":{let i={id:s.functionId};t||(i.content=s.result),e.addEvent(Ot.GEN_AI_TOOL_MESSAGE,i);break}}let r={};t||(r.content=n.join(`
169
+ `)),e.addEvent(Ot.GEN_AI_USER_MESSAGE,r)}function ru(o,e,t){if(o.modelUsage?.tokens){let n=o.modelUsage.tokens.thoughtsTokens?{[ye.LLM_USAGE_THOUGHTS_TOKENS]:o.modelUsage.tokens.thoughtsTokens}:{};e.addEvent(Ot.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(Ot.GEN_AI_CHOICE,{finish_reason:r.finishReason,index:n,message:JSON.stringify(i,null,2)})}}function os(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 Vl(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 Nr=(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))(Nr||{}),Lr=(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))(Lr||{});var $r=[{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},su=()=>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"},...Se()}),Jl=()=>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"},...Se()}),ss=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?Ut(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?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,y=e.modelConfig?.topK??this.config.topK,I=e.modelConfig?.n??this.config.n;if(I&&I>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"),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(C(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 _=Ql(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: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&&!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=ou(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:ou(s.stop_reason)}]}}return{results:[{index:r,content:""}]}};supportsImplicitCaching=()=>!0},On=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,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={...su(),...r},p=new ss(l,a),d=g=>{let f=dt({model:g,modelInfo:$r,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 I=l.thinkingTokenBudgetLevels,C=[["minimal",I?.minimal??1024],["low",I?.low??5e3],["medium",I?.medium??1e4],["high",I?.high??2e4],["highest",I?.highest??32e3]],v="minimal",O=Number.POSITIVE_INFINITY;for(let[R,E]of C){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:$r,defaults:{model:l.model},options:s,supportFor:d,models:m??i})}};function Ql(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=Yl(t);return Xl(n)}function Yl(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 Xl(o){return o.map(e=>e.role==="assistant"&&typeof e.content=="string"?{...e,content:e.content.replace(/\s+$/,"")}:e)}function ou(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 Dr=(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))(Dr||{}),En=(n=>(n.TextEmbeddingAda002="text-embedding-ada-002",n.TextEmbedding3Small="text-embedding-3-small",n.TextEmbedding3Large="text-embedding-3-large",n))(En||{});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 Pn=[{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}],is=[{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 Zl=o=>{let e=["o1","o1-mini","o3","o3-mini","o4-mini","o1-pro","o3-pro"];return e.includes(o)||e.includes(o)},an=()=>structuredClone({model:"gpt-5-mini",embedModel:"text-embedding-3-small",...Se()}),us=()=>structuredClone({...an(),model:"gpt-5"}),cs=()=>structuredClone({model:"gpt-5-mini",embedModel:"text-embedding-3-small",...We()}),ls=()=>({...an(),model:"gpt-5-nano"}),as=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=ep(e),u=e.modelConfig?.frequencyPenalty??this.config.frequencyPenalty,c=e.modelConfig?.stream??this.config.stream,l=this.config.store,p=Zl(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=iu(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=iu(f),A=d?.map(({id:h,index:y,function:{name:I,arguments:C}})=>{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:I,params:C}}: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)}}},iu=o=>{switch(o){case"stop":return"stop";case"length":return"length";case"content_filter":return"error";case"tool_calls":return"function_call"}};function ep(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:u}){if(!e||e==="")throw new Error("OpenAI API key not set");let c=new as(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})}},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=[...Pn,...i??[]];let a=c=>{let l=dt({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,I]of x){let C=Math.abs(f-I);C<h&&(h=C,A=y)}g.thinkingTokenBudget=A}return p?.thinking?.includeThoughts!==void 0&&(g.showThoughts=!!p.thinking.includeThoughts),g});super({apiKey:e,apiURL:t,config:{...an(),...n},options:r,modelInfo:i,models:u??s,supportFor:a}),super.setName("OpenAI")}};var tp=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},np=o=>{let e=o.match(/^(\d{4}-\d{2}-\d{2})/);return e?e[1]>="2024-08-01":!1},au=an,rp=cs,op=ls,sp=us,_n=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={...au(),...s},l=tp(r),p=np(l);u=[...Pn,...u??[]];let d=g=>{let f=dt({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 ps=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.");ip(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 nt))throw p;switch(p.constructor){case Dt:throw p;case it:{if(![408,429,500,502,503,504].includes(p.status))throw p;break}case Ze:break;case $t:break;case At:break;case mt: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 nt)||r instanceof it&&![408,429,500,502,503,504].includes(r.status)||r instanceof Dt)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 ip(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 un(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 uu(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 ds(o,e){return o.map(t=>{let n=t.getFeatures(),r=uu(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 ms(o,e,t={}){if(e.length===0)throw new Error("No providers available");let n=un(o),r=ds(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 ap(o,e){let t=un(o),n=ds(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 up(o,e){return o.filter(t=>t.getFeatures().media[e].supported)}function cp(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 Ur=(r=>(r.CommandRPlus="command-r-plus",r.CommandR="command-r",r.Command="command",r.CommandLight="command-light",r))(Ur||{}),Gr=(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))(Gr||{});var gs=[{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 lp(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 lu=()=>structuredClone({model:"command-r-plus",embedModel:"embed-english-v3.0",...Se()}),pp=()=>structuredClone({model:"command-r",embedModel:"embed-english-v3.0",...We()}),fs=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=dp(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:lp(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}}},Nn=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={...lu(),...t},i=new fs(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:gs,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 dp(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=cu(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=cu(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 cu(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 jr=(n=>(n.DeepSeekChat="deepseek-chat",n.DeepSeekCoder="deepseek-coder",n.DeepSeekReasoner="deepseek-reasoner",n))(jr||{});var hs=[{name:"deepseek-chat",currency:"USD",promptTokenCostPer1M:.27,completionTokenCostPer1M:1.1},{name:"deepseek-reasoner",currency:"USD",promptTokenCostPer1M:.55,completionTokenCostPer1M:2.19}];var pu=()=>structuredClone({model:"deepseek-chat",...Se()}),mp=()=>structuredClone({model:"deepseek-coder",...We()}),Ln=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={...pu(),...t};s=[...hs,...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=(I=>(I.Gemini31Pro="gemini-3.1-pro-preview",I.Gemini3FlashLite="gemini-3.1-flash-lite-preview",I.Gemini3Flash="gemini-3-flash-preview",I.Gemini3Pro="gemini-3.1-pro-preview",I.Gemini3ProImage="gemini-3-pro-image-preview",I.Gemini25Pro="gemini-2.5-pro",I.Gemini25Flash="gemini-2.5-flash",I.Gemini25FlashLite="gemini-2.5-flash-lite",I.Gemini20Flash="gemini-2.0-flash",I.Gemini20FlashLite="gemini-2.0-flash-lite",I.Gemini20ProExp="gemini-2.0-pro-exp-02-05",I.Gemini20FlashThinkingExp="gemini-2.0-flash-thinking-exp-01-21",I.Gemini1Pro="gemini-1.0-pro",I.Gemini15Flash="gemini-1.5-flash",I.Gemini15Flash002="gemini-1.5-flash-002",I.Gemini15Flash8B="gemini-1.5-flash-8b",I.Gemini15Pro="gemini-1.5-pro",I.GeminiFlashLatest="gemini-flash-latest",I.GeminiFlashLiteLatest="gemini-flash-lite-latest",I.GeminiProLatest="gemini-pro-latest",I))(Br||{}),xs=(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))(xs||{}),As=(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))(As||{}),ys=(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))(ys||{}),du=(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))(du||{}),mu=["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 bs=[{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 Wt=o=>o.includes("gemini-3"),gu=o=>o.includes("gemini-3")&&o.includes("pro"),zr=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,zr(n)]))),e.items&&(e.items=zr(e.items)),e},fu=[{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"}],hu=()=>structuredClone({model:"gemini-2.5-flash",embedModel:"text-embedding-005",safetySettings:fu,thinkingTokenBudgetLevels:{minimal:200,low:800,medium:5e3,high:1e4,highest:24500},thinkingLevelMapping:{minimal:"minimal",low:"low",medium:"medium",high:"high",highest:"high"},...Se()}),gp=()=>structuredClone({model:"gemini-2.0-flash",embedModel:"text-embedding-005",safetySettings:fu,thinkingTokenBudgetLevels:{minimal:200,low:800,medium:5e3,high:1e4,highest:24500},thinkingLevelMapping:{minimal:"minimal",low:"low",medium:"medium",high:"high",highest:"high"},...We()}),Is=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(Wt(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(gu(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 I=Array.isArray(y.content)?y.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:y.content}];u.push({role:"user",parts:I});break}case"assistant":{let I=[],C=y.thoughtBlocks,v=y.functionCalls&&y.functionCalls.length>0,O=C?.[0],R=C?.map(S=>S.data).join("")??"",E=O?.signature;if(R&&I.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});I.push(...S)}if(y.content&&I.push({text:y.content}),I.length===0)throw new Error("Assistant content is empty");u.push({role:"model",parts:I});break}case"function":{let I=[],C=y,v=h;for(;;){if(!("functionId"in C))throw new Error(`Chat prompt functionId is empty (index: ${v})`);if(I.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,u.push({role:"user",parts:I});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 I={type:"object",properties:{dummy:{type:"string",description:"An optional dummy parameter, do not use"}},required:[]},C=y.parameters?zr(y.parameters):void 0;return C===void 0||C&&typeof C=="object"&&Object.keys(C).length===0?C={...I}: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:y.name,description:y.description,parameters:C}});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&&Wt(n)&&(m.thinkingLevel=this.config.thinking.thinkingLevel),t?.thinkingTokenBudget){let h=this.getEffectiveMappings(n),y=h.thinkingTokenBudgetLevels;if(Wt(n)){let C=gu(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(C&&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,Wt(n)||delete m.thinkingLevel,Wt(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(Wt(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=zr(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:Xe(),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 mu.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"};Wt(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}}},$n=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: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={...hu(),...s},m=new Is(d,c,r,e,i);u=[...bs,...u??[]];let g=x=>{let A=dt({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 I={...A};Object.keys(y).length>0&&(I.modelConfig={...A.modelConfig??{},...y});let C=h.thinking?.thinkingTokenBudget;if(typeof C=="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(C-_);$<E&&(E=$,R=S)}I.thinkingTokenBudget=R}return h.thinking?.includeThoughts!==void 0&&(I.showThoughts=!!h.thinking.includeThoughts),h.thinkingLevelMapping&&(I.thinkingLevelMapping=h.thinkingLevelMapping),h.thinkingTokenBudgetLevels&&(I.thinkingTokenBudgetLevels=h.thinkingTokenBudgetLevels),I});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 fp=new rt,Dn=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(fp.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 qr=(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))(qr||{});var Cs=[{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 hp=()=>structuredClone({model:"llama-3.3-70b-versatile",...Se()}),Un=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={...hp(),...t},a={...n,streamingUsage:!1};s=[...Cs,...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 Dn(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 Ts=[];var ws=(e=>(e.MetaLlama270BChatHF="meta-llama/Llama-2-70b-chat-hf",e))(ws||{});var xu=()=>structuredClone({model:"meta-llama/Llama-2-70b-chat-hf",...Se()}),xp=()=>structuredClone({model:"meta-llama/Llama-2-70b-chat-hf",...We()}),Rs=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}]})},Un=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={...fl(),...t},i=new ws(s);super(i,{name:"HuggingFace",apiURL:"https://api-inference.huggingface.co",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:Cs,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 Hr=(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))(Hr||{}),hl=(e=>(e.MistralEmbed="mistral-embed",e))(hl||{});var Rs=[{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 vs=()=>structuredClone({model:"mistral-small-latest",...Re(),topP:1}),fp=()=>structuredClone({...vs(),model:"mistral-large-latest"}),Gn=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={...vs(),...t};s=[...Rs,...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 Ss=class{constructor(e={}){this.config=e;this.config.id=this.config.id??Xe()}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 ks=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 xl=()=>structuredClone({...Re(),model:"nous-hermes2",embedModel:"all-minilm"}),hp=()=>structuredClone({...We(),model:"nous-hermes2",embedModel:"all-minilm"}),Bn=class extends Ge{constructor({apiKey:e="not-set",url:t="http://localhost:11434/v1",config:n,options:r,models:s}){let i={...xl(),...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 xp=o=>["o1","o1-mini","o1-pro","o3","o3-mini","o3-pro","o4-mini"].includes(o),jn=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=xp(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=Os(i.content,t),s.finishReason=i.status==="completed"?"stop":"content_filter",s.citations=Kr(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=Os(t.item.content,t.item.id),n.citations=Kr(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=Os([t.part],t.item_id),n.citations=Kr([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=Kr(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]}},Os=(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}]})},Gn=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={...xu(),...t},i=new Rs(s);super(i,{name:"HuggingFace",apiURL:"https://api-inference.huggingface.co",headers:async()=>({Authorization:`Bearer ${e}`}),modelInfo:Ts,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 Hr=(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))(Hr||{}),Au=(e=>(e.MistralEmbed="mistral-embed",e))(Au||{});var vs=[{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 Ss=()=>structuredClone({model:"mistral-small-latest",...Se(),topP:1}),Ap=()=>structuredClone({...Ss(),model:"mistral-large-latest"}),jn=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={...Ss(),...t};s=[...vs,...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 ks=class{constructor(e={}){this.config=e;this.config.id=this.config.id??Xe()}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 Os=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 yu=()=>structuredClone({...Se(),model:"nous-hermes2",embedModel:"all-minilm"}),yp=()=>structuredClone({...We(),model:"nous-hermes2",embedModel:"all-minilm"}),Bn=class extends Ge{constructor({apiKey:e="not-set",url:t="http://localhost:11434/v1",config:n,options:r,models:s}){let i={...yu(),...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 bp=o=>["o1","o1-mini","o1-pro","o3","o3-mini","o3-pro","o4-mini"].includes(o),zn=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=bp(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=Es(i.content,t),s.finishReason=i.status==="completed"?"stop":"content_filter",s.citations=Kr(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=Es(t.item.content,t.item.id),n.citations=Kr(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=Es([t.part],t.item_id),n.citations=Kr([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=Kr(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]}},Es=(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 Kr(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}),Ap=()=>({...Vr(),model:"gpt-4o",temperature:.5}),yp=()=>({...Vr(),model:"gpt-4o",temperature:.9}),Wr=class extends je{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 jn(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})}},zn=class extends Wr{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("OpenAI API key not set");s=[...ss,...s??[]];let i=a=>{let l=dt({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:{...Vr(),...t},options:n,modelInfo:s,models:r,supportFor:i})}};var Al=()=>structuredClone({model:"openrouter/auto",...Re()}),qn=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={...Al(),...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 Es(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 kt(i,"image","vision analysis")}else switch(t.fallbackBehavior){case"error":throw new yt("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 kt(i,"audio","transcription")}else switch(t.fallbackBehavior){case"error":throw new yt("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 kt(i,"file","text extraction")}else switch(t.fallbackBehavior){case"error":throw new yt("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 kt(i,"url","content fetching")}else switch(t.fallbackBehavior){case"error":throw new yt("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 yt||i instanceof kt?i:new kt(i,s.type||"unknown","content processing")}return r}function bp(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 Jr=(n=>(n.RekaCore="reka-core",n.RekaFlash="reka-flash",n.RekaEdge="reka-edge",n))(Jr||{});var Ms=[{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 Qr=()=>structuredClone({model:"reka-core",...Re()}),Tp=()=>structuredClone({...Qr(),model:"reka-core"}),Cp=()=>structuredClone({model:"reka-core",...We()}),Ip=()=>({...Qr(),model:"reka-flash"}),Ps=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=wp(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=yl(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=yl(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}})}}},yl=o=>{switch(o){case"stop":return"stop";case"context":return"length";case"length":return"length"}};function wp(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 Hn=class extends je{constructor({apiKey:e,config:t,options:n,apiURL:r,modelInfo:s=Ms,models:i}){if(!e||e==="")throw new Error("Reka API key not set");let a={...Qr(),...t},l=new Ps(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 Fs=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 yt&&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 Es(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=on(e),r=[],s=[],i=[];try{let a=ds(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=on(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 Yr=(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))(Yr||{});var _s=[{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 bl=()=>structuredClone({model:"meta-llama/Llama-3.3-70B-Instruct-Turbo",...Re()}),Kn=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={...bl(),...t};s=[..._s,...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 Xr=(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))(Xr||{});var Ns=[{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 Tl=()=>structuredClone({model:"Llama-3.2-3B-Instruct-q4f32_1-MLC",...Re()}),Rp=()=>structuredClone({model:"Llama-3.2-3B-Instruct-q4f32_1-MLC",...We()}),Ls=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")}},Wn=class extends je{constructor({engine:e,config:t,options:n,models:r}){if(!e)throw new Error("WebLLM engine instance is required");let s={...Tl(),...t},i=new Ls(s,e);super(i,{name:"WebLLM",apiURL:void 0,headers:async()=>({}),modelInfo:Ns,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 Zr=(r=>(r.Grok3="grok-3",r.Grok3Mini="grok-3-mini",r.Grok3Fast="grok-3-fast",r.Grok3MiniFast="grok-3-mini-fast",r))(Zr||{}),Cl=(e=>(e.GrokEmbedSmall="grok-embed-small",e))(Cl||{});var $s=[{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 Ds=()=>structuredClone({model:"grok-3-mini",...Re()}),vp=()=>structuredClone({...Ds(),model:"grok-3"}),Vn=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={...Ds(),...t};s=[...$s,...s??[]];let a=c=>{let u=dt({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 Sp(o){return eo.create(o)}var eo=class o{ai;static create(e){return new o(e)}constructor(e){switch(e.name){case"openai":this.ai=new Pn(e);break;case"openai-responses":this.ai=new zn(e);break;case"azure-openai":this.ai=new Fn(e);break;case"grok":this.ai=new Vn(e);break;case"huggingface":this.ai=new Un(e);break;case"groq":this.ai=new Dn(e);break;case"together":this.ai=new Kn(e);break;case"openrouter":this.ai=new qn(e);break;case"cohere":this.ai=new _n(e);break;case"google-gemini":this.ai=new Ln(e);break;case"anthropic":this.ai=new kn(e);break;case"mistral":this.ai=new Gn(e);break;case"deepseek":this.ai=new Nn(e);break;case"ollama":this.ai=new Bn(e);break;case"reka":this.ai=new Hn(e);break;case"webllm":this.ai=new Wn(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()}};import{SpanKind as Us}from"@opentelemetry/api";var Tt=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:Us.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:Us.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:Us.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 Gs="https://api.cloudflare.com/client/v4/accounts/",Jn=class extends Tt{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 et({url:new URL(`${this.accountId}/vectorize/indexes/${e.table}/upsert`,Gs),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 et({url:new URL(`${this.accountId}/vectorize/indexes/${r}/upsert`,Gs),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 et({url:new URL(`${this.accountId}/vectorize/indexes/${e.table}/query`,Gs),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 Vt=class extends Tt{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=kp(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={}}},kp=(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 Op=o=>({namespace:o.namespace,topK:o.limit||10,filter:{},includeValues:!0,includeMetadata:!0,vector:o.values??[],id:o.id}),Qn=class extends Tt{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 et({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 et({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:"/query",fetch:this.fetch,span:t?.span},Op(e))).matches.map(({id:s,score:i,values:a,metadata:l})=>({id:s,score:i,metadata:l,values:a}))}}};var Yn=class extends Tt{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 et({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 et({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 Kr(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}),Ip=()=>({...Vr(),model:"gpt-4o",temperature:.5}),Cp=()=>({...Vr(),model:"gpt-4o",temperature:.9}),Wr=class extends Be{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 zn(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",I=Number.POSITIVE_INFINITY;for(let[C,v]of h){let O=Math.abs(A-v);O<I&&(I=O,y=C)}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})}},qn=class extends Wr{constructor({apiKey:e,config:t,options:n,models:r,modelInfo:s}){if(!e||e==="")throw new Error("OpenAI API key not set");s=[...is,...s??[]];let i=a=>{let u=dt({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 bu=()=>structuredClone({model:"openrouter/auto",...Se()}),Hn=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={...bu(),...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 Ms(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 kt(i,"image","vision analysis")}else switch(t.fallbackBehavior){case"error":throw new yt("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 kt(i,"audio","transcription")}else switch(t.fallbackBehavior){case"error":throw new yt("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 kt(i,"file","text extraction")}else switch(t.fallbackBehavior){case"error":throw new yt("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 kt(i,"url","content fetching")}else switch(t.fallbackBehavior){case"error":throw new yt("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 yt||i instanceof kt?i:new kt(i,s.type||"unknown","content processing")}return r}function Tp(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 Jr=(n=>(n.RekaCore="reka-core",n.RekaFlash="reka-flash",n.RekaEdge="reka-edge",n))(Jr||{});var Ps=[{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 Qr=()=>structuredClone({model:"reka-core",...Se()}),wp=()=>structuredClone({...Qr(),model:"reka-core"}),Rp=()=>structuredClone({model:"reka-core",...We()}),vp=()=>({...Qr(),model:"reka-flash"}),Fs=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=Sp(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=Iu(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=Iu(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}})}}},Iu=o=>{switch(o){case"stop":return"stop";case"context":return"length";case"length":return"length"}};function Sp(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=Ps,models:i}){if(!e||e==="")throw new Error("Reka API key not set");let a={...Qr(),...t},u=new Fs(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 _s=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 yt&&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 Ms(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=un(e),r=[],s=[],i=[];try{let a=ms(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=un(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 Yr=(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))(Yr||{});var Ns=[{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 Cu=()=>structuredClone({model:"meta-llama/Llama-3.3-70B-Instruct-Turbo",...Se()}),Wn=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={...Cu(),...t};s=[...Ns,...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 Xr=(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))(Xr||{});var Ls=[{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 Tu=()=>structuredClone({model:"Llama-3.2-3B-Instruct-q4f32_1-MLC",...Se()}),kp=()=>structuredClone({model:"Llama-3.2-3B-Instruct-q4f32_1-MLC",...We()}),$s=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")}},Vn=class extends Be{constructor({engine:e,config:t,options:n,models:r}){if(!e)throw new Error("WebLLM engine instance is required");let s={...Tu(),...t},i=new $s(s,e);super(i,{name:"WebLLM",apiURL:void 0,headers:async()=>({}),modelInfo:Ls,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 Zr=(r=>(r.Grok3="grok-3",r.Grok3Mini="grok-3-mini",r.Grok3Fast="grok-3-fast",r.Grok3MiniFast="grok-3-mini-fast",r))(Zr||{}),wu=(e=>(e.GrokEmbedSmall="grok-embed-small",e))(wu||{});var Ds=[{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 Us=()=>structuredClone({model:"grok-3-mini",...Se()}),Op=()=>structuredClone({...Us(),model:"grok-3"}),Jn=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={...Us(),...t};s=[...Ds,...s??[]];let a=c=>{let l=dt({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 Ep(o){return eo.create(o)}var eo=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 qn(e);break;case"azure-openai":this.ai=new _n(e);break;case"grok":this.ai=new Jn(e);break;case"huggingface":this.ai=new Gn(e);break;case"groq":this.ai=new Un(e);break;case"together":this.ai=new Wn(e);break;case"openrouter":this.ai=new Hn(e);break;case"cohere":this.ai=new Nn(e);break;case"google-gemini":this.ai=new $n(e);break;case"anthropic":this.ai=new On(e);break;case"mistral":this.ai=new jn(e);break;case"deepseek":this.ai=new Ln(e);break;case"ollama":this.ai=new Bn(e);break;case"reka":this.ai=new Kn(e);break;case"webllm":this.ai=new Vn(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()}};import{SpanKind as Gs}from"@opentelemetry/api";var It=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:Gs.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:Gs.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:Gs.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 js="https://api.cloudflare.com/client/v4/accounts/",Qn=class extends It{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 et({url:new URL(`${this.accountId}/vectorize/indexes/${e.table}/upsert`,js),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 et({url:new URL(`${this.accountId}/vectorize/indexes/${r}/upsert`,js),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 et({url:new URL(`${this.accountId}/vectorize/indexes/${e.table}/query`,js),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 Vt=class extends It{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=Mp(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={}}},Mp=(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 Pp=o=>({namespace:o.namespace,topK:o.limit||10,filter:{},includeValues:!0,includeMetadata:!0,vector:o.values??[],id:o.id}),Yn=class extends It{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 et({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 et({url:this.apiURL,headers:{Authorization:`Bearer ${this.apiKey}`},name:"/query",fetch:this.fetch,span:t?.span},Pp(e))).matches.map(({id:s,score:i,values:a,metadata:u})=>({id:s,score:i,metadata:u,values:a}))}}};var Xn=class extends It{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 et({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 et({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 Bs=class{db;constructor(e){switch(e.name){case"weaviate":this.db=new Yn(e);break;case"pinecone":this.db=new Qn(e);break;case"cloudflare":this.db=new Jn(e);break;case"memory":this.db=new Vt(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 js="_internal",zs=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 Bs=class{db;constructor(e){switch(e.name){case"weaviate":this.db=new Xn(e);break;case"pinecone":this.db=new Yn(e);break;case"cloudflare":this.db=new Qn(e);break;case"memory":this.db=new Vt(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 zs="_internal",qs=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=Ep({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:js,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:js,values:c})):s=r.map(l=>this.db.query({table:js,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?Mp(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}},Ep=({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=Fp({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:zs,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:zs,values:c})):s=r.map(u=>this.db.query({table:zs,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?_p(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}},Fp=({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},Mp=(o,e=.1)=>{let t=[...o].sort((r,s)=>r.score-s.score),n=Math.ceil(t.length*e);return t.slice(0,n)};import{context as fd,SpanKind as hd,trace as xd}from"@opentelemetry/api";var Xn=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}},Zn=class{memories=new Map;defaultMemory;constructor(){this.defaultMemory=new Xn}getMemory(e){return e?(this.memories.has(e)||this.memories.set(e,new Xn),this.memories.get(e)):this.defaultMemory}addRequest(e,t){for(let n of e)Sn(n);this.getMemory(t).addRequest(e,0)}addResponse(e,t){ns(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 Xn):this.defaultMemory.reset()}};function Ct(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 Nt=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()}},sn=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 Nt({message:s});if(!s)throw r?new Nt({message:r}):new Error("Assertion Failed: No message provided for assertion")}}},qs=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 Nt({message:c});if(!c&&a)throw new Nt({message:a})}}};var Il={enabled:!0,enabledCategories:["generation","streaming","functions","errors","performance"],maxLabelLength:100,samplingRate:1},er,Hs=o=>{if(er)return er;let e=o??fe.meter;if(e)return er=Fp(e),er};var Pp=()=>{let o=[];return fe.meter||o.push("Global meter not initialized"),!er&&fe.meter&&o.push("Metrics instruments not created despite available meter"),{healthy:o.length===0,issues:o}},Fp=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"})}),to=Il,_p=o=>{to={...to,...o}},Np=()=>({...to}),It=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n),s=to.maxLabelLength;e[t]=r.length>s?r.substring(0,s):r}return e};var wl=(o,e,t,n,r,s,i)=>{try{let a=It({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)}},no=(o,e,t,n,r)=>{try{let s=It({...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)}},Ks=(o,e,t,n)=>{try{let r=It({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)}},Rl=(o,e,t)=>{try{let n=It({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)}},Ws=(o,e,t,n,r,s)=>{try{let i=It({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)}},vl=(o,e,t,n,r=!1,s,i)=>{try{let a=It({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)}},Sl=(o,e,t,n,r)=>{try{let s=It({...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)}},kl=(o,e,t,n,r,s)=>{try{let i=It({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)}},Ol=(o,e,t,n,r,s)=>{try{let i=It({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)}},El=(o,e,t,n,r,s,i)=>{try{let a=It({...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)}},ro=(o,e,t,n,r)=>{try{let s=It({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 an=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},Ve=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()}},Ml=o=>{let t=o.map(n=>`'${n.title}' (${an(n.type)})`).join(", ");return new Ve(`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 ${an(o[0]?.type)} value. Keep the output concise and avoid unrelated text.`)},oo=o=>new Ve(`Expected (Required) field not found: '${o.title}'. Begin a new section with "${o.title}:" and then provide a valid ${an(o.type)} value directly after.`);var so=o=>new Ve(`Required field is missing: '${o.title}'. After the "${o.title}:" label, provide a non-empty ${an(o.type)}. Do not use null, undefined, or leave it blank.`),Pl=(o,e)=>new Ve(`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.`),Fl=(o,e)=>new Ve(`Invalid Array: ${e} for '${o.title}'. Provide a JSON array of ${an(o.type)} items (e.g., [ ... ]). Markdown lists are also accepted if each item is on its own line starting with a hyphen.`),_l=(o,e,t)=>new Ve(`Field '${o.title}' has an invalid value '${e}': ${t}. Provide a ${an(o.type)}. Ensure formatting exactly matches the expected type.`),Nl=(o,e,t)=>new Ve(`Invalid date for '${o.title}': ${t}. Use the exact format YYYY-MM-DD (e.g., 2024-05-09). You provided: ${e}.`),Ll=(o,e,t)=>new Ve(`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}.`),Vs=(o,e,t)=>new Ve(`Invalid URL for '${o.title}': ${t}. Use a valid URL format (e.g., https://example.com). You provided: ${e}.`),ln=(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 Ve(r)},Js=(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 Ve(r)};var $l=({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(", ")??"";Oa(o,e,c,n)}return r&&Ks(r,"validation",s,a),i&&i.addEvent("validation.error",{message:o.toString(),fixing_instructions:l?.map(c=>c.title).join(", ")??""}),l},Dl=({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(", ")??"";Ea(o,e,c,n)}return r&&Ks(r,"assertion",s,a),i&&i.addEvent("assertion.error",{message:o.toString(),fixing_instructions:l?.map(c=>c.title).join(", ")??""}),l},Ul=({error:o,errCount:e,debug:t,logger:n,metricsInstruments:r,signatureName:s,span:i,customLabels:a})=>{t&&n&&Ma(o,e,n),r&&Rl(r,s,a),i&&i.addEvent("refusal.error",{message:o.toString()})};import Jt from"dayjs";import Lp from"dayjs/plugin/customParseFormat.js";import $p from"dayjs/plugin/timezone.js";import Dp from"dayjs/plugin/utc.js";Jt.extend(Dp);Jt.extend($p);Jt.extend(Lp);function Gl(o,e,t=!1){try{return Up(e)}catch(n){if(o.isOptional&&!t)return;let r=n.message;throw Nl(o,e,r)}}function Up(o){if(!Jt(o,"YYYY-MM-DD",!0).isValid())throw new Error('Invalid date format. Please provide the date in "YYYY-MM-DD" format.');return Jt.utc(o,"YYYY-MM-DD").startOf("day").toDate()}function Bl(o,e,t=!1){try{return Gp(e)}catch(n){if(o.isOptional&&!t)return;let r=n.message;throw Ll(o,e,r)}}function Gp(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=Jt.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 jl=o=>Jt(o).utc().format("YYYY-MM-DD HH:mm:ss [UTC]");var ky=new rt,tr=(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 nr(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 zl=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 Ys(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 Qs=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)}},Bp=new Qs(500);function ql(o,e,t=0,n=Bp){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 Gt(o,e){if(typeof o!="string")throw Vs(e,String(o),"URL must be a string");try{new URL(o)}catch{throw Vs(e,o,"Invalid URL format. Expected a valid URL like https://example.com")}}function gt(o,e){if(typeof o!="string")return;let t=e.type;if(t){if(t.minLength!==void 0&&o.length<t.minLength)throw ln(e,o,"minLength",t.minLength);if(t.maxLength!==void 0&&o.length>t.maxLength)throw ln(e,o,"maxLength",t.maxLength);if(t.pattern!==void 0&&!new RegExp(t.pattern).test(o))throw ln(e,o,"pattern",t.pattern);if(t.format==="email"&&!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(o))throw ln(e,o,"format","valid email address");if(t.format==="uri"||t.format==="url")try{new URL(o)}catch{throw ln(e,o,"format","valid URL")}}}function ft(o,e){if(typeof o!="number")return;let t=e.type;if(t){if(t.minimum!==void 0&&o<t.minimum)throw Js(e,o,"minimum",t.minimum);if(t.maximum!==void 0&&o>t.maximum)throw Js(e,o,"maximum",t.maximum)}}var lo=(o,e,t,n)=>{let r=n?.strictMode??!1,s=n?.treatAllFieldsOptional??!1,i=n?.treatAllFieldsOptional??!1,a={extractedFields:[],streamedIndex:{},s:-1};ei(o,e,a,t,{strictMode:r,skipEarlyFail:i,treatAllFieldsOptional:s}),ti(o,e,a,t,{strictMode:r,treatAllFieldsOptional:s,forceFinalize:!0});for(let l of o.getOutputFields())l.isInternal&&delete e[l.name]},Xs=(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 Ml(n)},ei=(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=ql(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 oo(g)}break}if(a&&p&&a.name!==p.name)throw oo(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=io(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)}},ti=(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=io(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 oo(p)}if(jp(o,e,n,t),!i){let c=t.currField!==void 0||(t.extractedFields?.length??0)>0;s||l?Xs(t,e,o.getOutputFields()):c||Xs(t,e,o.getOutputFields())}},jp=(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=io(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=io(i,u);if(p!==void 0){e[i.name]=p;break}}catch(p){if(!i.isOptional)throw p}break}}}},Hl=(o,e,t=!1)=>{switch(o.type?.name){case"code":return Zs(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 Gl(o,e,t);case"datetime":return Bl(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*Kl(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*ni(o,e,t,n,r){for(let i of n.prevFields??[]){let{field:a,s:l,e:c}=i;yield*Kl(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*Kl(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 io(o,e){if(!e||e===""||/^(null|undefined)\s*$/i.test(e)){if(o.isOptional)return;throw so(o)}let t;if(o.type?.name==="json"&&!o.type?.isArray)try{let r=Zs(e);return t=JSON.parse(r),t}catch(r){throw Pl(o,r.message)}if(o.type?.isArray)try{try{t=JSON.parse(e)}catch{t=zl(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 Fl(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=Zs(i);i=JSON.parse(a)}catch{}t[r]=Hl(o,i,!0)}}else t=Hl(o,e)}catch(r){throw _l(o,e,r.message)}if(typeof t=="string"&&t==="")return;let n=o.type;if(n&&t!==void 0&&(n.name==="url"&&Gt(t,o),(n.name==="string"||n.name==="code")&&gt(t,o),n.name==="number"&&ft(t,o),n.isArray&&Array.isArray(t)))for(let r of t)r!==void 0&&(n.name==="string"||n.name==="code"?gt(r,o):n.name==="number"&&ft(r,o));return t}function cn(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 so(r);continue}let i=r.type;if(i){if(i.name==="url"&&Gt(s,r),(i.name==="string"||i.name==="code")&&gt(s,r),i.name==="number"&&ft(s,r),i.isArray&&Array.isArray(s))for(let a of s)a!=null&&(i.name==="url"?Gt(a,r):i.name==="string"||i.name==="code"?gt(a,r):i.name==="number"&&ft(a,r));if(i.name==="object"&&i.fields&&typeof s=="object"&&!Array.isArray(s)&&ao(r,s,t),i.isArray&&i.fields&&Array.isArray(s)&&i.name==="object")for(let a of s)a&&typeof a=="object"&&ao(r,a,t)}}}function ao(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 so(i);continue}let l=i.type;if(l){if(l.name==="url"&&Gt(a,i),(l.name==="string"||l.name==="code")&&gt(a,i),l.name==="number"&&ft(a,i),l.isArray&&Array.isArray(a))for(let c of a)c!=null&&(l.name==="url"?Gt(c,i):l.name==="string"||l.name==="code"?gt(c,i):l.name==="number"&&ft(c,i));if(l.name==="object"&&l.fields&&typeof a=="object"&&!Array.isArray(a)&&ao(i,a,t),l.isArray&&l.fields&&Array.isArray(a)&&l.name==="object")for(let c of a)c&&typeof c=="object"&&ao(i,c,t)}}}var Zs=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 rr(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});Wl(r.field,t,i,n)}}async function ri(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});Wl(t.currField,n,u,s)}}var Wl=(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 Vl(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 Bt(o,e="Schema"){if("name"in o&&"type"in o)return co(o);let t={},n=[];for(let r of o){if(r.isInternal)continue;let s=co(r);t[r.name]=s,r.isOptional||n.push(r.name)}return{type:"object",title:e,properties:t,required:n,additionalProperties:!1}}function co(o,e=!1){let t=o.type,n=Vl(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]=co(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=Vl(t.description||o.description,t);r.items={type:Jl(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]=co(a,!0),i.isOptional||r.required.push(s)}}else t?.name==="class"&&t.options?(r.type="string",r.enum=t.options):(r.type=Jl(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 Jl(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 uo(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)');uo(o.items)}else if(o.type==="object"&&o.properties)for(let e of Object.values(o.properties))uo(e)}var un=class extends Error{calls;constructor(e){super(`Stop function executed: ${e.map(t=>t.func.name).join(", ")}`),this.name="AxStopFunctionCallException",this.calls=e}},po=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()}},or=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},_p=(o,e=.1)=>{let t=[...o].sort((r,s)=>r.score-s.score),n=Math.ceil(t.length*e);return t.slice(0,n)};import{context as Ad,SpanKind as yd,trace as bd}from"@opentelemetry/api";var Zn=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}},er=class{memories=new Map;defaultMemory;constructor(){this.defaultMemory=new Zn}getMemory(e){return e?(this.memories.has(e)||this.memories.set(e,new Zn),this.memories.get(e)):this.defaultMemory}addRequest(e,t){for(let n of e)kn(n);this.getMemory(t).addRequest(e,0)}addResponse(e,t){ns(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 Zn):this.defaultMemory.reset()}};function Ct(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 _t=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()}},cn=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 _t({message:s});if(!s)throw r?new _t({message:r}):new Error("Assertion Failed: No message provided for assertion")}}},Hs=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 _t({message:c});if(!c&&a)throw new _t({message:a})}}};var Ru={enabled:!0,enabledCategories:["generation","streaming","functions","errors","performance"],maxLabelLength:100,samplingRate:1},tr,Ks=o=>{if(tr)return tr;let e=o??Ae.meter;if(e)return tr=Lp(e),tr};var Np=()=>{let o=[];return Ae.meter||o.push("Global meter not initialized"),!tr&&Ae.meter&&o.push("Metrics instruments not created despite available meter"),{healthy:o.length===0,issues:o}},Lp=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"})}),to=Ru,$p=o=>{to={...to,...o}},Dp=()=>({...to}),Tt=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n),s=to.maxLabelLength;e[t]=r.length>s?r.substring(0,s):r}return e};var vu=(o,e,t,n,r,s,i)=>{try{let a=Tt({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)}},no=(o,e,t,n,r)=>{try{let s=Tt({...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)}},Ws=(o,e,t,n)=>{try{let r=Tt({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)}},Su=(o,e,t)=>{try{let n=Tt({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)}},Vs=(o,e,t,n,r,s)=>{try{let i=Tt({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)}},ku=(o,e,t,n,r=!1,s,i)=>{try{let a=Tt({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)}},Ou=(o,e,t,n,r)=>{try{let s=Tt({...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)}},Eu=(o,e,t,n,r,s)=>{try{let i=Tt({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)}},Mu=(o,e,t,n,r,s)=>{try{let i=Tt({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)}},Pu=(o,e,t,n,r,s,i)=>{try{let a=Tt({...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)}},ro=(o,e,t,n,r)=>{try{let s=Tt({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 ln=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},Ve=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()}},Fu=o=>{let t=o.map(n=>`'${n.title}' (${ln(n.type)})`).join(", ");return new Ve(`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 ${ln(o[0]?.type)} value. Keep the output concise and avoid unrelated text.`)},oo=o=>new Ve(`Expected (Required) field not found: '${o.title}'. Begin a new section with "${o.title}:" and then provide a valid ${ln(o.type)} value directly after.`);var so=o=>new Ve(`Required field is missing: '${o.title}'. After the "${o.title}:" label, provide a non-empty ${ln(o.type)}. Do not use null, undefined, or leave it blank.`),_u=(o,e)=>new Ve(`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.`),Nu=(o,e)=>new Ve(`Invalid Array: ${e} for '${o.title}'. Provide a JSON array of ${ln(o.type)} items (e.g., [ ... ]). Markdown lists are also accepted if each item is on its own line starting with a hyphen.`),Lu=(o,e,t)=>new Ve(`Field '${o.title}' has an invalid value '${e}': ${t}. Provide a ${ln(o.type)}. Ensure formatting exactly matches the expected type.`),$u=(o,e,t)=>new Ve(`Invalid date for '${o.title}': ${t}. Use the exact format YYYY-MM-DD (e.g., 2024-05-09). You provided: ${e}.`),Du=(o,e,t)=>new Ve(`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}.`),Js=(o,e,t)=>new Ve(`Invalid URL for '${o.title}': ${t}. Use a valid URL format (e.g., https://example.com). You provided: ${e}.`),pn=(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 Ve(r)},Qs=(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 Ve(r)};var Uu=({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(", ")??"";Pa(o,e,c,n)}return r&&Ws(r,"validation",s,a),i&&i.addEvent("validation.error",{message:o.toString(),fixing_instructions:u?.map(c=>c.title).join(", ")??""}),u},Gu=({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(", ")??"";Fa(o,e,c,n)}return r&&Ws(r,"assertion",s,a),i&&i.addEvent("assertion.error",{message:o.toString(),fixing_instructions:u?.map(c=>c.title).join(", ")??""}),u},ju=({error:o,errCount:e,debug:t,logger:n,metricsInstruments:r,signatureName:s,span:i,customLabels:a})=>{t&&n&&_a(o,e,n),r&&Su(r,s,a),i&&i.addEvent("refusal.error",{message:o.toString()})};import Jt from"dayjs";import Up from"dayjs/plugin/customParseFormat.js";import Gp from"dayjs/plugin/timezone.js";import jp from"dayjs/plugin/utc.js";Jt.extend(jp);Jt.extend(Gp);Jt.extend(Up);function Bu(o,e,t=!1){try{return Bp(e)}catch(n){if(o.isOptional&&!t)return;let r=n.message;throw $u(o,e,r)}}function Bp(o){if(!Jt(o,"YYYY-MM-DD",!0).isValid())throw new Error('Invalid date format. Please provide the date in "YYYY-MM-DD" format.');return Jt.utc(o,"YYYY-MM-DD").startOf("day").toDate()}function zu(o,e,t=!1){try{return zp(e)}catch(n){if(o.isOptional&&!t)return;let r=n.message;throw Du(o,e,r)}}function zp(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=Jt.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 qu=o=>Jt(o).utc().format("YYYY-MM-DD HH:mm:ss [UTC]");var Ty=new rt,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 rr(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 Hu=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 Xs(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 Ys=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)}},qp=new Ys(500);function Ku(o,e,t=0,n=qp){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 Gt(o,e){if(typeof o!="string")throw Js(e,String(o),"URL must be a string");try{new URL(o)}catch{throw Js(e,o,"Invalid URL format. Expected a valid URL like https://example.com")}}function gt(o,e){if(typeof o!="string")return;let t=e.type;if(t){if(t.minLength!==void 0&&o.length<t.minLength)throw pn(e,o,"minLength",t.minLength);if(t.maxLength!==void 0&&o.length>t.maxLength)throw pn(e,o,"maxLength",t.maxLength);if(t.pattern!==void 0&&!new RegExp(t.pattern).test(o))throw pn(e,o,"pattern",t.pattern);if(t.format==="email"&&!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(o))throw pn(e,o,"format","valid email address");if(t.format==="uri"||t.format==="url")try{new URL(o)}catch{throw pn(e,o,"format","valid URL")}}}function ft(o,e){if(typeof o!="number")return;let t=e.type;if(t){if(t.minimum!==void 0&&o<t.minimum)throw Qs(e,o,"minimum",t.minimum);if(t.maximum!==void 0&&o>t.maximum)throw Qs(e,o,"maximum",t.maximum)}}var uo=(o,e,t,n)=>{let r=n?.strictMode??!1,s=n?.treatAllFieldsOptional??!1,i=n?.treatAllFieldsOptional??!1,a={extractedFields:[],streamedIndex:{},s:-1};ti(o,e,a,t,{strictMode:r,skipEarlyFail:i,treatAllFieldsOptional:s}),ni(o,e,a,t,{strictMode:r,treatAllFieldsOptional:s,forceFinalize:!0});for(let u of o.getOutputFields())u.isInternal&&delete e[u.name]},Zs=(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 Fu(n)},ti=(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=Ku(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 oo(g)}break}if(a&&p&&a.name!==p.name)throw oo(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=io(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)}},ni=(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=io(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 oo(p)}if(Hp(o,e,n,t),!i){let c=t.currField!==void 0||(t.extractedFields?.length??0)>0;s||u?Zs(t,e,o.getOutputFields()):c||Zs(t,e,o.getOutputFields())}},Hp=(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=io(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=io(i,l);if(p!==void 0){e[i.name]=p;break}}catch(p){if(!i.isOptional)throw p}break}}}},Wu=(o,e,t=!1)=>{switch(o.type?.name){case"code":return ei(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 Bu(o,e,t);case"datetime":return zu(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*Vu(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*ri(o,e,t,n,r){for(let i of n.prevFields??[]){let{field:a,s:u,e:c}=i;yield*Vu(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*Vu(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 io(o,e){if(!e||e===""||/^(null|undefined)\s*$/i.test(e)){if(o.isOptional)return;throw so(o)}let t;if(o.type?.name==="json"&&!o.type?.isArray)try{let r=ei(e);return t=JSON.parse(r),t}catch(r){throw _u(o,r.message)}if(o.type?.isArray)try{try{t=JSON.parse(e)}catch{t=Hu(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 Nu(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=ei(i);i=JSON.parse(a)}catch{}t[r]=Wu(o,i,!0)}}else t=Wu(o,e)}catch(r){throw Lu(o,e,r.message)}if(typeof t=="string"&&t==="")return;let n=o.type;if(n&&t!==void 0&&(n.name==="url"&&Gt(t,o),(n.name==="string"||n.name==="code")&&gt(t,o),n.name==="number"&&ft(t,o),n.isArray&&Array.isArray(t)))for(let r of t)r!==void 0&&(n.name==="string"||n.name==="code"?gt(r,o):n.name==="number"&&ft(r,o));return t}function dn(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 so(r);continue}let i=r.type;if(i){if(i.name==="url"&&Gt(s,r),(i.name==="string"||i.name==="code")&&gt(s,r),i.name==="number"&&ft(s,r),i.isArray&&Array.isArray(s))for(let a of s)a!=null&&(i.name==="url"?Gt(a,r):i.name==="string"||i.name==="code"?gt(a,r):i.name==="number"&&ft(a,r));if(i.name==="object"&&i.fields&&typeof s=="object"&&!Array.isArray(s)&&ao(r,s,t),i.isArray&&i.fields&&Array.isArray(s)&&i.name==="object")for(let a of s)a&&typeof a=="object"&&ao(r,a,t)}}}function ao(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 so(i);continue}let u=i.type;if(u){if(u.name==="url"&&Gt(a,i),(u.name==="string"||u.name==="code")&&gt(a,i),u.name==="number"&&ft(a,i),u.isArray&&Array.isArray(a))for(let c of a)c!=null&&(u.name==="url"?Gt(c,i):u.name==="string"||u.name==="code"?gt(c,i):u.name==="number"&&ft(c,i));if(u.name==="object"&&u.fields&&typeof a=="object"&&!Array.isArray(a)&&ao(i,a,t),u.isArray&&u.fields&&Array.isArray(a)&&u.name==="object")for(let c of a)c&&typeof c=="object"&&ao(i,c,t)}}}var ei=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 or(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});Ju(r.field,t,i,n)}}async function oi(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});Ju(t.currField,n,l,s)}}var Ju=(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 Qu(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 jt(o,e="Schema"){if("name"in o&&"type"in o)return co(o);let t={},n=[];for(let r of o){if(r.isInternal)continue;let s=co(r);t[r.name]=s,r.isOptional||n.push(r.name)}return{type:"object",title:e,properties:t,required:n,additionalProperties:!1}}function co(o,e=!1){let t=o.type,n=Qu(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]=co(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=Qu(t.description||o.description,t);r.items={type:Yu(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]=co(a,!0),i.isOptional||r.required.push(s)}}else t?.name==="class"&&t.options?(r.type="string",r.enum=t.options):(r.type=Yu(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 Yu(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 lo(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)');lo(o.items)}else if(o.type==="object"&&o.properties)for(let e of Object.values(o.properties))lo(e)}var mn=class extends Error{calls;constructor(e){super(`Stop function executed: ${e.map(t=>t.func.name).join(", ")}`),this.name="AxStopFunctionCallException",this.calls=e}},po=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()}},sr=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()}},mo=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??fe.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 po?new or(i.getFields(),s,e.id):i}};execute=async(e,t)=>(await this.executeWithDetails(e,t)).formatted},Qt=(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{uo(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()}},mo=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??Ae.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 po?new sr(i.getFields(),s,e.id):i}};execute=async(e,t)=>(await this.executeWithDetails(e,t)).formatted},Qt=(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{lo(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]},go=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 mo(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??fe.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 or){let S=E.getFixingInstructions(),_={name:v.name,message:E.toString()};return a||(_.args=v.args,_.fixing_instructions=S),R?.addEvent?.("function.error",_),p&&Yo(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 or))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&&Yo(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&&ka(v,u)}if(A.length>0)throw new un(A);return x};function oi(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 Ql(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 zp(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 Yl(o){if(!o.trim())return{parsed:null,partialMarker:null};try{return{parsed:JSON.parse(o),partialMarker:null}}catch{}let e=zp(o),t=qp(o);try{return{parsed:JSON.parse(t),partialMarker:e}}catch{return{parsed:null,partialMarker:e}}}function qp(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*Xl({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*Hp({...s,result:m,skipEarlyFail:i,state:g,debug:n})}}}finally{c.releaseLock()}for(let u of t)yield*Kp({...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*Hp({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)Pr(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}=Yl(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&&Wp(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{cn(a,h,{allowMissingRequired:!0})}catch{}Object.assign(i.values,h),Object.keys(A).length>0&&(yield{index:o.index,delta:A});return}}if(ei(a,i.values,i.xstate,i.content,{strictMode:n,skipEarlyFail:r,treatAllFieldsOptional:s}))return;u.length!==0&&await qs(u,i.xstate,i.content),l.length!==0&&await ri(l,i.content,i.xstate,e,i.values,t),yield*ni(a,i.content,i.values,i.xstate,o.index),await sn(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*Kp({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:oi(t,o.functionCalls,o.values,n);if(v){if(!r)throw new Error("Functions are not defined");let k=await go({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{cn(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;ti(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 go({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 qs(p,o.xstate,o.content,!0),await sn(d,o.values),m.length&&await rr(m,o.values,s,i),g.length!==0&&await ri(g,o.content,o.xstate,s,o.values,i,!0),yield*ni(e,o.content,o.values,o.xstate,o.index)}}async function*Zl({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),lo(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=oi(o,P.functionCalls,F.values);if(N&&N.length>0){if(!s)throw new Error("Functions are not defined");let U;try{U=await go({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]);cn(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)lo(g,F.values,P.content,{strictMode:a,treatAllFieldsOptional:R});else throw G}else lo(g,F.values,P.content,{strictMode:a,treatAllFieldsOptional:R})}if(await sn(p,F.values),T||(t.removeByTag("correction",n),t.removeByTag("error",n)),d.length&&await rr(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 Wp(o,e){return e?!!(e.nestingLevel>0||e.inArray||e.inObject):!1}function ec(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 Vp=["none","minimal","low","medium","high","highest"];function si(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:[...Vp],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=Qt(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 sr=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 pe=class extends Error{constructor(t,n,r,s){super(t);this.position=n;this.context=r;this.suggestion=s;this.name="SignatureValidationError"}},ii=class{input;position;currentFieldName=null;currentSection="description";constructor(e){if(this.input=e.trim(),this.position=0,!this.input)throw new pe("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 pe("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 pe('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 pe(`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 pe)throw e;let t=e instanceof Error?e.message:"Unknown error";throw new pe(t,this.position,this.getErrorContext())}}validateParsedSignature(e){let t=new Set;for(let r of e.inputs){if(t.has(r.name))throw new pe(`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 pe(`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 pe(`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 pe("Signature must have at least one input field",0,"",'Add an input field before "->". Example: "userInput:string -> ..."');if(e.outputs.length===0)throw new pe("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 pe(`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 pe?r:new pe(`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 pe(`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 pe?r:new pe(`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 pe(`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 pe(`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 pe?s:new pe(`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 pe(`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 pe(`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 pe(`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 pe(`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 pe(`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 pe(`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 pe?i:new pe(`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(fe.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 pe(`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 pe(`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 pe(`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 pe(`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 pe(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 pe("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 pe(`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 pe(`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 pe(`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 pe(`Expected "->" but found "${e}..."`,this.position,this.getErrorContext(),t)}}};function tc(o){return new ii(o).parse()}var ho=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,xo(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,xo(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}},Je=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}},de=Object.assign(()=>new ho,{string:o=>new Je({type:"string",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),number:o=>new Je({type:"number",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),boolean:o=>new Je({type:"boolean",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),json:o=>new Je({type:"json",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),datetime:o=>new Je({type:"datetime",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),date:o=>new Je({type:"date",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),class:(o,e)=>new Je({type:"class",isArray:!1,options:o,description:e,isOptional:!1,isInternal:!1,isCached:!1}),image:o=>new Je({type:"image",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),audio:o=>new Je({type:"audio",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),file:o=>new Je({type:"file",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),url:o=>new Je({type:"url",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),email:o=>new Je({type:"string",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1,format:"email"}),code:(o,e)=>new Je({type:"code",isArray:!1,description:e||o,isOptional:!1,isInternal:!1,isCached:!1}),object:(o,e)=>new Je({type:"object",isArray:!1,fields:o,description:e,isOptional:!1,isInternal:!1,isCached:!1})});function xo(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,xo(t)])):void 0}}function fo(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 ai(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,xo(n)])):void 0},description:e.description,isOptional:e.isOptional||void 0,isInternal:e.isInternal||void 0,isCached:e.isCached||void 0}}function nc(o){return o.length===0?{type:"object",properties:{}}:Bt(o,"Schema")}function Jp(o){let e=ai("__value",o);return Bt([e],"Schema").properties?.__value??{type:"json"}}var li=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(ai(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(ai(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:nc(this.argFields),...this.returnMode==="single"&&this.returnFieldType?{returns:Jp(this.returnFieldType)}:this.returnMode==="fields"?{returns:nc(this.returnFields)}:{},...this.fnExamples.length>0?{examples:this.fnExamples.map(s=>({...s}))}:{},func:this.fnHandler}}},Qp=o=>new li(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=tc(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);Et(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);Et(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 Et(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 Et(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,...fo(t)}),n};prependInputField=(e,t)=>{let n=new o(this),r={name:e,...fo(t)},s=n.parseField(r);Et(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,...fo(t)}),n};prependOutputField=(e,t)=>{let n=new o(this),r={name:e,...fo(t)},s=n.parseField(r);Et(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=>{Et(e,"input")}),this.getOutputFields().forEach(e=>{Et(e,"output")}),this.sigHash=ut("sha256").update(JSON.stringify(this.inputFields)).update(JSON.stringify(this.outputFields)).digest("hex"),this.sigString=oc(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=>{Et(e,"input")}),this.getOutputFields().forEach(e=>{Et(e,"output")}),this.validateSignatureConsistency(),this.sigHash=ut("sha256").update(this.description??"").update(JSON.stringify(this.inputFields)).update(JSON.stringify(this.outputFields)).digest("hex"),this.sigString=oc(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 Bt(e,this.description??"Schema")};toInputJSONSchema=()=>Bt(this.inputFields,this.description??"Schema")};function rc(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 oc(o,e,t){let n=o?`"${o}" `:"",r=e.map(rc).join(", "),s=t.map(rc).join(", ");return`${n}${r} -> ${s}`}function Yp(o){let e=/^[a-z][a-zA-Z0-9]*$/,t=/^[a-z]+(_[a-z0-9]+)*$/;return e.test(o)||t.test(o)}function Et(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(!Yp(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(fe.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&&Xp(o,e)}function Xp(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&&ci(t.fields,o.name,e)}function ci(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&&ci(s.fields,i,t,n+1),s.isArray&&s.fields&&ci(s.fields,`${i}[]`,t,n+1)}}var Yt=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 sr,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&&(tr(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 nr(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&&(tr(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 sc={"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]},go=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 mo(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??Ae.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 sr){let S=E.getFixingInstructions(),_={name:v.name,message:E.toString()};return a||(_.args=v.args,_.fixing_instructions=S),R?.addEvent?.("function.error",_),p&&Yo(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 sr))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&&Yo(R,u,E,l),{functionId:v.id,isError:!0,index:u,result:E,role:"function"}})}),C=(await Promise.all(y)).map(v=>v.result===void 0||v.result===""?{...v,result:"done"}:v);if(n.addFunctionResults(C,r),p){let v=C.filter(O=>!O.isError);v.length>0&&Ma(v,l)}if(A.length>0)throw new mn(A);return x};function si(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 Xu(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 Kp(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 Zu(o){if(!o.trim())return{parsed:null,partialMarker:null};try{return{parsed:JSON.parse(o),partialMarker:null}}catch{}let e=Kp(o),t=Wp(o);try{return{parsed:JSON.parse(t),partialMarker:e}}catch{return{parsed:null,partialMarker:e}}}function Wp(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*ec({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*Vp({...s,result:m,skipEarlyFail:i,state:g,debug:n})}}}finally{c.releaseLock()}for(let l of t)yield*Jp({...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*Vp({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)Mr(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}=Zu(i.content);if(f&&typeof f=="object"){let A={},h={};for(let y of Object.keys(f))if(d.some(I=>I.name===y)){let I=f[y],C=i.values[y];if(Array.isArray(I)&&I.length>0&&Qp(I,x)&&(I=I.slice(0,-1)),h[y]=I,typeof I=="string"&&typeof C=="string"&&I.startsWith(C)){let v=I.slice(C.length);v&&(A[y]=v)}else Array.isArray(I)&&Array.isArray(C)?I.length>C.length&&(A[y]=I.slice(C.length)):JSON.stringify(I)!==JSON.stringify(C)&&(Array.isArray(I)||(A[y]=I))}try{dn(a,h,{allowMissingRequired:!0})}catch{}Object.assign(i.values,h),Object.keys(A).length>0&&(yield{index:o.index,delta:A});return}}if(ti(a,i.values,i.xstate,i.content,{strictMode:n,skipEarlyFail:r,treatAllFieldsOptional:s}))return;l.length!==0&&await Hs(l,i.xstate,i.content),u.length!==0&&await oi(u,i.content,i.xstate,e,i.values,t),yield*ri(a,i.content,i.values,i.xstate,o.index),await cn(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*Jp({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:I,abortSignal:C}){let v=x?void 0:si(t,o.functionCalls,o.values,n);if(v){if(!r)throw new Error("Functions are not defined");let O=await go({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:I,abortSignal:C});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{dn(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;ni(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 go({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:I,abortSignal:C});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 Hs(p,o.xstate,o.content,!0),await cn(d,o.values),m.length&&await or(m,o.values,s,i),g.length!==0&&await oi(g,o.content,o.xstate,s,o.values,i,!0),yield*ri(e,o.content,o.values,o.xstate,o.index)}}async function*tc({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:I,stepContext:C,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),uo(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=si(o,M.functionCalls,F.values);if(N&&N.length>0){if(!s)throw new Error("Functions are not defined");let G;try{G=await go({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:C,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]);dn(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)uo(g,F.values,M.content,{strictMode:a,treatAllFieldsOptional:R});else throw W}else uo(g,F.values,M.content,{strictMode:a,treatAllFieldsOptional:R})}if(await cn(p,F.values),I||(t.removeByTag("correction",n),t.removeByTag("error",n)),d.length&&await or(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 Qp(o,e){return e?!!(e.nestingLevel>0||e.inArray||e.inObject):!1}function nc(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 Yp=["none","minimal","low","medium","high","highest"];function ii(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:[...Yp],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=Qt(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 ir=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"}},ai=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 u=a.split(/[,|]/).map(c=>c.trim()).filter(c=>c.length>0);if(u.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:u}}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(Ae.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 rc(o){return new ai(o).parse()}var ho=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,xo(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,xo(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 _e(e);return this._useStructuredOutputs&&(t._forceComplexFields=!0,t._hasComplexFields=void 0),t}},Je=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}},ge=Object.assign(()=>new ho,{string:o=>new Je({type:"string",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),number:o=>new Je({type:"number",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),boolean:o=>new Je({type:"boolean",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),json:o=>new Je({type:"json",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),datetime:o=>new Je({type:"datetime",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),date:o=>new Je({type:"date",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),class:(o,e)=>new Je({type:"class",isArray:!1,options:o,description:e,isOptional:!1,isInternal:!1,isCached:!1}),image:o=>new Je({type:"image",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),audio:o=>new Je({type:"audio",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),file:o=>new Je({type:"file",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),url:o=>new Je({type:"url",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1}),email:o=>new Je({type:"string",isArray:!1,description:o,isOptional:!1,isInternal:!1,isCached:!1,format:"email"}),code:(o,e)=>new Je({type:"code",isArray:!1,description:e||o,isOptional:!1,isInternal:!1,isCached:!1}),object:(o,e)=>new Je({type:"object",isArray:!1,fields:o,description:e,isOptional:!1,isInternal:!1,isCached:!1})});function xo(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,xo(t)])):void 0}}function fo(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 ui(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,xo(n)])):void 0},description:e.description,isOptional:e.isOptional||void 0,isInternal:e.isInternal||void 0,isCached:e.isCached||void 0}}function oc(o){return o.length===0?{type:"object",properties:{}}:jt(o,"Schema")}function Xp(o){let e=ui("__value",o);return jt([e],"Schema").properties?.__value??{type:"json"}}var ci=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(ui(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(ui(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:oc(this.argFields),...this.returnMode==="single"&&this.returnFieldType?{returns:Xp(this.returnFieldType)}:this.returnMode==="fields"?{returns:oc(this.returnFields)}:{},...this.fnExamples.length>0?{examples:this.fnExamples.map(s=>({...s}))}:{},func:this.fnHandler}}},Zp=o=>new ci(o),ie=class extends Error{constructor(t,n,r){super(t);this.fieldName=n;this.suggestion=r;this.name="AxSignatureValidationError"}},_e=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=rc(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);Et(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);Et(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 Et(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 Et(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,...fo(t)}),n};prependInputField=(e,t)=>{let n=new o(this),r={name:e,...fo(t)},s=n.parseField(r);Et(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,...fo(t)}),n};prependOutputField=(e,t)=>{let n=new o(this),r={name:e,...fo(t)},s=n.parseField(r);Et(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=>{Et(e,"input")}),this.getOutputFields().forEach(e=>{Et(e,"output")}),this.sigHash=lt("sha256").update(JSON.stringify(this.inputFields)).update(JSON.stringify(this.outputFields)).digest("hex"),this.sigString=ic(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=>{Et(e,"input")}),this.getOutputFields().forEach(e=>{Et(e,"output")}),this.validateSignatureConsistency(),this.sigHash=lt("sha256").update(this.description??"").update(JSON.stringify(this.inputFields)).update(JSON.stringify(this.outputFields)).digest("hex"),this.sigString=ic(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 jt(e,this.description??"Schema")};toInputJSONSchema=()=>jt(this.inputFields,this.description??"Schema")};function sc(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 ic(o,e,t){let n=o?`"${o}" `:"",r=e.map(sc).join(", "),s=t.map(sc).join(", ");return`${n}${r} -> ${s}`}function ed(o){let e=/^[a-z][a-zA-Z0-9]*$/,t=/^[a-z]+(_[a-z0-9]+)*$/;return e.test(o)||t.test(o)}function Et(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(!ed(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(Ae.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&&td(o,e)}function td(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&&li(t.fields,o.name,e)}function li(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&&li(s.fields,i,t,n+1),s.isArray&&s.fields&&li(s.fields,`${i}[]`,t,n+1)}}var Yt=class o{signature;sigHash;examples;examplesOptions;demos;trace;usage=[];traceLabel;key;children;childNames=new Map;childCount=0;constructor(e,t){this.signature=new _e(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 ir,this.key={id:"root"}}getSignature(){return new _e(this.signature)}setSignature(e){this.signature=new _e(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 rr(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 ac={"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 ui=/{{\s*([^}]+?)\s*}}/g,ic=/^[A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)*$/,lc=/^([A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)*)\s*===\s*(?:'([^']*)'|"([^"]*)")$/,ac=new Map;function Mt(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 Zp(o){let e=[],t=0;ui.lastIndex=0;let n=ui.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=ui.exec(o)}return t<o.length&&e.push({type:"text",value:o.slice(t)}),e}function di(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(!ic.test(c)&&!lc.test(c))throw new Error(Mt(t,e,a.index,`Invalid if condition '${c}'`));let u=di(o,e,t,i+1,new Set(["else","/if"]));if(!u.terminator)throw new Error(Mt(t,e,a.index,"Unclosed 'if' block"));let p=[],d=u.nextIndex+1;if(u.terminator==="else"){let m=di(o,e,t,u.nextIndex+1,new Set(["/if"]));if(m.terminator!=="/if")throw new Error(Mt(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(Mt(t,e,a.index,"Unexpected 'else'"));if(l==="/if")throw new Error(Mt(t,e,a.index,"Unexpected '/if'"));if(l.startsWith("include "))throw new Error(Mt(t,e,a.index,"Unexpected 'include' directive at runtime (includes must be compiled)"));if(!ic.test(l))throw new Error(Mt(t,e,a.index,`Invalid tag '${l}'`));s.push({type:"var",name:l,index:a.index}),i++}return{nodes:s,nextIndex:i}}function pi(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(Mt(n,t,r,`Missing template variable '${e}'`));i=i[a]}return i}function mi(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=pi(e,s.name,t,n,s.index);if(typeof l!="string"&&typeof l!="number"&&typeof l!="boolean")throw new Error(Mt(n,t,s.index,`Variable '${s.name}' must be string, number, or boolean`));r+=String(l);continue}let i,a=lc.exec(s.condition);if(a){let[,l,c,u]=a,p=c??u??"";i=pi(e,l,t,n,s.index)===p}else{let l=pi(e,s.condition,t,n,s.index);if(typeof l!="boolean")throw new Error(Mt(n,t,s.index,`Condition '${s.condition}' must be boolean`));i=l}i?r+=mi(s.thenNodes,e,t,n):r+=mi(s.elseNodes,e,t,n)}return r}function ed(o,e){let t=Zp(o),n=di(t,o,e);if(n.terminator)throw new Error(`Unexpected template terminator '${n.terminator}' in ${e}`);return n.nodes}function ht(o,e={}){let t=sc[o],n=`template:${o}`;if(!t)throw new Error(`Unknown template id: ${String(o)}`);let r=ac.get(o);return r||(r=ed(t,n),ac.set(o,r)),mi(r,e,t,n)}var cc=ht("dsp/function-call-instructions.md"),td=ht("dsp/strict-output-formatting-rules.md"),nd=ht("dsp/example-disclaimer.md"),pn=ht("dsp/example-separator.md"),mn=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,fe.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=Ao(this.sig.getInputFields()),r=Ao(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}\`: ${dn(u.description)}`).join(`
714
+ `};var pi=/{{\s*([^}]+?)\s*}}/g,uc=/^[A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)*$/,lc=/^([A-Za-z_][A-Za-z0-9_]*(?:\.[A-Za-z_][A-Za-z0-9_]*)*)\s*===\s*(?:'([^']*)'|"([^"]*)")$/,cc=new Map;function Mt(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 nd(o){let e=[],t=0;pi.lastIndex=0;let n=pi.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=pi.exec(o)}return t<o.length&&e.push({type:"text",value:o.slice(t)}),e}function mi(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(!uc.test(c)&&!lc.test(c))throw new Error(Mt(t,e,a.index,`Invalid if condition '${c}'`));let l=mi(o,e,t,i+1,new Set(["else","/if"]));if(!l.terminator)throw new Error(Mt(t,e,a.index,"Unclosed 'if' block"));let p=[],d=l.nextIndex+1;if(l.terminator==="else"){let m=mi(o,e,t,l.nextIndex+1,new Set(["/if"]));if(m.terminator!=="/if")throw new Error(Mt(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(Mt(t,e,a.index,"Unexpected 'else'"));if(u==="/if")throw new Error(Mt(t,e,a.index,"Unexpected '/if'"));if(u.startsWith("include "))throw new Error(Mt(t,e,a.index,"Unexpected 'include' directive at runtime (includes must be compiled)"));if(!uc.test(u))throw new Error(Mt(t,e,a.index,`Invalid tag '${u}'`));s.push({type:"var",name:u,index:a.index}),i++}return{nodes:s,nextIndex:i}}function di(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(Mt(n,t,r,`Missing template variable '${e}'`));i=i[a]}return i}function gi(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=di(e,s.name,t,n,s.index);if(typeof u!="string"&&typeof u!="number"&&typeof u!="boolean")throw new Error(Mt(n,t,s.index,`Variable '${s.name}' must be string, number, or boolean`));r+=String(u);continue}let i,a=lc.exec(s.condition);if(a){let[,u,c,l]=a,p=c??l??"";i=di(e,u,t,n,s.index)===p}else{let u=di(e,s.condition,t,n,s.index);if(typeof u!="boolean")throw new Error(Mt(n,t,s.index,`Condition '${s.condition}' must be boolean`));i=u}i?r+=gi(s.thenNodes,e,t,n):r+=gi(s.elseNodes,e,t,n)}return r}function rd(o,e){let t=nd(o),n=mi(t,o,e);if(n.terminator)throw new Error(`Unexpected template terminator '${n.terminator}' in ${e}`);return n.nodes}function ht(o,e={}){let t=ac[o],n=`template:${o}`;if(!t)throw new Error(`Unknown template id: ${String(o)}`);let r=cc.get(o);return r||(r=rd(t,n),cc.set(o,r)),gi(r,e,t,n)}var pc=ht("dsp/function-call-instructions.md"),od=ht("dsp/strict-output-formatting-rules.md"),sd=ht("dsp/example-disclaimer.md"),gn=ht("dsp/example-separator.md"),Zt=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,Ae.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=Ao(this.sig.getInputFields()),r=Ao(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}\`: ${fn(l.description)}`).join(`
716
716
  `);i&&i.length>0&&e.push(`## Available Functions
717
- ${i}`);let a=this.getFieldNameToTitleMap(),l=uc(this.sig.getInputFields(),a);if(e.push(`## Input Fields
718
- ${l}`),!t){let u=pc(this.sig.getOutputFields(),a);e.push(`## Output Fields
719
- ${u}`)}i&&i.length>0&&e.push(cc.trim()),t&&this.structuredOutputFunctionName?e.push(ht("dsp/legacy-formatting-rules-structured-function.md",{structuredOutputFunctionName:this.structuredOutputFunctionName}).trim()):t||e.push(td.trim());let c=this.sig.getDescription();if(c){let u=dn(c);u=yo(u,a),e.push(u)}return{type:"text",text:e.join(`
717
+ ${i}`);let a=this.getFieldNameToTitleMap(),u=dc(this.sig.getInputFields(),a);if(e.push(`## Input Fields
718
+ ${u}`),!t){let l=mc(this.sig.getOutputFields(),a);e.push(`## Output Fields
719
+ ${l}`)}i&&i.length>0&&e.push(pc.trim()),t&&this.structuredOutputFunctionName?e.push(ht("dsp/legacy-formatting-rules-structured-function.md",{structuredOutputFunctionName:this.structuredOutputFunctionName}).trim()):t||e.push(od.trim());let c=this.sig.getDescription();if(c){let l=fn(c);l=yo(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(cc.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=Ao(this.sig.getInputFields()),t=Ao(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=dn(e);return n=yo(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}\`: ${dn(r.description??"")}`).join(`
727
+ `)}}buildIdentitySection(){let e=Ao(this.sig.getInputFields()),t=Ao(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=fn(e);return n=yo(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}\`: ${fn(r.description??"")}`).join(`
729
729
  `);return t.push(n),t.push(`
730
- ${cc.trim()}`),t.join(`
730
+ ${pc.trim()}`),t.join(`
731
731
  `)}buildInputFieldsSection(){let e=this.getFieldNameToTitleMap();return`**Input Fields**: The following fields will be provided to you:
732
732
 
733
- ${uc(this.sig.getInputFields(),e)}`}buildOutputFieldsSection(){let e=this.getFieldNameToTitleMap();return`**Output Fields**: You must generate the following fields:
733
+ ${dc(this.sig.getInputFields(),e)}`}buildOutputFieldsSection(){let e=this.getFieldNameToTitleMap();return`**Output Fields**: You must generate the following fields:
734
734
 
735
- ${pc(this.sig.getOutputFields(),e)}`}buildFormattingRulesSection(){let e=this.sig.hasComplexFields();return e&&this.structuredOutputFunctionName?ht("dsp/formatting-rules-structured-function.md",{structuredOutputFunctionName:this.structuredOutputFunctionName}).trim():e?ht("dsp/formatting-rules-structured-json.md").trim():ht("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(`
735
+ ${mc(this.sig.getOutputFields(),e)}`}buildFormattingRulesSection(){let e=this.sig.hasComplexFields();return e&&this.structuredOutputFunctionName?ht("dsp/formatting-rules-structured-function.md",{structuredOutputFunctionName:this.structuredOutputFunctionName}).trim():e?ht("dsp/formatting-rules-structured-json.md").trim():ht("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
736
  `):a.reduce(Xt(`
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(Xt(""),[]),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
- ${nd}`: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(`
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(Xt(""),[]),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
+ ${sd}`:this.task.text,cache:!!this.contextCache},a=t?this.renderExamplesAsMessages(t):[],u=n?this.renderDemosAsMessages(n):[],c=[];for(let C of[...a,...u])c.push(C.userMessage),c.push(C.assistantMessage),C.functionResultMessage&&c.push(C.functionResultMessage);let l=this.contextCache?.cacheBreakpoint??"after-examples",p=this.ignoreBreakpoints||l==="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,O=!0;for(let R of v){let E=this.renderInputFields(R.values),S=E.every(_=>_.type==="text")?E.map(_=>_.text).join(`
742
742
  `):E.reduce(Xt(`
743
- `),[]);if(R.role==="user"){k&&r&&(typeof S=="string"?S=pn+S:S=[{type:"text",text:pn},...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}
743
+ `),[]);if(R.role==="user"){O&&r&&(typeof S=="string"?S=gn+S:S=[{type:"text",text:gn},...S],O=!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||l!=="system"&&l!=="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
744
  `});let v=C.every(E=>E.type==="text")?C.map(E=>E.text).join(`
745
745
  `):C.reduce(Xt(`
746
- `),[]);r&&(typeof v=="string"?v=pn+v:v=[{type:"text",text:pn},...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(Xt(`
746
+ `),[]);r&&(typeof v=="string"?v=gn+v:v=[{type:"text",text:gn},...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(Xt(`
749
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(`
750
+ `});let y=h.every(C=>C.type==="text")?h.map(C=>C.text).join(`
751
751
  `):h.reduce(Xt(`
752
- `),[]);r&&(typeof b=="string"?b=pn+b:b=[{type:"text",text:pn},...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
752
+ `),[]);r&&(typeof y=="string"?y=gn+y:y=[{type:"text",text:gn},...y]);let I=f&&g.length===0&&this.contextCache;return[i,...c,{role:"user",content:y,...I?{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(`
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
769
  `):a.reduce(Xt(`
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&&tr(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(`
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(ud(e,r,n))return;e.type&&nr(e,r);let s=id(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("")}]}},Ao=o=>o.map(e=>`\`${e.title}\``).join(", "),uc=(o,e)=>o.map(n=>{let r=n.title,s=n.type?.name?gn(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=dn(n.description);e&&(l=yo(l,e)),a=` ${l}`}return`${r}: (${i})${a}`.trim()}).join(`
775
- `),pc=(o,e)=>o.map(n=>{let r=n.title,s=n.type?.name?gn(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:dn(n.description);e&&(l=yo(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?jl(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 od(o){return`{ ${Object.entries(o).map(([t,n])=>{let r=n.isOptional?"?":"",s=gn({name:n.type,isArray:n.isArray,fields:n.fields,options:n.options});return`${t}${r}: ${s}`}).join(", ")} }`}var gn=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 ${od(o.fields)}`:"object";default:return"string"}})();return o?.isArray?`json array of ${e} items`:e};function Xt(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 dn(o){let e=o.trim();return e.length>0?`${e.charAt(0).toUpperCase()}${e.slice(1)}${e.endsWith(".")?"":"."}`:""}function yo(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 id(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 ad(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 bo(o,e,t,n){if(!e?.resultPicker||o.length<=1)return 0;let r=e.resultPicker;if((t?id(t,n):!1)&&t){let l=ad(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 dc(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 bo(r,t,o,e)}var ir=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 To=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}=ld(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 Ve(`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 ld(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=cd(u);e.push({name:pd(d),title:ud(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 cd(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 ud(o,e){return`${o} ${e.replace(/\./g," ")}`}function pd(o){return o.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}function fc(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=gi(s.name),l=gc(s.parameters);n.getOutputFields().some(u=>u.name===a)||n.addOutputField({name:a,title:mc(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}=dd(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=gi(s.name),a=gc(s.parameters);n.getOutputFields().some(c=>c.name===i)||n.addOutputField({name:i,title:mc(s.name),type:a,description:s.description||`Parameters for ${s.name}`,isOptional:!0})}return{signature:n,toolParamFieldMap:r}}}function dd(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),g={name:gi(d),title:gd(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 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 gd(o,e){return`${o} ${e.replace(/\./g," ")}`}function gi(o){return o.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}function mc(o){return o.replace(/([A-Z])/g," $1").replace(/^./,e=>e.toUpperCase()).trim()}function gc(o){return!o||!o.properties||Object.keys(o.properties).length===0?{name:"string",isArray:!1}:{name:"json",isArray:!1}}var ar=class{tools;router;injectedToolFieldNames=new Set;constructor(e){this.tools=e,this.router=new To(e)}processSignature(e){let{signature:t}=fc(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 fn="__finalResult",Me=class o extends Yt{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??mn)(this.signature,n),this.asserts=this.options?.asserts??[],this.streamingAsserts=this.options?.streamingAsserts??[],this.excludeContentFromTrace=t?.excludeContentFromTrace??!1,this.functions=t?.functions?Qt(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 Hs()}getMergedCustomLabels(e,t){return Kt(fe.customLabels,e?.getOptions?.()?.customLabels,t?.customLabels)}updateMeter(e){Hs(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 dc(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:Bt(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??fe.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}=Ql(p,m,h,n);this.structuredOutputFunctionFallback&&C.filter(E=>E.name!==fn).length===0&&(v={type:"function",function:{name:fn}});let k=await this.forwardSendRequest({ai:e,mem:t,options:n,traceContext:i,functions:C,functionCall:v,stepIndex:r});k instanceof ReadableStream?yield*Xl({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*Zl({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 Zn,d=r.functions?Qt(r.functions):[...this.functions],m=new ir(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=si(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 ar(d)),A&&h==="auto"&&!e.getFeatures(r.model).functions&&(this.signatureToolCallingManager=new ar(d));let b,T,C=this.options?.promptTemplate??mn;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:fn,description:"Return the final result. Call this function with the complete output data.",parameters:Bt(this.signature.getOutputFields()),func:async()=>"done"};d.push(V),l=[...l??[],fn.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?fn:void 0};this.promptTemplate=new C(this.signature,S);let _,L=performance.now();Array.isArray(t)?(tl(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&&ro(F,"prompt_render",P,this.getSignatureName(),N);let U=performance.now();p.addRequest(_,r.sessionId);let G=performance.now()-U;F&&ro(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 $=Qt(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??fe.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]=si(e,g,$)}}if(m._isStopRequested)break;if(j?.aborted)throw new Fe("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 ue=new Map;n.forEach(X=>{ue.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 Pe=se.index,ae=se.delta,Ae=ue.get(Pe)??{},be=B.get(Pe)??{},oe={},me=!1;for(let Ie of Object.keys(ae)){let Be=ae[Ie],$e=Ae[Ie],ot;typeof Be=="string"&&(typeof $e=="string"||$e===void 0)?ot=($e??"")+Be:Array.isArray(Be)&&(Array.isArray($e)||$e===void 0)?ot=[...$e??[],...Be]:ot=Be,Ae[Ie]=ot;let Se=ot,ze=be[Ie];if(typeof Se=="string"&&typeof ze=="string")if(Se.startsWith(ze)){let le=Se.slice(ze.length);le&&(oe[Ie]=le,me=!0,be[Ie]=Se)}else ze.startsWith(Se)||Se!==ze&&(oe[Ie]=Se,me=!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,me=!0,be[Ie]=Se}}else JSON.stringify(Se)!==JSON.stringify(ze)&&(oe[Ie]=Se,me=!0,be[Ie]=Se)}me&&(yield{version:ne,index:se.index,delta:oe})}}catch(se){if(se instanceof un){if(z=!0,this.structuredOutputFunctionFallback){let Pe=se.calls.find(ae=>ae.func.name===fn);if(Pe?.args){let ae=Pe.args;cn(this.signature,ae);let Ae=this.signature.getOutputFields();for(let be of n){let oe={};for(let me of Ae)me.name in ae&&!me.isInternal&&(oe[me.name]=ae[me.name],be.values[me.name]=ae[me.name]);yield{version:ne,index:be.index,delta:oe}}for(let be of n)await sn(this.asserts,be.values);if(this.fieldProcessors.length>0)for(let be of n)await rr(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 ke=z||m._isStopRequested?!1:ec(p,l,n,f?.sessionId);if(x?.afterStep&&(await x.afterStep(m),te()),ke&&!m._isStopRequested&&!j?.aborted){let se=this.getMetricsInstruments();se&&no(se,V+1,u,this.getSignatureName(),N);continue e}if(j?.aborted)throw new Fe("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){no(Oe,V+1,u,this.getSignatureName(),N);let se=new Set;n.forEach(Pe=>{Pe.functionsExecuted.forEach(ae=>se.add(ae))}),se.size>0&&vl(Oe,!0,se.size,!0,!1,this.getSignatureName(),N),Sl(Oe,this.fieldProcessors.length,this.streamingFieldProcessors.length,this.getSignatureName(),N)}return}catch(X){if(X instanceof Fe)throw X;T=X;let z,ie=this.isDebug(e,r),ke=this.getLogger(e,r),Oe=this.getMetricsInstruments(),se=this.getSignatureName(),Pe={error:X,errCount:ne,logger:ke,metricsInstruments:Oe,signatureName:se,span:s,debug:ie,customLabels:N};if(s?.recordException(X),X instanceof Ve)z=$l(Pe),b=X;else if(X instanceof Nt)z=Dl(Pe),b=X;else if(X instanceof Le)Ul(Pe);else{if(X instanceof At)throw X;{let ae=X,Ae=ae instanceof it&&ae.status>=500&&ae.status<600,be=ae instanceof Ze,oe=ae instanceof mt;throw Ae||be||oe?X:fi(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&&Ws(K,c,!1,c,this.getSignatureName(),N),fi(new Error(`Unable to fix validation error: ${(b??T)?.message??(b??T)?.toString()??"unknown error"}
774
+ `))):n.push(t),[{type:"text",text:n.join("")}]}},Ao=o=>o.map(e=>`\`${e.title}\``).join(", "),dc=(o,e)=>o.map(n=>{let r=n.title,s=n.type?.name?hn(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=fn(n.description);e&&(u=yo(u,e)),a=` ${u}`}return`${r}: (${i})${a}`.trim()}).join(`
775
+ `),mc=(o,e)=>o.map(n=>{let r=n.title,s=n.type?.name?hn(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:fn(n.description);e&&(u=yo(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
+ `),id=(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?qu(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 ad(o){return`{ ${Object.entries(o).map(([t,n])=>{let r=n.isOptional?"?":"",s=hn({name:n.type,isArray:n.isArray,fields:n.fields,options:n.options});return`${t}${r}: ${s}`}).join(", ")} }`}var hn=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 ${ad(o.fields)}`:"object";default:return"string"}})();return o?.isArray?`json array of ${e} items`:e};function Xt(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 ud=(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 fn(o){let e=o.trim();return e.length>0?`${e.charAt(0).toUpperCase()}${e.slice(1)}${e.endsWith(".")?"":"."}`:""}function yo(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 cd(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 ld(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 bo(o,e,t,n){if(!e?.resultPicker||o.length<=1)return 0;let r=e.resultPicker;if((t?cd(t,n):!1)&&t){let u=ld(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 fi(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 bo(r,t,o,e)}var ar=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 Io=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}=pd(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 Ve(`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 pd(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=dd(l);e.push({name:gd(d),title:md(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 dd(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 md(o,e){return`${o} ${e.replace(/\./g," ")}`}function gd(o){return o.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}function hc(o,e,t){let n=new _e(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=hi(s.name),u=fc(s.parameters);n.getOutputFields().some(l=>l.name===a)||n.addOutputField({name:a,title:gc(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}=fd(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=hi(s.name),a=fc(s.parameters);n.getOutputFields().some(c=>c.name===i)||n.addOutputField({name:i,title:gc(s.name),type:a,description:s.description||`Parameters for ${s.name}`,isOptional:!0})}return{signature:n,toolParamFieldMap:r}}}function fd(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=hd(l),g={name:hi(d),title:xd(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 hd(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 xd(o,e){return`${o} ${e.replace(/\./g," ")}`}function hi(o){return o.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_|_$/g,"").replace(/[^a-z0-9_]/g,"_")}function gc(o){return o.replace(/([A-Z])/g," $1").replace(/^./,e=>e.toUpperCase()).trim()}function fc(o){return!o||!o.properties||Object.keys(o.properties).length===0?{name:"string",isArray:!1}:{name:"json",isArray:!1}}var en=class{tools;router;injectedToolFieldNames=new Set;constructor(e){this.tools=e,this.router=new Io(e)}processSignature(e){let{signature:t}=hc(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 tn="__finalResult",Pe=class o extends Yt{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??Zt)(this.signature,n),this.asserts=this.options?.asserts??[],this.streamingAsserts=this.options?.streamingAsserts??[],this.excludeContentFromTrace=t?.excludeContentFromTrace??!1,this.functions=t?.functions?Qt(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??Zt,s=[...this.functions],i=n?.functionCallMode??this.options?.functionCallMode??"auto",a=s.length>0,u;a&&i==="prompt"&&(u=new en(s)),a&&i==="auto"&&!e.getFeatures(n?.model).functions&&(u=new en(s));let c=new _e(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?tn:void 0}),x=this.getInstruction();x!==void 0&&f.setInstruction(x),Array.isArray(t)&&os(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 fi(h,n?.sessionId,{resultPicker:n?.resultPicker});return[...h.history(y,n?.sessionId),...A]}async _measurePromptCharsForInternalUse(e,t,n){return _r(await this.renderPromptForInternalUse(e,t,n))}getSignatureName(){return this.signature.getDescription()||"unknown_signature"}getMetricsInstruments(){return Ks()}getMergedCustomLabels(e,t){return Kt(Ae.customLabels,e?.getOptions?.()?.customLabels,t?.customLabels)}updateMeter(e){Ks(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 fi(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 I,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).`);I={type:"json_schema",schema:{name:"output",strict:!0,schema:jt(C)}}}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:I},{sessionId:u,rateLimiter:l,stream:p,debug:A,debugHideSystemPrompt:n?.debugHideSystemPrompt??this.options?.debugHideSystemPrompt??!h,thinkingTokenBudget:d,showThoughts:m,traceContext:r,abortSignal:n?.abortSignal??Ae.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),I=this.getLogger(e,n),{functions:C,functionCall:v}=Xu(p,m,h,n);this.structuredOutputFunctionFallback&&C.filter(E=>E.name!==tn).length===0&&(v={type:"function",function:{name:tn}});let O=await this.forwardSendRequest({ai:e,mem:t,options:n,traceContext:i,functions:C,functionCall:v,stepIndex:r});O instanceof ReadableStream?yield*ec({ai:e,model:x,res:O,mem:t,sessionId:l,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:I,debug:y,functionResultFormatter:d,signatureToolCallingManager:g,stopFunctionNames:u,disableMemoryCleanup:n.disableMemoryCleanup,stepContext:c,abortSignal:n.abortSignal}):yield*tc({ai:e,model:x,res:O,mem:t,sessionId:l,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:I,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 er,d=r.functions?Qt(r.functions):[...this.functions],m=new ar(l),g;if(r.selfTuning){if(g=r.selfTuning===!0?{model:!0,thinkingBudget:!0}:r.selfTuning,g.model!==!1){let Ie=e.getModelList()?.filter(L=>"model"in L);if(!Ie||Ie.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=ii(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 en(d)),A&&h==="auto"&&!e.getFeatures(r.model).functions&&(this.signatureToolCallingManager=new en(d));let y,I,C=this.options?.promptTemplate??Zt;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:tn,description:"Return the final result. Call this function with the complete output data.",parameters:jt(this.signature.getOutputFields()),func:async()=>"done"};d.push(re),u=[...u??[],tn.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?tn:void 0};this.promptTemplate=new C(this.signature,S);let _,$=performance.now();Array.isArray(t)?(os(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&&ro(F,"prompt_render",M,this.getSignatureName(),N);let G=performance.now();p.addRequest(_,r.sessionId);let W=performance.now()-G;F&&ro(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=Qt(oe);for(let K of L)d.some(ee=>ee.name===K.name)||d.push(K)}let Ie=m._consumeFunctionsToRemove();if(Ie){let L=new Set(Ie.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??Ae.abortSignal;e:for(let re=0;re<l;re++){if(m._beginStep(re),ae(),g&&g.model!==!1){let Ie=d.findIndex(L=>L.name==="adjustGeneration");if(Ie!==-1){let L=f.model?String(f.model):void 0;d[Ie]=ii(e,g,L)}}if(m._isStopRequested)break;if(j?.aborted)throw new Fe("between-steps",j.reason??"Aborted between steps");if(x?.beforeStep&&(await x.beforeStep(m),ae(),m._isStopRequested))break;let oe=c;for(let Ie=0;Ie<=oe;Ie++)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 fe=new Map;n.forEach(q=>{fe.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=fe.get(Re)??{},J=U.get(Re)??{},X={},he=!1;for(let we of Object.keys(se)){let je=se[we],$e=de[we],ot;typeof je=="string"&&(typeof $e=="string"||$e===void 0)?ot=($e??"")+je:Array.isArray(je)&&(Array.isArray($e)||$e===void 0)?ot=[...$e??[],...je]:ot=je,de[we]=ot;let Ee=ot,ze=J[we];if(typeof Ee=="string"&&typeof ze=="string")if(Ee.startsWith(ze)){let le=Ee.slice(ze.length);le&&(X[we]=le,he=!0,J[we]=Ee)}else ze.startsWith(Ee)||Ee!==ze&&(X[we]=Ee,he=!0,J[we]=Ee);else if(Array.isArray(Ee)&&Array.isArray(ze)){if(Ee.length>ze.length){let le=Ee.slice(ze.length);X[we]=le,he=!0,J[we]=Ee}}else JSON.stringify(Ee)!==JSON.stringify(ze)&&(X[we]=Ee,he=!0,J[we]=Ee)}he&&(yield{version:ee,index:ce.index,delta:X})}}catch(ce){if(ce instanceof mn){if(B=!0,this.structuredOutputFunctionFallback){let Re=ce.calls.find(se=>se.func.name===tn);if(Re?.args){let se=Re.args;dn(this.signature,se);let de=this.signature.getOutputFields();for(let J of n){let X={};for(let he of de)he.name in se&&!he.isInternal&&(X[he.name]=se[he.name],J.values[he.name]=se[he.name]);yield{version:ee,index:J.index,delta:X}}for(let J of n)await cn(this.asserts,J.values);if(this.fieldProcessors.length>0)for(let J of n)await or(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:nc(p,u,n,f?.sessionId);if(x?.afterStep&&(await x.afterStep(m),ae()),ke&&!m._isStopRequested&&!j?.aborted){let ce=this.getMetricsInstruments();ce&&no(ce,re+1,l,this.getSignatureName(),N);continue e}if(j?.aborted)throw new Fe("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){no(Oe,re+1,l,this.getSignatureName(),N);let ce=new Set;n.forEach(Re=>{Re.functionsExecuted.forEach(se=>ce.add(se))}),ce.size>0&&ku(Oe,!0,ce.size,!0,!1,this.getSignatureName(),N),Ou(Oe,this.fieldProcessors.length,this.streamingFieldProcessors.length,this.getSignatureName(),N)}return}catch(q){if(q instanceof Fe)throw q;I=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 Ve)B=Uu(Re),y=q;else if(q instanceof _t)B=Gu(Re),y=q;else if(q instanceof Le)ju(Re);else{if(q instanceof At)throw q;{let se=q,de=se instanceof it&&se.status>=500&&se.status<600,J=se instanceof Ze,X=se instanceof mt;throw de||J||X?q:xi(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&&Vs(K,c,!1,c,this.getSignatureName(),N),xi(new Error(`Unable to fix validation error: ${(y??I)?.message??(y??I)?.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 it&&K.status>=500&&K.status<600,ue=K instanceof Ze,X=K instanceof mt,z=K instanceof At;if((ne||ue||X||z)&&ve<xe){let ke=this.isDebug(e,r),Oe=this.getLogger(e,r),ae=Math.min(6e4,1e3*Math.pow(2,ve));ke&&Oe&&Oe({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 it?"status_error":K instanceof Ze?"network_error":K instanceof mt?"timeout_error":"stream_terminated",errorMessage:K.message}),await new Promise((Ae,be)=>{let oe=!1,me,Ie=()=>{j&&me&&j.removeEventListener("abort",me)},$e=setTimeout(()=>{oe||(oe=!0,Ie(),Ae())},ae);if(j){if(me=()=>{oe||(oe=!0,clearTimeout($e),Ie(),be(new Fe("infrastructure-retry-backoff",j.reason?String(j.reason):"Aborted during retry backoff")))},j.aborted){me();return}j.addEventListener("abort",me,{once:!0})}});continue}throw $}}throw F&&no(F,u,u,this.getSignatureName(),N),fi(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"&&Gt(r,n),s.name,s.name,(s.name==="string"||s.name==="code")&&gt(r,n),s.name==="number"&&ft(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"?gt(a,n):s.name==="number"?ft(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"?gt(i,a):s.type==="number"?ft(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"?gt(c,a):s.type==="number"?ft(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=Ct(r.signal,n?.abortSignal??fe.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&&ro(u,"state_creation",c,this.getSignatureName(),p);let d=n?.tracer??this.options?.tracer??e.getOptions().tracer,m=this.functions;if(n?.functions&&(m=Qt(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:hd.SERVER,attributes:f}),b=fd.active(),T=xd.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??fe.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&&El(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=Ys(f,R),A++;u=x;let h=performance.now();p=!!n?.resultPicker;let b=await bo(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);_a(f.length,b,T,R)}if(c=!0,d&&(Ol(d,f.length,p,p?T:void 0,a,m),kl(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&&(wl(m,d,c,a,e.getName(),n?.model?String(n.model):void 0,g),u>0&&Ws(m,u,c,n?.maxRetries??this.options?.maxRetries??3,a,g))}}async*streamingForward(e,t,n){let r=n?.cachingFunction??this.options?.cachingFunction??fe.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=Ys(a,p);let c=await bo(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??fe.debug??e.getOptions().debug??!1}getLogger(e,t){return t?.logger??this.options?.logger??fe.logger??e.getLogger()}computeCacheKey(e,t){let n=ut("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=ut("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")}},Co=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 fi(o,e,t){let n=o instanceof Error?o:new Error(String(o));if(n instanceof Fe)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 Co(`Generate failed: ${n.message}`,l,{cause:n})}var Ad=o=>o.replace(/^\W+|\W+$/g,""),yd=(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]},bd=o=>{let e=new Set,t=[];for(let n of o)e.has(n)||(e.add(n),t.push(n));return t},Td=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}},Cd=o=>{let e=o.match(/^(\d+)[.,\s]+(.*)$/);return e&&e[2]!==void 0?e[2].trim():o},Id=(o,e)=>{let t=[];for(let n=0;n<o.length;n+=e)t.push(o.slice(n,n+e));return t},hi={trimNonAlphaNum:Ad,splitIntoTwo:yd,dedup:bd,extractIdAndText:Td,extractIndexPrefixedText:Cd,batchArray:Id};var xi=class extends Me{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}=hi.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 Ai=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 rt,yi=class{name;context;constructor(e,t){this.name=e,this.context=t}getName(){return this.name}getContext(){return this.context}},bi=class{ai;db;debug;constructor(e){this.db=new Vt,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 hc=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 xc(o,e){return o.filter(t=>!e.has(t))}function Ac(o){let e={};for(let t of o)e[t]=(e[t]||0)+1;return e}function Zt(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 wd(o,e){return Zt(o)===Zt(e)?1:0}function Rd(o,e){let t=Zt(o).split(" "),n=Zt(e).split(" "),r=Ac(t),s=Ac(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 vd(o,e,t,n=!1){let r=Zt(o).split(" "),s=Zt(e).split(" "),i=Zt(t).split(" "),a=new Set([...hc,...r]);s=xc(s,a),i=xc(i,a);let l=0,c=l/s.length,u=l/i.length,p=2*c*u/(c+u);return n?u:p}var Sd={emScore:wd,f1Score:Rd,novelF1ScoreOptimized:vd};var Ti=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 it&&K.status>=500&&K.status<600,fe=K instanceof Ze,q=K instanceof mt,B=K instanceof At;if((ee||fe||q||B)&&Ie<oe){let ke=this.isDebug(e,r),Oe=this.getLogger(e,r),se=Math.min(6e4,1e3*Math.pow(2,Ie));ke&&Oe&&Oe({name:"Notification",id:"infrastructure-retry",value:`Infrastructure error (attempt ${Ie+1}/${oe+1}): ${K.message}. Retrying in ${se}ms...`}),s?.addEvent("infrastructure.retry",{attempt:Ie+1,maxRetries:oe,delay:se,errorType:K instanceof it?"status_error":K instanceof Ze?"network_error":K instanceof mt?"timeout_error":"stream_terminated",errorMessage:K.message}),await new Promise((de,J)=>{let X=!1,he,we=()=>{j&&he&&j.removeEventListener("abort",he)},$e=setTimeout(()=>{X||(X=!0,we(),de())},se);if(j){if(he=()=>{X||(X=!0,clearTimeout($e),we(),J(new Fe("infrastructure-retry-backoff",j.reason?String(j.reason):"Aborted during retry backoff")))},j.aborted){he();return}j.addEventListener("abort",he,{once:!0})}});continue}throw L}}throw F&&no(F,l,l,this.getSignatureName(),N),xi(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"&&Gt(r,n),s.name,s.name,(s.name==="string"||s.name==="code")&&gt(r,n),s.name==="number"&&ft(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"?gt(a,n):s.name==="number"?ft(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"?gt(i,a):s.type==="number"?ft(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"?gt(c,a):s.type==="number"?ft(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=Ct(r.signal,n?.abortSignal??Ae.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&&ro(l,"state_creation",c,this.getSignatureName(),p);let d=n?.tracer??this.options?.tracer??e.getOptions().tracer,m=this.functions;if(n?.functions&&(m=Qt(n.functions,this.functions)),!d){yield*this._forward2(e,t,u,{...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:yd.SERVER,attributes:f}),y=Ad.active(),I=bd.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,I),!this.excludeContentFromTrace){let C=u.map(O=>O.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??Ae.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&&Pu(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=Xs(f,R),A++;l=x;let h=performance.now();p=!!n?.resultPicker;let y=await bo(f,{resultPicker:n?.resultPicker},n?.mem,n?.sessionId),I=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);$a(f.length,y,I,R)}if(c=!0,d&&(Mu(d,f.length,p,p?I:void 0,a,m),Eu(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&&(vu(m,d,c,a,e.getName(),n?.model?String(n.model):void 0,g),l>0&&Vs(m,l,c,n?.maxRetries??this.options?.maxRetries??3,a,g))}}async*streamingForward(e,t,n){let r=n?.cachingFunction??this.options?.cachingFunction??Ae.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=Xs(a,p);let c=await bo(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??Ae.debug??e.getOptions().debug??!1}getLogger(e,t){return t?.logger??this.options?.logger??Ae.logger??e.getLogger()}computeCacheKey(e,t){let n=lt("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=lt("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")}},Co=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 xi(o,e,t){let n=o instanceof Error?o:new Error(String(o));if(n instanceof Fe)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 Co(`Generate failed: ${n.message}`,u,{cause:n})}var Id=o=>o.replace(/^\W+|\W+$/g,""),Cd=(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]},Td=o=>{let e=new Set,t=[];for(let n of o)e.has(n)||(e.add(n),t.push(n));return t},wd=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}},Rd=o=>{let e=o.match(/^(\d+)[.,\s]+(.*)$/);return e&&e[2]!==void 0?e[2].trim():o},vd=(o,e)=>{let t=[];for(let n=0;n<o.length;n+=e)t.push(o.slice(n,n+e));return t},Ai={trimNonAlphaNum:Id,splitIntoTwo:Cd,dedup:Td,extractIdAndText:wd,extractIndexPrefixedText:Rd,batchArray:vd};var yi=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}=Ai.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 bi=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 rI=new rt,Ii=class{name;context;constructor(e,t){this.name=e,this.context=t}getName(){return this.name}getContext(){return this.context}},Ci=class{ai;db;debug;constructor(e){this.db=new Vt,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 xc=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 Ac(o,e){return o.filter(t=>!e.has(t))}function yc(o){let e={};for(let t of o)e[t]=(e[t]||0)+1;return e}function nn(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 Sd(o,e){return nn(o)===nn(e)?1:0}function kd(o,e){let t=nn(o).split(" "),n=nn(e).split(" "),r=yc(t),s=yc(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 Od(o,e,t,n=!1){let r=nn(o).split(" "),s=nn(e).split(" "),i=nn(t).split(" "),a=new Set([...xc,...r]);s=Ac(s,a),i=Ac(i,a);let u=0,c=u/s.length,l=u/i.length,p=2*c*l/(c+l);return n?l:p}var Ed={emScore:Sd,f1Score:kd,novelF1ScoreOptimized:Od};var Ti=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 yc(){let o=Date.now().toString(36),e=Math.random().toString(36).substring(2,8);return`trace-${o}-${e}`}var lr=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=yc(),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=yc(),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 kd(o){return Ne.create(o)}function at(o,e){let t=typeof o=="string"?Ne.create(o):o;return new Me(t,e)}var bc=o=>{console.log(o)},Tc=(o=bc)=>{let e=new rt,t=e.gray("\u2500".repeat(50)),n=e.gray("\u2501".repeat(50));return r=>{let s="";switch(r.name){case"OptimizationStart":s=`
784
+ `)}};function bc(){let o=Date.now().toString(36),e=Math.random().toString(36).substring(2,8);return`trace-${o}-${e}`}var ur=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=bc(),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=bc(),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 Md(o){return _e.create(o)}function at(o,e){let t=typeof o=="string"?_e.create(o):o;return new Pe(t,e)}var Ic=o=>{console.log(o)},Cc=(o=Ic)=>{let e=new rt,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)}},Od=(o=bc)=>{let e="\u2500".repeat(60);return t=>{let n="";switch(t.name){case"OptimizationStart":n=`[ OPTIMIZATION START: ${t.value.optimizerType} ]
827
+ `}o(s)}},Pd=(o=Ic)=>{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)}},Io=Tc();var Cc={enabled:!0,enabledCategories:["optimization","convergence","resource_usage","teacher_student","checkpointing","pareto"],maxLabelLength:100,samplingRate:1},wo,Ed=o=>{if(wo)return wo;if(o)return wo=Fd(o),wo};var Ro=Cc,Md=o=>{Ro={...Ro,...o}},Pd=()=>({...Ro}),Fd=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"})}),vt=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n),s=Ro.maxLabelLength;e[t]=r.length>s?r.substring(0,s):r}return e},_d=(o,e,t,n,r,s)=>{try{let i=vt({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)}},Nd=(o,e,t,n,r,s,i)=>{try{let a=vt({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)}},Ld=(o,e,t,n)=>{try{let r=vt({reason:e,optimizer_type:t,...n});o.earlyStoppingCounter&&o.earlyStoppingCounter.add(1,r)}catch(r){console.warn("Failed to record early stopping metric:",r)}},$d=(o,e,t,n,r,s)=>{try{let i=vt({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)}},Dd=(o,e,t,n)=>{try{let r=vt({optimizer_type:t,...n});o.optimizationDurationHistogram&&o.optimizationDurationHistogram.record(e,r)}catch(r){console.warn("Failed to record optimization duration metric:",r)}},Ud=(o,e,t,n,r)=>{try{let s=vt({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)}},Gd=(o,e,t,n,r,s)=>{try{let i=vt({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)}},Bd=(o,e,t,n,r,s)=>{try{let i=vt({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)}},jd=(o,e,t,n,r,s,i)=>{try{let a=vt({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)}},zd=(o,e,t,n,r)=>{try{let s=vt({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)}},qd=(o,e,t,n,r)=>{try{let s=vt({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)}},wt=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)}},vo=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}},Rt=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 vo({maxTokens:1e6});this.costTracker=e.costTracker??t,this.metricsInstruments=Ed(fe.meter),this.stats=this.initializeStats(),this.debugOptimizer=e.debugOptimizer??!1,this.optimizerLogger=e.optimizerLogger??(this.verbose?Io:void 0),this.initializeResultExplainer()}getMergedCustomLabels(e){return Kt(fe.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 Me(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;jd(this.metricsInstruments,s,i,0,0,e,r)}qd(this.metricsInstruments,e,this.targetScore,void 0,r)}recordOptimizationComplete(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);_d(this.metricsInstruments,e,t,n,r,i),Dd(this.metricsInstruments,e,n,i);let a=this.costTracker?.getCurrentCost()??0,l=this.costTracker?.getTotalTokens()??0;$d(this.metricsInstruments,l,a,n,void 0,i)}recordConvergenceMetrics(e,t,n,r,s,i){if(!this.metricsInstruments)return;let a=this.getMergedCustomLabels(i);Nd(this.metricsInstruments,e,t,n,r,s,a)}recordEarlyStoppingMetrics(e,t,n){if(!this.metricsInstruments)return;let r=this.getMergedCustomLabels(n);Ld(this.metricsInstruments,e,t,r)}recordTeacherStudentMetrics(e,t,n,r){if(!this.metricsInstruments)return;let s=this.getMergedCustomLabels(r);Ud(this.metricsInstruments,e,t,n,s)}recordCheckpointMetrics(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);Gd(this.metricsInstruments,e,t,n,r,i)}recordParetoMetrics(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);Bd(this.metricsInstruments,e,t,n,r,i)}recordPerformanceMetrics(e,t,n,r){if(!this.metricsInstruments)return;let s=this.getMergedCustomLabels(r);zd(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??fe.optimizerLogger??Io}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=[]}};import Hd from"crypto";function So(o){let e=new Date().toISOString();return{version:1,sections:{},stats:{bulletCount:0,helpfulCount:0,harmfulCount:0,tokenEstimate:0},updatedAt:e,description:o}}function St(o){return JSON.parse(JSON.stringify(o))}function Kd(o){return Math.ceil(o.length/4)}function Ci(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=Vd(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??Wd(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 Ri(o),o.updatedAt=c,{updatedBulletIds:n,autoRemoved:r}}function Ii(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(),Ri(o);return}}}function en(o){let e=o.description?`## Context Playbook
853
+ ${e}`}o(n)}},To=Cc();var Tc={enabled:!0,enabledCategories:["optimization","convergence","resource_usage","teacher_student","checkpointing","pareto"],maxLabelLength:100,samplingRate:1},wo,Fd=o=>{if(wo)return wo;if(o)return wo=Ld(o),wo};var Ro=Tc,_d=o=>{Ro={...Ro,...o}},Nd=()=>({...Ro}),Ld=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"})}),vt=o=>{let e={};for(let[t,n]of Object.entries(o))if(n!=null){let r=String(n),s=Ro.maxLabelLength;e[t]=r.length>s?r.substring(0,s):r}return e},$d=(o,e,t,n,r,s)=>{try{let i=vt({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)}},Dd=(o,e,t,n,r,s,i)=>{try{let a=vt({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)}},Ud=(o,e,t,n)=>{try{let r=vt({reason:e,optimizer_type:t,...n});o.earlyStoppingCounter&&o.earlyStoppingCounter.add(1,r)}catch(r){console.warn("Failed to record early stopping metric:",r)}},Gd=(o,e,t,n,r,s)=>{try{let i=vt({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)}},jd=(o,e,t,n)=>{try{let r=vt({optimizer_type:t,...n});o.optimizationDurationHistogram&&o.optimizationDurationHistogram.record(e,r)}catch(r){console.warn("Failed to record optimization duration metric:",r)}},Bd=(o,e,t,n,r)=>{try{let s=vt({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)}},zd=(o,e,t,n,r,s)=>{try{let i=vt({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)}},qd=(o,e,t,n,r,s)=>{try{let i=vt({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)}},Hd=(o,e,t,n,r,s,i)=>{try{let a=vt({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)}},Kd=(o,e,t,n,r)=>{try{let s=vt({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)}},Wd=(o,e,t,n,r)=>{try{let s=vt({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)}},wt=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)}},vo=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}},Rt=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 vo({maxTokens:1e6});this.costTracker=e.costTracker??t,this.metricsInstruments=Fd(Ae.meter),this.stats=this.initializeStats(),this.debugOptimizer=e.debugOptimizer??!1,this.optimizerLogger=e.optimizerLogger??(this.verbose?To:void 0),this.initializeResultExplainer()}getMergedCustomLabels(e){return Kt(Ae.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,I,C={},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,I,C,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;Hd(this.metricsInstruments,s,i,0,0,e,r)}Wd(this.metricsInstruments,e,this.targetScore,void 0,r)}recordOptimizationComplete(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);$d(this.metricsInstruments,e,t,n,r,i),jd(this.metricsInstruments,e,n,i);let a=this.costTracker?.getCurrentCost()??0,u=this.costTracker?.getTotalTokens()??0;Gd(this.metricsInstruments,u,a,n,void 0,i)}recordConvergenceMetrics(e,t,n,r,s,i){if(!this.metricsInstruments)return;let a=this.getMergedCustomLabels(i);Dd(this.metricsInstruments,e,t,n,r,s,a)}recordEarlyStoppingMetrics(e,t,n){if(!this.metricsInstruments)return;let r=this.getMergedCustomLabels(n);Ud(this.metricsInstruments,e,t,r)}recordTeacherStudentMetrics(e,t,n,r){if(!this.metricsInstruments)return;let s=this.getMergedCustomLabels(r);Bd(this.metricsInstruments,e,t,n,s)}recordCheckpointMetrics(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);zd(this.metricsInstruments,e,t,n,r,i)}recordParetoMetrics(e,t,n,r,s){if(!this.metricsInstruments)return;let i=this.getMergedCustomLabels(s);qd(this.metricsInstruments,e,t,n,r,i)}recordPerformanceMetrics(e,t,n,r){if(!this.metricsInstruments)return;let s=this.getMergedCustomLabels(r);Kd(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??Ae.optimizerLogger??To}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=[]}};import Vd from"crypto";function So(o){let e=new Date().toISOString();return{version:1,sections:{},stats:{bulletCount:0,helpfulCount:0,harmfulCount:0,tokenEstimate:0},updatedAt:e,description:o}}function St(o){return JSON.parse(JSON.stringify(o))}function Jd(o){return Math.ceil(o.length/4)}function wi(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=Yd(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??Qd(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 Si(o),o.updatedAt=c,{updatedBulletIds:n,autoRemoved:r}}function Ri(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(),Si(o);return}}}function rn(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 Wd(o){let e=o.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"").slice(0,6),t=Hd.randomBytes(4).toString("hex");return`${e||"ctx"}-${t}`}function Vd(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 wi(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}Ri(o)}function Ri(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+=Kd(i.content);o.stats={bulletCount:e,helpfulCount:t,harmfulCount:n,tokenEstimate:r}}var Jd={maxEpochs:1,maxReflectorRounds:2,maxSectionSize:25,similarityThreshold:.95,allowDynamicSections:!0},ko=class extends wt{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=St(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(),"",en(this.playbook)].filter(s=>s&&s.trim().length>0).join(`
862
+ ${t}`.trim()}function Qd(o){let e=o.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"").slice(0,6),t=Vd.randomBytes(4).toString("hex");return`${e||"ctx"}-${t}`}function Yd(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 vi(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}Si(o)}function Si(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+=Jd(i.content);o.stats={bulletCount:e,helpfulCount:t,harmfulCount:n,tokenEstimate:r}}var Xd={maxEpochs:1,maxReflectorRounds:2,maxSectionSize:25,similarityThreshold:.95,allowDynamicSections:!0},ko=class extends wt{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=St(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(),"",rn(this.playbook)].filter(s=>s&&s.trim().length>0).join(`
863
863
 
864
- `);e.setDescription(r)}},cr=class extends Rt{aceConfig;playbook;baseInstruction;generatorHistory=[];deltaHistory=[];reflectorProgram;curatorProgram;program;constructor(e,t){super(e),this.aceConfig={...Jd,...t},this.playbook=t?.initialPlaybook!==void 0?St(t.initialPlaybook):So()}reset(){super.reset(),this.playbook=this.aceConfig.initialPlaybook!==void 0?St(this.aceConfig.initialPlaybook):So(),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?St(t.playbook):this.aceConfig.initialPlaybook!==void 0?St(this.aceConfig.initialPlaybook):So(),this.generatorHistory=[...t?.artifact?.feedback??[]],this.deltaHistory=[...t?.artifact?.history??[]]}getPlaybook(){return St(this.playbook)}getBaseInstruction(){return this.baseInstruction}getArtifact(){return{playbook:St(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=St(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=Ci(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)Ii(this.playbook,j.id,j.tag);P.length>0&&N.length>0&&wi(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:St(this.playbook),feedback:[...this.generatorHistory],history:[...this.deltaHistory]},f=new ko({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:St(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)Ii(this.playbook,p.id,p.tag);if(a.length>0){let p=this.collectProtectedBulletIds(a),d=Ci(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)),wi(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(),"",en(t)].filter(r=>r.trim().length>0).join(`
864
+ `);e.setDescription(r)}},cr=class extends Rt{aceConfig;playbook;baseInstruction;generatorHistory=[];deltaHistory=[];reflectorProgram;curatorProgram;program;constructor(e,t){super(e),this.aceConfig={...Xd,...t},this.playbook=t?.initialPlaybook!==void 0?St(t.initialPlaybook):So()}reset(){super.reset(),this.playbook=this.aceConfig.initialPlaybook!==void 0?St(this.aceConfig.initialPlaybook):So(),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?St(t.playbook):this.aceConfig.initialPlaybook!==void 0?St(this.aceConfig.initialPlaybook):So(),this.generatorHistory=[...t?.artifact?.feedback??[]],this.deltaHistory=[...t?.artifact?.history??[]]}getPlaybook(){return St(this.playbook)}getBaseInstruction(){return this.baseInstruction}getArtifact(){return{playbook:St(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=St(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],I=this.composeInstruction(a??u,this.playbook);e.setDescription?.(I);let C=await e.forward(this.studentAI,y);this.stats.totalCalls+=1;let v=await n({prediction:C,example:y});typeof v=="number"&&(this.stats.bestScore=Math.max(this.stats.bestScore,v),c=Math.max(c,v));let O=C?.severity,R=y?.severity,E=this.createGeneratorOutput(C,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=wi(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)Ri(this.playbook,j.id,j.tag);M.length>0&&N.length>0&&vi(this.playbook,this.aceConfig.similarityThreshold);let G={example:y,prediction:C,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:St(this.playbook),feedback:[...this.generatorHistory],history:[...this.deltaHistory]},f=new ko({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:St(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)Ri(this.playbook,p.id,p.tag);if(a.length>0){let p=this.collectProtectedBulletIds(a),d=wi(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)),vi(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(),"",rn(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:en(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:en(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=de().input("question",de.string("Original task input serialized as JSON")).input("generator_answer",de.string("Generator output serialized as JSON")).input("generator_reasoning",de.string("Generator reasoning trace").optional()).input("playbook",de.string("Current context playbook rendered as markdown")).input("expected_answer",de.string("Expected output when ground truth is available").optional()).input("feedback",de.string("External feedback or reward signal").optional()).input("previous_reflection",de.string("Most recent reflection JSON when running multi-round refinement").optional()).output("reasoning",de.string("Step-by-step analysis of generator performance")).output("errorIdentification",de.string("Specific mistakes detected")).output("rootCauseAnalysis",de.string("Underlying cause of the error")).output("correctApproach",de.string("What the generator should do differently")).output("keyInsight",de.string("Reusable insight to remember")).output("bulletTags",de.json("Array of {id, tag} entries referencing playbook bullets")).build();this.reflectorProgram=at(e)}return this.reflectorProgram}getOrCreateCuratorProgram(){if(!this.curatorProgram){let e=de().input("playbook",de.string("Current playbook serialized as JSON")).input("reflection",de.string("Latest reflection output serialized as JSON")).input("question_context",de.string("Original task input serialized as JSON")).input("token_budget",de.number("Approximate token budget for curator response").optional()).output("reasoning",de.string("Justification for the proposed updates")).output("operations",de.json("List of operations with type/section/content fields")).build();this.curatorProgram=at(e)}return this.curatorProgram}};function Ic(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 ur(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(Ic(o[i].scores,o[n].scores,e)){s=!0;break}Ic(o[n].scores,o[i].scores,e)&&r++}s||t.push({idx:o[n].idx,scores:o[n].scores,dominated:r})}return t}function hn(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 vi(o){if(o.length===0)return 0;let e=0;for(let t of o)e+=t;return e/o.length}function wc(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 Si(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 Rc(o,e,t){let n=Si(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 Qd(o){return o.size===0?{score:0}:Object.fromEntries([...o].map(e=>[e,0]))}function Oo(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 tn=class o extends Rt{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,ue)=>(ne[ue]=$[ue],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 ue={};for(let[X,z]of Object.entries(ne))typeof z=="number"&&Number.isFinite(z)&&(ue[X]=z);return ue},b=$=>{let K=r?.paretoMetricKey,ne=r?.paretoScalarize;if(typeof ne=="function")return ne($);if(K)return Number.isFinite($[K])?$[K]:0;let ue=Object.values($);return ue.length?ue.reduce((X,z)=>X+z,0)/ue.length:0},T=this.getOptimizerLogger(r),C=r?.verbose??this.verbose?$=>console.log(`[GEPA] ${$}`):$=>{},v=new Set,k=async($,K,ne,ue=!1)=>{let X=K.length;if(this.stats.totalCalls+X>a){if(ue)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,ke]of K.entries()){A($);let Oe,se;try{Oe=await e.forward(this.studentAI,ke,{sampleCount:this.sampleCount}),se=await h(Oe,ke);for(let ae of Object.keys(se))v.add(ae)}catch(ae){let Ae=ae instanceof Error?ae.message:String(ae);Oe={error:Ae},se=Qd(v),C(`Evaluation failed during ${ne}; scoring this example as zero. Error: ${Ae}`)}this.stats.totalCalls+=1;let Pe=b(se);z.push({input:ke,prediction:Oe,scores:se,scalar:Pe}),C(`${ne}: completed ${ie+1}/${K.length} (score=${Pe.toFixed(3)})`)}return{rows:z,avg:wc(z.map(ie=>ie.scores)),scalars:z.map(ie=>ie.scalar),sum:z.reduce((ie,ke)=>ie+ke.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=ur(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,He=new Set;for(let Qe=0;Qe<_.length;Qe++){let st=_[Qe][le];st>De+this.tieEpsilon?(De=st,He.clear(),He.add(Qe)):Math.abs(st-De)<=this.tieEpsilon&&He.add(Qe)}ne.push(He)}let ue=_.map(le=>vi(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,He=Si(ne,ue),Qe=new Set;for(let w of He)for(let O of w)Qe.add(O);let st=Array.from(Qe),y;for(let w=0;w<10&&!y&&!(st.length<2);w++){let O=De(st),I=De(st);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 tt of _e){let Y=Te[tt],J=Ue[tt],ge=ye[tt];if(J===Y&&ge!==J||ge===Y&&J!==ge){qe=!0;break}}qe&&W.push(Z)}if(W.length===0)continue;let M=W.map(Z=>Math.max(1e-9,ue[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=ue[D],Q=ue[O],W=ue[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,Ye)=>ue[Ce]>=ue[Ye]?Ce:Ye),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,Ye)=>Ye),qe=ye.filter(Ce=>(Te[Ce]??0)>(Ue[Ce]??0)),_e=ye.filter(Ce=>(Ue[Ce]??0)>(Te[Ce]??0)),tt=ye.filter(Ce=>!(qe.includes(Ce)||_e.includes(Ce))),Y=5,J=Math.ceil(Y/3),ge=(Ce,Ye)=>{if(Ye<=0||Ce.length===0)return[];if(Ce.length<=Ye)return[...Ce];let Rn=[],Sr=new Set;for(;Rn.length<Ye;){let xt=Math.floor(this.rand()*Ce.length);Sr.has(xt)||(Sr.add(xt),Rn.push(Ce[xt]))}return Rn},we=[];we.push(...ge(qe,Math.min(J,qe.length))),we.push(...ge(_e,Math.min(J,_e.length)));let Ee=Y-we.length;we.push(...ge(tt,Math.max(0,Ee)));let Ke=Y-we.length;if(Ke>0){let Ce=ye.filter(Ye=>!we.includes(Ye));we.push(...ge(Ce,Math.min(Ke,Ce.length)))}let zt=we.slice(0,Math.min(Y,ye.length)),Ho=zt.map(Ce=>u[Ce]),qt=await k(q,Ho,"merge subsample");if(!qt)break;let Ht=qt.sum,vr=zt.reduce((Ce,Ye)=>Ce+(Te[Ye]??0),0),ga=zt.reduce((Ce,Ye)=>Ce+(Ue[Ye]??0),0);if(Ht>=Math.max(vr,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 Ye=F.length,Rn=hn(F.map(xt=>S[xt].scores))??0;F=ur(S.map((xt,_u)=>({idx:_u,scores:xt.scores})),this.tieEpsilon).map(xt=>xt.idx);let Sr=hn(F.map(xt=>S[xt].scores))??0;(F.length>Ye||Sr>Rn+1e-6)&&(L=0),this.mergesDue-=1,this.totalMergesTested+=1,P.add(M),w=!0}if(w)continue}}let X=Rc(ne,ue,()=>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 ke={...S[X].cfg},Oe="reflective_mutation",se,Pe,ae=f[$%f.length],Ae=S[X].cfg[ae.id],be=r?.gepaAdapter,oe,me=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((st,y)=>st+(Number(y)||0),0):void 0;let De=be.make_reflective_dataset({...S[X].cfg},le,[ae.id]),He=await be.propose_new_texts?.({...S[X].cfg},De,[ae.id]),Qe=He?.[ae.id]??(He?Object.values(He)[0]:void 0);typeof Qe=="string"&&Qe.length>0&&(oe=Qe)}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,me)),ke[ae.id]=oe,be&&se!==void 0)try{let le=await be.evaluate(z,ke,!1);Pe=Array.isArray(le?.scores)?le.scores.reduce((De,He)=>De+(Number(He)||0),0):void 0}catch{}let Ie=await k(ke,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:Oe,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||Pe===void 0||Pe>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(ke,u,"validation evaluation");if(!$e)break;S.push({cfg:{...ke},parent:X,scores:$e.avg}),_.push($e.scalars);let ot=F.length,Se=hn(F.map(le=>S[le].scores))??0;F=ur(S.map((le,De)=>({idx:De,scores:le.scores})),this.tieEpsilon).map(le=>le.idx);let ze=hn(F.map(le=>S[le].scores))??0;if(F.length>ot||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=ur(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=hn(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 wt({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?vi(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=at('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=at('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}
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:rn(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:rn(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=ge().input("question",ge.string("Original task input serialized as JSON")).input("generator_answer",ge.string("Generator output serialized as JSON")).input("generator_reasoning",ge.string("Generator reasoning trace").optional()).input("playbook",ge.string("Current context playbook rendered as markdown")).input("expected_answer",ge.string("Expected output when ground truth is available").optional()).input("feedback",ge.string("External feedback or reward signal").optional()).input("previous_reflection",ge.string("Most recent reflection JSON when running multi-round refinement").optional()).output("reasoning",ge.string("Step-by-step analysis of generator performance")).output("errorIdentification",ge.string("Specific mistakes detected")).output("rootCauseAnalysis",ge.string("Underlying cause of the error")).output("correctApproach",ge.string("What the generator should do differently")).output("keyInsight",ge.string("Reusable insight to remember")).output("bulletTags",ge.json("Array of {id, tag} entries referencing playbook bullets")).build();this.reflectorProgram=at(e)}return this.reflectorProgram}getOrCreateCuratorProgram(){if(!this.curatorProgram){let e=ge().input("playbook",ge.string("Current playbook serialized as JSON")).input("reflection",ge.string("Latest reflection output serialized as JSON")).input("question_context",ge.string("Original task input serialized as JSON")).input("token_budget",ge.number("Approximate token budget for curator response").optional()).output("reasoning",ge.string("Justification for the proposed updates")).output("operations",ge.json("List of operations with type/section/content fields")).build();this.curatorProgram=at(e)}return this.curatorProgram}};function wc(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 lr(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(wc(o[i].scores,o[n].scores,e)){s=!0;break}wc(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 ki(o){if(o.length===0)return 0;let e=0;for(let t of o)e+=t;return e/o.length}function Rc(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 Oi(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 vc(o,e,t){let n=Oi(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 Zd(o){return o.size===0?{score:0}:Object.fromEntries([...o].map(e=>[e,0]))}function Oo(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 on=class o extends Rt{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,fe)=>(ee[fe]=L[fe],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 fe={};for(let[q,B]of Object.entries(ee))typeof B=="number"&&Number.isFinite(B)&&(fe[q]=B);return fe},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 fe=Object.values(L);return fe.length?fe.reduce((q,B)=>q+B,0)/fe.length:0},I=this.getOptimizerLogger(r),C=r?.verbose??this.verbose?L=>console.log(`[GEPA] ${L}`):L=>{},v=new Set,O=async(L,K,ee,fe=!1)=>{let q=K.length;if(this.stats.totalCalls+q>a){if(fe)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=[];C(`${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=Zd(v),C(`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}),C(`${ee}: completed ${ue+1}/${K.length} (score=${Re.toFixed(3)})`)}return{rows:B,avg:Rc(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];I?.({name:"OptimizationStart",value:{optimizerType:"GEPA",exampleCount:t.length,validationCount:l.length,config:{numTrials:this.numTrials,minibatch:this.minibatch,mergeMax:this.mergeMax,tunableCount:f.length}}}),C(`Starting GEPA optimization: ${t.length} train, ${l.length} validation, maxCalls=${a}`);let $=0,M=new Set,F=lr(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 le=0;le<K;le++){let De=Number.NEGATIVE_INFINITY,He=new Set;for(let Qe=0;Qe<_.length;Qe++){let st=_[Qe][le];st>De+this.tieEpsilon?(De=st,He.clear(),He.add(Qe)):Math.abs(st-De)<=this.tieEpsilon&&He.add(Qe)}ee.push(He)}let fe=_.map(le=>ki(le));if(this.mergeMax>0&&this.mergesDue>0&&this.lastIterFoundNewProgram){let le=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,He=Oi(ee,fe),Qe=new Set;for(let w of He)for(let k of w)Qe.add(k);let st=Array.from(Qe),b;for(let w=0;w<10&&!b&&!(st.length<2);w++){let k=De(st),T=De(st);if(k===T)continue;T<k&&([k,T]=[T,k]);let D=new Set(le(k)),H=new Set(le(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 Ce=S[te].cfg,Ue=S[k].cfg,be=S[T].cfg,qe=!1,Ne=new Set([...Object.keys(Ce),...Object.keys(Ue),...Object.keys(be)]);for(let tt of Ne){let Z=Ce[tt],Q=Ue[tt],xe=be[tt];if(Q===Z&&xe!==Q||xe===Z&&Q!==xe){qe=!0;break}}qe&&V.push(te)}if(V.length===0)continue;let P=V.map(te=>Math.max(1e-9,fe[te])),z=this.rand()*P.reduce((te,Ce)=>te+Ce,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=fe[D],Y=fe[k],V=fe[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,Ye)=>fe[Te]>=fe[Ye]?Te:Ye),te=`${Math.min(k,T)}|${Math.max(k,T)}|${ne}`;if(this.mergeCompositionKeys.has(te))continue;this.mergeCompositionKeys.add(te);let Ce=_[k],Ue=_[T],be=Array.from({length:Ce.length},(Te,Ye)=>Ye),qe=be.filter(Te=>(Ce[Te]??0)>(Ue[Te]??0)),Ne=be.filter(Te=>(Ue[Te]??0)>(Ce[Te]??0)),tt=be.filter(Te=>!(qe.includes(Te)||Ne.includes(Te))),Z=5,Q=Math.ceil(Z/3),xe=(Te,Ye)=>{if(Ye<=0||Te.length===0)return[];if(Te.length<=Ye)return[...Te];let vn=[],vr=new Set;for(;vn.length<Ye;){let xt=Math.floor(this.rand()*Te.length);vr.has(xt)||(vr.add(xt),vn.push(Te[xt]))}return vn},ve=[];ve.push(...xe(qe,Math.min(Q,qe.length))),ve.push(...xe(Ne,Math.min(Q,Ne.length)));let Me=Z-ve.length;ve.push(...xe(tt,Math.max(0,Me)));let Ke=Z-ve.length;if(Ke>0){let Te=be.filter(Ye=>!ve.includes(Ye));ve.push(...xe(Te,Math.min(Ke,Te.length)))}let zt=ve.slice(0,Math.min(Z,be.length)),Ho=zt.map(Te=>l[Te]),qt=await O(z,Ho,"merge subsample");if(!qt)break;let Ht=qt.sum,Rr=zt.reduce((Te,Ye)=>Te+(Ce[Ye]??0),0),xa=zt.reduce((Te,Ye)=>Te+(Ue[Ye]??0),0);if(Ht>=Math.max(Rr,xa)+this.minImprovementThreshold){C(`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 Ye=F.length,vn=xn(F.map(xt=>S[xt].scores))??0;F=lr(S.map((xt,$l)=>({idx:$l,scores:xt.scores})),this.tieEpsilon).map(xt=>xt.idx);let vr=xn(F.map(xt=>S[xt].scores))??0;(F.length>Ye||vr>vn+1e-6)&&($=0),this.mergesDue-=1,this.totalMergesTested+=1,M.add(P),w=!0}if(w)continue}}let q=vc(ee,fe,()=>this.rand());this.lastIterFoundNewProgram=!1;let B=this.minibatch?this.nextMinibatchIndices(g.length,L).map(le=>g[le]):g,ue=await O(S[q].cfg,B,"parent minibatch");if(!ue)break;if(r?.skipPerfectScore??!0){let le=Number(r?.perfectScore??1);if(ue.scalars.length>0&&ue.scalars.every(De=>De>=le))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,he=ue.rows.map(le=>({input:le.input,prediction:le.prediction,score:le.scalar}));if(J)try{let le=await J.evaluate(B,{...S[q].cfg},!0);ce=Array.isArray(le?.scores)?le.scores.reduce((st,b)=>st+(Number(b)||0),0):void 0;let De=J.make_reflective_dataset({...S[q].cfg},le,[se.id]),He=await J.propose_new_texts?.({...S[q].cfg},De,[se.id]),Qe=He?.[se.id]??(He?Object.values(He)[0]:void 0);typeof Qe=="string"&&Qe.length>0&&(X=Qe)}catch{}if(X||(X=await this.reflectTargetInstruction(se.id,de,e,A,{...S[q].cfg},B,async({prediction:le,example:De})=>y(await h(le,De)),r,he)),ke[se.id]=X,J&&ce!==void 0)try{let le=await J.evaluate(B,ke,!1);Re=Array.isArray(le?.scores)?le.scores.reduce((De,He)=>De+(Number(He)||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(C(`Iteration ${L+1}: Rejected (child=${we.sum.toFixed(3)} <= parent=${ue.sum.toFixed(3)})`),++$>=this.earlyStoppingTrials){C(`Early stopping: ${$} iterations without improvement`);break}continue}C(`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 ot=F.length,Ee=xn(F.map(le=>S[le].scores))??0;F=lr(S.map((le,De)=>({idx:De,scores:le.scores})),this.tieEpsilon).map(le=>le.idx);let ze=xn(F.map(le=>S[le].scores))??0;if(F.length>ot||ze>Ee+1e-6)$=0,C(`Iteration ${L+1}: Archive improved (size=${F.length}, hv=${ze.toFixed(4)})`);else if($++,C(`Iteration ${L+1}: Archive unchanged (stagnation=${$}/${this.earlyStoppingTrials})`),$>=this.earlyStoppingTrials){C(`Early stopping: ${$} iterations without archive improvement`);break}this.lastIterFoundNewProgram=!0,this.mergeMax>0&&this.totalMergesTested<this.mergeMax&&(this.mergesDue+=1)}let G=lr(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 wt({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,Ie=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:Ie}}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?ki(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 I=await a({prediction:y,example:h});l.push({input:h,prediction:y,score:typeof I=="number"?I:0})}catch{l.push({input:h,prediction:{},score:0})}let p=u?.overrideTeacherAI??this.teacherAI??this.studentAI,d=at('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=at('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[C,v]of Object.entries(h.input))y+=`### ${C}
869
869
  ${Oo(v)}
870
870
 
871
- `;else b+=`${Oo(h.input)}
871
+ `;else y+=`${Oo(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}
873
+ `;if(y+=`## Generated Outputs
874
+ `,typeof h.prediction=="object"&&h.prediction!==null)for(let[C,v]of Object.entries(h.prediction))y+=`### ${C}
875
875
  ${Oo(v)}
876
876
 
877
- `;else b+=`${Oo(h.prediction)}
877
+ `;else y+=`${Oo(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 I=`This trajectory got a score of ${h.score.toFixed(3)}.`;if(typeof l=="function")try{let C=l({prediction:h.prediction,example:h.input,componentId:c});C&&(I=Array.isArray(C)?C.join(`
881
+ `):C)}catch{}y+=`${I}
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=at('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=at(`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(I=>`score=${I.score.toFixed(2)}`).join(", ")}`;return this.feedbackMemory.unshift(y),this.feedbackMemory.length>this.feedbackMemorySize&&this.feedbackMemory.pop(),h}}}catch{}let g=at('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 I=r(t,n);m[x]=I===t?h:y,g.push(I===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=at(`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 vc(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 Yd(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 pr=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 Sc(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 em(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 pr=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
- ${vc(t)}
897
+ ${Sc(t)}
898
898
 
899
899
  The system produces these OUTPUT fields:
900
- ${Yd(n)}
900
+ ${em(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 Me("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
- ${vc(t)}
911
+ ${Sc(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 Me("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 Me(this.signature).forward(this.options.teacher,e,{model:this.options.model})}getSignature(){return this.signature}getTeacher(){return this.options.teacher}};var Xd={excellent:1,good:.8,acceptable:.5,poor:.2,unacceptable:0};function Zd(o){let{ai:e,criteria:t,description:n,randomizeOrder:r,...s}=o;return{...s,maxSteps:1}}function em(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 tm(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 nm(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,tm(a,l)&&(r+=1))}return s>0?r/s:0}function rm(o,e){let t=new Me(`
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 tm={excellent:1,good:.8,acceptable:.5,poor:.2,unacceptable:0};function nm(o){let{ai:e,criteria:t,description:n,randomizeOrder:r,...s}=o;return{...s,maxSteps:1}}function rm(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 om(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 sm(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,om(a,u)&&(r+=1))}return s>0?r/s:0}function im(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 Me(`
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=Zd(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&&em(u))return nm(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 Xd[m.quality.toLowerCase()]??.5}}var om="batch",ki={feedbackWindowSize:25,maxRecentTraces:100,updateBudget:4},Oi=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??om,continuousOptions:{feedbackWindowSize:t.continuousOptions?.feedbackWindowSize??ki.feedbackWindowSize,maxRecentTraces:t.continuousOptions?.maxRecentTraces??ki.maxRecentTraces,updateBudget:t.continuousOptions?.updateBudget??ki.updateBudget}},this.tracer=new lr(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 tn({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 cr({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 rm(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 pr(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(),"",en(e)].filter(i=>i&&i.trim().length>0).join(`
936
+ `),r=e.description?.trim();r&&(t.setInstruction(r),n.setInstruction(r));let s=nm(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&&rm(l))return sm(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 tm[m.quality.toLowerCase()]??.5}}var am="batch",Ei={feedbackWindowSize:25,maxRecentTraces:100,updateBudget:4},Mi=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??am,continuousOptions:{feedbackWindowSize:t.continuousOptions?.feedbackWindowSize??Ei.feedbackWindowSize,maxRecentTraces:t.continuousOptions?.maxRecentTraces??Ei.maxRecentTraces,updateBudget:t.continuousOptions?.updateBudget??Ei.updateBudget}},this.tracer=new ur(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 on({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 cr({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 im(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 I=i.get(A);I?I!==y&&i.set(A,`${I}
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 pr(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(),"",rn(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 Ei=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 dr=class extends Rt{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=im([...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=sm(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 sm(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 im=(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 Eo=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 Mi=class extends Rt{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 Eo(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 Pi=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 dr=class extends Rt{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=cm([...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=um(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 um(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 cm=(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 Eo=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 Fi=class extends Rt{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 Eo(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 at('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 dr({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 at('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 Me(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 wt({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 at('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 dr({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 at('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 I=x.temperature?{temperature:x.temperature}:void 0;y.setDemos(A,{modelConfig:I});let C=new wt({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:C,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 mr=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 xn(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 gr=class{steps=[];parallelGroups=[];analyzer=new mr;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 xn(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}}};import{context as cm,SpanKind as um,trace as pm}from"@opentelemetry/api";var Sc=o=>{console.log(o)},An=(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)},yn=o=>o<1e3?`${o.toFixed(1)}ms`:o<6e4?`${(o/1e3).toFixed(2)}s`:`${(o/6e4).toFixed(2)}min`,Mo=(o=Sc)=>{let e=new rt,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 mr=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 An(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 gr=class{steps=[];parallelGroups=[];analyzer=new mr;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 An(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}}};import{context as dm,SpanKind as mm,trace as gm}from"@opentelemetry/api";var kc=o=>{console.log(o)},yn=(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)},bn=o=>o<1e3?`${o.toFixed(1)}ms`:o<6e4?`${(o/1e3).toFixed(2)}s`:`${(o/6e4).toFixed(2)}min`,Mo=(o=kc)=>{let e=new rt,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(An(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 ${yn(r.executionTime)}`)}
997
+ `),s+=`${e.white("State:")} ${e.gray(yn(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 ${bn(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 ${yn(r.executionTime)}`)}
1003
+ `,s+=n;break;case"ParallelGroupComplete":s=`${e.blueBright("\u2705 [ PARALLEL GROUP COMPLETE ]")} ${e.white(`Level ${r.groupLevel}`)}`,s+=` ${e.magenta(`in ${bn(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(yn(r.totalExecutionTime))}
1011
+ ${t}`,s+=`${e.white("Total Time:")} ${e.magenta(bn(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(An(r.finalState,!0))}
1014
+ `,s+=`${e.white("Final State:")} ${e.gray(yn(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(An(r.state,!0))}
1020
- `),s+=t;break;default:s=e.gray(JSON.stringify(r,null,2))}o(s)}},am=(o=Sc)=>{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(yn(r.state,!0))}
1020
+ `),s+=t;break;default:s=e.gray(JSON.stringify(r,null,2))}o(s)}},lm=(o=kc)=>{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: ${An(n.state,!0)}
1032
+ `),r+=`State: ${yn(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 ${yn(n.executionTime)}
1034
+ `;break;case"StepComplete":r=`[ STEP ${n.stepIndex} COMPLETE ] (${n.stepType})`,n.nodeName&&(r+=` Node: ${n.nodeName}`),r+=` in ${bn(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 ${yn(n.executionTime)}
1041
+ `;break;case"ParallelGroupComplete":r=`[ PARALLEL GROUP COMPLETE ] Level ${n.groupLevel} in ${bn(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: ${yn(n.totalExecutionTime)}
1052
+ `,r+=`Total Time: ${bn(n.totalExecutionTime)}
1053
1053
  `,r+=`Steps Executed: ${n.stepsExecuted}
1054
1054
  `,r+=`Output Fields: ${n.outputFields.join(", ")}
1055
- `,r+=`Final State: ${An(n.finalState,!0)}
1055
+ `,r+=`Final State: ${yn(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: ${An(n.state,!0)}
1062
+ `,n.state&&(r+=`State: ${yn(n.state,!0)}
1063
1063
  `),r+=`${e}
1064
- `;break;default:r=JSON.stringify(n,null,2)}o(r)}},lm=Mo(),kc=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 fr=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}},Pi=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 Po=class o{static _ctorWarned=!1;nodes=new Map;flowDefinition=[];nodeGenerators=new Map;loopStack=[];stepLabels=new Map;branchContext=null;autoParallelConfig;executionPlanner=new gr;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=ut("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=ut("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 Fe("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 de().input("userInput",de.string("User input to the flow")).output("flowOutput",de.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=Mo():this.flowLogger=void 0,this.timingLogger=this.flowLogger?kc(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 Yt(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 nr(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]=nr(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??fe.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??fe.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:um.INTERNAL,attributes:{total_steps:b.totalSteps,parallel_groups:b.parallelGroups,max_parallelism:b.maxParallelism,auto_parallel_enabled:b.autoParallelEnabled}});let C=d??cm.active();m=pm.setSpan(C,l)}c=new AbortController,this.activeAbortControllers.add(c),this._stopRequested&&c.abort("Stopped by user (pre-forward)");let g=Ct(n?.abortSignal,n?.abortController?.signal),f=Ct(c.signal,Ct(g,fe.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=at(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 xn(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 xn(e,async(i,a)=>{let l=new fr(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 xn(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 Fi(o){return Po.create(o)}var _i=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 Ni=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 nn(o){return!!o&&/[A-Za-z0-9_$]/.test(o)}function Oc(o){return!!o&&/[A-Za-z_$]/.test(o)}function Pt(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)}},pm=Mo(),Oc=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 fr=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}},_i=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 Po=class o{static _ctorWarned=!1;nodes=new Map;flowDefinition=[];nodeGenerators=new Map;loopStack=[];stepLabels=new Map;branchContext=null;autoParallelConfig;executionPlanner=new gr;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=lt("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=lt("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 Fe("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 ge().input("userInput",ge.string("User input to the flow")).output("flowOutput",ge.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 _e;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 _e,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=Mo():this.flowLogger=void 0,this.timingLogger=this.flowLogger?Oc(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 Yt(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 rr(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]=rr(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??Ae.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??Ae.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(),I=n?.traceLabel?`AxFlow > ${n.traceLabel}`:"AxFlow";u=p.startSpan(I,{kind:mm.INTERNAL,attributes:{total_steps:y.totalSteps,parallel_groups:y.parallelGroups,max_parallelism:y.maxParallelism,auto_parallel_enabled:y.autoParallelEnabled}});let C=d??dm.active();m=gm.setSpan(C,u)}c=new AbortController,this.activeAbortControllers.add(c),this._stopRequested&&c.abort("Stopped by user (pre-forward)");let g=Ct(n?.abortSignal,n?.abortController?.signal),f=Ct(c.signal,Ct(g,Ae.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),I=await this.executeStepsWithLogging(y,a,x,!0);a=I.finalState,h=I.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 _e){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=at(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 An(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 An(e,async(i,a)=>{let u=new fr(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 An(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"?_e.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 Ni(o){return Po.create(o)}var Li=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 $i=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 sn(o){return!!o&&/[A-Za-z0-9_$]/.test(o)}function Ec(o){return!!o&&/[A-Za-z_$]/.test(o)}function Nt(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 hr(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&&nn(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&&nn(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(nn(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(nn(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(nn(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&&nn(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 Ec(o){let e=new Set(hr(o)),t=Pt(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&&nn(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(!Oc(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&&Oc(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 Li(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 hr(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&&sn(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 I=y==="{"?"}":"]";n++,p(I);continue}if(y==="."&&n+2<t&&o[n+1]==="."&&o[n+2]==="."){if(n+=3,l(),n<t&&sn(o[n])){let I=c();I&&e.push(I)}continue}if(y===","){n++;continue}if(y==="="){n++;let I=0;for(;n<t;){let C=o[n];if(C==="'"||C==='"'||C==="`"){i(C);continue}if(C==="("||C==="["||C==="{"){I++,n++;continue}if(C===")"||C==="]"||C==="}"){if(I>0){I--,n++;continue}break}if(C===","&&I===0)break;n++}continue}if(sn(y)){let I=c();if(l(),n<t&&o[n]===":"){if(n++,l(),n<t){let C=o[n];if(C==="{"||C==="["){let v=C==="{"?"}":"]";n++,p(v)}else if(sn(C)){let v=c();v&&e.push(v)}}}else I&&e.push(I);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(sn(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&&sn(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 Mc(o){let e=new Set(hr(o)),t=Nt(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&&sn(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 I=t.slice(Math.max(0,g-2),g)==="++"||t.slice(Math.max(0,g-2),g)==="--",C=t.startsWith("++",h)||t.startsWith("--",h);(I||C||c(h))&&e.add(m)},d=(m,g)=>{let f=a(g);if(t[f]!==".")return;let x=a(f+1);if(!Ec(t[x]))return;let{word:A,nextIndex:h}=l(x),y=a(h),I=t.slice(Math.max(0,m-2),m)==="++"||t.slice(Math.max(0,m-2),m)==="--",C=t.startsWith("++",y)||t.startsWith("--",y);A&&(I||C||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&&Ec(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 Di(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)},I=(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}},C=(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=I(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 ge=y[I];if(ge==="\\"){I+=2;continue}if(J>0){ge==="{"?J++:ge==="}"&&J--,I++;continue}if(ge==="$"&&I+1<O&&y[I+1]==="{"){J++,I+=2;continue}if(ge==="`"){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 ge=y[I];if(ge===Y){J--,I++;continue}if(ge==="{"||ge==="["){let we=ge==="{"?"}":"]";I++,J++,I--,J--,I++,Te(we);continue}if(ge==="."&&I+2<O&&y[I+1]==="."&&y[I+2]==="."){if(I+=3,Z(),I<O&&Q(y[I])){let we=ee();we&&w.push(we)}continue}if(ge===","){I++;continue}if(ge==="="){I++;let we=0;for(;I<O;){let Ee=y[I];if(Ee==="'"||Ee==='"'||Ee==="`"){W(Ee);continue}if(Ee==="("||Ee==="["||Ee==="{"){we++,I++;continue}if(Ee===")"||Ee==="]"||Ee==="}"){if(we>0){we--,I++;continue}break}if(Ee===","&&we===0)break;I++}continue}if(Q(ge)){let we=ee();if(Z(),I<O&&y[I]===":"){if(I++,Z(),I<O){let Ee=y[I];if(Ee==="{"||Ee==="["){let Ke=Ee==="{"?"}":"]";I++,Te(Ke)}else if(Q(Ee)){let Ke=ee();Ke&&w.push(Ke)}}}else we&&w.push(we);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 ge=I;return I++,Z(),I<O&&y[I]===","?(I++,!0):(I=ge,!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 ge=y[J];if(ge===" "||ge===" "||ge==="\r"){J--;continue}return ge===`
1100
- `||ge===";"||ge==="{"||ge==="}"}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,ge=ee();if((ge==="var"||ge==="let"||ge==="const")&&I<O&&(y[I]===" "||y[I]===" "||y[I]===`
1101
- `)&&qe(J)){ye();continue}continue}I++}let _e=new Set,tt=[];for(let Y of w)_e.has(Y)||(_e.add(Y),tt.push(Y));return tt},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 ue&&(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,ue=!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,ke=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")}},Oe=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)ke(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");Oe(w[0])}},Pe=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=Pe(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}},me=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)()},Be=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},ot=(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(ot(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)},He=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:ot(M,96)}:{}}]}catch{return[{name:I,type:"unknown",preview:"[unavailable]"}]}});return JSON.stringify({version:1,entries:O})},Qe=y=>{if(typeof structuredClone=="function")try{return structuredClone(y),!0}catch{return!1}try{return JSON.stringify(y),!0}catch{return!1}},st=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=Qe(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:ot(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,ue=w.captureConsole!==void 0?!!w.captureConsole:ne===i;let W=w.allowUnsafeNodeHostAccess===!0;me(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:He(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:st(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):Be(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 $i=4,Mc=16,Di="__ax_rlm_fn_ref__",Ui=16;function Pc(){let o={functionRefKey:Di,maxErrorCauseDepth:Ui},e=`(${Li.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=C(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 xe=b[T];if(xe==="\\"){T+=2;continue}if(Q>0){xe==="{"?Q++:xe==="}"&&Q--,T++;continue}if(xe==="$"&&T+1<k&&b[T+1]==="{"){Q++,T+=2;continue}if(xe==="`"){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},Ce=Z=>{let Q=1;for(;T<k&&Q>0;){if(te(),T>=k)return;let xe=b[T];if(xe===Z){Q--,T++;continue}if(xe==="{"||xe==="["){let ve=xe==="{"?"}":"]";T++,Q++,T--,Q--,T++,Ce(ve);continue}if(xe==="."&&T+2<k&&b[T+1]==="."&&b[T+2]==="."){if(T+=3,te(),T<k&&Y(b[T])){let ve=ne();ve&&w.push(ve)}continue}if(xe===","){T++;continue}if(xe==="="){T++;let ve=0;for(;T<k;){let Me=b[T];if(Me==="'"||Me==='"'||Me==="`"){V(Me);continue}if(Me==="("||Me==="["||Me==="{"){ve++,T++;continue}if(Me===")"||Me==="]"||Me==="}"){if(ve>0){ve--,T++;continue}break}if(Me===","&&ve===0)break;T++}continue}if(Y(xe)){let ve=ne();if(te(),T<k&&b[T]===":"){if(T++,te(),T<k){let Me=b[T];if(Me==="{"||Me==="["){let Ke=Me==="{"?"}":"]";T++,Ce(Ke)}else if(Y(Me)){let Ke=ne();Ke&&w.push(Ke)}}}else ve&&w.push(ve);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 xe=T;return T++,te(),T<k&&b[T]===","?(T++,!0):(T=xe,!1)}T++}return!1},be=()=>{for(;T<k;){if(te(),T>=k)return;let Z=b[T];if(Z==="{"){if(T++,Ce("}"),!Ue())return;continue}if(Z==="["){if(T++,Ce("]"),!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 xe=b[Q];if(xe===" "||xe===" "||xe==="\r"){Q--;continue}return xe===`
1100
+ `||xe===";"||xe==="{"||xe==="}"}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,xe=ne();if((xe==="var"||xe==="let"||xe==="const")&&T<k&&(b[T]===" "||b[T]===" "||b[T]===`
1101
+ `)&&qe(Q)){be();continue}continue}T++}let Ne=new Set,tt=[];for(let Z of w)Ne.has(Z)||(Ne.add(Z),tt.push(Z));return tt},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 fe&&(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)}},Ie=(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),Ce=P.slice(z,ne).map((Ue,be)=>` ${String(z+be+1).padStart(3)}| ${Ue}`).join(`
1105
+ `);Y.push(`Source:
1106
+ ${Ce}`)}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,Ce=te?.name!=null?String(te.name):"Error",Ue=te?.message!=null?String(te.message):oe(z),be=[`${Ce}: ${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,fe=!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,Ce)=>{L.set(T,{resolve:te,reject:Ce}),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,Ce,Ue){return Ce==="then"?(...be)=>(z(),Y(...be)):Ce==="catch"?(...be)=>(z(),V(...be)):Ce==="finally"?(...be)=>(z(),P(...be)):Reflect.get(te,Ce,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}},he=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)()},je=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},ot=(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(ot(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}},le=(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)},He=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=le(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:ot(P,96)}:{}}]}catch{return[{name:T,type:"unknown",preview:"[unavailable]"}]}});return JSON.stringify({version:1,entries:k})},Qe=b=>{if(typeof structuredClone=="function")try{return structuredClone(b),!0}catch{return!1}try{return JSON.stringify(b),!0}catch{return!1}},st=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=le(Y,V.type),z=De(Y,V.type,V.ctor),ne=Qe(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:ot(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,fe=w.captureConsole!==void 0?!!w.captureConsole:ee===i;let V=w.allowUnsafeNodeHostAccess===!0;he(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:He(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:st(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):je(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:Ie(V,T,D?2:0)}):g({type:"result",id:k,error:ae(V)})}finally{Y()}})}var Ui=4,Pc=16,Gi="__ax_rlm_fn_ref__",ji=16;function Fc(){let o={functionRefKey:Gi,maxErrorCauseDepth:ji},e=`(${Di.toString()})(${JSON.stringify(o)});
1111
1111
  `,t="";return e.includes("__name")&&(t+=`var __name=(fn,_n)=>fn;
1112
- `),t?`${t}${e}`:e}var Fc=()=>typeof Worker<"u"&&typeof Blob<"u"&&typeof URL<"u"&&typeof URL.createObjectURL=="function",Fo=()=>typeof process<"u"&&!!process.versions?.node,dm=()=>!!globalThis.Deno?.version?.deno,mm=()=>globalThis.Deno?.version?.deno??null,gm=o=>{let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(o.trim());return e?{major:Number(e[1]),minor:Number(e[2]),patch:Number(e[3])}:null},_c=o=>Number.isFinite(o)?Math.max(1,Math.min(Mc,Math.floor(o))):$i,fm=()=>{if(!Fo())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},hm=o=>{if(o!==void 0)return _c(o);let e=fm();return e?_c(Math.ceil(e/2)):$i},xm=o=>o?.debugNodeWorkerPool?!0:(globalThis.process?.env??{}).AX_RLM_DEBUG_NODE_POOL==="1",Am=o=>{let e=new Set(o),t={};return e.has("network")&&(t.net=!0),Object.keys(t).length>0?t:"none"},ym=(o,e)=>{let t=mm(),n=t?gm(t):null;if(n?n.major>=1:!0)try{return new Worker(o,{type:"module",deno:{permissions:Am(e)}})}catch{}return new Worker(o,{type:"module"})},Nc=(o,e)=>{let t=new Blob([o],{type:"application/javascript"}),n=URL.createObjectURL(t),r=dm()?ym(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},zi=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},qi=class{source;maxSize;idle=[];pendingCreates=0;constructor(e,t){this.source=e,this.maxSize=t}warm(){if(Fo())for(;this.idle.length+this.pendingCreates<this.maxSize;)this.pendingCreates+=1,zi(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(),zi(this.source)}release(e){e.onmessage=null,e.onerror=null,e.terminate(),this.warm()}},Lc=new Map,bm=(o,e)=>`${e}:${o}`,Tm=(o,e)=>{let t=bm(o,e),n=Lc.get(t);if(n)return n;let r=new qi(o,e);return Lc.set(t,r),r},$c=(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),{[Di]: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}},Dc=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}`)}},Gi=o=>!!o&&/[A-Za-z0-9_$]/.test(o),Bi=o=>!!o&&/[A-Za-z_$]/.test(o),Cm=(o,e)=>{let t=new Set(e);for(let m of hr(o))if(t.has(m))return m;let n=Pt(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&&Gi(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&&Bi(m)){let g=s,f=p();if((f==="function"||f==="class")&&u(g)){let x=l(s);if(Bi(n[x])){let A=x+1;for(;A<r&&Gi(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(Bi(n[A])){let h=A+1;for(;h<r&&Gi(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 ji(o){if(o==null||typeof o!="object")return String(o);try{return JSON.stringify(o,null,2)}catch{return String(o)}}function Uc(o,e=Ui,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):ji(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=Uc(p,e,t+1,n):a={name:"Error",message:ji(p)}}catch{a={name:"Error",message:ji(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 Gc(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=Gc(o.cause)),o.data!==void 0&&(t.data=o.data),t}function Im(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 wm(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(Im),bindings:n}}var Bc=(i=>(i.NETWORK="network",i.STORAGE="storage",i.CODE_LOADING="code-loading",i.COMMUNICATION="communication",i.TIMING="timing",i.WORKERS="workers",i))(Bc||{}),bn=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=hm(e?.nodeWorkerPoolSize),this.debugNodeWorkerPool=xm(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=Pc(),n=Fo()?Tm(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}=$c(e,{nextFnId:()=>++c});Dc(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(Gc(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:Uc(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(Fc()){r=Nc(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(Fc()){r=Nc(t,this.permissions),s="browser",r.onmessage=x,r.onerror=b;try{T(r)}catch(R){throw h(),R}return}if(!Fo())throw new Error("No worker runtime available: Web Worker is unavailable in this environment");i||(i=(n?n.acquire():zi(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 _=Cm(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(wm))},async patchGlobals(R,E){if(!R||typeof R!="object"||Array.isArray(R))throw new Error("patchGlobals expects an object");let{serializableGlobals:S,fnMap:_}=$c(R,{nextFnId:()=>++c});if(Dc(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 Rm(o){return new bn(o)}var Hi=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 _c=()=>typeof Worker<"u"&&typeof Blob<"u"&&typeof URL<"u"&&typeof URL.createObjectURL=="function",Fo=()=>typeof process<"u"&&!!process.versions?.node,fm=()=>!!globalThis.Deno?.version?.deno,hm=()=>globalThis.Deno?.version?.deno??null,xm=o=>{let e=/^(\d+)\.(\d+)\.(\d+)$/.exec(o.trim());return e?{major:Number(e[1]),minor:Number(e[2]),patch:Number(e[3])}:null},Nc=o=>Number.isFinite(o)?Math.max(1,Math.min(Pc,Math.floor(o))):Ui,Am=()=>{if(!Fo())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},ym=o=>{if(o!==void 0)return Nc(o);let e=Am();return e?Nc(Math.ceil(e/2)):Ui},bm=o=>o?.debugNodeWorkerPool?!0:(globalThis.process?.env??{}).AX_RLM_DEBUG_NODE_POOL==="1",Im=o=>{let e=new Set(o),t={};return e.has("network")&&(t.net=!0),Object.keys(t).length>0?t:"none"},Cm=(o,e)=>{let t=hm(),n=t?xm(t):null;if(n?n.major>=1:!0)try{return new Worker(o,{type:"module",deno:{permissions:Im(e)}})}catch{}return new Worker(o,{type:"module"})},Lc=(o,e)=>{let t=new Blob([o],{type:"application/javascript"}),n=URL.createObjectURL(t),r=fm()?Cm(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},Hi=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},Ki=class{source;maxSize;idle=[];pendingCreates=0;constructor(e,t){this.source=e,this.maxSize=t}warm(){if(Fo())for(;this.idle.length+this.pendingCreates<this.maxSize;)this.pendingCreates+=1,Hi(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(),Hi(this.source)}release(e){e.onmessage=null,e.onerror=null,e.terminate(),this.warm()}},$c=new Map,Tm=(o,e)=>`${e}:${o}`,wm=(o,e)=>{let t=Tm(o,e),n=$c.get(t);if(n)return n;let r=new Ki(o,e);return $c.set(t,r),r},Dc=(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),{[Gi]: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}},Uc=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}`)}},Bi=o=>!!o&&/[A-Za-z0-9_$]/.test(o),zi=o=>!!o&&/[A-Za-z_$]/.test(o),Rm=(o,e)=>{let t=new Set(e);for(let m of hr(o))if(t.has(m))return m;let n=Nt(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&&Bi(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&&zi(m)){let g=s,f=p();if((f==="function"||f==="class")&&l(g)){let x=u(s);if(zi(n[x])){let A=x+1;for(;A<r&&Bi(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(zi(n[A])){let h=A+1;for(;h<r&&Bi(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]==="]",I=n.startsWith("++",h)||n.startsWith("--",h)||x>0&&(n.slice(x-1,x+1)==="++"||n.slice(x-1,x+1)==="--");if(!y&&(I||d(h)))return f}continue}s++}};function qi(o){if(o==null||typeof o!="object")return String(o);try{return JSON.stringify(o,null,2)}catch{return String(o)}}function Gc(o,e=ji,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):qi(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=Gc(p,e,t+1,n):a={name:"Error",message:qi(p)}}catch{a={name:"Error",message:qi(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 jc(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=jc(o.cause)),o.data!==void 0&&(t.data=o.data),t}function vm(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 Sm(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(vm),bindings:n}}var Bc=(i=>(i.NETWORK="network",i.STORAGE="storage",i.CODE_LOADING="code-loading",i.COMMUNICATION="communication",i.TIMING="timing",i.WORKERS="workers",i))(Bc||{}),In=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=ym(e?.nodeWorkerPoolSize),this.debugNodeWorkerPool=bm(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=Fc(),n=Fo()?wm(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}=Dc(e,{nextFnId:()=>++c});Uc(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(jc(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:Gc($)})})}},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()},I=R=>{R.postMessage({type:"init",globals:l,fnNames:[...p.keys()],permissions:[...this.permissions],allowUnsafeNodeHostAccess:this.allowUnsafeNodeHostAccess,outputMode:this.outputMode,captureConsole:this.captureConsole})};if(_c()){r=Lc(t,this.permissions),s="browser",r.onmessage=x,r.onerror=y;try{I(r)}catch(R){throw h(),R}}let C=async()=>{if(!r){if(a)throw new Error("Session is closed");if(_c()){r=Lc(t,this.permissions),s="browser",r.onmessage=x,r.onerror=y;try{I(r)}catch(R){throw h(),R}return}if(!Fo())throw new Error("No worker runtime available: Web Worker is unavailable in this environment");i||(i=(n?n.acquire():Hi(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{I(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)}}C().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 _=Rm(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(Sm))},async patchGlobals(R,E){if(!R||typeof R!="object"||Array.isArray(R))throw new Error("patchGlobals expects an object");let{serializableGlobals:S,fnMap:_}=Dc(R,{nextFnId:()=>++c});if(Uc(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 km(o){return new In(o)}var Wi=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=Xe(),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 jc(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 zc(o){let t=new TextEncoder().encode(o),n=await fa().subtle.digest("SHA-256",t);return new Uint8Array(n)}async function Ki(){return jc(await zc(Xe()+Math.random().toString(36)))}async function qc(o){return jc(await zc(o))}async function _o(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 Hc(o){let e=new URLSearchParams;for(let[t,n]of Object.entries(o))n!==void 0&&e.set(t,n);return e.toString()}function xr(o){return o.endsWith("/")?o.slice(0,-1):o}function vm(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 Kc(o,e){let t=vm(e);if(t){let a=await _o(t),l=xr(new URL(o).toString().split("?")[0]),c=xr(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 _o(a.url),c=xr(l.resource??""),u=xr(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 Wc(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 _o(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 Tn=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 Wc(e);return this.asMetaCache.set(e,t),t}async ensureAccessToken(e){if(!this.oauth)return null;let{resource:t,issuers:n}=await Kc(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 Ki(),u=await qc(c),p=await Ki(),d=this.oauth.scopes?.join(" "),m=`${s.authorization_endpoint}?${Hc({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 Wi=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 Tn(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 Vi=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 Tn(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 Ji(o){return o.match(/^(\w+Error:\s*.{0,60})/m)?.[1]??o.slice(0,80)}function Jc(o){return hr(o)}function Sm(o){return Ec(o)}var km=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 Qc(o){let e=Pt(o),t=/\b([a-zA-Z_$][a-zA-Z0-9_$]*)\b/g,n=new Set,r=t.exec(e);for(;r!==null;)r[1]&&!km.has(r[1])&&n.add(r[1]),r=t.exec(e);return n}function Yc(o){let e=Qc(o);for(let t of Jc(o))e.delete(t);return e}var Om=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 Em(o){return/\b(final|ask_clarification)\s*\(/.test(o)}function Mm(o){return o.tags.includes("error")?"error":Em(o.code)?"finalize":/\b(llmQuery|listModuleFunctions|getFunctionDefinitions)\s*\(/.test(o.code)?"query":(o.producedVars?.length??0)>0?"transform":"explore"}function Pm(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 Yi(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 Fm(o){o.rank=void 0,o.tags=o.tags.filter(e=>!Om.has(e))}function Lt(o){o.producedVars||(o.producedVars=Sm(o.code)),o.referencedVars||(o.referencedVars=[...Qc(o.code)]),o.stepKind||(o.stepKind=Mm(o)),o.stateDelta||(o.stateDelta=Pm(o)),o.summary||(o.summary=Yi(o))}function Xc(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 _m(o){return/\blistModuleFunctions\s*\(/.test(o.code)?Xc(o.output,/^### Module `([^`]+)`/gm).map(e=>({module:e.key,text:e.text})):[]}function Nm(o){return/\bgetFunctionDefinitions\s*\(/.test(o.code)?Xc(o.output,/^### `([^`]+)`/gm).map(e=>({qualifiedName:e.key,text:e.text})):[]}function Lm(o){let e=Pt(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=_m(o)),o._discoveryFunctionSections||(o._discoveryFunctionSections=Nm(o)),o._directQualifiedCalls||(o._directQualifiedCalls=Lm(o.code))}function $m(o){return yr(o),o._directQualifiedCalls?.find(Boolean)}function No(o){let e=new Map;for(let t of o){let n=t;Lt(n);let r=$m(n);for(let i of n.producedVars??[])e.set(i,{createdTurn:n.turn,stepKind:n.stepKind,source:r,code:n.code});let s=Yc(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 Dm(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 Um(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=Xe(),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 zc(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 qc(o){let t=new TextEncoder().encode(o),n=await Aa().subtle.digest("SHA-256",t);return new Uint8Array(n)}async function Vi(){return zc(await qc(Xe()+Math.random().toString(36)))}async function Hc(o){return zc(await qc(o))}async function _o(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 Kc(o){let e=new URLSearchParams;for(let[t,n]of Object.entries(o))n!==void 0&&e.set(t,n);return e.toString()}function xr(o){return o.endsWith("/")?o.slice(0,-1):o}function Om(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 Wc(o,e){let t=Om(e);if(t){let a=await _o(t),u=xr(new URL(o).toString().split("?")[0]),c=xr(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 _o(a.url),c=xr(u.resource??""),l=xr(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 Vc(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 _o(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 Cn=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 Vc(e);return this.asMetaCache.set(e,t),t}async ensureAccessToken(e){if(!this.oauth)return null;let{resource:t,issuers:n}=await Wc(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 Vi(),l=await Hc(c),p=await Vi(),d=this.oauth.scopes?.join(" "),m=`${s.authorization_endpoint}?${Kc({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 Ji=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 Cn(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 Qi=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 Cn(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 Yi(o){return o.match(/^(\w+Error:\s*.{0,60})/m)?.[1]??o.slice(0,80)}function Qc(o){return hr(o)}function Em(o){return Mc(o)}var Mm=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 Yc(o){let e=Nt(o),t=/\b([a-zA-Z_$][a-zA-Z0-9_$]*)\b/g,n=new Set,r=t.exec(e);for(;r!==null;)r[1]&&!Mm.has(r[1])&&n.add(r[1]),r=t.exec(e);return n}function Xc(o){let e=Yc(o);for(let t of Qc(o))e.delete(t);return e}var Pm=new Set(["dead-end","foundational","pivot","superseded"]);function Pt(o,e=120){let t=o.replace(/\s+/g," ").trim();return t.length<=e?t:`${t.slice(0,e-3)}...`}function Fm(o){return/\b(final|ask_clarification)\s*\(/.test(o)}function _m(o){return o.tags.includes("error")?"error":Fm(o.code)?"finalize":/\b(llmQuery|listModuleFunctions|getFunctionDefinitions)\s*\(/.test(o.code)?"query":(o.producedVars?.length??0)>0?"transform":"explore"}function Nm(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 Zi(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=Pt(o.output||"(no output)"),n=Pt(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 Lm(o){o.rank=void 0,o.tags=o.tags.filter(e=>!Pm.has(e))}function Lt(o){o.producedVars||(o.producedVars=Em(o.code)),o.referencedVars||(o.referencedVars=[...Yc(o.code)]),o.stepKind||(o.stepKind=_m(o)),o.stateDelta||(o.stateDelta=Nm(o)),o.summary||(o.summary=Zi(o))}function Zc(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 $m(o){return/\blistModuleFunctions\s*\(/.test(o.code)?Zc(o.output,/^### Module `([^`]+)`/gm).map(e=>({module:e.key,text:e.text})):[]}function Dm(o){return/\bgetFunctionDefinitions\s*\(/.test(o.code)?Zc(o.output,/^### `([^`]+)`/gm).map(e=>({qualifiedName:e.key,text:e.text})):[]}function Um(o){let e=Nt(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=$m(o)),o._discoveryFunctionSections||(o._discoveryFunctionSections=Dm(o)),o._directQualifiedCalls||(o._directQualifiedCalls=Um(o.code))}function Gm(o){return yr(o),o._directQualifiedCalls?.find(Boolean)}function No(o){let e=new Map;for(let t of o){let n=t;Lt(n);let r=Gm(n);for(let i of n.producedVars??[])e.set(i,{createdTurn:n.turn,stepKind:n.stepKind,source:r,code:n.code});let s=Xc(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 jm(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 Bm(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(`
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 Lo(o,e){if(!e?.pruneUsedDocs||o.length===0)return[...o];let t=Dm(o);return o.flatMap((n,r)=>{let s=Um(n,t[r]??new Set);return s?[s]:[]})}function Gm(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 Bm(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)Lt(a);let s=Gm(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){Lt(o),Lt(e),Fm(o);let t=o.tags.includes("error"),n=e.tags.includes("error");if(t&&!n){o.rank=0,Ar(o,"dead-end");return}if(t&&n){let r=Ji(o.output),s=Ji(e.output);r!==s?(o.rank=3,Ar(o,"pivot")):(o.rank=0,Ar(o,"dead-end"));return}if(!t&&!n){let r=o.producedVars??Jc(o.code);if(r.length===0||o.stepKind==="explore"||o.stepKind==="query")return;let s=Yc(e.code);if(r.filter(a=>s.has(a)).length>0){o.rank=5,Ar(o,"foundational");return}o.stepKind==="transform"&&(o.rank=1,Ar(o,"superseded"));return}}function Ar(o,e){o.tags.includes(e)||o.tags.push(e)}function Qi(o,e){let t=o.output.split(`
1124
+ `),summary:void 0,_discoveryModuleSections:i}}return t}function Lo(o,e){if(!e?.pruneUsedDocs||o.length===0)return[...o];let t=jm(o);return o.flatMap((n,r)=>{let s=Bm(n,t[r]??new Set);return s?[s]:[]})}function zm(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 qm(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)Lt(a);let s=zm(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 Hm(o,e){Lt(o),Lt(e),Lm(o);let t=o.tags.includes("error"),n=e.tags.includes("error");if(t&&!n){o.rank=0,Ar(o,"dead-end");return}if(t&&n){let r=Yi(o.output),s=Yi(e.output);r!==s?(o.rank=3,Ar(o,"pivot")):(o.rank=0,Ar(o,"dead-end"));return}if(!t&&!n){let r=o.producedVars??Qc(o.code);if(r.length===0||o.stepKind==="explore"||o.stepKind==="query")return;let s=Xc(e.code);if(r.filter(a=>s.has(a)).length>0){o.rank=5,Ar(o,"foundational");return}o.stepKind==="transform"&&(o.rank=1,Ar(o,"superseded"));return}}function Ar(o,e){o.tags.includes(e)||o.tags.push(e)}function Xi(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)??Ji(o.output);return`[TOMBSTONE]: Resolved ${Ft(t,96)} in turn ${e.turn}.`}function zm(o){return o.startsWith("[TOMBSTONE]: Resolved ")}var qm=`You are an internal AxAgent tombstone summarizer.
1126
+ `).map(r=>r.trim()).filter(r=>!!r&&!r.startsWith("[")&&!r.startsWith("...")).at(-1)??Yi(o.output);return`[TOMBSTONE]: Resolved ${Pt(t,96)} in turn ${e.turn}.`}function Km(o){return o.startsWith("[TOMBSTONE]: Resolved ")}var Wm=`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.`,Hm=`You are an internal AxAgent checkpoint summarizer.
1133
+ - Keep it roughly 20-40 tokens.`,Vm=`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 Zc(o){let{mem:e,description:t,maxSteps:n,...r}=o??{};return r}function eu(o,e,t){let n=Zc(t);return{...n,description:o,traceLabel:n.traceLabel??e,maxSteps:1}}function tu(o){return{...Zc(o),maxSteps:1}}async function Km(o,e,t,n,r){let s=new Me("errorCode:string, errorOutput:string, resolutionCode:string -> tombstone:string",{...eu(qm,"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)},tu(t));return(typeof i.tombstone=="string"?i.tombstone.trim():String(i.tombstone).trim())||Qi(n,r)}catch{return Qi(n,r)}}function Wm(o){return o.map(e=>{Lt(e),yr(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(`
1154
+ - Be concise and factual, but prefer slightly more detail over losing task-critical specifics.`;function el(o){let{mem:e,description:t,maxSteps:n,...r}=o??{};return r}function tl(o,e,t){let n=el(t);return{...n,description:o,traceLabel:n.traceLabel??e,maxSteps:1}}function nl(o){return{...el(o),maxSteps:1}}async function Jm(o,e,t,n,r){let s=new Pe("errorCode:string, errorOutput:string, resolutionCode:string -> tombstone:string",{...tl(Wm,"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)},nl(t));return(typeof i.tombstone=="string"?i.tombstone.trim():String(i.tombstone).trim())||Xi(n,r)}catch{return Xi(n,r)}}function Qm(o){return o.map(e=>{Lt(e),yr(e);let t=e.actorFieldsOutput.replace(/^Actor fields:\s*/i,"").trim(),n=(e._directQualifiedCalls??[]).join(", ")||"none",r=e.tags.includes("error")?Pt(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: ${Pt(e.output||"(no output)",360)}`,`Actor fields: ${t||"none"}`,`Failure cues: ${r}`,`Code excerpt: ${Pt(e.code||"(no code)",360)}`].join(`
1155
1155
  `)}).join(`
1156
1156
 
1157
- `)}function Vc(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){Lt(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 ${Ft(l.code||"(no code)",140)}`):/\b(listModuleFunctions|getFunctionDefinitions)\s*\(/.test(l.code)&&n.push(`Turn ${l.turn}: ${Ft(l.code||"(no code)",140)}`);let u=Ft(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}: ${Ft(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 nu(o,e,t,n){let r=new Me("turns:string -> checkpointSummary:string",{...eu(Hm,"ax-agent-checkpoint-summary",e)});try{let s=await r.forward(o,{turns:Wm(n)},tu(t));return(typeof s.checkpointSummary=="string"?s.checkpointSummary.trim():String(s.checkpointSummary).trim())||Vc(n)}catch{return Vc(n)}}async function Xi(o,e,t,n,r){let s=o[e];if(!s)return;Lt(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=Qi(a,c)),!(!!t.tombstoning&&!!n&&!a._tombstonePromise&&(!a.tombstone||zm(a.tombstone)))||!n))continue;let p=typeof t.tombstoning=="object"?t.tombstoning:void 0;a._tombstonePromise=Km(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 Vm(o,e){if(e.has(o.turn)&&!o.tags.includes("error")&&o.replayMode!=="full")return"";if(o.tombstone)return`Action ${o.turn}:
1157
+ `)}function Jc(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){Lt(u),yr(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 ${Pt(u.code||"(no code)",140)}`):/\b(listModuleFunctions|getFunctionDefinitions)\s*\(/.test(u.code)&&n.push(`Turn ${u.turn}: ${Pt(u.code||"(no code)",140)}`);let l=Pt(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}: ${Pt(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 rl(o,e,t,n){let r=new Pe("turns:string -> checkpointSummary:string",{...tl(Vm,"ax-agent-checkpoint-summary",e)});try{let s=await r.forward(o,{turns:Qm(n)},nl(t));return(typeof s.checkpointSummary=="string"?s.checkpointSummary.trim():String(s.checkpointSummary).trim())||Jc(n)}catch{return Jc(n)}}async function ea(o,e,t,n,r){let s=o[e];if(!s)return;Lt(s);let i=s.tags.includes("error");if(t.hindsightEvaluation&&o.length>=2){let a=o[o.length-2];Hm(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=Xi(a,c)),!(!!t.tombstoning&&!!n&&!a._tombstonePromise&&(!a.tombstone||Km(a.tombstone)))||!n))continue;let p=typeof t.tombstoning=="object"?t.tombstoning:void 0;a._tombstonePromise=Jm(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 Ym(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 Lt(o),`Action ${o.turn}:
1160
- ${o.summary??Yi(o)}`;default:return`Action ${o.turn}:
1160
+ ${o.summary??Zi(o)}`;default:return`Action ${o.turn}:
1161
1161
  \`\`\`javascript
1162
1162
  ${o.code}
1163
1163
  \`\`\`
1164
1164
  Result:
1165
- ${o.output}${o.actorFieldsOutput}`}}function br(o,e){let t=Lo(o,{pruneUsedDocs:e.pruneUsedDocs});if(t.length===0)return{promptFacingEntries:t,checkpointEntries:[],historyText:"",historyChars:0};Bm(t,e);let n=t.filter(i=>!i.tags.includes("error")&&i.replayMode!=="full"),r=new Set(e.checkpointTurns??[]),s=t.map(i=>Vm(i,r)).filter(Boolean).join(`
1165
+ ${o.output}${o.actorFieldsOutput}`}}function ta(o,e){let t=Lo(o,{pruneUsedDocs:e.pruneUsedDocs});if(t.length===0)return{promptFacingEntries:t,checkpointEntries:[],historyText:"",historyChars:0};qm(t,e);let n=t.filter(i=>!i.tags.includes("error")&&i.replayMode!=="full"),r=new Set(e.checkpointTurns??[]),s=t.map(i=>Ym(i,r)).filter(Boolean).join(`
1166
1166
 
1167
- `);return{promptFacingEntries:t,checkpointEntries:n,historyText:s,historyChars:s.length}}function ru(o,e){let t=br(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 ol(o,e){let t=ta(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 ou(o,e){let t=Lo(o,{pruneUsedDocs:e?.pruneUsedDocs}),n=new Set(e?.checkpointTurns??[]),r=t.map(i=>{if(n.has(i.turn)&&!i.tags.includes("error"))return"";Lt(i);let a=i.tombstone??i.summary??Yi(i);return`- Action ${i.turn}: ${a}`}).filter(Boolean).join(`
1172
+ `)}function sl(o,e){let t=Lo(o,{pruneUsedDocs:e?.pruneUsedDocs}),n=new Set(e?.checkpointTurns??[]),r=t.map(i=>{if(n.has(i.turn)&&!i.tags.includes("error"))return"";Lt(i);let a=i.tombstone??i.summary??Zi(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 su(o,e=[]){return`(() => {
1176
+ `)}function il(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 iu(){return"(() => JSON.stringify(Object.getOwnPropertyNames(globalThis).sort()))()"}function Jm(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 Qm(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 Zi(o){if(o.enum)return o.enum.map(n=>`"${n}"`).join(" | ");let e=Jm(o);if(e.length===0)return"unknown";if(Qm(e))return"any";let t=[...new Set(e)].map(n=>{if(n==="array"){let r=o.items?Zi(o.items):"unknown";return r.includes(" | ")?`(${r})[]`:`${r}[]`}return n==="object"?o.properties&&Object.keys(o.properties).length>0?lu(o):"object":n});return t.length>1?t.join(" | "):t[0]??"unknown"}function lu(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=Zi(l),u=s&&!r.has(a)?"?":"";return`${a}${u}: ${c}`});return o?.additionalProperties===!0&&i.push("[key: string]: unknown"),`{ ${i.join(", ")} }`}function Ym(o){return o?Zi(o):"unknown"}function au(o){let e=lu(o.parameters,{respectRequired:!0}),t=o.returns?`: Promise<${Ym(o.returns)}>`:"";return`- \`${o.qualifiedName}(args: ${e})${t}\``}function ea(o,e,t,n){let r=n.promptLevel??"detailed",s=e.length>0?e.map(m=>{let g=gn(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=ht("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=>au({qualifiedName:`${c}.${m.name}`,parameters:m.parameters})).join(`
1299
- `),hasFunctions:!u&&l.length>0,functionsList:l.map(m=>au({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 al(){return"(() => JSON.stringify(Object.getOwnPropertyNames(globalThis).sort()))()"}function Xm(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 Zm(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 na(o){if(o.enum)return o.enum.map(n=>`"${n}"`).join(" | ");let e=Xm(o);if(e.length===0)return"unknown";if(Zm(e))return"any";let t=[...new Set(e)].map(n=>{if(n==="array"){let r=o.items?na(o.items):"unknown";return r.includes(" | ")?`(${r})[]`:`${r}[]`}return n==="object"?o.properties&&Object.keys(o.properties).length>0?cl(o):"object":n});return t.length>1?t.join(" | "):t[0]??"unknown"}function cl(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=na(u),l=s&&!r.has(a)?"?":"";return`${a}${l}: ${c}`});return o?.additionalProperties===!0&&i.push("[key: string]: unknown"),`{ ${i.join(", ")} }`}function eg(o){return o?na(o):"unknown"}function ul(o){let e=cl(o.parameters,{respectRequired:!0}),t=o.returns?`: Promise<${eg(o.returns)}>`:"";return`- \`${o.qualifiedName}(args: ${e})${t}\``}function ra(o,e,t,n){let r=n.promptLevel??"detailed",s=e.length>0?e.map(m=>{let g=hn(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=ht("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=>ul({qualifiedName:`${c}.${m.name}`,parameters:m.parameters})).join(`
1299
+ `),hasFunctions:!l&&u.length>0,functionsList:u.map(m=>ul({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 ta(o,e){let t=e.length>0?e.map(r=>{let s=gn(r.type),i=r.isOptional?"optional":"required";return`- \`${r.name}\` (${s}, ${i})`}).join(`
1305
+ ${o}`:d}function oa(o,e){let t=e.length>0?e.map(r=>{let s=hn(r.type),i=r.isOptional?"optional":"required";return`- \`${r.name}\` (${s}, ${i})`}).join(`
1306
1306
  `):"(none)",n=ht("rlm/responder.md",{contextVarSummary:t}).trim();return o?`${n}
1307
1307
 
1308
- ${o}`:n}var Tr="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"},Xm=()=>({promptTokens:0,completionTokens:0,totalTokens:0}),jt=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}},Cr=(o,e)=>{let t=jt(o),n=jt(e);return{promptTokens:t.promptTokens+n.promptTokens,completionTokens:t.completionTokens+n.completionTokens,totalTokens:t.totalTokens+n.totalTokens}},cu=(o,e)=>{let t=jt(o),n=jt(e);return jt({promptTokens:Math.max(0,t.promptTokens-n.promptTokens),completionTokens:Math.max(0,t.completionTokens-n.completionTokens),totalTokens:Math.max(0,t.totalTokens-n.totalTokens)})},$o=o=>(o??[]).reduce((e,t)=>Cr(e,{promptTokens:t.tokens?.promptTokens??0,completionTokens:t.tokens?.completionTokens??0,totalTokens:t.tokens?.totalTokens??0}),Xm()),_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 Do=(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=>Do(d,e)),u=jt(o.localUsage),p=c.reduce((d,m)=>Cr(d,m.cumulativeUsage),u);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:u,cumulativeUsage:p,children:c}},na=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:jt(o.localUsage),rootCumulativeUsage:jt(o.cumulativeUsage),topExpensiveNodes:u.sort((d,m)=>m.totalTokens-d.totalTokens).slice(0,5)}},ra=(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
- `)},uu=(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)uu(n,e)},Zm=o=>{let e=[],t=n=>{e.push(n);for(let r of n.children)t(r)};return t(o),e},pu=o=>{let e=o.prediction.recursiveTrace,t=o.prediction.recursiveStats;if(!e||!t)return;let n=[],r=[];uu(e,r);let s=Zm(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 Cn=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]:""}),du=(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 br="ax-agent-recursive-slots-v1",pe={shared:"root.actor.shared",root:"root.actor.root",recursive:"root.actor.recursive",terminal:"root.actor.terminal",responder:"root.responder"},tg=()=>({promptTokens:0,completionTokens:0,totalTokens:0}),Bt=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}},Ir=(o,e)=>{let t=Bt(o),n=Bt(e);return{promptTokens:t.promptTokens+n.promptTokens,completionTokens:t.completionTokens+n.completionTokens,totalTokens:t.totalTokens+n.totalTokens}},ll=(o,e)=>{let t=Bt(o),n=Bt(e);return Bt({promptTokens:Math.max(0,t.promptTokens-n.promptTokens),completionTokens:Math.max(0,t.completionTokens-n.completionTokens),totalTokens:Math.max(0,t.totalTokens-n.totalTokens)})},$o=o=>(o??[]).reduce((e,t)=>Ir(e,{promptTokens:t.tokens?.promptTokens??0,completionTokens:t.tokens?.completionTokens??0,totalTokens:t.tokens?.totalTokens??0}),tg()),Ft=(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 Do=(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=>Do(d,e)),l=Bt(o.localUsage),p=c.reduce((d,m)=>Ir(d,m.cumulativeUsage),l);return{nodeId:o.nodeId,parentId:o.parentId,depth:o.depth,role:o.role,taskDigest:Ft(o.taskDigest,r),contextDigest:Ft(o.contextDigest,s),completionType:o.completionType,turnCount:o.turnCount,childCount:c.length,actorTurns:o.actorTurns.map(d=>({turn:d.turn,code:Ft(d.code,t)??"",output:Ft(d.output,n)??"",isError:d.isError,thought:Ft(d.thought,n)})),functionCalls:o.functionCalls.slice(0,a).map(d=>({qualifiedName:d.qualifiedName,name:d.name,error:Ft(d.error,n)})),toolErrors:o.toolErrors.slice(0,i).map(d=>Ft(d,n)??""),localUsage:l,cumulativeUsage:p,children:c}},sa=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:Bt(o.localUsage),rootCumulativeUsage:Bt(o.cumulativeUsage),topExpensiveNodes:l.sort((d,m)=>m.totalTokens-d.totalTokens).slice(0,5)}},ia=(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
+ `)},pl=(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)pl(n,e)},ng=o=>{let e=[],t=n=>{e.push(n);for(let r of n.children)t(r)};return t(o),e},dl=o=>{let e=o.prediction.recursiveTrace,t=o.prediction.recursiveStats;if(!e||!t)return;let n=[],r=[];pl(e,r);let s=ng(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 pe.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 pe.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 pe.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 pe.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 Tn=o=>({[pe.shared]:o?.trim()??"",[pe.root]:"At the root, decide whether to solve directly or decompose. Delegate only when it clearly improves accuracy or reduces risk.",[pe.recursive]:"Within recursive branches, avoid redundant delegation. Narrow context, keep sibling tasks distinct, and finish locally when further fan-out is unnecessary.",[pe.terminal]:"At terminal depth, answer directly from the available context. Do not spend extra turns or imitate deeper delegation.",[pe.responder]:""}),ml=(o,e)=>{let t=[e[pe.shared]?.trim(),o==="root"?e[pe.root]?.trim():o==="recursive"?e[pe.recursive]?.trim():e[pe.terminal]?.trim()].filter(n=>!!n);if(t.length!==0)return t.join(`
1310
1310
 
1311
- `)};var pt=class extends Error{question;clarification;stateSnapshot;stateErrorMessage;constructor(e,t){let n=Eu(e);super(n.question),this.name="AxAgentClarificationError",this.question=n.question,this.clarification=n,this.stateSnapshot=t?.state?In(t.state):void 0,this.stateErrorMessage=t?.stateError}getState(){if(this.stateErrorMessage)throw new Error(this.stateErrorMessage);return this.stateSnapshot?In(this.stateSnapshot):void 0}},gu=8,oa=5e3,eg=8,fu=8,Uo=2,tg=1200,Go="agents",ng=2,rg=14e3,og=1e4,sg=4,ig=2,ag=3,lg=8e3,cg=3,ug=3,pg=100,dg=new Set(["console","Math","JSON","Object","Array","String","Number","Boolean","Date","Promise","Reflect","Map","Set","WeakMap","WeakSet","Symbol","Intl","URL","URLSearchParams"]),mg=/^[$A-Z_a-z][$0-9A-Z_a-z]*$/,gg=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"]),sa="listModuleFunctions",ia="getFunctionDefinitions",fg="AI service is required to use llmQuery(...) in AxAgent.test(). Pass options.ai or configure ai on the agent.",zo="[The JavaScript runtime was restarted; all global state was lost and must be recreated if needed.]",uI=new Ne(`
1311
+ `)};var pt=class extends Error{question;clarification;stateSnapshot;stateErrorMessage;constructor(e,t){let n=Fl(e);super(n.question),this.name="AxAgentClarificationError",this.question=n.question,this.clarification=n,this.stateSnapshot=t?.state?wn(t.state):void 0,this.stateErrorMessage=t?.stateError}getState(){if(this.stateErrorMessage)throw new Error(this.stateErrorMessage);return this.stateSnapshot?wn(this.stateSnapshot):void 0}},fl=8,aa=5e3,rg=8,hl=8,Uo=2,og=1200,Go="agents",sg=2,ig=100,xl='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 }]',ag=/^[$A-Z_a-z][$0-9A-Z_a-z]*$/,ug=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"]),ua="listModuleFunctions",ca="getFunctionDefinitions",cg="AI service is required to use llmQuery(...) in AxAgent.test(). Pass options.ai or configure ai on the agent.",zo="[The JavaScript runtime was restarted; all global state was lost and must be recreated if needed.]",aT=new _e(`
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 Tr="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
- `),hg=new Ne(`
1329
+ `),lg=new _e(`
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 Tr="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
- `),xg=new Ne(`
1349
+ `),pg=new _e(`
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 Ag(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 yg(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 bg(o){let e=`
1353
+ `);function dg(o){return"train"in o?{train:o.train,validation:o.validation}:{train:o}}function ut(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=>ut(e))}if(typeof o=="object")try{return JSON.parse(JSON.stringify(o))}catch{return String(o)}return String(o)}}function mg(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 gg(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 Tg(o){let{criteria:e,description:t,randomizeOrder:n,...r}=o;return{...r,maxSteps:1}}function Cg(o){let e=o.toLowerCase();return e==="excellent"?1:e==="good"?.8:e==="acceptable"?.5:e==="poor"?.2:e==="unacceptable"?0:.5}function hu(o,e){return e.qualifiedName===o||e.name===o||e.qualifiedName.endsWith(`.${o}`)}function Ig(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=>hu(a,l))).length;n*=.5+.5*(i/r.length)}return(e.forbiddenActions??[]).some(i=>t.functionCalls.some(a=>hu(i,a)))&&(n*=.2),Math.max(0,Math.min(1,n))}function wg(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 wn=class extends Error{constructor(t){super(`AxAgent protocol completion: ${t}`);this.type=t;this.name="AxAgentProtocolCompletionSignal"}};function xu(o){return{finalFunction:(...r)=>{o("final",r)},askClarificationFunction:(...r)=>{o("ask_clarification",r)},protocol:{final:(...r)=>{throw o("final",r),new wn("final")},askClarification:(...r)=>{throw o("ask_clarification",r),new wn("ask_clarification")}}}}function Rg(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 Au(o,e){if(typeof o!="string"||o.trim().length===0)throw new Error(`${e} must be a non-empty string`);return o.trim()}function vg(o){if(o)return{escalatedModel:Au(o.escalatedModel,"actorModelPolicy.escalatedModel"),...o.baseModel!==void 0?{baseModel:Au(o.baseModel,"actorModelPolicy.baseModel")}:{},escalateAtPromptChars:Math.max(1,o.escalateAtPromptChars??rg),escalateAtPromptCharsWhenCheckpointed:Math.max(1,o.escalateAtPromptCharsWhenCheckpointed??og),recentErrorWindowTurns:Math.max(1,o.recentErrorWindowTurns??sg),recentErrorThreshold:Math.max(1,o.recentErrorThreshold??ig),discoveryStallTurns:Math.max(1,o.discoveryStallTurns??ag),deescalateBelowPromptChars:Math.max(0,o.deescalateBelowPromptChars??lg),stableTurnsBeforeDeescalate:Math.max(1,o.stableTurnsBeforeDeescalate??cg),minEscalatedTurns:Math.max(0,o.minEscalatedTurns??ug)}}function yu(o){let e=o?.preset??"full",t=Sg(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:ng,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 Sg(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 ku(o){let e=Pt(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&&!dg.has(s)&&t.add(`${s}.${i}`),r=n.exec(e)}return[...t]}function kg(o){return o.tags.includes("error")||!/\b(listModuleFunctions|getFunctionDefinitions)\s*\(/.test(o.code)?!1:ku(o.code).length===0}function Og(o,e){return o.slice(-e.recentErrorWindowTurns).filter(r=>r.tags.includes("error")).length>=e.recentErrorThreshold}function Eg(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")||ku(r.code).length>0||!kg(r))break;if(t+=1,t>=e.discoveryStallTurns)return!0}return!1}function Mg(o,e,t,n){return{promptFacingChars:t,checkpointActive:n,recentErrorTrigger:Og(e,o),discoveryStallTrigger:Eg(e,o)}}function Pg(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 Fg(){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 la(o){let e=o.children.map(r=>la(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 qo=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=Go;functionDiscoveryEnabled=!1;runtimeUsageInstructions="";enforceIncrementalConsoleTurns=!1;activeAbortControllers=new Set;_stopRequested=!1;state;stateError;runtimeBootstrapContext=void 0;llmQueryBudgetState;recursiveInstructionSlots=Cn();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",Go,this.agentModuleNamespace,...this.functionDiscoveryEnabled?[sa,ia]:[]])}_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??Uo;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??Uo;return Math.max(0,e)>0?"root":void 0}_applyRecursiveActorInstruction(){let e=this._getRecursiveActorRole();if(!e||!this.actorProgram)return;let t=du(e,this.recursiveInstructionSlots),n=[this.baseActorDefinition.trim(),t?.trim()].filter(r=>!!r).join(`
1368
+ ${t}`:e}function fg(o){let{criteria:e,description:t,randomizeOrder:n,...r}=o;return{...r,maxSteps:1}}function hg(o){let e=o.toLowerCase();return e==="excellent"?1:e==="good"?.8:e==="acceptable"?.5:e==="poor"?.2:e==="unacceptable"?0:.5}function Al(o,e){return e.qualifiedName===o||e.name===o||e.qualifiedName.endsWith(`.${o}`)}function xg(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=>Al(a,u))).length;n*=.5+.5*(i/r.length)}return(e.forbiddenActions??[]).some(i=>t.functionCalls.some(a=>Al(i,a)))&&(n*=.2),Math.max(0,Math.min(1,n))}function Ag(o,e){let t=new Set(o.map(i=>i.id)),n=t.has(pe.shared),r=[pe.shared,pe.root,pe.recursive,pe.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(pe.responder)?[pe.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 Rn=class extends Error{constructor(t){super(`AxAgent protocol completion: ${t}`);this.type=t;this.name="AxAgentProtocolCompletionSignal"}};function yl(o){return{finalFunction:(...r)=>{o("final",r)},askClarificationFunction:(...r)=>{o("ask_clarification",r)},protocol:{final:(...r)=>{throw o("final",r),new Rn("final")},askClarification:(...r)=>{throw o("ask_clarification",r),new Rn("ask_clarification")}}}}function yg(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 bg(o,e){if(typeof o!="string"||o.trim().length===0)throw new Error(`${e} must be a non-empty string`);return o.trim()}function bl(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 Ig(o){if(o!==void 0){if(!Array.isArray(o))throw new Error(xl);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(xl);let r=bl(n.abovePromptChars,`actorModelPolicy[${t}].abovePromptChars`),s=bl(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:bg(n.model,`actorModelPolicy[${t}].model`),...r!==void 0?{abovePromptChars:r}:{},...s!==void 0?{aboveErrorTurns:s}:{}}})}}function Il(o){let e=o?.preset??"full",t=Cg(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:sg,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 Cg(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 El(o){return o?.consecutiveErrorTurns??0}function Ml(){return{consecutiveErrorTurns:0}}function Tg(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 Ml()}function wg(o,e){return{consecutiveErrorTurns:e?El(o)+1:0}}function Rg(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}function vg(){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 pa(o){let e=o.children.map(r=>pa(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 qo=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=Go;functionDiscoveryEnabled=!1;runtimeUsageInstructions="";enforceIncrementalConsoleTurns=!1;activeAbortControllers=new Set;_stopRequested=!1;state;stateError;runtimeBootstrapContext=void 0;llmQueryBudgetState;recursiveInstructionSlots=Tn();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",Go,this.agentModuleNamespace,...this.functionDiscoveryEnabled?[ua,ca]:[]])}_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??Uo;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??Uo;return Math.max(0,e)>0?"root":void 0}_applyRecursiveActorInstruction(){let e=this._getRecursiveActorRole();if(!e||!this.actorProgram)return;let t=ml(e,this.recursiveInstructionSlots),n=[this.baseActorDefinition.trim(),t?.trim()].filter(r=>!!r).join(`
1369
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 bn,this.runtimeUsageInstructions=this.runtime.getUsageInstructions(),this.enforceIncrementalConsoleTurns=df(this.runtimeUsageInstructions);let E=r??n?.namespace??Go;if(this.agentModuleNamespace=xf(E,{normalize:r===void 0}),new Set(["inputs","llmQuery","final","ask_clarification","inspect_runtime",sa,ia]).has(this.agentModuleNamespace))throw new Error(`Agent module namespace "${this.agentModuleNamespace}" is reserved`);let _=this._reservedAgentFunctionNamespaces(),L=aa(i.functions?.local,_),P=aa(i.functions?.shared,_),F=aa(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 Me(s,xe);let ve=this.program.getSignature().getInputFields(),$=cf(l,ve,tg);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:ue,...X}=v??{};this.actorDescription=K,this.actorPromptLevel=h??"detailed",this.actorModelPolicy=vg(b),this.actorForwardOptions=ne,this.recursiveInstructionSlots=Cn(K),this.responderDescription=ue,this.responderForwardOptions=X,this.judgeOptions=k?{...k}:void 0,this.inputUpdateCallback=R;let z=this.agents;for(let oe of z??[]){let me=oe.getFunction().name;this.program.register(oe,me)}n&&(this.func={name:Fu(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 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 se=i.agents?.shared??[],Pe=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[me,Ie]of oe.examples.entries())if(!Ie.code.trim())throw new Error(`Agent function "${oe.name}" example at index ${me} must define non-empty code`)}}if(this._validateConfiguredSignature(this.program.getSignature()),this._validateAgentFunctionNamespaces(be),ke.length>0&&z){let oe=ve.filter(me=>ke.includes(me.name));for(let me of z){if(!(me instanceof o))continue;let Ie=new Set(me.getExcludedSharedFields()),Be=oe.filter($e=>!Ie.has($e.name));Be.length!==0&&me._extendForSharedFields(Be,this.rlmConfig.contextFields)}}if(se.length>0&&z)for(let oe of z)oe instanceof o&&oe._extendForSharedAgents(se);if(Oe.length>0&&z){let oe=ve.filter(me=>Oe.includes(me.name));for(let me of z){if(!(me instanceof o))continue;let Ie=new Set(me.getExcludedSharedFields()),Be=oe.filter($e=>!Ie.has($e.name));Be.length!==0&&me._extendForGlobalSharedFields(Be,this.rlmConfig.contextFields)}}if(Pe.length>0&&z)for(let oe of z)oe instanceof o&&oe._extendForGlobalSharedAgents(Pe);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=de().addInputFields(i).addInputFields(s).input("contextMetadata",de.string("Metadata about pre-loaded context variables (type and size)")).input("actionLog",de.string("Chronological trace of code executions or actions and their outputs so far")).output("javascriptCode",de.code("JavaScript code to execute in runtime session"));l.length>0&&(u=u.addOutputFields(l));let p=u.build(),d=de().addInputFields(i).input("contextData",de.json("Context data to help synthesize the final answer.")).addOutputFields(c).build(),m=this.rlmConfig.maxSubAgentCalls??gu,g=this.rlmConfig.maxTurns??fu,f=this.recursionForwardOptions?.maxDepth??Uo,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=yu(this.rlmConfig.contextPolicy),v=ea(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=ta(this.responderDescription,r);this.actorProgram?(this.actorProgram.setSignature(p),this.actorProgram.setDescription(v)):this.actorProgram=new Me(p,{...this._genOptions,description:v}),this.responderProgram?(this.responderProgram.setSignature(d),this.responderProgram.setDescription(k)):this.responderProgram=new Me(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?In(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?In(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=$o(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=$o(this.getUsage());e.localUsage=Cr(e.localUsage,cu(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=Cr(t.localUsage,e))}async optimize(e,t){let n=Ag(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=wg(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(pg,n.train.length*4))),m=await new tn({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})=>pu({componentId:A,prediction:f,example:x})}),g=m.optimizedProgram;return m.optimizedProgram&&this._supportsRecursiveActorSlotOptimization()&&(g=new wt({...m.optimizedProgram,artifactFormatVersion:1,instructionSchema:Tr}),m.optimizedProgram=g),t?.apply!==!1&&g&&this.applyOptimization(g),m}_createOptimizationProgram(e,t){return{getId:()=>this.getId(),setId:n=>this.setId(n),getSignature:()=>xg,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=bg(t.criteria),r=new Me(hg),s=t.description?.trim();r.setInstruction(s?`${n}
1370
+ `);this.actorProgram.setDescription(n),this.actorProgram.setInstruction(n)}_setRecursiveInstructionSlot(e,t){if(e===pe.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:I,actorOptions:C,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 In,this.runtimeUsageInstructions=this.runtime.getUsageInstructions(),this.enforceIncrementalConsoleTurns=of(this.runtimeUsageInstructions);let E=r??n?.namespace??Go;if(this.agentModuleNamespace=lf(E,{normalize:r===void 0}),new Set(["inputs","llmQuery","final","ask_clarification","inspect_runtime",ua,ca]).has(this.agentModuleNamespace))throw new Error(`Agent module namespace "${this.agentModuleNamespace}" is reserved`);let _=this._reservedAgentFunctionNamespaces(),$=la(i.functions?.local,_),M=la(i.functions?.shared,_),F=la(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 Ie=this.program.getSignature().getInputFields(),L=tf(u,Ie,og);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=I;let{description:K,...ee}=C??{},{description:fe,...q}=v??{};this.actorDescription=K,this.actorPromptLevel=h??"detailed",this.actorModelPolicy=Ig(y),this.actorForwardOptions=ee,this.recursiveInstructionSlots=Tn(K),this.responderDescription=fe,this.responderForwardOptions=q,this.judgeOptions=O?{...O}:void 0,this.inputUpdateCallback=R;let B=this.agents;for(let X of B??[]){let he=X.getFunction().name;this.program.register(X,he)}n&&(this.func={name:Ll(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[he,we]of X.examples.entries())if(!we.code.trim())throw new Error(`Agent function "${X.name}" example at index ${he} must define non-empty code`)}}if(this._validateConfiguredSignature(this.program.getSignature()),this._validateAgentFunctionNamespaces(J),ke.length>0&&B){let X=Ie.filter(he=>ke.includes(he.name));for(let he of B){if(!(he instanceof o))continue;let we=new Set(he.getExcludedSharedFields()),je=X.filter($e=>!we.has($e.name));je.length!==0&&he._extendForSharedFields(je,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=Ie.filter(he=>Oe.includes(he.name));for(let he of B){if(!(he instanceof o))continue;let we=new Set(he.getExcludedSharedFields()),je=X.filter($e=>!we.has($e.name));je.length!==0&&he._extendForGlobalSharedFields(je,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=ge().addInputFields(i).addInputFields(s).input("contextMetadata",ge.string("Metadata about pre-loaded context variables (type and size)")).input("actionLog",ge.string("Chronological trace of code executions or actions and their outputs so far")).output("javascriptCode",ge.code("JavaScript code to execute in runtime session"));u.length>0&&(l=l.addOutputFields(u));let p=l.build(),d=ge().addInputFields(i).input("contextData",ge.json("Context data to help synthesize the final answer.")).addOutputFields(c).build(),m=this.rlmConfig.maxSubAgentCalls??fl,g=this.rlmConfig.maxTurns??hl,f=this.recursionForwardOptions?.maxDepth??Uo,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 I=[...y].sort((R,E)=>R.localeCompare(E)).map(R=>({namespace:R,selectionCriteria:this.agentFunctionModuleMetadata.get(R)?.selectionCriteria})),C=Il(this.rlmConfig.contextPolicy),v=ra(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:I,agents:A,agentFunctions:h});this.baseActorDefinition=v;let O=oa(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?wn(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?wn(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===pe.responder?this.responderProgram.getInstruction():this.recursiveInstructionSlots[e],setInstruction:n=>{this._setRecursiveInstructionSlot(e,n)},getSignature:()=>({getDescription:()=>t})}}}_listOptimizationTargetDescriptors(){return this._supportsRecursiveActorSlotOptimization()?[this._createRecursiveOptimizationProxy(pe.shared,"Shared recursive-actor guidance applied to every advanced recursive AxAgent actor invocation."),this._createRecursiveOptimizationProxy(pe.root,"Root-only recursive-actor guidance for deciding whether to answer directly or decompose into subtasks."),this._createRecursiveOptimizationProxy(pe.recursive,"Mid-tree recursive-actor guidance for branch orchestration, selective delegation, and efficient synthesis."),this._createRecursiveOptimizationProxy(pe.terminal,"Terminal-depth recursive-actor guidance for direct answers when deeper recursion is no longer available."),{id:pe.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=$o(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:Ft(Array.isArray(e)?e.filter(s=>s.role==="user").map(s=>s.values):e),contextDigest:Ft(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=$o(this.getUsage());e.localUsage=Ir(e.localUsage,ll(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=Ir(t.localUsage,e))}async optimize(e,t){let n=dg(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=Ag(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(ig,n.train.length*4))),m=await new on({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})=>dl({componentId:A,prediction:f,example:x})}),g=m.optimizedProgram;return m.optimizedProgram&&this._supportsRecursiveActorSlotOptimization()&&(g=new wt({...m.optimizedProgram,artifactFormatVersion:1,instructionSchema:br}),m.optimizedProgram=g),t?.apply!==!1&&g&&this.applyOptimization(g),m}_createOptimizationProgram(e,t){return{getId:()=>this.getId(),setId:n=>this.setId(n),getSignature:()=>pg,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=gg(t.criteria),r=new Pe(lg),s=t.description?.trim();r.setInstruction(s?`${n}
1371
1371
 
1372
1372
  Additional Judge Guidance:
1373
- ${s}`:n);let i=Tg(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 Ig(Cg(m.quality),c,u)}}async _forwardForEvaluation(e,t,n){let r=this.state?In(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=Ct(i.signal,n?.abortSignal);this.activeAbortControllers.add(i);let l=this._ensureLlmQueryBudgetState(),c=this.recursiveEvalContext,u=this.currentRecursiveTraceNodeId,p=this._supportsRecursiveActorSlotOptimization()?Fg():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?Do(la(p.rootNode)):void 0,F=P?na(P):void 0,N=P&&F?ra(P,F):void 0;return{completionType:"ask_clarification",clarification:Eu(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?Do(la(p.rootNode)):void 0,_=S?na(S):void 0,L=S&&_?ra(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?In(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=sf(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=uf(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??gu,m=u.maxRuntimeChars??oa,g=Math.max(1,u.maxBatchedLlmQueryConcurrency??eg),f=this.recursionForwardOptions?.maxDepth??Uo,x=Math.max(0,f),A=yu(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=de().input("task",de.string("Task for recursive analysis")).output("answer",de.string("Answer from recursive analysis")).build(),P=de().input("task",de.string("Task for recursive analysis")).input("context",de.json("Optional context for the recursive task")).output("answer",de.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 Me(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 Fe("rlm-llm-query",r.reason?String(r.reason):"Aborted");if(!e)throw new Error(fg);let ee=M,Z=ye=>{if(ye==null)return"";if(typeof ye=="string")return ct(ye,m);try{return ct(JSON.stringify(ye),m)}catch{return ct(String(ye),m)}},Te=async(ye,qe,_e=r)=>{if(_e?.aborted)throw new Fe("rlm-llm-query",_e.reason?String(_e.reason):"Aborted");let tt=qe===void 0?void 0:typeof qe=="string"?ct(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,ge=we=>`[ERROR] ${we instanceof Error?we.message:String(we)}. Retry with a simpler query, handle in JS, or proceed with data already gathered.`;for(let we=0;we<Y;we++)try{if(!N){let Ke=j(),zt=await Ke.forward(e,{task:ye,...tt!==void 0?{context:tt}:{}},{...S,...v,abortSignal:_e,debug:s});return this._recordEphemeralRecursiveUsage($o(Ke.getUsage())),Z(zt.answer)}let Ee=await(()=>{let Ke=B(G());return b.add(Ke),Ke.runtimeBootstrapContext=tt,Ke.forward(e,{task:ye},{...S,...v,abortSignal:_e,debug:s}).finally(()=>{b.delete(Ke)})})();return Z(Ee.answer)}catch(Ee){if(Ee instanceof Fe||Ee instanceof pt)throw Ee;if(J=Ee,!Yg(Ee)||we>=Y-1)return ge(Ee);let Ke=Math.min(6e4,1e3*Math.pow(2,we));await new Promise((zt,Ho)=>{let qt=!1,Ht,vr=()=>{_e&&Ht&&_e.removeEventListener("abort",Ht)},Ce=setTimeout(()=>{qt||(qt=!0,vr(),zt())},Ke);if(_e){if(Ht=()=>{qt||(qt=!0,clearTimeout(Ce),vr(),Ho(new Fe("rlm-llm-query-retry-backoff",_e.reason?String(_e.reason):"Aborted during retry backoff")))},_e.aborted){Ht();return}_e.addEventListener("abort",Ht,{once:!0})}})}return ge(J)};if(Array.isArray(M)){let ye=new AbortController,qe=Ct(r,ye.signal)??ye.signal,_e,tt=()=>{te()};qe.addEventListener("abort",tt,{once:!0});try{return await pf(M,g,async Y=>{try{return await Te(Y.query,Y.context,qe)}catch(J){if(J instanceof Fe||J instanceof pt)throw(J instanceof pt||!_e)&&(_e=J),ye.signal.aborted||ye.abort(J instanceof pt?"Child clarification":J.message),_e;return`[ERROR] ${J instanceof Error?J.message:String(J)}`}},qe)}finally{qe.removeEventListener("abort",tt)}}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",Go,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)),ue={};for(let M of ne)ue[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)ue[M]=t.currentInputs[M]},z=[...K],ie=[...K,...ne],ke=new Set(ie),Oe=this.runtimeBootstrapContext;this.runtimeBootstrapContext=void 0;let se=$g(Oe,ke),Pe=new Set(Object.keys(se)),ae=l??[],Ae,be,oe=M=>typeof M.inspectGlobals=="function"?M:void 0,me=async()=>{try{let M=await Ae.execute(iu(),{signal:r,reservedNames:ie});if(typeof M!="string")return[];let q=JSON.parse(M);return Array.isArray(q)?q.filter(ee=>typeof ee=="string"&&!Pe.has(ee)):[]}catch{return[]}},Ie=async()=>(be||(be=await me()),be),Be=async()=>{try{let M=oe(Ae);if(M?.inspectGlobals)return await M.inspectGlobals({signal:r,reservedNames:ie});let q=await Ie(),ee=su(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=Zg(M);if(!ee)return ef(M,q);let Z=No(ae);return ca(ee,Z,q)},ot=A.stateInspection.enabled?async()=>$e(await Be()):void 0,Se=()=>(be=void 0,p.createSession({...ue,inputs:$,...se,llmQuery:V,final:a.finalFunction,ask_clarification:a.askClarificationFunction,...ot?{inspect_runtime:ot}:{},...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?zg(se,{...le(),budgetRemaining:Math.max(0,d-h.used),budgetTotal:d}):void 0,He=async()=>{if(!i.payload)for(let M=0;M<3&&!i.payload;M++)await new Promise(q=>{setTimeout(q,0)})},Qe=async()=>{if(!A.stateSummary.enabled)return;let M=await Be();return $e(M,ze())||"(no user variables)"},st=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:Hg(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 Be();return $e(M,ze())||"(no user variables)"},captureRuntimeStateSummary:Qe,exportRuntimeState:async()=>{let q=await y(Ae).snapshotGlobals({signal:r,reservedNames:ie}),ee=No(ae);return{version:1,runtimeBindings:q.bindings,runtimeEntries:q.entries,actionLogEntries:qg(ae),provenance:Kg(ee)}},restoreRuntimeState:async M=>{let q=w(M);return await st(Ae).patchGlobals(q.runtimeBindings,{signal:r}),q},syncRuntimeInputsToSession:async()=>{X();let M=async q=>{await st(q).patchGlobals({inputs:{...$},...ue},{signal:r})};try{await M(Ae)}catch(q){if(r?.aborted)throw new Fe("rlm-session",r.reason??"Aborted");if(q instanceof Error&&(q.name==="AbortError"||q.message.startsWith("Aborted")))throw q;if(Ru(q)){Ae=Se(),await M(Ae);return}throw new Error(`Failed to sync runtime inputs: ${jo(q,m)}`)}},executeActorCode:async M=>{let q={result:void 0,output:Bo(void 0,m),isError:!1};try{let ee=await Ae.execute(M,{signal:r,reservedNames:z});return i.payload||Iu(M)&&wu(ee)&&(await He(),i.payload)?q:{result:ee,output:Bo(ee,m),isError:!1}}catch(ee){if(ee instanceof wn||i.payload)return q;if(ee instanceof pt||ee instanceof Fe)throw ee;if(r?.aborted)throw new Fe("rlm-session",r.reason??"Aborted");if(ee instanceof Error&&(ee.name==="AbortError"||ee.message.startsWith("Aborted")))throw ee;if(rf(ee))return{result:void 0,output:ct(`${zo}
1376
- ${jo(ee,m)}`,m),isError:!0};if(Ru(ee))try{Ae=Se(),i.payload=void 0;let Z=await Ae.execute(M,{signal:r,reservedNames:z});return{result:Z,output:ct(`${zo}
1377
- ${Bo(Z,m)}`,m),isError:!1}}catch(Z){if(Z instanceof pt||Z instanceof Fe)throw Z;return{result:void 0,output:ct(`${zo}
1378
- ${jo(Z,m)}`,m),isError:!0}}return{result:void 0,output:ct(jo(ee,m),m),isError:!0}}},executeTestCode:async M=>{try{let q=await Ae.execute(M,{signal:r,reservedNames:z});if(Iu(M)&&wu(q)&&await He(),i.payload)return i.payload;let ee=Bo(q,m);if(of(ee))throw new Error(ee);return ee}catch(q){if((q instanceof wn||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=xu((p,d)=>{a.payload=bu(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!==Tr)throw new Error(`AxAgent.applyOptimization(): unsupported instruction schema "${t}".`);if(t===Tr&&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===Tr){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=Cn(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=Cn(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=Cn(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??fu,u=this._createRuntimeInputState(t);u.recomputeTurnInputs(!1);let p={payload:void 0},d=xu((U,G)=>{p.payload=bu(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=Rg(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=()=>Lo(m,{pruneUsedDocs:v}),P=()=>ru(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=br(m,{actionReplay:_,recentFullActions:f.effectiveContextConfig.recentFullActions,pruneUsedDocs:v}),G=f.effectiveContextConfig.checkpoints.triggerChars;if(!G||U.historyChars<=G){k=void 0;return}let te=br(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 nu(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=Jg(No(m),Vg(G.provenance));g=B?ca(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=Wg(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=br(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,ke=Mg(this.actorModelPolicy,m,ie,!!k?.summary);R=Pg(R,this.actorModelPolicy,ke);let Oe=R.escalated?this.actorModelPolicy.escalatedModel:this.actorModelPolicy.baseModel??h.model;j=Oe!==void 0?{...h,model:Oe}:{...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=yg(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&&($=`
1373
+ ${s}`:n);let i=fg(t);return async({example:a,prediction:u})=>{let c=a,l=u,p={taskInput:ut(c.input),criteria:c.criteria,expectedOutput:c.expectedOutput,expectedActions:c.expectedActions,forbiddenActions:c.forbiddenActions,metadata:c.metadata},d={completionType:l.completionType,clarification:ut(l.clarification),finalOutput:ut(l.output),actionLog:l.actionLog,functionCalls:ut(l.functionCalls),toolErrors:l.toolErrors,turnCount:l.turnCount,usage:ut(l.usage??[]),recursiveTrace:ut(l.recursiveTrace),recursiveStats:ut(l.recursiveStats)},m=await r.forward(e,{...p,...d},i);return xg(hg(m.quality),c,l)}}async _forwardForEvaluation(e,t,n){let r=this.state?wn(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=Ct(i.signal,n?.abortSignal);this.activeAbortControllers.add(i);let u=this._ensureLlmQueryBudgetState(),c=this.recursiveEvalContext,l=this.currentRecursiveTraceNodeId,p=this._supportsRecursiveActorSlotOptimization()?vg():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:I,actionLog:C,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?Do(pa(p.rootNode)):void 0,F=M?sa(M):void 0,N=M&&F?ia(M,F):void 0;return{completionType:"ask_clarification",clarification:Fl(y.args[0]),actionLog:C,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?Do(pa(p.rootNode)):void 0,_=S?sa(S):void 0,$=S&&_?ia(S,_):void 0;return{completionType:"final",output:{...E,...I},actionLog:C,functionCalls:g,toolErrors:O,turnCount:v,recursiveTrace:S,recursiveStats:_,recursiveSummary:$}}finally{this.state=r?wn(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(`
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],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[I,C]of Object.entries(s))this.rlmConfig.contextFields.includes(I)?A[I]=C:u.has(I)||(h[I]=C);if(x){for(let I of this.rlmConfig.contextFields)if(!g.has(I)&&(!(I in A)||A[I]===void 0))throw new Error(`RLM contextField "${I}" is missing from input values`)}let y={};for(let[I,C]of this.contextPromptConfigByField){if(u.has(I)||!(I in A))continue;let v=Xg(A[I],C);v!==void 0&&(y[I]=v)}l=A,p=h,d=y;for(let I of Object.keys(c))delete c[I];for(let I of a)I in s&&(c[I]=s[I]),I in l&&(c[I]=l[I]);m=nf(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??fl,m=l.maxRuntimeChars??aa,g=Math.max(1,l.maxBatchedLlmQueryConcurrency??rg),f=this.recursionForwardOptions?.maxDepth??Uo,x=Math.max(0,f),A=Il(l.contextPolicy),h=this.llmQueryBudgetState??{used:0},y=new Set,I=Math.floor(d*.8),{maxDepth:C,...v}=this.recursionForwardOptions??{},{description:O,mem:R,sessionId:E,...S}=n??{},_={...this.recursionForwardOptions??{},maxDepth:Math.max(0,x-1)},$=ge().input("task",ge.string("Task for recursive analysis")).output("answer",ge.string("Answer from recursive analysis")).build(),M=ge().input("task",ge.string("Task for recursive analysis")).input("context",ge.json("Optional context for the recursive task")).output("answer",ge.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 Fe("rlm-llm-query",r.reason?String(r.reason):"Aborted");if(!e)throw new Error(cg);let ne=P,te=be=>{if(be==null)return"";if(typeof be=="string")return ct(be,m);try{return ct(JSON.stringify(be),m)}catch{return ct(String(be),m)}},Ce=async(be,qe,Ne=r)=>{if(Ne?.aborted)throw new Fe("rlm-llm-query",Ne.reason?String(Ne.reason):"Aborted");let tt=qe===void 0?void 0:typeof qe=="string"?ct(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,xe=ve=>`[ERROR] ${ve instanceof Error?ve.message:String(ve)}. Retry with a simpler query, handle in JS, or proceed with data already gathered.`;for(let ve=0;ve<Z;ve++)try{if(!N){let Ke=j(),zt=await Ke.forward(e,{task:be,...tt!==void 0?{context:tt}:{}},{...S,...v,abortSignal:Ne,debug:s});return this._recordEphemeralRecursiveUsage($o(Ke.getUsage())),te(zt.answer)}let Me=await(()=>{let Ke=U(W());return y.add(Ke),Ke.runtimeBootstrapContext=tt,Ke.forward(e,{task:be},{...S,...v,abortSignal:Ne,debug:s}).finally(()=>{y.delete(Ke)})})();return te(Me.answer)}catch(Me){if(Me instanceof Fe||Me instanceof pt)throw Me;if(Q=Me,!qg(Me)||ve>=Z-1)return xe(Me);let Ke=Math.min(6e4,1e3*Math.pow(2,ve));await new Promise((zt,Ho)=>{let qt=!1,Ht,Rr=()=>{Ne&&Ht&&Ne.removeEventListener("abort",Ht)},Te=setTimeout(()=>{qt||(qt=!0,Rr(),zt())},Ke);if(Ne){if(Ht=()=>{qt||(qt=!0,clearTimeout(Te),Rr(),Ho(new Fe("rlm-llm-query-retry-backoff",Ne.reason?String(Ne.reason):"Aborted during retry backoff")))},Ne.aborted){Ht();return}Ne.addEventListener("abort",Ht,{once:!0})}})}return xe(Q)};if(Array.isArray(P)){let be=new AbortController,qe=Ct(r,be.signal)??be.signal,Ne,tt=()=>{ae()};qe.addEventListener("abort",tt,{once:!0});try{return await rf(P,g,async Z=>{try{return await Ce(Z.query,Z.context,qe)}catch(Q){if(Q instanceof Fe||Q instanceof pt)throw(Q instanceof pt||!Ne)&&(Ne=Q),be.signal.aborted||be.abort(Q instanceof pt?"Child clarification":Q.message),Ne;return`[ERROR] ${Q instanceof Error?Q.message:String(Q)}`}},qe)}finally{qe.removeEventListener("abort",tt)}}let Ue=await Ce(ne,z);return h.used===I?`${Ue}
1375
+ [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),Ie=[...new Set(this.agentFunctions.map(P=>P.namespace??"utils"))],L={...t.currentInputs},K=new Set(["inputs","llmQuery",Go,this.agentModuleNamespace,"final","ask_clarification",...Ie,...A.stateInspection.enabled?["inspect_runtime"]:[],...Object.keys(oe)]),ee=[...new Set([...Object.keys(L),...t.signatureInputFieldNames])].filter(P=>!K.has(P)),fe={};for(let P of ee)fe[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)fe[P]=t.currentInputs[P]},B=[...K],ue=[...K,...ee],ke=new Set(ue),Oe=this.runtimeBootstrapContext;this.runtimeBootstrapContext=void 0;let ce=Eg(Oe,ke),Re=new Set(Object.keys(ce)),se=u??[],de,J,X=P=>typeof P.inspectGlobals=="function"?P:void 0,he=async()=>{try{let P=await de.execute(al(),{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 he()),J),je=async()=>{try{let P=X(de);if(P?.inspectGlobals)return await P.inspectGlobals({signal:r,reservedNames:ue});let z=await we(),ne=il(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=Kg(P);if(!ne)return Wg(P,z);let te=No(se);return da(ne,te,z)},ot=A.stateInspection.enabled?async()=>$e(await je()):void 0,Ee=()=>(J=void 0,p.createSession({...fe,inputs:L,...ce,llmQuery:re,final:a.finalFunction,ask_clarification:a.askClarificationFunction,...ot?{inspect_runtime:ot}:{},...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}),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(ce).length>0?Lg(ce,{...le(),budgetRemaining:Math.max(0,d-h.used),budgetTotal:d}):void 0,He=async()=>{if(!i.payload)for(let P=0;P<3&&!i.payload;P++)await new Promise(z=>{setTimeout(z,0)})},Qe=async()=>{if(!A.stateSummary.enabled)return;let P=await je();return $e(P,ze())||"(no user variables)"},st=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[Ce,Ue]of Object.entries(P.runtimeBindings??{}))z.has(Ce)||(ne[Ce]=Ue);let te=(P.runtimeEntries??[]).filter(Ce=>!z.has(Ce.name));return{runtimeBindings:ne,runtimeEntries:te,actionLogEntries:Dg(P.actionLogEntries),checkpointState:P.checkpointState,provenance:{...P.provenance??{}},actorModelState:Tg(P.actorModelState)}};return{effectiveContextConfig:A,bootstrapContextSummary:De,applyBootstrapRuntimeContext:async()=>{if(Object.keys(ce).length===0||!A.stateSummary.enabled)return;let P=await je();return $e(P,ze())||"(no user variables)"},captureRuntimeStateSummary:Qe,exportRuntimeState:async()=>{let z=await b(de).snapshotGlobals({signal:r,reservedNames:ue}),ne=No(se);return{version:1,runtimeBindings:z.bindings,runtimeEntries:z.entries,actionLogEntries:$g(se),provenance:Ug(ne)}},restoreRuntimeState:async P=>{let z=w(P);return await st(de).patchGlobals(z.runtimeBindings,{signal:r}),z},syncRuntimeInputsToSession:async()=>{q();let P=async z=>{await st(z).patchGlobals({inputs:{...L},...fe},{signal:r})};try{await P(de)}catch(z){if(r?.aborted)throw new Fe("rlm-session",r.reason??"Aborted");if(z instanceof Error&&(z.name==="AbortError"||z.message.startsWith("Aborted")))throw z;if(Sl(z)){de=Ee(),await P(de);return}throw new Error(`Failed to sync runtime inputs: ${Bo(z,m)}`)}},executeActorCode:async P=>{let z={result:void 0,output:jo(void 0,m),isError:!1};try{let ne=await de.execute(P,{signal:r,reservedNames:B});return i.payload||Rl(P)&&vl(ne)&&(await He(),i.payload)?z:{result:ne,output:jo(ne,m),isError:!1}}catch(ne){if(ne instanceof Rn||i.payload)return z;if(ne instanceof pt||ne instanceof Fe)throw ne;if(r?.aborted)throw new Fe("rlm-session",r.reason??"Aborted");if(ne instanceof Error&&(ne.name==="AbortError"||ne.message.startsWith("Aborted")))throw ne;if(Qg(ne))return{result:void 0,output:ct(`${zo}
1376
+ ${Bo(ne,m)}`,m),isError:!0};if(Sl(ne))try{de=Ee(),i.payload=void 0;let te=await de.execute(P,{signal:r,reservedNames:B});return{result:te,output:ct(`${zo}
1377
+ ${jo(te,m)}`,m),isError:!1}}catch(te){if(te instanceof pt||te instanceof Fe)throw te;return{result:void 0,output:ct(`${zo}
1378
+ ${Bo(te,m)}`,m),isError:!0}}return{result:void 0,output:ct(Bo(ne,m),m),isError:!0}}},executeTestCode:async P=>{try{let z=await de.execute(P,{signal:r,reservedNames:B});if(Rl(P)&&vl(z)&&await He(),i.payload)return i.payload;let ne=jo(z,m);if(Yg(ne))throw new Error(ne);return ne}catch(z){if((z instanceof Rn||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=yl((p,d)=>{a.payload=Cl(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 _e(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!==br)throw new Error(`AxAgent.applyOptimization(): unsupported instruction schema "${t}".`);if(t===br&&n!==void 0&&n!==1)throw new Error(`AxAgent.applyOptimization(): unsupported recursive artifact format version "${String(n)}".`);let r=e?.instructionMap??{},s=[pe.shared,pe.root,pe.recursive,pe.terminal].some(i=>typeof r[i]=="string");if(t===br){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=Tn(this.actorDescription);for(let a of[pe.shared,pe.root,pe.recursive,pe.terminal])typeof r[a]=="string"&&(this.recursiveInstructionSlots[a]=r[a]??"");this._applyRecursiveActorInstruction();let i=r[pe.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=Tn(this.actorDescription);let i=r["root.actor"]??e?.instruction;typeof i=="string"&&(this.recursiveInstructionSlots[pe.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=Tn(this.actorDescription);for(let a of[pe.shared,pe.root,pe.recursive,pe.terminal])typeof r[a]=="string"&&(this.recursiveInstructionSlots[a]=r[a]??"");this._applyRecursiveActorInstruction();let i=r[pe.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??hl,l=this._createRuntimeInputState(t);l.recomputeTurnInputs(!1);let p={payload:void 0},d=yl((re,oe)=>{p.payload=Cl(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,Ie]of Object.entries(re))l.signatureInputFieldNames.has(oe)&&(l.currentInputs[oe]=Ie)}},h={...this._genOptions,...this.actorForwardOptions,...n,debug:u,abortSignal:r},y={},I=f.effectiveContextConfig.stateInspection.enabled?f.effectiveContextConfig.stateInspection.contextThreshold:void 0,C=yg(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,$=()=>Lo(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,Ie)=>ol($(),{actionReplay:re,recentFullActions:f.effectiveContextConfig.recentFullActions,restoreNotice:E,delegatedContextSummary:x,stateSummary:g,checkpointSummary:oe,checkpointTurns:Ie})||"(no actions yet)",G=()=>N(f.effectiveContextConfig.actionReplay,O?.summary,O?.turns),W=()=>{!this.actorModelPolicy&&!R||(R=Ml())},U=re=>{!this.actorModelPolicy&&!R||(R=wg(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,Ie=N(_),L=await F(Ie);if(!oe||L<=oe)return re(void 0);let ee=ta(m,{actionReplay:S,recentFullActions:f.effectiveContextConfig.recentFullActions,pruneUsedDocs:v}).checkpointEntries;if(ee.length===0)return re(void 0);let fe=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===fe?!1:re({fingerprint:fe,turns:ee.map(q=>q.turn),summary:await rl(e,f.effectiveContextConfig.summarizerOptions,C,ee)})};try{if(this.state){let oe=await f.restoreRuntimeState(this.state),Ie=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=Bg(No(m),jg(oe.provenance));g=Ie?da(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=Gg(oe.runtimeEntries,{includeLiveRuntimeState:Ie})}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;I&&K>I&&(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 fe=ee?await F(L):K,q=h;if(this.actorModelPolicy){let J=Rg(this.actorModelPolicy,fe,El(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=mg(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(`
1379
+ `);J&&(Oe=`
1380
1380
  Actor fields:
1381
- ${z}`)}if(p.payload=void 0,this.enforceIncrementalConsoleTurns){let z=mf(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 Xi(m,m.length-1,f.effectiveContextConfig,e,C),await F();continue}}this.inputUpdateCallback&&await f.syncRuntimeInputsToSession();let K,ne,ue;try{let z=await f.executeActorCode(xe);K=z.result,ne=z.output,ue=z.isError}catch(z){throw(z instanceof pt||z instanceof Fe)&&(i?.push({turn:m.length+1,code:xe,output:Tu(z,a.maxRuntimeChars??oa),isError:z instanceof Fe,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:Tu(z,a.maxRuntimeChars??oa),isError:z instanceof Fe,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:ue?["error"]:[]}),i?.push({turn:X,code:xe,output:ne,isError:ue,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:ue,thought:typeof V.thought=="string"?V.thought:void 0}),await Xi(m,m.length-1,f.effectiveContextConfig,e,C),ue||(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:[ou(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=Ct(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 pt(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=Ct(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 pt(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[sa]=async p=>{let d=Su(p,"modules");return Cf(d,l,c)},i[ia]=async p=>{let d=Su(p,"functions");return If(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?hf(e,this._parentSharedFields):e}};function bu(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:[Ou(e[0])]}}return{type:o,args:e}}function da(o){return!!o&&typeof o=="object"&&!Array.isArray(o)&&Object.getPrototypeOf(o)===Object.prototype}function wr(o){return typeof o=="string"&&o.trim().length>0}function _g(o){if(wr(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(!wr(o.label))throw new Error("ask_clarification() choice objects require a non-empty label");if(o.value!==void 0&&!wr(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 Ou(o){if(wr(o))return o;if(!da(o))throw new Error("ask_clarification() requires a non-empty string or an object payload");if(!wr(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(_g)}:{}}}function Eu(o){let e=Ou(o);return typeof e=="string"?{question:e,type:"text"}:{...e,type:e.type??(e.choices&&e.choices.length>0?"single_choice":"text")}}function Ng(o){return typeof structuredClone=="function"?structuredClone(o):JSON.parse(JSON.stringify(o))}function Lg(o,e){return!e.has(o)&&!gg.has(o)&&mg.test(o)}function $g(o,e){if(o===void 0)return{};let t={context:o};if(!da(o))return t;for(let[n,r]of Object.entries(o))Lg(n,e)&&(t[n]=r);return t}function Dg(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 Ir(o){if(o===null)return"null";if(o===void 0)return"undefined";let e=typeof o;if(e==="string")return JSON.stringify(ma(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 Ug(o,e,t){if(e==="array"&&Array.isArray(o))return`[${o.slice(0,3).map(r=>Ir(r)).join(", ")}${o.length>3?", ...":""}]`;if(e==="map"&&o instanceof Map){let n=[...o.entries()].slice(0,3).map(([r,s])=>`${Ir(r)} => ${Ir(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=>Ir(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 Ir(o)}function Gg(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 Bg(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=Dg(t),r=Gg(t,n.type),s=Ug(t,n.type,n.ctor),i;n.type==="array"&&Array.isArray(t)&&(i=Bg(t));let a=s?ma(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 zg(o,e){let t=jg(o),n=ca(t,new Map,e),r=e?.budgetRemaining!==void 0&&e?.budgetTotal!==void 0?`
1381
+ ${J}`)}if(p.payload=void 0,this.enforceIncrementalConsoleTurns){let J=sf(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 ea(m,m.length-1,f.effectiveContextConfig,e,C),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 pt||J instanceof Fe)&&(i?.push({turn:m.length+1,code:ue,output:Tl(J,a.maxRuntimeChars??aa),isError:J instanceof Fe,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:Tl(J,a.maxRuntimeChars??aa),isError:J instanceof Fe,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 ea(m,m.length-1,f.effectiveContextConfig,e,C),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:[sl(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=Ct(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 pt(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=Ct(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 pt(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:ut(u),result:ut(c)}),c}catch(c){throw i?.({qualifiedName:s??e.name,name:e.name,arguments:ut(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:ut(p),result:ut(d)}),d}catch(d){throw a?.({qualifiedName:i??e.name,name:e.name,arguments:ut(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[ua]=async p=>{let d=Ol(p,"modules");return ff(d,u,c)},i[ca]=async p=>{let d=Ol(p,"functions");return hf(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 Cl(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:[Pl(e[0])]}}return{type:o,args:e}}function fa(o){return!!o&&typeof o=="object"&&!Array.isArray(o)&&Object.getPrototypeOf(o)===Object.prototype}function Tr(o){return typeof o=="string"&&o.trim().length>0}function Sg(o){if(Tr(o))return o;if(!fa(o))throw new Error("ask_clarification() choice entries must be non-empty strings or objects with a non-empty label");if(!Tr(o.label))throw new Error("ask_clarification() choice objects require a non-empty label");if(o.value!==void 0&&!Tr(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 Pl(o){if(Tr(o))return o;if(!fa(o))throw new Error("ask_clarification() requires a non-empty string or an object payload");if(!Tr(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(Sg)}:{}}}function Fl(o){let e=Pl(o);return typeof e=="string"?{question:e,type:"text"}:{...e,type:e.type??(e.choices&&e.choices.length>0?"single_choice":"text")}}function kg(o){return typeof structuredClone=="function"?structuredClone(o):JSON.parse(JSON.stringify(o))}function Og(o,e){return!e.has(o)&&!ug.has(o)&&ag.test(o)}function Eg(o,e){if(o===void 0)return{};let t={context:o};if(!fa(o))return t;for(let[n,r]of Object.entries(o))Og(n,e)&&(t[n]=r);return t}function Mg(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 Cr(o){if(o===null)return"null";if(o===void 0)return"undefined";let e=typeof o;if(e==="string")return JSON.stringify(ha(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 Pg(o,e,t){if(e==="array"&&Array.isArray(o))return`[${o.slice(0,3).map(r=>Cr(r)).join(", ")}${o.length>3?", ...":""}]`;if(e==="map"&&o instanceof Map){let n=[...o.entries()].slice(0,3).map(([r,s])=>`${Cr(r)} => ${Cr(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=>Cr(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 Cr(o)}function Fg(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 _g(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 Ng(o){return Object.entries(o).map(([e,t])=>{try{let n=Mg(t),r=Fg(t,n.type),s=Pg(t,n.type,n.ctor),i;n.type==="array"&&Array.isArray(t)&&(i=_g(t));let a=s?ha(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 Lg(o,e){let t=Ng(o),n=da(t,new Map,e),r=e?.budgetRemaining!==void 0&&e?.budgetTotal!==void 0?`
1382
1382
  Sub-query budget: ${e.budgetRemaining}/${e.budgetTotal} remaining`:"";return`Explore with code \u2014 do not assume values from these previews.
1383
- ${n}${r}`}function Tu(o,e){return o instanceof pt?ct(`[CLARIFICATION] ${o.question}`,e):ct(`[ABORTED] ${o.message}`,e)}function In(o){return Ng(o)}function qg(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 Hg(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 Kg(o){return Object.fromEntries([...o.entries()].map(([e,t])=>[e,{...t}]))}function Wg(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 Vg(o){return new Map(Object.entries(o??{}).map(([e,t])=>[e,{...t}]))}function Jg(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 Qg(o,e){let t=typeof o=="string"?Ne.create(o):o,{ai:n,judgeAI:r,agentIdentity:s,...i}=e;return new qo({ai:n,judgeAI:r,agentIdentity:s,signature:t},i)}function Yg(o){return o instanceof it&&o.status>=500&&o.status<600?!0:o instanceof Ze||o instanceof mt}function ct(o,e){return o.length<=e?o:`${o.slice(0,e)}
1385
- ...[truncated ${o.length-e} chars]`}function ma(o,e){return e<=0?"":o.length<=e?o:e<=3?o.slice(0,e):`${o.slice(0,e-3)}...`}function Xg(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 Zg(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(Xg):void 0}catch{return}}function Mu(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(ma(a,c)),i=n;break}return s.join(`
1387
- `)}function ef(o,e){let t=o.split(`
1388
- `).map(n=>n.trim()).filter(Boolean);return Mu(t,e)}function Cu(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 tf(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 nf(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 ca(o,e,t){let n=[...o].sort((r,s)=>{let i=Cu(r,e.get(r.name));return Cu(s,e.get(s.name))-i||r.name.localeCompare(s.name)}).map(r=>{let s=r.preview?` = ${r.preview}`:"",i=nf(e.get(r.name)),a="restorable"in r&&r.restorable===!1?" [snapshot only]":"";return`${r.name}: ${tf(r)}${s}${i}${a}`});return n.length===0?"(no user variables)":Mu(n,t)}function Bo(o,e){if(o===void 0)return"(no output)";if(typeof o=="string")return ct(o||"(no output)",e);try{return ct(JSON.stringify(o,null,2),e)}catch{return ct(String(o),e)}}function jo(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(`
1383
+ ${n}${r}`}function Tl(o,e){return o instanceof pt?ct(`[CLARIFICATION] ${o.question}`,e):ct(`[ABORTED] ${o.message}`,e)}function wn(o){return kg(o)}function $g(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 Dg(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 Ug(o){return Object.fromEntries([...o.entries()].map(([e,t])=>[e,{...t}]))}function Gg(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 jg(o){return new Map(Object.entries(o??{}).map(([e,t])=>[e,{...t}]))}function Bg(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 zg(o,e){let t=typeof o=="string"?_e.create(o):o,{ai:n,judgeAI:r,agentIdentity:s,...i}=e;return new qo({ai:n,judgeAI:r,agentIdentity:s,signature:t},i)}function qg(o){return o instanceof it&&o.status>=500&&o.status<600?!0:o instanceof Ze||o instanceof mt}function ct(o,e){return o.length<=e?o:`${o.slice(0,e)}
1385
+ ...[truncated ${o.length-e} chars]`}function ha(o,e){return e<=0?"":o.length<=e?o:e<=3?o.slice(0,e):`${o.slice(0,e-3)}...`}function Hg(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 Kg(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(Hg):void 0}catch{return}}function _l(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 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(ha(a,c)),i=n;break}return s.join(`
1387
+ `)}function Wg(o,e){let t=o.split(`
1388
+ `).map(n=>n.trim()).filter(Boolean);return _l(t,e)}function wl(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 Vg(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 Jg(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 da(o,e,t){let n=[...o].sort((r,s)=>{let i=wl(r,e.get(r.name));return wl(s,e.get(s.name))-i||r.name.localeCompare(s.name)}).map(r=>{let s=r.preview?` = ${r.preview}`:"",i=Jg(e.get(r.name)),a="restorable"in r&&r.restorable===!1?" [snapshot only]":"";return`${r.name}: ${Vg(r)}${s}${i}${a}`});return n.length===0?"(no user variables)":_l(n,t)}function jo(o,e){if(o===void 0)return"(no output)";if(typeof o=="string")return ct(o||"(no output)",e);try{return ct(JSON.stringify(o,null,2),e)}catch{return ct(String(o),e)}}function Bo(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(`
1389
1389
  `)};s.push(`Caused by: ${i(t.cause,1)}`)}return ct(s.join(`
1390
- `),e)}function Iu(o){let e=Pt(o);return/\bfinal\s*\(/.test(e)||/\bask_clarification\s*\(/.test(e)}function wu(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 Ru(o){return o instanceof Error&&o.message==="Session is closed"}function rf(o){return o instanceof Error&&o.message==="Execution timed out"}function of(o){return o.startsWith("[ERROR]")||o.startsWith(zo)?!0:/^(AggregateError|Error|EvalError|RangeError|ReferenceError|SyntaxError|TypeError|URIError): /.test(o)}function sf(o,e){if(e.kind==="threshold")return lf(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 af(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 lf(o){if(typeof o=="string")return o.length;try{return JSON.stringify(o).length}catch{return String(o).length}}function cf(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 uf(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":af(r,a,e?.inlinedFields?.has(n)===!0);t.push(`- ${n}: type=${s}, size=${i}, prompt=${l}`)}return t.join(`
1391
- `)}async function pf(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 df(o){return o.includes("console.log")}function mf(o){let e=Pt(o),t=/\bfinal\s*\(/.test(e),n=/\bask_clarification\s*\(/.test(e),r=Number(t)+Number(n),s=gf(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 gf(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=ff(o,a);t.push({closeParenIndex:l})}return t}function ff(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 hf(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 xf(o,e){let t=o.trim(),r=e?.normalize??!0?Fu(t):t;if(!r)throw new Error("Agent module namespace must contain letters or numbers");return r}function vu(o){return Array.isArray(o.functions)}function aa(o,e){if(!o||o.length===0)return{functions:[],moduleMetadata:[]};let t=o.every(a=>vu(a)),n=o.every(a=>!vu(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 Su(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 ua(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 Af(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 Rr(o){if(o.enum)return o.enum.map(n=>`"${n}"`).join(" | ");let e=ua(o);if(e.length===0)return"unknown";if(Af(e))return"any";let t=[...new Set(e)].map(n=>{if(n==="array"){let r=o.items?Rr(o.items):"unknown";return r.includes(" | ")?`(${r})[]`:`${r}[]`}return n==="object"?o.properties&&Object.keys(o.properties).length>0?Pu(o):"object":n});return t.length>1?t.join(" | "):t[0]??"unknown"}function Pu(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=Rr(l),u=s&&!r.has(a)?"?":"";return`${a}${u}: ${c}`});return o.additionalProperties===!0&&i.push("[key: string]: unknown"),`{ ${i.join(", ")} }`}function yf(o){let e=Pu(o.parameters,{respectRequired:!0}),t=o.returns?`: Promise<${Rr(o.returns)}>`:"";return`- \`${o.qualifiedName}(args: ${e})${t}\``}function pa(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:Rr(i),required:t?n.has(s):void 0,description:l});let c=ua(i);if(c.includes("object")&&i.properties&&r.push(...pa(i,a,!1)),c.includes("array")&&i.items){let u=i.items.description?.trim(),p=`${a}[]`;u&&r.push({name:p,type:Rr(i.items),description:u}),ua(i.items).includes("object")&&i.items.properties&&r.push(...pa(i.items,p,!1))}}return r}function bf(o){let e=pa(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 Tf(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(`
1390
+ `),e)}function Rl(o){let e=Nt(o);return/\bfinal\s*\(/.test(e)||/\bask_clarification\s*\(/.test(e)}function vl(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 Sl(o){return o instanceof Error&&o.message==="Session is closed"}function Qg(o){return o instanceof Error&&o.message==="Execution timed out"}function Yg(o){return o.startsWith("[ERROR]")||o.startsWith(zo)?!0:/^(AggregateError|Error|EvalError|RangeError|ReferenceError|SyntaxError|TypeError|URIError): /.test(o)}function Xg(o,e){if(e.kind==="threshold")return ef(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 Zg(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 ef(o){if(typeof o=="string")return o.length;try{return JSON.stringify(o).length}catch{return String(o).length}}function tf(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 nf(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":Zg(r,a,e?.inlinedFields?.has(n)===!0);t.push(`- ${n}: type=${s}, size=${i}, prompt=${u}`)}return t.join(`
1391
+ `)}async function rf(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 of(o){return o.includes("console.log")}function sf(o){let e=Nt(o),t=/\bfinal\s*\(/.test(e),n=/\bask_clarification\s*\(/.test(e),r=Number(t)+Number(n),s=af(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 af(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=uf(o,a);t.push({closeParenIndex:u})}return t}function uf(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 lf(o,e){let t=o.trim(),r=e?.normalize??!0?Ll(t):t;if(!r)throw new Error("Agent module namespace must contain letters or numbers");return r}function kl(o){return Array.isArray(o.functions)}function la(o,e){if(!o||o.length===0)return{functions:[],moduleMetadata:[]};let t=o.every(a=>kl(a)),n=o.every(a=>!kl(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 Ol(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 ma(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 pf(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 wr(o){if(o.enum)return o.enum.map(n=>`"${n}"`).join(" | ");let e=ma(o);if(e.length===0)return"unknown";if(pf(e))return"any";let t=[...new Set(e)].map(n=>{if(n==="array"){let r=o.items?wr(o.items):"unknown";return r.includes(" | ")?`(${r})[]`:`${r}[]`}return n==="object"?o.properties&&Object.keys(o.properties).length>0?Nl(o):"object":n});return t.length>1?t.join(" | "):t[0]??"unknown"}function Nl(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=wr(u),l=s&&!r.has(a)?"?":"";return`${a}${l}: ${c}`});return o.additionalProperties===!0&&i.push("[key: string]: unknown"),`{ ${i.join(", ")} }`}function df(o){let e=Nl(o.parameters,{respectRequired:!0}),t=o.returns?`: Promise<${wr(o.returns)}>`:"";return`- \`${o.qualifiedName}(args: ${e})${t}\``}function ga(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:wr(i),required:t?n.has(s):void 0,description:u});let c=ma(i);if(c.includes("object")&&i.properties&&r.push(...ga(i,a,!1)),c.includes("array")&&i.items){let l=i.items.description?.trim(),p=`${a}[]`;l&&r.push({name:p,type:wr(i.items),description:l}),ma(i.items).includes("object")&&i.items.properties&&r.push(...ga(i.items,p,!1))}}return r}function mf(o){let e=ga(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 gf(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
1393
  `)}).join(`
1394
1394
 
1395
1395
  `)].join(`
1396
- `)}function Cf(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(`
1396
+ `)}function ff(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(`
1397
+ `):`- Error: module \`${n}\` does not exist.`,u=[`### Module \`${n}\``];return i&&(u.push(`**${i.title}**`),i.description&&u.push(i.description)),u.push(a),u.join(`
1398
1398
  `)}).join(`
1399
1399
 
1400
- `)}function If(o,e){return o.map(t=>{let n=t.includes(".")?t:`utils.${t}`,r=e.get(n);return r?[`### \`${n}\``,r.description,yf({qualifiedName:n,parameters:r.parameters,returns:r.returns}),bf(r.parameters),Tf(r.examples)].filter(s=>!!s).join(`
1400
+ `)}function hf(o,e){return o.map(t=>{let n=t.includes(".")?t:`utils.${t}`,r=e.get(n);return r?[`### \`${n}\``,r.description,df({qualifiedName:n,parameters:r.parameters,returns:r.returns}),mf(r.parameters),gf(r.examples)].filter(s=>!!s).join(`
1401
1401
  `):`### \`${n}\`
1402
1402
  - Not found.`}).join(`
1403
1403
 
1404
- `)}function Fu(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 wf=(o,e)=>{let t=e?.maxHops??3,n=e?.qualityThreshold??.8,r=e?.maxIterations??2,s=e?.qualityTarget??.85,i=e?.disableQualityHealing??!1;return Fi({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}))};export{cr as AxACE,ko as AxACEOptimizedProgram,eo as AxAI,kn as AxAIAnthropic,Nr as AxAIAnthropicModel,Lr as AxAIAnthropicVertexModel,Fn as AxAIAzureOpenAI,_n as AxAICohere,Gr as AxAICohereEmbedModel,Ur as AxAICohereModel,Nn as AxAIDeepSeek,Br as AxAIDeepSeekModel,Ln as AxAIGoogleGemini,hs as AxAIGoogleGeminiEmbedModel,ul as AxAIGoogleGeminiEmbedTypes,jr as AxAIGoogleGeminiModel,xs as AxAIGoogleGeminiSafetyCategory,As as AxAIGoogleGeminiSafetyThreshold,Vn as AxAIGrok,Cl as AxAIGrokEmbedModels,Zr as AxAIGrokModel,Dn as AxAIGroq,qr as AxAIGroqModel,Un as AxAIHuggingFace,Is as AxAIHuggingFaceModel,Gn as AxAIMistral,hl as AxAIMistralEmbedModels,Hr as AxAIMistralModel,Bn as AxAIOllama,Pn as AxAIOpenAI,Ge as AxAIOpenAIBase,On as AxAIOpenAIEmbedModel,Dr as AxAIOpenAIModel,zn as AxAIOpenAIResponses,Wr as AxAIOpenAIResponsesBase,jn as AxAIOpenAIResponsesImpl,En as AxAIOpenAIResponsesModel,qn as AxAIOpenRouter,Le as AxAIRefusalError,Hn as AxAIReka,Jr as AxAIRekaModel,Fe as AxAIServiceAbortedError,Dt as AxAIServiceAuthenticationError,nt as AxAIServiceError,Ze as AxAIServiceNetworkError,$t as AxAIServiceResponseError,it as AxAIServiceStatusError,At as AxAIServiceStreamTerminatedError,mt as AxAIServiceTimeoutError,Kn as AxAITogether,Yr as AxAITogetherModel,Wn as AxAIWebLLM,Xr as AxAIWebLLMModel,qo as AxAgent,pt as AxAgentClarificationError,Ai as AxApacheTika,Nt as AxAssertionError,us as AxBalancer,je as AxBaseAI,Rt as AxBaseOptimizer,dr as AxBootstrapFewShot,kt as AxContentProcessingError,Bs as AxDB,Tt as AxDBBase,Jn as AxDBCloudflare,zs as AxDBManager,Vt as AxDBMemory,Qn as AxDBPinecone,Yn as AxDBWeaviate,vo as AxDefaultCostTracker,xi as AxDefaultResultReranker,_i as AxDockerSession,Ni as AxEmbeddingAdapter,Sd as AxEvalUtil,Po as AxFlow,mr as AxFlowDependencyAnalyzer,gr as AxFlowExecutionPlanner,fr as AxFlowSubContextImpl,Pi as AxFlowTypedSubContextImpl,Je as AxFluentFieldType,po as AxFunctionError,mo as AxFunctionProcessor,tn as AxGEPA,Me as AxGen,Co as AxGenerateError,Ei as AxHFDataLoader,sr as AxInstanceRegistry,bn as AxJSRuntime,Bc as AxJSRuntimePermission,Ia as AxLLMRequestTypeValues,Oi as AxLearn,Hi as AxMCPClient,Vi as AxMCPHTTPSSETransport,Wi as AxMCPStreambleHTTPTransport,yt as AxMediaNotSupportedError,Zn as AxMemory,Mi as AxMiPRO,Ss as AxMockAIService,ks as AxMultiServiceRouter,wt as AxOptimizedProgramImpl,Yt as AxProgram,mn as AxPromptTemplate,Fs as AxProviderRouter,$n as AxRateLimiterTokenUsage,Ne as AxSignature,ho as AxSignatureBuilder,bi as AxSimpleClassifier,yi as AxSimpleClassifierClass,wa as AxSpanKindValues,ir as AxStepContextImpl,un as AxStopFunctionCallException,hi as AxStringUtil,pr as AxSynth,Ti as AxTestPrompt,Er as AxTokenLimitError,lr as AxTraceLogger,Qg as agent,Sp as ai,at as ax,rl as axAIAnthropicDefaultConfig,Ku as axAIAnthropicVertexDefaultConfig,np as axAIAzureOpenAIBestConfig,ep as axAIAzureOpenAICreativeConfig,sl as axAIAzureOpenAIDefaultConfig,tp as axAIAzureOpenAIFastConfig,lp as axAICohereCreativeConfig,ll as axAICohereDefaultConfig,up as axAIDeepSeekCodeConfig,cl as axAIDeepSeekDefaultConfig,gl as axAIGoogleGeminiDefaultConfig,pp as axAIGoogleGeminiDefaultCreativeConfig,vp as axAIGrokBestConfig,Ds as axAIGrokDefaultConfig,gp as axAIHuggingFaceCreativeConfig,fl as axAIHuggingFaceDefaultConfig,fp as axAIMistralBestConfig,vs as axAIMistralDefaultConfig,xl as axAIOllamaDefaultConfig,hp as axAIOllamaDefaultCreativeConfig,as as axAIOpenAIBestConfig,ls as axAIOpenAICreativeConfig,rn as axAIOpenAIDefaultConfig,cs as axAIOpenAIFastConfig,Ap as axAIOpenAIResponsesBestConfig,yp as axAIOpenAIResponsesCreativeConfig,Vr as axAIOpenAIResponsesDefaultConfig,Al as axAIOpenRouterDefaultConfig,Tp as axAIRekaBestConfig,Cp as axAIRekaCreativeConfig,Qr as axAIRekaDefaultConfig,Ip as axAIRekaFastConfig,bl as axAITogetherDefaultConfig,Rp as axAIWebLLMCreativeConfig,Tl as axAIWebLLMDefaultConfig,bp as axAnalyzeChatPromptRequirements,on as axAnalyzeRequestRequirements,Re as axBaseAIDefaultConfig,We as axBaseAIDefaultCreativeConfig,ea as axBuildActorDefinition,ta as axBuildResponderDefinition,Pp as axCheckMetricsHealth,Ta as axCreateDefaultColorLogger,Tc as axCreateDefaultOptimizerColorLogger,Od as axCreateDefaultOptimizerTextLogger,Gu as axCreateDefaultTextLogger,Mo as axCreateFlowColorLogger,am as axCreateFlowTextLogger,Rm as axCreateJSRuntime,lm as axDefaultFlowLogger,Il as axDefaultMetricsConfig,Io as axDefaultOptimizerLogger,Cc as axDefaultOptimizerMetricsConfig,op as axGetCompatibilityReport,ip as axGetFormatCompatibility,Np as axGetMetricsConfig,Pd as axGetOptimizerMetricsConfig,sp as axGetProvidersWithMediaSupport,fe as axGlobals,$r as axModelInfoAnthropic,ms as axModelInfoCohere,fs as axModelInfoDeepSeek,ys as axModelInfoGoogleGemini,$s as axModelInfoGrok,Ts as axModelInfoGroq,Cs as axModelInfoHuggingFace,Rs as axModelInfoMistral,Mn as axModelInfoOpenAI,ss as axModelInfoOpenAIResponses,Ms as axModelInfoReka,_s as axModelInfoTogether,Ns as axModelInfoWebLLM,Es as axProcessContentForProvider,wf as axRAG,ps as axScoreProvidersForRequest,ds as axSelectOptimalProvider,he as axSpanAttributes,Ot as axSpanEvents,_p as axUpdateMetricsConfig,Md as axUpdateOptimizerMetricsConfig,Sn as axValidateChatRequestMessage,ns as axValidateChatResponseResult,il as axValidateProviderCapabilities,Li as axWorkerRuntime,de as f,Fi as flow,Qp as fn,kd as s};
1404
+ `)}function Ll(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 xf=(o,e)=>{let t=e?.maxHops??3,n=e?.qualityThreshold??.8,r=e?.maxIterations??2,s=e?.qualityTarget??.85,i=e?.disableQualityHealing??!1;return Ni({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}))};export{cr as AxACE,ko as AxACEOptimizedProgram,eo as AxAI,On as AxAIAnthropic,Nr as AxAIAnthropicModel,Lr as AxAIAnthropicVertexModel,_n as AxAIAzureOpenAI,Nn as AxAICohere,Gr as AxAICohereEmbedModel,Ur as AxAICohereModel,Ln as AxAIDeepSeek,jr as AxAIDeepSeekModel,$n as AxAIGoogleGemini,xs as AxAIGoogleGeminiEmbedModel,du as AxAIGoogleGeminiEmbedTypes,Br as AxAIGoogleGeminiModel,As as AxAIGoogleGeminiSafetyCategory,ys as AxAIGoogleGeminiSafetyThreshold,Jn as AxAIGrok,wu as AxAIGrokEmbedModels,Zr as AxAIGrokModel,Un as AxAIGroq,qr as AxAIGroqModel,Gn as AxAIHuggingFace,ws as AxAIHuggingFaceModel,jn as AxAIMistral,Au as AxAIMistralEmbedModels,Hr as AxAIMistralModel,Bn as AxAIOllama,Fn as AxAIOpenAI,Ge as AxAIOpenAIBase,En as AxAIOpenAIEmbedModel,Dr as AxAIOpenAIModel,qn as AxAIOpenAIResponses,Wr as AxAIOpenAIResponsesBase,zn as AxAIOpenAIResponsesImpl,Mn as AxAIOpenAIResponsesModel,Hn as AxAIOpenRouter,Le as AxAIRefusalError,Kn as AxAIReka,Jr as AxAIRekaModel,Fe as AxAIServiceAbortedError,Dt as AxAIServiceAuthenticationError,nt as AxAIServiceError,Ze as AxAIServiceNetworkError,$t as AxAIServiceResponseError,it as AxAIServiceStatusError,At as AxAIServiceStreamTerminatedError,mt as AxAIServiceTimeoutError,Wn as AxAITogether,Yr as AxAITogetherModel,Vn as AxAIWebLLM,Xr as AxAIWebLLMModel,qo as AxAgent,pt as AxAgentClarificationError,bi as AxApacheTika,_t as AxAssertionError,ps as AxBalancer,Be as AxBaseAI,Rt as AxBaseOptimizer,dr as AxBootstrapFewShot,kt as AxContentProcessingError,Bs as AxDB,It as AxDBBase,Qn as AxDBCloudflare,qs as AxDBManager,Vt as AxDBMemory,Yn as AxDBPinecone,Xn as AxDBWeaviate,vo as AxDefaultCostTracker,yi as AxDefaultResultReranker,Li as AxDockerSession,$i as AxEmbeddingAdapter,Ed as AxEvalUtil,Po as AxFlow,mr as AxFlowDependencyAnalyzer,gr as AxFlowExecutionPlanner,fr as AxFlowSubContextImpl,_i as AxFlowTypedSubContextImpl,Je as AxFluentFieldType,po as AxFunctionError,mo as AxFunctionProcessor,on as AxGEPA,Pe as AxGen,Co as AxGenerateError,Pi as AxHFDataLoader,ir as AxInstanceRegistry,In as AxJSRuntime,Bc as AxJSRuntimePermission,va as AxLLMRequestTypeValues,Mi as AxLearn,Wi as AxMCPClient,Qi as AxMCPHTTPSSETransport,Ji as AxMCPStreambleHTTPTransport,yt as AxMediaNotSupportedError,er as AxMemory,Fi as AxMiPRO,ks as AxMockAIService,Os as AxMultiServiceRouter,wt as AxOptimizedProgramImpl,Yt as AxProgram,Zt as AxPromptTemplate,_s as AxProviderRouter,Dn as AxRateLimiterTokenUsage,_e as AxSignature,ho as AxSignatureBuilder,Ci as AxSimpleClassifier,Ii as AxSimpleClassifierClass,Sa as AxSpanKindValues,ar as AxStepContextImpl,mn as AxStopFunctionCallException,Ai as AxStringUtil,pr as AxSynth,Ti as AxTestPrompt,Or as AxTokenLimitError,ur as AxTraceLogger,zg as agent,Ep as ai,at as ax,su as axAIAnthropicDefaultConfig,Jl as axAIAnthropicVertexDefaultConfig,sp as axAIAzureOpenAIBestConfig,rp as axAIAzureOpenAICreativeConfig,au as axAIAzureOpenAIDefaultConfig,op as axAIAzureOpenAIFastConfig,pp as axAICohereCreativeConfig,lu as axAICohereDefaultConfig,mp as axAIDeepSeekCodeConfig,pu as axAIDeepSeekDefaultConfig,hu as axAIGoogleGeminiDefaultConfig,gp as axAIGoogleGeminiDefaultCreativeConfig,Op as axAIGrokBestConfig,Us as axAIGrokDefaultConfig,xp as axAIHuggingFaceCreativeConfig,xu as axAIHuggingFaceDefaultConfig,Ap as axAIMistralBestConfig,Ss as axAIMistralDefaultConfig,yu as axAIOllamaDefaultConfig,yp as axAIOllamaDefaultCreativeConfig,us as axAIOpenAIBestConfig,cs as axAIOpenAICreativeConfig,an as axAIOpenAIDefaultConfig,ls as axAIOpenAIFastConfig,Ip as axAIOpenAIResponsesBestConfig,Cp as axAIOpenAIResponsesCreativeConfig,Vr as axAIOpenAIResponsesDefaultConfig,bu as axAIOpenRouterDefaultConfig,wp as axAIRekaBestConfig,Rp as axAIRekaCreativeConfig,Qr as axAIRekaDefaultConfig,vp as axAIRekaFastConfig,Cu as axAITogetherDefaultConfig,kp as axAIWebLLMCreativeConfig,Tu as axAIWebLLMDefaultConfig,Tp as axAnalyzeChatPromptRequirements,un as axAnalyzeRequestRequirements,Se as axBaseAIDefaultConfig,We as axBaseAIDefaultCreativeConfig,ra as axBuildActorDefinition,oa as axBuildResponderDefinition,Np as axCheckMetricsHealth,wa as axCreateDefaultColorLogger,Cc as axCreateDefaultOptimizerColorLogger,Pd as axCreateDefaultOptimizerTextLogger,zl as axCreateDefaultTextLogger,Mo as axCreateFlowColorLogger,lm as axCreateFlowTextLogger,km as axCreateJSRuntime,pm as axDefaultFlowLogger,Ru as axDefaultMetricsConfig,To as axDefaultOptimizerLogger,Tc as axDefaultOptimizerMetricsConfig,ap as axGetCompatibilityReport,cp as axGetFormatCompatibility,Dp as axGetMetricsConfig,Nd as axGetOptimizerMetricsConfig,up as axGetProvidersWithMediaSupport,Ae as axGlobals,$r as axModelInfoAnthropic,gs as axModelInfoCohere,hs as axModelInfoDeepSeek,bs as axModelInfoGoogleGemini,Ds as axModelInfoGrok,Cs as axModelInfoGroq,Ts as axModelInfoHuggingFace,vs as axModelInfoMistral,Pn as axModelInfoOpenAI,is as axModelInfoOpenAIResponses,Ps as axModelInfoReka,Ns as axModelInfoTogether,Ls as axModelInfoWebLLM,Ms as axProcessContentForProvider,xf as axRAG,ds as axScoreProvidersForRequest,ms as axSelectOptimalProvider,ye as axSpanAttributes,Ot as axSpanEvents,$p as axUpdateMetricsConfig,_d as axUpdateOptimizerMetricsConfig,kn as axValidateChatRequestMessage,ns as axValidateChatResponseResult,uu as axValidateProviderCapabilities,Di as axWorkerRuntime,ge as f,Ni as flow,Zp as fn,Md as s};
1406
1406
  //# sourceMappingURL=index.js.map