agent-afk 3.3.3 → 3.4.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 +287 -275
- package/dist/index.mjs +6 -6
- package/dist/telegram.mjs +35 -35
- package/package.json +2 -1
package/dist/telegram.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{existsSync as sg,readFileSync as Rr}from"fs";import{fileURLToPath as Ua}from"url";import{dirname as ja,join as Ha}from"path";function Pr(t,e){return!t||!e||t==="unknown"||e==="unknown"?{drift:!1}:t===e?{drift:!1}:{drift:!0,message:`[daemon] Version mismatch: running ${t} but installed is ${e}. Exiting.`}}import{Telegraf as tl}from"telegraf";import Ja from"better-sqlite3";import{existsSync as Xe,mkdirSync as Lr,readFileSync as wt,writeFileSync as Nr,readdirSync as Va,appendFileSync as Ya,unlinkSync as $r,copyFileSync as Xa}from"fs";import{join as Q,basename as Ur,resolve as kt,relative as Qa}from"path";import{join as N,dirname as Ga}from"path";import{homedir as xn}from"os";import{fileURLToPath as Ka}from"url";function J(){return process.env.AFK_HOME||N(xn(),".afk")}function xe(){return N(J(),"agent-framework")}function ft(){return N(xe(),"forge-telemetry.jsonl")}function
|
|
2
|
+
import{existsSync as sg,readFileSync as Rr}from"fs";import{fileURLToPath as Ua}from"url";import{dirname as ja,join as Ha}from"path";function Pr(t,e){return!t||!e||t==="unknown"||e==="unknown"?{drift:!1}:t===e?{drift:!1}:{drift:!0,message:`[daemon] Version mismatch: running ${t} but installed is ${e}. Exiting.`}}import{Telegraf as tl}from"telegraf";import Ja from"better-sqlite3";import{existsSync as Xe,mkdirSync as Lr,readFileSync as wt,writeFileSync as Nr,readdirSync as Va,appendFileSync as Ya,unlinkSync as $r,copyFileSync as Xa}from"fs";import{join as Q,basename as Ur,resolve as kt,relative as Qa}from"path";import{join as N,dirname as Ga}from"path";import{homedir as xn}from"os";import{fileURLToPath as Ka}from"url";function J(){return process.env.AFK_HOME||N(xn(),".afk")}function xe(){return N(J(),"agent-framework")}function ft(){return N(xe(),"forge-telemetry.jsonl")}function De(){return N(xe(),"briefs")}function mt(){return N(xe(),"ceiling-ledger")}function gt(){return N(J(),"skills")}function Fe(){return N(J(),"plugins")}function qa(){return N(process.cwd(),".afk")}function En(){return N(qa(),"plugins")}function ht(){return N(Fe(),".index.json")}function Tn(){return N(An(),"schedules.json")}function _n(){let t=Ka(import.meta.url),e=Ga(t);return N(e,"bundled-plugins")}function An(){return N(J(),"config")}function yt(){return N(J(),"state")}function Ve(){return N(yt(),"sessions")}function bt(){return N(yt(),"memory")}function Le(){return N(yt(),"session-grants.jsonl")}function Ir(){return N(J(),"farms")}function Cr(t){return N(Ir(),t)}function Mr(t="default"){return N(yt(),"daemon",`agent-afk@${t}`)}function Ye(){return N(An(),"afk.env")}function Or(){return N(An(),"afk.config.json")}function Dr(){return N(xn(),".afk.env")}function Fr(){return N(xn(),".afk.config.json")}function za(){return process.env.AFK_DEBUG==="1"||process.env.DEBUG==="1"}function C(...t){za()&&console.log(...t)}var jr="HOT.md",Za="HOT.md.bak",Hr="memory.db",Br="memory-wal.jsonl",vt="procedures",ec=5250,Qe=2,tc=`
|
|
3
3
|
CREATE TABLE IF NOT EXISTS sessions (
|
|
4
4
|
session_id TEXT PRIMARY KEY,
|
|
5
5
|
surface TEXT NOT NULL,
|
|
@@ -121,13 +121,13 @@ Available commands:
|
|
|
121
121
|
${Qr.map(e=>`${e.cmd} - ${e.desc}`).join(`
|
|
122
122
|
`)}
|
|
123
123
|
|
|
124
|
-
Just send me a message to get started!`}function to(t){return`${{opus:"\u{1F680}",sonnet:"\u26A1",haiku:"\u{1F338}"}[t]||"\u{1F916}"} Switched to Claude ${t.toUpperCase()}`}function _t(){return"\u{1F504} Conversation history cleared!"}function no(t){if(!t)return"\u{1F4E6} Conversation compacted (older messages summarized).";let e=t.tokensSavedEstimate!==void 0&&t.tokensSavedEstimate>0?` (~${pc(t.tokensSavedEstimate)} input tokens saved)`:"";return`\u{1F4E6} Compacted ${t.before} \u2192 ${t.after} messages${e}.`}function ro(t){return t==="aborted"?"\u{1F4E6} Compaction cancelled.":t.startsWith("summarization-failed")?`\u26A0\uFE0F Compaction failed: ${t}. History unchanged.`:`\u{1F4E6} Nothing to compact (${t}).`}function pc(t){return t>=1e3?`${Math.round(t/100)/10}k`:String(t)}async function Cn(t){await t.reply(eo())}async function Mn(t,e){let n=t.chat?.id,r,o=n?e.getSessionIfExists(n):void 0;if(o)try{await Promise.race([o.waitForInitialization(),new Promise((i,a)=>setTimeout(()=>a(new Error("timeout")),2e3))]);let s=o.getSessionMetadata();s.slashCommands?.length&&(r=s.slashCommands)}catch{}await t.reply(Zr(r))}async function
|
|
124
|
+
Just send me a message to get started!`}function to(t){return`${{opus:"\u{1F680}",sonnet:"\u26A1",haiku:"\u{1F338}"}[t]||"\u{1F916}"} Switched to Claude ${t.toUpperCase()}`}function _t(){return"\u{1F504} Conversation history cleared!"}function no(t){if(!t)return"\u{1F4E6} Conversation compacted (older messages summarized).";let e=t.tokensSavedEstimate!==void 0&&t.tokensSavedEstimate>0?` (~${pc(t.tokensSavedEstimate)} input tokens saved)`:"";return`\u{1F4E6} Compacted ${t.before} \u2192 ${t.after} messages${e}.`}function ro(t){return t==="aborted"?"\u{1F4E6} Compaction cancelled.":t.startsWith("summarization-failed")?`\u26A0\uFE0F Compaction failed: ${t}. History unchanged.`:`\u{1F4E6} Nothing to compact (${t}).`}function pc(t){return t>=1e3?`${Math.round(t/100)/10}k`:String(t)}async function Cn(t){await t.reply(eo())}async function Mn(t,e){let n=t.chat?.id,r,o=n?e.getSessionIfExists(n):void 0;if(o)try{await Promise.race([o.waitForInitialization(),new Promise((i,a)=>setTimeout(()=>a(new Error("timeout")),2e3))]);let s=o.getSessionMetadata();s.slashCommands?.length&&(r=s.slashCommands)}catch{}await t.reply(Zr(r))}async function On(t,e,n,r){let o=t.chat?.id;if(!o){await t.reply(q("Could not identify chat"));return}try{await e.resetSession(o),n.delete(o),await t.reply(_t())}catch(s){r("Clear error:",s),await t.reply(q(s))}}async function oo(t,e,n){let r=t.chat?.id;if(!r){await t.reply(q("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(no({before:s.messagesBefore,after:s.messagesAfter,...s.tokensSavedEstimate!==void 0?{tokensSavedEstimate:s.tokensSavedEstimate}:{}})):await t.reply(ro(s.reason??"unknown"))}catch(o){n("Compact error:",o),await t.reply(q(o))}}async function Dn(t,e,n){let r=t.chat?.id;if(!r){await t.reply(q("Could not identify chat"));return}let s=t.message.text.split(/\s+/).slice(1);if(s.length===0){let l=e.getModel(r);await t.reply(`Current model: ${l.toUpperCase()}
|
|
125
125
|
|
|
126
126
|
Usage: /model [opus|sonnet|haiku]`);return}let i=s[0];if(!i){await t.reply(q("Please specify a model: opus, sonnet, or haiku"));return}let a=i.toLowerCase();if(!["opus","sonnet","haiku"].includes(a)){await t.reply(q(`Invalid model: ${i}
|
|
127
127
|
Valid options: opus, sonnet, haiku`));return}try{await e.switchModel(r,a),await t.reply(to(a))}catch(l){n("Model switch error:",l),await t.reply(q(l))}}import{execFile as Ic,spawn as Cc}from"node:child_process";import{promisify as Mc}from"node:util";import{execFile as fc}from"node:child_process";import{randomBytes as mc}from"node:crypto";import{promises as At}from"node:fs";import{join as Rt}from"node:path";import{promisify as gc}from"node:util";var Xg=gc(fc);var he=class extends Error{cause;code;constructor(e,n,r){super(e),this.name="WorktreeError",this.cause=n,this.code=r}};function hc(t,e=40){return t.toLowerCase().trim().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"").slice(0,e).replace(/-+$/g,"")||"task"}function yc(){return mc(4).toString("hex").slice(0,4)}function bc(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 so(t,e={}){let n=(e.now??(()=>new Date))(),r=(e.randomSuffix??yc)();return`${bc(n)}-${hc(t,32)}-${r}`}function wc(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 Ne(t){let e=Rt(Cr(t),"farm.json");try{let n=await At.readFile(e,"utf8"),r=JSON.parse(n);if(r.schemaVersion!==1&&r.schemaVersion!==2&&r.schemaVersion!==3)throw new he(`unsupported farm manifest schema: ${r.schemaVersion} (expected 1, 2, or 3)`,void 0,"unsupported-schema");return wc(r)}catch(n){if(n.code==="ENOENT")return null;throw n instanceof he?n:new he(`failed to load farm manifest ${e}`,n,"invalid")}}async function io(t,e){let n=await Ne(t);if(!n)throw new he(`farm not found: ${t}`);return n.human_decision=e,n.decidedAt=new Date().toISOString(),n.schemaVersion=3,await At.writeFile(Rt(n.farmDir,"farm.json"),JSON.stringify(n,null,2)+`
|
|
128
128
|
`,"utf8"),n}async function ao(t,e){let n=await Ne(t);if(!n)throw new he(`farm not found: ${t}`);return n.respawnedAt=new Date().toISOString(),n.respawnedAs=e,n.schemaVersion=3,await At.writeFile(Rt(n.farmDir,"farm.json"),JSON.stringify(n,null,2)+`
|
|
129
129
|
`,"utf8"),n}async function co(t,e){let n=await Ne(t);if(!n)throw new he(`farm not found: ${t}`);return n.prUrl=e,n.prCreatedAt=new Date().toISOString(),n.schemaVersion=3,await At.writeFile(Rt(n.farmDir,"farm.json"),JSON.stringify(n,null,2)+`
|
|
130
|
-
`,"utf8"),n}import{execFile as kc}from"node:child_process";import{promisify as vc}from"node:util";var Sc=vc(kc),xc=2e4,nt=class extends Error{kind;exitCode;stderr;constructor(e,n,r,o){super(e),this.name="GhError",this.kind=n,this.exitCode=r,this.stderr=o}},Pt=null,tt=null;function Ec(t,e,n){return n===!0?"timeout":e==="ENOENT"?"not-found":/already exists/i.test(t)?"already-exists":/authentication|please log in|HTTP 40[13]|bad credentials|token|scope/i.test(t)?"unauthed":/ETIMEDOUT|ECONNRESET|ECONNREFUSED/i.test(t+(e??""))?"network":"unknown"}function lo(t,e){return Sc(t,e,{timeout:xc,killSignal:"SIGTERM"}).then(n=>({stdout:n.stdout,stderr:n.stderr}))}async function uo(t={}){let e=(t._now??(()=>Date.now()))(),n=t.ttlMs??6e4,r=t.execFn??lo,o=t.log??(()=>{});return Pt&&Pt.expiresAt>e?(o("[gh] checkGhReady cache hit"),Pt.result):(o("[gh] checkGhReady cache miss \u2014 probing"),tt||(tt=(async()=>{try{await r("gh",["--version"])}catch(a){let c=a;return c.killed?{ok:!1,hint:"`gh` timed out \u2014 check connectivity"}:c.code==="ENOENT"?{ok:!1,hint:"`gh` CLI not found \u2014 install with: brew install gh"}:{ok:!1,hint:"`gh --version` failed unexpectedly \u2014 check gh installation"}}try{await r("gh",["auth","status"])}catch(a){let c=a;return c.killed||/ETIMEDOUT|ECONNRESET|ENOTFOUND/i.test(String(c.code??""))?{ok:!1,hint:"check network \u2014 cannot reach GitHub"}:{ok:!1,hint:"`gh` is not authenticated \u2014 run: gh auth login"}}let i={ok:!0};return n>0&&(Pt={result:i,expiresAt:e+n}),i})().finally(()=>{tt=null}),tt))}async function po(t,e){let n=e??lo,r=["pr","create","--base",t.base,"--head",t.head,"--title",t.title,"--body",t.body];try{let{stdout:o}=await n("gh",r);return o.trim()}catch(o){let s=o,i=s.stderr??"",a=s.code,c=s.exitCode??1,l=Ec(i,a,s.killed);throw new nt(`gh pr create failed (${l}): ${i.trim()}`,l,c,i)}}function fo(t,e){let n;try{n=e?._store??new V}catch(r){return{skipped:!0,reason:r instanceof Error?r.message:String(r)}}try{let r={type:"farm-decision",taskSlug:t.taskSlug,decision:t.decision,decidedAt:t.decidedAt,via:t.via};return{factId:n.storeFact({category:"decision",content:JSON.stringify(r),source_surface:"afk"})}}catch(r){return{skipped:!0,reason:r instanceof Error?r.message:String(r)}}}import{promises as Tc}from"node:fs";import{join as _c}from"node:path";function ho(t){let e=t.filter(r=>r.score!==null),n=t.filter(r=>r.score===null).map(r=>r.index).sort((r,o)=>r-o);return e.sort((r,o)=>{let s=r.score,i=o.score,a=mo(s),c=mo(i);if(a!==c)return c-a;let l=go(s.lint_ok),d=go(i.lint_ok);return l!==d?d-l:s.loc_delta!==i.loc_delta?s.loc_delta-i.loc_delta:r.index-o.index}),[...e.map(r=>r.index),...n]}function mo(t){let e=t.pass+t.fail;return e===0?0:t.pass/e}function go(t){return t===!0?2:t===!1?1:0}async function It(t,e={}){if(t.branches.length===0)throw new Error(`resolveWinnerBranch: farm ${t.taskSlug} has no branches`);let n=e.loadScore??Ac,r=await Promise.all(t.branches.map(async i=>({index:i.index,score:await n(t.farmDir,i.index)}))),o=ho(r),s=new Map(t.branches.map(i=>[i.index,i]));for(let i of o){let a=r.find(c=>c.index===i)?.score;if(a&&a.pass>0&&a.fail===0){let c=s.get(i);if(c)return{branch:c,source:"winner"}}}for(let i of o)if(r.find(c=>c.index===i)?.score){let c=s.get(i);if(c)return{branch:c,source:"top-scored"}}return{branch:t.branches[0],source:"fallback-first-branch"}}async function Ac(t,e){let n=_c(t,"scores",`branch-${e}.json`);try{let r=await Tc.readFile(n,"utf8");return JSON.parse(r)}catch(r){return r.code==="ENOENT",null}}var Ct="afk:f:";var Rc=new Set(["p","d","r","x"]),Pc=/^[a-z0-9T][a-z0-9T-]{0,62}$/;function yo(t){if(!t||!t.startsWith(Ct)||Buffer.byteLength(t,"utf8")>64)return null;let e=t.slice(Ct.length),n=e.indexOf(":");if(n<1)return null;let r=e.slice(0,n),o=e.slice(n+1);return!Rc.has(r)||!Pc.test(o)?null:{action:r,taskSlug:o}}var
|
|
130
|
+
`,"utf8"),n}import{execFile as kc}from"node:child_process";import{promisify as vc}from"node:util";var Sc=vc(kc),xc=2e4,nt=class extends Error{kind;exitCode;stderr;constructor(e,n,r,o){super(e),this.name="GhError",this.kind=n,this.exitCode=r,this.stderr=o}},Pt=null,tt=null;function Ec(t,e,n){return n===!0?"timeout":e==="ENOENT"?"not-found":/already exists/i.test(t)?"already-exists":/authentication|please log in|HTTP 40[13]|bad credentials|token|scope/i.test(t)?"unauthed":/ETIMEDOUT|ECONNRESET|ECONNREFUSED/i.test(t+(e??""))?"network":"unknown"}function lo(t,e){return Sc(t,e,{timeout:xc,killSignal:"SIGTERM"}).then(n=>({stdout:n.stdout,stderr:n.stderr}))}async function uo(t={}){let e=(t._now??(()=>Date.now()))(),n=t.ttlMs??6e4,r=t.execFn??lo,o=t.log??(()=>{});return Pt&&Pt.expiresAt>e?(o("[gh] checkGhReady cache hit"),Pt.result):(o("[gh] checkGhReady cache miss \u2014 probing"),tt||(tt=(async()=>{try{await r("gh",["--version"])}catch(a){let c=a;return c.killed?{ok:!1,hint:"`gh` timed out \u2014 check connectivity"}:c.code==="ENOENT"?{ok:!1,hint:"`gh` CLI not found \u2014 install with: brew install gh"}:{ok:!1,hint:"`gh --version` failed unexpectedly \u2014 check gh installation"}}try{await r("gh",["auth","status"])}catch(a){let c=a;return c.killed||/ETIMEDOUT|ECONNRESET|ENOTFOUND/i.test(String(c.code??""))?{ok:!1,hint:"check network \u2014 cannot reach GitHub"}:{ok:!1,hint:"`gh` is not authenticated \u2014 run: gh auth login"}}let i={ok:!0};return n>0&&(Pt={result:i,expiresAt:e+n}),i})().finally(()=>{tt=null}),tt))}async function po(t,e){let n=e??lo,r=["pr","create","--base",t.base,"--head",t.head,"--title",t.title,"--body",t.body];try{let{stdout:o}=await n("gh",r);return o.trim()}catch(o){let s=o,i=s.stderr??"",a=s.code,c=s.exitCode??1,l=Ec(i,a,s.killed);throw new nt(`gh pr create failed (${l}): ${i.trim()}`,l,c,i)}}function fo(t,e){let n;try{n=e?._store??new V}catch(r){return{skipped:!0,reason:r instanceof Error?r.message:String(r)}}try{let r={type:"farm-decision",taskSlug:t.taskSlug,decision:t.decision,decidedAt:t.decidedAt,via:t.via};return{factId:n.storeFact({category:"decision",content:JSON.stringify(r),source_surface:"afk"})}}catch(r){return{skipped:!0,reason:r instanceof Error?r.message:String(r)}}}import{promises as Tc}from"node:fs";import{join as _c}from"node:path";function ho(t){let e=t.filter(r=>r.score!==null),n=t.filter(r=>r.score===null).map(r=>r.index).sort((r,o)=>r-o);return e.sort((r,o)=>{let s=r.score,i=o.score,a=mo(s),c=mo(i);if(a!==c)return c-a;let l=go(s.lint_ok),d=go(i.lint_ok);return l!==d?d-l:s.loc_delta!==i.loc_delta?s.loc_delta-i.loc_delta:r.index-o.index}),[...e.map(r=>r.index),...n]}function mo(t){let e=t.pass+t.fail;return e===0?0:t.pass/e}function go(t){return t===!0?2:t===!1?1:0}async function It(t,e={}){if(t.branches.length===0)throw new Error(`resolveWinnerBranch: farm ${t.taskSlug} has no branches`);let n=e.loadScore??Ac,r=await Promise.all(t.branches.map(async i=>({index:i.index,score:await n(t.farmDir,i.index)}))),o=ho(r),s=new Map(t.branches.map(i=>[i.index,i]));for(let i of o){let a=r.find(c=>c.index===i)?.score;if(a&&a.pass>0&&a.fail===0){let c=s.get(i);if(c)return{branch:c,source:"winner"}}}for(let i of o)if(r.find(c=>c.index===i)?.score){let c=s.get(i);if(c)return{branch:c,source:"top-scored"}}return{branch:t.branches[0],source:"fallback-first-branch"}}async function Ac(t,e){let n=_c(t,"scores",`branch-${e}.json`);try{let r=await Tc.readFile(n,"utf8");return JSON.parse(r)}catch(r){return r.code==="ENOENT",null}}var Ct="afk:f:";var Rc=new Set(["p","d","r","x"]),Pc=/^[a-z0-9T][a-z0-9T-]{0,62}$/;function yo(t){if(!t||!t.startsWith(Ct)||Buffer.byteLength(t,"utf8")>64)return null;let e=t.slice(Ct.length),n=e.indexOf(":");if(n<1)return null;let r=e.slice(0,n),o=e.slice(n+1);return!Rc.has(r)||!Pc.test(o)?null:{action:r,taskSlug:o}}var Oc=Mc(Ic),Fn=new Map;async function wo(t,e={}){let n=e.log??(()=>{}),r=Dc(t),o=yo(r);if(!o){await H(t,"Unknown action",n);return}if(t.chat?.id===void 0){await H(t,"No chat context",n);return}let s=e.loadFarm??Ne,i;try{i=await s(o.taskSlug)}catch(a){n("[farm-callback] loadFarm failed:",a),await H(t,"Farm load failed",n);return}if(!i){await H(t,"Farm not found (already GC\u2019d?)",n);return}try{await Fc(o.action,t,i,e,n)}catch(a){n("[farm-callback] dispatch error:",a),await H(t,"Internal error",n)}}function Dc(t){return t.callbackQuery?.data}async function H(t,e,n){try{await t.answerCbQuery(e)}catch(r){n("[farm-callback] answerCbQuery failed:",r)}}async function Fc(t,e,n,r,o){switch(t){case"x":return Uc(e,n,r,o);case"d":return jc(e,n,r,o);case"p":return bo(`p:${n.taskSlug}`,e,n,r,o,Lc);case"r":return bo(`r:${n.taskSlug}`,e,n,r,o,$c)}}async function bo(t,e,n,r,o,s){let i=Fn.get(t);if(i){o(`[farm-callback] ${t} \u2014 second tap, awaiting in-flight lock`);try{await i}catch{}let c=r.loadFarm??Ne,l;try{l=await c(n.taskSlug)}catch{await H(e,"Farm load failed",o);return}if(!l){await H(e,"Farm not found",o);return}return s(e,l,r,o)}let a=s(e,n,r,o);return Fn.set(t,a),a.finally(()=>{Fn.delete(t)}),a}async function Lc(t,e,n,r){if(e.prUrl){await H(t,`PR already open: ${e.prUrl}`,r);return}await H(t,"Opening PR\u2026",r);let o=n.checkGhReady??uo,s;try{s=await o()}catch(m){r("[farm-callback] checkGhReady threw:",m);try{await t.reply("gh readiness check failed \u2014 see daemon logs")}catch{}return}if(!s.ok){try{await t.reply(s.hint)}catch{}return}let i=n.resolveWinnerBranch??It,a;try{a=await i(e)}catch(m){r("[farm-callback] resolveWinnerBranch failed:",m);try{await t.reply("Winner lookup failed")}catch{}return}let c=a.branch.branch,l=e.baseBranch??"main",d=`Auto PR: ${e.taskName}`,u=`Auto-generated by afk farm ${e.taskSlug} | winner: ${c} | created: ${new Date().toISOString()}`,p=n.createPr??po,f;try{f=await p({base:l,head:c,title:d,body:u})}catch(m){if(m instanceof nt){let w={"not-found":"gh CLI not found \u2014 install with: brew install gh","already-exists":"PR already exists for this branch",unauthed:"gh is not authenticated \u2014 run: gh auth login",network:"Network error \u2014 check gh connectivity",timeout:"gh timed out \u2014 check connectivity",unknown:"gh pr create failed \u2014 see daemon logs"};try{await t.reply(w[m.kind])}catch{}return}r("[farm-callback] createPr failed:",m);try{await t.reply("gh pr create failed \u2014 see daemon logs")}catch{}return}let g=n.recordPrCreated??co;try{await g(e.taskSlug,f)}catch(m){r("[farm-callback] recordPrCreated failed:",m)}try{await t.reply(`PR opened \u2713
|
|
131
131
|
\u{1F517} ${f}`)}catch(m){r("[farm-callback] reply failed:",m)}}function Nc(t,e=()=>{}){e("[farm] spawning child afk process",{args:t});let n=Cc("afk",t,{detached:!0,stdio:"ignore"});n.on("error",r=>{e("[farm] child spawn error",{args:t,err:r.message})}),n.on("exit",(r,o)=>{r!==0&&e("[farm] child exited with non-zero code",{args:t,code:r,signal:o})}),n.unref()}async function $c(t,e,n,r){if(e.respawnedAs){await H(t,`Already respawned as ${e.respawnedAs}`,r);return}if(e.branches.length===0){await H(t,"No branches remain \u2014 cannot respawn",r);return}await H(t,"Respawning\u2026",r);let o=n.resolveWinnerBranch??It,s;try{s=await o(e)}catch(u){r("[farm-callback] resolveWinnerBranch failed:",u);try{await t.reply("Winner lookup failed")}catch{}return}let i=s.branch,a=so(e.taskName,{now:n._now,randomSuffix:n._randomSuffix}),c=e.branches.length;r("[farm] spawning child",{childSlug:a,baseRef:i.branch,branches:c});let l=n.spawnFarm??(u=>Nc(u,r));try{l(["farm",e.taskName,"--branches",String(c),"--base-ref",i.branch,"--task-slug",a])}catch(u){r("[farm-callback] spawnFarm failed:",u);try{await t.reply("Respawn failed")}catch{}return}let d=n.recordRespawn??ao;try{await d(e.taskSlug,a)}catch(u){r("[farm-callback] recordRespawn failed:",u)}try{await t.reply(`Respawning as \`${a}\` from ${i.branch} \u2713
|
|
132
132
|
\u{1F504} Farm \`${e.taskSlug}\` respawned.
|
|
133
133
|
Child slug: \`${a}\`
|
|
@@ -138,8 +138,8 @@ Commits:
|
|
|
138
138
|
${l.stdout.trim()||"(none)"}
|
|
139
139
|
|
|
140
140
|
Stat:
|
|
141
|
-
${d.stdout.trim()||"(no changes)"}`;await t.reply(u.slice(0,4e3))}catch(l){r("[farm-callback] diff failed:",l);try{await t.reply("Diff failed \u2014 see daemon logs.")}catch{}}}async function Hc(t,e){let n=await
|
|
142
|
-
`)}return n.accessToken}function Eo(){if(process.platform==="darwin")try{return ko("security",["find-generic-password","-s","Claude Code-credentials","-a",So().username,"-w"],{stdio:["ignore","pipe","ignore"],encoding:"utf-8"}).trim()}catch{return}if(process.platform==="linux"){let t=xo(vo(),".claude",".credentials.json");if(!Bc(t))return;try{return Wc(t,"utf-8")}catch{return}}}function To(t){let e;try{e=JSON.parse(t)}catch{return}if(typeof e!="object"||e===null)return;let n=e.claudeAiOauth;if(typeof n!="object"||n===null)return;let r=n,o=r.accessToken;if(typeof o!="string"||o.length===0)return;let s={accessToken:o},i=r.refreshToken;typeof i=="string"&&i.length>0&&(s.refreshToken=i);let a=r.expiresAt;return typeof a=="number"&&(s.expiresAt=a),s}async function Jc(t){try{let e=await fetch(qc,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({grant_type:"refresh_token",refresh_token:t,client_id:Kc})});if(!e.ok)return;let n=await e.json(),r=n.access_token,o=n.expires_in;if(typeof r!="string"||typeof o!="number")return;let s=n.refresh_token;return{accessToken:r,expiresAt:Date.now()+o*1e3,...typeof s=="string"&&s.length>0?{refreshToken:s}:{}}}catch{return}}function Mt(t){if(!t||t.length<3)return"token:(unknown)";try{let n=t.split(".");if(n.length<2)throw new Error("not a JWT");let r=Buffer.from(n[1],"base64url").toString("utf-8"),o=JSON.parse(r),s=typeof o.email=="string"&&o.email||typeof o.sub=="string"&&o.sub||typeof o.account_id=="string"&&o.account_id||typeof o.preferred_username=="string"&&o.preferred_username;if(s)return s}catch{}return`token:${t.length>=8?t.slice(-8):t}`}function Vc(t){if(process.platform==="darwin")ko("security",["add-generic-password","-U","-s","Claude Code-credentials","-a",So().username,"-w",t],{stdio:["ignore","ignore","ignore"]});else if(process.platform==="linux"){let e=xo(vo(),".claude",".credentials.json");Gc(e,t,"utf-8")}}function Nn(t){if(!("status"in t))return null;let e=t.status;if(e===429){let n=t.message.split("|");if(n.length>=2){let r=parseInt(n[1].trim(),10);if(!isNaN(r)&&r>0)return{kind:"oauth-limit",resetsAt:new Date(r*1e3)}}return{kind:"oauth-limit-no-ts"}}return e===400&&t.message.includes("invalid_request_error")&&t.message.includes("credit balance")?{kind:"credit-exhausted"}:null}async function _o(t){let{resetsAt:e,signal:n,readToken:r=ye}=t,o=r(),s=e.getTime()+3e4;return new Promise(i=>{let a=()=>n.aborted?(i("aborted"),!0):Date.now()>=s?(i("timer"),!0):r()!==o?(i("hot-swap"),!0):!1;if(a())return;let c=setInterval(()=>{a()&&clearInterval(c)},3e4);n.addEventListener("abort",()=>{clearInterval(c),i("aborted")},{once:!0})})}function
|
|
141
|
+
${d.stdout.trim()||"(no changes)"}`;await t.reply(u.slice(0,4e3))}catch(l){r("[farm-callback] diff failed:",l);try{await t.reply("Diff failed \u2014 see daemon logs.")}catch{}}}async function Hc(t,e){let n=await Oc("git",e,{cwd:t,maxBuffer:4194304});return{stdout:n.stdout,stderr:n.stderr}}import{execFileSync as ko}from"child_process";import{existsSync as Bc,readFileSync as Wc,writeFileSync as Gc}from"fs";import{homedir as vo,userInfo as So}from"os";import{join as xo}from"path";var Kc="9d1c250a-e61b-44d9-88ed-5944d1962f5e",qc="https://platform.claude.com/v1/oauth/token",zc=300*1e3;function ye(){let t=Eo();if(t===void 0)return;let e=To(t);if(e!==void 0){if(e.expiresAt!==void 0&&e.expiresAt<=Date.now()){process.stderr.write("agent-afk: Claude Code OAuth token in keychain is expired. Run `claude login` to refresh.\n");return}return e.accessToken}}async function Ln(){let t=Eo();if(t===void 0)return;let e=To(t);if(e===void 0)return;if(e.expiresAt!==void 0&&e.expiresAt>Date.now()+zc)return e.accessToken;if(!e.refreshToken){process.stderr.write("agent-afk: OAuth token expired and no refresh token available. Run `claude login` to refresh.\n");return}let n=await Jc(e.refreshToken);if(!n){process.stderr.write("agent-afk: OAuth token refresh failed. Run `claude login` to refresh.\n");return}try{let r={};try{r=JSON.parse(t)}catch{}let o=r.claudeAiOauth??{};r.claudeAiOauth={...o,accessToken:n.accessToken,expiresAt:n.expiresAt,...n.refreshToken!==void 0?{refreshToken:n.refreshToken}:{}},Vc(JSON.stringify(r))}catch{process.stderr.write(`agent-afk: Refreshed OAuth token but failed to write back to credential store.
|
|
142
|
+
`)}return n.accessToken}function Eo(){if(process.platform==="darwin")try{return ko("security",["find-generic-password","-s","Claude Code-credentials","-a",So().username,"-w"],{stdio:["ignore","pipe","ignore"],encoding:"utf-8"}).trim()}catch{return}if(process.platform==="linux"){let t=xo(vo(),".claude",".credentials.json");if(!Bc(t))return;try{return Wc(t,"utf-8")}catch{return}}}function To(t){let e;try{e=JSON.parse(t)}catch{return}if(typeof e!="object"||e===null)return;let n=e.claudeAiOauth;if(typeof n!="object"||n===null)return;let r=n,o=r.accessToken;if(typeof o!="string"||o.length===0)return;let s={accessToken:o},i=r.refreshToken;typeof i=="string"&&i.length>0&&(s.refreshToken=i);let a=r.expiresAt;return typeof a=="number"&&(s.expiresAt=a),s}async function Jc(t){try{let e=await fetch(qc,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({grant_type:"refresh_token",refresh_token:t,client_id:Kc})});if(!e.ok)return;let n=await e.json(),r=n.access_token,o=n.expires_in;if(typeof r!="string"||typeof o!="number")return;let s=n.refresh_token;return{accessToken:r,expiresAt:Date.now()+o*1e3,...typeof s=="string"&&s.length>0?{refreshToken:s}:{}}}catch{return}}function Mt(t){if(!t||t.length<3)return"token:(unknown)";try{let n=t.split(".");if(n.length<2)throw new Error("not a JWT");let r=Buffer.from(n[1],"base64url").toString("utf-8"),o=JSON.parse(r),s=typeof o.email=="string"&&o.email||typeof o.sub=="string"&&o.sub||typeof o.account_id=="string"&&o.account_id||typeof o.preferred_username=="string"&&o.preferred_username;if(s)return s}catch{}return`token:${t.length>=8?t.slice(-8):t}`}function Vc(t){if(process.platform==="darwin")ko("security",["add-generic-password","-U","-s","Claude Code-credentials","-a",So().username,"-w",t],{stdio:["ignore","ignore","ignore"]});else if(process.platform==="linux"){let e=xo(vo(),".claude",".credentials.json");Gc(e,t,"utf-8")}}function Nn(t){if(!("status"in t))return null;let e=t.status;if(e===429){let n=t.message.split("|");if(n.length>=2){let r=parseInt(n[1].trim(),10);if(!isNaN(r)&&r>0)return{kind:"oauth-limit",resetsAt:new Date(r*1e3)}}return{kind:"oauth-limit-no-ts"}}return e===400&&t.message.includes("invalid_request_error")&&t.message.includes("credit balance")?{kind:"credit-exhausted"}:null}async function _o(t){let{resetsAt:e,signal:n,readToken:r=ye}=t,o=r(),s=e.getTime()+3e4;return new Promise(i=>{let a=()=>n.aborted?(i("aborted"),!0):Date.now()>=s?(i("timer"),!0):r()!==o?(i("hot-swap"),!0):!1;if(a())return;let c=setInterval(()=>{a()&&clearInterval(c)},3e4);n.addEventListener("abort",()=>{clearInterval(c),i("aborted")},{once:!0})})}function Ot(t){let e=t instanceof Error?t.message:String(t);return e.toLowerCase().includes("rate limit")||e.toLowerCase().includes("too many requests")}function Dt(t){let e=t instanceof Error?t.message:String(t);return e.toLowerCase().includes("network")||e.toLowerCase().includes("connect")||e.toLowerCase().includes("timeout")}import{TelegramError as Po}from"telegraf";import{AsyncLocalStorage as Yc}from"node:async_hooks";var Ao=new Yc;function Ro(t,e){return Ao.run(t,e)}function oe(){return Ao.getStore()}var Xc=300,Qc=9e4,Io=6e4,Zc=300*1e3,el=9e4;async function Co(t,e,n,r){if(!t.chat?.id){r?.("streamResponse: ctx.chat is undefined (non-chat context); skipping");return}let o="",s=null,i=0,a=null,c=null,l=!1,d=-1,u=async(p,f=!1)=>{let g=Date.now();if(!s){let b=Tt(p||"\u2026"),h=Et(b);try{s=await t.reply(h[0]??"\u2026",{parse_mode:"HTML"})}catch(y){if(y instanceof Po&&y.code===400&&/can't parse entities/i.test(y.description))s=await t.reply(p||"\u2026");else throw y}return}if(!f&&g-i<Xc&&p.length<100)return;i=g;let m=Tt(p||"\u2026"),w=Et(m);try{await t.telegram.editMessageText(t.chat?.id,s.message_id,void 0,w[0]??m,{parse_mode:"HTML"})}catch(b){if(b instanceof Po&&b.code===400&&/can't parse entities/i.test(b.description))try{await t.telegram.editMessageText(t.chat?.id,s.message_id,void 0,p)}catch{}}};try{let p="sendMessageStream"in e&&typeof e.sendMessageStream=="function"?e.sendMessageStream(n):(async function*(){let h=await e.sendMessage(n,{stream:!1});yield{type:"message",message:h},yield{type:"done",metadata:h.metadata}})();await u("Thinking\u2026");let f=p[Symbol.asyncIterator](),g=!1,m=null,w=()=>{let h=a!==null?Math.max(Io,a.getTime()-Date.now()+el):g?Io:Qc;return new Promise((y,k)=>{m=setTimeout(()=>{m=null,k(new Error(g?"Response timed out. Try sending a shorter message or try again.":"Request timed out. The agent may still be starting (first message can take a minute). Try again in a moment."))},h),f.next().then(_=>{m!=null&&(clearTimeout(m),m=null),y(_)},_=>{m!=null&&(clearTimeout(m),m=null),k(_)})})},b=(h,y)=>{let k=y.agentType??y.subagentId;if(h.type==="chunk"&&h.chunk.type==="tool_use_detail"){let _=h.chunk.toolInput.length>60?h.chunk.toolInput.slice(0,57)+"...":h.chunk.toolInput;o+=`
|
|
143
143
|
\u25E6 ${k}: ${h.chunk.toolName} ${_}`,u(o)}else h.type==="done"&&(o+=`
|
|
144
144
|
\u25E6 ${k}: Done`,u(o))};try{await Ro(b,async()=>{for(;;){process.env.AFK_TELEGRAM_TRACE&&console.log("[trace] awaiting next event");let h=await w();if(process.env.AFK_TELEGRAM_TRACE&&console.log("[trace] event arrived:",h.done?"DONE":h.value.type),h.done)break;let y=h.value;if(g||(g=!0,console.log("\u{1F4E1} First stream event received:",y.type),r?.("First stream event received:",y.type)),y.type==="chunk"&&y.chunk.type==="content"&&(o+=y.chunk.content,await u(o)),y.type==="chunk"&&y.chunk.type,y.type==="message"&&y.message.role==="assistant"&&(o=y.message.content,await u(o)),y.type==="progress"){let{description:k,summary:_,lastToolName:I}=y.progress,S=I?`
|
|
145
145
|
\u25E6 ${k} (${I})`:`
|
|
@@ -156,7 +156,7 @@ I'll auto-resume when the limit resets \u2014 no need to retype.`;await u(I,!0),
|
|
|
156
156
|
|
|
157
157
|
Resets at ${a.toLocaleTimeString(void 0,{hour:"numeric",minute:"2-digit",hour12:!0})} (in ~${S} min).
|
|
158
158
|
|
|
159
|
-
I'll auto-resume when the limit resets \u2014 no need to retype.`;l=!0,u(R,!0).finally(()=>{l=!1})}},Zc));continue}if(y.type==="resumed"){c!==null&&(clearInterval(c),c=null),a=null;let k=y.hotSwapped&&y.accountId?`\u25B6 **Resumed on ${y.accountId}**`:"\u25B6 **Resumed**";await u(k,!0);continue}if(y.type==="done"){c!==null&&(clearInterval(c),c=null),o.trim()&&await u(o,!0);break}if(y.type==="error")throw c!==null&&(clearInterval(c),c=null),y.error}})}finally{await Promise.resolve(f.return?.(void 0)).catch(()=>{})}if(o&&s){let h=Et(Tt(o));if(h.length>1)for(let y=1;y<h.length;y++){let k=h[y];k&&await t.reply(k,{parse_mode:"HTML"})}}await Promise.resolve(f.return?.(void 0)).catch(h=>{r?.("iter.return error (session cleanup):",h)})}catch(p){throw r?.("Streaming error:",p),p}}async function Mo(t,e,n,r,o){if(!r.has(e))try{await Promise.race([n.waitForInitialization(),new Promise((a,c)=>setTimeout(()=>c(new Error("timeout")),5e3))]);let s=n.getSessionMetadata(),i=[{command:"start",description:"Show welcome and command list"},{command:"help",description:"Show this command list"},{command:"clear",description:"Clear conversation history"},{command:"compact",description:"Compact conversation history"},{command:"model",description:"Switch Claude model (opus/sonnet/haiku)"}];if(s.slashCommands?.length)for(let a of s.slashCommands){let c=a.replace(/^\//,"");i.push({command:c,description:`SDK command: ${c}`})}if(s.skills?.length)for(let a of s.skills)i.push({command:a,description:`Run ${a} skill`});await t.telegram.setMyCommands(i,{scope:{type:"chat",chat_id:e}}),r.add(e),o(`Registered ${i.length} commands for chat ${e}`)}catch(s){o(`Could not register dynamic commands for chat ${e}:`,s)}}var Ft=class{sessionManager;messageQueues=new Map;registeredCommandChats;log;bot;constructor(e,n,r,o){this.bot=e,this.sessionManager=n,this.registeredCommandChats=r,this.log=o}async handle(e){let n=e.chat?.id,r=e.message.text;if(!(!n||!r)&&(console.log(`\u{1F4EC} Message from chat ID: ${n}`),!r.startsWith("/")))try{let o=await this.sessionManager.getSession(n);if(Mo(this.bot,n,o,this.registeredCommandChats,this.log).catch(s=>this.log("Failed to register chat commands:",s)),o.state!=="idle"){this.enqueueMessage(n,e,r),await e.reply("Message queued.");return}await this.processOne(n,e,r)}catch(o){if(console.error("\u274C Message handling error:",o),this.log("Message handling error:",o),(o?.message??"").includes("session is busy")){this.enqueueMessage(n,e,r),await e.reply("Message queued.");return}Dt(o)?await e.reply("\u23F3 Rate limit reached. Please wait a moment and try again."):Ot(o)?await e.reply("\u{1F310} Network error. Please check your connection and try again."):await e.reply(In())}}async processClearDirect(e,n){try{await this.sessionManager.resetSession(e),this.registeredCommandChats.delete(e),await n.reply(_t())}catch(r){this.log("Clear error:",r),await n.reply(q(r))}}enqueueMessage(e,n,r){let o=this.messageQueues.get(e);o||(o=[],this.messageQueues.set(e,o)),o.push({type:"message",ctx:n,text:r})}enqueueClear(e,n){let r=this.messageQueues.get(e);r||(r=[],this.messageQueues.set(e,r)),r.push({type:"clear",ctx:n})}async processOne(e,n,r){try{let o=await this.sessionManager.getSession(e);await n.sendChatAction("typing").catch(()=>{}),await Co(n,o,r,this.log)}catch(o){console.error("\u274C Message handling error:",o),this.log("Message handling error:",o),Dt(o)?await n.reply("\u23F3 Rate limit reached. Please wait a moment and try again."):Ot(o)?await n.reply("\u{1F310} Network error. Please check your connection and try again."):await n.reply(In())}finally{this.drainQueue(e).catch(o=>this.log("Drain error:",o))}}async drainQueue(e){let n=this.messageQueues.get(e);if(!n?.length)return;let r=n.shift();r.type==="message"?await this.processOne(e,r.ctx,r.text):await this.processClearDirect(e,r.ctx)}};function rt(t,e=()=>{}){let n=new Set;if(!t)return n;for(let r of t.split(",")){let o=r.trim();if(o){if(!/^-?\d+$/.test(o)){e("[allowlist] Ignoring non-numeric chat ID:",o);continue}n.add(Number(o))}}return n}function Do(t,e=()=>{}){return async(n,r)=>{let o=n.chat?.id;if(o===void 0||!t.has(o)){e("[allowlist] Rejecting update from chat:",o??"<unknown>");return}await r()}}var Lt=class{bot;sessionManager;options;running=!1;registeredCommandChats=new Set;messageHandler;constructor(e){this.options=e,this.bot=new tl(e.botToken),this.sessionManager=new xt(e),this.messageHandler=new Ft(this.bot,this.sessionManager,this.registeredCommandChats,this.log.bind(this)),this.setupHandlers()}setupHandlers(){this.bot.use(Do(this.options.allowedChatIds,this.log.bind(this))),this.bot.command("start",n=>Cn(n)),this.bot.command("help",n=>Mn(n,this.sessionManager)),this.bot.command("clear",async n=>{let r=n.chat?.id;if(!r){await n.reply(q("Could not identify chat"));return}(await this.sessionManager.getSession(r)).state!=="idle"?(this.messageHandler.enqueueClear(r,n),await n.reply("Clear queued.")):await Dn(n,this.sessionManager,this.registeredCommandChats,this.log.bind(this))}),this.bot.command("compact",n=>oo(n,this.sessionManager,this.log.bind(this))),this.bot.command("model",n=>On(n,this.sessionManager,this.log.bind(this))),this.bot.on("text",n=>this.messageHandler.handle(n));let e=new RegExp(`^${nl(Ct)}`);this.bot.action(e,n=>wo(n,{log:this.log.bind(this)})),this.bot.catch((n,r)=>{this.log("Bot error:",n),r.reply(q("An unexpected error occurred. Please try again.")).catch(o=>this.log("Failed to send error message:",o))})}async start(){if(this.running)throw new Error("Bot is already running");this.log("Loading sessions..."),await this.sessionManager.loadSessions(),this.log("Starting bot..."),await this.bot.launch(),this.log("Registering bot commands..."),await this.bot.telegram.setMyCommands([{command:"start",description:"Show welcome and command list"},{command:"help",description:"Show this command list"},{command:"clear",description:"Clear conversation history"},{command:"compact",description:"Compact conversation history"},{command:"model",description:"Switch Claude model (opus/sonnet/haiku)"}]),this.running=!0,this.log("Bot started successfully");let e=async n=>{this.log(`Received ${n}, shutting down...`),await this.stop(),process.exit(0)};process.once("SIGINT",()=>e("SIGINT")),process.once("SIGTERM",()=>e("SIGTERM"))}async stop(){if(this.running){this.log("Stopping bot..."),this.running=!1,this.log("Closing sessions..."),await this.sessionManager.closeAll(),this.log("Stopping bot polling...");try{this.bot.stop()}catch(e){this.log("Error stopping bot (may not have been started):",e)}this.log("Bot stopped")}}getStats(){return{running:this.running,activeSessions:this.sessionManager.getSessionCount(),totalChats:this.sessionManager.getChatCount()}}async handleStart(e){return Cn(e)}async handleHelp(e){return Mn(e,this.sessionManager)}async handleClear(e){let n=e.chat?.id;if(!n){await e.reply(q("Could not identify chat"));return}if((await this.sessionManager.getSession(n)).state!=="idle")this.messageHandler.enqueueClear(n,e),await e.reply("Clear queued.");else return Dn(e,this.sessionManager,this.registeredCommandChats,this.log.bind(this))}async handleMessage(e){return this.messageHandler.handle(e)}async handleModelSwitch(e){return On(e,this.sessionManager,this.log.bind(this))}log(...e){this.options.verbose&&console.log("[TelegramBot]",...e)}};function nl(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}import oy from"chalk";var rl="https://api.telegram.org";async function Oo(t){try{let e=await fetch(`${rl}/bot${t}/getMe`);if(!e.ok)return null;let n=await e.json();return!n.ok||!n.result?.id||!n.result?.first_name?null:{id:n.result.id,...n.result.username!==void 0?{username:n.result.username}:{},firstName:n.result.first_name}}catch{return null}}var Z=class extends Error{constructor(e){super(e),this.name="AbortError"}},ae=class extends Error{constructor(n,r){super(n);this.timeoutMs=r;this.name="TimeoutError"}timeoutMs},B=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 $e=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};async function $n(t,e){if(t)try{await t.write({kind:"tool_call",payload:e})}catch(n){C(`trace.emit tool_call failed: ${Te(n)}`)}}async function Ue(t,e){if(t)try{await t.write({kind:"hook_decision",payload:e})}catch(n){C(`trace.emit hook_decision failed: ${Te(n)}`)}}async function Ee(t,e){if(t)try{await t.write({kind:"subagent_lifecycle",payload:e})}catch(n){C(`trace.emit subagent_lifecycle failed: ${Te(n)}`)}}async function Fo(t,e){if(t)try{await t.write({kind:"budget",payload:e})}catch(n){C(`trace.emit budget failed: ${Te(n)}`)}}async function Lo(t,e){if(t)try{await t.write({kind:"abort",payload:e})}catch(n){C(`trace.emit abort failed: ${Te(n)}`)}}async function No(t,e){if(t)try{await t.write({kind:"compaction",payload:e})}catch(n){C(`trace.emit compaction failed: ${Te(n)}`)}}async function $o(t,e){if(t)try{await t.write({kind:"closure",payload:e})}catch(n){C(`trace.emit closure failed: ${Te(n)}`)}}function Te(t){return t instanceof Error?t.message:String(t)}import wr from"path";import{appendFileSync as nm,mkdirSync as rm}from"fs";import{dirname as om}from"path";import ta from"@anthropic-ai/sdk";var Uo="claude-code-20250219,oauth-2025-04-20,interleaved-thinking-2025-05-14",ol="effort-2025-11-24",sl="claude-cli/1.0.0 (external, cli)",il="x-anthropic-billing-header: cc_version=1.0.0.test; cc_entrypoint=cli; cch=00000;";function Nt(t){return t.startsWith("sk-ant-oat01-")?"oauth":"api-key"}function Un(t,e,n){let r=e==="oauth"?{authToken:t}:{apiKey:t};return typeof n=="string"&&n.length>0?{...r,baseURL:n}:r}function _e(t,e,n,r){return t!=="oauth"?{}:{"anthropic-beta":r?`${Uo},${ol}`:Uo,"x-app":"cli","User-Agent":sl,"X-Claude-Code-Session-Id":e,"x-client-request-id":n}}function jo(t){return t!=="oauth"?null:[{type:"text",text:il}]}import{randomUUID as Zi}from"node:crypto";function $t(t){if(typeof t?.baseUrl=="string"&&t.baseUrl.length>0)return!1;let e=process.env.AFK_DISABLE_PROMPT_CACHE;if(e===void 0||e.length===0)return!0;let n=e.toLowerCase();return!(n==="1"||n==="true"||n==="yes"||n==="on")}function Ut(){let t=process.env.AFK_PROMPT_CACHE_TTL;return t==="5m"?"5m":"1h"}function Ho(t,e){if(t.length===0)return t;let n=t[t.length-1],r=Wo(n,e);return r===n?t:[...t.slice(0,-1),r]}function Bo(t,e){if(t.length===0)return t;let n=t[t.length-1],r=al(n,e);return r===n?t:[...t.slice(0,-1),r]}function al(t,e){let n=t.content;if(typeof n=="string")return n.length===0?t:{...t,content:[{type:"text",text:n,cache_control:{type:"ephemeral",ttl:e}}]};if(!Array.isArray(n)||n.length===0)return t;let r=n[n.length-1],o=Wo(r,e);return o===r?t:{...t,content:[...n.slice(0,-1),o]}}function Wo(t,e){return t.type==="thinking"||t.type==="redacted_thinking"?t:{...t,cache_control:{type:"ephemeral",ttl:e}}}var cl=["## Plan mode is active","","Write-class tools (`write_file`, `edit_file`, write-intent `bash`) are refused at the hook layer.","The user has asked you to plan, not yet to act. Treat this turn as planning work.","","Traverse the shape that matches the work \u2014 skip steps the terrain already covers, do not skip steps the terrain hides:",""," unknown field \u2192 ground the current terrain \u2192 gather missing codebase context \u2192"," research missing external context \u2192 reveal chaos / constraints / risks \u2192"," name the failure geometry \u2192 form a candidate plan \u2192 apply adversarial pressure \u2192 embody the final plan","","Reach for these skills (invoke via the `skill` tool) when the cost of skipping exceeds the cost of dispatching:"," - `ground-state` \u2014 survey git, infra, memory before non-trivial work"," - `gather` \u2014 parallel context-gathering for a code area"," - `research` \u2014 parallel external + local context for the current task"," - `devils-advocate` \u2014 generate alternatives and rank them before committing"," - `shadow-verify` \u2014 independently re-derive load-bearing claims","","Do not declare readiness silently. When the plan is ready, state: chosen approach, risks named, and alternatives considered. The user will exit plan mode (`/plan off`) when satisfied."].join(`
|
|
159
|
+
I'll auto-resume when the limit resets \u2014 no need to retype.`;l=!0,u(R,!0).finally(()=>{l=!1})}},Zc));continue}if(y.type==="resumed"){c!==null&&(clearInterval(c),c=null),a=null;let k=y.hotSwapped&&y.accountId?`\u25B6 **Resumed on ${y.accountId}**`:"\u25B6 **Resumed**";await u(k,!0);continue}if(y.type==="done"){c!==null&&(clearInterval(c),c=null),o.trim()&&await u(o,!0);break}if(y.type==="error")throw c!==null&&(clearInterval(c),c=null),y.error}})}finally{await Promise.resolve(f.return?.(void 0)).catch(()=>{})}if(o&&s){let h=Et(Tt(o));if(h.length>1)for(let y=1;y<h.length;y++){let k=h[y];k&&await t.reply(k,{parse_mode:"HTML"})}}await Promise.resolve(f.return?.(void 0)).catch(h=>{r?.("iter.return error (session cleanup):",h)})}catch(p){throw r?.("Streaming error:",p),p}}async function Mo(t,e,n,r,o){if(!r.has(e))try{await Promise.race([n.waitForInitialization(),new Promise((a,c)=>setTimeout(()=>c(new Error("timeout")),5e3))]);let s=n.getSessionMetadata(),i=[{command:"start",description:"Show welcome and command list"},{command:"help",description:"Show this command list"},{command:"clear",description:"Clear conversation history"},{command:"compact",description:"Compact conversation history"},{command:"model",description:"Switch Claude model (opus/sonnet/haiku)"}];if(s.slashCommands?.length)for(let a of s.slashCommands){let c=a.replace(/^\//,"");i.push({command:c,description:`SDK command: ${c}`})}if(s.skills?.length)for(let a of s.skills)i.push({command:a,description:`Run ${a} skill`});await t.telegram.setMyCommands(i,{scope:{type:"chat",chat_id:e}}),r.add(e),o(`Registered ${i.length} commands for chat ${e}`)}catch(s){o(`Could not register dynamic commands for chat ${e}:`,s)}}var Ft=class{sessionManager;messageQueues=new Map;registeredCommandChats;log;bot;constructor(e,n,r,o){this.bot=e,this.sessionManager=n,this.registeredCommandChats=r,this.log=o}async handle(e){let n=e.chat?.id,r=e.message.text;if(!(!n||!r)&&(console.log(`\u{1F4EC} Message from chat ID: ${n}`),!r.startsWith("/")))try{let o=await this.sessionManager.getSession(n);if(Mo(this.bot,n,o,this.registeredCommandChats,this.log).catch(s=>this.log("Failed to register chat commands:",s)),o.state!=="idle"){this.enqueueMessage(n,e,r),await e.reply("Message queued.");return}await this.processOne(n,e,r)}catch(o){if(console.error("\u274C Message handling error:",o),this.log("Message handling error:",o),(o?.message??"").includes("session is busy")){this.enqueueMessage(n,e,r),await e.reply("Message queued.");return}Ot(o)?await e.reply("\u23F3 Rate limit reached. Please wait a moment and try again."):Dt(o)?await e.reply("\u{1F310} Network error. Please check your connection and try again."):await e.reply(In())}}async processClearDirect(e,n){try{await this.sessionManager.resetSession(e),this.registeredCommandChats.delete(e),await n.reply(_t())}catch(r){this.log("Clear error:",r),await n.reply(q(r))}}enqueueMessage(e,n,r){let o=this.messageQueues.get(e);o||(o=[],this.messageQueues.set(e,o)),o.push({type:"message",ctx:n,text:r})}enqueueClear(e,n){let r=this.messageQueues.get(e);r||(r=[],this.messageQueues.set(e,r)),r.push({type:"clear",ctx:n})}async processOne(e,n,r){try{let o=await this.sessionManager.getSession(e);await n.sendChatAction("typing").catch(()=>{}),await Co(n,o,r,this.log)}catch(o){console.error("\u274C Message handling error:",o),this.log("Message handling error:",o),Ot(o)?await n.reply("\u23F3 Rate limit reached. Please wait a moment and try again."):Dt(o)?await n.reply("\u{1F310} Network error. Please check your connection and try again."):await n.reply(In())}finally{this.drainQueue(e).catch(o=>this.log("Drain error:",o))}}async drainQueue(e){let n=this.messageQueues.get(e);if(!n?.length)return;let r=n.shift();r.type==="message"?await this.processOne(e,r.ctx,r.text):await this.processClearDirect(e,r.ctx)}};function rt(t,e=()=>{}){let n=new Set;if(!t)return n;for(let r of t.split(",")){let o=r.trim();if(o){if(!/^-?\d+$/.test(o)){e("[allowlist] Ignoring non-numeric chat ID:",o);continue}n.add(Number(o))}}return n}function Oo(t,e=()=>{}){return async(n,r)=>{let o=n.chat?.id;if(o===void 0||!t.has(o)){e("[allowlist] Rejecting update from chat:",o??"<unknown>");return}await r()}}var Lt=class{bot;sessionManager;options;running=!1;registeredCommandChats=new Set;messageHandler;constructor(e){this.options=e,this.bot=new tl(e.botToken),this.sessionManager=new xt(e),this.messageHandler=new Ft(this.bot,this.sessionManager,this.registeredCommandChats,this.log.bind(this)),this.setupHandlers()}setupHandlers(){this.bot.use(Oo(this.options.allowedChatIds,this.log.bind(this))),this.bot.command("start",n=>Cn(n)),this.bot.command("help",n=>Mn(n,this.sessionManager)),this.bot.command("clear",async n=>{let r=n.chat?.id;if(!r){await n.reply(q("Could not identify chat"));return}(await this.sessionManager.getSession(r)).state!=="idle"?(this.messageHandler.enqueueClear(r,n),await n.reply("Clear queued.")):await On(n,this.sessionManager,this.registeredCommandChats,this.log.bind(this))}),this.bot.command("compact",n=>oo(n,this.sessionManager,this.log.bind(this))),this.bot.command("model",n=>Dn(n,this.sessionManager,this.log.bind(this))),this.bot.on("text",n=>this.messageHandler.handle(n));let e=new RegExp(`^${nl(Ct)}`);this.bot.action(e,n=>wo(n,{log:this.log.bind(this)})),this.bot.catch((n,r)=>{this.log("Bot error:",n),r.reply(q("An unexpected error occurred. Please try again.")).catch(o=>this.log("Failed to send error message:",o))})}async start(){if(this.running)throw new Error("Bot is already running");this.log("Loading sessions..."),await this.sessionManager.loadSessions(),this.log("Starting bot..."),await this.bot.launch(),this.log("Registering bot commands..."),await this.bot.telegram.setMyCommands([{command:"start",description:"Show welcome and command list"},{command:"help",description:"Show this command list"},{command:"clear",description:"Clear conversation history"},{command:"compact",description:"Compact conversation history"},{command:"model",description:"Switch Claude model (opus/sonnet/haiku)"}]),this.running=!0,this.log("Bot started successfully");let e=async n=>{this.log(`Received ${n}, shutting down...`),await this.stop(),process.exit(0)};process.once("SIGINT",()=>e("SIGINT")),process.once("SIGTERM",()=>e("SIGTERM"))}async stop(){if(this.running){this.log("Stopping bot..."),this.running=!1,this.log("Closing sessions..."),await this.sessionManager.closeAll(),this.log("Stopping bot polling...");try{this.bot.stop()}catch(e){this.log("Error stopping bot (may not have been started):",e)}this.log("Bot stopped")}}getStats(){return{running:this.running,activeSessions:this.sessionManager.getSessionCount(),totalChats:this.sessionManager.getChatCount()}}async handleStart(e){return Cn(e)}async handleHelp(e){return Mn(e,this.sessionManager)}async handleClear(e){let n=e.chat?.id;if(!n){await e.reply(q("Could not identify chat"));return}if((await this.sessionManager.getSession(n)).state!=="idle")this.messageHandler.enqueueClear(n,e),await e.reply("Clear queued.");else return On(e,this.sessionManager,this.registeredCommandChats,this.log.bind(this))}async handleMessage(e){return this.messageHandler.handle(e)}async handleModelSwitch(e){return Dn(e,this.sessionManager,this.log.bind(this))}log(...e){this.options.verbose&&console.log("[TelegramBot]",...e)}};function nl(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}import oy from"chalk";var rl="https://api.telegram.org";async function Do(t){try{let e=await fetch(`${rl}/bot${t}/getMe`);if(!e.ok)return null;let n=await e.json();return!n.ok||!n.result?.id||!n.result?.first_name?null:{id:n.result.id,...n.result.username!==void 0?{username:n.result.username}:{},firstName:n.result.first_name}}catch{return null}}var Z=class extends Error{constructor(e){super(e),this.name="AbortError"}},ae=class extends Error{constructor(n,r){super(n);this.timeoutMs=r;this.name="TimeoutError"}timeoutMs},B=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 $e=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};async function $n(t,e){if(t)try{await t.write({kind:"tool_call",payload:e})}catch(n){C(`trace.emit tool_call failed: ${Te(n)}`)}}async function Ue(t,e){if(t)try{await t.write({kind:"hook_decision",payload:e})}catch(n){C(`trace.emit hook_decision failed: ${Te(n)}`)}}async function Ee(t,e){if(t)try{await t.write({kind:"subagent_lifecycle",payload:e})}catch(n){C(`trace.emit subagent_lifecycle failed: ${Te(n)}`)}}async function Fo(t,e){if(t)try{await t.write({kind:"budget",payload:e})}catch(n){C(`trace.emit budget failed: ${Te(n)}`)}}async function Lo(t,e){if(t)try{await t.write({kind:"abort",payload:e})}catch(n){C(`trace.emit abort failed: ${Te(n)}`)}}async function No(t,e){if(t)try{await t.write({kind:"compaction",payload:e})}catch(n){C(`trace.emit compaction failed: ${Te(n)}`)}}async function $o(t,e){if(t)try{await t.write({kind:"closure",payload:e})}catch(n){C(`trace.emit closure failed: ${Te(n)}`)}}function Te(t){return t instanceof Error?t.message:String(t)}import wr from"path";import{appendFileSync as nm,mkdirSync as rm}from"fs";import{dirname as om}from"path";import ta from"@anthropic-ai/sdk";var Uo="claude-code-20250219,oauth-2025-04-20,interleaved-thinking-2025-05-14",ol="effort-2025-11-24",sl="claude-cli/1.0.0 (external, cli)",il="x-anthropic-billing-header: cc_version=1.0.0.test; cc_entrypoint=cli; cch=00000;";function Nt(t){return t.startsWith("sk-ant-oat01-")?"oauth":"api-key"}function Un(t,e,n){let r=e==="oauth"?{authToken:t}:{apiKey:t};return typeof n=="string"&&n.length>0?{...r,baseURL:n}:r}function _e(t,e,n,r){return t!=="oauth"?{}:{"anthropic-beta":r?`${Uo},${ol}`:Uo,"x-app":"cli","User-Agent":sl,"X-Claude-Code-Session-Id":e,"x-client-request-id":n}}function jo(t){return t!=="oauth"?null:[{type:"text",text:il}]}import{randomUUID as Zi}from"node:crypto";function $t(t){if(typeof t?.baseUrl=="string"&&t.baseUrl.length>0)return!1;let e=process.env.AFK_DISABLE_PROMPT_CACHE;if(e===void 0||e.length===0)return!0;let n=e.toLowerCase();return!(n==="1"||n==="true"||n==="yes"||n==="on")}function Ut(){let t=process.env.AFK_PROMPT_CACHE_TTL;return t==="5m"?"5m":"1h"}function Ho(t,e){if(t.length===0)return t;let n=t[t.length-1],r=Wo(n,e);return r===n?t:[...t.slice(0,-1),r]}function Bo(t,e){if(t.length===0)return t;let n=t[t.length-1],r=al(n,e);return r===n?t:[...t.slice(0,-1),r]}function al(t,e){let n=t.content;if(typeof n=="string")return n.length===0?t:{...t,content:[{type:"text",text:n,cache_control:{type:"ephemeral",ttl:e}}]};if(!Array.isArray(n)||n.length===0)return t;let r=n[n.length-1],o=Wo(r,e);return o===r?t:{...t,content:[...n.slice(0,-1),o]}}function Wo(t,e){return t.type==="thinking"||t.type==="redacted_thinking"?t:{...t,cache_control:{type:"ephemeral",ttl:e}}}var cl=["## Plan mode is active","","Write-class tools (`write_file`, `edit_file`, write-intent `bash`) are refused at the hook layer.","The user has asked you to plan, not yet to act. Treat this turn as planning work.","","Traverse the shape that matches the work \u2014 skip steps the terrain already covers, do not skip steps the terrain hides:",""," unknown field \u2192 ground the current terrain \u2192 gather missing codebase context \u2192"," research missing external context \u2192 reveal chaos / constraints / risks \u2192"," name the failure geometry \u2192 form a candidate plan \u2192 apply adversarial pressure \u2192 embody the final plan","","Reach for these skills (invoke via the `skill` tool) when the cost of skipping exceeds the cost of dispatching:"," - `ground-state` \u2014 survey git, infra, memory before non-trivial work"," - `gather` \u2014 parallel context-gathering for a code area"," - `research` \u2014 parallel external + local context for the current task"," - `devils-advocate` \u2014 generate alternatives and rank them before committing"," - `shadow-verify` \u2014 independently re-derive load-bearing claims","","Do not declare readiness silently. When the plan is ready, state: chosen approach, risks named, and alternatives considered. The user will exit plan mode (`/plan off`) when satisfied."].join(`
|
|
160
160
|
`);function Go(t){return t!=="plan"?null:{type:"text",text:cl}}import{z as U}from"zod";import{mkdir as cs,appendFile as ls}from"fs/promises";import{join as Kn}from"path";var Ko={"audit-fit":{"01-skill-inspector.md":`# Skill Inspector
|
|
161
161
|
|
|
162
162
|
You are an inspector auditing skills for correct type categorization. Skills come from two sources:
|
|
@@ -1128,16 +1128,16 @@ Unless the dispatcher specifies a different schema, return:
|
|
|
1128
1128
|
**\`boundary_flag\` is required.** If nothing applies, emit \`"none"\` \u2014 do not omit the field. Treat missing as \`"none"\` is acceptable on the orchestrator side, but emit the field explicitly so downstream synthesizers and validators do not see \`null\`.
|
|
1129
1129
|
|
|
1130
1130
|
If \`scope_check\` flags implementation (non-git), the orchestrator should dispatch a different sub-agent type for follow-up. Do not re-dispatch the same task through \`research-agent\`.
|
|
1131
|
-
`,sourcePath:"agent-framework-private/agents/research-agent.md",allowedTools:["Read","Grep","Glob","WebFetch","WebSearch"],description:"Read-only sub-agent for research, validation, verification, and codebase inspection. Mechanically locked to Read, Grep, Glob, WebFetch, WebSearch \u2014 cannot Edit, Write, Bash, commit, or push. Delegates git queries to `git-investigator`. Use when the dispatched task is findings-only."};import{existsSync as ke,readdirSync as Rl,readFileSync as Pl}from"fs";import{join as ue}from"path";import{existsSync as Wn,readFileSync as xl,readdirSync as El,statSync as Tl}from"fs";import{join as st,resolve as ts}from"path";import{existsSync as vl,mkdirSync as eb,readFileSync as Sl,renameSync as tb,writeFileSync as nb,unlinkSync as rb}from"fs";function es(t=ht()){if(!vl(t))return zt();try{let e=Sl(t,"utf8"),n=JSON.parse(e);if(!n||typeof n!="object")return zt();let r=n,o=r.plugins&&typeof r.plugins=="object"?r.plugins:{};if(r.version===1)return{version:2,plugins:o,marketplaces:{}};if(r.version===2){let s=r.marketplaces&&typeof r.marketplaces=="object"?r.marketplaces:{};return{version:2,plugins:o,marketplaces:s}}return zt()}catch{return zt()}}function zt(){return{version:2,plugins:{},marketplaces:{}}}var _l=5,ns="cache",ot;function de(t=Fe()){ot||(ot=new Map);let e=ot.get(t);if(e)return[...e];if(!Wn(t))return ot.set(t,[]),[];let n=t===Fe()?ht():st(t,".index.json"),r=es(n),o=[];return rs(t,t,0,o,new Set,r.plugins),ot.set(t,o),[...o]}function rs(t,e,n,r,o,s){if(n>_l||o.has(e))return;if(o.add(e),Wn(st(e,".claude-plugin","plugin.json"))){let a=Gn(t,e);if(a===null){r.push({type:"local",path:e});return}if(a.layout==="cache"){let l=s[a.key];if(!l||l.enabled===!1)return;r.push({type:"local",path:e});return}let c=s[a.key];if(c&&c.enabled===!1)return;r.push({type:"local",path:e});return}let i;try{i=El(e)}catch{return}for(let a of i){if(a.startsWith("."))continue;let c=st(e,a),l;try{l=Tl(c)}catch{continue}l.isDirectory()&&rs(t,c,n+1,r,o,s)}}function Gn(t,e){if(!e.startsWith(t))return null;let n=e.slice(t.length).replace(/^\/+/,"");if(!n)return null;let r=n.split("/").filter(s=>s.length>0);if(r.length===0)return null;if(r[0]===ns&&r.length>=3){let s=r[1];if(s){let i=st(t,ns,s),c=Al(i,e)??r[2];if(c)return{layout:"cache",key:`${s}:${c}`}}}let o=r[0];return o?{layout:"flat",key:o}:null}function Al(t,e){let n=st(t,".claude-plugin","marketplace.json");if(!Wn(n))return null;let r;try{r=JSON.parse(xl(n,"utf8"))}catch{return null}if(!r||typeof r!="object")return null;let o=r.plugins;if(!Array.isArray(o))return null;let s=ts(e);for(let i of o){if(!i||typeof i!="object")continue;let a=i;if(!(typeof a.name!="string"||typeof a.source!="string")&&!(!a.source.startsWith("./")&&!a.source.startsWith("../"))&&ts(t,a.source)===s)return a.name}return null}var os=["command","agent"];function ss(t=J()){let e=[],n=ue(t,"skills");if(ke(n))for(let r of Jt(n)){let o=ue(n,r,"SKILL.md");ke(o)&&e.push({path:o,type:"skill",source:"user"})}for(let r of os){let o=ue(t,`${r}s`);if(ke(o))for(let s of Jt(o))s.endsWith(".md")&&e.push({path:ue(o,s),type:r,source:"user"})}return e}function is(t=Fe()){if(!ke(t))return[];let e=[],n=de(t);for(let r of n){let s=Gn(t,r.path)?.key,i=ue(r.path,"skills");if(ke(i))for(let a of Jt(i)){let c=ue(i,a,"SKILL.md");if(!ke(c))continue;let l={path:c,type:"skill",source:"plugin"};s&&(l.plugin_key=s),e.push(l)}for(let a of os){let c=ue(r.path,`${a}s`);if(ke(c))for(let l of Jt(c)){if(!l.endsWith(".md"))continue;let d={path:ue(c,l),type:a,source:"plugin"};s&&(d.plugin_key=s),e.push(d)}}}return e}function as(t=ue(J(),"settings.json")){if(!ke(t))return[];try{let e=Pl(t,"utf8"),r=JSON.parse(e).hooks;if(!r||typeof r!="object")return[];let o=[];for(let[s,i]of Object.entries(r))if(Array.isArray(i))for(let a=0;a<i.length;a++)o.push({event:s,index:a,raw:i[a]});return o}catch{return[]}}function Jt(t){try{return Rl(t).filter(e=>!e.startsWith("."))}catch{return[]}}var us=U.object({path:U.string(),type:U.enum(["skill","command","agent","hook"]),source:U.enum(["user","plugin"]),plugin_key:U.string().optional(),verdict:U.enum(["correct","misfit","outlier"]),recommended_type:U.string(),rationale:U.string(),confidence:U.enum(["high","med","low"])}),ds=U.record(U.string(),U.record(U.string(),U.number())),_b=U.object({inventory:U.object({user:ds,plugin:ds}),misfits:U.array(us),briefs_written:U.number(),total_artifacts:U.number()}),Il=U.object({writeBriefs:U.boolean().optional(),scope:U.enum(["user","plugin","all"]).optional()}),Cl=["skill","command","agent"],ps=["skill","command","agent","hook"];function Ml(t){return{runUserDiscovery:t!=="plugin",runPluginDiscovery:t!=="user",runHookInspector:t!=="plugin"}}function
|
|
1131
|
+
`,sourcePath:"agent-framework-private/agents/research-agent.md",allowedTools:["Read","Grep","Glob","WebFetch","WebSearch"],description:"Read-only sub-agent for research, validation, verification, and codebase inspection. Mechanically locked to Read, Grep, Glob, WebFetch, WebSearch \u2014 cannot Edit, Write, Bash, commit, or push. Delegates git queries to `git-investigator`. Use when the dispatched task is findings-only."};import{existsSync as ke,readdirSync as Rl,readFileSync as Pl}from"fs";import{join as ue}from"path";import{existsSync as Wn,readFileSync as xl,readdirSync as El,statSync as Tl}from"fs";import{join as st,resolve as ts}from"path";import{existsSync as vl,mkdirSync as eb,readFileSync as Sl,renameSync as tb,writeFileSync as nb,unlinkSync as rb}from"fs";function es(t=ht()){if(!vl(t))return zt();try{let e=Sl(t,"utf8"),n=JSON.parse(e);if(!n||typeof n!="object")return zt();let r=n,o=r.plugins&&typeof r.plugins=="object"?r.plugins:{};if(r.version===1)return{version:2,plugins:o,marketplaces:{}};if(r.version===2){let s=r.marketplaces&&typeof r.marketplaces=="object"?r.marketplaces:{};return{version:2,plugins:o,marketplaces:s}}return zt()}catch{return zt()}}function zt(){return{version:2,plugins:{},marketplaces:{}}}var _l=5,ns="cache",ot;function de(t=Fe()){ot||(ot=new Map);let e=ot.get(t);if(e)return[...e];if(!Wn(t))return ot.set(t,[]),[];let n=t===Fe()?ht():st(t,".index.json"),r=es(n),o=[];return rs(t,t,0,o,new Set,r.plugins),ot.set(t,o),[...o]}function rs(t,e,n,r,o,s){if(n>_l||o.has(e))return;if(o.add(e),Wn(st(e,".claude-plugin","plugin.json"))){let a=Gn(t,e);if(a===null){r.push({type:"local",path:e});return}if(a.layout==="cache"){let l=s[a.key];if(!l||l.enabled===!1)return;r.push({type:"local",path:e});return}let c=s[a.key];if(c&&c.enabled===!1)return;r.push({type:"local",path:e});return}let i;try{i=El(e)}catch{return}for(let a of i){if(a.startsWith("."))continue;let c=st(e,a),l;try{l=Tl(c)}catch{continue}l.isDirectory()&&rs(t,c,n+1,r,o,s)}}function Gn(t,e){if(!e.startsWith(t))return null;let n=e.slice(t.length).replace(/^\/+/,"");if(!n)return null;let r=n.split("/").filter(s=>s.length>0);if(r.length===0)return null;if(r[0]===ns&&r.length>=3){let s=r[1];if(s){let i=st(t,ns,s),c=Al(i,e)??r[2];if(c)return{layout:"cache",key:`${s}:${c}`}}}let o=r[0];return o?{layout:"flat",key:o}:null}function Al(t,e){let n=st(t,".claude-plugin","marketplace.json");if(!Wn(n))return null;let r;try{r=JSON.parse(xl(n,"utf8"))}catch{return null}if(!r||typeof r!="object")return null;let o=r.plugins;if(!Array.isArray(o))return null;let s=ts(e);for(let i of o){if(!i||typeof i!="object")continue;let a=i;if(!(typeof a.name!="string"||typeof a.source!="string")&&!(!a.source.startsWith("./")&&!a.source.startsWith("../"))&&ts(t,a.source)===s)return a.name}return null}var os=["command","agent"];function ss(t=J()){let e=[],n=ue(t,"skills");if(ke(n))for(let r of Jt(n)){let o=ue(n,r,"SKILL.md");ke(o)&&e.push({path:o,type:"skill",source:"user"})}for(let r of os){let o=ue(t,`${r}s`);if(ke(o))for(let s of Jt(o))s.endsWith(".md")&&e.push({path:ue(o,s),type:r,source:"user"})}return e}function is(t=Fe()){if(!ke(t))return[];let e=[],n=de(t);for(let r of n){let s=Gn(t,r.path)?.key,i=ue(r.path,"skills");if(ke(i))for(let a of Jt(i)){let c=ue(i,a,"SKILL.md");if(!ke(c))continue;let l={path:c,type:"skill",source:"plugin"};s&&(l.plugin_key=s),e.push(l)}for(let a of os){let c=ue(r.path,`${a}s`);if(ke(c))for(let l of Jt(c)){if(!l.endsWith(".md"))continue;let d={path:ue(c,l),type:a,source:"plugin"};s&&(d.plugin_key=s),e.push(d)}}}return e}function as(t=ue(J(),"settings.json")){if(!ke(t))return[];try{let e=Pl(t,"utf8"),r=JSON.parse(e).hooks;if(!r||typeof r!="object")return[];let o=[];for(let[s,i]of Object.entries(r))if(Array.isArray(i))for(let a=0;a<i.length;a++)o.push({event:s,index:a,raw:i[a]});return o}catch{return[]}}function Jt(t){try{return Rl(t).filter(e=>!e.startsWith("."))}catch{return[]}}var us=U.object({path:U.string(),type:U.enum(["skill","command","agent","hook"]),source:U.enum(["user","plugin"]),plugin_key:U.string().optional(),verdict:U.enum(["correct","misfit","outlier"]),recommended_type:U.string(),rationale:U.string(),confidence:U.enum(["high","med","low"])}),ds=U.record(U.string(),U.record(U.string(),U.number())),_b=U.object({inventory:U.object({user:ds,plugin:ds}),misfits:U.array(us),briefs_written:U.number(),total_artifacts:U.number()}),Il=U.object({writeBriefs:U.boolean().optional(),scope:U.enum(["user","plugin","all"]).optional()}),Cl=["skill","command","agent"],ps=["skill","command","agent","hook"];function Ml(t){return{runUserDiscovery:t!=="plugin",runPluginDiscovery:t!=="user",runHookInspector:t!=="plugin"}}function Ol(t){let e=()=>{let s={};for(let i of ps)s[i]={correct:0,misfit:0,outlier:0};return s},n={user:e(),plugin:e()};for(let s of t)n[s.source][s.type][s.verdict]+=1;let r={high:0,med:1,low:2},o=t.filter(s=>s.verdict==="misfit").slice().sort((s,i)=>r[s.confidence]-r[i.confidence]);return{inventory:n,misfits:o}}function Dl(t){return t.verdict==="misfit"&&t.confidence==="high"&&t.source==="user"}function Fl(t){let e=t.filter(o=>o.source==="user"),n=t.filter(o=>o.source==="plugin"),r=["","## Discovered artifacts (audit only these)",""];if(r.push('### User-scope artifacts (set `"source": "user"`, omit `plugin_key`)'),e.length===0)r.push("(none discovered)");else for(let o of e)r.push(`- ${o.path}`);if(r.push(""),r.push('### Plugin-scope artifacts (set `"source": "plugin"`, copy `plugin_key` from each entry)'),n.length===0)r.push("(none discovered)");else for(let o of n){let s=o.plugin_key??"<unknown>";r.push(`- ${o.path} (plugin_key: ${s})`)}return r.join(`
|
|
1132
1132
|
`)}function Ll(t,e){let n=["","## Discovered hooks (audit only these)",""];if(n.push(`Settings file (use this absolute path verbatim in each verdict's \`path\` field): \`${t}\``),n.push(""),e.length===0)return n.push("(no hooks discovered)"),n.join(`
|
|
1133
1133
|
`);for(let r of e){let o=`${r.event}-${r.index}`;n.push(`### Hook \`${o}\``),n.push(""),n.push("```json"),n.push(JSON.stringify(r.raw,null,2)),n.push("```"),n.push("")}return n.join(`
|
|
1134
1134
|
`)}function Nl(t,e){if(!e)return{kind:"failure",message:`${t}: no result`};if(e.schemaError)return{kind:"failure",message:`${t}: schema mismatch \u2014 ${e.schemaError.message}`};if(e.status!=="succeeded"){let n=e.error?` \u2014 ${e.error.message}`:"";return{kind:"failure",message:`${t}: ${e.status}${n}`}}return e.output?{kind:"success",output:e.output}:{kind:"failure",message:`${t}: no output`}}async function $l(t,e,n){let r=n?.apiKey,o=n?.callId,s=typeof t=="object"&&t!==null?t:{},i=Il.parse(s),a=i.writeBriefs??!0,c=i.scope??"all",l=Ml(c);if(!e?.sessionId)throw new Error("audit-fit requires a parent session with sessionId");let d=e.sessionId,u=$("audit-fit"),p={skill:u["01-skill-inspector.md"],command:u["02-command-inspector.md"],agent:u["03-agent-inspector.md"],hook:u["04-hook-inspector.md"]};for(let v of ps)if(!p[v])throw new Error(`audit-fit skill missing inspector prompt for ${v}`);let f=l.runUserDiscovery?ss():[],g=l.runPluginDiscovery?is():[],m={skill:[],command:[],agent:[]};for(let v of[...f,...g])m[v.type].push(v);let w=new P({apiKey:r}),b=()=>async v=>X.allowedTools.includes(v)?{behavior:"allow"}:{behavior:"deny",message:`Tool ${v} not allowed for audit-fit inspectors. Allowed tools: ${X.allowedTools.join(", ")}`},h=[];for(let v of Cl){let E=m[v];if(E.length===0)continue;let M=p[v];M&&h.push({type:v,prompt:`${M}
|
|
1135
1135
|
${Fl(E)}`,artifacts:E,runPrompt:`Inspect every ${v} listed in the artifact section.`})}if(l.runHookInspector){let v=p.hook;if(v){let E=Kn(J(),"settings.json"),M=as(E);h.push({type:"hook",prompt:`${v}
|
|
1136
|
-
${Ll(E,M)}`,artifacts:[],runPrompt:`Inspect every hook listed in the Discovered hooks section. Settings file: ${E}.`})}}let y=[];if(h.length>0){let v=await Promise.all(h.map(
|
|
1136
|
+
${Ll(E,M)}`,artifacts:[],runPrompt:`Inspect every hook listed in the Discovered hooks section. Settings file: ${E}.`})}}let y=[];if(h.length>0){let v=await Promise.all(h.map(O=>w.forkSubagent({parent:{sessionId:d},config:{model:"sonnet",systemPrompt:`${X.systemPrompt}
|
|
1137
1137
|
|
|
1138
|
-
${
|
|
1138
|
+
${O.prompt}`,canUseTool:b()},idPrefix:`inspector-${O.type}`,outputSchema:U.array(us),...o?{parentId:o}:{}}))),E=await qt(h.map((O,G)=>{let L=v[G];if(!L)throw new Error(`audit-fit: missing handle for ${O.type} inspector`);return{handle:L,prompt:O.runPrompt}}),{failFast:!1}),M=[];for(let O=0;O<E.length;O++){let G=E[O],L=h[O];if(!L)continue;let z=Nl(L.type,G);if(z.kind==="failure"){M.push(z.message);continue}let re=new Map;for(let W of L.artifacts)re.set(W.path,W.source);for(let W of z.output){if(L.type==="hook"){if(W.source!=="user"){M.push(`${L.type}: hook verdict has source=${W.source} (must be 'user')`);continue}}else{let D=re.get(W.path);if(D===void 0){M.push(`${L.type}: verdict for unknown path ${W.path} (not in discovered list)`);continue}if(W.source!==D){M.push(`${L.type}: verdict source mismatch for ${W.path} (expected ${D}, got ${W.source})`);continue}}y.push(W)}}if(M.length>0){let O=M.map(G=>` - ${G}`).join(`
|
|
1139
1139
|
`);throw new Error(`audit-fit: ${M.length} inspector failure(s):
|
|
1140
|
-
${
|
|
1140
|
+
${O}`)}}let{inventory:k,misfits:_}=Ol(y),I=0;if(a){let v=De();await cs(v,{recursive:!0});for(let E of _.filter(Dl)){let M=E.path.replace(/[^a-z0-9]+/gi,"-").toLowerCase().slice(0,30),O=Kn(v,`audit-fit-${M}.md`),G=`---
|
|
1141
1141
|
theme: audit-fit
|
|
1142
1142
|
session_count: 1
|
|
1143
1143
|
---
|
|
@@ -1159,8 +1159,8 @@ ${E.rationale}
|
|
|
1159
1159
|
|
|
1160
1160
|
---
|
|
1161
1161
|
Generated by audit-fit on ${new Date().toISOString().split(".")[0]}Z
|
|
1162
|
-
`;await ls(
|
|
1163
|
-
`),{inventory:k,misfits:_,briefs_written:I,total_artifacts:y.length}}var Ul={name:"audit-fit",description:"Audit ~/.afk artifacts (skills, commands, agents, hooks) for correct type categorization. Walks user-scope dirs (~/.afk/{skills,commands,agents}/) and every plugin installed under ~/.afk/plugins/ (flat and marketplace-cache layouts), plus ~/.afk/settings.json for hooks. Dispatches per-type inspectors in parallel, applies decision heuristics (progressive-disclosure value, isolation need, deterministic vs. reasoning), flags misfits. Generates migration briefs only for user-scope misfits (plugin misfits are inventory-only \u2014 refactoring vendored plugin code is the maintainer's job). Optional `scope` input filters to `user`, `plugin`, or `all` (default). Use for inventory audits after bulk authoring, imports, or periodic hygiene.",handler:$l,argumentHint:"[--write-briefs]",whenToUse:"When the user wants ~/.afk artifacts (skills, commands, agents, hooks) audited for correct type categorization.",flags:["--write-briefs"]};Y(Ul);import{z as T}from"zod";import{execFile as Wl}from"node:child_process";import{promisify as Gl}from"node:util";import{tmpdir as Kl}from"node:os";import{join as ms}from"node:path";function fs(t){return t.confidence<.5?{verify:!0,reason:`low confidence (${t.confidence.toFixed(2)} < ${.5})`}:t.boundary_flag&&t.boundary_flag.length>0?{verify:!0,reason:`boundary flag set: ${t.boundary_flag}`}:t.coverage_gaps&&t.coverage_gaps.length>0?{verify:!0,reason:`coverage gap${t.coverage_gaps.length===1?"":"s"}: ${t.coverage_gaps.length} unresolved`}:{verify:!1,reason:`confidence ${t.confidence.toFixed(2)} with no gaps or boundary`}}import{fileURLToPath as jl}from"node:url";import{dirname as Hl}from"node:path";var Bl=jl(import.meta.url),Mb=Hl(Bl),qn={name:"git-investigator",systemPrompt:'---\nname: git-investigator\ndescription: Read-only git specialist. Dispatched by research-agent (or any research-shaped caller) when a finding requires git history, reflog, diff, blame, branch/remote state, or merge-base analysis. Runs git commands only \u2014 no mutations, no shell escapes.\nmodel: sonnet\ntools: Bash, Read, Grep, Glob\n---\n\nYou are `git-investigator`, a leaf sub-agent specialized for read-only git queries.\n\nYou have Bash, Read, Grep, and Glob. You do not dispatch other sub-agents. You do not Edit or Write. Your Bash surface is restricted **by this prompt** to `git ...` invocations and benign output-shaping pipes.\n\n## Allowed commands\n\nRead-only git only:\n\n- `git status`, `git log`, `git diff`, `git show`\n- `git rev-parse`, `git rev-list`, `git reflog`\n- `git branch -v / -vv / -a` (list only)\n- `git remote -v`, `git ls-remote`\n- `git ls-files`, `git blame`\n- `git merge-base`, `git for-each-ref`, `git describe`\n- `git cat-file`, `git shortlog`\n- `git tag` (list/show only)\n- `git stash list`, `git stash show`\n- `git config --get`, `git config --get-all`, `git config --list`\n- `git worktree list` (read only)\n\nOutput-shaping pipes are fine: `| head`, `| tail`, `| wc`, `| grep`, `| jq`, `| awk \'NR==...\'` (for formatting only \u2014 no mutations).\n\n## Forbidden\n\nAnything that mutates repo or working tree state:\n\n- `commit`, `push`, `pull`, `fetch --prune`\n- `reset`, `revert`, `rebase`, `merge`, `cherry-pick`\n- `checkout` (except `checkout -- <path>` file-restore, and even that is mutation \u2014 avoid it, just report the need)\n- `restore`, `switch`\n- `branch -d / -D / -m / -M`, `branch <new>`\n- `stash push / pop / drop / apply / clear`\n- `tag -d`, creating a new tag\n- `remote add / remove / set-url`\n- `config --set`, `config --unset`\n- `gc`, `fsck`, `prune`, `reflog delete`, `reflog expire`\n- `filter-branch`, `filter-repo`\n- `worktree add / remove / move`\n- `hooks install`, `submodule add / update`\n- Any non-`git` command that mutates: `rm`, `mv`, `cp` (writes), `sed -i`, `> file`, `>> file`, `tee`, `curl`, `wget`, `pip install`, shell builtins that change state.\n\nIf the caller asks for any of the above, do not run it. Return `scope_check: "requires mutation: <reason>"` and stop.\n\n## Behavior\n\n- Run the minimum set of commands needed. Prefer `git log -n 5 --oneline -- <path>` over `git log -- <path>` when a count is fine.\n- Cite concrete evidence: commit SHAs (short form OK), ref names, `path:line` references from blame, diff hunks trimmed to the relevant range.\n- Use `Read`/`Grep`/`Glob` for follow-up inspection of files the git output identifies (e.g., `git show SHA:path | head` then `Read` the current file to diff mentally).\n- Do not speculate beyond what the commands show. If a question needs history the commands don\'t surface (deleted-file recovery, ancient reflog that has expired), say so in `caveats`.\n- Keep output compact \u2014 dispatchers merge your findings into a larger response. No preamble, no ceremony.\n\n## Return shape\n\n```\n{\n "findings": "<summary of what the git data shows>",\n "evidence": ["<SHA>", "<ref>", "<path:line>", ...],\n "git_commands_run": ["git log ...", "git diff ...", ...],\n "caveats": "<gaps, ambiguity, or \'none\'>",\n "scope_check": "pure git research" | "requires mutation: <reason>"\n}\n```\n\nBegin your response with the first schema field. No preamble.\n',sourcePath:"agent-framework-private/agents/git-investigator.md",allowedTools:["Bash","Read","Grep","Glob"],description:"Read-only git specialist. Dispatched by research-agent (or any research-shaped caller) when a finding requires git history, reflog, diff, blame, branch/remote state, or merge-base analysis. Runs git commands only \u2014 no mutations, no shell escapes.",model:"sonnet"};function zn(t){let e={description:t.description,prompt:t.systemPrompt};return t.allowedTools&&(e.tools=[...t.allowedTools]),t.model&&(e.model=t.model),e}var Vt=Gl(Wl),ys=T.object({id:T.string(),claim:T.string(),confidence:T.number().min(0).max(1),evidence_sources:T.array(T.string()),location:T.string().optional(),proposed_fix:T.string().optional(),coverage_gaps:T.array(T.string()).optional(),boundary_flag:T.string().optional()}),ql=T.object({hypothesis_id:T.string(),claim:T.string(),verdict:T.enum(["VERIFIED","REFUTED","INCONCLUSIVE"]),evidence:T.string(),gate_reason:T.string()}),bs=T.object({hypothesis_id:T.string(),reproducer_passed:T.boolean(),regressions:T.array(T.string()),confidence:T.number().min(0).max(1),verification_log:T.string()}),zl=T.enum(["crash","regression","logic-error","flaky","environment","unknown"]),Jl=T.object({failure_type:zl,error_signature:T.string(),affected_area:T.string()}),Vl=T.enum(["clear_winner","multiple_plausible","dissent","all_inconclusive","no_hypotheses"]),Vb=T.object({reproducer:T.string().optional(),triage:Jl.optional(),hypotheses:T.array(ys),premise_verifications:T.array(ql).optional(),winner:T.object({hypothesis_id:T.string(),verification_log:T.string(),proposed_fix:T.string()}).optional(),verification_results:T.array(bs).optional(),outcome:Vl.optional(),recommended_next_skill:T.enum(["spec"]).optional()});async function Yl(t,e){let n=t.map(c=>({hypothesis:c,decision:fs(c)})).filter(c=>c.decision.verify);if(n.length===0)return{premise_verifications:[],hypotheses_to_test:t};let r=[],o;try{r=await e(n.map(c=>c.hypothesis.claim))}catch(c){o=c instanceof Error?c.message:String(c)}let s=n.map((c,l)=>{let d=r[l];return o!==void 0?{hypothesis_id:c.hypothesis.id,claim:c.hypothesis.claim,verdict:"INCONCLUSIVE",evidence:`shadow-verify dispatch failed: ${o}`,gate_reason:c.decision.reason}:d?{hypothesis_id:c.hypothesis.id,claim:c.hypothesis.claim,verdict:d.verdict,evidence:d.evidence,gate_reason:c.decision.reason}:{hypothesis_id:c.hypothesis.id,claim:c.hypothesis.claim,verdict:"INCONCLUSIVE",evidence:"no verifier result for this claim",gate_reason:c.decision.reason}}),i=new Set(s.filter(c=>c.verdict==="REFUTED").map(c=>c.hypothesis_id)),a=i.size===0?t:t.filter(c=>!i.has(c.id));return{premise_verifications:s,hypotheses_to_test:a}}async function Xl(t,e,n){let r=n?.apiKey,o=(()=>{if(typeof t=="string")return{failure:t,repoPath:process.cwd(),context:"",maxHypotheses:4};if(typeof t=="object"&&t!==null){let
|
|
1162
|
+
`;await ls(O,G),I++}}let S=xe();await cs(S,{recursive:!0});let x=v=>{let E=0;for(let M of Object.values(v))for(let O of Object.values(M))E+=O;return E},A=v=>{let E=k.user[v]??{},M=k.plugin[v]??{},O=G=>Object.values(G).reduce((L,z)=>L+z,0);return O(E)+O(M)},R={timestamp:new Date().toISOString(),surface:"afk",scope:c,total_artifacts:y.length,misfits_count:_.length,briefs_written:I,by_source:{user:x(k.user),plugin:x(k.plugin)},by_type:{skill:A("skill"),command:A("command"),agent:A("agent"),hook:A("hook")}},F=Kn(S,"audit-fit-telemetry.jsonl");return await ls(F,JSON.stringify(R)+`
|
|
1163
|
+
`),{inventory:k,misfits:_,briefs_written:I,total_artifacts:y.length}}var Ul={name:"audit-fit",description:"Audit ~/.afk artifacts (skills, commands, agents, hooks) for correct type categorization. Walks user-scope dirs (~/.afk/{skills,commands,agents}/) and every plugin installed under ~/.afk/plugins/ (flat and marketplace-cache layouts), plus ~/.afk/settings.json for hooks. Dispatches per-type inspectors in parallel, applies decision heuristics (progressive-disclosure value, isolation need, deterministic vs. reasoning), flags misfits. Generates migration briefs only for user-scope misfits (plugin misfits are inventory-only \u2014 refactoring vendored plugin code is the maintainer's job). Optional `scope` input filters to `user`, `plugin`, or `all` (default). Use for inventory audits after bulk authoring, imports, or periodic hygiene.",handler:$l,argumentHint:"[--write-briefs]",whenToUse:"When the user wants ~/.afk artifacts (skills, commands, agents, hooks) audited for correct type categorization.",flags:["--write-briefs"]};Y(Ul);import{z as T}from"zod";import{execFile as Wl}from"node:child_process";import{promisify as Gl}from"node:util";import{tmpdir as Kl}from"node:os";import{join as ms}from"node:path";function fs(t){return t.confidence<.5?{verify:!0,reason:`low confidence (${t.confidence.toFixed(2)} < ${.5})`}:t.boundary_flag&&t.boundary_flag.length>0?{verify:!0,reason:`boundary flag set: ${t.boundary_flag}`}:t.coverage_gaps&&t.coverage_gaps.length>0?{verify:!0,reason:`coverage gap${t.coverage_gaps.length===1?"":"s"}: ${t.coverage_gaps.length} unresolved`}:{verify:!1,reason:`confidence ${t.confidence.toFixed(2)} with no gaps or boundary`}}import{fileURLToPath as jl}from"node:url";import{dirname as Hl}from"node:path";var Bl=jl(import.meta.url),Mb=Hl(Bl),qn={name:"git-investigator",systemPrompt:'---\nname: git-investigator\ndescription: Read-only git specialist. Dispatched by research-agent (or any research-shaped caller) when a finding requires git history, reflog, diff, blame, branch/remote state, or merge-base analysis. Runs git commands only \u2014 no mutations, no shell escapes.\nmodel: sonnet\ntools: Bash, Read, Grep, Glob\n---\n\nYou are `git-investigator`, a leaf sub-agent specialized for read-only git queries.\n\nYou have Bash, Read, Grep, and Glob. You do not dispatch other sub-agents. You do not Edit or Write. Your Bash surface is restricted **by this prompt** to `git ...` invocations and benign output-shaping pipes.\n\n## Allowed commands\n\nRead-only git only:\n\n- `git status`, `git log`, `git diff`, `git show`\n- `git rev-parse`, `git rev-list`, `git reflog`\n- `git branch -v / -vv / -a` (list only)\n- `git remote -v`, `git ls-remote`\n- `git ls-files`, `git blame`\n- `git merge-base`, `git for-each-ref`, `git describe`\n- `git cat-file`, `git shortlog`\n- `git tag` (list/show only)\n- `git stash list`, `git stash show`\n- `git config --get`, `git config --get-all`, `git config --list`\n- `git worktree list` (read only)\n\nOutput-shaping pipes are fine: `| head`, `| tail`, `| wc`, `| grep`, `| jq`, `| awk \'NR==...\'` (for formatting only \u2014 no mutations).\n\n## Forbidden\n\nAnything that mutates repo or working tree state:\n\n- `commit`, `push`, `pull`, `fetch --prune`\n- `reset`, `revert`, `rebase`, `merge`, `cherry-pick`\n- `checkout` (except `checkout -- <path>` file-restore, and even that is mutation \u2014 avoid it, just report the need)\n- `restore`, `switch`\n- `branch -d / -D / -m / -M`, `branch <new>`\n- `stash push / pop / drop / apply / clear`\n- `tag -d`, creating a new tag\n- `remote add / remove / set-url`\n- `config --set`, `config --unset`\n- `gc`, `fsck`, `prune`, `reflog delete`, `reflog expire`\n- `filter-branch`, `filter-repo`\n- `worktree add / remove / move`\n- `hooks install`, `submodule add / update`\n- Any non-`git` command that mutates: `rm`, `mv`, `cp` (writes), `sed -i`, `> file`, `>> file`, `tee`, `curl`, `wget`, `pip install`, shell builtins that change state.\n\nIf the caller asks for any of the above, do not run it. Return `scope_check: "requires mutation: <reason>"` and stop.\n\n## Behavior\n\n- Run the minimum set of commands needed. Prefer `git log -n 5 --oneline -- <path>` over `git log -- <path>` when a count is fine.\n- Cite concrete evidence: commit SHAs (short form OK), ref names, `path:line` references from blame, diff hunks trimmed to the relevant range.\n- Use `Read`/`Grep`/`Glob` for follow-up inspection of files the git output identifies (e.g., `git show SHA:path | head` then `Read` the current file to diff mentally).\n- Do not speculate beyond what the commands show. If a question needs history the commands don\'t surface (deleted-file recovery, ancient reflog that has expired), say so in `caveats`.\n- Keep output compact \u2014 dispatchers merge your findings into a larger response. No preamble, no ceremony.\n\n## Return shape\n\n```\n{\n "findings": "<summary of what the git data shows>",\n "evidence": ["<SHA>", "<ref>", "<path:line>", ...],\n "git_commands_run": ["git log ...", "git diff ...", ...],\n "caveats": "<gaps, ambiguity, or \'none\'>",\n "scope_check": "pure git research" | "requires mutation: <reason>"\n}\n```\n\nBegin your response with the first schema field. No preamble.\n',sourcePath:"agent-framework-private/agents/git-investigator.md",allowedTools:["Bash","Read","Grep","Glob"],description:"Read-only git specialist. Dispatched by research-agent (or any research-shaped caller) when a finding requires git history, reflog, diff, blame, branch/remote state, or merge-base analysis. Runs git commands only \u2014 no mutations, no shell escapes.",model:"sonnet"};function zn(t){let e={description:t.description,prompt:t.systemPrompt};return t.allowedTools&&(e.tools=[...t.allowedTools]),t.model&&(e.model=t.model),e}var Vt=Gl(Wl),ys=T.object({id:T.string(),claim:T.string(),confidence:T.number().min(0).max(1),evidence_sources:T.array(T.string()),location:T.string().optional(),proposed_fix:T.string().optional(),coverage_gaps:T.array(T.string()).optional(),boundary_flag:T.string().optional()}),ql=T.object({hypothesis_id:T.string(),claim:T.string(),verdict:T.enum(["VERIFIED","REFUTED","INCONCLUSIVE"]),evidence:T.string(),gate_reason:T.string()}),bs=T.object({hypothesis_id:T.string(),reproducer_passed:T.boolean(),regressions:T.array(T.string()),confidence:T.number().min(0).max(1),verification_log:T.string()}),zl=T.enum(["crash","regression","logic-error","flaky","environment","unknown"]),Jl=T.object({failure_type:zl,error_signature:T.string(),affected_area:T.string()}),Vl=T.enum(["clear_winner","multiple_plausible","dissent","all_inconclusive","no_hypotheses"]),Vb=T.object({reproducer:T.string().optional(),triage:Jl.optional(),hypotheses:T.array(ys),premise_verifications:T.array(ql).optional(),winner:T.object({hypothesis_id:T.string(),verification_log:T.string(),proposed_fix:T.string()}).optional(),verification_results:T.array(bs).optional(),outcome:Vl.optional(),recommended_next_skill:T.enum(["spec"]).optional()});async function Yl(t,e){let n=t.map(c=>({hypothesis:c,decision:fs(c)})).filter(c=>c.decision.verify);if(n.length===0)return{premise_verifications:[],hypotheses_to_test:t};let r=[],o;try{r=await e(n.map(c=>c.hypothesis.claim))}catch(c){o=c instanceof Error?c.message:String(c)}let s=n.map((c,l)=>{let d=r[l];return o!==void 0?{hypothesis_id:c.hypothesis.id,claim:c.hypothesis.claim,verdict:"INCONCLUSIVE",evidence:`shadow-verify dispatch failed: ${o}`,gate_reason:c.decision.reason}:d?{hypothesis_id:c.hypothesis.id,claim:c.hypothesis.claim,verdict:d.verdict,evidence:d.evidence,gate_reason:c.decision.reason}:{hypothesis_id:c.hypothesis.id,claim:c.hypothesis.claim,verdict:"INCONCLUSIVE",evidence:"no verifier result for this claim",gate_reason:c.decision.reason}}),i=new Set(s.filter(c=>c.verdict==="REFUTED").map(c=>c.hypothesis_id)),a=i.size===0?t:t.filter(c=>!i.has(c.id));return{premise_verifications:s,hypotheses_to_test:a}}async function Xl(t,e,n){let r=n?.apiKey,o=(()=>{if(typeof t=="string")return{failure:t,repoPath:process.cwd(),context:"",maxHypotheses:4};if(typeof t=="object"&&t!==null){let D=t;if(typeof D.failure=="string")return{failure:D.failure,repoPath:D.repoPath||process.cwd(),context:D.context||"",maxHypotheses:Math.min(D.maxHypotheses||4,4)}}throw new Error("diagnose handler requires input.failure (string) or a string argument")})();if(!e?.sessionId)throw new Error("diagnose requires a parent session with sessionId");let s=e.sessionId,i=$("diagnose"),a=i["system.md"],c=i["research.md"],l=i["hypothesis.md"],d=i["verify.md"];if(!a||!c||!l||!d)throw new Error("diagnose skill missing required prompts (system.md, research.md, hypothesis.md, verify.md)");let u=new P({apiKey:r}),p=td(o.context),f=Ql(o.failure,o.context),g=`Triage:
|
|
1164
1164
|
failure_type: ${f.failure_type}
|
|
1165
1165
|
error_signature: ${f.error_signature}
|
|
1166
1166
|
affected_area: ${f.affected_area}`,m=`${X.systemPrompt}
|
|
@@ -1189,9 +1189,9 @@ ${JSON.stringify(I.codebase,null,2)}
|
|
|
1189
1189
|
GIT RESEARCH:
|
|
1190
1190
|
${JSON.stringify(I.git,null,2)}
|
|
1191
1191
|
|
|
1192
|
-
Original failure: ${o.failure}`,A;try{A=await S.runToResult(x)}finally{await S.teardown().catch(()=>{})}if(A.status!=="succeeded"||!A.output){if(A.schemaError){let
|
|
1193
|
-
Raw response (first 500 chars): ${
|
|
1194
|
-
Hint: model response must include a fenced JSON block with a hypotheses array.`)}throw new Error(`hypothesis synthesis failed: ${j(A)}`)}let R=A.output.hypotheses.slice(0,o.maxHypotheses);if(R.length===0)return{reproducer:p,triage:f,hypotheses:[],verification_results:[],outcome:"no_hypotheses"};let{premise_verifications:F,hypotheses_to_test:v}=await Yl(R,async
|
|
1192
|
+
Original failure: ${o.failure}`,A;try{A=await S.runToResult(x)}finally{await S.teardown().catch(()=>{})}if(A.status!=="succeeded"||!A.output){if(A.schemaError){let D=A.message?.content||"(no response)";throw new Error(`hypothesis synthesis schema mismatch: ${A.schemaError.message}
|
|
1193
|
+
Raw response (first 500 chars): ${D.slice(0,500)}
|
|
1194
|
+
Hint: model response must include a fenced JSON block with a hypotheses array.`)}throw new Error(`hypothesis synthesis failed: ${j(A)}`)}let R=A.output.hypotheses.slice(0,o.maxHypotheses);if(R.length===0)return{reproducer:p,triage:f,hypotheses:[],verification_results:[],outcome:"no_hypotheses"};let{premise_verifications:F,hypotheses_to_test:v}=await Yl(R,async D=>{if(!n?.dispatchSkill)throw new Error("shadow-verify dispatch unavailable (no dispatchSkill in ctx)");let Se=JSON.stringify({claims:D,context:`Original failure: ${o.failure}`}),Wa=await n.dispatchSkill("shadow-verify",Se);return JSON.parse(Wa).verifications});if(v.length===0)return{reproducer:p,triage:f,hypotheses:R,premise_verifications:F,verification_results:[],outcome:"no_hypotheses"};let E=p||o.failure,M=v.map(D=>rd(D,E,o.repoPath,s,d,u,b)),O=await Promise.all(M),L=O.filter(D=>D.reproducer_passed&&D.regressions.length===0).slice().sort((D,Se)=>Se.confidence-D.confidence)[0]??O.find(D=>D.reproducer_passed),z=ed(R,O),re=L?R.find(D=>D.id===L.hypothesis_id):void 0,W=z==="clear_winner"&&re&&Zl(re)?"spec":void 0;return{reproducer:p,triage:f,hypotheses:R,premise_verifications:F.length>0?F:void 0,winner:L?{hypothesis_id:L.hypothesis_id,verification_log:L.verification_log,proposed_fix:re?.proposed_fix||""}:void 0,verification_results:O,outcome:z,recommended_next_skill:W}}function Ql(t,e){let n=`${t}
|
|
1195
1195
|
${e}`,r="unknown",o=n.toLowerCase();/flaky|non-?deterministic|intermittent|sometimes fails|race/.test(o)?r="flaky":/regression|used to work|worked before|broke in|ci.*green.*red|was passing/.test(o)?r="regression":/\b(uncaught|unhandled)\b|panic|segfault|exit(ed)? (with )?(code )?[1-9]|sigsegv|stack overflow|fatal|traceback|core dumped|abort(ed)?|\b(type|reference|range|syntax|internal|eval|uri)error\b/.test(o)?r="crash":/platform|node version|python version|dependency|version mismatch|works on .* not |env(ironment)?|config drift/.test(o)?r="environment":/expected .* but|got .* expected|wrong|incorrect|unexpected/.test(o)&&(r="logic-error");let s=t.split(`
|
|
1196
1196
|
`).map(l=>l.trim()).find(l=>l.length>0),i=s?s.length>200?`${s.slice(0,197)}...`:s:"unknown",c=n.match(/(?:^|[\s'"`(])((?:\.{1,2}\/)?[\w@./-]+\.(?:ts|tsx|js|jsx|mjs|cjs|py|rb|go|rs|java|kt|cpp|c|h|hpp|md|json|yaml|yml)(?::\d+(?::\d+)?)?)/)?.[1]??"unknown";return{failure_type:r,error_signature:i,affected_area:c}}function Zl(t){let n=`${t.proposed_fix??""}
|
|
1197
1197
|
${t.location??""}`.match(/(?:^|[\s'"`(])((?:\.{1,2}\/)?[\w@./-]+\.(?:ts|tsx|js|jsx|mjs|cjs|py|rb|go|rs|java|kt|cpp|c|h|hpp))/g);return n?new Set(n.map(o=>o.trim().replace(/^[\s'"`(]+/,"").split(":")[0])).size>2:!1}function ed(t,e){if(t.length===0)return"no_hypotheses";let n=e.filter(o=>o.reproducer_passed&&o.regressions.length===0);return n.length===1?"clear_winner":n.length>=2?"multiple_plausible":t.filter(o=>o.confidence>=.7).length>=2?"dissent":"all_inconclusive"}function td(t){if(!t)return;let e=[/test:\s*(.+)/i,/command:\s*(.+)/i,/reproducer:\s*(.+)/i,/failing test:\s*(.+)/i];for(let n of e){let r=t.match(n);if(r)return r[1]}}function gs(){return async t=>X.allowedTools.includes(t)?{behavior:"allow"}:{behavior:"deny",message:`Tool ${t} not allowed. Allowed tools: ${X.allowedTools.join(", ")}`}}var hs=[...X.allowedTools,"Agent"];function nd(){return async t=>hs.includes(t)?{behavior:"allow"}:{behavior:"deny",message:`Tool ${t} not allowed for git orchestrator. Allowed tools: ${hs.join(", ")}`}}async function rd(t,e,n,r,o,s,i){let a=ms(Kl(),`diagnose-hyp-${t.id}-${Date.now()}`),c;try{await Vt("git",["worktree","add","--detach",a,"HEAD"],{cwd:n});try{let{writeFile:u}=await import("node:fs/promises"),p="",f="";try{p=(await Vt("git",["rev-parse","HEAD"],{cwd:n})).stdout.trim()}catch{}try{f=(await Vt("git",["symbolic-ref","--short","HEAD"],{cwd:n})).stdout.trim()}catch{}await u(ms(a,".afk-worktree-meta.json"),JSON.stringify({owner:"diagnose",createdAt:new Date().toISOString(),baseSha:p,baseBranch:f},null,2),"utf-8")}catch{}c=await s.forkSubagent({parent:{sessionId:r},config:{model:"sonnet",systemPrompt:`${o}
|
|
@@ -1438,20 +1438,20 @@ If the append fails (permissions, disk full, unwritable path), do not retry and
|
|
|
1438
1438
|
Be skeptical. Protect the plugin from fluff. Stage 2 catches patterns that are strong when they work and catastrophic when they don't.
|
|
1439
1439
|
`,sourcePath:"agent-framework-local/agents/qualify.md"};import{fileURLToPath as ld}from"node:url";import{dirname as dd}from"node:path";var ud=ld(import.meta.url),sw=dd(ud);import{mkdir as ws,writeFile as ks}from"fs/promises";import{dirname as pd,join as fd}from"path";async function te(t){let e=ft();await ws(pd(e),{recursive:!0});let n=new Date().toISOString().split(".")[0]+"Z",r={timestamp:n,surface:"afk",...t},o=JSON.stringify(r)+`
|
|
1440
1440
|
`;return await ks(e,o,{flag:"a"}),n}async function vs(){let t=mt(),e=fd(t,"forge-thaw-history.jsonl");await ws(t,{recursive:!0});let r={timestamp:new Date().toISOString().split(".")[0]+"Z",surface:"afk",event:"forge.thaw_override",thaw_triggered:!0},o=JSON.stringify(r)+`
|
|
1441
|
-
`;await ks(e,o,{flag:"a"})}import{readFile as Ss,readdir as md,writeFile as gd,mkdir as hd,unlink as yd}from"fs/promises";import{join as Yt}from"path";import{existsSync as bd}from"fs";async function xs(t){let e=Yt(
|
|
1441
|
+
`;await ks(e,o,{flag:"a"})}import{readFile as Ss,readdir as md,writeFile as gd,mkdir as hd,unlink as yd}from"fs/promises";import{join as Yt}from"path";import{existsSync as bd}from"fs";async function xs(t){let e=Yt(De(),t+".md"),n=await Ss(e,"utf-8");return{id:t,content:n}}async function Es(){let t=De();return bd(t)?(await md(t,{withFileTypes:!0})).filter(r=>r.isFile()&&r.name.endsWith(".md")).map(r=>r.name.slice(0,-3)):[]}async function Vn(t,e){let n=De(),r=Yt(n,t+".md"),o=Yt(n,e),s=Yt(o,t+".md");await hd(o,{recursive:!0});let i=await Ss(r,"utf-8");await gd(s,i,"utf-8"),await yd(r)}var wd=/^(APPROVE|SALVAGE|REJECT)\b/,kd=/^(?:\w+\s+)*verdict\s*[:\-—]\s*(APPROVE|SALVAGE|REJECT)\b/i;function Ts(t,e){for(let n=0;n<t.length;n++){let r=t[n];if(!r)continue;let o=r.match(e);if(o&&o[1])return{index:n,verdict:o[1]}}return null}function _s(t){let e=t.split(`
|
|
1442
1442
|
`).map(c=>c.trim()).filter(c=>c.length>0),n=e.map(c=>c.replace(/\*\*/g,"")),r=Ts(n,wd)??Ts(n,kd);if(!r)return{verdict:"REJECT",feedback:t};let o=t.match(/score:\s*(\d+)/i),s=o&&o[1]?parseInt(o[1],10):void 0,i=e.slice(r.index+1).join(`
|
|
1443
1443
|
`).trim(),a=e[r.index]??"";return{verdict:r.verdict,score:s,feedback:i||a}}var Td=Sd(vd);function _d(t){let e=[],n=process.env.AFK_EVAL_HARNESS_ROOT;if(n){let i=pe(n,"scripts","eval-harness","runner.py");if(e.push(i),Xt(i))return i}let r=pe(t,"../../.."),o=pe(r,"..","awa-private","scripts","eval-harness","runner.py");if(e.push(o),Xt(o))return o;let s=t;for(let i=0;i<12;i++){let a=pe(s,"awa-private","scripts","eval-harness","runner.py");if(e.push(a),Xt(a))return a;let c=Ps(s);if(c===s)break;s=c}throw new Error(`Could not find eval-harness runner.py. Tried:
|
|
1444
1444
|
- ${e.join(`
|
|
1445
1445
|
- `)}`)}function Ad(){let t=Ps(Ed(import.meta.url));return _d(t)}function Rd(t){return pe(t,"..","..","..","plugins","awa-private")}function Pd(){return mt()}function Id(t){let e=t.split(`
|
|
1446
1446
|
`),n=[],r=/^\s+✗\s+(\S+):/;for(let o of e){let s=o.match(r);s&&s[1]&&n.push(s[1])}return n}async function Cd(t){let e=Pd(),n=pe(e,"qualifications.jsonl");await As(e,{recursive:!0});let o=new Date().toISOString().split(".")[0]+"Z",i=JSON.stringify({timestamp:o,surface:"afk",refers_to_run_id:t,source:"forge-gate-check-ts"})+`
|
|
1447
|
-
`;return await Rs(n,i,{flag:"a"}),o}async function Md(){let t;try{t=Ad()}catch(c){throw new Error(`Failed to resolve eval-harness runner.py: ${c instanceof Error?c.message:String(c)}`)}let e=Rd(t),n="",r="",o=0;try{let c=await Td("python3",[t,"--plugin-root",e],{timeout:6e4});n=c.stdout||"",r=c.stderr||"",o=0}catch(c){let l=c;if(n=l.stdout||"",r=l.stderr||"",o=typeof l.code=="number"?l.code:1,l.code==="ENOENT"||r&&r.includes("No such file"))throw new Error(`eval-harness runner.py not found at ${t}.`)}let s=o===0?"OPEN":"CLOSED",i=s==="CLOSED"?Id(n):void 0,a;if(s==="OPEN"){let c=new Date().toISOString().split(".")[0]+"Z";a=await Cd(c)}return{gate_status:s,exit_code:o,stdout:n,stderr:r||void 0,tasks_failed:i,ledger_entry_ref:a}}var
|
|
1447
|
+
`;return await Rs(n,i,{flag:"a"}),o}async function Md(){let t;try{t=Ad()}catch(c){throw new Error(`Failed to resolve eval-harness runner.py: ${c instanceof Error?c.message:String(c)}`)}let e=Rd(t),n="",r="",o=0;try{let c=await Td("python3",[t,"--plugin-root",e],{timeout:6e4});n=c.stdout||"",r=c.stderr||"",o=0}catch(c){let l=c;if(n=l.stdout||"",r=l.stderr||"",o=typeof l.code=="number"?l.code:1,l.code==="ENOENT"||r&&r.includes("No such file"))throw new Error(`eval-harness runner.py not found at ${t}.`)}let s=o===0?"OPEN":"CLOSED",i=s==="CLOSED"?Id(n):void 0,a;if(s==="OPEN"){let c=new Date().toISOString().split(".")[0]+"Z";a=await Cd(c)}return{gate_status:s,exit_code:o,stdout:n,stderr:r||void 0,tasks_failed:i,ledger_entry_ref:a}}var Od=se.object({iteration:se.number().int().positive(),verdict:se.enum(["APPROVE","SALVAGE","REJECT"]),score:se.number().optional(),feedback:se.string()}),jw=se.object({status:se.enum(["APPROVED","REJECTED","GATE_CLOSED","MAX_ITERATIONS"]),skill_path:se.string().optional(),qualify_verdicts:se.array(Od),brief_id:se.string().optional(),telemetry_ref:se.string()}),Dd=new Set(["unknown","unnamed","skill","new-skill","tbd","placeholder","<name>",""]);function Fd(t){if(!t.startsWith(`---
|
|
1448
1448
|
`))return{ok:!1,reason:"frontmatter_missing",message:"SKILL.md does not start with a YAML frontmatter fence (---)",skillNameAttempted:null};let e=t.split(`
|
|
1449
1449
|
`),n=-1;for(let c=1;c<Math.min(e.length,41);c++)if(e[c]==="---"){n=c;break}if(n===-1)return{ok:!1,reason:"frontmatter_missing",message:'SKILL.md frontmatter closing "---" not found within first 40 lines',skillNameAttempted:null};let o=e.slice(1,n).join(`
|
|
1450
|
-
`);if(!o.match(/^name:/m)||!o.match(/^description:/m))return{ok:!1,reason:"frontmatter_missing",message:'SKILL.md frontmatter is missing required "name:" or "description:" key',skillNameAttempted:null};let a=(o.match(/^name:[ \t]*([^\n]*)/m)?.[1]??"").trim().replace(/^["']|["']$/g,"");return a?
|
|
1450
|
+
`);if(!o.match(/^name:/m)||!o.match(/^description:/m))return{ok:!1,reason:"frontmatter_missing",message:'SKILL.md frontmatter is missing required "name:" or "description:" key',skillNameAttempted:null};let a=(o.match(/^name:[ \t]*([^\n]*)/m)?.[1]??"").trim().replace(/^["']|["']$/g,"");return a?Dd.has(a)?{ok:!1,reason:"sentinel_name",message:`SKILL.md "name:" resolved to sentinel/placeholder value: "${a}"`,skillNameAttempted:a}:{ok:!0,skillName:a}:{ok:!1,reason:"name_unparseable",message:'SKILL.md frontmatter "name:" key is present but value is empty after trim',skillNameAttempted:null}}function Ld(t,e){if(e.registeredSkills.includes(t))return{ok:!1,reason:"name_collision",message:`skill name "${t}" is already registered in this session (built-in, plugin, or user-scope). Delete or rename the existing skill before forging a replacement.`,skillNameAttempted:t};let n=pe(e.skillsDir,t);return Xt(n)?{ok:!1,reason:"name_collision",message:`target directory already exists on disk: ${n}. Forge would silently overwrite or shadow it. Remove the directory first if you intend to replace the skill.`,skillNameAttempted:t}:null}async function Nd(t,e,n){let r=n?.apiKey,o=n?.callId,s=typeof t=="string"?{brief:t}:typeof t=="object"&&t!==null?t:{},i=s.brief,a=s.forceThaw??!1,c=s.maxIterations??3,l="",d=[],u="REJECTED",p,f;try{let g=await Md();if(g.gate_status==="CLOSED"&&!a)return l=await te({event:"forge.gate_check",gate_status:"CLOSED"}),{status:"GATE_CLOSED",qualify_verdicts:[],telemetry_ref:l};a&&g.gate_status==="CLOSED"&&(await vs(),l=await te({event:"forge.thaw_override",gate_status:"CLOSED"})),l=await te({event:"forge.gate_check",gate_status:"OPEN"});let m="",w=!1;if(i)m=i,w=!0;else{let x=await Es();if(x.length>0){let A=x[0],R=await xs(A);m=R.content,f=R.id,w=!0}else{if(!e?.sessionId)throw new Error("forge requires parent session for gap discovery");let R=$("forge")["gap-discovery.md"];if(!R)throw new Error("forge skill missing gap-discovery.md prompt");let E=await(await new P({apiKey:r}).forkSubagent({parent:{sessionId:e.sessionId},config:{model:"sonnet",systemPrompt:R},idPrefix:"forge-gap-discovery",...o?{parentId:o}:{}})).runToResult("Identify the most impactful skill gap.");if(E.status!=="succeeded")throw new Error(`gap discovery failed: ${j(E)}`);if(m=E.message?.content||"",!m)throw new Error("gap discovery returned no concept")}}if(l=await te({event:"forge.brief_loaded",used_brief:w,brief_id:f||null}),!e?.sessionId)throw new Error("forge requires parent session for skill generation");let b=$("forge"),h=b["generate.md"],y=b["system.md"];if(!h)throw new Error("forge skill missing generate.md prompt");if(!y)throw new Error("forge skill missing system.md prompt");let I=await(await new P({apiKey:r}).forkSubagent({parent:{sessionId:e.sessionId},config:{model:"sonnet",systemPrompt:y},idPrefix:"forge-generate",...o?{parentId:o}:{}})).runToResult(`Generate a new amplifier skill based on this concept:
|
|
1451
1451
|
|
|
1452
1452
|
${m}`);if(I.status!=="succeeded")throw new Error(`skill generation failed: ${j(I)}`);let S=I.message?.content||"";if(!S)throw new Error("skill generation returned no output");for(let x=1;x<=c;x++){let A=Jn.systemPrompt;if(!A)throw new Error("qualify agent missing system prompt");let v=await(await new P({apiKey:r}).forkSubagent({parent:{sessionId:e.sessionId},config:{model:"sonnet",systemPrompt:A},idPrefix:`forge-qualify-${x}`,...o?{parentId:o}:{}})).runToResult(`Evaluate this amplifier skill against the force-multiplier criteria:
|
|
1453
1453
|
|
|
1454
|
-
${S}`);if(v.status!=="succeeded")throw new Error(`qualify iteration ${x} failed: ${j(v)}`);let E=v.message?.content||"",{verdict:M,score:D,feedback:G}=_s(E),L={iteration:x,verdict:M,score:D,feedback:G};if(d.push(L),l=await te({event:"forge.qualify_iteration",iteration:x,verdict:M,score:D||null,feedback:G||null}),M==="APPROVE"){u="APPROVED";break}else if(M==="SALVAGE"&&x<c){let z=b["qualify-rework.md"];if(!z)throw new Error("forge skill missing qualify-rework.md prompt");let re=z.replace("{feedback}",G).replace("{original_skill}",S),Se=await(await new P({apiKey:r}).forkSubagent({parent:{sessionId:e.sessionId},config:{model:"sonnet",systemPrompt:re},idPrefix:`forge-rework-${x}`,...o?{parentId:o}:{}})).runToResult("Refine the skill based on the feedback.");if(Se.status!=="succeeded")throw new Error(`rework iteration ${x} failed: ${j(Se)}`);if(S=Se.message?.content||"",!S)throw new Error(`rework iteration ${x} returned no output`)}else M==="REJECT"&&x>=c&&(u="MAX_ITERATIONS")}if(u==="APPROVED"){let x=Fd(S);if(!x.ok)throw l=await te({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=x.skillName,R=Ld(A,{skillsDir:gt(),registeredSkills:Ht()});if(R)throw l=await te({event:"forge.write_failed",reason:R.reason,skill_name_attempted:R.skillNameAttempted}),new Error(`forge write-step invariant failed (${R.reason}): ${R.message}`);let F=pe(gt(),A);await As(F,{recursive:!0});let v=pe(F,"SKILL.md");await Rs(v,S,"utf-8");let E;try{E=await xd(v,"utf-8")}catch{E=""}if(!E.startsWith("---"))throw l=await te({event:"forge.write_failed",reason:"readback_failed",skill_name_attempted:A}),new Error(`forge write-step invariant failed (readback_failed): written file at ${v} did not read back with expected frontmatter`);p=v,w&&f&&await Vn(f,"consumed"),l=await te({event:"forge.complete",status:"APPROVED",skill_name:A,iterations:d.length})}else u==="MAX_ITERATIONS"&&(w&&f&&await Vn(f,"failed"),l=await te({event:"forge.complete",status:"MAX_ITERATIONS",skill_name_attempted:m||null,iterations:d.length}))}catch(g){throw l=await te({event:"forge.error",error:g instanceof Error?g.message:String(g)}),g}return{status:u,skill_path:p,qualify_verdicts:d,brief_id:f,telemetry_ref:l}}var $d={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:Nd,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"]};Y($d);import ar from"path";import{appendFileSync as Mp,mkdirSync as Dp}from"fs";import{dirname as Op}from"path";import Xn from"path";import{appendFileSync as Qd,mkdirSync as Zd}from"fs";import{dirname as eu}from"path";function Yn(t,e){return e?.allowedTools?e.allowedTools.includes(t)?{allowed:!0}:{allowed:!1,reason:`Tool "${t}" is not in the configured allowlist`}:{allowed:!0}}var Ud={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"]}},jd={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"]}},Hd={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"]}},Bd={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"]}},Wd={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"]}},Gd={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"]}},Kd={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"]}},qd={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"]}},zd={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 Jina Reader (https://r.jina.ai). 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.\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.\n- `search`: queries Jina Web Search (https://s.jina.ai) and returns ranked markdown results. Use when you need to FIND a URL, not read one. Provide `query` instead of `url`.\n\nIf `JINA_API_KEY` is set in the environment, it is sent as a bearer token to the two Jina-backed modes \u2014 anonymous requests work but are heavily rate-limited.\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:[]}},Ae={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.
|
|
1454
|
+
${S}`);if(v.status!=="succeeded")throw new Error(`qualify iteration ${x} failed: ${j(v)}`);let E=v.message?.content||"",{verdict:M,score:O,feedback:G}=_s(E),L={iteration:x,verdict:M,score:O,feedback:G};if(d.push(L),l=await te({event:"forge.qualify_iteration",iteration:x,verdict:M,score:O||null,feedback:G||null}),M==="APPROVE"){u="APPROVED";break}else if(M==="SALVAGE"&&x<c){let z=b["qualify-rework.md"];if(!z)throw new Error("forge skill missing qualify-rework.md prompt");let re=z.replace("{feedback}",G).replace("{original_skill}",S),Se=await(await new P({apiKey:r}).forkSubagent({parent:{sessionId:e.sessionId},config:{model:"sonnet",systemPrompt:re},idPrefix:`forge-rework-${x}`,...o?{parentId:o}:{}})).runToResult("Refine the skill based on the feedback.");if(Se.status!=="succeeded")throw new Error(`rework iteration ${x} failed: ${j(Se)}`);if(S=Se.message?.content||"",!S)throw new Error(`rework iteration ${x} returned no output`)}else M==="REJECT"&&x>=c&&(u="MAX_ITERATIONS")}if(u==="APPROVED"){let x=Fd(S);if(!x.ok)throw l=await te({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=x.skillName,R=Ld(A,{skillsDir:gt(),registeredSkills:Ht()});if(R)throw l=await te({event:"forge.write_failed",reason:R.reason,skill_name_attempted:R.skillNameAttempted}),new Error(`forge write-step invariant failed (${R.reason}): ${R.message}`);let F=pe(gt(),A);await As(F,{recursive:!0});let v=pe(F,"SKILL.md");await Rs(v,S,"utf-8");let E;try{E=await xd(v,"utf-8")}catch{E=""}if(!E.startsWith("---"))throw l=await te({event:"forge.write_failed",reason:"readback_failed",skill_name_attempted:A}),new Error(`forge write-step invariant failed (readback_failed): written file at ${v} did not read back with expected frontmatter`);p=v,w&&f&&await Vn(f,"consumed"),l=await te({event:"forge.complete",status:"APPROVED",skill_name:A,iterations:d.length})}else u==="MAX_ITERATIONS"&&(w&&f&&await Vn(f,"failed"),l=await te({event:"forge.complete",status:"MAX_ITERATIONS",skill_name_attempted:m||null,iterations:d.length}))}catch(g){throw l=await te({event:"forge.error",error:g instanceof Error?g.message:String(g)}),g}return{status:u,skill_path:p,qualify_verdicts:d,brief_id:f,telemetry_ref:l}}var $d={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:Nd,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"]};Y($d);import ar from"path";import{appendFileSync as Mp,mkdirSync as Op}from"fs";import{dirname as Dp}from"path";import Xn from"path";import{appendFileSync as Qd,mkdirSync as Zd}from"fs";import{dirname as eu}from"path";function Yn(t,e){return e?.allowedTools?e.allowedTools.includes(t)?{allowed:!0}:{allowed:!1,reason:`Tool "${t}" is not in the configured allowlist`}:{allowed:!0}}var Ud={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"]}},jd={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"]}},Hd={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"]}},Bd={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"]}},Wd={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"]}},Gd={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"]}},Kd={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"]}},qd={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"]}},zd={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 Jina Reader (https://r.jina.ai). 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.\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.\n- `search`: queries Jina Web Search (https://s.jina.ai) and returns ranked markdown results. Use when you need to FIND a URL, not read one. Provide `query` instead of `url`.\n\nIf `JINA_API_KEY` is set in the environment, it is sent as a bearer token to the two Jina-backed modes \u2014 anonymous requests work but are heavily rate-limited.\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:[]}},Ae={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.
|
|
1455
1455
|
|
|
1456
1456
|
Parallelize: dispatch multiple \`agent\` calls in a single tool-use turn to run independent investigations concurrently.
|
|
1457
1457
|
|
|
@@ -1474,7 +1474,7 @@ SECURITY NOTE: upstream node output injected into downstream prompts is user-con
|
|
|
1474
1474
|
[output truncated \u2014 exceeded 100KB]`),u({content:b,...h!==void 0?{testResult:h}:{}})}),p.on("error",b=>{u({content:`Failed to execute: ${b.message}`,isError:!0})})}))}}var Cs=Qt("default");import{promises as Tu}from"fs";import Qn from"path";function ne(t,e,n="read"){let r=e?.resolveBase??e?.cwd,o=Qn.isAbsolute(t)?t:Qn.resolve(r??process.cwd(),t);if(r===void 0)return o;let s=n==="read"?e?.readRoots??[r]:e?.writeRoots??[r];for(let c of s)if(!Qn.relative(c,o).startsWith(".."))return o;let i=s.map(c=>`\`${c}\``).join(", "),a=n==="read"?"read roots":"write roots";throw new Error(`Path \`${t}\` is outside the allowed ${a} [${i}].`)}var Ms=async(t,e,n)=>{if(!t||typeof t!="object")return{content:"Invalid input: expected an object",isError:!0};let r=t,o=r.file_path,s=r.offset??1,i=r.limit??2e3;if(typeof o!="string")return{content:"Invalid input: file_path must be a string",isError:!0};if(typeof s!="number"||s<1)return{content:"Invalid input: offset must be a positive number",isError:!0};if(typeof i!="number"||i<1)return{content:"Invalid input: limit must be a positive number",isError:!0};let a;try{a=ne(o,n,"read")}catch(c){return{content:c instanceof Error?c.message:String(c),isError:!0}}try{let c=await Tu.readFile(a),l=Math.min(8192,c.length);for(let h=0;h<l;h++)if(c[h]===0)return{content:`File appears to be binary: ${a}`,isError:!0};let d=c.toString("utf-8");if(d.length===0)return{content:""};let u=d.split(`
|
|
1475
1475
|
`),p=Math.max(0,s-1),f=Math.min(u.length,p+i),g=u.slice(p,f),m=u.length;if(g.length===0)return{content:`... (offset ${s} is past end of file \u2014 file has ${m} lines)`};let w=String(m).length,b=g.map((h,y)=>{let k=p+y+1;return`${String(k).padStart(w," ")} ${h}`}).join(`
|
|
1476
1476
|
`);if(g.length<m){let h=p+1,y=p+g.length,k=y<m?` \u2014 pass offset=${y+1} to continue`:"";return{content:`${b}
|
|
1477
|
-
... (showing lines ${h}-${y} of ${m}${k})`}}return{content:b}}catch(c){if(c instanceof Error){let l=c;return l.code==="ENOENT"?{content:`File not found: ${a}`,isError:!0}:l.code==="EACCES"?{content:`Permission denied: ${a}`,isError:!0}:{content:`Error reading file: ${c.message}`,isError:!0}}return{content:"Unknown error reading file",isError:!0}}};import{readFile as Mu,writeFile as
|
|
1477
|
+
... (showing lines ${h}-${y} of ${m}${k})`}}return{content:b}}catch(c){if(c instanceof Error){let l=c;return l.code==="ENOENT"?{content:`File not found: ${a}`,isError:!0}:l.code==="EACCES"?{content:`Permission denied: ${a}`,isError:!0}:{content:`Error reading file: ${c.message}`,isError:!0}}return{content:"Unknown error reading file",isError:!0}}};import{readFile as Mu,writeFile as Ou,mkdir as Du,stat as Fu}from"fs/promises";import{dirname as Lu}from"path";import{realpathSync as Os}from"fs";import{dirname as _u,resolve as en,join as Au}from"path";import{homedir as Zt}from"os";var Ru=[`${Zt()}/.ssh`,`${Zt()}/.aws`,`${Zt()}/.gnupg`,`${Zt()}/.config/gcloud`,"/etc","/System","/private/etc","/usr/local/etc"];function Pu(){let t=process.env.AFK_WRITE_DENYLIST,e=t?t.split(":").map(n=>Zn(en(n))).filter(Boolean):[];return[...Ru.map(n=>Zn(en(n))),...e]}function Zn(t){let e=en(t);try{return Os(e)}catch{}let n=[],r=e;for(let o=0;o<64;o++){let s=_u(r);if(s===r)break;n.unshift(r.slice(s.length+1)),r=s;try{let i=Os(r);return Au(i,...n)}catch{}}return e}function tn(t,e="write_file"){let n=Zn(en(t));for(let r of Pu())if(n===r||n.startsWith(r+"/"))throw new Error(`${e}: refusing to write to protected path: ${n} (matches denylist entry: ${r})`)}function Ds(t){if(t==="")return[];let e=t.split(/\r?\n/);return e.length>0&&e[e.length-1]===""&&/\r?\n$/.test(t)&&e.pop(),e}function Iu(t,e){let n=t.length,r=e.length;if((n+1)*(r+1)>=4e6){let l=[];for(let d of t)l.push({op:"del",text:d});for(let d of e)l.push({op:"add",text:d});return l}let o=r+1,s=new Int32Array((n+1)*o);for(let l=1;l<=n;l++)for(let d=1;d<=r;d++)if(t[l-1]===e[d-1])s[l*o+d]=s[(l-1)*o+(d-1)]+1;else{let u=s[(l-1)*o+d],p=s[l*o+(d-1)];s[l*o+d]=u>=p?u:p}let i=[],a=n,c=r;for(;a>0||c>0;)a>0&&c>0&&t[a-1]===e[c-1]?(i.push({op:"same",text:t[a-1]}),a--,c--):c>0&&(a===0||s[a*o+(c-1)]>=s[(a-1)*o+c])?(i.push({op:"add",text:e[c-1]}),c--):(i.push({op:"del",text:t[a-1]}),a--);return i.reverse(),i}function Cu(t){let e=new Int32Array(t.length+1);e[t.length]=t.length;for(let i=t.length-1;i>=0;i--)e[i]=t[i].op==="same"?e[i+1]:i;let n=[],r=1,o=1,s=0;for(;s<t.length;){if(t[s].op==="same"){r++,o++,s++;continue}let i=s,a=0;for(;i>0&&t[i-1].op==="same"&&a<3;)i--,a++;let c=Math.max(1,r-a),l=Math.max(1,o-a),d=[],u=0,p=0;for(let g=i;g<s;g++)d.push({kind:" ",text:t[g].text}),u++,p++;let f=!1;for(;!f&&s<t.length;){let g=t[s];if(g.op==="same"){let m=e[s],w=m-s;if(m===t.length||w>6){for(let h=0;h<3&&s<t.length&&t[s].op==="same";h++)d.push({kind:" ",text:t[s].text}),u++,p++,r++,o++,s++;f=!0}else d.push({kind:" ",text:g.text}),u++,p++,r++,o++,s++}else g.op==="add"?(d.push({kind:"+",text:g.text}),p++,o++,s++):(d.push({kind:"-",text:g.text}),u++,r++,s++)}n.push({oldStart:c,oldLines:u,newStart:l,newLines:p,lines:d})}return n}function nn(t,e){if(t===e)return null;let n=Ds(t),r=Ds(e),o=Iu(n,r),s=Cu(o);if(s.length===0)return null;let i=0,a=0;for(let c of s)for(let l of c.lines)l.kind==="+"?i++:l.kind==="-"&&a++;return{hunks:s,addedLines:i,removedLines:a}}function Nu(t){if(typeof t!="object"||t===null)throw new Error("Input must be an object");let e=t;if(typeof e.file_path!="string")throw new Error('Input must have a "file_path" field of type string');if(typeof e.content!="string")throw new Error('Input must have a "content" field of type string');return{file_path:e.file_path,content:e.content}}var Fs=async(t,e,n)=>{if(e.aborted)return{content:"Aborted",isError:!0};let{file_path:r,content:o}=Nu(t),s;try{s=ne(r,n,"write")}catch(i){return{content:i instanceof Error?i.message:String(i),isError:!0}}try{tn(s,"write_file");let i=(()=>{let p=process.env.AFK_WRITE_DIFF;if(p===void 0)return!1;let f=p.trim().toLowerCase();return f==="0"||f==="false"||f==="no"||f==="off"})(),a=10*1024*1024,c=null;if(!i)try{let p=await Fu(s);if(p.size>a)process.env.AFK_DEBUG&&console.debug(`[write_file] skipping diff: prior file ${p.size} bytes > ${a}`);else{let f=await Mu(s);try{c=new TextDecoder("utf-8",{fatal:!0}).decode(f)}catch{c=null}}}catch(p){p instanceof Error&&"code"in p&&p.code==="ENOENT"&&(c="")}let l=Lu(s);await Du(l,{recursive:!0}),await Ou(s,o,{signal:e});let d=null;if(c!==null&&!o.includes("\0")){let p=performance.now();d=nn(c,o);let f=performance.now()-p;f>=500?console.warn(`[write_file] computeLineDiff took ${f.toFixed(1)}ms`):f>=50&&process.env.AFK_DEBUG&&console.debug(`[write_file] computeLineDiff took ${f.toFixed(1)}ms`)}return{content:`Wrote ${Buffer.byteLength(o,"utf8")} bytes to ${s}`,...d?{render:{diff:d}}:{}}}catch(i){return i instanceof Error?"code"in i&&i.code==="EACCES"?{content:`Permission denied: ${s}`,isError:!0}:{content:`Error writing file: ${i.message}`,isError:!0}:{content:"Unknown error writing file",isError:!0}}};import{readFile as $u,writeFile as Uu}from"fs/promises";function ju(t){if(typeof t!="object"||t===null)throw new Error("Input must be an object");let e=t;if(typeof e.file_path!="string")throw new Error('Input must have a "file_path" field of type string');if(typeof e.old_string!="string")throw new Error('Input must have an "old_string" field of type string');if(typeof e.new_string!="string")throw new Error('Input must have a "new_string" field of type string');let n=!1;if(e.replace_all!==void 0){if(typeof e.replace_all!="boolean")throw new Error("replace_all must be a boolean");n=e.replace_all}return{file_path:e.file_path,old_string:e.old_string,new_string:e.new_string,replace_all:n}}function Hu(t,e){if(e.length===0)return 0;let n=0,r=0;for(;(r=t.indexOf(e,r))!==-1;)n++,r+=e.length;return n}var Ls=async(t,e,n)=>{if(e.aborted)return{content:"Aborted",isError:!0};let{file_path:r,old_string:o,new_string:s,replace_all:i}=ju(t),a;try{a=ne(r,n,"write")}catch(c){return{content:c instanceof Error?c.message:String(c),isError:!0}}try{tn(a,"edit_file");let c=await $u(a,"utf-8"),l=Hu(c,o);if(l===0)return{content:`old_string not found in ${a}`,isError:!0};if(l>1&&!i)return{content:`old_string matches ${l} locations in ${a}. Use replace_all: true or provide more context.`,isError:!0};let d;if(i)d=c.split(o).join(s);else{let m=c.indexOf(o);d=c.slice(0,m)+s+c.slice(m+o.length)}await Uu(a,d,"utf-8");let u=l===1?`Replaced 1 occurrence in ${a}`:`Replaced ${l} occurrences in ${a}`,p=performance.now(),f=nn(c,d),g=performance.now()-p;return g>=500?console.warn(`[edit_file] computeLineDiff took ${g.toFixed(1)}ms`):g>=50&&process.env.AFK_DEBUG&&console.debug(`[edit_file] computeLineDiff took ${g.toFixed(1)}ms`),{content:u,...f?{render:{diff:f}}:{}}}catch(c){return{content:`Error: ${c instanceof Error?c.message:String(c)}`,isError:!0}}};import{promises as $s}from"fs";import Bu from"path";function Wu(t,e){let n=t.replace(/\\/g,"/"),r=e.replace(/\\/g,"/");if(r.includes("**")){let s=r.split("**"),i=0;for(let a=0;a<s.length;a++){let c=s[a]??"",l=Ns(c);if(a===0){let d=n.match(new RegExp(`^${l}`));if(!d)return!1;i=d[0].length}else if(a===s.length-1){let d=new RegExp(`${l}$`);if(!n.slice(i).match(d))return!1}else{let d=new RegExp(l),u=n.slice(i).match(d);if(!u)return!1;let p=u.index??0;i+=p+u[0].length}}return!0}return new RegExp(`^${Ns(r)}$`).test(n)}function Ns(t){return t.replace(/[.+^${}()|[\]\\]/g,"\\$&").replace(/\*/g,"[^/]*").replace(/\?/g,"[^/]")}async function Gu(t,e){let n=[];async function o(s,i){if(n.length>=500)return!0;try{let a=await $s.readdir(s,{withFileTypes:!0});for(let c of a){if(n.length>=500)return!0;let l=Bu.join(s,c.name),d=i?`${i}/${c.name}`:c.name;if(Wu(d,e)&&n.push(d),c.isDirectory()&&await o(l,d))return!0}}catch{}return!1}return await o(t,""),n}function er(t){return async(e,n,r)=>{if(!e||typeof e!="object")return{content:"Invalid input: expected an object",isError:!0};let o=e,s=o.pattern,i=o.path??r?.resolveBase??r?.cwd??t??process.cwd();if(typeof s!="string")return{content:"Invalid input: pattern must be a string",isError:!0};if(s.trim()==="")return{content:"Invalid input: pattern cannot be empty",isError:!0};if(typeof i!="string")return{content:"Invalid input: path must be a string",isError:!0};let a;try{a=ne(i,r,"read")}catch(c){return{content:c instanceof Error?c.message:String(c),isError:!0}}try{if(!(await $s.stat(a)).isDirectory())return{content:`Invalid input: path is not a directory: ${a}`,isError:!0};let l=await Gu(a,s);if(l.length===0)return{content:`No files matched pattern '${s}' in ${a}`};let d=l.join(`
|
|
1478
1478
|
`);return l.length>=500&&(d+=`
|
|
1479
1479
|
[results capped at 500 entries]`),{content:d}}catch(c){return c instanceof Error?"code"in c&&c.code==="ENOENT"?{content:`Path not found: ${a}`,isError:!0}:"code"in c&&c.code==="EACCES"?{content:`Permission denied: ${a}`,isError:!0}:{content:`Error scanning directory: ${c.message}`,isError:!0}:{content:"Unknown error scanning directory",isError:!0}}}}var Us=er();import{spawn as Ku}from"child_process";function qu(t,e,n){if(typeof t!="object"||t===null)throw new Error("Input must be an object");let r=t;if(typeof r.pattern!="string")throw new Error('Input must have a "pattern" field of type string');let o=typeof r.path=="string"?r.path:e?.resolveBase??e?.cwd??n??process.cwd(),s=ne(o,e,"read"),i;if(r.include!==void 0){if(typeof r.include!="string")throw new Error("include must be a string");i=r.include}return{pattern:r.pattern,path:s,include:i}}function zu(t){return t.replace(/\x1b\[[0-9;]*[a-zA-Z]/g,"")}function tr(t){return async(e,n,r)=>{let{pattern:o,path:s,include:i}=qu(e,r,t);return n.aborted?{content:"Search aborted",isError:!0}:new Promise(a=>{let c=!1;function l(m){c||(c=!0,n.removeEventListener("abort",g),a(m))}let d=["-rn"];i&&d.push(`--include=${i}`),d.push(o,s);let u=Ku("grep",d,t!==void 0?{cwd:t}:{}),p="",f="";u.stdout.on("data",m=>{p+=m.toString()}),u.stderr.on("data",m=>{f+=m.toString()});let g=()=>{u.kill(),l({content:"Search aborted",isError:!0})};n.addEventListener("abort",g),u.on("close",m=>{if(m===1){l({content:`No matches found for '${o}' in ${s}`});return}if(m===2){l({content:`grep error: ${f.trim()}`,isError:!0});return}let w=p.trimEnd();w=zu(w);let b=1e5;w.length>b&&(w=w.slice(0,b)+`
|
|
1480
1480
|
[output truncated]`),l({content:w})}),u.on("error",m=>{l({content:`Failed to execute grep: ${m.message}`,isError:!0})})})}}var js=tr();import{promises as Ju}from"fs";var Hs=async(t,e,n)=>{if(!t||typeof t!="object")throw new Error("Invalid input: expected an object");let o=t.path;if(typeof o!="string")throw new Error("Invalid input: path must be a string");let s;try{s=ne(o,n,"read")}catch(i){return{content:i instanceof Error?i.message:String(i),isError:!0}}try{let i=await Ju.readdir(s,{withFileTypes:!0}),a=i.filter(u=>u.isDirectory()).map(u=>`${u.name}/`),c=i.filter(u=>!u.isDirectory()).map(u=>u.name);a.sort(),c.sort();let l=[...a,...c];return l.length===0?{content:"(empty directory)"}:{content:l.join(`
|
|
@@ -1482,11 +1482,11 @@ SECURITY NOTE: upstream node output injected into downstream prompts is user-con
|
|
|
1482
1482
|
|
|
1483
1483
|
[\u2026truncated by agent-afk web_scrape]`,Qu="https://r.jina.ai/",Zu="https://s.jina.ai/";function ep(t){if(!t||typeof t!="object")return{error:"Invalid input: expected an object"};let e=t,n=e.mode??"markdown";if(n!=="markdown"&&n!=="raw"&&n!=="search")return{error:`Invalid input: mode must be one of "markdown", "raw", "search" (got ${JSON.stringify(n)})`};let r=n,o,s;if(r==="search"){if(typeof e.query!="string"||e.query.length===0)return{error:'Invalid input: search mode requires a non-empty "query" string'};s=e.query}else{if(typeof e.url!="string"||e.url.length===0)return{error:`Invalid input: ${r} mode requires a non-empty "url" string`};let c;try{c=new URL(e.url)}catch{return{error:`Invalid input: "${e.url}" is not a valid absolute URL`}}if(c.protocol!=="http:"&&c.protocol!=="https:")return{error:`Invalid input: protocol "${c.protocol}" not supported (http/https only)`};o=c.toString()}let i=3e4;if(e.timeout_ms!==void 0){if(typeof e.timeout_ms!="number"||!Number.isFinite(e.timeout_ms)||e.timeout_ms<=0)return{error:"Invalid input: timeout_ms must be a positive finite number"};i=Math.min(e.timeout_ms,12e4)}let a=1e6;if(e.max_bytes!==void 0){if(typeof e.max_bytes!="number"||!Number.isFinite(e.max_bytes)||e.max_bytes<=0)return{error:"Invalid input: max_bytes must be a positive finite number"};a=Math.min(e.max_bytes,1e7)}return{mode:r,url:o,query:s,timeoutMs:i,maxBytes:a}}function tp(t){return t.mode==="search"?`${Zu}${encodeURIComponent(t.query)}`:t.mode==="markdown"?`${Qu}${t.url}`:t.url}function np(t,e){let n={"User-Agent":"agent-afk/web_scrape",Accept:t.mode==="raw"?"*/*":"text/plain, text/markdown, */*;q=0.5"};return(t.mode==="markdown"||t.mode==="search")&&e.JINA_API_KEY&&(n.Authorization=`Bearer ${e.JINA_API_KEY}`),n}function rp(t,e){let n=Buffer.from(t,"utf8");return n.byteLength<=e?t:n.subarray(0,e).toString("utf8")+Xu}function op(t={}){let e=t.fetchFn??globalThis.fetch,n=t.env??process.env;return async(r,o)=>{if(typeof e!="function")return{content:"web_scrape unavailable: global fetch() is not present in this runtime (agent-afk requires Node 20+).",isError:!0};let s=ep(r);if("error"in s)return{content:s.error,isError:!0};let i=tp(s),a=np(s,n);if(o.aborted){let u=o.reason;return{content:`web_scrape aborted: ${u instanceof Error?u.message:String(u??"aborted")}`,isError:!0}}let c=new AbortController,l=()=>{c.abort(o.reason)},d;try{o.addEventListener("abort",l,{once:!0}),d=setTimeout(()=>{c.abort(new Error(`web_scrape timeout after ${s.timeoutMs}ms`))},s.timeoutMs);let u;try{u=await e(i,{headers:a,signal:c.signal})}catch(g){if(c.signal.aborted){let m=c.signal.reason;return{content:`web_scrape aborted: ${m instanceof Error?m.message:String(m??"aborted")}`,isError:!0}}return{content:`web_scrape network error: ${g instanceof Error?g.message:String(g)}`,isError:!0}}if(!u.ok)return{content:`web_scrape HTTP ${u.status} ${u.statusText||""}`.trimEnd()+` for ${i}`,isError:!0};let p;try{p=await u.text()}catch(g){return{content:`web_scrape read error: ${g instanceof Error?g.message:String(g)}`,isError:!0}}return{content:rp(p,s.maxBytes)}}finally{d!==void 0&&clearTimeout(d),o.removeEventListener("abort",l)}}}var Ks=op();import{existsSync as Xs,readFileSync as mp}from"node:fs";import{readFile as gp}from"node:fs/promises";import{join as hp}from"node:path";import{existsSync as zs,mkdirSync as sp,readFileSync as ip,renameSync as ap,unlinkSync as cp,writeFileSync as lp}from"node:fs";import{dirname as qs,join as dp}from"node:path";import{randomBytes as up}from"node:crypto";function je(t){let e=t??Tn();if(!zs(e))return[];try{let n=ip(e,"utf-8");return JSON.parse(n)}catch(n){let r=n instanceof Error?n.message:String(n);return console.error(`[schedule-store] failed to parse ${e}: ${r}`),[]}}function rn(t,e){let n=e??Tn();sp(qs(n),{recursive:!0});let r=dp(qs(n),`.schedules.json.${process.pid}.${up(4).toString("hex")}.tmp`),o=JSON.stringify(t,null,2);try{lp(r,o,"utf-8"),ap(r,n)}catch(s){try{zs(r)&&cp(r)}catch{}throw s}}function Js(t,e){let n=je(e),r=n.map(c=>c.id),o=pp(t.name),s=fp(o,r),i=new Date().toISOString(),a={...t,notifyOn:t.notifyOn??"failure",id:s,createdAt:i,updatedAt:i};return n.push(a),rn(n,e),a}function Vs(t,e){let n=je(e),r=n.length,o=n.filter(s=>s.id!==t);return o.length===r?!1:(rn(o,e),!0)}function Ys(t,e){return je(e).find(n=>n.id===t)}function pp(t){return t.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/-{2,}/g,"-").replace(/^-+|-+$/g,"")}function fp(t,e){if(!e.includes(t))return t;let n=2;for(;e.includes(`${t}-${n}`);)n+=1;return`${t}-${n}`}async function nr(t,e,n){try{let r=hp(Mr("default"),"port");if(!Xs(r))return;let o=mp(r,"utf-8").trim(),s=parseInt(o,10);if(Number.isNaN(s))return;await fetch(`http://localhost:${s}${e}`,{method:t,headers:{"Content-Type":"application/json"},body:n!==void 0?JSON.stringify(n):void 0,signal:AbortSignal.timeout(2e3)})}catch{}}var Qs=async(t,e)=>{if(!t||typeof t!="object")return{content:"Invalid input: expected object",isError:!0};let n=t;if(typeof n.name!="string"||!n.name)return{content:"Invalid input: name required",isError:!0};if(typeof n.command!="string"||!n.command)return{content:"Invalid input: command required",isError:!0};if(typeof n.cron!="string"||!n.cron)return{content:"Invalid input: cron required",isError:!0};let r=n.cron.trim().split(/\s+/);if(r.length!==5&&r.length!==6)return{content:"Invalid input: cron must be a 5 or 6-field expression",isError:!0};let o=Js({name:n.name,command:n.command,cron:n.cron,trigger:n.trigger??"cron",notifyOn:n.notifyOn,enabled:typeof n.enabled=="boolean"?n.enabled:!0});return await nr("POST","/tasks",{taskId:o.id,command:o.command,cron:o.cron,trigger:o.trigger,notifyOn:o.notifyOn}),{content:JSON.stringify({id:o.id,name:o.name,cron:o.cron,enabled:o.enabled})}},Zs=async(t,e)=>{let n=je();return{content:JSON.stringify(n.map(r=>({id:r.id,name:r.name,cron:r.cron,trigger:r.trigger,enabled:r.enabled,notifyOn:r.notifyOn})))}},ei=async(t,e)=>{if(!t||typeof t!="object")return{content:"Invalid input: expected object",isError:!0};let n=t;if(typeof n.taskId!="string"||!n.taskId)return{content:"Invalid input: taskId required",isError:!0};let r=n.taskId,o=typeof n.limit=="number"?Math.min(Math.max(1,n.limit),50):10,s=ft();if(!Xs(s))return{content:JSON.stringify([])};let i;try{let l=await gp(s);i=(l.length>1048576?l.subarray(l.length-1048576):l).toString("utf-8")}catch{return{content:JSON.stringify([])}}let a=i.split(`
|
|
1484
1484
|
`),c=[];for(let l=a.length-1;l>=0;l-=1){let d=a[l];if(d)try{let u=JSON.parse(d);if(u.taskId!==r)continue;if(c.push(u),c.length>=o)break}catch{continue}}return{content:JSON.stringify(c.reverse())}},ti=async(t,e)=>{if(!t||typeof t!="object")return{content:"Invalid input: expected object",isError:!0};let n=t;if(typeof n.taskId!="string"||!n.taskId)return{content:"Invalid input: taskId required",isError:!0};let r=n.taskId,o=n.permanent===!0;if(!Ys(r))return{content:JSON.stringify({error:"task not found"})};if(o)Vs(r),await nr("DELETE",`/tasks/${r}`);else{let a=je().map(c=>c.id===r?{...c,enabled:!1,updatedAt:new Date().toISOString()}:c);rn(a),await nr("DELETE",`/tasks/${r}`)}return{content:JSON.stringify({ok:!0,taskId:r,permanent:o})}};function on(t,e){let n=t!==void 0?Qt(t,e):e!==void 0?Qt("default",e):Cs,r=e!==void 0?er(e):Us,o=e!==void 0?tr(e):js;return new Map([["bash",n],["read_file",Ms],["write_file",Fs],["edit_file",Ls],["glob",r],["grep",o],["list_directory",Hs],["send_telegram",Gs],["web_scrape",Ks],["create_schedule",Qs],["list_schedules",Zs],["get_schedule_history",ei],["cancel_schedule",ti]])}import Ap from"openai";function at(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 yp={opus:128e3,opus_1m:128e3,sonnet:64e3,sonnet_1m:64e3,haiku:64e3,"claude-opus-4-7":128e3,"claude-sonnet-4-6":64e3,"claude-haiku-4-5-20251001":64e3},bp=64e3;function ni(t){return yp[t]??bp}var wp={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},kp=2e5;function sn(t){return wp[t]??kp}import{readFileSync as vp}from"node:fs";import{homedir as Sp}from"node:os";import{join as xp}from"node:path";function Ep(t){try{return vp(t,"utf-8")}catch{return null}}function or(t,e={}){let n=e.readEnv??(c=>process.env[c]),r=(e.homedir??Sp)(),o=e.readFile??Ep;if(t&&t.length>0)return{apiKey:t,source:"config",last4:rr(t)};let s=n("OPENAI_API_KEY");if(s&&s.length>0)return{apiKey:s,source:"env",last4:rr(s)};let i=xp(r,".codex","auth.json"),a=o(i);if(a!==null){let c=Tp(a);if(c.kind==="apikey")return{apiKey:c.apiKey,source:"codex-cli",last4:rr(c.apiKey)};if(c.kind==="chatgpt")return{apiKey:null,source:"no-usable-auth-codex-oauth"}}return{apiKey:null,source:"no-usable-auth"}}function Tp(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 rr(t){return t.length<=4?t:t.slice(-4)}function sr(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 ri(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(`
|
|
1485
|
-
`)}function _p(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 oi(t){let e=[],n=_p(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 si(){return{assistantText:"",reasoningText:"",toolCallsByIndex:new Map,finishReason:null,usage:null,model:null,id:null}}function*ii(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 ai(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 ci(t){return[...t.toolCallsByIndex.values()].sort((e,n)=>e.index-n.index)}function li(t){return t.finishReason==="tool_calls"||t.finishReason==="function_call"?!0:t.toolCallsByIndex.size>0}function di(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 ui(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 pi(t,e){return{role:"assistant",content:t.length>0?t:null,tool_calls:e.map(n=>({id:n.id,type:"function",function:{name:n.name,arguments:n.argumentsRaw}}))}}function fi(t){return t.map(({call:e,result:n})=>({role:"tool",tool_call_id:e.id,content:n.isError?`[error] ${n.content}`:n.content}))}var ir="openai-compatible",Rp=50,Pp=null;function mi(t){return t??"default"}var an=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=mi(e.config.permissionMode),this.toolDispatcher=e.toolDispatcher,this.toolDispatcher){let n=this.toolDispatcher;Array.isArray(n.toolDefs)&&n.toolDefs.length>0&&(this.openAITools=di(n.toolDefs))}if(e.auth.apiKey===null)this.client=null;else{let n=Pp??Ip,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:[],apiKeySource:this.opts.auth.source,version:ir}},this.opts.auth.apiKey===null){yield{type:"error",error:new Error(sr(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=ri(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;this.priorTurns.push({role:"user",content:e});let r={stopReason:null,resultSubtype:"success",isError:!1},o="";for(let s=0;s<Rp;s++){if(n.signal.aborted){this.abortController===n&&(this.abortController=null);return}let i=yield*this.runIteration(n);if(i===null){this.abortController===n&&(this.abortController=null);return}if(r=at(r,ai(i.state)),i.text.length>0&&(o=i.text),!i.needsToolDispatch)break;if(yield*this.dispatchAndAppend(i.state,n.signal),n.signal.aborted){this.abortController===n&&(this.abortController=null);return}}this.abortController===n&&(this.abortController=null),o.length>0&&this.priorTurns.push({role:"assistant",content:o}),this.lastUsage=r,yield{type:"assistant.message",text:o,sessionId:this.initSessionId},yield{type:"turn.completed",usage:r,sessionId:this.initSessionId}}async*runIteration(e){let n=oi({config:this.opts.config,...this.opts.config.resumeHistory!==void 0?{resumeHistory:this.opts.config.resumeHistory}:{},priorTurns:this.priorTurns}),r=si(),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 ii(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:li(r)&&r.toolCallsByIndex.size>0}}async*dispatchAndAppend(e,n){if(!this.toolDispatcher)return;let r=ci(e),{calls:o,parseErrors:s}=ui(r,n);for(let a of o)yield{type:"tool.use.start",toolUseId:a.id,toolName:a.name,toolInput:Cp(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,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}
|
|
1485
|
+
`)}function _p(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 oi(t){let e=[],n=_p(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 si(){return{assistantText:"",reasoningText:"",toolCallsByIndex:new Map,finishReason:null,usage:null,model:null,id:null}}function*ii(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 ai(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 ci(t){return[...t.toolCallsByIndex.values()].sort((e,n)=>e.index-n.index)}function li(t){return t.finishReason==="tool_calls"||t.finishReason==="function_call"?!0:t.toolCallsByIndex.size>0}function di(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 ui(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 pi(t,e){return{role:"assistant",content:t.length>0?t:null,tool_calls:e.map(n=>({id:n.id,type:"function",function:{name:n.name,arguments:n.argumentsRaw}}))}}function fi(t){return t.map(({call:e,result:n})=>({role:"tool",tool_call_id:e.id,content:n.isError?`[error] ${n.content}`:n.content}))}var ir="openai-compatible",Rp=50,Pp=null;function mi(t){return t??"default"}var an=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=mi(e.config.permissionMode),this.toolDispatcher=e.toolDispatcher,this.toolDispatcher){let n=this.toolDispatcher;Array.isArray(n.toolDefs)&&n.toolDefs.length>0&&(this.openAITools=di(n.toolDefs))}if(e.auth.apiKey===null)this.client=null;else{let n=Pp??Ip,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:ir}},this.opts.auth.apiKey===null){yield{type:"error",error:new Error(sr(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=ri(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;this.priorTurns.push({role:"user",content:e});let r={stopReason:null,resultSubtype:"success",isError:!1},o="";for(let s=0;s<Rp;s++){if(n.signal.aborted){this.abortController===n&&(this.abortController=null);return}let i=yield*this.runIteration(n);if(i===null){this.abortController===n&&(this.abortController=null);return}if(r=at(r,ai(i.state)),i.text.length>0&&(o=i.text),!i.needsToolDispatch)break;if(yield*this.dispatchAndAppend(i.state,n.signal),n.signal.aborted){this.abortController===n&&(this.abortController=null);return}}this.abortController===n&&(this.abortController=null),o.length>0&&this.priorTurns.push({role:"assistant",content:o}),this.lastUsage=r,yield{type:"assistant.message",text:o,sessionId:this.initSessionId},yield{type:"turn.completed",usage:r,sessionId:this.initSessionId}}async*runIteration(e){let n=oi({config:this.opts.config,...this.opts.config.resumeHistory!==void 0?{resumeHistory:this.opts.config.resumeHistory}:{},priorTurns:this.priorTurns}),r=si(),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 ii(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:li(r)&&r.toolCallsByIndex.size>0}}async*dispatchAndAppend(e,n){if(!this.toolDispatcher)return;let r=ci(e),{calls:o,parseErrors:s}=ui(r,n);for(let a of o)yield{type:"tool.use.start",toolUseId:a.id,toolName:a.name,toolInput:Cp(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,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}
|
|
1486
1486
|
--
|
|
1487
|
-
${d.content}`,isError:!0}),i.push({call:l,result:d}),yield{type:"tool.output",toolUseId:l.id,content:d.content,...d.isError===!0?{isError:!0}:{},sessionId:this.initSessionId}}}this.priorTurns.push(pi(e.assistantText,r));for(let a of fi(i))this.priorTurns.push(a)}async interrupt(){let e=this.abortController;if(e&&!e.signal.aborted){e.abort("interrupted");return}this.pendingAbortReason="interrupted"}async setModel(e){e!==void 0&&(this.currentModel=e)}async setPermissionMode(e){this.currentPermissionMode=mi(e)}async supportedCommands(){try{return Ce().map(n=>{let r={name:n.name,description:n.description};return n.argumentHint&&(r.argumentHint=n.argumentHint),r})}catch{return[]}}async supportedModels(){return[{value:"gpt-4o",displayName:"GPT-4o",description:"OpenAI flagship multimodal"},{value:"gpt-4o-mini",displayName:"GPT-4o mini",description:"Fast/cheap GPT-4o"},{value:"gpt-4.1",displayName:"GPT-4.1",description:"Long-context GPT-4"},{value:"gpt-4.1-mini",displayName:"GPT-4.1 mini",description:"Fast 4.1 variant"},{value:"o1",displayName:"o1",description:"Reasoning model"},{value:"o1-mini",displayName:"o1 mini",description:"Fast reasoning"},{value:"o3-mini",displayName:"o3 mini",description:"Newer reasoning, faster"}]}async supportedAgents(){return[]}async getContextUsage(){let e=this.lastUsage,n=sn(this.currentModel),r;if(e&&n>0){let o=(e.inputTokens??0)+(e.outputTokens??0)+(e.cachedInputTokens??0)+(e.cacheCreationTokens??0);r=Math.min(100,Math.max(0,o/n*100))}return{tools:[],agents:[],isAutoCompactEnabled:!1,apiUsage:this.lastUsage,...r!==void 0?{percentage:r}:{},maxTokens:n}}async mcpServerStatus(){return[]}async accountInfo(){return{authSource:this.opts.auth.source}}async rewindFiles(e,n){return{canRewind:!1,error:`${ir} provider does not support file checkpoint rewind yet.`}}close(){this.closed=!0;let e=this.abortController;e&&!e.signal.aborted?e.abort("closed"):this.pendingAbortReason="closed",this.closeResolve?.(),C(`\u{1F7E2} ${ir}: closed`)}};function Ip(t){let e={apiKey:t.apiKey};return t.baseURL!==void 0&&(e.baseURL=t.baseURL),new Ap(e)}function Cp(t){if(!t||typeof t!="object")return"";let e=t,n=e.file_path??e.path??e.filePath;if(typeof n=="string")return" "+n;let r=e.command??e.cmd;if(typeof r=="string"){let s=r.split(`
|
|
1488
|
-
`)[0];return" "+(s.length>80?s.slice(0,77)+"\u2026":s)}let o=e.query??e.pattern??e.url??e.description;return typeof o=="string"?" "+o:""}function gi(t,e,n={}){let r=or(t.apiKey),o=t.resume??`openai-pending-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,s=typeof t.model=="string"?t.model:"gpt-4o-mini",i={auth:r,model:s,synthesizedSessionId:o,promptStream:e,config:t};return n.baseURL!==void 0&&(i.baseURL=n.baseURL),n.toolDispatcher!==void 0&&(i.toolDispatcher=n.toolDispatcher),new an(i)}var Fp="openai-compatible",Me=class{name=Fp;providerOpts;memoryStore;schemas;_sharedReadRoots;_sharedWriteRoots;_initialResolveBase;constructor(e={}){this.providerOpts=e,this.memoryStore=e.memoryStore??new V;let n=[...fe];e.subagentExecutor&&n.push(Ae),e.skillExecutor&&n.push(Re),e.composeExecutor&&n.push(Pe),n.push(...ge),this.schemas=n}query(e){let n=e.config,r=n.permissionMode??"default";this.ensureSharedRoots(n.cwd),n.readRoots&&this._sharedReadRoots&&this._sharedReadRoots.length<=1&&(this._sharedReadRoots.length=0,this._sharedReadRoots.push(...n.readRoots)),n.writeRoots&&this._sharedWriteRoots&&this._sharedWriteRoots.length<=1&&(this._sharedWriteRoots.length=0,this._sharedWriteRoots.push(...n.writeRoots));let o=this.providerOpts.tools??this.buildDispatcher(r,{...n.cwd!==void 0?{cwd:n.cwd}:{},...this._sharedReadRoots!==void 0?{readRoots:this._sharedReadRoots}:{},...this._sharedWriteRoots!==void 0?{writeRoots:this._sharedWriteRoots}:{},...n.sessionId!==void 0?{sessionId:n.sessionId}:{},...n.traceWriter!==void 0?{traceWriter:n.traceWriter}:{}}),s={};return this.providerOpts.baseURL!==void 0&&(s.baseURL=this.providerOpts.baseURL),s.toolDispatcher=o,gi(n,e.prompt,s)}buildDispatcher(e,n){let r=on(e,n.cwd),o=Ze(this.memoryStore,void 0,this.providerOpts.surface??"cli");for(let[
|
|
1489
|
-
`)}catch{}}close(){this.memoryStore.close()}},Lp=new Me;import{readFileSync as ki,existsSync as lr}from"fs";import{join as dn}from"path";import{config as jp}from"dotenv";var cn={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 ln(t){return t in cn}function hi(t){let e=cn[t];if(!e)throw new Error(`Invalid model: ${t}`);return e}function
|
|
1487
|
+
${d.content}`,isError:!0}),i.push({call:l,result:d}),yield{type:"tool.output",toolUseId:l.id,content:d.content,...d.isError===!0?{isError:!0}:{},sessionId:this.initSessionId}}}this.priorTurns.push(pi(e.assistantText,r));for(let a of fi(i))this.priorTurns.push(a)}async interrupt(){let e=this.abortController;if(e&&!e.signal.aborted){e.abort("interrupted");return}this.pendingAbortReason="interrupted"}async setModel(e){e!==void 0&&(this.currentModel=e)}async setPermissionMode(e){this.currentPermissionMode=mi(e)}async supportedCommands(){try{return Ce().map(n=>{let r={name:n.name,description:n.description};return n.argumentHint&&(r.argumentHint=n.argumentHint),r})}catch{return[]}}async supportedModels(){return[{value:"gpt-4o",displayName:"GPT-4o",description:"OpenAI flagship multimodal"},{value:"gpt-4o-mini",displayName:"GPT-4o mini",description:"Fast/cheap GPT-4o"},{value:"gpt-4.1",displayName:"GPT-4.1",description:"Long-context GPT-4"},{value:"gpt-4.1-mini",displayName:"GPT-4.1 mini",description:"Fast 4.1 variant"},{value:"o1",displayName:"o1",description:"Reasoning model"},{value:"o1-mini",displayName:"o1 mini",description:"Fast reasoning"},{value:"o3-mini",displayName:"o3 mini",description:"Newer reasoning, faster"}]}async supportedAgents(){return[]}async getContextUsage(){let e=this.lastUsage,n=sn(this.currentModel),r;if(e&&n>0){let o=(e.inputTokens??0)+(e.outputTokens??0)+(e.cachedInputTokens??0)+(e.cacheCreationTokens??0);r=Math.min(100,Math.max(0,o/n*100))}return{tools:[],agents:[],isAutoCompactEnabled:!1,apiUsage:this.lastUsage,...r!==void 0?{percentage:r}:{},maxTokens:n}}async mcpServerStatus(){return this.opts.mcpManager?this.opts.mcpManager.getServerStates().map(e=>({name:e.serverName,status:e.status})):[]}async accountInfo(){return{authSource:this.opts.auth.source}}async rewindFiles(e,n){return{canRewind:!1,error:`${ir} provider does not support file checkpoint rewind yet.`}}close(){this.closed=!0;let e=this.abortController;e&&!e.signal.aborted?e.abort("closed"):this.pendingAbortReason="closed",this.closeResolve?.(),C(`\u{1F7E2} ${ir}: closed`)}};function Ip(t){let e={apiKey:t.apiKey};return t.baseURL!==void 0&&(e.baseURL=t.baseURL),new Ap(e)}function Cp(t){if(!t||typeof t!="object")return"";let e=t,n=e.file_path??e.path??e.filePath;if(typeof n=="string")return" "+n;let r=e.command??e.cmd;if(typeof r=="string"){let s=r.split(`
|
|
1488
|
+
`)[0];return" "+(s.length>80?s.slice(0,77)+"\u2026":s)}let o=e.query??e.pattern??e.url??e.description;return typeof o=="string"?" "+o:""}function gi(t,e,n={}){let r=or(t.apiKey),o=t.resume??`openai-pending-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,s=typeof t.model=="string"?t.model:"gpt-4o-mini",i={auth:r,model:s,synthesizedSessionId:o,promptStream:e,config:t};return n.baseURL!==void 0&&(i.baseURL=n.baseURL),n.toolDispatcher!==void 0&&(i.toolDispatcher=n.toolDispatcher),n.mcpManager!==void 0&&(i.mcpManager=n.mcpManager),new an(i)}var Fp="openai-compatible",Me=class{name=Fp;providerOpts;memoryStore;schemas;_sharedReadRoots;_sharedWriteRoots;_initialResolveBase;constructor(e={}){this.providerOpts=e,this.memoryStore=e.memoryStore??new V;let n=[...fe];e.subagentExecutor&&n.push(Ae),e.skillExecutor&&n.push(Re),e.composeExecutor&&n.push(Pe),n.push(...ge),this.schemas=n}query(e){let n=e.config,r=n.permissionMode??"default";this.ensureSharedRoots(n.cwd),n.readRoots&&this._sharedReadRoots&&this._sharedReadRoots.length<=1&&(this._sharedReadRoots.length=0,this._sharedReadRoots.push(...n.readRoots)),n.writeRoots&&this._sharedWriteRoots&&this._sharedWriteRoots.length<=1&&(this._sharedWriteRoots.length=0,this._sharedWriteRoots.push(...n.writeRoots));let o=this.providerOpts.tools??this.buildDispatcher(r,{...n.cwd!==void 0?{cwd:n.cwd}:{},...this._sharedReadRoots!==void 0?{readRoots:this._sharedReadRoots}:{},...this._sharedWriteRoots!==void 0?{writeRoots:this._sharedWriteRoots}:{},...n.sessionId!==void 0?{sessionId:n.sessionId}:{},...n.traceWriter!==void 0?{traceWriter:n.traceWriter}:{}}),s={};return this.providerOpts.baseURL!==void 0&&(s.baseURL=this.providerOpts.baseURL),s.toolDispatcher=o,this.providerOpts.mcpManager!==void 0&&(s.mcpManager=this.providerOpts.mcpManager),gi(n,e.prompt,s)}buildDispatcher(e,n){let r=on(e,n.cwd),o=Ze(this.memoryStore,void 0,this.providerOpts.surface??"cli");for(let[a,c]of o)r.set(a,c);let s=this.providerOpts.mcpManager?this.providerOpts.mcpManager.getMcpTools():[];if(this.providerOpts.mcpManager)for(let[a,c]of this.providerOpts.mcpManager.getMcpHandlers())r.set(a,c);let i={handlers:r,schemas:[...this.schemas,...s]};return this.providerOpts.hookRegistry!==void 0&&(i.hookRegistry=this.providerOpts.hookRegistry),this.providerOpts.permissions!==void 0&&(i.permissions=this.providerOpts.permissions),this.providerOpts.subagentExecutor!==void 0&&(i.subagentExecutor=this.providerOpts.subagentExecutor),this.providerOpts.skillExecutor!==void 0&&(i.skillExecutor=this.providerOpts.skillExecutor),this.providerOpts.composeExecutor!==void 0&&(i.composeExecutor=this.providerOpts.composeExecutor),n.cwd!==void 0&&(i.cwd=n.cwd),n.readRoots!==void 0&&(i.readRoots=n.readRoots),n.writeRoots!==void 0&&(i.writeRoots=n.writeRoots),n.sessionId!==void 0&&(i.sessionId=n.sessionId),n.traceWriter!==void 0&&(i.traceWriter=n.traceWriter),new Ie(i)}ensureSharedRoots(e){if(!this._sharedReadRoots){let n=e?[e]:[];this._sharedReadRoots=n.slice(),this._sharedWriteRoots=n.slice(),e&&!this._initialResolveBase&&(this._initialResolveBase=e)}}addReadRoot(e,n="slash",r){this.ensureSharedRoots();let o=ar.resolve(e);this._sharedReadRoots.includes(o)||this._sharedReadRoots.push(o),this.appendProviderAuditLog({action:"grant-read",path:o,source:n,sessionId:r})}addWriteRoot(e,n="slash",r){this.ensureSharedRoots();let o=ar.resolve(e);this._sharedReadRoots.includes(o)||this._sharedReadRoots.push(o),this._sharedWriteRoots.includes(o)||this._sharedWriteRoots.push(o),this.appendProviderAuditLog({action:"grant-write",path:o,source:n,sessionId:r})}revokeRoot(e,n="slash",r){if(!this._sharedReadRoots)return;let o=ar.resolve(e);if(this._initialResolveBase&&o===this._initialResolveBase)return;let s=this._sharedReadRoots.indexOf(o);if(s!==-1&&this._sharedReadRoots.splice(s,1),this._sharedWriteRoots){let i=this._sharedWriteRoots.indexOf(o);i!==-1&&this._sharedWriteRoots.splice(i,1)}this.appendProviderAuditLog({action:"revoke",path:o,source:n,sessionId:r})}getGrants(){return{resolveBase:this._initialResolveBase,readRoots:this._sharedReadRoots?.slice()??[],writeRoots:this._sharedWriteRoots?.slice()??[]}}appendProviderAuditLog(e){try{let n=Le();Op(Dp(n),{recursive:!0});let r=JSON.stringify({timestamp:new Date().toISOString(),sessionId:e.sessionId??null,action:e.action,path:e.path,source:e.source});Mp(n,r+`
|
|
1489
|
+
`)}catch{}}close(){this.memoryStore.close()}},Lp=new Me;import{readFileSync as ki,existsSync as lr}from"fs";import{join as dn}from"path";import{config as jp}from"dotenv";var cn={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 ln(t){return t in cn}function hi(t){let e=cn[t];if(!e)throw new Error(`Invalid model: ${t}`);return e}function Oe(t){if(t!==void 0)return typeof t=="string"&&ln(t)?hi(t):t}import{execFile as Np}from"node:child_process";import{promisify as $p}from"node:util";var zv=$p(Np);var Up=/^[A-Za-z0-9_\-./]*$/,yi=64;function bi(t,e){if(t.length>yi)throw new Error(`Invalid branch prefix from ${e}: length ${t.length} exceeds ${yi}.`);if(!Up.test(t))throw new Error(`Invalid branch prefix from ${e}: '${t}' \u2014 only [A-Za-z0-9_-./] are allowed.`);if(t.startsWith("-"))throw new Error(`Invalid branch prefix from ${e}: '${t}' \u2014 must not start with '-' (would be parsed by git as a flag).`);return t}var ct={model:"sonnet",maxTokens:4096,temperature:1,updatePolicy:"notify"},wi=!1;function lt(){return process.env.ANTHROPIC_API_KEY||process.env.CLAUDE_CODE_OAUTH_TOKEN||ye()}var cr;function Hp(){if(cr!==void 0)return cr;if(!wi){let o=[dn(process.cwd(),".env"),Ye(),Dr()];for(let s of o)lr(s)&&jp({path:s,override:!1});wi=!0}let t={},e=lt();e!==void 0&&(t.apiKey=e);let n=process.env.AFK_MODEL??process.env.CLAUDE_MODEL;if(n){let o=n.toLowerCase();t.model=ln(o)?o:n}let r=process.env.AFK_LOCAL_BASE_URL;if(r&&r.length>0&&(t.baseUrl=r,t.apiKey=process.env.AFK_LOCAL_API_KEY||"local"),process.env.AFK_MAX_TOKENS&&(t.maxTokens=parseInt(process.env.AFK_MAX_TOKENS,10)),process.env.AFK_TEMPERATURE&&(t.temperature=parseFloat(process.env.AFK_TEMPERATURE)),process.env.AFK_SYSTEM_PROMPT&&(t.systemPrompt=process.env.AFK_SYSTEM_PROMPT),process.env.AFK_AUTO_ROUTING){let o=process.env.AFK_AUTO_ROUTING.toLowerCase()==="true";t.autoRouting={interactive:o,chat:o,telegram:o,daemon:o}}return process.env.AFK_OPENAI_BASE_URL&&(t.openaiBaseUrl=process.env.AFK_OPENAI_BASE_URL),cr=t,t}var He,Be;function Bp(){if(He!==void 0)return He;let t=[dn(process.cwd(),"afk.config.json"),Or(),Fr()];for(let e of t)if(lr(e))try{let n=ki(e,"utf-8"),r=JSON.parse(n),o={};if(typeof r.model=="string"&&r.model.length>0&&(o.model=(ln(r.model),r.model)),typeof r.maxTokens=="number"&&(o.maxTokens=r.maxTokens),typeof r.temperature=="number"&&(o.temperature=r.temperature),r.systemPrompt&&(o.systemPrompt=r.systemPrompt),r.autoRouting&&typeof r.autoRouting=="object"){let s={};typeof r.autoRouting.interactive=="boolean"&&(s.interactive=r.autoRouting.interactive),typeof r.autoRouting.chat=="boolean"&&(s.chat=r.autoRouting.chat),typeof r.autoRouting.telegram=="boolean"&&(s.telegram=r.autoRouting.telegram),typeof r.autoRouting.daemon=="boolean"&&(s.daemon=r.autoRouting.daemon),o.autoRouting=s}if(r.daemon&&typeof r.daemon=="object"){let s={};typeof r.daemon.task=="string"&&(s.task=r.daemon.task),typeof r.daemon.taskId=="string"&&(s.taskId=r.daemon.taskId);let i=r.daemon.worktreePrune;i&&typeof i=="object"&&(s.worktreePrune={enabled:typeof i.enabled=="boolean"?i.enabled:!0,cron:typeof i.cron=="string"?i.cron:"0 4 * * *",maxAgeDaysClean:typeof i.maxAgeDaysClean=="number"?i.maxAgeDaysClean:14,maxAgeDaysDirty:typeof i.maxAgeDaysDirty=="number"?i.maxAgeDaysDirty:30,scope:typeof i.scope=="string"?i.scope:"all"}),o.daemon=s}if(r.updatePolicy&&["notify","auto","off"].includes(r.updatePolicy)&&(o.updatePolicy=r.updatePolicy),typeof r.autoResumeOnUsageLimit=="boolean"&&(o.autoResumeOnUsageLimit=r.autoResumeOnUsageLimit),r.interactive&&typeof r.interactive=="object"){let s={};typeof r.interactive.worktreeAutoname=="boolean"&&(s.worktreeAutoname=r.interactive.worktreeAutoname),typeof r.interactive.worktreeBranchPrefix=="string"&&(s.worktreeBranchPrefix=bi(r.interactive.worktreeBranchPrefix,`${e}#/interactive/worktreeBranchPrefix`)),Object.keys(s).length>0&&(o.interactive=s)}return He={config:o,sourcePath:e},He}catch(n){console.error(`Warning: Failed to parse ${e}:`,n)}return He={config:{},sourcePath:void 0},He}function Wp(){if(Be!==void 0)return Be.value;let t=[dn(process.cwd(),"AFK.md"),dn(J(),"AFK.md")];for(let e of t)if(lr(e))try{let n=ki(e,"utf-8").trim();if(n.length>0)return Be={value:{content:n,path:e}},Be.value}catch{}return Be={value:null},Be.value}function dr(t){let e=Hp(),{config:n,sourcePath:r}=Bp(),o={...ct,...e,...n,...t},s;if(e.systemPrompt!==void 0)s="env:AFK_SYSTEM_PROMPT";else if(n.systemPrompt!==void 0&&r!==void 0)s=`file:${r}`;else if(o.systemPrompt===void 0){let a=Wp();a!==null&&(o.systemPrompt=a.content,s=`afk-md:${a.path}`)}let i={model:o.model??ct.model,maxTokens:o.maxTokens??ct.maxTokens,temperature:o.temperature??ct.temperature,updatePolicy:o.updatePolicy??ct.updatePolicy,...o.apiKey!==void 0?{apiKey:o.apiKey}:{},...o.baseUrl!==void 0?{baseUrl:o.baseUrl}:{},...o.openaiBaseUrl!==void 0?{openaiBaseUrl:o.openaiBaseUrl}:{},...o.systemPrompt!==void 0?{systemPrompt:o.systemPrompt}:{},...s!==void 0?{systemPromptSource:s}:{},...o.autoRouting!==void 0?{autoRouting:o.autoRouting}:{},...o.daemon!==void 0?{daemon:o.daemon}:{}};if(typeof i.model=="string"&&i.model.toLowerCase().startsWith("local-")&&(i.baseUrl===void 0||i.baseUrl.length===0))throw new Error(`Model '${i.model}' requires AFK_LOCAL_BASE_URL to be set (e.g. AFK_LOCAL_BASE_URL=http://127.0.0.1:8080). Point it at your local Anthropic-Messages-compatible server.`);return i}function K(){return lt()}function un(){let t=process.env.AFK_DEFAULT_SUBAGENT_MODEL;return!t||t.length===0?"sonnet":t}function Gp(t){if(t===void 0)return;if(t==="max")return Number.POSITIVE_INFINITY;if(t===""||t==="NaN")throw new Error(`Invalid --max-output-tokens value: ${JSON.stringify(t)}. Expected a positive integer or 'max'.`);if(!/^\d+$/.test(t))throw new Error(`Invalid --max-output-tokens value: ${JSON.stringify(t)}. Expected a positive integer or 'max'.`);let e=Number(t);if(!Number.isFinite(e)||!Number.isInteger(e)||e<=0)throw new Error(`Invalid --max-output-tokens value: ${JSON.stringify(t)}. Must be a positive integer.`);return e}function vi(){return Gp(process.env.AFK_MAX_OUTPUT_TOKENS)}async function Si(t,e,n,r){let s=$("mint")["spec.md"];if(!s)throw new Error("mint skill missing spec.md prompt");let c=await(await new P(n!==void 0?{cwd:n}:{}).forkSubagent({parent:{sessionId:e},config:{model:"sonnet",systemPrompt:s,apiKey:K()},idPrefix:"mint-spec",...r?{parentId:r}:{}})).runToResult(`Create a detailed specification for: ${t}`);if(c.status!=="succeeded"||!c.message)throw new Error(`spec phase failed: ${j(c)}`);return c.message.content}async function xi(t,e,n,r){let s=$("mint")["research.md"];if(!s)throw new Error("mint skill missing research.md prompt");let c=await(await new P(n!==void 0?{cwd:n}:{}).forkSubagent({parent:{sessionId:e},config:{model:"sonnet",systemPrompt:s,apiKey:K()},idPrefix:"mint-research",...r?{parentId:r}:{}})).runToResult(`Gather context and research for this specification:
|
|
1490
1490
|
|
|
1491
1491
|
${t}`);if(c.status!=="succeeded"||!c.message)throw new Error(`research phase failed: ${j(c)}`);return c.message.content}async function Ei(t,e,n,r,o){let i=$("mint")["plan.md"];if(!i)throw new Error("mint skill missing plan.md prompt");let c=await new P(r!==void 0?{cwd:r}:{}).forkSubagent({parent:{sessionId:n},config:{model:"sonnet",systemPrompt:i,apiKey:K()},idPrefix:"mint-plan",...o?{parentId:o}:{}}),l=`Specification:
|
|
1492
1492
|
${t}
|
|
@@ -1537,20 +1537,20 @@ ${JSON.stringify(t.buildResults,null,2)}
|
|
|
1537
1537
|
Verification results:
|
|
1538
1538
|
${JSON.stringify(t.verifyResults,null,2)}
|
|
1539
1539
|
|
|
1540
|
-
Create a ship-ready summary with next steps.`,l=await a.runToResult(c);if(l.status!=="succeeded"||!l.message)throw new Error(`ship phase failed: ${j(l)}`);let d=t.buildResults?.filesChanged.length??0,u=t.healIterations;return Ge({kind:"checkpoint",title:"ship \u2014 done",body:[`Files changed: ${d}`,`Heal iterations: ${u}`,`Idea: ${t.idea}`]}),l.message.content}import{existsSync as Pi,mkdirSync as Jp,readFileSync as Vp,unlinkSync as Yp,writeFileSync as Xp}from"fs";import{dirname as Qp,join as Zp}from"path";function pr(t){return Zp(Ve(),t,"mint-state.json")}function Ii(t,e){let n=pr(t);Jp(Qp(n),{recursive:!0}),Xp(n,JSON.stringify(e,null,2),"utf-8")}function ef(t){if(typeof t!="object"||t===null)return!1;let e=t;return typeof e.currentPhase=="string"&&typeof e.idea=="string"&&typeof e.spec=="string"&&typeof e.healIterations=="number"&&Array.isArray(e.history)}function Ci(t){let e=pr(t);if(!Pi(e))return null;try{let n=JSON.parse(Vp(e,"utf-8"));return ef(n)?n:null}catch{return null}}function fr(t){let e=pr(t);if(Pi(e))try{Yp(e)}catch{}}var tf=2,Mi=/^\s*(?:--continue(?:\s+(?:approved|yes|y))?|approved?|yes|y|lgtm|sure)\s*$/i,nf='To approve and run the rest of the pipeline, say "approve", "yes", "sure", or "lgtm" \u2014 or invoke /mint --continue approved. The handler will reload the spec state from disk.';function ce(t,e,n){t.history.push({phase:e,output:n,timestamp:Date.now()})}function Li(t){if("completed"in t&&"paused"in t)throw new Error("mint: invariant violation \u2014 MintResult carries both completed and paused keys simultaneously")}var
|
|
1540
|
+
Create a ship-ready summary with next steps.`,l=await a.runToResult(c);if(l.status!=="succeeded"||!l.message)throw new Error(`ship phase failed: ${j(l)}`);let d=t.buildResults?.filesChanged.length??0,u=t.healIterations;return Ge({kind:"checkpoint",title:"ship \u2014 done",body:[`Files changed: ${d}`,`Heal iterations: ${u}`,`Idea: ${t.idea}`]}),l.message.content}import{existsSync as Pi,mkdirSync as Jp,readFileSync as Vp,unlinkSync as Yp,writeFileSync as Xp}from"fs";import{dirname as Qp,join as Zp}from"path";function pr(t){return Zp(Ve(),t,"mint-state.json")}function Ii(t,e){let n=pr(t);Jp(Qp(n),{recursive:!0}),Xp(n,JSON.stringify(e,null,2),"utf-8")}function ef(t){if(typeof t!="object"||t===null)return!1;let e=t;return typeof e.currentPhase=="string"&&typeof e.idea=="string"&&typeof e.spec=="string"&&typeof e.healIterations=="number"&&Array.isArray(e.history)}function Ci(t){let e=pr(t);if(!Pi(e))return null;try{let n=JSON.parse(Vp(e,"utf-8"));return ef(n)?n:null}catch{return null}}function fr(t){let e=pr(t);if(Pi(e))try{Yp(e)}catch{}}var tf=2,Mi=/^\s*(?:--continue(?:\s+(?:approved|yes|y))?|approved?|yes|y|lgtm|sure)\s*$/i,nf='To approve and run the rest of the pipeline, say "approve", "yes", "sure", or "lgtm" \u2014 or invoke /mint --continue approved. The handler will reload the spec state from disk.';function ce(t,e,n){t.history.push({phase:e,output:n,timestamp:Date.now()})}function Li(t){if("completed"in t&&"paused"in t)throw new Error("mint: invariant violation \u2014 MintResult carries both completed and paused keys simultaneously")}var Oi=240;function rf(t){return t.length<=Oi?t:t.slice(0,Oi)+"\u2026"}function Ni(t){if(typeof t=="string"){if(Mi.test(t))return{userApproved:!0};if(t.length>1&&t.trimStart().startsWith("{"))try{let e=JSON.parse(t);if(typeof e=="object"&&e!==null)return Ni(e)}catch{}return{idea:t}}if(typeof t=="object"&&t!==null){let e=t,n=typeof e.idea=="string"?e.idea:void 0;if(n!==void 0&&Mi.test(n))return{userApproved:!0};if("idea"in e||"resumeFrom"in e||e.userApproved===!0)return e}throw new Error("mint handler requires input.idea (string), input as string, or {userApproved: true} to resume")}async function Di(t,e,n){if(!e.sessionId)throw new Error("runPhasesAfterSpec requires parentSession.sessionId");let r=e.sessionId,o=e.cwd;try{t.currentPhase="research",t.research=await xi(t.spec,r,o,n),ce(t,"research",t.research),t.currentPhase="plan",t.plan=await Ei(t.spec,t.research,r,o,n),ce(t,"plan",t.plan),t.currentPhase="parallelize";let s=await Ti(t.plan,e,n);if(s.kind==="plan")t.waveOrchestrationPlan=s.plan,ce(t,"parallelize",JSON.stringify(s.plan));else if(s.kind==="skipped")t.waveOrchestrationPlan=void 0,ce(t,"parallelize",`skipped: ${s.reason}`);else if(s.kind==="failed"){t.waveOrchestrationPlan=void 0;let c=rf(s.error);ce(t,"parallelize",`failed: ${c}`),ee({event:"fallback.inline",parent_session_id:r,reason:"parallelize-dispatch-failed",error_message:c}),console.warn(`[mint] parallelize dispatch failed (single-lane fallback): ${c}`)}else{let c=s}t.currentPhase="build",t.buildResults=await _i(t.plan,t.waveOrchestrationPlan,r,o,n),ce(t,"build",JSON.stringify(t.buildResults)),t.currentPhase="verify",t.verifyResults=await fn(t.plan,t.buildResults,r,o,n),ce(t,"verify",JSON.stringify(t.verifyResults)),t.currentPhase="heal";let i=t.verifyResults.testsPassed&&t.verifyResults.lintPassed&&t.verifyResults.designReviewPassed;for(;!i&&t.healIterations<tf;){let c=await Ai(t.plan,t.buildResults,t.verifyResults,t.healIterations,e,n);t.healIterations=c.newHealIterations,t.verifyResults=c.newVerifyResults,i=c.healed,ce(t,"heal",`Iterations: ${t.healIterations}, Success: ${i}`)}if(!i)return{paused:!0,phase:"heal-failed",reason:`Heal capped at ${t.healIterations} iterations; still have failures`,state:t,nextStep:"Heal loop exhausted. Inspect verifyResults, fix manually, then re-invoke /mint with a fresh idea \u2014 resume is not supported from heal-failed."};t.currentPhase="ship";let a=await Ri(t,r,o,n);return ce(t,"ship",a),{completed:!0,artifact:a,state:t}}catch(s){throw new Error(`mint failed at ${t.currentPhase}: ${s}`)}}function Fi(t,e){return Li(e),("completed"in e||e.phase==="heal-failed")&&fr(t),e}async function of(t,e,n){let r=Ni(t);if(!e?.sessionId)throw new Error("mint handler requires a parent session to fork subagents");let o=e.sessionId,s=n?.callId;if(r.userApproved){let c=r.resumeFrom??Ci(o);if(!c)throw new Error("mint: no paused spec found for this session to continue. Run /mint <idea> first, then /mint --continue approved.");let l=await Di(c,e,s);return Fi(o,l)}if(!r.idea)throw new Error("mint: no idea provided. Run /mint <idea> to start, or /mint --continue approved to resume a paused spec.");fr(o);let i={currentPhase:"spec",idea:r.idea,healIterations:0,history:[]};try{i.spec=await Si(r.idea,o,e.cwd,s),ce(i,"spec",i.spec)}catch(c){throw new Error(`mint failed at spec: ${c}`)}if(!r.autoApprove){Ii(o,i);let c={paused:!0,phase:"spec",spec:i.spec,state:i,nextStep:nf};return Li(c),c}let a=await Di(i,e,s);return Fi(o,a)}var sf={name:"mint",description:"Takes a feature idea or refactor scope and delivers a ship-ready, verified implementation end-to-end",handler:of,argumentHint:"<idea> | --continue [approved]",whenToUse:'When the user wants a feature or refactor delivered end-to-end (spec \u2192 research \u2192 build \u2192 verify) in one ship-ready pass. After the spec phase pauses for approval, resume by invoking mint again with the literal string `"approved"` (or `"yes"`, `"lgtm"`, `"--continue approved"`) as the arguments. Equivalent JSON forms `{"userApproved": true}` and `{"idea": "approved"}` are also accepted. The handler reloads the spec state from disk and runs phases 2\u20138.',flags:["--continue"]};Y(sf);async function af(){throw new Error("service-setup is a fork skill; its handler should never be called directly. Invoke via the `skill` tool or `/service-setup` slash command.")}var cf={name:"service-setup",description:"Install an AFK background process (telegram bot or daemon) as a macOS LaunchAgent so it auto-starts on login and relaunches on crash. Runs pre-flight checks (e.g., refuses to install the telegram service with an invalid token, which would otherwise crash-loop under KeepAlive), invokes `afk service install`, verifies with `afk service status`, and surfaces the management cheatsheet. macOS-only \u2014 gracefully refuses on other platforms.",handler:af,context:"fork",whenToUse:"When the user wants to make `afk telegram start` or `afk daemon` always-on \u2014 i.e., survive reboot, crash, OOM. Triggers on phrasings like 'install as a service', 'auto-start on login', 'keep the bot running', 'launchd', 'always-on telegram', or right after a successful `/telegram-setup` when the user asks how to make it persistent."};Y(cf);async function lf(){throw new Error("telegram-setup is a fork skill; its handler should never be called directly. Invoke via the `skill` tool or `/telegram-setup` slash command.")}var df={name:"telegram-setup",description:"Guide the user through first-time Telegram bot onboarding without leaking the bearer token. Walks the user to run `afk telegram setup` in a terminal for token entry, then uses the sanctioned `afk telegram check-token`/`discover-chat`/`set-allowed-chat` subcommands to validate and finish allowlist setup \u2014 the token never enters the model context. Works in REPL or Telegram. Use when the user wants to set up Telegram push notifications for the first time, or to debug a partially-configured install.",handler:lf,context:"fork",whenToUse:`When the user wants to set up Telegram bot notifications for the first time, or when they say something like "set up telegram", "connect telegram", "enable push", or you detect that TELEGRAM_BOT_TOKEN is unset and they're asking for notifications.`};Y(df);import{existsSync as uf,readdirSync as pf,readFileSync as ff,statSync as mf}from"fs";import{join as gf}from"path";function mr(t){let e=[];function n(r,o=0){if(o>10||!uf(r))return;let s;try{s=pf(r)}catch{return}for(let i of s){if(i.startsWith("."))continue;let a=gf(r,i),c;try{c=mf(a)}catch{continue}if(c.isFile()&&i==="SKILL.md"){let l=hf(a);l.name&&e.push(l)}else c.isDirectory()&&n(a,o+1)}}return n(t),e}function hf(t){try{let e=ff(t,"utf-8");if(!e.startsWith(`---
|
|
1541
1541
|
`))return{};let n=e.slice(4),r=n.indexOf(`
|
|
1542
1542
|
---`);if(r===-1)return{};let o=n.slice(0,r),s=n.slice(r+4).trim(),i={},a=o.split(`
|
|
1543
1543
|
`);for(let c of a){if(!c)continue;let l=c.indexOf(":");if(l===-1)continue;let d=c.slice(0,l).trim(),u=c.slice(l+1).trim();d==="name"?i.name=u.replace(/^["']|["']$/g,""):d==="description"?i.description=u.replace(/^["']|["']$/g,""):d==="argumentHint"&&(i.argumentHint=u.replace(/^["']|["']$/g,""))}return s.length>0&&(i.body=s),i}catch{return{}}}function $i(t){let e=Ce(t);if(e.length===0)return"";let n=[];for(let r of e){let o=r.argumentHint?`${r.argumentHint}`:"",s=o?`- \`${r.name} ${o}\`: ${r.description}`:`- ${r.name}: ${r.description}`;n.push(s),r.whenToUse&&n.push(` When to use: ${r.whenToUse}`)}return["Available skills (invoke via the `skill` tool):","","Each skill dispatches one or more context-isolated subagents internally. Calling `skill` is a delegation primitive \u2014 it preserves the main session's context. Prefer a skill over inline investigation when the task shape matches.","",...n].join(`
|
|
1544
1544
|
`)}function Ce(t){let e=[],n=new Set;for(let o of Ht()){let s=le(o);e.push({name:o,description:s.description,source:s.origin==="user"?"user":s.origin==="project"?"project":"builtin",argumentHint:s.argumentHint,whenToUse:s.whenToUse}),n.add(o)}let r=t??[...de(En()),...de(),...de(_n())];for(let o of r){if(o.type!=="local")continue;let s=mr(o.path);for(let i of s)!i.name||n.has(i.name)||(e.push({name:i.name,description:i.description??`Skill from plugin at ${o.path}`,source:"plugin"}),n.add(i.name))}return e}function pn(t){let e=new Map,n=t??[...de(En()),...de(),...de(_n())];for(let r of n){if(r.type!=="local")continue;let o=mr(r.path);for(let s of o)s.name&&s.body&&s.body.length>0&&!e.has(s.name)&&e.set(s.name,{body:s.body,pluginPath:r.path})}return e}function Ui(t){if(t.length===0)return;let e=t[t.length-1];if(!e||e.role!=="assistant"||typeof e.content=="string")return;let n=e.content,r=[];for(let s of n)s.type==="tool_use"&&typeof s.id=="string"&&r.push(s.id);if(r.length===0)return;let o={role:"user",content:r.map(s=>({type:"tool_result",tool_use_id:s,content:"Tool call interrupted before completing \u2014 no result recorded.",is_error:!0}))};t.push(o)}function ji(t){return{messages:t.initialMessages?[...t.initialMessages]:[],currentModel:t.model,currentPermissionMode:t.permissionMode,userSystem:t.userSystem,toolDispatcher:t.toolDispatcher,lastUsage:null,closed:!1}}var yf="__closed__",mn=class{current=null;pendingReason=null;closedPromise;closeResolve=null;constructor(){this.closedPromise=new Promise(e=>{this.closeResolve=()=>e(yf)})}begin(){let e=new AbortController;return this.current=e,this.pendingReason!==null&&!e.signal.aborted&&(e.abort(this.pendingReason),this.pendingReason=null),e}clear(e){this.current===e&&(this.current=null)}requestAbort(e){let n=this.current;if(n&&!n.signal.aborted){n.abort(e);return}this.pendingReason=e}isIdle(){return this.current===null}markClosed(){this.closeResolve?.()}};import{randomUUID as Wi}from"node:crypto";import{randomUUID as Sf}from"node:crypto";var bf=new Map([["claude-sonnet-4-5-20250929",{inputPerMTok:3,outputPerMTok:15,cacheWritePerMTok:3.75,cacheReadPerMTok:.3}],["claude-opus-4-5-20250929",{inputPerMTok:15,outputPerMTok:75,cacheWritePerMTok:18.75,cacheReadPerMTok:1.5}],["claude-haiku-4-5-20250929",{inputPerMTok:1,outputPerMTok:5,cacheWritePerMTok:1.25,cacheReadPerMTok:.1}],["claude-haiku-4-5-20251001",{inputPerMTok:1,outputPerMTok:5,cacheWritePerMTok:1.25,cacheReadPerMTok:.1}],["claude-3-7-sonnet-20250219",{inputPerMTok:3,outputPerMTok:15,cacheWritePerMTok:3.75,cacheReadPerMTok:.3}],["claude-3-5-sonnet-20241022",{inputPerMTok:3,outputPerMTok:15,cacheWritePerMTok:3.75,cacheReadPerMTok:.3}],["claude-3-5-sonnet-20240620",{inputPerMTok:3,outputPerMTok:15,cacheWritePerMTok:3.75,cacheReadPerMTok:.3}],["claude-3-5-haiku-20241022",{inputPerMTok:.8,outputPerMTok:4,cacheWritePerMTok:1,cacheReadPerMTok:.08}],["claude-3-opus-20240229",{inputPerMTok:15,outputPerMTok:75,cacheWritePerMTok:18.75,cacheReadPerMTok:1.5}],["claude-3-sonnet-20240229",{inputPerMTok:3,outputPerMTok:15,cacheWritePerMTok:3.75,cacheReadPerMTok:.3}],["claude-3-haiku-20240307",{inputPerMTok:.25,outputPerMTok:1.25,cacheWritePerMTok:.3,cacheReadPerMTok:.03}]]);function wf(t,e,n,r,o){let s=bf.get(t);if(!s)return;let i=1e6,c=Math.max(0,e-r-o)/i*s.inputPerMTok,l=n/i*s.outputPerMTok,d=s.cacheWritePerMTok??s.inputPerMTok*1.25,u=s.cacheReadPerMTok??s.inputPerMTok*.1,p=o/i*d,f=r/i*u;return c+l+p+f}function Hi(t,e,n){if(!t)return{stopReason:e??null};let r={inputTokens:t.input_tokens,outputTokens:t.output_tokens,stopReason:e??null};if(t.cache_read_input_tokens!=null&&(r.cachedInputTokens=t.cache_read_input_tokens),t.cache_creation_input_tokens!=null&&(r.cacheCreationTokens=t.cache_creation_input_tokens),r.totalTokens=(t.input_tokens??0)+(t.output_tokens??0),n){let o=wf(n,t.input_tokens??0,t.output_tokens??0,t.cache_read_input_tokens??0,t.cache_creation_input_tokens??0);o!==void 0&&(r.totalCostUsd=o)}return r}function kf(t){let e=t.trim();if(e.length===0)return{};try{return JSON.parse(e)}catch{return{}}}function vf(t,e,n){let r=[],o=[];for(let a of t)a&&(a.kind==="text"?(r.push({type:"text",text:a.text}),o.push(a.text)):a.kind==="thinking"?a.thinking&&a.signature&&r.push({type:"thinking",thinking:a.thinking,signature:a.signature}):r.push({type:"tool_use",id:a.id,name:a.name,input:kf(a.partialJson)}));let s=a=>a.type==="tool_use",i=r.filter(s);return{stopReason:e,assistantBlocks:r,toolUseBlocks:i,usage:n,text:o.join("")}}async function*Bi(t,e){let n=[],r=null,o=null,s=!1;try{process.env.AFK_TELEGRAM_TRACE&&console.log("[translate] starting SDK event iteration");for await(let i of t){switch(process.env.AFK_TELEGRAM_TRACE&&console.log("[translate] SDK evt:",i.type),i.type){case"message_start":{let a=i.message?.usage;a&&(o={...a});break}case"content_block_start":{let a=i.content_block;a.type==="text"?n[i.index]={kind:"text",text:""}:a.type==="thinking"?n[i.index]={kind:"thinking",thinking:"",signature:""}:a.type==="tool_use"&&(n[i.index]={kind:"tool_use",id:a.id,name:a.name,partialJson:""},yield{kind:"event",event:{type:"tool.use.start",toolUseId:a.id,toolName:a.name,toolInput:" \u2026",sessionId:e.sessionId}});break}case"content_block_delta":{let a=n[i.index],c=i.delta;c.type==="text_delta"?(a&&a.kind==="text"&&(a.text+=c.text),yield{kind:"event",event:{type:"delta.text",text:c.text,sessionId:e.sessionId}}):c.type==="input_json_delta"?a&&a.kind==="tool_use"&&(a.partialJson+=c.partial_json):c.type==="thinking_delta"?(a&&a.kind==="thinking"&&(a.thinking+=c.thinking),yield{kind:"event",event:{type:"delta.reasoning",text:c.thinking,sessionId:e.sessionId}}):c.type==="signature_delta"&&a&&a.kind==="thinking"&&(a.signature=c.signature);break}case"content_block_stop":{let a=n[i.index];a&&a.kind==="tool_use"&&(yield{kind:"event",event:{type:"tool.use",summary:a.name,toolUseIds:[a.id],sessionId:e.sessionId}});break}case"message_delta":{i.delta&&i.delta.stop_reason!==void 0&&(r=i.delta.stop_reason);let a=i.usage;a&&(o!==null?(o.output_tokens=a.output_tokens,a.cache_creation_input_tokens!=null&&(o.cache_creation_input_tokens=a.cache_creation_input_tokens),a.cache_read_input_tokens!=null&&(o.cache_read_input_tokens=a.cache_read_input_tokens),a.input_tokens!=null&&(o.input_tokens=a.input_tokens)):o={cache_creation:null,cache_creation_input_tokens:a.cache_creation_input_tokens??null,cache_read_input_tokens:a.cache_read_input_tokens??null,inference_geo:null,input_tokens:a.input_tokens??0,output_tokens:a.output_tokens,server_tool_use:null,service_tier:null});break}case"message_stop":{s=!0;break}default:break}if(s)break}process.env.AFK_TELEGRAM_TRACE&&console.log("[translate] SDK iteration ended naturally, stopped=",s)}catch(i){process.env.AFK_TELEGRAM_TRACE&&console.log("[translate] SDK iteration threw:",i.message),yield{kind:"event",event:{type:"error",error:i instanceof Error?i:new Error(String(i))}};return}process.env.AFK_TELEGRAM_TRACE&&console.log("[translate] yielding turn-result"),yield{kind:"turn-result",result:vf(n,r,o)}}var xf=0;function Ef(t){let{name:e,description:n,input_schema:r}=t;return{name:e,...n!==void 0?{description:n}:{},input_schema:r}}var Tf=3,_f=5e3;function Af(t){if(!("status"in t))return!1;let e=t.status;return e===529||e===503}function Rf(t,e){return new Promise(n=>{if(e.aborted){n();return}let r=setTimeout(n,t);e.addEventListener("abort",()=>{clearTimeout(r),n()},{once:!0})})}async function Pf(t,e,n,r){for(let o=0;;o++){if(o>0){let s=_f*Math.pow(2,o-1);if(await Rf(s,r),r.aborted)throw new Error("aborted")}try{return await Promise.resolve(t.messages.create(e,{headers:n,signal:r}))}catch(s){if(r.aborted)throw s;let i=s instanceof Error?s:new Error(String(s));if(Af(i)&&o<Tf)continue;throw i}}}function If(t){if(!t||typeof t!="object")return"";let e=t,n=e.file_path??e.path??e.filePath;if(typeof n=="string")return" "+n;let r=e.command??e.cmd;if(typeof r=="string"){let s=r.split(`
|
|
1545
|
-
`)[0];return" "+(s.length>80?s.slice(0,77)+"\u2026":s)}let o=e.query??e.pattern??e.url??e.description;return typeof o=="string"?" "+o:""}async function*gr(t){let e=t.maxToolUseIterations??xf,n={stopReason:null},r=0,o=Sf(),s=Date.now();for(;;){if(t.signal.aborted){yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}let i=$t({baseUrl:t.baseUrl})?Bo(t.messages,Ut()):t.messages,a={model:t.model,max_tokens:t.maxTokens,messages:i,stream:!0,...t.system!==null?{system:t.system}:{},...t.tools!==null&&t.tools.length>0?{tools:t.tools.map(Ef)}:{},...t.thinking!==void 0?{thinking:t.thinking}:{},...t.effort!==void 0?{output_config:{effort:t.effort}}:{}},c;try{c=await Pf(t.client,a,t.headers,t.signal)}catch(f){if(t.signal.aborted){yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}let g=f instanceof Error?f:new Error(String(f));g.message.includes("thinking")&&Cf(t.messages,g),yield{type:"error",error:g};return}let l=null,d=!1;try{process.env.AFK_TELEGRAM_TRACE&&console.log("[loop] awaiting translateMessageStream events");for await(let f of Bi(c,t.ctx))if(process.env.AFK_TELEGRAM_TRACE&&console.log("[loop] translate yielded:",f.kind,f.kind==="event"?f.event.type:""),f.kind==="event"){if(f.event.type==="error"){yield f.event,d=!0;break}yield f.event}else{l=f.result;break}process.env.AFK_TELEGRAM_TRACE&&console.log("[loop] translate loop exited, turnResult=",l?"set":"null")}catch(f){if(t.signal.aborted){yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}yield{type:"error",error:f instanceof Error?f:new Error(String(f))};return}if(d){t.signal.aborted&&(yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId});return}if(l===null){yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}if(n=at(n,Hi(l.usage,l.stopReason,t.model)),l.stopReason!=="tool_use"){l.text.length>0&&(yield{type:"assistant.message",text:l.text,sessionId:t.ctx.sessionId},l.text.length<=200&&(yield{type:"suggestion",suggestion:l.text,sessionId:t.ctx.sessionId}));let f=l.assistantBlocks.filter(g=>g.type!=="tool_use");f.length>0&&t.messages.push({role:"assistant",content:f}),yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}let u=t.messages.length;t.messages.push({role:"assistant",content:l.assistantBlocks});try{let f=[],g=new Map;for(let h of l.toolUseBlocks){f.push({id:h.id,name:h.name,input:h.input,signal:t.signal});let y=Date.now();g.set(h.id,y),$n(t.traceWriter,{phase:"started",toolUseId:h.id,name:h.name,inputBytes:Buffer.byteLength(JSON.stringify(h.input??{}),"utf8")}),yield{type:"tool.use.start",toolUseId:h.id,toolName:h.name,toolInput:If(h.input),sessionId:t.ctx.sessionId}}if(t.signal.aborted){let h=f.map(y=>({type:"tool_result",tool_use_id:y.id,content:"Tool call aborted",is_error:!0}));t.messages.push({role:"user",content:h}),yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}let m;if(t.toolDispatcher.executeBatch)try{m=await t.toolDispatcher.executeBatch(f)}catch(h){m=f.map(()=>({content:`Tool batch execution failed: ${h instanceof Error?h.message:String(h)}`,isError:!0}))}else{m=[];for(let h of f){if(t.signal.aborted){m.push({content:"Tool call aborted",isError:!0});continue}try{m.push(await t.toolDispatcher.execute(h))}catch(y){let k=y instanceof Error?y.message:String(y);m.push({content:`Tool execution threw: ${k}`,isError:!0})}}}let w=[];for(let h=0;h<f.length;h++){let y=f[h],k=m[h],_=g.get(y.id),I=typeof _=="number"?Date.now()-_:0;$n(t.traceWriter,{phase:"completed",toolUseId:y.id,name:y.name,resultBytes:Buffer.byteLength(k.content,"utf8"),isError:k.isError===!0,truncated:k.content.includes("[output truncated"),durationMs:I}),yield{type:"tool.output",toolUseId:y.id,toolName:y.name,content:k.content,...k.isError===!0?{isError:!0}:{},sessionId:t.ctx.sessionId},k.render?.diff&&(yield{type:"tool.diff",toolUseId:y.id,diff:k.render.diff,sessionId:t.ctx.sessionId});let{content:S,isError:x}=k;w.push({type:"tool_result",tool_use_id:y.id,content:S,...x===!0?{is_error:!0}:{}})}let b={role:"user",content:w};t.messages.push(b)}catch(f){throw t.messages.splice(u),f}r+=1;let p=l.toolUseBlocks[l.toolUseBlocks.length-1];if(yield{type:"progress",progress:{taskId:o,description:"Tool-use loop",summary:`Iteration ${r}: used ${p?.name??"unknown"}`,lastToolName:p?.name,totalTokens:n.totalTokens??0,toolUses:r,durationMs:Date.now()-s},sessionId:t.ctx.sessionId},e>0&&r>=e){yield{type:"turn.completed",usage:{...n,stopReason:"tool_use_loop_capped"},sessionId:t.ctx.sessionId};return}}}function Cf(t,e){try{let n=[];for(let r=0;r<t.length;r++){let o=t[r];if(o.role!=="assistant"||typeof o.content=="string")continue;let s=o.content;for(let i=0;i<s.length;i++){let a=s[i];if(a.type==="thinking"){let c=a;(!c.thinking||!c.signature)&&n.push({msgIdx:r,blockIdx:i,thinking:c.thinking?`(${c.thinking.length} chars)`:"(empty)",sigLen:c.signature?.length??0})}}}console.error("[afk] thinking-block diagnostic \u2014 API rejected request with:",e.message),console.error(`[afk] messages.length=${t.length}, invalid thinking blocks:`,n.length>0?JSON.stringify(n):"none found (cause may be elsewhere)")}catch{}}var Mf=7200*1e3,gn=class{_client;_authMode;initSessionId;tokenRefresher;autoResumeOnUsageLimit;refreshPromise=null;usageLimitWaitPromise=null;constructor(e){this._client=e.client,this._authMode=e.authMode,this.initSessionId=e.initSessionId,this.tokenRefresher=e.tokenRefresher,this.autoResumeOnUsageLimit=e.autoResumeOnUsageLimit}get client(){return this._client}get authMode(){return this._authMode}async*turnWithRetries(e,n){yield*this.turnWithUsageLimitRetry(e,n)}async*turnWithUsageLimitRetry(e,n){let r=null,o=null;for await(let l of this.turnWithAuthRetry(e,n)){if(l.type==="error"){let d=Nn(l.error);if(d&&d.kind==="oauth-limit"){o=d.resetsAt,r=l;break}}yield l}if(!o||!r)return;if(o.getTime()-Date.now()>Mf){yield r;return}let s=Mt(ye()??"");if(yield{type:"paused",reason:"usage-limit",resetsAt:o,accountId:s},!this.autoResumeOnUsageLimit){yield r;return}let i;if(this.usageLimitWaitPromise)i=await this.usageLimitWaitPromise;else{this.usageLimitWaitPromise=_o({resetsAt:o,signal:e.signal});try{i=await this.usageLimitWaitPromise}finally{this.usageLimitWaitPromise=null}}if(i==="aborted")return;let a=ye();e.headers=_e(this._authMode,this.initSessionId,Wi());let c=i==="hot-swap"?Mt(a??""):s;yield{type:"resumed",hotSwapped:i==="hot-swap",accountId:c},yield*this.turnWithAuthRetry(e,n)}async*turnWithAuthRetry(e,n){let r=null;for await(let s of gr(e)){if(n())return;if(s.type==="error"&&this.isRetryableAuth(s.error)){r=s;break}yield s}if(!r)return;let o=null;try{if(this.refreshPromise)o=await this.refreshPromise;else{this.refreshPromise=this.tokenRefresher();try{o=await this.refreshPromise??null}finally{this.refreshPromise=null}}}catch{this.refreshPromise=null}if(!o){yield r;return}this._client=o,e.client=this._client,e.headers=_e(this._authMode,this.initSessionId,Wi()),yield*gr(e)}isRetryableAuth(e){return this._authMode==="oauth"&&this.tokenRefresher!==void 0&&"status"in e&&e.status===401}};import{randomUUID as Nf}from"node:crypto";var
|
|
1546
|
-
`),Gi="[Compacted summary of earlier conversation]",Ki="Acknowledged. Continuing from the summary above.";function
|
|
1545
|
+
`)[0];return" "+(s.length>80?s.slice(0,77)+"\u2026":s)}let o=e.query??e.pattern??e.url??e.description;return typeof o=="string"?" "+o:""}async function*gr(t){let e=t.maxToolUseIterations??xf,n={stopReason:null},r=0,o=Sf(),s=Date.now();for(;;){if(t.signal.aborted){yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}let i=$t({baseUrl:t.baseUrl})?Bo(t.messages,Ut()):t.messages,a={model:t.model,max_tokens:t.maxTokens,messages:i,stream:!0,...t.system!==null?{system:t.system}:{},...t.tools!==null&&t.tools.length>0?{tools:t.tools.map(Ef)}:{},...t.thinking!==void 0?{thinking:t.thinking}:{},...t.effort!==void 0?{output_config:{effort:t.effort}}:{}},c;try{c=await Pf(t.client,a,t.headers,t.signal)}catch(f){if(t.signal.aborted){yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}let g=f instanceof Error?f:new Error(String(f));g.message.includes("thinking")&&Cf(t.messages,g),yield{type:"error",error:g};return}let l=null,d=!1;try{process.env.AFK_TELEGRAM_TRACE&&console.log("[loop] awaiting translateMessageStream events");for await(let f of Bi(c,t.ctx))if(process.env.AFK_TELEGRAM_TRACE&&console.log("[loop] translate yielded:",f.kind,f.kind==="event"?f.event.type:""),f.kind==="event"){if(f.event.type==="error"){yield f.event,d=!0;break}yield f.event}else{l=f.result;break}process.env.AFK_TELEGRAM_TRACE&&console.log("[loop] translate loop exited, turnResult=",l?"set":"null")}catch(f){if(t.signal.aborted){yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}yield{type:"error",error:f instanceof Error?f:new Error(String(f))};return}if(d){t.signal.aborted&&(yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId});return}if(l===null){yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}if(n=at(n,Hi(l.usage,l.stopReason,t.model)),l.stopReason!=="tool_use"){l.text.length>0&&(yield{type:"assistant.message",text:l.text,sessionId:t.ctx.sessionId},l.text.length<=200&&(yield{type:"suggestion",suggestion:l.text,sessionId:t.ctx.sessionId}));let f=l.assistantBlocks.filter(g=>g.type!=="tool_use");f.length>0&&t.messages.push({role:"assistant",content:f}),yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}let u=t.messages.length;t.messages.push({role:"assistant",content:l.assistantBlocks});try{let f=[],g=new Map;for(let h of l.toolUseBlocks){f.push({id:h.id,name:h.name,input:h.input,signal:t.signal});let y=Date.now();g.set(h.id,y),$n(t.traceWriter,{phase:"started",toolUseId:h.id,name:h.name,inputBytes:Buffer.byteLength(JSON.stringify(h.input??{}),"utf8")}),yield{type:"tool.use.start",toolUseId:h.id,toolName:h.name,toolInput:If(h.input),sessionId:t.ctx.sessionId}}if(t.signal.aborted){let h=f.map(y=>({type:"tool_result",tool_use_id:y.id,content:"Tool call aborted",is_error:!0}));t.messages.push({role:"user",content:h}),yield{type:"turn.completed",usage:n,sessionId:t.ctx.sessionId};return}let m;if(t.toolDispatcher.executeBatch)try{m=await t.toolDispatcher.executeBatch(f)}catch(h){m=f.map(()=>({content:`Tool batch execution failed: ${h instanceof Error?h.message:String(h)}`,isError:!0}))}else{m=[];for(let h of f){if(t.signal.aborted){m.push({content:"Tool call aborted",isError:!0});continue}try{m.push(await t.toolDispatcher.execute(h))}catch(y){let k=y instanceof Error?y.message:String(y);m.push({content:`Tool execution threw: ${k}`,isError:!0})}}}let w=[];for(let h=0;h<f.length;h++){let y=f[h],k=m[h],_=g.get(y.id),I=typeof _=="number"?Date.now()-_:0;$n(t.traceWriter,{phase:"completed",toolUseId:y.id,name:y.name,resultBytes:Buffer.byteLength(k.content,"utf8"),isError:k.isError===!0,truncated:k.content.includes("[output truncated"),durationMs:I}),yield{type:"tool.output",toolUseId:y.id,toolName:y.name,content:k.content,...k.isError===!0?{isError:!0}:{},sessionId:t.ctx.sessionId},k.render?.diff&&(yield{type:"tool.diff",toolUseId:y.id,diff:k.render.diff,sessionId:t.ctx.sessionId});let{content:S,isError:x}=k;w.push({type:"tool_result",tool_use_id:y.id,content:S,...x===!0?{is_error:!0}:{}})}let b={role:"user",content:w};t.messages.push(b)}catch(f){throw t.messages.splice(u),f}r+=1;let p=l.toolUseBlocks[l.toolUseBlocks.length-1];if(yield{type:"progress",progress:{taskId:o,description:"Tool-use loop",summary:`Iteration ${r}: used ${p?.name??"unknown"}`,lastToolName:p?.name,totalTokens:n.totalTokens??0,toolUses:r,durationMs:Date.now()-s},sessionId:t.ctx.sessionId},e>0&&r>=e){yield{type:"turn.completed",usage:{...n,stopReason:"tool_use_loop_capped"},sessionId:t.ctx.sessionId};return}}}function Cf(t,e){try{let n=[];for(let r=0;r<t.length;r++){let o=t[r];if(o.role!=="assistant"||typeof o.content=="string")continue;let s=o.content;for(let i=0;i<s.length;i++){let a=s[i];if(a.type==="thinking"){let c=a;(!c.thinking||!c.signature)&&n.push({msgIdx:r,blockIdx:i,thinking:c.thinking?`(${c.thinking.length} chars)`:"(empty)",sigLen:c.signature?.length??0})}}}console.error("[afk] thinking-block diagnostic \u2014 API rejected request with:",e.message),console.error(`[afk] messages.length=${t.length}, invalid thinking blocks:`,n.length>0?JSON.stringify(n):"none found (cause may be elsewhere)")}catch{}}var Mf=7200*1e3,gn=class{_client;_authMode;initSessionId;tokenRefresher;autoResumeOnUsageLimit;refreshPromise=null;usageLimitWaitPromise=null;constructor(e){this._client=e.client,this._authMode=e.authMode,this.initSessionId=e.initSessionId,this.tokenRefresher=e.tokenRefresher,this.autoResumeOnUsageLimit=e.autoResumeOnUsageLimit}get client(){return this._client}get authMode(){return this._authMode}async*turnWithRetries(e,n){yield*this.turnWithUsageLimitRetry(e,n)}async*turnWithUsageLimitRetry(e,n){let r=null,o=null;for await(let l of this.turnWithAuthRetry(e,n)){if(l.type==="error"){let d=Nn(l.error);if(d&&d.kind==="oauth-limit"){o=d.resetsAt,r=l;break}}yield l}if(!o||!r)return;if(o.getTime()-Date.now()>Mf){yield r;return}let s=Mt(ye()??"");if(yield{type:"paused",reason:"usage-limit",resetsAt:o,accountId:s},!this.autoResumeOnUsageLimit){yield r;return}let i;if(this.usageLimitWaitPromise)i=await this.usageLimitWaitPromise;else{this.usageLimitWaitPromise=_o({resetsAt:o,signal:e.signal});try{i=await this.usageLimitWaitPromise}finally{this.usageLimitWaitPromise=null}}if(i==="aborted")return;let a=ye();e.headers=_e(this._authMode,this.initSessionId,Wi());let c=i==="hot-swap"?Mt(a??""):s;yield{type:"resumed",hotSwapped:i==="hot-swap",accountId:c},yield*this.turnWithAuthRetry(e,n)}async*turnWithAuthRetry(e,n){let r=null;for await(let s of gr(e)){if(n())return;if(s.type==="error"&&this.isRetryableAuth(s.error)){r=s;break}yield s}if(!r)return;let o=null;try{if(this.refreshPromise)o=await this.refreshPromise;else{this.refreshPromise=this.tokenRefresher();try{o=await this.refreshPromise??null}finally{this.refreshPromise=null}}}catch{this.refreshPromise=null}if(!o){yield r;return}this._client=o,e.client=this._client,e.headers=_e(this._authMode,this.initSessionId,Wi()),yield*gr(e)}isRetryableAuth(e){return this._authMode==="oauth"&&this.tokenRefresher!==void 0&&"status"in e&&e.status===401}};import{randomUUID as Nf}from"node:crypto";var Of=["You are a conversation-summarization assistant. The user will paste a","prior conversation between a user and an AI assistant that includes tool","calls and tool results. Produce a concise but complete summary that lets","the AI continue the conversation without losing track.","","Preserve, in this priority order:","1. The user's original intent, explicit asks, constraints, corrections,"," and preferences stated during the conversation.","2. Tool decisions and their outcomes \u2014 file paths read or written, shell"," commands run, search queries, URLs fetched, code edits made, tests"," run, errors observed, and whether each action succeeded or failed.","3. Current state: what has been completed, what remains unresolved, and"," the safest next action.","4. Open questions, pending decisions, blockers, and assumptions.","5. Key facts the assistant discovered (function locations, schemas,"," observed behaviors, important external findings).","","Drop prose narration, conversational filler, and exploratory dead-ends.","Drop verbatim tool output unless an exact snippet, error, path, command,","or result is needed for continuation.","Do not invent details. If something is uncertain, mark it explicitly.","Output plain text, no markdown headers. Aim for ~250 words; use up to","~400 only when needed to preserve tool state or unresolved tasks."].join(`
|
|
1546
|
+
`),Gi="[Compacted summary of earlier conversation]",Ki="Acknowledged. Continuing from the summary above.";function Df(t){if(t.role!=="user")return!1;let e=t.content;if(typeof e=="string")return!0;if(!Array.isArray(e))return!1;for(let n of e)if(n.type==="tool_result")return!1;return!0}function qi(t,e){if(e<=0)return t.length;let n=0;for(let r=t.length-1;r>=0;r--){let o=t[r];if(o&&Df(o)&&(n+=1,n===e))return r}return-1}function zi(t,e,n){let r=Ff(t);return{model:e,max_tokens:n,system:Of,messages:[{role:"user",content:`Summarize the following conversation transcript. Follow the system instructions exactly.
|
|
1547
1547
|
|
|
1548
1548
|
<transcript>
|
|
1549
1549
|
`+r+`
|
|
1550
1550
|
</transcript>`}],stream:!0}}function Ji(t,e,n){return[{role:"user",content:Gi+`
|
|
1551
1551
|
|
|
1552
1552
|
`+n},{role:"assistant",content:Ki},...t.slice(e)]}function Vi(t,e,n){let r=Lf(t.slice(0,e)),o=Gi.length+2+n.length+Ki.length,s=Math.max(0,r-o);return Math.round(s/4)}function Ff(t){let e=[];for(let n of t){let r=n.role==="user"?"User":"Assistant";if(e.push(r+":"),typeof n.content=="string")e.push(n.content);else if(Array.isArray(n.content))for(let o of n.content){let s=o.type;if(s==="text"&&"text"in o)e.push(o.text);else if(s==="tool_use"){let i=o.name??"unknown",a=Yi(o.input);e.push(`[tool call: ${i} ${a}]`)}else if(s==="tool_result"){let i=o.content;e.push(`[tool result: ${Xi(i)}]`)}else s==="image"?e.push("[image]"):s==="document"&&e.push("[document]")}e.push("")}return e.join(`
|
|
1553
|
-
`).trim()}function Yi(t){try{let e=JSON.stringify(t);return e.length>240?e.slice(0,237)+"...":e}catch{return"{}"}}function Xi(t){if(typeof t=="string")return t.length>320?t.slice(0,317)+"...":t;if(Array.isArray(t)){let e=[];for(let r of t)r.type==="text"&&"text"in r&&e.push(r.text);let n=e.join(" ");return n.length>320?n.slice(0,317)+"...":n}return""}function Lf(t){let e=0;for(let n of t)if(typeof n.content=="string")e+=n.content.length;else if(Array.isArray(n.content))for(let r of n.content){let o=r.type;o==="text"&&"text"in r?e+=r.text.length:o==="tool_use"?e+=Yi(r.input).length:o==="tool_result"&&(e+=Xi(r.content).length)}return e}var $f=2,Uf="claude-haiku-4-5-20251001",jf=1024;async function Qi(t){let{state:e,abort:n,retry:r,initSessionId:o,traceWriter:s}=t,i=e.messages.length;if(e.closed)return{compacted:!1,reason:"session-closed",messagesBefore:i,messagesAfter:i};if(!n.isIdle())return{compacted:!1,reason:"turn-in-flight",messagesBefore:i,messagesAfter:i};let a=Hf(),c=qi(e.messages,a);if(c<0)return{compacted:!1,reason:"history-too-short",messagesBefore:i,messagesAfter:i};if(c===0)return{compacted:!1,reason:"nothing-to-summarize",messagesBefore:i,messagesAfter:i};let l=e.messages.slice(0,c),d=Bf(),u=zi(l,d,jf),p=n.begin(),f;try{if(p.signal.aborted)return{compacted:!1,reason:"aborted",messagesBefore:i,messagesAfter:i};let b=_e(r.authMode,o,Nf()),h=r.client,y=await Promise.resolve(h.messages.create(u,{headers:b,signal:p.signal}));f=await Wf(y)}catch(b){return p.signal.aborted?{compacted:!1,reason:"aborted",messagesBefore:i,messagesAfter:i}:{compacted:!1,reason:"summarization-failed: "+(b instanceof Error?b.message:String(b)),messagesBefore:i,messagesAfter:i}}finally{n.clear(p)}if(f.trim().length===0)return{compacted:!1,reason:"empty-summary",messagesBefore:i,messagesAfter:i};let g=Vi(e.messages,c,f),m=Ji(e.messages,c,f);e.messages.splice(0,e.messages.length,...m);let w=e.messages.length;return No(s,{trigger:"manual",preCompactionMessages:l,summary:f,keptTailCount:i-c,keepLastNConfig:a,messagesBefore:i,messagesAfter:w,tokensSavedEstimate:g}),{compacted:!0,messagesBefore:i,messagesAfter:w,tokensSavedEstimate:g}}function Hf(){let t=process.env.AFK_COMPACT_KEEP_LAST_TURNS;if(t!==void 0&&t.length>0){let e=Number.parseInt(t,10);if(Number.isFinite(e)&&e>0)return e}return $f}function Bf(){let t=process.env.AFK_COMPACT_MODEL;return t!==void 0&&t.length>0?t:Uf}async function Wf(t){let e="";for await(let n of t)if(n.type==="content_block_delta"){let r=n.delta;r.type==="text_delta"&&typeof r.text=="string"&&(e+=r.text)}return e}var Gf=[{value:"claude-sonnet-4-5-20250929",displayName:"Claude Sonnet 4.5",description:"Latest balanced Claude \u2014 recommended default"},{value:"claude-opus-4-5-20250929",displayName:"Claude Opus 4.5",description:"Highest-capability Claude"},{value:"claude-haiku-4-5-20250929",displayName:"Claude Haiku 4.5",description:"Fastest, cheapest Claude"}],hn=class{initSessionId;promptStream;maxTokens;tools;systemPrefix;thinking;effort;baseUrl;traceWriter;state;abort;retry;cwdDependentsFactory;constructor(e){this.initSessionId=e.sessionId??Zi(),this.promptStream=e.promptStream,this.maxTokens=e.maxTokens,this.tools=e.tools,this.systemPrefix=e.systemPrefix,this.thinking=e.thinking,e.effort!==void 0&&(this.effort=e.effort),e.baseUrl!==void 0&&(this.baseUrl=e.baseUrl),this.traceWriter=e.traceWriter,this.cwdDependentsFactory=e.cwdDependentsFactory,this.retry=new gn({client:e.client,authMode:e.authMode,initSessionId:this.initSessionId,...e.tokenRefresher?{tokenRefresher:e.tokenRefresher}:{},autoResumeOnUsageLimit:e.autoResumeOnUsageLimit??!0}),this.state=ji({model:e.model,permissionMode:e.permissionMode??"default",userSystem:e.userSystem,toolDispatcher:e.toolDispatcher,...e.initialMessages?{initialMessages:e.initialMessages}:{}}),this.abort=new mn}async*[Symbol.asyncIterator](){yield{type:"session.init",info:{sessionId:this.initSessionId,model:this.state.currentModel,permissionMode:this.state.currentPermissionMode,cwd:process.cwd(),tools:[],slashCommands:[],skills:[],plugins:[],mcpServers:[],apiKeySource:this.retry.authMode,version:"anthropic-direct-v1"}};let n=this.promptStream[Symbol.asyncIterator]();try{for(;!this.state.closed;){let r=await Promise.race([n.next(),this.abort.closedPromise]);if(r==="__closed__")break;let o=r;if(o.done)break;let s=o.value,i=this.abort.begin();if(i.signal.aborted){this.abort.clear(i);return}Ui(this.state.messages),this.state.messages.push({role:"user",content:s.content});let a=this.composeSystem(),c=_e(this.retry.authMode,this.initSessionId,Zi(),this.effort!==void 0),l={client:this.retry.client,messages:this.state.messages,system:a,tools:this.tools,toolDispatcher:this.state.toolDispatcher,model:this.state.currentModel,maxTokens:this.maxTokens,headers:c,signal:i.signal,ctx:{sessionId:this.initSessionId},...this.thinking!==void 0?{thinking:this.thinking}:{},...this.effort!==void 0?{effort:this.effort}:{},...this.baseUrl!==void 0?{baseUrl:this.baseUrl}:{},...this.traceWriter?{traceWriter:this.traceWriter}:{}};try{for await(let d of this.retry.turnWithRetries(l,()=>this.state.closed)){if(this.state.closed)return;d.type==="turn.completed"&&(this.state.lastUsage=d.usage,this.abort.clear(i)),yield d}}catch(d){if(i.signal.aborted)return;yield{type:"error",error:d instanceof Error?d:new Error(String(d))};return}finally{this.abort.clear(i)}}}catch(r){yield{type:"error",error:r instanceof Error?r:new Error(String(r))}}finally{try{await n.return?.()}catch{}}}composeSystem(){let e=this.systemPrefix,n=this.state.userSystem,r=[];e&&e.length>0&&r.push(...e),n&&n.length>0&&r.push({type:"text",text:n});let o=Go(this.state.currentPermissionMode);return o!==null&&r.push(o),r.length===0?null:$t({baseUrl:this.baseUrl})?Ho(r,Ut()):r}async interrupt(){this.abort.requestAbort("interrupted")}async setModel(e){e!==void 0&&e.length>0&&(this.state.currentModel=e)}async setPermissionMode(e){this.state.currentPermissionMode=e}setCwd(e){if(!this.cwdDependentsFactory)return;let{userSystem:n,dispatcher:r}=this.cwdDependentsFactory(e);this.state.userSystem=n,this.state.toolDispatcher=r}async supportedCommands(){try{return Ce().map(n=>{let r={name:n.name,description:n.description};return n.argumentHint&&(r.argumentHint=n.argumentHint),r})}catch{return[]}}async supportedModels(){return Gf.map(e=>({...e}))}async supportedAgents(){return[]}async getContextUsage(){let e=this.state.lastUsage,n=sn(this.state.currentModel),r;if(e&&n>0){let o=(e.inputTokens??0)+(e.outputTokens??0)+(e.cachedInputTokens??0)+(e.cacheCreationTokens??0);r=Math.min(100,Math.max(0,o/n*100))}return{tools:[],agents:[],isAutoCompactEnabled:!1,apiUsage:this.state.lastUsage,...r!==void 0?{percentage:r}:{},maxTokens:n}}async mcpServerStatus(){return[]}async accountInfo(){return{subscriptionType:this.retry.authMode==="oauth"?"claude-subscription":"api-key"}}async rewindFiles(e,n){return{canRewind:!1,error:"anthropic-direct provider does not support file checkpoint rewind"}}async compact(){return Qi({state:this.state,abort:this.abort,retry:this.retry,initSessionId:this.initSessionId,...this.traceWriter?{traceWriter:this.traceWriter}:{}})}close(){this.state.closed=!0,this.abort.requestAbort("closed"),this.abort.markClosed()}};var hr=`You have access to tools for working with the filesystem and running commands. Follow these conventions:
|
|
1553
|
+
`).trim()}function Yi(t){try{let e=JSON.stringify(t);return e.length>240?e.slice(0,237)+"...":e}catch{return"{}"}}function Xi(t){if(typeof t=="string")return t.length>320?t.slice(0,317)+"...":t;if(Array.isArray(t)){let e=[];for(let r of t)r.type==="text"&&"text"in r&&e.push(r.text);let n=e.join(" ");return n.length>320?n.slice(0,317)+"...":n}return""}function Lf(t){let e=0;for(let n of t)if(typeof n.content=="string")e+=n.content.length;else if(Array.isArray(n.content))for(let r of n.content){let o=r.type;o==="text"&&"text"in r?e+=r.text.length:o==="tool_use"?e+=Yi(r.input).length:o==="tool_result"&&(e+=Xi(r.content).length)}return e}var $f=2,Uf="claude-haiku-4-5-20251001",jf=1024;async function Qi(t){let{state:e,abort:n,retry:r,initSessionId:o,traceWriter:s}=t,i=e.messages.length;if(e.closed)return{compacted:!1,reason:"session-closed",messagesBefore:i,messagesAfter:i};if(!n.isIdle())return{compacted:!1,reason:"turn-in-flight",messagesBefore:i,messagesAfter:i};let a=Hf(),c=qi(e.messages,a);if(c<0)return{compacted:!1,reason:"history-too-short",messagesBefore:i,messagesAfter:i};if(c===0)return{compacted:!1,reason:"nothing-to-summarize",messagesBefore:i,messagesAfter:i};let l=e.messages.slice(0,c),d=Bf(),u=zi(l,d,jf),p=n.begin(),f;try{if(p.signal.aborted)return{compacted:!1,reason:"aborted",messagesBefore:i,messagesAfter:i};let b=_e(r.authMode,o,Nf()),h=r.client,y=await Promise.resolve(h.messages.create(u,{headers:b,signal:p.signal}));f=await Wf(y)}catch(b){return p.signal.aborted?{compacted:!1,reason:"aborted",messagesBefore:i,messagesAfter:i}:{compacted:!1,reason:"summarization-failed: "+(b instanceof Error?b.message:String(b)),messagesBefore:i,messagesAfter:i}}finally{n.clear(p)}if(f.trim().length===0)return{compacted:!1,reason:"empty-summary",messagesBefore:i,messagesAfter:i};let g=Vi(e.messages,c,f),m=Ji(e.messages,c,f);e.messages.splice(0,e.messages.length,...m);let w=e.messages.length;return No(s,{trigger:"manual",preCompactionMessages:l,summary:f,keptTailCount:i-c,keepLastNConfig:a,messagesBefore:i,messagesAfter:w,tokensSavedEstimate:g}),{compacted:!0,messagesBefore:i,messagesAfter:w,tokensSavedEstimate:g}}function Hf(){let t=process.env.AFK_COMPACT_KEEP_LAST_TURNS;if(t!==void 0&&t.length>0){let e=Number.parseInt(t,10);if(Number.isFinite(e)&&e>0)return e}return $f}function Bf(){let t=process.env.AFK_COMPACT_MODEL;return t!==void 0&&t.length>0?t:Uf}async function Wf(t){let e="";for await(let n of t)if(n.type==="content_block_delta"){let r=n.delta;r.type==="text_delta"&&typeof r.text=="string"&&(e+=r.text)}return e}var Gf=[{value:"claude-sonnet-4-5-20250929",displayName:"Claude Sonnet 4.5",description:"Latest balanced Claude \u2014 recommended default"},{value:"claude-opus-4-5-20250929",displayName:"Claude Opus 4.5",description:"Highest-capability Claude"},{value:"claude-haiku-4-5-20250929",displayName:"Claude Haiku 4.5",description:"Fastest, cheapest Claude"}],hn=class{initSessionId;promptStream;maxTokens;tools;systemPrefix;thinking;effort;baseUrl;traceWriter;state;abort;retry;cwdDependentsFactory;mcpManager;constructor(e){this.initSessionId=e.sessionId??Zi(),this.promptStream=e.promptStream,this.maxTokens=e.maxTokens,this.tools=e.tools,this.systemPrefix=e.systemPrefix,this.thinking=e.thinking,e.effort!==void 0&&(this.effort=e.effort),e.baseUrl!==void 0&&(this.baseUrl=e.baseUrl),this.traceWriter=e.traceWriter,this.cwdDependentsFactory=e.cwdDependentsFactory,this.mcpManager=e.mcpManager,this.retry=new gn({client:e.client,authMode:e.authMode,initSessionId:this.initSessionId,...e.tokenRefresher?{tokenRefresher:e.tokenRefresher}:{},autoResumeOnUsageLimit:e.autoResumeOnUsageLimit??!0}),this.state=ji({model:e.model,permissionMode:e.permissionMode??"default",userSystem:e.userSystem,toolDispatcher:e.toolDispatcher,...e.initialMessages?{initialMessages:e.initialMessages}:{}}),this.abort=new mn}async*[Symbol.asyncIterator](){yield{type:"session.init",info:{sessionId:this.initSessionId,model:this.state.currentModel,permissionMode:this.state.currentPermissionMode,cwd:process.cwd(),tools:[],slashCommands:[],skills:[],plugins:[],mcpServers:this.mcpManager?.getServerStates().map(r=>({name:r.serverName,status:r.status}))??[],apiKeySource:this.retry.authMode,version:"anthropic-direct-v1"}};let n=this.promptStream[Symbol.asyncIterator]();try{for(;!this.state.closed;){let r=await Promise.race([n.next(),this.abort.closedPromise]);if(r==="__closed__")break;let o=r;if(o.done)break;let s=o.value,i=this.abort.begin();if(i.signal.aborted){this.abort.clear(i);return}Ui(this.state.messages),this.state.messages.push({role:"user",content:s.content});let a=this.composeSystem(),c=_e(this.retry.authMode,this.initSessionId,Zi(),this.effort!==void 0),l={client:this.retry.client,messages:this.state.messages,system:a,tools:this.tools,toolDispatcher:this.state.toolDispatcher,model:this.state.currentModel,maxTokens:this.maxTokens,headers:c,signal:i.signal,ctx:{sessionId:this.initSessionId},...this.thinking!==void 0?{thinking:this.thinking}:{},...this.effort!==void 0?{effort:this.effort}:{},...this.baseUrl!==void 0?{baseUrl:this.baseUrl}:{},...this.traceWriter?{traceWriter:this.traceWriter}:{}};try{for await(let d of this.retry.turnWithRetries(l,()=>this.state.closed)){if(this.state.closed)return;d.type==="turn.completed"&&(this.state.lastUsage=d.usage,this.abort.clear(i)),yield d}}catch(d){if(i.signal.aborted)return;yield{type:"error",error:d instanceof Error?d:new Error(String(d))};return}finally{this.abort.clear(i)}}}catch(r){yield{type:"error",error:r instanceof Error?r:new Error(String(r))}}finally{try{await n.return?.()}catch{}}}composeSystem(){let e=this.systemPrefix,n=this.state.userSystem,r=[];e&&e.length>0&&r.push(...e),n&&n.length>0&&r.push({type:"text",text:n});let o=Go(this.state.currentPermissionMode);return o!==null&&r.push(o),r.length===0?null:$t({baseUrl:this.baseUrl})?Ho(r,Ut()):r}async interrupt(){this.abort.requestAbort("interrupted")}async setModel(e){e!==void 0&&e.length>0&&(this.state.currentModel=e)}async setPermissionMode(e){this.state.currentPermissionMode=e}setCwd(e){if(!this.cwdDependentsFactory)return;let{userSystem:n,dispatcher:r}=this.cwdDependentsFactory(e);this.state.userSystem=n,this.state.toolDispatcher=r}async supportedCommands(){try{return Ce().map(n=>{let r={name:n.name,description:n.description};return n.argumentHint&&(r.argumentHint=n.argumentHint),r})}catch{return[]}}async supportedModels(){return Gf.map(e=>({...e}))}async supportedAgents(){return[]}async getContextUsage(){let e=this.state.lastUsage,n=sn(this.state.currentModel),r;if(e&&n>0){let o=(e.inputTokens??0)+(e.outputTokens??0)+(e.cachedInputTokens??0)+(e.cacheCreationTokens??0);r=Math.min(100,Math.max(0,o/n*100))}return{tools:[],agents:[],isAutoCompactEnabled:!1,apiUsage:this.state.lastUsage,...r!==void 0?{percentage:r}:{},maxTokens:n}}async mcpServerStatus(){return this.mcpManager?this.mcpManager.getServerStates().map(e=>({name:e.serverName,status:e.status})):[]}async accountInfo(){return{subscriptionType:this.retry.authMode==="oauth"?"claude-subscription":"api-key"}}async rewindFiles(e,n){return{canRewind:!1,error:"anthropic-direct provider does not support file checkpoint rewind"}}async compact(){return Qi({state:this.state,abort:this.abort,retry:this.retry,initSessionId:this.initSessionId,...this.traceWriter?{traceWriter:this.traceWriter}:{}})}close(){this.state.closed=!0,this.abort.requestAbort("closed"),this.abort.markClosed()}};var hr=`You have access to tools for working with the filesystem and running commands. Follow these conventions:
|
|
1554
1554
|
|
|
1555
1555
|
- Use read_file before editing to verify the exact content you want to change.
|
|
1556
1556
|
- Prefer edit_file over write_file for modifying existing files \u2014 write_file is for new files or complete rewrites.
|
|
@@ -1594,21 +1594,21 @@ Save reusable multi-step workflows the user teaches you or that you discover wor
|
|
|
1594
1594
|
`);let n=t.options,r=typeof n=="object"&&n!==null?n.systemPrompt:void 0,o=tm(r),s={timestamp:new Date().toISOString(),prompt:t.prompt,options:em(t.options),provenance:t.provenance,resolution:o};if(e==="1"||e.toLowerCase()==="true"||e.toLowerCase()==="stderr"){let c=JSON.stringify(s,null,2)+`
|
|
1595
1595
|
`;process.stderr.write(c);return}let i=Jf(e),a=Vf(i);try{Kf(a,{recursive:!0});let l=(!zf(i)?Yf:"")+JSON.stringify(s)+`
|
|
1596
1596
|
`;qf(i,l)}catch(c){let l=`[prompt-dump] Failed to write to ${i}: ${String(c)}
|
|
1597
|
-
`;process.stderr.write(l)}}var na="anthropic-direct",sm="claude-sonnet-4-5-20250929",im=t=>/opus-4-(7|[89])/.test(t),ra=null;var ie=class{name=na;externalTools;memoryStore;providerFactory;skillExecutor;schemas;hookRegistry;permissions;subagentExecutor;composeExecutor;surface;_sharedReadRoots;_sharedWriteRoots;_initialResolveBase;constructor(e={}){let n=[...fe];e.subagentExecutor&&n.push(Ae),e.skillExecutor&&n.push(Re),e.composeExecutor&&n.push(Pe),n.push(...ge),this.memoryStore=e.memoryStore??new V,this.externalTools=e.tools,this.skillExecutor=e.skillExecutor,this.schemas=n,this.hookRegistry=e.hookRegistry,this.permissions=e.permissions,this.subagentExecutor=e.subagentExecutor,this.composeExecutor=e.composeExecutor,this.surface=e.surface??"cli",e.clientFactory&&(this.providerFactory=e.clientFactory)}buildDispatcher(e,n){let r=on(e,n?.cwd),o=Ze(this.memoryStore,void 0,this.surface);for(let[
|
|
1598
|
-
`)}catch{}}query(e){let n=e.config,r=typeof n.baseUrl=="string"&&n.baseUrl.length>0,o=r?n.apiKey&&n.apiKey.length>0?n.apiKey:process.env.AFK_LOCAL_API_KEY||"local":n.apiKey&&n.apiKey.length>0?n.apiKey:process.env.ANTHROPIC_API_KEY||process.env.CLAUDE_CODE_OAUTH_TOKEN||"";if(!o||o.length===0)throw new Error(`${na} provider requires config.apiKey (resolved from ANTHROPIC_API_KEY or CLAUDE_CODE_OAUTH_TOKEN)`);let s=Nt(o),i=Un(o,s,n.baseUrl),a=this.providerFactory??ra,c=a?a(i):new ta(i),l=r?null:jo(s),d=am(n.systemPrompt),u=typeof n.model=="string"&&n.model.length>0?
|
|
1597
|
+
`;process.stderr.write(l)}}var na="anthropic-direct",sm="claude-sonnet-4-5-20250929",im=t=>/opus-4-(7|[89])/.test(t),ra=null;var ie=class{name=na;externalTools;memoryStore;providerFactory;skillExecutor;schemas;hookRegistry;permissions;subagentExecutor;composeExecutor;surface;mcpManager;_sharedReadRoots;_sharedWriteRoots;_initialResolveBase;_mcpToolsCache=null;_mcpHandlersCache=null;constructor(e={}){let n=[...fe];if(e.subagentExecutor&&n.push(Ae),e.skillExecutor&&n.push(Re),e.composeExecutor&&n.push(Pe),n.push(...ge),this.memoryStore=e.memoryStore??new V,this.externalTools=e.tools,this.skillExecutor=e.skillExecutor,this.schemas=n,this.hookRegistry=e.hookRegistry,this.permissions=e.permissions,this.subagentExecutor=e.subagentExecutor,this.composeExecutor=e.composeExecutor,this.surface=e.surface??"cli",this.mcpManager=e.mcpManager,e.mcpManager){let r=e.mcpManager.onToolsRefreshed;e.mcpManager.onToolsRefreshed=o=>{this._mcpToolsCache=null,this._mcpHandlersCache=null,r?.(o)}}e.clientFactory&&(this.providerFactory=e.clientFactory)}buildDispatcher(e,n){let r=on(e,n?.cwd),o=Ze(this.memoryStore,void 0,this.surface);for(let[i,a]of o)r.set(i,a);if(this.mcpManager){this._mcpToolsCache||(this._mcpToolsCache=this.mcpManager.getMcpTools()),this._mcpHandlersCache||(this._mcpHandlersCache=this.mcpManager.getMcpHandlers());for(let[i,a]of this._mcpHandlersCache)r.set(i,a)}let s=this._mcpToolsCache??[];return new Ie({handlers:r,schemas:[...this.schemas,...s],hookRegistry:this.hookRegistry,permissions:this.permissions,subagentExecutor:this.subagentExecutor,skillExecutor:this.skillExecutor,composeExecutor:this.composeExecutor,cwd:n?.cwd,readRoots:n?.readRoots,writeRoots:n?.writeRoots,...n?.env!==void 0?{env:n.env}:{},sessionId:n?.sessionId,...n?.traceWriter?{traceWriter:n.traceWriter}:{}})}close(){this.memoryStore.close()}ensureSharedRoots(e){if(!this._sharedReadRoots){let n=e?[e]:[];this._sharedReadRoots=n.slice(),this._sharedWriteRoots=n.slice(),e&&!this._initialResolveBase&&(this._initialResolveBase=e)}}addReadRoot(e,n="slash",r){this.ensureSharedRoots();let o=wr.resolve(e);this._sharedReadRoots.includes(o)||this._sharedReadRoots.push(o),this.appendProviderAuditLog({action:"grant-read",path:o,source:n,sessionId:r})}addWriteRoot(e,n="slash",r){this.ensureSharedRoots();let o=wr.resolve(e);this._sharedReadRoots.includes(o)||this._sharedReadRoots.push(o),this._sharedWriteRoots.includes(o)||this._sharedWriteRoots.push(o),this.appendProviderAuditLog({action:"grant-write",path:o,source:n,sessionId:r})}revokeRoot(e,n="slash",r){if(!this._sharedReadRoots)return;let o=wr.resolve(e);if(this._initialResolveBase&&o===this._initialResolveBase)return;let s=this._sharedReadRoots.indexOf(o);if(s!==-1&&this._sharedReadRoots.splice(s,1),this._sharedWriteRoots){let i=this._sharedWriteRoots.indexOf(o);i!==-1&&this._sharedWriteRoots.splice(i,1)}this.appendProviderAuditLog({action:"revoke",path:o,source:n,sessionId:r})}getGrants(){return{resolveBase:this._initialResolveBase,readRoots:this._sharedReadRoots?.slice()??[],writeRoots:this._sharedWriteRoots?.slice()??[]}}appendProviderAuditLog(e){try{let n=Le();rm(om(n),{recursive:!0});let r=JSON.stringify({timestamp:new Date().toISOString(),sessionId:e.sessionId??null,action:e.action,path:e.path,source:e.source});nm(n,r+`
|
|
1598
|
+
`)}catch{}}query(e){let n=e.config,r=typeof n.baseUrl=="string"&&n.baseUrl.length>0,o=r?n.apiKey&&n.apiKey.length>0?n.apiKey:process.env.AFK_LOCAL_API_KEY||"local":n.apiKey&&n.apiKey.length>0?n.apiKey:process.env.ANTHROPIC_API_KEY||process.env.CLAUDE_CODE_OAUTH_TOKEN||"";if(!o||o.length===0)throw new Error(`${na} provider requires config.apiKey (resolved from ANTHROPIC_API_KEY or CLAUDE_CODE_OAUTH_TOKEN)`);let s=Nt(o),i=Un(o,s,n.baseUrl),a=this.providerFactory??ra,c=a?a(i):new ta(i),l=r?null:jo(s),d=am(n.systemPrompt),u=typeof n.model=="string"&&n.model.length>0?Oe(n.model)??n.model:sm,p=cm(n,u),f=n.permissionMode??"default";this.ensureSharedRoots(n.cwd),n.readRoots&&this._sharedReadRoots&&this._sharedReadRoots.length<=1&&(this._sharedReadRoots.length=0,this._sharedReadRoots.push(...n.readRoots)),n.writeRoots&&this._sharedWriteRoots&&this._sharedWriteRoots.length<=1&&(this._sharedWriteRoots.length=0,this._sharedWriteRoots.push(...n.writeRoots));let g=this.externalTools??this.buildDispatcher(f,{cwd:n.cwd,readRoots:this._sharedReadRoots,writeRoots:this._sharedWriteRoots,...n.env!==void 0?{env:n.env}:{},sessionId:n.sessionId,traceWriter:n.traceWriter}),m=g instanceof Ie?[...g.toolDefs]:[...fe],w=this.skillExecutor?$i():"",b=n.cwd||process.cwd(),h=[hr,yr];h.push(`# Environment
|
|
1599
1599
|
- Working directory: ${b}`),w.length>0&&h.push(w),d&&h.push(d);let y=h.join(`
|
|
1600
1600
|
|
|
1601
1601
|
`),k=[hr,yr];w.length>0&&k.push(w),d&&k.push(d),ea({prompt:e.prompt,options:{model:u,maxTokens:p,system:y},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 _;if(s==="oauth"&&!r){let R=this.providerFactory??ra;_=async()=>{let F=await Ln();if(!F)return null;let v=Un(F,"oauth",n.baseUrl);return R?R(v):new ta(v)}}let I=n.sessionId??n.resume,S=lm(n.resumeHistory),x=this.externalTools?void 0:R=>{let v=[k[0],k[1],`# Environment
|
|
1602
1602
|
- Working directory: ${R}`,...k.slice(2)].join(`
|
|
1603
1603
|
|
|
1604
|
-
`),E=this.buildDispatcher(f,{cwd:R,readRoots:this._sharedReadRoots,writeRoots:this._sharedWriteRoots,...n.env!==void 0?{env:n.env}:{},sessionId:n.sessionId,traceWriter:n.traceWriter});return{userSystem:v,dispatcher:E}},A=um(n.effort,u);return new hn({client:c,authMode:r?"api-key":s,promptStream:e.prompt,toolDispatcher:g,...I!==void 0?{sessionId:I}:{},...S!==void 0?{initialMessages:S}:{},model:u,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},maxTokens:p,tools:m,userSystem:y,systemPrefix:l,tokenRefresher:_,...n.thinking!==void 0?{thinking:dm(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}:{},...x!==void 0?{cwdDependentsFactory:x}:{}})}};function am(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}function cm(t,e){let n=t.maxOutputTokens;return typeof n=="number"&&Number.isFinite(n)&&n>0?Math.floor(n):ni(e)}function lm(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 dm(t,e,n){switch(t.type){case"adaptive":return{type:"adaptive",display:"summarized"};case"disabled":return{type:"disabled"};case"enabled":{if(typeof n=="string"&&im(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 um(t,e){if(t!==void 0)return t;let n=e.toLowerCase();if(/(claude-)?(opus|sonnet)-4-[67]/.test(n))return"max"}var pm=new ie;var fm=new Set([...Object.keys(cn),"auto"]);function We(t){if(!t)return"anthropic-direct";let e=t.trim().toLowerCase();return!e||fm.has(e)||e.startsWith("claude-")||e.startsWith("claude_")?"anthropic-direct":e.startsWith("gpt-")||e.startsWith("gpt_")||e.startsWith("o1")||e.startsWith("o3")||e.startsWith("o4")||e.startsWith("codex-")||e.startsWith("codex_")||e==="codex"||e.includes("/")?"openai-compatible":"anthropic-direct"}function oa(t){switch(We(t)){case"openai-compatible":case"openai-codex":return new Me;default:return new ie}}async function yn(t,e,n){if(!t)return;if(n.kind==="blocked"){await Ue(t,{hookEvent:e,decision:"block",...n.err.reason!==void 0?{reason:n.err.reason}:{}});return}let r=n.decision;await Ue(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 sa(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await yn(n.traceWriter,"SessionStart",{kind:"decision",decision:r})}catch(r){throw r instanceof B&&await yn(n.traceWriter,"SessionStart",{kind:"blocked",err:r}),r}}async function ia(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await yn(n.traceWriter,"SessionEnd",{kind:"decision",decision:r})}catch(r){if(r instanceof B&&await yn(n.traceWriter,"SessionEnd",{kind:"blocked",err:r}),r instanceof B||r instanceof Z){C(`SessionEnd hook swallowed ${r.name}: ${r.message}`),n.onError?.(r);return}C(`SessionEnd hook unexpected error: ${String(r)}`),n.onError?.(r instanceof Error?r:new Error(String(r)))}}var bn=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 aa(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 ca(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 wn=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 la(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 da(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 ua(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 kr(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)?pa(mm(o)):o!==null&&typeof o=="object"?pa(gm(o)):null}function mm(t){return t.length===0?"[empty array]":t.length===1?"[1 item]":`[${t.length} items]`}function gm(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 pa(t){return t.length<=80?t:t.slice(0,79)+"\u2026"}var hm=new Map([["memory_search",la],["memory_update",da],["procedure_write",ua],["bash",kr],["Bash",kr]]);function ym(t){return t.replace(/\x1b\[[0-?]*[ -/]*[@-~]/g,"").replace(/\x1b[@-_]/g,"").replace(/[\x00-\x1f\x7f]/g," ").trim()}function fa(t,e){if(!t)return null;let n=hm.get(t);if(!n)return null;try{let r=n(e);if(r===null)return null;let o=ym(r);return o.length>0?o:null}catch{return null}}function bm(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 wm(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 km(t){let e=Buffer.byteLength(t,"utf8"),n=wm(e),r=t.split(`
|
|
1605
|
-
`);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 vm(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 Sm(t){let e=t.isError===!0?null:fa(t.toolName,t.content),n=e!==null?{display:e}:{},r=bm(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,truncated:s,lineCount:i,sizeBytes:a,sizeLabel:c}=km(t.content);return{type:"chunk",chunk:{type:"tool_result",toolUseId:t.toolUseId,content:o,isError:t.isError===!0,sizeBytes:a,sizeLabel:c,...s&&{truncated:s},...i!==void 0&&{lineCount:i},...n}}}function vr(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 Sm(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=vm(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 $e(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}:{}};case"resumed":return{type:"resumed",hotSwapped:t.hotSwapped,...t.accountId!==void 0?{accountId:t.accountId}:{}};default:return null}}var we=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,aa(e.abortSignal,this.abortController,()=>{this.onAbort()}),this.initSdkLifecycle()}initSdkLifecycle(){let e=De(this.config.model)??this.config.model,{sessionIdentity:n,metadata:r}=ca(this.config,e);this.stateManager=new wn(n,r),this.inputStream=new bn(()=>this.sessionId);let o=this.config.provider??oa(e);C(`\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 sa(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=vr(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}async sendMessage(e,n={}){this.assertCanSend();let r=this.config.timeoutMs??Wt,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=vr(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 Z("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,jn))]).catch(()=>{}),this.stateManager.resolveInitializationIfNeeded();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=De(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)}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{this.providerQuery.close()}catch{}if(await this.providerIterator.return?.(),this.initPromise)try{await Promise.race([this.initPromise,new Promise(e=>setTimeout(e,jn))])}catch{}await this.dispatchSessionEndOnce("close")}}async dispatchSessionEndOnce(e){this.sessionEndDispatched||(this.sessionEndDispatched=!0,await this.emitClosure(e).catch(()=>{}),await this.sealTraceWriter(e).catch(()=>{}),await ia(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 $o(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 $e)return"budget_exceeded";if(r instanceof ae)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 Z("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 xr=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){Sr(n,e.event);let r=this.handlers.get(e.event);if(!r||r.length===0)return{};let o=r.slice(),s={};for(let i of o){Sr(n,e.event);let a;try{a=await i(e)}catch(c){throw new B(`hook handler threw during ${e.event}`,e.event,c instanceof Error?c.message:String(c),{cause:c})}if(Sr(n,e.event),xm(a))throw new B(`hook handler blocked ${e.event}${a.reason?`: ${a.reason}`:""}`,e.event,a.reason);s=a}return s}};function xm(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 Z(r)}}function ma(){return new xr}function ga(){return ma()}var Em=["shadow-verify","shadow_verify","resolve","diagnose","appmap","qualify","mint"],Tm=[/\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],_m=[/\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],Am=`shadow-verify nudge:
|
|
1604
|
+
`),E=this.buildDispatcher(f,{cwd:R,readRoots:this._sharedReadRoots,writeRoots:this._sharedWriteRoots,...n.env!==void 0?{env:n.env}:{},sessionId:n.sessionId,traceWriter:n.traceWriter});return{userSystem:v,dispatcher:E}},A=um(n.effort,u);return new hn({client:c,authMode:r?"api-key":s,promptStream:e.prompt,toolDispatcher:g,...I!==void 0?{sessionId:I}:{},...S!==void 0?{initialMessages:S}:{},model:u,...n.permissionMode!==void 0?{permissionMode:n.permissionMode}:{},maxTokens:p,tools:m,userSystem:y,systemPrefix:l,tokenRefresher:_,...n.thinking!==void 0?{thinking:dm(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}:{},...x!==void 0?{cwdDependentsFactory:x}:{},...this.mcpManager!==void 0?{mcpManager:this.mcpManager}:{}})}};function am(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}function cm(t,e){let n=t.maxOutputTokens;return typeof n=="number"&&Number.isFinite(n)&&n>0?Math.floor(n):ni(e)}function lm(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 dm(t,e,n){switch(t.type){case"adaptive":return{type:"adaptive",display:"summarized"};case"disabled":return{type:"disabled"};case"enabled":{if(typeof n=="string"&&im(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 um(t,e){if(t!==void 0)return t;let n=e.toLowerCase();if(/(claude-)?(opus|sonnet)-4-[67]/.test(n))return"max"}var pm=new ie;var fm=new Set([...Object.keys(cn),"auto"]);function We(t){if(!t)return"anthropic-direct";let e=t.trim().toLowerCase();return!e||fm.has(e)||e.startsWith("claude-")||e.startsWith("claude_")?"anthropic-direct":e.startsWith("gpt-")||e.startsWith("gpt_")||e.startsWith("o1")||e.startsWith("o3")||e.startsWith("o4")||e.startsWith("codex-")||e.startsWith("codex_")||e==="codex"||e.includes("/")?"openai-compatible":"anthropic-direct"}function oa(t){switch(We(t)){case"openai-compatible":case"openai-codex":return new Me;default:return new ie}}async function yn(t,e,n){if(!t)return;if(n.kind==="blocked"){await Ue(t,{hookEvent:e,decision:"block",...n.err.reason!==void 0?{reason:n.err.reason}:{}});return}let r=n.decision;await Ue(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 sa(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await yn(n.traceWriter,"SessionStart",{kind:"decision",decision:r})}catch(r){throw r instanceof B&&await yn(n.traceWriter,"SessionStart",{kind:"blocked",err:r}),r}}async function ia(t,e,n={}){if(t)try{let r=await t.dispatch(e,n.signal);await yn(n.traceWriter,"SessionEnd",{kind:"decision",decision:r})}catch(r){if(r instanceof B&&await yn(n.traceWriter,"SessionEnd",{kind:"blocked",err:r}),r instanceof B||r instanceof Z){C(`SessionEnd hook swallowed ${r.name}: ${r.message}`),n.onError?.(r);return}C(`SessionEnd hook unexpected error: ${String(r)}`),n.onError?.(r instanceof Error?r:new Error(String(r)))}}var bn=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 aa(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 ca(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 wn=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 la(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 da(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 ua(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 kr(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)?pa(mm(o)):o!==null&&typeof o=="object"?pa(gm(o)):null}function mm(t){return t.length===0?"[empty array]":t.length===1?"[1 item]":`[${t.length} items]`}function gm(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 pa(t){return t.length<=80?t:t.slice(0,79)+"\u2026"}var hm=new Map([["memory_search",la],["memory_update",da],["procedure_write",ua],["bash",kr],["Bash",kr]]);function ym(t){return t.replace(/\x1b\[[0-?]*[ -/]*[@-~]/g,"").replace(/\x1b[@-_]/g,"").replace(/[\x00-\x1f\x7f]/g," ").trim()}function fa(t,e){if(!t)return null;let n=hm.get(t);if(!n)return null;try{let r=n(e);if(r===null)return null;let o=ym(r);return o.length>0?o:null}catch{return null}}function bm(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 wm(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 km(t){let e=Buffer.byteLength(t,"utf8"),n=wm(e),r=t.split(`
|
|
1605
|
+
`);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 vm(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 Sm(t){let e=t.isError===!0?null:fa(t.toolName,t.content),n=e!==null?{display:e}:{},r=bm(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,truncated:s,lineCount:i,sizeBytes:a,sizeLabel:c}=km(t.content);return{type:"chunk",chunk:{type:"tool_result",toolUseId:t.toolUseId,content:o,isError:t.isError===!0,sizeBytes:a,sizeLabel:c,...s&&{truncated:s},...i!==void 0&&{lineCount:i},...n}}}function vr(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 Sm(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=vm(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 $e(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}:{}};case"resumed":return{type:"resumed",hotSwapped:t.hotSwapped,...t.accountId!==void 0?{accountId:t.accountId}:{}};default:return null}}var we=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,aa(e.abortSignal,this.abortController,()=>{this.onAbort()}),this.initSdkLifecycle()}initSdkLifecycle(){let e=Oe(this.config.model)??this.config.model,{sessionIdentity:n,metadata:r}=ca(this.config,e);this.stateManager=new wn(n,r),this.inputStream=new bn(()=>this.sessionId);let o=this.config.provider??oa(e);C(`\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 sa(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=vr(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}async sendMessage(e,n={}){this.assertCanSend();let r=this.config.timeoutMs??Wt,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=vr(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 Z("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,jn))]).catch(()=>{}),this.stateManager.resolveInitializationIfNeeded();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=Oe(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)}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{this.providerQuery.close()}catch{}if(await this.providerIterator.return?.(),this.initPromise)try{await Promise.race([this.initPromise,new Promise(e=>setTimeout(e,jn))])}catch{}await this.dispatchSessionEndOnce("close")}}async dispatchSessionEndOnce(e){this.sessionEndDispatched||(this.sessionEndDispatched=!0,await this.emitClosure(e).catch(()=>{}),await this.sealTraceWriter(e).catch(()=>{}),await ia(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 $o(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 $e)return"budget_exceeded";if(r instanceof ae)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 Z("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 xr=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){Sr(n,e.event);let r=this.handlers.get(e.event);if(!r||r.length===0)return{};let o=r.slice(),s={};for(let i of o){Sr(n,e.event);let a;try{a=await i(e)}catch(c){throw new B(`hook handler threw during ${e.event}`,e.event,c instanceof Error?c.message:String(c),{cause:c})}if(Sr(n,e.event),xm(a))throw new B(`hook handler blocked ${e.event}${a.reason?`: ${a.reason}`:""}`,e.event,a.reason);s=a}return s}};function xm(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 Z(r)}}function ma(){return new xr}function ga(){return ma()}var Em=["shadow-verify","shadow_verify","resolve","diagnose","appmap","qualify","mint"],Tm=[/\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],_m=[/\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],Am=`shadow-verify nudge:
|
|
1606
1606
|
|
|
1607
1607
|
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).
|
|
1608
1608
|
|
|
1609
1609
|
Single-pass sub-agent reports are prone to confident hallucination \u2014 polished output that falls apart on re-derivation. Before acting on these conclusions, consider dispatching \`/shadow-verify\`. Independent verifiers will re-derive the 2\u20133 most load-bearing claims from scratch (without seeing the original reasoning) and flag any that don't hold up.
|
|
1610
1610
|
|
|
1611
|
-
Skip when: the findings are purely exploratory, the sub-agent ran inside an already-verifying orchestrator, the user is about to dismiss the report, or the stakes are low (read-only Q&A).`;function Rm(t){if(!t)return!1;let e=t.toLowerCase();return Em.some(n=>e.includes(n))}function Pm(t){return _m.some(e=>e.test(t))}function Im(t){let e=0;for(let n of Tm)n.test(t)&&e++;return e}function ha(t){if(t.event!=="SubagentStop")return{};let e=t.lastMessage??"";return e.length<600?{}:Rm(t.agentType)?{}:Pm(e)?{}:Im(e)<2?{}:{injectContext:Am}}var Cm=new Set(["Read","Glob","Grep","NotebookRead","LS","read_file","glob","grep","list_directory","memory_search"]),Mm=new Set(["Write","Edit","NotebookEdit","MultiEdit","write_file","edit_file","memory_update","procedure_write"]),
|
|
1611
|
+
Skip when: the findings are purely exploratory, the sub-agent ran inside an already-verifying orchestrator, the user is about to dismiss the report, or the stakes are low (read-only Q&A).`;function Rm(t){if(!t)return!1;let e=t.toLowerCase();return Em.some(n=>e.includes(n))}function Pm(t){return _m.some(e=>e.test(t))}function Im(t){let e=0;for(let n of Tm)n.test(t)&&e++;return e}function ha(t){if(t.event!=="SubagentStop")return{};let e=t.lastMessage??"";return e.length<600?{}:Rm(t.agentType)?{}:Pm(e)?{}:Im(e)<2?{}:{injectContext:Am}}var Cm=new Set(["Read","Glob","Grep","NotebookRead","LS","read_file","glob","grep","list_directory","memory_search"]),Mm=new Set(["Write","Edit","NotebookEdit","MultiEdit","write_file","edit_file","memory_update","procedure_write"]),Om=new Set(["Bash","BashOutput","KillBash","bash"]),ya=new Set(["Agent","Task","agent"]),ba=new Set(["Skill","skill"]),wa=new Set(["Compose","compose"]),GT=new Set([...ya,...wa,...ba]),Dm=new Set(["WebFetch","WebSearch","send_telegram","web_scrape"]),Fm=new Set(["TaskCreate","TaskUpdate","TaskList","TaskGet","TaskOutput","TaskStop","EnterPlanMode","ExitPlanMode","ToolSearch"]),Lm=new Set(["create_schedule","list_schedules","get_schedule_history","cancel_schedule"]);function ve(t,e){if(t.has(e))return!0;let n=e.charAt(0).toUpperCase()+e.slice(1);return n!==e&&t.has(n)}function ka(t){return t.startsWith("mcp__")||t.startsWith("MCP__")?"mcp":ve(Cm,t)?"read":ve(Mm,t)?"write":ve(Om,t)?"shell":ve(ya,t)?"subagent":ve(ba,t)?"skill":ve(wa,t)?"dag":ve(Dm,t)?"web":ve(Fm,t)?"planning":Lm.has(t)?"schedule":"other"}var Nm=["git commit","git push","git reset","rm ","mv ","mkdir","touch","chmod","chown","cp ","tee "," > "," >> ","npm install","pnpm install","pip install","apt ","apt-get ","brew install"," && "];function va(t){return function(n){if(n.event!=="PreToolUse")return{};if(t()!=="plan")return{};let{toolName:r}=n;if(ka(r)==="write")return{decision:"block",reason:`plan mode: ${r} is refused. Use /plan off to exit plan mode.`};if(r==="bash"){let o=typeof n.input=="object"&&n.input!==null?String(n.input.command??""):"";if(Nm.some(i=>o.includes(i)))return{decision:"block",reason:"plan mode: write-intent bash is refused. Use /plan off or rephrase as a read-only command."}}return{}}}import{mkdirSync as jm,rmSync as Hm,writeFileSync as Bm}from"fs";import{join as Er}from"path";function $m(t){let e=new Set;for(let a of t.nodes){if(e.has(a.id))throw new Error(`Duplicate node ID: ${a.id}`);e.add(a.id)}let n=new Set;for(let a of t.edges){if(!e.has(a.from))throw new Error(`Edge references non-existent node: ${a.from}`);if(!e.has(a.to))throw new Error(`Edge references non-existent node: ${a.to}`);let c=`${a.from}->${a.to}`;if(n.has(c))throw new Error(`Duplicate edge: ${a.from} -> ${a.to}`);n.add(c)}let r=Sa(t),o=new Map(r.inDegree),s=[];for(let[a,c]of o)c===0&&s.push(a);let i=0;for(;s.length>0;){let a=s.shift();i+=1;for(let c of r.downstream.get(a)??[]){let l=o.get(c)-1;o.set(c,l),l===0&&s.push(c)}}if(i!==e.size)throw new Error("Cycle detected in DAG")}function Sa(t){let e=new Map,n=new Map,r=new Map;for(let o of t.nodes)e.set(o.id,new Set),n.set(o.id,new Set),r.set(o.id,0);for(let o of t.edges)e.get(o.from).add(o.to),n.get(o.to).add(o.from),r.set(o.to,r.get(o.to)+1);return{downstream:e,upstream:n,inDegree:r}}function Um(t,e,n){let r=[t];for(;r.length>0;){let o=r.shift();for(let s of e.get(o)??[])n.has(s)||(n.add(s),r.push(s))}}async function xa(t,e,n={}){if(t.nodes.length===0)return{outputs:{},failed:[],skipped:[]};$m(t);let{failFast:r=!0,nodeTimeoutMs:o}=n,s=o!==void 0&&Number.isFinite(o)&&o>0,i=Sa(t),a=new Map(t.nodes.map(m=>[m.id,m])),c={},l=[],d=new Set,u=new Set,p=new Map(i.inDegree),f=new AbortController,g=()=>{f.signal.aborted||f.abort(e.reason)};e.aborted?f.abort(e.reason):e.addEventListener("abort",g,{once:!0});try{for(;!f.signal.aborted;){let m=[];for(let[b,h]of p)h===0&&!u.has(b)&&!d.has(b)&&m.push(b);if(m.length===0)break;let w=await Promise.allSettled(m.map(async b=>{let h=a.get(b),y=new AbortController,k=()=>{y.signal.aborted||y.abort(f.signal.reason)};f.signal.aborted?y.abort(f.signal.reason):f.signal.addEventListener("abort",k,{once:!0});let _;s&&!y.signal.aborted&&(_=setTimeout(()=>{y.signal.aborted||y.abort(new ae(`DAG node "${b}" exceeded nodeTimeoutMs of ${o}ms`,o))},o));let I={};for(let S of i.upstream.get(b)??[])I[S]=c[S];try{let S=await h.run(I,y.signal);return{id:b,result:S}}finally{_!==void 0&&clearTimeout(_),f.signal.removeEventListener("abort",k)}}));for(let b=0;b<w.length;b++){let h=w[b];if(h.status==="fulfilled"){let{id:y,result:k}=h.value;c[y]=k,u.add(y),p.delete(y);for(let _ of i.downstream.get(y)??[])p.set(_,p.get(_)-1)}else{let y=h.reason instanceof Error?h.reason:new Error(String(h.reason)),k=m[b];l.push({id:k,error:y}),u.add(k),p.delete(k),Um(k,i.downstream,d),r&&f.abort("fail-fast")}}}}finally{e.removeEventListener("abort",g)}return{outputs:c,failed:l,skipped:Array.from(d)}}async function Ea(t){let{manager:e,parentSession:n,nodes:r,edges:o,failFast:s,nodeTimeoutMs:i}=t,a=n.abortSignal??new AbortController().signal,c=r.map(l=>({id:l.id,async run(d,u){let p=await e.forkSubagent({parent:{sessionId:n.sessionId},config:{model:l.model??"sonnet",systemPrompt:l.systemPrompt,...l.canUseTool!==void 0?{canUseTool:l.canUseTool}:{},...l.cwd!==void 0?{cwd:l.cwd}:{},...l.readRoots!==void 0?{readRoots:l.readRoots}:{},...l.writeRoots!==void 0?{writeRoots:l.writeRoots}:{}},idPrefix:l.idPrefix??`dag-${l.id}`,...l.outputSchema!==void 0?{outputSchema:l.outputSchema}:{},...l.agentType!==void 0?{agentType:l.agentType}:{},...l.parentId!==void 0?{parentId:l.parentId}:{}}),f=()=>{p.cancel().catch(()=>{})};u.aborted?p.cancel().catch(()=>{}):u.addEventListener("abort",f,{once:!0});try{if(u.aborted)throw new DOMException("Aborted","AbortError");let g=l.promptBuilder(d),m=await p.runToResult(g);if(m.status!=="succeeded"){let w,b=u.reason;throw b instanceof ae?w=new Error(`Subagent ${l.id} aborted: ${b.message}`,m.error?{cause:m.error}:{}):w=m.error??new Error(`Subagent ${l.id} ${m.status}`),Zo(w,{partialOutput:m.partialOutput,subagentId:m.id})}return m.output??m.message?.content}finally{u.removeEventListener("abort",f),await p.teardown().catch(()=>{})}}}));return xa({nodes:c,edges:o},a,{failFast:s,nodeTimeoutMs:i})}var Ta=1e3,kn=36e5,_a=1,Aa=1e3;function Wm(t){if(typeof t!="object"||t===null)throw new Error("Compose tool input must be an object");let e=t,n=e.nodes;if(!Array.isArray(n)||n.length===0)throw new Error('Compose tool requires a non-empty "nodes" array');let r=20;if(n.length>r)throw new Error(`Compose tool supports at most ${r} nodes (got ${n.length}). Split into multiple compose calls for larger workloads.`);let o=[],s=new Set;for(let u of n){if(typeof u!="object"||u===null)throw new Error("Each node must be an object");let p=u,f=p.id;if(typeof f!="string"||f.trim().length===0)throw new Error('Each node must have a non-empty "id" string');if(!/^[A-Za-z0-9_-]+$/.test(f)){let w=f.replace(/[\x00-\x1f\x7f]/g,"?").slice(0,32);throw new Error(`Node id "${w}" must match /^[A-Za-z0-9_-]+$/ (alphanumeric, underscore, hyphen)`)}if(s.has(f))throw new Error(`Duplicate node ID: ${f}`);s.add(f);let g=p.prompt;if(typeof g!="string"||g.trim().length===0)throw new Error(`Node "${f}" must have a non-empty "prompt" string`);let m;if(p.model!==void 0){if(typeof p.model!="string")throw new Error(`Node "${f}" model must be a string`);m=p.model}o.push({id:f,prompt:g,model:m})}let i;if(e.edges!==void 0){if(!Array.isArray(e.edges))throw new Error('"edges" must be an array');i=[];for(let u of e.edges){if(typeof u!="object"||u===null)throw new Error("Each edge must be an object");let p=u;if(typeof p.from!="string"||typeof p.to!="string")throw new Error('Each edge must have "from" and "to" strings');if(!s.has(p.from))throw new Error(`Edge references non-existent node: ${p.from}`);if(!s.has(p.to))throw new Error(`Edge references non-existent node: ${p.to}`);i.push({from:p.from,to:p.to})}}let a;if(e.fail_fast!==void 0){if(typeof e.fail_fast!="boolean")throw new Error('"fail_fast" must be a boolean');a=e.fail_fast}let c=[],l;if(e.node_timeout_ms!==void 0){let u=e.node_timeout_ms;if(typeof u!="number"||!Number.isFinite(u)||u<=0)throw new Error('"node_timeout_ms" must be a positive finite number (milliseconds)');if(u<Ta)throw new Error(`"node_timeout_ms" must be at least ${Ta}ms (got ${u}). Sub-second timeouts are almost always a unit mistake.`);l=Math.min(kn,u),u>kn&&c.push(`node_timeout_ms clamped: requested ${u}ms exceeds the maximum ${kn}ms; using ${kn}ms.`)}let d;if(e.max_tool_calls_per_node!==void 0){let u=e.max_tool_calls_per_node;if(typeof u!="number"||!Number.isFinite(u)||u<=0)throw new Error('"max_tool_calls_per_node" must be a positive finite number');if(!Number.isInteger(u))throw new Error(`"max_tool_calls_per_node" must be an integer (got ${u}). Tool calls are discrete events; fractional budgets are not meaningful.`);if(u<_a)throw new Error(`"max_tool_calls_per_node" must be at least ${_a}`);if(u>Aa)throw new Error(`"max_tool_calls_per_node" must be at most ${Aa} (got ${u}). A larger budget no longer constrains useful work.`);d=u}return{parsed:{nodes:o,edges:i,fail_fast:a,node_timeout_ms:l,max_tool_calls_per_node:d},warnings:c}}var dt=8e3,Ra=500,Pa=4e3;function Gm(t){if(t==null)return;let e=typeof t=="string"?t:JSON.stringify(t);if(e.length!==0)return e.length>Pa?e.slice(0,Pa)+`
|
|
1612
1612
|
\u2026 (truncated)`:e}function Km(t,e,n,r){try{let o=Er(Ve(),t,"compose",e);jm(o,{recursive:!0});let s=Er(o,`${n}.txt`);return Bm(s,r,"utf8"),s}catch{return}}function qm(t,e){let n=[],r=[];for(let[o,s]of Object.entries(t.outputs)){let i=typeof s=="string"?s:s!=null?JSON.stringify(s):"(no output)",a;if(i.length>dt){let c=Km(e.sessionId,e.callId,o,i);r.push({nodeId:o,emittedChars:dt,totalChars:i.length,...c!==void 0?{spillPath:c}:{}});let l=c!==void 0?`
|
|
1613
1613
|
\u2026 (truncated at ${dt} / ${i.length} chars \u2014 full output at ${c})`:`
|
|
1614
1614
|
\u2026 (truncated at ${dt} / ${i.length} chars)`;a=i.slice(0,dt)+l}else a=i;n.push(`## ${o}
|
|
@@ -1635,9 +1635,9 @@ ${y.map(S=>`> - ${S}`).join(`
|
|
|
1635
1635
|
|
|
1636
1636
|
`:"")+w,I=g.failed.length>0;return{content:_,isError:I}}catch(u){let p=u instanceof Error?u.message:String(u);return ee({event:"compose.failed",parent_session_id:this.ctx.parentSession.sessionId,error_message:p.slice(0,240),duration_ms:Date.now()-d}).catch(()=>{}),{content:`Compose execution error: ${p}`,isError:!0}}finally{await c.teardownAll()}}};function Tr(t,e,n,r){let o=ga();o.register("SubagentStop",ha);let s=n??new V;return r!==void 0&&o.register("PreToolUse",va(r)),o.register("SessionEnd",Pn(s,e)),o.register("SessionEnd",i=>i.event!=="SessionEnd"?{}:(i.sessionId&&Ia(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 Jm="[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 _r(t,e){return!t||!e?t:`${t}
|
|
1637
1637
|
|
|
1638
|
-
${Jm}`}var y_=300*1e3;var Sn=class extends Error{constructor(e,n){super(`Background job cap reached (${e}/${n} running). Wait for existing jobs to finish or cancel them before spawning more.`),this.name="BackgroundJobCapError"}};var Vm=new Set;function Ca(t){return Vm.has(t)}var Ym=new Set,Xm=new Set;function Ma(t){for(let e of Ym)e(t)}function Da(t){for(let e of Xm)e(t)}function Qm(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 Zm(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 qe=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??ze;if(n>=r){let c=Qm(e.input);return ee({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=Zm(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.body,s.pluginPath,o.arguments,e);let a=Ce(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=Ca(e.name);o&&Da(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,callId:r.id,dispatchSkill:this.createDispatchSkillCallback(r)})}catch(l){i=l}finally{if(o){let l=Date.now()-s;Ma({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??ze,s={...e};if(!this.ctx.childProviderFactory||r>=o)return{childConfig:s,childManager:void 0};let i=new P({parentAbortSignal:n}),a=new Je({subagentManager:i,parentSession:ut(n),defaultConfig:{model:s.model,apiKey:this.ctx.apiKey,...this.ctx.baseUrl!==void 0?{baseUrl:this.ctx.baseUrl}:{}},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 P({parentAbortSignal:r.signal,apiKey:this.ctx.apiKey,...this.ctx.baseUrl!==void 0?{baseUrl:this.ctx.baseUrl}:{},progressSink:oe()}),{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.",d=await c.runToResult(l);return d.status==="succeeded"&&d.message?{content:d.message.content}:{content:d.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,s){if(s.signal.aborted)return{content:"Skill call aborted",isError:!0};let i=new P({parentAbortSignal:s.signal,apiKey:this.ctx.apiKey,...this.ctx.baseUrl!==void 0?{baseUrl:this.ctx.baseUrl}:{},progressSink:oe()}),{childConfig:a,childManager:c}=this.buildForkedChildConfig({model:this.ctx.defaultSubagentModel??this.ctx.defaultModel??"sonnet",systemPrompt:n,env:{PLUGIN_ROOT:r}},s.signal);try{let l=await i.forkSubagent({parent:this.ctx.parentSession,config:a,idPrefix:`skill-${e}`,parentId:s.id,agentType:e}),d=o&&o.length>0?o:"Run the skill.",u=await l.runToResult(d);return u.status==="succeeded"&&u.message?{content:u.message.content}:{content:u.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 c?.teardownAll(),await i.teardownAll()}}getPluginSkillBody(e){return this.pluginBodies||(this.pluginBodies=pn(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 ze=3;function ut(t){return{sessionId:void 0,getInputStreamRef:()=>({pushUserMessage:()=>{}}),abortSignal:t}}var eg=[...it,"agent","skill"];function Oa(){return({childExecutor:t,childSkillExecutor:e})=>new ie({permissions:{allowedTools:eg},subagentExecutor:t,skillExecutor:e})}function Fa(t,e,n,r){let o=(s,i,a)=>new qe({parentSession:ut(a),defaultModel:t,apiKey:e,...r!==void 0?{baseUrl:r}:{},depth:s,maxDepth:i,childProviderFactory:n,childSkillExecutorFactory:o});return o}function La(t){return t.replace(/\x1b\[[0-9;]*[a-zA-Z]/g,"")}function tg(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",d=e.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)}`);l=d}return{prompt:n,model:r,max_turns:s,id_prefix:a,mode:l}}function Ar(t){try{return ee(t).catch(()=>{})}catch{return Promise.resolve()}}function pt(t,e=240){return t.length<=e?t:t.slice(0,e)+"\u2026"}function $a(t){if(t!=null){if(typeof t=="string")return t.length;try{return JSON.stringify(t).length}catch{return}}}var ng=4096,Na=1024;function rg(t){if(t==null)return;let e=$a(t);return e!==void 0&&e>ng?{truncated:!0,chars:e}:t}function og(t){let e={status:t.status,error:pt(t.errorMessage,Na),subagent_id:t.subagentId};t.schemaErrorMessage&&(e.schemaError=pt(t.schemaErrorMessage,Na));let n=rg(t.partialOutput);return n!==void 0&&(e.partialOutput=n),e}var Je=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=tg(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??ze,s,i={model:n.model??this.ctx.defaultSubagentModel??"sonnet",apiKey:this.ctx.defaultConfig.apiKey,systemPrompt:this.ctx.defaultConfig.systemPrompt,baseUrl:this.ctx.defaultConfig.baseUrl,maxTurns:n.max_turns},a;if(this.ctx.childProviderFactory&&r<o){s=new P({parentAbortSignal:e.signal}),a=ut(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"?La(n.id_prefix).replace(/[\r\n]+/g," ").trim()||"agent":La(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 await c.teardown().catch(m=>C("subagent-executor: handle teardown failed: "+(m instanceof Error?m.message:String(m)))),{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;try{f=p.register({handle:c,prompt:n.prompt,model:i.model??"sonnet"})}catch(m){if(m instanceof Sn)return await c.teardown().catch(w=>C("subagent-executor: handle teardown failed after cap error: "+(w instanceof Error?w.message:String(w)))),{content:m.message,isError:!0};throw m}let 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 l=()=>{c.cancel()};e.signal.addEventListener("abort",l,{once:!0});let d=Date.now(),u=this.ctx.parentSession.sessionId;try{let p=await c.runToResult(n.prompt);if(p.status==="succeeded"&&p.message){let w=p.message.content,b=typeof w=="string"?w:JSON.stringify(w),h=p.trace;return Ar({event:"subagent.completed",subagent_id:c.id,parent_session_id:u,status:p.status,duration_ms:Date.now()-d,content_chars:b.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(y=>y.name))]):void 0}),{content:b}}let f=p.error?.message??"Subagent failed with no output",g=p.trace;Ar({event:"subagent.failed",subagent_id:c.id,id_prefix:n.id_prefix,parent_session_id:u,status:p.status,duration_ms:Date.now()-d,error_message:pt(f),schema_error:p.schemaError?pt(p.schemaError.message):void 0,partial_output_chars:$a(p.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(w=>w.name))]):void 0});let m=og({status:p.status,errorMessage:f,schemaErrorMessage:p.schemaError?.message,partialOutput:p.partialOutput,subagentId:c.id});return{content:JSON.stringify(m),isError:!0}}catch(p){let f=p instanceof Error?p.message:String(p);throw Ar({event:"subagent.failed",subagent_id:c.id,id_prefix:n.id_prefix,parent_session_id:u,status:"failed",duration_ms:Date.now()-d,error_message:pt(f),depth:r}),p}finally{e.signal.removeEventListener("abort",l),await s?.teardownAll(),await c.teardown()}}};var Ba="unknown";try{let t=Ha(ja(Ua(import.meta.url)),"..","package.json"),e=JSON.parse(Rr(t,"utf8"));e.version&&(Ba=e.version)}catch{console.warn("\u26A0\uFE0F [daemon] Could not read package.json at startup \u2014 version drift check disabled.")}async function ig(){let t;try{t=dr()}catch(l){console.error("\u274C Configuration error:",l.message),process.exit(1)}let e=We(t.model);if(e==="openai-compatible"||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 OpenAI auth":"\u{1F4DD} Will attempt API key from ~/.codex/auth.json (run `afk provider auth diagnose` for details)")}else{let l=lt();(!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)),Nt(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}lg(Ye());let n=process.env.TELEGRAM_BOT_TOKEN;n||(console.error("\u274C Error: TELEGRAM_BOT_TOKEN environment variable is required"),console.error(`
|
|
1638
|
+
${Jm}`}var y_=300*1e3;var Sn=class extends Error{constructor(e,n){super(`Background job cap reached (${e}/${n} running). Wait for existing jobs to finish or cancel them before spawning more.`),this.name="BackgroundJobCapError"}};var Vm=new Set;function Ca(t){return Vm.has(t)}var Ym=new Set,Xm=new Set;function Ma(t){for(let e of Ym)e(t)}function Oa(t){for(let e of Xm)e(t)}function Qm(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 Zm(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 qe=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??ze;if(n>=r){let c=Qm(e.input);return ee({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=Zm(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.body,s.pluginPath,o.arguments,e);let a=Ce(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=Ca(e.name);o&&Oa(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,callId:r.id,dispatchSkill:this.createDispatchSkillCallback(r)})}catch(l){i=l}finally{if(o){let l=Date.now()-s;Ma({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??ze,s={...e};if(!this.ctx.childProviderFactory||r>=o)return{childConfig:s,childManager:void 0};let i=new P({parentAbortSignal:n,...this.ctx.traceWriter!==void 0?{traceWriter:this.ctx.traceWriter}:{}}),a=new Je({subagentManager:i,parentSession:ut(n),defaultConfig:{model:s.model,apiKey:this.ctx.apiKey,...this.ctx.baseUrl!==void 0?{baseUrl:this.ctx.baseUrl}:{}},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 P({parentAbortSignal:r.signal,apiKey:this.ctx.apiKey,...this.ctx.baseUrl!==void 0?{baseUrl:this.ctx.baseUrl}:{},...this.ctx.traceWriter!==void 0?{traceWriter:this.ctx.traceWriter}:{},progressSink:oe()}),{childConfig:i,childManager:a}=this.buildForkedChildConfig({model:e.model??this.ctx.defaultSubagentModel??this.ctx.defaultModel??"sonnet",systemPrompt:o,...this.ctx.traceWriter!==void 0?{traceWriter:this.ctx.traceWriter}:{}},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.",d=await c.runToResult(l);return d.status==="succeeded"&&d.message?{content:d.message.content}:{content:d.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,s){if(s.signal.aborted)return{content:"Skill call aborted",isError:!0};let i=new P({parentAbortSignal:s.signal,apiKey:this.ctx.apiKey,...this.ctx.baseUrl!==void 0?{baseUrl:this.ctx.baseUrl}:{},...this.ctx.traceWriter!==void 0?{traceWriter:this.ctx.traceWriter}:{},progressSink:oe()}),{childConfig:a,childManager:c}=this.buildForkedChildConfig({model:this.ctx.defaultSubagentModel??this.ctx.defaultModel??"sonnet",systemPrompt:n,env:{PLUGIN_ROOT:r},...this.ctx.traceWriter!==void 0?{traceWriter:this.ctx.traceWriter}:{}},s.signal);try{let l=await i.forkSubagent({parent:this.ctx.parentSession,config:a,idPrefix:`skill-${e}`,parentId:s.id,agentType:e}),d=o&&o.length>0?o:"Run the skill.",u=await l.runToResult(d);return u.status==="succeeded"&&u.message?{content:u.message.content}:{content:u.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 c?.teardownAll(),await i.teardownAll()}}getPluginSkillBody(e){return this.pluginBodies||(this.pluginBodies=pn(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 ze=3;function ut(t){return{sessionId:void 0,getInputStreamRef:()=>({pushUserMessage:()=>{}}),abortSignal:t}}var eg=[...it,"agent","skill"];function Da(){return({childExecutor:t,childSkillExecutor:e})=>new ie({permissions:{allowedTools:eg},subagentExecutor:t,skillExecutor:e})}function Fa(t,e,n,r,o){let s=(i,a,c)=>new qe({parentSession:ut(c),defaultModel:t,apiKey:e,...r!==void 0?{baseUrl:r}:{},depth:i,maxDepth:a,childProviderFactory:n,childSkillExecutorFactory:s,...o!==void 0?{traceWriter:o}:{}});return s}function La(t){return t.replace(/\x1b\[[0-9;]*[a-zA-Z]/g,"")}function tg(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",d=e.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)}`);l=d}return{prompt:n,model:r,max_turns:s,id_prefix:a,mode:l}}function Ar(t){try{return ee(t).catch(()=>{})}catch{return Promise.resolve()}}function pt(t,e=240){return t.length<=e?t:t.slice(0,e)+"\u2026"}function $a(t){if(t!=null){if(typeof t=="string")return t.length;try{return JSON.stringify(t).length}catch{return}}}var ng=4096,Na=1024;function rg(t){if(t==null)return;let e=$a(t);return e!==void 0&&e>ng?{truncated:!0,chars:e}:t}function og(t){let e={status:t.status,error:pt(t.errorMessage,Na),subagent_id:t.subagentId};t.schemaErrorMessage&&(e.schemaError=pt(t.schemaErrorMessage,Na));let n=rg(t.partialOutput);return n!==void 0&&(e.partialOutput=n),e}var Je=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=tg(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??ze,s,i={model:n.model??this.ctx.defaultSubagentModel??"sonnet",apiKey:this.ctx.defaultConfig.apiKey,systemPrompt:this.ctx.defaultConfig.systemPrompt,baseUrl:this.ctx.defaultConfig.baseUrl,maxTurns:n.max_turns},a;if(this.ctx.childProviderFactory&&r<o){s=new P({parentAbortSignal:e.signal}),a=ut(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"?La(n.id_prefix).replace(/[\r\n]+/g," ").trim()||"agent":La(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 await c.teardown().catch(m=>C("subagent-executor: handle teardown failed: "+(m instanceof Error?m.message:String(m)))),{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;try{f=p.register({handle:c,prompt:n.prompt,model:i.model??"sonnet"})}catch(m){if(m instanceof Sn)return await c.teardown().catch(w=>C("subagent-executor: handle teardown failed after cap error: "+(w instanceof Error?w.message:String(w)))),{content:m.message,isError:!0};throw m}let 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 l=()=>{c.cancel()};e.signal.addEventListener("abort",l,{once:!0});let d=Date.now(),u=this.ctx.parentSession.sessionId;try{let p=await c.runToResult(n.prompt);if(p.status==="succeeded"&&p.message){let w=p.message.content,b=typeof w=="string"?w:JSON.stringify(w),h=p.trace;return Ar({event:"subagent.completed",subagent_id:c.id,parent_session_id:u,status:p.status,duration_ms:Date.now()-d,content_chars:b.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(y=>y.name))]):void 0}),{content:b}}let f=p.error?.message??"Subagent failed with no output",g=p.trace;Ar({event:"subagent.failed",subagent_id:c.id,id_prefix:n.id_prefix,parent_session_id:u,status:p.status,duration_ms:Date.now()-d,error_message:pt(f),schema_error:p.schemaError?pt(p.schemaError.message):void 0,partial_output_chars:$a(p.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(w=>w.name))]):void 0});let m=og({status:p.status,errorMessage:f,schemaErrorMessage:p.schemaError?.message,partialOutput:p.partialOutput,subagentId:c.id});return{content:JSON.stringify(m),isError:!0}}catch(p){let f=p instanceof Error?p.message:String(p);throw Ar({event:"subagent.failed",subagent_id:c.id,id_prefix:n.id_prefix,parent_session_id:u,status:"failed",duration_ms:Date.now()-d,error_message:pt(f),depth:r}),p}finally{e.signal.removeEventListener("abort",l),await s?.teardownAll(),await c.teardown()}}};var Ba="unknown";try{let t=Ha(ja(Ua(import.meta.url)),"..","package.json"),e=JSON.parse(Rr(t,"utf8"));e.version&&(Ba=e.version)}catch{console.warn("\u26A0\uFE0F [daemon] Could not read package.json at startup \u2014 version drift check disabled.")}async function ig(){let t;try{t=dr()}catch(l){console.error("\u274C Configuration error:",l.message),process.exit(1)}let e=We(t.model);if(e==="openai-compatible"||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 OpenAI auth":"\u{1F4DD} Will attempt API key from ~/.codex/auth.json (run `afk provider auth diagnose` for details)")}else{let l=lt();(!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)),Nt(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}lg(Ye());let n=process.env.TELEGRAM_BOT_TOKEN;n||(console.error("\u274C Error: TELEGRAM_BOT_TOKEN environment variable is required"),console.error(`
|
|
1639
1639
|
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=rt(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(`
|
|
1640
|
-
This is an allowlist that gates who can message the bot.`),console.error("Run `afk telegram setup` to set it interactively, or set it manually:"),console.error(" AFK_TELEGRAM_ALLOWED_CHAT_IDS=123456789,-100987654321"),process.exit(1)),console.log("\u{1F50E} Validating bot token...");let o=await
|
|
1640
|
+
This is an allowlist that gates who can message the bot.`),console.error("Run `afk telegram setup` to set it interactively, or set it manually:"),console.error(" AFK_TELEGRAM_ALLOWED_CHAT_IDS=123456789,-100987654321"),process.exit(1)),console.log("\u{1F50E} Validating bot token...");let o=await Do(n);o||(console.error("\u274C Error: TELEGRAM_BOT_TOKEN was rejected by Telegram (getMe failed)"),console.error(" The token may be revoked, malformed, or your network may be unreachable."),console.error(" Re-run `afk telegram setup` to refresh it."),process.exit(1));let s=o.username?`@${o.username}`:o.firstName;console.log(""),console.log(`\u{1F916} Starting Agent AFK Telegram Bot as ${s} (id ${o.id})`),console.log(`\u{1F4E1} Model: ${t.model} \xB7 Provider: ${e}`),console.log(`\u{1F512} Allowlist: ${r.size} chat ID(s)`);let i=new V,a=process.env.AFK_TELEGRAM_CWD,c=new Lt({botToken:n,apiKey:t.apiKey??"",dataDir:process.env.TELEGRAM_DATA_DIR||"./data/telegram-sessions",defaultModel:t.model,verbose:process.env.TELEGRAM_VERBOSE==="true",allowedChatIds:r,settingSources:["user","project"],createSession:async l=>{let d=Oe(l.model)??l.model;console.log(`Creating session with model: ${l.model} -> ${d}`);let u=We(d),p=u==="openai-compatible"||u==="openai-codex",f=p?void 0:vi(),g;if(!p){let k,_=l.apiKey??t.apiKey??"",I=t.baseUrl,S=l.cwd??a,x=new P({apiKey:_,...I!==void 0?{baseUrl:I}:{},...S!==void 0&&S.length>0?{cwd:S}:{}}),A={get sessionId(){return k?.sessionId},getInputStreamRef(){return k?.getInputStreamRef?.()??{pushUserMessage:()=>{}}},get abortSignal(){return k?.abortSignal??new AbortController().signal}},R=Da(),F=Fa(l.model,_,R,I),v=new Je({subagentManager:x,parentSession:A,defaultConfig:{apiKey:_,systemPrompt:l.systemPrompt??t.systemPrompt,...I!==void 0?{baseUrl:I}:{}},defaultSubagentModel:un(),childProviderFactory:R,childSkillExecutorFactory:F}),E=new qe({parentSession:A,defaultModel:l.model,defaultSubagentModel:un(),apiKey:_,childProviderFactory:R,childSkillExecutorFactory:F,...I!==void 0?{baseUrl:I}:{}}),M=l.systemPrompt??t.systemPrompt,O=new vn({parentSession:A,defaultModel:l.model,defaultSubagentModel:un(),apiKey:_,...I!==void 0?{baseUrl:I}:{},systemPrompt:typeof M=="string"?M:""}),G=[...it,...St,"agent","skill","compose"];g=new ie({permissions:{allowedTools:G},subagentExecutor:v,skillExecutor:E,composeExecutor:O});let L=l.systemPrompt??t.systemPrompt,z=t.autoRouting?.telegram??!1,re=typeof L=="string"?_r(L,z):L,W=new we({...l.apiKey!==void 0?{apiKey:l.apiKey}:{},model:l.model,...re!==void 0?{systemPrompt:re}:{},maxTurns:100,...f!==void 0?{maxOutputTokens:f}:{},...I!==void 0?{baseUrl:I}:{},...S!==void 0&&S.length>0?{cwd:S}:{},provider:g,hookRegistry:Tr(void 0,"telegram",i).registry});return k=W,W}let m=l.systemPrompt??t.systemPrompt,w=t.autoRouting?.telegram??!1,b=typeof m=="string"?_r(m,w):m,h=l.cwd??a;return new we({...l.apiKey!==void 0?{apiKey:l.apiKey}:{},model:l.model,...b!==void 0?{systemPrompt:b}:{},maxTurns:100,...f!==void 0?{maxOutputTokens:f}:{},...h!==void 0&&h.length>0?{cwd:h}:{},hookRegistry:Tr(void 0,"telegram",i).registry})}});try{c.start(),console.log("\u2705 Bot started successfully!"),console.log(`
|
|
1641
1641
|
\u{1F4DD} Slash commands (Agent SDK):`),console.log(" /start - Welcome and command list"),console.log(" /help - Show command list"),console.log(" /clear - Clear conversation history"),console.log(" /compact - Compact history (summarize older messages)"),console.log(" /model - Switch model (opus/sonnet/haiku/gpt-5.4/...)"),console.log(`
|
|
1642
1642
|
\u{1F4AC} Send any message to chat with the agent.`),console.log(`
|
|
1643
1643
|
\u23F9\uFE0F Press Ctrl+C to stop the bot.`);let l=setInterval(()=>{let u=c.getStats();console.log(`
|