agent-afk 2.26.6 → 2.26.7
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 +2 -2
- package/dist/telegram.mjs +1 -1
- package/package.json +1 -1
package/dist/cli.mjs
CHANGED
|
@@ -1818,7 +1818,7 @@ ${I}`:T.prompt},model:T.model??this.ctx.defaultSubagentModel??this.ctx.defaultMo
|
|
|
1818
1818
|
${x.map(T=>`> - ${T}`).join(`
|
|
1819
1819
|
`)}
|
|
1820
1820
|
|
|
1821
|
-
`:"")+S,C=g.failed.length>0;return{content:w,isError:C}}catch(u){let m=u instanceof Error?u.message:String(u);return je({event:"compose.failed",parent_session_id:this.ctx.parentSession.sessionId,error_message:m.slice(0,240),duration_ms:Date.now()-d}).catch(()=>{}),{content:`Compose execution error: ${m}`,isError:!0}}finally{await l.teardownAll()}}};function On(e,t,n,r){let o=Yd();o.register("SubagentStop",Vd);let s=n??new Me;return r!==void 0&&o.register("PreToolUse",Jd(r)),o.register("SessionEnd",Mi(s,t)),o.register("SessionEnd",i=>i.event!=="SessionEnd"?{}:(i.sessionId&&op(i.sessionId),{})),e&&o.register("SubagentStop",i=>i.event!=="SubagentStop"?{}:i.status==="idle"||i.status==="running"?{}:(e({subagentId:i.subagentId,status:i.status,durationMs:i.durationMs,agentType:i.agentType}),{})),{registry:o,memoryStore:s}}function re(e){let t=Math.round(e/1e3);if(t<=0)return"0s";let n=Math.floor(t/86400),r=Math.floor(t%86400/3600),o=Math.floor(t%3600/60),s=t%60;return n>0?`${n}d ${r}h`:r>0?`${r}h ${o}m`:o>0?`${o}m ${s}s`:`${s}s`}function $e(e){return e===0?"$0.00":e<.01?`$${e.toFixed(4)}`:`$${e.toFixed(2)}`}function H(e){if(e<1e3)return String(e);if(e<1e6){let n=e/1e3;return n%1===0?`${n}k`:`${n.toFixed(1).replace(/\.0$/,"")}k`}let t=e/1e6;return t%1===0?`${t}m`:`${t.toFixed(1).replace(/\.0$/,"")}m`}var Jv="[skill-routing: active]\n\nRoute recurring work through registered skills instead of rolling ad-hoc solutions:\n\n-
|
|
1821
|
+
`:"")+S,C=g.failed.length>0;return{content:w,isError:C}}catch(u){let m=u instanceof Error?u.message:String(u);return je({event:"compose.failed",parent_session_id:this.ctx.parentSession.sessionId,error_message:m.slice(0,240),duration_ms:Date.now()-d}).catch(()=>{}),{content:`Compose execution error: ${m}`,isError:!0}}finally{await l.teardownAll()}}};function On(e,t,n,r){let o=Yd();o.register("SubagentStop",Vd);let s=n??new Me;return r!==void 0&&o.register("PreToolUse",Jd(r)),o.register("SessionEnd",Mi(s,t)),o.register("SessionEnd",i=>i.event!=="SessionEnd"?{}:(i.sessionId&&op(i.sessionId),{})),e&&o.register("SubagentStop",i=>i.event!=="SubagentStop"?{}:i.status==="idle"||i.status==="running"?{}:(e({subagentId:i.subagentId,status:i.status,durationMs:i.durationMs,agentType:i.agentType}),{})),{registry:o,memoryStore:s}}function re(e){let t=Math.round(e/1e3);if(t<=0)return"0s";let n=Math.floor(t/86400),r=Math.floor(t%86400/3600),o=Math.floor(t%3600/60),s=t%60;return n>0?`${n}d ${r}h`:r>0?`${r}h ${o}m`:o>0?`${o}m ${s}s`:`${s}s`}function $e(e){return e===0?"$0.00":e<.01?`$${e.toFixed(4)}`:`$${e.toFixed(2)}`}function H(e){if(e<1e3)return String(e);if(e<1e6){let n=e/1e3;return n%1===0?`${n}k`:`${n.toFixed(1).replace(/\.0$/,"")}k`}let t=e/1e6;return t%1===0?`${t}m`:`${t.toFixed(1).replace(/\.0$/,"")}m`}var Jv="[skill-routing: active]\n\nRoute recurring work through registered skills instead of rolling ad-hoc solutions:\n\n- Bugs, failing tests, or regressions \u2192 `/diagnose`\n- High-stakes sub-agent output that will drive edits or commits \u2192 `/shadow-verify` before acting\n- Refactor needing parallel waves \u2192 `/parallelize`\n- Parallel or dependent multi-task work \u2192 `compose` tool (DAG of subagent nodes)\n- Greenfield feature where a written spec would genuinely help (novel scope, multi-day work, or external stakeholders involved) \u2192 `/mint`\n\nDo NOT reach for `/mint` for: bug fixes (use `/diagnose`), refactors with known shape, single-feature edits, work already spec'd in chat, or anything where the spec/approve pause would feel like ceremony. Implement directly in those cases.\n\nCommon composed sequences \u2014 reach for these when the task shape matches:\n\n- Bug with failing test and non-trivial fix \u2192 `/diagnose` \u2192 `/shadow-verify` on the proposed fix\n- Refactor needing parallel waves \u2192 plan \u2192 `/parallelize` \u2192 build waves\n- Diagnose + fix in parallel \u2192 `compose` with two independent nodes\n- Research \u2192 implement \u2192 verify pipeline \u2192 `compose` with edges: research\u2192implement\u2192verify\n- Multiple independent investigations \u2192 `compose` with N nodes, no edges\n\nReach for context-isolated investigators when the task is exploratory:\n\n- Map an unfamiliar module before editing \u2192 `/gather` or `/research`\n- Re-derive a load-bearing claim independently \u2192 `/shadow-verify`\n- Audit a diff before merge \u2192 `/review`\n- Survey git + infra + memory before non-trivial work \u2192 `/ground-state`\n- Generate alternatives before committing to a plan \u2192 `/devils-advocate`\n\nOr dispatch a raw `agent` call when no skill matches but the work is parallelizable, verification-heavy, or would otherwise consume substantial inline context.\n\nSkip orchestration for: single-line edits, trivial Q&A, and direct tool calls the user explicitly requested. The goal is leverage, not ceremony. If a skill would add overhead without adding value, don't invoke it.";function Go(e,t){return!e||!t?e:`${e}
|
|
1822
1822
|
|
|
1823
1823
|
${Jv}`}import nn from"chalk";var Xv=new Set(["Read","Glob","Grep","NotebookRead","LS","read_file","glob","grep","list_directory","memory_search"]),Zv=new Set(["Write","Edit","NotebookEdit","MultiEdit","write_file","edit_file","memory_update","procedure_write"]),Qv=new Set(["Bash","BashOutput","KillBash","bash"]),Sr=new Set(["Agent","Task","agent"]),sp=new Set(["Skill","skill"]),ip=new Set(["Compose","compose"]),ft=new Set([...Sr,...ip,...sp]),eT=new Set(["WebFetch","WebSearch","send_telegram","web_scrape"]),tT=new Set(["TaskCreate","TaskUpdate","TaskList","TaskGet","TaskOutput","TaskStop","EnterPlanMode","ExitPlanMode","ToolSearch"]);function Dt(e,t){if(e.has(t))return!0;let n=t.charAt(0).toUpperCase()+t.slice(1);return n!==t&&e.has(n)}function zo(e){return e.startsWith("mcp__")||e.startsWith("MCP__")?"mcp":Dt(Xv,e)?"read":Dt(Zv,e)?"write":Dt(Qv,e)?"shell":Dt(Sr,e)?"subagent":Dt(sp,e)?"skill":Dt(ip,e)?"dag":Dt(eT,e)?"web":Dt(tT,e)?"planning":"other"}var nT={read:nn.hex("#9CC4D6"),write:nn.hex("#E8A33D"),shell:nn.hex("#A8E060"),subagent:p.plan,skill:nn.hex("#F08AC4"),dag:nn.hex("#4EC9B0"),mcp:nn.hex("#5FE0C0"),web:nn.hex("#7FCDC0"),planning:p.meta,other:p.info},rT={read:"\u25CF",write:"\u270E",shell:"$",subagent:"\u2192",skill:"\u25C6",dag:"\u2B21",mcp:"\u22A1",web:"\u2316",planning:"\u25B1",other:"\u25CF"},oT={subagent:"subagent",skill:"skill",dag:"dag"};function ap(e){return oT[e]}function la(e){return{color:nT[e],glyph:rT[e]}}function Dn(e){return la(zo(e))}function lp(e){let{description:t,summary:n,lastToolName:r,totalTokens:o,toolUses:s,durationMs:i}=e,a=[];if(r){let{color:c,glyph:d}=Dn(r);a.push(`via ${c(`${d} ${r}`)}`)}s&&a.push(`${s} tool${s===1?"":"s"}`),o&&a.push(`${H(o)} tok`),i&&a.push(re(i));let l=a.length>0?` (${a.join(" \xB7 ")})`:"";return n?[p.dim(` \u25E6 ${t}`),p.dim(` ${n}${l}`)]:[p.dim(` \u25E6 ${t}${l}`)]}function qo(e){let t=e.status==="succeeded"?"\u2713":e.status==="failed"?"\u2717":"\u2298",n=e.agentType??e.subagentId,r=[t,n];return e.durationMs!==void 0&&r.push(`\xB7 ${re(e.durationMs)}`),p.dim(` ${r.join(" ")}`)}var cp=new Set;function up(e){cp.add(e)}function dp(e){return cp.has(e)}var ca=new Set,ua=new Set;function pp(e){ca.add(e)}function mp(e){ca.delete(e)}function fp(e){ua.add(e)}function gp(e){ua.delete(e)}function hp(e){for(let t of ca)t(e)}function yp(e){for(let t of ua)t(e)}function sT(e){if(typeof e!="object"||e===null)return;let t=e.name;if(typeof t!="string")return;let n=t.trim();return n.length>0?n:void 0}function iT(e){if(typeof e!="object"||e===null)throw new Error("Skill tool input must be an object");let t=e,n=t.name;if(typeof n!="string"||n.trim().length===0)throw new Error('Skill tool input must have a non-empty "name" field');let r,o=t.arguments;if(o!==void 0){if(typeof o!="string")throw new Error('Skill tool "arguments" must be a string');r=o}return{name:n.trim(),arguments:r}}var Ft=class{constructor(t){this.ctx=t}ctx;pluginBodies=null;async execute(t){if(t.signal.aborted)return{content:"Skill tool call aborted",isError:!0};let n=this.ctx.depth??0,r=this.ctx.maxDepth??Fn;if(n>=r){let l=sT(t.input);return je({event:"delegation.skipped",parent_session_id:this.ctx.parentSession.sessionId,reason:"max_depth",depth:n,requested_name:l}).catch(()=>{}),{content:`Skill tool not available at nesting depth ${n} (max ${r})`,isError:!0}}let o;try{o=iT(t.input)}catch(l){return{content:`Skill tool input validation failed: ${l instanceof Error?l.message:String(l)}`,isError:!0}}try{let l=Se(o.name);return await this.executeRegistrySkill(l,o.arguments,t)}catch{}let s=this.getPluginSkillBody(o.name);if(s)return await this.executePluginSkill(o.name,s,o.arguments,t);let a=hr(this.ctx.pluginConfigs).map(l=>l.name).join(", ");return{content:`Skill "${o.name}" not found. Available skills: ${a||"(none)"}`,isError:!0}}async executeRegistrySkill(t,n,r){if(r.signal.aborted)return{content:"Skill call aborted",isError:!0};if(t.context==="fork")return this.executeForkedRegistrySkill(t,n,r);let o=dp(t.name);o&&yp(t.name);let s=Date.now(),i,a;try{a=await t.handler(n&&n.length>0?n:void 0,this.ctx.parentSession,{apiKey:this.ctx.apiKey,defaultModel:this.ctx.defaultModel,defaultSubagentModel:this.ctx.defaultSubagentModel,dispatchSkill:this.createDispatchSkillCallback(r)})}catch(c){i=c}finally{if(o){let c=Date.now()-s;hp({skillName:t.name,durationMs:c,...i!==void 0?{isError:!0}:{}})}}return i!==void 0?{content:`Skill execution error: ${i instanceof Error?i.message:String(i)}`,isError:!0}:{content:typeof a=="string"?a:a!=null?JSON.stringify(a):"Skill completed successfully."}}buildForkedChildConfig(t,n){let r=this.ctx.depth??0,o=this.ctx.maxDepth??Fn,s={...t};if(!this.ctx.childProviderFactory||r>=o)return{childConfig:s,childManager:void 0};let i=new N({parentAbortSignal:n}),a=new Lt({subagentManager:i,parentSession:vr(n),defaultConfig:{model:s.model,apiKey:this.ctx.apiKey},defaultSubagentModel:this.ctx.defaultSubagentModel,childProviderFactory:this.ctx.childProviderFactory,childSkillExecutorFactory:this.ctx.childSkillExecutorFactory,depth:r+1,maxDepth:o}),l=this.ctx.childSkillExecutorFactory?this.ctx.childSkillExecutorFactory(r+1,o,n):void 0;return s.provider=this.ctx.childProviderFactory({childExecutor:a,childSkillExecutor:l}),{childConfig:s,childManager:i}}async executeForkedRegistrySkill(t,n,r){if(r.signal.aborted)return{content:"Skill call aborted",isError:!0};let o;try{if(o=ae(t.name)["system.md"],!o)return{content:`Skill "${t.name}" has context: "fork" but no prompts/system.md found`,isError:!0}}catch(l){return{content:`Failed to load skill prompts: ${l instanceof Error?l.message:String(l)}`,isError:!0}}let s=new N({parentAbortSignal:r.signal,apiKey:this.ctx.apiKey,progressSink:qe()}),{childConfig:i,childManager:a}=this.buildForkedChildConfig({model:t.model??this.ctx.defaultSubagentModel??this.ctx.defaultModel??"sonnet",systemPrompt:o},r.signal);try{let l=await s.forkSubagent({parent:this.ctx.parentSession,config:i,idPrefix:`skill-fork-${t.name}`,parentId:r.id,agentType:t.name}),c=n&&n.length>0?n:"Run the skill.",d=await l.runToResult(c);return d.status==="succeeded"&&d.message?{content:d.message.content}:{content:d.error?.message??"Forked skill failed with no output",isError:!0}}catch(l){return{content:`Forked skill execution error: ${l instanceof Error?l.message:String(l)}`,isError:!0}}finally{await a?.teardownAll(),await s.teardownAll()}}async executePluginSkill(t,n,r,o){if(o.signal.aborted)return{content:"Skill call aborted",isError:!0};let s=new N({parentAbortSignal:o.signal,apiKey:this.ctx.apiKey,progressSink:qe()}),{childConfig:i,childManager:a}=this.buildForkedChildConfig({model:this.ctx.defaultSubagentModel??this.ctx.defaultModel??"sonnet",systemPrompt:n},o.signal);try{let l=await s.forkSubagent({parent:this.ctx.parentSession,config:i,idPrefix:`skill-${t}`,parentId:o.id,agentType:t}),c=r&&r.length>0?r:"Run the skill.",d=await l.runToResult(c);return d.status==="succeeded"&&d.message?{content:d.message.content}:{content:d.error?.message??"Plugin skill failed with no output",isError:!0}}catch(l){return{content:`Plugin skill execution error: ${l instanceof Error?l.message:String(l)}`,isError:!0}}finally{await a?.teardownAll(),await s.teardownAll()}}getPluginSkillBody(t){return this.pluginBodies||(this.pluginBodies=Eo(this.ctx.pluginConfigs)),this.pluginBodies.get(t)}createDispatchSkillCallback(t){return async(n,r)=>{let o={id:`${t.id}-dispatch-${n}`,name:"skill",input:{name:n,...r!==void 0?{arguments:r}:{}},signal:t.signal},s=await this.execute(o);if(s.isError)throw new Error(s.content);return s.content}}};var Fn=3;function vr(e){return{sessionId:void 0,getInputStreamRef:()=>({pushUserMessage:()=>{}}),abortSignal:e}}var aT=[...It,"agent","skill"];function Yo(){return({childExecutor:e,childSkillExecutor:t})=>new Te({permissions:{allowedTools:aT},subagentExecutor:e,skillExecutor:t})}function Vo(e,t,n){let r=(o,s,i)=>new Ft({parentSession:vr(i),defaultModel:e,apiKey:t,depth:o,maxDepth:s,childProviderFactory:n,childSkillExecutorFactory:r});return r}function bp(e){return e.replace(/\x1b\[[0-9;]*[a-zA-Z]/g,"")}function lT(e){if(typeof e!="object"||e===null)throw new Error("Agent tool input must be an object");let t=e,n=t.prompt;if(typeof n!="string")throw new Error('Agent tool input must have a "prompt" field of type string');if(n.trim().length===0)throw new Error("Agent tool prompt cannot be empty");let r,o=t.model;if(o!==void 0){if(typeof o!="string")throw new Error("Agent tool model must be a string");r=o}let s=10,i=t.max_turns;if(i!==void 0){if(typeof i!="number")throw new Error("Agent tool max_turns must be a number");s=Math.max(1,Math.min(50,Math.floor(i)))}let a="agent-tool",l=t.id_prefix;if(l!==void 0){if(typeof l!="string")throw new Error("Agent tool id_prefix must be a string");a=l}let c="foreground",d=t.mode;if(d!==void 0){if(d!=="foreground"&&d!=="background")throw new Error(`Agent tool mode must be "foreground" or "background", got: ${JSON.stringify(d)}`);c=d}return{prompt:n,model:r,max_turns:s,id_prefix:a,mode:c}}function da(e){try{return je(e).catch(()=>{})}catch{return Promise.resolve()}}function Tr(e,t=240){return e.length<=t?e:e.slice(0,t)+"\u2026"}function wp(e){if(e!=null){if(typeof e=="string")return e.length;try{return JSON.stringify(e).length}catch{return}}}var cT=4096,kp=1024;function uT(e){if(e==null)return;let t=wp(e);return t!==void 0&&t>cT?{truncated:!0,chars:t}:e}function dT(e){let t={status:e.status,error:Tr(e.errorMessage,kp),subagent_id:e.subagentId};e.schemaErrorMessage&&(t.schemaError=Tr(e.schemaErrorMessage,kp));let n=uT(e.partialOutput);return n!==void 0&&(t.partialOutput=n),t}var Lt=class e{constructor(t){this.ctx=t}ctx;async execute(t){if(t.signal.aborted)return{content:"Agent tool call aborted",isError:!0};let n;try{n=lT(t.input)}catch(m){return{content:`Agent tool input validation failed: ${m instanceof Error?m.message:String(m)}`,isError:!0}}let r=this.ctx.depth??0,o=this.ctx.maxDepth??Fn,s,i={model:n.model??this.ctx.defaultSubagentModel??"sonnet",apiKey:this.ctx.defaultConfig.apiKey,systemPrompt:this.ctx.defaultConfig.systemPrompt,maxTurns:n.max_turns},a;if(this.ctx.childProviderFactory&&r<o){s=new N({parentAbortSignal:t.signal}),a=vr(t.signal);let m=new e({subagentManager:s,parentSession:a,defaultConfig:this.ctx.defaultConfig,defaultSubagentModel:this.ctx.defaultSubagentModel,childProviderFactory:this.ctx.childProviderFactory,childSkillExecutorFactory:this.ctx.childSkillExecutorFactory,depth:r+1,maxDepth:o}),f=this.ctx.childSkillExecutorFactory?this.ctx.childSkillExecutorFactory(r+1,o,t.signal):void 0;i.provider=this.ctx.childProviderFactory({childExecutor:m,childSkillExecutor:f})}let l;try{l=await this.ctx.subagentManager.forkSubagent({parent:this.ctx.parentSession,parentId:t.id,config:i,idPrefix:n.id_prefix,agentType:n.id_prefix&&n.id_prefix!=="agent-tool"?bp(n.id_prefix).replace(/[\r\n]+/g," ").trim()||"agent":bp(n.prompt).replace(/[\r\n]+/g," ").slice(0,40).trim()||"agent"}),a!==void 0&&(a.sessionId=l.id)}catch(m){return{content:`Failed to fork subagent: ${m instanceof Error?m.message:String(m)}`,isError:!0}}if(n.mode==="background"){let m=this.ctx.backgroundRegistry;if(!m)return l.teardown(),{content:'Background mode is not available in this session \u2014 no BackgroundAgentRegistry is wired. Re-issue the call with mode="foreground" or run inside `afk interactive`.',isError:!0};let f=m.register({handle:l,prompt:n.prompt,model:i.model??"sonnet"}),g={status:"running",jobId:f.jobId,subagentId:f.subagentId,label:f.label,message:`Background subagent started (jobId=${f.jobId}). It is running detached and its result will NOT auto-inject into this context. Retrieve it later via /bgsub:join ${f.jobId} or ask the user to join.`};return{content:JSON.stringify(g)}}let c=()=>{l.cancel()};t.signal.addEventListener("abort",c,{once:!0});let d=Date.now(),u=this.ctx.parentSession.sessionId;try{let m=await l.runToResult(n.prompt);if(m.status==="succeeded"&&m.message){let S=m.message.content,h=typeof S=="string"?S:JSON.stringify(S),k=m.trace;return da({event:"subagent.completed",subagent_id:l.id,parent_session_id:u,status:m.status,duration_ms:Date.now()-d,content_chars:h.length,depth:r,tool_call_count:k?.toolCalls.length,thinking_present:k?.thinkingPresent,tool_names:k?.toolCalls.length?JSON.stringify([...new Set(k.toolCalls.map(x=>x.name))]):void 0}),{content:h}}let f=m.error?.message??"Subagent failed with no output",g=m.trace;da({event:"subagent.failed",subagent_id:l.id,parent_session_id:u,status:m.status,duration_ms:Date.now()-d,error_message:Tr(f),schema_error:m.schemaError?Tr(m.schemaError.message):void 0,partial_output_chars:wp(m.partialOutput),depth:r,tool_call_count:g?.toolCalls.length,thinking_present:g?.thinkingPresent,tool_names:g?.toolCalls.length?JSON.stringify([...new Set(g.toolCalls.map(S=>S.name))]):void 0});let b=dT({status:m.status,errorMessage:f,schemaErrorMessage:m.schemaError?.message,partialOutput:m.partialOutput,subagentId:l.id});return{content:JSON.stringify(b),isError:!0}}catch(m){let f=m instanceof Error?m.message:String(m);throw da({event:"subagent.failed",subagent_id:l.id,parent_session_id:u,status:"failed",duration_ms:Date.now()-d,error_message:Tr(f),depth:r}),m}finally{t.signal.removeEventListener("abort",c),await s?.teardownAll(),await l.teardown()}}};import{randomUUID as OT}from"node:crypto";import{createHash as RT}from"crypto";import{mkdir as IT,open as MT,writeFile as $T}from"fs/promises";import{join as Ip}from"path";import{z as y}from"zod";var pT=y.object({phase:y.literal("started"),toolUseId:y.string(),name:y.string(),inputBytes:y.number().int().nonnegative(),subagentId:y.string().optional()}),mT=y.object({phase:y.literal("completed"),toolUseId:y.string(),name:y.string(),resultBytes:y.number().int().nonnegative(),isError:y.boolean(),truncated:y.boolean(),durationMs:y.number().nonnegative(),subagentId:y.string().optional()}),Sp=y.discriminatedUnion("phase",[pT,mT]),fT=y.enum(["PreToolUse","PostToolUse","SessionStart","SessionEnd","SubagentStart","SubagentStop"]),vp=y.object({hookEvent:fT,decision:y.union([y.literal("block"),y.literal("approve"),y.undefined()]),reason:y.string().optional(),blockedTool:y.string().optional(),injectedContextBytes:y.number().int().nonnegative().optional()}),gT=y.object({transition:y.literal("started"),subagentId:y.string(),parentId:y.string(),model:y.string(),allowedTools:y.array(y.string()).readonly().optional(),systemPromptHash:y.string().optional()}),hT=y.object({transition:y.literal("succeeded"),subagentId:y.string(),durationMs:y.number().nonnegative(),turnCount:y.number().int().nonnegative(),totalCostUsd:y.number().nonnegative().optional(),outputBytes:y.number().int().nonnegative()}),yT=y.object({transition:y.literal("failed"),subagentId:y.string(),errorClass:y.string(),errorMessage:y.string(),partialOutputBytes:y.number().int().nonnegative()}),bT=y.object({transition:y.literal("cancelled"),subagentId:y.string(),source:y.enum(["cascade","explicit"])}),Tp=y.discriminatedUnion("transition",[gT,hT,yT,bT]),kT=y.object({transition:y.literal("started"),jobId:y.string(),subagentId:y.string(),label:y.string(),model:y.string()}),wT=y.object({transition:y.literal("completed"),jobId:y.string(),subagentId:y.string(),durationMs:y.number().nonnegative(),outputBytes:y.number().int().nonnegative()}),ST=y.object({transition:y.literal("failed"),jobId:y.string(),subagentId:y.string(),durationMs:y.number().nonnegative(),errorClass:y.string(),errorMessage:y.string()}),vT=y.object({transition:y.literal("cancelled"),jobId:y.string(),subagentId:y.string(),source:y.enum(["explicit","cascade"])}),TT=y.object({transition:y.literal("joined"),jobId:y.string(),subagentId:y.string(),jobStatus:y.enum(["completed","failed","cancelled"])}),xp=y.discriminatedUnion("transition",[kT,wT,ST,vT,TT]),Ep=y.object({kind:y.literal("monetary"),runningCostUsd:y.number().nonnegative(),maxBudgetUsd:y.number().nonnegative(),lastTurnCostUsd:y.number().nonnegative()}),xT=y.enum(["user_signal","cascade","timeout","budget","hook_block"]),Cp=y.object({origin:xT,cascadedTo:y.array(y.string()).readonly(),reason:y.string().optional()}),Ap=y.enum(["manual","token_threshold","turn_count"]),ET=y.object({path:y.string(),sizeBytes:y.number().int().nonnegative(),sha256:y.string().regex(/^[0-9a-f]{64}$/)}),CT=y.object({trigger:Ap,preCompactionMessages:y.array(y.unknown()),summary:y.string(),keptTailCount:y.number().int().nonnegative(),keepLastNConfig:y.number().int().nonnegative(),messagesBefore:y.number().int().nonnegative(),messagesAfter:y.number().int().nonnegative(),tokensSavedEstimate:y.number().nonnegative().optional(),summarizationTokens:y.object({input:y.number().int().nonnegative(),output:y.number().int().nonnegative()}).optional()}),AT=y.object({trigger:Ap,preCompactionMessagesRef:ET,summary:y.string(),keptTailCount:y.number().int().nonnegative(),keepLastNConfig:y.number().int().nonnegative(),messagesBefore:y.number().int().nonnegative(),messagesAfter:y.number().int().nonnegative(),tokensSavedEstimate:y.number().nonnegative().optional(),summarizationTokens:y.object({input:y.number().int().nonnegative(),output:y.number().int().nonnegative()}).optional()}),PT=y.enum(["model_end_turn","iteration_cap","abort","timeout","budget_exceeded","hook_blocked","max_turns_exceeded"]),Pp=y.object({reason:PT,finalTurnCount:y.number().int().nonnegative(),finalCostUsd:y.number().nonnegative(),finalTokens:y.object({input:y.number().int().nonnegative().optional(),output:y.number().int().nonnegative().optional(),cacheRead:y.number().int().nonnegative().optional(),cacheCreation:y.number().int().nonnegative().optional()}),lastStopReason:y.string().optional()}),_p=y.object({source:y.string(),assertion:y.string(),evidence:y.array(y.string()).readonly(),confidence:y.number().min(0).max(1),dissent:y.string().optional()}),_T=y.object({status:y.enum(["succeeded","failed","cancelled"]),finalCostUsd:y.number().nonnegative(),finalTurnCount:y.number().int().nonnegative(),closedAt:y.string().datetime()}),Rp=y.discriminatedUnion("kind",[y.object({kind:y.literal("tool_call"),payload:Sp}),y.object({kind:y.literal("hook_decision"),payload:vp}),y.object({kind:y.literal("subagent_lifecycle"),payload:Tp}),y.object({kind:y.literal("background_agent"),payload:xp}),y.object({kind:y.literal("budget"),payload:Ep}),y.object({kind:y.literal("abort"),payload:Cp}),y.object({kind:y.literal("compaction"),payload:CT}),y.object({kind:y.literal("closure"),payload:Pp}),y.object({kind:y.literal("claim"),payload:_p})]),RU=y.discriminatedUnion("kind",[y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("tool_call"),payload:Sp}),y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("hook_decision"),payload:vp}),y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("subagent_lifecycle"),payload:Tp}),y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("background_agent"),payload:xp}),y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("budget"),payload:Ep}),y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("abort"),payload:Cp}),y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("compaction"),payload:AT}),y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("closure"),payload:Pp}),y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("claim"),payload:_p}),y.object({ts:y.string().datetime(),seq:y.number().int().nonnegative(),kind:y.literal("session_sealed"),payload:_T})]);var Jo=class{traceDir;tracePath;seq=0;sealed=!1;fh=null;writeQueue=Promise.resolve();constructor(t){this.traceDir=t.traceDir,this.tracePath=Ip(this.traceDir,"trace.jsonl")}getTracePath(){return this.tracePath}async write(t){if(this.sealed)throw new Error("NdjsonTraceWriter: trace is sealed; write() rejected");return Rp.parse(t),this.enqueue(async()=>{await this.ensureOpen();let n=await this.materializePersistedEvent(t);await this.appendLine(n)})}async seal(t){this.sealed||(this.sealed=!0,await this.enqueue(async()=>{await this.ensureOpen();let n={ts:new Date().toISOString(),seq:this.seq++,kind:"session_sealed",payload:t};await this.appendLine(n),this.fh&&await this.fh.sync()}),await this.closeHandle())}async close(){await this.enqueue(async()=>{}),await this.closeHandle()}enqueue(t){let n=this.writeQueue.then(t,t);return this.writeQueue=n.then(()=>{},()=>{}),n}async ensureOpen(){this.fh||(await IT(this.traceDir,{recursive:!0}),this.fh=await MT(this.tracePath,"a"))}async closeHandle(){if(!this.fh)return;let t=this.fh;this.fh=null,await t.close()}async appendLine(t){if(!this.fh)throw new Error("NdjsonTraceWriter: file handle missing");await this.fh.appendFile(`${JSON.stringify(t)}
|
|
1824
1824
|
`)}async materializePersistedEvent(t){let n=new Date().toISOString(),r=this.seq++;if(t.kind==="compaction"){let o=await this.persistCompactionSidecar(t.payload,r,n);return{ts:n,seq:r,kind:"compaction",payload:o}}return{ts:n,seq:r,kind:t.kind,payload:t.payload}}async persistCompactionSidecar(t,n,r){let o=r.replace(/[:.]/g,"-"),s=Ip(this.traceDir,`${String(n).padStart(6,"0")}-${o}-pre-compaction.json`),i=JSON.stringify(t.preCompactionMessages),a=Buffer.byteLength(i,"utf8"),l=RT("sha256").update(i).digest("hex");await $T(s,i,{encoding:"utf8",flag:"w"});let c={path:s,sizeBytes:a,sha256:l};return{trigger:t.trigger,preCompactionMessagesRef:c,summary:t.summary,keptTailCount:t.keptTailCount,keepLastNConfig:t.keepLastNConfig,messagesBefore:t.messagesBefore,messagesAfter:t.messagesAfter,...t.tokensSavedEstimate!==void 0?{tokensSavedEstimate:t.tokensSavedEstimate}:{},...t.summarizationTokens!==void 0?{summarizationTokens:t.summarizationTokens}:{}}}};function Xo(e={}){if(process.env.AFK_TRACE_DISABLED==="1")return null;let t=e.sessionLabel??OT(),n=Ul(t),r=new Jo({traceDir:n});return{writer:r,tracePath:r.getTracePath(),sessionLabel:t}}import{execFile as DT}from"node:child_process";import{promisify as FT}from"node:util";import{promises as xr}from"node:fs";import{dirname as pa,isAbsolute as LT,join as Er,resolve as NT}from"node:path";import{randomBytes as UT}from"node:crypto";var Mp=FT(DT),jT="afk/";function $p(e){if(e!==void 0)return e;let t=process.env.AFK_WORKTREE_BRANCH_PREFIX;return t!==void 0?t:jT}function Ln(e){return e instanceof Error}function BT(e){let t=l=>String(l).padStart(2,"0"),n=String(e.getFullYear()),r=t(e.getMonth()+1),o=t(e.getDate()),s=t(e.getHours()),i=t(e.getMinutes()),a=t(e.getSeconds());return`${n}${r}${o}-${s}${i}${a}`}function WT(e){let t=BT(new Date),n=UT(3).toString("hex");return`${e}${t}-${n}`}function Op(e){if(e.trim().length===0)throw new Error("Invalid branch name: '' \u2014 branch name cannot be empty.");if(e.startsWith("-"))throw new Error(`Invalid branch name: '${e}' \u2014 must not start with '-' (would be parsed by git as a flag).`);if(e==="HEAD")throw new Error("Invalid branch name: 'HEAD' \u2014 reserved by git.");if(e.includes(".."))throw new Error(`Invalid branch name: '${e}' \u2014 must not contain '..'.`);let n=[{char:"~",label:"'~'"},{char:"^",label:"'^'"},{char:":",label:"':'"},{char:"?",label:"'?'"},{char:"*",label:"'*'"},{char:"[",label:"'['"},{char:"\\",label:"'\\'"},{char:"\0",label:"NUL byte"}];for(let{char:r,label:o}of n)if(e.includes(r))throw new Error(`Invalid branch name: '${e}' \u2014 must not contain ${o}.`);if(/\s/.test(e))throw new Error(`Invalid branch name: '${e}' \u2014 must not contain whitespace.`)}async function HT(e){let t;try{t=(await e("git",["rev-parse","--git-common-dir"])).stdout.trim()}catch{throw new Error("Not in a git repository (run from inside a git checkout).")}if(!t)throw new Error("Not in a git repository (run from inside a git checkout).");let n=LT(t)?t:NT(process.cwd(),t);return pa(n)}async function KT(e){let t=Er(e,".gitignore"),n=".afk-worktrees/",r="";try{r=await xr.readFile(t,"utf8")}catch(i){if(i.code!=="ENOENT")throw i;r=""}if(r.split(`
|
|
@@ -1975,7 +1975,7 @@ _ended: ${new Date().toISOString()}_
|
|
|
1975
1975
|
`)}function KA(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 GA(e,t){let n=[];e&&n.push({type:"text",text:e});for(let r of t)n.push({type:"image",source:{type:"base64",media_type:r.mediaType,data:r.bytes.toString("base64")}});return n}async function Rg(e,t,n,r,o="summary",s,i){let a=pg(e.text,e.attachments);r.setInFlight(!0);let l="",c=!1,d,u=!1,m=!1,f=!1,g,b=!1,S=[],h=new Map,k=e.text.startsWith("/")?e.text.split(/[\s:]/)[0]?.slice(1):void 0,x=new Wt({out:Wn(),thinkingMode:o,...k?{activeSkillName:k}:{},onCancel:()=>{t.interrupt().catch(w=>{Ce()&&console.error(" "+p.error("session.interrupt() failed:"),w)})},...i?{onBackground:()=>{b=!0}}:{}}),P=async()=>{if(!m){m=!0;try{await x.dispose()}catch{}}};try{console.log(),await x.arm();let w=x.getCompositor();if(s&&w){let v=w;s.fn=E=>v.commitAbove(E)}r.setActiveCompositor?.(w),r.rearmStatus?.();let C=e.attachments.length===0?e.text:GA(e.text,e.attachments),T=t.sendMessageStream(C);if(await Sn(x.sink,async()=>{for await(let v of T){if(b&&i){let E=k??e.text.slice(0,40),I=i.register(E),_=cs(I,i);us(T,l,a,I,i,_,n,r.onTurnComplete,t.abortSignal),await P(),console.log(p.dim(` \u2192 backgrounded as ${I.id}: ${I.label}`)),r.setInFlight(!1),r.rearmStatus?.();return}if(v.type==="chunk"&&v.chunk.type==="content"?(l+=v.chunk.content,c=!0):v.type==="message"&&!c&&(l=v.message.content),v.type==="chunk"&&v.chunk.type==="tool_use_detail"){let E=v.chunk,I={toolName:E.toolName,toolUseId:E.toolUseId,input:E.toolInput};h.set(E.toolUseId,I),S.push(I)}else if(v.type==="chunk"&&v.chunk.type==="tool_result"){let E=v.chunk,I=h.get(E.toolUseId);I&&(I.result=E.content,I.isError=E.isError,h.delete(E.toolUseId))}if(v.type==="paused"){await P(),console.log(fc({reason:v.reason,...v.resetsAt!==void 0?{resetsAt:v.resetsAt}:{},...v.accountId!==void 0?{accountId:v.accountId}:{}}));continue}if(v.type==="resumed"){let E=v.hotSwapped&&v.accountId?`\u25B6 Resumed on ${v.accountId}`:"\u25B6 Resumed";console.log(p.success(E));continue}if(v.type==="error"){await P(),bn(yn(v.error)),u=!0;continue}x.process(v),v.type==="done"&&(f=!0,g=v.metadata)}}),!m){let v=x.getCompositor();if(v)try{let{text:E,queued:I}=v.getBuffer();I&&E.length>0&&(d=E)}catch{}}if(await P(),f){rs(n,a,l,g,S),r.onTurnComplete&&await r.onTurnComplete(a,l).catch(()=>{}),c&&console.log(`
|
|
1976
1976
|
`);let v=Pg(l);if(v&&(console.log(_g(v)),console.log(),r.onTerminalState))try{r.onTerminalState(v)}catch{}if(zA(g,n),r.onAfterTurn){let E=r.onAfterTurn();E instanceof Promise&&await E.catch(()=>{})}}}catch(w){await P(),u||bn(yn(w))}finally{await P(),s&&(s.fn=w=>console.log(w)),r.setActiveCompositor?.(null),r.setInFlight(!1),r.rearmStatus?.()}return d}function zA(e,t){if(!e)return;let n=[];e.durationMs&&n.push(re(e.durationMs)),e.totalCostUsd!==void 0&&n.push($e(e.totalCostUsd));let r=Number(e.usage?.input_tokens??0),o=Number(e.usage?.output_tokens??0);r+o>0&&n.push(H(r+o)+" tok"),n.length>0&&console.log(p.dim(" \u25E6 "+n.join(" \xB7 ")));let s=ba(t);if(s>.5){let i=s>.8?p.error:p.warning;console.log(i(` context ${Math.round(s*100)}% used of ${H(tt(t.model))}`))}console.log()}function Ig(e={}){let t=e.load??is,n=e.onResize??(i=>xt.subscribe(i)),r="",o,s=n(()=>{r=""});return{renderIfChanged(i){let a=i??"unbound",l=t(a),c=cm(l);return a===o&&c===r?[]:(o=a,r=c,c===""?[]:as(l))},invalidate(){r=""},dispose(){try{s()}catch{}}}}var il={done:{glyph:"\u2713",color:p.success,label:"done"},blocked:{glyph:"\u2298",color:p.error,label:"blocked"},asking:{glyph:"?",color:p.warning,label:"asking"},interrupted:{glyph:"\u23F8",color:p.info,label:"interrupted"}};function Mg(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=p.dim(" ledger "),o=p.dim(" \xB7 "),s=n.map(d=>{let u=il[d];return u.color(`${u.glyph} ${u.label}`)}),i=p.dim(` (${n.length} turn${n.length===1?"":"s"})`),a=r+s.join(o)+i,l=Math.max(20,ee()-2);if(U(a)<=l)return a;let c=r+n.map(d=>il[d].color(il[d].glyph)).join(p.dim(" "))+i;return ie(c,l)}}}var $g=["\u25D0","\u25D1","\u25D2","\u25D3"],Ks=class{stream;manager;throttleMs;started=!1;lastRepaint=0;spinnerIndex=0;spinnerInterval=null;resizeUnsub=null;updateHandler=null;rowCount=0;onRowCountChange;constructor(t,n={}){this.manager=t,this.stream=n.stream??process.stdout,this.throttleMs=n.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.resizeUnsub=xt.subscribe(()=>this.repaint()),this.spinnerInterval=setInterval(()=>{this.spinnerIndex=(this.spinnerIndex+1)%$g.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.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(),n=t.length;if(n!==this.rowCount&&(this.rowCount>0&&this.clearRows(),this.rowCount=n,this.onRowCountChange?.(n)),n===0)return;let o=(this.stream.rows??24)-n;this.stream.write("\x1B[s");for(let s=0;s<t.length;s++){let i=t[s],a=o+s;this.stream.write(`\x1B[${a};1H`),this.stream.write("\x1B[2K"),this.stream.write(this.formatTaskLine(i))}this.stream.write("\x1B[u")}clearRows(){if(!this.stream.isTTY)return;let n=(this.stream.rows??24)-this.rowCount;this.stream.write("\x1B[s");for(let r=0;r<this.rowCount;r++)this.stream.write(`\x1B[${n+r};1H`),this.stream.write("\x1B[2K");this.stream.write("\x1B[u")}formatTaskLine(t){let n=Math.max(4,(this.stream.columns??80)-2),r=p.brand($g[this.spinnerIndex]),o=p.dim(t.id),s=p.bold(t.label),i=[r,o,s];t.progressDescription&&i.push(p.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(`${H(t.stats.tokens)} tok`);let l=Date.now()-t.startedAt;return a.push(re(l)),a.length>0&&i.push(p.dim(a.join(" \xB7 "))),ie(" "+i.join(" "),n)}};function Og(e,t){let n=p.brand("afk")+p.dim(` (${e})`),r=t?p.warning(" \u25CF plan"):"";return n+r+p.dim(" \u203A ")}async function Dg(e,t,n,r){let o=null,s=[];e.session.waitForInitialization().then(async g=>{Ce()&&(o=ss(g)),await Af(e.session),Ce()&&(s=Cf())}).catch(()=>{});let i=await Ag(),a,l=Ig(),c=Mg(),d=new ls;wm(d),Cm(d),Pm(d);let u=new Ks(d);u.setRowCountChangeHandler(g=>{e.statusLine.setExtraRows(g)}),u.start();let m=50,f=[];d.on("complete",g=>{f.length>=m&&f.shift(),f.push(g)});try{for(;;){if(o&&(e.replRenderer.writeLine(o),e.replRenderer.writeLine(""),o=null),s.length>0){for(let w of s)e.replRenderer.writeLine(w);e.replRenderer.writeLine(""),s=[]}for(;f.length>0;){let w=f.shift(),C=w.status==="succeeded"?"\u2713":"\u2717",T=[];if(w.resultText){let E=w.resultText.trim().split(`
|
|
1977
1977
|
`)[0]?.slice(0,80)??"";E&&T.push(E)}w.error&&T.push(w.error.message);let v=[w.stats.toolUses>0?`${w.stats.toolUses} tools`:"",w.stats.tokens>0?`${Math.round(w.stats.tokens/1e3)}k tok`:"",w.stats.durationMs>0?`${Math.round(w.stats.durationMs/1e3)}s`:""].filter(Boolean).join(" \xB7 ");v&&T.push(v),e.replRenderer.writeLine(Et({kind:w.status==="succeeded"?"checkpoint":"diagnosis",title:`${C} ${w.id} ${w.label}`,body:T})),e.replRenderer.writeLine("")}let g=l.renderIfChanged(e.stats.sessionId);if(g.length>0){for(let w of g)e.replRenderer.writeLine(w);e.replRenderer.writeLine("")}let b=c.render();b&&e.replRenderer.writeLine(b);let S,h;if(a!==void 0){let w=a;a=void 0;let C=Og(e.stats.model,e.stats.planMode),T=Rr({buffer:w,promptText:C,isTTY:!!process.stdout.isTTY});e.replRenderer.writeLine(T),S=w.trim(),h=[]}else{let w=await Tg({rl:e.rl,promptFn:()=>Og(e.stats.model,e.stats.planMode),onSigint:r,statusLine:e.statusLine,compositor:n.activeCompositor??void 0,history:i,onShiftTab:()=>{let C=e.slashCtx;C.stats.planMode&&C.stats.pendingPlanExit?(C.stats.pendingPlanExit=!1,gt(C,!1,{closureSummarySkipped:!0}).catch(()=>{})):gt(C).catch(()=>{}),e.statusLine.rearm()}});S=w.text.trim(),h=w.attachments}if(!S&&h.length===0)continue;let k=!1;if(S.startsWith("/")){let w=await Yp(S,e.slashCtx);if(w.handled){if(w.result==="exit"){e.rl.close();return}if((S==="/clear"||S.startsWith("/clear "))&&(await t.rotateOnClear(),e.replRenderer.writeLine(p.dim(` transcript: ${t.path()}`)),c.reset()),w.result!==null&&typeof w.result=="object"&&"kind"in w.result&&w.result.kind==="submit"){a=w.result.message,e.statusLine.rearm();continue}e.statusLine.rearm();continue}k=!0}i.push(S);let x=S;if(k){let w=ya(S);if(w){let C=w.name.replace(/^\//,"").split(":").pop()??"";if(C&&Wa(C)){let T={skillName:C,rawArgs:w.args,source:"plugin",capabilities:{compose:!0,subagents:!0}},v=e.session.sessionId,E=Or(v),I=await $r(T,{cwd:process.cwd(),artifactDir:E},_=>{Ce()&&e.replRenderer.writeLine(p.warning(`\u26A0 preflight(${C}) failed: `)+(_ instanceof Error?_.message:String(_)))});x=Ka(I?.manifestBlock,S)}}}let P;if(e.firstTurnHook&&e.stats.totalTurns===0){let w=e.firstTurnHook;e.firstTurnHook=void 0,P=Promise.resolve().then(()=>w(S)).catch(C=>{console.warn(p.warning("\u26A0 ")+"first-turn hook failed: "+(C instanceof Error?C.message:String(C)))})}a=await Rg({text:x,attachments:h},e.session,e.stats,{setInFlight(w){n.turnInFlight=w},async onTurnComplete(w,C){await t.appendTurn(w,C)},async onAfterTurn(){await e.contextSampler.onTurn(e.stats.totalTurns),await em(e.slashCtx),e.statusLine.rearm()},rearmStatus:()=>e.statusLine.rearm(),onTerminalState:w=>c.push(w),setActiveCompositor:w=>{n.activeCompositor=w,e.replRenderer.setCompositor(w)}},e.options.thinkingUi,e.completionWriter,d),P!==void 0&&await P}}finally{u.stop(),l.dispose()}}import{promises as YA}from"node:fs";import{dirname as VA,join as JA}from"node:path";import{randomBytes as XA}from"node:crypto";import qA from"@anthropic-ai/sdk";import{randomUUID as Fg}from"node:crypto";async function Lg(e){let{token:t,model:n,system:r,user:o,maxTokens:s=64,signal:i,clientFactory:a}=e;if(!t)throw new Error("oneShotCompletion: token required");let l=ro(t),c=or(t,l),d=a?a(c):new qA(c),u=Fg(),m=Fg(),f=Zt(l,u,m),g={};Object.keys(f).length>0&&(g.headers=f),i&&(g.signal=i);let b=await d.messages.create({model:n,max_tokens:s,system:r,messages:[{role:"user",content:o}]},Object.keys(g).length>0?g:void 0),S=[];for(let k of b.content)k.type==="text"&&S.push(k.text);let h=S.join("").trim();return h.length===0&&console.warn("oneShotCompletion: response contained no text blocks \u2014 returning empty string"),h}var ZA=["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(`
|
|
1978
|
-
`),Ng=/^[a-z0-9]+(-[a-z0-9]+){1,3}$/,al=30,QA=1024,eP=8e3,tP="haiku";async function nP(e,t){let n=e.trim();if(n.length===0||n.startsWith("/"))return null;let r=iP(n,QA),o=new AbortController,s=setTimeout(()=>o.abort(),t.timeoutMs??eP),i=t.signal?aP([t.signal,o.signal]):o.signal,a;try{t.slugGenerator?a=await t.slugGenerator(r,i):a=await Lg({token:t.token,model:t.model??tP,system:ZA,user:r,maxTokens:32,signal:i})}catch{return null}finally{clearTimeout(s)}let l=rP(a);if(l===null)return null;let c=VA(t.worktreePath);return await oP(l,c)}function rP(e){let t=e.trim().toLowerCase();if(t.length===0)return null;if(Ng.test(t)&&t.length<=al)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>al)break;o=i}return Ng.test(o)?o:null}async function oP(e,t){if(!await sP(JA(t,e)))return e;let n=XA(2).toString("hex");return`${e.split("-").slice(0,3).join("-").slice(0,al-5)}-${n}`}async function sP(e){try{return await YA.access(e),!0}catch{return!1}}function iP(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 aP(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 Ug(e){let t=await nP(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}:{}});if(t===null)return{status:"skipped",reason:"slug generation returned null"};let r=await(e.renameFn??Dp)(e.handle,t,e.branchPrefix!==void 0?{branchPrefix:e.branchPrefix}:void 0);return r.ok?(e.session&&e.session.setCwd(r.newPath),{status:"renamed",oldPath:r.oldPath,newPath:r.newPath,oldBranch:r.oldBranch,newBranch:r.newBranch}):(r.partial==="branch"&&e.session&&e.session.setCwd(e.handle.path),{status:"failed",reason:r.reason,...r.partial!==void 0?{partial:r.partial}:{}})}import{spawn as jg}from"child_process";import{existsSync as pP,mkdirSync as mP,readFileSync as Bg,unlinkSync as fP,writeFileSync as gP}from"fs";import{get as hP}from"https";import{join as Wg}from"path";import{readFileSync as lP}from"fs";import{dirname as cP,join as uP}from"path";import{fileURLToPath as dP}from"url";function fn(){try{return"2.26.
|
|
1978
|
+
`),Ng=/^[a-z0-9]+(-[a-z0-9]+){1,3}$/,al=30,QA=1024,eP=8e3,tP="haiku";async function nP(e,t){let n=e.trim();if(n.length===0||n.startsWith("/"))return null;let r=iP(n,QA),o=new AbortController,s=setTimeout(()=>o.abort(),t.timeoutMs??eP),i=t.signal?aP([t.signal,o.signal]):o.signal,a;try{t.slugGenerator?a=await t.slugGenerator(r,i):a=await Lg({token:t.token,model:t.model??tP,system:ZA,user:r,maxTokens:32,signal:i})}catch{return null}finally{clearTimeout(s)}let l=rP(a);if(l===null)return null;let c=VA(t.worktreePath);return await oP(l,c)}function rP(e){let t=e.trim().toLowerCase();if(t.length===0)return null;if(Ng.test(t)&&t.length<=al)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>al)break;o=i}return Ng.test(o)?o:null}async function oP(e,t){if(!await sP(JA(t,e)))return e;let n=XA(2).toString("hex");return`${e.split("-").slice(0,3).join("-").slice(0,al-5)}-${n}`}async function sP(e){try{return await YA.access(e),!0}catch{return!1}}function iP(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 aP(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 Ug(e){let t=await nP(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}:{}});if(t===null)return{status:"skipped",reason:"slug generation returned null"};let r=await(e.renameFn??Dp)(e.handle,t,e.branchPrefix!==void 0?{branchPrefix:e.branchPrefix}:void 0);return r.ok?(e.session&&e.session.setCwd(r.newPath),{status:"renamed",oldPath:r.oldPath,newPath:r.newPath,oldBranch:r.oldBranch,newBranch:r.newBranch}):(r.partial==="branch"&&e.session&&e.session.setCwd(e.handle.path),{status:"failed",reason:r.reason,...r.partial!==void 0?{partial:r.partial}:{}})}import{spawn as jg}from"child_process";import{existsSync as pP,mkdirSync as mP,readFileSync as Bg,unlinkSync as fP,writeFileSync as gP}from"fs";import{get as hP}from"https";import{join as Wg}from"path";import{readFileSync as lP}from"fs";import{dirname as cP,join as uP}from"path";import{fileURLToPath as dP}from"url";function fn(){try{return"2.26.7"}catch{}try{let e=cP(dP(import.meta.url));for(let t of["../../package.json","../package.json"])try{let n=JSON.parse(lP(uP(e,t),"utf-8"));if(typeof n.version=="string")return n.version}catch{}}catch{}return"0.0.0-unknown"}var yP=64*1024,bP=1440*60*1e3,kP="update-check.json",wP="pending-update.json";function Hg(){return Wg(qr(),kP)}function ll(){return Wg(qr(),wP)}function Kg(){let e=qr();pP(e)||mP(e,{recursive:!0})}function SP(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 vP(){try{let e=Bg(Hg(),"utf-8"),t=JSON.parse(e);if(typeof t.latestVersion=="string"&&typeof t.checkedAt=="number")return t}catch{}return null}function TP(){try{Kg();let e=`
|
|
1979
1979
|
const https = require('https');
|
|
1980
1980
|
const fs = require('fs');
|
|
1981
1981
|
const url = 'https://registry.npmjs.org/agent-afk/latest';
|
package/dist/telegram.mjs
CHANGED
|
@@ -1634,7 +1634,7 @@ ${D}`:w.prompt},model:w.model??this.ctx.defaultSubagentModel??this.ctx.defaultMo
|
|
|
1634
1634
|
${b.map(w=>`> - ${w}`).join(`
|
|
1635
1635
|
`)}
|
|
1636
1636
|
|
|
1637
|
-
`:"")+k,R=y.failed.length>0;return{content:x,isError:R}}catch(d){let p=d instanceof Error?d.message:String(d);return Q({event:"compose.failed",parent_session_id:this.ctx.parentSession.sessionId,error_message:p.slice(0,240),duration_ms:Date.now()-u}).catch(()=>{}),{content:`Compose execution error: ${p}`,isError:!0}}finally{await c.teardownAll()}}};function or(t,e,n,r){let o=Ai();o.register("SubagentStop",Pi);let s=n??new te;return r!==void 0&&o.register("PreToolUse",Ri(r)),o.register("SessionEnd",an(s,e)),o.register("SessionEnd",i=>i.event!=="SessionEnd"?{}:(i.sessionId&&Li(i.sessionId),{})),t&&o.register("SubagentStop",i=>i.event!=="SubagentStop"?{}:i.status==="idle"||i.status==="running"?{}:(t({subagentId:i.subagentId,status:i.status,durationMs:i.durationMs,agentType:i.agentType}),{})),{registry:o,memoryStore:s}}var Xp="[skill-routing: active]\n\nRoute recurring work through registered skills instead of rolling ad-hoc solutions:\n\n-
|
|
1637
|
+
`:"")+k,R=y.failed.length>0;return{content:x,isError:R}}catch(d){let p=d instanceof Error?d.message:String(d);return Q({event:"compose.failed",parent_session_id:this.ctx.parentSession.sessionId,error_message:p.slice(0,240),duration_ms:Date.now()-u}).catch(()=>{}),{content:`Compose execution error: ${p}`,isError:!0}}finally{await c.teardownAll()}}};function or(t,e,n,r){let o=Ai();o.register("SubagentStop",Pi);let s=n??new te;return r!==void 0&&o.register("PreToolUse",Ri(r)),o.register("SessionEnd",an(s,e)),o.register("SessionEnd",i=>i.event!=="SessionEnd"?{}:(i.sessionId&&Li(i.sessionId),{})),t&&o.register("SubagentStop",i=>i.event!=="SubagentStop"?{}:i.status==="idle"||i.status==="running"?{}:(t({subagentId:i.subagentId,status:i.status,durationMs:i.durationMs,agentType:i.agentType}),{})),{registry:o,memoryStore:s}}var Xp="[skill-routing: active]\n\nRoute recurring work through registered skills instead of rolling ad-hoc solutions:\n\n- Bugs, failing tests, or regressions \u2192 `/diagnose`\n- High-stakes sub-agent output that will drive edits or commits \u2192 `/shadow-verify` before acting\n- Refactor needing parallel waves \u2192 `/parallelize`\n- Parallel or dependent multi-task work \u2192 `compose` tool (DAG of subagent nodes)\n- Greenfield feature where a written spec would genuinely help (novel scope, multi-day work, or external stakeholders involved) \u2192 `/mint`\n\nDo NOT reach for `/mint` for: bug fixes (use `/diagnose`), refactors with known shape, single-feature edits, work already spec'd in chat, or anything where the spec/approve pause would feel like ceremony. Implement directly in those cases.\n\nCommon composed sequences \u2014 reach for these when the task shape matches:\n\n- Bug with failing test and non-trivial fix \u2192 `/diagnose` \u2192 `/shadow-verify` on the proposed fix\n- Refactor needing parallel waves \u2192 plan \u2192 `/parallelize` \u2192 build waves\n- Diagnose + fix in parallel \u2192 `compose` with two independent nodes\n- Research \u2192 implement \u2192 verify pipeline \u2192 `compose` with edges: research\u2192implement\u2192verify\n- Multiple independent investigations \u2192 `compose` with N nodes, no edges\n\nReach for context-isolated investigators when the task is exploratory:\n\n- Map an unfamiliar module before editing \u2192 `/gather` or `/research`\n- Re-derive a load-bearing claim independently \u2192 `/shadow-verify`\n- Audit a diff before merge \u2192 `/review`\n- Survey git + infra + memory before non-trivial work \u2192 `/ground-state`\n- Generate alternatives before committing to a plan \u2192 `/devils-advocate`\n\nOr dispatch a raw `agent` call when no skill matches but the work is parallelizable, verification-heavy, or would otherwise consume substantial inline context.\n\nSkip orchestration for: single-line edits, trivial Q&A, and direct tool calls the user explicitly requested. The goal is leverage, not ceremony. If a skill would add overhead without adding value, don't invoke it.";function sr(t,e){return!t||!e?t:`${t}
|
|
1638
1638
|
|
|
1639
1639
|
${Xp}`}var Qp=new Set;function Ui(t){return Qp.has(t)}var Zp=new Set,ef=new Set;function ji(t){for(let e of Zp)e(t)}function Hi(t){for(let e of ef)e(t)}function tf(t){if(typeof t!="object"||t===null)return;let e=t.name;if(typeof e!="string")return;let n=e.trim();return n.length>0?n:void 0}function nf(t){if(typeof t!="object"||t===null)throw new Error("Skill tool input must be an object");let e=t,n=e.name;if(typeof n!="string"||n.trim().length===0)throw new Error('Skill tool input must have a non-empty "name" field');let r,o=e.arguments;if(o!==void 0){if(typeof o!="string")throw new Error('Skill tool "arguments" must be a string');r=o}return{name:n.trim(),arguments:r}}var Fe=class{constructor(e){this.ctx=e}ctx;pluginBodies=null;async execute(e){if(e.signal.aborted)return{content:"Skill tool call aborted",isError:!0};let n=this.ctx.depth??0,r=this.ctx.maxDepth??$e;if(n>=r){let c=tf(e.input);return Q({event:"delegation.skipped",parent_session_id:this.ctx.parentSession.sessionId,reason:"max_depth",depth:n,requested_name:c}).catch(()=>{}),{content:`Skill tool not available at nesting depth ${n} (max ${r})`,isError:!0}}let o;try{o=nf(e.input)}catch(c){return{content:`Skill tool input validation failed: ${c instanceof Error?c.message:String(c)}`,isError:!0}}try{let c=le(o.name);return await this.executeRegistrySkill(c,o.arguments,e)}catch{}let s=this.getPluginSkillBody(o.name);if(s)return await this.executePluginSkill(o.name,s,o.arguments,e);let a=Qe(this.ctx.pluginConfigs).map(c=>c.name).join(", ");return{content:`Skill "${o.name}" not found. Available skills: ${a||"(none)"}`,isError:!0}}async executeRegistrySkill(e,n,r){if(r.signal.aborted)return{content:"Skill call aborted",isError:!0};if(e.context==="fork")return this.executeForkedRegistrySkill(e,n,r);let o=Ui(e.name);o&&Hi(e.name);let s=Date.now(),i,a;try{a=await e.handler(n&&n.length>0?n:void 0,this.ctx.parentSession,{apiKey:this.ctx.apiKey,defaultModel:this.ctx.defaultModel,defaultSubagentModel:this.ctx.defaultSubagentModel,dispatchSkill:this.createDispatchSkillCallback(r)})}catch(l){i=l}finally{if(o){let l=Date.now()-s;ji({skillName:e.name,durationMs:l,...i!==void 0?{isError:!0}:{}})}}return i!==void 0?{content:`Skill execution error: ${i instanceof Error?i.message:String(i)}`,isError:!0}:{content:typeof a=="string"?a:a!=null?JSON.stringify(a):"Skill completed successfully."}}buildForkedChildConfig(e,n){let r=this.ctx.depth??0,o=this.ctx.maxDepth??$e,s={...e};if(!this.ctx.childProviderFactory||r>=o)return{childConfig:s,childManager:void 0};let i=new _({parentAbortSignal:n}),a=new Ne({subagentManager:i,parentSession:rt(n),defaultConfig:{model:s.model,apiKey:this.ctx.apiKey},defaultSubagentModel:this.ctx.defaultSubagentModel,childProviderFactory:this.ctx.childProviderFactory,childSkillExecutorFactory:this.ctx.childSkillExecutorFactory,depth:r+1,maxDepth:o}),c=this.ctx.childSkillExecutorFactory?this.ctx.childSkillExecutorFactory(r+1,o,n):void 0;return s.provider=this.ctx.childProviderFactory({childExecutor:a,childSkillExecutor:c}),{childConfig:s,childManager:i}}async executeForkedRegistrySkill(e,n,r){if(r.signal.aborted)return{content:"Skill call aborted",isError:!0};let o;try{if(o=$(e.name)["system.md"],!o)return{content:`Skill "${e.name}" has context: "fork" but no prompts/system.md found`,isError:!0}}catch(c){return{content:`Failed to load skill prompts: ${c instanceof Error?c.message:String(c)}`,isError:!0}}let s=new _({parentAbortSignal:r.signal,apiKey:this.ctx.apiKey,progressSink:ne()}),{childConfig:i,childManager:a}=this.buildForkedChildConfig({model:e.model??this.ctx.defaultSubagentModel??this.ctx.defaultModel??"sonnet",systemPrompt:o},r.signal);try{let c=await s.forkSubagent({parent:this.ctx.parentSession,config:i,idPrefix:`skill-fork-${e.name}`,parentId:r.id,agentType:e.name}),l=n&&n.length>0?n:"Run the skill.",u=await c.runToResult(l);return u.status==="succeeded"&&u.message?{content:u.message.content}:{content:u.error?.message??"Forked skill failed with no output",isError:!0}}catch(c){return{content:`Forked skill execution error: ${c instanceof Error?c.message:String(c)}`,isError:!0}}finally{await a?.teardownAll(),await s.teardownAll()}}async executePluginSkill(e,n,r,o){if(o.signal.aborted)return{content:"Skill call aborted",isError:!0};let s=new _({parentAbortSignal:o.signal,apiKey:this.ctx.apiKey,progressSink:ne()}),{childConfig:i,childManager:a}=this.buildForkedChildConfig({model:this.ctx.defaultSubagentModel??this.ctx.defaultModel??"sonnet",systemPrompt:n},o.signal);try{let c=await s.forkSubagent({parent:this.ctx.parentSession,config:i,idPrefix:`skill-${e}`,parentId:o.id,agentType:e}),l=r&&r.length>0?r:"Run the skill.",u=await c.runToResult(l);return u.status==="succeeded"&&u.message?{content:u.message.content}:{content:u.error?.message??"Plugin skill failed with no output",isError:!0}}catch(c){return{content:`Plugin skill execution error: ${c instanceof Error?c.message:String(c)}`,isError:!0}}finally{await a?.teardownAll(),await s.teardownAll()}}getPluginSkillBody(e){return this.pluginBodies||(this.pluginBodies=Ht(this.ctx.pluginConfigs)),this.pluginBodies.get(e)}createDispatchSkillCallback(e){return async(n,r)=>{let o={id:`${e.id}-dispatch-${n}`,name:"skill",input:{name:n,...r!==void 0?{arguments:r}:{}},signal:e.signal},s=await this.execute(o);if(s.isError)throw new Error(s.content);return s.content}}};var $e=3;function rt(t){return{sessionId:void 0,getInputStreamRef:()=>({pushUserMessage:()=>{}}),abortSignal:t}}var rf=[...Je,"agent","skill"];function Bi(){return({childExecutor:t,childSkillExecutor:e})=>new ie({permissions:{allowedTools:rf},subagentExecutor:t,skillExecutor:e})}function Wi(t,e,n){let r=(o,s,i)=>new Fe({parentSession:rt(i),defaultModel:t,apiKey:e,depth:o,maxDepth:s,childProviderFactory:n,childSkillExecutorFactory:r});return r}function Gi(t){return t.replace(/\x1b\[[0-9;]*[a-zA-Z]/g,"")}function of(t){if(typeof t!="object"||t===null)throw new Error("Agent tool input must be an object");let e=t,n=e.prompt;if(typeof n!="string")throw new Error('Agent tool input must have a "prompt" field of type string');if(n.trim().length===0)throw new Error("Agent tool prompt cannot be empty");let r,o=e.model;if(o!==void 0){if(typeof o!="string")throw new Error("Agent tool model must be a string");r=o}let s=10,i=e.max_turns;if(i!==void 0){if(typeof i!="number")throw new Error("Agent tool max_turns must be a number");s=Math.max(1,Math.min(50,Math.floor(i)))}let a="agent-tool",c=e.id_prefix;if(c!==void 0){if(typeof c!="string")throw new Error("Agent tool id_prefix must be a string");a=c}let l="foreground",u=e.mode;if(u!==void 0){if(u!=="foreground"&&u!=="background")throw new Error(`Agent tool mode must be "foreground" or "background", got: ${JSON.stringify(u)}`);l=u}return{prompt:n,model:r,max_turns:s,id_prefix:a,mode:l}}function ir(t){try{return Q(t).catch(()=>{})}catch{return Promise.resolve()}}function ot(t,e=240){return t.length<=e?t:t.slice(0,e)+"\u2026"}function qi(t){if(t!=null){if(typeof t=="string")return t.length;try{return JSON.stringify(t).length}catch{return}}}var sf=4096,Ki=1024;function af(t){if(t==null)return;let e=qi(t);return e!==void 0&&e>sf?{truncated:!0,chars:e}:t}function cf(t){let e={status:t.status,error:ot(t.errorMessage,Ki),subagent_id:t.subagentId};t.schemaErrorMessage&&(e.schemaError=ot(t.schemaErrorMessage,Ki));let n=af(t.partialOutput);return n!==void 0&&(e.partialOutput=n),e}var Ne=class t{constructor(e){this.ctx=e}ctx;async execute(e){if(e.signal.aborted)return{content:"Agent tool call aborted",isError:!0};let n;try{n=of(e.input)}catch(p){return{content:`Agent tool input validation failed: ${p instanceof Error?p.message:String(p)}`,isError:!0}}let r=this.ctx.depth??0,o=this.ctx.maxDepth??$e,s,i={model:n.model??this.ctx.defaultSubagentModel??"sonnet",apiKey:this.ctx.defaultConfig.apiKey,systemPrompt:this.ctx.defaultConfig.systemPrompt,maxTurns:n.max_turns},a;if(this.ctx.childProviderFactory&&r<o){s=new _({parentAbortSignal:e.signal}),a=rt(e.signal);let p=new t({subagentManager:s,parentSession:a,defaultConfig:this.ctx.defaultConfig,defaultSubagentModel:this.ctx.defaultSubagentModel,childProviderFactory:this.ctx.childProviderFactory,childSkillExecutorFactory:this.ctx.childSkillExecutorFactory,depth:r+1,maxDepth:o}),f=this.ctx.childSkillExecutorFactory?this.ctx.childSkillExecutorFactory(r+1,o,e.signal):void 0;i.provider=this.ctx.childProviderFactory({childExecutor:p,childSkillExecutor:f})}let c;try{c=await this.ctx.subagentManager.forkSubagent({parent:this.ctx.parentSession,parentId:e.id,config:i,idPrefix:n.id_prefix,agentType:n.id_prefix&&n.id_prefix!=="agent-tool"?Gi(n.id_prefix).replace(/[\r\n]+/g," ").trim()||"agent":Gi(n.prompt).replace(/[\r\n]+/g," ").slice(0,40).trim()||"agent"}),a!==void 0&&(a.sessionId=c.id)}catch(p){return{content:`Failed to fork subagent: ${p instanceof Error?p.message:String(p)}`,isError:!0}}if(n.mode==="background"){let p=this.ctx.backgroundRegistry;if(!p)return c.teardown(),{content:'Background mode is not available in this session \u2014 no BackgroundAgentRegistry is wired. Re-issue the call with mode="foreground" or run inside `afk interactive`.',isError:!0};let f=p.register({handle:c,prompt:n.prompt,model:i.model??"sonnet"}),y={status:"running",jobId:f.jobId,subagentId:f.subagentId,label:f.label,message:`Background subagent started (jobId=${f.jobId}). It is running detached and its result will NOT auto-inject into this context. Retrieve it later via /bgsub:join ${f.jobId} or ask the user to join.`};return{content:JSON.stringify(y)}}let l=()=>{c.cancel()};e.signal.addEventListener("abort",l,{once:!0});let u=Date.now(),d=this.ctx.parentSession.sessionId;try{let p=await c.runToResult(n.prompt);if(p.status==="succeeded"&&p.message){let k=p.message.content,m=typeof k=="string"?k:JSON.stringify(k),h=p.trace;return ir({event:"subagent.completed",subagent_id:c.id,parent_session_id:d,status:p.status,duration_ms:Date.now()-u,content_chars:m.length,depth:r,tool_call_count:h?.toolCalls.length,thinking_present:h?.thinkingPresent,tool_names:h?.toolCalls.length?JSON.stringify([...new Set(h.toolCalls.map(b=>b.name))]):void 0}),{content:m}}let f=p.error?.message??"Subagent failed with no output",y=p.trace;ir({event:"subagent.failed",subagent_id:c.id,parent_session_id:d,status:p.status,duration_ms:Date.now()-u,error_message:ot(f),schema_error:p.schemaError?ot(p.schemaError.message):void 0,partial_output_chars:qi(p.partialOutput),depth:r,tool_call_count:y?.toolCalls.length,thinking_present:y?.thinkingPresent,tool_names:y?.toolCalls.length?JSON.stringify([...new Set(y.toolCalls.map(k=>k.name))]):void 0});let g=cf({status:p.status,errorMessage:f,schemaErrorMessage:p.schemaError?.message,partialOutput:p.partialOutput,subagentId:c.id});return{content:JSON.stringify(g),isError:!0}}catch(p){let f=p instanceof Error?p.message:String(p);throw ir({event:"subagent.failed",subagent_id:c.id,parent_session_id:d,status:"failed",duration_ms:Date.now()-u,error_message:ot(f),depth:r}),p}finally{e.signal.removeEventListener("abort",l),await s?.teardownAll(),await c.teardown()}}};var Yi="unknown";try{let t=Ji(Vi(zi(import.meta.url)),"..","package.json"),e=JSON.parse(ar(t,"utf8"));e.version&&(Yi=e.version)}catch{console.warn("\u26A0\uFE0F [daemon] Could not read package.json at startup \u2014 version drift check disabled.")}async function df(){let t;try{t=Nn()}catch(l){console.error("\u274C Configuration error:",l.message),process.exit(1)}let e=Me(t.model);if(e==="openai-codex"){let l=process.env.OPENAI_API_KEY||process.env.CODEX_API_KEY;console.log(l?"\u{1F4DD} Using OPENAI_API_KEY / CODEX_API_KEY for Codex auth":"\u{1F4DD} Using existing `codex login` state on disk for Codex auth")}else{let l=Xe();(!l||l.length===0)&&(console.error("\u274C Claude models require ANTHROPIC_API_KEY or CLAUDE_CODE_OAUTH_TOKEN."),console.error(" Set one in your environment, run `afk login`, or sign in to Claude Code."),process.exit(1)),Et(l)==="oauth"?(process.env.CLAUDE_CODE_OAUTH_TOKEN=l,console.log("\u{1F4DD} Using CLAUDE_CODE_OAUTH_TOKEN for Anthropic auth (OAuth, auto-refresh on 401)")):(process.env.ANTHROPIC_API_KEY=l,console.log("\u{1F4DD} Using ANTHROPIC_API_KEY for Anthropic auth")),t.apiKey=l}ff(_e());let n=process.env.TELEGRAM_BOT_TOKEN;n||(console.error("\u274C Error: TELEGRAM_BOT_TOKEN environment variable is required"),console.error(`
|
|
1640
1640
|
How to get a bot token:`),console.error(" 1. Open Telegram and search for @BotFather"),console.error(" 2. Send /newbot and follow the instructions"),console.error(" 3. Run: afk telegram setup"),process.exit(1));let r=Ge(process.env.AFK_TELEGRAM_ALLOWED_CHAT_IDS,console.warn);r.size===0&&(console.error("\u274C Error: AFK_TELEGRAM_ALLOWED_CHAT_IDS must list at least one chat ID"),console.error(`
|