qlogicagent 2.9.0 → 2.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/agent.js CHANGED
@@ -1,23 +1,23 @@
1
- var sn=Object.defineProperty;var rn=(t,e)=>()=>(t&&(e=t(t=0)),e);var an=(t,e)=>{for(var n in e)sn(t,n,{get:e[n],enumerable:!0})};var Ho={};an(Ho,{resolveToolEligibility:()=>_i});function yi(t,e){if(hi.some(n=>n.test(t)))return!0;if(e)for(let n of e)try{if(new RegExp(n,"i").test(t))return!0}catch{}return!1}function bi(t,e){let n=t.function.name,o=t.meta,s=[];return e.blockedToolNames?.includes(n)?(s.push("policy_blocked"),{level:5,reasons:s}):o?.isReadOnly?(s.push("always_allowed"),{level:1,reasons:s}):o?.requiresApproval?(s.push("approval_required"),{level:4,reasons:s}):o?.isDangerous||yi(n,e.dangerousPatterns)?(s.push("dangerous_tool"),{level:3,reasons:s}):{level:2,reasons:s}}function Ti(t){switch(t){case 1:return"eligible";case 2:return"eligible";case 3:return"dangerous-notify";case 4:return"approval-required";case 5:return"blocked-by-policy"}}function _i(t,e={}){let n=new Map,o=[],s=[],i=[];for(let a of t){let r=a.function.name,{level:d,reasons:h}=bi(a,e),p=Ti(d),f={toolName:r,status:p,permissionLevel:d,approvalRequired:d===4,reasonCodes:h};n.set(r,f),d===5?s.push(f):(o.push(a),d===4&&i.push(f))}return{eligibleTools:o,blockedTools:s,approvalRequiredTools:i,eligibilityByName:n}}var hi,Ko=rn(()=>{"use strict";hi=[/^(?:bash|shell|exec|terminal|run_command)$/i,/^(?:write_file|delete_file|move_file|create_directory)$/i,/^(?:git_push|git_reset|git_force)$/i]});function je(t,e,n,o){return{role:"assistant",content:e||null,tool_calls:t,...n&&n.length>0?{thinkingBlocks:n}:{},...o?{reasoning_content:o}:{}}}function W(t,e){let n=e.ok?typeof e.payload=="string"?e.payload:JSON.stringify(e.payload??""):`Error: ${e.error??"Tool execution failed"}`;return{role:"tool",tool_call_id:t,content:n,...!e.ok&&{is_error:!0},...e.toolReferences?.length?{toolReferences:e.toolReferences}:{},...e.imageUrls?.length?{imageUrls:e.imageUrls}:{}}}var cn=/\b(?:daily|weekly|monthly)(?:\/(?:daily|weekly|monthly))* (?:usage )?limit(?:s)?(?: (?:exhausted|reached|exceeded))?\b/i,K={rateLimit:[/rate[_ ]limit|too many requests|429/,"model_cooldown","exceeded your current quota","resource has been exhausted","quota exceeded","resource_exhausted","usage limit",/\btpm\b/i,"tokens per minute","tokens per day"],overloaded:[/overloaded_error|"type"\s*:\s*"overloaded_error"/i,"overloaded",/service[_ ]unavailable.*(?:overload|capacity|high[_ ]demand)|(?:overload|capacity|high[_ ]demand).*service[_ ]unavailable/i,"high demand"],timeout:["timeout","timed out","service unavailable","deadline exceeded","context deadline exceeded","connection error","network error","network request failed","fetch failed","socket hang up",/\beconn(?:refused|reset|aborted)\b/i,/\benotfound\b/i,/\beai_again\b/i,/without sending (?:any )?chunks?/i,/\bstop reason:\s*(?:abort|error|network_error)\b/i,/\breason:\s*(?:abort|error|network_error)\b/i,/\bunhandled stop reason:\s*(?:abort|error|network_error)\b/i],billing:[/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment/i,"payment required","insufficient credits",/insufficient[_ ]quota/i,"credit balance","plans & billing","insufficient balance"],authPermanent:[/api[_ ]?key[_ ]?(?:revoked|invalid|deactivated|deleted)/i,"invalid_api_key","key has been disabled","key has been revoked","account has been deactivated",/could not (?:authenticate|validate).*(?:api[_ ]?key|credentials)/i,"permission_error","not allowed for this organization"],auth:[/invalid[_ ]?api[_ ]?key/,"incorrect api key","invalid token","authentication","re-authenticate","oauth token refresh failed","unauthorized","forbidden","access denied","insufficient permissions","insufficient permission",/missing scopes?:/i,"expired","token has expired",/\b401\b/,/\b403\b/,"no credentials found","no api key found"],format:["string should match pattern","tool_use.id","tool_use_id","messages.1.content.1.tool_use.id","invalid request format",/tool call id was.*must be/i]},un=/^(?:error[:\s-]+)?billing(?:\s+error)?(?:[:\s-]+|$)|^(?:error[:\s-]+)?(?:credit balance|insufficient credits?|payment required|http\s*402\b)/i,dn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|^\s*402\s+payment/i,pn=512,mn=/^(?:http\s*)?(\d{3})(?:\s+([\s\S]+))?$/i;var fn=new Set([500,502,503,504,521,522,523,524,529]),gn=["insufficient credits","insufficient quota","credit balance","insufficient balance","plans & billing","add more credits","top up"],hn=["upgrade your plan","upgrade plan","current plan","subscription"],yn=["daily","weekly","monthly"],bn=["try again","retry","temporary","cooldown"],Tn=["usage limit","rate limit","organization usage"],_n=["organization","workspace"],xn=["billing period","exceeded","reached","exhausted"],kn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment required\b/i,wn=/^(?:error[:\s-]+)?(?:(?:http\s*)?402(?:\s+payment required)?|payment required)(?:[:\s-]+|$)/i;function V(t,e){if(!t)return!1;let n=t.toLowerCase();return e.some(o=>o instanceof RegExp?o.test(n):n.includes(o))}function Cn(t){return V(t,K.format)}function $t(t){return V(t,K.rateLimit)}function Sn(t){return V(t,K.timeout)}function vn(t){return cn.test(t)}function We(t){let e=t.toLowerCase();return e?t.length>pn?dn.test(e):V(e,K.billing)?!0:un.test(t)?e.includes("upgrade")||e.includes("credits")||e.includes("payment")||e.includes("plan"):!1:!1}function Nt(t){return V(t,K.authPermanent)}function Mn(t){return V(t,K.auth)}function Ft(t){return V(t,K.overloaded)}function H(t,e){return e.some(n=>t.includes(n))}function Rn(t){return H(t,gn)||H(t,hn)&&t.includes("limit")||t.includes("billing hard limit")||t.includes("hard limit reached")||t.includes("maximum allowed")&&t.includes("limit")}function En(t){let e=H(t,yn),n=t.includes("spend limit")||t.includes("spending limit"),o=H(t,_n);return H(t,bn)&&H(t,Tn)||e&&(t.includes("usage limit")||n)||e&&t.includes("limit")&&t.includes("reset")||o&&t.includes("limit")&&(n||H(t,xn))}function An(t){return t.trim().toLowerCase().replace(wn,"").trim()}function Bt(t){let e=An(t);return!e||Rn(e)?"billing":$t(e)||En(e)?"rate_limit":"billing"}function In(t){return kn.test(t)?Bt(t):null}function Gt(t){let e=t.match(mn);if(!e)return null;let n=Number(e[1]);return Number.isFinite(n)?{code:n,rest:(e[2]??"").trim()}:null}function On(t){if(!t)return!1;let e=t.toLowerCase();return e.includes('"type":"api_error"')&&e.includes("internal server error")}function Un(t){let e=t.trim();if(!e)return!1;let n=Gt(e);return n?fn.has(n.code):!1}function jt(t,e){return typeof t!="number"||!Number.isFinite(t)?null:t===402?e?Bt(e):"billing":t===429?"rate_limit":t===401||t===403?e&&Nt(e)?"auth_permanent":"auth":t===408?"timeout":t===503?e&&Ft(e)?"overloaded":"timeout":t===502||t===504?"timeout":t===529?"overloaded":t===400?e&&We(e)?"billing":"format":null}function Ln(t){if(!t)return!1;let e=t.toLowerCase();return!!(e.includes("unknown model")||e.includes("model not found")||e.includes("model_not_found")||e.includes("not_found_error")||e.includes("does not exist")&&e.includes("model")||e.includes("invalid model")&&!e.includes("invalid model reference")||/models\/[^\s]+ is not found/i.test(t)||/\b404\b/.test(t)&&/not[-_ ]?found/i.test(t))}function Pn(t){if(!t)return!1;let e=t.toLowerCase();return e.includes("session not found")||e.includes("session does not exist")||e.includes("session expired")||e.includes("session invalid")||e.includes("conversation not found")||e.includes("conversation does not exist")||e.includes("conversation expired")||e.includes("conversation invalid")||e.includes("no such session")||e.includes("invalid session")||e.includes("session id not found")||e.includes("conversation id not found")}function Wt(t){if(Pn(t))return"session_expired";if(Ln(t))return"model_not_found";let e=In(t);return e||(vn(t)?We(t)?"billing":"rate_limit":$t(t)?"rate_limit":Ft(t)?"overloaded":Un(t)?Gt(t.trim())?.code===529?"overloaded":"timeout":On(t)?"timeout":Cn(t)?"format":We(t)?"billing":Sn(t)?"timeout":Nt(t)?"auth_permanent":Mn(t)?"auth":null)}var Dn={timeout:"RETRYABLE_TRANSIENT",overloaded:"RETRYABLE_TRANSIENT",rate_limit:"RETRYABLE_DEGRADED",auth:"NON_RETRYABLE_AUTH",auth_permanent:"NON_RETRYABLE_AUTH",billing:"NON_RETRYABLE_QUOTA",format:"NON_RETRYABLE_CONTENT",model_not_found:"NON_RETRYABLE_CONTENT",session_expired:"NON_RETRYABLE_CONTENT",unknown:"RETRYABLE_TRANSIENT"},$n=new Set(["RETRYABLE_TRANSIENT","RETRYABLE_DEGRADED","TOOL_EXECUTION_FAILED"]);function Y(t,e){let n=jt(t,e)??(e?Wt(e):null);return n?Dn[n]:typeof t=="number"&&t>=400&&t<500?"NON_RETRYABLE_CONTENT":"RETRYABLE_TRANSIENT"}function ze(t){return $n.has(t)}var zt=4,se=class{constructor(e){this.estimateTokens=e}estimateTokens;compress(e,n){let o=[],s=[];for(let p of e)p.role==="system"?o.push(p):s.push(p);let i=n;for(let p of o)i-=this.estimateTokens(p);let a;for(let p of s)if(p.role==="user"){a=p;break}if(a&&(i-=this.estimateTokens(a)),i<=0)return{messages:a?[...o,a]:o,droppedCount:s.length-(a?1:0),strategy:"sliding-window"};let r=[],d=0;for(let p=s.length-1;p>=0;p--){let f=s[p];if(f===a)continue;let b=this.estimateTokens(f);if(i-b<0&&d>=zt)break;if(i-b<0&&d<zt){r.unshift(f),d++;continue}i-=b,r.unshift(f),d++}let h=[...o];return a&&!r.includes(a)&&h.push(a),h.push(...r),{messages:h,droppedCount:s.length-(r.length+(a&&!r.includes(a)?1:0)),strategy:"sliding-window"}}};var ie=class{constructor(e=8e3){this.maxToolResultChars=e}maxToolResultChars;compress(e,n){let o=0;return{messages:e.map(i=>i.role!=="tool"||typeof i.content!="string"||i.content.length<=this.maxToolResultChars?i:(o++,{...i,content:Nn(i.content,this.maxToolResultChars)})),droppedCount:o,strategy:"tool-result-trim"}}};function Nn(t,e){if(t.length<=e)return t;let n=t.slice(0,e);if(t.trimStart().startsWith("{")||t.trimStart().startsWith("[")){let i=Math.max(n.lastIndexOf("},"),n.lastIndexOf("],"),n.lastIndexOf(`}
1
+ var sn=Object.defineProperty;var rn=(t,e)=>()=>(t&&(e=t(t=0)),e);var an=(t,e)=>{for(var n in e)sn(t,n,{get:e[n],enumerable:!0})};var Ho={};an(Ho,{resolveToolEligibility:()=>_s});function ys(t,e){if(hs.some(n=>n.test(t)))return!0;if(e)for(let n of e)try{if(new RegExp(n,"i").test(t))return!0}catch{}return!1}function bs(t,e){let n=t.function.name,o=t.meta,i=[];return e.blockedToolNames?.includes(n)?(i.push("policy_blocked"),{level:5,reasons:i}):o?.isReadOnly?(i.push("always_allowed"),{level:1,reasons:i}):o?.requiresApproval?(i.push("approval_required"),{level:4,reasons:i}):o?.isDangerous||ys(n,e.dangerousPatterns)?(i.push("dangerous_tool"),{level:3,reasons:i}):{level:2,reasons:i}}function Ts(t){switch(t){case 1:return"eligible";case 2:return"eligible";case 3:return"dangerous-notify";case 4:return"approval-required";case 5:return"blocked-by-policy"}}function _s(t,e={}){let n=new Map,o=[],i=[],s=[];for(let a of t){let r=a.function.name,{level:d,reasons:h}=bs(a,e),p=Ts(d),f={toolName:r,status:p,permissionLevel:d,approvalRequired:d===4,reasonCodes:h};n.set(r,f),d===5?i.push(f):(o.push(a),d===4&&s.push(f))}return{eligibleTools:o,blockedTools:i,approvalRequiredTools:s,eligibilityByName:n}}var hs,Ko=rn(()=>{"use strict";hs=[/^(?:bash|shell|exec|terminal|run_command)$/i,/^(?:write_file|delete_file|move_file|create_directory)$/i,/^(?:git_push|git_reset|git_force)$/i]});function je(t,e,n,o){return{role:"assistant",content:e||null,tool_calls:t,...n&&n.length>0?{thinkingBlocks:n}:{},...o?{reasoning_content:o}:{}}}function W(t,e){let n=e.ok?typeof e.payload=="string"?e.payload:JSON.stringify(e.payload??""):`Error: ${e.error??"Tool execution failed"}`;return{role:"tool",tool_call_id:t,content:n,...!e.ok&&{is_error:!0},...e.toolReferences?.length?{toolReferences:e.toolReferences}:{},...e.imageUrls?.length?{imageUrls:e.imageUrls}:{}}}var cn=/\b(?:daily|weekly|monthly)(?:\/(?:daily|weekly|monthly))* (?:usage )?limit(?:s)?(?: (?:exhausted|reached|exceeded))?\b/i,K={rateLimit:[/rate[_ ]limit|too many requests|429/,"model_cooldown","exceeded your current quota","resource has been exhausted","quota exceeded","resource_exhausted","usage limit",/\btpm\b/i,"tokens per minute","tokens per day"],overloaded:[/overloaded_error|"type"\s*:\s*"overloaded_error"/i,"overloaded",/service[_ ]unavailable.*(?:overload|capacity|high[_ ]demand)|(?:overload|capacity|high[_ ]demand).*service[_ ]unavailable/i,"high demand"],timeout:["timeout","timed out","service unavailable","deadline exceeded","context deadline exceeded","connection error","network error","network request failed","fetch failed","socket hang up",/\beconn(?:refused|reset|aborted)\b/i,/\benotfound\b/i,/\beai_again\b/i,/without sending (?:any )?chunks?/i,/\bstop reason:\s*(?:abort|error|network_error)\b/i,/\breason:\s*(?:abort|error|network_error)\b/i,/\bunhandled stop reason:\s*(?:abort|error|network_error)\b/i],billing:[/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment/i,"payment required","insufficient credits",/insufficient[_ ]quota/i,"credit balance","plans & billing","insufficient balance"],authPermanent:[/api[_ ]?key[_ ]?(?:revoked|invalid|deactivated|deleted)/i,"invalid_api_key","key has been disabled","key has been revoked","account has been deactivated",/could not (?:authenticate|validate).*(?:api[_ ]?key|credentials)/i,"permission_error","not allowed for this organization"],auth:[/invalid[_ ]?api[_ ]?key/,"incorrect api key","invalid token","authentication","re-authenticate","oauth token refresh failed","unauthorized","forbidden","access denied","insufficient permissions","insufficient permission",/missing scopes?:/i,"expired","token has expired",/\b401\b/,/\b403\b/,"no credentials found","no api key found"],format:["string should match pattern","tool_use.id","tool_use_id","messages.1.content.1.tool_use.id","invalid request format",/tool call id was.*must be/i]},un=/^(?:error[:\s-]+)?billing(?:\s+error)?(?:[:\s-]+|$)|^(?:error[:\s-]+)?(?:credit balance|insufficient credits?|payment required|http\s*402\b)/i,dn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|^\s*402\s+payment/i,pn=512,mn=/^(?:http\s*)?(\d{3})(?:\s+([\s\S]+))?$/i;var fn=new Set([500,502,503,504,521,522,523,524,529]),gn=["insufficient credits","insufficient quota","credit balance","insufficient balance","plans & billing","add more credits","top up"],hn=["upgrade your plan","upgrade plan","current plan","subscription"],yn=["daily","weekly","monthly"],bn=["try again","retry","temporary","cooldown"],Tn=["usage limit","rate limit","organization usage"],_n=["organization","workspace"],xn=["billing period","exceeded","reached","exhausted"],kn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment required\b/i,wn=/^(?:error[:\s-]+)?(?:(?:http\s*)?402(?:\s+payment required)?|payment required)(?:[:\s-]+|$)/i;function V(t,e){if(!t)return!1;let n=t.toLowerCase();return e.some(o=>o instanceof RegExp?o.test(n):n.includes(o))}function Cn(t){return V(t,K.format)}function $t(t){return V(t,K.rateLimit)}function Sn(t){return V(t,K.timeout)}function vn(t){return cn.test(t)}function We(t){let e=t.toLowerCase();return e?t.length>pn?dn.test(e):V(e,K.billing)?!0:un.test(t)?e.includes("upgrade")||e.includes("credits")||e.includes("payment")||e.includes("plan"):!1:!1}function Nt(t){return V(t,K.authPermanent)}function Mn(t){return V(t,K.auth)}function Ft(t){return V(t,K.overloaded)}function H(t,e){return e.some(n=>t.includes(n))}function Rn(t){return H(t,gn)||H(t,hn)&&t.includes("limit")||t.includes("billing hard limit")||t.includes("hard limit reached")||t.includes("maximum allowed")&&t.includes("limit")}function En(t){let e=H(t,yn),n=t.includes("spend limit")||t.includes("spending limit"),o=H(t,_n);return H(t,bn)&&H(t,Tn)||e&&(t.includes("usage limit")||n)||e&&t.includes("limit")&&t.includes("reset")||o&&t.includes("limit")&&(n||H(t,xn))}function An(t){return t.trim().toLowerCase().replace(wn,"").trim()}function Bt(t){let e=An(t);return!e||Rn(e)?"billing":$t(e)||En(e)?"rate_limit":"billing"}function In(t){return kn.test(t)?Bt(t):null}function Gt(t){let e=t.match(mn);if(!e)return null;let n=Number(e[1]);return Number.isFinite(n)?{code:n,rest:(e[2]??"").trim()}:null}function On(t){if(!t)return!1;let e=t.toLowerCase();return e.includes('"type":"api_error"')&&e.includes("internal server error")}function Un(t){let e=t.trim();if(!e)return!1;let n=Gt(e);return n?fn.has(n.code):!1}function jt(t,e){return typeof t!="number"||!Number.isFinite(t)?null:t===402?e?Bt(e):"billing":t===429?"rate_limit":t===401||t===403?e&&Nt(e)?"auth_permanent":"auth":t===408?"timeout":t===503?e&&Ft(e)?"overloaded":"timeout":t===502||t===504?"timeout":t===529?"overloaded":t===400?e&&We(e)?"billing":"format":null}function Ln(t){if(!t)return!1;let e=t.toLowerCase();return!!(e.includes("unknown model")||e.includes("model not found")||e.includes("model_not_found")||e.includes("not_found_error")||e.includes("does not exist")&&e.includes("model")||e.includes("invalid model")&&!e.includes("invalid model reference")||/models\/[^\s]+ is not found/i.test(t)||/\b404\b/.test(t)&&/not[-_ ]?found/i.test(t))}function Pn(t){if(!t)return!1;let e=t.toLowerCase();return e.includes("session not found")||e.includes("session does not exist")||e.includes("session expired")||e.includes("session invalid")||e.includes("conversation not found")||e.includes("conversation does not exist")||e.includes("conversation expired")||e.includes("conversation invalid")||e.includes("no such session")||e.includes("invalid session")||e.includes("session id not found")||e.includes("conversation id not found")}function Wt(t){if(Pn(t))return"session_expired";if(Ln(t))return"model_not_found";let e=In(t);return e||(vn(t)?We(t)?"billing":"rate_limit":$t(t)?"rate_limit":Ft(t)?"overloaded":Un(t)?Gt(t.trim())?.code===529?"overloaded":"timeout":On(t)?"timeout":Cn(t)?"format":We(t)?"billing":Sn(t)?"timeout":Nt(t)?"auth_permanent":Mn(t)?"auth":null)}var Dn={timeout:"RETRYABLE_TRANSIENT",overloaded:"RETRYABLE_TRANSIENT",rate_limit:"RETRYABLE_DEGRADED",auth:"NON_RETRYABLE_AUTH",auth_permanent:"NON_RETRYABLE_AUTH",billing:"NON_RETRYABLE_QUOTA",format:"NON_RETRYABLE_CONTENT",model_not_found:"NON_RETRYABLE_CONTENT",session_expired:"NON_RETRYABLE_CONTENT",unknown:"RETRYABLE_TRANSIENT"},$n=new Set(["RETRYABLE_TRANSIENT","RETRYABLE_DEGRADED","TOOL_EXECUTION_FAILED"]);function Y(t,e){let n=jt(t,e)??(e?Wt(e):null);return n?Dn[n]:typeof t=="number"&&t>=400&&t<500?"NON_RETRYABLE_CONTENT":"RETRYABLE_TRANSIENT"}function ze(t){return $n.has(t)}var zt=4,ie=class{constructor(e){this.estimateTokens=e}estimateTokens;compress(e,n){let o=[],i=[];for(let p of e)p.role==="system"?o.push(p):i.push(p);let s=n;for(let p of o)s-=this.estimateTokens(p);let a;for(let p of i)if(p.role==="user"){a=p;break}if(a&&(s-=this.estimateTokens(a)),s<=0)return{messages:a?[...o,a]:o,droppedCount:i.length-(a?1:0),strategy:"sliding-window"};let r=[],d=0;for(let p=i.length-1;p>=0;p--){let f=i[p];if(f===a)continue;let b=this.estimateTokens(f);if(s-b<0&&d>=zt)break;if(s-b<0&&d<zt){r.unshift(f),d++;continue}s-=b,r.unshift(f),d++}let h=[...o];return a&&!r.includes(a)&&h.push(a),h.push(...r),{messages:h,droppedCount:i.length-(r.length+(a&&!r.includes(a)?1:0)),strategy:"sliding-window"}}};var se=class{constructor(e=8e3){this.maxToolResultChars=e}maxToolResultChars;compress(e,n){let o=0;return{messages:e.map(s=>s.role!=="tool"||typeof s.content!="string"||s.content.length<=this.maxToolResultChars?s:(o++,{...s,content:Nn(s.content,this.maxToolResultChars)})),droppedCount:o,strategy:"tool-result-trim"}}};function Nn(t,e){if(t.length<=e)return t;let n=t.slice(0,e);if(t.trimStart().startsWith("{")||t.trimStart().startsWith("[")){let s=Math.max(n.lastIndexOf("},"),n.lastIndexOf("],"),n.lastIndexOf(`}
2
2
  `),n.lastIndexOf(`]
3
- `));if(i>e*.5)return n.slice(0,i+1)+`
4
- [...truncated: ${t.length-i-1} chars omitted]`}let s=n.lastIndexOf(`
5
- `);return s>e*.7?n.slice(0,s)+`
6
- [...truncated: ${t.length-s} chars omitted]`:n+`
7
- [...truncated: ${t.length-e} chars omitted]`}function He(...t){return{compress(e,n){let o=e,s=0,i=[];for(let a of t){let r=a.compress(o,n);o=r.messages,s+=r.droppedCount,r.droppedCount>0&&i.push(r.strategy)}return{messages:o,droppedCount:s,strategy:i.length>0?i.join("+"):"none"}}}}var Ht={modelContextWindow:128e3,targetUsageRatio:.75,minBudget:16e3,maxBudget:12e4};function Ke(t={}){let e={...Ht,...t},n=Math.floor(e.modelContextWindow*e.targetUsageRatio);return Math.max(e.minBudget,Math.min(n,e.maxBudget))}function Ve(t,e){let n=t/e;return n<=.8?"none":n<=1?"trim-only":n<=1.5?"sliding-window":"llm-summarize"}var re=class{events=[];maxEvents;constructor(e=100){this.maxEvents=e}record(e){this.events.push(e),this.events.length>this.maxEvents&&this.events.shift()}snapshot(){let e=this.events.length;if(e===0)return{totalCompressions:0,totalLlmCalls:0,totalCacheInvalidations:0,averageCompressionRatio:1,averageLatencyMs:0,totalTokensSaved:0,recentEvents:[]};let n=0,o=0,s=0,i=0,a=0;for(let r of this.events)n+=r.tokensBefore>0?r.tokensAfter/r.tokensBefore:1,o+=r.latencyMs,s+=Math.max(0,r.tokensBefore-r.tokensAfter),r.usedLlm&&i++,r.cacheInvalidated&&a++;return{totalCompressions:e,totalLlmCalls:i,totalCacheInvalidations:a,averageCompressionRatio:n/e,averageLatencyMs:o/e,totalTokensSaved:s,recentEvents:this.events.slice(-10)}}reset(){this.events.length=0}},ae=class{engines=new Map;activeId;register(e){this.engines.set(e.id,e)}activate(e){return this.engines.has(e)?(this.activeId=e,!0):!1}getActive(){return this.activeId?this.engines.get(this.activeId):void 0}listEngines(){return Array.from(this.engines.values()).map(e=>({id:e.id,label:e.label,active:e.id===this.activeId}))}};function Kt(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}var Fn=new Set(["file_read","read","Read","bash","shell","Bash","grep","search","Grep","grep_search","glob","Glob","file_search","web_search","WebSearch","web_fetch","WebFetch","file_edit","edit","Edit","file_write","write","Write"]),X=class{constructor(e=20,n=Kt){this.preserveRecentCount=e;this.estimateTokens=n}preserveRecentCount;estimateTokens;compress(e,n){if(e.length<=this.preserveRecentCount)return{messages:e,droppedCount:0,strategy:"micro-compact"};let o=e.length-this.preserveRecentCount,s=0,i=0;return{messages:e.map((r,d)=>{if(d>=o||r.role!=="tool"||typeof r.content!="string"||!r.name||!Fn.has(r.name)||r.content.length<=200)return r;let h=this.estimateTokens(r);return i+=h,s++,{...r,content:`[result cleared \u2014 ${r.content.length} chars]`}}),droppedCount:s,strategy:"micro-compact",metrics:s>0?{tokensBefore:0,tokensAfter:0,compressionRatio:0,latencyMs:0,usedLlm:!1,cacheInvalidated:!1}:void 0}}};function Xe(t,e,n=Kt){if(e.size===0)return{messages:t,tokensFreed:0,removedCount:0};let o=0,s=0,i=[];for(let r of t){let d=r.tool_call_id??"";if(d&&e.has(d)){o+=n(r),s++,e.delete(d);continue}i.push(r)}let a=s>0?{role:"system",content:`[${s} messages removed by snip]`}:void 0;return{messages:i,tokensFreed:o,removedCount:s,boundaryMessage:a}}function Ye(){return{stages:[]}}function Je(t,e,n){let o=n?.thresholdMessages??40;if(t.filter(r=>r.role!=="system").length<=o)return{messages:t,stagedCount:0};let i=Vt(t,e),a=Bn(i,e,o);if(a.length===0)return{messages:i,stagedCount:0};for(let r of a)e.stages.push(r);return i=Vt(t,e),{messages:i,stagedCount:a.length}}function Qe(t,e){let n=0;for(let o of e.stages)o.committed||(o.committed=!0,n++);return n===0?{messages:t,committed:0}:{messages:Xt(t,e),committed:n}}function Vt(t,e){return e.stages.filter(o=>o.committed).length===0?t:Xt(t,e)}function Xt(t,e){let n=e.stages.filter(s=>s.committed).sort((s,i)=>i.range[0]-s.range[0]),o=[...t];for(let s of n){let[i,a]=s.range;if(i>=o.length)continue;let r=Math.min(a,o.length),d={role:"system",content:s.summary};o.splice(i,r-i,d)}return o}function Bn(t,e,n){let o=Math.max(0,t.length-Math.floor(n/2)),s=[],i=new Set(e.stages.map(d=>`${d.range[0]}-${d.range[1]}`)),a=-1,r=0;for(let d=0;d<o;d++){let h=t[d];if(h.role==="tool"||h.role==="assistant"&&typeof h.content=="string"&&h.content==="")a<0&&(a=d),r++;else{if(r>=3){let f=`${a}-${a+r}`;i.has(f)||s.push({id:`collapse_${a}_${a+r}`,range:[a,a+r],summary:`[${r} tool results collapsed]`,committed:!1})}a=-1,r=0}}if(r>=3){let d=`${a}-${a+r}`;i.has(d)||s.push({id:`collapse_${a}_${a+r}`,range:[a,a+r],summary:`[${r} tool results collapsed]`,committed:!1})}return s}import{existsSync as et,readFileSync as yo,writeFileSync as Gn,readdirSync as bo,mkdirSync as jn}from"node:fs";import{join as tt,dirname as Wn}from"node:path";var Yt=Math.min(Math.max(1,Number(process.env.TOOL_LOOP_DEFAULT_BUDGET)||25),100),Jt=3,Qt=2,xe=2,Zt=128e3,qt=13e3,eo=16384,to=65536,oo=3,no=65536,Ze=500,so=3,io=5e4,ro=2e5,qe=2e3,ao=3e4,lo=3,le=2;var co=20;var uo=3,po=2,mo=300*1e3,fo=3,go=720*60*60*1e3;var Xi=300*1e3;var Yi=3600*1e3;var Ji=50*1024,Qi=500*1024,Zi=500*1024*1024,qi=50*1024*1024;var er=60*1024;var To=0;var zn="skill-patterns.json";function _o(t){return tt(t,".qlogicagent",zn)}function Hn(t){let e=_o(t);try{return JSON.parse(yo(e,"utf8"))}catch{return{version:1,patterns:{}}}}function ho(t,e){let n=_o(t);jn(Wn(n),{recursive:!0}),Gn(n,JSON.stringify(e,null,2),"utf8")}function Kn(t){let e=Date.now()-go;for(let[n,o]of Object.entries(t.patterns))new Date(o.lastSeen).getTime()<e&&delete t.patterns[n]}function xo(t,e){if(e.length===0)return!1;let n=ke(e),o=Hn(t);Kn(o);let s=new Date().toISOString(),i=o.patterns[n];if(i||(i={signature:n,count:0,firstSeen:s,lastSeen:s,promoted:!1},o.patterns[n]=i),i.promoted)return ho(t,o),!1;i.count++,i.lastSeen=s;let a=i.count>=fo;return a&&(i.promoted=!0),ho(t,o),a}function ke(t){return[...t].sort().join("+")}function Vn(t,e){if(!et(e))return null;let n=ke(t);try{let o=bo(e,{withFileTypes:!0});for(let s of o){if(!s.isDirectory())continue;let i=tt(e,s.name,"SKILL.md");try{let r=yo(i,"utf8").match(/^tools:\s*\n((?:\s+-\s+\S+\n?)+)/m);if(r){let d=r[1].split(`
8
- `).map(h=>h.replace(/^\s*-\s*/,"").trim()).filter(Boolean);if(ke(d)===n)return s.name}}catch{}}}catch{}return null}function Xn(t){if(!et(t))return 0;try{return bo(t,{withFileTypes:!0}).filter(e=>e.isDirectory()&&et(tt(t,e.name,"SKILL.md"))).length}catch{return 0}}function Yn(t,e){return!(!t.ok||t.existingSkillName||!t.multiStep||t.toolCallCount<uo||t.distinctToolCount<po||Date.now()-To<mo||e?.projectSkillsDir&&(Xn(e.projectSkillsDir)>=co||e.tools.length>0&&Vn(e.tools,e.projectSkillsDir))||e?.projectRoot&&e.tools.length>0&&!xo(e.projectRoot,e.tools))}function Jn(t){return t.existingSkillName?t.feedback==="negative":!1}function we(t,e){return Jn(t)?{type:"skill.improve",skillName:t.existingSkillName,reason:"negative user feedback on existing skill execution"}:Yn(t,e)?(To=Date.now(),{type:"skill.create",suggestedName:e.suggestedName??`auto-skill-${e.tools.slice(0,3).join("-")}`,description:`Multi-step orchestration using ${e.tools.join(", ")}`,tools:e.tools,stepCount:t.toolCallCount}):null}function ko(t){return t.function&&typeof t.function=="object"&&typeof t.function.name=="string"?t.function.name.trim():typeof t.name=="string"?t.name.trim():""}function Qn(t){return t==="enabled-eligible"||t==="installed-awaiting-approval"}function Zn(t){return new Map((t??[]).map(e=>[e.toolName,e]))}function qn(t){if(!t.eligibility?.length)return[...t.tools];let e=Zn(t.eligibility);return t.tools.filter(n=>{let o=ko(n);if(!o)return!1;let s=e.get(o);return!s||Qn(s.status)})}function es(t){let e=[],n=t.compatibility??{},o=t.toolChoice;if(t.thinkingEnabled&&n.requireAutoWhenThinking){let s=typeof o=="object"&&o&&!Array.isArray(o)?String(o.type??""):o;s&&s!=="auto"&&s!=="none"&&(e.push("tool_choice downgraded to auto because thinking mode requires auto/none compatibility."),o="auto")}if(o==="required"&&n.allowRequiredToolChoice===!1){let s=n.requiredFallback??"auto";e.push(`tool_choice=required is not supported by this provider; downgraded to ${s}.`),o=s}if(o&&typeof o=="object"&&!Array.isArray(o)&&o.type==="function"&&n.allowNamedToolChoice===!1){let s=n.namedFallback??"required";e.push(`named tool_choice is not supported by this provider; downgraded to ${s}.`),o=s}return{normalizedToolChoice:o,warnings:e}}function ot(t){let e=es({toolChoice:t.toolChoice,thinkingEnabled:t.thinkingEnabled,compatibility:t.compatibility}),n=e.normalizedToolChoice,o=[...e.warnings],s=qn({tools:t.tools,eligibility:t.eligibility});if(!n||n==="auto")return{tools:s,normalizedToolChoice:n,warnings:o};if(n==="none")return{tools:[],normalizedToolChoice:"none",warnings:o};if(n==="required"){if(s.length===0)throw new Error("tool_choice=required but no tools were provided");return{tools:s,normalizedToolChoice:"required",extraSystemPrompt:"You must call one of the available tools before responding.",warnings:o}}if(typeof n=="object"&&!Array.isArray(n)&&n.type==="function"){let i=n.function??void 0,a=typeof i?.name=="string"?i.name.trim():"";if(!a)throw new Error("tool_choice.function.name is required");let r=s.filter(d=>ko(d)===a);if(r.length===0)throw new Error(`tool_choice requested unknown tool: ${a}`);return{tools:r,normalizedToolChoice:{type:"function",function:{name:a}},extraSystemPrompt:`You must call the ${a} tool before responding.`,warnings:o}}return{tools:s,normalizedToolChoice:n,warnings:o}}var ts=["stop","aborted","timeout","cancelled","interrupted","error"],os=["tool_calls","toolCalls","function_call","functionCall","raw_tool_calls","rawToolCalls"];function wo(t){return t==null?[]:typeof t=="string"?t.length>0?[{type:"text",text:t}]:[]:Array.isArray(t)?t:[{type:"text",text:String(t)}]}function ns(t,e){return{...t,content:[...wo(t.content),...wo(e.content)]}}function ss(t){if(!t||typeof t!="object")return!1;if(t.function&&typeof t.function=="object"){let e=t.function.name;if(typeof e=="string"&&e.length>0)return!0}return typeof t.name=="string"&&t.name.length>0}function is(t){return new Set((t??ts).map(e=>e.trim().toLowerCase()))}function rs(t,e){return t?is(e).has(t.trim().toLowerCase()):!1}function nt(t){if(!Array.isArray(t)||t.length===0)return[...t];let e=t.map(r=>{if(r.role==="assistant"&&Array.isArray(r.tool_calls)){let d=r.tool_calls.filter(h=>ss(h));return{...r,...d.length>0?{tool_calls:d}:{tool_calls:void 0}}}return{...r}}),n=new Set;for(let r of e)if(!(r.role!=="assistant"||!Array.isArray(r.tool_calls)))for(let d of r.tool_calls)typeof d.id=="string"&&d.id&&n.add(d.id);let o=e.filter(r=>r.role!=="tool"?!0:!!(r.tool_call_id&&n.has(r.tool_call_id))),s=new Set;for(let r of o)r.role==="tool"&&typeof r.tool_call_id=="string"&&r.tool_call_id&&s.add(r.tool_call_id);let i=[];for(let r of o){if(r.role==="assistant"&&Array.isArray(r.tool_calls)&&r.tool_calls.length>0){let d=r.tool_calls.filter(h=>typeof h.id=="string"&&s.has(h.id));if(d.length===0){let{tool_calls:h,...p}=r;p.content!=null&&p.content!==""&&i.push(p);continue}if(d.length<r.tool_calls.length){i.push({...r,tool_calls:d});continue}}i.push(r)}let a=[];for(let r of i){let d=a.length>0?a[a.length-1]:void 0;if(r.role==="user"&&d?.role==="user"){a[a.length-1]=ns(d,r);continue}a.push(r)}return a}function st(t,e){return rs(e?.stopReason,e?.forcedStopReasons)?t.map(n=>{if(n.role!=="assistant")return{...n};let o={...n};for(let s of os)delete o[s];return o}):[...t]}function it(t,e){let n=e?.placeholderToolResult??"Error: Tool loop interrupted before the tool result was replayed.",o=new Set;for(let i of t)i.role==="tool"&&typeof i.tool_call_id=="string"&&i.tool_call_id&&o.add(i.tool_call_id);let s=[];for(let i of t)if(s.push({...i}),!(i.role!=="assistant"||!Array.isArray(i.tool_calls)||i.tool_calls.length===0))for(let a of i.tool_calls)typeof a.id!="string"||!a.id||o.has(a.id)||(o.add(a.id),s.push({role:"tool",tool_call_id:a.id,content:n}));return s}function rt(t,e){let n=nt(t),o=st(n,e);return it(o,e)}function as(t){let e=new Set,n=new Set;for(let o of t){if(o.role==="assistant"&&Array.isArray(o.tool_calls))for(let s of o.tool_calls)typeof s.id=="string"&&s.id&&e.add(s.id);o.role==="tool"&&typeof o.tool_call_id=="string"&&o.tool_call_id&&n.add(o.tool_call_id)}return[...e].filter(o=>!n.has(o))}function ls(t){let e=new Set;for(let n of t)n.role==="tool"&&typeof n.tool_call_id=="string"&&n.tool_call_id&&e.add(n.tool_call_id);return[...e]}function cs(t){return{round:t.round??0,maxRounds:t.maxRounds,pendingToolCallIds:[...t.pendingToolCallIds??[]],completedToolCallIds:[...t.completedToolCallIds??[]],lastStopReason:t.lastStopReason,replayMessages:[...t.replayMessages??[]]}}function at(t,e){return{round:t.round+1,maxRounds:t.maxRounds,pendingToolCallIds:[...e.pendingToolCallIds??t.pendingToolCallIds],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function Ce(t,e){return{round:t.round,maxRounds:t.maxRounds,pendingToolCallIds:[],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function Se(t){let e=[],n=nt(t.replayMessages);n.length!==t.replayMessages.length&&e.push({kind:"drop-orphan-tool-result",detail:"Removed orphan tool results or invalid assistant tool calls."});let o=st(n,t.options);o.some((i,a)=>i!==n[a])&&e.push({kind:"strip-forced-stop-tool-metadata",detail:"Removed assistant tool-call metadata after forced stop."});let s=it(o,t.options);return s.length>o.length&&e.push({kind:"inject-placeholder-tool-result",detail:"Injected placeholder tool result for pending tool calls."}),{state:cs({maxRounds:t.maxRounds,round:t.round,lastStopReason:t.lastStopReason,replayMessages:s,pendingToolCallIds:as(s),completedToolCallIds:ls(s)}),recoveryActions:e}}var us=new Set(["main","sdk","agent","compact","hook","verification","side_question"]);function lt(t){return t?us.has(t):!0}function ct(t){return t===429||t===529}function ve(t,e=500,n=32e3){let o=Math.min(e*Math.pow(2,t-1),n);return o+Math.floor(Math.random()*o*.25)}var pr={maxBackoffMs:300*1e3,resetCapMs:360*60*1e3,heartbeatIntervalMs:3e4};function Me(){let t=process.env.QLOGICAGENT_PERSISTENT_RETRY;return t==="1"||t==="true"}var ce=class extends Error{constructor(n,o){super(`Model fallback triggered: ${n} -> ${o}`);this.originalModel=n;this.fallbackModel=o;this.name="FallbackTriggeredError"}originalModel;fallbackModel};function ut(t){return{promptTokens:0,hasAttemptedReactiveCompact:!1,currentMaxOutputTokens:t.maxOutputTokens,consecutiveTruncations:0,aborted:t.abortSignal?.aborted??!1}}function dt(t,e){if(t.aborted)return{level:"blocking",usagePercent:100,reason:"budget_exhausted"};let n=e.contextWindowTokens-e.responseBufferTokens-t.currentMaxOutputTokens,o=n>0?t.promptTokens/n*100:100;return t.promptTokens>=n?t.hasAttemptedReactiveCompact||!e.reactiveCompactEnabled?{level:"blocking",usagePercent:o,reason:"prompt_too_long"}:{level:"blocking",usagePercent:o,reason:"prompt_too_long"}:o>=85?{level:"warning",usagePercent:o,remainingTokens:n-t.promptTokens}:{level:"ok"}}function pt(t,e,n){let o=t.message?.toLowerCase()??"",s=t.status??0;return s===413||o.includes("prompt_too_long")||o.includes("context_length_exceeded")?!e.hasAttemptedReactiveCompact&&n.reactiveCompactEnabled?{action:"reactive_compact"}:{action:"abort",reason:"prompt_too_long_unrecoverable"}:s>=500&&s<600?{action:"retry",reason:`server_error_${s}`}:s===429?{action:"retry",reason:"rate_limited"}:s===401||s===403?{action:"abort",reason:"auth_error"}:s===404?{action:"abort",reason:"model_not_found"}:{action:"abort",reason:o||"unknown_error"}}function mt(t,e,n){if(!e.outputEscalationEnabled)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};if(t.consecutiveTruncations>=3)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};let o=Math.min(t.currentMaxOutputTokens*2,n);return o<=t.currentMaxOutputTokens?{shouldEscalate:!1,newMax:t.currentMaxOutputTokens}:{shouldEscalate:!0,newMax:o}}function ft(t,e){return t.aborted?!0:e.abortSignal?.aborted?(t.aborted=!0,!0):!1}var ps={maxConsecutiveFailures:3,minMessagesAfterCompact:4,targetUsagePercent:50};function gt(){return{consecutiveFailures:0,attemptedThisTurn:!1,lastCompactAt:null,toolsAtLastCompact:[]}}function J(t,e=ps){return!(t.attemptedThisTurn||t.consecutiveFailures>=e.maxConsecutiveFailures)}function ht(t,e){let n=t.get(e.index);n||(n={id:"",name:"",arguments:""},t.set(e.index,n)),e.id&&(n.id=e.id),e.name&&(n.name+=e.name),n.arguments+=e.arguments}import{writeFileSync as ua,mkdirSync as da}from"node:fs";import{join as ma}from"node:path";import{randomUUID as ga}from"node:crypto";import{join as yt}from"node:path";import{homedir as Ts,tmpdir as _s}from"node:os";function Co(){return process.env.QLOGICAGENT_HOME??yt(Ts()||_s(),".qlogicagent")}function Q(){return process.env.QLOGICAGENT_CACHE_DIR??yt(Co(),"cache")}function So(){return process.env.QLOGICAGENT_DEBUG_LOG_DIR??yt(Co(),"debug-logs")}import{writeFileSync as Ea,mkdirSync as Aa}from"node:fs";import{join as Oa}from"node:path";import{randomUUID as La}from"node:crypto";import{writeFileSync as _a,mkdirSync as xa}from"node:fs";import{join as wa}from"node:path";import{randomUUID as Sa}from"node:crypto";import{writeFileSync as Ba,mkdirSync as Ga}from"node:fs";import{join as Wa}from"node:path";import{randomUUID as Ha}from"node:crypto";var bt=[{id:"deepseek",name:"DeepSeek",transport:"anthropic-messages",baseUrl:"https://api.deepseek.com/anthropic",apiKeyEnvVars:["DEEPSEEK_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"deepseek-v4-flash",quirks:{useEffortInsteadOfBudget:!0,filterImageBlocks:!0,maxReasoningEffort:"max",supportsPrefixCompletion:!0},models:[{id:"deepseek-v4-flash",name:"DeepSeek V4 Flash",contextWindow:1e6,maxOutput:384e3,toolCall:!0,reasoning:!0,vision:!1,costInput:.14,costOutput:.28,costCacheRead:.003},{id:"deepseek-v4-pro",name:"DeepSeek V4 Pro",contextWindow:1e6,maxOutput:384e3,toolCall:!0,reasoning:!0,vision:!1,costInput:1.74,costOutput:3.48,costCacheRead:.014}]},{id:"qwen",name:"Alibaba Qwen (DashScope)",transport:"anthropic-messages",baseUrl:"https://dashscope.aliyuncs.com/apps/anthropic",apiKeyEnvVars:["DASHSCOPE_API_KEY","QWEN_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"qwen3.6-plus",models:[{id:"qwen3.6-max-preview",name:"Qwen3.6 Max (Preview)",contextWindow:1e6,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:2,costOutput:8,costCacheRead:.2,costCacheWrite:2.5},{id:"qwen3.6-plus",name:"Qwen3.6 Plus",contextWindow:1e6,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:3,costCacheRead:.05,costCacheWrite:.625},{id:"qwen3.6-flash",name:"Qwen3.6 Flash",contextWindow:1e6,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.1,costOutput:.5,costCacheRead:.01,costCacheWrite:.125},{id:"qwq-plus",name:"QwQ Plus",contextWindow:131072,maxOutput:65536,toolCall:!0,reasoning:!0,reasoningRequired:!0,streamRequired:!0,vision:!1,costInput:.5,costOutput:3,costCacheRead:.05,costCacheWrite:.625},{id:"qwen-max",name:"Qwen Max",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:2,costOutput:6,costCacheRead:.2,costCacheWrite:2.5},{id:"qwen-plus",name:"Qwen Plus",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:.85,costCacheRead:.03,costCacheWrite:.375},{id:"qwen-flash",name:"Qwen Flash",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1},{id:"qwen-turbo",name:"Qwen Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!1},{id:"qwen-vl-max",name:"Qwen VL Max",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!0,costInput:3,costOutput:8.5},{id:"qwen3.5-omni-plus",name:"Qwen3.5 Omni Plus",contextWindow:131072,maxOutput:16384,toolCall:!1,reasoning:!1,streamRequired:!0,vision:!0},{id:"qwen3.5-omni-plus-realtime",name:"Qwen3.5 Omni Plus Realtime",contextWindow:131072,maxOutput:16384,toolCall:!1,reasoning:!1,streamRequired:!0,vision:!0,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",modalities:["text","audio"],vad:!0,toolCalling:!1}},{id:"qwen-vl-ocr",name:"Qwen VL OCR",contextWindow:131072,maxOutput:4096,toolCall:!1,reasoning:!1,vision:!0,mediaType:"document_parsing",mediaCapabilities:{type:"document_parsing",supportedFormats:["jpg","jpeg","png","bmp","tiff","pdf"],maxFileSizeMB:10}},{id:"qwen3-tts-voicedesign",name:"Qwen3 TTS VoiceDesign",contextWindow:32768,maxOutput:16384,toolCall:!1,reasoning:!1,vision:!1,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],maxCharacters:32768,formats:["mp3","wav"]}},{id:"cosyvoice-v2",name:"CosyVoice V2",contextWindow:1e4,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],maxCharacters:1e4,formats:["mp3","wav","pcm"]}},{id:"wan2.7-image-pro",name:"Wan 2.7 Image Pro",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","1280x720","720x1280","2048x2048","3840x2160"]}},{id:"wanx2.1-t2i-turbo",name:"Wan 2.1 Text-to-Image Turbo",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","720x1280","1280x720"]}},{id:"wan2.7-t2v-plus",name:"Wan 2.7 Text/Image-to-Video Plus",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:15,resolutions:["720P","1080P"]}},{id:"wanx2.1-t2v-turbo",name:"Wan 2.1 Text/Image-to-Video Turbo",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:5,resolutions:["480P","720P"]}},{id:"text-embedding-v4",name:"Text Embedding V4",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:1024,maxTokens:8192}},{id:"sensevoice-v1",name:"SenseVoice V1",contextWindow:0,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"stt",mediaCapabilities:{type:"stt",languages:["zh","en","ja","ko","yue"],formats:["wav","mp3","m4a","flac","aac"]}},{id:"wanx-background-generation-v2",name:"Wan Background Generation V2",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["inpainting"],sizes:["1024x1024","1280x720","720x1280"]}},{id:"qwen3-rerank",name:"Qwen3 Rerank",contextWindow:32768,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"rerank",mediaCapabilities:{type:"rerank",maxDocuments:100}}]},{id:"zhipu",name:"\u93C5\u9E3F\u6C28 GLM (Zhipu)",group:"zhipu",transport:"anthropic-messages",baseUrl:"https://open.bigmodel.cn/api/anthropic",apiKeyEnvVars:["ZHIPU_API_KEY","GLM_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"glm-5.1",quirks:{filterThinkingBlocks:!0},models:[{id:"glm-5.1",name:"GLM-5.1",contextWindow:2e5,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:6,costOutput:24,costCacheRead:1.3},{id:"glm-5",name:"GLM-5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-5-turbo",name:"GLM-5 Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1,costCacheRead:.1},{id:"glm-4.7",name:"GLM-4.7",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.6",name:"GLM-4.6",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.5-air",name:"GLM-4.5 Air",contextWindow:131072,maxOutput:98304,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1.5,costCacheRead:.1},{id:"glm-4-long",name:"GLM-4 Long",contextWindow:1e6,maxOutput:4096,toolCall:!0,reasoning:!1,vision:!1,costInput:.1,costOutput:.1},{id:"glm-4.7-flash",name:"GLM-4.7 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-4.5-flash",name:"GLM-4.5 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-5v-turbo",name:"GLM-5V Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:1},{id:"glm-4.6v",name:"GLM-4.6V",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:1,costOutput:3.2},{id:"glm-4.6v-flash",name:"GLM-4.6V Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!0,costInput:0,costOutput:0},{id:"cogview-4-250304",name:"CogView-4",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","768x1344","864x1152","1344x768","1152x864","1440x720","720x1440"]}},{id:"cogview-3-flash",name:"CogView-3 Flash (Free)",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","768x1344","864x1152","1344x768","1152x864","1440x720","720x1440"]}},{id:"glm-image",name:"GLM-Image",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1280x1280","1568x1056","1056x1568","1472x1088","1088x1472","1728x960","960x1728"]}},{id:"cogvideox-3",name:"CogVideoX-3",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["1080p"]}},{id:"cogvideox-flash",name:"CogVideoX Flash (Free)",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:6}},{id:"glm-tts",name:"GLM-TTS",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech"],voices:["tongtong","chuichui","xiaochen","jam","kazi","douji","luodo"],maxCharacters:1024,formats:["wav","pcm"]}},{id:"glm-tts-clone",name:"GLM-TTS Clone",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"voice_clone",mediaCapabilities:{type:"voice_clone",maxSampleDurationSeconds:30,maxSampleSizeMB:10,formats:["wav","mp3"]}},{id:"glm-asr-2512",name:"GLM-ASR-2512",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"stt",mediaCapabilities:{type:"stt",languages:["zh","en"],maxDurationSeconds:30,formats:["wav","mp3"]}},{id:"glm-4-voice",name:"GLM-4-Voice",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",modalities:["text","audio"],vad:!0,toolCalling:!1}},{id:"glm-realtime-flash",name:"GLM Realtime Flash",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!0,mediaType:"realtime_video",mediaCapabilities:{type:"realtime_video",modalities:["text","audio","video"],vad:!0,toolCalling:!1}},{id:"glm-realtime-air",name:"GLM Realtime Air",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!0,mediaType:"realtime_video",mediaCapabilities:{type:"realtime_video",modalities:["text","audio","video"],vad:!0,toolCalling:!1}},{id:"embedding-3",name:"Embedding-3",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:2048,maxTokens:3072}},{id:"embedding-2",name:"Embedding-2",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:1024,maxTokens:512}},{id:"rerank",name:"GLM Rerank",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"rerank",mediaCapabilities:{type:"rerank",maxDocuments:128,maxQueryLength:4096,maxDocumentLength:4096}},{id:"glm-ocr",name:"GLM-OCR",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"document_parsing",mediaCapabilities:{type:"document_parsing",supportedFormats:["pdf","jpg","png"],maxPageCount:100,maxFileSizeMB:50}}]},{id:"zhipu-openai",name:"\u93C5\u9E3F\u6C28 GLM OpenAI (Zhipu)",group:"zhipu",transport:"openai-chat",baseUrl:"https://open.bigmodel.cn/api/paas/v4",apiKeyEnvVars:["ZHIPU_API_KEY","GLM_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"glm-5.1",quirks:{supportsReasoningEffort:!0,supportsThinkingParam:!0,supportsToolStream:!0,builtinWebSearch:!0,builtinCodeInterpreter:!0},models:[{id:"glm-5.1",name:"GLM-5.1",contextWindow:2e5,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:6,costOutput:24,costCacheRead:1.3},{id:"glm-5",name:"GLM-5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-5-turbo",name:"GLM-5 Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1,costCacheRead:.1},{id:"glm-4.7",name:"GLM-4.7",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.6",name:"GLM-4.6",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.5-air",name:"GLM-4.5 Air",contextWindow:131072,maxOutput:98304,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1.5,costCacheRead:.1},{id:"glm-4-long",name:"GLM-4 Long",contextWindow:1e6,maxOutput:4096,toolCall:!0,reasoning:!1,vision:!1,costInput:.1,costOutput:.1},{id:"glm-4.7-flash",name:"GLM-4.7 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-4.5-flash",name:"GLM-4.5 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-5v-turbo",name:"GLM-5V Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:1},{id:"glm-4.6v",name:"GLM-4.6V",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:1,costOutput:3.2},{id:"glm-4.6v-flash",name:"GLM-4.6V Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!0,costInput:0,costOutput:0}]},{id:"zhipu-coding",name:"\u93C5\u9E3F\u6C28 GLM Coding (Zhipu)",group:"zhipu",transport:"openai-chat",baseUrl:"https://open.bigmodel.cn/api/coding/paas/v4",apiKeyEnvVars:["ZHIPU_API_KEY","GLM_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"codegeex-4",quirks:{supportsReasoningEffort:!0,supportsThinkingParam:!0,supportsToolStream:!0},models:[{id:"codegeex-4",name:"CodeGeeX-4",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.1,costOutput:.1}]},{id:"minimax",name:"MiniMax",group:"minimax",transport:"anthropic-messages",baseUrl:"https://api.minimaxi.com/anthropic",apiKeyEnvVars:["MINIMAX_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"MiniMax-M2.7",omitZeroTemperature:!0,quirks:{filterImageBlocks:!0},models:[{id:"MiniMax-M2.7",name:"MiniMax M2.7",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2,costCacheRead:.06,costCacheWrite:.375},{id:"MiniMax-M2.7-highspeed",name:"MiniMax M2.7 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2,costCacheRead:.06,costCacheWrite:.375},{id:"MiniMax-M2.5",name:"MiniMax M2.5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6,costCacheRead:.03,costCacheWrite:.19},{id:"MiniMax-M2.5-highspeed",name:"MiniMax M2.5 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6,costCacheRead:.03,costCacheWrite:.19},{id:"MiniMax-M2.1",name:"MiniMax M2.1 (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.1-highspeed",name:"MiniMax M2.1 Highspeed (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2",name:"MiniMax M2 (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.1,costOutput:.4},{id:"music-2.6",name:"MiniMax Music 2.6",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"music",mediaCapabilities:{type:"music",operations:["text2music"],maxDurationSeconds:300,formats:["mp3","wav"]}},{id:"music-cover",name:"MiniMax Music Cover",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"music",mediaCapabilities:{type:"music",operations:["cover"],maxDurationSeconds:300,formats:["mp3","wav"]}},{id:"MiniMax-Hailuo-2.3",name:"Hailuo 2.3",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["768P","1080P"]}},{id:"MiniMax-Hailuo-2.3-Fast",name:"Hailuo 2.3 Fast",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["768P","1080P"]}},{id:"MiniMax-Hailuo-02",name:"Hailuo 02",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["512P","768P","1080P"]}},{id:"image-01",name:"MiniMax Image 01",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["512x512","1024x1024","2048x2048"]}},{id:"image-01-live",name:"MiniMax Image 01 Live",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024"]}},{id:"speech-2.8-hd",name:"MiniMax Speech 2.8 HD",contextWindow:1e4,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],formats:["mp3","pcm","flac","wav","opus"]}},{id:"speech-2.8-turbo",name:"MiniMax Speech 2.8 Turbo",contextWindow:1e4,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],formats:["mp3","pcm","flac","wav","opus"]}},{id:"voice-clone",aliases:["minimax-voice-clone"],name:"MiniMax Voice Clone",contextWindow:0,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"voice_clone",mediaCapabilities:{type:"voice_clone",maxSampleDurationSeconds:30,maxSampleSizeMB:20,formats:["mp3","wav","m4a"]}}]},{id:"minimax-openai",name:"MiniMax (OpenAI)",group:"minimax",transport:"openai-chat",baseUrl:"https://api.minimaxi.com/v1",apiKeyEnvVars:["MINIMAX_API_KEY"],authType:"bearer",isAggregator:!1,omitZeroTemperature:!0,defaultModel:"MiniMax-M2.7",quirks:{supportsReasoningSplit:!0},models:[{id:"MiniMax-M2.7",aliases:["minimax-m2.7"],name:"MiniMax M2.7",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2},{id:"MiniMax-M2.7-highspeed",name:"MiniMax M2.7 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2},{id:"MiniMax-M2.5",name:"MiniMax M2.5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.5-highspeed",name:"MiniMax M2.5 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.1",name:"MiniMax M2.1 (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.1-highspeed",name:"MiniMax M2.1 Highspeed (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6}]},{id:"moonshot",name:"Moonshot (Kimi)",transport:"openai-chat",baseUrl:"https://api.moonshot.cn",apiKeyEnvVars:["MOONSHOT_API_KEY"],authType:"bearer",isAggregator:!1,omitZeroTemperature:!0,defaultModel:"kimi-k2.6",quirks:{supportsReasoningEffort:!0,supportsThinkingParam:!0,builtinWebSearch:!0},models:[{id:"kimi-k2.6",name:"Kimi K2.6",contextWindow:262144,maxOutput:262144,toolCall:!0,reasoning:!0,vision:!0,costInput:.95,costOutput:4,costCacheRead:.16},{id:"kimi-k2.5",name:"Kimi K2.5",contextWindow:262144,maxOutput:262144,toolCall:!0,reasoning:!0,vision:!0,costInput:.8,costOutput:4,costCacheRead:.2},{id:"moonshot-v1-128k",name:"Moonshot V1 128K",contextWindow:131072,maxOutput:8192,toolCall:!0,reasoning:!1,vision:!1,costInput:.84,costOutput:.84}]},{id:"volcengine",name:"\u749E\u55D7\u5BD8 (Doubao/Volcengine)",transport:"volcengine-responses",baseUrl:"https://ark.cn-beijing.volces.com/api",apiKeyEnvVars:["ARK_API_KEY","DOUBAO_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"doubao-seed-2-0-lite-260215",models:[{id:"doubao-seed-2-0-pro-260215",name:"Doubao Seed 2.0 Pro",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-lite-260428",aliases:["doubao-seed-2-0-lite"],name:"Doubao Seed 2.0 Lite (0428)",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-lite-260215",name:"Doubao Seed 2.0 Lite",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-mini-260428",name:"Doubao Seed 2.0 Mini (0428)",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-mini-260215",name:"Doubao Seed 2.0 Mini",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-code-preview-260215",name:"Doubao Seed 2.0 Code Preview",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-1-8-251228",name:"Doubao Seed 1.8",contextWindow:262144,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seedance-2-0-260128",aliases:["doubao-seedance-2-0"],name:"Doubao Seedance 2.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video","video2video","edit","merge","upscale"],maxDurationSeconds:15,resolutions:["480p","720p","1080p"],aspectRatios:["16:9","9:16","1:1"],fps:[24]}},{id:"doubao-seedance-2-0-fast-260128",aliases:["doubao-seedance-2-0-fast"],name:"Doubao Seedance 2.0 Fast",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video","video2video","edit","merge","upscale"],maxDurationSeconds:15,resolutions:["480p","720p"],aspectRatios:["16:9","9:16","1:1"],fps:[24]}},{id:"doubao-seedream-5-0-260128",aliases:["doubao-seedream-5-0"],name:"Doubao Seedream 5.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["512x512","1024x1024","2K"]}},{id:"doubao-seedream-4-5-251128",aliases:["doubao-seedream-4-5"],name:"Doubao Seedream 4.5",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["512x512","1024x1024","2K"]}},{id:"doubao-seed3d-2-0-260328",aliases:["doubao-seed3d-2-0"],name:"Doubao Seed3D 2.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"3d",mediaCapabilities:{type:"3d",operations:["img2_3d"],outputFormats:["glb","obj","usd","usdz"]}},{id:"hyper3d-gen2-260112",aliases:["hyper3d-gen2"],name:"Hyper3D Gen2",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"3d",mediaCapabilities:{type:"3d",operations:["text2_3d","img2_3d"],outputFormats:["glb","obj"]}},{id:"hitem3d-2-0-251223",aliases:["hitem3d-2-0"],name:"HiTem3D 2.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"3d",mediaCapabilities:{type:"3d",operations:["img2_3d"],outputFormats:["glb","obj","usd"]}}]},{id:"openai",name:"OpenAI",transport:"openai-responses",baseUrl:"https://api.openai.com",apiKeyEnvVars:["OPENAI_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"gpt-5.5",quirks:{builtinWebSearch:!0,builtinCodeInterpreter:!0,builtinFileSearch:!0},models:[{id:"gpt-5.5",name:"GPT-5.5",contextWindow:105e4,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:30,costCacheRead:.5},{id:"gpt-5.4",name:"GPT-5.4",contextWindow:105e4,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:2.5,costOutput:15,costCacheRead:.25},{id:"gpt-5.4-mini",name:"GPT-5.4 Mini",contextWindow:4e5,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:.75,costOutput:4.5,costCacheRead:.075},{id:"gpt-5.4-nano",name:"GPT-5.4 Nano",contextWindow:4e5,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:.2,costOutput:1.25,costCacheRead:.02},{id:"gpt-image-2",name:"GPT Image 2",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img","inpainting"],sizes:["1024x1024","1536x1024","1024x1536","auto"],transparentBackground:!0}},{id:"gpt-realtime-2",name:"GPT Realtime 2",contextWindow:128e3,maxOutput:16e3,toolCall:!0,reasoning:!0,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!0}},{id:"gpt-realtime-translate",name:"GPT Realtime Translate",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!1}},{id:"gpt-realtime-1.5",name:"GPT Realtime 1.5",contextWindow:128e3,maxOutput:16e3,toolCall:!0,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!0}},{id:"gpt-realtime-mini",name:"GPT Realtime Mini",contextWindow:128e3,maxOutput:16e3,toolCall:!0,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!0}}]},{id:"anthropic",name:"Anthropic",transport:"anthropic-messages",baseUrl:"https://api.anthropic.com",apiKeyEnvVars:["ANTHROPIC_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"claude-opus-4-7",quirks:{supportsDocumentVision:!0},models:[{id:"claude-opus-4-7",name:"Claude Opus 4.7",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5,costCacheWrite:6.25},{id:"claude-opus-4-6",name:"Claude Opus 4.6",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5,costCacheWrite:6.25},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6",contextWindow:1e6,maxOutput:64e3,toolCall:!0,reasoning:!0,vision:!0,costInput:3,costOutput:15,costCacheRead:.3,costCacheWrite:3.75},{id:"claude-sonnet-4-5",name:"Claude Sonnet 4.5",contextWindow:2e5,maxOutput:64e3,toolCall:!0,reasoning:!0,vision:!0,costInput:3,costOutput:15,costCacheRead:.3,costCacheWrite:3.75},{id:"claude-haiku-4-5",name:"Claude Haiku 4.5",contextWindow:2e5,maxOutput:64e3,toolCall:!0,reasoning:!0,vision:!0,costInput:1,costOutput:5,costCacheRead:.1,costCacheWrite:1.25}]},{id:"google",name:"Google Gemini",transport:"gemini-generatecontent",baseUrl:"https://generativelanguage.googleapis.com/v1beta",apiKeyEnvVars:["GOOGLE_API_KEY","GEMINI_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"gemini-3-flash-preview",quirks:{builtinWebSearch:!0,builtinCodeInterpreter:!0,builtinUrlContext:!0,builtinMapsGrounding:!0,builtinFileSearch:!0,supportsDocumentVision:!0},models:[{id:"gemini-3.1-pro-preview",name:"Gemini 3.1 Pro",contextWindow:1048576,maxOutput:65536,toolCall:!0,reasoning:!0,reasoningRequired:!0,vision:!0,costInput:2,costOutput:12},{id:"gemini-3-flash-preview",name:"Gemini 3 Flash",contextWindow:1048576,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:3},{id:"gemini-3.1-flash-lite",name:"Gemini 3.1 Flash-Lite",contextWindow:1048576,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.25,costOutput:1.5},{id:"gemini-3.1-flash-image-preview",name:"Gemini 3.1 Flash Image (Nano Banana 2)",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["1024x1024"]}},{id:"gemini-3-pro-image-preview",name:"Gemini 3 Pro Image (Nano Banana Pro)",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["1024x1024"]}},{id:"veo-3.1-generate-preview",name:"Veo 3.1 Standard",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:8,resolutions:["720P","1080P","4K"]}},{id:"veo-3.1-fast-generate-preview",name:"Veo 3.1 Fast",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:8,resolutions:["720P","1080P","4K"]}},{id:"veo-3.1-lite-generate-preview",name:"Veo 3.1 Lite",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:8,resolutions:["720P","1080P"]}},{id:"lyria-3-pro-preview",name:"Lyria 3 Pro",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"music",mediaCapabilities:{type:"music",operations:["text2music"],maxDurationSeconds:300,formats:["mp3"]}},{id:"lyria-3-clip-preview",name:"Lyria 3 Clip",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"music",mediaCapabilities:{type:"music",operations:["text2music"],maxDurationSeconds:30,formats:["mp3"]}},{id:"lyria-realtime-exp",name:"Lyria RealTime (Experimental)",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"music_realtime",mediaCapabilities:{type:"music",operations:["realtime"],formats:["wav"]}},{id:"gemini-3.1-flash-tts-preview",name:"Gemini 3.1 Flash TTS",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:1,costOutput:20,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech"],maxCharacters:8e3,formats:["mp3","wav"]}},{id:"gemini-embedding-2",name:"Gemini Embedding 2 (Multimodal)",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:.2,costOutput:0,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:3072,maxTokens:8192}}]},{id:"openrouter",name:"OpenRouter",transport:"openai-chat",baseUrl:"https://openrouter.ai/api",apiKeyEnvVars:["OPENROUTER_API_KEY"],authType:"bearer",isAggregator:!0,defaultModel:"anthropic/claude-opus-4.7",extraHeaders:{"HTTP-Referer":"https://claw.bot","X-Title":"XiaozhiClaw"},models:[{id:"anthropic/claude-opus-4.7",name:"Claude Opus 4.7 (via OpenRouter)",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5},{id:"anthropic/claude-opus-4.6",name:"Claude Opus 4.6 (via OpenRouter)",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5},{id:"deepseek/deepseek-v4-flash",name:"DeepSeek V4 Flash (via OpenRouter)",contextWindow:1048576,maxOutput:393216,toolCall:!0,reasoning:!0,vision:!1,costInput:.14,costOutput:.28,costCacheRead:.028}]},{id:"qwen-coding",name:"Alibaba Qwen (Coding Plan)",transport:"anthropic-messages",baseUrl:"https://coding.dashscope.aliyuncs.com/apps/anthropic",apiKeyEnvVars:["DASHSCOPE_API_KEY","QWEN_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"qwen3-coder-plus",models:[{id:"qwen3-coder-plus",name:"Qwen3 Coder Plus (Coding Plan)",contextWindow:262144,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!1},{id:"qwen3-coder-flash",name:"Qwen3 Coder Flash (Coding Plan)",contextWindow:262144,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!1}]}];import{existsSync as vs,mkdirSync as Ms,readFileSync as Rs,writeFileSync as Es}from"node:fs";import{join as As}from"node:path";var Is="https://models.dev/api.json",Os=3e4,Us=1440*60*1e3,Ls=300*1e3,Ro={deepseek:"deepseek",qwen:"qwen","qwen-coding-plan":"qwen-coding","alibaba-cn":"qwen",zhipuai:"zhipu",minimax:"minimax",moonshot:"moonshot",moonshotai:"moonshot","moonshotai-cn":"moonshot",doubao:"volcengine","bytedance-seed":"volcengine",volcengine:"volcengine",openai:"openai",anthropic:"anthropic",google:"google",openrouter:"openrouter"},Z=class{cache=null;cacheDir;cacheFile;ttlMs;fetching=!1;lastFetchAttempt=0;constructor(e){this.cacheDir=e?.cacheDir??Q(),this.cacheFile=As(this.cacheDir,"model_catalog.json"),this.ttlMs=e?.ttlMs??Us}getModels(e){this.ensureLoaded();let n=this.cache?.providers.get(e);return n?[...n.models.values()]:[]}getModel(e,n){return this.ensureLoaded(),this.cache?.providers.get(e)?.models.get(n)}listProviderIds(){return this.ensureLoaded(),this.cache?[...this.cache.providers.keys()]:[]}getEmbeddingModels(e){return this.ensureLoaded(),this.cache?.embeddingModels.get(e)??[]}getDefaultEmbeddingModel(e){let n=this.getEmbeddingModels(e);return n.filter(s=>s.dimensions>=512)[0]??n[0]}getAllEmbeddingModels(){return this.ensureLoaded(),this.cache?.embeddingModels??new Map}async refreshCatalog(){return this.fetchRemote()}ensureLoaded(){this.cache&&!this.isStale()||(this.cache||this.loadFromDisk(),(!this.cache||this.isStale())&&this.backgroundFetch())}isStale(){return this.cache?Date.now()-this.cache.fetchedAt>this.ttlMs:!0}loadFromDisk(){try{if(!vs(this.cacheFile))return;let e=Rs(this.cacheFile,"utf8"),n=JSON.parse(e);if(!n.fetchedAt||!n.data)return;this.cache={fetchedAt:n.fetchedAt,providers:vo(n.data),embeddingModels:Mo(n.data)}}catch{}}saveToDisk(e){try{Ms(this.cacheDir,{recursive:!0});let n=JSON.stringify({fetchedAt:Date.now(),data:e},null,0);Es(this.cacheFile,n,"utf8")}catch{}}backgroundFetch(){this.fetching||Date.now()-this.lastFetchAttempt<Ls||(this.fetching=!0,this.fetchRemote().finally(()=>{this.fetching=!1}))}async fetchRemote(){this.lastFetchAttempt=Date.now();try{let e=await fetch(Is,{signal:AbortSignal.timeout(Os),headers:{Accept:"application/json"}});if(!e.ok)return!1;let n=await e.json(),o=vo(n);return o.size===0?!1:(this.cache={fetchedAt:Date.now(),providers:o,embeddingModels:Mo(n)},this.saveToDisk(n),!0)}catch{return!1}}};function vo(t){let e=new Map;if(!t||typeof t!="object")return e;for(let[n,o]of Object.entries(t)){let s=Ro[n];if(!s||!o||typeof o!="object")continue;let a=o.models;if(!a||typeof a!="object")continue;let r=e.get(s);r||(r={models:new Map},e.set(s,r));for(let[d,h]of Object.entries(a)){if(!h||typeof h!="object"||r.models.has(d))continue;let p=h,f=typeof p.family=="string"?p.family:"";if(Eo(f,d)||d.toLowerCase().includes("reranker"))continue;let b=p.cost??{},y=p.limit??{},_=p.modalities??{},k=Array.isArray(_.input)?_.input:[],w=Array.isArray(_.output)?_.output:[],L=Ps(w,k,d);r.models.set(d,{id:d,name:typeof p.name=="string"?p.name:d,contextWindow:typeof y.context=="number"?y.context:2e5,maxOutput:typeof y.output=="number"?y.output:8192,toolCall:p.tool_call===!0,reasoning:p.reasoning===!0,vision:p.attachment===!0||k.includes("image"),costInput:typeof b.input=="number"?b.input:void 0,costOutput:typeof b.output=="number"?b.output:void 0,costCacheRead:typeof b.cache_read=="number"?b.cache_read:void 0,costCacheWrite:typeof b.cache_write=="number"?b.cache_write:void 0,mediaType:L})}}return e}function Ps(t,e,n){if(t.includes("video"))return"video";if(t.includes("image")&&!t.includes("text"))return"image";if(t.includes("audio")&&!t.includes("text"))return"tts";if(t.includes("3d"))return"3d";if(e.includes("video")&&t.includes("text"))return"video_understanding";let o=n.toLowerCase();if(o.includes("tts")||o.includes("speech")||o.includes("cosyvoice"))return"tts";if(o.includes("music")||o.includes("suno"))return"music";if(o.includes("seedream")||o.includes("image")||o.includes("dall"))return"image";if(o.includes("seedance")||o.includes("video"))return"video"}var Ds={qwen:[{id:"text-embedding-v3",name:"Text Embedding v3",providerId:"qwen",dimensions:1024,maxInputTokens:8192,costInput:.7,family:"text-embedding"},{id:"text-embedding-v2",name:"Text Embedding v2",providerId:"qwen",dimensions:1536,maxInputTokens:2048,costInput:.7,family:"text-embedding"}],zhipu:[{id:"embedding-3",name:"Embedding-3",providerId:"zhipu",dimensions:2048,maxInputTokens:8192,costInput:.5,family:"text-embedding"},{id:"embedding-2",name:"Embedding-2",providerId:"zhipu",dimensions:1024,maxInputTokens:512,costInput:.5,family:"text-embedding"}],minimax:[{id:"embo-01",name:"embo-01",providerId:"minimax",dimensions:1536,maxInputTokens:4096,costInput:.5,family:"text-embedding"}],volcengine:[{id:"doubao-embedding-vision-251215",name:"Doubao Embedding Vision (Latest)",providerId:"volcengine",dimensions:1024,maxInputTokens:128e3,costInput:.5,family:"text-embedding"},{id:"doubao-embedding-vision-250615",name:"Doubao Embedding Vision",providerId:"volcengine",dimensions:1024,maxInputTokens:128e3,costInput:.5,family:"text-embedding"}],google:[{id:"text-embedding-004",name:"Text Embedding 004",providerId:"google",dimensions:768,maxInputTokens:2048,costInput:.025,family:"text-embedding"},{id:"gemini-embedding-001",name:"Gemini Embedding",providerId:"google",dimensions:3072,maxInputTokens:8192,costInput:0,family:"text-embedding"}]},$s=new Set(["text-embedding","bge","cohere-embed","plamo"]),Ns=[/embed/i,/^bge-/i,/^gte-/i,/^e5-/i,/multi-qa-/i];function Eo(t,e){return t&&$s.has(t)?!0:Ns.some(n=>n.test(e))}function Mo(t){let e=new Map;if(!t||typeof t!="object")return e;for(let[n,o]of Object.entries(t)){let s=Ro[n];if(!s||!o||typeof o!="object")continue;let a=o.models;if(!(!a||typeof a!="object"))for(let[r,d]of Object.entries(a)){if(!d||typeof d!="object")continue;let h=d,p=typeof h.family=="string"?h.family:"";if(!Eo(p,r)||r.toLowerCase().includes("reranker"))continue;let f=h.limit??{},b=h.cost??{},y=typeof f.output=="number"?f.output:0,_=typeof f.context=="number"?f.context:512;if(y<=1)continue;let k={id:r,name:typeof h.name=="string"?h.name:r,providerId:s,dimensions:y,maxInputTokens:_,costInput:typeof b.input=="number"?b.input:void 0,family:p},w=e.get(s);w||(w=[],e.set(s,w)),w.push(k)}}for(let n of e.values())n.sort((o,s)=>{let i=o.costInput??0,a=s.costInput??0;return i!==a?i-a:s.dimensions-o.dimensions});for(let[n,o]of Object.entries(Ds)){let s=e.get(n);(!s||s.length===0)&&e.set(n,[...o])}return e}var Fs={claude:"anthropic",gemini:"google",doubao:"volcengine"},ue=class{builtins=new Map;catalog;overrides=new Map;constructor(e){for(let n of bt)this.builtins.set(n.id,n);this.catalog=e?.catalog??new Z}applyOverride(e,n){this.overrides.set(e,{...this.overrides.get(e),...n})}getProvider(e){let n=Fs[e]??e,o=this.builtins.get(n),s=this.overrides.get(n);if(!(!o&&!s))return!o&&s?!s.id||!s.transport||!s.baseUrl?void 0:{id:s.id,name:s.name??s.id,transport:s.transport,baseUrl:s.baseUrl,apiKeyEnvVars:s.apiKeyEnvVars??[],authType:s.authType??"bearer",isAggregator:s.isAggregator??!1,defaultModel:s.defaultModel,models:s.models}:o&&!s?o:{...o,...s,models:s.models??o.models}}listProviders(){let e=new Map;for(let[n,o]of this.builtins)e.set(n,o);for(let[n]of this.overrides){let o=this.getProvider(n);o&&e.set(n,o)}return[...e.values()]}listModels(e){let o=this.getProvider(e)?.models??[],s=this.catalog.getModels(e);if(s.length===0)return o;let i=new Map;for(let a of s)i.set(a.id,a);for(let a of o)i.set(a.id,a);return[...i.values()]}getModelInfo(e,n){return this.listModels(e).find(o=>o.id===n)}async refreshCatalog(){return this.catalog.refreshCatalog()}resolveApiKey(e,n){if(n)return n;let o=this.getProvider(e);if(o)for(let s of o.apiKeyEnvVars){let i=process.env[s];if(i?.trim())return i.trim()}}};var gl=20*1024*1024;import{createHmac as Yl,randomUUID as Jl}from"node:crypto";import{join as _c}from"node:path";import{mkdirSync as kc,appendFileSync as wc}from"node:fs";var Sc=So();import{mkdir as Ks,writeFile as Vs}from"fs/promises";import{join as Ao}from"path";import{tmpdir as Xs}from"os";var Ys="tool-results",Io="<persisted-output>",Js="</persisted-output>";function Oo(){return{seenIds:new Set,replacements:new Map}}function Uo(t){return Ao(Xs(),"qlogicagent-sessions",t,Ys)}async function Qs(t){try{await Ks(Uo(t),{recursive:!0})}catch{}}function Zs(t,e){let n=e.replace(/[^a-zA-Z0-9_-]/g,"_");return Ao(Uo(t),`${n}.txt`)}function qs(t,e){if(t.length<=e)return{preview:t,hasMore:!1};let o=t.slice(0,e).lastIndexOf(`
9
- `),s=o>e*.5?o:e;return{preview:t.slice(0,s),hasMore:!0}}function Lo(t){return t.includes(Io)}async function Po(t,e,n){await Qs(n);let o=Zs(n,e);try{await Vs(o,t,{encoding:"utf-8",flag:"wx"})}catch(a){if(a.code!=="EEXIST")return null}let{preview:s,hasMore:i}=qs(t,qe);return{filepath:o,originalSize:t.length,preview:s,hasMore:i}}function Do(t){let e=`${Io}
3
+ `));if(s>e*.5)return n.slice(0,s+1)+`
4
+ [...truncated: ${t.length-s-1} chars omitted]`}let i=n.lastIndexOf(`
5
+ `);return i>e*.7?n.slice(0,i)+`
6
+ [...truncated: ${t.length-i} chars omitted]`:n+`
7
+ [...truncated: ${t.length-e} chars omitted]`}function He(...t){return{compress(e,n){let o=e,i=0,s=[];for(let a of t){let r=a.compress(o,n);o=r.messages,i+=r.droppedCount,r.droppedCount>0&&s.push(r.strategy)}return{messages:o,droppedCount:i,strategy:s.length>0?s.join("+"):"none"}}}}var Ht={modelContextWindow:128e3,targetUsageRatio:.75,minBudget:16e3,maxBudget:12e4};function Ke(t={}){let e={...Ht,...t},n=Math.floor(e.modelContextWindow*e.targetUsageRatio);return Math.max(e.minBudget,Math.min(n,e.maxBudget))}function Ve(t,e){let n=t/e;return n<=.8?"none":n<=1?"trim-only":n<=1.5?"sliding-window":"llm-summarize"}var re=class{events=[];maxEvents;constructor(e=100){this.maxEvents=e}record(e){this.events.push(e),this.events.length>this.maxEvents&&this.events.shift()}snapshot(){let e=this.events.length;if(e===0)return{totalCompressions:0,totalLlmCalls:0,totalCacheInvalidations:0,averageCompressionRatio:1,averageLatencyMs:0,totalTokensSaved:0,recentEvents:[]};let n=0,o=0,i=0,s=0,a=0;for(let r of this.events)n+=r.tokensBefore>0?r.tokensAfter/r.tokensBefore:1,o+=r.latencyMs,i+=Math.max(0,r.tokensBefore-r.tokensAfter),r.usedLlm&&s++,r.cacheInvalidated&&a++;return{totalCompressions:e,totalLlmCalls:s,totalCacheInvalidations:a,averageCompressionRatio:n/e,averageLatencyMs:o/e,totalTokensSaved:i,recentEvents:this.events.slice(-10)}}reset(){this.events.length=0}},ae=class{engines=new Map;activeId;register(e){this.engines.set(e.id,e)}activate(e){return this.engines.has(e)?(this.activeId=e,!0):!1}getActive(){return this.activeId?this.engines.get(this.activeId):void 0}listEngines(){return Array.from(this.engines.values()).map(e=>({id:e.id,label:e.label,active:e.id===this.activeId}))}};function Kt(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}var Fn=new Set(["file_read","read","Read","bash","shell","Bash","grep","search","Grep","grep_search","glob","Glob","file_search","web_search","WebSearch","web_fetch","WebFetch","file_edit","edit","Edit","file_write","write","Write"]),X=class{constructor(e=20,n=Kt){this.preserveRecentCount=e;this.estimateTokens=n}preserveRecentCount;estimateTokens;compress(e,n){if(e.length<=this.preserveRecentCount)return{messages:e,droppedCount:0,strategy:"micro-compact"};let o=e.length-this.preserveRecentCount,i=0,s=0;return{messages:e.map((r,d)=>{if(d>=o||r.role!=="tool"||typeof r.content!="string"||!r.name||!Fn.has(r.name)||r.content.length<=200)return r;let h=this.estimateTokens(r);return s+=h,i++,{...r,content:`[result cleared \u2014 ${r.content.length} chars]`}}),droppedCount:i,strategy:"micro-compact",metrics:i>0?{tokensBefore:0,tokensAfter:0,compressionRatio:0,latencyMs:0,usedLlm:!1,cacheInvalidated:!1}:void 0}}};function Xe(t,e,n=Kt){if(e.size===0)return{messages:t,tokensFreed:0,removedCount:0};let o=0,i=0,s=[];for(let r of t){let d=r.tool_call_id??"";if(d&&e.has(d)){o+=n(r),i++,e.delete(d);continue}s.push(r)}let a=i>0?{role:"system",content:`[${i} messages removed by snip]`}:void 0;return{messages:s,tokensFreed:o,removedCount:i,boundaryMessage:a}}function Ye(){return{stages:[]}}function Je(t,e,n){let o=n?.thresholdMessages??40;if(t.filter(r=>r.role!=="system").length<=o)return{messages:t,stagedCount:0};let s=Vt(t,e),a=Bn(s,e,o);if(a.length===0)return{messages:s,stagedCount:0};for(let r of a)e.stages.push(r);return s=Vt(t,e),{messages:s,stagedCount:a.length}}function Qe(t,e){let n=0;for(let o of e.stages)o.committed||(o.committed=!0,n++);return n===0?{messages:t,committed:0}:{messages:Xt(t,e),committed:n}}function Vt(t,e){return e.stages.filter(o=>o.committed).length===0?t:Xt(t,e)}function Xt(t,e){let n=e.stages.filter(i=>i.committed).sort((i,s)=>s.range[0]-i.range[0]),o=[...t];for(let i of n){let[s,a]=i.range;if(s>=o.length)continue;let r=Math.min(a,o.length),d={role:"system",content:i.summary};o.splice(s,r-s,d)}return o}function Bn(t,e,n){let o=Math.max(0,t.length-Math.floor(n/2)),i=[],s=new Set(e.stages.map(d=>`${d.range[0]}-${d.range[1]}`)),a=-1,r=0;for(let d=0;d<o;d++){let h=t[d];if(h.role==="tool"||h.role==="assistant"&&typeof h.content=="string"&&h.content==="")a<0&&(a=d),r++;else{if(r>=3){let f=`${a}-${a+r}`;s.has(f)||i.push({id:`collapse_${a}_${a+r}`,range:[a,a+r],summary:`[${r} tool results collapsed]`,committed:!1})}a=-1,r=0}}if(r>=3){let d=`${a}-${a+r}`;s.has(d)||i.push({id:`collapse_${a}_${a+r}`,range:[a,a+r],summary:`[${r} tool results collapsed]`,committed:!1})}return i}import{existsSync as et,readFileSync as yo,writeFileSync as Gn,readdirSync as bo,mkdirSync as jn}from"node:fs";import{join as tt,dirname as Wn}from"node:path";var Yt=Math.min(Math.max(1,Number(process.env.TOOL_LOOP_DEFAULT_BUDGET)||25),100),Jt=3,Qt=2,xe=2,Zt=128e3,qt=13e3,eo=16384,to=65536,oo=3,no=65536,Ze=500,io=3,so=5e4,ro=2e5,qe=2e3,ao=3e4,lo=3,le=2;var co=20;var uo=3,po=2,mo=300*1e3,fo=3,go=720*60*60*1e3;var Xs=300*1e3;var Ys=3600*1e3;var Js=50*1024,Qs=500*1024,Zs=500*1024*1024,qs=50*1024*1024;var er=60*1024;var To=0;var zn="skill-patterns.json";function _o(t){return tt(t,".qlogicagent",zn)}function Hn(t){let e=_o(t);try{return JSON.parse(yo(e,"utf8"))}catch{return{version:1,patterns:{}}}}function ho(t,e){let n=_o(t);jn(Wn(n),{recursive:!0}),Gn(n,JSON.stringify(e,null,2),"utf8")}function Kn(t){let e=Date.now()-go;for(let[n,o]of Object.entries(t.patterns))new Date(o.lastSeen).getTime()<e&&delete t.patterns[n]}function xo(t,e){if(e.length===0)return!1;let n=ke(e),o=Hn(t);Kn(o);let i=new Date().toISOString(),s=o.patterns[n];if(s||(s={signature:n,count:0,firstSeen:i,lastSeen:i,promoted:!1},o.patterns[n]=s),s.promoted)return ho(t,o),!1;s.count++,s.lastSeen=i;let a=s.count>=fo;return a&&(s.promoted=!0),ho(t,o),a}function ke(t){return[...t].sort().join("+")}function Vn(t,e){if(!et(e))return null;let n=ke(t);try{let o=bo(e,{withFileTypes:!0});for(let i of o){if(!i.isDirectory())continue;let s=tt(e,i.name,"SKILL.md");try{let r=yo(s,"utf8").match(/^tools:\s*\n((?:\s+-\s+\S+\n?)+)/m);if(r){let d=r[1].split(`
8
+ `).map(h=>h.replace(/^\s*-\s*/,"").trim()).filter(Boolean);if(ke(d)===n)return i.name}}catch{}}}catch{}return null}function Xn(t){if(!et(t))return 0;try{return bo(t,{withFileTypes:!0}).filter(e=>e.isDirectory()&&et(tt(t,e.name,"SKILL.md"))).length}catch{return 0}}function Yn(t,e){return!(!t.ok||t.existingSkillName||!t.multiStep||t.toolCallCount<uo||t.distinctToolCount<po||Date.now()-To<mo||e?.projectSkillsDir&&(Xn(e.projectSkillsDir)>=co||e.tools.length>0&&Vn(e.tools,e.projectSkillsDir))||e?.projectRoot&&e.tools.length>0&&!xo(e.projectRoot,e.tools))}function Jn(t){return t.existingSkillName?t.feedback==="negative":!1}function we(t,e){return Jn(t)?{type:"skill.improve",skillName:t.existingSkillName,reason:"negative user feedback on existing skill execution"}:Yn(t,e)?(To=Date.now(),{type:"skill.create",suggestedName:e.suggestedName??`auto-skill-${e.tools.slice(0,3).join("-")}`,description:`Multi-step orchestration using ${e.tools.join(", ")}`,tools:e.tools,stepCount:t.toolCallCount}):null}function ko(t){return t.function&&typeof t.function=="object"&&typeof t.function.name=="string"?t.function.name.trim():typeof t.name=="string"?t.name.trim():""}function Qn(t){return t==="enabled-eligible"||t==="installed-awaiting-approval"}function Zn(t){return new Map((t??[]).map(e=>[e.toolName,e]))}function qn(t){if(!t.eligibility?.length)return[...t.tools];let e=Zn(t.eligibility);return t.tools.filter(n=>{let o=ko(n);if(!o)return!1;let i=e.get(o);return!i||Qn(i.status)})}function ei(t){let e=[],n=t.compatibility??{},o=t.toolChoice;if(t.thinkingEnabled&&n.requireAutoWhenThinking){let i=typeof o=="object"&&o&&!Array.isArray(o)?String(o.type??""):o;i&&i!=="auto"&&i!=="none"&&(e.push("tool_choice downgraded to auto because thinking mode requires auto/none compatibility."),o="auto")}if(o==="required"&&n.allowRequiredToolChoice===!1){let i=n.requiredFallback??"auto";e.push(`tool_choice=required is not supported by this provider; downgraded to ${i}.`),o=i}if(o&&typeof o=="object"&&!Array.isArray(o)&&o.type==="function"&&n.allowNamedToolChoice===!1){let i=n.namedFallback??"required";e.push(`named tool_choice is not supported by this provider; downgraded to ${i}.`),o=i}return{normalizedToolChoice:o,warnings:e}}function ot(t){let e=ei({toolChoice:t.toolChoice,thinkingEnabled:t.thinkingEnabled,compatibility:t.compatibility}),n=e.normalizedToolChoice,o=[...e.warnings],i=qn({tools:t.tools,eligibility:t.eligibility});if(!n||n==="auto")return{tools:i,normalizedToolChoice:n,warnings:o};if(n==="none")return{tools:[],normalizedToolChoice:"none",warnings:o};if(n==="required"){if(i.length===0)throw new Error("tool_choice=required but no tools were provided");return{tools:i,normalizedToolChoice:"required",extraSystemPrompt:"You must call one of the available tools before responding.",warnings:o}}if(typeof n=="object"&&!Array.isArray(n)&&n.type==="function"){let s=n.function??void 0,a=typeof s?.name=="string"?s.name.trim():"";if(!a)throw new Error("tool_choice.function.name is required");let r=i.filter(d=>ko(d)===a);if(r.length===0)throw new Error(`tool_choice requested unknown tool: ${a}`);return{tools:r,normalizedToolChoice:{type:"function",function:{name:a}},extraSystemPrompt:`You must call the ${a} tool before responding.`,warnings:o}}return{tools:i,normalizedToolChoice:n,warnings:o}}var ti=["stop","aborted","timeout","cancelled","interrupted","error"],oi=["tool_calls","toolCalls","function_call","functionCall","raw_tool_calls","rawToolCalls"];function wo(t){return t==null?[]:typeof t=="string"?t.length>0?[{type:"text",text:t}]:[]:Array.isArray(t)?t:[{type:"text",text:String(t)}]}function ni(t,e){return{...t,content:[...wo(t.content),...wo(e.content)]}}function ii(t){if(!t||typeof t!="object")return!1;if(t.function&&typeof t.function=="object"){let e=t.function.name;if(typeof e=="string"&&e.length>0)return!0}return typeof t.name=="string"&&t.name.length>0}function si(t){return new Set((t??ti).map(e=>e.trim().toLowerCase()))}function ri(t,e){return t?si(e).has(t.trim().toLowerCase()):!1}function nt(t){if(!Array.isArray(t)||t.length===0)return[...t];let e=t.map(r=>{if(r.role==="assistant"&&Array.isArray(r.tool_calls)){let d=r.tool_calls.filter(h=>ii(h));return{...r,...d.length>0?{tool_calls:d}:{tool_calls:void 0}}}return{...r}}),n=new Set;for(let r of e)if(!(r.role!=="assistant"||!Array.isArray(r.tool_calls)))for(let d of r.tool_calls)typeof d.id=="string"&&d.id&&n.add(d.id);let o=e.filter(r=>r.role!=="tool"?!0:!!(r.tool_call_id&&n.has(r.tool_call_id))),i=new Set;for(let r of o)r.role==="tool"&&typeof r.tool_call_id=="string"&&r.tool_call_id&&i.add(r.tool_call_id);let s=[];for(let r of o){if(r.role==="assistant"&&Array.isArray(r.tool_calls)&&r.tool_calls.length>0){let d=r.tool_calls.filter(h=>typeof h.id=="string"&&i.has(h.id));if(d.length===0){let{tool_calls:h,...p}=r;p.content!=null&&p.content!==""&&s.push(p);continue}if(d.length<r.tool_calls.length){s.push({...r,tool_calls:d});continue}}s.push(r)}let a=[];for(let r of s){let d=a.length>0?a[a.length-1]:void 0;if(r.role==="user"&&d?.role==="user"){a[a.length-1]=ni(d,r);continue}a.push(r)}return a}function it(t,e){return ri(e?.stopReason,e?.forcedStopReasons)?t.map(n=>{if(n.role!=="assistant")return{...n};let o={...n};for(let i of oi)delete o[i];return o}):[...t]}function st(t,e){let n=e?.placeholderToolResult??"Error: Tool loop interrupted before the tool result was replayed.",o=new Set;for(let s of t)s.role==="tool"&&typeof s.tool_call_id=="string"&&s.tool_call_id&&o.add(s.tool_call_id);let i=[];for(let s of t)if(i.push({...s}),!(s.role!=="assistant"||!Array.isArray(s.tool_calls)||s.tool_calls.length===0))for(let a of s.tool_calls)typeof a.id!="string"||!a.id||o.has(a.id)||(o.add(a.id),i.push({role:"tool",tool_call_id:a.id,content:n}));return i}function rt(t,e){let n=nt(t),o=it(n,e);return st(o,e)}function ai(t){let e=new Set,n=new Set;for(let o of t){if(o.role==="assistant"&&Array.isArray(o.tool_calls))for(let i of o.tool_calls)typeof i.id=="string"&&i.id&&e.add(i.id);o.role==="tool"&&typeof o.tool_call_id=="string"&&o.tool_call_id&&n.add(o.tool_call_id)}return[...e].filter(o=>!n.has(o))}function li(t){let e=new Set;for(let n of t)n.role==="tool"&&typeof n.tool_call_id=="string"&&n.tool_call_id&&e.add(n.tool_call_id);return[...e]}function ci(t){return{round:t.round??0,maxRounds:t.maxRounds,pendingToolCallIds:[...t.pendingToolCallIds??[]],completedToolCallIds:[...t.completedToolCallIds??[]],lastStopReason:t.lastStopReason,replayMessages:[...t.replayMessages??[]]}}function at(t,e){return{round:t.round+1,maxRounds:t.maxRounds,pendingToolCallIds:[...e.pendingToolCallIds??t.pendingToolCallIds],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function Ce(t,e){return{round:t.round,maxRounds:t.maxRounds,pendingToolCallIds:[],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function Se(t){let e=[],n=nt(t.replayMessages);n.length!==t.replayMessages.length&&e.push({kind:"drop-orphan-tool-result",detail:"Removed orphan tool results or invalid assistant tool calls."});let o=it(n,t.options);o.some((s,a)=>s!==n[a])&&e.push({kind:"strip-forced-stop-tool-metadata",detail:"Removed assistant tool-call metadata after forced stop."});let i=st(o,t.options);return i.length>o.length&&e.push({kind:"inject-placeholder-tool-result",detail:"Injected placeholder tool result for pending tool calls."}),{state:ci({maxRounds:t.maxRounds,round:t.round,lastStopReason:t.lastStopReason,replayMessages:i,pendingToolCallIds:ai(i),completedToolCallIds:li(i)}),recoveryActions:e}}var ui=new Set(["main","sdk","agent","compact","hook","verification","side_question"]);function lt(t){return t?ui.has(t):!0}function ct(t){return t===429||t===529}function ve(t,e=500,n=32e3){let o=Math.min(e*Math.pow(2,t-1),n);return o+Math.floor(Math.random()*o*.25)}var pr={maxBackoffMs:300*1e3,resetCapMs:360*60*1e3,heartbeatIntervalMs:3e4};function Me(){let t=process.env.QLOGICAGENT_PERSISTENT_RETRY;return t==="1"||t==="true"}var ce=class extends Error{constructor(n,o){super(`Model fallback triggered: ${n} -> ${o}`);this.originalModel=n;this.fallbackModel=o;this.name="FallbackTriggeredError"}originalModel;fallbackModel};function ut(t){return{promptTokens:0,hasAttemptedReactiveCompact:!1,currentMaxOutputTokens:t.maxOutputTokens,consecutiveTruncations:0,aborted:t.abortSignal?.aborted??!1}}function dt(t,e){if(t.aborted)return{level:"blocking",usagePercent:100,reason:"budget_exhausted"};let n=e.contextWindowTokens-e.responseBufferTokens-t.currentMaxOutputTokens,o=n>0?t.promptTokens/n*100:100;return t.promptTokens>=n?t.hasAttemptedReactiveCompact||!e.reactiveCompactEnabled?{level:"blocking",usagePercent:o,reason:"prompt_too_long"}:{level:"blocking",usagePercent:o,reason:"prompt_too_long"}:o>=85?{level:"warning",usagePercent:o,remainingTokens:n-t.promptTokens}:{level:"ok"}}function pt(t,e,n){let o=t.message?.toLowerCase()??"",i=t.status??0;return i===413||o.includes("prompt_too_long")||o.includes("context_length_exceeded")?!e.hasAttemptedReactiveCompact&&n.reactiveCompactEnabled?{action:"reactive_compact"}:{action:"abort",reason:"prompt_too_long_unrecoverable"}:i>=500&&i<600?{action:"retry",reason:`server_error_${i}`}:i===429?{action:"retry",reason:"rate_limited"}:i===401||i===403?{action:"abort",reason:"auth_error"}:i===404?{action:"abort",reason:"model_not_found"}:{action:"abort",reason:o||"unknown_error"}}function mt(t,e,n){if(!e.outputEscalationEnabled)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};if(t.consecutiveTruncations>=3)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};let o=Math.min(t.currentMaxOutputTokens*2,n);return o<=t.currentMaxOutputTokens?{shouldEscalate:!1,newMax:t.currentMaxOutputTokens}:{shouldEscalate:!0,newMax:o}}function ft(t,e){return t.aborted?!0:e.abortSignal?.aborted?(t.aborted=!0,!0):!1}var pi={maxConsecutiveFailures:3,minMessagesAfterCompact:4,targetUsagePercent:50};function gt(){return{consecutiveFailures:0,attemptedThisTurn:!1,lastCompactAt:null,toolsAtLastCompact:[]}}function J(t,e=pi){return!(t.attemptedThisTurn||t.consecutiveFailures>=e.maxConsecutiveFailures)}function ht(t,e){let n=t.get(e.index);n||(n={id:"",name:"",arguments:""},t.set(e.index,n)),e.id&&(n.id=e.id),e.name&&(n.name+=e.name),n.arguments+=e.arguments}import{writeFileSync as ua,mkdirSync as da}from"node:fs";import{join as ma}from"node:path";import{randomUUID as ga}from"node:crypto";import{join as yt}from"node:path";import{homedir as Ti,tmpdir as _i}from"node:os";function Co(){return process.env.QLOGICAGENT_HOME??yt(Ti()||_i(),".qlogicagent")}function Q(){return process.env.QLOGICAGENT_CACHE_DIR??yt(Co(),"cache")}function So(){return process.env.QLOGICAGENT_DEBUG_LOG_DIR??yt(Co(),"debug-logs")}import{writeFileSync as Ea,mkdirSync as Aa}from"node:fs";import{join as Oa}from"node:path";import{randomUUID as La}from"node:crypto";import{writeFileSync as _a,mkdirSync as xa}from"node:fs";import{join as wa}from"node:path";import{randomUUID as Sa}from"node:crypto";import{writeFileSync as Ba,mkdirSync as Ga}from"node:fs";import{join as Wa}from"node:path";import{randomUUID as Ha}from"node:crypto";var bt=[{id:"deepseek",name:"DeepSeek",transport:"anthropic-messages",baseUrl:"https://api.deepseek.com/anthropic",apiKeyEnvVars:["DEEPSEEK_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"deepseek-v4-flash",quirks:{useEffortInsteadOfBudget:!0,filterImageBlocks:!0,maxReasoningEffort:"max",supportsPrefixCompletion:!0,supportsThinkingParam:!0,disableThinkingByDefault:!0},models:[{id:"deepseek-v4-flash",name:"DeepSeek V4 Flash",contextWindow:1e6,maxOutput:384e3,toolCall:!0,reasoning:!0,vision:!1,costInput:.14,costOutput:.28,costCacheRead:.003},{id:"deepseek-v4-pro",name:"DeepSeek V4 Pro",contextWindow:1e6,maxOutput:384e3,toolCall:!0,reasoning:!0,vision:!1,costInput:1.74,costOutput:3.48,costCacheRead:.014}]},{id:"qwen",name:"Alibaba Qwen (DashScope)",transport:"anthropic-messages",baseUrl:"https://dashscope.aliyuncs.com/apps/anthropic",apiKeyEnvVars:["DASHSCOPE_API_KEY","QWEN_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"qwen3.6-plus",quirks:{supportsThinkingParam:!0,disableThinkingByDefault:!0},models:[{id:"qwen3.6-max-preview",name:"Qwen3.6 Max (Preview)",contextWindow:1e6,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:2,costOutput:8,costCacheRead:.2,costCacheWrite:2.5},{id:"qwen3.6-plus",name:"Qwen3.6 Plus",contextWindow:1e6,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:3,costCacheRead:.05,costCacheWrite:.625},{id:"qwen3.6-flash",name:"Qwen3.6 Flash",contextWindow:1e6,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.1,costOutput:.5,costCacheRead:.01,costCacheWrite:.125},{id:"qwq-plus",name:"QwQ Plus",contextWindow:131072,maxOutput:65536,toolCall:!0,reasoning:!0,reasoningRequired:!0,streamRequired:!0,vision:!1,costInput:.5,costOutput:3,costCacheRead:.05,costCacheWrite:.625},{id:"qwen-max",name:"Qwen Max",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:2,costOutput:6,costCacheRead:.2,costCacheWrite:2.5},{id:"qwen-plus",name:"Qwen Plus",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:.85,costCacheRead:.03,costCacheWrite:.375},{id:"qwen-flash",name:"Qwen Flash",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1},{id:"qwen-turbo",name:"Qwen Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!1},{id:"qwen-vl-max",name:"Qwen VL Max",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!0,costInput:3,costOutput:8.5},{id:"qwen3.5-omni-plus",name:"Qwen3.5 Omni Plus",contextWindow:131072,maxOutput:16384,toolCall:!1,reasoning:!1,streamRequired:!0,vision:!0},{id:"qwen3.5-omni-plus-realtime",name:"Qwen3.5 Omni Plus Realtime",contextWindow:131072,maxOutput:16384,toolCall:!1,reasoning:!1,streamRequired:!0,vision:!0,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",modalities:["text","audio"],vad:!0,toolCalling:!1}},{id:"qwen-vl-ocr",name:"Qwen VL OCR",contextWindow:131072,maxOutput:4096,toolCall:!1,reasoning:!1,vision:!0,mediaType:"document_parsing",mediaCapabilities:{type:"document_parsing",supportedFormats:["jpg","jpeg","png","bmp","tiff","pdf"],maxFileSizeMB:10}},{id:"qwen3-tts-voicedesign",name:"Qwen3 TTS VoiceDesign",contextWindow:32768,maxOutput:16384,toolCall:!1,reasoning:!1,vision:!1,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],maxCharacters:32768,formats:["mp3","wav"]}},{id:"cosyvoice-v2",name:"CosyVoice V2",contextWindow:1e4,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],maxCharacters:1e4,formats:["mp3","wav","pcm"]}},{id:"wan2.7-image-pro",name:"Wan 2.7 Image Pro",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","1280x720","720x1280","2048x2048","3840x2160"]}},{id:"wanx2.1-t2i-turbo",name:"Wan 2.1 Text-to-Image Turbo",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","720x1280","1280x720"]}},{id:"wan2.7-t2v-plus",name:"Wan 2.7 Text/Image-to-Video Plus",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:15,resolutions:["720P","1080P"]}},{id:"wanx2.1-t2v-turbo",name:"Wan 2.1 Text/Image-to-Video Turbo",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:5,resolutions:["480P","720P"]}},{id:"text-embedding-v4",name:"Text Embedding V4",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:1024,maxTokens:8192}},{id:"sensevoice-v1",name:"SenseVoice V1",contextWindow:0,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"stt",mediaCapabilities:{type:"stt",languages:["zh","en","ja","ko","yue"],formats:["wav","mp3","m4a","flac","aac"]}},{id:"wanx-background-generation-v2",name:"Wan Background Generation V2",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["inpainting"],sizes:["1024x1024","1280x720","720x1280"]}},{id:"qwen3-rerank",name:"Qwen3 Rerank",contextWindow:32768,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"rerank",mediaCapabilities:{type:"rerank",maxDocuments:100}}]},{id:"zhipu",name:"\u93C5\u9E3F\u6C28 GLM (Zhipu)",group:"zhipu",transport:"anthropic-messages",baseUrl:"https://open.bigmodel.cn/api/anthropic",apiKeyEnvVars:["ZHIPU_API_KEY","GLM_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"glm-5.1",quirks:{filterThinkingBlocks:!0},models:[{id:"glm-5.1",name:"GLM-5.1",contextWindow:2e5,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:6,costOutput:24,costCacheRead:1.3},{id:"glm-5",name:"GLM-5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-5-turbo",name:"GLM-5 Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1,costCacheRead:.1},{id:"glm-4.7",name:"GLM-4.7",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.6",name:"GLM-4.6",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.5-air",name:"GLM-4.5 Air",contextWindow:131072,maxOutput:98304,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1.5,costCacheRead:.1},{id:"glm-4-long",name:"GLM-4 Long",contextWindow:1e6,maxOutput:4096,toolCall:!0,reasoning:!1,vision:!1,costInput:.1,costOutput:.1},{id:"glm-4.7-flash",name:"GLM-4.7 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-4.5-flash",name:"GLM-4.5 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-5v-turbo",name:"GLM-5V Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:1},{id:"glm-4.6v",name:"GLM-4.6V",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:1,costOutput:3.2},{id:"glm-4.6v-flash",name:"GLM-4.6V Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!0,costInput:0,costOutput:0},{id:"cogview-4-250304",name:"CogView-4",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","768x1344","864x1152","1344x768","1152x864","1440x720","720x1440"]}},{id:"cogview-3-flash",name:"CogView-3 Flash (Free)",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","768x1344","864x1152","1344x768","1152x864","1440x720","720x1440"]}},{id:"glm-image",name:"GLM-Image",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1280x1280","1568x1056","1056x1568","1472x1088","1088x1472","1728x960","960x1728"]}},{id:"cogvideox-3",name:"CogVideoX-3",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["1080p"]}},{id:"cogvideox-flash",name:"CogVideoX Flash (Free)",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:6}},{id:"glm-tts",name:"GLM-TTS",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech"],voices:["tongtong","chuichui","xiaochen","jam","kazi","douji","luodo"],maxCharacters:1024,formats:["wav","pcm"]}},{id:"glm-tts-clone",name:"GLM-TTS Clone",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"voice_clone",mediaCapabilities:{type:"voice_clone",maxSampleDurationSeconds:30,maxSampleSizeMB:10,formats:["wav","mp3"]}},{id:"glm-asr-2512",name:"GLM-ASR-2512",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"stt",mediaCapabilities:{type:"stt",languages:["zh","en"],maxDurationSeconds:30,formats:["wav","mp3"]}},{id:"glm-4-voice",name:"GLM-4-Voice",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",modalities:["text","audio"],vad:!0,toolCalling:!1}},{id:"glm-realtime-flash",name:"GLM Realtime Flash",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!0,mediaType:"realtime_video",mediaCapabilities:{type:"realtime_video",modalities:["text","audio","video"],vad:!0,toolCalling:!1}},{id:"glm-realtime-air",name:"GLM Realtime Air",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!0,mediaType:"realtime_video",mediaCapabilities:{type:"realtime_video",modalities:["text","audio","video"],vad:!0,toolCalling:!1}},{id:"embedding-3",name:"Embedding-3",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:2048,maxTokens:3072}},{id:"embedding-2",name:"Embedding-2",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:1024,maxTokens:512}},{id:"rerank",name:"GLM Rerank",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"rerank",mediaCapabilities:{type:"rerank",maxDocuments:128,maxQueryLength:4096,maxDocumentLength:4096}},{id:"glm-ocr",name:"GLM-OCR",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"document_parsing",mediaCapabilities:{type:"document_parsing",supportedFormats:["pdf","jpg","png"],maxPageCount:100,maxFileSizeMB:50}}]},{id:"zhipu-openai",name:"\u93C5\u9E3F\u6C28 GLM OpenAI (Zhipu)",group:"zhipu",transport:"openai-chat",baseUrl:"https://open.bigmodel.cn/api/paas/v4",apiKeyEnvVars:["ZHIPU_API_KEY","GLM_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"glm-5.1",quirks:{supportsReasoningEffort:!0,supportsThinkingParam:!0,supportsToolStream:!0,builtinWebSearch:!0,builtinCodeInterpreter:!0},models:[{id:"glm-5.1",name:"GLM-5.1",contextWindow:2e5,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:6,costOutput:24,costCacheRead:1.3},{id:"glm-5",name:"GLM-5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-5-turbo",name:"GLM-5 Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1,costCacheRead:.1},{id:"glm-4.7",name:"GLM-4.7",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.6",name:"GLM-4.6",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.5-air",name:"GLM-4.5 Air",contextWindow:131072,maxOutput:98304,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1.5,costCacheRead:.1},{id:"glm-4-long",name:"GLM-4 Long",contextWindow:1e6,maxOutput:4096,toolCall:!0,reasoning:!1,vision:!1,costInput:.1,costOutput:.1},{id:"glm-4.7-flash",name:"GLM-4.7 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-4.5-flash",name:"GLM-4.5 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-5v-turbo",name:"GLM-5V Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:1},{id:"glm-4.6v",name:"GLM-4.6V",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:1,costOutput:3.2},{id:"glm-4.6v-flash",name:"GLM-4.6V Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!0,costInput:0,costOutput:0}]},{id:"zhipu-coding",name:"\u93C5\u9E3F\u6C28 GLM Coding (Zhipu)",group:"zhipu",transport:"openai-chat",baseUrl:"https://open.bigmodel.cn/api/coding/paas/v4",apiKeyEnvVars:["ZHIPU_API_KEY","GLM_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"codegeex-4",quirks:{supportsReasoningEffort:!0,supportsThinkingParam:!0,supportsToolStream:!0},models:[{id:"codegeex-4",name:"CodeGeeX-4",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.1,costOutput:.1}]},{id:"minimax",name:"MiniMax",group:"minimax",transport:"anthropic-messages",baseUrl:"https://api.minimaxi.com/anthropic",apiKeyEnvVars:["MINIMAX_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"MiniMax-M2.7",omitZeroTemperature:!0,quirks:{filterImageBlocks:!0},models:[{id:"MiniMax-M2.7",name:"MiniMax M2.7",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2,costCacheRead:.06,costCacheWrite:.375},{id:"MiniMax-M2.7-highspeed",name:"MiniMax M2.7 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2,costCacheRead:.06,costCacheWrite:.375},{id:"MiniMax-M2.5",name:"MiniMax M2.5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6,costCacheRead:.03,costCacheWrite:.19},{id:"MiniMax-M2.5-highspeed",name:"MiniMax M2.5 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6,costCacheRead:.03,costCacheWrite:.19},{id:"MiniMax-M2.1",name:"MiniMax M2.1 (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.1-highspeed",name:"MiniMax M2.1 Highspeed (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2",name:"MiniMax M2 (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.1,costOutput:.4},{id:"music-2.6",name:"MiniMax Music 2.6",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"music",mediaCapabilities:{type:"music",operations:["text2music"],maxDurationSeconds:300,formats:["mp3","wav"]}},{id:"music-cover",name:"MiniMax Music Cover",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"music",mediaCapabilities:{type:"music",operations:["cover"],maxDurationSeconds:300,formats:["mp3","wav"]}},{id:"MiniMax-Hailuo-2.3",name:"Hailuo 2.3",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["768P","1080P"]}},{id:"MiniMax-Hailuo-2.3-Fast",name:"Hailuo 2.3 Fast",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["768P","1080P"]}},{id:"MiniMax-Hailuo-02",name:"Hailuo 02",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["512P","768P","1080P"]}},{id:"image-01",name:"MiniMax Image 01",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["512x512","1024x1024","2048x2048"]}},{id:"image-01-live",name:"MiniMax Image 01 Live",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024"]}},{id:"speech-2.8-hd",name:"MiniMax Speech 2.8 HD",contextWindow:1e4,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],formats:["mp3","pcm","flac","wav","opus"]}},{id:"speech-2.8-turbo",name:"MiniMax Speech 2.8 Turbo",contextWindow:1e4,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],formats:["mp3","pcm","flac","wav","opus"]}},{id:"voice-clone",aliases:["minimax-voice-clone"],name:"MiniMax Voice Clone",contextWindow:0,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"voice_clone",mediaCapabilities:{type:"voice_clone",maxSampleDurationSeconds:30,maxSampleSizeMB:20,formats:["mp3","wav","m4a"]}}]},{id:"minimax-openai",name:"MiniMax (OpenAI)",group:"minimax",transport:"openai-chat",baseUrl:"https://api.minimaxi.com/v1",apiKeyEnvVars:["MINIMAX_API_KEY"],authType:"bearer",isAggregator:!1,omitZeroTemperature:!0,defaultModel:"MiniMax-M2.7",quirks:{supportsReasoningSplit:!0},models:[{id:"MiniMax-M2.7",aliases:["minimax-m2.7"],name:"MiniMax M2.7",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2},{id:"MiniMax-M2.7-highspeed",name:"MiniMax M2.7 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2},{id:"MiniMax-M2.5",name:"MiniMax M2.5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.5-highspeed",name:"MiniMax M2.5 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.1",name:"MiniMax M2.1 (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.1-highspeed",name:"MiniMax M2.1 Highspeed (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6}]},{id:"moonshot",name:"Moonshot (Kimi)",transport:"openai-chat",baseUrl:"https://api.moonshot.cn",apiKeyEnvVars:["MOONSHOT_API_KEY"],authType:"bearer",isAggregator:!1,omitZeroTemperature:!0,defaultModel:"kimi-k2.6",quirks:{supportsReasoningEffort:!0,supportsThinkingParam:!0,disableThinkingByDefault:!0,builtinWebSearch:!0},models:[{id:"kimi-k2.6",name:"Kimi K2.6",contextWindow:262144,maxOutput:262144,toolCall:!0,reasoning:!0,vision:!0,costInput:.95,costOutput:4,costCacheRead:.16},{id:"kimi-k2.5",name:"Kimi K2.5",contextWindow:262144,maxOutput:262144,toolCall:!0,reasoning:!0,vision:!0,costInput:.8,costOutput:4,costCacheRead:.2},{id:"moonshot-v1-128k",name:"Moonshot V1 128K",contextWindow:131072,maxOutput:8192,toolCall:!0,reasoning:!1,vision:!1,costInput:.84,costOutput:.84}]},{id:"volcengine",name:"\u749E\u55D7\u5BD8 (Doubao/Volcengine)",transport:"volcengine-responses",baseUrl:"https://ark.cn-beijing.volces.com/api",apiKeyEnvVars:["ARK_API_KEY","DOUBAO_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"doubao-seed-2-0-lite-260215",models:[{id:"doubao-seed-2-0-pro-260215",name:"Doubao Seed 2.0 Pro",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-lite-260428",aliases:["doubao-seed-2-0-lite"],name:"Doubao Seed 2.0 Lite (0428)",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-lite-260215",name:"Doubao Seed 2.0 Lite",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-mini-260428",name:"Doubao Seed 2.0 Mini (0428)",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-mini-260215",name:"Doubao Seed 2.0 Mini",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-code-preview-260215",name:"Doubao Seed 2.0 Code Preview",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-1-8-251228",name:"Doubao Seed 1.8",contextWindow:262144,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seedance-2-0-260128",aliases:["doubao-seedance-2-0"],name:"Doubao Seedance 2.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video","video2video","edit","merge","upscale"],maxDurationSeconds:15,resolutions:["480p","720p","1080p"],aspectRatios:["16:9","9:16","1:1"],fps:[24]}},{id:"doubao-seedance-2-0-fast-260128",aliases:["doubao-seedance-2-0-fast"],name:"Doubao Seedance 2.0 Fast",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video","video2video","edit","merge","upscale"],maxDurationSeconds:15,resolutions:["480p","720p"],aspectRatios:["16:9","9:16","1:1"],fps:[24]}},{id:"doubao-seedream-5-0-260128",aliases:["doubao-seedream-5-0"],name:"Doubao Seedream 5.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["2K"]}},{id:"doubao-seedream-4-5-251128",aliases:["doubao-seedream-4-5"],name:"Doubao Seedream 4.5",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["2K"]}},{id:"doubao-seed3d-2-0-260328",aliases:["doubao-seed3d-2-0"],name:"Doubao Seed3D 2.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"3d",mediaCapabilities:{type:"3d",operations:["img2_3d"],outputFormats:["glb","obj","usd","usdz"]}},{id:"hyper3d-gen2-260112",aliases:["hyper3d-gen2"],name:"Hyper3D Gen2",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"3d",mediaCapabilities:{type:"3d",operations:["text2_3d","img2_3d"],outputFormats:["glb","obj"]}},{id:"hitem3d-2-0-251223",aliases:["hitem3d-2-0"],name:"HiTem3D 2.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"3d",mediaCapabilities:{type:"3d",operations:["img2_3d"],outputFormats:["glb","obj","usd"]}}]},{id:"openai",name:"OpenAI",transport:"openai-responses",baseUrl:"https://api.openai.com",apiKeyEnvVars:["OPENAI_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"gpt-5.5",quirks:{builtinWebSearch:!0,builtinCodeInterpreter:!0,builtinFileSearch:!0},models:[{id:"gpt-5.5",name:"GPT-5.5",contextWindow:105e4,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:30,costCacheRead:.5},{id:"gpt-5.4",name:"GPT-5.4",contextWindow:105e4,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:2.5,costOutput:15,costCacheRead:.25},{id:"gpt-5.4-mini",name:"GPT-5.4 Mini",contextWindow:4e5,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:.75,costOutput:4.5,costCacheRead:.075},{id:"gpt-5.4-nano",name:"GPT-5.4 Nano",contextWindow:4e5,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:.2,costOutput:1.25,costCacheRead:.02},{id:"gpt-image-2",name:"GPT Image 2",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img","inpainting"],sizes:["1024x1024","1536x1024","1024x1536","auto"],transparentBackground:!0}},{id:"gpt-realtime-2",name:"GPT Realtime 2",contextWindow:128e3,maxOutput:16e3,toolCall:!0,reasoning:!0,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!0}},{id:"gpt-realtime-translate",name:"GPT Realtime Translate",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!1}},{id:"gpt-realtime-1.5",name:"GPT Realtime 1.5",contextWindow:128e3,maxOutput:16e3,toolCall:!0,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!0}},{id:"gpt-realtime-mini",name:"GPT Realtime Mini",contextWindow:128e3,maxOutput:16e3,toolCall:!0,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!0}}]},{id:"anthropic",name:"Anthropic",transport:"anthropic-messages",baseUrl:"https://api.anthropic.com",apiKeyEnvVars:["ANTHROPIC_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"claude-opus-4-7",quirks:{supportsDocumentVision:!0},models:[{id:"claude-opus-4-7",name:"Claude Opus 4.7",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5,costCacheWrite:6.25},{id:"claude-opus-4-6",name:"Claude Opus 4.6",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5,costCacheWrite:6.25},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6",contextWindow:1e6,maxOutput:64e3,toolCall:!0,reasoning:!0,vision:!0,costInput:3,costOutput:15,costCacheRead:.3,costCacheWrite:3.75},{id:"claude-sonnet-4-5",name:"Claude Sonnet 4.5",contextWindow:2e5,maxOutput:64e3,toolCall:!0,reasoning:!0,vision:!0,costInput:3,costOutput:15,costCacheRead:.3,costCacheWrite:3.75},{id:"claude-haiku-4-5",name:"Claude Haiku 4.5",contextWindow:2e5,maxOutput:64e3,toolCall:!0,reasoning:!0,vision:!0,costInput:1,costOutput:5,costCacheRead:.1,costCacheWrite:1.25}]},{id:"google",name:"Google Gemini",transport:"gemini-generatecontent",baseUrl:"https://generativelanguage.googleapis.com/v1beta",apiKeyEnvVars:["GOOGLE_API_KEY","GEMINI_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"gemini-3-flash-preview",quirks:{builtinWebSearch:!0,builtinCodeInterpreter:!0,builtinUrlContext:!0,builtinMapsGrounding:!0,builtinFileSearch:!0,supportsDocumentVision:!0},models:[{id:"gemini-3.1-pro-preview",name:"Gemini 3.1 Pro",contextWindow:1048576,maxOutput:65536,toolCall:!0,reasoning:!0,reasoningRequired:!0,vision:!0,costInput:2,costOutput:12},{id:"gemini-3-flash-preview",name:"Gemini 3 Flash",contextWindow:1048576,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:3},{id:"gemini-3.1-flash-lite",name:"Gemini 3.1 Flash-Lite",contextWindow:1048576,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.25,costOutput:1.5},{id:"gemini-3.1-flash-image-preview",name:"Gemini 3.1 Flash Image (Nano Banana 2)",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["1024x1024"]}},{id:"gemini-3-pro-image-preview",name:"Gemini 3 Pro Image (Nano Banana Pro)",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["1024x1024"]}},{id:"veo-3.1-generate-preview",name:"Veo 3.1 Standard",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:8,resolutions:["720P","1080P","4K"]}},{id:"veo-3.1-fast-generate-preview",name:"Veo 3.1 Fast",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:8,resolutions:["720P","1080P","4K"]}},{id:"veo-3.1-lite-generate-preview",name:"Veo 3.1 Lite",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:8,resolutions:["720P","1080P"]}},{id:"lyria-3-pro-preview",name:"Lyria 3 Pro",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"music",mediaCapabilities:{type:"music",operations:["text2music"],maxDurationSeconds:300,formats:["mp3"]}},{id:"lyria-3-clip-preview",name:"Lyria 3 Clip",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"music",mediaCapabilities:{type:"music",operations:["text2music"],maxDurationSeconds:30,formats:["mp3"]}},{id:"lyria-realtime-exp",name:"Lyria RealTime (Experimental)",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"music_realtime",mediaCapabilities:{type:"music",operations:["realtime"],formats:["wav"]}},{id:"gemini-3.1-flash-tts-preview",name:"Gemini 3.1 Flash TTS",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:1,costOutput:20,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech"],maxCharacters:8e3,formats:["mp3","wav"]}},{id:"gemini-embedding-2",name:"Gemini Embedding 2 (Multimodal)",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:.2,costOutput:0,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:3072,maxTokens:8192}}]},{id:"openrouter",name:"OpenRouter",transport:"openai-chat",baseUrl:"https://openrouter.ai/api",apiKeyEnvVars:["OPENROUTER_API_KEY"],authType:"bearer",isAggregator:!0,defaultModel:"anthropic/claude-opus-4.7",extraHeaders:{"HTTP-Referer":"https://claw.bot","X-Title":"XiaozhiClaw"},models:[{id:"anthropic/claude-opus-4.7",name:"Claude Opus 4.7 (via OpenRouter)",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5},{id:"anthropic/claude-opus-4.6",name:"Claude Opus 4.6 (via OpenRouter)",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5},{id:"deepseek/deepseek-v4-flash",name:"DeepSeek V4 Flash (via OpenRouter)",contextWindow:1048576,maxOutput:393216,toolCall:!0,reasoning:!0,vision:!1,costInput:.14,costOutput:.28,costCacheRead:.028}]},{id:"qwen-coding",name:"Alibaba Qwen (Coding Plan)",transport:"anthropic-messages",baseUrl:"https://coding.dashscope.aliyuncs.com/apps/anthropic",apiKeyEnvVars:["DASHSCOPE_API_KEY","QWEN_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"qwen3-coder-plus",models:[{id:"qwen3-coder-plus",name:"Qwen3 Coder Plus (Coding Plan)",contextWindow:262144,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!1},{id:"qwen3-coder-flash",name:"Qwen3 Coder Flash (Coding Plan)",contextWindow:262144,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!1}]}];import{existsSync as vi,mkdirSync as Mi,readFileSync as Ri,writeFileSync as Ei}from"node:fs";import{join as Ai}from"node:path";var Ii="https://models.dev/api.json",Oi=3e4,Ui=1440*60*1e3,Li=300*1e3,Ro={deepseek:"deepseek",qwen:"qwen","qwen-coding-plan":"qwen-coding","alibaba-cn":"qwen",zhipuai:"zhipu",minimax:"minimax",moonshot:"moonshot",moonshotai:"moonshot","moonshotai-cn":"moonshot",doubao:"volcengine","bytedance-seed":"volcengine",volcengine:"volcengine",openai:"openai",anthropic:"anthropic",google:"google",openrouter:"openrouter"},Z=class{cache=null;cacheDir;cacheFile;ttlMs;fetching=!1;lastFetchAttempt=0;constructor(e){this.cacheDir=e?.cacheDir??Q(),this.cacheFile=Ai(this.cacheDir,"model_catalog.json"),this.ttlMs=e?.ttlMs??Ui}getModels(e){this.ensureLoaded();let n=this.cache?.providers.get(e);return n?[...n.models.values()]:[]}getModel(e,n){return this.ensureLoaded(),this.cache?.providers.get(e)?.models.get(n)}listProviderIds(){return this.ensureLoaded(),this.cache?[...this.cache.providers.keys()]:[]}getEmbeddingModels(e){return this.ensureLoaded(),this.cache?.embeddingModels.get(e)??[]}getDefaultEmbeddingModel(e){let n=this.getEmbeddingModels(e);return n.filter(i=>i.dimensions>=512)[0]??n[0]}getAllEmbeddingModels(){return this.ensureLoaded(),this.cache?.embeddingModels??new Map}async refreshCatalog(){return this.fetchRemote()}ensureLoaded(){this.cache&&!this.isStale()||(this.cache||this.loadFromDisk(),(!this.cache||this.isStale())&&this.backgroundFetch())}isStale(){return this.cache?Date.now()-this.cache.fetchedAt>this.ttlMs:!0}loadFromDisk(){try{if(!vi(this.cacheFile))return;let e=Ri(this.cacheFile,"utf8"),n=JSON.parse(e);if(!n.fetchedAt||!n.data)return;this.cache={fetchedAt:n.fetchedAt,providers:vo(n.data),embeddingModels:Mo(n.data)}}catch{}}saveToDisk(e){try{Mi(this.cacheDir,{recursive:!0});let n=JSON.stringify({fetchedAt:Date.now(),data:e},null,0);Ei(this.cacheFile,n,"utf8")}catch{}}backgroundFetch(){this.fetching||Date.now()-this.lastFetchAttempt<Li||(this.fetching=!0,this.fetchRemote().finally(()=>{this.fetching=!1}))}async fetchRemote(){this.lastFetchAttempt=Date.now();try{let e=await fetch(Ii,{signal:AbortSignal.timeout(Oi),headers:{Accept:"application/json"}});if(!e.ok)return!1;let n=await e.json(),o=vo(n);return o.size===0?!1:(this.cache={fetchedAt:Date.now(),providers:o,embeddingModels:Mo(n)},this.saveToDisk(n),!0)}catch{return!1}}};function vo(t){let e=new Map;if(!t||typeof t!="object")return e;for(let[n,o]of Object.entries(t)){let i=Ro[n];if(!i||!o||typeof o!="object")continue;let a=o.models;if(!a||typeof a!="object")continue;let r=e.get(i);r||(r={models:new Map},e.set(i,r));for(let[d,h]of Object.entries(a)){if(!h||typeof h!="object"||r.models.has(d))continue;let p=h,f=typeof p.family=="string"?p.family:"";if(Eo(f,d)||d.toLowerCase().includes("reranker"))continue;let b=p.cost??{},y=p.limit??{},_=p.modalities??{},k=Array.isArray(_.input)?_.input:[],w=Array.isArray(_.output)?_.output:[],L=Pi(w,k,d);r.models.set(d,{id:d,name:typeof p.name=="string"?p.name:d,contextWindow:typeof y.context=="number"?y.context:2e5,maxOutput:typeof y.output=="number"?y.output:8192,toolCall:p.tool_call===!0,reasoning:p.reasoning===!0,vision:p.attachment===!0||k.includes("image"),costInput:typeof b.input=="number"?b.input:void 0,costOutput:typeof b.output=="number"?b.output:void 0,costCacheRead:typeof b.cache_read=="number"?b.cache_read:void 0,costCacheWrite:typeof b.cache_write=="number"?b.cache_write:void 0,mediaType:L})}}return e}function Pi(t,e,n){if(t.includes("video"))return"video";if(t.includes("image")&&!t.includes("text"))return"image";if(t.includes("audio")&&!t.includes("text"))return"tts";if(t.includes("3d"))return"3d";if(e.includes("video")&&t.includes("text"))return"video_understanding";let o=n.toLowerCase();if(o.includes("tts")||o.includes("speech")||o.includes("cosyvoice"))return"tts";if(o.includes("music")||o.includes("suno"))return"music";if(o.includes("seedream")||o.includes("image")||o.includes("dall"))return"image";if(o.includes("seedance")||o.includes("video"))return"video"}var Di={qwen:[{id:"text-embedding-v3",name:"Text Embedding v3",providerId:"qwen",dimensions:1024,maxInputTokens:8192,costInput:.7,family:"text-embedding"},{id:"text-embedding-v2",name:"Text Embedding v2",providerId:"qwen",dimensions:1536,maxInputTokens:2048,costInput:.7,family:"text-embedding"}],zhipu:[{id:"embedding-3",name:"Embedding-3",providerId:"zhipu",dimensions:2048,maxInputTokens:8192,costInput:.5,family:"text-embedding"},{id:"embedding-2",name:"Embedding-2",providerId:"zhipu",dimensions:1024,maxInputTokens:512,costInput:.5,family:"text-embedding"}],minimax:[{id:"embo-01",name:"embo-01",providerId:"minimax",dimensions:1536,maxInputTokens:4096,costInput:.5,family:"text-embedding"}],volcengine:[{id:"doubao-embedding-vision-251215",name:"Doubao Embedding Vision (Latest)",providerId:"volcengine",dimensions:1024,maxInputTokens:128e3,costInput:.5,family:"text-embedding"},{id:"doubao-embedding-vision-250615",name:"Doubao Embedding Vision",providerId:"volcengine",dimensions:1024,maxInputTokens:128e3,costInput:.5,family:"text-embedding"}],google:[{id:"text-embedding-004",name:"Text Embedding 004",providerId:"google",dimensions:768,maxInputTokens:2048,costInput:.025,family:"text-embedding"},{id:"gemini-embedding-001",name:"Gemini Embedding",providerId:"google",dimensions:3072,maxInputTokens:8192,costInput:0,family:"text-embedding"}]},$i=new Set(["text-embedding","bge","cohere-embed","plamo"]),Ni=[/embed/i,/^bge-/i,/^gte-/i,/^e5-/i,/multi-qa-/i];function Eo(t,e){return t&&$i.has(t)?!0:Ni.some(n=>n.test(e))}function Mo(t){let e=new Map;if(!t||typeof t!="object")return e;for(let[n,o]of Object.entries(t)){let i=Ro[n];if(!i||!o||typeof o!="object")continue;let a=o.models;if(!(!a||typeof a!="object"))for(let[r,d]of Object.entries(a)){if(!d||typeof d!="object")continue;let h=d,p=typeof h.family=="string"?h.family:"";if(!Eo(p,r)||r.toLowerCase().includes("reranker"))continue;let f=h.limit??{},b=h.cost??{},y=typeof f.output=="number"?f.output:0,_=typeof f.context=="number"?f.context:512;if(y<=1)continue;let k={id:r,name:typeof h.name=="string"?h.name:r,providerId:i,dimensions:y,maxInputTokens:_,costInput:typeof b.input=="number"?b.input:void 0,family:p},w=e.get(i);w||(w=[],e.set(i,w)),w.push(k)}}for(let n of e.values())n.sort((o,i)=>{let s=o.costInput??0,a=i.costInput??0;return s!==a?s-a:i.dimensions-o.dimensions});for(let[n,o]of Object.entries(Di)){let i=e.get(n);(!i||i.length===0)&&e.set(n,[...o])}return e}var Fi={claude:"anthropic",gemini:"google",doubao:"volcengine"},ue=class{builtins=new Map;catalog;overrides=new Map;constructor(e){for(let n of bt)this.builtins.set(n.id,n);this.catalog=e?.catalog??new Z}applyOverride(e,n){this.overrides.set(e,{...this.overrides.get(e),...n})}getProvider(e){let n=Fi[e]??e,o=this.builtins.get(n),i=this.overrides.get(n);if(!(!o&&!i))return!o&&i?!i.id||!i.transport||!i.baseUrl?void 0:{id:i.id,name:i.name??i.id,transport:i.transport,baseUrl:i.baseUrl,apiKeyEnvVars:i.apiKeyEnvVars??[],authType:i.authType??"bearer",isAggregator:i.isAggregator??!1,defaultModel:i.defaultModel,models:i.models}:o&&!i?o:{...o,...i,models:i.models??o.models}}listProviders(){let e=new Map;for(let[n,o]of this.builtins)e.set(n,o);for(let[n]of this.overrides){let o=this.getProvider(n);o&&e.set(n,o)}return[...e.values()]}listModels(e){let o=this.getProvider(e)?.models??[],i=this.catalog.getModels(e);if(i.length===0)return o;let s=new Map;for(let a of i)s.set(a.id,a);for(let a of o)s.set(a.id,a);return[...s.values()]}getModelInfo(e,n){return this.listModels(e).find(o=>o.id===n)}async refreshCatalog(){return this.catalog.refreshCatalog()}resolveApiKey(e,n){if(n)return n;let o=this.getProvider(e);if(o)for(let i of o.apiKeyEnvVars){let s=process.env[i];if(s?.trim())return s.trim()}}};var gl=20*1024*1024;import{createHmac as Yl,randomUUID as Jl}from"node:crypto";import{join as _c}from"node:path";import{mkdirSync as kc,appendFileSync as wc}from"node:fs";var Sc=So();import{mkdir as Ki,writeFile as Vi}from"fs/promises";import{join as Ao}from"path";import{tmpdir as Xi}from"os";var Yi="tool-results",Io="<persisted-output>",Ji="</persisted-output>";function Oo(){return{seenIds:new Set,replacements:new Map}}function Uo(t){return Ao(Xi(),"qlogicagent-sessions",t,Yi)}async function Qi(t){try{await Ki(Uo(t),{recursive:!0})}catch{}}function Zi(t,e){let n=e.replace(/[^a-zA-Z0-9_-]/g,"_");return Ao(Uo(t),`${n}.txt`)}function qi(t,e){if(t.length<=e)return{preview:t,hasMore:!1};let o=t.slice(0,e).lastIndexOf(`
9
+ `),i=o>e*.5?o:e;return{preview:t.slice(0,i),hasMore:!0}}function Lo(t){return t.includes(Io)}async function Po(t,e,n){await Qi(n);let o=Zi(n,e);try{await Vi(o,t,{encoding:"utf-8",flag:"wx"})}catch(a){if(a.code!=="EEXIST")return null}let{preview:i,hasMore:s}=qi(t,qe);return{filepath:o,originalSize:t.length,preview:i,hasMore:s}}function Do(t){let e=`${Io}
10
10
  `;return e+=`Output too large (${t.originalSize} chars). Full output saved to: ${t.filepath}
11
11
 
12
12
  `,e+=`Preview (first ${qe} bytes):
13
13
  `,e+=t.preview,e+=t.hasMore?`
14
14
  ...
15
15
  `:`
16
- `,e+=Js,e}async function $o(t,e,n,o=io){if(t.length<=o||Lo(t))return t;let s=await Po(t,e,n);return s?Do(s):t.slice(0,o)+`
17
- ...[truncated ${t.length-o} chars]`}function ei(t){let e=[],n=[];for(let o of t)o.role==="tool"&&typeof o.content=="string"&&o.tool_call_id?Lo(o.content)||n.push({toolCallId:o.tool_call_id,content:o.content,size:o.content.length}):o.role==="assistant"&&n.length>0&&(e.push(n),n=[]);return n.length>0&&e.push(n),e}function ti(t,e){let n=[],o=[],s=[];for(let i of t){let a=e.replacements.get(i.toolCallId);a!==void 0?n.push({...i,replacement:a}):e.seenIds.has(i.toolCallId)?o.push(i):s.push(i)}return{mustReapply:n,frozen:o,fresh:s}}function oi(t,e,n){let o=[...t].sort((a,r)=>r.size-a.size),s=[],i=e+t.reduce((a,r)=>a+r.size,0);for(let a of o){if(i<=n)break;s.push(a),i-=a.size}return s}async function No(t,e,n,o=ro){let s=ei(t);if(s.length===0)return{messages:t,newlyReplacedCount:0};let i=new Map,a=[];for(let p of s){let{mustReapply:f,frozen:b,fresh:y}=ti(p,e);for(let v of f)i.set(v.toolCallId,v.replacement);if(y.length===0){for(let v of p)e.seenIds.add(v.toolCallId);continue}let _=b.reduce((v,A)=>v+A.size,0),k=y.reduce((v,A)=>v+A.size,0),w=_+k>o?oi(y,_,o):[],L=new Set(w.map(v=>v.toolCallId));for(let v of p)L.has(v.toolCallId)||e.seenIds.add(v.toolCallId);w.length>0&&a.push(...w)}if(i.size===0&&a.length===0)return{messages:t,newlyReplacedCount:0};let r=await Promise.all(a.map(async p=>{let f=await Po(p.content,p.toolCallId,n);return{candidate:p,result:f}})),d=0;for(let{candidate:p,result:f}of r){if(e.seenIds.add(p.toolCallId),!f)continue;let b=Do(f);i.set(p.toolCallId,b),e.replacements.set(p.toolCallId,b),d++}return i.size===0?{messages:t,newlyReplacedCount:0}:{messages:t.map(p=>{if(p.role!=="tool"||!p.tool_call_id)return p;let f=i.get(p.tool_call_id);return f===void 0?p:{...p,content:f}}),newlyReplacedCount:d}}var ni=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),si=new Set(["bash","execute_command","Bash","shell"]),Pe=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??ni,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let n=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:n,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let n=this.tools.filter(s=>s.status==="executing"),o=this.config.maxConcurrentTools;return o&&o>0&&n.length>=o?!1:n.length===0||e&&n.every(s=>s.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let n;try{n=JSON.parse(e.toolCall.function.arguments)}catch{}let o=n?.command??n?.file_path??n?.pattern??"";if(typeof o=="string"&&o.length>0){let s=o.length>40?o.slice(0,40)+"\u2026":o;return`${e.toolCall.function.name}(${s})`}return e.toolCall.function.name}createSyntheticError(e,n){let o=this.erroredToolDescription,s=n==="user_interrupted"?"User rejected tool use":n==="discarded"?"Streaming fallback - tool execution discarded":o?`Cancelled: parallel tool call ${o} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:s,message:W(e.id,{ok:!1,error:s})}}async executeTool(e){e.status="executing";let o=(async()=>{let s=this.getAbortReason();if(s){e.results.push(this.createSyntheticError(e,s)),e.status="completed";return}let{toolInvoker:i,hooks:a,sessionId:r,turnId:d,log:h}=this.config,p=e.toolCall.function.name,f=!1,b=e.toolCall.function.arguments;if(a)try{let v=await a.invoke("tool.before_invoke",{sessionId:r,turnId:d,callId:e.id,toolName:p,arguments:ii(b)});if(v.action==="abort"){let A=v.reason??"blocked by policy";h.info(`tool ${p} blocked: ${A}`),e.results.push({callId:e.id,toolName:p,ok:!1,error:A,blocked:!0,blockReason:A,message:W(e.id,{ok:!1,error:A})}),e.status="completed";return}v.action==="continue"&&v.context?.arguments&&(b=JSON.stringify(v.context.arguments))}catch{}let y=await i.invoke(d,p,b,this.siblingAbortController.signal),_=this.getAbortReason();if(_&&!f){e.results.push(this.createSyntheticError(e,_)),e.status="completed";return}let k=!y.error,w=y.result;k&&w&&w.length>5e4&&(w=await $o(w,e.id,r));let L=W(e.id,{ok:k,payload:w,error:y.error,toolReferences:y.toolReferences,imageUrls:y.imageUrls});k||(f=!0,si.has(p)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),a?.invoke(k?"tool.after_invoke":"tool.invoke_failed",{sessionId:r,turnId:d,callId:e.id,toolName:p,ok:k,...y.error?{error:y.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:p,ok:k,error:y.error,message:L}),e.status="completed"})();e.promise=o,o.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let n of e.results)yield n}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(o=>o.status==="executing"&&o.promise).map(o=>o.promise),n=new Promise(o=>{this.progressResolve=o});e.length>0&&await Promise.race([...e,n])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}};function ii(t){try{return JSON.parse(t)}catch{return}}import{readFile as Ru}from"node:fs/promises";import*as $ from"node:fs";import{homedir as ri}from"node:os";import{join as Fo}from"node:path";import{existsSync as yu}from"node:fs";var ai=".qlogicagent";function li(){return process.env.QLOGICAGENT_HOME||Fo(ri(),ai)}function Bo(){return Fo(li(),"settings.json")}var De=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let n of e){this.pools.set(n.providerId,n);for(let o of n.keys)this.runtimeStates.set(o.id,this.createInitialState())}}acquireKey(e){let n=this.pools.get(e);if(!n||n.keys.length===0)return null;let o=Date.now(),s=this.getHealthyCandidates(n,o);if(s.length===0)return null;let i=this.selectByStrategy(s,n.strategy,o);if(!i)return null;let a=this.runtimeStates.get(i.id);return a.inFlight++,a.totalRequests++,a.lastUsedAt=o,a.requestTimestamps.push(o),{keyId:i.id,apiKey:i.key,providerId:e,release:r=>this.releaseKey(i.id,r)}}releaseKey(e,n){let o=this.runtimeStates.get(e);if(o)if(o.inFlight=Math.max(0,o.inFlight-1),n.success)o.consecutiveErrors=0,o.healthStatus="healthy",n.tokens&&(o.totalTokens+=n.tokens,o.tokenCounts.push(n.tokens));else if(o.consecutiveErrors++,o.lastErrorAt=Date.now(),n.errorCode===429){let s=n.retryAfter?n.retryAfter*1e3:3e4;o.cooldownUntil=Date.now()+s,o.healthStatus="cooldown"}else o.consecutiveErrors>=5?(o.cooldownUntil=Date.now()+6e4,o.healthStatus="cooldown"):o.consecutiveErrors>=3&&(o.healthStatus="degraded")}addProvider(e,n){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:n?.baseUrl,strategy:n?.strategy??"weighted-round-robin",keys:[],rateLimit:n?.rateLimit})}removeProvider(e){let n=this.pools.get(e);if(n){for(let o of n.keys)this.runtimeStates.delete(o.id);this.pools.delete(e)}}addKey(e,n,o){let s=this.pools.get(e);s||(s={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,s));let i=o?.id??crypto.randomUUID(),a={id:i,key:n,label:o?.label,weight:o?.weight??1,enabled:o?.enabled??!0};return s.keys.push(a),this.runtimeStates.set(i,this.createInitialState()),i}removeKey(e){for(let n of this.pools.values()){let o=n.keys.findIndex(s=>s.id===e);if(o!==-1){n.keys.splice(o,1),this.runtimeStates.delete(e);return}}}updateKey(e,n){for(let o of this.pools.values()){let s=o.keys.find(i=>i.id===e);if(s){if(n.label!==void 0&&(s.label=n.label),n.weight!==void 0&&(s.weight=n.weight),n.enabled!==void 0){s.enabled=n.enabled;let i=this.runtimeStates.get(e);i&&(i.healthStatus=n.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,n){let o=this.runtimeStates.get(e);o&&(o.healthStatus=n)}setStrategy(e,n){let o=this.pools.get(e);o&&(o.strategy=n)}setRateLimit(e,n){let o=this.pools.get(e);o&&(o.rateLimit=n)}getPoolStatus(e){let n=this.pools.get(e);return n?this.buildPoolStatus(n):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let n=this.pools.get(e);return n?this.getHealthyCandidates(n,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let n=new Set;for(let o of e){this.pools.set(o.providerId,o);for(let s of o.keys)n.add(s.id),this.runtimeStates.has(s.id)||this.runtimeStates.set(s.id,this.createInitialState())}for(let o of[...this.pools.keys()])e.some(s=>s.providerId===o)||this.pools.delete(o);for(let o of[...this.runtimeStates.keys()])n.has(o)||this.runtimeStates.delete(o)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,n){let o=[];for(let s of e.keys){if(!s.enabled)continue;let i=this.runtimeStates.get(s.id);if(i){if(i.healthStatus==="cooldown")if(n>=i.cooldownUntil)i.healthStatus="healthy",i.consecutiveErrors=0;else continue;i.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(i.requestTimestamps,n),i.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(i.tokenCounts,n),i.tokenCounts.reduce((r,d)=>r+d,0)>=e.rateLimit.tpm*.9)||o.push(s))}}return o}selectByStrategy(e,n,o){if(e.length===0)return null;if(e.length===1)return e[0];switch(n){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let n=e.reduce((s,i)=>s+i.weight,0),o=Math.random()*n;for(let s of e)if(o-=s.weight,o<=0)return s;return e[e.length-1]}leastBusy(e){let n=1/0,o=e[0];for(let s of e){let a=this.runtimeStates.get(s.id)?.inFlight??0;(a<n||a===n&&s.weight>o.weight)&&(n=a,o=s)}return o}pruneWindow(e,n){let o=n-6e4;for(;e.length>0&&e[0]<o;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(n=>{let o=this.runtimeStates.get(n.id)??this.createInitialState();return{...n,inFlight:o.inFlight,totalRequests:o.totalRequests,totalTokens:o.totalTokens,lastUsedAt:o.lastUsedAt,lastErrorAt:o.lastErrorAt,consecutiveErrors:o.consecutiveErrors,cooldownUntil:o.cooldownUntil,healthStatus:n.enabled?o.healthStatus:"disabled"}})}}};var Go=[{id:"deepseek",displayName:"DeepSeek",baseUrl:"https://api.deepseek.com",defaultRateLimit:{rpm:60},knownModels:[]},{id:"qwen",displayName:"\u901A\u4E49\u5343\u95EE (DashScope)",baseUrl:"https://dashscope.aliyuncs.com/compatible-mode/v1",defaultRateLimit:{rpm:120},knownModels:[{model:"text-embedding-v4",displayName:"Text Embedding V4",purposes:["embedding"]},{model:"cosyvoice-v2",displayName:"CosyVoice V2",purposes:["tts"]},{model:"paraformer-realtime-v2",displayName:"Paraformer Realtime V2",purposes:["stt"]},{model:"qwen3.5-omni-plus-realtime",displayName:"Qwen Omni Realtime",purposes:["realtimeAudio"]},{model:"wan2.7-t2v",displayName:"\u4E07\u76F8 2.7 \u6587\u751F\u89C6\u9891",purposes:["videoGeneration"]},{model:"wan2.7-i2v",displayName:"\u4E07\u76F8 2.7 \u56FE\u751F\u89C6\u9891",purposes:["videoGeneration"]},{model:"tripo-sr-v2.0-20250123",displayName:"Tripo SR V2",purposes:["threeDGeneration"]}]},{id:"zhipu",displayName:"\u667A\u8C31 AI",baseUrl:"https://open.bigmodel.cn/api/paas/v4",defaultRateLimit:{rpm:120},knownModels:[{model:"embedding-3",displayName:"Embedding-3",purposes:["embedding"]},{model:"glm-tts",displayName:"GLM-TTS",purposes:["tts"]},{model:"glm-asr-2512",displayName:"GLM-ASR",purposes:["stt"]},{model:"glm-image",displayName:"GLM-Image",purposes:["imageGeneration"]},{model:"cogview-4-250304",displayName:"CogView-4",purposes:["imageGeneration"]},{model:"cogvideox-3",displayName:"CogVideoX-3",purposes:["videoGeneration"]},{model:"glm-4-voice",displayName:"GLM-4-Voice",purposes:["realtimeAudio"]},{model:"glm-realtime-flash",displayName:"GLM-Realtime Flash",purposes:["realtimeVideo"]},{model:"glm-realtime-air",displayName:"GLM-Realtime Air",purposes:["realtimeVideo"]}]},{id:"volcengine",displayName:"\u706B\u5C71\u5F15\u64CE (\u8C46\u5305)",baseUrl:"https://ark.cn-beijing.volces.com/api/v3",defaultRateLimit:{rpm:120},knownModels:[{model:"doubao-embedding-large-text-250515",displayName:"\u8C46\u5305\u5411\u91CF Large",purposes:["embedding"]},{model:"doubao-seedream-5.0-lite",displayName:"Seedream 5.0 Lite",purposes:["imageGeneration"]},{model:"doubao-seedream-4.5",displayName:"Seedream 4.5",purposes:["imageGeneration"]},{model:"doubao-seedance-2.0",displayName:"Seedance 2.0",purposes:["videoGeneration"]},{model:"doubao-seedance-2.0-fast",displayName:"Seedance 2.0 Fast",purposes:["videoGeneration"]},{model:"doubao-seed3d-2-0-260328",displayName:"Seed3D 2.0",purposes:["threeDGeneration"]},{model:"hyper3d-gen2",displayName:"Hyper3D Gen2",purposes:["threeDGeneration"]},{model:"hitem3d-2.0",displayName:"Hitem3D 2.0",purposes:["threeDGeneration"]}]},{id:"minimax",displayName:"MiniMax",baseUrl:"https://api.minimax.chat/v1",defaultRateLimit:{rpm:60},knownModels:[{model:"speech-2.8-hd",displayName:"Speech 2.8 HD",purposes:["tts","voiceClone"]},{model:"MiniMax-Hailuo-2.3",displayName:"Hailuo 2.3",purposes:["videoGeneration"]},{model:"image-01",displayName:"Image-01",purposes:["imageGeneration"]},{model:"music-2.6",displayName:"Music 2.6",purposes:["musicGeneration"]},{model:"music-cover",displayName:"Music Cover",purposes:["musicGeneration"]}]},{id:"moonshot",displayName:"Moonshot (Kimi)",baseUrl:"https://api.moonshot.cn/v1",defaultRateLimit:{rpm:60},knownModels:[{model:"kimi-k2.6",displayName:"Kimi K2.6",purposes:["textGeneration","imageUnderstanding"]},{model:"kimi-k2.5",displayName:"Kimi K2.5",purposes:["textGeneration","imageUnderstanding"]},{model:"kimi-k2-thinking",displayName:"Kimi K2 Thinking",purposes:["textGeneration"]},{model:"kimi-k2-turbo-preview",displayName:"Kimi K2 Turbo",purposes:["textGeneration","smallModel"]}]},{id:"openai",displayName:"OpenAI",baseUrl:"https://api.openai.com/v1",defaultRateLimit:{rpm:60},knownModels:[{model:"text-embedding-3-large",displayName:"Text Embedding 3 Large",purposes:["embedding"]},{model:"gpt-image-2",displayName:"GPT Image 2",purposes:["imageGeneration"]},{model:"gpt-4o-mini-tts",displayName:"GPT-4o Mini TTS",purposes:["tts"]},{model:"gpt-realtime-whisper",displayName:"GPT Realtime Whisper",purposes:["stt"]},{model:"gpt-realtime-2",displayName:"GPT Realtime 2",purposes:["realtimeAudio"]}]},{id:"anthropic",displayName:"Anthropic",baseUrl:"https://api.anthropic.com",defaultRateLimit:{rpm:60},knownModels:[]},{id:"google",displayName:"Google (Gemini)",baseUrl:"https://generativelanguage.googleapis.com/v1beta",defaultRateLimit:{rpm:60},knownModels:[{model:"gemini-embedding-2",displayName:"Gemini Embedding 2",purposes:["embedding"]},{model:"imagen-4.0-generate-001",displayName:"Imagen 4",purposes:["imageGeneration"]},{model:"imagen-4.0-fast-generate-001",displayName:"Imagen 4 Fast",purposes:["imageGeneration"]},{model:"veo-3.1-generate-preview",displayName:"Veo 3.1",purposes:["videoGeneration"]},{model:"veo-3.1-fast-generate-preview",displayName:"Veo 3.1 Fast",purposes:["videoGeneration"]},{model:"gemini-3.1-flash-tts-preview",displayName:"Gemini 3.1 TTS",purposes:["tts"]},{model:"gemini-3.1-flash-live-preview",displayName:"Gemini 3.1 Live",purposes:["realtimeAudio"]},{model:"lyria-3-pro-preview",displayName:"Lyria 3 Pro",purposes:["musicGeneration"]},{model:"lyria-3-clip-preview",displayName:"Lyria 3 Clip",purposes:["musicGeneration"]}]}];var xt=class{keyPool;models=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){if(this.settingsPath=Bo(),this.keyPool=new De(e?.providers),e?.models)for(let n of e.models)this.models.set(n.id,n);e?.bindings&&(this.bindings={...e.bindings})}getActiveModel(e){let n=this.bindings[e];if(!n)return null;let o=this.models.get(n);if(!o||!o.enabled)return null;let s=this.keyPool.acquireKey(o.provider);return s?{provider:o.provider,model:o.model,apiKey:s.apiKey,baseUrl:o.baseUrl??this.getProviderBaseUrl(o.provider),keyHandle:s}:null}peekActiveModel(e){let n=this.bindings[e];return n?this.models.get(n)??null:null}isAvailable(e){let n=this.bindings[e];if(!n)return!1;let o=this.models.get(n);return!o||!o.enabled?!1:this.keyPool.hasAvailableKey(o.provider)}resolveModelForPurpose(e){let n=this.peekActiveModel(e);if(n)return n.model;if(e!=="textGeneration"){let o=this.peekActiveModel("textGeneration");if(o)return o.model}return null}addProvider(e,n){this.keyPool.addProvider(e,n),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[n,o]of this.models)if(o.provider===e){this.models.delete(n);for(let[s,i]of Object.entries(this.bindings))i===n&&delete this.bindings[s]}this.emitChange()}addKey(e,n,o){let s=this.keyPool.addKey(e,n,o);return this.emitChange(),s}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,n){this.keyPool.updateKey(e,n)}setKeyHealth(e,n){this.keyPool.setKeyHealth(e,n)}setStrategy(e,n){this.keyPool.setStrategy(e,n)}addModel(e){let n=e.id??`${e.provider}:${e.model}`,o={...e,id:n};return this.models.set(n,o),this.emitChange(),n}removeModel(e){this.models.delete(e);for(let[n,o]of Object.entries(this.bindings))o===e&&delete this.bindings[n];this.emitChange()}enableModel(e){let n=this.models.get(e);n&&(n.enabled=!0)}disableModel(e){let n=this.models.get(e);n&&(n.enabled=!1)}listModels(e){let n=[...this.models.values()];return e?.purpose&&(n=n.filter(o=>o.purposes.includes(e.purpose))),e?.provider&&(n=n.filter(o=>o.provider===e.provider)),e?.enabledOnly&&(n=n.filter(o=>o.enabled)),n}getModel(e){return this.models.get(e)??null}setBinding(e,n){let o=this.models.get(n);if(!o)throw new Error(`Model "${n}" not found in pool.`);if(!o.purposes.includes(e))throw new Error(`Model "${n}" does not support purpose "${e}".`);this.bindings[e]=n,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let n=this.bindings[e];return n?this.models.get(n)??null:null}getAllBindings(){let e={};for(let n of ci){let o=this.bindings[n];e[n]=o?this.models.get(o)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{$.existsSync(this.settingsPath)&&(e=JSON.parse($.readFileSync(this.settingsPath,"utf-8")))}catch{}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let n={...e,providers:this.keyPool.exportConfig(),models:[...this.models.values()],bindings:{...this.bindings}},o=this.settingsPath.replace(/[/\\][^/\\]+$/,"");$.existsSync(o)||$.mkdirSync(o,{recursive:!0}),$.writeFileSync(this.settingsPath,JSON.stringify(n,null,2),"utf-8")}load(){try{if(!$.existsSync(this.settingsPath))return!1;let e=$.readFileSync(this.settingsPath,"utf-8"),n=JSON.parse(e);if(!n.providers&&typeof n.provider=="string"&&typeof n.apiKey=="string"){let s=n.provider,i=n.apiKey,a=n.model||"",r=n.baseUrl,d=Go.find(y=>y.id===s),h=r||d?.baseUrl||"",p={providerId:s,baseUrl:h,strategy:"weighted-round-robin",keys:[{id:`${s}-key-0`,key:i,label:"migrated",weight:1,enabled:!0}]};this.keyPool.reloadConfig([p]),this.models.clear();let f=d?.knownModels??[],b="";for(let y of f){let _=`${s}:${y.model}`;this.models.set(_,{id:_,provider:s,model:y.model,displayName:y.displayName,purposes:y.purposes,baseUrl:y.baseUrl,enabled:!0}),y.model===a&&(b=_)}return!b&&a&&(b=`${s}:${a}`,this.models.set(b,{id:b,provider:s,model:a,displayName:a,purposes:["textGeneration"],enabled:!0})),b?this.bindings={textGeneration:b}:f.length>0?this.bindings={textGeneration:`${s}:${f[0].model}`}:this.bindings={},this.save(),this.emitChange(),!0}let o=n;if(o.providers&&this.keyPool.reloadConfig(o.providers),this.models.clear(),o.models)for(let s of o.models)this.models.set(s.id,s);return this.bindings=o.bindings??{},("summary"in this.bindings||"background"in this.bindings)&&!("smallModel"in this.bindings)&&(this.bindings.smallModel=this.bindings.summary??this.bindings.background),delete this.bindings.summary,delete this.bindings.background,this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:[...this.models.values()],bindings:{...this.bindings}}}getTunable(e){try{if(!$.existsSync(this.settingsPath))return;let n=$.readFileSync(this.settingsPath,"utf-8");return JSON.parse(n).tunables?.[e]}catch{return}}_providerRegistry=null;getProviderRegistry(){return this._providerRegistry||(this._providerRegistry=new ue),this._providerRegistry}getModelInfo(e,n){return this.getProviderRegistry().getModelInfo(e,n)}getProviderDefaultModel(e){return this.getProviderRegistry().getProvider(e)?.defaultModel}listProviderDefs(){return this.getProviderRegistry().listProviders()}resolveProviderApiKey(e){let n=this.getKeyForProvider(e);return n||this.getProviderRegistry().resolveApiKey(e)}onChange(e){return this.changeListeners.push(e),()=>{let n=this.changeListeners.indexOf(e);n>=0&&this.changeListeners.splice(n,1)}}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}getKeyForProvider(e){let n=this.keyPool.acquireKey(e);if(!n)return null;let o=n.apiKey;return n.release({success:!0}),o}snapshotProviderKeys(){let e={};for(let n of this.keyPool.getAllStatus()){let o=this.getKeyForProvider(n.providerId);o&&(e[n.providerId]=o)}return e}getProviderBaseUrl(e){return this.keyPool.getPoolStatus(e)?.baseUrl}},ci=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],$e=null;function kt(){return $e||($e=new xt,$e.load()),$e}function St(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}function wt(t){let e=0;for(let n of t)e+=St(n);return e}var Ct={"deepseek-v4-flash":1e6,"deepseek-v4-pro":1e6,"deepseek-chat":1e6,"deepseek-reasoner":1e6,"gpt-4o":128e3,"gpt-4o-mini":128e3,"claude-sonnet-4-20250514":2e5,"claude-3-5-haiku-20241022":2e5,"gemini-3.1-pro-preview":1e6,"gemini-3-flash-preview":1e6,"gemini-3.1-flash-lite":1e6};function ui(t){if(!t)return 128e3;if(t in Ct)return Ct[t];let e=t.toLowerCase();for(let[n,o]of Object.entries(Ct))if(e.startsWith(n.toLowerCase()))return o;return 128e3}var di=8e3;var pi=new re(200);var mi=new ae;function jo(){return mi}function fi(){return He(new ie(di),new X(20,St),new se(St))}var gi=null;function Wo(t,e){let n=e?.budget??Ke({modelContextWindow:ui(e?.model)}),s=(e?.pipeline??fi()).compress(t,n);if(s.droppedCount>0){let i=wt(t),a=wt(s.messages);pi.record({timestamp:Date.now(),strategy:s.strategy,tokensBefore:i,tokensAfter:a,droppedCount:s.droppedCount,latencyMs:s.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:s.metrics?.cacheInvalidated??!1,tier:Ve(i,n)})}return s.droppedCount>0&&gi?.(s.droppedCount,wt(s.messages)),s}function zo(t,e,n){let o=n-e;return`[Budget] ${Math.round(t)}% used (${e.toLocaleString()} / ${n.toLocaleString()} tokens). ${o.toLocaleString()} tokens remaining. `+(t>=90?"Wrap up your current taskyou are near the token limit.":"Continue workingdo not summarize prematurely.")}var wi=new Set(["write","edit","patch","apply_patch"]);function Ci(t){let e=t.split(".").pop()?.toLowerCase()??"";return["png","jpg","jpeg","gif","webp","svg","bmp","ico"].includes(e)?"image":["md","txt","pdf","doc","docx","rtf","html"].includes(e)?"document":["mermaid","mmd","dot","puml","plantuml"].includes(e)?"diagram":["csv","tsv","xlsx","xls"].includes(e)?"table":["ts","tsx","js","jsx","py","rs","go","java","c","cpp","h","cs","rb","sh","sql","json","yaml","yml","toml","xml","css","scss","vue","svelte"].includes(e)?"code":"file"}function Si(t){let e=t.split(".").pop()?.toLowerCase()??"";return{ts:"typescript",tsx:"typescriptreact",js:"javascript",jsx:"javascriptreact",py:"python",rs:"rust",go:"go",java:"java",c:"c",cpp:"cpp",h:"c",cs:"csharp",rb:"ruby",sh:"shellscript",sql:"sql",json:"json",yaml:"yaml",yml:"yaml",toml:"toml",xml:"xml",html:"html",css:"css",scss:"scss",vue:"vue",svelte:"svelte",md:"markdown"}[e]}var vi=/^no (matches|files|results) found\.?$|^file not found|^not found|^0 results|^\(exit code \d+, no output\)$/i,Mi=new Set(["search","grep","glob","find","list","read","exec"]);function Ri(t){if(!Mi.has(t.toolName))return!1;let e=typeof t.message?.content=="string"?t.message.content.trim():"";return e.length>0&&e.length<200&&vi.test(e)}function Vo(t,e){for(let n=t.length-1;n>=0;n--){let o=t[n];if(!o||o.role!=="tool")continue;let s=typeof o.content=="string"?o.content:"";if(s.startsWith("Error: "))return s.slice(7).trim()}}function Ei(t){return typeof t=="number"&&Number.isFinite(t)&&t>=1?Math.min(Math.round(t),100):Yt}function Xo(t){let e=t.message.toLowerCase();return t.status===413||e.includes("prompt_too_long")||e.includes("context_length_exceeded")||e.includes("maximum context length")}function Ai(t){return t==="length"||t==="max_tokens"}function Yo(t){let e=t.message.toLowerCase();return(e.includes("image")||e.includes("media")||e.includes("file too large")||e.includes("payload too large"))&&(t.status===413||e.includes("too large")||e.includes("size"))}function Ii(t){let e=t.headers;if(!e)return null;let n=e["retry-after"]??e["Retry-After"];if(!n)return null;let o=parseInt(n,10);return!isNaN(o)&&o>0?o*1e3:null}function Oi(t){if(t.status!==400)return null;let e=t.message.match(/input length and `max_tokens` exceed context limit: (\d+) \+ (\d+) > (\d+)/);if(!e?.[1]||!e?.[3])return null;let n=parseInt(e[1],10),o=parseInt(e[3],10);if(isNaN(n)||isNaN(o))return null;let s=o-n-1e3;return s>=3e3?s:null}function Ui(t){return t.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*Jo(t,e,n,o){let{turnId:s,sessionId:i,messages:a,tools:r,model:d,apiKey:h,temperature:p=0,hooks:f,signal:b}=t,y={sessionId:i,turnId:s},_=t.maxTurns??0,k=t.querySource,{resolveToolEligibility:w}=await Promise.resolve().then(()=>(Ko(),Ho)),L=w(r,t.toolEligibilityContext),v=L.eligibleTools;for(let C of L.blockedTools)yield{type:"tool_blocked",turnId:s,callId:"",name:C.toolName,reason:"blocked-by-policy"};if(!v.length){yield*Li(s,d,a,h,p,b,e,o);return}let A=Ei(t.maxRounds),D={contextWindowTokens:t.contextWindowTokens??Zt,responseBufferTokens:qt,maxOutputTokens:t.maxOutputTokens??eo,abortSignal:b,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},R=new Set,I=0,pe=v,me,l={messages:[...a],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:ut(D),reactiveCompactState:gt(),toolLoopState:Se({maxRounds:A,replayMessages:[...a]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:Ye(),currentModel:d,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:Oo(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},vt=Math.max(_*5,200),Mt=0;for(;;){if(Mt++,Mt>vt){o.info(`hard iteration cap reached (${vt}), forcing completion`);let c=l.finalText||de(l.messages,o);yield{type:"end",turnId:s,content:c,usage:l.totalUsage,model:l.currentModel};return}let{messages:C,maxOutputTokensRecoveryCount:q,hasAttemptedReactiveCompact:Ni,maxOutputTokensOverride:Rt,turnCount:ee,guardState:O,reactiveCompactState:G,collapseStore:Ne}=l,{toolLoopState:N}=l;if(me){try{let c=await me;c&&(yield{type:"tool_use_summary",turnId:s,summary:c})}catch{}me=void 0}if(t.refreshTools&&ee>1){let c=t.refreshTools();c!==pe&&(pe=c,o.debug(`tools refreshed: ${c.length} tools`))}if(ft(O,D)){o.info(`turn aborted by guard at turn ${ee}`),yield{type:"error",turnId:s,error:"Turn aborted",code:"ABORTED",usage:l.totalUsage};return}let z=dt(O,D);if(z.level==="blocking"){z.reason==="prompt_too_long"&&J(G)&&(G.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,o.info(`token budget blocking (${z.reason}), reactive compact needed`),yield{type:"recovery",turnId:s,action:"reactive_compact",detail:"token budget pre-check"}),o.info(`token budget blocking (${z.reason}), ending tool loop`);break}z.level==="warning"&&o.info(`token budget warning: ${z.usagePercent}% used, ${z.remainingTokens} remaining`);let U;{let c=await No(C,l.contentReplacementState,i);U=c.messages,c.newlyReplacedCount>0&&(o.info(`tool-result-budget: persisted ${c.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:s,action:"tool_result_budget",detail:`${c.newlyReplacedCount} persisted`})}{let c=Xe(U,l.snipRemovedIds);U=c.messages,c.removedCount>0&&(o.info(`snip: removed ${c.removedCount} messages, freed ~${c.tokensFreed} tokens`),yield{type:"recovery",turnId:s,action:"snip",detail:`${c.removedCount} messages`})}{let u=new X().compress(U,0);u.droppedCount>0&&(U=u.messages,o.info(`microcompact: cleared ${u.droppedCount} old tool results`))}if(U=Je(U,Ne).messages,O.promptTokens>0){let c=D.contextWindowTokens*.75,u=jo().getActive(),m;u?m=await u.compressAsync(U,c,{model:l.currentModel,sessionId:i}):m=Wo(U,{budget:c,model:l.currentModel}),m.droppedCount>0&&(U=m.messages,o.info(`autocompact: ${m.strategy}, dropped ${m.droppedCount}`),yield{type:"recovery",turnId:s,action:"autocompact",detail:`${m.strategy}: ${m.droppedCount} dropped`},l.hasAttemptedReactiveCompact=!1,f?.invoke("context.after_compact",{...y,removedCount:m.droppedCount}).catch(()=>{}))}U=Ui(U);let fe=ot({tools:pe,toolChoice:t.toolChoice??"auto"}),te=Se({maxRounds:A,replayMessages:U,lastStopReason:N.lastStopReason,options:{stopReason:N.lastStopReason}}),Et=fe.extraSystemPrompt?[{role:"system",content:fe.extraSystemPrompt},...te.state.replayMessages]:te.state.replayMessages;N=te.state,te.recoveryActions.length>0&&o.debug(`tool loop recovery: ${te.recoveryActions.map(c=>c.detail??c.kind).join("; ")}`),o.debug(`turn ${ee}, messages: ${Et.length}`),f?.invoke("turn.before_inference",{...y,model:l.currentModel}).catch(()=>{});let ge=!1,At=[],It=new Map,Ot="stop",F,S=null,he=!1,oe=[],P=[];try{for await(let c of e.stream({model:l.currentModel,messages:Et,tools:fe.tools,toolChoice:fe.normalizedToolChoice??"auto",temperature:p,maxTokens:(Rt??O.currentMaxOutputTokens)||void 0,streamRequired:t.streamRequired,previousResponseId:l.lastResponseId,reasoning:t.reasoning,promptCacheKey:t.promptCacheKey,promptCacheRetention:t.promptCacheRetention,serviceTier:t.serviceTier,openaiBuiltinTools:t.openaiBuiltinTools,maxToolCalls:t.maxToolCalls,parallelToolCalls:t.parallelToolCalls,textVerbosity:t.textVerbosity},h,b))switch(c.type){case"delta":At.push(c.text),ge||(yield{type:"delta",turnId:s,text:c.text});break;case"tool_call_delta":ge=!0,ht(It,c);break;case"reasoning_delta":oe.push(c.text);break;case"reasoning_block_complete":c.signature&&P.push({thinking:oe.join(""),signature:c.signature}),oe.length=0;break;case"usage":F={inputTokens:c.promptTokens,outputTokens:c.completionTokens,reasoningTokens:c.reasoningTokens,cacheRead:c.cacheReadTokens,cacheWrite:c.cacheCreationTokens};break;case"response_id":l.lastResponseId=c.id;break;case"annotations":yield{type:"annotations",turnId:s,annotations:c.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:s,message:`${c.toolType}: ${c.event}`};break;case"done":Ot=c.finishReason;break}if(ge||f?.invoke("turn.after_inference",{...y,model:l.currentModel}).catch(()=>{}),t.postSamplingHooks&&t.postSamplingHooks.length>0){let c=l.currentModel;for(let u of t.postSamplingHooks)try{u({messages:[...U],model:c,sessionId:i})}catch{}}}catch(c){if(c instanceof ce&&t.fallbackModel){o.info(`model fallback triggered: ${c.originalModel} \u2192 ${c.fallbackModel}`),yield{type:"recovery",turnId:s,action:"model_fallback",detail:`${c.originalModel} \u2192 ${c.fallbackModel}`},l={...l,currentModel:c.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let u=c instanceof Error?c.message:String(c),m=typeof c?.status=="number"?c.status:void 0;if(!m&&u&&(u.includes("ECONNRESET")||u.includes("EPIPE"))){let x=(l.consecutiveApiRetries??0)+1;if(x>le){o.info(`stale connection retry limit reached (${le}), aborting`),yield{type:"error",turnId:s,error:u,code:"RETRIES_EXHAUSTED",usage:l.totalUsage};return}o.info(`stale connection (${u.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:s,action:"stale_connection_retry",detail:u.slice(0,80)},l={...l,consecutiveApiRetries:x,transition:void 0};continue}let g=Oi({status:m,message:u});if(g!==null){o.info(`max_tokens overflow: adjusting to ${g}`),O.currentMaxOutputTokens=g,l={...l,maxOutputTokensOverride:g,transition:void 0};continue}if(ct(m)){l.consecutive529Errors++;let x=2,E=t.fallbackModel&&l.currentModel!==t.fallbackModel;if(l.consecutive529Errors>x&&!E&&!Me()){o.info(`transient ${m} \xD7 ${l.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:s,error:`API unavailable after ${l.consecutive529Errors} consecutive ${m} errors`,code:"API_ERROR",usage:l.totalUsage};return}if(l.consecutive529Errors>=lo&&t.fallbackModel&&l.currentModel!==t.fallbackModel){o.info(`529 \xD7 ${l.consecutive529Errors}: triggering fallback to ${t.fallbackModel}`),yield{type:"recovery",turnId:s,action:"model_fallback",detail:`529 \xD7 ${l.consecutive529Errors}`},l={...l,currentModel:t.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Me()){let T=ve(l.consecutive529Errors);o.info(`persistent retry: waiting ${T}ms (attempt ${l.consecutive529Errors})`);let M=T;for(;M>0;){if(b?.aborted){yield{type:"error",turnId:s,error:"Aborted during retry wait",code:"ABORTED",usage:l.totalUsage};return}yield{type:"heartbeat",turnId:s,message:`Retrying in ${Math.ceil(M/1e3)}s (${m})`};let B=Math.min(M,ao);await new Promise(Ge=>setTimeout(Ge,B)),M-=B}l={...l,transition:void 0};continue}if(lt(k)){let M=Ii({status:m,message:u})??ve(l.consecutive529Errors);o.info(`transient ${m}: retry in ${M}ms`),yield{type:"recovery",turnId:s,action:"retry",detail:`${m} retry in ${M}ms`},await new Promise(B=>setTimeout(B,M)),l={...l,transition:void 0};continue}o.info(`background source ${k}: not retrying ${m}`)}S={status:m,message:u}}if(S&&f?.invoke("turn.after_inference",{...y,model:l.currentModel,response:{error:S.message}}).catch(()=>{}),S)if(Xo(S))he=!0,o.info(`withheld prompt_too_long error (status=${S.status})`);else if(Yo(S))he=!0,o.info(`withheld media_size error (status=${S.status})`);else{let c=pt({status:S.status??500,message:S.message},O,D);if(c.action==="reactive_compact"&&J(G)&&(G.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:s,action:"reactive_compact",detail:`API ${S.status??500}: ${S.message}`}),c.action==="retry"){let m=(l.consecutiveApiRetries??0)+1;if(m>le){o.info(`API retry limit reached (${le}), aborting`);let g=Y(S.status,S.message);yield{type:"error",turnId:s,error:S.message,code:g,usage:l.totalUsage};return}yield{type:"recovery",turnId:s,action:"retry",detail:c.reason},l={...l,consecutiveApiRetries:m,transition:void 0};continue}let u=Y(S.status,S.message);f?.invoke("stop.failure",{sessionId:i,reason:u,error:S.message}).catch(()=>{}),yield{type:"error",turnId:s,error:S.message,code:u,usage:l.totalUsage};return}F&&(l.totalUsage.inputTokens+=F.inputTokens,l.totalUsage.outputTokens+=F.outputTokens,F.reasoningTokens&&(l.totalUsage.reasoningTokens=(l.totalUsage.reasoningTokens??0)+F.reasoningTokens),F.cacheRead&&(l.totalUsage.cacheRead=(l.totalUsage.cacheRead??0)+F.cacheRead),F.cacheWrite&&(l.totalUsage.cacheWrite=(l.totalUsage.cacheWrite??0)+F.cacheWrite)),F?.inputTokens&&(O.promptTokens=F.inputTokens);let Ut=At.join("");Ut&&(l.finalText=Ut);let j=[...It.values()].map(c=>({id:c.id||`tc_${s}_${ee}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:c.name,arguments:c.arguments}}));if(j.length===0&&!ge){if(he&&S&&Xo(S)){if(l.transition?.reason!=="collapse_drain_retry"){let m=Qe(U,Ne);if(m.committed>0){o.info(`collapse drain: committed ${m.committed} stages`),yield{type:"recovery",turnId:s,action:"collapse_drain",detail:`${m.committed} stages committed`},l={...l,messages:m.messages,transition:{reason:"collapse_drain_retry",committed:m.committed}};continue}}if(J(G)){G.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,o.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:s,action:"reactive_compact",detail:"withheld prompt_too_long"},l={...l,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld 413: recovery exhausted, surfacing error"),f?.invoke("stop.failure",{sessionId:i,reason:"prompt_too_long",error:S.message}).catch(()=>{}),yield{type:"error",turnId:s,error:S.message,code:"PROMPT_TOO_LONG",usage:l.totalUsage};return}if(he&&S&&Yo(S)){if(J(G)){G.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,o.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:s,action:"reactive_compact",detail:"media error strip-retry"},l={...l,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld media error: recovery exhausted"),f?.invoke("stop.failure",{sessionId:i,reason:"media_error",error:S.message}).catch(()=>{}),yield{type:"error",turnId:s,error:S.message,code:"IMAGE_ERROR",usage:l.totalUsage};return}if(Ai(Ot)){O.consecutiveTruncations+=1;let m=t.modelMaxOutputTokens??to,g=mt(O,D,m);if(g.shouldEscalate&&Rt===void 0){O.currentMaxOutputTokens=g.newMax,o.info(`max_output_tokens escalate: ${g.newMax} tokens`),yield{type:"recovery",turnId:s,action:"output_escalation",detail:`${g.newMax} tokens`},l={...l,maxOutputTokensOverride:no,transition:{reason:"max_output_tokens_escalate"}};continue}if(q<oo){let x={role:"user",content:"Output token limit hit. Resume directly \u2014 no apology, no recap of what you were doing. Pick up mid-thought if that is where the cut happened. Break remaining work into smaller pieces."};o.info(`max_output_tokens recovery #${q+1}`),yield{type:"recovery",turnId:s,action:"max_output_tokens_recovery",detail:`attempt ${q+1}`},l={...l,messages:[...U,x],maxOutputTokensRecoveryCount:q+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:q+1}};continue}o.info("max_output_tokens recovery exhausted, completing with partial content")}else O.consecutiveTruncations=0;if(N=Ce(N,{replayMessages:C,lastStopReason:"completed"}),f){let m=await f.invoke("stop",{sessionId:i,reason:"completed"});if(m.action==="prevent"){o.info(`stop hook prevented continuation: ${m.reason??"no reason"}`),yield{type:"end",turnId:s,content:l.finalText,usage:l.totalUsage,model:l.currentModel};return}if(m.action==="abort"){let g=m.reason??"Stop hook requested continuation";o.info(`stop hook blocking: ${g}`);let x={role:"user",content:g},E={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,E,x],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(t.tokenBudget&&t.tokenBudget>0&&l.budgetContinuationCount<5){let m=l.totalUsage.inputTokens+l.totalUsage.outputTokens+(l.totalUsage.reasoningTokens??0),g=m/t.tokenBudget*100,x=m-l.lastBudgetGlobalTokens,E=l.budgetContinuationCount>=so&&x<Ze&&l.lastBudgetDeltaTokens<Ze;if(E&&o.info(`token budget early stop: diminishing returns at ${Math.round(g)}% (delta=${x})`),!E&&g<90){let T=l.budgetContinuationCount+1,M={role:"user",content:zo(g,m,t.tokenBudget)};o.info(`token budget continuation #${T}: ${Math.round(g)}% used`),yield{type:"recovery",turnId:s,action:"budget_continuation",detail:`${Math.round(g)}% used (#${T})`};let B={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,B,M],budgetContinuationCount:T,lastBudgetDeltaTokens:x,lastBudgetGlobalTokens:m,transition:{reason:"token_budget_continuation"}};continue}}if(!l.stopHookActive){let m=a.find(T=>T.role==="user"),g=typeof m?.content=="string"?m.content:"",x=/创建文件|生成文件|写入|写一个|建一个|新建|重写|改写|create\s+(a\s+)?file|write\s+(a\s+)?file|make\s+(a\s+)?file|修改|改成|把.*改|文件名叫/i.test(g),E=R.has("write")||R.has("edit");if(x&&!E){if(o.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),I>0){let B=[...C].reverse().find(Ge=>Ge.role==="tool");B&&typeof B.content=="string"&&(B.content+=`
16
+ `,e+=Ji,e}async function $o(t,e,n,o=so){if(t.length<=o||Lo(t))return t;let i=await Po(t,e,n);return i?Do(i):t.slice(0,o)+`
17
+ ...[truncated ${t.length-o} chars]`}function es(t){let e=[],n=[];for(let o of t)o.role==="tool"&&typeof o.content=="string"&&o.tool_call_id?Lo(o.content)||n.push({toolCallId:o.tool_call_id,content:o.content,size:o.content.length}):o.role==="assistant"&&n.length>0&&(e.push(n),n=[]);return n.length>0&&e.push(n),e}function ts(t,e){let n=[],o=[],i=[];for(let s of t){let a=e.replacements.get(s.toolCallId);a!==void 0?n.push({...s,replacement:a}):e.seenIds.has(s.toolCallId)?o.push(s):i.push(s)}return{mustReapply:n,frozen:o,fresh:i}}function os(t,e,n){let o=[...t].sort((a,r)=>r.size-a.size),i=[],s=e+t.reduce((a,r)=>a+r.size,0);for(let a of o){if(s<=n)break;i.push(a),s-=a.size}return i}async function No(t,e,n,o=ro){let i=es(t);if(i.length===0)return{messages:t,newlyReplacedCount:0};let s=new Map,a=[];for(let p of i){let{mustReapply:f,frozen:b,fresh:y}=ts(p,e);for(let v of f)s.set(v.toolCallId,v.replacement);if(y.length===0){for(let v of p)e.seenIds.add(v.toolCallId);continue}let _=b.reduce((v,A)=>v+A.size,0),k=y.reduce((v,A)=>v+A.size,0),w=_+k>o?os(y,_,o):[],L=new Set(w.map(v=>v.toolCallId));for(let v of p)L.has(v.toolCallId)||e.seenIds.add(v.toolCallId);w.length>0&&a.push(...w)}if(s.size===0&&a.length===0)return{messages:t,newlyReplacedCount:0};let r=await Promise.all(a.map(async p=>{let f=await Po(p.content,p.toolCallId,n);return{candidate:p,result:f}})),d=0;for(let{candidate:p,result:f}of r){if(e.seenIds.add(p.toolCallId),!f)continue;let b=Do(f);s.set(p.toolCallId,b),e.replacements.set(p.toolCallId,b),d++}return s.size===0?{messages:t,newlyReplacedCount:0}:{messages:t.map(p=>{if(p.role!=="tool"||!p.tool_call_id)return p;let f=s.get(p.tool_call_id);return f===void 0?p:{...p,content:f}}),newlyReplacedCount:d}}var ns=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),is=new Set(["bash","execute_command","Bash","shell"]),Pe=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??ns,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let n=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:n,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let n=this.tools.filter(i=>i.status==="executing"),o=this.config.maxConcurrentTools;return o&&o>0&&n.length>=o?!1:n.length===0||e&&n.every(i=>i.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let n;try{n=JSON.parse(e.toolCall.function.arguments)}catch{}let o=n?.command??n?.file_path??n?.pattern??"";if(typeof o=="string"&&o.length>0){let i=o.length>40?o.slice(0,40)+"\u2026":o;return`${e.toolCall.function.name}(${i})`}return e.toolCall.function.name}createSyntheticError(e,n){let o=this.erroredToolDescription,i=n==="user_interrupted"?"User rejected tool use":n==="discarded"?"Streaming fallback - tool execution discarded":o?`Cancelled: parallel tool call ${o} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:i,message:W(e.id,{ok:!1,error:i})}}async executeTool(e){e.status="executing";let o=(async()=>{let i=this.getAbortReason();if(i){e.results.push(this.createSyntheticError(e,i)),e.status="completed";return}let{toolInvoker:s,hooks:a,sessionId:r,turnId:d,log:h}=this.config,p=e.toolCall.function.name,f=!1,b=e.toolCall.function.arguments;if(a)try{let v=await a.invoke("tool.before_invoke",{sessionId:r,turnId:d,callId:e.id,toolName:p,arguments:ss(b)});if(v.action==="abort"){let A=v.reason??"blocked by policy";h.info(`tool ${p} blocked: ${A}`),e.results.push({callId:e.id,toolName:p,ok:!1,error:A,blocked:!0,blockReason:A,message:W(e.id,{ok:!1,error:A})}),e.status="completed";return}v.action==="continue"&&v.context?.arguments&&(b=JSON.stringify(v.context.arguments))}catch{}let y=await s.invoke(d,p,b,this.siblingAbortController.signal),_=this.getAbortReason();if(_&&!f){e.results.push(this.createSyntheticError(e,_)),e.status="completed";return}let k=!y.error,w=y.result;k&&w&&w.length>5e4&&(w=await $o(w,e.id,r));let L=W(e.id,{ok:k,payload:w,error:y.error,toolReferences:y.toolReferences,imageUrls:y.imageUrls});k||(f=!0,is.has(p)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),a?.invoke(k?"tool.after_invoke":"tool.invoke_failed",{sessionId:r,turnId:d,callId:e.id,toolName:p,ok:k,...y.error?{error:y.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:p,ok:k,error:y.error,message:L}),e.status="completed"})();e.promise=o,o.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let n of e.results)yield n}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(o=>o.status==="executing"&&o.promise).map(o=>o.promise),n=new Promise(o=>{this.progressResolve=o});e.length>0&&await Promise.race([...e,n])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}};function ss(t){try{return JSON.parse(t)}catch{return}}import{readFile as Ru}from"node:fs/promises";import*as $ from"node:fs";import{homedir as rs}from"node:os";import{join as Fo}from"node:path";import{existsSync as yu}from"node:fs";var as=".qlogicagent";function ls(){return process.env.QLOGICAGENT_HOME||Fo(rs(),as)}function Bo(){return Fo(ls(),"settings.json")}var De=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let n of e){this.pools.set(n.providerId,n);for(let o of n.keys)this.runtimeStates.set(o.id,this.createInitialState())}}acquireKey(e){let n=this.pools.get(e);if(!n||n.keys.length===0)return null;let o=Date.now(),i=this.getHealthyCandidates(n,o);if(i.length===0)return null;let s=this.selectByStrategy(i,n.strategy,o);if(!s)return null;let a=this.runtimeStates.get(s.id);return a.inFlight++,a.totalRequests++,a.lastUsedAt=o,a.requestTimestamps.push(o),{keyId:s.id,apiKey:s.key,providerId:e,release:r=>this.releaseKey(s.id,r)}}releaseKey(e,n){let o=this.runtimeStates.get(e);if(o)if(o.inFlight=Math.max(0,o.inFlight-1),n.success)o.consecutiveErrors=0,o.healthStatus="healthy",n.tokens&&(o.totalTokens+=n.tokens,o.tokenCounts.push(n.tokens));else if(o.consecutiveErrors++,o.lastErrorAt=Date.now(),n.errorCode===429){let i=n.retryAfter?n.retryAfter*1e3:3e4;o.cooldownUntil=Date.now()+i,o.healthStatus="cooldown"}else o.consecutiveErrors>=5?(o.cooldownUntil=Date.now()+6e4,o.healthStatus="cooldown"):o.consecutiveErrors>=3&&(o.healthStatus="degraded")}addProvider(e,n){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:n?.baseUrl,strategy:n?.strategy??"weighted-round-robin",keys:[],rateLimit:n?.rateLimit})}removeProvider(e){let n=this.pools.get(e);if(n){for(let o of n.keys)this.runtimeStates.delete(o.id);this.pools.delete(e)}}addKey(e,n,o){let i=this.pools.get(e);i||(i={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,i));let s=o?.id??crypto.randomUUID(),a={id:s,key:n,label:o?.label,weight:o?.weight??1,enabled:o?.enabled??!0};return i.keys.push(a),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let n of this.pools.values()){let o=n.keys.findIndex(i=>i.id===e);if(o!==-1){n.keys.splice(o,1),this.runtimeStates.delete(e);return}}}updateKey(e,n){for(let o of this.pools.values()){let i=o.keys.find(s=>s.id===e);if(i){if(n.label!==void 0&&(i.label=n.label),n.weight!==void 0&&(i.weight=n.weight),n.enabled!==void 0){i.enabled=n.enabled;let s=this.runtimeStates.get(e);s&&(s.healthStatus=n.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,n){let o=this.runtimeStates.get(e);o&&(o.healthStatus=n)}setStrategy(e,n){let o=this.pools.get(e);o&&(o.strategy=n)}setRateLimit(e,n){let o=this.pools.get(e);o&&(o.rateLimit=n)}getPoolStatus(e){let n=this.pools.get(e);return n?this.buildPoolStatus(n):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let n=this.pools.get(e);return n?this.getHealthyCandidates(n,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let n=new Set;for(let o of e){this.pools.set(o.providerId,o);for(let i of o.keys)n.add(i.id),this.runtimeStates.has(i.id)||this.runtimeStates.set(i.id,this.createInitialState())}for(let o of[...this.pools.keys()])e.some(i=>i.providerId===o)||this.pools.delete(o);for(let o of[...this.runtimeStates.keys()])n.has(o)||this.runtimeStates.delete(o)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,n){let o=[];for(let i of e.keys){if(!i.enabled)continue;let s=this.runtimeStates.get(i.id);if(s){if(s.healthStatus==="cooldown")if(n>=s.cooldownUntil)s.healthStatus="healthy",s.consecutiveErrors=0;else continue;s.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(s.requestTimestamps,n),s.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(s.tokenCounts,n),s.tokenCounts.reduce((r,d)=>r+d,0)>=e.rateLimit.tpm*.9)||o.push(i))}}return o}selectByStrategy(e,n,o){if(e.length===0)return null;if(e.length===1)return e[0];switch(n){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let n=e.reduce((i,s)=>i+s.weight,0),o=Math.random()*n;for(let i of e)if(o-=i.weight,o<=0)return i;return e[e.length-1]}leastBusy(e){let n=1/0,o=e[0];for(let i of e){let a=this.runtimeStates.get(i.id)?.inFlight??0;(a<n||a===n&&i.weight>o.weight)&&(n=a,o=i)}return o}pruneWindow(e,n){let o=n-6e4;for(;e.length>0&&e[0]<o;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(n=>{let o=this.runtimeStates.get(n.id)??this.createInitialState();return{...n,inFlight:o.inFlight,totalRequests:o.totalRequests,totalTokens:o.totalTokens,lastUsedAt:o.lastUsedAt,lastErrorAt:o.lastErrorAt,consecutiveErrors:o.consecutiveErrors,cooldownUntil:o.cooldownUntil,healthStatus:n.enabled?o.healthStatus:"disabled"}})}}};var Go=[{id:"deepseek",displayName:"DeepSeek",baseUrl:"https://api.deepseek.com",defaultRateLimit:{rpm:60},knownModels:[]},{id:"qwen",displayName:"\u901A\u4E49\u5343\u95EE (DashScope)",baseUrl:"https://dashscope.aliyuncs.com/compatible-mode/v1",defaultRateLimit:{rpm:120},knownModels:[{model:"text-embedding-v4",displayName:"Text Embedding V4",purposes:["embedding"]},{model:"cosyvoice-v2",displayName:"CosyVoice V2",purposes:["tts"]},{model:"paraformer-realtime-v2",displayName:"Paraformer Realtime V2",purposes:["stt"]},{model:"qwen3.5-omni-plus-realtime",displayName:"Qwen Omni Realtime",purposes:["realtimeAudio"]},{model:"wan2.7-t2v",displayName:"\u4E07\u76F8 2.7 \u6587\u751F\u89C6\u9891",purposes:["videoGeneration"]},{model:"wan2.7-i2v",displayName:"\u4E07\u76F8 2.7 \u56FE\u751F\u89C6\u9891",purposes:["videoGeneration"]},{model:"tripo-sr-v2.0-20250123",displayName:"Tripo SR V2",purposes:["threeDGeneration"]}]},{id:"zhipu",displayName:"\u667A\u8C31 AI",baseUrl:"https://open.bigmodel.cn/api/paas/v4",defaultRateLimit:{rpm:120},knownModels:[{model:"embedding-3",displayName:"Embedding-3",purposes:["embedding"]},{model:"glm-tts",displayName:"GLM-TTS",purposes:["tts"]},{model:"glm-asr-2512",displayName:"GLM-ASR",purposes:["stt"]},{model:"glm-image",displayName:"GLM-Image",purposes:["imageGeneration"]},{model:"cogview-4-250304",displayName:"CogView-4",purposes:["imageGeneration"]},{model:"cogvideox-3",displayName:"CogVideoX-3",purposes:["videoGeneration"]},{model:"glm-4-voice",displayName:"GLM-4-Voice",purposes:["realtimeAudio"]},{model:"glm-realtime-flash",displayName:"GLM-Realtime Flash",purposes:["realtimeVideo"]},{model:"glm-realtime-air",displayName:"GLM-Realtime Air",purposes:["realtimeVideo"]}]},{id:"volcengine",displayName:"\u706B\u5C71\u5F15\u64CE (\u8C46\u5305)",baseUrl:"https://ark.cn-beijing.volces.com/api/v3",defaultRateLimit:{rpm:120},knownModels:[{model:"doubao-embedding-large-text-250515",displayName:"\u8C46\u5305\u5411\u91CF Large",purposes:["embedding"]},{model:"doubao-seedream-5.0-lite",displayName:"Seedream 5.0 Lite",purposes:["imageGeneration"]},{model:"doubao-seedream-4.5",displayName:"Seedream 4.5",purposes:["imageGeneration"]},{model:"doubao-seedance-2.0",displayName:"Seedance 2.0",purposes:["videoGeneration"]},{model:"doubao-seedance-2.0-fast",displayName:"Seedance 2.0 Fast",purposes:["videoGeneration"]},{model:"doubao-seed3d-2-0-260328",displayName:"Seed3D 2.0",purposes:["threeDGeneration"]},{model:"hyper3d-gen2",displayName:"Hyper3D Gen2",purposes:["threeDGeneration"]},{model:"hitem3d-2.0",displayName:"Hitem3D 2.0",purposes:["threeDGeneration"]}]},{id:"minimax",displayName:"MiniMax",baseUrl:"https://api.minimax.chat/v1",defaultRateLimit:{rpm:60},knownModels:[{model:"speech-2.8-hd",displayName:"Speech 2.8 HD",purposes:["tts","voiceClone"]},{model:"MiniMax-Hailuo-2.3",displayName:"Hailuo 2.3",purposes:["videoGeneration"]},{model:"image-01",displayName:"Image-01",purposes:["imageGeneration"]},{model:"music-2.6",displayName:"Music 2.6",purposes:["musicGeneration"]},{model:"music-cover",displayName:"Music Cover",purposes:["musicGeneration"]}]},{id:"moonshot",displayName:"Moonshot (Kimi)",baseUrl:"https://api.moonshot.cn/v1",defaultRateLimit:{rpm:60},knownModels:[{model:"kimi-k2.6",displayName:"Kimi K2.6",purposes:["textGeneration","imageUnderstanding"]},{model:"kimi-k2.5",displayName:"Kimi K2.5",purposes:["textGeneration","imageUnderstanding"]},{model:"kimi-k2-thinking",displayName:"Kimi K2 Thinking",purposes:["textGeneration"]},{model:"kimi-k2-turbo-preview",displayName:"Kimi K2 Turbo",purposes:["textGeneration","smallModel"]}]},{id:"openai",displayName:"OpenAI",baseUrl:"https://api.openai.com/v1",defaultRateLimit:{rpm:60},knownModels:[{model:"text-embedding-3-large",displayName:"Text Embedding 3 Large",purposes:["embedding"]},{model:"gpt-image-2",displayName:"GPT Image 2",purposes:["imageGeneration"]},{model:"gpt-4o-mini-tts",displayName:"GPT-4o Mini TTS",purposes:["tts"]},{model:"gpt-realtime-whisper",displayName:"GPT Realtime Whisper",purposes:["stt"]},{model:"gpt-realtime-2",displayName:"GPT Realtime 2",purposes:["realtimeAudio"]}]},{id:"anthropic",displayName:"Anthropic",baseUrl:"https://api.anthropic.com",defaultRateLimit:{rpm:60},knownModels:[]},{id:"google",displayName:"Google (Gemini)",baseUrl:"https://generativelanguage.googleapis.com/v1beta",defaultRateLimit:{rpm:60},knownModels:[{model:"gemini-embedding-2",displayName:"Gemini Embedding 2",purposes:["embedding"]},{model:"imagen-4.0-generate-001",displayName:"Imagen 4",purposes:["imageGeneration"]},{model:"imagen-4.0-fast-generate-001",displayName:"Imagen 4 Fast",purposes:["imageGeneration"]},{model:"veo-3.1-generate-preview",displayName:"Veo 3.1",purposes:["videoGeneration"]},{model:"veo-3.1-fast-generate-preview",displayName:"Veo 3.1 Fast",purposes:["videoGeneration"]},{model:"gemini-3.1-flash-tts-preview",displayName:"Gemini 3.1 TTS",purposes:["tts"]},{model:"gemini-3.1-flash-live-preview",displayName:"Gemini 3.1 Live",purposes:["realtimeAudio"]},{model:"lyria-3-pro-preview",displayName:"Lyria 3 Pro",purposes:["musicGeneration"]},{model:"lyria-3-clip-preview",displayName:"Lyria 3 Clip",purposes:["musicGeneration"]}]}];var xt=class{keyPool;models=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){if(this.settingsPath=Bo(),this.keyPool=new De(e?.providers),e?.models)for(let n of e.models)this.models.set(n.id,n);e?.bindings&&(this.bindings={...e.bindings})}getActiveModel(e){let n=this.bindings[e];if(!n)return null;let o=this.models.get(n);if(!o||!o.enabled)return null;let i=this.keyPool.acquireKey(o.provider);return i?{provider:o.provider,model:o.model,apiKey:i.apiKey,baseUrl:o.baseUrl??this.getProviderBaseUrl(o.provider),keyHandle:i}:null}peekActiveModel(e){let n=this.bindings[e];return n?this.models.get(n)??null:null}isAvailable(e){let n=this.bindings[e];if(!n)return!1;let o=this.models.get(n);return!o||!o.enabled?!1:this.keyPool.hasAvailableKey(o.provider)}resolveModelForPurpose(e){let n=this.peekActiveModel(e);if(n)return n.model;if(e!=="textGeneration"){let o=this.peekActiveModel("textGeneration");if(o)return o.model}return null}addProvider(e,n){this.keyPool.addProvider(e,n),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[n,o]of this.models)if(o.provider===e){this.models.delete(n);for(let[i,s]of Object.entries(this.bindings))s===n&&delete this.bindings[i]}this.emitChange()}addKey(e,n,o){let i=this.keyPool.addKey(e,n,o);return this.emitChange(),i}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,n){this.keyPool.updateKey(e,n)}setKeyHealth(e,n){this.keyPool.setKeyHealth(e,n)}setStrategy(e,n){this.keyPool.setStrategy(e,n)}addModel(e){let n=e.id??`${e.provider}:${e.model}`,o={...e,id:n};return this.models.set(n,o),this.emitChange(),n}removeModel(e){this.models.delete(e);for(let[n,o]of Object.entries(this.bindings))o===e&&delete this.bindings[n];this.emitChange()}enableModel(e){let n=this.models.get(e);n&&(n.enabled=!0)}disableModel(e){let n=this.models.get(e);n&&(n.enabled=!1)}listModels(e){let n=[...this.models.values()];return e?.purpose&&(n=n.filter(o=>o.purposes.includes(e.purpose))),e?.provider&&(n=n.filter(o=>o.provider===e.provider)),e?.enabledOnly&&(n=n.filter(o=>o.enabled)),n}getModel(e){return this.models.get(e)??null}setBinding(e,n){let o=this.models.get(n);if(!o)throw new Error(`Model "${n}" not found in pool.`);if(!o.purposes.includes(e))throw new Error(`Model "${n}" does not support purpose "${e}".`);this.bindings[e]=n,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let n=this.bindings[e];return n?this.models.get(n)??null:null}getAllBindings(){let e={};for(let n of cs){let o=this.bindings[n];e[n]=o?this.models.get(o)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{$.existsSync(this.settingsPath)&&(e=JSON.parse($.readFileSync(this.settingsPath,"utf-8")))}catch{}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let n={...e,providers:this.keyPool.exportConfig(),models:[...this.models.values()],bindings:{...this.bindings}},o=this.settingsPath.replace(/[/\\][^/\\]+$/,"");$.existsSync(o)||$.mkdirSync(o,{recursive:!0}),$.writeFileSync(this.settingsPath,JSON.stringify(n,null,2),"utf-8")}load(){try{if(!$.existsSync(this.settingsPath))return!1;let e=$.readFileSync(this.settingsPath,"utf-8"),n=JSON.parse(e);if(!n.providers&&typeof n.provider=="string"&&typeof n.apiKey=="string"){let i=n.provider,s=n.apiKey,a=n.model||"",r=n.baseUrl,d=Go.find(y=>y.id===i),h=r||d?.baseUrl||"",p={providerId:i,baseUrl:h,strategy:"weighted-round-robin",keys:[{id:`${i}-key-0`,key:s,label:"migrated",weight:1,enabled:!0}]};this.keyPool.reloadConfig([p]),this.models.clear();let f=d?.knownModels??[],b="";for(let y of f){let _=`${i}:${y.model}`;this.models.set(_,{id:_,provider:i,model:y.model,displayName:y.displayName,purposes:y.purposes,baseUrl:y.baseUrl,enabled:!0}),y.model===a&&(b=_)}return!b&&a&&(b=`${i}:${a}`,this.models.set(b,{id:b,provider:i,model:a,displayName:a,purposes:["textGeneration"],enabled:!0})),b?this.bindings={textGeneration:b}:f.length>0?this.bindings={textGeneration:`${i}:${f[0].model}`}:this.bindings={},this.save(),this.emitChange(),!0}let o=n;if(o.providers&&this.keyPool.reloadConfig(o.providers),this.models.clear(),o.models)for(let i of o.models)this.models.set(i.id,i);return this.bindings=o.bindings??{},("summary"in this.bindings||"background"in this.bindings)&&!("smallModel"in this.bindings)&&(this.bindings.smallModel=this.bindings.summary??this.bindings.background),delete this.bindings.summary,delete this.bindings.background,this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:[...this.models.values()],bindings:{...this.bindings}}}getTunable(e){try{if(!$.existsSync(this.settingsPath))return;let n=$.readFileSync(this.settingsPath,"utf-8");return JSON.parse(n).tunables?.[e]}catch{return}}_providerRegistry=null;getProviderRegistry(){return this._providerRegistry||(this._providerRegistry=new ue),this._providerRegistry}getModelInfo(e,n){return this.getProviderRegistry().getModelInfo(e,n)}getProviderDefaultModel(e){return this.getProviderRegistry().getProvider(e)?.defaultModel}listProviderDefs(){return this.getProviderRegistry().listProviders()}resolveProviderApiKey(e){let n=this.getKeyForProvider(e);return n||this.getProviderRegistry().resolveApiKey(e)}onChange(e){return this.changeListeners.push(e),()=>{let n=this.changeListeners.indexOf(e);n>=0&&this.changeListeners.splice(n,1)}}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}getKeyForProvider(e){let n=this.keyPool.acquireKey(e);if(!n)return null;let o=n.apiKey;return n.release({success:!0}),o}snapshotProviderKeys(){let e={};for(let n of this.keyPool.getAllStatus()){let o=this.getKeyForProvider(n.providerId);o&&(e[n.providerId]=o)}return e}getProviderBaseUrl(e){return this.keyPool.getPoolStatus(e)?.baseUrl}},cs=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],$e=null;function kt(){return $e||($e=new xt,$e.load()),$e}function St(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}function wt(t){let e=0;for(let n of t)e+=St(n);return e}var Ct={"deepseek-v4-flash":1e6,"deepseek-v4-pro":1e6,"deepseek-chat":1e6,"deepseek-reasoner":1e6,"gpt-4o":128e3,"gpt-4o-mini":128e3,"claude-sonnet-4-20250514":2e5,"claude-3-5-haiku-20241022":2e5,"gemini-3.1-pro-preview":1e6,"gemini-3-flash-preview":1e6,"gemini-3.1-flash-lite":1e6};function us(t){if(!t)return 128e3;if(t in Ct)return Ct[t];let e=t.toLowerCase();for(let[n,o]of Object.entries(Ct))if(e.startsWith(n.toLowerCase()))return o;return 128e3}var ds=8e3;var ps=new re(200);var ms=new ae;function jo(){return ms}function fs(){return He(new se(ds),new X(20,St),new ie(St))}var gs=null;function Wo(t,e){let n=e?.budget??Ke({modelContextWindow:us(e?.model)}),i=(e?.pipeline??fs()).compress(t,n);if(i.droppedCount>0){let s=wt(t),a=wt(i.messages);ps.record({timestamp:Date.now(),strategy:i.strategy,tokensBefore:s,tokensAfter:a,droppedCount:i.droppedCount,latencyMs:i.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:i.metrics?.cacheInvalidated??!1,tier:Ve(s,n)})}return i.droppedCount>0&&gs?.(i.droppedCount,wt(i.messages)),i}function zo(t,e,n){let o=n-e;return`[Budget] ${Math.round(t)}% used (${e.toLocaleString()} / ${n.toLocaleString()} tokens). ${o.toLocaleString()} tokens remaining. `+(t>=90?"Wrap up your current taskyou are near the token limit.":"Continue workingdo not summarize prematurely.")}var ws=new Set(["write","edit","patch","apply_patch"]);function Cs(t){let e=t.split(".").pop()?.toLowerCase()??"";return["png","jpg","jpeg","gif","webp","svg","bmp","ico"].includes(e)?"image":["md","txt","pdf","doc","docx","rtf","html"].includes(e)?"document":["mermaid","mmd","dot","puml","plantuml"].includes(e)?"diagram":["csv","tsv","xlsx","xls"].includes(e)?"table":["ts","tsx","js","jsx","py","rs","go","java","c","cpp","h","cs","rb","sh","sql","json","yaml","yml","toml","xml","css","scss","vue","svelte"].includes(e)?"code":"file"}function Ss(t){let e=t.split(".").pop()?.toLowerCase()??"";return{ts:"typescript",tsx:"typescriptreact",js:"javascript",jsx:"javascriptreact",py:"python",rs:"rust",go:"go",java:"java",c:"c",cpp:"cpp",h:"c",cs:"csharp",rb:"ruby",sh:"shellscript",sql:"sql",json:"json",yaml:"yaml",yml:"yaml",toml:"toml",xml:"xml",html:"html",css:"css",scss:"scss",vue:"vue",svelte:"svelte",md:"markdown"}[e]}var vs=/^no (matches|files|results) found\.?$|^file not found|^not found|^0 results|^\(exit code \d+, no output\)$/i,Ms=new Set(["search","grep","glob","find","list","read","exec"]);function Rs(t){if(!Ms.has(t.toolName))return!1;let e=typeof t.message?.content=="string"?t.message.content.trim():"";return e.length>0&&e.length<200&&vs.test(e)}function Vo(t,e){for(let n=t.length-1;n>=0;n--){let o=t[n];if(!o||o.role!=="tool")continue;let i=typeof o.content=="string"?o.content:"";if(i.startsWith("Error: "))return i.slice(7).trim()}}function Es(t){return typeof t=="number"&&Number.isFinite(t)&&t>=1?Math.min(Math.round(t),100):Yt}function Xo(t){let e=t.message.toLowerCase();return t.status===413||e.includes("prompt_too_long")||e.includes("context_length_exceeded")||e.includes("maximum context length")}function As(t){return t==="length"||t==="max_tokens"}function Yo(t){let e=t.message.toLowerCase();return(e.includes("image")||e.includes("media")||e.includes("file too large")||e.includes("payload too large"))&&(t.status===413||e.includes("too large")||e.includes("size"))}function Is(t){let e=t.headers;if(!e)return null;let n=e["retry-after"]??e["Retry-After"];if(!n)return null;let o=parseInt(n,10);return!isNaN(o)&&o>0?o*1e3:null}function Os(t){if(t.status!==400)return null;let e=t.message.match(/input length and `max_tokens` exceed context limit: (\d+) \+ (\d+) > (\d+)/);if(!e?.[1]||!e?.[3])return null;let n=parseInt(e[1],10),o=parseInt(e[3],10);if(isNaN(n)||isNaN(o))return null;let i=o-n-1e3;return i>=3e3?i:null}function Us(t){return t.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*Jo(t,e,n,o){let{turnId:i,sessionId:s,messages:a,tools:r,model:d,apiKey:h,temperature:p=0,hooks:f,signal:b}=t,y={sessionId:s,turnId:i},_=t.maxTurns??0,k=t.querySource,{resolveToolEligibility:w}=await Promise.resolve().then(()=>(Ko(),Ho)),L=w(r,t.toolEligibilityContext),v=L.eligibleTools;for(let C of L.blockedTools)yield{type:"tool_blocked",turnId:i,callId:"",name:C.toolName,reason:"blocked-by-policy"};if(!v.length){yield*Ls(i,d,a,h,p,b,e,o);return}let A=Es(t.maxRounds),D={contextWindowTokens:t.contextWindowTokens??Zt,responseBufferTokens:qt,maxOutputTokens:t.maxOutputTokens??eo,abortSignal:b,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},R=new Set,I=0,pe=v,me,l={messages:[...a],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:ut(D),reactiveCompactState:gt(),toolLoopState:Se({maxRounds:A,replayMessages:[...a]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:Ye(),currentModel:d,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:Oo(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},vt=Math.max(_*5,200),Mt=0;for(;;){if(Mt++,Mt>vt){o.info(`hard iteration cap reached (${vt}), forcing completion`);let c=l.finalText||de(l.messages,o);yield{type:"end",turnId:i,content:c,usage:l.totalUsage,model:l.currentModel};return}let{messages:C,maxOutputTokensRecoveryCount:q,hasAttemptedReactiveCompact:Ns,maxOutputTokensOverride:Rt,turnCount:ee,guardState:O,reactiveCompactState:G,collapseStore:Ne}=l,{toolLoopState:N}=l;if(me){try{let c=await me;c&&(yield{type:"tool_use_summary",turnId:i,summary:c})}catch{}me=void 0}if(t.refreshTools&&ee>1){let c=t.refreshTools();c!==pe&&(pe=c,o.debug(`tools refreshed: ${c.length} tools`))}if(ft(O,D)){o.info(`turn aborted by guard at turn ${ee}`),yield{type:"error",turnId:i,error:"Turn aborted",code:"ABORTED",usage:l.totalUsage};return}let z=dt(O,D);if(z.level==="blocking"){z.reason==="prompt_too_long"&&J(G)&&(G.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,o.info(`token budget blocking (${z.reason}), reactive compact needed`),yield{type:"recovery",turnId:i,action:"reactive_compact",detail:"token budget pre-check"}),o.info(`token budget blocking (${z.reason}), ending tool loop`);break}z.level==="warning"&&o.info(`token budget warning: ${z.usagePercent}% used, ${z.remainingTokens} remaining`);let U;{let c=await No(C,l.contentReplacementState,s);U=c.messages,c.newlyReplacedCount>0&&(o.info(`tool-result-budget: persisted ${c.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:i,action:"tool_result_budget",detail:`${c.newlyReplacedCount} persisted`})}{let c=Xe(U,l.snipRemovedIds);U=c.messages,c.removedCount>0&&(o.info(`snip: removed ${c.removedCount} messages, freed ~${c.tokensFreed} tokens`),yield{type:"recovery",turnId:i,action:"snip",detail:`${c.removedCount} messages`})}{let u=new X().compress(U,0);u.droppedCount>0&&(U=u.messages,o.info(`microcompact: cleared ${u.droppedCount} old tool results`))}if(U=Je(U,Ne).messages,O.promptTokens>0){let c=D.contextWindowTokens*.75,u=jo().getActive(),m;u?m=await u.compressAsync(U,c,{model:l.currentModel,sessionId:s}):m=Wo(U,{budget:c,model:l.currentModel}),m.droppedCount>0&&(U=m.messages,o.info(`autocompact: ${m.strategy}, dropped ${m.droppedCount}`),yield{type:"recovery",turnId:i,action:"autocompact",detail:`${m.strategy}: ${m.droppedCount} dropped`},l.hasAttemptedReactiveCompact=!1,f?.invoke("context.after_compact",{...y,removedCount:m.droppedCount}).catch(()=>{}))}U=Us(U);let fe=ot({tools:pe,toolChoice:t.toolChoice??"auto"}),te=Se({maxRounds:A,replayMessages:U,lastStopReason:N.lastStopReason,options:{stopReason:N.lastStopReason}}),Et=fe.extraSystemPrompt?[{role:"system",content:fe.extraSystemPrompt},...te.state.replayMessages]:te.state.replayMessages;N=te.state,te.recoveryActions.length>0&&o.debug(`tool loop recovery: ${te.recoveryActions.map(c=>c.detail??c.kind).join("; ")}`),o.debug(`turn ${ee}, messages: ${Et.length}`),f?.invoke("turn.before_inference",{...y,model:l.currentModel}).catch(()=>{});let ge=!1,At=[],It=new Map,Ot="stop",F,S=null,he=!1,oe=[],P=[];try{for await(let c of e.stream({model:l.currentModel,messages:Et,tools:fe.tools,toolChoice:fe.normalizedToolChoice??"auto",temperature:p,maxTokens:(Rt??O.currentMaxOutputTokens)||void 0,streamRequired:t.streamRequired,previousResponseId:l.lastResponseId,reasoning:t.reasoning,promptCacheKey:t.promptCacheKey,promptCacheRetention:t.promptCacheRetention,serviceTier:t.serviceTier,openaiBuiltinTools:t.openaiBuiltinTools,maxToolCalls:t.maxToolCalls,parallelToolCalls:t.parallelToolCalls,textVerbosity:t.textVerbosity},h,b))switch(c.type){case"delta":At.push(c.text),ge||(yield{type:"delta",turnId:i,text:c.text});break;case"tool_call_delta":ge=!0,ht(It,c);break;case"reasoning_delta":oe.push(c.text);break;case"reasoning_block_complete":c.signature&&P.push({thinking:oe.join(""),signature:c.signature}),oe.length=0;break;case"usage":F={inputTokens:c.promptTokens,outputTokens:c.completionTokens,reasoningTokens:c.reasoningTokens,cacheRead:c.cacheReadTokens,cacheWrite:c.cacheCreationTokens};break;case"response_id":l.lastResponseId=c.id;break;case"annotations":yield{type:"annotations",turnId:i,annotations:c.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:i,message:`${c.toolType}: ${c.event}`};break;case"done":Ot=c.finishReason;break}if(ge||f?.invoke("turn.after_inference",{...y,model:l.currentModel}).catch(()=>{}),t.postSamplingHooks&&t.postSamplingHooks.length>0){let c=l.currentModel;for(let u of t.postSamplingHooks)try{u({messages:[...U],model:c,sessionId:s})}catch{}}}catch(c){if(c instanceof ce&&t.fallbackModel){o.info(`model fallback triggered: ${c.originalModel} \u2192 ${c.fallbackModel}`),yield{type:"recovery",turnId:i,action:"model_fallback",detail:`${c.originalModel} \u2192 ${c.fallbackModel}`},l={...l,currentModel:c.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let u=c instanceof Error?c.message:String(c),m=typeof c?.status=="number"?c.status:void 0;if(!m&&u&&(u.includes("ECONNRESET")||u.includes("EPIPE"))){let x=(l.consecutiveApiRetries??0)+1;if(x>le){o.info(`stale connection retry limit reached (${le}), aborting`),yield{type:"error",turnId:i,error:u,code:"RETRIES_EXHAUSTED",usage:l.totalUsage};return}o.info(`stale connection (${u.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:i,action:"stale_connection_retry",detail:u.slice(0,80)},l={...l,consecutiveApiRetries:x,transition:void 0};continue}let g=Os({status:m,message:u});if(g!==null){o.info(`max_tokens overflow: adjusting to ${g}`),O.currentMaxOutputTokens=g,l={...l,maxOutputTokensOverride:g,transition:void 0};continue}if(ct(m)){l.consecutive529Errors++;let x=2,E=t.fallbackModel&&l.currentModel!==t.fallbackModel;if(l.consecutive529Errors>x&&!E&&!Me()){o.info(`transient ${m} \xD7 ${l.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:i,error:`API unavailable after ${l.consecutive529Errors} consecutive ${m} errors`,code:"API_ERROR",usage:l.totalUsage};return}if(l.consecutive529Errors>=lo&&t.fallbackModel&&l.currentModel!==t.fallbackModel){o.info(`529 \xD7 ${l.consecutive529Errors}: triggering fallback to ${t.fallbackModel}`),yield{type:"recovery",turnId:i,action:"model_fallback",detail:`529 \xD7 ${l.consecutive529Errors}`},l={...l,currentModel:t.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Me()){let T=ve(l.consecutive529Errors);o.info(`persistent retry: waiting ${T}ms (attempt ${l.consecutive529Errors})`);let M=T;for(;M>0;){if(b?.aborted){yield{type:"error",turnId:i,error:"Aborted during retry wait",code:"ABORTED",usage:l.totalUsage};return}yield{type:"heartbeat",turnId:i,message:`Retrying in ${Math.ceil(M/1e3)}s (${m})`};let B=Math.min(M,ao);await new Promise(Ge=>setTimeout(Ge,B)),M-=B}l={...l,transition:void 0};continue}if(lt(k)){let M=Is({status:m,message:u})??ve(l.consecutive529Errors);o.info(`transient ${m}: retry in ${M}ms`),yield{type:"recovery",turnId:i,action:"retry",detail:`${m} retry in ${M}ms`},await new Promise(B=>setTimeout(B,M)),l={...l,transition:void 0};continue}o.info(`background source ${k}: not retrying ${m}`)}S={status:m,message:u}}if(S&&f?.invoke("turn.after_inference",{...y,model:l.currentModel,response:{error:S.message}}).catch(()=>{}),S)if(Xo(S))he=!0,o.info(`withheld prompt_too_long error (status=${S.status})`);else if(Yo(S))he=!0,o.info(`withheld media_size error (status=${S.status})`);else{let c=pt({status:S.status??500,message:S.message},O,D);if(c.action==="reactive_compact"&&J(G)&&(G.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:i,action:"reactive_compact",detail:`API ${S.status??500}: ${S.message}`}),c.action==="retry"){let m=(l.consecutiveApiRetries??0)+1;if(m>le){o.info(`API retry limit reached (${le}), aborting`);let g=Y(S.status,S.message);yield{type:"error",turnId:i,error:S.message,code:g,usage:l.totalUsage};return}yield{type:"recovery",turnId:i,action:"retry",detail:c.reason},l={...l,consecutiveApiRetries:m,transition:void 0};continue}let u=Y(S.status,S.message);f?.invoke("stop.failure",{sessionId:s,reason:u,error:S.message}).catch(()=>{}),yield{type:"error",turnId:i,error:S.message,code:u,usage:l.totalUsage};return}F&&(l.totalUsage.inputTokens+=F.inputTokens,l.totalUsage.outputTokens+=F.outputTokens,F.reasoningTokens&&(l.totalUsage.reasoningTokens=(l.totalUsage.reasoningTokens??0)+F.reasoningTokens),F.cacheRead&&(l.totalUsage.cacheRead=(l.totalUsage.cacheRead??0)+F.cacheRead),F.cacheWrite&&(l.totalUsage.cacheWrite=(l.totalUsage.cacheWrite??0)+F.cacheWrite)),F?.inputTokens&&(O.promptTokens=F.inputTokens);let Ut=At.join("");Ut&&(l.finalText=Ut);let j=[...It.values()].map(c=>({id:c.id||`tc_${i}_${ee}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:c.name,arguments:c.arguments}}));if(j.length===0&&!ge){if(he&&S&&Xo(S)){if(l.transition?.reason!=="collapse_drain_retry"){let m=Qe(U,Ne);if(m.committed>0){o.info(`collapse drain: committed ${m.committed} stages`),yield{type:"recovery",turnId:i,action:"collapse_drain",detail:`${m.committed} stages committed`},l={...l,messages:m.messages,transition:{reason:"collapse_drain_retry",committed:m.committed}};continue}}if(J(G)){G.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,o.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:i,action:"reactive_compact",detail:"withheld prompt_too_long"},l={...l,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld 413: recovery exhausted, surfacing error"),f?.invoke("stop.failure",{sessionId:s,reason:"prompt_too_long",error:S.message}).catch(()=>{}),yield{type:"error",turnId:i,error:S.message,code:"PROMPT_TOO_LONG",usage:l.totalUsage};return}if(he&&S&&Yo(S)){if(J(G)){G.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,o.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:i,action:"reactive_compact",detail:"media error strip-retry"},l={...l,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld media error: recovery exhausted"),f?.invoke("stop.failure",{sessionId:s,reason:"media_error",error:S.message}).catch(()=>{}),yield{type:"error",turnId:i,error:S.message,code:"IMAGE_ERROR",usage:l.totalUsage};return}if(As(Ot)){O.consecutiveTruncations+=1;let m=t.modelMaxOutputTokens??to,g=mt(O,D,m);if(g.shouldEscalate&&Rt===void 0){O.currentMaxOutputTokens=g.newMax,o.info(`max_output_tokens escalate: ${g.newMax} tokens`),yield{type:"recovery",turnId:i,action:"output_escalation",detail:`${g.newMax} tokens`},l={...l,maxOutputTokensOverride:no,transition:{reason:"max_output_tokens_escalate"}};continue}if(q<oo){let x={role:"user",content:"Output token limit hit. Resume directly \u2014 no apology, no recap of what you were doing. Pick up mid-thought if that is where the cut happened. Break remaining work into smaller pieces."};o.info(`max_output_tokens recovery #${q+1}`),yield{type:"recovery",turnId:i,action:"max_output_tokens_recovery",detail:`attempt ${q+1}`},l={...l,messages:[...U,x],maxOutputTokensRecoveryCount:q+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:q+1}};continue}o.info("max_output_tokens recovery exhausted, completing with partial content")}else O.consecutiveTruncations=0;if(N=Ce(N,{replayMessages:C,lastStopReason:"completed"}),f){let m=await f.invoke("stop",{sessionId:s,reason:"completed"});if(m.action==="prevent"){o.info(`stop hook prevented continuation: ${m.reason??"no reason"}`),yield{type:"end",turnId:i,content:l.finalText,usage:l.totalUsage,model:l.currentModel};return}if(m.action==="abort"){let g=m.reason??"Stop hook requested continuation";o.info(`stop hook blocking: ${g}`);let x={role:"user",content:g},E={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,E,x],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(t.tokenBudget&&t.tokenBudget>0&&l.budgetContinuationCount<5){let m=l.totalUsage.inputTokens+l.totalUsage.outputTokens+(l.totalUsage.reasoningTokens??0),g=m/t.tokenBudget*100,x=m-l.lastBudgetGlobalTokens,E=l.budgetContinuationCount>=io&&x<Ze&&l.lastBudgetDeltaTokens<Ze;if(E&&o.info(`token budget early stop: diminishing returns at ${Math.round(g)}% (delta=${x})`),!E&&g<90){let T=l.budgetContinuationCount+1,M={role:"user",content:zo(g,m,t.tokenBudget)};o.info(`token budget continuation #${T}: ${Math.round(g)}% used`),yield{type:"recovery",turnId:i,action:"budget_continuation",detail:`${Math.round(g)}% used (#${T})`};let B={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,B,M],budgetContinuationCount:T,lastBudgetDeltaTokens:x,lastBudgetGlobalTokens:m,transition:{reason:"token_budget_continuation"}};continue}}if(!l.stopHookActive){let m=a.find(T=>T.role==="user"),g=typeof m?.content=="string"?m.content:"",x=/创建文件|生成文件|写入|写一个|建一个|新建|重写|改写|create\s+(a\s+)?file|write\s+(a\s+)?file|make\s+(a\s+)?file|修改|改成|把.*改|文件名叫/i.test(g),E=R.has("write")||R.has("edit");if(x&&!E){if(o.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),I>0){let B=[...C].reverse().find(Ge=>Ge.role==="tool");B&&typeof B.content=="string"&&(B.content+=`
18
18
 
19
- \u26A0\uFE0F NOTE: You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail silently or produce incorrect results on this platform. Please use the 'write' tool directly to create the requested file with the correct content.`)}let T={role:"user",content:I===0?"You described what to do but did not actually call any tool to write or edit a file. Please use the write or edit tool now to perform the requested action. Do not just describe the changes \u2014 actually make them.":"You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail on this platform. Please use the write tool directly to create the requested file with the correct content."},M={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,M,T],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!l.stopHookActive&&I>=3&&R.has("write")){let m=0;for(let g of C){let x=g,E=x.is_error===!0||typeof x.content=="string"&&x.content.startsWith("Error:");x.role==="tool"&&typeof x.content=="string"&&!E&&m++}if(m>=3){o.info("AP3 verification nudge: 3+ files created, injecting completeness check");let g={role:"user",content:"You created multiple files. Before completing, verify: (1) All imports between your files resolve to real exports. (2) No TODO, placeholder, or 'not implemented' stubs remain. (3) Functions that are imported are actually called, not just declared. If everything is correct, confirm completion. If not, fix the issues now."},x={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,x,g],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(I>0){let m={ok:!0,toolCallCount:I,distinctToolCount:R.size,multiStep:I>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},g=we(m,{tools:[...R],projectRoot:t.projectRoot});g&&(yield{type:"skill_instruction",turnId:s,instruction:g})}let u=l.finalText||de(C,o);yield{type:"end",turnId:s,content:u,usage:l.totalUsage,model:l.currentModel};return}let en=P.length===0&&oe.length>0?oe.join(""):void 0;C.push(je(j,l.finalText||void 0,P.length>0?P:void 0,en)),N=at(N,{replayMessages:C,pendingToolCallIds:j.map(c=>c.id),completedToolCallIds:N.completedToolCallIds,lastStopReason:"tool_calls"});let ye=l.identicalCallCounts,Lt=[],be=[],Pt=!1;for(let c of j){let u=`${c.function.name}::${c.function.arguments}`,m=ye.get(u)??0;ye.set(u,m+1),m+1>Qt?(be.push(c),Pt||(Pt=!0,o.info(`AP4 blocked: ${c.function.name} repeated ${m+1}x`))):Lt.push(c)}let Te=[];for(let c of be){let u=ye.get(`${c.function.name}::${c.function.arguments}`),m=Vo(C,c.function.name),g=m?`This exact tool call has been attempted ${u} times. Last error: ${m}. Do not retry. Report this error to the user.`:`This exact tool call has been attempted ${u} times and keeps failing. Do not retry it. Report the issue to the user or try a completely different approach.`,x=W(c.id,{ok:!1,error:g});C.push(x),Te.push(c.id),R.add(c.function.name),I++,yield{type:"tool_result",turnId:s,callId:c.id,name:c.function.name,ok:!1,error:g}}if(be.length>0){let c=Vo(C,be[0].function.name),u={role:"user",content:"Tool calls were blocked because you repeated them with identical arguments too many times. "+(c?`The error was: "${c}". Tell the user about this error. `:"The operation is not working. ")+"Stop retrying and report the result to the user."};C.push(u)}let _e=[],Fe=[];for(let c of Lt)(l.toolFailureCounts.get(c.function.name)??0)>=xe?Fe.push(c):_e.push(c);if(Fe.length>0){for(let u of Fe){let m=l.toolFailureCounts.get(u.function.name),g=`Tool "${u.function.name}" has failed ${m} times this turn with different arguments. The target likely does not exist. Stop trying variations and report the issue to the user.`,x=W(u.id,{ok:!1,error:g});C.push(x),Te.push(u.id),R.add(u.function.name),I++,yield{type:"tool_result",turnId:s,callId:u.id,name:u.function.name,ok:!1,error:g},o.info(`AP4-variant blocked: ${u.function.name} failed ${m}x with different args`)}let c={role:"user",content:"Tool calls were blocked because the tool has failed too many times with different arguments. The resource you are looking for does not exist. Stop trying variations and tell the user what happened."};C.push(c)}for(let c of _e){let u=c.function.arguments,m=pe.find(g=>g.function.name===c.function.name);if(m?.backfillObservableInput)try{let g=JSON.parse(c.function.arguments),x={...g};m.backfillObservableInput(x),Object.keys(x).some(T=>!(T in g))&&(u=JSON.stringify(x))}catch{}yield{type:"tool_call",turnId:s,callId:c.id,name:c.function.name,arguments:u}}let tn=new Map(l.toolFailureCounts);try{let c=new Pe({toolInvoker:n,hooks:f,sessionId:i,turnId:s,log:o,signal:b,maxConcurrentTools:t?.maxConcurrentTools});for(let u of _e)c.addTool(u);for await(let u of c.getRemainingResults()){u.blocked&&(yield{type:"tool_blocked",turnId:s,callId:u.callId,name:u.toolName,reason:u.blockReason??"blocked"}),C.push(u.message),Te.push(u.callId),R.add(u.toolName),I++;let m=u.ok&&Ri(u);if(!u.ok||m){let T=(l.toolFailureCounts.get(u.toolName)??0)+1;l.toolFailureCounts.set(u.toolName,T)}if(u.ok&&u.toolName==="read"){let E=_e.find(T=>T.id===u.callId);if(E)try{let T=JSON.parse(E.function.arguments),M=T.file_path??T.path??T.filePath??"";if(M){let B=l.fileReadCounts.get(M)??0;l.fileReadCounts.set(M,B+1)}}catch{}}let g=typeof u.message?.content=="string"?u.message.content:"",x=u.ok&&g?g.slice(0,2e3):void 0;if(yield{type:"tool_result",turnId:s,callId:u.callId,name:u.toolName,ok:u.ok,error:u.error,outputPreview:x},u.ok){let E=j.find(T=>T.id===u.callId);if(E){if(u.toolName==="plan_mode")try{let T=JSON.parse(E.function.arguments);T.action==="exit"&&typeof T.plan=="string"&&T.plan.length>0&&(yield{type:"plan_update",turnId:s,slug:"approved-plan",content:T.plan})}catch{}if(wi.has(u.toolName))try{let T=JSON.parse(E.function.arguments),M=typeof T.file_path=="string"?T.file_path:typeof T.filePath=="string"?T.filePath:typeof T.path=="string"?T.path:void 0;M&&(yield{type:"artifact",turnId:s,artifactId:`artifact-${u.callId}`,artifactType:Ci(M),title:M.split(/[\\/]/).pop()||M,filePath:M,language:Si(M)})}catch{}}}}}catch(c){let u=c instanceof Error?c.message:String(c);yield{type:"error",turnId:s,error:u,code:"TOOL_EXECUTION_ERROR",usage:l.totalUsage};return}for(let[c,u]of l.toolFailureCounts)u>=xe&&(tn.get(c)??0)<xe&&C.push({role:"user",content:`Tool "${c}" has now failed/returned empty results ${u} times with different arguments. The target clearly does not exist. Do NOT call "${c}" again. Report the result to the user immediately.`});if(N=Ce(N,{replayMessages:C,completedToolCallIds:[...N.completedToolCallIds,...Te],lastStopReason:"tool_calls"}),t.generateToolUseSummary&&j.length>0){let c=j.map(u=>({name:u.function.name,arguments:u.function.arguments}));me=t.generateToolUseSummary(c).catch(()=>null)}let on=j.length>0&&j.every(c=>{let u=C.find(g=>g?.role==="tool"&&g?.tool_call_id===c.id);if(!u)return!0;let m=u.content;return typeof m=="string"&&m.startsWith("Error: ")}),ne=l.consecutiveFailedRounds;if(on){if(ne+=1,ne>=Jt){let c=l.finalText||de(C,o);o.info(`early exit: ${ne} consecutive failed rounds, returning ${l.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:s,content:c,usage:l.totalUsage,model:l.currentModel};return}}else ne=0;let nn=3,Dt=[...l.fileReadCounts.entries()].filter(([,c])=>c>=nn);if(Dt.length>0){let c=Dt.map(([m])=>m).join(", ");o.info(`AP5: file read cycle detected on ${c}, injecting nudge`);let u={role:"user",content:`You are reading the same files repeatedly (${c}). This indicates a circular dependency or cycle. Stop reading files, summarize your findings so far, and explain the circular structure to the user.`};C.push(u),l.fileReadCounts.clear()}let Be=ee+1;if(_>0&&Be>_){if(o.info(`max turns reached (${_}), completing`),f){let u=await f.invoke("stop",{sessionId:i,reason:"max_turns"});if(u.action==="abort"){let m=u.reason??"Stop hook requested continuation after max_turns",g={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,g,{role:"user",content:m}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let c=l.finalText||de(C,o);yield{type:"end",turnId:s,content:c,usage:l.totalUsage,model:l.currentModel};return}if(Be>A){if(o.info(`tool loop budget exhausted (${A} rounds), returning`),I>0){let u={ok:!0,toolCallCount:I,distinctToolCount:R.size,multiStep:I>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},m=we(u,{tools:[...R],projectRoot:t.projectRoot});m&&(yield{type:"skill_instruction",turnId:s,instruction:m})}let c=l.finalText||de(C,o);yield{type:"end",turnId:s,content:c,usage:l.totalUsage,model:l.currentModel};return}l={messages:C,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:Be,transition:{reason:"next_turn"},guardState:O,reactiveCompactState:G,toolLoopState:N,consecutiveFailedRounds:ne,finalText:l.finalText,totalUsage:l.totalUsage,collapseStore:Ne,currentModel:l.currentModel,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:l.stopHookActive,lastResponseId:l.lastResponseId,snipRemovedIds:l.snipRemovedIds,contentReplacementState:l.contentReplacementState,budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:ye,toolFailureCounts:l.toolFailureCounts,fileReadCounts:l.fileReadCounts}}}function de(t,e){let n=[];for(let o=t.length-1;o>=0;o--){let s=t[o];if(s.role==="tool"&&typeof s.content=="string")n.unshift(s.content.slice(0,500));else if(s.role==="assistant"){if(typeof s.content=="string"&&s.content.trim())return e.info("synthesizeFallbackContent: found assistant text, using it"),s.content;break}else break}return n.length>0?(e.info(`synthesizeFallbackContent: synthesized from ${n.length} tool result(s)`),n.join(`
19
+ \u26A0\uFE0F NOTE: You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail silently or produce incorrect results on this platform. Please use the 'write' tool directly to create the requested file with the correct content.`)}let T={role:"user",content:I===0?"You described what to do but did not actually call any tool to write or edit a file. Please use the write or edit tool now to perform the requested action. Do not just describe the changes \u2014 actually make them.":"You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail on this platform. Please use the write tool directly to create the requested file with the correct content."},M={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,M,T],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!l.stopHookActive&&I>=3&&R.has("write")){let m=0;for(let g of C){let x=g,E=x.is_error===!0||typeof x.content=="string"&&x.content.startsWith("Error:");x.role==="tool"&&typeof x.content=="string"&&!E&&m++}if(m>=3){o.info("AP3 verification nudge: 3+ files created, injecting completeness check");let g={role:"user",content:"You created multiple files. Before completing, verify: (1) All imports between your files resolve to real exports. (2) No TODO, placeholder, or 'not implemented' stubs remain. (3) Functions that are imported are actually called, not just declared. If everything is correct, confirm completion. If not, fix the issues now."},x={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,x,g],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(I>0){let m={ok:!0,toolCallCount:I,distinctToolCount:R.size,multiStep:I>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},g=we(m,{tools:[...R],projectRoot:t.projectRoot});g&&(yield{type:"skill_instruction",turnId:i,instruction:g})}let u=l.finalText||de(C,o);yield{type:"end",turnId:i,content:u,usage:l.totalUsage,model:l.currentModel};return}let en=P.length===0&&oe.length>0?oe.join(""):void 0;C.push(je(j,l.finalText||void 0,P.length>0?P:void 0,en)),N=at(N,{replayMessages:C,pendingToolCallIds:j.map(c=>c.id),completedToolCallIds:N.completedToolCallIds,lastStopReason:"tool_calls"});let ye=l.identicalCallCounts,Lt=[],be=[],Pt=!1;for(let c of j){let u=`${c.function.name}::${c.function.arguments}`,m=ye.get(u)??0;ye.set(u,m+1),m+1>Qt?(be.push(c),Pt||(Pt=!0,o.info(`AP4 blocked: ${c.function.name} repeated ${m+1}x`))):Lt.push(c)}let Te=[];for(let c of be){let u=ye.get(`${c.function.name}::${c.function.arguments}`),m=Vo(C,c.function.name),g=m?`This exact tool call has been attempted ${u} times. Last error: ${m}. Do not retry. Report this error to the user.`:`This exact tool call has been attempted ${u} times and keeps failing. Do not retry it. Report the issue to the user or try a completely different approach.`,x=W(c.id,{ok:!1,error:g});C.push(x),Te.push(c.id),R.add(c.function.name),I++,yield{type:"tool_result",turnId:i,callId:c.id,name:c.function.name,ok:!1,error:g}}if(be.length>0){let c=Vo(C,be[0].function.name),u={role:"user",content:"Tool calls were blocked because you repeated them with identical arguments too many times. "+(c?`The error was: "${c}". Tell the user about this error. `:"The operation is not working. ")+"Stop retrying and report the result to the user."};C.push(u)}let _e=[],Fe=[];for(let c of Lt)(l.toolFailureCounts.get(c.function.name)??0)>=xe?Fe.push(c):_e.push(c);if(Fe.length>0){for(let u of Fe){let m=l.toolFailureCounts.get(u.function.name),g=`Tool "${u.function.name}" has failed ${m} times this turn with different arguments. The target likely does not exist. Stop trying variations and report the issue to the user.`,x=W(u.id,{ok:!1,error:g});C.push(x),Te.push(u.id),R.add(u.function.name),I++,yield{type:"tool_result",turnId:i,callId:u.id,name:u.function.name,ok:!1,error:g},o.info(`AP4-variant blocked: ${u.function.name} failed ${m}x with different args`)}let c={role:"user",content:"Tool calls were blocked because the tool has failed too many times with different arguments. The resource you are looking for does not exist. Stop trying variations and tell the user what happened."};C.push(c)}for(let c of _e){let u=c.function.arguments,m=pe.find(g=>g.function.name===c.function.name);if(m?.backfillObservableInput)try{let g=JSON.parse(c.function.arguments),x={...g};m.backfillObservableInput(x),Object.keys(x).some(T=>!(T in g))&&(u=JSON.stringify(x))}catch{}yield{type:"tool_call",turnId:i,callId:c.id,name:c.function.name,arguments:u}}let tn=new Map(l.toolFailureCounts);try{let c=new Pe({toolInvoker:n,hooks:f,sessionId:s,turnId:i,log:o,signal:b,maxConcurrentTools:t?.maxConcurrentTools});for(let u of _e)c.addTool(u);for await(let u of c.getRemainingResults()){u.blocked&&(yield{type:"tool_blocked",turnId:i,callId:u.callId,name:u.toolName,reason:u.blockReason??"blocked"}),C.push(u.message),Te.push(u.callId),R.add(u.toolName),I++;let m=u.ok&&Rs(u);if(!u.ok||m){let T=(l.toolFailureCounts.get(u.toolName)??0)+1;l.toolFailureCounts.set(u.toolName,T)}if(u.ok&&u.toolName==="read"){let E=_e.find(T=>T.id===u.callId);if(E)try{let T=JSON.parse(E.function.arguments),M=T.file_path??T.path??T.filePath??"";if(M){let B=l.fileReadCounts.get(M)??0;l.fileReadCounts.set(M,B+1)}}catch{}}let g=typeof u.message?.content=="string"?u.message.content:"",x=u.ok&&g?g.slice(0,2e3):void 0;if(yield{type:"tool_result",turnId:i,callId:u.callId,name:u.toolName,ok:u.ok,error:u.error,outputPreview:x},u.ok){let E=j.find(T=>T.id===u.callId);if(E){if(u.toolName==="plan_mode")try{let T=JSON.parse(E.function.arguments);T.action==="exit"&&typeof T.plan=="string"&&T.plan.length>0&&(yield{type:"plan_update",turnId:i,slug:"approved-plan",content:T.plan})}catch{}if(ws.has(u.toolName))try{let T=JSON.parse(E.function.arguments),M=typeof T.file_path=="string"?T.file_path:typeof T.filePath=="string"?T.filePath:typeof T.path=="string"?T.path:void 0;M&&(yield{type:"artifact",turnId:i,artifactId:`artifact-${u.callId}`,artifactType:Cs(M),title:M.split(/[\\/]/).pop()||M,filePath:M,language:Ss(M)})}catch{}}}}}catch(c){let u=c instanceof Error?c.message:String(c);yield{type:"error",turnId:i,error:u,code:"TOOL_EXECUTION_ERROR",usage:l.totalUsage};return}for(let[c,u]of l.toolFailureCounts)u>=xe&&(tn.get(c)??0)<xe&&C.push({role:"user",content:`Tool "${c}" has now failed/returned empty results ${u} times with different arguments. The target clearly does not exist. Do NOT call "${c}" again. Report the result to the user immediately.`});if(N=Ce(N,{replayMessages:C,completedToolCallIds:[...N.completedToolCallIds,...Te],lastStopReason:"tool_calls"}),t.generateToolUseSummary&&j.length>0){let c=j.map(u=>({name:u.function.name,arguments:u.function.arguments}));me=t.generateToolUseSummary(c).catch(()=>null)}let on=j.length>0&&j.every(c=>{let u=C.find(g=>g?.role==="tool"&&g?.tool_call_id===c.id);if(!u)return!0;let m=u.content;return typeof m=="string"&&m.startsWith("Error: ")}),ne=l.consecutiveFailedRounds;if(on){if(ne+=1,ne>=Jt){let c=l.finalText||de(C,o);o.info(`early exit: ${ne} consecutive failed rounds, returning ${l.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:i,content:c,usage:l.totalUsage,model:l.currentModel};return}}else ne=0;let nn=3,Dt=[...l.fileReadCounts.entries()].filter(([,c])=>c>=nn);if(Dt.length>0){let c=Dt.map(([m])=>m).join(", ");o.info(`AP5: file read cycle detected on ${c}, injecting nudge`);let u={role:"user",content:`You are reading the same files repeatedly (${c}). This indicates a circular dependency or cycle. Stop reading files, summarize your findings so far, and explain the circular structure to the user.`};C.push(u),l.fileReadCounts.clear()}let Be=ee+1;if(_>0&&Be>_){if(o.info(`max turns reached (${_}), completing`),f){let u=await f.invoke("stop",{sessionId:s,reason:"max_turns"});if(u.action==="abort"){let m=u.reason??"Stop hook requested continuation after max_turns",g={role:"assistant",content:l.finalText,...P.length>0&&{thinkingBlocks:[...P]}};l={...l,messages:[...C,g,{role:"user",content:m}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let c=l.finalText||de(C,o);yield{type:"end",turnId:i,content:c,usage:l.totalUsage,model:l.currentModel};return}if(Be>A){if(o.info(`tool loop budget exhausted (${A} rounds), returning`),I>0){let u={ok:!0,toolCallCount:I,distinctToolCount:R.size,multiStep:I>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},m=we(u,{tools:[...R],projectRoot:t.projectRoot});m&&(yield{type:"skill_instruction",turnId:i,instruction:m})}let c=l.finalText||de(C,o);yield{type:"end",turnId:i,content:c,usage:l.totalUsage,model:l.currentModel};return}l={messages:C,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:Be,transition:{reason:"next_turn"},guardState:O,reactiveCompactState:G,toolLoopState:N,consecutiveFailedRounds:ne,finalText:l.finalText,totalUsage:l.totalUsage,collapseStore:Ne,currentModel:l.currentModel,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:l.stopHookActive,lastResponseId:l.lastResponseId,snipRemovedIds:l.snipRemovedIds,contentReplacementState:l.contentReplacementState,budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:ye,toolFailureCounts:l.toolFailureCounts,fileReadCounts:l.fileReadCounts}}}function de(t,e){let n=[];for(let o=t.length-1;o>=0;o--){let i=t[o];if(i.role==="tool"&&typeof i.content=="string")n.unshift(i.content.slice(0,500));else if(i.role==="assistant"){if(typeof i.content=="string"&&i.content.trim())return e.info("synthesizeFallbackContent: found assistant text, using it"),i.content;break}else break}return n.length>0?(e.info(`synthesizeFallbackContent: synthesized from ${n.length} tool result(s)`),n.join(`
20
20
 
21
- `)):""}async function*Li(t,e,n,o,s,i,a,r){let d=[],h;r.debug(`single LLM round, messages: ${n.length}`);for await(let p of a.stream({model:e,messages:n,temperature:s},o,i))switch(p.type){case"delta":d.push(p.text),yield{type:"delta",turnId:t,text:p.text};break;case"usage":h={inputTokens:p.promptTokens,outputTokens:p.completionTokens,reasoningTokens:p.reasoningTokens,cacheRead:p.cacheReadTokens,cacheWrite:p.cacheCreationTokens};break;case"done":break}yield{type:"end",turnId:t,content:d.join(""),usage:h??{inputTokens:0,outputTokens:0},model:e}}var Pi={coding:[/(?:bug|error|fix|debug|报错|修复|编译|compile|build|lint)/i,/(?:implement|refactor|重构|实现|代码|code|function|method|class)/i,/(?:test|测试|vitest|jest|断言|assert)/i,/(?:type(?:script)?|接口|interface|generic|泛型)/i,/(?:import|export|module|依赖|package|npm|pnpm)/i,/(?:git|commit|branch|merge|rebase|PR|MR)/i],config:[/(?:deploy|部署|运维|docker|container|kubernetes|k8s)/i,/(?:port|端口|config|配置|env|环境变量|.env)/i,/(?:server|service|daemon|进程|systemd|nginx|redis)/i,/(?:版本|version|upgrade|migrate|迁移)/i,/(?:domain|域名|ssl|cert|证书|DNS)/i],conversation:[/(?:你好|hi|hello|hey|请问|问一下)/i,/(?:我(?:喜欢|偏好|习惯|想)|prefer|I (?:like|want|need))/i,/(?:帮我|help me|能不能|可以吗|would you)/i,/(?:style|风格|format|格式|命名|naming)/i],learning:[/(?:best practice|最佳实践|pattern|模式|惯例|convention)/i,/(?:怎么做|how to|how do|what's the|推荐|recommend)/i,/(?:为什么|why|原因|reason|explain|解释)/i,/(?:lesson|经验|教训|gotcha|pitfall|坑)/i],decision:[/(?:should|应该|选择|choose|decision|决定|trade-?off|权衡)/i,/(?:vs|versus|对比|compare|区别|difference)/i,/(?:architecture|架构|方案|approach|strategy)/i,/(?:pros|cons|优缺点|利弊|好处|坏处)/i],general:[]},Di={coding:{preferred:["lesson","pattern","fact"],deprioritized:["preference"]},config:{preferred:["fact","decision","lesson"],deprioritized:["preference","skill-learning"]},conversation:{preferred:["preference","fact"],deprioritized:["pattern","skill-learning"]},learning:{preferred:["lesson","pattern","skill-learning"],deprioritized:["preference"]},decision:{preferred:["decision","fact","lesson"],deprioritized:["skill-learning","preference"]},general:{preferred:[],deprioritized:[]}};function Qo(t){if(!t||t.length<5)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};let e=[];for(let[s,i]of Object.entries(Pi)){if(s==="general")continue;let a=i.filter(r=>r.test(t)).length;if(a>0){let r=Math.min(1,a/2);e.push({scenario:s,score:r})}}if(e.length===0)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};e.sort((s,i)=>i.score-s.score);let n=e[0];if(n.score<.5)return{scenario:"general",preferred:[],deprioritized:[],confidence:n.score};let o=Di[n.scenario];return{scenario:n.scenario,preferred:o.preferred,deprioritized:o.deprioritized,confidence:n.score}}var qo=class{transport;apiKey;toolInvoker;log;hooks;maxRounds;projectRoot;constructor(e){this.transport=e.llmTransport,this.apiKey=e.apiKey,this.toolInvoker=e.toolInvoker,this.log=e.log,this.hooks=e.hooks,this.projectRoot=e.projectRoot,this.maxRounds=Math.min(e.maxRounds??25,100)}async*run(e,n){let{turnId:o,messages:s,tools:i,systemPrompt:a,config:r}=e,d={sessionId:e.sessionId,turnId:o};yield{type:"start",turnId:o},this.hooks?.invoke("turn.submitted",{...d,prompt:s[s.length-1]?.content??void 0}).catch(()=>{});let h=rt(s),p=[];if(a&&p.push({role:"system",content:a}),p.push(...h),this.hooks){let y=h.filter(k=>k.role==="user").pop(),_=typeof y?.content=="string"?y.content.slice(0,500):void 0;if(_)try{let k=Qo(_),w=await this.hooks.invoke("memory.before_recall",{sessionId:e.sessionId,turnId:o,query:_,preferredCategories:k.preferred.length>0?k.preferred:void 0,deprioritizedCategories:k.deprioritized.length>0?k.deprioritized:void 0}),L=w?.context?.recalledMemories;if(L&&L.length>0){let A=0,D=[];for(let R of L){let I=(R.text?.length??0)*2;if(A+I>8192)break;D.push(R),A+=I}if(D.length>0){let R=D.map(I=>`- ${I.text}`).join(`
21
+ `)):""}async function*Ls(t,e,n,o,i,s,a,r){let d=[],h;r.debug(`single LLM round, messages: ${n.length}`);for await(let p of a.stream({model:e,messages:n,temperature:i},o,s))switch(p.type){case"delta":d.push(p.text),yield{type:"delta",turnId:t,text:p.text};break;case"usage":h={inputTokens:p.promptTokens,outputTokens:p.completionTokens,reasoningTokens:p.reasoningTokens,cacheRead:p.cacheReadTokens,cacheWrite:p.cacheCreationTokens};break;case"done":break}yield{type:"end",turnId:t,content:d.join(""),usage:h??{inputTokens:0,outputTokens:0},model:e}}var Ps={coding:[/(?:bug|error|fix|debug|报错|修复|编译|compile|build|lint)/i,/(?:implement|refactor|重构|实现|代码|code|function|method|class)/i,/(?:test|测试|vitest|jest|断言|assert)/i,/(?:type(?:script)?|接口|interface|generic|泛型)/i,/(?:import|export|module|依赖|package|npm|pnpm)/i,/(?:git|commit|branch|merge|rebase|PR|MR)/i],config:[/(?:deploy|部署|运维|docker|container|kubernetes|k8s)/i,/(?:port|端口|config|配置|env|环境变量|.env)/i,/(?:server|service|daemon|进程|systemd|nginx|redis)/i,/(?:版本|version|upgrade|migrate|迁移)/i,/(?:domain|域名|ssl|cert|证书|DNS)/i],conversation:[/(?:你好|hi|hello|hey|请问|问一下)/i,/(?:我(?:喜欢|偏好|习惯|想)|prefer|I (?:like|want|need))/i,/(?:帮我|help me|能不能|可以吗|would you)/i,/(?:style|风格|format|格式|命名|naming)/i],learning:[/(?:best practice|最佳实践|pattern|模式|惯例|convention)/i,/(?:怎么做|how to|how do|what's the|推荐|recommend)/i,/(?:为什么|why|原因|reason|explain|解释)/i,/(?:lesson|经验|教训|gotcha|pitfall|坑)/i],decision:[/(?:should|应该|选择|choose|decision|决定|trade-?off|权衡)/i,/(?:vs|versus|对比|compare|区别|difference)/i,/(?:architecture|架构|方案|approach|strategy)/i,/(?:pros|cons|优缺点|利弊|好处|坏处)/i],general:[]},Ds={coding:{preferred:["lesson","pattern","fact"],deprioritized:["preference"]},config:{preferred:["fact","decision","lesson"],deprioritized:["preference","skill-learning"]},conversation:{preferred:["preference","fact"],deprioritized:["pattern","skill-learning"]},learning:{preferred:["lesson","pattern","skill-learning"],deprioritized:["preference"]},decision:{preferred:["decision","fact","lesson"],deprioritized:["skill-learning","preference"]},general:{preferred:[],deprioritized:[]}};function Qo(t){if(!t||t.length<5)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};let e=[];for(let[i,s]of Object.entries(Ps)){if(i==="general")continue;let a=s.filter(r=>r.test(t)).length;if(a>0){let r=Math.min(1,a/2);e.push({scenario:i,score:r})}}if(e.length===0)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};e.sort((i,s)=>s.score-i.score);let n=e[0];if(n.score<.5)return{scenario:"general",preferred:[],deprioritized:[],confidence:n.score};let o=Ds[n.scenario];return{scenario:n.scenario,preferred:o.preferred,deprioritized:o.deprioritized,confidence:n.score}}var qo=class{transport;apiKey;toolInvoker;log;hooks;maxRounds;projectRoot;constructor(e){this.transport=e.llmTransport,this.apiKey=e.apiKey,this.toolInvoker=e.toolInvoker,this.log=e.log,this.hooks=e.hooks,this.projectRoot=e.projectRoot,this.maxRounds=Math.min(e.maxRounds??25,100)}async*run(e,n){let{turnId:o,messages:i,tools:s,systemPrompt:a,config:r}=e,d={sessionId:e.sessionId,turnId:o};yield{type:"start",turnId:o},this.hooks?.invoke("turn.submitted",{...d,prompt:i[i.length-1]?.content??void 0}).catch(()=>{});let h=rt(i),p=[];if(a&&p.push({role:"system",content:a}),p.push(...h),this.hooks){let y=h.filter(k=>k.role==="user").pop(),_=typeof y?.content=="string"?y.content.slice(0,500):void 0;if(_)try{let k=Qo(_),w=await this.hooks.invoke("memory.before_recall",{sessionId:e.sessionId,turnId:o,query:_,preferredCategories:k.preferred.length>0?k.preferred:void 0,deprioritizedCategories:k.deprioritized.length>0?k.deprioritized:void 0}),L=w?.context?.recalledMemories;if(L&&L.length>0){let A=0,D=[];for(let R of L){let I=(R.text?.length??0)*2;if(A+I>8192)break;D.push(R),A+=I}if(D.length>0){let R=D.map(I=>`- ${I.text}`).join(`
22
22
  `);p.splice(a?1:0,0,{role:"system",content:`[Recalled memories \u2014 context priority: project-specific facts override general user preferences when they conflict]
23
- ${R}`})}}this.hooks.invoke("memory.after_recall",{sessionId:e.sessionId,turnId:o,blockCount:w?.context?.recalledMemories?.length??0}).catch(()=>{})}catch{}}let f=r?.model??"",b=Math.min(r?.maxRounds??this.maxRounds,100);try{let y=async w=>{let L=kt().resolveModelForPurpose("smallModel");if(!L)return null;try{let v=w.map(R=>`${R.name}(${R.arguments.slice(0,200)})`).join(", "),A=this.transport.stream({model:L,messages:[{role:"system",content:"Summarize the tool usage in ~30 chars, git-commit-subject style. Reply with ONLY the summary, nothing else."},{role:"user",content:v}],tools:[],maxTokens:60},r?.apiKey??this.apiKey),D="";for await(let R of A)R.type==="delta"&&(D+=R.text);return D.trim()||null}catch{return null}},_={turnId:o,sessionId:e.sessionId,messages:p,tools:i,model:f,apiKey:r?.apiKey??this.apiKey,temperature:r?.temperature,maxRounds:b,contextWindowTokens:r?.contextWindowTokens,maxOutputTokens:r?.maxOutputTokens,modelMaxOutputTokens:r?.modelMaxOutputTokens,toolChoice:r?.toolChoice,parentDepth:r?.parentDepth,hooks:this.hooks,fallbackModel:r?.fallbackModel,maxTurns:r?.maxTurns,tokenBudget:r?.tokenBudget,maxConcurrentTools:r?.maxConcurrentTools,streamRequired:r?.streamRequired,reasoning:r?.reasoning,promptCacheKey:r?.promptCacheKey,promptCacheRetention:r?.promptCacheRetention,serviceTier:r?.serviceTier,openaiBuiltinTools:r?.openaiBuiltinTools,maxToolCalls:r?.maxToolCalls,parallelToolCalls:r?.parallelToolCalls,textVerbosity:r?.textVerbosity,projectRoot:this.projectRoot,generateToolUseSummary:y,signal:n},k;for await(let w of Jo(_,this.transport,this.toolInvoker,this.log))k=w,yield w;k?.type==="end"?this.hooks?.invoke("turn.completed",{...d}).catch(()=>{}):k?.type==="error"&&this.hooks?.invoke("turn.failed",{...d,code:k.code,error:k.error}).catch(()=>{})}catch(y){if(n?.aborted)this.hooks?.invoke("turn.failed",{...d,code:"ABORTED",error:"Turn aborted"}).catch(()=>{}),yield{type:"error",turnId:o,error:"Turn aborted",code:"ABORTED"};else{let _=y instanceof Error?y.message:String(y),k=typeof y?.status=="number"?y.status:void 0,w=Y(k,_);this.log.error(`turn ${o} error [${w}, retryable=${ze(w)}]: ${_}`),this.hooks?.invoke("turn.failed",{...d,code:w,error:_}).catch(()=>{}),yield{type:"error",turnId:o,error:_,code:w}}}}};export{qo as Agent};
23
+ ${R}`})}}this.hooks.invoke("memory.after_recall",{sessionId:e.sessionId,turnId:o,blockCount:w?.context?.recalledMemories?.length??0}).catch(()=>{})}catch{}}let f=r?.model??"",b=Math.min(r?.maxRounds??this.maxRounds,100);try{let y=async w=>{let L=kt().resolveModelForPurpose("smallModel");if(!L)return null;try{let v=w.map(R=>`${R.name}(${R.arguments.slice(0,200)})`).join(", "),A=this.transport.stream({model:L,messages:[{role:"system",content:"Summarize the tool usage in ~30 chars, git-commit-subject style. Reply with ONLY the summary, nothing else."},{role:"user",content:v}],tools:[],maxTokens:60},r?.apiKey??this.apiKey),D="";for await(let R of A)R.type==="delta"&&(D+=R.text);return D.trim()||null}catch{return null}},_={turnId:o,sessionId:e.sessionId,messages:p,tools:s,model:f,apiKey:r?.apiKey??this.apiKey,temperature:r?.temperature,maxRounds:b,contextWindowTokens:r?.contextWindowTokens,maxOutputTokens:r?.maxOutputTokens,modelMaxOutputTokens:r?.modelMaxOutputTokens,toolChoice:r?.toolChoice,parentDepth:r?.parentDepth,hooks:this.hooks,fallbackModel:r?.fallbackModel,maxTurns:r?.maxTurns,tokenBudget:r?.tokenBudget,maxConcurrentTools:r?.maxConcurrentTools,streamRequired:r?.streamRequired,reasoning:r?.reasoning,promptCacheKey:r?.promptCacheKey,promptCacheRetention:r?.promptCacheRetention,serviceTier:r?.serviceTier,openaiBuiltinTools:r?.openaiBuiltinTools,maxToolCalls:r?.maxToolCalls,parallelToolCalls:r?.parallelToolCalls,textVerbosity:r?.textVerbosity,projectRoot:this.projectRoot,generateToolUseSummary:y,signal:n},k;for await(let w of Jo(_,this.transport,this.toolInvoker,this.log))k=w,yield w;k?.type==="end"?this.hooks?.invoke("turn.completed",{...d}).catch(()=>{}):k?.type==="error"&&this.hooks?.invoke("turn.failed",{...d,code:k.code,error:k.error}).catch(()=>{})}catch(y){if(n?.aborted)this.hooks?.invoke("turn.failed",{...d,code:"ABORTED",error:"Turn aborted"}).catch(()=>{}),yield{type:"error",turnId:o,error:"Turn aborted",code:"ABORTED"};else{let _=y instanceof Error?y.message:String(y),k=typeof y?.status=="number"?y.status:void 0,w=Y(k,_);this.log.error(`turn ${o} error [${w}, retryable=${ze(w)}]: ${_}`),this.hooks?.invoke("turn.failed",{...d,code:w,error:_}).catch(()=>{}),yield{type:"error",turnId:o,error:_,code:w}}}}};export{qo as Agent};