@zibby/core 0.5.4 → 0.5.6

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.
@@ -1,11 +1,11 @@
1
- import{AgentStrategy as ye,getSkill as F}from"@zibby/agent-workflow";import M from"chalk";var A={debug:0,info:1,warn:2,error:3,silent:4},Y=class{constructor(){this._level=this._getLogLevel()}_getLogLevel(){if(process.env.ZIBBY_DEBUG==="true")return A.debug;if(process.env.ZIBBY_VERBOSE==="true")return A.info;let e=process.env.LOG_LEVEL?.toLowerCase();return e&&e in A?A[e]:A.info}_shouldLog(e){return A[e]>=this._level}_formatMessage(e,t,s={}){let o=new Date().toISOString(),l=`${this._getPrefix(e)} ${t}`;return Object.keys(s).length>0&&(l+=M.dim(` ${JSON.stringify(s)}`)),l}_getPrefix(e){return{debug:M.gray("[DEBUG]"),info:M.cyan("[INFO]"),warn:M.yellow("[WARN]"),error:M.red("\u274C [ERROR]")}[e]||""}debug(e,t){this._shouldLog("debug")&&console.log(this._formatMessage("debug",e,t))}info(e,t){this._shouldLog("info")&&console.log(this._formatMessage("info",e,t))}warn(e,t){this._shouldLog("warn")&&console.warn(this._formatMessage("warn",e,t))}error(e,t){this._shouldLog("error")&&console.error(this._formatMessage("error",e,t))}setLevel(e){e in A&&(this._level=A[e])}getLevel(){return Object.keys(A).find(e=>A[e]===this._level)}},O=new Y;var q={ASSISTANT:"gpt-5.4-nano-2026-03-17",CLAUDE:"claude-sonnet-4-6",CURSOR:"auto",CODEX:"o4-mini",GEMINI:"gemini-2.5-pro",OPENAI_POSTPROCESSING:"gpt-4o-mini"};var Ae={CURSOR_AGENT_DEFAULT:1200*1e3,OPENAI_REQUEST:18e4};var R=class{formatTools(e){throw new Error("formatTools() must be implemented")}hasToolCalls(e){throw new Error("hasToolCalls() must be implemented")}parseToolCalls(e){throw new Error("parseToolCalls() must be implemented")}getTextContent(e){throw new Error("getTextContent() must be implemented")}buildAssistantMessage(e){throw new Error("buildAssistantMessage() must be implemented")}buildToolResultMessage(e,t){throw new Error("buildToolResultMessage() must be implemented")}injectToolsIntoBody(e,t){throw new Error("injectToolsIntoBody() must be implemented")}};var $=class extends R{formatTools(e){return e.map(t=>({type:"function",function:{name:t.name,description:t.description,parameters:t.parameters||t.input_schema||{type:"object",properties:{}}}}))}hasToolCalls(e){let t=e.choices?.[0]?.message;return!!(t?.tool_calls&&t.tool_calls.length>0)}parseToolCalls(e){return(e.choices?.[0]?.message?.tool_calls||[]).map(s=>({id:s.id,name:s.function.name,args:JSON.parse(s.function.arguments||"{}")}))}getTextContent(e){return e.choices?.[0]?.message?.content||""}buildAssistantMessage(e){return e.choices?.[0]?.message}buildToolResultMessage(e,t){return{role:"tool",tool_call_id:e,content:typeof t=="string"?t:JSON.stringify(t)}}injectToolsIntoBody(e,t){return t.length>0&&(e.tools=t),e}};var I=class{async fetchCompletion(e,t,s={}){throw new Error("fetchCompletion() must be implemented")}async fetchStreamingCompletion(e,t,s={}){throw new Error("fetchStreamingCompletion() must be implemented")}};function N(n){return Buffer.byteLength(JSON.stringify(n),"utf8")}function U(n,e){let t=String(n||"");if(t.length<=e)return t;let s=Math.max(0,e-28);return`${t.slice(0,s)}
1
+ import{AgentStrategy as be,getSkill as G}from"@zibby/agent-workflow";import M from"chalk";var v={debug:0,info:1,warn:2,error:3,silent:4},Y=class{constructor(){this._level=this._getLogLevel()}_getLogLevel(){if(process.env.ZIBBY_DEBUG==="true")return v.debug;if(process.env.ZIBBY_VERBOSE==="true")return v.info;let e=process.env.LOG_LEVEL?.toLowerCase();return e&&e in v?v[e]:v.info}_shouldLog(e){return v[e]>=this._level}_formatMessage(e,o,n={}){let t=new Date().toISOString(),l=`${this._getPrefix(e)} ${o}`;return Object.keys(n).length>0&&(l+=M.dim(` ${JSON.stringify(n)}`)),l}_getPrefix(e){return{debug:M.gray("[DEBUG]"),info:M.cyan("[INFO]"),warn:M.yellow("[WARN]"),error:M.red("\u274C [ERROR]")}[e]||""}debug(e,o){this._shouldLog("debug")&&console.log(this._formatMessage("debug",e,o))}info(e,o){this._shouldLog("info")&&console.log(this._formatMessage("info",e,o))}warn(e,o){this._shouldLog("warn")&&console.warn(this._formatMessage("warn",e,o))}error(e,o){this._shouldLog("error")&&console.error(this._formatMessage("error",e,o))}setLevel(e){e in v&&(this._level=v[e])}getLevel(){return Object.keys(v).find(e=>v[e]===this._level)}},I=new Y;var ae=[{alias:"auto",canonicalId:"claude-sonnet-4-6",vendor:"claude",label:"Claude \xB7 Sonnet 4.6",family:"claude-sonnet-4",pickerVisible:!0,isDefault:!0},{alias:"opus-4.8",canonicalId:"claude-opus-4-8",vendor:"claude",label:"Claude \xB7 Opus 4.8",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-8",canonicalId:"claude-opus-4-8",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.8"},{alias:"sonnet-4.8",canonicalId:"claude-sonnet-4-8",vendor:"claude",label:"Claude \xB7 Sonnet 4.8",family:"claude-sonnet-4",pickerVisible:!0},{alias:"sonnet-4-8",canonicalId:"claude-sonnet-4-8",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.8"},{alias:"opus-4.7",canonicalId:"claude-opus-4-7",vendor:"claude",label:"Claude \xB7 Opus 4.7",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-7",canonicalId:"claude-opus-4-7",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.7"},{alias:"sonnet-4.7",canonicalId:"claude-sonnet-4-7",vendor:"claude",label:"Claude \xB7 Sonnet 4.7",family:"claude-sonnet-4",pickerVisible:!0},{alias:"sonnet-4-7",canonicalId:"claude-sonnet-4-7",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.7"},{alias:"sonnet-4.6",canonicalId:"claude-sonnet-4-6",vendor:"claude",family:"claude-sonnet-4",aliasOf:"auto"},{alias:"sonnet-4-6",canonicalId:"claude-sonnet-4-6",vendor:"claude",family:"claude-sonnet-4",aliasOf:"auto"},{alias:"opus-4.6",canonicalId:"claude-opus-4-6",vendor:"claude",label:"Claude \xB7 Opus 4.6",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-6",canonicalId:"claude-opus-4-6",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.6"},{alias:"sonnet-4.5",canonicalId:"claude-sonnet-4-5-20250929",vendor:"claude",label:"Claude \xB7 Sonnet 4.5",family:"claude-sonnet-4",pickerVisible:!0},{alias:"sonnet-4-5",canonicalId:"claude-sonnet-4-5-20250929",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.5"},{alias:"opus-4.5",canonicalId:"claude-opus-4-5-20251101",vendor:"claude",label:"Claude \xB7 Opus 4.5",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-5",canonicalId:"claude-opus-4-5-20251101",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.5"},{alias:"haiku-4.5",canonicalId:"claude-haiku-4-5-20251001",vendor:"claude",label:"Claude \xB7 Haiku 4.5",family:"claude-haiku-4"},{alias:"haiku-4-5",canonicalId:"claude-haiku-4-5-20251001",vendor:"claude",family:"claude-haiku-4",aliasOf:"haiku-4.5"},{alias:"claude-opus-4-8",canonicalId:"claude-opus-4-8",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.8"},{alias:"claude-sonnet-4-8",canonicalId:"claude-sonnet-4-8",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.8"},{alias:"claude-opus-4-7",canonicalId:"claude-opus-4-7",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.7"},{alias:"claude-sonnet-4-7",canonicalId:"claude-sonnet-4-7",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.7"},{alias:"claude-sonnet-4-6",canonicalId:"claude-sonnet-4-6",vendor:"claude",family:"claude-sonnet-4",aliasOf:"auto"},{alias:"claude-opus-4-6",canonicalId:"claude-opus-4-6",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.6"},{alias:"claude-sonnet-4-5-20250929",canonicalId:"claude-sonnet-4-5-20250929",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.5"},{alias:"claude-opus-4-5-20251101",canonicalId:"claude-opus-4-5-20251101",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.5"},{alias:"claude-haiku-4-5-20251001",canonicalId:"claude-haiku-4-5-20251001",vendor:"claude",family:"claude-haiku-4",aliasOf:"haiku-4.5"},{alias:"claude-opus-4-20250514",canonicalId:"claude-opus-4-20250514",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.5"},{alias:"auto",canonicalId:"o4-mini",vendor:"codex",label:"Codex \xB7 o4-mini",family:"o4-mini",isDefault:!0},{alias:"o4-mini",canonicalId:"o4-mini",vendor:"codex",label:"Codex \xB7 o4-mini",family:"o4-mini",pickerVisible:!0},{alias:"o3",canonicalId:"o3",vendor:"codex",family:"o3"},{alias:"o3-mini",canonicalId:"o3-mini",vendor:"codex",family:"o3-mini"},{alias:"codex-mini",canonicalId:"codex-mini-latest",vendor:"codex",family:"codex-mini"},{alias:"gpt-4o",canonicalId:"gpt-4o",vendor:"codex",label:"Codex \xB7 GPT-4o",family:"gpt-4o",pickerVisible:!0},{alias:"gpt-4o-mini",canonicalId:"gpt-4o-mini",vendor:"codex",label:"Codex \xB7 GPT-4o mini",family:"gpt-4o-mini",pickerVisible:!0},{alias:"gpt-5.2-codex",canonicalId:"gpt-5.2-codex",vendor:"codex",label:"Codex \xB7 GPT-5.2",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.2",canonicalId:"gpt-5.2",vendor:"codex",label:"Codex \xB7 GPT-5.2 base",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.3",canonicalId:"gpt-5.3",vendor:"codex",label:"Codex \xB7 GPT-5.3",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.3-codex",canonicalId:"gpt-5.3-codex",vendor:"codex",family:"gpt-5"},{alias:"gpt-5.4",canonicalId:"gpt-5.4",vendor:"codex",label:"Codex \xB7 GPT-5.4",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.5",canonicalId:"gpt-5.5",vendor:"codex",label:"Codex \xB7 GPT-5.5",family:"gpt-5",pickerVisible:!0},{alias:"auto",canonicalId:"gemini-3-pro",vendor:"gemini",label:"Gemini \xB7 3 Pro",family:"gemini-3",isDefault:!0},{alias:"gemini-3-pro",canonicalId:"gemini-3-pro",vendor:"gemini",label:"Gemini \xB7 3 Pro",family:"gemini-3",pickerVisible:!0},{alias:"gemini-3-flash",canonicalId:"gemini-3-flash",vendor:"gemini",label:"Gemini \xB7 3 Flash",family:"gemini-3",pickerVisible:!0},{alias:"gemini-2.5-pro",canonicalId:"gemini-2.5-pro",vendor:"gemini",label:"Gemini \xB7 2.5 Pro",family:"gemini-2.5",pickerVisible:!0},{alias:"gemini-2.5-flash",canonicalId:"gemini-2.5-flash",vendor:"gemini",label:"Gemini \xB7 2.5 Flash",family:"gemini-2.5",pickerVisible:!0}];function N(s){let e={};for(let o of ae)o.vendor===s&&(e[o.alias]=o.canonicalId);return e}var q={ASSISTANT:"gpt-5.4-nano-2026-03-17",CLAUDE:"claude-sonnet-4-6",CURSOR:"auto",CODEX:"o4-mini",GEMINI:"gemini-3-pro",OPENAI_POSTPROCESSING:"gpt-4o-mini"};var Ie=N("claude"),Ce=N("codex"),Ee=N("gemini"),$e={CURSOR_AGENT_DEFAULT:1200*1e3,OPENAI_REQUEST:18e4};var B=class{formatTools(e){throw new Error("formatTools() must be implemented")}hasToolCalls(e){throw new Error("hasToolCalls() must be implemented")}parseToolCalls(e){throw new Error("parseToolCalls() must be implemented")}getTextContent(e){throw new Error("getTextContent() must be implemented")}buildAssistantMessage(e){throw new Error("buildAssistantMessage() must be implemented")}buildToolResultMessage(e,o){throw new Error("buildToolResultMessage() must be implemented")}injectToolsIntoBody(e,o){throw new Error("injectToolsIntoBody() must be implemented")}};var C=class extends B{formatTools(e){return e.map(o=>({type:"function",function:{name:o.name,description:o.description,parameters:o.parameters||o.input_schema||{type:"object",properties:{}}}}))}hasToolCalls(e){let o=e.choices?.[0]?.message;return!!(o?.tool_calls&&o.tool_calls.length>0)}parseToolCalls(e){return(e.choices?.[0]?.message?.tool_calls||[]).map(n=>({id:n.id,name:n.function.name,args:JSON.parse(n.function.arguments||"{}")}))}getTextContent(e){return e.choices?.[0]?.message?.content||""}buildAssistantMessage(e){return e.choices?.[0]?.message}buildToolResultMessage(e,o){return{role:"tool",tool_call_id:e,content:typeof o=="string"?o:JSON.stringify(o)}}injectToolsIntoBody(e,o){return o.length>0&&(e.tools=o),e}};var L=class{async fetchCompletion(e,o,n={}){throw new Error("fetchCompletion() must be implemented")}async fetchStreamingCompletion(e,o,n={}){throw new Error("fetchStreamingCompletion() must be implemented")}};function D(s){return Buffer.byteLength(JSON.stringify(s),"utf8")}function U(s,e){let o=String(s||"");if(o.length<=e)return o;let n=Math.max(0,e-28);return`${o.slice(0,n)}
2
2
 
3
- [truncated for size budget]`}function G(n,e=0){if(!n||typeof n!="object"||e>8)return n;if(Array.isArray(n))return n.map(s=>G(s,e+1));let t={};for(let[s,o]of Object.entries(n))s==="description"||s==="title"||s==="examples"||s==="default"||(t[s]=G(o,e+1));return t}function re(n=[]){return n.map(e=>({...e,function:{...e.function,description:U(e.function?.description||"",180),parameters:G(e.function?.parameters||{type:"object",properties:{}})}}))}function W(n){let e=new Set;for(let o of n)if(o.role==="assistant"&&Array.isArray(o.tool_calls))for(let r of o.tool_calls)e.add(r.id);let t=n.filter(o=>o.role==="tool"?e.has(o.tool_call_id):!0),s=new Set;for(let o of t)o.role==="tool"&&s.add(o.tool_call_id);return t.map(o=>{if(o.role!=="assistant"||!Array.isArray(o.tool_calls)||o.tool_calls.every(a=>s.has(a.id)))return o;let{tool_calls:l,...i}=o;return{...i,content:i.content||""}})}function X(n,e={}){let t=e.maxBytes||49e3,s=e.systemMaxChars||12e3,o={...n,messages:Array.isArray(n.messages)?[...n.messages]:[],tools:Array.isArray(n.tools)?re(n.tools):n.tools};o.messages.length>0&&o.messages[0]?.role==="system"&&(o.messages[0]={...o.messages[0],content:U(o.messages[0].content,s)});let r=!1;for(;N(o)>t&&o.messages.length>2;)o.messages.splice(1,1),r=!0;if(r&&(o.messages=W(o.messages)),N(o)>t&&o.messages.length>0&&(o.messages[0]={...o.messages[0],content:U(o.messages[0].content,6e3)},r=!0),N(o)>t){let l=o.messages.find(a=>a.role==="system")||o.messages[0],i=o.messages.slice(-2);o.messages=W([l,...i].filter(Boolean).map((a,c)=>({...a,content:U(a.content,c===0?4e3:8e3)}))),r=!0}return{body:o,meta:{bytes:N(o),trimmed:r,maxBytes:t,messageCount:o.messages.length}}}var V=n=>Buffer.byteLength(JSON.stringify(n),"utf8"),P=class extends I{async fetchCompletion(e,t,s={}){let o=V(e),{body:r,meta:l}=X(e,s.payloadCompaction);s.onBudget?.({streaming:!1,beforeBytes:o,meta:l});let i=this.#e(s),a=`${t.baseUrl}${s.chatCompletionsPath||"/v1/chat/completions"}`,c=await fetch(a,{method:"POST",headers:t.headers,body:JSON.stringify(r),signal:i});if(!c.ok){let u=await c.text();throw c.status===401||c.status===403?new Error("Session expired. Run `zibby login` to re-authenticate."):new Error(`Proxy error ${c.status}: ${u}`)}return c.json()}async fetchStreamingCompletion(e,t,s={}){let o={...e,stream:!0},r=V(o),{body:l,meta:i}=X(o,s.payloadCompaction);s.onBudget?.({streaming:!0,beforeBytes:r,meta:i});let a=this.#e(s),c=`${t.baseUrl}${s.chatCompletionsPath||"/v1/chat/completions"}`,u=await fetch(c,{method:"POST",headers:t.headers,body:JSON.stringify(l),signal:a});if(!u.ok){let k=await u.text();throw u.status===401||u.status===403?new Error("Session expired. Run `zibby login` to re-authenticate."):new Error(`Proxy error ${u.status}: ${k}`)}let m=u.body.getReader(),_=new TextDecoder,S="",T="",E=new Map;for(;;){let{done:k,value:d}=await m.read();if(k)break;S+=_.decode(d,{stream:!0});let x=S.split(`
4
- `);S=x.pop();for(let b of x){if(!b.startsWith("data: "))continue;let f=b.slice(6).trim();if(f==="[DONE]")continue;let p;try{p=JSON.parse(f)}catch{continue}let g=p.choices?.[0]?.delta;if(g&&(g.content&&(T+=g.content,s.onToken&&s.onToken(g.content)),g.tool_calls))for(let h of g.tool_calls){let w=h.index??0;E.has(w)||E.set(w,{id:"",name:"",args:""});let C=E.get(w);h.id&&(C.id=h.id),h.function?.name&&(C.name=h.function.name),h.function?.arguments!=null&&(C.args+=h.function.arguments)}}}if(E.size>0){let k=[...E.entries()].sort(([d],[x])=>d-x).map(([,d])=>({id:d.id,type:"function",function:{name:d.name,arguments:d.args}}));return{choices:[{message:{role:"assistant",content:T||null,tool_calls:k}}]}}return{choices:[{message:{role:"assistant",content:T}}]}}#e(e={}){let t=[e.signal,e.timeout?AbortSignal.timeout(e.timeout):null].filter(Boolean);return t.length>1?AbortSignal.any(t):t[0]||void 0}};import{Client as ie}from"@modelcontextprotocol/sdk/client/index.js";import{StdioClientTransport as le}from"@modelcontextprotocol/sdk/client/stdio.js";var D=class{#e=new Map;async ensureServer(e,t){if(this.#e.has(e))return this.#e.get(e);let{command:s,args:o=[],env:r={}}=t;O.debug(`[MCP] Starting ${e}: ${s} ${o.join(" ")}`);let l=new le({command:s,args:o,env:{...process.env,...r}}),i=new ie({name:`zibby-chat-${e}`,version:"1.0.0"},{capabilities:{}});await i.connect(l);let a={client:i,transport:l,serverConfig:t};return this.#e.set(e,a),a}async callTool(e,t,s={}){let o=this.#e.get(e);if(!o)throw new Error(`MCP server "${e}" not running`);O.debug(`[MCP] ${e}.${t}(${JSON.stringify(s).slice(0,200)})`);let r=await o.client.callTool({name:t,arguments:s});return{text:r.content?.filter(i=>i.type==="text").map(i=>i.text).join(`
5
- `)||"",isError:r.isError||!1}}isRunning(e){return this.#e.has(e)}async stopServer(e){let t=this.#e.get(e);if(t){try{await t.client.close()}catch(s){O.debug(`[MCP] Error closing ${e}: ${s.message}`)}this.#e.delete(e)}}async stopAll(){let e=[...this.#e.keys()];await Promise.allSettled(e.map(t=>this.stopServer(t)))}};import{existsSync as ae,readFileSync as ce}from"node:fs";import{join as ue}from"node:path";import{homedir as fe}from"node:os";function me(){try{let n=ue(fe(),".zibby","config.json");return ae(n)?JSON.parse(ce(n,"utf-8")):{}}catch{return{}}}function j(n){return String(n||"").replace(/\/v1\/?$/,"")}function de(n,e){let t=process.env.OPENAI_PROXY_URL;if(t)return j(t);if(n==="session")return e.proxyUrl?j(e.proxyUrl):`${(process.env.ZIBBY_API_URL||"https://api-prod.zibby.app").replace(/\/$/,"")}/openai-proxy`;if(n==="byok"){let s=process.env.OPENAI_BASE_URL;return j(s||"https://api.openai.com")}return j(t||"")}function Z(){let n=me(),e=process.env.ZIBBY_USER_TOKEN||n.sessionToken||null,t=process.env.OPENAI_API_KEY||null,s=(process.env.ASSISTANT_AUTH_MODE||"").trim().toLowerCase(),o=process.env.OPENAI_PROXY_NO_AUTH==="true",r=process.env.OPENAI_PROXY_URL,l="session";s==="byok"||s==="local"||s==="session"?l=s:e?l="session":t?l="byok":r&&o&&(l="local");let i=de(l,n),a={"Content-Type":"application/json"};if(l==="session"){if(!e)return{ok:!1,mode:l,reason:"missing_session_token"};a.Authorization=`Bearer ${e}`}else if(l==="byok"){if(!t)return{ok:!1,mode:l,reason:"missing_openai_api_key"};a.Authorization=`Bearer ${t}`}else if(l==="local"){if(!i)return{ok:!1,mode:l,reason:"missing_openai_proxy_url"};!o&&t&&(a.Authorization=`Bearer ${t}`)}return i?{ok:!0,mode:l,baseUrl:i,headers:a,tokenPreview:a.Authorization?`***${a.Authorization.slice(-4)}`:"none"}:{ok:!1,mode:l,reason:"missing_base_url"}}function z(n,e){let t=String(n??"");return t.length<=e?t:`${t.slice(0,Math.max(0,e-30))}
3
+ [truncated for size budget]`}function J(s,e=0){if(!s||typeof s!="object"||e>8)return s;if(Array.isArray(s))return s.map(n=>J(n,e+1));let o={};for(let[n,t]of Object.entries(s))n==="description"||n==="title"||n==="examples"||n==="default"||(o[n]=J(t,e+1));return o}function le(s=[]){return s.map(e=>({...e,function:{...e.function,description:U(e.function?.description||"",180),parameters:J(e.function?.parameters||{type:"object",properties:{}})}}))}function W(s){let e=new Set;for(let t of s)if(t.role==="assistant"&&Array.isArray(t.tool_calls))for(let i of t.tool_calls)e.add(i.id);let o=s.filter(t=>t.role==="tool"?e.has(t.tool_call_id):!0),n=new Set;for(let t of o)t.role==="tool"&&n.add(t.tool_call_id);return o.map(t=>{if(t.role!=="assistant"||!Array.isArray(t.tool_calls)||t.tool_calls.every(r=>n.has(r.id)))return t;let{tool_calls:l,...a}=t;return{...a,content:a.content||""}})}function X(s,e={}){let o=e.maxBytes||49e3,n=e.systemMaxChars||12e3,t={...s,messages:Array.isArray(s.messages)?[...s.messages]:[],tools:Array.isArray(s.tools)?le(s.tools):s.tools};t.messages.length>0&&t.messages[0]?.role==="system"&&(t.messages[0]={...t.messages[0],content:U(t.messages[0].content,n)});let i=!1;for(;D(t)>o&&t.messages.length>2;)t.messages.splice(1,1),i=!0;if(i&&(t.messages=W(t.messages)),D(t)>o&&t.messages.length>0&&(t.messages[0]={...t.messages[0],content:U(t.messages[0].content,6e3)},i=!0),D(t)>o){let l=t.messages.find(r=>r.role==="system")||t.messages[0],a=t.messages.slice(-2);t.messages=W([l,...a].filter(Boolean).map((r,c)=>({...r,content:U(r.content,c===0?4e3:8e3)}))),i=!0}return{body:t,meta:{bytes:D(t),trimmed:i,maxBytes:o,messageCount:t.messages.length}}}var Q=s=>Buffer.byteLength(JSON.stringify(s),"utf8"),E=class extends L{async fetchCompletion(e,o,n={}){let t=Q(e),{body:i,meta:l}=X(e,n.payloadCompaction);n.onBudget?.({streaming:!1,beforeBytes:t,meta:l});let a=this.#e(n),r=`${o.baseUrl}${n.chatCompletionsPath||"/v1/chat/completions"}`,c=await fetch(r,{method:"POST",headers:o.headers,body:JSON.stringify(i),signal:a});if(!c.ok){let u=await c.text();throw c.status===401||c.status===403?new Error("Session expired. Run `zibby login` to re-authenticate."):new Error(`Proxy error ${c.status}: ${u}`)}return c.json()}async fetchStreamingCompletion(e,o,n={}){let t={...e,stream:!0},i=Q(t),{body:l,meta:a}=X(t,n.payloadCompaction);n.onBudget?.({streaming:!0,beforeBytes:i,meta:a});let r=this.#e(n),c=`${o.baseUrl}${n.chatCompletionsPath||"/v1/chat/completions"}`,u=await fetch(c,{method:"POST",headers:o.headers,body:JSON.stringify(l),signal:r});if(!u.ok){let O=await u.text();throw u.status===401||u.status===403?new Error("Session expired. Run `zibby login` to re-authenticate."):new Error(`Proxy error ${u.status}: ${O}`)}let f=u.body.getReader(),_=new TextDecoder,b="",x="",w=new Map;for(;;){let{done:O,value:m}=await f.read();if(O)break;b+=_.decode(m,{stream:!0});let T=b.split(`
4
+ `);b=T.pop();for(let S of T){if(!S.startsWith("data: "))continue;let d=S.slice(6).trim();if(d==="[DONE]")continue;let p;try{p=JSON.parse(d)}catch{continue}let g=p.choices?.[0]?.delta;if(g&&(g.content&&(x+=g.content,n.onToken&&n.onToken(g.content)),g.tool_calls))for(let y of g.tool_calls){let k=y.index??0;w.has(k)||w.set(k,{id:"",name:"",args:""});let A=w.get(k);y.id&&(A.id=y.id),y.function?.name&&(A.name=y.function.name),y.function?.arguments!=null&&(A.args+=y.function.arguments)}}}if(w.size>0){let O=[...w.entries()].sort(([m],[T])=>m-T).map(([,m])=>({id:m.id,type:"function",function:{name:m.name,arguments:m.args}}));return{choices:[{message:{role:"assistant",content:x||null,tool_calls:O}}]}}return{choices:[{message:{role:"assistant",content:x}}]}}#e(e={}){let o=[e.signal,e.timeout?AbortSignal.timeout(e.timeout):null].filter(Boolean);return o.length>1?AbortSignal.any(o):o[0]||void 0}};import{Client as re}from"@modelcontextprotocol/sdk/client/index.js";import{StdioClientTransport as ce}from"@modelcontextprotocol/sdk/client/stdio.js";var j=class{#e=new Map;async ensureServer(e,o){if(this.#e.has(e))return this.#e.get(e);let{command:n,args:t=[],env:i={}}=o;I.debug(`[MCP] Starting ${e}: ${n} ${t.join(" ")}`);let l=new ce({command:n,args:t,env:{...process.env,...i}}),a=new re({name:`zibby-chat-${e}`,version:"1.0.0"},{capabilities:{}});await a.connect(l);let r={client:a,transport:l,serverConfig:o};return this.#e.set(e,r),r}async callTool(e,o,n={}){let t=this.#e.get(e);if(!t)throw new Error(`MCP server "${e}" not running`);I.debug(`[MCP] ${e}.${o}(${JSON.stringify(n).slice(0,200)})`);let i=await t.client.callTool({name:o,arguments:n});return{text:i.content?.filter(a=>a.type==="text").map(a=>a.text).join(`
5
+ `)||"",isError:i.isError||!1}}isRunning(e){return this.#e.has(e)}async stopServer(e){let o=this.#e.get(e);if(o){try{await o.client.close()}catch(n){I.debug(`[MCP] Error closing ${e}: ${n.message}`)}this.#e.delete(e)}}async stopAll(){let e=[...this.#e.keys()];await Promise.allSettled(e.map(o=>this.stopServer(o)))}};import{existsSync as ue,readFileSync as de}from"node:fs";import{join as fe}from"node:path";import{homedir as me}from"node:os";function pe(){try{let s=fe(me(),".zibby","config.json");return ue(s)?JSON.parse(de(s,"utf-8")):{}}catch{return{}}}function V(s){return String(s||"").replace(/\/v1\/?$/,"")}function ge(s,e){let o=process.env.OPENAI_PROXY_URL;if(o)return V(o);if(s==="session")return e.proxyUrl?V(e.proxyUrl):`${(process.env.ZIBBY_API_URL||"https://api-prod.zibby.app").replace(/\/$/,"")}/openai-proxy`;if(s==="byok"){let n=process.env.OPENAI_BASE_URL;return V(n||"https://api.openai.com")}return V(o||"")}function H(){let s=pe(),e=process.env.ZIBBY_USER_TOKEN||s.sessionToken||null,o=process.env.OPENAI_API_KEY||null,n=(process.env.ASSISTANT_AUTH_MODE||"").trim().toLowerCase(),t=process.env.OPENAI_PROXY_NO_AUTH==="true",i=process.env.OPENAI_PROXY_URL,l="session";n==="byok"||n==="local"||n==="session"?l=n:e?l="session":o?l="byok":i&&t&&(l="local");let a=ge(l,s),r={"Content-Type":"application/json"};if(l==="session"){if(!e)return{ok:!1,mode:l,reason:"missing_session_token"};r.Authorization=`Bearer ${e}`}else if(l==="byok"){if(!o)return{ok:!1,mode:l,reason:"missing_openai_api_key"};r.Authorization=`Bearer ${o}`}else if(l==="local"){if(!a)return{ok:!1,mode:l,reason:"missing_openai_proxy_url"};!t&&o&&(r.Authorization=`Bearer ${o}`)}return a?{ok:!0,mode:l,baseUrl:a,headers:r,tokenPreview:r.Authorization?`***${r.Authorization.slice(-4)}`:"none"}:{ok:!1,mode:l,reason:"missing_base_url"}}function F(s,e){let o=String(s??"");return o.length<=e?o:`${o.slice(0,Math.max(0,e-30))}
6
6
 
7
- [tool result truncated for size]`}function pe(n,e){if(typeof n=="string")return z(n,e);try{return z(JSON.stringify(n),e)}catch{return z(String(n),e)}}function Q(n){let e=new Set;for(let o of n)if(o.role==="assistant"&&Array.isArray(o.tool_calls))for(let r of o.tool_calls)e.add(r.id);let t=n.filter(o=>o.role==="tool"?e.has(o.tool_call_id):!0),s=new Set;for(let o of t)o.role==="tool"&&s.add(o.tool_call_id);return t.map(o=>{if(o.role!=="assistant"||!Array.isArray(o.tool_calls)||o.tool_calls.every(a=>s.has(a.id)))return o;let{tool_calls:l,...i}=o;return{...i,content:i.content||""}})}function ge(n){let e=Array.isArray(n?.messages)?n.messages:[],t=e.find(r=>r.role==="system"),s=e.slice(-4).map(r=>({...r,content:z(r.content,r.role==="tool"?1200:2500)}));s=Q(s);let o={...n,messages:[t,...s].filter(Boolean)};return delete o.tools,o}async function he({body:n,streaming:e,auth:t,options:s,fetchCompletion:o,fetchStreamingCompletion:r,onFallbackLog:l}){try{return e?await r(n,t,s):await o(n,t,s)}catch(i){let a=String(i?.message||i||"");if(!/proxy error 413|payload too large/i.test(a))throw i;let c=ge(n);return typeof l=="function"&&l(n,c),{data:e?await r(c,t,s):await o(c,t,s),fallback:c}}}async function ee({body:n,auth:e,options:t,streaming:s,toolContext:o,activeSkills:r,round:l,verbose:i,dependencies:a,config:c={}}){let u=c.maxToolResultChars||3e3,{fetchCompletion:m,fetchStreamingCompletion:_,onFallbackLog:S,hasToolCalls:T,getTextContent:E,parseToolCalls:k,buildAssistantMessage:d,buildToolResultMessage:x,executeTool:b,onToolCallLog:f,injectTools:p}=a;Array.isArray(n?.messages)&&(n.messages=Q(n.messages));let g=await he({body:n,streaming:s,auth:e,options:t,fetchCompletion:m,fetchStreamingCompletion:_,onFallbackLog:S}),h=g?.data||g;if(!T(h))return{done:!0,text:E(h),body:g?.fallback||n};let w=k(h),C=g?.fallback||n;C.messages.push(d(h)),i&&typeof f=="function"&&f(w);let L=await Promise.all(w.map((y,K)=>(typeof t.onToolCall=="function"&&t.onToolCall(y.name,y.args,{round:l,index:K,total:w.length}),b(y,o))));for(let y=0;y<w.length;y++){let ne=w[y].name==="get_skill_context"?typeof L[y]=="string"?L[y]:JSON.stringify(L[y]):pe(L[y],u);C.messages.push(x(w[y].id,ne))}return typeof t.onToolCall=="function"&&t.onToolCall(null),p(C,r),{done:!1,body:C}}function te(n){let e=`${n}_POOL`,t=process.env[e];if(!t||typeof t!="string")return{picked:null,count:0,dispose:()=>{}};let s=t.split(/[,\n]+/).map(l=>l.trim()).filter(Boolean);if(s.length===0)return{picked:null,count:0,dispose:()=>{}};let o=s[Math.floor(Math.random()*s.length)],r=process.env[n];return process.env[n]=o,O.debug(`[auth-pool] ${n}: picked 1 of ${s.length} from pool (***${o.slice(-4)})`),{picked:o,count:s.length,dispose(){r===void 0?delete process.env[n]:process.env[n]=r}}}var _e=q.ASSISTANT,Se=15,H="get_skill_context";function B(n){!n||typeof n!="object"||(n.type==="object"&&n.properties&&(n.required=Object.keys(n.properties),n.additionalProperties=!1,Object.values(n.properties).forEach(B)),n.type==="array"&&n.items&&B(n.items),n.anyOf&&n.anyOf.forEach(B),n.oneOf&&n.oneOf.forEach(B),n.allOf&&n.allOf.forEach(B))}var oe={maxBytes:49e3,systemMaxChars:12e3},v=()=>process.env.ZIBBY_VERBOSE==="true"||process.env.ZIBBY_DEBUG==="true",Te=n=>Buffer.byteLength(JSON.stringify(n),"utf8");function J(n){return Array.isArray(n)?new Set(n.map(e=>String(e||"").trim()).filter(Boolean)):new Set}function xe(n){return Array.isArray(n)?n.map(e=>String(e||"").trim()).filter(Boolean):[]}var se=class extends ye{#e;#t;#o=new D;constructor(e=null){super("assistant","Zibby Assistant",200),e&&typeof e=="object"&&(e.toolProvider||e.completionProvider)?(this.#e=e.toolProvider||new $,this.#t=e.completionProvider||new P):(this.#e=e||new $,this.#t=new P)}canHandle(e){return Z().ok}async invoke(e,t={}){let s=te("OPENAI_API_KEY");try{let o=t.model&&t.model!=="auto"?t.model:_e,r=Z();if(!r.ok)throw r.reason==="missing_session_token"?new Error("Login required. Run `zibby login` to authenticate."):r.reason==="missing_openai_api_key"?new Error("Missing OPENAI_API_KEY for BYOK mode."):r.reason==="missing_openai_proxy_url"?new Error("Missing OPENAI_PROXY_URL for local mode."):new Error(`Assistant auth unavailable (${r.reason}).`);let l=t.messages||[{role:"user",content:e}],i=r.baseUrl,a=v();if(a?await this.#p(l,o,i,r.tokenPreview||"none"):O.debug(`[Assistant] ${i} | model: ${o} | messages: ${l.length}`),t.schema)return this.#c(o,l,r,t);let c=t.activeSkills||[],u=this.#f(t),m=this.#m(c,u),_=this.#d(m),S=this.#u(t),T={...t,payloadCompaction:S},E={activeSkills:m,options:T,executionRegistry:_,capabilityPolicy:u},k=!!t.stream,d={model:o,messages:[...l],stream:!1};this.#n(d,m,u);for(let x=0;x<Se;x++){if(t.signal?.aborted){let f=new Error("Aborted via signal");throw f.name="AbortError",f}let b=await ee({body:d,auth:r,options:T,streaming:k,toolContext:E,activeSkills:m,round:x,verbose:a,dependencies:{fetchCompletion:this.#r.bind(this),fetchStreamingCompletion:this.#a.bind(this),onFallbackLog:(f,p)=>{v()&&console.log(`413 fallback: messages ${f.messages.length} -> ${p.messages.length}, bytes=${Te(p)}`)},hasToolCalls:f=>this.#e.hasToolCalls(f),getTextContent:f=>this.#e.getTextContent(f),parseToolCalls:f=>this.#e.parseToolCalls(f),buildAssistantMessage:f=>this.#e.buildAssistantMessage(f),buildToolResultMessage:(f,p)=>this.#e.buildToolResultMessage(f,p),executeTool:(f,p)=>this.#l(f,p),onToolCallLog:async f=>{let p=(await import("chalk")).default;console.log(p.dim(` ${f.map(g=>`${g.name}(${JSON.stringify(g.args).slice(0,80)})`).join(", ")}`))},injectTools:(f,p)=>this.#n(f,p,u)},config:{maxToolResultChars:t.maxToolResultChars||3e3}});if(b.done)return b.text;d.messages=b.body.messages,b.body.tools?d.tools=b.body.tools:delete d.tools}return"I hit my tool-calling limit for this turn. Please try again."}finally{s.dispose()}}async cleanup(){await this.#o.stopAll()}#n(e,t,s=null){let o=this.#i(t,s),r=this.#e.formatTools(o);this.#e.injectToolsIntoBody(e,r)}#i(e,t=null){let s=[],o=new Set;for(let r of e){let l=F(r);if(l?.tools?.length)for(let i of l.tools)this.#s(i.name,t)&&(o.has(i.name)||(o.add(i.name),s.push({name:i.name,description:i.description,parameters:i.parameters||i.input_schema||{type:"object",properties:{}}})))}return!t?.disableSkillContextTool&&this.#s(H,t)&&s.push({name:H,description:"Fetch full prompt guidance/instructions for one installed skill on demand. Use this before making complex tool decisions if guidance is needed.",parameters:{type:"object",properties:{skillId:{type:"string",description:"Installed skill id to inspect (e.g. jira, github, runner, chat-memory)"}},required:["skillId"]}}),s}async#l(e,t){let{activeSkills:s,options:o,executionRegistry:r,capabilityPolicy:l}=t;if(!this.#s(e.name,l))return`Tool "${e.name}" blocked by policy`;if(e.name===H){let c=String(e.args?.skillId||"").trim();if(!c)return JSON.stringify({error:"skillId is required"});if(!s.includes(c))return JSON.stringify({error:`Skill "${c}" is not active`,activeSkills:s});let u=F(c);if(!u)return JSON.stringify({error:`Skill "${c}" not found`});let m=typeof u.promptFragment=="function"?u.promptFragment():u.promptFragment||"",_=(u.tools||[]).map(T=>T.name),S=JSON.stringify({skillId:c,description:u.description||"",toolNames:_,promptFragment:m||""});return v()&&(console.log(`
8
- \u{1F4D6} get_skill_context("${c}") \u2192 ${S.length} chars (fragment: ${m.length} chars)`),console.log(` tools: [${_.join(", ")}]`),console.log(` fragment preview: ${m.slice(0,200).replace(/\n/g,"\\n")}\u2026
9
- `)),S}let i=r?.get(e.name)||null;if(!i)return`Unknown tool: ${e.name}`;let a=F(i.skillId);if(!a)return`Skill "${i.skillId}" not found for tool "${e.name}"`;if(i.mode==="handler")try{return a.handleToolCall(e.name,e.args,t)}catch(c){return`Error in ${e.name}: ${c.message}`}if(i.mode==="mcp")try{if(!this.#o.isRunning(a.serverName)){let u=a.resolve(o);if(!u)return`Skill "${i.skillId}" is not available (cannot start server)`;await this.#o.ensureServer(a.serverName,u)}let c=await this.#o.callTool(a.serverName,e.name,e.args);return c.text||(c.isError?"Tool call failed":"Done")}catch(c){return`MCP error (${a.serverName}): ${c.message}`}return`Skill "${i.skillId}" owns tool "${e.name}" but has no execution mode`}async#a(e,t,s){return this.#t.fetchStreamingCompletion(e,t,{...s,onBudget:({beforeBytes:o,meta:r})=>{v()&&console.log(`payload bytes (stream) before=${o} after=${r.bytes} trimmed=${r.trimmed} messages=${r.messageCount}`)}})}async#r(e,t,s){return this.#t.fetchCompletion(e,t,{...s,onBudget:({beforeBytes:o,meta:r})=>{v()&&console.log(`payload bytes before=${o} after=${r.bytes} trimmed=${r.trimmed} messages=${r.messageCount}`)}})}async#c(e,t,s,o){let{zodToJsonSchema:r}=await import("zod-to-json-schema"),l=typeof o.schema?.parse=="function",i=l?r(o.schema):o.schema;delete i.$schema,B(i);let a={model:e,messages:t,stream:!1,response_format:{type:"json_schema",json_schema:{name:"extract",schema:i,strict:!0}}},c=await this.#r(a,s,o),u=this.#e.getTextContent(c),m=JSON.parse(u),_=l?o.schema.parse(m):m;return{raw:u,structured:_}}#u(e={}){let t=e?.config?.agent?.assistant?.payloadCompaction||{};return{maxBytes:Number(t.maxBytes||e.maxPayloadBytes||oe.maxBytes),systemMaxChars:Number(t.systemMaxChars||oe.systemMaxChars)}}#f(e={}){let t=e?.config?.agent?.assistant?.toolPolicy||{};return{allowTools:J(t.allowTools||e.allowTools),denyTools:J(t.denyTools||e.denyTools),denyPrefixes:xe(t.denyPrefixes||e.denyToolPrefixes),includeSkills:J(t.includeSkills||e.includeSkills),excludeSkills:J(t.excludeSkills||e.excludeSkills),disableSkillContextTool:!!(t.disableSkillContextTool||e.disableSkillContextTool)}}#m(e,t){let s=t?.includeSkills||new Set,o=t?.excludeSkills||new Set;return s.size===0&&o.size===0?e:e.filter(r=>!(s.size>0&&!s.has(r)||o.has(r)))}#s(e,t){let s=String(e||"").trim();if(!s)return!1;let o=t?.allowTools;if(o&&o.size>0&&!o.has(s))return!1;let r=t?.denyTools;return!(r&&r.has(s)||(t?.denyPrefixes||[]).some(i=>s.startsWith(i)))}#d(e){let t=new Map,s=[];for(let o of e){let r=F(o);if(!r?.tools?.length)continue;let l=typeof r.handleToolCall=="function"?"handler":r.serverName&&typeof r.resolve=="function"?"mcp":null;if(l)for(let i of r.tools){let a=String(i?.name||"").trim();if(a){if(t.has(a)){s.push({tool:a,winner:t.get(a).skillId,skipped:o});continue}t.set(a,{skillId:o,mode:l})}}}if(s.length>0&&v()){let o=s.slice(0,5).map(r=>`${r.tool}:${r.winner}>${r.skipped}`).join(", ");console.log(`tool registry collisions: ${o}${s.length>5?" ...":""}`)}return t}async#p(e,t,s,o){console.log(`
10
- \u25C6 Model: ${t} | proxy: ${s} | token: ${o||"none"}
11
- `);let r=(await import("chalk")).default;console.log(r.bold("Prompt sent to LLM:")),console.log(r.dim("\u2500".repeat(60)));let l=!1;for(let i of e)if(i.role==="system")console.log(r.dim(`[System] ${i.content||""}`));else{l||(console.log(r.dim("\u2500\u2500\u2500 chat history \u2500\u2500\u2500")),l=!0);let a=i.role==="user"?"Human":"AI",c=i.content?.length>200?`${i.content.slice(0,200)}...`:i.content||"";console.log(r.dim(`[${a}] ${c}`))}console.log(r.dim("\u2500".repeat(60)))}};export{se as AssistantStrategy};
7
+ [tool result truncated for size]`}function ye(s,e){if(typeof s=="string")return F(s,e);try{return F(JSON.stringify(s),e)}catch{return F(String(s),e)}}function ee(s){let e=new Set;for(let t of s)if(t.role==="assistant"&&Array.isArray(t.tool_calls))for(let i of t.tool_calls)e.add(i.id);let o=s.filter(t=>t.role==="tool"?e.has(t.tool_call_id):!0),n=new Set;for(let t of o)t.role==="tool"&&n.add(t.tool_call_id);return o.map(t=>{if(t.role!=="assistant"||!Array.isArray(t.tool_calls)||t.tool_calls.every(r=>n.has(r.id)))return t;let{tool_calls:l,...a}=t;return{...a,content:a.content||""}})}function he(s){let e=Array.isArray(s?.messages)?s.messages:[],o=e.find(i=>i.role==="system"),n=e.slice(-4).map(i=>({...i,content:F(i.content,i.role==="tool"?1200:2500)}));n=ee(n);let t={...s,messages:[o,...n].filter(Boolean)};return delete t.tools,t}async function _e({body:s,streaming:e,auth:o,options:n,fetchCompletion:t,fetchStreamingCompletion:i,onFallbackLog:l}){try{return e?await i(s,o,n):await t(s,o,n)}catch(a){let r=String(a?.message||a||"");if(!/proxy error 413|payload too large/i.test(r))throw a;let c=he(s);return typeof l=="function"&&l(s,c),{data:e?await i(c,o,n):await t(c,o,n),fallback:c}}}async function oe({body:s,auth:e,options:o,streaming:n,toolContext:t,activeSkills:i,round:l,verbose:a,dependencies:r,config:c={}}){let u=c.maxToolResultChars||3e3,{fetchCompletion:f,fetchStreamingCompletion:_,onFallbackLog:b,hasToolCalls:x,getTextContent:w,parseToolCalls:O,buildAssistantMessage:m,buildToolResultMessage:T,executeTool:S,onToolCallLog:d,injectTools:p}=r;Array.isArray(s?.messages)&&(s.messages=ee(s.messages));let g=await _e({body:s,streaming:n,auth:e,options:o,fetchCompletion:f,fetchStreamingCompletion:_,onFallbackLog:b}),y=g?.data||g;if(!x(y))return{done:!0,text:w(y),body:g?.fallback||s};let k=O(y),A=g?.fallback||s;A.messages.push(m(y)),a&&typeof d=="function"&&d(k);let R=await Promise.all(k.map((h,K)=>(typeof o.onToolCall=="function"&&o.onToolCall(h.name,h.args,{round:l,index:K,total:k.length}),S(h,t))));for(let h=0;h<k.length;h++){let ie=k[h].name==="get_skill_context"?typeof R[h]=="string"?R[h]:JSON.stringify(R[h]):ye(R[h],u);A.messages.push(T(k[h].id,ie))}return typeof o.onToolCall=="function"&&o.onToolCall(null),p(A,i),{done:!1,body:A}}function te(s){let e=`${s}_POOL`,o=process.env[e];if(!o||typeof o!="string")return{picked:null,count:0,dispose:()=>{}};let n=o.split(/[,\n]+/).map(l=>l.trim()).filter(Boolean);if(n.length===0)return{picked:null,count:0,dispose:()=>{}};let t=n[Math.floor(Math.random()*n.length)],i=process.env[s];return process.env[s]=t,I.debug(`[auth-pool] ${s}: picked 1 of ${n.length} from pool (***${t.slice(-4)})`),{picked:t,count:n.length,dispose(){i===void 0?delete process.env[s]:process.env[s]=i}}}var xe=q.ASSISTANT,Te=15,Z="get_skill_context";function P(s){!s||typeof s!="object"||(s.type==="object"&&s.properties&&(s.required=Object.keys(s.properties),s.additionalProperties=!1,Object.values(s.properties).forEach(P)),s.type==="array"&&s.items&&P(s.items),s.anyOf&&s.anyOf.forEach(P),s.oneOf&&s.oneOf.forEach(P),s.allOf&&s.allOf.forEach(P))}var ne={maxBytes:49e3,systemMaxChars:12e3},$=()=>process.env.ZIBBY_VERBOSE==="true"||process.env.ZIBBY_DEBUG==="true",Se=s=>Buffer.byteLength(JSON.stringify(s),"utf8");function z(s){return Array.isArray(s)?new Set(s.map(e=>String(e||"").trim()).filter(Boolean)):new Set}function ke(s){return Array.isArray(s)?s.map(e=>String(e||"").trim()).filter(Boolean):[]}var se=class extends be{#e;#o;#t=new j;constructor(e=null){super("assistant","Zibby Assistant",200),e&&typeof e=="object"&&(e.toolProvider||e.completionProvider)?(this.#e=e.toolProvider||new C,this.#o=e.completionProvider||new E):(this.#e=e||new C,this.#o=new E)}canHandle(e){return H().ok}async invoke(e,o={}){let n=te("OPENAI_API_KEY");try{let t=o.model&&o.model!=="auto"?o.model:xe,i=H();if(!i.ok)throw i.reason==="missing_session_token"?new Error("Login required. Run `zibby login` to authenticate."):i.reason==="missing_openai_api_key"?new Error("Missing OPENAI_API_KEY for BYOK mode."):i.reason==="missing_openai_proxy_url"?new Error("Missing OPENAI_PROXY_URL for local mode."):new Error(`Assistant auth unavailable (${i.reason}).`);let l=o.messages||[{role:"user",content:e}],a=i.baseUrl,r=$();if(r?await this.#p(l,t,a,i.tokenPreview||"none"):I.debug(`[Assistant] ${a} | model: ${t} | messages: ${l.length}`),o.schema)return this.#c(t,l,i,o);let c=o.activeSkills||[],u=this.#d(o),f=this.#f(c,u),_=this.#m(f),b=this.#u(o),x={...o,payloadCompaction:b},w={activeSkills:f,options:x,executionRegistry:_,capabilityPolicy:u},O=!!o.stream,m={model:t,messages:[...l],stream:!1};this.#s(m,f,u);for(let T=0;T<Te;T++){if(o.signal?.aborted){let d=new Error("Aborted via signal");throw d.name="AbortError",d}let S=await oe({body:m,auth:i,options:x,streaming:O,toolContext:w,activeSkills:f,round:T,verbose:r,dependencies:{fetchCompletion:this.#i.bind(this),fetchStreamingCompletion:this.#r.bind(this),onFallbackLog:(d,p)=>{$()&&console.log(`413 fallback: messages ${d.messages.length} -> ${p.messages.length}, bytes=${Se(p)}`)},hasToolCalls:d=>this.#e.hasToolCalls(d),getTextContent:d=>this.#e.getTextContent(d),parseToolCalls:d=>this.#e.parseToolCalls(d),buildAssistantMessage:d=>this.#e.buildAssistantMessage(d),buildToolResultMessage:(d,p)=>this.#e.buildToolResultMessage(d,p),executeTool:(d,p)=>this.#l(d,p),onToolCallLog:async d=>{let p=(await import("chalk")).default;console.log(p.dim(` ${d.map(g=>`${g.name}(${JSON.stringify(g.args).slice(0,80)})`).join(", ")}`))},injectTools:(d,p)=>this.#s(d,p,u)},config:{maxToolResultChars:o.maxToolResultChars||3e3}});if(S.done)return S.text;m.messages=S.body.messages,S.body.tools?m.tools=S.body.tools:delete m.tools}return"I hit my tool-calling limit for this turn. Please try again."}finally{n.dispose()}}async cleanup(){await this.#t.stopAll()}#s(e,o,n=null){let t=this.#a(o,n),i=this.#e.formatTools(t);this.#e.injectToolsIntoBody(e,i)}#a(e,o=null){let n=[],t=new Set;for(let i of e){let l=G(i);if(l?.tools?.length)for(let a of l.tools)this.#n(a.name,o)&&(t.has(a.name)||(t.add(a.name),n.push({name:a.name,description:a.description,parameters:a.parameters||a.input_schema||{type:"object",properties:{}}})))}return!o?.disableSkillContextTool&&this.#n(Z,o)&&n.push({name:Z,description:"Fetch full prompt guidance/instructions for one installed skill on demand. Use this before making complex tool decisions if guidance is needed.",parameters:{type:"object",properties:{skillId:{type:"string",description:"Installed skill id to inspect (e.g. jira, github, runner, chat-memory)"}},required:["skillId"]}}),n}async#l(e,o){let{activeSkills:n,options:t,executionRegistry:i,capabilityPolicy:l}=o;if(!this.#n(e.name,l))return`Tool "${e.name}" blocked by policy`;if(e.name===Z){let c=String(e.args?.skillId||"").trim();if(!c)return JSON.stringify({error:"skillId is required"});if(!n.includes(c))return JSON.stringify({error:`Skill "${c}" is not active`,activeSkills:n});let u=G(c);if(!u)return JSON.stringify({error:`Skill "${c}" not found`});let f=typeof u.promptFragment=="function"?u.promptFragment():u.promptFragment||"",_=(u.tools||[]).map(x=>x.name),b=JSON.stringify({skillId:c,description:u.description||"",toolNames:_,promptFragment:f||""});return $()&&(console.log(`
8
+ \u{1F4D6} get_skill_context("${c}") \u2192 ${b.length} chars (fragment: ${f.length} chars)`),console.log(` tools: [${_.join(", ")}]`),console.log(` fragment preview: ${f.slice(0,200).replace(/\n/g,"\\n")}\u2026
9
+ `)),b}let a=i?.get(e.name)||null;if(!a)return`Unknown tool: ${e.name}`;let r=G(a.skillId);if(!r)return`Skill "${a.skillId}" not found for tool "${e.name}"`;if(a.mode==="handler")try{return r.handleToolCall(e.name,e.args,o)}catch(c){return`Error in ${e.name}: ${c.message}`}if(a.mode==="mcp")try{if(!this.#t.isRunning(r.serverName)){let u=r.resolve(t);if(!u)return`Skill "${a.skillId}" is not available (cannot start server)`;await this.#t.ensureServer(r.serverName,u)}let c=await this.#t.callTool(r.serverName,e.name,e.args);return c.text||(c.isError?"Tool call failed":"Done")}catch(c){return`MCP error (${r.serverName}): ${c.message}`}return`Skill "${a.skillId}" owns tool "${e.name}" but has no execution mode`}async#r(e,o,n){return this.#o.fetchStreamingCompletion(e,o,{...n,onBudget:({beforeBytes:t,meta:i})=>{$()&&console.log(`payload bytes (stream) before=${t} after=${i.bytes} trimmed=${i.trimmed} messages=${i.messageCount}`)}})}async#i(e,o,n){return this.#o.fetchCompletion(e,o,{...n,onBudget:({beforeBytes:t,meta:i})=>{$()&&console.log(`payload bytes before=${t} after=${i.bytes} trimmed=${i.trimmed} messages=${i.messageCount}`)}})}async#c(e,o,n,t){let{zodToJsonSchema:i}=await import("zod-to-json-schema"),l=typeof t.schema?.parse=="function",a=l?i(t.schema):t.schema;delete a.$schema,P(a);let r={model:e,messages:o,stream:!1,response_format:{type:"json_schema",json_schema:{name:"extract",schema:a,strict:!0}}},c=await this.#i(r,n,t),u=this.#e.getTextContent(c),f=JSON.parse(u),_=l?t.schema.parse(f):f;return{raw:u,structured:_}}#u(e={}){let o=e?.config?.agent?.assistant?.payloadCompaction||{};return{maxBytes:Number(o.maxBytes||e.maxPayloadBytes||ne.maxBytes),systemMaxChars:Number(o.systemMaxChars||ne.systemMaxChars)}}#d(e={}){let o=e?.config?.agent?.assistant?.toolPolicy||{};return{allowTools:z(o.allowTools||e.allowTools),denyTools:z(o.denyTools||e.denyTools),denyPrefixes:ke(o.denyPrefixes||e.denyToolPrefixes),includeSkills:z(o.includeSkills||e.includeSkills),excludeSkills:z(o.excludeSkills||e.excludeSkills),disableSkillContextTool:!!(o.disableSkillContextTool||e.disableSkillContextTool)}}#f(e,o){let n=o?.includeSkills||new Set,t=o?.excludeSkills||new Set;return n.size===0&&t.size===0?e:e.filter(i=>!(n.size>0&&!n.has(i)||t.has(i)))}#n(e,o){let n=String(e||"").trim();if(!n)return!1;let t=o?.allowTools;if(t&&t.size>0&&!t.has(n))return!1;let i=o?.denyTools;return!(i&&i.has(n)||(o?.denyPrefixes||[]).some(a=>n.startsWith(a)))}#m(e){let o=new Map,n=[];for(let t of e){let i=G(t);if(!i?.tools?.length)continue;let l=typeof i.handleToolCall=="function"?"handler":i.serverName&&typeof i.resolve=="function"?"mcp":null;if(l)for(let a of i.tools){let r=String(a?.name||"").trim();if(r){if(o.has(r)){n.push({tool:r,winner:o.get(r).skillId,skipped:t});continue}o.set(r,{skillId:t,mode:l})}}}if(n.length>0&&$()){let t=n.slice(0,5).map(i=>`${i.tool}:${i.winner}>${i.skipped}`).join(", ");console.log(`tool registry collisions: ${t}${n.length>5?" ...":""}`)}return o}async#p(e,o,n,t){console.log(`
10
+ \u25C6 Model: ${o} | proxy: ${n} | token: ${t||"none"}
11
+ `);let i=(await import("chalk")).default;console.log(i.bold("Prompt sent to LLM:")),console.log(i.dim("\u2500".repeat(60)));let l=!1;for(let a of e)if(a.role==="system")console.log(i.dim(`[System] ${a.content||""}`));else{l||(console.log(i.dim("\u2500\u2500\u2500 chat history \u2500\u2500\u2500")),l=!0);let r=a.role==="user"?"Human":"AI",c=a.content?.length>200?`${a.content.slice(0,200)}...`:a.content||"";console.log(i.dim(`[${r}] ${c}`))}console.log(i.dim("\u2500".repeat(60)))}};export{se as AssistantStrategy};
@@ -1,3 +1,3 @@
1
- import{AgentStrategy as re,getSkill as ie}from"@zibby/agent-workflow";import{query as ce}from"@anthropic-ai/claude-agent-sdk";import{zodToJsonSchema as le}from"zod-to-json-schema";import{writeFileSync as P,mkdirSync as R,existsSync as Q,readFileSync as V}from"fs";import{homedir as ee}from"os";import{join as E}from"path";import N from"chalk";var m={debug:0,info:1,warn:2,error:3,silent:4},b=class{constructor(){this._level=this._getLogLevel()}_getLogLevel(){if(process.env.ZIBBY_DEBUG==="true")return m.debug;if(process.env.ZIBBY_VERBOSE==="true")return m.info;let e=process.env.LOG_LEVEL?.toLowerCase();return e&&e in m?m[e]:m.info}_shouldLog(e){return m[e]>=this._level}_formatMessage(e,s,i={}){let n=new Date().toISOString(),d=`${this._getPrefix(e)} ${s}`;return Object.keys(i).length>0&&(d+=N.dim(` ${JSON.stringify(i)}`)),d}_getPrefix(e){return{debug:N.gray("[DEBUG]"),info:N.cyan("[INFO]"),warn:N.yellow("[WARN]"),error:N.red("\u274C [ERROR]")}[e]||""}debug(e,s){this._shouldLog("debug")&&console.log(this._formatMessage("debug",e,s))}info(e,s){this._shouldLog("info")&&console.log(this._formatMessage("info",e,s))}warn(e,s){this._shouldLog("warn")&&console.warn(this._formatMessage("warn",e,s))}error(e,s){this._shouldLog("error")&&console.error(this._formatMessage("error",e,s))}setLevel(e){e in m&&(this._level=m[e])}getLevel(){return Object.keys(m).find(e=>m[e]===this._level)}},r=new b;import{timeline as I,Timeline as _e,WORKFLOW_GRAPH_LOG_MARKER_PREFIX as he}from"@zibby/agent-workflow";var x={ASSISTANT:"gpt-5.4-nano-2026-03-17",CLAUDE:"claude-sonnet-4-6",CURSOR:"auto",CODEX:"o4-mini",GEMINI:"gemini-2.5-pro",OPENAI_POSTPROCESSING:"gpt-4o-mini"};var M={auto:"claude-sonnet-4-6","sonnet-4.6":"claude-sonnet-4-6","sonnet-4-6":"claude-sonnet-4-6","opus-4.6":"claude-opus-4-6","opus-4-6":"claude-opus-4-6","sonnet-4.5":"claude-sonnet-4-5-20250929","sonnet-4-5":"claude-sonnet-4-5-20250929","opus-4.5":"claude-opus-4-20250514","opus-4-5":"claude-opus-4-20250514","claude-sonnet-4-6":"claude-sonnet-4-6","claude-opus-4-6":"claude-opus-4-6","claude-sonnet-4-5-20250929":"claude-sonnet-4-5-20250929","claude-opus-4-20250514":"claude-opus-4-20250514"};var Oe={CURSOR_AGENT_DEFAULT:1200*1e3,OPENAI_REQUEST:18e4};function v(a){let e=`${a}_POOL`,s=process.env[e];if(!s||typeof s!="string")return{picked:null,count:0,dispose:()=>{}};let i=s.split(/[,\n]+/).map(d=>d.trim()).filter(Boolean);if(i.length===0)return{picked:null,count:0,dispose:()=>{}};let n=i[Math.floor(Math.random()*i.length)],o=process.env[a];return process.env[a]=n,r.debug(`[auth-pool] ${a}: picked 1 of ${i.length} from pool (***${n.slice(-4)})`),{picked:n,count:i.length,dispose(){o===void 0?delete process.env[a]:process.env[a]=o}}}var z=class extends re{constructor(){super("claude","Claude (Anthropic API)",50)}canHandle(e){let s=!!process.env.ANTHROPIC_API_KEY||!!process.env.ANTHROPIC_API_KEY_POOL,i=!!process.env.CLAUDE_CODE_OAUTH_TOKEN||!!process.env.CLAUDE_CODE_OAUTH_TOKEN_POOL,n=!!process.env.ANTHROPIC_AUTH_TOKEN||!!process.env.ANTHROPIC_AUTH_TOKEN_POOL,o=s||i||n;return o||r.debug("ClaudeAgentStrategy: no credentials. Set one of ANTHROPIC_API_KEY / CLAUDE_CODE_OAUTH_TOKEN / ANTHROPIC_AUTH_TOKEN (or a *_POOL variant for multi-token rotation)."),o}async invoke(e,s={}){let{model:i,workspace:n=process.cwd(),schema:o=null,images:d=[],skills:p=null,sessionPath:_=null,nodeName:L=null,timeout:U,config:K={},signal:S=null,sessionId:J,resume:F,forkSession:te,sessionStore:H}=s,f=i;(!f||f==="auto")&&(r.debug(`Model is '${f||"undefined"}', using default: ${x.CLAUDE}`),f=x.CLAUDE);let T=M[f]||f;M[f]&&f!==T&&r.debug(`Mapped model: ${f} \u2192 ${T}`);let oe=[v("ANTHROPIC_API_KEY"),v("CLAUDE_CODE_OAUTH_TOKEN"),v("ANTHROPIC_AUTH_TOKEN")];try{r.debug(`Invoking Claude Agent SDK with model: ${T}, skills: ${JSON.stringify(p)}`);let O=process.env.CLAUDE_CODE_OAUTH_TOKEN,j=process.env.ANTHROPIC_API_KEY,B=process.env.ANTHROPIC_AUTH_TOKEN;process.env.CLAUDE_CODE_CREDENTIALS_JSON?de(process.env.CLAUDE_CODE_CREDENTIALS_JSON):O&&ue(O,process.env.__ZIBBY_CLAUDE_PLAN);let $=process.env.__ZIBBY_CLAUDE_PLAN,G=$?$.charAt(0).toUpperCase()+$.slice(1):null,y;O?y=G?`Claude ${G} plan \xB7 ***${O.slice(-4)}`:`Subscription \xB7 ***${O.slice(-4)}`:j?y=`API key \xB7 ***${j.slice(-4)}`:B?y=`Bearer \xB7 ***${B.slice(-4)}`:y="NONE \u2014 request will fail";let h=(await import("chalk")).default;console.log(""),console.log(` ${h.cyan("\u25C6")} ${h.bold(T)}`),console.log(` ${h.dim("Auth: ")}${y}`),console.log(` ${h.dim("Workdir: ")}${n}`),console.log(""),console.log(h.bold("Prompt sent to LLM:")),console.log(h.dim("\u2500".repeat(60))),console.log(h.dim(e)),console.log(h.dim("\u2500".repeat(60)));let{allowedTools:W,mcpServers:C}=this._resolveSkills(p,{sessionPath:_,workspace:n,nodeName:L});try{let g={cwd:n,allowedTools:W,settings:{permissions:{allow:["Bash(*)","Read(*)","Write(*)","Edit(*)","MultiEdit(*)","NotebookEdit(*)","Grep(*)","Glob(*)","WebFetch(*)","WebSearch(*)","Task(*)","TodoWrite(*)","Skill(*)"]}},model:T,...Object.keys(C).length>0&&{mcpServers:C},...J&&{sessionId:J},...F&&{resume:F},...te&&{forkSession:!0},...H&&{sessionStore:H}};if(o){let A=typeof o.parse=="function"?le(o,{target:"openApi3"}):o;g.outputFormat={type:"json_schema",schema:A},r.debug("Structured output enforced via SDK outputFormat")}r.debug(`Agent SDK options: ${JSON.stringify({cwd:g.cwd,toolCount:W.length,permissionMode:g.permissionMode,model:g.model,hasOutputFormat:!!g.outputFormat})}`);let D="",Y=0,Z=[];r.debug("Starting Claude Agent SDK query stream");let q;try{q=ce({prompt:e,options:g})}catch(t){throw r.error(`Failed to initialize Claude Agent SDK: ${t.message}`),t}let X=null,k=0,se=3;if(S?.aborted){let t=new Error("Aborted via signal");throw t.name="AbortError",t}try{for await(let t of q){if(S?.aborted){let l=new Error("Aborted via signal");throw l.name="AbortError",l}if(Z.push(t),t.type==="system"&&t.subtype==="init"){let l=t.mcp_servers||[];if(l.length>0){let c=l.map(u=>`${u.name}=${u.status}${u.error?` (${String(u.error).slice(0,120)})`:""}`).join(", ");r.info(`[mcp] SDK init \u2014 ${l.length} server(s): ${c}`);for(let u of l)u.status!=="connected"&&r.warn(`[mcp] server '${u.name}' did not connect: status=${u.status}`,{name:u.name,status:u.status,error:u.error})}else Object.keys(C||{}).length>0&&r.warn(`[mcp] SDK init returned no mcp_servers despite passing ${Object.keys(C).length} server(s) \u2014 SDK version may not expose this field, or config was dropped`);if(Array.isArray(t.tools)){let c=t.tools.filter(u=>u.startsWith("mcp__"));c.length>0?r.info(`[mcp] tools visible to model: ${c.join(", ")}`):Object.keys(C||{}).length>0&&r.warn("[mcp] no mcp__* tools in model's tool list \u2014 MCP servers configured but tools didn't reach the prompt")}}if(t.type==="error"||t.error){let l=t.error?.message||t.error||t.message||"Unknown API error";try{r.error("SDK error event raw payload",{fullMessage:JSON.stringify(t,null,2)})}catch{}throw new Error(typeof l=="string"?l:JSON.stringify(l))}let A=JSON.stringify(t.message?.content||t.text||"").slice(0,200);if(A===X){if(k++,k>=se){let l=(t.message?.content?.[0]?.text||t.text||"unknown").slice(0,100);throw new Error(`API stuck in loop (${k}x repeated): ${l}`)}}else X=A,k=1;if(t.type==="assistant"||t.constructor?.name==="AssistantMessage"){let l=t.message?.content||t.content||[];for(let c of l)if(c.type==="thinking"&&c.thinking)console.log(`${c.thinking.substring(0,200)}${c.thinking.length>200?"...":""}`);else if(c.type==="text"&&c.text)D+=c.text,c.text.length<500?console.log(`${c.text}`):console.log(`${c.text.substring(0,200)}... (${c.text.length} chars)`);else if(c.type==="tool_use"){Y++,c.name.includes("memory")?I.stepMemory(`Tool: ${c.name}`):I.stepTool(`Tool: ${c.name}`);let ne=JSON.stringify(c.input).substring(0,100);console.log(` Input: ${ne}${JSON.stringify(c.input).length>100?"...":""}`)}}else if(!(t.type==="user"&&t.tool_use_result)){if(t.type==="result"||t.constructor?.name==="ResultMessage"){let l=t.result||t.text||t.content||D;try{ae({message:t,sessionPath:_,nodeName:L,model:f,toolCallCount:Y})}catch(c){r.debug(`usage.json write failed: ${c.message}`)}if(o){if(t.structured_output){r.debug("Using SDK native structured_output");let u=typeof o.parse=="function"?o.parse(t.structured_output):t.structured_output;return{raw:l,structured:u}}if(l){let c=this._extractJson(l,o);if(c)return{raw:l,structured:c}}r.warn(`Could not extract structured output \u2014 returning raw text (${(l||"").length} chars)`)}return l||""}}}if(r.warn(`Agent SDK ended without result. Collected ${Z.length} messages`),D.length>0)return r.debug("Returning accumulated text from messages"),D;throw new Error("Claude Agent SDK query ended without result")}catch(t){let A={message:t?.message,name:t?.name,code:t?.code,cause:t?.cause?.message||t?.cause,stack:t?.stack?.split(`
1
+ import{AgentStrategy as le,getSkill as re}from"@zibby/agent-workflow";import{query as ce}from"@anthropic-ai/claude-agent-sdk";import{zodToJsonSchema as ue}from"zod-to-json-schema";import{writeFileSync as R,mkdirSync as U,existsSync as Q,readFileSync as ee}from"fs";import{homedir as oe}from"os";import{join as v}from"path";import I from"chalk";var g={debug:0,info:1,warn:2,error:3,silent:4},N=class{constructor(){this._level=this._getLogLevel()}_getLogLevel(){if(process.env.ZIBBY_DEBUG==="true")return g.debug;if(process.env.ZIBBY_VERBOSE==="true")return g.info;let e=process.env.LOG_LEVEL?.toLowerCase();return e&&e in g?g[e]:g.info}_shouldLog(e){return g[e]>=this._level}_formatMessage(e,n,i={}){let s=new Date().toISOString(),d=`${this._getPrefix(e)} ${n}`;return Object.keys(i).length>0&&(d+=I.dim(` ${JSON.stringify(i)}`)),d}_getPrefix(e){return{debug:I.gray("[DEBUG]"),info:I.cyan("[INFO]"),warn:I.yellow("[WARN]"),error:I.red("\u274C [ERROR]")}[e]||""}debug(e,n){this._shouldLog("debug")&&console.log(this._formatMessage("debug",e,n))}info(e,n){this._shouldLog("info")&&console.log(this._formatMessage("info",e,n))}warn(e,n){this._shouldLog("warn")&&console.warn(this._formatMessage("warn",e,n))}error(e,n){this._shouldLog("error")&&console.error(this._formatMessage("error",e,n))}setLevel(e){e in g&&(this._level=g[e])}getLevel(){return Object.keys(g).find(e=>g[e]===this._level)}},a=new N;import{timeline as $,Timeline as he,WORKFLOW_GRAPH_LOG_MARKER_PREFIX as ye}from"@zibby/agent-workflow";var ie=[{alias:"auto",canonicalId:"claude-sonnet-4-6",vendor:"claude",label:"Claude \xB7 Sonnet 4.6",family:"claude-sonnet-4",pickerVisible:!0,isDefault:!0},{alias:"opus-4.8",canonicalId:"claude-opus-4-8",vendor:"claude",label:"Claude \xB7 Opus 4.8",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-8",canonicalId:"claude-opus-4-8",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.8"},{alias:"sonnet-4.8",canonicalId:"claude-sonnet-4-8",vendor:"claude",label:"Claude \xB7 Sonnet 4.8",family:"claude-sonnet-4",pickerVisible:!0},{alias:"sonnet-4-8",canonicalId:"claude-sonnet-4-8",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.8"},{alias:"opus-4.7",canonicalId:"claude-opus-4-7",vendor:"claude",label:"Claude \xB7 Opus 4.7",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-7",canonicalId:"claude-opus-4-7",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.7"},{alias:"sonnet-4.7",canonicalId:"claude-sonnet-4-7",vendor:"claude",label:"Claude \xB7 Sonnet 4.7",family:"claude-sonnet-4",pickerVisible:!0},{alias:"sonnet-4-7",canonicalId:"claude-sonnet-4-7",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.7"},{alias:"sonnet-4.6",canonicalId:"claude-sonnet-4-6",vendor:"claude",family:"claude-sonnet-4",aliasOf:"auto"},{alias:"sonnet-4-6",canonicalId:"claude-sonnet-4-6",vendor:"claude",family:"claude-sonnet-4",aliasOf:"auto"},{alias:"opus-4.6",canonicalId:"claude-opus-4-6",vendor:"claude",label:"Claude \xB7 Opus 4.6",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-6",canonicalId:"claude-opus-4-6",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.6"},{alias:"sonnet-4.5",canonicalId:"claude-sonnet-4-5-20250929",vendor:"claude",label:"Claude \xB7 Sonnet 4.5",family:"claude-sonnet-4",pickerVisible:!0},{alias:"sonnet-4-5",canonicalId:"claude-sonnet-4-5-20250929",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.5"},{alias:"opus-4.5",canonicalId:"claude-opus-4-5-20251101",vendor:"claude",label:"Claude \xB7 Opus 4.5",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-5",canonicalId:"claude-opus-4-5-20251101",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.5"},{alias:"haiku-4.5",canonicalId:"claude-haiku-4-5-20251001",vendor:"claude",label:"Claude \xB7 Haiku 4.5",family:"claude-haiku-4"},{alias:"haiku-4-5",canonicalId:"claude-haiku-4-5-20251001",vendor:"claude",family:"claude-haiku-4",aliasOf:"haiku-4.5"},{alias:"claude-opus-4-8",canonicalId:"claude-opus-4-8",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.8"},{alias:"claude-sonnet-4-8",canonicalId:"claude-sonnet-4-8",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.8"},{alias:"claude-opus-4-7",canonicalId:"claude-opus-4-7",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.7"},{alias:"claude-sonnet-4-7",canonicalId:"claude-sonnet-4-7",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.7"},{alias:"claude-sonnet-4-6",canonicalId:"claude-sonnet-4-6",vendor:"claude",family:"claude-sonnet-4",aliasOf:"auto"},{alias:"claude-opus-4-6",canonicalId:"claude-opus-4-6",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.6"},{alias:"claude-sonnet-4-5-20250929",canonicalId:"claude-sonnet-4-5-20250929",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.5"},{alias:"claude-opus-4-5-20251101",canonicalId:"claude-opus-4-5-20251101",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.5"},{alias:"claude-haiku-4-5-20251001",canonicalId:"claude-haiku-4-5-20251001",vendor:"claude",family:"claude-haiku-4",aliasOf:"haiku-4.5"},{alias:"claude-opus-4-20250514",canonicalId:"claude-opus-4-20250514",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.5"},{alias:"auto",canonicalId:"o4-mini",vendor:"codex",label:"Codex \xB7 o4-mini",family:"o4-mini",isDefault:!0},{alias:"o4-mini",canonicalId:"o4-mini",vendor:"codex",label:"Codex \xB7 o4-mini",family:"o4-mini",pickerVisible:!0},{alias:"o3",canonicalId:"o3",vendor:"codex",family:"o3"},{alias:"o3-mini",canonicalId:"o3-mini",vendor:"codex",family:"o3-mini"},{alias:"codex-mini",canonicalId:"codex-mini-latest",vendor:"codex",family:"codex-mini"},{alias:"gpt-4o",canonicalId:"gpt-4o",vendor:"codex",label:"Codex \xB7 GPT-4o",family:"gpt-4o",pickerVisible:!0},{alias:"gpt-4o-mini",canonicalId:"gpt-4o-mini",vendor:"codex",label:"Codex \xB7 GPT-4o mini",family:"gpt-4o-mini",pickerVisible:!0},{alias:"gpt-5.2-codex",canonicalId:"gpt-5.2-codex",vendor:"codex",label:"Codex \xB7 GPT-5.2",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.2",canonicalId:"gpt-5.2",vendor:"codex",label:"Codex \xB7 GPT-5.2 base",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.3",canonicalId:"gpt-5.3",vendor:"codex",label:"Codex \xB7 GPT-5.3",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.3-codex",canonicalId:"gpt-5.3-codex",vendor:"codex",family:"gpt-5"},{alias:"gpt-5.4",canonicalId:"gpt-5.4",vendor:"codex",label:"Codex \xB7 GPT-5.4",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.5",canonicalId:"gpt-5.5",vendor:"codex",label:"Codex \xB7 GPT-5.5",family:"gpt-5",pickerVisible:!0},{alias:"auto",canonicalId:"gemini-3-pro",vendor:"gemini",label:"Gemini \xB7 3 Pro",family:"gemini-3",isDefault:!0},{alias:"gemini-3-pro",canonicalId:"gemini-3-pro",vendor:"gemini",label:"Gemini \xB7 3 Pro",family:"gemini-3",pickerVisible:!0},{alias:"gemini-3-flash",canonicalId:"gemini-3-flash",vendor:"gemini",label:"Gemini \xB7 3 Flash",family:"gemini-3",pickerVisible:!0},{alias:"gemini-2.5-pro",canonicalId:"gemini-2.5-pro",vendor:"gemini",label:"Gemini \xB7 2.5 Pro",family:"gemini-2.5",pickerVisible:!0},{alias:"gemini-2.5-flash",canonicalId:"gemini-2.5-flash",vendor:"gemini",label:"Gemini \xB7 2.5 Flash",family:"gemini-2.5",pickerVisible:!0}];function w(r){let e={};for(let n of ie)n.vendor===r&&(e[n.alias]=n.canonicalId);return e}var P={ASSISTANT:"gpt-5.4-nano-2026-03-17",CLAUDE:"claude-sonnet-4-6",CURSOR:"auto",CODEX:"o4-mini",GEMINI:"gemini-3-pro",OPENAI_POSTPROCESSING:"gpt-4o-mini"};var M=w("claude"),Ee=w("codex"),be=w("gemini"),Se={CURSOR_AGENT_DEFAULT:1200*1e3,OPENAI_REQUEST:18e4};function D(r){let e=`${r}_POOL`,n=process.env[e];if(!n||typeof n!="string")return{picked:null,count:0,dispose:()=>{}};let i=n.split(/[,\n]+/).map(d=>d.trim()).filter(Boolean);if(i.length===0)return{picked:null,count:0,dispose:()=>{}};let s=i[Math.floor(Math.random()*i.length)],t=process.env[r];return process.env[r]=s,a.debug(`[auth-pool] ${r}: picked 1 of ${i.length} from pool (***${s.slice(-4)})`),{picked:s,count:i.length,dispose(){t===void 0?delete process.env[r]:process.env[r]=t}}}var z=class extends le{constructor(){super("claude","Claude (Anthropic API)",50)}canHandle(e){let n=!!process.env.ANTHROPIC_API_KEY||!!process.env.ANTHROPIC_API_KEY_POOL,i=!!process.env.CLAUDE_CODE_OAUTH_TOKEN||!!process.env.CLAUDE_CODE_OAUTH_TOKEN_POOL,s=!!process.env.ANTHROPIC_AUTH_TOKEN||!!process.env.ANTHROPIC_AUTH_TOKEN_POOL,t=n||i||s;return t||a.debug("ClaudeAgentStrategy: no credentials. Set one of ANTHROPIC_API_KEY / CLAUDE_CODE_OAUTH_TOKEN / ANTHROPIC_AUTH_TOKEN (or a *_POOL variant for multi-token rotation)."),t}async invoke(e,n={}){let{model:i,workspace:s=process.cwd(),schema:t=null,images:d=[],skills:p=null,sessionPath:O=null,nodeName:C=null,timeout:K,config:G={},signal:A=null,sessionId:J,resume:F,forkSession:ne,sessionStore:H}=n,m=i;(!m||m==="auto")&&(a.debug(`Model is '${m||"undefined"}', using default: ${P.CLAUDE}`),m=P.CLAUDE);let E=M[m]||m;M[m]&&m!==E&&a.debug(`Mapped model: ${m} \u2192 ${E}`);let te=[D("ANTHROPIC_API_KEY"),D("CLAUDE_CODE_OAUTH_TOKEN"),D("ANTHROPIC_AUTH_TOKEN")];try{a.debug(`Invoking Claude Agent SDK with model: ${E}, skills: ${JSON.stringify(p)}`);let h=process.env.CLAUDE_CODE_OAUTH_TOKEN,V=process.env.ANTHROPIC_API_KEY,j=process.env.ANTHROPIC_AUTH_TOKEN;process.env.CLAUDE_CODE_CREDENTIALS_JSON?fe(process.env.CLAUDE_CODE_CREDENTIALS_JSON):h&&pe(h,process.env.__ZIBBY_CLAUDE_PLAN);let L=process.env.__ZIBBY_CLAUDE_PLAN,B=L?L.charAt(0).toUpperCase()+L.slice(1):null,b;h?b=B?`Claude ${B} plan \xB7 ***${h.slice(-4)}`:`Subscription \xB7 ***${h.slice(-4)}`:V?b=`API key \xB7 ***${V.slice(-4)}`:j?b=`Bearer \xB7 ***${j.slice(-4)}`:b="NONE \u2014 request will fail";let _=(await import("chalk")).default;console.log(""),console.log(` ${_.cyan("\u25C6")} ${_.bold(E)}`),console.log(` ${_.dim("Auth: ")}${b}`),console.log(` ${_.dim("Workdir: ")}${s}`),console.log(""),console.log(_.bold("Prompt sent to LLM:")),console.log(_.dim("\u2500".repeat(60))),console.log(_.dim(e)),console.log(_.dim("\u2500".repeat(60)));let{allowedTools:W,mcpServers:S}=this._resolveSkills(p,{sessionPath:O,workspace:s,nodeName:C});try{let f={cwd:s,allowedTools:W,settings:{permissions:{allow:["Bash(*)","Read(*)","Write(*)","Edit(*)","MultiEdit(*)","NotebookEdit(*)","Grep(*)","Glob(*)","WebFetch(*)","WebSearch(*)","Task(*)","TodoWrite(*)","Skill(*)"]}},model:E,...Object.keys(S).length>0&&{mcpServers:S},...J&&{sessionId:J},...F&&{resume:F},...ne&&{forkSession:!0},...H&&{sessionStore:H}};if(t){let y=typeof t.parse=="function"?ue(t,{target:"openApi3"}):t;f.outputFormat={type:"json_schema",schema:y},a.debug("Structured output enforced via SDK outputFormat")}a.debug(`Agent SDK options: ${JSON.stringify({cwd:f.cwd,toolCount:W.length,permissionMode:f.permissionMode,model:f.model,hasOutputFormat:!!f.outputFormat})}`);let T="",Y=0,Z=[];a.debug("Starting Claude Agent SDK query stream");let q;try{q=ce({prompt:e,options:f})}catch(o){throw a.error(`Failed to initialize Claude Agent SDK: ${o.message}`),o}let X=null,x=0,se=3;if(A?.aborted){let o=new Error("Aborted via signal");throw o.name="AbortError",o}try{for await(let o of q){if(A?.aborted){let c=new Error("Aborted via signal");throw c.name="AbortError",c}if(Z.push(o),o.type==="system"&&o.subtype==="init"){let c=o.mcp_servers||[];if(c.length>0){let l=c.map(u=>`${u.name}=${u.status}${u.error?` (${String(u.error).slice(0,120)})`:""}`).join(", ");a.info(`[mcp] SDK init \u2014 ${c.length} server(s): ${l}`);for(let u of c)u.status!=="connected"&&a.warn(`[mcp] server '${u.name}' did not connect: status=${u.status}`,{name:u.name,status:u.status,error:u.error})}else Object.keys(S||{}).length>0&&a.warn(`[mcp] SDK init returned no mcp_servers despite passing ${Object.keys(S).length} server(s) \u2014 SDK version may not expose this field, or config was dropped`);if(Array.isArray(o.tools)){let l=o.tools.filter(u=>u.startsWith("mcp__"));l.length>0?a.info(`[mcp] tools visible to model: ${l.join(", ")}`):Object.keys(S||{}).length>0&&a.warn("[mcp] no mcp__* tools in model's tool list \u2014 MCP servers configured but tools didn't reach the prompt")}}if(o.type==="error"||o.error){let c=o.error?.message||o.error||o.message||"Unknown API error";try{a.error("SDK error event raw payload",{fullMessage:JSON.stringify(o,null,2)})}catch{}throw new Error(typeof c=="string"?c:JSON.stringify(c))}let y=JSON.stringify(o.message?.content||o.text||"").slice(0,200);if(y===X){if(x++,x>=se){let c=(o.message?.content?.[0]?.text||o.text||"unknown").slice(0,100);throw new Error(`API stuck in loop (${x}x repeated): ${c}`)}}else X=y,x=1;if(o.type==="assistant"||o.constructor?.name==="AssistantMessage"){let c=o.message?.content||o.content||[];for(let l of c)if(l.type==="thinking"&&l.thinking)console.log(`${l.thinking.substring(0,200)}${l.thinking.length>200?"...":""}`);else if(l.type==="text"&&l.text)T+=l.text,l.text.length<500?console.log(`${l.text}`):console.log(`${l.text.substring(0,200)}... (${l.text.length} chars)`);else if(l.type==="tool_use"){Y++,l.name.includes("memory")?$.stepMemory(`Tool: ${l.name}`):$.stepTool(`Tool: ${l.name}`);let ae=JSON.stringify(l.input).substring(0,100);console.log(` Input: ${ae}${JSON.stringify(l.input).length>100?"...":""}`)}}else if(!(o.type==="user"&&o.tool_use_result)){if(o.type==="result"||o.constructor?.name==="ResultMessage"){let c=o.result||o.text||o.content||T;try{de({message:o,sessionPath:O,nodeName:C,model:m,toolCallCount:Y})}catch(l){a.debug(`usage.json write failed: ${l.message}`)}if(t){if(o.structured_output){a.debug("Using SDK native structured_output");let u=typeof t.parse=="function"?t.parse(o.structured_output):o.structured_output;return{raw:c,structured:u}}if(c){let l=this._extractJson(c,t);if(l)return{raw:c,structured:l}}a.warn(`Could not extract structured output \u2014 returning raw text (${(c||"").length} chars)`)}return c||""}}}if(a.warn(`Agent SDK ended without result. Collected ${Z.length} messages`),T.length>0)return a.debug("Returning accumulated text from messages"),T;throw new Error("Claude Agent SDK query ended without result")}catch(o){let y={message:o?.message,name:o?.name,code:o?.code,cause:o?.cause?.message||o?.cause,stack:o?.stack?.split(`
2
2
  `).slice(0,5).join(`
3
- `),stringified:(()=>{try{return JSON.stringify(t,Object.getOwnPropertyNames(Object(t)))}catch{return String(t)}})()};throw r.error(`Error during query stream: ${t?.message||t}`,A),t}}catch(g){throw r.error("Claude Agent SDK call failed",{message:g?.message,name:g?.name,code:g?.code,cause:g?.cause?.message||g?.cause}),g}}finally{for(let O of oe)O.dispose()}}_resolveSkills(e,s){let i=["Read","Write","Edit","Bash","Grep","Glob"];if(e===null)return r.debug("No skills \u2014 pure LLM mode"),{allowedTools:[],mcpServers:{}};if(!Array.isArray(e)||e.length===0)return r.debug("Default IDE skills for code generation"),{allowedTools:[...i],mcpServers:{}};let n=[...i],o={};for(let d of e){let p=ie(d);if(!p){r.warn(`Unknown skill "${d}" \u2014 skipping`);continue}if(p.allowedTools&&n.push(...p.allowedTools),typeof p.resolve=="function"){let _=p.resolve(s);_&&(o[p.serverName]=_,r.debug(`MCP: ${p.serverName} \u2192 ${_.command} ${_.args[0]}`))}}return{allowedTools:n,mcpServers:o}}_extractJson(e,s){let i=[()=>{if(e.includes("===JSON_START===")){let n=e.indexOf("===JSON_START===")+16,o=e.indexOf("===JSON_END===");return e.substring(n,o).trim()}},()=>e.match(/```json\s*\n([\s\S]*?)\n```/)?.[1]?.trim(),()=>{if(!e.startsWith("{"))return e.match(/```\s*\n([\s\S]*?)\n```/)?.[1]?.trim()},()=>e.trim(),()=>{let n=e.indexOf("{"),o=e.lastIndexOf("}");if(n!==-1&&o>n)return e.substring(n,o+1)}];for(let n of i)try{let o=n();if(!o)continue;let d=JSON.parse(o);if(typeof d!="object"||d===null)continue;return typeof s.parse=="function"?s.parse(d):d}catch{}return null}};function ae({message:a,sessionPath:e,nodeName:s,model:i,toolCallCount:n}){if(!e||!s)return;let o=a?.usage||a?.message?.usage||{},d=w(o.input_tokens,o.inputTokens),p=w(o.output_tokens,o.outputTokens),_=w(o.cache_read_input_tokens,o.cacheReadInputTokens),L=w(o.cache_creation_input_tokens,o.cacheCreationInputTokens),U=w(a?.duration_ms,a?.durationMs),K={model:i||null,input_tokens:d,output_tokens:p,cache_read_tokens:_,cache_creation_tokens:L,tool_call_count:typeof n=="number"?n:null,duration_ms:U,captured_at:new Date().toISOString()},S=E(e,s);try{R(S,{recursive:!0})}catch{}P(E(S,"usage.json"),JSON.stringify(K,null,2),"utf-8")}function w(...a){for(let e of a){if(typeof e=="number"&&Number.isFinite(e))return e;if(typeof e=="string"&&e.trim()!==""&&!isNaN(Number(e)))return Number(e)}return null}function ue(a,e){let s=E(ee(),".claude"),i=E(s,".credentials.json"),n={claudeAiOauth:{accessToken:a,...e?{subscriptionType:String(e).toLowerCase()}:{}}};try{if(Q(i)&&JSON.parse(V(i,"utf-8"))?.claudeAiOauth?.accessToken===a)return;R(s,{recursive:!0}),P(i,JSON.stringify(n,null,2),"utf-8"),r.debug(`Wrote Claude Code OAuth credentials to ${i}`)}catch(o){r.warn(`Could not write ${i}: ${o.message} \u2014 Claude SDK may fail to authenticate.`)}}function de(a){let e=E(ee(),".claude"),s=E(e,".credentials.json"),i;try{i=JSON.parse(a)}catch(n){r.warn(`CLAUDE_CODE_CREDENTIALS_JSON not valid JSON: ${n.message}`);return}if(!i?.claudeAiOauth?.accessToken){r.warn("CLAUDE_CODE_CREDENTIALS_JSON missing claudeAiOauth.accessToken \u2014 skipping write.");return}try{if(Q(s)){let n=JSON.parse(V(s,"utf-8"));if(n?.claudeAiOauth?.accessToken===i.claudeAiOauth.accessToken&&n?.claudeAiOauth?.expiresAt===i.claudeAiOauth.expiresAt)return}R(e,{recursive:!0}),P(s,JSON.stringify(i,null,2),"utf-8"),r.debug(`Wrote full Claude Code credentials blob to ${s}`)}catch(n){r.warn(`Could not write ${s}: ${n.message} \u2014 Claude SDK may fail to authenticate.`)}}export{z as ClaudeAgentStrategy};
3
+ `),stringified:(()=>{try{return JSON.stringify(o,Object.getOwnPropertyNames(Object(o)))}catch{return String(o)}})()};throw a.error(`Error during query stream: ${o?.message||o}`,y),o}}catch(f){throw a.error("Claude Agent SDK call failed",{message:f?.message,name:f?.name,code:f?.code,cause:f?.cause?.message||f?.cause}),f}}finally{for(let h of te)h.dispose()}}_resolveSkills(e,n){let i=["Read","Write","Edit","Bash","Grep","Glob"];if(e===null)return a.debug("No skills \u2014 pure LLM mode"),{allowedTools:[],mcpServers:{}};if(!Array.isArray(e)||e.length===0)return a.debug("Default IDE skills for code generation"),{allowedTools:[...i],mcpServers:{}};let s=[...i],t={};for(let d of e){let p=re(d);if(!p){a.warn(`Unknown skill "${d}" \u2014 skipping`);continue}if(p.allowedTools&&s.push(...p.allowedTools),typeof p.resolve=="function"){let O=p.resolve(n);O&&(t[p.serverName]=O,a.debug(`MCP: ${p.serverName} \u2192 ${O.command} ${O.args[0]}`))}}return{allowedTools:s,mcpServers:t}}_extractJson(e,n){let i=[()=>{if(e.includes("===JSON_START===")){let s=e.indexOf("===JSON_START===")+16,t=e.indexOf("===JSON_END===");return e.substring(s,t).trim()}},()=>e.match(/```json\s*\n([\s\S]*?)\n```/)?.[1]?.trim(),()=>{if(!e.startsWith("{"))return e.match(/```\s*\n([\s\S]*?)\n```/)?.[1]?.trim()},()=>e.trim(),()=>{let s=e.indexOf("{"),t=e.lastIndexOf("}");if(s!==-1&&t>s)return e.substring(s,t+1)}];for(let s of i)try{let t=s();if(!t)continue;let d=JSON.parse(t);if(typeof d!="object"||d===null)continue;return typeof n.parse=="function"?n.parse(d):d}catch{}return null}};function de({message:r,sessionPath:e,nodeName:n,model:i,toolCallCount:s}){if(!e||!n)return;let t=r?.usage||r?.message?.usage||{},d=k(t.input_tokens,t.inputTokens),p=k(t.output_tokens,t.outputTokens),O=k(t.cache_read_input_tokens,t.cacheReadInputTokens),C=k(t.cache_creation_input_tokens,t.cacheCreationInputTokens),K=k(r?.duration_ms,r?.durationMs),G={model:i||null,input_tokens:d,output_tokens:p,cache_read_tokens:O,cache_creation_tokens:C,tool_call_count:typeof s=="number"?s:null,duration_ms:K,captured_at:new Date().toISOString()},A=v(e,n);try{U(A,{recursive:!0})}catch{}R(v(A,"usage.json"),JSON.stringify(G,null,2),"utf-8")}function k(...r){for(let e of r){if(typeof e=="number"&&Number.isFinite(e))return e;if(typeof e=="string"&&e.trim()!==""&&!isNaN(Number(e)))return Number(e)}return null}function pe(r,e){let n=v(oe(),".claude"),i=v(n,".credentials.json"),s={claudeAiOauth:{accessToken:r,...e?{subscriptionType:String(e).toLowerCase()}:{}}};try{if(Q(i)&&JSON.parse(ee(i,"utf-8"))?.claudeAiOauth?.accessToken===r)return;U(n,{recursive:!0}),R(i,JSON.stringify(s,null,2),"utf-8"),a.debug(`Wrote Claude Code OAuth credentials to ${i}`)}catch(t){a.warn(`Could not write ${i}: ${t.message} \u2014 Claude SDK may fail to authenticate.`)}}function fe(r){let e=v(oe(),".claude"),n=v(e,".credentials.json"),i;try{i=JSON.parse(r)}catch(s){a.warn(`CLAUDE_CODE_CREDENTIALS_JSON not valid JSON: ${s.message}`);return}if(!i?.claudeAiOauth?.accessToken){a.warn("CLAUDE_CODE_CREDENTIALS_JSON missing claudeAiOauth.accessToken \u2014 skipping write.");return}try{if(Q(n)){let s=JSON.parse(ee(n,"utf-8"));if(s?.claudeAiOauth?.accessToken===i.claudeAiOauth.accessToken&&s?.claudeAiOauth?.expiresAt===i.claudeAiOauth.expiresAt)return}U(e,{recursive:!0}),R(n,JSON.stringify(i,null,2),"utf-8"),a.debug(`Wrote full Claude Code credentials blob to ${n}`)}catch(s){a.warn(`Could not write ${n}: ${s.message} \u2014 Claude SDK may fail to authenticate.`)}}export{z as ClaudeAgentStrategy};
@@ -1,4 +1,4 @@
1
- import{AgentStrategy as G,getSkill as X}from"@zibby/agent-workflow";import{execSync as j}from"node:child_process";import{zodToJsonSchema as B}from"zod-to-json-schema";import h from"chalk";var u={debug:0,info:1,warn:2,error:3,silent:4},y=class{constructor(){this._level=this._getLogLevel()}_getLogLevel(){if(process.env.ZIBBY_DEBUG==="true")return u.debug;if(process.env.ZIBBY_VERBOSE==="true")return u.info;let e=process.env.LOG_LEVEL?.toLowerCase();return e&&e in u?u[e]:u.info}_shouldLog(e){return u[e]>=this._level}_formatMessage(e,t,r={}){let l=new Date().toISOString(),n=`${this._getPrefix(e)} ${t}`;return Object.keys(r).length>0&&(n+=h.dim(` ${JSON.stringify(r)}`)),n}_getPrefix(e){return{debug:h.gray("[DEBUG]"),info:h.cyan("[INFO]"),warn:h.yellow("[WARN]"),error:h.red("\u274C [ERROR]")}[e]||""}debug(e,t){this._shouldLog("debug")&&console.log(this._formatMessage("debug",e,t))}info(e,t){this._shouldLog("info")&&console.log(this._formatMessage("info",e,t))}warn(e,t){this._shouldLog("warn")&&console.warn(this._formatMessage("warn",e,t))}error(e,t){this._shouldLog("error")&&console.error(this._formatMessage("error",e,t))}setLevel(e){e in u&&(this._level=u[e])}getLevel(){return Object.keys(u).find(e=>u[e]===this._level)}},o=new y;import{timeline as w,Timeline as Q,WORKFLOW_GRAPH_LOG_MARKER_PREFIX as V}from"@zibby/agent-workflow";var $={ASSISTANT:"gpt-5.4-nano-2026-03-17",CLAUDE:"claude-sonnet-4-6",CURSOR:"auto",CODEX:"o4-mini",GEMINI:"gemini-2.5-pro",OPENAI_POSTPROCESSING:"gpt-4o-mini"};var k={auto:"o4-mini","o4-mini":"o4-mini",o3:"o3","o3-mini":"o3-mini","codex-mini":"codex-mini-latest","gpt-4o":"gpt-4o","gpt-4o-mini":"gpt-4o-mini","gpt-5.2-codex":"gpt-5.2-codex","gpt-5.2":"gpt-5.2","gpt-5.3":"gpt-5.3","gpt-5.4":"gpt-5.4"};var ee={CURSOR_AGENT_DEFAULT:1200*1e3,OPENAI_REQUEST:18e4};function D(p){let e=`${p}_POOL`,t=process.env[e];if(!t||typeof t!="string")return{picked:null,count:0,dispose:()=>{}};let r=t.split(/[,\n]+/).map(n=>n.trim()).filter(Boolean);if(r.length===0)return{picked:null,count:0,dispose:()=>{}};let l=r[Math.floor(Math.random()*r.length)],s=process.env[p];return process.env[p]=l,o.debug(`[auth-pool] ${p}: picked 1 of ${r.length} from pool (***${l.slice(-4)})`),{picked:l,count:r.length,dispose(){s===void 0?delete process.env[p]:process.env[p]=s}}}var T=class extends G{constructor(){super("codex","Codex (OpenAI)",75)}canHandle(e){if(!!!(process.env.OPENAI_API_KEY||process.env.OPENAI_API_KEY_POOL||process.env.CODEX_API_KEY||process.env.CODEX_API_KEY_POOL))return o.debug("CodexAgentStrategy: OPENAI_API_KEY or CODEX_API_KEY not set"),!1;try{return j("codex --version",{encoding:"utf-8",timeout:5e3,stdio:"pipe"}),!0}catch{return o.warn("[Codex] codex CLI not found. Install: npm install -g @openai/codex"),!1}}async invoke(e,t={}){let{model:r,workspace:l=process.cwd(),schema:s=null,skills:n=null,sessionPath:O=null,nodeName:f=null,timeout:F,config:J={},signal:M=null}=t,R=[D("OPENAI_API_KEY"),D("CODEX_API_KEY")];try{let{Codex:S}=await import("@openai/codex-sdk"),d=r;(!d||d==="auto")&&(o.debug(`Model is '${d||"undefined"}', using default: ${$.CODEX}`),d=$.CODEX);let v=k[d]||d;k[d]&&d!==v&&o.debug(`Mapped model: ${d} \u2192 ${v}`),o.debug(`Invoking Codex SDK with model: ${v}, skills: ${JSON.stringify(n)}`);let x=process.env.CODEX_API_KEY||process.env.OPENAI_API_KEY;x&&!process.env.CODEX_API_KEY&&(process.env.CODEX_API_KEY=x);let K=x?` | key: ***${x.slice(-4)}`:" | key: not set";console.log(`
2
- \u25C6 Model: ${v}${K}
3
- `);let A=(await import("chalk")).default;console.log(`
4
- ${A.bold("Prompt sent to LLM:")}`),console.log(A.dim("\u2500".repeat(60))),console.log(A.dim(e)),console.log(A.dim("\u2500".repeat(60)));let I=this._resolveSkillsToMcp(n,{sessionPath:O,workspace:l,nodeName:f}),C={};Object.keys(I).length>0&&(C.mcp_servers=I,o.debug(`[Codex] MCP servers: ${Object.keys(I).join(", ")}`));let U=new S({...Object.keys(C).length>0&&{config:C}}).startThread({workingDirectory:l,skipGitRepoCheck:!0,approvalPolicy:"never",sandboxMode:"danger-full-access",networkAccessEnabled:!0}),b=s&&typeof s.parse=="function",N={};if(s)try{let i=b?B(s,{target:"openAi"}):s;N.outputSchema=i,o.debug("Structured output via SDK outputSchema")}catch(i){o.warn(`[Codex] Schema conversion failed, will extract from text: ${i.message}`)}if(M?.aborted){let i=new Error("Aborted via signal");throw i.name="AbortError",i}try{let{events:i}=await U.runStreamed(e,N),m=0,a="";for await(let g of i){if(M?.aborted){let c=new Error("Aborted via signal");throw c.name="AbortError",c}let _=g.type;if(_==="item.completed"){let c=g.item,E=c?.type;if(E==="mcp_tool_call"){m++;let L=`${c.server}/${c.tool}`;if(w.stepTool(`Tool: ${L}`),c.arguments){let P=JSON.stringify(c.arguments),Y=P.length>100?`${P.substring(0,100)}...`:P;console.log(` Input: ${Y}`)}}else if(E==="tool_call"||E==="function_call"||E==="command_execution"){m++;let L=c.name||c.tool||c.command||"unknown";w.stepTool(`Tool: ${L}`)}else E==="agent_message"&&(a=c.text||"",a.length<500?console.log(a):console.log(`${a.substring(0,200)}... (${a.length} chars)`))}else _==="turn.completed"?o.debug(`[Codex] Turn completed. Usage: ${JSON.stringify(g.usage||{})}`):o.debug(`[Codex] Event: ${_} ${JSON.stringify(g).slice(0,300)}`)}if(o.debug(`[Codex] Last agent message (${a.length} chars): ${a.slice(0,500)}`),s){if(!a)throw new Error("Codex agent returned no response");let g=JSON.parse(a),_=b?s.parse(g):g;return o.debug("\u2705 [Codex] Structured output validated"),{raw:a,structured:_}}return a||""}catch(i){let m=i.message||String(i);throw o.error(`\u274C [Codex] SDK call failed: ${m}`),m.includes("exited with code")&&(o.error("\u{1F4A1} [Codex] Verify: codex --version && echo $OPENAI_API_KEY"),o.error("\u{1F4A1} [Codex] If codex is missing: npm install -g @openai/codex")),i}}finally{for(let S of R)S.dispose()}}_resolveSkillsToMcp(e,t={}){if(!Array.isArray(e)||e.length===0)return{};let r={};for(let l of e){let s=X(l);if(!s){o.warn(`[Codex] Unknown skill "${l}" \u2014 skipping`);continue}if(typeof s.resolve!="function")continue;let n=s.resolve(t);if(!n)continue;let O=s.serverName||l,f={command:n.command};n.args?.length&&(f.args=n.args),n.env&&Object.keys(n.env).length>0&&(f.env=n.env),r[O]=f,o.debug(`[Codex] MCP: ${O} \u2192 ${n.command} ${(n.args||[]).join(" ")}`)}return r}};export{T as CodexAgentStrategy};
1
+ import{AgentStrategy as X,getSkill as F}from"@zibby/agent-workflow";import{execSync as j}from"node:child_process";import{zodToJsonSchema as B}from"zod-to-json-schema";import y from"chalk";var u={debug:0,info:1,warn:2,error:3,silent:4},A=class{constructor(){this._level=this._getLogLevel()}_getLogLevel(){if(process.env.ZIBBY_DEBUG==="true")return u.debug;if(process.env.ZIBBY_VERBOSE==="true")return u.info;let e=process.env.LOG_LEVEL?.toLowerCase();return e&&e in u?u[e]:u.info}_shouldLog(e){return u[e]>=this._level}_formatMessage(e,o,l={}){let c=new Date().toISOString(),a=`${this._getPrefix(e)} ${o}`;return Object.keys(l).length>0&&(a+=y.dim(` ${JSON.stringify(l)}`)),a}_getPrefix(e){return{debug:y.gray("[DEBUG]"),info:y.cyan("[INFO]"),warn:y.yellow("[WARN]"),error:y.red("\u274C [ERROR]")}[e]||""}debug(e,o){this._shouldLog("debug")&&console.log(this._formatMessage("debug",e,o))}info(e,o){this._shouldLog("info")&&console.log(this._formatMessage("info",e,o))}warn(e,o){this._shouldLog("warn")&&console.warn(this._formatMessage("warn",e,o))}error(e,o){this._shouldLog("error")&&console.error(this._formatMessage("error",e,o))}setLevel(e){e in u&&(this._level=u[e])}getLevel(){return Object.keys(u).find(e=>u[e]===this._level)}},n=new A;import{timeline as L,Timeline as ee,WORKFLOW_GRAPH_LOG_MARKER_PREFIX as oe}from"@zibby/agent-workflow";var U=[{alias:"auto",canonicalId:"claude-sonnet-4-6",vendor:"claude",label:"Claude \xB7 Sonnet 4.6",family:"claude-sonnet-4",pickerVisible:!0,isDefault:!0},{alias:"opus-4.8",canonicalId:"claude-opus-4-8",vendor:"claude",label:"Claude \xB7 Opus 4.8",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-8",canonicalId:"claude-opus-4-8",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.8"},{alias:"sonnet-4.8",canonicalId:"claude-sonnet-4-8",vendor:"claude",label:"Claude \xB7 Sonnet 4.8",family:"claude-sonnet-4",pickerVisible:!0},{alias:"sonnet-4-8",canonicalId:"claude-sonnet-4-8",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.8"},{alias:"opus-4.7",canonicalId:"claude-opus-4-7",vendor:"claude",label:"Claude \xB7 Opus 4.7",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-7",canonicalId:"claude-opus-4-7",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.7"},{alias:"sonnet-4.7",canonicalId:"claude-sonnet-4-7",vendor:"claude",label:"Claude \xB7 Sonnet 4.7",family:"claude-sonnet-4",pickerVisible:!0},{alias:"sonnet-4-7",canonicalId:"claude-sonnet-4-7",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.7"},{alias:"sonnet-4.6",canonicalId:"claude-sonnet-4-6",vendor:"claude",family:"claude-sonnet-4",aliasOf:"auto"},{alias:"sonnet-4-6",canonicalId:"claude-sonnet-4-6",vendor:"claude",family:"claude-sonnet-4",aliasOf:"auto"},{alias:"opus-4.6",canonicalId:"claude-opus-4-6",vendor:"claude",label:"Claude \xB7 Opus 4.6",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-6",canonicalId:"claude-opus-4-6",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.6"},{alias:"sonnet-4.5",canonicalId:"claude-sonnet-4-5-20250929",vendor:"claude",label:"Claude \xB7 Sonnet 4.5",family:"claude-sonnet-4",pickerVisible:!0},{alias:"sonnet-4-5",canonicalId:"claude-sonnet-4-5-20250929",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.5"},{alias:"opus-4.5",canonicalId:"claude-opus-4-5-20251101",vendor:"claude",label:"Claude \xB7 Opus 4.5",family:"claude-opus-4",pickerVisible:!0},{alias:"opus-4-5",canonicalId:"claude-opus-4-5-20251101",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.5"},{alias:"haiku-4.5",canonicalId:"claude-haiku-4-5-20251001",vendor:"claude",label:"Claude \xB7 Haiku 4.5",family:"claude-haiku-4"},{alias:"haiku-4-5",canonicalId:"claude-haiku-4-5-20251001",vendor:"claude",family:"claude-haiku-4",aliasOf:"haiku-4.5"},{alias:"claude-opus-4-8",canonicalId:"claude-opus-4-8",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.8"},{alias:"claude-sonnet-4-8",canonicalId:"claude-sonnet-4-8",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.8"},{alias:"claude-opus-4-7",canonicalId:"claude-opus-4-7",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.7"},{alias:"claude-sonnet-4-7",canonicalId:"claude-sonnet-4-7",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.7"},{alias:"claude-sonnet-4-6",canonicalId:"claude-sonnet-4-6",vendor:"claude",family:"claude-sonnet-4",aliasOf:"auto"},{alias:"claude-opus-4-6",canonicalId:"claude-opus-4-6",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.6"},{alias:"claude-sonnet-4-5-20250929",canonicalId:"claude-sonnet-4-5-20250929",vendor:"claude",family:"claude-sonnet-4",aliasOf:"sonnet-4.5"},{alias:"claude-opus-4-5-20251101",canonicalId:"claude-opus-4-5-20251101",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.5"},{alias:"claude-haiku-4-5-20251001",canonicalId:"claude-haiku-4-5-20251001",vendor:"claude",family:"claude-haiku-4",aliasOf:"haiku-4.5"},{alias:"claude-opus-4-20250514",canonicalId:"claude-opus-4-20250514",vendor:"claude",family:"claude-opus-4",aliasOf:"opus-4.5"},{alias:"auto",canonicalId:"o4-mini",vendor:"codex",label:"Codex \xB7 o4-mini",family:"o4-mini",isDefault:!0},{alias:"o4-mini",canonicalId:"o4-mini",vendor:"codex",label:"Codex \xB7 o4-mini",family:"o4-mini",pickerVisible:!0},{alias:"o3",canonicalId:"o3",vendor:"codex",family:"o3"},{alias:"o3-mini",canonicalId:"o3-mini",vendor:"codex",family:"o3-mini"},{alias:"codex-mini",canonicalId:"codex-mini-latest",vendor:"codex",family:"codex-mini"},{alias:"gpt-4o",canonicalId:"gpt-4o",vendor:"codex",label:"Codex \xB7 GPT-4o",family:"gpt-4o",pickerVisible:!0},{alias:"gpt-4o-mini",canonicalId:"gpt-4o-mini",vendor:"codex",label:"Codex \xB7 GPT-4o mini",family:"gpt-4o-mini",pickerVisible:!0},{alias:"gpt-5.2-codex",canonicalId:"gpt-5.2-codex",vendor:"codex",label:"Codex \xB7 GPT-5.2",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.2",canonicalId:"gpt-5.2",vendor:"codex",label:"Codex \xB7 GPT-5.2 base",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.3",canonicalId:"gpt-5.3",vendor:"codex",label:"Codex \xB7 GPT-5.3",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.3-codex",canonicalId:"gpt-5.3-codex",vendor:"codex",family:"gpt-5"},{alias:"gpt-5.4",canonicalId:"gpt-5.4",vendor:"codex",label:"Codex \xB7 GPT-5.4",family:"gpt-5",pickerVisible:!0},{alias:"gpt-5.5",canonicalId:"gpt-5.5",vendor:"codex",label:"Codex \xB7 GPT-5.5",family:"gpt-5",pickerVisible:!0},{alias:"auto",canonicalId:"gemini-3-pro",vendor:"gemini",label:"Gemini \xB7 3 Pro",family:"gemini-3",isDefault:!0},{alias:"gemini-3-pro",canonicalId:"gemini-3-pro",vendor:"gemini",label:"Gemini \xB7 3 Pro",family:"gemini-3",pickerVisible:!0},{alias:"gemini-3-flash",canonicalId:"gemini-3-flash",vendor:"gemini",label:"Gemini \xB7 3 Flash",family:"gemini-3",pickerVisible:!0},{alias:"gemini-2.5-pro",canonicalId:"gemini-2.5-pro",vendor:"gemini",label:"Gemini \xB7 2.5 Pro",family:"gemini-2.5",pickerVisible:!0},{alias:"gemini-2.5-flash",canonicalId:"gemini-2.5-flash",vendor:"gemini",label:"Gemini \xB7 2.5 Flash",family:"gemini-2.5",pickerVisible:!0}];function E(d){let e={};for(let o of U)o.vendor===d&&(e[o.alias]=o.canonicalId);return e}var w={ASSISTANT:"gpt-5.4-nano-2026-03-17",CLAUDE:"claude-sonnet-4-6",CURSOR:"auto",CODEX:"o4-mini",GEMINI:"gemini-3-pro",OPENAI_POSTPROCESSING:"gpt-4o-mini"};var ie=E("claude"),$=E("codex"),le=E("gemini"),se={CURSOR_AGENT_DEFAULT:1200*1e3,OPENAI_REQUEST:18e4};function M(d){let e=`${d}_POOL`,o=process.env[e];if(!o||typeof o!="string")return{picked:null,count:0,dispose:()=>{}};let l=o.split(/[,\n]+/).map(a=>a.trim()).filter(Boolean);if(l.length===0)return{picked:null,count:0,dispose:()=>{}};let c=l[Math.floor(Math.random()*l.length)],i=process.env[d];return process.env[d]=c,n.debug(`[auth-pool] ${d}: picked 1 of ${l.length} from pool (***${c.slice(-4)})`),{picked:c,count:l.length,dispose(){i===void 0?delete process.env[d]:process.env[d]=i}}}var N=class extends X{constructor(){super("codex","Codex (OpenAI)",75)}canHandle(e){if(!!!(process.env.OPENAI_API_KEY||process.env.OPENAI_API_KEY_POOL||process.env.CODEX_API_KEY||process.env.CODEX_API_KEY_POOL))return n.debug("CodexAgentStrategy: OPENAI_API_KEY or CODEX_API_KEY not set"),!1;try{return j("codex --version",{encoding:"utf-8",timeout:5e3,stdio:"pipe"}),!0}catch{return n.warn("[Codex] codex CLI not found. Install: npm install -g @openai/codex"),!1}}async invoke(e,o={}){let{model:l,workspace:c=process.cwd(),schema:i=null,skills:a=null,sessionPath:O=null,nodeName:m=null,timeout:J,config:W={},signal:D=null}=o,R=[M("OPENAI_API_KEY"),M("CODEX_API_KEY")];try{let{Codex:b}=await import("@openai/codex-sdk"),p=l;(!p||p==="auto")&&(n.debug(`Model is '${p||"undefined"}', using default: ${w.CODEX}`),p=w.CODEX);let x=$[p]||p;$[p]&&p!==x&&n.debug(`Mapped model: ${p} \u2192 ${x}`),n.debug(`Invoking Codex SDK with model: ${x}, skills: ${JSON.stringify(a)}`);let _=process.env.CODEX_API_KEY||process.env.OPENAI_API_KEY;_&&!process.env.CODEX_API_KEY&&(process.env.CODEX_API_KEY=_);let V=_?` | key: ***${_.slice(-4)}`:" | key: not set";console.log(`
2
+ \u25C6 Model: ${x}${V}
3
+ `);let h=(await import("chalk")).default;console.log(`
4
+ ${h.bold("Prompt sent to LLM:")}`),console.log(h.dim("\u2500".repeat(60))),console.log(h.dim(e)),console.log(h.dim("\u2500".repeat(60)));let k=this._resolveSkillsToMcp(a,{sessionPath:O,workspace:c,nodeName:m}),C={};Object.keys(k).length>0&&(C.mcp_servers=k,n.debug(`[Codex] MCP servers: ${Object.keys(k).join(", ")}`));let K=new b({...Object.keys(C).length>0&&{config:C}}).startThread({workingDirectory:c,skipGitRepoCheck:!0,approvalPolicy:"never",sandboxMode:"danger-full-access",networkAccessEnabled:!0}),T=i&&typeof i.parse=="function",G={};if(i)try{let s=T?B(i,{target:"openAi"}):i;G.outputSchema=s,n.debug("Structured output via SDK outputSchema")}catch(s){n.warn(`[Codex] Schema conversion failed, will extract from text: ${s.message}`)}if(D?.aborted){let s=new Error("Aborted via signal");throw s.name="AbortError",s}try{let{events:s}=await K.runStreamed(e,G),g=0,r="";for await(let f of s){if(D?.aborted){let t=new Error("Aborted via signal");throw t.name="AbortError",t}let v=f.type;if(v==="item.completed"){let t=f.item,I=t?.type;if(I==="mcp_tool_call"){g++;let P=`${t.server}/${t.tool}`;if(L.stepTool(`Tool: ${P}`),t.arguments){let S=JSON.stringify(t.arguments),Y=S.length>100?`${S.substring(0,100)}...`:S;console.log(` Input: ${Y}`)}}else if(I==="tool_call"||I==="function_call"||I==="command_execution"){g++;let P=t.name||t.tool||t.command||"unknown";L.stepTool(`Tool: ${P}`)}else I==="agent_message"&&(r=t.text||"",r.length<500?console.log(r):console.log(`${r.substring(0,200)}... (${r.length} chars)`))}else v==="turn.completed"?n.debug(`[Codex] Turn completed. Usage: ${JSON.stringify(f.usage||{})}`):n.debug(`[Codex] Event: ${v} ${JSON.stringify(f).slice(0,300)}`)}if(n.debug(`[Codex] Last agent message (${r.length} chars): ${r.slice(0,500)}`),i){if(!r)throw new Error("Codex agent returned no response");let f=JSON.parse(r),v=T?i.parse(f):f;return n.debug("\u2705 [Codex] Structured output validated"),{raw:r,structured:v}}return r||""}catch(s){let g=s.message||String(s);throw n.error(`\u274C [Codex] SDK call failed: ${g}`),g.includes("exited with code")&&(n.error("\u{1F4A1} [Codex] Verify: codex --version && echo $OPENAI_API_KEY"),n.error("\u{1F4A1} [Codex] If codex is missing: npm install -g @openai/codex")),s}}finally{for(let b of R)b.dispose()}}_resolveSkillsToMcp(e,o={}){if(!Array.isArray(e)||e.length===0)return{};let l={};for(let c of e){let i=F(c);if(!i){n.warn(`[Codex] Unknown skill "${c}" \u2014 skipping`);continue}if(typeof i.resolve!="function")continue;let a=i.resolve(o);if(!a)continue;let O=i.serverName||c,m={command:a.command};a.args?.length&&(m.args=a.args),a.env&&Object.keys(a.env).length>0&&(m.env=a.env),l[O]=m,n.debug(`[Codex] MCP: ${O} \u2192 ${a.command} ${(a.args||[]).join(" ")}`)}return l}};export{N as CodexAgentStrategy};