agent-afk 3.48.0 → 3.50.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.mjs +4 -4
- package/dist/index.mjs +3 -3
- package/dist/telegram.mjs +3 -3
- package/package.json +1 -1
package/dist/cli.mjs
CHANGED
|
@@ -1169,7 +1169,7 @@ ${t.replace(/<\/?cross-session-memory\b[^>]*>/gi,"")}
|
|
|
1169
1169
|
|
|
1170
1170
|
${o}`};if(o&&typeof o=="object"&&"type"in o&&o.type==="preset"){let s=o.append??"";return{...e,systemPrompt:{...o,append:`${r}
|
|
1171
1171
|
|
|
1172
|
-
${s}`}}}return{...e,systemPrompt:r}}function $u(e,t="cli"){return n=>{if(n.event!=="SessionEnd")return{};try{let r=n.sessionId;r&&(e.startSession({session_id:r,surface:t}),e.endSession(r,n.reason??"session ended","completed"))}catch{}return{}}}import hP from"openai";import{randomUUID as yP}from"node:crypto";function rs(e,t){let n=(d,p)=>{if(!(d==null&&p==null))return(d??0)+(p??0)},r=(d,p)=>p!==void 0?p:d,o={stopReason:t.stopReason??e.stopReason??null},s=n(e.inputTokens,t.inputTokens);s!==void 0&&(o.inputTokens=s);let i=n(e.outputTokens,t.outputTokens);i!==void 0&&(o.outputTokens=i);let a=r(e.cachedInputTokens,t.cachedInputTokens);a!==void 0&&(o.cachedInputTokens=a);let l=r(e.cacheCreationTokens,t.cacheCreationTokens);l!==void 0&&(o.cacheCreationTokens=l);let c=n(e.totalTokens,t.totalTokens);c!==void 0&&(o.totalTokens=c);let u=n(e.totalCostUsd,t.totalCostUsd);return u!==void 0&&(o.totalCostUsd=u),o}var Sh={opus:128e3,opus_1m:128e3,sonnet:64e3,sonnet_1m:64e3,haiku:64e3,"claude-opus-4-
|
|
1172
|
+
${s}`}}}return{...e,systemPrompt:r}}function $u(e,t="cli"){return n=>{if(n.event!=="SessionEnd")return{};try{let r=n.sessionId;r&&(e.startSession({session_id:r,surface:t}),e.endSession(r,n.reason??"session ended","completed"))}catch{}return{}}}import hP from"openai";import{randomUUID as yP}from"node:crypto";function rs(e,t){let n=(d,p)=>{if(!(d==null&&p==null))return(d??0)+(p??0)},r=(d,p)=>p!==void 0?p:d,o={stopReason:t.stopReason??e.stopReason??null},s=n(e.inputTokens,t.inputTokens);s!==void 0&&(o.inputTokens=s);let i=n(e.outputTokens,t.outputTokens);i!==void 0&&(o.outputTokens=i);let a=r(e.cachedInputTokens,t.cachedInputTokens);a!==void 0&&(o.cachedInputTokens=a);let l=r(e.cacheCreationTokens,t.cacheCreationTokens);l!==void 0&&(o.cacheCreationTokens=l);let c=n(e.totalTokens,t.totalTokens);c!==void 0&&(o.totalTokens=c);let u=n(e.totalCostUsd,t.totalCostUsd);return u!==void 0&&(o.totalCostUsd=u),o}var Sh={opus:128e3,opus_1m:128e3,sonnet:64e3,sonnet_1m:64e3,haiku:64e3,"claude-opus-4-8":128e3,"claude-sonnet-4-6":64e3,"claude-haiku-4-5-20251001":64e3},iP=64e3;function Du(e){return Sh[e]??iP}var os={opus:2e5,opus_1m:1e6,sonnet:2e5,sonnet_1m:1e6,haiku:2e5,"gpt-4o":128e3,"gpt-4o-mini":128e3,"gpt-4.1":1e6,"gpt-4.1-mini":1e6,o1:2e5,"o1-mini":128e3,o3:2e5,"o3-mini":2e5,"o4-mini":2e5,"mlx-community/qwen3-30b-a3b-4bit":128e3,"mlx-community/qwen3-32b-4bit":128e3,"mlx-community/qwen2.5-coder-32b-instruct-4bit":131072},aP=2e5,lP=262144;function cP(e){if(!e)return!1;let t=e.trim().toLowerCase();return t?!!(t.includes("/")||t.startsWith("gpt-")||t.startsWith("gpt_")||t.startsWith("o1")||t.startsWith("o3")||t.startsWith("o4")||t.startsWith("codex-")||t.startsWith("codex_")||t==="codex"):!1}function nt(e){let t=os[e]??os[e.toLowerCase()];return t!==void 0?t:cP(e)?lP:aP}import{readFileSync as uP}from"node:fs";import{homedir as dP}from"node:os";import{join as pP}from"node:path";function mP(e){try{return uP(e,"utf-8")}catch{return null}}function ss(e,t={}){let n=t.readEnv??(l=>process.env[l]),r=(t.homedir??dP)(),o=t.readFile??mP;if(e&&e.length>0)return{apiKey:e,source:"config",last4:Lu(e)};let s=n("OPENAI_API_KEY");if(s&&s.length>0)return{apiKey:s,source:"env",last4:Lu(s)};let i=pP(r,".codex","auth.json"),a=o(i);if(a!==null){let l=fP(a);if(l.kind==="apikey")return{apiKey:l.apiKey,source:"codex-cli",last4:Lu(l.apiKey)};if(l.kind==="chatgpt")return{apiKey:null,source:"no-usable-auth-codex-oauth"}}return{apiKey:null,source:"no-usable-auth"}}function fP(e){let t;try{t=JSON.parse(e)}catch{return{kind:"invalid"}}if(typeof t!="object"||t===null)return{kind:"invalid"};let n=t,r=n.OPENAI_API_KEY;return typeof r=="string"&&r.length>0?{kind:"apikey",apiKey:r}:n.auth_mode==="chatgpt"?{kind:"chatgpt"}:{kind:"no-key"}}function Lu(e){return e.length<=4?e:e.slice(-4)}function is(e){switch(e.source){case"config":return`using explicit AFK config API key (\u2026${e.last4??"????"})`;case"env":return`using OPENAI_API_KEY env var (\u2026${e.last4??"????"})`;case"codex-cli":return`using Codex CLI API key from ~/.codex/auth.json (\u2026${e.last4??"????"})`;case"no-usable-auth-codex-oauth":return"AFK OpenAI provider currently requires API key auth. Found ChatGPT/OAuth credentials in ~/.codex/auth.json but no API key. Run `codex login --api-key` or set OPENAI_API_KEY.";default:return"No OpenAI auth found. Set OPENAI_API_KEY, pass an explicit apiKey in AFK config, or run `codex login --api-key`."}}function kh(e){return typeof e=="string"?e:e.map(t=>{if(typeof t=="object"&&t&&"type"in t){if(t.type==="text")return t.text;if(t.type==="image")return"[image omitted]"}return""}).join(`
|
|
1173
1173
|
`)}function gP(e){let t=e.systemPrompt;if(t!==void 0){if(typeof t=="string")return t.length>0?t:void 0;if(typeof t=="object"&&t!==null&&"append"in t){let n=t.append;return n&&n.length>0?n:void 0}}}function vh(e){let t=[],n=gP(e.config);if(n!==void 0&&t.push({role:"system",content:n}),e.resumeHistory)for(let r of e.resumeHistory)r.user&&t.push({role:"user",content:r.user}),r.assistant&&t.push({role:"assistant",content:r.assistant});if(e.priorTurns)for(let r of e.priorTurns)t.push(r);return e.currentUserText!==void 0&&t.push({role:"user",content:e.currentUserText}),t}function Th(){return{assistantText:"",reasoningText:"",toolCallsByIndex:new Map,finishReason:null,usage:null,model:null,id:null}}function*Eh(e,t,n){e.id&&!t.id&&(t.id=e.id),e.model&&!t.model&&(t.model=e.model),e.usage&&(t.usage=e.usage);let r=e.choices?.[0];if(!r)return;r.finish_reason&&(t.finishReason=r.finish_reason);let o=r.delta;if(!o)return;let s=o.reasoning_content??o.reasoning;if(typeof s=="string"&&s.length>0&&(t.reasoningText+=s,yield{type:"delta.reasoning",text:s,sessionId:n}),typeof o.content=="string"&&o.content.length>0&&(t.assistantText+=o.content,yield{type:"delta.text",text:o.content,sessionId:n}),o.tool_calls&&o.tool_calls.length>0)for(let i of o.tool_calls){let a=t.toolCallsByIndex.get(i.index)??{index:i.index,id:"",name:"",argumentsRaw:"",startEmitted:!1};i.id&&(a.id=i.id),i.function?.name&&(a.name=i.function.name),i.function?.arguments&&(a.argumentsRaw+=i.function.arguments),t.toolCallsByIndex.set(i.index,a)}}function xh(e){let t=e.usage;if(!t)return{stopReason:e.finishReason??null,resultSubtype:"success",isError:!1};let n=t.prompt_tokens_details?.cached_tokens??0,r=t.prompt_tokens??0,o=t.completion_tokens??0;return{inputTokens:r,outputTokens:o,cachedInputTokens:n,totalTokens:t.total_tokens??r+o,stopReason:e.finishReason??null,resultSubtype:"success",isError:!1,raw:{...t}}}function Fu(e){return[...e.toolCallsByIndex.values()].sort((t,n)=>t.index-n.index)}function Rh(e){return e.finishReason==="tool_calls"||e.finishReason==="function_call"?!0:e.toolCallsByIndex.size>0}function Ah(e){return e.map(t=>{let n={name:t.name,parameters:t.input_schema};return t.description!==void 0&&(n.description=t.description),{type:"function",function:n}})}function _h(e,t){let n=[],r=new Map;for(let o of e){let s={};if(o.argumentsRaw.length>0)try{s=JSON.parse(o.argumentsRaw)}catch(i){let a=i instanceof Error?i.message:String(i);r.set(o.id,`Failed to parse tool arguments as JSON: ${a}`),s={}}n.push({id:o.id,name:o.name,input:s,signal:t})}return{calls:n,parseErrors:r}}function Ch(e,t,n=""){let r={role:"assistant",content:e.length>0?e:null,tool_calls:t.map(o=>({id:o.id,type:"function",function:{name:o.name,arguments:o.argumentsRaw}}))};return n.length>0&&(r.reasoning_content=n),r}function Ih(e){return e.map(({call:t,result:n})=>({role:"tool",tool_call_id:t.id,content:n.isError?`[error] ${n.content}`:n.content}))}function as(e){return(e.inputTokens??0)+(e.outputTokens??0)}function Ph(e,t,n){return t<=0||e<=0||n<=0||n>=1?!1:e/t>=n}var Nu="openai-compatible",bP=50,wP=null;function Mh(e){return e??"default"}var zi=class{client;opts;initSessionId;toolDispatcher;openAITools;priorTurns=[];currentModel;currentPermissionMode;abortController=null;pendingAbortReason=null;closed=!1;closeResolve=null;closedPromise;lastUsage=null;constructor(t){if(this.opts=t,this.initSessionId=t.synthesizedSessionId,this.currentModel=t.model,this.currentPermissionMode=Mh(t.config.permissionMode),this.toolDispatcher=t.toolDispatcher,this.toolDispatcher){let n=this.toolDispatcher;Array.isArray(n.toolDefs)&&n.toolDefs.length>0&&(this.openAITools=Ah(n.toolDefs))}if(t.auth.apiKey===null)this.client=null;else{let n=wP??SP,r={apiKey:t.auth.apiKey};t.baseURL!==void 0&&(r.baseURL=t.baseURL),this.client=n(r)}this.closedPromise=new Promise(n=>{this.closeResolve=()=>n("__closed__")})}async*[Symbol.asyncIterator](){if(yield{type:"session.init",info:{sessionId:this.initSessionId,model:this.currentModel,permissionMode:this.currentPermissionMode,cwd:process.cwd(),tools:this.openAITools?this.openAITools.map(r=>r.function.name):[],slashCommands:[],skills:[],plugins:[],mcpServers:this.opts.mcpManager?.getServerStates().map(r=>({name:r.serverName,status:r.status}))??[],apiKeySource:this.opts.auth.source,version:Nu}},this.opts.auth.apiKey===null){yield{type:"error",error:new Error(is(this.opts.auth))};return}let n=this.opts.promptStream[Symbol.asyncIterator]();try{for(;!this.closed;){let r=await Promise.race([n.next(),this.closedPromise]);if(r==="__closed__")break;let o=r;if(o.done)break;let s=kh(o.value.content);yield*this.runTurn(s)}}catch(r){yield{type:"error",error:r instanceof Error?r:new Error(String(r))}}finally{try{await n.return?.()}catch{}}}async*runTurn(t){let n=new AbortController;if(this.abortController=n,this.pendingAbortReason!==null&&!n.signal.aborted&&(n.abort(this.pendingAbortReason),this.pendingAbortReason=null),n.signal.aborted)return;let r=Date.now(),o=yP();this.priorTurns.push({role:"user",content:t});let s={stopReason:null,resultSubtype:"success",isError:!1},i="",a="";for(let l=0;l<bP;l++){if(n.signal.aborted){this.abortController===n&&(this.abortController=null);return}let c=yield*this.runIteration(n);if(c===null){this.abortController===n&&(this.abortController=null);return}if(s=rs(s,xh(c.state)),c.text.length>0&&(i=c.text),a=c.state.reasoningText,!c.needsToolDispatch)break;yield*this.dispatchAndAppend(c.state,n.signal);{let u=Fu(c.state).at(-1)?.name;yield{type:"progress",progress:{taskId:o,description:"Tool-use loop",summary:`Iteration ${l+1}: used ${u??"unknown"}`,lastToolName:u,totalTokens:s.totalTokens??0,toolUses:l+1,durationMs:Date.now()-r},sessionId:this.initSessionId}}if(n.signal.aborted){this.abortController===n&&(this.abortController=null);return}}if(this.abortController===n&&(this.abortController=null),i.length>0){let l={role:"assistant",content:i};a.length>0&&(l.reasoning_content=a),this.priorTurns.push(l)}this.lastUsage=s,yield{type:"assistant.message",text:i,sessionId:this.initSessionId},yield{type:"turn.completed",usage:{...s,durationMs:Date.now()-r},sessionId:this.initSessionId}}async*runIteration(t){let n=vh({config:this.opts.config,...this.opts.config.resumeHistory!==void 0?{resumeHistory:this.opts.config.resumeHistory}:{},priorTurns:this.priorTurns});this.currentPermissionMode==="plan"&&n[0]?.role==="system"&&(n[0]={...n[0],content:n[0].content+`
|
|
1174
1174
|
|
|
1175
1175
|
`+eu});let r=Th(),o={model:this.currentModel,messages:n,stream:!0,stream_options:{include_usage:!0}};this.openAITools&&this.openAITools.length>0&&(o.tools=this.openAITools);let s;try{s=await this.client.chat.completions.create(o,{signal:t.signal})}catch(i){return t.signal.aborted||(yield{type:"error",error:i instanceof Error?i:new Error(String(i))}),null}try{for await(let i of s){if(this.closed)return null;for(let a of Eh(i,r,this.initSessionId))yield a}}catch(i){return t.signal.aborted||(yield{type:"error",error:i instanceof Error?i:new Error(String(i))}),null}return{state:r,events:[],text:r.assistantText,needsToolDispatch:Rh(r)&&r.toolCallsByIndex.size>0}}async*dispatchAndAppend(t,n){if(!this.toolDispatcher)return;let r=Fu(t),{calls:o,parseErrors:s}=_h(r,n);for(let a of o)yield{type:"tool.use.start",toolUseId:a.id,toolName:a.name,toolInput:kP(a.input),sessionId:this.initSessionId};let i=[];if(n.aborted)for(let a of o){let l={content:"Tool call aborted",isError:!0};i.push({call:a,result:l}),yield{type:"tool.output",toolUseId:a.id,toolName:a.name,content:l.content,isError:!0,sessionId:this.initSessionId}}else{let a;try{if(this.toolDispatcher.executeBatch)a=await this.toolDispatcher.executeBatch(o);else{a=[];for(let l of o){if(n.aborted){a.push({content:"Tool call aborted",isError:!0});continue}try{a.push(await this.toolDispatcher.execute(l))}catch(c){let u=c instanceof Error?c.message:String(c);a.push({content:`Tool execution threw: ${u}`,isError:!0})}}}}catch(l){let c=l instanceof Error?l.message:String(l);a=o.map(()=>({content:`Tool batch execution failed: ${c}`,isError:!0}))}for(let l=0;l<o.length;l++){let c=o[l],u=a[l],d=s.get(c.id);d!==void 0&&(u={content:`${d}
|
|
@@ -1586,7 +1586,7 @@ Be skeptical. Protect the plugin from fluff. Stage 2 catches patterns that are s
|
|
|
1586
1586
|
|
|
1587
1587
|
${h}`);if(I.status!=="succeeded")throw new Error(`skill generation failed: ${xe(I)}`);let R=I.message?.content||"";if(!R)throw new Error("skill generation returned no output");for(let C=1;C<=l;C++){let O=ed.systemPrompt;if(!O)throw new Error("qualify agent missing system prompt");let A=await(await new V({apiKey:r}).forkSubagent({parent:{sessionId:t.sessionId},config:{model:"sonnet",systemPrompt:O},idPrefix:`forge-qualify-${C}`,...o?{parentId:o}:{}})).runToResult(`Evaluate this amplifier skill against the force-multiplier criteria:
|
|
1588
1588
|
|
|
1589
|
-
${R}`);if(A.status!=="succeeded")throw new Error(`qualify iteration ${C} failed: ${xe(A)}`);let P=A.message?.content||"",{verdict:N,score:K,feedback:q}=Oy(P),D={iteration:C,verdict:N,score:K,feedback:q};if(u.push(D),c=await ze({event:"forge.qualify_iteration",iteration:C,verdict:N,score:K||null,feedback:q||null}),N==="APPROVE"){d="APPROVED";break}else if(N==="SALVAGE"&&C<l){let F=w["qualify-rework.md"];if(!F)throw new Error("forge skill missing qualify-rework.md prompt");let W=F.replace("{feedback}",q).replace("{original_skill}",R),L=await(await new V({apiKey:r}).forkSubagent({parent:{sessionId:t.sessionId},config:{model:"sonnet",systemPrompt:W},idPrefix:`forge-rework-${C}`,...o?{parentId:o}:{}})).runToResult("Refine the skill based on the feedback.");if(L.status!=="succeeded")throw new Error(`rework iteration ${C} failed: ${xe(L)}`);if(R=L.message?.content||"",!R)throw new Error(`rework iteration ${C} returned no output`)}else N==="REJECT"&&C>=l&&(d="MAX_ITERATIONS")}if(d==="APPROVED"){let C=TM(R);if(!C.ok)throw c=await ze({event:"forge.write_failed",reason:C.reason,skill_name_attempted:C.skillNameAttempted}),new Error(`forge write-step invariant failed (${C.reason}): ${C.message}`);let O=C.skillName,$=C.recoveredContent??R;C.recoveredContent!==void 0&&(c=await ze({event:"forge.preamble_recovered",skill_name:O,bytes_trimmed:R.length-C.recoveredContent.length}));let x=nd(O,{skillsDir:Hn(),registeredSkills:pt()});if(x)throw c=await ze({event:"forge.write_failed",reason:x.reason,skill_name_attempted:x.skillNameAttempted}),new Error(`forge write-step invariant failed (${x.reason}): ${x.message}`);let A=Zt(Hn(),O);await Ly(A,{recursive:!0});let P=Zt(A,"SKILL.md");await Fy(P,$,"utf-8");let N;try{N=await dM(P,"utf-8")}catch{N=""}if(!N.startsWith("---"))throw c=await ze({event:"forge.write_failed",reason:"readback_failed",skill_name_attempted:O}),new Error(`forge write-step invariant failed (readback_failed): written file at ${P} did not read back with expected frontmatter`);p=P,b&&f&&await td(f,"consumed"),c=await ze({event:"forge.complete",status:"APPROVED",skill_name:O,iterations:u.length})}else d==="MAX_ITERATIONS"&&(b&&f&&await td(f,"failed"),c=await ze({event:"forge.complete",status:"MAX_ITERATIONS",skill_name_attempted:h||null,iterations:u.length}))}catch(g){throw c=await ze({event:"forge.error",error:g instanceof Error?g.message:String(g)}),g}return{status:d,skill_path:p,qualify_verdicts:u,brief_id:f,telemetry_ref:c}}var RM={name:"forge",description:'Creates new amplifier skills gated by forge-gate-check, with autonomous gap discovery, skill generation, and qualify iteration loop \u22643\xD7. Writes approved skills and appends telemetry to shared JSONL with surface: "afk".',handler:xM,argumentHint:"[--brief <path>]",whenToUse:"When the user wants to grow the plugin with a new amplifier skill \u2014 autonomously generates and validates one.",flags:["--brief"]};Ze(RM);import{readFileSync as Vy,existsSync as ad}from"fs";import{join as ua}from"path";import{config as WM}from"dotenv";var aa={opus:"claude-opus-4-
|
|
1589
|
+
${R}`);if(A.status!=="succeeded")throw new Error(`qualify iteration ${C} failed: ${xe(A)}`);let P=A.message?.content||"",{verdict:N,score:K,feedback:q}=Oy(P),D={iteration:C,verdict:N,score:K,feedback:q};if(u.push(D),c=await ze({event:"forge.qualify_iteration",iteration:C,verdict:N,score:K||null,feedback:q||null}),N==="APPROVE"){d="APPROVED";break}else if(N==="SALVAGE"&&C<l){let F=w["qualify-rework.md"];if(!F)throw new Error("forge skill missing qualify-rework.md prompt");let W=F.replace("{feedback}",q).replace("{original_skill}",R),L=await(await new V({apiKey:r}).forkSubagent({parent:{sessionId:t.sessionId},config:{model:"sonnet",systemPrompt:W},idPrefix:`forge-rework-${C}`,...o?{parentId:o}:{}})).runToResult("Refine the skill based on the feedback.");if(L.status!=="succeeded")throw new Error(`rework iteration ${C} failed: ${xe(L)}`);if(R=L.message?.content||"",!R)throw new Error(`rework iteration ${C} returned no output`)}else N==="REJECT"&&C>=l&&(d="MAX_ITERATIONS")}if(d==="APPROVED"){let C=TM(R);if(!C.ok)throw c=await ze({event:"forge.write_failed",reason:C.reason,skill_name_attempted:C.skillNameAttempted}),new Error(`forge write-step invariant failed (${C.reason}): ${C.message}`);let O=C.skillName,$=C.recoveredContent??R;C.recoveredContent!==void 0&&(c=await ze({event:"forge.preamble_recovered",skill_name:O,bytes_trimmed:R.length-C.recoveredContent.length}));let x=nd(O,{skillsDir:Hn(),registeredSkills:pt()});if(x)throw c=await ze({event:"forge.write_failed",reason:x.reason,skill_name_attempted:x.skillNameAttempted}),new Error(`forge write-step invariant failed (${x.reason}): ${x.message}`);let A=Zt(Hn(),O);await Ly(A,{recursive:!0});let P=Zt(A,"SKILL.md");await Fy(P,$,"utf-8");let N;try{N=await dM(P,"utf-8")}catch{N=""}if(!N.startsWith("---"))throw c=await ze({event:"forge.write_failed",reason:"readback_failed",skill_name_attempted:O}),new Error(`forge write-step invariant failed (readback_failed): written file at ${P} did not read back with expected frontmatter`);p=P,b&&f&&await td(f,"consumed"),c=await ze({event:"forge.complete",status:"APPROVED",skill_name:O,iterations:u.length})}else d==="MAX_ITERATIONS"&&(b&&f&&await td(f,"failed"),c=await ze({event:"forge.complete",status:"MAX_ITERATIONS",skill_name_attempted:h||null,iterations:u.length}))}catch(g){throw c=await ze({event:"forge.error",error:g instanceof Error?g.message:String(g)}),g}return{status:d,skill_path:p,qualify_verdicts:u,brief_id:f,telemetry_ref:c}}var RM={name:"forge",description:'Creates new amplifier skills gated by forge-gate-check, with autonomous gap discovery, skill generation, and qualify iteration loop \u22643\xD7. Writes approved skills and appends telemetry to shared JSONL with surface: "afk".',handler:xM,argumentHint:"[--brief <path>]",whenToUse:"When the user wants to grow the plugin with a new amplifier skill \u2014 autonomously generates and validates one.",flags:["--brief"]};Ze(RM);import{readFileSync as Vy,existsSync as ad}from"fs";import{join as ua}from"path";import{config as WM}from"dotenv";var aa={opus:"claude-opus-4-8",opus_1m:"claude-opus-4-8",sonnet:"claude-sonnet-4-6",sonnet_1m:"claude-sonnet-4-6",haiku:"claude-haiku-4-5-20251001"};function la(e){return e in aa}function Uy(e){let t=aa[e];if(!t)throw new Error(`Invalid model: ${e}`);return t}function rr(e){if(e!==void 0)return typeof e=="string"&&la(e)?Uy(e):e}j();H();import{execFile as IM}from"node:child_process";import{promisify as PM}from"node:util";import{promises as ms}from"node:fs";import{dirname as od,isAbsolute as MM,join as fs,resolve as OM}from"node:path";import{randomBytes as $M}from"node:crypto";H();import{basename as jy}from"node:path";function AM(e){return`# >>> afk shell-init >>>
|
|
1590
1590
|
# Auto-cd into a preserved worktree after \`afk\` exits.
|
|
1591
1591
|
# REQUIRES: bash or zsh. Uses \`local\` (also works in dash/ash but
|
|
1592
1592
|
# breaks in ksh93). For fish, use \`afk shell-init fish | source\`.
|
|
@@ -1924,7 +1924,7 @@ ${wd}`,v=[E,Sd];v.push(Ur({cwd:k,...n.sessionId!==void 0?{sessionId:n.sessionId}
|
|
|
1924
1924
|
|
|
1925
1925
|
`),I=[E,Sd];w.length>0&&I.push(w),u&&I.push(u),$b({prompt:t.prompt,options:{model:d,maxTokens:p,system:_},provenance:{systemPrompt:{source:n.systemPromptSource??"none",shape:typeof n.systemPrompt=="string"?"string":Array.isArray(n.systemPrompt)?"string[]":n.systemPrompt!=null?"preset":"undefined",...typeof n.systemPrompt=="string"?{length:n.systemPrompt.length}:{}},...n.apiKey?{apiKey:{source:"config"}}:{}}});let R;if(s==="oauth"&&!r){let A=this.providerFactory??Lb;R=async()=>{let P=await Qc();if(!P)return null;let N=qo(P,"oauth",n.baseUrl);return A?A(N):new Db(N)}}let C=n.sessionId??n.resume,O=y$(n.resumeHistory),$=this.externalTools?void 0:A=>{let P=this._currentCwd;if(this._sharedReadRoots&&P!==void 0&&P!==A){let D=this._sharedReadRoots.indexOf(P);D!==-1?this._sharedReadRoots[D]=A:this._sharedReadRoots.includes(A)||this._sharedReadRoots.push(A)}if(this._sharedWriteRoots&&P!==void 0&&P!==A){let D=this._sharedWriteRoots.indexOf(P);D!==-1?this._sharedWriteRoots[D]=A:this._sharedWriteRoots.includes(A)||this._sharedWriteRoots.push(A)}this._currentCwd=A;let K=[I[0],I[1],Ur({cwd:A,...n.sessionId!==void 0?{sessionId:n.sessionId}:{},surface:this.surface,...n.depth!==void 0?{depth:n.depth}:{},...n.maxDepth!==void 0?{maxDepth:n.maxDepth}:{},workspace:h.getWorkspace()}),...I.slice(2)].join(`
|
|
1926
1926
|
|
|
1927
|
-
`),q=this.buildDispatcher(f,{cwd:A,readRoots:this._sharedReadRoots,writeRoots:this._sharedWriteRoots,...n.env!==void 0?{env:n.env}:{},sessionId:n.sessionId,traceWriter:n.traceWriter,runtimeStateSource:h});return{userSystem:K,dispatcher:q}},x=w$(n.effort,d);return new ha({client:l,authMode:r?"api-key":s,promptStream:t.prompt,toolDispatcher:g,...C!==void 0?{sessionId:C}:{},...O!==void 0?{initialMessages:O}:{},model:d,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},maxTokens:p,tools:y,userSystem:_,systemPrefix:c,tokenRefresher:R,...n.thinking!==void 0?{thinking:b$(n.thinking,p,d)}:{},...x!==void 0?{effort:x}:{},...r?{baseUrl:n.baseUrl}:{},...n.traceWriter?{traceWriter:n.traceWriter}:{},...n.autoResumeOnUsageLimit!==void 0?{autoResumeOnUsageLimit:n.autoResumeOnUsageLimit}:{},...$!==void 0?{cwdDependentsFactory:$}:{},...this.mcpManager!==void 0?{mcpManager:this.mcpManager}:{},...Fb(n.autoCompact)!==void 0?{autoCompactThreshold:Fb(n.autoCompact)}:{}})}};function f$(e){if(e===void 0)return null;if(typeof e=="string")return e.length>0?e:null;if(typeof e=="object"&&e!==null&&"append"in e){let t=e.append;return t&&t.length>0?t:null}return null}var g$=.9;function Fb(e){if(e===void 0||e===!1)return;if(e===!0)return g$;let t=e.threshold;if(!(typeof t!="number"||!Number.isFinite(t)||t<=0||t>=1))return t}function h$(e,t){let n=e.maxOutputTokens;return typeof n=="number"&&Number.isFinite(n)&&n>0?Math.floor(n):Du(t)}function y$(e){if(!e||e.length===0)return;let t=[];for(let n of e)n.user.length>0&&t.push({role:"user",content:n.user}),n.assistant.length>0&&t.push({role:"assistant",content:n.assistant});return t.length>0?t:void 0}function b$(e,t,n){switch(e.type){case"adaptive":return{type:"adaptive",display:"summarized"};case"disabled":return{type:"disabled"};case"enabled":{if(typeof n=="string"&&m$(n))return{type:"adaptive",display:"summarized"};let r=e.budgetTokens!==void 0&&Number.isFinite(e.budgetTokens)?Math.min(e.budgetTokens,t-1):t-1;return{type:"enabled",budget_tokens:Math.max(r,1024),display:"summarized"}}}}function w$(e,t){if(e!==void 0)return e;let n=t.toLowerCase();if(/(claude-)?(opus|sonnet)-4-[
|
|
1927
|
+
`),q=this.buildDispatcher(f,{cwd:A,readRoots:this._sharedReadRoots,writeRoots:this._sharedWriteRoots,...n.env!==void 0?{env:n.env}:{},sessionId:n.sessionId,traceWriter:n.traceWriter,runtimeStateSource:h});return{userSystem:K,dispatcher:q}},x=w$(n.effort,d);return new ha({client:l,authMode:r?"api-key":s,promptStream:t.prompt,toolDispatcher:g,...C!==void 0?{sessionId:C}:{},...O!==void 0?{initialMessages:O}:{},model:d,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},maxTokens:p,tools:y,userSystem:_,systemPrefix:c,tokenRefresher:R,...n.thinking!==void 0?{thinking:b$(n.thinking,p,d)}:{},...x!==void 0?{effort:x}:{},...r?{baseUrl:n.baseUrl}:{},...n.traceWriter?{traceWriter:n.traceWriter}:{},...n.autoResumeOnUsageLimit!==void 0?{autoResumeOnUsageLimit:n.autoResumeOnUsageLimit}:{},...$!==void 0?{cwdDependentsFactory:$}:{},...this.mcpManager!==void 0?{mcpManager:this.mcpManager}:{},...Fb(n.autoCompact)!==void 0?{autoCompactThreshold:Fb(n.autoCompact)}:{}})}};function f$(e){if(e===void 0)return null;if(typeof e=="string")return e.length>0?e:null;if(typeof e=="object"&&e!==null&&"append"in e){let t=e.append;return t&&t.length>0?t:null}return null}var g$=.9;function Fb(e){if(e===void 0||e===!1)return;if(e===!0)return g$;let t=e.threshold;if(!(typeof t!="number"||!Number.isFinite(t)||t<=0||t>=1))return t}function h$(e,t){let n=e.maxOutputTokens;return typeof n=="number"&&Number.isFinite(n)&&n>0?Math.floor(n):Du(t)}function y$(e){if(!e||e.length===0)return;let t=[];for(let n of e)n.user.length>0&&t.push({role:"user",content:n.user}),n.assistant.length>0&&t.push({role:"assistant",content:n.assistant});return t.length>0?t:void 0}function b$(e,t,n){switch(e.type){case"adaptive":return{type:"adaptive",display:"summarized"};case"disabled":return{type:"disabled"};case"enabled":{if(typeof n=="string"&&m$(n))return{type:"adaptive",display:"summarized"};let r=e.budgetTokens!==void 0&&Number.isFinite(e.budgetTokens)?Math.min(e.budgetTokens,t-1):t-1;return{type:"enabled",budget_tokens:Math.max(r,1024),display:"summarized"}}}}function w$(e,t){if(e!==void 0)return e;let n=t.toLowerCase();if(/(claude-)?(opus|sonnet)-4-[678]/.test(n))return"max"}var S$=new Ue;H();var k$=new Set([...Object.keys(aa),"auto"]);function v$(e){if(!e)return;let t=e.trim().toLowerCase();if(t){if(t==="anthropic"||t==="anthropic-direct")return"anthropic-direct";if(t==="openai"||t==="openai-compatible"||t==="openai-codex")return"openai-compatible"}}function Ee(e,t){let n=t?.explicit??T.AFK_PROVIDER,r=t?.openaiBaseUrl??T.AFK_OPENAI_BASE_URL,o=v$(n);if(o)return o;let s=(e??"").trim().toLowerCase();return s&&(k$.has(s)||s.startsWith("claude-")||s.startsWith("claude_")||s.startsWith("local-")||s.startsWith("local_"))?"anthropic-direct":s&&(s.startsWith("gpt-")||s.startsWith("gpt_")||s.startsWith("o1")||s.startsWith("o3")||s.startsWith("o4")||s.startsWith("codex-")||s.startsWith("codex_")||s==="codex"||s.startsWith("deepseek-")||s.startsWith("deepseek_")||s.startsWith("mistral-")||s.startsWith("mistral_")||s.startsWith("mixtral-")||s.startsWith("mixtral_")||s.startsWith("llama-")||s.startsWith("llama_")||s.startsWith("qwen-")||s.startsWith("qwen_")||s.includes("/"))||r&&r.trim()?"openai-compatible":"anthropic-direct"}function Nb(e,t){switch(Ee(e,t)){case"openai-compatible":case"openai-codex":return new vt;default:return new Ue}}async function wa(e,t,n){if(!e)return;if(n.kind==="blocked"){await Lr(e,{hookEvent:t,decision:"block",...n.err.reason!==void 0?{reason:n.err.reason}:{}});return}let r=n.decision;await Lr(e,{hookEvent:t,decision:r.decision,...r.reason!==void 0?{reason:r.reason}:{},...r.injectContext!==void 0?{injectedContextBytes:Buffer.byteLength(r.injectContext,"utf8")}:{}})}async function Ub(e,t,n={}){if(e)try{let r=await e.dispatch(t,n.signal);await wa(n.traceWriter,"SessionStart",{kind:"decision",decision:r})}catch(r){throw r instanceof Re&&await wa(n.traceWriter,"SessionStart",{kind:"blocked",err:r}),r}}async function jb(e,t,n={}){if(e)try{let r=await e.dispatch(t,n.signal);await wa(n.traceWriter,"SessionEnd",{kind:"decision",decision:r})}catch(r){if(r instanceof Re&&await wa(n.traceWriter,"SessionEnd",{kind:"blocked",err:r}),r instanceof Re||r instanceof ct){J(`SessionEnd hook swallowed ${r.name}: ${r.message}`),n.onError?.(r);return}J(`SessionEnd hook unexpected error: ${String(r)}`),n.onError?.(r instanceof Error?r:new Error(String(r)))}}var Sa=class{pendingResolve=null;bufferedMessage=null;getSessionId;constructor(t){this.getSessionId=t}pushUserMessage(t){if(this.pendingResolve){let n=this.pendingResolve;this.pendingResolve=null;let r=this.getSessionId();n({content:t,...r!==void 0?{sessionId:r}:{}});return}this.bufferedMessage=t}createIterable(){let t=this;return{[Symbol.asyncIterator](){return{next(){if(t.bufferedMessage!==null){let n=t.bufferedMessage;t.bufferedMessage=null;let r=t.getSessionId();return Promise.resolve({value:{content:n,...r!==void 0?{sessionId:r}:{}},done:!1})}return new Promise(n=>{t.pendingResolve=r=>n({value:r,done:!1})})},return(){return Promise.resolve({value:void 0,done:!0})}}}}}};function Bb(e,t,n){e&&(e.aborted?t.abort(e.reason):e.addEventListener("abort",()=>{t.signal.aborted||t.abort(e.reason)},{once:!0})),t.signal.addEventListener("abort",n,{once:!0})}function Wb(e,t){let n=e.permissionMode??"default",r=e.persistSession??!0,o={sessionId:e.sessionId,configuredSessionId:e.sessionId,resume:e.resume,resumeSessionAt:e.resumeSessionAt,continue:e.continue,forkSession:e.forkSession,persistSession:r},s={sessionId:e.sessionId,model:t,permissionMode:n};return{sessionIdentity:o,metadata:s}}var ka=class{initializationPromise;resolveInitialization;rejectInitialization;initializationSettled=!1;sessionMetadata;sessionIdentity;constructor(t,n){this.sessionIdentity=t,this.sessionMetadata=n,this.initializationPromise=new Promise((r,o)=>{this.resolveInitialization=r,this.rejectInitialization=o})}waitForInitialization(){return this.initializationPromise}getSessionIdentity(){return{...this.sessionIdentity,sessionId:this.getSessionId()}}getSessionMetadata(){return{...this.sessionMetadata,sessionId:this.getSessionId()}}getSessionId(){return this.sessionMetadata.sessionId??this.sessionIdentity.sessionId}updateSessionIdentity(t){t&&(this.sessionIdentity={...this.sessionIdentity,sessionId:t},this.sessionMetadata={...this.sessionMetadata,sessionId:t})}setSessionMetadata(t){this.sessionMetadata=t(this.sessionMetadata)}resolveInitializationIfNeeded(){this.initializationSettled||(this.initializationSettled=!0,this.resolveInitialization(this.getSessionMetadata()))}resolveInitializationOnce(){this.initializationSettled||(this.initializationSettled=!0,this.resolveInitialization(this.getSessionMetadata()))}rejectInitializationOnce(t){this.initializationSettled||(this.initializationSettled=!0,this.rejectInitialization(t))}isInitializationSettled(){return this.initializationSettled}};function Hb(e){try{let t=JSON.parse(e);if(!Array.isArray(t))return null;let n=t.length;if(n===0)return"no results";let r=0,o=0;for(let a of t)if(a&&typeof a=="object"){let l=a.type;l==="fact"?r++:l==="procedure"&&o++}let s=`${n} result${n===1?"":"s"}`;if(r+o!==n)return s;let i=[];return r>0&&i.push(`${r} fact${r===1?"":"s"}`),o>0&&i.push(`${o} procedure${o===1?"":"s"}`),i.length===0?s:`${s} (${i.join(", ")})`}catch{return null}}function Kb(e){try{let t=JSON.parse(e);if(!t||typeof t!="object")return null;let n=t;if(n.target==="hot"&&n.saved===!0)return"hot memory saved";if(n.target==="fact"){if(n.action==="remove")return n.removed===!0?"fact removed":"fact not found";if(n.action==="set"&&typeof n.id=="number")return`fact #${n.id} set`;if(n.action==="supersede"&&typeof n.id=="number"&&typeof n.supersedes=="number")return`fact #${n.id} supersedes #${n.supersedes}`}return null}catch{return null}}function Gb(e){try{let t=JSON.parse(e);if(!t||typeof t!="object")return null;let n=t;return typeof n.name=="string"&&n.written===!0?`wrote procedure '${n.name}'`:null}catch{return null}}function Td(e){let t=e.trim();if(t.length===0)return null;let n=t[0];if(n!=="{"&&n!=="[")return null;let r=t[t.length-1];if(n==="{"&&r!=="}"||n==="["&&r!=="]")return null;let o;try{o=JSON.parse(t)}catch{return null}return Array.isArray(o)?qb(T$(o)):o!==null&&typeof o=="object"?qb(E$(o)):null}function T$(e){return e.length===0?"[empty array]":e.length===1?"[1 item]":`[${e.length} items]`}function E$(e){let t=Object.keys(e);if(t.length===0)return"{empty object}";let n=t.slice(0,4),r=t.length>4?", \u2026":"";return`{${n.join(", ")}${r}}`}function qb(e){return e.length<=80?e:e.slice(0,79)+"\u2026"}var x$=new Map([["memory_search",Hb],["memory_update",Kb],["procedure_write",Gb],["bash",Td],["Bash",Td]]);function R$(e){return e.replace(/\x1b\[[0-?]*[ -/]*[@-~]/g,"").replace(/\x1b[@-_]/g,"").replace(/[\x00-\x1f\x7f]/g," ").trim()}function zb(e,t){if(!e)return null;let n=x$.get(e);if(!n)return null;try{let r=n(t);if(r===null)return null;let o=R$(r);return o.length>0?o:null}catch{return null}}function A$(e){let t=/Output too large \((\d+(?:\.\d+)?)\s*(B|KB|MB|GB)\)\.\s*Full output saved to:\s*(\/[^\n]+)/,n=e.match(t);if(!n||!n[1]||!n[2]||!n[3])return null;let r=n[1],o=n[2],s=n[3],i=parseFloat(r),a=i;o==="KB"?a=i*1024:o==="MB"?a=i*1024*1024:o==="GB"&&(a=i*1024*1024*1024);let l=r;return i%1===0&&(l=String(Math.floor(i))),l+=o,{sizeLabel:l,sizeBytes:Math.round(a),absolutePath:s.trim()}}function _$(e){if(e<1024)return`${e}B`;let t=e/1024;if(t<1024)return t%1===0?`${Math.floor(t)}KB`:`${t.toFixed(1)}KB`;let n=t/1024;if(n<1024)return n%1===0?`${Math.floor(n)}MB`:`${n.toFixed(1)}MB`;let r=n/1024;return r%1===0?`${Math.floor(r)}GB`:`${r.toFixed(1)}GB`}function C$(e){let t=Buffer.byteLength(e,"utf8"),n=_$(t),r=e.split(`
|
|
1928
1928
|
`);if(r.length<=1&&e.length<=80)return{content:e,truncated:!1,sizeBytes:t,sizeLabel:n};if(r.length<=1)return e.length<=80?{content:e,truncated:!1,sizeBytes:t,sizeLabel:n}:{content:e.substring(0,80)+"\u2026",truncated:!0,sizeBytes:t,sizeLabel:n};if(e.length<=80)return{content:e,truncated:!1,sizeBytes:t,sizeLabel:n};let o=r[0]??"",s=o;return o.length>80&&(s=o.substring(0,80)+"\u2026"),{content:s+`\u2026+${r.length} lines`,truncated:!0,lineCount:r.length,sizeBytes:t,sizeLabel:n}}function I$(e,t){let n={...e.raw??{}};return e.inputTokens!==void 0&&(n.input_tokens=e.inputTokens),e.outputTokens!==void 0&&(n.output_tokens=e.outputTokens),e.cachedInputTokens!==void 0&&(n.cache_read_input_tokens=e.cachedInputTokens),e.cacheCreationTokens!==void 0&&(n.cache_creation_input_tokens=e.cacheCreationTokens),e.totalTokens!==void 0&&(n.total_tokens=e.totalTokens),{sessionId:t,stopReason:e.stopReason??void 0,resultSubtype:e.resultSubtype,durationMs:e.durationMs,durationApiMs:e.durationApiMs,totalCostUsd:e.totalCostUsd,isError:e.isError,usage:Object.keys(n).length>0?n:void 0,modelUsage:e.modelUsage,permissionDenials:e.permissionDenials,errors:e.errors}}function P$(e){let t=e.isError===!0?null:zb(e.toolName,e.content),n=t!==null?{display:t}:{},r=A$(e.content);if(r)return{type:"chunk",chunk:{type:"tool_result",toolUseId:e.toolUseId,content:`Output persisted (${r.sizeLabel}) \u2192 ${r.absolutePath}`,isError:e.isError===!0,persistedPath:r.absolutePath,sizeBytes:r.sizeBytes,sizeLabel:r.sizeLabel,...n}};let{content:o,lineCount:s,sizeBytes:i,sizeLabel:a}=C$(e.content);return{type:"chunk",chunk:{type:"tool_result",toolUseId:e.toolUseId,content:o,isError:e.isError===!0,sizeBytes:i,sizeLabel:a,...e.truncated===!0&&{truncated:!0},...s!==void 0&&{lineCount:s},...n}}}function Ed(e,t){switch(e.type){case"session.init":{let n=e.info;return t.setSessionMetadata(r=>({...r,sessionId:n.sessionId,model:n.model??r.model,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},...n.cwd!==void 0?{cwd:n.cwd}:{},tools:n.tools?[...n.tools]:r.tools,slashCommands:n.slashCommands?[...n.slashCommands]:r.slashCommands,skills:n.skills?[...n.skills]:r.skills,plugins:n.plugins?n.plugins.map(o=>({...o})):r.plugins,mcpServers:n.mcpServers?n.mcpServers.map(o=>({...o})):r.mcpServers,...n.apiKeySource!==void 0?{apiKeySource:n.apiKeySource}:{},...n.version!==void 0?{claudeCodeVersion:n.version}:{},...n.outputStyle!==void 0?{outputStyle:n.outputStyle}:{}})),t.updateSessionIdentity(n.sessionId),t.resolveInitialization(),null}case"session.status":return t.setSessionMetadata(n=>({...n,sessionId:e.sessionId,...e.permissionMode!==void 0?{permissionMode:e.permissionMode}:{permissionMode:n.permissionMode},...e.status!==void 0?{status:e.status}:{}})),null;case"delta.text":return{type:"chunk",chunk:{type:"content",content:e.text,metadata:{eventType:"delta",deltaType:"text_delta"}}};case"delta.reasoning":return{type:"chunk",chunk:{type:"thinking",content:e.text,metadata:{eventType:"delta",deltaType:"thinking_delta"}}};case"assistant.message":if(e.sessionId&&t.updateSessionIdentity(e.sessionId),e.text){let n={role:"assistant",content:e.text,timestamp:new Date};return t.conversationHistory.push(n),{type:"message",message:n}}return null;case"tool.use.start":return{type:"chunk",chunk:{type:"tool_use_detail",toolUseId:e.toolUseId,toolName:e.toolName,toolInput:e.toolInput}};case"tool.use":return{type:"chunk",chunk:{type:"tool_use",content:e.summary,metadata:{eventType:"tool_use_summary",precedingToolUseIds:e.toolUseIds}}};case"tool.output":return P$(e);case"tool.diff":return{type:"chunk",chunk:{type:"tool_diff",toolUseId:e.toolUseId,diff:e.diff}};case"progress":return{type:"progress",progress:{taskId:e.progress.taskId,description:e.progress.description,...e.progress.summary!==void 0?{summary:e.progress.summary}:{},...e.progress.lastToolName!==void 0?{lastToolName:e.progress.lastToolName}:{},totalTokens:e.progress.totalTokens,toolUses:e.progress.toolUses,durationMs:e.progress.durationMs}};case"suggestion":return{type:"suggestion",suggestion:e.suggestion};case"turn.completed":{let n=I$(e.usage,e.sessionId??t.getSessionMetadata().sessionId);t.setLastResponseMetadata(n);for(let r=t.conversationHistory.length-1;r>=0;r--){let o=t.conversationHistory[r];if(o?.role==="assistant"){o.metadata=n;break}}if(t.maxBudgetUsd!==void 0&&t.abortBudget!==void 0&&typeof n.totalCostUsd=="number"&&(t._runningCostUsd=(t._runningCostUsd??0)+n.totalCostUsd,t._runningCostUsd>=t.maxBudgetUsd)){Cf(t.traceWriter,{kind:"monetary",runningCostUsd:t._runningCostUsd,maxBudgetUsd:t.maxBudgetUsd,lastTurnCostUsd:n.totalCostUsd});let r=new cn(t._runningCostUsd,t.maxBudgetUsd);return t.abortBudget(r.message),{type:"error",error:r}}return{type:"done",metadata:n}}case"error":return{type:"error",error:e.error};case"paused":return{type:"paused",reason:e.reason,...e.resetsAt!==void 0?{resetsAt:e.resetsAt}:{},...e.accountId!==void 0?{accountId:e.accountId}:{},...e.autoResume!==void 0?{autoResume:e.autoResume}:{}};case"resumed":return{type:"resumed",hotSwapped:e.hotSwapped,...e.accountId!==void 0?{accountId:e.accountId}:{}};default:return null}}var ot=class{config;currentState="idle";providerQuery;providerIterator;conversationHistory=[];turnCount=0;lastResponseMetadata=null;initPromise=null;inputStream;abortController;hookRegistry;sessionEndDispatched=!1;stateManager;sessionRunningCostUsd=0;sessionRunningTokens={input:0,output:0,cacheRead:0,cacheCreation:0};lastStopReason;constructor(t){this.config=t,this.abortController=new AbortController,this.hookRegistry=t.hookRegistry,Bb(t.abortSignal,this.abortController,()=>{this.onAbort()}),this.initSdkLifecycle()}initSdkLifecycle(){let t=rr(this.config.model)??this.config.model,{sessionIdentity:n,metadata:r}=Wb(this.config,t);this.stateManager=new ka(n,r),this.inputStream=new Sa(()=>this.sessionId);let o=this.config.provider??Nb(t);J(`\u{1F7E2} AgentSession: Creating query session via provider=${o.name}`),this.providerQuery=o.query({prompt:this.inputStream.createIterable(),config:this.config}),this.conversationHistory=[],this.turnCount=0,this.lastResponseMetadata=null,this.sessionRunningCostUsd=0,this.sessionRunningTokens={input:0,output:0,cacheRead:0,cacheCreation:0},this.lastStopReason=void 0,this.sessionEndDispatched=!1,this.currentState="idle";let s=this.providerQuery;this.providerIterator=s[Symbol.asyncIterator](),this.initPromise=this.pullInitialization()}async pullInitialization(){try{for(await Ub(this.hookRegistry,{event:"SessionStart",sessionId:this.sessionId},{signal:this.abortController.signal,...this.config.traceWriter?{traceWriter:this.config.traceWriter}:{}});;){let t=await this.providerIterator.next();if(t.done){this.stateManager.resolveInitializationIfNeeded();return}let n=t.value,r=Ed(n,this.buildTransformDeps());if(n.type==="session.init"||r&&r.type==="error")return}}catch(t){let n=t instanceof Error?t:new Error(String(t));this.stateManager.isInitializationSettled()||this.stateManager.rejectInitializationOnce(n),await this.dispatchSessionEndOnce("error").catch(()=>{})}}buildTransformDeps(){return{conversationHistory:this.conversationHistory,getSessionMetadata:()=>this.stateManager.getSessionMetadata(),setSessionMetadata:t=>this.stateManager.setSessionMetadata(t),updateSessionIdentity:t=>this.stateManager.updateSessionIdentity(t),resolveInitialization:()=>this.stateManager.resolveInitializationOnce(),setLastResponseMetadata:t=>{this.lastResponseMetadata=t,typeof t.totalCostUsd=="number"&&Number.isFinite(t.totalCostUsd)&&(this.sessionRunningCostUsd+=t.totalCostUsd);let n=t.usage;if(n&&typeof n=="object"){let r=n,o=(s,i)=>{let a=r[s];typeof a=="number"&&Number.isFinite(a)&&(this.sessionRunningTokens[i]+=a)};o("input_tokens","input"),o("output_tokens","output"),o("cache_read_input_tokens","cacheRead"),o("cache_creation_input_tokens","cacheCreation")}typeof t.stopReason=="string"&&(this.lastStopReason=t.stopReason)},maxBudgetUsd:this.config.maxBudgetUsd,abortBudget:t=>{this.abortController.signal.aborted||this.abortController.abort(t)},...this.config.traceWriter?{traceWriter:this.config.traceWriter}:{}}}get state(){return this.currentState}get sessionId(){return this.stateManager.getSessionId()}get cwd(){return this.config.cwd}get abortSignal(){return this.abortController.signal}abort(t){if(t==="closed"||t.startsWith("Budget ")||t.includes("timed out"))throw new Error(`AgentSession.abort: reserved reason "${t}" (use a caller-specific string like 'sigint')`);this.abortController.signal.aborted||this.abortController.abort(t)}async sendMessage(t,n={}){this.assertCanSend();let r=this.config.timeoutMs??_i,o=async()=>{let s=null,i="";this.currentState=n.stream?"streaming":"processing";for await(let a of this.sendMessageStreamInternal(t)){if(a.type==="chunk"&&a.chunk.type==="content"&&(i+=a.chunk.content),a.type==="message"&&a.message.role==="assistant"&&(s=a.message),a.type==="error")throw a.error;if(a.type==="done"){if(s)return{...s,metadata:a.metadata};if(i)return{role:"assistant",content:i,metadata:a.metadata,timestamp:new Date}}}if(s)return s;if(i)return{role:"assistant",content:i,timestamp:new Date};throw new Error("No assistant response received")};try{return await Ci(o(),r,{controller:this.abortController,label:this.sessionId??"session"})}finally{this.currentState==="processing"&&(this.currentState="idle")}}async*sendMessageStream(t){this.assertCanSend(),this.currentState="streaming";try{yield*this.sendMessageStreamInternal(t)}finally{this.currentState==="streaming"&&(this.currentState="idle")}}async*sendMessageStreamInternal(t){this.initPromise&&await this.initPromise;let r={role:"user",content:typeof t=="string"?t:this.summarizeContentBlocks(t),timestamp:new Date};this.conversationHistory.push(r),this.inputStream.pushUserMessage(t);let o=this.buildTransformDeps();try{for(;;){let s=await this.providerIterator.next();if(s.done)break;let i=s.value,a=Ed(i,o);if(a&&(a.type==="done"&&this.turnCount++,yield a,a.type==="done"||a.type==="error"))break}}finally{this.currentState==="streaming"&&(this.currentState="idle")}}summarizeContentBlocks(t){let n=[],r=0;for(let s of t)s.type==="text"?n.push(s.text):s.type==="image"&&r++;let o=n.join(" ");return r>0&&(o=o?`${o} [+ ${r} image(s)]`:`[+ ${r} image(s)]`),o||"[content block(s)]"}async interrupt(){this.currentState!=="streaming"&&this.currentState!=="processing"||(this.currentState="idle",await this.providerQuery.interrupt())}async reset(){if(this.currentState==="closed")throw new Error("Cannot reset: session is closed");if(this.abortController.signal.aborted)throw new ct("Cannot reset: session aborted");if(this.currentState==="processing"||this.currentState==="streaming")try{await this.providerQuery.interrupt()}catch{}await this.dispatchSessionEndOnce("reset");try{await this.providerQuery.close()}catch{}await this.providerIterator.return?.(),this.initPromise&&await Promise.race([this.initPromise,new Promise(t=>setTimeout(t,tu))]).catch(()=>{}),this.stateManager.resolveInitializationIfNeeded(),this.config={...this.config},delete this.config.resume,delete this.config.sessionId,delete this.config.resumeHistory,delete this.config.resumeSessionAt,delete this.config.continue,delete this.config.forkSession;try{this.initSdkLifecycle()}catch(t){throw this.currentState="closed",new Error(`Session reset failed during lifecycle rebuild: ${t instanceof Error?t.message:String(t)}`,{cause:t})}}async onAbort(){try{await this.providerQuery.interrupt()}catch{}}async setModel(t){let n=rr(t),r=this.stateManager.getSessionMetadata();await this.providerQuery.setModel(n??r.model??""),n&&this.stateManager.setSessionMetadata(o=>({...o,model:n}))}async setPermissionMode(t){await this.providerQuery.setPermissionMode(t),this.stateManager.setSessionMetadata(n=>({...n,permissionMode:t}))}setCwd(t){this.config={...this.config,cwd:t},this.providerQuery.setCwd?.(t)}async reauth(){return await this.providerQuery.reauth?.()??null}waitForInitialization(){return this.stateManager.waitForInitialization()}getSessionIdentity(){return this.stateManager.getSessionIdentity()}getSessionMetadata(){return this.stateManager.getSessionMetadata()}getQuery(){return this.providerQuery}supportedCommands(){return this.providerQuery.supportedCommands()}supportedModels(){return this.providerQuery.supportedModels()}supportedAgents(){return this.providerQuery.supportedAgents()}getContextUsage(){return this.providerQuery.getContextUsage()}mcpServerStatus(){return this.providerQuery.mcpServerStatus()}accountInfo(){return this.providerQuery.accountInfo()}rewindFiles(t,n){return this.providerQuery.rewindFiles(t,n)}async compact(){if(this.currentState==="closed")throw new Error("Cannot compact: session is closed");if(this.currentState!=="idle")return{compacted:!1,reason:"session-busy",messagesBefore:0,messagesAfter:0};let t=this.providerQuery.compact?.bind(this.providerQuery);return t?t():{compacted:!1,reason:"not-supported",messagesBefore:0,messagesAfter:0}}getLastResponseMetadata(){return this.lastResponseMetadata}getOutputStream(){throw new Error("getOutputStream() is not supported \u2014 use sendMessageStream() instead")}getInputStreamRef(){return{pushUserMessage:t=>this.inputStream.pushUserMessage(t)}}getHistory(){return[...this.conversationHistory]}getTurnCount(){return this.turnCount}async close(){if(this.currentState!=="closed"){this.currentState="closed",this.abortController.signal.aborted||this.abortController.abort("closed"),this.stateManager.resolveInitializationIfNeeded();try{await this.providerQuery.close()}catch{}if(await this.providerIterator.return?.(),this.initPromise)try{await Promise.race([this.initPromise,new Promise(t=>setTimeout(t,tu))])}catch{}await this.dispatchSessionEndOnce("close")}}async dispatchSessionEndOnce(t){this.sessionEndDispatched||(this.sessionEndDispatched=!0,await this.emitClosure(t).catch(()=>{}),await this.sealTraceWriter(t).catch(()=>{}),await jb(this.hookRegistry,{event:"SessionEnd",sessionId:this.sessionId,reason:t},this.config.traceWriter?{traceWriter:this.config.traceWriter}:{}))}async emitClosure(t){let n=this.config.traceWriter;if(!n)return;let r=this.deriveClosureReason(t),o={};this.sessionRunningTokens.input>0&&(o.input=this.sessionRunningTokens.input),this.sessionRunningTokens.output>0&&(o.output=this.sessionRunningTokens.output),this.sessionRunningTokens.cacheRead>0&&(o.cacheRead=this.sessionRunningTokens.cacheRead),this.sessionRunningTokens.cacheCreation>0&&(o.cacheCreation=this.sessionRunningTokens.cacheCreation),await Mf(n,{reason:r,finalTurnCount:this.turnCount,finalCostUsd:this.sessionRunningCostUsd,finalTokens:o,...this.lastStopReason!==void 0?{lastStopReason:this.lastStopReason}:{}})}deriveClosureReason(t){if(t==="error")return"abort";let n=this.abortController.signal;if(n.aborted&&n.reason!=="closed"){let r=n.reason;if(r instanceof cn)return"budget_exceeded";if(r instanceof ut)return"timeout";if(typeof r=="string"){if(r.startsWith("Budget "))return"budget_exceeded";if(r.includes("timed out"))return"timeout"}return"abort"}return"model_end_turn"}async sealTraceWriter(t){let n=this.config.traceWriter;if(!n)return;let r=this.deriveSealStatus(t);await n.seal({status:r,finalCostUsd:this.sessionRunningCostUsd,finalTurnCount:this.turnCount,closedAt:new Date().toISOString()})}deriveSealStatus(t){if(t==="error")return"failed";let n=this.abortController.signal;return n.aborted&&n.reason!=="closed"?"cancelled":"succeeded"}assertCanSend(){if(this.currentState==="closed")throw new Error("Cannot send message: session is closed");if(this.abortController.signal.aborted)throw new ct("Cannot send message: session aborted");if(this.currentState==="processing"||this.currentState==="streaming")throw new Error("Cannot send message: session is busy");if(this.config.maxTurns&&this.turnCount>=this.config.maxTurns)throw new Error(`Maximum turns (${this.config.maxTurns}) exceeded`)}};function Jb(){return qf()}var M$=["shadow-verify","shadow_verify","resolve","diagnose","appmap","qualify","mint"],O$=[/\bverdict(s)?\b/i,/\brecommend(ation)?s?\b/i,/\bshould\s+(delete|remove|rewrite|refactor|rename|reject|merge|revert|disable)\b/i,/\b(USELESS|KEEP|REJECT|APPROVE|SALVAGE|BLOCK|FAIL)\b/,/\b(redundant|duplicated|superseded|obsolete)\b/i,/\bvulnerab\w*\b/i,/\bunused\b/i,/\bbroken\b/i,/\bregress\w*\b/i,/\|\s*(status|verdict|decision|severity|risk|finding|priority|holds\??)\s*\|/i,/\bfound\s+\d+\s*(issue|problem|bug|error|finding|vulnerabilit)/i,/\b(critical|high|medium|low)\s+(severity|priority|risk)\b/i,/\bclaim(s)?\b[^\n]{0,80}\b(holds?|refuted|verified|partial|confirmed|disputed)\b/i,/\b(root\s*cause|incident)\b/i,/\brecommend\s+(removing|deleting|rewriting|refactoring|merging|reverting)\b/i,/\bI\s+(applied|committed|pushed|edited|wrote|fixed|patched|reset|restored|staged)\b/i,/\b(applied|committed|pushed|fixed|patched)\s+(the|these|those)\s+(change|commit|fix|patch|edit)/i],$$=[/\bverifier_verdict\b/i,/"\s*claim\s*"\s*:/i,/\bre-derived\b[^.\n]{0,80}\bindependent/i,/\bindependently\s+(re-derived|re-verified|verified|checked)\b/i,/\bverifier\s+(agrees|disagrees|confirms|refutes)\b/i],D$=`shadow-verify nudge:
|
|
1929
1929
|
|
|
1930
1930
|
The sub-agent that just finished returned output that reads like **decision-driving findings** (verdicts, recommendations, audit conclusions, or claim-style results that could drive file edits, deletions, commits, or external side-effects).
|
|
@@ -2196,7 +2196,7 @@ _ended: ${new Date().toISOString()}_
|
|
|
2196
2196
|
`)}function Dj(e){let t=[],n=(r,o)=>{o&&o.trim().length>0&&t.push({label:r,value:o.trim()})};switch(e.kind){case"done":n("done",e.whatWasDone),n("evidence",e.evidence),n("deferred",e.deferred);break;case"blocked":n("blocks",e.whatBlocks),n("unblock",e.unblockCondition),n("progress",e.alreadyDone);break;case"asking":n("question",e.question),n("resolves",e.assumption),n("after",e.followup);break;case"interrupted":n("was doing",e.whatWasInProgress),n("saved at",e.stateLocation),n("resume",e.resumeRequires);break}return t}function uT(e,t,n){let r=[];return n&&n.trim().length>0&&r.push({type:"text",text:n}),e&&r.push({type:"text",text:e}),vl(r,t),r}async function dT(e,t,n,r,o="summary",s,i,a){let l=KS(e.text,e.attachments);r.setInFlight(!0);let c="",u=!1,d=!1,p=!1,f=!1,g,h=!1,b=!1,y=[],w=new Map,k=e.text.startsWith("/")?e.text.split(/[\s:]/)[0]?.slice(1):void 0,E=r.getCompositor?r.getCompositor():null,v=()=>new vo({out:To(s),thinkingMode:o,...k?{activeSkillName:k}:{},onCancel:()=>{t.interrupt().catch(C=>{Ke()&&console.error(" "+m.error("session.interrupt() failed:"),C)})},...i?{onBackground:()=>{h=!0}}:{},...a?.history?{history:a.history}:{},...a?.autocompleteState?{autocompleteState:a.autocompleteState}:{},...a?.promptText!==void 0?{promptText:a.promptText}:{},...r.scrollRegion?{scrollRegion:r.scrollRegion}:{},...E?{compositor:E}:{}}),_=v(),I=async()=>{if(!p){p=!0;try{await _.dispose()}catch{}}},R=async()=>{await _.arm();let C=_.getCompositor();if(s&&C){let O=C;s.fn=$=>O.commitAbove($)}r.setActiveCompositor?.(C),r.rearmStatus?.()};try{E?E.commitAbove(""):console.log(),r.setSoftStopHandler&&r.setSoftStopHandler(()=>{b=!0}),await R(),i&&r.setBackgroundHandler&&r.setBackgroundHandler(()=>{h=!0});let C=e.attachments.length===0?e.text:uT(e.text,e.attachments),O=t.sendMessageStream(C);if(await Nr((x,A)=>{_.process(x,A)},async()=>{for await(let x of O){if(b){t.interrupt().catch(A=>{Ke()&&console.error(" "+m.error("soft-stop session.interrupt() failed:"),A)});break}if(h&&i){let A=k??e.text.slice(0,40),P=i.register(A),N=qa(P,i);za(O,c,l,P,i,N,n,r.onTurnComplete,t.abortSignal),await I(),(s??{fn:console.log}).fn(m.dim(` \u2192 backgrounded as ${P.id}: ${P.label}`)),r.setInFlight(!1),r.rearmStatus?.();return}if(x.type==="chunk"&&x.chunk.type==="content"?(c+=x.chunk.content,u=!0):x.type==="message"&&!u&&(c=x.message.content),x.type==="chunk"&&x.chunk.type==="tool_use_detail"){let A=x.chunk,P={toolName:A.toolName,toolUseId:A.toolUseId,input:A.toolInput};w.set(A.toolUseId,P),y.push(P)}else if(x.type==="chunk"&&x.chunk.type==="tool_result"){let A=x.chunk,P=w.get(A.toolUseId);P&&(P.result=A.content,P.isError=A.isError,w.delete(A.toolUseId))}if(x.type==="paused"){await I(),(s??{fn:console.log}).fn(vf({reason:x.reason,...x.resetsAt!==void 0?{resetsAt:x.resetsAt}:{},...x.accountId!==void 0?{accountId:x.accountId}:{},...x.autoResume!==void 0?{autoResume:x.autoResume}:{}}));continue}if(x.type==="resumed"){let A=x.hotSwapped&&x.accountId?`\u25B6 Resumed on ${x.accountId}`:"\u25B6 Resumed";c="",u=!1,y.length=0,w.clear(),f=!1,g=void 0,d=!1,h=!1,_=v(),p=!1,await R(),(s??{fn:console.log}).fn(m.success(A));continue}if(x.type==="error"){await I(),Dr(Or(x.error)),d=!0;continue}_.process(x),x.type==="done"&&(f=!0,g=x.metadata)}}),await I(),b){let x=s?s.fn:console.log;x(m.warning("\u23F8 Stopped \u2014 work so far kept.")+m.dim(" Use /resume or --resume to continue.")),x("")}if(f&&!b){or(n,l,c,g,y),r.onTurnComplete&&await r.onTurnComplete(l,c).catch(()=>{});let x=P=>{s?s.fn(P):console.log(P)},A=lT(c);if(A&&(x(cT(A)),x(""),r.onTerminalState))try{r.onTerminalState(A)}catch{}if(Lj(g,n,x),r.onAfterTurn){let P=r.onAfterTurn();P instanceof Promise&&await P.catch(()=>{})}}}catch(C){await I(),d||Dr(Or(C))}finally{await I(),s&&(s.fn=s.idleFn),r.setActiveCompositor?.(null),r.setBackgroundHandler?.(null),r.setSoftStopHandler?.(null),r.setInFlight(!1),r.rearmStatus?.()}}function Lj(e,t,n=console.log){if(!e)return;let r=[];e.durationMs&&r.push(se(e.durationMs)),e.totalCostUsd!==void 0&&r.push(Le(e.totalCostUsd));let o=Number(e.usage?.input_tokens??0),s=Number(e.usage?.output_tokens??0);o+s>0&&r.push(ee(o+s)+" tok"),r.length>0&&n(m.dim(" \u25E6 "+r.join(" \xB7 ")));let i=$d(t),a=nt(t.model);if(i>=1){let l=Math.round((i-1)*a),c=Math.round(a/1e3);console.log(m.error(` context OVER ${c}k tok by ~${ee(l)} tok \u2014 model output may be silently truncated`))}else if(i>.5){let l=i>.8?m.error:m.warning;n(l(` context ${Math.round(i*100)}% used of ${ee(a)}`))}n("")}function pT(e={}){let t=e.load??Ha,n=e.onResize??(i=>He.subscribe(i)),r="",o,s=n(()=>{r=""});return{renderIfChanged(i){let a=i??"unbound",l=t(a),c=sS(l);return a===o&&c===r?[]:(o=a,r=c,c===""?[]:Ka(l))},invalidate(){r=""},dispose(){try{s()}catch{}}}}var Wp={done:{glyph:"\u2713",color:m.success,label:"done"},blocked:{glyph:"\u2298",color:m.error,label:"blocked"},asking:{glyph:"?",color:m.warning,label:"asking"},interrupted:{glyph:"\u23F8",color:m.meta,label:"interrupted"}};function mT(e={}){let t=Math.max(2,e.capacity??8),n=[];return{push(r){n.push(r.kind),n.length>t&&(n=n.slice(n.length-t))},reset(){n=[]},entries(){return n},render(){if(n.length===0)return null;let r=m.dim(" ledger "),o=m.dim(" \xB7 "),s=n.map(u=>{let d=Wp[u];return d.color(`${d.glyph} ${d.label}`)}),i=m.dim(` (${n.length} turn${n.length===1?"":"s"})`),a=r+s.join(o)+i,l=Math.max(20,X()-2);if(z(a)<=l)return a;let c=r+n.map(u=>Wp[u].color(Wp[u].glyph)).join(m.dim(" "))+i;return ue(c,l)}}}var Hp=["\u25D0","\u25D1","\u25D2","\u25D3"],Ql=class{stream;manager;registry;throttleMs;started=!1;lastRepaint=0;spinnerIndex=0;spinnerInterval=null;resizeUnsub=null;updateHandler=null;registryStartedHandler=null;registrySettledHandler=null;rowCount=0;onRowCountChange;constructor(t,n,r={}){this.manager=t,this.registry=n,this.stream=r.stream??process.stdout,this.throttleMs=r.throttleMs??200}setRowCountChangeHandler(t){this.onRowCountChange=t}start(){this.started||(this.started=!0,this.updateHandler=()=>this.scheduleRepaint(),this.manager.on("update",this.updateHandler),this.manager.on("complete",this.updateHandler),this.registry&&(this.registryStartedHandler=t=>{this.scheduleRepaint()},this.registrySettledHandler=t=>{this.scheduleRepaint()},this.registry.on("started",this.registryStartedHandler),this.registry.on("settled",this.registrySettledHandler)),this.resizeUnsub=He.subscribe(()=>this.repaint()),this.spinnerInterval=setInterval(()=>{this.spinnerIndex=(this.spinnerIndex+1)%Hp.length,this.rowCount>0&&this.repaint()},Math.max(this.throttleMs,50)))}stop(){this.started&&(this.started=!1,this.updateHandler&&(this.manager.removeListener("update",this.updateHandler),this.manager.removeListener("complete",this.updateHandler),this.updateHandler=null),this.registry&&(this.registryStartedHandler&&(this.registry.off("started",this.registryStartedHandler),this.registryStartedHandler=null),this.registrySettledHandler&&(this.registry.off("settled",this.registrySettledHandler),this.registrySettledHandler=null)),this.resizeUnsub&&(this.resizeUnsub(),this.resizeUnsub=null),this.spinnerInterval&&(clearInterval(this.spinnerInterval),this.spinnerInterval=null),this.rowCount>0&&(this.clearRows(),this.rowCount=0,this.onRowCountChange?.(0)))}scheduleRepaint(){Date.now()-this.lastRepaint<this.throttleMs||this.repaint()}repaint(){if(!this.started||!this.stream.isTTY)return;this.lastRepaint=Date.now();let t=[...this.manager.running().map(s=>({kind:"turn",task:s})),...(this.registry?.list()??[]).filter(s=>s.status==="running").map(s=>({kind:"subagent",job:s}))],n=this.stream.rows??24,r=Math.max(0,Math.min(t.length,n-1));if(r!==this.rowCount&&(this.rowCount>0&&this.clearRows(),this.rowCount=r,this.onRowCountChange?.(r)),r===0)return;let o=Math.max(1,n-r);this.stream.write("\x1B[s");for(let s=0;s<r;s++){let i=t[s],a=o+s;this.stream.write(`\x1B[${a};1H`),this.stream.write("\x1B[2K"),this.stream.write(this.formatItemLine(i))}this.stream.write("\x1B[u")}clearRows(){if(!this.stream.isTTY)return;let t=this.stream.rows??24,n=Math.min(this.rowCount,t-1),r=Math.max(1,t-n);this.stream.write("\x1B[s");for(let o=0;o<n;o++)this.stream.write(`\x1B[${r+o};1H`),this.stream.write("\x1B[2K");this.stream.write("\x1B[u")}formatItemLine(t){return t.kind==="turn"?this.formatTaskLine(t.task):this.formatJobLine(t.job)}formatTaskLine(t){let n=Math.max(4,(this.stream.columns??80)-2),r=m.brand(Hp[this.spinnerIndex]),o=m.dim(t.id),s=m.bold(t.label),i=[r,o,s];t.progressDescription&&i.push(m.dim(t.progressDescription));let a=[];t.stats.toolUses>0&&a.push(`${t.stats.toolUses} tool${t.stats.toolUses===1?"":"s"}`),t.stats.tokens>0&&a.push(`${ee(t.stats.tokens)} tok`);let l=Date.now()-t.startedAt;return a.push(se(l)),a.length>0&&i.push(m.dim(a.join(" \xB7 "))),ue(" "+i.join(" "),n)}formatJobLine(t){let n=Math.max(4,(this.stream.columns??80)-2),r=m.brand(Hp[this.spinnerIndex]),o=m.dim(t.jobId),s=m.bold(t.label||t.jobId),i=[r,o,s],a=Date.now()-t.startedAt;return i.push(m.dim(se(a))),ue(" "+i.join(" "),n)}};function ec(e,t){let n=m.brand("afk")+m.dim(` (${e})`),r=t?m.warning(" \u25CF plan"):"";return n+r+m.dim(" \u203A ")}async function fT(e,t,n,r){let o=null,s=[];e.session.current.waitForInitialization().then(async p=>{Ke()&&(o=Ua(p)),await Al(e.session.current),Ke()&&(s=pv())}).catch(()=>{});let i=await tT(),a=new Zl({rl:e.rl,history:i,statusLine:e.statusLine}),l,c,u,d;try{await a.armCompositor({promptFn:()=>ec(e.stats.model,e.stats.planMode),onCancel:r,onShiftTab:()=>{let y=e.slashCtx;y.stats.planMode&&y.stats.pendingPlanExit?(y.stats.pendingPlanExit=!1,Et(y,!1,{closureSummarySkipped:!0}).catch(()=>{})):Et(y).catch(()=>{}),e.statusLine.rearm()},scrollRegion:e.statusLine,...e.preArmAnchorRow!==void 0?{anchorRow:e.preArmAnchorRow}:{}});let p=a.getCompositor();Ot.install($a({readLine:y=>a.readLine({promptFn:()=>y}).then(w=>w.text),writer:{line:(y="")=>{let w=a.getCompositor();w?w.commitAbove(y):process.stdout.write(y+`
|
|
2197
2197
|
`)}},pendingCount:()=>Ot.pendingCount(),...p?{pickFromList:y=>iT(p,y),readTextOverlay:y=>aT(p,y)}:{}})),e.replRenderer.setCompositor(a.getCompositor()),e.slashCtx.getCompositor=()=>a.getCompositor();let f=a.getCompositor();if(f){let y=w=>f.commitAbove(w);e.completionWriter.fn=y,e.completionWriter.idleFn=y}e.slashCtx.setSoftStopHandler=y=>a.setSoftStopHandler(y),e.inputSurfaceRef&&(e.inputSurfaceRef.current=a),c=pT();let g=mT();e.clearVerdictLedger=()=>g.reset(),u=new Ga,hS(u),vS(u),xS(u),TS(e.backgroundRegistry),d=new Ql(u,e.backgroundRegistry),d.setRowCountChangeHandler(y=>{e.statusLine.setExtraRows(y)}),d.start();let h=50,b=[];for(u.on("complete",y=>{b.length>=h&&b.shift(),b.push(y)});;){if(o&&(e.replRenderer.writeLine(o),e.replRenderer.writeLine(""),o=null),s.length>0){for(let R of s)e.replRenderer.writeLine(R);e.replRenderer.writeLine(""),s=[]}for(;b.length>0;){let R=b.shift(),C=R.status==="succeeded"?"\u2713":"\u2717",O=[];if(R.resultText){let x=R.resultText.trim().split(`
|
|
2198
2198
|
`)[0]?.slice(0,80)??"";x&&O.push(x)}R.error&&O.push(R.error.message);let $=[R.stats.toolUses>0?`${R.stats.toolUses} tools`:"",R.stats.tokens>0?`${Math.round(R.stats.tokens/1e3)}k tok`:"",R.stats.durationMs>0?`${Math.round(R.stats.durationMs/1e3)}s`:""].filter(Boolean).join(" \xB7 ");$&&O.push($),e.replRenderer.writeLine(pn({kind:R.status==="succeeded"?"checkpoint":"diagnosis",title:`${C} ${R.id} ${R.label}`,body:O})),e.replRenderer.writeLine("")}let y=c.renderIfChanged(e.stats.sessionId);if(y.length>0){for(let R of y)e.replRenderer.writeLine(R);e.replRenderer.writeLine("")}let w=g.render();w&&e.replRenderer.writeLine(w);let k,E;if(l!==void 0){let R=l;l=void 0;let C=ec(e.stats.model,e.stats.planMode),O=lr({buffer:R.text,promptText:C,isTTY:!!process.stdout.isTTY,attachmentSummary:yo([...R.attachments])});e.replRenderer.writeLine(O),k=R.text.trim(),E=R.attachments}else{let R=await a.readLine({promptFn:()=>ec(e.stats.model,e.stats.planMode),onSigint:r,onShiftTab:()=>{let C=e.slashCtx;C.stats.planMode&&C.stats.pendingPlanExit?(C.stats.pendingPlanExit=!1,Et(C,!1,{closureSummarySkipped:!0}).catch(()=>{})):Et(C).catch(()=>{}),e.statusLine.rearm()}});k=R.text.trim(),E=R.attachments}if(!k&&E.length===0)continue;let v=!1;if(k.startsWith("/")){let R=await Lw(k,e.slashCtx,E);if(R.handled){if(R.result==="exit"){e.rl.close();return}if((k==="/clear"||k.startsWith("/clear "))&&(await t.rotateOnClear(),e.replRenderer.writeLine(m.dim(` transcript: ${t.path()}`)),g.reset()),R.result!==null&&typeof R.result=="object"&&"kind"in R.result&&R.result.kind==="submit"){l={text:R.result.message,attachments:E??[]},e.statusLine.rearm();continue}e.statusLine.rearm();continue}v=!0}i.push(k);let _=k;if(v){let R=Od(k);if(R){let C=R.name.replace(/^\//,"").split(":").pop()??"";if(C&&bp(C)){let O={skillName:C,rawArgs:R.args,source:"plugin",capabilities:{compose:!0,subagents:!0}},$=e.session.current.sessionId,x=yr($),A=Date.now();J(`[afk trace] preflight.start commandName=${C}`);let P=!1,N=await hr(O,{cwd:e.stats.cwd??process.cwd(),artifactDir:x},K=>{Ke()&&e.replRenderer.writeLine(m.warning(`\u26A0 preflight(${C}) failed: `)+(K instanceof Error?K.message:String(K)))});P=N!==null,J(`[afk trace] preflight.end commandName=${C} durationMs=${Date.now()-A} success=${P}`),_=kp(N?.manifestBlock,k)}}}let I;if(e.firstTurnHook&&e.stats.totalTurns===0){let R=e.firstTurnHook;e.firstTurnHook=void 0,I=Promise.resolve().then(()=>R(k)).catch(C=>{e.completionWriter.fn(m.warning("\u26A0 ")+"first-turn hook failed: "+(C instanceof Error?C.message:String(C)))})}await dT({text:_,attachments:E},e.session.current,e.stats,{setInFlight(R){n.turnInFlight=R},async onTurnComplete(R,C){await t.appendTurn(R,C)},async onAfterTurn(){await e.contextSampler.onTurn(e.stats.totalTurns),await Yw(e.slashCtx),e.statusLine.rearm()},rearmStatus:()=>e.statusLine.rearm(),onTerminalState:R=>g.push(R),setActiveCompositor:R=>{n.activeCompositor=R},scrollRegion:e.statusLine,getCompositor:()=>a.getCompositor(),setBackgroundHandler:R=>a.setBackgroundHandler(R),setSoftStopHandler:R=>a.setSoftStopHandler(R)},e.options.thinkingUi,e.completionWriter,u,a.toRunTurnRefs(ec(e.stats.model,e.stats.planMode))),I!==void 0&&await I}}finally{if(u!==void 0)for(let f of u.running())u.cancel(f.id);d?.stop(),c?.dispose();let p=f=>console.log(f);e.completionWriter.fn=p,e.completionWriter.idleFn=p,await a.dispose(),e.inputSurfaceRef&&(e.inputSurfaceRef.current=null)}}import{execFile as Fj}from"node:child_process";import{dirname as Nj,isAbsolute as Uj,resolve as jj}from"node:path";import{promisify as Bj}from"node:util";var gT=Bj(Fj),Wj=3e3,Hj=new Set(["empty","orphaned-dir","orphaned-registration","dead-owner"]);async function Kj(){let t=(await gT("git",["rev-parse","--git-common-dir"])).stdout.trim();if(!t)throw new Error("Not in a git repository.");let n=Uj(t)?t:jj(process.cwd(),t);return Nj(n)}async function hT(e){if(e?.disabled)return{ran:!1,removedCount:0,skippedReason:"disabled"};let t;try{t=await Kj()}catch{return{ran:!1,removedCount:0,skippedReason:"not-in-repo"}}let n,r=new Promise(o=>{n=setTimeout(()=>o("timeout"),Wj)});try{let o=Ut({execFile:gT,repoRoot:t,dryRun:!1,scope:"interactive",bypassSoftLaunch:!0}),s=await Promise.race([o,r]);if(s==="timeout")return{ran:!1,removedCount:0,skippedReason:"timeout"};let i=s;return i.warnings.some(c=>c.toLowerCase().includes("contested"))?{ran:!1,removedCount:0,skippedReason:"lock-contested"}:{ran:!0,removedCount:i.candidates.filter(c=>Hj.has(c.verdict)&&i.removed.includes(c.path)).length}}catch{return{ran:!1,removedCount:0,skippedReason:"error"}}finally{n&&clearTimeout(n)}}import{promises as Gj}from"node:fs";import{dirname as qj,join as zj}from"node:path";import{randomBytes as Jj}from"node:crypto";var Vj=["Generate a 2-4 word kebab-case slug describing this work request.","Rules:","- ASCII lowercase letters and digits only, separated by single hyphens","- 2 to 4 hyphen-separated words","- Maximum 30 characters total","- No prefix, no quotes, no punctuation other than hyphens","- Output ONLY the slug \u2014 no explanation, no preamble","Examples: fix-cleanup-race, add-telegram-allowlist, refactor-prompt-loader, debug-flaky-test"].join(`
|
|
2199
|
-
`),yT=/^[a-z0-9]+(-[a-z0-9]+){1,3}$/,Kp=30,Yj=1024,Xj=8e3,Zj="haiku";async function Qj(e,t){let n=e.trim();if(n.length===0)return t.onSkip?.("empty-message"),null;if(n.startsWith("/"))return t.onSkip?.("slash-command"),null;let r=rB(n,Yj),o=new AbortController,s=setTimeout(()=>o.abort(),t.timeoutMs??Xj),i=t.signal?oB([t.signal,o.signal]):o.signal,a;try{t.slugGenerator?a=await t.slugGenerator(r,i):a=await Wl({token:t.token,model:t.model??Zj,system:Vj,user:r,maxTokens:32,signal:i})}catch(d){let p=d instanceof Error?d.message:String(d);return t.onSkip?.("slug-generator-error",p.slice(0,200)),null}finally{clearTimeout(s)}let l=eB(a);if(l===null)return t.onSkip?.("invalid-slug-output",a.slice(0,60)),null;let c=qj(t.worktreePath);return await tB(l,c)}function eB(e){let t=e.trim().toLowerCase();if(t.length===0)return null;if(yT.test(t)&&t.length<=Kp)return t;let n=t.replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"");if(n.length===0)return null;let r=n.split("-").filter(s=>s.length>0).slice(0,4);if(r.length<2)return null;let o=r[0];for(let s=1;s<r.length;s++){let i=`${o}-${r[s]}`;if(i.length>Kp)break;o=i}return yT.test(o)?o:null}async function tB(e,t){if(!await nB(zj(t,e)))return e;let n=Jj(2).toString("hex");return`${e.split("-").slice(0,3).join("-").slice(0,Kp-5)}-${n}`}async function nB(e){try{return await Gj.access(e),!0}catch{return!1}}function rB(e,t){let n=Buffer.from(e,"utf8");if(n.length<=t)return e;let r=t;for(;r>0&&n[r]!==void 0&&(n[r]&192)===128;)r--;return n.slice(0,r).toString("utf8")}function oB(e){let t=AbortSignal.any;if(typeof t=="function")return t.call(AbortSignal,e);let n=new AbortController;for(let r of e){if(r.aborted)return n.abort(r.reason),n.signal;r.addEventListener("abort",()=>n.abort(r.reason),{once:!0})}return n.signal}async function wT(e){let t,n,r=await Qj(e.message,{token:e.token,...e.model!==void 0?{model:e.model}:{},...e.timeoutMs!==void 0?{timeoutMs:e.timeoutMs}:{},worktreePath:e.handle.path,...e.signal!==void 0?{signal:e.signal}:{},...e.slugGenerator!==void 0?{slugGenerator:e.slugGenerator}:{},onSkip:(i,a)=>{t=i,n=a}});if(r===null)return{status:"skipped",reason:t??"unknown",...n!==void 0?{detail:n}:{}};let s=await(e.renameFn??qy)(e.handle,r,e.branchPrefix!==void 0?{branchPrefix:e.branchPrefix}:void 0);return s.ok?(e.session&&e.session.setCwd(s.newPath),bT(s.newPath),{status:"renamed",oldPath:s.oldPath,newPath:s.newPath,oldBranch:s.oldBranch,newBranch:s.newBranch}):(s.partial==="branch"&&(e.session&&e.session.setCwd(e.handle.path),bT(e.handle.path)),{status:"failed",reason:s.reason,...s.partial!==void 0?{partial:s.partial}:{}})}function bT(e){try{process.chdir(e)}catch{}}j();import{spawn as ST}from"child_process";import{existsSync as cB,mkdirSync as uB,readFileSync as kT,unlinkSync as dB,writeFileSync as pB}from"fs";import{get as mB}from"https";import{join as vT}from"path";import{readFileSync as sB}from"fs";import{dirname as iB,join as aB}from"path";import{fileURLToPath as lB}from"url";function rn(){try{return"3.
|
|
2199
|
+
`),yT=/^[a-z0-9]+(-[a-z0-9]+){1,3}$/,Kp=30,Yj=1024,Xj=8e3,Zj="haiku";async function Qj(e,t){let n=e.trim();if(n.length===0)return t.onSkip?.("empty-message"),null;if(n.startsWith("/"))return t.onSkip?.("slash-command"),null;let r=rB(n,Yj),o=new AbortController,s=setTimeout(()=>o.abort(),t.timeoutMs??Xj),i=t.signal?oB([t.signal,o.signal]):o.signal,a;try{t.slugGenerator?a=await t.slugGenerator(r,i):a=await Wl({token:t.token,model:t.model??Zj,system:Vj,user:r,maxTokens:32,signal:i})}catch(d){let p=d instanceof Error?d.message:String(d);return t.onSkip?.("slug-generator-error",p.slice(0,200)),null}finally{clearTimeout(s)}let l=eB(a);if(l===null)return t.onSkip?.("invalid-slug-output",a.slice(0,60)),null;let c=qj(t.worktreePath);return await tB(l,c)}function eB(e){let t=e.trim().toLowerCase();if(t.length===0)return null;if(yT.test(t)&&t.length<=Kp)return t;let n=t.replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"");if(n.length===0)return null;let r=n.split("-").filter(s=>s.length>0).slice(0,4);if(r.length<2)return null;let o=r[0];for(let s=1;s<r.length;s++){let i=`${o}-${r[s]}`;if(i.length>Kp)break;o=i}return yT.test(o)?o:null}async function tB(e,t){if(!await nB(zj(t,e)))return e;let n=Jj(2).toString("hex");return`${e.split("-").slice(0,3).join("-").slice(0,Kp-5)}-${n}`}async function nB(e){try{return await Gj.access(e),!0}catch{return!1}}function rB(e,t){let n=Buffer.from(e,"utf8");if(n.length<=t)return e;let r=t;for(;r>0&&n[r]!==void 0&&(n[r]&192)===128;)r--;return n.slice(0,r).toString("utf8")}function oB(e){let t=AbortSignal.any;if(typeof t=="function")return t.call(AbortSignal,e);let n=new AbortController;for(let r of e){if(r.aborted)return n.abort(r.reason),n.signal;r.addEventListener("abort",()=>n.abort(r.reason),{once:!0})}return n.signal}async function wT(e){let t,n,r=await Qj(e.message,{token:e.token,...e.model!==void 0?{model:e.model}:{},...e.timeoutMs!==void 0?{timeoutMs:e.timeoutMs}:{},worktreePath:e.handle.path,...e.signal!==void 0?{signal:e.signal}:{},...e.slugGenerator!==void 0?{slugGenerator:e.slugGenerator}:{},onSkip:(i,a)=>{t=i,n=a}});if(r===null)return{status:"skipped",reason:t??"unknown",...n!==void 0?{detail:n}:{}};let s=await(e.renameFn??qy)(e.handle,r,e.branchPrefix!==void 0?{branchPrefix:e.branchPrefix}:void 0);return s.ok?(e.session&&e.session.setCwd(s.newPath),bT(s.newPath),{status:"renamed",oldPath:s.oldPath,newPath:s.newPath,oldBranch:s.oldBranch,newBranch:s.newBranch}):(s.partial==="branch"&&(e.session&&e.session.setCwd(e.handle.path),bT(e.handle.path)),{status:"failed",reason:s.reason,...s.partial!==void 0?{partial:s.partial}:{}})}function bT(e){try{process.chdir(e)}catch{}}j();import{spawn as ST}from"child_process";import{existsSync as cB,mkdirSync as uB,readFileSync as kT,unlinkSync as dB,writeFileSync as pB}from"fs";import{get as mB}from"https";import{join as vT}from"path";import{readFileSync as sB}from"fs";import{dirname as iB,join as aB}from"path";import{fileURLToPath as lB}from"url";function rn(){try{return"3.50.0"}catch{}try{let e=iB(lB(import.meta.url));for(let t of["../../package.json","../package.json"])try{let n=JSON.parse(sB(aB(e,t),"utf-8"));if(typeof n.version=="string")return n.version}catch{}}catch{}return"0.0.0-unknown"}H();var fB=64*1024,gB=1440*60*1e3,hB="update-check.json",yB="pending-update.json";function TT(){return vT(ui(),hB)}function Gp(){return vT(ui(),yB)}function ET(){let e=ui();cB(e)||uB(e,{recursive:!0})}function bB(e,t){let n=e.split(".").map(Number),r=t.split(".").map(Number),o=Math.max(n.length,r.length);for(let s=0;s<o;s++){let i=n[s]??0,a=r[s]??0;if(a>i)return!0;if(a<i)return!1}return!1}function wB(){try{let e=kT(TT(),"utf-8"),t=JSON.parse(e);if(typeof t.latestVersion=="string"&&typeof t.checkedAt=="number")return t}catch{}return null}function SB(){try{ET();let e=`
|
|
2200
2200
|
const https = require('https');
|
|
2201
2201
|
const fs = require('fs');
|
|
2202
2202
|
const url = 'https://registry.npmjs.org/agent-afk/latest';
|
package/dist/index.mjs
CHANGED
|
@@ -1108,7 +1108,7 @@ ${e.replace(/<\/?cross-session-memory\b[^>]*>/gi,"")}
|
|
|
1108
1108
|
|
|
1109
1109
|
${o}`};if(o&&typeof o=="object"&&"type"in o&&o.type==="preset"){let s=o.append??"";return{...t,systemPrompt:{...o,append:`${r}
|
|
1110
1110
|
|
|
1111
|
-
${s}`}}}return{...t,systemPrompt:r}}import of from"openai";import{randomUUID as sf}from"node:crypto";function xt(t,e){let n=(u,p)=>{if(!(u==null&&p==null))return(u??0)+(p??0)},r=(u,p)=>p!==void 0?p:u,o={stopReason:e.stopReason??t.stopReason??null},s=n(t.inputTokens,e.inputTokens);s!==void 0&&(o.inputTokens=s);let i=n(t.outputTokens,e.outputTokens);i!==void 0&&(o.outputTokens=i);let a=r(t.cachedInputTokens,e.cachedInputTokens);a!==void 0&&(o.cachedInputTokens=a);let c=r(t.cacheCreationTokens,e.cacheCreationTokens);c!==void 0&&(o.cacheCreationTokens=c);let l=n(t.totalTokens,e.totalTokens);l!==void 0&&(o.totalTokens=l);let d=n(t.totalCostUsd,e.totalCostUsd);return d!==void 0&&(o.totalCostUsd=d),o}var zp={opus:128e3,opus_1m:128e3,sonnet:64e3,sonnet_1m:64e3,haiku:64e3,"claude-opus-4-
|
|
1111
|
+
${s}`}}}return{...t,systemPrompt:r}}import of from"openai";import{randomUUID as sf}from"node:crypto";function xt(t,e){let n=(u,p)=>{if(!(u==null&&p==null))return(u??0)+(p??0)},r=(u,p)=>p!==void 0?p:u,o={stopReason:e.stopReason??t.stopReason??null},s=n(t.inputTokens,e.inputTokens);s!==void 0&&(o.inputTokens=s);let i=n(t.outputTokens,e.outputTokens);i!==void 0&&(o.outputTokens=i);let a=r(t.cachedInputTokens,e.cachedInputTokens);a!==void 0&&(o.cachedInputTokens=a);let c=r(t.cacheCreationTokens,e.cacheCreationTokens);c!==void 0&&(o.cacheCreationTokens=c);let l=n(t.totalTokens,e.totalTokens);l!==void 0&&(o.totalTokens=l);let d=n(t.totalCostUsd,e.totalCostUsd);return d!==void 0&&(o.totalCostUsd=d),o}var zp={opus:128e3,opus_1m:128e3,sonnet:64e3,sonnet_1m:64e3,haiku:64e3,"claude-opus-4-8":128e3,"claude-sonnet-4-6":64e3,"claude-haiku-4-5-20251001":64e3},Jp=64e3;function hi(t){return zp[t]??Jp}var gi={opus:2e5,opus_1m:1e6,sonnet:2e5,sonnet_1m:1e6,haiku:2e5,"gpt-4o":128e3,"gpt-4o-mini":128e3,"gpt-4.1":1e6,"gpt-4.1-mini":1e6,o1:2e5,"o1-mini":128e3,o3:2e5,"o3-mini":2e5,"o4-mini":2e5,"mlx-community/qwen3-30b-a3b-4bit":128e3,"mlx-community/qwen3-32b-4bit":128e3,"mlx-community/qwen2.5-coder-32b-instruct-4bit":131072},Vp=2e5,Yp=262144;function Xp(t){if(!t)return!1;let e=t.trim().toLowerCase();return e?!!(e.includes("/")||e.startsWith("gpt-")||e.startsWith("gpt_")||e.startsWith("o1")||e.startsWith("o3")||e.startsWith("o4")||e.startsWith("codex-")||e.startsWith("codex_")||e==="codex"):!1}function Tt(t){let e=gi[t]??gi[t.toLowerCase()];return e!==void 0?e:Xp(t)?Yp:Vp}import{readFileSync as Qp}from"node:fs";import{homedir as Zp}from"node:os";import{join as ef}from"node:path";function tf(t){try{return Qp(t,"utf-8")}catch{return null}}function vr(t,e={}){let n=e.readEnv??(c=>process.env[c]),r=(e.homedir??Zp)(),o=e.readFile??tf;if(t&&t.length>0)return{apiKey:t,source:"config",last4:kr(t)};let s=n("OPENAI_API_KEY");if(s&&s.length>0)return{apiKey:s,source:"env",last4:kr(s)};let i=ef(r,".codex","auth.json"),a=o(i);if(a!==null){let c=nf(a);if(c.kind==="apikey")return{apiKey:c.apiKey,source:"codex-cli",last4:kr(c.apiKey)};if(c.kind==="chatgpt")return{apiKey:null,source:"no-usable-auth-codex-oauth"}}return{apiKey:null,source:"no-usable-auth"}}function nf(t){let e;try{e=JSON.parse(t)}catch{return{kind:"invalid"}}if(typeof e!="object"||e===null)return{kind:"invalid"};let n=e,r=n.OPENAI_API_KEY;return typeof r=="string"&&r.length>0?{kind:"apikey",apiKey:r}:n.auth_mode==="chatgpt"?{kind:"chatgpt"}:{kind:"no-key"}}function kr(t){return t.length<=4?t:t.slice(-4)}function _r(t){switch(t.source){case"config":return`using explicit AFK config API key (\u2026${t.last4??"????"})`;case"env":return`using OPENAI_API_KEY env var (\u2026${t.last4??"????"})`;case"codex-cli":return`using Codex CLI API key from ~/.codex/auth.json (\u2026${t.last4??"????"})`;case"no-usable-auth-codex-oauth":return"AFK OpenAI provider currently requires API key auth. Found ChatGPT/OAuth credentials in ~/.codex/auth.json but no API key. Run `codex login --api-key` or set OPENAI_API_KEY.";default:return"No OpenAI auth found. Set OPENAI_API_KEY, pass an explicit apiKey in AFK config, or run `codex login --api-key`."}}function yi(t){return typeof t=="string"?t:t.map(e=>{if(typeof e=="object"&&e&&"type"in e){if(e.type==="text")return e.text;if(e.type==="image")return"[image omitted]"}return""}).join(`
|
|
1112
1112
|
`)}function rf(t){let e=t.systemPrompt;if(e!==void 0){if(typeof e=="string")return e.length>0?e:void 0;if(typeof e=="object"&&e!==null&&"append"in e){let n=e.append;return n&&n.length>0?n:void 0}}}function bi(t){let e=[],n=rf(t.config);if(n!==void 0&&e.push({role:"system",content:n}),t.resumeHistory)for(let r of t.resumeHistory)r.user&&e.push({role:"user",content:r.user}),r.assistant&&e.push({role:"assistant",content:r.assistant});if(t.priorTurns)for(let r of t.priorTurns)e.push(r);return t.currentUserText!==void 0&&e.push({role:"user",content:t.currentUserText}),e}function wi(){return{assistantText:"",reasoningText:"",toolCallsByIndex:new Map,finishReason:null,usage:null,model:null,id:null}}function*Si(t,e,n){t.id&&!e.id&&(e.id=t.id),t.model&&!e.model&&(e.model=t.model),t.usage&&(e.usage=t.usage);let r=t.choices?.[0];if(!r)return;r.finish_reason&&(e.finishReason=r.finish_reason);let o=r.delta;if(!o)return;let s=o.reasoning_content??o.reasoning;if(typeof s=="string"&&s.length>0&&(e.reasoningText+=s,yield{type:"delta.reasoning",text:s,sessionId:n}),typeof o.content=="string"&&o.content.length>0&&(e.assistantText+=o.content,yield{type:"delta.text",text:o.content,sessionId:n}),o.tool_calls&&o.tool_calls.length>0)for(let i of o.tool_calls){let a=e.toolCallsByIndex.get(i.index)??{index:i.index,id:"",name:"",argumentsRaw:"",startEmitted:!1};i.id&&(a.id=i.id),i.function?.name&&(a.name=i.function.name),i.function?.arguments&&(a.argumentsRaw+=i.function.arguments),e.toolCallsByIndex.set(i.index,a)}}function ki(t){let e=t.usage;if(!e)return{stopReason:t.finishReason??null,resultSubtype:"success",isError:!1};let n=e.prompt_tokens_details?.cached_tokens??0,r=e.prompt_tokens??0,o=e.completion_tokens??0;return{inputTokens:r,outputTokens:o,cachedInputTokens:n,totalTokens:e.total_tokens??r+o,stopReason:t.finishReason??null,resultSubtype:"success",isError:!1,raw:{...e}}}function Er(t){return[...t.toolCallsByIndex.values()].sort((e,n)=>e.index-n.index)}function vi(t){return t.finishReason==="tool_calls"||t.finishReason==="function_call"?!0:t.toolCallsByIndex.size>0}function _i(t){return t.map(e=>{let n={name:e.name,parameters:e.input_schema};return e.description!==void 0&&(n.description=e.description),{type:"function",function:n}})}function Ei(t,e){let n=[],r=new Map;for(let o of t){let s={};if(o.argumentsRaw.length>0)try{s=JSON.parse(o.argumentsRaw)}catch(i){let a=i instanceof Error?i.message:String(i);r.set(o.id,`Failed to parse tool arguments as JSON: ${a}`),s={}}n.push({id:o.id,name:o.name,input:s,signal:e})}return{calls:n,parseErrors:r}}function Ai(t,e,n=""){let r={role:"assistant",content:t.length>0?t:null,tool_calls:e.map(o=>({id:o.id,type:"function",function:{name:o.name,arguments:o.argumentsRaw}}))};return n.length>0&&(r.reasoning_content=n),r}function xi(t){return t.map(({call:e,result:n})=>({role:"tool",tool_call_id:e.id,content:n.isError?`[error] ${n.content}`:n.content}))}function Rt(t){return(t.inputTokens??0)+(t.outputTokens??0)}function Ti(t,e,n){return e<=0||t<=0||n<=0||n>=1?!1:t/e>=n}var Ar="openai-compatible",af=50,cf=null;function Ri(t){return t??"default"}var cn=class{client;opts;initSessionId;toolDispatcher;openAITools;priorTurns=[];currentModel;currentPermissionMode;abortController=null;pendingAbortReason=null;closed=!1;closeResolve=null;closedPromise;lastUsage=null;constructor(e){if(this.opts=e,this.initSessionId=e.synthesizedSessionId,this.currentModel=e.model,this.currentPermissionMode=Ri(e.config.permissionMode),this.toolDispatcher=e.toolDispatcher,this.toolDispatcher){let n=this.toolDispatcher;Array.isArray(n.toolDefs)&&n.toolDefs.length>0&&(this.openAITools=_i(n.toolDefs))}if(e.auth.apiKey===null)this.client=null;else{let n=cf??lf,r={apiKey:e.auth.apiKey};e.baseURL!==void 0&&(r.baseURL=e.baseURL),this.client=n(r)}this.closedPromise=new Promise(n=>{this.closeResolve=()=>n("__closed__")})}async*[Symbol.asyncIterator](){if(yield{type:"session.init",info:{sessionId:this.initSessionId,model:this.currentModel,permissionMode:this.currentPermissionMode,cwd:process.cwd(),tools:this.openAITools?this.openAITools.map(r=>r.function.name):[],slashCommands:[],skills:[],plugins:[],mcpServers:this.opts.mcpManager?.getServerStates().map(r=>({name:r.serverName,status:r.status}))??[],apiKeySource:this.opts.auth.source,version:Ar}},this.opts.auth.apiKey===null){yield{type:"error",error:new Error(_r(this.opts.auth))};return}let n=this.opts.promptStream[Symbol.asyncIterator]();try{for(;!this.closed;){let r=await Promise.race([n.next(),this.closedPromise]);if(r==="__closed__")break;let o=r;if(o.done)break;let s=yi(o.value.content);yield*this.runTurn(s)}}catch(r){yield{type:"error",error:r instanceof Error?r:new Error(String(r))}}finally{try{await n.return?.()}catch{}}}async*runTurn(e){let n=new AbortController;if(this.abortController=n,this.pendingAbortReason!==null&&!n.signal.aborted&&(n.abort(this.pendingAbortReason),this.pendingAbortReason=null),n.signal.aborted)return;let r=Date.now(),o=sf();this.priorTurns.push({role:"user",content:e});let s={stopReason:null,resultSubtype:"success",isError:!1},i="",a="";for(let c=0;c<af;c++){if(n.signal.aborted){this.abortController===n&&(this.abortController=null);return}let l=yield*this.runIteration(n);if(l===null){this.abortController===n&&(this.abortController=null);return}if(s=xt(s,ki(l.state)),l.text.length>0&&(i=l.text),a=l.state.reasoningText,!l.needsToolDispatch)break;yield*this.dispatchAndAppend(l.state,n.signal);{let d=Er(l.state).at(-1)?.name;yield{type:"progress",progress:{taskId:o,description:"Tool-use loop",summary:`Iteration ${c+1}: used ${d??"unknown"}`,lastToolName:d,totalTokens:s.totalTokens??0,toolUses:c+1,durationMs:Date.now()-r},sessionId:this.initSessionId}}if(n.signal.aborted){this.abortController===n&&(this.abortController=null);return}}if(this.abortController===n&&(this.abortController=null),i.length>0){let c={role:"assistant",content:i};a.length>0&&(c.reasoning_content=a),this.priorTurns.push(c)}this.lastUsage=s,yield{type:"assistant.message",text:i,sessionId:this.initSessionId},yield{type:"turn.completed",usage:{...s,durationMs:Date.now()-r},sessionId:this.initSessionId}}async*runIteration(e){let n=bi({config:this.opts.config,...this.opts.config.resumeHistory!==void 0?{resumeHistory:this.opts.config.resumeHistory}:{},priorTurns:this.priorTurns});this.currentPermissionMode==="plan"&&n[0]?.role==="system"&&(n[0]={...n[0],content:n[0].content+`
|
|
1113
1113
|
|
|
1114
1114
|
`+Hn});let r=wi(),o={model:this.currentModel,messages:n,stream:!0,stream_options:{include_usage:!0}};this.openAITools&&this.openAITools.length>0&&(o.tools=this.openAITools);let s;try{s=await this.client.chat.completions.create(o,{signal:e.signal})}catch(i){return e.signal.aborted||(yield{type:"error",error:i instanceof Error?i:new Error(String(i))}),null}try{for await(let i of s){if(this.closed)return null;for(let a of Si(i,r,this.initSessionId))yield a}}catch(i){return e.signal.aborted||(yield{type:"error",error:i instanceof Error?i:new Error(String(i))}),null}return{state:r,events:[],text:r.assistantText,needsToolDispatch:vi(r)&&r.toolCallsByIndex.size>0}}async*dispatchAndAppend(e,n){if(!this.toolDispatcher)return;let r=Er(e),{calls:o,parseErrors:s}=Ei(r,n);for(let a of o)yield{type:"tool.use.start",toolUseId:a.id,toolName:a.name,toolInput:df(a.input),sessionId:this.initSessionId};let i=[];if(n.aborted)for(let a of o){let c={content:"Tool call aborted",isError:!0};i.push({call:a,result:c}),yield{type:"tool.output",toolUseId:a.id,toolName:a.name,content:c.content,isError:!0,sessionId:this.initSessionId}}else{let a;try{if(this.toolDispatcher.executeBatch)a=await this.toolDispatcher.executeBatch(o);else{a=[];for(let c of o){if(n.aborted){a.push({content:"Tool call aborted",isError:!0});continue}try{a.push(await this.toolDispatcher.execute(c))}catch(l){let d=l instanceof Error?l.message:String(l);a.push({content:`Tool execution threw: ${d}`,isError:!0})}}}}catch(c){let l=c instanceof Error?c.message:String(c);a=o.map(()=>({content:`Tool batch execution failed: ${l}`,isError:!0}))}for(let c=0;c<o.length;c++){let l=o[c],d=a[c],u=s.get(l.id);u!==void 0&&(d={content:`${u}
|
|
@@ -1508,7 +1508,7 @@ Be skeptical. Protect the plugin from fluff. Stage 2 catches patterns that are s
|
|
|
1508
1508
|
|
|
1509
1509
|
${f}`);if(P.status!=="succeeded")throw new Error(`skill generation failed: ${q(P)}`);let O=P.message?.content||"";if(!O)throw new Error("skill generation returned no output");for(let R=1;R<=c;R++){let M=Nr.systemPrompt;if(!M)throw new Error("qualify agent missing system prompt");let k=await(await new F({apiKey:r}).forkSubagent({parent:{sessionId:e.sessionId},config:{model:"sonnet",systemPrompt:M},idPrefix:`forge-qualify-${R}`,...o?{parentId:o}:{}})).runToResult(`Evaluate this amplifier skill against the force-multiplier criteria:
|
|
1510
1510
|
|
|
1511
|
-
${O}`);if(k.status!=="succeeded")throw new Error(`qualify iteration ${R} failed: ${q(k)}`);let T=k.message?.content||"",{verdict:C,score:B,feedback:H}=la(T),N={iteration:R,verdict:C,score:B,feedback:H};if(d.push(N),l=await Q({event:"forge.qualify_iteration",iteration:R,verdict:C,score:B||null,feedback:H||null}),C==="APPROVE"){u="APPROVED";break}else if(C==="SALVAGE"&&R<c){let V=_["qualify-rework.md"];if(!V)throw new Error("forge skill missing qualify-rework.md prompt");let $=V.replace("{feedback}",H).replace("{original_skill}",O),Le=await(await new F({apiKey:r}).forkSubagent({parent:{sessionId:e.sessionId},config:{model:"sonnet",systemPrompt:$},idPrefix:`forge-rework-${R}`,...o?{parentId:o}:{}})).runToResult("Refine the skill based on the feedback.");if(Le.status!=="succeeded")throw new Error(`rework iteration ${R} failed: ${q(Le)}`);if(O=Le.message?.content||"",!O)throw new Error(`rework iteration ${R} returned no output`)}else C==="REJECT"&&R>=c&&(u="MAX_ITERATIONS")}if(u==="APPROVED"){let R=Wm(O);if(!R.ok)throw l=await Q({event:"forge.write_failed",reason:R.reason,skill_name_attempted:R.skillNameAttempted}),new Error(`forge write-step invariant failed (${R.reason}): ${R.message}`);let M=R.skillName,E=R.recoveredContent??O;R.recoveredContent!==void 0&&(l=await Q({event:"forge.preamble_recovered",skill_name:M,bytes_trimmed:O.length-R.recoveredContent.length}));let A=Ur(M,{skillsDir:ze(),registeredSkills:pt()});if(A)throw l=await Q({event:"forge.write_failed",reason:A.reason,skill_name_attempted:A.skillNameAttempted}),new Error(`forge write-step invariant failed (${A.reason}): ${A.message}`);let k=ve(ze(),M);await pa(k,{recursive:!0});let T=ve(k,"SKILL.md");await fa(T,E,"utf-8");let C;try{C=await Cm(T,"utf-8")}catch{C=""}if(!C.startsWith("---"))throw l=await Q({event:"forge.write_failed",reason:"readback_failed",skill_name_attempted:M}),new Error(`forge write-step invariant failed (readback_failed): written file at ${T} did not read back with expected frontmatter`);p=T,b&&g&&await $r(g,"consumed"),l=await Q({event:"forge.complete",status:"APPROVED",skill_name:M,iterations:d.length})}else u==="MAX_ITERATIONS"&&(b&&g&&await $r(g,"failed"),l=await Q({event:"forge.complete",status:"MAX_ITERATIONS",skill_name_attempted:f||null,iterations:d.length}))}catch(m){throw l=await Q({event:"forge.error",error:m instanceof Error?m.message:String(m)}),m}return{status:u,skill_path:p,qualify_verdicts:d,brief_id:g,telemetry_ref:l}}var qm={name:"forge",description:'Creates new amplifier skills gated by forge-gate-check, with autonomous gap discovery, skill generation, and qualify iteration loop \u22643\xD7. Writes approved skills and appends telemetry to shared JSONL with surface: "afk".',handler:Gm,argumentHint:"[--brief <path>]",whenToUse:"When the user wants to grow the plugin with a new amplifier skill \u2014 autonomously generates and validates one.",flags:["--brief"]};Z(qm);import{config as ZA}from"dotenv";var hn={opus:"claude-opus-4-
|
|
1511
|
+
${O}`);if(k.status!=="succeeded")throw new Error(`qualify iteration ${R} failed: ${q(k)}`);let T=k.message?.content||"",{verdict:C,score:B,feedback:H}=la(T),N={iteration:R,verdict:C,score:B,feedback:H};if(d.push(N),l=await Q({event:"forge.qualify_iteration",iteration:R,verdict:C,score:B||null,feedback:H||null}),C==="APPROVE"){u="APPROVED";break}else if(C==="SALVAGE"&&R<c){let V=_["qualify-rework.md"];if(!V)throw new Error("forge skill missing qualify-rework.md prompt");let $=V.replace("{feedback}",H).replace("{original_skill}",O),Le=await(await new F({apiKey:r}).forkSubagent({parent:{sessionId:e.sessionId},config:{model:"sonnet",systemPrompt:$},idPrefix:`forge-rework-${R}`,...o?{parentId:o}:{}})).runToResult("Refine the skill based on the feedback.");if(Le.status!=="succeeded")throw new Error(`rework iteration ${R} failed: ${q(Le)}`);if(O=Le.message?.content||"",!O)throw new Error(`rework iteration ${R} returned no output`)}else C==="REJECT"&&R>=c&&(u="MAX_ITERATIONS")}if(u==="APPROVED"){let R=Wm(O);if(!R.ok)throw l=await Q({event:"forge.write_failed",reason:R.reason,skill_name_attempted:R.skillNameAttempted}),new Error(`forge write-step invariant failed (${R.reason}): ${R.message}`);let M=R.skillName,E=R.recoveredContent??O;R.recoveredContent!==void 0&&(l=await Q({event:"forge.preamble_recovered",skill_name:M,bytes_trimmed:O.length-R.recoveredContent.length}));let A=Ur(M,{skillsDir:ze(),registeredSkills:pt()});if(A)throw l=await Q({event:"forge.write_failed",reason:A.reason,skill_name_attempted:A.skillNameAttempted}),new Error(`forge write-step invariant failed (${A.reason}): ${A.message}`);let k=ve(ze(),M);await pa(k,{recursive:!0});let T=ve(k,"SKILL.md");await fa(T,E,"utf-8");let C;try{C=await Cm(T,"utf-8")}catch{C=""}if(!C.startsWith("---"))throw l=await Q({event:"forge.write_failed",reason:"readback_failed",skill_name_attempted:M}),new Error(`forge write-step invariant failed (readback_failed): written file at ${T} did not read back with expected frontmatter`);p=T,b&&g&&await $r(g,"consumed"),l=await Q({event:"forge.complete",status:"APPROVED",skill_name:M,iterations:d.length})}else u==="MAX_ITERATIONS"&&(b&&g&&await $r(g,"failed"),l=await Q({event:"forge.complete",status:"MAX_ITERATIONS",skill_name_attempted:f||null,iterations:d.length}))}catch(m){throw l=await Q({event:"forge.error",error:m instanceof Error?m.message:String(m)}),m}return{status:u,skill_path:p,qualify_verdicts:d,brief_id:g,telemetry_ref:l}}var qm={name:"forge",description:'Creates new amplifier skills gated by forge-gate-check, with autonomous gap discovery, skill generation, and qualify iteration loop \u22643\xD7. Writes approved skills and appends telemetry to shared JSONL with surface: "afk".',handler:Gm,argumentHint:"[--brief <path>]",whenToUse:"When the user wants to grow the plugin with a new amplifier skill \u2014 autonomously generates and validates one.",flags:["--brief"]};Z(qm);import{config as ZA}from"dotenv";var hn={opus:"claude-opus-4-8",opus_1m:"claude-opus-4-8",sonnet:"claude-sonnet-4-6",sonnet_1m:"claude-sonnet-4-6",haiku:"claude-haiku-4-5-20251001"};function ga(t){return t in hn}function ha(t){let e=hn[t];if(!e)throw new Error(`Invalid model: ${t}`);return e}function Ct(t){if(t!==void 0)return typeof t=="string"&&ga(t)?ha(t):t}U();L();import{execFile as zm}from"node:child_process";import{promisify as Jm}from"node:util";L();U();L();var GA=Jm(zm);L();function ya(){return v.ANTHROPIC_API_KEY||v.CLAUDE_CODE_OAUTH_TOKEN||se()}L();function X(){let t=v.AFK_MODEL??v.CLAUDE_MODEL;return Ym(t)}function Vm(){return v.OPENAI_API_KEY||v.CODEX_API_KEY||void 0}function Ym(t){let e=de(t);return e==="openai-compatible"||e==="openai-codex"?Vm():ya()}async function ba(t,e,n,r){let s=K("mint")["spec.md"];if(!s)throw new Error("mint skill missing spec.md prompt");let c=await(await new F(n!==void 0?{cwd:n}:{}).forkSubagent({parent:{sessionId:e},config:{model:"sonnet",systemPrompt:s,apiKey:X()},idPrefix:"mint-spec",phaseRole:"read-only",...r?{parentId:r}:{}})).runToResult(`Create a detailed specification for: ${t}`);if(c.status!=="succeeded"||!c.message)throw new Error(`spec phase failed: ${q(c)}`);return c.message.content}async function wa(t,e,n,r){let s=K("mint")["research.md"];if(!s)throw new Error("mint skill missing research.md prompt");let c=await(await new F(n!==void 0?{cwd:n}:{}).forkSubagent({parent:{sessionId:e},config:{model:"sonnet",systemPrompt:s,apiKey:X()},idPrefix:"mint-research",phaseRole:"read-only",...r?{parentId:r}:{}})).runToResult(`Gather context and research for this specification:
|
|
1512
1512
|
|
|
1513
1513
|
${t}`);if(c.status!=="succeeded"||!c.message)throw new Error(`research phase failed: ${q(c)}`);return c.message.content}async function Sa(t,e,n,r,o){let i=K("mint")["plan.md"];if(!i)throw new Error("mint skill missing plan.md prompt");let c=await new F(r!==void 0?{cwd:r}:{}).forkSubagent({parent:{sessionId:n},config:{model:"sonnet",systemPrompt:i,apiKey:X()},idPrefix:"mint-plan",phaseRole:"read-only",...o?{parentId:o}:{}}),l=`Specification:
|
|
1514
1514
|
${t}
|
|
@@ -1623,7 +1623,7 @@ ${zr}`,S=[h,Jr];S.push(Ye({cwd:y,...n.sessionId!==void 0?{sessionId:n.sessionId}
|
|
|
1623
1623
|
|
|
1624
1624
|
`),P=[h,Jr];_.length>0&&P.push(_),d&&P.push(d),Xa({prompt:e.prompt,options:{model:u,maxTokens:p,system:x},provenance:{systemPrompt:{source:n.systemPromptSource??"none",shape:typeof n.systemPrompt=="string"?"string":Array.isArray(n.systemPrompt)?"string[]":n.systemPrompt!=null?"preset":"undefined",...typeof n.systemPrompt=="string"?{length:n.systemPrompt.length}:{}},...n.apiKey?{apiKey:{source:"config"}}:{}}});let O;if(s==="oauth"&&!r){let k=this.providerFactory??Za;O=async()=>{let T=await Bn();if(!T)return null;let C=Un(T,"oauth",n.baseUrl);return k?k(C):new Qa(C)}}let R=n.sessionId??n.resume,M=gh(n.resumeHistory),E=this.externalTools?void 0:k=>{let T=this._currentCwd;if(this._sharedReadRoots&&T!==void 0&&T!==k){let N=this._sharedReadRoots.indexOf(T);N!==-1?this._sharedReadRoots[N]=k:this._sharedReadRoots.includes(k)||this._sharedReadRoots.push(k)}if(this._sharedWriteRoots&&T!==void 0&&T!==k){let N=this._sharedWriteRoots.indexOf(T);N!==-1?this._sharedWriteRoots[N]=k:this._sharedWriteRoots.includes(k)||this._sharedWriteRoots.push(k)}this._currentCwd=k;let B=[P[0],P[1],Ye({cwd:k,...n.sessionId!==void 0?{sessionId:n.sessionId}:{},surface:this.surface,...n.depth!==void 0?{depth:n.depth}:{},...n.maxDepth!==void 0?{maxDepth:n.maxDepth}:{},workspace:f.getWorkspace()}),...P.slice(2)].join(`
|
|
1625
1625
|
|
|
1626
|
-
`),H=this.buildDispatcher(g,{cwd:k,readRoots:this._sharedReadRoots,writeRoots:this._sharedWriteRoots,...n.env!==void 0?{env:n.env}:{},sessionId:n.sessionId,traceWriter:n.traceWriter,runtimeStateSource:f});return{userSystem:B,dispatcher:H}},A=yh(n.effort,u);return new Sn({client:c,authMode:r?"api-key":s,promptStream:e.prompt,toolDispatcher:m,...R!==void 0?{sessionId:R}:{},...M!==void 0?{initialMessages:M}:{},model:u,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},maxTokens:p,tools:w,userSystem:x,systemPrefix:l,tokenRefresher:O,...n.thinking!==void 0?{thinking:hh(n.thinking,p,u)}:{},...A!==void 0?{effort:A}:{},...r?{baseUrl:n.baseUrl}:{},...n.traceWriter?{traceWriter:n.traceWriter}:{},...n.autoResumeOnUsageLimit!==void 0?{autoResumeOnUsageLimit:n.autoResumeOnUsageLimit}:{},...E!==void 0?{cwdDependentsFactory:E}:{},...this.mcpManager!==void 0?{mcpManager:this.mcpManager}:{},...ec(n.autoCompact)!==void 0?{autoCompactThreshold:ec(n.autoCompact)}:{}})}};function ph(t){if(t===void 0)return null;if(typeof t=="string")return t.length>0?t:null;if(typeof t=="object"&&t!==null&&"append"in t){let e=t.append;return e&&e.length>0?e:null}return null}var fh=.9;function ec(t){if(t===void 0||t===!1)return;if(t===!0)return fh;let e=t.threshold;if(!(typeof e!="number"||!Number.isFinite(e)||e<=0||e>=1))return e}function mh(t,e){let n=t.maxOutputTokens;return typeof n=="number"&&Number.isFinite(n)&&n>0?Math.floor(n):hi(e)}function gh(t){if(!t||t.length===0)return;let e=[];for(let n of t)n.user.length>0&&e.push({role:"user",content:n.user}),n.assistant.length>0&&e.push({role:"assistant",content:n.assistant});return e.length>0?e:void 0}function hh(t,e,n){switch(t.type){case"adaptive":return{type:"adaptive",display:"summarized"};case"disabled":return{type:"disabled"};case"enabled":{if(typeof n=="string"&&uh(n))return{type:"adaptive",display:"summarized"};let r=t.budgetTokens!==void 0&&Number.isFinite(t.budgetTokens)?Math.min(t.budgetTokens,e-1):e-1;return{type:"enabled",budget_tokens:Math.max(r,1024),display:"summarized"}}}}function yh(t,e){if(t!==void 0)return t;let n=e.toLowerCase();if(/(claude-)?(opus|sonnet)-4-[
|
|
1626
|
+
`),H=this.buildDispatcher(g,{cwd:k,readRoots:this._sharedReadRoots,writeRoots:this._sharedWriteRoots,...n.env!==void 0?{env:n.env}:{},sessionId:n.sessionId,traceWriter:n.traceWriter,runtimeStateSource:f});return{userSystem:B,dispatcher:H}},A=yh(n.effort,u);return new Sn({client:c,authMode:r?"api-key":s,promptStream:e.prompt,toolDispatcher:m,...R!==void 0?{sessionId:R}:{},...M!==void 0?{initialMessages:M}:{},model:u,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},maxTokens:p,tools:w,userSystem:x,systemPrefix:l,tokenRefresher:O,...n.thinking!==void 0?{thinking:hh(n.thinking,p,u)}:{},...A!==void 0?{effort:A}:{},...r?{baseUrl:n.baseUrl}:{},...n.traceWriter?{traceWriter:n.traceWriter}:{},...n.autoResumeOnUsageLimit!==void 0?{autoResumeOnUsageLimit:n.autoResumeOnUsageLimit}:{},...E!==void 0?{cwdDependentsFactory:E}:{},...this.mcpManager!==void 0?{mcpManager:this.mcpManager}:{},...ec(n.autoCompact)!==void 0?{autoCompactThreshold:ec(n.autoCompact)}:{}})}};function ph(t){if(t===void 0)return null;if(typeof t=="string")return t.length>0?t:null;if(typeof t=="object"&&t!==null&&"append"in t){let e=t.append;return e&&e.length>0?e:null}return null}var fh=.9;function ec(t){if(t===void 0||t===!1)return;if(t===!0)return fh;let e=t.threshold;if(!(typeof e!="number"||!Number.isFinite(e)||e<=0||e>=1))return e}function mh(t,e){let n=t.maxOutputTokens;return typeof n=="number"&&Number.isFinite(n)&&n>0?Math.floor(n):hi(e)}function gh(t){if(!t||t.length===0)return;let e=[];for(let n of t)n.user.length>0&&e.push({role:"user",content:n.user}),n.assistant.length>0&&e.push({role:"assistant",content:n.assistant});return e.length>0?e:void 0}function hh(t,e,n){switch(t.type){case"adaptive":return{type:"adaptive",display:"summarized"};case"disabled":return{type:"disabled"};case"enabled":{if(typeof n=="string"&&uh(n))return{type:"adaptive",display:"summarized"};let r=t.budgetTokens!==void 0&&Number.isFinite(t.budgetTokens)?Math.min(t.budgetTokens,e-1):e-1;return{type:"enabled",budget_tokens:Math.max(r,1024),display:"summarized"}}}}function yh(t,e){if(t!==void 0)return t;let n=e.toLowerCase();if(/(claude-)?(opus|sonnet)-4-[678]/.test(n))return"max"}var bh=new we;L();var wh=new Set([...Object.keys(hn),"auto"]);function Sh(t){if(!t)return;let e=t.trim().toLowerCase();if(e){if(e==="anthropic"||e==="anthropic-direct")return"anthropic-direct";if(e==="openai"||e==="openai-compatible"||e==="openai-codex")return"openai-compatible"}}function de(t,e){let n=e?.explicit??v.AFK_PROVIDER,r=e?.openaiBaseUrl??v.AFK_OPENAI_BASE_URL,o=Sh(n);if(o)return o;let s=(t??"").trim().toLowerCase();return s&&(wh.has(s)||s.startsWith("claude-")||s.startsWith("claude_")||s.startsWith("local-")||s.startsWith("local_"))?"anthropic-direct":s&&(s.startsWith("gpt-")||s.startsWith("gpt_")||s.startsWith("o1")||s.startsWith("o3")||s.startsWith("o4")||s.startsWith("codex-")||s.startsWith("codex_")||s==="codex"||s.startsWith("deepseek-")||s.startsWith("deepseek_")||s.startsWith("mistral-")||s.startsWith("mistral_")||s.startsWith("mixtral-")||s.startsWith("mixtral_")||s.startsWith("llama-")||s.startsWith("llama_")||s.startsWith("qwen-")||s.startsWith("qwen_")||s.includes("/"))||r&&r.trim()?"openai-compatible":"anthropic-direct"}function _n(t,e){switch(de(t,e)){case"openai-compatible":case"openai-codex":return new le;default:return new we}}async function En(t,e,n){if(!t)return;if(n.kind==="blocked"){await Ge(t,{hookEvent:e,decision:"block",...n.err.reason!==void 0?{reason:n.err.reason}:{}});return}let r=n.decision;await Ge(t,{hookEvent:e,decision:r.decision,...r.reason!==void 0?{reason:r.reason}:{},...r.injectContext!==void 0?{injectedContextBytes:Buffer.byteLength(r.injectContext,"utf8")}:{}})}async function tc(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await En(n.traceWriter,"SessionStart",{kind:"decision",decision:r})}catch(r){throw r instanceof Y&&await En(n.traceWriter,"SessionStart",{kind:"blocked",err:r}),r}}async function nc(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await En(n.traceWriter,"SessionEnd",{kind:"decision",decision:r})}catch(r){if(r instanceof Y&&await En(n.traceWriter,"SessionEnd",{kind:"blocked",err:r}),r instanceof Y||r instanceof oe){D(`SessionEnd hook swallowed ${r.name}: ${r.message}`),n.onError?.(r);return}D(`SessionEnd hook unexpected error: ${String(r)}`),n.onError?.(r instanceof Error?r:new Error(String(r)))}}var An=class{pendingResolve=null;bufferedMessage=null;getSessionId;constructor(e){this.getSessionId=e}pushUserMessage(e){if(this.pendingResolve){let n=this.pendingResolve;this.pendingResolve=null;let r=this.getSessionId();n({content:e,...r!==void 0?{sessionId:r}:{}});return}this.bufferedMessage=e}createIterable(){let e=this;return{[Symbol.asyncIterator](){return{next(){if(e.bufferedMessage!==null){let n=e.bufferedMessage;e.bufferedMessage=null;let r=e.getSessionId();return Promise.resolve({value:{content:n,...r!==void 0?{sessionId:r}:{}},done:!1})}return new Promise(n=>{e.pendingResolve=r=>n({value:r,done:!1})})},return(){return Promise.resolve({value:void 0,done:!0})}}}}}};function rc(t,e,n){t&&(t.aborted?e.abort(t.reason):t.addEventListener("abort",()=>{e.signal.aborted||e.abort(t.reason)},{once:!0})),e.signal.addEventListener("abort",n,{once:!0})}function oc(t,e){let n=t.permissionMode??"default",r=t.persistSession??!0,o={sessionId:t.sessionId,configuredSessionId:t.sessionId,resume:t.resume,resumeSessionAt:t.resumeSessionAt,continue:t.continue,forkSession:t.forkSession,persistSession:r},s={sessionId:t.sessionId,model:e,permissionMode:n};return{sessionIdentity:o,metadata:s}}var xn=class{initializationPromise;resolveInitialization;rejectInitialization;initializationSettled=!1;sessionMetadata;sessionIdentity;constructor(e,n){this.sessionIdentity=e,this.sessionMetadata=n,this.initializationPromise=new Promise((r,o)=>{this.resolveInitialization=r,this.rejectInitialization=o})}waitForInitialization(){return this.initializationPromise}getSessionIdentity(){return{...this.sessionIdentity,sessionId:this.getSessionId()}}getSessionMetadata(){return{...this.sessionMetadata,sessionId:this.getSessionId()}}getSessionId(){return this.sessionMetadata.sessionId??this.sessionIdentity.sessionId}updateSessionIdentity(e){e&&(this.sessionIdentity={...this.sessionIdentity,sessionId:e},this.sessionMetadata={...this.sessionMetadata,sessionId:e})}setSessionMetadata(e){this.sessionMetadata=e(this.sessionMetadata)}resolveInitializationIfNeeded(){this.initializationSettled||(this.initializationSettled=!0,this.resolveInitialization(this.getSessionMetadata()))}resolveInitializationOnce(){this.initializationSettled||(this.initializationSettled=!0,this.resolveInitialization(this.getSessionMetadata()))}rejectInitializationOnce(e){this.initializationSettled||(this.initializationSettled=!0,this.rejectInitialization(e))}isInitializationSettled(){return this.initializationSettled}};function sc(t){try{let e=JSON.parse(t);if(!Array.isArray(e))return null;let n=e.length;if(n===0)return"no results";let r=0,o=0;for(let a of e)if(a&&typeof a=="object"){let c=a.type;c==="fact"?r++:c==="procedure"&&o++}let s=`${n} result${n===1?"":"s"}`;if(r+o!==n)return s;let i=[];return r>0&&i.push(`${r} fact${r===1?"":"s"}`),o>0&&i.push(`${o} procedure${o===1?"":"s"}`),i.length===0?s:`${s} (${i.join(", ")})`}catch{return null}}function ic(t){try{let e=JSON.parse(t);if(!e||typeof e!="object")return null;let n=e;if(n.target==="hot"&&n.saved===!0)return"hot memory saved";if(n.target==="fact"){if(n.action==="remove")return n.removed===!0?"fact removed":"fact not found";if(n.action==="set"&&typeof n.id=="number")return`fact #${n.id} set`;if(n.action==="supersede"&&typeof n.id=="number"&&typeof n.supersedes=="number")return`fact #${n.id} supersedes #${n.supersedes}`}return null}catch{return null}}function ac(t){try{let e=JSON.parse(t);if(!e||typeof e!="object")return null;let n=e;return typeof n.name=="string"&&n.written===!0?`wrote procedure '${n.name}'`:null}catch{return null}}function Xr(t){let e=t.trim();if(e.length===0)return null;let n=e[0];if(n!=="{"&&n!=="[")return null;let r=e[e.length-1];if(n==="{"&&r!=="}"||n==="["&&r!=="]")return null;let o;try{o=JSON.parse(e)}catch{return null}return Array.isArray(o)?cc(kh(o)):o!==null&&typeof o=="object"?cc(vh(o)):null}function kh(t){return t.length===0?"[empty array]":t.length===1?"[1 item]":`[${t.length} items]`}function vh(t){let e=Object.keys(t);if(e.length===0)return"{empty object}";let n=e.slice(0,4),r=e.length>4?", \u2026":"";return`{${n.join(", ")}${r}}`}function cc(t){return t.length<=80?t:t.slice(0,79)+"\u2026"}var _h=new Map([["memory_search",sc],["memory_update",ic],["procedure_write",ac],["bash",Xr],["Bash",Xr]]);function Eh(t){return t.replace(/\x1b\[[0-?]*[ -/]*[@-~]/g,"").replace(/\x1b[@-_]/g,"").replace(/[\x00-\x1f\x7f]/g," ").trim()}function lc(t,e){if(!t)return null;let n=_h.get(t);if(!n)return null;try{let r=n(e);if(r===null)return null;let o=Eh(r);return o.length>0?o:null}catch{return null}}function Ah(t){let e=/Output too large \((\d+(?:\.\d+)?)\s*(B|KB|MB|GB)\)\.\s*Full output saved to:\s*(\/[^\n]+)/,n=t.match(e);if(!n||!n[1]||!n[2]||!n[3])return null;let r=n[1],o=n[2],s=n[3],i=parseFloat(r),a=i;o==="KB"?a=i*1024:o==="MB"?a=i*1024*1024:o==="GB"&&(a=i*1024*1024*1024);let c=r;return i%1===0&&(c=String(Math.floor(i))),c+=o,{sizeLabel:c,sizeBytes:Math.round(a),absolutePath:s.trim()}}function xh(t){if(t<1024)return`${t}B`;let e=t/1024;if(e<1024)return e%1===0?`${Math.floor(e)}KB`:`${e.toFixed(1)}KB`;let n=e/1024;if(n<1024)return n%1===0?`${Math.floor(n)}MB`:`${n.toFixed(1)}MB`;let r=n/1024;return r%1===0?`${Math.floor(r)}GB`:`${r.toFixed(1)}GB`}function Th(t){let e=Buffer.byteLength(t,"utf8"),n=xh(e),r=t.split(`
|
|
1627
1627
|
`);if(r.length<=1&&t.length<=80)return{content:t,truncated:!1,sizeBytes:e,sizeLabel:n};if(r.length<=1)return t.length<=80?{content:t,truncated:!1,sizeBytes:e,sizeLabel:n}:{content:t.substring(0,80)+"\u2026",truncated:!0,sizeBytes:e,sizeLabel:n};if(t.length<=80)return{content:t,truncated:!1,sizeBytes:e,sizeLabel:n};let o=r[0]??"",s=o;return o.length>80&&(s=o.substring(0,80)+"\u2026"),{content:s+`\u2026+${r.length} lines`,truncated:!0,lineCount:r.length,sizeBytes:e,sizeLabel:n}}function Rh(t,e){let n={...t.raw??{}};return t.inputTokens!==void 0&&(n.input_tokens=t.inputTokens),t.outputTokens!==void 0&&(n.output_tokens=t.outputTokens),t.cachedInputTokens!==void 0&&(n.cache_read_input_tokens=t.cachedInputTokens),t.cacheCreationTokens!==void 0&&(n.cache_creation_input_tokens=t.cacheCreationTokens),t.totalTokens!==void 0&&(n.total_tokens=t.totalTokens),{sessionId:e,stopReason:t.stopReason??void 0,resultSubtype:t.resultSubtype,durationMs:t.durationMs,durationApiMs:t.durationApiMs,totalCostUsd:t.totalCostUsd,isError:t.isError,usage:Object.keys(n).length>0?n:void 0,modelUsage:t.modelUsage,permissionDenials:t.permissionDenials,errors:t.errors}}function Ph(t){let e=t.isError===!0?null:lc(t.toolName,t.content),n=e!==null?{display:e}:{},r=Ah(t.content);if(r)return{type:"chunk",chunk:{type:"tool_result",toolUseId:t.toolUseId,content:`Output persisted (${r.sizeLabel}) \u2192 ${r.absolutePath}`,isError:t.isError===!0,persistedPath:r.absolutePath,sizeBytes:r.sizeBytes,sizeLabel:r.sizeLabel,...n}};let{content:o,lineCount:s,sizeBytes:i,sizeLabel:a}=Th(t.content);return{type:"chunk",chunk:{type:"tool_result",toolUseId:t.toolUseId,content:o,isError:t.isError===!0,sizeBytes:i,sizeLabel:a,...t.truncated===!0&&{truncated:!0},...s!==void 0&&{lineCount:s},...n}}}function Qr(t,e){switch(t.type){case"session.init":{let n=t.info;return e.setSessionMetadata(r=>({...r,sessionId:n.sessionId,model:n.model??r.model,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},...n.cwd!==void 0?{cwd:n.cwd}:{},tools:n.tools?[...n.tools]:r.tools,slashCommands:n.slashCommands?[...n.slashCommands]:r.slashCommands,skills:n.skills?[...n.skills]:r.skills,plugins:n.plugins?n.plugins.map(o=>({...o})):r.plugins,mcpServers:n.mcpServers?n.mcpServers.map(o=>({...o})):r.mcpServers,...n.apiKeySource!==void 0?{apiKeySource:n.apiKeySource}:{},...n.version!==void 0?{claudeCodeVersion:n.version}:{},...n.outputStyle!==void 0?{outputStyle:n.outputStyle}:{}})),e.updateSessionIdentity(n.sessionId),e.resolveInitialization(),null}case"session.status":return e.setSessionMetadata(n=>({...n,sessionId:t.sessionId,...t.permissionMode!==void 0?{permissionMode:t.permissionMode}:{permissionMode:n.permissionMode},...t.status!==void 0?{status:t.status}:{}})),null;case"delta.text":return{type:"chunk",chunk:{type:"content",content:t.text,metadata:{eventType:"delta",deltaType:"text_delta"}}};case"delta.reasoning":return{type:"chunk",chunk:{type:"thinking",content:t.text,metadata:{eventType:"delta",deltaType:"thinking_delta"}}};case"assistant.message":if(t.sessionId&&e.updateSessionIdentity(t.sessionId),t.text){let n={role:"assistant",content:t.text,timestamp:new Date};return e.conversationHistory.push(n),{type:"message",message:n}}return null;case"tool.use.start":return{type:"chunk",chunk:{type:"tool_use_detail",toolUseId:t.toolUseId,toolName:t.toolName,toolInput:t.toolInput}};case"tool.use":return{type:"chunk",chunk:{type:"tool_use",content:t.summary,metadata:{eventType:"tool_use_summary",precedingToolUseIds:t.toolUseIds}}};case"tool.output":return Ph(t);case"tool.diff":return{type:"chunk",chunk:{type:"tool_diff",toolUseId:t.toolUseId,diff:t.diff}};case"progress":return{type:"progress",progress:{taskId:t.progress.taskId,description:t.progress.description,...t.progress.summary!==void 0?{summary:t.progress.summary}:{},...t.progress.lastToolName!==void 0?{lastToolName:t.progress.lastToolName}:{},totalTokens:t.progress.totalTokens,toolUses:t.progress.toolUses,durationMs:t.progress.durationMs}};case"suggestion":return{type:"suggestion",suggestion:t.suggestion};case"turn.completed":{let n=Rh(t.usage,t.sessionId??e.getSessionMetadata().sessionId);e.setLastResponseMetadata(n);for(let r=e.conversationHistory.length-1;r>=0;r--){let o=e.conversationHistory[r];if(o?.role==="assistant"){o.metadata=n;break}}if(e.maxBudgetUsd!==void 0&&e.abortBudget!==void 0&&typeof n.totalCostUsd=="number"&&(e._runningCostUsd=(e._runningCostUsd??0)+n.totalCostUsd,e._runningCostUsd>=e.maxBudgetUsd)){fo(e.traceWriter,{kind:"monetary",runningCostUsd:e._runningCostUsd,maxBudgetUsd:e.maxBudgetUsd,lastTurnCostUsd:n.totalCostUsd});let r=new Ke(e._runningCostUsd,e.maxBudgetUsd);return e.abortBudget(r.message),{type:"error",error:r}}return{type:"done",metadata:n}}case"error":return{type:"error",error:t.error};case"paused":return{type:"paused",reason:t.reason,...t.resetsAt!==void 0?{resetsAt:t.resetsAt}:{},...t.accountId!==void 0?{accountId:t.accountId}:{},...t.autoResume!==void 0?{autoResume:t.autoResume}:{}};case"resumed":return{type:"resumed",hotSwapped:t.hotSwapped,...t.accountId!==void 0?{accountId:t.accountId}:{}};default:return null}}var je=class{config;currentState="idle";providerQuery;providerIterator;conversationHistory=[];turnCount=0;lastResponseMetadata=null;initPromise=null;inputStream;abortController;hookRegistry;sessionEndDispatched=!1;stateManager;sessionRunningCostUsd=0;sessionRunningTokens={input:0,output:0,cacheRead:0,cacheCreation:0};lastStopReason;constructor(e){this.config=e,this.abortController=new AbortController,this.hookRegistry=e.hookRegistry,rc(e.abortSignal,this.abortController,()=>{this.onAbort()}),this.initSdkLifecycle()}initSdkLifecycle(){let e=Ct(this.config.model)??this.config.model,{sessionIdentity:n,metadata:r}=oc(this.config,e);this.stateManager=new xn(n,r),this.inputStream=new An(()=>this.sessionId);let o=this.config.provider??_n(e);D(`\u{1F7E2} AgentSession: Creating query session via provider=${o.name}`),this.providerQuery=o.query({prompt:this.inputStream.createIterable(),config:this.config}),this.conversationHistory=[],this.turnCount=0,this.lastResponseMetadata=null,this.sessionRunningCostUsd=0,this.sessionRunningTokens={input:0,output:0,cacheRead:0,cacheCreation:0},this.lastStopReason=void 0,this.sessionEndDispatched=!1,this.currentState="idle";let s=this.providerQuery;this.providerIterator=s[Symbol.asyncIterator](),this.initPromise=this.pullInitialization()}async pullInitialization(){try{for(await tc(this.hookRegistry,{event:"SessionStart",sessionId:this.sessionId},{signal:this.abortController.signal,...this.config.traceWriter?{traceWriter:this.config.traceWriter}:{}});;){let e=await this.providerIterator.next();if(e.done){this.stateManager.resolveInitializationIfNeeded();return}let n=e.value,r=Qr(n,this.buildTransformDeps());if(n.type==="session.init"||r&&r.type==="error")return}}catch(e){let n=e instanceof Error?e:new Error(String(e));this.stateManager.isInitializationSettled()||this.stateManager.rejectInitializationOnce(n),await this.dispatchSessionEndOnce("error").catch(()=>{})}}buildTransformDeps(){return{conversationHistory:this.conversationHistory,getSessionMetadata:()=>this.stateManager.getSessionMetadata(),setSessionMetadata:e=>this.stateManager.setSessionMetadata(e),updateSessionIdentity:e=>this.stateManager.updateSessionIdentity(e),resolveInitialization:()=>this.stateManager.resolveInitializationOnce(),setLastResponseMetadata:e=>{this.lastResponseMetadata=e,typeof e.totalCostUsd=="number"&&Number.isFinite(e.totalCostUsd)&&(this.sessionRunningCostUsd+=e.totalCostUsd);let n=e.usage;if(n&&typeof n=="object"){let r=n,o=(s,i)=>{let a=r[s];typeof a=="number"&&Number.isFinite(a)&&(this.sessionRunningTokens[i]+=a)};o("input_tokens","input"),o("output_tokens","output"),o("cache_read_input_tokens","cacheRead"),o("cache_creation_input_tokens","cacheCreation")}typeof e.stopReason=="string"&&(this.lastStopReason=e.stopReason)},maxBudgetUsd:this.config.maxBudgetUsd,abortBudget:e=>{this.abortController.signal.aborted||this.abortController.abort(e)},...this.config.traceWriter?{traceWriter:this.config.traceWriter}:{}}}get state(){return this.currentState}get sessionId(){return this.stateManager.getSessionId()}get cwd(){return this.config.cwd}get abortSignal(){return this.abortController.signal}abort(e){if(e==="closed"||e.startsWith("Budget ")||e.includes("timed out"))throw new Error(`AgentSession.abort: reserved reason "${e}" (use a caller-specific string like 'sigint')`);this.abortController.signal.aborted||this.abortController.abort(e)}async sendMessage(e,n={}){this.assertCanSend();let r=this.config.timeoutMs??mt,o=async()=>{let s=null,i="";this.currentState=n.stream?"streaming":"processing";for await(let a of this.sendMessageStreamInternal(e)){if(a.type==="chunk"&&a.chunk.type==="content"&&(i+=a.chunk.content),a.type==="message"&&a.message.role==="assistant"&&(s=a.message),a.type==="error")throw a.error;if(a.type==="done"){if(s)return{...s,metadata:a.metadata};if(i)return{role:"assistant",content:i,metadata:a.metadata,timestamp:new Date}}}if(s)return s;if(i)return{role:"assistant",content:i,timestamp:new Date};throw new Error("No assistant response received")};try{return await gt(o(),r,{controller:this.abortController,label:this.sessionId??"session"})}finally{this.currentState==="processing"&&(this.currentState="idle")}}async*sendMessageStream(e){this.assertCanSend(),this.currentState="streaming";try{yield*this.sendMessageStreamInternal(e)}finally{this.currentState==="streaming"&&(this.currentState="idle")}}async*sendMessageStreamInternal(e){this.initPromise&&await this.initPromise;let r={role:"user",content:typeof e=="string"?e:this.summarizeContentBlocks(e),timestamp:new Date};this.conversationHistory.push(r),this.inputStream.pushUserMessage(e);let o=this.buildTransformDeps();try{for(;;){let s=await this.providerIterator.next();if(s.done)break;let i=s.value,a=Qr(i,o);if(a&&(a.type==="done"&&this.turnCount++,yield a,a.type==="done"||a.type==="error"))break}}finally{this.currentState==="streaming"&&(this.currentState="idle")}}summarizeContentBlocks(e){let n=[],r=0;for(let s of e)s.type==="text"?n.push(s.text):s.type==="image"&&r++;let o=n.join(" ");return r>0&&(o=o?`${o} [+ ${r} image(s)]`:`[+ ${r} image(s)]`),o||"[content block(s)]"}async interrupt(){this.currentState!=="streaming"&&this.currentState!=="processing"||(this.currentState="idle",await this.providerQuery.interrupt())}async reset(){if(this.currentState==="closed")throw new Error("Cannot reset: session is closed");if(this.abortController.signal.aborted)throw new oe("Cannot reset: session aborted");if(this.currentState==="processing"||this.currentState==="streaming")try{await this.providerQuery.interrupt()}catch{}await this.dispatchSessionEndOnce("reset");try{await this.providerQuery.close()}catch{}await this.providerIterator.return?.(),this.initPromise&&await Promise.race([this.initPromise,new Promise(e=>setTimeout(e,Bt))]).catch(()=>{}),this.stateManager.resolveInitializationIfNeeded(),this.config={...this.config},delete this.config.resume,delete this.config.sessionId,delete this.config.resumeHistory,delete this.config.resumeSessionAt,delete this.config.continue,delete this.config.forkSession;try{this.initSdkLifecycle()}catch(e){throw this.currentState="closed",new Error(`Session reset failed during lifecycle rebuild: ${e instanceof Error?e.message:String(e)}`,{cause:e})}}async onAbort(){try{await this.providerQuery.interrupt()}catch{}}async setModel(e){let n=Ct(e),r=this.stateManager.getSessionMetadata();await this.providerQuery.setModel(n??r.model??""),n&&this.stateManager.setSessionMetadata(o=>({...o,model:n}))}async setPermissionMode(e){await this.providerQuery.setPermissionMode(e),this.stateManager.setSessionMetadata(n=>({...n,permissionMode:e}))}setCwd(e){this.config={...this.config,cwd:e},this.providerQuery.setCwd?.(e)}async reauth(){return await this.providerQuery.reauth?.()??null}waitForInitialization(){return this.stateManager.waitForInitialization()}getSessionIdentity(){return this.stateManager.getSessionIdentity()}getSessionMetadata(){return this.stateManager.getSessionMetadata()}getQuery(){return this.providerQuery}supportedCommands(){return this.providerQuery.supportedCommands()}supportedModels(){return this.providerQuery.supportedModels()}supportedAgents(){return this.providerQuery.supportedAgents()}getContextUsage(){return this.providerQuery.getContextUsage()}mcpServerStatus(){return this.providerQuery.mcpServerStatus()}accountInfo(){return this.providerQuery.accountInfo()}rewindFiles(e,n){return this.providerQuery.rewindFiles(e,n)}async compact(){if(this.currentState==="closed")throw new Error("Cannot compact: session is closed");if(this.currentState!=="idle")return{compacted:!1,reason:"session-busy",messagesBefore:0,messagesAfter:0};let e=this.providerQuery.compact?.bind(this.providerQuery);return e?e():{compacted:!1,reason:"not-supported",messagesBefore:0,messagesAfter:0}}getLastResponseMetadata(){return this.lastResponseMetadata}getOutputStream(){throw new Error("getOutputStream() is not supported \u2014 use sendMessageStream() instead")}getInputStreamRef(){return{pushUserMessage:e=>this.inputStream.pushUserMessage(e)}}getHistory(){return[...this.conversationHistory]}getTurnCount(){return this.turnCount}async close(){if(this.currentState!=="closed"){this.currentState="closed",this.abortController.signal.aborted||this.abortController.abort("closed"),this.stateManager.resolveInitializationIfNeeded();try{await this.providerQuery.close()}catch{}if(await this.providerIterator.return?.(),this.initPromise)try{await Promise.race([this.initPromise,new Promise(e=>setTimeout(e,Bt))])}catch{}await this.dispatchSessionEndOnce("close")}}async dispatchSessionEndOnce(e){this.sessionEndDispatched||(this.sessionEndDispatched=!0,await this.emitClosure(e).catch(()=>{}),await this.sealTraceWriter(e).catch(()=>{}),await nc(this.hookRegistry,{event:"SessionEnd",sessionId:this.sessionId,reason:e},this.config.traceWriter?{traceWriter:this.config.traceWriter}:{}))}async emitClosure(e){let n=this.config.traceWriter;if(!n)return;let r=this.deriveClosureReason(e),o={};this.sessionRunningTokens.input>0&&(o.input=this.sessionRunningTokens.input),this.sessionRunningTokens.output>0&&(o.output=this.sessionRunningTokens.output),this.sessionRunningTokens.cacheRead>0&&(o.cacheRead=this.sessionRunningTokens.cacheRead),this.sessionRunningTokens.cacheCreation>0&&(o.cacheCreation=this.sessionRunningTokens.cacheCreation),await ho(n,{reason:r,finalTurnCount:this.turnCount,finalCostUsd:this.sessionRunningCostUsd,finalTokens:o,...this.lastStopReason!==void 0?{lastStopReason:this.lastStopReason}:{}})}deriveClosureReason(e){if(e==="error")return"abort";let n=this.abortController.signal;if(n.aborted&&n.reason!=="closed"){let r=n.reason;if(r instanceof Ke)return"budget_exceeded";if(r instanceof Ee)return"timeout";if(typeof r=="string"){if(r.startsWith("Budget "))return"budget_exceeded";if(r.includes("timed out"))return"timeout"}return"abort"}return"model_end_turn"}async sealTraceWriter(e){let n=this.config.traceWriter;if(!n)return;let r=this.deriveSealStatus(e);await n.seal({status:r,finalCostUsd:this.sessionRunningCostUsd,finalTurnCount:this.turnCount,closedAt:new Date().toISOString()})}deriveSealStatus(e){if(e==="error")return"failed";let n=this.abortController.signal;return n.aborted&&n.reason!=="closed"?"cancelled":"succeeded"}assertCanSend(){if(this.currentState==="closed")throw new Error("Cannot send message: session is closed");if(this.abortController.signal.aborted)throw new oe("Cannot send message: session aborted");if(this.currentState==="processing"||this.currentState==="streaming")throw new Error("Cannot send message: session is busy");if(this.config.maxTurns&&this.turnCount>=this.config.maxTurns)throw new Error(`Maximum turns (${this.config.maxTurns}) exceeded`)}};function Ih(t){let e=new Map,n=t.defaultMode??"ask";if(t.tools)for(let[r,o]of Object.entries(t.tools))typeof o=="string"?e.set(r,{mode:o}):e.set(r,{mode:o.mode,reason:o.reason});if(t.list)for(let r of t.list)e.set(r.tool,{mode:r.mode,reason:r.reason});return{defaultMode:n,byTool:e}}function Ch(t){return t.behavior==="allow"?{behavior:"allow"}:{behavior:"deny",message:t.reason??"Tool denied by permission rules"}}function dc(t){let{defaultMode:e,byTool:n}=Ih(t.rules);return async(r,o)=>{let s={toolName:r,input:o},i=n.get(r),a=i?.mode??e,c=i?.reason,l;return a==="ask"&&t.onAsk?l=await t.onAsk(s):a==="deny"?l={behavior:"deny",reason:c}:l={behavior:"allow"},t.onDecision?.(s,l),Ch(l)}}import{Telegraf as vy}from"telegraf";import{promises as Mt}from"fs";import{join as uc}from"path";var it=class{sessions=new Map;pendingSessions=new Map;sessionData=new Map;options;constructor(e){this.options={dataDir:e.dataDir||"./data/telegram-sessions",defaultModel:e.defaultModel||"sonnet",apiKey:e.apiKey,settingSources:e.settingSources,thinking:e.thinking,effort:e.effort,botCwd:e.botCwd,createSession:e.createSession}}getSessionIfExists(e){return this.sessions.get(e)}async getSession(e){let n=this.sessions.get(e);if(n)return this._touchActivity(e),n;let r=this.pendingSessions.get(e);if(r)try{return await r}finally{this._touchActivity(e)}let o=this.sessionData.get(e)??{chatId:e,model:this.options.defaultModel,createdAt:new Date().toISOString(),lastActivity:new Date().toISOString()},s=(async()=>{let i={model:o.model,apiKey:this.options.apiKey};this.options.settingSources?.length&&(i.settingSources=this.options.settingSources),this.options.thinking!==void 0&&(i.thinking=this.options.thinking),this.options.effort!==void 0&&(i.effort=this.options.effort);let a=o.cwd??this.options.botCwd;a!==void 0&&a.length>0&&(i.cwd=a);let c=await this.options.createSession(Sr(i));return this.sessions.set(e,c),this.sessionData.set(e,o),c})();this.pendingSessions.set(e,s);try{let i=await s;return this._touchActivity(e),i}finally{this.pendingSessions.delete(e)}}_touchActivity(e){let n=this.sessionData.get(e);n&&(n.lastActivity=new Date().toISOString())}async resetSession(e){let n=this.sessions.get(e);n&&(await n.close(),this.sessions.delete(e));let r=this.sessionData.get(e);r&&(r.lastActivity=new Date().toISOString())}async switchModel(e,n){let r=this.sessions.get(e);r&&(await r.close(),this.sessions.delete(e));let o=this.sessionData.get(e);o?(o.model=n,o.lastActivity=new Date().toISOString()):(o={chatId:e,model:n,createdAt:new Date().toISOString(),lastActivity:new Date().toISOString()},this.sessionData.set(e,o))}getModel(e){return this.sessionData.get(e)?.model||this.options.defaultModel}async setCwd(e,n){let r=this.sessions.get(e);r&&(await r.close(),this.sessions.delete(e));let o=this.sessionData.get(e);o?(o.cwd=n,o.lastActivity=new Date().toISOString()):(o={chatId:e,model:this.options.defaultModel,createdAt:new Date().toISOString(),lastActivity:new Date().toISOString(),cwd:n},this.sessionData.set(e,o))}getCwd(e){return this.sessionData.get(e)?.cwd??this.options.botCwd}async loadSessions(){try{await Mt.mkdir(this.options.dataDir,{recursive:!0});let e=await Mt.readdir(this.options.dataDir);for(let n of e)if(n.endsWith(".json")){let r=uc(this.options.dataDir,n),o=await Mt.readFile(r,"utf-8"),s=JSON.parse(o);this.sessionData.set(s.chatId,s)}}catch(e){e.code!=="ENOENT"&&console.error("Failed to load sessions:",e)}}async saveSessions(){try{await Mt.mkdir(this.options.dataDir,{recursive:!0});for(let[e,n]of this.sessionData.entries()){let r=uc(this.options.dataDir,`${e}.json`);await Mt.writeFile(r,JSON.stringify(n,null,2))}}catch(e){console.error("Failed to save sessions:",e)}}async closeAll(){await this.saveSessions();let e=Array.from(this.sessions.values()).map(n=>n.close().catch(r=>console.error("Error closing session:",r)));await Promise.all(e),this.sessions.clear()}getSessionCount(){return this.sessions.size}getChatCount(){return this.sessionData.size}};function Ot(t,e=4096){if(t.length<=e)return[t];let n=[],r=t;for(;r.length>0;){if(r.length<=e){n.push(r);break}let o=e,s=r.lastIndexOf(`
|
|
1628
1628
|
`,e);if(s>e-500&&s>0)o=s+1;else{let i=r.slice(0,e).match(/[.!?]\s+(?=[A-Z])/g);if(i&&i.length>0){let a=i[i.length-1];if(a){let c=r.lastIndexOf(a,e);c>e-200&&c>0&&(o=c+2)}}else{let a=r.lastIndexOf(" ",e);a>e-100&&a>0&&(o=a+1)}}n.push(r.slice(0,o).trim()),r=r.slice(o).trim()}return n}function Tn(t){t=t.replace(/[\x02\x03]/g,"");let e=t.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">"),n=[];e=e.replace(/^ {0,3}```([\w]*)\n([\s\S]*?)```/gm,(o,s,i)=>{let a=n.length;if(i.trim()===""){let c=s?`(empty ${s} block)`:"(empty code block)";n.push(`<i>${c}</i>`)}else n.push(`<pre>${i}</pre>`);return`FENCED${a}`});let r=[];return e=e.replace(/`([^`]+)`/g,(o,s)=>{let i=r.length;return r.push(`<code>${s}</code>`),`CODE${i}`}),e=e.replace(/\*\*([^*]+)\*\*/g,"<b>$1</b>"),e=e.replace(/__([^_]+)__/g,"<b>$1</b>"),e=e.replace(/\*([^*]+)\*/g,"<i>$1</i>"),e=e.replace(/(^|[^\w])_([^_\n]+?)_(?!\w)/gm,"$1<i>$2</i>"),e=e.replace(/~~([^~]+)~~/g,"<s>$1</s>"),e=e.replace(/\[([^\]]+)\]\(([^)]+)\)/g,(o,s,i)=>'<a href="'+i.replace(/"/g,""")+'">'+s+"</a>"),e=e.replace(/^#{1,6}\s+/gm,""),e=e.replace(/\x02CODE(\d+)\x03/g,(o,s)=>r[Number(s)]??o),e=e.replace(/\x02FENCED(\d+)\x03/g,(o,s)=>n[Number(s)]??o),e}function at(t){let e=["\\","_","*","[","]","(",")","~","`",">","#","+","-","=","|","{","}",".","!"],n=t;for(let r of e)n=n.replace(new RegExp(`\\${r}`,"g"),`\\${r}`);return n}function W(t){return`\u274C Error: ${t instanceof Error?t.message:t}`}function Rn(){return"\u26A0\uFE0F An internal error occurred. Please try again."}var pc=[{cmd:"/start",desc:"Show welcome and this command list"},{cmd:"/help",desc:"Show this command list"},{cmd:"/clear",desc:"Clear conversation history (SDK /clear)"},{cmd:"/compact",desc:"Compact conversation history (summarize older messages)"},{cmd:"/model [opus|sonnet|haiku]",desc:"Switch Claude model"},{cmd:"/cd [path]",desc:"Show or change the session working directory"}];function fc(t){let e=["\u{1F4CB} Bot commands (aligned with agent-afk CLI):","",...pc.map(n=>` ${n.cmd}
|
|
1629
1629
|
${n.desc}`)];return t&&t.length>0&&e.push("","\u{1F4CB} Session commands (from SDK, when using settingSources):","",...t.map(n=>` /${n.replace(/^\//,"")}`)),e.push("","Just send a message to chat with Claude."),e.join(`
|
package/dist/telegram.mjs
CHANGED
|
@@ -1081,7 +1081,7 @@ Don't refuse the flow; just clarify where the wizard runs.
|
|
|
1081
1081
|
|
|
1082
1082
|
Be terse and operational. The user is doing one-time setup; they want it done, not narrated. Confirm each step in one line, don't over-explain. Use \`\u2713\` for success, \`\u2717\` for failure, and code fences for any command they should run.
|
|
1083
1083
|
`}};function W(t){let e=Ts[t];if(!e){let n=Object.keys(Ts).sort(),r=n.length>0?"Available: "+n.join(", "):"";throw new Error("Unknown skill: "+t+". "+r)}return e}var dn=new Map;function re(t){dn.set(t.name,t)}function we(t){let e=dn.get(t);if(e)return e;let n=Array.from(dn.keys()).sort(),r=n.length>0?`
|
|
1084
|
-
Available skills: ${n.join(", ")}`:"";throw new Error(`Skill not found: ${t}${r}`)}function At(){return Array.from(dn.keys()).sort()}async function yr(t,e){if(t)try{await t.write({kind:"tool_call",payload:e})}catch(n){F(`trace.emit tool_call failed: ${Ue(n)}`)}}async function Qe(t,e){if(t)try{await t.write({kind:"hook_decision",payload:e})}catch(n){F(`trace.emit hook_decision failed: ${Ue(n)}`)}}async function $e(t,e){if(t)try{await t.write({kind:"subagent_lifecycle",payload:e})}catch(n){F(`trace.emit subagent_lifecycle failed: ${Ue(n)}`)}}async function Rs(t,e){if(t)try{await t.write({kind:"budget",payload:e})}catch(n){F(`trace.emit budget failed: ${Ue(n)}`)}}async function Is(t,e){if(t)try{await t.write({kind:"abort",payload:e})}catch(n){F(`trace.emit abort failed: ${Ue(n)}`)}}async function Ps(t,e){if(t)try{await t.write({kind:"compaction",payload:e})}catch(n){F(`trace.emit compaction failed: ${Ue(n)}`)}}async function Cs(t,e){if(t)try{await t.write({kind:"closure",payload:e})}catch(n){F(`trace.emit closure failed: ${Ue(n)}`)}}function Ue(t){return t instanceof Error?t.message:String(t)}var un=class{nodes=new Map;traceWriter;constructor(e){this.traceWriter=e}register(e,n){this.nodes.has(e)||this.nodes.set(e,{controller:n,children:new Set,listeners:new Set,cascading:!1})}has(e){return this.nodes.has(e)}getController(e){return this.nodes.get(e)?.controller}childrenOf(e){let n=this.nodes.get(e);return n?Array.from(n.children):[]}linkChild(e,n){let r=this.nodes.get(e),o=this.nodes.get(n);if(!r)throw new Error(`AbortGraph: parent ${e} not registered`);if(!o)throw new Error(`AbortGraph: child ${n} not registered`);if(o.parentId=e,r.children.add(n),r.controller.signal.aborted){o.controller.signal.aborted||(o.cascading=!0,o.controller.abort(r.controller.signal.reason));return}r.controller.signal.addEventListener("abort",()=>{let s=this.nodes.get(n);!s||s.parentId!==e||s.controller.signal.aborted||(s.cascading=!0,s.controller.abort(r.controller.signal.reason))},{once:!0}),o.controller.signal.addEventListener("abort",()=>{let s=this.nodes.get(n);if(!s||s.parentId!==e||s.cascading)return;let i=this.nodes.get(e);if(!i)return;let a={parentId:e,childId:n,reason:s.controller.signal.reason};for(let c of i.listeners)try{c(a)}catch{}},{once:!0})}onChildAborted(e,n){let r=this.nodes.get(e);if(!r)throw new Error(`AbortGraph: ${e} not registered`);return r.listeners.add(n),()=>{r.listeners.delete(n)}}abort(e,n,r="user_signal"){let o=this.nodes.get(e);if(!o||o.controller.signal.aborted)return;let s=[],i=[...o.children],a=new Set;for(;i.length;){let c=i.shift();if(a.has(c))continue;a.add(c);let l=this.nodes.get(c);if(l){l.cascading=!0,s.push(c);for(let d of l.children)i.push(d)}}Is(this.traceWriter,{origin:r,cascadedTo:s,...n!==void 0?{reason:Bd(n)}:{}}),o.controller.abort(n);for(let c of s){let l=this.nodes.get(c);l&&!l.controller.signal.aborted&&l.controller.abort(n)}}dispose(e){let n=this.nodes.get(e);if(n){n.parentId&&this.nodes.get(n.parentId)?.children.delete(e);for(let r of n.children){let o=this.nodes.get(r);o&&(o.parentId=void 0)}this.nodes.delete(e)}}};function Bd(t){if(typeof t=="string")return t;if(t instanceof Error)return t.message;try{return JSON.stringify(t)}catch{return String(t)}}var ie=class extends Error{constructor(e){super(e),this.name="AbortError"}},me=class extends Error{constructor(n,r){super(n);this.timeoutMs=r;this.name="TimeoutError"}timeoutMs},V=class extends Error{constructor(n,r,o,s){super(n);this.event=r;this.reason=o;this.name="HookBlockedError",s?.cause!==void 0&&(this.cause=s.cause)}event;reason;cause};var Ze=class extends Error{constructor(n,r,o){super(o??`Budget ceiling reached: $${n.toFixed(4)} cumulative >= $${r.toFixed(4)} limit`);this.runningCostUsd=n;this.maxBudgetUsd=r;this.name="BudgetExceededError"}runningCostUsd;maxBudgetUsd};var pn=0,br=5e3;async function fn(t,e,n={}){if(!Number.isFinite(e)||e<=0)return t;let r,o=new Promise((s,i)=>{r=setTimeout(()=>{let a=n.label?` (${n.label})`:"",c=new me(`Operation timed out after ${e}ms${a}`,e);n.controller&&!n.controller.signal.aborted&&n.controller.abort(c),i(c)},e)});try{return await Promise.race([t,o])}finally{r!==void 0&&clearTimeout(r)}}async function mn(t,e,n){if(!t)return;if(n.kind==="blocked"){await Qe(t,{hookEvent:e,decision:"block",...n.err.reason!==void 0?{reason:n.err.reason}:{}});return}let r=n.decision;await Qe(t,{hookEvent:e,decision:r.decision,...r.reason!==void 0?{reason:r.reason}:{},...r.injectContext!==void 0?{injectedContextBytes:Buffer.byteLength(r.injectContext,"utf8")}:{}})}async function Ms(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await mn(n.traceWriter,"SessionStart",{kind:"decision",decision:r})}catch(r){throw r instanceof V&&await mn(n.traceWriter,"SessionStart",{kind:"blocked",err:r}),r}}async function Os(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await mn(n.traceWriter,"SessionEnd",{kind:"decision",decision:r})}catch(r){if(r instanceof V&&await mn(n.traceWriter,"SessionEnd",{kind:"blocked",err:r}),r instanceof V||r instanceof ie){F(`SessionEnd hook swallowed ${r.name}: ${r.message}`),n.onError?.(r);return}F(`SessionEnd hook unexpected error: ${String(r)}`),n.onError?.(r instanceof Error?r:new Error(String(r)))}}var gn=class{pendingResolve=null;bufferedMessage=null;getSessionId;constructor(e){this.getSessionId=e}pushUserMessage(e){if(this.pendingResolve){let n=this.pendingResolve;this.pendingResolve=null;let r=this.getSessionId();n({content:e,...r!==void 0?{sessionId:r}:{}});return}this.bufferedMessage=e}createIterable(){let e=this;return{[Symbol.asyncIterator](){return{next(){if(e.bufferedMessage!==null){let n=e.bufferedMessage;e.bufferedMessage=null;let r=e.getSessionId();return Promise.resolve({value:{content:n,...r!==void 0?{sessionId:r}:{}},done:!1})}return new Promise(n=>{e.pendingResolve=r=>n({value:r,done:!1})})},return(){return Promise.resolve({value:void 0,done:!0})}}}}}};var hn={opus:"claude-opus-4-7",opus_1m:"claude-opus-4-7",sonnet:"claude-sonnet-4-6",sonnet_1m:"claude-sonnet-4-6",haiku:"claude-haiku-4-5-20251001"};function yn(t){return t in hn}function Ds(t){let e=hn[t];if(!e)throw new Error(`Invalid model: ${t}`);return e}function Be(t){if(t!==void 0)return typeof t=="string"&&yn(t)?Ds(t):t}function Fs(t,e,n){t&&(t.aborted?e.abort(t.reason):t.addEventListener("abort",()=>{e.signal.aborted||e.abort(t.reason)},{once:!0})),e.signal.addEventListener("abort",n,{once:!0})}function Ls(t,e){let n=t.permissionMode??"default",r=t.persistSession??!0,o={sessionId:t.sessionId,configuredSessionId:t.sessionId,resume:t.resume,resumeSessionAt:t.resumeSessionAt,continue:t.continue,forkSession:t.forkSession,persistSession:r},s={sessionId:t.sessionId,model:e,permissionMode:n};return{sessionIdentity:o,metadata:s}}var bn=class{initializationPromise;resolveInitialization;rejectInitialization;initializationSettled=!1;sessionMetadata;sessionIdentity;constructor(e,n){this.sessionIdentity=e,this.sessionMetadata=n,this.initializationPromise=new Promise((r,o)=>{this.resolveInitialization=r,this.rejectInitialization=o})}waitForInitialization(){return this.initializationPromise}getSessionIdentity(){return{...this.sessionIdentity,sessionId:this.getSessionId()}}getSessionMetadata(){return{...this.sessionMetadata,sessionId:this.getSessionId()}}getSessionId(){return this.sessionMetadata.sessionId??this.sessionIdentity.sessionId}updateSessionIdentity(e){e&&(this.sessionIdentity={...this.sessionIdentity,sessionId:e},this.sessionMetadata={...this.sessionMetadata,sessionId:e})}setSessionMetadata(e){this.sessionMetadata=e(this.sessionMetadata)}resolveInitializationIfNeeded(){this.initializationSettled||(this.initializationSettled=!0,this.resolveInitialization(this.getSessionMetadata()))}resolveInitializationOnce(){this.initializationSettled||(this.initializationSettled=!0,this.resolveInitialization(this.getSessionMetadata()))}rejectInitializationOnce(e){this.initializationSettled||(this.initializationSettled=!0,this.rejectInitialization(e))}isInitializationSettled(){return this.initializationSettled}};function Ns(t){try{let e=JSON.parse(t);if(!Array.isArray(e))return null;let n=e.length;if(n===0)return"no results";let r=0,o=0;for(let a of e)if(a&&typeof a=="object"){let c=a.type;c==="fact"?r++:c==="procedure"&&o++}let s=`${n} result${n===1?"":"s"}`;if(r+o!==n)return s;let i=[];return r>0&&i.push(`${r} fact${r===1?"":"s"}`),o>0&&i.push(`${o} procedure${o===1?"":"s"}`),i.length===0?s:`${s} (${i.join(", ")})`}catch{return null}}function $s(t){try{let e=JSON.parse(t);if(!e||typeof e!="object")return null;let n=e;if(n.target==="hot"&&n.saved===!0)return"hot memory saved";if(n.target==="fact"){if(n.action==="remove")return n.removed===!0?"fact removed":"fact not found";if(n.action==="set"&&typeof n.id=="number")return`fact #${n.id} set`;if(n.action==="supersede"&&typeof n.id=="number"&&typeof n.supersedes=="number")return`fact #${n.id} supersedes #${n.supersedes}`}return null}catch{return null}}function Us(t){try{let e=JSON.parse(t);if(!e||typeof e!="object")return null;let n=e;return typeof n.name=="string"&&n.written===!0?`wrote procedure '${n.name}'`:null}catch{return null}}function wr(t){let e=t.trim();if(e.length===0)return null;let n=e[0];if(n!=="{"&&n!=="[")return null;let r=e[e.length-1];if(n==="{"&&r!=="}"||n==="["&&r!=="]")return null;let o;try{o=JSON.parse(e)}catch{return null}return Array.isArray(o)?Bs(Hd(o)):o!==null&&typeof o=="object"?Bs(jd(o)):null}function Hd(t){return t.length===0?"[empty array]":t.length===1?"[1 item]":`[${t.length} items]`}function jd(t){let e=Object.keys(t);if(e.length===0)return"{empty object}";let n=e.slice(0,4),r=e.length>4?", \u2026":"";return`{${n.join(", ")}${r}}`}function Bs(t){return t.length<=80?t:t.slice(0,79)+"\u2026"}var Wd=new Map([["memory_search",Ns],["memory_update",$s],["procedure_write",Us],["bash",wr],["Bash",wr]]);function Kd(t){return t.replace(/\x1b\[[0-?]*[ -/]*[@-~]/g,"").replace(/\x1b[@-_]/g,"").replace(/[\x00-\x1f\x7f]/g," ").trim()}function Hs(t,e){if(!t)return null;let n=Wd.get(t);if(!n)return null;try{let r=n(e);if(r===null)return null;let o=Kd(r);return o.length>0?o:null}catch{return null}}function Gd(t){let e=/Output too large \((\d+(?:\.\d+)?)\s*(B|KB|MB|GB)\)\.\s*Full output saved to:\s*(\/[^\n]+)/,n=t.match(e);if(!n||!n[1]||!n[2]||!n[3])return null;let r=n[1],o=n[2],s=n[3],i=parseFloat(r),a=i;o==="KB"?a=i*1024:o==="MB"?a=i*1024*1024:o==="GB"&&(a=i*1024*1024*1024);let c=r;return i%1===0&&(c=String(Math.floor(i))),c+=o,{sizeLabel:c,sizeBytes:Math.round(a),absolutePath:s.trim()}}function qd(t){if(t<1024)return`${t}B`;let e=t/1024;if(e<1024)return e%1===0?`${Math.floor(e)}KB`:`${e.toFixed(1)}KB`;let n=e/1024;if(n<1024)return n%1===0?`${Math.floor(n)}MB`:`${n.toFixed(1)}MB`;let r=n/1024;return r%1===0?`${Math.floor(r)}GB`:`${r.toFixed(1)}GB`}function zd(t){let e=Buffer.byteLength(t,"utf8"),n=qd(e),r=t.split(`
|
|
1084
|
+
Available skills: ${n.join(", ")}`:"";throw new Error(`Skill not found: ${t}${r}`)}function At(){return Array.from(dn.keys()).sort()}async function yr(t,e){if(t)try{await t.write({kind:"tool_call",payload:e})}catch(n){F(`trace.emit tool_call failed: ${Ue(n)}`)}}async function Qe(t,e){if(t)try{await t.write({kind:"hook_decision",payload:e})}catch(n){F(`trace.emit hook_decision failed: ${Ue(n)}`)}}async function $e(t,e){if(t)try{await t.write({kind:"subagent_lifecycle",payload:e})}catch(n){F(`trace.emit subagent_lifecycle failed: ${Ue(n)}`)}}async function Rs(t,e){if(t)try{await t.write({kind:"budget",payload:e})}catch(n){F(`trace.emit budget failed: ${Ue(n)}`)}}async function Is(t,e){if(t)try{await t.write({kind:"abort",payload:e})}catch(n){F(`trace.emit abort failed: ${Ue(n)}`)}}async function Ps(t,e){if(t)try{await t.write({kind:"compaction",payload:e})}catch(n){F(`trace.emit compaction failed: ${Ue(n)}`)}}async function Cs(t,e){if(t)try{await t.write({kind:"closure",payload:e})}catch(n){F(`trace.emit closure failed: ${Ue(n)}`)}}function Ue(t){return t instanceof Error?t.message:String(t)}var un=class{nodes=new Map;traceWriter;constructor(e){this.traceWriter=e}register(e,n){this.nodes.has(e)||this.nodes.set(e,{controller:n,children:new Set,listeners:new Set,cascading:!1})}has(e){return this.nodes.has(e)}getController(e){return this.nodes.get(e)?.controller}childrenOf(e){let n=this.nodes.get(e);return n?Array.from(n.children):[]}linkChild(e,n){let r=this.nodes.get(e),o=this.nodes.get(n);if(!r)throw new Error(`AbortGraph: parent ${e} not registered`);if(!o)throw new Error(`AbortGraph: child ${n} not registered`);if(o.parentId=e,r.children.add(n),r.controller.signal.aborted){o.controller.signal.aborted||(o.cascading=!0,o.controller.abort(r.controller.signal.reason));return}r.controller.signal.addEventListener("abort",()=>{let s=this.nodes.get(n);!s||s.parentId!==e||s.controller.signal.aborted||(s.cascading=!0,s.controller.abort(r.controller.signal.reason))},{once:!0}),o.controller.signal.addEventListener("abort",()=>{let s=this.nodes.get(n);if(!s||s.parentId!==e||s.cascading)return;let i=this.nodes.get(e);if(!i)return;let a={parentId:e,childId:n,reason:s.controller.signal.reason};for(let c of i.listeners)try{c(a)}catch{}},{once:!0})}onChildAborted(e,n){let r=this.nodes.get(e);if(!r)throw new Error(`AbortGraph: ${e} not registered`);return r.listeners.add(n),()=>{r.listeners.delete(n)}}abort(e,n,r="user_signal"){let o=this.nodes.get(e);if(!o||o.controller.signal.aborted)return;let s=[],i=[...o.children],a=new Set;for(;i.length;){let c=i.shift();if(a.has(c))continue;a.add(c);let l=this.nodes.get(c);if(l){l.cascading=!0,s.push(c);for(let d of l.children)i.push(d)}}Is(this.traceWriter,{origin:r,cascadedTo:s,...n!==void 0?{reason:Bd(n)}:{}}),o.controller.abort(n);for(let c of s){let l=this.nodes.get(c);l&&!l.controller.signal.aborted&&l.controller.abort(n)}}dispose(e){let n=this.nodes.get(e);if(n){n.parentId&&this.nodes.get(n.parentId)?.children.delete(e);for(let r of n.children){let o=this.nodes.get(r);o&&(o.parentId=void 0)}this.nodes.delete(e)}}};function Bd(t){if(typeof t=="string")return t;if(t instanceof Error)return t.message;try{return JSON.stringify(t)}catch{return String(t)}}var ie=class extends Error{constructor(e){super(e),this.name="AbortError"}},me=class extends Error{constructor(n,r){super(n);this.timeoutMs=r;this.name="TimeoutError"}timeoutMs},V=class extends Error{constructor(n,r,o,s){super(n);this.event=r;this.reason=o;this.name="HookBlockedError",s?.cause!==void 0&&(this.cause=s.cause)}event;reason;cause};var Ze=class extends Error{constructor(n,r,o){super(o??`Budget ceiling reached: $${n.toFixed(4)} cumulative >= $${r.toFixed(4)} limit`);this.runningCostUsd=n;this.maxBudgetUsd=r;this.name="BudgetExceededError"}runningCostUsd;maxBudgetUsd};var pn=0,br=5e3;async function fn(t,e,n={}){if(!Number.isFinite(e)||e<=0)return t;let r,o=new Promise((s,i)=>{r=setTimeout(()=>{let a=n.label?` (${n.label})`:"",c=new me(`Operation timed out after ${e}ms${a}`,e);n.controller&&!n.controller.signal.aborted&&n.controller.abort(c),i(c)},e)});try{return await Promise.race([t,o])}finally{r!==void 0&&clearTimeout(r)}}async function mn(t,e,n){if(!t)return;if(n.kind==="blocked"){await Qe(t,{hookEvent:e,decision:"block",...n.err.reason!==void 0?{reason:n.err.reason}:{}});return}let r=n.decision;await Qe(t,{hookEvent:e,decision:r.decision,...r.reason!==void 0?{reason:r.reason}:{},...r.injectContext!==void 0?{injectedContextBytes:Buffer.byteLength(r.injectContext,"utf8")}:{}})}async function Ms(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await mn(n.traceWriter,"SessionStart",{kind:"decision",decision:r})}catch(r){throw r instanceof V&&await mn(n.traceWriter,"SessionStart",{kind:"blocked",err:r}),r}}async function Os(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await mn(n.traceWriter,"SessionEnd",{kind:"decision",decision:r})}catch(r){if(r instanceof V&&await mn(n.traceWriter,"SessionEnd",{kind:"blocked",err:r}),r instanceof V||r instanceof ie){F(`SessionEnd hook swallowed ${r.name}: ${r.message}`),n.onError?.(r);return}F(`SessionEnd hook unexpected error: ${String(r)}`),n.onError?.(r instanceof Error?r:new Error(String(r)))}}var gn=class{pendingResolve=null;bufferedMessage=null;getSessionId;constructor(e){this.getSessionId=e}pushUserMessage(e){if(this.pendingResolve){let n=this.pendingResolve;this.pendingResolve=null;let r=this.getSessionId();n({content:e,...r!==void 0?{sessionId:r}:{}});return}this.bufferedMessage=e}createIterable(){let e=this;return{[Symbol.asyncIterator](){return{next(){if(e.bufferedMessage!==null){let n=e.bufferedMessage;e.bufferedMessage=null;let r=e.getSessionId();return Promise.resolve({value:{content:n,...r!==void 0?{sessionId:r}:{}},done:!1})}return new Promise(n=>{e.pendingResolve=r=>n({value:r,done:!1})})},return(){return Promise.resolve({value:void 0,done:!0})}}}}}};var hn={opus:"claude-opus-4-8",opus_1m:"claude-opus-4-8",sonnet:"claude-sonnet-4-6",sonnet_1m:"claude-sonnet-4-6",haiku:"claude-haiku-4-5-20251001"};function yn(t){return t in hn}function Ds(t){let e=hn[t];if(!e)throw new Error(`Invalid model: ${t}`);return e}function Be(t){if(t!==void 0)return typeof t=="string"&&yn(t)?Ds(t):t}function Fs(t,e,n){t&&(t.aborted?e.abort(t.reason):t.addEventListener("abort",()=>{e.signal.aborted||e.abort(t.reason)},{once:!0})),e.signal.addEventListener("abort",n,{once:!0})}function Ls(t,e){let n=t.permissionMode??"default",r=t.persistSession??!0,o={sessionId:t.sessionId,configuredSessionId:t.sessionId,resume:t.resume,resumeSessionAt:t.resumeSessionAt,continue:t.continue,forkSession:t.forkSession,persistSession:r},s={sessionId:t.sessionId,model:e,permissionMode:n};return{sessionIdentity:o,metadata:s}}var bn=class{initializationPromise;resolveInitialization;rejectInitialization;initializationSettled=!1;sessionMetadata;sessionIdentity;constructor(e,n){this.sessionIdentity=e,this.sessionMetadata=n,this.initializationPromise=new Promise((r,o)=>{this.resolveInitialization=r,this.rejectInitialization=o})}waitForInitialization(){return this.initializationPromise}getSessionIdentity(){return{...this.sessionIdentity,sessionId:this.getSessionId()}}getSessionMetadata(){return{...this.sessionMetadata,sessionId:this.getSessionId()}}getSessionId(){return this.sessionMetadata.sessionId??this.sessionIdentity.sessionId}updateSessionIdentity(e){e&&(this.sessionIdentity={...this.sessionIdentity,sessionId:e},this.sessionMetadata={...this.sessionMetadata,sessionId:e})}setSessionMetadata(e){this.sessionMetadata=e(this.sessionMetadata)}resolveInitializationIfNeeded(){this.initializationSettled||(this.initializationSettled=!0,this.resolveInitialization(this.getSessionMetadata()))}resolveInitializationOnce(){this.initializationSettled||(this.initializationSettled=!0,this.resolveInitialization(this.getSessionMetadata()))}rejectInitializationOnce(e){this.initializationSettled||(this.initializationSettled=!0,this.rejectInitialization(e))}isInitializationSettled(){return this.initializationSettled}};function Ns(t){try{let e=JSON.parse(t);if(!Array.isArray(e))return null;let n=e.length;if(n===0)return"no results";let r=0,o=0;for(let a of e)if(a&&typeof a=="object"){let c=a.type;c==="fact"?r++:c==="procedure"&&o++}let s=`${n} result${n===1?"":"s"}`;if(r+o!==n)return s;let i=[];return r>0&&i.push(`${r} fact${r===1?"":"s"}`),o>0&&i.push(`${o} procedure${o===1?"":"s"}`),i.length===0?s:`${s} (${i.join(", ")})`}catch{return null}}function $s(t){try{let e=JSON.parse(t);if(!e||typeof e!="object")return null;let n=e;if(n.target==="hot"&&n.saved===!0)return"hot memory saved";if(n.target==="fact"){if(n.action==="remove")return n.removed===!0?"fact removed":"fact not found";if(n.action==="set"&&typeof n.id=="number")return`fact #${n.id} set`;if(n.action==="supersede"&&typeof n.id=="number"&&typeof n.supersedes=="number")return`fact #${n.id} supersedes #${n.supersedes}`}return null}catch{return null}}function Us(t){try{let e=JSON.parse(t);if(!e||typeof e!="object")return null;let n=e;return typeof n.name=="string"&&n.written===!0?`wrote procedure '${n.name}'`:null}catch{return null}}function wr(t){let e=t.trim();if(e.length===0)return null;let n=e[0];if(n!=="{"&&n!=="[")return null;let r=e[e.length-1];if(n==="{"&&r!=="}"||n==="["&&r!=="]")return null;let o;try{o=JSON.parse(e)}catch{return null}return Array.isArray(o)?Bs(Hd(o)):o!==null&&typeof o=="object"?Bs(jd(o)):null}function Hd(t){return t.length===0?"[empty array]":t.length===1?"[1 item]":`[${t.length} items]`}function jd(t){let e=Object.keys(t);if(e.length===0)return"{empty object}";let n=e.slice(0,4),r=e.length>4?", \u2026":"";return`{${n.join(", ")}${r}}`}function Bs(t){return t.length<=80?t:t.slice(0,79)+"\u2026"}var Wd=new Map([["memory_search",Ns],["memory_update",$s],["procedure_write",Us],["bash",wr],["Bash",wr]]);function Kd(t){return t.replace(/\x1b\[[0-?]*[ -/]*[@-~]/g,"").replace(/\x1b[@-_]/g,"").replace(/[\x00-\x1f\x7f]/g," ").trim()}function Hs(t,e){if(!t)return null;let n=Wd.get(t);if(!n)return null;try{let r=n(e);if(r===null)return null;let o=Kd(r);return o.length>0?o:null}catch{return null}}function Gd(t){let e=/Output too large \((\d+(?:\.\d+)?)\s*(B|KB|MB|GB)\)\.\s*Full output saved to:\s*(\/[^\n]+)/,n=t.match(e);if(!n||!n[1]||!n[2]||!n[3])return null;let r=n[1],o=n[2],s=n[3],i=parseFloat(r),a=i;o==="KB"?a=i*1024:o==="MB"?a=i*1024*1024:o==="GB"&&(a=i*1024*1024*1024);let c=r;return i%1===0&&(c=String(Math.floor(i))),c+=o,{sizeLabel:c,sizeBytes:Math.round(a),absolutePath:s.trim()}}function qd(t){if(t<1024)return`${t}B`;let e=t/1024;if(e<1024)return e%1===0?`${Math.floor(e)}KB`:`${e.toFixed(1)}KB`;let n=e/1024;if(n<1024)return n%1===0?`${Math.floor(n)}MB`:`${n.toFixed(1)}MB`;let r=n/1024;return r%1===0?`${Math.floor(r)}GB`:`${r.toFixed(1)}GB`}function zd(t){let e=Buffer.byteLength(t,"utf8"),n=qd(e),r=t.split(`
|
|
1085
1085
|
`);if(r.length<=1&&t.length<=80)return{content:t,truncated:!1,sizeBytes:e,sizeLabel:n};if(r.length<=1)return t.length<=80?{content:t,truncated:!1,sizeBytes:e,sizeLabel:n}:{content:t.substring(0,80)+"\u2026",truncated:!0,sizeBytes:e,sizeLabel:n};if(t.length<=80)return{content:t,truncated:!1,sizeBytes:e,sizeLabel:n};let o=r[0]??"",s=o;return o.length>80&&(s=o.substring(0,80)+"\u2026"),{content:s+`\u2026+${r.length} lines`,truncated:!0,lineCount:r.length,sizeBytes:e,sizeLabel:n}}function Jd(t,e){let n={...t.raw??{}};return t.inputTokens!==void 0&&(n.input_tokens=t.inputTokens),t.outputTokens!==void 0&&(n.output_tokens=t.outputTokens),t.cachedInputTokens!==void 0&&(n.cache_read_input_tokens=t.cachedInputTokens),t.cacheCreationTokens!==void 0&&(n.cache_creation_input_tokens=t.cacheCreationTokens),t.totalTokens!==void 0&&(n.total_tokens=t.totalTokens),{sessionId:e,stopReason:t.stopReason??void 0,resultSubtype:t.resultSubtype,durationMs:t.durationMs,durationApiMs:t.durationApiMs,totalCostUsd:t.totalCostUsd,isError:t.isError,usage:Object.keys(n).length>0?n:void 0,modelUsage:t.modelUsage,permissionDenials:t.permissionDenials,errors:t.errors}}function Vd(t){let e=t.isError===!0?null:Hs(t.toolName,t.content),n=e!==null?{display:e}:{},r=Gd(t.content);if(r)return{type:"chunk",chunk:{type:"tool_result",toolUseId:t.toolUseId,content:`Output persisted (${r.sizeLabel}) \u2192 ${r.absolutePath}`,isError:t.isError===!0,persistedPath:r.absolutePath,sizeBytes:r.sizeBytes,sizeLabel:r.sizeLabel,...n}};let{content:o,lineCount:s,sizeBytes:i,sizeLabel:a}=zd(t.content);return{type:"chunk",chunk:{type:"tool_result",toolUseId:t.toolUseId,content:o,isError:t.isError===!0,sizeBytes:i,sizeLabel:a,...t.truncated===!0&&{truncated:!0},...s!==void 0&&{lineCount:s},...n}}}function kr(t,e){switch(t.type){case"session.init":{let n=t.info;return e.setSessionMetadata(r=>({...r,sessionId:n.sessionId,model:n.model??r.model,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},...n.cwd!==void 0?{cwd:n.cwd}:{},tools:n.tools?[...n.tools]:r.tools,slashCommands:n.slashCommands?[...n.slashCommands]:r.slashCommands,skills:n.skills?[...n.skills]:r.skills,plugins:n.plugins?n.plugins.map(o=>({...o})):r.plugins,mcpServers:n.mcpServers?n.mcpServers.map(o=>({...o})):r.mcpServers,...n.apiKeySource!==void 0?{apiKeySource:n.apiKeySource}:{},...n.version!==void 0?{claudeCodeVersion:n.version}:{},...n.outputStyle!==void 0?{outputStyle:n.outputStyle}:{}})),e.updateSessionIdentity(n.sessionId),e.resolveInitialization(),null}case"session.status":return e.setSessionMetadata(n=>({...n,sessionId:t.sessionId,...t.permissionMode!==void 0?{permissionMode:t.permissionMode}:{permissionMode:n.permissionMode},...t.status!==void 0?{status:t.status}:{}})),null;case"delta.text":return{type:"chunk",chunk:{type:"content",content:t.text,metadata:{eventType:"delta",deltaType:"text_delta"}}};case"delta.reasoning":return{type:"chunk",chunk:{type:"thinking",content:t.text,metadata:{eventType:"delta",deltaType:"thinking_delta"}}};case"assistant.message":if(t.sessionId&&e.updateSessionIdentity(t.sessionId),t.text){let n={role:"assistant",content:t.text,timestamp:new Date};return e.conversationHistory.push(n),{type:"message",message:n}}return null;case"tool.use.start":return{type:"chunk",chunk:{type:"tool_use_detail",toolUseId:t.toolUseId,toolName:t.toolName,toolInput:t.toolInput}};case"tool.use":return{type:"chunk",chunk:{type:"tool_use",content:t.summary,metadata:{eventType:"tool_use_summary",precedingToolUseIds:t.toolUseIds}}};case"tool.output":return Vd(t);case"tool.diff":return{type:"chunk",chunk:{type:"tool_diff",toolUseId:t.toolUseId,diff:t.diff}};case"progress":return{type:"progress",progress:{taskId:t.progress.taskId,description:t.progress.description,...t.progress.summary!==void 0?{summary:t.progress.summary}:{},...t.progress.lastToolName!==void 0?{lastToolName:t.progress.lastToolName}:{},totalTokens:t.progress.totalTokens,toolUses:t.progress.toolUses,durationMs:t.progress.durationMs}};case"suggestion":return{type:"suggestion",suggestion:t.suggestion};case"turn.completed":{let n=Jd(t.usage,t.sessionId??e.getSessionMetadata().sessionId);e.setLastResponseMetadata(n);for(let r=e.conversationHistory.length-1;r>=0;r--){let o=e.conversationHistory[r];if(o?.role==="assistant"){o.metadata=n;break}}if(e.maxBudgetUsd!==void 0&&e.abortBudget!==void 0&&typeof n.totalCostUsd=="number"&&(e._runningCostUsd=(e._runningCostUsd??0)+n.totalCostUsd,e._runningCostUsd>=e.maxBudgetUsd)){Rs(e.traceWriter,{kind:"monetary",runningCostUsd:e._runningCostUsd,maxBudgetUsd:e.maxBudgetUsd,lastTurnCostUsd:n.totalCostUsd});let r=new Ze(e._runningCostUsd,e.maxBudgetUsd);return e.abortBudget(r.message),{type:"error",error:r}}return{type:"done",metadata:n}}case"error":return{type:"error",error:t.error};case"paused":return{type:"paused",reason:t.reason,...t.resetsAt!==void 0?{resetsAt:t.resetsAt}:{},...t.accountId!==void 0?{accountId:t.accountId}:{},...t.autoResume!==void 0?{autoResume:t.autoResume}:{}};case"resumed":return{type:"resumed",hotSwapped:t.hotSwapped,...t.accountId!==void 0?{accountId:t.accountId}:{}};default:return null}}var Ie=class{config;currentState="idle";providerQuery;providerIterator;conversationHistory=[];turnCount=0;lastResponseMetadata=null;initPromise=null;inputStream;abortController;hookRegistry;sessionEndDispatched=!1;stateManager;sessionRunningCostUsd=0;sessionRunningTokens={input:0,output:0,cacheRead:0,cacheCreation:0};lastStopReason;constructor(e){this.config=e,this.abortController=new AbortController,this.hookRegistry=e.hookRegistry,Fs(e.abortSignal,this.abortController,()=>{this.onAbort()}),this.initSdkLifecycle()}initSdkLifecycle(){let e=Be(this.config.model)??this.config.model,{sessionIdentity:n,metadata:r}=Ls(this.config,e);this.stateManager=new bn(n,r),this.inputStream=new gn(()=>this.sessionId);let o=this.config.provider??js(e);F(`\u{1F7E2} AgentSession: Creating query session via provider=${o.name}`),this.providerQuery=o.query({prompt:this.inputStream.createIterable(),config:this.config}),this.conversationHistory=[],this.turnCount=0,this.lastResponseMetadata=null,this.sessionRunningCostUsd=0,this.sessionRunningTokens={input:0,output:0,cacheRead:0,cacheCreation:0},this.lastStopReason=void 0,this.sessionEndDispatched=!1,this.currentState="idle";let s=this.providerQuery;this.providerIterator=s[Symbol.asyncIterator](),this.initPromise=this.pullInitialization()}async pullInitialization(){try{for(await Ms(this.hookRegistry,{event:"SessionStart",sessionId:this.sessionId},{signal:this.abortController.signal,...this.config.traceWriter?{traceWriter:this.config.traceWriter}:{}});;){let e=await this.providerIterator.next();if(e.done){this.stateManager.resolveInitializationIfNeeded();return}let n=e.value,r=kr(n,this.buildTransformDeps());if(n.type==="session.init"||r&&r.type==="error")return}}catch(e){let n=e instanceof Error?e:new Error(String(e));this.stateManager.isInitializationSettled()||this.stateManager.rejectInitializationOnce(n),await this.dispatchSessionEndOnce("error").catch(()=>{})}}buildTransformDeps(){return{conversationHistory:this.conversationHistory,getSessionMetadata:()=>this.stateManager.getSessionMetadata(),setSessionMetadata:e=>this.stateManager.setSessionMetadata(e),updateSessionIdentity:e=>this.stateManager.updateSessionIdentity(e),resolveInitialization:()=>this.stateManager.resolveInitializationOnce(),setLastResponseMetadata:e=>{this.lastResponseMetadata=e,typeof e.totalCostUsd=="number"&&Number.isFinite(e.totalCostUsd)&&(this.sessionRunningCostUsd+=e.totalCostUsd);let n=e.usage;if(n&&typeof n=="object"){let r=n,o=(s,i)=>{let a=r[s];typeof a=="number"&&Number.isFinite(a)&&(this.sessionRunningTokens[i]+=a)};o("input_tokens","input"),o("output_tokens","output"),o("cache_read_input_tokens","cacheRead"),o("cache_creation_input_tokens","cacheCreation")}typeof e.stopReason=="string"&&(this.lastStopReason=e.stopReason)},maxBudgetUsd:this.config.maxBudgetUsd,abortBudget:e=>{this.abortController.signal.aborted||this.abortController.abort(e)},...this.config.traceWriter?{traceWriter:this.config.traceWriter}:{}}}get state(){return this.currentState}get sessionId(){return this.stateManager.getSessionId()}get cwd(){return this.config.cwd}get abortSignal(){return this.abortController.signal}abort(e){if(e==="closed"||e.startsWith("Budget ")||e.includes("timed out"))throw new Error(`AgentSession.abort: reserved reason "${e}" (use a caller-specific string like 'sigint')`);this.abortController.signal.aborted||this.abortController.abort(e)}async sendMessage(e,n={}){this.assertCanSend();let r=this.config.timeoutMs??pn,o=async()=>{let s=null,i="";this.currentState=n.stream?"streaming":"processing";for await(let a of this.sendMessageStreamInternal(e)){if(a.type==="chunk"&&a.chunk.type==="content"&&(i+=a.chunk.content),a.type==="message"&&a.message.role==="assistant"&&(s=a.message),a.type==="error")throw a.error;if(a.type==="done"){if(s)return{...s,metadata:a.metadata};if(i)return{role:"assistant",content:i,metadata:a.metadata,timestamp:new Date}}}if(s)return s;if(i)return{role:"assistant",content:i,timestamp:new Date};throw new Error("No assistant response received")};try{return await fn(o(),r,{controller:this.abortController,label:this.sessionId??"session"})}finally{this.currentState==="processing"&&(this.currentState="idle")}}async*sendMessageStream(e){this.assertCanSend(),this.currentState="streaming";try{yield*this.sendMessageStreamInternal(e)}finally{this.currentState==="streaming"&&(this.currentState="idle")}}async*sendMessageStreamInternal(e){this.initPromise&&await this.initPromise;let r={role:"user",content:typeof e=="string"?e:this.summarizeContentBlocks(e),timestamp:new Date};this.conversationHistory.push(r),this.inputStream.pushUserMessage(e);let o=this.buildTransformDeps();try{for(;;){let s=await this.providerIterator.next();if(s.done)break;let i=s.value,a=kr(i,o);if(a&&(a.type==="done"&&this.turnCount++,yield a,a.type==="done"||a.type==="error"))break}}finally{this.currentState==="streaming"&&(this.currentState="idle")}}summarizeContentBlocks(e){let n=[],r=0;for(let s of e)s.type==="text"?n.push(s.text):s.type==="image"&&r++;let o=n.join(" ");return r>0&&(o=o?`${o} [+ ${r} image(s)]`:`[+ ${r} image(s)]`),o||"[content block(s)]"}async interrupt(){this.currentState!=="streaming"&&this.currentState!=="processing"||(this.currentState="idle",await this.providerQuery.interrupt())}async reset(){if(this.currentState==="closed")throw new Error("Cannot reset: session is closed");if(this.abortController.signal.aborted)throw new ie("Cannot reset: session aborted");if(this.currentState==="processing"||this.currentState==="streaming")try{await this.providerQuery.interrupt()}catch{}await this.dispatchSessionEndOnce("reset");try{await this.providerQuery.close()}catch{}await this.providerIterator.return?.(),this.initPromise&&await Promise.race([this.initPromise,new Promise(e=>setTimeout(e,br))]).catch(()=>{}),this.stateManager.resolveInitializationIfNeeded(),this.config={...this.config},delete this.config.resume,delete this.config.sessionId,delete this.config.resumeHistory,delete this.config.resumeSessionAt,delete this.config.continue,delete this.config.forkSession;try{this.initSdkLifecycle()}catch(e){throw this.currentState="closed",new Error(`Session reset failed during lifecycle rebuild: ${e instanceof Error?e.message:String(e)}`,{cause:e})}}async onAbort(){try{await this.providerQuery.interrupt()}catch{}}async setModel(e){let n=Be(e),r=this.stateManager.getSessionMetadata();await this.providerQuery.setModel(n??r.model??""),n&&this.stateManager.setSessionMetadata(o=>({...o,model:n}))}async setPermissionMode(e){await this.providerQuery.setPermissionMode(e),this.stateManager.setSessionMetadata(n=>({...n,permissionMode:e}))}setCwd(e){this.config={...this.config,cwd:e},this.providerQuery.setCwd?.(e)}async reauth(){return await this.providerQuery.reauth?.()??null}waitForInitialization(){return this.stateManager.waitForInitialization()}getSessionIdentity(){return this.stateManager.getSessionIdentity()}getSessionMetadata(){return this.stateManager.getSessionMetadata()}getQuery(){return this.providerQuery}supportedCommands(){return this.providerQuery.supportedCommands()}supportedModels(){return this.providerQuery.supportedModels()}supportedAgents(){return this.providerQuery.supportedAgents()}getContextUsage(){return this.providerQuery.getContextUsage()}mcpServerStatus(){return this.providerQuery.mcpServerStatus()}accountInfo(){return this.providerQuery.accountInfo()}rewindFiles(e,n){return this.providerQuery.rewindFiles(e,n)}async compact(){if(this.currentState==="closed")throw new Error("Cannot compact: session is closed");if(this.currentState!=="idle")return{compacted:!1,reason:"session-busy",messagesBefore:0,messagesAfter:0};let e=this.providerQuery.compact?.bind(this.providerQuery);return e?e():{compacted:!1,reason:"not-supported",messagesBefore:0,messagesAfter:0}}getLastResponseMetadata(){return this.lastResponseMetadata}getOutputStream(){throw new Error("getOutputStream() is not supported \u2014 use sendMessageStream() instead")}getInputStreamRef(){return{pushUserMessage:e=>this.inputStream.pushUserMessage(e)}}getHistory(){return[...this.conversationHistory]}getTurnCount(){return this.turnCount}async close(){if(this.currentState!=="closed"){this.currentState="closed",this.abortController.signal.aborted||this.abortController.abort("closed"),this.stateManager.resolveInitializationIfNeeded();try{await this.providerQuery.close()}catch{}if(await this.providerIterator.return?.(),this.initPromise)try{await Promise.race([this.initPromise,new Promise(e=>setTimeout(e,br))])}catch{}await this.dispatchSessionEndOnce("close")}}async dispatchSessionEndOnce(e){this.sessionEndDispatched||(this.sessionEndDispatched=!0,await this.emitClosure(e).catch(()=>{}),await this.sealTraceWriter(e).catch(()=>{}),await Os(this.hookRegistry,{event:"SessionEnd",sessionId:this.sessionId,reason:e},this.config.traceWriter?{traceWriter:this.config.traceWriter}:{}))}async emitClosure(e){let n=this.config.traceWriter;if(!n)return;let r=this.deriveClosureReason(e),o={};this.sessionRunningTokens.input>0&&(o.input=this.sessionRunningTokens.input),this.sessionRunningTokens.output>0&&(o.output=this.sessionRunningTokens.output),this.sessionRunningTokens.cacheRead>0&&(o.cacheRead=this.sessionRunningTokens.cacheRead),this.sessionRunningTokens.cacheCreation>0&&(o.cacheCreation=this.sessionRunningTokens.cacheCreation),await Cs(n,{reason:r,finalTurnCount:this.turnCount,finalCostUsd:this.sessionRunningCostUsd,finalTokens:o,...this.lastStopReason!==void 0?{lastStopReason:this.lastStopReason}:{}})}deriveClosureReason(e){if(e==="error")return"abort";let n=this.abortController.signal;if(n.aborted&&n.reason!=="closed"){let r=n.reason;if(r instanceof Ze)return"budget_exceeded";if(r instanceof me)return"timeout";if(typeof r=="string"){if(r.startsWith("Budget "))return"budget_exceeded";if(r.includes("timed out"))return"timeout"}return"abort"}return"model_end_turn"}async sealTraceWriter(e){let n=this.config.traceWriter;if(!n)return;let r=this.deriveSealStatus(e);await n.seal({status:r,finalCostUsd:this.sessionRunningCostUsd,finalTurnCount:this.turnCount,closedAt:new Date().toISOString()})}deriveSealStatus(e){if(e==="error")return"failed";let n=this.abortController.signal;return n.aborted&&n.reason!=="closed"?"cancelled":"succeeded"}assertCanSend(){if(this.currentState==="closed")throw new Error("Cannot send message: session is closed");if(this.abortController.signal.aborted)throw new ie("Cannot send message: session aborted");if(this.currentState==="processing"||this.currentState==="streaming")throw new Error("Cannot send message: session is busy");if(this.config.maxTurns&&this.turnCount>=this.config.maxTurns)throw new Error(`Maximum turns (${this.config.maxTurns}) exceeded`)}};var xt=3e4;function Yd(t,e,n){return new Promise((r,o)=>{let s=!1,i=setTimeout(()=>{s||(s=!0,o(new He(n,e)))},e);i.unref(),Promise.resolve(t).then(a=>{s||(s=!0,clearTimeout(i),r(a))},a=>{s||(s=!0,clearTimeout(i),o(a))})})}var He=class extends Error{constructor(n,r){super(`hook handler timed out after ${r}ms during ${n}`);this.hookEvent=n;this.timeoutMs=r;this.name="HookHandlerTimeoutError"}hookEvent;timeoutMs;code="HOOK_HANDLER_TIMEOUT"},vr=class{handlers=new Map;register(e,n){let r=this.handlers.get(e);return r||(r=[],this.handlers.set(e,r)),r.push(n),()=>{let o=this.handlers.get(e);if(!o)return;let s=o.indexOf(n);s>=0&&o.splice(s,1)}}count(e){return this.handlers.get(e)?.length??0}async dispatch(e,n,r=xt){Sr(n,e.event);let o=this.handlers.get(e.event);if(!o||o.length===0)return{};let s=o.slice(),i={};for(let a of s){Sr(n,e.event);let c;try{let l=a(e);c=r>0&&Number.isFinite(r)?await Yd(l,r,e.event):await l}catch(l){throw l instanceof He?l:new V(`hook handler threw during ${e.event}`,e.event,l instanceof Error?l.message:String(l),{cause:l})}if(Sr(n,e.event),Xd(c))throw new V(`hook handler blocked ${e.event}${c.reason?`: ${c.reason}`:""}`,e.event,c.reason);i=c}return i}};function Xd(t){return t.continue===!1||t.decision==="block"}function Sr(t,e){if(t?.aborted){let n=t.reason,r=`aborted during ${e}${n?`: ${String(n)}`:""}`;throw new ie(r)}}function Ws(){return new vr}async function Pe(t,e,n,r){if(!t)return;if(r.kind==="blocked"){await Qe(t,{hookEvent:e,decision:"block",...r.err.reason!==void 0?{reason:r.err.reason}:{},...e==="PreToolUse"&&n.toolName!==void 0?{blockedTool:n.toolName}:{}});return}let o=r.decision;await Qe(t,{hookEvent:e,decision:o.decision,...o.reason!==void 0?{reason:o.reason}:{},...o.injectContext!==void 0?{injectedContextBytes:Buffer.byteLength(o.injectContext,"utf8")}:{}})}async function Ks(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await Pe(n.traceWriter,"SubagentStart",{},{kind:"decision",decision:r})}catch(r){throw r instanceof V&&await Pe(n.traceWriter,"SubagentStart",{},{kind:"blocked",err:r}),r}}function Qd(t,e,n){return new Promise((r,o)=>{let s=!1,i=setTimeout(()=>{s||(s=!0,o(new He(n,e)))},e);i.unref(),t.then(a=>{s||(s=!0,clearTimeout(i),r(a))},a=>{s||(s=!0,clearTimeout(i),o(a))})})}async function Gs(t,e,n={}){if(!t)return{};try{let r=await Qd(t.dispatch(e,n.signal,xt),xt,"SubagentStop");return await Pe(n.traceWriter,"SubagentStop",{},{kind:"decision",decision:r}),r}catch(r){return r instanceof He?(console.warn(`[afk] SubagentStop hook timed out after ${xt}ms (subagentId=${e.subagentId}): ${r.message}`),n.onError?.(r),{}):(r instanceof V&&await Pe(n.traceWriter,"SubagentStop",{},{kind:"blocked",err:r}),r instanceof V||r instanceof ie?(F(`SubagentStop hook swallowed ${r.name}: ${r.message}`),n.onError?.(r),{}):(F(`SubagentStop hook unexpected error: ${String(r)}`),n.onError?.(r instanceof Error?r:new Error(String(r))),{}))}}async function _r(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await Pe(n.traceWriter,"PreToolUse",{toolName:e.toolName},{kind:"decision",decision:r})}catch(r){throw r instanceof V&&await Pe(n.traceWriter,"PreToolUse",{toolName:e.toolName},{kind:"blocked",err:r}),r}}async function qs(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await Pe(n.traceWriter,"PostToolUse",{toolName:e.toolName},{kind:"decision",decision:r})}catch(r){if(r instanceof V&&await Pe(n.traceWriter,"PostToolUse",{toolName:e.toolName},{kind:"blocked",err:r}),r instanceof V||r instanceof ie){F(`PostToolUse hook swallowed ${r.name}: ${r.message}`),n.onError?.(r);return}F(`PostToolUse hook unexpected error: ${String(r)}`),n.onError?.(r instanceof Error?r:new Error(String(r)))}}N();U();import{mkdir as Zd,writeFile as eu}from"fs/promises";import{dirname as tu,join as nu}from"path";function ru(){return nu(Le(),"routing-decisions.jsonl")}async function Y(t){if(!(S.VITEST||S.NODE_ENV==="test"))try{let e=ru();await Zd(tu(e),{recursive:!0});let r={ts:new Date().toISOString().split(".")[0]+"Z",surface:"afk"};for(let[s,i]of Object.entries(t))i!==void 0&&(r[s]=i);let o=JSON.stringify(r)+`
|
|
1086
1086
|
`;await eu(e,o,{flag:"a"})}catch{}}import{AsyncLocalStorage as ou}from"node:async_hooks";var zs=new ou;function Js(t,e){return zs.run(t,e)}function ae(){return zs.getStore()}U();import to from"path";import{appendFileSync as Om,mkdirSync as Dm}from"fs";import{dirname as Fm}from"path";import Rr from"path";import{appendFileSync as Lu,mkdirSync as Nu}from"fs";import{dirname as $u}from"path";function Er(t,e){return e?.allowedTools?e.allowedTools.includes(t)?{allowed:!0}:{allowed:!1,reason:`Tool "${t}" is not in the configured allowlist`}:{allowed:!0}}U();var su={name:"bash",category:"shell",concurrencySafe:!1,description:"Execute a shell command and return its stdout and stderr. Use for running programs, installing packages, git operations, and any task that requires a shell. Commands run in the user's default shell. Long-running commands should use timeout_ms. Output is capped at ~100KB; excess is truncated with a notice.",input_schema:{type:"object",properties:{command:{type:"string",description:"The shell command to execute."},timeout_ms:{type:"number",description:"Optional timeout in milliseconds (default 120000, max 600000). The command is killed if it exceeds this duration."}},required:["command"]}},iu={name:"read_file",category:"read",concurrencySafe:!0,description:"Read a file from the filesystem. Returns the file content with line numbers. Use offset and limit to read specific sections of large files. When the read returns a partial view, the response ends with a `... (showing lines X-Y of Z [\u2014 pass offset=N to continue])` annotation indicating the full file size and how to continue. Binary files are detected and rejected. Missing files return an error.",input_schema:{type:"object",properties:{file_path:{type:"string",description:"Absolute path to the file to read."},offset:{type:"number",description:"Line number to start reading from (1-based). Defaults to 1."},limit:{type:"number",description:"Maximum number of lines to read. Defaults to 2000."}},required:["file_path"]}},au={name:"write_file",category:"write",concurrencySafe:!1,description:"Write content to a file, creating it if it does not exist or overwriting if it does. Parent directories are created automatically. Prefer edit_file for modifying existing files \u2014 use write_file only for new files or complete rewrites.",input_schema:{type:"object",properties:{file_path:{type:"string",description:"Absolute path to the file to write."},content:{type:"string",description:"The full content to write to the file."}},required:["file_path","content"]}},cu={name:"edit_file",category:"write",concurrencySafe:!1,description:"Perform an exact string replacement in a file. Finds old_string and replaces it with new_string. The edit fails if old_string is not found or matches multiple locations (unless replace_all is true). Always use read_file first to verify the exact content before editing.",input_schema:{type:"object",properties:{file_path:{type:"string",description:"Absolute path to the file to edit."},old_string:{type:"string",description:"The exact string to find and replace. Must match file content exactly."},new_string:{type:"string",description:"The replacement string."},replace_all:{type:"boolean",description:"If true, replace all occurrences. If false (default), fail when multiple matches exist."}},required:["file_path","old_string","new_string"]}},lu={name:"glob",category:"read",concurrencySafe:!0,description:'Find files matching a glob pattern. Returns matching file paths, capped at 500 results. Use for discovering files before reading them. Patterns follow standard glob syntax (e.g., "src/**/*.ts", "*.json").',input_schema:{type:"object",properties:{pattern:{type:"string",description:'Glob pattern to match (e.g., "src/**/*.ts").'},path:{type:"string",description:"Base directory to search from. Defaults to the current working directory."}},required:["pattern"]}},du={name:"grep",category:"read",concurrencySafe:!0,description:"Search file contents for lines matching a pattern. Returns matches in file:line:content format. Uses grep -rn (or ripgrep if available). Output is capped to prevent overflow. Use for finding symbols, strings, or patterns across the codebase.",input_schema:{type:"object",properties:{pattern:{type:"string",description:"Search pattern (basic regex by default)."},path:{type:"string",description:"Directory or file to search. Defaults to current working directory."},include:{type:"string",description:'File glob to restrict search (e.g., "*.ts"). Passed as --include to grep.'}},required:["pattern"]}},uu={name:"list_directory",category:"read",concurrencySafe:!0,description:"List the contents of a directory. Returns file and subdirectory names with type annotations (directories end with /). Use for exploring project structure.",input_schema:{type:"object",properties:{path:{type:"string",description:"Absolute path to the directory to list."}},required:["path"]}},pu={name:"send_telegram",category:"web",concurrencySafe:!1,riskClass:"caution",description:"Send a Telegram message to the operator. Use to surface terminal-state notifications, blocking questions, or important status updates when the user is away from keyboard (AFK). The message is delivered through the same Telegram bot the operator uses to drive this session, to every chat ID in `AFK_TELEGRAM_ALLOWED_CHAT_IDS` (typically just the operator).\n\nPlain text only \u2014 Telegram's 4096-character limit per message is enforced. Returns an error if Telegram is not configured (missing `TELEGRAM_BOT_TOKEN` or empty allowlist) so the tool is safe to attempt unconditionally.\n\nUse sparingly: this is a real push notification to a human. Reserve for terminal states (Done/Blocked/Asking) and material progress, not running commentary. When running inside the Telegram bot, prefer replying normally \u2014 your response already reaches the operator through the bot. Use this tool only from CLI or daemon sessions.",input_schema:{type:"object",properties:{message:{type:"string",description:"Plain-text message body to send to the operator. Max 4096 characters (Telegram API limit). Must be non-empty."}},required:["message"]}},fu={name:"web_scrape",category:"web",concurrencySafe:!0,description:'Scrape a web page or run a web search and return text content suitable for reasoning over. Three modes:\n\n- `markdown` (default): converts the target URL to clean markdown via Firecrawl (https://firecrawl.dev). Handles JS-rendered pages because rendering happens server-side. Use this for articles, docs, blog posts, and most "I want to read this page" cases. Requires `FIRECRAWL_API_KEY`.\n- `raw`: GETs the URL directly with no transformation. Use for JSON APIs, robots.txt, RSS, plain-text endpoints, or when you need the literal bytes. No API key required.\n- `search`: queries Firecrawl Search and returns ranked markdown results. Use when you need to FIND a URL, not read one. Provide `query` instead of `url`. Requires `FIRECRAWL_API_KEY`.\n\nThe `markdown` and `search` modes require `FIRECRAWL_API_KEY` in the environment (no anonymous tier). The handler fails fast with a clear error if the key is missing.\n\nOutputs are capped at `max_bytes` UTF-8 bytes (default 1MB, ceiling 10MB) and the request is aborted after `timeout_ms` (default 30000, ceiling 120000).',input_schema:{type:"object",properties:{mode:{type:"string",enum:["markdown","raw","search"],description:'Fetch mode. Defaults to "markdown".'},url:{type:"string",description:"Absolute http(s) URL. Required for markdown and raw modes. Ignored in search mode."},query:{type:"string",description:"Search query string. Required for search mode. Ignored otherwise."},timeout_ms:{type:"number",description:"Request timeout in milliseconds (default 30000, clamped to 120000)."},max_bytes:{type:"number",description:"Maximum UTF-8 bytes returned. Content beyond this is truncated with a marker. Default 1000000, clamped to 10000000."}},required:[]}},je={name:"agent",category:"subagent",concurrencySafe:!0,description:`Dispatch an independent subagent with its own context window and tool access. Use for tasks that protect the main session's context: codebase exploration, multi-file inspection, repo search, verification, debugging, failing-test investigation, PR review, parallel hypothesis testing, independent re-derivation of a claim, audit work, stale-path detection, feature-wiring checks, and any research-shaped investigation.
|
|
1087
1087
|
|
|
@@ -1127,7 +1127,7 @@ ${n.join(`
|
|
|
1127
1127
|
`;try{await n(c,l,"utf-8"),await Zp(c,i),r.push(`${s.name}: terminal.integrated.fontSize set to ${e}`)}catch(d){let u=d;r.push(`${s.name}: could not write settings \u2014 ${u.message}`),o=!0}}return o?{content:r.join(`
|
|
1128
1128
|
`),isError:!0}:{content:r.join(`
|
|
1129
1129
|
`)}}var af=Ur();var ot={action:"decline"},Br=class{handler=null;timeoutMs=3e5;queue=Promise.resolve();queueDepth=0;install(e,n={}){this.handler=e,this.timeoutMs=n.timeoutMs??3e5}uninstall(){this.handler=null,this.timeoutMs=3e5}pendingCount(){return this.queueDepth}route(e,n){if(n.signal.aborted)return Promise.resolve(ot);this.queueDepth+=1;let r,o=new Promise(a=>{r=a}),s=this.handler,i=this.timeoutMs;return this.queue=this.queue.then(async()=>{try{if(n.signal.aborted){r(ot);return}if(!s){r(ot);return}let a=null,c=new Promise(l=>{a=setTimeout(()=>l(ot),i)});try{let l=await Promise.race([s(e,n).catch(()=>ot),c]);r(l)}finally{a!==null&&clearTimeout(a)}}finally{this.queueDepth-=1,r(ot)}}).catch(()=>{}),o}},Mt=new Br;var Ri=async(t,e)=>{if(!t||typeof t!="object")return{content:"Invalid input: expected an object",isError:!0};let n=t,r=n.question;if(typeof r!="string"||r.trim()==="")return{content:"Invalid input: question must be a non-empty string",isError:!0};let o=new Set(["text","confirm","choice","multi_choice","number"]),s=n.type??"text";if(typeof s!="string"||!o.has(s))return{content:"Invalid input: type must be one of: text, confirm, choice, multi_choice, number",isError:!0};if(s==="choice"||s==="multi_choice"){let g=n.choices;if(!Array.isArray(g)||g.length===0)return{content:`Invalid input: choices array is required and must be non-empty for type "${s}"`,isError:!0};if(g.length>100)return{content:`Invalid input: choices array must not exceed 100 items, got ${g.length}`,isError:!0};for(let m of g)if(typeof m!="string")return{content:"Invalid input: all choices must be strings",isError:!0}}let i=n.min,a=n.max;if(i!==void 0&&(typeof i!="number"||!Number.isFinite(i)))return{content:"Invalid input: min must be a finite number",isError:!0};if(a!==void 0&&(typeof a!="number"||!Number.isFinite(a)))return{content:"Invalid input: max must be a finite number",isError:!0};if(i!==void 0&&a!==void 0&&i>a)return{content:`Invalid input: min (${i}) must be \u2264 max (${a})`,isError:!0};let c=n.min_length,l=n.max_length;if(c!==void 0&&typeof c!="number")return{content:"Invalid input: min_length must be a number",isError:!0};if(l!==void 0&&typeof l!="number")return{content:"Invalid input: max_length must be a number",isError:!0};if((c!==void 0||l!==void 0)&&s!=="text")return{content:`Invalid input: min_length/max_length are only valid for type "text", got "${s}"`,isError:!0};let d={serverName:"agent",message:r.trim(),origin:"agent",type:s,...n.choices!==void 0&&{choices:n.choices},...n.context!==void 0&&typeof n.context=="string"&&{context:n.context},...n.default!==void 0&&{questionDefault:n.default},...c!==void 0&&{minLength:c},...l!==void 0&&{maxLength:l},...i!==void 0&&{min:i},...a!==void 0&&{max:a},...n.allow_skip!==void 0&&{allowSkip:!!n.allow_skip}},u=await Mt.route(d,{signal:e}),p=u.action==="decline"||u.action==="cancel";return{content:JSON.stringify(u),...p&&{isError:!0}}};N();var Zf=["Cannot find package","ERR_MODULE_NOT_FOUND"],Qi=["load","domcontentloaded","networkidle"];function em(t){if(!t||typeof t!="object")return{error:"browser_open: input must be an object"};let e=t,n=e.url;if(typeof n!="string"||n.length===0)return{error:'browser_open: "url" is required and must be a non-empty string'};let r;try{r=new URL(n)}catch{return{error:`browser_open: "${n}" is not a valid absolute URL`}}if(r.protocol!=="http:"&&r.protocol!=="https:")return{error:`browser_open: protocol "${r.protocol}" is not supported (http/https only)`};let o;if(e.wait_for!==void 0){if(!Qi.includes(e.wait_for))return{error:`browser_open: "wait_for" must be one of ${Qi.map(a=>`"${a}"`).join(", ")} (got ${JSON.stringify(e.wait_for)})`};o=e.wait_for}let s;if(e.screenshot!==void 0){if(typeof e.screenshot!="boolean")return{error:'browser_open: "screenshot" must be a boolean'};s=e.screenshot}let i;if(e.timeout_ms!==void 0){if(typeof e.timeout_ms!="number"||!Number.isFinite(e.timeout_ms)||e.timeout_ms<=0)return{error:'browser_open: "timeout_ms" must be a positive finite number'};i=e.timeout_ms}return{url:r.toString(),waitFor:o,screenshot:s,timeoutMs:i}}function tm(t={}){return async(e,n)=>{if(n.aborted){let i=n.reason;return{content:`browser_open aborted: ${i instanceof Error?i.message:String(i??"aborted")}`,isError:!0}}let r=em(e);if("error"in r)return{content:r.error,isError:!0};let o=S.AFK_SESSION_ID??"default";if(!/^[a-zA-Z0-9_-]+$/.test(o))return{content:`Invalid AFK_SESSION_ID: must match /^[a-zA-Z0-9_-]+$/, got: ${JSON.stringify(o)}`,isError:!0};let s;try{if(t.getBrowserProvider)s=await t.getBrowserProvider();else{let{getBrowserProvider:i}=await Promise.resolve().then(()=>(it(),st));s=await i()}}catch(i){let a=i instanceof Error?i.message:String(i);return Zf.some(c=>a.includes(c))?{content:"browser tools require the optional `playwright` peer dependency. Install via: pnpm add playwright. Or pick a different tool.",isError:!0}:{content:`browser_open failed to get provider: ${a}`,isError:!0}}try{let i=await s.open({sessionId:o,url:r.url,waitFor:r.waitFor,screenshot:r.screenshot,timeoutMs:r.timeoutMs});return"outcome"in i&&i.outcome==="blocked_by_policy"?{content:`browser_open blocked: ${i.reason}`,isError:!0}:{content:JSON.stringify(i,null,2)}}catch(i){return{content:`browser_open failed: ${i instanceof Error?i.message:String(i)}`,isError:!0}}}}var Zi=tm();N();var nm=["Cannot find package","ERR_MODULE_NOT_FOUND"];function rm(t){if(t!=null&&typeof t!="object")return{error:"browser_observe: input must be an object or omitted"};if(!t)return{};let e=t,n;if(e.screenshot!==void 0){if(typeof e.screenshot!="boolean")return{error:'browser_observe: "screenshot" must be a boolean'};n=e.screenshot}let r;if(e.include_hidden!==void 0){if(typeof e.include_hidden!="boolean")return{error:'browser_observe: "include_hidden" must be a boolean'};r=e.include_hidden}let o;if(e.max_elements!==void 0){if(typeof e.max_elements!="number"||!Number.isFinite(e.max_elements)||e.max_elements<=0||!Number.isInteger(e.max_elements))return{error:'browser_observe: "max_elements" must be a positive integer'};o=e.max_elements}return{screenshot:n,includeHidden:r,maxElements:o}}function om(t={}){return async(e,n)=>{if(n.aborted){let i=n.reason;return{content:`browser_observe aborted: ${i instanceof Error?i.message:String(i??"aborted")}`,isError:!0}}let r=rm(e);if("error"in r)return{content:r.error,isError:!0};let o=S.AFK_SESSION_ID??"default";if(!/^[a-zA-Z0-9_-]+$/.test(o))return{content:`Invalid AFK_SESSION_ID: must match /^[a-zA-Z0-9_-]+$/, got: ${JSON.stringify(o)}`,isError:!0};let s;try{if(t.getBrowserProvider)s=await t.getBrowserProvider();else{let{getBrowserProvider:i}=await Promise.resolve().then(()=>(it(),st));s=await i()}}catch(i){let a=i instanceof Error?i.message:String(i);return nm.some(c=>a.includes(c))?{content:"browser tools require the optional `playwright` peer dependency. Install via: pnpm add playwright. Or pick a different tool.",isError:!0}:{content:`browser_observe failed to get provider: ${a}`,isError:!0}}try{let i=await s.observe({sessionId:o,screenshot:r.screenshot,includeHidden:r.includeHidden,maxElements:r.maxElements});return{content:JSON.stringify(i,null,2)}}catch(i){return{content:`browser_observe failed: ${i instanceof Error?i.message:String(i)}`,isError:!0}}}}var ea=om();Ot();N();var sm=["Cannot find package","ERR_MODULE_NOT_FOUND"],ta=["click","fill","press","select","hover","scroll_to","wait_for"],na=["semantic","element_id","selector"];function im(t){if(!t||typeof t!="object")return{error:"browser_act: input must be an object"};let e=t;if(typeof e.action!="string")return{error:'browser_act: "action" is required and must be a string'};if(!ta.includes(e.action))return{error:`browser_act: "action" must be one of ${ta.map(d=>`"${d}"`).join(", ")} (got ${JSON.stringify(e.action)})`};let n=e.action,r=e.target;if(!r||typeof r!="object")return{error:'browser_act: "target" is required and must be an object'};let o=r;if(typeof o.kind!="string"||!na.includes(o.kind))return{error:`browser_act: "target.kind" must be one of ${na.map(d=>`"${d}"`).join(", ")} (got ${JSON.stringify(o.kind)})`};let s,i=o.kind;if(i==="semantic"){if(typeof o.text!="string"||o.text.length===0)return{error:'browser_act: target.kind=semantic requires "target.text" (non-empty string)'};s={kind:"semantic",text:o.text,...typeof o.role=="string"&&o.role.length>0?{role:o.role}:{}}}else if(i==="element_id"){if(typeof o.element_id!="string"||o.element_id.length===0)return{error:'browser_act: target.kind=element_id requires "target.element_id" (non-empty string)'};s={kind:"element_id",elementId:o.element_id}}else{if(typeof o.selector!="string"||o.selector.length===0)return{error:'browser_act: target.kind=selector requires "target.selector" (non-empty string)'};s={kind:"selector",selector:o.selector}}let a;if(e.value!==void 0){if(typeof e.value!="string")return{error:'browser_act: "value" must be a string when provided'};a=e.value}let c;if(e.timeout_ms!==void 0){if(typeof e.timeout_ms!="number"||!Number.isFinite(e.timeout_ms)||e.timeout_ms<=0)return{error:'browser_act: "timeout_ms" must be a positive finite number'};c=e.timeout_ms}let l;if(e.screenshot!==void 0){if(typeof e.screenshot!="boolean")return{error:'browser_act: "screenshot" must be a boolean'};l=e.screenshot}return{action:n,target:s,value:a,timeoutMs:c,screenshot:l}}function am(t,e){let n=t.role?`"${t.text}" (role: ${t.role})`:`"${t.text}"`;return[`browser_act: ambiguous target \u2014 ${e.length} elements matched ${n}.`,'Retry with target.kind="element_id" using one of the following:',...e.map(o=>` id=${o.id} role=${o.role} label=${o.label}`)].join(`
|
|
1130
|
-
`)}function cm(t){return t.kind==="semantic"?`semantic:${Fi(t.text)}`:t.kind==="element_id"?`element_id:${t.elementId}`:`selector:${Di(t.selector)}`}function lm(t={}){return async(e,n)=>{if(n.aborted){let a=n.reason;return{content:`browser_act aborted: ${a instanceof Error?a.message:String(a??"aborted")}`,isError:!0}}let r=im(e);if("error"in r)return{content:r.error,isError:!0};let o=cm(r.target),s=S.AFK_SESSION_ID??"default";if(!/^[a-zA-Z0-9_-]+$/.test(s))return{content:`Invalid AFK_SESSION_ID: must match /^[a-zA-Z0-9_-]+$/, got: ${JSON.stringify(s)}`,isError:!0};let i;try{if(t.getBrowserProvider)i=await t.getBrowserProvider();else{let{getBrowserProvider:a}=await Promise.resolve().then(()=>(it(),st));i=await a()}}catch(a){let c=a instanceof Error?a.message:String(a);return sm.some(l=>c.includes(l))?{content:"browser tools require the optional `playwright` peer dependency. Install via: pnpm add playwright. Or pick a different tool.",isError:!0}:{content:`browser_act failed to get provider: ${c}`,isError:!0}}try{let a=await i.act({sessionId:s,action:r.action,target:r.target,value:r.value,timeoutMs:r.timeoutMs,screenshot:r.screenshot});if("outcome"in a){if(a.outcome==="ambiguous_target")return{content:am(a.query,a.candidates),isError:!0};if(a.outcome==="blocked_by_policy")return{content:`browser_act blocked: ${a.reason}`,isError:!0}}return{content:JSON.stringify(a,null,2)}}catch(a){return{content:`browser_act failed: ${a instanceof Error?a.message:String(a)}`,isError:!0}}}}var ra=lm();N();var dm=["Cannot find package","ERR_MODULE_NOT_FOUND"],oa=["semantic","element_id","selector"];function um(t){if(typeof t.kind!="string"||!oa.includes(t.kind))return{error:`browser_screenshot: "target.kind" must be one of ${oa.map(n=>`"${n}"`).join(", ")} (got ${JSON.stringify(t.kind)})`};let e=t.kind;return e==="semantic"?typeof t.text!="string"||t.text.length===0?{error:'browser_screenshot: target.kind=semantic requires "target.text" (non-empty string)'}:{kind:"semantic",text:t.text,...typeof t.role=="string"&&t.role.length>0?{role:t.role}:{}}:e==="element_id"?typeof t.element_id!="string"||t.element_id.length===0?{error:'browser_screenshot: target.kind=element_id requires "target.element_id" (non-empty string)'}:{kind:"element_id",elementId:t.element_id}:typeof t.selector!="string"||t.selector.length===0?{error:'browser_screenshot: target.kind=selector requires "target.selector" (non-empty string)'}:{kind:"selector",selector:t.selector}}function pm(t){if(t!=null&&typeof t!="object")return{error:"browser_screenshot: input must be an object or omitted"};if(!t)return{};let e=t,n;if(e.target!==void 0){if(!e.target||typeof e.target!="object")return{error:'browser_screenshot: "target" must be an object when provided'};let o=um(e.target);if("error"in o)return o;n=o}let r;if(e.full_page!==void 0){if(typeof e.full_page!="boolean")return{error:'browser_screenshot: "full_page" must be a boolean'};r=e.full_page}return{target:n,fullPage:r}}function fm(t={}){return async(e,n)=>{if(n.aborted){let i=n.reason;return{content:`browser_screenshot aborted: ${i instanceof Error?i.message:String(i??"aborted")}`,isError:!0}}let r=pm(e);if("error"in r)return{content:r.error,isError:!0};let o=S.AFK_SESSION_ID??"default";if(!/^[a-zA-Z0-9_-]+$/.test(o))return{content:`Invalid AFK_SESSION_ID: must match /^[a-zA-Z0-9_-]+$/, got: ${JSON.stringify(o)}`,isError:!0};let s;try{if(t.getBrowserProvider)s=await t.getBrowserProvider();else{let{getBrowserProvider:i}=await Promise.resolve().then(()=>(it(),st));s=await i()}}catch(i){let a=i instanceof Error?i.message:String(i);return dm.some(c=>a.includes(c))?{content:"browser tools require the optional `playwright` peer dependency. Install via: pnpm add playwright. Or pick a different tool.",isError:!0}:{content:`browser_screenshot failed to get provider: ${a}`,isError:!0}}try{let i=await s.screenshot({sessionId:o,target:r.target,fullPage:r.fullPage});return{content:JSON.stringify(i,null,2)}}catch(i){return{content:`browser_screenshot failed: ${i instanceof Error?i.message:String(i)}`,isError:!0}}}}var sa=fm();N();var mm=["Cannot find package","ERR_MODULE_NOT_FOUND"];function gm(t={}){return async(e,n)=>{if(n.aborted){let s=n.reason;return{content:`browser_close aborted: ${s instanceof Error?s.message:String(s??"aborted")}`,isError:!0}}let r=S.AFK_SESSION_ID??"default";if(!/^[a-zA-Z0-9_-]+$/.test(r))return{content:`Invalid AFK_SESSION_ID: must match /^[a-zA-Z0-9_-]+$/, got: ${JSON.stringify(r)}`,isError:!0};let o;try{if(t.getBrowserProvider)o=await t.getBrowserProvider();else{let{getBrowserProvider:s}=await Promise.resolve().then(()=>(it(),st));o=await s()}}catch(s){let i=s instanceof Error?s.message:String(s);return mm.some(a=>i.includes(a))?{content:"browser tools require the optional `playwright` peer dependency. Install via: pnpm add playwright. Or pick a different tool.",isError:!0}:{content:`browser_close failed to get provider: ${i}`,isError:!0}}try{return await o.close({sessionId:r}),{content:"Browser session closed."}}catch(s){return{content:`browser_close failed: ${s instanceof Error?s.message:String(s)}`,isError:!0}}}}var ia=gm();function Rn(t,e){let n=t!==void 0?kn(t,e):e!==void 0?kn("default",e):Xs,r=e!==void 0?Mr(e):si,o=e!==void 0?Or(e):ai,s=Ur();return new Map([["bash",n],["read_file",Qs],["write_file",ti],["edit_file",ni],["glob",r],["grep",o],["list_directory",ci],["send_telegram",pi],["web_scrape",mi],["create_schedule",Si],["list_schedules",vi],["get_schedule_history",_i],["cancel_schedule",Ei],["terminal_font_size",s],["ask_question",Ri],["browser_open",Zi],["browser_observe",ea],["browser_act",ra],["browser_screenshot",sa],["browser_close",ia]])}import Tm from"openai";import{randomUUID as Rm}from"node:crypto";function Dt(t,e){let n=(u,p)=>{if(!(u==null&&p==null))return(u??0)+(p??0)},r=(u,p)=>p!==void 0?p:u,o={stopReason:e.stopReason??t.stopReason??null},s=n(t.inputTokens,e.inputTokens);s!==void 0&&(o.inputTokens=s);let i=n(t.outputTokens,e.outputTokens);i!==void 0&&(o.outputTokens=i);let a=r(t.cachedInputTokens,e.cachedInputTokens);a!==void 0&&(o.cachedInputTokens=a);let c=r(t.cacheCreationTokens,e.cacheCreationTokens);c!==void 0&&(o.cacheCreationTokens=c);let l=n(t.totalTokens,e.totalTokens);l!==void 0&&(o.totalTokens=l);let d=n(t.totalCostUsd,e.totalCostUsd);return d!==void 0&&(o.totalCostUsd=d),o}var hm={opus:128e3,opus_1m:128e3,sonnet:64e3,sonnet_1m:64e3,haiku:64e3,"claude-opus-4-
|
|
1130
|
+
`)}function cm(t){return t.kind==="semantic"?`semantic:${Fi(t.text)}`:t.kind==="element_id"?`element_id:${t.elementId}`:`selector:${Di(t.selector)}`}function lm(t={}){return async(e,n)=>{if(n.aborted){let a=n.reason;return{content:`browser_act aborted: ${a instanceof Error?a.message:String(a??"aborted")}`,isError:!0}}let r=im(e);if("error"in r)return{content:r.error,isError:!0};let o=cm(r.target),s=S.AFK_SESSION_ID??"default";if(!/^[a-zA-Z0-9_-]+$/.test(s))return{content:`Invalid AFK_SESSION_ID: must match /^[a-zA-Z0-9_-]+$/, got: ${JSON.stringify(s)}`,isError:!0};let i;try{if(t.getBrowserProvider)i=await t.getBrowserProvider();else{let{getBrowserProvider:a}=await Promise.resolve().then(()=>(it(),st));i=await a()}}catch(a){let c=a instanceof Error?a.message:String(a);return sm.some(l=>c.includes(l))?{content:"browser tools require the optional `playwright` peer dependency. Install via: pnpm add playwright. Or pick a different tool.",isError:!0}:{content:`browser_act failed to get provider: ${c}`,isError:!0}}try{let a=await i.act({sessionId:s,action:r.action,target:r.target,value:r.value,timeoutMs:r.timeoutMs,screenshot:r.screenshot});if("outcome"in a){if(a.outcome==="ambiguous_target")return{content:am(a.query,a.candidates),isError:!0};if(a.outcome==="blocked_by_policy")return{content:`browser_act blocked: ${a.reason}`,isError:!0}}return{content:JSON.stringify(a,null,2)}}catch(a){return{content:`browser_act failed: ${a instanceof Error?a.message:String(a)}`,isError:!0}}}}var ra=lm();N();var dm=["Cannot find package","ERR_MODULE_NOT_FOUND"],oa=["semantic","element_id","selector"];function um(t){if(typeof t.kind!="string"||!oa.includes(t.kind))return{error:`browser_screenshot: "target.kind" must be one of ${oa.map(n=>`"${n}"`).join(", ")} (got ${JSON.stringify(t.kind)})`};let e=t.kind;return e==="semantic"?typeof t.text!="string"||t.text.length===0?{error:'browser_screenshot: target.kind=semantic requires "target.text" (non-empty string)'}:{kind:"semantic",text:t.text,...typeof t.role=="string"&&t.role.length>0?{role:t.role}:{}}:e==="element_id"?typeof t.element_id!="string"||t.element_id.length===0?{error:'browser_screenshot: target.kind=element_id requires "target.element_id" (non-empty string)'}:{kind:"element_id",elementId:t.element_id}:typeof t.selector!="string"||t.selector.length===0?{error:'browser_screenshot: target.kind=selector requires "target.selector" (non-empty string)'}:{kind:"selector",selector:t.selector}}function pm(t){if(t!=null&&typeof t!="object")return{error:"browser_screenshot: input must be an object or omitted"};if(!t)return{};let e=t,n;if(e.target!==void 0){if(!e.target||typeof e.target!="object")return{error:'browser_screenshot: "target" must be an object when provided'};let o=um(e.target);if("error"in o)return o;n=o}let r;if(e.full_page!==void 0){if(typeof e.full_page!="boolean")return{error:'browser_screenshot: "full_page" must be a boolean'};r=e.full_page}return{target:n,fullPage:r}}function fm(t={}){return async(e,n)=>{if(n.aborted){let i=n.reason;return{content:`browser_screenshot aborted: ${i instanceof Error?i.message:String(i??"aborted")}`,isError:!0}}let r=pm(e);if("error"in r)return{content:r.error,isError:!0};let o=S.AFK_SESSION_ID??"default";if(!/^[a-zA-Z0-9_-]+$/.test(o))return{content:`Invalid AFK_SESSION_ID: must match /^[a-zA-Z0-9_-]+$/, got: ${JSON.stringify(o)}`,isError:!0};let s;try{if(t.getBrowserProvider)s=await t.getBrowserProvider();else{let{getBrowserProvider:i}=await Promise.resolve().then(()=>(it(),st));s=await i()}}catch(i){let a=i instanceof Error?i.message:String(i);return dm.some(c=>a.includes(c))?{content:"browser tools require the optional `playwright` peer dependency. Install via: pnpm add playwright. Or pick a different tool.",isError:!0}:{content:`browser_screenshot failed to get provider: ${a}`,isError:!0}}try{let i=await s.screenshot({sessionId:o,target:r.target,fullPage:r.fullPage});return{content:JSON.stringify(i,null,2)}}catch(i){return{content:`browser_screenshot failed: ${i instanceof Error?i.message:String(i)}`,isError:!0}}}}var sa=fm();N();var mm=["Cannot find package","ERR_MODULE_NOT_FOUND"];function gm(t={}){return async(e,n)=>{if(n.aborted){let s=n.reason;return{content:`browser_close aborted: ${s instanceof Error?s.message:String(s??"aborted")}`,isError:!0}}let r=S.AFK_SESSION_ID??"default";if(!/^[a-zA-Z0-9_-]+$/.test(r))return{content:`Invalid AFK_SESSION_ID: must match /^[a-zA-Z0-9_-]+$/, got: ${JSON.stringify(r)}`,isError:!0};let o;try{if(t.getBrowserProvider)o=await t.getBrowserProvider();else{let{getBrowserProvider:s}=await Promise.resolve().then(()=>(it(),st));o=await s()}}catch(s){let i=s instanceof Error?s.message:String(s);return mm.some(a=>i.includes(a))?{content:"browser tools require the optional `playwright` peer dependency. Install via: pnpm add playwright. Or pick a different tool.",isError:!0}:{content:`browser_close failed to get provider: ${i}`,isError:!0}}try{return await o.close({sessionId:r}),{content:"Browser session closed."}}catch(s){return{content:`browser_close failed: ${s instanceof Error?s.message:String(s)}`,isError:!0}}}}var ia=gm();function Rn(t,e){let n=t!==void 0?kn(t,e):e!==void 0?kn("default",e):Xs,r=e!==void 0?Mr(e):si,o=e!==void 0?Or(e):ai,s=Ur();return new Map([["bash",n],["read_file",Qs],["write_file",ti],["edit_file",ni],["glob",r],["grep",o],["list_directory",ci],["send_telegram",pi],["web_scrape",mi],["create_schedule",Si],["list_schedules",vi],["get_schedule_history",_i],["cancel_schedule",Ei],["terminal_font_size",s],["ask_question",Ri],["browser_open",Zi],["browser_observe",ea],["browser_act",ra],["browser_screenshot",sa],["browser_close",ia]])}import Tm from"openai";import{randomUUID as Rm}from"node:crypto";function Dt(t,e){let n=(u,p)=>{if(!(u==null&&p==null))return(u??0)+(p??0)},r=(u,p)=>p!==void 0?p:u,o={stopReason:e.stopReason??t.stopReason??null},s=n(t.inputTokens,e.inputTokens);s!==void 0&&(o.inputTokens=s);let i=n(t.outputTokens,e.outputTokens);i!==void 0&&(o.outputTokens=i);let a=r(t.cachedInputTokens,e.cachedInputTokens);a!==void 0&&(o.cachedInputTokens=a);let c=r(t.cacheCreationTokens,e.cacheCreationTokens);c!==void 0&&(o.cacheCreationTokens=c);let l=n(t.totalTokens,e.totalTokens);l!==void 0&&(o.totalTokens=l);let d=n(t.totalCostUsd,e.totalCostUsd);return d!==void 0&&(o.totalCostUsd=d),o}var hm={opus:128e3,opus_1m:128e3,sonnet:64e3,sonnet_1m:64e3,haiku:64e3,"claude-opus-4-8":128e3,"claude-sonnet-4-6":64e3,"claude-haiku-4-5-20251001":64e3},ym=64e3;function ca(t){return hm[t]??ym}var aa={opus:2e5,opus_1m:1e6,sonnet:2e5,sonnet_1m:1e6,haiku:2e5,"gpt-4o":128e3,"gpt-4o-mini":128e3,"gpt-4.1":1e6,"gpt-4.1-mini":1e6,o1:2e5,"o1-mini":128e3,o3:2e5,"o3-mini":2e5,"o4-mini":2e5,"mlx-community/qwen3-30b-a3b-4bit":128e3,"mlx-community/qwen3-32b-4bit":128e3,"mlx-community/qwen2.5-coder-32b-instruct-4bit":131072},bm=2e5,wm=262144;function km(t){if(!t)return!1;let e=t.trim().toLowerCase();return e?!!(e.includes("/")||e.startsWith("gpt-")||e.startsWith("gpt_")||e.startsWith("o1")||e.startsWith("o3")||e.startsWith("o4")||e.startsWith("codex-")||e.startsWith("codex_")||e==="codex"):!1}function Ft(t){let e=aa[t]??aa[t.toLowerCase()];return e!==void 0?e:km(t)?wm:bm}import{readFileSync as Sm}from"node:fs";import{homedir as vm}from"node:os";import{join as _m}from"node:path";function Em(t){try{return Sm(t,"utf-8")}catch{return null}}function Xr(t,e={}){let n=e.readEnv??(c=>process.env[c]),r=(e.homedir??vm)(),o=e.readFile??Em;if(t&&t.length>0)return{apiKey:t,source:"config",last4:Yr(t)};let s=n("OPENAI_API_KEY");if(s&&s.length>0)return{apiKey:s,source:"env",last4:Yr(s)};let i=_m(r,".codex","auth.json"),a=o(i);if(a!==null){let c=Am(a);if(c.kind==="apikey")return{apiKey:c.apiKey,source:"codex-cli",last4:Yr(c.apiKey)};if(c.kind==="chatgpt")return{apiKey:null,source:"no-usable-auth-codex-oauth"}}return{apiKey:null,source:"no-usable-auth"}}function Am(t){let e;try{e=JSON.parse(t)}catch{return{kind:"invalid"}}if(typeof e!="object"||e===null)return{kind:"invalid"};let n=e,r=n.OPENAI_API_KEY;return typeof r=="string"&&r.length>0?{kind:"apikey",apiKey:r}:n.auth_mode==="chatgpt"?{kind:"chatgpt"}:{kind:"no-key"}}function Yr(t){return t.length<=4?t:t.slice(-4)}function Qr(t){switch(t.source){case"config":return`using explicit AFK config API key (\u2026${t.last4??"????"})`;case"env":return`using OPENAI_API_KEY env var (\u2026${t.last4??"????"})`;case"codex-cli":return`using Codex CLI API key from ~/.codex/auth.json (\u2026${t.last4??"????"})`;case"no-usable-auth-codex-oauth":return"AFK OpenAI provider currently requires API key auth. Found ChatGPT/OAuth credentials in ~/.codex/auth.json but no API key. Run `codex login --api-key` or set OPENAI_API_KEY.";default:return"No OpenAI auth found. Set OPENAI_API_KEY, pass an explicit apiKey in AFK config, or run `codex login --api-key`."}}function la(t){return typeof t=="string"?t:t.map(e=>{if(typeof e=="object"&&e&&"type"in e){if(e.type==="text")return e.text;if(e.type==="image")return"[image omitted]"}return""}).join(`
|
|
1131
1131
|
`)}function xm(t){let e=t.systemPrompt;if(e!==void 0){if(typeof e=="string")return e.length>0?e:void 0;if(typeof e=="object"&&e!==null&&"append"in e){let n=e.append;return n&&n.length>0?n:void 0}}}function da(t){let e=[],n=xm(t.config);if(n!==void 0&&e.push({role:"system",content:n}),t.resumeHistory)for(let r of t.resumeHistory)r.user&&e.push({role:"user",content:r.user}),r.assistant&&e.push({role:"assistant",content:r.assistant});if(t.priorTurns)for(let r of t.priorTurns)e.push(r);return t.currentUserText!==void 0&&e.push({role:"user",content:t.currentUserText}),e}function ua(){return{assistantText:"",reasoningText:"",toolCallsByIndex:new Map,finishReason:null,usage:null,model:null,id:null}}function*pa(t,e,n){t.id&&!e.id&&(e.id=t.id),t.model&&!e.model&&(e.model=t.model),t.usage&&(e.usage=t.usage);let r=t.choices?.[0];if(!r)return;r.finish_reason&&(e.finishReason=r.finish_reason);let o=r.delta;if(!o)return;let s=o.reasoning_content??o.reasoning;if(typeof s=="string"&&s.length>0&&(e.reasoningText+=s,yield{type:"delta.reasoning",text:s,sessionId:n}),typeof o.content=="string"&&o.content.length>0&&(e.assistantText+=o.content,yield{type:"delta.text",text:o.content,sessionId:n}),o.tool_calls&&o.tool_calls.length>0)for(let i of o.tool_calls){let a=e.toolCallsByIndex.get(i.index)??{index:i.index,id:"",name:"",argumentsRaw:"",startEmitted:!1};i.id&&(a.id=i.id),i.function?.name&&(a.name=i.function.name),i.function?.arguments&&(a.argumentsRaw+=i.function.arguments),e.toolCallsByIndex.set(i.index,a)}}function fa(t){let e=t.usage;if(!e)return{stopReason:t.finishReason??null,resultSubtype:"success",isError:!1};let n=e.prompt_tokens_details?.cached_tokens??0,r=e.prompt_tokens??0,o=e.completion_tokens??0;return{inputTokens:r,outputTokens:o,cachedInputTokens:n,totalTokens:e.total_tokens??r+o,stopReason:t.finishReason??null,resultSubtype:"success",isError:!1,raw:{...e}}}function Zr(t){return[...t.toolCallsByIndex.values()].sort((e,n)=>e.index-n.index)}function ma(t){return t.finishReason==="tool_calls"||t.finishReason==="function_call"?!0:t.toolCallsByIndex.size>0}function ga(t){return t.map(e=>{let n={name:e.name,parameters:e.input_schema};return e.description!==void 0&&(n.description=e.description),{type:"function",function:n}})}function ha(t,e){let n=[],r=new Map;for(let o of t){let s={};if(o.argumentsRaw.length>0)try{s=JSON.parse(o.argumentsRaw)}catch(i){let a=i instanceof Error?i.message:String(i);r.set(o.id,`Failed to parse tool arguments as JSON: ${a}`),s={}}n.push({id:o.id,name:o.name,input:s,signal:e})}return{calls:n,parseErrors:r}}function ya(t,e,n=""){let r={role:"assistant",content:t.length>0?t:null,tool_calls:e.map(o=>({id:o.id,type:"function",function:{name:o.name,arguments:o.argumentsRaw}}))};return n.length>0&&(r.reasoning_content=n),r}function ba(t){return t.map(({call:e,result:n})=>({role:"tool",tool_call_id:e.id,content:n.isError?`[error] ${n.content}`:n.content}))}function Lt(t){return(t.inputTokens??0)+(t.outputTokens??0)}function wa(t,e,n){return e<=0||t<=0||n<=0||n>=1?!1:t/e>=n}var eo="openai-compatible",Im=50,Pm=null;function ka(t){return t??"default"}var In=class{client;opts;initSessionId;toolDispatcher;openAITools;priorTurns=[];currentModel;currentPermissionMode;abortController=null;pendingAbortReason=null;closed=!1;closeResolve=null;closedPromise;lastUsage=null;constructor(e){if(this.opts=e,this.initSessionId=e.synthesizedSessionId,this.currentModel=e.model,this.currentPermissionMode=ka(e.config.permissionMode),this.toolDispatcher=e.toolDispatcher,this.toolDispatcher){let n=this.toolDispatcher;Array.isArray(n.toolDefs)&&n.toolDefs.length>0&&(this.openAITools=ga(n.toolDefs))}if(e.auth.apiKey===null)this.client=null;else{let n=Pm??Cm,r={apiKey:e.auth.apiKey};e.baseURL!==void 0&&(r.baseURL=e.baseURL),this.client=n(r)}this.closedPromise=new Promise(n=>{this.closeResolve=()=>n("__closed__")})}async*[Symbol.asyncIterator](){if(yield{type:"session.init",info:{sessionId:this.initSessionId,model:this.currentModel,permissionMode:this.currentPermissionMode,cwd:process.cwd(),tools:this.openAITools?this.openAITools.map(r=>r.function.name):[],slashCommands:[],skills:[],plugins:[],mcpServers:this.opts.mcpManager?.getServerStates().map(r=>({name:r.serverName,status:r.status}))??[],apiKeySource:this.opts.auth.source,version:eo}},this.opts.auth.apiKey===null){yield{type:"error",error:new Error(Qr(this.opts.auth))};return}let n=this.opts.promptStream[Symbol.asyncIterator]();try{for(;!this.closed;){let r=await Promise.race([n.next(),this.closedPromise]);if(r==="__closed__")break;let o=r;if(o.done)break;let s=la(o.value.content);yield*this.runTurn(s)}}catch(r){yield{type:"error",error:r instanceof Error?r:new Error(String(r))}}finally{try{await n.return?.()}catch{}}}async*runTurn(e){let n=new AbortController;if(this.abortController=n,this.pendingAbortReason!==null&&!n.signal.aborted&&(n.abort(this.pendingAbortReason),this.pendingAbortReason=null),n.signal.aborted)return;let r=Date.now(),o=Rm();this.priorTurns.push({role:"user",content:e});let s={stopReason:null,resultSubtype:"success",isError:!1},i="",a="";for(let c=0;c<Im;c++){if(n.signal.aborted){this.abortController===n&&(this.abortController=null);return}let l=yield*this.runIteration(n);if(l===null){this.abortController===n&&(this.abortController=null);return}if(s=Dt(s,fa(l.state)),l.text.length>0&&(i=l.text),a=l.state.reasoningText,!l.needsToolDispatch)break;yield*this.dispatchAndAppend(l.state,n.signal);{let d=Zr(l.state).at(-1)?.name;yield{type:"progress",progress:{taskId:o,description:"Tool-use loop",summary:`Iteration ${c+1}: used ${d??"unknown"}`,lastToolName:d,totalTokens:s.totalTokens??0,toolUses:c+1,durationMs:Date.now()-r},sessionId:this.initSessionId}}if(n.signal.aborted){this.abortController===n&&(this.abortController=null);return}}if(this.abortController===n&&(this.abortController=null),i.length>0){let c={role:"assistant",content:i};a.length>0&&(c.reasoning_content=a),this.priorTurns.push(c)}this.lastUsage=s,yield{type:"assistant.message",text:i,sessionId:this.initSessionId},yield{type:"turn.completed",usage:{...s,durationMs:Date.now()-r},sessionId:this.initSessionId}}async*runIteration(e){let n=da({config:this.opts.config,...this.opts.config.resumeHistory!==void 0?{resumeHistory:this.opts.config.resumeHistory}:{},priorTurns:this.priorTurns});this.currentPermissionMode==="plan"&&n[0]?.role==="system"&&(n[0]={...n[0],content:n[0].content+`
|
|
1132
1132
|
|
|
1133
1133
|
`+hr});let r=ua(),o={model:this.currentModel,messages:n,stream:!0,stream_options:{include_usage:!0}};this.openAITools&&this.openAITools.length>0&&(o.tools=this.openAITools);let s;try{s=await this.client.chat.completions.create(o,{signal:e.signal})}catch(i){return e.signal.aborted||(yield{type:"error",error:i instanceof Error?i:new Error(String(i))}),null}try{for await(let i of s){if(this.closed)return null;for(let a of pa(i,r,this.initSessionId))yield a}}catch(i){return e.signal.aborted||(yield{type:"error",error:i instanceof Error?i:new Error(String(i))}),null}return{state:r,events:[],text:r.assistantText,needsToolDispatch:ma(r)&&r.toolCallsByIndex.size>0}}async*dispatchAndAppend(e,n){if(!this.toolDispatcher)return;let r=Zr(e),{calls:o,parseErrors:s}=ha(r,n);for(let a of o)yield{type:"tool.use.start",toolUseId:a.id,toolName:a.name,toolInput:Mm(a.input),sessionId:this.initSessionId};let i=[];if(n.aborted)for(let a of o){let c={content:"Tool call aborted",isError:!0};i.push({call:a,result:c}),yield{type:"tool.output",toolUseId:a.id,toolName:a.name,content:c.content,isError:!0,sessionId:this.initSessionId}}else{let a;try{if(this.toolDispatcher.executeBatch)a=await this.toolDispatcher.executeBatch(o);else{a=[];for(let c of o){if(n.aborted){a.push({content:"Tool call aborted",isError:!0});continue}try{a.push(await this.toolDispatcher.execute(c))}catch(l){let d=l instanceof Error?l.message:String(l);a.push({content:`Tool execution threw: ${d}`,isError:!0})}}}}catch(c){let l=c instanceof Error?c.message:String(c);a=o.map(()=>({content:`Tool batch execution failed: ${l}`,isError:!0}))}for(let c=0;c<o.length;c++){let l=o[c],d=a[c],u=s.get(l.id);u!==void 0&&(d={content:`${u}
|
|
@@ -1647,7 +1647,7 @@ ${_o}`,v=[h,Eo];v.push(et({cwd:y,...n.sessionId!==void 0?{sessionId:n.sessionId}
|
|
|
1647
1647
|
|
|
1648
1648
|
`),x=[h,Eo];k.length>0&&x.push(k),d&&x.push(d),sl({prompt:e.prompt,options:{model:u,maxTokens:p,system:A},provenance:{systemPrompt:{source:n.systemPromptSource??"none",shape:typeof n.systemPrompt=="string"?"string":Array.isArray(n.systemPrompt)?"string[]":n.systemPrompt!=null?"preset":"undefined",...typeof n.systemPrompt=="string"?{length:n.systemPrompt.length}:{}},...n.apiKey?{apiKey:{source:"config"}}:{}}});let O;if(s==="oauth"&&!r){let _=this.providerFactory??al;O=async()=>{let I=await gr();if(!I)return null;let C=mr(I,"oauth",n.baseUrl);return _?_(C):new il(C)}}let R=n.sessionId??n.resume,P=ab(n.resumeHistory),E=this.externalTools?void 0:_=>{let I=this._currentCwd;if(this._sharedReadRoots&&I!==void 0&&I!==_){let $=this._sharedReadRoots.indexOf(I);$!==-1?this._sharedReadRoots[$]=_:this._sharedReadRoots.includes(_)||this._sharedReadRoots.push(_)}if(this._sharedWriteRoots&&I!==void 0&&I!==_){let $=this._sharedWriteRoots.indexOf(I);$!==-1?this._sharedWriteRoots[$]=_:this._sharedWriteRoots.includes(_)||this._sharedWriteRoots.push(_)}this._currentCwd=_;let H=[x[0],x[1],et({cwd:_,...n.sessionId!==void 0?{sessionId:n.sessionId}:{},surface:this.surface,...n.depth!==void 0?{depth:n.depth}:{},...n.maxDepth!==void 0?{maxDepth:n.maxDepth}:{},workspace:f.getWorkspace()}),...x.slice(2)].join(`
|
|
1649
1649
|
|
|
1650
|
-
`),B=this.buildDispatcher(g,{cwd:_,readRoots:this._sharedReadRoots,writeRoots:this._sharedWriteRoots,...n.env!==void 0?{env:n.env}:{},sessionId:n.sessionId,traceWriter:n.traceWriter,runtimeStateSource:f});return{userSystem:H,dispatcher:B}},T=lb(n.effort,u);return new Gn({client:c,authMode:r?"api-key":s,promptStream:e.prompt,toolDispatcher:m,...R!==void 0?{sessionId:R}:{},...P!==void 0?{initialMessages:P}:{},model:u,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},maxTokens:p,tools:b,userSystem:A,systemPrefix:l,tokenRefresher:O,...n.thinking!==void 0?{thinking:cb(n.thinking,p,u)}:{},...T!==void 0?{effort:T}:{},...r?{baseUrl:n.baseUrl}:{},...n.traceWriter?{traceWriter:n.traceWriter}:{},...n.autoResumeOnUsageLimit!==void 0?{autoResumeOnUsageLimit:n.autoResumeOnUsageLimit}:{},...E!==void 0?{cwdDependentsFactory:E}:{},...this.mcpManager!==void 0?{mcpManager:this.mcpManager}:{},...cl(n.autoCompact)!==void 0?{autoCompactThreshold:cl(n.autoCompact)}:{}})}};function ob(t){if(t===void 0)return null;if(typeof t=="string")return t.length>0?t:null;if(typeof t=="object"&&t!==null&&"append"in t){let e=t.append;return e&&e.length>0?e:null}return null}var sb=.9;function cl(t){if(t===void 0||t===!1)return;if(t===!0)return sb;let e=t.threshold;if(!(typeof e!="number"||!Number.isFinite(e)||e<=0||e>=1))return e}function ib(t,e){let n=t.maxOutputTokens;return typeof n=="number"&&Number.isFinite(n)&&n>0?Math.floor(n):ca(e)}function ab(t){if(!t||t.length===0)return;let e=[];for(let n of t)n.user.length>0&&e.push({role:"user",content:n.user}),n.assistant.length>0&&e.push({role:"assistant",content:n.assistant});return e.length>0?e:void 0}function cb(t,e,n){switch(t.type){case"adaptive":return{type:"adaptive",display:"summarized"};case"disabled":return{type:"disabled"};case"enabled":{if(typeof n=="string"&&rb(n))return{type:"adaptive",display:"summarized"};let r=t.budgetTokens!==void 0&&Number.isFinite(t.budgetTokens)?Math.min(t.budgetTokens,e-1):e-1;return{type:"enabled",budget_tokens:Math.max(r,1024),display:"summarized"}}}}function lb(t,e){if(t!==void 0)return t;let n=e.toLowerCase();if(/(claude-)?(opus|sonnet)-4-[
|
|
1650
|
+
`),B=this.buildDispatcher(g,{cwd:_,readRoots:this._sharedReadRoots,writeRoots:this._sharedWriteRoots,...n.env!==void 0?{env:n.env}:{},sessionId:n.sessionId,traceWriter:n.traceWriter,runtimeStateSource:f});return{userSystem:H,dispatcher:B}},T=lb(n.effort,u);return new Gn({client:c,authMode:r?"api-key":s,promptStream:e.prompt,toolDispatcher:m,...R!==void 0?{sessionId:R}:{},...P!==void 0?{initialMessages:P}:{},model:u,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},maxTokens:p,tools:b,userSystem:A,systemPrefix:l,tokenRefresher:O,...n.thinking!==void 0?{thinking:cb(n.thinking,p,u)}:{},...T!==void 0?{effort:T}:{},...r?{baseUrl:n.baseUrl}:{},...n.traceWriter?{traceWriter:n.traceWriter}:{},...n.autoResumeOnUsageLimit!==void 0?{autoResumeOnUsageLimit:n.autoResumeOnUsageLimit}:{},...E!==void 0?{cwdDependentsFactory:E}:{},...this.mcpManager!==void 0?{mcpManager:this.mcpManager}:{},...cl(n.autoCompact)!==void 0?{autoCompactThreshold:cl(n.autoCompact)}:{}})}};function ob(t){if(t===void 0)return null;if(typeof t=="string")return t.length>0?t:null;if(typeof t=="object"&&t!==null&&"append"in t){let e=t.append;return e&&e.length>0?e:null}return null}var sb=.9;function cl(t){if(t===void 0||t===!1)return;if(t===!0)return sb;let e=t.threshold;if(!(typeof e!="number"||!Number.isFinite(e)||e<=0||e>=1))return e}function ib(t,e){let n=t.maxOutputTokens;return typeof n=="number"&&Number.isFinite(n)&&n>0?Math.floor(n):ca(e)}function ab(t){if(!t||t.length===0)return;let e=[];for(let n of t)n.user.length>0&&e.push({role:"user",content:n.user}),n.assistant.length>0&&e.push({role:"assistant",content:n.assistant});return e.length>0?e:void 0}function cb(t,e,n){switch(t.type){case"adaptive":return{type:"adaptive",display:"summarized"};case"disabled":return{type:"disabled"};case"enabled":{if(typeof n=="string"&&rb(n))return{type:"adaptive",display:"summarized"};let r=t.budgetTokens!==void 0&&Number.isFinite(t.budgetTokens)?Math.min(t.budgetTokens,e-1):e-1;return{type:"enabled",budget_tokens:Math.max(r,1024),display:"summarized"}}}}function lb(t,e){if(t!==void 0)return t;let n=e.toLowerCase();if(/(claude-)?(opus|sonnet)-4-[678]/.test(n))return"max"}var db=new le;N();var ub=new Set([...Object.keys(hn),"auto"]);function pb(t){if(!t)return;let e=t.trim().toLowerCase();if(e){if(e==="anthropic"||e==="anthropic-direct")return"anthropic-direct";if(e==="openai"||e==="openai-compatible"||e==="openai-codex")return"openai-compatible"}}function Q(t,e){let n=e?.explicit??S.AFK_PROVIDER,r=e?.openaiBaseUrl??S.AFK_OPENAI_BASE_URL,o=pb(n);if(o)return o;let s=(t??"").trim().toLowerCase();return s&&(ub.has(s)||s.startsWith("claude-")||s.startsWith("claude_")||s.startsWith("local-")||s.startsWith("local_"))?"anthropic-direct":s&&(s.startsWith("gpt-")||s.startsWith("gpt_")||s.startsWith("o1")||s.startsWith("o3")||s.startsWith("o4")||s.startsWith("codex-")||s.startsWith("codex_")||s==="codex"||s.startsWith("deepseek-")||s.startsWith("deepseek_")||s.startsWith("mistral-")||s.startsWith("mistral_")||s.startsWith("mixtral-")||s.startsWith("mixtral_")||s.startsWith("llama-")||s.startsWith("llama_")||s.startsWith("qwen-")||s.startsWith("qwen_")||s.includes("/"))||r&&r.trim()?"openai-compatible":"anthropic-direct"}function js(t,e){switch(Q(t,e)){case"openai-compatible":case"openai-codex":return new ye;default:return new le}}async function Ro(t,e,n,r){let o=t.chat?.id;if(!o){await t.reply(G("Could not identify chat"));return}try{await e.resetSession(o),n.delete(o),await t.reply(sn())}catch(s){r("Clear error:",s),await t.reply(G(s))}}async function dl(t,e,n){let r=t.chat?.id;if(!r){await t.reply(G("Could not identify chat"));return}try{let o=await e.getSession(r);await t.sendChatAction("typing").catch(()=>{});let s=await o.compact();s.compacted?await t.reply(fs({before:s.messagesBefore,after:s.messagesAfter,...s.tokensSavedEstimate!==void 0?{tokensSavedEstimate:s.tokensSavedEstimate}:{}})):await t.reply(ms(s.reason??"unknown"))}catch(o){n("Compact error:",o),await t.reply(G(o))}}async function Io(t,e,n){let r=t.chat?.id;if(!r){await t.reply(G("Could not identify chat"));return}let s=t.message.text.split(/\s+/).slice(1);if(s.length===0){let u=e.getModel(r);await t.reply(`Current model: ${u.toUpperCase()}
|
|
1651
1651
|
|
|
1652
1652
|
Usage: /model [opus|opus_1m|sonnet|sonnet_1m|haiku] or org/model HF id`);return}let i=s[0];if(!i){await t.reply(G("Please specify a model: opus, opus_1m, sonnet, sonnet_1m, haiku, or an org/model id"));return}let a=["opus","opus_1m","sonnet","sonnet_1m","haiku"],c=i.toLowerCase(),l=a.includes(c),d=Q(c)==="openai-compatible";if(!l&&!d){await t.reply(G(`Invalid model: ${i}
|
|
1653
1653
|
Aliases: ${a.join(", ")}, or org/model HF id`));return}try{await e.switchModel(r,c),await t.reply(ds(c))}catch(u){n("Model switch error:",u),await t.reply(G(u))}}function gb(t,e){let n=t.trim();return n==="~"?ll():n.startsWith("~/")?To(ll(),n.slice(2)):mb(n)?To(n):To(e,n)}async function ul(t,e,n){let r=t.chat?.id;if(!r){await t.reply(G("Could not identify chat"));return}let s=t.message.text.split(/\s+/).slice(1).filter(l=>l.length>0);if(s.length===0){let l=e.getCwd(r);await t.reply(us(l));return}let i=s[0];if(!i){await t.reply(G("Please specify a directory path"));return}let a=e.getCwd(r)??process.cwd(),c=gb(i,a);try{if(!(await fb.stat(c)).isDirectory()){await t.reply(G(`Not a directory: ${c}`));return}}catch(l){let d=l.code;d==="ENOENT"?await t.reply(G(`Directory does not exist: ${c}`)):d==="EACCES"?await t.reply(G(`Permission denied: ${c}`)):(n("cwd stat error:",l),await t.reply(G(l)));return}try{await e.setCwd(r,c),await t.reply(ps(c))}catch(l){n("Cwd switch error:",l),await t.reply(G(l))}}import{execFile as Ob,spawn as Db}from"node:child_process";import{promisify as Fb}from"node:util";U();import{execFile as hb}from"node:child_process";import{randomBytes as yb}from"node:crypto";import{promises as Jn}from"node:fs";import{join as Vn}from"node:path";import{promisify as bb}from"node:util";var wM=bb(hb);var De=class extends Error{cause;code;constructor(e,n,r){super(e),this.name="WorktreeError",this.cause=n,this.code=r}};function wb(t,e=40){return t.toLowerCase().trim().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"").slice(0,e).replace(/-+$/g,"")||"task"}function kb(){return yb(4).toString("hex").slice(0,4)}function Sb(t){let e=n=>String(n).padStart(2,"0");return`${t.getUTCFullYear()}${e(t.getUTCMonth()+1)}${e(t.getUTCDate())}T${e(t.getUTCHours())}${e(t.getUTCMinutes())}${e(t.getUTCSeconds())}`}function pl(t,e={}){let n=(e.now??(()=>new Date))(),r=(e.randomSuffix??kb)();return`${Sb(n)}-${wb(t,32)}-${r}`}function vb(t){let e=t;return e.respawnedAt===void 0&&(e.respawnedAt=void 0),e.respawnedAs===void 0&&(e.respawnedAs=void 0),e.prUrl===void 0&&(e.prUrl=void 0),e.prCreatedAt===void 0&&(e.prCreatedAt=void 0),e}async function gt(t){let e=Vn(Uo(t),"farm.json");try{let n=await Jn.readFile(e,"utf8"),r=JSON.parse(n);if(r.schemaVersion!==1&&r.schemaVersion!==2&&r.schemaVersion!==3)throw new De(`unsupported farm manifest schema: ${r.schemaVersion} (expected 1, 2, or 3)`,void 0,"unsupported-schema");return vb(r)}catch(n){if(n.code==="ENOENT")return null;throw n instanceof De?n:new De(`failed to load farm manifest ${e}`,n,"invalid")}}async function fl(t,e){let n=await gt(t);if(!n)throw new De(`farm not found: ${t}`);return n.human_decision=e,n.decidedAt=new Date().toISOString(),n.schemaVersion=3,await Jn.writeFile(Vn(n.farmDir,"farm.json"),JSON.stringify(n,null,2)+`
|